From a19fd52ae8c4736b334e42fdb2d4690b4316f9d1 Mon Sep 17 00:00:00 2001 From: TJ Koury Date: Mon, 6 May 2024 10:42:41 -0400 Subject: [PATCH] deploy --- docs/Cesium.js | 946 ++++++++++++++++++++++++------------------------- 1 file changed, 473 insertions(+), 473 deletions(-) diff --git a/docs/Cesium.js b/docs/Cesium.js index dc019f61..c0bb64be 100644 --- a/docs/Cesium.js +++ b/docs/Cesium.js @@ -23,7 +23,7 @@ * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. */ -var Cesium=(()=>{var pMt=Object.create;var PO=Object.defineProperty;var uMt=Object.getOwnPropertyDescriptor;var ZMt=Object.getOwnPropertyNames;var VMt=Object.getPrototypeOf,bMt=Object.prototype.hasOwnProperty;var Og=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,n)=>(typeof require<"u"?require:e)[n]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var Vo=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),vO=(t,e)=>{for(var n in e)PO(t,n,{get:e[n],enumerable:!0})},Oct=(t,e,n,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of ZMt(e))!bMt.call(t,o)&&o!==n&&PO(t,o,{get:()=>e[o],enumerable:!(i=uMt(e,o))||i.enumerable});return t};var R=(t,e,n)=>(n=t!=null?pMt(VMt(t)):{},Oct(e||!t||!t.__esModule?PO(n,"default",{value:t,enumerable:!0}):n,t)),RMt=t=>Oct(PO({},"__esModule",{value:!0}),t);var W=Vo(()=>{globalThis.CESIUM_WORKERS=atob("var CesiumWorkers=(()=>{var b8=Object.create;var qR=Object.defineProperty;var F8=Object.getOwnPropertyDescriptor;var Y8=Object.getOwnPropertyNames;var S8=Object.getPrototypeOf,O8=Object.prototype.hasOwnProperty;var Xo=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,i)=>(typeof require<"u"?require:e)[i]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')}),jB=t=>e=>{var i=t[e];if(i)return i();throw new Error("Module not found in bundle: "+e)};var O=(t,e)=>()=>(t&&(e=t(t=0)),e);var ts=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),He=(t,e)=>{for(var i in e)qR(t,i,{get:e[i],enumerable:!0})},HB=(t,e,i,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Y8(e))!O8.call(t,s)&&s!==i&&qR(t,s,{get:()=>e[s],enumerable:!(n=F8(e,s))||n.enumerable});return t};var co=(t,e,i)=>(i=t!=null?b8(S8(t)):{},HB(e||!t||!t.__esModule?qR(i,"default",{value:t,enumerable:!0}):i,t)),V8=t=>HB(qR({},"__esModule",{value:!0}),t);function G8(t){return t!=null}var m,mt=O(()=>{m=G8});function B8(t){let e,i=t.name,n=t.message;m(i)&&m(n)?e=`${i}: ${n}`:e=t.toString();let s=t.stack;return m(s)&&(e+=`
${s}`),e}var vB,zB=O(()=>{mt();vB=B8});var t0={};He(t0,{default:()=>Wi});function W8(t){async function e({data:n}){let s=[],o={id:n.id,result:void 0,error:void 0};self.CESIUM_BASE_URL=n.baseUrl;try{let r=await t(n.parameters,s);o.result=r}catch(r){r instanceof Error?o.error={name:r.name,message:r.message,stack:r.stack}:o.error=r}n.canTransferArrayBuffer||(s.length=0);try{postMessage(o,s)}catch(r){o.result=void 0,o.error=`postMessage failed with error: ${vB(r)}
  with responseMessage: ${JSON.stringify(o)}`,postMessage(o)}}function i(n){postMessage({id:n.data?.id,error:`postMessage failed with error: ${JSON.stringify(n)}`})}return self.onmessage=e,self.onmessageerror=i,self}var Wi,Ns=O(()=>{zB();Wi=W8});var e0={};He(e0,{default:()=>M8});async function D8(){return[]}var M8,i0=O(()=>{Ns();M8=Wi(D8)});var KB,XB,$i,ic=O(()=>{KB={FIXED:0,INERTIAL:1,TEME:2,VVLH:3,ENU:4,NED:5,NEU:6,RIC:7},XB=[KB.NEU],$i=Object.freeze(KB)});function fl(t){this.name="DeveloperError",this.message=t;let e;try{throw new Error}catch(i){e=i.stack}this.stack=e}var Y,Vt=O(()=>{mt();m(Object.create)&&(fl.prototype=Object.create(Error.prototype),fl.prototype.constructor=fl);fl.prototype.toString=function(){let t=`${this.name}: ${this.message}`;return m(this.stack)&&(t+=`
${this.stack.toString()}`),t};fl.throwInstantiationError=function(){throw new fl("This function defines an interface and should not be called directly.")};Y=fl});function U8(t){return`${t} is required, actual value was undefined`}function _m(t,e,i){return`Expected ${i} to be typeof ${e}, actual typeof was ${t}`}var bs,p,ae=O(()=>{mt();Vt();bs={};bs.typeOf={};bs.defined=function(t,e){if(!m(e))throw new Y(U8(t))};bs.typeOf.func=function(t,e){if(typeof e!="function")throw new Y(_m(typeof e,"function",t))};bs.typeOf.string=function(t,e){if(typeof e!="string")throw new Y(_m(typeof e,"string",t))};bs.typeOf.number=function(t,e){if(typeof e!="number")throw new Y(_m(typeof e,"number",t))};bs.typeOf.number.lessThan=function(t,e,i){if(bs.typeOf.number(t,e),e>=i)throw new Y(`Expected ${t} to be less than ${i}, actual value was ${e}`)};bs.typeOf.number.lessThanOrEquals=function(t,e,i){if(bs.typeOf.number(t,e),e>i)throw new Y(`Expected ${t} to be less than or equal to ${i}, actual value was ${e}`)};bs.typeOf.number.greaterThan=function(t,e,i){if(bs.typeOf.number(t,e),e<=i)throw new Y(`Expected ${t} to be greater than ${i}, actual value was ${e}`)};bs.typeOf.number.greaterThanOrEquals=function(t,e,i){if(bs.typeOf.number(t,e),e<i)throw new Y(`Expected ${t} to be greater than or equal to ${i}, actual value was ${e}`)};bs.typeOf.object=function(t,e){if(typeof e!="object")throw new Y(_m(typeof e,"object",t))};bs.typeOf.bool=function(t,e){if(typeof e!="boolean")throw new Y(_m(typeof e,"boolean",t))};bs.typeOf.bigint=function(t,e){if(typeof e!="bigint")throw new Y(_m(typeof e,"bigint",t))};bs.typeOf.number.equals=function(t,e,i,n){if(bs.typeOf.number(t,i),bs.typeOf.number(e,n),i!==n)throw new Y(`${t} must be equal to ${e}, the actual values are ${i} and ${n}`)};p=bs});function nE(){this._listeners=[],this._scopes=[],this._toRemove=[],this._insideRaiseEvent=!1}function Q8(t,e){return e-t}var We,xi=O(()=>{ae();mt();Object.defineProperties(nE.prototype,{numberOfListeners:{get:function(){return this._listeners.length-this._toRemove.length}}});nE.prototype.addEventListener=function(t,e){p.typeOf.func("listener",t),this._listeners.push(t),this._scopes.push(e);let i=this;return function(){i.removeEventListener(t,e)}};nE.prototype.removeEventListener=function(t,e){p.typeOf.func("listener",t);let i=this._listeners,n=this._scopes,s=-1;for(let o=0;o<i.length;o++)if(i[o]===t&&n[o]===e){s=o;break}return s!==-1?(this._insideRaiseEvent?(this._toRemove.push(s),i[s]=void 0,n[s]=void 0):(i.splice(s,1),n.splice(s,1)),!0):!1};nE.prototype.raiseEvent=function(){this._insideRaiseEvent=!0;let t,e=this._listeners,i=this._scopes,n=e.length;for(t=0;t<n;t++){let o=e[t];m(o)&&e[t].apply(i[t],arguments)}let s=this._toRemove;if(n=s.length,n>0){for(s.sort(Q8),t=0;t<n;t++){let o=s[t];e.splice(o,1),i.splice(o,1)}s.length=0}this._insideRaiseEvent=!1};We=nE});function $R(){Y.throwInstantiationError()}var qB,$B=O(()=>{Vt();Object.defineProperties($R.prototype,{name:{get:Y.throwInstantiationError},clock:{get:Y.throwInstantiationError},entities:{get:Y.throwInstantiationError},isLoading:{get:Y.throwInstantiationError},changedEvent:{get:Y.throwInstantiationError},errorEvent:{get:Y.throwInstantiationError},loadingEvent:{get:Y.throwInstantiationError},show:{get:Y.throwInstantiationError},clustering:{get:Y.throwInstantiationError}});$R.prototype.update=function(t){Y.throwInstantiationError()};$R.setLoading=function(t,e){t._isLoading!==e&&(e?t._entityCollection.suspendEvents():t._entityCollection.resumeEvents(),t._isLoading=e,t._loading.raiseEvent(t,e))};qB=$R});function tW(t,e){return t??e}var Z,bt=O(()=>{tW.EMPTY_OBJECT=Object.freeze({});Z=tW});var iW=ts((_pt,eW)=>{var vA=function(t){t==null&&(t=new Date().getTime()),this.N=624,this.M=397,this.MATRIX_A=2567483615,this.UPPER_MASK=2147483648,this.LOWER_MASK=2147483647,this.mt=new Array(this.N),this.mti=this.N+1,t.constructor==Array?this.init_by_array(t,t.length):this.init_seed(t)};vA.prototype.init_seed=function(t){for(this.mt[0]=t>>>0,this.mti=1;this.mti<this.N;this.mti++){var t=this.mt[this.mti-1]^this.mt[this.mti-1]>>>30;this.mt[this.mti]=(((t&4294901760)>>>16)*1812433253<<16)+(t&65535)*1812433253+this.mti,this.mt[this.mti]>>>=0}};vA.prototype.init_by_array=function(t,e){var i,n,s;for(this.init_seed(19650218),i=1,n=0,s=this.N>e?this.N:e;s;s--){var o=this.mt[i-1]^this.mt[i-1]>>>30;this.mt[i]=(this.mt[i]^(((o&4294901760)>>>16)*1664525<<16)+(o&65535)*1664525)+t[n]+n,this.mt[i]>>>=0,i++,n++,i>=this.N&&(this.mt[0]=this.mt[this.N-1],i=1),n>=e&&(n=0)}for(s=this.N-1;s;s--){var o=this.mt[i-1]^this.mt[i-1]>>>30;this.mt[i]=(this.mt[i]^(((o&4294901760)>>>16)*1566083941<<16)+(o&65535)*1566083941)-i,this.mt[i]>>>=0,i++,i>=this.N&&(this.mt[0]=this.mt[this.N-1],i=1)}this.mt[0]=2147483648};vA.prototype.random_int=function(){var t,e=new Array(0,this.MATRIX_A);if(this.mti>=this.N){var i;for(this.mti==this.N+1&&this.init_seed(5489),i=0;i<this.N-this.M;i++)t=this.mt[i]&this.UPPER_MASK|this.mt[i+1]&this.LOWER_MASK,this.mt[i]=this.mt[i+this.M]^t>>>1^e[t&1];for(;i<this.N-1;i++)t=this.mt[i]&this.UPPER_MASK|this.mt[i+1]&this.LOWER_MASK,this.mt[i]=this.mt[i+(this.M-this.N)]^t>>>1^e[t&1];t=this.mt[this.N-1]&this.UPPER_MASK|this.mt[0]&this.LOWER_MASK,this.mt[this.N-1]=this.mt[this.M-1]^t>>>1^e[t&1],this.mti=0}return t=this.mt[this.mti++],t^=t>>>11,t^=t<<7&2636928640,t^=t<<15&4022730752,t^=t>>>18,t>>>0};vA.prototype.random_int31=function(){return this.random_int()>>>1};vA.prototype.random_incl=function(){return this.random_int()*(1/4294967295)};vA.prototype.random=function(){return this.random_int()*(1/4294967296)};vA.prototype.random_excl=function(){return(this.random_int()+.5)*(1/4294967296)};vA.prototype.random_long=function(){var t=this.random_int()>>>5,e=this.random_int()>>>6;return(t*67108864+e)*(1/9007199254740992)};eW.exports=vA});var n0,Kt,tZ,nW,L,_e=O(()=>{n0=co(iW(),1);ae();bt();mt();Vt();Kt={};Kt.EPSILON1=.1;Kt.EPSILON2=.01;Kt.EPSILON3=.001;Kt.EPSILON4=1e-4;Kt.EPSILON5=1e-5;Kt.EPSILON6=1e-6;Kt.EPSILON7=1e-7;Kt.EPSILON8=1e-8;Kt.EPSILON9=1e-9;Kt.EPSILON10=1e-10;Kt.EPSILON11=1e-11;Kt.EPSILON12=1e-12;Kt.EPSILON13=1e-13;Kt.EPSILON14=1e-14;Kt.EPSILON15=1e-15;Kt.EPSILON16=1e-16;Kt.EPSILON17=1e-17;Kt.EPSILON18=1e-18;Kt.EPSILON19=1e-19;Kt.EPSILON20=1e-20;Kt.EPSILON21=1e-21;Kt.GRAVITATIONALPARAMETER=3986004418e5;Kt.SOLAR_RADIUS=6955e5;Kt.LUNAR_RADIUS=1737400;Kt.SIXTY_FOUR_KILOBYTES=64*1024;Kt.FOUR_GIGABYTES=4*1024*1024*1024;Kt.sign=Z(Math.sign,function(e){return e=+e,e===0||e!==e?e:e>0?1:-1});Kt.signNotZero=function(t){return t<0?-1:1};Kt.toSNorm=function(t,e){return e=Z(e,255),Math.round((Kt.clamp(t,-1,1)*.5+.5)*e)};Kt.fromSNorm=function(t,e){return e=Z(e,255),Kt.clamp(t,0,e)/e*2-1};Kt.normalize=function(t,e,i){return i=Math.max(i-e,0),i===0?0:Kt.clamp((t-e)/i,0,1)};Kt.sinh=Z(Math.sinh,function(e){return(Math.exp(e)-Math.exp(-e))/2});Kt.cosh=Z(Math.cosh,function(e){return(Math.exp(e)+Math.exp(-e))/2});Kt.lerp=function(t,e,i){return(1-i)*t+i*e};Kt.PI=Math.PI;Kt.ONE_OVER_PI=1/Math.PI;Kt.PI_OVER_TWO=Math.PI/2;Kt.PI_OVER_THREE=Math.PI/3;Kt.PI_OVER_FOUR=Math.PI/4;Kt.PI_OVER_SIX=Math.PI/6;Kt.THREE_PI_OVER_TWO=3*Math.PI/2;Kt.TWO_PI=2*Math.PI;Kt.ONE_OVER_TWO_PI=1/(2*Math.PI);Kt.RADIANS_PER_DEGREE=Math.PI/180;Kt.DEGREES_PER_RADIAN=180/Math.PI;Kt.RADIANS_PER_ARCSECOND=Kt.RADIANS_PER_DEGREE/3600;Kt.toRadians=function(t){if(!m(t))throw new Y("degrees is required.");return t*Kt.RADIANS_PER_DEGREE};Kt.toDegrees=function(t){if(!m(t))throw new Y("radians is required.");return t*Kt.DEGREES_PER_RADIAN};Kt.convertLongitudeRange=function(t){if(!m(t))throw new Y("angle is required.");let e=Kt.TWO_PI,i=t-Math.floor(t/e)*e;return i<-Math.PI?i+e:i>=Math.PI?i-e:i};Kt.clampToLatitudeRange=function(t){if(!m(t))throw new Y("angle is required.");return Kt.clamp(t,-1*Kt.PI_OVER_TWO,Kt.PI_OVER_TWO)};Kt.negativePiToPi=function(t){if(!m(t))throw new Y("angle is required.");return t>=-Kt.PI&&t<=Kt.PI?t:Kt.zeroToTwoPi(t+Kt.PI)-Kt.PI};Kt.zeroToTwoPi=function(t){if(!m(t))throw new Y("angle is required.");if(t>=0&&t<=Kt.TWO_PI)return t;let e=Kt.mod(t,Kt.TWO_PI);return Math.abs(e)<Kt.EPSILON14&&Math.abs(t)>Kt.EPSILON14?Kt.TWO_PI:e};Kt.mod=function(t,e){if(!m(t))throw new Y("m is required.");if(!m(e))throw new Y("n is required.");if(e===0)throw new Y("divisor cannot be 0.");return Kt.sign(t)===Kt.sign(e)&&Math.abs(t)<Math.abs(e)?t:(t%e+e)%e};Kt.equalsEpsilon=function(t,e,i,n){if(!m(t))throw new Y("left is required.");if(!m(e))throw new Y("right is required.");i=Z(i,0),n=Z(n,i);let s=Math.abs(t-e);return s<=n||s<=i*Math.max(Math.abs(t),Math.abs(e))};Kt.lessThan=function(t,e,i){if(!m(t))throw new Y("first is required.");if(!m(e))throw new Y("second is required.");if(!m(i))throw new Y("absoluteEpsilon is required.");return t-e<-i};Kt.lessThanOrEquals=function(t,e,i){if(!m(t))throw new Y("first is required.");if(!m(e))throw new Y("second is required.");if(!m(i))throw new Y("absoluteEpsilon is required.");return t-e<i};Kt.greaterThan=function(t,e,i){if(!m(t))throw new Y("first is required.");if(!m(e))throw new Y("second is required.");if(!m(i))throw new Y("absoluteEpsilon is required.");return t-e>i};Kt.greaterThanOrEquals=function(t,e,i){if(!m(t))throw new Y("first is required.");if(!m(e))throw new Y("second is required.");if(!m(i))throw new Y("absoluteEpsilon is required.");return t-e>-i};tZ=[1];Kt.factorial=function(t){if(typeof t!="number"||t<0)throw new Y("A number greater than or equal to 0 is required.");let e=tZ.length;if(t>=e){let i=tZ[e-1];for(let n=e;n<=t;n++){let s=i*n;tZ.push(s),i=s}}return tZ[t]};Kt.incrementWrap=function(t,e,i){if(i=Z(i,0),!m(t))throw new Y("n is required.");if(e<=i)throw new Y("maximumValue must be greater than minimumValue.");return++t,t>e&&(t=i),t};Kt.isPowerOfTwo=function(t){if(typeof t!="number"||t<0||t>4294967295)throw new Y("A number between 0 and (2^32)-1 is required.");return t!==0&&(t&t-1)===0};Kt.nextPowerOfTwo=function(t){if(typeof t!="number"||t<0||t>2147483648)throw new Y("A number between 0 and 2^31 is required.");return--t,t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,++t,t};Kt.previousPowerOfTwo=function(t){if(typeof t!="number"||t<0||t>4294967295)throw new Y("A number between 0 and (2^32)-1 is required.");return t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,t|=t>>32,t=(t>>>0)-(t>>>1),t};Kt.clamp=function(t,e,i){return p.typeOf.number("value",t),p.typeOf.number("min",e),p.typeOf.number("max",i),t<e?e:t>i?i:t};nW=new n0.default;Kt.setRandomNumberSeed=function(t){if(!m(t))throw new Y("seed is required.");nW=new n0.default(t)};Kt.nextRandomNumber=function(){return nW.random()};Kt.randomBetween=function(t,e){return Kt.nextRandomNumber()*(e-t)+t};Kt.acosClamped=function(t){if(!m(t))throw new Y("value is required.");return Math.acos(Kt.clamp(t,-1,1))};Kt.asinClamped=function(t){if(!m(t))throw new Y("value is required.");return Math.asin(Kt.clamp(t,-1,1))};Kt.chordLength=function(t,e){if(!m(t))throw new Y("angle is required.");if(!m(e))throw new Y("radius is required.");return 2*e*Math.sin(t*.5)};Kt.logBase=function(t,e){if(!m(t))throw new Y("number is required.");if(!m(e))throw new Y("base is required.");return Math.log(t)/Math.log(e)};Kt.cbrt=Z(Math.cbrt,function(e){let i=Math.pow(Math.abs(e),.3333333333333333);return e<0?-i:i});Kt.log2=Z(Math.log2,function(e){return Math.log(e)*Math.LOG2E});Kt.fog=function(t,e){let i=t*e;return 1-Math.exp(-(i*i))};Kt.fastApproximateAtan=function(t){return p.typeOf.number("x",t),t*(-.1784*Math.abs(t)-.0663*t*t+1.0301)};Kt.fastApproximateAtan2=function(t,e){p.typeOf.number("x",t),p.typeOf.number("y",e);let i,n=Math.abs(t);i=Math.abs(e);let s=Math.max(n,i);i=Math.min(n,i);let o=i/s;if(isNaN(o))throw new Y("either x or y must be nonzero");return n=Kt.fastApproximateAtan(o),n=Math.abs(e)>Math.abs(t)?Kt.PI_OVER_TWO-n:n,n=t<0?Kt.PI-n:n,n=e<0?-n:n,n};L=Kt});function Re(t,e){this.x=Z(t,0),this.y=Z(e,0)}var eZ,sW,oW,rW,k8,nt,Xe=O(()=>{ae();bt();mt();Vt();_e();Re.fromElements=function(t,e,i){return m(i)?(i.x=t,i.y=e,i):new Re(t,e)};Re.clone=function(t,e){if(m(t))return m(e)?(e.x=t.x,e.y=t.y,e):new Re(t.x,t.y)};Re.fromCartesian3=Re.clone;Re.fromCartesian4=Re.clone;Re.packedLength=2;Re.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.x,e[i]=t.y,e};Re.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Re),i.x=t[e++],i.y=t[e],i};Re.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*2;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 2 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)Re.pack(t[s],e,s*2);return e};Re.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,2),t.length%2!==0)throw new Y("array length must be a multiple of 2.");let i=t.length;m(e)?e.length=i/2:e=new Array(i/2);for(let n=0;n<i;n+=2){let s=n/2;e[s]=Re.unpack(t,n,e[s])}return e};Re.fromArray=Re.unpack;Re.maximumComponent=function(t){return p.typeOf.object("cartesian",t),Math.max(t.x,t.y)};Re.minimumComponent=function(t){return p.typeOf.object("cartesian",t),Math.min(t.x,t.y)};Re.minimumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.min(t.x,e.x),i.y=Math.min(t.y,e.y),i};Re.maximumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.max(t.x,e.x),i.y=Math.max(t.y,e.y),i};Re.clamp=function(t,e,i,n){p.typeOf.object("value",t),p.typeOf.object("min",e),p.typeOf.object("max",i),p.typeOf.object("result",n);let s=L.clamp(t.x,e.x,i.x),o=L.clamp(t.y,e.y,i.y);return n.x=s,n.y=o,n};Re.magnitudeSquared=function(t){return p.typeOf.object("cartesian",t),t.x*t.x+t.y*t.y};Re.magnitude=function(t){return Math.sqrt(Re.magnitudeSquared(t))};eZ=new Re;Re.distance=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),Re.subtract(t,e,eZ),Re.magnitude(eZ)};Re.distanceSquared=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),Re.subtract(t,e,eZ),Re.magnitudeSquared(eZ)};Re.normalize=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=Re.magnitude(t);if(e.x=t.x/i,e.y=t.y/i,isNaN(e.x)||isNaN(e.y))throw new Y("normalized result is not a number");return e};Re.dot=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.x*e.x+t.y*e.y};Re.cross=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.x*e.y-t.y*e.x};Re.multiplyComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x*e.x,i.y=t.y*e.y,i};Re.divideComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x/e.x,i.y=t.y/e.y,i};Re.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x+e.x,i.y=t.y+e.y,i};Re.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x-e.x,i.y=t.y-e.y,i};Re.multiplyByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x*e,i.y=t.y*e,i};Re.divideByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x/e,i.y=t.y/e,i};Re.negate=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=-t.x,e.y=-t.y,e};Re.abs=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=Math.abs(t.x),e.y=Math.abs(t.y),e};sW=new Re;Re.lerp=function(t,e,i,n){return p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n),Re.multiplyByScalar(e,i,sW),n=Re.multiplyByScalar(t,1-i,n),Re.add(sW,n,n)};oW=new Re,rW=new Re;Re.angleBetween=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),Re.normalize(t,oW),Re.normalize(e,rW),L.acosClamped(Re.dot(oW,rW))};k8=new Re;Re.mostOrthogonalAxis=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=Re.normalize(t,k8);return Re.abs(i,i),i.x<=i.y?e=Re.clone(Re.UNIT_X,e):e=Re.clone(Re.UNIT_Y,e),e};Re.equals=function(t,e){return t===e||m(t)&&m(e)&&t.x===e.x&&t.y===e.y};Re.equalsArray=function(t,e,i){return t.x===e[i]&&t.y===e[i+1]};Re.equalsEpsilon=function(t,e,i,n){return t===e||m(t)&&m(e)&&L.equalsEpsilon(t.x,e.x,i,n)&&L.equalsEpsilon(t.y,e.y,i,n)};Re.ZERO=Object.freeze(new Re(0,0));Re.ONE=Object.freeze(new Re(1,1));Re.UNIT_X=Object.freeze(new Re(1,0));Re.UNIT_Y=Object.freeze(new Re(0,1));Re.prototype.clone=function(t){return Re.clone(this,t)};Re.prototype.equals=function(t){return Re.equals(this,t)};Re.prototype.equalsEpsilon=function(t,e,i){return Re.equalsEpsilon(this,t,e,i)};Re.prototype.toString=function(){return`(${this.x}, ${this.y})`};nt=Re});function wt(t,e,i){this.x=Z(t,0),this.y=Z(e,0),this.z=Z(i,0)}var nZ,aW,iZ,s0,L8,Or,Rm,y8,l,Ht=O(()=>{ae();bt();mt();Vt();_e();wt.fromSpherical=function(t,e){p.typeOf.object("spherical",t),m(e)||(e=new wt);let i=t.clock,n=t.cone,s=Z(t.magnitude,1),o=s*Math.sin(n);return e.x=o*Math.cos(i),e.y=o*Math.sin(i),e.z=s*Math.cos(n),e};wt.fromElements=function(t,e,i,n){return m(n)?(n.x=t,n.y=e,n.z=i,n):new wt(t,e,i)};wt.clone=function(t,e){if(m(t))return m(e)?(e.x=t.x,e.y=t.y,e.z=t.z,e):new wt(t.x,t.y,t.z)};wt.fromCartesian4=wt.clone;wt.packedLength=3;wt.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.x,e[i++]=t.y,e[i]=t.z,e};wt.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new wt),i.x=t[e++],i.y=t[e++],i.z=t[e],i};wt.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*3;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 3 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)wt.pack(t[s],e,s*3);return e};wt.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,3),t.length%3!==0)throw new Y("array length must be a multiple of 3.");let i=t.length;m(e)?e.length=i/3:e=new Array(i/3);for(let n=0;n<i;n+=3){let s=n/3;e[s]=wt.unpack(t,n,e[s])}return e};wt.fromArray=wt.unpack;wt.maximumComponent=function(t){return p.typeOf.object("cartesian",t),Math.max(t.x,t.y,t.z)};wt.minimumComponent=function(t){return p.typeOf.object("cartesian",t),Math.min(t.x,t.y,t.z)};wt.minimumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.min(t.x,e.x),i.y=Math.min(t.y,e.y),i.z=Math.min(t.z,e.z),i};wt.maximumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.max(t.x,e.x),i.y=Math.max(t.y,e.y),i.z=Math.max(t.z,e.z),i};wt.clamp=function(t,e,i,n){p.typeOf.object("value",t),p.typeOf.object("min",e),p.typeOf.object("max",i),p.typeOf.object("result",n);let s=L.clamp(t.x,e.x,i.x),o=L.clamp(t.y,e.y,i.y),r=L.clamp(t.z,e.z,i.z);return n.x=s,n.y=o,n.z=r,n};wt.magnitudeSquared=function(t){return p.typeOf.object("cartesian",t),t.x*t.x+t.y*t.y+t.z*t.z};wt.magnitude=function(t){return Math.sqrt(wt.magnitudeSquared(t))};nZ=new wt;wt.distance=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),wt.subtract(t,e,nZ),wt.magnitude(nZ)};wt.distanceSquared=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),wt.subtract(t,e,nZ),wt.magnitudeSquared(nZ)};wt.normalize=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=wt.magnitude(t);if(e.x=t.x/i,e.y=t.y/i,e.z=t.z/i,isNaN(e.x)||isNaN(e.y)||isNaN(e.z))throw new Y("normalized result is not a number");return e};wt.dot=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.x*e.x+t.y*e.y+t.z*e.z};wt.multiplyComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x*e.x,i.y=t.y*e.y,i.z=t.z*e.z,i};wt.divideComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x/e.x,i.y=t.y/e.y,i.z=t.z/e.z,i};wt.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x+e.x,i.y=t.y+e.y,i.z=t.z+e.z,i};wt.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x-e.x,i.y=t.y-e.y,i.z=t.z-e.z,i};wt.multiplyByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x*e,i.y=t.y*e,i.z=t.z*e,i};wt.divideByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x/e,i.y=t.y/e,i.z=t.z/e,i};wt.negate=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=-t.x,e.y=-t.y,e.z=-t.z,e};wt.abs=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=Math.abs(t.x),e.y=Math.abs(t.y),e.z=Math.abs(t.z),e};aW=new wt;wt.lerp=function(t,e,i,n){return p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n),wt.multiplyByScalar(e,i,aW),n=wt.multiplyByScalar(t,1-i,n),wt.add(aW,n,n)};iZ=new wt,s0=new wt;wt.angleBetween=function(t,e){p.typeOf.object("left",t),p.typeOf.object("right",e),wt.normalize(t,iZ),wt.normalize(e,s0);let i=wt.dot(iZ,s0),n=wt.magnitude(wt.cross(iZ,s0,iZ));return Math.atan2(n,i)};L8=new wt;wt.mostOrthogonalAxis=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=wt.normalize(t,L8);return wt.abs(i,i),i.x<=i.y?i.x<=i.z?e=wt.clone(wt.UNIT_X,e):e=wt.clone(wt.UNIT_Z,e):i.y<=i.z?e=wt.clone(wt.UNIT_Y,e):e=wt.clone(wt.UNIT_Z,e),e};wt.projectVector=function(t,e,i){p.defined("a",t),p.defined("b",e),p.defined("result",i);let n=wt.dot(t,e)/wt.dot(e,e);return wt.multiplyByScalar(e,n,i)};wt.equals=function(t,e){return t===e||m(t)&&m(e)&&t.x===e.x&&t.y===e.y&&t.z===e.z};wt.equalsArray=function(t,e,i){return t.x===e[i]&&t.y===e[i+1]&&t.z===e[i+2]};wt.equalsEpsilon=function(t,e,i,n){return t===e||m(t)&&m(e)&&L.equalsEpsilon(t.x,e.x,i,n)&&L.equalsEpsilon(t.y,e.y,i,n)&&L.equalsEpsilon(t.z,e.z,i,n)};wt.cross=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t.x,s=t.y,o=t.z,r=e.x,a=e.y,h=e.z,A=s*h-o*a,d=o*r-n*h,f=n*a-s*r;return i.x=A,i.y=d,i.z=f,i};wt.midpoint=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=(t.x+e.x)*.5,i.y=(t.y+e.y)*.5,i.z=(t.z+e.z)*.5,i};wt.fromDegrees=function(t,e,i,n,s){return p.typeOf.number("longitude",t),p.typeOf.number("latitude",e),t=L.toRadians(t),e=L.toRadians(e),wt.fromRadians(t,e,i,n,s)};Or=new wt,Rm=new wt,y8=new wt(6378137*6378137,6378137*6378137,6356752314245179e-9*6356752314245179e-9);wt.fromRadians=function(t,e,i,n,s){p.typeOf.number("longitude",t),p.typeOf.number("latitude",e),i=Z(i,0);let o=m(n)?n.radiiSquared:y8,r=Math.cos(e);Or.x=r*Math.cos(t),Or.y=r*Math.sin(t),Or.z=Math.sin(e),Or=wt.normalize(Or,Or),wt.multiplyComponents(o,Or,Rm);let a=Math.sqrt(wt.dot(Or,Rm));return Rm=wt.divideByScalar(Rm,a,Rm),Or=wt.multiplyByScalar(Or,i,Or),m(s)||(s=new wt),wt.add(Rm,Or,s)};wt.fromDegreesArray=function(t,e,i){if(p.defined("coordinates",t),t.length<2||t.length%2!==0)throw new Y("the number of coordinates must be a multiple of 2 and at least 2");let n=t.length;m(i)?i.length=n/2:i=new Array(n/2);for(let s=0;s<n;s+=2){let o=t[s],r=t[s+1],a=s/2;i[a]=wt.fromDegrees(o,r,0,e,i[a])}return i};wt.fromRadiansArray=function(t,e,i){if(p.defined("coordinates",t),t.length<2||t.length%2!==0)throw new Y("the number of coordinates must be a multiple of 2 and at least 2");let n=t.length;m(i)?i.length=n/2:i=new Array(n/2);for(let s=0;s<n;s+=2){let o=t[s],r=t[s+1],a=s/2;i[a]=wt.fromRadians(o,r,0,e,i[a])}return i};wt.fromDegreesArrayHeights=function(t,e,i){if(p.defined("coordinates",t),t.length<3||t.length%3!==0)throw new Y("the number of coordinates must be a multiple of 3 and at least 3");let n=t.length;m(i)?i.length=n/3:i=new Array(n/3);for(let s=0;s<n;s+=3){let o=t[s],r=t[s+1],a=t[s+2],h=s/3;i[h]=wt.fromDegrees(o,r,a,e,i[h])}return i};wt.fromRadiansArrayHeights=function(t,e,i){if(p.defined("coordinates",t),t.length<3||t.length%3!==0)throw new Y("the number of coordinates must be a multiple of 3 and at least 3");let n=t.length;m(i)?i.length=n/3:i=new Array(n/3);for(let s=0;s<n;s+=3){let o=t[s],r=t[s+1],a=t[s+2],h=s/3;i[h]=wt.fromRadians(o,r,a,e,i[h])}return i};wt.ZERO=Object.freeze(new wt(0,0,0));wt.ONE=Object.freeze(new wt(1,1,1));wt.UNIT_X=Object.freeze(new wt(1,0,0));wt.UNIT_Y=Object.freeze(new wt(0,1,0));wt.UNIT_Z=Object.freeze(new wt(0,0,1));wt.prototype.clone=function(t){return wt.clone(this,t)};wt.prototype.equals=function(t){return wt.equals(this,t)};wt.prototype.equalsEpsilon=function(t,e,i){return wt.equalsEpsilon(this,t,e,i)};wt.prototype.toString=function(){return`(${this.x}, ${this.y}, ${this.z})`};l=wt});function P8(t,e,i,n,s){if(!m(t))throw new Y("cartesian is required.");if(!m(e))throw new Y("oneOverRadii is required.");if(!m(i))throw new Y("oneOverRadiiSquared is required.");if(!m(n))throw new Y("centerToleranceSquared is required.");let o=t.x,r=t.y,a=t.z,h=e.x,A=e.y,d=e.z,f=o*o*h*h,E=r*r*A*A,_=a*a*d*d,R=f+E+_,I=Math.sqrt(1/R),C=l.multiplyByScalar(t,I,w8);if(R<n)return isFinite(I)?l.clone(C,s):void 0;let N=i.x,T=i.y,F=i.z,b=x8;b.x=C.x*N*2,b.y=C.y*T*2,b.z=C.z*F*2;let G=(1-I)*l.magnitude(t)/(.5*l.magnitude(b)),M=0,Q,U,k,y,c,g,V,D,w,x,H;do{G-=M,k=1/(1+G*N),y=1/(1+G*T),c=1/(1+G*F),g=k*k,V=y*y,D=c*c,w=g*k,x=V*y,H=D*c,Q=f*g+E*V+_*D-1,U=f*w*N+E*x*T+_*H*F;let j=-2*U;M=Q/j}while(Math.abs(Q)>L.EPSILON12);return m(s)?(s.x=o*k,s.y=r*y,s.z=a*c,s):new l(o*k,r*y,a*c)}var w8,x8,sZ,o0=O(()=>{Ht();mt();Vt();_e();w8=new l,x8=new l;sZ=P8});function fs(t,e,i){this.longitude=Z(t,0),this.latitude=Z(e,0),this.height=Z(i,0)}var J8,j8,H8,v8,z8,K8,ut,ri=O(()=>{Ht();ae();bt();mt();_e();o0();fs.fromRadians=function(t,e,i,n){return p.typeOf.number("longitude",t),p.typeOf.number("latitude",e),i=Z(i,0),m(n)?(n.longitude=t,n.latitude=e,n.height=i,n):new fs(t,e,i)};fs.fromDegrees=function(t,e,i,n){return p.typeOf.number("longitude",t),p.typeOf.number("latitude",e),t=L.toRadians(t),e=L.toRadians(e),fs.fromRadians(t,e,i,n)};J8=new l,j8=new l,H8=new l,v8=new l(1/6378137,1/6378137,1/6356752314245179e-9),z8=new l(1/(6378137*6378137),1/(6378137*6378137),1/(6356752314245179e-9*6356752314245179e-9)),K8=L.EPSILON1;fs.fromCartesian=function(t,e,i){let n=m(e)?e.oneOverRadii:v8,s=m(e)?e.oneOverRadiiSquared:z8,o=m(e)?e._centerToleranceSquared:K8,r=sZ(t,n,s,o,j8);if(!m(r))return;let a=l.multiplyComponents(r,s,J8);a=l.normalize(a,a);let h=l.subtract(t,r,H8),A=Math.atan2(a.y,a.x),d=Math.asin(a.z),f=L.sign(l.dot(h,t))*l.magnitude(h);return m(i)?(i.longitude=A,i.latitude=d,i.height=f,i):new fs(A,d,f)};fs.toCartesian=function(t,e,i){return p.defined("cartographic",t),l.fromRadians(t.longitude,t.latitude,t.height,e,i)};fs.clone=function(t,e){if(m(t))return m(e)?(e.longitude=t.longitude,e.latitude=t.latitude,e.height=t.height,e):new fs(t.longitude,t.latitude,t.height)};fs.equals=function(t,e){return t===e||m(t)&&m(e)&&t.longitude===e.longitude&&t.latitude===e.latitude&&t.height===e.height};fs.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t.longitude-e.longitude)<=i&&Math.abs(t.latitude-e.latitude)<=i&&Math.abs(t.height-e.height)<=i};fs.ZERO=Object.freeze(new fs(0,0,0));fs.prototype.clone=function(t){return fs.clone(this,t)};fs.prototype.equals=function(t){return fs.equals(this,t)};fs.prototype.equalsEpsilon=function(t,e){return fs.equalsEpsilon(this,t,e)};fs.prototype.toString=function(){return`(${this.longitude}, ${this.latitude}, ${this.height})`};ut=fs});function hW(t,e,i,n){e=Z(e,0),i=Z(i,0),n=Z(n,0),p.typeOf.number.greaterThanOrEquals("x",e,0),p.typeOf.number.greaterThanOrEquals("y",i,0),p.typeOf.number.greaterThanOrEquals("z",n,0),t._radii=new l(e,i,n),t._radiiSquared=new l(e*e,i*i,n*n),t._radiiToTheFourth=new l(e*e*e*e,i*i*i*i,n*n*n*n),t._oneOverRadii=new l(e===0?0:1/e,i===0?0:1/i,n===0?0:1/n),t._oneOverRadiiSquared=new l(e===0?0:1/(e*e),i===0?0:1/(i*i),n===0?0:1/(n*n)),t._minimumRadius=Math.min(e,i,n),t._maximumRadius=Math.max(e,i,n),t._centerToleranceSquared=L.EPSILON1,t._radiiSquared.z!==0&&(t._squaredXOverSquaredZ=t._radiiSquared.x/t._radiiSquared.z)}function Li(t,e,i){this._radii=void 0,this._radiiSquared=void 0,this._radiiToTheFourth=void 0,this._oneOverRadii=void 0,this._oneOverRadiiSquared=void 0,this._minimumRadius=void 0,this._maximumRadius=void 0,this._centerToleranceSquared=void 0,this._squaredXOverSquaredZ=void 0,hW(this,t,e,i)}function AW(t,e,i){p.typeOf.number("a",t),p.typeOf.number("b",e),p.typeOf.func("func",i);let n=.5*(e+t),s=.5*(e-t),o=0;for(let r=0;r<5;r++){let a=s*nq[r];o+=sq[r]*(i(n+a)+i(n-a))}return o*=s,o}var X8,q8,$8,tq,eq,iq,nq,sq,ot,Ve=O(()=>{Xe();Ht();ri();ae();bt();mt();Vt();_e();o0();Object.defineProperties(Li.prototype,{radii:{get:function(){return this._radii}},radiiSquared:{get:function(){return this._radiiSquared}},radiiToTheFourth:{get:function(){return this._radiiToTheFourth}},oneOverRadii:{get:function(){return this._oneOverRadii}},oneOverRadiiSquared:{get:function(){return this._oneOverRadiiSquared}},minimumRadius:{get:function(){return this._minimumRadius}},maximumRadius:{get:function(){return this._maximumRadius}}});Li.clone=function(t,e){if(!m(t))return;let i=t._radii;return m(e)?(l.clone(i,e._radii),l.clone(t._radiiSquared,e._radiiSquared),l.clone(t._radiiToTheFourth,e._radiiToTheFourth),l.clone(t._oneOverRadii,e._oneOverRadii),l.clone(t._oneOverRadiiSquared,e._oneOverRadiiSquared),e._minimumRadius=t._minimumRadius,e._maximumRadius=t._maximumRadius,e._centerToleranceSquared=t._centerToleranceSquared,e):new Li(i.x,i.y,i.z)};Li.fromCartesian3=function(t,e){return m(e)||(e=new Li),m(t)&&hW(e,t.x,t.y,t.z),e};Li.WGS84=Object.freeze(new Li(6378137,6378137,6356752314245179e-9));Li.UNIT_SPHERE=Object.freeze(new Li(1,1,1));Li.MOON=Object.freeze(new Li(L.LUNAR_RADIUS,L.LUNAR_RADIUS,L.LUNAR_RADIUS));Li.prototype.clone=function(t){return Li.clone(this,t)};Li.packedLength=l.packedLength;Li.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),l.pack(t._radii,e,i),e};Li.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=l.unpack(t,e);return Li.fromCartesian3(n,i)};Li.prototype.geocentricSurfaceNormal=l.normalize;Li.prototype.geodeticSurfaceNormalCartographic=function(t,e){p.typeOf.object("cartographic",t);let i=t.longitude,n=t.latitude,s=Math.cos(n),o=s*Math.cos(i),r=s*Math.sin(i),a=Math.sin(n);return m(e)||(e=new l),e.x=o,e.y=r,e.z=a,l.normalize(e,e)};Li.prototype.geodeticSurfaceNormal=function(t,e){if(p.typeOf.object("cartesian",t),isNaN(t.x)||isNaN(t.y)||isNaN(t.z))throw new Y("cartesian has a NaN component");if(!l.equalsEpsilon(t,l.ZERO,L.EPSILON14))return m(e)||(e=new l),e=l.multiplyComponents(t,this._oneOverRadiiSquared,e),l.normalize(e,e)};X8=new l,q8=new l;Li.prototype.cartographicToCartesian=function(t,e){let i=X8,n=q8;this.geodeticSurfaceNormalCartographic(t,i),l.multiplyComponents(this._radiiSquared,i,n);let s=Math.sqrt(l.dot(i,n));return l.divideByScalar(n,s,n),l.multiplyByScalar(i,t.height,i),m(e)||(e=new l),l.add(n,i,e)};Li.prototype.cartographicArrayToCartesianArray=function(t,e){p.defined("cartographics",t);let i=t.length;m(e)?e.length=i:e=new Array(i);for(let n=0;n<i;n++)e[n]=this.cartographicToCartesian(t[n],e[n]);return e};$8=new l,tq=new l,eq=new l;Li.prototype.cartesianToCartographic=function(t,e){let i=this.scaleToGeodeticSurface(t,tq);if(!m(i))return;let n=this.geodeticSurfaceNormal(i,$8),s=l.subtract(t,i,eq),o=Math.atan2(n.y,n.x),r=Math.asin(n.z),a=L.sign(l.dot(s,t))*l.magnitude(s);return m(e)?(e.longitude=o,e.latitude=r,e.height=a,e):new ut(o,r,a)};Li.prototype.cartesianArrayToCartographicArray=function(t,e){p.defined("cartesians",t);let i=t.length;m(e)?e.length=i:e=new Array(i);for(let n=0;n<i;++n)e[n]=this.cartesianToCartographic(t[n],e[n]);return e};Li.prototype.scaleToGeodeticSurface=function(t,e){return sZ(t,this._oneOverRadii,this._oneOverRadiiSquared,this._centerToleranceSquared,e)};Li.prototype.scaleToGeocentricSurface=function(t,e){p.typeOf.object("cartesian",t),m(e)||(e=new l);let i=t.x,n=t.y,s=t.z,o=this._oneOverRadiiSquared,r=1/Math.sqrt(i*i*o.x+n*n*o.y+s*s*o.z);return l.multiplyByScalar(t,r,e)};Li.prototype.transformPositionToScaledSpace=function(t,e){return m(e)||(e=new l),l.multiplyComponents(t,this._oneOverRadii,e)};Li.prototype.transformPositionFromScaledSpace=function(t,e){return m(e)||(e=new l),l.multiplyComponents(t,this._radii,e)};Li.prototype.equals=function(t){return this===t||m(t)&&l.equals(this._radii,t._radii)};Li.prototype.toString=function(){return this._radii.toString()};Li.prototype.getSurfaceNormalIntersectionWithZAxis=function(t,e,i){if(p.typeOf.object("position",t),!L.equalsEpsilon(this._radii.x,this._radii.y,L.EPSILON15))throw new Y("Ellipsoid must be an ellipsoid of revolution (radii.x == radii.y)");p.typeOf.number.greaterThan("Ellipsoid.radii.z",this._radii.z,0),e=Z(e,0);let n=this._squaredXOverSquaredZ;if(m(i)||(i=new l),i.x=0,i.y=0,i.z=t.z*(1-n),!(Math.abs(i.z)>=this._radii.z-e))return i};iq=new l;Li.prototype.getLocalCurvature=function(t,e){p.typeOf.object("surfacePosition",t),m(e)||(e=new nt);let i=this.getSurfaceNormalIntersectionWithZAxis(t,0,iq),n=l.distance(t,i),s=this.minimumRadius*n/this.maximumRadius**2,o=n*s**2;return nt.fromElements(1/n,1/o,e)};nq=[.14887433898163,.43339539412925,.67940956829902,.86506336668898,.97390652851717,0],sq=[.29552422471475,.26926671930999,.21908636251598,.14945134915058,.066671344308684,0];Li.prototype.surfaceArea=function(t){p.typeOf.object("rectangle",t);let e=t.west,i=t.east,n=t.south,s=t.north;for(;i<e;)i+=L.TWO_PI;let o=this._radiiSquared,r=o.x,a=o.y,h=o.z,A=r*a;return AW(n,s,function(d){let f=Math.cos(d),E=Math.sin(d);return Math.cos(d)*AW(e,i,function(_){let R=Math.cos(_),I=Math.sin(_);return Math.sqrt(A*E*E+h*(a*R*R+r*I*I)*f*f)})})};ot=Li});function oZ(t){this._ellipsoid=Z(t,ot.WGS84),this._semimajorAxis=this._ellipsoid.maximumRadius,this._oneOverSemimajorAxis=1/this._semimajorAxis}var Os,zA=O(()=>{Ht();ri();bt();mt();Vt();Ve();Object.defineProperties(oZ.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});oZ.prototype.project=function(t,e){let i=this._semimajorAxis,n=t.longitude*i,s=t.latitude*i,o=t.height;return m(e)?(e.x=n,e.y=s,e.z=o,e):new l(n,s,o)};oZ.prototype.unproject=function(t,e){if(!m(t))throw new Y("cartesian is required");let i=this._oneOverSemimajorAxis,n=t.x*i,s=t.y*i,o=t.z;return m(e)?(e.longitude=n,e.latitude=s,e.height=o,e):new ut(n,s,o)};Os=oZ});var oq,Nn,nc=O(()=>{oq={OUTSIDE:-1,INTERSECTING:0,INSIDE:1},Nn=Object.freeze(oq)});function oe(t,e,i,n){this.x=Z(t,0),this.y=Z(e,0),this.z=Z(i,0),this.w=Z(n,0)}var rZ,cW,rq,r0,lo,aq,Aq,lW,ie,Vs=O(()=>{ae();bt();mt();Vt();_e();oe.fromElements=function(t,e,i,n,s){return m(s)?(s.x=t,s.y=e,s.z=i,s.w=n,s):new oe(t,e,i,n)};oe.fromColor=function(t,e){return p.typeOf.object("color",t),m(e)?(e.x=t.red,e.y=t.green,e.z=t.blue,e.w=t.alpha,e):new oe(t.red,t.green,t.blue,t.alpha)};oe.clone=function(t,e){if(m(t))return m(e)?(e.x=t.x,e.y=t.y,e.z=t.z,e.w=t.w,e):new oe(t.x,t.y,t.z,t.w)};oe.packedLength=4;oe.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.x,e[i++]=t.y,e[i++]=t.z,e[i]=t.w,e};oe.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new oe),i.x=t[e++],i.y=t[e++],i.z=t[e++],i.w=t[e],i};oe.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*4;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 4 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)oe.pack(t[s],e,s*4);return e};oe.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,4),t.length%4!==0)throw new Y("array length must be a multiple of 4.");let i=t.length;m(e)?e.length=i/4:e=new Array(i/4);for(let n=0;n<i;n+=4){let s=n/4;e[s]=oe.unpack(t,n,e[s])}return e};oe.fromArray=oe.unpack;oe.maximumComponent=function(t){return p.typeOf.object("cartesian",t),Math.max(t.x,t.y,t.z,t.w)};oe.minimumComponent=function(t){return p.typeOf.object("cartesian",t),Math.min(t.x,t.y,t.z,t.w)};oe.minimumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.min(t.x,e.x),i.y=Math.min(t.y,e.y),i.z=Math.min(t.z,e.z),i.w=Math.min(t.w,e.w),i};oe.maximumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.max(t.x,e.x),i.y=Math.max(t.y,e.y),i.z=Math.max(t.z,e.z),i.w=Math.max(t.w,e.w),i};oe.clamp=function(t,e,i,n){p.typeOf.object("value",t),p.typeOf.object("min",e),p.typeOf.object("max",i),p.typeOf.object("result",n);let s=L.clamp(t.x,e.x,i.x),o=L.clamp(t.y,e.y,i.y),r=L.clamp(t.z,e.z,i.z),a=L.clamp(t.w,e.w,i.w);return n.x=s,n.y=o,n.z=r,n.w=a,n};oe.magnitudeSquared=function(t){return p.typeOf.object("cartesian",t),t.x*t.x+t.y*t.y+t.z*t.z+t.w*t.w};oe.magnitude=function(t){return Math.sqrt(oe.magnitudeSquared(t))};rZ=new oe;oe.distance=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),oe.subtract(t,e,rZ),oe.magnitude(rZ)};oe.distanceSquared=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),oe.subtract(t,e,rZ),oe.magnitudeSquared(rZ)};oe.normalize=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=oe.magnitude(t);if(e.x=t.x/i,e.y=t.y/i,e.z=t.z/i,e.w=t.w/i,isNaN(e.x)||isNaN(e.y)||isNaN(e.z)||isNaN(e.w))throw new Y("normalized result is not a number");return e};oe.dot=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.x*e.x+t.y*e.y+t.z*e.z+t.w*e.w};oe.multiplyComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x*e.x,i.y=t.y*e.y,i.z=t.z*e.z,i.w=t.w*e.w,i};oe.divideComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x/e.x,i.y=t.y/e.y,i.z=t.z/e.z,i.w=t.w/e.w,i};oe.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x+e.x,i.y=t.y+e.y,i.z=t.z+e.z,i.w=t.w+e.w,i};oe.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x-e.x,i.y=t.y-e.y,i.z=t.z-e.z,i.w=t.w-e.w,i};oe.multiplyByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x*e,i.y=t.y*e,i.z=t.z*e,i.w=t.w*e,i};oe.divideByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x/e,i.y=t.y/e,i.z=t.z/e,i.w=t.w/e,i};oe.negate=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=-t.x,e.y=-t.y,e.z=-t.z,e.w=-t.w,e};oe.abs=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=Math.abs(t.x),e.y=Math.abs(t.y),e.z=Math.abs(t.z),e.w=Math.abs(t.w),e};cW=new oe;oe.lerp=function(t,e,i,n){return p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n),oe.multiplyByScalar(e,i,cW),n=oe.multiplyByScalar(t,1-i,n),oe.add(cW,n,n)};rq=new oe;oe.mostOrthogonalAxis=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=oe.normalize(t,rq);return oe.abs(i,i),i.x<=i.y?i.x<=i.z?i.x<=i.w?e=oe.clone(oe.UNIT_X,e):e=oe.clone(oe.UNIT_W,e):i.z<=i.w?e=oe.clone(oe.UNIT_Z,e):e=oe.clone(oe.UNIT_W,e):i.y<=i.z?i.y<=i.w?e=oe.clone(oe.UNIT_Y,e):e=oe.clone(oe.UNIT_W,e):i.z<=i.w?e=oe.clone(oe.UNIT_Z,e):e=oe.clone(oe.UNIT_W,e),e};oe.equals=function(t,e){return t===e||m(t)&&m(e)&&t.x===e.x&&t.y===e.y&&t.z===e.z&&t.w===e.w};oe.equalsArray=function(t,e,i){return t.x===e[i]&&t.y===e[i+1]&&t.z===e[i+2]&&t.w===e[i+3]};oe.equalsEpsilon=function(t,e,i,n){return t===e||m(t)&&m(e)&&L.equalsEpsilon(t.x,e.x,i,n)&&L.equalsEpsilon(t.y,e.y,i,n)&&L.equalsEpsilon(t.z,e.z,i,n)&&L.equalsEpsilon(t.w,e.w,i,n)};oe.ZERO=Object.freeze(new oe(0,0,0,0));oe.ONE=Object.freeze(new oe(1,1,1,1));oe.UNIT_X=Object.freeze(new oe(1,0,0,0));oe.UNIT_Y=Object.freeze(new oe(0,1,0,0));oe.UNIT_Z=Object.freeze(new oe(0,0,1,0));oe.UNIT_W=Object.freeze(new oe(0,0,0,1));oe.prototype.clone=function(t){return oe.clone(this,t)};oe.prototype.equals=function(t){return oe.equals(this,t)};oe.prototype.equalsEpsilon=function(t,e,i){return oe.equalsEpsilon(this,t,e,i)};oe.prototype.toString=function(){return`(${this.x}, ${this.y}, ${this.z}, ${this.w})`};r0=new Float32Array(1),lo=new Uint8Array(r0.buffer),aq=new Uint32Array([287454020]),Aq=new Uint8Array(aq.buffer),lW=Aq[0]===68;oe.packFloat=function(t,e){return p.typeOf.number("value",t),m(e)||(e=new oe),r0[0]=t,lW?(e.x=lo[0],e.y=lo[1],e.z=lo[2],e.w=lo[3]):(e.x=lo[3],e.y=lo[2],e.z=lo[1],e.w=lo[0]),e};oe.unpackFloat=function(t){return p.typeOf.object("packedFloat",t),lW?(lo[0]=t.x,lo[1]=t.y,lo[2]=t.z,lo[3]=t.w):(lo[0]=t.w,lo[1]=t.z,lo[2]=t.y,lo[3]=t.x),r0[0]};ie=oe});function hq(t,e,i){p.defined("array",t),p.defined("itemToFind",e),p.defined("comparator",i);let n=0,s=t.length-1,o,r;for(;n<=s;){if(o=~~((n+s)/2),r=i(t[o],e),r<0){n=o+1;continue}if(r>0){s=o-1;continue}return o}return~(s+1)}var Bo,sE=O(()=>{ae();Bo=hq});function cq(t,e,i,n,s){this.xPoleWander=t,this.yPoleWander=e,this.xPoleOffset=i,this.yPoleOffset=n,this.ut1MinusUtc=s}var oE,a0=O(()=>{oE=cq});function lq(t){if(t===null||isNaN(t))throw new Y("year is required and must be a number.");return t%4===0&&t%100!==0||t%400===0}var rE,A0=O(()=>{Vt();rE=lq});function dq(t,e,i,n,s,o,r,a){t=Z(t,1),e=Z(e,1),i=Z(i,1),n=Z(n,0),s=Z(s,0),o=Z(o,0),r=Z(r,0),a=Z(a,!1),I(),C(),this.year=t,this.month=e,this.day=i,this.hour=n,this.minute=s,this.second=o,this.millisecond=r,this.isLeapSecond=a;function I(){p.typeOf.number.greaterThanOrEquals("Year",t,1),p.typeOf.number.lessThanOrEquals("Year",t,9999),p.typeOf.number.greaterThanOrEquals("Month",e,1),p.typeOf.number.lessThanOrEquals("Month",e,12),p.typeOf.number.greaterThanOrEquals("Day",i,1),p.typeOf.number.lessThanOrEquals("Day",i,31),p.typeOf.number.greaterThanOrEquals("Hour",n,0),p.typeOf.number.lessThanOrEquals("Hour",n,23),p.typeOf.number.greaterThanOrEquals("Minute",s,0),p.typeOf.number.lessThanOrEquals("Minute",s,59),p.typeOf.bool("IsLeapSecond",a),p.typeOf.number.greaterThanOrEquals("Second",o,0),p.typeOf.number.lessThanOrEquals("Second",o,a?60:59),p.typeOf.number.greaterThanOrEquals("Millisecond",r,0),p.typeOf.number.lessThan("Millisecond",r,1e3)}function C(){let N=e===2&&rE(t)?dW[e-1]+1:dW[e-1];if(i>N)throw new Y("Month and Day represents invalid date")}}var dW,aZ,mW=O(()=>{ae();bt();Vt();A0();dW=[31,28,31,30,31,30,31,31,30,31,30,31];aZ=dq});function mq(t,e){this.julianDate=t,this.offset=e}var zi,h0=O(()=>{zi=mq});var fq,bn,AZ=O(()=>{fq={SECONDS_PER_MILLISECOND:.001,SECONDS_PER_MINUTE:60,MINUTES_PER_HOUR:60,HOURS_PER_DAY:24,SECONDS_PER_HOUR:3600,MINUTES_PER_DAY:1440,SECONDS_PER_DAY:86400,DAYS_PER_JULIAN_CENTURY:36525,PICOSECOND:1e-9,MODIFIED_JULIAN_DATE_DIFFERENCE:24000005e-1},bn=Object.freeze(fq)});var Eq,Ei,hZ=O(()=>{Eq={UTC:0,TAI:1},Ei=Object.freeze(Eq)});function c0(t,e){return me.compare(t.julianDate,e.julianDate)}function mZ(t){Zm.julianDate=t;let e=me.leapSeconds,i=Bo(e,Zm,c0);i<0&&(i=~i),i>=e.length&&(i=e.length-1);let n=e[i].offset;i>0&&me.secondsDifference(e[i].julianDate,t)>n&&(i--,n=e[i].offset),me.addSeconds(t,n,t)}function fW(t,e){Zm.julianDate=t;let i=me.leapSeconds,n=Bo(i,Zm,c0);if(n<0&&(n=~n),n===0)return me.addSeconds(t,-i[0].offset,e);if(n>=i.length)return me.addSeconds(t,-i[n-1].offset,e);let s=me.secondsDifference(i[n].julianDate,t);if(s===0)return me.addSeconds(t,-i[n].offset,e);if(!(s<=1))return me.addSeconds(t,-i[--n].offset,e)}function sc(t,e,i){let n=e/bn.SECONDS_PER_DAY|0;return t+=n,e-=bn.SECONDS_PER_DAY*n,e<0&&(t--,e+=bn.SECONDS_PER_DAY),i.dayNumber=t,i.secondsOfDay=e,i}function l0(t,e,i,n,s,o,r){let a=(e-14)/12|0,h=t+4800+a,A=(1461*h/4|0)+(367*(e-2-12*a)/12|0)-(3*((h+100)/100|0)/4|0)+i-32075;n=n-12,n<0&&(n+=24);let d=o+(n*bn.SECONDS_PER_HOUR+s*bn.SECONDS_PER_MINUTE+r*bn.SECONDS_PER_MILLISECOND);return d>=43200&&(A-=1),[A,d]}function me(t,e,i){this.dayNumber=void 0,this.secondsOfDay=void 0,t=Z(t,0),e=Z(e,0),i=Z(i,Ei.UTC);let n=t|0;e=e+(t-n)*bn.SECONDS_PER_DAY,sc(n,e,this),i===Ei.UTC&&mZ(this)}var EW,cZ,lZ,Zm,_q,Rq,Zq,Iq,pq,d0,uq,Cq,gq,Za,dZ,Ze,Vr=O(()=>{sE();bt();mt();Vt();mW();A0();h0();AZ();hZ();EW=new aZ,cZ=[31,28,31,30,31,30,31,31,30,31,30,31],lZ=29;Zm=new zi;_q=/^(\d{4})$/,Rq=/^(\d{4})-(\d{2})$/,Zq=/^(\d{4})-?(\d{3})$/,Iq=/^(\d{4})-?W(\d{2})-?(\d{1})?$/,pq=/^(\d{4})-?(\d{2})-?(\d{2})$/,d0=/([Z+\-])?(\d{2})?:?(\d{2})?$/,uq=/^(\d{2})(\.\d+)?/.source+d0.source,Cq=/^(\d{2}):?(\d{2})(\.\d+)?/.source+d0.source,gq=/^(\d{2}):?(\d{2}):?(\d{2})(\.\d+)?/.source+d0.source,Za="Invalid ISO 8601 date.";me.fromGregorianDate=function(t,e){if(!(t instanceof aZ))throw new Y("date must be a valid GregorianDate.");let i=l0(t.year,t.month,t.day,t.hour,t.minute,t.second,t.millisecond);return m(e)?(sc(i[0],i[1],e),mZ(e),e):new me(i[0],i[1],Ei.UTC)};me.fromDate=function(t,e){if(!(t instanceof Date)||isNaN(t.getTime()))throw new Y("date must be a valid JavaScript Date.");let i=l0(t.getUTCFullYear(),t.getUTCMonth()+1,t.getUTCDate(),t.getUTCHours(),t.getUTCMinutes(),t.getUTCSeconds(),t.getUTCMilliseconds());return m(e)?(sc(i[0],i[1],e),mZ(e),e):new me(i[0],i[1],Ei.UTC)};me.fromIso8601=function(t,e){if(typeof t!="string")throw new Y(Za);t=t.replace(",",".");let i=t.split("T"),n,s=1,o=1,r=0,a=0,h=0,A=0,d=i[0],f=i[1],E,_;if(!m(d))throw new Y(Za);let R;if(i=d.match(pq),i!==null){if(R=d.split("-").length-1,R>0&&R!==2)throw new Y(Za);n=+i[1],s=+i[2],o=+i[3]}else if(i=d.match(Rq),i!==null)n=+i[1],s=+i[2];else if(i=d.match(_q),i!==null)n=+i[1];else{let T;if(i=d.match(Zq),i!==null){if(n=+i[1],T=+i[2],_=rE(n),T<1||_&&T>366||!_&&T>365)throw new Y(Za)}else if(i=d.match(Iq),i!==null){n=+i[1];let F=+i[2],b=+i[3]||0;if(R=d.split("-").length-1,R>0&&(!m(i[3])&&R!==1||m(i[3])&&R!==2))throw new Y(Za);let G=new Date(Date.UTC(n,0,4));T=F*7+b-G.getUTCDay()-3}else throw new Y(Za);E=new Date(Date.UTC(n,0,1)),E.setUTCDate(T),s=E.getUTCMonth()+1,o=E.getUTCDate()}if(_=rE(n),s<1||s>12||o<1||(s!==2||!_)&&o>cZ[s-1]||_&&s===2&&o>lZ)throw new Y(Za);let I;if(m(f)){if(i=f.match(gq),i!==null){if(R=f.split(":").length-1,R>0&&R!==2&&R!==3)throw new Y(Za);r=+i[1],a=+i[2],h=+i[3],A=+(i[4]||0)*1e3,I=5}else if(i=f.match(Cq),i!==null){if(R=f.split(":").length-1,R>2)throw new Y(Za);r=+i[1],a=+i[2],h=+(i[3]||0)*60,I=4}else if(i=f.match(uq),i!==null)r=+i[1],a=+(i[2]||0)*60,I=3;else throw new Y(Za);if(a>=60||h>=61||r>24||r===24&&(a>0||h>0||A>0))throw new Y(Za);let T=i[I],F=+i[I+1],b=+(i[I+2]||0);switch(T){case"+":r=r-F,a=a-b;break;case"-":r=r+F,a=a+b;break;case"Z":break;default:a=a+new Date(Date.UTC(n,s-1,o,r,a)).getTimezoneOffset();break}}let C=h===60;for(C&&h--;a>=60;)a-=60,r++;for(;r>=24;)r-=24,o++;for(E=_&&s===2?lZ:cZ[s-1];o>E;)o-=E,s++,s>12&&(s-=12,n++),E=_&&s===2?lZ:cZ[s-1];for(;a<0;)a+=60,r--;for(;r<0;)r+=24,o--;for(;o<1;)s--,s<1&&(s+=12,n--),E=_&&s===2?lZ:cZ[s-1],o+=E;let N=l0(n,s,o,r,a,h,A);return m(e)?(sc(N[0],N[1],e),mZ(e)):e=new me(N[0],N[1],Ei.UTC),C&&me.addSeconds(e,1,e),e};me.now=function(t){return me.fromDate(new Date,t)};dZ=new me(0,0,Ei.TAI);me.toGregorianDate=function(t,e){if(!m(t))throw new Y("julianDate is required.");let i=!1,n=fW(t,dZ);m(n)||(me.addSeconds(t,-1,dZ),n=fW(dZ,dZ),i=!0);let s=n.dayNumber,o=n.secondsOfDay;o>=43200&&(s+=1);let r=s+68569|0,a=4*r/146097|0;r=r-((146097*a+3)/4|0)|0;let h=4e3*(r+1)/1461001|0;r=r-(1461*h/4|0)+31|0;let A=80*r/2447|0,d=r-(2447*A/80|0)|0;r=A/11|0;let f=A+2-12*r|0,E=100*(a-49)+h+r|0,_=o/bn.SECONDS_PER_HOUR|0,R=o-_*bn.SECONDS_PER_HOUR,I=R/bn.SECONDS_PER_MINUTE|0;R=R-I*bn.SECONDS_PER_MINUTE;let C=R|0,N=(R-C)/bn.SECONDS_PER_MILLISECOND;return _+=12,_>23&&(_-=24),i&&(C+=1),m(e)?(e.year=E,e.month=f,e.day=d,e.hour=_,e.minute=I,e.second=C,e.millisecond=N,e.isLeapSecond=i,e):new aZ(E,f,d,_,I,C,N,i)};me.toDate=function(t){if(!m(t))throw new Y("julianDate is required.");let e=me.toGregorianDate(t,EW),i=e.second;return e.isLeapSecond&&(i-=1),new Date(Date.UTC(e.year,e.month-1,e.day,e.hour,e.minute,i,e.millisecond))};me.toIso8601=function(t,e){if(!m(t))throw new Y("julianDate is required.");let i=me.toGregorianDate(t,EW),n=i.year,s=i.month,o=i.day,r=i.hour,a=i.minute,h=i.second,A=i.millisecond;n===1e4&&s===1&&o===1&&r===0&&a===0&&h===0&&A===0&&(n=9999,s=12,o=31,r=24);let d;return!m(e)&&A!==0?(d=(A*.01).toString().replace(".",""),`${n.toString().padStart(4,"0")}-${s.toString().padStart(2,"0")}-${o.toString().padStart(2,"0")}T${r.toString().padStart(2,"0")}:${a.toString().padStart(2,"0")}:${h.toString().padStart(2,"0")}.${d}Z`):!m(e)||e===0?`${n.toString().padStart(4,"0")}-${s.toString().padStart(2,"0")}-${o.toString().padStart(2,"0")}T${r.toString().padStart(2,"0")}:${a.toString().padStart(2,"0")}:${h.toString().padStart(2,"0")}Z`:(d=(A*.01).toFixed(e).replace(".","").slice(0,e),`${n.toString().padStart(4,"0")}-${s.toString().padStart(2,"0")}-${o.toString().padStart(2,"0")}T${r.toString().padStart(2,"0")}:${a.toString().padStart(2,"0")}:${h.toString().padStart(2,"0")}.${d}Z`)};me.clone=function(t,e){if(m(t))return m(e)?(e.dayNumber=t.dayNumber,e.secondsOfDay=t.secondsOfDay,e):new me(t.dayNumber,t.secondsOfDay,Ei.TAI)};me.compare=function(t,e){if(!m(t))throw new Y("left is required.");if(!m(e))throw new Y("right is required.");let i=t.dayNumber-e.dayNumber;return i!==0?i:t.secondsOfDay-e.secondsOfDay};me.equals=function(t,e){return t===e||m(t)&&m(e)&&t.dayNumber===e.dayNumber&&t.secondsOfDay===e.secondsOfDay};me.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(me.secondsDifference(t,e))<=i};me.totalDays=function(t){if(!m(t))throw new Y("julianDate is required.");return t.dayNumber+t.secondsOfDay/bn.SECONDS_PER_DAY};me.secondsDifference=function(t,e){if(!m(t))throw new Y("left is required.");if(!m(e))throw new Y("right is required.");return(t.dayNumber-e.dayNumber)*bn.SECONDS_PER_DAY+(t.secondsOfDay-e.secondsOfDay)};me.daysDifference=function(t,e){if(!m(t))throw new Y("left is required.");if(!m(e))throw new Y("right is required.");let i=t.dayNumber-e.dayNumber,n=(t.secondsOfDay-e.secondsOfDay)/bn.SECONDS_PER_DAY;return i+n};me.computeTaiMinusUtc=function(t){Zm.julianDate=t;let e=me.leapSeconds,i=Bo(e,Zm,c0);return i<0&&(i=~i,--i,i<0&&(i=0)),e[i].offset};me.addSeconds=function(t,e,i){if(!m(t))throw new Y("julianDate is required.");if(!m(e))throw new Y("seconds is required.");if(!m(i))throw new Y("result is required.");return sc(t.dayNumber,t.secondsOfDay+e,i)};me.addMinutes=function(t,e,i){if(!m(t))throw new Y("julianDate is required.");if(!m(e))throw new Y("minutes is required.");if(!m(i))throw new Y("result is required.");let n=t.secondsOfDay+e*bn.SECONDS_PER_MINUTE;return sc(t.dayNumber,n,i)};me.addHours=function(t,e,i){if(!m(t))throw new Y("julianDate is required.");if(!m(e))throw new Y("hours is required.");if(!m(i))throw new Y("result is required.");let n=t.secondsOfDay+e*bn.SECONDS_PER_HOUR;return sc(t.dayNumber,n,i)};me.addDays=function(t,e,i){if(!m(t))throw new Y("julianDate is required.");if(!m(e))throw new Y("days is required.");if(!m(i))throw new Y("result is required.");let n=t.dayNumber+e;return sc(n,t.secondsOfDay,i)};me.lessThan=function(t,e){return me.compare(t,e)<0};me.lessThanOrEquals=function(t,e){return me.compare(t,e)<=0};me.greaterThan=function(t,e){return me.compare(t,e)>0};me.greaterThanOrEquals=function(t,e){return me.compare(t,e)>=0};me.prototype.clone=function(t){return me.clone(this,t)};me.prototype.equals=function(t){return me.equals(this,t)};me.prototype.equalsEpsilon=function(t,e){return me.equalsEpsilon(this,t,e)};me.prototype.toString=function(){return me.toIso8601(this)};me.leapSeconds=[new zi(new me(2441317,43210,Ei.TAI),10),new zi(new me(2441499,43211,Ei.TAI),11),new zi(new me(2441683,43212,Ei.TAI),12),new zi(new me(2442048,43213,Ei.TAI),13),new zi(new me(2442413,43214,Ei.TAI),14),new zi(new me(2442778,43215,Ei.TAI),15),new zi(new me(2443144,43216,Ei.TAI),16),new zi(new me(2443509,43217,Ei.TAI),17),new zi(new me(2443874,43218,Ei.TAI),18),new zi(new me(2444239,43219,Ei.TAI),19),new zi(new me(2444786,43220,Ei.TAI),20),new zi(new me(2445151,43221,Ei.TAI),21),new zi(new me(2445516,43222,Ei.TAI),22),new zi(new me(2446247,43223,Ei.TAI),23),new zi(new me(2447161,43224,Ei.TAI),24),new zi(new me(2447892,43225,Ei.TAI),25),new zi(new me(2448257,43226,Ei.TAI),26),new zi(new me(2448804,43227,Ei.TAI),27),new zi(new me(2449169,43228,Ei.TAI),28),new zi(new me(2449534,43229,Ei.TAI),29),new zi(new me(2450083,43230,Ei.TAI),30),new zi(new me(2450630,43231,Ei.TAI),31),new zi(new me(2451179,43232,Ei.TAI),32),new zi(new me(2453736,43233,Ei.TAI),33),new zi(new me(2454832,43234,Ei.TAI),34),new zi(new me(2456109,43235,Ei.TAI),35),new zi(new me(2457204,43236,Ei.TAI),36),new zi(new me(2457754,43237,Ei.TAI),37)];Ze=me});var _W=ts((Im,pm)=>{/*! https://mths.be/punycode v1.4.0 by @mathias */(function(t){var e=typeof Im=="object"&&Im&&!Im.nodeType&&Im,i=typeof pm=="object"&&pm&&!pm.nodeType&&pm,n=typeof global=="object"&&global;(n.global===n||n.window===n||n.self===n)&&(t=n);var s,o=2147483647,r=36,a=1,h=26,A=38,d=700,f=72,E=128,_="-",R=/^xn--/,I=/[^\x20-\x7E]/,C=/[\x2E\u3002\uFF0E\uFF61]/g,N={overflow:"Overflow: input needs wider integers to process","not-basic":"Illegal input >= 0x80 (not a basic code point)","invalid-input":"Invalid input"},T=r-a,F=Math.floor,b=String.fromCharCode,G;function M(j){throw new RangeError(N[j])}function Q(j,X){for(var tt=j.length,B=[];tt--;)B[tt]=X(j[tt]);return B}function U(j,X){var tt=j.split("@"),B="";tt.length>1&&(B=tt[0]+"@",j=tt[1]),j=j.replace(C,".");var It=j.split("."),gt=Q(It,X).join(".");return B+gt}function k(j){for(var X=[],tt=0,B=j.length,It,gt;tt<B;)It=j.charCodeAt(tt++),It>=55296&&It<=56319&&tt<B?(gt=j.charCodeAt(tt++),(gt&64512)==56320?X.push(((It&1023)<<10)+(gt&1023)+65536):(X.push(It),tt--)):X.push(It);return X}function y(j){return Q(j,function(X){var tt="";return X>65535&&(X-=65536,tt+=b(X>>>10&1023|55296),X=56320|X&1023),tt+=b(X),tt}).join("")}function c(j){return j-48<10?j-22:j-65<26?j-65:j-97<26?j-97:r}function g(j,X){return j+22+75*(j<26)-((X!=0)<<5)}function V(j,X,tt){var B=0;for(j=tt?F(j/d):j>>1,j+=F(j/X);j>T*h>>1;B+=r)j=F(j/T);return F(B+(T+1)*j/(j+A))}function D(j){var X=[],tt=j.length,B,It=0,gt=E,Yt=f,Mt,Ct,zt,kt,Jt,Wt,Ft,ee,ce;for(Mt=j.lastIndexOf(_),Mt<0&&(Mt=0),Ct=0;Ct<Mt;++Ct)j.charCodeAt(Ct)>=128&&M("not-basic"),X.push(j.charCodeAt(Ct));for(zt=Mt>0?Mt+1:0;zt<tt;){for(kt=It,Jt=1,Wt=r;zt>=tt&&M("invalid-input"),Ft=c(j.charCodeAt(zt++)),(Ft>=r||Ft>F((o-It)/Jt))&&M("overflow"),It+=Ft*Jt,ee=Wt<=Yt?a:Wt>=Yt+h?h:Wt-Yt,!(Ft<ee);Wt+=r)ce=r-ee,Jt>F(o/ce)&&M("overflow"),Jt*=ce;B=X.length+1,Yt=V(It-kt,B,kt==0),F(It/B)>o-gt&&M("overflow"),gt+=F(It/B),It%=B,X.splice(It++,0,gt)}return y(X)}function w(j){var X,tt,B,It,gt,Yt,Mt,Ct,zt,kt,Jt,Wt=[],Ft,ee,ce,je;for(j=k(j),Ft=j.length,X=E,tt=0,gt=f,Yt=0;Yt<Ft;++Yt)Jt=j[Yt],Jt<128&&Wt.push(b(Jt));for(B=It=Wt.length,It&&Wt.push(_);B<Ft;){for(Mt=o,Yt=0;Yt<Ft;++Yt)Jt=j[Yt],Jt>=X&&Jt<Mt&&(Mt=Jt);for(ee=B+1,Mt-X>F((o-tt)/ee)&&M("overflow"),tt+=(Mt-X)*ee,X=Mt,Yt=0;Yt<Ft;++Yt)if(Jt=j[Yt],Jt<X&&++tt>o&&M("overflow"),Jt==X){for(Ct=tt,zt=r;kt=zt<=gt?a:zt>=gt+h?h:zt-gt,!(Ct<kt);zt+=r)je=Ct-kt,ce=r-kt,Wt.push(b(g(kt+je%ce,0))),Ct=F(je/ce);Wt.push(b(g(Ct,0))),gt=V(tt,ee,B==It),tt=0,++B}++tt,++X}return Wt.join("")}function x(j){return U(j,function(X){return R.test(X)?D(X.slice(4).toLowerCase()):X})}function H(j){return U(j,function(X){return I.test(X)?"xn--"+w(X):X})}if(s={version:"1.3.2",ucs2:{decode:k,encode:y},decode:D,encode:w,toASCII:H,toUnicode:x},typeof define=="function"&&typeof define.amd=="object"&&define.amd)define("punycode",function(){return s});else if(e&&i)if(pm.exports==e)i.exports=s;else for(G in s)s.hasOwnProperty(G)&&(e[G]=s[G]);else t.punycode=s})(Im)});var ZW=ts((RW,fZ)=>{/*!
 * URI.js - Mutating URLs
 * IPv6 Support
 *
 * Version: 1.19.11
 *
 * Author: Rodney Rehm
 * Web: http://medialize.github.io/URI.js/
 *
 * Licensed under
 *   MIT License http://www.opensource.org/licenses/mit-license
 *
 */(function(t,e){"use strict";typeof fZ=="object"&&fZ.exports?fZ.exports=e():typeof define=="function"&&define.amd?define(e):t.IPv6=e(t)})(RW,function(t){"use strict";var e=t&&t.IPv6;function i(s){var o=s.toLowerCase(),r=o.split(":"),a=r.length,h=8;r[0]===""&&r[1]===""&&r[2]===""?(r.shift(),r.shift()):r[0]===""&&r[1]===""?r.shift():r[a-1]===""&&r[a-2]===""&&r.pop(),a=r.length,r[a-1].indexOf(".")!==-1&&(h=7);var A;for(A=0;A<a&&r[A]!=="";A++);if(A<h)for(r.splice(A,1,"0000");r.length<h;)r.splice(A,0,"0000");for(var d,f=0;f<h;f++){d=r[f].split("");for(var E=0;E<3&&(d[0]==="0"&&d.length>1);E++)d.splice(0,1);r[f]=d.join("")}var _=-1,R=0,I=0,C=-1,N=!1;for(f=0;f<h;f++)N?r[f]==="0"?I+=1:(N=!1,I>R&&(_=C,R=I)):r[f]==="0"&&(N=!0,C=f,I=1);I>R&&(_=C,R=I),R>1&&r.splice(_,R,""),a=r.length;var T="";for(r[0]===""&&(T=":"),f=0;f<a&&(T+=r[f],f!==a-1);f++)T+=":";return r[a-1]===""&&(T+=":"),T}function n(){return t.IPv6===this&&(t.IPv6=e),this}return{best:i,noConflict:n}})});var pW=ts((IW,EZ)=>{/*!
 * URI.js - Mutating URLs
 * Second Level Domain (SLD) Support
 *
 * Version: 1.19.11
 *
 * Author: Rodney Rehm
 * Web: http://medialize.github.io/URI.js/
 *
 * Licensed under
 *   MIT License http://www.opensource.org/licenses/mit-license
 *
 */(function(t,e){"use strict";typeof EZ=="object"&&EZ.exports?EZ.exports=e():typeof define=="function"&&define.amd?define(e):t.SecondLevelDomains=e(t)})(IW,function(t){"use strict";var e=t&&t.SecondLevelDomains,i={list:{ac:" com gov mil net org ",ae:" ac co gov mil name net org pro sch ",af:" com edu gov net org ",al:" com edu gov mil net org ",ao:" co ed gv it og pb ",ar:" com edu gob gov int mil net org tur ",at:" ac co gv or ",au:" asn com csiro edu gov id net org ",ba:" co com edu gov mil net org rs unbi unmo unsa untz unze ",bb:" biz co com edu gov info net org store tv ",bh:" biz cc com edu gov info net org ",bn:" com edu gov net org ",bo:" com edu gob gov int mil net org tv ",br:" adm adv agr am arq art ato b bio blog bmd cim cng cnt com coop ecn edu eng esp etc eti far flog fm fnd fot fst g12 ggf gov imb ind inf jor jus lel mat med mil mus net nom not ntr odo org ppg pro psc psi qsl rec slg srv tmp trd tur tv vet vlog wiki zlg ",bs:" com edu gov net org ",bz:" du et om ov rg ",ca:" ab bc mb nb nf nl ns nt nu on pe qc sk yk ",ck:" biz co edu gen gov info net org ",cn:" ac ah bj com cq edu fj gd gov gs gx gz ha hb he hi hl hn jl js jx ln mil net nm nx org qh sc sd sh sn sx tj tw xj xz yn zj ",co:" com edu gov mil net nom org ",cr:" ac c co ed fi go or sa ",cy:" ac biz com ekloges gov ltd name net org parliament press pro tm ",do:" art com edu gob gov mil net org sld web ",dz:" art asso com edu gov net org pol ",ec:" com edu fin gov info med mil net org pro ",eg:" com edu eun gov mil name net org sci ",er:" com edu gov ind mil net org rochest w ",es:" com edu gob nom org ",et:" biz com edu gov info name net org ",fj:" ac biz com info mil name net org pro ",fk:" ac co gov net nom org ",fr:" asso com f gouv nom prd presse tm ",gg:" co net org ",gh:" com edu gov mil org ",gn:" ac com gov net org ",gr:" com edu gov mil net org ",gt:" com edu gob ind mil net org ",gu:" com edu gov net org ",hk:" com edu gov idv net org ",hu:" 2000 agrar bolt casino city co erotica erotika film forum games hotel info ingatlan jogasz konyvelo lakas media news org priv reklam sex shop sport suli szex tm tozsde utazas video ",id:" ac co go mil net or sch web ",il:" ac co gov idf k12 muni net org ",in:" ac co edu ernet firm gen gov i ind mil net nic org res ",iq:" com edu gov i mil net org ",ir:" ac co dnssec gov i id net org sch ",it:" edu gov ",je:" co net org ",jo:" com edu gov mil name net org sch ",jp:" ac ad co ed go gr lg ne or ",ke:" ac co go info me mobi ne or sc ",kh:" com edu gov mil net org per ",ki:" biz com de edu gov info mob net org tel ",km:" asso com coop edu gouv k medecin mil nom notaires pharmaciens presse tm veterinaire ",kn:" edu gov net org ",kr:" ac busan chungbuk chungnam co daegu daejeon es gangwon go gwangju gyeongbuk gyeonggi gyeongnam hs incheon jeju jeonbuk jeonnam k kg mil ms ne or pe re sc seoul ulsan ",kw:" com edu gov net org ",ky:" com edu gov net org ",kz:" com edu gov mil net org ",lb:" com edu gov net org ",lk:" assn com edu gov grp hotel int ltd net ngo org sch soc web ",lr:" com edu gov net org ",lv:" asn com conf edu gov id mil net org ",ly:" com edu gov id med net org plc sch ",ma:" ac co gov m net org press ",mc:" asso tm ",me:" ac co edu gov its net org priv ",mg:" com edu gov mil nom org prd tm ",mk:" com edu gov inf name net org pro ",ml:" com edu gov net org presse ",mn:" edu gov org ",mo:" com edu gov net org ",mt:" com edu gov net org ",mv:" aero biz com coop edu gov info int mil museum name net org pro ",mw:" ac co com coop edu gov int museum net org ",mx:" com edu gob net org ",my:" com edu gov mil name net org sch ",nf:" arts com firm info net other per rec store web ",ng:" biz com edu gov mil mobi name net org sch ",ni:" ac co com edu gob mil net nom org ",np:" com edu gov mil net org ",nr:" biz com edu gov info net org ",om:" ac biz co com edu gov med mil museum net org pro sch ",pe:" com edu gob mil net nom org sld ",ph:" com edu gov i mil net ngo org ",pk:" biz com edu fam gob gok gon gop gos gov net org web ",pl:" art bialystok biz com edu gda gdansk gorzow gov info katowice krakow lodz lublin mil net ngo olsztyn org poznan pwr radom slupsk szczecin torun warszawa waw wroc wroclaw zgora ",pr:" ac biz com edu est gov info isla name net org pro prof ",ps:" com edu gov net org plo sec ",pw:" belau co ed go ne or ",ro:" arts com firm info nom nt org rec store tm www ",rs:" ac co edu gov in org ",sb:" com edu gov net org ",sc:" com edu gov net org ",sh:" co com edu gov net nom org ",sl:" com edu gov net org ",st:" co com consulado edu embaixada gov mil net org principe saotome store ",sv:" com edu gob org red ",sz:" ac co org ",tr:" av bbs bel biz com dr edu gen gov info k12 name net org pol tel tsk tv web ",tt:" aero biz cat co com coop edu gov info int jobs mil mobi museum name net org pro tel travel ",tw:" club com ebiz edu game gov idv mil net org ",mu:" ac co com gov net or org ",mz:" ac co edu gov org ",na:" co com ",nz:" ac co cri geek gen govt health iwi maori mil net org parliament school ",pa:" abo ac com edu gob ing med net nom org sld ",pt:" com edu gov int net nome org publ ",py:" com edu gov mil net org ",qa:" com edu gov mil net org ",re:" asso com nom ",ru:" ac adygeya altai amur arkhangelsk astrakhan bashkiria belgorod bir bryansk buryatia cbg chel chelyabinsk chita chukotka chuvashia com dagestan e-burg edu gov grozny int irkutsk ivanovo izhevsk jar joshkar-ola kalmykia kaluga kamchatka karelia kazan kchr kemerovo khabarovsk khakassia khv kirov koenig komi kostroma kranoyarsk kuban kurgan kursk lipetsk magadan mari mari-el marine mil mordovia mosreg msk murmansk nalchik net nnov nov novosibirsk nsk omsk orenburg org oryol penza perm pp pskov ptz rnd ryazan sakhalin samara saratov simbirsk smolensk spb stavropol stv surgut tambov tatarstan tom tomsk tsaritsyn tsk tula tuva tver tyumen udm udmurtia ulan-ude vladikavkaz vladimir vladivostok volgograd vologda voronezh vrn vyatka yakutia yamal yekaterinburg yuzhno-sakhalinsk ",rw:" ac co com edu gouv gov int mil net ",sa:" com edu gov med net org pub sch ",sd:" com edu gov info med net org tv ",se:" a ac b bd c d e f g h i k l m n o org p parti pp press r s t tm u w x y z ",sg:" com edu gov idn net org per ",sn:" art com edu gouv org perso univ ",sy:" com edu gov mil net news org ",th:" ac co go in mi net or ",tj:" ac biz co com edu go gov info int mil name net nic org test web ",tn:" agrinet com defense edunet ens fin gov ind info intl mincom nat net org perso rnrt rns rnu tourism ",tz:" ac co go ne or ",ua:" biz cherkassy chernigov chernovtsy ck cn co com crimea cv dn dnepropetrovsk donetsk dp edu gov if in ivano-frankivsk kh kharkov kherson khmelnitskiy kiev kirovograd km kr ks kv lg lugansk lutsk lviv me mk net nikolaev od odessa org pl poltava pp rovno rv sebastopol sumy te ternopil uzhgorod vinnica vn zaporizhzhe zhitomir zp zt ",ug:" ac co go ne or org sc ",uk:" ac bl british-library co cym gov govt icnet jet lea ltd me mil mod national-library-scotland nel net nhs nic nls org orgn parliament plc police sch scot soc ",us:" dni fed isa kids nsn ",uy:" com edu gub mil net org ",ve:" co com edu gob info mil net org web ",vi:" co com k12 net org ",vn:" ac biz com edu gov health info int name net org pro ",ye:" co com gov ltd me net org plc ",yu:" ac co edu gov org ",za:" ac agric alt bourse city co cybernet db edu gov grondar iaccess imt inca landesign law mil net ngo nis nom olivetti org pix school tm web ",zm:" ac co com edu gov net org sch ",com:"ar br cn de eu gb gr hu jpn kr no qc ru sa se uk us uy za ",net:"gb jp se uk ",org:"ae",de:"com "},has:function(n){var s=n.lastIndexOf(".");if(s<=0||s>=n.length-1)return!1;var o=n.lastIndexOf(".",s-1);if(o<=0||o>=s-1)return!1;var r=i.list[n.slice(s+1)];return r?r.indexOf(" "+n.slice(o+1,s)+" ")>=0:!1},is:function(n){var s=n.lastIndexOf(".");if(s<=0||s>=n.length-1)return!1;var o=n.lastIndexOf(".",s-1);if(o>=0)return!1;var r=i.list[n.slice(s+1)];return r?r.indexOf(" "+n.slice(0,s)+" ")>=0:!1},get:function(n){var s=n.lastIndexOf(".");if(s<=0||s>=n.length-1)return null;var o=n.lastIndexOf(".",s-1);if(o<=0||o>=s-1)return null;var r=i.list[n.slice(s+1)];return!r||r.indexOf(" "+n.slice(o+1,s)+" ")<0?null:n.slice(o+1)},noConflict:function(){return t.SecondLevelDomains===this&&(t.SecondLevelDomains=e),this}};return i})});var oc=ts((uW,_Z)=>{/*!
 * URI.js - Mutating URLs
 *
 * Version: 1.19.11
 *
 * Author: Rodney Rehm
 * Web: http://medialize.github.io/URI.js/
 *
 * Licensed under
 *   MIT License http://www.opensource.org/licenses/mit-license
 *
 */(function(t,e){"use strict";typeof _Z=="object"&&_Z.exports?_Z.exports=e(_W(),ZW(),pW()):typeof define=="function"&&define.amd?define(["./punycode","./IPv6","./SecondLevelDomains"],e):t.URI=e(t.punycode,t.IPv6,t.SecondLevelDomains,t)})(uW,function(t,e,i,n){"use strict";var s=n&&n.URI;function o(g,V){var D=arguments.length>=1,w=arguments.length>=2;if(!(this instanceof o))return D?w?new o(g,V):new o(g):new o;if(g===void 0){if(D)throw new TypeError("undefined is not a valid argument for URI");typeof location<"u"?g=location.href+"":g=""}if(g===null&&D)throw new TypeError("null is not a valid argument for URI");return this.href(g),V!==void 0?this.absoluteTo(V):this}function r(g){return/^[0-9]+$/.test(g)}o.version="1.19.11";var a=o.prototype,h=Object.prototype.hasOwnProperty;function A(g){return g.replace(/([.*+?^=!:${}()|[\]\/\\])/g,"\\$1")}function d(g){return g===void 0?"Undefined":String(Object.prototype.toString.call(g)).slice(8,-1)}function f(g){return d(g)==="Array"}function E(g,V){var D={},w,x;if(d(V)==="RegExp")D=null;else if(f(V))for(w=0,x=V.length;w<x;w++)D[V[w]]=!0;else D[V]=!0;for(w=0,x=g.length;w<x;w++){var H=D&&D[g[w]]!==void 0||!D&&V.test(g[w]);H&&(g.splice(w,1),x--,w--)}return g}function _(g,V){var D,w;if(f(V)){for(D=0,w=V.length;D<w;D++)if(!_(g,V[D]))return!1;return!0}var x=d(V);for(D=0,w=g.length;D<w;D++)if(x==="RegExp"){if(typeof g[D]=="string"&&g[D].match(V))return!0}else if(g[D]===V)return!0;return!1}function R(g,V){if(!f(g)||!f(V)||g.length!==V.length)return!1;g.sort(),V.sort();for(var D=0,w=g.length;D<w;D++)if(g[D]!==V[D])return!1;return!0}function I(g){var V=/^\/+|\/+$/g;return g.replace(V,"")}o._parts=function(){return{protocol:null,username:null,password:null,hostname:null,urn:null,port:null,path:null,query:null,fragment:null,preventInvalidHostname:o.preventInvalidHostname,duplicateQueryParameters:o.duplicateQueryParameters,escapeQuerySpace:o.escapeQuerySpace}},o.preventInvalidHostname=!1,o.duplicateQueryParameters=!1,o.escapeQuerySpace=!0,o.protocol_expression=/^[a-z][a-z0-9.+-]*$/i,o.idn_expression=/[^a-z0-9\._-]/i,o.punycode_expression=/(xn--)/i,o.ip4_expression=/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/,o.ip6_expression=/^\s*((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9A-Fa-f]{1,4}:){6}(:[0-9A-Fa-f]{1,4}|((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){5}(((:[0-9A-Fa-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){4}(((:[0-9A-Fa-f]{1,4}){1,3})|((:[0-9A-Fa-f]{1,4})?:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){3}(((:[0-9A-Fa-f]{1,4}){1,4})|((:[0-9A-Fa-f]{1,4}){0,2}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){2}(((:[0-9A-Fa-f]{1,4}){1,5})|((:[0-9A-Fa-f]{1,4}){0,3}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){1}(((:[0-9A-Fa-f]{1,4}){1,6})|((:[0-9A-Fa-f]{1,4}){0,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(:(((:[0-9A-Fa-f]{1,4}){1,7})|((:[0-9A-Fa-f]{1,4}){0,5}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(%.+)?\s*$/,o.find_uri_expression=/\b((?:[a-z][\w-]+:(?:\/{1,3}|[a-z0-9%])|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))/ig,o.findUri={start:/\b(?:([a-z][a-z0-9.+-]*:\/\/)|www\.)/gi,end:/[\s\r\n]|$/,trim:/[`!()\[\]{};:'".,<>?«»“”„‘’]+$/,parens:/(\([^\)]*\)|\[[^\]]*\]|\{[^}]*\}|<[^>]*>)/g},o.leading_whitespace_expression=/^[\x00-\x20\u00a0\u1680\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff]+/,o.ascii_tab_whitespace=/[\u0009\u000A\u000D]+/g,o.defaultPorts={http:"80",https:"443",ftp:"21",gopher:"70",ws:"80",wss:"443"},o.hostProtocols=["http","https"],o.invalid_hostname_characters=/[^a-zA-Z0-9\.\-:_]/,o.domAttributes={a:"href",blockquote:"cite",link:"href",base:"href",script:"src",form:"action",img:"src",area:"href",iframe:"src",embed:"src",source:"src",track:"src",input:"src",audio:"src",video:"src"},o.getDomAttribute=function(g){if(!(!g||!g.nodeName)){var V=g.nodeName.toLowerCase();if(!(V==="input"&&g.type!=="image"))return o.domAttributes[V]}};function C(g){return escape(g)}function N(g){return encodeURIComponent(g).replace(/[!'()*]/g,C).replace(/\*/g,"%2A")}o.encode=N,o.decode=decodeURIComponent,o.iso8859=function(){o.encode=escape,o.decode=unescape},o.unicode=function(){o.encode=N,o.decode=decodeURIComponent},o.characters={pathname:{encode:{expression:/%(24|26|2B|2C|3B|3D|3A|40)/ig,map:{"%24":"$","%26":"&","%2B":"+","%2C":",","%3B":";","%3D":"=","%3A":":","%40":"@"}},decode:{expression:/[\/\?#]/g,map:{"/":"%2F","?":"%3F","#":"%23"}}},reserved:{encode:{expression:/%(21|23|24|26|27|28|29|2A|2B|2C|2F|3A|3B|3D|3F|40|5B|5D)/ig,map:{"%3A":":","%2F":"/","%3F":"?","%23":"#","%5B":"[","%5D":"]","%40":"@","%21":"!","%24":"$","%26":"&","%27":"'","%28":"(","%29":")","%2A":"*","%2B":"+","%2C":",","%3B":";","%3D":"="}}},urnpath:{encode:{expression:/%(21|24|27|28|29|2A|2B|2C|3B|3D|40)/ig,map:{"%21":"!","%24":"$","%27":"'","%28":"(","%29":")","%2A":"*","%2B":"+","%2C":",","%3B":";","%3D":"=","%40":"@"}},decode:{expression:/[\/\?#:]/g,map:{"/":"%2F","?":"%3F","#":"%23",":":"%3A"}}}},o.encodeQuery=function(g,V){var D=o.encode(g+"");return V===void 0&&(V=o.escapeQuerySpace),V?D.replace(/%20/g,"+"):D},o.decodeQuery=function(g,V){g+="",V===void 0&&(V=o.escapeQuerySpace);try{return o.decode(V?g.replace(/\+/g,"%20"):g)}catch{return g}};var T={encode:"encode",decode:"decode"},F,b=function(g,V){return function(D){try{return o[V](D+"").replace(o.characters[g][V].expression,function(w){return o.characters[g][V].map[w]})}catch{return D}}};for(F in T)o[F+"PathSegment"]=b("pathname",T[F]),o[F+"UrnPathSegment"]=b("urnpath",T[F]);var G=function(g,V,D){return function(w){var x;D?x=function(tt){return o[V](o[D](tt))}:x=o[V];for(var H=(w+"").split(g),j=0,X=H.length;j<X;j++)H[j]=x(H[j]);return H.join(g)}};o.decodePath=G("/","decodePathSegment"),o.decodeUrnPath=G(":","decodeUrnPathSegment"),o.recodePath=G("/","encodePathSegment","decode"),o.recodeUrnPath=G(":","encodeUrnPathSegment","decode"),o.encodeReserved=b("reserved","encode"),o.parse=function(g,V){var D;return V||(V={preventInvalidHostname:o.preventInvalidHostname}),g=g.replace(o.leading_whitespace_expression,""),g=g.replace(o.ascii_tab_whitespace,""),D=g.indexOf("#"),D>-1&&(V.fragment=g.substring(D+1)||null,g=g.substring(0,D)),D=g.indexOf("?"),D>-1&&(V.query=g.substring(D+1)||null,g=g.substring(0,D)),g=g.replace(/^(https?|ftp|wss?)?:+[/\\]*/i,"$1://"),g=g.replace(/^[/\\]{2,}/i,"//"),g.substring(0,2)==="//"?(V.protocol=null,g=g.substring(2),g=o.parseAuthority(g,V)):(D=g.indexOf(":"),D>-1&&(V.protocol=g.substring(0,D)||null,V.protocol&&!V.protocol.match(o.protocol_expression)?V.protocol=void 0:g.substring(D+1,D+3).replace(/\\/g,"/")==="//"?(g=g.substring(D+3),g=o.parseAuthority(g,V)):(g=g.substring(D+1),V.urn=!0))),V.path=g,V},o.parseHost=function(g,V){g||(g=""),g=g.replace(/\\/g,"/");var D=g.indexOf("/"),w,x;if(D===-1&&(D=g.length),g.charAt(0)==="[")w=g.indexOf("]"),V.hostname=g.substring(1,w)||null,V.port=g.substring(w+2,D)||null,V.port==="/"&&(V.port=null);else{var H=g.indexOf(":"),j=g.indexOf("/"),X=g.indexOf(":",H+1);X!==-1&&(j===-1||X<j)?(V.hostname=g.substring(0,D)||null,V.port=null):(x=g.substring(0,D).split(":"),V.hostname=x[0]||null,V.port=x[1]||null)}return V.hostname&&g.substring(D).charAt(0)!=="/"&&(D++,g="/"+g),V.preventInvalidHostname&&o.ensureValidHostname(V.hostname,V.protocol),V.port&&o.ensureValidPort(V.port),g.substring(D)||"/"},o.parseAuthority=function(g,V){return g=o.parseUserinfo(g,V),o.parseHost(g,V)},o.parseUserinfo=function(g,V){var D=g,w=g.indexOf("\\");w!==-1&&(g=g.replace(/\\/g,"/"));var x=g.indexOf("/"),H=g.lastIndexOf("@",x>-1?x:g.length-1),j;return H>-1&&(x===-1||H<x)?(j=g.substring(0,H).split(":"),V.username=j[0]?o.decode(j[0]):null,j.shift(),V.password=j[0]?o.decode(j.join(":")):null,g=D.substring(H+1)):(V.username=null,V.password=null),g},o.parseQuery=function(g,V){if(!g)return{};if(g=g.replace(/&+/g,"&").replace(/^\?*&*|&+$/g,""),!g)return{};for(var D={},w=g.split("&"),x=w.length,H,j,X,tt=0;tt<x;tt++)H=w[tt].split("="),j=o.decodeQuery(H.shift(),V),X=H.length?o.decodeQuery(H.join("="),V):null,j!=="__proto__"&&(h.call(D,j)?((typeof D[j]=="string"||D[j]===null)&&(D[j]=[D[j]]),D[j].push(X)):D[j]=X);return D},o.build=function(g){var V="",D=!1;return g.protocol&&(V+=g.protocol+":"),!g.urn&&(V||g.hostname)&&(V+="//",D=!0),V+=o.buildAuthority(g)||"",typeof g.path=="string"&&(g.path.charAt(0)!=="/"&&D&&(V+="/"),V+=g.path),typeof g.query=="string"&&g.query&&(V+="?"+g.query),typeof g.fragment=="string"&&g.fragment&&(V+="#"+g.fragment),V},o.buildHost=function(g){var V="";if(g.hostname)o.ip6_expression.test(g.hostname)?V+="["+g.hostname+"]":V+=g.hostname;else return"";return g.port&&(V+=":"+g.port),V},o.buildAuthority=function(g){return o.buildUserinfo(g)+o.buildHost(g)},o.buildUserinfo=function(g){var V="";return g.username&&(V+=o.encode(g.username)),g.password&&(V+=":"+o.encode(g.password)),V&&(V+="@"),V},o.buildQuery=function(g,V,D){var w="",x,H,j,X;for(H in g)if(H!=="__proto__"&&h.call(g,H))if(f(g[H]))for(x={},j=0,X=g[H].length;j<X;j++)g[H][j]!==void 0&&x[g[H][j]+""]===void 0&&(w+="&"+o.buildQueryParameter(H,g[H][j],D),V!==!0&&(x[g[H][j]+""]=!0));else g[H]!==void 0&&(w+="&"+o.buildQueryParameter(H,g[H],D));return w.substring(1)},o.buildQueryParameter=function(g,V,D){return o.encodeQuery(g,D)+(V!==null?"="+o.encodeQuery(V,D):"")},o.addQuery=function(g,V,D){if(typeof V=="object")for(var w in V)h.call(V,w)&&o.addQuery(g,w,V[w]);else if(typeof V=="string"){if(g[V]===void 0){g[V]=D;return}else typeof g[V]=="string"&&(g[V]=[g[V]]);f(D)||(D=[D]),g[V]=(g[V]||[]).concat(D)}else throw new TypeError("URI.addQuery() accepts an object, string as the name parameter")},o.setQuery=function(g,V,D){if(typeof V=="object")for(var w in V)h.call(V,w)&&o.setQuery(g,w,V[w]);else if(typeof V=="string")g[V]=D===void 0?null:D;else throw new TypeError("URI.setQuery() accepts an object, string as the name parameter")},o.removeQuery=function(g,V,D){var w,x,H;if(f(V))for(w=0,x=V.length;w<x;w++)g[V[w]]=void 0;else if(d(V)==="RegExp")for(H in g)V.test(H)&&(g[H]=void 0);else if(typeof V=="object")for(H in V)h.call(V,H)&&o.removeQuery(g,H,V[H]);else if(typeof V=="string")D!==void 0?d(D)==="RegExp"?!f(g[V])&&D.test(g[V])?g[V]=void 0:g[V]=E(g[V],D):g[V]===String(D)&&(!f(D)||D.length===1)?g[V]=void 0:f(g[V])&&(g[V]=E(g[V],D)):g[V]=void 0;else throw new TypeError("URI.removeQuery() accepts an object, string, RegExp as the first parameter")},o.hasQuery=function(g,V,D,w){switch(d(V)){case"String":break;case"RegExp":for(var x in g)if(h.call(g,x)&&V.test(x)&&(D===void 0||o.hasQuery(g,x,D)))return!0;return!1;case"Object":for(var H in V)if(h.call(V,H)&&!o.hasQuery(g,H,V[H]))return!1;return!0;default:throw new TypeError("URI.hasQuery() accepts a string, regular expression or object as the name parameter")}switch(d(D)){case"Undefined":return V in g;case"Boolean":var j=!!(f(g[V])?g[V].length:g[V]);return D===j;case"Function":return!!D(g[V],V,g);case"Array":if(!f(g[V]))return!1;var X=w?_:R;return X(g[V],D);case"RegExp":return f(g[V])?w?_(g[V],D):!1:!!(g[V]&&g[V].match(D));case"Number":D=String(D);case"String":return f(g[V])?w?_(g[V],D):!1:g[V]===D;default:throw new TypeError("URI.hasQuery() accepts undefined, boolean, string, number, RegExp, Function as the value parameter")}},o.joinPaths=function(){for(var g=[],V=[],D=0,w=0;w<arguments.length;w++){var x=new o(arguments[w]);g.push(x);for(var H=x.segment(),j=0;j<H.length;j++)typeof H[j]=="string"&&V.push(H[j]),H[j]&&D++}if(!V.length||!D)return new o("");var X=new o("").segment(V);return(g[0].path()===""||g[0].path().slice(0,1)==="/")&&X.path("/"+X.path()),X.normalize()},o.commonPath=function(g,V){var D=Math.min(g.length,V.length),w;for(w=0;w<D;w++)if(g.charAt(w)!==V.charAt(w)){w--;break}return w<1?g.charAt(0)===V.charAt(0)&&g.charAt(0)==="/"?"/":"":((g.charAt(w)!=="/"||V.charAt(w)!=="/")&&(w=g.substring(0,w).lastIndexOf("/")),g.substring(0,w+1))},o.withinString=function(g,V,D){D||(D={});var w=D.start||o.findUri.start,x=D.end||o.findUri.end,H=D.trim||o.findUri.trim,j=D.parens||o.findUri.parens,X=/[a-z0-9-]=["']?$/i;for(w.lastIndex=0;;){var tt=w.exec(g);if(!tt)break;var B=tt.index;if(D.ignoreHtml){var It=g.slice(Math.max(B-3,0),B);if(It&&X.test(It))continue}for(var gt=B+g.slice(B).search(x),Yt=g.slice(B,gt),Mt=-1;;){var Ct=j.exec(Yt);if(!Ct)break;var zt=Ct.index+Ct[0].length;Mt=Math.max(Mt,zt)}if(Mt>-1?Yt=Yt.slice(0,Mt)+Yt.slice(Mt).replace(H,""):Yt=Yt.replace(H,""),!(Yt.length<=tt[0].length)&&!(D.ignore&&D.ignore.test(Yt))){gt=B+Yt.length;var kt=V(Yt,B,gt,g);if(kt===void 0){w.lastIndex=gt;continue}kt=String(kt),g=g.slice(0,B)+kt+g.slice(gt),w.lastIndex=B+kt.length}}return w.lastIndex=0,g},o.ensureValidHostname=function(g,V){var D=!!g,w=!!V,x=!1;if(w&&(x=_(o.hostProtocols,V)),x&&!D)throw new TypeError("Hostname cannot be empty, if protocol is "+V);if(g&&g.match(o.invalid_hostname_characters)){if(!t)throw new TypeError('Hostname "'+g+'" contains characters other than [A-Z0-9.-:_] and Punycode.js is not available');if(t.toASCII(g).match(o.invalid_hostname_characters))throw new TypeError('Hostname "'+g+'" contains characters other than [A-Z0-9.-:_]')}},o.ensureValidPort=function(g){if(g){var V=Number(g);if(!(r(V)&&V>0&&V<65536))throw new TypeError('Port "'+g+'" is not a valid port')}},o.noConflict=function(g){if(g){var V={URI:this.noConflict()};return n.URITemplate&&typeof n.URITemplate.noConflict=="function"&&(V.URITemplate=n.URITemplate.noConflict()),n.IPv6&&typeof n.IPv6.noConflict=="function"&&(V.IPv6=n.IPv6.noConflict()),n.SecondLevelDomains&&typeof n.SecondLevelDomains.noConflict=="function"&&(V.SecondLevelDomains=n.SecondLevelDomains.noConflict()),V}else n.URI===this&&(n.URI=s);return this},a.build=function(g){return g===!0?this._deferred_build=!0:(g===void 0||this._deferred_build)&&(this._string=o.build(this._parts),this._deferred_build=!1),this},a.clone=function(){return new o(this)},a.valueOf=a.toString=function(){return this.build(!1)._string};function M(g){return function(V,D){return V===void 0?this._parts[g]||"":(this._parts[g]=V||null,this.build(!D),this)}}function Q(g,V){return function(D,w){return D===void 0?this._parts[g]||"":(D!==null&&(D=D+"",D.charAt(0)===V&&(D=D.substring(1))),this._parts[g]=D,this.build(!w),this)}}a.protocol=M("protocol"),a.username=M("username"),a.password=M("password"),a.hostname=M("hostname"),a.port=M("port"),a.query=Q("query","?"),a.fragment=Q("fragment","#"),a.search=function(g,V){var D=this.query(g,V);return typeof D=="string"&&D.length?"?"+D:D},a.hash=function(g,V){var D=this.fragment(g,V);return typeof D=="string"&&D.length?"#"+D:D},a.pathname=function(g,V){if(g===void 0||g===!0){var D=this._parts.path||(this._parts.hostname?"/":"");return g?(this._parts.urn?o.decodeUrnPath:o.decodePath)(D):D}else return this._parts.urn?this._parts.path=g?o.recodeUrnPath(g):"":this._parts.path=g?o.recodePath(g):"/",this.build(!V),this},a.path=a.pathname,a.href=function(g,V){var D;if(g===void 0)return this.toString();this._string="",this._parts=o._parts();var w=g instanceof o,x=typeof g=="object"&&(g.hostname||g.path||g.pathname);if(g.nodeName){var H=o.getDomAttribute(g);g=g[H]||"",x=!1}if(!w&&x&&g.pathname!==void 0&&(g=g.toString()),typeof g=="string"||g instanceof String)this._parts=o.parse(String(g),this._parts);else if(w||x){var j=w?g._parts:g;for(D in j)D!=="query"&&h.call(this._parts,D)&&(this._parts[D]=j[D]);j.query&&this.query(j.query,!1)}else throw new TypeError("invalid input");return this.build(!V),this},a.is=function(g){var V=!1,D=!1,w=!1,x=!1,H=!1,j=!1,X=!1,tt=!this._parts.urn;switch(this._parts.hostname&&(tt=!1,D=o.ip4_expression.test(this._parts.hostname),w=o.ip6_expression.test(this._parts.hostname),V=D||w,x=!V,H=x&&i&&i.has(this._parts.hostname),j=x&&o.idn_expression.test(this._parts.hostname),X=x&&o.punycode_expression.test(this._parts.hostname)),g.toLowerCase()){case"relative":return tt;case"absolute":return!tt;case"domain":case"name":return x;case"sld":return H;case"ip":return V;case"ip4":case"ipv4":case"inet4":return D;case"ip6":case"ipv6":case"inet6":return w;case"idn":return j;case"url":return!this._parts.urn;case"urn":return!!this._parts.urn;case"punycode":return X}return null};var U=a.protocol,k=a.port,y=a.hostname;a.protocol=function(g,V){if(g&&(g=g.replace(/:(\/\/)?$/,""),!g.match(o.protocol_expression)))throw new TypeError('Protocol "'+g+`" contains characters other than [A-Z0-9.+-] or doesn't start with [A-Z]`);return U.call(this,g,V)},a.scheme=a.protocol,a.port=function(g,V){return this._parts.urn?g===void 0?"":this:(g!==void 0&&(g===0&&(g=null),g&&(g+="",g.charAt(0)===":"&&(g=g.substring(1)),o.ensureValidPort(g))),k.call(this,g,V))},a.hostname=function(g,V){if(this._parts.urn)return g===void 0?"":this;if(g!==void 0){var D={preventInvalidHostname:this._parts.preventInvalidHostname},w=o.parseHost(g,D);if(w!=="/")throw new TypeError('Hostname "'+g+'" contains characters other than [A-Z0-9.-]');g=D.hostname,this._parts.preventInvalidHostname&&o.ensureValidHostname(g,this._parts.protocol)}return y.call(this,g,V)},a.origin=function(g,V){if(this._parts.urn)return g===void 0?"":this;if(g===void 0){var D=this.protocol(),w=this.authority();return w?(D?D+"://":"")+this.authority():""}else{var x=o(g);return this.protocol(x.protocol()).authority(x.authority()).build(!V),this}},a.host=function(g,V){if(this._parts.urn)return g===void 0?"":this;if(g===void 0)return this._parts.hostname?o.buildHost(this._parts):"";var D=o.parseHost(g,this._parts);if(D!=="/")throw new TypeError('Hostname "'+g+'" contains characters other than [A-Z0-9.-]');return this.build(!V),this},a.authority=function(g,V){if(this._parts.urn)return g===void 0?"":this;if(g===void 0)return this._parts.hostname?o.buildAuthority(this._parts):"";var D=o.parseAuthority(g,this._parts);if(D!=="/")throw new TypeError('Hostname "'+g+'" contains characters other than [A-Z0-9.-]');return this.build(!V),this},a.userinfo=function(g,V){if(this._parts.urn)return g===void 0?"":this;if(g===void 0){var D=o.buildUserinfo(this._parts);return D&&D.substring(0,D.length-1)}else return g[g.length-1]!=="@"&&(g+="@"),o.parseUserinfo(g,this._parts),this.build(!V),this},a.resource=function(g,V){var D;return g===void 0?this.path()+this.search()+this.hash():(D=o.parse(g),this._parts.path=D.path,this._parts.query=D.query,this._parts.fragment=D.fragment,this.build(!V),this)},a.subdomain=function(g,V){if(this._parts.urn)return g===void 0?"":this;if(g===void 0){if(!this._parts.hostname||this.is("IP"))return"";var D=this._parts.hostname.length-this.domain().length-1;return this._parts.hostname.substring(0,D)||""}else{var w=this._parts.hostname.length-this.domain().length,x=this._parts.hostname.substring(0,w),H=new RegExp("^"+A(x));if(g&&g.charAt(g.length-1)!=="."&&(g+="."),g.indexOf(":")!==-1)throw new TypeError("Domains cannot contain colons");return g&&o.ensureValidHostname(g,this._parts.protocol),this._parts.hostname=this._parts.hostname.replace(H,g),this.build(!V),this}},a.domain=function(g,V){if(this._parts.urn)return g===void 0?"":this;if(typeof g=="boolean"&&(V=g,g=void 0),g===void 0){if(!this._parts.hostname||this.is("IP"))return"";var D=this._parts.hostname.match(/\./g);if(D&&D.length<2)return this._parts.hostname;var w=this._parts.hostname.length-this.tld(V).length-1;return w=this._parts.hostname.lastIndexOf(".",w-1)+1,this._parts.hostname.substring(w)||""}else{if(!g)throw new TypeError("cannot set domain empty");if(g.indexOf(":")!==-1)throw new TypeError("Domains cannot contain colons");if(o.ensureValidHostname(g,this._parts.protocol),!this._parts.hostname||this.is("IP"))this._parts.hostname=g;else{var x=new RegExp(A(this.domain())+"$");this._parts.hostname=this._parts.hostname.replace(x,g)}return this.build(!V),this}},a.tld=function(g,V){if(this._parts.urn)return g===void 0?"":this;if(typeof g=="boolean"&&(V=g,g=void 0),g===void 0){if(!this._parts.hostname||this.is("IP"))return"";var D=this._parts.hostname.lastIndexOf("."),w=this._parts.hostname.substring(D+1);return V!==!0&&i&&i.list[w.toLowerCase()]&&i.get(this._parts.hostname)||w}else{var x;if(g)if(g.match(/[^a-zA-Z0-9-]/))if(i&&i.is(g))x=new RegExp(A(this.tld())+"$"),this._parts.hostname=this._parts.hostname.replace(x,g);else throw new TypeError('TLD "'+g+'" contains characters other than [A-Z0-9]');else{if(!this._parts.hostname||this.is("IP"))throw new ReferenceError("cannot set TLD on non-domain host");x=new RegExp(A(this.tld())+"$"),this._parts.hostname=this._parts.hostname.replace(x,g)}else throw new TypeError("cannot set TLD empty");return this.build(!V),this}},a.directory=function(g,V){if(this._parts.urn)return g===void 0?"":this;if(g===void 0||g===!0){if(!this._parts.path&&!this._parts.hostname)return"";if(this._parts.path==="/")return"/";var D=this._parts.path.length-this.filename().length-1,w=this._parts.path.substring(0,D)||(this._parts.hostname?"/":"");return g?o.decodePath(w):w}else{var x=this._parts.path.length-this.filename().length,H=this._parts.path.substring(0,x),j=new RegExp("^"+A(H));return this.is("relative")||(g||(g="/"),g.charAt(0)!=="/"&&(g="/"+g)),g&&g.charAt(g.length-1)!=="/"&&(g+="/"),g=o.recodePath(g),this._parts.path=this._parts.path.replace(j,g),this.build(!V),this}},a.filename=function(g,V){if(this._parts.urn)return g===void 0?"":this;if(typeof g!="string"){if(!this._parts.path||this._parts.path==="/")return"";var D=this._parts.path.lastIndexOf("/"),w=this._parts.path.substring(D+1);return g?o.decodePathSegment(w):w}else{var x=!1;g.charAt(0)==="/"&&(g=g.substring(1)),g.match(/\.?\//)&&(x=!0);var H=new RegExp(A(this.filename())+"$");return g=o.recodePath(g),this._parts.path=this._parts.path.replace(H,g),x?this.normalizePath(V):this.build(!V),this}},a.suffix=function(g,V){if(this._parts.urn)return g===void 0?"":this;if(g===void 0||g===!0){if(!this._parts.path||this._parts.path==="/")return"";var D=this.filename(),w=D.lastIndexOf("."),x,H;return w===-1?"":(x=D.substring(w+1),H=/^[a-z0-9%]+$/i.test(x)?x:"",g?o.decodePathSegment(H):H)}else{g.charAt(0)==="."&&(g=g.substring(1));var j=this.suffix(),X;if(j)g?X=new RegExp(A(j)+"$"):X=new RegExp(A("."+j)+"$");else{if(!g)return this;this._parts.path+="."+o.recodePath(g)}return X&&(g=o.recodePath(g),this._parts.path=this._parts.path.replace(X,g)),this.build(!V),this}},a.segment=function(g,V,D){var w=this._parts.urn?":":"/",x=this.path(),H=x.substring(0,1)==="/",j=x.split(w);if(g!==void 0&&typeof g!="number"&&(D=V,V=g,g=void 0),g!==void 0&&typeof g!="number")throw new Error('Bad segment "'+g+'", must be 0-based integer');if(H&&j.shift(),g<0&&(g=Math.max(j.length+g,0)),V===void 0)return g===void 0?j:j[g];if(g===null||j[g]===void 0)if(f(V)){j=[];for(var X=0,tt=V.length;X<tt;X++)!V[X].length&&(!j.length||!j[j.length-1].length)||(j.length&&!j[j.length-1].length&&j.pop(),j.push(I(V[X])))}else(V||typeof V=="string")&&(V=I(V),j[j.length-1]===""?j[j.length-1]=V:j.push(V));else V?j[g]=I(V):j.splice(g,1);return H&&j.unshift(""),this.path(j.join(w),D)},a.segmentCoded=function(g,V,D){var w,x,H;if(typeof g!="number"&&(D=V,V=g,g=void 0),V===void 0){if(w=this.segment(g,V,D),!f(w))w=w!==void 0?o.decode(w):void 0;else for(x=0,H=w.length;x<H;x++)w[x]=o.decode(w[x]);return w}if(!f(V))V=typeof V=="string"||V instanceof String?o.encode(V):V;else for(x=0,H=V.length;x<H;x++)V[x]=o.encode(V[x]);return this.segment(g,V,D)};var c=a.query;return a.query=function(g,V){if(g===!0)return o.parseQuery(this._parts.query,this._parts.escapeQuerySpace);if(typeof g=="function"){var D=o.parseQuery(this._parts.query,this._parts.escapeQuerySpace),w=g.call(this,D);return this._parts.query=o.buildQuery(w||D,this._parts.duplicateQueryParameters,this._parts.escapeQuerySpace),this.build(!V),this}else return g!==void 0&&typeof g!="string"?(this._parts.query=o.buildQuery(g,this._parts.duplicateQueryParameters,this._parts.escapeQuerySpace),this.build(!V),this):c.call(this,g,V)},a.setQuery=function(g,V,D){var w=o.parseQuery(this._parts.query,this._parts.escapeQuerySpace);if(typeof g=="string"||g instanceof String)w[g]=V!==void 0?V:null;else if(typeof g=="object")for(var x in g)h.call(g,x)&&(w[x]=g[x]);else throw new TypeError("URI.addQuery() accepts an object, string as the name parameter");return this._parts.query=o.buildQuery(w,this._parts.duplicateQueryParameters,this._parts.escapeQuerySpace),typeof g!="string"&&(D=V),this.build(!D),this},a.addQuery=function(g,V,D){var w=o.parseQuery(this._parts.query,this._parts.escapeQuerySpace);return o.addQuery(w,g,V===void 0?null:V),this._parts.query=o.buildQuery(w,this._parts.duplicateQueryParameters,this._parts.escapeQuerySpace),typeof g!="string"&&(D=V),this.build(!D),this},a.removeQuery=function(g,V,D){var w=o.parseQuery(this._parts.query,this._parts.escapeQuerySpace);return o.removeQuery(w,g,V),this._parts.query=o.buildQuery(w,this._parts.duplicateQueryParameters,this._parts.escapeQuerySpace),typeof g!="string"&&(D=V),this.build(!D),this},a.hasQuery=function(g,V,D){var w=o.parseQuery(this._parts.query,this._parts.escapeQuerySpace);return o.hasQuery(w,g,V,D)},a.setSearch=a.setQuery,a.addSearch=a.addQuery,a.removeSearch=a.removeQuery,a.hasSearch=a.hasQuery,a.normalize=function(){return this._parts.urn?this.normalizeProtocol(!1).normalizePath(!1).normalizeQuery(!1).normalizeFragment(!1).build():this.normalizeProtocol(!1).normalizeHostname(!1).normalizePort(!1).normalizePath(!1).normalizeQuery(!1).normalizeFragment(!1).build()},a.normalizeProtocol=function(g){return typeof this._parts.protocol=="string"&&(this._parts.protocol=this._parts.protocol.toLowerCase(),this.build(!g)),this},a.normalizeHostname=function(g){return this._parts.hostname&&(this.is("IDN")&&t?this._parts.hostname=t.toASCII(this._parts.hostname):this.is("IPv6")&&e&&(this._parts.hostname=e.best(this._parts.hostname)),this._parts.hostname=this._parts.hostname.toLowerCase(),this.build(!g)),this},a.normalizePort=function(g){return typeof this._parts.protocol=="string"&&this._parts.port===o.defaultPorts[this._parts.protocol]&&(this._parts.port=null,this.build(!g)),this},a.normalizePath=function(g){var V=this._parts.path;if(!V)return this;if(this._parts.urn)return this._parts.path=o.recodeUrnPath(this._parts.path),this.build(!g),this;if(this._parts.path==="/")return this;V=o.recodePath(V);var D,w="",x,H;for(V.charAt(0)!=="/"&&(D=!0,V="/"+V),(V.slice(-3)==="/.."||V.slice(-2)==="/.")&&(V+="/"),V=V.replace(/(\/(\.\/)+)|(\/\.$)/g,"/").replace(/\/{2,}/g,"/"),D&&(w=V.substring(1).match(/^(\.\.\/)+/)||"",w&&(w=w[0]));x=V.search(/\/\.\.(\/|$)/),x!==-1;){if(x===0){V=V.substring(3);continue}H=V.substring(0,x).lastIndexOf("/"),H===-1&&(H=x),V=V.substring(0,H)+V.substring(x+3)}return D&&this.is("relative")&&(V=w+V.substring(1)),this._parts.path=V,this.build(!g),this},a.normalizePathname=a.normalizePath,a.normalizeQuery=function(g){return typeof this._parts.query=="string"&&(this._parts.query.length?this.query(o.parseQuery(this._parts.query,this._parts.escapeQuerySpace)):this._parts.query=null,this.build(!g)),this},a.normalizeFragment=function(g){return this._parts.fragment||(this._parts.fragment=null,this.build(!g)),this},a.normalizeSearch=a.normalizeQuery,a.normalizeHash=a.normalizeFragment,a.iso8859=function(){var g=o.encode,V=o.decode;o.encode=escape,o.decode=decodeURIComponent;try{this.normalize()}finally{o.encode=g,o.decode=V}return this},a.unicode=function(){var g=o.encode,V=o.decode;o.encode=N,o.decode=unescape;try{this.normalize()}finally{o.encode=g,o.decode=V}return this},a.readable=function(){var g=this.clone();g.username("").password("").normalize();var V="";if(g._parts.protocol&&(V+=g._parts.protocol+"://"),g._parts.hostname&&(g.is("punycode")&&t?(V+=t.toUnicode(g._parts.hostname),g._parts.port&&(V+=":"+g._parts.port)):V+=g.host()),g._parts.hostname&&g._parts.path&&g._parts.path.charAt(0)!=="/"&&(V+="/"),V+=g.path(!0),g._parts.query){for(var D="",w=0,x=g._parts.query.split("&"),H=x.length;w<H;w++){var j=(x[w]||"").split("=");D+="&"+o.decodeQuery(j[0],this._parts.escapeQuerySpace).replace(/&/g,"%26"),j[1]!==void 0&&(D+="="+o.decodeQuery(j[1],this._parts.escapeQuerySpace).replace(/&/g,"%26"))}V+="?"+D.substring(1)}return V+=o.decodeQuery(g.hash(),!0),V},a.absoluteTo=function(g){var V=this.clone(),D=["protocol","username","password","hostname","port"],w,x,H;if(this._parts.urn)throw new Error("URNs do not have any generally defined hierarchical components");if(g instanceof o||(g=new o(g)),V._parts.protocol||(V._parts.protocol=g._parts.protocol,this._parts.hostname))return V;for(x=0;H=D[x];x++)V._parts[H]=g._parts[H];return V._parts.path?(V._parts.path.substring(-2)===".."&&(V._parts.path+="/"),V.path().charAt(0)!=="/"&&(w=g.directory(),w=w||(g.path().indexOf("/")===0?"/":""),V._parts.path=(w?w+"/":"")+V._parts.path,V.normalizePath())):(V._parts.path=g._parts.path,V._parts.query||(V._parts.query=g._parts.query)),V.build(),V},a.relativeTo=function(g){var V=this.clone().normalize(),D,w,x,H,j;if(V._parts.urn)throw new Error("URNs do not have any generally defined hierarchical components");if(g=new o(g).normalize(),D=V._parts,w=g._parts,H=V.path(),j=g.path(),H.charAt(0)!=="/")throw new Error("URI is already relative");if(j.charAt(0)!=="/")throw new Error("Cannot calculate a URI relative to another relative URI");if(D.protocol===w.protocol&&(D.protocol=null),D.username!==w.username||D.password!==w.password||D.protocol!==null||D.username!==null||D.password!==null)return V.build();if(D.hostname===w.hostname&&D.port===w.port)D.hostname=null,D.port=null;else return V.build();if(H===j)return D.path="",V.build();if(x=o.commonPath(H,j),!x)return V.build();var X=w.path.substring(x.length).replace(/[^\/]*$/,"").replace(/.*?\//g,"../");return D.path=X+D.path.substring(x.length)||"./",V.build()},a.equals=function(g){var V=this.clone(),D=new o(g),w={},x={},H={},j,X,tt;if(V.normalize(),D.normalize(),V.toString()===D.toString())return!0;if(j=V.query(),X=D.query(),V.query(""),D.query(""),V.toString()!==D.toString()||j.length!==X.length)return!1;w=o.parseQuery(j,this._parts.escapeQuerySpace),x=o.parseQuery(X,this._parts.escapeQuerySpace);for(tt in w)if(h.call(w,tt)){if(f(w[tt])){if(!R(w[tt],x[tt]))return!1}else if(w[tt]!==x[tt])return!1;H[tt]=!0}for(tt in x)if(h.call(x,tt)&&!H[tt])return!1;return!0},a.preventInvalidHostname=function(g){return this._parts.preventInvalidHostname=!!g,this},a.duplicateQueryParameters=function(g){return this._parts.duplicateQueryParameters=!!g,this},a.escapeQuerySpace=function(g){return this._parts.escapeQuerySpace=!!g,this},o})});function Tq(t){return(t.length===0||t[t.length-1]!=="/")&&(t=`${t}/`),t}var CW,gW=O(()=>{CW=Tq});function TW(t,e){if(t===null||typeof t!="object")return t;e=Z(e,!1);let i=new t.constructor;for(let n in t)if(t.hasOwnProperty(n)){let s=t[n];e&&(s=TW(s,e)),i[n]=s}return i}var qs,aE=O(()=>{bt();qs=TW});function NW(t,e,i){i=Z(i,!1);let n={},s=m(t),o=m(e),r,a,h;if(s)for(r in t)t.hasOwnProperty(r)&&(a=t[r],o&&i&&typeof a=="object"&&e.hasOwnProperty(r)?(h=e[r],typeof h=="object"?n[r]=NW(a,h,i):n[r]=a):n[r]=a);if(o)for(r in e)e.hasOwnProperty(r)&&!n.hasOwnProperty(r)&&(h=e[r],n[r]=h);return n}var es,KA=O(()=>{bt();mt();es=NW});function Nq(){let t,e,i=new Promise(function(n,s){t=n,e=s});return{resolve:t,reject:e,promise:i}}var El,m0=O(()=>{El=Nq});function f0(t,e){let i;return typeof document<"u"&&(i=document),f0._implementation(t,e,i)}var bW,AE,E0=O(()=>{bW=co(oc(),1);bt();mt();Vt();f0._implementation=function(t,e,i){if(!m(t))throw new Y("relative uri is required.");if(!m(e)){if(typeof i>"u")return t;e=Z(i.baseURI,i.location.href)}let n=new bW.default(t);return n.scheme()!==""?n.toString():n.absoluteTo(e).toString()};AE=f0});function bq(t,e){if(!m(t))throw new Y("uri is required.");let i="",n=t.lastIndexOf("/");return n!==-1&&(i=t.substring(0,n+1)),e&&(t=new FW.default(t),t.query().length!==0&&(i+=`?${t.query()}`),t.fragment().length!==0&&(i+=`#${t.fragment()}`)),i}var FW,YW,SW=O(()=>{FW=co(oc(),1);mt();Vt();YW=bq});function Fq(t){if(!m(t))throw new Y("uri is required.");let e=new OW.default(t);e.normalize();let i=e.path(),n=i.lastIndexOf("/");return n!==-1&&(i=i.substr(n+1)),n=i.lastIndexOf("."),n===-1?i="":i=i.substr(n+1),i}var OW,VW,GW=O(()=>{OW=co(oc(),1);mt();Vt();VW=Fq});function Yq(t,e,i){m(e)||(e=t.width),m(i)||(i=t.height);let n=BW[e];m(n)||(n={},BW[e]=n);let s=n[i];if(!m(s)){let o=document.createElement("canvas");o.width=e,o.height=i,s=o.getContext("2d",{willReadFrequently:!0}),s.globalCompositeOperation="copy",n[i]=s}return s.drawImage(t,0,0,e,i),s.getImageData(0,0,e,i).data}var BW,_0,WW=O(()=>{mt();BW={};_0=Yq});function Oq(t){return p.typeOf.string("uri",t),Sq.test(t)}var Sq,RZ,R0=O(()=>{ae();Sq=/^blob:/i;RZ=Oq});function Vq(t){m(aA)||(aA=document.createElement("a")),aA.href=window.location.href;let e=aA.host,i=aA.protocol;return aA.href=t,aA.href=aA.href,i!==aA.protocol||e!==aA.host}var aA,ZZ,Z0=O(()=>{mt();ZZ=Vq});function Bq(t){return p.typeOf.string("uri",t),Gq.test(t)}var Gq,IZ,I0=O(()=>{ae();Gq=/^data:/i;IZ=Bq});function Wq(t){let e=document.createElement("script");return e.async=!0,e.src=t,new Promise((i,n)=>{window.crossOriginIsolated&&e.setAttribute("crossorigin","anonymous");let s=document.getElementsByTagName("head")[0];e.onload=function(){e.onload=void 0,s.removeChild(e),i()},e.onerror=function(o){n(o)},s.appendChild(e)})}var DW,MW=O(()=>{DW=Wq});function Dq(t){if(!m(t))throw new Y("obj is required.");let e="";for(let i in t)if(t.hasOwnProperty(i)){let n=t[i],s=`${encodeURIComponent(i)}=`;if(Array.isArray(n))for(let o=0,r=n.length;o<r;++o)e+=`${s+encodeURIComponent(n[o])}&`;else e+=`${s+encodeURIComponent(n)}&`}return e=e.slice(0,-1),e}var UW,QW=O(()=>{mt();Vt();UW=Dq});function Mq(t){if(!m(t))throw new Y("queryString is required.");let e={};if(t==="")return e;let i=t.replace(/\+/g,"%20").split(/[&;]/);for(let n=0,s=i.length;n<s;++n){let o=i[n].split("="),r=decodeURIComponent(o[0]),a=o[1];m(a)?a=decodeURIComponent(a):a="";let h=e[r];typeof h=="string"?e[r]=[h,a]:Array.isArray(h)?h.push(a):e[r]=a}return e}var kW,LW=O(()=>{mt();Vt();kW=Mq});var Uq,Un,pZ=O(()=>{Uq={UNISSUED:0,ISSUED:1,ACTIVE:2,RECEIVED:3,CANCELLED:4,FAILED:5},Un=Object.freeze(Uq)});var Qq,yW,wW=O(()=>{Qq={TERRAIN:0,IMAGERY:1,TILES3D:2,OTHER:3},yW=Object.freeze(Qq)});function uZ(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.throttleByServer,!1),i=Z(t.throttle,!1);this.url=t.url,this.requestFunction=t.requestFunction,this.cancelFunction=t.cancelFunction,this.priorityFunction=t.priorityFunction,this.priority=Z(t.priority,0),this.throttle=i,this.throttleByServer=e,this.type=Z(t.type,yW.OTHER),this.serverKey=t.serverKey,this.state=Un.UNISSUED,this.deferred=void 0,this.cancelled=!1}var xW,PW=O(()=>{bt();mt();pZ();wW();uZ.prototype.cancel=function(){this.cancelled=!0};uZ.prototype.clone=function(t){return m(t)?(t.url=this.url,t.requestFunction=this.requestFunction,t.cancelFunction=this.cancelFunction,t.priorityFunction=this.priorityFunction,t.priority=this.priority,t.throttle=this.throttle,t.throttleByServer=this.throttleByServer,t.type=this.type,t.serverKey=this.serverKey,t.state=Un.UNISSUED,t.deferred=void 0,t.cancelled=!1,t):new uZ(this)};xW=uZ});function kq(t){let e={};if(!t)return e;let i=t.split(`\r
`);for(let n=0;n<i.length;++n){let s=i[n],o=s.indexOf(": ");if(o>0){let r=s.substring(0,o),a=s.substring(o+2);e[r]=a}}return e}var JW,jW=O(()=>{JW=kq});function HW(t,e,i){this.statusCode=t,this.response=e,this.responseHeaders=i,typeof this.responseHeaders=="string"&&(this.responseHeaders=JW(this.responseHeaders))}var hE,vW=O(()=>{mt();jW();HW.prototype.toString=function(){let t="Request has failed.";return m(this.statusCode)&&(t+=` Status Code: ${this.statusCode}`),t};hE=HW});function _l(t){p.typeOf.object("options",t),p.defined("options.comparator",t.comparator),this._comparator=t.comparator,this._array=[],this._length=0,this._maximumLength=void 0}function p0(t,e,i){let n=t[e];t[e]=t[i],t[i]=n}var zW,KW=O(()=>{ae();bt();mt();Object.defineProperties(_l.prototype,{length:{get:function(){return this._length}},internalArray:{get:function(){return this._array}},maximumLength:{get:function(){return this._maximumLength},set:function(t){p.typeOf.number.greaterThanOrEquals("maximumLength",t,0);let e=this._length;if(t<e){let i=this._array;for(let n=t;n<e;++n)i[n]=void 0;this._length=t,i.length=t}this._maximumLength=t}},comparator:{get:function(){return this._comparator}}});_l.prototype.reserve=function(t){t=Z(t,this._length),this._array.length=t};_l.prototype.heapify=function(t){t=Z(t,0);let e=this._length,i=this._comparator,n=this._array,s=-1,o=!0;for(;o;){let r=2*(t+1),a=r-1;a<e&&i(n[a],n[t])<0?s=a:s=t,r<e&&i(n[r],n[s])<0&&(s=r),s!==t?(p0(n,s,t),t=s):o=!1}};_l.prototype.resort=function(){let t=this._length;for(let e=Math.ceil(t/2);e>=0;--e)this.heapify(e)};_l.prototype.insert=function(t){p.defined("element",t);let e=this._array,i=this._comparator,n=this._maximumLength,s=this._length++;for(s<e.length?e[s]=t:e.push(t);s!==0;){let r=Math.floor((s-1)/2);if(i(e[s],e[r])<0)p0(e,s,r),s=r;else break}let o;return m(n)&&this._length>n&&(o=e[n],this._length=n),o};_l.prototype.pop=function(t){if(t=Z(t,0),this._length===0)return;p.typeOf.number.lessThan("index",t,this._length);let e=this._array,i=e[t];return p0(e,t,--this._length),this.heapify(t),e[this._length]=void 0,i};zW=_l});function Lq(t,e){return t.priority-e.priority}function Gn(){}function XW(t){m(t.priorityFunction)&&(t.priority=t.priorityFunction())}function qW(t){return t.state===Un.UNISSUED&&(t.state=Un.ISSUED,t.deferred=El()),t.deferred.promise}function wq(t){return function(e){if(t.state===Un.CANCELLED)return;let i=t.deferred;--Pi.numberOfActiveRequests,--XA[t.serverKey],gZ.raiseEvent(),t.state=Un.RECEIVED,t.deferred=void 0,i.resolve(e)}}function xq(t){return function(e){t.state!==Un.CANCELLED&&(++Pi.numberOfFailedRequests,--Pi.numberOfActiveRequests,--XA[t.serverKey],gZ.raiseEvent(e),t.state=Un.FAILED,t.deferred.reject(e))}}function $W(t){let e=qW(t);return t.state=Un.ACTIVE,AA.push(t),++Pi.numberOfActiveRequests,++Pi.numberOfActiveRequestsEver,++XA[t.serverKey],t.requestFunction().then(wq(t)).catch(xq(t)),e}function Rl(t){let e=t.state===Un.ACTIVE;if(t.state=Un.CANCELLED,++Pi.numberOfCancelledRequests,m(t.deferred)){let i=t.deferred;t.deferred=void 0,i.reject()}e&&(--Pi.numberOfActiveRequests,--XA[t.serverKey],++Pi.numberOfCancelledActiveRequests),m(t.cancelFunction)&&t.cancelFunction()}function Pq(){Gn.debugShowStatistics&&(Pi.numberOfActiveRequests===0&&Pi.lastNumberOfActiveRequests>0&&(Pi.numberOfAttemptedRequests>0&&(console.log(`Number of attempted requests: ${Pi.numberOfAttemptedRequests}`),Pi.numberOfAttemptedRequests=0),Pi.numberOfCancelledRequests>0&&(console.log(`Number of cancelled requests: ${Pi.numberOfCancelledRequests}`),Pi.numberOfCancelledRequests=0),Pi.numberOfCancelledActiveRequests>0&&(console.log(`Number of cancelled active requests: ${Pi.numberOfCancelledActiveRequests}`),Pi.numberOfCancelledActiveRequests=0),Pi.numberOfFailedRequests>0&&(console.log(`Number of failed requests: ${Pi.numberOfFailedRequests}`),Pi.numberOfFailedRequests=0)),Pi.lastNumberOfActiveRequests=Pi.numberOfActiveRequests)}var CZ,Pi,um,mo,AA,XA,yq,gZ,TZ,t2=O(()=>{CZ=co(oc(),1);ae();bt();m0();mt();xi();KW();R0();I0();pZ();Pi={numberOfAttemptedRequests:0,numberOfActiveRequests:0,numberOfCancelledRequests:0,numberOfCancelledActiveRequests:0,numberOfFailedRequests:0,numberOfActiveRequestsEver:0,lastNumberOfActiveRequests:0},um=20,mo=new zW({comparator:Lq});mo.maximumLength=um;mo.reserve(um);AA=[],XA={},yq=typeof document<"u"?new CZ.default(document.location.href):new CZ.default,gZ=new We;Gn.maximumRequests=50;Gn.maximumRequestsPerServer=18;Gn.requestsByServer={};Gn.throttleRequests=!0;Gn.debugShowStatistics=!1;Gn.requestCompletedEvent=gZ;Object.defineProperties(Gn,{statistics:{get:function(){return Pi}},priorityHeapLength:{get:function(){return um},set:function(t){if(t<um)for(;mo.length>t;){let e=mo.pop();Rl(e)}um=t,mo.maximumLength=t,mo.reserve(t)}}});Gn.serverHasOpenSlots=function(t,e){e=Z(e,1);let i=Z(Gn.requestsByServer[t],Gn.maximumRequestsPerServer);return XA[t]+e<=i};Gn.heapHasOpenSlots=function(t){return mo.length+t<=um};Gn.update=function(){let t,e,i=0,n=AA.length;for(t=0;t<n;++t){if(e=AA[t],e.cancelled&&Rl(e),e.state!==Un.ACTIVE){++i;continue}i>0&&(AA[t-i]=e)}AA.length-=i;let s=mo.internalArray,o=mo.length;for(t=0;t<o;++t)XW(s[t]);mo.resort();let r=Math.max(Gn.maximumRequests-AA.length,0),a=0;for(;a<r&&mo.length>0;){if(e=mo.pop(),e.cancelled){Rl(e);continue}if(e.throttleByServer&&!Gn.serverHasOpenSlots(e.serverKey)){Rl(e);continue}$W(e),++a}Pq()};Gn.getServerKey=function(t){p.typeOf.string("url",t);let e=new CZ.default(t);e.scheme()===""&&(e=e.absoluteTo(yq),e.normalize());let i=e.authority();/:/.test(i)||(i=`${i}:${e.scheme()==="https"?"443":"80"}`);let n=XA[i];return m(n)||(XA[i]=0),i};Gn.request=function(t){if(p.typeOf.object("request",t),p.typeOf.string("request.url",t.url),p.typeOf.func("request.requestFunction",t.requestFunction),IZ(t.url)||RZ(t.url))return gZ.raiseEvent(),t.state=Un.RECEIVED,t.requestFunction();if(++Pi.numberOfAttemptedRequests,m(t.serverKey)||(t.serverKey=Gn.getServerKey(t.url)),Gn.throttleRequests&&t.throttleByServer&&!Gn.serverHasOpenSlots(t.serverKey))return;if(!Gn.throttleRequests||!t.throttle)return $W(t);if(AA.length>=Gn.maximumRequests)return;XW(t);let e=mo.insert(t);if(m(e)){if(e===t)return;Rl(e)}return qW(t)};Gn.clearForSpecs=function(){for(;mo.length>0;){let e=mo.pop();Rl(e)}let t=AA.length;for(let e=0;e<t;++e)Rl(AA[e]);AA.length=0,XA={},Pi.numberOfAttemptedRequests=0,Pi.numberOfActiveRequests=0,Pi.numberOfCancelledRequests=0,Pi.numberOfCancelledActiveRequests=0,Pi.numberOfFailedRequests=0,Pi.numberOfActiveRequestsEver=0,Pi.lastNumberOfActiveRequests=0};Gn.numberOfActiveRequestsByServer=function(t){return XA[t]};Gn.requestHeap=mo;TZ=Gn});function cE(t){this.name="RuntimeError",this.message=t;let e;try{throw new Error}catch(i){e=i.stack}this.stack=e}var ke,Ps=O(()=>{mt();m(Object.create)&&(cE.prototype=Object.create(Error.prototype),cE.prototype.constructor=cE);cE.prototype.toString=function(){let t=`${this.name}: ${this.message}`;return m(this.stack)&&(t+=`
${this.stack.toString()}`),t};ke=cE});function Jq(t){let e=new e2.default(t);e.normalize();let i=e.authority();if(i.length!==0){if(e.authority(i),i.indexOf("@")!==-1&&(i=i.split("@")[1]),i.indexOf(":")===-1){let n=e.scheme();if(n.length===0&&(n=window.location.protocol,n=n.substring(0,n.length-1)),n==="http")i+=":80";else if(n==="https")i+=":443";else return}return i}}var e2,lE,Cm,u0,i2=O(()=>{e2=co(oc(),1);mt();Vt();lE={},Cm={};lE.add=function(t,e){if(!m(t))throw new Y("host is required.");if(!m(e)||e<=0)throw new Y("port is required to be greater than 0.");let i=`${t.toLowerCase()}:${e}`;m(Cm[i])||(Cm[i]=!0)};lE.remove=function(t,e){if(!m(t))throw new Y("host is required.");if(!m(e)||e<=0)throw new Y("port is required to be greater than 0.");let i=`${t.toLowerCase()}:${e}`;m(Cm[i])&&delete Cm[i]};lE.contains=function(t){if(!m(t))throw new Y("url is required.");let e=Jq(t);return!!(m(e)&&m(Cm[e]))};lE.clear=function(){Cm={}};u0=lE});function le(t){t=Z(t,Z.EMPTY_OBJECT),typeof t=="string"&&(t={url:t}),p.typeOf.string("options.url",t.url),this._url=void 0,this._templateValues=hA(t.templateValues,{}),this._queryParameters=hA(t.queryParameters,{}),this.headers=hA(t.headers,{}),this.request=Z(t.request,new xW),this.proxy=t.proxy,this.retryCallback=t.retryCallback,this.retryAttempts=Z(t.retryAttempts,0),this._retryCount=0,Z(t.parseUrl,!0)?this.parseUrl(t.url,!0,!0):this._url=t.url,this._credits=t.credits}function hA(t,e){return m(t)?qs(t):e}function jq(t){return t.length===0?{}:t.indexOf("=")===-1?{[t]:void 0}:kW(t)}function bZ(t,e,i){if(!i)return es(t,e);let n=qs(t,!0);for(let s in e)if(e.hasOwnProperty(s)){let o=n[s],r=e[s];m(o)?(Array.isArray(o)||(o=n[s]=[o]),n[s]=o.concat(r)):n[s]=Array.isArray(r)?r.slice():r}return n}function Hq(t){let e=Object.keys(t);return e.length===0?"":e.length===1&&!m(t[e[0]])?`?${e[0]}`:`?${UW(t)}`}function C0(t){let e=t.resource,i=t.flipY,n=t.skipColorSpaceConversion,s=t.preferImageBitmap,o=e.request;o.url=e.url,o.requestFunction=function(){let a=!1;!e.isDataUri&&!e.isBlobUri&&(a=e.isCrossOriginUrl);let h=El();return le._Implementations.createImage(o,a,h,i,n,s),h.promise};let r=TZ.request(o);if(m(r))return r.catch(function(a){return o.state!==Un.FAILED?Promise.reject(a):e.retryOnError(a).then(function(h){return h?(o.state=Un.UNISSUED,o.deferred=void 0,C0({resource:e,flipY:i,skipColorSpaceConversion:n,preferImageBitmap:s})):Promise.reject(a)})})}function r2(t,e,i){let n={};n[e]=i,t.setQueryParameters(n);let s=t.request,o=t.url;s.url=o,s.requestFunction=function(){let a=El();return window[i]=function(h){a.resolve(h);try{delete window[i]}catch{window[i]=void 0}},le._Implementations.loadAndExecuteScript(o,i,a),a.promise};let r=TZ.request(s);if(m(r))return r.catch(function(a){return s.state!==Un.FAILED?Promise.reject(a):t.retryOnError(a).then(function(h){return h?(s.state=Un.UNISSUED,s.deferred=void 0,r2(t,e,i)):Promise.reject(a)})})}function g0(t){if(t.state===Un.ISSUED||t.state===Un.ACTIVE)throw new ke("The Resource is already being fetched.");t.state=Un.UNISSUED,t.deferred=void 0}function NZ(t,e){let i=decodeURIComponent(e);return t?atob(i):i}function n2(t,e){let i=NZ(t,e),n=new ArrayBuffer(i.length),s=new Uint8Array(n);for(let o=0;o<i.length;o++)s[o]=i.charCodeAt(o);return n}function zq(t,e){e=Z(e,"");let i=t[1],n=!!t[2],s=t[3],o,r;switch(e){case"":case"text":return NZ(n,s);case"arraybuffer":return n2(n,s);case"blob":return o=n2(n,s),new Blob([o],{type:i});case"document":return r=new DOMParser,r.parseFromString(NZ(n,s),i);case"json":return JSON.parse(NZ(n,s));default:throw new Y(`Unhandled responseType: ${e}`)}}function Kq(t,e,i,n,s,o,r){fetch(t,{method:i,headers:s}).then(async a=>{if(!a.ok){let h={};a.headers.forEach((A,d)=>{h[d]=A}),o.reject(new hE(a.status,a,h));return}switch(e){case"text":o.resolve(a.text());break;case"json":o.resolve(a.json());break;default:o.resolve(new Uint8Array(await a.arrayBuffer()).buffer);break}}).catch(()=>{o.reject(new hE)})}var s2,o2,gm,vq,Xq,tn,Ia=O(()=>{s2=co(oc(),1);gW();ae();aE();KA();bt();m0();mt();Vt();E0();SW();GW();WW();R0();Z0();I0();MW();_e();QW();LW();PW();vW();t2();pZ();Ps();i2();o2=function(){try{let t=new XMLHttpRequest;return t.open("GET","#",!0),t.responseType="blob",t.responseType==="blob"}catch{return!1}}();le.createIfNeeded=function(t){return t instanceof le?t.getDerivedResource({request:t.request}):typeof t!="string"?t:new le({url:t})};le.supportsImageBitmapOptions=function(){return m(gm)?gm:typeof createImageBitmap!="function"?(gm=Promise.resolve(!1),gm):(gm=le.fetchBlob({url:"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAIAAACQd1PeAAAABGdBTUEAAE4g3rEiDgAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAADElEQVQI12Ng6GAAAAEUAIngE3ZiAAAAAElFTkSuQmCC"}).then(function(e){let i={imageOrientation:"flipY",premultiplyAlpha:"none",colorSpaceConversion:"none"};return Promise.all([createImageBitmap(e,i),createImageBitmap(e)])}).then(function(e){let i=_0(e[0]),n=_0(e[1]);return i[1]!==n[1]}).catch(function(){return!1}),gm)};Object.defineProperties(le,{isBlobSupported:{get:function(){return o2}}});Object.defineProperties(le.prototype,{queryParameters:{get:function(){return this._queryParameters}},templateValues:{get:function(){return this._templateValues}},url:{get:function(){return this.getUrlComponent(!0,!0)},set:function(t){this.parseUrl(t,!1,!1)}},extension:{get:function(){return VW(this._url)}},isDataUri:{get:function(){return IZ(this._url)}},isBlobUri:{get:function(){return RZ(this._url)}},isCrossOriginUrl:{get:function(){return ZZ(this._url)}},hasHeaders:{get:function(){return Object.keys(this.headers).length>0}},credits:{get:function(){return this._credits}}});le.prototype.toString=function(){return this.getUrlComponent(!0,!0)};le.prototype.parseUrl=function(t,e,i,n){let s=new s2.default(t),o=jq(s.query());this._queryParameters=e?bZ(o,this.queryParameters,i):o,s.search(""),s.fragment(""),m(n)&&s.scheme()===""&&(s=s.absoluteTo(AE(n))),this._url=s.toString()};le.prototype.getUrlComponent=function(t,e){if(this.isDataUri)return this._url;let i=this._url;t&&(i=`${i}${Hq(this.queryParameters)}`),i=i.replace(/%7B/g,"{").replace(/%7D/g,"}");let n=this._templateValues;return Object.keys(n).length>0&&(i=i.replace(/{(.*?)}/g,function(s,o){let r=n[o];return m(r)?encodeURIComponent(r):s})),e&&m(this.proxy)&&(i=this.proxy.getURL(i)),i};le.prototype.setQueryParameters=function(t,e){e?this._queryParameters=bZ(this._queryParameters,t,!1):this._queryParameters=bZ(t,this._queryParameters,!1)};le.prototype.appendQueryParameters=function(t){this._queryParameters=bZ(t,this._queryParameters,!0)};le.prototype.setTemplateValues=function(t,e){e?this._templateValues=es(this._templateValues,t):this._templateValues=es(t,this._templateValues)};le.prototype.getDerivedResource=function(t){let e=this.clone();if(e._retryCount=0,m(t.url)){let i=Z(t.preserveQueryParameters,!1);e.parseUrl(t.url,!0,i,this._url)}return m(t.queryParameters)&&(e._queryParameters=es(t.queryParameters,e.queryParameters)),m(t.templateValues)&&(e._templateValues=es(t.templateValues,e.templateValues)),m(t.headers)&&(e.headers=es(t.headers,e.headers)),m(t.proxy)&&(e.proxy=t.proxy),m(t.request)&&(e.request=t.request),m(t.retryCallback)&&(e.retryCallback=t.retryCallback),m(t.retryAttempts)&&(e.retryAttempts=t.retryAttempts),e};le.prototype.retryOnError=function(t){let e=this.retryCallback;if(typeof e!="function"||this._retryCount>=this.retryAttempts)return Promise.resolve(!1);let i=this;return Promise.resolve(e(this,t)).then(function(n){return++i._retryCount,n})};le.prototype.clone=function(t){return m(t)?(t._url=this._url,t._queryParameters=qs(this._queryParameters),t._templateValues=qs(this._templateValues),t.headers=qs(this.headers),t.proxy=this.proxy,t.retryCallback=this.retryCallback,t.retryAttempts=this.retryAttempts,t._retryCount=0,t.request=this.request.clone(),t):new le({url:this._url,queryParameters:this.queryParameters,templateValues:this.templateValues,headers:this.headers,proxy:this.proxy,retryCallback:this.retryCallback,retryAttempts:this.retryAttempts,request:this.request.clone(),parseUrl:!1,credits:m(this.credits)?this.credits.slice():void 0})};le.prototype.getBaseUri=function(t){return YW(this.getUrlComponent(t),t)};le.prototype.appendForwardSlash=function(){this._url=CW(this._url)};le.prototype.fetchArrayBuffer=function(){return this.fetch({responseType:"arraybuffer"})};le.fetchArrayBuffer=function(t){return new le(t).fetchArrayBuffer()};le.prototype.fetchBlob=function(){return this.fetch({responseType:"blob"})};le.fetchBlob=function(t){return new le(t).fetchBlob()};le.prototype.fetchImage=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.preferImageBitmap,!1),i=Z(t.preferBlob,!1),n=Z(t.flipY,!1),s=Z(t.skipColorSpaceConversion,!1);if(g0(this.request),!o2||this.isDataUri||this.isBlobUri||!this.hasHeaders&&!i)return C0({resource:this,flipY:n,skipColorSpaceConversion:s,preferImageBitmap:e});let o=this.fetchBlob();if(!m(o))return;let r,a,h,A;return le.supportsImageBitmapOptions().then(function(d){return r=d,a=r&&e,o}).then(function(d){if(!m(d))return;if(A=d,a)return le.createImageBitmapFromBlob(d,{flipY:n,premultiplyAlpha:!1,skipColorSpaceConversion:s});let f=window.URL.createObjectURL(d);return h=new le({url:f}),C0({resource:h,flipY:n,skipColorSpaceConversion:s,preferImageBitmap:!1})}).then(function(d){if(m(d))return d.blob=A,a||window.URL.revokeObjectURL(h.url),d}).catch(function(d){return m(h)&&window.URL.revokeObjectURL(h.url),d.blob=A,Promise.reject(d)})};le.fetchImage=function(t){return new le(t).fetchImage({flipY:t.flipY,skipColorSpaceConversion:t.skipColorSpaceConversion,preferBlob:t.preferBlob,preferImageBitmap:t.preferImageBitmap})};le.prototype.fetchText=function(){return this.fetch({responseType:"text"})};le.fetchText=function(t){return new le(t).fetchText()};le.prototype.fetchJson=function(){let t=this.fetch({responseType:"text",headers:{Accept:"application/json,*/*;q=0.01"}});if(m(t))return t.then(function(e){if(m(e))return JSON.parse(e)})};le.fetchJson=function(t){return new le(t).fetchJson()};le.prototype.fetchXML=function(){return this.fetch({responseType:"document",overrideMimeType:"text/xml"})};le.fetchXML=function(t){return new le(t).fetchXML()};le.prototype.fetchJsonp=function(t){t=Z(t,"callback"),g0(this.request);let e;do e=`loadJsonp${L.nextRandomNumber().toString().substring(2,8)}`;while(m(window[e]));return r2(this,t,e)};le.fetchJsonp=function(t){return new le(t).fetchJsonp(t.callbackParameterName)};le.prototype._makeRequest=function(t){let e=this;g0(e.request);let i=e.request,n=e.url;i.url=n,i.requestFunction=function(){let o=t.responseType,r=es(t.headers,e.headers),a=t.overrideMimeType,h=t.method,A=t.data,d=El(),f=le._Implementations.loadWithXhr(n,o,h,A,r,d,a);return m(f)&&m(f.abort)&&(i.cancelFunction=function(){f.abort()}),d.promise};let s=TZ.request(i);if(m(s))return s.then(function(o){return i.cancelFunction=void 0,o}).catch(function(o){return i.cancelFunction=void 0,i.state!==Un.FAILED?Promise.reject(o):e.retryOnError(o).then(function(r){return r?(i.state=Un.UNISSUED,i.deferred=void 0,e.fetch(t)):Promise.reject(o)})})};vq=/^data:(.*?)(;base64)?,(.*)$/;le.prototype.fetch=function(t){return t=hA(t,{}),t.method="GET",this._makeRequest(t)};le.fetch=function(t){return new le(t).fetch({responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le.prototype.delete=function(t){return t=hA(t,{}),t.method="DELETE",this._makeRequest(t)};le.delete=function(t){return new le(t).delete({responseType:t.responseType,overrideMimeType:t.overrideMimeType,data:t.data})};le.prototype.head=function(t){return t=hA(t,{}),t.method="HEAD",this._makeRequest(t)};le.head=function(t){return new le(t).head({responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le.prototype.options=function(t){return t=hA(t,{}),t.method="OPTIONS",this._makeRequest(t)};le.options=function(t){return new le(t).options({responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le.prototype.post=function(t,e){return p.defined("data",t),e=hA(e,{}),e.method="POST",e.data=t,this._makeRequest(e)};le.post=function(t){return new le(t).post(t.data,{responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le.prototype.put=function(t,e){return p.defined("data",t),e=hA(e,{}),e.method="PUT",e.data=t,this._makeRequest(e)};le.put=function(t){return new le(t).put(t.data,{responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le.prototype.patch=function(t,e){return p.defined("data",t),e=hA(e,{}),e.method="PATCH",e.data=t,this._makeRequest(e)};le.patch=function(t){return new le(t).patch(t.data,{responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le._Implementations={};le._Implementations.loadImageElement=function(t,e,i){let n=new Image;n.onload=function(){n.naturalWidth===0&&n.naturalHeight===0&&n.width===0&&n.height===0&&(n.width=300,n.height=150),i.resolve(n)},n.onerror=function(s){i.reject(s)},e&&(u0.contains(t)?n.crossOrigin="use-credentials":n.crossOrigin=""),n.src=t};le._Implementations.createImage=function(t,e,i,n,s,o){let r=t.url;le.supportsImageBitmapOptions().then(function(a){if(!(a&&o)){le._Implementations.loadImageElement(r,e,i);return}let h="blob",A="GET",d=El(),f=le._Implementations.loadWithXhr(r,h,A,void 0,void 0,d,void 0,void 0,void 0);return m(f)&&m(f.abort)&&(t.cancelFunction=function(){f.abort()}),d.promise.then(function(E){if(!m(E)){i.reject(new ke(`Successfully retrieved ${r} but it contained no content.`));return}return le.createImageBitmapFromBlob(E,{flipY:n,premultiplyAlpha:!1,skipColorSpaceConversion:s})}).then(function(E){i.resolve(E)})}).catch(function(a){i.reject(a)})};le.createImageBitmapFromBlob=function(t,e){return p.defined("options",e),p.typeOf.bool("options.flipY",e.flipY),p.typeOf.bool("options.premultiplyAlpha",e.premultiplyAlpha),p.typeOf.bool("options.skipColorSpaceConversion",e.skipColorSpaceConversion),createImageBitmap(t,{imageOrientation:e.flipY?"flipY":"none",premultiplyAlpha:e.premultiplyAlpha?"premultiply":"none",colorSpaceConversion:e.skipColorSpaceConversion?"none":"default"})};Xq=typeof XMLHttpRequest>"u";le._Implementations.loadWithXhr=function(t,e,i,n,s,o,r){let a=vq.exec(t);if(a!==null){o.resolve(zq(a,e));return}if(Xq){Kq(t,e,i,n,s,o,r);return}let h=new XMLHttpRequest;if(u0.contains(t)&&(h.withCredentials=!0),h.open(i,t,!0),m(r)&&m(h.overrideMimeType)&&h.overrideMimeType(r),m(s))for(let d in s)s.hasOwnProperty(d)&&h.setRequestHeader(d,s[d]);m(e)&&(h.responseType=e);let A=!1;return typeof t=="string"&&(A=t.indexOf("file://")===0||typeof window<"u"&&window.location.origin==="file://"),h.onload=function(){if((h.status<200||h.status>=300)&&!(A&&h.status===0)){o.reject(new hE(h.status,h.response,h.getAllResponseHeaders()));return}let d=h.response,f=h.responseType;if(i==="HEAD"||i==="OPTIONS"){let _=h.getAllResponseHeaders().trim().split(/[\r\n]+/),R={};_.forEach(function(I){let C=I.split(": "),N=C.shift();R[N]=C.join(": ")}),o.resolve(R);return}if(h.status===204)o.resolve(void 0);else if(m(d)&&(!m(e)||f===e))o.resolve(d);else if(e==="json"&&typeof d=="string")try{o.resolve(JSON.parse(d))}catch(E){o.reject(E)}else(f===""||f==="document")&&m(h.responseXML)&&h.responseXML.hasChildNodes()?o.resolve(h.responseXML):(f===""||f==="text")&&m(h.responseText)?o.resolve(h.responseText):o.reject(new ke("Invalid XMLHttpRequest response type."))},h.onerror=function(d){o.reject(new hE)},h.send(n),h};le._Implementations.loadAndExecuteScript=function(t,e,i){return DW(t,e).catch(function(n){i.reject(n)})};le._DefaultImplementations={};le._DefaultImplementations.createImage=le._Implementations.createImage;le._DefaultImplementations.loadWithXhr=le._Implementations.loadWithXhr;le._DefaultImplementations.loadAndExecuteScript=le._Implementations.loadAndExecuteScript;le.DEFAULT=Object.freeze(new le({url:typeof document>"u"?"":document.location.href.split("?")[0]}));tn=le});function mE(t){t=Z(t,Z.EMPTY_OBJECT),this._dates=void 0,this._samples=void 0,this._dateColumn=-1,this._xPoleWanderRadiansColumn=-1,this._yPoleWanderRadiansColumn=-1,this._ut1MinusUtcSecondsColumn=-1,this._xCelestialPoleOffsetRadiansColumn=-1,this._yCelestialPoleOffsetRadiansColumn=-1,this._taiMinusUtcSecondsColumn=-1,this._columnCount=0,this._lastIndex=-1,this._addNewLeapSeconds=Z(t.addNewLeapSeconds,!0),m(t.data)?a2(this,t.data):a2(this,{columnNames:["dateIso8601","modifiedJulianDateUtc","xPoleWanderRadians","yPoleWanderRadians","ut1MinusUtcSeconds","lengthOfDayCorrectionSeconds","xCelestialPoleOffsetRadians","yCelestialPoleOffsetRadians","taiMinusUtcSeconds"],samples:[]})}function qq(t,e){return Ze.compare(t.julianDate,e)}function a2(t,e){if(!m(e.columnNames))throw new ke("Error in loaded EOP data: The columnNames property is required.");if(!m(e.samples))throw new ke("Error in loaded EOP data: The samples property is required.");let i=e.columnNames.indexOf("modifiedJulianDateUtc"),n=e.columnNames.indexOf("xPoleWanderRadians"),s=e.columnNames.indexOf("yPoleWanderRadians"),o=e.columnNames.indexOf("ut1MinusUtcSeconds"),r=e.columnNames.indexOf("xCelestialPoleOffsetRadians"),a=e.columnNames.indexOf("yCelestialPoleOffsetRadians"),h=e.columnNames.indexOf("taiMinusUtcSeconds");if(i<0||n<0||s<0||o<0||r<0||a<0||h<0)throw new ke("Error in loaded EOP data: The columnNames property must include modifiedJulianDateUtc, xPoleWanderRadians, yPoleWanderRadians, ut1MinusUtcSeconds, xCelestialPoleOffsetRadians, yCelestialPoleOffsetRadians, and taiMinusUtcSeconds columns");let A=t._samples=e.samples,d=t._dates=[];t._dateColumn=i,t._xPoleWanderRadiansColumn=n,t._yPoleWanderRadiansColumn=s,t._ut1MinusUtcSecondsColumn=o,t._xCelestialPoleOffsetRadiansColumn=r,t._yCelestialPoleOffsetRadiansColumn=a,t._taiMinusUtcSecondsColumn=h,t._columnCount=e.columnNames.length,t._lastIndex=void 0;let f,E=t._addNewLeapSeconds;for(let _=0,R=A.length;_<R;_+=t._columnCount){let I=A[_+i],C=A[_+h],N=I+bn.MODIFIED_JULIAN_DATE_DIFFERENCE,T=new Ze(N,C,Ei.TAI);if(d.push(T),E){if(C!==f&&m(f)){let F=Ze.leapSeconds,b=Bo(F,T,qq);if(b<0){let G=new zi(T,C);F.splice(~b,0,G)}}f=C}}}function A2(t,e,i,n,s){let o=i*n;s.xPoleWander=e[o+t._xPoleWanderRadiansColumn],s.yPoleWander=e[o+t._yPoleWanderRadiansColumn],s.xPoleOffset=e[o+t._xCelestialPoleOffsetRadiansColumn],s.yPoleOffset=e[o+t._yCelestialPoleOffsetRadiansColumn],s.ut1MinusUtc=e[o+t._ut1MinusUtcSecondsColumn]}function dE(t,e,i){return e+t*(i-e)}function h2(t,e,i,n,s,o,r){let a=t._columnCount;if(o>e.length-1)return r.xPoleWander=0,r.yPoleWander=0,r.xPoleOffset=0,r.yPoleOffset=0,r.ut1MinusUtc=0,r;let h=e[s],A=e[o];if(h.equals(A)||n.equals(h))return A2(t,i,s,a,r),r;if(n.equals(A))return A2(t,i,o,a,r),r;let d=Ze.secondsDifference(n,h)/Ze.secondsDifference(A,h),f=s*a,E=o*a,_=i[f+t._ut1MinusUtcSecondsColumn],R=i[E+t._ut1MinusUtcSecondsColumn],I=R-_;if(I>.5||I<-.5){let C=i[f+t._taiMinusUtcSecondsColumn],N=i[E+t._taiMinusUtcSecondsColumn];C!==N&&(A.equals(n)?_=R:R-=N-C)}return r.xPoleWander=dE(d,i[f+t._xPoleWanderRadiansColumn],i[E+t._xPoleWanderRadiansColumn]),r.yPoleWander=dE(d,i[f+t._yPoleWanderRadiansColumn],i[E+t._yPoleWanderRadiansColumn]),r.xPoleOffset=dE(d,i[f+t._xCelestialPoleOffsetRadiansColumn],i[E+t._xCelestialPoleOffsetRadiansColumn]),r.yPoleOffset=dE(d,i[f+t._yCelestialPoleOffsetRadiansColumn],i[E+t._yCelestialPoleOffsetRadiansColumn]),r.ut1MinusUtc=dE(d,_,R),r}var c2,l2=O(()=>{sE();ae();bt();mt();a0();Vr();h0();Ia();Ps();AZ();hZ();mE.fromUrl=async function(t,e){p.defined("url",t),e=Z(e,Z.EMPTY_OBJECT);let i=tn.createIfNeeded(t),n;try{n=await i.fetchJson()}catch{throw new ke(`An error occurred while retrieving the EOP data from the URL ${i.url}.`)}return new mE({addNewLeapSeconds:e.addNewLeapSeconds,data:n})};mE.NONE=Object.freeze({compute:function(t,e){return m(e)?(e.xPoleWander=0,e.yPoleWander=0,e.xPoleOffset=0,e.yPoleOffset=0,e.ut1MinusUtc=0):e=new oE(0,0,0,0,0),e}});mE.prototype.compute=function(t,e){if(!m(this._samples))return;if(m(e)||(e=new oE(0,0,0,0,0)),this._samples.length===0)return e.xPoleWander=0,e.yPoleWander=0,e.xPoleOffset=0,e.yPoleOffset=0,e.ut1MinusUtc=0,e;let i=this._dates,n=this._lastIndex,s=0,o=0;if(m(n)){let a=i[n],h=i[n+1],A=Ze.lessThanOrEquals(a,t),d=!m(h),f=d||Ze.greaterThanOrEquals(h,t);if(A&&f)return s=n,!d&&h.equals(t)&&++s,o=s+1,h2(this,i,this._samples,t,s,o,e),e}let r=Bo(i,t,Ze.compare,this._dateColumn);return r>=0?(r<i.length-1&&i[r+1].equals(t)&&++r,s=r,o=r):(o=~r,s=o-1,s<0&&(s=0)),this._lastIndex=s,h2(this,i,this._samples,t,s,o,e),e};c2=mE});function xt(t,e,i,n,s,o,r,a,h){this[0]=Z(t,0),this[1]=Z(n,0),this[2]=Z(r,0),this[3]=Z(e,0),this[4]=Z(s,0),this[5]=Z(a,0),this[6]=Z(i,0),this[7]=Z(o,0),this[8]=Z(h,0)}function n9(t){let e=0;for(let i=0;i<9;++i){let n=t[i];e+=n*n}return Math.sqrt(e)}function s9(t){let e=0;for(let i=0;i<3;++i){let n=t[xt.getElementIndex(b0[i],N0[i])];e+=2*n*n}return Math.sqrt(e)}function o9(t,e){let i=L.EPSILON15,n=0,s=1;for(let A=0;A<3;++A){let d=Math.abs(t[xt.getElementIndex(b0[A],N0[A])]);d>n&&(s=A,n=d)}let o=1,r=0,a=N0[s],h=b0[s];if(Math.abs(t[xt.getElementIndex(h,a)])>i){let A=t[xt.getElementIndex(h,h)],d=t[xt.getElementIndex(a,a)],f=t[xt.getElementIndex(h,a)],E=(A-d)/2/f,_;E<0?_=-1/(-E+Math.sqrt(1+E*E)):_=1/(E+Math.sqrt(1+E*E)),o=1/Math.sqrt(1+_*_),r=_*o}return e=xt.clone(xt.IDENTITY,e),e[xt.getElementIndex(a,a)]=e[xt.getElementIndex(h,h)]=o,e[xt.getElementIndex(h,a)]=r,e[xt.getElementIndex(a,h)]=-r,e}var $q,t9,T0,d2,e9,i9,N0,b0,FZ,m2,r9,lt,dn=O(()=>{Ht();ae();bt();mt();Vt();_e();xt.packedLength=9;xt.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t[0],e[i++]=t[1],e[i++]=t[2],e[i++]=t[3],e[i++]=t[4],e[i++]=t[5],e[i++]=t[6],e[i++]=t[7],e[i++]=t[8],e};xt.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new xt),i[0]=t[e++],i[1]=t[e++],i[2]=t[e++],i[3]=t[e++],i[4]=t[e++],i[5]=t[e++],i[6]=t[e++],i[7]=t[e++],i[8]=t[e++],i};xt.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*9;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 9 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)xt.pack(t[s],e,s*9);return e};xt.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,9),t.length%9!==0)throw new Y("array length must be a multiple of 9.");let i=t.length;m(e)?e.length=i/9:e=new Array(i/9);for(let n=0;n<i;n+=9){let s=n/9;e[s]=xt.unpack(t,n,e[s])}return e};xt.clone=function(t,e){if(m(t))return m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e):new xt(t[0],t[3],t[6],t[1],t[4],t[7],t[2],t[5],t[8])};xt.fromArray=xt.unpack;xt.fromColumnMajorArray=function(t,e){return p.defined("values",t),xt.clone(t,e)};xt.fromRowMajorArray=function(t,e){return p.defined("values",t),m(e)?(e[0]=t[0],e[1]=t[3],e[2]=t[6],e[3]=t[1],e[4]=t[4],e[5]=t[7],e[6]=t[2],e[7]=t[5],e[8]=t[8],e):new xt(t[0],t[1],t[2],t[3],t[4],t[5],t[6],t[7],t[8])};xt.fromQuaternion=function(t,e){p.typeOf.object("quaternion",t);let i=t.x*t.x,n=t.x*t.y,s=t.x*t.z,o=t.x*t.w,r=t.y*t.y,a=t.y*t.z,h=t.y*t.w,A=t.z*t.z,d=t.z*t.w,f=t.w*t.w,E=i-r-A+f,_=2*(n-d),R=2*(s+h),I=2*(n+d),C=-i+r-A+f,N=2*(a-o),T=2*(s-h),F=2*(a+o),b=-i-r+A+f;return m(e)?(e[0]=E,e[1]=I,e[2]=T,e[3]=_,e[4]=C,e[5]=F,e[6]=R,e[7]=N,e[8]=b,e):new xt(E,_,R,I,C,N,T,F,b)};xt.fromHeadingPitchRoll=function(t,e){p.typeOf.object("headingPitchRoll",t);let i=Math.cos(-t.pitch),n=Math.cos(-t.heading),s=Math.cos(t.roll),o=Math.sin(-t.pitch),r=Math.sin(-t.heading),a=Math.sin(t.roll),h=i*n,A=-s*r+a*o*n,d=a*r+s*o*n,f=i*r,E=s*n+a*o*r,_=-a*n+s*o*r,R=-o,I=a*i,C=s*i;return m(e)?(e[0]=h,e[1]=f,e[2]=R,e[3]=A,e[4]=E,e[5]=I,e[6]=d,e[7]=_,e[8]=C,e):new xt(h,A,d,f,E,_,R,I,C)};xt.fromScale=function(t,e){return p.typeOf.object("scale",t),m(e)?(e[0]=t.x,e[1]=0,e[2]=0,e[3]=0,e[4]=t.y,e[5]=0,e[6]=0,e[7]=0,e[8]=t.z,e):new xt(t.x,0,0,0,t.y,0,0,0,t.z)};xt.fromUniformScale=function(t,e){return p.typeOf.number("scale",t),m(e)?(e[0]=t,e[1]=0,e[2]=0,e[3]=0,e[4]=t,e[5]=0,e[6]=0,e[7]=0,e[8]=t,e):new xt(t,0,0,0,t,0,0,0,t)};xt.fromCrossProduct=function(t,e){return p.typeOf.object("vector",t),m(e)?(e[0]=0,e[1]=t.z,e[2]=-t.y,e[3]=-t.z,e[4]=0,e[5]=t.x,e[6]=t.y,e[7]=-t.x,e[8]=0,e):new xt(0,-t.z,t.y,t.z,0,-t.x,-t.y,t.x,0)};xt.fromRotationX=function(t,e){p.typeOf.number("angle",t);let i=Math.cos(t),n=Math.sin(t);return m(e)?(e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=i,e[5]=n,e[6]=0,e[7]=-n,e[8]=i,e):new xt(1,0,0,0,i,-n,0,n,i)};xt.fromRotationY=function(t,e){p.typeOf.number("angle",t);let i=Math.cos(t),n=Math.sin(t);return m(e)?(e[0]=i,e[1]=0,e[2]=-n,e[3]=0,e[4]=1,e[5]=0,e[6]=n,e[7]=0,e[8]=i,e):new xt(i,0,n,0,1,0,-n,0,i)};xt.fromRotationZ=function(t,e){p.typeOf.number("angle",t);let i=Math.cos(t),n=Math.sin(t);return m(e)?(e[0]=i,e[1]=n,e[2]=0,e[3]=-n,e[4]=i,e[5]=0,e[6]=0,e[7]=0,e[8]=1,e):new xt(i,-n,0,n,i,0,0,0,1)};xt.toArray=function(t,e){return p.typeOf.object("matrix",t),m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e):[t[0],t[1],t[2],t[3],t[4],t[5],t[6],t[7],t[8]]};xt.getElementIndex=function(t,e){return p.typeOf.number.greaterThanOrEquals("row",e,0),p.typeOf.number.lessThanOrEquals("row",e,2),p.typeOf.number.greaterThanOrEquals("column",t,0),p.typeOf.number.lessThanOrEquals("column",t,2),t*3+e};xt.getColumn=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,2),p.typeOf.object("result",i);let n=e*3,s=t[n],o=t[n+1],r=t[n+2];return i.x=s,i.y=o,i.z=r,i};xt.setColumn=function(t,e,i,n){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,2),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=xt.clone(t,n);let s=e*3;return n[s]=i.x,n[s+1]=i.y,n[s+2]=i.z,n};xt.getRow=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,2),p.typeOf.object("result",i);let n=t[e],s=t[e+3],o=t[e+6];return i.x=n,i.y=s,i.z=o,i};xt.setRow=function(t,e,i,n){return p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,2),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=xt.clone(t,n),n[e]=i.x,n[e+3]=i.y,n[e+6]=i.z,n};$q=new l;xt.setScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i);let n=xt.getScale(t,$q),s=e.x/n.x,o=e.y/n.y,r=e.z/n.z;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*s,i[3]=t[3]*o,i[4]=t[4]*o,i[5]=t[5]*o,i[6]=t[6]*r,i[7]=t[7]*r,i[8]=t[8]*r,i};t9=new l;xt.setUniformScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i);let n=xt.getScale(t,t9),s=e/n.x,o=e/n.y,r=e/n.z;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*s,i[3]=t[3]*o,i[4]=t[4]*o,i[5]=t[5]*o,i[6]=t[6]*r,i[7]=t[7]*r,i[8]=t[8]*r,i};T0=new l;xt.getScale=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e.x=l.magnitude(l.fromElements(t[0],t[1],t[2],T0)),e.y=l.magnitude(l.fromElements(t[3],t[4],t[5],T0)),e.z=l.magnitude(l.fromElements(t[6],t[7],t[8],T0)),e};d2=new l;xt.getMaximumScale=function(t){return xt.getScale(t,d2),l.maximumComponent(d2)};e9=new l;xt.setRotation=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("result",i);let n=xt.getScale(t,e9);return i[0]=e[0]*n.x,i[1]=e[1]*n.x,i[2]=e[2]*n.x,i[3]=e[3]*n.y,i[4]=e[4]*n.y,i[5]=e[5]*n.y,i[6]=e[6]*n.z,i[7]=e[7]*n.z,i[8]=e[8]*n.z,i};i9=new l;xt.getRotation=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=xt.getScale(t,i9);return e[0]=t[0]/i.x,e[1]=t[1]/i.x,e[2]=t[2]/i.x,e[3]=t[3]/i.y,e[4]=t[4]/i.y,e[5]=t[5]/i.y,e[6]=t[6]/i.z,e[7]=t[7]/i.z,e[8]=t[8]/i.z,e};xt.multiply=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t[0]*e[0]+t[3]*e[1]+t[6]*e[2],s=t[1]*e[0]+t[4]*e[1]+t[7]*e[2],o=t[2]*e[0]+t[5]*e[1]+t[8]*e[2],r=t[0]*e[3]+t[3]*e[4]+t[6]*e[5],a=t[1]*e[3]+t[4]*e[4]+t[7]*e[5],h=t[2]*e[3]+t[5]*e[4]+t[8]*e[5],A=t[0]*e[6]+t[3]*e[7]+t[6]*e[8],d=t[1]*e[6]+t[4]*e[7]+t[7]*e[8],f=t[2]*e[6]+t[5]*e[7]+t[8]*e[8];return i[0]=n,i[1]=s,i[2]=o,i[3]=r,i[4]=a,i[5]=h,i[6]=A,i[7]=d,i[8]=f,i};xt.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]+e[0],i[1]=t[1]+e[1],i[2]=t[2]+e[2],i[3]=t[3]+e[3],i[4]=t[4]+e[4],i[5]=t[5]+e[5],i[6]=t[6]+e[6],i[7]=t[7]+e[7],i[8]=t[8]+e[8],i};xt.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]-e[0],i[1]=t[1]-e[1],i[2]=t[2]-e[2],i[3]=t[3]-e[3],i[4]=t[4]-e[4],i[5]=t[5]-e[5],i[6]=t[6]-e[6],i[7]=t[7]-e[7],i[8]=t[8]-e[8],i};xt.multiplyByVector=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("cartesian",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z,r=t[0]*n+t[3]*s+t[6]*o,a=t[1]*n+t[4]*s+t[7]*o,h=t[2]*n+t[5]*s+t[8]*o;return i.x=r,i.y=a,i.z=h,i};xt.multiplyByScalar=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3]*e,i[4]=t[4]*e,i[5]=t[5]*e,i[6]=t[6]*e,i[7]=t[7]*e,i[8]=t[8]*e,i};xt.multiplyByScale=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i),i[0]=t[0]*e.x,i[1]=t[1]*e.x,i[2]=t[2]*e.x,i[3]=t[3]*e.y,i[4]=t[4]*e.y,i[5]=t[5]*e.y,i[6]=t[6]*e.z,i[7]=t[7]*e.z,i[8]=t[8]*e.z,i};xt.multiplyByUniformScale=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3]*e,i[4]=t[4]*e,i[5]=t[5]*e,i[6]=t[6]*e,i[7]=t[7]*e,i[8]=t[8]*e,i};xt.negate=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=-t[0],e[1]=-t[1],e[2]=-t[2],e[3]=-t[3],e[4]=-t[4],e[5]=-t[5],e[6]=-t[6],e[7]=-t[7],e[8]=-t[8],e};xt.transpose=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[0],n=t[3],s=t[6],o=t[1],r=t[4],a=t[7],h=t[2],A=t[5],d=t[8];return e[0]=i,e[1]=n,e[2]=s,e[3]=o,e[4]=r,e[5]=a,e[6]=h,e[7]=A,e[8]=d,e};N0=[1,0,0],b0=[2,2,1];FZ=new xt,m2=new xt;xt.computeEigenDecomposition=function(t,e){p.typeOf.object("matrix",t);let i=L.EPSILON20,n=10,s=0,o=0;m(e)||(e={});let r=e.unitary=xt.clone(xt.IDENTITY,e.unitary),a=e.diagonal=xt.clone(t,e.diagonal),h=i*n9(a);for(;o<n&&s9(a)>h;)o9(a,FZ),xt.transpose(FZ,m2),xt.multiply(a,FZ,a),xt.multiply(m2,a,a),xt.multiply(r,FZ,r),++s>2&&(++o,s=0);return e};xt.abs=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=Math.abs(t[0]),e[1]=Math.abs(t[1]),e[2]=Math.abs(t[2]),e[3]=Math.abs(t[3]),e[4]=Math.abs(t[4]),e[5]=Math.abs(t[5]),e[6]=Math.abs(t[6]),e[7]=Math.abs(t[7]),e[8]=Math.abs(t[8]),e};xt.determinant=function(t){p.typeOf.object("matrix",t);let e=t[0],i=t[3],n=t[6],s=t[1],o=t[4],r=t[7],a=t[2],h=t[5],A=t[8];return e*(o*A-h*r)+s*(h*n-i*A)+a*(i*r-o*n)};xt.inverse=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[0],n=t[1],s=t[2],o=t[3],r=t[4],a=t[5],h=t[6],A=t[7],d=t[8],f=xt.determinant(t);if(Math.abs(f)<=L.EPSILON15)throw new Y("matrix is not invertible");e[0]=r*d-A*a,e[1]=A*s-n*d,e[2]=n*a-r*s,e[3]=h*a-o*d,e[4]=i*d-h*s,e[5]=o*s-i*a,e[6]=o*A-h*r,e[7]=h*n-i*A,e[8]=i*r-o*n;let E=1/f;return xt.multiplyByScalar(e,E,e)};r9=new xt;xt.inverseTranspose=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),xt.inverse(xt.transpose(t,r9),e)};xt.equals=function(t,e){return t===e||m(t)&&m(e)&&t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]&&t[4]===e[4]&&t[5]===e[5]&&t[6]===e[6]&&t[7]===e[7]&&t[8]===e[8]};xt.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t[0]-e[0])<=i&&Math.abs(t[1]-e[1])<=i&&Math.abs(t[2]-e[2])<=i&&Math.abs(t[3]-e[3])<=i&&Math.abs(t[4]-e[4])<=i&&Math.abs(t[5]-e[5])<=i&&Math.abs(t[6]-e[6])<=i&&Math.abs(t[7]-e[7])<=i&&Math.abs(t[8]-e[8])<=i};xt.IDENTITY=Object.freeze(new xt(1,0,0,0,1,0,0,0,1));xt.ZERO=Object.freeze(new xt(0,0,0,0,0,0,0,0,0));xt.COLUMN0ROW0=0;xt.COLUMN0ROW1=1;xt.COLUMN0ROW2=2;xt.COLUMN1ROW0=3;xt.COLUMN1ROW1=4;xt.COLUMN1ROW2=5;xt.COLUMN2ROW0=6;xt.COLUMN2ROW1=7;xt.COLUMN2ROW2=8;Object.defineProperties(xt.prototype,{length:{get:function(){return xt.packedLength}}});xt.prototype.clone=function(t){return xt.clone(this,t)};xt.prototype.equals=function(t){return xt.equals(this,t)};xt.equalsArray=function(t,e,i){return t[0]===e[i]&&t[1]===e[i+1]&&t[2]===e[i+2]&&t[3]===e[i+3]&&t[4]===e[i+4]&&t[5]===e[i+5]&&t[6]===e[i+6]&&t[7]===e[i+7]&&t[8]===e[i+8]};xt.prototype.equalsEpsilon=function(t,e){return xt.equalsEpsilon(this,t,e)};xt.prototype.toString=function(){return`(${this[0]}, ${this[3]}, ${this[6]})
(${this[1]}, ${this[4]}, ${this[7]})
(${this[2]}, ${this[5]}, ${this[8]})`};lt=xt});function yt(t,e,i,n,s,o,r,a,h,A,d,f,E,_,R,I){this[0]=Z(t,0),this[1]=Z(s,0),this[2]=Z(h,0),this[3]=Z(E,0),this[4]=Z(e,0),this[5]=Z(o,0),this[6]=Z(A,0),this[7]=Z(_,0),this[8]=Z(i,0),this[9]=Z(r,0),this[10]=Z(d,0),this[11]=Z(R,0),this[12]=Z(n,0),this[13]=Z(a,0),this[14]=Z(f,0),this[15]=Z(I,0)}var Tm,Nm,fE,a9,A9,F0,f2,h9,c9,l9,d9,m9,f9,E9,at,Fi=O(()=>{Ht();Vs();ae();bt();mt();Vt();_e();dn();Ps();yt.packedLength=16;yt.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t[0],e[i++]=t[1],e[i++]=t[2],e[i++]=t[3],e[i++]=t[4],e[i++]=t[5],e[i++]=t[6],e[i++]=t[7],e[i++]=t[8],e[i++]=t[9],e[i++]=t[10],e[i++]=t[11],e[i++]=t[12],e[i++]=t[13],e[i++]=t[14],e[i]=t[15],e};yt.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new yt),i[0]=t[e++],i[1]=t[e++],i[2]=t[e++],i[3]=t[e++],i[4]=t[e++],i[5]=t[e++],i[6]=t[e++],i[7]=t[e++],i[8]=t[e++],i[9]=t[e++],i[10]=t[e++],i[11]=t[e++],i[12]=t[e++],i[13]=t[e++],i[14]=t[e++],i[15]=t[e],i};yt.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*16;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 16 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)yt.pack(t[s],e,s*16);return e};yt.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,16),t.length%16!==0)throw new Y("array length must be a multiple of 16.");let i=t.length;m(e)?e.length=i/16:e=new Array(i/16);for(let n=0;n<i;n+=16){let s=n/16;e[s]=yt.unpack(t,n,e[s])}return e};yt.clone=function(t,e){if(m(t))return m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e):new yt(t[0],t[4],t[8],t[12],t[1],t[5],t[9],t[13],t[2],t[6],t[10],t[14],t[3],t[7],t[11],t[15])};yt.fromArray=yt.unpack;yt.fromColumnMajorArray=function(t,e){return p.defined("values",t),yt.clone(t,e)};yt.fromRowMajorArray=function(t,e){return p.defined("values",t),m(e)?(e[0]=t[0],e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=t[1],e[5]=t[5],e[6]=t[9],e[7]=t[13],e[8]=t[2],e[9]=t[6],e[10]=t[10],e[11]=t[14],e[12]=t[3],e[13]=t[7],e[14]=t[11],e[15]=t[15],e):new yt(t[0],t[1],t[2],t[3],t[4],t[5],t[6],t[7],t[8],t[9],t[10],t[11],t[12],t[13],t[14],t[15])};yt.fromRotationTranslation=function(t,e,i){return p.typeOf.object("rotation",t),e=Z(e,l.ZERO),m(i)?(i[0]=t[0],i[1]=t[1],i[2]=t[2],i[3]=0,i[4]=t[3],i[5]=t[4],i[6]=t[5],i[7]=0,i[8]=t[6],i[9]=t[7],i[10]=t[8],i[11]=0,i[12]=e.x,i[13]=e.y,i[14]=e.z,i[15]=1,i):new yt(t[0],t[3],t[6],e.x,t[1],t[4],t[7],e.y,t[2],t[5],t[8],e.z,0,0,0,1)};yt.fromTranslationQuaternionRotationScale=function(t,e,i,n){p.typeOf.object("translation",t),p.typeOf.object("rotation",e),p.typeOf.object("scale",i),m(n)||(n=new yt);let s=i.x,o=i.y,r=i.z,a=e.x*e.x,h=e.x*e.y,A=e.x*e.z,d=e.x*e.w,f=e.y*e.y,E=e.y*e.z,_=e.y*e.w,R=e.z*e.z,I=e.z*e.w,C=e.w*e.w,N=a-f-R+C,T=2*(h-I),F=2*(A+_),b=2*(h+I),G=-a+f-R+C,M=2*(E-d),Q=2*(A-_),U=2*(E+d),k=-a-f+R+C;return n[0]=N*s,n[1]=b*s,n[2]=Q*s,n[3]=0,n[4]=T*o,n[5]=G*o,n[6]=U*o,n[7]=0,n[8]=F*r,n[9]=M*r,n[10]=k*r,n[11]=0,n[12]=t.x,n[13]=t.y,n[14]=t.z,n[15]=1,n};yt.fromTranslationRotationScale=function(t,e){return p.typeOf.object("translationRotationScale",t),yt.fromTranslationQuaternionRotationScale(t.translation,t.rotation,t.scale,e)};yt.fromTranslation=function(t,e){return p.typeOf.object("translation",t),yt.fromRotationTranslation(lt.IDENTITY,t,e)};yt.fromScale=function(t,e){return p.typeOf.object("scale",t),m(e)?(e[0]=t.x,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=t.y,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=t.z,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e):new yt(t.x,0,0,0,0,t.y,0,0,0,0,t.z,0,0,0,0,1)};yt.fromUniformScale=function(t,e){return p.typeOf.number("scale",t),m(e)?(e[0]=t,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=t,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=t,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e):new yt(t,0,0,0,0,t,0,0,0,0,t,0,0,0,0,1)};yt.fromRotation=function(t,e){return p.typeOf.object("rotation",t),m(e)||(e=new yt),e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=0,e[4]=t[3],e[5]=t[4],e[6]=t[5],e[7]=0,e[8]=t[6],e[9]=t[7],e[10]=t[8],e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e};Tm=new l,Nm=new l,fE=new l;yt.fromCamera=function(t,e){p.typeOf.object("camera",t);let i=t.position,n=t.direction,s=t.up;p.typeOf.object("camera.position",i),p.typeOf.object("camera.direction",n),p.typeOf.object("camera.up",s),l.normalize(n,Tm),l.normalize(l.cross(Tm,s,Nm),Nm),l.normalize(l.cross(Nm,Tm,fE),fE);let o=Nm.x,r=Nm.y,a=Nm.z,h=Tm.x,A=Tm.y,d=Tm.z,f=fE.x,E=fE.y,_=fE.z,R=i.x,I=i.y,C=i.z,N=o*-R+r*-I+a*-C,T=f*-R+E*-I+_*-C,F=h*R+A*I+d*C;return m(e)?(e[0]=o,e[1]=f,e[2]=-h,e[3]=0,e[4]=r,e[5]=E,e[6]=-A,e[7]=0,e[8]=a,e[9]=_,e[10]=-d,e[11]=0,e[12]=N,e[13]=T,e[14]=F,e[15]=1,e):new yt(o,r,a,N,f,E,_,T,-h,-A,-d,F,0,0,0,1)};yt.computePerspectiveFieldOfView=function(t,e,i,n,s){p.typeOf.number.greaterThan("fovY",t,0),p.typeOf.number.lessThan("fovY",t,Math.PI),p.typeOf.number.greaterThan("near",i,0),p.typeOf.number.greaterThan("far",n,0),p.typeOf.object("result",s);let r=1/Math.tan(t*.5),a=r/e,h=(n+i)/(i-n),A=2*n*i/(i-n);return s[0]=a,s[1]=0,s[2]=0,s[3]=0,s[4]=0,s[5]=r,s[6]=0,s[7]=0,s[8]=0,s[9]=0,s[10]=h,s[11]=-1,s[12]=0,s[13]=0,s[14]=A,s[15]=0,s};yt.computeOrthographicOffCenter=function(t,e,i,n,s,o,r){p.typeOf.number("left",t),p.typeOf.number("right",e),p.typeOf.number("bottom",i),p.typeOf.number("top",n),p.typeOf.number("near",s),p.typeOf.number("far",o),p.typeOf.object("result",r);let a=1/(e-t),h=1/(n-i),A=1/(o-s),d=-(e+t)*a,f=-(n+i)*h,E=-(o+s)*A;return a*=2,h*=2,A*=-2,r[0]=a,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=h,r[6]=0,r[7]=0,r[8]=0,r[9]=0,r[10]=A,r[11]=0,r[12]=d,r[13]=f,r[14]=E,r[15]=1,r};yt.computePerspectiveOffCenter=function(t,e,i,n,s,o,r){p.typeOf.number("left",t),p.typeOf.number("right",e),p.typeOf.number("bottom",i),p.typeOf.number("top",n),p.typeOf.number("near",s),p.typeOf.number("far",o),p.typeOf.object("result",r);let a=2*s/(e-t),h=2*s/(n-i),A=(e+t)/(e-t),d=(n+i)/(n-i),f=-(o+s)/(o-s),E=-1,_=-2*o*s/(o-s);return r[0]=a,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=h,r[6]=0,r[7]=0,r[8]=A,r[9]=d,r[10]=f,r[11]=E,r[12]=0,r[13]=0,r[14]=_,r[15]=0,r};yt.computeInfinitePerspectiveOffCenter=function(t,e,i,n,s,o){p.typeOf.number("left",t),p.typeOf.number("right",e),p.typeOf.number("bottom",i),p.typeOf.number("top",n),p.typeOf.number("near",s),p.typeOf.object("result",o);let r=2*s/(e-t),a=2*s/(n-i),h=(e+t)/(e-t),A=(n+i)/(n-i),d=-1,f=-1,E=-2*s;return o[0]=r,o[1]=0,o[2]=0,o[3]=0,o[4]=0,o[5]=a,o[6]=0,o[7]=0,o[8]=h,o[9]=A,o[10]=d,o[11]=f,o[12]=0,o[13]=0,o[14]=E,o[15]=0,o};yt.computeViewportTransformation=function(t,e,i,n){m(n)||(n=new yt),t=Z(t,Z.EMPTY_OBJECT);let s=Z(t.x,0),o=Z(t.y,0),r=Z(t.width,0),a=Z(t.height,0);e=Z(e,0),i=Z(i,1);let h=r*.5,A=a*.5,d=(i-e)*.5,f=h,E=A,_=d,R=s+h,I=o+A,C=e+d,N=1;return n[0]=f,n[1]=0,n[2]=0,n[3]=0,n[4]=0,n[5]=E,n[6]=0,n[7]=0,n[8]=0,n[9]=0,n[10]=_,n[11]=0,n[12]=R,n[13]=I,n[14]=C,n[15]=N,n};yt.computeView=function(t,e,i,n,s){return p.typeOf.object("position",t),p.typeOf.object("direction",e),p.typeOf.object("up",i),p.typeOf.object("right",n),p.typeOf.object("result",s),s[0]=n.x,s[1]=i.x,s[2]=-e.x,s[3]=0,s[4]=n.y,s[5]=i.y,s[6]=-e.y,s[7]=0,s[8]=n.z,s[9]=i.z,s[10]=-e.z,s[11]=0,s[12]=-l.dot(n,t),s[13]=-l.dot(i,t),s[14]=l.dot(e,t),s[15]=1,s};yt.toArray=function(t,e){return p.typeOf.object("matrix",t),m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e):[t[0],t[1],t[2],t[3],t[4],t[5],t[6],t[7],t[8],t[9],t[10],t[11],t[12],t[13],t[14],t[15]]};yt.getElementIndex=function(t,e){return p.typeOf.number.greaterThanOrEquals("row",e,0),p.typeOf.number.lessThanOrEquals("row",e,3),p.typeOf.number.greaterThanOrEquals("column",t,0),p.typeOf.number.lessThanOrEquals("column",t,3),t*4+e};yt.getColumn=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,3),p.typeOf.object("result",i);let n=e*4,s=t[n],o=t[n+1],r=t[n+2],a=t[n+3];return i.x=s,i.y=o,i.z=r,i.w=a,i};yt.setColumn=function(t,e,i,n){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,3),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=yt.clone(t,n);let s=e*4;return n[s]=i.x,n[s+1]=i.y,n[s+2]=i.z,n[s+3]=i.w,n};yt.getRow=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,3),p.typeOf.object("result",i);let n=t[e],s=t[e+4],o=t[e+8],r=t[e+12];return i.x=n,i.y=s,i.z=o,i.w=r,i};yt.setRow=function(t,e,i,n){return p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,3),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=yt.clone(t,n),n[e]=i.x,n[e+4]=i.y,n[e+8]=i.z,n[e+12]=i.w,n};yt.setTranslation=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.object("translation",e),p.typeOf.object("result",i),i[0]=t[0],i[1]=t[1],i[2]=t[2],i[3]=t[3],i[4]=t[4],i[5]=t[5],i[6]=t[6],i[7]=t[7],i[8]=t[8],i[9]=t[9],i[10]=t[10],i[11]=t[11],i[12]=e.x,i[13]=e.y,i[14]=e.z,i[15]=t[15],i};a9=new l;yt.setScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i);let n=yt.getScale(t,a9),s=e.x/n.x,o=e.y/n.y,r=e.z/n.z;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*s,i[3]=t[3],i[4]=t[4]*o,i[5]=t[5]*o,i[6]=t[6]*o,i[7]=t[7],i[8]=t[8]*r,i[9]=t[9]*r,i[10]=t[10]*r,i[11]=t[11],i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i};A9=new l;yt.setUniformScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i);let n=yt.getScale(t,A9),s=e/n.x,o=e/n.y,r=e/n.z;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*s,i[3]=t[3],i[4]=t[4]*o,i[5]=t[5]*o,i[6]=t[6]*o,i[7]=t[7],i[8]=t[8]*r,i[9]=t[9]*r,i[10]=t[10]*r,i[11]=t[11],i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i};F0=new l;yt.getScale=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e.x=l.magnitude(l.fromElements(t[0],t[1],t[2],F0)),e.y=l.magnitude(l.fromElements(t[4],t[5],t[6],F0)),e.z=l.magnitude(l.fromElements(t[8],t[9],t[10],F0)),e};f2=new l;yt.getMaximumScale=function(t){return yt.getScale(t,f2),l.maximumComponent(f2)};h9=new l;yt.setRotation=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("result",i);let n=yt.getScale(t,h9);return i[0]=e[0]*n.x,i[1]=e[1]*n.x,i[2]=e[2]*n.x,i[3]=t[3],i[4]=e[3]*n.y,i[5]=e[4]*n.y,i[6]=e[5]*n.y,i[7]=t[7],i[8]=e[6]*n.z,i[9]=e[7]*n.z,i[10]=e[8]*n.z,i[11]=t[11],i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i};c9=new l;yt.getRotation=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=yt.getScale(t,c9);return e[0]=t[0]/i.x,e[1]=t[1]/i.x,e[2]=t[2]/i.x,e[3]=t[4]/i.y,e[4]=t[5]/i.y,e[5]=t[6]/i.y,e[6]=t[8]/i.z,e[7]=t[9]/i.z,e[8]=t[10]/i.z,e};yt.multiply=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t[0],s=t[1],o=t[2],r=t[3],a=t[4],h=t[5],A=t[6],d=t[7],f=t[8],E=t[9],_=t[10],R=t[11],I=t[12],C=t[13],N=t[14],T=t[15],F=e[0],b=e[1],G=e[2],M=e[3],Q=e[4],U=e[5],k=e[6],y=e[7],c=e[8],g=e[9],V=e[10],D=e[11],w=e[12],x=e[13],H=e[14],j=e[15],X=n*F+a*b+f*G+I*M,tt=s*F+h*b+E*G+C*M,B=o*F+A*b+_*G+N*M,It=r*F+d*b+R*G+T*M,gt=n*Q+a*U+f*k+I*y,Yt=s*Q+h*U+E*k+C*y,Mt=o*Q+A*U+_*k+N*y,Ct=r*Q+d*U+R*k+T*y,zt=n*c+a*g+f*V+I*D,kt=s*c+h*g+E*V+C*D,Jt=o*c+A*g+_*V+N*D,Wt=r*c+d*g+R*V+T*D,Ft=n*w+a*x+f*H+I*j,ee=s*w+h*x+E*H+C*j,ce=o*w+A*x+_*H+N*j,je=r*w+d*x+R*H+T*j;return i[0]=X,i[1]=tt,i[2]=B,i[3]=It,i[4]=gt,i[5]=Yt,i[6]=Mt,i[7]=Ct,i[8]=zt,i[9]=kt,i[10]=Jt,i[11]=Wt,i[12]=Ft,i[13]=ee,i[14]=ce,i[15]=je,i};yt.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]+e[0],i[1]=t[1]+e[1],i[2]=t[2]+e[2],i[3]=t[3]+e[3],i[4]=t[4]+e[4],i[5]=t[5]+e[5],i[6]=t[6]+e[6],i[7]=t[7]+e[7],i[8]=t[8]+e[8],i[9]=t[9]+e[9],i[10]=t[10]+e[10],i[11]=t[11]+e[11],i[12]=t[12]+e[12],i[13]=t[13]+e[13],i[14]=t[14]+e[14],i[15]=t[15]+e[15],i};yt.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]-e[0],i[1]=t[1]-e[1],i[2]=t[2]-e[2],i[3]=t[3]-e[3],i[4]=t[4]-e[4],i[5]=t[5]-e[5],i[6]=t[6]-e[6],i[7]=t[7]-e[7],i[8]=t[8]-e[8],i[9]=t[9]-e[9],i[10]=t[10]-e[10],i[11]=t[11]-e[11],i[12]=t[12]-e[12],i[13]=t[13]-e[13],i[14]=t[14]-e[14],i[15]=t[15]-e[15],i};yt.multiplyTransformation=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t[0],s=t[1],o=t[2],r=t[4],a=t[5],h=t[6],A=t[8],d=t[9],f=t[10],E=t[12],_=t[13],R=t[14],I=e[0],C=e[1],N=e[2],T=e[4],F=e[5],b=e[6],G=e[8],M=e[9],Q=e[10],U=e[12],k=e[13],y=e[14],c=n*I+r*C+A*N,g=s*I+a*C+d*N,V=o*I+h*C+f*N,D=n*T+r*F+A*b,w=s*T+a*F+d*b,x=o*T+h*F+f*b,H=n*G+r*M+A*Q,j=s*G+a*M+d*Q,X=o*G+h*M+f*Q,tt=n*U+r*k+A*y+E,B=s*U+a*k+d*y+_,It=o*U+h*k+f*y+R;return i[0]=c,i[1]=g,i[2]=V,i[3]=0,i[4]=D,i[5]=w,i[6]=x,i[7]=0,i[8]=H,i[9]=j,i[10]=X,i[11]=0,i[12]=tt,i[13]=B,i[14]=It,i[15]=1,i};yt.multiplyByMatrix3=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("rotation",e),p.typeOf.object("result",i);let n=t[0],s=t[1],o=t[2],r=t[4],a=t[5],h=t[6],A=t[8],d=t[9],f=t[10],E=e[0],_=e[1],R=e[2],I=e[3],C=e[4],N=e[5],T=e[6],F=e[7],b=e[8],G=n*E+r*_+A*R,M=s*E+a*_+d*R,Q=o*E+h*_+f*R,U=n*I+r*C+A*N,k=s*I+a*C+d*N,y=o*I+h*C+f*N,c=n*T+r*F+A*b,g=s*T+a*F+d*b,V=o*T+h*F+f*b;return i[0]=G,i[1]=M,i[2]=Q,i[3]=0,i[4]=U,i[5]=k,i[6]=y,i[7]=0,i[8]=c,i[9]=g,i[10]=V,i[11]=0,i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i};yt.multiplyByTranslation=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("translation",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z,r=n*t[0]+s*t[4]+o*t[8]+t[12],a=n*t[1]+s*t[5]+o*t[9]+t[13],h=n*t[2]+s*t[6]+o*t[10]+t[14];return i[0]=t[0],i[1]=t[1],i[2]=t[2],i[3]=t[3],i[4]=t[4],i[5]=t[5],i[6]=t[6],i[7]=t[7],i[8]=t[8],i[9]=t[9],i[10]=t[10],i[11]=t[11],i[12]=r,i[13]=a,i[14]=h,i[15]=t[15],i};yt.multiplyByScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z;return n===1&&s===1&&o===1?yt.clone(t,i):(i[0]=n*t[0],i[1]=n*t[1],i[2]=n*t[2],i[3]=t[3],i[4]=s*t[4],i[5]=s*t[5],i[6]=s*t[6],i[7]=t[7],i[8]=o*t[8],i[9]=o*t[9],i[10]=o*t[10],i[11]=t[11],i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i)};yt.multiplyByUniformScale=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3],i[4]=t[4]*e,i[5]=t[5]*e,i[6]=t[6]*e,i[7]=t[7],i[8]=t[8]*e,i[9]=t[9]*e,i[10]=t[10]*e,i[11]=t[11],i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i};yt.multiplyByVector=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("cartesian",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z,r=e.w,a=t[0]*n+t[4]*s+t[8]*o+t[12]*r,h=t[1]*n+t[5]*s+t[9]*o+t[13]*r,A=t[2]*n+t[6]*s+t[10]*o+t[14]*r,d=t[3]*n+t[7]*s+t[11]*o+t[15]*r;return i.x=a,i.y=h,i.z=A,i.w=d,i};yt.multiplyByPointAsVector=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("cartesian",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z,r=t[0]*n+t[4]*s+t[8]*o,a=t[1]*n+t[5]*s+t[9]*o,h=t[2]*n+t[6]*s+t[10]*o;return i.x=r,i.y=a,i.z=h,i};yt.multiplyByPoint=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("cartesian",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z,r=t[0]*n+t[4]*s+t[8]*o+t[12],a=t[1]*n+t[5]*s+t[9]*o+t[13],h=t[2]*n+t[6]*s+t[10]*o+t[14];return i.x=r,i.y=a,i.z=h,i};yt.multiplyByScalar=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3]*e,i[4]=t[4]*e,i[5]=t[5]*e,i[6]=t[6]*e,i[7]=t[7]*e,i[8]=t[8]*e,i[9]=t[9]*e,i[10]=t[10]*e,i[11]=t[11]*e,i[12]=t[12]*e,i[13]=t[13]*e,i[14]=t[14]*e,i[15]=t[15]*e,i};yt.negate=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=-t[0],e[1]=-t[1],e[2]=-t[2],e[3]=-t[3],e[4]=-t[4],e[5]=-t[5],e[6]=-t[6],e[7]=-t[7],e[8]=-t[8],e[9]=-t[9],e[10]=-t[10],e[11]=-t[11],e[12]=-t[12],e[13]=-t[13],e[14]=-t[14],e[15]=-t[15],e};yt.transpose=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[1],n=t[2],s=t[3],o=t[6],r=t[7],a=t[11];return e[0]=t[0],e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=i,e[5]=t[5],e[6]=t[9],e[7]=t[13],e[8]=n,e[9]=o,e[10]=t[10],e[11]=t[14],e[12]=s,e[13]=r,e[14]=a,e[15]=t[15],e};yt.abs=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=Math.abs(t[0]),e[1]=Math.abs(t[1]),e[2]=Math.abs(t[2]),e[3]=Math.abs(t[3]),e[4]=Math.abs(t[4]),e[5]=Math.abs(t[5]),e[6]=Math.abs(t[6]),e[7]=Math.abs(t[7]),e[8]=Math.abs(t[8]),e[9]=Math.abs(t[9]),e[10]=Math.abs(t[10]),e[11]=Math.abs(t[11]),e[12]=Math.abs(t[12]),e[13]=Math.abs(t[13]),e[14]=Math.abs(t[14]),e[15]=Math.abs(t[15]),e};yt.equals=function(t,e){return t===e||m(t)&&m(e)&&t[12]===e[12]&&t[13]===e[13]&&t[14]===e[14]&&t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[4]===e[4]&&t[5]===e[5]&&t[6]===e[6]&&t[8]===e[8]&&t[9]===e[9]&&t[10]===e[10]&&t[3]===e[3]&&t[7]===e[7]&&t[11]===e[11]&&t[15]===e[15]};yt.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t[0]-e[0])<=i&&Math.abs(t[1]-e[1])<=i&&Math.abs(t[2]-e[2])<=i&&Math.abs(t[3]-e[3])<=i&&Math.abs(t[4]-e[4])<=i&&Math.abs(t[5]-e[5])<=i&&Math.abs(t[6]-e[6])<=i&&Math.abs(t[7]-e[7])<=i&&Math.abs(t[8]-e[8])<=i&&Math.abs(t[9]-e[9])<=i&&Math.abs(t[10]-e[10])<=i&&Math.abs(t[11]-e[11])<=i&&Math.abs(t[12]-e[12])<=i&&Math.abs(t[13]-e[13])<=i&&Math.abs(t[14]-e[14])<=i&&Math.abs(t[15]-e[15])<=i};yt.getTranslation=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e.x=t[12],e.y=t[13],e.z=t[14],e};yt.getMatrix3=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[4],e[4]=t[5],e[5]=t[6],e[6]=t[8],e[7]=t[9],e[8]=t[10],e};l9=new lt,d9=new lt,m9=new ie,f9=new ie(0,0,0,1);yt.inverse=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[0],n=t[4],s=t[8],o=t[12],r=t[1],a=t[5],h=t[9],A=t[13],d=t[2],f=t[6],E=t[10],_=t[14],R=t[3],I=t[7],C=t[11],N=t[15],T=E*N,F=_*C,b=f*N,G=_*I,M=f*C,Q=E*I,U=d*N,k=_*R,y=d*C,c=E*R,g=d*I,V=f*R,D=T*a+G*h+M*A-(F*a+b*h+Q*A),w=F*r+U*h+c*A-(T*r+k*h+y*A),x=b*r+k*a+g*A-(G*r+U*a+V*A),H=Q*r+y*a+V*h-(M*r+c*a+g*h),j=F*n+b*s+Q*o-(T*n+G*s+M*o),X=T*i+k*s+y*o-(F*i+U*s+c*o),tt=G*i+U*n+V*o-(b*i+k*n+g*o),B=M*i+c*n+g*s-(Q*i+y*n+V*s);T=s*A,F=o*h,b=n*A,G=o*a,M=n*h,Q=s*a,U=i*A,k=o*r,y=i*h,c=s*r,g=i*a,V=n*r;let It=T*I+G*C+M*N-(F*I+b*C+Q*N),gt=F*R+U*C+c*N-(T*R+k*C+y*N),Yt=b*R+k*I+g*N-(G*R+U*I+V*N),Mt=Q*R+y*I+V*C-(M*R+c*I+g*C),Ct=b*E+Q*_+F*f-(M*_+T*f+G*E),zt=y*_+T*d+k*E-(U*E+c*_+F*d),kt=U*f+V*_+G*d-(g*_+b*d+k*f),Jt=g*E+M*d+c*f-(y*f+V*E+Q*d),Wt=i*D+n*w+s*x+o*H;if(Math.abs(Wt)<L.EPSILON21){if(lt.equalsEpsilon(yt.getMatrix3(t,l9),d9,L.EPSILON7)&&ie.equals(yt.getRow(t,3,m9),f9))return e[0]=0,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=0,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=0,e[11]=0,e[12]=-t[12],e[13]=-t[13],e[14]=-t[14],e[15]=1,e;throw new ke("matrix is not invertible because its determinate is zero.")}return Wt=1/Wt,e[0]=D*Wt,e[1]=w*Wt,e[2]=x*Wt,e[3]=H*Wt,e[4]=j*Wt,e[5]=X*Wt,e[6]=tt*Wt,e[7]=B*Wt,e[8]=It*Wt,e[9]=gt*Wt,e[10]=Yt*Wt,e[11]=Mt*Wt,e[12]=Ct*Wt,e[13]=zt*Wt,e[14]=kt*Wt,e[15]=Jt*Wt,e};yt.inverseTransformation=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[0],n=t[1],s=t[2],o=t[4],r=t[5],a=t[6],h=t[8],A=t[9],d=t[10],f=t[12],E=t[13],_=t[14],R=-i*f-n*E-s*_,I=-o*f-r*E-a*_,C=-h*f-A*E-d*_;return e[0]=i,e[1]=o,e[2]=h,e[3]=0,e[4]=n,e[5]=r,e[6]=A,e[7]=0,e[8]=s,e[9]=a,e[10]=d,e[11]=0,e[12]=R,e[13]=I,e[14]=C,e[15]=1,e};E9=new yt;yt.inverseTranspose=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),yt.inverse(yt.transpose(t,E9),e)};yt.IDENTITY=Object.freeze(new yt(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1));yt.ZERO=Object.freeze(new yt(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0));yt.COLUMN0ROW0=0;yt.COLUMN0ROW1=1;yt.COLUMN0ROW2=2;yt.COLUMN0ROW3=3;yt.COLUMN1ROW0=4;yt.COLUMN1ROW1=5;yt.COLUMN1ROW2=6;yt.COLUMN1ROW3=7;yt.COLUMN2ROW0=8;yt.COLUMN2ROW1=9;yt.COLUMN2ROW2=10;yt.COLUMN2ROW3=11;yt.COLUMN3ROW0=12;yt.COLUMN3ROW1=13;yt.COLUMN3ROW2=14;yt.COLUMN3ROW3=15;Object.defineProperties(yt.prototype,{length:{get:function(){return yt.packedLength}}});yt.prototype.clone=function(t){return yt.clone(this,t)};yt.prototype.equals=function(t){return yt.equals(this,t)};yt.equalsArray=function(t,e,i){return t[0]===e[i]&&t[1]===e[i+1]&&t[2]===e[i+2]&&t[3]===e[i+3]&&t[4]===e[i+4]&&t[5]===e[i+5]&&t[6]===e[i+6]&&t[7]===e[i+7]&&t[8]===e[i+8]&&t[9]===e[i+9]&&t[10]===e[i+10]&&t[11]===e[i+11]&&t[12]===e[i+12]&&t[13]===e[i+13]&&t[14]===e[i+14]&&t[15]===e[i+15]};yt.prototype.equalsEpsilon=function(t,e){return yt.equalsEpsilon(this,t,e)};yt.prototype.toString=function(){return`(${this[0]}, ${this[4]}, ${this[8]}, ${this[12]})
(${this[1]}, ${this[5]}, ${this[9]}, ${this[13]})
(${this[2]}, ${this[6]}, ${this[10]}, ${this[14]})
(${this[3]}, ${this[7]}, ${this[11]}, ${this[15]})`};at=yt});var rc,is,qo,E2,_2=O(()=>{mt();is={requestFullscreen:void 0,exitFullscreen:void 0,fullscreenEnabled:void 0,fullscreenElement:void 0,fullscreenchange:void 0,fullscreenerror:void 0},qo={};Object.defineProperties(qo,{element:{get:function(){if(qo.supportsFullscreen())return document[is.fullscreenElement]}},changeEventName:{get:function(){if(qo.supportsFullscreen())return is.fullscreenchange}},errorEventName:{get:function(){if(qo.supportsFullscreen())return is.fullscreenerror}},enabled:{get:function(){if(qo.supportsFullscreen())return document[is.fullscreenEnabled]}},fullscreen:{get:function(){if(qo.supportsFullscreen())return qo.element!==null}}});qo.supportsFullscreen=function(){if(m(rc))return rc;rc=!1;let t=document.body;if(typeof t.requestFullscreen=="function")return is.requestFullscreen="requestFullscreen",is.exitFullscreen="exitFullscreen",is.fullscreenEnabled="fullscreenEnabled",is.fullscreenElement="fullscreenElement",is.fullscreenchange="fullscreenchange",is.fullscreenerror="fullscreenerror",rc=!0,rc;let e=["webkit","moz","o","ms","khtml"],i;for(let n=0,s=e.length;n<s;++n){let o=e[n];i=`${o}RequestFullscreen`,typeof t[i]=="function"?(is.requestFullscreen=i,rc=!0):(i=`${o}RequestFullScreen`,typeof t[i]=="function"&&(is.requestFullscreen=i,rc=!0)),i=`${o}ExitFullscreen`,typeof document[i]=="function"?is.exitFullscreen=i:(i=`${o}CancelFullScreen`,typeof document[i]=="function"&&(is.exitFullscreen=i)),i=`${o}FullscreenEnabled`,document[i]!==void 0?is.fullscreenEnabled=i:(i=`${o}FullScreenEnabled`,document[i]!==void 0&&(is.fullscreenEnabled=i)),i=`${o}FullscreenElement`,document[i]!==void 0?is.fullscreenElement=i:(i=`${o}FullScreenElement`,document[i]!==void 0&&(is.fullscreenElement=i)),i=`${o}fullscreenchange`,document[`on${i}`]!==void 0&&(o==="ms"&&(i="MSFullscreenChange"),is.fullscreenchange=i),i=`${o}fullscreenerror`,document[`on${i}`]!==void 0&&(o==="ms"&&(i="MSFullscreenError"),is.fullscreenerror=i)}return rc};qo.requestFullscreen=function(t,e){qo.supportsFullscreen()&&t[is.requestFullscreen]({vrDisplay:e})};qo.exitFullscreen=function(){qo.supportsFullscreen()&&document[is.exitFullscreen]()};qo._names=is;E2=qo});function Zl(t){let e=t.split(".");for(let i=0,n=e.length;i<n;++i)e[i]=parseInt(e[i],10);return e}function B0(){if(!m(YZ)&&(YZ=!1,!WZ())){let t=/ Chrome\/([\.0-9]+)/.exec(Eo.userAgent);t!==null&&(YZ=!0,R2=Zl(t[1]))}return YZ}function _9(){return B0()&&R2}function I2(){if(!m(SZ)&&(SZ=!1,!B0()&&!WZ()&&/ Safari\/[\.0-9]+/.test(Eo.userAgent))){let t=/ Version\/([\.0-9]+)/.exec(Eo.userAgent);t!==null&&(SZ=!0,Z2=Zl(t[1]))}return SZ}function R9(){return I2()&&Z2}function p2(){if(!m(OZ)){OZ=!1;let t=/ AppleWebKit\/([\.0-9]+)(\+?)/.exec(Eo.userAgent);t!==null&&(OZ=!0,V0=Zl(t[1]),V0.isNightly=!!t[2])}return OZ}function Z9(){return p2()&&V0}function u2(){if(!m(EE)){EE=!1;let t;Eo.appName==="Microsoft Internet Explorer"?(t=/MSIE ([0-9]{1,}[\.0-9]{0,})/.exec(Eo.userAgent),t!==null&&(EE=!0,G0=Zl(t[1]))):Eo.appName==="Netscape"&&(t=/Trident\/.*rv:([0-9]{1,}[\.0-9]{0,})/.exec(Eo.userAgent),t!==null&&(EE=!0,G0=Zl(t[1])))}return EE}function I9(){return u2()&&G0}function WZ(){if(!m(VZ)){VZ=!1;let t=/ Edg\/([\.0-9]+)/.exec(Eo.userAgent);t!==null&&(VZ=!0,C2=Zl(t[1]))}return VZ}function p9(){return WZ()&&C2}function DZ(){if(!m(GZ)){GZ=!1;let t=/Firefox\/([\.0-9]+)/.exec(Eo.userAgent);t!==null&&(GZ=!0,W0=Zl(t[1]))}return GZ}function u9(){return m(Y0)||(Y0=/Windows/i.test(Eo.appVersion)),Y0}function C9(){return m(S0)||(S0=navigator.platform==="iPhone"||navigator.platform==="iPod"||navigator.platform==="iPad"),S0}function g9(){return DZ()&&W0}function T9(){return m(O0)||(O0=!DZ()&&typeof PointerEvent<"u"&&(!m(Eo.pointerEnabled)||Eo.pointerEnabled)),O0}function T2(){if(!m(BZ)){let t=document.createElement("canvas");t.setAttribute("style","image-rendering: -moz-crisp-edges;image-rendering: pixelated;");let e=t.style.imageRendering;BZ=m(e)&&e!=="",BZ&&(g2=e)}return BZ}function N9(){return T2()?g2:void 0}function fo(){if(!fo.initialized)throw new Y("You must call FeatureDetection.supportsWebP.initialize and wait for the promise to resolve before calling FeatureDetection.supportsWebP");return fo._result}var Eo,YZ,R2,SZ,Z2,OZ,V0,EE,G0,VZ,C2,GZ,W0,Y0,S0,O0,g2,BZ,bm,Gr,_o,Il=O(()=>{ae();bt();mt();Vt();_2();typeof navigator<"u"?Eo=navigator:Eo={};fo._promise=void 0;fo._result=void 0;fo.initialize=function(){return m(fo._promise)||(fo._promise=new Promise(t=>{let e=new Image;e.onload=function(){fo._result=e.width>0&&e.height>0,t(fo._result)},e.onerror=function(){fo._result=!1,t(fo._result)},e.src="data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA"})),fo._promise};Object.defineProperties(fo,{initialized:{get:function(){return m(fo._result)}}});bm=[];typeof ArrayBuffer<"u"&&(bm.push(Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array),typeof Uint8ClampedArray<"u"&&bm.push(Uint8ClampedArray),typeof Uint8ClampedArray<"u"&&bm.push(Uint8ClampedArray),typeof BigInt64Array<"u"&&bm.push(BigInt64Array),typeof BigUint64Array<"u"&&bm.push(BigUint64Array));Gr={isChrome:B0,chromeVersion:_9,isSafari:I2,safariVersion:R9,isWebkit:p2,webkitVersion:Z9,isInternetExplorer:u2,internetExplorerVersion:I9,isEdge:WZ,edgeVersion:p9,isFirefox:DZ,firefoxVersion:g9,isWindows:u9,isIPadOrIOS:C9,hardwareConcurrency:Z(Eo.hardwareConcurrency,3),supportsPointerEvents:T9,supportsImageRenderingPixelated:T2,supportsWebP:fo,imageRenderingValue:N9,typedArrayTypes:bm};Gr.supportsBasis=function(t){return Gr.supportsWebAssembly()&&t.context.supportsBasis};Gr.supportsFullscreen=function(){return E2.supportsFullscreen()};Gr.supportsTypedArrays=function(){return typeof ArrayBuffer<"u"};Gr.supportsBigInt64Array=function(){return typeof BigInt64Array<"u"};Gr.supportsBigUint64Array=function(){return typeof BigUint64Array<"u"};Gr.supportsBigInt=function(){return typeof BigInt<"u"};Gr.supportsWebWorkers=function(){return typeof Worker<"u"};Gr.supportsWebAssembly=function(){return typeof WebAssembly<"u"};Gr.supportsWebgl2=function(t){return p.defined("scene",t),t.context.webgl2};Gr.supportsEsmWebWorkers=function(){return!DZ()||parseInt(W0)>=114};_o=Gr});function Pt(t,e,i,n){this.x=Z(t,0),this.y=Z(e,0),this.z=Z(i,0),this.w=Z(n,0)}var _E,b9,F9,N2,b2,D0,F2,MZ,M0,pa,Y2,UZ,U0,S2,Q0,k0,Y9,S9,RE,Fm,O9,O2,QZ,kZ,qA,$A,Ae,$s=O(()=>{Ht();ae();bt();mt();Il();_e();dn();_E=new l;Pt.fromAxisAngle=function(t,e,i){p.typeOf.object("axis",t),p.typeOf.number("angle",e);let n=e/2,s=Math.sin(n);_E=l.normalize(t,_E);let o=_E.x*s,r=_E.y*s,a=_E.z*s,h=Math.cos(n);return m(i)?(i.x=o,i.y=r,i.z=a,i.w=h,i):new Pt(o,r,a,h)};b9=[1,2,0],F9=new Array(3);Pt.fromRotationMatrix=function(t,e){p.typeOf.object("matrix",t);let i,n,s,o,r,a=t[lt.COLUMN0ROW0],h=t[lt.COLUMN1ROW1],A=t[lt.COLUMN2ROW2],d=a+h+A;if(d>0)i=Math.sqrt(d+1),r=.5*i,i=.5/i,n=(t[lt.COLUMN1ROW2]-t[lt.COLUMN2ROW1])*i,s=(t[lt.COLUMN2ROW0]-t[lt.COLUMN0ROW2])*i,o=(t[lt.COLUMN0ROW1]-t[lt.COLUMN1ROW0])*i;else{let f=b9,E=0;h>a&&(E=1),A>a&&A>h&&(E=2);let _=f[E],R=f[_];i=Math.sqrt(t[lt.getElementIndex(E,E)]-t[lt.getElementIndex(_,_)]-t[lt.getElementIndex(R,R)]+1);let I=F9;I[E]=.5*i,i=.5/i,r=(t[lt.getElementIndex(R,_)]-t[lt.getElementIndex(_,R)])*i,I[_]=(t[lt.getElementIndex(_,E)]+t[lt.getElementIndex(E,_)])*i,I[R]=(t[lt.getElementIndex(R,E)]+t[lt.getElementIndex(E,R)])*i,n=-I[0],s=-I[1],o=-I[2]}return m(e)?(e.x=n,e.y=s,e.z=o,e.w=r,e):new Pt(n,s,o,r)};N2=new Pt,b2=new Pt,D0=new Pt,F2=new Pt;Pt.fromHeadingPitchRoll=function(t,e){return p.typeOf.object("headingPitchRoll",t),F2=Pt.fromAxisAngle(l.UNIT_X,t.roll,N2),D0=Pt.fromAxisAngle(l.UNIT_Y,-t.pitch,e),e=Pt.multiply(D0,F2,D0),b2=Pt.fromAxisAngle(l.UNIT_Z,-t.heading,N2),Pt.multiply(b2,e,e)};MZ=new l,M0=new l,pa=new Pt,Y2=new Pt,UZ=new Pt;Pt.packedLength=4;Pt.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.x,e[i++]=t.y,e[i++]=t.z,e[i]=t.w,e};Pt.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Pt),i.x=t[e],i.y=t[e+1],i.z=t[e+2],i.w=t[e+3],i};Pt.packedInterpolationLength=3;Pt.convertPackedArrayForInterpolation=function(t,e,i,n){Pt.unpack(t,i*4,UZ),Pt.conjugate(UZ,UZ);for(let s=0,o=i-e+1;s<o;s++){let r=s*3;Pt.unpack(t,(e+s)*4,pa),Pt.multiply(pa,UZ,pa),pa.w<0&&Pt.negate(pa,pa),Pt.computeAxis(pa,MZ);let a=Pt.computeAngle(pa);m(n)||(n=[]),n[r]=MZ.x*a,n[r+1]=MZ.y*a,n[r+2]=MZ.z*a}};Pt.unpackInterpolationResult=function(t,e,i,n,s){m(s)||(s=new Pt),l.fromArray(t,0,M0);let o=l.magnitude(M0);return Pt.unpack(e,n*4,Y2),o===0?Pt.clone(Pt.IDENTITY,pa):Pt.fromAxisAngle(M0,o,pa),Pt.multiply(pa,Y2,s)};Pt.clone=function(t,e){if(m(t))return m(e)?(e.x=t.x,e.y=t.y,e.z=t.z,e.w=t.w,e):new Pt(t.x,t.y,t.z,t.w)};Pt.conjugate=function(t,e){return p.typeOf.object("quaternion",t),p.typeOf.object("result",e),e.x=-t.x,e.y=-t.y,e.z=-t.z,e.w=t.w,e};Pt.magnitudeSquared=function(t){return p.typeOf.object("quaternion",t),t.x*t.x+t.y*t.y+t.z*t.z+t.w*t.w};Pt.magnitude=function(t){return Math.sqrt(Pt.magnitudeSquared(t))};Pt.normalize=function(t,e){p.typeOf.object("result",e);let i=1/Pt.magnitude(t),n=t.x*i,s=t.y*i,o=t.z*i,r=t.w*i;return e.x=n,e.y=s,e.z=o,e.w=r,e};Pt.inverse=function(t,e){p.typeOf.object("result",e);let i=Pt.magnitudeSquared(t);return e=Pt.conjugate(t,e),Pt.multiplyByScalar(e,1/i,e)};Pt.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x+e.x,i.y=t.y+e.y,i.z=t.z+e.z,i.w=t.w+e.w,i};Pt.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x-e.x,i.y=t.y-e.y,i.z=t.z-e.z,i.w=t.w-e.w,i};Pt.negate=function(t,e){return p.typeOf.object("quaternion",t),p.typeOf.object("result",e),e.x=-t.x,e.y=-t.y,e.z=-t.z,e.w=-t.w,e};Pt.dot=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.x*e.x+t.y*e.y+t.z*e.z+t.w*e.w};Pt.multiply=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t.x,s=t.y,o=t.z,r=t.w,a=e.x,h=e.y,A=e.z,d=e.w,f=r*a+n*d+s*A-o*h,E=r*h-n*A+s*d+o*a,_=r*A+n*h-s*a+o*d,R=r*d-n*a-s*h-o*A;return i.x=f,i.y=E,i.z=_,i.w=R,i};Pt.multiplyByScalar=function(t,e,i){return p.typeOf.object("quaternion",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x*e,i.y=t.y*e,i.z=t.z*e,i.w=t.w*e,i};Pt.divideByScalar=function(t,e,i){return p.typeOf.object("quaternion",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x/e,i.y=t.y/e,i.z=t.z/e,i.w=t.w/e,i};Pt.computeAxis=function(t,e){p.typeOf.object("quaternion",t),p.typeOf.object("result",e);let i=t.w;if(Math.abs(i-1)<L.EPSILON6||Math.abs(i+1)<L.EPSILON6)return e.x=1,e.y=e.z=0,e;let n=1/Math.sqrt(1-i*i);return e.x=t.x*n,e.y=t.y*n,e.z=t.z*n,e};Pt.computeAngle=function(t){return p.typeOf.object("quaternion",t),Math.abs(t.w-1)<L.EPSILON6?0:2*Math.acos(t.w)};U0=new Pt;Pt.lerp=function(t,e,i,n){return p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n),U0=Pt.multiplyByScalar(e,i,U0),n=Pt.multiplyByScalar(t,1-i,n),Pt.add(U0,n,n)};S2=new Pt,Q0=new Pt,k0=new Pt;Pt.slerp=function(t,e,i,n){p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n);let s=Pt.dot(t,e),o=e;if(s<0&&(s=-s,o=S2=Pt.negate(e,S2)),1-s<L.EPSILON6)return Pt.lerp(t,o,i,n);let r=Math.acos(s);return Q0=Pt.multiplyByScalar(t,Math.sin((1-i)*r),Q0),k0=Pt.multiplyByScalar(o,Math.sin(i*r),k0),n=Pt.add(Q0,k0,n),Pt.multiplyByScalar(n,1/Math.sin(r),n)};Pt.log=function(t,e){p.typeOf.object("quaternion",t),p.typeOf.object("result",e);let i=L.acosClamped(t.w),n=0;return i!==0&&(n=i/Math.sin(i)),l.multiplyByScalar(t,n,e)};Pt.exp=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=l.magnitude(t),n=0;return i!==0&&(n=Math.sin(i)/i),e.x=t.x*n,e.y=t.y*n,e.z=t.z*n,e.w=Math.cos(i),e};Y9=new l,S9=new l,RE=new Pt,Fm=new Pt;Pt.computeInnerQuadrangle=function(t,e,i,n){p.typeOf.object("q0",t),p.typeOf.object("q1",e),p.typeOf.object("q2",i),p.typeOf.object("result",n);let s=Pt.conjugate(e,RE);Pt.multiply(s,i,Fm);let o=Pt.log(Fm,Y9);Pt.multiply(s,t,Fm);let r=Pt.log(Fm,S9);return l.add(o,r,o),l.multiplyByScalar(o,.25,o),l.negate(o,o),Pt.exp(o,RE),Pt.multiply(e,RE,n)};Pt.squad=function(t,e,i,n,s,o){p.typeOf.object("q0",t),p.typeOf.object("q1",e),p.typeOf.object("s0",i),p.typeOf.object("s1",n),p.typeOf.number("t",s),p.typeOf.object("result",o);let r=Pt.slerp(t,e,s,RE),a=Pt.slerp(i,n,s,Fm);return Pt.slerp(r,a,2*s*(1-s),o)};O9=new Pt,O2=1.9011074535173003,QZ=_o.supportsTypedArrays()?new Float32Array(8):[],kZ=_o.supportsTypedArrays()?new Float32Array(8):[],qA=_o.supportsTypedArrays()?new Float32Array(8):[],$A=_o.supportsTypedArrays()?new Float32Array(8):[];for(let t=0;t<7;++t){let e=t+1,i=2*e+1;QZ[t]=1/(e*i),kZ[t]=e/i}QZ[7]=O2/(8*17);kZ[7]=O2*8/17;Pt.fastSlerp=function(t,e,i,n){p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n);let s=Pt.dot(t,e),o;s>=0?o=1:(o=-1,s=-s);let r=s-1,a=1-i,h=i*i,A=a*a;for(let _=7;_>=0;--_)qA[_]=(QZ[_]*h-kZ[_])*r,$A[_]=(QZ[_]*A-kZ[_])*r;let d=o*i*(1+qA[0]*(1+qA[1]*(1+qA[2]*(1+qA[3]*(1+qA[4]*(1+qA[5]*(1+qA[6]*(1+qA[7])))))))),f=a*(1+$A[0]*(1+$A[1]*(1+$A[2]*(1+$A[3]*(1+$A[4]*(1+$A[5]*(1+$A[6]*(1+$A[7])))))))),E=Pt.multiplyByScalar(t,f,O9);return Pt.multiplyByScalar(e,d,n),Pt.add(E,n,n)};Pt.fastSquad=function(t,e,i,n,s,o){p.typeOf.object("q0",t),p.typeOf.object("q1",e),p.typeOf.object("s0",i),p.typeOf.object("s1",n),p.typeOf.number("t",s),p.typeOf.object("result",o);let r=Pt.fastSlerp(t,e,s,RE),a=Pt.fastSlerp(i,n,s,Fm);return Pt.fastSlerp(r,a,2*s*(1-s),o)};Pt.equals=function(t,e){return t===e||m(t)&&m(e)&&t.x===e.x&&t.y===e.y&&t.z===e.z&&t.w===e.w};Pt.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t.x-e.x)<=i&&Math.abs(t.y-e.y)<=i&&Math.abs(t.z-e.z)<=i&&Math.abs(t.w-e.w)<=i};Pt.ZERO=Object.freeze(new Pt(0,0,0,0));Pt.IDENTITY=Object.freeze(new Pt(0,0,0,1));Pt.prototype.clone=function(t){return Pt.clone(this,t)};Pt.prototype.equals=function(t){return Pt.equals(this,t)};Pt.prototype.equalsEpsilon=function(t,e){return Pt.equalsEpsilon(this,t,e)};Pt.prototype.toString=function(){return`(${this.x}, ${this.y}, ${this.z}, ${this.w})`};Ae=Pt});function Ro(t,e,i){this.heading=Z(t,0),this.pitch=Z(e,0),this.roll=Z(i,0)}var ZE,V2=O(()=>{bt();mt();Vt();_e();dn();Fi();$s();Ro.fromQuaternion=function(t,e,i){if(!m(t))throw new Y("quaternion is required");m(e)||(e=new Ro);let n,s;if(m(i)){if(typeof i=="function")n=i();else if(i instanceof at)n=i;else throw new Y("referenceFrame must be a Matrix4 or a function returning a Matrix4");let d=at.inverse(n,new at),f=at.getRotation(d,new lt),E=Ae.fromRotationMatrix(f,new Ae);s=Ae.multiply(E,t,new Ae)}else s=t;let o=2*(s.w*s.y-s.z*s.x),r=1-2*(s.x*s.x+s.y*s.y),a=2*(s.w*s.x+s.y*s.z),h=1-2*(s.y*s.y+s.z*s.z),A=2*(s.w*s.z+s.x*s.y);return e.heading=-Math.atan2(A,h),e.roll=Math.atan2(a,r),e.pitch=-L.asinClamped(o),e};Ro.fromDegrees=function(t,e,i,n){if(!m(t))throw new Y("heading is required");if(!m(e))throw new Y("pitch is required");if(!m(i))throw new Y("roll is required");return m(n)||(n=new Ro),n.heading=t*L.RADIANS_PER_DEGREE,n.pitch=e*L.RADIANS_PER_DEGREE,n.roll=i*L.RADIANS_PER_DEGREE,n};Ro.clone=function(t,e){if(m(t))return m(e)?(e.heading=t.heading,e.pitch=t.pitch,e.roll=t.roll,e):new Ro(t.heading,t.pitch,t.roll)};Ro.equals=function(t,e){return t===e||m(t)&&m(e)&&t.heading===e.heading&&t.pitch===e.pitch&&t.roll===e.roll};Ro.equalsEpsilon=function(t,e,i,n){return t===e||m(t)&&m(e)&&L.equalsEpsilon(t.heading,e.heading,i,n)&&L.equalsEpsilon(t.pitch,e.pitch,i,n)&&L.equalsEpsilon(t.roll,e.roll,i,n)};Ro.prototype.clone=function(t){return Ro.clone(this,t)};Ro.prototype.equals=function(t){return Ro.equals(this,t)};Ro.prototype.equalsEpsilon=function(t,e,i){return Ro.equalsEpsilon(this,t,e,i)};Ro.prototype.toString=function(){return`(${this.heading}, ${this.pitch}, ${this.roll})`};ZE=Ro});var L0,LZ,G2,yZ=O(()=>{L0={},LZ=[],G2={}});function V9(){let t=document.getElementsByTagName("script");for(let e=0,i=t.length;e<i;++e){let n=t[e].getAttribute("src"),s=W2.exec(n);if(s!==null)return s[1]}}function D2(t){return typeof document>"u"?t:(m(wZ)||(wZ=document.createElement("a")),wZ.href=t,wZ.href)}function M2(){if(m(pl))return pl;let t;return typeof CESIUM_BASE_URL<"u"?t=CESIUM_BASE_URL:m(B2?.url)?t=AE(".",B2.url):typeof define=="object"&&m(define.amd)&&!define.amd.toUrlUndefined&&m(Xo.toUrl)?t=AE("..",ul("Core/buildModuleUrl.js")):t=V9(),m(t)||(t="/"),pl=new tn({url:D2(t)}),pl.appendForwardSlash(),pl}function G9(t){return D2(Xo.toUrl(`../${t}`))}function U2(t){return M2().getDerivedResource({url:t}).url}function ul(t){return L0[t]?L0[t]:(m(xZ)||(typeof define=="object"&&m(define.amd)&&!define.amd.toUrlUndefined&&m(Xo.toUrl)?xZ=G9:xZ=U2),xZ(t))}var B2,W2,wZ,pl,xZ,th,PZ=O(()=>{mt();E0();Ia();yZ();B2={},W2=/((?:.*\/)|^)Cesium\.js(?:\?|\#|$)/;ul._cesiumScriptRegex=W2;ul._buildModuleUrlFromBaseUrl=U2;ul._clearBaseResource=function(){pl=void 0};ul.setBaseUrl=function(t){pl=tn.DEFAULT.getDerivedResource({url:t})};ul.getCesiumBaseUrl=M2;th=ul});function B9(t,e,i){this.x=t,this.y=e,this.s=i}var JZ,y0=O(()=>{JZ=B9});function P0(t){t=Z(t,Z.EMPTY_OBJECT),this._xysFileUrlTemplate=tn.createIfNeeded(t.xysFileUrlTemplate),this._interpolationOrder=Z(t.interpolationOrder,9),this._sampleZeroJulianEphemerisDate=Z(t.sampleZeroJulianEphemerisDate,24423965e-1),this._sampleZeroDateTT=new Ze(this._sampleZeroJulianEphemerisDate,0,Ei.TAI),this._stepSizeDays=Z(t.stepSizeDays,1),this._samplesPerXysFile=Z(t.samplesPerXysFile,1e3),this._totalSamples=Z(t.totalSamples,27426),this._samples=G2||new Array(this._totalSamples*3),this._chunkDownloadsInProgress=[];let e=this._interpolationOrder,i=this._denominators=new Array(e+1),n=this._xTable=new Array(e+1),s=Math.pow(this._stepSizeDays,e);for(let o=0;o<=e;++o){i[o]=s,n[o]=o*this._stepSizeDays;for(let r=0;r<=e;++r)r!==o&&(i[o]*=o-r);i[o]=1/i[o]}this._work=new Array(e+1),this._coef=new Array(e+1)}function w0(t,e,i){let n=W9;return n.dayNumber=e,n.secondsOfDay=i,Ze.daysDifference(n,t._sampleZeroDateTT)}function x0(t,e){if(t._chunkDownloadsInProgress[e])return t._chunkDownloadsInProgress[e];let i,n=t._xysFileUrlTemplate;m(n)?i=n.getDerivedResource({templateValues:{0:e}}):i=new tn({url:th(`Assets/IAU2006_XYS/IAU2006_XYS_${e}.json`)});let s=i.fetchJson().then(function(o){t._chunkDownloadsInProgress[e]=!1;let r=t._samples,a=o.samples,h=e*t._samplesPerXysFile*3;for(let A=0,d=a.length;A<d;++A)r[h+A]=a[A]});return t._chunkDownloadsInProgress[e]=s,s}var W9,Q2,k2=O(()=>{PZ();bt();mt();y0();Vr();Ia();hZ();yZ();W9=new Ze(0,0,Ei.TAI);P0.prototype.preload=function(t,e,i,n){let s=w0(this,t,e),o=w0(this,i,n),r=s/this._stepSizeDays-this._interpolationOrder/2|0;r<0&&(r=0);let a=o/this._stepSizeDays-this._interpolationOrder/2|0+this._interpolationOrder;a>=this._totalSamples&&(a=this._totalSamples-1);let h=r/this._samplesPerXysFile|0,A=a/this._samplesPerXysFile|0,d=[];for(let f=h;f<=A;++f)d.push(x0(this,f));return Promise.all(d)};P0.prototype.computeXysRadians=function(t,e,i){let n=w0(this,t,e);if(n<0)return;let s=n/this._stepSizeDays|0;if(s>=this._totalSamples)return;let o=this._interpolationOrder,r=s-(o/2|0);r<0&&(r=0);let a=r+o;a>=this._totalSamples&&(a=this._totalSamples-1,r=a-o,r<0&&(r=0));let h=!1,A=this._samples;if(m(A[r*3])||(x0(this,r/this._samplesPerXysFile|0),h=!0),m(A[a*3])||(x0(this,a/this._samplesPerXysFile|0),h=!0),h)return;m(i)?(i.x=0,i.y=0,i.s=0):i=new JZ(0,0,0);let d=n-r*this._stepSizeDays,f=this._work,E=this._denominators,_=this._coef,R=this._xTable,I,C;for(I=0;I<=o;++I)f[I]=d-R[I];for(I=0;I<=o;++I){for(_[I]=1,C=0;C<=o;++C)C!==I&&(_[I]*=f[C]);_[I]*=E[I];let N=(r+I)*3;i.x+=_[I]*A[N++],i.y+=_[I]*A[N++],i.s+=_[I]*A[N]}return i};Q2=P0});var Ke,J0,Ym,j0,$o,ac,Ac,hc,D9,M9,U9,Q9,k9,L9,y9,L2,w9,x9,P9,J9,j9,H9,v9,z9,K9,X9,jZ,K0,q9,$9,t7,H0,v0,e7,i7,n7,s7,w2,x2,X0,o7,r7,q0,P2,a7,A7,h7,c7,l7,d7,m7,f7,z0,E7,_7,R7,iTt,y2,In,fr=O(()=>{Xe();Ht();Vs();ri();ae();bt();mt();Vt();l2();a0();Ve();V2();k2();y0();Vr();_e();dn();Fi();$s();AZ();ic();Ke={},J0={up:{south:"east",north:"west",west:"south",east:"north"},down:{south:"west",north:"east",west:"north",east:"south"},south:{up:"west",down:"east",west:"down",east:"up"},north:{up:"east",down:"west",west:"up",east:"down"},west:{up:"north",down:"south",north:"down",south:"up"},east:{up:"south",down:"north",north:"up",south:"down"}},Ym={north:[-1,0,0],east:[0,1,0],up:[0,0,1],south:[1,0,0],west:[0,-1,0],down:[0,0,-1]},j0={},$o={east:new l,north:new l,up:new l,west:new l,south:new l,down:new l},ac=new l,Ac=new l,hc=new l;Ke.localFrameToFixedFrameGenerator=function(t,e){if(!J0.hasOwnProperty(t)||!J0[t].hasOwnProperty(e))throw new Y("firstAxis and secondAxis must be east, north, up, west, south or down.");let i=J0[t][e],n,s=t+e;return m(j0[s])?n=j0[s]:(n=function(o,r,a){if(!m(o))throw new Y("origin is required.");if(isNaN(o.x)||isNaN(o.y)||isNaN(o.z))throw new Y("origin has a NaN component");if(m(a)||(a=new at),l.equalsEpsilon(o,l.ZERO,L.EPSILON14))l.unpack(Ym[t],0,ac),l.unpack(Ym[e],0,Ac),l.unpack(Ym[i],0,hc);else if(L.equalsEpsilon(o.x,0,L.EPSILON14)&&L.equalsEpsilon(o.y,0,L.EPSILON14)){let h=L.sign(o.z);l.unpack(Ym[t],0,ac),t!=="east"&&t!=="west"&&l.multiplyByScalar(ac,h,ac),l.unpack(Ym[e],0,Ac),e!=="east"&&e!=="west"&&l.multiplyByScalar(Ac,h,Ac),l.unpack(Ym[i],0,hc),i!=="east"&&i!=="west"&&l.multiplyByScalar(hc,h,hc)}else{r=Z(r,ot.WGS84),r.geodeticSurfaceNormal(o,$o.up);let h=$o.up,A=$o.east;A.x=-o.y,A.y=o.x,A.z=0,l.normalize(A,$o.east),l.cross(h,A,$o.north),l.multiplyByScalar($o.up,-1,$o.down),l.multiplyByScalar($o.east,-1,$o.west),l.multiplyByScalar($o.north,-1,$o.south),ac=$o[t],Ac=$o[e],hc=$o[i]}return a[0]=ac.x,a[1]=ac.y,a[2]=ac.z,a[3]=0,a[4]=Ac.x,a[5]=Ac.y,a[6]=Ac.z,a[7]=0,a[8]=hc.x,a[9]=hc.y,a[10]=hc.z,a[11]=0,a[12]=o.x,a[13]=o.y,a[14]=o.z,a[15]=1,a},j0[s]=n),n};Ke.eastNorthUpToFixedFrame=Ke.localFrameToFixedFrameGenerator("east","north");Ke.northEastDownToFixedFrame=Ke.localFrameToFixedFrameGenerator("north","east");Ke.northUpEastToFixedFrame=Ke.localFrameToFixedFrameGenerator("north","up");Ke.northWestUpToFixedFrame=Ke.localFrameToFixedFrameGenerator("north","west");D9=new Ae,M9=new l(1,1,1),U9=new at;Ke.headingPitchRollToFixedFrame=function(t,e,i,n,s){p.typeOf.object("HeadingPitchRoll",e),n=Z(n,Ke.eastNorthUpToFixedFrame);let o=Ae.fromHeadingPitchRoll(e,D9),r=at.fromTranslationQuaternionRotationScale(l.ZERO,o,M9,U9);return s=n(t,i,s),at.multiply(s,r,s)};Ke.localToFixedFrameQuaternion=function(t,e,i,n,s){if(!m(e))throw new Y("localQuaternion is required");n=Z(n,Ke.eastNorthUpToFixedFrame);let o=n(t,i),r=at.getMatrix3(o,new lt),a=Ae.fromRotationMatrix(r);return s=m(s)?s:new Ae,Ae.multiply(a,e,s)};Q9=new at,k9=new lt;Ke.headingPitchRollQuaternion=function(t,e,i,n,s){p.typeOf.object("HeadingPitchRoll",e);let o=Ke.headingPitchRollToFixedFrame(t,e,i,n,Q9),r=at.getMatrix3(o,k9);return Ae.fromRotationMatrix(r,s)};L9=new l(1,1,1),y9=new l,L2=new at,w9=new at,x9=new lt,P9=new Ae;Ke.fixedFrameToHeadingPitchRoll=function(t,e,i,n){p.defined("transform",t),e=Z(e,ot.WGS84),i=Z(i,Ke.eastNorthUpToFixedFrame),m(n)||(n=new ZE);let s=at.getTranslation(t,y9);if(l.equals(s,l.ZERO))return n.heading=0,n.pitch=0,n.roll=0,n;let o=at.inverseTransformation(i(s,e,L2),L2),r=at.setScale(t,L9,w9);r=at.setTranslation(r,l.ZERO,r),o=at.multiply(o,r,o);let a=Ae.fromRotationMatrix(at.getMatrix3(o,x9),P9);return a=Ae.normalize(a,a),ZE.fromQuaternion(a,n)};J9=6*3600+41*60+50.54841,j9=8640184812866e-6,H9=.093104,v9=-62e-7,z9=11772758384668e-32,K9=72921158553e-15,X9=L.TWO_PI/86400,jZ=new Ze;Ke.computeTemeToPseudoFixedMatrix=function(t,e){if(!m(t))throw new Y("date is required.");jZ=Ze.addSeconds(t,-Ze.computeTaiMinusUtc(t),jZ);let i=jZ.dayNumber,n=jZ.secondsOfDay,s,o=i-2451545;n>=43200?s=(o+.5)/bn.DAYS_PER_JULIAN_CENTURY:s=(o-.5)/bn.DAYS_PER_JULIAN_CENTURY;let a=(J9+s*(j9+s*(H9+s*v9)))*X9%L.TWO_PI,h=K9+z9*(i-24515455e-1),A=(n+bn.SECONDS_PER_DAY*.5)%bn.SECONDS_PER_DAY,d=a+h*A,f=Math.cos(d),E=Math.sin(d);return m(e)?(e[0]=f,e[1]=-E,e[2]=0,e[3]=E,e[4]=f,e[5]=0,e[6]=0,e[7]=0,e[8]=1,e):new lt(f,E,0,-E,f,0,0,0,1)};Ke.iau2006XysData=new Q2;Ke.earthOrientationParameters=c2.NONE;K0=32.184,q9=2451545;Ke.preloadIcrfFixed=function(t){let e=t.start.dayNumber,i=t.start.secondsOfDay+K0,n=t.stop.dayNumber,s=t.stop.secondsOfDay+K0;return Ke.iau2006XysData.preload(e,i,n,s)};Ke.computeIcrfToFixedMatrix=function(t,e){if(!m(t))throw new Y("date is required.");m(e)||(e=new lt);let i=Ke.computeFixedToIcrfMatrix(t,e);if(m(i))return lt.transpose(i,e)};$9=new JZ(0,0,0),t7=new oE(0,0,0,0,0,0),H0=new lt,v0=new lt;Ke.computeFixedToIcrfMatrix=function(t,e){if(!m(t))throw new Y("date is required.");m(e)||(e=new lt);let i=Ke.earthOrientationParameters.compute(t,t7);if(!m(i))return;let n=t.dayNumber,s=t.secondsOfDay+K0,o=Ke.iau2006XysData.computeXysRadians(n,s,$9);if(!m(o))return;let r=o.x+i.xPoleOffset,a=o.y+i.yPoleOffset,h=1/(1+Math.sqrt(1-r*r-a*a)),A=H0;A[0]=1-h*r*r,A[3]=-h*r*a,A[6]=r,A[1]=-h*r*a,A[4]=1-h*a*a,A[7]=a,A[2]=-r,A[5]=-a,A[8]=1-h*(r*r+a*a);let d=lt.fromRotationZ(-o.s,v0),f=lt.multiply(A,d,H0),E=t.dayNumber,_=t.secondsOfDay-Ze.computeTaiMinusUtc(t)+i.ut1MinusUtc,R=E-2451545,I=_/bn.SECONDS_PER_DAY,C=.779057273264+I+.00273781191135448*(R+I);C=C%1*L.TWO_PI;let N=lt.fromRotationZ(C,v0),T=lt.multiply(f,N,H0),F=Math.cos(i.xPoleWander),b=Math.cos(i.yPoleWander),G=Math.sin(i.xPoleWander),M=Math.sin(i.yPoleWander),Q=n-q9+s/bn.SECONDS_PER_DAY;Q/=36525;let U=-47e-6*Q*L.RADIANS_PER_DEGREE/3600,k=Math.cos(U),y=Math.sin(U),c=v0;return c[0]=F*k,c[1]=F*y,c[2]=G,c[3]=-b*y+M*G*k,c[4]=b*k+M*G*y,c[5]=-M*F,c[6]=-M*y-b*G*k,c[7]=M*k-b*G*y,c[8]=b*F,lt.multiply(T,c,e)};e7=new ie;Ke.pointToWindowCoordinates=function(t,e,i,n){return n=Ke.pointToGLWindowCoordinates(t,e,i,n),n.y=2*e[5]-n.y,n};Ke.pointToGLWindowCoordinates=function(t,e,i,n){if(!m(t))throw new Y("modelViewProjectionMatrix is required.");if(!m(e))throw new Y("viewportTransformation is required.");if(!m(i))throw new Y("point is required.");m(n)||(n=new nt);let s=e7;return at.multiplyByVector(t,ie.fromElements(i.x,i.y,i.z,1,s),s),ie.multiplyByScalar(s,1/s.w,s),at.multiplyByVector(e,s,s),nt.fromCartesian4(s,n)};i7=new l,n7=new l,s7=new l;Ke.rotationMatrixFromPositionVelocity=function(t,e,i,n){if(!m(t))throw new Y("position is required.");if(!m(e))throw new Y("velocity is required.");let s=Z(i,ot.WGS84).geodeticSurfaceNormal(t,i7),o=l.cross(e,s,n7);l.equalsEpsilon(o,l.ZERO,L.EPSILON6)&&(o=l.clone(l.UNIT_X,o));let r=l.cross(o,e,s7);return l.normalize(r,r),l.cross(e,r,o),l.negate(o,o),l.normalize(o,o),m(n)||(n=new lt),n[0]=e.x,n[1]=e.y,n[2]=e.z,n[3]=o.x,n[4]=o.y,n[5]=o.z,n[6]=r.x,n[7]=r.y,n[8]=r.z,n};w2=new at(0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1),x2=new ut,X0=new l,o7=new l,r7=new lt,q0=new at,P2=new at;Ke.basisTo2D=function(t,e,i){if(!m(t))throw new Y("projection is required.");if(!m(e))throw new Y("matrix is required.");if(!m(i))throw new Y("result is required.");let n=at.getTranslation(e,o7),s=t.ellipsoid,o;if(l.equals(n,l.ZERO))o=l.clone(l.ZERO,X0);else{let d=s.cartesianToCartographic(n,x2);o=t.project(d,X0),l.fromElements(o.z,o.x,o.y,o)}let r=Ke.eastNorthUpToFixedFrame(n,s,q0),a=at.inverseTransformation(r,P2),h=at.getMatrix3(e,r7),A=at.multiplyByMatrix3(a,h,i);return at.multiply(w2,A,i),at.setTranslation(i,o,i),i};Ke.wgs84To2DModelMatrix=function(t,e,i){if(!m(t))throw new Y("projection is required.");if(!m(e))throw new Y("center is required.");if(!m(i))throw new Y("result is required.");let n=t.ellipsoid,s=Ke.eastNorthUpToFixedFrame(e,n,q0),o=at.inverseTransformation(s,P2),r=n.cartesianToCartographic(e,x2),a=t.project(r,X0);l.fromElements(a.z,a.x,a.y,a);let h=at.fromTranslation(a,q0);return at.multiply(w2,o,i),at.multiply(h,i,i),i};a7=new l,A7=new l,h7=new l,c7=new l,l7=new l,d7=new l,m7=new l,f7=new l,z0=new Ze,E7=new lt,_7=new lt,R7=new lt;Ke.vvlhToFixed=function(t,e,i){let n=t.getValue(e,a7);Ze.addSeconds(e,.01,z0);let s=t.getValue(z0,A7),o=ot.WGS84,r=o.maximumRadius+1e5;if(m(i)||(i=new at),l.magnitude(n)<=r){let E=l.subtract(s,n,new l),_;if(l.magnitude(E)===0){let C=Ke.eastNorthUpToFixedFrame(n,o);_=new l(C[0],C[1],C[2])}else _=l.normalize(E,new l);let R=o.geodeticSurfaceNormal(n,new l),I=l.cross(R,_,new l);return i[0]=_.x,i[1]=_.y,i[2]=_.z,i[3]=0,i[4]=I.x,i[5]=I.y,i[6]=I.z,i[7]=0,i[8]=R.x,i[9]=R.y,i[10]=R.z,i[11]=0,i[12]=n.x,i[13]=n.y,i[14]=n.z,i[15]=1,i}let a=Ke.computeFixedToIcrfMatrix(e,E7);if(!a)return new at;let h=Ke.computeFixedToIcrfMatrix(z0,_7),A=lt.transpose(a,R7),d=lt.multiplyByVector(a,n,h7),f=lt.multiplyByVector(h,s,c7);if(!l.equalsEpsilon(d,f,L.EPSILON14)){let E=l.subtract(f,d,l7),_=d7;try{l.negate(l.normalize(d,_),_)}catch{console.log(d,_)}let R=l.cross(E,_,m7);l.negate(R,R);let I=l.cross(R,_,f7);try{lt.multiplyByVector(A,I,I),lt.multiplyByVector(A,R,R),lt.multiplyByVector(A,_,_),l.normalize(I,I),l.normalize(R,R),l.normalize(_,_),i[0]=I.x,i[1]=I.y,i[2]=I.z,i[3]=0,i[4]=R.x,i[5]=R.y,i[6]=R.z,i[7]=0,i[8]=_.x,i[9]=_.y,i[10]=_.z,i[11]=0,i[12]=n.x,i[13]=n.y,i[14]=n.z,i[15]=1}catch(C){return console.log(C,I,R,_,E,n,s,t),new Array(16).fill(0)}}return at.multiply(i,new at(1,0,0,0,0,-1,0,0,0,0,-1,0,0,0,0,1),i),i};Ke.reverseHeadingQuaternion=function(t){if(!m(t))throw new Y("orientation is required");let e=new ZE;ZE.fromQuaternion(t,e),e.heading=-e.heading,e.roll=-e.roll;let i=new Ae;return Ae.fromHeadingPitchRoll(e,i),i};iTt=new at(0,0,1,0,0,1,0,0,-1,0,0,0,0,0,0,1);Ke.getPositionInVVLH=function(t,e,i,n,s=$i.FIXED){let o=e.position.getValueInReferenceFrame(i,s.FIXED),r=t.position.getValueInReferenceFrame(n,s.FIXED),a;try{a=at.inverse(Ke.vvlhToFixed(t.position,i),new at)}catch{a=new at}let h=at.multiplyByPoint(a,o,new l),A=at.getRotation(Ke.vvlhToFixed(t.position,n),new lt),d=lt.multiplyByVector(A,h,new l),f=l.add(r,d,new l);if(s===$i.INERTIAL){let E=Ke.computeFixedToIcrfMatrix(n);E&&(f=lt.multiplyByVector(E,f,new l))}return f};y2=Ke.localFrameToFixedFrameGenerator("north","west");Ke.getTransformToFixedFrame=function(t,e,i){let n,s={[$i.FIXED]:()=>at.IDENTITY,[$i.INERTIAL]:()=>{if(!m(e))throw new Y("Conversion from INERTIAL to FIXED requires a time.");return Ke.computeIcrfToFixedMatrix(e)},[$i.TEME]:()=>{throw new Y("Conversion from TEME to FIXED is not implemented.")},[$i.VVLH]:()=>{if(!m(e)||!m(i))throw new Y("Conversion from VVLH to FIXED requires both time and position.");let o=Ke.vvlhToFixed(i,e),r=at.fromScale(new l(1,-1,-1));return at.multiply(o,r,new at)},[$i.NED]:()=>{if(!m(e)||!m(i))throw new Y("Conversion from NED to FIXED requires both time and position.");let o=y2(i.getValue(e)),r=at.fromScale(new l(1,-1,-1));return at.multiply(o,r,new at)},[$i.NEU]:()=>{if(!m(e)||!m(i))throw new Y("Conversion from NEU to FIXED requires both time and position.");let o=y2(i.getValue(e)),r=at.fromScale(new l(1,-1,1));return at.multiply(o,r,new at)},[$i.RIC]:()=>{if(!m(e)||!m(i))throw new Y("Conversion from RIC to FIXED requires both time and position.");let o=Ke.vvlhToFixed(i,e),r=at.fromArray([0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1]);return at.multiply(o,r,new at)}};return s.hasOwnProperty(t)?n=s[t]:n=Ke.eastNorthUpToFixedFrame,n};In=Ke});function Je(t,e,i,n){this.west=Z(t,0),this.south=Z(e,0),this.east=Z(i,0),this.north=Z(n,0)}var Z7,I7,p7,u7,C7,$0,g7,Xt,pn=O(()=>{Ht();ri();ae();bt();mt();Ve();_e();fr();Fi();Object.defineProperties(Je.prototype,{width:{get:function(){return Je.computeWidth(this)}},height:{get:function(){return Je.computeHeight(this)}}});Je.packedLength=4;Je.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.west,e[i++]=t.south,e[i++]=t.east,e[i]=t.north,e};Je.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Je),i.west=t[e++],i.south=t[e++],i.east=t[e++],i.north=t[e],i};Je.computeWidth=function(t){p.typeOf.object("rectangle",t);let e=t.east,i=t.west;return e<i&&(e+=L.TWO_PI),e-i};Je.computeHeight=function(t){return p.typeOf.object("rectangle",t),t.north-t.south};Je.fromDegrees=function(t,e,i,n,s){return t=L.toRadians(Z(t,0)),e=L.toRadians(Z(e,0)),i=L.toRadians(Z(i,0)),n=L.toRadians(Z(n,0)),m(s)?(s.west=t,s.south=e,s.east=i,s.north=n,s):new Je(t,e,i,n)};Je.fromRadians=function(t,e,i,n,s){return m(s)?(s.west=Z(t,0),s.south=Z(e,0),s.east=Z(i,0),s.north=Z(n,0),s):new Je(t,e,i,n)};Je.fromCartographicArray=function(t,e){p.defined("cartographics",t);let i=Number.MAX_VALUE,n=-Number.MAX_VALUE,s=Number.MAX_VALUE,o=-Number.MAX_VALUE,r=Number.MAX_VALUE,a=-Number.MAX_VALUE;for(let h=0,A=t.length;h<A;h++){let d=t[h];i=Math.min(i,d.longitude),n=Math.max(n,d.longitude),r=Math.min(r,d.latitude),a=Math.max(a,d.latitude);let f=d.longitude>=0?d.longitude:d.longitude+L.TWO_PI;s=Math.min(s,f),o=Math.max(o,f)}return n-i>o-s&&(i=s,n=o,n>L.PI&&(n=n-L.TWO_PI),i>L.PI&&(i=i-L.TWO_PI)),m(e)?(e.west=i,e.south=r,e.east=n,e.north=a,e):new Je(i,r,n,a)};Je.fromCartesianArray=function(t,e,i){p.defined("cartesians",t),e=Z(e,ot.WGS84);let n=Number.MAX_VALUE,s=-Number.MAX_VALUE,o=Number.MAX_VALUE,r=-Number.MAX_VALUE,a=Number.MAX_VALUE,h=-Number.MAX_VALUE;for(let A=0,d=t.length;A<d;A++){let f=e.cartesianToCartographic(t[A]);n=Math.min(n,f.longitude),s=Math.max(s,f.longitude),a=Math.min(a,f.latitude),h=Math.max(h,f.latitude);let E=f.longitude>=0?f.longitude:f.longitude+L.TWO_PI;o=Math.min(o,E),r=Math.max(r,E)}return s-n>r-o&&(n=o,s=r,s>L.PI&&(s=s-L.TWO_PI),n>L.PI&&(n=n-L.TWO_PI)),m(i)?(i.west=n,i.south=a,i.east=s,i.north=h,i):new Je(n,a,s,h)};Z7=new l,I7=new l,p7=new l,u7=new l,C7=new l,$0=new Array(5);for(let t=0;t<$0.length;++t)$0[t]=new l;Je.fromBoundingSphere=function(t,e,i){p.typeOf.object("boundingSphere",t);let n=t.center,s=t.radius;if(m(e)||(e=ot.WGS84),m(i)||(i=new Je),l.equals(n,l.ZERO))return Je.clone(Je.MAX_VALUE,i),i;let o=In.eastNorthUpToFixedFrame(n,e,Z7),r=at.multiplyByPointAsVector(o,l.UNIT_X,I7);l.normalize(r,r);let a=at.multiplyByPointAsVector(o,l.UNIT_Y,p7);l.normalize(a,a),l.multiplyByScalar(a,s,a),l.multiplyByScalar(r,s,r);let h=l.negate(a,C7),A=l.negate(r,u7),d=$0,f=d[0];return l.add(n,a,f),f=d[1],l.add(n,A,f),f=d[2],l.add(n,h,f),f=d[3],l.add(n,r,f),d[4]=n,Je.fromCartesianArray(d,e,i)};Je.clone=function(t,e){if(m(t))return m(e)?(e.west=t.west,e.south=t.south,e.east=t.east,e.north=t.north,e):new Je(t.west,t.south,t.east,t.north)};Je.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t.west-e.west)<=i&&Math.abs(t.south-e.south)<=i&&Math.abs(t.east-e.east)<=i&&Math.abs(t.north-e.north)<=i};Je.prototype.clone=function(t){return Je.clone(this,t)};Je.prototype.equals=function(t){return Je.equals(this,t)};Je.equals=function(t,e){return t===e||m(t)&&m(e)&&t.west===e.west&&t.south===e.south&&t.east===e.east&&t.north===e.north};Je.prototype.equalsEpsilon=function(t,e){return Je.equalsEpsilon(this,t,e)};Je.validate=function(t){p.typeOf.object("rectangle",t);let e=t.north;p.typeOf.number.greaterThanOrEquals("north",e,-L.PI_OVER_TWO),p.typeOf.number.lessThanOrEquals("north",e,L.PI_OVER_TWO);let i=t.south;p.typeOf.number.greaterThanOrEquals("south",i,-L.PI_OVER_TWO),p.typeOf.number.lessThanOrEquals("south",i,L.PI_OVER_TWO);let n=t.west;p.typeOf.number.greaterThanOrEquals("west",n,-Math.PI),p.typeOf.number.lessThanOrEquals("west",n,Math.PI);let s=t.east;p.typeOf.number.greaterThanOrEquals("east",s,-Math.PI),p.typeOf.number.lessThanOrEquals("east",s,Math.PI)};Je.southwest=function(t,e){return p.typeOf.object("rectangle",t),m(e)?(e.longitude=t.west,e.latitude=t.south,e.height=0,e):new ut(t.west,t.south)};Je.northwest=function(t,e){return p.typeOf.object("rectangle",t),m(e)?(e.longitude=t.west,e.latitude=t.north,e.height=0,e):new ut(t.west,t.north)};Je.northeast=function(t,e){return p.typeOf.object("rectangle",t),m(e)?(e.longitude=t.east,e.latitude=t.north,e.height=0,e):new ut(t.east,t.north)};Je.southeast=function(t,e){return p.typeOf.object("rectangle",t),m(e)?(e.longitude=t.east,e.latitude=t.south,e.height=0,e):new ut(t.east,t.south)};Je.center=function(t,e){p.typeOf.object("rectangle",t);let i=t.east,n=t.west;i<n&&(i+=L.TWO_PI);let s=L.negativePiToPi((n+i)*.5),o=(t.south+t.north)*.5;return m(e)?(e.longitude=s,e.latitude=o,e.height=0,e):new ut(s,o)};Je.intersection=function(t,e,i){p.typeOf.object("rectangle",t),p.typeOf.object("otherRectangle",e);let n=t.east,s=t.west,o=e.east,r=e.west;n<s&&o>0?n+=L.TWO_PI:o<r&&n>0&&(o+=L.TWO_PI),n<s&&r<0?r+=L.TWO_PI:o<r&&s<0&&(s+=L.TWO_PI);let a=L.negativePiToPi(Math.max(s,r)),h=L.negativePiToPi(Math.min(n,o));if((t.west<t.east||e.west<e.east)&&h<=a)return;let A=Math.max(t.south,e.south),d=Math.min(t.north,e.north);if(!(A>=d))return m(i)?(i.west=a,i.south=A,i.east=h,i.north=d,i):new Je(a,A,h,d)};Je.simpleIntersection=function(t,e,i){p.typeOf.object("rectangle",t),p.typeOf.object("otherRectangle",e);let n=Math.max(t.west,e.west),s=Math.max(t.south,e.south),o=Math.min(t.east,e.east),r=Math.min(t.north,e.north);if(!(s>=r||n>=o))return m(i)?(i.west=n,i.south=s,i.east=o,i.north=r,i):new Je(n,s,o,r)};Je.union=function(t,e,i){p.typeOf.object("rectangle",t),p.typeOf.object("otherRectangle",e),m(i)||(i=new Je);let n=t.east,s=t.west,o=e.east,r=e.west;n<s&&o>0?n+=L.TWO_PI:o<r&&n>0&&(o+=L.TWO_PI),n<s&&r<0?r+=L.TWO_PI:o<r&&s<0&&(s+=L.TWO_PI);let a=L.negativePiToPi(Math.min(s,r)),h=L.negativePiToPi(Math.max(n,o));return i.west=a,i.south=Math.min(t.south,e.south),i.east=h,i.north=Math.max(t.north,e.north),i};Je.expand=function(t,e,i){return p.typeOf.object("rectangle",t),p.typeOf.object("cartographic",e),m(i)||(i=new Je),i.west=Math.min(t.west,e.longitude),i.south=Math.min(t.south,e.latitude),i.east=Math.max(t.east,e.longitude),i.north=Math.max(t.north,e.latitude),i};Je.contains=function(t,e){p.typeOf.object("rectangle",t),p.typeOf.object("cartographic",e);let i=e.longitude,n=e.latitude,s=t.west,o=t.east;return o<s&&(o+=L.TWO_PI,i<0&&(i+=L.TWO_PI)),(i>s||L.equalsEpsilon(i,s,L.EPSILON14))&&(i<o||L.equalsEpsilon(i,o,L.EPSILON14))&&n>=t.south&&n<=t.north};g7=new ut;Je.subsample=function(t,e,i,n){p.typeOf.object("rectangle",t),e=Z(e,ot.WGS84),i=Z(i,0),m(n)||(n=[]);let s=0,o=t.north,r=t.south,a=t.east,h=t.west,A=g7;A.height=i,A.longitude=h,A.latitude=o,n[s]=e.cartographicToCartesian(A,n[s]),s++,A.longitude=a,n[s]=e.cartographicToCartesian(A,n[s]),s++,A.latitude=r,n[s]=e.cartographicToCartesian(A,n[s]),s++,A.longitude=h,n[s]=e.cartographicToCartesian(A,n[s]),s++,o<0?A.latitude=o:r>0?A.latitude=r:A.latitude=0;for(let d=1;d<8;++d)A.longitude=-Math.PI+d*L.PI_OVER_TWO,Je.contains(t,A)&&(n[s]=e.cartographicToCartesian(A,n[s]),s++);return A.latitude===0&&(A.longitude=h,n[s]=e.cartographicToCartesian(A,n[s]),s++,A.longitude=a,n[s]=e.cartographicToCartesian(A,n[s]),s++),n.length=s,n};Je.subsection=function(t,e,i,n,s,o){if(p.typeOf.object("rectangle",t),p.typeOf.number.greaterThanOrEquals("westLerp",e,0),p.typeOf.number.lessThanOrEquals("westLerp",e,1),p.typeOf.number.greaterThanOrEquals("southLerp",i,0),p.typeOf.number.lessThanOrEquals("southLerp",i,1),p.typeOf.number.greaterThanOrEquals("eastLerp",n,0),p.typeOf.number.lessThanOrEquals("eastLerp",n,1),p.typeOf.number.greaterThanOrEquals("northLerp",s,0),p.typeOf.number.lessThanOrEquals("northLerp",s,1),p.typeOf.number.lessThanOrEquals("westLerp",e,n),p.typeOf.number.lessThanOrEquals("southLerp",i,s),m(o)||(o=new Je),t.west<=t.east){let a=t.east-t.west;o.west=t.west+e*a,o.east=t.west+n*a}else{let a=L.TWO_PI+t.east-t.west;o.west=L.negativePiToPi(t.west+e*a),o.east=L.negativePiToPi(t.west+n*a)}let r=t.north-t.south;return o.south=t.south+i*r,o.north=t.south+s*r,e===1&&(o.west=t.east),n===1&&(o.east=t.east),i===1&&(o.south=t.north),s===1&&(o.north=t.north),o};Je.MAX_VALUE=Object.freeze(new Je(-Math.PI,-L.PI_OVER_TWO,Math.PI,L.PI_OVER_TWO));Xt=Je});function ns(t,e,i,n){this.x=Z(t,0),this.y=Z(e,0),this.width=Z(i,0),this.height=Z(n,0)}var T7,N7,b7,mi,Er=O(()=>{Xe();ri();ae();bt();mt();zA();nc();pn();ns.packedLength=4;ns.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.x,e[i++]=t.y,e[i++]=t.width,e[i]=t.height,e};ns.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new ns),i.x=t[e++],i.y=t[e++],i.width=t[e++],i.height=t[e],i};ns.fromPoints=function(t,e){if(m(e)||(e=new ns),!m(t)||t.length===0)return e.x=0,e.y=0,e.width=0,e.height=0,e;let i=t.length,n=t[0].x,s=t[0].y,o=t[0].x,r=t[0].y;for(let a=1;a<i;a++){let h=t[a],A=h.x,d=h.y;n=Math.min(A,n),o=Math.max(A,o),s=Math.min(d,s),r=Math.max(d,r)}return e.x=n,e.y=s,e.width=o-n,e.height=r-s,e};T7=new Os,N7=new ut,b7=new ut;ns.fromRectangle=function(t,e,i){if(m(i)||(i=new ns),!m(t))return i.x=0,i.y=0,i.width=0,i.height=0,i;e=Z(e,T7);let n=e.project(Xt.southwest(t,N7)),s=e.project(Xt.northeast(t,b7));return nt.subtract(s,n,s),i.x=n.x,i.y=n.y,i.width=s.x,i.height=s.y,i};ns.clone=function(t,e){if(m(t))return m(e)?(e.x=t.x,e.y=t.y,e.width=t.width,e.height=t.height,e):new ns(t.x,t.y,t.width,t.height)};ns.union=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),m(i)||(i=new ns);let n=Math.min(t.x,e.x),s=Math.min(t.y,e.y),o=Math.max(t.x+t.width,e.x+e.width),r=Math.max(t.y+t.height,e.y+e.height);return i.x=n,i.y=s,i.width=o-n,i.height=r-s,i};ns.expand=function(t,e,i){p.typeOf.object("rectangle",t),p.typeOf.object("point",e),i=ns.clone(t,i);let n=e.x-i.x,s=e.y-i.y;return n>i.width?i.width=n:n<0&&(i.width-=n,i.x=e.x),s>i.height?i.height=s:s<0&&(i.height-=s,i.y=e.y),i};ns.intersect=function(t,e){p.typeOf.object("left",t),p.typeOf.object("right",e);let i=t.x,n=t.y,s=e.x,o=e.y;return i>s+e.width||i+t.width<s||n+t.height<o||n>o+e.height?Nn.OUTSIDE:Nn.INTERSECTING};ns.equals=function(t,e){return t===e||m(t)&&m(e)&&t.x===e.x&&t.y===e.y&&t.width===e.width&&t.height===e.height};ns.prototype.clone=function(t){return ns.clone(this,t)};ns.prototype.intersect=function(t){return ns.intersect(this,t)};ns.prototype.equals=function(t){return ns.equals(this,t)};mi=ns});function F7(t,e){this.start=Z(t,0),this.stop=Z(e,0)}var cA,HZ=O(()=>{bt();cA=F7});function Le(t,e){this.center=l.clone(Z(t,l.ZERO)),this.radius=Z(e,0)}var iT,nT,sT,oT,rT,aT,AT,Js,hT,cT,lT,dT,Y7,S7,O7,V7,tT,eT,G7,B7,W7,D7,M7,U7,Q7,k7,L7,y7,w7,x7,J2,P7,J7,j7,H7,v7,j2,z7,Nt,_i=O(()=>{Ht();ri();ae();bt();mt();Ve();zA();nc();HZ();_e();dn();Fi();pn();iT=new l,nT=new l,sT=new l,oT=new l,rT=new l,aT=new l,AT=new l,Js=new l,hT=new l,cT=new l,lT=new l,dT=new l,Y7=4/3*L.PI;Le.fromPoints=function(t,e){if(m(e)||(e=new Le),!m(t)||t.length===0)return e.center=l.clone(l.ZERO,e.center),e.radius=0,e;let i=l.clone(t[0],AT),n=l.clone(i,iT),s=l.clone(i,nT),o=l.clone(i,sT),r=l.clone(i,oT),a=l.clone(i,rT),h=l.clone(i,aT),A=t.length,d;for(d=1;d<A;d++){l.clone(t[d],i);let U=i.x,k=i.y,y=i.z;U<n.x&&l.clone(i,n),U>r.x&&l.clone(i,r),k<s.y&&l.clone(i,s),k>a.y&&l.clone(i,a),y<o.z&&l.clone(i,o),y>h.z&&l.clone(i,h)}let f=l.magnitudeSquared(l.subtract(r,n,Js)),E=l.magnitudeSquared(l.subtract(a,s,Js)),_=l.magnitudeSquared(l.subtract(h,o,Js)),R=n,I=r,C=f;E>C&&(C=E,R=s,I=a),_>C&&(C=_,R=o,I=h);let N=hT;N.x=(R.x+I.x)*.5,N.y=(R.y+I.y)*.5,N.z=(R.z+I.z)*.5;let T=l.magnitudeSquared(l.subtract(I,N,Js)),F=Math.sqrt(T),b=cT;b.x=n.x,b.y=s.y,b.z=o.z;let G=lT;G.x=r.x,G.y=a.y,G.z=h.z;let M=l.midpoint(b,G,dT),Q=0;for(d=0;d<A;d++){l.clone(t[d],i);let U=l.magnitude(l.subtract(i,M,Js));U>Q&&(Q=U);let k=l.magnitudeSquared(l.subtract(i,N,Js));if(k>T){let y=Math.sqrt(k);F=(F+y)*.5,T=F*F;let c=y-F;N.x=(F*N.x+c*i.x)/y,N.y=(F*N.y+c*i.y)/y,N.z=(F*N.z+c*i.z)/y}}return F<Q?(l.clone(N,e.center),e.radius=F):(l.clone(M,e.center),e.radius=Q),e};S7=new Os,O7=new l,V7=new l,tT=new ut,eT=new ut;Le.fromRectangle2D=function(t,e,i){return Le.fromRectangleWithHeights2D(t,e,0,0,i)};Le.fromRectangleWithHeights2D=function(t,e,i,n,s){if(m(s)||(s=new Le),!m(t))return s.center=l.clone(l.ZERO,s.center),s.radius=0,s;e=Z(e,S7),Xt.southwest(t,tT),tT.height=i,Xt.northeast(t,eT),eT.height=n;let o=e.project(tT,O7),r=e.project(eT,V7),a=r.x-o.x,h=r.y-o.y,A=r.z-o.z;s.radius=Math.sqrt(a*a+h*h+A*A)*.5;let d=s.center;return d.x=o.x+a*.5,d.y=o.y+h*.5,d.z=o.z+A*.5,s};G7=[];Le.fromRectangle3D=function(t,e,i,n){if(e=Z(e,ot.WGS84),i=Z(i,0),m(n)||(n=new Le),!m(t))return n.center=l.clone(l.ZERO,n.center),n.radius=0,n;let s=Xt.subsample(t,e,i,G7);return Le.fromPoints(s,n)};Le.fromVertices=function(t,e,i,n){if(m(n)||(n=new Le),!m(t)||t.length===0)return n.center=l.clone(l.ZERO,n.center),n.radius=0,n;e=Z(e,l.ZERO),i=Z(i,3),p.typeOf.number.greaterThanOrEquals("stride",i,3);let s=AT;s.x=t[0]+e.x,s.y=t[1]+e.y,s.z=t[2]+e.z;let o=l.clone(s,iT),r=l.clone(s,nT),a=l.clone(s,sT),h=l.clone(s,oT),A=l.clone(s,rT),d=l.clone(s,aT),f=t.length,E;for(E=0;E<f;E+=i){let y=t[E]+e.x,c=t[E+1]+e.y,g=t[E+2]+e.z;s.x=y,s.y=c,s.z=g,y<o.x&&l.clone(s,o),y>h.x&&l.clone(s,h),c<r.y&&l.clone(s,r),c>A.y&&l.clone(s,A),g<a.z&&l.clone(s,a),g>d.z&&l.clone(s,d)}let _=l.magnitudeSquared(l.subtract(h,o,Js)),R=l.magnitudeSquared(l.subtract(A,r,Js)),I=l.magnitudeSquared(l.subtract(d,a,Js)),C=o,N=h,T=_;R>T&&(T=R,C=r,N=A),I>T&&(T=I,C=a,N=d);let F=hT;F.x=(C.x+N.x)*.5,F.y=(C.y+N.y)*.5,F.z=(C.z+N.z)*.5;let b=l.magnitudeSquared(l.subtract(N,F,Js)),G=Math.sqrt(b),M=cT;M.x=o.x,M.y=r.y,M.z=a.z;let Q=lT;Q.x=h.x,Q.y=A.y,Q.z=d.z;let U=l.midpoint(M,Q,dT),k=0;for(E=0;E<f;E+=i){s.x=t[E]+e.x,s.y=t[E+1]+e.y,s.z=t[E+2]+e.z;let y=l.magnitude(l.subtract(s,U,Js));y>k&&(k=y);let c=l.magnitudeSquared(l.subtract(s,F,Js));if(c>b){let g=Math.sqrt(c);G=(G+g)*.5,b=G*G;let V=g-G;F.x=(G*F.x+V*s.x)/g,F.y=(G*F.y+V*s.y)/g,F.z=(G*F.z+V*s.z)/g}}return G<k?(l.clone(F,n.center),n.radius=G):(l.clone(U,n.center),n.radius=k),n};Le.fromEncodedCartesianVertices=function(t,e,i){if(m(i)||(i=new Le),!m(t)||!m(e)||t.length!==e.length||t.length===0)return i.center=l.clone(l.ZERO,i.center),i.radius=0,i;let n=AT;n.x=t[0]+e[0],n.y=t[1]+e[1],n.z=t[2]+e[2];let s=l.clone(n,iT),o=l.clone(n,nT),r=l.clone(n,sT),a=l.clone(n,oT),h=l.clone(n,rT),A=l.clone(n,aT),d=t.length,f;for(f=0;f<d;f+=3){let k=t[f]+e[f],y=t[f+1]+e[f+1],c=t[f+2]+e[f+2];n.x=k,n.y=y,n.z=c,k<s.x&&l.clone(n,s),k>a.x&&l.clone(n,a),y<o.y&&l.clone(n,o),y>h.y&&l.clone(n,h),c<r.z&&l.clone(n,r),c>A.z&&l.clone(n,A)}let E=l.magnitudeSquared(l.subtract(a,s,Js)),_=l.magnitudeSquared(l.subtract(h,o,Js)),R=l.magnitudeSquared(l.subtract(A,r,Js)),I=s,C=a,N=E;_>N&&(N=_,I=o,C=h),R>N&&(N=R,I=r,C=A);let T=hT;T.x=(I.x+C.x)*.5,T.y=(I.y+C.y)*.5,T.z=(I.z+C.z)*.5;let F=l.magnitudeSquared(l.subtract(C,T,Js)),b=Math.sqrt(F),G=cT;G.x=s.x,G.y=o.y,G.z=r.z;let M=lT;M.x=a.x,M.y=h.y,M.z=A.z;let Q=l.midpoint(G,M,dT),U=0;for(f=0;f<d;f+=3){n.x=t[f]+e[f],n.y=t[f+1]+e[f+1],n.z=t[f+2]+e[f+2];let k=l.magnitude(l.subtract(n,Q,Js));k>U&&(U=k);let y=l.magnitudeSquared(l.subtract(n,T,Js));if(y>F){let c=Math.sqrt(y);b=(b+c)*.5,F=b*b;let g=c-b;T.x=(b*T.x+g*n.x)/c,T.y=(b*T.y+g*n.y)/c,T.z=(b*T.z+g*n.z)/c}}return b<U?(l.clone(T,i.center),i.radius=b):(l.clone(Q,i.center),i.radius=U),i};Le.fromCornerPoints=function(t,e,i){p.typeOf.object("corner",t),p.typeOf.object("oppositeCorner",e),m(i)||(i=new Le);let n=l.midpoint(t,e,i.center);return i.radius=l.distance(n,e),i};Le.fromEllipsoid=function(t,e){return p.typeOf.object("ellipsoid",t),m(e)||(e=new Le),l.clone(l.ZERO,e.center),e.radius=t.maximumRadius,e};B7=new l;Le.fromBoundingSpheres=function(t,e){if(m(e)||(e=new Le),!m(t)||t.length===0)return e.center=l.clone(l.ZERO,e.center),e.radius=0,e;let i=t.length;if(i===1)return Le.clone(t[0],e);if(i===2)return Le.union(t[0],t[1],e);let n=[],s;for(s=0;s<i;s++)n.push(t[s].center);e=Le.fromPoints(n,e);let o=e.center,r=e.radius;for(s=0;s<i;s++){let a=t[s];r=Math.max(r,l.distance(o,a.center,B7)+a.radius)}return e.radius=r,e};W7=new l,D7=new l,M7=new l;Le.fromOrientedBoundingBox=function(t,e){p.defined("orientedBoundingBox",t),m(e)||(e=new Le);let i=t.halfAxes,n=lt.getColumn(i,0,W7),s=lt.getColumn(i,1,D7),o=lt.getColumn(i,2,M7);return l.add(n,s,n),l.add(n,o,n),e.center=l.clone(t.center,e.center),e.radius=l.magnitude(n),e};U7=new l,Q7=new l;Le.fromTransformation=function(t,e){p.typeOf.object("transformation",t),m(e)||(e=new Le);let i=at.getTranslation(t,U7),n=at.getScale(t,Q7),s=.5*l.magnitude(n);return e.center=l.clone(i,e.center),e.radius=s,e};Le.clone=function(t,e){if(m(t))return m(e)?(e.center=l.clone(t.center,e.center),e.radius=t.radius,e):new Le(t.center,t.radius)};Le.packedLength=4;Le.pack=function(t,e,i){p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0);let n=t.center;return e[i++]=n.x,e[i++]=n.y,e[i++]=n.z,e[i]=t.radius,e};Le.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0),m(i)||(i=new Le);let n=i.center;return n.x=t[e++],n.y=t[e++],n.z=t[e++],i.radius=t[e],i};k7=new l,L7=new l;Le.union=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),m(i)||(i=new Le);let n=t.center,s=t.radius,o=e.center,r=e.radius,a=l.subtract(o,n,k7),h=l.magnitude(a);if(s>=h+r)return t.clone(i),i;if(r>=h+s)return e.clone(i),i;let A=(s+h+r)*.5,d=l.multiplyByScalar(a,(-s+A)/h,L7);return l.add(d,n,d),l.clone(d,i.center),i.radius=A,i};y7=new l;Le.expand=function(t,e,i){p.typeOf.object("sphere",t),p.typeOf.object("point",e),i=Le.clone(t,i);let n=l.magnitude(l.subtract(e,i.center,y7));return n>i.radius&&(i.radius=n),i};Le.intersectPlane=function(t,e){p.typeOf.object("sphere",t),p.typeOf.object("plane",e);let i=t.center,n=t.radius,s=e.normal,o=l.dot(s,i)+e.distance;return o<-n?Nn.OUTSIDE:o<n?Nn.INTERSECTING:Nn.INSIDE};Le.transform=function(t,e,i){return p.typeOf.object("sphere",t),p.typeOf.object("transform",e),m(i)||(i=new Le),i.center=at.multiplyByPoint(e,t.center,i.center),i.radius=at.getMaximumScale(e)*t.radius,i};w7=new l;Le.distanceSquaredTo=function(t,e){p.typeOf.object("sphere",t),p.typeOf.object("cartesian",e);let i=l.subtract(t.center,e,w7),n=l.magnitude(i)-t.radius;return n<=0?0:n*n};Le.transformWithoutScale=function(t,e,i){return p.typeOf.object("sphere",t),p.typeOf.object("transform",e),m(i)||(i=new Le),i.center=at.multiplyByPoint(e,t.center,i.center),i.radius=t.radius,i};x7=new l;Le.computePlaneDistances=function(t,e,i,n){p.typeOf.object("sphere",t),p.typeOf.object("position",e),p.typeOf.object("direction",i),m(n)||(n=new cA);let s=l.subtract(t.center,e,x7),o=l.dot(i,s);return n.start=o-t.radius,n.stop=o+t.radius,n};J2=new l,P7=new l,J7=new l,j7=new l,H7=new l,v7=new ut,j2=new Array(8);for(let t=0;t<8;++t)j2[t]=new l;z7=new Os;Le.projectTo2D=function(t,e,i){p.typeOf.object("sphere",t),e=Z(e,z7);let n=e.ellipsoid,s=t.center,o=t.radius,r;l.equals(s,l.ZERO)?r=l.clone(l.UNIT_X,J2):r=n.geodeticSurfaceNormal(s,J2);let a=l.cross(l.UNIT_Z,r,P7);l.normalize(a,a);let h=l.cross(r,a,J7);l.normalize(h,h),l.multiplyByScalar(r,o,r),l.multiplyByScalar(h,o,h),l.multiplyByScalar(a,o,a);let A=l.negate(h,H7),d=l.negate(a,j7),f=j2,E=f[0];l.add(r,h,E),l.add(E,a,E),E=f[1],l.add(r,h,E),l.add(E,d,E),E=f[2],l.add(r,A,E),l.add(E,d,E),E=f[3],l.add(r,A,E),l.add(E,a,E),l.negate(r,r),E=f[4],l.add(r,h,E),l.add(E,a,E),E=f[5],l.add(r,h,E),l.add(E,d,E),E=f[6],l.add(r,A,E),l.add(E,d,E),E=f[7],l.add(r,A,E),l.add(E,a,E);let _=f.length;for(let N=0;N<_;++N){let T=f[N];l.add(s,T,T);let F=n.cartesianToCartographic(T,v7);e.project(F,T)}i=Le.fromPoints(f,i),s=i.center;let R=s.x,I=s.y,C=s.z;return s.x=C,s.y=R,s.z=I,i};Le.isOccluded=function(t,e){return p.typeOf.object("sphere",t),p.typeOf.object("occluder",e),!e.isBoundingSphereVisible(t)};Le.equals=function(t,e){return t===e||m(t)&&m(e)&&l.equals(t.center,e.center)&&t.radius===e.radius};Le.prototype.intersectPlane=function(t){return Le.intersectPlane(this,t)};Le.prototype.distanceSquaredTo=function(t){return Le.distanceSquaredTo(this,t)};Le.prototype.computePlaneDistances=function(t,e,i){return Le.computePlaneDistances(this,t,e,i)};Le.prototype.isOccluded=function(t){return Le.isOccluded(this,t)};Le.prototype.equals=function(t){return Le.equals(this,t)};Le.prototype.clone=function(t){return Le.clone(this,t)};Le.prototype.volume=function(){let t=this.radius;return Y7*t*t*t};Nt=Le});function lA(t,e){p.typeOf.object("ellipsoid",t),this._ellipsoid=t,this._cameraPosition=new l,this._cameraPositionInScaledSpace=new l,this._distanceToLimbInScaledSpaceSquared=0,m(e)&&(this.cameraPosition=e)}function z2(t,e,i){if(m(e)&&e<0&&t.minimumRadius>-e){let n=l.fromElements(t.radii.x+e,t.radii.y+e,t.radii.z+e,q7);t=ot.fromCartesian3(n,i)}return t}function K2(t,e,i,n){p.typeOf.object("directionToPoint",e),p.defined("positions",i),m(n)||(n=new l);let s=tD(t,e),o=0;for(let r=0,a=i.length;r<a;++r){let h=i[r],A=q2(t,h,s);if(A<0)return;o=Math.max(o,A)}return $2(s,o,n)}function X2(t,e,i,n,s,o){p.typeOf.object("directionToPoint",e),p.defined("vertices",i),p.typeOf.number("stride",n),m(o)||(o=new l),n=Z(n,3),s=Z(s,l.ZERO);let r=tD(t,e),a=0;for(let h=0,A=i.length;h<A;h+=n){vZ.x=i[h]+s.x,vZ.y=i[h+1]+s.y,vZ.z=i[h+2]+s.z;let d=q2(t,vZ,r);if(d<0)return;a=Math.max(a,d)}return $2(r,a,o)}function fT(t,e,i){let n=e,s=i,o=l.subtract(t,n,H2),r=-l.dot(o,n);return!(s<0?r>0:r>s&&r*r/l.magnitudeSquared(o)>s)}function q2(t,e,i){let n=t.transformPositionToScaledSpace(e,$7),s=l.magnitudeSquared(n),o=Math.sqrt(s),r=l.divideByScalar(n,o,t$);s=Math.max(1,s),o=Math.max(1,o);let a=l.dot(r,i),h=l.magnitude(l.cross(r,i,r)),A=1/o,d=Math.sqrt(s-1)*A;return 1/(a*A-h*d)}function $2(t,e,i){if(!(e<=0||e===1/0||e!==e))return l.multiplyByScalar(t,e,i)}function tD(t,e){return l.equals(e,l.ZERO)?e:(t.transformPositionToScaledSpace(e,mT),l.normalize(mT,mT))}var H2,K7,v2,X7,q7,vZ,$7,t$,mT,dA,Sm=O(()=>{_i();Ht();ae();bt();mt();Ve();pn();Object.defineProperties(lA.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},cameraPosition:{get:function(){return this._cameraPosition},set:function(t){let i=this._ellipsoid.transformPositionToScaledSpace(t,this._cameraPositionInScaledSpace),n=l.magnitudeSquared(i)-1;l.clone(t,this._cameraPosition),this._cameraPositionInScaledSpace=i,this._distanceToLimbInScaledSpaceSquared=n}}});H2=new l;lA.prototype.isPointVisible=function(t){let i=this._ellipsoid.transformPositionToScaledSpace(t,H2);return fT(i,this._cameraPositionInScaledSpace,this._distanceToLimbInScaledSpaceSquared)};lA.prototype.isScaledSpacePointVisible=function(t){return fT(t,this._cameraPositionInScaledSpace,this._distanceToLimbInScaledSpaceSquared)};K7=new l;lA.prototype.isScaledSpacePointVisiblePossiblyUnderEllipsoid=function(t,e){let i=this._ellipsoid,n,s;return m(e)&&e<0&&i.minimumRadius>-e?(s=K7,s.x=this._cameraPosition.x/(i.radii.x+e),s.y=this._cameraPosition.y/(i.radii.y+e),s.z=this._cameraPosition.z/(i.radii.z+e),n=s.x*s.x+s.y*s.y+s.z*s.z-1):(s=this._cameraPositionInScaledSpace,n=this._distanceToLimbInScaledSpaceSquared),fT(t,s,n)};lA.prototype.computeHorizonCullingPoint=function(t,e,i){return K2(this._ellipsoid,t,e,i)};v2=ot.clone(ot.UNIT_SPHERE);lA.prototype.computeHorizonCullingPointPossiblyUnderEllipsoid=function(t,e,i,n){let s=z2(this._ellipsoid,i,v2);return K2(s,t,e,n)};lA.prototype.computeHorizonCullingPointFromVertices=function(t,e,i,n,s){return X2(this._ellipsoid,t,e,i,n,s)};lA.prototype.computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid=function(t,e,i,n,s,o){let r=z2(this._ellipsoid,s,v2);return X2(r,t,e,i,n,o)};X7=[];lA.prototype.computeHorizonCullingPointFromRectangle=function(t,e,i){p.typeOf.object("rectangle",t);let n=Xt.subsample(t,e,0,X7),s=Nt.fromPoints(n);if(!(l.magnitude(s.center)<.1*e.minimumRadius))return this.computeHorizonCullingPoint(s.center,n,i)};q7=new l;vZ=new l;$7=new l,t$=new l;mT=new l;dA=lA});function ET(t,e,i){return i<0&&(i+=1),i>1&&(i-=1),i*6<1?t+(e-t)*6*i:i*2<1?e:i*3<2?t+(e-t)*(2/3-i)*6:t}function q(t,e,i,n){this.red=Z(t,1),this.green=Z(e,1),this.blue=Z(i,1),this.alpha=Z(n,1)}var _T,RT,eh,e$,i$,n$,s$,Zt,Qn=O(()=>{ae();bt();mt();Il();_e();q.fromCartesian4=function(t,e){return p.typeOf.object("cartesian",t),m(e)?(e.red=t.x,e.green=t.y,e.blue=t.z,e.alpha=t.w,e):new q(t.x,t.y,t.z,t.w)};q.fromBytes=function(t,e,i,n,s){return t=q.byteToFloat(Z(t,255)),e=q.byteToFloat(Z(e,255)),i=q.byteToFloat(Z(i,255)),n=q.byteToFloat(Z(n,255)),m(s)?(s.red=t,s.green=e,s.blue=i,s.alpha=n,s):new q(t,e,i,n)};q.fromAlpha=function(t,e,i){return p.typeOf.object("color",t),p.typeOf.number("alpha",e),m(i)?(i.red=t.red,i.green=t.green,i.blue=t.blue,i.alpha=e,i):new q(t.red,t.green,t.blue,e)};_o.supportsTypedArrays()&&(_T=new ArrayBuffer(4),RT=new Uint32Array(_T),eh=new Uint8Array(_T));q.fromRgba=function(t,e){return RT[0]=t,q.fromBytes(eh[0],eh[1],eh[2],eh[3],e)};q.fromHsl=function(t,e,i,n,s){t=Z(t,0)%1,e=Z(e,0),i=Z(i,0),n=Z(n,1);let o=i,r=i,a=i;if(e!==0){let h;i<.5?h=i*(1+e):h=i+e-i*e;let A=2*i-h;o=ET(A,h,t+1/3),r=ET(A,h,t),a=ET(A,h,t-1/3)}return m(s)?(s.red=o,s.green=r,s.blue=a,s.alpha=n,s):new q(o,r,a,n)};q.fromRandom=function(t,e){t=Z(t,Z.EMPTY_OBJECT);let i=t.red;if(!m(i)){let r=Z(t.minimumRed,0),a=Z(t.maximumRed,1);p.typeOf.number.lessThanOrEquals("minimumRed",r,a),i=r+L.nextRandomNumber()*(a-r)}let n=t.green;if(!m(n)){let r=Z(t.minimumGreen,0),a=Z(t.maximumGreen,1);p.typeOf.number.lessThanOrEquals("minimumGreen",r,a),n=r+L.nextRandomNumber()*(a-r)}let s=t.blue;if(!m(s)){let r=Z(t.minimumBlue,0),a=Z(t.maximumBlue,1);p.typeOf.number.lessThanOrEquals("minimumBlue",r,a),s=r+L.nextRandomNumber()*(a-r)}let o=t.alpha;if(!m(o)){let r=Z(t.minimumAlpha,0),a=Z(t.maximumAlpha,1);p.typeOf.number.lessThanOrEquals("minumumAlpha",r,a),o=r+L.nextRandomNumber()*(a-r)}return m(e)?(e.red=i,e.green=n,e.blue=s,e.alpha=o,e):new q(i,n,s,o)};e$=/^#([0-9a-f])([0-9a-f])([0-9a-f])([0-9a-f])?$/i,i$=/^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})?$/i,n$=/^rgba?\s*\(\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i,s$=/^hsla?\s*\(\s*([0-9.]+)\s*[,\s]+\s*([0-9.]+%)\s*[,\s]+\s*([0-9.]+%)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i;q.fromCssColorString=function(t,e){p.typeOf.string("color",t),m(e)||(e=new q),t=t.trim();let i=q[t.toUpperCase()];if(m(i))return q.clone(i,e),e;let n=e$.exec(t);return n!==null?(e.red=parseInt(n[1],16)/15,e.green=parseInt(n[2],16)/15,e.blue=parseInt(n[3],16)/15,e.alpha=parseInt(Z(n[4],"f"),16)/15,e):(n=i$.exec(t),n!==null?(e.red=parseInt(n[1],16)/255,e.green=parseInt(n[2],16)/255,e.blue=parseInt(n[3],16)/255,e.alpha=parseInt(Z(n[4],"ff"),16)/255,e):(n=n$.exec(t),n!==null?(e.red=parseFloat(n[1])/(n[1].substr(-1)==="%"?100:255),e.green=parseFloat(n[2])/(n[2].substr(-1)==="%"?100:255),e.blue=parseFloat(n[3])/(n[3].substr(-1)==="%"?100:255),e.alpha=parseFloat(Z(n[4],"1.0")),e):(n=s$.exec(t),n!==null?q.fromHsl(parseFloat(n[1])/360,parseFloat(n[2])/100,parseFloat(n[3])/100,parseFloat(Z(n[4],"1.0")),e):(e=void 0,e))))};q.packedLength=4;q.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.red,e[i++]=t.green,e[i++]=t.blue,e[i]=t.alpha,e};q.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new q),i.red=t[e++],i.green=t[e++],i.blue=t[e++],i.alpha=t[e],i};q.byteToFloat=function(t){return t/255};q.floatToByte=function(t){return t===1?255:t*256|0};q.clone=function(t,e){if(m(t))return m(e)?(e.red=t.red,e.green=t.green,e.blue=t.blue,e.alpha=t.alpha,e):new q(t.red,t.green,t.blue,t.alpha)};q.equals=function(t,e){return t===e||m(t)&&m(e)&&t.red===e.red&&t.green===e.green&&t.blue===e.blue&&t.alpha===e.alpha};q.equalsArray=function(t,e,i){return t.red===e[i]&&t.green===e[i+1]&&t.blue===e[i+2]&&t.alpha===e[i+3]};q.prototype.clone=function(t){return q.clone(this,t)};q.prototype.equals=function(t){return q.equals(this,t)};q.prototype.equalsEpsilon=function(t,e){return this===t||m(t)&&Math.abs(this.red-t.red)<=e&&Math.abs(this.green-t.green)<=e&&Math.abs(this.blue-t.blue)<=e&&Math.abs(this.alpha-t.alpha)<=e};q.prototype.toString=function(){return`(${this.red}, ${this.green}, ${this.blue}, ${this.alpha})`};q.prototype.toCssColorString=function(){let t=q.floatToByte(this.red),e=q.floatToByte(this.green),i=q.floatToByte(this.blue);return this.alpha===1?`rgb(${t},${e},${i})`:`rgba(${t},${e},${i},${this.alpha})`};q.prototype.toCssHexString=function(){let t=q.floatToByte(this.red).toString(16);t.length<2&&(t=`0${t}`);let e=q.floatToByte(this.green).toString(16);e.length<2&&(e=`0${e}`);let i=q.floatToByte(this.blue).toString(16);if(i.length<2&&(i=`0${i}`),this.alpha<1){let n=q.floatToByte(this.alpha).toString(16);return n.length<2&&(n=`0${n}`),`#${t}${e}${i}${n}`}return`#${t}${e}${i}`};q.prototype.toBytes=function(t){let e=q.floatToByte(this.red),i=q.floatToByte(this.green),n=q.floatToByte(this.blue),s=q.floatToByte(this.alpha);return m(t)?(t[0]=e,t[1]=i,t[2]=n,t[3]=s,t):[e,i,n,s]};q.prototype.toRgba=function(){return eh[0]=q.floatToByte(this.red),eh[1]=q.floatToByte(this.green),eh[2]=q.floatToByte(this.blue),eh[3]=q.floatToByte(this.alpha),RT[0]};q.prototype.brighten=function(t,e){return p.typeOf.number("magnitude",t),p.typeOf.number.greaterThanOrEquals("magnitude",t,0),p.typeOf.object("result",e),t=1-t,e.red=1-(1-this.red)*t,e.green=1-(1-this.green)*t,e.blue=1-(1-this.blue)*t,e.alpha=this.alpha,e};q.prototype.darken=function(t,e){return p.typeOf.number("magnitude",t),p.typeOf.number.greaterThanOrEquals("magnitude",t,0),p.typeOf.object("result",e),t=1-t,e.red=this.red*t,e.green=this.green*t,e.blue=this.blue*t,e.alpha=this.alpha,e};q.prototype.withAlpha=function(t,e){return q.fromAlpha(this,t,e)};q.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.red=t.red+e.red,i.green=t.green+e.green,i.blue=t.blue+e.blue,i.alpha=t.alpha+e.alpha,i};q.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.red=t.red-e.red,i.green=t.green-e.green,i.blue=t.blue-e.blue,i.alpha=t.alpha-e.alpha,i};q.multiply=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.red=t.red*e.red,i.green=t.green*e.green,i.blue=t.blue*e.blue,i.alpha=t.alpha*e.alpha,i};q.divide=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.red=t.red/e.red,i.green=t.green/e.green,i.blue=t.blue/e.blue,i.alpha=t.alpha/e.alpha,i};q.mod=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.red=t.red%e.red,i.green=t.green%e.green,i.blue=t.blue%e.blue,i.alpha=t.alpha%e.alpha,i};q.lerp=function(t,e,i,n){return p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n),n.red=L.lerp(t.red,e.red,i),n.green=L.lerp(t.green,e.green,i),n.blue=L.lerp(t.blue,e.blue,i),n.alpha=L.lerp(t.alpha,e.alpha,i),n};q.multiplyByScalar=function(t,e,i){return p.typeOf.object("color",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.red=t.red*e,i.green=t.green*e,i.blue=t.blue*e,i.alpha=t.alpha*e,i};q.divideByScalar=function(t,e,i){return p.typeOf.object("color",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.red=t.red/e,i.green=t.green/e,i.blue=t.blue/e,i.alpha=t.alpha/e,i};q.ALICEBLUE=Object.freeze(q.fromCssColorString("#F0F8FF"));q.ANTIQUEWHITE=Object.freeze(q.fromCssColorString("#FAEBD7"));q.AQUA=Object.freeze(q.fromCssColorString("#00FFFF"));q.AQUAMARINE=Object.freeze(q.fromCssColorString("#7FFFD4"));q.AZURE=Object.freeze(q.fromCssColorString("#F0FFFF"));q.BEIGE=Object.freeze(q.fromCssColorString("#F5F5DC"));q.BISQUE=Object.freeze(q.fromCssColorString("#FFE4C4"));q.BLACK=Object.freeze(q.fromCssColorString("#000000"));q.BLANCHEDALMOND=Object.freeze(q.fromCssColorString("#FFEBCD"));q.BLUE=Object.freeze(q.fromCssColorString("#0000FF"));q.BLUEVIOLET=Object.freeze(q.fromCssColorString("#8A2BE2"));q.BROWN=Object.freeze(q.fromCssColorString("#A52A2A"));q.BURLYWOOD=Object.freeze(q.fromCssColorString("#DEB887"));q.CADETBLUE=Object.freeze(q.fromCssColorString("#5F9EA0"));q.CHARTREUSE=Object.freeze(q.fromCssColorString("#7FFF00"));q.CHOCOLATE=Object.freeze(q.fromCssColorString("#D2691E"));q.CORAL=Object.freeze(q.fromCssColorString("#FF7F50"));q.CORNFLOWERBLUE=Object.freeze(q.fromCssColorString("#6495ED"));q.CORNSILK=Object.freeze(q.fromCssColorString("#FFF8DC"));q.CRIMSON=Object.freeze(q.fromCssColorString("#DC143C"));q.CYAN=Object.freeze(q.fromCssColorString("#00FFFF"));q.DARKBLUE=Object.freeze(q.fromCssColorString("#00008B"));q.DARKCYAN=Object.freeze(q.fromCssColorString("#008B8B"));q.DARKGOLDENROD=Object.freeze(q.fromCssColorString("#B8860B"));q.DARKGRAY=Object.freeze(q.fromCssColorString("#A9A9A9"));q.DARKGREEN=Object.freeze(q.fromCssColorString("#006400"));q.DARKGREY=q.DARKGRAY;q.DARKKHAKI=Object.freeze(q.fromCssColorString("#BDB76B"));q.DARKMAGENTA=Object.freeze(q.fromCssColorString("#8B008B"));q.DARKOLIVEGREEN=Object.freeze(q.fromCssColorString("#556B2F"));q.DARKORANGE=Object.freeze(q.fromCssColorString("#FF8C00"));q.DARKORCHID=Object.freeze(q.fromCssColorString("#9932CC"));q.DARKRED=Object.freeze(q.fromCssColorString("#8B0000"));q.DARKSALMON=Object.freeze(q.fromCssColorString("#E9967A"));q.DARKSEAGREEN=Object.freeze(q.fromCssColorString("#8FBC8F"));q.DARKSLATEBLUE=Object.freeze(q.fromCssColorString("#483D8B"));q.DARKSLATEGRAY=Object.freeze(q.fromCssColorString("#2F4F4F"));q.DARKSLATEGREY=q.DARKSLATEGRAY;q.DARKTURQUOISE=Object.freeze(q.fromCssColorString("#00CED1"));q.DARKVIOLET=Object.freeze(q.fromCssColorString("#9400D3"));q.DEEPPINK=Object.freeze(q.fromCssColorString("#FF1493"));q.DEEPSKYBLUE=Object.freeze(q.fromCssColorString("#00BFFF"));q.DIMGRAY=Object.freeze(q.fromCssColorString("#696969"));q.DIMGREY=q.DIMGRAY;q.DODGERBLUE=Object.freeze(q.fromCssColorString("#1E90FF"));q.FIREBRICK=Object.freeze(q.fromCssColorString("#B22222"));q.FLORALWHITE=Object.freeze(q.fromCssColorString("#FFFAF0"));q.FORESTGREEN=Object.freeze(q.fromCssColorString("#228B22"));q.FUCHSIA=Object.freeze(q.fromCssColorString("#FF00FF"));q.GAINSBORO=Object.freeze(q.fromCssColorString("#DCDCDC"));q.GHOSTWHITE=Object.freeze(q.fromCssColorString("#F8F8FF"));q.GOLD=Object.freeze(q.fromCssColorString("#FFD700"));q.GOLDENROD=Object.freeze(q.fromCssColorString("#DAA520"));q.GRAY=Object.freeze(q.fromCssColorString("#808080"));q.GREEN=Object.freeze(q.fromCssColorString("#008000"));q.GREENYELLOW=Object.freeze(q.fromCssColorString("#ADFF2F"));q.GREY=q.GRAY;q.HONEYDEW=Object.freeze(q.fromCssColorString("#F0FFF0"));q.HOTPINK=Object.freeze(q.fromCssColorString("#FF69B4"));q.INDIANRED=Object.freeze(q.fromCssColorString("#CD5C5C"));q.INDIGO=Object.freeze(q.fromCssColorString("#4B0082"));q.IVORY=Object.freeze(q.fromCssColorString("#FFFFF0"));q.KHAKI=Object.freeze(q.fromCssColorString("#F0E68C"));q.LAVENDER=Object.freeze(q.fromCssColorString("#E6E6FA"));q.LAVENDAR_BLUSH=Object.freeze(q.fromCssColorString("#FFF0F5"));q.LAWNGREEN=Object.freeze(q.fromCssColorString("#7CFC00"));q.LEMONCHIFFON=Object.freeze(q.fromCssColorString("#FFFACD"));q.LIGHTBLUE=Object.freeze(q.fromCssColorString("#ADD8E6"));q.LIGHTCORAL=Object.freeze(q.fromCssColorString("#F08080"));q.LIGHTCYAN=Object.freeze(q.fromCssColorString("#E0FFFF"));q.LIGHTGOLDENRODYELLOW=Object.freeze(q.fromCssColorString("#FAFAD2"));q.LIGHTGRAY=Object.freeze(q.fromCssColorString("#D3D3D3"));q.LIGHTGREEN=Object.freeze(q.fromCssColorString("#90EE90"));q.LIGHTGREY=q.LIGHTGRAY;q.LIGHTPINK=Object.freeze(q.fromCssColorString("#FFB6C1"));q.LIGHTSEAGREEN=Object.freeze(q.fromCssColorString("#20B2AA"));q.LIGHTSKYBLUE=Object.freeze(q.fromCssColorString("#87CEFA"));q.LIGHTSLATEGRAY=Object.freeze(q.fromCssColorString("#778899"));q.LIGHTSLATEGREY=q.LIGHTSLATEGRAY;q.LIGHTSTEELBLUE=Object.freeze(q.fromCssColorString("#B0C4DE"));q.LIGHTYELLOW=Object.freeze(q.fromCssColorString("#FFFFE0"));q.LIME=Object.freeze(q.fromCssColorString("#00FF00"));q.LIMEGREEN=Object.freeze(q.fromCssColorString("#32CD32"));q.LINEN=Object.freeze(q.fromCssColorString("#FAF0E6"));q.MAGENTA=Object.freeze(q.fromCssColorString("#FF00FF"));q.MAROON=Object.freeze(q.fromCssColorString("#800000"));q.MEDIUMAQUAMARINE=Object.freeze(q.fromCssColorString("#66CDAA"));q.MEDIUMBLUE=Object.freeze(q.fromCssColorString("#0000CD"));q.MEDIUMORCHID=Object.freeze(q.fromCssColorString("#BA55D3"));q.MEDIUMPURPLE=Object.freeze(q.fromCssColorString("#9370DB"));q.MEDIUMSEAGREEN=Object.freeze(q.fromCssColorString("#3CB371"));q.MEDIUMSLATEBLUE=Object.freeze(q.fromCssColorString("#7B68EE"));q.MEDIUMSPRINGGREEN=Object.freeze(q.fromCssColorString("#00FA9A"));q.MEDIUMTURQUOISE=Object.freeze(q.fromCssColorString("#48D1CC"));q.MEDIUMVIOLETRED=Object.freeze(q.fromCssColorString("#C71585"));q.MIDNIGHTBLUE=Object.freeze(q.fromCssColorString("#191970"));q.MINTCREAM=Object.freeze(q.fromCssColorString("#F5FFFA"));q.MISTYROSE=Object.freeze(q.fromCssColorString("#FFE4E1"));q.MOCCASIN=Object.freeze(q.fromCssColorString("#FFE4B5"));q.NAVAJOWHITE=Object.freeze(q.fromCssColorString("#FFDEAD"));q.NAVY=Object.freeze(q.fromCssColorString("#000080"));q.OLDLACE=Object.freeze(q.fromCssColorString("#FDF5E6"));q.OLIVE=Object.freeze(q.fromCssColorString("#808000"));q.OLIVEDRAB=Object.freeze(q.fromCssColorString("#6B8E23"));q.ORANGE=Object.freeze(q.fromCssColorString("#FFA500"));q.ORANGERED=Object.freeze(q.fromCssColorString("#FF4500"));q.ORCHID=Object.freeze(q.fromCssColorString("#DA70D6"));q.PALEGOLDENROD=Object.freeze(q.fromCssColorString("#EEE8AA"));q.PALEGREEN=Object.freeze(q.fromCssColorString("#98FB98"));q.PALETURQUOISE=Object.freeze(q.fromCssColorString("#AFEEEE"));q.PALEVIOLETRED=Object.freeze(q.fromCssColorString("#DB7093"));q.PAPAYAWHIP=Object.freeze(q.fromCssColorString("#FFEFD5"));q.PEACHPUFF=Object.freeze(q.fromCssColorString("#FFDAB9"));q.PERU=Object.freeze(q.fromCssColorString("#CD853F"));q.PINK=Object.freeze(q.fromCssColorString("#FFC0CB"));q.PLUM=Object.freeze(q.fromCssColorString("#DDA0DD"));q.POWDERBLUE=Object.freeze(q.fromCssColorString("#B0E0E6"));q.PURPLE=Object.freeze(q.fromCssColorString("#800080"));q.RED=Object.freeze(q.fromCssColorString("#FF0000"));q.ROSYBROWN=Object.freeze(q.fromCssColorString("#BC8F8F"));q.ROYALBLUE=Object.freeze(q.fromCssColorString("#4169E1"));q.SADDLEBROWN=Object.freeze(q.fromCssColorString("#8B4513"));q.SALMON=Object.freeze(q.fromCssColorString("#FA8072"));q.SANDYBROWN=Object.freeze(q.fromCssColorString("#F4A460"));q.SEAGREEN=Object.freeze(q.fromCssColorString("#2E8B57"));q.SEASHELL=Object.freeze(q.fromCssColorString("#FFF5EE"));q.SIENNA=Object.freeze(q.fromCssColorString("#A0522D"));q.SILVER=Object.freeze(q.fromCssColorString("#C0C0C0"));q.SKYBLUE=Object.freeze(q.fromCssColorString("#87CEEB"));q.SLATEBLUE=Object.freeze(q.fromCssColorString("#6A5ACD"));q.SLATEGRAY=Object.freeze(q.fromCssColorString("#708090"));q.SLATEGREY=q.SLATEGRAY;q.SNOW=Object.freeze(q.fromCssColorString("#FFFAFA"));q.SPRINGGREEN=Object.freeze(q.fromCssColorString("#00FF7F"));q.STEELBLUE=Object.freeze(q.fromCssColorString("#4682B4"));q.TAN=Object.freeze(q.fromCssColorString("#D2B48C"));q.TEAL=Object.freeze(q.fromCssColorString("#008080"));q.THISTLE=Object.freeze(q.fromCssColorString("#D8BFD8"));q.TOMATO=Object.freeze(q.fromCssColorString("#FF6347"));q.TURQUOISE=Object.freeze(q.fromCssColorString("#40E0D0"));q.VIOLET=Object.freeze(q.fromCssColorString("#EE82EE"));q.WHEAT=Object.freeze(q.fromCssColorString("#F5DEB3"));q.WHITE=Object.freeze(q.fromCssColorString("#FFFFFF"));q.WHITESMOKE=Object.freeze(q.fromCssColorString("#F5F5F5"));q.YELLOW=Object.freeze(q.fromCssColorString("#FFFF00"));q.YELLOWGREEN=Object.freeze(q.fromCssColorString("#9ACD32"));q.TRANSPARENT=Object.freeze(new q(0,0,0,0));Zt=q});function o$(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(t){let e=Math.random()*16|0;return(t==="x"?e:e&3|8).toString(16)})}var Gs,ih=O(()=>{Gs=o$});function _r(t,e){t=Z(t,0),this._near=t,e=Z(e,Number.MAX_VALUE),this._far=e}var Wo,zZ=O(()=>{bt();mt();Vt();Object.defineProperties(_r.prototype,{near:{get:function(){return this._near},set:function(t){this._near=t}},far:{get:function(){return this._far},set:function(t){this._far=t}}});_r.packedLength=2;_r.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),e[i++]=t.near,e[i]=t.far,e};_r.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");return e=Z(e,0),m(i)||(i=new _r),i.near=t[e++],i.far=t[e],i};_r.equals=function(t,e){return t===e||m(t)&&m(e)&&t.near===e.near&&t.far===e.far};_r.clone=function(t,e){if(m(t))return m(e)||(e=new _r),e.near=t.near,e.far=t.far,e};_r.prototype.clone=function(t){return _r.clone(this,t)};_r.prototype.equals=function(t){return _r.equals(this,t)};Wo=_r});function Br(t,e,i,n){this.near=Z(t,0),this.nearValue=Z(e,0),this.far=Z(i,1),this.farValue=Z(n,0)}var gi,IE=O(()=>{bt();mt();Vt();Br.clone=function(t,e){if(m(t))return m(e)?(e.near=t.near,e.nearValue=t.nearValue,e.far=t.far,e.farValue=t.farValue,e):new Br(t.near,t.nearValue,t.far,t.farValue)};Br.packedLength=4;Br.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),e[i++]=t.near,e[i++]=t.nearValue,e[i++]=t.far,e[i]=t.farValue,e};Br.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");return e=Z(e,0),m(i)||(i=new Br),i.near=t[e++],i.nearValue=t[e++],i.far=t[e++],i.farValue=t[e],i};Br.equals=function(t,e){return t===e||m(t)&&m(e)&&t.near===e.near&&t.nearValue===e.nearValue&&t.far===e.far&&t.farValue===e.farValue};Br.prototype.clone=function(t){return Br.clone(this,t)};Br.prototype.equals=function(t){return Br.equals(this,t)};gi=Br});function gl(t){return t===Cl.CLAMP_TO_GROUND||t===Cl.CLAMP_TO_3D_TILE||t===Cl.CLAMP_TO_TERRAIN}function eD(t){return t===Cl.RELATIVE_TO_GROUND||t===Cl.RELATIVE_TO_3D_TILE||t===Cl.RELATIVE_TO_TERRAIN}var Cl,Wr,Om=O(()=>{Cl={NONE:0,CLAMP_TO_GROUND:1,RELATIVE_TO_GROUND:2,CLAMP_TO_TERRAIN:3,RELATIVE_TO_TERRAIN:4,CLAMP_TO_3D_TILE:5,RELATIVE_TO_3D_TILE:6},Wr=Object.freeze(Cl)});var r$,to,Vm=O(()=>{r$={CENTER:0,LEFT:1,RIGHT:-1},to=Object.freeze(r$)});var KZ,ye,ua=O(()=>{KZ={MORPHING:0,COLUMBUS_VIEW:1,SCENE2D:2,SCENE3D:3};KZ.getMorphTime=function(t){return t===KZ.SCENE3D?1:t===KZ.MORPHING?void 0:0};ye=Object.freeze(KZ)});function Bs(t,e){if(p.typeOf.object("normal",t),!L.equalsEpsilon(l.magnitude(t),1,L.EPSILON6))throw new Y("normal must be normalized.");p.typeOf.number("distance",e),this.normal=l.clone(t),this.distance=e}var a$,A$,h$,c$,l$,Ki,nh=O(()=>{Ht();Vs();ae();mt();Vt();_e();Fi();Bs.fromPointNormal=function(t,e,i){if(p.typeOf.object("point",t),p.typeOf.object("normal",e),!L.equalsEpsilon(l.magnitude(e),1,L.EPSILON6))throw new Y("normal must be normalized.");let n=-l.dot(e,t);return m(i)?(l.clone(e,i.normal),i.distance=n,i):new Bs(e,n)};a$=new l;Bs.fromCartesian4=function(t,e){p.typeOf.object("coefficients",t);let i=l.fromCartesian4(t,a$),n=t.w;if(!L.equalsEpsilon(l.magnitude(i),1,L.EPSILON6))throw new Y("normal must be normalized.");return m(e)?(l.clone(i,e.normal),e.distance=n,e):new Bs(i,n)};Bs.getPointDistance=function(t,e){return p.typeOf.object("plane",t),p.typeOf.object("point",e),l.dot(t.normal,e)+t.distance};A$=new l;Bs.projectPointOntoPlane=function(t,e,i){p.typeOf.object("plane",t),p.typeOf.object("point",e),m(i)||(i=new l);let n=Bs.getPointDistance(t,e),s=l.multiplyByScalar(t.normal,n,A$);return l.subtract(e,s,i)};h$=new at,c$=new ie,l$=new l;Bs.transform=function(t,e,i){p.typeOf.object("plane",t),p.typeOf.object("transform",e);let n=t.normal,s=t.distance,o=at.inverseTranspose(e,h$),r=ie.fromElements(n.x,n.y,n.z,s,c$);r=at.multiplyByVector(o,r,r);let a=l.fromCartesian4(r,l$);return r=ie.divideByScalar(r,l.magnitude(a),r),Bs.fromCartesian4(r,i)};Bs.clone=function(t,e){return p.typeOf.object("plane",t),m(e)?(l.clone(t.normal,e.normal),e.distance=t.distance,e):new Bs(t.normal,t.distance)};Bs.equals=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.distance===e.distance&&l.equals(t.normal,e.normal)};Bs.ORIGIN_XY_PLANE=Object.freeze(new Bs(l.UNIT_Z,0));Bs.ORIGIN_YZ_PLANE=Object.freeze(new Bs(l.UNIT_X,0));Bs.ORIGIN_ZX_PLANE=Object.freeze(new Bs(l.UNIT_Y,0));Ki=Bs});function Dr(t){this.planes=Z(t,[])}var pE,cc,d$,iD,XZ,ZT=O(()=>{Ht();Vs();bt();mt();Vt();nc();nh();pE=[new l,new l,new l];l.clone(l.UNIT_X,pE[0]);l.clone(l.UNIT_Y,pE[1]);l.clone(l.UNIT_Z,pE[2]);cc=new l,d$=new l,iD=new Ki(new l(1,0,0),0);Dr.fromBoundingSphere=function(t,e){if(!m(t))throw new Y("boundingSphere is required.");m(e)||(e=new Dr);let i=pE.length,n=e.planes;n.length=2*i;let s=t.center,o=t.radius,r=0;for(let a=0;a<i;++a){let h=pE[a],A=n[r],d=n[r+1];m(A)||(A=n[r]=new ie),m(d)||(d=n[r+1]=new ie),l.multiplyByScalar(h,-o,cc),l.add(s,cc,cc),A.x=h.x,A.y=h.y,A.z=h.z,A.w=-l.dot(h,cc),l.multiplyByScalar(h,o,cc),l.add(s,cc,cc),d.x=-h.x,d.y=-h.y,d.z=-h.z,d.w=-l.dot(l.negate(h,d$),cc),r+=2}return e};Dr.prototype.computeVisibility=function(t){if(!m(t))throw new Y("boundingVolume is required.");let e=this.planes,i=!1;for(let n=0,s=e.length;n<s;++n){let o=t.intersectPlane(Ki.fromCartesian4(e[n],iD));if(o===Nn.OUTSIDE)return Nn.OUTSIDE;o===Nn.INTERSECTING&&(i=!0)}return i?Nn.INTERSECTING:Nn.INSIDE};Dr.prototype.computeVisibilityWithPlaneMask=function(t,e){if(!m(t))throw new Y("boundingVolume is required.");if(!m(e))throw new Y("parentPlaneMask is required.");if(e===Dr.MASK_OUTSIDE||e===Dr.MASK_INSIDE)return e;let i=Dr.MASK_INSIDE,n=this.planes;for(let s=0,o=n.length;s<o;++s){let r=s<31?1<<s:0;if(s<31&&!(e&r))continue;let a=t.intersectPlane(Ki.fromCartesian4(n[s],iD));if(a===Nn.OUTSIDE)return Dr.MASK_OUTSIDE;a===Nn.INTERSECTING&&(i|=r)}return i};Dr.MASK_OUTSIDE=4294967295;Dr.MASK_INSIDE=0;Dr.MASK_INDETERMINATE=2147483647;XZ=Dr});function mA(t){t=Z(t,Z.EMPTY_OBJECT),this.left=t.left,this._left=void 0,this.right=t.right,this._right=void 0,this.top=t.top,this._top=void 0,this.bottom=t.bottom,this._bottom=void 0,this.near=Z(t.near,1),this._near=this.near,this.far=Z(t.far,5e8),this._far=this.far,this._cullingVolume=new XZ,this._orthographicMatrix=new at}function nD(t){if(!m(t.right)||!m(t.left)||!m(t.top)||!m(t.bottom)||!m(t.near)||!m(t.far))throw new Y("right, left, top, bottom, near, or far parameters are not set.");if(t.top!==t._top||t.bottom!==t._bottom||t.left!==t._left||t.right!==t._right||t.near!==t._near||t.far!==t._far){if(t.left>t.right)throw new Y("right must be greater than left.");if(t.bottom>t.top)throw new Y("top must be greater than bottom.");if(t.near<=0||t.near>t.far)throw new Y("near must be greater than zero and less than far.");t._left=t.left,t._right=t.right,t._top=t.top,t._bottom=t.bottom,t._near=t.near,t._far=t.far,t._orthographicMatrix=at.computeOrthographicOffCenter(t.left,t.right,t.bottom,t.top,t.near,t.far,t._orthographicMatrix)}}var m$,f$,E$,IT,qZ,pT=O(()=>{Ht();Vs();ZT();bt();mt();Vt();_e();Fi();Object.defineProperties(mA.prototype,{projectionMatrix:{get:function(){return nD(this),this._orthographicMatrix}}});m$=new l,f$=new l,E$=new l,IT=new l;mA.prototype.computeCullingVolume=function(t,e,i){if(!m(t))throw new Y("position is required.");if(!m(e))throw new Y("direction is required.");if(!m(i))throw new Y("up is required.");let n=this._cullingVolume.planes,s=this.top,o=this.bottom,r=this.right,a=this.left,h=this.near,A=this.far,d=l.cross(e,i,m$);l.normalize(d,d);let f=f$;l.multiplyByScalar(e,h,f),l.add(t,f,f);let E=E$;l.multiplyByScalar(d,a,E),l.add(f,E,E);let _=n[0];return m(_)||(_=n[0]=new ie),_.x=d.x,_.y=d.y,_.z=d.z,_.w=-l.dot(d,E),l.multiplyByScalar(d,r,E),l.add(f,E,E),_=n[1],m(_)||(_=n[1]=new ie),_.x=-d.x,_.y=-d.y,_.z=-d.z,_.w=-l.dot(l.negate(d,IT),E),l.multiplyByScalar(i,o,E),l.add(f,E,E),_=n[2],m(_)||(_=n[2]=new ie),_.x=i.x,_.y=i.y,_.z=i.z,_.w=-l.dot(i,E),l.multiplyByScalar(i,s,E),l.add(f,E,E),_=n[3],m(_)||(_=n[3]=new ie),_.x=-i.x,_.y=-i.y,_.z=-i.z,_.w=-l.dot(l.negate(i,IT),E),_=n[4],m(_)||(_=n[4]=new ie),_.x=e.x,_.y=e.y,_.z=e.z,_.w=-l.dot(e,f),l.multiplyByScalar(e,A,E),l.add(t,E,E),_=n[5],m(_)||(_=n[5]=new ie),_.x=-e.x,_.y=-e.y,_.z=-e.z,_.w=-l.dot(l.negate(e,IT),E),this._cullingVolume};mA.prototype.getPixelDimensions=function(t,e,i,n,s){if(nD(this),!m(t)||!m(e))throw new Y("Both drawingBufferWidth and drawingBufferHeight are required.");if(t<=0)throw new Y("drawingBufferWidth must be greater than zero.");if(e<=0)throw new Y("drawingBufferHeight must be greater than zero.");if(!m(i))throw new Y("distance is required.");if(!m(n))throw new Y("pixelRatio is required.");if(n<=0)throw new Y("pixelRatio must be greater than zero.");if(!m(s))throw new Y("A result object is required.");let o=this.right-this.left,r=this.top-this.bottom,a=n*o/t,h=n*r/e;return s.x=a,s.y=h,s};mA.prototype.clone=function(t){return m(t)||(t=new mA),t.left=this.left,t.right=this.right,t.top=this.top,t.bottom=this.bottom,t.near=this.near,t.far=this.far,t._left=void 0,t._right=void 0,t._top=void 0,t._bottom=void 0,t._near=void 0,t._far=void 0,t};mA.prototype.equals=function(t){return m(t)&&t instanceof mA&&this.right===t.right&&this.left===t.left&&this.top===t.top&&this.bottom===t.bottom&&this.near===t.near&&this.far===t.far};mA.prototype.equalsEpsilon=function(t,e,i){return t===this||m(t)&&t instanceof mA&&L.equalsEpsilon(this.right,t.right,e,i)&&L.equalsEpsilon(this.left,t.left,e,i)&&L.equalsEpsilon(this.top,t.top,e,i)&&L.equalsEpsilon(this.bottom,t.bottom,e,i)&&L.equalsEpsilon(this.near,t.near,e,i)&&L.equalsEpsilon(this.far,t.far,e,i)};qZ=mA});function tr(t){t=Z(t,Z.EMPTY_OBJECT),this._offCenterFrustum=new qZ,this.width=t.width,this._width=void 0,this.aspectRatio=t.aspectRatio,this._aspectRatio=void 0,this.near=Z(t.near,1),this._near=this.near,this.far=Z(t.far,5e8),this._far=this.far}function lc(t){if(!m(t.width)||!m(t.aspectRatio)||!m(t.near)||!m(t.far))throw new Y("width, aspectRatio, near, or far parameters are not set.");let e=t._offCenterFrustum;if(t.width!==t._width||t.aspectRatio!==t._aspectRatio||t.near!==t._near||t.far!==t._far){if(t.aspectRatio<0)throw new Y("aspectRatio must be positive.");if(t.near<0||t.near>t.far)throw new Y("near must be greater than zero and less than far.");t._aspectRatio=t.aspectRatio,t._width=t.width,t._near=t.near,t._far=t.far;let i=1/t.aspectRatio;e.right=t.width*.5,e.left=-e.right,e.top=i*e.right,e.bottom=-e.top,e.near=t.near,e.far=t.far}}var js,$Z=O(()=>{ae();bt();mt();Vt();_e();pT();tr.packedLength=4;tr.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.width,e[i++]=t.aspectRatio,e[i++]=t.near,e[i]=t.far,e};tr.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new tr),i.width=t[e++],i.aspectRatio=t[e++],i.near=t[e++],i.far=t[e],i};Object.defineProperties(tr.prototype,{projectionMatrix:{get:function(){return lc(this),this._offCenterFrustum.projectionMatrix}},offCenterFrustum:{get:function(){return lc(this),this._offCenterFrustum}}});tr.prototype.computeCullingVolume=function(t,e,i){return lc(this),this._offCenterFrustum.computeCullingVolume(t,e,i)};tr.prototype.getPixelDimensions=function(t,e,i,n,s){return lc(this),this._offCenterFrustum.getPixelDimensions(t,e,i,n,s)};tr.prototype.clone=function(t){return m(t)||(t=new tr),t.aspectRatio=this.aspectRatio,t.width=this.width,t.near=this.near,t.far=this.far,t._aspectRatio=void 0,t._width=void 0,t._near=void 0,t._far=void 0,this._offCenterFrustum.clone(t._offCenterFrustum),t};tr.prototype.equals=function(t){return!m(t)||!(t instanceof tr)?!1:(lc(this),lc(t),this.width===t.width&&this.aspectRatio===t.aspectRatio&&this._offCenterFrustum.equals(t._offCenterFrustum))};tr.prototype.equalsEpsilon=function(t,e,i){return!m(t)||!(t instanceof tr)?!1:(lc(this),lc(t),L.equalsEpsilon(this.width,t.width,e,i)&&L.equalsEpsilon(this.aspectRatio,t.aspectRatio,e,i)&&this._offCenterFrustum.equalsEpsilon(t._offCenterFrustum,e,i))};js=tr});function uE(t,e,i,n){let s=i.viewMatrix,o=at.multiplyByVector(s,ie.fromElements(t.x,t.y,t.z,1,sD),sD),r=l.multiplyComponents(e,l.normalize(o,oD),oD);return o.x+=e.x+r.x,o.y+=e.y+r.y,o.z+=r.z,at.multiplyByVector(i.frustum.projectionMatrix,o,n)}var eo,_$,Zo,R$,uT,CT,sD,oD,Z$,I$,p$,sh,u$,rD,aD,AD,C$,hD,Gm,gT=O(()=>{Er();Xe();Ht();Vs();ri();mt();Vt();_e();Fi();$Z();pT();fr();ua();eo={},_$=new ie(0,0,0,1),Zo=new ie,R$=new mi,uT=new nt,CT=new nt;eo.wgs84ToWindowCoordinates=function(t,e,i){return eo.wgs84WithEyeOffsetToWindowCoordinates(t,e,l.ZERO,i)};sD=new ie,oD=new l;Z$=new ut(Math.PI,L.PI_OVER_TWO),I$=new l,p$=new l;eo.wgs84WithEyeOffsetToWindowCoordinates=function(t,e,i,n){if(!m(t))throw new Y("scene is required.");if(!m(e))throw new Y("position is required.");let s=t.frameState,o=eo.computeActualWgs84Position(s,e,_$);if(!m(o))return;let r=t.canvas,a=R$;a.x=0,a.y=0,a.width=r.clientWidth,a.height=r.clientHeight;let h=t.camera,A=!1;if(s.mode===ye.SCENE2D){let d=t.mapProjection,f=Z$,E=d.project(f,I$),_=l.clone(h.position,p$),R=h.frustum.clone(),I=at.computeViewportTransformation(a,0,1,new at),C=h.frustum.projectionMatrix,N=h.positionWC.y,T=l.fromElements(L.sign(N)*E.x-N,0,-h.positionWC.x),F=In.pointToGLWindowCoordinates(C,I,T);if(N===0||F.x<=0||F.x>=r.clientWidth)A=!0;else{if(F.x>r.clientWidth*.5){a.width=F.x,h.frustum.right=E.x-N,Zo=uE(o,i,h,Zo),eo.clipToGLWindowCoordinates(a,Zo,uT),a.x+=F.x,h.position.x=-h.position.x;let b=h.frustum.right;h.frustum.right=-h.frustum.left,h.frustum.left=-b,Zo=uE(o,i,h,Zo),eo.clipToGLWindowCoordinates(a,Zo,CT)}else{a.x+=F.x,a.width-=F.x,h.frustum.left=-E.x-N,Zo=uE(o,i,h,Zo),eo.clipToGLWindowCoordinates(a,Zo,uT),a.x=a.x-a.width,h.position.x=-h.position.x;let b=h.frustum.left;h.frustum.left=-h.frustum.right,h.frustum.right=-b,Zo=uE(o,i,h,Zo),eo.clipToGLWindowCoordinates(a,Zo,CT)}l.clone(_,h.position),h.frustum=R.clone(),n=nt.clone(uT,n),(n.x<0||n.x>r.clientWidth)&&(n.x=CT.x)}}if(s.mode!==ye.SCENE2D||A){if(Zo=uE(o,i,h,Zo),Zo.z<0&&!(h.frustum instanceof js)&&!(h.frustum instanceof qZ))return;n=eo.clipToGLWindowCoordinates(a,Zo,n)}return n.y=r.clientHeight-n.y,n};eo.wgs84ToDrawingBufferCoordinates=function(t,e,i){if(i=eo.wgs84ToWindowCoordinates(t,e,i),!!m(i))return eo.transformWindowToDrawingBuffer(t,i,i)};sh=new l,u$=new ut;eo.computeActualWgs84Position=function(t,e,i){let n=t.mode;if(n===ye.SCENE3D)return l.clone(e,i);let s=t.mapProjection,o=s.ellipsoid.cartesianToCartographic(e,u$);if(!m(o))return;if(s.project(o,sh),n===ye.COLUMBUS_VIEW)return l.fromElements(sh.z,sh.x,sh.y,i);if(n===ye.SCENE2D)return l.fromElements(0,sh.x,sh.y,i);let r=t.morphTime;return l.fromElements(L.lerp(sh.z,e.x,r),L.lerp(sh.x,e.y,r),L.lerp(sh.y,e.z,r),i)};rD=new l,aD=new l,AD=new at;eo.clipToGLWindowCoordinates=function(t,e,i){return l.divideByScalar(e,e.w,rD),at.computeViewportTransformation(t,0,1,AD),at.multiplyByPoint(AD,rD,aD),nt.fromCartesian3(aD,i)};eo.transformWindowToDrawingBuffer=function(t,e,i){let n=t.canvas,s=t.drawingBufferWidth/n.clientWidth,o=t.drawingBufferHeight/n.clientHeight;return nt.fromElements(e.x*s,e.y*o,i)};C$=new ie,hD=new ie;eo.drawingBufferToWgs84Coordinates=function(t,e,i,n){let o=t.context.uniformState,r=o.currentFrustum,a=r.x,h=r.y;if(t.frameState.useLogDepth){let _=i*o.log2FarDepthFromNearPlusOne,R=Math.pow(2,_)-1;i=h*(1-a/(R+a))/(h-a)}let A=t.view.passState.viewport,d=ie.clone(ie.UNIT_W,C$);d.x=(e.x-A.x)/A.width*2-1,d.y=(e.y-A.y)/A.height*2-1,d.z=i*2-1,d.w=1;let f,E=t.camera.frustum;if(m(E.fovy)){f=at.multiplyByVector(o.inverseViewProjection,d,hD);let _=1/f.w;l.multiplyByScalar(f,_,f)}else{let _=E.offCenterFrustum;m(_)&&(E=_),f=hD,f.x=(d.x*(E.right-E.left)+E.left+E.right)*.5,f.y=(d.y*(E.top-E.bottom)+E.bottom+E.top)*.5,f.z=(d.z*(a-h)-a-h)*.5,f.w=1,f=at.multiplyByVector(o.inverseView,f,f)}return l.fromCartesian4(f,n)};Gm=eo});var g$,mn,CE=O(()=>{g$={CENTER:0,BOTTOM:1,BASELINE:2,TOP:-1},mn=Object.freeze(g$)});function Ti(t,e){if(t=Z(t,Z.EMPTY_OBJECT),m(t.disableDepthTestDistance)&&t.disableDepthTestDistance<0)throw new Y("disableDepthTestDistance must be greater than or equal to 0.0.");let i=t.translucencyByDistance,n=t.pixelOffsetScaleByDistance,s=t.scaleByDistance,o=t.distanceDisplayCondition;if(m(i)){if(i.far<=i.near)throw new Y("translucencyByDistance.far must be greater than translucencyByDistance.near.");i=gi.clone(i)}if(m(n)){if(n.far<=n.near)throw new Y("pixelOffsetScaleByDistance.far must be greater than pixelOffsetScaleByDistance.near.");n=gi.clone(n)}if(m(s)){if(s.far<=s.near)throw new Y("scaleByDistance.far must be greater than scaleByDistance.near.");s=gi.clone(s)}if(m(o)){if(o.far<=o.near)throw new Y("distanceDisplayCondition.far must be greater than distanceDisplayCondition.near.");o=Wo.clone(o)}this._show=Z(t.show,!0),this._position=l.clone(Z(t.position,l.ZERO)),this._actualPosition=l.clone(this._position),this._pixelOffset=nt.clone(Z(t.pixelOffset,nt.ZERO)),this._translate=new nt(0,0),this._eyeOffset=l.clone(Z(t.eyeOffset,l.ZERO)),this._heightReference=Z(t.heightReference,Wr.NONE),this._verticalOrigin=Z(t.verticalOrigin,mn.CENTER),this._horizontalOrigin=Z(t.horizontalOrigin,to.CENTER),this._scale=Z(t.scale,1),this._color=Zt.clone(Z(t.color,Zt.WHITE)),this._rotation=Z(t.rotation,0),this._alignedAxis=l.clone(Z(t.alignedAxis,l.ZERO)),this._width=t.width,this._height=t.height,this._scaleByDistance=s,this._translucencyByDistance=i,this._pixelOffsetScaleByDistance=n,this._sizeInMeters=Z(t.sizeInMeters,!1),this._distanceDisplayCondition=o,this._disableDepthTestDistance=t.disableDepthTestDistance,this._id=t.id,this._collection=Z(t.collection,e),this._pickId=void 0,this._pickPrimitive=Z(t._pickPrimitive,this),this._billboardCollection=e,this._dirty=!1,this._index=-1,this._batchIndex=void 0,this._imageIndex=-1,this._imageIndexPromise=void 0,this._imageId=void 0,this._image=void 0,this._imageSubRegion=void 0,this._imageWidth=void 0,this._imageHeight=void 0,this._labelDimensions=void 0,this._labelHorizontalOrigin=void 0,this._labelTranslate=void 0;let r=t.image,a=t.imageId;m(r)&&(m(a)||(typeof r=="string"?a=r:m(r.src)?a=r.src:a=Gs()),this._imageId=a,this._image=r),m(t.imageSubRegion)&&(this._imageId=a,this._imageSubRegion=t.imageSubRegion),m(this._billboardCollection._textureAtlas)&&this._loadImage(),this._actualClampedPosition=void 0,this._removeCallbackFunc=void 0,this._mode=ye.SCENE3D,this._clusterShow=!0,this._outlineColor=Zt.clone(Z(t.outlineColor,Zt.BLACK)),this._outlineWidth=Z(t.outlineWidth,0),this._updateClamping()}function Fn(t,e){let i=t._billboardCollection;m(i)&&(i._updateBillboard(t,e),t._dirty=!0)}var cD,eI,fD,T$,N$,b$,F$,iI,lD,Y$,S$,O$,V$,G$,B$,W$,dD,nI,mD,ED,tI,un,sI=O(()=>{Er();Xe();Ht();Vs();ri();ae();Qn();ih();bt();mt();Vt();zZ();Ve();Fi();IE();Ia();Om();Vm();ua();gT();CE();cD=Ti.SHOW_INDEX=0,eI=Ti.POSITION_INDEX=1,fD=Ti.PIXEL_OFFSET_INDEX=2,T$=Ti.EYE_OFFSET_INDEX=3,N$=Ti.HORIZONTAL_ORIGIN_INDEX=4,b$=Ti.VERTICAL_ORIGIN_INDEX=5,F$=Ti.SCALE_INDEX=6,iI=Ti.IMAGE_INDEX_INDEX=7,lD=Ti.COLOR_INDEX=8,Y$=Ti.ROTATION_INDEX=9,S$=Ti.ALIGNED_AXIS_INDEX=10,O$=Ti.SCALE_BY_DISTANCE_INDEX=11,V$=Ti.TRANSLUCENCY_BY_DISTANCE_INDEX=12,G$=Ti.PIXEL_OFFSET_SCALE_BY_DISTANCE_INDEX=13,B$=Ti.DISTANCE_DISPLAY_CONDITION=14,W$=Ti.DISABLE_DEPTH_DISTANCE=15;Ti.TEXTURE_COORDINATE_BOUNDS=16;dD=Ti.SDF_INDEX=17;Ti.NUMBER_OF_PROPERTIES=18;Object.defineProperties(Ti.prototype,{show:{get:function(){return this._show},set:function(t){p.typeOf.bool("value",t),this._show!==t&&(this._show=t,Fn(this,cD))}},position:{get:function(){return this._position},set:function(t){p.typeOf.object("value",t);let e=this._position;l.equals(e,t)||(l.clone(t,e),l.clone(t,this._actualPosition),this._updateClamping(),Fn(this,eI))}},heightReference:{get:function(){return this._heightReference},set:function(t){p.typeOf.number("value",t);let e=this._heightReference;t!==e&&(this._heightReference=t,this._updateClamping(),Fn(this,eI))}},pixelOffset:{get:function(){return this._pixelOffset},set:function(t){p.typeOf.object("value",t);let e=this._pixelOffset;nt.equals(e,t)||(nt.clone(t,e),Fn(this,fD))}},scaleByDistance:{get:function(){return this._scaleByDistance},set:function(t){if(m(t)&&(p.typeOf.object("value",t),t.far<=t.near))throw new Y("far distance must be greater than near distance.");let e=this._scaleByDistance;gi.equals(e,t)||(this._scaleByDistance=gi.clone(t,e),Fn(this,O$))}},translucencyByDistance:{get:function(){return this._translucencyByDistance},set:function(t){if(m(t)&&(p.typeOf.object("value",t),t.far<=t.near))throw new Y("far distance must be greater than near distance.");let e=this._translucencyByDistance;gi.equals(e,t)||(this._translucencyByDistance=gi.clone(t,e),Fn(this,V$))}},pixelOffsetScaleByDistance:{get:function(){return this._pixelOffsetScaleByDistance},set:function(t){if(m(t)&&(p.typeOf.object("value",t),t.far<=t.near))throw new Y("far distance must be greater than near distance.");let e=this._pixelOffsetScaleByDistance;gi.equals(e,t)||(this._pixelOffsetScaleByDistance=gi.clone(t,e),Fn(this,G$))}},eyeOffset:{get:function(){return this._eyeOffset},set:function(t){p.typeOf.object("value",t);let e=this._eyeOffset;l.equals(e,t)||(l.clone(t,e),Fn(this,T$))}},horizontalOrigin:{get:function(){return this._horizontalOrigin},set:function(t){p.typeOf.number("value",t),this._horizontalOrigin!==t&&(this._horizontalOrigin=t,Fn(this,N$))}},verticalOrigin:{get:function(){return this._verticalOrigin},set:function(t){p.typeOf.number("value",t),this._verticalOrigin!==t&&(this._verticalOrigin=t,Fn(this,b$))}},scale:{get:function(){return this._scale},set:function(t){p.typeOf.number("value",t),this._scale!==t&&(this._scale=t,Fn(this,F$))}},color:{get:function(){return this._color},set:function(t){p.typeOf.object("value",t);let e=this._color;Zt.equals(e,t)||(Zt.clone(t,e),Fn(this,lD))}},rotation:{get:function(){return this._rotation},set:function(t){p.typeOf.number("value",t),this._rotation!==t&&(this._rotation=t,Fn(this,Y$))}},alignedAxis:{get:function(){return this._alignedAxis},set:function(t){p.typeOf.object("value",t);let e=this._alignedAxis;l.equals(e,t)||(l.clone(t,e),Fn(this,S$))}},width:{get:function(){return Z(this._width,this._imageWidth)},set:function(t){m(t)&&p.typeOf.number("value",t),this._width!==t&&(this._width=t,Fn(this,iI))}},height:{get:function(){return Z(this._height,this._imageHeight)},set:function(t){m(t)&&p.typeOf.number("value",t),this._height!==t&&(this._height=t,Fn(this,iI))}},sizeInMeters:{get:function(){return this._sizeInMeters},set:function(t){p.typeOf.bool("value",t),this._sizeInMeters!==t&&(this._sizeInMeters=t,Fn(this,lD))}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){if(!Wo.equals(t,this._distanceDisplayCondition)){if(m(t)&&(p.typeOf.object("value",t),t.far<=t.near))throw new Y("far distance must be greater than near distance.");this._distanceDisplayCondition=Wo.clone(t,this._distanceDisplayCondition),Fn(this,B$)}}},disableDepthTestDistance:{get:function(){return this._disableDepthTestDistance},set:function(t){if(m(t)&&(p.typeOf.number("value",t),t<0))throw new Y("disableDepthTestDistance must be greater than or equal to 0.0.");this._disableDepthTestDistance!==t&&(this._disableDepthTestDistance=t,Fn(this,W$))}},id:{get:function(){return this._id},set:function(t){this._id=t,m(this._pickId)&&(this._pickId.object.id=t)}},pickPrimitive:{get:function(){return this._pickPrimitive},set:function(t){this._pickPrimitive=t,m(this._pickId)&&(this._pickId.object.primitive=t)}},pickId:{get:function(){return this._pickId}},image:{get:function(){return this._imageId},set:function(t){m(t)?typeof t=="string"?this.setImage(t,t):t instanceof tn?this.setImage(t.url,t):m(t.src)?this.setImage(t.src,t):this.setImage(Gs(),t):(this._imageIndex=-1,this._imageSubRegion=void 0,this._imageId=void 0,this._image=void 0,this._imageIndexPromise=void 0,Fn(this,iI))}},ready:{get:function(){return this._imageIndex!==-1}},_clampedPosition:{get:function(){return this._actualClampedPosition},set:function(t){this._actualClampedPosition=l.clone(t,this._actualClampedPosition),Fn(this,eI)}},clusterShow:{get:function(){return this._clusterShow},set:function(t){this._clusterShow!==t&&(this._clusterShow=t,Fn(this,cD))}},outlineColor:{get:function(){return this._outlineColor},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._outlineColor;Zt.equals(e,t)||(Zt.clone(t,e),Fn(this,dD))}},outlineWidth:{get:function(){return this._outlineWidth},set:function(t){this._outlineWidth!==t&&(this._outlineWidth=t,Fn(this,dD))}}});Ti.prototype.getPickId=function(t){return m(this._pickId)||(this._pickId=t.createPickId({primitive:this._pickPrimitive,collection:this._collection,id:this._id})),this._pickId};Ti.prototype._updateClamping=function(){Ti._updateClamping(this._billboardCollection,this)};nI=new ut;Ti._updateClamping=function(t,e){let i=t._scene;if(!m(i)){if(e._heightReference!==Wr.NONE)throw new Y("Height reference is not supported without a scene.");return}let n=i.globe,s=Z(n?.ellipsoid,ot.WGS84),o=i.frameState.mode,r=o!==e._mode;if(e._mode=o,(e._heightReference===Wr.NONE||r)&&m(e._removeCallbackFunc)&&(e._removeCallbackFunc(),e._removeCallbackFunc=void 0,e._clampedPosition=void 0),e._heightReference===Wr.NONE||!m(e._position))return;m(e._removeCallbackFunc)&&e._removeCallbackFunc();let a=s.cartesianToCartographic(e._position);if(!m(a)){e._actualClampedPosition=void 0;return}function h(d){let f=s.cartographicToCartesian(d,e._clampedPosition);eD(e._heightReference)&&(e._mode===ye.SCENE3D?(d.height+=a.height,s.cartographicToCartesian(d,f)):f.x+=a.height),e._clampedPosition=f}e._removeCallbackFunc=i.updateHeight(a,h,e._heightReference),ut.clone(a,nI);let A=i.getHeight(a,e._heightReference);m(A)&&(nI.height=A),h(nI)};Ti.prototype._loadImage=function(){let t=this._billboardCollection._textureAtlas,e=this._imageId,i=this._image,n=this._imageSubRegion,s,o=this;function r(h){if(o._imageId!==e||o._image!==i||!mi.equals(o._imageSubRegion,n))return;let A=t.textureCoordinates[h];o._imageWidth=t.texture.width*A.width,o._imageHeight=t.texture.height*A.height,o._imageIndex=h,o._ready=!0,o._image=void 0,o._imageIndexPromise=void 0,Fn(o,iI);let d=o._billboardCollection._scene;m(d)&&d.frameState.afterRender.push(()=>!0)}if(m(i)&&(s=t.addImage(e,i)),m(n)&&(s=t.addSubRegion(e,n)),this._imageIndexPromise=s,!m(s))return;let a=t.getImageIndex(e);if(m(a)&&!m(n)){r(a);return}s.then(r).catch(function(h){console.error(`Error loading image for billboard: ${h}`),o._imageIndexPromise=void 0})};Ti.prototype.setImage=function(t,e){if(!m(t))throw new Y("id is required.");if(!m(e))throw new Y("image is required.");this._imageId!==t&&(this._imageIndex=-1,this._imageSubRegion=void 0,this._imageId=t,this._image=e,m(this._billboardCollection._textureAtlas)&&this._loadImage())};Ti.prototype.setImageSubRegion=function(t,e){if(!m(t))throw new Y("id is required.");if(!m(e))throw new Y("subRegion is required.");this._imageId===t&&mi.equals(this._imageSubRegion,e)||(this._imageIndex=-1,this._imageId=t,this._imageSubRegion=mi.clone(e),m(this._billboardCollection._textureAtlas)&&this._loadImage())};Ti.prototype._setTranslate=function(t){if(!m(t))throw new Y("value is required.");let e=this._translate;nt.equals(e,t)||(nt.clone(t,e),Fn(this,fD))};Ti.prototype._getActualPosition=function(){return m(this._clampedPosition)?this._clampedPosition:this._actualPosition};Ti.prototype._setActualPosition=function(t){m(this._clampedPosition)||l.clone(t,this._actualPosition),Fn(this,eI)};mD=new ie;Ti._computeActualPosition=function(t,e,i,n){return m(t._clampedPosition)?(i.mode!==t._mode&&t._updateClamping(),t._clampedPosition):i.mode===ye.SCENE3D?e:(at.multiplyByPoint(n,e,mD),Gm.computeActualWgs84Position(i,mD))};ED=new l;Ti._computeScreenSpacePosition=function(t,e,i,n,s,o){let r=at.multiplyByPoint(t,e,ED),a=Gm.wgs84WithEyeOffsetToWindowCoordinates(s,r,i,o);if(m(a))return nt.add(a,n,a),a};tI=new nt(0,0);Ti.prototype.computeScreenSpacePosition=function(t,e){let i=this._billboardCollection;if(m(e)||(e=new nt),!m(i))throw new Y("Billboard must be in a collection.  Was it removed?");if(!m(t))throw new Y("scene is required.");nt.clone(this._pixelOffset,tI),nt.add(tI,this._translate,tI);let n=i.modelMatrix,s=this._position;if(m(this._clampedPosition)&&(s=this._clampedPosition,t.mode!==ye.SCENE3D)){let r=t.mapProjection,a=r.ellipsoid,h=r.unproject(s,nI);s=a.cartographicToCartesian(h,ED),n=at.IDENTITY}return Ti._computeScreenSpacePosition(n,s,this._eyeOffset,tI,t,e)};Ti.getScreenSpaceBoundingBox=function(t,e,i){let n=t.width,s=t.height,o=t.scale;n*=o,s*=o;let r=e.x;t.horizontalOrigin===to.RIGHT?r-=n:t.horizontalOrigin===to.CENTER&&(r-=n*.5);let a=e.y;return t.verticalOrigin===mn.BOTTOM||t.verticalOrigin===mn.BASELINE?a-=s:t.verticalOrigin===mn.CENTER&&(a-=s*.5),m(i)||(i=new mi),i.x=r,i.y=a,i.width=n,i.height=s,i};Ti.prototype.equals=function(t){return this===t||m(t)&&this._id===t._id&&l.equals(this._position,t._position)&&this._imageId===t._imageId&&this._show===t._show&&this._scale===t._scale&&this._verticalOrigin===t._verticalOrigin&&this._horizontalOrigin===t._horizontalOrigin&&this._heightReference===t._heightReference&&mi.equals(this._imageSubRegion,t._imageSubRegion)&&Zt.equals(this._color,t._color)&&nt.equals(this._pixelOffset,t._pixelOffset)&&nt.equals(this._translate,t._translate)&&l.equals(this._eyeOffset,t._eyeOffset)&&gi.equals(this._scaleByDistance,t._scaleByDistance)&&gi.equals(this._translucencyByDistance,t._translucencyByDistance)&&gi.equals(this._pixelOffsetScaleByDistance,t._pixelOffsetScaleByDistance)&&Wo.equals(this._distanceDisplayCondition,t._distanceDisplayCondition)&&this._disableDepthTestDistance===t._disableDepthTestDistance};Ti.prototype._destroy=function(){m(this._customData)&&(this._billboardCollection._scene.globe._surface.removeTileCustomData(this._customData),this._customData=void 0),m(this._removeCallbackFunc)&&(this._removeCallbackFunc(),this._removeCallbackFunc=void 0),this.image=void 0,this._pickId=this._pickId&&this._pickId.destroy(),this._billboardCollection=void 0};un=Ti});var D$,it,ss=O(()=>{D$={DEPTH_BUFFER_BIT:256,STENCIL_BUFFER_BIT:1024,COLOR_BUFFER_BIT:16384,POINTS:0,LINES:1,LINE_LOOP:2,LINE_STRIP:3,TRIANGLES:4,TRIANGLE_STRIP:5,TRIANGLE_FAN:6,ZERO:0,ONE:1,SRC_COLOR:768,ONE_MINUS_SRC_COLOR:769,SRC_ALPHA:770,ONE_MINUS_SRC_ALPHA:771,DST_ALPHA:772,ONE_MINUS_DST_ALPHA:773,DST_COLOR:774,ONE_MINUS_DST_COLOR:775,SRC_ALPHA_SATURATE:776,FUNC_ADD:32774,BLEND_EQUATION:32777,BLEND_EQUATION_RGB:32777,BLEND_EQUATION_ALPHA:34877,FUNC_SUBTRACT:32778,FUNC_REVERSE_SUBTRACT:32779,BLEND_DST_RGB:32968,BLEND_SRC_RGB:32969,BLEND_DST_ALPHA:32970,BLEND_SRC_ALPHA:32971,CONSTANT_COLOR:32769,ONE_MINUS_CONSTANT_COLOR:32770,CONSTANT_ALPHA:32771,ONE_MINUS_CONSTANT_ALPHA:32772,BLEND_COLOR:32773,ARRAY_BUFFER:34962,ELEMENT_ARRAY_BUFFER:34963,ARRAY_BUFFER_BINDING:34964,ELEMENT_ARRAY_BUFFER_BINDING:34965,STREAM_DRAW:35040,STATIC_DRAW:35044,DYNAMIC_DRAW:35048,BUFFER_SIZE:34660,BUFFER_USAGE:34661,CURRENT_VERTEX_ATTRIB:34342,FRONT:1028,BACK:1029,FRONT_AND_BACK:1032,CULL_FACE:2884,BLEND:3042,DITHER:3024,STENCIL_TEST:2960,DEPTH_TEST:2929,SCISSOR_TEST:3089,POLYGON_OFFSET_FILL:32823,SAMPLE_ALPHA_TO_COVERAGE:32926,SAMPLE_COVERAGE:32928,NO_ERROR:0,INVALID_ENUM:1280,INVALID_VALUE:1281,INVALID_OPERATION:1282,OUT_OF_MEMORY:1285,CW:2304,CCW:2305,LINE_WIDTH:2849,ALIASED_POINT_SIZE_RANGE:33901,ALIASED_LINE_WIDTH_RANGE:33902,CULL_FACE_MODE:2885,FRONT_FACE:2886,DEPTH_RANGE:2928,DEPTH_WRITEMASK:2930,DEPTH_CLEAR_VALUE:2931,DEPTH_FUNC:2932,STENCIL_CLEAR_VALUE:2961,STENCIL_FUNC:2962,STENCIL_FAIL:2964,STENCIL_PASS_DEPTH_FAIL:2965,STENCIL_PASS_DEPTH_PASS:2966,STENCIL_REF:2967,STENCIL_VALUE_MASK:2963,STENCIL_WRITEMASK:2968,STENCIL_BACK_FUNC:34816,STENCIL_BACK_FAIL:34817,STENCIL_BACK_PASS_DEPTH_FAIL:34818,STENCIL_BACK_PASS_DEPTH_PASS:34819,STENCIL_BACK_REF:36003,STENCIL_BACK_VALUE_MASK:36004,STENCIL_BACK_WRITEMASK:36005,VIEWPORT:2978,SCISSOR_BOX:3088,COLOR_CLEAR_VALUE:3106,COLOR_WRITEMASK:3107,UNPACK_ALIGNMENT:3317,PACK_ALIGNMENT:3333,MAX_TEXTURE_SIZE:3379,MAX_VIEWPORT_DIMS:3386,SUBPIXEL_BITS:3408,RED_BITS:3410,GREEN_BITS:3411,BLUE_BITS:3412,ALPHA_BITS:3413,DEPTH_BITS:3414,STENCIL_BITS:3415,POLYGON_OFFSET_UNITS:10752,POLYGON_OFFSET_FACTOR:32824,TEXTURE_BINDING_2D:32873,SAMPLE_BUFFERS:32936,SAMPLES:32937,SAMPLE_COVERAGE_VALUE:32938,SAMPLE_COVERAGE_INVERT:32939,COMPRESSED_TEXTURE_FORMATS:34467,DONT_CARE:4352,FASTEST:4353,NICEST:4354,GENERATE_MIPMAP_HINT:33170,BYTE:5120,UNSIGNED_BYTE:5121,SHORT:5122,UNSIGNED_SHORT:5123,INT:5124,UNSIGNED_INT:5125,FLOAT:5126,DEPTH_COMPONENT:6402,ALPHA:6406,RGB:6407,RGBA:6408,LUMINANCE:6409,LUMINANCE_ALPHA:6410,UNSIGNED_SHORT_4_4_4_4:32819,UNSIGNED_SHORT_5_5_5_1:32820,UNSIGNED_SHORT_5_6_5:33635,FRAGMENT_SHADER:35632,VERTEX_SHADER:35633,MAX_VERTEX_ATTRIBS:34921,MAX_VERTEX_UNIFORM_VECTORS:36347,MAX_VARYING_VECTORS:36348,MAX_COMBINED_TEXTURE_IMAGE_UNITS:35661,MAX_VERTEX_TEXTURE_IMAGE_UNITS:35660,MAX_TEXTURE_IMAGE_UNITS:34930,MAX_FRAGMENT_UNIFORM_VECTORS:36349,SHADER_TYPE:35663,DELETE_STATUS:35712,LINK_STATUS:35714,VALIDATE_STATUS:35715,ATTACHED_SHADERS:35717,ACTIVE_UNIFORMS:35718,ACTIVE_ATTRIBUTES:35721,SHADING_LANGUAGE_VERSION:35724,CURRENT_PROGRAM:35725,NEVER:512,LESS:513,EQUAL:514,LEQUAL:515,GREATER:516,NOTEQUAL:517,GEQUAL:518,ALWAYS:519,KEEP:7680,REPLACE:7681,INCR:7682,DECR:7683,INVERT:5386,INCR_WRAP:34055,DECR_WRAP:34056,VENDOR:7936,RENDERER:7937,VERSION:7938,NEAREST:9728,LINEAR:9729,NEAREST_MIPMAP_NEAREST:9984,LINEAR_MIPMAP_NEAREST:9985,NEAREST_MIPMAP_LINEAR:9986,LINEAR_MIPMAP_LINEAR:9987,TEXTURE_MAG_FILTER:10240,TEXTURE_MIN_FILTER:10241,TEXTURE_WRAP_S:10242,TEXTURE_WRAP_T:10243,TEXTURE_2D:3553,TEXTURE:5890,TEXTURE_CUBE_MAP:34067,TEXTURE_BINDING_CUBE_MAP:34068,TEXTURE_CUBE_MAP_POSITIVE_X:34069,TEXTURE_CUBE_MAP_NEGATIVE_X:34070,TEXTURE_CUBE_MAP_POSITIVE_Y:34071,TEXTURE_CUBE_MAP_NEGATIVE_Y:34072,TEXTURE_CUBE_MAP_POSITIVE_Z:34073,TEXTURE_CUBE_MAP_NEGATIVE_Z:34074,MAX_CUBE_MAP_TEXTURE_SIZE:34076,TEXTURE0:33984,TEXTURE1:33985,TEXTURE2:33986,TEXTURE3:33987,TEXTURE4:33988,TEXTURE5:33989,TEXTURE6:33990,TEXTURE7:33991,TEXTURE8:33992,TEXTURE9:33993,TEXTURE10:33994,TEXTURE11:33995,TEXTURE12:33996,TEXTURE13:33997,TEXTURE14:33998,TEXTURE15:33999,TEXTURE16:34e3,TEXTURE17:34001,TEXTURE18:34002,TEXTURE19:34003,TEXTURE20:34004,TEXTURE21:34005,TEXTURE22:34006,TEXTURE23:34007,TEXTURE24:34008,TEXTURE25:34009,TEXTURE26:34010,TEXTURE27:34011,TEXTURE28:34012,TEXTURE29:34013,TEXTURE30:34014,TEXTURE31:34015,ACTIVE_TEXTURE:34016,REPEAT:10497,CLAMP_TO_EDGE:33071,MIRRORED_REPEAT:33648,FLOAT_VEC2:35664,FLOAT_VEC3:35665,FLOAT_VEC4:35666,INT_VEC2:35667,INT_VEC3:35668,INT_VEC4:35669,BOOL:35670,BOOL_VEC2:35671,BOOL_VEC3:35672,BOOL_VEC4:35673,FLOAT_MAT2:35674,FLOAT_MAT3:35675,FLOAT_MAT4:35676,SAMPLER_2D:35678,SAMPLER_CUBE:35680,VERTEX_ATTRIB_ARRAY_ENABLED:34338,VERTEX_ATTRIB_ARRAY_SIZE:34339,VERTEX_ATTRIB_ARRAY_STRIDE:34340,VERTEX_ATTRIB_ARRAY_TYPE:34341,VERTEX_ATTRIB_ARRAY_NORMALIZED:34922,VERTEX_ATTRIB_ARRAY_POINTER:34373,VERTEX_ATTRIB_ARRAY_BUFFER_BINDING:34975,IMPLEMENTATION_COLOR_READ_TYPE:35738,IMPLEMENTATION_COLOR_READ_FORMAT:35739,COMPILE_STATUS:35713,LOW_FLOAT:36336,MEDIUM_FLOAT:36337,HIGH_FLOAT:36338,LOW_INT:36339,MEDIUM_INT:36340,HIGH_INT:36341,FRAMEBUFFER:36160,RENDERBUFFER:36161,RGBA4:32854,RGB5_A1:32855,RGB565:36194,DEPTH_COMPONENT16:33189,STENCIL_INDEX:6401,STENCIL_INDEX8:36168,DEPTH_STENCIL:34041,RENDERBUFFER_WIDTH:36162,RENDERBUFFER_HEIGHT:36163,RENDERBUFFER_INTERNAL_FORMAT:36164,RENDERBUFFER_RED_SIZE:36176,RENDERBUFFER_GREEN_SIZE:36177,RENDERBUFFER_BLUE_SIZE:36178,RENDERBUFFER_ALPHA_SIZE:36179,RENDERBUFFER_DEPTH_SIZE:36180,RENDERBUFFER_STENCIL_SIZE:36181,FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE:36048,FRAMEBUFFER_ATTACHMENT_OBJECT_NAME:36049,FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL:36050,FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE:36051,COLOR_ATTACHMENT0:36064,DEPTH_ATTACHMENT:36096,STENCIL_ATTACHMENT:36128,DEPTH_STENCIL_ATTACHMENT:33306,NONE:0,FRAMEBUFFER_COMPLETE:36053,FRAMEBUFFER_INCOMPLETE_ATTACHMENT:36054,FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:36055,FRAMEBUFFER_INCOMPLETE_DIMENSIONS:36057,FRAMEBUFFER_UNSUPPORTED:36061,FRAMEBUFFER_BINDING:36006,RENDERBUFFER_BINDING:36007,MAX_RENDERBUFFER_SIZE:34024,INVALID_FRAMEBUFFER_OPERATION:1286,UNPACK_FLIP_Y_WEBGL:37440,UNPACK_PREMULTIPLY_ALPHA_WEBGL:37441,CONTEXT_LOST_WEBGL:37442,UNPACK_COLORSPACE_CONVERSION_WEBGL:37443,BROWSER_DEFAULT_WEBGL:37444,COMPRESSED_RGB_S3TC_DXT1_EXT:33776,COMPRESSED_RGBA_S3TC_DXT1_EXT:33777,COMPRESSED_RGBA_S3TC_DXT3_EXT:33778,COMPRESSED_RGBA_S3TC_DXT5_EXT:33779,COMPRESSED_RGB_PVRTC_4BPPV1_IMG:35840,COMPRESSED_RGB_PVRTC_2BPPV1_IMG:35841,COMPRESSED_RGBA_PVRTC_4BPPV1_IMG:35842,COMPRESSED_RGBA_PVRTC_2BPPV1_IMG:35843,COMPRESSED_RGBA_ASTC_4x4_WEBGL:37808,COMPRESSED_RGB_ETC1_WEBGL:36196,COMPRESSED_RGBA_BPTC_UNORM:36492,HALF_FLOAT_OES:36193,DOUBLE:5130,READ_BUFFER:3074,UNPACK_ROW_LENGTH:3314,UNPACK_SKIP_ROWS:3315,UNPACK_SKIP_PIXELS:3316,PACK_ROW_LENGTH:3330,PACK_SKIP_ROWS:3331,PACK_SKIP_PIXELS:3332,COLOR:6144,DEPTH:6145,STENCIL:6146,RED:6403,RGB8:32849,RGBA8:32856,RGB10_A2:32857,TEXTURE_BINDING_3D:32874,UNPACK_SKIP_IMAGES:32877,UNPACK_IMAGE_HEIGHT:32878,TEXTURE_3D:32879,TEXTURE_WRAP_R:32882,MAX_3D_TEXTURE_SIZE:32883,UNSIGNED_INT_2_10_10_10_REV:33640,MAX_ELEMENTS_VERTICES:33e3,MAX_ELEMENTS_INDICES:33001,TEXTURE_MIN_LOD:33082,TEXTURE_MAX_LOD:33083,TEXTURE_BASE_LEVEL:33084,TEXTURE_MAX_LEVEL:33085,MIN:32775,MAX:32776,DEPTH_COMPONENT24:33190,MAX_TEXTURE_LOD_BIAS:34045,TEXTURE_COMPARE_MODE:34892,TEXTURE_COMPARE_FUNC:34893,CURRENT_QUERY:34917,QUERY_RESULT:34918,QUERY_RESULT_AVAILABLE:34919,STREAM_READ:35041,STREAM_COPY:35042,STATIC_READ:35045,STATIC_COPY:35046,DYNAMIC_READ:35049,DYNAMIC_COPY:35050,MAX_DRAW_BUFFERS:34852,DRAW_BUFFER0:34853,DRAW_BUFFER1:34854,DRAW_BUFFER2:34855,DRAW_BUFFER3:34856,DRAW_BUFFER4:34857,DRAW_BUFFER5:34858,DRAW_BUFFER6:34859,DRAW_BUFFER7:34860,DRAW_BUFFER8:34861,DRAW_BUFFER9:34862,DRAW_BUFFER10:34863,DRAW_BUFFER11:34864,DRAW_BUFFER12:34865,DRAW_BUFFER13:34866,DRAW_BUFFER14:34867,DRAW_BUFFER15:34868,MAX_FRAGMENT_UNIFORM_COMPONENTS:35657,MAX_VERTEX_UNIFORM_COMPONENTS:35658,SAMPLER_3D:35679,SAMPLER_2D_SHADOW:35682,FRAGMENT_SHADER_DERIVATIVE_HINT:35723,PIXEL_PACK_BUFFER:35051,PIXEL_UNPACK_BUFFER:35052,PIXEL_PACK_BUFFER_BINDING:35053,PIXEL_UNPACK_BUFFER_BINDING:35055,FLOAT_MAT2x3:35685,FLOAT_MAT2x4:35686,FLOAT_MAT3x2:35687,FLOAT_MAT3x4:35688,FLOAT_MAT4x2:35689,FLOAT_MAT4x3:35690,SRGB:35904,SRGB8:35905,SRGB8_ALPHA8:35907,COMPARE_REF_TO_TEXTURE:34894,RGBA32F:34836,RGB32F:34837,RGBA16F:34842,RGB16F:34843,VERTEX_ATTRIB_ARRAY_INTEGER:35069,MAX_ARRAY_TEXTURE_LAYERS:35071,MIN_PROGRAM_TEXEL_OFFSET:35076,MAX_PROGRAM_TEXEL_OFFSET:35077,MAX_VARYING_COMPONENTS:35659,TEXTURE_2D_ARRAY:35866,TEXTURE_BINDING_2D_ARRAY:35869,R11F_G11F_B10F:35898,UNSIGNED_INT_10F_11F_11F_REV:35899,RGB9_E5:35901,UNSIGNED_INT_5_9_9_9_REV:35902,TRANSFORM_FEEDBACK_BUFFER_MODE:35967,MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS:35968,TRANSFORM_FEEDBACK_VARYINGS:35971,TRANSFORM_FEEDBACK_BUFFER_START:35972,TRANSFORM_FEEDBACK_BUFFER_SIZE:35973,TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN:35976,RASTERIZER_DISCARD:35977,MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS:35978,MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS:35979,INTERLEAVED_ATTRIBS:35980,SEPARATE_ATTRIBS:35981,TRANSFORM_FEEDBACK_BUFFER:35982,TRANSFORM_FEEDBACK_BUFFER_BINDING:35983,RGBA32UI:36208,RGB32UI:36209,RGBA16UI:36214,RGB16UI:36215,RGBA8UI:36220,RGB8UI:36221,RGBA32I:36226,RGB32I:36227,RGBA16I:36232,RGB16I:36233,RGBA8I:36238,RGB8I:36239,RED_INTEGER:36244,RGB_INTEGER:36248,RGBA_INTEGER:36249,SAMPLER_2D_ARRAY:36289,SAMPLER_2D_ARRAY_SHADOW:36292,SAMPLER_CUBE_SHADOW:36293,UNSIGNED_INT_VEC2:36294,UNSIGNED_INT_VEC3:36295,UNSIGNED_INT_VEC4:36296,INT_SAMPLER_2D:36298,INT_SAMPLER_3D:36299,INT_SAMPLER_CUBE:36300,INT_SAMPLER_2D_ARRAY:36303,UNSIGNED_INT_SAMPLER_2D:36306,UNSIGNED_INT_SAMPLER_3D:36307,UNSIGNED_INT_SAMPLER_CUBE:36308,UNSIGNED_INT_SAMPLER_2D_ARRAY:36311,DEPTH_COMPONENT32F:36012,DEPTH32F_STENCIL8:36013,FLOAT_32_UNSIGNED_INT_24_8_REV:36269,FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING:33296,FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE:33297,FRAMEBUFFER_ATTACHMENT_RED_SIZE:33298,FRAMEBUFFER_ATTACHMENT_GREEN_SIZE:33299,FRAMEBUFFER_ATTACHMENT_BLUE_SIZE:33300,FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE:33301,FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE:33302,FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE:33303,FRAMEBUFFER_DEFAULT:33304,UNSIGNED_INT_24_8:34042,DEPTH24_STENCIL8:35056,UNSIGNED_NORMALIZED:35863,DRAW_FRAMEBUFFER_BINDING:36006,READ_FRAMEBUFFER:36008,DRAW_FRAMEBUFFER:36009,READ_FRAMEBUFFER_BINDING:36010,RENDERBUFFER_SAMPLES:36011,FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER:36052,MAX_COLOR_ATTACHMENTS:36063,COLOR_ATTACHMENT1:36065,COLOR_ATTACHMENT2:36066,COLOR_ATTACHMENT3:36067,COLOR_ATTACHMENT4:36068,COLOR_ATTACHMENT5:36069,COLOR_ATTACHMENT6:36070,COLOR_ATTACHMENT7:36071,COLOR_ATTACHMENT8:36072,COLOR_ATTACHMENT9:36073,COLOR_ATTACHMENT10:36074,COLOR_ATTACHMENT11:36075,COLOR_ATTACHMENT12:36076,COLOR_ATTACHMENT13:36077,COLOR_ATTACHMENT14:36078,COLOR_ATTACHMENT15:36079,FRAMEBUFFER_INCOMPLETE_MULTISAMPLE:36182,MAX_SAMPLES:36183,HALF_FLOAT:5131,RG:33319,RG_INTEGER:33320,R8:33321,RG8:33323,R16F:33325,R32F:33326,RG16F:33327,RG32F:33328,R8I:33329,R8UI:33330,R16I:33331,R16UI:33332,R32I:33333,R32UI:33334,RG8I:33335,RG8UI:33336,RG16I:33337,RG16UI:33338,RG32I:33339,RG32UI:33340,VERTEX_ARRAY_BINDING:34229,R8_SNORM:36756,RG8_SNORM:36757,RGB8_SNORM:36758,RGBA8_SNORM:36759,SIGNED_NORMALIZED:36764,COPY_READ_BUFFER:36662,COPY_WRITE_BUFFER:36663,COPY_READ_BUFFER_BINDING:36662,COPY_WRITE_BUFFER_BINDING:36663,UNIFORM_BUFFER:35345,UNIFORM_BUFFER_BINDING:35368,UNIFORM_BUFFER_START:35369,UNIFORM_BUFFER_SIZE:35370,MAX_VERTEX_UNIFORM_BLOCKS:35371,MAX_FRAGMENT_UNIFORM_BLOCKS:35373,MAX_COMBINED_UNIFORM_BLOCKS:35374,MAX_UNIFORM_BUFFER_BINDINGS:35375,MAX_UNIFORM_BLOCK_SIZE:35376,MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS:35377,MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS:35379,UNIFORM_BUFFER_OFFSET_ALIGNMENT:35380,ACTIVE_UNIFORM_BLOCKS:35382,UNIFORM_TYPE:35383,UNIFORM_SIZE:35384,UNIFORM_BLOCK_INDEX:35386,UNIFORM_OFFSET:35387,UNIFORM_ARRAY_STRIDE:35388,UNIFORM_MATRIX_STRIDE:35389,UNIFORM_IS_ROW_MAJOR:35390,UNIFORM_BLOCK_BINDING:35391,UNIFORM_BLOCK_DATA_SIZE:35392,UNIFORM_BLOCK_ACTIVE_UNIFORMS:35394,UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES:35395,UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER:35396,UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER:35398,INVALID_INDEX:4294967295,MAX_VERTEX_OUTPUT_COMPONENTS:37154,MAX_FRAGMENT_INPUT_COMPONENTS:37157,MAX_SERVER_WAIT_TIMEOUT:37137,OBJECT_TYPE:37138,SYNC_CONDITION:37139,SYNC_STATUS:37140,SYNC_FLAGS:37141,SYNC_FENCE:37142,SYNC_GPU_COMMANDS_COMPLETE:37143,UNSIGNALED:37144,SIGNALED:37145,ALREADY_SIGNALED:37146,TIMEOUT_EXPIRED:37147,CONDITION_SATISFIED:37148,WAIT_FAILED:37149,SYNC_FLUSH_COMMANDS_BIT:1,VERTEX_ATTRIB_ARRAY_DIVISOR:35070,ANY_SAMPLES_PASSED:35887,ANY_SAMPLES_PASSED_CONSERVATIVE:36202,SAMPLER_BINDING:35097,RGB10_A2UI:36975,INT_2_10_10_10_REV:36255,TRANSFORM_FEEDBACK:36386,TRANSFORM_FEEDBACK_PAUSED:36387,TRANSFORM_FEEDBACK_ACTIVE:36388,TRANSFORM_FEEDBACK_BINDING:36389,COMPRESSED_R11_EAC:37488,COMPRESSED_SIGNED_R11_EAC:37489,COMPRESSED_RG11_EAC:37490,COMPRESSED_SIGNED_RG11_EAC:37491,COMPRESSED_RGB8_ETC2:37492,COMPRESSED_SRGB8_ETC2:37493,COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2:37494,COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2:37495,COMPRESSED_RGBA8_ETC2_EAC:37496,COMPRESSED_SRGB8_ALPHA8_ETC2_EAC:37497,TEXTURE_IMMUTABLE_FORMAT:37167,MAX_ELEMENT_INDEX:36203,TEXTURE_IMMUTABLE_LEVELS:33503,MAX_TEXTURE_MAX_ANISOTROPY_EXT:34047},it=Object.freeze(D$)});var xe,At,oi=O(()=>{bt();mt();Vt();ss();xe={BYTE:it.BYTE,UNSIGNED_BYTE:it.UNSIGNED_BYTE,SHORT:it.SHORT,UNSIGNED_SHORT:it.UNSIGNED_SHORT,INT:it.INT,UNSIGNED_INT:it.UNSIGNED_INT,FLOAT:it.FLOAT,DOUBLE:it.DOUBLE};xe.getSizeInBytes=function(t){if(!m(t))throw new Y("value is required.");switch(t){case xe.BYTE:return Int8Array.BYTES_PER_ELEMENT;case xe.UNSIGNED_BYTE:return Uint8Array.BYTES_PER_ELEMENT;case xe.SHORT:return Int16Array.BYTES_PER_ELEMENT;case xe.UNSIGNED_SHORT:return Uint16Array.BYTES_PER_ELEMENT;case xe.INT:return Int32Array.BYTES_PER_ELEMENT;case xe.UNSIGNED_INT:return Uint32Array.BYTES_PER_ELEMENT;case xe.FLOAT:return Float32Array.BYTES_PER_ELEMENT;case xe.DOUBLE:return Float64Array.BYTES_PER_ELEMENT;default:throw new Y("componentDatatype is not a valid value.")}};xe.fromTypedArray=function(t){if(t instanceof Int8Array)return xe.BYTE;if(t instanceof Uint8Array)return xe.UNSIGNED_BYTE;if(t instanceof Int16Array)return xe.SHORT;if(t instanceof Uint16Array)return xe.UNSIGNED_SHORT;if(t instanceof Int32Array)return xe.INT;if(t instanceof Uint32Array)return xe.UNSIGNED_INT;if(t instanceof Float32Array)return xe.FLOAT;if(t instanceof Float64Array)return xe.DOUBLE;throw new Y("array must be an Int8Array, Uint8Array, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, or Float64Array.")};xe.validate=function(t){return m(t)&&(t===xe.BYTE||t===xe.UNSIGNED_BYTE||t===xe.SHORT||t===xe.UNSIGNED_SHORT||t===xe.INT||t===xe.UNSIGNED_INT||t===xe.FLOAT||t===xe.DOUBLE)};xe.createTypedArray=function(t,e){if(!m(t))throw new Y("componentDatatype is required.");if(!m(e))throw new Y("valuesOrLength is required.");switch(t){case xe.BYTE:return new Int8Array(e);case xe.UNSIGNED_BYTE:return new Uint8Array(e);case xe.SHORT:return new Int16Array(e);case xe.UNSIGNED_SHORT:return new Uint16Array(e);case xe.INT:return new Int32Array(e);case xe.UNSIGNED_INT:return new Uint32Array(e);case xe.FLOAT:return new Float32Array(e);case xe.DOUBLE:return new Float64Array(e);default:throw new Y("componentDatatype is not a valid value.")}};xe.createArrayBufferView=function(t,e,i,n){if(!m(t))throw new Y("componentDatatype is required.");if(!m(e))throw new Y("buffer is required.");switch(i=Z(i,0),n=Z(n,(e.byteLength-i)/xe.getSizeInBytes(t)),t){case xe.BYTE:return new Int8Array(e,i,n);case xe.UNSIGNED_BYTE:return new Uint8Array(e,i,n);case xe.SHORT:return new Int16Array(e,i,n);case xe.UNSIGNED_SHORT:return new Uint16Array(e,i,n);case xe.INT:return new Int32Array(e,i,n);case xe.UNSIGNED_INT:return new Uint32Array(e,i,n);case xe.FLOAT:return new Float32Array(e,i,n);case xe.DOUBLE:return new Float64Array(e,i,n);default:throw new Y("componentDatatype is not a valid value.")}};xe.fromName=function(t){switch(t){case"BYTE":return xe.BYTE;case"UNSIGNED_BYTE":return xe.UNSIGNED_BYTE;case"SHORT":return xe.SHORT;case"UNSIGNED_SHORT":return xe.UNSIGNED_SHORT;case"INT":return xe.INT;case"UNSIGNED_INT":return xe.UNSIGNED_INT;case"FLOAT":return xe.FLOAT;case"DOUBLE":return xe.DOUBLE;default:throw new Y("name is not a valid value.")}};At=Object.freeze(xe)});function Te(t,e,i,n){this[0]=Z(t,0),this[1]=Z(i,0),this[2]=Z(e,0),this[3]=Z(n,0)}var M$,U$,_D,RD,Q$,k$,Hn,dc=O(()=>{Xe();ae();bt();mt();Vt();Te.packedLength=4;Te.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t[0],e[i++]=t[1],e[i++]=t[2],e[i++]=t[3],e};Te.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Te),i[0]=t[e++],i[1]=t[e++],i[2]=t[e++],i[3]=t[e++],i};Te.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*4;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 4 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)Te.pack(t[s],e,s*4);return e};Te.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,4),t.length%4!==0)throw new Y("array length must be a multiple of 4.");let i=t.length;m(e)?e.length=i/4:e=new Array(i/4);for(let n=0;n<i;n+=4){let s=n/4;e[s]=Te.unpack(t,n,e[s])}return e};Te.clone=function(t,e){if(m(t))return m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e):new Te(t[0],t[2],t[1],t[3])};Te.fromArray=Te.unpack;Te.fromColumnMajorArray=function(t,e){return p.defined("values",t),Te.clone(t,e)};Te.fromRowMajorArray=function(t,e){return p.defined("values",t),m(e)?(e[0]=t[0],e[1]=t[2],e[2]=t[1],e[3]=t[3],e):new Te(t[0],t[1],t[2],t[3])};Te.fromScale=function(t,e){return p.typeOf.object("scale",t),m(e)?(e[0]=t.x,e[1]=0,e[2]=0,e[3]=t.y,e):new Te(t.x,0,0,t.y)};Te.fromUniformScale=function(t,e){return p.typeOf.number("scale",t),m(e)?(e[0]=t,e[1]=0,e[2]=0,e[3]=t,e):new Te(t,0,0,t)};Te.fromRotation=function(t,e){p.typeOf.number("angle",t);let i=Math.cos(t),n=Math.sin(t);return m(e)?(e[0]=i,e[1]=n,e[2]=-n,e[3]=i,e):new Te(i,-n,n,i)};Te.toArray=function(t,e){return p.typeOf.object("matrix",t),m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e):[t[0],t[1],t[2],t[3]]};Te.getElementIndex=function(t,e){return p.typeOf.number.greaterThanOrEquals("row",e,0),p.typeOf.number.lessThanOrEquals("row",e,1),p.typeOf.number.greaterThanOrEquals("column",t,0),p.typeOf.number.lessThanOrEquals("column",t,1),t*2+e};Te.getColumn=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,1),p.typeOf.object("result",i);let n=e*2,s=t[n],o=t[n+1];return i.x=s,i.y=o,i};Te.setColumn=function(t,e,i,n){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,1),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=Te.clone(t,n);let s=e*2;return n[s]=i.x,n[s+1]=i.y,n};Te.getRow=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,1),p.typeOf.object("result",i);let n=t[e],s=t[e+2];return i.x=n,i.y=s,i};Te.setRow=function(t,e,i,n){return p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,1),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=Te.clone(t,n),n[e]=i.x,n[e+2]=i.y,n};M$=new nt;Te.setScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i);let n=Te.getScale(t,M$),s=e.x/n.x,o=e.y/n.y;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*o,i[3]=t[3]*o,i};U$=new nt;Te.setUniformScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i);let n=Te.getScale(t,U$),s=e/n.x,o=e/n.y;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*o,i[3]=t[3]*o,i};_D=new nt;Te.getScale=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e.x=nt.magnitude(nt.fromElements(t[0],t[1],_D)),e.y=nt.magnitude(nt.fromElements(t[2],t[3],_D)),e};RD=new nt;Te.getMaximumScale=function(t){return Te.getScale(t,RD),nt.maximumComponent(RD)};Q$=new nt;Te.setRotation=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("result",i);let n=Te.getScale(t,Q$);return i[0]=e[0]*n.x,i[1]=e[1]*n.x,i[2]=e[2]*n.y,i[3]=e[3]*n.y,i};k$=new nt;Te.getRotation=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=Te.getScale(t,k$);return e[0]=t[0]/i.x,e[1]=t[1]/i.x,e[2]=t[2]/i.y,e[3]=t[3]/i.y,e};Te.multiply=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t[0]*e[0]+t[2]*e[1],s=t[0]*e[2]+t[2]*e[3],o=t[1]*e[0]+t[3]*e[1],r=t[1]*e[2]+t[3]*e[3];return i[0]=n,i[1]=o,i[2]=s,i[3]=r,i};Te.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]+e[0],i[1]=t[1]+e[1],i[2]=t[2]+e[2],i[3]=t[3]+e[3],i};Te.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]-e[0],i[1]=t[1]-e[1],i[2]=t[2]-e[2],i[3]=t[3]-e[3],i};Te.multiplyByVector=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("cartesian",e),p.typeOf.object("result",i);let n=t[0]*e.x+t[2]*e.y,s=t[1]*e.x+t[3]*e.y;return i.x=n,i.y=s,i};Te.multiplyByScalar=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3]*e,i};Te.multiplyByScale=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i),i[0]=t[0]*e.x,i[1]=t[1]*e.x,i[2]=t[2]*e.y,i[3]=t[3]*e.y,i};Te.multiplyByUniformScale=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3]*e,i};Te.negate=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=-t[0],e[1]=-t[1],e[2]=-t[2],e[3]=-t[3],e};Te.transpose=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[0],n=t[2],s=t[1],o=t[3];return e[0]=i,e[1]=n,e[2]=s,e[3]=o,e};Te.abs=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=Math.abs(t[0]),e[1]=Math.abs(t[1]),e[2]=Math.abs(t[2]),e[3]=Math.abs(t[3]),e};Te.equals=function(t,e){return t===e||m(t)&&m(e)&&t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]};Te.equalsArray=function(t,e,i){return t[0]===e[i]&&t[1]===e[i+1]&&t[2]===e[i+2]&&t[3]===e[i+3]};Te.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t[0]-e[0])<=i&&Math.abs(t[1]-e[1])<=i&&Math.abs(t[2]-e[2])<=i&&Math.abs(t[3]-e[3])<=i};Te.IDENTITY=Object.freeze(new Te(1,0,0,1));Te.ZERO=Object.freeze(new Te(0,0,0,0));Te.COLUMN0ROW0=0;Te.COLUMN0ROW1=1;Te.COLUMN1ROW0=2;Te.COLUMN1ROW1=3;Object.defineProperties(Te.prototype,{length:{get:function(){return Te.packedLength}}});Te.prototype.clone=function(t){return Te.clone(this,t)};Te.prototype.equals=function(t){return Te.equals(this,t)};Te.prototype.equalsEpsilon=function(t,e){return Te.equalsEpsilon(this,t,e)};Te.prototype.toString=function(){return`(${this[0]}, ${this[2]})
(${this[1]}, ${this[3]})`};Hn=Te});var Ji,ZD,ID=O(()=>{Xe();Ht();Vs();ae();Vt();dc();dn();Fi();Ji={SCALAR:"SCALAR",VEC2:"VEC2",VEC3:"VEC3",VEC4:"VEC4",MAT2:"MAT2",MAT3:"MAT3",MAT4:"MAT4"};Ji.getMathType=function(t){switch(t){case Ji.SCALAR:return Number;case Ji.VEC2:return nt;case Ji.VEC3:return l;case Ji.VEC4:return ie;case Ji.MAT2:return Hn;case Ji.MAT3:return lt;case Ji.MAT4:return at;default:throw new Y("attributeType is not a valid value.")}};Ji.getNumberOfComponents=function(t){switch(t){case Ji.SCALAR:return 1;case Ji.VEC2:return 2;case Ji.VEC3:return 3;case Ji.VEC4:case Ji.MAT2:return 4;case Ji.MAT3:return 9;case Ji.MAT4:return 16;default:throw new Y("attributeType is not a valid value.")}};Ji.getAttributeLocationCount=function(t){switch(t){case Ji.SCALAR:case Ji.VEC2:case Ji.VEC3:case Ji.VEC4:return 1;case Ji.MAT2:return 2;case Ji.MAT3:return 3;case Ji.MAT4:return 4;default:throw new Y("attributeType is not a valid value.")}};Ji.getGlslType=function(t){switch(p.typeOf.string("attributeType",t),t){case Ji.SCALAR:return"float";case Ji.VEC2:return"vec2";case Ji.VEC3:return"vec3";case Ji.VEC4:return"vec4";case Ji.MAT2:return"mat2";case Ji.MAT3:return"mat3";case Ji.MAT4:return"mat4";default:throw new Y("attributeType is not a valid value.")}};ZD=Object.freeze(Ji)});function oI(t){return CD[0]=t,CD[0]}function TT(t){return t>>1^-(t&1)}var pD,uD,rn,gE,CD,NT,Yi,oh=O(()=>{Xe();Ht();oi();ae();mt();Vt();_e();ID();pD=1/256,uD=256,rn={};rn.octEncodeInRange=function(t,e,i){p.defined("vector",t),p.defined("result",i);let n=l.magnitudeSquared(t);if(Math.abs(n-1)>L.EPSILON6)throw new Y("vector must be normalized.");if(i.x=t.x/(Math.abs(t.x)+Math.abs(t.y)+Math.abs(t.z)),i.y=t.y/(Math.abs(t.x)+Math.abs(t.y)+Math.abs(t.z)),t.z<0){let s=i.x,o=i.y;i.x=(1-Math.abs(o))*L.signNotZero(s),i.y=(1-Math.abs(s))*L.signNotZero(o)}return i.x=L.toSNorm(i.x,e),i.y=L.toSNorm(i.y,e),i};rn.octEncode=function(t,e){return rn.octEncodeInRange(t,255,e)};gE=new nt,CD=new Uint8Array(1);rn.octEncodeToCartesian4=function(t,e){return rn.octEncodeInRange(t,65535,gE),e.x=oI(gE.x*pD),e.y=oI(gE.x),e.z=oI(gE.y*pD),e.w=oI(gE.y),e};rn.octDecodeInRange=function(t,e,i,n){if(p.defined("result",n),t<0||t>i||e<0||e>i)throw new Y(`x and y must be unsigned normalized integers between 0 and ${i}`);if(n.x=L.fromSNorm(t,i),n.y=L.fromSNorm(e,i),n.z=1-(Math.abs(n.x)+Math.abs(n.y)),n.z<0){let s=n.x;n.x=(1-Math.abs(n.y))*L.signNotZero(s),n.y=(1-Math.abs(s))*L.signNotZero(n.y)}return l.normalize(n,n)};rn.octDecode=function(t,e,i){return rn.octDecodeInRange(t,e,255,i)};rn.octDecodeFromCartesian4=function(t,e){p.typeOf.object("encoded",t),p.typeOf.object("result",e);let i=t.x,n=t.y,s=t.z,o=t.w;if(i<0||i>255||n<0||n>255||s<0||s>255||o<0||o>255)throw new Y("x, y, z, and w must be unsigned normalized integers between 0 and 255");let r=i*uD+n,a=s*uD+o;return rn.octDecodeInRange(r,a,65535,e)};rn.octPackFloat=function(t){return p.defined("encoded",t),256*t.x+t.y};NT=new nt;rn.octEncodeFloat=function(t){return rn.octEncode(t,NT),rn.octPackFloat(NT)};rn.octDecodeFloat=function(t,e){p.defined("value",t);let i=t/256,n=Math.floor(i),s=(i-n)*256;return rn.octDecode(n,s,e)};rn.octPack=function(t,e,i,n){p.defined("v1",t),p.defined("v2",e),p.defined("v3",i),p.defined("result",n);let s=rn.octEncodeFloat(t),o=rn.octEncodeFloat(e),r=rn.octEncode(i,NT);return n.x=65536*r.x+s,n.y=65536*r.y+o,n};rn.octUnpack=function(t,e,i,n){p.defined("packed",t),p.defined("v1",e),p.defined("v2",i),p.defined("v3",n);let s=t.x/65536,o=Math.floor(s),r=(s-o)*65536;s=t.y/65536;let a=Math.floor(s),h=(s-a)*65536;rn.octDecodeFloat(r,e),rn.octDecodeFloat(h,i),rn.octDecode(o,a,n)};rn.compressTextureCoordinates=function(t){p.defined("textureCoordinates",t);let e=t.x*4095|0,i=t.y*4095|0;return 4096*e+i};rn.decompressTextureCoordinates=function(t,e){p.defined("compressed",t),p.defined("result",e);let i=t/4096,n=Math.floor(i);return e.x=n/4095,e.y=(t-n*4096)/4095,e};rn.zigZagDeltaDecode=function(t,e,i){p.defined("uBuffer",t),p.defined("vBuffer",e),p.typeOf.number.equals("uBuffer.length","vBuffer.length",t.length,e.length),m(i)&&p.typeOf.number.equals("uBuffer.length","heightBuffer.length",t.length,i.length);let n=t.length,s=0,o=0,r=0;for(let a=0;a<n;++a)s+=TT(t[a]),o+=TT(e[a]),t[a]=s,e[a]=o,m(i)&&(r+=TT(i[a]),i[a]=r)};rn.dequantize=function(t,e,i,n){p.defined("typedArray",t),p.defined("componentDatatype",e),p.defined("type",i),p.defined("count",n);let s=ZD.getNumberOfComponents(i),o;switch(e){case At.BYTE:o=127;break;case At.UNSIGNED_BYTE:o=255;break;case At.SHORT:o=32767;break;case At.UNSIGNED_SHORT:o=65535;break;case At.INT:o=2147483647;break;case At.UNSIGNED_INT:o=4294967295;break;default:throw new Y(`Cannot dequantize component datatype: ${e}`)}let r=new Float32Array(n*s);for(let a=0;a<n;a++)for(let h=0;h<s;h++){let A=a*s+h;r[A]=Math.max(t[A]/o,-1)}return r};rn.decodeRGB565=function(t,e){p.defined("typedArray",t);let i=t.length*3;m(e)&&p.typeOf.number.equals("result.length","typedArray.length * 3",e.length,i);let n=t.length;m(e)||(e=new Float32Array(n*3));let s=31,o=63,r=1/31,a=1/63;for(let h=0;h<n;h++){let A=t[h],d=A>>11,f=A>>5&o,E=A&s,_=3*h;e[_]=d*r,e[_+1]=f*a,e[_+2]=E*r}return e};Yi=rn});function L$(){return!0}function y$(t,e){e=Z(e,"This object was destroyed, i.e., destroy() was called.");function i(){throw new Y(e)}for(let n in t)typeof t[n]=="function"&&(t[n]=i);t.isDestroyed=L$}var li,Ws=O(()=>{bt();Vt();li=y$});function fA(){this.high=l.clone(l.ZERO),this.low=l.clone(l.ZERO)}var rh,bT,Bn,Tl=O(()=>{Ht();ae();mt();fA.encode=function(t,e){p.typeOf.number("value",t),m(e)||(e={high:0,low:0});let i;return t>=0?(i=Math.floor(t/65536)*65536,e.high=i,e.low=t-i):(i=Math.floor(-t/65536)*65536,e.high=-i,e.low=t+i),e};rh={high:0,low:0};fA.fromCartesian=function(t,e){p.typeOf.object("cartesian",t),m(e)||(e=new fA);let i=e.high,n=e.low;return fA.encode(t.x,rh),i.x=rh.high,n.x=rh.low,fA.encode(t.y,rh),i.y=rh.high,n.y=rh.low,fA.encode(t.z,rh),i.z=rh.high,n.z=rh.low,e};bT=new fA;fA.writeElements=function(t,e,i){p.defined("cartesianArray",e),p.typeOf.number("index",i),p.typeOf.number.greaterThanOrEquals("index",i,0),fA.fromCartesian(t,bT);let n=bT.high,s=bT.low;e[i]=n.x,e[i+1]=n.y,e[i+2]=n.z,e[i+3]=s.x,e[i+4]=s.y,e[i+5]=s.z};Bn=fA});var Ds,te,Di=O(()=>{mt();Vt();_e();ss();Ds={UNSIGNED_BYTE:it.UNSIGNED_BYTE,UNSIGNED_SHORT:it.UNSIGNED_SHORT,UNSIGNED_INT:it.UNSIGNED_INT};Ds.getSizeInBytes=function(t){switch(t){case Ds.UNSIGNED_BYTE:return Uint8Array.BYTES_PER_ELEMENT;case Ds.UNSIGNED_SHORT:return Uint16Array.BYTES_PER_ELEMENT;case Ds.UNSIGNED_INT:return Uint32Array.BYTES_PER_ELEMENT}throw new Y("indexDatatype is required and must be a valid IndexDatatype constant.")};Ds.fromSizeInBytes=function(t){switch(t){case 2:return Ds.UNSIGNED_SHORT;case 4:return Ds.UNSIGNED_INT;case 1:return Ds.UNSIGNED_BYTE;default:throw new Y("Size in bytes cannot be mapped to an IndexDatatype")}};Ds.validate=function(t){return m(t)&&(t===Ds.UNSIGNED_BYTE||t===Ds.UNSIGNED_SHORT||t===Ds.UNSIGNED_INT)};Ds.createTypedArray=function(t,e){if(!m(t))throw new Y("numberOfVertices is required.");return t>=L.SIXTY_FOUR_KILOBYTES?new Uint32Array(e):new Uint16Array(e)};Ds.createTypedArrayFromArrayBuffer=function(t,e,i,n){if(!m(t))throw new Y("numberOfVertices is required.");if(!m(e))throw new Y("sourceArray is required.");if(!m(i))throw new Y("byteOffset is required.");return t>=L.SIXTY_FOUR_KILOBYTES?new Uint32Array(e,i,n):new Uint16Array(e,i,n)};Ds.fromTypedArray=function(t){if(t instanceof Uint8Array)return Ds.UNSIGNED_BYTE;if(t instanceof Uint16Array)return Ds.UNSIGNED_SHORT;if(t instanceof Uint32Array)return Ds.UNSIGNED_INT;throw new Y("array must be a Uint8Array, Uint16Array, or Uint32Array.")};te=Object.freeze(Ds)});var rI,ai,Nl=O(()=>{ss();rI={STREAM_DRAW:it.STREAM_DRAW,STATIC_DRAW:it.STATIC_DRAW,DYNAMIC_DRAW:it.DYNAMIC_DRAW,validate:function(t){return t===rI.STREAM_DRAW||t===rI.STATIC_DRAW||t===rI.DYNAMIC_DRAW}},ai=Object.freeze(rI)});function Mr(t){if(t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context),!m(t.typedArray)&&!m(t.sizeInBytes))throw new Y("Either options.sizeInBytes or options.typedArray is required.");if(m(t.typedArray)&&m(t.sizeInBytes))throw new Y("Cannot pass in both options.sizeInBytes and options.typedArray.");if(m(t.typedArray)&&(p.typeOf.object("options.typedArray",t.typedArray),p.typeOf.number("options.typedArray.byteLength",t.typedArray.byteLength)),!ai.validate(t.usage))throw new Y("usage is invalid.");let e=t.context._gl,i=t.bufferTarget,n=t.typedArray,s=t.sizeInBytes,o=t.usage,r=m(n);r&&(s=n.byteLength),p.typeOf.number.greaterThan("sizeInBytes",s,0);let a=e.createBuffer();e.bindBuffer(i,a),e.bufferData(i,r?n:s,o),e.bindBuffer(i,null),this._id=Gs(),this._gl=e,this._webgl2=t.context._webgl2,this._bufferTarget=i,this._sizeInBytes=s,this._usage=o,this._buffer=a,this.vertexArrayDestroyable=!0}var Ca,aI=O(()=>{ae();ih();bt();mt();Ws();Vt();Di();ss();Nl();Mr.createVertexBuffer=function(t){return p.defined("options.context",t.context),new Mr({context:t.context,bufferTarget:it.ARRAY_BUFFER,typedArray:t.typedArray,sizeInBytes:t.sizeInBytes,usage:t.usage})};Mr.createIndexBuffer=function(t){if(p.defined("options.context",t.context),!te.validate(t.indexDatatype))throw new Y("Invalid indexDatatype.");if(t.indexDatatype===te.UNSIGNED_INT&&!t.context.elementIndexUint)throw new Y("IndexDatatype.UNSIGNED_INT requires OES_element_index_uint, which is not supported on this system.  Check context.elementIndexUint.");let e=t.context,i=t.indexDatatype,n=te.getSizeInBytes(i),s=new Mr({context:e,bufferTarget:it.ELEMENT_ARRAY_BUFFER,typedArray:t.typedArray,sizeInBytes:t.sizeInBytes,usage:t.usage}),o=s.sizeInBytes/n;return Object.defineProperties(s,{indexDatatype:{get:function(){return i}},bytesPerIndex:{get:function(){return n}},numberOfIndices:{get:function(){return o}}}),s};Object.defineProperties(Mr.prototype,{sizeInBytes:{get:function(){return this._sizeInBytes}},usage:{get:function(){return this._usage}}});Mr.prototype._getBuffer=function(){return this._buffer};Mr.prototype.copyFromArrayView=function(t,e){e=Z(e,0),p.defined("arrayView",t),p.typeOf.number.lessThanOrEquals("offsetInBytes + arrayView.byteLength",e+t.byteLength,this._sizeInBytes);let i=this._gl,n=this._bufferTarget;i.bindBuffer(n,this._buffer),i.bufferSubData(n,e,t),i.bindBuffer(n,null)};Mr.prototype.copyFromBuffer=function(t,e,i,n){if(!this._webgl2)throw new Y("A WebGL 2 context is required.");if(!m(t))throw new Y("readBuffer must be defined.");if(!m(n)||n<=0)throw new Y("sizeInBytes must be defined and be greater than zero.");if(!m(e)||e<0||e+n>t._sizeInBytes)throw new Y("readOffset must be greater than or equal to zero and readOffset + sizeInBytes must be less than of equal to readBuffer.sizeInBytes.");if(!m(i)||i<0||i+n>this._sizeInBytes)throw new Y("writeOffset must be greater than or equal to zero and writeOffset + sizeInBytes must be less than of equal to this.sizeInBytes.");if(this._buffer===t._buffer&&(i>=e&&i<e+n||e>i&&e<i+n))throw new Y("When readBuffer is equal to this, the ranges [readOffset + sizeInBytes) and [writeOffset, writeOffset + sizeInBytes) must not overlap.");if(this._bufferTarget===it.ELEMENT_ARRAY_BUFFER&&t._bufferTarget!==it.ELEMENT_ARRAY_BUFFER||this._bufferTarget!==it.ELEMENT_ARRAY_BUFFER&&t._bufferTarget===it.ELEMENT_ARRAY_BUFFER)throw new Y("Can not copy an index buffer into another buffer type.");let s=it.COPY_READ_BUFFER,o=it.COPY_WRITE_BUFFER,r=this._gl;r.bindBuffer(o,this._buffer),r.bindBuffer(s,t._buffer),r.copyBufferSubData(s,o,e,i,n),r.bindBuffer(o,null),r.bindBuffer(s,null)};Mr.prototype.getBufferData=function(t,e,i,n){if(e=Z(e,0),i=Z(i,0),!this._webgl2)throw new Y("A WebGL 2 context is required.");if(!m(t))throw new Y("arrayView is required.");let s,o,r=t.byteLength;if(m(n)?(s=n,m(r)?o=1:(r=t.length,o=t.BYTES_PER_ELEMENT)):m(r)?(s=r-i,o=1):(r=t.length,s=r-i,o=t.BYTES_PER_ELEMENT),i<0||i>r)throw new Y("destinationOffset must be greater than zero and less than the arrayView length.");if(i+s>r)throw new Y("destinationOffset + length must be less than or equal to the arrayViewLength.");if(e<0||e>this._sizeInBytes)throw new Y("sourceOffset must be greater than zero and less than the buffers size.");if(e+s*o>this._sizeInBytes)throw new Y("sourceOffset + length must be less than the buffers size.");let a=this._gl,h=it.COPY_READ_BUFFER;a.bindBuffer(h,this._buffer),a.getBufferSubData(h,e,t,i,n),a.bindBuffer(h,null)};Mr.prototype.isDestroyed=function(){return!1};Mr.prototype.destroy=function(){return this._gl.deleteBuffer(this._buffer),li(this)};Ca=Mr});var vn,en,ga=O(()=>{vn={_maximumCombinedTextureImageUnits:0,_maximumCubeMapSize:0,_maximumFragmentUniformVectors:0,_maximumTextureImageUnits:0,_maximumRenderbufferSize:0,_maximumTextureSize:0,_maximumVaryingVectors:0,_maximumVertexAttributes:0,_maximumVertexTextureImageUnits:0,_maximumVertexUniformVectors:0,_minimumAliasedLineWidth:0,_maximumAliasedLineWidth:0,_minimumAliasedPointSize:0,_maximumAliasedPointSize:0,_maximumViewportWidth:0,_maximumViewportHeight:0,_maximumTextureFilterAnisotropy:0,_maximumDrawBuffers:0,_maximumColorAttachments:0,_maximumSamples:0,_highpFloatSupported:!1,_highpIntSupported:!1};Object.defineProperties(vn,{maximumCombinedTextureImageUnits:{get:function(){return vn._maximumCombinedTextureImageUnits}},maximumCubeMapSize:{get:function(){return vn._maximumCubeMapSize}},maximumFragmentUniformVectors:{get:function(){return vn._maximumFragmentUniformVectors}},maximumTextureImageUnits:{get:function(){return vn._maximumTextureImageUnits}},maximumRenderbufferSize:{get:function(){return vn._maximumRenderbufferSize}},maximumTextureSize:{get:function(){return vn._maximumTextureSize}},maximumVaryingVectors:{get:function(){return vn._maximumVaryingVectors}},maximumVertexAttributes:{get:function(){return vn._maximumVertexAttributes}},maximumVertexTextureImageUnits:{get:function(){return vn._maximumVertexTextureImageUnits}},maximumVertexUniformVectors:{get:function(){return vn._maximumVertexUniformVectors}},minimumAliasedLineWidth:{get:function(){return vn._minimumAliasedLineWidth}},maximumAliasedLineWidth:{get:function(){return vn._maximumAliasedLineWidth}},minimumAliasedPointSize:{get:function(){return vn._minimumAliasedPointSize}},maximumAliasedPointSize:{get:function(){return vn._maximumAliasedPointSize}},maximumViewportWidth:{get:function(){return vn._maximumViewportWidth}},maximumViewportHeight:{get:function(){return vn._maximumViewportHeight}},maximumTextureFilterAnisotropy:{get:function(){return vn._maximumTextureFilterAnisotropy}},maximumDrawBuffers:{get:function(){return vn._maximumDrawBuffers}},maximumColorAttachments:{get:function(){return vn._maximumColorAttachments}},maximumSamples:{get:function(){return vn._maximumSamples}},highpFloatSupported:{get:function(){return vn._highpFloatSupported}},highpIntSupported:{get:function(){return vn._highpIntSupported}}});en=vn});var io,ne,Xi=O(()=>{ss();io={POINTS:it.POINTS,LINES:it.LINES,LINE_LOOP:it.LINE_LOOP,LINE_STRIP:it.LINE_STRIP,TRIANGLES:it.TRIANGLES,TRIANGLE_STRIP:it.TRIANGLE_STRIP,TRIANGLE_FAN:it.TRIANGLE_FAN};io.isLines=function(t){return t===io.LINES||t===io.LINE_LOOP||t===io.LINE_STRIP};io.isTriangles=function(t){return t===io.TRIANGLES||t===io.TRIANGLE_STRIP||t===io.TRIANGLE_FAN};io.validate=function(t){return t===io.POINTS||t===io.LINES||t===io.LINE_LOOP||t===io.LINE_STRIP||t===io.TRIANGLES||t===io.TRIANGLE_STRIP||t===io.TRIANGLE_FAN};ne=Object.freeze(io)});function TE(t){t=Z(t,Z.EMPTY_OBJECT),this._boundingVolume=t.boundingVolume,this._orientedBoundingBox=t.orientedBoundingBox,this._modelMatrix=t.modelMatrix,this._primitiveType=Z(t.primitiveType,ne.TRIANGLES),this._vertexArray=t.vertexArray,this._count=t.count,this._offset=Z(t.offset,0),this._instanceCount=Z(t.instanceCount,0),this._shaderProgram=t.shaderProgram,this._uniformMap=t.uniformMap,this._renderState=t.renderState,this._framebuffer=t.framebuffer,this._pass=t.pass,this._owner=t.owner,this._debugOverlappingFrustums=0,this._pickId=t.pickId,this._flags=0,this.cull=Z(t.cull,!0),this.occlude=Z(t.occlude,!0),this.executeInClosestFrustum=Z(t.executeInClosestFrustum,!1),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.castShadows=Z(t.castShadows,!1),this.receiveShadows=Z(t.receiveShadows,!1),this.pickOnly=Z(t.pickOnly,!1),this.depthForTranslucentClassification=Z(t.depthForTranslucentClassification,!1),this.dirty=!0,this.lastDirtyTime=0,this.derivedCommands={}}function Io(t,e){return(t._flags&e)===e}function mc(t,e,i){i?t._flags|=e:t._flags&=~e}var zn,fn,Bm=O(()=>{bt();mt();Xi();zn={CULL:1,OCCLUDE:2,EXECUTE_IN_CLOSEST_FRUSTUM:4,DEBUG_SHOW_BOUNDING_VOLUME:8,CAST_SHADOWS:16,RECEIVE_SHADOWS:32,PICK_ONLY:64,DEPTH_FOR_TRANSLUCENT_CLASSIFICATION:128};Object.defineProperties(TE.prototype,{boundingVolume:{get:function(){return this._boundingVolume},set:function(t){this._boundingVolume!==t&&(this._boundingVolume=t,this.dirty=!0)}},orientedBoundingBox:{get:function(){return this._orientedBoundingBox},set:function(t){this._orientedBoundingBox!==t&&(this._orientedBoundingBox=t,this.dirty=!0)}},cull:{get:function(){return Io(this,zn.CULL)},set:function(t){Io(this,zn.CULL)!==t&&(mc(this,zn.CULL,t),this.dirty=!0)}},occlude:{get:function(){return Io(this,zn.OCCLUDE)},set:function(t){Io(this,zn.OCCLUDE)!==t&&(mc(this,zn.OCCLUDE,t),this.dirty=!0)}},modelMatrix:{get:function(){return this._modelMatrix},set:function(t){this._modelMatrix!==t&&(this._modelMatrix=t,this.dirty=!0)}},primitiveType:{get:function(){return this._primitiveType},set:function(t){this._primitiveType!==t&&(this._primitiveType=t,this.dirty=!0)}},vertexArray:{get:function(){return this._vertexArray},set:function(t){this._vertexArray!==t&&(this._vertexArray=t,this.dirty=!0)}},count:{get:function(){return this._count},set:function(t){this._count!==t&&(this._count=t,this.dirty=!0)}},offset:{get:function(){return this._offset},set:function(t){this._offset!==t&&(this._offset=t,this.dirty=!0)}},instanceCount:{get:function(){return this._instanceCount},set:function(t){this._instanceCount!==t&&(this._instanceCount=t,this.dirty=!0)}},shaderProgram:{get:function(){return this._shaderProgram},set:function(t){this._shaderProgram!==t&&(this._shaderProgram=t,this.dirty=!0)}},castShadows:{get:function(){return Io(this,zn.CAST_SHADOWS)},set:function(t){Io(this,zn.CAST_SHADOWS)!==t&&(mc(this,zn.CAST_SHADOWS,t),this.dirty=!0)}},receiveShadows:{get:function(){return Io(this,zn.RECEIVE_SHADOWS)},set:function(t){Io(this,zn.RECEIVE_SHADOWS)!==t&&(mc(this,zn.RECEIVE_SHADOWS,t),this.dirty=!0)}},uniformMap:{get:function(){return this._uniformMap},set:function(t){this._uniformMap!==t&&(this._uniformMap=t,this.dirty=!0)}},renderState:{get:function(){return this._renderState},set:function(t){this._renderState!==t&&(this._renderState=t,this.dirty=!0)}},framebuffer:{get:function(){return this._framebuffer},set:function(t){this._framebuffer!==t&&(this._framebuffer=t,this.dirty=!0)}},pass:{get:function(){return this._pass},set:function(t){this._pass!==t&&(this._pass=t,this.dirty=!0)}},executeInClosestFrustum:{get:function(){return Io(this,zn.EXECUTE_IN_CLOSEST_FRUSTUM)},set:function(t){Io(this,zn.EXECUTE_IN_CLOSEST_FRUSTUM)!==t&&(mc(this,zn.EXECUTE_IN_CLOSEST_FRUSTUM,t),this.dirty=!0)}},owner:{get:function(){return this._owner},set:function(t){this._owner!==t&&(this._owner=t,this.dirty=!0)}},debugShowBoundingVolume:{get:function(){return Io(this,zn.DEBUG_SHOW_BOUNDING_VOLUME)},set:function(t){Io(this,zn.DEBUG_SHOW_BOUNDING_VOLUME)!==t&&(mc(this,zn.DEBUG_SHOW_BOUNDING_VOLUME,t),this.dirty=!0)}},debugOverlappingFrustums:{get:function(){return this._debugOverlappingFrustums},set:function(t){this._debugOverlappingFrustums!==t&&(this._debugOverlappingFrustums=t,this.dirty=!0)}},pickId:{get:function(){return this._pickId},set:function(t){this._pickId!==t&&(this._pickId=t,this.dirty=!0)}},pickOnly:{get:function(){return Io(this,zn.PICK_ONLY)},set:function(t){Io(this,zn.PICK_ONLY)!==t&&(mc(this,zn.PICK_ONLY,t),this.dirty=!0)}},depthForTranslucentClassification:{get:function(){return Io(this,zn.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION)},set:function(t){Io(this,zn.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION)!==t&&(mc(this,zn.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION,t),this.dirty=!0)}}});TE.shallowClone=function(t,e){if(m(t))return m(e)||(e=new TE),e._boundingVolume=t._boundingVolume,e._orientedBoundingBox=t._orientedBoundingBox,e._modelMatrix=t._modelMatrix,e._primitiveType=t._primitiveType,e._vertexArray=t._vertexArray,e._count=t._count,e._offset=t._offset,e._instanceCount=t._instanceCount,e._shaderProgram=t._shaderProgram,e._uniformMap=t._uniformMap,e._renderState=t._renderState,e._framebuffer=t._framebuffer,e._pass=t._pass,e._owner=t._owner,e._debugOverlappingFrustums=t._debugOverlappingFrustums,e._pickId=t._pickId,e._flags=t._flags,e.dirty=!0,e.lastDirtyTime=0,e};TE.prototype.execute=function(t,e){t.draw(this,e)};fn=TE});var w$,os,Wm=O(()=>{w$={ENVIRONMENT:0,COMPUTE:1,GLOBE:2,TERRAIN_CLASSIFICATION:3,CESIUM_3D_TILE:4,CESIUM_3D_TILE_CLASSIFICATION:5,CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW:6,OPAQUE:7,TRANSLUCENT:8,VOXELS:9,OVERLAY:10,NUMBER_OF_PASSES:11},os=Object.freeze(w$)});var AI,Ms,fc=O(()=>{ss();AI={CLOCKWISE:it.CW,COUNTER_CLOCKWISE:it.CCW};AI.validate=function(t){return t===AI.CLOCKWISE||t===AI.COUNTER_CLOCKWISE};Ms=Object.freeze(AI)});function gD(t){if(typeof t!="object"||t===null)return t;let e,i=Object.keys(t);for(let n=0;n<i.length;n++)e=i[n],t.hasOwnProperty(e)&&e!=="_applyFunctions"&&(t[e]=gD(t[e]));return Object.freeze(t)}var TD,ND=O(()=>{TD=gD});function bD(t){return t===it.FUNC_ADD||t===it.FUNC_SUBTRACT||t===it.FUNC_REVERSE_SUBTRACT||t===it.MIN||t===it.MAX}function hI(t){return t===it.ZERO||t===it.ONE||t===it.SRC_COLOR||t===it.ONE_MINUS_SRC_COLOR||t===it.DST_COLOR||t===it.ONE_MINUS_DST_COLOR||t===it.SRC_ALPHA||t===it.ONE_MINUS_SRC_ALPHA||t===it.DST_ALPHA||t===it.ONE_MINUS_DST_ALPHA||t===it.CONSTANT_COLOR||t===it.ONE_MINUS_CONSTANT_COLOR||t===it.CONSTANT_ALPHA||t===it.ONE_MINUS_CONSTANT_ALPHA||t===it.SRC_ALPHA_SATURATE}function x$(t){return t===it.FRONT||t===it.BACK||t===it.FRONT_AND_BACK}function P$(t){return t===it.NEVER||t===it.LESS||t===it.EQUAL||t===it.LEQUAL||t===it.GREATER||t===it.NOTEQUAL||t===it.GEQUAL||t===it.ALWAYS}function FD(t){return t===it.NEVER||t===it.LESS||t===it.EQUAL||t===it.LEQUAL||t===it.GREATER||t===it.NOTEQUAL||t===it.GEQUAL||t===it.ALWAYS}function Dm(t){return t===it.ZERO||t===it.KEEP||t===it.REPLACE||t===it.INCR||t===it.DECR||t===it.INVERT||t===it.INCR_WRAP||t===it.DECR_WRAP}function _A(t){let e=Z(t,Z.EMPTY_OBJECT),i=Z(e.cull,Z.EMPTY_OBJECT),n=Z(e.polygonOffset,Z.EMPTY_OBJECT),s=Z(e.scissorTest,Z.EMPTY_OBJECT),o=Z(s.rectangle,Z.EMPTY_OBJECT),r=Z(e.depthRange,Z.EMPTY_OBJECT),a=Z(e.depthTest,Z.EMPTY_OBJECT),h=Z(e.colorMask,Z.EMPTY_OBJECT),A=Z(e.blending,Z.EMPTY_OBJECT),d=Z(A.color,Z.EMPTY_OBJECT),f=Z(e.stencilTest,Z.EMPTY_OBJECT),E=Z(f.frontOperation,Z.EMPTY_OBJECT),_=Z(f.backOperation,Z.EMPTY_OBJECT),R=Z(e.sampleCoverage,Z.EMPTY_OBJECT),I=e.viewport;if(this.frontFace=Z(e.frontFace,Ms.COUNTER_CLOCKWISE),this.cull={enabled:Z(i.enabled,!1),face:Z(i.face,it.BACK)},this.lineWidth=Z(e.lineWidth,1),this.polygonOffset={enabled:Z(n.enabled,!1),factor:Z(n.factor,0),units:Z(n.units,0)},this.scissorTest={enabled:Z(s.enabled,!1),rectangle:mi.clone(o)},this.depthRange={near:Z(r.near,0),far:Z(r.far,1)},this.depthTest={enabled:Z(a.enabled,!1),func:Z(a.func,it.LESS)},this.colorMask={red:Z(h.red,!0),green:Z(h.green,!0),blue:Z(h.blue,!0),alpha:Z(h.alpha,!0)},this.depthMask=Z(e.depthMask,!0),this.stencilMask=Z(e.stencilMask,-1),this.blending={enabled:Z(A.enabled,!1),color:new Zt(Z(d.red,0),Z(d.green,0),Z(d.blue,0),Z(d.alpha,0)),equationRgb:Z(A.equationRgb,it.FUNC_ADD),equationAlpha:Z(A.equationAlpha,it.FUNC_ADD),functionSourceRgb:Z(A.functionSourceRgb,it.ONE),functionSourceAlpha:Z(A.functionSourceAlpha,it.ONE),functionDestinationRgb:Z(A.functionDestinationRgb,it.ZERO),functionDestinationAlpha:Z(A.functionDestinationAlpha,it.ZERO)},this.stencilTest={enabled:Z(f.enabled,!1),frontFunction:Z(f.frontFunction,it.ALWAYS),backFunction:Z(f.backFunction,it.ALWAYS),reference:Z(f.reference,0),mask:Z(f.mask,-1),frontOperation:{fail:Z(E.fail,it.KEEP),zFail:Z(E.zFail,it.KEEP),zPass:Z(E.zPass,it.KEEP)},backOperation:{fail:Z(_.fail,it.KEEP),zFail:Z(_.zFail,it.KEEP),zPass:Z(_.zPass,it.KEEP)}},this.sampleCoverage={enabled:Z(R.enabled,!1),value:Z(R.value,1),invert:Z(R.invert,!1)},this.viewport=m(I)?new mi(I.x,I.y,I.width,I.height):void 0,this.lineWidth<en.minimumAliasedLineWidth||this.lineWidth>en.maximumAliasedLineWidth)throw new Y("renderState.lineWidth is out of range.  Check minimumAliasedLineWidth and maximumAliasedLineWidth.");if(!Ms.validate(this.frontFace))throw new Y("Invalid renderState.frontFace.");if(!x$(this.cull.face))throw new Y("Invalid renderState.cull.face.");if(this.scissorTest.rectangle.width<0||this.scissorTest.rectangle.height<0)throw new Y("renderState.scissorTest.rectangle.width and renderState.scissorTest.rectangle.height must be greater than or equal to zero.");if(this.depthRange.near>this.depthRange.far)throw new Y("renderState.depthRange.near can not be greater than renderState.depthRange.far.");if(this.depthRange.near<0)throw new Y("renderState.depthRange.near must be greater than or equal to zero.");if(this.depthRange.far>1)throw new Y("renderState.depthRange.far must be less than or equal to one.");if(!P$(this.depthTest.func))throw new Y("Invalid renderState.depthTest.func.");if(this.blending.color.red<0||this.blending.color.red>1||this.blending.color.green<0||this.blending.color.green>1||this.blending.color.blue<0||this.blending.color.blue>1||this.blending.color.alpha<0||this.blending.color.alpha>1)throw new Y("renderState.blending.color components must be greater than or equal to zero and less than or equal to one.");if(!bD(this.blending.equationRgb))throw new Y("Invalid renderState.blending.equationRgb.");if(!bD(this.blending.equationAlpha))throw new Y("Invalid renderState.blending.equationAlpha.");if(!hI(this.blending.functionSourceRgb))throw new Y("Invalid renderState.blending.functionSourceRgb.");if(!hI(this.blending.functionSourceAlpha))throw new Y("Invalid renderState.blending.functionSourceAlpha.");if(!hI(this.blending.functionDestinationRgb))throw new Y("Invalid renderState.blending.functionDestinationRgb.");if(!hI(this.blending.functionDestinationAlpha))throw new Y("Invalid renderState.blending.functionDestinationAlpha.");if(!FD(this.stencilTest.frontFunction))throw new Y("Invalid renderState.stencilTest.frontFunction.");if(!FD(this.stencilTest.backFunction))throw new Y("Invalid renderState.stencilTest.backFunction.");if(!Dm(this.stencilTest.frontOperation.fail))throw new Y("Invalid renderState.stencilTest.frontOperation.fail.");if(!Dm(this.stencilTest.frontOperation.zFail))throw new Y("Invalid renderState.stencilTest.frontOperation.zFail.");if(!Dm(this.stencilTest.frontOperation.zPass))throw new Y("Invalid renderState.stencilTest.frontOperation.zPass.");if(!Dm(this.stencilTest.backOperation.fail))throw new Y("Invalid renderState.stencilTest.backOperation.fail.");if(!Dm(this.stencilTest.backOperation.zFail))throw new Y("Invalid renderState.stencilTest.backOperation.zFail.");if(!Dm(this.stencilTest.backOperation.zPass))throw new Y("Invalid renderState.stencilTest.backOperation.zPass.");if(m(this.viewport)){if(this.viewport.width<0)throw new Y("renderState.viewport.width must be greater than or equal to zero.");if(this.viewport.height<0)throw new Y("renderState.viewport.height must be greater than or equal to zero.");if(this.viewport.width>en.maximumViewportWidth)throw new Y(`renderState.viewport.width must be less than or equal to the maximum viewport width (${en.maximumViewportWidth.toString()}).  Check maximumViewportWidth.`);if(this.viewport.height>en.maximumViewportHeight)throw new Y(`renderState.viewport.height must be less than or equal to the maximum viewport height (${en.maximumViewportHeight.toString()}).  Check maximumViewportHeight.`)}this.id=0,this._applyFunctions=[]}function bl(t,e,i){i?t.enable(e):t.disable(e)}function YD(t,e){t.frontFace(e.frontFace)}function SD(t,e){let i=e.cull,n=i.enabled;bl(t,t.CULL_FACE,n),n&&t.cullFace(i.face)}function OD(t,e){t.lineWidth(e.lineWidth)}function VD(t,e){let i=e.polygonOffset,n=i.enabled;bl(t,t.POLYGON_OFFSET_FILL,n),n&&t.polygonOffset(i.factor,i.units)}function GD(t,e,i){let n=e.scissorTest,s=m(i.scissorTest)?i.scissorTest.enabled:n.enabled;if(bl(t,t.SCISSOR_TEST,s),s){let o=m(i.scissorTest)?i.scissorTest.rectangle:n.rectangle;t.scissor(o.x,o.y,o.width,o.height)}}function BD(t,e){let i=e.depthRange;t.depthRange(i.near,i.far)}function WD(t,e){let i=e.depthTest,n=i.enabled;bl(t,t.DEPTH_TEST,n),n&&t.depthFunc(i.func)}function DD(t,e){let i=e.colorMask;t.colorMask(i.red,i.green,i.blue,i.alpha)}function MD(t,e){t.depthMask(e.depthMask)}function UD(t,e){t.stencilMask(e.stencilMask)}function j$(t,e){t.blendColor(e.red,e.green,e.blue,e.alpha)}function QD(t,e,i){let n=e.blending,s=m(i.blendingEnabled)?i.blendingEnabled:n.enabled;bl(t,t.BLEND,s),s&&(j$(t,n.color),t.blendEquationSeparate(n.equationRgb,n.equationAlpha),t.blendFuncSeparate(n.functionSourceRgb,n.functionDestinationRgb,n.functionSourceAlpha,n.functionDestinationAlpha))}function kD(t,e){let i=e.stencilTest,n=i.enabled;if(bl(t,t.STENCIL_TEST,n),n){let s=i.frontFunction,o=i.backFunction,r=i.reference,a=i.mask;t.stencilFunc(s,r,a),t.stencilFuncSeparate(t.BACK,o,r,a),t.stencilFuncSeparate(t.FRONT,s,r,a);let h=i.frontOperation,A=h.fail,d=h.zFail,f=h.zPass;t.stencilOpSeparate(t.FRONT,A,d,f);let E=i.backOperation,_=E.fail,R=E.zFail,I=E.zPass;t.stencilOpSeparate(t.BACK,_,R,I)}}function LD(t,e){let i=e.sampleCoverage,n=i.enabled;bl(t,t.SAMPLE_COVERAGE,n),n&&t.sampleCoverage(i.value,i.invert)}function yD(t,e,i){let n=Z(e.viewport,i.viewport);m(n)||(n=H$,n.width=i.context.drawingBufferWidth,n.height=i.context.drawingBufferHeight),i.context.uniformState.viewport=n,t.viewport(n.x,n.y,n.width,n.height)}function v$(t,e){let i=[];return t.frontFace!==e.frontFace&&i.push(YD),(t.cull.enabled!==e.cull.enabled||t.cull.face!==e.cull.face)&&i.push(SD),t.lineWidth!==e.lineWidth&&i.push(OD),(t.polygonOffset.enabled!==e.polygonOffset.enabled||t.polygonOffset.factor!==e.polygonOffset.factor||t.polygonOffset.units!==e.polygonOffset.units)&&i.push(VD),(t.depthRange.near!==e.depthRange.near||t.depthRange.far!==e.depthRange.far)&&i.push(BD),(t.depthTest.enabled!==e.depthTest.enabled||t.depthTest.func!==e.depthTest.func)&&i.push(WD),(t.colorMask.red!==e.colorMask.red||t.colorMask.green!==e.colorMask.green||t.colorMask.blue!==e.colorMask.blue||t.colorMask.alpha!==e.colorMask.alpha)&&i.push(DD),t.depthMask!==e.depthMask&&i.push(MD),t.stencilMask!==e.stencilMask&&i.push(UD),(t.stencilTest.enabled!==e.stencilTest.enabled||t.stencilTest.frontFunction!==e.stencilTest.frontFunction||t.stencilTest.backFunction!==e.stencilTest.backFunction||t.stencilTest.reference!==e.stencilTest.reference||t.stencilTest.mask!==e.stencilTest.mask||t.stencilTest.frontOperation.fail!==e.stencilTest.frontOperation.fail||t.stencilTest.frontOperation.zFail!==e.stencilTest.frontOperation.zFail||t.stencilTest.backOperation.fail!==e.stencilTest.backOperation.fail||t.stencilTest.backOperation.zFail!==e.stencilTest.backOperation.zFail||t.stencilTest.backOperation.zPass!==e.stencilTest.backOperation.zPass)&&i.push(kD),(t.sampleCoverage.enabled!==e.sampleCoverage.enabled||t.sampleCoverage.value!==e.sampleCoverage.value||t.sampleCoverage.invert!==e.sampleCoverage.invert)&&i.push(LD),i}var J$,EA,H$,Yn,Mm=O(()=>{Er();Qn();bt();mt();Vt();ss();fc();ga();ND();J$=0,EA={};_A.fromCache=function(t){let e=JSON.stringify(t),i=EA[e];if(m(i))return++i.referenceCount,i.state;let n=new _A(t),s=JSON.stringify(n);return i=EA[s],m(i)||(n.id=J$++,n=TD(n),i={referenceCount:0,state:n},EA[s]=i),++i.referenceCount,EA[e]={referenceCount:1,state:i.state},i.state};_A.removeFromCache=function(t){let e=new _A(t),i=JSON.stringify(e),n=EA[i],s=JSON.stringify(t),o=EA[s];m(o)&&(--o.referenceCount,o.referenceCount===0&&(delete EA[s],m(n)&&--n.referenceCount)),m(n)&&n.referenceCount===0&&delete EA[i]};_A.getCache=function(){return EA};_A.clearCache=function(){EA={}};H$=new mi;_A.apply=function(t,e,i){YD(t,e),SD(t,e),OD(t,e),VD(t,e),BD(t,e),WD(t,e),DD(t,e),MD(t,e),UD(t,e),kD(t,e),LD(t,e),GD(t,e,i),QD(t,e,i),yD(t,e,i)};_A.partialApply=function(t,e,i,n,s,o){if(e!==i){let d=i._applyFunctions[e.id];m(d)||(d=v$(e,i),i._applyFunctions[e.id]=d);let f=d.length;for(let E=0;E<f;++E)d[E](t,i)}let r=m(n.scissorTest)?n.scissorTest:e.scissorTest,a=m(s.scissorTest)?s.scissorTest:i.scissorTest;(r!==a||o)&&GD(t,i,s);let h=m(n.blendingEnabled)?n.blendingEnabled:e.blending.enabled,A=m(s.blendingEnabled)?s.blendingEnabled:i.blending.enabled;(h!==A||A&&e.blending!==i.blending)&&QD(t,i,s),(e!==i||n!==s||n.context!==s.context)&&yD(t,i,s)};_A.getState=function(t){if(!m(t))throw new Y("renderState is required.");return{frontFace:t.frontFace,cull:{enabled:t.cull.enabled,face:t.cull.face},lineWidth:t.lineWidth,polygonOffset:{enabled:t.polygonOffset.enabled,factor:t.polygonOffset.factor,units:t.polygonOffset.units},scissorTest:{enabled:t.scissorTest.enabled,rectangle:mi.clone(t.scissorTest.rectangle)},depthRange:{near:t.depthRange.near,far:t.depthRange.far},depthTest:{enabled:t.depthTest.enabled,func:t.depthTest.func},colorMask:{red:t.colorMask.red,green:t.colorMask.green,blue:t.colorMask.blue,alpha:t.colorMask.alpha},depthMask:t.depthMask,stencilMask:t.stencilMask,blending:{enabled:t.blending.enabled,color:Zt.clone(t.blending.color),equationRgb:t.blending.equationRgb,equationAlpha:t.blending.equationAlpha,functionSourceRgb:t.blending.functionSourceRgb,functionSourceAlpha:t.blending.functionSourceAlpha,functionDestinationRgb:t.blending.functionDestinationRgb,functionDestinationAlpha:t.blending.functionDestinationAlpha},stencilTest:{enabled:t.stencilTest.enabled,frontFunction:t.stencilTest.frontFunction,backFunction:t.stencilTest.backFunction,reference:t.stencilTest.reference,mask:t.stencilTest.mask,frontOperation:{fail:t.stencilTest.frontOperation.fail,zFail:t.stencilTest.frontOperation.zFail,zPass:t.stencilTest.frontOperation.zPass},backOperation:{fail:t.stencilTest.backOperation.fail,zFail:t.stencilTest.backOperation.zFail,zPass:t.stencilTest.backOperation.zPass}},sampleCoverage:{enabled:t.sampleCoverage.enabled,value:t.sampleCoverage.value,invert:t.sampleCoverage.invert},viewport:m(t.viewport)?mi.clone(t.viewport):void 0}};Yn=_A});function de(t){this._size=t.size,this._datatype=t.datatype,this.getValue=t.getValue}var z$,Hs,K$,Um,FT=O(()=>{Ht();Fi();ss();z$=new l;Hs={};Hs[it.FLOAT]="float";Hs[it.FLOAT_VEC2]="vec2";Hs[it.FLOAT_VEC3]="vec3";Hs[it.FLOAT_VEC4]="vec4";Hs[it.INT]="int";Hs[it.INT_VEC2]="ivec2";Hs[it.INT_VEC3]="ivec3";Hs[it.INT_VEC4]="ivec4";Hs[it.BOOL]="bool";Hs[it.BOOL_VEC2]="bvec2";Hs[it.BOOL_VEC3]="bvec3";Hs[it.BOOL_VEC4]="bvec4";Hs[it.FLOAT_MAT2]="mat2";Hs[it.FLOAT_MAT3]="mat3";Hs[it.FLOAT_MAT4]="mat4";Hs[it.SAMPLER_2D]="sampler2D";Hs[it.SAMPLER_CUBE]="samplerCube";de.prototype.getDeclaration=function(t){let e=`uniform ${Hs[this._datatype]} ${t}`,i=this._size;return i===1?e+=";":e+=`[${i.toString()}];`,e};K$={czm_viewport:new de({size:1,datatype:it.FLOAT_VEC4,getValue:function(t){return t.viewportCartesian4}}),czm_viewportOrthographic:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.viewportOrthographic}}),czm_viewportTransformation:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.viewportTransformation}}),czm_globeDepthTexture:new de({size:1,datatype:it.SAMPLER_2D,getValue:function(t){return t.globeDepthTexture}}),czm_model:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.model}}),czm_inverseModel:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseModel}}),czm_view:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.view}}),czm_view3D:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.view3D}}),czm_viewRotation:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.viewRotation}}),czm_viewRotation3D:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.viewRotation3D}}),czm_inverseView:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseView}}),czm_inverseView3D:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseView3D}}),czm_inverseViewRotation:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.inverseViewRotation}}),czm_inverseViewRotation3D:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.inverseViewRotation3D}}),czm_projection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.projection}}),czm_inverseProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseProjection}}),czm_infiniteProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.infiniteProjection}}),czm_modelView:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelView}}),czm_modelView3D:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelView3D}}),czm_modelViewRelativeToEye:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelViewRelativeToEye}}),czm_inverseModelView:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseModelView}}),czm_inverseModelView3D:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseModelView3D}}),czm_viewProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.viewProjection}}),czm_inverseViewProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseViewProjection}}),czm_modelViewProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelViewProjection}}),czm_inverseModelViewProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseModelViewProjection}}),czm_modelViewProjectionRelativeToEye:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelViewProjectionRelativeToEye}}),czm_modelViewInfiniteProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelViewInfiniteProjection}}),czm_orthographicIn3D:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.orthographicIn3D?1:0}}),czm_normal:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.normal}}),czm_normal3D:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.normal3D}}),czm_inverseNormal:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.inverseNormal}}),czm_inverseNormal3D:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.inverseNormal3D}}),czm_eyeHeight:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.eyeHeight}}),czm_eyeHeight2D:new de({size:1,datatype:it.FLOAT_VEC2,getValue:function(t){return t.eyeHeight2D}}),czm_eyeEllipsoidNormalEC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.eyeEllipsoidNormalEC}}),czm_eyeEllipsoidCurvature:new de({size:1,datatype:it.FLOAT_VEC2,getValue:function(t){return t.eyeEllipsoidCurvature}}),czm_modelToEnu:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelToEnu}}),czm_enuToModel:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.enuToModel}}),czm_entireFrustum:new de({size:1,datatype:it.FLOAT_VEC2,getValue:function(t){return t.entireFrustum}}),czm_currentFrustum:new de({size:1,datatype:it.FLOAT_VEC2,getValue:function(t){return t.currentFrustum}}),czm_frustumPlanes:new de({size:1,datatype:it.FLOAT_VEC4,getValue:function(t){return t.frustumPlanes}}),czm_farDepthFromNearPlusOne:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.farDepthFromNearPlusOne}}),czm_log2FarDepthFromNearPlusOne:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.log2FarDepthFromNearPlusOne}}),czm_oneOverLog2FarDepthFromNearPlusOne:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.oneOverLog2FarDepthFromNearPlusOne}}),czm_sunPositionWC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.sunPositionWC}}),czm_sunPositionColumbusView:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.sunPositionColumbusView}}),czm_sunDirectionEC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.sunDirectionEC}}),czm_sunDirectionWC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.sunDirectionWC}}),czm_moonDirectionEC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.moonDirectionEC}}),czm_lightDirectionEC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.lightDirectionEC}}),czm_lightDirectionWC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.lightDirectionWC}}),czm_lightColor:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.lightColor}}),czm_lightColorHdr:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.lightColorHdr}}),czm_encodedCameraPositionMCHigh:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.encodedCameraPositionMCHigh}}),czm_encodedCameraPositionMCLow:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.encodedCameraPositionMCLow}}),czm_viewerPositionWC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return at.getTranslation(t.inverseView,z$)}}),czm_frameNumber:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.frameState.frameNumber}}),czm_morphTime:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.frameState.morphTime}}),czm_sceneMode:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.frameState.mode}}),czm_pass:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.pass}}),czm_backgroundColor:new de({size:1,datatype:it.FLOAT_VEC4,getValue:function(t){return t.backgroundColor}}),czm_brdfLut:new de({size:1,datatype:it.SAMPLER_2D,getValue:function(t){return t.brdfLut}}),czm_environmentMap:new de({size:1,datatype:it.SAMPLER_CUBE,getValue:function(t){return t.environmentMap}}),czm_specularEnvironmentMaps:new de({size:1,datatype:it.SAMPLER_2D,getValue:function(t){return t.specularEnvironmentMaps}}),czm_specularEnvironmentMapSize:new de({size:1,datatype:it.FLOAT_VEC2,getValue:function(t){return t.specularEnvironmentMapsDimensions}}),czm_specularEnvironmentMapsMaximumLOD:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.specularEnvironmentMapsMaximumLOD}}),czm_sphericalHarmonicCoefficients:new de({size:9,datatype:it.FLOAT_VEC3,getValue:function(t){return t.sphericalHarmonicCoefficients}}),czm_temeToPseudoFixed:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.temeToPseudoFixedMatrix}}),czm_pixelRatio:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.pixelRatio}}),czm_fogDensity:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.fogDensity}}),czm_fogMinimumBrightness:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.fogMinimumBrightness}}),czm_atmosphereHsbShift:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.atmosphereHsbShift}}),czm_atmosphereLightIntensity:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.atmosphereLightIntensity}}),czm_atmosphereRayleighCoefficient:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.atmosphereRayleighCoefficient}}),czm_atmosphereRayleighScaleHeight:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.atmosphereRayleighScaleHeight}}),czm_atmosphereMieCoefficient:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.atmosphereMieCoefficient}}),czm_atmosphereMieScaleHeight:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.atmosphereMieScaleHeight}}),czm_atmosphereMieAnisotropy:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.atmosphereMieAnisotropy}}),czm_atmosphereDynamicLighting:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.atmosphereDynamicLighting}}),czm_splitPosition:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.splitPosition}}),czm_geometricToleranceOverMeter:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.geometricToleranceOverMeter}}),czm_minimumDisableDepthTestDistance:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.minimumDisableDepthTestDistance}}),czm_invertClassificationColor:new de({size:1,datatype:it.FLOAT_VEC4,getValue:function(t){return t.invertClassificationColor}}),czm_gamma:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.gamma}}),czm_ellipsoidRadii:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.ellipsoid.radii}}),czm_ellipsoidInverseRadii:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.ellipsoid.oneOverRadii}})},Um=K$});function X$(t,e,i,n){switch(e.type){case t.FLOAT:return new wD(t,e,i,n);case t.FLOAT_VEC2:return new xD(t,e,i,n);case t.FLOAT_VEC3:return new PD(t,e,i,n);case t.FLOAT_VEC4:return new JD(t,e,i,n);case t.SAMPLER_2D:case t.SAMPLER_CUBE:return new YT(t,e,i,n);case t.INT:case t.BOOL:return new jD(t,e,i,n);case t.INT_VEC2:case t.BOOL_VEC2:return new HD(t,e,i,n);case t.INT_VEC3:case t.BOOL_VEC3:return new vD(t,e,i,n);case t.INT_VEC4:case t.BOOL_VEC4:return new zD(t,e,i,n);case t.FLOAT_MAT2:return new KD(t,e,i,n);case t.FLOAT_MAT3:return new XD(t,e,i,n);case t.FLOAT_MAT4:return new qD(t,e,i,n);default:throw new ke(`Unrecognized uniform type: ${e.type} for uniform "${i}".`)}}function wD(t,e,i,n){this.name=i,this.value=void 0,this._value=0,this._gl=t,this._location=n}function xD(t,e,i,n){this.name=i,this.value=void 0,this._value=new nt,this._gl=t,this._location=n}function PD(t,e,i,n){this.name=i,this.value=void 0,this._value=void 0,this._gl=t,this._location=n}function JD(t,e,i,n){this.name=i,this.value=void 0,this._value=void 0,this._gl=t,this._location=n}function YT(t,e,i,n){this.name=i,this.value=void 0,this._gl=t,this._location=n,this.textureUnitIndex=void 0}function jD(t,e,i,n){this.name=i,this.value=void 0,this._value=0,this._gl=t,this._location=n}function HD(t,e,i,n){this.name=i,this.value=void 0,this._value=new nt,this._gl=t,this._location=n}function vD(t,e,i,n){this.name=i,this.value=void 0,this._value=new l,this._gl=t,this._location=n}function zD(t,e,i,n){this.name=i,this.value=void 0,this._value=new ie,this._gl=t,this._location=n}function KD(t,e,i,n){this.name=i,this.value=void 0,this._value=new Hn,this._gl=t,this._location=n}function XD(t,e,i,n){this.name=i,this.value=void 0,this._value=new lt,this._gl=t,this._location=n}function qD(t,e,i,n){this.name=i,this.value=void 0,this._value=new at,this._gl=t,this._location=n}var q$,$$,ttt,$D,tM=O(()=>{Xe();Ht();Vs();Qn();mt();Vt();dc();dn();Fi();Ps();wD.prototype.set=function(){this.value!==this._value&&(this._value=this.value,this._gl.uniform1f(this._location,this.value))};xD.prototype.set=function(){let t=this.value;nt.equals(t,this._value)||(nt.clone(t,this._value),this._gl.uniform2f(this._location,t.x,t.y))};PD.prototype.set=function(){let t=this.value;if(m(t.red))Zt.equals(t,this._value)||(this._value=Zt.clone(t,this._value),this._gl.uniform3f(this._location,t.red,t.green,t.blue));else if(m(t.x))l.equals(t,this._value)||(this._value=l.clone(t,this._value),this._gl.uniform3f(this._location,t.x,t.y,t.z));else throw new Y(`Invalid vec3 value for uniform "${this.name}".`)};JD.prototype.set=function(){let t=this.value;if(m(t.red))Zt.equals(t,this._value)||(this._value=Zt.clone(t,this._value),this._gl.uniform4f(this._location,t.red,t.green,t.blue,t.alpha));else if(m(t.x))ie.equals(t,this._value)||(this._value=ie.clone(t,this._value),this._gl.uniform4f(this._location,t.x,t.y,t.z,t.w));else throw new Y(`Invalid vec4 value for uniform "${this.name}".`)};YT.prototype.set=function(){let t=this._gl;t.activeTexture(t.TEXTURE0+this.textureUnitIndex);let e=this.value;t.bindTexture(e._target,e._texture)};YT.prototype._setSampler=function(t){return this.textureUnitIndex=t,this._gl.uniform1i(this._location,t),t+1};jD.prototype.set=function(){this.value!==this._value&&(this._value=this.value,this._gl.uniform1i(this._location,this.value))};HD.prototype.set=function(){let t=this.value;nt.equals(t,this._value)||(nt.clone(t,this._value),this._gl.uniform2i(this._location,t.x,t.y))};vD.prototype.set=function(){let t=this.value;l.equals(t,this._value)||(l.clone(t,this._value),this._gl.uniform3i(this._location,t.x,t.y,t.z))};zD.prototype.set=function(){let t=this.value;ie.equals(t,this._value)||(ie.clone(t,this._value),this._gl.uniform4i(this._location,t.x,t.y,t.z,t.w))};q$=new Float32Array(4);KD.prototype.set=function(){if(!Hn.equalsArray(this.value,this._value,0)){Hn.clone(this.value,this._value);let t=Hn.toArray(this.value,q$);this._gl.uniformMatrix2fv(this._location,!1,t)}};$$=new Float32Array(9);XD.prototype.set=function(){if(!lt.equalsArray(this.value,this._value,0)){lt.clone(this.value,this._value);let t=lt.toArray(this.value,$$);this._gl.uniformMatrix3fv(this._location,!1,t)}};ttt=new Float32Array(16);qD.prototype.set=function(){if(!at.equalsArray(this.value,this._value,0)){at.clone(this.value,this._value);let t=at.toArray(this.value,ttt);this._gl.uniformMatrix4fv(this._location,!1,t)}};$D=X$});function ett(t,e,i,n){switch(e.type){case t.FLOAT:return new eM(t,e,i,n);case t.FLOAT_VEC2:return new iM(t,e,i,n);case t.FLOAT_VEC3:return new nM(t,e,i,n);case t.FLOAT_VEC4:return new sM(t,e,i,n);case t.SAMPLER_2D:case t.SAMPLER_CUBE:return new ST(t,e,i,n);case t.INT:case t.BOOL:return new oM(t,e,i,n);case t.INT_VEC2:case t.BOOL_VEC2:return new rM(t,e,i,n);case t.INT_VEC3:case t.BOOL_VEC3:return new aM(t,e,i,n);case t.INT_VEC4:case t.BOOL_VEC4:return new AM(t,e,i,n);case t.FLOAT_MAT2:return new hM(t,e,i,n);case t.FLOAT_MAT3:return new cM(t,e,i,n);case t.FLOAT_MAT4:return new lM(t,e,i,n);default:throw new ke(`Unrecognized uniform type: ${e.type} for uniform "${i}".`)}}function eM(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s),this._gl=t,this._location=n[0]}function iM(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*2),this._gl=t,this._location=n[0]}function nM(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*3),this._gl=t,this._location=n[0]}function sM(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*4),this._gl=t,this._location=n[0]}function ST(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s),this._gl=t,this._locations=n,this.textureUnitIndex=void 0}function oM(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Int32Array(s),this._gl=t,this._location=n[0]}function rM(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Int32Array(s*2),this._gl=t,this._location=n[0]}function aM(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Int32Array(s*3),this._gl=t,this._location=n[0]}function AM(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Int32Array(s*4),this._gl=t,this._location=n[0]}function hM(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*4),this._gl=t,this._location=n[0]}function cM(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*9),this._gl=t,this._location=n[0]}function lM(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*16),this._gl=t,this._location=n[0]}var dM,mM=O(()=>{Xe();Ht();Vs();Qn();mt();Vt();dc();dn();Fi();Ps();eM.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1;for(let s=0;s<e;++s){let o=t[s];o!==i[s]&&(i[s]=o,n=!0)}n&&this._gl.uniform1fv(this._location,i)};iM.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];nt.equalsArray(r,i,s)||(nt.pack(r,i,s),n=!0),s+=2}n&&this._gl.uniform2fv(this._location,i)};nM.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];if(m(r.red))(r.red!==i[s]||r.green!==i[s+1]||r.blue!==i[s+2])&&(i[s]=r.red,i[s+1]=r.green,i[s+2]=r.blue,n=!0);else if(m(r.x))l.equalsArray(r,i,s)||(l.pack(r,i,s),n=!0);else throw new Y("Invalid vec3 value.");s+=3}n&&this._gl.uniform3fv(this._location,i)};sM.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];if(m(r.red))Zt.equalsArray(r,i,s)||(Zt.pack(r,i,s),n=!0);else if(m(r.x))ie.equalsArray(r,i,s)||(ie.pack(r,i,s),n=!0);else throw new Y("Invalid vec4 value.");s+=4}n&&this._gl.uniform4fv(this._location,i)};ST.prototype.set=function(){let t=this._gl,e=t.TEXTURE0+this.textureUnitIndex,i=this.value,n=i.length;for(let s=0;s<n;++s){let o=i[s];t.activeTexture(e+s),t.bindTexture(o._target,o._texture)}};ST.prototype._setSampler=function(t){this.textureUnitIndex=t;let e=this._locations,i=e.length;for(let n=0;n<i;++n){let s=t+n;this._gl.uniform1i(e[n],s)}return t+i};oM.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1;for(let s=0;s<e;++s){let o=t[s];o!==i[s]&&(i[s]=o,n=!0)}n&&this._gl.uniform1iv(this._location,i)};rM.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];nt.equalsArray(r,i,s)||(nt.pack(r,i,s),n=!0),s+=2}n&&this._gl.uniform2iv(this._location,i)};aM.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];l.equalsArray(r,i,s)||(l.pack(r,i,s),n=!0),s+=3}n&&this._gl.uniform3iv(this._location,i)};AM.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];ie.equalsArray(r,i,s)||(ie.pack(r,i,s),n=!0),s+=4}n&&this._gl.uniform4iv(this._location,i)};hM.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];Hn.equalsArray(r,i,s)||(Hn.pack(r,i,s),n=!0),s+=4}n&&this._gl.uniformMatrix2fv(this._location,!1,i)};cM.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];lt.equalsArray(r,i,s)||(lt.pack(r,i,s),n=!0),s+=9}n&&this._gl.uniformMatrix3fv(this._location,!1,i)};lM.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];at.equalsArray(r,i,s)||(at.pack(r,i,s),n=!0),s+=16}n&&this._gl.uniformMatrix4fv(this._location,!1,i)};dM=ett});function ah(t){let e=t.vertexShaderText,i=t.fragmentShaderText;typeof spector<"u"&&(e=e.replace(/^#line/gm,"//#line"),i=i.replace(/^#line/gm,"//#line"));let n=ntt(e,i);this._gl=t.gl,this._logShaderCompilation=t.logShaderCompilation,this._debugShaders=t.debugShaders,this._attributeLocations=t.attributeLocations,this._program=void 0,this._numberOfVertexAttributes=void 0,this._vertexAttributes=void 0,this._uniformsByName=void 0,this._uniforms=void 0,this._automaticUniforms=void 0,this._manualUniforms=void 0,this._duplicateUniformNames=n.duplicateUniformNames,this._cachedShader=void 0,this.maximumTextureUnitIndex=void 0,this._vertexShaderSource=t.vertexShaderSource,this._vertexShaderText=t.vertexShaderText,this._fragmentShaderSource=t.fragmentShaderSource,this._fragmentShaderText=n.fragmentShaderText,this.id=itt++}function fM(t){let e=[],i=t.match(/uniform.*?(?![^{]*})(?=[=\[;])/g);if(m(i)){let n=i.length;for(let s=0;s<n;s++){let o=i[s].trim(),r=o.slice(o.lastIndexOf(" ")+1);e.push(r)}}return e}function ntt(t,e){let i={};if(!en.highpFloatSupported||!en.highpIntSupported){let n,s,o,r,a=fM(t),h=fM(e),A=a.length,d=h.length;for(n=0;n<A;n++)for(s=0;s<d;s++)if(a[n]===h[s]){o=a[n],r=`czm_mediump_${o}`;let f=new RegExp(`${o}\\b`,"g");e=e.replace(f,r),i[r]=o}}return{fragmentShaderText:e,duplicateUniformNames:i}}function stt(t,e){let i=e._vertexShaderText,n=e._fragmentShaderText,s=t.createShader(t.VERTEX_SHADER);t.shaderSource(s,i),t.compileShader(s);let o=t.createShader(t.FRAGMENT_SHADER);t.shaderSource(o,n),t.compileShader(o);let r=t.createProgram();t.attachShader(r,s),t.attachShader(r,o);let a=e._attributeLocations;if(m(a))for(let E in a)a.hasOwnProperty(E)&&t.bindAttribLocation(r,a[E],E);t.linkProgram(r);let h;if(t.getProgramParameter(r,t.LINK_STATUS))return e._logShaderCompilation&&(h=t.getShaderInfoLog(s),m(h)&&h.length>0&&console.log(`${RA}Vertex shader compile log: ${h}`),h=t.getShaderInfoLog(o),m(h)&&h.length>0&&console.log(`${RA}Fragment shader compile log: ${h}`),h=t.getProgramInfoLog(r),m(h)&&h.length>0&&console.log(`${RA}Shader program link log: ${h}`)),t.deleteShader(s),t.deleteShader(o),r;let A,d=e._debugShaders;throw t.getShaderParameter(o,t.COMPILE_STATUS)?t.getShaderParameter(s,t.COMPILE_STATUS)?(h=t.getProgramInfoLog(r),console.error(`${RA}Shader program link log: ${h}`),f(s,"vertex"),f(o,"fragment"),A=`Program failed to link.  Link log: ${h}`):(h=t.getShaderInfoLog(s),console.error(`${RA}Vertex shader compile log: ${h}`),console.error(`${RA} Vertex shader source:
${i}`),A=`Vertex shader failed to compile.  Compile log: ${h}`):(h=t.getShaderInfoLog(o),console.error(`${RA}Fragment shader compile log: ${h}`),console.error(`${RA} Fragment shader source:
${n}`),A=`Fragment shader failed to compile.  Compile log: ${h}`),t.deleteShader(s),t.deleteShader(o),t.deleteProgram(r),new ke(A);function f(E,_){if(!m(d))return;let R=d.getTranslatedShaderSource(E);if(R===""){console.error(`${RA}${_} shader translation failed.`);return}console.error(`${RA}Translated ${_} shaderSource:
${R}`)}}function ott(t,e,i){let n={};for(let s=0;s<i;++s){let o=t.getActiveAttrib(e,s),r=t.getAttribLocation(e,o.name);n[o.name]={name:o.name,type:o.type,index:r}}return n}function rtt(t,e){let i={},n=[],s=[],o=t.getProgramParameter(e,t.ACTIVE_UNIFORMS);for(let r=0;r<o;++r){let a=t.getActiveUniform(e,r),h="[0]",A=a.name.indexOf(h,a.name.length-h.length)!==-1?a.name.slice(0,a.name.length-3):a.name;if(A.indexOf("gl_")!==0)if(a.name.indexOf("[")<0){let d=t.getUniformLocation(e,A);if(d!==null){let f=$D(t,a,A,d);i[A]=f,n.push(f),f._setSampler&&s.push(f)}}else{let d,f,E,_,R=A.indexOf("[");if(R>=0){if(d=i[A.slice(0,R)],!m(d))continue;f=d._locations,f.length<=1&&(E=d.value,_=t.getUniformLocation(e,A),_!==null&&(f.push(_),E.push(t.getUniform(e,_))))}else{f=[];for(let I=0;I<a.size;++I)_=t.getUniformLocation(e,`${A}[${I}]`),_!==null&&f.push(_);d=dM(t,a,A,f),i[A]=d,n.push(d),d._setSampler&&s.push(d)}}}return{uniformsByName:i,uniforms:n,samplerUniforms:s}}function att(t,e){let i=[],n=[];for(let s in e)if(e.hasOwnProperty(s)){let o=e[s],r=s,a=t._duplicateUniformNames[r];m(a)&&(o.name=a,r=a);let h=Um[r];m(h)?i.push({uniform:o,automaticUniform:h}):n.push(o)}return{automaticUniforms:i,manualUniforms:n}}function Att(t,e,i){t.useProgram(e);let n=0,s=i.length;for(let o=0;o<s;++o)n=i[o]._setSampler(n);return t.useProgram(null),n}function cI(t){m(t._program)||EM(t)}function EM(t){let e=t._program,i=t._gl,n=stt(i,t,t._debugShaders),s=i.getProgramParameter(n,i.ACTIVE_ATTRIBUTES),o=rtt(i,n),r=att(t,o.uniformsByName);t._program=n,t._numberOfVertexAttributes=s,t._vertexAttributes=ott(i,n,s),t._uniformsByName=o.uniformsByName,t._uniforms=o.uniforms,t._automaticUniforms=r.automaticUniforms,t._manualUniforms=r.manualUniforms,t.maximumTextureUnitIndex=Att(i,n,o.samplerUniforms),e&&t._gl.deleteProgram(e),typeof spector<"u"&&(t._program.__SPECTOR_rebuildProgram=function(a,h,A,d){let f=t._vertexShaderText,E=t._fragmentShaderText,_=/ ! = /g;t._vertexShaderText=a.replace(_," != "),t._fragmentShaderText=h.replace(_," != ");try{EM(t),A(t._program)}catch(R){t._vertexShaderText=f,t._fragmentShaderText=E;let C=/(?:Compile|Link) error: ([^]*)/.exec(R.message);d(C?C[1]:R.message)}})}var itt,RA,Es,Qm=O(()=>{ae();bt();mt();Ws();Vt();Ps();FT();ga();tM();mM();itt=0;ah.fromCache=function(t){return t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context),t.context.shaderCache.getShaderProgram(t)};ah.replaceCache=function(t){return t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context),t.context.shaderCache.replaceShaderProgram(t)};Object.defineProperties(ah.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},vertexAttributes:{get:function(){return cI(this),this._vertexAttributes}},numberOfVertexAttributes:{get:function(){return cI(this),this._numberOfVertexAttributes}},allUniforms:{get:function(){return cI(this),this._uniformsByName}}});RA="[Cesium WebGL] ";ah.prototype._bind=function(){cI(this),this._gl.useProgram(this._program)};ah.prototype._setUniforms=function(t,e,i){let n,s;if(m(t)){let a=this._manualUniforms;for(n=a.length,s=0;s<n;++s){let h=a[s];h.value=t[h.name]()}}let o=this._automaticUniforms;for(n=o.length,s=0;s<n;++s){let a=o[s];a.uniform.value=a.automaticUniform.getValue(e)}let r=this._uniforms;for(n=r.length,s=0;s<n;++s)r[s].set();if(i){let a=this._gl,h=this._program;if(a.validateProgram(h),!a.getProgramParameter(h,a.VALIDATE_STATUS))throw new Y(`Program validation failed.  Program info log: ${a.getProgramInfoLog(h)}`)}};ah.prototype.isDestroyed=function(){return!1};ah.prototype.destroy=function(){this._cachedShader.cache.releaseShaderProgram(this)};ah.prototype.finalDestroy=function(){return this._gl.deleteProgram(this._program),li(this)};Es=ah});var _M,RM=O(()=>{_M=`/**
 * A built-in GLSL floating-point constant for converting radians to degrees.
 *
 * @alias czm_degreesPerRadian
 * @glslConstant
 *
 * @see CesiumMath.DEGREES_PER_RADIAN
 *
 * @example
 * // GLSL declaration
 * const float czm_degreesPerRadian = ...;
 *
 * // Example
 * float deg = czm_degreesPerRadian * rad;
 */
const float czm_degreesPerRadian = 57.29577951308232;
`});var ZM,IM=O(()=>{ZM=`/**
 * A built-in GLSL vec2 constant for defining the depth range.
 * This is a workaround to a bug where IE11 does not implement gl_DepthRange.
 *
 * @alias czm_depthRange
 * @glslConstant
 *
 * @example
 * // GLSL declaration
 * float depthRangeNear = czm_depthRange.near;
 * float depthRangeFar = czm_depthRange.far;
 *
 */
const czm_depthRangeStruct czm_depthRange = czm_depthRangeStruct(0.0, 1.0);
`});var pM,uM=O(()=>{pM=`/**
 * 0.1
 *
 * @name czm_epsilon1
 * @glslConstant
 */
const float czm_epsilon1 = 0.1;
`});var CM,gM=O(()=>{CM=`/**
 * 0.01
 *
 * @name czm_epsilon2
 * @glslConstant
 */
const float czm_epsilon2 = 0.01;
`});var TM,NM=O(()=>{TM=`/**
 * 0.001
 *
 * @name czm_epsilon3
 * @glslConstant
 */
const float czm_epsilon3 = 0.001;
`});var bM,FM=O(()=>{bM=`/**
 * 0.0001
 *
 * @name czm_epsilon4
 * @glslConstant
 */
const float czm_epsilon4 = 0.0001;
`});var YM,SM=O(()=>{YM=`/**
 * 0.00001
 *
 * @name czm_epsilon5
 * @glslConstant
 */
const float czm_epsilon5 = 0.00001;
`});var OM,VM=O(()=>{OM=`/**
 * 0.000001
 *
 * @name czm_epsilon6
 * @glslConstant
 */
const float czm_epsilon6 = 0.000001;
`});var GM,BM=O(()=>{GM=`/**
 * 0.0000001
 *
 * @name czm_epsilon7
 * @glslConstant
 */
const float czm_epsilon7 = 0.0000001;
`});var WM,DM=O(()=>{WM=`/**
 * DOC_TBA
 *
 * @name czm_infinity
 * @glslConstant
 */
const float czm_infinity = 5906376272000.0;  // Distance from the Sun to Pluto in meters.  TODO: What is best given lowp, mediump, and highp?
`});var MM,UM=O(()=>{MM=`/**
 * A built-in GLSL floating-point constant for <code>1/pi</code>.
 *
 * @alias czm_oneOverPi
 * @glslConstant
 *
 * @see CesiumMath.ONE_OVER_PI
 *
 * @example
 * // GLSL declaration
 * const float czm_oneOverPi = ...;
 *
 * // Example
 * float pi = 1.0 / czm_oneOverPi;
 */
const float czm_oneOverPi = 0.3183098861837907;
`});var QM,kM=O(()=>{QM=`/**
 * A built-in GLSL floating-point constant for <code>1/2pi</code>.
 *
 * @alias czm_oneOverTwoPi
 * @glslConstant
 *
 * @see CesiumMath.ONE_OVER_TWO_PI
 *
 * @example
 * // GLSL declaration
 * const float czm_oneOverTwoPi = ...;
 *
 * // Example
 * float pi = 2.0 * czm_oneOverTwoPi;
 */
const float czm_oneOverTwoPi = 0.15915494309189535;
`});var LM,yM=O(()=>{LM=`/**
 * The automatic GLSL constant for {@link Pass#CESIUM_3D_TILE}
 *
 * @name czm_passCesium3DTile
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passCesium3DTile = 4.0;
`});var wM,xM=O(()=>{wM=`/**
 * The automatic GLSL constant for {@link Pass#CESIUM_3D_TILE_CLASSIFICATION}
 *
 * @name czm_passCesium3DTileClassification
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passCesium3DTileClassification = 5.0;
`});var PM,JM=O(()=>{PM=`/**
 * The automatic GLSL constant for {@link Pass#CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW}
 *
 * @name czm_passCesium3DTileClassificationIgnoreShow
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passCesium3DTileClassificationIgnoreShow = 6.0;
`});var jM,HM=O(()=>{jM=`/**
 * The automatic GLSL constant for {@link Pass#CLASSIFICATION}
 *
 * @name czm_passClassification
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passClassification = 7.0;
`});var vM,zM=O(()=>{vM=`/**
 * The automatic GLSL constant for {@link Pass#COMPUTE}
 *
 * @name czm_passCompute
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passCompute = 1.0;
`});var KM,XM=O(()=>{KM=`/**
 * The automatic GLSL constant for {@link Pass#ENVIRONMENT}
 *
 * @name czm_passEnvironment
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passEnvironment = 0.0;
`});var qM,$M=O(()=>{qM=`/**
 * The automatic GLSL constant for {@link Pass#GLOBE}
 *
 * @name czm_passGlobe
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passGlobe = 2.0;
`});var tU,eU=O(()=>{tU=`/**
 * The automatic GLSL constant for {@link Pass#OPAQUE}
 *
 * @name czm_passOpaque
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passOpaque = 7.0;
`});var iU,nU=O(()=>{iU=`/**
 * The automatic GLSL constant for {@link Pass#OVERLAY}
 *
 * @name czm_passOverlay
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passOverlay = 10.0;
`});var sU,oU=O(()=>{sU=`/**
 * The automatic GLSL constant for {@link Pass#TERRAIN_CLASSIFICATION}
 *
 * @name czm_passTerrainClassification
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passTerrainClassification = 3.0;
`});var rU,aU=O(()=>{rU=`/**
 * The automatic GLSL constant for {@link Pass#TRANSLUCENT}
 *
 * @name czm_passTranslucent
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passTranslucent = 8.0;
`});var AU,hU=O(()=>{AU=`/**
 * The automatic GLSL constant for {@link Pass#VOXELS}
 *
 * @name czm_passVoxels
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passVoxels = 9.0;
`});var cU,lU=O(()=>{cU=`/**
 * A built-in GLSL floating-point constant for <code>Math.PI</code>.
 *
 * @alias czm_pi
 * @glslConstant
 *
 * @see CesiumMath.PI
 *
 * @example
 * // GLSL declaration
 * const float czm_pi = ...;
 *
 * // Example
 * float twoPi = 2.0 * czm_pi;
 */
const float czm_pi = 3.141592653589793;
`});var dU,mU=O(()=>{dU=`/**
 * A built-in GLSL floating-point constant for <code>pi/4</code>.
 *
 * @alias czm_piOverFour
 * @glslConstant
 *
 * @see CesiumMath.PI_OVER_FOUR
 *
 * @example
 * // GLSL declaration
 * const float czm_piOverFour = ...;
 *
 * // Example
 * float pi = 4.0 * czm_piOverFour;
 */
const float czm_piOverFour = 0.7853981633974483;
`});var fU,EU=O(()=>{fU=`/**
 * A built-in GLSL floating-point constant for <code>pi/6</code>.
 *
 * @alias czm_piOverSix
 * @glslConstant
 *
 * @see CesiumMath.PI_OVER_SIX
 *
 * @example
 * // GLSL declaration
 * const float czm_piOverSix = ...;
 *
 * // Example
 * float pi = 6.0 * czm_piOverSix;
 */
const float czm_piOverSix = 0.5235987755982988;
`});var _U,RU=O(()=>{_U=`/**
 * A built-in GLSL floating-point constant for <code>pi/3</code>.
 *
 * @alias czm_piOverThree
 * @glslConstant
 *
 * @see CesiumMath.PI_OVER_THREE
 *
 * @example
 * // GLSL declaration
 * const float czm_piOverThree = ...;
 *
 * // Example
 * float pi = 3.0 * czm_piOverThree;
 */
const float czm_piOverThree = 1.0471975511965976;
`});var ZU,IU=O(()=>{ZU=`/**
 * A built-in GLSL floating-point constant for <code>pi/2</code>.
 *
 * @alias czm_piOverTwo
 * @glslConstant
 *
 * @see CesiumMath.PI_OVER_TWO
 *
 * @example
 * // GLSL declaration
 * const float czm_piOverTwo = ...;
 *
 * // Example
 * float pi = 2.0 * czm_piOverTwo;
 */
const float czm_piOverTwo = 1.5707963267948966;
`});var pU,uU=O(()=>{pU=`/**
 * A built-in GLSL floating-point constant for converting degrees to radians.
 *
 * @alias czm_radiansPerDegree
 * @glslConstant
 *
 * @see CesiumMath.RADIANS_PER_DEGREE
 *
 * @example
 * // GLSL declaration
 * const float czm_radiansPerDegree = ...;
 *
 * // Example
 * float rad = czm_radiansPerDegree * deg;
 */
const float czm_radiansPerDegree = 0.017453292519943295;
`});var CU,gU=O(()=>{CU=`/**
 * The constant identifier for the 2D {@link SceneMode}
 *
 * @name czm_sceneMode2D
 * @glslConstant
 * @see czm_sceneMode
 * @see czm_sceneModeColumbusView
 * @see czm_sceneMode3D
 * @see czm_sceneModeMorphing
 */
const float czm_sceneMode2D = 2.0;
`});var TU,NU=O(()=>{TU=`/**
 * The constant identifier for the 3D {@link SceneMode}
 *
 * @name czm_sceneMode3D
 * @glslConstant
 * @see czm_sceneMode
 * @see czm_sceneMode2D
 * @see czm_sceneModeColumbusView
 * @see czm_sceneModeMorphing
 */
const float czm_sceneMode3D = 3.0;
`});var bU,FU=O(()=>{bU=`/**
 * The constant identifier for the Columbus View {@link SceneMode}
 *
 * @name czm_sceneModeColumbusView
 * @glslConstant
 * @see czm_sceneMode
 * @see czm_sceneMode2D
 * @see czm_sceneMode3D
 * @see czm_sceneModeMorphing
 */
const float czm_sceneModeColumbusView = 1.0;
`});var YU,SU=O(()=>{YU=`/**
 * The constant identifier for the Morphing {@link SceneMode}
 *
 * @name czm_sceneModeMorphing
 * @glslConstant
 * @see czm_sceneMode
 * @see czm_sceneMode2D
 * @see czm_sceneModeColumbusView
 * @see czm_sceneMode3D
 */
const float czm_sceneModeMorphing = 0.0;
`});var OU,VU=O(()=>{OU=`/**
 * A built-in GLSL floating-point constant for one solar radius.
 *
 * @alias czm_solarRadius
 * @glslConstant
 *
 * @see CesiumMath.SOLAR_RADIUS
 *
 * @example
 * // GLSL declaration
 * const float czm_solarRadius = ...;
 */
const float czm_solarRadius = 695500000.0;
`});var GU,BU=O(()=>{GU=`/**
 * A built-in GLSL floating-point constant for <code>3pi/2</code>.
 *
 * @alias czm_threePiOver2
 * @glslConstant
 *
 * @see CesiumMath.THREE_PI_OVER_TWO
 *
 * @example
 * // GLSL declaration
 * const float czm_threePiOver2 = ...;
 *
 * // Example
 * float pi = (2.0 / 3.0) * czm_threePiOver2;
 */
const float czm_threePiOver2 = 4.71238898038469;
`});var WU,DU=O(()=>{WU=`/**
 * A built-in GLSL floating-point constant for <code>2pi</code>.
 *
 * @alias czm_twoPi
 * @glslConstant
 *
 * @see CesiumMath.TWO_PI
 *
 * @example
 * // GLSL declaration
 * const float czm_twoPi = ...;
 *
 * // Example
 * float pi = czm_twoPi / 2.0;
 */
const float czm_twoPi = 6.283185307179586;
`});var MU,UU=O(()=>{MU=`/**
 * The maximum latitude, in radians, both North and South, supported by a Web Mercator
 * (EPSG:3857) projection.  Technically, the Mercator projection is defined
 * for any latitude up to (but not including) 90 degrees, but it makes sense
 * to cut it off sooner because it grows exponentially with increasing latitude.
 * The logic behind this particular cutoff value, which is the one used by
 * Google Maps, Bing Maps, and Esri, is that it makes the projection
 * square.  That is, the rectangle is equal in the X and Y directions.
 *
 * The constant value is computed as follows:
 *   czm_pi * 0.5 - (2.0 * atan(exp(-czm_pi)))
 *
 * @name czm_webMercatorMaxLatitude
 * @glslConstant
 */
const float czm_webMercatorMaxLatitude = 1.4844222297453324;
`});var QU,kU=O(()=>{QU=`/**
 * @name czm_depthRangeStruct
 * @glslStruct
 */
struct czm_depthRangeStruct
{
    float near;
    float far;
};
`});var LU,yU=O(()=>{LU=`/**
 * Holds material information that can be used for lighting. Returned by all czm_getMaterial functions.
 *
 * @name czm_material
 * @glslStruct
 *
 * @property {vec3} diffuse Incoming light that scatters evenly in all directions.
 * @property {float} specular Intensity of incoming light reflecting in a single direction.
 * @property {float} shininess The sharpness of the specular reflection.  Higher values create a smaller, more focused specular highlight.
 * @property {vec3} normal Surface's normal in eye coordinates. It is used for effects such as normal mapping. The default is the surface's unmodified normal.
 * @property {vec3} emission Light emitted by the material equally in all directions. The default is vec3(0.0), which emits no light.
 * @property {float} alpha Alpha of this material. 0.0 is completely transparent; 1.0 is completely opaque.
 */
struct czm_material
{
    vec3 diffuse;
    float specular;
    float shininess;
    vec3 normal;
    vec3 emission;
    float alpha;
};
`});var wU,xU=O(()=>{wU=`/**
 * Used as input to every material's czm_getMaterial function.
 *
 * @name czm_materialInput
 * @glslStruct
 *
 * @property {float} s 1D texture coordinates.
 * @property {vec2} st 2D texture coordinates.
 * @property {vec3} str 3D texture coordinates.
 * @property {vec3} normalEC Unperturbed surface normal in eye coordinates.
 * @property {mat3} tangentToEyeMatrix Matrix for converting a tangent space normal to eye space.
 * @property {vec3} positionToEyeEC Vector from the fragment to the eye in eye coordinates.  The magnitude is the distance in meters from the fragment to the eye.
 * @property {float} height The height of the terrain in meters above or below the WGS84 ellipsoid.  Only available for globe materials.
 * @property {float} slope The slope of the terrain in radians.  0 is flat; pi/2 is vertical.  Only available for globe materials.
 * @property {float} aspect The aspect of the terrain in radians.  0 is East, pi/2 is North, pi is West, 3pi/2 is South.  Only available for globe materials.
 */
struct czm_materialInput
{
    float s;
    vec2 st;
    vec3 str;
    vec3 normalEC;
    mat3 tangentToEyeMatrix;
    vec3 positionToEyeEC;
    float height;
    float slope;
    float aspect;
};
`});var PU,JU=O(()=>{PU=`/**
 * Struct for representing a material for a {@link Model}. The model
 * rendering pipeline will pass this struct between material, custom shaders,
 * and lighting stages. This is not to be confused with {@link czm_material}
 * which is used by the older Fabric materials system, although they are similar.
 * <p>
 * All color values (diffuse, specular, emissive) are in linear color space.
 * </p>
 *
 * @name czm_modelMaterial
 * @glslStruct
 *
 * @property {vec3} diffuse Incoming light that scatters evenly in all directions.
 * @property {float} alpha Alpha of this material. 0.0 is completely transparent; 1.0 is completely opaque.
 * @property {vec3} specular Color of reflected light at normal incidence in PBR materials. This is sometimes referred to as f0 in the literature.
 * @property {float} roughness A number from 0.0 to 1.0 representing how rough the surface is. Values near 0.0 produce glossy surfaces, while values near 1.0 produce rough surfaces.
 * @property {vec3} normalEC Surface's normal in eye coordinates. It is used for effects such as normal mapping. The default is the surface's unmodified normal.
 * @property {float} occlusion Ambient occlusion recieved at this point on the material. 1.0 means fully lit, 0.0 means fully occluded.
 * @property {vec3} emissive Light emitted by the material equally in all directions. The default is vec3(0.0), which emits no light.
 */
struct czm_modelMaterial {
    vec3 diffuse;
    float alpha;
    vec3 specular;
    float roughness;
    vec3 normalEC;
    float occlusion;
    vec3 emissive;
};
`});var jU,HU=O(()=>{jU=`/**
 * Struct for representing the output of a custom vertex shader.
 * 
 * @name czm_modelVertexOutput
 * @glslStruct
 *
 * @see {@link CustomShader}
 * @see {@link Model}
 *
 * @property {vec3} positionMC The position of the vertex in model coordinates
 * @property {float} pointSize A custom value for gl_PointSize. This is only used for point primitives. 
 */
struct czm_modelVertexOutput {
  vec3 positionMC;
  float pointSize;
};
`});var vU,zU=O(()=>{vU=`/**
 * Parameters for {@link czm_pbrLighting}
 *
 * @name czm_material
 * @glslStruct
 *
 * @property {vec3} diffuseColor the diffuse color of the material for the lambert term of the rendering equation
 * @property {float} roughness a value from 0.0 to 1.0 that indicates how rough the surface of the material is.
 * @property {vec3} f0 The reflectance of the material at normal incidence
 */
struct czm_pbrParameters
{
    vec3 diffuseColor;
    float roughness;
    vec3 f0;
};
`});var KU,XU=O(()=>{KU=`/**
 * DOC_TBA
 *
 * @name czm_ray
 * @glslStruct
 */
struct czm_ray
{
    vec3 origin;
    vec3 direction;
};
`});var qU,$U=O(()=>{qU=`/**
 * DOC_TBA
 *
 * @name czm_raySegment
 * @glslStruct
 */
struct czm_raySegment
{
    float start;
    float stop;
};

/**
 * DOC_TBA
 *
 * @name czm_emptyRaySegment
 * @glslConstant 
 */
const czm_raySegment czm_emptyRaySegment = czm_raySegment(-czm_infinity, -czm_infinity);

/**
 * DOC_TBA
 *
 * @name czm_fullRaySegment
 * @glslConstant 
 */
const czm_raySegment czm_fullRaySegment = czm_raySegment(0.0, czm_infinity);
`});var tQ,eQ=O(()=>{tQ=`struct czm_shadowParameters
{
#ifdef USE_CUBE_MAP_SHADOW
    vec3 texCoords;
#else
    vec2 texCoords;
#endif

    float depthBias;
    float depth;
    float nDotL;
    vec2 texelStepSize;
    float normalShadingSmooth;
    float darkness;
};
`});var iQ,nQ=O(()=>{iQ=`/**
 * Converts an HSB color (hue, saturation, brightness) to RGB
 * HSB <-> RGB conversion with minimal branching: {@link http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl}
 *
 * @name czm_HSBToRGB
 * @glslFunction
 * 
 * @param {vec3} hsb The color in HSB.
 *
 * @returns {vec3} The color in RGB.
 *
 * @example
 * vec3 hsb = czm_RGBToHSB(rgb);
 * hsb.z *= 0.1;
 * rgb = czm_HSBToRGB(hsb);
 */

const vec4 K_HSB2RGB = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);

vec3 czm_HSBToRGB(vec3 hsb)
{
    vec3 p = abs(fract(hsb.xxx + K_HSB2RGB.xyz) * 6.0 - K_HSB2RGB.www);
    return hsb.z * mix(K_HSB2RGB.xxx, clamp(p - K_HSB2RGB.xxx, 0.0, 1.0), hsb.y);
}
`});var sQ,oQ=O(()=>{sQ=`/**
 * Converts an HSL color (hue, saturation, lightness) to RGB
 * HSL <-> RGB conversion: {@link http://www.chilliant.com/rgb2hsv.html}
 *
 * @name czm_HSLToRGB
 * @glslFunction
 * 
 * @param {vec3} rgb The color in HSL.
 *
 * @returns {vec3} The color in RGB.
 *
 * @example
 * vec3 hsl = czm_RGBToHSL(rgb);
 * hsl.z *= 0.1;
 * rgb = czm_HSLToRGB(hsl);
 */

vec3 hueToRGB(float hue)
{
    float r = abs(hue * 6.0 - 3.0) - 1.0;
    float g = 2.0 - abs(hue * 6.0 - 2.0);
    float b = 2.0 - abs(hue * 6.0 - 4.0);
    return clamp(vec3(r, g, b), 0.0, 1.0);
}

vec3 czm_HSLToRGB(vec3 hsl)
{
    vec3 rgb = hueToRGB(hsl.x);
    float c = (1.0 - abs(2.0 * hsl.z - 1.0)) * hsl.y;
    return (rgb - 0.5) * c + hsl.z;
}
`});var rQ,aQ=O(()=>{rQ=`/**
 * Converts an RGB color to HSB (hue, saturation, brightness)
 * HSB <-> RGB conversion with minimal branching: {@link http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl}
 *
 * @name czm_RGBToHSB
 * @glslFunction
 * 
 * @param {vec3} rgb The color in RGB.
 *
 * @returns {vec3} The color in HSB.
 *
 * @example
 * vec3 hsb = czm_RGBToHSB(rgb);
 * hsb.z *= 0.1;
 * rgb = czm_HSBToRGB(hsb);
 */

const vec4 K_RGB2HSB = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);

vec3 czm_RGBToHSB(vec3 rgb)
{
    vec4 p = mix(vec4(rgb.bg, K_RGB2HSB.wz), vec4(rgb.gb, K_RGB2HSB.xy), step(rgb.b, rgb.g));
    vec4 q = mix(vec4(p.xyw, rgb.r), vec4(rgb.r, p.yzx), step(p.x, rgb.r));

    float d = q.x - min(q.w, q.y);
    return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + czm_epsilon7)), d / (q.x + czm_epsilon7), q.x);
}
`});var AQ,hQ=O(()=>{AQ=`/**
 * Converts an RGB color to HSL (hue, saturation, lightness)
 * HSL <-> RGB conversion: {@link http://www.chilliant.com/rgb2hsv.html}
 *
 * @name czm_RGBToHSL
 * @glslFunction
 * 
 * @param {vec3} rgb The color in RGB.
 *
 * @returns {vec3} The color in HSL.
 *
 * @example
 * vec3 hsl = czm_RGBToHSL(rgb);
 * hsl.z *= 0.1;
 * rgb = czm_HSLToRGB(hsl);
 */
 
vec3 RGBtoHCV(vec3 rgb)
{
    // Based on work by Sam Hocevar and Emil Persson
    vec4 p = (rgb.g < rgb.b) ? vec4(rgb.bg, -1.0, 2.0 / 3.0) : vec4(rgb.gb, 0.0, -1.0 / 3.0);
    vec4 q = (rgb.r < p.x) ? vec4(p.xyw, rgb.r) : vec4(rgb.r, p.yzx);
    float c = q.x - min(q.w, q.y);
    float h = abs((q.w - q.y) / (6.0 * c + czm_epsilon7) + q.z);
    return vec3(h, c, q.x);
}

vec3 czm_RGBToHSL(vec3 rgb)
{
    vec3 hcv = RGBtoHCV(rgb);
    float l = hcv.z - hcv.y * 0.5;
    float s = hcv.y / (1.0 - abs(l * 2.0 - 1.0) + czm_epsilon7);
    return vec3(hcv.x, s, l);
}
`});var cQ,lQ=O(()=>{cQ=`/**
 * Converts an RGB color to CIE Yxy.
 * <p>The conversion is described in
 * {@link http://content.gpwiki.org/index.php/D3DBook:High-Dynamic_Range_Rendering#Luminance_Transform|Luminance Transform}
 * </p>
 * 
 * @name czm_RGBToXYZ
 * @glslFunction
 * 
 * @param {vec3} rgb The color in RGB.
 *
 * @returns {vec3} The color in CIE Yxy.
 *
 * @example
 * vec3 xyz = czm_RGBToXYZ(rgb);
 * xyz.x = max(xyz.x - luminanceThreshold, 0.0);
 * rgb = czm_XYZToRGB(xyz);
 */
vec3 czm_RGBToXYZ(vec3 rgb)
{
    const mat3 RGB2XYZ = mat3(0.4124, 0.2126, 0.0193,
                              0.3576, 0.7152, 0.1192,
                              0.1805, 0.0722, 0.9505);
    vec3 xyz = RGB2XYZ * rgb;
    vec3 Yxy;
    Yxy.r = xyz.g;
    float temp = dot(vec3(1.0), xyz);
    Yxy.gb = xyz.rg / temp;
    return Yxy;
}
`});var dQ,mQ=O(()=>{dQ=`/**
 * Converts a CIE Yxy color to RGB.
 * <p>The conversion is described in
 * {@link http://content.gpwiki.org/index.php/D3DBook:High-Dynamic_Range_Rendering#Luminance_Transform|Luminance Transform}
 * </p>
 * 
 * @name czm_XYZToRGB
 * @glslFunction
 * 
 * @param {vec3} Yxy The color in CIE Yxy.
 *
 * @returns {vec3} The color in RGB.
 *
 * @example
 * vec3 xyz = czm_RGBToXYZ(rgb);
 * xyz.x = max(xyz.x - luminanceThreshold, 0.0);
 * rgb = czm_XYZToRGB(xyz);
 */
vec3 czm_XYZToRGB(vec3 Yxy)
{
    const mat3 XYZ2RGB = mat3( 3.2405, -0.9693,  0.0556,
                              -1.5371,  1.8760, -0.2040,
                              -0.4985,  0.0416,  1.0572);
    vec3 xyz;
    xyz.r = Yxy.r * Yxy.g / Yxy.b;
    xyz.g = Yxy.r;
    xyz.b = Yxy.r * (1.0 - Yxy.g - Yxy.b) / Yxy.b;
    
    return XYZ2RGB * xyz;
}
`});var fQ,EQ=O(()=>{fQ=`// See:
//    https://knarkowicz.wordpress.com/2016/01/06/aces-filmic-tone-mapping-curve/

vec3 czm_acesTonemapping(vec3 color) {
    float g = 0.985;
    float a = 0.065;
    float b = 0.0001;
    float c = 0.433;
    float d = 0.238;

    color = (color * (color + a) - b) / (color * (g * color + c) + d);

    color = clamp(color, 0.0, 1.0);

    return color;
}
`});var _Q,RQ=O(()=>{_Q=`/**
 * @private
 */
float czm_alphaWeight(float a)
{
    float z = (gl_FragCoord.z - czm_viewportTransformation[3][2]) / czm_viewportTransformation[2][2];

    // See Weighted Blended Order-Independent Transparency for examples of different weighting functions:
    // http://jcgt.org/published/0002/02/09/
    return pow(a + 0.01, 4.0) + max(1e-2, min(3.0 * 1e3, 0.003 / (1e-5 + pow(abs(z) / 200.0, 4.0))));
}
`});var ZQ,IQ=O(()=>{ZQ=`/**
 * Procedural anti-aliasing by blurring two colors that meet at a sharp edge.
 *
 * @name czm_antialias
 * @glslFunction
 *
 * @param {vec4} color1 The color on one side of the edge.
 * @param {vec4} color2 The color on the other side of the edge.
 * @param {vec4} currentcolor The current color, either <code>color1</code> or <code>color2</code>.
 * @param {float} dist The distance to the edge in texture coordinates.
 * @param {float} [fuzzFactor=0.1] Controls the blurriness between the two colors.
 * @returns {vec4} The anti-aliased color.
 *
 * @example
 * // GLSL declarations
 * vec4 czm_antialias(vec4 color1, vec4 color2, vec4 currentColor, float dist, float fuzzFactor);
 * vec4 czm_antialias(vec4 color1, vec4 color2, vec4 currentColor, float dist);
 *
 * // get the color for a material that has a sharp edge at the line y = 0.5 in texture space
 * float dist = abs(textureCoordinates.t - 0.5);
 * vec4 currentColor = mix(bottomColor, topColor, step(0.5, textureCoordinates.t));
 * vec4 color = czm_antialias(bottomColor, topColor, currentColor, dist, 0.1);
 */
vec4 czm_antialias(vec4 color1, vec4 color2, vec4 currentColor, float dist, float fuzzFactor)
{
    float val1 = clamp(dist / fuzzFactor, 0.0, 1.0);
    float val2 = clamp((dist - 0.5) / fuzzFactor, 0.0, 1.0);
    val1 = val1 * (1.0 - val2);
    val1 = val1 * val1 * (3.0 - (2.0 * val1));
    val1 = pow(val1, 0.5); //makes the transition nicer
    
    vec4 midColor = (color1 + color2) * 0.5;
    return mix(midColor, currentColor, val1);
}

vec4 czm_antialias(vec4 color1, vec4 color2, vec4 currentColor, float dist)
{
    return czm_antialias(color1, color2, currentColor, dist, 0.1);
}
`});var pQ,uQ=O(()=>{pQ=`/**
 * Apply a HSB color shift to an RGB color.
 *
 * @param {vec3} rgb The color in RGB space.
 * @param {vec3} hsbShift The amount to shift each component. The xyz components correspond to hue, saturation, and brightness. Shifting the hue by +/- 1.0 corresponds to shifting the hue by a full cycle. Saturation and brightness are clamped between 0 and 1 after the adjustment
 * @param {bool} ignoreBlackPixels If true, black pixels will be unchanged. This is necessary in some shaders such as atmosphere-related effects.
 *
 * @return {vec3} The RGB color after shifting in HSB space and clamping saturation and brightness to a valid range.
 */
vec3 czm_applyHSBShift(vec3 rgb, vec3 hsbShift, bool ignoreBlackPixels) {
    // Convert rgb color to hsb
    vec3 hsb = czm_RGBToHSB(rgb);

    // Perform hsb shift
    // Hue cycles around so no clamp is needed.
    hsb.x += hsbShift.x; // hue
    hsb.y = clamp(hsb.y + hsbShift.y, 0.0, 1.0); // saturation

    // brightness
    //
    // Some shaders such as atmosphere-related effects need to leave black
    // pixels unchanged
    if (ignoreBlackPixels) {
        hsb.z = hsb.z > czm_epsilon7 ? hsb.z + hsbShift.z : 0.0;
    } else {
        hsb.z = hsb.z + hsbShift.z;
    }
    hsb.z = clamp(hsb.z, 0.0, 1.0);

    // Convert shifted hsb back to rgb
    return czm_HSBToRGB(hsb);
}
`});var CQ,gQ=O(()=>{CQ=`/**
 * Approximately computes spherical coordinates given a normal.
 * Uses approximate inverse trigonometry for speed and consistency,
 * since inverse trigonometry can differ from vendor-to-vendor and when compared with the CPU.
 *
 * @name czm_approximateSphericalCoordinates
 * @glslFunction
 *
 * @param {vec3} normal arbitrary-length normal.
 *
 * @returns {vec2} Approximate latitude and longitude spherical coordinates.
 */
vec2 czm_approximateSphericalCoordinates(vec3 normal) {
    // Project into plane with vertical for latitude
    float latitudeApproximation = czm_fastApproximateAtan(sqrt(normal.x * normal.x + normal.y * normal.y), normal.z);
    float longitudeApproximation = czm_fastApproximateAtan(normal.x, normal.y);
    return vec2(latitudeApproximation, longitudeApproximation);
}
`});var TQ,NQ=O(()=>{TQ=`/**
 * Compute a rational approximation to tanh(x)
 *
 * @param {float} x A real number input
 * @returns {float} An approximation for tanh(x)
*/
float czm_approximateTanh(float x) {
    float x2 = x * x;
    return max(-1.0, min(1.0, x * (27.0 + x2) / (27.0 + 9.0 * x2)));
}
`});var bQ,FQ=O(()=>{bQ=`/**
 * Determines if the fragment is back facing
 *
 * @name czm_backFacing
 * @glslFunction 
 * 
 * @returns {bool} <code>true</code> if the fragment is back facing; otherwise, <code>false</code>.
 */
bool czm_backFacing()
{
    // !gl_FrontFacing doesn't work as expected on Mac/Intel so use the more verbose form instead. See https://github.com/CesiumGS/cesium/pull/8494.
    return gl_FrontFacing == false;
}
`});var YQ,SQ=O(()=>{YQ=`/**
 * Branchless ternary operator to be used when it's inexpensive to explicitly
 * evaluate both possibilities for a float expression.
 *
 * @name czm_branchFreeTernary
 * @glslFunction
 *
 * @param {bool} comparison A comparison statement
 * @param {float} a Value to return if the comparison is true.
 * @param {float} b Value to return if the comparison is false.
 *
 * @returns {float} equivalent of comparison ? a : b
 */
float czm_branchFreeTernary(bool comparison, float a, float b) {
    float useA = float(comparison);
    return a * useA + b * (1.0 - useA);
}

/**
 * Branchless ternary operator to be used when it's inexpensive to explicitly
 * evaluate both possibilities for a vec2 expression.
 *
 * @name czm_branchFreeTernary
 * @glslFunction
 *
 * @param {bool} comparison A comparison statement
 * @param {vec2} a Value to return if the comparison is true.
 * @param {vec2} b Value to return if the comparison is false.
 *
 * @returns {vec2} equivalent of comparison ? a : b
 */
vec2 czm_branchFreeTernary(bool comparison, vec2 a, vec2 b) {
    float useA = float(comparison);
    return a * useA + b * (1.0 - useA);
}

/**
 * Branchless ternary operator to be used when it's inexpensive to explicitly
 * evaluate both possibilities for a vec3 expression.
 *
 * @name czm_branchFreeTernary
 * @glslFunction
 *
 * @param {bool} comparison A comparison statement
 * @param {vec3} a Value to return if the comparison is true.
 * @param {vec3} b Value to return if the comparison is false.
 *
 * @returns {vec3} equivalent of comparison ? a : b
 */
vec3 czm_branchFreeTernary(bool comparison, vec3 a, vec3 b) {
    float useA = float(comparison);
    return a * useA + b * (1.0 - useA);
}

/**
 * Branchless ternary operator to be used when it's inexpensive to explicitly
 * evaluate both possibilities for a vec4 expression.
 *
 * @name czm_branchFreeTernary
 * @glslFunction
 *
 * @param {bool} comparison A comparison statement
 * @param {vec3} a Value to return if the comparison is true.
 * @param {vec3} b Value to return if the comparison is false.
 *
 * @returns {vec3} equivalent of comparison ? a : b
 */
vec4 czm_branchFreeTernary(bool comparison, vec4 a, vec4 b) {
    float useA = float(comparison);
    return a * useA + b * (1.0 - useA);
}
`});var OQ,VQ=O(()=>{OQ=`
vec4 czm_cascadeColor(vec4 weights)
{
    return vec4(1.0, 0.0, 0.0, 1.0) * weights.x +
           vec4(0.0, 1.0, 0.0, 1.0) * weights.y +
           vec4(0.0, 0.0, 1.0, 1.0) * weights.z +
           vec4(1.0, 0.0, 1.0, 1.0) * weights.w;
}
`});var GQ,BQ=O(()=>{GQ=`
uniform vec4 shadowMap_cascadeDistances;

float czm_cascadeDistance(vec4 weights)
{
    return dot(shadowMap_cascadeDistances, weights);
}
`});var WQ,DQ=O(()=>{WQ=`
uniform mat4 shadowMap_cascadeMatrices[4];

mat4 czm_cascadeMatrix(vec4 weights)
{
    return shadowMap_cascadeMatrices[0] * weights.x +
           shadowMap_cascadeMatrices[1] * weights.y +
           shadowMap_cascadeMatrices[2] * weights.z +
           shadowMap_cascadeMatrices[3] * weights.w;
}
`});var MQ,UQ=O(()=>{MQ=`
uniform vec4 shadowMap_cascadeSplits[2];

vec4 czm_cascadeWeights(float depthEye)
{
    // One component is set to 1.0 and all others set to 0.0.
    vec4 near = step(shadowMap_cascadeSplits[0], vec4(depthEye));
    vec4 far = step(depthEye, shadowMap_cascadeSplits[1]);
    return near * far;
}
`});var QQ,kQ=O(()=>{QQ=`float getSignedDistance(vec2 uv, highp sampler2D clippingDistance) {
    float signedDistance = texture(clippingDistance, uv).r;
    return (signedDistance - 0.5) * 2.0;
}

void czm_clipPolygons(highp sampler2D clippingDistance, int extentsLength, vec2 clippingPosition, int regionIndex) {
    // Position is completely outside of polygons bounds
    vec2 rectUv = clippingPosition;
    if (regionIndex < 0 || rectUv.x <= 0.0 || rectUv.y <= 0.0 || rectUv.x >= 1.0 || rectUv.y >= 1.0) {
        #ifdef CLIPPING_INVERSE 
            discard;
        #endif
        return;
    }

    vec2 clippingDistanceTextureDimensions = vec2(textureSize(clippingDistance, 0));
    vec2 sampleOffset = max(1.0 / clippingDistanceTextureDimensions, vec2(0.005));
    float dimension = float(extentsLength);
    if (extentsLength > 2) {
       dimension = ceil(log2(float(extentsLength)));
    }

    vec2 textureOffset = vec2(mod(float(regionIndex), dimension), floor(float(regionIndex) / dimension)) / dimension;
    vec2 uv = textureOffset + rectUv / dimension;

    float signedDistance = getSignedDistance(uv, clippingDistance);

    #ifdef CLIPPING_INVERSE
    if (signedDistance > 0.0)  {
        discard;
    }
    #else
    if (signedDistance < 0.0)  {
        discard;
    }
    #endif
}
`});var LQ,yQ=O(()=>{LQ=`/**
 * DOC_TBA
 *
 * @name czm_columbusViewMorph
 * @glslFunction
 */
vec4 czm_columbusViewMorph(vec4 position2D, vec4 position3D, float time)
{
    // Just linear for now.
    vec3 p = mix(position2D.xyz, position3D.xyz, time);
    return vec4(p, 1.0);
}
`});var wQ,xQ=O(()=>{wQ=`/**
 * Compute the atmosphere color, applying Rayleigh and Mie scattering. This
 * builtin uses automatic uniforms so the atmophere settings are synced with the
 * state of the Scene, even in other contexts like Model.
 *
 * @name czm_computeAtmosphereColor
 * @glslFunction
 *
 * @param {vec3} positionWC Position of the fragment in world coords (low precision)
 * @param {vec3} lightDirection Light direction from the sun or other light source.
 * @param {vec3} rayleighColor The Rayleigh scattering color computed by a scattering function
 * @param {vec3} mieColor The Mie scattering color computed by a scattering function
 * @param {float} opacity The opacity computed by a scattering function.
 */
vec4 czm_computeAtmosphereColor(
    vec3 positionWC,
    vec3 lightDirection,
    vec3 rayleighColor,
    vec3 mieColor,
    float opacity
) {
    // Setup the primary ray: from the camera position to the vertex position.
    vec3 cameraToPositionWC = positionWC - czm_viewerPositionWC;
    vec3 cameraToPositionWCDirection = normalize(cameraToPositionWC);

    float cosAngle = dot(cameraToPositionWCDirection, lightDirection);
    float cosAngleSq = cosAngle * cosAngle;

    float G = czm_atmosphereMieAnisotropy;
    float GSq = G * G;

    // The Rayleigh phase function.
    float rayleighPhase = 3.0 / (50.2654824574) * (1.0 + cosAngleSq);
    // The Mie phase function.
    float miePhase = 3.0 / (25.1327412287) * ((1.0 - GSq) * (cosAngleSq + 1.0)) / (pow(1.0 + GSq - 2.0 * cosAngle * G, 1.5) * (2.0 + GSq));

    // The final color is generated by combining the effects of the Rayleigh and Mie scattering.
    vec3 rayleigh = rayleighPhase * rayleighColor;
    vec3 mie = miePhase * mieColor;

    vec3 color = (rayleigh + mie) * czm_atmosphereLightIntensity;

    return vec4(color, opacity);
}
`});var PQ,JQ=O(()=>{PQ=`/**
 * Compute atmosphere scattering for the ground atmosphere and fog. This method
 * uses automatic uniforms so it is always synced with the scene settings.
 *
 * @name czm_computeGroundAtmosphereScattering
 * @glslfunction
 *
 * @param {vec3} positionWC The position of the fragment in world coordinates.
 * @param {vec3} lightDirection The direction of the light to calculate the scattering from.
 * @param {vec3} rayleighColor The variable the Rayleigh scattering will be written to.
 * @param {vec3} mieColor The variable the Mie scattering will be written to.
 * @param {float} opacity The variable the transmittance will be written to.
 */
void czm_computeGroundAtmosphereScattering(vec3 positionWC, vec3 lightDirection, out vec3 rayleighColor, out vec3 mieColor, out float opacity) {
    vec3 cameraToPositionWC = positionWC - czm_viewerPositionWC;
    vec3 cameraToPositionWCDirection = normalize(cameraToPositionWC);
    czm_ray primaryRay = czm_ray(czm_viewerPositionWC, cameraToPositionWCDirection);

    float atmosphereInnerRadius = length(positionWC);

    czm_computeScattering(
        primaryRay,
        length(cameraToPositionWC),
        lightDirection,
        atmosphereInnerRadius,
        rayleighColor,
        mieColor,
        opacity
    );
}
`});var jQ,HQ=O(()=>{jQ=`/**
 * Returns a position in model coordinates relative to eye taking into
 * account the current scene mode: 3D, 2D, or Columbus view.
 * <p>
 * This uses standard position attributes, <code>position3DHigh</code>, 
 * <code>position3DLow</code>, <code>position2DHigh</code>, and <code>position2DLow</code>, 
 * and should be used when writing a vertex shader for an {@link Appearance}.
 * </p>
 *
 * @name czm_computePosition
 * @glslFunction
 *
 * @returns {vec4} The position relative to eye.
 *
 * @example
 * vec4 p = czm_computePosition();
 * v_positionEC = (czm_modelViewRelativeToEye * p).xyz;
 * gl_Position = czm_modelViewProjectionRelativeToEye * p;
 *
 * @see czm_translateRelativeToEye
 */
vec4 czm_computePosition();
`});var vQ,zQ=O(()=>{vQ=`/**
 * This function computes the colors contributed by Rayliegh and Mie scattering on a given ray, as well as
 * the transmittance value for the ray. This function uses automatic uniforms
 * so the atmosphere settings are always synced with the current scene.
 *
 * @name czm_computeScattering
 * @glslfunction
 *
 * @param {czm_ray} primaryRay The ray from the camera to the position.
 * @param {float} primaryRayLength The length of the primary ray.
 * @param {vec3} lightDirection The direction of the light to calculate the scattering from.
 * @param {vec3} rayleighColor The variable the Rayleigh scattering will be written to.
 * @param {vec3} mieColor The variable the Mie scattering will be written to.
 * @param {float} opacity The variable the transmittance will be written to.
 */
void czm_computeScattering(
    czm_ray primaryRay,
    float primaryRayLength,
    vec3 lightDirection,
    float atmosphereInnerRadius,
    out vec3 rayleighColor,
    out vec3 mieColor,
    out float opacity
) {
    const float ATMOSPHERE_THICKNESS = 111e3; // The thickness of the atmosphere in meters.
    const int PRIMARY_STEPS_MAX = 16; // Maximum number of times the ray from the camera to the world position (primary ray) is sampled.
    const int LIGHT_STEPS_MAX = 4; // Maximum number of times the light is sampled from the light source's intersection with the atmosphere to a sample position on the primary ray.

    // Initialize the default scattering amounts to 0.
    rayleighColor = vec3(0.0);
    mieColor = vec3(0.0);
    opacity = 0.0;

    float atmosphereOuterRadius = atmosphereInnerRadius + ATMOSPHERE_THICKNESS;

    vec3 origin = vec3(0.0);

    // Calculate intersection from the camera to the outer ring of the atmosphere.
    czm_raySegment primaryRayAtmosphereIntersect = czm_raySphereIntersectionInterval(primaryRay, origin, atmosphereOuterRadius);

    // Return empty colors if no intersection with the atmosphere geometry.
    if (primaryRayAtmosphereIntersect == czm_emptyRaySegment) {
        rayleighColor = vec3(1.0, 0.0, 1.0);
        return;
    }

    // To deal with smaller values of PRIMARY_STEPS (e.g. 4)
    // we implement a split strategy: sky or horizon.
    // For performance reasons, instead of a if/else branch
    // a soft choice is implemented through a weight 0.0 <= w_stop_gt_lprl <= 1.0
    float x = 1e-7 * primaryRayAtmosphereIntersect.stop / length(primaryRayLength);
    // Value close to 0.0: close to the horizon
    // Value close to 1.0: above in the sky
    float w_stop_gt_lprl = 0.5 * (1.0 + czm_approximateTanh(x));

    // The ray should start from the first intersection with the outer atmopshere, or from the camera position, if it is inside the atmosphere.
    float start_0 = primaryRayAtmosphereIntersect.start;
    primaryRayAtmosphereIntersect.start = max(primaryRayAtmosphereIntersect.start, 0.0);
    // The ray should end at the exit from the atmosphere or at the distance to the vertex, whichever is smaller.
    primaryRayAtmosphereIntersect.stop = min(primaryRayAtmosphereIntersect.stop, length(primaryRayLength));

    // For the number of ray steps, distinguish inside or outside atmosphere (outer space)
    // (1) from outer space we have to use more ray steps to get a realistic rendering
    // (2) within atmosphere we need fewer steps for faster rendering
    float x_o_a = start_0 - ATMOSPHERE_THICKNESS; // ATMOSPHERE_THICKNESS used as an ad-hoc constant, no precise meaning here, only the order of magnitude matters
    float w_inside_atmosphere = 1.0 - 0.5 * (1.0 + czm_approximateTanh(x_o_a));
    int PRIMARY_STEPS = PRIMARY_STEPS_MAX - int(w_inside_atmosphere * 12.0); // Number of times the ray from the camera to the world position (primary ray) is sampled.
    int LIGHT_STEPS = LIGHT_STEPS_MAX - int(w_inside_atmosphere * 2.0); // Number of times the light is sampled from the light source's intersection with the atmosphere to a sample position on the primary ray.

    // Setup for sampling positions along the ray - starting from the intersection with the outer ring of the atmosphere.
    float rayPositionLength = primaryRayAtmosphereIntersect.start;
    // (1) Outside the atmosphere: constant rayStepLength
    // (2) Inside atmosphere: variable rayStepLength to compensate the rough rendering of the smaller number of ray steps
    float totalRayLength = primaryRayAtmosphereIntersect.stop - rayPositionLength;
    float rayStepLengthIncrease = w_inside_atmosphere * ((1.0 - w_stop_gt_lprl) * totalRayLength / (float(PRIMARY_STEPS * (PRIMARY_STEPS + 1)) / 2.0));
    float rayStepLength = max(1.0 - w_inside_atmosphere, w_stop_gt_lprl) * totalRayLength / max(7.0 * w_inside_atmosphere, float(PRIMARY_STEPS));

    vec3 rayleighAccumulation = vec3(0.0);
    vec3 mieAccumulation = vec3(0.0);
    vec2 opticalDepth = vec2(0.0);
    vec2 heightScale = vec2(czm_atmosphereRayleighScaleHeight, czm_atmosphereMieScaleHeight);

    // Sample positions on the primary ray.
    for (int i = 0; i < PRIMARY_STEPS_MAX; ++i) {

        // The loop should be: for (int i = 0; i < PRIMARY_STEPS; ++i) {...} but WebGL1 cannot
        // loop with non-constant condition, so it has to break early instead
        if (i >= PRIMARY_STEPS) {
            break;
        }

        // Calculate sample position along viewpoint ray.
        vec3 samplePosition = primaryRay.origin + primaryRay.direction * (rayPositionLength + rayStepLength);

        // Calculate height of sample position above ellipsoid.
        float sampleHeight = length(samplePosition) - atmosphereInnerRadius;

        // Calculate and accumulate density of particles at the sample position.
        vec2 sampleDensity = exp(-sampleHeight / heightScale) * rayStepLength;
        opticalDepth += sampleDensity;

        // Generate ray from the sample position segment to the light source, up to the outer ring of the atmosphere.
        czm_ray lightRay = czm_ray(samplePosition, lightDirection);
        czm_raySegment lightRayAtmosphereIntersect = czm_raySphereIntersectionInterval(lightRay, origin, atmosphereOuterRadius);

        float lightStepLength = lightRayAtmosphereIntersect.stop / float(LIGHT_STEPS);
        float lightPositionLength = 0.0;

        vec2 lightOpticalDepth = vec2(0.0);

        // Sample positions along the light ray, to accumulate incidence of light on the latest sample segment.
        for (int j = 0; j < LIGHT_STEPS_MAX; ++j) {

            // The loop should be: for (int j = 0; i < LIGHT_STEPS; ++j) {...} but WebGL1 cannot
            // loop with non-constant condition, so it has to break early instead
            if (j >= LIGHT_STEPS) {
                break;
            }

            // Calculate sample position along light ray.
            vec3 lightPosition = samplePosition + lightDirection * (lightPositionLength + lightStepLength * 0.5);

            // Calculate height of the light sample position above ellipsoid.
            float lightHeight = length(lightPosition) - atmosphereInnerRadius;

            // Calculate density of photons at the light sample position.
            lightOpticalDepth += exp(-lightHeight / heightScale) * lightStepLength;

            // Increment distance on light ray.
            lightPositionLength += lightStepLength;
        }

        // Compute attenuation via the primary ray and the light ray.
        vec3 attenuation = exp(-((czm_atmosphereMieCoefficient * (opticalDepth.y + lightOpticalDepth.y)) + (czm_atmosphereRayleighCoefficient * (opticalDepth.x + lightOpticalDepth.x))));

        // Accumulate the scattering.
        rayleighAccumulation += sampleDensity.x * attenuation;
        mieAccumulation += sampleDensity.y * attenuation;

        // Increment distance on primary ray.
        rayPositionLength += (rayStepLength += rayStepLengthIncrease);
    }

    // Compute the scattering amount.
    rayleighColor = czm_atmosphereRayleighCoefficient * rayleighAccumulation;
    mieColor = czm_atmosphereMieCoefficient * mieAccumulation;

    // Compute the transmittance i.e. how much light is passing through the atmosphere.
    opacity = length(exp(-((czm_atmosphereMieCoefficient * opticalDepth.y) + (czm_atmosphereRayleighCoefficient * opticalDepth.x))));
}
`});var KQ,XQ=O(()=>{KQ=`/**
 * @private
 */
vec2 cordic(float angle)
{
// Scale the vector by the appropriate factor for the 24 iterations to follow.
    vec2 vector = vec2(6.0725293500888267e-1, 0.0);
// Iteration 1
    float sense = (angle < 0.0) ? -1.0 : 1.0;
 //   float factor = sense * 1.0;  // 2^-0
    mat2 rotation = mat2(1.0, sense, -sense, 1.0);
    vector = rotation * vector;
    angle -= sense * 7.8539816339744828e-1;  // atan(2^-0)
// Iteration 2
    sense = (angle < 0.0) ? -1.0 : 1.0;
    float factor = sense * 5.0e-1;  // 2^-1
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 4.6364760900080609e-1;  // atan(2^-1)
// Iteration 3
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 2.5e-1;  // 2^-2
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 2.4497866312686414e-1;  // atan(2^-2)
// Iteration 4
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.25e-1;  // 2^-3
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.2435499454676144e-1;  // atan(2^-3)
// Iteration 5
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 6.25e-2;  // 2^-4
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 6.2418809995957350e-2;  // atan(2^-4)
// Iteration 6
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 3.125e-2;  // 2^-5
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 3.1239833430268277e-2;  // atan(2^-5)
// Iteration 7
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.5625e-2;  // 2^-6
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.5623728620476831e-2;  // atan(2^-6)
// Iteration 8
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 7.8125e-3;  // 2^-7
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 7.8123410601011111e-3;  // atan(2^-7)
// Iteration 9
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 3.90625e-3;  // 2^-8
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 3.9062301319669718e-3;  // atan(2^-8)
// Iteration 10
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.953125e-3;  // 2^-9
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.9531225164788188e-3;  // atan(2^-9)
// Iteration 11
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 9.765625e-4;  // 2^-10
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 9.7656218955931946e-4;  // atan(2^-10)
// Iteration 12
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 4.8828125e-4;  // 2^-11
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 4.8828121119489829e-4;  // atan(2^-11)
// Iteration 13
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 2.44140625e-4;  // 2^-12
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 2.4414062014936177e-4;  // atan(2^-12)
// Iteration 14
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.220703125e-4;  // 2^-13
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.2207031189367021e-4;  // atan(2^-13)
// Iteration 15
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 6.103515625e-5;  // 2^-14
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 6.1035156174208773e-5;  // atan(2^-14)
// Iteration 16
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 3.0517578125e-5;  // 2^-15
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 3.0517578115526096e-5;  // atan(2^-15)
// Iteration 17
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.52587890625e-5;  // 2^-16
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.5258789061315762e-5;  // atan(2^-16)
// Iteration 18
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 7.62939453125e-6;  // 2^-17
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 7.6293945311019700e-6;  // atan(2^-17)
// Iteration 19
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 3.814697265625e-6;  // 2^-18
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 3.8146972656064961e-6;  // atan(2^-18)
// Iteration 20
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.9073486328125e-6;  // 2^-19
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.9073486328101870e-6;  // atan(2^-19)
// Iteration 21
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 9.5367431640625e-7;  // 2^-20
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 9.5367431640596084e-7;  // atan(2^-20)
// Iteration 22
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 4.76837158203125e-7;  // 2^-21
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 4.7683715820308884e-7;  // atan(2^-21)
// Iteration 23
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 2.384185791015625e-7;  // 2^-22
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 2.3841857910155797e-7;  // atan(2^-22)
// Iteration 24
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.1920928955078125e-7;  // 2^-23
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
//    angle -= sense * 1.1920928955078068e-7;  // atan(2^-23)

    return vector;
}

/**
 * Computes the cosine and sine of the provided angle using the CORDIC algorithm.
 *
 * @name czm_cosineAndSine
 * @glslFunction
 *
 * @param {float} angle The angle in radians.
 *
 * @returns {vec2} The resulting cosine of the angle (as the x coordinate) and sine of the angle (as the y coordinate).
 *
 * @example
 * vec2 v = czm_cosineAndSine(czm_piOverSix);
 * float cosine = v.x;
 * float sine = v.y;
 */
vec2 czm_cosineAndSine(float angle)
{
    if (angle < -czm_piOverTwo || angle > czm_piOverTwo)
    {
        if (angle < 0.0)
        {
            return -cordic(angle + czm_pi);
        }
        else
        {
            return -cordic(angle - czm_pi);
        }
    }
    else
    {
        return cordic(angle);
    }
}
`});var qQ,$Q=O(()=>{qQ=`/**
 * Decompresses texture coordinates that were packed into a single float.
 *
 * @name czm_decompressTextureCoordinates
 * @glslFunction
 *
 * @param {float} encoded The compressed texture coordinates.
 * @returns {vec2} The decompressed texture coordinates.
 */
 vec2 czm_decompressTextureCoordinates(float encoded)
 {
    float temp = encoded / 4096.0;
    float xZeroTo4095 = floor(temp);
    float stx = xZeroTo4095 / 4095.0;
    float sty = (encoded - xZeroTo4095 * 4096.0) / 4095.0;
    return vec2(stx, sty);
 }
`});var t1,e1=O(()=>{t1=`/**
 * Get default parameters for physically based rendering. These defaults
 * describe a rough dielectric (non-metal) surface (e.g. rough plastic).
 *
 * @return {czm_pbrParameters} Default parameters for {@link czm_pbrLighting}
 */
czm_pbrParameters czm_defaultPbrMaterial()
{
    czm_pbrParameters results;
    results.diffuseColor = vec3(1.0);
    results.roughness = 1.0;

    const vec3 REFLECTANCE_DIELECTRIC = vec3(0.04);
    results.f0 = REFLECTANCE_DIELECTRIC;
    return results;
}
`});var i1,n1=O(()=>{i1=`// emulated noperspective
#if (__VERSION__ == 300 || defined(GL_EXT_frag_depth)) && !defined(LOG_DEPTH)
out float v_WindowZ;
#endif

/**
 * Emulates GL_DEPTH_CLAMP, which is not available in WebGL 1 or 2.
 * GL_DEPTH_CLAMP clamps geometry that is outside the near and far planes, 
 * capping the shadow volume. More information here: 
 * https://www.khronos.org/registry/OpenGL/extensions/ARB/ARB_depth_clamp.txt.
 *
 * When GL_EXT_frag_depth is available we emulate GL_DEPTH_CLAMP by ensuring 
 * no geometry gets clipped by setting the clip space z value to 0.0 and then
 * sending the unaltered screen space z value (using emulated noperspective
 * interpolation) to the frag shader where it is clamped to [0,1] and then
 * written with gl_FragDepth (see czm_writeDepthClamp). This technique is based on:
 * https://stackoverflow.com/questions/5960757/how-to-emulate-gl-depth-clamp-nv.
 *
 * When GL_EXT_frag_depth is not available, which is the case on some mobile 
 * devices, we must attempt to fix this only in the vertex shader. 
 * The approach is to clamp the z value to the far plane, which closes the 
 * shadow volume but also distorts the geometry, so there can still be artifacts
 * on frustum seams.
 *
 * @name czm_depthClamp
 * @glslFunction
 *
 * @param {vec4} coords The vertex in clip coordinates.
 * @returns {vec4} The modified vertex.
 *
 * @example
 * gl_Position = czm_depthClamp(czm_modelViewProjection * vec4(position, 1.0));
 *
 * @see czm_writeDepthClamp
 */
vec4 czm_depthClamp(vec4 coords)
{
#ifndef LOG_DEPTH
#if __VERSION__ == 300 || defined(GL_EXT_frag_depth)
    v_WindowZ = (0.5 * (coords.z / coords.w) + 0.5) * coords.w;
    coords.z = 0.0;
#else
    coords.z = min(coords.z, coords.w);
#endif
#endif
    return coords;
}
`});var s1,o1=O(()=>{s1=`/**
 * Computes a 3x3 rotation matrix that transforms vectors from an ellipsoid's east-north-up coordinate system 
 * to eye coordinates.  In east-north-up coordinates, x points east, y points north, and z points along the 
 * surface normal.  East-north-up can be used as an ellipsoid's tangent space for operations such as bump mapping.
 * <br /><br />
 * The ellipsoid is assumed to be centered at the model coordinate's origin.
 *
 * @name czm_eastNorthUpToEyeCoordinates
 * @glslFunction
 *
 * @param {vec3} positionMC The position on the ellipsoid in model coordinates.
 * @param {vec3} normalEC The normalized ellipsoid surface normal, at <code>positionMC</code>, in eye coordinates.
 *
 * @returns {mat3} A 3x3 rotation matrix that transforms vectors from the east-north-up coordinate system to eye coordinates.
 *
 * @example
 * // Transform a vector defined in the east-north-up coordinate 
 * // system, (0, 0, 1) which is the surface normal, to eye 
 * // coordinates.
 * mat3 m = czm_eastNorthUpToEyeCoordinates(positionMC, normalEC);
 * vec3 normalEC = m * vec3(0.0, 0.0, 1.0);
 */
mat3 czm_eastNorthUpToEyeCoordinates(vec3 positionMC, vec3 normalEC)
{
    vec3 tangentMC = normalize(vec3(-positionMC.y, positionMC.x, 0.0));  // normalized surface tangent in model coordinates
    vec3 tangentEC = normalize(czm_normal3D * tangentMC);                // normalized surface tangent in eye coordinates
    vec3 bitangentEC = normalize(cross(normalEC, tangentEC));            // normalized surface bitangent in eye coordinates

    return mat3(
        tangentEC.x,   tangentEC.y,   tangentEC.z,
        bitangentEC.x, bitangentEC.y, bitangentEC.z,
        normalEC.x,    normalEC.y,    normalEC.z);
}
`});var r1,a1=O(()=>{r1=`/**
 * DOC_TBA
 *
 * @name czm_ellipsoidContainsPoint
 * @glslFunction
 *
 */
bool czm_ellipsoidContainsPoint(vec3 ellipsoid_inverseRadii, vec3 point)
{
    vec3 scaled = ellipsoid_inverseRadii * (czm_inverseModelView * vec4(point, 1.0)).xyz;
    return (dot(scaled, scaled) <= 1.0);
}
`});var A1,h1=O(()=>{A1=`/**
 * DOC_TBA
 *
 * @name czm_ellipsoidWgs84TextureCoordinates
 * @glslFunction
 */
vec2 czm_ellipsoidWgs84TextureCoordinates(vec3 normal)
{
    return vec2(atan(normal.y, normal.x) * czm_oneOverTwoPi + 0.5, asin(normal.z) * czm_oneOverPi + 0.5);
}
`});var c1,l1=O(()=>{c1=`/**
 * Compares <code>left</code> and <code>right</code> componentwise. Returns <code>true</code>
 * if they are within <code>epsilon</code> and <code>false</code> otherwise. The inputs
 * <code>left</code> and <code>right</code> can be <code>float</code>s, <code>vec2</code>s,
 * <code>vec3</code>s, or <code>vec4</code>s.
 *
 * @name czm_equalsEpsilon
 * @glslFunction
 *
 * @param {} left The first vector.
 * @param {} right The second vector.
 * @param {float} epsilon The epsilon to use for equality testing.
 * @returns {bool} <code>true</code> if the components are within <code>epsilon</code> and <code>false</code> otherwise.
 *
 * @example
 * // GLSL declarations
 * bool czm_equalsEpsilon(float left, float right, float epsilon);
 * bool czm_equalsEpsilon(vec2 left, vec2 right, float epsilon);
 * bool czm_equalsEpsilon(vec3 left, vec3 right, float epsilon);
 * bool czm_equalsEpsilon(vec4 left, vec4 right, float epsilon);
 */
bool czm_equalsEpsilon(vec4 left, vec4 right, float epsilon) {
    return all(lessThanEqual(abs(left - right), vec4(epsilon)));
}

bool czm_equalsEpsilon(vec3 left, vec3 right, float epsilon) {
    return all(lessThanEqual(abs(left - right), vec3(epsilon)));
}

bool czm_equalsEpsilon(vec2 left, vec2 right, float epsilon) {
    return all(lessThanEqual(abs(left - right), vec2(epsilon)));
}

bool czm_equalsEpsilon(float left, float right, float epsilon) {
    return (abs(left - right) <= epsilon);
}
`});var d1,m1=O(()=>{d1=`/**
 * DOC_TBA
 *
 * @name czm_eyeOffset
 * @glslFunction
 *
 * @param {vec4} positionEC DOC_TBA.
 * @param {vec3} eyeOffset DOC_TBA.
 *
 * @returns {vec4} DOC_TBA.
 */
vec4 czm_eyeOffset(vec4 positionEC, vec3 eyeOffset)
{
    // This equation is approximate in x and y.
    vec4 p = positionEC;
    vec4 zEyeOffset = normalize(p) * eyeOffset.z;
    p.xy += eyeOffset.xy + zEyeOffset.xy;
    p.z += zEyeOffset.z;
    return p;
}
`});var f1,E1=O(()=>{f1=`/**
 * Transforms a position from eye to window coordinates.  The transformation
 * from eye to clip coordinates is done using {@link czm_projection}.
 * The transform from normalized device coordinates to window coordinates is
 * done using {@link czm_viewportTransformation}, which assumes a depth range
 * of <code>near = 0</code> and <code>far = 1</code>.
 * <br /><br />
 * This transform is useful when there is a need to manipulate window coordinates
 * in a vertex shader as done by {@link BillboardCollection}.
 *
 * @name czm_eyeToWindowCoordinates
 * @glslFunction
 *
 * @param {vec4} position The position in eye coordinates to transform.
 *
 * @returns {vec4} The transformed position in window coordinates.
 *
 * @see czm_modelToWindowCoordinates
 * @see czm_projection
 * @see czm_viewportTransformation
 * @see BillboardCollection
 *
 * @example
 * vec4 positionWC = czm_eyeToWindowCoordinates(positionEC);
 */
vec4 czm_eyeToWindowCoordinates(vec4 positionEC)
{
    vec4 q = czm_projection * positionEC;                        // clip coordinates
    q.xyz /= q.w;                                                // normalized device coordinates
    q.xyz = (czm_viewportTransformation * vec4(q.xyz, 1.0)).xyz; // window coordinates
    return q;
}
`});var _1,R1=O(()=>{_1=`/**
 * Approxiamtes atan over the range [0, 1]. Safe to flip output for negative input.
 *
 * Based on Michal Drobot's approximation from ShaderFastLibs, which in turn is based on
 * "Efficient approximations for the arctangent function," Rajan, S. Sichun Wang Inkol, R. Joyal, A., May 2006.
 * Adapted from ShaderFastLibs under MIT License.
 *
 * Chosen for the following characteristics over range [0, 1]:
 * - basically no error at 0 and 1, important for getting around range limit (naive atan2 via atan requires infinite range atan)
 * - no visible artifacts from first-derivative discontinuities, unlike latitude via range-reduced sqrt asin approximations (at equator)
 *
 * The original code is x * (-0.1784 * abs(x) - 0.0663 * x * x + 1.0301);
 * Removed the abs() in here because it isn't needed, the input range is guaranteed as [0, 1] by how we're approximating atan2.
 *
 * @name czm_fastApproximateAtan
 * @glslFunction
 *
 * @param {float} x Value between 0 and 1 inclusive.
 *
 * @returns {float} Approximation of atan(x)
 */
float czm_fastApproximateAtan(float x) {
    return x * (-0.1784 * x - 0.0663 * x * x + 1.0301);
}

/**
 * Approximation of atan2.
 *
 * Range reduction math based on nvidia's cg reference implementation for atan2: http://developer.download.nvidia.com/cg/atan2.html
 * However, we replaced their atan curve with Michael Drobot's (see above).
 *
 * @name czm_fastApproximateAtan
 * @glslFunction
 *
 * @param {float} x Value between -1 and 1 inclusive.
 * @param {float} y Value between -1 and 1 inclusive.
 *
 * @returns {float} Approximation of atan2(x, y)
 */
float czm_fastApproximateAtan(float x, float y) {
    // atan approximations are usually only reliable over [-1, 1], or, in our case, [0, 1] due to modifications.
    // So range-reduce using abs and by flipping whether x or y is on top.
    float t = abs(x); // t used as swap and atan result.
    float opposite = abs(y);
    float adjacent = max(t, opposite);
    opposite = min(t, opposite);

    t = czm_fastApproximateAtan(opposite / adjacent);

    // Undo range reduction
    t = czm_branchFreeTernary(abs(y) > abs(x), czm_piOverTwo - t, t);
    t = czm_branchFreeTernary(x < 0.0, czm_pi - t, t);
    t = czm_branchFreeTernary(y < 0.0, -t, t);
    return t;
}
`});var Z1,I1=O(()=>{Z1=`/**
 * Gets the color with fog at a distance from the camera.
 *
 * @name czm_fog
 * @glslFunction
 *
 * @param {float} distanceToCamera The distance to the camera in meters.
 * @param {vec3} color The original color.
 * @param {vec3} fogColor The color of the fog.
 *
 * @returns {vec3} The color adjusted for fog at the distance from the camera.
 */
vec3 czm_fog(float distanceToCamera, vec3 color, vec3 fogColor)
{
    float scalar = distanceToCamera * czm_fogDensity;
    float fog = 1.0 - exp(-(scalar * scalar));
    return mix(color, fogColor, fog);
}

/**
 * Gets the color with fog at a distance from the camera.
 *
 * @name czm_fog
 * @glslFunction
 *
 * @param {float} distanceToCamera The distance to the camera in meters.
 * @param {vec3} color The original color.
 * @param {vec3} fogColor The color of the fog.
 * @param {float} fogModifierConstant A constant to modify the appearance of fog.
 *
 * @returns {vec3} The color adjusted for fog at the distance from the camera.
 */
vec3 czm_fog(float distanceToCamera, vec3 color, vec3 fogColor, float fogModifierConstant)
{
    float scalar = distanceToCamera * czm_fogDensity;
    float fog = 1.0 - exp(-((fogModifierConstant * scalar + fogModifierConstant) * (scalar * (1.0 + fogModifierConstant))));
    return mix(color, fogColor, fog);
}
`});var p1,u1=O(()=>{p1=`/**
 * Converts a color from RGB space to linear space.
 *
 * @name czm_gammaCorrect
 * @glslFunction
 *
 * @param {vec3} color The color in RGB space.
 * @returns {vec3} The color in linear space.
 */
vec3 czm_gammaCorrect(vec3 color) {
#ifdef HDR
    color = pow(color, vec3(czm_gamma));
#endif
    return color;
}

vec4 czm_gammaCorrect(vec4 color) {
#ifdef HDR
    color.rgb = pow(color.rgb, vec3(czm_gamma));
#endif
    return color;
}
`});var C1,g1=O(()=>{C1=`/**
 * DOC_TBA
 *
 * @name czm_geodeticSurfaceNormal
 * @glslFunction
 *
 * @param {vec3} positionOnEllipsoid DOC_TBA
 * @param {vec3} ellipsoidCenter DOC_TBA
 * @param {vec3} oneOverEllipsoidRadiiSquared DOC_TBA
 * 
 * @returns {vec3} DOC_TBA.
 */
vec3 czm_geodeticSurfaceNormal(vec3 positionOnEllipsoid, vec3 ellipsoidCenter, vec3 oneOverEllipsoidRadiiSquared)
{
    return normalize((positionOnEllipsoid - ellipsoidCenter) * oneOverEllipsoidRadiiSquared);
}
`});var T1,N1=O(()=>{T1=`/**
 * An czm_material with default values. Every material's czm_getMaterial
 * should use this default material as a base for the material it returns.
 * The default normal value is given by materialInput.normalEC.
 *
 * @name czm_getDefaultMaterial
 * @glslFunction
 *
 * @param {czm_materialInput} input The input used to construct the default material.
 *
 * @returns {czm_material} The default material.
 *
 * @see czm_materialInput
 * @see czm_material
 * @see czm_getMaterial
 */
czm_material czm_getDefaultMaterial(czm_materialInput materialInput)
{
    czm_material material;
    material.diffuse = vec3(0.0);
    material.specular = 0.0;
    material.shininess = 1.0;
    material.normal = materialInput.normalEC;
    material.emission = vec3(0.0);
    material.alpha = 1.0;
    return material;
}
`});var b1,F1=O(()=>{b1=`/**
 * Select which direction vector to use for dynamic atmosphere lighting based on an enum value
 *
 * @name czm_getDynamicAtmosphereLightDirection
 * @glslfunction
 * @see DynamicAtmosphereLightingType.js
 *
 * @param {vec3} positionWC the position of the vertex/fragment in world coordinates. This is normalized and returned when dynamic lighting is turned off.
 * @param {float} lightEnum The enum value for selecting between light sources.
 * @return {vec3} The normalized light direction vector. Depending on the enum value, it is either positionWC, czm_lightDirectionWC or czm_sunDirectionWC
 */
vec3 czm_getDynamicAtmosphereLightDirection(vec3 positionWC, float lightEnum) {
    const float NONE = 0.0;
    const float SCENE_LIGHT = 1.0;
    const float SUNLIGHT = 2.0;

    vec3 lightDirection =
        positionWC * float(lightEnum == NONE) +
        czm_lightDirectionWC * float(lightEnum == SCENE_LIGHT) +
        czm_sunDirectionWC * float(lightEnum == SUNLIGHT);
    return normalize(lightDirection);
}
`});var Y1,S1=O(()=>{Y1=`/**
 * Calculates the intensity of diffusely reflected light.
 *
 * @name czm_getLambertDiffuse
 * @glslFunction
 *
 * @param {vec3} lightDirectionEC Unit vector pointing to the light source in eye coordinates.
 * @param {vec3} normalEC The surface normal in eye coordinates.
 *
 * @returns {float} The intensity of the diffuse reflection.
 *
 * @see czm_phong
 *
 * @example
 * float diffuseIntensity = czm_getLambertDiffuse(lightDirectionEC, normalEC);
 * float specularIntensity = czm_getSpecular(lightDirectionEC, toEyeEC, normalEC, 200);
 * vec3 color = (diffuseColor * diffuseIntensity) + (specularColor * specularIntensity);
 */
float czm_getLambertDiffuse(vec3 lightDirectionEC, vec3 normalEC)
{
    return max(dot(lightDirectionEC, normalEC), 0.0);
}
`});var O1,V1=O(()=>{O1=`/**
 * Calculates the specular intensity of reflected light.
 *
 * @name czm_getSpecular
 * @glslFunction
 *
 * @param {vec3} lightDirectionEC Unit vector pointing to the light source in eye coordinates.
 * @param {vec3} toEyeEC Unit vector pointing to the eye position in eye coordinates.
 * @param {vec3} normalEC The surface normal in eye coordinates.
 * @param {float} shininess The sharpness of the specular reflection.  Higher values create a smaller, more focused specular highlight.
 *
 * @returns {float} The intensity of the specular highlight.
 *
 * @see czm_phong
 *
 * @example
 * float diffuseIntensity = czm_getLambertDiffuse(lightDirectionEC, normalEC);
 * float specularIntensity = czm_getSpecular(lightDirectionEC, toEyeEC, normalEC, 200);
 * vec3 color = (diffuseColor * diffuseIntensity) + (specularColor * specularIntensity);
 */
float czm_getSpecular(vec3 lightDirectionEC, vec3 toEyeEC, vec3 normalEC, float shininess)
{
    vec3 toReflectedLight = reflect(-lightDirectionEC, normalEC);
    float specular = max(dot(toReflectedLight, toEyeEC), 0.0);

    // pow has undefined behavior if both parameters <= 0.
    // Prevent this by making sure shininess is at least czm_epsilon2.
    return pow(specular, max(shininess, czm_epsilon2));
}
`});var G1,B1=O(()=>{G1=`/**
 * @private
 */
vec4 czm_getWaterNoise(sampler2D normalMap, vec2 uv, float time, float angleInRadians)
{
    float cosAngle = cos(angleInRadians);
    float sinAngle = sin(angleInRadians);

    // time dependent sampling directions
    vec2 s0 = vec2(1.0/17.0, 0.0);
    vec2 s1 = vec2(-1.0/29.0, 0.0);
    vec2 s2 = vec2(1.0/101.0, 1.0/59.0);
    vec2 s3 = vec2(-1.0/109.0, -1.0/57.0);

    // rotate sampling direction by specified angle
    s0 = vec2((cosAngle * s0.x) - (sinAngle * s0.y), (sinAngle * s0.x) + (cosAngle * s0.y));
    s1 = vec2((cosAngle * s1.x) - (sinAngle * s1.y), (sinAngle * s1.x) + (cosAngle * s1.y));
    s2 = vec2((cosAngle * s2.x) - (sinAngle * s2.y), (sinAngle * s2.x) + (cosAngle * s2.y));
    s3 = vec2((cosAngle * s3.x) - (sinAngle * s3.y), (sinAngle * s3.x) + (cosAngle * s3.y));

    vec2 uv0 = (uv/103.0) + (time * s0);
    vec2 uv1 = uv/107.0 + (time * s1) + vec2(0.23);
    vec2 uv2 = uv/vec2(897.0, 983.0) + (time * s2) + vec2(0.51);
    vec2 uv3 = uv/vec2(991.0, 877.0) + (time * s3) + vec2(0.71);

    uv0 = fract(uv0);
    uv1 = fract(uv1);
    uv2 = fract(uv2);
    uv3 = fract(uv3);
    vec4 noise = (texture(normalMap, uv0)) +
                 (texture(normalMap, uv1)) +
                 (texture(normalMap, uv2)) +
                 (texture(normalMap, uv3));

    // average and scale to between -1 and 1
    return ((noise / 4.0) - 0.5) * 2.0;
}
`});var W1,D1=O(()=>{W1=`/**
 * Adjusts the hue of a color.
 * 
 * @name czm_hue
 * @glslFunction
 * 
 * @param {vec3} rgb The color.
 * @param {float} adjustment The amount to adjust the hue of the color in radians.
 *
 * @returns {float} The color with the hue adjusted.
 *
 * @example
 * vec3 adjustHue = czm_hue(color, czm_pi); // The same as czm_hue(color, -czm_pi)
 */
vec3 czm_hue(vec3 rgb, float adjustment)
{
    const mat3 toYIQ = mat3(0.299,     0.587,     0.114,
                            0.595716, -0.274453, -0.321263,
                            0.211456, -0.522591,  0.311135);
    const mat3 toRGB = mat3(1.0,  0.9563,  0.6210,
                            1.0, -0.2721, -0.6474,
                            1.0, -1.107,   1.7046);
    
    vec3 yiq = toYIQ * rgb;
    float hue = atan(yiq.z, yiq.y) + adjustment;
    float chroma = sqrt(yiq.z * yiq.z + yiq.y * yiq.y);
    
    vec3 color = vec3(yiq.x, chroma * cos(hue), chroma * sin(hue));
    return toRGB * color;
}
`});var M1,U1=O(()=>{M1=`/**
 * Converts a color in linear space to RGB space.
 *
 * @name czm_inverseGamma
 * @glslFunction
 *
 * @param {vec3} color The color in linear space.
 * @returns {vec3} The color in RGB space.
 */
vec3 czm_inverseGamma(vec3 color) {
    return pow(color, vec3(1.0 / czm_gamma));
}
`});var Q1,k1=O(()=>{Q1=`/**
 * Determines if a time interval is empty.
 *
 * @name czm_isEmpty
 * @glslFunction 
 * 
 * @param {czm_raySegment} interval The interval to test.
 * 
 * @returns {bool} <code>true</code> if the time interval is empty; otherwise, <code>false</code>.
 *
 * @example
 * bool b0 = czm_isEmpty(czm_emptyRaySegment);      // true
 * bool b1 = czm_isEmpty(czm_raySegment(0.0, 1.0)); // false
 * bool b2 = czm_isEmpty(czm_raySegment(1.0, 1.0)); // false, contains 1.0.
 */
bool czm_isEmpty(czm_raySegment interval)
{
    return (interval.stop < 0.0);
}
`});var L1,y1=O(()=>{L1=`/**
 * Determines if a time interval is empty.
 *
 * @name czm_isFull
 * @glslFunction 
 * 
 * @param {czm_raySegment} interval The interval to test.
 * 
 * @returns {bool} <code>true</code> if the time interval is empty; otherwise, <code>false</code>.
 *
 * @example
 * bool b0 = czm_isEmpty(czm_emptyRaySegment);      // true
 * bool b1 = czm_isEmpty(czm_raySegment(0.0, 1.0)); // false
 * bool b2 = czm_isEmpty(czm_raySegment(1.0, 1.0)); // false, contains 1.0.
 */
bool czm_isFull(czm_raySegment interval)
{
    return (interval.start == 0.0 && interval.stop == czm_infinity);
}
`});var w1,x1=O(()=>{w1=`/**
 * Computes the fraction of a Web Wercator rectangle at which a given geodetic latitude is located.
 *
 * @name czm_latitudeToWebMercatorFraction
 * @glslFunction
 *
 * @param {float} latitude The geodetic latitude, in radians.
 * @param {float} southMercatorY The Web Mercator coordinate of the southern boundary of the rectangle.
 * @param {float} oneOverMercatorHeight The total height of the rectangle in Web Mercator coordinates.
 *
 * @returns {float} The fraction of the rectangle at which the latitude occurs.  If the latitude is the southern
 *          boundary of the rectangle, the return value will be zero.  If it is the northern boundary, the return
 *          value will be 1.0.  Latitudes in between are mapped according to the Web Mercator projection.
 */ 
float czm_latitudeToWebMercatorFraction(float latitude, float southMercatorY, float oneOverMercatorHeight)
{
    float sinLatitude = sin(latitude);
    float mercatorY = 0.5 * log((1.0 + sinLatitude) / (1.0 - sinLatitude));
    
    return (mercatorY - southMercatorY) * oneOverMercatorHeight;
}
`});var P1,J1=O(()=>{P1=`/**
 * Computes distance from an point in 2D to a line in 2D.
 *
 * @name czm_lineDistance
 * @glslFunction
 *
 * param {vec2} point1 A point along the line.
 * param {vec2} point2 A point along the line.
 * param {vec2} point A point that may or may not be on the line.
 * returns {float} The distance from the point to the line.
 */
float czm_lineDistance(vec2 point1, vec2 point2, vec2 point) {
    return abs((point2.y - point1.y) * point.x - (point2.x - point1.x) * point.y + point2.x * point1.y - point2.y * point1.x) / distance(point2, point1);
}
`});var j1,H1=O(()=>{j1=`/**
 * Converts a linear RGB color to an sRGB color.
 *
 * @param {vec3|vec4} linearIn The color in linear color space.
 * @returns {vec3|vec4} The color in sRGB color space. The vector type matches the input.
 */
vec3 czm_linearToSrgb(vec3 linearIn) 
{
    return pow(linearIn, vec3(1.0/2.2));
}

vec4 czm_linearToSrgb(vec4 linearIn) 
{
    vec3 srgbOut = pow(linearIn.rgb, vec3(1.0/2.2));
    return vec4(srgbOut, linearIn.a);
}
`});var v1,z1=O(()=>{v1=`/**
 * Computes the luminance of a color. 
 *
 * @name czm_luminance
 * @glslFunction
 *
 * @param {vec3} rgb The color.
 * 
 * @returns {float} The luminance.
 *
 * @example
 * float light = czm_luminance(vec3(0.0)); // 0.0
 * float dark = czm_luminance(vec3(1.0));  // ~1.0 
 */
float czm_luminance(vec3 rgb)
{
    // Algorithm from Chapter 10 of Graphics Shaders.
    const vec3 W = vec3(0.2125, 0.7154, 0.0721);
    return dot(rgb, W);
}
`});var K1,X1=O(()=>{K1=`/**
 * Computes the size of a pixel in meters at a distance from the eye.
 * <p>
 * Use this version when passing in a custom pixel ratio. For example, passing in 1.0 will return meters per native device pixel.
 * </p>
 * @name czm_metersPerPixel
 * @glslFunction
 *
 * @param {vec3} positionEC The position to get the meters per pixel in eye coordinates.
 * @param {float} pixelRatio The scaling factor from pixel space to coordinate space
 *
 * @returns {float} The meters per pixel at positionEC.
 */
float czm_metersPerPixel(vec4 positionEC, float pixelRatio)
{
    float width = czm_viewport.z;
    float height = czm_viewport.w;
    float pixelWidth;
    float pixelHeight;

    float top = czm_frustumPlanes.x;
    float bottom = czm_frustumPlanes.y;
    float left = czm_frustumPlanes.z;
    float right = czm_frustumPlanes.w;

    if (czm_sceneMode == czm_sceneMode2D || czm_orthographicIn3D == 1.0)
    {
        float frustumWidth = right - left;
        float frustumHeight = top - bottom;
        pixelWidth = frustumWidth / width;
        pixelHeight = frustumHeight / height;
    }
    else
    {
        float distanceToPixel = -positionEC.z;
        float inverseNear = 1.0 / czm_currentFrustum.x;
        float tanTheta = top * inverseNear;
        pixelHeight = 2.0 * distanceToPixel * tanTheta / height;
        tanTheta = right * inverseNear;
        pixelWidth = 2.0 * distanceToPixel * tanTheta / width;
    }

    return max(pixelWidth, pixelHeight) * pixelRatio;
}

/**
 * Computes the size of a pixel in meters at a distance from the eye.
 * <p>
 * Use this version when scaling by pixel ratio.
 * </p>
 * @name czm_metersPerPixel
 * @glslFunction
 *
 * @param {vec3} positionEC The position to get the meters per pixel in eye coordinates.
 *
 * @returns {float} The meters per pixel at positionEC.
 */
float czm_metersPerPixel(vec4 positionEC)
{
    return czm_metersPerPixel(positionEC, czm_pixelRatio);
}
`});var q1,$1=O(()=>{q1=`/**
 * Transforms a position from model to window coordinates.  The transformation
 * from model to clip coordinates is done using {@link czm_modelViewProjection}.
 * The transform from normalized device coordinates to window coordinates is
 * done using {@link czm_viewportTransformation}, which assumes a depth range
 * of <code>near = 0</code> and <code>far = 1</code>.
 * <br /><br />
 * This transform is useful when there is a need to manipulate window coordinates
 * in a vertex shader as done by {@link BillboardCollection}.
 * <br /><br />
 * This function should not be confused with {@link czm_viewportOrthographic},
 * which is an orthographic projection matrix that transforms from window 
 * coordinates to clip coordinates.
 *
 * @name czm_modelToWindowCoordinates
 * @glslFunction
 *
 * @param {vec4} position The position in model coordinates to transform.
 *
 * @returns {vec4} The transformed position in window coordinates.
 *
 * @see czm_eyeToWindowCoordinates
 * @see czm_modelViewProjection
 * @see czm_viewportTransformation
 * @see czm_viewportOrthographic
 * @see BillboardCollection
 *
 * @example
 * vec4 positionWC = czm_modelToWindowCoordinates(positionMC);
 */
vec4 czm_modelToWindowCoordinates(vec4 position)
{
    vec4 q = czm_modelViewProjection * position;                // clip coordinates
    q.xyz /= q.w;                                                // normalized device coordinates
    q.xyz = (czm_viewportTransformation * vec4(q.xyz, 1.0)).xyz; // window coordinates
    return q;
}
`});var tk,ek=O(()=>{tk=`/**
 * DOC_TBA
 *
 * @name czm_multiplyWithColorBalance
 * @glslFunction
 */
vec3 czm_multiplyWithColorBalance(vec3 left, vec3 right)
{
    // Algorithm from Chapter 10 of Graphics Shaders.
    const vec3 W = vec3(0.2125, 0.7154, 0.0721);
    
    vec3 target = left * right;
    float leftLuminance = dot(left, W);
    float rightLuminance = dot(right, W);
    float targetLuminance = dot(target, W);
    
    return ((leftLuminance + rightLuminance) / (2.0 * targetLuminance)) * target;
}
`});var ik,nk=O(()=>{ik=`/**
 * Computes a value that scales with distance.  The scaling is clamped at the near and
 * far distances, and does not extrapolate.  This function works with the
 * {@link NearFarScalar} JavaScript class.
 *
 * @name czm_nearFarScalar
 * @glslFunction
 *
 * @param {vec4} nearFarScalar A vector with 4 components: Near distance (x), Near value (y), Far distance (z), Far value (w).
 * @param {float} cameraDistSq The square of the current distance from the camera.
 *
 * @returns {float} The value at this distance.
 */
float czm_nearFarScalar(vec4 nearFarScalar, float cameraDistSq)
{
    float valueAtMin = nearFarScalar.y;
    float valueAtMax = nearFarScalar.w;
    float nearDistanceSq = nearFarScalar.x * nearFarScalar.x;
    float farDistanceSq = nearFarScalar.z * nearFarScalar.z;

    float t = (cameraDistSq - nearDistanceSq) / (farDistanceSq - nearDistanceSq);

    t = pow(clamp(t, 0.0, 1.0), 0.2);

    return mix(valueAtMin, valueAtMax, t);
}
`});var sk,ok=O(()=>{sk=` /**
  * Decodes a unit-length vector in 'oct' encoding to a normalized 3-component Cartesian vector.
  * The 'oct' encoding is described in "A Survey of Efficient Representations of Independent Unit Vectors",
  * Cigolle et al 2014: http://jcgt.org/published/0003/02/01/
  *
  * @name czm_octDecode
  * @param {vec2} encoded The oct-encoded, unit-length vector
  * @param {float} range The maximum value of the SNORM range. The encoded vector is stored in log2(rangeMax+1) bits.
  * @returns {vec3} The decoded and normalized vector
  */
  vec3 czm_octDecode(vec2 encoded, float range)
  {
      if (encoded.x == 0.0 && encoded.y == 0.0) {
          return vec3(0.0, 0.0, 0.0);
      }

     encoded = encoded / range * 2.0 - 1.0;
     vec3 v = vec3(encoded.x, encoded.y, 1.0 - abs(encoded.x) - abs(encoded.y));
     if (v.z < 0.0)
     {
         v.xy = (1.0 - abs(v.yx)) * czm_signNotZero(v.xy);
     }

     return normalize(v);
  }

/**
 * Decodes a unit-length vector in 'oct' encoding to a normalized 3-component Cartesian vector.
 * The 'oct' encoding is described in "A Survey of Efficient Representations of Independent Unit Vectors",
 * Cigolle et al 2014: http://jcgt.org/published/0003/02/01/
 *
 * @name czm_octDecode
 * @param {vec2} encoded The oct-encoded, unit-length vector
 * @returns {vec3} The decoded and normalized vector
 */
 vec3 czm_octDecode(vec2 encoded)
 {
    return czm_octDecode(encoded, 255.0);
 }

 /**
 * Decodes a unit-length vector in 'oct' encoding packed into a floating-point number to a normalized 3-component Cartesian vector.
 * The 'oct' encoding is described in "A Survey of Efficient Representations of Independent Unit Vectors",
 * Cigolle et al 2014: http://jcgt.org/published/0003/02/01/
 *
 * @name czm_octDecode
 * @param {float} encoded The oct-encoded, unit-length vector
 * @returns {vec3} The decoded and normalized vector
 */
 vec3 czm_octDecode(float encoded)
 {
    float temp = encoded / 256.0;
    float x = floor(temp);
    float y = (temp - x) * 256.0;
    return czm_octDecode(vec2(x, y));
 }

/**
 * Decodes three unit-length vectors in 'oct' encoding packed into two floating-point numbers to normalized 3-component Cartesian vectors.
 * The 'oct' encoding is described in "A Survey of Efficient Representations of Independent Unit Vectors",
 * Cigolle et al 2014: http://jcgt.org/published/0003/02/01/
 *
 * @name czm_octDecode
 * @param {vec2} encoded The packed oct-encoded, unit-length vectors.
 * @param {vec3} vector1 One decoded and normalized vector.
 * @param {vec3} vector2 One decoded and normalized vector.
 * @param {vec3} vector3 One decoded and normalized vector.
 */
  void czm_octDecode(vec2 encoded, out vec3 vector1, out vec3 vector2, out vec3 vector3)
 {
    float temp = encoded.x / 65536.0;
    float x = floor(temp);
    float encodedFloat1 = (temp - x) * 65536.0;

    temp = encoded.y / 65536.0;
    float y = floor(temp);
    float encodedFloat2 = (temp - y) * 65536.0;

    vector1 = czm_octDecode(encodedFloat1);
    vector2 = czm_octDecode(encodedFloat2);
    vector3 = czm_octDecode(vec2(x, y));
 }

`});var rk,ak=O(()=>{rk=`/**
 * Packs a depth value into a vec3 that can be represented by unsigned bytes.
 *
 * @name czm_packDepth
 * @glslFunction
 *
 * @param {float} depth The floating-point depth.
 * @returns {vec3} The packed depth.
 */
vec4 czm_packDepth(float depth)
{
    // See Aras Pranckevi\u010Dius' post Encoding Floats to RGBA
    // http://aras-p.info/blog/2009/07/30/encoding-floats-to-rgba-the-final/
    vec4 enc = vec4(1.0, 255.0, 65025.0, 16581375.0) * depth;
    enc = fract(enc);
    enc -= enc.yzww * vec4(1.0 / 255.0, 1.0 / 255.0, 1.0 / 255.0, 0.0);
    return enc;
}
`});var Ak,hk=O(()=>{Ak=`vec3 lambertianDiffuse(vec3 diffuseColor)
{
    return diffuseColor / czm_pi;
}

vec3 fresnelSchlick2(vec3 f0, vec3 f90, float VdotH)
{
    return f0 + (f90 - f0) * pow(clamp(1.0 - VdotH, 0.0, 1.0), 5.0);
}

float smithVisibilityG1(float NdotV, float roughness)
{
    // this is the k value for direct lighting.
    // for image based lighting it will be roughness^2 / 2
    float k = (roughness + 1.0) * (roughness + 1.0) / 8.0;
    return NdotV / (NdotV * (1.0 - k) + k);
}

float smithVisibilityGGX(float roughness, float NdotL, float NdotV)
{
    return (
        smithVisibilityG1(NdotL, roughness) *
        smithVisibilityG1(NdotV, roughness)
    );
}

float GGX(float roughness, float NdotH)
{
    float roughnessSquared = roughness * roughness;
    float f = (NdotH * roughnessSquared - NdotH) * NdotH + 1.0;
    return roughnessSquared / (czm_pi * f * f);
}

/**
 * Compute the diffuse and specular contributions using physically based
 * rendering. This function only handles direct lighting.
 * <p>
 * This function only handles the lighting calculations. Metallic/roughness
 * and specular/glossy must be handled separately. See {@czm_pbrMetallicRoughnessMaterial}, {@czm_pbrSpecularGlossinessMaterial} and {@czm_defaultPbrMaterial}
 * </p>
 *
 * @name czm_pbrlighting
 * @glslFunction
 *
 * @param {vec3} positionEC The position of the fragment in eye coordinates
 * @param {vec3} normalEC The surface normal in eye coordinates
 * @param {vec3} lightDirectionEC Unit vector pointing to the light source in eye coordinates.
 * @param {vec3} lightColorHdr radiance of the light source. This is a HDR value.
 * @param {czm_pbrParameters} The computed PBR parameters.
 * @return {vec3} The computed HDR color
 *
 * @example
 * czm_pbrParameters pbrParameters = czm_pbrMetallicRoughnessMaterial(
 *  baseColor,
 *  metallic,
 *  roughness
 * );
 * vec3 color = czm_pbrlighting(
 *  positionEC,
 *  normalEC,
 *  lightDirectionEC,
 *  lightColorHdr,
 *  pbrParameters);
 */
vec3 czm_pbrLighting(
    vec3 positionEC,
    vec3 normalEC,
    vec3 lightDirectionEC,
    vec3 lightColorHdr,
    czm_pbrParameters pbrParameters
)
{
    vec3 v = -normalize(positionEC);
    vec3 l = normalize(lightDirectionEC);
    vec3 h = normalize(v + l);
    vec3 n = normalEC;
    float NdotL = clamp(dot(n, l), 0.001, 1.0);
    float NdotV = abs(dot(n, v)) + 0.001;
    float NdotH = clamp(dot(n, h), 0.0, 1.0);
    float LdotH = clamp(dot(l, h), 0.0, 1.0);
    float VdotH = clamp(dot(v, h), 0.0, 1.0);

    vec3 f0 = pbrParameters.f0;
    float reflectance = max(max(f0.r, f0.g), f0.b);
    vec3 f90 = vec3(clamp(reflectance * 25.0, 0.0, 1.0));
    vec3 F = fresnelSchlick2(f0, f90, VdotH);

    float alpha = pbrParameters.roughness;
    float G = smithVisibilityGGX(alpha, NdotL, NdotV);
    float D = GGX(alpha, NdotH);
    vec3 specularContribution = F * G * D / (4.0 * NdotL * NdotV);

    vec3 diffuseColor = pbrParameters.diffuseColor;
    // F here represents the specular contribution
    vec3 diffuseContribution = (1.0 - F) * lambertianDiffuse(diffuseColor);

    // Lo = (diffuse + specular) * Li * NdotL
    return (diffuseContribution + specularContribution) * NdotL * lightColorHdr;
}
`});var ck,lk=O(()=>{ck=`/**
 * Compute parameters for physically based rendering using the
 * metallic/roughness workflow. All inputs are linear; sRGB texture values must
 * be decoded beforehand
 *
 * @name czm_pbrMetallicRoughnessMaterial
 * @glslFunction
 *
 * @param {vec3} baseColor For dielectrics, this is the base color. For metals, this is the f0 value (reflectance at normal incidence)
 * @param {float} metallic 0.0 indicates dielectric. 1.0 indicates metal. Values in between are allowed (e.g. to model rust or dirt);
 * @param {float} roughness A value between 0.0 and 1.0
 * @return {czm_pbrParameters} parameters to pass into {@link czm_pbrLighting}
 */
czm_pbrParameters czm_pbrMetallicRoughnessMaterial(
    vec3 baseColor,
    float metallic,
    float roughness
) 
{
    czm_pbrParameters results;

    // roughness is authored as perceptual roughness
    // square it to get material roughness
    roughness = clamp(roughness, 0.0, 1.0);
    results.roughness = roughness * roughness;

    // dielectrics use f0 = 0.04, metals use albedo as f0
    metallic = clamp(metallic, 0.0, 1.0);
    const vec3 REFLECTANCE_DIELECTRIC = vec3(0.04);
    vec3 f0 = mix(REFLECTANCE_DIELECTRIC, baseColor, metallic);
    results.f0 = f0;

    // diffuse only applies to dielectrics.
    results.diffuseColor = baseColor * (1.0 - f0) * (1.0 - metallic);

    return results;
}
`});var dk,mk=O(()=>{dk=`/**
 * Compute parameters for physically based rendering using the
 * specular/glossy workflow. All inputs are linear; sRGB texture values must
 * be decoded beforehand
 *
 * @name czm_pbrSpecularGlossinessMaterial
 * @glslFunction
 *
 * @param {vec3} diffuse The diffuse color for dielectrics (non-metals)
 * @param {vec3} specular The reflectance at normal incidence (f0)
 * @param {float} glossiness A number from 0.0 to 1.0 indicating how smooth the surface is.
 * @return {czm_pbrParameters} parameters to pass into {@link czm_pbrLighting}
 */
czm_pbrParameters czm_pbrSpecularGlossinessMaterial(
    vec3 diffuse,
    vec3 specular,
    float glossiness
) 
{
    czm_pbrParameters results;

    // glossiness is the opposite of roughness, but easier for artists to use.
    float roughness = 1.0 - glossiness;
    results.roughness = roughness * roughness;

    results.diffuseColor = diffuse * (1.0 - max(max(specular.r, specular.g), specular.b));
    results.f0 = specular;

    return results;
}
`});var fk,Ek=O(()=>{fk=`float czm_private_getLambertDiffuseOfMaterial(vec3 lightDirectionEC, czm_material material)
{
    return czm_getLambertDiffuse(lightDirectionEC, material.normal);
}

float czm_private_getSpecularOfMaterial(vec3 lightDirectionEC, vec3 toEyeEC, czm_material material)
{
    return czm_getSpecular(lightDirectionEC, toEyeEC, material.normal, material.shininess);
}

/**
 * Computes a color using the Phong lighting model.
 *
 * @name czm_phong
 * @glslFunction
 *
 * @param {vec3} toEye A normalized vector from the fragment to the eye in eye coordinates.
 * @param {czm_material} material The fragment's material.
 *
 * @returns {vec4} The computed color.
 *
 * @example
 * vec3 positionToEyeEC = // ...
 * czm_material material = // ...
 * vec3 lightDirectionEC = // ...
 * out_FragColor = czm_phong(normalize(positionToEyeEC), material, lightDirectionEC);
 *
 * @see czm_getMaterial
 */
vec4 czm_phong(vec3 toEye, czm_material material, vec3 lightDirectionEC)
{
    // Diffuse from directional light sources at eye (for top-down)
    float diffuse = czm_private_getLambertDiffuseOfMaterial(vec3(0.0, 0.0, 1.0), material);
    if (czm_sceneMode == czm_sceneMode3D) {
        // (and horizon views in 3D)
        diffuse += czm_private_getLambertDiffuseOfMaterial(vec3(0.0, 1.0, 0.0), material);
    }

    float specular = czm_private_getSpecularOfMaterial(lightDirectionEC, toEye, material);

    // Temporary workaround for adding ambient.
    vec3 materialDiffuse = material.diffuse * 0.5;

    vec3 ambient = materialDiffuse;
    vec3 color = ambient + material.emission;
    color += materialDiffuse * diffuse * czm_lightColor;
    color += material.specular * specular * czm_lightColor;

    return vec4(color, material.alpha);
}

vec4 czm_private_phong(vec3 toEye, czm_material material, vec3 lightDirectionEC)
{
    float diffuse = czm_private_getLambertDiffuseOfMaterial(lightDirectionEC, material);
    float specular = czm_private_getSpecularOfMaterial(lightDirectionEC, toEye, material);

    vec3 ambient = vec3(0.0);
    vec3 color = ambient + material.emission;
    color += material.diffuse * diffuse * czm_lightColor;
    color += material.specular * specular * czm_lightColor;

    return vec4(color, material.alpha);
}
`});var _k,Rk=O(()=>{_k=`/**
 * Computes distance from a point to a plane.
 *
 * @name czm_planeDistance
 * @glslFunction
 *
 * param {vec4} plane A Plane in Hessian Normal Form. See Plane.js
 * param {vec3} point A point in the same space as the plane.
 * returns {float} The distance from the point to the plane.
 */
float czm_planeDistance(vec4 plane, vec3 point) {
    return (dot(plane.xyz, point) + plane.w);
}

/**
 * Computes distance from a point to a plane.
 *
 * @name czm_planeDistance
 * @glslFunction
 *
 * param {vec3} planeNormal Normal for a plane in Hessian Normal Form. See Plane.js
 * param {float} planeDistance Distance for a plane in Hessian Normal form. See Plane.js
 * param {vec3} point A point in the same space as the plane.
 * returns {float} The distance from the point to the plane.
 */
float czm_planeDistance(vec3 planeNormal, float planeDistance, vec3 point) {
    return (dot(planeNormal, point) + planeDistance);
}
`});var Zk,Ik=O(()=>{Zk=`/**
 * Computes the point along a ray at the given time.  <code>time</code> can be positive, negative, or zero.
 *
 * @name czm_pointAlongRay
 * @glslFunction
 *
 * @param {czm_ray} ray The ray to compute the point along.
 * @param {float} time The time along the ray.
 * 
 * @returns {vec3} The point along the ray at the given time.
 * 
 * @example
 * czm_ray ray = czm_ray(vec3(0.0), vec3(1.0, 0.0, 0.0)); // origin, direction
 * vec3 v = czm_pointAlongRay(ray, 2.0); // (2.0, 0.0, 0.0)
 */
vec3 czm_pointAlongRay(czm_ray ray, float time)
{
    return ray.origin + (time * ray.direction);
}
`});var pk,uk=O(()=>{pk=`/**
 * DOC_TBA
 *
 * @name czm_rayEllipsoidIntersectionInterval
 * @glslFunction
 */
czm_raySegment czm_rayEllipsoidIntersectionInterval(czm_ray ray, vec3 ellipsoid_center, vec3 ellipsoid_inverseRadii)
{
   // ray and ellipsoid center in eye coordinates.  radii in model coordinates.
    vec3 q = ellipsoid_inverseRadii * (czm_inverseModelView * vec4(ray.origin, 1.0)).xyz;
    vec3 w = ellipsoid_inverseRadii * (czm_inverseModelView * vec4(ray.direction, 0.0)).xyz;

    q = q - ellipsoid_inverseRadii * (czm_inverseModelView * vec4(ellipsoid_center, 1.0)).xyz;

    float q2 = dot(q, q);
    float qw = dot(q, w);

    if (q2 > 1.0) // Outside ellipsoid.
    {
        if (qw >= 0.0) // Looking outward or tangent (0 intersections).
        {
            return czm_emptyRaySegment;
        }
        else // qw < 0.0.
        {
            float qw2 = qw * qw;
            float difference = q2 - 1.0; // Positively valued.
            float w2 = dot(w, w);
            float product = w2 * difference;

            if (qw2 < product) // Imaginary roots (0 intersections).
            {
                return czm_emptyRaySegment;
            }
            else if (qw2 > product) // Distinct roots (2 intersections).
            {
                float discriminant = qw * qw - product;
                float temp = -qw + sqrt(discriminant); // Avoid cancellation.
                float root0 = temp / w2;
                float root1 = difference / temp;
                if (root0 < root1)
                {
                    czm_raySegment i = czm_raySegment(root0, root1);
                    return i;
                }
                else
                {
                    czm_raySegment i = czm_raySegment(root1, root0);
                    return i;
                }
            }
            else // qw2 == product.  Repeated roots (2 intersections).
            {
                float root = sqrt(difference / w2);
                czm_raySegment i = czm_raySegment(root, root);
                return i;
            }
        }
    }
    else if (q2 < 1.0) // Inside ellipsoid (2 intersections).
    {
        float difference = q2 - 1.0; // Negatively valued.
        float w2 = dot(w, w);
        float product = w2 * difference; // Negatively valued.
        float discriminant = qw * qw - product;
        float temp = -qw + sqrt(discriminant); // Positively valued.
        czm_raySegment i = czm_raySegment(0.0, temp / w2);
        return i;
    }
    else // q2 == 1.0. On ellipsoid.
    {
        if (qw < 0.0) // Looking inward.
        {
            float w2 = dot(w, w);
            czm_raySegment i = czm_raySegment(0.0, -qw / w2);
            return i;
        }
        else // qw >= 0.0.  Looking outward or tangent.
        {
            return czm_emptyRaySegment;
        }
    }
}
`});var Ck,gk=O(()=>{Ck=`/**
 * Compute the intersection interval of a ray with a sphere.
 *
 * @name czm_raySphereIntersectionInterval
 * @glslFunction
 *
 * @param {czm_ray} ray The ray.
 * @param {vec3} center The center of the sphere.
 * @param {float} radius The radius of the sphere.
 * @return {czm_raySegment} The intersection interval of the ray with the sphere.
 */
czm_raySegment czm_raySphereIntersectionInterval(czm_ray ray, vec3 center, float radius)
{
    vec3 o = ray.origin;
    vec3 d = ray.direction;

    vec3 oc = o - center;

    float a = dot(d, d);
    float b = 2.0 * dot(d, oc);
    float c = dot(oc, oc) - (radius * radius);

    float det = (b * b) - (4.0 * a * c);

    if (det < 0.0) {
        return czm_emptyRaySegment;
    }

    float sqrtDet = sqrt(det);

    float t0 = (-b - sqrtDet) / (2.0 * a);
    float t1 = (-b + sqrtDet) / (2.0 * a);

    czm_raySegment result = czm_raySegment(t0, t1);
    return result;
}
`});var Tk,Nk=O(()=>{Tk=`float czm_readDepth(sampler2D depthTexture, vec2 texCoords)
{
    return czm_reverseLogDepth(texture(depthTexture, texCoords).r);
}
`});var bk,Fk=O(()=>{bk=`/**
 * Reads a value previously transformed with {@link czm_writeNonPerspective}
 * by dividing it by \`w\`, the value used in the perspective divide.
 * This function is intended to be called in a fragment shader to access a
 * \`varying\` that should not be subject to perspective interpolation.
 * For example, screen-space texture coordinates. The value should have been
 * previously written in the vertex shader with a call to
 * {@link czm_writeNonPerspective}.
 *
 * @name czm_readNonPerspective
 * @glslFunction
 *
 * @param {float|vec2|vec3|vec4} value The non-perspective value to be read.
 * @param {float} oneOverW One over the perspective divide value, \`w\`. Usually this is simply \`gl_FragCoord.w\`.
 * @returns {float|vec2|vec3|vec4} The usable value.
 */
float czm_readNonPerspective(float value, float oneOverW) {
    return value * oneOverW;
}

vec2 czm_readNonPerspective(vec2 value, float oneOverW) {
    return value * oneOverW;
}

vec3 czm_readNonPerspective(vec3 value, float oneOverW) {
    return value * oneOverW;
}

vec4 czm_readNonPerspective(vec4 value, float oneOverW) {
    return value * oneOverW;
}
`});var Yk,Sk=O(()=>{Yk=`float czm_reverseLogDepth(float logZ)
{
#ifdef LOG_DEPTH
    float near = czm_currentFrustum.x;
    float far = czm_currentFrustum.y;
    float log2Depth = logZ * czm_log2FarDepthFromNearPlusOne;
    float depthFromNear = pow(2.0, log2Depth) - 1.0;
    return far * (1.0 - near / (depthFromNear + near)) / (far - near);
#endif
    return logZ;
}
`});var Ok,Vk=O(()=>{Ok=`/**
 * Round a floating point value. This function exists because round() doesn't
 * exist in GLSL 1.00. 
 *
 * @param {float|vec2|vec3|vec4} value The value to round
 * @param {float|vec2|vec3|vec3} The rounded value. The type matches the input.
 */
float czm_round(float value) {
  return floor(value + 0.5);
}

vec2 czm_round(vec2 value) {
  return floor(value + 0.5);
}

vec3 czm_round(vec3 value) {
  return floor(value + 0.5);
}

vec4 czm_round(vec4 value) {
  return floor(value + 0.5);
}
`});var Gk,Bk=O(()=>{Gk=`/**
 * Samples the 4 neighboring pixels and return the weighted average.
 *
 * @private
 */
vec3 czm_sampleOctahedralProjectionWithFiltering(sampler2D projectedMap, vec2 textureSize, vec3 direction, float lod)
{
    direction /= dot(vec3(1.0), abs(direction));
    vec2 rev = abs(direction.zx) - vec2(1.0);
    vec2 neg = vec2(direction.x < 0.0 ? rev.x : -rev.x,
                    direction.z < 0.0 ? rev.y : -rev.y);
    vec2 uv = direction.y < 0.0 ? neg : direction.xz;
    vec2 coord = 0.5 * uv + vec2(0.5);
    vec2 pixel = 1.0 / textureSize;

    if (lod > 0.0)
    {
        // Each subseqeuent mip level is half the size
        float scale = 1.0 / pow(2.0, lod);
        float offset = ((textureSize.y + 1.0) / textureSize.x);

        coord.x *= offset;
        coord *= scale;

        coord.x += offset + pixel.x;
        coord.y += (1.0 - (1.0 / pow(2.0, lod - 1.0))) + pixel.y * (lod - 1.0) * 2.0;
    }
    else
    {
        coord.x *= (textureSize.y / textureSize.x);
    }

    // Do bilinear filtering
    #ifndef OES_texture_float_linear
        vec3 color1 = texture(projectedMap, coord + vec2(0.0, pixel.y)).rgb;
        vec3 color2 = texture(projectedMap, coord + vec2(pixel.x, 0.0)).rgb;
        vec3 color3 = texture(projectedMap, coord + pixel).rgb;
        vec3 color4 = texture(projectedMap, coord).rgb;

        vec2 texturePosition = coord * textureSize;

        float fu = fract(texturePosition.x);
        float fv = fract(texturePosition.y);

        vec3 average1 = mix(color4, color2, fu);
        vec3 average2 = mix(color1, color3, fu);

        vec3 color = mix(average1, average2, fv);
    #else
        vec3 color = texture(projectedMap, coord).rgb;
    #endif

    return color;
}


/**
 * Samples from a cube map that has been projected using an octahedral projection from the given direction.
 *
 * @name czm_sampleOctahedralProjection
 * @glslFunction
 *
 * @param {sampler2D} projectedMap The texture with the octahedral projected cube map.
 * @param {vec2} textureSize The width and height dimensions in pixels of the projected map.
 * @param {vec3} direction The normalized direction used to sample the cube map.
 * @param {float} lod The level of detail to sample.
 * @param {float} maxLod The maximum level of detail.
 * @returns {vec3} The color of the cube map at the direction.
 */
vec3 czm_sampleOctahedralProjection(sampler2D projectedMap, vec2 textureSize, vec3 direction, float lod, float maxLod) {
    float currentLod = floor(lod + 0.5);
    float nextLod = min(currentLod + 1.0, maxLod);

    vec3 colorCurrentLod = czm_sampleOctahedralProjectionWithFiltering(projectedMap, textureSize, direction, currentLod);
    vec3 colorNextLod = czm_sampleOctahedralProjectionWithFiltering(projectedMap, textureSize, direction, nextLod);

    return mix(colorNextLod, colorCurrentLod, nextLod - lod);
}
`});var Wk,Dk=O(()=>{Wk=`/**
 * Adjusts the saturation of a color.
 * 
 * @name czm_saturation
 * @glslFunction
 * 
 * @param {vec3} rgb The color.
 * @param {float} adjustment The amount to adjust the saturation of the color.
 *
 * @returns {float} The color with the saturation adjusted.
 *
 * @example
 * vec3 greyScale = czm_saturation(color, 0.0);
 * vec3 doubleSaturation = czm_saturation(color, 2.0);
 */
vec3 czm_saturation(vec3 rgb, float adjustment)
{
    // Algorithm from Chapter 16 of OpenGL Shading Language
    const vec3 W = vec3(0.2125, 0.7154, 0.0721);
    vec3 intensity = vec3(dot(rgb, W));
    return mix(intensity, rgb, adjustment);
}
`});var Mk,Uk=O(()=>{Mk=`
float czm_sampleShadowMap(highp samplerCube shadowMap, vec3 d)
{
    return czm_unpackDepth(czm_textureCube(shadowMap, d));
}

float czm_sampleShadowMap(highp sampler2D shadowMap, vec2 uv)
{
#ifdef USE_SHADOW_DEPTH_TEXTURE
    return texture(shadowMap, uv).r;
#else
    return czm_unpackDepth(texture(shadowMap, uv));
#endif
}

float czm_shadowDepthCompare(samplerCube shadowMap, vec3 uv, float depth)
{
    return step(depth, czm_sampleShadowMap(shadowMap, uv));
}

float czm_shadowDepthCompare(sampler2D shadowMap, vec2 uv, float depth)
{
    return step(depth, czm_sampleShadowMap(shadowMap, uv));
}
`});var Qk,kk=O(()=>{Qk=`
float czm_private_shadowVisibility(float visibility, float nDotL, float normalShadingSmooth, float darkness)
{
#ifdef USE_NORMAL_SHADING
#ifdef USE_NORMAL_SHADING_SMOOTH
    float strength = clamp(nDotL / normalShadingSmooth, 0.0, 1.0);
#else
    float strength = step(0.0, nDotL);
#endif
    visibility *= strength;
#endif

    visibility = max(visibility, darkness);
    return visibility;
}

#ifdef USE_CUBE_MAP_SHADOW
float czm_shadowVisibility(samplerCube shadowMap, czm_shadowParameters shadowParameters)
{
    float depthBias = shadowParameters.depthBias;
    float depth = shadowParameters.depth;
    float nDotL = shadowParameters.nDotL;
    float normalShadingSmooth = shadowParameters.normalShadingSmooth;
    float darkness = shadowParameters.darkness;
    vec3 uvw = shadowParameters.texCoords;

    depth -= depthBias;
    float visibility = czm_shadowDepthCompare(shadowMap, uvw, depth);
    return czm_private_shadowVisibility(visibility, nDotL, normalShadingSmooth, darkness);
}
#else
float czm_shadowVisibility(sampler2D shadowMap, czm_shadowParameters shadowParameters)
{
    float depthBias = shadowParameters.depthBias;
    float depth = shadowParameters.depth;
    float nDotL = shadowParameters.nDotL;
    float normalShadingSmooth = shadowParameters.normalShadingSmooth;
    float darkness = shadowParameters.darkness;
    vec2 uv = shadowParameters.texCoords;

    depth -= depthBias;
#ifdef USE_SOFT_SHADOWS
    vec2 texelStepSize = shadowParameters.texelStepSize;
    float radius = 1.0;
    float dx0 = -texelStepSize.x * radius;
    float dy0 = -texelStepSize.y * radius;
    float dx1 = texelStepSize.x * radius;
    float dy1 = texelStepSize.y * radius;
    float visibility = (
        czm_shadowDepthCompare(shadowMap, uv, depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx0, dy0), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(0.0, dy0), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx1, dy0), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx0, 0.0), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx1, 0.0), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx0, dy1), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(0.0, dy1), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx1, dy1), depth)
    ) * (1.0 / 9.0);
#else
    float visibility = czm_shadowDepthCompare(shadowMap, uv, depth);
#endif

    return czm_private_shadowVisibility(visibility, nDotL, normalShadingSmooth, darkness);
}
#endif
`});var Lk,yk=O(()=>{Lk=`/**
 * Returns 1.0 if the given value is positive or zero, and -1.0 if it is negative.  This is similar to the GLSL
 * built-in function <code>sign</code> except that returns 1.0 instead of 0.0 when the input value is 0.0.
 * 
 * @name czm_signNotZero
 * @glslFunction
 *
 * @param {} value The value for which to determine the sign.
 * @returns {} 1.0 if the value is positive or zero, -1.0 if the value is negative.
 */
float czm_signNotZero(float value)
{
    return value >= 0.0 ? 1.0 : -1.0;
}

vec2 czm_signNotZero(vec2 value)
{
    return vec2(czm_signNotZero(value.x), czm_signNotZero(value.y));
}

vec3 czm_signNotZero(vec3 value)
{
    return vec3(czm_signNotZero(value.x), czm_signNotZero(value.y), czm_signNotZero(value.z));
}

vec4 czm_signNotZero(vec4 value)
{
    return vec4(czm_signNotZero(value.x), czm_signNotZero(value.y), czm_signNotZero(value.z), czm_signNotZero(value.w));
}
`});var wk,xk=O(()=>{wk=`/**
 * Computes a color from the third order spherical harmonic coefficients and a normalized direction vector.
 * <p>
 * The order of the coefficients is [L00, L1_1, L10, L11, L2_2, L2_1, L20, L21, L22].
 * </p>
 *
 * @name czm_sphericalHarmonics
 * @glslFunction
 *
 * @param {vec3} normal The normalized direction.
 * @param {vec3[9]} coefficients The third order spherical harmonic coefficients.
 * @returns {vec3} The color at the direction.
 *
 * @see https://graphics.stanford.edu/papers/envmap/envmap.pdf
 */
vec3 czm_sphericalHarmonics(vec3 normal, vec3 coefficients[9])
{
    vec3 L00 = coefficients[0];
    vec3 L1_1 = coefficients[1];
    vec3 L10 = coefficients[2];
    vec3 L11 = coefficients[3];
    vec3 L2_2 = coefficients[4];
    vec3 L2_1 = coefficients[5];
    vec3 L20 = coefficients[6];
    vec3 L21 = coefficients[7];
    vec3 L22 = coefficients[8];

    float x = normal.x;
    float y = normal.y;
    float z = normal.z;

    return
          L00
        + L1_1 * y
        + L10 * z
        + L11 * x
        + L2_2 * (y * x)
        + L2_1 * (y * z)
        + L20 * (3.0 * z * z - 1.0)
        + L21 * (z * x)
        + L22 * (x * x - y * y);
}
`});var Pk,Jk=O(()=>{Pk=`/**
 * Converts an sRGB color to a linear RGB color.
 *
 * @param {vec3|vec4} srgbIn The color in sRGB space
 * @returns {vec3|vec4} The color in linear color space. The vector type matches the input.
 */
vec3 czm_srgbToLinear(vec3 srgbIn)
{
    return pow(srgbIn, vec3(2.2));
}

vec4 czm_srgbToLinear(vec4 srgbIn) 
{
    vec3 linearOut = pow(srgbIn.rgb, vec3(2.2));
    return vec4(linearOut, srgbIn.a);
}
`});var jk,Hk=O(()=>{jk=`/**
 * Creates a matrix that transforms vectors from tangent space to eye space.
 *
 * @name czm_tangentToEyeSpaceMatrix
 * @glslFunction
 *
 * @param {vec3} normalEC The normal vector in eye coordinates.
 * @param {vec3} tangentEC The tangent vector in eye coordinates.
 * @param {vec3} bitangentEC The bitangent vector in eye coordinates.
 *
 * @returns {mat3} The matrix that transforms from tangent space to eye space.
 *
 * @example
 * mat3 tangentToEye = czm_tangentToEyeSpaceMatrix(normalEC, tangentEC, bitangentEC);
 * vec3 normal = tangentToEye * texture(normalMap, st).xyz;
 */
mat3 czm_tangentToEyeSpaceMatrix(vec3 normalEC, vec3 tangentEC, vec3 bitangentEC)
{
    vec3 normal = normalize(normalEC);
    vec3 tangent = normalize(tangentEC);
    vec3 bitangent = normalize(bitangentEC);
    return mat3(tangent.x  , tangent.y  , tangent.z,
                bitangent.x, bitangent.y, bitangent.z,
                normal.x   , normal.y   , normal.z);
}
`});var vk,zk=O(()=>{vk=`/**
 * A wrapper around the texture (WebGL2) / textureCube (WebGL1)
 * function to allow for WebGL 1 support.
 * 
 * @name czm_textureCube
 * @glslFunction
 *
 * @param {samplerCube} sampler The sampler.
 * @param {vec3} p The coordinates to sample the texture at.
 */
vec4 czm_textureCube(samplerCube sampler, vec3 p) {
#if __VERSION__ == 300
    return texture(sampler, p);
#else  
    return textureCube(sampler, p);
#endif
}`});var Kk,Xk=O(()=>{Kk=`/**
 * Transforms a plane.
 * 
 * @name czm_transformPlane
 * @glslFunction
 *
 * @param {vec4} plane The plane in Hessian Normal Form.
 * @param {mat4} transform The inverse-transpose of a transformation matrix.
 */
vec4 czm_transformPlane(vec4 plane, mat4 transform) {
    vec4 transformedPlane = transform * plane;
    // Convert the transformed plane to Hessian Normal Form
    float normalMagnitude = length(transformedPlane.xyz);
    return transformedPlane / normalMagnitude;
}
`});var qk,$k=O(()=>{qk=`/**
 * Translates a position (or any <code>vec3</code>) that was encoded with {@link EncodedCartesian3},
 * and then provided to the shader as separate <code>high</code> and <code>low</code> bits to
 * be relative to the eye.  As shown in the example, the position can then be transformed in eye
 * or clip coordinates using {@link czm_modelViewRelativeToEye} or {@link czm_modelViewProjectionRelativeToEye},
 * respectively.
 * <p>
 * This technique, called GPU RTE, eliminates jittering artifacts when using large coordinates as
 * described in {@link http://help.agi.com/AGIComponents/html/BlogPrecisionsPrecisions.htm|Precisions, Precisions}.
 * </p>
 *
 * @name czm_translateRelativeToEye
 * @glslFunction
 *
 * @param {vec3} high The position's high bits.
 * @param {vec3} low The position's low bits.
 * @returns {vec3} The position translated to be relative to the camera's position.
 *
 * @example
 * in vec3 positionHigh;
 * in vec3 positionLow;
 *
 * void main()
 * {
 *   vec4 p = czm_translateRelativeToEye(positionHigh, positionLow);
 *   gl_Position = czm_modelViewProjectionRelativeToEye * p;
 * }
 *
 * @see czm_modelViewRelativeToEye
 * @see czm_modelViewProjectionRelativeToEye
 * @see czm_computePosition
 * @see EncodedCartesian3
 */
vec4 czm_translateRelativeToEye(vec3 high, vec3 low)
{
    vec3 highDifference = high - czm_encodedCameraPositionMCHigh;
    // This check handles the case when NaN values have gotten into \`highDifference\`.
    // Such a thing could happen on devices running iOS.
    if (length(highDifference) == 0.0) {  
        highDifference = vec3(0);  
    }
    vec3 lowDifference = low - czm_encodedCameraPositionMCLow;

    return vec4(highDifference + lowDifference, 1.0);
}
`});var tL,eL=O(()=>{tL=`/**
 * @private
 */
vec4 czm_translucentPhong(vec3 toEye, czm_material material, vec3 lightDirectionEC)
{
    // Diffuse from directional light sources at eye (for top-down and horizon views)
    float diffuse = czm_getLambertDiffuse(vec3(0.0, 0.0, 1.0), material.normal);

    if (czm_sceneMode == czm_sceneMode3D) {
        // (and horizon views in 3D)
        diffuse += czm_getLambertDiffuse(vec3(0.0, 1.0, 0.0), material.normal);
    }

    diffuse = clamp(diffuse, 0.0, 1.0);

    float specular = czm_getSpecular(lightDirectionEC, toEye, material.normal, material.shininess);

    // Temporary workaround for adding ambient.
    vec3 materialDiffuse = material.diffuse * 0.5;

    vec3 ambient = materialDiffuse;
    vec3 color = ambient + material.emission;
    color += materialDiffuse * diffuse * czm_lightColor;
    color += material.specular * specular * czm_lightColor;

    return vec4(color, material.alpha);
}
`});var iL,nL=O(()=>{iL=`/**
 * Returns the transpose of the matrix.  The input <code>matrix</code> can be
 * a <code>mat2</code>, <code>mat3</code>, or <code>mat4</code>.
 *
 * @name czm_transpose
 * @glslFunction
 *
 * @param {} matrix The matrix to transpose.
 *
 * @returns {} The transposed matrix.
 *
 * @example
 * // GLSL declarations
 * mat2 czm_transpose(mat2 matrix);
 * mat3 czm_transpose(mat3 matrix);
 * mat4 czm_transpose(mat4 matrix);
 *
 * // Transpose a 3x3 rotation matrix to find its inverse.
 * mat3 eastNorthUpToEye = czm_eastNorthUpToEyeCoordinates(
 *     positionMC, normalEC);
 * mat3 eyeToEastNorthUp = czm_transpose(eastNorthUpToEye);
 */
mat2 czm_transpose(mat2 matrix)
{
    return mat2(
        matrix[0][0], matrix[1][0],
        matrix[0][1], matrix[1][1]);
}

mat3 czm_transpose(mat3 matrix)
{
    return mat3(
        matrix[0][0], matrix[1][0], matrix[2][0],
        matrix[0][1], matrix[1][1], matrix[2][1],
        matrix[0][2], matrix[1][2], matrix[2][2]);
}

mat4 czm_transpose(mat4 matrix)
{
    return mat4(
        matrix[0][0], matrix[1][0], matrix[2][0], matrix[3][0],
        matrix[0][1], matrix[1][1], matrix[2][1], matrix[3][1],
        matrix[0][2], matrix[1][2], matrix[2][2], matrix[3][2],
        matrix[0][3], matrix[1][3], matrix[2][3], matrix[3][3]);
}
`});var sL,oL=O(()=>{sL=`vec2 getLookupUv(vec2 dimensions, int i) {
    int pixY = i / int(dimensions.x);
    int pixX = i - (pixY * int(dimensions.x));
    float pixelWidth = 1.0 / dimensions.x;
    float pixelHeight = 1.0 / dimensions.y;
    float u = (float(pixX) + 0.5) * pixelWidth; // sample from center of pixel
    float v = (float(pixY) + 0.5) * pixelHeight;
    return vec2(u, v);
}

vec4 czm_unpackClippingExtents(highp sampler2D extentsTexture, int index) {
    vec2 textureDimensions = vec2(textureSize(extentsTexture, 0));
    return texture(extentsTexture, getLookupUv(textureDimensions, index));
}`});var rL,aL=O(()=>{rL=`/**
 * Unpacks a vec4 depth value to a float in [0, 1) range.
 *
 * @name czm_unpackDepth
 * @glslFunction
 *
 * @param {vec4} packedDepth The packed depth.
 *
 * @returns {float} The floating-point depth in [0, 1) range.
 */
 float czm_unpackDepth(vec4 packedDepth)
 {
    // See Aras Pranckevi\u010Dius' post Encoding Floats to RGBA
    // http://aras-p.info/blog/2009/07/30/encoding-floats-to-rgba-the-final/
    return dot(packedDepth, vec4(1.0, 1.0 / 255.0, 1.0 / 65025.0, 1.0 / 16581375.0));
 }
`});var AL,hL=O(()=>{AL=`/**
 * Unpack an IEEE 754 single-precision float that is packed as a little-endian unsigned normalized vec4.
 *
 * @name czm_unpackFloat
 * @glslFunction
 *
 * @param {vec4} packedFloat The packed float.
 *
 * @returns {float} The floating-point depth in arbitrary range.
 */
float czm_unpackFloat(vec4 packedFloat)
{
    // Convert to [0.0, 255.0] and round to integer
    packedFloat = floor(packedFloat * 255.0 + 0.5);
    float sign = 1.0 - step(128.0, packedFloat[3]) * 2.0;
    float exponent = 2.0 * mod(packedFloat[3], 128.0) + step(128.0, packedFloat[2]) - 127.0;    
    if (exponent == -127.0)
    {
        return 0.0;
    }
    float mantissa = mod(packedFloat[2], 128.0) * 65536.0 + packedFloat[1] * 256.0 + packedFloat[0] + float(0x800000);
    float result = sign * exp2(exponent - 23.0) * mantissa;
    return result;
}
`});var cL,lL=O(()=>{cL=`/**
 * Unpack unsigned integers of 1-4 bytes. in WebGL 1, there is no uint type,
 * so the return value is an int.
 * <p>
 * There are also precision limitations in WebGL 1. highp int is still limited
 * to 24 bits. Above the value of 2^24 = 16777216, precision loss may occur.
 * </p>
 *
 * @param {float|vec2|vec3|vec4} packed The packed value. For vectors, the components are listed in little-endian order.
 *
 * @return {int} The unpacked value.
 */
 int czm_unpackUint(float packedValue) {
   float rounded = czm_round(packedValue * 255.0);
   return int(rounded);
 }

 int czm_unpackUint(vec2 packedValue) {
   vec2 rounded = czm_round(packedValue * 255.0);
   return int(dot(rounded, vec2(1.0, 256.0)));
 }

 int czm_unpackUint(vec3 packedValue) {
   vec3 rounded = czm_round(packedValue * 255.0);
   return int(dot(rounded, vec3(1.0, 256.0, 65536.0)));
 }

 int czm_unpackUint(vec4 packedValue) {
   vec4 rounded = czm_round(packedValue * 255.0);
   return int(dot(rounded, vec4(1.0, 256.0, 65536.0, 16777216.0)));
 }
`});var dL,mL=O(()=>{dL=`/**
 * Transform metadata values following the EXT_structural_metadata spec
 * by multiplying by scale and adding the offset. Operations are always
 * performed component-wise, even for matrices.
 * 
 * @param {float|vec2|vec3|vec4|mat2|mat3|mat4} offset The offset to add
 * @param {float|vec2|vec3|vec4|mat2|mat3|mat4} scale The scale factor to multiply
 * @param {float|vec2|vec3|vec4|mat2|mat3|mat4} value The original value.
 *
 * @return {float|vec2|vec3|vec4|mat2|mat3|mat4} The transformed value of the same scalar/vector/matrix type as the input.
 */
float czm_valueTransform(float offset, float scale, float value) {
  return scale * value + offset;
}

vec2 czm_valueTransform(vec2 offset, vec2 scale, vec2 value) {
  return scale * value + offset;
}

vec3 czm_valueTransform(vec3 offset, vec3 scale, vec3 value) {
  return scale * value + offset;
}

vec4 czm_valueTransform(vec4 offset, vec4 scale, vec4 value) {
  return scale * value + offset;
}

mat2 czm_valueTransform(mat2 offset, mat2 scale, mat2 value) {
  return matrixCompMult(scale, value) + offset;
}

mat3 czm_valueTransform(mat3 offset, mat3 scale, mat3 value) {
  return matrixCompMult(scale, value) + offset;
}

mat4 czm_valueTransform(mat4 offset, mat4 scale, mat4 value) {
  return matrixCompMult(scale, value) + offset;
}
`});var fL,EL=O(()=>{fL=`#ifdef LOG_DEPTH
// 1.0 at the near plane, increasing linearly from there.
out float v_depthFromNearPlusOne;
#ifdef SHADOW_MAP
out vec3 v_logPositionEC;
#endif
#endif

vec4 czm_updatePositionDepth(vec4 coords) {
#if defined(LOG_DEPTH)

#ifdef SHADOW_MAP
    vec3 logPositionEC = (czm_inverseProjection * coords).xyz;
    v_logPositionEC = logPositionEC;
#endif

    // With the very high far/near ratios used with the logarithmic depth
    // buffer, floating point rounding errors can cause linear depth values
    // to end up on the wrong side of the far plane, even for vertices that
    // are really nowhere near it. Since we always write a correct logarithmic
    // depth value in the fragment shader anyway, we just need to make sure
    // such errors don't cause the primitive to be clipped entirely before
    // we even get to the fragment shader.
    coords.z = clamp(coords.z / coords.w, -1.0, 1.0) * coords.w;
#endif

    return coords;
}

/**
 * Writes the logarithmic depth to gl_Position using the already computed gl_Position.
 *
 * @name czm_vertexLogDepth
 * @glslFunction
 */
void czm_vertexLogDepth()
{
#ifdef LOG_DEPTH
    v_depthFromNearPlusOne = (gl_Position.w - czm_currentFrustum.x) + 1.0;
    gl_Position = czm_updatePositionDepth(gl_Position);
#endif
}

/**
 * Writes the logarithmic depth to gl_Position using the provided clip coordinates.
 * <p>
 * An example use case for this function would be moving the vertex in window coordinates
 * before converting back to clip coordinates. Use the original vertex clip coordinates.
 * </p>
 * @name czm_vertexLogDepth
 * @glslFunction
 *
 * @param {vec4} clipCoords The vertex in clip coordinates.
 *
 * @example
 * czm_vertexLogDepth(czm_projection * vec4(positionEyeCoordinates, 1.0));
 */
void czm_vertexLogDepth(vec4 clipCoords)
{
#ifdef LOG_DEPTH
    v_depthFromNearPlusOne = (clipCoords.w - czm_currentFrustum.x) + 1.0;
    czm_updatePositionDepth(clipCoords);
#endif
}
`});var _L,RL=O(()=>{_L=`vec4 czm_screenToEyeCoordinates(vec4 screenCoordinate)
{
    // Reconstruct NDC coordinates
    float x = 2.0 * screenCoordinate.x - 1.0;
    float y = 2.0 * screenCoordinate.y - 1.0;
    float z = (screenCoordinate.z - czm_viewportTransformation[3][2]) / czm_viewportTransformation[2][2];
    vec4 q = vec4(x, y, z, 1.0);

    // Reverse the perspective division to obtain clip coordinates.
    q /= screenCoordinate.w;

    // Reverse the projection transformation to obtain eye coordinates.
    if (!(czm_inverseProjection == mat4(0.0))) // IE and Edge sometimes do something weird with != between mat4s
    {
        q = czm_inverseProjection * q;
    }
    else
    {
        float top = czm_frustumPlanes.x;
        float bottom = czm_frustumPlanes.y;
        float left = czm_frustumPlanes.z;
        float right = czm_frustumPlanes.w;

        float near = czm_currentFrustum.x;
        float far = czm_currentFrustum.y;

        q.x = (q.x * (right - left) + left + right) * 0.5;
        q.y = (q.y * (top - bottom) + bottom + top) * 0.5;
        q.z = (q.z * (near - far) - near - far) * 0.5;
        q.w = 1.0;
    }

    return q;
}

/**
 * Transforms a position from window to eye coordinates.
 * The transform from window to normalized device coordinates is done using components
 * of (@link czm_viewport} and {@link czm_viewportTransformation} instead of calculating
 * the inverse of <code>czm_viewportTransformation</code>. The transformation from
 * normalized device coordinates to clip coordinates is done using <code>fragmentCoordinate.w</code>,
 * which is expected to be the scalar used in the perspective divide. The transformation
 * from clip to eye coordinates is done using {@link czm_inverseProjection}.
 *
 * @name czm_windowToEyeCoordinates
 * @glslFunction
 *
 * @param {vec4} fragmentCoordinate The position in window coordinates to transform.
 *
 * @returns {vec4} The transformed position in eye coordinates.
 *
 * @see czm_modelToWindowCoordinates
 * @see czm_eyeToWindowCoordinates
 * @see czm_inverseProjection
 * @see czm_viewport
 * @see czm_viewportTransformation
 *
 * @example
 * vec4 positionEC = czm_windowToEyeCoordinates(gl_FragCoord);
 */
vec4 czm_windowToEyeCoordinates(vec4 fragmentCoordinate)
{
    vec2 screenCoordXY = (fragmentCoordinate.xy - czm_viewport.xy) / czm_viewport.zw;
    return czm_screenToEyeCoordinates(vec4(screenCoordXY, fragmentCoordinate.zw));
}

vec4 czm_screenToEyeCoordinates(vec2 screenCoordinateXY, float depthOrLogDepth)
{
    // See reverseLogDepth.glsl. This is separate to re-use the pow.
#if defined(LOG_DEPTH) || defined(LOG_DEPTH_READ_ONLY)
    float near = czm_currentFrustum.x;
    float far = czm_currentFrustum.y;
    float log2Depth = depthOrLogDepth * czm_log2FarDepthFromNearPlusOne;
    float depthFromNear = pow(2.0, log2Depth) - 1.0;
    float depthFromCamera = depthFromNear + near;
    vec4 screenCoord = vec4(screenCoordinateXY, far * (1.0 - near / depthFromCamera) / (far - near), 1.0);
    vec4 eyeCoordinate = czm_screenToEyeCoordinates(screenCoord);
    eyeCoordinate.w = 1.0 / depthFromCamera; // Better precision
    return eyeCoordinate;
#else
    vec4 screenCoord = vec4(screenCoordinateXY, depthOrLogDepth, 1.0);
    vec4 eyeCoordinate = czm_screenToEyeCoordinates(screenCoord);
#endif
    return eyeCoordinate;
}

/**
 * Transforms a position given as window x/y and a depth or a log depth from window to eye coordinates.
 * This function produces more accurate results for window positions with log depth than
 * conventionally unpacking the log depth using czm_reverseLogDepth and using the standard version
 * of czm_windowToEyeCoordinates.
 *
 * @name czm_windowToEyeCoordinates
 * @glslFunction
 *
 * @param {vec2} fragmentCoordinateXY The XY position in window coordinates to transform.
 * @param {float} depthOrLogDepth A depth or log depth for the fragment.
 *
 * @see czm_modelToWindowCoordinates
 * @see czm_eyeToWindowCoordinates
 * @see czm_inverseProjection
 * @see czm_viewport
 * @see czm_viewportTransformation
 *
 * @returns {vec4} The transformed position in eye coordinates.
 */
vec4 czm_windowToEyeCoordinates(vec2 fragmentCoordinateXY, float depthOrLogDepth)
{
    vec2 screenCoordXY = (fragmentCoordinateXY.xy - czm_viewport.xy) / czm_viewport.zw;
    return czm_screenToEyeCoordinates(screenCoordXY, depthOrLogDepth);
}
`});var ZL,IL=O(()=>{ZL=`// emulated noperspective
#if !defined(LOG_DEPTH)
in float v_WindowZ;
#endif

/**
 * Emulates GL_DEPTH_CLAMP. Clamps a fragment to the near and far plane
 * by writing the fragment's depth. See czm_depthClamp for more details.
 *
 * @name czm_writeDepthClamp
 * @glslFunction
 *
 * @example
 * out_FragColor = color;
 * czm_writeDepthClamp();
 *
 * @see czm_depthClamp
 */
void czm_writeDepthClamp()
{
#if (!defined(LOG_DEPTH) && (__VERSION__ == 300 || defined(GL_EXT_frag_depth)))
    gl_FragDepth = clamp(v_WindowZ * gl_FragCoord.w, 0.0, 1.0);
#endif
}
`});var pL,uL=O(()=>{pL=`#ifdef LOG_DEPTH
in float v_depthFromNearPlusOne;

#ifdef POLYGON_OFFSET
uniform vec2 u_polygonOffset;
#endif

#endif

/**
 * Writes the fragment depth to the logarithmic depth buffer.
 * <p>
 * Use this when the vertex shader does not call {@link czm_vertexlogDepth}, for example, when
 * ray-casting geometry using a full screen quad.
 * </p>
 * @name czm_writeLogDepth
 * @glslFunction
 *
 * @param {float} depth The depth coordinate, where 1.0 is on the near plane and
 *                      depth increases in eye-space units from there
 *
 * @example
 * czm_writeLogDepth((czm_projection * v_positionEyeCoordinates).w + 1.0);
 */
void czm_writeLogDepth(float depth)
{
#if (defined(LOG_DEPTH) && (__VERSION__ == 300 || defined(GL_EXT_frag_depth)))
    // Discard the vertex if it's not between the near and far planes.
    // We allow a bit of epsilon on the near plane comparison because a 1.0
    // from the vertex shader (indicating the vertex should be _on_ the near
    // plane) will not necessarily come here as exactly 1.0.
    if (depth <= 0.9999999 || depth > czm_farDepthFromNearPlusOne) {
        discard;
    }

#ifdef POLYGON_OFFSET
    // Polygon offset: m * factor + r * units
    float factor = u_polygonOffset[0];
    float units = u_polygonOffset[1];

#if (__VERSION__ == 300 || defined(GL_OES_standard_derivatives))
    // This factor doesn't work in IE 10
    if (factor != 0.0) {
        // m = sqrt(dZdX^2 + dZdY^2);
        float x = dFdx(depth);
        float y = dFdy(depth);
        float m = sqrt(x * x + y * y);

        // Apply the factor before computing the log depth.
        depth += m * factor;
    }
#endif

#endif

    gl_FragDepth = log2(depth) * czm_oneOverLog2FarDepthFromNearPlusOne;

#ifdef POLYGON_OFFSET
    // Apply the units after the log depth.
    gl_FragDepth += czm_epsilon7 * units;
#endif

#endif
}

/**
 * Writes the fragment depth to the logarithmic depth buffer.
 * <p>
 * Use this when the vertex shader calls {@link czm_vertexlogDepth}.
 * </p>
 *
 * @name czm_writeLogDepth
 * @glslFunction
 */
void czm_writeLogDepth() {
#ifdef LOG_DEPTH
    czm_writeLogDepth(v_depthFromNearPlusOne);
#endif
}
`});var CL,gL=O(()=>{CL=`/**
 * Transforms a value for non-perspective interpolation by multiplying
 * it by w, the value used in the perspective divide. This function is
 * intended to be called in a vertex shader to compute the value of a
 * \`varying\` that should not be subject to perspective interpolation.
 * For example, screen-space texture coordinates. The fragment shader
 * must call {@link czm_readNonPerspective} to retrieve the final
 * non-perspective value.
 *
 * @name czm_writeNonPerspective
 * @glslFunction
 *
 * @param {float|vec2|vec3|vec4} value The value to be interpolated without accounting for perspective.
 * @param {float} w The perspective divide value. Usually this is the computed \`gl_Position.w\`.
 * @returns {float|vec2|vec3|vec4} The transformed value, intended to be stored in a \`varying\` and read in the
 *          fragment shader with {@link czm_readNonPerspective}.
 */
float czm_writeNonPerspective(float value, float w) {
    return value * w;
}

vec2 czm_writeNonPerspective(vec2 value, float w) {
    return value * w;
}

vec3 czm_writeNonPerspective(vec3 value, float w) {
    return value * w;
}

vec4 czm_writeNonPerspective(vec4 value, float w) {
    return value * w;
}
`});var lI,TL=O(()=>{RM();IM();uM();gM();NM();FM();SM();VM();BM();DM();UM();kM();yM();xM();JM();HM();zM();XM();$M();eU();nU();oU();aU();hU();lU();mU();EU();RU();IU();uU();gU();NU();FU();SU();VU();BU();DU();UU();kU();yU();xU();JU();HU();zU();XU();$U();eQ();nQ();oQ();aQ();hQ();lQ();mQ();EQ();RQ();IQ();uQ();gQ();NQ();FQ();SQ();VQ();BQ();DQ();UQ();kQ();yQ();xQ();JQ();HQ();zQ();XQ();$Q();e1();n1();o1();a1();h1();l1();m1();E1();R1();I1();u1();g1();N1();F1();S1();V1();B1();D1();U1();k1();y1();x1();J1();H1();z1();X1();$1();ek();nk();ok();ak();hk();lk();mk();Ek();Rk();Ik();uk();gk();Nk();Fk();Sk();Vk();Bk();Dk();Uk();kk();yk();xk();Jk();Hk();zk();Xk();$k();eL();nL();oL();aL();hL();lL();mL();EL();RL();IL();uL();gL();lI={czm_degreesPerRadian:_M,czm_depthRange:ZM,czm_epsilon1:pM,czm_epsilon2:CM,czm_epsilon3:TM,czm_epsilon4:bM,czm_epsilon5:YM,czm_epsilon6:OM,czm_epsilon7:GM,czm_infinity:WM,czm_oneOverPi:MM,czm_oneOverTwoPi:QM,czm_passCesium3DTile:LM,czm_passCesium3DTileClassification:wM,czm_passCesium3DTileClassificationIgnoreShow:PM,czm_passClassification:jM,czm_passCompute:vM,czm_passEnvironment:KM,czm_passGlobe:qM,czm_passOpaque:tU,czm_passOverlay:iU,czm_passTerrainClassification:sU,czm_passTranslucent:rU,czm_passVoxels:AU,czm_pi:cU,czm_piOverFour:dU,czm_piOverSix:fU,czm_piOverThree:_U,czm_piOverTwo:ZU,czm_radiansPerDegree:pU,czm_sceneMode2D:CU,czm_sceneMode3D:TU,czm_sceneModeColumbusView:bU,czm_sceneModeMorphing:YU,czm_solarRadius:OU,czm_threePiOver2:GU,czm_twoPi:WU,czm_webMercatorMaxLatitude:MU,czm_depthRangeStruct:QU,czm_material:LU,czm_materialInput:wU,czm_modelMaterial:PU,czm_modelVertexOutput:jU,czm_pbrParameters:vU,czm_ray:KU,czm_raySegment:qU,czm_shadowParameters:tQ,czm_HSBToRGB:iQ,czm_HSLToRGB:sQ,czm_RGBToHSB:rQ,czm_RGBToHSL:AQ,czm_RGBToXYZ:cQ,czm_XYZToRGB:dQ,czm_acesTonemapping:fQ,czm_alphaWeight:_Q,czm_antialias:ZQ,czm_applyHSBShift:pQ,czm_approximateSphericalCoordinates:CQ,czm_approximateTanh:TQ,czm_backFacing:bQ,czm_branchFreeTernary:YQ,czm_cascadeColor:OQ,czm_cascadeDistance:GQ,czm_cascadeMatrix:WQ,czm_cascadeWeights:MQ,czm_clipPolygons:QQ,czm_columbusViewMorph:LQ,czm_computeAtmosphereColor:wQ,czm_computeGroundAtmosphereScattering:PQ,czm_computePosition:jQ,czm_computeScattering:vQ,czm_cosineAndSine:KQ,czm_decompressTextureCoordinates:qQ,czm_defaultPbrMaterial:t1,czm_depthClamp:i1,czm_eastNorthUpToEyeCoordinates:s1,czm_ellipsoidContainsPoint:r1,czm_ellipsoidWgs84TextureCoordinates:A1,czm_equalsEpsilon:c1,czm_eyeOffset:d1,czm_eyeToWindowCoordinates:f1,czm_fastApproximateAtan:_1,czm_fog:Z1,czm_gammaCorrect:p1,czm_geodeticSurfaceNormal:C1,czm_getDefaultMaterial:T1,czm_getDynamicAtmosphereLightDirection:b1,czm_getLambertDiffuse:Y1,czm_getSpecular:O1,czm_getWaterNoise:G1,czm_hue:W1,czm_inverseGamma:M1,czm_isEmpty:Q1,czm_isFull:L1,czm_latitudeToWebMercatorFraction:w1,czm_lineDistance:P1,czm_linearToSrgb:j1,czm_luminance:v1,czm_metersPerPixel:K1,czm_modelToWindowCoordinates:q1,czm_multiplyWithColorBalance:tk,czm_nearFarScalar:ik,czm_octDecode:sk,czm_packDepth:rk,czm_pbrLighting:Ak,czm_pbrMetallicRoughnessMaterial:ck,czm_pbrSpecularGlossinessMaterial:dk,czm_phong:fk,czm_planeDistance:_k,czm_pointAlongRay:Zk,czm_rayEllipsoidIntersectionInterval:pk,czm_raySphereIntersectionInterval:Ck,czm_readDepth:Tk,czm_readNonPerspective:bk,czm_reverseLogDepth:Yk,czm_round:Ok,czm_sampleOctahedralProjection:Gk,czm_saturation:Wk,czm_shadowDepthCompare:Mk,czm_shadowVisibility:Qk,czm_signNotZero:Lk,czm_sphericalHarmonics:wk,czm_srgbToLinear:Pk,czm_tangentToEyeSpaceMatrix:jk,czm_textureCube:vk,czm_transformPlane:Kk,czm_translateRelativeToEye:qk,czm_translucentPhong:tL,czm_transpose:iL,czm_unpackClippingExtents:sL,czm_unpackDepth:rL,czm_unpackFloat:AL,czm_unpackUint:cL,czm_valueTransform:dL,czm_vertexLogDepth:fL,czm_windowToEyeCoordinates:_L,czm_writeDepthClamp:ZL,czm_writeLogDepth:pL,czm_writeNonPerspective:CL}});function htt(t,e){let i=t;return i=i.replaceAll("version 300 es",""),i=i.replaceAll(/(texture\()/g,"texture2D("),e?(i=i.replaceAll(/\n\s*(in)\s+(vec\d|mat\d|float)/g,`
varying $2`),/out_FragData_(\d+)/.test(i)&&(i=`#extension GL_EXT_draw_buffers : enable
${i}`,i=i.replaceAll(/layout\s+\(location\s*=\s*\d+\)\s*out\s+vec4\s+out_FragData_\d+;/g,""),i=i.replaceAll(/out_FragData_(\d+)/g,"gl_FragData[$1]")),i=i.replaceAll(/layout\s+\(location\s*=\s*0\)\s*out\s+vec4\s+out_FragColor;/g,""),i=i.replaceAll(/out_FragColor/g,"gl_FragColor"),i=i.replaceAll(/out_FragColor\[(\d+)\]/g,"gl_FragColor[$1]"),/gl_FragDepth/.test(i)&&(i=`#extension GL_EXT_frag_depth : enable
${i}`,i=i.replaceAll(/gl_FragDepth/g,"gl_FragDepthEXT")),i=`#ifdef GL_OES_standard_derivatives
#extension GL_OES_standard_derivatives : enable
#endif
${i}`):(i=i.replaceAll(/(in)\s+(vec\d|mat\d|float)/g,"attribute $2"),i=i.replaceAll(/(out)\s+(vec\d|mat\d|float)\s+([\w]+);/g,"varying $2 $3;")),i=`#version 100
${i}`,i}var NL,bL=O(()=>{NL=htt});function FL(t){return t=t.replace(/\/\/.*/g,""),t.replace(/\/\*\*[\s\S]*?\*\//gm,function(e){let i=e.match(/\n/gm).length,n="";for(let s=0;s<i;++s)n+=`
`;return n})}function YL(t,e,i){let n;for(let s=0;s<i.length;++s)i[s].name===t&&(n=i[s]);return m(n)||(e=FL(e),n={name:t,glslSource:e,dependsOn:[],requiredBy:[],evaluated:!1},i.push(n)),n}function SL(t,e){if(t.evaluated)return;t.evaluated=!0;let i=t.glslSource.match(/\bczm_[a-zA-Z0-9_]*/g);m(i)&&i!==null&&(i=i.filter(function(n,s){return i.indexOf(n)===s}),i.forEach(function(n){if(n!==t.name&&Us._czmBuiltinsAndUniforms.hasOwnProperty(n)){let s=YL(n,Us._czmBuiltinsAndUniforms[n],e);t.dependsOn.push(s),s.requiredBy.push(t),SL(s,e)}}))}function ctt(t){let e=[],i=[];for(;t.length>0;){let s=t.pop();i.push(s),s.requiredBy.length===0&&e.push(s)}for(;e.length>0;){let s=e.shift();t.push(s);for(let o=0;o<s.dependsOn.length;++o){let r=s.dependsOn[o],a=r.requiredBy.indexOf(s);r.requiredBy.splice(a,1),r.requiredBy.length===0&&e.push(r)}}let n=[];for(let s=0;s<i.length;++s)i[s].requiredBy.length!==0&&n.push(i[s]);if(n.length!==0){let s=`A circular dependency was found in the following built-in functions/structs/constants: 
`;for(let o=0;o<n.length;++o)s=`${s+n[o].name}
`;throw new Y(s)}}function ltt(t){let e=[],i=YL("main",t,e);SL(i,e),ctt(e);let n="";for(let s=e.length-1;s>=0;--s)n=`${n+e[s].glslSource}
`;return n.replace(i.glslSource,"")}function OL(t,e,i){let n,s,o="",r=t.sources;if(m(r))for(n=0,s=r.length;n<s;++n)o+=`
#line 0
${r[n]}`;o=FL(o);let a;o=o.replace(/#version\s+(.*?)\n/gm,function(I,C){if(m(a)&&a!==C)throw new Y(`inconsistent versions found: ${a} and ${C}`);return a=C,`
`});let h=[];o=o.replace(/#extension.*\n/gm,function(I){return h.push(I),`
`}),o=o.replace(/precision\s(lowp|mediump|highp)\s(float|int);/,"");let A=t.pickColorQualifier;m(A)&&(o=Us.createPickFragmentShaderSource(o,A));let d="",f=h.length;for(n=0;n<f;n++)d+=h[n];e&&(d+=`#ifdef GL_FRAGMENT_PRECISION_HIGH
    precision highp float;
    precision highp int;
#else
    precision mediump float;
    precision mediump int;
    #define highp mediump
#endif

`);let E=t.defines;if(m(E))for(n=0,s=E.length;n<s;++n){let I=E[n];I.length!==0&&(d+=`#define ${I}
`)}i.textureFloatLinear&&(d+=`#define OES_texture_float_linear

`),i.floatingPointTexture&&(d+=`#define OES_texture_float

`);let _="";t.includeBuiltIns&&(_=ltt(o)),d+=`
#line 0
`;let R=_+o;return i.webgl2&&e&&!/layout\s*\(location\s*=\s*0\)\s*out\s+vec4\s+out_FragColor;/g.test(R)&&!/czm_out_FragColor/g.test(R)&&/out_FragColor/g.test(R)&&(d+=`layout(location = 0) out vec4 out_FragColor;

`),d+=_,d+=o,i.webgl2?d=`#version 300 es
${d}`:d=NL(d,e),d}function Us(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.pickColorQualifier;if(m(e)&&e!=="uniform"&&e!=="in")throw new Y("options.pickColorQualifier must be 'uniform' or 'in'.");this.defines=m(t.defines)?t.defines.slice(0):[],this.sources=m(t.sources)?t.sources.slice(0):[],this.pickColorQualifier=e,this.includeBuiltIns=Z(t.includeBuiltIns,!0)}function dtt(t,e){let i=t.defines,n=i.length;for(let s=0;s<n;++s)if(i[s]===e)return!0;return!1}function VL(t,e){let i=t.sources,n=i.length;for(let s=0;s<n;++s)if(i[s].indexOf(e)!==-1)return!0;return!1}function GL(t,e){let i=e.length;for(let n=0;n<i;++n){let s=e[n];if(VL(t,s))return s}}var mtt,ftt,Mi,Fl=O(()=>{bt();mt();Vt();TL();FT();bL();Us.prototype.clone=function(){return new Us({sources:this.sources,defines:this.defines,pickColorQualifier:this.pickColorQualifier,includeBuiltIns:this.includeBuiltIns})};Us.replaceMain=function(t,e){return e=`void ${e}()`,t.replace(/void\s+main\s*\(\s*(?:void)?\s*\)/g,e)};Us.prototype.getCacheKey=function(){let e=this.defines.slice().sort().join(","),i=this.pickColorQualifier,n=this.includeBuiltIns,s=this.sources.join(`
`);return`${e}:${i}:${n}:${s}`};Us.prototype.createCombinedVertexShader=function(t){return OL(this,!1,t)};Us.prototype.createCombinedFragmentShader=function(t){return OL(this,!0,t)};Us._czmBuiltinsAndUniforms={};for(let t in lI)lI.hasOwnProperty(t)&&(Us._czmBuiltinsAndUniforms[t]=lI[t]);for(let t in Um)if(Um.hasOwnProperty(t)){let e=Um[t];typeof e.getDeclaration=="function"&&(Us._czmBuiltinsAndUniforms[t]=e.getDeclaration(t))}Us.createPickVertexShaderSource=function(t){return`${Us.replaceMain(t,"czm_old_main")}
in vec4 pickColor; 
out vec4 czm_pickColor; 
void main() 
{ 
    czm_old_main(); 
    czm_pickColor = pickColor; 
}`};Us.createPickFragmentShaderSource=function(t,e){let i=Us.replaceMain(t,"czm_old_main"),n=`${e} vec4 czm_pickColor; 
void main() 
{ 
    czm_old_main(); 
    if (out_FragColor.a == 0.0) { 
       discard; 
    } 
    out_FragColor = czm_pickColor; 
}`;return`${i}
${n}`};mtt=["v_normalEC","v_normal"];Us.findNormalVarying=function(t){return VL(t,"#ifdef HAS_NORMALS")?dtt(t,"HAS_NORMALS")?"v_normalEC":void 0:GL(t,mtt)};ftt=["v_positionEC"];Us.findPositionVarying=function(t){return GL(t,ftt)};Mi=Us});var Ett,Ah,dI=O(()=>{Ett={NONE:0,TRIANGLES:1,LINES:2,POLYLINES:3},Ah=Object.freeze(Ett)});function OT(t){t=Z(t,Z.EMPTY_OBJECT),p.typeOf.object("options.attributes",t.attributes),this.attributes=t.attributes,this.indices=t.indices,this.primitiveType=Z(t.primitiveType,ne.TRIANGLES),this.boundingSphere=t.boundingSphere,this.geometryType=Z(t.geometryType,Ah.NONE),this.boundingSphereCV=t.boundingSphereCV,this.offsetAttribute=t.offsetAttribute}var _tt,Rtt,BL,Ztt,Itt,ptt,utt,Ctt,gtt,Ttt,se,yi=O(()=>{Xe();Ht();ri();ae();bt();mt();dI();dc();dn();Fi();Xi();$s();pn();fr();OT.computeNumberOfVertices=function(t){p.typeOf.object("geometry",t);let e=-1;for(let i in t.attributes)if(t.attributes.hasOwnProperty(i)&&m(t.attributes[i])&&m(t.attributes[i].values)){let n=t.attributes[i],s=n.values.length/n.componentsPerAttribute;e=s}return e};_tt=new ut,Rtt=new l,BL=new at,Ztt=[new ut,new ut,new ut],Itt=[new nt,new nt,new nt],ptt=[new nt,new nt,new nt],utt=new l,Ctt=new Ae,gtt=new at,Ttt=new Hn;OT._textureCoordinateRotationPoints=function(t,e,i,n){let s,o=Xt.center(n,_tt),r=ut.toCartesian(o,i,Rtt),a=In.eastNorthUpToFixedFrame(r,i,BL),h=at.inverse(a,BL),A=Itt,d=Ztt;d[0].longitude=n.west,d[0].latitude=n.south,d[1].longitude=n.west,d[1].latitude=n.north,d[2].longitude=n.east,d[2].latitude=n.south;let f=utt;for(s=0;s<3;s++)ut.toCartesian(d[s],i,f),f=at.multiplyByPointAsVector(h,f,f),A[s].x=f.x,A[s].y=f.y;let E=Ae.fromAxisAngle(l.UNIT_Z,-e,Ctt),_=lt.fromQuaternion(E,gtt),R=t.length,I=Number.POSITIVE_INFINITY,C=Number.POSITIVE_INFINITY,N=Number.NEGATIVE_INFINITY,T=Number.NEGATIVE_INFINITY;for(s=0;s<R;s++)f=at.multiplyByPointAsVector(h,t[s],f),f=lt.multiplyByVector(_,f,f),I=Math.min(I,f.x),C=Math.min(C,f.y),N=Math.max(N,f.x),T=Math.max(T,f.y);let F=Hn.fromRotation(e,Ttt),b=ptt;b[0].x=I,b[0].y=C,b[1].x=I,b[1].y=T,b[2].x=N,b[2].y=C;let G=A[0],M=A[2].x-G.x,Q=A[1].y-G.y;for(s=0;s<3;s++){let g=b[s];Hn.multiplyByVector(F,g,g),g.x=(g.x-G.x)/M,g.y=(g.y-G.y)/Q}let U=b[0],k=b[1],y=b[2],c=new Array(6);return nt.pack(U,c),nt.pack(k,c,2),nt.pack(y,c,4),c};se=OT});function Ntt(t,e,i,n){let s=m(e.vertexBuffer),o=m(e.value),r=e.value?e.value.length:e.componentsPerAttribute;if(!s&&!o)throw new Y("attribute must have a vertexBuffer or a value.");if(s&&o)throw new Y("attribute cannot have both a vertexBuffer and a value.  It must have either a vertexBuffer property defining per-vertex data or a value property defining data for all vertices.");if(r!==1&&r!==2&&r!==3&&r!==4)throw o?new Y("attribute.value.length must be in the range [1, 4]."):new Y("attribute.componentsPerAttribute must be in the range [1, 4].");if(m(e.componentDatatype)&&!At.validate(e.componentDatatype))throw new Y("attribute must have a valid componentDatatype or not specify it.");if(m(e.strideInBytes)&&e.strideInBytes>255)throw new Y("attribute must have a strideInBytes less than or equal to 255 or not specify it.");if(m(e.instanceDivisor)&&e.instanceDivisor>0&&!n.instancedArrays)throw new Y("instanced arrays is not supported");if(m(e.instanceDivisor)&&e.instanceDivisor<0)throw new Y("attribute must have an instanceDivisor greater than or equal to zero");if(m(e.instanceDivisor)&&o)throw new Y("attribute cannot have have an instanceDivisor if it is not backed by a buffer");if(m(e.instanceDivisor)&&e.instanceDivisor>0&&e.index===0)throw new Y("attribute zero cannot have an instanceDivisor greater than 0");let a={index:Z(e.index,i),enabled:Z(e.enabled,!0),vertexBuffer:e.vertexBuffer,value:o?e.value.slice(0):void 0,componentsPerAttribute:r,componentDatatype:Z(e.componentDatatype,At.FLOAT),normalize:Z(e.normalize,!1),offsetInBytes:Z(e.offsetInBytes,0),strideInBytes:Z(e.strideInBytes,0),instanceDivisor:Z(e.instanceDivisor,0)};if(s)a.vertexAttrib=function(h){let A=this.index;h.bindBuffer(h.ARRAY_BUFFER,this.vertexBuffer._getBuffer()),h.vertexAttribPointer(A,this.componentsPerAttribute,this.componentDatatype,this.normalize,this.strideInBytes,this.offsetInBytes),h.enableVertexAttribArray(A),this.instanceDivisor>0&&(n.glVertexAttribDivisor(A,this.instanceDivisor),n._vertexAttribDivisors[A]=this.instanceDivisor,n._previousDrawInstanced=!0)},a.disableVertexAttribArray=function(h){h.disableVertexAttribArray(this.index),this.instanceDivisor>0&&n.glVertexAttribDivisor(i,0)};else{switch(a.componentsPerAttribute){case 1:a.vertexAttrib=function(h){h.vertexAttrib1fv(this.index,this.value)};break;case 2:a.vertexAttrib=function(h){h.vertexAttrib2fv(this.index,this.value)};break;case 3:a.vertexAttrib=function(h){h.vertexAttrib3fv(this.index,this.value)};break;case 4:a.vertexAttrib=function(h){h.vertexAttrib4fv(this.index,this.value)};break}a.disableVertexAttribArray=function(h){}}t.push(a)}function DL(t,e,i){for(let n=0;n<e.length;++n){let s=e[n];s.enabled&&s.vertexAttrib(t)}m(i)&&t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,i._getBuffer())}function hh(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context),p.defined("options.attributes",t.attributes);let e=t.context,i=e._gl,n=t.attributes,s=t.indexBuffer,o,r=[],a=1,h=!1,A=!1,d=n.length;for(o=0;o<d;++o)Ntt(r,n[o],o,e);for(d=r.length,o=0;o<d;++o){let _=r[o];if(m(_.vertexBuffer)&&_.instanceDivisor===0){let R=_.strideInBytes||_.componentsPerAttribute*At.getSizeInBytes(_.componentDatatype);a=_.vertexBuffer.sizeInBytes/R;break}}for(o=0;o<d;++o)r[o].instanceDivisor>0&&(h=!0),m(r[o].value)&&(A=!0);let f={};for(o=0;o<d;++o){let _=r[o].index;if(f[_])throw new Y(`Index ${_} is used by more than one attribute.`);f[_]=!0}let E;e.vertexArrayObject&&(E=e.glCreateVertexArray(),e.glBindVertexArray(E),DL(i,r,s),e.glBindVertexArray(null)),this._numberOfVertices=a,this._hasInstancedAttributes=h,this._hasConstantAttributes=A,this._context=e,this._gl=i,this._vao=E,this._attributes=r,this._indexBuffer=s}function WL(t){return t.values.length/t.componentsPerAttribute}function btt(t){return At.getSizeInBytes(t.componentDatatype)*t.componentsPerAttribute}function Ftt(t){let e,i,n,s=[];for(i in t)t.hasOwnProperty(i)&&m(t[i])&&m(t[i].values)&&(s.push(i),t[i].componentDatatype===At.DOUBLE&&(t[i].componentDatatype=At.FLOAT,t[i].values=At.createTypedArray(At.FLOAT,t[i].values)));let o,r=s.length;if(r>0)for(o=WL(t[s[0]]),e=1;e<r;++e){let A=WL(t[s[e]]);if(A!==o)throw new ke(`Each attribute list must have the same number of vertices.  Attribute ${s[e]} has a different number of vertices (${A.toString()}) than attribute ${s[0]} (${o.toString()}).`)}s.sort(function(A,d){return At.getSizeInBytes(t[d].componentDatatype)-At.getSizeInBytes(t[A].componentDatatype)});let a=0,h={};for(e=0;e<r;++e)i=s[e],n=t[i],h[i]=a,a+=btt(n);if(a>0){let A=At.getSizeInBytes(t[s[0]].componentDatatype),d=a%A;d!==0&&(a+=A-d);let f=o*a,E=new ArrayBuffer(f),_={};for(e=0;e<r;++e){i=s[e];let R=At.getSizeInBytes(t[i].componentDatatype);_[i]={pointer:At.createTypedArray(t[i].componentDatatype,E),index:h[i]/R,strideInComponentType:a/R}}for(e=0;e<o;++e)for(let R=0;R<r;++R){i=s[R],n=t[i];let I=n.values,C=_[i],N=C.pointer,T=n.componentsPerAttribute;for(let F=0;F<T;++F)N[C.index+F]=I[e*T+F];C.index+=C.strideInComponentType}return{buffer:E,offsetsInBytes:h,vertexSizeInBytes:a}}}function Ytt(t){let e=t._context,i=t._hasInstancedAttributes;if(!i&&!e._previousDrawInstanced)return;e._previousDrawInstanced=i;let n=e._vertexAttribDivisors,s=t._attributes,o=en.maximumVertexAttributes,r;if(i){let a=s.length;for(r=0;r<a;++r){let h=s[r];if(h.enabled){let A=h.instanceDivisor,d=h.index;A!==n[d]&&(e.glVertexAttribDivisor(d,A),n[d]=A)}}}else for(r=0;r<o;++r)n[r]>0&&(e.glVertexAttribDivisor(r,0),n[r]=0)}function Stt(t,e){let i=t._attributes,n=i.length;for(let s=0;s<n;++s){let o=i[s];o.enabled&&m(o.value)&&o.vertexAttrib(e)}}var mI,VT=O(()=>{ae();oi();bt();mt();Ws();Vt();yi();Di();_e();Ps();aI();Nl();ga();hh.fromGeometry=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context);let e=t.context,i=Z(t.geometry,Z.EMPTY_OBJECT),n=Z(t.bufferUsage,ai.DYNAMIC_DRAW),s=Z(t.attributeLocations,Z.EMPTY_OBJECT),o=Z(t.interleave,!1),r=t.vertexArrayAttributes,a,h,A,d=m(r)?r:[],f=i.attributes;if(o){let R=Ftt(f);if(m(R)){A=Ca.createVertexBuffer({context:e,typedArray:R.buffer,usage:n});let I=R.offsetsInBytes,C=R.vertexSizeInBytes;for(a in f)f.hasOwnProperty(a)&&m(f[a])&&(h=f[a],m(h.values)?d.push({index:s[a],vertexBuffer:A,componentDatatype:h.componentDatatype,componentsPerAttribute:h.componentsPerAttribute,normalize:h.normalize,offsetInBytes:I[a],strideInBytes:C}):d.push({index:s[a],value:h.value,componentDatatype:h.componentDatatype,normalize:h.normalize}))}}else for(a in f)if(f.hasOwnProperty(a)&&m(f[a])){h=f[a];let R=h.componentDatatype;R===At.DOUBLE&&(R=At.FLOAT),A=void 0,m(h.values)&&(A=Ca.createVertexBuffer({context:e,typedArray:At.createTypedArray(R,h.values),usage:n})),d.push({index:s[a],vertexBuffer:A,value:h.value,componentDatatype:R,componentsPerAttribute:h.componentsPerAttribute,normalize:h.normalize})}let E,_=i.indices;return m(_)&&(se.computeNumberOfVertices(i)>=L.SIXTY_FOUR_KILOBYTES&&e.elementIndexUint?E=Ca.createIndexBuffer({context:e,typedArray:new Uint32Array(_),usage:n,indexDatatype:te.UNSIGNED_INT}):E=Ca.createIndexBuffer({context:e,typedArray:new Uint16Array(_),usage:n,indexDatatype:te.UNSIGNED_SHORT})),new hh({context:e,attributes:d,indexBuffer:E})};Object.defineProperties(hh.prototype,{numberOfAttributes:{get:function(){return this._attributes.length}},numberOfVertices:{get:function(){return this._numberOfVertices}},indexBuffer:{get:function(){return this._indexBuffer}}});hh.prototype.getAttribute=function(t){return p.defined("index",t),this._attributes[t]};hh.prototype._bind=function(){m(this._vao)?(this._context.glBindVertexArray(this._vao),this._context.instancedArrays&&Ytt(this),this._hasConstantAttributes&&Stt(this,this._gl)):DL(this._gl,this._attributes,this._indexBuffer)};hh.prototype._unBind=function(){if(m(this._vao))this._context.glBindVertexArray(null);else{let t=this._attributes,e=this._gl;for(let i=0;i<t.length;++i){let n=t[i];n.enabled&&n.disableVertexAttribArray(e)}this._indexBuffer&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null)}};hh.prototype.isDestroyed=function(){return!1};hh.prototype.destroy=function(){let t=this._attributes;for(let i=0;i<t.length;++i){let n=t[i].vertexBuffer;m(n)&&!n.isDestroyed()&&n.vertexArrayDestroyable&&n.destroy()}let e=this._indexBuffer;return m(e)&&!e.isDestroyed()&&e.vertexArrayDestroyable&&e.destroy(),m(this._vao)&&this._context.glDeleteVertexArray(this._vao),li(this)};mI=hh});function Qs(t,e,i,n){if(p.defined("context",t),!e||e.length===0)throw new Y("At least one attribute is required.");let s=Qs._verifyAttributes(e);i=Z(i,0);let o=[],r={},a,h,A=s.length;for(let f=0;f<A;++f){let E=s[f];if(E.vertexBuffer){o.push(E);continue}h=E.usage,a=r[h],m(a)||(a=r[h]=[]),a.push(E)}function d(f,E){return At.getSizeInBytes(E.componentDatatype)-At.getSizeInBytes(f.componentDatatype)}this._allBuffers=[];for(h in r)if(r.hasOwnProperty(h)){a=r[h],a.sort(d);let f=Qs._vertexSizeInBytes(a),E=a[0].usage,_={vertexSizeInBytes:f,vertexBuffer:void 0,usage:E,needsCommit:!1,arrayBuffer:void 0,arrayViews:Qs._createArrayViews(a,f)};this._allBuffers.push(_)}this._size=0,this._instanced=Z(n,!1),this._precreated=o,this._context=t,this.writers=void 0,this.va=void 0,this.resize(i)}function Vtt(t,e){if(e.needsCommit&&e.vertexSizeInBytes>0){e.needsCommit=!1;let i=e.vertexBuffer,n=t._size*e.vertexSizeInBytes,s=m(i);if(!s||i.sizeInBytes<n)return s&&i.destroy(),e.vertexBuffer=Ca.createVertexBuffer({context:t._context,typedArray:e.arrayBuffer,usage:e.usage}),e.vertexBuffer.vertexArrayDestroyable=!1,!0;e.vertexBuffer.copyFromArrayView(e.arrayBuffer)}return!1}function Gtt(t,e,i){if(t.needsCommit&&t.vertexSizeInBytes>0){let n=t.vertexSizeInBytes*e,s=t.vertexSizeInBytes*i;t.vertexBuffer.copyFromArrayView(new Uint8Array(t.arrayBuffer,n,s),n)}}function GT(t){let e=t.va;if(!m(e))return;let i=e.length;for(let n=0;n<i;++n)e[n].va.destroy();t.va=void 0}var Ott,fI,BT=O(()=>{ae();oi();bt();mt();Ws();Vt();_e();aI();Nl();VT();Qs._verifyAttributes=function(t){let e=[];for(let n=0;n<t.length;++n){let s=t[n],o={index:Z(s.index,n),enabled:Z(s.enabled,!0),componentsPerAttribute:s.componentsPerAttribute,componentDatatype:Z(s.componentDatatype,At.FLOAT),normalize:Z(s.normalize,!1),vertexBuffer:s.vertexBuffer,usage:Z(s.usage,ai.STATIC_DRAW)};if(e.push(o),o.componentsPerAttribute!==1&&o.componentsPerAttribute!==2&&o.componentsPerAttribute!==3&&o.componentsPerAttribute!==4)throw new Y("attribute.componentsPerAttribute must be in the range [1, 4].");let r=o.componentDatatype;if(!At.validate(r))throw new Y("Attribute must have a valid componentDatatype or not specify it.");if(!ai.validate(o.usage))throw new Y("Attribute must have a valid usage or not specify it.")}let i=new Array(e.length);for(let n=0;n<e.length;++n){let o=e[n].index;if(i[o])throw new Y(`Index ${o} is used by more than one attribute.`);i[o]=!0}return e};Qs._vertexSizeInBytes=function(t){let e=0,i=t.length;for(let r=0;r<i;++r){let a=t[r];e+=a.componentsPerAttribute*At.getSizeInBytes(a.componentDatatype)}let n=i>0?At.getSizeInBytes(t[0].componentDatatype):0,s=n>0?e%n:0,o=s===0?0:n-s;return e+=o,e};Qs._createArrayViews=function(t,e){let i=[],n=0,s=t.length;for(let o=0;o<s;++o){let r=t[o],a=r.componentDatatype;i.push({index:r.index,enabled:r.enabled,componentsPerAttribute:r.componentsPerAttribute,componentDatatype:a,normalize:r.normalize,offsetInBytes:n,vertexSizeInComponentType:e/At.getSizeInBytes(a),view:void 0}),n+=r.componentsPerAttribute*At.getSizeInBytes(a)}return i};Qs.prototype.resize=function(t){this._size=t;let e=this._allBuffers;this.writers=[];for(let i=0,n=e.length;i<n;++i){let s=e[i];Qs._resize(s,this._size),Qs._appendWriters(this.writers,s)}GT(this)};Qs._resize=function(t,e){if(t.vertexSizeInBytes>0){let i=new ArrayBuffer(e*t.vertexSizeInBytes);if(m(t.arrayBuffer)){let o=new Uint8Array(i),r=new Uint8Array(t.arrayBuffer),a=r.length;for(let h=0;h<a;++h)o[h]=r[h]}let n=t.arrayViews,s=n.length;for(let o=0;o<s;++o){let r=n[o];r.view=At.createArrayBufferView(r.componentDatatype,i,r.offsetInBytes)}t.arrayBuffer=i}};Ott=[function(t,e,i){return function(n,s){e[n*i]=s,t.needsCommit=!0}},function(t,e,i){return function(n,s,o){let r=n*i;e[r]=s,e[r+1]=o,t.needsCommit=!0}},function(t,e,i){return function(n,s,o,r){let a=n*i;e[a]=s,e[a+1]=o,e[a+2]=r,t.needsCommit=!0}},function(t,e,i){return function(n,s,o,r,a){let h=n*i;e[h]=s,e[h+1]=o,e[h+2]=r,e[h+3]=a,t.needsCommit=!0}}];Qs._appendWriters=function(t,e){let i=e.arrayViews,n=i.length;for(let s=0;s<n;++s){let o=i[s];t[o.index]=Ott[o.componentsPerAttribute-1](e,o.view,o.vertexSizeInComponentType)}};Qs.prototype.commit=function(t){let e=!1,i=this._allBuffers,n,s,o;for(s=0,o=i.length;s<o;++s)n=i[s],e=Vtt(this,n)||e;if(e||!m(this.va)){GT(this);let r=this.va=[],a=L.SIXTY_FOUR_KILOBYTES-4,h=m(t)&&!this._instanced?Math.ceil(this._size/a):1;for(let A=0;A<h;++A){let d=[];for(s=0,o=i.length;s<o;++s){n=i[s];let f=A*(n.vertexSizeInBytes*a);Qs._appendAttributes(d,n,f,this._instanced)}d=d.concat(this._precreated),r.push({va:new mI({context:this._context,attributes:d,indexBuffer:t}),indicesCount:1.5*(A!==h-1?a:this._size%a)})}}};Qs._appendAttributes=function(t,e,i,n){let s=e.arrayViews,o=s.length;for(let r=0;r<o;++r){let a=s[r];t.push({index:a.index,enabled:a.enabled,componentsPerAttribute:a.componentsPerAttribute,componentDatatype:a.componentDatatype,normalize:a.normalize,vertexBuffer:e.vertexBuffer,offsetInBytes:i+a.offsetInBytes,strideInBytes:e.vertexSizeInBytes,instanceDivisor:n?1:0})}};Qs.prototype.subCommit=function(t,e){if(t<0||t>=this._size)throw new Y("offsetInVertices must be greater than or equal to zero and less than the vertex array size.");if(t+e>this._size)throw new Y("offsetInVertices + lengthInVertices cannot exceed the vertex array size.");let i=this._allBuffers;for(let n=0,s=i.length;n<s;++n)Gtt(i[n],t,e)};Qs.prototype.endSubCommits=function(){let t=this._allBuffers;for(let e=0,i=t.length;e<i;++e)t[e].needsCommit=!1};Qs.prototype.isDestroyed=function(){return!1};Qs.prototype.destroy=function(){let t=this._allBuffers;for(let e=0,i=t.length;e<i;++e){let n=t[e];n.vertexBuffer=n.vertexBuffer&&n.vertexBuffer.destroy()}return GT(this),li(this)};fI=Qs});var ML,UL=O(()=>{ML=`uniform sampler2D u_atlas;

#ifdef VECTOR_TILE
uniform vec4 u_highlightColor;
#endif

in vec2 v_textureCoordinates;
in vec4 v_pickColor;
in vec4 v_color;

#ifdef SDF
in vec4 v_outlineColor;
in float v_outlineWidth;
#endif

#ifdef FRAGMENT_DEPTH_CHECK
in vec4 v_textureCoordinateBounds;                  // the min and max x and y values for the texture coordinates
in vec4 v_originTextureCoordinateAndTranslate;      // texture coordinate at the origin, billboard translate (used for label glyphs)
in vec4 v_compressed;                               // x: eyeDepth, y: applyTranslate & enableDepthCheck, z: dimensions, w: imageSize
in mat2 v_rotationMatrix;

const float SHIFT_LEFT12 = 4096.0;
const float SHIFT_LEFT1 = 2.0;

const float SHIFT_RIGHT12 = 1.0 / 4096.0;
const float SHIFT_RIGHT1 = 1.0 / 2.0;

float getGlobeDepth(vec2 adjustedST, vec2 depthLookupST, bool applyTranslate, vec2 dimensions, vec2 imageSize)
{
    vec2 lookupVector = imageSize * (depthLookupST - adjustedST);
    lookupVector = v_rotationMatrix * lookupVector;
    vec2 labelOffset = (dimensions - imageSize) * (depthLookupST - vec2(0.0, v_originTextureCoordinateAndTranslate.y)); // aligns label glyph with bounding rectangle.  Will be zero for billboards because dimensions and imageSize will be equal

    vec2 translation = v_originTextureCoordinateAndTranslate.zw;

    if (applyTranslate)
    {
        // this is only needed for labels where the horizontal origin is not LEFT
        // it moves the label back to where the "origin" should be since all label glyphs are set to HorizontalOrigin.LEFT
        translation += (dimensions * v_originTextureCoordinateAndTranslate.xy * vec2(1.0, 0.0));
    }

    vec2 st = ((lookupVector - translation + labelOffset) + gl_FragCoord.xy) / czm_viewport.zw;
    float logDepthOrDepth = czm_unpackDepth(texture(czm_globeDepthTexture, st));

    if (logDepthOrDepth == 0.0)
    {
        return 0.0; // not on the globe
    }

    vec4 eyeCoordinate = czm_windowToEyeCoordinates(gl_FragCoord.xy, logDepthOrDepth);
    return eyeCoordinate.z / eyeCoordinate.w;
}
#endif


#ifdef SDF

// Get the distance from the edge of a glyph at a given position sampling an SDF texture.
float getDistance(vec2 position)
{
    return texture(u_atlas, position).r;
}

// Samples the sdf texture at the given position and produces a color based on the fill color and the outline.
vec4 getSDFColor(vec2 position, float outlineWidth, vec4 outlineColor, float smoothing)
{
    float distance = getDistance(position);

    if (outlineWidth > 0.0)
    {
        // Don't get the outline edge exceed the SDF_EDGE
        float outlineEdge = clamp(SDF_EDGE - outlineWidth, 0.0, SDF_EDGE);
        float outlineFactor = smoothstep(SDF_EDGE - smoothing, SDF_EDGE + smoothing, distance);
        vec4 sdfColor = mix(outlineColor, v_color, outlineFactor);
        float alpha = smoothstep(outlineEdge - smoothing, outlineEdge + smoothing, distance);
        return vec4(sdfColor.rgb, sdfColor.a * alpha);
    }
    else
    {
        float alpha = smoothstep(SDF_EDGE - smoothing, SDF_EDGE + smoothing, distance);
        return vec4(v_color.rgb, v_color.a * alpha);
    }
}
#endif

void main()
{
    vec4 color = texture(u_atlas, v_textureCoordinates);

#ifdef SDF
    float outlineWidth = v_outlineWidth;
    vec4 outlineColor = v_outlineColor;

    // Get the current distance
    float distance = getDistance(v_textureCoordinates);

#if (__VERSION__ == 300 || defined(GL_OES_standard_derivatives))
    float smoothing = fwidth(distance);
    // Get an offset that is approximately half the distance to the neighbor pixels
    // 0.354 is approximately half of 1/sqrt(2)
    vec2 sampleOffset = 0.354 * vec2(dFdx(v_textureCoordinates) + dFdy(v_textureCoordinates));

    // Sample the center point
    vec4 center = getSDFColor(v_textureCoordinates, outlineWidth, outlineColor, smoothing);

    // Sample the 4 neighbors
    vec4 color1 = getSDFColor(v_textureCoordinates + vec2(sampleOffset.x, sampleOffset.y), outlineWidth, outlineColor, smoothing);
    vec4 color2 = getSDFColor(v_textureCoordinates + vec2(-sampleOffset.x, sampleOffset.y), outlineWidth, outlineColor, smoothing);
    vec4 color3 = getSDFColor(v_textureCoordinates + vec2(-sampleOffset.x, -sampleOffset.y), outlineWidth, outlineColor, smoothing);
    vec4 color4 = getSDFColor(v_textureCoordinates + vec2(sampleOffset.x, -sampleOffset.y), outlineWidth, outlineColor, smoothing);

    // Equally weight the center sample and the 4 neighboring samples
    color = (center + color1 + color2 + color3 + color4)/5.0;
#else
    // If no derivatives available (IE 10?), just do a single sample
    float smoothing = 1.0/32.0;
    color = getSDFColor(v_textureCoordinates, outlineWidth, outlineColor, smoothing);
#endif

    color = czm_gammaCorrect(color);
#else
    color = czm_gammaCorrect(color);
    color *= czm_gammaCorrect(v_color);
#endif

// Fully transparent parts of the billboard are not pickable.
#if !defined(OPAQUE) && !defined(TRANSLUCENT)
    if (color.a < 0.005)   // matches 0/255 and 1/255
    {
        discard;
    }
#else
// The billboard is rendered twice. The opaque pass discards translucent fragments
// and the translucent pass discards opaque fragments.
#ifdef OPAQUE
    if (color.a < 0.995)   // matches < 254/255
    {
        discard;
    }
#else
    if (color.a >= 0.995)  // matches 254/255 and 255/255
    {
        discard;
    }
#endif
#endif

#ifdef VECTOR_TILE
    color *= u_highlightColor;
#endif
    out_FragColor = color;

#ifdef LOG_DEPTH
    czm_writeLogDepth();
#endif

#ifdef FRAGMENT_DEPTH_CHECK
    float temp = v_compressed.y;

    temp = temp * SHIFT_RIGHT1;

    float temp2 = (temp - floor(temp)) * SHIFT_LEFT1;
    bool enableDepthTest = temp2 != 0.0;
    bool applyTranslate = floor(temp) != 0.0;

    if (enableDepthTest) {
        temp = v_compressed.z;
        temp = temp * SHIFT_RIGHT12;

        vec2 dimensions;
        dimensions.y = (temp - floor(temp)) * SHIFT_LEFT12;
        dimensions.x = floor(temp);

        temp = v_compressed.w;
        temp = temp * SHIFT_RIGHT12;

        vec2 imageSize;
        imageSize.y = (temp - floor(temp)) * SHIFT_LEFT12;
        imageSize.x = floor(temp);

        vec2 adjustedST = v_textureCoordinates - v_textureCoordinateBounds.xy;
        adjustedST = adjustedST / vec2(v_textureCoordinateBounds.z - v_textureCoordinateBounds.x, v_textureCoordinateBounds.w - v_textureCoordinateBounds.y);

        float epsilonEyeDepth = v_compressed.x + czm_epsilon1;
        float globeDepth1 = getGlobeDepth(adjustedST, v_originTextureCoordinateAndTranslate.xy, applyTranslate, dimensions, imageSize);

        // negative values go into the screen
        if (globeDepth1 != 0.0 && globeDepth1 > epsilonEyeDepth)
        {
            float globeDepth2 = getGlobeDepth(adjustedST, vec2(0.0, 1.0), applyTranslate, dimensions, imageSize); // top left corner
            if (globeDepth2 != 0.0 && globeDepth2 > epsilonEyeDepth)
            {
                float globeDepth3 = getGlobeDepth(adjustedST, vec2(1.0, 1.0), applyTranslate, dimensions, imageSize); // top right corner
                if (globeDepth3 != 0.0 && globeDepth3 > epsilonEyeDepth)
                {
                    discard;
                }
            }
        }
    }
#endif

}
`});var QL,kL=O(()=>{QL=`#ifdef INSTANCED
in vec2 direction;
#endif
in vec4 positionHighAndScale;
in vec4 positionLowAndRotation;
in vec4 compressedAttribute0;                       // pixel offset, translate, horizontal origin, vertical origin, show, direction, texture coordinates (texture offset)
in vec4 compressedAttribute1;                       // aligned axis, translucency by distance, image width
in vec4 compressedAttribute2;                       // label horizontal origin, image height, color, pick color, size in meters, valid aligned axis, 13 bits free
in vec4 eyeOffset;                                  // eye offset in meters, 4 bytes free (texture range)
in vec4 scaleByDistance;                            // near, nearScale, far, farScale
in vec4 pixelOffsetScaleByDistance;                 // near, nearScale, far, farScale
in vec4 compressedAttribute3;                       // distance display condition near, far, disableDepthTestDistance, dimensions
in vec2 sdf;                                        // sdf outline color (rgb) and width (w)
#if defined(VERTEX_DEPTH_CHECK) || defined(FRAGMENT_DEPTH_CHECK)
in vec4 textureCoordinateBoundsOrLabelTranslate;    // the min and max x and y values for the texture coordinates
#endif
#ifdef VECTOR_TILE
in float a_batchId;
#endif

out vec2 v_textureCoordinates;
#ifdef FRAGMENT_DEPTH_CHECK
out vec4 v_textureCoordinateBounds;
out vec4 v_originTextureCoordinateAndTranslate;
out vec4 v_compressed;                                 // x: eyeDepth, y: applyTranslate & enableDepthCheck, z: dimensions, w: imageSize
out mat2 v_rotationMatrix;
#endif

out vec4 v_pickColor;
out vec4 v_color;
#ifdef SDF
out vec4 v_outlineColor;
out float v_outlineWidth;
#endif

const float UPPER_BOUND = 32768.0;

const float SHIFT_LEFT16 = 65536.0;
const float SHIFT_LEFT12 = 4096.0;
const float SHIFT_LEFT8 = 256.0;
const float SHIFT_LEFT7 = 128.0;
const float SHIFT_LEFT5 = 32.0;
const float SHIFT_LEFT3 = 8.0;
const float SHIFT_LEFT2 = 4.0;
const float SHIFT_LEFT1 = 2.0;

const float SHIFT_RIGHT12 = 1.0 / 4096.0;
const float SHIFT_RIGHT8 = 1.0 / 256.0;
const float SHIFT_RIGHT7 = 1.0 / 128.0;
const float SHIFT_RIGHT5 = 1.0 / 32.0;
const float SHIFT_RIGHT3 = 1.0 / 8.0;
const float SHIFT_RIGHT2 = 1.0 / 4.0;
const float SHIFT_RIGHT1 = 1.0 / 2.0;

vec4 addScreenSpaceOffset(vec4 positionEC, vec2 imageSize, float scale, vec2 direction, vec2 origin, vec2 translate, vec2 pixelOffset, vec3 alignedAxis, bool validAlignedAxis, float rotation, bool sizeInMeters, out mat2 rotationMatrix, out float mpp)
{
    // Note the halfSize cannot be computed in JavaScript because it is sent via
    // compressed vertex attributes that coerce it to an integer.
    vec2 halfSize = imageSize * scale * 0.5;
    halfSize *= ((direction * 2.0) - 1.0);

    vec2 originTranslate = origin * abs(halfSize);

#if defined(ROTATION) || defined(ALIGNED_AXIS)
    if (validAlignedAxis || rotation != 0.0)
    {
        float angle = rotation;
        if (validAlignedAxis)
        {
            vec4 projectedAlignedAxis = czm_modelView3D * vec4(alignedAxis, 0.0);
            angle += sign(-projectedAlignedAxis.x) * acos(sign(projectedAlignedAxis.y) * (projectedAlignedAxis.y * projectedAlignedAxis.y) /
                    (projectedAlignedAxis.x * projectedAlignedAxis.x + projectedAlignedAxis.y * projectedAlignedAxis.y));
        }

        float cosTheta = cos(angle);
        float sinTheta = sin(angle);
        rotationMatrix = mat2(cosTheta, sinTheta, -sinTheta, cosTheta);
        halfSize = rotationMatrix * halfSize;
    }
    else
    {
        rotationMatrix = mat2(1.0, 0.0, 0.0, 1.0);
    }
#endif

    mpp = czm_metersPerPixel(positionEC);
    positionEC.xy += (originTranslate + halfSize) * czm_branchFreeTernary(sizeInMeters, 1.0, mpp);
    positionEC.xy += (translate + pixelOffset) * mpp;

    return positionEC;
}

#ifdef VERTEX_DEPTH_CHECK
float getGlobeDepth(vec4 positionEC)
{
    vec4 posWC = czm_eyeToWindowCoordinates(positionEC);

    float globeDepth = czm_unpackDepth(texture(czm_globeDepthTexture, posWC.xy / czm_viewport.zw));

    if (globeDepth == 0.0)
    {
        return 0.0; // not on the globe
    }

    vec4 eyeCoordinate = czm_windowToEyeCoordinates(posWC.xy, globeDepth);
    return eyeCoordinate.z / eyeCoordinate.w;
}
#endif
void main()
{
    // Modifying this shader may also require modifications to Billboard._computeScreenSpacePosition

    // unpack attributes
    vec3 positionHigh = positionHighAndScale.xyz;
    vec3 positionLow = positionLowAndRotation.xyz;
    float scale = positionHighAndScale.w;

#if defined(ROTATION) || defined(ALIGNED_AXIS)
    float rotation = positionLowAndRotation.w;
#else
    float rotation = 0.0;
#endif

    float compressed = compressedAttribute0.x;

    vec2 pixelOffset;
    pixelOffset.x = floor(compressed * SHIFT_RIGHT7);
    compressed -= pixelOffset.x * SHIFT_LEFT7;
    pixelOffset.x -= UPPER_BOUND;

    vec2 origin;
    origin.x = floor(compressed * SHIFT_RIGHT5);
    compressed -= origin.x * SHIFT_LEFT5;

    origin.y = floor(compressed * SHIFT_RIGHT3);
    compressed -= origin.y * SHIFT_LEFT3;

#ifdef FRAGMENT_DEPTH_CHECK
    vec2 depthOrigin = origin.xy;
#endif
    origin -= vec2(1.0);

    float show = floor(compressed * SHIFT_RIGHT2);
    compressed -= show * SHIFT_LEFT2;

#ifdef INSTANCED
    vec2 textureCoordinatesBottomLeft = czm_decompressTextureCoordinates(compressedAttribute0.w);
    vec2 textureCoordinatesRange = czm_decompressTextureCoordinates(eyeOffset.w);
    vec2 textureCoordinates = textureCoordinatesBottomLeft + direction * textureCoordinatesRange;
#else
    vec2 direction;
    direction.x = floor(compressed * SHIFT_RIGHT1);
    direction.y = compressed - direction.x * SHIFT_LEFT1;

    vec2 textureCoordinates = czm_decompressTextureCoordinates(compressedAttribute0.w);
#endif

    float temp = compressedAttribute0.y  * SHIFT_RIGHT8;
    pixelOffset.y = -(floor(temp) - UPPER_BOUND);

    vec2 translate;
    translate.y = (temp - floor(temp)) * SHIFT_LEFT16;

    temp = compressedAttribute0.z * SHIFT_RIGHT8;
    translate.x = floor(temp) - UPPER_BOUND;

    translate.y += (temp - floor(temp)) * SHIFT_LEFT8;
    translate.y -= UPPER_BOUND;

    temp = compressedAttribute1.x * SHIFT_RIGHT8;
    float temp2 = floor(compressedAttribute2.w * SHIFT_RIGHT2);

    vec2 imageSize = vec2(floor(temp), temp2);

#ifdef FRAGMENT_DEPTH_CHECK
    float labelHorizontalOrigin = floor(compressedAttribute2.w - (temp2 * SHIFT_LEFT2));
    float applyTranslate = 0.0;
    if (labelHorizontalOrigin != 0.0) // is a billboard, so set apply translate to false
    {
        applyTranslate = 1.0;
        labelHorizontalOrigin -= 2.0;
        depthOrigin.x = labelHorizontalOrigin + 1.0;
    }

    depthOrigin = vec2(1.0) - (depthOrigin * 0.5);
#endif

#ifdef EYE_DISTANCE_TRANSLUCENCY
    vec4 translucencyByDistance;
    translucencyByDistance.x = compressedAttribute1.z;
    translucencyByDistance.z = compressedAttribute1.w;

    translucencyByDistance.y = ((temp - floor(temp)) * SHIFT_LEFT8) / 255.0;

    temp = compressedAttribute1.y * SHIFT_RIGHT8;
    translucencyByDistance.w = ((temp - floor(temp)) * SHIFT_LEFT8) / 255.0;
#endif

#if defined(VERTEX_DEPTH_CHECK) || defined(FRAGMENT_DEPTH_CHECK)
    temp = compressedAttribute3.w;
    temp = temp * SHIFT_RIGHT12;

    vec2 dimensions;
    dimensions.y = (temp - floor(temp)) * SHIFT_LEFT12;
    dimensions.x = floor(temp);
#endif

#ifdef ALIGNED_AXIS
    vec3 alignedAxis = czm_octDecode(floor(compressedAttribute1.y * SHIFT_RIGHT8));
    temp = compressedAttribute2.z * SHIFT_RIGHT5;
    bool validAlignedAxis = (temp - floor(temp)) * SHIFT_LEFT1 > 0.0;
#else
    vec3 alignedAxis = vec3(0.0);
    bool validAlignedAxis = false;
#endif

    vec4 pickColor;
    vec4 color;

    temp = compressedAttribute2.y;
    temp = temp * SHIFT_RIGHT8;
    pickColor.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    pickColor.g = (temp - floor(temp)) * SHIFT_LEFT8;
    pickColor.r = floor(temp);

    temp = compressedAttribute2.x;
    temp = temp * SHIFT_RIGHT8;
    color.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    color.g = (temp - floor(temp)) * SHIFT_LEFT8;
    color.r = floor(temp);

    temp = compressedAttribute2.z * SHIFT_RIGHT8;
    bool sizeInMeters = floor((temp - floor(temp)) * SHIFT_LEFT7) > 0.0;
    temp = floor(temp) * SHIFT_RIGHT8;

    pickColor.a = (temp - floor(temp)) * SHIFT_LEFT8;
    pickColor /= 255.0;

    color.a = floor(temp);
    color /= 255.0;

    ///////////////////////////////////////////////////////////////////////////

    vec4 p = czm_translateRelativeToEye(positionHigh, positionLow);
    vec4 positionEC = czm_modelViewRelativeToEye * p;

#if defined(FRAGMENT_DEPTH_CHECK) || defined(VERTEX_DEPTH_CHECK)
    float eyeDepth = positionEC.z;
#endif

    positionEC = czm_eyeOffset(positionEC, eyeOffset.xyz);
    positionEC.xyz *= show;

    ///////////////////////////////////////////////////////////////////////////

#if defined(EYE_DISTANCE_SCALING) || defined(EYE_DISTANCE_TRANSLUCENCY) || defined(EYE_DISTANCE_PIXEL_OFFSET) || defined(DISTANCE_DISPLAY_CONDITION) || defined(DISABLE_DEPTH_DISTANCE)
    float lengthSq;
    if (czm_sceneMode == czm_sceneMode2D)
    {
        // 2D camera distance is a special case
        // treat all billboards as flattened to the z=0.0 plane
        lengthSq = czm_eyeHeight2D.y;
    }
    else
    {
        lengthSq = dot(positionEC.xyz, positionEC.xyz);
    }
#endif

#ifdef EYE_DISTANCE_SCALING
    float distanceScale = czm_nearFarScalar(scaleByDistance, lengthSq);
    scale *= distanceScale;
    translate *= distanceScale;
    // push vertex behind near plane for clipping
    if (scale == 0.0)
    {
        positionEC.xyz = vec3(0.0);
    }
#endif

    float translucency = 1.0;
#ifdef EYE_DISTANCE_TRANSLUCENCY
    translucency = czm_nearFarScalar(translucencyByDistance, lengthSq);
    // push vertex behind near plane for clipping
    if (translucency == 0.0)
    {
        positionEC.xyz = vec3(0.0);
    }
#endif

#ifdef EYE_DISTANCE_PIXEL_OFFSET
    float pixelOffsetScale = czm_nearFarScalar(pixelOffsetScaleByDistance, lengthSq);
    pixelOffset *= pixelOffsetScale;
#endif

#ifdef DISTANCE_DISPLAY_CONDITION
    float nearSq = compressedAttribute3.x;
    float farSq = compressedAttribute3.y;
    if (lengthSq < nearSq || lengthSq > farSq)
    {
        positionEC.xyz = vec3(0.0);
    }
#endif

    mat2 rotationMatrix;
    float mpp;

#ifdef DISABLE_DEPTH_DISTANCE
    float disableDepthTestDistance = compressedAttribute3.z;
#endif

#ifdef VERTEX_DEPTH_CHECK
if (lengthSq < disableDepthTestDistance) {
    float depthsilon = 10.0;

    vec2 labelTranslate = textureCoordinateBoundsOrLabelTranslate.xy;
    vec4 pEC1 = addScreenSpaceOffset(positionEC, dimensions, scale, vec2(0.0), origin, labelTranslate, pixelOffset, alignedAxis, validAlignedAxis, rotation, sizeInMeters, rotationMatrix, mpp);
    float globeDepth1 = getGlobeDepth(pEC1);

    if (globeDepth1 != 0.0 && pEC1.z + depthsilon < globeDepth1)
    {
        vec4 pEC2 = addScreenSpaceOffset(positionEC, dimensions, scale, vec2(0.0, 1.0), origin, labelTranslate, pixelOffset, alignedAxis, validAlignedAxis, rotation, sizeInMeters, rotationMatrix, mpp);
        float globeDepth2 = getGlobeDepth(pEC2);

        if (globeDepth2 != 0.0 && pEC2.z + depthsilon < globeDepth2)
        {
            vec4 pEC3 = addScreenSpaceOffset(positionEC, dimensions, scale, vec2(1.0), origin, labelTranslate, pixelOffset, alignedAxis, validAlignedAxis, rotation, sizeInMeters, rotationMatrix, mpp);
            float globeDepth3 = getGlobeDepth(pEC3);
            if (globeDepth3 != 0.0 && pEC3.z + depthsilon < globeDepth3)
            {
                positionEC.xyz = vec3(0.0);
            }
        }
    }
}
#endif

    positionEC = addScreenSpaceOffset(positionEC, imageSize, scale, direction, origin, translate, pixelOffset, alignedAxis, validAlignedAxis, rotation, sizeInMeters, rotationMatrix, mpp);
    gl_Position = czm_projection * positionEC;
    v_textureCoordinates = textureCoordinates;

#ifdef LOG_DEPTH
    czm_vertexLogDepth();
#endif

#ifdef DISABLE_DEPTH_DISTANCE
    if (disableDepthTestDistance == 0.0 && czm_minimumDisableDepthTestDistance != 0.0)
    {
        disableDepthTestDistance = czm_minimumDisableDepthTestDistance;
    }

    if (disableDepthTestDistance != 0.0)
    {
        // Don't try to "multiply both sides" by w.  Greater/less-than comparisons won't work for negative values of w.
        float zclip = gl_Position.z / gl_Position.w;
        bool clipped = (zclip < -1.0 || zclip > 1.0);
        if (!clipped && (disableDepthTestDistance < 0.0 || (lengthSq > 0.0 && lengthSq < disableDepthTestDistance)))
        {
            // Position z on the near plane.
            gl_Position.z = -gl_Position.w;
#ifdef LOG_DEPTH
            v_depthFromNearPlusOne = 1.0;
#endif
        }
    }
#endif

#ifdef FRAGMENT_DEPTH_CHECK
    if (sizeInMeters) {
        translate /= mpp;
        dimensions /= mpp;
        imageSize /= mpp;
    }

#if defined(ROTATION) || defined(ALIGNED_AXIS)
    v_rotationMatrix = rotationMatrix;
#else
    v_rotationMatrix = mat2(1.0, 0.0, 0.0, 1.0);
#endif

    float enableDepthCheck = 0.0;
    if (lengthSq < disableDepthTestDistance)
    {
        enableDepthCheck = 1.0;
    }

    float dw = floor(clamp(dimensions.x, 0.0, SHIFT_LEFT12));
    float dh = floor(clamp(dimensions.y, 0.0, SHIFT_LEFT12));

    float iw = floor(clamp(imageSize.x, 0.0, SHIFT_LEFT12));
    float ih = floor(clamp(imageSize.y, 0.0, SHIFT_LEFT12));

    v_compressed.x = eyeDepth;
    v_compressed.y = applyTranslate * SHIFT_LEFT1 + enableDepthCheck;
    v_compressed.z = dw * SHIFT_LEFT12 + dh;
    v_compressed.w = iw * SHIFT_LEFT12 + ih;
    v_originTextureCoordinateAndTranslate.xy = depthOrigin;
    v_originTextureCoordinateAndTranslate.zw = translate;
    v_textureCoordinateBounds = textureCoordinateBoundsOrLabelTranslate;

#endif

#ifdef SDF
    vec4 outlineColor;
    float outlineWidth;

    temp = sdf.x;
    temp = temp * SHIFT_RIGHT8;
    outlineColor.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    outlineColor.g = (temp - floor(temp)) * SHIFT_LEFT8;
    outlineColor.r = floor(temp);

    temp = sdf.y;
    temp = temp * SHIFT_RIGHT8;
    float temp3 = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    outlineWidth = (temp - floor(temp)) * SHIFT_LEFT8;
    outlineColor.a = floor(temp);
    outlineColor /= 255.0;

    v_outlineWidth = outlineWidth / 255.0;
    v_outlineColor = outlineColor;
    v_outlineColor.a *= translucency;
#endif

    v_pickColor = pickColor;

    v_color = color;
    v_color.a *= translucency;

}
`});var Btt,Yl,LL=O(()=>{ss();Btt={ADD:it.FUNC_ADD,SUBTRACT:it.FUNC_SUBTRACT,REVERSE_SUBTRACT:it.FUNC_REVERSE_SUBTRACT,MIN:it.MIN,MAX:it.MAX},Yl=Object.freeze(Btt)});var Wtt,Rr,yL=O(()=>{ss();Wtt={ZERO:it.ZERO,ONE:it.ONE,SOURCE_COLOR:it.SRC_COLOR,ONE_MINUS_SOURCE_COLOR:it.ONE_MINUS_SRC_COLOR,DESTINATION_COLOR:it.DST_COLOR,ONE_MINUS_DESTINATION_COLOR:it.ONE_MINUS_DST_COLOR,SOURCE_ALPHA:it.SRC_ALPHA,ONE_MINUS_SOURCE_ALPHA:it.ONE_MINUS_SRC_ALPHA,DESTINATION_ALPHA:it.DST_ALPHA,ONE_MINUS_DESTINATION_ALPHA:it.ONE_MINUS_DST_ALPHA,CONSTANT_COLOR:it.CONSTANT_COLOR,ONE_MINUS_CONSTANT_COLOR:it.ONE_MINUS_CONSTANT_COLOR,CONSTANT_ALPHA:it.CONSTANT_ALPHA,ONE_MINUS_CONSTANT_ALPHA:it.ONE_MINUS_CONSTANT_ALPHA,SOURCE_ALPHA_SATURATE:it.SRC_ALPHA_SATURATE},Rr=Object.freeze(Wtt)});var Dtt,Ur,km=O(()=>{LL();yL();Dtt={DISABLED:Object.freeze({enabled:!1}),ALPHA_BLEND:Object.freeze({enabled:!0,equationRgb:Yl.ADD,equationAlpha:Yl.ADD,functionSourceRgb:Rr.SOURCE_ALPHA,functionSourceAlpha:Rr.ONE,functionDestinationRgb:Rr.ONE_MINUS_SOURCE_ALPHA,functionDestinationAlpha:Rr.ONE_MINUS_SOURCE_ALPHA}),PRE_MULTIPLIED_ALPHA_BLEND:Object.freeze({enabled:!0,equationRgb:Yl.ADD,equationAlpha:Yl.ADD,functionSourceRgb:Rr.ONE,functionSourceAlpha:Rr.ONE,functionDestinationRgb:Rr.ONE_MINUS_SOURCE_ALPHA,functionDestinationAlpha:Rr.ONE_MINUS_SOURCE_ALPHA}),ADDITIVE_BLEND:Object.freeze({enabled:!0,equationRgb:Yl.ADD,equationAlpha:Yl.ADD,functionSourceRgb:Rr.SOURCE_ALPHA,functionSourceAlpha:Rr.ONE,functionDestinationRgb:Rr.ONE,functionDestinationAlpha:Rr.ONE})},Ur=Object.freeze(Dtt)});var Mtt,Wn,EI=O(()=>{Mtt={OPAQUE:0,TRANSLUCENT:1,OPAQUE_AND_TRANSLUCENT:2},Wn=Object.freeze(Mtt)});var Utt,po,_I=O(()=>{Utt={FONT_SIZE:48,PADDING:10,RADIUS:8,CUTOFF:.25},po=Object.freeze(Utt)});var Si,ge,Ec=O(()=>{ss();Si={UNSIGNED_BYTE:it.UNSIGNED_BYTE,UNSIGNED_SHORT:it.UNSIGNED_SHORT,UNSIGNED_INT:it.UNSIGNED_INT,FLOAT:it.FLOAT,HALF_FLOAT:it.HALF_FLOAT_OES,UNSIGNED_INT_24_8:it.UNSIGNED_INT_24_8,UNSIGNED_SHORT_4_4_4_4:it.UNSIGNED_SHORT_4_4_4_4,UNSIGNED_SHORT_5_5_5_1:it.UNSIGNED_SHORT_5_5_5_1,UNSIGNED_SHORT_5_6_5:it.UNSIGNED_SHORT_5_6_5};Si.toWebGLConstant=function(t,e){switch(t){case Si.UNSIGNED_BYTE:return it.UNSIGNED_BYTE;case Si.UNSIGNED_SHORT:return it.UNSIGNED_SHORT;case Si.UNSIGNED_INT:return it.UNSIGNED_INT;case Si.FLOAT:return it.FLOAT;case Si.HALF_FLOAT:return e.webgl2?it.HALF_FLOAT:it.HALF_FLOAT_OES;case Si.UNSIGNED_INT_24_8:return it.UNSIGNED_INT_24_8;case Si.UNSIGNED_SHORT_4_4_4_4:return it.UNSIGNED_SHORT_4_4_4_4;case Si.UNSIGNED_SHORT_5_5_5_1:return it.UNSIGNED_SHORT_5_5_5_1;case Si.UNSIGNED_SHORT_5_6_5:return Si.UNSIGNED_SHORT_5_6_5}};Si.isPacked=function(t){return t===Si.UNSIGNED_INT_24_8||t===Si.UNSIGNED_SHORT_4_4_4_4||t===Si.UNSIGNED_SHORT_5_5_5_1||t===Si.UNSIGNED_SHORT_5_6_5};Si.sizeInBytes=function(t){switch(t){case Si.UNSIGNED_BYTE:return 1;case Si.UNSIGNED_SHORT:case Si.UNSIGNED_SHORT_4_4_4_4:case Si.UNSIGNED_SHORT_5_5_5_1:case Si.UNSIGNED_SHORT_5_6_5:case Si.HALF_FLOAT:return 2;case Si.UNSIGNED_INT:case Si.FLOAT:case Si.UNSIGNED_INT_24_8:return 4}};Si.validate=function(t){return t===Si.UNSIGNED_BYTE||t===Si.UNSIGNED_SHORT||t===Si.UNSIGNED_INT||t===Si.FLOAT||t===Si.HALF_FLOAT||t===Si.UNSIGNED_INT_24_8||t===Si.UNSIGNED_SHORT_4_4_4_4||t===Si.UNSIGNED_SHORT_5_5_5_1||t===Si.UNSIGNED_SHORT_5_6_5};ge=Object.freeze(Si)});var vt,Ie,_c=O(()=>{Ec();ss();vt={DEPTH_COMPONENT:it.DEPTH_COMPONENT,DEPTH_STENCIL:it.DEPTH_STENCIL,ALPHA:it.ALPHA,RED:it.RED,RG:it.RG,RGB:it.RGB,RGBA:it.RGBA,LUMINANCE:it.LUMINANCE,LUMINANCE_ALPHA:it.LUMINANCE_ALPHA,RGB_DXT1:it.COMPRESSED_RGB_S3TC_DXT1_EXT,RGBA_DXT1:it.COMPRESSED_RGBA_S3TC_DXT1_EXT,RGBA_DXT3:it.COMPRESSED_RGBA_S3TC_DXT3_EXT,RGBA_DXT5:it.COMPRESSED_RGBA_S3TC_DXT5_EXT,RGB_PVRTC_4BPPV1:it.COMPRESSED_RGB_PVRTC_4BPPV1_IMG,RGB_PVRTC_2BPPV1:it.COMPRESSED_RGB_PVRTC_2BPPV1_IMG,RGBA_PVRTC_4BPPV1:it.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG,RGBA_PVRTC_2BPPV1:it.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG,RGBA_ASTC:it.COMPRESSED_RGBA_ASTC_4x4_WEBGL,RGB_ETC1:it.COMPRESSED_RGB_ETC1_WEBGL,RGB8_ETC2:it.COMPRESSED_RGB8_ETC2,RGBA8_ETC2_EAC:it.COMPRESSED_RGBA8_ETC2_EAC,RGBA_BC7:it.COMPRESSED_RGBA_BPTC_UNORM};vt.componentsLength=function(t){switch(t){case vt.RGB:return 3;case vt.RGBA:return 4;case vt.LUMINANCE_ALPHA:case vt.RG:return 2;case vt.ALPHA:case vt.RED:case vt.LUMINANCE:return 1;default:return 1}};vt.validate=function(t){return t===vt.DEPTH_COMPONENT||t===vt.DEPTH_STENCIL||t===vt.ALPHA||t===vt.RED||t===vt.RG||t===vt.RGB||t===vt.RGBA||t===vt.LUMINANCE||t===vt.LUMINANCE_ALPHA||t===vt.RGB_DXT1||t===vt.RGBA_DXT1||t===vt.RGBA_DXT3||t===vt.RGBA_DXT5||t===vt.RGB_PVRTC_4BPPV1||t===vt.RGB_PVRTC_2BPPV1||t===vt.RGBA_PVRTC_4BPPV1||t===vt.RGBA_PVRTC_2BPPV1||t===vt.RGBA_ASTC||t===vt.RGB_ETC1||t===vt.RGB8_ETC2||t===vt.RGBA8_ETC2_EAC||t===vt.RGBA_BC7};vt.isColorFormat=function(t){return t===vt.RED||t===vt.ALPHA||t===vt.RGB||t===vt.RGBA||t===vt.LUMINANCE||t===vt.LUMINANCE_ALPHA};vt.isDepthFormat=function(t){return t===vt.DEPTH_COMPONENT||t===vt.DEPTH_STENCIL};vt.isCompressedFormat=function(t){return t===vt.RGB_DXT1||t===vt.RGBA_DXT1||t===vt.RGBA_DXT3||t===vt.RGBA_DXT5||t===vt.RGB_PVRTC_4BPPV1||t===vt.RGB_PVRTC_2BPPV1||t===vt.RGBA_PVRTC_4BPPV1||t===vt.RGBA_PVRTC_2BPPV1||t===vt.RGBA_ASTC||t===vt.RGB_ETC1||t===vt.RGB8_ETC2||t===vt.RGBA8_ETC2_EAC||t===vt.RGBA_BC7};vt.isDXTFormat=function(t){return t===vt.RGB_DXT1||t===vt.RGBA_DXT1||t===vt.RGBA_DXT3||t===vt.RGBA_DXT5};vt.isPVRTCFormat=function(t){return t===vt.RGB_PVRTC_4BPPV1||t===vt.RGB_PVRTC_2BPPV1||t===vt.RGBA_PVRTC_4BPPV1||t===vt.RGBA_PVRTC_2BPPV1};vt.isASTCFormat=function(t){return t===vt.RGBA_ASTC};vt.isETC1Format=function(t){return t===vt.RGB_ETC1};vt.isETC2Format=function(t){return t===vt.RGB8_ETC2||t===vt.RGBA8_ETC2_EAC};vt.isBC7Format=function(t){return t===vt.RGBA_BC7};vt.compressedTextureSizeInBytes=function(t,e,i){switch(t){case vt.RGB_DXT1:case vt.RGBA_DXT1:case vt.RGB_ETC1:case vt.RGB8_ETC2:return Math.floor((e+3)/4)*Math.floor((i+3)/4)*8;case vt.RGBA_DXT3:case vt.RGBA_DXT5:case vt.RGBA_ASTC:case vt.RGBA8_ETC2_EAC:return Math.floor((e+3)/4)*Math.floor((i+3)/4)*16;case vt.RGB_PVRTC_4BPPV1:case vt.RGBA_PVRTC_4BPPV1:return Math.floor((Math.max(e,8)*Math.max(i,8)*4+7)/8);case vt.RGB_PVRTC_2BPPV1:case vt.RGBA_PVRTC_2BPPV1:return Math.floor((Math.max(e,16)*Math.max(i,8)*2+7)/8);case vt.RGBA_BC7:return Math.ceil(e/4)*Math.ceil(i/4)*16;default:return 0}};vt.textureSizeInBytes=function(t,e,i,n){let s=vt.componentsLength(t);return ge.isPacked(e)&&(s=1),s*ge.sizeInBytes(e)*i*n};vt.alignmentInBytes=function(t,e,i){let n=vt.textureSizeInBytes(t,e,i,1)%4;return n===0?4:n===2?2:1};vt.createTypedArray=function(t,e,i,n){let s,o=ge.sizeInBytes(e);o===Uint8Array.BYTES_PER_ELEMENT?s=Uint8Array:o===Uint16Array.BYTES_PER_ELEMENT?s=Uint16Array:o===Float32Array.BYTES_PER_ELEMENT&&e===ge.FLOAT?s=Float32Array:s=Uint32Array;let r=vt.componentsLength(t)*i*n;return new s(r)};vt.flipY=function(t,e,i,n,s){if(s===1)return t;let o=vt.createTypedArray(e,i,n,s),r=vt.componentsLength(e),a=n*r;for(let h=0;h<s;++h){let A=h*n*r,d=(s-h-1)*n*r;for(let f=0;f<a;++f)o[d+f]=t[A+f]}return o};vt.toInternalFormat=function(t,e,i){if(!i.webgl2)return t;if(t===vt.DEPTH_STENCIL)return it.DEPTH24_STENCIL8;if(t===vt.DEPTH_COMPONENT){if(e===ge.UNSIGNED_SHORT)return it.DEPTH_COMPONENT16;if(e===ge.UNSIGNED_INT)return it.DEPTH_COMPONENT24}if(e===ge.FLOAT)switch(t){case vt.RGBA:return it.RGBA32F;case vt.RGB:return it.RGB32F;case vt.RG:return it.RG32F;case vt.RED:return it.R32F}if(e===ge.HALF_FLOAT)switch(t){case vt.RGBA:return it.RGBA16F;case vt.RGB:return it.RGB16F;case vt.RG:return it.RG16F;case vt.RED:return it.R16F}return t};Ie=Object.freeze(vt)});function WT(t,e,i){let n=t._gl;n.framebufferTexture2D(n.FRAMEBUFFER,e,i._target,i._texture,0)}function RI(t,e,i){let n=t._gl;n.framebufferRenderbuffer(n.FRAMEBUFFER,e,n.RENDERBUFFER,i._getRenderbuffer())}function Ta(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.context;p.defined("options.context",e);let i=e._gl,n=en.maximumColorAttachments;if(this._gl=i,this._framebuffer=i.createFramebuffer(),this._colorTextures=[],this._colorRenderbuffers=[],this._activeColorAttachments=[],this._depthTexture=void 0,this._depthRenderbuffer=void 0,this._stencilRenderbuffer=void 0,this._depthStencilTexture=void 0,this._depthStencilRenderbuffer=void 0,this.destroyAttachments=Z(t.destroyAttachments,!0),m(t.colorTextures)&&m(t.colorRenderbuffers))throw new Y("Cannot have both color texture and color renderbuffer attachments.");if(m(t.depthTexture)&&m(t.depthRenderbuffer))throw new Y("Cannot have both a depth texture and depth renderbuffer attachment.");if(m(t.depthStencilTexture)&&m(t.depthStencilRenderbuffer))throw new Y("Cannot have both a depth-stencil texture and depth-stencil renderbuffer attachment.");let s=m(t.depthTexture)||m(t.depthRenderbuffer),o=m(t.depthStencilTexture)||m(t.depthStencilRenderbuffer);if(s&&o)throw new Y("Cannot have both a depth and depth-stencil attachment.");if(m(t.stencilRenderbuffer)&&o)throw new Y("Cannot have both a stencil and depth-stencil attachment.");if(s&&m(t.stencilRenderbuffer))throw new Y("Cannot have both a depth and stencil attachment.");this._bind();let r,a,h,A,d;if(m(t.colorTextures)){let f=t.colorTextures;if(A=this._colorTextures.length=this._activeColorAttachments.length=f.length,A>n)throw new Y("The number of color attachments exceeds the number supported.");for(h=0;h<A;++h){if(r=f[h],!Ie.isColorFormat(r.pixelFormat))throw new Y("The color-texture pixel-format must be a color format.");if(r.pixelDatatype===ge.FLOAT&&!e.colorBufferFloat)throw new Y("The color texture pixel datatype is FLOAT and the WebGL implementation does not support the EXT_color_buffer_float or WEBGL_color_buffer_float extensions. See Context.colorBufferFloat.");if(r.pixelDatatype===ge.HALF_FLOAT&&!e.colorBufferHalfFloat)throw new Y("The color texture pixel datatype is HALF_FLOAT and the WebGL implementation does not support the EXT_color_buffer_half_float extension. See Context.colorBufferHalfFloat.");d=this._gl.COLOR_ATTACHMENT0+h,WT(this,d,r),this._activeColorAttachments[h]=d,this._colorTextures[h]=r}}if(m(t.colorRenderbuffers)){let f=t.colorRenderbuffers;if(A=this._colorRenderbuffers.length=this._activeColorAttachments.length=f.length,A>n)throw new Y("The number of color attachments exceeds the number supported.");for(h=0;h<A;++h)a=f[h],d=this._gl.COLOR_ATTACHMENT0+h,RI(this,d,a),this._activeColorAttachments[h]=d,this._colorRenderbuffers[h]=a}if(m(t.depthTexture)){if(r=t.depthTexture,r.pixelFormat!==Ie.DEPTH_COMPONENT)throw new Y("The depth-texture pixel-format must be DEPTH_COMPONENT.");WT(this,this._gl.DEPTH_ATTACHMENT,r),this._depthTexture=r}if(m(t.depthRenderbuffer)&&(a=t.depthRenderbuffer,RI(this,this._gl.DEPTH_ATTACHMENT,a),this._depthRenderbuffer=a),m(t.stencilRenderbuffer)&&(a=t.stencilRenderbuffer,RI(this,this._gl.STENCIL_ATTACHMENT,a),this._stencilRenderbuffer=a),m(t.depthStencilTexture)){if(r=t.depthStencilTexture,r.pixelFormat!==Ie.DEPTH_STENCIL)throw new Y("The depth-stencil pixel-format must be DEPTH_STENCIL.");WT(this,this._gl.DEPTH_STENCIL_ATTACHMENT,r),this._depthStencilTexture=r}m(t.depthStencilRenderbuffer)&&(a=t.depthStencilRenderbuffer,RI(this,this._gl.DEPTH_STENCIL_ATTACHMENT,a),this._depthStencilRenderbuffer=a),this._unBind()}var wL,xL=O(()=>{ae();bt();mt();Ws();Vt();_c();ga();Ec();Object.defineProperties(Ta.prototype,{status:{get:function(){this._bind();let t=this._gl.checkFramebufferStatus(this._gl.FRAMEBUFFER);return this._unBind(),t}},numberOfColorAttachments:{get:function(){return this._activeColorAttachments.length}},depthTexture:{get:function(){return this._depthTexture}},depthRenderbuffer:{get:function(){return this._depthRenderbuffer}},stencilRenderbuffer:{get:function(){return this._stencilRenderbuffer}},depthStencilTexture:{get:function(){return this._depthStencilTexture}},depthStencilRenderbuffer:{get:function(){return this._depthStencilRenderbuffer}},hasDepthAttachment:{get:function(){return!!(this.depthTexture||this.depthRenderbuffer||this.depthStencilTexture||this.depthStencilRenderbuffer)}}});Ta.prototype._bind=function(){let t=this._gl;t.bindFramebuffer(t.FRAMEBUFFER,this._framebuffer)};Ta.prototype._unBind=function(){let t=this._gl;t.bindFramebuffer(t.FRAMEBUFFER,null)};Ta.prototype.bindDraw=function(){let t=this._gl;t.bindFramebuffer(t.DRAW_FRAMEBUFFER,this._framebuffer)};Ta.prototype.bindRead=function(){let t=this._gl;t.bindFramebuffer(t.READ_FRAMEBUFFER,this._framebuffer)};Ta.prototype._getActiveColorAttachments=function(){return this._activeColorAttachments};Ta.prototype.getColorTexture=function(t){if(!m(t)||t<0||t>=this._colorTextures.length)throw new Y("index is required, must be greater than or equal to zero and must be less than the number of color attachments.");return this._colorTextures[t]};Ta.prototype.getColorRenderbuffer=function(t){if(!m(t)||t<0||t>=this._colorRenderbuffers.length)throw new Y("index is required, must be greater than or equal to zero and must be less than the number of color attachments.");return this._colorRenderbuffers[t]};Ta.prototype.isDestroyed=function(){return!1};Ta.prototype.destroy=function(){if(this.destroyAttachments){let t=0,e=this._colorTextures,i=e.length;for(;t<i;++t){let s=e[t];m(s)&&s.destroy()}let n=this._colorRenderbuffers;for(i=n.length,t=0;t<i;++t){let s=n[t];m(s)&&s.destroy()}this._depthTexture=this._depthTexture&&this._depthTexture.destroy(),this._depthRenderbuffer=this._depthRenderbuffer&&this._depthRenderbuffer.destroy(),this._stencilRenderbuffer=this._stencilRenderbuffer&&this._stencilRenderbuffer.destroy(),this._depthStencilTexture=this._depthStencilTexture&&this._depthStencilTexture.destroy(),this._depthStencilRenderbuffer=this._depthStencilRenderbuffer&&this._depthStencilRenderbuffer.destroy()}return this._gl.deleteFramebuffer(this._framebuffer),li(this)};wL=Ta});var ZI,Lm,DT=O(()=>{ss();ZI={DONT_CARE:it.DONT_CARE,FASTEST:it.FASTEST,NICEST:it.NICEST,validate:function(t){return t===ZI.DONT_CARE||t===ZI.FASTEST||t===ZI.NICEST}},Lm=Object.freeze(ZI)});var II,Na,NE=O(()=>{ss();II={NEAREST:it.NEAREST,LINEAR:it.LINEAR};II.validate=function(t){return t===II.NEAREST||t===II.LINEAR};Na=Object.freeze(II)});var Rc,_s,bE=O(()=>{ss();Rc={NEAREST:it.NEAREST,LINEAR:it.LINEAR,NEAREST_MIPMAP_NEAREST:it.NEAREST_MIPMAP_NEAREST,LINEAR_MIPMAP_NEAREST:it.LINEAR_MIPMAP_NEAREST,NEAREST_MIPMAP_LINEAR:it.NEAREST_MIPMAP_LINEAR,LINEAR_MIPMAP_LINEAR:it.LINEAR_MIPMAP_LINEAR};Rc.validate=function(t){return t===Rc.NEAREST||t===Rc.LINEAR||t===Rc.NEAREST_MIPMAP_NEAREST||t===Rc.LINEAR_MIPMAP_NEAREST||t===Rc.NEAREST_MIPMAP_LINEAR||t===Rc.LINEAR_MIPMAP_LINEAR};_s=Object.freeze(Rc)});var pI,Sl,PL=O(()=>{ss();pI={CLAMP_TO_EDGE:it.CLAMP_TO_EDGE,REPEAT:it.REPEAT,MIRRORED_REPEAT:it.MIRRORED_REPEAT,validate:function(t){return t===pI.CLAMP_TO_EDGE||t===pI.REPEAT||t===pI.MIRRORED_REPEAT}},Sl=Object.freeze(pI)});function FE(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.wrapS,Sl.CLAMP_TO_EDGE),i=Z(t.wrapT,Sl.CLAMP_TO_EDGE),n=Z(t.minificationFilter,_s.LINEAR),s=Z(t.magnificationFilter,Na.LINEAR),o=m(t.maximumAnisotropy)?t.maximumAnisotropy:1;if(!Sl.validate(e))throw new Y("Invalid sampler.wrapS.");if(!Sl.validate(i))throw new Y("Invalid sampler.wrapT.");if(!_s.validate(n))throw new Y("Invalid sampler.minificationFilter.");if(!Na.validate(s))throw new Y("Invalid sampler.magnificationFilter.");p.typeOf.number.greaterThanOrEquals("maximumAnisotropy",o,1),this._wrapS=e,this._wrapT=i,this._minificationFilter=n,this._magnificationFilter=s,this._maximumAnisotropy=o}var ZA,YE=O(()=>{ae();bt();mt();Vt();NE();bE();PL();Object.defineProperties(FE.prototype,{wrapS:{get:function(){return this._wrapS}},wrapT:{get:function(){return this._wrapT}},minificationFilter:{get:function(){return this._minificationFilter}},magnificationFilter:{get:function(){return this._magnificationFilter}},maximumAnisotropy:{get:function(){return this._maximumAnisotropy}}});FE.equals=function(t,e){return t===e||m(t)&&m(e)&&t._wrapS===e._wrapS&&t._wrapT===e._wrapT&&t._minificationFilter===e._minificationFilter&&t._magnificationFilter===e._magnificationFilter&&t._maximumAnisotropy===e._maximumAnisotropy};FE.NEAREST=Object.freeze(new FE({wrapS:Sl.CLAMP_TO_EDGE,wrapT:Sl.CLAMP_TO_EDGE,minificationFilter:_s.NEAREST,magnificationFilter:Na.NEAREST}));ZA=FE});function ba(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context);let e=t.context,i=t.width,n=t.height,s=t.source;m(s)&&(m(i)||(i=Z(s.videoWidth,s.width)),m(n)||(n=Z(s.videoHeight,s.height)));let o=Z(t.pixelFormat,Ie.RGBA),r=Z(t.pixelDatatype,ge.UNSIGNED_BYTE),a=Ie.toInternalFormat(o,r,e),h=Ie.isCompressedFormat(a);if(!m(i)||!m(n))throw new Y("options requires a source field to create an initialized texture or width and height fields to create a blank texture.");if(p.typeOf.number.greaterThan("width",i,0),i>en.maximumTextureSize)throw new Y(`Width must be less than or equal to the maximum texture size (${en.maximumTextureSize}).  Check maximumTextureSize.`);if(p.typeOf.number.greaterThan("height",n,0),n>en.maximumTextureSize)throw new Y(`Height must be less than or equal to the maximum texture size (${en.maximumTextureSize}).  Check maximumTextureSize.`);if(!Ie.validate(o))throw new Y("Invalid options.pixelFormat.");if(!h&&!ge.validate(r))throw new Y("Invalid options.pixelDatatype.");if(o===Ie.DEPTH_COMPONENT&&r!==ge.UNSIGNED_SHORT&&r!==ge.UNSIGNED_INT)throw new Y("When options.pixelFormat is DEPTH_COMPONENT, options.pixelDatatype must be UNSIGNED_SHORT or UNSIGNED_INT.");if(o===Ie.DEPTH_STENCIL&&r!==ge.UNSIGNED_INT_24_8)throw new Y("When options.pixelFormat is DEPTH_STENCIL, options.pixelDatatype must be UNSIGNED_INT_24_8.");if(r===ge.FLOAT&&!e.floatingPointTexture)throw new Y("When options.pixelDatatype is FLOAT, this WebGL implementation must support the OES_texture_float extension.  Check context.floatingPointTexture.");if(r===ge.HALF_FLOAT&&!e.halfFloatingPointTexture)throw new Y("When options.pixelDatatype is HALF_FLOAT, this WebGL implementation must support the OES_texture_half_float extension. Check context.halfFloatingPointTexture.");if(Ie.isDepthFormat(o)){if(m(s))throw new Y("When options.pixelFormat is DEPTH_COMPONENT or DEPTH_STENCIL, source cannot be provided.");if(!e.depthTexture)throw new Y("When options.pixelFormat is DEPTH_COMPONENT or DEPTH_STENCIL, this WebGL implementation must support WEBGL_depth_texture.  Check context.depthTexture.")}if(h){if(!m(s)||!m(s.arrayBufferView))throw new Y("When options.pixelFormat is compressed, options.source.arrayBufferView must be defined.");if(Ie.isDXTFormat(a)&&!e.s3tc)throw new Y("When options.pixelFormat is S3TC compressed, this WebGL implementation must support the WEBGL_compressed_texture_s3tc extension. Check context.s3tc.");if(Ie.isPVRTCFormat(a)&&!e.pvrtc)throw new Y("When options.pixelFormat is PVRTC compressed, this WebGL implementation must support the WEBGL_compressed_texture_pvrtc extension. Check context.pvrtc.");if(Ie.isASTCFormat(a)&&!e.astc)throw new Y("When options.pixelFormat is ASTC compressed, this WebGL implementation must support the WEBGL_compressed_texture_astc extension. Check context.astc.");if(Ie.isETC2Format(a)&&!e.etc)throw new Y("When options.pixelFormat is ETC2 compressed, this WebGL implementation must support the WEBGL_compressed_texture_etc extension. Check context.etc.");if(Ie.isETC1Format(a)&&!e.etc1)throw new Y("When options.pixelFormat is ETC1 compressed, this WebGL implementation must support the WEBGL_compressed_texture_etc1 extension. Check context.etc1.");if(Ie.isBC7Format(a)&&!e.bc7)throw new Y("When options.pixelFormat is BC7 compressed, this WebGL implementation must support the EXT_texture_compression_bptc extension. Check context.bc7.");if(Ie.compressedTextureSizeInBytes(a,i,n)!==s.arrayBufferView.byteLength)throw new Y("The byte length of the array buffer is invalid for the compressed texture with the given width and height.")}let A=t.preMultiplyAlpha||o===Ie.RGB||o===Ie.LUMINANCE,d=Z(t.flipY,!0),f=Z(t.skipColorSpaceConversion,!1),E=!0,_=e._gl,R=_.TEXTURE_2D,I=_.createTexture();_.activeTexture(_.TEXTURE0),_.bindTexture(R,I);let C=4;if(m(s)&&m(s.arrayBufferView)&&!h&&(C=Ie.alignmentInBytes(o,r,i)),_.pixelStorei(_.UNPACK_ALIGNMENT,C),f?_.pixelStorei(_.UNPACK_COLORSPACE_CONVERSION_WEBGL,_.NONE):_.pixelStorei(_.UNPACK_COLORSPACE_CONVERSION_WEBGL,_.BROWSER_DEFAULT_WEBGL),m(s))if(m(s.arrayBufferView)){_.pixelStorei(_.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),_.pixelStorei(_.UNPACK_FLIP_Y_WEBGL,!1);let T=s.arrayBufferView,F,b,G;if(h){if(_.compressedTexImage2D(R,0,a,i,n,0,T),m(s.mipLevels))for(b=i,G=n,F=0;F<s.mipLevels.length;++F)b=Math.floor(b/2)|0,b<1&&(b=1),G=Math.floor(G/2)|0,G<1&&(G=1),_.compressedTexImage2D(R,F+1,a,b,G,0,s.mipLevels[F])}else if(d&&(T=Ie.flipY(T,o,r,i,n)),_.texImage2D(R,0,a,i,n,0,o,ge.toWebGLConstant(r,e),T),m(s.mipLevels))for(b=i,G=n,F=0;F<s.mipLevels.length;++F)b=Math.floor(b/2)|0,b<1&&(b=1),G=Math.floor(G/2)|0,G<1&&(G=1),_.texImage2D(R,F+1,a,b,G,0,o,ge.toWebGLConstant(r,e),s.mipLevels[F])}else m(s.framebuffer)?(_.pixelStorei(_.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),_.pixelStorei(_.UNPACK_FLIP_Y_WEBGL,!1),s.framebuffer!==e.defaultFramebuffer&&s.framebuffer._bind(),_.copyTexImage2D(R,0,a,s.xOffset,s.yOffset,i,n,0),s.framebuffer!==e.defaultFramebuffer&&s.framebuffer._unBind()):(_.pixelStorei(_.UNPACK_PREMULTIPLY_ALPHA_WEBGL,A),_.pixelStorei(_.UNPACK_FLIP_Y_WEBGL,d),_.texImage2D(R,0,a,o,ge.toWebGLConstant(r,e),s));else _.texImage2D(R,0,a,i,n,0,o,ge.toWebGLConstant(r,e),null),E=!1;_.bindTexture(R,null);let N;h?N=Ie.compressedTextureSizeInBytes(o,i,n):N=Ie.textureSizeInBytes(o,r,i,n),this._id=Gs(),this._context=e,this._textureFilterAnisotropic=e._textureFilterAnisotropic,this._textureTarget=R,this._texture=I,this._internalFormat=a,this._pixelFormat=o,this._pixelDatatype=r,this._width=i,this._height=n,this._dimensions=new nt(i,n),this._hasMipmap=!1,this._sizeInBytes=N,this._preMultiplyAlpha=A,this._flipY=d,this._initialized=E,this._sampler=void 0,this.sampler=m(t.sampler)?t.sampler:new ZA}var Fa,uI=O(()=>{Xe();ae();ih();bt();mt();Ws();Vt();_e();_c();ga();DT();Ec();YE();NE();bE();ba.create=function(t){return new ba(t)};ba.fromFramebuffer=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context);let e=t.context,i=e._gl,n=Z(t.pixelFormat,Ie.RGB),s=Z(t.framebufferXOffset,0),o=Z(t.framebufferYOffset,0),r=Z(t.width,i.drawingBufferWidth),a=Z(t.height,i.drawingBufferHeight),h=t.framebuffer;if(!Ie.validate(n))throw new Y("Invalid pixelFormat.");if(Ie.isDepthFormat(n)||Ie.isCompressedFormat(n))throw new Y("pixelFormat cannot be DEPTH_COMPONENT, DEPTH_STENCIL or a compressed format.");if(p.defined("options.context",t.context),p.typeOf.number.greaterThanOrEquals("framebufferXOffset",s,0),p.typeOf.number.greaterThanOrEquals("framebufferYOffset",o,0),s+r>i.drawingBufferWidth)throw new Y("framebufferXOffset + width must be less than or equal to drawingBufferWidth");if(o+a>i.drawingBufferHeight)throw new Y("framebufferYOffset + height must be less than or equal to drawingBufferHeight.");return new ba({context:e,width:r,height:a,pixelFormat:n,source:{framebuffer:m(h)?h:e.defaultFramebuffer,xOffset:s,yOffset:o,width:r,height:a}})};Object.defineProperties(ba.prototype,{id:{get:function(){return this._id}},sampler:{get:function(){return this._sampler},set:function(t){let e=t.minificationFilter,i=t.magnificationFilter,n=this._context,s=this._pixelFormat,o=this._pixelDatatype,r=e===_s.NEAREST_MIPMAP_NEAREST||e===_s.NEAREST_MIPMAP_LINEAR||e===_s.LINEAR_MIPMAP_NEAREST||e===_s.LINEAR_MIPMAP_LINEAR;(o===ge.FLOAT&&!n.textureFloatLinear||o===ge.HALF_FLOAT&&!n.textureHalfFloatLinear)&&(e=r?_s.NEAREST_MIPMAP_NEAREST:_s.NEAREST,i=Na.NEAREST),n.webgl2&&Ie.isDepthFormat(s)&&(e=_s.NEAREST,i=Na.NEAREST);let a=n._gl,h=this._textureTarget;a.activeTexture(a.TEXTURE0),a.bindTexture(h,this._texture),a.texParameteri(h,a.TEXTURE_MIN_FILTER,e),a.texParameteri(h,a.TEXTURE_MAG_FILTER,i),a.texParameteri(h,a.TEXTURE_WRAP_S,t.wrapS),a.texParameteri(h,a.TEXTURE_WRAP_T,t.wrapT),m(this._textureFilterAnisotropic)&&a.texParameteri(h,this._textureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT,t.maximumAnisotropy),a.bindTexture(h,null),this._sampler=t}},pixelFormat:{get:function(){return this._pixelFormat}},pixelDatatype:{get:function(){return this._pixelDatatype}},dimensions:{get:function(){return this._dimensions}},preMultiplyAlpha:{get:function(){return this._preMultiplyAlpha}},flipY:{get:function(){return this._flipY}},width:{get:function(){return this._width}},height:{get:function(){return this._height}},sizeInBytes:{get:function(){return this._hasMipmap?Math.floor(this._sizeInBytes*4/3):this._sizeInBytes}},_target:{get:function(){return this._textureTarget}}});ba.prototype.copyFrom=function(t){p.defined("options",t);let e=Z(t.xOffset,0),i=Z(t.yOffset,0);if(p.defined("options.source",t.source),Ie.isDepthFormat(this._pixelFormat))throw new Y("Cannot call copyFrom when the texture pixel format is DEPTH_COMPONENT or DEPTH_STENCIL.");if(Ie.isCompressedFormat(this._pixelFormat))throw new Y("Cannot call copyFrom with a compressed texture pixel format.");p.typeOf.number.greaterThanOrEquals("xOffset",e,0),p.typeOf.number.greaterThanOrEquals("yOffset",i,0),p.typeOf.number.lessThanOrEquals("xOffset + options.source.width",e+t.source.width,this._width),p.typeOf.number.lessThanOrEquals("yOffset + options.source.height",i+t.source.height,this._height);let n=t.source,s=this._context,o=s._gl,r=this._textureTarget;o.activeTexture(o.TEXTURE0),o.bindTexture(r,this._texture);let a=n.width,h=n.height,A=n.arrayBufferView,d=this._width,f=this._height,E=this._internalFormat,_=this._pixelFormat,R=this._pixelDatatype,I=this._preMultiplyAlpha,C=this._flipY,N=Z(t.skipColorSpaceConversion,!1),T=4;m(A)&&(T=Ie.alignmentInBytes(_,R,a)),o.pixelStorei(o.UNPACK_ALIGNMENT,T),N?o.pixelStorei(o.UNPACK_COLORSPACE_CONVERSION_WEBGL,o.NONE):o.pixelStorei(o.UNPACK_COLORSPACE_CONVERSION_WEBGL,o.BROWSER_DEFAULT_WEBGL);let F=!1;if(!this._initialized){if(e===0&&i===0&&a===d&&h===f)m(A)?(o.pixelStorei(o.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),o.pixelStorei(o.UNPACK_FLIP_Y_WEBGL,!1),C&&(A=Ie.flipY(A,_,R,d,f)),o.texImage2D(r,0,E,d,f,0,_,ge.toWebGLConstant(R,s),A)):(o.pixelStorei(o.UNPACK_PREMULTIPLY_ALPHA_WEBGL,I),o.pixelStorei(o.UNPACK_FLIP_Y_WEBGL,C),o.texImage2D(r,0,E,_,ge.toWebGLConstant(R,s),n)),F=!0;else{o.pixelStorei(o.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),o.pixelStorei(o.UNPACK_FLIP_Y_WEBGL,!1);let b=Ie.createTypedArray(_,R,d,f);o.texImage2D(r,0,E,d,f,0,_,ge.toWebGLConstant(R,s),b)}this._initialized=!0}F||(m(A)?(o.pixelStorei(o.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),o.pixelStorei(o.UNPACK_FLIP_Y_WEBGL,!1),C&&(A=Ie.flipY(A,_,R,a,h)),o.texSubImage2D(r,0,e,i,a,h,_,ge.toWebGLConstant(R,s),A)):(o.pixelStorei(o.UNPACK_PREMULTIPLY_ALPHA_WEBGL,I),o.pixelStorei(o.UNPACK_FLIP_Y_WEBGL,C),o.texSubImage2D(r,0,e,i,_,ge.toWebGLConstant(R,s),n))),o.bindTexture(r,null)};ba.prototype.copyFromFramebuffer=function(t,e,i,n,s,o){if(t=Z(t,0),e=Z(e,0),i=Z(i,0),n=Z(n,0),s=Z(s,this._width),o=Z(o,this._height),Ie.isDepthFormat(this._pixelFormat))throw new Y("Cannot call copyFromFramebuffer when the texture pixel format is DEPTH_COMPONENT or DEPTH_STENCIL.");if(this._pixelDatatype===ge.FLOAT)throw new Y("Cannot call copyFromFramebuffer when the texture pixel data type is FLOAT.");if(this._pixelDatatype===ge.HALF_FLOAT)throw new Y("Cannot call copyFromFramebuffer when the texture pixel data type is HALF_FLOAT.");if(Ie.isCompressedFormat(this._pixelFormat))throw new Y("Cannot call copyFrom with a compressed texture pixel format.");p.typeOf.number.greaterThanOrEquals("xOffset",t,0),p.typeOf.number.greaterThanOrEquals("yOffset",e,0),p.typeOf.number.greaterThanOrEquals("framebufferXOffset",i,0),p.typeOf.number.greaterThanOrEquals("framebufferYOffset",n,0),p.typeOf.number.lessThanOrEquals("xOffset + width",t+s,this._width),p.typeOf.number.lessThanOrEquals("yOffset + height",e+o,this._height);let r=this._context._gl,a=this._textureTarget;r.activeTexture(r.TEXTURE0),r.bindTexture(a,this._texture),r.copyTexSubImage2D(a,0,t,e,i,n,s,o),r.bindTexture(a,null),this._initialized=!0};ba.prototype.generateMipmap=function(t){if(t=Z(t,Lm.DONT_CARE),Ie.isDepthFormat(this._pixelFormat))throw new Y("Cannot call generateMipmap when the texture pixel format is DEPTH_COMPONENT or DEPTH_STENCIL.");if(Ie.isCompressedFormat(this._pixelFormat))throw new Y("Cannot call generateMipmap with a compressed pixel format.");if(!this._context.webgl2){if(this._width>1&&!L.isPowerOfTwo(this._width))throw new Y("width must be a power of two to call generateMipmap() in a WebGL1 context.");if(this._height>1&&!L.isPowerOfTwo(this._height))throw new Y("height must be a power of two to call generateMipmap() in a WebGL1 context.")}if(!Lm.validate(t))throw new Y("hint is invalid.");this._hasMipmap=!0;let e=this._context._gl,i=this._textureTarget;e.hint(e.GENERATE_MIPMAP_HINT,t),e.activeTexture(e.TEXTURE0),e.bindTexture(i,this._texture),e.generateMipmap(i),e.bindTexture(i,null)};ba.prototype.isDestroyed=function(){return!1};ba.prototype.destroy=function(){return this._context._gl.deleteTexture(this._texture),li(this)};Fa=ba});function ch(t,e,i,n,s){this.bottomLeft=Z(t,nt.ZERO),this.topRight=Z(e,nt.ZERO),this.childNode1=i,this.childNode2=n,this.imageIndex=s}function Zc(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.borderWidthInPixels,1),i=Z(t.initialSize,Qtt);if(!m(t.context))throw new Y("context is required.");if(e<0)throw new Y("borderWidthInPixels must be greater than or equal to zero.");if(i.x<1||i.y<1)throw new Y("initialSize must be greater than zero.");this._context=t.context,this._pixelFormat=Z(t.pixelFormat,Ie.RGBA),this._borderWidthInPixels=e,this._textureCoordinates=[],this._guid=Gs(),this._idHash={},this._indexHash={},this._initialSize=i,this._root=void 0}function ktt(t,e){let i=t._context,n=t.numberOfImages,s=2,o=t._borderWidthInPixels;if(n>0){let r=t._texture.width,a=t._texture.height,h=s*(r+e.width+o),A=s*(a+e.height+o),d=r/h,f=a/A,E=new ch(new nt(r+o,o),new nt(h,a)),_=new ch(new nt,new nt(h,a),t._root,E),R=new ch(new nt(o,a+o),new nt(h,A)),I=new ch(new nt,new nt(h,A),_,R);for(let T=0;T<t._textureCoordinates.length;T++){let F=t._textureCoordinates[T];m(F)&&(F.x*=d,F.y*=f,F.width*=d,F.height*=f)}let C=new Fa({context:t._context,width:h,height:A,pixelFormat:t._pixelFormat}),N=new wL({context:i,colorTextures:[t._texture],destroyAttachments:!1});N._bind(),C.copyFromFramebuffer(0,0,0,0,h,A),N._unBind(),N.destroy(),t._texture=t._texture&&t._texture.destroy(),t._texture=C,t._root=I}else{let r=s*(e.width+2*o),a=s*(e.height+2*o);r<t._initialSize.x&&(r=t._initialSize.x),a<t._initialSize.y&&(a=t._initialSize.y),t._texture=t._texture&&t._texture.destroy(),t._texture=new Fa({context:t._context,width:r,height:a,pixelFormat:t._pixelFormat}),t._root=new ch(new nt(o,o),new nt(r,a))}}function CI(t,e,i){if(m(e)){if(!m(e.childNode1)&&!m(e.childNode2)){if(m(e.imageIndex))return;let n=e.topRight.x-e.bottomLeft.x,s=e.topRight.y-e.bottomLeft.y,o=n-i.width,r=s-i.height;if(o<0||r<0)return;if(o===0&&r===0)return e;if(o>r){e.childNode1=new ch(new nt(e.bottomLeft.x,e.bottomLeft.y),new nt(e.bottomLeft.x+i.width,e.topRight.y));let a=e.bottomLeft.x+i.width+t._borderWidthInPixels;a<e.topRight.x&&(e.childNode2=new ch(new nt(a,e.bottomLeft.y),new nt(e.topRight.x,e.topRight.y)))}else{e.childNode1=new ch(new nt(e.bottomLeft.x,e.bottomLeft.y),new nt(e.topRight.x,e.bottomLeft.y+i.height));let a=e.bottomLeft.y+i.height+t._borderWidthInPixels;a<e.topRight.y&&(e.childNode2=new ch(new nt(e.bottomLeft.x,a),new nt(e.topRight.x,e.topRight.y)))}return CI(t,e.childNode1,i)}return CI(t,e.childNode1,i)||CI(t,e.childNode2,i)}}function JL(t,e,i){let n=CI(t,t._root,e);if(m(n)){n.imageIndex=i;let s=t._texture.width,o=t._texture.height,r=n.topRight.x-n.bottomLeft.x,a=n.topRight.y-n.bottomLeft.y,h=n.bottomLeft.x/s,A=n.bottomLeft.y/o,d=r/s,f=a/o;t._textureCoordinates[i]=new mi(h,A,d,f),t._texture.copyFrom({source:e,xOffset:n.bottomLeft.x,yOffset:n.bottomLeft.y})}else ktt(t,e),JL(t,e,i);t._guid=Gs()}function jL(t,e){if(!m(t)||t.isDestroyed())return-1;let i=t.numberOfImages;return JL(t,e,i),i}var Qtt,SE,MT=O(()=>{Er();Xe();ih();bt();mt();Ws();Vt();_c();Ia();Ps();xL();uI();Qtt=new nt(16,16);Object.defineProperties(Zc.prototype,{borderWidthInPixels:{get:function(){return this._borderWidthInPixels}},textureCoordinates:{get:function(){return this._textureCoordinates}},texture:{get:function(){return m(this._texture)||(this._texture=new Fa({context:this._context,width:this._initialSize.x,height:this._initialSize.y,pixelFormat:this._pixelFormat})),this._texture}},numberOfImages:{get:function(){return this._textureCoordinates.length}},guid:{get:function(){return this._guid}}});Zc.prototype.getImageIndex=function(t){if(!m(t))throw new Y("id is required.");return this._indexHash[t]};Zc.prototype.addImageSync=function(t,e){if(!m(t))throw new Y("id is required.");if(!m(e))throw new Y("image is required.");let i=this._indexHash[t];return m(i)||(i=jL(this,e),this._idHash[t]=Promise.resolve(i),this._indexHash[t]=i),i};Zc.prototype.addImage=function(t,e){if(!m(t))throw new Y("id is required.");if(!m(e))throw new Y("image is required.");let i=this._idHash[t];if(m(i))return i;if(typeof e=="function"){if(e=e(t),!m(e))throw new Y("image is required.")}else(typeof e=="string"||e instanceof tn)&&(e=tn.createIfNeeded(e).fetchImage());let n=this;return i=Promise.resolve(e).then(function(s){let o=jL(n,s);return n._indexHash[t]=o,o}),this._idHash[t]=i,i};Zc.prototype.addSubRegion=function(t,e){if(!m(t))throw new Y("id is required.");if(!m(e))throw new Y("subRegion is required.");let i=this._idHash[t];if(!m(i))throw new ke(`image with id "${t}" not found in the atlas.`);let n=this;return Promise.resolve(i).then(function(s){if(s===-1)return-1;let o=n._texture.width,r=n._texture.height,a=n._textureCoordinates[s],h=a.x+e.x/o,A=a.y+e.y/r,d=e.width/o,f=e.height/r,E=n._textureCoordinates.push(new mi(h,A,d,f))-1;return n._indexHash[t]=E,n._guid=Gs(),E})};Zc.prototype.isDestroyed=function(){return!1};Zc.prototype.destroy=function(){return this._texture=this._texture&&this._texture.destroy(),li(this)};SE=Zc});function Lr(t){t=Z(t,Z.EMPTY_OBJECT),this._scene=t.scene,this._batchTable=t.batchTable,this._textureAtlas=void 0,this._textureAtlasGUID=void 0,this._destroyTextureAtlas=!0,this._sp=void 0,this._spTranslucent=void 0,this._rsOpaque=void 0,this._rsTranslucent=void 0,this._vaf=void 0,this._billboards=[],this._billboardsToUpdate=[],this._billboardsToUpdateIndex=0,this._billboardsRemoved=!1,this._createVertexArray=!1,this._shaderRotation=!1,this._compiledShaderRotation=!1,this._shaderAlignedAxis=!1,this._compiledShaderAlignedAxis=!1,this._shaderScaleByDistance=!1,this._compiledShaderScaleByDistance=!1,this._shaderTranslucencyByDistance=!1,this._compiledShaderTranslucencyByDistance=!1,this._shaderPixelOffsetScaleByDistance=!1,this._compiledShaderPixelOffsetScaleByDistance=!1,this._shaderDistanceDisplayCondition=!1,this._compiledShaderDistanceDisplayCondition=!1,this._shaderDisableDepthDistance=!1,this._compiledShaderDisableDepthDistance=!1,this._shaderClampToGround=!1,this._compiledShaderClampToGround=!1,this._propertiesChanged=new Uint32Array(xT),this._maxSize=0,this._maxEyeOffset=0,this._maxScale=1,this._maxPixelOffset=0,this._allHorizontalCenter=!0,this._allVerticalCenter=!0,this._allSizedInMeters=!0,this._baseVolume=new Nt,this._baseVolumeWC=new Nt,this._baseVolume2D=new Nt,this._boundingVolume=new Nt,this._boundingVolumeDirty=!1,this._colorCommands=[],this.show=Z(t.show,!0),this.modelMatrix=at.clone(Z(t.modelMatrix,at.IDENTITY)),this._modelMatrix=at.clone(at.IDENTITY),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.debugShowTextureAtlas=Z(t.debugShowTextureAtlas,!1),this.blendOption=Z(t.blendOption,Wn.OPAQUE_AND_TRANSLUCENT),this._blendOption=void 0,this._mode=ye.SCENE3D,this._buffersUsage=[ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW],this._highlightColor=Zt.clone(Zt.WHITE);let e=this;this._uniforms={u_atlas:function(){return e._textureAtlas.texture},u_highlightColor:function(){return e._highlightColor}};let i=this._scene;m(i)&&m(i.terrainProviderChanged)&&(this._removeCallbackFunc=i.terrainProviderChanged.addEventListener(function(){let n=this._billboards,s=n.length;for(let o=0;o<s;++o)m(n[o])&&n[o]._updateClamping()},this))}function ey(t){let e=t.length;for(let i=0;i<e;++i)t[i]&&t[i]._destroy()}function PT(t){if(t._billboardsRemoved){t._billboardsRemoved=!1;let e=[],i=t._billboards,n=i.length;for(let s=0,o=0;s<n;++s){let r=i[s];m(r)&&(r._index=o++,e.push(r))}t._billboards=e}}function Ktt(t){let i=t.cache.billboardCollection_indexBufferBatched;if(m(i))return i;let n=16384*6-6,s=new Uint16Array(n);for(let o=0,r=0;o<n;o+=6,r+=4)s[o]=r,s[o+1]=r+1,s[o+2]=r+2,s[o+3]=r+0,s[o+4]=r+2,s[o+5]=r+3;return i=Ca.createIndexBuffer({context:t,typedArray:s,usage:ai.STATIC_DRAW,indexDatatype:te.UNSIGNED_SHORT}),i.vertexArrayDestroyable=!1,t.cache.billboardCollection_indexBufferBatched=i,i}function Xtt(t){let e=t.cache.billboardCollection_indexBufferInstanced;return m(e)||(e=Ca.createIndexBuffer({context:t,typedArray:new Uint16Array([0,1,2,0,2,3]),usage:ai.STATIC_DRAW,indexDatatype:te.UNSIGNED_SHORT}),e.vertexArrayDestroyable=!1,t.cache.billboardCollection_indexBufferInstanced=e),e}function qtt(t){let e=t.cache.billboardCollection_vertexBufferInstanced;return m(e)||(e=Ca.createVertexBuffer({context:t,typedArray:new Float32Array([0,0,1,0,1,1,0,1]),usage:ai.STATIC_DRAW}),e.vertexArrayDestroyable=!1,t.cache.billboardCollection_vertexBufferInstanced=e),e}function $tt(t,e,i,n,s,o){let r=[{index:an.positionHighAndScale,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[VE]},{index:an.positionLowAndRotation,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[VE]},{index:an.compressedAttribute0,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[HL]},{index:an.compressedAttribute1,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[XL]},{index:an.compressedAttribute2,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[zL]},{index:an.eyeOffset,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[vL]},{index:an.scaleByDistance,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[KL]},{index:an.pixelOffsetScaleByDistance,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[qL]},{index:an.compressedAttribute3,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[$L]},{index:an.textureCoordinateBoundsOrLabelTranslate,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[Htt]}];n&&r.push({index:an.direction,componentsPerAttribute:2,componentDatatype:At.FLOAT,vertexBuffer:qtt(t)}),m(s)&&r.push({index:an.a_batchId,componentsPerAttribute:1,componentDatatype:At.FLOAT,bufferUsage:ai.STATIC_DRAW}),o&&r.push({index:an.sdf,componentsPerAttribute:2,componentDatatype:At.FLOAT,usage:i[ty]});let a=n?e:4*e;return new fI(t,r,a,n)}function iy(t,e,i,n,s){let o,r=n[an.positionHighAndScale],a=n[an.positionLowAndRotation],h=s._getActualPosition();t._mode===ye.SCENE3D&&(Nt.expand(t._baseVolume,h,t._baseVolume),t._boundingVolumeDirty=!0),Bn.fromCartesian(h,QT);let A=s.scale,d=s.rotation;d!==0&&(t._shaderRotation=!0),t._maxScale=Math.max(t._maxScale,A);let f=QT.high,E=QT.low;t._instanced?(o=s._index,r(o,f.x,f.y,f.z,A),a(o,E.x,E.y,E.z,d)):(o=s._index*4,r(o+0,f.x,f.y,f.z,A),r(o+1,f.x,f.y,f.z,A),r(o+2,f.x,f.y,f.z,A),r(o+3,f.x,f.y,f.z,A),a(o+0,E.x,E.y,E.z,d),a(o+1,E.x,E.y,E.z,d),a(o+2,E.x,E.y,E.z,d),a(o+3,E.x,E.y,E.z,d))}function Ay(t,e,i,n,s){let o,r=n[an.compressedAttribute0],a=s.pixelOffset,h=a.x,A=a.y,d=s._translate,f=d.x,E=d.y;t._maxPixelOffset=Math.max(t._maxPixelOffset,Math.abs(h+f),Math.abs(-A+E));let _=s.horizontalOrigin,R=s._verticalOrigin,I=s.show&&s.clusterShow;s.color.alpha===0&&(I=!1),R===mn.BASELINE&&(R=mn.BOTTOM),t._allHorizontalCenter=t._allHorizontalCenter&&_===to.CENTER,t._allVerticalCenter=t._allVerticalCenter&&R===mn.CENTER;let C=0,N=0,T=0,F=0,b=s._imageIndex;if(b!==-1){let H=i[b];if(!m(H))throw new Y(`Invalid billboard image index: ${b}`);C=H.x,N=H.y,T=H.width,F=H.height}let G=C+T,M=N+F,Q=Math.floor(L.clamp(h,-Qr,Qr)+Qr)*tet;Q+=(_+1)*eet,Q+=(R+1)*iet,Q+=(I?1:0)*ny;let U=Math.floor(L.clamp(A,-Qr,Qr)+Qr)*IA,k=Math.floor(L.clamp(f,-Qr,Qr)+Qr)*IA,y=(L.clamp(E,-Qr,Qr)+Qr)*net,c=Math.floor(y),g=Math.floor((y-c)*IA);U+=c,k+=g,kr.x=C,kr.y=N;let V=Yi.compressTextureCoordinates(kr);kr.x=G;let D=Yi.compressTextureCoordinates(kr);kr.y=M;let w=Yi.compressTextureCoordinates(kr);kr.x=C;let x=Yi.compressTextureCoordinates(kr);t._instanced?(o=s._index,r(o,Q,U,k,V)):(o=s._index*4,r(o+0,Q+sy,U,k,V),r(o+1,Q+oy,U,k,D),r(o+2,Q+ry,U,k,w),r(o+3,Q+ay,U,k,x))}function hy(t,e,i,n,s){let o,r=n[an.compressedAttribute1],a=s.alignedAxis;l.equals(a,l.ZERO)||(t._shaderAlignedAxis=!0);let h=0,A=1,d=1,f=1,E=s.translucencyByDistance;m(E)&&(h=E.near,A=E.nearValue,d=E.far,f=E.farValue,(A!==1||f!==1)&&(t._shaderTranslucencyByDistance=!0));let _=0,R=s._imageIndex;if(R!==-1){let F=i[R];if(!m(F))throw new Y(`Invalid billboard image index: ${R}`);_=F.width}let I=t._textureAtlas.texture.width,C=Math.round(Z(s.width,I*_));t._maxSize=Math.max(t._maxSize,C);let N=L.clamp(C,0,ym),T=0;Math.abs(l.magnitudeSquared(a)-1)<L.EPSILON6&&(T=Yi.octEncodeFloat(a)),A=L.clamp(A,0,1),A=A===1?255:A*255|0,N=N*IA+A,f=L.clamp(f,0,1),f=f===1?255:f*255|0,T=T*IA+f,t._instanced?(o=s._index,r(o,N,T,h,d)):(o=s._index*4,r(o+0,N,T,h,d),r(o+1,N,T,h,d),r(o+2,N,T,h,d),r(o+3,N,T,h,d))}function yT(t,e,i,n,s){let o,r=n[an.compressedAttribute2],a=s.color,h=m(t._batchTable)?Zt.WHITE:s.getPickId(e.context).color,A=s.sizeInMeters?1:0,d=Math.abs(l.magnitudeSquared(s.alignedAxis)-1)<L.EPSILON6?1:0;t._allSizedInMeters=t._allSizedInMeters&&A===1;let f=0,E=s._imageIndex;if(E!==-1){let Q=i[E];if(!m(Q))throw new Y(`Invalid billboard image index: ${E}`);f=Q.height}let _=t._textureAtlas.texture.dimensions,R=Math.round(Z(s.height,_.y*f));t._maxSize=Math.max(t._maxSize,R);let I=Z(s._labelHorizontalOrigin,-2);I+=2;let C=R*ny+I,N=Zt.floatToByte(a.red),T=Zt.floatToByte(a.green),F=Zt.floatToByte(a.blue),b=N*ym+T*IA+F;N=Zt.floatToByte(h.red),T=Zt.floatToByte(h.green),F=Zt.floatToByte(h.blue);let G=N*ym+T*IA+F,M=Zt.floatToByte(a.alpha)*ym+Zt.floatToByte(h.alpha)*IA;M+=A*2+d,t._instanced?(o=s._index,r(o,b,G,M,C)):(o=s._index*4,r(o+0,b,G,M,C),r(o+1,b,G,M,C),r(o+2,b,G,M,C),r(o+3,b,G,M,C))}function wT(t,e,i,n,s){let o,r=n[an.eyeOffset],a=s.eyeOffset,h=a.z;if(s._heightReference!==Wr.NONE&&(h*=1.005),t._maxEyeOffset=Math.max(t._maxEyeOffset,Math.abs(a.x),Math.abs(a.y),Math.abs(h)),t._instanced){let A=0,d=0,f=s._imageIndex;if(f!==-1){let _=i[f];if(!m(_))throw new Y(`Invalid billboard image index: ${f}`);A=_.width,d=_.height}kr.x=A,kr.y=d;let E=Yi.compressTextureCoordinates(kr);o=s._index,r(o,a.x,a.y,h,E)}else o=s._index*4,r(o+0,a.x,a.y,h,0),r(o+1,a.x,a.y,h,0),r(o+2,a.x,a.y,h,0),r(o+3,a.x,a.y,h,0)}function cy(t,e,i,n,s){let o,r=n[an.scaleByDistance],a=0,h=1,A=1,d=1,f=s.scaleByDistance;m(f)&&(a=f.near,h=f.nearValue,A=f.far,d=f.farValue,(h!==1||d!==1)&&(t._shaderScaleByDistance=!0)),t._instanced?(o=s._index,r(o,a,h,A,d)):(o=s._index*4,r(o+0,a,h,A,d),r(o+1,a,h,A,d),r(o+2,a,h,A,d),r(o+3,a,h,A,d))}function ly(t,e,i,n,s){let o,r=n[an.pixelOffsetScaleByDistance],a=0,h=1,A=1,d=1,f=s.pixelOffsetScaleByDistance;m(f)&&(a=f.near,h=f.nearValue,A=f.far,d=f.farValue,(h!==1||d!==1)&&(t._shaderPixelOffsetScaleByDistance=!0)),t._instanced?(o=s._index,r(o,a,h,A,d)):(o=s._index*4,r(o+0,a,h,A,d),r(o+1,a,h,A,d),r(o+2,a,h,A,d),r(o+3,a,h,A,d))}function dy(t,e,i,n,s){let o,r=n[an.compressedAttribute3],a=0,h=Number.MAX_VALUE,A=s.distanceDisplayCondition;m(A)&&(a=A.near,h=A.far,a*=a,h*=h,t._shaderDistanceDisplayCondition=!0);let d=s.disableDepthTestDistance,f=gl(s.heightReference)&&e.context.depthTexture;m(d)||(d=f?5e3:0),d*=d,(f||d>0)&&(t._shaderDisableDepthDistance=!0,d===Number.POSITIVE_INFINITY&&(d=-1));let E,_;if(m(s._labelDimensions))_=s._labelDimensions.x,E=s._labelDimensions.y;else{let N=0,T=0,F=s._imageIndex;if(F!==-1){let G=i[F];if(!m(G))throw new Y(`Invalid billboard image index: ${F}`);N=G.height,T=G.width}E=Math.round(Z(s.height,t._textureAtlas.texture.dimensions.y*N));let b=t._textureAtlas.texture.width;_=Math.round(Z(s.width,b*T))}let R=Math.floor(L.clamp(_,0,kT)),I=Math.floor(L.clamp(E,0,kT)),C=R*kT+I;t._instanced?(o=s._index,r(o,a,h,d,C)):(o=s._index*4,r(o+0,a,h,d,C),r(o+1,a,h,d,C),r(o+2,a,h,d,C),r(o+3,a,h,d,C))}function my(t,e,i,n,s){if(gl(s.heightReference)){let R=t._scene,I=e.context,C=e.globeTranslucencyState.translucent,N=m(R.globe)&&R.globe.depthTestAgainstTerrain;t._shaderClampToGround=I.depthTexture&&!C&&N}let o,r=n[an.textureCoordinateBoundsOrLabelTranslate];if(en.maximumVertexTextureImageUnits>0){let R=0,I=0;m(s._labelTranslate)&&(R=s._labelTranslate.x,I=s._labelTranslate.y),t._instanced?(o=s._index,r(o,R,I,0,0)):(o=s._index*4,r(o+0,R,I,0,0),r(o+1,R,I,0,0),r(o+2,R,I,0,0),r(o+3,R,I,0,0));return}let a=0,h=0,A=0,d=0,f=s._imageIndex;if(f!==-1){let R=i[f];if(!m(R))throw new Y(`Invalid billboard image index: ${f}`);a=R.x,h=R.y,A=R.width,d=R.height}let E=a+A,_=h+d;t._instanced?(o=s._index,r(o,a,h,E,_)):(o=s._index*4,r(o+0,a,h,E,_),r(o+1,a,h,E,_),r(o+2,a,h,E,_),r(o+3,a,h,E,_))}function set(t,e,i,n,s){if(!m(t._batchTable))return;let o=n[an.a_batchId],r=s._batchIndex,a;t._instanced?(a=s._index,o(a,r)):(a=s._index*4,o(a+0,r),o(a+1,r),o(a+2,r),o(a+3,r))}function fy(t,e,i,n,s){if(!t._sdf)return;let o,r=n[an.sdf],a=s.outlineColor,h=s.outlineWidth,A=Zt.floatToByte(a.red),d=Zt.floatToByte(a.green),f=Zt.floatToByte(a.blue),E=A*ym+d*IA+f,_=h/po.RADIUS,R=Zt.floatToByte(a.alpha)*ym+Zt.floatToByte(_)*IA;t._instanced?(o=s._index,r(o,E,R)):(o=s._index*4,r(o+0,E+sy,R),r(o+1,E+oy,R),r(o+2,E+ry,R),r(o+3,E+ay,R))}function oet(t,e,i,n,s){iy(t,e,i,n,s),Ay(t,e,i,n,s),hy(t,e,i,n,s),yT(t,e,i,n,s),wT(t,e,i,n,s),cy(t,e,i,n,s),ly(t,e,i,n,s),dy(t,e,i,n,s),my(t,e,i,n,s),set(t,e,i,n,s),fy(t,e,i,n,s)}function LT(t,e,i,n,s,o){let r;n.mode===ye.SCENE3D?(r=t._baseVolume,t._boundingVolumeDirty=!0):r=t._baseVolume2D;let a=[];for(let h=0;h<i;++h){let A=e[h],d=A.position,f=un._computeActualPosition(A,d,n,s);m(f)&&(A._setActualPosition(f),o?a.push(f):Nt.expand(r,f,r))}o&&Nt.fromPoints(a,r)}function ret(t,e){let i=e.mode,n=t._billboards,s=t._billboardsToUpdate,o=t._modelMatrix;t._createVertexArray||t._mode!==i||i!==ye.SCENE3D&&!at.equals(o,t.modelMatrix)?(t._mode=i,at.clone(t.modelMatrix,o),t._createVertexArray=!0,(i===ye.SCENE3D||i===ye.SCENE2D||i===ye.COLUMBUS_VIEW)&&LT(t,n,n.length,e,o,!0)):i===ye.MORPHING?LT(t,n,n.length,e,o,!0):(i===ye.SCENE2D||i===ye.COLUMBUS_VIEW)&&LT(t,s,t._billboardsToUpdateIndex,e,o,!1)}function aet(t,e,i){let n=1;(!t._allSizedInMeters||t._maxPixelOffset!==0)&&(n=e.camera.getPixelSize(i,e.context.drawingBufferWidth,e.context.drawingBufferHeight));let s=n*t._maxScale*t._maxSize*2;t._allHorizontalCenter&&t._allVerticalCenter&&(s*=.5);let o=n*t._maxPixelOffset+t._maxEyeOffset;i.radius+=s+o}function Aet(t,e){let n=e.createViewportQuadCommand(`uniform sampler2D billboard_texture; 
in vec2 v_textureCoordinates; 
void main() 
{ 
    out_FragColor = texture(billboard_texture, v_textureCoordinates); 
} 
`,{uniformMap:{billboard_texture:function(){return t._textureAtlas.texture}}});return n.pass=os.OVERLAY,n}var Ltt,VE,HL,vL,ytt,wtt,xtt,OE,zL,Ptt,Jtt,KL,XL,qL,$L,jtt,Htt,ty,xT,an,vtt,ztt,UT,QT,kr,Qr,ym,kT,IA,tet,eet,iet,ny,net,sy,oy,ry,ay,het,wm,JT=O(()=>{oh();_i();Xe();Ht();ae();Qn();oi();bt();mt();Ws();Vt();Tl();Di();_e();Fi();ss();aI();Nl();ga();Bm();Wm();Mm();Qm();Fl();BT();UL();kL();sI();km();EI();Om();Vm();ua();_I();MT();CE();Ltt=un.SHOW_INDEX,VE=un.POSITION_INDEX,HL=un.PIXEL_OFFSET_INDEX,vL=un.EYE_OFFSET_INDEX,ytt=un.HORIZONTAL_ORIGIN_INDEX,wtt=un.VERTICAL_ORIGIN_INDEX,xtt=un.SCALE_INDEX,OE=un.IMAGE_INDEX_INDEX,zL=un.COLOR_INDEX,Ptt=un.ROTATION_INDEX,Jtt=un.ALIGNED_AXIS_INDEX,KL=un.SCALE_BY_DISTANCE_INDEX,XL=un.TRANSLUCENCY_BY_DISTANCE_INDEX,qL=un.PIXEL_OFFSET_SCALE_BY_DISTANCE_INDEX,$L=un.DISTANCE_DISPLAY_CONDITION,jtt=un.DISABLE_DEPTH_DISTANCE,Htt=un.TEXTURE_COORDINATE_BOUNDS,ty=un.SDF_INDEX,xT=un.NUMBER_OF_PROPERTIES,vtt={positionHighAndScale:0,positionLowAndRotation:1,compressedAttribute0:2,compressedAttribute1:3,compressedAttribute2:4,eyeOffset:5,scaleByDistance:6,pixelOffsetScaleByDistance:7,compressedAttribute3:8,textureCoordinateBoundsOrLabelTranslate:9,a_batchId:10,sdf:11},ztt={direction:0,positionHighAndScale:1,positionLowAndRotation:2,compressedAttribute0:3,compressedAttribute1:4,compressedAttribute2:5,eyeOffset:6,scaleByDistance:7,pixelOffsetScaleByDistance:8,compressedAttribute3:9,textureCoordinateBoundsOrLabelTranslate:10,a_batchId:11,sdf:12};Object.defineProperties(Lr.prototype,{length:{get:function(){return PT(this),this._billboards.length}},textureAtlas:{get:function(){return this._textureAtlas},set:function(t){this._textureAtlas!==t&&(this._textureAtlas=this._destroyTextureAtlas&&this._textureAtlas&&this._textureAtlas.destroy(),this._textureAtlas=t,this._createVertexArray=!0)}},destroyTextureAtlas:{get:function(){return this._destroyTextureAtlas},set:function(t){this._destroyTextureAtlas=t}}});Lr.prototype.add=function(t){let e=new un(t,this);return e._index=this._billboards.length,this._billboards.push(e),this._createVertexArray=!0,e};Lr.prototype.remove=function(t){return this.contains(t)?(this._billboards[t._index]=void 0,this._billboardsRemoved=!0,this._createVertexArray=!0,t._destroy(),!0):!1};Lr.prototype.removeAll=function(){ey(this._billboards),this._billboards=[],this._billboardsToUpdate=[],this._billboardsToUpdateIndex=0,this._billboardsRemoved=!1,this._createVertexArray=!0};Lr.prototype._updateBillboard=function(t,e){t._dirty||(this._billboardsToUpdate[this._billboardsToUpdateIndex++]=t),++this._propertiesChanged[e]};Lr.prototype.contains=function(t){return m(t)&&t._billboardCollection===this};Lr.prototype.get=function(t){return p.typeOf.number("index",t),PT(this),this._billboards[t]};Lr.prototype.computeNewBuffersUsage=function(){let t=this._buffersUsage,e=!1,i=this._propertiesChanged;for(let n=0;n<xT;++n){let s=i[n]===0?ai.STATIC_DRAW:ai.STREAM_DRAW;e=e||t[n]!==s,t[n]=s}return e};QT=new Bn;kr=new nt,Qr=32768,ym=65536,kT=4096,IA=256,tet=128,eet=32,iet=8,ny=4,net=1/256,sy=0,oy=2,ry=3,ay=1;het=[];Lr.prototype.update=function(t){if(PT(this),!this.show)return;let e=this._billboards,i=e.length,n=t.context;this._instanced=n.instancedArrays,an=this._instanced?ztt:vtt,UT=this._instanced?Xtt:Ktt;let s=this._textureAtlas;if(!m(s)){s=this._textureAtlas=new SE({context:n});for(let U=0;U<i;++U)e[U]._loadImage()}let o=s.textureCoordinates;if(o.length===0)return;ret(this,t),e=this._billboards,i=e.length;let r=this._billboardsToUpdate,a=this._billboardsToUpdateIndex,h=this._propertiesChanged,A=s.guid,d=this._createVertexArray||this._textureAtlasGUID!==A;this._textureAtlasGUID=A;let f,E=t.passes,_=E.pick;if(d||!_&&this.computeNewBuffersUsage()){this._createVertexArray=!1;for(let U=0;U<xT;++U)h[U]=0;if(this._vaf=this._vaf&&this._vaf.destroy(),i>0){this._vaf=$tt(n,i,this._buffersUsage,this._instanced,this._batchTable,this._sdf),f=this._vaf.writers;for(let U=0;U<i;++U){let k=this._billboards[U];k._dirty=!1,oet(this,t,o,f,k)}this._vaf.commit(UT(n))}this._billboardsToUpdateIndex=0}else if(a>0){let U=het;U.length=0,(h[VE]||h[Ptt]||h[xtt])&&U.push(iy),(h[OE]||h[HL]||h[ytt]||h[wtt]||h[Ltt])&&(U.push(Ay),this._instanced&&U.push(wT)),(h[OE]||h[Jtt]||h[XL])&&(U.push(hy),U.push(yT)),(h[OE]||h[zL])&&U.push(yT),h[vL]&&U.push(wT),h[KL]&&U.push(cy),h[qL]&&U.push(ly),(h[$L]||h[jtt]||h[OE]||h[VE])&&U.push(dy),(h[OE]||h[VE])&&U.push(my),h[ty]&&U.push(fy);let k=U.length;if(f=this._vaf.writers,a/i>.1){for(let y=0;y<a;++y){let c=r[y];c._dirty=!1;for(let g=0;g<k;++g)U[g](this,t,o,f,c)}this._vaf.commit(UT(n))}else{for(let y=0;y<a;++y){let c=r[y];c._dirty=!1;for(let g=0;g<k;++g)U[g](this,t,o,f,c);this._instanced?this._vaf.subCommit(c._index,1):this._vaf.subCommit(c._index*4,4)}this._vaf.endSubCommits()}this._billboardsToUpdateIndex=0}if(a>i*1.5&&(r.length=i),!m(this._vaf)||!m(this._vaf.va))return;this._boundingVolumeDirty&&(this._boundingVolumeDirty=!1,Nt.transform(this._baseVolume,this.modelMatrix,this._baseVolumeWC));let R,I=at.IDENTITY;t.mode===ye.SCENE3D?(I=this.modelMatrix,R=Nt.clone(this._baseVolumeWC,this._boundingVolume)):R=Nt.clone(this._baseVolume2D,this._boundingVolume),aet(this,t,R);let C=this._blendOption!==this.blendOption;if(this._blendOption=this.blendOption,C){this._blendOption===Wn.OPAQUE||this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT?this._rsOpaque=Yn.fromCache({depthTest:{enabled:!0,func:it.LESS},depthMask:!0}):this._rsOpaque=void 0;let U=this._blendOption===Wn.TRANSLUCENT;this._blendOption===Wn.TRANSLUCENT||this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT?this._rsTranslucent=Yn.fromCache({depthTest:{enabled:!0,func:U?it.LEQUAL:it.LESS},depthMask:U,blending:Ur.ALPHA_BLEND}):this._rsTranslucent=void 0}this._shaderDisableDepthDistance=this._shaderDisableDepthDistance||t.minimumDisableDepthTestDistance!==0;let N,T,F,b,G,M=en.maximumVertexTextureImageUnits>0;if(C||this._shaderRotation!==this._compiledShaderRotation||this._shaderAlignedAxis!==this._compiledShaderAlignedAxis||this._shaderScaleByDistance!==this._compiledShaderScaleByDistance||this._shaderTranslucencyByDistance!==this._compiledShaderTranslucencyByDistance||this._shaderPixelOffsetScaleByDistance!==this._compiledShaderPixelOffsetScaleByDistance||this._shaderDistanceDisplayCondition!==this._compiledShaderDistanceDisplayCondition||this._shaderDisableDepthDistance!==this._compiledShaderDisableDepthDistance||this._shaderClampToGround!==this._compiledShaderClampToGround||this._sdf!==this._compiledSDF){N=QL,T=ML,G=[],m(this._batchTable)&&(G.push("VECTOR_TILE"),N=this._batchTable.getVertexShaderCallback(!1,"a_batchId",void 0)(N),T=this._batchTable.getFragmentShaderCallback(!1,void 0)(T)),F=new Mi({defines:G,sources:[N]}),this._instanced&&F.defines.push("INSTANCED"),this._shaderRotation&&F.defines.push("ROTATION"),this._shaderAlignedAxis&&F.defines.push("ALIGNED_AXIS"),this._shaderScaleByDistance&&F.defines.push("EYE_DISTANCE_SCALING"),this._shaderTranslucencyByDistance&&F.defines.push("EYE_DISTANCE_TRANSLUCENCY"),this._shaderPixelOffsetScaleByDistance&&F.defines.push("EYE_DISTANCE_PIXEL_OFFSET"),this._shaderDistanceDisplayCondition&&F.defines.push("DISTANCE_DISPLAY_CONDITION"),this._shaderDisableDepthDistance&&F.defines.push("DISABLE_DEPTH_DISTANCE"),this._shaderClampToGround&&(M?F.defines.push("VERTEX_DEPTH_CHECK"):F.defines.push("FRAGMENT_DEPTH_CHECK"));let U=1-po.CUTOFF;this._sdf&&F.defines.push("SDF");let k=m(this._batchTable)?"VECTOR_TILE":"";this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT&&(b=new Mi({defines:["OPAQUE",k],sources:[T]}),this._shaderClampToGround&&(M?b.defines.push("VERTEX_DEPTH_CHECK"):b.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(b.defines.push("SDF"),b.defines.push(`SDF_EDGE ${U}`)),this._sp=Es.replaceCache({context:n,shaderProgram:this._sp,vertexShaderSource:F,fragmentShaderSource:b,attributeLocations:an}),b=new Mi({defines:["TRANSLUCENT",k],sources:[T]}),this._shaderClampToGround&&(M?b.defines.push("VERTEX_DEPTH_CHECK"):b.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(b.defines.push("SDF"),b.defines.push(`SDF_EDGE ${U}`)),this._spTranslucent=Es.replaceCache({context:n,shaderProgram:this._spTranslucent,vertexShaderSource:F,fragmentShaderSource:b,attributeLocations:an})),this._blendOption===Wn.OPAQUE&&(b=new Mi({defines:[k],sources:[T]}),this._shaderClampToGround&&(M?b.defines.push("VERTEX_DEPTH_CHECK"):b.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(b.defines.push("SDF"),b.defines.push(`SDF_EDGE ${U}`)),this._sp=Es.replaceCache({context:n,shaderProgram:this._sp,vertexShaderSource:F,fragmentShaderSource:b,attributeLocations:an})),this._blendOption===Wn.TRANSLUCENT&&(b=new Mi({defines:[k],sources:[T]}),this._shaderClampToGround&&(M?b.defines.push("VERTEX_DEPTH_CHECK"):b.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(b.defines.push("SDF"),b.defines.push(`SDF_EDGE ${U}`)),this._spTranslucent=Es.replaceCache({context:n,shaderProgram:this._spTranslucent,vertexShaderSource:F,fragmentShaderSource:b,attributeLocations:an})),this._compiledShaderRotation=this._shaderRotation,this._compiledShaderAlignedAxis=this._shaderAlignedAxis,this._compiledShaderScaleByDistance=this._shaderScaleByDistance,this._compiledShaderTranslucencyByDistance=this._shaderTranslucencyByDistance,this._compiledShaderPixelOffsetScaleByDistance=this._shaderPixelOffsetScaleByDistance,this._compiledShaderDistanceDisplayCondition=this._shaderDistanceDisplayCondition,this._compiledShaderDisableDepthDistance=this._shaderDisableDepthDistance,this._compiledShaderClampToGround=this._shaderClampToGround,this._compiledSDF=this._sdf}let Q=t.commandList;if(E.render||E.pick){let U=this._colorCommands,k=this._blendOption===Wn.OPAQUE,y=this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT,c=this._vaf.va,g=c.length,V=this._uniforms,D;m(this._batchTable)?(V=this._batchTable.getUniformMapCallback()(V),D=this._batchTable.getPickId()):D="v_pickColor",U.length=g;let w=y?g*2:g;for(let x=0;x<w;++x){let H=U[x];m(H)||(H=U[x]=new fn);let j=k||y&&x%2===0;H.pass=j||!y?os.OPAQUE:os.TRANSLUCENT,H.owner=this;let X=y?Math.floor(x/2):x;H.boundingVolume=R,H.modelMatrix=I,H.count=c[X].indicesCount,H.shaderProgram=j?this._sp:this._spTranslucent,H.uniformMap=V,H.vertexArray=c[X].va,H.renderState=j?this._rsOpaque:this._rsTranslucent,H.debugShowBoundingVolume=this.debugShowBoundingVolume,H.pickId=D,this._instanced&&(H.count=6,H.instanceCount=i),Q.push(H)}this.debugShowTextureAtlas&&(m(this.debugCommand)||(this.debugCommand=Aet(this,t.context)),Q.push(this.debugCommand))}};Lr.prototype.isDestroyed=function(){return!1};Lr.prototype.destroy=function(){return m(this._removeCallbackFunc)&&(this._removeCallbackFunc(),this._removeCallbackFunc=void 0),this._textureAtlas=this._destroyTextureAtlas&&this._textureAtlas&&this._textureAtlas.destroy(),this._sp=this._sp&&this._sp.destroy(),this._spTranslucent=this._spTranslucent&&this._spTranslucent.destroy(),this._vaf=this._vaf&&this._vaf.destroy(),ey(this._billboards),li(this)};wm=Lr});var cet,Ya,jT=O(()=>{cet={FILL:0,OUTLINE:1,FILL_AND_OUTLINE:2},Ya=Object.freeze(cet)});function Ol(t){!t._rebindAllGlyphs&&!t._repositionAllGlyphs&&t._labelCollection._labelsToUpdate.push(t),t._rebindAllGlyphs=!0}function GE(t){!t._rebindAllGlyphs&&!t._repositionAllGlyphs&&t._labelCollection._labelsToUpdate.push(t),t._repositionAllGlyphs=!0}function BE(t,e){return document.defaultView.getComputedStyle(t,null).getPropertyValue(e)}function Zy(t){let e=Ey[t._font];if(!m(e)){let i=document.createElement("div");i.style.position="absolute",i.style.opacity=0,i.style.font=t._font,document.body.appendChild(i);let n=parseFloat(BE(i,"line-height"));isNaN(n)&&(n=void 0),e={family:BE(i,"font-family"),size:BE(i,"font-size").replace("px",""),style:BE(i,"font-style"),weight:BE(i,"font-weight"),lineHeight:n},document.body.removeChild(i),_y<det&&(Ey[t._font]=e,_y++)}t._fontFamily=e.family,t._fontSize=e.size,t._fontStyle=e.style,t._fontWeight=e.weight,t._lineHeight=e.lineHeight}function lh(t,e){if(t=Z(t,Z.EMPTY_OBJECT),m(t.disableDepthTestDistance)&&t.disableDepthTestDistance<0)throw new Y("disableDepthTestDistance must be greater than 0.0.");let i=t.translucencyByDistance,n=t.pixelOffsetScaleByDistance,s=t.scaleByDistance,o=t.distanceDisplayCondition;if(m(i)){if(i.far<=i.near)throw new Y("translucencyByDistance.far must be greater than translucencyByDistance.near.");i=gi.clone(i)}if(m(n)){if(n.far<=n.near)throw new Y("pixelOffsetScaleByDistance.far must be greater than pixelOffsetScaleByDistance.near.");n=gi.clone(n)}if(m(s)){if(s.far<=s.near)throw new Y("scaleByDistance.far must be greater than scaleByDistance.near.");s=gi.clone(s)}if(m(o)){if(o.far<=o.near)throw new Y("distanceDisplayCondition.far must be greater than distanceDisplayCondition.near.");o=Wo.clone(o)}this._renderedText=void 0,this._text=void 0,this._show=Z(t.show,!0),this._font=Z(t.font,"30px sans-serif"),this._fillColor=Zt.clone(Z(t.fillColor,Zt.WHITE)),this._outlineColor=Zt.clone(Z(t.outlineColor,Zt.BLACK)),this._outlineWidth=Z(t.outlineWidth,1),this._showBackground=Z(t.showBackground,!1),this._backgroundColor=Zt.clone(Z(t.backgroundColor,met)),this._backgroundPadding=nt.clone(Z(t.backgroundPadding,fet)),this._style=Z(t.style,Ya.FILL),this._verticalOrigin=Z(t.verticalOrigin,mn.BASELINE),this._horizontalOrigin=Z(t.horizontalOrigin,to.LEFT),this._pixelOffset=nt.clone(Z(t.pixelOffset,nt.ZERO)),this._eyeOffset=l.clone(Z(t.eyeOffset,l.ZERO)),this._position=l.clone(Z(t.position,l.ZERO)),this._scale=Z(t.scale,1),this._id=t.id,this._translucencyByDistance=i,this._pixelOffsetScaleByDistance=n,this._scaleByDistance=s,this._heightReference=Z(t.heightReference,Wr.NONE),this._distanceDisplayCondition=o,this._disableDepthTestDistance=t.disableDepthTestDistance,this._labelCollection=e,this._glyphs=[],this._backgroundBillboard=void 0,this._batchIndex=void 0,this._rebindAllGlyphs=!0,this._repositionAllGlyphs=!0,this._actualClampedPosition=void 0,this._removeCallbackFunc=void 0,this._mode=void 0,this._clusterShow=!0,this.text=Z(t.text,""),this._relativeSize=1,Zy(this),this._updateClamping()}function Eet(t,e){let i=/[a-zA-Z0-9]/,n=/[()[\]{}<>]/,s=[],o="",r=Rs.LTR,a="",h=t.length;for(let A=0;A<h;++A){let d=t.charAt(A);e.test(d)?a=Rs.RTL:i.test(d)?a=Rs.LTR:n.test(d)?a=Rs.BRACKETS:a=Rs.WEAK,A===0&&(r=a),r===a&&a!==Rs.BRACKETS?o+=d:(o!==""&&s.push({Type:r,Word:o}),r=a,o=d)}return s.push({Type:a,Word:o}),s}function _et(t){return t.split("").reverse().join("")}function WE(t,e,i){return t.slice(0,e)+i+t.slice(e)}function Ret(t){switch(t){case"(":return")";case")":return"(";case"[":return"]";case"]":return"[";case"{":return"}";case"}":return"{";case"<":return">";case">":return"<"}}function pet(t){let e=t.split(`
`),i="";for(let n=0;n<e.length;n++){let s=e[n],o=Ry.test(s.charAt(0)),r=Eet(s,Ry),a=0,h="";for(let A=0;A<r.length;++A){let d=r[A],f=d.Type===Rs.BRACKETS?Ret(d.Word):_et(d.Word);o?d.Type===Rs.RTL?(h=f+h,a=0):d.Type===Rs.LTR?(h=WE(h,a,d.Word),a+=d.Word.length):(d.Type===Rs.WEAK||d.Type===Rs.BRACKETS)&&(d.Type===Rs.WEAK&&r[A-1].Type===Rs.BRACKETS?h=f+h:r[A-1].Type===Rs.RTL?(h=f+h,a=0):r.length>A+1?r[A+1].Type===Rs.RTL?(h=f+h,a=0):(h=WE(h,a,d.Word),a+=d.Word.length):h=WE(h,0,f)):d.Type===Rs.RTL?h=WE(h,a,f):d.Type===Rs.LTR?(h+=d.Word,a=h.length):(d.Type===Rs.WEAK||d.Type===Rs.BRACKETS)&&(A>0&&r[A-1].Type===Rs.RTL?r.length>A+1?r[A+1].Type===Rs.RTL?h=WE(h,a,f):(h+=d.Word,a=h.length):h+=d.Word:(h+=d.Word,a=h.length))}i+=h,n<e.length-1&&(i+=`
`)}return i}var Ey,_y,det,met,fet,Rs,Zet,Iet,Ry,DE,HT=O(()=>{Er();Xe();Ht();Qn();bt();mt();Vt();zZ();IE();sI();Om();Vm();jT();_I();CE();Ey={},_y=0,det=256,met=new Zt(.165,.165,.165,.8),fet=new nt(7,5),Rs=Object.freeze({LTR:0,RTL:1,WEAK:2,BRACKETS:3});Object.defineProperties(lh.prototype,{show:{get:function(){return this._show},set:function(t){if(!m(t))throw new Y("value is required.");if(this._show!==t){this._show=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n].billboard;m(o)&&(o.show=t)}let i=this._backgroundBillboard;m(i)&&(i.show=t)}}},position:{get:function(){return this._position},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._position;if(!l.equals(e,t)){l.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s].billboard;m(r)&&(r.position=t)}let n=this._backgroundBillboard;m(n)&&(n.position=t),this._updateClamping()}}},heightReference:{get:function(){return this._heightReference},set:function(t){if(!m(t))throw new Y("value is required.");if(t!==this._heightReference){this._heightReference=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n].billboard;m(o)&&(o.heightReference=t)}let i=this._backgroundBillboard;m(i)&&(i.heightReference=t),GE(this),this._updateClamping()}}},text:{get:function(){return this._text},set:function(t){if(!m(t))throw new Y("value is required.");if(this._text!==t){this._text=t;let e=t.replace(/\u00ad/g,"");this._renderedText=lh.enableRightToLeftDetection?pet(e):e,Ol(this)}}},font:{get:function(){return this._font},set:function(t){if(!m(t))throw new Y("value is required.");this._font!==t&&(this._font=t,Ol(this),Zy(this))}},fillColor:{get:function(){return this._fillColor},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._fillColor;Zt.equals(e,t)||(Zt.clone(t,e),Ol(this))}},outlineColor:{get:function(){return this._outlineColor},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._outlineColor;Zt.equals(e,t)||(Zt.clone(t,e),Ol(this))}},outlineWidth:{get:function(){return this._outlineWidth},set:function(t){if(!m(t))throw new Y("value is required.");this._outlineWidth!==t&&(this._outlineWidth=t,Ol(this))}},showBackground:{get:function(){return this._showBackground},set:function(t){if(!m(t))throw new Y("value is required.");this._showBackground!==t&&(this._showBackground=t,Ol(this))}},backgroundColor:{get:function(){return this._backgroundColor},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._backgroundColor;if(!Zt.equals(e,t)){Zt.clone(t,e);let i=this._backgroundBillboard;m(i)&&(i.color=e)}}},backgroundPadding:{get:function(){return this._backgroundPadding},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._backgroundPadding;nt.equals(e,t)||(nt.clone(t,e),GE(this))}},style:{get:function(){return this._style},set:function(t){if(!m(t))throw new Y("value is required.");this._style!==t&&(this._style=t,Ol(this))}},pixelOffset:{get:function(){return this._pixelOffset},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._pixelOffset;if(!nt.equals(e,t)){nt.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s];m(r.billboard)&&(r.billboard.pixelOffset=t)}let n=this._backgroundBillboard;m(n)&&(n.pixelOffset=t)}}},translucencyByDistance:{get:function(){return this._translucencyByDistance},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far distance must be greater than near distance.");let e=this._translucencyByDistance;if(!gi.equals(e,t)){this._translucencyByDistance=gi.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s];m(r.billboard)&&(r.billboard.translucencyByDistance=t)}let n=this._backgroundBillboard;m(n)&&(n.translucencyByDistance=t)}}},pixelOffsetScaleByDistance:{get:function(){return this._pixelOffsetScaleByDistance},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far distance must be greater than near distance.");let e=this._pixelOffsetScaleByDistance;if(!gi.equals(e,t)){this._pixelOffsetScaleByDistance=gi.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s];m(r.billboard)&&(r.billboard.pixelOffsetScaleByDistance=t)}let n=this._backgroundBillboard;m(n)&&(n.pixelOffsetScaleByDistance=t)}}},scaleByDistance:{get:function(){return this._scaleByDistance},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far distance must be greater than near distance.");let e=this._scaleByDistance;if(!gi.equals(e,t)){this._scaleByDistance=gi.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s];m(r.billboard)&&(r.billboard.scaleByDistance=t)}let n=this._backgroundBillboard;m(n)&&(n.scaleByDistance=t)}}},eyeOffset:{get:function(){return this._eyeOffset},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._eyeOffset;if(!l.equals(e,t)){l.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s];m(r.billboard)&&(r.billboard.eyeOffset=t)}let n=this._backgroundBillboard;m(n)&&(n.eyeOffset=t)}}},horizontalOrigin:{get:function(){return this._horizontalOrigin},set:function(t){if(!m(t))throw new Y("value is required.");this._horizontalOrigin!==t&&(this._horizontalOrigin=t,GE(this))}},verticalOrigin:{get:function(){return this._verticalOrigin},set:function(t){if(!m(t))throw new Y("value is required.");if(this._verticalOrigin!==t){this._verticalOrigin=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.verticalOrigin=t)}let i=this._backgroundBillboard;m(i)&&(i.verticalOrigin=t),GE(this)}}},scale:{get:function(){return this._scale},set:function(t){if(!m(t))throw new Y("value is required.");if(this._scale!==t){this._scale=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.scale=t*this._relativeSize)}let i=this._backgroundBillboard;m(i)&&(i.scale=t*this._relativeSize),GE(this)}}},totalScale:{get:function(){return this._scale*this._relativeSize}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far must be greater than near");if(!Wo.equals(t,this._distanceDisplayCondition)){this._distanceDisplayCondition=Wo.clone(t,this._distanceDisplayCondition);let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.distanceDisplayCondition=t)}let i=this._backgroundBillboard;m(i)&&(i.distanceDisplayCondition=t)}}},disableDepthTestDistance:{get:function(){return this._disableDepthTestDistance},set:function(t){if(this._disableDepthTestDistance!==t){if(m(t)&&t<0)throw new Y("disableDepthTestDistance must be greater than 0.0.");this._disableDepthTestDistance=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.disableDepthTestDistance=t)}let i=this._backgroundBillboard;m(i)&&(i.disableDepthTestDistance=t)}}},id:{get:function(){return this._id},set:function(t){if(this._id!==t){this._id=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.id=t)}let i=this._backgroundBillboard;m(i)&&(i.id=t)}}},pickId:{get:function(){if(!(this._glyphs.length===0||!m(this._glyphs[0].billboard)))return this._glyphs[0].billboard.pickId}},_clampedPosition:{get:function(){return this._actualClampedPosition},set:function(t){this._actualClampedPosition=l.clone(t,this._actualClampedPosition);let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard._clampedPosition=t)}let i=this._backgroundBillboard;m(i)&&(i._clampedPosition=t)}},clusterShow:{get:function(){return this._clusterShow},set:function(t){if(this._clusterShow!==t){this._clusterShow=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.clusterShow=t)}let i=this._backgroundBillboard;m(i)&&(i.clusterShow=t)}}}});lh.prototype._updateClamping=function(){un._updateClamping(this._labelCollection,this)};lh.prototype.computeScreenSpacePosition=function(t,e){if(!m(t))throw new Y("scene is required.");m(e)||(e=new nt);let n=this._labelCollection.modelMatrix,s=m(this._actualClampedPosition)?this._actualClampedPosition:this._position;return un._computeScreenSpacePosition(n,s,this._eyeOffset,this._pixelOffset,t,e)};lh.getScreenSpaceBoundingBox=function(t,e,i){let n=0,s=0,o=0,r=0,a=t.totalScale,h=t._backgroundBillboard;if(m(h))n=e.x+h._translate.x,s=e.y-h._translate.y,o=h.width*a,r=h.height*a,t.verticalOrigin===mn.BOTTOM||t.verticalOrigin===mn.BASELINE?s-=r:t.verticalOrigin===mn.CENTER&&(s-=r*.5);else{n=Number.POSITIVE_INFINITY,s=Number.POSITIVE_INFINITY;let A=0,d=0,f=t._glyphs,E=f.length;for(let _=0;_<E;++_){let R=f[_],I=R.billboard;if(!m(I))continue;let C=e.x+I._translate.x,N=e.y-I._translate.y,T=R.dimensions.width*a,F=R.dimensions.height*a;t.verticalOrigin===mn.BOTTOM||t.verticalOrigin===mn.BASELINE?N-=F:t.verticalOrigin===mn.CENTER&&(N-=F*.5),t._verticalOrigin===mn.TOP?N+=po.PADDING*a:(t._verticalOrigin===mn.BOTTOM||t._verticalOrigin===mn.BASELINE)&&(N-=po.PADDING*a),n=Math.min(n,C),s=Math.min(s,N),A=Math.max(A,C+T),d=Math.max(d,N+F)}o=A-n,r=d-s}return m(i)||(i=new mi),i.x=n,i.y=s,i.width=o,i.height=r,i};lh.prototype.equals=function(t){return this===t||m(t)&&this._show===t._show&&this._scale===t._scale&&this._outlineWidth===t._outlineWidth&&this._showBackground===t._showBackground&&this._style===t._style&&this._verticalOrigin===t._verticalOrigin&&this._horizontalOrigin===t._horizontalOrigin&&this._heightReference===t._heightReference&&this._renderedText===t._renderedText&&this._font===t._font&&l.equals(this._position,t._position)&&Zt.equals(this._fillColor,t._fillColor)&&Zt.equals(this._outlineColor,t._outlineColor)&&Zt.equals(this._backgroundColor,t._backgroundColor)&&nt.equals(this._backgroundPadding,t._backgroundPadding)&&nt.equals(this._pixelOffset,t._pixelOffset)&&l.equals(this._eyeOffset,t._eyeOffset)&&gi.equals(this._translucencyByDistance,t._translucencyByDistance)&&gi.equals(this._pixelOffsetScaleByDistance,t._pixelOffsetScaleByDistance)&&gi.equals(this._scaleByDistance,t._scaleByDistance)&&Wo.equals(this._distanceDisplayCondition,t._distanceDisplayCondition)&&this._disableDepthTestDistance===t._disableDepthTestDistance&&this._id===t._id};lh.prototype.isDestroyed=function(){return!1};lh.enableRightToLeftDetection=!1;Zet="\u05D0-\u05EA",Iet="\u0600-\u06FF\u0750-\u077F\u08A0-\u08FF",Ry=new RegExp(`[${Zet}${Iet}]`);DE=lh});function uet(t,e,i,n,s){let o=t.measureText(e);if(!!/\S/.test(e)){let a=document.defaultView.getComputedStyle(t.canvas).getPropertyValue("font-size").replace("px",""),h=document.createElement("canvas"),A=100,d=o.width+A|0,f=3*a,E=f/2;h.width=d,h.height=f;let _=h.getContext("2d");_.font=i,_.fillStyle="white",_.fillRect(0,0,h.width+1,h.height+1),n&&(_.strokeStyle="black",_.lineWidth=t.lineWidth,_.strokeText(e,A/2,E)),s&&(_.fillStyle="black",_.fillText(e,A/2,E));let R=_.getImageData(0,0,d,f).data,I=R.length,C=d*4,N,T,F,b;for(N=0;N<I;++N)if(R[N]!==255){F=N/C|0;break}for(N=I-1;N>=0;--N)if(R[N]!==255){b=N/C|0;break}let G=-1;for(N=0;N<d&&G===-1;++N)for(T=0;T<f;++T){let M=N*4+T*C;if(R[M]!==255||R[M+1]!==255||R[M+2]!==255||R[M+3]!==255){G=N;break}}return{width:o.width,height:b-F,ascent:E-F,descent:b-E,minx:G-A/2}}return{width:o.width,height:0,ascent:0,descent:0,minx:0}}function Cet(t,e){if(!m(t))throw new Y("text is required.");if(t==="")return;e=Z(e,Z.EMPTY_OBJECT);let i=Z(e.font,"10px sans-serif"),n=Z(e.stroke,!1),s=Z(e.fill,!0),o=Z(e.strokeWidth,1),r=Z(e.backgroundColor,Zt.TRANSPARENT),a=Z(e.padding,0),h=a*2,A=document.createElement("canvas");A.width=1,A.height=1,A.style.font=i;let d=A.getContext("2d",{willReadFrequently:!0});m(Vl)||(m(d.imageSmoothingEnabled)?Vl="imageSmoothingEnabled":m(d.mozImageSmoothingEnabled)?Vl="mozImageSmoothingEnabled":m(d.webkitImageSmoothingEnabled)?Vl="webkitImageSmoothingEnabled":m(d.msImageSmoothingEnabled)&&(Vl="msImageSmoothingEnabled")),d.font=i,d.lineJoin="round",d.lineWidth=o,d[Vl]=!1,A.style.visibility="hidden",document.body.appendChild(A);let f=uet(d,t,i,n,s);A.dimensions=f,document.body.removeChild(A),A.style.visibility="";let E=-f.minx,_=Math.ceil(f.width)+E+h,R=f.height+h,I=R-f.ascent+a,C=R-I+h;if(A.width=_,A.height=R,d.font=i,d.lineJoin="round",d.lineWidth=o,d[Vl]=!1,r!==Zt.TRANSPARENT&&(d.fillStyle=r.toCssColorString(),d.fillRect(0,0,A.width,A.height)),n){let N=Z(e.strokeColor,Zt.BLACK);d.strokeStyle=N.toCssColorString(),d.strokeText(t,E+a,C)}if(s){let N=Z(e.fillColor,Zt.WHITE);d.fillStyle=N.toCssColorString(),d.fillText(t,E+a,C)}return A}var Vl,Iy,py=O(()=>{Qn();bt();mt();Vt();Iy=Cet});var Ty=ts((eMt,gy)=>{"use strict";gy.exports=get;var ME=1e20;function get(t,e){e||(e={});var i=e.cutoff==null?.25:e.cutoff,n=e.radius==null?8:e.radius,s=e.channel||0,o,r,a,h,A,d,f,E,_,R,I;if(ArrayBuffer.isView(t)||Array.isArray(t)){if(!e.width||!e.height)throw Error("For raw data width and height should be provided by options");o=e.width,r=e.height,h=t,e.stride?d=e.stride:d=Math.floor(t.length/o/r)}else window.HTMLCanvasElement&&t instanceof window.HTMLCanvasElement?(E=t,f=E.getContext("2d"),o=E.width,r=E.height,_=f.getImageData(0,0,o,r),h=_.data,d=4):window.CanvasRenderingContext2D&&t instanceof window.CanvasRenderingContext2D?(E=t.canvas,f=t,o=E.width,r=E.height,_=f.getImageData(0,0,o,r),h=_.data,d=4):window.ImageData&&t instanceof window.ImageData&&(_=t,o=t.width,r=t.height,h=_.data,d=4);if(a=Math.max(o,r),window.Uint8ClampedArray&&h instanceof window.Uint8ClampedArray||window.Uint8Array&&h instanceof window.Uint8Array)for(A=h,h=Array(o*r),R=0,I=Math.floor(A.length/d);R<I;R++)h[R]=A[R*d+s]/255;else if(d!==1)throw Error("Raw data can have only 1 value per pixel");var C=Array(o*r),N=Array(o*r),T=Array(a),F=Array(a),b=Array(a+1),G=Array(a);for(R=0,I=o*r;R<I;R++){var M=h[R];C[R]=M===1?0:M===0?ME:Math.pow(Math.max(0,.5-M),2),N[R]=M===1?ME:M===0?0:Math.pow(Math.max(0,M-.5),2)}uy(C,o,r,T,F,G,b),uy(N,o,r,T,F,G,b);var Q=window.Float32Array?new Float32Array(o*r):new Array(o*r);for(R=0,I=o*r;R<I;R++)Q[R]=Math.min(Math.max(1-((C[R]-N[R])/n+i),0),1);return Q}function uy(t,e,i,n,s,o,r){for(var a=0;a<e;a++){for(var h=0;h<i;h++)n[h]=t[h*e+a];for(Cy(n,s,o,r,i),h=0;h<i;h++)t[h*e+a]=s[h]}for(h=0;h<i;h++){for(a=0;a<e;a++)n[a]=t[h*e+a];for(Cy(n,s,o,r,e),a=0;a<e;a++)t[h*e+a]=Math.sqrt(s[a])}}function Cy(t,e,i,n,s){i[0]=0,n[0]=-ME,n[1]=+ME;for(var o=1,r=0;o<s;o++){for(var a=(t[o]+o*o-(t[i[r]]+i[r]*i[r]))/(2*o-2*i[r]);a<=n[r];)r--,a=(t[o]+o*o-(t[i[r]]+i[r]*i[r]))/(2*o-2*i[r]);r++,i[r]=o,n[r]=a,n[r+1]=+ME}for(o=0,r=0;o<s;o++){for(;n[r+1]<o;)r++;e[o]=(o-i[r])*(o-i[r])+t[i[r]]}}});var Ny=ts((iMt,gI)=>{function Tet(){var t=0,e=1,i=2,n=3,s=4,o=5,r=6,a=7,h=8,A=9,d=10,f=11,E=12,_=13,R=14,I=15,C=16,N=17,T=0,F=1,b=2,G=3,M=4;function Q(c,g){return 55296<=c.charCodeAt(g)&&c.charCodeAt(g)<=56319&&56320<=c.charCodeAt(g+1)&&c.charCodeAt(g+1)<=57343}function U(c,g){g===void 0&&(g=0);var V=c.charCodeAt(g);if(55296<=V&&V<=56319&&g<c.length-1){var D=V,w=c.charCodeAt(g+1);return 56320<=w&&w<=57343?(D-55296)*1024+(w-56320)+65536:D}if(56320<=V&&V<=57343&&g>=1){var D=c.charCodeAt(g-1),w=V;return 55296<=D&&D<=56319?(D-55296)*1024+(w-56320)+65536:w}return V}function k(c,g,V){var D=[c].concat(g).concat([V]),w=D[D.length-2],x=V,H=D.lastIndexOf(R);if(H>1&&D.slice(1,H).every(function(tt){return tt==n})&&[n,_,N].indexOf(c)==-1)return b;var j=D.lastIndexOf(s);if(j>0&&D.slice(1,j).every(function(tt){return tt==s})&&[E,s].indexOf(w)==-1)return D.filter(function(tt){return tt==s}).length%2==1?G:M;if(w==t&&x==e)return T;if(w==i||w==t||w==e)return x==R&&g.every(function(tt){return tt==n})?b:F;if(x==i||x==t||x==e)return F;if(w==r&&(x==r||x==a||x==A||x==d))return T;if((w==A||w==a)&&(x==a||x==h))return T;if((w==d||w==h)&&x==h)return T;if(x==n||x==I)return T;if(x==o)return T;if(w==E)return T;var X=D.indexOf(n)!=-1?D.lastIndexOf(n)-1:D.length-2;return[_,N].indexOf(D[X])!=-1&&D.slice(X+1,-1).every(function(tt){return tt==n})&&x==R||w==I&&[C,N].indexOf(x)!=-1?T:g.indexOf(s)!=-1?b:w==s&&x==s?T:F}this.nextBreak=function(c,g){if(g===void 0&&(g=0),g<0)return 0;if(g>=c.length-1)return c.length;for(var V=y(U(c,g)),D=[],w=g+1;w<c.length;w++)if(!Q(c,w-1)){var x=y(U(c,w));if(k(V,D,x))return w;D.push(x)}return c.length},this.splitGraphemes=function(c){for(var g=[],V=0,D;(D=this.nextBreak(c,V))<c.length;)g.push(c.slice(V,D)),V=D;return V<c.length&&g.push(c.slice(V)),g},this.iterateGraphemes=function(c){var g=0,V={next:function(){var D,w;return(w=this.nextBreak(c,g))<c.length?(D=c.slice(g,w),g=w,{value:D,done:!1}):g<c.length?(D=c.slice(g),g=c.length,{value:D,done:!1}):{value:void 0,done:!0}}.bind(this)};return typeof Symbol<"u"&&Symbol.iterator&&(V[Symbol.iterator]=function(){return V}),V},this.countGraphemes=function(c){for(var g=0,V=0,D;(D=this.nextBreak(c,V))<c.length;)V=D,g++;return V<c.length&&g++,g};function y(c){return 1536<=c&&c<=1541||c==1757||c==1807||c==2274||c==3406||c==69821||70082<=c&&c<=70083||c==72250||72326<=c&&c<=72329||c==73030?E:c==13?t:c==10?e:0<=c&&c<=9||11<=c&&c<=12||14<=c&&c<=31||127<=c&&c<=159||c==173||c==1564||c==6158||c==8203||8206<=c&&c<=8207||c==8232||c==8233||8234<=c&&c<=8238||8288<=c&&c<=8292||c==8293||8294<=c&&c<=8303||55296<=c&&c<=57343||c==65279||65520<=c&&c<=65528||65529<=c&&c<=65531||113824<=c&&c<=113827||119155<=c&&c<=119162||c==917504||c==917505||917506<=c&&c<=917535||917632<=c&&c<=917759||918e3<=c&&c<=921599?i:768<=c&&c<=879||1155<=c&&c<=1159||1160<=c&&c<=1161||1425<=c&&c<=1469||c==1471||1473<=c&&c<=1474||1476<=c&&c<=1477||c==1479||1552<=c&&c<=1562||1611<=c&&c<=1631||c==1648||1750<=c&&c<=1756||1759<=c&&c<=1764||1767<=c&&c<=1768||1770<=c&&c<=1773||c==1809||1840<=c&&c<=1866||1958<=c&&c<=1968||2027<=c&&c<=2035||2070<=c&&c<=2073||2075<=c&&c<=2083||2085<=c&&c<=2087||2089<=c&&c<=2093||2137<=c&&c<=2139||2260<=c&&c<=2273||2275<=c&&c<=2306||c==2362||c==2364||2369<=c&&c<=2376||c==2381||2385<=c&&c<=2391||2402<=c&&c<=2403||c==2433||c==2492||c==2494||2497<=c&&c<=2500||c==2509||c==2519||2530<=c&&c<=2531||2561<=c&&c<=2562||c==2620||2625<=c&&c<=2626||2631<=c&&c<=2632||2635<=c&&c<=2637||c==2641||2672<=c&&c<=2673||c==2677||2689<=c&&c<=2690||c==2748||2753<=c&&c<=2757||2759<=c&&c<=2760||c==2765||2786<=c&&c<=2787||2810<=c&&c<=2815||c==2817||c==2876||c==2878||c==2879||2881<=c&&c<=2884||c==2893||c==2902||c==2903||2914<=c&&c<=2915||c==2946||c==3006||c==3008||c==3021||c==3031||c==3072||3134<=c&&c<=3136||3142<=c&&c<=3144||3146<=c&&c<=3149||3157<=c&&c<=3158||3170<=c&&c<=3171||c==3201||c==3260||c==3263||c==3266||c==3270||3276<=c&&c<=3277||3285<=c&&c<=3286||3298<=c&&c<=3299||3328<=c&&c<=3329||3387<=c&&c<=3388||c==3390||3393<=c&&c<=3396||c==3405||c==3415||3426<=c&&c<=3427||c==3530||c==3535||3538<=c&&c<=3540||c==3542||c==3551||c==3633||3636<=c&&c<=3642||3655<=c&&c<=3662||c==3761||3764<=c&&c<=3769||3771<=c&&c<=3772||3784<=c&&c<=3789||3864<=c&&c<=3865||c==3893||c==3895||c==3897||3953<=c&&c<=3966||3968<=c&&c<=3972||3974<=c&&c<=3975||3981<=c&&c<=3991||3993<=c&&c<=4028||c==4038||4141<=c&&c<=4144||4146<=c&&c<=4151||4153<=c&&c<=4154||4157<=c&&c<=4158||4184<=c&&c<=4185||4190<=c&&c<=4192||4209<=c&&c<=4212||c==4226||4229<=c&&c<=4230||c==4237||c==4253||4957<=c&&c<=4959||5906<=c&&c<=5908||5938<=c&&c<=5940||5970<=c&&c<=5971||6002<=c&&c<=6003||6068<=c&&c<=6069||6071<=c&&c<=6077||c==6086||6089<=c&&c<=6099||c==6109||6155<=c&&c<=6157||6277<=c&&c<=6278||c==6313||6432<=c&&c<=6434||6439<=c&&c<=6440||c==6450||6457<=c&&c<=6459||6679<=c&&c<=6680||c==6683||c==6742||6744<=c&&c<=6750||c==6752||c==6754||6757<=c&&c<=6764||6771<=c&&c<=6780||c==6783||6832<=c&&c<=6845||c==6846||6912<=c&&c<=6915||c==6964||6966<=c&&c<=6970||c==6972||c==6978||7019<=c&&c<=7027||7040<=c&&c<=7041||7074<=c&&c<=7077||7080<=c&&c<=7081||7083<=c&&c<=7085||c==7142||7144<=c&&c<=7145||c==7149||7151<=c&&c<=7153||7212<=c&&c<=7219||7222<=c&&c<=7223||7376<=c&&c<=7378||7380<=c&&c<=7392||7394<=c&&c<=7400||c==7405||c==7412||7416<=c&&c<=7417||7616<=c&&c<=7673||7675<=c&&c<=7679||c==8204||8400<=c&&c<=8412||8413<=c&&c<=8416||c==8417||8418<=c&&c<=8420||8421<=c&&c<=8432||11503<=c&&c<=11505||c==11647||11744<=c&&c<=11775||12330<=c&&c<=12333||12334<=c&&c<=12335||12441<=c&&c<=12442||c==42607||42608<=c&&c<=42610||42612<=c&&c<=42621||42654<=c&&c<=42655||42736<=c&&c<=42737||c==43010||c==43014||c==43019||43045<=c&&c<=43046||43204<=c&&c<=43205||43232<=c&&c<=43249||43302<=c&&c<=43309||43335<=c&&c<=43345||43392<=c&&c<=43394||c==43443||43446<=c&&c<=43449||c==43452||c==43493||43561<=c&&c<=43566||43569<=c&&c<=43570||43573<=c&&c<=43574||c==43587||c==43596||c==43644||c==43696||43698<=c&&c<=43700||43703<=c&&c<=43704||43710<=c&&c<=43711||c==43713||43756<=c&&c<=43757||c==43766||c==44005||c==44008||c==44013||c==64286||65024<=c&&c<=65039||65056<=c&&c<=65071||65438<=c&&c<=65439||c==66045||c==66272||66422<=c&&c<=66426||68097<=c&&c<=68099||68101<=c&&c<=68102||68108<=c&&c<=68111||68152<=c&&c<=68154||c==68159||68325<=c&&c<=68326||c==69633||69688<=c&&c<=69702||69759<=c&&c<=69761||69811<=c&&c<=69814||69817<=c&&c<=69818||69888<=c&&c<=69890||69927<=c&&c<=69931||69933<=c&&c<=69940||c==70003||70016<=c&&c<=70017||70070<=c&&c<=70078||70090<=c&&c<=70092||70191<=c&&c<=70193||c==70196||70198<=c&&c<=70199||c==70206||c==70367||70371<=c&&c<=70378||70400<=c&&c<=70401||c==70460||c==70462||c==70464||c==70487||70502<=c&&c<=70508||70512<=c&&c<=70516||70712<=c&&c<=70719||70722<=c&&c<=70724||c==70726||c==70832||70835<=c&&c<=70840||c==70842||c==70845||70847<=c&&c<=70848||70850<=c&&c<=70851||c==71087||71090<=c&&c<=71093||71100<=c&&c<=71101||71103<=c&&c<=71104||71132<=c&&c<=71133||71219<=c&&c<=71226||c==71229||71231<=c&&c<=71232||c==71339||c==71341||71344<=c&&c<=71349||c==71351||71453<=c&&c<=71455||71458<=c&&c<=71461||71463<=c&&c<=71467||72193<=c&&c<=72198||72201<=c&&c<=72202||72243<=c&&c<=72248||72251<=c&&c<=72254||c==72263||72273<=c&&c<=72278||72281<=c&&c<=72283||72330<=c&&c<=72342||72344<=c&&c<=72345||72752<=c&&c<=72758||72760<=c&&c<=72765||c==72767||72850<=c&&c<=72871||72874<=c&&c<=72880||72882<=c&&c<=72883||72885<=c&&c<=72886||73009<=c&&c<=73014||c==73018||73020<=c&&c<=73021||73023<=c&&c<=73029||c==73031||92912<=c&&c<=92916||92976<=c&&c<=92982||94095<=c&&c<=94098||113821<=c&&c<=113822||c==119141||119143<=c&&c<=119145||119150<=c&&c<=119154||119163<=c&&c<=119170||119173<=c&&c<=119179||119210<=c&&c<=119213||119362<=c&&c<=119364||121344<=c&&c<=121398||121403<=c&&c<=121452||c==121461||c==121476||121499<=c&&c<=121503||121505<=c&&c<=121519||122880<=c&&c<=122886||122888<=c&&c<=122904||122907<=c&&c<=122913||122915<=c&&c<=122916||122918<=c&&c<=122922||125136<=c&&c<=125142||125252<=c&&c<=125258||917536<=c&&c<=917631||917760<=c&&c<=917999?n:127462<=c&&c<=127487?s:c==2307||c==2363||2366<=c&&c<=2368||2377<=c&&c<=2380||2382<=c&&c<=2383||2434<=c&&c<=2435||2495<=c&&c<=2496||2503<=c&&c<=2504||2507<=c&&c<=2508||c==2563||2622<=c&&c<=2624||c==2691||2750<=c&&c<=2752||c==2761||2763<=c&&c<=2764||2818<=c&&c<=2819||c==2880||2887<=c&&c<=2888||2891<=c&&c<=2892||c==3007||3009<=c&&c<=3010||3014<=c&&c<=3016||3018<=c&&c<=3020||3073<=c&&c<=3075||3137<=c&&c<=3140||3202<=c&&c<=3203||c==3262||3264<=c&&c<=3265||3267<=c&&c<=3268||3271<=c&&c<=3272||3274<=c&&c<=3275||3330<=c&&c<=3331||3391<=c&&c<=3392||3398<=c&&c<=3400||3402<=c&&c<=3404||3458<=c&&c<=3459||3536<=c&&c<=3537||3544<=c&&c<=3550||3570<=c&&c<=3571||c==3635||c==3763||3902<=c&&c<=3903||c==3967||c==4145||4155<=c&&c<=4156||4182<=c&&c<=4183||c==4228||c==6070||6078<=c&&c<=6085||6087<=c&&c<=6088||6435<=c&&c<=6438||6441<=c&&c<=6443||6448<=c&&c<=6449||6451<=c&&c<=6456||6681<=c&&c<=6682||c==6741||c==6743||6765<=c&&c<=6770||c==6916||c==6965||c==6971||6973<=c&&c<=6977||6979<=c&&c<=6980||c==7042||c==7073||7078<=c&&c<=7079||c==7082||c==7143||7146<=c&&c<=7148||c==7150||7154<=c&&c<=7155||7204<=c&&c<=7211||7220<=c&&c<=7221||c==7393||7410<=c&&c<=7411||c==7415||43043<=c&&c<=43044||c==43047||43136<=c&&c<=43137||43188<=c&&c<=43203||43346<=c&&c<=43347||c==43395||43444<=c&&c<=43445||43450<=c&&c<=43451||43453<=c&&c<=43456||43567<=c&&c<=43568||43571<=c&&c<=43572||c==43597||c==43755||43758<=c&&c<=43759||c==43765||44003<=c&&c<=44004||44006<=c&&c<=44007||44009<=c&&c<=44010||c==44012||c==69632||c==69634||c==69762||69808<=c&&c<=69810||69815<=c&&c<=69816||c==69932||c==70018||70067<=c&&c<=70069||70079<=c&&c<=70080||70188<=c&&c<=70190||70194<=c&&c<=70195||c==70197||70368<=c&&c<=70370||70402<=c&&c<=70403||c==70463||70465<=c&&c<=70468||70471<=c&&c<=70472||70475<=c&&c<=70477||70498<=c&&c<=70499||70709<=c&&c<=70711||70720<=c&&c<=70721||c==70725||70833<=c&&c<=70834||c==70841||70843<=c&&c<=70844||c==70846||c==70849||71088<=c&&c<=71089||71096<=c&&c<=71099||c==71102||71216<=c&&c<=71218||71227<=c&&c<=71228||c==71230||c==71340||71342<=c&&c<=71343||c==71350||71456<=c&&c<=71457||c==71462||72199<=c&&c<=72200||c==72249||72279<=c&&c<=72280||c==72343||c==72751||c==72766||c==72873||c==72881||c==72884||94033<=c&&c<=94078||c==119142||c==119149?o:4352<=c&&c<=4447||43360<=c&&c<=43388?r:4448<=c&&c<=4519||55216<=c&&c<=55238?a:4520<=c&&c<=4607||55243<=c&&c<=55291?h:c==44032||c==44060||c==44088||c==44116||c==44144||c==44172||c==44200||c==44228||c==44256||c==44284||c==44312||c==44340||c==44368||c==44396||c==44424||c==44452||c==44480||c==44508||c==44536||c==44564||c==44592||c==44620||c==44648||c==44676||c==44704||c==44732||c==44760||c==44788||c==44816||c==44844||c==44872||c==44900||c==44928||c==44956||c==44984||c==45012||c==45040||c==45068||c==45096||c==45124||c==45152||c==45180||c==45208||c==45236||c==45264||c==45292||c==45320||c==45348||c==45376||c==45404||c==45432||c==45460||c==45488||c==45516||c==45544||c==45572||c==45600||c==45628||c==45656||c==45684||c==45712||c==45740||c==45768||c==45796||c==45824||c==45852||c==45880||c==45908||c==45936||c==45964||c==45992||c==46020||c==46048||c==46076||c==46104||c==46132||c==46160||c==46188||c==46216||c==46244||c==46272||c==46300||c==46328||c==46356||c==46384||c==46412||c==46440||c==46468||c==46496||c==46524||c==46552||c==46580||c==46608||c==46636||c==46664||c==46692||c==46720||c==46748||c==46776||c==46804||c==46832||c==46860||c==46888||c==46916||c==46944||c==46972||c==47e3||c==47028||c==47056||c==47084||c==47112||c==47140||c==47168||c==47196||c==47224||c==47252||c==47280||c==47308||c==47336||c==47364||c==47392||c==47420||c==47448||c==47476||c==47504||c==47532||c==47560||c==47588||c==47616||c==47644||c==47672||c==47700||c==47728||c==47756||c==47784||c==47812||c==47840||c==47868||c==47896||c==47924||c==47952||c==47980||c==48008||c==48036||c==48064||c==48092||c==48120||c==48148||c==48176||c==48204||c==48232||c==48260||c==48288||c==48316||c==48344||c==48372||c==48400||c==48428||c==48456||c==48484||c==48512||c==48540||c==48568||c==48596||c==48624||c==48652||c==48680||c==48708||c==48736||c==48764||c==48792||c==48820||c==48848||c==48876||c==48904||c==48932||c==48960||c==48988||c==49016||c==49044||c==49072||c==49100||c==49128||c==49156||c==49184||c==49212||c==49240||c==49268||c==49296||c==49324||c==49352||c==49380||c==49408||c==49436||c==49464||c==49492||c==49520||c==49548||c==49576||c==49604||c==49632||c==49660||c==49688||c==49716||c==49744||c==49772||c==49800||c==49828||c==49856||c==49884||c==49912||c==49940||c==49968||c==49996||c==50024||c==50052||c==50080||c==50108||c==50136||c==50164||c==50192||c==50220||c==50248||c==50276||c==50304||c==50332||c==50360||c==50388||c==50416||c==50444||c==50472||c==50500||c==50528||c==50556||c==50584||c==50612||c==50640||c==50668||c==50696||c==50724||c==50752||c==50780||c==50808||c==50836||c==50864||c==50892||c==50920||c==50948||c==50976||c==51004||c==51032||c==51060||c==51088||c==51116||c==51144||c==51172||c==51200||c==51228||c==51256||c==51284||c==51312||c==51340||c==51368||c==51396||c==51424||c==51452||c==51480||c==51508||c==51536||c==51564||c==51592||c==51620||c==51648||c==51676||c==51704||c==51732||c==51760||c==51788||c==51816||c==51844||c==51872||c==51900||c==51928||c==51956||c==51984||c==52012||c==52040||c==52068||c==52096||c==52124||c==52152||c==52180||c==52208||c==52236||c==52264||c==52292||c==52320||c==52348||c==52376||c==52404||c==52432||c==52460||c==52488||c==52516||c==52544||c==52572||c==52600||c==52628||c==52656||c==52684||c==52712||c==52740||c==52768||c==52796||c==52824||c==52852||c==52880||c==52908||c==52936||c==52964||c==52992||c==53020||c==53048||c==53076||c==53104||c==53132||c==53160||c==53188||c==53216||c==53244||c==53272||c==53300||c==53328||c==53356||c==53384||c==53412||c==53440||c==53468||c==53496||c==53524||c==53552||c==53580||c==53608||c==53636||c==53664||c==53692||c==53720||c==53748||c==53776||c==53804||c==53832||c==53860||c==53888||c==53916||c==53944||c==53972||c==54e3||c==54028||c==54056||c==54084||c==54112||c==54140||c==54168||c==54196||c==54224||c==54252||c==54280||c==54308||c==54336||c==54364||c==54392||c==54420||c==54448||c==54476||c==54504||c==54532||c==54560||c==54588||c==54616||c==54644||c==54672||c==54700||c==54728||c==54756||c==54784||c==54812||c==54840||c==54868||c==54896||c==54924||c==54952||c==54980||c==55008||c==55036||c==55064||c==55092||c==55120||c==55148||c==55176?A:44033<=c&&c<=44059||44061<=c&&c<=44087||44089<=c&&c<=44115||44117<=c&&c<=44143||44145<=c&&c<=44171||44173<=c&&c<=44199||44201<=c&&c<=44227||44229<=c&&c<=44255||44257<=c&&c<=44283||44285<=c&&c<=44311||44313<=c&&c<=44339||44341<=c&&c<=44367||44369<=c&&c<=44395||44397<=c&&c<=44423||44425<=c&&c<=44451||44453<=c&&c<=44479||44481<=c&&c<=44507||44509<=c&&c<=44535||44537<=c&&c<=44563||44565<=c&&c<=44591||44593<=c&&c<=44619||44621<=c&&c<=44647||44649<=c&&c<=44675||44677<=c&&c<=44703||44705<=c&&c<=44731||44733<=c&&c<=44759||44761<=c&&c<=44787||44789<=c&&c<=44815||44817<=c&&c<=44843||44845<=c&&c<=44871||44873<=c&&c<=44899||44901<=c&&c<=44927||44929<=c&&c<=44955||44957<=c&&c<=44983||44985<=c&&c<=45011||45013<=c&&c<=45039||45041<=c&&c<=45067||45069<=c&&c<=45095||45097<=c&&c<=45123||45125<=c&&c<=45151||45153<=c&&c<=45179||45181<=c&&c<=45207||45209<=c&&c<=45235||45237<=c&&c<=45263||45265<=c&&c<=45291||45293<=c&&c<=45319||45321<=c&&c<=45347||45349<=c&&c<=45375||45377<=c&&c<=45403||45405<=c&&c<=45431||45433<=c&&c<=45459||45461<=c&&c<=45487||45489<=c&&c<=45515||45517<=c&&c<=45543||45545<=c&&c<=45571||45573<=c&&c<=45599||45601<=c&&c<=45627||45629<=c&&c<=45655||45657<=c&&c<=45683||45685<=c&&c<=45711||45713<=c&&c<=45739||45741<=c&&c<=45767||45769<=c&&c<=45795||45797<=c&&c<=45823||45825<=c&&c<=45851||45853<=c&&c<=45879||45881<=c&&c<=45907||45909<=c&&c<=45935||45937<=c&&c<=45963||45965<=c&&c<=45991||45993<=c&&c<=46019||46021<=c&&c<=46047||46049<=c&&c<=46075||46077<=c&&c<=46103||46105<=c&&c<=46131||46133<=c&&c<=46159||46161<=c&&c<=46187||46189<=c&&c<=46215||46217<=c&&c<=46243||46245<=c&&c<=46271||46273<=c&&c<=46299||46301<=c&&c<=46327||46329<=c&&c<=46355||46357<=c&&c<=46383||46385<=c&&c<=46411||46413<=c&&c<=46439||46441<=c&&c<=46467||46469<=c&&c<=46495||46497<=c&&c<=46523||46525<=c&&c<=46551||46553<=c&&c<=46579||46581<=c&&c<=46607||46609<=c&&c<=46635||46637<=c&&c<=46663||46665<=c&&c<=46691||46693<=c&&c<=46719||46721<=c&&c<=46747||46749<=c&&c<=46775||46777<=c&&c<=46803||46805<=c&&c<=46831||46833<=c&&c<=46859||46861<=c&&c<=46887||46889<=c&&c<=46915||46917<=c&&c<=46943||46945<=c&&c<=46971||46973<=c&&c<=46999||47001<=c&&c<=47027||47029<=c&&c<=47055||47057<=c&&c<=47083||47085<=c&&c<=47111||47113<=c&&c<=47139||47141<=c&&c<=47167||47169<=c&&c<=47195||47197<=c&&c<=47223||47225<=c&&c<=47251||47253<=c&&c<=47279||47281<=c&&c<=47307||47309<=c&&c<=47335||47337<=c&&c<=47363||47365<=c&&c<=47391||47393<=c&&c<=47419||47421<=c&&c<=47447||47449<=c&&c<=47475||47477<=c&&c<=47503||47505<=c&&c<=47531||47533<=c&&c<=47559||47561<=c&&c<=47587||47589<=c&&c<=47615||47617<=c&&c<=47643||47645<=c&&c<=47671||47673<=c&&c<=47699||47701<=c&&c<=47727||47729<=c&&c<=47755||47757<=c&&c<=47783||47785<=c&&c<=47811||47813<=c&&c<=47839||47841<=c&&c<=47867||47869<=c&&c<=47895||47897<=c&&c<=47923||47925<=c&&c<=47951||47953<=c&&c<=47979||47981<=c&&c<=48007||48009<=c&&c<=48035||48037<=c&&c<=48063||48065<=c&&c<=48091||48093<=c&&c<=48119||48121<=c&&c<=48147||48149<=c&&c<=48175||48177<=c&&c<=48203||48205<=c&&c<=48231||48233<=c&&c<=48259||48261<=c&&c<=48287||48289<=c&&c<=48315||48317<=c&&c<=48343||48345<=c&&c<=48371||48373<=c&&c<=48399||48401<=c&&c<=48427||48429<=c&&c<=48455||48457<=c&&c<=48483||48485<=c&&c<=48511||48513<=c&&c<=48539||48541<=c&&c<=48567||48569<=c&&c<=48595||48597<=c&&c<=48623||48625<=c&&c<=48651||48653<=c&&c<=48679||48681<=c&&c<=48707||48709<=c&&c<=48735||48737<=c&&c<=48763||48765<=c&&c<=48791||48793<=c&&c<=48819||48821<=c&&c<=48847||48849<=c&&c<=48875||48877<=c&&c<=48903||48905<=c&&c<=48931||48933<=c&&c<=48959||48961<=c&&c<=48987||48989<=c&&c<=49015||49017<=c&&c<=49043||49045<=c&&c<=49071||49073<=c&&c<=49099||49101<=c&&c<=49127||49129<=c&&c<=49155||49157<=c&&c<=49183||49185<=c&&c<=49211||49213<=c&&c<=49239||49241<=c&&c<=49267||49269<=c&&c<=49295||49297<=c&&c<=49323||49325<=c&&c<=49351||49353<=c&&c<=49379||49381<=c&&c<=49407||49409<=c&&c<=49435||49437<=c&&c<=49463||49465<=c&&c<=49491||49493<=c&&c<=49519||49521<=c&&c<=49547||49549<=c&&c<=49575||49577<=c&&c<=49603||49605<=c&&c<=49631||49633<=c&&c<=49659||49661<=c&&c<=49687||49689<=c&&c<=49715||49717<=c&&c<=49743||49745<=c&&c<=49771||49773<=c&&c<=49799||49801<=c&&c<=49827||49829<=c&&c<=49855||49857<=c&&c<=49883||49885<=c&&c<=49911||49913<=c&&c<=49939||49941<=c&&c<=49967||49969<=c&&c<=49995||49997<=c&&c<=50023||50025<=c&&c<=50051||50053<=c&&c<=50079||50081<=c&&c<=50107||50109<=c&&c<=50135||50137<=c&&c<=50163||50165<=c&&c<=50191||50193<=c&&c<=50219||50221<=c&&c<=50247||50249<=c&&c<=50275||50277<=c&&c<=50303||50305<=c&&c<=50331||50333<=c&&c<=50359||50361<=c&&c<=50387||50389<=c&&c<=50415||50417<=c&&c<=50443||50445<=c&&c<=50471||50473<=c&&c<=50499||50501<=c&&c<=50527||50529<=c&&c<=50555||50557<=c&&c<=50583||50585<=c&&c<=50611||50613<=c&&c<=50639||50641<=c&&c<=50667||50669<=c&&c<=50695||50697<=c&&c<=50723||50725<=c&&c<=50751||50753<=c&&c<=50779||50781<=c&&c<=50807||50809<=c&&c<=50835||50837<=c&&c<=50863||50865<=c&&c<=50891||50893<=c&&c<=50919||50921<=c&&c<=50947||50949<=c&&c<=50975||50977<=c&&c<=51003||51005<=c&&c<=51031||51033<=c&&c<=51059||51061<=c&&c<=51087||51089<=c&&c<=51115||51117<=c&&c<=51143||51145<=c&&c<=51171||51173<=c&&c<=51199||51201<=c&&c<=51227||51229<=c&&c<=51255||51257<=c&&c<=51283||51285<=c&&c<=51311||51313<=c&&c<=51339||51341<=c&&c<=51367||51369<=c&&c<=51395||51397<=c&&c<=51423||51425<=c&&c<=51451||51453<=c&&c<=51479||51481<=c&&c<=51507||51509<=c&&c<=51535||51537<=c&&c<=51563||51565<=c&&c<=51591||51593<=c&&c<=51619||51621<=c&&c<=51647||51649<=c&&c<=51675||51677<=c&&c<=51703||51705<=c&&c<=51731||51733<=c&&c<=51759||51761<=c&&c<=51787||51789<=c&&c<=51815||51817<=c&&c<=51843||51845<=c&&c<=51871||51873<=c&&c<=51899||51901<=c&&c<=51927||51929<=c&&c<=51955||51957<=c&&c<=51983||51985<=c&&c<=52011||52013<=c&&c<=52039||52041<=c&&c<=52067||52069<=c&&c<=52095||52097<=c&&c<=52123||52125<=c&&c<=52151||52153<=c&&c<=52179||52181<=c&&c<=52207||52209<=c&&c<=52235||52237<=c&&c<=52263||52265<=c&&c<=52291||52293<=c&&c<=52319||52321<=c&&c<=52347||52349<=c&&c<=52375||52377<=c&&c<=52403||52405<=c&&c<=52431||52433<=c&&c<=52459||52461<=c&&c<=52487||52489<=c&&c<=52515||52517<=c&&c<=52543||52545<=c&&c<=52571||52573<=c&&c<=52599||52601<=c&&c<=52627||52629<=c&&c<=52655||52657<=c&&c<=52683||52685<=c&&c<=52711||52713<=c&&c<=52739||52741<=c&&c<=52767||52769<=c&&c<=52795||52797<=c&&c<=52823||52825<=c&&c<=52851||52853<=c&&c<=52879||52881<=c&&c<=52907||52909<=c&&c<=52935||52937<=c&&c<=52963||52965<=c&&c<=52991||52993<=c&&c<=53019||53021<=c&&c<=53047||53049<=c&&c<=53075||53077<=c&&c<=53103||53105<=c&&c<=53131||53133<=c&&c<=53159||53161<=c&&c<=53187||53189<=c&&c<=53215||53217<=c&&c<=53243||53245<=c&&c<=53271||53273<=c&&c<=53299||53301<=c&&c<=53327||53329<=c&&c<=53355||53357<=c&&c<=53383||53385<=c&&c<=53411||53413<=c&&c<=53439||53441<=c&&c<=53467||53469<=c&&c<=53495||53497<=c&&c<=53523||53525<=c&&c<=53551||53553<=c&&c<=53579||53581<=c&&c<=53607||53609<=c&&c<=53635||53637<=c&&c<=53663||53665<=c&&c<=53691||53693<=c&&c<=53719||53721<=c&&c<=53747||53749<=c&&c<=53775||53777<=c&&c<=53803||53805<=c&&c<=53831||53833<=c&&c<=53859||53861<=c&&c<=53887||53889<=c&&c<=53915||53917<=c&&c<=53943||53945<=c&&c<=53971||53973<=c&&c<=53999||54001<=c&&c<=54027||54029<=c&&c<=54055||54057<=c&&c<=54083||54085<=c&&c<=54111||54113<=c&&c<=54139||54141<=c&&c<=54167||54169<=c&&c<=54195||54197<=c&&c<=54223||54225<=c&&c<=54251||54253<=c&&c<=54279||54281<=c&&c<=54307||54309<=c&&c<=54335||54337<=c&&c<=54363||54365<=c&&c<=54391||54393<=c&&c<=54419||54421<=c&&c<=54447||54449<=c&&c<=54475||54477<=c&&c<=54503||54505<=c&&c<=54531||54533<=c&&c<=54559||54561<=c&&c<=54587||54589<=c&&c<=54615||54617<=c&&c<=54643||54645<=c&&c<=54671||54673<=c&&c<=54699||54701<=c&&c<=54727||54729<=c&&c<=54755||54757<=c&&c<=54783||54785<=c&&c<=54811||54813<=c&&c<=54839||54841<=c&&c<=54867||54869<=c&&c<=54895||54897<=c&&c<=54923||54925<=c&&c<=54951||54953<=c&&c<=54979||54981<=c&&c<=55007||55009<=c&&c<=55035||55037<=c&&c<=55063||55065<=c&&c<=55091||55093<=c&&c<=55119||55121<=c&&c<=55147||55149<=c&&c<=55175||55177<=c&&c<=55203?d:c==9757||c==9977||9994<=c&&c<=9997||c==127877||127938<=c&&c<=127940||c==127943||127946<=c&&c<=127948||128066<=c&&c<=128067||128070<=c&&c<=128080||c==128110||128112<=c&&c<=128120||c==128124||128129<=c&&c<=128131||128133<=c&&c<=128135||c==128170||128372<=c&&c<=128373||c==128378||c==128400||128405<=c&&c<=128406||128581<=c&&c<=128583||128587<=c&&c<=128591||c==128675||128692<=c&&c<=128694||c==128704||c==128716||129304<=c&&c<=129308||129310<=c&&c<=129311||c==129318||129328<=c&&c<=129337||129341<=c&&c<=129342||129489<=c&&c<=129501?_:127995<=c&&c<=127999?R:c==8205?I:c==9792||c==9794||9877<=c&&c<=9878||c==9992||c==10084||c==127752||c==127806||c==127859||c==127891||c==127908||c==127912||c==127979||c==127981||c==128139||128187<=c&&c<=128188||c==128295||c==128300||c==128488||c==128640||c==128658?C:128102<=c&&c<=128105?N:f}return this}typeof gI<"u"&&gI.exports&&(gI.exports=Tet)});function Net(){this.textureInfo=void 0,this.dimensions=void 0,this.billboard=void 0}function bet(t,e,i){this.labelCollection=t,this.index=e,this.dimensions=i}function Set(t){let e=document.createElement("canvas");e.width=vT.x,e.height=vT.y;let i=e.getContext("2d");return i.fillStyle="#fff",i.fillRect(0,0,e.width,e.height),t.addImage(Sy,e)}function Oet(t,e,i,n,s,o,r){return yr.font=e,yr.fillColor=i,yr.strokeColor=n,yr.strokeWidth=s,yr.padding=po.PADDING,r===mn.CENTER?yr.textBaseline="middle":r===mn.TOP?yr.textBaseline="top":yr.textBaseline="bottom",yr.fill=o===Ya.FILL||o===Ya.FILL_AND_OUTLINE,yr.stroke=o===Ya.OUTLINE||o===Ya.FILL_AND_OUTLINE,yr.backgroundColor=Zt.BLACK,Iy(t,yr)}function zT(t,e){e.textureInfo=void 0,e.dimensions=void 0;let i=e.billboard;m(i)&&(i.show=!1,i.image=void 0,m(i._removeCallbackFunc)&&(i._removeCallbackFunc(),i._removeCallbackFunc=void 0),t._spareBillboards.push(i),e.billboard=void 0)}function Vet(t,e,i,n){n.index=t.addImageSync(e,i)}function Bet(t,e){let i=e._renderedText,n=Get.splitGraphemes(i),s=n.length,o=e._glyphs,r=o.length,a,h,A;if(e._relativeSize=e._fontSize/po.FONT_SIZE,s<r)for(h=s;h<r;++h)zT(t,o[h]);o.length=s;let d=e.show&&e._showBackground&&i.split(`
`).join("").length>0,f=e._backgroundBillboard,E=t._backgroundBillboardCollection;d?(m(f)||(f=E.add({collection:t,image:Sy,imageSubRegion:Yet}),e._backgroundBillboard=f),f.color=e._backgroundColor,f.show=e._show,f.position=e._position,f.eyeOffset=e._eyeOffset,f.pixelOffset=e._pixelOffset,f.horizontalOrigin=to.LEFT,f.verticalOrigin=e._verticalOrigin,f.heightReference=e._heightReference,f.scale=e.totalScale,f.pickPrimitive=e,f.id=e._id,f.translucencyByDistance=e._translucencyByDistance,f.pixelOffsetScaleByDistance=e._pixelOffsetScaleByDistance,f.scaleByDistance=e._scaleByDistance,f.distanceDisplayCondition=e._distanceDisplayCondition,f.disableDepthTestDistance=e._disableDepthTestDistance,f.clusterShow=e.clusterShow):m(f)&&(E.remove(f),e._backgroundBillboard=f=void 0);let _=t._glyphTextureCache;for(A=0;A<s;++A){let R=n[A],I=e._verticalOrigin,C=JSON.stringify([R,e._fontFamily,e._fontStyle,e._fontWeight,+I]),N=_[C];if(!m(N)){let T=`${e._fontStyle} ${e._fontWeight} ${po.FONT_SIZE}px ${e._fontFamily}`,F=Oet(R,T,Zt.WHITE,Zt.WHITE,0,Ya.FILL,I);if(N=new bet(t,-1,F.dimensions),_[C]=N,F.width>0&&F.height>0){let b=(0,Fy.default)(F,{cutoff:po.CUTOFF,radius:po.RADIUS}),G=F.getContext("2d"),M=F.width,Q=F.height,U=G.getImageData(0,0,M,Q);for(let k=0;k<M;k++)for(let y=0;y<Q;y++){let c=y*M+k,g=b[c]*255,V=c*4;U.data[V+0]=g,U.data[V+1]=g,U.data[V+2]=g,U.data[V+3]=g}G.putImageData(U,0,0),R!==" "&&Vet(t._textureAtlas,C,F,N)}}if(a=o[A],m(a)?N.index===-1?zT(t,a):m(a.textureInfo)&&(a.textureInfo=void 0):(a=new Net,o[A]=a),a.textureInfo=N,a.dimensions=N.dimensions,N.index!==-1){let T=a.billboard,F=t._spareBillboards;m(T)||(F.length>0?T=F.pop():(T=t._billboardCollection.add({collection:t}),T._labelDimensions=new nt,T._labelTranslate=new nt),a.billboard=T),T.show=e._show,T.position=e._position,T.eyeOffset=e._eyeOffset,T.pixelOffset=e._pixelOffset,T.horizontalOrigin=to.LEFT,T.verticalOrigin=e._verticalOrigin,T.heightReference=e._heightReference,T.scale=e.totalScale,T.pickPrimitive=e,T.id=e._id,T.image=C,T.translucencyByDistance=e._translucencyByDistance,T.pixelOffsetScaleByDistance=e._pixelOffsetScaleByDistance,T.scaleByDistance=e._scaleByDistance,T.distanceDisplayCondition=e._distanceDisplayCondition,T.disableDepthTestDistance=e._disableDepthTestDistance,T._batchIndex=e._batchIndex,T.outlineColor=e.outlineColor,e.style===Ya.FILL_AND_OUTLINE?(T.color=e._fillColor,T.outlineWidth=e.outlineWidth):e.style===Ya.FILL?(T.color=e._fillColor,T.outlineWidth=0):e.style===Ya.OUTLINE&&(T.color=Zt.TRANSPARENT,T.outlineWidth=e.outlineWidth)}}e._repositionAllGlyphs=!0}function by(t,e,i){return e===to.CENTER?-t/2:e===to.RIGHT?-(t+i.x):i.x}function Det(t){let e=t._glyphs,i=t._renderedText,n,s,o=0,r=0,a=[],h=Number.NEGATIVE_INFINITY,A=0,d=1,f,E=e.length,_=t._backgroundBillboard,R=nt.clone(m(_)?t._backgroundPadding:nt.ZERO,Wet);for(R.x/=t._relativeSize,R.y/=t._relativeSize,f=0;f<E;++f)i.charAt(f)===`
`?(a.push(o),++d,o=0):(n=e[f],s=n.dimensions,A=Math.max(A,s.height-s.descent),h=Math.max(h,s.descent),o+=s.width-s.minx,f<E-1&&(o+=e[f+1].dimensions.minx),r=Math.max(r,o));a.push(o);let I=A+h,C=t.totalScale,N=t._horizontalOrigin,T=t._verticalOrigin,F=0,b=a[F],G=by(b,N,R),M=(m(t._lineHeight)?t._lineHeight:Fet*t._fontSize)/t._relativeSize,Q=M*(d-1),U=r,k=I+Q;m(_)&&(U+=R.x*2,k+=R.y*2,_._labelHorizontalOrigin=N),kn.x=G*C,kn.y=0;let y=!0,c=0;for(f=0;f<E;++f)if(i.charAt(f)===`
`)++F,c+=M,b=a[F],G=by(b,N,R),kn.x=G*C,y=!0;else if(n=e[f],s=n.dimensions,T===mn.TOP?(kn.y=s.height-A-R.y,kn.y+=po.PADDING):T===mn.CENTER?kn.y=(Q+s.height-A)/2:T===mn.BASELINE?(kn.y=Q,kn.y-=po.PADDING):(kn.y=Q+h+R.y,kn.y-=po.PADDING),kn.y=(kn.y-s.descent-c)*C,y&&(kn.x-=po.PADDING*C,y=!1),m(n.billboard)&&(n.billboard._setTranslate(kn),n.billboard._labelDimensions.x=U,n.billboard._labelDimensions.y=k,n.billboard._labelHorizontalOrigin=N),f<E-1){let g=e[f+1];kn.x+=(s.width-s.minx+g.dimensions.minx)*C}if(m(_)&&i.split(`
`).join("").length>0&&(N===to.CENTER?G=-r/2-R.x:N===to.RIGHT?G=-(r+R.x*2):G=0,kn.x=G*C,T===mn.TOP?kn.y=I-A-h:T===mn.CENTER?kn.y=(I-A)/2-h:T===mn.BASELINE?kn.y=-R.y-h:kn.y=0,kn.y=kn.y*C,_.width=U,_.height=k,_._setTranslate(kn),_._labelTranslate=nt.clone(kn,_._labelTranslate)),gl(t.heightReference))for(f=0;f<E;++f){n=e[f];let g=n.billboard;m(g)&&(g._labelTranslate=nt.clone(kn,g._labelTranslate))}}function Oy(t,e){let i=e._glyphs;for(let n=0,s=i.length;n<s;++n)zT(t,i[n]);m(e._backgroundBillboard)&&(t._backgroundBillboardCollection.remove(e._backgroundBillboard),e._backgroundBillboard=void 0),e._labelCollection=void 0,m(e._removeCallbackFunc)&&e._removeCallbackFunc(),li(e)}function pA(t){t=Z(t,Z.EMPTY_OBJECT),this._scene=t.scene,this._batchTable=t.batchTable,this._textureAtlas=void 0,this._backgroundTextureAtlas=void 0,this._backgroundBillboardCollection=new wm({scene:this._scene}),this._backgroundBillboardCollection.destroyTextureAtlas=!1,this._billboardCollection=new wm({scene:this._scene,batchTable:this._batchTable}),this._billboardCollection.destroyTextureAtlas=!1,this._billboardCollection._sdf=!0,this._spareBillboards=[],this._glyphTextureCache={},this._labels=[],this._labelsToUpdate=[],this._totalGlyphCount=0,this._highlightColor=Zt.clone(Zt.WHITE),this.show=Z(t.show,!0),this.modelMatrix=at.clone(Z(t.modelMatrix,at.IDENTITY)),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.blendOption=Z(t.blendOption,Wn.OPAQUE_AND_TRANSLUCENT)}var Fy,Yy,Fet,Sy,vT,Yet,yr,Get,kn,Wet,KT,Vy=O(()=>{Er();Xe();Qn();bt();mt();Ws();Vt();Fi();py();Fy=co(Ty(),1);JT();EI();Om();Vm();HT();jT();_I();MT();CE();Yy=co(Ny(),1);Fet=1.2,Sy="ID_WHITE_PIXEL",vT=new nt(4,4),Yet=new mi(1,1,1,1);yr={};Get=new Yy.default;kn=new nt,Wet=new nt;Object.defineProperties(pA.prototype,{length:{get:function(){return this._labels.length}}});pA.prototype.add=function(t){let e=new DE(t,this);return this._labels.push(e),this._labelsToUpdate.push(e),e};pA.prototype.remove=function(t){if(m(t)&&t._labelCollection===this){let e=this._labels.indexOf(t);if(e!==-1)return this._labels.splice(e,1),Oy(this,t),!0}return!1};pA.prototype.removeAll=function(){let t=this._labels;for(let e=0,i=t.length;e<i;++e)Oy(this,t[e]);t.length=0};pA.prototype.contains=function(t){return m(t)&&t._labelCollection===this};pA.prototype.get=function(t){if(!m(t))throw new Y("index is required.");return this._labels[t]};pA.prototype.update=function(t){if(!this.show)return;let e=this._billboardCollection,i=this._backgroundBillboardCollection;e.modelMatrix=this.modelMatrix,e.debugShowBoundingVolume=this.debugShowBoundingVolume,i.modelMatrix=this.modelMatrix,i.debugShowBoundingVolume=this.debugShowBoundingVolume;let n=t.context;m(this._textureAtlas)||(this._textureAtlas=new SE({context:n}),e.textureAtlas=this._textureAtlas),m(this._backgroundTextureAtlas)||(this._backgroundTextureAtlas=new SE({context:n,initialSize:vT}),i.textureAtlas=this._backgroundTextureAtlas,Set(this._backgroundTextureAtlas));let s=this._labelsToUpdate.length;for(let r=0;r<s;++r){let a=this._labelsToUpdate[r];if(a.isDestroyed())continue;let h=a._glyphs.length;a._rebindAllGlyphs&&(Bet(this,a),a._rebindAllGlyphs=!1),a._repositionAllGlyphs&&(Det(a),a._repositionAllGlyphs=!1);let A=a._glyphs.length-h;this._totalGlyphCount+=A}let o=i.length>0?Wn.TRANSLUCENT:this.blendOption;e.blendOption=o,i.blendOption=o,e._highlightColor=this._highlightColor,i._highlightColor=this._highlightColor,this._labelsToUpdate.length=0,i.update(t),e.update(t)};pA.prototype.isDestroyed=function(){return!1};pA.prototype.destroy=function(){return this.removeAll(),this._billboardCollection=this._billboardCollection.destroy(),this._textureAtlas=this._textureAtlas&&this._textureAtlas.destroy(),this._backgroundBillboardCollection=this._backgroundBillboardCollection.destroy(),this._backgroundTextureAtlas=this._backgroundTextureAtlas&&this._backgroundTextureAtlas.destroy(),li(this)};KT=pA});function rs(t,e){if(t=Z(t,Z.EMPTY_OBJECT),m(t.disableDepthTestDistance)&&t.disableDepthTestDistance<0)throw new Y("disableDepthTestDistance must be greater than or equal to 0.0.");let i=t.translucencyByDistance,n=t.scaleByDistance,s=t.distanceDisplayCondition;if(m(i)){if(i.far<=i.near)throw new Y("translucencyByDistance.far must be greater than translucencyByDistance.near.");i=gi.clone(i)}if(m(n)){if(n.far<=n.near)throw new Y("scaleByDistance.far must be greater than scaleByDistance.near.");n=gi.clone(n)}if(m(s)){if(s.far<=s.near)throw new Y("distanceDisplayCondition.far must be greater than distanceDisplayCondition.near.");s=Wo.clone(s)}this._show=Z(t.show,!0),this._position=l.clone(Z(t.position,l.ZERO)),this._actualPosition=l.clone(this._position),this._color=Zt.clone(Z(t.color,Zt.WHITE)),this._outlineColor=Zt.clone(Z(t.outlineColor,Zt.TRANSPARENT)),this._outlineWidth=Z(t.outlineWidth,0),this._pixelSize=Z(t.pixelSize,10),this._scaleByDistance=n,this._translucencyByDistance=i,this._distanceDisplayCondition=s,this._disableDepthTestDistance=Z(t.disableDepthTestDistance,0),this._id=t.id,this._collection=Z(t.collection,e),this._clusterShow=!0,this._pickId=void 0,this._pointPrimitiveCollection=e,this._dirty=!1,this._index=-1}function wr(t,e){let i=t._pointPrimitiveCollection;m(i)&&(i._updatePointPrimitive(t,e),t._dirty=!0)}var Gy,Dy,Met,Uet,Qet,ket,Let,yet,wet,xet,By,Wy,uo,XT=O(()=>{Er();Xe();Ht();Vs();Qn();bt();mt();Vt();zZ();Fi();IE();ua();gT();Gy=rs.SHOW_INDEX=0,Dy=rs.POSITION_INDEX=1,Met=rs.COLOR_INDEX=2,Uet=rs.OUTLINE_COLOR_INDEX=3,Qet=rs.OUTLINE_WIDTH_INDEX=4,ket=rs.PIXEL_SIZE_INDEX=5,Let=rs.SCALE_BY_DISTANCE_INDEX=6,yet=rs.TRANSLUCENCY_BY_DISTANCE_INDEX=7,wet=rs.DISTANCE_DISPLAY_CONDITION_INDEX=8,xet=rs.DISABLE_DEPTH_DISTANCE_INDEX=9;rs.NUMBER_OF_PROPERTIES=10;Object.defineProperties(rs.prototype,{show:{get:function(){return this._show},set:function(t){if(!m(t))throw new Y("value is required.");this._show!==t&&(this._show=t,wr(this,Gy))}},position:{get:function(){return this._position},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._position;l.equals(e,t)||(l.clone(t,e),l.clone(t,this._actualPosition),wr(this,Dy))}},scaleByDistance:{get:function(){return this._scaleByDistance},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far distance must be greater than near distance.");let e=this._scaleByDistance;gi.equals(e,t)||(this._scaleByDistance=gi.clone(t,e),wr(this,Let))}},translucencyByDistance:{get:function(){return this._translucencyByDistance},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far distance must be greater than near distance.");let e=this._translucencyByDistance;gi.equals(e,t)||(this._translucencyByDistance=gi.clone(t,e),wr(this,yet))}},pixelSize:{get:function(){return this._pixelSize},set:function(t){if(!m(t))throw new Y("value is required.");this._pixelSize!==t&&(this._pixelSize=t,wr(this,ket))}},color:{get:function(){return this._color},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._color;Zt.equals(e,t)||(Zt.clone(t,e),wr(this,Met))}},outlineColor:{get:function(){return this._outlineColor},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._outlineColor;Zt.equals(e,t)||(Zt.clone(t,e),wr(this,Uet))}},outlineWidth:{get:function(){return this._outlineWidth},set:function(t){if(!m(t))throw new Y("value is required.");this._outlineWidth!==t&&(this._outlineWidth=t,wr(this,Qet))}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far must be greater than near");Wo.equals(this._distanceDisplayCondition,t)||(this._distanceDisplayCondition=Wo.clone(t,this._distanceDisplayCondition),wr(this,wet))}},disableDepthTestDistance:{get:function(){return this._disableDepthTestDistance},set:function(t){if(this._disableDepthTestDistance!==t){if(!m(t)||t<0)throw new Y("disableDepthTestDistance must be greater than or equal to 0.0.");this._disableDepthTestDistance=t,wr(this,xet)}}},id:{get:function(){return this._id},set:function(t){this._id=t,m(this._pickId)&&(this._pickId.object.id=t)}},pickId:{get:function(){return this._pickId}},clusterShow:{get:function(){return this._clusterShow},set:function(t){this._clusterShow!==t&&(this._clusterShow=t,wr(this,Gy))}}});rs.prototype.getPickId=function(t){return m(this._pickId)||(this._pickId=t.createPickId({primitive:this,collection:this._collection,id:this._id})),this._pickId};rs.prototype._getActualPosition=function(){return this._actualPosition};rs.prototype._setActualPosition=function(t){l.clone(t,this._actualPosition),wr(this,Dy)};By=new ie;rs._computeActualPosition=function(t,e,i){return e.mode===ye.SCENE3D?t:(at.multiplyByPoint(i,t,By),Gm.computeActualWgs84Position(e,By))};Wy=new ie;rs._computeScreenSpacePosition=function(t,e,i,n){let s=at.multiplyByVector(t,ie.fromElements(e.x,e.y,e.z,1,Wy),Wy);return Gm.wgs84ToWindowCoordinates(i,s,n)};rs.prototype.computeScreenSpacePosition=function(t,e){let i=this._pointPrimitiveCollection;if(m(e)||(e=new nt),!m(i))throw new Y("PointPrimitive must be in a collection.");if(!m(t))throw new Y("scene is required.");let n=i.modelMatrix,s=rs._computeScreenSpacePosition(n,this._actualPosition,t,e);if(m(s))return s.y=t.canvas.clientHeight-s.y,s};rs.getScreenSpaceBoundingBox=function(t,e,i){let n=t.pixelSize,s=n*.5,o=e.x-s,r=e.y-s,a=n,h=n;return m(i)||(i=new mi),i.x=o,i.y=r,i.width=a,i.height=h,i};rs.prototype.equals=function(t){return this===t||m(t)&&this._id===t._id&&l.equals(this._position,t._position)&&Zt.equals(this._color,t._color)&&this._pixelSize===t._pixelSize&&this._outlineWidth===t._outlineWidth&&this._show===t._show&&Zt.equals(this._outlineColor,t._outlineColor)&&gi.equals(this._scaleByDistance,t._scaleByDistance)&&gi.equals(this._translucencyByDistance,t._translucencyByDistance)&&Wo.equals(this._distanceDisplayCondition,t._distanceDisplayCondition)&&this._disableDepthTestDistance===t._disableDepthTestDistance};rs.prototype._destroy=function(){this._pickId=this._pickId&&this._pickId.destroy(),this._pointPrimitiveCollection=void 0};uo=rs});var UE,My=O(()=>{UE=`in vec4 v_color;
in vec4 v_outlineColor;
in float v_innerPercent;
in float v_pixelDistance;
in vec4 v_pickColor;

void main()
{
    // The distance in UV space from this fragment to the center of the point, at most 0.5.
    float distanceToCenter = length(gl_PointCoord - vec2(0.5));
    // The max distance stops one pixel shy of the edge to leave space for anti-aliasing.
    float maxDistance = max(0.0, 0.5 - v_pixelDistance);
    float wholeAlpha = 1.0 - smoothstep(maxDistance, 0.5, distanceToCenter);
    float innerAlpha = 1.0 - smoothstep(maxDistance * v_innerPercent, 0.5 * v_innerPercent, distanceToCenter);

    vec4 color = mix(v_outlineColor, v_color, innerAlpha);
    color.a *= wholeAlpha;

// Fully transparent parts of the billboard are not pickable.
#if !defined(OPAQUE) && !defined(TRANSLUCENT)
    if (color.a < 0.005)   // matches 0/255 and 1/255
    {
        discard;
    }
#else
// The billboard is rendered twice. The opaque pass discards translucent fragments
// and the translucent pass discards opaque fragments.
#ifdef OPAQUE
    if (color.a < 0.995)   // matches < 254/255
    {
        discard;
    }
#else
    if (color.a >= 0.995)  // matches 254/255 and 255/255
    {
        discard;
    }
#endif
#endif

    out_FragColor = czm_gammaCorrect(color);
    czm_writeLogDepth();
}
`});var Uy,Qy=O(()=>{Uy=`uniform float u_maxTotalPointSize;

in vec4 positionHighAndSize;
in vec4 positionLowAndOutline;
in vec4 compressedAttribute0;                       // color, outlineColor, pick color
in vec4 compressedAttribute1;                       // show, translucency by distance, some free space
in vec4 scaleByDistance;                            // near, nearScale, far, farScale
in vec3 distanceDisplayConditionAndDisableDepth;    // near, far, disableDepthTestDistance

out vec4 v_color;
out vec4 v_outlineColor;
out float v_innerPercent;
out float v_pixelDistance;
out vec4 v_pickColor;

const float SHIFT_LEFT8 = 256.0;
const float SHIFT_RIGHT8 = 1.0 / 256.0;

void main()
{
    // Modifying this shader may also require modifications to PointPrimitive._computeScreenSpacePosition

    // unpack attributes
    vec3 positionHigh = positionHighAndSize.xyz;
    vec3 positionLow = positionLowAndOutline.xyz;
    float outlineWidthBothSides = 2.0 * positionLowAndOutline.w;
    float totalSize = positionHighAndSize.w + outlineWidthBothSides;
    float outlinePercent = outlineWidthBothSides / totalSize;
    // Scale in response to browser-zoom.
    totalSize *= czm_pixelRatio;

    float temp = compressedAttribute1.x * SHIFT_RIGHT8;
    float show = floor(temp);

#ifdef EYE_DISTANCE_TRANSLUCENCY
    vec4 translucencyByDistance;
    translucencyByDistance.x = compressedAttribute1.z;
    translucencyByDistance.z = compressedAttribute1.w;

    translucencyByDistance.y = ((temp - floor(temp)) * SHIFT_LEFT8) / 255.0;

    temp = compressedAttribute1.y * SHIFT_RIGHT8;
    translucencyByDistance.w = ((temp - floor(temp)) * SHIFT_LEFT8) / 255.0;
#endif

    ///////////////////////////////////////////////////////////////////////////

    vec4 color;
    vec4 outlineColor;
    vec4 pickColor;

    // compressedAttribute0.z => pickColor.rgb

    temp = compressedAttribute0.z * SHIFT_RIGHT8;
    pickColor.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    pickColor.g = (temp - floor(temp)) * SHIFT_LEFT8;
    pickColor.r = floor(temp);

    // compressedAttribute0.x => color.rgb

    temp = compressedAttribute0.x * SHIFT_RIGHT8;
    color.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    color.g = (temp - floor(temp)) * SHIFT_LEFT8;
    color.r = floor(temp);

    // compressedAttribute0.y => outlineColor.rgb

    temp = compressedAttribute0.y * SHIFT_RIGHT8;
    outlineColor.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    outlineColor.g = (temp - floor(temp)) * SHIFT_LEFT8;
    outlineColor.r = floor(temp);

    // compressedAttribute0.w => color.a, outlineColor.a, pickColor.a

    temp = compressedAttribute0.w * SHIFT_RIGHT8;
    pickColor.a = (temp - floor(temp)) * SHIFT_LEFT8;
    pickColor = pickColor / 255.0;

    temp = floor(temp) * SHIFT_RIGHT8;
    outlineColor.a = (temp - floor(temp)) * SHIFT_LEFT8;
    outlineColor /= 255.0;
    color.a = floor(temp);
    color /= 255.0;

    ///////////////////////////////////////////////////////////////////////////

    vec4 p = czm_translateRelativeToEye(positionHigh, positionLow);
    vec4 positionEC = czm_modelViewRelativeToEye * p;

    ///////////////////////////////////////////////////////////////////////////

#if defined(EYE_DISTANCE_SCALING) || defined(EYE_DISTANCE_TRANSLUCENCY) || defined(DISTANCE_DISPLAY_CONDITION) || defined(DISABLE_DEPTH_DISTANCE)
    float lengthSq;
    if (czm_sceneMode == czm_sceneMode2D)
    {
        // 2D camera distance is a special case
        // treat all billboards as flattened to the z=0.0 plane
        lengthSq = czm_eyeHeight2D.y;
    }
    else
    {
        lengthSq = dot(positionEC.xyz, positionEC.xyz);
    }
#endif

#ifdef EYE_DISTANCE_SCALING
    totalSize *= czm_nearFarScalar(scaleByDistance, lengthSq);
#endif
    if (totalSize > 0.0) {
        // Add padding for anti-aliasing on both sides.
        totalSize += 3.0;
    }

    // Clamp to max point size.
    totalSize = min(totalSize, u_maxTotalPointSize);
    // If size is too small, push vertex behind near plane for clipping.
    // Note that context.minimumAliasedPointSize "will be at most 1.0".
    if (totalSize < 1.0)
    {
        positionEC.xyz = vec3(0.0);
        totalSize = 1.0;
    }

    float translucency = 1.0;
#ifdef EYE_DISTANCE_TRANSLUCENCY
    translucency = czm_nearFarScalar(translucencyByDistance, lengthSq);
    // push vertex behind near plane for clipping
    if (translucency < 0.004)
    {
        positionEC.xyz = vec3(0.0);
    }
#endif

#ifdef DISTANCE_DISPLAY_CONDITION
    float nearSq = distanceDisplayConditionAndDisableDepth.x;
    float farSq = distanceDisplayConditionAndDisableDepth.y;
    if (lengthSq < nearSq || lengthSq > farSq) {
        // push vertex behind camera to force it to be clipped
        positionEC.xyz = vec3(0.0, 0.0, 1.0);
    }
#endif

    gl_Position = czm_projection * positionEC;
    czm_vertexLogDepth();

#ifdef DISABLE_DEPTH_DISTANCE
    float disableDepthTestDistance = distanceDisplayConditionAndDisableDepth.z;
    if (disableDepthTestDistance == 0.0 && czm_minimumDisableDepthTestDistance != 0.0)
    {
        disableDepthTestDistance = czm_minimumDisableDepthTestDistance;
    }

    if (disableDepthTestDistance != 0.0)
    {
        // Don't try to "multiply both sides" by w.  Greater/less-than comparisons won't work for negative values of w.
        float zclip = gl_Position.z / gl_Position.w;
        bool clipped = (zclip < -1.0 || zclip > 1.0);
        if (!clipped && (disableDepthTestDistance < 0.0 || (lengthSq > 0.0 && lengthSq < disableDepthTestDistance)))
        {
            // Position z on the near plane.
            gl_Position.z = -gl_Position.w;
#ifdef LOG_DEPTH
            czm_vertexLogDepth(vec4(czm_currentFrustum.x));
#endif
        }
    }
#endif

    v_color = color;
    v_color.a *= translucency * show;
    v_outlineColor = outlineColor;
    v_outlineColor.a *= translucency * show;

    v_innerPercent = 1.0 - outlinePercent;
    v_pixelDistance = 2.0 / totalSize;
    gl_PointSize = totalSize * show;
    gl_Position *= show;

    v_pickColor = pickColor;
}
`});function xr(t){t=Z(t,Z.EMPTY_OBJECT),this._sp=void 0,this._spTranslucent=void 0,this._rsOpaque=void 0,this._rsTranslucent=void 0,this._vaf=void 0,this._pointPrimitives=[],this._pointPrimitivesToUpdate=[],this._pointPrimitivesToUpdateIndex=0,this._pointPrimitivesRemoved=!1,this._createVertexArray=!1,this._shaderScaleByDistance=!1,this._compiledShaderScaleByDistance=!1,this._shaderTranslucencyByDistance=!1,this._compiledShaderTranslucencyByDistance=!1,this._shaderDistanceDisplayCondition=!1,this._compiledShaderDistanceDisplayCondition=!1,this._shaderDisableDepthDistance=!1,this._compiledShaderDisableDepthDistance=!1,this._propertiesChanged=new Uint32Array(eN),this._maxPixelSize=1,this._baseVolume=new Nt,this._baseVolumeWC=new Nt,this._baseVolume2D=new Nt,this._boundingVolume=new Nt,this._boundingVolumeDirty=!1,this._colorCommands=[],this.show=Z(t.show,!0),this.modelMatrix=at.clone(Z(t.modelMatrix,at.IDENTITY)),this._modelMatrix=at.clone(at.IDENTITY),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.blendOption=Z(t.blendOption,Wn.OPAQUE_AND_TRANSLUCENT),this._blendOption=void 0,this._mode=ye.SCENE3D,this._maxTotalPointSize=1,this._buffersUsage=[ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW];let e=this;this._uniforms={u_maxTotalPointSize:function(){return e._maxTotalPointSize}}}function xy(t){let e=t.length;for(let i=0;i<e;++i)t[i]&&t[i]._destroy()}function iN(t){if(t._pointPrimitivesRemoved){t._pointPrimitivesRemoved=!1;let e=[],i=t._pointPrimitives,n=i.length;for(let s=0,o=0;s<n;++s){let r=i[s];r&&(r._index=o++,e.push(r))}t._pointPrimitives=e}}function zet(t,e,i){return new fI(t,[{index:Co.positionHighAndSize,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[tN]},{index:Co.positionLowAndShow,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[tN]},{index:Co.compressedAttribute0,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[ky]},{index:Co.compressedAttribute1,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[yy]},{index:Co.scaleByDistance,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[Ly]},{index:Co.distanceDisplayConditionAndDisableDepth,componentsPerAttribute:3,componentDatatype:At.FLOAT,usage:i[wy]}],e)}function Py(t,e,i,n){let s=n._index,o=n._getActualPosition();t._mode===ye.SCENE3D&&(Nt.expand(t._baseVolume,o,t._baseVolume),t._boundingVolumeDirty=!0),Bn.fromCartesian(o,qT);let r=n.pixelSize,a=n.outlineWidth;t._maxPixelSize=Math.max(t._maxPixelSize,r+a);let h=i[Co.positionHighAndSize],A=qT.high;h(s,A.x,A.y,A.z,r);let d=i[Co.positionLowAndOutline],f=qT.low;d(s,f.x,f.y,f.z,a)}function Jy(t,e,i,n){let s=n._index,o=n.color,r=n.getPickId(e).color,a=n.outlineColor,h=Zt.floatToByte(o.red),A=Zt.floatToByte(o.green),d=Zt.floatToByte(o.blue),f=h*TI+A*QE+d;h=Zt.floatToByte(a.red),A=Zt.floatToByte(a.green),d=Zt.floatToByte(a.blue);let E=h*TI+A*QE+d;h=Zt.floatToByte(r.red),A=Zt.floatToByte(r.green),d=Zt.floatToByte(r.blue);let _=h*TI+A*QE+d,R=Zt.floatToByte(o.alpha)*TI+Zt.floatToByte(a.alpha)*QE+Zt.floatToByte(r.alpha),I=i[Co.compressedAttribute0];I(s,f,E,_,R)}function jy(t,e,i,n){let s=n._index,o=0,r=1,a=1,h=1,A=n.translucencyByDistance;m(A)&&(o=A.near,r=A.nearValue,a=A.far,h=A.farValue,(r!==1||h!==1)&&(t._shaderTranslucencyByDistance=!0));let d=n.show&&n.clusterShow;n.color.alpha===0&&n.outlineColor.alpha===0&&(d=!1),r=L.clamp(r,0,1),r=r===1?255:r*255|0;let f=(d?1:0)*QE+r;h=L.clamp(h,0,1),h=h===1?255:h*255|0;let E=h,_=i[Co.compressedAttribute1];_(s,f,E,o,a)}function Hy(t,e,i,n){let s=n._index,o=i[Co.scaleByDistance],r=0,a=1,h=1,A=1,d=n.scaleByDistance;m(d)&&(r=d.near,a=d.nearValue,h=d.far,A=d.farValue,(a!==1||A!==1)&&(t._shaderScaleByDistance=!0)),o(s,r,a,h,A)}function vy(t,e,i,n){let s=n._index,o=i[Co.distanceDisplayConditionAndDisableDepth],r=0,a=Number.MAX_VALUE,h=n.distanceDisplayCondition;m(h)&&(r=h.near,a=h.far,r*=r,a*=a,t._shaderDistanceDisplayCondition=!0);let A=n.disableDepthTestDistance;A*=A,A>0&&(t._shaderDisableDepthDistance=!0,A===Number.POSITIVE_INFINITY&&(A=-1)),o(s,r,a,A)}function Ket(t,e,i,n){Py(t,e,i,n),Jy(t,e,i,n),jy(t,e,i,n),Hy(t,e,i,n),vy(t,e,i,n)}function $T(t,e,i,n,s,o){let r;n.mode===ye.SCENE3D?(r=t._baseVolume,t._boundingVolumeDirty=!0):r=t._baseVolume2D;let a=[];for(let h=0;h<i;++h){let A=e[h],d=A.position,f=uo._computeActualPosition(d,n,s);m(f)&&(A._setActualPosition(f),o?a.push(f):Nt.expand(r,f,r))}o&&Nt.fromPoints(a,r)}function Xet(t,e){let i=e.mode,n=t._pointPrimitives,s=t._pointPrimitivesToUpdate,o=t._modelMatrix;t._createVertexArray||t._mode!==i||i!==ye.SCENE3D&&!at.equals(o,t.modelMatrix)?(t._mode=i,at.clone(t.modelMatrix,o),t._createVertexArray=!0,(i===ye.SCENE3D||i===ye.SCENE2D||i===ye.COLUMBUS_VIEW)&&$T(t,n,n.length,e,o,!0)):i===ye.MORPHING?$T(t,n,n.length,e,o,!0):(i===ye.SCENE2D||i===ye.COLUMBUS_VIEW)&&$T(t,s,t._pointPrimitivesToUpdateIndex,e,o,!1)}function qet(t,e,i){let s=e.camera.getPixelSize(i,e.context.drawingBufferWidth,e.context.drawingBufferHeight)*t._maxPixelSize;i.radius+=s}var Pet,tN,ky,Jet,jet,Het,Ly,yy,wy,vet,eN,Co,qT,TI,QE,$et,nN,zy=O(()=>{_i();Qn();oi();bt();mt();Ws();Vt();Tl();_e();Fi();Xi();ss();Nl();ga();Bm();Wm();Mm();Qm();Fl();BT();My();Qy();km();EI();XT();ua();Pet=uo.SHOW_INDEX,tN=uo.POSITION_INDEX,ky=uo.COLOR_INDEX,Jet=uo.OUTLINE_COLOR_INDEX,jet=uo.OUTLINE_WIDTH_INDEX,Het=uo.PIXEL_SIZE_INDEX,Ly=uo.SCALE_BY_DISTANCE_INDEX,yy=uo.TRANSLUCENCY_BY_DISTANCE_INDEX,wy=uo.DISTANCE_DISPLAY_CONDITION_INDEX,vet=uo.DISABLE_DEPTH_DISTANCE_INDEX,eN=uo.NUMBER_OF_PROPERTIES,Co={positionHighAndSize:0,positionLowAndOutline:1,compressedAttribute0:2,compressedAttribute1:3,scaleByDistance:4,distanceDisplayConditionAndDisableDepth:5};Object.defineProperties(xr.prototype,{length:{get:function(){return iN(this),this._pointPrimitives.length}}});xr.prototype.add=function(t){let e=new uo(t,this);return e._index=this._pointPrimitives.length,this._pointPrimitives.push(e),this._createVertexArray=!0,e};xr.prototype.remove=function(t){return this.contains(t)?(this._pointPrimitives[t._index]=null,this._pointPrimitivesRemoved=!0,this._createVertexArray=!0,t._destroy(),!0):!1};xr.prototype.removeAll=function(){xy(this._pointPrimitives),this._pointPrimitives=[],this._pointPrimitivesToUpdate=[],this._pointPrimitivesToUpdateIndex=0,this._pointPrimitivesRemoved=!1,this._createVertexArray=!0};xr.prototype._updatePointPrimitive=function(t,e){t._dirty||(this._pointPrimitivesToUpdate[this._pointPrimitivesToUpdateIndex++]=t),++this._propertiesChanged[e]};xr.prototype.contains=function(t){return m(t)&&t._pointPrimitiveCollection===this};xr.prototype.get=function(t){if(!m(t))throw new Y("index is required.");return iN(this),this._pointPrimitives[t]};xr.prototype.computeNewBuffersUsage=function(){let t=this._buffersUsage,e=!1,i=this._propertiesChanged;for(let n=0;n<eN;++n){let s=i[n]===0?ai.STATIC_DRAW:ai.STREAM_DRAW;e=e||t[n]!==s,t[n]=s}return e};qT=new Bn;TI=65536,QE=256;$et=[];xr.prototype.update=function(t){if(iN(this),!this.show)return;this._maxTotalPointSize=en.maximumAliasedPointSize,Xet(this,t);let i=this._pointPrimitives.length,n=this._pointPrimitivesToUpdate,s=this._pointPrimitivesToUpdateIndex,o=this._propertiesChanged,r=this._createVertexArray,a,h=t.context,A=t.passes,d=A.pick;if(r||!d&&this.computeNewBuffersUsage()){this._createVertexArray=!1;for(let G=0;G<eN;++G)o[G]=0;if(this._vaf=this._vaf&&this._vaf.destroy(),i>0){this._vaf=zet(h,i,this._buffersUsage),a=this._vaf.writers;for(let G=0;G<i;++G){let M=this._pointPrimitives[G];M._dirty=!1,Ket(this,h,a,M)}this._vaf.commit()}this._pointPrimitivesToUpdateIndex=0}else if(s>0){let G=$et;G.length=0,(o[tN]||o[jet]||o[Het])&&G.push(Py),(o[ky]||o[Jet])&&G.push(Jy),(o[Pet]||o[yy])&&G.push(jy),o[Ly]&&G.push(Hy),(o[wy]||o[vet])&&G.push(vy);let M=G.length;if(a=this._vaf.writers,s/i>.1){for(let Q=0;Q<s;++Q){let U=n[Q];U._dirty=!1;for(let k=0;k<M;++k)G[k](this,h,a,U)}this._vaf.commit()}else{for(let Q=0;Q<s;++Q){let U=n[Q];U._dirty=!1;for(let k=0;k<M;++k)G[k](this,h,a,U);this._vaf.subCommit(U._index,1)}this._vaf.endSubCommits()}this._pointPrimitivesToUpdateIndex=0}if(s>i*1.5&&(n.length=i),!m(this._vaf)||!m(this._vaf.va))return;this._boundingVolumeDirty&&(this._boundingVolumeDirty=!1,Nt.transform(this._baseVolume,this.modelMatrix,this._baseVolumeWC));let f,E=at.IDENTITY;t.mode===ye.SCENE3D?(E=this.modelMatrix,f=Nt.clone(this._baseVolumeWC,this._boundingVolume)):f=Nt.clone(this._baseVolume2D,this._boundingVolume),qet(this,t,f);let _=this._blendOption!==this.blendOption;this._blendOption=this.blendOption,_&&(this._blendOption===Wn.OPAQUE||this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT?this._rsOpaque=Yn.fromCache({depthTest:{enabled:!0,func:it.LEQUAL},depthMask:!0}):this._rsOpaque=void 0,this._blendOption===Wn.TRANSLUCENT||this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT?this._rsTranslucent=Yn.fromCache({depthTest:{enabled:!0,func:it.LEQUAL},depthMask:!1,blending:Ur.ALPHA_BLEND}):this._rsTranslucent=void 0),this._shaderDisableDepthDistance=this._shaderDisableDepthDistance||t.minimumDisableDepthTestDistance!==0;let R,I;(_||this._shaderScaleByDistance&&!this._compiledShaderScaleByDistance||this._shaderTranslucencyByDistance&&!this._compiledShaderTranslucencyByDistance||this._shaderDistanceDisplayCondition&&!this._compiledShaderDistanceDisplayCondition||this._shaderDisableDepthDistance!==this._compiledShaderDisableDepthDistance)&&(R=new Mi({sources:[Uy]}),this._shaderScaleByDistance&&R.defines.push("EYE_DISTANCE_SCALING"),this._shaderTranslucencyByDistance&&R.defines.push("EYE_DISTANCE_TRANSLUCENCY"),this._shaderDistanceDisplayCondition&&R.defines.push("DISTANCE_DISPLAY_CONDITION"),this._shaderDisableDepthDistance&&R.defines.push("DISABLE_DEPTH_DISTANCE"),this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT&&(I=new Mi({defines:["OPAQUE"],sources:[UE]}),this._sp=Es.replaceCache({context:h,shaderProgram:this._sp,vertexShaderSource:R,fragmentShaderSource:I,attributeLocations:Co}),I=new Mi({defines:["TRANSLUCENT"],sources:[UE]}),this._spTranslucent=Es.replaceCache({context:h,shaderProgram:this._spTranslucent,vertexShaderSource:R,fragmentShaderSource:I,attributeLocations:Co})),this._blendOption===Wn.OPAQUE&&(I=new Mi({sources:[UE]}),this._sp=Es.replaceCache({context:h,shaderProgram:this._sp,vertexShaderSource:R,fragmentShaderSource:I,attributeLocations:Co})),this._blendOption===Wn.TRANSLUCENT&&(I=new Mi({sources:[UE]}),this._spTranslucent=Es.replaceCache({context:h,shaderProgram:this._spTranslucent,vertexShaderSource:R,fragmentShaderSource:I,attributeLocations:Co})),this._compiledShaderScaleByDistance=this._shaderScaleByDistance,this._compiledShaderTranslucencyByDistance=this._shaderTranslucencyByDistance,this._compiledShaderDistanceDisplayCondition=this._shaderDistanceDisplayCondition,this._compiledShaderDisableDepthDistance=this._shaderDisableDepthDistance);let C,N,T,F,b=t.commandList;if(A.render||d){let G=this._colorCommands,M=this._blendOption===Wn.OPAQUE,Q=this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT;C=this._vaf.va,N=C.length,G.length=N;let U=Q?N*2:N;for(F=0;F<U;++F){let k=M||Q&&F%2===0;T=G[F],m(T)||(T=G[F]=new fn),T.primitiveType=ne.POINTS,T.pass=k||!Q?os.OPAQUE:os.TRANSLUCENT,T.owner=this;let y=Q?Math.floor(F/2):F;T.boundingVolume=f,T.modelMatrix=E,T.shaderProgram=k?this._sp:this._spTranslucent,T.uniformMap=this._uniforms,T.vertexArray=C[y].va,T.renderState=k?this._rsOpaque:this._rsTranslucent,T.debugShowBoundingVolume=this.debugShowBoundingVolume,T.pickId="v_pickColor",b.push(T)}}};xr.prototype.isDestroyed=function(){return!1};xr.prototype.destroy=function(){return this._sp=this._sp&&this._sp.destroy(),this._spTranslucent=this._spTranslucent&&this._spTranslucent.destroy(),this._spPick=this._spPick&&this._spPick.destroy(),this._vaf=this._vaf&&this._vaf.destroy(),xy(this._pointPrimitives),li(this)};nN=xr});function rN(t,e,i,n,s,o){if(s-n<=i)return;let r=n+s>>1;qy(t,e,r,n,s,o),rN(t,e,i,n,r-1,1-o),rN(t,e,i,r+1,s,1-o)}function qy(t,e,i,n,s,o){for(;s>n;){if(s-n>600){let A=s-n+1,d=i-n+1,f=Math.log(A),E=.5*Math.exp(2*f/3),_=.5*Math.sqrt(f*E*(A-E)/A)*(d-A/2<0?-1:1),R=Math.max(n,Math.floor(i-d*E/A+_)),I=Math.min(s,Math.floor(i+(A-d)*E/A+_));qy(t,e,i,R,I,o)}let r=e[2*i+o],a=n,h=s;for(LE(t,e,n,i),e[2*s+o]>r&&LE(t,e,n,s);a<h;){for(LE(t,e,a,h),a++,h--;e[2*a+o]<r;)a++;for(;e[2*h+o]>r;)h--}e[2*n+o]===r?LE(t,e,n,h):(h++,LE(t,e,h,s)),h<=i&&(n=h+1),i<=h&&(s=h-1)}}function LE(t,e,i,n){oN(t,i,n),oN(e,2*i,2*n),oN(e,2*i+1,2*n+1)}function oN(t,e,i){let n=t[e];t[e]=t[i],t[i]=n}function Xy(t,e,i,n){let s=t-i,o=e-n;return s*s+o*o}var Ky,sN,kE,yE,$y=O(()=>{Ky=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],sN=1,kE=8,yE=class t{static from(e){if(!(e instanceof ArrayBuffer))throw new Error("Data must be an instance of ArrayBuffer.");let[i,n]=new Uint8Array(e,0,2);if(i!==219)throw new Error("Data does not appear to be in a KDBush format.");let s=n>>4;if(s!==sN)throw new Error(`Got v${s} data when expected v${sN}.`);let o=Ky[n&15];if(!o)throw new Error("Unrecognized array type.");let[r]=new Uint16Array(e,2,1),[a]=new Uint32Array(e,4,1);return new t(a,r,o,e)}constructor(e,i=64,n=Float64Array,s){if(isNaN(e)||e<0)throw new Error(`Unpexpected numItems value: ${e}.`);this.numItems=+e,this.nodeSize=Math.min(Math.max(+i,2),65535),this.ArrayType=n,this.IndexArrayType=e<65536?Uint16Array:Uint32Array;let o=Ky.indexOf(this.ArrayType),r=e*2*this.ArrayType.BYTES_PER_ELEMENT,a=e*this.IndexArrayType.BYTES_PER_ELEMENT,h=(8-a%8)%8;if(o<0)throw new Error(`Unexpected typed array class: ${n}.`);s&&s instanceof ArrayBuffer?(this.data=s,this.ids=new this.IndexArrayType(this.data,kE,e),this.coords=new this.ArrayType(this.data,kE+a+h,e*2),this._pos=e*2,this._finished=!0):(this.data=new ArrayBuffer(kE+r+a+h),this.ids=new this.IndexArrayType(this.data,kE,e),this.coords=new this.ArrayType(this.data,kE+a+h,e*2),this._pos=0,this._finished=!1,new Uint8Array(this.data,0,2).set([219,(sN<<4)+o]),new Uint16Array(this.data,2,1)[0]=i,new Uint32Array(this.data,4,1)[0]=e)}add(e,i){let n=this._pos>>1;return this.ids[n]=n,this.coords[this._pos++]=e,this.coords[this._pos++]=i,n}finish(){let e=this._pos>>1;if(e!==this.numItems)throw new Error(`Added ${e} items when expected ${this.numItems}.`);return rN(this.ids,this.coords,this.nodeSize,0,this.numItems-1,0),this._finished=!0,this}range(e,i,n,s){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");let{ids:o,coords:r,nodeSize:a}=this,h=[0,o.length-1,0],A=[];for(;h.length;){let d=h.pop()||0,f=h.pop()||0,E=h.pop()||0;if(f-E<=a){for(let C=E;C<=f;C++){let N=r[2*C],T=r[2*C+1];N>=e&&N<=n&&T>=i&&T<=s&&A.push(o[C])}continue}let _=E+f>>1,R=r[2*_],I=r[2*_+1];R>=e&&R<=n&&I>=i&&I<=s&&A.push(o[_]),(d===0?e<=R:i<=I)&&(h.push(E),h.push(_-1),h.push(1-d)),(d===0?n>=R:s>=I)&&(h.push(_+1),h.push(f),h.push(1-d))}return A}within(e,i,n){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");let{ids:s,coords:o,nodeSize:r}=this,a=[0,s.length-1,0],h=[],A=n*n;for(;a.length;){let d=a.pop()||0,f=a.pop()||0,E=a.pop()||0;if(f-E<=r){for(let C=E;C<=f;C++)Xy(o[2*C],o[2*C+1],e,i)<=A&&h.push(s[C]);continue}let _=E+f>>1,R=o[2*_],I=o[2*_+1];Xy(R,I,e,i)<=A&&h.push(s[_]),(d===0?e-n<=R:i-n<=I)&&(a.push(E),a.push(_-1),a.push(1-d)),(d===0?e+n>=R:i+n>=I)&&(a.push(_+1),a.push(f),a.push(1-d))}return h}}});function Sa(t){t=Z(t,Z.EMPTY_OBJECT),this._enabled=Z(t.enabled,!1),this._pixelRange=Z(t.pixelRange,80),this._minimumClusterSize=Z(t.minimumClusterSize,2),this._clusterBillboards=Z(t.clusterBillboards,!0),this._clusterLabels=Z(t.clusterLabels,!0),this._clusterPoints=Z(t.clusterPoints,!0),this._labelCollection=void 0,this._billboardCollection=void 0,this._pointCollection=void 0,this._clusterBillboardCollection=void 0,this._clusterLabelCollection=void 0,this._clusterPointCollection=void 0,this._collectionIndicesByEntity={},this._unusedLabelIndices=[],this._unusedBillboardIndices=[],this._unusedPointIndices=[],this._previousClusters=[],this._previousHeight=void 0,this._enabledDirty=!1,this._clusterDirty=!1,this._cluster=void 0,this._removeEventListener=void 0,this._clusterEvent=new We,this.show=Z(t.show,!0)}function tw(t,e){t.x-=e,t.y-=e,t.width+=e*2,t.height+=e*2}function ew(t,e,i,n,s){if(m(t._labelCollection)&&n._clusterLabels?s=DE.getScreenSpaceBoundingBox(t,e,s):m(t._billboardCollection)&&n._clusterBillboards?s=un.getScreenSpaceBoundingBox(t,e,s):m(t._pointPrimitiveCollection)&&n._clusterPoints&&(s=uo.getScreenSpaceBoundingBox(t,e,s)),tw(s,i),n._clusterLabels&&!m(t._labelCollection)&&m(t.id)&&nw(n,t.id.id)&&m(t.id._label)){let o=n._collectionIndicesByEntity[t.id.id].labelIndex,r=n._labelCollection.get(o),a=DE.getScreenSpaceBoundingBox(r,e,tit);tw(a,i),s=mi.union(s,a,s)}return s}function eit(t,e){if(t.clusterShow=!0,!m(t._labelCollection)&&m(t.id)&&nw(e,t.id.id)&&m(t.id._label)){let i=e._collectionIndicesByEntity[t.id.id].labelIndex,n=e._labelCollection.get(i);n.clusterShow=!0}}function iw(t,e,i,n){let s={billboard:n._clusterBillboardCollection.add(),label:n._clusterLabelCollection.add(),point:n._clusterPointCollection.add()};s.billboard.show=!1,s.point.show=!1,s.label.show=!0,s.label.text=e.toLocaleString(),s.label.id=i,s.billboard.position=s.label.position=s.point.position=t,n._clusterEvent.raiseEvent(i,s)}function nw(t,e){return m(t)&&m(t._collectionIndicesByEntity[e])&&m(t._collectionIndicesByEntity[e].labelIndex)}function aN(t,e,i,n,s){if(!m(t))return;let o=t.length;for(let r=0;r<o;++r){let a=t.get(r);if(a.clusterShow=!1,!a.show||s._scene.mode===ye.SCENE3D&&!n.isPointVisible(a.position))continue;let h=s._clusterLabels&&m(a._labelCollection),A=s._clusterBillboards&&m(a.id._billboard),d=s._clusterPoints&&m(a.id._point);if(h&&(d||A))continue;let f=a.computeScreenSpacePosition(i);m(f)&&e.push({index:r,collection:t,clustered:!1,coord:f})}}function oit(t){return function(e){if(m(e)&&e<.05||!t.enabled)return;let i=t._scene,n=t._labelCollection,s=t._billboardCollection,o=t._pointCollection;if(!m(n)&&!m(s)&&!m(o)||!t._clusterBillboards&&!t._clusterLabels&&!t._clusterPoints)return;let r=t._clusterLabelCollection,a=t._clusterBillboardCollection,h=t._clusterPointCollection;m(r)?r.removeAll():r=t._clusterLabelCollection=new KT({scene:i}),m(a)?a.removeAll():a=t._clusterBillboardCollection=new wm({scene:i}),m(h)?h.removeAll():h=t._clusterPointCollection=new nN;let A=t._pixelRange,d=t._minimumClusterSize,f=t._previousClusters,E=[],_=t._previousHeight,R=i.camera.positionCartographic.height,I=i.mapProjection.ellipsoid,C=i.camera.positionWC,N=new dA(I,C),T=[];t._clusterLabels&&aN(n,T,i,N,t),t._clusterBillboards&&aN(s,T,i,N,t),t._clusterPoints&&aN(o,T,i,N,t);let F,b,G,M,Q,U,k,y,c,g,V,D;if(T.length>0){let w=new yE(T.length,64,Uint32Array);for(let x=0;x<T.length;++x)w.add(T[x].coord.x,T[x].coord.y);if(w.finish(),R<_)for(G=f.length,F=0;F<G;++F){let x=f[F];if(!N.isPointVisible(x.position))continue;let H=un._computeScreenSpacePosition(at.IDENTITY,x.position,l.ZERO,nt.ZERO,i);if(!m(H))continue;let j=1-R/_,X=x.width=x.width*j,tt=x.height=x.height*j;X=Math.max(X,x.minimumWidth),tt=Math.max(tt,x.minimumHeight);let B=H.x-X*.5,It=H.y-tt*.5,gt=H.x+X,Yt=H.y+tt;for(Q=w.range(B,It,gt,Yt),U=Q.length,g=0,c=[],b=0;b<U;++b)k=Q[b],y=T[k],y.clustered||(++g,V=y.collection,D=y.index,c.push(V.get(D).id));if(g>=d)for(iw(x.position,g,c,t),E.push(x),b=0;b<U;++b)T[Q[b]].clustered=!0}for(G=T.length,F=0;F<G;++F){let x=T[F];if(x.clustered)continue;x.clustered=!0,V=x.collection,D=x.index;let H=V.get(D);M=ew(H,x.coord,A,t,iit);let j=mi.clone(M,nit);Q=w.range(M.x,M.y,M.x+M.width,M.y+M.height),U=Q.length;let X=l.clone(H.position);for(g=1,c=[H.id],b=0;b<U;++b)if(k=Q[b],y=T[k],!y.clustered){let tt=y.collection.get(y.index),B=ew(tt,y.coord,A,t,sit);l.add(tt.position,X,X),mi.union(j,B,j),++g,c.push(tt.id)}if(g>=d){let tt=l.multiplyByScalar(X,1/g,X);for(iw(tt,g,c,t),E.push({position:tt,width:j.width,height:j.height,minimumWidth:M.width,minimumHeight:M.height}),b=0;b<U;++b)T[Q[b]].clustered=!0}else eit(H,t)}}r.length===0&&(r.destroy(),t._clusterLabelCollection=void 0),a.length===0&&(a.destroy(),t._clusterBillboardCollection=void 0),h.length===0&&(h.destroy(),t._clusterPointCollection=void 0),t._previousClusters=E,t._previousHeight=R}}function hN(t,e,i,n){return function(s){let o=this[t];m(this._collectionIndicesByEntity)||(this._collectionIndicesByEntity={});let r=this._collectionIndicesByEntity[s.id];if(m(r)||(r=this._collectionIndicesByEntity[s.id]={billboardIndex:void 0,labelIndex:void 0,pointIndex:void 0}),m(o)&&m(r[n]))return o.get(r[n]);m(o)||(o=this[t]=new e({scene:this._scene}));let a,h,A=this[i];A.length>0?(a=A.shift(),h=o.get(a)):(h=o.add(),a=o.length-1),r[n]=a;let d=this;return Promise.resolve().then(function(){d._clusterDirty=!0}),h}}function cN(t,e){let i=t._collectionIndicesByEntity[e];!m(i.billboardIndex)&&!m(i.labelIndex)&&!m(i.pointIndex)&&delete t._collectionIndicesByEntity[e]}function AN(t){if(!m(t))return;let e=t.length;for(let i=0;i<e;++i)t.get(i).clusterShow=!0}function rit(t){t.enabled||(m(t._clusterLabelCollection)&&t._clusterLabelCollection.destroy(),m(t._clusterBillboardCollection)&&t._clusterBillboardCollection.destroy(),m(t._clusterPointCollection)&&t._clusterPointCollection.destroy(),t._clusterLabelCollection=void 0,t._clusterBillboardCollection=void 0,t._clusterPointCollection=void 0,AN(t._labelCollection),AN(t._billboardCollection),AN(t._pointCollection))}var tit,iit,nit,sit,sw,ow=O(()=>{Er();Xe();Ht();bt();mt();Sm();xi();Fi();sI();JT();HT();Vy();XT();zy();ua();$y();tit=new mi;iit=new mi,nit=new mi,sit=new mi;Sa.prototype._initialize=function(t){this._scene=t;let e=oit(this);this._cluster=e,this._removeEventListener=t.camera.changed.addEventListener(e)};Object.defineProperties(Sa.prototype,{enabled:{get:function(){return this._enabled},set:function(t){this._enabledDirty=t!==this._enabled,this._enabled=t}},pixelRange:{get:function(){return this._pixelRange},set:function(t){this._clusterDirty=this._clusterDirty||t!==this._pixelRange,this._pixelRange=t}},minimumClusterSize:{get:function(){return this._minimumClusterSize},set:function(t){this._clusterDirty=this._clusterDirty||t!==this._minimumClusterSize,this._minimumClusterSize=t}},clusterEvent:{get:function(){return this._clusterEvent}},clusterBillboards:{get:function(){return this._clusterBillboards},set:function(t){this._clusterDirty=this._clusterDirty||t!==this._clusterBillboards,this._clusterBillboards=t}},clusterLabels:{get:function(){return this._clusterLabels},set:function(t){this._clusterDirty=this._clusterDirty||t!==this._clusterLabels,this._clusterLabels=t}},clusterPoints:{get:function(){return this._clusterPoints},set:function(t){this._clusterDirty=this._clusterDirty||t!==this._clusterPoints,this._clusterPoints=t}}});Sa.prototype.getLabel=hN("_labelCollection",KT,"_unusedLabelIndices","labelIndex");Sa.prototype.removeLabel=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!m(this._labelCollection)||!m(e)||!m(e.labelIndex))return;let i=e.labelIndex;e.labelIndex=void 0,cN(this,t.id);let n=this._labelCollection.get(i);n.show=!1,n.text="",n.id=void 0,this._unusedLabelIndices.push(i),this._clusterDirty=!0};Sa.prototype.getBillboard=hN("_billboardCollection",wm,"_unusedBillboardIndices","billboardIndex");Sa.prototype.removeBillboard=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!m(this._billboardCollection)||!m(e)||!m(e.billboardIndex))return;let i=e.billboardIndex;e.billboardIndex=void 0,cN(this,t.id);let n=this._billboardCollection.get(i);n.id=void 0,n.show=!1,n.image=void 0,this._unusedBillboardIndices.push(i),this._clusterDirty=!0};Sa.prototype.getPoint=hN("_pointCollection",nN,"_unusedPointIndices","pointIndex");Sa.prototype.removePoint=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!m(this._pointCollection)||!m(e)||!m(e.pointIndex))return;let i=e.pointIndex;e.pointIndex=void 0,cN(this,t.id);let n=this._pointCollection.get(i);n.show=!1,n.id=void 0,this._unusedPointIndices.push(i),this._clusterDirty=!0};Sa.prototype.update=function(t){if(!this.show)return;let e;m(this._labelCollection)&&this._labelCollection.length>0&&this._labelCollection.get(0)._glyphs.length===0&&(e=t.commandList,t.commandList=[],this._labelCollection.update(t),t.commandList=e),m(this._billboardCollection)&&this._billboardCollection.length>0&&!m(this._billboardCollection.get(0).width)&&(e=t.commandList,t.commandList=[],this._billboardCollection.update(t),t.commandList=e),this._enabledDirty&&(this._enabledDirty=!1,rit(this),this._clusterDirty=!0),this._clusterDirty&&(this._clusterDirty=!1,this._cluster()),m(this._clusterLabelCollection)&&this._clusterLabelCollection.update(t),m(this._clusterBillboardCollection)&&this._clusterBillboardCollection.update(t),m(this._clusterPointCollection)&&this._clusterPointCollection.update(t),m(this._labelCollection)&&this._labelCollection.update(t),m(this._billboardCollection)&&this._billboardCollection.update(t),m(this._pointCollection)&&this._pointCollection.update(t)};Sa.prototype.destroy=function(){this._labelCollection=this._labelCollection&&this._labelCollection.destroy(),this._billboardCollection=this._billboardCollection&&this._billboardCollection.destroy(),this._pointCollection=this._pointCollection&&this._pointCollection.destroy(),this._clusterLabelCollection=this._clusterLabelCollection&&this._clusterLabelCollection.destroy(),this._clusterBillboardCollection=this._clusterBillboardCollection&&this._clusterBillboardCollection.destroy(),this._clusterPointCollection=this._clusterPointCollection&&this._clusterPointCollection.destroy(),m(this._removeEventListener)&&(this._removeEventListener(),this._removeEventListener=void 0),this._labelCollection=void 0,this._billboardCollection=void 0,this._pointCollection=void 0,this._clusterBillboardCollection=void 0,this._clusterLabelCollection=void 0,this._clusterPointCollection=void 0,this._collectionIndicesByEntity=void 0,this._unusedLabelIndices=[],this._unusedBillboardIndices=[],this._unusedPointIndices=[],this._previousClusters=[],this._previousHeight=void 0,this._enabledDirty=!1,this._pixelRangeDirty=!1,this._minimumClusterSizeDirty=!1};sw=Sa});function Gl(){this._array=[],this._hash={}}var wE,rw=O(()=>{mt();Vt();Object.defineProperties(Gl.prototype,{length:{get:function(){return this._array.length}},values:{get:function(){return this._array}}});Gl.prototype.contains=function(t){if(typeof t!="string"&&typeof t!="number")throw new Y("key is required to be a string or number.");return m(this._hash[t])};Gl.prototype.set=function(t,e){if(typeof t!="string"&&typeof t!="number")throw new Y("key is required to be a string or number.");let i=this._hash[t];e!==i&&(this.remove(t),this._hash[t]=e,this._array.push(e))};Gl.prototype.get=function(t){if(typeof t!="string"&&typeof t!="number")throw new Y("key is required to be a string or number.");return this._hash[t]};Gl.prototype.remove=function(t){if(m(t)&&typeof t!="string"&&typeof t!="number")throw new Y("key is required to be a string or number.");let e=this._hash[t],i=m(e);if(i){let n=this._array;n.splice(n.indexOf(e),1),delete this._hash[t]}return i};Gl.prototype.removeAll=function(){let t=this._array;t.length>0&&(this._hash={},t.length=0)};wE=Gl});function Dn(t){t=Z(t,Z.EMPTY_OBJECT),this.start=m(t.start)?Ze.clone(t.start):new Ze,this.stop=m(t.stop)?Ze.clone(t.stop):new Ze,this.data=t.data,this.isStartIncluded=Z(t.isStartIncluded,!0),this.isStopIncluded=Z(t.isStopIncluded,!0)}var xm,NI,lN=O(()=>{ae();bt();mt();Vt();Vr();Object.defineProperties(Dn.prototype,{isEmpty:{get:function(){let t=Ze.compare(this.stop,this.start);return t<0||t===0&&(!this.isStartIncluded||!this.isStopIncluded)}}});xm={start:void 0,stop:void 0,isStartIncluded:void 0,isStopIncluded:void 0,data:void 0};Dn.fromIso8601=function(t,e){p.typeOf.object("options",t),p.typeOf.string("options.iso8601",t.iso8601);let i=t.iso8601.split("/");if(i.length!==2)throw new Y("options.iso8601 is an invalid ISO 8601 interval.");let n=Ze.fromIso8601(i[0]),s=Ze.fromIso8601(i[1]),o=Z(t.isStartIncluded,!0),r=Z(t.isStopIncluded,!0),a=t.data;return m(e)?(e.start=n,e.stop=s,e.isStartIncluded=o,e.isStopIncluded=r,e.data=a,e):(xm.start=n,xm.stop=s,xm.isStartIncluded=o,xm.isStopIncluded=r,xm.data=a,new Dn(xm))};Dn.toIso8601=function(t,e){return p.typeOf.object("timeInterval",t),`${Ze.toIso8601(t.start,e)}/${Ze.toIso8601(t.stop,e)}`};Dn.clone=function(t,e){if(m(t))return m(e)?(e.start=t.start,e.stop=t.stop,e.isStartIncluded=t.isStartIncluded,e.isStopIncluded=t.isStopIncluded,e.data=t.data,e):new Dn(t)};Dn.equals=function(t,e,i){return t===e||m(t)&&m(e)&&(t.isEmpty&&e.isEmpty||t.isStartIncluded===e.isStartIncluded&&t.isStopIncluded===e.isStopIncluded&&Ze.equals(t.start,e.start)&&Ze.equals(t.stop,e.stop)&&(t.data===e.data||m(i)&&i(t.data,e.data)))};Dn.equalsEpsilon=function(t,e,i,n){return i=Z(i,0),t===e||m(t)&&m(e)&&(t.isEmpty&&e.isEmpty||t.isStartIncluded===e.isStartIncluded&&t.isStopIncluded===e.isStopIncluded&&Ze.equalsEpsilon(t.start,e.start,i)&&Ze.equalsEpsilon(t.stop,e.stop,i)&&(t.data===e.data||m(n)&&n(t.data,e.data)))};Dn.intersect=function(t,e,i,n){if(p.typeOf.object("left",t),!m(e))return Dn.clone(Dn.EMPTY,i);let s=t.start,o=t.stop,r=e.start,a=e.stop,h=Ze.greaterThanOrEquals(r,s)&&Ze.greaterThanOrEquals(o,r),A=!h&&Ze.lessThanOrEquals(r,s)&&Ze.lessThanOrEquals(s,a);if(!h&&!A)return Dn.clone(Dn.EMPTY,i);let d=t.isStartIncluded,f=t.isStopIncluded,E=e.isStartIncluded,_=e.isStopIncluded,R=Ze.lessThan(o,a);return m(i)||(i=new Dn),i.start=h?r:s,i.isStartIncluded=d&&E||!Ze.equals(r,s)&&(h&&E||A&&d),i.stop=R?o:a,i.isStopIncluded=R?f:f&&_||!Ze.equals(a,o)&&_,i.data=m(n)?n(t.data,e.data):t.data,i};Dn.contains=function(t,e){if(p.typeOf.object("timeInterval",t),p.typeOf.object("julianDate",e),t.isEmpty)return!1;let i=Ze.compare(t.start,e);if(i===0)return t.isStartIncluded;let n=Ze.compare(e,t.stop);return n===0?t.isStopIncluded:i<0&&n<0};Dn.prototype.clone=function(t){return Dn.clone(this,t)};Dn.prototype.equals=function(t,e){return Dn.equals(this,t,e)};Dn.prototype.equalsEpsilon=function(t,e,i){return Dn.equalsEpsilon(this,t,e,i)};Dn.prototype.toString=function(){return Dn.toIso8601(this)};Dn.EMPTY=Object.freeze(new Dn({start:new Ze,stop:new Ze,isStartIncluded:!1,isStopIncluded:!1}));NI=Dn});var aw,Aw,ait,Ait,dh,hw=O(()=>{Vr();lN();aw=Object.freeze(Ze.fromIso8601("0000-01-01T00:00:00Z")),Aw=Object.freeze(Ze.fromIso8601("9999-12-31T24:00:00Z")),ait=Object.freeze(new NI({start:aw,stop:Aw})),Ait={MINIMUM_VALUE:aw,MAXIMUM_VALUE:Aw,MAXIMUM_INTERVAL:ait},dh=Ait});function Ic(t){t=Z(t,Z.EMPTY_OBJECT),this._ellipsoid=Z(t.ellipsoid,ot.WGS84),this._rectangle=Z(t.rectangle,Xt.MAX_VALUE),this._projection=new Os(this._ellipsoid),this._numberOfLevelZeroTilesX=Z(t.numberOfLevelZeroTilesX,2),this._numberOfLevelZeroTilesY=Z(t.numberOfLevelZeroTilesY,1)}var cw,lw=O(()=>{Xe();ae();bt();mt();Ve();zA();_e();pn();Object.defineProperties(Ic.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},rectangle:{get:function(){return this._rectangle}},projection:{get:function(){return this._projection}}});Ic.prototype.getNumberOfXTilesAtLevel=function(t){return this._numberOfLevelZeroTilesX<<t};Ic.prototype.getNumberOfYTilesAtLevel=function(t){return this._numberOfLevelZeroTilesY<<t};Ic.prototype.rectangleToNativeRectangle=function(t,e){p.defined("rectangle",t);let i=L.toDegrees(t.west),n=L.toDegrees(t.south),s=L.toDegrees(t.east),o=L.toDegrees(t.north);return m(e)?(e.west=i,e.south=n,e.east=s,e.north=o,e):new Xt(i,n,s,o)};Ic.prototype.tileXYToNativeRectangle=function(t,e,i,n){let s=this.tileXYToRectangle(t,e,i,n);return s.west=L.toDegrees(s.west),s.south=L.toDegrees(s.south),s.east=L.toDegrees(s.east),s.north=L.toDegrees(s.north),s};Ic.prototype.tileXYToRectangle=function(t,e,i,n){let s=this._rectangle,o=this.getNumberOfXTilesAtLevel(i),r=this.getNumberOfYTilesAtLevel(i),a=s.width/o,h=t*a+s.west,A=(t+1)*a+s.west,d=s.height/r,f=s.north-e*d,E=s.north-(e+1)*d;return m(n)||(n=new Xt(h,E,A,f)),n.west=h,n.south=E,n.east=A,n.north=f,n};Ic.prototype.positionToTileXY=function(t,e,i){let n=this._rectangle;if(!Xt.contains(n,t))return;let s=this.getNumberOfXTilesAtLevel(e),o=this.getNumberOfYTilesAtLevel(e),r=n.width/s,a=n.height/o,h=t.longitude;n.east<n.west&&(h+=L.TWO_PI);let A=(h-n.west)/r|0;A>=s&&(A=s-1);let d=(n.north-t.latitude)/a|0;return d>=o&&(d=o-1),m(i)?(i.x=A,i.y=d,i):new nt(A,d)};cw=Ic});function _w(t){ut.fromRadians(t.east,t.north,0,xE[0]),ut.fromRadians(t.west,t.north,0,xE[1]),ut.fromRadians(t.east,t.south,0,xE[2]),ut.fromRadians(t.west,t.south,0,xE[3]);let e=0,i=0,n=0,s=0,o=Kn._terrainHeightsMaxLevel,r;for(r=0;r<=o;++r){let a=!1;for(let h=0;h<4;++h){let A=xE[h];if(cit.positionToTileXY(A,r,PE),h===0)n=PE.x,s=PE.y;else if(n!==PE.x||s!==PE.y){a=!0;break}}if(a)break;e=n,i=s}if(r!==0)return{x:e,y:i,level:r>o?o:r-1}}var dw,mw,fw,dN,hit,Ew,cit,xE,PE,Kn,Do,JE=O(()=>{_i();PZ();Xe();Ht();ri();ae();bt();mt();Vt();Ve();lw();pn();Ia();yZ();dw=new l,mw=new l,fw=new ut,dN=new l,hit=new l,Ew=new Nt,cit=new cw,xE=[new ut,new ut,new ut,new ut],PE=new nt,Kn={};Kn.initialize=function(){let t=Kn._initPromise;return m(t)||(t=tn.fetchJson(th("Assets/approximateTerrainHeights.json")).then(function(e){Kn._terrainHeights=e}),Kn._initPromise=t),t};Kn.getMinimumMaximumHeights=function(t,e){if(p.defined("rectangle",t),!m(Kn._terrainHeights))throw new Y("You must call ApproximateTerrainHeights.initialize and wait for the promise to resolve before using this function");e=Z(e,ot.WGS84);let i=_w(t),n=Kn._defaultMinTerrainHeight,s=Kn._defaultMaxTerrainHeight;if(m(i)){let o=`${i.level}-${i.x}-${i.y}`,r=Kn._terrainHeights[o];m(r)&&(n=r[0],s=r[1]),e.cartographicToCartesian(Xt.northeast(t,fw),dw),e.cartographicToCartesian(Xt.southwest(t,fw),mw),l.midpoint(mw,dw,dN);let a=e.scaleToGeodeticSurface(dN,hit);if(m(a)){let h=l.distance(dN,a);n=Math.min(n,-h)}else n=Kn._defaultMinTerrainHeight}return n=Math.max(Kn._defaultMinTerrainHeight,n),{minimumTerrainHeight:n,maximumTerrainHeight:s}};Kn.getBoundingSphere=function(t,e){if(p.defined("rectangle",t),!m(Kn._terrainHeights))throw new Y("You must call ApproximateTerrainHeights.initialize and wait for the promise to resolve before using this function");e=Z(e,ot.WGS84);let i=_w(t),n=Kn._defaultMaxTerrainHeight;if(m(i)){let o=`${i.level}-${i.x}-${i.y}`,r=Kn._terrainHeights[o];m(r)&&(n=r[1])}let s=Nt.fromRectangle3D(t,e,0);return Nt.fromRectangle3D(t,e,n,Ew),Nt.union(s,Ew,s)};Kn._terrainHeightsMaxLevel=6;Kn._defaultMaxTerrainHeight=9e3;Kn._defaultMinTerrainHeight=-1e5;Kn._terrainHeights=LZ?LZ:void 0;Kn._initPromise=LZ?new Promise(function(t){t()}):void 0;Object.defineProperties(Kn,{initialized:{get:function(){return m(Kn._terrainHeights)}}});Do=Kn});function lit(t){if(t=Z(t,Z.EMPTY_OBJECT),!m(t.geometry))throw new Y("options.geometry is required.");this.geometry=t.geometry,this.modelMatrix=at.clone(Z(t.modelMatrix,at.IDENTITY)),this.id=t.id,this.pickPrimitive=t.pickPrimitive,this.attributes=Z(t.attributes,{}),this.westHemisphereGeometry=void 0,this.eastHemisphereGeometry=void 0}var Ln,uA=O(()=>{bt();mt();Vt();Fi();Ln=lit});function dit(t){if(t=Z(t,Z.EMPTY_OBJECT),!m(t.componentDatatype))throw new Y("options.componentDatatype is required.");if(!m(t.componentsPerAttribute))throw new Y("options.componentsPerAttribute is required.");if(t.componentsPerAttribute<1||t.componentsPerAttribute>4)throw new Y("options.componentsPerAttribute must be between 1 and 4.");if(!m(t.value))throw new Y("options.value is required.");this.componentDatatype=t.componentDatatype,this.componentsPerAttribute=t.componentsPerAttribute,this.normalize=Z(t.normalize,!1),this.value=t.value}var Zr,mN=O(()=>{bt();mt();Vt();Zr=dit});var mit,ti,Bl=O(()=>{mit={NONE:0,GEODESIC:1,RHUMB:2},ti=Object.freeze(mit)});function fit(t,e,i,n){if(p.defined("equalsEpsilon",e),!m(t))return;i=Z(i,!1);let s=m(n),o=t.length;if(o<2)return t;let r,a=t[0],h,A,d=0,f=-1;for(r=1;r<o;++r)h=t[r],e(a,h,Rw)?(m(A)||(A=t.slice(0,r),d=r-1,f=0),s&&n.push(r)):(m(A)&&(A.push(h),d=r,s&&(f=n.length)),a=h);return i&&e(t[0],t[o-1],Rw)&&(s&&(m(A)?n.splice(f,0,d):n.push(o-1)),m(A)?A.length-=1:A=t.slice(0,-1)),m(A)?A:t}var Rw,Xn,Oa=O(()=>{ae();bt();mt();_e();Rw=L.EPSILON10;Xn=fit});function Eit(t){let e=t._uSquared,i=t._ellipsoid.maximumRadius,n=t._ellipsoid.minimumRadius,s=(i-n)/i,o=Math.cos(t._startHeading),r=Math.sin(t._startHeading),a=(1-s)*Math.tan(t._start.latitude),h=1/Math.sqrt(1+a*a),A=h*a,d=Math.atan2(a,o),f=h*r,E=f*f,_=1-E,R=Math.sqrt(_),I=e/4,C=I*I,N=C*I,T=C*C,F=1+I-3*C/4+5*N/4-175*T/64,b=1-I+15*C/8-35*N/8,G=1-3*I+35*C/4,M=1-5*I,Q=F*d-b*Math.sin(2*d)*I/2-G*Math.sin(4*d)*C/16-M*Math.sin(6*d)*N/48-Math.sin(8*d)*5*T/512,U=t._constants;U.a=i,U.b=n,U.f=s,U.cosineHeading=o,U.sineHeading=r,U.tanU=a,U.cosineU=h,U.sineU=A,U.sigma=d,U.sineAlpha=f,U.sineSquaredAlpha=E,U.cosineSquaredAlpha=_,U.cosineAlpha=R,U.u2Over4=I,U.u4Over16=C,U.u6Over64=N,U.u8Over256=T,U.a0=F,U.a1=b,U.a2=G,U.a3=M,U.distanceRatio=Q}function _it(t,e){return t*e*(4+t*(4-3*e))/16}function Zw(t,e,i,n,s,o,r){let a=_it(t,i);return(1-a)*t*e*(n+a*s*(r+a*o*(2*r*r-1)))}function Rit(t,e,i,n,s,o,r){let a=(e-i)/e,h=o-n,A=Math.atan((1-a)*Math.tan(s)),d=Math.atan((1-a)*Math.tan(r)),f=Math.cos(A),E=Math.sin(A),_=Math.cos(d),R=Math.sin(d),I=f*_,C=f*R,N=E*R,T=E*_,F=h,b=L.TWO_PI,G=Math.cos(F),M=Math.sin(F),Q,U,k,y,c;do{G=Math.cos(F),M=Math.sin(F);let tt=C-T*G;k=Math.sqrt(_*_*M*M+tt*tt),U=N+I*G,Q=Math.atan2(k,U);let B;k===0?(B=0,y=1):(B=I*M/k,y=1-B*B),b=F,c=U-2*N/y,isFinite(c)||(c=0),F=h+Zw(a,B,y,Q,k,U,c)}while(Math.abs(F-b)>L.EPSILON12);let g=y*(e*e-i*i)/(i*i),V=1+g*(4096+g*(g*(320-175*g)-768))/16384,D=g*(256+g*(g*(74-47*g)-128))/1024,w=c*c,x=D*k*(c+D*(U*(2*w-1)-D*c*(4*k*k-3)*(4*w-3)/6)/4),H=i*V*(Q-x),j=Math.atan2(_*M,C-T*G),X=Math.atan2(f*M,C*G-T);t._distance=H,t._startHeading=j,t._endHeading=X,t._uSquared=g}function Iw(t,e,i,n){let s=l.normalize(n.cartographicToCartesian(e,fN),Zit),o=l.normalize(n.cartographicToCartesian(i,fN),fN);p.typeOf.number.greaterThanOrEquals("value",Math.abs(Math.abs(l.angleBetween(s,o))-Math.PI),.0125),Rit(t,n.maximumRadius,n.minimumRadius,e.longitude,e.latitude,i.longitude,i.latitude),t._start=ut.clone(e,t._start),t._end=ut.clone(i,t._end),t._start.height=0,t._end.height=0,Eit(t)}function jE(t,e,i){let n=Z(i,ot.WGS84);this._ellipsoid=n,this._start=new ut,this._end=new ut,this._constants={},this._startHeading=void 0,this._endHeading=void 0,this._distance=void 0,this._uSquared=void 0,m(t)&&m(e)&&Iw(this,t,e,n)}var Zit,fN,bI,EN=O(()=>{Ht();ri();ae();bt();mt();Ve();_e();Zit=new l,fN=new l;Object.defineProperties(jE.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},surfaceDistance:{get:function(){return p.defined("distance",this._distance),this._distance}},start:{get:function(){return this._start}},end:{get:function(){return this._end}},startHeading:{get:function(){return p.defined("distance",this._distance),this._startHeading}},endHeading:{get:function(){return p.defined("distance",this._distance),this._endHeading}}});jE.prototype.setEndPoints=function(t,e){p.defined("start",t),p.defined("end",e),Iw(this,t,e,this._ellipsoid)};jE.prototype.interpolateUsingFraction=function(t,e){return this.interpolateUsingSurfaceDistance(this._distance*t,e)};jE.prototype.interpolateUsingSurfaceDistance=function(t,e){p.defined("distance",this._distance);let i=this._constants,n=i.distanceRatio+t/i.b,s=Math.cos(2*n),o=Math.cos(4*n),r=Math.cos(6*n),a=Math.sin(2*n),h=Math.sin(4*n),A=Math.sin(6*n),d=Math.sin(8*n),f=n*n,E=n*f,_=i.u8Over256,R=i.u2Over4,I=i.u6Over64,C=i.u4Over16,N=2*E*_*s/3+n*(1-R+7*C/4-15*I/4+579*_/64-(C-15*I/4+187*_/16)*s-(5*I/4-115*_/16)*o-29*_*r/16)+(R/2-C+71*I/32-85*_/16)*a+(5*C/16-5*I/4+383*_/96)*h-f*((I-11*_/2)*a+5*_*h/2)+(29*I/96-29*_/16)*A+539*_*d/1536,T=Math.asin(Math.sin(N)*i.cosineAlpha),F=Math.atan(i.a/i.b*Math.tan(T));N=N-i.sigma;let b=Math.cos(2*i.sigma+N),G=Math.sin(N),M=Math.cos(N),Q=i.cosineU*M,U=i.sineU*G,y=Math.atan2(G*i.sineHeading,Q-U*i.cosineHeading)-Zw(i.f,i.sineAlpha,i.cosineSquaredAlpha,N,G,M,b);return m(e)?(e.longitude=this._start.longitude+y,e.latitude=F,e.height=0,e):new ut(this._start.longitude+y,F,0)};bI=jE});function RN(t,e,i){if(t===0)return e*i;let n=t*t,s=n*n,o=s*n,r=o*n,a=r*n,h=a*n,A=i,d=Math.sin(2*A),f=Math.sin(4*A),E=Math.sin(6*A),_=Math.sin(8*A),R=Math.sin(10*A),I=Math.sin(12*A);return e*((1-n/4-3*s/64-5*o/256-175*r/16384-441*a/65536-4851*h/1048576)*A-(3*n/8+3*s/32+45*o/1024+105*r/4096+2205*a/131072+6237*h/524288)*d+(15*s/256+45*o/1024+525*r/16384+1575*a/65536+155925*h/8388608)*f-(35*o/3072+175*r/12288+3675*a/262144+13475*h/1048576)*E+(315*r/131072+2205*a/524288+43659*h/8388608)*_-(693*a/1310720+6237*h/5242880)*R+1001*h/8388608*I)}function Iit(t,e,i){let n=t/i;if(e===0)return n;let s=n*n,o=s*n,r=o*n,a=e,h=a*a,A=h*h,d=A*h,f=d*h,E=f*h,_=E*h,R=Math.sin(2*n),I=Math.cos(2*n),C=Math.sin(4*n),N=Math.cos(4*n),T=Math.sin(6*n),F=Math.cos(6*n),b=Math.sin(8*n),G=Math.cos(8*n),M=Math.sin(10*n),Q=Math.cos(10*n),U=Math.sin(12*n);return n+n*h/4+7*n*A/64+15*n*d/256+579*n*f/16384+1515*n*E/65536+16837*n*_/1048576+(3*n*A/16+45*n*d/256-n*(32*s-561)*f/4096-n*(232*s-1677)*E/16384+n*(399985-90560*s+512*r)*_/5242880)*I+(21*n*d/256+483*n*f/4096-n*(224*s-1969)*E/16384-n*(33152*s-112599)*_/1048576)*N+(151*n*f/4096+4681*n*E/65536+1479*n*_/16384-453*o*_/32768)*F+(1097*n*E/65536+42783*n*_/1048576)*G+8011*n*_/1048576*Q+(3*h/8+3*A/16+213*d/2048-3*s*d/64+255*f/4096-33*s*f/512+20861*E/524288-33*s*E/512+r*E/1024+28273*_/1048576-471*s*_/8192+9*r*_/4096)*R+(21*A/256+21*d/256+533*f/8192-21*s*f/512+197*E/4096-315*s*E/4096+584039*_/16777216-12517*s*_/131072+7*r*_/2048)*C+(151*d/6144+151*f/4096+5019*E/131072-453*s*E/16384+26965*_/786432-8607*s*_/131072)*T+(1097*f/131072+1097*E/65536+225797*_/10485760-1097*s*_/65536)*b+(8011*E/2621440+8011*_/1048576)*M+293393*_/251658240*U}function Pm(t,e){if(t===0)return Math.log(Math.tan(.5*(L.PI_OVER_TWO+e)));let i=t*Math.sin(e);return Math.log(Math.tan(.5*(L.PI_OVER_TWO+e)))-t/2*Math.log((1+i)/(1-i))}function pit(t,e,i,n,s){let o=Pm(t._ellipticity,i),r=Pm(t._ellipticity,s);return Math.atan2(L.negativePiToPi(n-e),r-o)}function uit(t,e,i,n,s,o,r){let a=t._heading,h=o-n,A=0;if(L.equalsEpsilon(Math.abs(a),L.PI_OVER_TWO,L.EPSILON8))if(e===i)A=e*Math.cos(s)*L.negativePiToPi(h);else{let d=Math.sin(s);A=e*Math.cos(s)*L.negativePiToPi(h)/Math.sqrt(1-t._ellipticitySquared*d*d)}else{let d=RN(t._ellipticity,e,s);A=(RN(t._ellipticity,e,r)-d)/Math.cos(a)}return Math.abs(A)}function pw(t,e,i,n){let s=l.normalize(n.cartographicToCartesian(e,_N),Cit),o=l.normalize(n.cartographicToCartesian(i,_N),_N);p.typeOf.number.greaterThanOrEquals("value",Math.abs(Math.abs(l.angleBetween(s,o))-Math.PI),.0125);let r=n.maximumRadius,a=n.minimumRadius,h=r*r,A=a*a;t._ellipticitySquared=(h-A)/h,t._ellipticity=Math.sqrt(t._ellipticitySquared),t._start=ut.clone(e,t._start),t._start.height=0,t._end=ut.clone(i,t._end),t._end.height=0,t._heading=pit(t,e.longitude,e.latitude,i.longitude,i.latitude),t._distance=uit(t,n.maximumRadius,n.minimumRadius,e.longitude,e.latitude,i.longitude,i.latitude)}function uw(t,e,i,n,s,o){if(i===0)return ut.clone(t,o);let r=s*s,a,h,A;if(Math.abs(L.PI_OVER_TWO-Math.abs(e))>L.EPSILON8){let d=RN(s,n,t.latitude),f=i*Math.cos(e),E=d+f;if(h=Iit(E,s,n),Math.abs(e)<L.EPSILON10)a=L.negativePiToPi(t.longitude);else{let _=Pm(s,t.latitude),R=Pm(s,h);A=Math.tan(e)*(R-_),a=L.negativePiToPi(t.longitude+A)}}else{h=t.latitude;let d;if(s===0)d=n*Math.cos(t.latitude);else{let f=Math.sin(t.latitude);d=n*Math.cos(t.latitude)/Math.sqrt(1-r*f*f)}A=i/d,e>0?a=L.negativePiToPi(t.longitude+A):a=L.negativePiToPi(t.longitude-A)}return m(o)?(o.longitude=a,o.latitude=h,o.height=0,o):new ut(a,h,0)}function mh(t,e,i){let n=Z(i,ot.WGS84);this._ellipsoid=n,this._start=new ut,this._end=new ut,this._heading=void 0,this._distance=void 0,this._ellipticity=void 0,this._ellipticitySquared=void 0,m(t)&&m(e)&&pw(this,t,e,n)}var Cit,_N,er,HE=O(()=>{Ht();ri();ae();bt();mt();Vt();Ve();_e();Cit=new l,_N=new l;Object.defineProperties(mh.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},surfaceDistance:{get:function(){return p.defined("distance",this._distance),this._distance}},start:{get:function(){return this._start}},end:{get:function(){return this._end}},heading:{get:function(){return p.defined("distance",this._distance),this._heading}}});mh.fromStartHeadingDistance=function(t,e,i,n,s){p.defined("start",t),p.defined("heading",e),p.defined("distance",i),p.typeOf.number.greaterThan("distance",i,0);let o=Z(n,ot.WGS84),r=o.maximumRadius,a=o.minimumRadius,h=r*r,A=a*a,d=Math.sqrt((h-A)/h);e=L.negativePiToPi(e);let f=uw(t,e,i,o.maximumRadius,d);return!m(s)||m(n)&&!n.equals(s.ellipsoid)?new mh(t,f,o):(s.setEndPoints(t,f),s)};mh.prototype.setEndPoints=function(t,e){p.defined("start",t),p.defined("end",e),pw(this,t,e,this._ellipsoid)};mh.prototype.interpolateUsingFraction=function(t,e){return this.interpolateUsingSurfaceDistance(t*this._distance,e)};mh.prototype.interpolateUsingSurfaceDistance=function(t,e){if(p.typeOf.number("distance",t),!m(this._distance)||this._distance===0)throw new Y("EllipsoidRhumbLine must have distinct start and end set.");return uw(this._start,this._heading,t,this._ellipsoid.maximumRadius,this._ellipticity,e)};mh.prototype.findIntersectionWithLongitude=function(t,e){if(p.typeOf.number("intersectionLongitude",t),!m(this._distance)||this._distance===0)throw new Y("EllipsoidRhumbLine must have distinct start and end set.");let i=this._ellipticity,n=this._heading,s=Math.abs(n),o=this._start;if(t=L.negativePiToPi(t),L.equalsEpsilon(Math.abs(t),Math.PI,L.EPSILON14)&&(t=L.sign(o.longitude)*Math.PI),m(e)||(e=new ut),Math.abs(L.PI_OVER_TWO-s)<=L.EPSILON8)return e.longitude=t,e.latitude=o.latitude,e.height=0,e;if(L.equalsEpsilon(Math.abs(L.PI_OVER_TWO-s),L.PI_OVER_TWO,L.EPSILON8))return L.equalsEpsilon(t,o.longitude,L.EPSILON12)?void 0:(e.longitude=t,e.latitude=L.PI_OVER_TWO*L.sign(L.PI_OVER_TWO-n),e.height=0,e);let r=o.latitude,a=i*Math.sin(r),h=Math.tan(.5*(L.PI_OVER_TWO+r))*Math.exp((t-o.longitude)/Math.tan(n)),A=(1+a)/(1-a),d=o.latitude,f;do{f=d;let E=i*Math.sin(f),_=(1+E)/(1-E);d=2*Math.atan(h*Math.pow(_/A,i/2))-L.PI_OVER_TWO}while(!L.equalsEpsilon(d,f,L.EPSILON12));return e.longitude=t,e.latitude=d,e.height=0,e};mh.prototype.findIntersectionWithLatitude=function(t,e){if(p.typeOf.number("intersectionLatitude",t),!m(this._distance)||this._distance===0)throw new Y("EllipsoidRhumbLine must have distinct start and end set.");let i=this._ellipticity,n=this._heading,s=this._start;if(L.equalsEpsilon(Math.abs(n),L.PI_OVER_TWO,L.EPSILON8))return;let o=Pm(i,s.latitude),r=Pm(i,t),a=Math.tan(n)*(r-o),h=L.negativePiToPi(s.longitude+a);return m(e)?(e.longitude=h,e.latitude=t,e.height=0,e):new ut(h,t,0)};er=mh});function git(t){if(t=Z(t,Z.EMPTY_OBJECT),!m(t.componentDatatype))throw new Y("options.componentDatatype is required.");if(!m(t.componentsPerAttribute))throw new Y("options.componentsPerAttribute is required.");if(t.componentsPerAttribute<1||t.componentsPerAttribute>4)throw new Y("options.componentsPerAttribute must be between 1 and 4.");if(!m(t.values))throw new Y("options.values is required.");this.componentDatatype=t.componentDatatype,this.componentsPerAttribute=t.componentsPerAttribute,this.normalize=Z(t.normalize,!1),this.values=t.values}var Tt,ji=O(()=>{bt();mt();Vt();Tt=git});function Cw(t,e,i){let n=t+e;return L.sign(t)!==L.sign(e)&&Math.abs(n/Math.max(Math.abs(t),Math.abs(e)))<i?0:n}var ZN,Pr,FI=O(()=>{Vt();_e();ZN={};ZN.computeDiscriminant=function(t,e,i){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");return e*e-4*t*i};ZN.computeRealRoots=function(t,e,i){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");let n;if(t===0)return e===0?[]:[-i/e];if(e===0){if(i===0)return[0,0];let h=Math.abs(i),A=Math.abs(t);if(h<A&&h/A<L.EPSILON14)return[0,0];if(h>A&&A/h<L.EPSILON14)return[];if(n=-i/t,n<0)return[];let d=Math.sqrt(n);return[-d,d]}else if(i===0)return n=-e/t,n<0?[n,0]:[0,n];let s=e*e,o=4*t*i,r=Cw(s,-o,L.EPSILON14);if(r<0)return[];let a=-.5*Cw(e,L.sign(e)*Math.sqrt(r),L.EPSILON14);return e>0?[a/t,i/a]:[i/a,a/t]};Pr=ZN});function IN(t,e,i,n){let s=t,o=e/3,r=i/3,a=n,h=s*r,A=o*a,d=o*o,f=r*r,E=s*r-d,_=s*a-o*r,R=o*a-f,I=4*E*R-_*_,C,N;if(I<0){let B,It,gt;d*A>=h*f?(B=s,It=E,gt=-2*o*E+s*_):(B=a,It=R,gt=-a*_+2*r*R);let Mt=-(gt<0?-1:1)*Math.abs(B)*Math.sqrt(-I);N=-gt+Mt;let Ct=N/2,zt=Ct<0?-Math.pow(-Ct,1/3):Math.pow(Ct,1/3),kt=N===Mt?-zt:-It/zt;return C=It<=0?zt+kt:-gt/(zt*zt+kt*kt+It),d*A>=h*f?[(C-o)/s]:[-a/(C+r)]}let T=E,F=-2*o*E+s*_,b=R,G=-a*_+2*r*R,M=Math.sqrt(I),Q=Math.sqrt(3)/2,U=Math.abs(Math.atan2(s*M,-F)/3);C=2*Math.sqrt(-T);let k=Math.cos(U);N=C*k;let y=C*(-k/2-Q*Math.sin(U)),c=N+y>2*o?N-o:y-o,g=s,V=c/g;U=Math.abs(Math.atan2(a*M,-G)/3),C=2*Math.sqrt(-b),k=Math.cos(U),N=C*k,y=C*(-k/2-Q*Math.sin(U));let D=-a,w=N+y<2*r?N+r:y+r,x=D/w,H=g*w,j=-c*w-g*D,X=c*D,tt=(r*j-o*X)/(-o*j+r*H);return V<=tt?V<=x?tt<=x?[V,tt,x]:[V,x,tt]:[x,V,tt]:V<=x?[tt,V,x]:tt<=x?[tt,x,V]:[x,tt,V]}var pN,YI,gw=O(()=>{Vt();FI();pN={};pN.computeDiscriminant=function(t,e,i,n){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");if(typeof n!="number")throw new Y("d is a required number.");let s=t*t,o=e*e,r=i*i,a=n*n;return 18*t*e*i*n+o*r-27*s*a-4*(t*r*i+o*e*n)};pN.computeRealRoots=function(t,e,i,n){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");if(typeof n!="number")throw new Y("d is a required number.");let s,o;if(t===0)return Pr.computeRealRoots(e,i,n);if(e===0){if(i===0){if(n===0)return[0,0,0];o=-n/t;let r=o<0?-Math.pow(-o,1/3):Math.pow(o,1/3);return[r,r,r]}else if(n===0)return s=Pr.computeRealRoots(t,0,i),s.Length===0?[0]:[s[0],0,s[1]];return IN(t,0,i,n)}else{if(i===0)return n===0?(o=-e/t,o<0?[o,0,0]:[0,0,o]):IN(t,e,0,n);if(n===0)return s=Pr.computeRealRoots(t,e,i),s.length===0?[0]:s[1]<=0?[s[0],s[1],0]:s[0]>=0?[0,s[0],s[1]]:[s[0],0,s[1]]}return IN(t,e,i,n)};YI=pN});function Va(t,e,i,n){let s=t*t,o=e-3*s/8,r=i-e*t/2+s*t/8,a=n-i*t/4+e*s/16-3*s*s/256,h=YI.computeRealRoots(1,2*o,o*o-4*a,-r*r);if(h.length>0){let A=-t/4,d=h[h.length-1];if(Math.abs(d)<L.EPSILON14){let f=Pr.computeRealRoots(1,o,a);if(f.length===2){let E=f[0],_=f[1],R;if(E>=0&&_>=0){let I=Math.sqrt(E),C=Math.sqrt(_);return[A-C,A-I,A+I,A+C]}else{if(E>=0&&_<0)return R=Math.sqrt(E),[A-R,A+R];if(E<0&&_>=0)return R=Math.sqrt(_),[A-R,A+R]}}return[]}else if(d>0){let f=Math.sqrt(d),E=(o+d-r/f)/2,_=(o+d+r/f)/2,R=Pr.computeRealRoots(1,f,E),I=Pr.computeRealRoots(1,-f,_);return R.length!==0?(R[0]+=A,R[1]+=A,I.length!==0?(I[0]+=A,I[1]+=A,R[1]<=I[0]?[R[0],R[1],I[0],I[1]]:I[1]<=R[0]?[I[0],I[1],R[0],R[1]]:R[0]>=I[0]&&R[1]<=I[1]?[I[0],R[0],R[1],I[1]]:I[0]>=R[0]&&I[1]<=R[1]?[R[0],I[0],I[1],R[1]]:R[0]>I[0]&&R[0]<I[1]?[I[0],R[0],I[1],R[1]]:[R[0],I[0],R[1],I[1]]):R):I.length!==0?(I[0]+=A,I[1]+=A,I):[]}}return[]}function vE(t,e,i,n){let s=i*i,o=e*e,r=t*t,a=-2*e,h=i*t+o-4*n,A=r*n-i*e*t+s,d=YI.computeRealRoots(1,a,h,A);if(d.length>0){let f=d[0],E=e-f,_=E*E,R=t/2,I=E/2,C=_-4*n,N=_+4*Math.abs(n),T=r-4*f,F=r+4*Math.abs(f),b,G;if(f<0||C*F<T*N){let g=Math.sqrt(T);b=g/2,G=g===0?0:(t*I-i)/g}else{let g=Math.sqrt(C);b=g===0?0:(t*I-i)/g,G=g/2}let M,Q;R===0&&b===0?(M=0,Q=0):L.sign(R)===L.sign(b)?(M=R+b,Q=f/M):(Q=R-b,M=f/Q);let U,k;I===0&&G===0?(U=0,k=0):L.sign(I)===L.sign(G)?(U=I+G,k=n/U):(k=I-G,U=n/k);let y=Pr.computeRealRoots(1,M,U),c=Pr.computeRealRoots(1,Q,k);if(y.length!==0)return c.length!==0?y[1]<=c[0]?[y[0],y[1],c[0],c[1]]:c[1]<=y[0]?[c[0],c[1],y[0],y[1]]:y[0]>=c[0]&&y[1]<=c[1]?[c[0],y[0],y[1],c[1]]:c[0]>=y[0]&&c[1]<=y[1]?[y[0],c[0],c[1],y[1]]:y[0]>c[0]&&y[0]<c[1]?[c[0],y[0],c[1],y[1]]:[y[0],c[0],y[1],c[1]]:y;if(c.length!==0)return c}return[]}var uN,Tw,Nw=O(()=>{gw();Vt();_e();FI();uN={};uN.computeDiscriminant=function(t,e,i,n,s){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");if(typeof n!="number")throw new Y("d is a required number.");if(typeof s!="number")throw new Y("e is a required number.");let o=t*t,r=o*t,a=e*e,h=a*e,A=i*i,d=A*i,f=n*n,E=f*n,_=s*s,R=_*s;return a*A*f-4*h*E-4*t*d*f+18*t*e*i*E-27*o*f*f+256*r*R+s*(18*h*i*n-4*a*d+16*t*A*A-80*t*e*A*n-6*t*a*f+144*o*i*f)+_*(144*t*a*i-27*a*a-128*o*A-192*o*e*n)};uN.computeRealRoots=function(t,e,i,n,s){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");if(typeof n!="number")throw new Y("d is a required number.");if(typeof s!="number")throw new Y("e is a required number.");if(Math.abs(t)<L.EPSILON15)return YI.computeRealRoots(e,i,n,s);let o=e/t,r=i/t,a=n/t,h=s/t,A=o<0?1:0;switch(A+=r<0?A+1:A,A+=a<0?A+1:A,A+=h<0?A+1:A,A){case 0:return Va(o,r,a,h);case 1:return vE(o,r,a,h);case 2:return vE(o,r,a,h);case 3:return Va(o,r,a,h);case 4:return Va(o,r,a,h);case 5:return vE(o,r,a,h);case 6:return Va(o,r,a,h);case 7:return Va(o,r,a,h);case 8:return vE(o,r,a,h);case 9:return Va(o,r,a,h);case 10:return Va(o,r,a,h);case 11:return vE(o,r,a,h);case 12:return Va(o,r,a,h);case 13:return Va(o,r,a,h);case 14:return Va(o,r,a,h);case 15:return Va(o,r,a,h);default:return}};Tw=uN});function SI(t,e){e=l.clone(Z(e,l.ZERO)),l.equals(e,l.ZERO)||l.normalize(e,e),this.origin=l.clone(Z(t,l.ZERO)),this.direction=e}var Wl,OI=O(()=>{Ht();ae();bt();mt();SI.clone=function(t,e){if(m(t))return m(e)?(e.origin=l.clone(t.origin),e.direction=l.clone(t.direction),e):new SI(t.origin,t.direction)};SI.getPoint=function(t,e,i){return p.typeOf.object("ray",t),p.typeOf.number("t",e),m(i)||(i=new l),i=l.multiplyByScalar(t.direction,e,i),l.add(t.origin,i,i)};Wl=SI});function Fit(t,e,i,n){let s=e*e-4*t*i;if(s<0)return;if(s>0){let r=1/(2*t),a=Math.sqrt(s),h=(-e+a)*r,A=(-e-a)*r;return h<A?(n.root0=h,n.root1=A):(n.root0=A,n.root1=h),n}let o=-e/(2*t);if(o!==0)return n.root0=n.root1=o,n}function Ww(t,e,i){m(i)||(i=new cA);let n=t.origin,s=t.direction,o=e.center,r=e.radius*e.radius,a=l.subtract(n,o,Bw),h=l.dot(s,s),A=2*l.dot(s,a),d=l.magnitudeSquared(a)-r,f=Fit(h,A,d,Yit);if(m(f))return i.start=f.root0,i.stop=f.root1,i}function Dl(t,e,i){let n=t+e;return L.sign(t)!==L.sign(e)&&Math.abs(n/Math.max(Math.abs(t),Math.abs(e)))<i?0:n}var Sn,Tit,Nit,Bw,bw,Fw,bit,Yit,Sit,Oit,Vit,CN,Yw,Sw,VI,Git,Bit,Wit,Dit,Mit,Uit,Ow,Vw,Gw,Qit,kit,Lit,no,Ml=O(()=>{Ht();ri();bt();mt();Vt();HZ();_e();dn();FI();Nw();OI();Sn={};Sn.rayPlane=function(t,e,i){if(!m(t))throw new Y("ray is required.");if(!m(e))throw new Y("plane is required.");m(i)||(i=new l);let n=t.origin,s=t.direction,o=e.normal,r=l.dot(o,s);if(Math.abs(r)<L.EPSILON15)return;let a=(-e.distance-l.dot(o,n))/r;if(!(a<0))return i=l.multiplyByScalar(s,a,i),l.add(n,i,i)};Tit=new l,Nit=new l,Bw=new l,bw=new l,Fw=new l;Sn.rayTriangleParametric=function(t,e,i,n,s){if(!m(t))throw new Y("ray is required.");if(!m(e))throw new Y("p0 is required.");if(!m(i))throw new Y("p1 is required.");if(!m(n))throw new Y("p2 is required.");s=Z(s,!1);let o=t.origin,r=t.direction,a=l.subtract(i,e,Tit),h=l.subtract(n,e,Nit),A=l.cross(r,h,Bw),d=l.dot(a,A),f,E,_,R,I;if(s){if(d<L.EPSILON6||(f=l.subtract(o,e,bw),_=l.dot(f,A),_<0||_>d)||(E=l.cross(f,a,Fw),R=l.dot(r,E),R<0||_+R>d))return;I=l.dot(h,E)/d}else{if(Math.abs(d)<L.EPSILON6)return;let C=1/d;if(f=l.subtract(o,e,bw),_=l.dot(f,A)*C,_<0||_>1||(E=l.cross(f,a,Fw),R=l.dot(r,E)*C,R<0||_+R>1))return;I=l.dot(h,E)*C}return I};Sn.rayTriangle=function(t,e,i,n,s,o){let r=Sn.rayTriangleParametric(t,e,i,n,s);if(!(!m(r)||r<0))return m(o)||(o=new l),l.multiplyByScalar(t.direction,r,o),l.add(t.origin,o,o)};bit=new Wl;Sn.lineSegmentTriangle=function(t,e,i,n,s,o,r){if(!m(t))throw new Y("v0 is required.");if(!m(e))throw new Y("v1 is required.");if(!m(i))throw new Y("p0 is required.");if(!m(n))throw new Y("p1 is required.");if(!m(s))throw new Y("p2 is required.");let a=bit;l.clone(t,a.origin),l.subtract(e,t,a.direction),l.normalize(a.direction,a.direction);let h=Sn.rayTriangleParametric(a,i,n,s,o);if(!(!m(h)||h<0||h>l.distance(t,e)))return m(r)||(r=new l),l.multiplyByScalar(a.direction,h,r),l.add(a.origin,r,r)};Yit={root0:0,root1:0};Sn.raySphere=function(t,e,i){if(!m(t))throw new Y("ray is required.");if(!m(e))throw new Y("sphere is required.");if(i=Ww(t,e,i),!(!m(i)||i.stop<0))return i.start=Math.max(i.start,0),i};Sit=new Wl;Sn.lineSegmentSphere=function(t,e,i,n){if(!m(t))throw new Y("p0 is required.");if(!m(e))throw new Y("p1 is required.");if(!m(i))throw new Y("sphere is required.");let s=Sit;l.clone(t,s.origin);let o=l.subtract(e,t,s.direction),r=l.magnitude(o);if(l.normalize(o,o),n=Ww(s,i,n),!(!m(n)||n.stop<0||n.start>r))return n.start=Math.max(n.start,0),n.stop=Math.min(n.stop,r),n};Oit=new l,Vit=new l;Sn.rayEllipsoid=function(t,e){if(!m(t))throw new Y("ray is required.");if(!m(e))throw new Y("ellipsoid is required.");let i=e.oneOverRadii,n=l.multiplyComponents(i,t.origin,Oit),s=l.multiplyComponents(i,t.direction,Vit),o=l.magnitudeSquared(n),r=l.dot(n,s),a,h,A,d,f;if(o>1){if(r>=0)return;let E=r*r;if(a=o-1,h=l.magnitudeSquared(s),A=h*a,E<A)return;if(E>A){d=r*r-A,f=-r+Math.sqrt(d);let R=f/h,I=a/f;return R<I?new cA(R,I):{start:I,stop:R}}let _=Math.sqrt(a/h);return new cA(_,_)}else if(o<1)return a=o-1,h=l.magnitudeSquared(s),A=h*a,d=r*r-A,f=-r+Math.sqrt(d),new cA(0,f/h);if(r<0)return h=l.magnitudeSquared(s),new cA(0,-r/h)};Sn.quadraticVectorExpression=function(t,e,i,n,s){let o=n*n,r=s*s,a=(t[lt.COLUMN1ROW1]-t[lt.COLUMN2ROW2])*r,h=s*(n*Dl(t[lt.COLUMN1ROW0],t[lt.COLUMN0ROW1],L.EPSILON15)+e.y),A=t[lt.COLUMN0ROW0]*o+t[lt.COLUMN2ROW2]*r+n*e.x+i,d=r*Dl(t[lt.COLUMN2ROW1],t[lt.COLUMN1ROW2],L.EPSILON15),f=s*(n*Dl(t[lt.COLUMN2ROW0],t[lt.COLUMN0ROW2])+e.z),E,_=[];if(f===0&&d===0){if(E=Pr.computeRealRoots(a,h,A),E.length===0)return _;let U=E[0],k=Math.sqrt(Math.max(1-U*U,0));if(_.push(new l(n,s*U,s*-k)),_.push(new l(n,s*U,s*k)),E.length===2){let y=E[1],c=Math.sqrt(Math.max(1-y*y,0));_.push(new l(n,s*y,s*-c)),_.push(new l(n,s*y,s*c))}return _}let R=f*f,I=d*d,C=a*a,N=f*d,T=C+I,F=2*(h*a+N),b=2*A*a+h*h-I+R,G=2*(A*h-N),M=A*A-R;if(T===0&&F===0&&b===0&&G===0)return _;E=Tw.computeRealRoots(T,F,b,G,M);let Q=E.length;if(Q===0)return _;for(let U=0;U<Q;++U){let k=E[U],y=k*k,c=Math.max(1-y,0),g=Math.sqrt(c),V;L.sign(a)===L.sign(A)?V=Dl(a*y+A,h*k,L.EPSILON12):L.sign(A)===L.sign(h*k)?V=Dl(a*y,h*k+A,L.EPSILON12):V=Dl(a*y+h*k,A,L.EPSILON12);let D=Dl(d*k,f,L.EPSILON15),w=V*D;w<0?_.push(new l(n,s*k,s*g)):w>0?_.push(new l(n,s*k,s*-g)):g!==0?(_.push(new l(n,s*k,s*-g)),_.push(new l(n,s*k,s*g)),++U):_.push(new l(n,s*k,s*g))}return _};CN=new l,Yw=new l,Sw=new l,VI=new l,Git=new l,Bit=new lt,Wit=new lt,Dit=new lt,Mit=new lt,Uit=new lt,Ow=new lt,Vw=new lt,Gw=new l,Qit=new l,kit=new ut;Sn.grazingAltitudeLocation=function(t,e){if(!m(t))throw new Y("ray is required.");if(!m(e))throw new Y("ellipsoid is required.");let i=t.origin,n=t.direction;if(!l.equals(i,l.ZERO)){let M=e.geodeticSurfaceNormal(i,CN);if(l.dot(n,M)>=0)return i}let s=m(this.rayEllipsoid(t,e)),o=e.transformPositionToScaledSpace(n,CN),r=l.normalize(o,o),a=l.mostOrthogonalAxis(o,VI),h=l.normalize(l.cross(a,r,Yw),Yw),A=l.normalize(l.cross(r,h,Sw),Sw),d=Bit;d[0]=r.x,d[1]=r.y,d[2]=r.z,d[3]=h.x,d[4]=h.y,d[5]=h.z,d[6]=A.x,d[7]=A.y,d[8]=A.z;let f=lt.transpose(d,Wit),E=lt.fromScale(e.radii,Dit),_=lt.fromScale(e.oneOverRadii,Mit),R=Uit;R[0]=0,R[1]=-n.z,R[2]=n.y,R[3]=n.z,R[4]=0,R[5]=-n.x,R[6]=-n.y,R[7]=n.x,R[8]=0;let I=lt.multiply(lt.multiply(f,_,Ow),R,Ow),C=lt.multiply(lt.multiply(I,E,Vw),d,Vw),N=lt.multiplyByVector(I,i,Git),T=Sn.quadraticVectorExpression(C,l.negate(N,CN),0,0,1),F,b,G=T.length;if(G>0){let M=l.clone(l.ZERO,Qit),Q=Number.NEGATIVE_INFINITY;for(let k=0;k<G;++k){F=lt.multiplyByVector(E,lt.multiplyByVector(d,T[k],Gw),Gw);let y=l.normalize(l.subtract(F,i,VI),VI),c=l.dot(y,n);c>Q&&(Q=c,M=l.clone(F,M))}let U=e.cartesianToCartographic(M,kit);return Q=L.clamp(Q,0,1),b=l.magnitude(l.subtract(M,i,VI))*Math.sqrt(1-Q*Q),b=s?-b:b,U.height=b,e.cartographicToCartesian(U,new l)}};Lit=new l;Sn.lineSegmentPlane=function(t,e,i,n){if(!m(t))throw new Y("endPoint0 is required.");if(!m(e))throw new Y("endPoint1 is required.");if(!m(i))throw new Y("plane is required.");m(n)||(n=new l);let s=l.subtract(e,t,Lit),o=i.normal,r=l.dot(o,s);if(Math.abs(r)<L.EPSILON6)return;let a=l.dot(o,t),h=-(i.distance+a)/r;if(!(h<0||h>1))return l.multiplyByScalar(s,h,n),l.add(t,n,n),n};Sn.trianglePlaneIntersection=function(t,e,i,n){if(!m(t)||!m(e)||!m(i)||!m(n))throw new Y("p0, p1, p2, and plane are required.");let s=n.normal,o=n.distance,r=l.dot(s,t)+o<0,a=l.dot(s,e)+o<0,h=l.dot(s,i)+o<0,A=0;A+=r?1:0,A+=a?1:0,A+=h?1:0;let d,f;if((A===1||A===2)&&(d=new l,f=new l),A===1){if(r)return Sn.lineSegmentPlane(t,e,n,d),Sn.lineSegmentPlane(t,i,n,f),{positions:[t,e,i,d,f],indices:[0,3,4,1,2,4,1,4,3]};if(a)return Sn.lineSegmentPlane(e,i,n,d),Sn.lineSegmentPlane(e,t,n,f),{positions:[t,e,i,d,f],indices:[1,3,4,2,0,4,2,4,3]};if(h)return Sn.lineSegmentPlane(i,t,n,d),Sn.lineSegmentPlane(i,e,n,f),{positions:[t,e,i,d,f],indices:[2,3,4,0,1,4,0,4,3]}}else if(A===2)if(r)if(a){if(!h)return Sn.lineSegmentPlane(t,i,n,d),Sn.lineSegmentPlane(e,i,n,f),{positions:[t,e,i,d,f],indices:[0,1,4,0,4,3,2,3,4]}}else return Sn.lineSegmentPlane(i,e,n,d),Sn.lineSegmentPlane(t,e,n,f),{positions:[t,e,i,d,f],indices:[2,0,4,2,4,3,1,3,4]};else return Sn.lineSegmentPlane(e,t,n,d),Sn.lineSegmentPlane(i,t,n,f),{positions:[t,e,i,d,f],indices:[1,2,4,1,4,3,0,3,4]}};no=Sn});function ir(t){this._ellipsoid=Z(t,ot.WGS84),this._semimajorAxis=this._ellipsoid.maximumRadius,this._oneOverSemimajorAxis=1/this._semimajorAxis}var ks,Ul=O(()=>{Ht();ri();bt();mt();Vt();Ve();_e();Object.defineProperties(ir.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});ir.mercatorAngleToGeodeticLatitude=function(t){return L.PI_OVER_TWO-2*Math.atan(Math.exp(-t))};ir.geodeticLatitudeToMercatorAngle=function(t){t>ir.MaximumLatitude?t=ir.MaximumLatitude:t<-ir.MaximumLatitude&&(t=-ir.MaximumLatitude);let e=Math.sin(t);return .5*Math.log((1+e)/(1-e))};ir.MaximumLatitude=ir.mercatorAngleToGeodeticLatitude(Math.PI);ir.prototype.project=function(t,e){let i=this._semimajorAxis,n=t.longitude*i,s=ir.geodeticLatitudeToMercatorAngle(t.latitude)*i,o=t.height;return m(e)?(e.x=n,e.y=s,e.z=o,e):new l(n,s,o)};ir.prototype.unproject=function(t,e){if(!m(t))throw new Y("cartesian is required");let i=this._oneOverSemimajorAxis,n=t.x*i,s=ir.mercatorAngleToGeodeticLatitude(t.y*i),o=t.z;return m(e)?(e.longitude=n,e.latitude=s,e.height=o,e):new ut(n,s,o)};ks=ir});function uc(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions;if(!m(e)||e.length<2)throw new Y("At least two positions are required.");if(m(t.arcType)&&t.arcType!==ti.GEODESIC&&t.arcType!==ti.RHUMB)throw new Y("Valid options for arcType are ArcType.GEODESIC and ArcType.RHUMB.");this.width=Z(t.width,1),this._positions=e,this.granularity=Z(t.granularity,9999),this.loop=Z(t.loop,!1),this.arcType=Z(t.arcType,ti.GEODESIC),this._ellipsoid=ot.WGS84,this._projectionIndex=0,this._workerName="createGroundPolylineGeometry",this._scene3DOnly=!1}function SN(t,e,i,n,s){let o=Mo(n,t,0,wit),r=Mo(n,t,i,Mw),a=Mo(n,e,0,Uw),h=fh(r,o,Mw),A=fh(a,o,Uw);return l.cross(A,h,s),l.normalize(s,s)}function gN(t,e,i,n,s,o,r,a,h,A,d){if(s===0)return;let f;o===ti.GEODESIC?f=new bI(t,e,r):o===ti.RHUMB&&(f=new er(t,e,r));let E=f.surfaceDistance;if(E<s)return;let _=SN(t,e,n,r,jit),R=Math.ceil(E/s),I=E/R,C=I,N=R-1,T=a.length;for(let F=0;F<N;F++){let b=f.interpolateUsingSurfaceDistance(C,xit),G=Mo(r,b,i,Pit),M=Mo(r,b,n,Jit);l.pack(_,a,T),l.pack(G,h,T),l.pack(M,A,T),d.push(b.latitude),d.push(b.longitude),T+=3,C+=I}}function Mo(t,e,i,n){return ut.clone(e,TN),TN.height=i,ut.toCartesian(TN,t,n)}function fh(t,e,i){return l.subtract(t,e,i),l.normalize(i,i),i}function Qw(t,e,i,n){return n=fh(t,e,n),n=l.cross(n,i,n),n=l.normalize(n,n),n=l.cross(i,n,n),n}function NN(t,e,i,n,s){let o=fh(i,e,nx),r=Qw(t,e,o,Hit),a=Qw(n,e,o,vit);if(L.equalsEpsilon(l.dot(r,a),Xit,L.EPSILON5))return s=l.cross(o,r,s),s=l.normalize(s,s),s;s=l.add(a,r,s),s=l.normalize(s,s);let h=l.cross(o,s,zit);return l.dot(a,h)<Kit&&(s=l.negate(s,s)),s}function yw(t,e,i,n){let s=fh(i,e,nnt),o=l.dot(s,t);if(o>tx||o<Dw){let r=fh(n,i,nx),a=o<Dw?L.PI_OVER_TWO:-L.PI_OVER_TWO,h=Ae.fromAxisAngle(r,a,ont),A=lt.fromQuaternion(h,snt);return lt.multiplyByVector(A,t,t),!0}return!1}function zE(t,e,i,n,s){let o=ut.toCartesian(e,t._ellipsoid,rnt),r=l.add(o,i,xw),a=!1,h=t._ellipsoid,A=h.cartesianToCartographic(r,ww);Math.abs(e.longitude-A.longitude)>L.PI_OVER_TWO&&(a=!0,r=l.subtract(o,i,xw),A=h.cartesianToCartographic(r,ww)),A.height=0;let d=t.project(A,s);return s=l.subtract(d,n,s),s.z=0,s=l.normalize(s,s),a&&l.negate(s,s),s}function Jw(t,e,i,n,s,o){let r=l.subtract(e,t,ant);l.normalize(r,r);let a=i-ex,h=l.multiplyByScalar(r,a,Pw);l.add(t,h,s);let A=n-ix;h=l.multiplyByScalar(r,A,Pw),l.add(e,h,o)}function WI(t,e){let i=Ki.getPointDistance(DI,t),n=Ki.getPointDistance(DI,e),s=Ant;L.equalsEpsilon(i,0,L.EPSILON2)?(s=fh(e,t,s),l.multiplyByScalar(s,L.EPSILON2,s),l.add(t,s,t)):L.equalsEpsilon(n,0,L.EPSILON2)&&(s=fh(t,e,s),l.multiplyByScalar(s,L.EPSILON2,s),l.add(e,s,e))}function hnt(t,e){let i=Math.abs(t.longitude),n=Math.abs(e.longitude);if(L.equalsEpsilon(i,L.PI,L.EPSILON11)){let s=L.sign(e.longitude);return t.longitude=s*(i-L.EPSILON11),1}else if(L.equalsEpsilon(n,L.PI,L.EPSILON11)){let s=L.sign(t.longitude);return e.longitude=s*(n-L.EPSILON11),2}return 0}function Ynt(t,e,i,n,s,o,r){let a,h,A=e._ellipsoid,d=i.length/3-1,f=d*8,E=f*4,_=d*36,R=f>65535?new Uint32Array(_):new Uint16Array(_),I=new Float64Array(f*3),C=new Float32Array(E),N=new Float32Array(E),T=new Float32Array(E),F=new Float32Array(E),b=new Float32Array(E),G,M,Q,U;r&&(G=new Float32Array(E),M=new Float32Array(E),Q=new Float32Array(E),U=new Float32Array(f*2));let k=o.length/2,y=0,c=sx;c.height=0;let g=ox;g.height=0;let V=jw,D=bN;if(r)for(h=0,a=1;a<k;a++)c.latitude=o[h],c.longitude=o[h+1],g.latitude=o[h+2],g.longitude=o[h+3],V=e.project(c,V),D=e.project(g,D),y+=l.distance(V,D),h+=2;let w=n.length/3;D=l.unpack(n,0,D);let x=0;for(h=3,a=1;a<w;a++)V=l.clone(D,V),D=l.unpack(n,h,D),x+=l.distance(V,D),h+=3;let H;h=3;let j=0,X=0,tt=0,B=0,It=!1,gt=l.unpack(i,0,vw),Yt=l.unpack(n,0,bN),Mt=l.unpack(s,0,zw);if(t){let ce=l.unpack(i,i.length-6,Hw);yw(Mt,ce,gt,Yt)&&(Mt=l.negate(Mt,Mt))}let Ct=0,zt=0,kt=0;for(a=0;a<d;a++){let ce=l.clone(gt,Hw),je=l.clone(Yt,jw),Oe=l.clone(Mt,cnt);It&&(Oe=l.negate(Oe,Oe)),gt=l.unpack(i,h,vw),Yt=l.unpack(n,h,bN),Mt=l.unpack(s,h,zw),It=yw(Mt,ce,gt,Yt),c.latitude=o[j],c.longitude=o[j+1],g.latitude=o[j+2],g.longitude=o[j+3];let Me,Ue,Ce,be;if(r){let Ci=hnt(c,g);Me=e.project(c,Rnt),Ue=e.project(g,Znt);let Jn=fh(Ue,Me,Xw);Jn.y=Math.abs(Jn.y),Ce=FN,be=YN,Ci===0||l.dot(Jn,l.UNIT_Y)>tx?(Ce=zE(e,c,Oe,Me,FN),be=zE(e,g,Mt,Ue,YN)):Ci===1?(be=zE(e,g,Mt,Ue,YN),Ce.x=0,Ce.y=L.sign(c.longitude-Math.abs(g.longitude)),Ce.z=0):(Ce=zE(e,c,Oe,Me,FN),be.x=0,be.y=L.sign(c.longitude-g.longitude),be.z=0)}let ni=l.distance(je,Yt),ze=Bn.fromCartesian(ce,Tnt),Ge=l.subtract(gt,ce,Int),Ui=l.normalize(Ge,Kw),Ri=l.subtract(je,ce,pnt);Ri=l.normalize(Ri,Ri);let si=l.cross(Ui,Ri,Kw);si=l.normalize(si,si);let qe=l.cross(Ri,Oe,Cnt);qe=l.normalize(qe,qe);let Vi=l.subtract(Yt,gt,unt);Vi=l.normalize(Vi,Vi);let gn=l.cross(Mt,Vi,gnt);gn=l.normalize(gn,gn);let De=ni/x,Ye=Ct/x,Bi=0,An,Ne,ei,_n=0,hs=0;if(r){Bi=l.distance(Me,Ue),An=Bn.fromCartesian(Me,Nnt),Ne=l.subtract(Ue,Me,Xw),ei=l.normalize(Ne,bnt);let Ci=ei.x;ei.x=ei.y,ei.y=-Ci,_n=Bi/y,hs=zt/y}for(H=0;H<8;H++){let Ci=B+H*4,Jn=X+H*2,ls=Ci+3,ao=H<4?1:-1,qi=H===2||H===3||H===6||H===7?1:-1;l.pack(ze.high,C,Ci),C[ls]=Ge.x,l.pack(ze.low,N,Ci),N[ls]=Ge.y,l.pack(qe,T,Ci),T[ls]=Ge.z,l.pack(gn,F,Ci),F[ls]=De*ao,l.pack(si,b,Ci);let hn=Ye*qi;hn===0&&qi<0&&(hn=9),b[ls]=hn,r&&(G[Ci]=An.high.x,G[Ci+1]=An.high.y,G[Ci+2]=An.low.x,G[Ci+3]=An.low.y,Q[Ci]=-Ce.y,Q[Ci+1]=Ce.x,Q[Ci+2]=be.y,Q[Ci+3]=-be.x,M[Ci]=Ne.x,M[Ci+1]=Ne.y,M[Ci+2]=ei.x,M[Ci+3]=ei.y,U[Jn]=_n*ao,hn=hs*qi,hn===0&&qi<0&&(hn=9),U[Jn+1]=hn)}let Qi=Ent,nn=_nt,ki=mnt,sn=fnt,Cs=Xt.fromCartographicArray(lnt,dnt),cs=Do.getMinimumMaximumHeights(Cs,A),xn=cs.minimumTerrainHeight,Pn=cs.maximumTerrainHeight;kt+=Math.abs(xn),kt+=Math.abs(Pn),Jw(ce,je,xn,Pn,Qi,ki),Jw(gt,Yt,xn,Pn,nn,sn);let Ai=l.multiplyByScalar(si,L.EPSILON5,qw);l.add(Qi,Ai,Qi),l.add(nn,Ai,nn),l.add(ki,Ai,ki),l.add(sn,Ai,sn),WI(Qi,nn),WI(ki,sn),l.pack(Qi,I,tt),l.pack(nn,I,tt+3),l.pack(sn,I,tt+6),l.pack(ki,I,tt+9),Ai=l.multiplyByScalar(si,-2*L.EPSILON5,qw),l.add(Qi,Ai,Qi),l.add(nn,Ai,nn),l.add(ki,Ai,ki),l.add(sn,Ai,sn),WI(Qi,nn),WI(ki,sn),l.pack(Qi,I,tt+12),l.pack(nn,I,tt+15),l.pack(sn,I,tt+18),l.pack(ki,I,tt+21),j+=2,h+=3,X+=16,tt+=24,B+=32,Ct+=ni,zt+=Bi}h=0;let Jt=0;for(a=0;a<d;a++){for(H=0;H<$w;H++)R[h+H]=rx[H]+Jt;Jt+=8,h+=$w}let Wt=Fnt;Nt.fromVertices(i,l.ZERO,3,Wt[0]),Nt.fromVertices(n,l.ZERO,3,Wt[1]);let Ft=Nt.fromBoundingSpheres(Wt);Ft.radius+=kt/(d*2);let ee={position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,normalize:!1,values:I}),startHiAndForwardOffsetX:pc(C),startLoAndForwardOffsetY:pc(N),startNormalAndForwardOffsetZ:pc(T),endNormalAndTextureCoordinateNormalizationX:pc(F),rightNormalAndTextureCoordinateNormalizationY:pc(b)};return r&&(ee.startHiLo2D=pc(G),ee.offsetAndRight2D=pc(M),ee.startEndNormals2D=pc(Q),ee.texcoordNormalization2D=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,normalize:!1,values:U})),new se({attributes:ee,indices:R,boundingSphere:Ft})}function pc(t){return new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,values:t})}var ON,yit,tx,Dw,ex,ix,wit,Mw,Uw,xit,Pit,Jit,jit,TN,Hit,vit,zit,nx,Kit,Xit,DI,qit,$it,tnt,ent,int,GI,BI,kw,Lw,nnt,snt,ont,ww,rnt,xw,ant,Pw,Ant,sx,ox,jw,bN,Hw,vw,cnt,zw,lnt,dnt,mnt,fnt,Ent,_nt,Rnt,Znt,FN,YN,Int,pnt,unt,Kw,Cnt,gnt,Tnt,Nnt,Xw,bnt,qw,Fnt,rx,$w,KE,VN=O(()=>{JE();Bl();Oa();_i();Ht();ri();ae();oi();bt();mt();Vt();Ve();EN();HE();Tl();zA();yi();ji();Ml();_e();dn();nh();$s();pn();Ul();ON=[Os,ks],yit=ON.length,tx=Math.cos(L.toRadians(30)),Dw=Math.cos(L.toRadians(150)),ex=0,ix=1e3;Object.defineProperties(uc.prototype,{packedLength:{get:function(){return 1+this._positions.length*3+1+1+1+ot.packedLength+1+1}}});uc.setProjectionAndEllipsoid=function(t,e){let i=0;for(let n=0;n<yit;n++)if(e instanceof ON[n]){i=n;break}t._projectionIndex=i,t._ellipsoid=e.ellipsoid};wit=new l,Mw=new l,Uw=new l;xit=new ut,Pit=new l,Jit=new l,jit=new l;TN=new ut;uc.pack=function(t,e,i){p.typeOf.object("value",t),p.defined("array",e);let n=Z(i,0),s=t._positions,o=s.length;e[n++]=o;for(let r=0;r<o;++r){let a=s[r];l.pack(a,e,n),n+=3}return e[n++]=t.granularity,e[n++]=t.loop?1:0,e[n++]=t.arcType,ot.pack(t._ellipsoid,e,n),n+=ot.packedLength,e[n++]=t._projectionIndex,e[n++]=t._scene3DOnly?1:0,e};uc.unpack=function(t,e,i){p.defined("array",t);let n=Z(e,0),s=t[n++],o=new Array(s);for(let E=0;E<s;E++)o[E]=l.unpack(t,n),n+=3;let r=t[n++],a=t[n++]===1,h=t[n++],A=ot.unpack(t,n);n+=ot.packedLength;let d=t[n++],f=t[n++]===1;return m(i)||(i=new uc({positions:o})),i._positions=o,i.granularity=r,i.loop=a,i.arcType=h,i._ellipsoid=A,i._projectionIndex=d,i._scene3DOnly=f,i};Hit=new l,vit=new l,zit=new l,nx=new l,Kit=0,Xit=-1;DI=Ki.fromPointNormal(l.ZERO,l.UNIT_Y),qit=new l,$it=new l,tnt=new l,ent=new l,int=new l,GI=new l,BI=new ut,kw=new ut,Lw=new ut;uc.createGeometry=function(t){let e=!t._scene3DOnly,i=t.loop,n=t._ellipsoid,s=t.granularity,o=t.arcType,r=new ON[t._projectionIndex](n),a=ex,h=ix,A,d,f=t._positions,E=f.length;E===2&&(i=!1);let _,R,I,C,N=new er(void 0,void 0,n),T,F,b,G=[f[0]];for(d=0;d<E-1;d++)_=f[d],R=f[d+1],T=no.lineSegmentPlane(_,R,DI,GI),m(T)&&!l.equalsEpsilon(T,_,L.EPSILON7)&&!l.equalsEpsilon(T,R,L.EPSILON7)&&(t.arcType===ti.GEODESIC?G.push(l.clone(T)):t.arcType===ti.RHUMB&&(b=n.cartesianToCartographic(T,BI).longitude,I=n.cartesianToCartographic(_,BI),C=n.cartesianToCartographic(R,kw),N.setEndPoints(I,C),F=N.findIntersectionWithLongitude(b,Lw),T=n.cartographicToCartesian(F,GI),m(T)&&!l.equalsEpsilon(T,_,L.EPSILON7)&&!l.equalsEpsilon(T,R,L.EPSILON7)&&G.push(l.clone(T)))),G.push(R);i&&(_=f[E-1],R=f[0],T=no.lineSegmentPlane(_,R,DI,GI),m(T)&&!l.equalsEpsilon(T,_,L.EPSILON7)&&!l.equalsEpsilon(T,R,L.EPSILON7)&&(t.arcType===ti.GEODESIC?G.push(l.clone(T)):t.arcType===ti.RHUMB&&(b=n.cartesianToCartographic(T,BI).longitude,I=n.cartesianToCartographic(_,BI),C=n.cartesianToCartographic(R,kw),N.setEndPoints(I,C),F=N.findIntersectionWithLongitude(b,Lw),T=n.cartographicToCartesian(F,GI),m(T)&&!l.equalsEpsilon(T,_,L.EPSILON7)&&!l.equalsEpsilon(T,R,L.EPSILON7)&&G.push(l.clone(T)))));let M=G.length,Q=new Array(M);for(d=0;d<M;d++){let It=ut.fromCartesian(G[d],n);It.height=0,Q[d]=It}if(Q=Xn(Q,ut.equalsEpsilon),M=Q.length,M<2)return;let U=[],k=[],y=[],c=[],g=qit,V=$it,D=tnt,w=ent,x=int,H=Q[0],j=Q[1],X=Q[M-1];for(g=Mo(n,X,a,g),w=Mo(n,j,a,w),V=Mo(n,H,a,V),D=Mo(n,H,h,D),i?x=NN(g,V,D,w,x):x=SN(H,j,h,n,x),l.pack(x,k,0),l.pack(V,y,0),l.pack(D,c,0),U.push(H.latitude),U.push(H.longitude),gN(H,j,a,h,s,o,n,k,y,c,U),d=1;d<M-1;++d){g=l.clone(V,g),V=l.clone(w,V);let It=Q[d];Mo(n,It,h,D),Mo(n,Q[d+1],a,w),NN(g,V,D,w,x),A=k.length,l.pack(x,k,A),l.pack(V,y,A),l.pack(D,c,A),U.push(It.latitude),U.push(It.longitude),gN(Q[d],Q[d+1],a,h,s,o,n,k,y,c,U)}let tt=Q[M-1],B=Q[M-2];if(V=Mo(n,tt,a,V),D=Mo(n,tt,h,D),i){let It=Q[0];g=Mo(n,B,a,g),w=Mo(n,It,a,w),x=NN(g,V,D,w,x)}else x=SN(B,tt,h,n,x);if(A=k.length,l.pack(x,k,A),l.pack(V,y,A),l.pack(D,c,A),U.push(tt.latitude),U.push(tt.longitude),i){for(gN(tt,H,a,h,s,o,n,k,y,c,U),A=k.length,d=0;d<3;++d)k[A+d]=k[d],y[A+d]=y[d],c[A+d]=c[d];U.push(H.latitude),U.push(H.longitude)}return Ynt(i,r,y,c,k,U,e)};nnt=new l,snt=new lt,ont=new Ae;ww=new ut,rnt=new l,xw=new l;ant=new l,Pw=new l;Ant=new l;sx=new ut,ox=new ut,jw=new l,bN=new l,Hw=new l,vw=new l,cnt=new l,zw=new l,lnt=[sx,ox],dnt=new Xt,mnt=new l,fnt=new l,Ent=new l,_nt=new l,Rnt=new l,Znt=new l,FN=new l,YN=new l,Int=new l,pnt=new l,unt=new l,Kw=new l,Cnt=new l,gnt=new l,Tnt=new Bn,Nnt=new Bn,Xw=new l,bnt=new l,qw=new l,Fnt=[new Nt,new Nt],rx=[0,2,1,0,3,2,0,7,3,0,4,7,0,5,4,0,1,5,5,7,4,5,6,7,5,2,6,5,1,2,3,6,2,3,7,6],$w=rx.length;uc._projectNormal=zE;KE=uc});var ax,Ax=O(()=>{ax=`in vec4 v_startPlaneNormalEcAndHalfWidth;
in vec4 v_endPlaneNormalEcAndBatchId;
in vec4 v_rightPlaneEC; // Technically can compute distance for this here
in vec4 v_endEcAndStartEcX;
in vec4 v_texcoordNormalizationAndStartEcYZ;

#ifdef PER_INSTANCE_COLOR
in vec4 v_color;
#endif

void main(void)
{
    float logDepthOrDepth = czm_branchFreeTernary(czm_sceneMode == czm_sceneMode2D, gl_FragCoord.z, czm_unpackDepth(texture(czm_globeDepthTexture, gl_FragCoord.xy / czm_viewport.zw)));
    vec3 ecStart = vec3(v_endEcAndStartEcX.w, v_texcoordNormalizationAndStartEcYZ.zw);

    // Discard for sky
    if (logDepthOrDepth == 0.0) {
#ifdef DEBUG_SHOW_VOLUME
        out_FragColor = vec4(1.0, 0.0, 0.0, 0.5);
        return;
#else // DEBUG_SHOW_VOLUME
        discard;
#endif // DEBUG_SHOW_VOLUME
    }

    vec4 eyeCoordinate = czm_windowToEyeCoordinates(gl_FragCoord.xy, logDepthOrDepth);
    eyeCoordinate /= eyeCoordinate.w;

    float halfMaxWidth = v_startPlaneNormalEcAndHalfWidth.w * czm_metersPerPixel(eyeCoordinate);
    // Check distance of the eye coordinate against the right-facing plane
    float widthwiseDistance = czm_planeDistance(v_rightPlaneEC, eyeCoordinate.xyz);

    // Check eye coordinate against the mitering planes
    float distanceFromStart = czm_planeDistance(v_startPlaneNormalEcAndHalfWidth.xyz, -dot(ecStart, v_startPlaneNormalEcAndHalfWidth.xyz), eyeCoordinate.xyz);
    float distanceFromEnd = czm_planeDistance(v_endPlaneNormalEcAndBatchId.xyz, -dot(v_endEcAndStartEcX.xyz, v_endPlaneNormalEcAndBatchId.xyz), eyeCoordinate.xyz);

    if (abs(widthwiseDistance) > halfMaxWidth || distanceFromStart < 0.0 || distanceFromEnd < 0.0) {
#ifdef DEBUG_SHOW_VOLUME
        out_FragColor = vec4(1.0, 0.0, 0.0, 0.5);
        return;
#else // DEBUG_SHOW_VOLUME
        discard;
#endif // DEBUG_SHOW_VOLUME
    }

    // Check distance of the eye coordinate against start and end planes with normals in the right plane.
    // For computing unskewed lengthwise texture coordinate.
    // Can also be used for clipping extremely pointy miters, but in practice unnecessary because of miter breaking.

    // aligned plane: cross the right plane normal with miter plane normal, then cross the result with right again to point it more "forward"
    vec3 alignedPlaneNormal;

    // start aligned plane
    alignedPlaneNormal = cross(v_rightPlaneEC.xyz, v_startPlaneNormalEcAndHalfWidth.xyz);
    alignedPlaneNormal = normalize(cross(alignedPlaneNormal, v_rightPlaneEC.xyz));
    distanceFromStart = czm_planeDistance(alignedPlaneNormal, -dot(alignedPlaneNormal, ecStart), eyeCoordinate.xyz);

    // end aligned plane
    alignedPlaneNormal = cross(v_rightPlaneEC.xyz, v_endPlaneNormalEcAndBatchId.xyz);
    alignedPlaneNormal = normalize(cross(alignedPlaneNormal, v_rightPlaneEC.xyz));
    distanceFromEnd = czm_planeDistance(alignedPlaneNormal, -dot(alignedPlaneNormal, v_endEcAndStartEcX.xyz), eyeCoordinate.xyz);

#ifdef PER_INSTANCE_COLOR
    out_FragColor = czm_gammaCorrect(v_color);
#else // PER_INSTANCE_COLOR
    // Clamp - distance to aligned planes may be negative due to mitering,
    // so fragment texture coordinate might be out-of-bounds.
    float s = clamp(distanceFromStart / (distanceFromStart + distanceFromEnd), 0.0, 1.0);
    s = (s * v_texcoordNormalizationAndStartEcYZ.x) + v_texcoordNormalizationAndStartEcYZ.y;
    float t = (widthwiseDistance + halfMaxWidth) / (2.0 * halfMaxWidth);

    czm_materialInput materialInput;

    materialInput.s = s;
    materialInput.st = vec2(s, t);
    materialInput.str = vec3(s, t, 0.0);

    czm_material material = czm_getMaterial(materialInput);
    out_FragColor = vec4(material.diffuse + material.emission, material.alpha);
#endif // PER_INSTANCE_COLOR

    // Premultiply alpha. Required for classification primitives on translucent globe.
    out_FragColor.rgb *= out_FragColor.a;

    czm_writeDepthClamp();
}
`});var hx,cx=O(()=>{hx=`in vec3 v_forwardDirectionEC;
in vec3 v_texcoordNormalizationAndHalfWidth;
in float v_batchId;

#ifdef PER_INSTANCE_COLOR
in vec4 v_color;
#else
in vec2 v_alignedPlaneDistances;
in float v_texcoordT;
#endif

float rayPlaneDistanceUnsafe(vec3 origin, vec3 direction, vec3 planeNormal, float planeDistance) {
    // We don't expect the ray to ever be parallel to the plane
    return (-planeDistance - dot(planeNormal, origin)) / dot(planeNormal, direction);
}

void main(void)
{
    vec4 eyeCoordinate = gl_FragCoord;
    eyeCoordinate /= eyeCoordinate.w;

#ifdef PER_INSTANCE_COLOR
    out_FragColor = czm_gammaCorrect(v_color);
#else // PER_INSTANCE_COLOR
    // Use distances for planes aligned with segment to prevent skew in dashing
    float distanceFromStart = rayPlaneDistanceUnsafe(eyeCoordinate.xyz, -v_forwardDirectionEC, v_forwardDirectionEC.xyz, v_alignedPlaneDistances.x);
    float distanceFromEnd = rayPlaneDistanceUnsafe(eyeCoordinate.xyz, v_forwardDirectionEC, -v_forwardDirectionEC.xyz, v_alignedPlaneDistances.y);

    // Clamp - distance to aligned planes may be negative due to mitering
    distanceFromStart = max(0.0, distanceFromStart);
    distanceFromEnd = max(0.0, distanceFromEnd);

    float s = distanceFromStart / (distanceFromStart + distanceFromEnd);
    s = (s * v_texcoordNormalizationAndHalfWidth.x) + v_texcoordNormalizationAndHalfWidth.y;

    czm_materialInput materialInput;

    materialInput.s = s;
    materialInput.st = vec2(s, v_texcoordT);
    materialInput.str = vec3(s, v_texcoordT, 0.0);

    czm_material material = czm_getMaterial(materialInput);
    out_FragColor = vec4(material.diffuse + material.emission, material.alpha);
#endif // PER_INSTANCE_COLOR
}
`});var lx,dx=O(()=>{lx=`in vec3 position3DHigh;
in vec3 position3DLow;

in vec4 startHiAndForwardOffsetX;
in vec4 startLoAndForwardOffsetY;
in vec4 startNormalAndForwardOffsetZ;
in vec4 endNormalAndTextureCoordinateNormalizationX;
in vec4 rightNormalAndTextureCoordinateNormalizationY;
in vec4 startHiLo2D;
in vec4 offsetAndRight2D;
in vec4 startEndNormals2D;
in vec2 texcoordNormalization2D;

in float batchId;

out vec3 v_forwardDirectionEC;
out vec3 v_texcoordNormalizationAndHalfWidth;
out float v_batchId;

// For materials
#ifdef WIDTH_VARYING
out float v_width;
#endif
#ifdef ANGLE_VARYING
out float v_polylineAngle;
#endif

#ifdef PER_INSTANCE_COLOR
out vec4 v_color;
#else
out vec2 v_alignedPlaneDistances;
out float v_texcoordT;
#endif

// Morphing planes using SLERP or NLERP doesn't seem to work, so instead draw the material directly on the shadow volume.
// Morph views are from very far away and aren't meant to be used precisely, so this should be sufficient.
void main()
{
    v_batchId = batchId;

    // Start position
    vec4 posRelativeToEye2D = czm_translateRelativeToEye(vec3(0.0, startHiLo2D.xy), vec3(0.0, startHiLo2D.zw));
    vec4 posRelativeToEye3D = czm_translateRelativeToEye(startHiAndForwardOffsetX.xyz, startLoAndForwardOffsetY.xyz);
    vec4 posRelativeToEye = czm_columbusViewMorph(posRelativeToEye2D, posRelativeToEye3D, czm_morphTime);
    vec3 posEc2D = (czm_modelViewRelativeToEye * posRelativeToEye2D).xyz;
    vec3 posEc3D = (czm_modelViewRelativeToEye * posRelativeToEye3D).xyz;
    vec3 startEC = (czm_modelViewRelativeToEye * posRelativeToEye).xyz;

    // Start plane
    vec4 startPlane2D;
    vec4 startPlane3D;
    startPlane2D.xyz = czm_normal * vec3(0.0, startEndNormals2D.xy);
    startPlane3D.xyz = czm_normal * startNormalAndForwardOffsetZ.xyz;
    startPlane2D.w = -dot(startPlane2D.xyz, posEc2D);
    startPlane3D.w = -dot(startPlane3D.xyz, posEc3D);

    // Right plane
    vec4 rightPlane2D;
    vec4 rightPlane3D;
    rightPlane2D.xyz = czm_normal * vec3(0.0, offsetAndRight2D.zw);
    rightPlane3D.xyz = czm_normal * rightNormalAndTextureCoordinateNormalizationY.xyz;
    rightPlane2D.w = -dot(rightPlane2D.xyz, posEc2D);
    rightPlane3D.w = -dot(rightPlane3D.xyz, posEc3D);

    // End position
    posRelativeToEye2D = posRelativeToEye2D + vec4(0.0, offsetAndRight2D.xy, 0.0);
    posRelativeToEye3D = posRelativeToEye3D + vec4(startHiAndForwardOffsetX.w, startLoAndForwardOffsetY.w, startNormalAndForwardOffsetZ.w, 0.0);
    posRelativeToEye = czm_columbusViewMorph(posRelativeToEye2D, posRelativeToEye3D, czm_morphTime);
    posEc2D = (czm_modelViewRelativeToEye * posRelativeToEye2D).xyz;
    posEc3D = (czm_modelViewRelativeToEye * posRelativeToEye3D).xyz;
    vec3 endEC = (czm_modelViewRelativeToEye * posRelativeToEye).xyz;
    vec3 forwardEc3D = czm_normal * normalize(vec3(startHiAndForwardOffsetX.w, startLoAndForwardOffsetY.w, startNormalAndForwardOffsetZ.w));
    vec3 forwardEc2D = czm_normal * normalize(vec3(0.0, offsetAndRight2D.xy));

    // End plane
    vec4 endPlane2D;
    vec4 endPlane3D;
    endPlane2D.xyz = czm_normal * vec3(0.0, startEndNormals2D.zw);
    endPlane3D.xyz = czm_normal * endNormalAndTextureCoordinateNormalizationX.xyz;
    endPlane2D.w = -dot(endPlane2D.xyz, posEc2D);
    endPlane3D.w = -dot(endPlane3D.xyz, posEc3D);

    // Forward direction
    v_forwardDirectionEC = normalize(endEC - startEC);

    vec2 cleanTexcoordNormalization2D;
    cleanTexcoordNormalization2D.x = abs(texcoordNormalization2D.x);
    cleanTexcoordNormalization2D.y = czm_branchFreeTernary(texcoordNormalization2D.y > 1.0, 0.0, abs(texcoordNormalization2D.y));
    vec2 cleanTexcoordNormalization3D;
    cleanTexcoordNormalization3D.x = abs(endNormalAndTextureCoordinateNormalizationX.w);
    cleanTexcoordNormalization3D.y = rightNormalAndTextureCoordinateNormalizationY.w;
    cleanTexcoordNormalization3D.y = czm_branchFreeTernary(cleanTexcoordNormalization3D.y > 1.0, 0.0, abs(cleanTexcoordNormalization3D.y));

    v_texcoordNormalizationAndHalfWidth.xy = mix(cleanTexcoordNormalization2D, cleanTexcoordNormalization3D, czm_morphTime);

#ifdef PER_INSTANCE_COLOR
    v_color = czm_batchTable_color(batchId);
#else // PER_INSTANCE_COLOR
    // For computing texture coordinates

    v_alignedPlaneDistances.x = -dot(v_forwardDirectionEC, startEC);
    v_alignedPlaneDistances.y = -dot(-v_forwardDirectionEC, endEC);
#endif // PER_INSTANCE_COLOR

#ifdef WIDTH_VARYING
    float width = czm_batchTable_width(batchId);
    float halfWidth = width * 0.5;
    v_width = width;
    v_texcoordNormalizationAndHalfWidth.z = halfWidth;
#else
    float halfWidth = 0.5 * czm_batchTable_width(batchId);
    v_texcoordNormalizationAndHalfWidth.z = halfWidth;
#endif

    // Compute a normal along which to "push" the position out, extending the miter depending on view distance.
    // Position has already been "pushed" by unit length along miter normal, and miter normals are encoded in the planes.
    // Decode the normal to use at this specific vertex, push the position back, and then push to where it needs to be.
    // Since this is morphing, compute both 3D and 2D positions and then blend.

    // ****** 3D ******
    // Check distance to the end plane and start plane, pick the plane that is closer
    vec4 positionEc3D = czm_modelViewRelativeToEye * czm_translateRelativeToEye(position3DHigh, position3DLow); // w = 1.0, see czm_computePosition
    float absStartPlaneDistance = abs(czm_planeDistance(startPlane3D, positionEc3D.xyz));
    float absEndPlaneDistance = abs(czm_planeDistance(endPlane3D, positionEc3D.xyz));
    vec3 planeDirection = czm_branchFreeTernary(absStartPlaneDistance < absEndPlaneDistance, startPlane3D.xyz, endPlane3D.xyz);
    vec3 upOrDown = normalize(cross(rightPlane3D.xyz, planeDirection)); // Points "up" for start plane, "down" at end plane.
    vec3 normalEC = normalize(cross(planeDirection, upOrDown));         // In practice, the opposite seems to work too.

    // Nudge the top vertex upwards to prevent flickering
    vec3 geodeticSurfaceNormal = normalize(cross(normalEC, forwardEc3D));
    geodeticSurfaceNormal *= float(0.0 <= rightNormalAndTextureCoordinateNormalizationY.w && rightNormalAndTextureCoordinateNormalizationY.w <= 1.0);
    geodeticSurfaceNormal *= MAX_TERRAIN_HEIGHT;
    positionEc3D.xyz += geodeticSurfaceNormal;

    // Determine if this vertex is on the "left" or "right"
    normalEC *= sign(endNormalAndTextureCoordinateNormalizationX.w);

    // A "perfect" implementation would push along normals according to the angle against forward.
    // In practice, just pushing the normal out by halfWidth is sufficient for morph views.
    positionEc3D.xyz += halfWidth * max(0.0, czm_metersPerPixel(positionEc3D)) * normalEC; // prevent artifacts when czm_metersPerPixel is negative (behind camera)

    // ****** 2D ******
    // Check distance to the end plane and start plane, pick the plane that is closer
    vec4 positionEc2D = czm_modelViewRelativeToEye * czm_translateRelativeToEye(position2DHigh.zxy, position2DLow.zxy); // w = 1.0, see czm_computePosition
    absStartPlaneDistance = abs(czm_planeDistance(startPlane2D, positionEc2D.xyz));
    absEndPlaneDistance = abs(czm_planeDistance(endPlane2D, positionEc2D.xyz));
    planeDirection = czm_branchFreeTernary(absStartPlaneDistance < absEndPlaneDistance, startPlane2D.xyz, endPlane2D.xyz);
    upOrDown = normalize(cross(rightPlane2D.xyz, planeDirection)); // Points "up" for start plane, "down" at end plane.
    normalEC = normalize(cross(planeDirection, upOrDown));         // In practice, the opposite seems to work too.

    // Nudge the top vertex upwards to prevent flickering
    geodeticSurfaceNormal = normalize(cross(normalEC, forwardEc2D));
    geodeticSurfaceNormal *= float(0.0 <= texcoordNormalization2D.y && texcoordNormalization2D.y <= 1.0);
    geodeticSurfaceNormal *= MAX_TERRAIN_HEIGHT;
    positionEc2D.xyz += geodeticSurfaceNormal;

    // Determine if this vertex is on the "left" or "right"
    normalEC *= sign(texcoordNormalization2D.x);
#ifndef PER_INSTANCE_COLOR
    // Use vertex's sidedness to compute its texture coordinate.
    v_texcoordT = clamp(sign(texcoordNormalization2D.x), 0.0, 1.0);
#endif

    // A "perfect" implementation would push along normals according to the angle against forward.
    // In practice, just pushing the normal out by halfWidth is sufficient for morph views.
    positionEc2D.xyz += halfWidth * max(0.0, czm_metersPerPixel(positionEc2D)) * normalEC; // prevent artifacts when czm_metersPerPixel is negative (behind camera)

    // Blend for actual position
    gl_Position = czm_projection * mix(positionEc2D, positionEc3D, czm_morphTime);

#ifdef ANGLE_VARYING
    // Approximate relative screen space direction of the line.
    vec2 approxLineDirection = normalize(vec2(v_forwardDirectionEC.x, -v_forwardDirectionEC.y));
    approxLineDirection.y = czm_branchFreeTernary(approxLineDirection.x == 0.0 && approxLineDirection.y == 0.0, -1.0, approxLineDirection.y);
    v_polylineAngle = czm_fastApproximateAtan(approxLineDirection.x, approxLineDirection.y);
#endif
}
`});var mx,fx=O(()=>{mx=`in vec3 position3DHigh;
in vec3 position3DLow;

// In 2D and in 3D, texture coordinate normalization component signs encodes:
// * X sign - sidedness relative to right plane
// * Y sign - is negative OR magnitude is greater than 1.0 if vertex is on bottom of volume
#ifndef COLUMBUS_VIEW_2D
in vec4 startHiAndForwardOffsetX;
in vec4 startLoAndForwardOffsetY;
in vec4 startNormalAndForwardOffsetZ;
in vec4 endNormalAndTextureCoordinateNormalizationX;
in vec4 rightNormalAndTextureCoordinateNormalizationY;
#else
in vec4 startHiLo2D;
in vec4 offsetAndRight2D;
in vec4 startEndNormals2D;
in vec2 texcoordNormalization2D;
#endif

in float batchId;

out vec4 v_startPlaneNormalEcAndHalfWidth;
out vec4 v_endPlaneNormalEcAndBatchId;
out vec4 v_rightPlaneEC;
out vec4 v_endEcAndStartEcX;
out vec4 v_texcoordNormalizationAndStartEcYZ;

// For materials
#ifdef WIDTH_VARYING
out float v_width;
#endif
#ifdef ANGLE_VARYING
out float v_polylineAngle;
#endif

#ifdef PER_INSTANCE_COLOR
out vec4 v_color;
#endif

void main()
{
#ifdef COLUMBUS_VIEW_2D
    vec3 ecStart = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(vec3(0.0, startHiLo2D.xy), vec3(0.0, startHiLo2D.zw))).xyz;

    vec3 forwardDirectionEC = czm_normal * vec3(0.0, offsetAndRight2D.xy);
    vec3 ecEnd = forwardDirectionEC + ecStart;
    forwardDirectionEC = normalize(forwardDirectionEC);

    // Right plane
    v_rightPlaneEC.xyz = czm_normal * vec3(0.0, offsetAndRight2D.zw);
    v_rightPlaneEC.w = -dot(v_rightPlaneEC.xyz, ecStart);

    // start plane
    vec4 startPlaneEC;
    startPlaneEC.xyz =  czm_normal * vec3(0.0, startEndNormals2D.xy);
    startPlaneEC.w = -dot(startPlaneEC.xyz, ecStart);

    // end plane
    vec4 endPlaneEC;
    endPlaneEC.xyz =  czm_normal * vec3(0.0, startEndNormals2D.zw);
    endPlaneEC.w = -dot(endPlaneEC.xyz, ecEnd);

    v_texcoordNormalizationAndStartEcYZ.x = abs(texcoordNormalization2D.x);
    v_texcoordNormalizationAndStartEcYZ.y = texcoordNormalization2D.y;

#else // COLUMBUS_VIEW_2D
    vec3 ecStart = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(startHiAndForwardOffsetX.xyz, startLoAndForwardOffsetY.xyz)).xyz;
    vec3 offset = czm_normal * vec3(startHiAndForwardOffsetX.w, startLoAndForwardOffsetY.w, startNormalAndForwardOffsetZ.w);
    vec3 ecEnd = ecStart + offset;

    vec3 forwardDirectionEC = normalize(offset);

    // start plane
    vec4 startPlaneEC;
    startPlaneEC.xyz = czm_normal * startNormalAndForwardOffsetZ.xyz;
    startPlaneEC.w = -dot(startPlaneEC.xyz, ecStart);

    // end plane
    vec4 endPlaneEC;
    endPlaneEC.xyz = czm_normal * endNormalAndTextureCoordinateNormalizationX.xyz;
    endPlaneEC.w = -dot(endPlaneEC.xyz, ecEnd);

    // Right plane
    v_rightPlaneEC.xyz = czm_normal * rightNormalAndTextureCoordinateNormalizationY.xyz;
    v_rightPlaneEC.w = -dot(v_rightPlaneEC.xyz, ecStart);

    v_texcoordNormalizationAndStartEcYZ.x = abs(endNormalAndTextureCoordinateNormalizationX.w);
    v_texcoordNormalizationAndStartEcYZ.y = rightNormalAndTextureCoordinateNormalizationY.w;

#endif // COLUMBUS_VIEW_2D

    v_endEcAndStartEcX.xyz = ecEnd;
    v_endEcAndStartEcX.w = ecStart.x;
    v_texcoordNormalizationAndStartEcYZ.zw = ecStart.yz;

#ifdef PER_INSTANCE_COLOR
    v_color = czm_batchTable_color(batchId);
#endif // PER_INSTANCE_COLOR

    // Compute a normal along which to "push" the position out, extending the miter depending on view distance.
    // Position has already been "pushed" by unit length along miter normal, and miter normals are encoded in the planes.
    // Decode the normal to use at this specific vertex, push the position back, and then push to where it needs to be.
    vec4 positionRelativeToEye = czm_computePosition();

    // Check distance to the end plane and start plane, pick the plane that is closer
    vec4 positionEC = czm_modelViewRelativeToEye * positionRelativeToEye; // w = 1.0, see czm_computePosition
    float absStartPlaneDistance = abs(czm_planeDistance(startPlaneEC, positionEC.xyz));
    float absEndPlaneDistance = abs(czm_planeDistance(endPlaneEC, positionEC.xyz));
    vec3 planeDirection = czm_branchFreeTernary(absStartPlaneDistance < absEndPlaneDistance, startPlaneEC.xyz, endPlaneEC.xyz);
    vec3 upOrDown = normalize(cross(v_rightPlaneEC.xyz, planeDirection)); // Points "up" for start plane, "down" at end plane.
    vec3 normalEC = normalize(cross(planeDirection, upOrDown));           // In practice, the opposite seems to work too.

    // Extrude bottom vertices downward for far view distances, like for GroundPrimitives
    upOrDown = cross(forwardDirectionEC, normalEC);
    upOrDown = float(czm_sceneMode == czm_sceneMode3D) * upOrDown;
    upOrDown = float(v_texcoordNormalizationAndStartEcYZ.y > 1.0 || v_texcoordNormalizationAndStartEcYZ.y < 0.0) * upOrDown;
    upOrDown = min(GLOBE_MINIMUM_ALTITUDE, czm_geometricToleranceOverMeter * length(positionRelativeToEye.xyz)) * upOrDown;
    positionEC.xyz += upOrDown;

    v_texcoordNormalizationAndStartEcYZ.y = czm_branchFreeTernary(v_texcoordNormalizationAndStartEcYZ.y > 1.0, 0.0, abs(v_texcoordNormalizationAndStartEcYZ.y));

    // Determine distance along normalEC to push for a volume of appropriate width.
    // Make volumes about double pixel width for a conservative fit - in practice the
    // extra cost here is minimal compared to the loose volume heights.
    //
    // N = normalEC (guaranteed "right-facing")
    // R = rightEC
    // p = angle between N and R
    // w = distance to push along R if R == N
    // d = distance to push along N
    //
    //   N   R
    //  {  p| }      * cos(p) = dot(N, R) = w / d
    //  d  |  |w    * d = w / dot(N, R)
    //    { | }
    //       o---------- polyline segment ---->
    //
    float width = czm_batchTable_width(batchId);
#ifdef WIDTH_VARYING
    v_width = width;
#endif

    v_startPlaneNormalEcAndHalfWidth.xyz = startPlaneEC.xyz;
    v_startPlaneNormalEcAndHalfWidth.w = width * 0.5;

    v_endPlaneNormalEcAndBatchId.xyz = endPlaneEC.xyz;
    v_endPlaneNormalEcAndBatchId.w = batchId;

    width = width * max(0.0, czm_metersPerPixel(positionEC)); // width = distance to push along R
    width = width / dot(normalEC, v_rightPlaneEC.xyz); // width = distance to push along N

    // Determine if this vertex is on the "left" or "right"
#ifdef COLUMBUS_VIEW_2D
        normalEC *= sign(texcoordNormalization2D.x);
#else
        normalEC *= sign(endNormalAndTextureCoordinateNormalizationX.w);
#endif

    positionEC.xyz += width * normalEC;
    gl_Position = czm_depthClamp(czm_projection * positionEC);

#ifdef ANGLE_VARYING
    // Approximate relative screen space direction of the line.
    vec2 approxLineDirection = normalize(vec2(forwardDirectionEC.x, -forwardDirectionEC.y));
    approxLineDirection.y = czm_branchFreeTernary(approxLineDirection.x == 0.0 && approxLineDirection.y == 0.0, -1.0, approxLineDirection.y);
    v_polylineAngle = czm_fastApproximateAtan(approxLineDirection.x, approxLineDirection.y);
#endif
}
`});var Ex,Jr,MI=O(()=>{Ex={TERRAIN:0,CESIUM_3D_TILE:1,BOTH:2};Ex.NUMBER_OF_CLASSIFICATION_TYPES=3;Jr=Object.freeze(Ex)});var Snt,Eh,UI=O(()=>{ss();Snt={FRONT:it.FRONT,BACK:it.BACK,FRONT_AND_BACK:it.FRONT_AND_BACK},Eh=Object.freeze(Snt)});function Zs(t){t=Z(t,Z.EMPTY_OBJECT),this.position=Z(t.position,!1),this.normal=Z(t.normal,!1),this.st=Z(t.st,!1),this.bitangent=Z(t.bitangent,!1),this.tangent=Z(t.tangent,!1),this.color=Z(t.color,!1)}var Ot,Ls=O(()=>{bt();mt();Vt();Zs.POSITION_ONLY=Object.freeze(new Zs({position:!0}));Zs.POSITION_AND_NORMAL=Object.freeze(new Zs({position:!0,normal:!0}));Zs.POSITION_NORMAL_AND_ST=Object.freeze(new Zs({position:!0,normal:!0,st:!0}));Zs.POSITION_AND_ST=Object.freeze(new Zs({position:!0,st:!0}));Zs.POSITION_AND_COLOR=Object.freeze(new Zs({position:!0,color:!0}));Zs.ALL=Object.freeze(new Zs({position:!0,normal:!0,st:!0,tangent:!0,bitangent:!0}));Zs.DEFAULT=Zs.POSITION_NORMAL_AND_ST;Zs.packedLength=6;Zs.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),e[i++]=t.position?1:0,e[i++]=t.normal?1:0,e[i++]=t.st?1:0,e[i++]=t.tangent?1:0,e[i++]=t.bitangent?1:0,e[i]=t.color?1:0,e};Zs.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");return e=Z(e,0),m(i)||(i=new Zs),i.position=t[e++]===1,i.normal=t[e++]===1,i.st=t[e++]===1,i.tangent=t[e++]===1,i.bitangent=t[e++]===1,i.color=t[e]===1,i};Zs.clone=function(t,e){if(m(t))return m(e)||(e=new Zs),e.position=t.position,e.normal=t.normal,e.st=t.st,e.tangent=t.tangent,e.bitangent=t.bitangent,e.color=t.color,e};Ot=Zs});var QI,GN=O(()=>{QI=`in vec4 v_color;

void main()
{
    out_FragColor = czm_gammaCorrect(v_color);
}
`});var _x,Rx=O(()=>{_x=`in vec3 position3DHigh;
in vec3 position3DLow;
in vec3 prevPosition3DHigh;
in vec3 prevPosition3DLow;
in vec3 nextPosition3DHigh;
in vec3 nextPosition3DLow;
in vec2 expandAndWidth;
in vec4 color;
in float batchId;

out vec4 v_color;

void main()
{
    float expandDir = expandAndWidth.x;
    float width = abs(expandAndWidth.y) + 0.5;
    bool usePrev = expandAndWidth.y < 0.0;

    vec4 p = czm_computePosition();
    vec4 prev = czm_computePrevPosition();
    vec4 next = czm_computeNextPosition();

    float angle;
    vec4 positionWC = getPolylineWindowCoordinates(p, prev, next, expandDir, width, usePrev, angle);
    gl_Position = czm_viewportOrthographic * positionWC;

    v_color = color;
}
`});var kI,BN=O(()=>{kI=`void clipLineSegmentToNearPlane(
    vec3 p0,
    vec3 p1,
    out vec4 positionWC,
    out bool clipped,
    out bool culledByNearPlane,
    out vec4 clippedPositionEC)
{
    culledByNearPlane = false;
    clipped = false;

    vec3 p0ToP1 = p1 - p0;
    float magnitude = length(p0ToP1);
    vec3 direction = normalize(p0ToP1);

    // Distance that p0 is behind the near plane. Negative means p0 is
    // in front of the near plane.
    float endPoint0Distance =  czm_currentFrustum.x + p0.z;

    // Camera looks down -Z.
    // When moving a point along +Z: LESS VISIBLE
    //   * Points in front of the camera move closer to the camera.
    //   * Points behind the camrea move farther away from the camera.
    // When moving a point along -Z: MORE VISIBLE
    //   * Points in front of the camera move farther away from the camera.
    //   * Points behind the camera move closer to the camera.

    // Positive denominator: -Z, becoming more visible
    // Negative denominator: +Z, becoming less visible
    // Nearly zero: parallel to near plane
    float denominator = -direction.z;

    if (endPoint0Distance > 0.0 && abs(denominator) < czm_epsilon7)
    {
        // p0 is behind the near plane and the line to p1 is nearly parallel to
        // the near plane, so cull the segment completely.
        culledByNearPlane = true;
    }
    else if (endPoint0Distance > 0.0)
    {
        // p0 is behind the near plane, and the line to p1 is moving distinctly
        // toward or away from it.

        // t = (-plane distance - dot(plane normal, ray origin)) / dot(plane normal, ray direction)
        float t = endPoint0Distance / denominator;
        if (t < 0.0 || t > magnitude)
        {
            // Near plane intersection is not between the two points.
            // We already confirmed p0 is behind the naer plane, so now
            // we know the entire segment is behind it.
            culledByNearPlane = true;
        }
        else
        {
            // Segment crosses the near plane, update p0 to lie exactly on it.
            p0 = p0 + t * direction;

            // Numerical noise might put us a bit on the wrong side of the near plane.
            // Don't let that happen.
            p0.z = min(p0.z, -czm_currentFrustum.x);

            clipped = true;
        }
    }

    clippedPositionEC = vec4(p0, 1.0);
    positionWC = czm_eyeToWindowCoordinates(clippedPositionEC);
}

vec4 getPolylineWindowCoordinatesEC(vec4 positionEC, vec4 prevEC, vec4 nextEC, float expandDirection, float width, bool usePrevious, out float angle)
{
    // expandDirection +1 is to the _left_ when looking from positionEC toward nextEC.

#ifdef POLYLINE_DASH
    // Compute the window coordinates of the points.
    vec4 positionWindow = czm_eyeToWindowCoordinates(positionEC);
    vec4 previousWindow = czm_eyeToWindowCoordinates(prevEC);
    vec4 nextWindow = czm_eyeToWindowCoordinates(nextEC);

    // Determine the relative screen space direction of the line.
    vec2 lineDir;
    if (usePrevious) {
        lineDir = normalize(positionWindow.xy - previousWindow.xy);
    }
    else {
        lineDir = normalize(nextWindow.xy - positionWindow.xy);
    }
    angle = atan(lineDir.x, lineDir.y) - 1.570796327; // precomputed atan(1,0)

    // Quantize the angle so it doesn't change rapidly between segments.
    angle = floor(angle / czm_piOverFour + 0.5) * czm_piOverFour;
#endif

    vec4 clippedPrevWC, clippedPrevEC;
    bool prevSegmentClipped, prevSegmentCulled;
    clipLineSegmentToNearPlane(prevEC.xyz, positionEC.xyz, clippedPrevWC, prevSegmentClipped, prevSegmentCulled, clippedPrevEC);

    vec4 clippedNextWC, clippedNextEC;
    bool nextSegmentClipped, nextSegmentCulled;
    clipLineSegmentToNearPlane(nextEC.xyz, positionEC.xyz, clippedNextWC, nextSegmentClipped, nextSegmentCulled, clippedNextEC);

    bool segmentClipped, segmentCulled;
    vec4 clippedPositionWC, clippedPositionEC;
    clipLineSegmentToNearPlane(positionEC.xyz, usePrevious ? prevEC.xyz : nextEC.xyz, clippedPositionWC, segmentClipped, segmentCulled, clippedPositionEC);

    if (segmentCulled)
    {
        return vec4(0.0, 0.0, 0.0, 1.0);
    }

    vec2 directionToPrevWC = normalize(clippedPrevWC.xy - clippedPositionWC.xy);
    vec2 directionToNextWC = normalize(clippedNextWC.xy - clippedPositionWC.xy);

    // If a segment was culled, we can't use the corresponding direction
    // computed above. We should never see both of these be true without
    // \`segmentCulled\` above also being true.
    if (prevSegmentCulled)
    {
        directionToPrevWC = -directionToNextWC;
    }
    else if (nextSegmentCulled)
    {
        directionToNextWC = -directionToPrevWC;
    }

    vec2 thisSegmentForwardWC, otherSegmentForwardWC;
    if (usePrevious)
    {
        thisSegmentForwardWC = -directionToPrevWC;
        otherSegmentForwardWC = directionToNextWC;
    }
    else
    {
        thisSegmentForwardWC = directionToNextWC;
        otherSegmentForwardWC =  -directionToPrevWC;
    }

    vec2 thisSegmentLeftWC = vec2(-thisSegmentForwardWC.y, thisSegmentForwardWC.x);

    vec2 leftWC = thisSegmentLeftWC;
    float expandWidth = width * 0.5;

    // When lines are split at the anti-meridian, the position may be at the
    // same location as the next or previous position, and we need to handle
    // that to avoid producing NaNs.
    if (!czm_equalsEpsilon(prevEC.xyz - positionEC.xyz, vec3(0.0), czm_epsilon1) && !czm_equalsEpsilon(nextEC.xyz - positionEC.xyz, vec3(0.0), czm_epsilon1))
    {
        vec2 otherSegmentLeftWC = vec2(-otherSegmentForwardWC.y, otherSegmentForwardWC.x);

        vec2 leftSumWC = thisSegmentLeftWC + otherSegmentLeftWC;
        float leftSumLength = length(leftSumWC);
        leftWC = leftSumLength < czm_epsilon6 ? thisSegmentLeftWC : (leftSumWC / leftSumLength);

        // The sine of the angle between the two vectors is given by the formula
        //         |a x b| = |a||b|sin(theta)
        // which is
        //     float sinAngle = length(cross(vec3(leftWC, 0.0), vec3(-thisSegmentForwardWC, 0.0)));
        // Because the z components of both vectors are zero, the x and y coordinate will be zero.
        // Therefore, the sine of the angle is just the z component of the cross product.
        vec2 u = -thisSegmentForwardWC;
        vec2 v = leftWC;
        float sinAngle = abs(u.x * v.y - u.y * v.x);
        expandWidth = clamp(expandWidth / sinAngle, 0.0, width * 2.0);
    }

    vec2 offset = leftWC * expandDirection * expandWidth * czm_pixelRatio;
    return vec4(clippedPositionWC.xy + offset, -clippedPositionWC.z, 1.0) * (czm_projection * clippedPositionEC).w;
}

vec4 getPolylineWindowCoordinates(vec4 position, vec4 previous, vec4 next, float expandDirection, float width, bool usePrevious, out float angle)
{
    vec4 positionEC = czm_modelViewRelativeToEye * position;
    vec4 prevEC = czm_modelViewRelativeToEye * previous;
    vec4 nextEC = czm_modelViewRelativeToEye * next;
    return getPolylineWindowCoordinatesEC(positionEC, prevEC, nextEC, expandDirection, width, usePrevious, angle);
}
`});function Jm(t){t=Z(t,Z.EMPTY_OBJECT),this.material=t.material,this.translucent=Z(t.translucent,!0),this._vertexShaderSource=t.vertexShaderSource,this._fragmentShaderSource=t.fragmentShaderSource,this._renderState=t.renderState,this._closed=Z(t.closed,!1)}var Uo,LI=O(()=>{aE();KA();bt();mt();km();UI();Object.defineProperties(Jm.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}}});Jm.prototype.getFragmentShaderSource=function(){let t=[];return this.flat&&t.push("#define FLAT"),this.faceForward&&t.push("#define FACE_FORWARD"),m(this.material)&&t.push(this.material.shaderSource),t.push(this.fragmentShaderSource),t.join(`
`)};Jm.prototype.isTranslucent=function(){return m(this.material)&&this.material.isTranslucent()||!m(this.material)&&this.translucent};Jm.prototype.getRenderState=function(){let t=this.isTranslucent(),e=qs(this.renderState,!1);return t?(e.depthMask=!1,e.blending=Ur.ALPHA_BLEND):e.depthMask=!0,e};Jm.getDefaultRenderState=function(t,e,i){let n={depthTest:{enabled:!0}};return t&&(n.depthMask=!1,n.blending=Ur.ALPHA_BLEND),e&&(n.cull={enabled:!0,face:Eh.BACK}),m(i)&&(n=es(i,n,!0)),n};Uo=Jm});function Ql(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.translucent,!0),i=!1,n=Ql.VERTEX_FORMAT;this.material=void 0,this.translucent=e,this._vertexShaderSource=Z(t.vertexShaderSource,WN),this._fragmentShaderSource=Z(t.fragmentShaderSource,Ont),this._renderState=Uo.getDefaultRenderState(e,i,t.renderState),this._closed=i,this._vertexFormat=n}var WN,Ont,DN,Zx=O(()=>{bt();Il();Ls();GN();Rx();BN();LI();WN=`${kI}
${_x}`,Ont=QI;_o.isInternetExplorer()||(WN=`#define CLIP_POLYLINE 
${WN}`);Object.defineProperties(Ql.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},vertexFormat:{get:function(){return this._vertexFormat}}});Ql.VERTEX_FORMAT=Ot.POSITION_ONLY;Ql.prototype.getFragmentShaderSource=Uo.prototype.getFragmentShaderSource;Ql.prototype.isTranslucent=Uo.prototype.isTranslucent;Ql.prototype.getRenderState=Uo.prototype.getRenderState;DN=Ql});var Ix,px=O(()=>{Ix=`in vec3 position3DHigh;
in vec3 position3DLow;
in vec3 prevPosition3DHigh;
in vec3 prevPosition3DLow;
in vec3 nextPosition3DHigh;
in vec3 nextPosition3DLow;
in vec2 expandAndWidth;
in vec2 st;
in float batchId;

out float v_width;
out vec2 v_st;
out float v_polylineAngle;

void main()
{
    float expandDir = expandAndWidth.x;
    float width = abs(expandAndWidth.y) + 0.5;
    bool usePrev = expandAndWidth.y < 0.0;

    vec4 p = czm_computePosition();
    vec4 prev = czm_computePrevPosition();
    vec4 next = czm_computeNextPosition();

    float angle;
    vec4 positionWC = getPolylineWindowCoordinates(p, prev, next, expandDir, width, usePrev, angle);
    gl_Position = czm_viewportOrthographic * positionWC;

    v_width = width;
    v_st.s = st.s;
    v_st.t = czm_writeNonPerspective(st.t, gl_Position.w);
    v_polylineAngle = angle;
}
`});var ux,Cx=O(()=>{ux=`#ifdef VECTOR_TILE
uniform vec4 u_highlightColor;
#endif

in vec2 v_st;

void main()
{
    czm_materialInput materialInput;

    vec2 st = v_st;
    st.t = czm_readNonPerspective(st.t, gl_FragCoord.w);

    materialInput.s = st.s;
    materialInput.st = st;
    materialInput.str = vec3(st, 0.0);

    czm_material material = czm_getMaterial(materialInput);
    out_FragColor = vec4(material.diffuse + material.emission, material.alpha);
#ifdef VECTOR_TILE
    out_FragColor *= u_highlightColor;
#endif

    czm_writeLogDepth();
}
`});function jm(t,e,i,n,s){this._format=t,this._datatype=e,this._width=i,this._height=n,this._buffer=s}var gx,Tx=O(()=>{mt();Object.defineProperties(jm.prototype,{internalFormat:{get:function(){return this._format}},pixelDatatype:{get:function(){return this._datatype}},width:{get:function(){return this._width}},height:{get:function(){return this._height}},bufferView:{get:function(){return this._buffer}}});jm.clone=function(t){if(m(t))return new jm(t._format,t._datatype,t._width,t._height,t._buffer)};jm.prototype.clone=function(){return jm.clone(this)};gx=jm});function bx(){if(!m(so._canTransferArrayBuffer)){let t=QN("transferTypedArrayTest");t.postMessage=Z(t.webkitPostMessage,t.postMessage);let e=99,i=new Int8Array([e]);try{t.postMessage({array:i},[i.buffer])}catch{return so._canTransferArrayBuffer=!1,so._canTransferArrayBuffer}so._canTransferArrayBuffer=new Promise(n=>{t.onmessage=function(s){let o=s.data.array,r=m(o)&&o[0]===e;n(r),t.terminate(),so._canTransferArrayBuffer=r}})}return so._canTransferArrayBuffer}function MN(t){let e;try{e=new Blob([t],{type:"application/javascript"})}catch{let s=window.BlobBuilder||window.WebKitBlobBuilder||window.MozBlobBuilder||window.MSBlobBuilder,o=new s;o.append(t),e=o.getBlob("application/javascript")}return(window.URL||window.webkitURL).createObjectURL(e)}function QN(t){let e=new Nx.default(t),i=e.scheme().length!==0&&e.fragment().length===0,n={},s;if(ZZ(t)){let r=`importScripts("${t}");`;return s=MN(r),new Worker(s,n)}let o=t.replace(/\.js$/,"");if(!i&&typeof CESIUM_WORKERS<"u"){let r=`
      importScripts("${MN(CESIUM_WORKERS)}");
      CesiumWorkers["${o}"]();
    `;return s=MN(r),new Worker(s,n)}if(s=t,i||(s=th(`${so._workerModulePrefix+o}.js`)),!_o.supportsEsmWebWorkers())throw new ke("This browser is not supported. Please update your browser to continue.");return n.type="module",new Worker(s,n)}async function Vnt(t,e){let i={modulePath:void 0,wasmBinaryFile:void 0,wasmBinary:void 0};if(!_o.supportsWebAssembly()){if(!m(e.fallbackModulePath))throw new ke(`This browser does not support Web Assembly, and no backup module was provided for ${t._workerPath}`);return i.modulePath=th(e.fallbackModulePath),i}i.wasmBinaryFile=th(e.wasmBinaryFile);let n=await tn.fetchArrayBuffer({url:i.wasmBinaryFile});return i.wasmBinary=n,i}function so(t,e){this._workerPath=t,this._maximumActiveTasks=Z(e,Number.POSITIVE_INFINITY),this._activeTasks=0,this._nextID=0,this._webAssemblyPromise=void 0}async function Wnt(t,e,i){let n=await Promise.resolve(bx());m(i)?n||(i.length=0):i=Bnt;let s=t._nextID++,o=new Promise((r,a)=>{t._worker.addEventListener("message",Gnt(t._worker,s,r,a))});return t._worker.postMessage({id:s,baseUrl:th.getCesiumBaseUrl().url,parameters:e,canTransferArrayBuffer:n},i),o}async function Dnt(t,e,i){++t._activeTasks;try{let n=await Wnt(t,e,i);return--t._activeTasks,n}catch(n){throw--t._activeTasks,n}}var Nx,UN,Gnt,Bnt,XE,kN=O(()=>{Nx=co(oc(),1);PZ();bt();mt();Ws();Vt();xi();Il();Z0();Ia();Ps();UN=new We;Gnt=(t,e,i,n)=>{let s=({data:o})=>{if(o.id===e){if(m(o.error)){let r=o.error;r.name==="RuntimeError"?(r=new ke(o.error.message),r.stack=o.error.stack):r.name==="DeveloperError"?(r=new Y(o.error.message),r.stack=o.error.stack):r.name==="Error"&&(r=new Error(o.error.message),r.stack=o.error.stack),UN.raiseEvent(r),n(r)}else UN.raiseEvent(),i(o.result);t.removeEventListener("message",s)}};return s},Bnt=[];so.prototype.scheduleTask=function(t,e){if(m(this._worker)||(this._worker=QN(this._workerPath)),!(this._activeTasks>=this._maximumActiveTasks))return Dnt(this,t,e)};so.prototype.initWebAssemblyModule=async function(t){if(m(this._webAssemblyPromise))return this._webAssemblyPromise;let e=async()=>{let i=this._worker=QN(this._workerPath),n=await Vnt(this,t),s=await Promise.resolve(bx()),o,r=n.wasmBinary;m(r)&&s&&(o=[r]);let a=new Promise((h,A)=>{i.onmessage=function({data:d}){m(d)?h(d.result):A(new ke("Could not configure wasm module"))}});return i.postMessage({canTransferArrayBuffer:s,parameters:{webAssemblyConfig:n}},o),a};return this._webAssemblyPromise=e(),this._webAssemblyPromise};so.prototype.isDestroyed=function(){return!1};so.prototype.destroy=function(){return m(this._worker)&&this._worker.terminate(),li(this)};so.taskCompletedEvent=UN;so._defaultWorkerModulePrefix="Workers/";so._workerModulePrefix=so._defaultWorkerModulePrefix;so._canTransferArrayBuffer=void 0;XE=so});function _h(){}function Mnt(){let t=_h._transcodeTaskProcessor.initWebAssemblyModule({wasmBinaryFile:"ThirdParty/basis_transcoder.wasm"}).then(function(e){if(e)return _h._transcodeTaskProcessor;throw new ke("KTX2 transcoder could not be initialized.")});_h._readyPromise=t}var Fx,Yx=O(()=>{ae();Tx();mt();Ps();kN();_h._transcodeTaskProcessor=new XE("transcodeKTX2",Number.POSITIVE_INFINITY);_h._readyPromise=void 0;_h.transcode=function(t,e){return p.defined("supportedTargetFormats",e),m(_h._readyPromise)||Mnt(),_h._readyPromise.then(function(i){let n;if(t instanceof ArrayBuffer){let s=new Uint8Array(t);return n={supportedTargetFormats:e,ktx2Buffer:s},i.scheduleTask(n,[t])}return n={supportedTargetFormats:e,ktx2Buffer:t},i.scheduleTask(n,[t.buffer])}).then(function(i){let n=i.length,s=Object.keys(i[0]),o=s.length,r;for(r=0;r<n;r++){let a=i[r];for(let h=0;h<o;h++){let A=a[s[h]];a[s[h]]=new gx(A.internalFormat,A.datatype,A.width,A.height,A.levelBuffer)}}if(o===1){for(r=0;r<n;++r)i[r]=i[r][s[0]];n===1&&(i=i[0])}return i}).catch(function(i){throw i})};Fx=_h});function Ox(t){p.defined("resourceOrUrlOrBuffer",t);let e;return t instanceof ArrayBuffer||ArrayBuffer.isView(t)?e=Promise.resolve(t):e=tn.createIfNeeded(t).fetchArrayBuffer(),e.then(function(i){return Fx.transcode(i,Sx)})}var Sx,Vx,Gx=O(()=>{ae();Ia();Yx();Ox.setKTX2SupportedFormats=function(t,e,i,n,s,o){Sx={s3tc:t,pvrtc:e,astc:i,etc:n,etc1:s,bc7:o}};Vx=Ox});function yI(t,e,i,n,s,o,r,a,h,A,d){this._context=t,this._texture=e,this._textureTarget=i,this._targetFace=n,this._pixelDatatype=r,this._internalFormat=s,this._pixelFormat=o,this._size=a,this._preMultiplyAlpha=h,this._flipY=A,this._initialized=d}var kl,Bx=O(()=>{ae();bt();mt();Vt();_c();Ec();Object.defineProperties(yI.prototype,{pixelFormat:{get:function(){return this._pixelFormat}},pixelDatatype:{get:function(){return this._pixelDatatype}},_target:{get:function(){return this._targetFace}}});yI.prototype.copyFrom=function(t){p.defined("options",t);let e=Z(t.xOffset,0),i=Z(t.yOffset,0);if(p.defined("options.source",t.source),p.typeOf.number.greaterThanOrEquals("xOffset",e,0),p.typeOf.number.greaterThanOrEquals("yOffset",i,0),e+t.source.width>this._size)throw new Y("xOffset + options.source.width must be less than or equal to width.");if(i+t.source.height>this._size)throw new Y("yOffset + options.source.height must be less than or equal to height.");let n=t.source,s=this._context._gl,o=this._textureTarget,r=this._targetFace;s.activeTexture(s.TEXTURE0),s.bindTexture(o,this._texture);let a=n.width,h=n.height,A=n.arrayBufferView,d=this._size,f=this._pixelFormat,E=this._internalFormat,_=this._pixelDatatype,R=this._preMultiplyAlpha,I=this._flipY,C=Z(t.skipColorSpaceConversion,!1),N=4;m(A)&&(N=Ie.alignmentInBytes(f,_,a)),s.pixelStorei(s.UNPACK_ALIGNMENT,N),C?s.pixelStorei(s.UNPACK_COLORSPACE_CONVERSION_WEBGL,s.NONE):s.pixelStorei(s.UNPACK_COLORSPACE_CONVERSION_WEBGL,s.BROWSER_DEFAULT_WEBGL);let T=!1;if(!this._initialized){if(e===0&&i===0&&a===d&&h===d)m(A)?(s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL,!1),I&&(A=Ie.flipY(A,f,_,d,d)),s.texImage2D(r,0,E,d,d,0,f,ge.toWebGLConstant(_,this._context),A)):(s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,R),s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL,I),s.texImage2D(r,0,E,f,ge.toWebGLConstant(_,this._context),n)),T=!0;else{s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL,!1);let F=Ie.createTypedArray(f,_,d,d);s.texImage2D(r,0,E,d,d,0,f,ge.toWebGLConstant(_,this._context),F)}this._initialized=!0}T||(m(A)?(s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL,!1),I&&(A=Ie.flipY(A,f,_,a,h)),s.texSubImage2D(r,0,e,i,a,h,f,ge.toWebGLConstant(_,this._context),A)):(s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,R),s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL,I),s.texSubImage2D(r,0,e,i,f,ge.toWebGLConstant(_,this._context),n))),s.bindTexture(o,null)};yI.prototype.copyFromFramebuffer=function(t,e,i,n,s,o){if(t=Z(t,0),e=Z(e,0),i=Z(i,0),n=Z(n,0),s=Z(s,this._size),o=Z(o,this._size),p.typeOf.number.greaterThanOrEquals("xOffset",t,0),p.typeOf.number.greaterThanOrEquals("yOffset",e,0),p.typeOf.number.greaterThanOrEquals("framebufferXOffset",i,0),p.typeOf.number.greaterThanOrEquals("framebufferYOffset",n,0),t+s>this._size)throw new Y("xOffset + source.width must be less than or equal to width.");if(e+o>this._size)throw new Y("yOffset + source.height must be less than or equal to height.");if(this._pixelDatatype===ge.FLOAT)throw new Y("Cannot call copyFromFramebuffer when the texture pixel data type is FLOAT.");if(this._pixelDatatype===ge.HALF_FLOAT)throw new Y("Cannot call copyFromFramebuffer when the texture pixel data type is HALF_FLOAT.");let r=this._context._gl,a=this._textureTarget;r.activeTexture(r.TEXTURE0),r.bindTexture(a,this._texture),r.copyTexSubImage2D(this._targetFace,0,t,e,i,n,s,o),r.bindTexture(a,null),this._initialized=!0};kl=yI});function qE(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context);let e=t.context,i=t.source,n,s;if(m(i)){let T=[i.positiveX,i.negativeX,i.positiveY,i.negativeY,i.positiveZ,i.negativeZ];if(!T[0]||!T[1]||!T[2]||!T[3]||!T[4]||!T[5])throw new Y("options.source requires positiveX, negativeX, positiveY, negativeY, positiveZ, and negativeZ faces.");n=T[0].width,s=T[0].height;for(let F=1;F<6;++F)if(Number(T[F].width)!==n||Number(T[F].height)!==s)throw new Y("Each face in options.source must have the same width and height.")}else n=t.width,s=t.height;let o=n,r=Z(t.pixelDatatype,ge.UNSIGNED_BYTE),a=Z(t.pixelFormat,Ie.RGBA),h=Ie.toInternalFormat(a,r,e);if(!m(n)||!m(s))throw new Y("options requires a source field to create an initialized cube map or width and height fields to create a blank cube map.");if(n!==s)throw new Y("Width must equal height.");if(o<=0)throw new Y("Width and height must be greater than zero.");if(o>en.maximumCubeMapSize)throw new Y(`Width and height must be less than or equal to the maximum cube map size (${en.maximumCubeMapSize}).  Check maximumCubeMapSize.`);if(!Ie.validate(a))throw new Y("Invalid options.pixelFormat.");if(Ie.isDepthFormat(a))throw new Y("options.pixelFormat cannot be DEPTH_COMPONENT or DEPTH_STENCIL.");if(!ge.validate(r))throw new Y("Invalid options.pixelDatatype.");if(r===ge.FLOAT&&!e.floatingPointTexture)throw new Y("When options.pixelDatatype is FLOAT, this WebGL implementation must support the OES_texture_float extension.");if(r===ge.HALF_FLOAT&&!e.halfFloatingPointTexture)throw new Y("When options.pixelDatatype is HALF_FLOAT, this WebGL implementation must support the OES_texture_half_float extension.");let A=Ie.textureSizeInBytes(a,r,o,o)*6,d=t.preMultiplyAlpha||a===Ie.RGB||a===Ie.LUMINANCE,f=Z(t.flipY,!0),E=Z(t.skipColorSpaceConversion,!1),_=e._gl,R=_.TEXTURE_CUBE_MAP,I=_.createTexture();_.activeTexture(_.TEXTURE0),_.bindTexture(R,I);function C(T,F,b,G,M){let Q=F.arrayBufferView;m(Q)||(Q=F.bufferView);let U=4;m(Q)&&(U=Ie.alignmentInBytes(a,r,n)),_.pixelStorei(_.UNPACK_ALIGNMENT,U),M?_.pixelStorei(_.UNPACK_COLORSPACE_CONVERSION_WEBGL,_.NONE):_.pixelStorei(_.UNPACK_COLORSPACE_CONVERSION_WEBGL,_.BROWSER_DEFAULT_WEBGL),m(Q)?(_.pixelStorei(_.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),_.pixelStorei(_.UNPACK_FLIP_Y_WEBGL,!1),G&&(Q=Ie.flipY(Q,a,r,o,o)),_.texImage2D(T,0,h,o,o,0,a,ge.toWebGLConstant(r,e),Q)):(_.pixelStorei(_.UNPACK_PREMULTIPLY_ALPHA_WEBGL,b),_.pixelStorei(_.UNPACK_FLIP_Y_WEBGL,G),_.texImage2D(T,0,h,a,ge.toWebGLConstant(r,e),F))}m(i)?(C(_.TEXTURE_CUBE_MAP_POSITIVE_X,i.positiveX,d,f,E),C(_.TEXTURE_CUBE_MAP_NEGATIVE_X,i.negativeX,d,f,E),C(_.TEXTURE_CUBE_MAP_POSITIVE_Y,i.positiveY,d,f,E),C(_.TEXTURE_CUBE_MAP_NEGATIVE_Y,i.negativeY,d,f,E),C(_.TEXTURE_CUBE_MAP_POSITIVE_Z,i.positiveZ,d,f,E),C(_.TEXTURE_CUBE_MAP_NEGATIVE_Z,i.negativeZ,d,f,E)):(_.texImage2D(_.TEXTURE_CUBE_MAP_POSITIVE_X,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null),_.texImage2D(_.TEXTURE_CUBE_MAP_NEGATIVE_X,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null),_.texImage2D(_.TEXTURE_CUBE_MAP_POSITIVE_Y,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null),_.texImage2D(_.TEXTURE_CUBE_MAP_NEGATIVE_Y,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null),_.texImage2D(_.TEXTURE_CUBE_MAP_POSITIVE_Z,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null),_.texImage2D(_.TEXTURE_CUBE_MAP_NEGATIVE_Z,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null)),_.bindTexture(R,null),this._context=e,this._textureFilterAnisotropic=e._textureFilterAnisotropic,this._textureTarget=R,this._texture=I,this._pixelFormat=a,this._pixelDatatype=r,this._size=o,this._hasMipmap=!1,this._sizeInBytes=A,this._preMultiplyAlpha=d,this._flipY=f,this._sampler=void 0;let N=m(i);this._positiveX=new kl(e,I,R,_.TEXTURE_CUBE_MAP_POSITIVE_X,h,a,r,o,d,f,N),this._negativeX=new kl(e,I,R,_.TEXTURE_CUBE_MAP_NEGATIVE_X,h,a,r,o,d,f,N),this._positiveY=new kl(e,I,R,_.TEXTURE_CUBE_MAP_POSITIVE_Y,h,a,r,o,d,f,N),this._negativeY=new kl(e,I,R,_.TEXTURE_CUBE_MAP_NEGATIVE_Y,h,a,r,o,d,f,N),this._positiveZ=new kl(e,I,R,_.TEXTURE_CUBE_MAP_POSITIVE_Z,h,a,r,o,d,f,N),this._negativeZ=new kl(e,I,R,_.TEXTURE_CUBE_MAP_NEGATIVE_Z,h,a,r,o,d,f,N),this.sampler=m(t.sampler)?t.sampler:new ZA}var LN,Wx=O(()=>{ae();bt();mt();Ws();Vt();_e();_c();ga();Bx();DT();Ec();YE();NE();bE();Object.defineProperties(qE.prototype,{positiveX:{get:function(){return this._positiveX}},negativeX:{get:function(){return this._negativeX}},positiveY:{get:function(){return this._positiveY}},negativeY:{get:function(){return this._negativeY}},positiveZ:{get:function(){return this._positiveZ}},negativeZ:{get:function(){return this._negativeZ}},sampler:{get:function(){return this._sampler},set:function(t){let e=t.minificationFilter,i=t.magnificationFilter,n=e===_s.NEAREST_MIPMAP_NEAREST||e===_s.NEAREST_MIPMAP_LINEAR||e===_s.LINEAR_MIPMAP_NEAREST||e===_s.LINEAR_MIPMAP_LINEAR,s=this._context,o=this._pixelDatatype;(o===ge.FLOAT&&!s.textureFloatLinear||o===ge.HALF_FLOAT&&!s.textureHalfFloatLinear)&&(e=n?_s.NEAREST_MIPMAP_NEAREST:_s.NEAREST,i=Na.NEAREST);let r=s._gl,a=this._textureTarget;r.activeTexture(r.TEXTURE0),r.bindTexture(a,this._texture),r.texParameteri(a,r.TEXTURE_MIN_FILTER,e),r.texParameteri(a,r.TEXTURE_MAG_FILTER,i),r.texParameteri(a,r.TEXTURE_WRAP_S,t.wrapS),r.texParameteri(a,r.TEXTURE_WRAP_T,t.wrapT),m(this._textureFilterAnisotropic)&&r.texParameteri(a,this._textureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT,t.maximumAnisotropy),r.bindTexture(a,null),this._sampler=t}},pixelFormat:{get:function(){return this._pixelFormat}},pixelDatatype:{get:function(){return this._pixelDatatype}},width:{get:function(){return this._size}},height:{get:function(){return this._size}},sizeInBytes:{get:function(){return this._hasMipmap?Math.floor(this._sizeInBytes*4/3):this._sizeInBytes}},preMultiplyAlpha:{get:function(){return this._preMultiplyAlpha}},flipY:{get:function(){return this._flipY}},_target:{get:function(){return this._textureTarget}}});qE.prototype.generateMipmap=function(t){if(t=Z(t,Lm.DONT_CARE),this._size>1&&!L.isPowerOfTwo(this._size))throw new Y("width and height must be a power of two to call generateMipmap().");if(!Lm.validate(t))throw new Y("hint is invalid.");this._hasMipmap=!0;let e=this._context._gl,i=this._textureTarget;e.hint(e.GENERATE_MIPMAP_HINT,t),e.activeTexture(e.TEXTURE0),e.bindTexture(i,this._texture),e.generateMipmap(i),e.bindTexture(i,null)};qE.prototype.isDestroyed=function(){return!1};qE.prototype.destroy=function(){return this._context._gl.deleteTexture(this._texture),this._positiveX=li(this._positiveX),this._negativeX=li(this._negativeX),this._positiveY=li(this._positiveY),this._negativeY=li(this._negativeY),this._positiveZ=li(this._positiveZ),this._negativeZ=li(this._negativeZ),li(this)};LN=qE});var Dx,Mx=O(()=>{Dx=`uniform sampler2D image;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);
    vec4 rampColor = texture(image, vec2(materialInput.aspect / (2.0 * czm_pi), 0.5));
    rampColor = czm_gammaCorrect(rampColor);
    material.diffuse = rampColor.rgb;
    material.alpha = rampColor.a;
    return material;
}
`});var Ux,Qx=O(()=>{Ux=`uniform sampler2D image;
uniform float strength;
uniform vec2 repeat;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;

    vec2 centerPixel = fract(repeat * st);
    float centerBump = texture(image, centerPixel).channel;

    float imageWidth = float(imageDimensions.x);
    vec2 rightPixel = fract(repeat * (st + vec2(1.0 / imageWidth, 0.0)));
    float rightBump = texture(image, rightPixel).channel;

    float imageHeight = float(imageDimensions.y);
    vec2 leftPixel = fract(repeat * (st + vec2(0.0, 1.0 / imageHeight)));
    float topBump = texture(image, leftPixel).channel;

    vec3 normalTangentSpace = normalize(vec3(centerBump - rightBump, centerBump - topBump, clamp(1.0 - strength, 0.1, 1.0)));
    vec3 normalEC = materialInput.tangentToEyeMatrix * normalTangentSpace;

    material.normal = normalEC;
    material.diffuse = vec3(0.01);

    return material;
}
`});var kx,Lx=O(()=>{kx=`uniform vec4 lightColor;
uniform vec4 darkColor;
uniform vec2 repeat;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;

    // From Stefan Gustavson's Procedural Textures in GLSL in OpenGL Insights
    float b = mod(floor(repeat.s * st.s) + floor(repeat.t * st.t), 2.0);  // 0.0 or 1.0

    // Find the distance from the closest separator (region between two colors)
    float scaledWidth = fract(repeat.s * st.s);
    scaledWidth = abs(scaledWidth - floor(scaledWidth + 0.5));
    float scaledHeight = fract(repeat.t * st.t);
    scaledHeight = abs(scaledHeight - floor(scaledHeight + 0.5));
    float value = min(scaledWidth, scaledHeight);

    vec4 currentColor = mix(lightColor, darkColor, b);
    vec4 color = czm_antialias(lightColor, darkColor, currentColor, value, 0.03);

    color = czm_gammaCorrect(color);
    material.diffuse = color.rgb;
    material.alpha = color.a;

    return material;
}
`});var yx,wx=O(()=>{yx=`uniform vec4 lightColor;
uniform vec4 darkColor;
uniform vec2 repeat;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    // From Stefan Gustavson's Procedural Textures in GLSL in OpenGL Insights
    float b = smoothstep(0.3, 0.32, length(fract(repeat * materialInput.st) - 0.5));  // 0.0 or 1.0

    vec4 color = mix(lightColor, darkColor, b);
    color = czm_gammaCorrect(color);
    material.diffuse = color.rgb;
    material.alpha = color.a;

    return material;
}
`});var xx,Px=O(()=>{xx=`uniform sampler2D heights;
uniform sampler2D colors;

// This material expects heights to be sorted from lowest to highest.

float getHeight(int idx, float invTexSize)
{
    vec2 uv = vec2((float(idx) + 0.5) * invTexSize, 0.5);
#ifdef OES_texture_float
    return texture(heights, uv).x;
#else
    return czm_unpackFloat(texture(heights, uv));
#endif
}

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    float height = materialInput.height;
    float invTexSize = 1.0 / float(heightsDimensions.x);

    float minHeight = getHeight(0, invTexSize);
    float maxHeight = getHeight(heightsDimensions.x - 1, invTexSize);

    // early-out when outside the height range
    if (height < minHeight || height > maxHeight) {
        material.diffuse = vec3(0.0);
        material.alpha = 0.0;
        return material;
    }

    // Binary search to find heights above and below.
    int idxBelow = 0;
    int idxAbove = heightsDimensions.x;
    float heightBelow = minHeight;
    float heightAbove = maxHeight;

    // while loop not allowed, so use for loop with max iterations.
    // maxIterations of 16 supports a texture size up to 65536 (2^16).
    const int maxIterations = 16;
    for (int i = 0; i < maxIterations; i++) {
        if (idxBelow >= idxAbove - 1) {
            break;
        }

        int idxMid = (idxBelow + idxAbove) / 2;
        float heightTex = getHeight(idxMid, invTexSize);

        if (height > heightTex) {
            idxBelow = idxMid;
            heightBelow = heightTex;
        } else {
            idxAbove = idxMid;
            heightAbove = heightTex;
        }
    }

    float lerper = heightBelow == heightAbove ? 1.0 : (height - heightBelow) / (heightAbove - heightBelow);
    vec2 colorUv = vec2(invTexSize * (float(idxBelow) + 0.5 + lerper), 0.5);
    vec4 color = texture(colors, colorUv);

    // undo preumultiplied alpha
    if (color.a > 0.0) 
    {
        color.rgb /= color.a;
    }
    
    color.rgb = czm_gammaCorrect(color.rgb);

    material.diffuse = color.rgb;
    material.alpha = color.a;
    return material;
}
`});var Jx,jx=O(()=>{Jx=`uniform vec4 color;
uniform float spacing;
uniform float width;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    float distanceToContour = mod(materialInput.height, spacing);

#if (__VERSION__ == 300 || defined(GL_OES_standard_derivatives))
    float dxc = abs(dFdx(materialInput.height));
    float dyc = abs(dFdy(materialInput.height));
    float dF = max(dxc, dyc) * czm_pixelRatio * width;
    float alpha = (distanceToContour < dF) ? 1.0 : 0.0;
#else
    // If no derivatives available (IE 10?), use pixel ratio
    float alpha = (distanceToContour < (czm_pixelRatio * width)) ? 1.0 : 0.0;
#endif

    vec4 outColor = czm_gammaCorrect(vec4(color.rgb, alpha * color.a));
    material.diffuse = outColor.rgb;
    material.alpha = outColor.a;

    return material;
}
`});var Hx,vx=O(()=>{Hx=`uniform sampler2D image;
uniform float minimumHeight;
uniform float maximumHeight;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);
    float scaledHeight = clamp((materialInput.height - minimumHeight) / (maximumHeight - minimumHeight), 0.0, 1.0);
    vec4 rampColor = texture(image, vec2(scaledHeight, 0.5));
    rampColor = czm_gammaCorrect(rampColor);
    material.diffuse = rampColor.rgb;
    material.alpha = rampColor.a;
    return material;
}
`});var zx,Kx=O(()=>{zx=`uniform vec4 fadeInColor;
uniform vec4 fadeOutColor;
uniform float maximumDistance;
uniform bool repeat;
uniform vec2 fadeDirection;
uniform vec2 time;

float getTime(float t, float coord)
{
    float scalar = 1.0 / maximumDistance;
    float q  = distance(t, coord) * scalar;
    if (repeat)
    {
        float r = distance(t, coord + 1.0) * scalar;
        float s = distance(t, coord - 1.0) * scalar;
        q = min(min(r, s), q);
    }
    return clamp(q, 0.0, 1.0);
}

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;
    float s = getTime(time.x, st.s) * fadeDirection.s;
    float t = getTime(time.y, st.t) * fadeDirection.t;

    float u = length(vec2(s, t));
    vec4 color = mix(fadeInColor, fadeOutColor, u);

    color = czm_gammaCorrect(color);
    material.emission = color.rgb;
    material.alpha = color.a;

    return material;
}
`});var Xx,qx=O(()=>{Xx=`uniform vec4 color;
uniform float cellAlpha;
uniform vec2 lineCount;
uniform vec2 lineThickness;
uniform vec2 lineOffset;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;

    float scaledWidth = fract(lineCount.s * st.s - lineOffset.s);
    scaledWidth = abs(scaledWidth - floor(scaledWidth + 0.5));
    float scaledHeight = fract(lineCount.t * st.t - lineOffset.t);
    scaledHeight = abs(scaledHeight - floor(scaledHeight + 0.5));

    float value;

    // Fuzz Factor - Controls blurriness of lines
#if (__VERSION__ == 300 || defined(GL_OES_standard_derivatives))
    const float fuzz = 1.2;
    vec2 thickness = (lineThickness * czm_pixelRatio) - 1.0;

    // From "3D Engine Design for Virtual Globes" by Cozzi and Ring, Listing 4.13.
    vec2 dx = abs(dFdx(st));
    vec2 dy = abs(dFdy(st));
    vec2 dF = vec2(max(dx.s, dy.s), max(dx.t, dy.t)) * lineCount;
    value = min(
        smoothstep(dF.s * thickness.s, dF.s * (fuzz + thickness.s), scaledWidth),
        smoothstep(dF.t * thickness.t, dF.t * (fuzz + thickness.t), scaledHeight));
#else
    // If no derivatives available (IE 10?), revert to view-dependent fuzz
    const float fuzz = 0.05;

    vec2 range = 0.5 - (lineThickness * 0.05);
    value = min(
        1.0 - smoothstep(range.s, range.s + fuzz, scaledWidth),
        1.0 - smoothstep(range.t, range.t + fuzz, scaledHeight));
#endif

    // Edges taken from RimLightingMaterial.glsl
    // See http://www.fundza.com/rman_shaders/surface/fake_rim/fake_rim1.html
    float dRim = 1.0 - abs(dot(materialInput.normalEC, normalize(materialInput.positionToEyeEC)));
    float sRim = smoothstep(0.8, 1.0, dRim);
    value *= (1.0 - sRim);

    vec4 halfColor;
    halfColor.rgb = color.rgb * 0.5;
    halfColor.a = color.a * (1.0 - ((1.0 - cellAlpha) * value));
    halfColor = czm_gammaCorrect(halfColor);
    material.diffuse = halfColor.rgb;
    material.emission = halfColor.rgb;
    material.alpha = halfColor.a;

    return material;
}
`});var $x,tP=O(()=>{$x=`uniform sampler2D image;
uniform float strength;
uniform vec2 repeat;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);
    
    vec4 textureValue = texture(image, fract(repeat * materialInput.st));
    vec3 normalTangentSpace = textureValue.channels;
    normalTangentSpace.xy = normalTangentSpace.xy * 2.0 - 1.0;
    normalTangentSpace.z = clamp(1.0 - strength, 0.1, 1.0);
    normalTangentSpace = normalize(normalTangentSpace);
    vec3 normalEC = materialInput.tangentToEyeMatrix * normalTangentSpace;
    
    material.normal = normalEC;
    
    return material;
}
`});var eP,iP=O(()=>{eP=`uniform vec4 color;

float getPointOnLine(vec2 p0, vec2 p1, float x)
{
    float slope = (p0.y - p1.y) / (p0.x - p1.x);
    return slope * (x - p0.x) + p0.y;
}

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;

#if (__VERSION__ == 300 || defined(GL_OES_standard_derivatives))
    float base = 1.0 - abs(fwidth(st.s)) * 10.0 * czm_pixelRatio;
#else
     // If no derivatives available (IE 10?), 2.5% of the line will be the arrow head
    float base = 0.975;
#endif

    vec2 center = vec2(1.0, 0.5);
    float ptOnUpperLine = getPointOnLine(vec2(base, 1.0), center, st.s);
    float ptOnLowerLine = getPointOnLine(vec2(base, 0.0), center, st.s);

    float halfWidth = 0.15;
    float s = step(0.5 - halfWidth, st.t);
    s *= 1.0 - step(0.5 + halfWidth, st.t);
    s *= 1.0 - step(base, st.s);

    float t = step(base, materialInput.st.s);
    t *= 1.0 - step(ptOnUpperLine, st.t);
    t *= step(ptOnLowerLine, st.t);

    // Find the distance from the closest separator (region between two colors)
    float dist;
    if (st.s < base)
    {
        float d1 = abs(st.t - (0.5 - halfWidth));
        float d2 = abs(st.t - (0.5 + halfWidth));
        dist = min(d1, d2);
    }
    else
    {
        float d1 = czm_infinity;
        if (st.t < 0.5 - halfWidth && st.t > 0.5 + halfWidth)
        {
            d1 = abs(st.s - base);
        }
        float d2 = abs(st.t - ptOnUpperLine);
        float d3 = abs(st.t - ptOnLowerLine);
        dist = min(min(d1, d2), d3);
    }

    vec4 outsideColor = vec4(0.0);
    vec4 currentColor = mix(outsideColor, color, clamp(s + t, 0.0, 1.0));
    vec4 outColor = czm_antialias(outsideColor, color, currentColor, dist);

    outColor = czm_gammaCorrect(outColor);
    material.diffuse = outColor.rgb;
    material.alpha = outColor.a;
    return material;
}
`});var nP,sP=O(()=>{nP=`uniform vec4 color;
uniform vec4 gapColor;
uniform float dashLength;
uniform float dashPattern;
in float v_polylineAngle;

const float maskLength = 16.0;

mat2 rotate(float rad) {
    float c = cos(rad);
    float s = sin(rad);
    return mat2(
        c, s,
        -s, c
    );
}

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 pos = rotate(v_polylineAngle) * gl_FragCoord.xy;

    // Get the relative position within the dash from 0 to 1
    float dashPosition = fract(pos.x / (dashLength * czm_pixelRatio));
    // Figure out the mask index.
    float maskIndex = floor(dashPosition * maskLength);
    // Test the bit mask.
    float maskTest = floor(dashPattern / pow(2.0, maskIndex));
    vec4 fragColor = (mod(maskTest, 2.0) < 1.0) ? gapColor : color;
    if (fragColor.a < 0.005) {   // matches 0/255 and 1/255
        discard;
    }

    fragColor = czm_gammaCorrect(fragColor);
    material.emission = fragColor.rgb;
    material.alpha = fragColor.a;
    return material;
}
`});var oP,rP=O(()=>{oP=`uniform vec4 color;
uniform float glowPower;
uniform float taperPower;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;
    float glow = glowPower / abs(st.t - 0.5) - (glowPower / 0.5);

    if (taperPower <= 0.99999) {
        glow *= min(1.0, taperPower / (0.5 - st.s * 0.5) - (taperPower / 0.5));
    }

    vec4 fragColor;
    fragColor.rgb = max(vec3(glow - 1.0 + color.rgb), color.rgb);
    fragColor.a = clamp(0.0, 1.0, glow) * color.a;
    fragColor = czm_gammaCorrect(fragColor);

    material.emission = fragColor.rgb;
    material.alpha = fragColor.a;

    return material;
}
`});var aP,AP=O(()=>{aP=`uniform vec4 color;
uniform vec4 outlineColor;
uniform float outlineWidth;

in float v_width;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;
    float halfInteriorWidth =  0.5 * (v_width - outlineWidth) / v_width;
    float b = step(0.5 - halfInteriorWidth, st.t);
    b *= 1.0 - step(0.5 + halfInteriorWidth, st.t);

    // Find the distance from the closest separator (region between two colors)
    float d1 = abs(st.t - (0.5 - halfInteriorWidth));
    float d2 = abs(st.t - (0.5 + halfInteriorWidth));
    float dist = min(d1, d2);

    vec4 currentColor = mix(outlineColor, color, b);
    vec4 outColor = czm_antialias(outlineColor, color, currentColor, dist);
    outColor = czm_gammaCorrect(outColor);

    material.diffuse = outColor.rgb;
    material.alpha = outColor.a;

    return material;
}
`});var hP,cP=O(()=>{hP=`uniform vec4 color;
uniform vec4 rimColor;
uniform float width;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    // See http://www.fundza.com/rman_shaders/surface/fake_rim/fake_rim1.html
    float d = 1.0 - dot(materialInput.normalEC, normalize(materialInput.positionToEyeEC));
    float s = smoothstep(1.0 - width, 1.0, d);

    vec4 outColor = czm_gammaCorrect(color);
    vec4 outRimColor = czm_gammaCorrect(rimColor);

    material.diffuse = outColor.rgb;
    material.emission = outRimColor.rgb * s;
    material.alpha = mix(outColor.a, outRimColor.a, s);

    return material;
}
`});var lP,dP=O(()=>{lP=`uniform sampler2D image;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);
    vec4 rampColor = texture(image, vec2(materialInput.slope / (czm_pi / 2.0), 0.5));
    rampColor = czm_gammaCorrect(rampColor);
    material.diffuse = rampColor.rgb;
    material.alpha = rampColor.a;
    return material;
}
`});var mP,fP=O(()=>{mP=`uniform vec4 evenColor;
uniform vec4 oddColor;
uniform float offset;
uniform float repeat;
uniform bool horizontal;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    // Based on the Stripes Fragment Shader in the Orange Book (11.1.2)
    float coord = mix(materialInput.st.s, materialInput.st.t, float(horizontal));
    float value = fract((coord - offset) * (repeat * 0.5));
    float dist = min(value, min(abs(value - 0.5), 1.0 - value));

    vec4 currentColor = mix(evenColor, oddColor, step(0.5, value));
    vec4 color = czm_antialias(evenColor, oddColor, currentColor, dist);
    color = czm_gammaCorrect(color);

    material.diffuse = color.rgb;
    material.alpha = color.a;

    return material;
}
`});var EP,_P=O(()=>{EP=`// Thanks for the contribution Jonas
// http://29a.ch/2012/7/19/webgl-terrain-rendering-water-fog

uniform sampler2D specularMap;
uniform sampler2D normalMap;
uniform vec4 baseWaterColor;
uniform vec4 blendColor;
uniform float frequency;
uniform float animationSpeed;
uniform float amplitude;
uniform float specularIntensity;
uniform float fadeFactor;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    float time = czm_frameNumber * animationSpeed;

    // fade is a function of the distance from the fragment and the frequency of the waves
    float fade = max(1.0, (length(materialInput.positionToEyeEC) / 10000000000.0) * frequency * fadeFactor);

    float specularMapValue = texture(specularMap, materialInput.st).r;

    // note: not using directional motion at this time, just set the angle to 0.0;
    vec4 noise = czm_getWaterNoise(normalMap, materialInput.st * frequency, time, 0.0);
    vec3 normalTangentSpace = noise.xyz * vec3(1.0, 1.0, (1.0 / amplitude));

    // fade out the normal perturbation as we move further from the water surface
    normalTangentSpace.xy /= fade;

    // attempt to fade out the normal perturbation as we approach non water areas (low specular map value)
    normalTangentSpace = mix(vec3(0.0, 0.0, 50.0), normalTangentSpace, specularMapValue);

    normalTangentSpace = normalize(normalTangentSpace);

    // get ratios for alignment of the new normal vector with a vector perpendicular to the tangent plane
    float tsPerturbationRatio = clamp(dot(normalTangentSpace, vec3(0.0, 0.0, 1.0)), 0.0, 1.0);

    // fade out water effect as specular map value decreases
    material.alpha = mix(blendColor.a, baseWaterColor.a, specularMapValue) * specularMapValue;

    // base color is a blend of the water and non-water color based on the value from the specular map
    // may need a uniform blend factor to better control this
    material.diffuse = mix(blendColor.rgb, baseWaterColor.rgb, specularMapValue);

    // diffuse highlights are based on how perturbed the normal is
    material.diffuse += (0.1 * tsPerturbationRatio);

    material.diffuse = material.diffuse;

    material.normal = normalize(materialInput.tangentToEyeMatrix * normalTangentSpace);

    material.specular = specularIntensity;
    material.shininess = 10.0;

    return material;
}
`});function Qt(t){this.type=void 0,this.shaderSource=void 0,this.materials=void 0,this.uniforms=void 0,this._uniforms=void 0,this.translucent=void 0,this._minificationFilter=Z(t.minificationFilter,_s.LINEAR),this._magnificationFilter=Z(t.magnificationFilter,Na.LINEAR),this._strict=void 0,this._template=void 0,this._count=void 0,this._texturePaths={},this._loadedImages=[],this._loadedCubeMaps=[],this._textures={},this._updateFunctions=[],this._defaultTexture=void 0,Unt(t,this),Object.defineProperties(this,{type:{value:this.type,writable:!1}}),m(Qt._uniformList[this.type])||(Qt._uniformList[this.type]=Object.keys(this._uniforms))}function Unt(t,e){t=Z(t,Z.EMPTY_OBJECT),e._strict=Z(t.strict,!1),e._count=Z(t.count,0),e._template=qs(Z(t.fabric,Z.EMPTY_OBJECT)),e._template.uniforms=qs(Z(e._template.uniforms,Z.EMPTY_OBJECT)),e._template.materials=qs(Z(e._template.materials,Z.EMPTY_OBJECT)),e.type=m(e._template.type)?e._template.type:Gs(),e.shaderSource="",e.materials={},e.uniforms={},e._uniforms={},e._translucentFunctions=[];let i,n=Qt._materialCache.getMaterial(e.type);if(m(n)){let o=qs(n.fabric,!0);e._template=es(e._template,o,!0),i=n.translucent}ynt(e),m(n)||Qt._materialCache.addMaterial(e.type,e),xnt(e),Hnt(e),znt(e);let s=e._translucentFunctions.length===0?!0:void 0;if(i=Z(i,s),i=Z(t.translucent,i),m(i))if(typeof i=="function"){let o=function(){return i(e)};e._translucentFunctions.push(o)}else e._translucentFunctions.push(i)}function yN(t,e,i,n){if(m(t)){for(let s in t)if(t.hasOwnProperty(s)){let o=e.indexOf(s)!==-1;(n&&!o||!n&&o)&&i(s,e)}}}function RP(t,e){let i=`fabric: property name '${t}' is not valid. It should be `;for(let n=0;n<e.length;n++){let s=`'${e[n]}'`;i+=n===e.length-1?`or ${s}.`:`${s}, `}throw new Y(i)}function Qnt(t,e){let i=`fabric: uniforms and materials cannot share the same property '${t}'`;throw new Y(i)}function ynt(t){let e=t._template,i=e.uniforms,n=e.materials,s=e.components;if(m(s)&&m(e.source))throw new Y("fabric: cannot have source and components in the same template.");yN(e,knt,RP,!0),yN(s,Lnt,RP,!0);let o=[];for(let r in n)n.hasOwnProperty(r)&&o.push(r);yN(i,o,Qnt,!1)}function wnt(t,e){let i=e._template.materials;for(let n in i)if(i.hasOwnProperty(n)&&t.indexOf(n)>-1)return!0;return!1}function xnt(t){let e=t._template.components,i=t._template.source;if(m(i))t.shaderSource+=`${i}
`;else{if(t.shaderSource+=`czm_material czm_getMaterial(czm_materialInput materialInput)
{
`,t.shaderSource+=`czm_material material = czm_getDefaultMaterial(materialInput);
`,m(e)){let n=Object.keys(t._template.materials).length>0;for(let s in e)if(e.hasOwnProperty(s))if(s==="diffuse"||s==="emission"){let r=n&&wnt(e[s],t)?e[s]:`czm_gammaCorrect(${e[s]})`;t.shaderSource+=`material.${s} = ${r}; 
`}else s==="alpha"?t.shaderSource+=`material.alpha = ${e.alpha}; 
`:t.shaderSource+=`material.${s} = ${e[s]};
`}t.shaderSource+=`return material;
}
`}}function Jnt(t){let e;return function(i,n){let s=i.uniforms,o=s[t],r=e!==o,a=!m(o)||o===Qt.DefaultImageId;e=o;let h=i._textures[t],A,d;if(o instanceof HTMLVideoElement){if(o.readyState>=2){if(r&&m(h)&&(h!==n.defaultTexture&&h.destroy(),h=void 0),!m(h)||h===n.defaultTexture){let E=new ZA({minificationFilter:i._minificationFilter,magnificationFilter:i._magnificationFilter});h=new Fa({context:n,source:o,sampler:E}),i._textures[t]=h;return}h.copyFrom({source:o})}else m(h)||(i._textures[t]=n.defaultTexture);return}if(o instanceof Fa&&o!==h){i._texturePaths[t]=void 0;let E=i._textures[t];m(E)&&E!==i._defaultTexture&&E.destroy(),i._textures[t]=o,A=`${t}Dimensions`,s.hasOwnProperty(A)&&(d=s[A],d.x=o._width,d.y=o._height);return}if(r&&m(h)&&a&&(h!==i._defaultTexture&&h.destroy(),h=void 0),m(h)||(i._texturePaths[t]=void 0,h=i._textures[t]=i._defaultTexture,A=`${t}Dimensions`,s.hasOwnProperty(A)&&(d=s[A],d.x=h._width,d.y=h._height)),a)return;let f=o instanceof tn;if(!m(i._texturePaths[t])||f&&o.url!==i._texturePaths[t].url||!f&&o!==i._texturePaths[t]){if(typeof o=="string"||f){let E=f?o:tn.createIfNeeded(o),_;Pnt.test(E.url)?_=Vx(E.url):_=E.fetchImage(),Promise.resolve(_).then(function(R){i._loadedImages.push({id:t,image:R})}).catch(function(){m(h)&&h!==i._defaultTexture&&h.destroy(),i._textures[t]=i._defaultTexture})}else(o instanceof HTMLCanvasElement||o instanceof HTMLImageElement)&&i._loadedImages.push({id:t,image:o});i._texturePaths[t]=o}}}function jnt(t){return function(e,i){let n=e.uniforms[t];if(n instanceof LN){let o=e._textures[t];o!==e._defaultTexture&&o.destroy(),e._texturePaths[t]=void 0,e._textures[t]=n;return}if(m(e._textures[t])||(e._texturePaths[t]=void 0,e._textures[t]=i.defaultCubeMap),n===Qt.DefaultCubeMapId)return;let s=n.positiveX+n.negativeX+n.positiveY+n.negativeY+n.positiveZ+n.negativeZ;if(s!==e._texturePaths[t]){let o=[tn.createIfNeeded(n.positiveX).fetchImage(),tn.createIfNeeded(n.negativeX).fetchImage(),tn.createIfNeeded(n.positiveY).fetchImage(),tn.createIfNeeded(n.negativeY).fetchImage(),tn.createIfNeeded(n.positiveZ).fetchImage(),tn.createIfNeeded(n.negativeZ).fetchImage()];Promise.all(o).then(function(r){e._loadedCubeMaps.push({id:t,images:r})}),e._texturePaths[t]=s}}}function Hnt(t){let e=t._template.uniforms;for(let i in e)e.hasOwnProperty(i)&&IP(t,i)}function IP(t,e){let i=t._strict,n=t._template.uniforms,s=n[e],o=vnt(s);if(!m(o))throw new Y(`fabric: uniform '${e}' has invalid type.`);let r;if(o==="channels"){if(r=$E(t,e,s,!1),r===0&&i)throw new Y(`strict: shader source does not use channels '${e}'.`)}else{if(o==="sampler2D"){let A=`${e}Dimensions`;Knt(t,A)>0&&(n[A]={type:"ivec3",x:1,y:1},IP(t,A))}if(!new RegExp(`uniform\\s+${o}\\s+${e}\\s*;`).test(t.shaderSource)){let A=`uniform ${o} ${e};`;t.shaderSource=A+t.shaderSource}let h=`${e}_${t._count++}`;if(r=$E(t,e,h),r===1&&i)throw new Y(`strict: shader source does not use uniform '${e}'.`);if(t.uniforms[e]=s,o==="sampler2D")t._uniforms[h]=function(){return t._textures[e]},t._updateFunctions.push(Jnt(e));else if(o==="samplerCube")t._uniforms[h]=function(){return t._textures[e]},t._updateFunctions.push(jnt(e));else if(o.indexOf("mat")!==-1){let A=new ZP[o];t._uniforms[h]=function(){return ZP[o].fromColumnMajorArray(t.uniforms[e],A)}}else t._uniforms[h]=function(){return t.uniforms[e]}}}function vnt(t){let e=t.type;if(!m(e)){let i=typeof t;if(i==="number")e="float";else if(i==="boolean")e="bool";else if(i==="string"||t instanceof tn||t instanceof HTMLCanvasElement||t instanceof HTMLImageElement)/^([rgba]){1,4}$/i.test(t)?e="channels":t===Qt.DefaultCubeMapId?e="samplerCube":e="sampler2D";else if(i==="object")if(Array.isArray(t))(t.length===4||t.length===9||t.length===16)&&(e=`mat${Math.sqrt(t.length)}`);else{let n=0;for(let s in t)t.hasOwnProperty(s)&&(n+=1);n>=2&&n<=4?e=`vec${n}`:n===6&&(e="samplerCube")}}return e}function znt(t){let e=t._strict,i=t._template.materials;for(let n in i)if(i.hasOwnProperty(n)){let s=new Qt({strict:e,fabric:i[n],count:t._count});t._count=s._count,t._uniforms=es(t._uniforms,s._uniforms,!0),t.materials[n]=s,t._translucentFunctions=t._translucentFunctions.concat(s._translucentFunctions);let o="czm_getMaterial",r=`${o}_${t._count++}`;$E(s,o,r),t.shaderSource=s.shaderSource+t.shaderSource;let a=`${r}(materialInput)`;if($E(t,n,a)===0&&e)throw new Y(`strict: shader source does not use material '${n}'.`)}}function $E(t,e,i,n){n=Z(n,!0);let s=0,o="([\\w])?",r=`([\\w${n?".":""}])?`,a=new RegExp(r+e+o,"g");return t.shaderSource=t.shaderSource.replace(a,function(h,A,d){return A||d?h:(s+=1,i)}),s}function Knt(t,e,i){return $E(t,e,e,i)}var knt,Lnt,ZP,Pnt,wN,pP=O(()=>{Xe();aE();Qn();KA();ih();bt();mt();Ws();Vt();Gx();dc();dn();Fi();Ia();Wx();uI();Mx();Qx();Lx();wx();Px();jx();vx();Kx();qx();tP();iP();sP();rP();AP();cP();YE();dP();fP();NE();bE();_P();Qt._uniformList={};Qt.fromType=function(t,e){if(!m(Qt._materialCache.getMaterial(t)))throw new Y(`material with type '${t}' does not exist.`);let i=new Qt({fabric:{type:t}});if(m(e))for(let n in e)e.hasOwnProperty(n)&&(i.uniforms[n]=e[n]);return i};Qt.prototype.isTranslucent=function(){if(m(this.translucent))return typeof this.translucent=="function"?this.translucent():this.translucent;let t=!0,e=this._translucentFunctions,i=e.length;for(let n=0;n<i;++n){let s=e[n];if(typeof s=="function"?t=t&&s():t=t&&s,!t)break}return t};Qt.prototype.update=function(t){this._defaultTexture=t.defaultTexture;let e,i,n=this._loadedImages,s=n.length;for(e=0;e<s;++e){let h=n[e];i=h.id;let A=h.image,d;Array.isArray(A)&&(d=A.slice(1,A.length).map(function(I){return I.bufferView}),A=A[0]);let f=new ZA({minificationFilter:this._minificationFilter,magnificationFilter:this._magnificationFilter}),E;m(A.internalFormat)?E=new Fa({context:t,pixelFormat:A.internalFormat,width:A.width,height:A.height,source:{arrayBufferView:A.bufferView,mipLevels:d},sampler:f}):E=new Fa({context:t,source:A,sampler:f});let _=this._textures[i];m(_)&&_!==this._defaultTexture&&_.destroy(),this._textures[i]=E;let R=`${i}Dimensions`;if(this.uniforms.hasOwnProperty(R)){let I=this.uniforms[R];I.x=E._width,I.y=E._height}}n.length=0;let o=this._loadedCubeMaps;for(s=o.length,e=0;e<s;++e){let h=o[e];i=h.id;let A=h.images,d=new LN({context:t,source:{positiveX:A[0],negativeX:A[1],positiveY:A[2],negativeY:A[3],positiveZ:A[4],negativeZ:A[5]},sampler:new ZA({minificationFilter:this._minificationFilter,magnificationFilter:this._magnificationFilter})});this._textures[i]=d}o.length=0;let r=this._updateFunctions;for(s=r.length,e=0;e<s;++e)r[e](this,t);let a=this.materials;for(let h in a)a.hasOwnProperty(h)&&a[h].update(t)};Qt.prototype.isDestroyed=function(){return!1};Qt.prototype.destroy=function(){let t=this._textures;for(let i in t)if(t.hasOwnProperty(i)){let n=t[i];n!==this._defaultTexture&&n.destroy()}let e=this.materials;for(let i in e)e.hasOwnProperty(i)&&e[i].destroy();return li(this)};knt=["type","materials","uniforms","components","source"],Lnt=["diffuse","specular","shininess","normal","emission","alpha"];ZP={mat2:Hn,mat3:lt,mat4:at},Pnt=/\.ktx2$/i;Qt._materialCache={_materials:{},addMaterial:function(t,e){this._materials[t]=e},getMaterial:function(t){return this._materials[t]}};Qt.DefaultImageId="czm_defaultImage";Qt.DefaultCubeMapId="czm_defaultCubeMap";Qt.ColorType="Color";Qt._materialCache.addMaterial(Qt.ColorType,{fabric:{type:Qt.ColorType,uniforms:{color:new Zt(1,0,0,.5)},components:{diffuse:"color.rgb",alpha:"color.a"}},translucent:function(t){return t.uniforms.color.alpha<1}});Qt.ImageType="Image";Qt._materialCache.addMaterial(Qt.ImageType,{fabric:{type:Qt.ImageType,uniforms:{image:Qt.DefaultImageId,repeat:new nt(1,1),color:new Zt(1,1,1,1)},components:{diffuse:"texture(image, fract(repeat * materialInput.st)).rgb * color.rgb",alpha:"texture(image, fract(repeat * materialInput.st)).a * color.a"}},translucent:function(t){return t.uniforms.color.alpha<1}});Qt.DiffuseMapType="DiffuseMap";Qt._materialCache.addMaterial(Qt.DiffuseMapType,{fabric:{type:Qt.DiffuseMapType,uniforms:{image:Qt.DefaultImageId,channels:"rgb",repeat:new nt(1,1)},components:{diffuse:"texture(image, fract(repeat * materialInput.st)).channels"}},translucent:!1});Qt.AlphaMapType="AlphaMap";Qt._materialCache.addMaterial(Qt.AlphaMapType,{fabric:{type:Qt.AlphaMapType,uniforms:{image:Qt.DefaultImageId,channel:"a",repeat:new nt(1,1)},components:{alpha:"texture(image, fract(repeat * materialInput.st)).channel"}},translucent:!0});Qt.SpecularMapType="SpecularMap";Qt._materialCache.addMaterial(Qt.SpecularMapType,{fabric:{type:Qt.SpecularMapType,uniforms:{image:Qt.DefaultImageId,channel:"r",repeat:new nt(1,1)},components:{specular:"texture(image, fract(repeat * materialInput.st)).channel"}},translucent:!1});Qt.EmissionMapType="EmissionMap";Qt._materialCache.addMaterial(Qt.EmissionMapType,{fabric:{type:Qt.EmissionMapType,uniforms:{image:Qt.DefaultImageId,channels:"rgb",repeat:new nt(1,1)},components:{emission:"texture(image, fract(repeat * materialInput.st)).channels"}},translucent:!1});Qt.BumpMapType="BumpMap";Qt._materialCache.addMaterial(Qt.BumpMapType,{fabric:{type:Qt.BumpMapType,uniforms:{image:Qt.DefaultImageId,channel:"r",strength:.8,repeat:new nt(1,1)},source:Ux},translucent:!1});Qt.NormalMapType="NormalMap";Qt._materialCache.addMaterial(Qt.NormalMapType,{fabric:{type:Qt.NormalMapType,uniforms:{image:Qt.DefaultImageId,channels:"rgb",strength:.8,repeat:new nt(1,1)},source:$x},translucent:!1});Qt.GridType="Grid";Qt._materialCache.addMaterial(Qt.GridType,{fabric:{type:Qt.GridType,uniforms:{color:new Zt(0,1,0,1),cellAlpha:.1,lineCount:new nt(8,8),lineThickness:new nt(1,1),lineOffset:new nt(0,0)},source:Xx},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.cellAlpha<1}});Qt.StripeType="Stripe";Qt._materialCache.addMaterial(Qt.StripeType,{fabric:{type:Qt.StripeType,uniforms:{horizontal:!0,evenColor:new Zt(1,1,1,.5),oddColor:new Zt(0,0,1,.5),offset:0,repeat:5},source:mP},translucent:function(t){let e=t.uniforms;return e.evenColor.alpha<1||e.oddColor.alpha<1}});Qt.CheckerboardType="Checkerboard";Qt._materialCache.addMaterial(Qt.CheckerboardType,{fabric:{type:Qt.CheckerboardType,uniforms:{lightColor:new Zt(1,1,1,.5),darkColor:new Zt(0,0,0,.5),repeat:new nt(5,5)},source:kx},translucent:function(t){let e=t.uniforms;return e.lightColor.alpha<1||e.darkColor.alpha<1}});Qt.DotType="Dot";Qt._materialCache.addMaterial(Qt.DotType,{fabric:{type:Qt.DotType,uniforms:{lightColor:new Zt(1,1,0,.75),darkColor:new Zt(0,1,1,.75),repeat:new nt(5,5)},source:yx},translucent:function(t){let e=t.uniforms;return e.lightColor.alpha<1||e.darkColor.alpha<1}});Qt.WaterType="Water";Qt._materialCache.addMaterial(Qt.WaterType,{fabric:{type:Qt.WaterType,uniforms:{baseWaterColor:new Zt(.2,.3,.6,1),blendColor:new Zt(0,1,.699,1),specularMap:Qt.DefaultImageId,normalMap:Qt.DefaultImageId,frequency:10,animationSpeed:.01,amplitude:1,specularIntensity:.5,fadeFactor:1},source:EP},translucent:function(t){let e=t.uniforms;return e.baseWaterColor.alpha<1||e.blendColor.alpha<1}});Qt.RimLightingType="RimLighting";Qt._materialCache.addMaterial(Qt.RimLightingType,{fabric:{type:Qt.RimLightingType,uniforms:{color:new Zt(1,0,0,.7),rimColor:new Zt(1,1,1,.4),width:.3},source:hP},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.rimColor.alpha<1}});Qt.FadeType="Fade";Qt._materialCache.addMaterial(Qt.FadeType,{fabric:{type:Qt.FadeType,uniforms:{fadeInColor:new Zt(1,0,0,1),fadeOutColor:new Zt(0,0,0,0),maximumDistance:.5,repeat:!0,fadeDirection:{x:!0,y:!0},time:new nt(.5,.5)},source:zx},translucent:function(t){let e=t.uniforms;return e.fadeInColor.alpha<1||e.fadeOutColor.alpha<1}});Qt.PolylineArrowType="PolylineArrow";Qt._materialCache.addMaterial(Qt.PolylineArrowType,{fabric:{type:Qt.PolylineArrowType,uniforms:{color:new Zt(1,1,1,1)},source:eP},translucent:!0});Qt.PolylineDashType="PolylineDash";Qt._materialCache.addMaterial(Qt.PolylineDashType,{fabric:{type:Qt.PolylineDashType,uniforms:{color:new Zt(1,0,1,1),gapColor:new Zt(0,0,0,0),dashLength:16,dashPattern:255},source:nP},translucent:!0});Qt.PolylineGlowType="PolylineGlow";Qt._materialCache.addMaterial(Qt.PolylineGlowType,{fabric:{type:Qt.PolylineGlowType,uniforms:{color:new Zt(0,.5,1,1),glowPower:.25,taperPower:1},source:oP},translucent:!0});Qt.PolylineOutlineType="PolylineOutline";Qt._materialCache.addMaterial(Qt.PolylineOutlineType,{fabric:{type:Qt.PolylineOutlineType,uniforms:{color:new Zt(1,1,1,1),outlineColor:new Zt(1,0,0,1),outlineWidth:1},source:aP},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.outlineColor.alpha<1}});Qt.ElevationContourType="ElevationContour";Qt._materialCache.addMaterial(Qt.ElevationContourType,{fabric:{type:Qt.ElevationContourType,uniforms:{spacing:100,color:new Zt(1,0,0,1),width:1},source:Jx},translucent:!1});Qt.ElevationRampType="ElevationRamp";Qt._materialCache.addMaterial(Qt.ElevationRampType,{fabric:{type:Qt.ElevationRampType,uniforms:{image:Qt.DefaultImageId,minimumHeight:0,maximumHeight:1e4},source:Hx},translucent:!1});Qt.SlopeRampMaterialType="SlopeRamp";Qt._materialCache.addMaterial(Qt.SlopeRampMaterialType,{fabric:{type:Qt.SlopeRampMaterialType,uniforms:{image:Qt.DefaultImageId},source:lP},translucent:!1});Qt.AspectRampMaterialType="AspectRamp";Qt._materialCache.addMaterial(Qt.AspectRampMaterialType,{fabric:{type:Qt.AspectRampMaterialType,uniforms:{image:Qt.DefaultImageId},source:Dx},translucent:!1});Qt.ElevationBandType="ElevationBand";Qt._materialCache.addMaterial(Qt.ElevationBandType,{fabric:{type:Qt.ElevationBandType,uniforms:{heights:Qt.DefaultImageId,colors:Qt.DefaultImageId},source:xx},translucent:!0});wN=Qt});function Ll(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.translucent,!0),i=!1,n=Ll.VERTEX_FORMAT;this.material=m(t.material)?t.material:wN.fromType(wN.ColorType),this.translucent=e,this._vertexShaderSource=Z(t.vertexShaderSource,xN),this._fragmentShaderSource=Z(t.fragmentShaderSource,Xnt),this._renderState=Uo.getDefaultRenderState(e,i,t.renderState),this._closed=i,this._vertexFormat=n}var xN,Xnt,uP,CP=O(()=>{bt();mt();Il();Ls();px();BN();Cx();LI();pP();xN=`${kI}
${Ix}`,Xnt=ux;_o.isInternetExplorer()||(xN=`#define CLIP_POLYLINE 
${xN}`);Object.defineProperties(Ll.prototype,{vertexShaderSource:{get:function(){let t=this._vertexShaderSource;return this.material.shaderSource.search(/in\s+float\s+v_polylineAngle;/g)!==-1&&(t=`#define POLYLINE_DASH
${t}`),t}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},vertexFormat:{get:function(){return this._vertexFormat}}});Ll.VERTEX_FORMAT=Ot.POSITION_AND_ST;Ll.prototype.getFragmentShaderSource=Uo.prototype.getFragmentShaderSource;Ll.prototype.isTranslucent=Uo.prototype.isTranslucent;Ll.prototype.getRenderState=Uo.prototype.getRenderState;uP=Ll});function qnt(t){t=Z(t,Z.EMPTY_OBJECT),this.position=t.position,this.normal=t.normal,this.st=t.st,this.bitangent=t.bitangent,this.tangent=t.tangent,this.color=t.color}var we,En=O(()=>{bt();we=qnt});var $nt,Pe,go=O(()=>{$nt={NONE:0,TOP:1,ALL:2},Pe=Object.freeze($nt)});function tst(t,e){if(!m(t))throw new Y("array is required.");if(!m(e)||e<1)throw new Y("numberOfArrays must be greater than 0.");let i=[],n=t.length,s=0;for(;s<n;){let o=Math.ceil((n-s)/e--);i.push(t.slice(s,s+o)),s+=o}return i}var gP,TP=O(()=>{mt();Vt();gP=tst});function Rh(t,e,i){if(!m(t))throw new Y("context is required");if(!m(e))throw new Y("attributes is required");if(!m(i))throw new Y("numberOfInstances is required");if(this._attributes=e,this._numberOfInstances=i,e.length===0)return;let n=est(e),s=t.floatingPointTexture,o=n===ge.FLOAT&&!s,r=ist(e,o),a=nst(r,e,o),h=Math.floor(en.maximumTextureSize/a),A=Math.min(i,h),d=a*A,f=Math.ceil(i/A),E=1/d,_=E*.5,R=1/f,I=R*.5;this._textureDimensions=new nt(d,f),this._textureStep=new ie(E,_,R,I),this._pixelDatatype=o?ge.UNSIGNED_BYTE:n,this._packFloats=o,this._offsets=r,this._stride=a,this._texture=void 0;let C=4*d*f;this._batchValues=n===ge.FLOAT&&!o?new Float32Array(C):new Uint8Array(C),this._batchValuesDirty=!1}function est(t){let e=!1,i=t.length;for(let n=0;n<i;++n)if(t[n].componentDatatype!==At.UNSIGNED_BYTE){e=!0;break}return e?ge.FLOAT:ge.UNSIGNED_BYTE}function bP(t,e){let i=t[e].componentsPerAttribute;return i===2?nt:i===3?l:i===4?ie:Number}function ist(t,e){let i=new Array(t.length),n=0,s=t.length;for(let o=0;o<s;++o){let a=t[o].componentDatatype;i[o]=n,a!==At.UNSIGNED_BYTE&&e?n+=4:++n}return i}function nst(t,e,i){let n=t.length,s=t[n-1];return e[n-1].componentDatatype!==At.UNSIGNED_BYTE&&i?s+4:s+1}function sst(t,e,i){let n=ie.unpack(t,e,t_),s=ie.unpackFloat(n);n=ie.unpack(t,e+4,t_);let o=ie.unpackFloat(n);n=ie.unpack(t,e+8,t_);let r=ie.unpackFloat(n);n=ie.unpack(t,e+12,t_);let a=ie.unpackFloat(n);return ie.fromElements(s,o,r,a,i)}function ost(t,e,i){let n=ie.packFloat(t.x,t_);ie.pack(n,e,i),n=ie.packFloat(t.y,n),ie.pack(n,e,i+4),n=ie.packFloat(t.z,n),ie.pack(n,e,i+8),n=ie.packFloat(t.w,n),ie.pack(n,e,i+12)}function Ast(t,e){let i=t._textureDimensions;t._texture=new Fa({context:e,pixelFormat:Ie.RGBA,pixelDatatype:t._pixelDatatype,width:i.x,height:i.y,sampler:ZA.NEAREST,flipY:!1})}function hst(t){let e=t._textureDimensions;t._texture.copyFrom({source:{width:e.x,height:e.y,arrayBufferView:t._batchValues}})}function cst(t){let e=t._stride;return t._textureDimensions.y===1?`uniform vec4 batchTextureStep; 
vec2 computeSt(float batchId) 
{ 
    float stepX = batchTextureStep.x; 
    float centerX = batchTextureStep.y; 
    float numberOfAttributes = float(${e}); 
    return vec2(centerX + (batchId * numberOfAttributes * stepX), 0.5); 
} 
`:`uniform vec4 batchTextureStep; 
uniform vec2 batchTextureDimensions; 
vec2 computeSt(float batchId) 
{ 
    float stepX = batchTextureStep.x; 
    float centerX = batchTextureStep.y; 
    float stepY = batchTextureStep.z; 
    float centerY = batchTextureStep.w; 
    float numberOfAttributes = float(${e}); 
    float xId = mod(batchId * numberOfAttributes, batchTextureDimensions.x); 
    float yId = floor(batchId * numberOfAttributes / batchTextureDimensions.x); 
    return vec2(centerX + (xId * stepX), centerY + (yId * stepY)); 
} 
`}function lst(t){return t===1?"float":`vec${t}`}function dst(t){return t===1?".x":t===2?".xy":t===3?".xyz":""}function mst(t,e){let n=t._attributes[e],s=n.componentsPerAttribute,o=n.functionName,r=lst(s),a=dst(s),h=t._offsets[e],A=`${r} ${o}(float batchId) 
{ 
    vec2 st = computeSt(batchId); 
    st.x += batchTextureStep.x * float(${h}); 
`;return t._packFloats&&n.componentDatatype!==ge.UNSIGNED_BYTE?A+=`vec4 textureValue; 
textureValue.x = czm_unpackFloat(texture(batchTexture, st)); 
textureValue.y = czm_unpackFloat(texture(batchTexture, st + vec2(batchTextureStep.x, 0.0))); 
textureValue.z = czm_unpackFloat(texture(batchTexture, st + vec2(batchTextureStep.x * 2.0, 0.0))); 
textureValue.w = czm_unpackFloat(texture(batchTexture, st + vec2(batchTextureStep.x * 3.0, 0.0))); 
`:A+=`    vec4 textureValue = texture(batchTexture, st); 
`,A+=`    ${r} value = textureValue${a}; 
`,t._pixelDatatype===ge.UNSIGNED_BYTE&&n.componentDatatype===At.UNSIGNED_BYTE&&!n.normalize?A+=`value *= 255.0; 
`:t._pixelDatatype===ge.FLOAT&&n.componentDatatype===At.UNSIGNED_BYTE&&n.normalize&&(A+=`value /= 255.0; 
`),A+=`    return value; 
} 
`,A}var t_,NP,rst,ast,FP,YP=O(()=>{Xe();Ht();Vs();KA();oi();mt();Ws();Vt();_c();ga();Ec();YE();uI();Object.defineProperties(Rh.prototype,{attributes:{get:function(){return this._attributes}},numberOfInstances:{get:function(){return this._numberOfInstances}}});t_=new ie;NP=new ie;Rh.prototype.getBatchedAttribute=function(t,e,i){if(t<0||t>=this._numberOfInstances)throw new Y("instanceIndex is out of range.");if(e<0||e>=this._attributes.length)throw new Y("attributeIndex is out of range");let n=this._attributes,s=this._offsets[e],r=4*this._stride*t+4*s,a;this._packFloats&&n[e].componentDatatype!==ge.UNSIGNED_BYTE?a=sst(this._batchValues,r,NP):a=ie.unpack(this._batchValues,r,NP);let h=bP(n,e);return m(h.fromCartesian4)?h.fromCartesian4(a,i):m(h.clone)?h.clone(a,i):a.x};rst=[void 0,void 0,new nt,new l,new ie],ast=new ie;Rh.prototype.setBatchedAttribute=function(t,e,i){if(t<0||t>=this._numberOfInstances)throw new Y("instanceIndex is out of range.");if(e<0||e>=this._attributes.length)throw new Y("attributeIndex is out of range");if(!m(i))throw new Y("value is required.");let n=this._attributes,s=rst[n[e].componentsPerAttribute],o=this.getBatchedAttribute(t,e,s),r=bP(this._attributes,e);if(m(r.equals)?r.equals(o,i):o===i)return;let h=ast;h.x=m(i.x)?i.x:i,h.y=m(i.y)?i.y:0,h.z=m(i.z)?i.z:0,h.w=m(i.w)?i.w:0;let A=this._offsets[e],f=4*this._stride*t+4*A;this._packFloats&&n[e].componentDatatype!==ge.UNSIGNED_BYTE?ost(h,this._batchValues,f):ie.pack(h,this._batchValues,f),this._batchValuesDirty=!0};Rh.prototype.update=function(t){m(this._texture)&&!this._batchValuesDirty||this._attributes.length===0||(this._batchValuesDirty=!1,m(this._texture)||Ast(this,t.context),hst(this))};Rh.prototype.getUniformMapCallback=function(){let t=this;return function(e){return t._attributes.length===0?e:es(e,{batchTexture:function(){return t._texture},batchTextureDimensions:function(){return t._textureDimensions},batchTextureStep:function(){return t._textureStep}})}};Rh.prototype.getVertexShaderCallback=function(){let t=this._attributes;if(t.length===0)return function(n){return n};let e=`uniform highp sampler2D batchTexture; 
`;e+=`${cst(this)}
`;let i=t.length;for(let n=0;n<i;++n)e+=mst(this,n);return function(n){let s=n.indexOf("void main"),o=n.substring(0,s),r=n.substring(s);return`${o}
${e}
${r}`}};Rh.prototype.isDestroyed=function(){return!1};Rh.prototype.destroy=function(){return this._texture=this._texture&&this._texture.destroy(),li(this)};FP=Rh});var fst,wI,PN=O(()=>{ss();fst={NEVER:it.NEVER,LESS:it.LESS,EQUAL:it.EQUAL,LESS_OR_EQUAL:it.LEQUAL,GREATER:it.GREATER,NOT_EQUAL:it.NOTEQUAL,GREATER_OR_EQUAL:it.GEQUAL,ALWAYS:it.ALWAYS},wI=Object.freeze(fst)});function Est(t,e,i,n,s){p.defined("point",t),p.defined("p0",e),p.defined("p1",i),p.defined("p2",n),m(s)||(s=new l);let o,r,a,h,A,d,f,E;if(m(e.z)){if(l.equalsEpsilon(t,e,L.EPSILON14))return l.clone(l.UNIT_X,s);if(l.equalsEpsilon(t,i,L.EPSILON14))return l.clone(l.UNIT_Y,s);if(l.equalsEpsilon(t,n,L.EPSILON14))return l.clone(l.UNIT_Z,s);o=l.subtract(i,e,SP),r=l.subtract(n,e,OP),a=l.subtract(t,e,VP),h=l.dot(o,o),A=l.dot(o,r),d=l.dot(o,a),f=l.dot(r,r),E=l.dot(r,a)}else{if(nt.equalsEpsilon(t,e,L.EPSILON14))return l.clone(l.UNIT_X,s);if(nt.equalsEpsilon(t,i,L.EPSILON14))return l.clone(l.UNIT_Y,s);if(nt.equalsEpsilon(t,n,L.EPSILON14))return l.clone(l.UNIT_Z,s);o=nt.subtract(i,e,SP),r=nt.subtract(n,e,OP),a=nt.subtract(t,e,VP),h=nt.dot(o,o),A=nt.dot(o,r),d=nt.dot(o,a),f=nt.dot(r,r),E=nt.dot(r,a)}s.y=f*d-A*E,s.z=h*E-A*d;let _=h*f-A*A;if(_!==0)return s.y/=_,s.z/=_,s.x=1-s.y-s.z,s}var SP,OP,VP,GP,BP=O(()=>{Xe();Ht();ae();mt();_e();SP=new l,OP=new l,VP=new l;GP=Est});var JN,WP,DP=O(()=>{bt();mt();Vt();JN={};JN.calculateACMR=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.indices,i=t.maximumIndex,n=Z(t.cacheSize,24);if(!m(e))throw new Y("indices is required.");let s=e.length;if(s<3||s%3!==0)throw new Y("indices length must be a multiple of three.");if(i<=0)throw new Y("maximumIndex must be greater than zero.");if(n<3)throw new Y("cacheSize must be greater than two.");if(!m(i)){i=0;let a=0,h=e[a];for(;a<s;)h>i&&(i=h),++a,h=e[a]}let o=[];for(let a=0;a<i+1;a++)o[a]=0;let r=n+1;for(let a=0;a<s;++a)r-o[e[a]]>n&&(o[e[a]]=r,++r);return(r-n+1)/(s/3)};JN.tipsify=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.indices,i=t.maximumIndex,n=Z(t.cacheSize,24),s;function o(c,g,V,D){for(;g.length>=1;){let w=g[g.length-1];if(g.splice(g.length-1,1),c[w].numLiveTriangles>0)return w}for(;s<D;){if(c[s].numLiveTriangles>0)return++s,s-1;++s}return-1}function r(c,g,V,D,w,x,H){let j=-1,X,tt=-1,B=0;for(;B<V.length;){let It=V[B];D[It].numLiveTriangles&&(X=0,w-D[It].timeStamp+2*D[It].numLiveTriangles<=g&&(X=w-D[It].timeStamp),(X>tt||tt===-1)&&(tt=X,j=It)),++B}return j===-1?o(D,x,c,H):j}if(!m(e))throw new Y("indices is required.");let a=e.length;if(a<3||a%3!==0)throw new Y("indices length must be a multiple of three.");if(i<=0)throw new Y("maximumIndex must be greater than zero.");if(n<3)throw new Y("cacheSize must be greater than two.");let h=0,A=0,d=e[A],f=a;if(m(i))h=i+1;else{for(;A<f;)d>h&&(h=d),++A,d=e[A];if(h===-1)return 0;++h}let E=[],_;for(_=0;_<h;_++)E[_]={numLiveTriangles:0,timeStamp:0,vertexTriangles:[]};A=0;let R=0;for(;A<f;)E[e[A]].vertexTriangles.push(R),++E[e[A]].numLiveTriangles,E[e[A+1]].vertexTriangles.push(R),++E[e[A+1]].numLiveTriangles,E[e[A+2]].vertexTriangles.push(R),++E[e[A+2]].numLiveTriangles,++R,A+=3;let I=0,C=n+1;s=1;let N=[],T=[],F,b,G=0,M=[],Q=a/3,U=[];for(_=0;_<Q;_++)U[_]=!1;let k,y;for(;I!==-1;){N=[],b=E[I],y=b.vertexTriangles.length;for(let c=0;c<y;++c)if(R=b.vertexTriangles[c],!U[R]){U[R]=!0,A=R+R+R;for(let g=0;g<3;++g)k=e[A],N.push(k),T.push(k),M[G]=k,++G,F=E[k],--F.numLiveTriangles,C-F.timeStamp>n&&(F.timeStamp=C,++C),++A}I=r(e,n,N,E,C,T,h)}return M};WP=JN});function zI(t,e,i,n,s){t[e++]=i,t[e++]=n,t[e++]=n,t[e++]=s,t[e++]=s,t[e]=i}function _st(t){let e=t.length,i=e/3*6,n=te.createTypedArray(e,i),s=0;for(let o=0;o<e;o+=3,s+=6)zI(n,s,t[o],t[o+1],t[o+2]);return n}function Rst(t){let e=t.length;if(e>=3){let i=(e-2)*6,n=te.createTypedArray(e,i);zI(n,0,t[0],t[1],t[2]);let s=6;for(let o=3;o<e;++o,s+=6)zI(n,s,t[o-1],t[o],t[o-2]);return n}return new Uint16Array}function Zst(t){if(t.length>0){let e=t.length-1,i=(e-1)*6,n=te.createTypedArray(e,i),s=t[0],o=0;for(let r=1;r<e;++r,o+=6)zI(n,o,s,t[r],t[r+1]);return n}return new Uint16Array}function MP(t){let e={};for(let i in t)if(t.hasOwnProperty(i)&&m(t[i])&&m(t[i].values)){let n=t[i];e[i]=new Tt({componentDatatype:n.componentDatatype,componentsPerAttribute:n.componentsPerAttribute,normalize:n.normalize,values:[]})}return e}function Ist(t,e,i){for(let n in e)if(e.hasOwnProperty(n)&&m(e[n])&&m(e[n].values)){let s=e[n];for(let o=0;o<s.componentsPerAttribute;++o)t[n].values.push(s.values[i*s.componentsPerAttribute+o])}}function HN(t,e){if(m(e)){let i=e.values,n=i.length;for(let s=0;s<n;s+=3)l.unpack(i,s,Ba),at.multiplyByPoint(t,Ba,Ba),l.pack(Ba,i,s)}}function vN(t,e){if(m(e)){let i=e.values,n=i.length;for(let s=0;s<n;s+=3)l.unpack(i,s,Ba),lt.multiplyByVector(t,Ba,Ba),Ba=l.normalize(Ba,Ba),l.pack(Ba,i,s)}}function ust(t,e){let i=t.length,n={},s=t[0][e].attributes,o;for(o in s)if(s.hasOwnProperty(o)&&m(s[o])&&m(s[o].values)){let r=s[o],a=r.values.length,h=!0;for(let A=1;A<i;++A){let d=t[A][e].attributes[o];if(!m(d)||r.componentDatatype!==d.componentDatatype||r.componentsPerAttribute!==d.componentsPerAttribute||r.normalize!==d.normalize){h=!1;break}a+=d.values.length}h&&(n[o]=new Tt({componentDatatype:r.componentDatatype,componentsPerAttribute:r.componentsPerAttribute,normalize:r.normalize,values:At.createTypedArray(r.componentDatatype,a)}))}return n}function zN(t,e){let i=t.length,n,s,o,r,a=t[0].modelMatrix,h=m(t[0][e].indices),A=t[0][e].primitiveType;for(s=1;s<i;++s){if(!at.equals(t[s].modelMatrix,a))throw new Y("All instances must have the same modelMatrix.");if(m(t[s][e].indices)!==h)throw new Y("All instance geometries must have an indices or not have one.");if(t[s][e].primitiveType!==A)throw new Y("All instance geometries must have the same primitiveType.")}let d=ust(t,e),f,E,_;for(n in d)if(d.hasOwnProperty(n))for(f=d[n].values,r=0,s=0;s<i;++s)for(E=t[s][e].attributes[n].values,_=E.length,o=0;o<_;++o)f[r++]=E[o];let R;if(h){let T=0;for(s=0;s<i;++s)T+=t[s][e].indices.length;let F=se.computeNumberOfVertices(new se({attributes:d,primitiveType:ne.POINTS})),b=te.createTypedArray(F,T),G=0,M=0;for(s=0;s<i;++s){let Q=t[s][e].indices,U=Q.length;for(r=0;r<U;++r)b[G++]=M+Q[r];M+=se.computeNumberOfVertices(t[s][e])}R=b}let I=new l,C=0,N;for(s=0;s<i;++s){if(N=t[s][e].boundingSphere,!m(N)){I=void 0;break}l.add(N.center,I,I)}if(m(I))for(l.divideByScalar(I,i,I),s=0;s<i;++s){N=t[s][e].boundingSphere;let T=l.magnitude(l.subtract(N.center,I,Cst))+N.radius;T>C&&(C=T)}return new se({attributes:d,indices:R,primitiveType:A,boundingSphere:m(I)?new Nt(I,C):void 0})}function Nst(t){if(m(t.indices))return t;let e=se.computeNumberOfVertices(t);if(e<3)throw new Y("The number of vertices must be at least three.");if(e%3!==0)throw new Y("The number of vertices must be a multiple of three.");let i=te.createTypedArray(e,e);for(let n=0;n<e;++n)i[n]=n;return t.indices=i,t}function bst(t){let e=se.computeNumberOfVertices(t);if(e<3)throw new Y("The number of vertices must be at least three.");let i=te.createTypedArray(e,(e-2)*3);i[0]=1,i[1]=0,i[2]=2;let n=3;for(let s=3;s<e;++s)i[n++]=s-1,i[n++]=0,i[n++]=s;return t.indices=i,t.primitiveType=ne.TRIANGLES,t}function Fst(t){let e=se.computeNumberOfVertices(t);if(e<3)throw new Y("The number of vertices must be at least 3.");let i=te.createTypedArray(e,(e-2)*3);i[0]=0,i[1]=1,i[2]=2,e>3&&(i[3]=0,i[4]=2,i[5]=3);let n=6;for(let s=3;s<e-1;s+=2)i[n++]=s,i[n++]=s-1,i[n++]=s+1,s+2<e&&(i[n++]=s,i[n++]=s+1,i[n++]=s+2);return t.indices=i,t.primitiveType=ne.TRIANGLES,t}function Yst(t){if(m(t.indices))return t;let e=se.computeNumberOfVertices(t);if(e<2)throw new Y("The number of vertices must be at least two.");if(e%2!==0)throw new Y("The number of vertices must be a multiple of 2.");let i=te.createTypedArray(e,e);for(let n=0;n<e;++n)i[n]=n;return t.indices=i,t}function Sst(t){let e=se.computeNumberOfVertices(t);if(e<2)throw new Y("The number of vertices must be at least two.");let i=te.createTypedArray(e,(e-1)*2);i[0]=0,i[1]=1;let n=2;for(let s=2;s<e;++s)i[n++]=s-1,i[n++]=s;return t.indices=i,t.primitiveType=ne.LINES,t}function Ost(t){let e=se.computeNumberOfVertices(t);if(e<2)throw new Y("The number of vertices must be at least two.");let i=te.createTypedArray(e,e*2);i[0]=0,i[1]=1;let n=2;for(let s=2;s<e;++s)i[n++]=s-1,i[n++]=s;return i[n++]=e-1,i[n]=0,t.indices=i,t.primitiveType=ne.LINES,t}function Vst(t){switch(t.primitiveType){case ne.TRIANGLE_FAN:return bst(t);case ne.TRIANGLE_STRIP:return Fst(t);case ne.TRIANGLES:return Nst(t);case ne.LINE_STRIP:return Sst(t);case ne.LINE_LOOP:return Ost(t);case ne.LINES:return Yst(t)}return t}function Cc(t,e){Math.abs(t.y)<L.EPSILON6&&(e?t.y=-L.EPSILON6:t.y=L.EPSILON6)}function Gst(t,e,i){if(t.y!==0&&e.y!==0&&i.y!==0){Cc(t,t.y<0),Cc(e,e.y<0),Cc(i,i.y<0);return}let n=Math.abs(t.y),s=Math.abs(e.y),o=Math.abs(i.y),r;n>s?n>o?r=L.sign(t.y):r=L.sign(i.y):s>o?r=L.sign(e.y):r=L.sign(i.y);let a=r<0;Cc(t,a),Cc(e,a),Cc(i,a)}function Hr(t,e,i,n){l.add(t,l.multiplyByScalar(l.subtract(e,t,yP),t.y/(t.y-e.y),yP),i),l.clone(i,n),Cc(i,!0),Cc(n,!1)}function Bst(t,e,i){if(t.x>=0||e.x>=0||i.x>=0)return;Gst(t,e,i);let n=t.y<0,s=e.y<0,o=i.y<0,r=0;r+=n?1:0,r+=s?1:0,r+=o?1:0;let a=KN.indices;r===1?(a[1]=3,a[2]=4,a[5]=6,a[7]=6,a[8]=5,n?(Hr(t,e,yl,xl),Hr(t,i,wl,Pl),a[0]=0,a[3]=1,a[4]=2,a[6]=1):s?(Hr(e,i,yl,xl),Hr(e,t,wl,Pl),a[0]=1,a[3]=2,a[4]=0,a[6]=2):o&&(Hr(i,t,yl,xl),Hr(i,e,wl,Pl),a[0]=2,a[3]=0,a[4]=1,a[6]=0)):r===2&&(a[2]=4,a[4]=4,a[5]=3,a[7]=5,a[8]=6,n?s?o||(Hr(i,t,yl,xl),Hr(i,e,wl,Pl),a[0]=0,a[1]=1,a[3]=0,a[6]=2):(Hr(e,i,yl,xl),Hr(e,t,wl,Pl),a[0]=2,a[1]=0,a[3]=2,a[6]=1):(Hr(t,e,yl,xl),Hr(t,i,wl,Pl),a[0]=1,a[1]=2,a[3]=1,a[6]=0));let h=KN.positions;return h[0]=t,h[1]=e,h[2]=i,h.length=3,(r===1||r===2)&&(h[3]=yl,h[4]=wl,h[5]=xl,h[6]=Pl,h.length=7),KN}function wP(t,e){let i=t.attributes;if(i.position.values.length===0)return;for(let s in i)if(i.hasOwnProperty(s)&&m(i[s])&&m(i[s].values)){let o=i[s];o.values=At.createTypedArray(o.componentDatatype,o.values)}let n=se.computeNumberOfVertices(t);return t.indices=te.createTypedArray(n,t.indices),e&&(t.boundingSphere=Nt.fromVertices(i.position.values)),t}function Km(t){let e=t.attributes,i={};for(let n in e)if(e.hasOwnProperty(n)&&m(e[n])&&m(e[n].values)){let s=e[n];i[n]=new Tt({componentDatatype:s.componentDatatype,componentsPerAttribute:s.componentsPerAttribute,normalize:s.normalize,values:[]})}return new se({attributes:i,indices:[],primitiveType:t.primitiveType})}function tb(t,e,i){let n=m(t.geometry.boundingSphere);e=wP(e,n),i=wP(i,n),m(i)&&!m(e)?t.geometry=i:!m(i)&&m(e)?t.geometry=e:(t.westHemisphereGeometry=e,t.eastHemisphereGeometry=i,t.geometry=void 0)}function eb(t,e){let i=new t,n=new t,s=new t;return function(o,r,a,h,A,d,f,E){let _=t.fromArray(A,o*e,i),R=t.fromArray(A,r*e,n),I=t.fromArray(A,a*e,s);t.multiplyByScalar(_,h.x,_),t.multiplyByScalar(R,h.y,R),t.multiplyByScalar(I,h.z,I);let C=t.add(_,R,_);if(t.add(C,I,C),E)try{t.normalize(C,C)}catch(N){throw new Y(N)}t.pack(C,d,f*e)}}function jI(t,e,i,n,s,o,r,a,h,A,d,f,E,_,R,I){if(!m(o)&&!m(r)&&!m(a)&&!m(h)&&!m(A)&&_===0)return;let C=l.fromArray(s,t*3,n_),N=l.fromArray(s,e*3,XN),T=l.fromArray(s,i*3,qN),F=GP(n,C,N,T,Mst);if(m(F)){if(m(o)&&vI(t,e,i,F,o,f.normal.values,I,!0),m(A)){let b=l.fromArray(A,t*3,n_),G=l.fromArray(A,e*3,XN),M=l.fromArray(A,i*3,qN);l.multiplyByScalar(b,F.x,b),l.multiplyByScalar(G,F.y,G),l.multiplyByScalar(M,F.z,M);let Q;!l.equals(b,l.ZERO)||!l.equals(G,l.ZERO)||!l.equals(M,l.ZERO)?(Q=l.add(b,G,b),l.add(Q,M,Q),l.normalize(Q,Q)):(Q=n_,Q.x=0,Q.y=0,Q.z=0),l.pack(Q,f.extrudeDirection.values,I*3)}if(m(d)&&Dst(t,e,i,F,d,f.applyOffset.values,I),m(r)&&vI(t,e,i,F,r,f.tangent.values,I,!0),m(a)&&vI(t,e,i,F,a,f.bitangent.values,I,!0),m(h)&&vP(t,e,i,F,h,f.st.values,I),_>0)for(let b=0;b<_;b++){let G=E[b];Ust(t,e,i,F,I,R[G],f[G])}}}function Ust(t,e,i,n,s,o,r){let a=o.componentsPerAttribute,h=o.values,A=r.values;switch(a){case 4:Wst(t,e,i,n,h,A,s,!1);break;case 3:vI(t,e,i,n,h,A,s,!1);break;case 2:vP(t,e,i,n,h,A,s,!1);break;default:A[s]=h[t]*n.x+h[e]*n.y+h[i]*n.z}}function CA(t,e,i,n,s,o){let r=t.position.values.length/3;if(s!==-1){let a=n[s],h=i[a];return h===-1?(i[a]=r,t.position.values.push(o.x,o.y,o.z),e.push(r),r):(e.push(h),h)}return t.position.values.push(o.x,o.y,o.z),e.push(r),r}function xP(t){let e=t.geometry,i=e.attributes,n=i.position.values,s=m(i.normal)?i.normal.values:void 0,o=m(i.bitangent)?i.bitangent.values:void 0,r=m(i.tangent)?i.tangent.values:void 0,a=m(i.st)?i.st.values:void 0,h=m(i.extrudeDirection)?i.extrudeDirection.values:void 0,A=m(i.applyOffset)?i.applyOffset.values:void 0,d=e.indices,f=[];for(let Q in i)i.hasOwnProperty(Q)&&!Qst[Q]&&m(i[Q])&&f.push(Q);let E=f.length,_=Km(e),R=Km(e),I,C,N,T,F,b=[];b.length=n.length/3;let G=[];for(G.length=n.length/3,F=0;F<b.length;++F)b[F]=-1,G[F]=-1;let M=d.length;for(F=0;F<M;F+=3){let Q=d[F],U=d[F+1],k=d[F+2],y=l.fromArray(n,Q*3),c=l.fromArray(n,U*3),g=l.fromArray(n,k*3),V=Bst(y,c,g);if(m(V)&&V.positions.length>3){let D=V.positions,w=V.indices,x=w.length;for(let H=0;H<x;++H){let j=w[H],X=D[j];X.y<0?(I=R.attributes,C=R.indices,N=b):(I=_.attributes,C=_.indices,N=G),T=CA(I,C,N,d,j<3?F+j:-1,X),jI(Q,U,k,X,n,s,r,o,a,h,A,I,f,E,i,T)}}else m(V)&&(y=V.positions[0],c=V.positions[1],g=V.positions[2]),y.y<0?(I=R.attributes,C=R.indices,N=b):(I=_.attributes,C=_.indices,N=G),T=CA(I,C,N,d,F,y),jI(Q,U,k,y,n,s,r,o,a,h,A,I,f,E,i,T),T=CA(I,C,N,d,F+1,c),jI(Q,U,k,c,n,s,r,o,a,h,A,I,f,E,i,T),T=CA(I,C,N,d,F+2,g),jI(Q,U,k,g,n,s,r,o,a,h,A,I,f,E,i,T)}tb(t,R,_)}function zm(t,e,i,n,s,o,r){if(!m(r))return;let a=l.fromArray(n,t*3,n_);l.equalsEpsilon(a,i,L.EPSILON10)?o.applyOffset.values[s]=r[t]:o.applyOffset.values[s]=r[e]}function PP(t){let e=t.geometry,i=e.attributes,n=i.position.values,s=m(i.applyOffset)?i.applyOffset.values:void 0,o=e.indices,r=Km(e),a=Km(e),h,A=o.length,d=[];d.length=n.length/3;let f=[];for(f.length=n.length/3,h=0;h<d.length;++h)d[h]=-1,f[h]=-1;for(h=0;h<A;h+=2){let E=o[h],_=o[h+1],R=l.fromArray(n,E*3,n_),I=l.fromArray(n,_*3,XN),C;Math.abs(R.y)<L.EPSILON6&&(R.y<0?R.y=-L.EPSILON6:R.y=L.EPSILON6),Math.abs(I.y)<L.EPSILON6&&(I.y<0?I.y=-L.EPSILON6:I.y=L.EPSILON6);let N=r.attributes,T=r.indices,F=f,b=a.attributes,G=a.indices,M=d,Q=no.lineSegmentPlane(R,I,zP,qN);if(m(Q)){let U=l.multiplyByScalar(l.UNIT_Y,5*L.EPSILON9,kst);R.y<0&&(l.negate(U,U),N=a.attributes,T=a.indices,F=d,b=r.attributes,G=r.indices,M=f);let k=l.add(Q,U,Lst);C=CA(N,T,F,o,h,R),zm(E,_,R,n,C,N,s),C=CA(N,T,F,o,-1,k),zm(E,_,k,n,C,N,s),l.negate(U,U),l.add(Q,U,k),C=CA(b,G,M,o,-1,k),zm(E,_,k,n,C,b,s),C=CA(b,G,M,o,h+1,I),zm(E,_,I,n,C,b,s)}else{let U,k,y;R.y<0?(U=a.attributes,k=a.indices,y=d):(U=r.attributes,k=r.indices,y=f),C=CA(U,k,y,o,h,R),zm(E,_,R,n,C,U,s),C=CA(U,k,y,o,h+1,I),zm(E,_,I,n,C,U,s)}}tb(t,a,r)}function HP(t){let e=t.attributes,i=e.position.values,n=e.prevPosition.values,s=e.nextPosition.values,o=i.length;for(let r=0;r<o;r+=3){let a=l.unpack(i,r,KP);if(a.x>0)continue;let h=l.unpack(n,r,XP);(a.y<0&&h.y>0||a.y>0&&h.y<0)&&(r-3>0?(n[r]=i[r-3],n[r+1]=i[r-2],n[r+2]=i[r-1]):l.pack(a,n,r));let A=l.unpack(s,r,$N);(a.y<0&&A.y>0||a.y>0&&A.y<0)&&(r+3<o?(s[r]=i[r+3],s[r+1]=i[r+4],s[r+2]=i[r+5]):l.pack(a,s,r))}}function jst(t){let e=t.geometry,i=e.attributes,n=i.position.values,s=i.prevPosition.values,o=i.nextPosition.values,r=i.expandAndWidth.values,a=m(i.st)?i.st.values:void 0,h=m(i.color)?i.color.values:void 0,A=Km(e),d=Km(e),f,E,_,R=!1,I=n.length/3;for(f=0;f<I;f+=4){let C=f,N=f+2,T=l.fromArray(n,C*3,KP),F=l.fromArray(n,N*3,XP);if(Math.abs(T.y)<HI)for(T.y=HI*(F.y<0?-1:1),n[f*3+1]=T.y,n[(f+1)*3+1]=T.y,E=C*3;E<C*3+4*3;E+=3)s[E]=n[f*3],s[E+1]=n[f*3+1],s[E+2]=n[f*3+2];if(Math.abs(F.y)<HI)for(F.y=HI*(T.y<0?-1:1),n[(f+2)*3+1]=F.y,n[(f+3)*3+1]=F.y,E=C*3;E<C*3+4*3;E+=3)o[E]=n[(f+2)*3],o[E+1]=n[(f+2)*3+1],o[E+2]=n[(f+2)*3+2];let b=A.attributes,G=A.indices,M=d.attributes,Q=d.indices,U=no.lineSegmentPlane(T,F,zP,wst);if(m(U)){R=!0;let k=l.multiplyByScalar(l.UNIT_Y,Jst,xst);T.y<0&&(l.negate(k,k),b=d.attributes,G=d.indices,M=A.attributes,Q=A.indices);let y=l.add(U,k,Pst);b.position.values.push(T.x,T.y,T.z,T.x,T.y,T.z),b.position.values.push(y.x,y.y,y.z),b.position.values.push(y.x,y.y,y.z),b.prevPosition.values.push(s[C*3],s[C*3+1],s[C*3+2]),b.prevPosition.values.push(s[C*3+3],s[C*3+4],s[C*3+5]),b.prevPosition.values.push(T.x,T.y,T.z,T.x,T.y,T.z),b.nextPosition.values.push(y.x,y.y,y.z),b.nextPosition.values.push(y.x,y.y,y.z),b.nextPosition.values.push(y.x,y.y,y.z),b.nextPosition.values.push(y.x,y.y,y.z),l.negate(k,k),l.add(U,k,y),M.position.values.push(y.x,y.y,y.z),M.position.values.push(y.x,y.y,y.z),M.position.values.push(F.x,F.y,F.z,F.x,F.y,F.z),M.prevPosition.values.push(y.x,y.y,y.z),M.prevPosition.values.push(y.x,y.y,y.z),M.prevPosition.values.push(y.x,y.y,y.z),M.prevPosition.values.push(y.x,y.y,y.z),M.nextPosition.values.push(F.x,F.y,F.z,F.x,F.y,F.z),M.nextPosition.values.push(o[N*3],o[N*3+1],o[N*3+2]),M.nextPosition.values.push(o[N*3+3],o[N*3+4],o[N*3+5]);let c=nt.fromArray(r,C*2,JP),g=Math.abs(c.y);b.expandAndWidth.values.push(-1,g,1,g),b.expandAndWidth.values.push(-1,-g,1,-g),M.expandAndWidth.values.push(-1,g,1,g),M.expandAndWidth.values.push(-1,-g,1,-g);let V=l.magnitudeSquared(l.subtract(U,T,$N));if(V/=l.magnitudeSquared(l.subtract(F,T,$N)),m(h)){let D=ie.fromArray(h,C*4,jP),w=ie.fromArray(h,N*4,jP),x=L.lerp(D.x,w.x,V),H=L.lerp(D.y,w.y,V),j=L.lerp(D.z,w.z,V),X=L.lerp(D.w,w.w,V);for(E=C*4;E<C*4+2*4;++E)b.color.values.push(h[E]);for(b.color.values.push(x,H,j,X),b.color.values.push(x,H,j,X),M.color.values.push(x,H,j,X),M.color.values.push(x,H,j,X),E=N*4;E<N*4+2*4;++E)M.color.values.push(h[E])}if(m(a)){let D=nt.fromArray(a,C*2,JP),w=nt.fromArray(a,(f+3)*2,yst),x=L.lerp(D.x,w.x,V);for(E=C*2;E<C*2+2*2;++E)b.st.values.push(a[E]);for(b.st.values.push(x,D.y),b.st.values.push(x,w.y),M.st.values.push(x,D.y),M.st.values.push(x,w.y),E=N*2;E<N*2+2*2;++E)M.st.values.push(a[E])}_=b.position.values.length/3-4,G.push(_,_+2,_+1),G.push(_+1,_+2,_+3),_=M.position.values.length/3-4,Q.push(_,_+2,_+1),Q.push(_+1,_+2,_+3)}else{let k,y;for(T.y<0?(k=d.attributes,y=d.indices):(k=A.attributes,y=A.indices),k.position.values.push(T.x,T.y,T.z),k.position.values.push(T.x,T.y,T.z),k.position.values.push(F.x,F.y,F.z),k.position.values.push(F.x,F.y,F.z),E=f*3;E<f*3+4*3;++E)k.prevPosition.values.push(s[E]),k.nextPosition.values.push(o[E]);for(E=f*2;E<f*2+4*2;++E)k.expandAndWidth.values.push(r[E]),m(a)&&k.st.values.push(a[E]);if(m(h))for(E=f*4;E<f*4+4*4;++E)k.color.values.push(h[E]);_=k.position.values.length/3-4,y.push(_,_+2,_+1),y.push(_+1,_+2,_+3)}}R&&(HP(d),HP(A)),tb(t,d,A)}var Qo,UP,pst,jN,Ba,xI,PI,Cst,jr,e_,Hm,vm,gst,QP,Tst,i_,Ga,kP,LP,JI,yP,yl,wl,xl,Pl,KN,Wst,vI,vP,Dst,n_,XN,qN,Mst,Qst,zP,kst,Lst,JP,yst,KP,XP,$N,wst,xst,Pst,jP,Jst,HI,wi,gA=O(()=>{oh();BP();_i();Xe();Ht();Vs();ri();oi();bt();mt();Vt();Tl();zA();yi();ji();dI();Di();nc();Ml();_e();dn();Fi();nh();Xi();DP();Qo={};Qo.toWireframe=function(t){if(!m(t))throw new Y("geometry is required.");let e=t.indices;if(m(e)){switch(t.primitiveType){case ne.TRIANGLES:t.indices=_st(e);break;case ne.TRIANGLE_STRIP:t.indices=Rst(e);break;case ne.TRIANGLE_FAN:t.indices=Zst(e);break;default:throw new Y("geometry.primitiveType must be TRIANGLES, TRIANGLE_STRIP, or TRIANGLE_FAN.")}t.primitiveType=ne.LINES}return t};Qo.createLineSegmentsForVectors=function(t,e,i){if(e=Z(e,"normal"),!m(t))throw new Y("geometry is required.");if(!m(t.attributes.position))throw new Y("geometry.attributes.position is required.");if(!m(t.attributes[e]))throw new Y(`geometry.attributes must have an attribute with the same name as the attributeName parameter, ${e}.`);i=Z(i,1e4);let n=t.attributes.position.values,s=t.attributes[e].values,o=n.length,r=new Float64Array(2*o),a=0;for(let d=0;d<o;d+=3)r[a++]=n[d],r[a++]=n[d+1],r[a++]=n[d+2],r[a++]=n[d]+s[d]*i,r[a++]=n[d+1]+s[d+1]*i,r[a++]=n[d+2]+s[d+2]*i;let h,A=t.boundingSphere;return m(A)&&(h=new Nt(A.center,A.radius+i)),new se({attributes:{position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:r})},primitiveType:ne.LINES,boundingSphere:h})};Qo.createAttributeLocations=function(t){if(!m(t))throw new Y("geometry is required.");let e=["position","positionHigh","positionLow","position3DHigh","position3DLow","position2DHigh","position2DLow","pickColor","normal","st","tangent","bitangent","extrudeDirection","compressedAttributes"],i=t.attributes,n={},s=0,o,r=e.length;for(o=0;o<r;++o){let a=e[o];m(i[a])&&(n[a]=s++)}for(let a in i)i.hasOwnProperty(a)&&!m(n[a])&&(n[a]=s++);return n};Qo.reorderForPreVertexCache=function(t){if(!m(t))throw new Y("geometry is required.");let e=se.computeNumberOfVertices(t),i=t.indices;if(m(i)){let n=new Int32Array(e);for(let E=0;E<e;E++)n[E]=-1;let s=i,o=s.length,r=te.createTypedArray(e,o),a=0,h=0,A=0,d;for(;a<o;)d=n[s[a]],d!==-1?r[h]=d:(d=s[a],n[d]=A,r[h]=A,++A),++a,++h;t.indices=r;let f=t.attributes;for(let E in f)if(f.hasOwnProperty(E)&&m(f[E])&&m(f[E].values)){let _=f[E],R=_.values,I=0,C=_.componentsPerAttribute,N=At.createTypedArray(_.componentDatatype,A*C);for(;I<e;){let T=n[I];if(T!==-1)for(let F=0;F<C;F++)N[C*T+F]=R[C*I+F];++I}_.values=N}}return t};Qo.reorderForPostVertexCache=function(t,e){if(!m(t))throw new Y("geometry is required.");let i=t.indices;if(t.primitiveType===ne.TRIANGLES&&m(i)){let n=i.length,s=0;for(let o=0;o<n;o++)i[o]>s&&(s=i[o]);t.indices=WP.tipsify({indices:i,maximumIndex:s,cacheSize:e})}return t};Qo.fitToUnsignedShortIndices=function(t){if(!m(t))throw new Y("geometry is required.");if(m(t.indices)&&t.primitiveType!==ne.TRIANGLES&&t.primitiveType!==ne.LINES&&t.primitiveType!==ne.POINTS)throw new Y("geometry.primitiveType must equal to PrimitiveType.TRIANGLES, PrimitiveType.LINES, or PrimitiveType.POINTS.");let e=[],i=se.computeNumberOfVertices(t);if(m(t.indices)&&i>=L.SIXTY_FOUR_KILOBYTES){let n=[],s=[],o=0,r=MP(t.attributes),a=t.indices,h=a.length,A;t.primitiveType===ne.TRIANGLES?A=3:t.primitiveType===ne.LINES?A=2:t.primitiveType===ne.POINTS&&(A=1);for(let d=0;d<h;d+=A){for(let f=0;f<A;++f){let E=a[d+f],_=n[E];m(_)||(_=o++,n[E]=_,Ist(r,t.attributes,E)),s.push(_)}o+A>=L.SIXTY_FOUR_KILOBYTES&&(e.push(new se({attributes:r,indices:s,primitiveType:t.primitiveType,boundingSphere:t.boundingSphere,boundingSphereCV:t.boundingSphereCV})),n=[],s=[],o=0,r=MP(t.attributes))}s.length!==0&&e.push(new se({attributes:r,indices:s,primitiveType:t.primitiveType,boundingSphere:t.boundingSphere,boundingSphereCV:t.boundingSphereCV}))}else e.push(t);return e};UP=new l,pst=new ut;Qo.projectTo2D=function(t,e,i,n,s){if(!m(t))throw new Y("geometry is required.");if(!m(e))throw new Y("attributeName is required.");if(!m(i))throw new Y("attributeName3D is required.");if(!m(n))throw new Y("attributeName2D is required.");if(!m(t.attributes[e]))throw new Y(`geometry must have attribute matching the attributeName argument: ${e}.`);if(t.attributes[e].componentDatatype!==At.DOUBLE)throw new Y("The attribute componentDatatype must be ComponentDatatype.DOUBLE.");let o=t.attributes[e];s=m(s)?s:new Os;let r=s.ellipsoid,a=o.values,h=new Float64Array(a.length),A=0;for(let d=0;d<a.length;d+=3){let f=l.fromArray(a,d,UP),E=r.cartesianToCartographic(f,pst);if(!m(E)){if(f.x&&f.y&&f.z)throw new Y(`Could not project point (${f.x}, ${f.y}, ${f.z}) to 2D.`);continue}let _=s.project(E,UP);h[A++]=_.x,h[A++]=_.y,h[A++]=_.z}return t.attributes[i]=o,t.attributes[n]=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:h}),delete t.attributes[e],t};jN={high:0,low:0};Qo.encodeAttribute=function(t,e,i,n){if(!m(t))throw new Y("geometry is required.");if(!m(e))throw new Y("attributeName is required.");if(!m(i))throw new Y("attributeHighName is required.");if(!m(n))throw new Y("attributeLowName is required.");if(!m(t.attributes[e]))throw new Y(`geometry must have attribute matching the attributeName argument: ${e}.`);if(t.attributes[e].componentDatatype!==At.DOUBLE)throw new Y("The attribute componentDatatype must be ComponentDatatype.DOUBLE.");let s=t.attributes[e],o=s.values,r=o.length,a=new Float32Array(r),h=new Float32Array(r);for(let d=0;d<r;++d)Bn.encode(o[d],jN),a[d]=jN.high,h[d]=jN.low;let A=s.componentsPerAttribute;return t.attributes[i]=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:A,values:a}),t.attributes[n]=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:A,values:h}),delete t.attributes[e],t};Ba=new l;xI=new at,PI=new lt;Qo.transformToWorldCoordinates=function(t){if(!m(t))throw new Y("instance is required.");let e=t.modelMatrix;if(at.equals(e,at.IDENTITY))return t;let i=t.geometry.attributes;HN(e,i.position),HN(e,i.prevPosition),HN(e,i.nextPosition),(m(i.normal)||m(i.tangent)||m(i.bitangent))&&(at.inverse(e,xI),at.transpose(xI,xI),at.getMatrix3(xI,PI),vN(PI,i.normal),vN(PI,i.tangent),vN(PI,i.bitangent));let n=t.geometry.boundingSphere;return m(n)&&(t.geometry.boundingSphere=Nt.transform(n,e,n)),t.modelMatrix=at.clone(at.IDENTITY),t};Cst=new l;Qo.combineInstances=function(t){if(!m(t)||t.length<1)throw new Y("instances is required and must have length greater than zero.");let e=[],i=[],n=t.length;for(let o=0;o<n;++o){let r=t[o];m(r.geometry)?e.push(r):m(r.westHemisphereGeometry)&&m(r.eastHemisphereGeometry)&&i.push(r)}let s=[];return e.length>0&&s.push(zN(e,"geometry")),i.length>0&&(s.push(zN(i,"westHemisphereGeometry")),s.push(zN(i,"eastHemisphereGeometry"))),s};jr=new l,e_=new l,Hm=new l,vm=new l;Qo.computeNormal=function(t){if(!m(t))throw new Y("geometry is required.");if(!m(t.attributes.position)||!m(t.attributes.position.values))throw new Y("geometry.attributes.position.values is required.");if(!m(t.indices))throw new Y("geometry.indices is required.");if(t.indices.length<2||t.indices.length%3!==0)throw new Y("geometry.indices length must be greater than 0 and be a multiple of 3.");if(t.primitiveType!==ne.TRIANGLES)throw new Y("geometry.primitiveType must be PrimitiveType.TRIANGLES.");let e=t.indices,i=t.attributes,n=i.position.values,s=i.position.values.length/3,o=e.length,r=new Array(s),a=new Array(o/3),h=new Array(o),A;for(A=0;A<s;A++)r[A]={indexOffset:0,count:0,currentCount:0};let d=0;for(A=0;A<o;A+=3){let R=e[A],I=e[A+1],C=e[A+2],N=R*3,T=I*3,F=C*3;e_.x=n[N],e_.y=n[N+1],e_.z=n[N+2],Hm.x=n[T],Hm.y=n[T+1],Hm.z=n[T+2],vm.x=n[F],vm.y=n[F+1],vm.z=n[F+2],r[R].count++,r[I].count++,r[C].count++,l.subtract(Hm,e_,Hm),l.subtract(vm,e_,vm),a[d]=l.cross(Hm,vm,new l),d++}let f=0;for(A=0;A<s;A++)r[A].indexOffset+=f,f+=r[A].count;d=0;let E;for(A=0;A<o;A+=3){E=r[e[A]];let R=E.indexOffset+E.currentCount;h[R]=d,E.currentCount++,E=r[e[A+1]],R=E.indexOffset+E.currentCount,h[R]=d,E.currentCount++,E=r[e[A+2]],R=E.indexOffset+E.currentCount,h[R]=d,E.currentCount++,d++}let _=new Float32Array(s*3);for(A=0;A<s;A++){let R=A*3;if(E=r[A],l.clone(l.ZERO,jr),E.count>0){for(d=0;d<E.count;d++)l.add(jr,a[h[E.indexOffset+d]],jr);l.equalsEpsilon(l.ZERO,jr,L.EPSILON10)&&l.clone(a[h[E.indexOffset]],jr)}l.equalsEpsilon(l.ZERO,jr,L.EPSILON10)&&(jr.z=1),l.normalize(jr,jr),_[R]=jr.x,_[R+1]=jr.y,_[R+2]=jr.z}return t.attributes.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_}),t};gst=new l,QP=new l,Tst=new l;Qo.computeTangentAndBitangent=function(t){if(!m(t))throw new Y("geometry is required.");let e=t.attributes,i=t.indices;if(!m(e.position)||!m(e.position.values))throw new Y("geometry.attributes.position.values is required.");if(!m(e.normal)||!m(e.normal.values))throw new Y("geometry.attributes.normal.values is required.");if(!m(e.st)||!m(e.st.values))throw new Y("geometry.attributes.st.values is required.");if(!m(i))throw new Y("geometry.indices is required.");if(i.length<2||i.length%3!==0)throw new Y("geometry.indices length must be greater than 0 and be a multiple of 3.");if(t.primitiveType!==ne.TRIANGLES)throw new Y("geometry.primitiveType must be PrimitiveType.TRIANGLES.");let n=t.attributes.position.values,s=t.attributes.normal.values,o=t.attributes.st.values,r=t.attributes.position.values.length/3,a=i.length,h=new Array(r*3),A;for(A=0;A<h.length;A++)h[A]=0;let d,f,E;for(A=0;A<a;A+=3){let I=i[A],C=i[A+1],N=i[A+2];d=I*3,f=C*3,E=N*3;let T=I*2,F=C*2,b=N*2,G=n[d],M=n[d+1],Q=n[d+2],U=o[T],k=o[T+1],y=o[F+1]-k,c=o[b+1]-k,g=1/((o[F]-U)*c-(o[b]-U)*y),V=(c*(n[f]-G)-y*(n[E]-G))*g,D=(c*(n[f+1]-M)-y*(n[E+1]-M))*g,w=(c*(n[f+2]-Q)-y*(n[E+2]-Q))*g;h[d]+=V,h[d+1]+=D,h[d+2]+=w,h[f]+=V,h[f+1]+=D,h[f+2]+=w,h[E]+=V,h[E+1]+=D,h[E+2]+=w}let _=new Float32Array(r*3),R=new Float32Array(r*3);for(A=0;A<r;A++){d=A*3,f=d+1,E=d+2;let I=l.fromArray(s,d,gst),C=l.fromArray(h,d,Tst),N=l.dot(I,C);l.multiplyByScalar(I,N,QP),l.normalize(l.subtract(C,QP,C),C),_[d]=C.x,_[f]=C.y,_[E]=C.z,l.normalize(l.cross(I,C,C),C),R[d]=C.x,R[f]=C.y,R[E]=C.z}return t.attributes.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_}),t.attributes.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:R}),t};i_=new nt,Ga=new l,kP=new l,LP=new l,JI=new nt;Qo.compressVertices=function(t){if(!m(t))throw new Y("geometry is required.");let e=t.attributes.extrudeDirection,i,n;if(m(e)){let M=e.values;n=M.length/3;let Q=new Float32Array(n*2),U=0;for(i=0;i<n;++i){if(l.fromArray(M,i*3,Ga),l.equals(Ga,l.ZERO)){U+=2;continue}JI=Yi.octEncodeInRange(Ga,65535,JI),Q[U++]=JI.x,Q[U++]=JI.y}return t.attributes.compressedAttributes=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:Q}),delete t.attributes.extrudeDirection,t}let s=t.attributes.normal,o=t.attributes.st,r=m(s),a=m(o);if(!r&&!a)return t;let h=t.attributes.tangent,A=t.attributes.bitangent,d=m(h),f=m(A),E,_,R,I;r&&(E=s.values),a&&(_=o.values),d&&(R=h.values),f&&(I=A.values),n=(r?E.length:_.length)/(r?3:2);let T=n,F=a&&r?2:1;F+=d||f?1:0,T*=F;let b=new Float32Array(T),G=0;for(i=0;i<n;++i){a&&(nt.fromArray(_,i*2,i_),b[G++]=Yi.compressTextureCoordinates(i_));let M=i*3;r&&m(R)&&m(I)?(l.fromArray(E,M,Ga),l.fromArray(R,M,kP),l.fromArray(I,M,LP),Yi.octPack(Ga,kP,LP,i_),b[G++]=i_.x,b[G++]=i_.y):(r&&(l.fromArray(E,M,Ga),b[G++]=Yi.octEncodeFloat(Ga)),d&&(l.fromArray(R,M,Ga),b[G++]=Yi.octEncodeFloat(Ga)),f&&(l.fromArray(I,M,Ga),b[G++]=Yi.octEncodeFloat(Ga)))}return t.attributes.compressedAttributes=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:F,values:b}),r&&delete t.attributes.normal,a&&delete t.attributes.st,f&&delete t.attributes.bitangent,d&&delete t.attributes.tangent,t};yP=new l;yl=new l,wl=new l,xl=new l,Pl=new l,KN={positions:new Array(7),indices:new Array(3*3)};Wst=eb(ie,4),vI=eb(l,3),vP=eb(nt,2),Dst=function(t,e,i,n,s,o,r){let a=s[t]*n.x,h=s[e]*n.y,A=s[i]*n.z;o[r]=a+h+A>L.EPSILON6?1:0},n_=new l,XN=new l,qN=new l,Mst=new l;Qst={position:!0,normal:!0,bitangent:!0,tangent:!0,st:!0,extrudeDirection:!0,applyOffset:!0};zP=Ki.fromPointNormal(l.ZERO,l.UNIT_Y),kst=new l,Lst=new l;JP=new nt,yst=new nt,KP=new l,XP=new l,$N=new l,wst=new l,xst=new l,Pst=new l,jP=new ie;Jst=5*L.EPSILON9,HI=L.EPSILON6;Qo.splitLongitude=function(t){if(!m(t))throw new Y("instance is required.");let e=t.geometry,i=e.boundingSphere;if(m(i)&&(i.center.x-i.radius>0||Nt.intersectPlane(i,Ki.ORIGIN_ZX_PLANE)!==Nn.INTERSECTING))return t;if(e.geometryType!==Ah.NONE)switch(e.geometryType){case Ah.POLYLINES:jst(t);break;case Ah.TRIANGLES:xP(t);break;case Ah.LINES:PP(t);break}else Vst(e),e.primitiveType===ne.TRIANGLES?xP(t):e.primitiveType===ne.LINES&&PP(t);return t};wi=Qo});function s_(t,e,i){t=Z(t,0),e=Z(e,0),i=Z(i,0),this.value=new Float32Array([t,e,i])}var qP,$P=O(()=>{ae();oi();bt();mt();Object.defineProperties(s_.prototype,{componentDatatype:{get:function(){return At.FLOAT}},componentsPerAttribute:{get:function(){return 3}},normalize:{get:function(){return!1}}});s_.fromCartesian3=function(t){return p.defined("offset",t),new s_(t.x,t.y,t.z)};s_.toValue=function(t,e){return p.defined("offset",t),m(e)||(e=new Float32Array([t.x,t.y,t.z])),e[0]=t.x,e[1]=t.y,e[2]=t.z,e};qP=s_});function Hst(t,e,i){let n=!i,s=t.length,o;if(!n&&s>1){let r=t[0].modelMatrix;for(o=1;o<s;++o)if(!at.equals(r,t[o].modelMatrix)){n=!0;break}}if(n)for(o=0;o<s;++o)m(t[o].geometry)&&wi.transformToWorldCoordinates(t[o]);else at.multiplyTransformation(e,t[0].modelMatrix,e)}function ib(t,e){let i=t.attributes,n=i.position,s=n.values.length/n.componentsPerAttribute;i.batchId=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:1,values:new Float32Array(s)});let o=i.batchId.values;for(let r=0;r<s;++r)o[r]=e}function vst(t){let e=t.length;for(let i=0;i<e;++i){let n=t[i];m(n.geometry)?ib(n.geometry,i):m(n.westHemisphereGeometry)&&m(n.eastHemisphereGeometry)&&(ib(n.westHemisphereGeometry,i),ib(n.eastHemisphereGeometry,i))}}function zst(t){let e=t.instances,i=t.projection,n=t.elementIndexUintSupported,s=t.scene3DOnly,o=t.vertexCacheOptimize,r=t.compressVertices,a=t.modelMatrix,h,A,d,f=e.length;for(h=0;h<f;++h)if(m(e[h].geometry)){d=e[h].geometry.primitiveType;break}for(h=1;h<f;++h)if(m(e[h].geometry)&&e[h].geometry.primitiveType!==d)throw new Y("All instance geometries must have the same primitiveType.");if(Hst(e,a,s),!s)for(h=0;h<f;++h)m(e[h].geometry)&&wi.splitLongitude(e[h]);if(vst(e),o)for(h=0;h<f;++h){let _=e[h];m(_.geometry)?(wi.reorderForPostVertexCache(_.geometry),wi.reorderForPreVertexCache(_.geometry)):m(_.westHemisphereGeometry)&&m(_.eastHemisphereGeometry)&&(wi.reorderForPostVertexCache(_.westHemisphereGeometry),wi.reorderForPreVertexCache(_.westHemisphereGeometry),wi.reorderForPostVertexCache(_.eastHemisphereGeometry),wi.reorderForPreVertexCache(_.eastHemisphereGeometry))}let E=wi.combineInstances(e);for(f=E.length,h=0;h<f;++h){A=E[h];let _=A.attributes;if(s)for(let R in _)_.hasOwnProperty(R)&&_[R].componentDatatype===At.DOUBLE&&wi.encodeAttribute(A,R,`${R}3DHigh`,`${R}3DLow`);else for(let R in _)if(_.hasOwnProperty(R)&&_[R].componentDatatype===At.DOUBLE){let I=`${R}3D`,C=`${R}2D`;wi.projectTo2D(A,R,I,C,i),m(A.boundingSphere)&&R==="position"&&(A.boundingSphereCV=Nt.fromVertices(A.attributes.position2D.values)),wi.encodeAttribute(A,I,`${I}High`,`${I}Low`),wi.encodeAttribute(A,C,`${C}High`,`${C}Low`)}r&&wi.compressVertices(A)}if(!n){let _=[];for(f=E.length,h=0;h<f;++h)A=E[h],_=_.concat(wi.fitToUnsignedShortIndices(A));E=_}return E}function nb(t,e,i,n){let s,o,r,a=n.length-1;if(a>=0){let A=n[a];s=A.offset+A.count,r=A.index,o=i[r].indices.length}else s=0,r=0,o=i[r].indices.length;let h=t.length;for(let A=0;A<h;++A){let f=t[A][e];if(!m(f))continue;let E=f.indices.length;s+E>o&&(s=0,o=i[++r].indices.length),n.push({index:r,offset:s,count:E}),s+=E}}function Kst(t,e){let i=[];return nb(t,"geometry",e,i),nb(t,"westHemisphereGeometry",e,i),nb(t,"eastHemisphereGeometry",e,i),i}function Xst(t,e){let i=t.attributes;for(let n in i)if(i.hasOwnProperty(n)){let s=i[n];m(s)&&m(s.values)&&e.push(s.values.buffer)}m(t.indices)&&e.push(t.indices.buffer)}function qst(t,e){let i=t.length;for(let n=0;n<i;++n)Xst(t[n],e)}function $st(t){let e=1,i=t.length;for(let n=0;n<i;n++){let s=t[n];if(++e,!m(s))continue;let o=s.attributes;e+=7+2*Nt.packedLength+(m(s.indices)?s.indices.length:0);for(let r in o)if(o.hasOwnProperty(r)&&m(o[r])){let a=o[r];e+=5+a.values.length}}return e}function tot(t,e){let i=t.length,n=new Float64Array(1+i*19),s=0;n[s++]=i;for(let o=0;o<i;o++){let r=t[o];if(at.pack(r.modelMatrix,n,s),s+=at.packedLength,m(r.attributes)&&m(r.attributes.offset)){let a=r.attributes.offset.value;n[s]=a[0],n[s+1]=a[1],n[s+2]=a[2]}s+=3}return e.push(n.buffer),n}function eot(t){let e=t,i=new Array(e[0]),n=0,s=1;for(;s<e.length;){let o=at.unpack(e,s),r;s+=at.packedLength,m(e[s])&&(r={offset:new qP(e[s],e[s+1],e[s+2])}),s+=3,i[n++]={modelMatrix:o,attributes:r}}return i}function tJ(t){let e=t.length,i=1+(Nt.packedLength+1)*e,n=new Float32Array(i),s=0;n[s++]=e;for(let o=0;o<e;++o){let r=t[o];m(r)?(n[s++]=1,Nt.pack(t[o],n,s)):n[s++]=0,s+=Nt.packedLength}return n}function eJ(t){let e=new Array(t[0]),i=0,n=1;for(;n<t.length;)t[n++]===1&&(e[i]=Nt.unpack(t,n)),++i,n+=Nt.packedLength;return e}var Zh,TA,KI=O(()=>{_i();oi();bt();mt();Vt();Ve();zA();yi();ji();En();gA();Di();Fi();$P();Ul();Zh={};Zh.combineGeometry=function(t){let e,i,n=t.instances,s=n.length,o,r,a=!1;s>0&&(e=zst(t),e.length>0&&(i=wi.createAttributeLocations(e[0]),t.createPickOffsets&&(o=Kst(n,e))),m(n[0].attributes)&&m(n[0].attributes.offset)&&(r=new Array(s),a=!0));let h=new Array(s),A=new Array(s);for(let d=0;d<s;++d){let f=n[d],E=f.geometry;m(E)&&(h[d]=E.boundingSphere,A[d]=E.boundingSphereCV,a&&(r[d]=f.geometry.offsetAttribute));let _=f.eastHemisphereGeometry,R=f.westHemisphereGeometry;m(_)&&m(R)&&(m(_.boundingSphere)&&m(R.boundingSphere)&&(h[d]=Nt.union(_.boundingSphere,R.boundingSphere)),m(_.boundingSphereCV)&&m(R.boundingSphereCV)&&(A[d]=Nt.union(_.boundingSphereCV,R.boundingSphereCV)))}return{geometries:e,modelMatrix:t.modelMatrix,attributeLocations:i,pickOffsets:o,offsetInstanceExtend:r,boundingSpheres:h,boundingSpheresCV:A}};Zh.packCreateGeometryResults=function(t,e){let i=new Float64Array($st(t)),n=[],s={},o=t.length,r=0;i[r++]=o;for(let a=0;a<o;a++){let h=t[a],A=m(h);if(i[r++]=A?1:0,!A)continue;i[r++]=h.primitiveType,i[r++]=h.geometryType,i[r++]=Z(h.offsetAttribute,-1);let d=m(h.boundingSphere)?1:0;i[r++]=d,d&&Nt.pack(h.boundingSphere,i,r),r+=Nt.packedLength;let f=m(h.boundingSphereCV)?1:0;i[r++]=f,f&&Nt.pack(h.boundingSphereCV,i,r),r+=Nt.packedLength;let E=h.attributes,_=[];for(let I in E)E.hasOwnProperty(I)&&m(E[I])&&(_.push(I),m(s[I])||(s[I]=n.length,n.push(I)));i[r++]=_.length;for(let I=0;I<_.length;I++){let C=_[I],N=E[C];i[r++]=s[C],i[r++]=N.componentDatatype,i[r++]=N.componentsPerAttribute,i[r++]=N.normalize?1:0,i[r++]=N.values.length,i.set(N.values,r),r+=N.values.length}let R=m(h.indices)?h.indices.length:0;i[r++]=R,R>0&&(i.set(h.indices,r),r+=R)}return e.push(i.buffer),{stringTable:n,packedData:i}};Zh.unpackCreateGeometryResults=function(t){let e=t.stringTable,i=t.packedData,n,s=new Array(i[0]),o=0,r=1;for(;r<i.length;){if(!(i[r++]===1)){s[o++]=void 0;continue}let h=i[r++],A=i[r++],d=i[r++];d===-1&&(d=void 0);let f,E;i[r++]===1&&(f=Nt.unpack(i,r)),r+=Nt.packedLength,i[r++]===1&&(E=Nt.unpack(i,r)),r+=Nt.packedLength;let I,C,N,T=new we,F=i[r++];for(n=0;n<F;n++){let G=e[i[r++]],M=i[r++];N=i[r++];let Q=i[r++]!==0;I=i[r++],C=At.createTypedArray(M,I);for(let U=0;U<I;U++)C[U]=i[r++];T[G]=new Tt({componentDatatype:M,componentsPerAttribute:N,normalize:Q,values:C})}let b;if(I=i[r++],I>0){let G=C.length/N;for(b=te.createTypedArray(G,I),n=0;n<I;n++)b[n]=i[r++]}s[o++]=new se({primitiveType:h,geometryType:A,boundingSphere:f,boundingSphereCV:E,indices:b,attributes:T,offsetAttribute:d})}return s};Zh.packCombineGeometryParameters=function(t,e){let i=t.createGeometryResults,n=i.length;for(let s=0;s<n;s++)e.push(i[s].packedData.buffer);return{createGeometryResults:t.createGeometryResults,packedInstances:tot(t.instances,e),ellipsoid:t.ellipsoid,isGeographic:t.projection instanceof Os,elementIndexUintSupported:t.elementIndexUintSupported,scene3DOnly:t.scene3DOnly,vertexCacheOptimize:t.vertexCacheOptimize,compressVertices:t.compressVertices,modelMatrix:t.modelMatrix,createPickOffsets:t.createPickOffsets}};Zh.unpackCombineGeometryParameters=function(t){let e=eot(t.packedInstances),i=t.createGeometryResults,n=i.length,s=0;for(let a=0;a<n;a++){let h=Zh.unpackCreateGeometryResults(i[a]),A=h.length;for(let d=0;d<A;d++){let f=h[d],E=e[s];E.geometry=f,++s}}let o=ot.clone(t.ellipsoid),r=t.isGeographic?new Os(o):new ks(o);return{instances:e,ellipsoid:o,projection:r,elementIndexUintSupported:t.elementIndexUintSupported,scene3DOnly:t.scene3DOnly,vertexCacheOptimize:t.vertexCacheOptimize,compressVertices:t.compressVertices,modelMatrix:at.clone(t.modelMatrix),createPickOffsets:t.createPickOffsets}};Zh.packCombineGeometryResults=function(t,e){m(t.geometries)&&qst(t.geometries,e);let i=tJ(t.boundingSpheres),n=tJ(t.boundingSpheresCV);return e.push(i.buffer,n.buffer),{geometries:t.geometries,attributeLocations:t.attributeLocations,modelMatrix:t.modelMatrix,pickOffsets:t.pickOffsets,offsetInstanceExtend:t.offsetInstanceExtend,boundingSpheres:i,boundingSpheresCV:n}};Zh.unpackCombineGeometryResults=function(t){return{geometries:t.geometries,attributeLocations:t.attributeLocations,modelMatrix:t.modelMatrix,pickOffsets:t.pickOffsets,offsetInstanceExtend:t.offsetInstanceExtend,boundingSpheres:eJ(t.boundingSpheres),boundingSpheresCV:eJ(t.boundingSpheresCV)}};TA=Zh});var iot,Is,iJ=O(()=>{iot={READY:0,CREATING:1,CREATED:2,COMBINING:3,COMBINED:4,COMPLETE:5,FAILED:6},Is=Object.freeze(iot)});var Ir,XI,nJ=O(()=>{Ir={DISABLED:0,ENABLED:1,CAST_ONLY:2,RECEIVE_ONLY:3};Ir.NUMBER_OF_SHADOW_MODES=4;Ir.castShadows=function(t){return t===Ir.ENABLED||t===Ir.CAST_ONLY};Ir.receiveShadows=function(t){return t===Ir.ENABLED||t===Ir.RECEIVE_ONLY};Ir.fromCastReceive=function(t,e){return t&&e?Ir.ENABLED:t?Ir.CAST_ONLY:e?Ir.RECEIVE_ONLY:Ir.DISABLED};XI=Object.freeze(Ir)});function qn(t){if(t=Z(t,Z.EMPTY_OBJECT),this.geometryInstances=t.geometryInstances,this.appearance=t.appearance,this._appearance=void 0,this._material=void 0,this.depthFailAppearance=t.depthFailAppearance,this._depthFailAppearance=void 0,this._depthFailMaterial=void 0,this.modelMatrix=at.clone(Z(t.modelMatrix,at.IDENTITY)),this._modelMatrix=new at,this.show=Z(t.show,!0),this._vertexCacheOptimize=Z(t.vertexCacheOptimize,!1),this._interleave=Z(t.interleave,!1),this._releaseGeometryInstances=Z(t.releaseGeometryInstances,!0),this._allowPicking=Z(t.allowPicking,!0),this._asynchronous=Z(t.asynchronous,!0),this._compressVertices=Z(t.compressVertices,!0),this.cull=Z(t.cull,!0),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.rtcCenter=t.rtcCenter,m(this.rtcCenter)&&(!m(this.geometryInstances)||Array.isArray(this.geometryInstances)&&this.geometryInstances.length!==1))throw new Y("Relative-to-center rendering only supports one geometry instance.");this.shadows=Z(t.shadows,XI.DISABLED),this._translucent=void 0,this._state=Is.READY,this._geometries=[],this._error=void 0,this._numberOfInstances=0,this._boundingSpheres=[],this._boundingSphereWC=[],this._boundingSphereCV=[],this._boundingSphere2D=[],this._boundingSphereMorph=[],this._perInstanceAttributeCache=new Map,this._instanceIds=[],this._lastPerInstanceAttributeIndex=0,this._va=[],this._attributeLocations=void 0,this._primitiveType=void 0,this._frontFaceRS=void 0,this._backFaceRS=void 0,this._sp=void 0,this._depthFailAppearance=void 0,this._spDepthFail=void 0,this._frontFaceDepthFailRS=void 0,this._backFaceDepthFailRS=void 0,this._pickIds=[],this._colorCommands=[],this._pickCommands=[],this._createBoundingVolumeFunction=t._createBoundingVolumeFunction,this._createRenderStatesFunction=t._createRenderStatesFunction,this._createShaderProgramFunction=t._createShaderProgramFunction,this._createCommandsFunction=t._createCommandsFunction,this._updateAndQueueCommandsFunction=t._updateAndQueueCommandsFunction,this._createPickOffsets=t._createPickOffsets,this._pickOffsets=void 0,this._createGeometryResults=void 0,this._ready=!1,this._batchTable=void 0,this._batchTableAttributeIndices=void 0,this._offsetInstanceExtend=void 0,this._batchTableOffsetAttribute2DIndex=void 0,this._batchTableOffsetsUpdated=!1,this._instanceBoundingSpheres=void 0,this._instanceBoundingSpheresCV=void 0,this._tempBoundingSpheres=void 0,this._recomputeBoundingSpheres=!1,this._batchTableBoundingSpheresUpdated=!1,this._batchTableBoundingSphereAttributeIndices=void 0}function not(t){let e=t.length,i=[],n=t[0].attributes,s;for(s in n)if(n.hasOwnProperty(s)&&m(n[s])){let o=n[s],r=!0;for(let a=1;a<e;++a){let h=t[a].attributes[s];if(!m(h)||o.componentDatatype!==h.componentDatatype||o.componentsPerAttribute!==h.componentsPerAttribute||o.normalize!==h.normalize){r=!1;break}}r&&i.push(s)}return i}function mJ(t){let e=t.length;if(e===1)return t[0];if(e===2)return nt.unpack(t,0,sot);if(e===3)return l.unpack(t,0,oot);if(e===4)return ie.unpack(t,0,dJ)}function rot(t,e){let i=t.geometryInstances,n=Array.isArray(i)?i:[i],s=n.length;if(s===0)return;let o=not(n),r=o.length,a=[],h={},A={},d,E=n[0].attributes,_,R,I;for(_=0;_<r;++_)R=o[_],I=E[R],h[R]=_,a.push({functionName:`czm_batchTable_${R}`,componentDatatype:I.componentDatatype,componentsPerAttribute:I.componentsPerAttribute,normalize:I.normalize});o.indexOf("distanceDisplayCondition")!==-1&&(a.push({functionName:"czm_batchTable_boundingSphereCenter3DHigh",componentDatatype:At.FLOAT,componentsPerAttribute:3},{functionName:"czm_batchTable_boundingSphereCenter3DLow",componentDatatype:At.FLOAT,componentsPerAttribute:3},{functionName:"czm_batchTable_boundingSphereCenter2DHigh",componentDatatype:At.FLOAT,componentsPerAttribute:3},{functionName:"czm_batchTable_boundingSphereCenter2DLow",componentDatatype:At.FLOAT,componentsPerAttribute:3},{functionName:"czm_batchTable_boundingSphereRadius",componentDatatype:At.FLOAT,componentsPerAttribute:1}),A.center3DHigh=a.length-5,A.center3DLow=a.length-4,A.center2DHigh=a.length-3,A.center2DLow=a.length-2,A.radius=a.length-1),o.indexOf("offset")!==-1&&(a.push({functionName:"czm_batchTable_offset2D",componentDatatype:At.FLOAT,componentsPerAttribute:3}),d=a.length-1),a.push({functionName:"czm_batchTable_pickColor",componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:4,normalize:!0});let C=a.length,N=new FP(e,a,s);for(_=0;_<s;++_){let T=n[_];E=T.attributes;for(let Q=0;Q<r;++Q){R=o[Q],I=E[R];let U=mJ(I.value),k=h[R];N.setBatchedAttribute(_,k,U)}let F={primitive:Z(T.pickPrimitive,t)};m(T.id)&&(F.id=T.id);let b=e.createPickId(F);t._pickIds.push(b);let G=b.color,M=dJ;M.x=Zt.floatToByte(G.red),M.y=Zt.floatToByte(G.green),M.z=Zt.floatToByte(G.blue),M.w=Zt.floatToByte(G.alpha),N.setBatchedAttribute(_,C-1,M)}t._batchTable=N,t._batchTableAttributeIndices=h,t._batchTableBoundingSphereAttributeIndices=A,t._batchTableOffsetAttribute2DIndex=d}function aot(t){let e;return Array.isArray(t.values)?e=t.values.slice(0):e=new t.values.constructor(t.values),new Tt({componentDatatype:t.componentDatatype,componentsPerAttribute:t.componentsPerAttribute,normalize:t.normalize,values:e})}function Aot(t){let e=t.attributes,i=new we;for(let s in e)e.hasOwnProperty(s)&&m(e[s])&&(i[s]=aot(e[s]));let n;if(m(t.indices)){let s=t.indices;Array.isArray(s)?n=s.slice(0):n=new s.constructor(s)}return new se({attributes:i,indices:n,primitiveType:t.primitiveType,boundingSphere:Nt.clone(t.boundingSphere)})}function hot(t,e){return{geometry:e,attributes:t.attributes,modelMatrix:at.clone(t.modelMatrix),pickPrimitive:t.pickPrimitive,id:t.id}}function sJ(t){return`${Mi.replaceMain(t,"czm_non_pick_main")}
out vec4 v_pickColor; 
void main() 
{ 
    czm_non_pick_main(); 
    v_pickColor = czm_batchTable_pickColor(batchId); 
}`}function oJ(t){return`in vec4 v_pickColor;
${t}`}function rJ(t,e){if(!t.compressVertices)return e;let i=e.search(/in\s+vec3\s+normal;/g)!==-1,n=e.search(/in\s+vec2\s+st;/g)!==-1;if(!i&&!n)return e;let s=e.search(/in\s+vec3\s+tangent;/g)!==-1,o=e.search(/in\s+vec3\s+bitangent;/g)!==-1,r=n&&i?2:1;r+=s||o?1:0;let a=r>1?`vec${r}`:"float",h="compressedAttributes",A=`in ${a} ${h};`,d="",f="";if(n){d+=`vec2 st;
`;let R=r>1?`${h}.x`:h;f+=`    st = czm_decompressTextureCoordinates(${R});
`}i&&s&&o?(d+=`vec3 normal;
vec3 tangent;
vec3 bitangent;
`,f+=`    czm_octDecode(${h}.${n?"yz":"xy"}, normal, tangent, bitangent);
`):(i&&(d+=`vec3 normal;
`,f+=`    normal = czm_octDecode(${h}${r>1?`.${n?"y":"x"}`:""});
`),s&&(d+=`vec3 tangent;
`,f+=`    tangent = czm_octDecode(${h}.${n&&i?"z":"y"});
`),o&&(d+=`vec3 bitangent;
`,f+=`    bitangent = czm_octDecode(${h}.${n&&i?"z":"y"});
`));let E=e;E=E.replace(/in\s+vec3\s+normal;/g,""),E=E.replace(/in\s+vec2\s+st;/g,""),E=E.replace(/in\s+vec3\s+tangent;/g,""),E=E.replace(/in\s+vec3\s+bitangent;/g,""),E=Mi.replaceMain(E,"czm_non_compressed_main");let _=`void main() 
{ 
${f}    czm_non_compressed_main(); 
}`;return[A,d,E,_].join(`
`)}function lot(t){let e=Mi.replaceMain(t,"czm_non_depth_clamp_main");return e+=`void main() {
    czm_non_depth_clamp_main();
    gl_Position = czm_depthClamp(gl_Position);}
`,e}function dot(t){let e=Mi.replaceMain(t,"czm_non_depth_clamp_main");return e+=`void main() {
    czm_non_depth_clamp_main();
    #if defined(LOG_DEPTH)
        czm_writeLogDepth();
    #else
        czm_writeDepthClamp();
    #endif
}
`,e}function aJ(t,e){let i=t.vertexAttributes;for(let n in i)if(i.hasOwnProperty(n)&&!m(e[n]))throw new Y(`Appearance/Geometry mismatch.  The appearance requires vertex shader attribute input '${n}', which was not computed as part of the Geometry.  Use the appearance's vertexFormat property when constructing the geometry.`)}function mot(t,e){return function(){return t[e]}}function Eot(t,e){let i,n,s,o,r=t._instanceIds;if(t._state===Is.READY){i=Array.isArray(t.geometryInstances)?t.geometryInstances:[t.geometryInstances];let a=t._numberOfInstances=i.length,h=[],A=[];for(s=0;s<a;++s){if(n=i[s].geometry,r.push(i[s].id),m(n._workerName)&&m(n._workerPath)||!m(n._workerName)&&!m(n._workerPath))throw new Y("Must define either _workerName or _workerPath for asynchronous geometry.");A.push({moduleName:n._workerName,modulePath:n._workerPath,geometry:n})}if(!m(qI))for(qI=new Array(sb),s=0;s<sb;s++)qI[s]=new XE("createGeometry");let d;for(A=gP(A,sb),s=0;s<A.length;s++){let f=0,E=A[s],_=E.length;for(o=0;o<_;++o)d=E[o],n=d.geometry,m(n.constructor.pack)&&(d.offset=f,f+=Z(n.constructor.packedLength,n.packedLength));let R;if(f>0){let I=new Float64Array(f);for(R=[I.buffer],o=0;o<_;++o)d=E[o],n=d.geometry,m(n.constructor.pack)&&(n.constructor.pack(n,I,d.offset),d.geometry=I)}h.push(qI[s].scheduleTask({subTasks:A[s]},R))}t._state=Is.CREATING,Promise.all(h).then(function(f){t._createGeometryResults=f,t._state=Is.CREATED}).catch(function(f){r_(t,e,Is.FAILED,f)})}else if(t._state===Is.CREATED){let a=[];i=Array.isArray(t.geometryInstances)?t.geometryInstances:[t.geometryInstances];let h=e.scene3DOnly,A=e.mapProjection,d=fot.scheduleTask(TA.packCombineGeometryParameters({createGeometryResults:t._createGeometryResults,instances:i,ellipsoid:A.ellipsoid,projection:A,elementIndexUintSupported:e.context.elementIndexUint,scene3DOnly:h,vertexCacheOptimize:t.vertexCacheOptimize,compressVertices:t.compressVertices,modelMatrix:t.modelMatrix,createPickOffsets:t._createPickOffsets},a),a);t._createGeometryResults=void 0,t._state=Is.COMBINING,Promise.resolve(d).then(function(f){let E=TA.unpackCombineGeometryResults(f);t._geometries=E.geometries,t._attributeLocations=E.attributeLocations,t.modelMatrix=at.clone(E.modelMatrix,t.modelMatrix),t._pickOffsets=E.pickOffsets,t._offsetInstanceExtend=E.offsetInstanceExtend,t._instanceBoundingSpheres=E.boundingSpheres,t._instanceBoundingSpheresCV=E.boundingSpheresCV,m(t._geometries)&&t._geometries.length>0?(t._recomputeBoundingSpheres=!0,t._state=Is.COMBINED):r_(t,e,Is.FAILED,void 0)}).catch(function(f){r_(t,e,Is.FAILED,f)})}}function _ot(t,e){let i=Array.isArray(t.geometryInstances)?t.geometryInstances:[t.geometryInstances],n=t._numberOfInstances=i.length,s=new Array(n),o=t._instanceIds,r,a,h=0;for(a=0;a<n;a++){r=i[a];let E=r.geometry,_;m(E.attributes)&&m(E.primitiveType)?_=Aot(E):_=E.constructor.createGeometry(E),s[h++]=hot(r,_),o.push(r.id)}s.length=h;let A=e.scene3DOnly,d=e.mapProjection,f=TA.combineGeometry({instances:s,ellipsoid:d.ellipsoid,projection:d,elementIndexUintSupported:e.context.elementIndexUint,scene3DOnly:A,vertexCacheOptimize:t.vertexCacheOptimize,compressVertices:t.compressVertices,modelMatrix:t.modelMatrix,createPickOffsets:t._createPickOffsets});t._geometries=f.geometries,t._attributeLocations=f.attributeLocations,t.modelMatrix=at.clone(f.modelMatrix,t.modelMatrix),t._pickOffsets=f.pickOffsets,t._offsetInstanceExtend=f.offsetInstanceExtend,t._instanceBoundingSpheres=f.boundingSpheres,t._instanceBoundingSpheresCV=f.boundingSpheresCV,m(t._geometries)&&t._geometries.length>0?(t._recomputeBoundingSpheres=!0,t._state=Is.COMBINED):r_(t,e,Is.FAILED,void 0)}function Rot(t,e){let i=t._batchTableAttributeIndices.offset;if(!t._recomputeBoundingSpheres||!m(i)){t._recomputeBoundingSpheres=!1;return}let n,s=t._offsetInstanceExtend,o=t._instanceBoundingSpheres,r=o.length,a=t._tempBoundingSpheres;if(!m(a)){for(a=new Array(r),n=0;n<r;n++)a[n]=new Nt;t._tempBoundingSpheres=a}for(n=0;n<r;++n){let I=a[n],C=t._batchTable.getBatchedAttribute(n,i,new l);I=o[n].clone(I),RJ(I,C,s[n])}let h=[],A=[],d=[];for(n=0;n<r;++n){let I=a[n];I.center.x-I.radius>0||Nt.intersectPlane(I,Ki.ORIGIN_ZX_PLANE)!==Nn.INTERSECTING?h.push(I):(A.push(I),d.push(I))}let f=h[0],E=d[0],_=A[0];for(n=1;n<h.length;n++)f=Nt.union(f,h[n]);for(n=1;n<d.length;n++)E=Nt.union(E,d[n]);for(n=1;n<A.length;n++)_=Nt.union(_,A[n]);let R=[];for(m(f)&&R.push(f),m(E)&&R.push(E),m(_)&&R.push(_),n=0;n<R.length;n++){let I=R[n].clone(t._boundingSpheres[n]);t._boundingSpheres[n]=I,t._boundingSphereCV[n]=Nt.projectTo2D(I,e.mapProjection,t._boundingSphereCV[n])}qn._updateBoundingVolumes(t,e,t.modelMatrix,!0),t._recomputeBoundingSpheres=!1}function Zot(t,e){if(!m(t._batchTableAttributeIndices.distanceDisplayCondition)||t._batchTableBoundingSpheresUpdated)return;let n=t._batchTableBoundingSphereAttributeIndices,s=n.center3DHigh,o=n.center3DLow,r=n.center2DHigh,a=n.center2DLow,h=n.radius,A=e.mapProjection,d=A.ellipsoid,f=t._batchTable,E=t._instanceBoundingSpheres,_=E.length;for(let R=0;R<_;++R){let I=E[R];if(!m(I))continue;let C=t.modelMatrix;m(C)&&(I=Nt.transform(I,C,_J));let N=I.center,T=I.radius,F=Bn.fromCartesian(N,AJ);if(f.setBatchedAttribute(R,s,F.high),f.setBatchedAttribute(R,o,F.low),!e.scene3DOnly){let b=d.cartesianToCartographic(N,fJ),G=A.project(b,EJ);F=Bn.fromCartesian(G,AJ),f.setBatchedAttribute(R,r,F.high),f.setBatchedAttribute(R,a,F.low)}f.setBatchedAttribute(R,h,T)}t._batchTableBoundingSpheresUpdated=!0}function hJ(t,e){if(!m(t._batchTableAttributeIndices.offset)||t._batchTableOffsetsUpdated||e.scene3DOnly)return;let n=t._batchTableOffsetAttribute2DIndex,s=e.mapProjection,o=s.ellipsoid,r=t._batchTable,a=t._instanceBoundingSpheres,h=a.length;for(let A=0;A<h;++A){let d=a[A];if(!m(d))continue;let f=r.getBatchedAttribute(A,t._batchTableAttributeIndices.offset);if(l.equals(f,l.ZERO)){r.setBatchedAttribute(A,n,l.ZERO);continue}let E=t.modelMatrix;m(E)&&(d=Nt.transform(d,E,_J));let _=d.center;_=o.scaleToGeodeticSurface(_,Iot);let R=o.cartesianToCartographic(_,fJ),I=s.project(R,EJ),C=l.add(f,_,ob);R=o.cartesianToCartographic(C,R);let N=s.project(R,ob),T=l.subtract(N,I,ob),F=T.x;T.x=T.z,T.z=T.y,T.y=F,r.setBatchedAttribute(A,n,T)}t._batchTableOffsetsUpdated=!0}function pot(t,e){let i=t._attributeLocations,n=t._geometries,s=e.scene3DOnly,o=e.context,r=[],a=n.length;for(let h=0;h<a;++h){let A=n[h];if(r.push(mI.fromGeometry({context:o,geometry:A,attributeLocations:i,bufferUsage:ai.STATIC_DRAW,interleave:t._interleave})),m(t._createBoundingVolumeFunction))t._createBoundingVolumeFunction(e,A);else if(t._boundingSpheres.push(Nt.clone(A.boundingSphere)),t._boundingSphereWC.push(new Nt),!s){let d=A.boundingSphereCV.center,f=d.x,E=d.y,_=d.z;d.x=_,d.y=f,d.z=E,t._boundingSphereCV.push(Nt.clone(A.boundingSphereCV)),t._boundingSphere2D.push(new Nt),t._boundingSphereMorph.push(new Nt)}}t._va=r,t._primitiveType=n[0].primitiveType,t.releaseGeometryInstances&&(t.geometryInstances=void 0),t._geometries=void 0,r_(t,e,Is.COMPLETE,void 0)}function uot(t,e,i,n){let s=i.getRenderState(),o;n?(o=qs(s,!1),o.cull={enabled:!0,face:Eh.BACK},t._frontFaceRS=Yn.fromCache(o),o.cull.face=Eh.FRONT,t._backFaceRS=Yn.fromCache(o)):(t._frontFaceRS=Yn.fromCache(s),t._backFaceRS=t._frontFaceRS),o=qs(s,!1),m(t._depthFailAppearance)&&(o.depthTest.enabled=!1),m(t._depthFailAppearance)&&(s=t._depthFailAppearance.getRenderState(),o=qs(s,!1),o.depthTest.func=wI.GREATER,n?(o.cull={enabled:!0,face:Eh.BACK},t._frontFaceDepthFailRS=Yn.fromCache(o),o.cull.face=Eh.FRONT,t._backFaceDepthFailRS=Yn.fromCache(o)):(t._frontFaceDepthFailRS=Yn.fromCache(o),t._backFaceDepthFailRS=t._frontFaceRS))}function Cot(t,e,i){let n=e.context,s=t._attributeLocations,o=t._batchTable.getVertexShaderCallback()(i.vertexShaderSource);o=qn._appendOffsetToShader(t,o),o=qn._appendShowToShader(t,o),o=qn._appendDistanceDisplayConditionToShader(t,o,e.scene3DOnly),o=sJ(o),o=qn._updateColorAttribute(t,o,!1),o=rJ(t,o),o=qn._modifyShaderPosition(t,o,e.scene3DOnly);let r=i.getFragmentShaderSource();r=oJ(r),t._sp=Es.replaceCache({context:n,shaderProgram:t._sp,vertexShaderSource:o,fragmentShaderSource:r,attributeLocations:s}),aJ(t._sp,s),m(t._depthFailAppearance)&&(o=t._batchTable.getVertexShaderCallback()(t._depthFailAppearance.vertexShaderSource),o=qn._appendShowToShader(t,o),o=qn._appendDistanceDisplayConditionToShader(t,o,e.scene3DOnly),o=sJ(o),o=qn._updateColorAttribute(t,o,!0),o=rJ(t,o),o=qn._modifyShaderPosition(t,o,e.scene3DOnly),o=lot(o),r=t._depthFailAppearance.getFragmentShaderSource(),r=oJ(r),r=dot(r),t._spDepthFail=Es.replaceCache({context:n,shaderProgram:t._spDepthFail,vertexShaderSource:o,fragmentShaderSource:r,attributeLocations:s}),aJ(t._spDepthFail,s))}function lJ(t,e,i,n){let s=m(i)?i._uniforms:void 0,o={},r=e.uniforms;if(m(r)){for(let h in r)if(r.hasOwnProperty(h)){if(m(s)&&m(s[h]))throw new Y(`Appearance and material have a uniform with the same name: ${h}`);o[h]=mot(r,h)}}let a=es(o,s);return a=t._batchTable.getUniformMapCallback()(a),m(t.rtcCenter)&&(a.u_modifiedModelView=function(){let h=n.context.uniformState.view;return at.multiply(h,t._modelMatrix,o_),at.multiplyByPoint(o_,t.rtcCenter,cJ),at.setTranslation(o_,cJ,o_),o_}),a}function got(t,e,i,n,s,o,r,a){let h=lJ(t,e,i,a),A;m(t._depthFailAppearance)&&(A=lJ(t,t._depthFailAppearance,t._depthFailAppearance.material,a));let d=n?os.TRANSLUCENT:os.OPAQUE,f=s?2:1;f*=m(t._depthFailAppearance)?2:1,o.length=t._va.length*f;let E=o.length,_=0;for(let R=0;R<E;++R){let I;s&&(I=o[R],m(I)||(I=o[R]=new fn({owner:t,primitiveType:t._primitiveType})),I.vertexArray=t._va[_],I.renderState=t._backFaceRS,I.shaderProgram=t._sp,I.uniformMap=h,I.pass=d,++R),I=o[R],m(I)||(I=o[R]=new fn({owner:t,primitiveType:t._primitiveType})),I.vertexArray=t._va[_],I.renderState=t._frontFaceRS,I.shaderProgram=t._sp,I.uniformMap=h,I.pass=d,m(t._depthFailAppearance)&&(s&&(++R,I=o[R],m(I)||(I=o[R]=new fn({owner:t,primitiveType:t._primitiveType})),I.vertexArray=t._va[_],I.renderState=t._backFaceDepthFailRS,I.shaderProgram=t._spDepthFail,I.uniformMap=A,I.pass=d),++R,I=o[R],m(I)||(I=o[R]=new fn({owner:t,primitiveType:t._primitiveType})),I.vertexArray=t._va[_],I.renderState=t._frontFaceDepthFailRS,I.shaderProgram=t._spDepthFail,I.uniformMap=A,I.pass=d),++_}}function Tot(t,e,i,n,s,o,r,a){if(e.mode!==ye.SCENE3D&&!at.equals(s,at.IDENTITY))throw new Y("Primitive.modelMatrix is only supported in 3D mode.");qn._updateBoundingVolumes(t,e,s);let h;e.mode===ye.SCENE3D?h=t._boundingSphereWC:e.mode===ye.COLUMBUS_VIEW?h=t._boundingSphereCV:e.mode===ye.SCENE2D&&m(t._boundingSphere2D)?h=t._boundingSphere2D:m(t._boundingSphereMorph)&&(h=t._boundingSphereMorph);let A=e.commandList,d=e.passes;if(d.render||d.pick){let f=t.allowPicking,E=XI.castShadows(t.shadows),_=XI.receiveShadows(t.shadows),R=i.length,I=a?2:1;I*=m(t._depthFailAppearance)?2:1;for(let C=0;C<R;++C){let N=Math.floor(C/I),T=i[C];T.modelMatrix=s,T.boundingVolume=h[N],T.cull=o,T.debugShowBoundingVolume=r,T.castShadows=E,T.receiveShadows=_,f?T.pickId="v_pickColor":T.pickId=void 0,A.push(T)}}}function RJ(t,e,i){if(i===Pe.TOP){let n=Nt.clone(t,Not),s=Nt.clone(t,bot);s.center=l.add(s.center,e,s.center),t=Nt.union(n,s,t)}else i===Pe.ALL&&(t.center=l.add(t.center,e,t.center));return t}function Fot(t,e,i){return function(){let n=t.getBatchedAttribute(e,i),s=t.attributes[i],o=s.componentsPerAttribute,r=At.createTypedArray(s.componentDatatype,o);return m(n.constructor.pack)?n.constructor.pack(n,r,0):r[0]=n,r}}function Yot(t,e,i,n,s){return function(o){if(!m(o)||!m(o.length)||o.length<1||o.length>4)throw new Y("value must be and array with length between 1 and 4.");let r=mJ(o);t.setBatchedAttribute(e,i,r),s==="offset"&&(n._recomputeBoundingSpheres=!0,n._batchTableOffsetsUpdated=!1)}}function Oot(t,e,i){e.boundingSphere={get:function(){let n=t._instanceBoundingSpheres[i];if(m(n)){n=n.clone();let s=t.modelMatrix,o=e.offset;m(o)&&RJ(n,l.fromArray(o.get(),0,Sot),t._offsetInstanceExtend[i]),m(s)&&(n=Nt.transform(n,s))}return n}},e.boundingSphereCV={get:function(){return t._instanceBoundingSpheresCV[i]}}}function Vot(t,e,i){e.pickId={get:function(){return t._pickIds[i]}}}function r_(t,e,i,n){t._error=n,t._state=i,e.afterRender.push(function(){t._ready=t._state===Is.COMPLETE||t._state===Is.FAILED})}var sot,oot,dJ,cot,sb,qI,fot,AJ,fJ,EJ,_J,ob,Iot,o_,cJ,Not,bot,Sot,vs,rb=O(()=>{_i();Xe();Ht();Vs();ri();aE();Qn();KA();oi();bt();mt();Ws();Vt();Tl();Il();yi();ji();En();go();nc();Fi();nh();Ps();TP();kN();Nl();ga();Bm();Wm();Mm();Qm();Fl();VT();YP();UI();PN();KI();iJ();ua();nJ();Object.defineProperties(qn.prototype,{vertexCacheOptimize:{get:function(){return this._vertexCacheOptimize}},interleave:{get:function(){return this._interleave}},releaseGeometryInstances:{get:function(){return this._releaseGeometryInstances}},allowPicking:{get:function(){return this._allowPicking}},asynchronous:{get:function(){return this._asynchronous}},compressVertices:{get:function(){return this._compressVertices}},ready:{get:function(){return this._ready}}});sot=new nt,oot=new l,dJ=new ie;cot=/in\s+vec(?:3|4)\s+(.*)3DHigh;/g;qn._modifyShaderPosition=function(t,e,i){let n,s="",o="",r="";for(;(n=cot.exec(e))!==null;){let a=n[1],h=`vec4 czm_compute${a[0].toUpperCase()}${a.substr(1)}()`;h!=="vec4 czm_computePosition()"&&(s+=`${h};
`),m(t.rtcCenter)?(e=e.replace(/in\s+vec(?:3|4)\s+position3DHigh;/g,""),e=e.replace(/in\s+vec(?:3|4)\s+position3DLow;/g,""),s+=`uniform mat4 u_modifiedModelView;
`,o+=`in vec4 position;
`,r+=`${h}
{
    return u_modifiedModelView * position;
}

`,e=e.replace(/czm_modelViewRelativeToEye\s+\*\s+/g,""),e=e.replace(/czm_modelViewProjectionRelativeToEye/g,"czm_projection")):i?r+=`${h}
{
    return czm_translateRelativeToEye(${a}3DHigh, ${a}3DLow);
}

`:(o+=`in vec3 ${a}2DHigh;
in vec3 ${a}2DLow;
`,r+=`${h}
{
    vec4 p;
    if (czm_morphTime == 1.0)
    {
        p = czm_translateRelativeToEye(${a}3DHigh, ${a}3DLow);
    }
    else if (czm_morphTime == 0.0)
    {
        p = czm_translateRelativeToEye(${a}2DHigh.zxy, ${a}2DLow.zxy);
    }
    else
    {
        p = czm_columbusViewMorph(
                czm_translateRelativeToEye(${a}2DHigh.zxy, ${a}2DLow.zxy),
                czm_translateRelativeToEye(${a}3DHigh, ${a}3DLow),
                czm_morphTime);
    }
    return p;
}

`)}return[s,o,e,r].join(`
`)};qn._appendShowToShader=function(t,e){return m(t._batchTableAttributeIndices.show)?`${Mi.replaceMain(e,"czm_non_show_main")}
void main() 
{ 
    czm_non_show_main(); 
    gl_Position *= czm_batchTable_show(batchId); 
}`:e};qn._updateColorAttribute=function(t,e,i){if(!m(t._batchTableAttributeIndices.color)&&!m(t._batchTableAttributeIndices.depthFailColor)||e.search(/in\s+vec4\s+color;/g)===-1)return e;if(i&&!m(t._batchTableAttributeIndices.depthFailColor))throw new Y("A depthFailColor per-instance attribute is required when using a depth fail appearance that uses a color attribute.");let n=e;return n=n.replace(/in\s+vec4\s+color;/g,""),i?n=n.replace(/(\b)color(\b)/g,"$1czm_batchTable_depthFailColor(batchId)$2"):n=n.replace(/(\b)color(\b)/g,"$1czm_batchTable_color(batchId)$2"),n};qn._updatePickColorAttribute=function(t){let e=t.replace(/in\s+vec4\s+pickColor;/g,"");return e=e.replace(/(\b)pickColor(\b)/g,"$1czm_batchTable_pickColor(batchId)$2"),e};qn._appendOffsetToShader=function(t,e){if(!m(t._batchTableAttributeIndices.offset))return e;let i=`in float batchId;
`;i+="in float applyOffset;";let n=e.replace(/in\s+float\s+batchId;/g,i),s=`vec4 $1 = czm_computePosition();
`;return s+=`    if (czm_sceneMode == czm_sceneMode3D)
`,s+=`    {
`,s+="        $1 = $1 + vec4(czm_batchTable_offset(batchId) * applyOffset, 0.0);",s+=`    }
`,s+=`    else
`,s+=`    {
`,s+="        $1 = $1 + vec4(czm_batchTable_offset2D(batchId) * applyOffset, 0.0);",s+=`    }
`,n=n.replace(/vec4\s+([A-Za-z0-9_]+)\s+=\s+czm_computePosition\(\);/g,s),n};qn._appendDistanceDisplayConditionToShader=function(t,e,i){if(!m(t._batchTableAttributeIndices.distanceDisplayCondition))return e;let n=Mi.replaceMain(e,"czm_non_distanceDisplayCondition_main"),s=`void main() 
{ 
    czm_non_distanceDisplayCondition_main(); 
    vec2 distanceDisplayCondition = czm_batchTable_distanceDisplayCondition(batchId);
    vec3 boundingSphereCenter3DHigh = czm_batchTable_boundingSphereCenter3DHigh(batchId);
    vec3 boundingSphereCenter3DLow = czm_batchTable_boundingSphereCenter3DLow(batchId);
    float boundingSphereRadius = czm_batchTable_boundingSphereRadius(batchId);
`;return i?s+=`    vec4 centerRTE = czm_translateRelativeToEye(boundingSphereCenter3DHigh, boundingSphereCenter3DLow);
`:s+=`    vec3 boundingSphereCenter2DHigh = czm_batchTable_boundingSphereCenter2DHigh(batchId);
    vec3 boundingSphereCenter2DLow = czm_batchTable_boundingSphereCenter2DLow(batchId);
    vec4 centerRTE;
    if (czm_morphTime == 1.0)
    {
        centerRTE = czm_translateRelativeToEye(boundingSphereCenter3DHigh, boundingSphereCenter3DLow);
    }
    else if (czm_morphTime == 0.0)
    {
        centerRTE = czm_translateRelativeToEye(boundingSphereCenter2DHigh.zxy, boundingSphereCenter2DLow.zxy);
    }
    else
    {
        centerRTE = czm_columbusViewMorph(
                czm_translateRelativeToEye(boundingSphereCenter2DHigh.zxy, boundingSphereCenter2DLow.zxy),
                czm_translateRelativeToEye(boundingSphereCenter3DHigh, boundingSphereCenter3DLow),
                czm_morphTime);
    }
`,s+=`    float radiusSq = boundingSphereRadius * boundingSphereRadius; 
    float distanceSq; 
    if (czm_sceneMode == czm_sceneMode2D) 
    { 
        distanceSq = czm_eyeHeight2D.y - radiusSq; 
    } 
    else 
    { 
        distanceSq = dot(centerRTE.xyz, centerRTE.xyz) - radiusSq; 
    } 
    distanceSq = max(distanceSq, 0.0); 
    float nearSq = distanceDisplayCondition.x * distanceDisplayCondition.x; 
    float farSq = distanceDisplayCondition.y * distanceDisplayCondition.y; 
    float show = (distanceSq >= nearSq && distanceSq <= farSq) ? 1.0 : 0.0; 
    gl_Position *= show; 
}`,`${n}
${s}`};sb=Math.max(_o.hardwareConcurrency-1,1),fot=new XE("combineGeometry");AJ=new Bn,fJ=new ut,EJ=new l,_J=new Nt;ob=new l,Iot=new l;o_=new at,cJ=new l;qn._updateBoundingVolumes=function(t,e,i,n){let s,o,r;if(n||!at.equals(i,t._modelMatrix))for(at.clone(i,t._modelMatrix),o=t._boundingSpheres.length,s=0;s<o;++s)r=t._boundingSpheres[s],m(r)&&(t._boundingSphereWC[s]=Nt.transform(r,i,t._boundingSphereWC[s]),e.scene3DOnly||(t._boundingSphere2D[s]=Nt.clone(t._boundingSphereCV[s],t._boundingSphere2D[s]),t._boundingSphere2D[s].center.x=0,t._boundingSphereMorph[s]=Nt.union(t._boundingSphereWC[s],t._boundingSphereCV[s])));let a=t.appearance.pixelSize;if(m(a))for(o=t._boundingSpheres.length,s=0;s<o;++s){r=t._boundingSpheres[s];let h=t._boundingSphereWC[s],d=e.camera.getPixelSize(r,e.context.drawingBufferWidth,e.context.drawingBufferHeight)*a;h.radius=r.radius+d}};qn.prototype.update=function(t){if(!m(this.geometryInstances)&&this._va.length===0||m(this.geometryInstances)&&Array.isArray(this.geometryInstances)&&this.geometryInstances.length===0||!m(this.appearance)||t.mode!==ye.SCENE3D&&t.scene3DOnly||!t.passes.render&&!t.passes.pick)return;if(m(this._error))throw this._error;if(m(this.rtcCenter)&&!t.scene3DOnly)throw new Y("RTC rendering is only available for 3D only scenes.");if(this._state===Is.FAILED)return;let e=t.context;if(m(this._batchTable)||rot(this,e),this._batchTable.attributes.length>0){if(en.maximumVertexTextureImageUnits===0)throw new ke("Vertex texture fetch support is required to render primitives with per-instance attributes. The maximum number of vertex texture image units must be greater than zero.");this._batchTable.update(t)}if(this._state!==Is.COMPLETE&&this._state!==Is.COMBINED&&(this.asynchronous?Eot(this,t):_ot(this,t)),this._state===Is.COMBINED&&(Zot(this,t),hJ(this,t),pot(this,t)),!this.show||this._state!==Is.COMPLETE)return;this._batchTableOffsetsUpdated||hJ(this,t),this._recomputeBoundingSpheres&&Rot(this,t);let i=this.appearance,n=i.material,s=!1,o=!1;this._appearance!==i?(this._appearance=i,this._material=n,s=!0,o=!0):this._material!==n&&(this._material=n,o=!0);let r=this.depthFailAppearance,a=m(r)?r.material:void 0;this._depthFailAppearance!==r?(this._depthFailAppearance=r,this._depthFailMaterial=a,s=!0,o=!0):this._depthFailMaterial!==a&&(this._depthFailMaterial=a,o=!0);let h=this._appearance.isTranslucent();this._translucent!==h&&(this._translucent=h,s=!0),m(this._material)&&this._material.update(e);let A=i.closed&&h;s&&Z(this._createRenderStatesFunction,uot)(this,e,i,A),o&&Z(this._createShaderProgramFunction,Cot)(this,t,i),(s||o)&&Z(this._createCommandsFunction,got)(this,i,n,h,A,this._colorCommands,this._pickCommands,t),Z(this._updateAndQueueCommandsFunction,Tot)(this,t,this._colorCommands,this._pickCommands,this.modelMatrix,this.cull,this.debugShowBoundingVolume,A)};Not=new Nt,bot=new Nt;Sot=new l;qn.prototype.getGeometryInstanceAttributes=function(t){if(!m(t))throw new Y("id is required");if(!m(this._batchTable))throw new Y("must call update before calling getGeometryInstanceAttributes");let e=this._perInstanceAttributeCache.get(t);if(m(e))return e;let i=-1,n=this._lastPerInstanceAttributeIndex,s=this._instanceIds,o=s.length;for(let A=0;A<o;++A){let d=(n+A)%o;if(t===s[d]){i=d;break}}if(i===-1)return;let r=this._batchTable,a=this._batchTableAttributeIndices;e={};let h={};for(let A in a)if(a.hasOwnProperty(A)){let d=a[A];h[A]={get:Fot(r,i,d),set:Yot(r,i,d,this,A)}}return Oot(this,h,i),Vot(this,h,i),Object.defineProperties(e,h),this._lastPerInstanceAttributeIndex=i,this._perInstanceAttributeCache.set(t,e),e};qn.prototype.isDestroyed=function(){return!1};qn.prototype.destroy=function(){let t,e;this._sp=this._sp&&this._sp.destroy(),this._spDepthFail=this._spDepthFail&&this._spDepthFail.destroy();let i=this._va;for(t=i.length,e=0;e<t;++e)i[e].destroy();this._va=void 0;let n=this._pickIds;for(t=n.length,e=0;e<t;++e)n[e].destroy();return this._pickIds=void 0,this._batchTable=this._batchTable&&this._batchTable.destroy(),this._instanceIds=void 0,this._perInstanceAttributeCache=void 0,this._attributeLocations=void 0,li(this)};vs=qn});var Got,pr,$I=O(()=>{ss();Got={NEVER:it.NEVER,LESS:it.LESS,EQUAL:it.EQUAL,LESS_OR_EQUAL:it.LEQUAL,GREATER:it.GREATER,NOT_EQUAL:it.NOTEQUAL,GREATER_OR_EQUAL:it.GEQUAL,ALWAYS:it.ALWAYS},pr=Object.freeze(Got)});var Bot,Hi,tp=O(()=>{ss();Bot={ZERO:it.ZERO,KEEP:it.KEEP,REPLACE:it.REPLACE,INCREMENT:it.INCR,DECREMENT:it.DECR,INVERT:it.INVERT,INCREMENT_WRAP:it.INCR_WRAP,DECREMENT_WRAP:it.DECR_WRAP},Hi=Object.freeze(Bot)});var ep,Wa,ab=O(()=>{$I();tp();ep={CESIUM_3D_TILE_MASK:128,SKIP_LOD_MASK:112,SKIP_LOD_BIT_SHIFT:4,CLASSIFICATION_MASK:15};ep.setCesium3DTileBit=function(){return{enabled:!0,frontFunction:pr.ALWAYS,frontOperation:{fail:Hi.KEEP,zFail:Hi.KEEP,zPass:Hi.REPLACE},backFunction:pr.ALWAYS,backOperation:{fail:Hi.KEEP,zFail:Hi.KEEP,zPass:Hi.REPLACE},reference:ep.CESIUM_3D_TILE_MASK,mask:ep.CESIUM_3D_TILE_MASK}};Wa=Object.freeze(ep)});function Ih(t){t=Z(t,Z.EMPTY_OBJECT),this.geometryInstances=t.geometryInstances,this._hasPerInstanceColors=!0;let e=t.appearance;m(e)||(e=new uP),this.appearance=e,this.show=Z(t.show,!0),this.classificationType=Z(t.classificationType,Jr.BOTH),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this._debugShowShadowVolume=Z(t.debugShowShadowVolume,!1),this._primitiveOptions={geometryInstances:void 0,appearance:void 0,vertexCacheOptimize:!1,interleave:Z(t.interleave,!1),releaseGeometryInstances:Z(t.releaseGeometryInstances,!0),allowPicking:Z(t.allowPicking,!0),asynchronous:Z(t.asynchronous,!0),compressVertices:!1,_createShaderProgramFunction:void 0,_createCommandsFunction:void 0,_updateAndQueueCommandsFunction:void 0},this._zIndex=void 0,this._ready=!1,this._primitive=void 0,this._sp=void 0,this._sp2D=void 0,this._spMorph=void 0,this._renderState=ZJ(!1),this._renderState3DTiles=ZJ(!0),this._renderStateMorph=Yn.fromCache({cull:{enabled:!0,face:Eh.FRONT},depthTest:{enabled:!0},blending:Ur.PRE_MULTIPLIED_ALPHA_BLEND,depthMask:!1})}function Wot(t,e,i){let n=e.context,s=t._primitive,o=s._attributeLocations,r=s._batchTable.getVertexShaderCallback()(mx);r=vs._appendShowToShader(s,r),r=vs._appendDistanceDisplayConditionToShader(s,r),r=vs._modifyShaderPosition(t,r,e.scene3DOnly);let a=s._batchTable.getVertexShaderCallback()(lx);a=vs._appendShowToShader(s,a),a=vs._appendDistanceDisplayConditionToShader(s,a),a=vs._modifyShaderPosition(t,a,e.scene3DOnly);let h=s._batchTable.getVertexShaderCallback()(ax),A=[`GLOBE_MINIMUM_ALTITUDE ${e.mapProjection.ellipsoid.minimumRadius.toFixed(1)}`],d="",f="";m(i.material)?(f=m(i.material)?i.material.shaderSource:"",f.search(/in\s+float\s+v_polylineAngle;/g)!==-1&&A.push("ANGLE_VARYING"),f.search(/in\s+float\s+v_width;/g)!==-1&&A.push("WIDTH_VARYING")):d="PER_INSTANCE_COLOR",A.push(d);let E=t.debugShowShadowVolume?["DEBUG_SHOW_VOLUME",d]:[d],_=new Mi({defines:A,sources:[r]}),R=new Mi({defines:E,sources:[f,h]});t._sp=Es.replaceCache({context:n,shaderProgram:s._sp,vertexShaderSource:_,fragmentShaderSource:R,attributeLocations:o});let I=n.shaderCache.getDerivedShaderProgram(t._sp,"2dColor");if(!m(I)){let N=new Mi({defines:A.concat(["COLUMBUS_VIEW_2D"]),sources:[r]});I=n.shaderCache.createDerivedShaderProgram(t._sp,"2dColor",{context:n,shaderProgram:t._sp2D,vertexShaderSource:N,fragmentShaderSource:R,attributeLocations:o})}t._sp2D=I;let C=n.shaderCache.getDerivedShaderProgram(t._sp,"MorphColor");if(!m(C)){let N=new Mi({defines:A.concat([`MAX_TERRAIN_HEIGHT ${Do._defaultMaxTerrainHeight.toFixed(1)}`]),sources:[a]});h=s._batchTable.getVertexShaderCallback()(hx);let T=new Mi({defines:E,sources:[f,h]});C=n.shaderCache.createDerivedShaderProgram(t._sp,"MorphColor",{context:n,shaderProgram:t._spMorph,vertexShaderSource:N,fragmentShaderSource:T,attributeLocations:o})}t._spMorph=C}function ZJ(t){return Yn.fromCache({cull:{enabled:!0},blending:Ur.PRE_MULTIPLIED_ALPHA_BLEND,depthMask:!1,stencilTest:{enabled:t,frontFunction:pr.EQUAL,frontOperation:{fail:Hi.KEEP,zFail:Hi.KEEP,zPass:Hi.KEEP},backFunction:pr.EQUAL,backOperation:{fail:Hi.KEEP,zFail:Hi.KEEP,zPass:Hi.KEEP},reference:Wa.CESIUM_3D_TILE_MASK,mask:Wa.CESIUM_3D_TILE_MASK}})}function Dot(t,e,i,n,s,o){let r=t._primitive,a=r._va.length;s.length=a,o.length=a;let A=e instanceof DN?{}:i._uniforms,d=r._batchTable.getUniformMapCallback()(A);for(let f=0;f<a;f++){let E=r._va[f],_=s[f];m(_)||(_=s[f]=new fn({owner:t,primitiveType:r._primitiveType})),_.vertexArray=E,_.renderState=t._renderState,_.shaderProgram=t._sp,_.uniformMap=d,_.pass=os.TERRAIN_CLASSIFICATION,_.pickId="czm_batchTable_pickColor(v_endPlaneNormalEcAndBatchId.w)";let R=fn.shallowClone(_,_.derivedCommands.tileset);R.renderState=t._renderState3DTiles,R.pass=os.CESIUM_3D_TILE_CLASSIFICATION,_.derivedCommands.tileset=R;let I=fn.shallowClone(_,_.derivedCommands.color2D);I.shaderProgram=t._sp2D,_.derivedCommands.color2D=I;let C=fn.shallowClone(R,R.derivedCommands.color2D);C.shaderProgram=t._sp2D,R.derivedCommands.color2D=C;let N=fn.shallowClone(_,_.derivedCommands.colorMorph);N.renderState=t._renderStateMorph,N.shaderProgram=t._spMorph,N.pickId="czm_batchTable_pickColor(v_batchId)",_.derivedCommands.colorMorph=N}}function IJ(t,e,i,n,s,o,r){i.mode===ye.MORPHING?e=e.derivedCommands.colorMorph:i.mode!==ye.SCENE3D&&(e=e.derivedCommands.color2D),e.modelMatrix=n,e.boundingVolume=o,e.cull=s,e.debugShowBoundingVolume=r,i.commandList.push(e)}function Mot(t,e,i,n,s,o,r){let a=t._primitive;vs._updateBoundingVolumes(a,e,s);let h;e.mode===ye.SCENE3D?h=a._boundingSphereWC:e.mode===ye.COLUMBUS_VIEW?h=a._boundingSphereCV:e.mode===ye.SCENE2D&&m(a._boundingSphere2D)?h=a._boundingSphere2D:m(a._boundingSphereMorph)&&(h=a._boundingSphereMorph);let A=e.mode===ye.MORPHING,d=t.classificationType,f=d!==Jr.CESIUM_3D_TILE,E=d!==Jr.TERRAIN&&!A,_,R=e.passes;if(R.render||R.pick&&a.allowPicking){let I=i.length;for(let C=0;C<I;++C){let N=h[C];f&&(_=i[C],IJ(t,_,e,s,o,N,r)),E&&(_=i[C].derivedCommands.tileset,IJ(t,_,e,s,o,N,r))}}}var pJ,uJ=O(()=>{JE();oi();bt();mt();Ws();Vt();uA();mN();VN();Bm();Wm();Mm();Qm();Fl();Ax();cx();dx();fx();km();MI();UI();Zx();CP();rb();ua();ab();$I();tp();Object.defineProperties(Ih.prototype,{interleave:{get:function(){return this._primitiveOptions.interleave}},releaseGeometryInstances:{get:function(){return this._primitiveOptions.releaseGeometryInstances}},allowPicking:{get:function(){return this._primitiveOptions.allowPicking}},asynchronous:{get:function(){return this._primitiveOptions.asynchronous}},ready:{get:function(){return this._ready}},debugShowShadowVolume:{get:function(){return this._debugShowShadowVolume}}});Ih.initializeTerrainHeights=function(){return Do.initialize()};Ih.prototype.update=function(t){if(!m(this._primitive)&&!m(this.geometryInstances))return;if(!Do.initialized){if(!this.asynchronous)throw new Y("For synchronous GroundPolylinePrimitives, you must call GroundPolylinePrimitives.initializeTerrainHeights() and wait for the returned promise to resolve.");Ih.initializeTerrainHeights();return}let e,i=this,n=this._primitiveOptions;if(!m(this._primitive)){let s=Array.isArray(this.geometryInstances)?this.geometryInstances:[this.geometryInstances],o=s.length,r=new Array(o),a;for(e=0;e<o;++e)if(a=s[e].attributes,!m(a)||!m(a.color)){this._hasPerInstanceColors=!1;break}for(e=0;e<o;++e){let h=s[e];a={};let A=h.attributes;for(let d in A)A.hasOwnProperty(d)&&(a[d]=A[d]);m(a.width)||(a.width=new Zr({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,value:[h.geometry.width]})),h.geometry._scene3DOnly=t.scene3DOnly,KE.setProjectionAndEllipsoid(h.geometry,t.mapProjection),r[e]=new Ln({geometry:h.geometry,attributes:a,id:h.id,pickPrimitive:i})}n.geometryInstances=r,n.appearance=this.appearance,n._createShaderProgramFunction=function(h,A,d){Wot(i,A,d)},n._createCommandsFunction=function(h,A,d,f,E,_,R){Dot(i,A,d,f,_,R)},n._updateAndQueueCommandsFunction=function(h,A,d,f,E,_,R,I){Mot(i,A,d,f,E,_,R)},this._primitive=new vs(n)}if(this.appearance instanceof DN&&!this._hasPerInstanceColors)throw new Y("All GeometryInstances must have color attributes to use PolylineColorAppearance with GroundPolylinePrimitive.");this._primitive.appearance=this.appearance,this._primitive.show=this.show,this._primitive.debugShowBoundingVolume=this.debugShowBoundingVolume,this._primitive.update(t),t.afterRender.push(()=>{!this._ready&&m(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};Ih.prototype.getGeometryInstanceAttributes=function(t){if(!m(this._primitive))throw new Y("must call update before calling getGeometryInstanceAttributes");return this._primitive.getGeometryInstanceAttributes(t)};Ih.isSupported=function(t){return t.frameState.context.depthTexture};Ih.prototype.isDestroyed=function(){return!1};Ih.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),this._sp=this._sp&&this._sp.destroy(),this._sp2D=void 0,this._spMorph=void 0,li(this)};pJ=Ih});function ko(t,e,i){this.minimum=l.clone(Z(t,l.ZERO)),this.maximum=l.clone(Z(e,l.ZERO)),m(i)?i=l.clone(i):i=l.midpoint(this.minimum,this.maximum,new l),this.center=i}var ip,ph,a_=O(()=>{Ht();ae();bt();mt();nc();ko.fromCorners=function(t,e,i){return p.defined("minimum",t),p.defined("maximum",e),m(i)||(i=new ko),i.minimum=l.clone(t,i.minimum),i.maximum=l.clone(e,i.maximum),i.center=l.midpoint(t,e,i.center),i};ko.fromPoints=function(t,e){if(m(e)||(e=new ko),!m(t)||t.length===0)return e.minimum=l.clone(l.ZERO,e.minimum),e.maximum=l.clone(l.ZERO,e.maximum),e.center=l.clone(l.ZERO,e.center),e;let i=t[0].x,n=t[0].y,s=t[0].z,o=t[0].x,r=t[0].y,a=t[0].z,h=t.length;for(let f=1;f<h;f++){let E=t[f],_=E.x,R=E.y,I=E.z;i=Math.min(_,i),o=Math.max(_,o),n=Math.min(R,n),r=Math.max(R,r),s=Math.min(I,s),a=Math.max(I,a)}let A=e.minimum;A.x=i,A.y=n,A.z=s;let d=e.maximum;return d.x=o,d.y=r,d.z=a,e.center=l.midpoint(A,d,e.center),e};ko.clone=function(t,e){if(m(t))return m(e)?(e.minimum=l.clone(t.minimum,e.minimum),e.maximum=l.clone(t.maximum,e.maximum),e.center=l.clone(t.center,e.center),e):new ko(t.minimum,t.maximum,t.center)};ko.equals=function(t,e){return t===e||m(t)&&m(e)&&l.equals(t.center,e.center)&&l.equals(t.minimum,e.minimum)&&l.equals(t.maximum,e.maximum)};ip=new l;ko.intersectPlane=function(t,e){p.defined("box",t),p.defined("plane",e),ip=l.subtract(t.maximum,t.minimum,ip);let i=l.multiplyByScalar(ip,.5,ip),n=e.normal,s=i.x*Math.abs(n.x)+i.y*Math.abs(n.y)+i.z*Math.abs(n.z),o=l.dot(t.center,n)+e.distance;return o-s>0?Nn.INSIDE:o+s<0?Nn.OUTSIDE:Nn.INTERSECTING};ko.prototype.clone=function(t){return ko.clone(this,t)};ko.prototype.intersectPlane=function(t){return ko.intersectPlane(this,t)};ko.prototype.equals=function(t){return ko.equals(this,t)};ph=ko});function NA(t,e){if(p.defined("origin",t),e=Z(e,ot.WGS84),t=e.scaleToGeodeticSurface(t),!m(t))throw new Y("origin must not be at the center of the ellipsoid.");let i=In.eastNorthUpToFixedFrame(t,e);this._ellipsoid=e,this._origin=t,this._xAxis=l.fromCartesian4(at.getColumn(i,0,Ab)),this._yAxis=l.fromCartesian4(at.getColumn(i,1,Ab));let n=l.fromCartesian4(at.getColumn(i,2,Ab));this._plane=Ki.fromPointNormal(t,n)}var Ab,Uot,CJ,np,Qot,oo,Xm=O(()=>{a_();Xe();Ht();Vs();ae();bt();mt();Vt();Ve();Ml();Fi();nh();OI();fr();Ab=new ie;Object.defineProperties(NA.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},origin:{get:function(){return this._origin}},plane:{get:function(){return this._plane}},xAxis:{get:function(){return this._xAxis}},yAxis:{get:function(){return this._yAxis}},zAxis:{get:function(){return this._plane.normal}}});Uot=new ph;NA.fromPoints=function(t,e){p.defined("cartesians",t);let i=ph.fromPoints(t,Uot);return new NA(i.center,e)};CJ=new Wl,np=new l;NA.prototype.projectPointOntoPlane=function(t,e){p.defined("cartesian",t);let i=CJ;i.origin=t,l.normalize(t,i.direction);let n=no.rayPlane(i,this._plane,np);if(m(n)||(l.negate(i.direction,i.direction),n=no.rayPlane(i,this._plane,np)),m(n)){let s=l.subtract(n,this._origin,n),o=l.dot(this._xAxis,s),r=l.dot(this._yAxis,s);return m(e)?(e.x=o,e.y=r,e):new nt(o,r)}};NA.prototype.projectPointsOntoPlane=function(t,e){p.defined("cartesians",t),m(e)||(e=[]);let i=0,n=t.length;for(let s=0;s<n;s++){let o=this.projectPointOntoPlane(t[s],e[i]);m(o)&&(e[i]=o,i++)}return e.length=i,e};NA.prototype.projectPointToNearestOnPlane=function(t,e){p.defined("cartesian",t),m(e)||(e=new nt);let i=CJ;i.origin=t,l.clone(this._plane.normal,i.direction);let n=no.rayPlane(i,this._plane,np);m(n)||(l.negate(i.direction,i.direction),n=no.rayPlane(i,this._plane,np));let s=l.subtract(n,this._origin,n),o=l.dot(this._xAxis,s),r=l.dot(this._yAxis,s);return e.x=o,e.y=r,e};NA.prototype.projectPointsToNearestOnPlane=function(t,e){p.defined("cartesians",t),m(e)||(e=[]);let i=t.length;e.length=i;for(let n=0;n<i;n++)e[n]=this.projectPointToNearestOnPlane(t[n],e[n]);return e};Qot=new l;NA.prototype.projectPointOntoEllipsoid=function(t,e){p.defined("cartesian",t),m(e)||(e=new l);let i=this._ellipsoid,n=this._origin,s=this._xAxis,o=this._yAxis,r=Qot;return l.multiplyByScalar(s,t.x,r),e=l.add(n,r,e),l.multiplyByScalar(o,t.y,r),l.add(e,r,e),i.scaleToGeocentricSurface(e,e),e};NA.prototype.projectPointsOntoEllipsoid=function(t,e){p.defined("cartesians",t);let i=t.length;m(e)?e.length=i:e=new Array(i);for(let n=0;n<i;++n)e[n]=this.projectPointOntoEllipsoid(t[n],e[n]);return e};oo=NA});function Gi(t,e){this.center=l.clone(Z(t,l.ZERO)),this.halfAxes=lt.clone(Z(e,lt.ZERO))}function gJ(t,e,i,n,s,o,r,a,h,A,d){if(!m(s)||!m(o)||!m(r)||!m(a)||!m(h)||!m(A))throw new Y("all extents (minimum/maximum X/Y/Z) are required.");m(d)||(d=new Gi);let f=d.halfAxes;lt.setColumn(f,0,e,f),lt.setColumn(f,1,i,f),lt.setColumn(f,2,n,f);let E=YJ;E.x=(s+o)/2,E.y=(r+a)/2,E.z=(h+A)/2;let _=Hot;_.x=(o-s)/2,_.y=(a-r)/2,_.z=(A-h)/2;let R=d.center;return E=lt.multiplyByVector(f,E,E),l.add(t,E,R),lt.multiplyByScale(f,_,f),d}var kot,Lot,yot,wot,xot,Pot,Jot,jot,YJ,Hot,TJ,vot,zot,Kot,Xot,qot,$ot,trt,NJ,ert,bJ,irt,nrt,srt,ort,rrt,art,Art,hrt,crt,lrt,drt,mrt,frt,Ert,_rt,SJ,OJ,VJ,Rrt,FJ,Zrt,Irt,prt,urt,Crt,grt,Trt,Nrt,zs,Jl=O(()=>{_i();Xe();Ht();ri();ae();bt();mt();Vt();Ve();Xm();nc();HZ();_e();dn();Fi();nh();pn();Gi.packedLength=l.packedLength+lt.packedLength;Gi.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),l.pack(t.center,e,i),lt.pack(t.halfAxes,e,i+l.packedLength),e};Gi.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Gi),l.unpack(t,e,i.center),lt.unpack(t,e+l.packedLength,i.halfAxes),i};kot=new l,Lot=new l,yot=new l,wot=new l,xot=new l,Pot=new l,Jot=new lt,jot={unitary:new lt,diagonal:new lt};Gi.fromPoints=function(t,e){if(m(e)||(e=new Gi),!m(t)||t.length===0)return e.halfAxes=lt.ZERO,e.center=l.ZERO,e;let i,n=t.length,s=l.clone(t[0],kot);for(i=1;i<n;i++)l.add(s,t[i],s);let o=1/n;l.multiplyByScalar(s,o,s);let r=0,a=0,h=0,A=0,d=0,f=0,E;for(i=0;i<n;i++)E=l.subtract(t[i],s,Lot),r+=E.x*E.x,a+=E.x*E.y,h+=E.x*E.z,A+=E.y*E.y,d+=E.y*E.z,f+=E.z*E.z;r*=o,a*=o,h*=o,A*=o,d*=o,f*=o;let _=Jot;_[0]=r,_[1]=a,_[2]=h,_[3]=a,_[4]=A,_[5]=d,_[6]=h,_[7]=d,_[8]=f;let R=lt.computeEigenDecomposition(_,jot),I=lt.clone(R.unitary,e.halfAxes),C=lt.getColumn(I,0,wot),N=lt.getColumn(I,1,xot),T=lt.getColumn(I,2,Pot),F=-Number.MAX_VALUE,b=-Number.MAX_VALUE,G=-Number.MAX_VALUE,M=Number.MAX_VALUE,Q=Number.MAX_VALUE,U=Number.MAX_VALUE;for(i=0;i<n;i++)E=t[i],F=Math.max(l.dot(C,E),F),b=Math.max(l.dot(N,E),b),G=Math.max(l.dot(T,E),G),M=Math.min(l.dot(C,E),M),Q=Math.min(l.dot(N,E),Q),U=Math.min(l.dot(T,E),U);C=l.multiplyByScalar(C,.5*(M+F),C),N=l.multiplyByScalar(N,.5*(Q+b),N),T=l.multiplyByScalar(T,.5*(U+G),T);let k=l.add(C,N,e.center);l.add(k,T,k);let y=yot;return y.x=F-M,y.y=b-Q,y.z=G-U,l.multiplyByScalar(y,.5,y),lt.multiplyByScale(e.halfAxes,y,e.halfAxes),e};YJ=new l,Hot=new l;TJ=new ut,vot=new l,zot=new ut,Kot=new ut,Xot=new ut,qot=new ut,$ot=new ut,trt=new l,NJ=new l,ert=new l,bJ=new l,irt=new l,nrt=new nt,srt=new nt,ort=new nt,rrt=new nt,art=new nt,Art=new l,hrt=new l,crt=new l,lrt=new l,drt=new nt,mrt=new l,frt=new l,Ert=new l,_rt=new Ki(l.UNIT_X,0);Gi.fromRectangle=function(t,e,i,n,s){if(!m(t))throw new Y("rectangle is required");if(t.width<0||t.width>L.TWO_PI)throw new Y("Rectangle width must be between 0 and 2 * pi");if(t.height<0||t.height>L.PI)throw new Y("Rectangle height must be between 0 and pi");if(m(n)&&!L.equalsEpsilon(n.radii.x,n.radii.y,L.EPSILON15))throw new Y("Ellipsoid must be an ellipsoid of revolution (radii.x == radii.y)");e=Z(e,0),i=Z(i,0),n=Z(n,ot.WGS84);let o,r,a,h,A,d,f;if(t.width<=L.PI){let Q=Xt.center(t,TJ),U=n.cartographicToCartesian(Q,vot),k=new oo(U,n);f=k.plane;let y=Q.longitude,c=t.south<0&&t.north>0?0:Q.latitude,g=ut.fromRadians(y,t.north,i,zot),V=ut.fromRadians(t.west,t.north,i,Kot),D=ut.fromRadians(t.west,c,i,Xot),w=ut.fromRadians(t.west,t.south,i,qot),x=ut.fromRadians(y,t.south,i,$ot),H=n.cartographicToCartesian(g,trt),j=n.cartographicToCartesian(V,NJ),X=n.cartographicToCartesian(D,ert),tt=n.cartographicToCartesian(w,bJ),B=n.cartographicToCartesian(x,irt),It=k.projectPointToNearestOnPlane(H,nrt),gt=k.projectPointToNearestOnPlane(j,srt),Yt=k.projectPointToNearestOnPlane(X,ort),Mt=k.projectPointToNearestOnPlane(tt,rrt),Ct=k.projectPointToNearestOnPlane(B,art);return o=Math.min(gt.x,Yt.x,Mt.x),r=-o,h=Math.max(gt.y,It.y),a=Math.min(Mt.y,Ct.y),V.height=w.height=e,j=n.cartographicToCartesian(V,NJ),tt=n.cartographicToCartesian(w,bJ),A=Math.min(Ki.getPointDistance(f,j),Ki.getPointDistance(f,tt)),d=i,gJ(k.origin,k.xAxis,k.yAxis,k.zAxis,o,r,a,h,A,d,s)}let E=t.south>0,_=t.north<0,R=E?t.south:_?t.north:0,I=Xt.center(t,TJ).longitude,C=l.fromRadians(I,R,i,n,Art);C.z=0;let T=Math.abs(C.x)<L.EPSILON10&&Math.abs(C.y)<L.EPSILON10?l.UNIT_X:l.normalize(C,hrt),F=l.UNIT_Z,b=l.cross(T,F,crt);f=Ki.fromPointNormal(C,T,_rt);let G=l.fromRadians(I+L.PI_OVER_TWO,R,i,n,lrt);r=l.dot(Ki.projectPointOntoPlane(f,G,drt),b),o=-r,h=l.fromRadians(0,t.north,_?e:i,n,mrt).z,a=l.fromRadians(0,t.south,E?e:i,n,frt).z;let M=l.fromRadians(t.east,R,i,n,Ert);return A=Ki.getPointDistance(f,M),d=0,gJ(C,b,F,T,o,r,a,h,A,d,s)};Gi.fromTransformation=function(t,e){return p.typeOf.object("transformation",t),m(e)||(e=new Gi),e.center=at.getTranslation(t,e.center),e.halfAxes=at.getMatrix3(t,e.halfAxes),e.halfAxes=lt.multiplyByScalar(e.halfAxes,.5,e.halfAxes),e};Gi.clone=function(t,e){if(m(t))return m(e)?(l.clone(t.center,e.center),lt.clone(t.halfAxes,e.halfAxes),e):new Gi(t.center,t.halfAxes)};Gi.intersectPlane=function(t,e){if(!m(t))throw new Y("box is required.");if(!m(e))throw new Y("plane is required.");let i=t.center,n=e.normal,s=t.halfAxes,o=n.x,r=n.y,a=n.z,h=Math.abs(o*s[lt.COLUMN0ROW0]+r*s[lt.COLUMN0ROW1]+a*s[lt.COLUMN0ROW2])+Math.abs(o*s[lt.COLUMN1ROW0]+r*s[lt.COLUMN1ROW1]+a*s[lt.COLUMN1ROW2])+Math.abs(o*s[lt.COLUMN2ROW0]+r*s[lt.COLUMN2ROW1]+a*s[lt.COLUMN2ROW2]),A=l.dot(n,i)+e.distance;return A<=-h?Nn.OUTSIDE:A>=h?Nn.INSIDE:Nn.INTERSECTING};SJ=new l,OJ=new l,VJ=new l,Rrt=new l,FJ=new l,Zrt=new l;Gi.distanceSquaredTo=function(t,e){if(!m(t))throw new Y("box is required.");if(!m(e))throw new Y("cartesian is required.");let i=l.subtract(e,t.center,YJ),n=t.halfAxes,s=lt.getColumn(n,0,SJ),o=lt.getColumn(n,1,OJ),r=lt.getColumn(n,2,VJ),a=l.magnitude(s),h=l.magnitude(o),A=l.magnitude(r),d=!0,f=!0,E=!0;a>0?l.divideByScalar(s,a,s):d=!1,h>0?l.divideByScalar(o,h,o):f=!1,A>0?l.divideByScalar(r,A,r):E=!1;let _=!d+!f+!E,R,I,C;if(_===1){let b=s;R=o,I=r,f?E||(b=r,I=s):(b=o,R=s),C=l.cross(R,I,FJ),b===s?s=C:b===o?o=C:b===r&&(r=C)}else if(_===2){R=s,f?R=o:E&&(R=r);let b=l.UNIT_Y;b.equalsEpsilon(R,L.EPSILON3)&&(b=l.UNIT_X),I=l.cross(R,b,Rrt),l.normalize(I,I),C=l.cross(R,I,FJ),l.normalize(C,C),R===s?(o=I,r=C):R===o?(r=I,s=C):R===r&&(s=I,o=C)}else _===3&&(s=l.UNIT_X,o=l.UNIT_Y,r=l.UNIT_Z);let N=Zrt;N.x=l.dot(i,s),N.y=l.dot(i,o),N.z=l.dot(i,r);let T=0,F;return N.x<-a?(F=N.x+a,T+=F*F):N.x>a&&(F=N.x-a,T+=F*F),N.y<-h?(F=N.y+h,T+=F*F):N.y>h&&(F=N.y-h,T+=F*F),N.z<-A?(F=N.z+A,T+=F*F):N.z>A&&(F=N.z-A,T+=F*F),T};Irt=new l,prt=new l;Gi.computePlaneDistances=function(t,e,i,n){if(!m(t))throw new Y("box is required.");if(!m(e))throw new Y("position is required.");if(!m(i))throw new Y("direction is required.");m(n)||(n=new cA);let s=Number.POSITIVE_INFINITY,o=Number.NEGATIVE_INFINITY,r=t.center,a=t.halfAxes,h=lt.getColumn(a,0,SJ),A=lt.getColumn(a,1,OJ),d=lt.getColumn(a,2,VJ),f=l.add(h,A,Irt);l.add(f,d,f),l.add(f,r,f);let E=l.subtract(f,e,prt),_=l.dot(i,E);return s=Math.min(_,s),o=Math.max(_,o),l.add(r,h,f),l.add(f,A,f),l.subtract(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.add(r,h,f),l.subtract(f,A,f),l.add(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.add(r,h,f),l.subtract(f,A,f),l.subtract(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.subtract(r,h,f),l.add(f,A,f),l.add(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.subtract(r,h,f),l.add(f,A,f),l.subtract(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.subtract(r,h,f),l.subtract(f,A,f),l.add(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.subtract(r,h,f),l.subtract(f,A,f),l.subtract(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),n.start=s,n.stop=o,n};urt=new l,Crt=new l,grt=new l;Gi.computeCorners=function(t,e){p.typeOf.object("box",t),m(e)||(e=[new l,new l,new l,new l,new l,new l,new l,new l]);let i=t.center,n=t.halfAxes,s=lt.getColumn(n,0,urt),o=lt.getColumn(n,1,Crt),r=lt.getColumn(n,2,grt);return l.clone(i,e[0]),l.subtract(e[0],s,e[0]),l.subtract(e[0],o,e[0]),l.subtract(e[0],r,e[0]),l.clone(i,e[1]),l.subtract(e[1],s,e[1]),l.subtract(e[1],o,e[1]),l.add(e[1],r,e[1]),l.clone(i,e[2]),l.subtract(e[2],s,e[2]),l.add(e[2],o,e[2]),l.subtract(e[2],r,e[2]),l.clone(i,e[3]),l.subtract(e[3],s,e[3]),l.add(e[3],o,e[3]),l.add(e[3],r,e[3]),l.clone(i,e[4]),l.add(e[4],s,e[4]),l.subtract(e[4],o,e[4]),l.subtract(e[4],r,e[4]),l.clone(i,e[5]),l.add(e[5],s,e[5]),l.subtract(e[5],o,e[5]),l.add(e[5],r,e[5]),l.clone(i,e[6]),l.add(e[6],s,e[6]),l.add(e[6],o,e[6]),l.subtract(e[6],r,e[6]),l.clone(i,e[7]),l.add(e[7],s,e[7]),l.add(e[7],o,e[7]),l.add(e[7],r,e[7]),e};Trt=new lt;Gi.computeTransformation=function(t,e){p.typeOf.object("box",t),m(e)||(e=new at);let i=t.center,n=lt.multiplyByUniformScale(t.halfAxes,2,Trt);return at.fromRotationTranslation(n,i,e)};Nrt=new Nt;Gi.isOccluded=function(t,e){if(!m(t))throw new Y("box is required.");if(!m(e))throw new Y("occluder is required.");let i=Nt.fromOrientedBoundingBox(t,Nrt);return!e.isBoundingSphereVisible(i)};Gi.prototype.intersectPlane=function(t){return Gi.intersectPlane(this,t)};Gi.prototype.distanceSquaredTo=function(t){return Gi.distanceSquaredTo(this,t)};Gi.prototype.computePlaneDistances=function(t,e,i){return Gi.computePlaneDistances(this,t,e,i)};Gi.prototype.computeCorners=function(t){return Gi.computeCorners(this,t)};Gi.prototype.computeTransformation=function(t){return Gi.computeTransformation(this,t)};Gi.prototype.isOccluded=function(t){return Gi.isOccluded(this,t)};Gi.equals=function(t,e){return t===e||m(t)&&m(e)&&l.equals(t.center,e.center)&&lt.equals(t.halfAxes,e.halfAxes)};Gi.prototype.clone=function(t){return Gi.clone(this,t)};Gi.prototype.equals=function(t){return Gi.equals(this,t)};zs=Gi});var sp,brt,A_,hb=O(()=>{Ht();ri();Vt();mt();sp={};sp.getHeight=function(t,e,i){if(!Number.isFinite(e))throw new Y("scale must be a finite number.");if(!Number.isFinite(i))throw new Y("relativeHeight must be a finite number.");return(t-i)*e+i};brt=new ut;sp.getPosition=function(t,e,i,n,s){let o=e.cartesianToCartographic(t,brt);if(!m(o))return l.clone(t,s);let r=sp.getHeight(o.height,i,n);return l.fromRadians(o.longitude,o.latitude,r,e,s)};A_=sp});function qm(t,e,i,n){t=Z(t,1),e=Z(e,1),i=Z(i,1),n=Z(n,1),this.value=new Uint8Array([Zt.floatToByte(t),Zt.floatToByte(e),Zt.floatToByte(i),Zt.floatToByte(n)])}var GJ,BJ=O(()=>{Qn();oi();bt();mt();Vt();Object.defineProperties(qm.prototype,{componentDatatype:{get:function(){return At.UNSIGNED_BYTE}},componentsPerAttribute:{get:function(){return 4}},normalize:{get:function(){return!0}}});qm.fromColor=function(t){if(!m(t))throw new Y("color is required.");return new qm(t.red,t.green,t.blue,t.alpha)};qm.toValue=function(t,e){if(!m(t))throw new Y("color is required.");return m(e)?t.toBytes(e):new Uint8Array(t.toBytes())};qm.equals=function(t,e){return t===e||m(t)&&m(e)&&t.value[0]===e.value[0]&&t.value[1]===e.value[1]&&t.value[2]===e.value[2]&&t.value[3]===e.value[3]};GJ=qm});var WJ,DJ=O(()=>{WJ=`in vec3 position3DHigh;
in vec3 position3DLow;
in float batchId;

#ifdef EXTRUDED_GEOMETRY
in vec3 extrudeDirection;

uniform float u_globeMinimumAltitude;
#endif // EXTRUDED_GEOMETRY

#ifdef PER_INSTANCE_COLOR
out vec4 v_color;
#endif // PER_INSTANCE_COLOR

#ifdef TEXTURE_COORDINATES
#ifdef SPHERICAL
out vec4 v_sphericalExtents;
#else // SPHERICAL
out vec2 v_inversePlaneExtents;
out vec4 v_westPlane;
out vec4 v_southPlane;
#endif // SPHERICAL
out vec3 v_uvMinAndSphericalLongitudeRotation;
out vec3 v_uMaxAndInverseDistance;
out vec3 v_vMaxAndInverseDistance;
#endif // TEXTURE_COORDINATES

void main()
{
    vec4 position = czm_computePosition();

#ifdef EXTRUDED_GEOMETRY
    float delta = min(u_globeMinimumAltitude, czm_geometricToleranceOverMeter * length(position.xyz));
    delta *= czm_sceneMode == czm_sceneMode3D ? 1.0 : 0.0;

    //extrudeDirection is zero for the top layer
    position = position + vec4(extrudeDirection * delta, 0.0);
#endif

#ifdef TEXTURE_COORDINATES
#ifdef SPHERICAL
    v_sphericalExtents = czm_batchTable_sphericalExtents(batchId);
    v_uvMinAndSphericalLongitudeRotation.z = czm_batchTable_longitudeRotation(batchId);
#else // SPHERICAL
#ifdef COLUMBUS_VIEW_2D
    vec4 planes2D_high = czm_batchTable_planes2D_HIGH(batchId);
    vec4 planes2D_low = czm_batchTable_planes2D_LOW(batchId);

    // If the primitive is split across the IDL (planes2D_high.x > planes2D_high.w):
    // - If this vertex is on the east side of the IDL (position3DLow.y > 0.0, comparison with position3DHigh may produce artifacts)
    // - existing "east" is on the wrong side of the world, far away (planes2D_high/low.w)
    // - so set "east" as beyond the eastmost extent of the projection (idlSplitNewPlaneHiLow)
    vec2 idlSplitNewPlaneHiLow = vec2(EAST_MOST_X_HIGH - (WEST_MOST_X_HIGH - planes2D_high.w), EAST_MOST_X_LOW - (WEST_MOST_X_LOW - planes2D_low.w));
    bool idlSplit = planes2D_high.x > planes2D_high.w && position3DLow.y > 0.0;
    planes2D_high.w = czm_branchFreeTernary(idlSplit, idlSplitNewPlaneHiLow.x, planes2D_high.w);
    planes2D_low.w = czm_branchFreeTernary(idlSplit, idlSplitNewPlaneHiLow.y, planes2D_low.w);

    // - else, if this vertex is on the west side of the IDL (position3DLow.y < 0.0)
    // - existing "west" is on the wrong side of the world, far away (planes2D_high/low.x)
    // - so set "west" as beyond the westmost extent of the projection (idlSplitNewPlaneHiLow)
    idlSplit = planes2D_high.x > planes2D_high.w && position3DLow.y < 0.0;
    idlSplitNewPlaneHiLow = vec2(WEST_MOST_X_HIGH - (EAST_MOST_X_HIGH - planes2D_high.x), WEST_MOST_X_LOW - (EAST_MOST_X_LOW - planes2D_low.x));
    planes2D_high.x = czm_branchFreeTernary(idlSplit, idlSplitNewPlaneHiLow.x, planes2D_high.x);
    planes2D_low.x = czm_branchFreeTernary(idlSplit, idlSplitNewPlaneHiLow.y, planes2D_low.x);

    vec3 southWestCorner = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(vec3(0.0, planes2D_high.xy), vec3(0.0, planes2D_low.xy))).xyz;
    vec3 northWestCorner = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(vec3(0.0, planes2D_high.x, planes2D_high.z), vec3(0.0, planes2D_low.x, planes2D_low.z))).xyz;
    vec3 southEastCorner = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(vec3(0.0, planes2D_high.w, planes2D_high.y), vec3(0.0, planes2D_low.w, planes2D_low.y))).xyz;
#else // COLUMBUS_VIEW_2D
    // 3D case has smaller "plane extents," so planes encoded as a 64 bit position and 2 vec3s for distances/direction
    vec3 southWestCorner = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(czm_batchTable_southWest_HIGH(batchId), czm_batchTable_southWest_LOW(batchId))).xyz;
    vec3 northWestCorner = czm_normal * czm_batchTable_northward(batchId) + southWestCorner;
    vec3 southEastCorner = czm_normal * czm_batchTable_eastward(batchId) + southWestCorner;
#endif // COLUMBUS_VIEW_2D

    vec3 eastWard = southEastCorner - southWestCorner;
    float eastExtent = length(eastWard);
    eastWard /= eastExtent;

    vec3 northWard = northWestCorner - southWestCorner;
    float northExtent = length(northWard);
    northWard /= northExtent;

    v_westPlane = vec4(eastWard, -dot(eastWard, southWestCorner));
    v_southPlane = vec4(northWard, -dot(northWard, southWestCorner));
    v_inversePlaneExtents = vec2(1.0 / eastExtent, 1.0 / northExtent);
#endif // SPHERICAL
    vec4 uvMinAndExtents = czm_batchTable_uvMinAndExtents(batchId);
    vec4 uMaxVmax = czm_batchTable_uMaxVmax(batchId);

    v_uMaxAndInverseDistance = vec3(uMaxVmax.xy, uvMinAndExtents.z);
    v_vMaxAndInverseDistance = vec3(uMaxVmax.zw, uvMinAndExtents.w);
    v_uvMinAndSphericalLongitudeRotation.xy = uvMinAndExtents.xy;
#endif // TEXTURE_COORDINATES

#ifdef PER_INSTANCE_COLOR
    v_color = czm_batchTable_color(batchId);
#endif

    gl_Position = czm_depthClamp(czm_modelViewProjectionRelativeToEye * position);
}
`});var MJ,UJ=O(()=>{MJ=`#ifdef VECTOR_TILE
uniform vec4 u_highlightColor;
#endif

void main(void)
{
#ifdef VECTOR_TILE
    out_FragColor = czm_gammaCorrect(u_highlightColor);
#else
    out_FragColor = vec4(1.0);
#endif
    czm_writeDepthClamp();
}
`});var QJ,kJ=O(()=>{QJ=`in vec3 v_positionEC;
in vec3 v_normalEC;
in vec4 v_color;

void main()
{
    vec3 positionToEyeEC = -v_positionEC;

    vec3 normalEC = normalize(v_normalEC);
#ifdef FACE_FORWARD
    normalEC = faceforward(normalEC, vec3(0.0, 0.0, 1.0), -normalEC);
#endif

    vec4 color = czm_gammaCorrect(v_color);

    czm_materialInput materialInput;
    materialInput.normalEC = normalEC;
    materialInput.positionToEyeEC = positionToEyeEC;
    czm_material material = czm_getDefaultMaterial(materialInput);
    material.diffuse = color.rgb;
    material.alpha = color.a;

    out_FragColor = czm_phong(normalize(positionToEyeEC), material, czm_lightDirectionEC);
}
`});var LJ,yJ=O(()=>{LJ=`in vec3 position3DHigh;
in vec3 position3DLow;
in vec3 normal;
in vec4 color;
in float batchId;

out vec3 v_positionEC;
out vec3 v_normalEC;
out vec4 v_color;

void main()
{
    vec4 p = czm_computePosition();

    v_positionEC = (czm_modelViewRelativeToEye * p).xyz;      // position in eye coordinates
    v_normalEC = czm_normal * normal;                         // normal in eye coordinates
    v_color = color;

    gl_Position = czm_modelViewProjectionRelativeToEye * p;
}
`});var wJ,xJ=O(()=>{wJ=`in vec3 position3DHigh;
in vec3 position3DLow;
in vec4 color;
in float batchId;

out vec4 v_color;

void main()
{
    vec4 p = czm_computePosition();

    v_color = color;

    gl_Position = czm_modelViewProjectionRelativeToEye * p;
}
`});function uh(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.translucent,!0),i=Z(t.closed,!1),n=Z(t.flat,!1),s=n?wJ:LJ,o=n?QI:QJ,r=n?uh.FLAT_VERTEX_FORMAT:uh.VERTEX_FORMAT;this.material=void 0,this.translucent=e,this._vertexShaderSource=Z(t.vertexShaderSource,s),this._fragmentShaderSource=Z(t.fragmentShaderSource,o),this._renderState=Uo.getDefaultRenderState(e,i,t.renderState),this._closed=i,this._vertexFormat=r,this._flat=n,this._faceForward=Z(t.faceForward,!i)}var Da,op=O(()=>{bt();Ls();kJ();yJ();GN();xJ();LI();Object.defineProperties(uh.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},vertexFormat:{get:function(){return this._vertexFormat}},flat:{get:function(){return this._flat}},faceForward:{get:function(){return this._faceForward}}});uh.VERTEX_FORMAT=Ot.POSITION_AND_NORMAL;uh.FLAT_VERTEX_FORMAT=Ot.POSITION_ONLY;uh.prototype.getFragmentShaderSource=Uo.prototype.getFragmentShaderSource;uh.prototype.isTranslucent=Uo.prototype.isTranslucent;uh.prototype.getRenderState=Uo.prototype.getRenderState;Da=uh});var cb,PJ=O(()=>{cb=`#ifdef TEXTURE_COORDINATES
#ifdef SPHERICAL
in vec4 v_sphericalExtents;
#else // SPHERICAL
in vec2 v_inversePlaneExtents;
in vec4 v_westPlane;
in vec4 v_southPlane;
#endif // SPHERICAL
in vec3 v_uvMinAndSphericalLongitudeRotation;
in vec3 v_uMaxAndInverseDistance;
in vec3 v_vMaxAndInverseDistance;
#endif // TEXTURE_COORDINATES

#ifdef PER_INSTANCE_COLOR
in vec4 v_color;
#endif

#ifdef NORMAL_EC
vec3 getEyeCoordinate3FromWindowCoordinate(vec2 fragCoord, float logDepthOrDepth) {
    vec4 eyeCoordinate = czm_windowToEyeCoordinates(fragCoord, logDepthOrDepth);
    return eyeCoordinate.xyz / eyeCoordinate.w;
}

vec3 vectorFromOffset(vec4 eyeCoordinate, vec2 positiveOffset) {
    vec2 glFragCoordXY = gl_FragCoord.xy;
    // Sample depths at both offset and negative offset
    float upOrRightLogDepth = czm_unpackDepth(texture(czm_globeDepthTexture, (glFragCoordXY + positiveOffset) / czm_viewport.zw));
    float downOrLeftLogDepth = czm_unpackDepth(texture(czm_globeDepthTexture, (glFragCoordXY - positiveOffset) / czm_viewport.zw));
    // Explicitly evaluate both paths
    // Necessary for multifrustum and for edges of the screen
    bvec2 upOrRightInBounds = lessThan(glFragCoordXY + positiveOffset, czm_viewport.zw);
    float useUpOrRight = float(upOrRightLogDepth > 0.0 && upOrRightInBounds.x && upOrRightInBounds.y);
    float useDownOrLeft = float(useUpOrRight == 0.0);
    vec3 upOrRightEC = getEyeCoordinate3FromWindowCoordinate(glFragCoordXY + positiveOffset, upOrRightLogDepth);
    vec3 downOrLeftEC = getEyeCoordinate3FromWindowCoordinate(glFragCoordXY - positiveOffset, downOrLeftLogDepth);
    return (upOrRightEC - (eyeCoordinate.xyz / eyeCoordinate.w)) * useUpOrRight + ((eyeCoordinate.xyz / eyeCoordinate.w) - downOrLeftEC) * useDownOrLeft;
}
#endif // NORMAL_EC

void main(void)
{
#ifdef REQUIRES_EC
    float logDepthOrDepth = czm_unpackDepth(texture(czm_globeDepthTexture, gl_FragCoord.xy / czm_viewport.zw));
    vec4 eyeCoordinate = czm_windowToEyeCoordinates(gl_FragCoord.xy, logDepthOrDepth);
#endif

#ifdef REQUIRES_WC
    vec4 worldCoordinate4 = czm_inverseView * eyeCoordinate;
    vec3 worldCoordinate = worldCoordinate4.xyz / worldCoordinate4.w;
#endif

#ifdef TEXTURE_COORDINATES
    vec2 uv;
#ifdef SPHERICAL
    // Treat world coords as a sphere normal for spherical coordinates
    vec2 sphericalLatLong = czm_approximateSphericalCoordinates(worldCoordinate);
    sphericalLatLong.y += v_uvMinAndSphericalLongitudeRotation.z;
    sphericalLatLong.y = czm_branchFreeTernary(sphericalLatLong.y < czm_pi, sphericalLatLong.y, sphericalLatLong.y - czm_twoPi);
    uv.x = (sphericalLatLong.y - v_sphericalExtents.y) * v_sphericalExtents.w;
    uv.y = (sphericalLatLong.x - v_sphericalExtents.x) * v_sphericalExtents.z;
#else // SPHERICAL
    // Unpack planes and transform to eye space
    uv.x = czm_planeDistance(v_westPlane, eyeCoordinate.xyz / eyeCoordinate.w) * v_inversePlaneExtents.x;
    uv.y = czm_planeDistance(v_southPlane, eyeCoordinate.xyz / eyeCoordinate.w) * v_inversePlaneExtents.y;
#endif // SPHERICAL
#endif // TEXTURE_COORDINATES

#ifdef PICK
#ifdef CULL_FRAGMENTS
    // When classifying translucent geometry, logDepthOrDepth == 0.0
    // indicates a region that should not be classified, possibly due to there
    // being opaque pixels there in another buffer.
    // Check for logDepthOrDepth != 0.0 to make sure this should be classified.
    if (0.0 <= uv.x && uv.x <= 1.0 && 0.0 <= uv.y && uv.y <= 1.0 || logDepthOrDepth != 0.0) {
        out_FragColor.a = 1.0; // 0.0 alpha leads to discard from ShaderSource.createPickFragmentShaderSource
        czm_writeDepthClamp();
    }
#else // CULL_FRAGMENTS
        out_FragColor.a = 1.0;
#endif // CULL_FRAGMENTS
#else // PICK

#ifdef CULL_FRAGMENTS
    // When classifying translucent geometry, logDepthOrDepth == 0.0
    // indicates a region that should not be classified, possibly due to there
    // being opaque pixels there in another buffer.
    if (uv.x <= 0.0 || 1.0 <= uv.x || uv.y <= 0.0 || 1.0 <= uv.y || logDepthOrDepth == 0.0) {
        discard;
    }
#endif

#ifdef NORMAL_EC
    // Compute normal by sampling adjacent pixels in 2x2 block in screen space
    vec3 downUp = vectorFromOffset(eyeCoordinate, vec2(0.0, 1.0));
    vec3 leftRight = vectorFromOffset(eyeCoordinate, vec2(1.0, 0.0));
    vec3 normalEC = normalize(cross(leftRight, downUp));
#endif


#ifdef PER_INSTANCE_COLOR

    vec4 color = czm_gammaCorrect(v_color);
#ifdef FLAT
    out_FragColor = color;
#else // FLAT
    czm_materialInput materialInput;
    materialInput.normalEC = normalEC;
    materialInput.positionToEyeEC = -eyeCoordinate.xyz;
    czm_material material = czm_getDefaultMaterial(materialInput);
    material.diffuse = color.rgb;
    material.alpha = color.a;

    out_FragColor = czm_phong(normalize(-eyeCoordinate.xyz), material, czm_lightDirectionEC);
#endif // FLAT

    // Premultiply alpha. Required for classification primitives on translucent globe.
    out_FragColor.rgb *= out_FragColor.a;

#else // PER_INSTANCE_COLOR

    // Material support.
    // USES_ is distinct from REQUIRES_, because some things are dependencies of each other or
    // dependencies for culling but might not actually be used by the material.

    czm_materialInput materialInput;

#ifdef USES_NORMAL_EC
    materialInput.normalEC = normalEC;
#endif

#ifdef USES_POSITION_TO_EYE_EC
    materialInput.positionToEyeEC = -eyeCoordinate.xyz;
#endif

#ifdef USES_TANGENT_TO_EYE
    materialInput.tangentToEyeMatrix = czm_eastNorthUpToEyeCoordinates(worldCoordinate, normalEC);
#endif

#ifdef USES_ST
    // Remap texture coordinates from computed (approximately aligned with cartographic space) to the desired
    // texture coordinate system, which typically forms a tight oriented bounding box around the geometry.
    // Shader is provided a set of reference points for remapping.
    materialInput.st.x = czm_lineDistance(v_uvMinAndSphericalLongitudeRotation.xy, v_uMaxAndInverseDistance.xy, uv) * v_uMaxAndInverseDistance.z;
    materialInput.st.y = czm_lineDistance(v_uvMinAndSphericalLongitudeRotation.xy, v_vMaxAndInverseDistance.xy, uv) * v_vMaxAndInverseDistance.z;
#endif

    czm_material material = czm_getMaterial(materialInput);

#ifdef FLAT
    out_FragColor = vec4(material.diffuse + material.emission, material.alpha);
#else // FLAT
    out_FragColor = czm_phong(normalize(-eyeCoordinate.xyz), material, czm_lightDirectionEC);
#endif // FLAT

    // Premultiply alpha. Required for classification primitives on translucent globe.
    out_FragColor.rgb *= out_FragColor.a;

#endif // PER_INSTANCE_COLOR
    czm_writeDepthClamp();
#endif // PICK
}
`});function vr(t,e,i){p.typeOf.bool("extentsCulling",t),p.typeOf.bool("planarExtents",e),p.typeOf.object("appearance",i),this._projectionExtentDefines={eastMostYhighDefine:"",eastMostYlowDefine:"",westMostYhighDefine:"",westMostYlowDefine:""};let n=new lb;n.requiresTextureCoordinates=t,n.requiresEC=!i.flat;let s=new lb;if(s.requiresTextureCoordinates=t,i instanceof Da)n.requiresNormalEC=!i.flat;else{let o=`${i.material.shaderSource}
${i.fragmentShaderSource}`;n.normalEC=o.indexOf("materialInput.normalEC")!==-1||o.indexOf("czm_getDefaultMaterial")!==-1,n.positionToEyeEC=o.indexOf("materialInput.positionToEyeEC")!==-1,n.tangentToEyeMatrix=o.indexOf("materialInput.tangentToEyeMatrix")!==-1,n.st=o.indexOf("materialInput.st")!==-1}this._colorShaderDependencies=n,this._pickShaderDependencies=s,this._appearance=i,this._extentsCulling=t,this._planarExtents=e}function qJ(t,e,i,n,s,o,r,a){let h=n.slice();if(a.eastMostYhighDefine===""){let A=jJ;A.longitude=L.PI,A.latitude=0,A.height=0;let d=r.project(A,JJ),f=Bn.encode(d.x,HJ);a.eastMostYhighDefine=`EAST_MOST_X_HIGH ${f.high.toFixed(`${f.high}`.length+1)}`,a.eastMostYlowDefine=`EAST_MOST_X_LOW ${f.low.toFixed(`${f.low}`.length+1)}`;let E=jJ;E.longitude=-L.PI,E.latitude=0,E.height=0;let _=r.project(E,JJ);f=Bn.encode(_.x,HJ),a.westMostYhighDefine=`WEST_MOST_X_HIGH ${f.high.toFixed(`${f.high}`.length+1)}`,a.westMostYlowDefine=`WEST_MOST_X_LOW ${f.low.toFixed(`${f.low}`.length+1)}`}return i&&(h.push(a.eastMostYhighDefine),h.push(a.eastMostYlowDefine),h.push(a.westMostYhighDefine),h.push(a.westMostYlowDefine)),m(o)&&o instanceof Da&&h.push("PER_INSTANCE_COLOR"),t.requiresTextureCoordinates&&(h.push("TEXTURE_COORDINATES"),e||i||h.push("SPHERICAL"),i&&h.push("COLUMBUS_VIEW_2D")),new Mi({defines:h,sources:[s]})}function lb(){this._requiresEC=!1,this._requiresWC=!1,this._requiresNormalEC=!1,this._requiresTextureCoordinates=!1,this._usesNormalEC=!1,this._usesPositionToEyeEC=!1,this._usesTangentToEyeMat=!1,this._usesSt=!1}function vJ(t,e,i){return Math.abs((e.y-t.y)*i.x-(e.x-t.x)*i.y+e.x*t.y-e.y*t.x)/nt.distance(e,t)}function $J(t,e){let i=Frt,n=nt.unpack(e,0,i[0]),s=nt.unpack(e,2,i[1]),o=nt.unpack(e,4,i[2]);t.uMaxVmax=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,value:[s.x,s.y,o.x,o.y]});let r=1/vJ(n,s,o),a=1/vJ(n,o,s);t.uvMinAndExtents=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,value:[n.x,n.y,r,a]})}function ij(t,e,i){let n=tj;n.height=0,n.longitude=t.west,n.latitude=t.south;let s=e.project(n,ej);n.latitude=t.north;let o=e.project(n,Yrt);n.longitude=t.east,n.latitude=t.south;let r=e.project(n,Srt),a=[0,0,0,0],h=[0,0,0,0],A=Bn.encode(s.x,rp);a[0]=A.high,h[0]=A.low,A=Bn.encode(s.y,rp),a[1]=A.high,h[1]=A.low,A=Bn.encode(o.y,rp),a[2]=A.high,h[2]=A.low,A=Bn.encode(r.x,rp),a[3]=A.high,h[3]=A.low,i.planes2D_HIGH=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,value:a}),i.planes2D_LOW=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,value:h})}function Wrt(t,e,i,n,s,o){let r=Xt.center(t,Grt);r.height=i;let a=ut.toCartesian(r,e,zJ),h=In.eastNorthUpToFixedFrame(a,e,Ort),A=at.inverse(h,Vrt),d=t.west,f=t.east,E=t.north,_=t.south,R=Brt;R[0].latitude=_,R[0].longitude=d,R[1].latitude=E,R[1].longitude=d,R[2].latitude=E,R[2].longitude=f,R[3].latitude=_,R[3].longitude=f;let I=(d+f)*.5,C=(E+_)*.5;R[4].latitude=_,R[4].longitude=I,R[5].latitude=E,R[5].longitude=I,R[6].latitude=C,R[6].longitude=d,R[7].latitude=C,R[7].longitude=f;let N=Number.POSITIVE_INFINITY,T=Number.NEGATIVE_INFINITY,F=Number.POSITIVE_INFINITY,b=Number.NEGATIVE_INFINITY;for(let U=0;U<8;U++){R[U].height=i;let k=ut.toCartesian(R[U],e,zJ);at.multiplyByPoint(A,k,k),k.z=0,N=Math.min(N,k.x),T=Math.max(T,k.x),F=Math.min(F,k.y),b=Math.max(b,k.y)}let G=n;G.x=N,G.y=F,G.z=0,at.multiplyByPoint(h,G,G);let M=s;M.x=T,M.y=F,M.z=0,at.multiplyByPoint(h,M,M),l.subtract(M,G,s);let Q=o;Q.x=N,Q.y=b,Q.z=0,at.multiplyByPoint(h,Q,Q),l.subtract(Q,G,o)}function KJ(t,e,i,n){let s=tj;s.latitude=t,s.longitude=e,s.height=0;let o=ut.toCartesian(s,i,Qrt),r=Math.sqrt(o.x*o.x+o.y*o.y),a=L.fastApproximateAtan2(r,o.z),h=L.fastApproximateAtan2(o.x,o.y);return n.x=a,n.y=h,n}function krt(t){return Math.max(t.width,t.height)>vr.MAX_WIDTH_FOR_PLANAR_EXTENTS}var JJ,jJ,HJ,Frt,tj,ej,Yrt,Srt,rp,Ort,Vrt,zJ,Grt,Brt,Drt,Mrt,Urt,Qrt,XJ,gc,db=O(()=>{Xe();Ht();ri();ae();oi();bt();mt();Tl();mN();_e();Fi();pn();fr();Fl();op();PJ();vr.prototype.createFragmentShader=function(t){p.typeOf.bool("columbusView2D",t);let e=this._appearance,i=this._colorShaderDependencies,n=[];!t&&!this._planarExtents&&n.push("SPHERICAL"),i.requiresEC&&n.push("REQUIRES_EC"),i.requiresWC&&n.push("REQUIRES_WC"),i.requiresTextureCoordinates&&n.push("TEXTURE_COORDINATES"),this._extentsCulling&&n.push("CULL_FRAGMENTS"),i.requiresNormalEC&&n.push("NORMAL_EC"),e instanceof Da&&n.push("PER_INSTANCE_COLOR"),i.normalEC&&n.push("USES_NORMAL_EC"),i.positionToEyeEC&&n.push("USES_POSITION_TO_EYE_EC"),i.tangentToEyeMatrix&&n.push("USES_TANGENT_TO_EYE"),i.st&&n.push("USES_ST"),e.flat&&n.push("FLAT");let s="";return e instanceof Da||(s=e.material.shaderSource),new Mi({defines:n,sources:[s,cb]})};vr.prototype.createPickFragmentShader=function(t){p.typeOf.bool("columbusView2D",t);let e=this._pickShaderDependencies,i=["PICK"];return!t&&!this._planarExtents&&i.push("SPHERICAL"),e.requiresEC&&i.push("REQUIRES_EC"),e.requiresWC&&i.push("REQUIRES_WC"),e.requiresTextureCoordinates&&i.push("TEXTURE_COORDINATES"),this._extentsCulling&&i.push("CULL_FRAGMENTS"),new Mi({defines:i,sources:[cb],pickColorQualifier:"in"})};vr.prototype.createVertexShader=function(t,e,i,n){return p.defined("defines",t),p.typeOf.string("vertexShaderSource",e),p.typeOf.bool("columbusView2D",i),p.defined("mapProjection",n),qJ(this._colorShaderDependencies,this._planarExtents,i,t,e,this._appearance,n,this._projectionExtentDefines)};vr.prototype.createPickVertexShader=function(t,e,i,n){return p.defined("defines",t),p.typeOf.string("vertexShaderSource",e),p.typeOf.bool("columbusView2D",i),p.defined("mapProjection",n),qJ(this._pickShaderDependencies,this._planarExtents,i,t,e,void 0,n,this._projectionExtentDefines)};JJ=new l,jJ=new ut,HJ={high:0,low:0};Object.defineProperties(lb.prototype,{requiresEC:{get:function(){return this._requiresEC},set:function(t){this._requiresEC=t||this._requiresEC}},requiresWC:{get:function(){return this._requiresWC},set:function(t){this._requiresWC=t||this._requiresWC,this.requiresEC=this._requiresWC}},requiresNormalEC:{get:function(){return this._requiresNormalEC},set:function(t){this._requiresNormalEC=t||this._requiresNormalEC,this.requiresEC=this._requiresNormalEC}},requiresTextureCoordinates:{get:function(){return this._requiresTextureCoordinates},set:function(t){this._requiresTextureCoordinates=t||this._requiresTextureCoordinates,this.requiresWC=this._requiresTextureCoordinates}},normalEC:{set:function(t){this.requiresNormalEC=t,this._usesNormalEC=t},get:function(){return this._usesNormalEC}},tangentToEyeMatrix:{set:function(t){this.requiresWC=t,this.requiresNormalEC=t,this._usesTangentToEyeMat=t},get:function(){return this._usesTangentToEyeMat}},positionToEyeEC:{set:function(t){this.requiresEC=t,this._usesPositionToEyeEC=t},get:function(){return this._usesPositionToEyeEC}},st:{set:function(t){this.requiresTextureCoordinates=t,this._usesSt=t},get:function(){return this._usesSt}}});Frt=[new nt,new nt,new nt,new nt];tj=new ut,ej=new l,Yrt=new l,Srt=new l,rp={high:0,low:0};Ort=new at,Vrt=new at,zJ=new l,Grt=new ut,Brt=[new ut,new ut,new ut,new ut,new ut,new ut,new ut,new ut];Drt=new l,Mrt=new l,Urt=new Bn;vr.getPlanarTextureCoordinateAttributes=function(t,e,i,n,s){p.typeOf.object("boundingRectangle",t),p.defined("textureCoordinateRotationPoints",e),p.typeOf.object("ellipsoid",i),p.typeOf.object("projection",n);let o=ej,r=Drt,a=Mrt;Wrt(t,i,Z(s,0),o,r,a);let h={};$J(h,e);let A=Bn.fromCartesian(o,Urt);return h.southWest_HIGH=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:3,normalize:!1,value:l.pack(A.high,[0,0,0])}),h.southWest_LOW=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:3,normalize:!1,value:l.pack(A.low,[0,0,0])}),h.eastward=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:3,normalize:!1,value:l.pack(r,[0,0,0])}),h.northward=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:3,normalize:!1,value:l.pack(a,[0,0,0])}),ij(t,n,h),h};Qrt=new l;XJ=new nt;vr.getSphericalExtentGeometryInstanceAttributes=function(t,e,i,n){p.typeOf.object("boundingRectangle",t),p.defined("textureCoordinateRotationPoints",e),p.typeOf.object("ellipsoid",i),p.typeOf.object("projection",n);let s=KJ(t.south,t.west,i,XJ),o=s.x,r=s.y,a=KJ(t.north,t.east,i,XJ),h=a.x,A=a.y,d=0;r>A&&(d=L.PI-r,r=-L.PI,A+=d),o-=L.EPSILON5,r-=L.EPSILON5,h+=L.EPSILON5,A+=L.EPSILON5;let f=1/(A-r),E=1/(h-o),_={sphericalExtents:new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,value:[o,r,E,f]}),longitudeRotation:new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:1,normalize:!1,value:[d]})};return $J(_,e),ij(t,n,_),_};vr.hasAttributesForTextureCoordinatePlanes=function(t){return m(t.southWest_HIGH)&&m(t.southWest_LOW)&&m(t.northward)&&m(t.eastward)&&m(t.planes2D_HIGH)&&m(t.planes2D_LOW)&&m(t.uMaxVmax)&&m(t.uvMinAndExtents)};vr.hasAttributesForSphericalExtents=function(t){return m(t.sphericalExtents)&&m(t.longitudeRotation)&&m(t.planes2D_HIGH)&&m(t.planes2D_LOW)&&m(t.uMaxVmax)&&m(t.uvMinAndExtents)};vr.shouldUseSphericalCoordinates=function(t){return p.typeOf.object("rectangle",t),krt(t)};vr.MAX_WIDTH_FOR_PLANAR_EXTENTS=L.toRadians(1);gc=vr});function jl(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.geometryInstances;this.geometryInstances=e,this.show=Z(t.show,!0),this.classificationType=Z(t.classificationType,Jr.BOTH),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.debugShowShadowVolume=Z(t.debugShowShadowVolume,!1),this._debugShowShadowVolume=!1,this._extruded=Z(t._extruded,!1),this._uniformMap=t._uniformMap,this._sp=void 0,this._spStencil=void 0,this._spPick=void 0,this._spColor=void 0,this._spPick2D=void 0,this._spColor2D=void 0,this._rsStencilDepthPass=void 0,this._rsStencilDepthPass3DTiles=void 0,this._rsColorPass=void 0,this._rsPickPass=void 0,this._commandsIgnoreShow=[],this._ready=!1,this._primitive=void 0,this._pickPrimitive=t._pickPrimitive,this._hasSphericalExtentsAttribute=!1,this._hasPlanarExtentsAttributes=!1,this._hasPerColorAttribute=!1,this.appearance=t.appearance,this._createBoundingVolumeFunction=t._createBoundingVolumeFunction,this._updateAndQueueCommandsFunction=t._updateAndQueueCommandsFunction,this._usePickOffsets=!1,this._primitiveOptions={geometryInstances:void 0,appearance:void 0,vertexCacheOptimize:Z(t.vertexCacheOptimize,!1),interleave:Z(t.interleave,!1),releaseGeometryInstances:Z(t.releaseGeometryInstances,!0),allowPicking:Z(t.allowPicking,!0),asynchronous:Z(t.asynchronous,!0),compressVertices:Z(t.compressVertices,!0),_createBoundingVolumeFunction:void 0,_createRenderStatesFunction:void 0,_createShaderProgramFunction:void 0,_createCommandsFunction:void 0,_updateAndQueueCommandsFunction:void 0,_createPickOffsets:!0}}function $m(t,e){let i=e?pr.EQUAL:pr.ALWAYS;return{colorMask:{red:!1,green:!1,blue:!1,alpha:!1},stencilTest:{enabled:t,frontFunction:i,frontOperation:{fail:Hi.KEEP,zFail:Hi.DECREMENT_WRAP,zPass:Hi.KEEP},backFunction:i,backOperation:{fail:Hi.KEEP,zFail:Hi.INCREMENT_WRAP,zPass:Hi.KEEP},reference:Wa.CESIUM_3D_TILE_MASK,mask:Wa.CESIUM_3D_TILE_MASK},stencilMask:Wa.CLASSIFICATION_MASK,depthTest:{enabled:!0,func:wI.LESS_OR_EQUAL},depthMask:!1}}function fb(t){return{stencilTest:{enabled:t,frontFunction:pr.NOT_EQUAL,frontOperation:{fail:Hi.ZERO,zFail:Hi.ZERO,zPass:Hi.ZERO},backFunction:pr.NOT_EQUAL,backOperation:{fail:Hi.ZERO,zFail:Hi.ZERO,zPass:Hi.ZERO},reference:0,mask:Wa.CLASSIFICATION_MASK},stencilMask:Wa.CLASSIFICATION_MASK,depthTest:{enabled:!1},depthMask:!1,blending:Ur.PRE_MULTIPLIED_ALPHA_BLEND}}function yrt(t,e,i,n){if(m(t._rsStencilDepthPass))return;let s=!t.debugShowShadowVolume;t._rsStencilDepthPass=Yn.fromCache($m(s,!1)),t._rsStencilDepthPass3DTiles=Yn.fromCache($m(s,!0)),t._rsColorPass=Yn.fromCache(fb(s,!1)),t._rsPickPass=Yn.fromCache(Lrt)}function wrt(t,e){if(!t.compressVertices)return e;if(e.search(/in\s+vec3\s+extrudeDirection;/g)!==-1){let i="compressedAttributes",n=`in vec2 ${i};`,s=`vec3 extrudeDirection;
`,o=`    extrudeDirection = czm_octDecode(${i}, 65535.0);
`,r=e;r=r.replace(/in\s+vec3\s+extrudeDirection;/g,""),r=Mi.replaceMain(r,"czm_non_compressed_main");let a=`void main() 
{ 
${o}    czm_non_compressed_main(); 
}`;return[n,s,r,a].join(`
`)}}function xrt(t,e){let i=e.context,n=t._primitive,s=WJ;s=t._primitive._batchTable.getVertexShaderCallback()(s),s=vs._appendDistanceDisplayConditionToShader(n,s),s=vs._modifyShaderPosition(t,s,e.scene3DOnly),s=vs._updateColorAttribute(n,s);let o=t._hasPlanarExtentsAttributes,r=o||t._hasSphericalExtentsAttribute;t._extruded&&(s=wrt(n,s));let a=t._extruded?"EXTRUDED_GEOMETRY":"",h=new Mi({defines:[a],sources:[s]}),A=new Mi({sources:[MJ]}),d=t._primitive._attributeLocations,f=new gc(r,o,t.appearance);if(t._spStencil=Es.replaceCache({context:i,shaderProgram:t._spStencil,vertexShaderSource:h,fragmentShaderSource:A,attributeLocations:d}),t._primitive.allowPicking){let R=Mi.createPickVertexShaderSource(s);R=vs._appendShowToShader(n,R),R=vs._updatePickColorAttribute(R);let I=f.createPickFragmentShader(!1),C=f.createPickVertexShader([a],R,!1,e.mapProjection);if(t._spPick=Es.replaceCache({context:i,shaderProgram:t._spPick,vertexShaderSource:C,fragmentShaderSource:I,attributeLocations:d}),r){let N=i.shaderCache.getDerivedShaderProgram(t._spPick,"2dPick");if(!m(N)){let T=f.createPickFragmentShader(!0),F=f.createPickVertexShader([a],R,!0,e.mapProjection);N=i.shaderCache.createDerivedShaderProgram(t._spPick,"2dPick",{vertexShaderSource:F,fragmentShaderSource:T,attributeLocations:d})}t._spPick2D=N}}else t._spPick=Es.fromCache({context:i,vertexShaderSource:h,fragmentShaderSource:A,attributeLocations:d});s=vs._appendShowToShader(n,s),h=new Mi({defines:[a],sources:[s]}),t._sp=Es.replaceCache({context:i,shaderProgram:t._sp,vertexShaderSource:h,fragmentShaderSource:A,attributeLocations:d});let E=f.createFragmentShader(!1),_=f.createVertexShader([a],s,!1,e.mapProjection);if(t._spColor=Es.replaceCache({context:i,shaderProgram:t._spColor,vertexShaderSource:_,fragmentShaderSource:E,attributeLocations:d}),r){let R=i.shaderCache.getDerivedShaderProgram(t._spColor,"2dColor");if(!m(R)){let I=f.createFragmentShader(!0),C=f.createVertexShader([a],s,!0,e.mapProjection);R=i.shaderCache.createDerivedShaderProgram(t._spColor,"2dColor",{vertexShaderSource:C,fragmentShaderSource:I,attributeLocations:d})}t._spColor2D=R}}function Prt(t,e){let i=t._primitive,n=i._va.length*2;e.length=n;let s,o,r,a=0,h=i._batchTable.getUniformMapCallback()(t._uniformMap),A=t._needs2DShader;for(s=0;s<n;s+=2){let _=i._va[a++];o=e[s],m(o)||(o=e[s]=new fn({owner:t,primitiveType:i._primitiveType})),o.vertexArray=_,o.renderState=t._rsStencilDepthPass,o.shaderProgram=t._sp,o.uniformMap=h,o.pass=os.TERRAIN_CLASSIFICATION,r=fn.shallowClone(o,o.derivedCommands.tileset),r.renderState=t._rsStencilDepthPass3DTiles,r.pass=os.CESIUM_3D_TILE_CLASSIFICATION,o.derivedCommands.tileset=r,o=e[s+1],m(o)||(o=e[s+1]=new fn({owner:t,primitiveType:i._primitiveType})),o.vertexArray=_,o.renderState=t._rsColorPass,o.shaderProgram=t._spColor,o.pass=os.TERRAIN_CLASSIFICATION;let I=t.appearance.material;if(m(I)&&(h=es(h,I._uniforms)),o.uniformMap=h,r=fn.shallowClone(o,o.derivedCommands.tileset),r.pass=os.CESIUM_3D_TILE_CLASSIFICATION,o.derivedCommands.tileset=r,A){let C=fn.shallowClone(o,o.derivedCommands.appearance2D);C.shaderProgram=t._spColor2D,o.derivedCommands.appearance2D=C,C=fn.shallowClone(r,r.derivedCommands.appearance2D),C.shaderProgram=t._spColor2D,r.derivedCommands.appearance2D=C}}let d=t._commandsIgnoreShow,f=t._spStencil,E=0;n=d.length=n/2;for(let _=0;_<n;++_){let R=d[_]=fn.shallowClone(e[E],d[_]);R.shaderProgram=f,R.pass=os.CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW,E+=2}}function Jrt(t,e){let i=t._usePickOffsets,n=t._primitive,s=n._va.length*2,o,r=0,a;i&&(o=n._pickOffsets,s=o.length*2),e.length=s;let h,A,d,f=0,E=n._batchTable.getUniformMapCallback()(t._uniformMap),_=t._needs2DShader;for(h=0;h<s;h+=2){let R=n._va[f++];if(i&&(a=o[r++],R=n._va[a.index]),A=e[h],m(A)||(A=e[h]=new fn({owner:t,primitiveType:n._primitiveType,pickOnly:!0})),A.vertexArray=R,A.renderState=t._rsStencilDepthPass,A.shaderProgram=t._sp,A.uniformMap=E,A.pass=os.TERRAIN_CLASSIFICATION,i&&(A.offset=a.offset,A.count=a.count),d=fn.shallowClone(A,A.derivedCommands.tileset),d.renderState=t._rsStencilDepthPass3DTiles,d.pass=os.CESIUM_3D_TILE_CLASSIFICATION,A.derivedCommands.tileset=d,A=e[h+1],m(A)||(A=e[h+1]=new fn({owner:t,primitiveType:n._primitiveType,pickOnly:!0})),A.vertexArray=R,A.renderState=t._rsPickPass,A.shaderProgram=t._spPick,A.uniformMap=E,A.pass=os.TERRAIN_CLASSIFICATION,i&&(A.offset=a.offset,A.count=a.count),d=fn.shallowClone(A,A.derivedCommands.tileset),d.pass=os.CESIUM_3D_TILE_CLASSIFICATION,A.derivedCommands.tileset=d,_){let I=fn.shallowClone(A,A.derivedCommands.pick2D);I.shaderProgram=t._spPick2D,A.derivedCommands.pick2D=I,I=fn.shallowClone(d,d.derivedCommands.pick2D),I.shaderProgram=t._spPick2D,d.derivedCommands.pick2D=I}}}function jrt(t,e,i,n,s,o,r){Prt(t,o),Jrt(t,r)}function nj(t,e){return Math.floor(t%e/2)}function mb(t,e,i,n,s,o){t.modelMatrix=i,t.boundingVolume=s,t.cull=n,t.debugShowBoundingVolume=o,e.commandList.push(t)}function sj(t,e,i,n,s){t.modelMatrix=i,t.boundingVolume=s,t.cull=n,e.commandList.push(t)}function Hrt(t,e,i,n,s,o,r,a){let h=t._primitive;vs._updateBoundingVolumes(h,e,s);let A;e.mode===ye.SCENE3D?A=h._boundingSphereWC:e.mode===ye.COLUMBUS_VIEW?A=h._boundingSphereCV:e.mode===ye.SCENE2D&&m(h._boundingSphere2D)?A=h._boundingSphere2D:m(h._boundingSphereMorph)&&(A=h._boundingSphereMorph);let d=t.classificationType,f=d!==Jr.CESIUM_3D_TILE,E=d!==Jr.TERRAIN,_=e.passes,R,I,C;if(_.render){let N=i.length;for(R=0;R<N;++R)I=A[nj(R,N)],f&&(C=i[R],mb(C,e,s,o,I,r)),E&&(C=i[R].derivedCommands.tileset,mb(C,e,s,o,I,r));if(e.invertClassification){let T=t._commandsIgnoreShow,F=T.length;for(R=0;R<F;++R)I=A[R],C=T[R],mb(C,e,s,o,I,r)}}if(_.pick){let N=n.length,T=h._pickOffsets;for(R=0;R<N;++R){let F=T[nj(R,N)];I=A[F.index],f&&(C=n[R],sj(C,e,s,o,I)),E&&(C=n[R].derivedCommands.tileset,sj(C,e,s,o,I))}}}var Lrt,Eb,oj=O(()=>{BJ();KA();bt();mt();Ws();Vt();uA();Bm();Wm();Mm();Qm();Fl();DJ();UJ();km();MI();PN();op();rb();ua();db();ab();$I();tp();Object.defineProperties(jl.prototype,{vertexCacheOptimize:{get:function(){return this._primitiveOptions.vertexCacheOptimize}},interleave:{get:function(){return this._primitiveOptions.interleave}},releaseGeometryInstances:{get:function(){return this._primitiveOptions.releaseGeometryInstances}},allowPicking:{get:function(){return this._primitiveOptions.allowPicking}},asynchronous:{get:function(){return this._primitiveOptions.asynchronous}},compressVertices:{get:function(){return this._primitiveOptions.compressVertices}},ready:{get:function(){return this._ready}},_needs2DShader:{get:function(){return this._hasPlanarExtentsAttributes||this._hasSphericalExtentsAttribute}}});jl.isSupported=function(t){return t.context.stencilBuffer};Lrt={stencilTest:{enabled:!0,frontFunction:pr.NOT_EQUAL,frontOperation:{fail:Hi.ZERO,zFail:Hi.ZERO,zPass:Hi.ZERO},backFunction:pr.NOT_EQUAL,backOperation:{fail:Hi.ZERO,zFail:Hi.ZERO,zPass:Hi.ZERO},reference:0,mask:Wa.CLASSIFICATION_MASK},stencilMask:Wa.CLASSIFICATION_MASK,depthTest:{enabled:!1},depthMask:!1};jl.prototype.update=function(t){if(!m(this._primitive)&&!m(this.geometryInstances))return;let e=this.appearance;m(e)&&m(e.material)&&e.material.update(t.context);let i=this,n=this._primitiveOptions;if(!m(this._primitive)){let s=Array.isArray(this.geometryInstances)?this.geometryInstances:[this.geometryInstances],o=s.length,r,a,h,A=!1,d=!0,f,E=!1,_=!1;for(o>0&&(h=s[0].attributes,E=gc.hasAttributesForSphericalExtents(h),_=gc.hasAttributesForTextureCoordinatePlanes(h),f=h.color),r=0;r<o;r++){a=s[r];let I=a.attributes.color;if(m(I))A=!0;else if(A)throw new Y("All GeometryInstances must have color attributes to use per-instance color.");d=d&&m(I)&&GJ.equals(f,I)}if(!d&&!E&&!_)throw new Y("All GeometryInstances must have the same color attribute except via GroundPrimitives");if(A&&!m(e)&&(e=new Da({flat:!0}),this.appearance=e),!A&&e instanceof Da)throw new Y("PerInstanceColorAppearance requires color GeometryInstanceAttributes on all GeometryInstances");if(m(e.material)&&!E&&!_)throw new Y("Materials on ClassificationPrimitives are not supported except via GroundPrimitives");this._usePickOffsets=!E&&!_,this._hasSphericalExtentsAttribute=E,this._hasPlanarExtentsAttributes=_,this._hasPerColorAttribute=A;let R=new Array(o);for(r=0;r<o;++r)a=s[r],R[r]=new Ln({geometry:a.geometry,attributes:a.attributes,modelMatrix:a.modelMatrix,id:a.id,pickPrimitive:Z(this._pickPrimitive,i)});n.appearance=e,n.geometryInstances=R,m(this._createBoundingVolumeFunction)&&(n._createBoundingVolumeFunction=function(I,C){i._createBoundingVolumeFunction(I,C)}),n._createRenderStatesFunction=function(I,C,N,T){yrt(i,C)},n._createShaderProgramFunction=function(I,C,N){xrt(i,C)},n._createCommandsFunction=function(I,C,N,T,F,b,G){jrt(i,void 0,void 0,!0,!1,b,G)},m(this._updateAndQueueCommandsFunction)?n._updateAndQueueCommandsFunction=function(I,C,N,T,F,b,G,M){i._updateAndQueueCommandsFunction(I,C,N,T,F,b,G,M)}:n._updateAndQueueCommandsFunction=function(I,C,N,T,F,b,G,M){Hrt(i,C,N,T,F,b,G,M)},this._primitive=new vs(n)}if(this.debugShowShadowVolume&&!this._debugShowShadowVolume&&this._ready?(this._debugShowShadowVolume=!0,this._rsStencilDepthPass=Yn.fromCache($m(!1,!1)),this._rsStencilDepthPass3DTiles=Yn.fromCache($m(!1,!0)),this._rsColorPass=Yn.fromCache(fb(!1))):!this.debugShowShadowVolume&&this._debugShowShadowVolume&&(this._debugShowShadowVolume=!1,this._rsStencilDepthPass=Yn.fromCache($m(!0,!1)),this._rsStencilDepthPass3DTiles=Yn.fromCache($m(!0,!0)),this._rsColorPass=Yn.fromCache(fb(!0))),this._primitive.appearance!==e){if(!this._hasSphericalExtentsAttribute&&!this._hasPlanarExtentsAttributes&&m(e.material))throw new Y("Materials on ClassificationPrimitives are not supported except via GroundPrimitive");if(!this._hasPerColorAttribute&&e instanceof Da)throw new Y("PerInstanceColorAppearance requires color GeometryInstanceAttribute");this._primitive.appearance=e}this._primitive.show=this.show,this._primitive.debugShowBoundingVolume=this.debugShowBoundingVolume,this._primitive.update(t),t.afterRender.push(()=>{m(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};jl.prototype.getGeometryInstanceAttributes=function(t){if(!m(this._primitive))throw new Y("must call update before calling getGeometryInstanceAttributes");return this._primitive.getGeometryInstanceAttributes(t)};jl.prototype.isDestroyed=function(){return!1};jl.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),this._sp=this._sp&&this._sp.destroy(),this._spPick=this._spPick&&this._spPick.destroy(),this._spColor=this._spColor&&this._spColor.destroy(),this._spPick2D=void 0,this._spColor2D=void 0,li(this)};Eb=jl});function nr(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.appearance,i=t.geometryInstances;if(!m(e)&&m(i)){let s=Array.isArray(i)?i:[i],o=s.length;for(let r=0;r<o;r++){let a=s[r].attributes;if(m(a)&&m(a.color)){e=new Da({flat:!0});break}}}this.appearance=e,this.geometryInstances=t.geometryInstances,this.show=Z(t.show,!0),this.classificationType=Z(t.classificationType,Jr.BOTH),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.debugShowShadowVolume=Z(t.debugShowShadowVolume,!1),this._boundingVolumes=[],this._boundingVolumes2D=[],this._ready=!1,this._primitive=void 0,this._maxHeight=void 0,this._minHeight=void 0,this._maxTerrainHeight=Do._defaultMaxTerrainHeight,this._minTerrainHeight=Do._defaultMinTerrainHeight,this._boundingSpheresKeys=[],this._boundingSpheres=[],this._useFragmentCulling=!1,this._zIndex=void 0;let n=this;this._classificationPrimitiveOptions={geometryInstances:void 0,appearance:void 0,vertexCacheOptimize:Z(t.vertexCacheOptimize,!1),interleave:Z(t.interleave,!1),releaseGeometryInstances:Z(t.releaseGeometryInstances,!0),allowPicking:Z(t.allowPicking,!0),asynchronous:Z(t.asynchronous,!0),compressVertices:Z(t.compressVertices,!0),_createBoundingVolumeFunction:void 0,_updateAndQueueCommandsFunction:void 0,_pickPrimitive:n,_extruded:!0,_uniformMap:vrt}}function rj(t){return function(e,i){let n=i.maximumRadius,s=n/Math.cos(e*.5)-n;return t._maxHeight+s}}function aj(t){return function(e,i){return t._minHeight}}function ap(t,e){let i=t.mapProjection.ellipsoid;if(!m(e.attributes)||!m(e.attributes.position3DHigh))return m(e.rectangle)?e.rectangle:void 0;let n=e.attributes.position3DHigh.values,s=e.attributes.position3DLow.values,o=n.length,r=Number.POSITIVE_INFINITY,a=Number.POSITIVE_INFINITY,h=Number.NEGATIVE_INFINITY,A=Number.NEGATIVE_INFINITY;for(let f=0;f<o;f+=3){let E=l.unpack(n,f,zrt),_=l.unpack(s,f,Krt),R=l.add(E,_,Xrt),I=i.cartesianToCartographic(R,qrt),C=I.latitude,N=I.longitude;r=Math.min(r,C),a=Math.min(a,N),h=Math.max(h,C),A=Math.max(A,N)}let d=$rt;return d.north=h,d.south=r,d.east=A,d.west=a,d}function tat(t,e,i){let n=Do.getMinimumMaximumHeights(e,i);t._minTerrainHeight=n.minimumTerrainHeight,t._maxTerrainHeight=n.maximumTerrainHeight}function eat(t,e,i){let n=e.mapProjection.ellipsoid,s=ap(e,i),o=zs.fromRectangle(s,t._minHeight,t._maxHeight,n);if(t._boundingVolumes.push(o),!e.scene3DOnly){let r=e.mapProjection,a=Nt.fromRectangleWithHeights2D(s,r,t._maxHeight,t._minHeight);l.fromElements(a.center.z,a.center.x,a.center.y,a.center),t._boundingVolumes2D.push(a)}}function _b(t,e){return Math.floor(t%e/2)}function Rb(t,e,i,n,s,o,r){let a=t._primitive;i.mode!==ye.SCENE3D&&e.shaderProgram===a._spColor&&a._needs2DShader&&(e=e.derivedCommands.appearance2D),e.owner=t,e.modelMatrix=n,e.boundingVolume=o,e.cull=s,e.debugShowBoundingVolume=r,i.commandList.push(e)}function Aj(t,e,i,n,s,o){let r=t._primitive;i.mode!==ye.SCENE3D&&e.shaderProgram===r._spPick&&r._needs2DShader&&(e=e.derivedCommands.pick2D),e.owner=t,e.modelMatrix=n,e.boundingVolume=o,e.cull=s,i.commandList.push(e)}function iat(t,e,i,n,s,o,r,a){let h;e.mode===ye.SCENE3D?h=t._boundingVolumes:h=t._boundingVolumes2D;let A=t.classificationType,d=A!==Jr.CESIUM_3D_TILE,f=A!==Jr.TERRAIN,E=e.passes,_=t._primitive,R,I,C;if(E.render){let N=i.length;for(R=0;R<N;++R)I=h[_b(R,N)],d&&(C=i[R],Rb(t,C,e,s,o,I,r)),f&&(C=i[R].derivedCommands.tileset,Rb(t,C,e,s,o,I,r));if(e.invertClassification){let T=_._commandsIgnoreShow,F=T.length;for(R=0;R<F;++R)I=h[R],C=T[R],Rb(t,C,e,s,o,I,r)}}if(E.pick){let N=n.length,T;for(t._useFragmentCulling||(T=_._primitive._pickOffsets),R=0;R<N;++R){if(I=h[_b(R,N)],!t._useFragmentCulling){let F=T[_b(R,N)];I=h[F.index]}d&&(C=n[R],Aj(t,C,e,s,o,I)),f&&(C=n[R].derivedCommands.tileset,Aj(t,C,e,s,o,I))}}}var vrt,zrt,Krt,Xrt,qrt,$rt,hj,cj=O(()=>{JE();_i();Ht();ri();ae();bt();mt();Ws();Vt();uA();Jl();pn();hb();oj();MI();op();ua();db();vrt={u_globeMinimumAltitude:function(){return 55e3}};Object.defineProperties(nr.prototype,{vertexCacheOptimize:{get:function(){return this._classificationPrimitiveOptions.vertexCacheOptimize}},interleave:{get:function(){return this._classificationPrimitiveOptions.interleave}},releaseGeometryInstances:{get:function(){return this._classificationPrimitiveOptions.releaseGeometryInstances}},allowPicking:{get:function(){return this._classificationPrimitiveOptions.allowPicking}},asynchronous:{get:function(){return this._classificationPrimitiveOptions.asynchronous}},compressVertices:{get:function(){return this._classificationPrimitiveOptions.compressVertices}},ready:{get:function(){return this._ready}}});nr.isSupported=Eb.isSupported;zrt=new l,Krt=new l,Xrt=new l,qrt=new ut,$rt=new Xt;nr.initializeTerrainHeights=function(){return Do.initialize()};nr.prototype.update=function(t){if(!m(this._primitive)&&!m(this.geometryInstances))return;if(!Do.initialized){if(!this.asynchronous)throw new Y("For synchronous GroundPrimitives, you must call GroundPrimitive.initializeTerrainHeights() and wait for the returned promise to resolve.");nr.initializeTerrainHeights();return}let e=this,i=this._classificationPrimitiveOptions;if(!m(this._primitive)){let n=t.mapProjection.ellipsoid,s,o,r,a=Array.isArray(this.geometryInstances)?this.geometryInstances:[this.geometryInstances],h=a.length,A=new Array(h),d,f;for(d=0;d<h;++d){s=a[d],o=s.geometry;let I=ap(t,o);m(f)?m(I)&&Xt.union(f,I,f):f=Xt.clone(I);let C=s.id;if(m(C)&&m(I)){let N=Do.getBoundingSphere(I,n);this._boundingSpheresKeys.push(C),this._boundingSpheres.push(N)}if(r=o.constructor,!m(r)||!m(r.createShadowVolume))throw new Y("Not all of the geometry instances have GroundPrimitive support.")}tat(this,f,n);let E=t.verticalExaggeration,_=t.verticalExaggerationRelativeHeight;this._minHeight=A_.getHeight(this._minTerrainHeight,E,_),this._maxHeight=A_.getHeight(this._maxTerrainHeight,E,_);let R=nr._supportsMaterials(t.context);if(this._useFragmentCulling=R,R){let I,C=!0;for(d=0;d<h;++d)if(s=a[d],o=s.geometry,f=ap(t,o),gc.shouldUseSphericalCoordinates(f)){C=!1;break}for(d=0;d<h;++d){s=a[d],o=s.geometry,r=o.constructor;let N=ap(t,o),T=o.textureCoordinateRotationPoints;C?I=gc.getPlanarTextureCoordinateAttributes(N,T,n,t.mapProjection,this._maxHeight):I=gc.getSphericalExtentGeometryInstanceAttributes(N,T,n,t.mapProjection);let F=s.attributes;for(let b in F)F.hasOwnProperty(b)&&(I[b]=F[b]);A[d]=new Ln({geometry:r.createShadowVolume(o,aj(this),rj(this)),attributes:I,id:s.id})}}else for(d=0;d<h;++d)s=a[d],o=s.geometry,r=o.constructor,A[d]=new Ln({geometry:r.createShadowVolume(o,aj(this),rj(this)),attributes:s.attributes,id:s.id});i.geometryInstances=A,i.appearance=this.appearance,i._createBoundingVolumeFunction=function(I,C){eat(e,I,C)},i._updateAndQueueCommandsFunction=function(I,C,N,T,F,b,G,M){iat(e,C,N,T,F,b,G,M)},this._primitive=new Eb(i)}this._primitive.appearance=this.appearance,this._primitive.show=this.show,this._primitive.debugShowShadowVolume=this.debugShowShadowVolume,this._primitive.debugShowBoundingVolume=this.debugShowBoundingVolume,this._primitive.update(t),t.afterRender.push(()=>{!this._ready&&m(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};nr.prototype.getBoundingSphere=function(t){let e=this._boundingSpheresKeys.indexOf(t);if(e!==-1)return this._boundingSpheres[e]};nr.prototype.getGeometryInstanceAttributes=function(t){if(!m(this._primitive))throw new Y("must call update before calling getGeometryInstanceAttributes");return this._primitive.getGeometryInstanceAttributes(t)};nr.prototype.isDestroyed=function(){return!1};nr.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),li(this)};nr._supportsMaterials=function(t){return t.depthTexture};nr.supportsMaterials=function(t){return p.typeOf.object("scene",t),nr._supportsMaterials(t.frameState.context)};hj=nr});function Tc(t){this._value=void 0,this._hasClone=!1,this._hasEquals=!1,this._definitionChanged=new We,this.setValue(t)}var Ch,h_=O(()=>{mt();xi();Object.defineProperties(Tc.prototype,{isConstant:{value:!0},definitionChanged:{get:function(){return this._definitionChanged}}});Tc.prototype.getValue=function(t,e){return this._hasClone?this._value.clone(e):this._value};Tc.prototype.setValue=function(t){let e=this._value;if(e!==t){let i=m(t),n=i&&typeof t.clone=="function",s=i&&typeof t.equals=="function";(!s||!t.equals(e))&&(this._hasClone=n,this._hasEquals=s,this._value=n?t.clone(this._value):t,this._definitionChanged.raiseEvent(this))}};Tc.prototype.equals=function(t){return this===t||t instanceof Tc&&(!this._hasEquals&&this._value===t._value||this._hasEquals&&this._value.equals(t._value))};Tc.prototype.valueOf=function(){return this._value};Tc.prototype.toString=function(){return String(this._value)};Ch=Tc});function nat(t,e,i,n,s){return{configurable:n,get:function(){return this[e]},set:function(o){let r=this[e],a=this[i];m(a)&&(a(),this[i]=void 0),o!==void 0&&(!m(o)||!m(o.getValue))&&m(s)&&(o=s(o)),r!==o&&(this[e]=o,this._definitionChanged.raiseEvent(this,t,o,r)),m(o)&&m(o.definitionChanged)&&(this[i]=o.definitionChanged.addEventListener(function(){this._definitionChanged.raiseEvent(this,t,o,o)},this))}}}function sat(t){return new Ch(t)}function oat(t,e,i){return nat(t,`_${t.toString()}`,`_${t.toString()}Subscription`,Z(e,!1),Z(i,sat))}var rt,yn=O(()=>{bt();mt();h_();rt=oat});function c_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._image=void 0,this._imageSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this._pixelOffset=void 0,this._pixelOffsetSubscription=void 0,this._eyeOffset=void 0,this._eyeOffsetSubscription=void 0,this._horizontalOrigin=void 0,this._horizontalOriginSubscription=void 0,this._verticalOrigin=void 0,this._verticalOriginSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._color=void 0,this._colorSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._alignedAxis=void 0,this._alignedAxisSubscription=void 0,this._sizeInMeters=void 0,this._sizeInMetersSubscription=void 0,this._width=void 0,this._widthSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._scaleByDistance=void 0,this._scaleByDistanceSubscription=void 0,this._translucencyByDistance=void 0,this._translucencyByDistanceSubscription=void 0,this._pixelOffsetScaleByDistance=void 0,this._pixelOffsetScaleByDistanceSubscription=void 0,this._imageSubRegion=void 0,this._imageSubRegionSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._disableDepthTestDistance=void 0,this._disableDepthTestDistanceSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var lj,dj=O(()=>{bt();mt();Vt();xi();yn();Object.defineProperties(c_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),image:rt("image"),scale:rt("scale"),pixelOffset:rt("pixelOffset"),eyeOffset:rt("eyeOffset"),horizontalOrigin:rt("horizontalOrigin"),verticalOrigin:rt("verticalOrigin"),heightReference:rt("heightReference"),color:rt("color"),rotation:rt("rotation"),alignedAxis:rt("alignedAxis"),sizeInMeters:rt("sizeInMeters"),width:rt("width"),height:rt("height"),scaleByDistance:rt("scaleByDistance"),translucencyByDistance:rt("translucencyByDistance"),pixelOffsetScaleByDistance:rt("pixelOffsetScaleByDistance"),imageSubRegion:rt("imageSubRegion"),distanceDisplayCondition:rt("distanceDisplayCondition"),disableDepthTestDistance:rt("disableDepthTestDistance")});c_.prototype.clone=function(t){return m(t)?(t.show=this._show,t.image=this._image,t.scale=this._scale,t.pixelOffset=this._pixelOffset,t.eyeOffset=this._eyeOffset,t.horizontalOrigin=this._horizontalOrigin,t.verticalOrigin=this._verticalOrigin,t.heightReference=this._heightReference,t.color=this._color,t.rotation=this._rotation,t.alignedAxis=this._alignedAxis,t.sizeInMeters=this._sizeInMeters,t.width=this._width,t.height=this._height,t.scaleByDistance=this._scaleByDistance,t.translucencyByDistance=this._translucencyByDistance,t.pixelOffsetScaleByDistance=this._pixelOffsetScaleByDistance,t.imageSubRegion=this._imageSubRegion,t.distanceDisplayCondition=this._distanceDisplayCondition,t.disableDepthTestDistance=this._disableDepthTestDistance,t):new c_(this)};c_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this._show,t.show),this.image=Z(this._image,t.image),this.scale=Z(this._scale,t.scale),this.pixelOffset=Z(this._pixelOffset,t.pixelOffset),this.eyeOffset=Z(this._eyeOffset,t.eyeOffset),this.horizontalOrigin=Z(this._horizontalOrigin,t.horizontalOrigin),this.verticalOrigin=Z(this._verticalOrigin,t.verticalOrigin),this.heightReference=Z(this._heightReference,t.heightReference),this.color=Z(this._color,t.color),this.rotation=Z(this._rotation,t.rotation),this.alignedAxis=Z(this._alignedAxis,t.alignedAxis),this.sizeInMeters=Z(this._sizeInMeters,t.sizeInMeters),this.width=Z(this._width,t.width),this.height=Z(this._height,t.height),this.scaleByDistance=Z(this._scaleByDistance,t.scaleByDistance),this.translucencyByDistance=Z(this._translucencyByDistance,t.translucencyByDistance),this.pixelOffsetScaleByDistance=Z(this._pixelOffsetScaleByDistance,t.pixelOffsetScaleByDistance),this.imageSubRegion=Z(this._imageSubRegion,t.imageSubRegion),this.distanceDisplayCondition=Z(this._distanceDisplayCondition,t.distanceDisplayCondition),this.disableDepthTestDistance=Z(this._disableDepthTestDistance,t.disableDepthTestDistance)};lj=c_});function Ma(){Y.throwInstantiationError()}var Oi,Hl=O(()=>{bt();mt();Vt();Object.defineProperties(Ma.prototype,{isConstant:{get:Y.throwInstantiationError},definitionChanged:{get:Y.throwInstantiationError}});Ma.prototype.getValue=Y.throwInstantiationError;Ma.prototype.equals=Y.throwInstantiationError;Ma.equals=function(t,e){return t===e||m(t)&&t.equals(e)};Ma.arrayEquals=function(t,e){if(t===e)return!0;if(!m(t)||!m(e)||t.length!==e.length)return!1;let i=t.length;for(let n=0;n<i;n++)if(!Ma.equals(t[n],e[n]))return!1;return!0};Ma.isConstant=function(t){return!m(t)||t.isConstant};Ma.getValueOrUndefined=function(t,e,i){return m(t)?t.getValue(e,i):void 0};Ma.getValueOrDefault=function(t,e,i,n){return m(t)?Z(t.getValue(e,n),i):i};Ma.getValueOrClonedDefault=function(t,e,i,n){let s;return m(t)&&(s=t.getValue(e,n)),m(s)||(s=i.clone(s)),s};Oi=Ma});function tf(t){this._definitionChanged=new We,this._color=void 0,this._colorSubscription=void 0,this.color=t}var mj,fj=O(()=>{Qn();mt();xi();yn();Hl();Object.defineProperties(tf.prototype,{isConstant:{get:function(){return Oi.isConstant(this._color)}},definitionChanged:{get:function(){return this._definitionChanged}},color:rt("color")});tf.prototype.getType=function(t){return"Color"};tf.prototype.getValue=function(t,e){return m(e)||(e={}),e.color=Oi.getValueOrClonedDefault(this._color,t,Zt.WHITE,e.color),e};tf.prototype.equals=function(t){return this===t||t instanceof tf&&Oi.equals(this._color,t._color)};mj=tf});function ef(t){t=Z(t,Z.EMPTY_OBJECT),this._definitionChanged=new We,this._image=void 0,this._imageSubscription=void 0,this._repeat=void 0,this._repeatSubscription=void 0,this._color=void 0,this._colorSubscription=void 0,this._transparent=void 0,this._transparentSubscription=void 0,this.image=t.image,this.repeat=t.repeat,this.color=t.color,this.transparent=t.transparent}var rat,aat,Aat,Ej,_j=O(()=>{Xe();Qn();bt();mt();xi();yn();Hl();rat=new nt(1,1),aat=!1,Aat=Zt.WHITE;Object.defineProperties(ef.prototype,{isConstant:{get:function(){return Oi.isConstant(this._image)&&Oi.isConstant(this._repeat)}},definitionChanged:{get:function(){return this._definitionChanged}},image:rt("image"),repeat:rt("repeat"),color:rt("color"),transparent:rt("transparent")});ef.prototype.getType=function(t){return"Image"};ef.prototype.getValue=function(t,e){return m(e)||(e={}),e.image=Oi.getValueOrUndefined(this._image,t),e.repeat=Oi.getValueOrClonedDefault(this._repeat,t,rat,e.repeat),e.color=Oi.getValueOrClonedDefault(this._color,t,Aat,e.color),Oi.getValueOrDefault(this._transparent,t,aat)&&(e.color.alpha=Math.min(.99,e.color.alpha)),e};ef.prototype.equals=function(t){return this===t||t instanceof ef&&Oi.equals(this._image,t._image)&&Oi.equals(this._repeat,t._repeat)&&Oi.equals(this._color,t._color)&&Oi.equals(this._transparent,t._transparent)};Ej=ef});function hat(t){if(t instanceof Zt)return new mj(t);if(typeof t=="string"||t instanceof tn||t instanceof HTMLCanvasElement||t instanceof HTMLVideoElement){let e=new Ej;return e.image=t,e}throw new Y(`Unable to infer material type: ${t}`)}function cat(t,e){return rt(t,e,hat)}var wn,ur=O(()=>{Qn();Vt();Ia();fj();yn();_j();wn=cat});function l_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._dimensions=void 0,this._dimensionsSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Rj,Zj=O(()=>{bt();mt();Vt();xi();ur();yn();Object.defineProperties(l_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),dimensions:rt("dimensions"),heightReference:rt("heightReference"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});l_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.dimensions=this.dimensions,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new l_(this)};l_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.dimensions=Z(this.dimensions,t.dimensions),this.heightReference=Z(this.heightReference,t.heightReference),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};Rj=l_});function nf(){Y.throwInstantiationError()}var Zb,Ap,Ib=O(()=>{Ht();mt();Vt();dn();ic();fr();Object.defineProperties(nf.prototype,{isConstant:{get:Y.throwInstantiationError},definitionChanged:{get:Y.throwInstantiationError},referenceFrame:{get:Y.throwInstantiationError}});nf.prototype.getValue=Y.throwInstantiationError;nf.prototype.getValueInReferenceFrame=Y.throwInstantiationError;nf.prototype.equals=Y.throwInstantiationError;Zb=new lt;nf.convertToReferenceFrame=function(t,e,i,n,s){if(!m(e))return e;if(m(s)||(s=new l),i===n)return l.clone(e,s);let o=In.computeIcrfToFixedMatrix(t,Zb);if(m(o)||(o=In.computeTemeToPseudoFixedMatrix(t,Zb)),i===$i.INERTIAL)return lt.multiplyByVector(o,e,s);if(i===$i.FIXED)return lt.multiplyByVector(lt.transpose(o,Zb),e,s)};Ap=nf});function vl(t,e){this._definitionChanged=new We,this._value=l.clone(t),this._referenceFrame=Z(e,$i.FIXED)}var Ij,pj=O(()=>{Ht();bt();mt();Vt();xi();ic();Ib();Object.defineProperties(vl.prototype,{isConstant:{get:function(){return!m(this._value)||this._referenceFrame===$i.FIXED}},definitionChanged:{get:function(){return this._definitionChanged}},referenceFrame:{get:function(){return this._referenceFrame}}});vl.prototype.getValue=function(t,e){return this.getValueInReferenceFrame(t,$i.FIXED,e)};vl.prototype.setValue=function(t,e){let i=!1;l.equals(this._value,t)||(i=!0,this._value=l.clone(t)),m(e)&&this._referenceFrame!==e&&(i=!0,this._referenceFrame=e),i&&this._definitionChanged.raiseEvent(this)};vl.prototype.getValueInReferenceFrame=function(t,e,i){if(!m(t))throw new Y("time is required.");if(!m(e))throw new Y("referenceFrame is required.");return Ap.convertToReferenceFrame(t,this._value,this._referenceFrame,e,i)};vl.prototype.equals=function(t){return this===t||t instanceof vl&&l.equals(this._value,t._value)&&this._referenceFrame===t._referenceFrame};Ij=vl});function d_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._positions=void 0,this._positionsSubscription=void 0,this._width=void 0,this._widthSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._cornerType=void 0,this._cornerTypeSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var uj,Cj=O(()=>{bt();mt();Vt();xi();ur();yn();Object.defineProperties(d_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),positions:rt("positions"),width:rt("width"),height:rt("height"),heightReference:rt("heightReference"),extrudedHeight:rt("extrudedHeight"),extrudedHeightReference:rt("extrudedHeightReference"),cornerType:rt("cornerType"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition"),classificationType:rt("classificationType"),zIndex:rt("zIndex")});d_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.positions=this.positions,t.width=this.width,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.cornerType=this.cornerType,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new d_(this)};d_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.positions=Z(this.positions,t.positions),this.width=Z(this.width,t.width),this.height=Z(this.height,t.height),this.heightReference=Z(this.heightReference,t.heightReference),this.extrudedHeight=Z(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=Z(this.extrudedHeightReference,t.extrudedHeightReference),this.cornerType=Z(this.cornerType,t.cornerType),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=Z(this.classificationType,t.classificationType),this.zIndex=Z(this.zIndex,t.zIndex)};uj=d_});function lat(t){return t}function dat(t,e){return rt(t,e,lat)}var hp,gj=O(()=>{yn();hp=dat});function m_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._length=void 0,this._lengthSubscription=void 0,this._topRadius=void 0,this._topRadiusSubscription=void 0,this._bottomRadius=void 0,this._bottomRadiusSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._numberOfVerticalLines=void 0,this._numberOfVerticalLinesSubscription=void 0,this._slices=void 0,this._slicesSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Tj,Nj=O(()=>{bt();mt();Vt();xi();ur();yn();Object.defineProperties(m_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),length:rt("length"),topRadius:rt("topRadius"),bottomRadius:rt("bottomRadius"),heightReference:rt("heightReference"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),numberOfVerticalLines:rt("numberOfVerticalLines"),slices:rt("slices"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});m_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.length=this.length,t.topRadius=this.topRadius,t.bottomRadius=this.bottomRadius,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.numberOfVerticalLines=this.numberOfVerticalLines,t.slices=this.slices,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new m_(this)};m_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.length=Z(this.length,t.length),this.topRadius=Z(this.topRadius,t.topRadius),this.bottomRadius=Z(this.bottomRadius,t.bottomRadius),this.heightReference=Z(this.heightReference,t.heightReference),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.numberOfVerticalLines=Z(this.numberOfVerticalLines,t.numberOfVerticalLines),this.slices=Z(this.slices,t.slices),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};Tj=m_});function f_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._semiMajorAxis=void 0,this._semiMajorAxisSubscription=void 0,this._semiMinorAxis=void 0,this._semiMinorAxisSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._stRotation=void 0,this._stRotationSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._numberOfVerticalLines=void 0,this._numberOfVerticalLinesSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var bj,Fj=O(()=>{bt();mt();Vt();xi();ur();yn();Object.defineProperties(f_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),semiMajorAxis:rt("semiMajorAxis"),semiMinorAxis:rt("semiMinorAxis"),height:rt("height"),heightReference:rt("heightReference"),extrudedHeight:rt("extrudedHeight"),extrudedHeightReference:rt("extrudedHeightReference"),rotation:rt("rotation"),stRotation:rt("stRotation"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),numberOfVerticalLines:rt("numberOfVerticalLines"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition"),classificationType:rt("classificationType"),zIndex:rt("zIndex")});f_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.semiMajorAxis=this.semiMajorAxis,t.semiMinorAxis=this.semiMinorAxis,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.rotation=this.rotation,t.stRotation=this.stRotation,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.numberOfVerticalLines=this.numberOfVerticalLines,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new f_(this)};f_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.semiMajorAxis=Z(this.semiMajorAxis,t.semiMajorAxis),this.semiMinorAxis=Z(this.semiMinorAxis,t.semiMinorAxis),this.height=Z(this.height,t.height),this.heightReference=Z(this.heightReference,t.heightReference),this.extrudedHeight=Z(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=Z(this.extrudedHeightReference,t.extrudedHeightReference),this.rotation=Z(this.rotation,t.rotation),this.stRotation=Z(this.stRotation,t.stRotation),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.numberOfVerticalLines=Z(this.numberOfVerticalLines,t.numberOfVerticalLines),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=Z(this.classificationType,t.classificationType),this.zIndex=Z(this.zIndex,t.zIndex)};bj=f_});function E_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._radii=void 0,this._radiiSubscription=void 0,this._innerRadii=void 0,this._innerRadiiSubscription=void 0,this._minimumClock=void 0,this._minimumClockSubscription=void 0,this._maximumClock=void 0,this._maximumClockSubscription=void 0,this._minimumCone=void 0,this._minimumConeSubscription=void 0,this._maximumCone=void 0,this._maximumConeSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._stackPartitions=void 0,this._stackPartitionsSubscription=void 0,this._slicePartitions=void 0,this._slicePartitionsSubscription=void 0,this._subdivisions=void 0,this._subdivisionsSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Yj,Sj=O(()=>{bt();mt();Vt();xi();ur();yn();Object.defineProperties(E_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),radii:rt("radii"),innerRadii:rt("innerRadii"),minimumClock:rt("minimumClock"),maximumClock:rt("maximumClock"),minimumCone:rt("minimumCone"),maximumCone:rt("maximumCone"),heightReference:rt("heightReference"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),stackPartitions:rt("stackPartitions"),slicePartitions:rt("slicePartitions"),subdivisions:rt("subdivisions"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});E_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.radii=this.radii,t.innerRadii=this.innerRadii,t.minimumClock=this.minimumClock,t.maximumClock=this.maximumClock,t.minimumCone=this.minimumCone,t.maximumCone=this.maximumCone,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.stackPartitions=this.stackPartitions,t.slicePartitions=this.slicePartitions,t.subdivisions=this.subdivisions,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new E_(this)};E_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.radii=Z(this.radii,t.radii),this.innerRadii=Z(this.innerRadii,t.innerRadii),this.minimumClock=Z(this.minimumClock,t.minimumClock),this.maximumClock=Z(this.maximumClock,t.maximumClock),this.minimumCone=Z(this.minimumCone,t.minimumCone),this.maximumCone=Z(this.maximumCone,t.maximumCone),this.heightReference=Z(this.heightReference,t.heightReference),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.stackPartitions=Z(this.stackPartitions,t.stackPartitions),this.slicePartitions=Z(this.slicePartitions,t.slicePartitions),this.subdivisions=Z(this.subdivisions,t.subdivisions),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};Yj=E_});function __(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._text=void 0,this._textSubscription=void 0,this._font=void 0,this._fontSubscription=void 0,this._style=void 0,this._styleSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this._showBackground=void 0,this._showBackgroundSubscription=void 0,this._backgroundColor=void 0,this._backgroundColorSubscription=void 0,this._backgroundPadding=void 0,this._backgroundPaddingSubscription=void 0,this._pixelOffset=void 0,this._pixelOffsetSubscription=void 0,this._eyeOffset=void 0,this._eyeOffsetSubscription=void 0,this._horizontalOrigin=void 0,this._horizontalOriginSubscription=void 0,this._verticalOrigin=void 0,this._verticalOriginSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fillColor=void 0,this._fillColorSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._translucencyByDistance=void 0,this._translucencyByDistanceSubscription=void 0,this._pixelOffsetScaleByDistance=void 0,this._pixelOffsetScaleByDistanceSubscription=void 0,this._scaleByDistance=void 0,this._scaleByDistanceSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._disableDepthTestDistance=void 0,this._disableDepthTestDistanceSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Oj,Vj=O(()=>{bt();mt();Vt();xi();yn();Object.defineProperties(__.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),text:rt("text"),font:rt("font"),style:rt("style"),scale:rt("scale"),showBackground:rt("showBackground"),backgroundColor:rt("backgroundColor"),backgroundPadding:rt("backgroundPadding"),pixelOffset:rt("pixelOffset"),eyeOffset:rt("eyeOffset"),horizontalOrigin:rt("horizontalOrigin"),verticalOrigin:rt("verticalOrigin"),heightReference:rt("heightReference"),fillColor:rt("fillColor"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),translucencyByDistance:rt("translucencyByDistance"),pixelOffsetScaleByDistance:rt("pixelOffsetScaleByDistance"),scaleByDistance:rt("scaleByDistance"),distanceDisplayCondition:rt("distanceDisplayCondition"),disableDepthTestDistance:rt("disableDepthTestDistance")});__.prototype.clone=function(t){return m(t)?(t.show=this.show,t.text=this.text,t.font=this.font,t.style=this.style,t.scale=this.scale,t.showBackground=this.showBackground,t.backgroundColor=this.backgroundColor,t.backgroundPadding=this.backgroundPadding,t.pixelOffset=this.pixelOffset,t.eyeOffset=this.eyeOffset,t.horizontalOrigin=this.horizontalOrigin,t.verticalOrigin=this.verticalOrigin,t.heightReference=this.heightReference,t.fillColor=this.fillColor,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.translucencyByDistance=this.translucencyByDistance,t.pixelOffsetScaleByDistance=this.pixelOffsetScaleByDistance,t.scaleByDistance=this.scaleByDistance,t.distanceDisplayCondition=this.distanceDisplayCondition,t.disableDepthTestDistance=this.disableDepthTestDistance,t):new __(this)};__.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.text=Z(this.text,t.text),this.font=Z(this.font,t.font),this.style=Z(this.style,t.style),this.scale=Z(this.scale,t.scale),this.showBackground=Z(this.showBackground,t.showBackground),this.backgroundColor=Z(this.backgroundColor,t.backgroundColor),this.backgroundPadding=Z(this.backgroundPadding,t.backgroundPadding),this.pixelOffset=Z(this.pixelOffset,t.pixelOffset),this.eyeOffset=Z(this.eyeOffset,t.eyeOffset),this.horizontalOrigin=Z(this.horizontalOrigin,t.horizontalOrigin),this.verticalOrigin=Z(this.verticalOrigin,t.verticalOrigin),this.heightReference=Z(this.heightReference,t.heightReference),this.fillColor=Z(this.fillColor,t.fillColor),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.translucencyByDistance=Z(this.translucencyByDistance,t.translucencyByDistance),this.pixelOffsetScaleByDistance=Z(this.pixelOffsetScaleByDistance,t.pixelOffsetScaleByDistance),this.scaleByDistance=Z(this.scaleByDistance,t.scaleByDistance),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.disableDepthTestDistance=Z(this.disableDepthTestDistance,t.disableDepthTestDistance)};Oj=__});function Gj(t,e,i){this.translation=l.clone(Z(t,fat)),this.rotation=Ae.clone(Z(e,Eat)),this.scale=l.clone(Z(i,mat))}var mat,fat,Eat,pb,Bj=O(()=>{Ht();bt();mt();$s();mat=new l(1,1,1),fat=l.ZERO,Eat=Ae.IDENTITY;Gj.prototype.equals=function(t){return this===t||m(t)&&l.equals(this.translation,t.translation)&&Ae.equals(this.rotation,t.rotation)&&l.equals(this.scale,t.scale)};pb=Gj});function R_(t){t=Z(t,Z.EMPTY_OBJECT),this._definitionChanged=new We,this._translation=void 0,this._translationSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this.translation=t.translation,this.rotation=t.rotation,this.scale=t.scale}var ub,Wj,Dj=O(()=>{bt();mt();xi();Bj();yn();Hl();ub=new pb;Object.defineProperties(R_.prototype,{isConstant:{get:function(){return Oi.isConstant(this._translation)&&Oi.isConstant(this._rotation)&&Oi.isConstant(this._scale)}},definitionChanged:{get:function(){return this._definitionChanged}},translation:rt("translation"),rotation:rt("rotation"),scale:rt("scale")});R_.prototype.getValue=function(t,e){return m(e)||(e=new pb),e.translation=Oi.getValueOrClonedDefault(this._translation,t,ub.translation,e.translation),e.rotation=Oi.getValueOrClonedDefault(this._rotation,t,ub.rotation,e.rotation),e.scale=Oi.getValueOrClonedDefault(this._scale,t,ub.scale,e.scale),e};R_.prototype.equals=function(t){return this===t||t instanceof R_&&Oi.equals(this._translation,t._translation)&&Oi.equals(this._rotation,t._rotation)&&Oi.equals(this._scale,t._scale)};Wj=R_});function gh(t,e){this._propertyNames=[],this._definitionChanged=new We,m(t)&&this.merge(t,e)}function _at(t){return new Ch(t)}function Rat(t,e){let i=t._propertyNames,n=e._propertyNames,s=i.length;if(s!==n.length)return!1;for(let o=0;o<s;++o){let r=i[o];if(n.indexOf(r)===-1||!Oi.equals(t[r],e[r]))return!1}return!0}var zl,Cb=O(()=>{bt();mt();Vt();xi();h_();yn();Hl();Object.defineProperties(gh.prototype,{propertyNames:{get:function(){return this._propertyNames}},isConstant:{get:function(){let t=this._propertyNames;for(let e=0,i=t.length;e<i;e++)if(!Oi.isConstant(this[t[e]]))return!1;return!0}},definitionChanged:{get:function(){return this._definitionChanged}}});gh.prototype.hasProperty=function(t){return this._propertyNames.indexOf(t)!==-1};gh.prototype.addProperty=function(t,e,i){let n=this._propertyNames;if(!m(t))throw new Y("propertyName is required.");if(n.indexOf(t)!==-1)throw new Y(`${t} is already a registered property.`);n.push(t),Object.defineProperty(this,t,rt(t,!0,Z(i,_at))),m(e)&&(this[t]=e),this._definitionChanged.raiseEvent(this)};gh.prototype.removeProperty=function(t){let i=this._propertyNames.indexOf(t);if(!m(t))throw new Y("propertyName is required.");if(i===-1)throw new Y(`${t} is not a registered property.`);this._propertyNames.splice(i,1),delete this[t],this._definitionChanged.raiseEvent(this)};gh.prototype.getValue=function(t,e){if(!m(t))throw new Y("time is required.");m(e)||(e={});let i=this._propertyNames;for(let n=0,s=i.length;n<s;n++){let o=i[n];e[o]=Oi.getValueOrUndefined(this[o],t,e[o])}return e};gh.prototype.merge=function(t,e){if(!m(t))throw new Y("source is required.");let i=this._propertyNames,n=m(t._propertyNames)?t._propertyNames:Object.keys(t);for(let s=0,o=n.length;s<o;s++){let r=n[s],a=this[r],h=t[r];a===void 0&&i.indexOf(r)===-1&&this.addProperty(r,void 0,e),h!==void 0&&(a!==void 0?m(a)&&m(a.merge)&&a.merge(h):m(h)&&m(h.merge)&&m(h.clone)?this[r]=h.clone():this[r]=h)}};gh.prototype.equals=function(t){return this===t||t instanceof gh&&Rat(this,t)};zl=gh});function Mj(t){return new Wj(t)}function Zat(t){return new zl(t,Mj)}function Iat(t){return new zl(t)}function Z_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._uri=void 0,this._uriSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this._minimumPixelSize=void 0,this._minimumPixelSizeSubscription=void 0,this._maximumScale=void 0,this._maximumScaleSubscription=void 0,this._incrementallyLoadTextures=void 0,this._incrementallyLoadTexturesSubscription=void 0,this._runAnimations=void 0,this._runAnimationsSubscription=void 0,this._clampAnimations=void 0,this._clampAnimationsSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._silhouetteColor=void 0,this._silhouetteColorSubscription=void 0,this._silhouetteSize=void 0,this._silhouetteSizeSubscription=void 0,this._color=void 0,this._colorSubscription=void 0,this._colorBlendMode=void 0,this._colorBlendModeSubscription=void 0,this._colorBlendAmount=void 0,this._colorBlendAmountSubscription=void 0,this._imageBasedLightingFactor=void 0,this._imageBasedLightingFactorSubscription=void 0,this._lightColor=void 0,this._lightColorSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._nodeTransformations=void 0,this._nodeTransformationsSubscription=void 0,this._articulations=void 0,this._articulationsSubscription=void 0,this._clippingPlanes=void 0,this._clippingPlanesSubscription=void 0,this._customShader=void 0,this._customShaderSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Uj,Qj=O(()=>{bt();mt();Vt();xi();yn();Dj();Cb();Object.defineProperties(Z_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),uri:rt("uri"),scale:rt("scale"),minimumPixelSize:rt("minimumPixelSize"),maximumScale:rt("maximumScale"),incrementallyLoadTextures:rt("incrementallyLoadTextures"),runAnimations:rt("runAnimations"),clampAnimations:rt("clampAnimations"),shadows:rt("shadows"),heightReference:rt("heightReference"),silhouetteColor:rt("silhouetteColor"),silhouetteSize:rt("silhouetteSize"),color:rt("color"),colorBlendMode:rt("colorBlendMode"),colorBlendAmount:rt("colorBlendAmount"),imageBasedLightingFactor:rt("imageBasedLightingFactor"),lightColor:rt("lightColor"),distanceDisplayCondition:rt("distanceDisplayCondition"),nodeTransformations:rt("nodeTransformations",void 0,Zat),articulations:rt("articulations",void 0,Iat),clippingPlanes:rt("clippingPlanes"),customShader:rt("customShader")});Z_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.uri=this.uri,t.scale=this.scale,t.minimumPixelSize=this.minimumPixelSize,t.maximumScale=this.maximumScale,t.incrementallyLoadTextures=this.incrementallyLoadTextures,t.runAnimations=this.runAnimations,t.clampAnimations=this.clampAnimations,t.heightReference=this._heightReference,t.silhouetteColor=this.silhouetteColor,t.silhouetteSize=this.silhouetteSize,t.color=this.color,t.colorBlendMode=this.colorBlendMode,t.colorBlendAmount=this.colorBlendAmount,t.imageBasedLightingFactor=this.imageBasedLightingFactor,t.lightColor=this.lightColor,t.distanceDisplayCondition=this.distanceDisplayCondition,t.nodeTransformations=this.nodeTransformations,t.articulations=this.articulations,t.clippingPlanes=this.clippingPlanes,t.customShader=this.customShader,t):new Z_(this)};Z_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.uri=Z(this.uri,t.uri),this.scale=Z(this.scale,t.scale),this.minimumPixelSize=Z(this.minimumPixelSize,t.minimumPixelSize),this.maximumScale=Z(this.maximumScale,t.maximumScale),this.incrementallyLoadTextures=Z(this.incrementallyLoadTextures,t.incrementallyLoadTextures),this.runAnimations=Z(this.runAnimations,t.runAnimations),this.clampAnimations=Z(this.clampAnimations,t.clampAnimations),this.shadows=Z(this.shadows,t.shadows),this.heightReference=Z(this.heightReference,t.heightReference),this.silhouetteColor=Z(this.silhouetteColor,t.silhouetteColor),this.silhouetteSize=Z(this.silhouetteSize,t.silhouetteSize),this.color=Z(this.color,t.color),this.colorBlendMode=Z(this.colorBlendMode,t.colorBlendMode),this.colorBlendAmount=Z(this.colorBlendAmount,t.colorBlendAmount),this.imageBasedLightingFactor=Z(this.imageBasedLightingFactor,t.imageBasedLightingFactor),this.lightColor=Z(this.lightColor,t.lightColor),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.clippingPlanes=Z(this.clippingPlanes,t.clippingPlanes),this.customShader=Z(this.customShader,t.customShader);let e=t.nodeTransformations;if(m(e)){let n=this.nodeTransformations;m(n)?n.merge(e):this.nodeTransformations=new zl(e,Mj)}let i=t.articulations;if(m(i)){let n=this.articulations;m(n)?n.merge(i):this.articulations=new zl(i)}};Uj=Z_});function I_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._uri=void 0,this._uriSubscription=void 0,this._maximumScreenSpaceError=void 0,this._maximumScreenSpaceErrorSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var kj,Lj=O(()=>{bt();mt();Vt();xi();yn();Object.defineProperties(I_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),uri:rt("uri"),maximumScreenSpaceError:rt("maximumScreenSpaceError")});I_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.uri=this.uri,t.maximumScreenSpaceError=this.maximumScreenSpaceError,t):new I_(this)};I_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.uri=Z(this.uri,t.uri),this.maximumScreenSpaceError=Z(this.maximumScreenSpaceError,t.maximumScreenSpaceError)};kj=I_});function p_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._leadTime=void 0,this._leadTimeSubscription=void 0,this._trailTime=void 0,this._trailTimeSubscription=void 0,this._width=void 0,this._widthSubscription=void 0,this._resolution=void 0,this._resolutionSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var yj,wj=O(()=>{bt();mt();Vt();xi();ur();yn();Object.defineProperties(p_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),leadTime:rt("leadTime"),trailTime:rt("trailTime"),width:rt("width"),resolution:rt("resolution"),material:wn("material"),distanceDisplayCondition:rt("distanceDisplayCondition")});p_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.leadTime=this.leadTime,t.trailTime=this.trailTime,t.width=this.width,t.resolution=this.resolution,t.material=this.material,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new p_(this)};p_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.leadTime=Z(this.leadTime,t.leadTime),this.trailTime=Z(this.trailTime,t.trailTime),this.width=Z(this.width,t.width),this.resolution=Z(this.resolution,t.resolution),this.material=Z(this.material,t.material),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};yj=p_});function u_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._plane=void 0,this._planeSubscription=void 0,this._dimensions=void 0,this._dimensionsSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var xj,Pj=O(()=>{bt();mt();Vt();xi();ur();yn();Object.defineProperties(u_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),plane:rt("plane"),dimensions:rt("dimensions"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});u_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.plane=this.plane,t.dimensions=this.dimensions,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new u_(this)};u_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.plane=Z(this.plane,t.plane),this.dimensions=Z(this.dimensions,t.dimensions),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};xj=u_});function C_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._pixelSize=void 0,this._pixelSizeSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._color=void 0,this._colorSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._scaleByDistance=void 0,this._scaleByDistanceSubscription=void 0,this._translucencyByDistance=void 0,this._translucencyByDistanceSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._disableDepthTestDistance=void 0,this._disableDepthTestDistanceSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Jj,jj=O(()=>{bt();mt();Vt();xi();yn();Object.defineProperties(C_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),pixelSize:rt("pixelSize"),heightReference:rt("heightReference"),color:rt("color"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),scaleByDistance:rt("scaleByDistance"),translucencyByDistance:rt("translucencyByDistance"),distanceDisplayCondition:rt("distanceDisplayCondition"),disableDepthTestDistance:rt("disableDepthTestDistance")});C_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.pixelSize=this.pixelSize,t.heightReference=this.heightReference,t.color=this.color,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.scaleByDistance=this.scaleByDistance,t.translucencyByDistance=this._translucencyByDistance,t.distanceDisplayCondition=this.distanceDisplayCondition,t.disableDepthTestDistance=this.disableDepthTestDistance,t):new C_(this)};C_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.pixelSize=Z(this.pixelSize,t.pixelSize),this.heightReference=Z(this.heightReference,t.heightReference),this.color=Z(this.color,t.color),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.scaleByDistance=Z(this.scaleByDistance,t.scaleByDistance),this.translucencyByDistance=Z(this._translucencyByDistance,t.translucencyByDistance),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.disableDepthTestDistance=Z(this.disableDepthTestDistance,t.disableDepthTestDistance)};Jj=C_});function pat(t,e){this.positions=m(t)?t:[],this.holes=m(e)?e:[]}var sf,cp=O(()=>{mt();sf=pat});function uat(t){return Array.isArray(t)&&(t=new sf(t)),new Ch(t)}function g_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._hierarchy=void 0,this._hierarchySubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._stRotation=void 0,this._stRotationSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._perPositionHeight=void 0,this._perPositionHeightSubscription=void 0,this._closeTop=void 0,this._closeTopSubscription=void 0,this._closeBottom=void 0,this._closeBottomSubscription=void 0,this._arcType=void 0,this._arcTypeSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this._textureCoordinates=void 0,this._textureCoordinatesSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Hj,vj=O(()=>{bt();mt();Vt();xi();cp();h_();ur();yn();Object.defineProperties(g_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),hierarchy:rt("hierarchy",void 0,uat),height:rt("height"),heightReference:rt("heightReference"),extrudedHeight:rt("extrudedHeight"),extrudedHeightReference:rt("extrudedHeightReference"),stRotation:rt("stRotation"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),perPositionHeight:rt("perPositionHeight"),closeTop:rt("closeTop"),closeBottom:rt("closeBottom"),arcType:rt("arcType"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition"),classificationType:rt("classificationType"),zIndex:rt("zIndex"),textureCoordinates:rt("textureCoordinates")});g_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.hierarchy=this.hierarchy,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.stRotation=this.stRotation,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.perPositionHeight=this.perPositionHeight,t.closeTop=this.closeTop,t.closeBottom=this.closeBottom,t.arcType=this.arcType,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t.textureCoordinates=this.textureCoordinates,t):new g_(this)};g_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.hierarchy=Z(this.hierarchy,t.hierarchy),this.height=Z(this.height,t.height),this.heightReference=Z(this.heightReference,t.heightReference),this.extrudedHeight=Z(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=Z(this.extrudedHeightReference,t.extrudedHeightReference),this.stRotation=Z(this.stRotation,t.stRotation),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.perPositionHeight=Z(this.perPositionHeight,t.perPositionHeight),this.closeTop=Z(this.closeTop,t.closeTop),this.closeBottom=Z(this.closeBottom,t.closeBottom),this.arcType=Z(this.arcType,t.arcType),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=Z(this.classificationType,t.classificationType),this.zIndex=Z(this.zIndex,t.zIndex),this.textureCoordinates=Z(this.textureCoordinates,t.textureCoordinates)};Hj=g_});function T_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._positions=void 0,this._positionsSubscription=void 0,this._width=void 0,this._widthSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._depthFailMaterial=void 0,this._depthFailMaterialSubscription=void 0,this._arcType=void 0,this._arcTypeSubscription=void 0,this._clampToGround=void 0,this._clampToGroundSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var zj,Kj=O(()=>{bt();mt();Vt();xi();ur();yn();Object.defineProperties(T_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),positions:rt("positions"),width:rt("width"),granularity:rt("granularity"),material:wn("material"),depthFailMaterial:wn("depthFailMaterial"),arcType:rt("arcType"),clampToGround:rt("clampToGround"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition"),classificationType:rt("classificationType"),zIndex:rt("zIndex")});T_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.positions=this.positions,t.width=this.width,t.granularity=this.granularity,t.material=this.material,t.depthFailMaterial=this.depthFailMaterial,t.arcType=this.arcType,t.clampToGround=this.clampToGround,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new T_(this)};T_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.positions=Z(this.positions,t.positions),this.width=Z(this.width,t.width),this.granularity=Z(this.granularity,t.granularity),this.material=Z(this.material,t.material),this.depthFailMaterial=Z(this.depthFailMaterial,t.depthFailMaterial),this.arcType=Z(this.arcType,t.arcType),this.clampToGround=Z(this.clampToGround,t.clampToGround),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=Z(this.classificationType,t.classificationType),this.zIndex=Z(this.zIndex,t.zIndex)};zj=T_});function N_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._positions=void 0,this._positionsSubscription=void 0,this._shape=void 0,this._shapeSubscription=void 0,this._cornerType=void 0,this._cornerTypeSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubsription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Xj,qj=O(()=>{bt();mt();Vt();xi();ur();yn();Object.defineProperties(N_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),positions:rt("positions"),shape:rt("shape"),cornerType:rt("cornerType"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});N_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.positions=this.positions,t.shape=this.shape,t.cornerType=this.cornerType,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new N_(this)};N_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.positions=Z(this.positions,t.positions),this.shape=Z(this.shape,t.shape),this.cornerType=Z(this.cornerType,t.cornerType),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};Xj=N_});function b_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._coordinates=void 0,this._coordinatesSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._stRotation=void 0,this._stRotationSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distancedisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var $j,t3=O(()=>{bt();mt();Vt();xi();ur();yn();Object.defineProperties(b_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),coordinates:rt("coordinates"),height:rt("height"),heightReference:rt("heightReference"),extrudedHeight:rt("extrudedHeight"),extrudedHeightReference:rt("extrudedHeightReference"),rotation:rt("rotation"),stRotation:rt("stRotation"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition"),classificationType:rt("classificationType"),zIndex:rt("zIndex")});b_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.coordinates=this.coordinates,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.rotation=this.rotation,t.stRotation=this.stRotation,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new b_(this)};b_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.coordinates=Z(this.coordinates,t.coordinates),this.height=Z(this.height,t.height),this.heightReference=Z(this.heightReference,t.heightReference),this.extrudedHeight=Z(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=Z(this.extrudedHeightReference,t.extrudedHeightReference),this.rotation=Z(this.rotation,t.rotation),this.stRotation=Z(this.stRotation,t.stRotation),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=Z(this.classificationType,t.classificationType),this.zIndex=Z(this.zIndex,t.zIndex)};$j=b_});function F_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._positions=void 0,this._positionsSubscription=void 0,this._minimumHeights=void 0,this._minimumHeightsSubscription=void 0,this._maximumHeights=void 0,this._maximumHeightsSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var e3,i3=O(()=>{bt();mt();Vt();xi();ur();yn();Object.defineProperties(F_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),positions:rt("positions"),minimumHeights:rt("minimumHeights"),maximumHeights:rt("maximumHeights"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});F_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.positions=this.positions,t.minimumHeights=this.minimumHeights,t.maximumHeights=this.maximumHeights,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new F_(this)};F_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.positions=Z(this.positions,t.positions),this.minimumHeights=Z(this.minimumHeights,t.minimumHeights),this.maximumHeights=Z(this.maximumHeights,t.maximumHeights),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};e3=F_});var Cat,Kl,n3=O(()=>{Cat={NONE:0,HOLD:1,EXTRAPOLATE:2},Kl=Object.freeze(Cat)});var gb,s3,o3=O(()=>{mt();Vt();gb={type:"Linear"};gb.getRequiredDataPoints=function(t){return 2};gb.interpolateOrderZero=function(t,e,i,n,s){if(e.length!==2)throw new Y("The xTable provided to the linear interpolator must have exactly two elements.");if(n<=0)throw new Y("There must be at least 1 dependent variable for each independent variable.");m(s)||(s=new Array(n));let o,r,a,h=e[0],A=e[1];if(h===A)throw new Y("Divide by zero error: xTable[0] and xTable[1] are equal");for(o=0;o<n;o++)r=i[o],a=i[o+n],s[o]=((a-r)*t+A*r-h*a)/(A-h);return s};s3=gb});function a3(t,e,i){let n,s=t.length,o=i.length,r=s+o;if(t.length=r,s!==e){let a=s-1;for(n=r-1;n>=e;n--)t[n]=t[a--]}for(n=0;n<o;n++)t[e++]=i[n]}function A3(t,e){return t instanceof Ze?t:typeof t=="string"?Ze.fromIso8601(t):Ze.addSeconds(e,t,new Ze)}function lp(t,e,i,n,s){let o=0,r,a,h,A,d,f;for(;o<n.length;){d=A3(n[o],t),h=Bo(e,d,Ze.compare);let E=0,_=0;if(h<0){for(h=~h,A=h*s,a=void 0,f=e[h];o<n.length&&(d=A3(n[o],t),!(m(a)&&Ze.compare(a,d)>=0||m(f)&&Ze.compare(d,f)>=0));){for(Tb[E++]=d,o=o+1,r=0;r<s;r++)Nb[_++]=n[o],o=o+1;a=d}E>0&&(Nb.length=_,a3(i,A,Nb),Tb.length=E,a3(e,h,Tb))}else{for(r=0;r<s;r++)o++,i[h*s+r]=n[o];o++}}}function Ua(t,e){p.defined("type",t);let i=t;i===Number&&(i=r3);let n=i.packedLength,s=Z(i.packedInterpolationLength,n),o=0,r;if(m(e)){let a=e.length;r=new Array(a);for(let h=0;h<a;h++){let A=e[h];A===Number&&(A=r3);let d=A.packedLength;n+=d,s+=Z(A.packedInterpolationLength,d),r[h]=A}o=a}this._type=t,this._innerType=i,this._interpolationDegree=1,this._interpolationAlgorithm=s3,this._numberOfPoints=0,this._times=[],this._values=[],this._xTable=[],this._yTable=[],this._packedLength=n,this._packedInterpolationLength=s,this._updateTableLength=!0,this._interpolationResult=new Array(s),this._definitionChanged=new We,this._derivativeTypes=e,this._innerDerivativeTypes=r,this._inputOrder=o,this._forwardExtrapolationType=Kl.NONE,this._forwardExtrapolationDuration=0,this._backwardExtrapolationType=Kl.NONE,this._backwardExtrapolationDuration=0}function h3(t,e,i){let n=t._packedLength;t._times.splice(e,i),t._values.splice(e*n,i*n),t._updateTableLength=!0,t._definitionChanged.raiseEvent(t)}var r3,Tb,Nb,dp,bb=O(()=>{sE();ae();bt();mt();Vt();xi();n3();Vr();o3();r3={packedLength:1,pack:function(t,e,i){i=Z(i,0),e[i]=t},unpack:function(t,e,i){return e=Z(e,0),t[e]}};Tb=[],Nb=[];Object.defineProperties(Ua.prototype,{isConstant:{get:function(){return this._values.length===0}},definitionChanged:{get:function(){return this._definitionChanged}},type:{get:function(){return this._type}},derivativeTypes:{get:function(){return this._derivativeTypes}},interpolationDegree:{get:function(){return this._interpolationDegree}},interpolationAlgorithm:{get:function(){return this._interpolationAlgorithm}},forwardExtrapolationType:{get:function(){return this._forwardExtrapolationType},set:function(t){this._forwardExtrapolationType!==t&&(this._forwardExtrapolationType=t,this._definitionChanged.raiseEvent(this))}},forwardExtrapolationDuration:{get:function(){return this._forwardExtrapolationDuration},set:function(t){this._forwardExtrapolationDuration!==t&&(this._forwardExtrapolationDuration=t,this._definitionChanged.raiseEvent(this))}},backwardExtrapolationType:{get:function(){return this._backwardExtrapolationType},set:function(t){this._backwardExtrapolationType!==t&&(this._backwardExtrapolationType=t,this._definitionChanged.raiseEvent(this))}},backwardExtrapolationDuration:{get:function(){return this._backwardExtrapolationDuration},set:function(t){this._backwardExtrapolationDuration!==t&&(this._backwardExtrapolationDuration=t,this._definitionChanged.raiseEvent(this))}}});Ua.prototype.getValue=function(t,e){p.defined("time",t);let i=this._times,n=i.length;if(n===0)return;let s,o=this._innerType,r=this._values,a=Bo(i,t,Ze.compare);if(a<0){if(a=~a,a===0){let b=i[a];if(s=this._backwardExtrapolationDuration,this._backwardExtrapolationType===Kl.NONE||s!==0&&Ze.secondsDifference(b,t)>s)return;if(this._backwardExtrapolationType===Kl.HOLD)return o.unpack(r,0,e)}if(a>=n){a=n-1;let b=i[a];if(s=this._forwardExtrapolationDuration,this._forwardExtrapolationType===Kl.NONE||s!==0&&Ze.secondsDifference(t,b)>s)return;if(this._forwardExtrapolationType===Kl.HOLD)return a=n-1,o.unpack(r,a*o.packedLength,e)}let h=this._xTable,A=this._yTable,d=this._interpolationAlgorithm,f=this._packedInterpolationLength,E=this._inputOrder;if(this._updateTableLength){this._updateTableLength=!1;let b=Math.min(d.getRequiredDataPoints(this._interpolationDegree,E),n);b!==this._numberOfPoints&&(this._numberOfPoints=b,h.length=b,A.length=b*f)}let _=this._numberOfPoints-1;if(_<1)return;let R=0,I=n-1;if(I-R+1>=_+1){let b=a-(_/2|0)-1;b<R&&(b=R);let G=b+_;G>I&&(G=I,b=G-_,b<R&&(b=R)),R=b,I=G}let N=I-R+1;for(let b=0;b<N;++b)h[b]=Ze.secondsDifference(i[R+b],i[I]);if(m(o.convertPackedArrayForInterpolation))o.convertPackedArrayForInterpolation(r,R,I,A);else{let b=0,G=this._packedLength,M=R*G,Q=(I+1)*G;for(;M<Q;)A[b]=r[M],M++,b++}let T=Ze.secondsDifference(t,i[I]),F;if(E===0||!m(d.interpolate))F=d.interpolateOrderZero(T,h,A,f,this._interpolationResult);else{let b=Math.floor(f/(E+1));F=d.interpolate(T,h,A,b,E,E,this._interpolationResult)}return m(o.unpackInterpolationResult)?o.unpackInterpolationResult(F,r,R,I,e):o.unpack(F,0,e)}return o.unpack(r,a*this._packedLength,e)};Ua.prototype.setInterpolationOptions=function(t){if(!m(t))return;let e=!1,i=t.interpolationAlgorithm,n=t.interpolationDegree;m(i)&&this._interpolationAlgorithm!==i&&(this._interpolationAlgorithm=i,e=!0),m(n)&&this._interpolationDegree!==n&&(this._interpolationDegree=n,e=!0),e&&(this._updateTableLength=!0,this._definitionChanged.raiseEvent(this))};Ua.prototype.addSample=function(t,e,i){let n=this._innerDerivativeTypes,s=m(n);p.defined("time",t),p.defined("value",e),s&&p.defined("derivatives",i);let o=this._innerType,r=[];if(r.push(t),o.pack(e,r,r.length),s){let a=n.length;for(let h=0;h<a;h++)n[h].pack(i[h],r,r.length)}lp(void 0,this._times,this._values,r,this._packedLength),this._updateTableLength=!0,this._definitionChanged.raiseEvent(this)};Ua.prototype.addSamples=function(t,e,i){let n=this._innerDerivativeTypes,s=m(n);if(p.defined("times",t),p.defined("values",e),t.length!==e.length)throw new Y("times and values must be the same length.");if(s&&(!m(i)||i.length!==t.length))throw new Y("times and derivativeValues must be the same length.");let o=this._innerType,r=t.length,a=[];for(let h=0;h<r;h++)if(a.push(t[h]),o.pack(e[h],a,a.length),s){let A=i[h],d=n.length;for(let f=0;f<d;f++)n[f].pack(A[f],a,a.length)}lp(void 0,this._times,this._values,a,this._packedLength),this._updateTableLength=!0,this._definitionChanged.raiseEvent(this)};Ua.prototype.addSamplesPackedArray=function(t,e){p.defined("packedSamples",t),lp(e,this._times,this._values,t,this._packedLength),this._updateTableLength=!0,this._definitionChanged.raiseEvent(this)};Ua.prototype.removeSample=function(t){p.defined("time",t);let e=Bo(this._times,t,Ze.compare);return e<0?!1:(h3(this,e,1),!0)};Ua.prototype.removeSamples=function(t){p.defined("timeInterval",t);let e=this._times,i=Bo(e,t.start,Ze.compare);i<0?i=~i:t.isStartIncluded||++i;let n=Bo(e,t.stop,Ze.compare);n<0?n=~n:t.isStopIncluded&&++n,h3(this,i,n-i)};Ua.prototype.equals=function(t){if(this===t)return!0;if(!m(t)||this._type!==t._type||this._interpolationDegree!==t._interpolationDegree||this._interpolationAlgorithm!==t._interpolationAlgorithm)return!1;let e=this._derivativeTypes,i=m(e),n=t._derivativeTypes,s=m(n);if(i!==s)return!1;let o,r;if(i){if(r=e.length,r!==n.length)return!1;for(o=0;o<r;o++)if(e[o]!==n[o])return!1}let a=this._times,h=t._times;if(r=a.length,r!==h.length)return!1;for(o=0;o<r;o++)if(!Ze.equals(a[o],h[o]))return!1;let A=this._values,d=t._values;for(r=A.length,o=0;o<r;o++)if(A[o]!==d[o])return!1;return!0};Ua._mergeNewSamples=lp;dp=Ua});function bat(t){return new Ij(t)}function Fat(t){return rt(t,void 0,bat)}function ys(t,e){return rt(t,void 0,function(i){return i instanceof e?i:new e(i)})}function sr(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.id;m(e)||(e=Gs()),this._availability=void 0,this._id=e,this._definitionChanged=new We,this._name=t.name,this._show=Z(t.show,!0),this._parent=void 0,this._propertyNames=["billboard","box","corridor","cylinder","description","ellipse","ellipsoid","label","model","tileset","orientation","path","plane","point","polygon","polyline","polylineVolume","position","properties","rectangle","viewFrom","wall","referenceFrame","gltfZForwardYUp",...Fb],this._billboard=void 0,this._billboardSubscription=void 0,this._box=void 0,this._boxSubscription=void 0,this._corridor=void 0,this._corridorSubscription=void 0,this._cylinder=void 0,this._cylinderSubscription=void 0,this._description=void 0,this._descriptionSubscription=void 0,this._ellipse=void 0,this._ellipseSubscription=void 0,this._ellipsoid=void 0,this._ellipsoidSubscription=void 0,this._label=void 0,this._labelSubscription=void 0,this._model=void 0,this._modelSubscription=void 0,this._tileset=void 0,this._tilesetSubscription=void 0,this._orientation=void 0,this._orientationSubscription=void 0,this._path=void 0,this._pathSubscription=void 0,this._plane=void 0,this._planeSubscription=void 0,this._point=void 0,this._pointSubscription=void 0,this._polygon=void 0,this._polygonSubscription=void 0,this._polyline=void 0,this._polylineSubscription=void 0,this._polylineVolume=void 0,this._polylineVolumeSubscription=void 0,this._position=void 0,this._positionSubscription=void 0,this._properties=void 0,this._propertiesSubscription=void 0,this._rectangle=void 0,this._rectangleSubscription=void 0,this._viewFrom=void 0,this._viewFromSubscription=void 0,this._wall=void 0,this._wallSubscription=void 0,this._children=[],this.entityCollection=void 0,this._referenceFrame=Z(t.referenceFrame,void 0),this._gltfZForwardYUp=Z(t.gltfZForwardYUp,!1),this.parent=t.parent,this.merge(t)}function Yb(t,e,i){let n=e.length;for(let s=0;s<n;s++){let o=e[s],r=o._show;(!i&&r)!==(i&&r)&&Yb(o,o._children,i)}t._definitionChanged.raiseEvent(t,"isShowing",i,!i)}var gat,Tat,Nat,Fb,Sb,c3,l3,of,rf,Ob=O(()=>{Ht();ri();ae();ih();bt();mt();Vt();xi();_e();dn();Fi();$s();fr();uJ();cj();Om();dj();Zj();pj();Cj();yn();gj();Nj();Fj();Sj();Vj();Qj();Lj();wj();Pj();jj();vj();Kj();qj();Hl();Cb();t3();i3();ic();bb();sE();Vr();h_();({eastNorthUpToFixedFrame:gat,getTransformToFixedFrame:Tat}=In),Nat=new ut,Fb=[];Object.defineProperties(sr.prototype,{availability:hp("availability"),id:{get:function(){return this._id}},definitionChanged:{get:function(){return this._definitionChanged}},name:hp("name"),show:{get:function(){return this._show},set:function(t){if(!m(t))throw new Y("value is required.");if(t===this._show)return;let e=this.isShowing;this._show=t;let i=this.isShowing;e!==i&&Yb(this,this._children,i),this._definitionChanged.raiseEvent(this,"show",t,!t)}},isShowing:{get:function(){return this._show&&(!m(this.entityCollection)||this.entityCollection.show)&&(!m(this._parent)||this._parent.isShowing)}},parent:{get:function(){return this._parent},set:function(t){let e=this._parent;if(e===t)return;let i=this.isShowing;if(m(e)){let s=e._children.indexOf(this);e._children.splice(s,1)}this._parent=t,m(t)&&t._children.push(this);let n=this.isShowing;i!==n&&Yb(this,this._children,n),this._definitionChanged.raiseEvent(this,"parent",t,e)}},propertyNames:{get:function(){return this._propertyNames}},billboard:ys("billboard",lj),box:ys("box",Rj),corridor:ys("corridor",uj),cylinder:ys("cylinder",Tj),description:rt("description"),ellipse:ys("ellipse",bj),ellipsoid:ys("ellipsoid",Yj),label:ys("label",Oj),model:ys("model",Uj),tileset:ys("tileset",kj),orientation:rt("orientation"),path:ys("path",yj),plane:ys("plane",xj),point:ys("point",Jj),polygon:ys("polygon",Hj),polyline:ys("polyline",zj),polylineVolume:ys("polylineVolume",Xj),properties:ys("properties",zl),position:Fat("position"),rectangle:ys("rectangle",$j),viewFrom:rt("viewFrom"),wall:ys("wall",e3)});sr.registerEntityType=function(t,e){Object.defineProperties(sr.prototype,{[t]:ys(t,e)}),Fb.includes(t)||Fb.push(t)};sr.prototype.isAvailable=function(t){if(!m(t))throw new Y("time is required.");let e=this._availability;return!m(e)||e.contains(t)};sr.prototype.addProperty=function(t){let e=this._propertyNames;if(!m(t))throw new Y("propertyName is required.");if(e.indexOf(t)!==-1)throw new Y(`${t} is already a registered property.`);if(t in this)throw new Y(`${t} is a reserved property name.`);e.push(t),Object.defineProperty(this,t,hp(t,!0))};sr.prototype.removeProperty=function(t){let i=this._propertyNames.indexOf(t);if(!m(t))throw new Y("propertyName is required.");if(i===-1)throw new Y(`${t} is not a registered property.`);this._propertyNames.splice(i,1),delete this[t]};sr.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.name=Z(this.name,t.name),this.availability=Z(this.availability,t.availability);let e=this._propertyNames,i=m(t._propertyNames)?t._propertyNames:Object.keys(t),n=i.length;for(let s=0;s<n;s++){let o=i[s];if(o==="parent"||o==="name"||o==="availability"||o==="children")continue;let r=this[o],a=t[o];!m(r)&&e.indexOf(o)===-1&&this.addProperty(o),m(a)&&(m(r)?m(r.merge)&&r.merge(a):m(a.merge)&&m(a.clone)?this[o]=a.clone():this[o]=a)}};Sb=new lt,c3=new l,l3=new Ae;Object.defineProperties(sr.prototype,{referenceFrame:{get:function(){return this._referenceFrame},set:function(t){Object.values($i).includes(t)&&(this._referenceFrame=t)}},gltfZForwardYUp:{get:function(){return this._gltfZForwardYUp},set:function(t){this._gltfZForwardYUp=t}}});sr.prototype.computeModelMatrix=function(t,e,i=!0,n=void 0){p.typeOf.object("time",t);let s=Oi.getValueOrUndefined(this._position,t,c3);if(!m(s))return;let o=Oi.getValueOrUndefined(this._orientation,t,l3);o&&~XB.indexOf(this.referenceFrame)&&(o=In.reverseHeadingQuaternion(o));let r=Tat(n||this.referenceFrame,t,this._position);return!m(o)||!i?e=r(s,void 0,e):m(this.referenceFrame)?(In.localToFixedFrameQuaternion(s,o,null,r,o),e=at.fromRotationTranslation(lt.fromQuaternion(o,Sb),s,e)):e=at.fromRotationTranslation(lt.fromQuaternion(o,Sb),s,e),e};sr.prototype.computeModelMatrixForHeightReference=function(t,e,i,n,s){p.typeOf.object("time",t);let o=Oi.getValueOrDefault(e,t,Wr.NONE),r=Oi.getValueOrUndefined(this._position,t,c3);if(o===Wr.NONE||!m(r)||l.equalsEpsilon(r,l.ZERO,L.EPSILON8))return this.computeModelMatrix(t,s);let a=n.cartesianToCartographic(r,Nat);gl(o)?a.height=i:a.height+=i,r=n.cartographicToCartesian(a,r);let h=Oi.getValueOrUndefined(this._orientation,t,l3);return m(h)?s=at.fromRotationTranslation(lt.fromQuaternion(h,Sb),r,s):s=gat(r,void 0,s),s};sr.supportsMaterialsforEntitiesOnTerrain=function(t){return hj.supportsMaterials(t)};sr.supportsPolylinesOnTerrain=function(t){return pJ.isSupported(t)};of=new Ae;sr.prototype.updateAdditiveOrientation=function(t,e){this.orientation||(this.orientation=new Ch(Ae.clone(Ae.IDENTITY)));let i=this.orientation,n=Ae.fromAxisAngle(l.UNIT_X,t.roll),s=Ae.fromAxisAngle(l.UNIT_Y,-t.pitch),o=Ae.fromAxisAngle(l.UNIT_Z,-t.heading),r=new Ae;if(Ae.multiply(s,o,r),Ae.multiply(n,r,r),i instanceof dp){let a=i._times,h=e?Bo(a,e,Ze.compare):0;h<0&&(h=~h);let A=i._values[h];Ae.multiply(r,A,of),i._values[h]=Ae.clone(of)}else if(i instanceof Ch){let a=i.getValue();Ae.multiply(a,r,of),Ae.normalize(of,of),i.setValue(Ae.clone(of))}else throw new Y("Unsupported orientation property type.")};rf=sr});function Y_(t){if(t._firing){t._refire=!0;return}if(t._suspendCount===0){let e=t._addedEntities,i=t._removedEntities,n=t._changedEntities;if(n.length!==0||e.length!==0||i.length!==0){t._firing=!0;do{t._refire=!1;let s=e.values.slice(0),o=i.values.slice(0),r=n.values.slice(0);e.removeAll(),i.removeAll(),n.removeAll(),t._collectionChanged.raiseEvent(t,s,o,r)}while(t._refire);t._firing=!1}}}function To(t){this._owner=t,this._entities=new wE,this._addedEntities=new wE,this._removedEntities=new wE,this._changedEntities=new wE,this._suspendCount=0,this._collectionChanged=new We,this._id=Gs(),this._show=!0,this._firing=!1,this._refire=!1}var d3,m3,f3=O(()=>{rw();ih();mt();Vt();xi();hw();Vr();lN();Ob();d3={id:void 0};To.prototype.suspendEvents=function(){this._suspendCount++};To.prototype.resumeEvents=function(){if(this._suspendCount===0)throw new Y("resumeEvents can not be called before suspendEvents.");this._suspendCount--,Y_(this)};Object.defineProperties(To.prototype,{collectionChanged:{get:function(){return this._collectionChanged}},id:{get:function(){return this._id}},values:{get:function(){return this._entities.values}},show:{get:function(){return this._show},set:function(t){if(!m(t))throw new Y("value is required.");if(t===this._show)return;this.suspendEvents();let e,i=[],n=this._entities.values,s=n.length;for(e=0;e<s;e++)i.push(n[e].isShowing);for(this._show=t,e=0;e<s;e++){let o=i[e],r=n[e];o!==r.isShowing&&r.definitionChanged.raiseEvent(r,"isShowing",r.isShowing,o)}this.resumeEvents()}},owner:{get:function(){return this._owner}}});To.prototype.computeAvailability=function(){let t=dh.MAXIMUM_VALUE,e=dh.MINIMUM_VALUE,i=this._entities.values;for(let n=0,s=i.length;n<s;n++){let r=i[n].availability;if(m(r)){let a=r.start,h=r.stop;Ze.lessThan(a,t)&&!a.equals(dh.MINIMUM_VALUE)&&(t=a),Ze.greaterThan(h,e)&&!h.equals(dh.MAXIMUM_VALUE)&&(e=h)}}return dh.MAXIMUM_VALUE.equals(t)&&(t=dh.MINIMUM_VALUE),dh.MINIMUM_VALUE.equals(e)&&(e=dh.MAXIMUM_VALUE),new NI({start:t,stop:e})};To.prototype.add=function(t){if(!m(t))throw new Y("entity is required.");t instanceof rf||(t=new rf(t));let e=t.id,i=this._entities;if(i.contains(e))throw new Y(`An entity with id ${e} already exists in this collection.`);return t.entityCollection=this,i.set(e,t),this._removedEntities.remove(e)||this._addedEntities.set(e,t),t.definitionChanged.addEventListener(To.prototype._onEntityDefinitionChanged,this),Y_(this),t};To.prototype.remove=function(t){return m(t)?this.removeById(t.id):!1};To.prototype.contains=function(t){if(!m(t))throw new Y("entity is required");return this._entities.get(t.id)===t};To.prototype.removeById=function(t){if(!m(t))return!1;let i=this._entities.get(t);return this._entities.remove(t)?(this._addedEntities.remove(t)||(this._removedEntities.set(t,i),this._changedEntities.remove(t)),this._entities.remove(t),i.definitionChanged.removeEventListener(To.prototype._onEntityDefinitionChanged,this),Y_(this),!0):!1};To.prototype.removeAll=function(){let t=this._entities,e=t.length,i=t.values,n=this._addedEntities,s=this._removedEntities;for(let o=0;o<e;o++){let r=i[o],a=r.id,h=n.get(a);m(h)||(r.definitionChanged.removeEventListener(To.prototype._onEntityDefinitionChanged,this),s.set(a,r))}t.removeAll(),n.removeAll(),this._changedEntities.removeAll(),Y_(this)};To.prototype.getById=function(t){if(!m(t))throw new Y("id is required.");return this._entities.get(t)};To.prototype.getOrCreateEntity=function(t){if(!m(t))throw new Y("id is required.");let e=this._entities.get(t);return m(e)||(d3.id=t,e=new rf(d3),this.add(e)),e};To.prototype._onEntityDefinitionChanged=function(t){let e=t.id;this._addedEntities.contains(e)||this._changedEntities.set(e,t),Y_(this)};m3=To});function Vb(t){this._name=t,this._clock=void 0,this._changed=new We,this._error=new We,this._isLoading=!1,this._loading=new We,this._entityCollection=new m3(this),this._entityCluster=new sw}var S_,Gb=O(()=>{mt();Vt();xi();$B();ow();f3();Object.defineProperties(Vb.prototype,{name:{get:function(){return this._name},set:function(t){this._name!==t&&(this._name=t,this._changed.raiseEvent(this))}},clock:{get:function(){return this._clock},set:function(t){this._clock!==t&&(this._clock=t,this._changed.raiseEvent(this))}},entities:{get:function(){return this._entityCollection}},isLoading:{get:function(){return this._isLoading},set:function(t){qB.setLoading(this,t)}},changedEvent:{get:function(){return this._changed}},errorEvent:{get:function(){return this._error}},loadingEvent:{get:function(){return this._loading}},show:{get:function(){return this._entityCollection.show},set:function(t){this._entityCollection.show=t}},clustering:{get:function(){return this._entityCluster},set:function(t){if(!m(t))throw new Y("value must be defined.");this._entityCluster=t}}});Vb.prototype.update=function(t){return!0};S_=Vb});function zr(t,e){e=Z(e,0);let i;if(e>0){i=new Array(e);for(let n=0;n<e;n++)i[n]=l}this._numberOfDerivatives=e,this._property=new dp(l,i),this._definitionChanged=new We,this._referenceFrame=Z(t,$i.FIXED),this._property._definitionChanged.addEventListener(function(){this._definitionChanged.raiseEvent(this)},this)}var E3,_3=O(()=>{Ht();ae();bt();mt();Vt();xi();ic();Ib();Hl();bb();Object.defineProperties(zr.prototype,{isConstant:{get:function(){return this._property.isConstant}},definitionChanged:{get:function(){return this._definitionChanged}},referenceFrame:{get:function(){return this._referenceFrame}},interpolationDegree:{get:function(){return this._property.interpolationDegree}},interpolationAlgorithm:{get:function(){return this._property.interpolationAlgorithm}},numberOfDerivatives:{get:function(){return this._numberOfDerivatives}},forwardExtrapolationType:{get:function(){return this._property.forwardExtrapolationType},set:function(t){this._property.forwardExtrapolationType=t}},forwardExtrapolationDuration:{get:function(){return this._property.forwardExtrapolationDuration},set:function(t){this._property.forwardExtrapolationDuration=t}},backwardExtrapolationType:{get:function(){return this._property.backwardExtrapolationType},set:function(t){this._property.backwardExtrapolationType=t}},backwardExtrapolationDuration:{get:function(){return this._property.backwardExtrapolationDuration},set:function(t){this._property.backwardExtrapolationDuration=t}}});zr.prototype.getValue=function(t,e){return this.getValueInReferenceFrame(t,$i.FIXED,e)};zr.prototype.getValueInReferenceFrame=function(t,e,i){if(p.defined("time",t),p.defined("referenceFrame",e),i=this._property.getValue(t,i),m(i))return Ap.convertToReferenceFrame(t,i,this._referenceFrame,e,i)};zr.prototype.setInterpolationOptions=function(t){this._property.setInterpolationOptions(t)};zr.prototype.addSample=function(t,e,i){let n=this._numberOfDerivatives;if(n>0&&(!m(i)||i.length!==n))throw new Y("derivatives length must be equal to the number of derivatives.");this._property.addSample(t,e,i)};zr.prototype.addSamples=function(t,e,i){this._property.addSamples(t,e,i)};zr.prototype.addSamplesPackedArray=function(t,e){this._property.addSamplesPackedArray(t,e)};zr.prototype.removeSample=function(t){return this._property.removeSample(t)};zr.prototype.removeSamples=function(t){this._property.removeSamples(t)};zr.prototype.equals=function(t){return this===t||t instanceof zr&&Oi.equals(this._property,t._property)&&this._referenceFrame===t._referenceFrame};E3=zr});var af,or,Cr,ct,Xl=O(()=>{af=2,or=4,Cr=4,ct=4});var Qa,O_,V_,ql,Bb=O(()=>{Qa=new Int32Array(2),O_=new Float32Array(Qa.buffer),V_=new Float64Array(Qa.buffer),ql=new Uint16Array(new Uint8Array([1,0]).buffer)[0]===1});var Af,Wb=O(()=>{(function(t){t[t.UTF8_BYTES=1]="UTF8_BYTES",t[t.UTF16_STRING=2]="UTF16_STRING"})(Af||(Af={}))});var $l,Db=O(()=>{Xl();Bb();Wb();$l=class t{constructor(e){this.bytes_=e,this.position_=0,this.text_decoder_=new TextDecoder}static allocate(e){return new t(new Uint8Array(e))}clear(){this.position_=0}bytes(){return this.bytes_}position(){return this.position_}setPosition(e){this.position_=e}capacity(){return this.bytes_.length}readInt8(e){return this.readUint8(e)<<24>>24}readUint8(e){return this.bytes_[e]}readInt16(e){return this.readUint16(e)<<16>>16}readUint16(e){return this.bytes_[e]|this.bytes_[e+1]<<8}readInt32(e){return this.bytes_[e]|this.bytes_[e+1]<<8|this.bytes_[e+2]<<16|this.bytes_[e+3]<<24}readUint32(e){return this.readInt32(e)>>>0}readInt64(e){return BigInt.asIntN(64,BigInt(this.readUint32(e))+(BigInt(this.readUint32(e+4))<<BigInt(32)))}readUint64(e){return BigInt.asUintN(64,BigInt(this.readUint32(e))+(BigInt(this.readUint32(e+4))<<BigInt(32)))}readFloat32(e){return Qa[0]=this.readInt32(e),O_[0]}readFloat64(e){return Qa[ql?0:1]=this.readInt32(e),Qa[ql?1:0]=this.readInt32(e+4),V_[0]}writeInt8(e,i){this.bytes_[e]=i}writeUint8(e,i){this.bytes_[e]=i}writeInt16(e,i){this.bytes_[e]=i,this.bytes_[e+1]=i>>8}writeUint16(e,i){this.bytes_[e]=i,this.bytes_[e+1]=i>>8}writeInt32(e,i){this.bytes_[e]=i,this.bytes_[e+1]=i>>8,this.bytes_[e+2]=i>>16,this.bytes_[e+3]=i>>24}writeUint32(e,i){this.bytes_[e]=i,this.bytes_[e+1]=i>>8,this.bytes_[e+2]=i>>16,this.bytes_[e+3]=i>>24}writeInt64(e,i){this.writeInt32(e,Number(BigInt.asIntN(32,i))),this.writeInt32(e+4,Number(BigInt.asIntN(32,i>>BigInt(32))))}writeUint64(e,i){this.writeUint32(e,Number(BigInt.asUintN(32,i))),this.writeUint32(e+4,Number(BigInt.asUintN(32,i>>BigInt(32))))}writeFloat32(e,i){O_[0]=i,this.writeInt32(e,Qa[0])}writeFloat64(e,i){V_[0]=i,this.writeInt32(e,Qa[ql?0:1]),this.writeInt32(e+4,Qa[ql?1:0])}getBufferIdentifier(){if(this.bytes_.length<this.position_+4+4)throw new Error("FlatBuffers: ByteBuffer is too short to contain an identifier.");let e="";for(let i=0;i<4;i++)e+=String.fromCharCode(this.readInt8(this.position_+4+i));return e}__offset(e,i){let n=e-this.readInt32(e);return i<this.readInt16(n)?this.readInt16(n+i):0}__union(e,i){return e.bb_pos=i+this.readInt32(i),e.bb=this,e}__string(e,i){e+=this.readInt32(e);let n=this.readInt32(e);e+=4;let s=this.bytes_.subarray(e,e+n);return i===Af.UTF8_BYTES?s:this.text_decoder_.decode(s)}__union_with_string(e,i){return typeof e=="string"?this.__string(i):this.__union(e,i)}__indirect(e){return e+this.readInt32(e)}__vector(e){return e+this.readInt32(e)+4}__vector_len(e){return this.readInt32(e+this.readInt32(e))}__has_identifier(e){if(e.length!=4)throw new Error("FlatBuffers: file identifier must be length "+4);for(let i=0;i<4;i++)if(e.charCodeAt(i)!=this.readInt8(this.position()+4+i))return!1;return!0}createScalarList(e,i){let n=[];for(let s=0;s<i;++s){let o=e(s);o!==null&&n.push(o)}return n}createObjList(e,i){let n=[];for(let s=0;s<i;++s){let o=e(s);o!==null&&n.push(o.unpack())}return n}}});var mp,R3=O(()=>{Db();Xl();mp=class t{constructor(e){this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1,this.string_maps=null,this.text_encoder=new TextEncoder;let i;e?i=e:i=1024,this.bb=$l.allocate(i),this.space=i}clear(){this.bb.clear(),this.space=this.bb.capacity(),this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1,this.string_maps=null}forceDefaults(e){this.force_defaults=e}dataBuffer(){return this.bb}asUint8Array(){return this.bb.bytes().subarray(this.bb.position(),this.bb.position()+this.offset())}prep(e,i){e>this.minalign&&(this.minalign=e);let n=~(this.bb.capacity()-this.space+i)+1&e-1;for(;this.space<n+e+i;){let s=this.bb.capacity();this.bb=t.growByteBuffer(this.bb),this.space+=this.bb.capacity()-s}this.pad(n)}pad(e){for(let i=0;i<e;i++)this.bb.writeInt8(--this.space,0)}writeInt8(e){this.bb.writeInt8(this.space-=1,e)}writeInt16(e){this.bb.writeInt16(this.space-=2,e)}writeInt32(e){this.bb.writeInt32(this.space-=4,e)}writeInt64(e){this.bb.writeInt64(this.space-=8,e)}writeFloat32(e){this.bb.writeFloat32(this.space-=4,e)}writeFloat64(e){this.bb.writeFloat64(this.space-=8,e)}addInt8(e){this.prep(1,0),this.writeInt8(e)}addInt16(e){this.prep(2,0),this.writeInt16(e)}addInt32(e){this.prep(4,0),this.writeInt32(e)}addInt64(e){this.prep(8,0),this.writeInt64(e)}addFloat32(e){this.prep(4,0),this.writeFloat32(e)}addFloat64(e){this.prep(8,0),this.writeFloat64(e)}addFieldInt8(e,i,n){(this.force_defaults||i!=n)&&(this.addInt8(i),this.slot(e))}addFieldInt16(e,i,n){(this.force_defaults||i!=n)&&(this.addInt16(i),this.slot(e))}addFieldInt32(e,i,n){(this.force_defaults||i!=n)&&(this.addInt32(i),this.slot(e))}addFieldInt64(e,i,n){(this.force_defaults||i!==n)&&(this.addInt64(i),this.slot(e))}addFieldFloat32(e,i,n){(this.force_defaults||i!=n)&&(this.addFloat32(i),this.slot(e))}addFieldFloat64(e,i,n){(this.force_defaults||i!=n)&&(this.addFloat64(i),this.slot(e))}addFieldOffset(e,i,n){(this.force_defaults||i!=n)&&(this.addOffset(i),this.slot(e))}addFieldStruct(e,i,n){i!=n&&(this.nested(i),this.slot(e))}nested(e){if(e!=this.offset())throw new Error("FlatBuffers: struct must be serialized inline.")}notNested(){if(this.isNested)throw new Error("FlatBuffers: object serialization must not be nested.")}slot(e){this.vtable!==null&&(this.vtable[e]=this.offset())}offset(){return this.bb.capacity()-this.space}static growByteBuffer(e){let i=e.capacity();if(i&3221225472)throw new Error("FlatBuffers: cannot grow buffer beyond 2 gigabytes.");let n=i<<1,s=$l.allocate(n);return s.setPosition(n-i),s.bytes().set(e.bytes(),n-i),s}addOffset(e){this.prep(4,0),this.writeInt32(this.offset()-e+4)}startObject(e){this.notNested(),this.vtable==null&&(this.vtable=[]),this.vtable_in_use=e;for(let i=0;i<e;i++)this.vtable[i]=0;this.isNested=!0,this.object_start=this.offset()}endObject(){if(this.vtable==null||!this.isNested)throw new Error("FlatBuffers: endObject called without startObject");this.addInt32(0);let e=this.offset(),i=this.vtable_in_use-1;for(;i>=0&&this.vtable[i]==0;i--);let n=i+1;for(;i>=0;i--)this.addInt16(this.vtable[i]!=0?e-this.vtable[i]:0);let s=2;this.addInt16(e-this.object_start);let o=(n+s)*2;this.addInt16(o);let r=0,a=this.space;t:for(i=0;i<this.vtables.length;i++){let h=this.bb.capacity()-this.vtables[i];if(o==this.bb.readInt16(h)){for(let A=2;A<o;A+=2)if(this.bb.readInt16(a+A)!=this.bb.readInt16(h+A))continue t;r=this.vtables[i];break}}return r?(this.space=this.bb.capacity()-e,this.bb.writeInt32(this.space,r-e)):(this.vtables.push(this.offset()),this.bb.writeInt32(this.bb.capacity()-e,this.offset()-e)),this.isNested=!1,e}finish(e,i,n){let s=n?4:0;if(i){let o=i;if(this.prep(this.minalign,8+s),o.length!=4)throw new Error("FlatBuffers: file identifier must be length "+4);for(let r=3;r>=0;r--)this.writeInt8(o.charCodeAt(r))}this.prep(this.minalign,4+s),this.addOffset(e),s&&this.addInt32(this.bb.capacity()-this.space),this.bb.setPosition(this.space)}finishSizePrefixed(e,i){this.finish(e,i,!0)}requiredField(e,i){let n=this.bb.capacity()-e,s=n-this.bb.readInt32(n);if(!(i<this.bb.readInt16(s)&&this.bb.readInt16(s+i)!=0))throw new Error("FlatBuffers: field "+i+" must be set")}startVector(e,i,n){this.notNested(),this.vector_num_elems=i,this.prep(4,e*i),this.prep(n,e*i)}endVector(){return this.writeInt32(this.vector_num_elems),this.offset()}createSharedString(e){if(!e)return 0;if(this.string_maps||(this.string_maps=new Map),this.string_maps.has(e))return this.string_maps.get(e);let i=this.createString(e);return this.string_maps.set(e,i),i}createString(e){if(e==null)return 0;let i;e instanceof Uint8Array?i=e:i=this.text_encoder.encode(e),this.addInt8(0),this.startVector(1,i.length,1),this.bb.setPosition(this.space-=i.length);for(let n=0,s=this.space,o=this.bb.bytes();n<i.length;n++)o[s++]=i[n];return this.endVector()}createObjectOffset(e){return e===null?0:typeof e=="string"?this.createString(e):e.pack(this)}createObjectOffsetList(e){let i=[];for(let n=0;n<e.length;++n){let s=e[n];if(s!==null)i.push(this.createObjectOffset(s));else throw new Error("FlatBuffers: Argument for createObjectOffsetList cannot contain null.")}return i}createStructOffsetList(e,i){return i(this,e.length),this.createObjectOffsetList(e.slice().reverse()),this.endVector()}}});var Et={};He(Et,{Builder:()=>mp,ByteBuffer:()=>$l,Encoding:()=>Af,FILE_IDENTIFIER_LENGTH:()=>Cr,SIZEOF_INT:()=>or,SIZEOF_SHORT:()=>af,SIZE_PREFIX_LENGTH:()=>ct,float32:()=>O_,float64:()=>V_,int32:()=>Qa,isLittleEndian:()=>ql});var _t=O(()=>{Xl();Xl();Xl();Xl();Bb();Wb();R3();Db()});var Yat,Mb,Z3=O(()=>{_t();({ByteBuffer:Yat}=Et),Mb=(t,e,i)=>{t=new Uint8Array(t);let n=new i[`${e}COLLECTIONT`];return i[`${e}COLLECTION`][`getRootAs${e}COLLECTION`](new Yat(t)).unpackTo(n),n}});var Ub=O(()=>{_t()});var I3=O(()=>{_t();Ub()});var p3=O(()=>{Ub();I3()});var ka,G_,fp=O(()=>{_t();ka=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsFrequencyRange(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsFrequencyRange(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}LOWER(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat64(this.bb_pos+e):0}static startFrequencyRange(e){e.startObject(2)}static addLower(e,i){e.addFieldFloat64(0,i,0)}static addUpper(e,i){e.addFieldFloat64(1,i,0)}static endFrequencyRange(e){return e.endObject()}static createFrequencyRange(e,i,n){return t.startFrequencyRange(e),t.addLower(e,i),t.addUpper(e,n),t.endFrequencyRange(e)}unpack(){return new G_(this.LOWER(),this.UPPER())}unpackTo(e){e.LOWER=this.LOWER(),e.UPPER=this.UPPER()}},G_=class{constructor(e=0,i=0){this.LOWER=e,this.UPPER=i}pack(e){return ka.createFrequencyRange(e,this.LOWER,this.UPPER)}}});var bA,B_,Qb=O(()=>{_t();fp();bA=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsBand(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsBand(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}NAME(e){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__string(this.bb_pos+i,e):null}FREQUENCY_RANGE(e){let i=this.bb.__offset(this.bb_pos,6);return i?(e||new ka).__init(this.bb.__indirect(this.bb_pos+i),this.bb):null}static startBand(e){e.startObject(2)}static addName(e,i){e.addFieldOffset(0,i,0)}static addFrequencyRange(e,i){e.addFieldOffset(1,i,0)}static endBand(e){return e.endObject()}unpack(){return new B_(this.NAME(),this.FREQUENCY_RANGE()!==null?this.FREQUENCY_RANGE().unpack():null)}unpackTo(e){e.NAME=this.NAME(),e.FREQUENCY_RANGE=this.FREQUENCY_RANGE()!==null?this.FREQUENCY_RANGE().unpack():null}},B_=class{constructor(e=null,i=null){this.NAME=e,this.FREQUENCY_RANGE=i}pack(e){let i=this.NAME!==null?e.createString(this.NAME):0,n=this.FREQUENCY_RANGE!==null?this.FREQUENCY_RANGE.pack(e):0;return bA.startBand(e),bA.addName(e,i),bA.addFrequencyRange(e,n),bA.endBand(e)}}});var Nc,kb=O(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(Nc||(Nc={}))});var bc,Lb=O(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(bc||(bc={}))});var Fc,yb=O(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(Fc||(Fc={}))});var Yc,wb=O(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(Yc||(Yc={}))});var td,W_,xb=O(()=>{_t();td=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsStokesParameters(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsStokesParameters(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}I(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}Q(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat64(this.bb_pos+e):0}U(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readFloat64(this.bb_pos+e):0}V(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readFloat64(this.bb_pos+e):0}static startStokesParameters(e){e.startObject(4)}static addI(e,i){e.addFieldFloat64(0,i,0)}static addQ(e,i){e.addFieldFloat64(1,i,0)}static addU(e,i){e.addFieldFloat64(2,i,0)}static addV(e,i){e.addFieldFloat64(3,i,0)}static endStokesParameters(e){return e.endObject()}static createStokesParameters(e,i,n,s,o){return t.startStokesParameters(e),t.addI(e,i),t.addQ(e,n),t.addU(e,s),t.addV(e,o),t.endStokesParameters(e)}unpack(){return new W_(this.I(),this.Q(),this.U(),this.V())}unpackTo(e){e.I=this.I(),e.Q=this.Q(),e.U=this.U(),e.V=this.V()}},W_=class{constructor(e=0,i=0,n=0,s=0){this.I=e,this.Q=i,this.U=n,this.V=s}pack(e){return td.createStokesParameters(e,this.I,this.Q,this.U,this.V)}}});var Zi,D_,Ep=O(()=>{_t();Qb();kb();Lb();fp();yb();wb();xb();Zi=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsIDM(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsIDM(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$IDM")}ID(e){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__string(this.bb_pos+i,e):null}NAME(e){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__string(this.bb_pos+i,e):null}DATA_MODE(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readInt8(this.bb_pos+e):Nc.REAL}UPLINK(e){let i=this.bb.__offset(this.bb_pos,10);return i?(e||new ka).__init(this.bb.__indirect(this.bb_pos+i),this.bb):null}DOWNLINK(e){let i=this.bb.__offset(this.bb_pos,12);return i?(e||new ka).__init(this.bb.__indirect(this.bb_pos+i),this.bb):null}BEACON(e){let i=this.bb.__offset(this.bb_pos,14);return i?(e||new ka).__init(this.bb.__indirect(this.bb_pos+i),this.bb):null}BAND(e,i){let n=this.bb.__offset(this.bb_pos,16);return n?(i||new bA).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}bandLength(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.__vector_len(this.bb_pos+e):0}POLARIZATION_TYPE(){let e=this.bb.__offset(this.bb_pos,18);return e?this.bb.readInt8(this.bb_pos+e):Fc.linear}SIMPLE_POLARIZATION(){let e=this.bb.__offset(this.bb_pos,20);return e?this.bb.readInt8(this.bb_pos+e):Yc.vertical}STOKES_PARAMETERS(e){let i=this.bb.__offset(this.bb_pos,22);return i?(e||new td).__init(this.bb.__indirect(this.bb_pos+i),this.bb):null}POWER_REQUIRED(){let e=this.bb.__offset(this.bb_pos,24);return e?this.bb.readFloat64(this.bb_pos+e):0}POWER_TYPE(e){let i=this.bb.__offset(this.bb_pos,26);return i?this.bb.__string(this.bb_pos+i,e):null}TRANSMIT(){let e=this.bb.__offset(this.bb_pos,28);return e?!!this.bb.readInt8(this.bb_pos+e):!1}RECEIVE(){let e=this.bb.__offset(this.bb_pos,30);return e?!!this.bb.readInt8(this.bb_pos+e):!1}SENSOR_TYPE(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readInt8(this.bb_pos+e):bc.UNKNOWN}SOURCE(e){let i=this.bb.__offset(this.bb_pos,34);return i?this.bb.__string(this.bb_pos+i,e):null}LAST_OB_TIME(e){let i=this.bb.__offset(this.bb_pos,36);return i?this.bb.__string(this.bb_pos+i,e):null}LOWER_LEFT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,38);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_LEFT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,40);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_RIGHT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_LEFT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_RIGHT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_RIGHT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_RIGHT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,50);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_LEFT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,52);return e?this.bb.readFloat64(this.bb_pos+e):0}RIGHT_GEO_BELT_LIMIT(){let e=this.bb.__offset(this.bb_pos,54);return e?this.bb.readFloat64(this.bb_pos+e):0}LEFT_GEO_BELT_LIMIT(){let e=this.bb.__offset(this.bb_pos,56);return e?this.bb.readFloat64(this.bb_pos+e):0}MAGNITUDE_LIMIT(){let e=this.bb.__offset(this.bb_pos,58);return e?this.bb.readFloat64(this.bb_pos+e):0}TASKABLE(){let e=this.bb.__offset(this.bb_pos,60);return e?!!this.bb.readInt8(this.bb_pos+e):!1}static startIDM(e){e.startObject(29)}static addId(e,i){e.addFieldOffset(0,i,0)}static addName(e,i){e.addFieldOffset(1,i,0)}static addDataMode(e,i){e.addFieldInt8(2,i,Nc.REAL)}static addUplink(e,i){e.addFieldOffset(3,i,0)}static addDownlink(e,i){e.addFieldOffset(4,i,0)}static addBeacon(e,i){e.addFieldOffset(5,i,0)}static addBand(e,i){e.addFieldOffset(6,i,0)}static createBandVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startBandVector(e,i){e.startVector(4,i,4)}static addPolarizationType(e,i){e.addFieldInt8(7,i,Fc.linear)}static addSimplePolarization(e,i){e.addFieldInt8(8,i,Yc.vertical)}static addStokesParameters(e,i){e.addFieldOffset(9,i,0)}static addPowerRequired(e,i){e.addFieldFloat64(10,i,0)}static addPowerType(e,i){e.addFieldOffset(11,i,0)}static addTransmit(e,i){e.addFieldInt8(12,+i,0)}static addReceive(e,i){e.addFieldInt8(13,+i,0)}static addSensorType(e,i){e.addFieldInt8(14,i,bc.UNKNOWN)}static addSource(e,i){e.addFieldOffset(15,i,0)}static addLastObTime(e,i){e.addFieldOffset(16,i,0)}static addLowerLeftElevationLimit(e,i){e.addFieldFloat64(17,i,0)}static addUpperLeftAzimuthLimit(e,i){e.addFieldFloat64(18,i,0)}static addLowerRightElevationLimit(e,i){e.addFieldFloat64(19,i,0)}static addLowerLeftAzimuthLimit(e,i){e.addFieldFloat64(20,i,0)}static addUpperRightElevationLimit(e,i){e.addFieldFloat64(21,i,0)}static addUpperRightAzimuthLimit(e,i){e.addFieldFloat64(22,i,0)}static addLowerRightAzimuthLimit(e,i){e.addFieldFloat64(23,i,0)}static addUpperLeftElevationLimit(e,i){e.addFieldFloat64(24,i,0)}static addRightGeoBeltLimit(e,i){e.addFieldFloat64(25,i,0)}static addLeftGeoBeltLimit(e,i){e.addFieldFloat64(26,i,0)}static addMagnitudeLimit(e,i){e.addFieldFloat64(27,i,0)}static addTaskable(e,i){e.addFieldInt8(28,+i,0)}static endIDM(e){return e.endObject()}static finishIDMBuffer(e,i){e.finish(i,"$IDM")}static finishSizePrefixedIDMBuffer(e,i){e.finish(i,"$IDM",!0)}unpack(){return new D_(this.ID(),this.NAME(),this.DATA_MODE(),this.UPLINK()!==null?this.UPLINK().unpack():null,this.DOWNLINK()!==null?this.DOWNLINK().unpack():null,this.BEACON()!==null?this.BEACON().unpack():null,this.bb.createObjList(this.BAND.bind(this),this.bandLength()),this.POLARIZATION_TYPE(),this.SIMPLE_POLARIZATION(),this.STOKES_PARAMETERS()!==null?this.STOKES_PARAMETERS().unpack():null,this.POWER_REQUIRED(),this.POWER_TYPE(),this.TRANSMIT(),this.RECEIVE(),this.SENSOR_TYPE(),this.SOURCE(),this.LAST_OB_TIME(),this.LOWER_LEFT_ELEVATION_LIMIT(),this.UPPER_LEFT_AZIMUTH_LIMIT(),this.LOWER_RIGHT_ELEVATION_LIMIT(),this.LOWER_LEFT_AZIMUTH_LIMIT(),this.UPPER_RIGHT_ELEVATION_LIMIT(),this.UPPER_RIGHT_AZIMUTH_LIMIT(),this.LOWER_RIGHT_AZIMUTH_LIMIT(),this.UPPER_LEFT_ELEVATION_LIMIT(),this.RIGHT_GEO_BELT_LIMIT(),this.LEFT_GEO_BELT_LIMIT(),this.MAGNITUDE_LIMIT(),this.TASKABLE())}unpackTo(e){e.ID=this.ID(),e.NAME=this.NAME(),e.DATA_MODE=this.DATA_MODE(),e.UPLINK=this.UPLINK()!==null?this.UPLINK().unpack():null,e.DOWNLINK=this.DOWNLINK()!==null?this.DOWNLINK().unpack():null,e.BEACON=this.BEACON()!==null?this.BEACON().unpack():null,e.BAND=this.bb.createObjList(this.BAND.bind(this),this.bandLength()),e.POLARIZATION_TYPE=this.POLARIZATION_TYPE(),e.SIMPLE_POLARIZATION=this.SIMPLE_POLARIZATION(),e.STOKES_PARAMETERS=this.STOKES_PARAMETERS()!==null?this.STOKES_PARAMETERS().unpack():null,e.POWER_REQUIRED=this.POWER_REQUIRED(),e.POWER_TYPE=this.POWER_TYPE(),e.TRANSMIT=this.TRANSMIT(),e.RECEIVE=this.RECEIVE(),e.SENSOR_TYPE=this.SENSOR_TYPE(),e.SOURCE=this.SOURCE(),e.LAST_OB_TIME=this.LAST_OB_TIME(),e.LOWER_LEFT_ELEVATION_LIMIT=this.LOWER_LEFT_ELEVATION_LIMIT(),e.UPPER_LEFT_AZIMUTH_LIMIT=this.UPPER_LEFT_AZIMUTH_LIMIT(),e.LOWER_RIGHT_ELEVATION_LIMIT=this.LOWER_RIGHT_ELEVATION_LIMIT(),e.LOWER_LEFT_AZIMUTH_LIMIT=this.LOWER_LEFT_AZIMUTH_LIMIT(),e.UPPER_RIGHT_ELEVATION_LIMIT=this.UPPER_RIGHT_ELEVATION_LIMIT(),e.UPPER_RIGHT_AZIMUTH_LIMIT=this.UPPER_RIGHT_AZIMUTH_LIMIT(),e.LOWER_RIGHT_AZIMUTH_LIMIT=this.LOWER_RIGHT_AZIMUTH_LIMIT(),e.UPPER_LEFT_ELEVATION_LIMIT=this.UPPER_LEFT_ELEVATION_LIMIT(),e.RIGHT_GEO_BELT_LIMIT=this.RIGHT_GEO_BELT_LIMIT(),e.LEFT_GEO_BELT_LIMIT=this.LEFT_GEO_BELT_LIMIT(),e.MAGNITUDE_LIMIT=this.MAGNITUDE_LIMIT(),e.TASKABLE=this.TASKABLE()}},D_=class{constructor(e=null,i=null,n=Nc.REAL,s=null,o=null,r=null,a=[],h=Fc.linear,A=Yc.vertical,d=null,f=0,E=null,_=!1,R=!1,I=bc.UNKNOWN,C=null,N=null,T=0,F=0,b=0,G=0,M=0,Q=0,U=0,k=0,y=0,c=0,g=0,V=!1){this.ID=e,this.NAME=i,this.DATA_MODE=n,this.UPLINK=s,this.DOWNLINK=o,this.BEACON=r,this.BAND=a,this.POLARIZATION_TYPE=h,this.SIMPLE_POLARIZATION=A,this.STOKES_PARAMETERS=d,this.POWER_REQUIRED=f,this.POWER_TYPE=E,this.TRANSMIT=_,this.RECEIVE=R,this.SENSOR_TYPE=I,this.SOURCE=C,this.LAST_OB_TIME=N,this.LOWER_LEFT_ELEVATION_LIMIT=T,this.UPPER_LEFT_AZIMUTH_LIMIT=F,this.LOWER_RIGHT_ELEVATION_LIMIT=b,this.LOWER_LEFT_AZIMUTH_LIMIT=G,this.UPPER_RIGHT_ELEVATION_LIMIT=M,this.UPPER_RIGHT_AZIMUTH_LIMIT=Q,this.LOWER_RIGHT_AZIMUTH_LIMIT=U,this.UPPER_LEFT_ELEVATION_LIMIT=k,this.RIGHT_GEO_BELT_LIMIT=y,this.LEFT_GEO_BELT_LIMIT=c,this.MAGNITUDE_LIMIT=g,this.TASKABLE=V}pack(e){let i=this.ID!==null?e.createString(this.ID):0,n=this.NAME!==null?e.createString(this.NAME):0,s=this.UPLINK!==null?this.UPLINK.pack(e):0,o=this.DOWNLINK!==null?this.DOWNLINK.pack(e):0,r=this.BEACON!==null?this.BEACON.pack(e):0,a=Zi.createBandVector(e,e.createObjectOffsetList(this.BAND)),h=this.STOKES_PARAMETERS!==null?this.STOKES_PARAMETERS.pack(e):0,A=this.POWER_TYPE!==null?e.createString(this.POWER_TYPE):0,d=this.SOURCE!==null?e.createString(this.SOURCE):0,f=this.LAST_OB_TIME!==null?e.createString(this.LAST_OB_TIME):0;return Zi.startIDM(e),Zi.addId(e,i),Zi.addName(e,n),Zi.addDataMode(e,this.DATA_MODE),Zi.addUplink(e,s),Zi.addDownlink(e,o),Zi.addBeacon(e,r),Zi.addBand(e,a),Zi.addPolarizationType(e,this.POLARIZATION_TYPE),Zi.addSimplePolarization(e,this.SIMPLE_POLARIZATION),Zi.addStokesParameters(e,h),Zi.addPowerRequired(e,this.POWER_REQUIRED),Zi.addPowerType(e,A),Zi.addTransmit(e,this.TRANSMIT),Zi.addReceive(e,this.RECEIVE),Zi.addSensorType(e,this.SENSOR_TYPE),Zi.addSource(e,d),Zi.addLastObTime(e,f),Zi.addLowerLeftElevationLimit(e,this.LOWER_LEFT_ELEVATION_LIMIT),Zi.addUpperLeftAzimuthLimit(e,this.UPPER_LEFT_AZIMUTH_LIMIT),Zi.addLowerRightElevationLimit(e,this.LOWER_RIGHT_ELEVATION_LIMIT),Zi.addLowerLeftAzimuthLimit(e,this.LOWER_LEFT_AZIMUTH_LIMIT),Zi.addUpperRightElevationLimit(e,this.UPPER_RIGHT_ELEVATION_LIMIT),Zi.addUpperRightAzimuthLimit(e,this.UPPER_RIGHT_AZIMUTH_LIMIT),Zi.addLowerRightAzimuthLimit(e,this.LOWER_RIGHT_AZIMUTH_LIMIT),Zi.addUpperLeftElevationLimit(e,this.UPPER_LEFT_ELEVATION_LIMIT),Zi.addRightGeoBeltLimit(e,this.RIGHT_GEO_BELT_LIMIT),Zi.addLeftGeoBeltLimit(e,this.LEFT_GEO_BELT_LIMIT),Zi.addMagnitudeLimit(e,this.MAGNITUDE_LIMIT),Zi.addTaskable(e,this.TASKABLE),Zi.endIDM(e)}}});var FA,M_,_p=O(()=>{_t();Ep();FA=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsPLD(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsPLD(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$PLD")}PAYLOAD_DURATION(e){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__string(this.bb_pos+i,e):null}MASS_AT_LAUNCH(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat32(this.bb_pos+e):0}DIMENSIONS(e){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__string(this.bb_pos+i,e):null}SOLAR_ARRAY_AREA(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readFloat32(this.bb_pos+e):0}SOLAR_ARRAY_DIMENSIONS(e){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.__string(this.bb_pos+i,e):null}NOMINAL_OPERATIONAL_LIFETIME(e){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.__string(this.bb_pos+i,e):null}INSTRUMENTS(e,i){let n=this.bb.__offset(this.bb_pos,16);return n?(i||new Zi).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}instrumentsLength(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.__vector_len(this.bb_pos+e):0}static startPLD(e){e.startObject(7)}static addPayloadDuration(e,i){e.addFieldOffset(0,i,0)}static addMassAtLaunch(e,i){e.addFieldFloat32(1,i,0)}static addDimensions(e,i){e.addFieldOffset(2,i,0)}static addSolarArrayArea(e,i){e.addFieldFloat32(3,i,0)}static addSolarArrayDimensions(e,i){e.addFieldOffset(4,i,0)}static addNominalOperationalLifetime(e,i){e.addFieldOffset(5,i,0)}static addInstruments(e,i){e.addFieldOffset(6,i,0)}static createInstrumentsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startInstrumentsVector(e,i){e.startVector(4,i,4)}static endPLD(e){return e.endObject()}static finishPLDBuffer(e,i){e.finish(i,"$PLD")}static finishSizePrefixedPLDBuffer(e,i){e.finish(i,"$PLD",!0)}static createPLD(e,i,n,s,o,r,a,h){return t.startPLD(e),t.addPayloadDuration(e,i),t.addMassAtLaunch(e,n),t.addDimensions(e,s),t.addSolarArrayArea(e,o),t.addSolarArrayDimensions(e,r),t.addNominalOperationalLifetime(e,a),t.addInstruments(e,h),t.endPLD(e)}unpack(){return new M_(this.PAYLOAD_DURATION(),this.MASS_AT_LAUNCH(),this.DIMENSIONS(),this.SOLAR_ARRAY_AREA(),this.SOLAR_ARRAY_DIMENSIONS(),this.NOMINAL_OPERATIONAL_LIFETIME(),this.bb.createObjList(this.INSTRUMENTS.bind(this),this.instrumentsLength()))}unpackTo(e){e.PAYLOAD_DURATION=this.PAYLOAD_DURATION(),e.MASS_AT_LAUNCH=this.MASS_AT_LAUNCH(),e.DIMENSIONS=this.DIMENSIONS(),e.SOLAR_ARRAY_AREA=this.SOLAR_ARRAY_AREA(),e.SOLAR_ARRAY_DIMENSIONS=this.SOLAR_ARRAY_DIMENSIONS(),e.NOMINAL_OPERATIONAL_LIFETIME=this.NOMINAL_OPERATIONAL_LIFETIME(),e.INSTRUMENTS=this.bb.createObjList(this.INSTRUMENTS.bind(this),this.instrumentsLength())}},M_=class{constructor(e=null,i=0,n=null,s=0,o=null,r=null,a=[]){this.PAYLOAD_DURATION=e,this.MASS_AT_LAUNCH=i,this.DIMENSIONS=n,this.SOLAR_ARRAY_AREA=s,this.SOLAR_ARRAY_DIMENSIONS=o,this.NOMINAL_OPERATIONAL_LIFETIME=r,this.INSTRUMENTS=a}pack(e){let i=this.PAYLOAD_DURATION!==null?e.createString(this.PAYLOAD_DURATION):0,n=this.DIMENSIONS!==null?e.createString(this.DIMENSIONS):0,s=this.SOLAR_ARRAY_DIMENSIONS!==null?e.createString(this.SOLAR_ARRAY_DIMENSIONS):0,o=this.NOMINAL_OPERATIONAL_LIFETIME!==null?e.createString(this.NOMINAL_OPERATIONAL_LIFETIME):0,r=FA.createInstrumentsVector(e,e.createObjectOffsetList(this.INSTRUMENTS));return FA.createPLD(e,i,this.MASS_AT_LAUNCH,n,this.SOLAR_ARRAY_AREA,s,o,r)}}});var Sc,Pb=O(()=>{(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(Sc||(Sc={}))});var Oc,Jb=O(()=>{(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(Oc||(Oc={}))});var Vc,jb=O(()=>{(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(Vc||(Vc={}))});var Gc,Hb=O(()=>{(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(Gc||(Gc={}))});var Bc,vb=O(()=>{(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(Bc||(Bc={}))});var Wc,U_,zb=O(()=>{_t();_p();Pb();Jb();jb();Hb();vb();Wc=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsCAT(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsCAT(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$CAT")}OBJECT_NAME(e){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__string(this.bb_pos+i,e):null}OBJECT_ID(e){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__string(this.bb_pos+i,e):null}NORAD_CAT_ID(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readUint32(this.bb_pos+e):0}OBJECT_TYPE(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readInt8(this.bb_pos+e):Vc.UNKNOWN}OPS_STATUS_CODE(){let e=this.bb.__offset(this.bb_pos,12);return e?this.bb.readInt8(this.bb_pos+e):Gc.UNKNOWN}OWNER(e){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.__string(this.bb_pos+i,e):null}LAUNCH_DATE(e){let i=this.bb.__offset(this.bb_pos,16);return i?this.bb.__string(this.bb_pos+i,e):null}LAUNCH_SITE(e){let i=this.bb.__offset(this.bb_pos,18);return i?this.bb.__string(this.bb_pos+i,e):null}DECAY_DATE(e){let i=this.bb.__offset(this.bb_pos,20);return i?this.bb.__string(this.bb_pos+i,e):null}PERIOD(){let e=this.bb.__offset(this.bb_pos,22);return e?this.bb.readFloat64(this.bb_pos+e):0}INCLINATION(){let e=this.bb.__offset(this.bb_pos,24);return e?this.bb.readFloat64(this.bb_pos+e):0}APOGEE(){let e=this.bb.__offset(this.bb_pos,26);return e?this.bb.readFloat64(this.bb_pos+e):0}PERIGEE(){let e=this.bb.__offset(this.bb_pos,28);return e?this.bb.readFloat64(this.bb_pos+e):0}RCS(){let e=this.bb.__offset(this.bb_pos,30);return e?this.bb.readFloat64(this.bb_pos+e):0}DATA_STATUS_CODE(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readInt8(this.bb_pos+e):Sc.NO_CURRENT_ELEMENTS}ORBIT_CENTER(e){let i=this.bb.__offset(this.bb_pos,34);return i?this.bb.__string(this.bb_pos+i,e):null}ORBIT_TYPE(){let e=this.bb.__offset(this.bb_pos,36);return e?this.bb.readInt8(this.bb_pos+e):Bc.ORBIT}DEPLOYMENT_DATE(e){let i=this.bb.__offset(this.bb_pos,38);return i?this.bb.__string(this.bb_pos+i,e):null}MANEUVERABLE(){let e=this.bb.__offset(this.bb_pos,40);return e?!!this.bb.readInt8(this.bb_pos+e):!1}SIZE(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS_TYPE(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readInt8(this.bb_pos+e):Oc.DRY}PAYLOADS(e,i){let n=this.bb.__offset(this.bb_pos,48);return n?(i||new FA).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}payloadsLength(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.__vector_len(this.bb_pos+e):0}static startCAT(e){e.startObject(23)}static addObjectName(e,i){e.addFieldOffset(0,i,0)}static addObjectId(e,i){e.addFieldOffset(1,i,0)}static addNoradCatId(e,i){e.addFieldInt32(2,i,0)}static addObjectType(e,i){e.addFieldInt8(3,i,Vc.UNKNOWN)}static addOpsStatusCode(e,i){e.addFieldInt8(4,i,Gc.UNKNOWN)}static addOwner(e,i){e.addFieldOffset(5,i,0)}static addLaunchDate(e,i){e.addFieldOffset(6,i,0)}static addLaunchSite(e,i){e.addFieldOffset(7,i,0)}static addDecayDate(e,i){e.addFieldOffset(8,i,0)}static addPeriod(e,i){e.addFieldFloat64(9,i,0)}static addInclination(e,i){e.addFieldFloat64(10,i,0)}static addApogee(e,i){e.addFieldFloat64(11,i,0)}static addPerigee(e,i){e.addFieldFloat64(12,i,0)}static addRcs(e,i){e.addFieldFloat64(13,i,0)}static addDataStatusCode(e,i){e.addFieldInt8(14,i,Sc.NO_CURRENT_ELEMENTS)}static addOrbitCenter(e,i){e.addFieldOffset(15,i,0)}static addOrbitType(e,i){e.addFieldInt8(16,i,Bc.ORBIT)}static addDeploymentDate(e,i){e.addFieldOffset(17,i,0)}static addManeuverable(e,i){e.addFieldInt8(18,+i,0)}static addSize(e,i){e.addFieldFloat64(19,i,0)}static addMass(e,i){e.addFieldFloat64(20,i,0)}static addMassType(e,i){e.addFieldInt8(21,i,Oc.DRY)}static addPayloads(e,i){e.addFieldOffset(22,i,0)}static createPayloadsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startPayloadsVector(e,i){e.startVector(4,i,4)}static endCAT(e){return e.endObject()}static finishCATBuffer(e,i){e.finish(i,"$CAT")}static finishSizePrefixedCATBuffer(e,i){e.finish(i,"$CAT",!0)}static createCAT(e,i,n,s,o,r,a,h,A,d,f,E,_,R,I,C,N,T,F,b,G,M,Q,U){return t.startCAT(e),t.addObjectName(e,i),t.addObjectId(e,n),t.addNoradCatId(e,s),t.addObjectType(e,o),t.addOpsStatusCode(e,r),t.addOwner(e,a),t.addLaunchDate(e,h),t.addLaunchSite(e,A),t.addDecayDate(e,d),t.addPeriod(e,f),t.addInclination(e,E),t.addApogee(e,_),t.addPerigee(e,R),t.addRcs(e,I),t.addDataStatusCode(e,C),t.addOrbitCenter(e,N),t.addOrbitType(e,T),t.addDeploymentDate(e,F),t.addManeuverable(e,b),t.addSize(e,G),t.addMass(e,M),t.addMassType(e,Q),t.addPayloads(e,U),t.endCAT(e)}unpack(){return new U_(this.OBJECT_NAME(),this.OBJECT_ID(),this.NORAD_CAT_ID(),this.OBJECT_TYPE(),this.OPS_STATUS_CODE(),this.OWNER(),this.LAUNCH_DATE(),this.LAUNCH_SITE(),this.DECAY_DATE(),this.PERIOD(),this.INCLINATION(),this.APOGEE(),this.PERIGEE(),this.RCS(),this.DATA_STATUS_CODE(),this.ORBIT_CENTER(),this.ORBIT_TYPE(),this.DEPLOYMENT_DATE(),this.MANEUVERABLE(),this.SIZE(),this.MASS(),this.MASS_TYPE(),this.bb.createObjList(this.PAYLOADS.bind(this),this.payloadsLength()))}unpackTo(e){e.OBJECT_NAME=this.OBJECT_NAME(),e.OBJECT_ID=this.OBJECT_ID(),e.NORAD_CAT_ID=this.NORAD_CAT_ID(),e.OBJECT_TYPE=this.OBJECT_TYPE(),e.OPS_STATUS_CODE=this.OPS_STATUS_CODE(),e.OWNER=this.OWNER(),e.LAUNCH_DATE=this.LAUNCH_DATE(),e.LAUNCH_SITE=this.LAUNCH_SITE(),e.DECAY_DATE=this.DECAY_DATE(),e.PERIOD=this.PERIOD(),e.INCLINATION=this.INCLINATION(),e.APOGEE=this.APOGEE(),e.PERIGEE=this.PERIGEE(),e.RCS=this.RCS(),e.DATA_STATUS_CODE=this.DATA_STATUS_CODE(),e.ORBIT_CENTER=this.ORBIT_CENTER(),e.ORBIT_TYPE=this.ORBIT_TYPE(),e.DEPLOYMENT_DATE=this.DEPLOYMENT_DATE(),e.MANEUVERABLE=this.MANEUVERABLE(),e.SIZE=this.SIZE(),e.MASS=this.MASS(),e.MASS_TYPE=this.MASS_TYPE(),e.PAYLOADS=this.bb.createObjList(this.PAYLOADS.bind(this),this.payloadsLength())}},U_=class{constructor(e=null,i=null,n=0,s=Vc.UNKNOWN,o=Gc.UNKNOWN,r=null,a=null,h=null,A=null,d=0,f=0,E=0,_=0,R=0,I=Sc.NO_CURRENT_ELEMENTS,C=null,N=Bc.ORBIT,T=null,F=!1,b=0,G=0,M=Oc.DRY,Q=[]){this.OBJECT_NAME=e,this.OBJECT_ID=i,this.NORAD_CAT_ID=n,this.OBJECT_TYPE=s,this.OPS_STATUS_CODE=o,this.OWNER=r,this.LAUNCH_DATE=a,this.LAUNCH_SITE=h,this.DECAY_DATE=A,this.PERIOD=d,this.INCLINATION=f,this.APOGEE=E,this.PERIGEE=_,this.RCS=R,this.DATA_STATUS_CODE=I,this.ORBIT_CENTER=C,this.ORBIT_TYPE=N,this.DEPLOYMENT_DATE=T,this.MANEUVERABLE=F,this.SIZE=b,this.MASS=G,this.MASS_TYPE=M,this.PAYLOADS=Q}pack(e){let i=this.OBJECT_NAME!==null?e.createString(this.OBJECT_NAME):0,n=this.OBJECT_ID!==null?e.createString(this.OBJECT_ID):0,s=this.OWNER!==null?e.createString(this.OWNER):0,o=this.LAUNCH_DATE!==null?e.createString(this.LAUNCH_DATE):0,r=this.LAUNCH_SITE!==null?e.createString(this.LAUNCH_SITE):0,a=this.DECAY_DATE!==null?e.createString(this.DECAY_DATE):0,h=this.ORBIT_CENTER!==null?e.createString(this.ORBIT_CENTER):0,A=this.DEPLOYMENT_DATE!==null?e.createString(this.DEPLOYMENT_DATE):0,d=Wc.createPayloadsVector(e,e.createObjectOffsetList(this.PAYLOADS));return Wc.createCAT(e,i,n,this.NORAD_CAT_ID,this.OBJECT_TYPE,this.OPS_STATUS_CODE,s,o,r,a,this.PERIOD,this.INCLINATION,this.APOGEE,this.PERIGEE,this.RCS,this.DATA_STATUS_CODE,h,this.ORBIT_TYPE,A,this.MANEUVERABLE,this.SIZE,this.MASS,this.MASS_TYPE,d)}}});var hf,Q_,u3=O(()=>{_t();zb();hf=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsCATCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsCATCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new Wc).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startCATCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endCATCOLLECTION(e){return e.endObject()}static createCATCOLLECTION(e,i){return t.startCATCOLLECTION(e),t.addRecords(e,i),t.endCATCOLLECTION(e)}unpack(){return new Q_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},Q_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=hf.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return hf.createCATCOLLECTION(e,i)}}});var cf,k_,C3=O(()=>{_t();Ep();cf=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsIDMCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsIDMCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new Zi).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startIDMCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endIDMCOLLECTION(e){return e.endObject()}static createIDMCOLLECTION(e,i){return t.startIDMCOLLECTION(e),t.addRecords(e,i),t.endIDMCOLLECTION(e)}unpack(){return new k_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},k_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=cf.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return cf.createIDMCOLLECTION(e,i)}}});var lf,L_,g3=O(()=>{_t();_p();lf=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsPLDCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsPLDCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new FA).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startPLDCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endPLDCOLLECTION(e){return e.endObject()}static createPLDCOLLECTION(e,i){return t.startPLDCOLLECTION(e),t.addRecords(e,i),t.endPLDCOLLECTION(e)}unpack(){return new L_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},L_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=lf.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return lf.createPLDCOLLECTION(e,i)}}});var ed={};He(ed,{Band:()=>bA,BandT:()=>B_,CAT:()=>Wc,CATCOLLECTION:()=>hf,CATCOLLECTIONT:()=>Q_,CATT:()=>U_,DataMode:()=>Nc,DeviceType:()=>bc,FrequencyRange:()=>ka,FrequencyRangeT:()=>G_,IDM:()=>Zi,IDMCOLLECTION:()=>cf,IDMCOLLECTIONT:()=>k_,IDMT:()=>D_,PLD:()=>FA,PLDCOLLECTION:()=>lf,PLDCOLLECTIONT:()=>L_,PLDT:()=>M_,PolarizationType:()=>Fc,SimplePolarization:()=>Yc,StokesParameters:()=>td,StokesParametersT:()=>W_,dataStatusCode:()=>Sc,massType:()=>Oc,objectType:()=>Vc,opsStatusCode:()=>Gc,orbitType:()=>Bc});var T3=O(()=>{Qb();zb();u3();kb();Lb();fp();Ep();C3();_p();g3();yb();wb();xb();Pb();Jb();jb();Hb();vb()});var Kb=O(()=>{_t()});var Rp=O(()=>{_t()});var Xb=O(()=>{_t();Rp()});var Zp,qb=O(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(Zp||(Zp={}))});var Ip,$b=O(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(Ip||(Ip={}))});var pp,tF=O(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(pp||(pp={}))});var up,eF=O(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(up||(up={}))});var iF=O(()=>{_t()});var Cp=O(()=>{_t();Xb();qb();$b();Rp();tF();eF();iF()});var gp=O(()=>{_t();Cp()});var Tp,nF=O(()=>{(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(Tp||(Tp={}))});var Np,sF=O(()=>{(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(Np||(Np={}))});var bp,oF=O(()=>{(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(bp||(bp={}))});var Fp,rF=O(()=>{(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(Fp||(Fp={}))});var Yp,aF=O(()=>{(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(Yp||(Yp={}))});var Sp=O(()=>{_t();gp();nF();sF();oF();rF();aF()});var S3=O(()=>{_t();Sp()});var Op,AF=O(()=>{(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(Op||(Op={}))});var hF=O(()=>{_t();AF()});var Vp=O(()=>{_t();Kb();hF()});var Gp,cF=O(()=>{(function(t){t[t.CALCULATED=0]="CALCULATED",t[t.DEFAULT=1]="DEFAULT"})(Gp||(Gp={}))});var df,y_=O(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(df||(df={}))});var lF=O(()=>{_t();Sp();Vp();cF();y_()});var Bp=O(()=>{_t()});var Wp,dF=O(()=>{(function(t){t[t.ELLIPSOID=0]="ELLIPSOID",t[t.BOX=1]="BOX"})(Wp||(Wp={}))});var mF=O(()=>{_t();lF();Bp();y_();dF()});var G3=O(()=>{_t();mF()});var B3=O(()=>{_t();Vp()});var W3=O(()=>{_t();Cp()});var D3=O(()=>{_t();gp()});var M3=O(()=>{_t();Bp()});var fF=O(()=>{_t();y_()});var U3=O(()=>{_t();fF()});var Q3=O(()=>{Kb();Xb();Sp();S3();mF();G3();lF();hF();qb();$b();Vp();B3();Rp();Cp();W3();AF();gp();D3();Bp();M3();tF();fF();U3();eF();iF();cF();nF();sF();oF();rF();aF();y_();dF()});var EF=O(()=>{_t()});var k3=O(()=>{_t();EF()});var L3=O(()=>{EF();k3()});var Dp=O(()=>{_t()});var _F=O(()=>{_t();Dp()});var Mp,RF=O(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(Mp||(Mp={}))});var Up,ZF=O(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(Up||(Up={}))});var Qp,IF=O(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(Qp||(Qp={}))});var kp,pF=O(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(kp||(kp={}))});var uF=O(()=>{_t()});var Lp=O(()=>{_t();_F();RF();ZF();Dp();IF();pF();uF()});var yp=O(()=>{_t();Lp()});var wp,CF=O(()=>{(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(wp||(wp={}))});var xp,gF=O(()=>{(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(xp||(xp={}))});var Pp,TF=O(()=>{(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(Pp||(Pp={}))});var Jp,NF=O(()=>{(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(Jp||(Jp={}))});var jp,bF=O(()=>{(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(jp||(jp={}))});var Hp=O(()=>{_t();yp();CF();gF();TF();NF();bF()});var J3=O(()=>{_t();Hp()});var FF=O(()=>{_t();Hp()});var j3=O(()=>{_t();FF()});var H3=O(()=>{_t();Lp()});var v3=O(()=>{_t();yp()});var z3=O(()=>{_F();Hp();J3();FF();j3();RF();ZF();Dp();Lp();H3();yp();v3();IF();pF();uF();CF();gF();TF();NF();bF()});var YF=O(()=>{_t()});var K3=O(()=>{_t();YF()});var X3=O(()=>{YF();K3()});var SF=O(()=>{_t()});var q3=O(()=>{_t();SF()});var $3=O(()=>{SF();q3()});var w_,vp=O(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(w_||(w_={}))});var OF=O(()=>{_t();vp()});var t4=O(()=>{_t();OF()});var VF=O(()=>{_t();vp()});var e4=O(()=>{_t();VF()});var i4=O(()=>{OF();t4();VF();e4();vp()});var zp,GF=O(()=>{(function(t){t[t.OBSERVED=0]="OBSERVED",t[t.PREDICTED=1]="PREDICTED"})(zp||(zp={}))});var BF=O(()=>{_t();GF()});var n4=O(()=>{_t();BF()});var s4=O(()=>{GF();BF();n4()});var WF=O(()=>{_t()});var Kp,DF=O(()=>{(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(Kp||(Kp={}))});var MF=O(()=>{_t();DF()});var UF=O(()=>{_t();WF();MF()});var o4=O(()=>{_t();UF()});var r4=O(()=>{WF();MF();UF();o4();DF()});var Xp,QF=O(()=>{(function(t){t[t.OUTLIER=0]="OUTLIER"})(Xp||(Xp={}))});var kF=O(()=>{_t();QF()});var LF=O(()=>{_t();kF()});var a4=O(()=>{_t();LF()});var A4=O(()=>{LF();a4();kF();QF()});var qp=O(()=>{_t()});var yF=O(()=>{_t();qp()});var $p,wF=O(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})($p||($p={}))});var tu,xF=O(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(tu||(tu={}))});var eu,PF=O(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(eu||(eu={}))});var iu,JF=O(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(iu||(iu={}))});var jF=O(()=>{_t()});var HF=O(()=>{_t();yF();wF();xF();qp();PF();JF();jF()});var c4=O(()=>{_t();HF()});var l4=O(()=>{yF();wF();xF();qp();HF();c4();PF();JF();jF()});var vF=O(()=>{_t()});var nu=O(()=>{_t()});var m4=O(()=>{_t();nu()});var su=O(()=>{_t()});var zF=O(()=>{_t();su()});var ou,KF=O(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(ou||(ou={}))});var ru,XF=O(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(ru||(ru={}))});var au,qF=O(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(au||(au={}))});var Au,$F=O(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(Au||(Au={}))});var tY=O(()=>{_t()});var x_=O(()=>{_t();zF();KF();XF();su();qF();$F();tY()});var hu=O(()=>{_t();x_()});var cu,iY=O(()=>{(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(cu||(cu={}))});var lu,nY=O(()=>{(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(lu||(lu={}))});var du,sY=O(()=>{(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(du||(du={}))});var mu,oY=O(()=>{(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(mu||(mu={}))});var fu,rY=O(()=>{(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(fu||(fu={}))});var Eu=O(()=>{_t();hu();iY();nY();sY();oY();rY()});var R4=O(()=>{_t();Eu()});var _u,aY=O(()=>{(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(_u||(_u={}))});var AY=O(()=>{_t();aY()});var Ru,hY=O(()=>{(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(Ru||(Ru={}))});var cY=O(()=>{_t();hY()});var Zu=O(()=>{_t();vF();AY()});var I4=O(()=>{_t();Zu()});var lY=O(()=>{_t()});var p4=O(()=>{_t();x_()});var dY=O(()=>{_t();cY()});var mY=O(()=>{_t()});var Iu=O(()=>{_t();dY();mY()});var pu,fY=O(()=>{(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(pu||(pu={}))});var uu=O(()=>{_t();lY();x_();fY()});var EY=O(()=>{_t();nu();Eu();Zu();Iu();uu()});var g4=O(()=>{_t();EY()});var T4=O(()=>{_t();hu()});var N4=O(()=>{_t();Iu()});var b4=O(()=>{_t();uu()});var F4=O(()=>{vF();nu();m4();zF();Eu();R4();AY();KF();XF();cY();hY();Zu();I4();su();lY();x_();p4();aY();EY();g4();hu();T4();qF();Iu();N4();uu();b4();dY();mY();$F();fY();tY();iY();nY();sY();oY();rY()});var Cu,_Y=O(()=>{(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(Cu||(Cu={}))});var RY=O(()=>{_t();_Y()});var Y4=O(()=>{_t();RY()});var S4=O(()=>{RY();Y4();_Y()});var P_,gu=O(()=>{(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(P_||(P_={}))});var ZY=O(()=>{_t();gu()});var O4=O(()=>{_t();ZY()});var IY=O(()=>{_t();gu()});var V4=O(()=>{_t();IY()});var G4=O(()=>{ZY();O4();IY();V4();gu()});var mf,J_=O(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(mf||(mf={}))});var pY=O(()=>{_t();J_()});var uY=O(()=>{_t()});var j_,Tu=O(()=>{(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(j_||(j_={}))});var CY=O(()=>{_t();pY();uY();J_();Tu()});var gY=O(()=>{_t();CY()});var B4=O(()=>{_t();gY()});var TY=O(()=>{_t();J_()});var W4=O(()=>{_t();TY()});var NY=O(()=>{_t();Tu()});var D4=O(()=>{_t();NY()});var M4=O(()=>{gY();B4();TY();W4();NY();D4();pY();CY();uY();J_();Tu()});var Kr,Nu=O(()=>{(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(Kr||(Kr={}))});var id,H_,bY=O(()=>{_t();Nu();id=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsMET(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsMET(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$MET")}MEAN_ELEMENT_THEORY(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):Kr.SGP4}static startMET(e){e.startObject(1)}static addMeanElementTheory(e,i){e.addFieldInt8(0,i,Kr.SGP4)}static endMET(e){return e.endObject()}static finishMETBuffer(e,i){e.finish(i,"$MET")}static finishSizePrefixedMETBuffer(e,i){e.finish(i,"$MET",!0)}static createMET(e,i){return t.startMET(e),t.addMeanElementTheory(e,i),t.endMET(e)}unpack(){return new H_(this.MEAN_ELEMENT_THEORY())}unpackTo(e){e.MEAN_ELEMENT_THEORY=this.MEAN_ELEMENT_THEORY()}},H_=class{constructor(e=Kr.SGP4){this.MEAN_ELEMENT_THEORY=e}pack(e){return id.createMET(e,this.MEAN_ELEMENT_THEORY)}}});var ff,v_,U4=O(()=>{_t();bY();ff=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsMETCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsMETCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new id).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startMETCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endMETCOLLECTION(e){return e.endObject()}static createMETCOLLECTION(e,i){return t.startMETCOLLECTION(e),t.addRecords(e,i),t.endMETCOLLECTION(e)}unpack(){return new v_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},v_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=ff.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return ff.createMETCOLLECTION(e,i)}}});var Dc,FY=O(()=>{(function(t){t[t.SGP=0]="SGP",t[t.SGP4=1]="SGP4",t[t.SDP4=2]="SDP4",t[t.SGP8=3]="SGP8",t[t.SDP8=4]="SDP8"})(Dc||(Dc={}))});var Lo,bu=O(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(Lo||(Lo={}))});var Xr,Fu=O(()=>{(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(Xr||(Xr={}))});var nd,z_,YY=O(()=>{_t();FY();Nu();bu();Fu();nd=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsOMM(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsOMM(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$OMM")}CCSDS_OMM_VERS(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}CREATION_DATE(e){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__string(this.bb_pos+i,e):null}ORIGINATOR(e){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__string(this.bb_pos+i,e):null}OBJECT_NAME(e){let i=this.bb.__offset(this.bb_pos,10);return i?this.bb.__string(this.bb_pos+i,e):null}OBJECT_ID(e){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.__string(this.bb_pos+i,e):null}CENTER_NAME(e){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.__string(this.bb_pos+i,e):null}REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.readInt8(this.bb_pos+e):Lo.TEME}REFERENCE_FRAME_EPOCH(e){let i=this.bb.__offset(this.bb_pos,18);return i?this.bb.__string(this.bb_pos+i,e):null}TIME_SYSTEM(){let e=this.bb.__offset(this.bb_pos,20);return e?this.bb.readInt8(this.bb_pos+e):Xr.UTC}MEAN_ELEMENT_THEORY(){let e=this.bb.__offset(this.bb_pos,22);return e?this.bb.readInt8(this.bb_pos+e):Kr.SGP4}COMMENT(e){let i=this.bb.__offset(this.bb_pos,24);return i?this.bb.__string(this.bb_pos+i,e):null}EPOCH(e){let i=this.bb.__offset(this.bb_pos,26);return i?this.bb.__string(this.bb_pos+i,e):null}SEMI_MAJOR_AXIS(){let e=this.bb.__offset(this.bb_pos,28);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION(){let e=this.bb.__offset(this.bb_pos,30);return e?this.bb.readFloat64(this.bb_pos+e):0}ECCENTRICITY(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readFloat64(this.bb_pos+e):0}INCLINATION(){let e=this.bb.__offset(this.bb_pos,34);return e?this.bb.readFloat64(this.bb_pos+e):0}RA_OF_ASC_NODE(){let e=this.bb.__offset(this.bb_pos,36);return e?this.bb.readFloat64(this.bb_pos+e):0}ARG_OF_PERICENTER(){let e=this.bb.__offset(this.bb_pos,38);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_ANOMALY(){let e=this.bb.__offset(this.bb_pos,40);return e?this.bb.readFloat64(this.bb_pos+e):0}GM(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}SOLAR_RAD_AREA(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readFloat64(this.bb_pos+e):0}SOLAR_RAD_COEFF(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.readFloat64(this.bb_pos+e):0}DRAG_AREA(){let e=this.bb.__offset(this.bb_pos,50);return e?this.bb.readFloat64(this.bb_pos+e):0}DRAG_COEFF(){let e=this.bb.__offset(this.bb_pos,52);return e?this.bb.readFloat64(this.bb_pos+e):0}EPHEMERIS_TYPE(){let e=this.bb.__offset(this.bb_pos,54);return e?this.bb.readInt8(this.bb_pos+e):Dc.SGP4}CLASSIFICATION_TYPE(e){let i=this.bb.__offset(this.bb_pos,56);return i?this.bb.__string(this.bb_pos+i,e):null}NORAD_CAT_ID(){let e=this.bb.__offset(this.bb_pos,58);return e?this.bb.readUint32(this.bb_pos+e):0}ELEMENT_SET_NO(){let e=this.bb.__offset(this.bb_pos,60);return e?this.bb.readUint32(this.bb_pos+e):0}REV_AT_EPOCH(){let e=this.bb.__offset(this.bb_pos,62);return e?this.bb.readFloat64(this.bb_pos+e):0}BSTAR(){let e=this.bb.__offset(this.bb_pos,64);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION_DOT(){let e=this.bb.__offset(this.bb_pos,66);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION_DDOT(){let e=this.bb.__offset(this.bb_pos,68);return e?this.bb.readFloat64(this.bb_pos+e):0}COV_REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,70);return e?this.bb.readInt8(this.bb_pos+e):Lo.RSW}CX_X(){let e=this.bb.__offset(this.bb_pos,72);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_X(){let e=this.bb.__offset(this.bb_pos,74);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_Y(){let e=this.bb.__offset(this.bb_pos,76);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_X(){let e=this.bb.__offset(this.bb_pos,78);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_Y(){let e=this.bb.__offset(this.bb_pos,80);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_Z(){let e=this.bb.__offset(this.bb_pos,82);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_X(){let e=this.bb.__offset(this.bb_pos,84);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_Y(){let e=this.bb.__offset(this.bb_pos,86);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_Z(){let e=this.bb.__offset(this.bb_pos,88);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,90);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_X(){let e=this.bb.__offset(this.bb_pos,92);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Y(){let e=this.bb.__offset(this.bb_pos,94);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Z(){let e=this.bb.__offset(this.bb_pos,96);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,98);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Y_DOT(){let e=this.bb.__offset(this.bb_pos,100);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_X(){let e=this.bb.__offset(this.bb_pos,102);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Y(){let e=this.bb.__offset(this.bb_pos,104);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Z(){let e=this.bb.__offset(this.bb_pos,106);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,108);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Y_DOT(){let e=this.bb.__offset(this.bb_pos,110);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Z_DOT(){let e=this.bb.__offset(this.bb_pos,112);return e?this.bb.readFloat64(this.bb_pos+e):0}USER_DEFINED_BIP_0044_TYPE(){let e=this.bb.__offset(this.bb_pos,114);return e?this.bb.readUint32(this.bb_pos+e):0}USER_DEFINED_OBJECT_DESIGNATOR(e){let i=this.bb.__offset(this.bb_pos,116);return i?this.bb.__string(this.bb_pos+i,e):null}USER_DEFINED_EARTH_MODEL(e){let i=this.bb.__offset(this.bb_pos,118);return i?this.bb.__string(this.bb_pos+i,e):null}USER_DEFINED_EPOCH_TIMESTAMP(){let e=this.bb.__offset(this.bb_pos,120);return e?this.bb.readFloat64(this.bb_pos+e):0}USER_DEFINED_MICROSECONDS(){let e=this.bb.__offset(this.bb_pos,122);return e?this.bb.readFloat64(this.bb_pos+e):0}static startOMM(e){e.startObject(60)}static addCcsdsOmmVers(e,i){e.addFieldFloat64(0,i,0)}static addCreationDate(e,i){e.addFieldOffset(1,i,0)}static addOriginator(e,i){e.addFieldOffset(2,i,0)}static addObjectName(e,i){e.addFieldOffset(3,i,0)}static addObjectId(e,i){e.addFieldOffset(4,i,0)}static addCenterName(e,i){e.addFieldOffset(5,i,0)}static addReferenceFrame(e,i){e.addFieldInt8(6,i,Lo.TEME)}static addReferenceFrameEpoch(e,i){e.addFieldOffset(7,i,0)}static addTimeSystem(e,i){e.addFieldInt8(8,i,Xr.UTC)}static addMeanElementTheory(e,i){e.addFieldInt8(9,i,Kr.SGP4)}static addComment(e,i){e.addFieldOffset(10,i,0)}static addEpoch(e,i){e.addFieldOffset(11,i,0)}static addSemiMajorAxis(e,i){e.addFieldFloat64(12,i,0)}static addMeanMotion(e,i){e.addFieldFloat64(13,i,0)}static addEccentricity(e,i){e.addFieldFloat64(14,i,0)}static addInclination(e,i){e.addFieldFloat64(15,i,0)}static addRaOfAscNode(e,i){e.addFieldFloat64(16,i,0)}static addArgOfPericenter(e,i){e.addFieldFloat64(17,i,0)}static addMeanAnomaly(e,i){e.addFieldFloat64(18,i,0)}static addGm(e,i){e.addFieldFloat64(19,i,0)}static addMass(e,i){e.addFieldFloat64(20,i,0)}static addSolarRadArea(e,i){e.addFieldFloat64(21,i,0)}static addSolarRadCoeff(e,i){e.addFieldFloat64(22,i,0)}static addDragArea(e,i){e.addFieldFloat64(23,i,0)}static addDragCoeff(e,i){e.addFieldFloat64(24,i,0)}static addEphemerisType(e,i){e.addFieldInt8(25,i,Dc.SGP4)}static addClassificationType(e,i){e.addFieldOffset(26,i,0)}static addNoradCatId(e,i){e.addFieldInt32(27,i,0)}static addElementSetNo(e,i){e.addFieldInt32(28,i,0)}static addRevAtEpoch(e,i){e.addFieldFloat64(29,i,0)}static addBstar(e,i){e.addFieldFloat64(30,i,0)}static addMeanMotionDot(e,i){e.addFieldFloat64(31,i,0)}static addMeanMotionDdot(e,i){e.addFieldFloat64(32,i,0)}static addCovReferenceFrame(e,i){e.addFieldInt8(33,i,Lo.RSW)}static addCxX(e,i){e.addFieldFloat64(34,i,0)}static addCyX(e,i){e.addFieldFloat64(35,i,0)}static addCyY(e,i){e.addFieldFloat64(36,i,0)}static addCzX(e,i){e.addFieldFloat64(37,i,0)}static addCzY(e,i){e.addFieldFloat64(38,i,0)}static addCzZ(e,i){e.addFieldFloat64(39,i,0)}static addCxDotX(e,i){e.addFieldFloat64(40,i,0)}static addCxDotY(e,i){e.addFieldFloat64(41,i,0)}static addCxDotZ(e,i){e.addFieldFloat64(42,i,0)}static addCxDotXDot(e,i){e.addFieldFloat64(43,i,0)}static addCyDotX(e,i){e.addFieldFloat64(44,i,0)}static addCyDotY(e,i){e.addFieldFloat64(45,i,0)}static addCyDotZ(e,i){e.addFieldFloat64(46,i,0)}static addCyDotXDot(e,i){e.addFieldFloat64(47,i,0)}static addCyDotYDot(e,i){e.addFieldFloat64(48,i,0)}static addCzDotX(e,i){e.addFieldFloat64(49,i,0)}static addCzDotY(e,i){e.addFieldFloat64(50,i,0)}static addCzDotZ(e,i){e.addFieldFloat64(51,i,0)}static addCzDotXDot(e,i){e.addFieldFloat64(52,i,0)}static addCzDotYDot(e,i){e.addFieldFloat64(53,i,0)}static addCzDotZDot(e,i){e.addFieldFloat64(54,i,0)}static addUserDefinedBip0044Type(e,i){e.addFieldInt32(55,i,0)}static addUserDefinedObjectDesignator(e,i){e.addFieldOffset(56,i,0)}static addUserDefinedEarthModel(e,i){e.addFieldOffset(57,i,0)}static addUserDefinedEpochTimestamp(e,i){e.addFieldFloat64(58,i,0)}static addUserDefinedMicroseconds(e,i){e.addFieldFloat64(59,i,0)}static endOMM(e){return e.endObject()}static finishOMMBuffer(e,i){e.finish(i,"$OMM")}static finishSizePrefixedOMMBuffer(e,i){e.finish(i,"$OMM",!0)}static createOMM(e,i,n,s,o,r,a,h,A,d,f,E,_,R,I,C,N,T,F,b,G,M,Q,U,k,y,c,g,V,D,w,x,H,j,X,tt,B,It,gt,Yt,Mt,Ct,zt,kt,Jt,Wt,Ft,ee,ce,je,Oe,Me,Ue,Ce,be,ni,ze,Ge,Ui,Ri,si){return t.startOMM(e),t.addCcsdsOmmVers(e,i),t.addCreationDate(e,n),t.addOriginator(e,s),t.addObjectName(e,o),t.addObjectId(e,r),t.addCenterName(e,a),t.addReferenceFrame(e,h),t.addReferenceFrameEpoch(e,A),t.addTimeSystem(e,d),t.addMeanElementTheory(e,f),t.addComment(e,E),t.addEpoch(e,_),t.addSemiMajorAxis(e,R),t.addMeanMotion(e,I),t.addEccentricity(e,C),t.addInclination(e,N),t.addRaOfAscNode(e,T),t.addArgOfPericenter(e,F),t.addMeanAnomaly(e,b),t.addGm(e,G),t.addMass(e,M),t.addSolarRadArea(e,Q),t.addSolarRadCoeff(e,U),t.addDragArea(e,k),t.addDragCoeff(e,y),t.addEphemerisType(e,c),t.addClassificationType(e,g),t.addNoradCatId(e,V),t.addElementSetNo(e,D),t.addRevAtEpoch(e,w),t.addBstar(e,x),t.addMeanMotionDot(e,H),t.addMeanMotionDdot(e,j),t.addCovReferenceFrame(e,X),t.addCxX(e,tt),t.addCyX(e,B),t.addCyY(e,It),t.addCzX(e,gt),t.addCzY(e,Yt),t.addCzZ(e,Mt),t.addCxDotX(e,Ct),t.addCxDotY(e,zt),t.addCxDotZ(e,kt),t.addCxDotXDot(e,Jt),t.addCyDotX(e,Wt),t.addCyDotY(e,Ft),t.addCyDotZ(e,ee),t.addCyDotXDot(e,ce),t.addCyDotYDot(e,je),t.addCzDotX(e,Oe),t.addCzDotY(e,Me),t.addCzDotZ(e,Ue),t.addCzDotXDot(e,Ce),t.addCzDotYDot(e,be),t.addCzDotZDot(e,ni),t.addUserDefinedBip0044Type(e,ze),t.addUserDefinedObjectDesignator(e,Ge),t.addUserDefinedEarthModel(e,Ui),t.addUserDefinedEpochTimestamp(e,Ri),t.addUserDefinedMicroseconds(e,si),t.endOMM(e)}unpack(){return new z_(this.CCSDS_OMM_VERS(),this.CREATION_DATE(),this.ORIGINATOR(),this.OBJECT_NAME(),this.OBJECT_ID(),this.CENTER_NAME(),this.REFERENCE_FRAME(),this.REFERENCE_FRAME_EPOCH(),this.TIME_SYSTEM(),this.MEAN_ELEMENT_THEORY(),this.COMMENT(),this.EPOCH(),this.SEMI_MAJOR_AXIS(),this.MEAN_MOTION(),this.ECCENTRICITY(),this.INCLINATION(),this.RA_OF_ASC_NODE(),this.ARG_OF_PERICENTER(),this.MEAN_ANOMALY(),this.GM(),this.MASS(),this.SOLAR_RAD_AREA(),this.SOLAR_RAD_COEFF(),this.DRAG_AREA(),this.DRAG_COEFF(),this.EPHEMERIS_TYPE(),this.CLASSIFICATION_TYPE(),this.NORAD_CAT_ID(),this.ELEMENT_SET_NO(),this.REV_AT_EPOCH(),this.BSTAR(),this.MEAN_MOTION_DOT(),this.MEAN_MOTION_DDOT(),this.COV_REFERENCE_FRAME(),this.CX_X(),this.CY_X(),this.CY_Y(),this.CZ_X(),this.CZ_Y(),this.CZ_Z(),this.CX_DOT_X(),this.CX_DOT_Y(),this.CX_DOT_Z(),this.CX_DOT_X_DOT(),this.CY_DOT_X(),this.CY_DOT_Y(),this.CY_DOT_Z(),this.CY_DOT_X_DOT(),this.CY_DOT_Y_DOT(),this.CZ_DOT_X(),this.CZ_DOT_Y(),this.CZ_DOT_Z(),this.CZ_DOT_X_DOT(),this.CZ_DOT_Y_DOT(),this.CZ_DOT_Z_DOT(),this.USER_DEFINED_BIP_0044_TYPE(),this.USER_DEFINED_OBJECT_DESIGNATOR(),this.USER_DEFINED_EARTH_MODEL(),this.USER_DEFINED_EPOCH_TIMESTAMP(),this.USER_DEFINED_MICROSECONDS())}unpackTo(e){e.CCSDS_OMM_VERS=this.CCSDS_OMM_VERS(),e.CREATION_DATE=this.CREATION_DATE(),e.ORIGINATOR=this.ORIGINATOR(),e.OBJECT_NAME=this.OBJECT_NAME(),e.OBJECT_ID=this.OBJECT_ID(),e.CENTER_NAME=this.CENTER_NAME(),e.REFERENCE_FRAME=this.REFERENCE_FRAME(),e.REFERENCE_FRAME_EPOCH=this.REFERENCE_FRAME_EPOCH(),e.TIME_SYSTEM=this.TIME_SYSTEM(),e.MEAN_ELEMENT_THEORY=this.MEAN_ELEMENT_THEORY(),e.COMMENT=this.COMMENT(),e.EPOCH=this.EPOCH(),e.SEMI_MAJOR_AXIS=this.SEMI_MAJOR_AXIS(),e.MEAN_MOTION=this.MEAN_MOTION(),e.ECCENTRICITY=this.ECCENTRICITY(),e.INCLINATION=this.INCLINATION(),e.RA_OF_ASC_NODE=this.RA_OF_ASC_NODE(),e.ARG_OF_PERICENTER=this.ARG_OF_PERICENTER(),e.MEAN_ANOMALY=this.MEAN_ANOMALY(),e.GM=this.GM(),e.MASS=this.MASS(),e.SOLAR_RAD_AREA=this.SOLAR_RAD_AREA(),e.SOLAR_RAD_COEFF=this.SOLAR_RAD_COEFF(),e.DRAG_AREA=this.DRAG_AREA(),e.DRAG_COEFF=this.DRAG_COEFF(),e.EPHEMERIS_TYPE=this.EPHEMERIS_TYPE(),e.CLASSIFICATION_TYPE=this.CLASSIFICATION_TYPE(),e.NORAD_CAT_ID=this.NORAD_CAT_ID(),e.ELEMENT_SET_NO=this.ELEMENT_SET_NO(),e.REV_AT_EPOCH=this.REV_AT_EPOCH(),e.BSTAR=this.BSTAR(),e.MEAN_MOTION_DOT=this.MEAN_MOTION_DOT(),e.MEAN_MOTION_DDOT=this.MEAN_MOTION_DDOT(),e.COV_REFERENCE_FRAME=this.COV_REFERENCE_FRAME(),e.CX_X=this.CX_X(),e.CY_X=this.CY_X(),e.CY_Y=this.CY_Y(),e.CZ_X=this.CZ_X(),e.CZ_Y=this.CZ_Y(),e.CZ_Z=this.CZ_Z(),e.CX_DOT_X=this.CX_DOT_X(),e.CX_DOT_Y=this.CX_DOT_Y(),e.CX_DOT_Z=this.CX_DOT_Z(),e.CX_DOT_X_DOT=this.CX_DOT_X_DOT(),e.CY_DOT_X=this.CY_DOT_X(),e.CY_DOT_Y=this.CY_DOT_Y(),e.CY_DOT_Z=this.CY_DOT_Z(),e.CY_DOT_X_DOT=this.CY_DOT_X_DOT(),e.CY_DOT_Y_DOT=this.CY_DOT_Y_DOT(),e.CZ_DOT_X=this.CZ_DOT_X(),e.CZ_DOT_Y=this.CZ_DOT_Y(),e.CZ_DOT_Z=this.CZ_DOT_Z(),e.CZ_DOT_X_DOT=this.CZ_DOT_X_DOT(),e.CZ_DOT_Y_DOT=this.CZ_DOT_Y_DOT(),e.CZ_DOT_Z_DOT=this.CZ_DOT_Z_DOT(),e.USER_DEFINED_BIP_0044_TYPE=this.USER_DEFINED_BIP_0044_TYPE(),e.USER_DEFINED_OBJECT_DESIGNATOR=this.USER_DEFINED_OBJECT_DESIGNATOR(),e.USER_DEFINED_EARTH_MODEL=this.USER_DEFINED_EARTH_MODEL(),e.USER_DEFINED_EPOCH_TIMESTAMP=this.USER_DEFINED_EPOCH_TIMESTAMP(),e.USER_DEFINED_MICROSECONDS=this.USER_DEFINED_MICROSECONDS()}},z_=class{constructor(e=0,i=null,n=null,s=null,o=null,r=null,a=Lo.TEME,h=null,A=Xr.UTC,d=Kr.SGP4,f=null,E=null,_=0,R=0,I=0,C=0,N=0,T=0,F=0,b=0,G=0,M=0,Q=0,U=0,k=0,y=Dc.SGP4,c=null,g=0,V=0,D=0,w=0,x=0,H=0,j=Lo.RSW,X=0,tt=0,B=0,It=0,gt=0,Yt=0,Mt=0,Ct=0,zt=0,kt=0,Jt=0,Wt=0,Ft=0,ee=0,ce=0,je=0,Oe=0,Me=0,Ue=0,Ce=0,be=0,ni=0,ze=null,Ge=null,Ui=0,Ri=0){this.CCSDS_OMM_VERS=e,this.CREATION_DATE=i,this.ORIGINATOR=n,this.OBJECT_NAME=s,this.OBJECT_ID=o,this.CENTER_NAME=r,this.REFERENCE_FRAME=a,this.REFERENCE_FRAME_EPOCH=h,this.TIME_SYSTEM=A,this.MEAN_ELEMENT_THEORY=d,this.COMMENT=f,this.EPOCH=E,this.SEMI_MAJOR_AXIS=_,this.MEAN_MOTION=R,this.ECCENTRICITY=I,this.INCLINATION=C,this.RA_OF_ASC_NODE=N,this.ARG_OF_PERICENTER=T,this.MEAN_ANOMALY=F,this.GM=b,this.MASS=G,this.SOLAR_RAD_AREA=M,this.SOLAR_RAD_COEFF=Q,this.DRAG_AREA=U,this.DRAG_COEFF=k,this.EPHEMERIS_TYPE=y,this.CLASSIFICATION_TYPE=c,this.NORAD_CAT_ID=g,this.ELEMENT_SET_NO=V,this.REV_AT_EPOCH=D,this.BSTAR=w,this.MEAN_MOTION_DOT=x,this.MEAN_MOTION_DDOT=H,this.COV_REFERENCE_FRAME=j,this.CX_X=X,this.CY_X=tt,this.CY_Y=B,this.CZ_X=It,this.CZ_Y=gt,this.CZ_Z=Yt,this.CX_DOT_X=Mt,this.CX_DOT_Y=Ct,this.CX_DOT_Z=zt,this.CX_DOT_X_DOT=kt,this.CY_DOT_X=Jt,this.CY_DOT_Y=Wt,this.CY_DOT_Z=Ft,this.CY_DOT_X_DOT=ee,this.CY_DOT_Y_DOT=ce,this.CZ_DOT_X=je,this.CZ_DOT_Y=Oe,this.CZ_DOT_Z=Me,this.CZ_DOT_X_DOT=Ue,this.CZ_DOT_Y_DOT=Ce,this.CZ_DOT_Z_DOT=be,this.USER_DEFINED_BIP_0044_TYPE=ni,this.USER_DEFINED_OBJECT_DESIGNATOR=ze,this.USER_DEFINED_EARTH_MODEL=Ge,this.USER_DEFINED_EPOCH_TIMESTAMP=Ui,this.USER_DEFINED_MICROSECONDS=Ri}pack(e){let i=this.CREATION_DATE!==null?e.createString(this.CREATION_DATE):0,n=this.ORIGINATOR!==null?e.createString(this.ORIGINATOR):0,s=this.OBJECT_NAME!==null?e.createString(this.OBJECT_NAME):0,o=this.OBJECT_ID!==null?e.createString(this.OBJECT_ID):0,r=this.CENTER_NAME!==null?e.createString(this.CENTER_NAME):0,a=this.REFERENCE_FRAME_EPOCH!==null?e.createString(this.REFERENCE_FRAME_EPOCH):0,h=this.COMMENT!==null?e.createString(this.COMMENT):0,A=this.EPOCH!==null?e.createString(this.EPOCH):0,d=this.CLASSIFICATION_TYPE!==null?e.createString(this.CLASSIFICATION_TYPE):0,f=this.USER_DEFINED_OBJECT_DESIGNATOR!==null?e.createString(this.USER_DEFINED_OBJECT_DESIGNATOR):0,E=this.USER_DEFINED_EARTH_MODEL!==null?e.createString(this.USER_DEFINED_EARTH_MODEL):0;return nd.createOMM(e,this.CCSDS_OMM_VERS,i,n,s,o,r,this.REFERENCE_FRAME,a,this.TIME_SYSTEM,this.MEAN_ELEMENT_THEORY,h,A,this.SEMI_MAJOR_AXIS,this.MEAN_MOTION,this.ECCENTRICITY,this.INCLINATION,this.RA_OF_ASC_NODE,this.ARG_OF_PERICENTER,this.MEAN_ANOMALY,this.GM,this.MASS,this.SOLAR_RAD_AREA,this.SOLAR_RAD_COEFF,this.DRAG_AREA,this.DRAG_COEFF,this.EPHEMERIS_TYPE,d,this.NORAD_CAT_ID,this.ELEMENT_SET_NO,this.REV_AT_EPOCH,this.BSTAR,this.MEAN_MOTION_DOT,this.MEAN_MOTION_DDOT,this.COV_REFERENCE_FRAME,this.CX_X,this.CY_X,this.CY_Y,this.CZ_X,this.CZ_Y,this.CZ_Z,this.CX_DOT_X,this.CX_DOT_Y,this.CX_DOT_Z,this.CX_DOT_X_DOT,this.CY_DOT_X,this.CY_DOT_Y,this.CY_DOT_Z,this.CY_DOT_X_DOT,this.CY_DOT_Y_DOT,this.CZ_DOT_X,this.CZ_DOT_Y,this.CZ_DOT_Z,this.CZ_DOT_X_DOT,this.CZ_DOT_Y_DOT,this.CZ_DOT_Z_DOT,this.USER_DEFINED_BIP_0044_TYPE,f,E,this.USER_DEFINED_EPOCH_TIMESTAMP,this.USER_DEFINED_MICROSECONDS)}}});var Ef,K_,Q4=O(()=>{_t();YY();Ef=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsOMMCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsOMMCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new nd).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startOMMCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endOMMCOLLECTION(e){return e.endObject()}static createOMMCOLLECTION(e,i){return t.startOMMCOLLECTION(e),t.addRecords(e,i),t.endOMMCOLLECTION(e)}unpack(){return new K_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},K_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=Ef.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return Ef.createOMMCOLLECTION(e,i)}}});var sd,X_,SY=O(()=>{_t();bu();sd=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsRFM(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsRFM(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$RFM")}REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):Lo.ECEF}static startRFM(e){e.startObject(1)}static addReferenceFrame(e,i){e.addFieldInt8(0,i,Lo.ECEF)}static endRFM(e){return e.endObject()}static finishRFMBuffer(e,i){e.finish(i,"$RFM")}static finishSizePrefixedRFMBuffer(e,i){e.finish(i,"$RFM",!0)}static createRFM(e,i){return t.startRFM(e),t.addReferenceFrame(e,i),t.endRFM(e)}unpack(){return new X_(this.REFERENCE_FRAME())}unpackTo(e){e.REFERENCE_FRAME=this.REFERENCE_FRAME()}},X_=class{constructor(e=Lo.ECEF){this.REFERENCE_FRAME=e}pack(e){return sd.createRFM(e,this.REFERENCE_FRAME)}}});var _f,q_,k4=O(()=>{_t();SY();_f=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsRFMCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsRFMCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new sd).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startRFMCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endRFMCOLLECTION(e){return e.endObject()}static createRFMCOLLECTION(e,i){return t.startRFMCOLLECTION(e),t.addRecords(e,i),t.endRFMCOLLECTION(e)}unpack(){return new q_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},q_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=_f.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return _f.createRFMCOLLECTION(e,i)}}});var od,$_,OY=O(()=>{_t();Fu();od=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsTIM(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsTIM(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$TIM")}TIME_SYSTEM(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):Xr.GMST}static startTIM(e){e.startObject(1)}static addTimeSystem(e,i){e.addFieldInt8(0,i,Xr.GMST)}static endTIM(e){return e.endObject()}static finishTIMBuffer(e,i){e.finish(i,"$TIM")}static finishSizePrefixedTIMBuffer(e,i){e.finish(i,"$TIM",!0)}static createTIM(e,i){return t.startTIM(e),t.addTimeSystem(e,i),t.endTIM(e)}unpack(){return new $_(this.TIME_SYSTEM())}unpackTo(e){e.TIME_SYSTEM=this.TIME_SYSTEM()}},$_=class{constructor(e=Xr.GMST){this.TIME_SYSTEM=e}pack(e){return od.createTIM(e,this.TIME_SYSTEM)}}});var Rf,tR,L4=O(()=>{_t();OY();Rf=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsTIMCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsTIMCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new od).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startTIMCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endTIMCOLLECTION(e){return e.endObject()}static createTIMCOLLECTION(e,i){return t.startTIMCOLLECTION(e),t.addRecords(e,i),t.endTIMCOLLECTION(e)}unpack(){return new tR(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},tR=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=Rf.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return Rf.createTIMCOLLECTION(e,i)}}});var rd={};He(rd,{MET:()=>id,METCOLLECTION:()=>ff,METCOLLECTIONT:()=>v_,METT:()=>H_,OMM:()=>nd,OMMCOLLECTION:()=>Ef,OMMCOLLECTIONT:()=>K_,OMMT:()=>z_,RFM:()=>sd,RFMCOLLECTION:()=>_f,RFMCOLLECTIONT:()=>q_,RFMT:()=>X_,TIM:()=>od,TIMCOLLECTION:()=>Rf,TIMCOLLECTIONT:()=>tR,TIMT:()=>$_,ephemerisType:()=>Dc,meanElementTheory:()=>Kr,refFrame:()=>Lo,timeSystem:()=>Xr});var y4=O(()=>{bY();U4();YY();Q4();SY();k4();OY();L4();FY();Nu();bu();Fu()});var VY=O(()=>{_t()});var w4=O(()=>{_t();VY()});var x4=O(()=>{VY();w4()});var Yu=O(()=>{_t()});var GY=O(()=>{_t();Yu()});var Su,BY=O(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(Su||(Su={}))});var Ou,WY=O(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(Ou||(Ou={}))});var Vu,DY=O(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(Vu||(Vu={}))});var Gu,MY=O(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(Gu||(Gu={}))});var UY=O(()=>{_t()});var Bu=O(()=>{_t();GY();BY();WY();Yu();DY();MY();UY()});var j4=O(()=>{_t();Bu()});var QY=O(()=>{_t();Bu()});var H4=O(()=>{_t();QY()});var v4=O(()=>{GY();BY();WY();Yu();Bu();j4();QY();H4();DY();MY();UY()});var kY=O(()=>{_t()});var z4=O(()=>{_t();kY()});var K4=O(()=>{kY();z4()});var LY=O(()=>{_t()});var yY=O(()=>{_t();LY()});var X4=O(()=>{_t();yY()});var q4=O(()=>{yY();X4();LY()});var wY=O(()=>{_t()});var eR=O(()=>{_t()});var $4=O(()=>{_t();eR()});var Wu=O(()=>{_t()});var PY=O(()=>{_t();Wu()});var Du,JY=O(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(Du||(Du={}))});var Mu,jY=O(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(Mu||(Mu={}))});var Uu,HY=O(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(Uu||(Uu={}))});var Qu,vY=O(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(Qu||(Qu={}))});var zY=O(()=>{_t()});var Zf=O(()=>{_t();PY();JY();jY();Wu();HY();vY();zY()});var iR=O(()=>{_t();Zf()});var Lu,KY=O(()=>{(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(Lu||(Lu={}))});var yu,XY=O(()=>{(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(yu||(yu={}))});var wu,qY=O(()=>{(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(wu||(wu={}))});var xu,$Y=O(()=>{(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(xu||(xu={}))});var Pu,tS=O(()=>{(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(Pu||(Pu={}))});var ad=O(()=>{_t();iR();KY();XY();qY();$Y();tS()});var eH=O(()=>{_t();ad()});var Ju,iS=O(()=>{(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(Ju||(Ju={}))});var nS=O(()=>{_t();iS()});var If=O(()=>{_t();wY();nS()});var ju,sS=O(()=>{(function(t){t[t.CALCULATED=0]="CALCULATED",t[t.DEFAULT=1]="DEFAULT"})(ju||(ju={}))});var La,YA=O(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(La||(La={}))});var oS=O(()=>{_t();ad();If();sS();YA()});var sR=O(()=>{_t()});var vu,rS=O(()=>{(function(t){t[t.ELLIPSOID=0]="ELLIPSOID",t[t.BOX=1]="BOX"})(vu||(vu={}))});var zu=O(()=>{_t();oS();sR();YA();rS()});var nH=O(()=>{_t();zu()});var Ku=O(()=>{_t()});var oH=O(()=>{_t();Ku()});var Xu=O(()=>{_t();ad()});var aH=O(()=>{_t();Xu()});var qu=O(()=>{_t()});var hH=O(()=>{_t();qu()});var $u,AS=O(()=>{(function(t){t[t.OBSERVED=0]="OBSERVED",t[t.PREDICTED=1]="PREDICTED"})($u||($u={}))});var tC=O(()=>{_t()});var lH=O(()=>{_t();tC()});var eC,hS=O(()=>{(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(eC||(eC={}))});var cS=O(()=>{_t();hS()});var iC=O(()=>{_t();YA()});var mH=O(()=>{_t();iC()});var nC=O(()=>{_t();AS()});var EH=O(()=>{_t();nC()});var _H=O(()=>{_t();If()});var lS=O(()=>{_t()});var sC,dS=O(()=>{(function(t){t[t.OUTLIER=0]="OUTLIER"})(sC||(sC={}))});var mS=O(()=>{_t();dS()});var oC=O(()=>{_t();mS()});var ZH=O(()=>{_t();oC()});var IH=O(()=>{_t();Zf()});var fS=O(()=>{_t();cS()});var ES=O(()=>{_t()});var oR=O(()=>{_t();fS();ES()});var rC,_S=O(()=>{(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(rC||(rC={}))});var rR=O(()=>{_t();lS();Zf();_S()});var aC=O(()=>{_t();eR();ad();If();oR();rR()});var uH=O(()=>{_t();aC()});var pf,aR=O(()=>{(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(pf||(pf={}))});var AC=O(()=>{_t();aR()});var gH=O(()=>{_t();AC()});var hC=O(()=>{_t();aR()});var NH=O(()=>{_t();hC()});var IS=O(()=>{_t();YA()});var pS=O(()=>{_t()});var uf,AR=O(()=>{(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(uf||(uf={}))});var uS=O(()=>{_t();IS();pS();YA();AR()});var cC=O(()=>{_t();uS()});var FH=O(()=>{_t();cC()});var lC,CS=O(()=>{(function(t){t[t.SGP=0]="SGP",t[t.SGP4=1]="SGP4",t[t.SDP4=2]="SDP4",t[t.SGP8=3]="SGP8",t[t.SDP8=4]="SDP8"})(lC||(lC={}))});var dC=O(()=>{_t();CS();aR();YA();AR()});var SH=O(()=>{_t();dC()});var mC=O(()=>{_t()});var VH=O(()=>{_t();mC()});var GH=O(()=>{_t();iR()});var BH=O(()=>{_t();sR()});var gS=O(()=>{_t()});var fC=O(()=>{_t();gS()});var DH=O(()=>{_t();fC()});var EC=O(()=>{_t();YA()});var TS=O(()=>{_t()});var _C=O(()=>{_t();TS()});var RC=O(()=>{_t();YA()});var ZC=O(()=>{_t();AR()});var IC,NS=O(()=>{eR();ad();zu();Ku();Xu();qu();tC();iC();nC();If();oC();Zf();aC();AC();hC();cC();dC();mC();iR();sR();fC();EC();oR();_C();rR();RC();ZC();(function(t){t[t.NONE=0]="NONE",t[t.MPE=1]="MPE",t[t.OMM=2]="OMM",t[t.PLD=3]="PLD",t[t.RFM=4]="RFM",t[t.CSM=5]="CSM",t[t.OSM=6]="OSM",t[t.CAT=7]="CAT",t[t.CRM=8]="CRM",t[t.SCM=9]="SCM",t[t.TDM=10]="TDM",t[t.IDM=11]="IDM",t[t.MET=12]="MET",t[t.ROC=13]="ROC",t[t.BOV=14]="BOV",t[t.EOP=15]="EOP",t[t.EOO=16]="EOO",t[t.EME=17]="EME",t[t.LDM=18]="LDM",t[t.PNM=19]="PNM",t[t.HYP=20]="HYP",t[t.CTR=21]="CTR",t[t.CDM=22]="CDM",t[t.SIT=23]="SIT",t[t.OEM=24]="OEM",t[t.TIM=25]="TIM",t[t.EPM=26]="EPM",t[t.PRG=27]="PRG"})(IC||(IC={}))});var bS=O(()=>{_t();NS()});var LH=O(()=>{_t();bS()});var yH=O(()=>{_t();EC()});var wH=O(()=>{_t();oR()});var xH=O(()=>{_t();_C()});var PH=O(()=>{_t();rR()});var JH=O(()=>{_t();RC()});var jH=O(()=>{_t();ZC()});var HH=O(()=>{wY();eR();$4();PY();ad();eH();zu();nH();oS();Ku();oH();Xu();aH();qu();hH();nS();JY();AS();jY();tC();lH();cS();hS();iC();mH();nC();EH();If();_H();Wu();lS();oC();ZH();Zf();IH();iS();aC();uH();AC();gH();hC();NH();cC();FH();dC();SH();mC();VH();iR();GH();sR();BH();fC();DH();HY();LH();EC();yH();oR();wH();bS();NS();TS();_C();xH();rR();PH();fS();ES();mS();dS();vY();_S();zY();RC();JH();ZC();jH();gS();IS();sS();KY();uS();pS();CS();XY();aR();qY();$Y();tS();YA();rS();AR()});var pC,FS=O(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(pC||(pC={}))});var YS=O(()=>{_t();FS()});var vH=O(()=>{_t();YS()});var zH=O(()=>{YS();vH();FS()});var uC,SS=O(()=>{(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(uC||(uC={}))});var OS=O(()=>{_t();SS()});var VS=O(()=>{_t();OS()});var GS=O(()=>{_t()});var BS=O(()=>{_t();VS();GS()});var KH=O(()=>{_t();BS()});var XH=O(()=>{OS();SS();BS();KH();VS();GS()});var WS=O(()=>{_t()});var DS=O(()=>{_t();WS()});var qH=O(()=>{_t();DS()});var $H=O(()=>{WS();DS();qH()});var CC=O(()=>{_t()});var MS=O(()=>{_t();CC()});var gC,US=O(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(gC||(gC={}))});var TC,QS=O(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(TC||(TC={}))});var kS=O(()=>{_t()});var NC,LS=O(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(NC||(NC={}))});var bC,yS=O(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(bC||(bC={}))});var wS=O(()=>{_t()});var FC=O(()=>{_t();MS();US();QS();CC();LS();yS();wS()});var iv=O(()=>{_t();FC()});var YC,xS=O(()=>{(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(YC||(YC={}))});var PS=O(()=>{_t();kS();FC();xS()});var nv=O(()=>{_t();PS()});var sv=O(()=>{MS();US();QS();CC();kS();FC();iv();LS();PS();nv();yS();xS();wS()});var hR,SC=O(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(hR||(hR={}))});var JS=O(()=>{_t();SC()});var ov=O(()=>{_t();JS()});var jS=O(()=>{_t();SC()});var rv=O(()=>{_t();jS()});var av=O(()=>{JS();ov();jS();rv();SC()});var OC,HS=O(()=>{(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(OC||(OC={}))});var vS=O(()=>{_t();HS()});var Av=O(()=>{_t();vS()});var hv=O(()=>{vS();Av();HS()});var zS=O(()=>{p3();T3();Q3();L3();z3();X3();$3();i4();s4();r4();A4();l4();F4();S4();G4();M4();y4();x4();v4();K4();q4();HH();zH();XH();$H();sv();av();hv()});var Fht,Yfe,Yht,Sfe,VC,cv=O(()=>{Ob();Vr();mt();Ht();_3();ic();fr();dn();Qn();zS();({OMMT:Fht,OMMCOLLECTIONT:Yfe}=rd),{CATT:Yht,CATCOLLECTIONT:Sfe}=ed;Number.prototype.map=function(t,e,i,n){return(this-t)*(n-i)/(e-t)+i};VC=class extends rf{constructor(e,i,n,s){super(e),this.constructor.prototype.wasmSchema={},this._position=new E3,this._spaceCatalog=n,this._wasmModule=i,this._velocity={getValue:(o,r)=>this._velocity.getValueInReferenceFrame(o,0,r),getValueInReferenceFrame:(o,r,a)=>{let h=new Float64Array(i.HEAP8.buffer,n.getVelocity(this.properties.wasmSpaceEntity,Ze.toDate(o).getTime(),r!==$i.TEME),3);if(m(a)||(a=new l),a=l.fromArray(h),r===$i.INERTIAL){let A=In.computeFixedToIcrfMatrix(o);if(m(A)){let d=new l;lt.multiplyByVector(A,a,d),a=d}}return a}},Object.defineProperty(this,"velocity",{get:()=>this._velocity,set:()=>{}}),Object.defineProperties(this._position,{isConstant:{get:()=>!1},_referenceFrame:{get:()=>this.entityCollection.referenceFrame},referenceFrame:{get:()=>this._referenceFrame}}),this._position.getValue=(o,r)=>this._position.getValueInReferenceFrame(o,0,r),this._position.getValueInReferenceFrame=(o,r,a)=>{let h=new Float64Array(i.HEAP8.buffer,n.getPositionInReferenceFrame(this.properties.wasmSpaceEntity,Ze.toDate(o).getTime(),r!==$i.TEME),3);if(m(a)||(a=new l),a=l.fromArray(h),r===$i.INERTIAL){let A=In.computeFixedToIcrfMatrix(o);if(m(A)){let d=new l;lt.multiplyByVector(A,a,d),a=d}}return a},this.children={add:o=>(o=this.entityCollection.add(o),this.entityCollection.allValues||(Object.defineProperty(this.entityCollection,"allValues",{get:function(){return this._entities.values}}),Object.defineProperty(this.entityCollection,"values",{get:function(){return this._entities.values.filter(r=>!r._isChild)}})),o._isChild=!0,o.parent=this,o.position=this.position,o),remove:o=>{this.entityCollection.remove(o);let r=this._children.indexOf(this);this._children.splice(r,1)},values:this._children},this.loadOMM(s)}loadOMM(e){let i=new this._wasmModule.PropagatedPositionProperty;i.addOMM(e),this.properties.wasmSpaceEntity=i,this.properties.CAT=this.properties._CAT||new Yht,this.properties._CAT._value.APOGEE=i.apogee,this.properties._CAT._value.PERIGEE=i.perigee,this.properties._CAT._value.PERIOD=i.period_sec,this.properties.OMM=this.properties._OMM||new Fht,this.properties._OMM._value.ECCENTRICITY=i.ecco,this.properties._OMM._value.SEMI_MAJOR_AXIS=i.semi_major_axis/1e3,this.properties._OMM._value.SEMI_MINOR_AXIS=i.semi_minor_axis/1e3,this.array_index=this.properties.wasmSpaceEntity.array_index,this.samplesPerPeriod=180,this.extraEpochSamples=60,this.resolutionAtEpoch=5,this.autoEpochResolution=!0,this.epochBlockSize=.5,this.extraSamples=5,this.eccentricityThreshold=.2,this.targetIntervalCount=20,this._orbitShowing=!1,this._coverageShowing=!1,this.referenceFrame=$i.RIC,this._position._clearCache=!0}get orbitShowing(){return this._orbitShowing}get coverageShowing(){return this._coverageShowing}showCoverage(e={show:!1}){this._coverageShowing=e.show,e.show?this.entityCollection.owner._coverageGroup.push(this):this.entityCollection.owner._coverageGroup.remove({id:this.id})}showOrbit(e={show:!1}){if(this._orbitShowing=e.show,!e.show){this.path=null;return}e&&(e.color=e.material),e?.referenceEntity?this._localReferenceEntity=e.referenceEntity:this._localReferenceEntity=void 0,this.path=this.path||{};let{material:i,width:n,leadTime:s,trailTime:o,resolution:r}=this.path;this.path=Object.assign({},{material:i||Zt.WHITE,width:n||1.25,leadTime:s||5e3,trailTime:o||5e3,resolution:r||120,show:!0},e);let{ecco:a,period_sec:h}=this.properties.wasmSpaceEntity,A=a<this.eccentricityThreshold;A||(this.extraSamples=a.map(this.eccentricityThreshold,.9,10,50),this.samplesPerPeriod=a.map(this.eccentricityThreshold,.9,180,1440));let{samplesPerPeriod:d}=this,E=h/(A?1.8:2);this.path.leadTime=E,this.path.trailTime=E;let _={...this,period:h,resolution:h/d};this.path.resolution=A?{..._,method:"timeStep"}:{..._,method:"trueAnomaly",period:h,samplesPerPeriod:d}}}});var Oht,Sht,GC,lv=O(()=>{Oht={},Sht=(()=>{var t=Oht.url;return function(e={}){var i=e,n,s;i.ready=new Promise((u,S)=>{n=u,s=S}),["_getCoveragePositions","_inflateEllipsoid","_malloc","_free","_memory","_fflush","__embind_initialize_bindings","___indirect_function_table","___start_em_asm","___stop_em_asm","onRuntimeInitialized"].forEach(u=>{Object.getOwnPropertyDescriptor(i.ready,u)||Object.defineProperty(i.ready,u,{get:()=>Ge("You are getting "+u+" on the Promise object, instead of the instance. Use .then() to get called back with the instance, see the MODULARIZE docs in src/settings.js"),set:()=>Ge("You are setting "+u+" on the Promise object, instead of the instance. Use .then() to get called back with the instance, see the MODULARIZE docs in src/settings.js")})}),globalThis.__dirname=globalThis.__dirname||"";var o=Object.assign({},i),r=[],a="./this.program",h=(u,S)=>{throw S},A=!0,d=!1,f=!1,E=!1;if(i.ENVIRONMENT)throw new Error("Module.ENVIRONMENT has been deprecated. To force the environment, use the ENVIRONMENT compile-time option (for example, -sENVIRONMENT=web or -sENVIRONMENT=node)");var _="";function R(u){return i.locateFile?i.locateFile(u,_):_+u}var I,C,N,T;if(E){if(typeof process=="object"&&typeof Xo=="function"||typeof window=="object"||typeof importScripts=="function")throw new Error("not compiled for this environment (did you build to HTML and try to run it not on the web, or set ENVIRONMENT to something - like node - and run it someplace else - like on the web?)");typeof read<"u"&&(I=read),N=u=>{if(typeof readbuffer=="function")return new Uint8Array(readbuffer(u));let S=read(u,"binary");return c(typeof S=="object"),S},C=(u,S,W)=>{setTimeout(()=>S(N(u)))},typeof clearTimeout>"u"&&(globalThis.clearTimeout=u=>{}),typeof setTimeout>"u"&&(globalThis.setTimeout=u=>typeof u=="function"?u():Ge()),typeof scriptArgs<"u"?r=scriptArgs:typeof arguments<"u"&&(r=arguments),typeof quit=="function"&&(h=(u,S)=>{throw setTimeout(()=>{if(!(S instanceof cs)){let W=S;S&&typeof S=="object"&&S.stack&&(W=[S,S.stack]),b(`exiting due to exception: ${W}`)}quit(u)}),S}),typeof print<"u"&&(typeof console>"u"&&(console={}),console.log=print,console.warn=console.error=typeof printErr<"u"?printErr:print)}else if(A||d){if(d?_=self.location.href:typeof document<"u"&&document.currentScript&&(_=document.currentScript.src),t&&(_=t),_.indexOf("blob:")!==0?_=_.substr(0,_.replace(/[?#].*/,"").lastIndexOf("/")+1):_="",!(typeof window=="object"||typeof importScripts=="function"))throw new Error("not compiled for this environment (did you build to HTML and try to run it not on the web, or set ENVIRONMENT to something - like node - and run it someplace else - like on the web?)");I=u=>{var S=new XMLHttpRequest;return S.open("GET",u,!1),S.send(null),S.responseText},d&&(N=u=>{var S=new XMLHttpRequest;return S.open("GET",u,!1),S.responseType="arraybuffer",S.send(null),new Uint8Array(S.response)}),C=(u,S,W)=>{var P=new XMLHttpRequest;P.open("GET",u,!0),P.responseType="arraybuffer",P.onload=()=>{if(P.status==200||P.status==0&&P.response){S(P.response);return}W()},P.onerror=W,P.send(null)},T=u=>document.title=u}else throw new Error("environment detection error");var F=i.print||console.log.bind(console),b=i.printErr||console.error.bind(console);Object.assign(i,o),o=null,l8(),i.arguments&&(r=i.arguments),_n("arguments","arguments_"),i.thisProgram&&(a=i.thisProgram),_n("thisProgram","thisProgram"),i.quit&&(h=i.quit),_n("quit","quit_"),c(typeof i.memoryInitializerPrefixURL>"u","Module.memoryInitializerPrefixURL option was removed, use Module.locateFile instead"),c(typeof i.pthreadMainPrefixURL>"u","Module.pthreadMainPrefixURL option was removed, use Module.locateFile instead"),c(typeof i.cdInitializerPrefixURL>"u","Module.cdInitializerPrefixURL option was removed, use Module.locateFile instead"),c(typeof i.filePackagePrefixURL>"u","Module.filePackagePrefixURL option was removed, use Module.locateFile instead"),c(typeof i.read>"u","Module.read option was removed (modify read_ in JS)"),c(typeof i.readAsync>"u","Module.readAsync option was removed (modify readAsync in JS)"),c(typeof i.readBinary>"u","Module.readBinary option was removed (modify readBinary in JS)"),c(typeof i.setWindowTitle>"u","Module.setWindowTitle option was removed (modify setWindowTitle in JS)"),c(typeof i.TOTAL_MEMORY>"u","Module.TOTAL_MEMORY has been renamed Module.INITIAL_MEMORY"),_n("asm","wasmExports"),_n("read","read_"),_n("readAsync","readAsync"),_n("readBinary","readBinary"),_n("setWindowTitle","setWindowTitle"),c(!d,"worker environment detected but not enabled at build time.  Add 'worker' to `-sENVIRONMENT` to enable."),c(!f,"node environment detected but not enabled at build time.  Add 'node' to `-sENVIRONMENT` to enable."),c(!E,"shell environment detected but not enabled at build time.  Add 'shell' to `-sENVIRONMENT` to enable.");var G;i.wasmBinary&&(G=i.wasmBinary),_n("wasmBinary","wasmBinary");var M=i.noExitRuntime||!0;_n("noExitRuntime","noExitRuntime"),typeof WebAssembly!="object"&&Ge("no native wasm support detected");var Q,U,k=!1,y;function c(u,S){u||Ge("Assertion failed"+(S?": "+S:""))}var g,V,D,w,x,H,j,X;function tt(){var u=Q.buffer;i.HEAP8=g=new Int8Array(u),i.HEAP16=D=new Int16Array(u),i.HEAP32=x=new Int32Array(u),i.HEAPU8=V=new Uint8Array(u),i.HEAPU16=w=new Uint16Array(u),i.HEAPU32=H=new Uint32Array(u),i.HEAPF32=j=new Float32Array(u),i.HEAPF64=X=new Float64Array(u)}c(!i.STACK_SIZE,"STACK_SIZE can no longer be set at runtime.  Use -sSTACK_SIZE at link time"),c(typeof Int32Array<"u"&&typeof Float64Array<"u"&&Int32Array.prototype.subarray!=null&&Int32Array.prototype.set!=null,"JS engine does not provide full typed array support"),c(!i.wasmMemory,"Use of `wasmMemory` detected.  Use -sIMPORTED_MEMORY to define wasmMemory externally"),c(!i.INITIAL_MEMORY,"Detected runtime INITIAL_MEMORY setting.  Use -sIMPORTED_MEMORY to define wasmMemory dynamically");var B;function It(){var u=$g();c((u&3)==0),u==0&&(u+=4),H[u>>2]=34821223,H[u+4>>2]=2310721022,H[0]=1668509029}function gt(){if(!k){var u=$g();u==0&&(u+=4);var S=H[u>>2],W=H[u+4>>2];(S!=34821223||W!=2310721022)&&Ge(`Stack overflow! Stack cookie has been overwritten at ${Pn(u)}, expected hex dwords 0x89BACDFE and 0x2135467, but received ${Pn(W)} ${Pn(S)}`),H[0]!=1668509029&&Ge("Runtime error: The application has corrupted its heap memory area (address zero)!")}}(function(){var u=new Int16Array(1),S=new Int8Array(u.buffer);if(u[0]=25459,S[0]!==115||S[1]!==99)throw"Runtime error: expected the system to be little-endian! (Run with -sSUPPORT_BIG_ENDIAN to bypass)"})();var Yt=[],Mt=[],Ct=[],zt=!1,kt=0;function Jt(){if(i.preRun)for(typeof i.preRun=="function"&&(i.preRun=[i.preRun]);i.preRun.length;)ee(i.preRun.shift());xn(Yt)}function Wt(){c(!zt),zt=!0,gt(),!i.noFSInit&&!K.init.initialized&&K.init(),K.ignorePermissions=!1,pi.init(),xn(Mt)}function Ft(){if(gt(),i.postRun)for(typeof i.postRun=="function"&&(i.postRun=[i.postRun]);i.postRun.length;)je(i.postRun.shift());xn(Ct)}function ee(u){Yt.unshift(u)}function ce(u){Mt.unshift(u)}function je(u){Ct.unshift(u)}c(Math.imul,"This browser does not support Math.imul(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),c(Math.fround,"This browser does not support Math.fround(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),c(Math.clz32,"This browser does not support Math.clz32(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),c(Math.trunc,"This browser does not support Math.trunc(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill");var Oe=0,Me=null,Ue=null,Ce={};function be(u){for(var S=u;;){if(!Ce[u])return u;u=S+Math.random()}}function ni(u){Oe++,i.monitorRunDependencies&&i.monitorRunDependencies(Oe),u?(c(!Ce[u]),Ce[u]=1,Me===null&&typeof setInterval<"u"&&(Me=setInterval(()=>{if(k){clearInterval(Me),Me=null;return}var S=!1;for(var W in Ce)S||(S=!0,b("still waiting on run dependencies:")),b("dependency: "+W);S&&b("(end of list)")},1e4))):b("warning: run dependency added without ID")}function ze(u){if(Oe--,i.monitorRunDependencies&&i.monitorRunDependencies(Oe),u?(c(Ce[u]),delete Ce[u]):b("warning: run dependency removed without ID"),Oe==0&&(Me!==null&&(clearInterval(Me),Me=null),Ue)){var S=Ue;Ue=null,S()}}function Ge(u){i.onAbort&&i.onAbort(u),u="Aborted("+u+")",b(u),k=!0,y=1;var S=new WebAssembly.RuntimeError(u);throw s(S),S}var Ui="data:application/octet-stream;base64,";function Ri(u){return u.startsWith(Ui)}function si(u){return u.startsWith("file://")}function qe(u){return function(){c(zt,`native function \`${u}\` called before runtime initialization`);var S=U[u];return c(S,`exported native function \`${u}\` not found`),S.apply(null,arguments)}}var Vi;Vi="data:application/octet-stream;base64,AGFzbQEAAAABrwRGYAF/AX9gAX8AYAJ/fwBgAn9/AX9gA39/fwF/YAZ/f39/f38Bf2AEf39/fwF/YAV/f39/fwF/YAN/f38AYAAAYAR/f39/AGAIf39/f39/f38Bf2AGf39/f39/AGAFf39/f38AYAABf2AHf39/f39/fwF/YAd/f39/f39/AGAFf35+fn4AYAF8AXxgBH98f38Bf2AFf39/f34Bf2ACfHwBfGADf35/AX5gC39/f39/f39/f39/AX9gCn9/f39/f39/f38AYAR/fn5/AGACf3wBf2AEf398fwF/YAZ/f39/fn4Bf2AHf39/f39+fgF/YAN/f38BfGACfH8BfGAFf398f38AYAN8fH8BfGAGf3x/f39/AX9gBX9/fn9/AGADf39/AX5gBH9/f38BfmAMf39/f39/f39/f39/AX9gBX9/f398AX9gD39/f39/f39/f39/f39/fwBgCH9/f39/f39/AGANf39/f39/f39/f39/fwBgCX9/f39/f39/fwBgAAF8YAR+fn5+AX9gA35+fgF/YAF+AX9gAn5+AXxgAn98AGACfn4BfWACf38BfGADf398AGAEf3x/fwBgA39/fAF/YAF+AX5gBX9/f3x/AX9gBn9/f3x/fwBgAXwAYAJ8fwF/YAJ+fwF/YAJ/fgBgAn9/AX5gA39/fgBgAn9+AX9gBH9/f34BfmADf39/AX1gCX9/f39/f39/fwF/YAp/f39/f39/f39/AX9gBH9/fn4AArEIJQNlbnYcZW1zY3JpcHRlbl9ydW5fc2NyaXB0X3N0cmluZwAAA2VudgtfX2N4YV90aHJvdwAIA2Vudg1fZW12YWxfZGVjcmVmAAEDZW52Fl9lbWJpbmRfcmVnaXN0ZXJfY2xhc3MAKgNlbnYiX2VtYmluZF9yZWdpc3Rlcl9jbGFzc19jb25zdHJ1Y3RvcgAMA2Vudh9fZW1iaW5kX3JlZ2lzdGVyX2NsYXNzX2Z1bmN0aW9uACsDZW52H19lbWJpbmRfcmVnaXN0ZXJfY2xhc3NfcHJvcGVydHkAGANlbnYTX2VtdmFsX2dldF9wcm9wZXJ0eQADA2VudhJfZW12YWxfbmV3X2NzdHJpbmcAAANlbnYJX2VtdmFsX2FzAB4DZW52Fl9lbXZhbF9ydW5fZGVzdHJ1Y3RvcnMAAQNlbnYZX2VtYmluZF9yZWdpc3Rlcl9mdW5jdGlvbgAQA2VudhhlbXNjcmlwdGVuX2FzbV9jb25zdF9pbnQABANlbnYVX2VtYmluZF9yZWdpc3Rlcl92b2lkAAIDZW52FV9lbWJpbmRfcmVnaXN0ZXJfYm9vbAANA2VudhtfZW1iaW5kX3JlZ2lzdGVyX3N0ZF9zdHJpbmcAAgNlbnYcX2VtYmluZF9yZWdpc3Rlcl9zdGRfd3N0cmluZwAIA2VudhZfZW1iaW5kX3JlZ2lzdGVyX2VtdmFsAAIDZW52GF9lbWJpbmRfcmVnaXN0ZXJfaW50ZWdlcgANA2VudhZfZW1iaW5kX3JlZ2lzdGVyX2Zsb2F0AAgDZW52HF9lbWJpbmRfcmVnaXN0ZXJfbWVtb3J5X3ZpZXcACANlbnYTZW1zY3JpcHRlbl9kYXRlX25vdwAsA2VudiBfZW1zY3JpcHRlbl9nZXRfbm93X2lzX21vbm90b25pYwAOFndhc2lfc25hcHNob3RfcHJldmlldzEHZmRfcmVhZAAGFndhc2lfc25hcHNob3RfcHJldmlldzEIZmRfd3JpdGUABhZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxCGZkX2Nsb3NlAAADZW52FWVtc2NyaXB0ZW5fbWVtY3B5X2JpZwAIA2VudglfdHpzZXRfanMACANlbnYWZW1zY3JpcHRlbl9yZXNpemVfaGVhcAAAA2VudgVhYm9ydAAJFndhc2lfc25hcHNob3RfcHJldmlldzERZW52aXJvbl9zaXplc19nZXQAAxZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxC2Vudmlyb25fZ2V0AAMDZW52CnN0cmZ0aW1lX2wABwNlbnYXX2VtYmluZF9yZWdpc3Rlcl9iaWdpbnQAEBZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxB2ZkX3NlZWsABwNlbnYKX21rdGltZV9qcwAAA2VudgpfZ210aW1lX2pzAAgDxATCBAkOAAEEAAQEBgkAHxEAAAEDAi0uGREZEREAAQkODg4OAQARERUvBBUwAjECMgECAAkBCQEAAAIJAAABAA4DBDM0AwgBBBISFTUCEwkBAwADCAgAAQkBDgMIGjYAAgMIEzcCBAQBCQ4DAwACAQECAgkAAAIBAhobOBsAAQAJOSAJEhISOgUJAAkSAAQEFgAJBAAWAyE7HwcPCAAKPA0DBCICCAAAPQAGERkKPj8GBAQDCUAAAAEAAQIEIwoEBAAAAwQECgoDAAEAAQABAQEBAAMDAAAAAAEAAQIAAQQEAAQAAQADAAAAAgIEAgIIBAADAQgCCAICAAIABAMCAAMAAwIEAwIAAwADAwADAQZBCgcKBAcKBAIABAUADwAAAQUACBcGCgQOJAIFJQUGJAUGBSUFDSZCBR4FCgUEAwUADwAFAwgXBAUFBQUFDSYFBQUHAAAHCgcEEAIUBxQnBAYQHAcHAAcQBQQUBxQnEBwHCwAFBQUMBQwFDQcLCwUFBQwFDAUNBwsPDA8AAgICAAICDxcCCAgAAAMDDw0PFwICAAIAAw8NHRgoBAUdGCgEBQQMDAIBCAIOCAgBAQABAAAAAAIBAAEAAQABAAECAQEAAAAAAQABAAEAAQECAQEBAAAAAgICAQAAAAICAgsLBwcACwsHAQALBAsHBwAABwALBwQGBgYDBAMEBgQHAQADBAMEBgQHAQABKSkDAwMDAwEJAQkEBAQDDAoNCggKDQoEAw0QDA0MDAAAAAABACEVBxAPQ0RFBAcBcAHOA84DBQcBAYAMgIACBhcEfwFBwLIYC38BQQALfwFBAAt/AUEACwedBBsGbWVtb3J5AgARX193YXNtX2NhbGxfY3RvcnMAJQZtYWxsb2MAMwRmcmVlADQQaW5mbGF0ZUVsbGlwc29pZACoARRnZXRDb3ZlcmFnZVBvc2l0aW9ucwCjAQZmZmx1c2gArgENX19nZXRUeXBlTmFtZQCrARtfZW1iaW5kX2luaXRpYWxpemVfYmluZGluZ3MArAEQX19lcnJub19sb2NhdGlvbgAmGV9faW5kaXJlY3RfZnVuY3Rpb25fdGFibGUBAAtzZXRUZW1wUmV0MAA/FWVtc2NyaXB0ZW5fc3RhY2tfaW5pdABAGWVtc2NyaXB0ZW5fc3RhY2tfZ2V0X2ZyZWUAQRllbXNjcmlwdGVuX3N0YWNrX2dldF9iYXNlAEIYZW1zY3JpcHRlbl9zdGFja19nZXRfZW5kAEMJc3RhY2tTYXZlAEQMc3RhY2tSZXN0b3JlAEUKc3RhY2tBbGxvYwBGHGVtc2NyaXB0ZW5fc3RhY2tfZ2V0X2N1cnJlbnQARCJfX2N4YV9pbmNyZW1lbnRfZXhjZXB0aW9uX3JlZmNvdW50AMMEFV9fY3hhX2lzX3BvaW50ZXJfdHlwZQDZBAxkeW5DYWxsX2ppamkA4QQOZHluQ2FsbF92aWlqaWkA4gQOZHluQ2FsbF9paWlpaWoA4wQPZHluQ2FsbF9paWlpaWpqAOQEEGR5bkNhbGxfaWlpaWlpamoA5QQJ4QYBAEEBC80DUlpcXV5eX2BhYmNkZWZncF1xcnN0dXldemB7fH1+f4ABgQGCAYMBVokBigFdcWCLAYwBXV5ecY0BjgGMAY8BkAGUAV1eXnFylQGWAYIBlwGDAZgBmQGaAX+bAZwBmwGdAZ4BggGhAaIBowFeqgHTAcQBxQHSAZQCNMECKPAD7wPtA+UD5wPpA+sD/wP+A/wD9QP3A/kD+wNvhAFekQGTAZEBkgGgAZ8Bd3iyAbABsQG1AbYBrwHaAdsB3AHdAd4B3wG1AbUB4AHiAeMB5AHlAeQB/gH/AdwB3QHeAd8BtQG1AYAC4gGCAuQBgwLkAdsBpwKoAqoCqwLsAe0B7gHvAdcB2QHYAdkB2wGkApwCpQKmAvkB+gH7AfwB/wGfAqACogKjAuwB7QHuAe8B1wHZAf8BmwKcAp0CngL5AfoB+wH8AbgEtwTcA68ErgSwBLEEsgSzBOkBtAS1BLYElwSWBJgEmgScBJ0EtQGfBKAEiASHBIkEigSLBIwEjQSBBIAEggSDBIQEhQSGBF6RAZEBowSkBKUEpgSnBKgEqQSqBOkBqwSsBK0EkQGhBKEEkAQnJ6IEJ5EBkwSUBJAEtQG1AZUEkgSRAZMElASQBLUBtQGVBJIEkQGOBI8EkAS1AbUBkQSSBJEBjgSPBJAEtQG1AZEEkgRekQGzArQCtQJekQG2ArcCuwKRAbwCwgLMAs4C0QLRAtMC1QLZAtsC3QKRAeAC5ALpAuoC6wLrAuwC7QLwAvEC8gKRAfMC9gL8Av0C/gL/AoMDhAORAYUDhwOLA4wDjQOOA5ADkQNekQGTA5QDlQOWA5gDmgOdA/ED8gPzA/QD9gP4A/oDXpEBkwOfA6ADoQOjA6UDqAPgA+ED4gPjA+YD6APqA94D3wOpA94D3wOrA5EBrAOsA60DrQOtA64DtQGvA68DkQGsA6wDrQOtA60DrgO1Aa8DrwORAbADsAOtA60DrQOxA7UBrwOvA5EBsAOwA60DrQOtA7EDtQGvA68DkQGzA7wDkQG+A8YDkQHIA8wD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AyABNgIwIAMgADYCNAsCQCACIAVGDQAgBUF/cyACaiEGAkAgAEEHcSIHRQRAIAUhAAwBC0EAIQQgBSEAA0AgASAALQAAOgAAIAFBAWohASAAQQFqIQAgBEEBaiIEIAdHDQALCyAGQQdJDQADQCABIAAtAAA6AAAgASAALQABOgABIAEgAC0AAjoAAiABIAAtAAM6AAMgASAALQAEOgAEIAEgAC0ABToABSABIAAtAAY6AAYgASAALQAHOgAHIAFBCGohASAAQQhqIgAgAkcNAAsLQQAhAiABQQA6AABB4AAQVEGO5RJB2AAQKyIJQQA6AFggA0EANgIoIANCADcDICADKAI0IAMsADsiCEH/AXEgCEEASCIAGyIBBH8gAygCMCADQTBqIAAbIQADQCADQSBqIAkgAkHYAHBqLQAAIAAgAmotAABzwBCGASACQQFqIgIgAUcNAAsgAygCICADQSBqIAMtACvAQQBIGwUgA0EgagsQACECIAMsACtBAEgEQCADKAIgEDQLIAIQLyIBQfD///8HTw0CAkAgAUEKTQRAIAMgAToAKyADQSBqIQAMAQsgAUEPckEBaiIEEFQhACADIARBgICAgHhyNgIoIAMgADYCICADIAE2AiQLIAAgAiABEEsgAWpBADoAACMAQRBrIgYkACAGQRA2AgwgA0EgaiIAKAIEIAAtAAsiAUH/AHEgAUGAAXFBB3YbIgFBAEkEQBDVAQALIAAoAgAgACAALQALQYABcUEHdhshCiAGIAE2AgggA0EIaiIBIQAgBkEIaiAGQQxqIAYoAgggBigCDEkbKAIAIQQjAEEQayIHJAACQCAEQfD///8HSQRAAkAgBEELSQRAIAAgBDoACwwBCyAHQQhqIARBC08EfyAEQRBqQXBxIgIgAkEBayICIAJBC0YbBUEKC0EBahCOAiAAIAcoAggiAjYCACAAIAcoAgxBgICAgHhyNgIIIAAgBDYCBCACIQALIAAgCiAEEOEBIARqQQA6AAAgB0EQaiQADAELEFUACyAGQRBqJAAgA0EUaiABIgAQWyAALAALQQBIBEAgACgCABA0C0GAAhBUQdzBAEHwARArIgFBADoA8AECQCADKAIYIAMtAB8iACAAwEEASCIAGyIGBEAgAUHwAWohBCADKAIUIANBFGogABshBwJAAkACQCAGQfABSg0AIAcs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IgZB//8BRwRAQQQgBg0BGkECQQMgAyAKhFAbDAILIAMgCoRQCwshBiACQjCIpyIIQf//AXEiB0H//wFGDQAgBg0BCyAFQRBqIAEgAiADIAQQPCAFIAUpAxAiAiAFKQMYIgEgAiABEDogBSkDCCECIAUpAwAhBAwBCyABIAJC////////////AIMiCiADIARC////////////AIMiCRA3QQBMBEAgASAKIAMgCRA3BEAgASEEDAILIAVB8ABqIAEgAkIAQgAQPCAFKQN4IQIgBSkDcCEEDAELIARCMIinQf//AXEhBiAHBH4gAQUgBUHgAGogASAKQgBCgICAgICAwLvAABA8IAUpA2giCkIwiKdB+ABrIQcgBSkDYAshBCAGRQRAIAVB0ABqIAMgCUIAQoCAgICAgMC7wAAQPCAFKQNYIglCMIinQfgAayEGIAUpA1AhAwsgCUL///////8/g0KAgICAgIDAAIQhCyAKQv///////z+DQoCAgICAgMAAhCEKIAYgB0gEQANAAn4gCiALfSADIARWrX0iCUIAWQRAIAkgBCADfSIEhFAEQCAFQSBqIAEgAkIAQgAQPCAFKQMoIQIgBSkDICEEDAULIAlCAYYgBEI/iIQMAQsgCkIBhiAEQj+IhAshCiAEQgGGIQQgB0EBayIHIAZKDQALIAYhBwsCQCAKIAt9IAMgBFatfSIJQgBTBEAgCiEJDAELIAkgBCADfSIEhEIAUg0AIAVBMGogASACQgBCABA8IAUpAzghAiAFKQMwIQQMAQsgCUL///////8/WARAA0AgBEI/iCEBIAdBAWshByAEQgGGIQQgASAJQgGGhCIJQoCAgICAgMAAVA0ACwsgCEGAgAJxIQYgB0EATARAIAVBQGsgBCAJQv///////z+DIAdB+ABqIAZyrUIwhoRCAEKAgICAgIDAwz8QPCAFKQNIIQIgBSkDQCEEDAELIAlC////////P4MgBiAHcq1CMIaEIQILIAAgBDcDACAAIAI3AwggBUGAAWokAAtSAQJ/Qaj7EygCACIBIABBB2pBeHEiAmohAAJAIAJBACAAIAFNGw0AIAA/AEEQdEsEQCAAEBxFDQELQaj7EyAANgIAIAEPC0Gg/xNBMDYCAEF/C8goAQt/IwBBEGsiCiQAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkAC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IAQgB3I2AgAgAiAANgIAIAAgAjYCGAwBCyABQRkgA0EBdmtBACADQR9HG3QhAyACKAIAIQIDQCACIgQoAgRBeHEgAUYNAiADQR12IQIgA0EBdCEDIAQgAkEEcWoiB0EQaigCACICDQALIAcgADYCECAAIAQ2AhgLIAAgADYCDCAAIAA2AggPCyAEKAIIIgEgADYCDCAEIAA2AgggAEEANgIYIAAgBDYCDCAAIAE2AggLC9sBAgF/An5BASEEAkAgAEIAUiABQv///////////wCDIgVCgICAgICAwP//AFYgBUKAgICAgIDA//8AURsNACACQgBSIANC////////////AIMiBkKAgICAgIDA//8AViAGQoCAgICAgMD//wBRGw0AIAAgAoQgBSAGhIRQBEBBAA8LIAEgA4NCAFkEQEF/IQQgACACVCABIANTIAEgA1EbDQEgACAChSABIAOFhEIAUg8LQX8hBCAAIAJWIAEgA1UgASADURsNACAAIAKFIAEgA4WEQgBSIQQLIAQLwAECAX8CfkF/IQMCQCAAQgBSIAFC////////////AIMiBEKAgICAgIDA//8AViAEQoCAgICAgMD//wBRGw0AIAJC////////////AIMiBUKAgICAgIDA//8AViAFQoCAgICAgMD//wBScQ0AIAAgBCAFhIRQBEBBAA8LIAEgAoNCAFkEQCABIAJSIAEgAlNxDQEgACABIAKFhEIAUg8LIABCAFIgASACVSABIAJRGw0AIAAgASAChYRCAFIhAwsgAwtQAQF+AkAgA0HAAHEEQCABIANBQGqthiECQgAhAQwBCyADRQ0AIAIgA60iBIYgAUHAACADa62IhCECIAEgBIYhAQsgACABNwMAIAAgAjcDCAupDwIFfw9+IwBB0AJrIgUkACAEQv///////z+DIQsgAkL///////8/gyEKIAIgBIVCgICAgICAgICAf4MhDSAEQjCIp0H//wFxIQgCQAJAIAJCMIinQf//AXEiCUH//wFrQYKAfk8EQCAIQf//AWtBgYB+Sw0BCyABUCACQv///////////wCDIgxCgICAgICAwP//AFQgDEKAgICAgIDA//8AURtFBEAgAkKAgICAgIAghCENDAILIANQIARC////////////AIMiAkKAgICAgIDA//8AVCACQoCAgICAgMD/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IQILIAAgATcDACAAIAI3AwgLwwoCBX8PfiMAQeAAayIFJAAgBEL///////8/gyEMIAIgBIVCgICAgICAgICAf4MhCiACQv///////z+DIg1CIIghDiAEQjCIp0H//wFxIQcCQAJAIAJCMIinQf//AXEiCUH//wFrQYKAfk8EQCAHQf//AWtBgYB+Sw0BCyABUCACQv///////////wCDIgtCgICAgICAwP//AFQgC0KAgICAgIDA//8AURtFBEAgAkKAgICAgIAghCEKDAILIANQIARC////////////AIMiAkKAgICAgIDA//8AVCACQoCAgICAgMD//wBRG0UEQCAEQoCAgICAgCCEIQogAyEBDAILIAEgC0KAgICAgIDA//8AhYRQBEAgAiADhFAEQEKAgICAgIDg//8AIQpCACEBDAMLIApCgICAgICAwP//AIQhCkIAIQEMAgsgAyACQoCAgICAgMD//wCFhFAEQCABIAuEIQJCACEBIAJQBEBCgICAgICA4P//ACEKDAMLIApCgICAgICAwP//AIQhCgwCCyABIAuEUARAQgAhAQwCCyACIAOEUARAQgAhAQwCCyALQv///////z9YBEAgBUHQAGogASANIAEgDSANUCIGG3kgBkEGdK18pyIGQQ9rEDlBECAGayEGIAUpA1giDUIgiCEOIAUpA1AhAQsgAkL///////8/Vg0AIAVBQGsgAyAMIAMgDCAMUCIIG3kgCEEGdK18pyIIQQ9rEDkgBiAIa0EQaiEGIAUpA0ghDCAFKQNAIQMLIANCD4YiC0KAgP7/D4MiAiABQiCIIgR+IhAgC0IgiCITIAFC/////w+DIgF+fCIPQiCGIhEgASACfnwiCyARVK0gAiANQv////8PgyINfiIVIAQgE358IhEgDEIPhiISIANCMYiEQv////8PgyIDIAF+fCIUIA8gEFStQiCGIA9CIIiEfCIPIAIgDkKAgASEIgx+IhYgDSATfnwiDiASQiCIQoCAgIAIhCICIAF+fCIQIAMgBH58IhJCIIZ8Ihd8IQEgByAJaiAGakH//wBrIQYCQCACIAR+IhggDCATfnwiBCAYVK0gBCAEIAMgDX58IgRWrXwgAiAMfnwgBCAEIBEgFVStIBEgFFatfHwiBFatfCADIAx+IgMgAiANfnwiAiADVK1CIIYgAkIgiIR8IAQgAkIghnwiAiAEVK18IAIgAiAQIBJWrSAOIBZUrSAOIBBWrXx8QiCGIBJCIIiEfCICVq18IAIgAiAPIBRUrSAPIBdWrXx8IgJWrXwiBEKAgICAgIDAAINCAFIEQCAGQQFqIQYMAQsgC0I/iCEDIARCAYYgAkI/iIQhBCACQgGGIAFCP4iEIQIgC0IBhiELIAMgAUIBhoQhAQsgBkH//wFOBEAgCkKAgICAgIDA//8AhCEKQgAhAQwBCwJ+IAZBAEwEQEEBIAZrIgdB/wBNBEAgBUEwaiALIAEgBkH/AGoiBhA5IAVBIGogAiAEIAYQOSAFQRBqIAsgASAHEDsgBSACIAQgBxA7IAUpAzAgBSkDOIRCAFKtIAUpAyAgBSkDEISEIQsgBSkDKCAFKQMYhCEBIAUpAwAhAiAFKQMIDAILQgAhAQwCCyAEQv///////z+DIAatQjCGhAsgCoQhCiALUCABQgBZIAFCgICAgICAgICAf1EbRQRAIAogAkIBfCIBUK18IQoMAQsgCyABQoCAgICAgICAgH+FhEIAUgRAIAIhAQwBCyAKIAIgAkIBg3wiASACVK18IQoLIAAgATcDACAAIAo3AwggBUHgAGokAAt1AQF+IAAgASAEfiACIAN+fCADQiCIIgIgAUIgiCIEfnwgA0L/////D4MiAyABQv////8PgyIBfiIFQiCIIAMgBH58IgNCIIh8IAEgAn4gA0L/////D4N8IgFCIIh8NwMIIAAgBUL/////D4MgAUIghoQ3AwALpgEBAX8CfwJAIAAoAkwiAUEATgRAIAFFDQFBhJkUKAIAIAFB/////3txRw0BCyAAKAIEIgEgACgCCEcEQCAAIAFBAWo2AgQgAS0AAAwCCyAAEMgBDAELIAAgACgCTCIBQf////8DIAEbNgJMAn8gACgCBCIBIAAoAghHBEAgACABQQFqNgIEIAEtAAAMAQsgABDIAQshASAAKAJMGiAAQQA2AkwgAQsLBgAgACQBCw4AQcCyGCQDQcCyFCQCCwcAIwAjAmsLBAAjAwsEACMCCwQAIwALBgAgACQACxAAIwAgAGtBcHEiACQAIAALxQkCBH8FfiMAQfAAayIGJAAgBEL///////////8AgyEJAkACQCABUCIFIAJC////////////AIMiCkKAgICAgIDA//8AfUKAgICAgIDAgIB/VCAKUBtFBEAgA0IAUiAJQoCAgICAgMD//wB9IgtCgICAgICAwICAf1YgC0KAgICAgIDAgIB/URsNAQsgBSAKQoCAgICAgMD//wBUIApCgICAgICAwP//AFEbRQRAIAJCgICAgICAIIQhBCABIQMMAgsgA1AgCUKAgICAgIDA//8AVCAJQoCAgICAgMD//wBRG0UEQCAEQoCAgICAgCCEIQQMAgsgASAKQoCAgICAgMD//wCFhFAEQEKAgICAgIDg//8AIAIgASADhSACIASFQoCAgICAgICAgH+FhFAiBRshBEIAIAEgBRshAwwCCyADIAlCgICAgICAwP//AIWEUA0BIAEgCoRQBEAgAyAJhEIAUg0CIAEgA4MhAyACIASDIQQMAgsgAyAJhEIAUg0AIAEhAyACIQQMAQsgAyABIAEgA1QgCSAKViAJIApRGyIIGyEKIAQgAiAIGyILQv///////z+DIQkgAiAEIAgbIgJCMIinQf//AXEhByALQjCIp0H//wFxIgVFBEAgBkHgAGogCiAJIAogCSAJUCIFG3kgBUEGdK18pyIFQQ9rEDkgBikDaCEJIAYpA2AhCkEQIAVrIQULIAEgAyAIGyEDIAJC////////P4MhBCAHRQRAIAZB0ABqIAMgBCADIAQgBFAiBxt5IAdBBnStfKciB0EPaxA5QRAgB2shByAGKQNYIQQgBikDUCEDCyAEQgOGIANCPYiEQoCAgICAgIAEhCEBIAlCA4YgCkI9iIQhBCACIAuFIQ0CfiADQgOGIgIgBSAHRg0AGiAFIAdrIgdB/wBLBEBCACEBQgEMAQsgBkFAayACIAFBgAEgB2sQOSAGQTBqIAIgASAHEDsgBikDOCEBIAYpAzAgBikDQCAGKQNIhEIAUq2ECyEJIARCgICAgICAgASEIQwgCkIDhiEKAkAgDUIAUwRAQgAhA0IAIQQgCSAKhSABIAyFhFANAiAKIAl9IQIgDCABfSAJIApWrX0iBEL/////////A1YNASAGQSBqIAIgBCACIAQgBFAiBxt5IAdBBnStfKdBDGsiBxA5IAUgB2shBSAGKQMoIQQgBikDICECDAELIAkgCnwiAiAJVK0gASAMfHwiBEKAgICAgICACINQDQAgCUIBgyAEQj+GIAJCAYiEhCECIAVBAWohBSAEQgGIIQQLIAtCgICA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AACiDwsCQCACQv////////8HVgRAIAIhAwwBCwNAIAZBAWshBiACQoCAgICAgIAEVCEHIAJCAYYiAyECIAcNAAsLIAVCgICAgICAgICAf4MhAiAGQQBKBH4gA0KAgICAgICACH0gBq1CNIaEBSADQQEgBmutiAsgAoS/C9EDAgJ+An8jAEEgayIEJAACQCABQv///////////wCDIgNCgICAgICAwIA8fSADQoCAgICAgMD/wwB9VARAIAFCBIYgAEI8iIQhAyAAQv//////////D4MiAEKBgICAgICAgAhaBEAgA0KBgICAgICAgMAAfCECDAILIANCgICAgICAgIBAfSECIABCgICAgICAgIAIUg0BIAIgA0IBg3whAgwBCyAAUCADQoCAgICAgMD//wBUIANCgICAgICAwP//AFEbRQRAIAFCBIYgAEI8iIRC/////////wODQoCAgICAgID8/wCEIQIMAQtCgICAgICAgPj/ACECIANC////////v//DAFYNAEIAIQIgA0IwiKciBUGR9wBJDQAgBEEQaiAAIAFC////////P4NCgICAgICAwACEIgIgBUGB9wBrEDkgBCAAIAJBgfgAIAVrEDsgBCkDCEIEhiAEKQMAIgBCPIiEIQIgBCkDECAEKQMYhEIAUq0gAEL//////////w+DhCIAQoGAgICAgICACFoEQCACQgF8IQIMAQsgAEKAgICAgICAgAhSDQAgAkIBgyACfCECCyAEQSBqJAAgAiABQoCAgICAgICAgH+DhL8LfgICfwF+IwBBEGsiAyQAIAACfiABRQRAQgAMAQsgAyABIAFBH3UiAnMgAmsiAq1CACACZyICQdEAahA5IAMpAwhCgICAgICAwACFQZ6AASACa61CMIZ8IAFBgICAgHhxrUIghoQhBCADKQMACzcDACAAIAQ3AwggA0EQaiQAC/kBAgN+An8jAEEQayIFJAACfiABvSIDQv///////////wCDIgJCgICAgICAgAh9Qv/////////v/wBYBEAgAkI8hiEEIAJCBIhCgICAgICAgIA8fAwBCyACQoCAgICAgID4/wBaBEAgA0I8hiEEIANCBIhCgICAgICAwP//AIQMAQsgAlAEQEIADAELIAUgAkIAIAOnZ0EgaiACQiCIp2cgAkKAgICAEFQbIgZBMWoQOSAFKQMAIQQgBSkDCEKAgICAgIDAAIVBjPgAIAZrrUIwhoQLIQIgACAENwMAIAAgAiADQoCAgICAgICAgH+DhDcDCCAFQRBqJAALYwIBfwF+IwBBEGsiAiQAIAACfiABRQRAQgAMAQsgAiABrUIAIAFnIgFB0QBqEDkgAikDCEKAgICAgIDAAIVBnoABIAFrrUIwhnwhAyACKQMACzcDACAAIAM3AwggAkEQaiQAC7QDAgN/AX4jAEEgayIDJAACQCABQv///////////wCDIgVCgICAgICAwMA/fSAFQoCAgICAgMC/wAB9VARAIAFCGYinIQQgAFAgAUL///8PgyIFQoCAgAhUIAVCgICACFEbRQRAIARBgYCAgARqIQIMAgsgBEGAgICABGohAiAAIAVCgICACIWEQgBSDQEgAiAEQQFxaiECDAELIABQIAVCgICAgICAwP//AFQgBUKAgICAgIDA//8AURtFBEAgAUIZiKdB////AXFBgICA/gdyIQIMAQtBgICA/AchAiAFQv///////7+/wABWDQBBACECIAVCMIinIgRBkf4ASQ0AIANBEGogACABQv///////z+DQoCAgICAgMAAhCIFIARBgf4AaxA5IAMgACAFQYH/ACAEaxA7IAMpAwgiAEIZiKchAiADKQMAIAMpAxAgAykDGIRCAFKthCIFUCAAQv///w+DIgBCgICACFQgAEKAgIAIURtFBEAgAkEBaiECDAELIAUgAEKAgIAIhYRCAFINACACQQFxIAJqIQILIANBIGokACACIAFCIIinQYCAgIB4cXK+CxgAQa+DFCwAAEEASARAQaSDFCgCABA0CwtqAQN/IAEQLyICQfD///8HSQRAAkAgAkEKTQRAIAAgAjoACyAAIQMMAQsgAkEPckEBaiIEEFQhAyAAIARBgICAgHhyNgIIIAAgAzYCACAAIAI2AgQLIAMgASACEEsgAmpBADoAAA8LEFUACzYBAX9BASAAIABBAU0bIQACQANAIAAQMyIBDQFBsLIUKAIAIgEEQCABEQkADAELCxAdAAsgAQsIAEGoPxBYAAsYAEGfgxQsAABBAEgEQEGUgxQoAgAQNAsLCABBuzwQWAALYQEDf0EIEFkiAUGc+xM2AgAgAUHI+RM2AgAgABAvIgJBDWoQVCIDQQA2AgggAyACNgIEIAMgAjYCACABIANB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w6T/A00EQCACQYCAwPIDSQ0BIABEAAAAAAAAAABBABDfBCEADAELIAJBgIDA/wdPBEAgACAAoSEADAELAkACQAJAAkAgACABELkBQQNxDgMAAQIDCyABKwMAIAErAwhBARDfBCEADAMLIAErAwAgASsDCBDgBCEADAILIAErAwAgASsDCEEBEN8EmiEADAELIAErAwAgASsDCBDgBJohAAsgAUEQaiQAIAALqAMCBX8BfiAAvUL///////////8Ag0KBgICAgICA+P8AVCABvUL///////////8Ag0KAgICAgICA+P8AWHFFBEAgACABoA8LIAG9IgdCIIinIgJBgIDA/wNrIAenIgVyRQRAIAAQpwEPCyACQR52QQJxIgYgAL0iB0I/iKdyIQMCQCAHQiCIp0H/////B3EiBCAHp3JFBEACQAJAIANBAmsOAgABAwtEGC1EVPshCUAPC0QYLURU+yEJwA8LIAJB/////wdxIgIgBXJFBEBEGC1EVPsh+T8gAKYPCwJAIAJBgIDA/wdGBEAgBEGAgMD/B0cNASADQQN0QYD2EmorAwAPCyAEQYCAwP8HRyACQYCAgCBqIARPcUUEQEQYLURU+yH5PyAApg8LAnwgBgRARAAAAAAAAAAAIARBgICAIGogAkkNARoLIAAgAaOZEKcBCyEAAkACQAJAIAMOAwQAAQILIACaDwtEGC1EVPshCUAgAEQHXBQzJqahvKChDwsgAEQHXBQzJqahvKBEGC1EVPshCcCgDwsgA0EDdEGg9hJqKwMAIQALIAALryACMXwEfyMAQTBrIjUkACAAIAE5A4ABIABBADYCDCAAKwPYASABIAGiIgWiIQggACsDwAEgAaIgACsD+AWgIQogBSAAKwOIAaIhEiAAKwPgBSIGIAArAzCiIAGiIRhEAAAAAAAA8D8gACsDKCABoqEhDyAAKwNoIicgAaIgACsDiAYiKKAhDCAAKwO4ASABoiAAKwOQBqAhBCAAKwOQByEdIAArA4gHIR8gACgCFEEBRwRAIAUgAaIiCSABoiIHIAEgACsDoAGiIAArA5gBoKIgACsDkAEgCaIgEqCgIRIgDyAAKwNAIAWioSAAKwNIIAmioSAAKwNQIAeioSEPIAArA2AhBSAEEGohCSAMIAArA3AgAaIgACsD0AEgBSAJokQAAAAAAADwP6AiBSAF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aiAJIARrQQJ0aigCAEUNAAsgAyAEaiEEA0AgBkHAAmogAyAKaiIHQQN0aiADQQFqIgMgEGpBAnRB0PYSaigCALc5AwBBACECRAAAAAAAAAAAIQAgCkEASgRAA0AgDyACQQN0aisDACAGQcACaiAHIAJrQQN0aisDAKIgAKAhACACQQFqIgIgCkcNAAsLIAYgA0EDdGogADkDACADIARIDQALIAQhAwwACwALIQMgCCsDACEAIBpCAFMEQCABIACaOQMAIAEgCCsDCJo5AwhBACADayEDDAELIAEgADkDACABIAgrAwg5AwgLIAhBMGokACADC38CAX8BfiAAvSIDQjSIp0H/D3EiAkH/D0cEfCACRQRAIAEgAEQAAAAAAAAAAGEEf0EABSAARAAAAAAAAPBDoiABELoBIQAgASgCAEFAags2AgAgAA8LIAEgAkH+B2s2AgAgA0L/////////h4B/g0KAgICAgICA8D+EvwUgAAsLxgIBBH8jAEHQAWsiBSQAIAUgAjYCzAEgBUGgAWoiAkEAQSgQKRogBSAFKALMATYCyAECQEEAIAEgBUHIAWogBUHQAGogAiADIAQQvAFBAEgEQEF/IQQMAQsgACgCTEEATiEGIAAgACgCACIIQV9xNgIAAn8CQAJAIAAoAjBFBEAgAEHQADYCMCAAQQA2AhwgAEIANwMQIAAoAiwhByAAIAU2AiwMAQsgACgCEA0BC0F/IAAQKg0BGgsgACABIAVByAFqIAVB0ABqIAVBoAFqIAMgBBC8AQshAiAHBEAgAEEAQQAgACgCJBEEABogAEEANgIwIAAgBzYCLCAAQQA2AhwgACgCFCEBIABCADcDECACQX8gARshAgsgACAAKAIAIgAgCEEgcXI2AgBBfyACIABBIHEbIQQgBkUNAAsgBUHQAWokACAEC50TAhN/AX4jAEHQAGsiCCQAIAggATYCTCAIQTdqIRggCEE4aiESAkACQAJAA0BBACEHA0AgASENIAcgEUH/////B3NKDQIgByARaiERAkACQAJAIA0iBy0AACILBEADQAJAAkAgC0H/AXEiAUUEQCAHIQEMAQsgAUElRw0BIAchCwNAIAstAAFBJUcEQCALIQEMAgsgB0EBaiEHIAstAAIhCSALQQJqIgEhCyAJQSVGDQALCyAHIA1rIgcgEUH/////B3MiGUoN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QQhqQaCiFEEYEIgBRQ0BQRgQMyIARQ0AIAAgASkCCDcCACAAIAEpAhg3AhAgACABKQIQNwIIDAELQQAhAAsgAUEgaiQAQZykFEEBOgAAQZikFCAANgIAIAALFgAgACABIAJCgICAgICAgICAfxCxAgs/AQF/AkAgACABRg0AA0AgACABQQRrIgFPDQEgACgCACECIAAgASgCADYCACABIAI2AgAgAEEEaiEADAALAAsL5QQBAn8gAygCBCEAIAMoAhwhBiMAQeABayIDJAAgAyACNgLYASADIAE2AtwBIAAQwwIhByADQcgBaiAGIANB1wFqEMQCIANBvAFqIgJCADcCACACQQA2AgggAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCPAiADIAIoAgAgAiACLQALQYABcUEHdhsiBjYCuAEgAyADQRBqNgIMIANBADYCCANAAkAgA0HcAWogA0HYAWoQ9QENACADKAK4ASAGIAIoAgQgAi0ACyIAQf8AcSAAQYABcUEHdhsiAGpGBEAgAiAAQQF0EI8CIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQjwIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgYgAGo2ArgBCwJ/IAMoAtwBIgAoAgwiASAAKAIQRgRAIAAgACgCACgCJBEAAAwBCyABLQAAC8AgByAGIANBuAFqIANBCGogAywA1wEgAygCzAEgAy0A0wEgA0EQaiADQQxqQZC5ExDFAg0AIANB3AFqEPcBGgwBCwsgAygCDCEAAkACQCADKALMASADLQDTASIBQf8AcSABQYABcUEHdhtFDQAgACADQRBqa0GfAUoNACADIABBBGoiATYCDCAAIAMoAgg2AgAMAQsgACEBCyAFIAYgAygCuAEgBCAHEM0CNwMAIANByAFqIANBEGogASAEEMcCIANB3AFqIANB2AFqEPUBBEAgBCAEKAIAQQJyNgIACyADKALcASEAIAIQvwIaIANByAFqEL8CGiADQeABaiQAIAALrQECAn8BfiMAQRBrIgQkAAJAIAAgAUcEQEGg/xMoAgAhBUGg/xNBADYCABDJAhogACAEQQxqIAMQygIhBgJAQaD/EygCACIABEAgBCgCDCABRw0BIABBxABHDQMgAkEENgIAQv//////////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aiAGIANBwAFqIAcgASADQdABaiADQSBqIANBHGogA0EYaiADQeABahDXAg0AIANBjAJqEPcBGgwBCwsgAygCHCEAAkACQCADKALUASADLQDbASIBQf8AcSABQYABcUEHdhtFDQAgAy0AF0UNACAAIANBIGprQZ8BSg0AIAMgAEEEaiIBNgIcIAAgAygCGDYCAAwBCyAAIQELIAMgBiADKALAASAEENwCIAMpAwAhCSAFIAMpAwg3AwggBSAJNwMAIANB0AFqIANBIGogASAEEMcCIANBjAJqIANBiAJqEPUBBEAgBCAEKAIAQQJyNgIACyADKAKMAiEAIAIQvwIaIANB0AFqEL8CGiADQZACaiQAIAALsgICBH4FfyMAQSBrIggkAAJAAkACQCABIAJHBEBBoP8TKAIAIQxBoP8TQQA2AgAjAEEQayIJJAAQyQIaIwBBEGsiCiQAIwBBEGsiCyQAIAsgASAIQRxqQQIQsgIgCykDACEEIAogCykDCDcDCCAKIAQ3AwAgC0EQaiQAIAopAwAhBCAJIAopAwg3AwggCSAENwMAIApBEGokACAJKQMAIQQgCCAJKQMINwMQIAggBDcDCCAJQRBqJAAgCCkDECEEIAgpAwghBUGg/xMoAgAiAUUNASAIKAIcIAJHDQIgBSEGIAQhByABQcQARw0DDAILIANBBDYCAAwCC0Gg/xMgDDYCACAIKAIcIAJGDQELIANBBDYCACAGIQUgByEECyAAIAU3AwAgACAENwMIIAhBIGokAAuMBQECfyMAQYACayIAJAAgACACNgL4ASAAIAE2AvwBIABBxAFqIgdCADcCACAHQQA2AgggAEEQaiIGIAMoAhwiATYCACABIAEoAgRBAWo2AgQgACgCEBDzASIBQZC5E0GquRMgAEHQAWogASgCACgCIBEGABogACgCECIBIAEoAgRBAWsiAjYCBCACQX9GBEAgASABKAIAKAIIEQEACyAAQbgBaiICQgA3AgAgAkEANgIIIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQjwIgACACKAIAIAIgAi0AC0GAAXFBB3YbIgM2ArQBIAAgBjYCDCAAQQA2AgggAyEBA0ACQCACIABB/AFqIABB+AFqEPUBBH8gAwUgAyABIAIoAgQgAi0ACyIGQf8AcSAGQYABcUEH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iQUBA38gAygCHCEAIwBB8AJrIgMkACADIAI2AugCIAMgATYC7AIgA0HMAWogACADQeABaiADQdwBaiADQdgBahDuAiADQcABaiICQgA3AgAgAkEANgIIIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQjwIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgY2ArwBIAMgA0EQajYCDCADQQA2AgggA0EBOgAHIANBxQA6AAYgAygC2AEhASADKALcASEHA0ACQCADQewCaiADQegCahCHAg0AIAMoArwBIAYgAigCBCACLQALIgBB/wBxIABBgAFxQQd2GyIAakYEQCACIABBAXQQjwIgAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCPAiADIAIoAgAgAiACLQALQYABcUEHdhsiBiAAajYCvAELAn8gAygC7AIiACgCDCIIIAAoAhBGBEAgACAAKAIAKAIkEQAADAELIAgoAgALIANBB2ogA0EGaiAGIANBvAFqIAcgASADQcwBaiADQRBqIANBDGogA0EIaiADQeABahDvAg0AIANB7AJqEIkCGgwBCwsgAygCDCEAAkACQCADKALQASADLQDXASIBQf8AcSABQYABcUEHdhtFDQAgAy0AB0UNACAAIANBEGprQZ8BSg0AIAMgAEEEaiIBNgIMIAAgAygCCDYCAAwBCyAAIQELIAUgBiADKAK8ASAEENgCOAIAIANBzAFqIANBEGogASAEEMcCIANB7AJqIANB6AJqEIcCBEAgBCAEKAIAQQJyNgIACyADKALsAiEAIAIQvwIaIANBzAFqEL8CGiADQfACaiQAIAALrAEBAX8jAEEQayIFJAAgBSABNgIMIAEgASgCBEEBajYCBCAFKAIMEIYCIgFBkLkTQbC5EyACIAEoAgAoAjARBgAaIAMgBSgCDBDhAiIBIAEoAgAoAgwRAAA2AgAgBCABIAEoAgAoAhARAAA2AgAgACABIAEoAgAoAhQRAgAgBSgCDCIAIAAoAgRBAWsiATYCBCABQX9GBEAgACAAKAIAKAIIEQEACyAFQRBqJAALxgQAAkACQCAAIAVGBEAgAS0AAEUNAkEAIQUgAUEAOgAAIAQgBCgCACIAQQFqNgIAIABBLjoAACAHKAIEIActAAsiAEH/AHEgAEGA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AygC/AIhACACEL8CGiADQdwBahC/AhogA0GAA2okACAAC4sFAQJ/IwBBwAJrIgAkACAAIAI2ArgCIAAgATYCvAIgAEHEAWoiB0IANwIAIAdBADYCCCAAQRBqIgYgAygCHCIBNgIAIAEgASgCBEEBajYCBCAAKAIQEIYCIgFBkLkTQaq5EyAAQdABaiABKAIAKAIwEQYAGiAAKAIQIgEgASgCBEEBayICNgIEIAJBf0YEQCABIAEoAgAoAggRAQALIABBuAFqIgJCADcCACACQQA2AgggAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCPAiAAIAIoAgAgAiACLQALQYABcUEHdhsiAzYCtAEgACAGNgIMIABBADYCCCADIQEDQAJAIAIgAEG8AmogAEG4AmoQhwIEfyADBSADIAEgAigCBCACLQALIgZB/wBxIAZBgAFxQQd2GyIGakYEQCACIAZBAXQQjwIgAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCPAiAAIAIoAgAgAiACLQALQYABcUEHdhsiASAGajYCtAELAn8gACgCvAIiAygCDCIGIAMoAhBGBEAgAyADKAIAKAIkEQAADAELIAYoAgALQRAgASAAQbQBaiAAQQhqQQAgBygCBCAHLQALIABBEGogAEEMaiAAQdABahDnAkUNASAAKAK0AQsgAWsQjwIgAigCACACIAItAAtBgAFxQQd2GyEBEMkCIQMgACAFNgIAIAEgAyAAEN4CQQFHBEAgBEEENgIACyAAQbwCaiAAQbgCahCHAgRAIAQgBCgCAEECcjYCAAsgACgCvAIhASACEL8CGiAHEL8CGiAAQcACaiQAIAEPCyAAQbwCahCJAhogACgCtAEhAwwACwALkwIBAX8jAEEgayIFJAAgBSABNgIcAkAgAi0ABEEBcUUEQCAAIAEgAiADIAQgACgCACgCGBEHACECDAELIAUgAigCHCIANgIQIAAgACgCBEEBajYCBCAFKAIQEL0CIQAgBSgCECIBIAEoAgRBAWsiAjYCBCACQX9GBEAgASABKAIAKAIIEQEACwJAIAQEQCAFQRBqIAAgACgCACgCGBECAAwBCyAFQRBqIAAgACgCACgCHBECAAsgBSAFQRBqEPQCNgIMA0AgBUEQahD1AiEAIAAgBSgC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QRBqJAAgACgCECEBIAAgACgCFDYCDCACIAE2AgggAiAAKAIMNgIMIABBIGokACACKAIMIQAgAkEQaiQAIAMkACAACwUAQf8ACxAAIABCADcCACAAQQA2AggLJwAjAEEQayIBJAAgAEEBOgALIABBAUEtEJECQQA6AAEgAUEQaiQACwwAIABBgoaAIDYAAAsIAEH/////BwsMACAAQQFBLRCKAxoLNQAgAS0AC0GAAXFBB3ZFBEAgACABKQIANwIAIAAgASgCCDYCCA8LIAAgASgCACABKAIEEHYL8wQBAn8jAEGQAmsiACQAIAAgAjYCiAIgACABNgKMAiAAQdYANgIQIABBmAFqIgcgAEGgAWo2AgAgByAAKAIQNgIEIABBkAFqIgggBCgCHCIBNgIAIAEgASgCBEEBajYCBCAAKAKQARDzASEBIABBADoAjwECQCAAQYwCaiACIAMgCCAEKAIEIAUgAEGPAWogASAHIABBlAFqIABBhAJqELQDRQ0AIABB7uUSKAAANgCHASAAQeflEikAADcDgAEgASAAQYABaiAAQYoBaiAAQfYAaiABKAIAKAIgEQYAGiAAQdQANgIQIABBCGoiA0EANgIAIAMgAEEQaiIEKAIANgIEAkAgACgClAEiASAHKAIAayICQeMATgRAIAJBAmoQMyEEIAMoAgAhAiADIAQ2AgAgAgRAIAIgAygCBBEBAAsgAygCACIERQ0BCyAALQCPAQRAIARBLToAACAEQQFqIQQLIAcoAgAhAgNAIAEgAk0EQAJAIARBADoAACAAIAY2AgAgAEEQakGBwAAgABBpQQFHDQAgAygCACEBIANBADYCACABBEAgASADKAIEEQEACwwECwUgBCAAQfYAaiIBIAFBCmogAi0AABDIAiAAayAAai0ACjoAACAEQQFqIQQgAkEBaiECIAAoApQBIQEMAQsLENUBAAsQ1QEACyAAQYwCaiAAQYgCahD1AQRAIAUgBSgCAEECcjYCAAsgACgCjAIhAiAAKAKQASIBIAEoAgRBAWsiAzYCBCADQX9GBEAgASABKAIAKAIIEQEACyAHKAIAIQEgB0EANgIAIAEEQCABIAcoAgQRAQALIABBkAJqJAAgAguGGAEPfyMAQZAEayILJAAgCyAKNgKIBCALIAE2AowEAkAgACALQYwEahD1AQRAIAUgBSgCAEEEcjYCAEEAIQAMAQsgC0HWADYCTCALQegAaiIBIAtB8ABqNgIAIAEgC0HMAGoiESgCADYCBCALIAEiEygCACIONgJkIAsgDkGQA2o2AmAgEUIANwIAIBFBADYCCCALQUBrIg9CADcCACAPQQA2AgggC0E0aiIMQgA3AgAgDEEANgIIIAtBKGoiDUIANwIAIA1BADYCCCALQRxqIhJCADcCACASQQA2AgggAygCACEBIwBBEGsiAyQAIAsCfyACBEAgA0EEaiICIAEQuAMiASABKAIAKAIsEQIAIAsgAygCBDYAXCACIAEgASgCACgCIBECACANIAIQjAIgAhC/AhogAiABIAEoAgAoAhwRAgAgDCACEIwCIAIQvwIaIAsgASABKAIAKAIMEQAAOgBbIAsgASABKAIAKAIQEQAAOgBaIAIgASABKAIAKAIUEQIAIBEgAhCMAiACEL8CGiACIAEgASgCACgCGBECACAPIAIQjAIgAhC/AhogASABKAIAKAIkEQAADAELIANBBGoiAiABELkDIgEgASgCACgCLBECACALIAMoAgQ2AFwgAiABIAEoAgAoAiARAgAgDSACEIwCIAIQvwIaIAIgASABKAIAKAIcEQIAIAwgAhCMAiACEL8CGiALIAEgASgCACgCDBEAADoAWyALIAEgASgCACgCEBEAADoAWiACIAEgASgCACgCFBECACARIAIQjAIgAhC/AhogAiABIAEoAgAoAhgRAgAgDyACEIwCIAIQvwIaIAEgASgCACgCJBEAAAs2AhggA0EQaiQAIAkgCCgCADYCACAEQYAEcSEWIAsoAhghFCALLQBfIRcgCy0AWyEYIAstAFohGSAOIQRBACECA0ACQAJAAkACQCACQQRGDQAgACALQYwEahD1AQ0AQQAhAQJAAkACQAJAAkACQAJAIAtB3ABqIAJqLAAADgUBAAQDBQkLIAJBA0YNCAJ/IAAoAgAiASgCDCIDIAEoAhBGBEAgASABKAIAKAIkEQAADAELIAMtAAALwCEBIAcoAgghAyABQQBOBH8gAyABQf8BcUECdGooAgBBAXEFQQALBEAgC0EQaiAAELUDIBIgCywAEBCGAQwCCyAFIAUoAgBBBHI2AgBBACEADAkLIAJBA0YNBwsDQCAAIAtBjARqEPUBDQcCfyAAKAIAIgEoAgwiAyABKAIQ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AiAAKAIkIAAoAiAgAyAEEKkBIQIgACgCKCEBIABBADYCKCABBEAgASAAKAIsEQEACyAHEL8CGiAIEL8CGiANEL8CGiAAKALMASIBIAEoAgRBAWsiAzYCBCADQX9GBEAgASABKAIAKAIIEQEACyAAKALQASEBIABBADYC0AEgAQRAIAEgACgC1AERAQALIAsoAgAhASALQQA2AgAgAQRAIAEgCygCBBEBAAsgAEHAA2okACACDwsQ1QEAC+8DAQF/IwBBEGsiCiQAIAkCfyAABEAgAhC4AyEAAkAgAQRAIApBBGoiASAAIAAoAgAoAiwRAgAgAyAKKAIENgAAIAEgACAAKAIAKAIgEQIADAELIApBBGoiASAAIAAoAgAoAigRAgAgAyAKKAIENgAAIAEgACAAKAIAKAIcEQIACyAIIAEQjAIgARC/AhogBCAAIAAoAgAoAgwRAAA6AAAgBSAAIAAoAgAoAhARAAA6AAAgCkEEaiIBIAAgACgCACgCFBECACAGIAEQjAIgARC/AhogASAAIAAoAgAoAhgRAgAgByABEIwCIAEQvwIaIAAgACgCACgCJBEAAAwBCyACELkDIQACQCABBEAgCkEEaiIBIAAgACgCACgCLBECACADIAooAgQ2AAAgASAAIAAoAgAoAiARAgAMAQsgCkEEaiIBIAAgACgCACgCKBECACADIAooAgQ2AAAgASAAIAAoAgAoAhwRAgALIAggARCMAiABEL8CGiAEIAAgACgCACgCDBEAADoAACAFIAAgACgCACgCEBEAADoAACAKQQRqIgEgACAAKAIAKAIUEQIAIAYgARCMAiABEL8CGiABIAAgACgCACgCGBECACAHIAEQjAIgARC/AhogACAAKAIAKAIkEQAACzYCACAKQRBqJAALqAcBCX8gAiAANgIAIANBgARxIRUDQCAUQQRGBEAgDSgCBCANLQALIgRB/wBxIARBgAFxQQd2G0EBSwRAIAIgDRD0AkEBELoDIA0Q9QIgAigCABDLAzYCAAsgA0GwAXEiA0EQRwRAIAEgA0EgRgR/IAIoAgAFIAALNgIACwUCQAJAAkACQAJAAkAgCCAUaiwAAA4FAAEDAgQFCyABIAIoAgA2AgAMBAsgASACKAIANgIAIAZBICAGKAIAKAIcEQMAIQ8gAiACKAIAIhBBAWo2AgAgECAPOgAADAMLIA0oAgQgDS0ACyIPQf8AcSAPQYABcUEHdhtFDQIgDSgCACANIA0tAAtBgAFxQQd2Gy0AACEPIAIgAigCACIQQQFqNgIAIBAgDzoAAAwCCyAMKAIEIAwtAAsiD0H/AHEgD0GAAXFBB3YbRSEPIBVFDQEgDw0BIAIgDBD0AiAMEPUCIAIoAgAQywM2AgAMAQsgBigCCCEPIAIoAgAhFiAEIAdqIgQhEQNAAkAgBSARTQ0AIBEsAAAiEEEATgR/IA8gEEH/AXFBAnRqKAIAQcAAcUEARwVBAAtFDQAgEUEBaiERDAELCyAOIg9BAEoEQANAAkAgBCARTw0AIA9FDQAgD0EBayEPIBFBAWsiES0AACEQIAIgAigCACISQQFqNgIAIBIgEDoAAAwBCwsgDwR/IAZBMCAGKAIAKAIcEQMABUEACyESA0AgAiACKAIAIhBBAWo2AgAgD0EASgRAIBAgEjoAACAPQQFrIQ8MAQsLIBAgCToAAAsCQCAEIBFGBEAgBkEwIAYoAgAoAhwRAwAhDyACIAIoAgAiEEEBajYCACAQIA86AAAMAQtBfyEQIAsoAgQgCy0ACyIPQf8AcSAPQYABcUEHdhsEQCALKAIAIAsgCy0AC0GAAXFBB3YbLAAAIRALQQAhD0EAIRMDQCAEIBFGDQECQCAPIBBHBEAgDyESDAELIAIgAigCACIQQQFqNgIAIBAgCjoAAEEAIRIgE0EBaiITIAsoAgQgCy0ACyIQQf8AcSAQQYABcUEHdhtPBEAgDyEQDAELQX8hECATIAsoAgAgCyALLQALQYABcUEHdhtqLQAAQf8ARg0AIBMgCygCACALIAstAAtBgAFxQQd2G2osAAAhEAsgEUEBayIRLQAAIQ8gAiACKAIAIhdBAWo2AgAgFyAPOgAAIBJBAWohDwwACwALIBYgAigCABD7AgsgFEEBaiEUDAELCwuTAQEDfyMAQRBrIgQkACMAQSBrIgMkACMAQRBrIgUkACAFIAE2AgwgAyAANgIYIAMgBSgCDDYCHCAFQRBqJAAgA0EQaiADKAIYIAMoAhwgAhDoASAAIAMoAhAgAGsQugMhACADIAMoAhQ2AgwgBCAANgIIIAQgAygCDDYCDCADQSBqJAAgBCgCDCEAIARBEGokACAAC8gFAQh/IwBBsAFrIgAkACAAIAMoAhwiBjYCrAEgBiAGKAIEQQFqNgIEIAAoAqwBEPMBIQsgBSgCBCAFLQALIgZB/wBxIAZBgAFxQQd2GwRAIAUoAgAgBSAFLQALQYABcUEHdhstAAAgC0EtIAsoAgAoAhwRAwBB/wFxRiEMCyAAQZgBaiIKQgA3AgAgCkEANgIIIABBjAFqIgZCADcCACAGQQA2AgggAEGAAWoiCUIANwIAIAlBADYCCCACIAwgACgCrAEgAEGoAWogAEGnAWogAEGmAWogCiAGIAkgAEH8AGoQyQMgAEHUADYCECAAQQA2AgggACAAQRBqIgIoAgA2AgwCQAJ/IAUoAgQgBS0ACyIHQf8AcSAHQYABcUEHdhsiByAAKAJ8Ig1KBEAgByANa0EBdCAJKAIEIAktAAsiCEH/AHEgCEGAAXFBB3YbaiAGKAIEIAYtAAsiCEH/AHEgCEGAAXFBB3YbakEBagwBCyAJKAIEIAktAAsiCEH/AHEgCEGAAXFBB3YbIAYoAgQgBi0ACyIIQf8AcSAIQYABcUEHdhtqQQJqCyANaiIIQeUATwRAIAgQMyEHIAAoAgghAiAAIAc2AgggAgRAIAIgACgCDBEBAAsgACgCCCICRQ0BIAUoAgQgBS0ACyIHQf8AcSAHQYABcUEHdhshBwsgAiAAQQRqIAAgAygCBCAFKAIAIAUgBS0AC0GAAXFBB3YbIgUgBSAHaiALIAwgAEGoAWogACwApwEgACwApgEgCiAGIAkgDRDKAyABIAIgACgCBCAAKAIAIAMgBBCpASECIAAoAgghASAAQQA2AgggAQRAIAEgACgCDBEBAAsgCRC/AhogBhC/AhogChC/AhogACgCrAEiASABKAIEQQFrIgM2AgQgA0F/RgRAIAEgASgCACgCCBEBAAsgAEGwAWokACACDwsQ1QEAC6kHAQp/IwBBoAhrIgAkACAAIAU3AxAgACAGNwMYIAAgAEGwB2oiCzYCrAcgCyAAQRBqEKwCIQogAEHUADYCkAQgAEGIBGoiC0EANgIAIAsgACgCkAQ2AgQgAEHUADYCkAQgAEEANgKABCAAIAAoApAENgKEBAJAAkAgCkHkAEkEQCAAQZAEaiEMIABBsAdqIQgMAQsQyQIhCiAAIAU3AwAgACAGNwMIIABBrAdqIApB+z8gABCBAyIKQX9GDQEgCygCACEHIAsgACgCrAciCDYCACAHBEAgByALKAIEEQEACyAKQQJ0EDMhDCAAKAKABCEHIAAgDDYCgAQgBwRAIAcgACgChAQRAQALIAAoAoAEIgxFDQELIAAgAygCHCIHNgL8AyAHIAcoAgRBAWo2AgQgACgC/AMQhgIiECIHIAggCCAKaiAMIAcoAgAoAjARBgAaIApBAEoEQCAILQAAQS1GIQ4LIABB5ANqIg1CADcCACANQQA2AgggAEHYA2oiCEIANwIAIAhBADYCCCAAQcwDaiIHQgA3AgAgB0EANgIIIAIgDiAAKAL8AyAAQfgDaiAAQfQDaiAAQfADaiANIAggByAAQcgDahDOAyAAQdQANgIwIABBADYCKCAAIABBMGoiAigCADYCLAJ/IAAoAsgDIg8gCkgEQCAKIA9rQQF0IAcoAgQgBy0ACyIJQf8AcSAJQYABcUEHdhtqIAgoAgQgCC0ACyIJQf8AcSAJQYABcUEHdhtqQQFqDAELIAcoAgQgBy0ACyIJQf8AcSAJQYABcUEHdhsgCCgCBCAILQALIglB/wBxIAlBgAFxQQd2G2pBAmoLIA9qIglB5QBPBEAgCUECdBAzIQkgACgCKCECIAAgCTYCKCACBEAgAiAAKAIsEQEACyAAKAIoIgJFDQELIAIgAEEkaiAAQSBqIAMoAgQgDCAMIApBAnRqIBAgDiAAQfgDaiAAKAL0AyAAKALwAyANIAggByAPEM8DIAEgAiAAKAIkIAAoAiAgAyAEEIkDIQIgACgCKCEBIABBADYCKCABBEAgASAAKAIsEQEACyAHEOMCGiAIEOMCGiANEL8CGiAAKAL8AyIBIAEoAgRBAWsiAzYCBCADQX9GBEAgASABKAIAKAIIEQEACyAAKAKABCEBIABBADYCgAQgAQRAIAEgACgChAQRAQALIAsoAgAhASALQQA2AgAgAQRAIAEgCygCBBEBAAsgAEGgCGokACACDwsQ1QEAC+8DAQF/IwBBEGsiCiQAIAkCfyAABEAgAhDCAyEAAkAgAQRAIApBBGoiASAAIAAoAgAoAiwRAgAgAyAKKAIENgAAIAEgACAAKAIAKAIgEQIADAELIApBBGoiASAAIAAoAgAoAigRAgAgAyAKKAIENgAAIAEgACAAKAIAKAIcEQIACyAIIAEQwwMgARDjAhogBCAAIAAoAgAoAgwRAAA2AgAgBSAAIAAoAgAoAhARAAA2AgAgCkEEaiIBIAAgACgCACgCFBECACAGIAEQjAIgARC/AhogASAAIAAoAgAoAhgRAgAgByABEMMDIAEQ4wIaIAAgACgCACgCJBEAAAwBCyACEMQDIQACQCABBEAgCkEEaiIBIAAgACgCACgCLBECACADIAooAgQ2AAAgASAAIAAoAgAoAiARAgAMAQsgCkEEaiIBIAAgACgCACgCKBECACADIAooAgQ2AAAgASAAIAAoAgAoAhwRAgALIAggARDDAyABEOMCGiAEIAAgACgCACgCDBEAADYCACAFIAAgACgCACgCEBEAADYCACAKQQRqIgEgACAAKAIAKAIUEQIAIAYgARCMAiABEL8CGiABIAAgACgCACgCGBECACAHIAEQwwMgARDjAhogACAAKAIAKAIkEQAACzYCACAKQRBqJAALuwcBCX8gAiAANgIAIANBgARxIRUgB0ECdCEWA0AgFEEERgRAIA0oAgQgDS0ACyIEQf8AcSAEQYABcUEHdhtBAUsEQCACIA0Q9AJBARDFAyANEIYDIAIoAgAQ0AM2AgALIANBsAFxIgNBEEcEQCABIANBIEYEfyACKAIABSAACzYCAAsFAkACQAJAAkACQAJAIAggFGosAAAOBQABAwIEBQsgASACKAIANgIADAQLIAEgAigCADYCACAGQSAgBigCACgCLBEDACEHIAIgAigCACIPQQRqNgIAIA8gBzYCAAwDCyANKAIEIA0tAAsiB0H/AHEgB0GAAXFBB3YbRQ0CIA0oAgAgDSANLQALQYABcUEHdhsoAgAhByACIAIoAgAiD0EEajYCACAPIAc2AgAMAgsgDCgCBCAMLQALIgdB/wBxIAdBgAFxQQd2G0UhByAVRQ0BIAcNASACIAwQ9AIgDBCGAyACKAIAENADNgIADAELIAIoAgAhFyAEIBZqIgQhBwNAAkAgBSAHTQ0AIAZBwAAgBygCACAGKAIAKAIMEQQARQ0AIAdBBGohBwwBCwsgDkEASgRAIAIoAgAhDyAOIRADQAJAIAQgB08NACAQRQ0AIBBBAWshECAHQQRrIgcoAgAhESACIA9BBGoiEjYCACAPIBE2AgAgEiEPDAELCwJAIBBFBEBBACERDAELIAZBMCAGKAIAKAIsEQMAIREgAigCACEPCwNAIA9BBGohEiAQQQBKBEAgDyARNgIAIBBBAWsh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dEHAoxNqKAIABSABCws8AANAIAEgAkZFBEAgASABKAIAIgBB/wBNBH8gAEECdEHAoxNqKAIABSAACzYCACABQQRqIQEMAQsLIAILKgADQCABIAJGRQRAIAMgASwAADYCACADQQRqIQMgAUEBaiEBDAELCyACCw4AIAEgAiABQYABSRvACzUAA0AgASACRkUEQCAEIAEoAgAiACADIABBgAFJGzoAACAEQQFqIQQgAUEEaiEBDAELCyACCwkAIAAQrwQQNAsoAQF/IABBnLsTNgIAAkAgACgCCCIBRQ0AIAAtAAxFDQAgARA0CyAACx8AIAFBAE4EfyABQf8BcUECdEHArxNqKAIABSABC8ALOwADQCABIAJGRQRAIAEgASwAACIAQQBOBH8gAEECdEHArxNqKAIABSAACzoAACABQQFqIQEMAQsLIAILHwAgAUEATgR/IAFB/wFxQQJ0QcCjE2ooAgAFIAELwAs7AANAIAEgAkZFBEAgASABLAAAIgBBAE4EfyAAQQJ0QcCjE2ooAgAFIAALOgAAIAFBAWohAQwBCwsgAgsqAANAIAEgAkZFBEAgAyABLQAAOgAAIANBAWohAyABQQFqIQEMAQsLIAILDAAgAiABIAFBAEgbCzQAA0AgASACRkUEQCAEIAMgASwAACIAIABBAEgbOgAAIARBAWohBCABQQFqIQEMAQsLIAILCQAgABC4BBA0C74BAQR/IABBiLsTNgIAIABBCGohAwNAIAIgACgCDCAAKAIIIgFrQQJ1SQRAIAEgAkECdGooAgAiAQRAIAEgASgCBEEBayIENgIEIARBf0YEQCABIAEoAgAoAggRAQALCyACQQFqIQIMAQsLIABBmAFqEL8CGiMAQRBrIgEkACABIAM2AgwgASgCDCICKAIABEAgAhDWAyABKAIMIgJBEGogAigCACIDIAIoAgggA2tBAnUQ2wMLIAFBEGokACAACwMAAAu9AgEDfyMAQRBrIggkACACQe7///8HIAFrTQRAIAAoAgAgACAALQALQYABcUEHdhshCSAIQQRqIAFB5v///wNNBH8gCCABQQF0NgIMIAggASACajYCBCAIQQxqIgIgCEEEaiIKIAooAgAgAigCAEkbKAIAIgJBC08EfyACQRBqQXBxIgIgAkEBayICIAJBC0YbBUEKC0EBagVB7////wcLEI4C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AyAEIAUgACgCACgCFBEMAAuaAQAgAEEBOgA1AkAgACgCBCACRw0AIABBAToANAJAIAAoAhAiAkUEQCAAQQE2AiQgACADNgIYIAAgATYCECADQQFHDQIgACgCMEEBRg0BDAILIAEgAkYEQCAAKAIYIgJBAkYEQCAAIAM2AhggAyECCyAAKAIwQQFHDQIgAkEBRg0BDAILIAAgACgCJEEBajYCJAsgAEEBOgA2CwuKAgAgACABKAIIIAQQxgQEQAJAIAEoAgQgAkcNACABKAIcQQFGDQAgASADNgIcCw8LAkAgACABKAIAIAQQxgQEQAJAIAIgASgCEEcEQCABKAIUIAJHDQELIANBAUcNAiABQQE2AiAPCyABIAM2AiACQCABKAIsQQRGDQAgAUEAOwE0IAAoAggiACABIAIgAkEBIAQgACgCACgCFBEMACABLQA1BEAgAUEDNgIsIAEtADRFDQEMAwsgAUEENgIsCyABIAI2AhQgASABKAIoQQFqNgIoIAEoAiRBAUcNASABKAIYQQJHDQEgAUEBOgA2DwsgACgCCCIAIAEgAiADIAQgACgCACgCGBENAAsLMwAgACABKAIIQQAQxgQEQCABIAIgAxDNBA8LIAAoAggiACABIAIgAyAAKAIAKAIcEQoAC10BAX8gACgCECIDRQRAIABBATYCJCAAIAI2AhggACABNgIQDwsCQCABIANGBEAgACgCGEECRw0BIAAgAjYCGA8LIABBAToANiAAQQI2AhggACAAKAIkQQFqNgIkCwsaACAAIAEoAghBABDGBARAIAEgAiADEM0ECwtEACAAIAICf0EAIANFDQAaIAFBCHUiAiABQQFxRQ0AGiACIAMoAgBqKAIACyADaiAEQQIgAUECcRsgACgCACgCHBEKAAt6AQJ/IAAgASgCCEEAEMYEBEAgASACIAMQzQQPCyAAKAIMIQUgACgCECAAKAIUIAEgAiADEM8EAkAgAEEYaiIEIABBEGogBUEDdGoiAE8NAANAIAQoAgAgBCgCBCABIAIgAxDPBCABLQA2DQEgBEEIaiIEIABJDQALCwviBAEFfyMAQUBqIgUkAAJAIAFB3PUTQQAQxgQEQCACQQA2AgBBASEEDAELAn8gAC0ACEEYcQRAIAAgAUEBEMYEDAELAkAgAUUNACABQdDzExDIBCIGRQ0AIAAgASAG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AEGJOAsX6NUjtBnUP53gkOw25Ag9AAAAAABA5z8AQak4CxfIccKNcdQ/ddZnCc4nL70AAAAAACDnPwBByTgLFzAXnuDJ1D+k2AobiSAuvQAAAAAAAOc/AEHpOAsXoDgHriLVP1nHZIFwvi49AAAAAADg5j8AQYk5CxfQyFP3e9U/70Bd7u2tHz0AAAAAAMDmPwBBqTkL+7MSYFnfvdXVP9xlpAgqCwq9UHJvcGFnYXRlZFBvc2l0aW9uUHJvcGVydHkAcmVtb3ZlRW50aXR5AGluZmluaXR5AGdldFZlbG9jaXR5AFBvc2l0aW9uUmVnaXN0cnkARmVicnVhcnkASmFudWFyeQBKdWx5AFRodXJzZGF5AFR1ZXNkYXkAV2VkbmVzZGF5AFNhdHVyZGF5AFN1bmRheQBNb25kYXkARnJpZGF5AE1heQAlbS8lZC8leQAlMDE2bGx4AGFycmF5X2luZGV4AGVwaGVtZXJpc19zdGFydF9pZHgALSsgICAwWDB4AC0wWCswWCAwWC0weCsweCAweABOb3YAVGh1AEF1Z3VzdAB1bnNpZ25lZCBzaG9ydABlcGhlbWVyaXNfc3RhcnQAdW5zaWduZWQgaW50AE9jdABmbG9hdABTYXQAdWludDY0X3QAU3ViY2xhc3MAZ2V0Q292ZXJhZ2VQb3NpdGlvbnMAc2VtaV9taW5vcl9heGlzAHNlbWlfbWFqb3JfYXhpcwBBcHIAdmVjdG9yAGdldFZlbG9jaXR5UG9pbnRlcgBPY3RvYmVyAE5vdmVtYmVyAFNlcHRlbWJlcgBEZWNlbWJlcgB1bnNpZ25lZCBjaGFyAE1hcgBhbHRwAGVwaGVtZXJpc19zdG9wAHVuaXhfdGltZXN0YW1wAGVwaGVtZXJpc19zdGVwAFNlcAAlSTolTTolUyAlcABpbmNsbwBlY2NvAFN1bgBKdW4Ac3RkOjpleGNlcHRpb24AZ2V0UG9zaXRpb24ARW50aXR5Q29sbGVjdGlvbgBNb24AbmFuAEphbgBSZWNlaXZlZDogJXNcbgByYWRpdXNlYXJ0aGttAEp1bABib29sAHJlbW92ZUFsbABBcHJpbABlbXNjcmlwdGVuOjp2YWwARnJpAGJhZF9hcnJheV9uZXdfbGVuZ3RoAE1hcmNoAEF1ZwB1bnNpZ25lZCBsb25nAHRlcm1pbmF0aW5nAHN0ZDo6d3N0cmluZwBiYXNpY19zdHJpbmcAc3RkOjpzdHJpbmcAc3RkOjp1MTZzdHJpbmcAc3RkOjp1MzJzdHJpbmcAaW5mACU0ZC0lMmQtJTJkVCUyZDolMmQ6JWxmACUuMExmACVMZgBzaXplAHRydWUAVHVlAHVwZGF0ZQBmYWxzZQB0YWtlQmFzZQBKdW5lAGdldFBvc2l0aW9uSW5SZWZlcmVuY2VGcmFtZQBnZXROYW1lAGRvdWJsZQB2aXNpYmxlAGFwb2dlZQBwZXJpZ2VlAHBlcmlvZAB2b2lkAG5vcmFkX2NhdF9pZAB0ZXJtaW5hdGVfaGFuZGxlciB1bmV4cGVjdGVkbHkgcmV0dXJuZWQAV2VkAHN0ZDo6YmFkX2FsbG9jAHBlcmlvZF9zZWMARGVjAEZlYgBhbHRhAGY2Y2FlMTZkNjcxNGFlODc5N2RjYzY5NDI0NTgwYzJkMTczYjMyOWJmY2YwNDYyZjQ0MTA3YjlmMzBkNDA4ZTYxY2EyMDYxMjBjZjY1YzI1YWE1OGRiNWIzNWJhNGQ0YWRhNjQwZDIxNzJkYzc5NDU0ODdhNDdhZmIzNzM4ZTEzYjUxY2M5Y2M3NTk4NGRjMTg2N2IyZjgwNTc1MjE2Mzk1MTM4OGE1OTA1YWI2MGE2OTlmY2ZlMzE5NDFhMjZmNzAwODYxZjM1OTlkY2E0NTM4NmMwOTcyMGNlYTI2NTFlYzM5MWFkNDNkMjZkNmQ4YQBFQ0NFTlRSSUNJVFkATUVBTl9BTk9NQUxZACVhICViICVkICVIOiVNOiVTICVZAFBPU0lYAE1FQU5fTU9USU9OX0RPVABNRUFOX01PVElPTl9ERE9UAEdNVAAlSDolTTolUwBBUkdfT0ZfUEVSSUNFTlRFUgBCU1RBUgBFTEVNRU5UX1NFVF9OTwBNRUFOX01PVElPTgBJTkNMSU5BVElPTgBOQU4AUE0AYWRkT01NAEdNAEFNAExDX0FMTABSRVZfQVRfRVBPQ0gATEFORwBJTkYARVBIRU1FUklTX1RZUEUAQ0xBU1NJRklDQVRJT05fVFlQRQBSQV9PRl9BU0NfTk9ERQBPQkpFQ1RfSUQATk9SQURfQ0FUX0lEAEMAZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8c2hvcnQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIHNob3J0PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxpbnQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIGludD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8ZmxvYXQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVpbnQ4X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludDhfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dWludDE2X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludDE2X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVpbnQ2NF90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxpbnQ2NF90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzx1aW50MzJfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8aW50MzJfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8Y2hhcj4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgY2hhcj4Ac3RkOjpiYXNpY19zdHJpbmc8dW5zaWduZWQgY2hhcj4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8c2lnbmVkIGNoYXI+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGxvbmc+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIGxvbmc+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGRvdWJsZT4ARmZoYTBmNmRPZENmNWJqZENhQ2JRZElnWGRRZHRlQWNNYUFiVWg1ZU9oRGZrYUhiVGNHZ1ZjMGVVZHdiMWdaZUJhUmhnZGthTWZ6ZllneGJEaGdmSWRQYUdoemhNZzViRGNUZFllOGVLZkJiRWNZY1ZlbGFnZnVoU2FnYU1ndWRWZzFhSWhwY0JnamNWY1NjQWRTZGxiVGVDaFJjWWJHZVZmaWJjaDBkRmgxZU1ocmhOZEJmQWJ4YUZjZ2R4Z1hmTGd5ZkJlUWdXZlNkQmJWaEloQ2VjZm5nTWVSZ01ldWRIZUFlWmJiYVhjQmFNZ1RiTWZpZW9iOGFJY2dic2ZyZURhVWg0ZlVjVWNTZElmTmVNaERoY2JVZEFiMWFNZjVlTWdGYk1iTmRXZFFjVWZZYUpnRGhNZzJiTWdRYzRoQ2REZnhic2N6ZE9lUWIwZjJjUGNDZGdjUmhHZkZjWmdZYkxja2VvY0RlTGJsY2RlU2ZLY1FjWWUxZlVnZ2NFY3BmVWN3Y2tiV2ZCZWxmWWhuY05mQmRkY1RkS2Z6YVFmUWdNaFJiWWZNZlZoeWQ4Y2dnVWFGY2tkZ2NWZ1NiQWJuZUpoemJFYVRnTGJoaHdjR2RXZDFjd2FUZUVhemhJaHFkUGRDaEljTGJLaHdnMWJPaEZnRmdFZ2loRGdUYkFhM2dGZkFjTmJUYk9kVGNCaFRhRGVWYmtoRmVHYkNnUWJ6YU5hamdFYU9hQWRnYjhoYmVNY3pla2JOaE5namV3Zm9lRWVSZGhnV2VXYUNkNWdLZUFieWM1YVhlVWVpZGtoR2NOYlZmSWhCYktnVmhNZEplRmNnZVpkV2VKZ3piUWhYYVVneWVzYjBiRWREZkVkV2FEZEZoY2d2YUlnRmFCaFpmSWRGZ1VoZ2FKZHlmY2d4ZUVheWI0ZGNoQmNsYXRlY2dFZnhoTWR5YUtoamZ3ZWlmQ2Z5YnNhTmhUaGhhUmhSZUlhZ2QwZXdkTmZ4ZVFnRGJVZXpia2R3Z1Vnd2ExYVpiQmhSZGdoa2JNZXpoWWF4Z0RiZ2FJZVBkR2V6ZE1hNWZEZVRmWWQ4Y0tlQmhFaFlmVmJsZWdhdWhTY2doTWV1Y1ZnMWFJZ3BlQmNqYVZiU2dBYlNibGVUaENmUmVZZEdjVmFpaGNmMGdGZjFoTWFyY05kQmdBYXhhRmhnaHhoWGVMZnljQmRRZldhU2hCZVZoSWFDZmNlbmdNZFJoTWV1ZUhkQWhaZWJjWGVCZ01mVGJNZGlkb2Q4aElhZ2ZzYXJjRGVVZTRjVWFVY1NkSWNOZE1nRGNjYlVnQWgxZk1mNWdNY0ZmTWJOZVdjUWNVaFllSmREYk1hMmVNYVFoNGVDZERmeGRzaHplT2ZRaDBkMmdQZENlZ2NSZEdiRmhaY1ljTGJrZm9kRGRMZGxmZGhTZktlUWJZZjFkVWRnaEVocGRVYndia2NXZ0JnbGFZaG5kTmhCZ2RjVGVLZXpiUWRRaE1jUmNZY01kVmZ5YThjZ2RVZ0Zha2dnYVZiU2VBaG5nSmR6ZUViVGdMY2hid2ZHYVdnMWN3aFRkRWV6YklocWNQYUNoSWdMZ0tmd2cxZ09kRmNGZEVmaWNEZVRlQWczZ0ZnQWVOYVRoT2VUZUJkVGZEaFZka2hGZEdjQ2VRZHpoTmRqZEVhT2FBZWdlOGFiZE1memNraE5oTmhqYXdob2hFaFJnaGVXZldhQ2U1YkthQWR5ZTVmWGJVY2lna2JHZE5mVmJJZEJnS2dWZU1iSmRGZGdjWmhXY0poemVRYlhkVWh5ZXNmMGFFaERmRWFXaERlRmVjYnZjSWVGZkJiWmdJYUZiVWdnZEpoeWdjZ3hkRWV5ZjRiY2VCZ2xldGRjZEVjeGdNZ3loS2NqZXdkaWJDYnlmc2ZOZFRiaGVSYVJiSWhnZjBhd2JOZXhnUWJEY1VhemJrZndiVWd3ZDFnWmFCY1JoZ2VrYk1lemJZYnhoRGRnaEloUGdHZnpkTWI1ZkRkVGRZYThnS2FCY0VjWWNWZ2xoZ2d1ZlNoZ2NNYnVkVmIxZElhcGVCY2poVmFTYUFkU2dsZlRoQ2JSaFljR2VWZWlhY2UwZUZiMWJNYXJmTmdCZEFieGhGZGdheGRYZExheWZCZ1FmV2ZTaEJoVmZJZ0NkY2JuZ01iUmdNZ3VkSGRBYlplYmJYY0JoTWVUYU1maWFvZDhoSWdnZ3NlcmJEZFVnNGJVZVVjU2JJZk5iTWVEZWNjVWRBaDFoTWE1ZE1oRmJNZk5hV2FRZ1VmWWhKY0RkTWMyaE1jUWg0Y0NhRGd4aHNkemNPaFFlMGMyaFBlQ2ZnYVJoR2NGZVplWWJMY2tob2NEYUxhbGdkaFNjS2NRZVlmMWJVZ2dmRWFwYVVmd2VrZVdhQmVsZllnbmhOZEJmZGZUaEtnemVRY1FjTWJSZFliTWdWaHlhOGJnZlVhRmFrYWdhVmhTZEFnbmhKYnpoRWFUaExoaGZ3YkdjV2gxY3diVGJFZ3pmSWhxZ1BiQ2hJY0xkS2V3ZzFhT2FGaEZnRWFpZ0RnVGNBaDNhRmhBaE5kVGNPZlRoQmJUYkRnVmZrZEZjR2JDaFFkemdOZWpiRWRPaEFmZ2Y4Z2JnTWF6YWtoTmVOZ2pod2RvZ0VnUmZoYldjV2FDYTVjS2JBZ3lnNWRYY1VjaWRrYkdoTmVWZUlmQmVLY1ZiTWJKYUZiZ2VaZ1dnSmh6Y1FoWGdVZHlkc2YwZUVlRGFFZVdmRGNGYWNhdmdJY0ZoQmVaYklnRmJVYmdmSmh5YmNmeGJFZHloNGdjYkJlbGR0ZGNlRWZ4aE1jeWJLZWpjd2NpZkNneWVzZk5lVGFoaFJlUmNJYmdlMGh3ZU5meGRRaERnVWV6ZWtmd2RVZndhMWRaZ0JiUmVnaGtiTWV6ZVlheGNEY2dkSWdQY0diemZNYzVhRGNUZlllOGZLYUJmRWVZYVZlbGFnZ3VlU2JnZE1ldWNWZjFjSWJwZEJnamJWZFNiQWVTYWxmVGVDZlJnWWJHY1ZmaWFjZzBlRmMxZ01kcmdOaEJiQWR4Z0ZmZ2Z4ZlhjTGV5YkJnUWVXZlNmQmhWZUljQ2ZjZW5kTWRSZU1mdWFIY0FjWmZiZ1hlQmJNYVRnTWFpZG9jOGFJY2dhc2ZyYkRhVWc0YlViVWRTZklkTmVNaERjY2dVZUFoMWZNYjVoTWZGZk1oTmJXZFFmVWNZZ0plRGJNYjJmTWRRYzRjQ2VEZXhkc2R6YU9kUWIwZzJoUGVDaGdjUmJHaEZkWmhZYkxka2dvYkRnTGdsY2RjU2FLYVFmWWgxaFVnZ2JFYXBoVWF3ZmtkV2FCYmxnWWJuZ05lQmNkYlRlS2V6YVFoUWNNYlJkWWdNY1ZheWM4ZGdlVWZGY2tkZ2RWYVNoQWNuaEpkemNFYVRlTGJoZHdhR2hXZDFod2NUZUViemRJZXFjUGVDZklnTGFLYXdmMWFPY0ZlRmRFZWlkRGVUaEFnM2ZGZ0FmTmRUZU9nVGZCZlRhRGJWYmtkRmZHZENjUWV6Z05oamdFZ09lQWZnZzhlYmdNYnpma2NOZ05mamR3YW9lRWVSZ2hmV2ZXZkNjNWdLYkFjeWM1Z1hoVWNpYmthR2VOYlZnSWhCYUthVmZNZEpjRmJnaFpjV2FKZXpjUWNYZVVjeWZzZzBkRWhEYkVhV2JEZEZlY2h2ZElnRmRCaFpjSWVGY1ViZ2JKZHlhY2Z4aEVoeWY0aGNnQmFsZ3RiY2FFYXhhTWR5Z0thamV3YmljQ2Z5ZHNlTmVUZGhmUmhSYUloZ2MwYndmTmF4aFFiRGdVZnpma2R3ZFVld2ExYVplQmNSZmdia2RNYXpjWWN4Y0RiZ2NJZ1BjR2F6ZE1jNWhEZ1RkWWg4Y0tkQmFFZVlnVmVsZ2dodWRTZGdiTWZ1ZFZnMWVJZXBlQmVqZ1ZiU2FBY1NhbGZUZ0NlUmJZY0dkVmJpaGNmMGFGZzFjTWdyZU5lQmdBZnhlRmVnZHhhWGVMYXlkQmVRZldoU2VCZ1ZnSWFDZGNibmFNZlJjTWd1aEhiQWRaYWJkWGhCYk1iVGRNZGlnb2E4YUloZ2JzYnJhRGhVYzRnVWNVZFNnSWJOYU1lRGdjZ1VlQWQxY01kNWhNZUZlTWhOaFdoUWdVZ1lhSmFEY01mMmZNZ1FjNGhDZERjeGJzZXphT2ZRaDBnMmdQZUNkZ2NSYUdkRmJaYVlhTGdrZG9kRGVMZmxjZGZTZEtmUWJZaDFhVWFnYkVmcGVVY3dha2FXZEJlbGRZZG5lTmZCaGRlVGhLY3pkUWVRaE1iUmNZZE1oVmZ5YjhlZ2dVZkZia2FnYlZnU2NBZm5hSmZ6ZUVmVGRMZmhjd2RHZldmMWd3Z1RnRWd6aElncWNQZ0NmSWNMZUtkd2cxYU9oRmRGYkVlaWZEZlRiQWUzYUZhQWdOZVRkT2dUZUJiVGhEY1Zla2NGaEdlQ2dRZnpnTmVqZUVoT2JBZ2diOGRiaE1jemZrZU5hTmNqYXdob2NFZ1JlaGVXZ1diQ2U1ZktkQWd5ZjVnWGRVZWlna2hHZk5iVmhJZEJjS2RWZE1mSmNGYmdlWmFXaEplemFRYlhnVWh5Y3NkMGhFZERkRWZXZERjRmJjaHZjSWJGaEJkWmVJYUZoVWhnZEpkeWVjYXhnRWJ5ZjRmY2RCZGxjdGZjZkVleGdNZ3llS2hqYndlaWFDYnllc2ROY1RmaGdSY1JnSWJnaDBid2JOaHhhUWhEY1ViemNrY3dnVWV3YTFiWmVCaFJjZ2hrZE1oemZZaHhhRGdnZEljUGdHYXphTWQ1ZURnVGZZYThnS2NCZkVjWWdWZGxmZ2V1ZFNhZ2FNZ3ViVmQxYUllcGFCY2piVmRTZUFiU2dsZ1RnQ2ZSY1lmR2FWYWlkY2cwY0ZkMWJNYXJmTmNCZkFoeGRGY2djeGZYZExmeWNCYVFhV2NTZ0JlVmZJZENiY2JuZk1iUmVNY3ViSGJBaFpkYmRYZkJmTWhUYk1haWdvZThkSWJnZHNmcmVEYVViNGVVZlVjU2ZJZ05mTWZEZGNmVWNBYzFmTWY1aE1iRmhNYU5mV2JRZFVlWWFKZURiTWcyYU1iUWI0ZkNhRGJ4YXNnemdPZ1FnMGgyZVBnQ2hnY1JhR2hGYlpkWWZMZWtlb2VEZUxhbGZkZFNjS2RRZ1lmMWNVaGdnRWJwZ1Vjd2JraFdnQmZsaFllbmFOZ0JiZGNUZUtkemNRaFFjTWhSY1lhTWhWZXloOGdnZ1ViRmRraGdoVmJTZ0FlbmJKYXpmRWVUYkxiaGR3ZUdiV2YxZndhVGJFZHpiSWVxZVBmQ2FJZExoS2V3YzFoT2RGY0ZkRWdpZURhVGNBZzNlRmhBY05nVGFPZFRiQmVUY0RlVmdrZEZmR2ZDZ1FhemdOZ2plRWNPY0FhZ2Q4ZmJiTWR6YmtiTmJOZGpod2VvYkVkUmJoaFdiV2NDYzVlS2JBYnllNWVYYVVhaWVraEdkTmJWY0lkQmZLZlZjTWdKYUZhZ2JaaFdlSmV6Y1FoWGZVYnloc2UwZEVhRGRFY1dmRGJGYWNkdmhJZ0ZkQmJaZUlnRmFVY2dhSmR5aGNieGdFY3loNGhjZ0JhbGR0Z2NlRWZ4ZU1ieWVLY2pjd2hpaENheWFzY05mVGJoaFJiUmRJZWdlMGZ3aE5jeGFRYkRkVWh6Y2tkd2hVZXdiMWVaZkJhUmVnZmtmTWR6YVljeGhEZmdlSWRQYUdnemNNZDVnRGdUaFllOGRLYUJmRWJZZlZibGRnZHVoU2dnZ01ndWRWYTFiSWNwZUJlamJWZFNhQWhTZ2xmVGRDZlJhWWhHZlZhaWZjYjBmRmExaE1mcmdOZkJoQWJ4Y0ZmZ2J4ZFhoTGh5ZEJnUWFXZFNhQmZWYklnQ2RjY25jTWFSYU1kdWVIZ0FhWmZiaFhoQmNNYlRjTWNpaG9iOGNJZGdhc2hyY0RkVWM0ZFVmVWJTZkllTmJNYURmY2hVYUFoMWhNZjVhTWdGZk1jTmVXYlFoVWdZaEpoRGFNYjJhTWdRZTRnQ2NEZXhic2d6Y09iUWQwZTJjUGdDZWdlUmJHYUZoWmhZZUxna2JvaERmTGZsZWRoU2ZLYlFiWWgxZVVoZ2RFY3BiVWZ3ZWthV2dCZGxmWWhuY05oQmhkaFRhS2d6YVFhUWFNaFJhWWFNYVZleWM4Z2dhVWRGaGtkZ2ZWZFNoQWRuYkpnemdFYVRhTGdoY3diR2NXZDFld2VUZUVmemhJaHFjUGNDYklhTGhLZXdiMWRPZ0ZkRmNFY2lnRGRUZEFmM2RGZEFhTmdUYU9iVGhCYVRjRGRWYmtkRmhHZkNiUWN6Z05namhFY09oQWVnZDhhYmNNZHpka2ROYk5jamF3Y29iRWZSYWhnV2ZXZUNkNWVLZEFkeWU1ZlhhVWZpY2tmR2JOYVZkSWhCZkthVmhNZkpkRmhnaFplV2NKZ3plUWhYaFVheWFzZDBkRWZEZUVoV2JEYUZjY2N2Y0lhRmZCZFpnSWNGaFVnZ2ZKZ3lhY2V4YkVmeWM0aGNoQmFsZHRlY2dFYXhkTWZ5Y0toamJ3YmliQ2R5aHNkTmNUYWhnUmNSY0llZ2cwaHdmTmN4aFFiRGNVYnpoa2d3Y1Vnd2YxZFpnQmRSZmdma2hNYnpjWWZ4Z0RoZ2JJZlBoR2V6aE1mNWdEY1RiWWQ4ZUtlQmFFYVlmVmdsaGdkdWFTZWdhTWR1YlZkMWNJaHBhQmFqZ1ZlU2RBZVNnbGZUYUNmUmNZaEdhVmJpY2NoMGhGZzFiTWZyYU5nQmJBaHhmRmhnYXhjWGNMYXlkQmdRYldlU2VCZ1ZiSWhDZGNnbmVNY1JnTWd1ZEhkQWNaYWJkWGJCZE1hVGZNaGlob2E4YUlhZ2VzY3JiRGNVZTRkVWJVYVNoSWdOYk1nRGRjY1ViQWMxZ01lNWdNZUZhTWhOZ1dmUWVVYllmSmdEY01nMmdNZlFjNGFDaERoeGVzaHpkT2JRYTBiMmRQZ0NmZ2hSY0djRmhaZ1liTGdraG9lRGRMZmxnZGJTYUtiUWNZZDFkVWJnZkVhcGVVaHdia2hXYkJibGFZZG5mTmZCZ2RnVGNLYXpoUWdRYk1oUmFZYU1jVmh5ZzhiZ2RVZEZia2VnZlZiU2NBYW5mSmJ6ZEVmVGdMZ2hmd2FHZFdlMWd3ZVRjRWF6YklkcWFQZkNoSWVMZEtld2cxZE9mRmFGaEVnaWhEYlRnQWEzYUZhQWdOY1RmT2JUZEJmVGFEZ1Zha2dGZEdkQ2JRYnpmTmRqZEViT2NBZ2dmOGViaE1lemhrZE5oTmVqZXdhb2ZFZ1JlaGVXaFdnQ2M1Y0tmQWd5ZTVhWGZVY2loa2dHZE5hVmZJZUJmS2VWYU1lSmNGYWdnWmNXaEplemJRZVhoVWh5Z3NoMGdFZ0RmRWZXY0RlRmJjY3ZhSWFGZ0JjWmZJZkZkVWNnZEpoeWdjY3hjRWR5YjRlY2dCZmxmdGJjZ0VieGdNZHlnS2NqZ3dnaWVDY3lic2JOYlRjaGFSaFJkSWdnYzBhd2VOYnhhUWdEY1VoemZrZXdhVWd3YzFkWmFCYlJiZ2ZrZE1lemJZZ3hoRGRnaEliUGNHYnpkTWQ1Z0RnVGVZZDhoS2VCaEVnWWVWZGxiZ2Z1aFNiZ2FNY3VhVmUxZkllcGRCYWpnVmVTZUFlU2dsaFRjQ2JSYlloR2NWZGljY2gwZUZlMWhNaHJhTmVCZ0FheGVGZmdoeGZYZExmeWRCYVFjV2hTZkJlVmdJYkNhY2huZ01iUmRNYXVoSGRBYVpjYmFYYUJoTWZUY01naWFvYThoSWNnZHNkcmZEZFVmNGRVY1VlU2NJaE5hTWZEYWNmVWhBZTFoTWM1ZU1nRmFNZE5iV2VRaFVlWWRKZURjTWEyZk1kUWE0ZENmRGV4aHNhemNPZlFlMGIyYlBnQ2VnZ1JjR2NGZFpkWWVMZ2tib2JEYUxmbGFkZ1NjS2RRYlloMWNVaGdhRWhwZ1Vhd2VrYVdmQmhsYVlnbmNOZEJoZGVUZEtnemhRZVFmTWNSaFlnTWRWZnlmOGRnZlViRmZraGdoVmdTY0FmbmdKYXpjRWNUY0xoaGJ3Y0doV2IxZXdkVGFFZ3poSWZxYVBkQ2NJZ0xoS2h3ZTFjT2hGYUZnRWdpZURlVGNBYjNjRmVBY05kVGFPY1RhQmJUZERkVmdrYUZnR2FDYVFiemFOYmpnRWZPZUFlZ2U4YWJlTWJ6ZGtmTmROaGpld2ZvYUVmUmZoZ1dlV2hDZjVlS2NBZXliNWRYY1VhaWZrY0djTmZWYkloQmJLZFZiTWJKYkZlZ2haZldlSmJ6ZFFmWGdVYXlic2EwaEVoRGhFaFdlRGFGY2NhdmZJYkZkQmVaYUljRmFVaGdjSmF5aGNieGRFZnloNGZjYkJnbGd0Z2NiRWJ4Z01meWdLZWpld2VpZENjeWhzYk5oVGNoaFJhUmZJZ2djMGd3aE5leGZRY0RhVWh6Y2tld2RVZ3doMWhaY0JhUmhnZWthTWJ6Z1lieGNEZGdmSWNQZkdkemdNZjVjRGNUYlllOGZLZ0JjRWFZY1ZobGdnaHVmU2JnYU1idWVWZDFhSWJwaEJoamRWaFNiQWVTZ2xmVGJDZFJjWWVHY1ZnaWZjZjBnRmExaE1hcmFOYUJjQWJ4YkZnZ2V4ZFhjTGJ5aEJiUWRXZVNmQmJWZ0loQ2RjaG5oTWdSZU1idWVIaEFhWmhiYlhoQmhNaFRmTWdpYm9iOGdJZmdic2NyZURmVWg0ZFVoVWRTZUlnTmVNZERoY2NVZUFnMWVNZzVoTWRGZU1jTmFXaFFlVWRZZEpmRGdNZDJnTWRRYTRkQ2NEY3hic2Z6Zk9hUWYwZTJkUGJDZGdjUmZHZEZkWmRZZUxka2dvYURlTGhsZGRjU2FLZFFlWWQxaFVjZ2JFZXBjVWJ3Z2tnV2FCZWxkWWVuYU5kQmdkYlRoS2F6ZFFoUWdNYVJlWWVNaFZieWE4YmdnVWZGYmthZ2NWY1NnQWZuZEplemJFZFRjTGRoaHdmR2VXZDFhd2RUY0VoemZJaHFkUGhDY0liTGZLZXdmMWdPYkZmRmdFY2lmRGhUaEFjM2RGaEFhTmdUYk9lVGVCYVRiRGhWZ2tnRmFHZkNiUWJ6Zk5kamdFYk9mQWFnZzhlYmJNZnpma2ROYk5oamR3aG9nRWNSaGhiV2VXY0NjNWRLZEFkeWU1YVhoVWVpYmtjR2ZOZFZjSWNCZktkVmFNZUpnRmFnZVphV2RKZ3plUWhYaFVmeWZzZDBjRWhEYkVkV2ZEZUZhY2Z2Z0lmRmZCY1pkSWhGZlVnZ2FKY3lkY2R4aEVneWg0YmNmQmRsZnRnY2FFZnhhTWZ5ZUtlamR3ZWllQ2V5ZHNjTmFUZGhnUmdSZ0loZ2IwYndoTmV4ZFFoRGdVZHpka2J3YVVjd2UxZFpjQmZSYmdma2ZNYnpiWWV4Y0RiZ2JJZVBlR2J6aE1mNWJEY1RiWWQ4aEthQmhFY1ljVmRsZmdhdWZTY2djTWh1Z1ZlMWdJY3BlQmdqZFZlU2JBZVNjbGVUY0NlUmRZZEdmVmVpaGNlMGhGZDFiTWFyZ05hQmNBZnhhRmRnZXhjWGhMYnlhQmFRYVdmU2FCYlZlSWVDZ2NlbmhNZFJlTWF1ZEhiQWFaYWJnWGJCaE1iVGJNY2ljb2M4aElhZ2JzYXJhRGFVZzRkVWNVaFNjSWNOY01iRGFjaFVhQWQxZU1hNWdNYkZoTWNOYldoUWZVZllhSmdEY01hMmVNZVFoNGFDZURjeGJzYXplT2dRZzBoMmJQZkNjZ2dSZUdnRmFaaFloTGdraG9mRGVMY2xnZGdTZ0thUWdZZTFiVWJnaEVhcGdVZXdoa2NXYkJobGZZZW5jTmhCYWRnVGZLZ3poUWRRY01kUmNZZ01kVmh5aDhlZ2dVYkZoa2JnY1ZoU2ZBZG5nSmR6Z0ViVGRMZGhmd2VHYVdlMWZ3Z1RhRWN6ZkljcWRQY0NmSWJMaEtid2MxZ09hRmFGYkVmaWdEY1RiQWYzY0ZlQWhOaFRkT2FUZkJiVGNEY1Zla2RGZEdmQ2ZRZXpiTmJqZkVlT2JBZ2dmOGdiYU1nemJrYk5nTmZqZHdnb2JFZVJkaGVXY1dlQ2M1ZkthQWF5ZzVjWGdVZ2lha2VHYU5kVmVJaEJhS2hWZk1oSmZGYmdlWmZXZEplemhRYVhiVWJ5Y3NiMGdFYURlRWRXYkRnRmhjZHZhSWVGY0JlWmNJYUZjVWFnZ0pieWFjZXhnRWZ5ZjRmY2NCaGxndGdjZUVmeGdNYnljS2FqZ3dlaWJDZHljc2FOY1RlaGhSZVJhSWFnZTBmd2dOZ3hiUWhEZ1VjemJraHdlVWV3ZTFkWmVCYlJkZ2drZU1hemJZZXhlRGZnZElhUGJHYXplTWQ1ZkRmVGRZYjhkS2VCZkVjWWRWaGxlZ2R1ZVNjZ2NNYnVlVmQxZ0llcGRCZWpoVmRTZ0FoU2FsY1RiQ2FSaFlkR2FWY2lhY2YwZ0ZlMWZNY3JmTmVCZUFleGZGZGdleGJYZkxkeWRCZFFkV2RTaEJjVmFJY0NhY2VuZ01oUmVNaHVnSGRBZ1pjYmNYZEJhTWFUYU1oaWhvYThlSWVnZHNicmFEZVVkNGhVaFVnU2RJZ05lTWhEYmNlVWhBYzFjTWc1ZE1iRmNNaE5mV2hRaFVjWWFKZkRhTWIyZE1nUWE0YkNoRGN4ZXNkemhPY1FoMGQyZVBjQ2ZnZ1JkR2JGYVphWWRMaGtnb2NEZUxkbGFkYlNmS2ZRaFlkMWJVZWdkRWJwaFVmd2NrZ1doQmRsY1ljbmhOZkJjZGJUZUtlemZRZlFoTWZSZVlhTWNWY3ljOGZnZlVjRmdrYWdmVmJTZ0FkbmRKYXpnRWRUYUxmaGV3ZkdlV2MxY3doVGdFZXpjSWRxZlBjQ2VJZkxhS2N3ZzFoT2NGZEZkRWJpYkRmVGdBYzNnRmNBZE5hVGdPZVRhQmVUZkRnVmJrYkZnR2JDZVFhemVOZWpiRWhPYkFnZ2Q4Y2JnTWh6YmtjTmFOZGpmd2JvYkVjUmdoYVdhV2hDZDVkS2JBZ3lmNWRYZVVjaWFrZEdnTmVWZkloQmhLaFZiTWNKZUZkZ2FaZ1dkSmN6ZlFmWGVVZnlkc2IwZUVjRGJFYldoRGFGYmNldmJJY0ZnQmFaZEloRmNVZmdhSmd5YWNneGNFaHliNGVjZUJibGF0ZGNkRWh4Yk1ieWJLZmphd2hpZ0NheWVzaE5kVGFoZFJoUmZJZ2dmMGh3Zk5oeGhRYkRhVWV6YWtld2hVYXdmMWFaZ0JnUmNnYmtkTWh6YVlneGdEZGdlSWNQYUdjemNNaDVhRGNUZlllOGZLZ0JlRWdZZlZmbGdnZ3VkU2FnaE1jdWRWZTFnSWJwZEJlamNWYVNoQWNTYWxiVGdDZFJlWWhHZVZmaWZjZzBjRmUxZ01ocmNOY0JiQWZ4YUZiZ2h4ZFhmTGJ5Z0JiUWNXYlNnQmhWYkliQ2FjZG5lTWFSZE1jdWhIY0FkWmJiZ1hoQmdNZFRoTWZpZ29oOGFJZmdkc2JyZURoVWU0Z1VhVWFTZklkTmZNZERlY2NVYUFjMWFNZzVkTWRGaE1oTmNXZ1FoVWNZaEpnRGdNZjJiTWRRYjRnQ2hEZ3hjc2Z6Y09hUWYwZDJhUGJDZ2dnUmRHZ0ZnWmJZZkxna2VvYkRkTGZsZ2RlU2hLYlFjWWUxZ1VnZ2ZFZHBmVWh3ZmthV2hCZWxlWWhuZU5hQmVkZFRkS2Z6Z1FmUWhNZ1JoWWVNYlZjeWI4aGdlVWVGYWthZ2JWYVNnQWNuZEpjemFFZVRiTGFoYXdjR2VXYzFjd2dUY0ViemNJY3FhUGNDY0liTGZLaHdlMWNPYUZoRmhFYmllRGFUYUFkM2hGZEFmTmFUYk9kVGJCYVRlRGFWY2tiRmhHZENiUWR6Z05hamJFY09lQWNnZDhnYmJNZnpka2JOYk5jamV3ZG9hRWJSYmhiV2JXZUNmNWNLY0FjeWc1ZFhlVWFpY2tnR2dOZVZkSWVCZktiVmJNY0phRmRnY1plV2NKZnpnUWVYY1VheWNzZTBnRWZEYkVnV2dEZkZkY2Z2ZEliRmNCZlphSWNGYlViZ2dKaHliY2Z4Y0VheWg0Z2NhQmhsYnRoY2NFZnhiTWN5ZUtnamF3ZWlmQ2F5YXNlTmRUY2hlUmZSZkloZ2QwZndhTmZ4ZFFnRGRVY3poa2F3YVVnd2IxaFpkQmJSaGdka2RNYXpnWWV4aERmZ2hJY1BoR2N6Z01kNWdEYVRlWWY4YktlQmNFYVliVmdsY2dkdWdTYWdiTWR1Z1ZlMWNJZXBhQmZqY1ZhU2ZBZVNnbGFUZENmUmdZZkdnVmJpZGNiMGFGYzFlTWZyZk5nQmVBZHhoRmhnYXhlWGhMaHliQmRRZVdmU2NCZFZkSWNDYmNkbmRNYVJjTWV1Y0hoQWZaYWJhWGNCYk1nVGNNYmlnb2U4Z0ljZ2NzZXJkRGFVYTRmVWRVZlNnSWZOY01nRGZjZ1VoQWgxZ01nNWhNZkZhTWdOY1dnUWhVaFliSmdEY01kMmdNY1FhNGJDZURkeGJzZnpmT2RRYzBiMmdQaENhZ2JSZUdoRmNaZFliTGZrZG9nRGFMZmxoZGVTYUtmUWVZYzFlVWRnZkVmcGdVZ3dja2FXaEJjbGFZYW5lTmNCaGRjVGFLZHplUWFRYU1iUmJZYk1iVmJ5ZThhZ2ZVYkZma2hnZFZjU2hBZm5mSmd6ZUVmVGZMZmhmd2hHZ1djMWV3ZFRnRWV6ZklhcWRQZUNlSWVMaEtid2ExYU9nRmZGaEVhaWJEaFRjQWUzYkZnQWdOYVRiT2VUYUJmVGVEZFZia2JGY0dlQ2NRZnpiTmhqY0VnT2JBZWdlOGJiZ01jemNrZk5hTmhqZHdmb2RFYVJiaGNXYVdiQ2Q1ZUtnQWF5aDVlWGZVY2lka2RHZk5hVmRJYkJoS2RWZE1lSmJGZGdhWmZXYUpoemZRaFhnVWJ5ZXNiMGJFaERoRWJXYkRoRmhjZ3ZlSWFGZUJmWmNJYkZkVWhnZkpheWhjYXhmRWJ5YTRmY2JCaGxodGZjZUVoeGRNYnlhS2hqYndmaWJDYnlmc2ZOZ1RkaGdSZVJmSWZnYjBmd2NOZ3hjUWREZVViemNrZXdiVWZ3ZjFiWmVCZVJoZ2hrYk1memFZY3hlRGVnYkljUGhHYnpjTWE1YkRiVGhZYzhkS2hCYkViWWRWYmxnZ2d1YlNoZ2VNYXVoVmMxY0lmcGdCZWpoVmZTZEFnU2NsZVRkQ2VSZ1llR2RWZWliY2QwYkZmMWVNZ3JnTmhCZkFieGdGZmdkeGRYZ0xleWVCZVFlV2JTYUJiVmZJYUNnY2VuZU1oUmJNaHVkSGhBYlpnYmVYZEJkTWVUYU1laWZvZDhhSWNnZXNmcmdEYlViNGdVZFVjU2hJYU5lTWREaGNnVWJBZjFjTWI1aE1kRmRNZU5oV2RRaFViWWRKY0RmTWIyZ01iUWI0aENmRGV4YnNlemhPZ1FmMGMyaFBlQ2VnZVJiR2JGYVpoWWhMZWthb2VEY0xibGJkZVNlS2NRYllnMWRVYWdjRWVwZVVkd2ZrYVdlQmNsZ1libmNOZUJoZGNUZktlemdRZlFjTWFSY1lmTWNWZXllOGVnYVVmRmNrZ2dnVmFTaEFjbmNKY3poRWRUaExoaGR3Z0dhV2cxYndoVGdFaHpnSWJxaFBjQ2dJaExjS2R3YTFiT2JGYUZlRWhpYkRkVGhBZzNkRmhBZk5nVGRPaFRkQmNUZURiVmhrYkZmR2VDYVFkemJOaGphRWJPZ0FmZ2c4aGJmTWR6YWtnTmhOZWpkd2RvZ0VnUmJoYldnV2NDYjVkS2JBZXllNWdYYVVkaWRrYUdmTmhWZ0liQmdLYlZlTWdKZUZnZ2VaZldnSmh6ZlFjWGRVZ3lkc2YwZUVoRGVFaFdlRGhGY2NmdmRJZkZiQmFaY0liRmhVaGdmSmN5ZGNieGJFZXlmNGRjYkJhbGR0YWNjRWN4Zk1heWVLZWpld2RpYUNheWVzYk5jVGFoZlJnUmdJZGdkMGR3ZU5jeGhRYURjVWh6Ymtld2FVZHdjMWJaaEJkUmdnZmtjTWh6Z1lieGhEZWdhSWNQaEdhemZNZzViRGVUZVlhOGdLZEJjRWJZYVZnbGZnZnVkU2RnZU1odWVWZzFnSWVwZEJjamZWZlNnQWFTZGxlVGRDYlJkWWJHYVZoaWhjYTBnRmExYk1kcmROZUJiQWF4Y0ZmZ2R4YlhoTGR5Z0JhUWhXZlNhQmNWYUlnQ2JjaG5oTWhSZU1kdWdIZkFhWmFiYlhkQmRNY1RnTWRpZ29iOGZJZmdhc2dyZ0RnVWU0ZVVjVWdTaElmTmZNZ0RiY2VVZEFkMWhNZjVlTWJGZU1mTmNXYVFmVWJZYUphRGFNZDJhTWdRYzRnQ2dEZnhhc2d6aE9nUWQwZzJlUGJDZ2djUmNHZ0ZlWmFZYUxka2VvZERhTGNsY2RlU2hLYVFmWWQxZVVoZ2NFZXBkVWZ3YWtmV2NCZWxnWWFuY05iQmFkYVRmS2h6YlFmUWdNY1JoWWZNZFZheWc4ZmdhVWFGYmtoZ2FWYVNlQWRuY0poemhFaFRhTGdoY3djR2hXYzFnd2dUZkVjemJJZHFnUGVDZElkTGJLZXdmMWNPZ0ZlRmZFY2lhRGZUZUFmM2ZGY0FoTmFUZE9jVGdCaFRjRGRWZmtmRmhHaENmUWF6YU5iamNFYk9kQWdnZDhhYmNNYXpma2JOZk5lamR3aG9nRWNSZmhoV2RXaENnNWdLZ0FheWI1YVhhVWFpZmtkR2JOYlZlSWVCZEtnVmVNaEphRmdnZlpjV2JKZHpiUWZYZVVjeWRzZTBmRWdEYUVmV2NEYUZhY2d2ZElhRmFCYVpjSWNGZ1VoZ2FKZHloY2F4YUVoeWc0YmNlQmNsaHRkY2ZFZnhhTWF5ZkthamR3YmlmQ2J5aHNjTmVUZmhnUmZSZUlkZ2MwZHdhTmF4Y1FjRGhVY3pka2F3Y1Vid2UxZlphQmFSZGdja2dNY3pmWWV4Y0RjZ2dJY1BmR2R6Z01nNWNEZ1RjWWY4ZEtoQmFFYVliVmFsZ2dldWNTZGdoTWF1ZVZjMWZJYXBoQmVqaFZnU2NBYVNkbGFUZ0NiUmFZZkdkVmhpZGNlMGhGZzFhTWhyZU5hQmhBaHhoRmVnZnhkWGdMY3lmQmRRZ1dkU2RCYVZkSWRDY2NkbmNNY1JkTWh1YkhnQWFaYmJiWGJCZU1jVGhNYmlib2g4ZklhZ2ZzZHJiRGJVYTRlVWFVZVNhSWFOYk1jRGVjaFVoQWUxYk1lNWRNZEZjTWVOYVdiUWNVYVlmSmZEY01mMmhNZ1FhNGNDZ0RheGNzZnphT2hRZjBiMmJQZkNlZ2dSY0dkRmFaY1liTGFrZ29kRGFMZ2xiZGhTYkthUWdZZzFjVWNnYkVjcGNVZndma2hXYUJjbGJZaG5nTmFCYWRmVGFLZXphUWFRYk1lUmNZZk1oVmh5ZThkZ2dVZkZla2FnZVZoU2VBYm5oSmN6YkVnVGdMZmhhd2VHZFdoMWJ3ZlRoRWV6ZUljcWVQYUNiSWVMZ0tnd2UxZE9oRmhGY0ViaWJEaFRhQWUzZEZlQWhOYVRkT2JUYUJoVGhEYVZia2VGZkdkQ2JRZ3pjTmNqYUViT2ZBZGdhOGViYk1lemRrZE5lTmZqZXdhb2dFYlJmaGNXYVdhQ2U1YUtlQWN5YTVnWGJVZ2lka2hHZE5iVmJJZEJoS2RWZE1nSmFGZ2dkWmFXZUpnemNRZlhhVWR5YnNiMGNFYURiRWdXY0RoRmFjZnZkSWFGZ0JlWmdJZ0ZhVWFnZkpieWJjZXhhRWR5ZTRmY2RCZmxidGFjZUVmeGRNYnlkS2JqZ3diaWZDZnlkc2ZOZVRiaGFSaFJoSWhnZjBid2VOZ3hhUWZEZVVhemRrZndkVWR3ZzFmWmNCaFJlZ2hrZE1iemhZZnhhRGVnZElnUGNHYnpnTWg1ZURmVGhZZDhlS2hCYUVkWWNWYWxjZ2Z1Y1NjZ2VNYnViVmIxZElocGVCYWpoVmdTYUFhU2hsaFRhQ2FSYVloR2NWZGloY2MwY0ZhMWFNYnJnTmRCaEFoeGFGY2dleGdYYkxheWFCZlFkV2VTY0JmVmRJY0NkY2NuY01nUmJNZXVmSGNBYVpnYmNYY0JoTWVUZU1oaWFvZDhjSWZnZHNjcmNEZFVnNGNVZFVnU2VJaE5jTWREY2NoVWRBYTFnTWQ1ZE1lRmJNaE5iV2VRY1VhWWNKYURlTWUyZU1hUWc0Z0NkRGh4Z3NnemdPYVFiMGYyZVBoQ2hnaFJhR2VGZFpkWWRMaGtnb2hEZExibGFkZ1NoS2hRaFlnMWNVY2dlRWdwZlVnd2RrZldjQmFsZ1lhbmdOZ0JoZGJUY0tjemdRY1FnTWZSY1llTWFWZ3llOGhnaFVnRmRrZmdkVmhTY0FkbmJKZXpoRWFUZ0xlaGR3aEdjV2ExY3dkVGhFY3pjSWVxZFBlQ2RJY0xmS2h3ZjFhT2ZGZ0ZhRWRpZ0RmVGVBZDNlRmdBZk5jVGJPYVRmQmhUY0RoVmNrZ0ZnR2dDZFFiemdOZWpnRWFPaEFnZ2E4YWJhTWR6aGtiTmZOZ2pld2dvYkVoUmdoYldlV2ZDZzVjS2ZBYnlnNWVYYlVnaWhrZkdjTmZWaElnQmhLYlZmTWhKY0ZmZ2haaFdnSmd6ZlFjWGdVaHlnc2MwZUVnRGhFY1diRGhGYmNodmFJaEZhQmdaZklkRmhVZGdhSmF5YmNjeGJFYXliNGJjZ0JlbGh0ZWNoRWF4Y01leWFLaGpid2VpZkNmeWdzYU5mVGhoZlJmUmRJaGdoMGV3aE5oeGdRYkRmVWJ6ZWtid2NVaHdhMWVaYkJlUmRnZmtlTWh6ZFloeGNEZmdjSWdQZ0dnemhNYzVlRGFUYlllOGdLY0JoRWRZZVZibGFnY3VmU2RnaE1ldWZWYjFkSWVwZ0JnamhWYVNkQWJTYmxmVGFDZVJjWWdHZVZmaWJjYzBhRmUxZ01kcmFOZEJiQWN4ZUZnZ2Z4ZVhlTGR5Z0JhUWhXZFNlQmVWY0liQ2ZjZ25lTWFSZU1ndWFIZ0FhWmZiY1hkQmJNZlRmTWRpYW9oOGFJYmdmc2FyYURhVWM0Y1VjVWdTYkllTmhNZkRoY2NVaEFkMWNNZjVhTWJGYk1lTmZXZlFoVWJZYUpkRGJNaDJiTWNRZzRmQ2REY3hmc2F6ZU9oUWcwZzJlUGNDZWdjUmZHaEZlWmdZaExia2hvYkRkTGZsYmRmU2VLY1FlWWQxZVViZ2JFZnBiVWF3YmtlV2JCZmxhWWRuY05oQmFkZVRmS2d6YlFlUWVNYlJlWWhNZlZheWE4ZGdjVWdGYmtnZ2dWZVNmQWFuYkpoemVFZ1RiTGhoaHdhR2JXYzFjd2dUaEVhemNJYXFoUGRDZEllTGVLY3dhMWhPZ0ZjRmFFZWliRGhUZkFkM2JGZ0FlTmJUZk9kVGhCZ1RoRGJWZWtjRmZHZkNkUWR6ZU5hamFFZ09lQWRnZzhjYmhNZXpia2FOZU5namF3ZG9kRWhSZmhjV2RXZENnNWRLZEFoeWQ1aFhmVWFpYWtmR2ZOZlZnSWRCaEthVmRNZEpkRmZnYVpoV2hKY3phUWJYYVVoeWNzZjBoRWhEYUVmV2NEZEZmY2Z2Z0lmRmhCaFpnSWhGZVVkZ2JKYXliY2h4Y0VleWQ0Y2NlQmRsZHRlY2hFYXhoTWh5ZEtjamN3Z2lhQ2d5ZHNjTmZUaGhjUmZSaEljZ2gwZHdnTmJ4ZFFoRGJVZHpja2R3Y1Vid2YxZlpiQmhSYmdja2hNYXpiWWd4YkRmZ2hJY1BoR2F6Zk1jNWJEZ1RnWWY4ZktmQmRFYllkVmFsZGdjdWhTYWdnTWh1Z1ZjMWhJZHBlQmNqYlZkU2NBaFNkbGhUZENmUmZZaEdmVmNpZWNoMGhGYTFjTWVyYk5lQmhBZ3hjRmRnaHhkWGFMY3ljQmVRZ1dkU2JCZVZhSWdDZmNhbmNNY1JjTWJ1YkhkQWRaZmJhWGJCZE1mVGZNY2lmb2g4YUljZ2JzZnJmRGZVZzRhVWFVYlNiSWhOZU1iRGJjZFVnQWYxaE1nNWFNZEZiTWdOY1doUWVVYllhSmNEYU1iMmFNZ1FkNGRDZURneGVzZnpkT2RRYTBoMmdQZ0NjZ2FSaEdlRmJaYVliTGdrYW9iRGJMZmxlZGRTY0thUWZZZzFhVWNnaEVlcGZVYndia2JXYkJlbGdZZm5kTmdCYmRiVGRLZnpoUWVRZk1mUmVZZk1lVmN5ZThiZ2hVYUZka2FnY1ZoU2ZBaG5oSmR6ZEVjVGVMYWhld2JHaFdoMWV3ZlRhRWJ6YkllcWFQZkNlSWNMZ0tmd2MxYk9iRmVGZUVjaWREaFRkQWUzaEZkQWFOY1RlT2dUY0JlVGVEZFZma2ZGZUdhQ2FRY3pmTmdqaEVkT2hBYWdjOGhiYk1iemJraE5mTmZqZndlb2RFYVJmaGdXYVdmQ2Q1Y0thQWF5YjVjWGFVY2lma2NHaE5kVmVJZEJlS2NWZU1nSmFGYWdoWmZXZ0plemNRZVhnVWR5Y3NkMGVFZERoRWJXZkRhRmJjaHZhSWZGY0JmWmNJYUZhVWJnYUpneWFjYXhnRWF5YzRjY2NCaGxndGRjZ0VleGRNZ3lnS2RqZ3diaWNDYnlmc2hOZVRoaGVSZVJnSWhnaDBhd2ZOZHhjUWZEZFVnemNrZ3diVWJ3YTFiWmFCZlJnZ2VrZU1iemJZYXhjRGdnaElnUGJHYnpkTWI1aERjVGdZZzhmS2VCZEViWWFWZ2xmZ2d1ZFNoZ2hNZnVnVmUxZUlocGZCYWphVmRTZ0FlU2ZsYlRkQ2ZSZFljR2VWZmlkY2QwY0ZiMWJNaHJiTmZCYUFneGVGZmdneGhYaExieWVCYlFoV2ZTaEJlVmZJYkNmY2FuZU1lUmNNZXVjSGdBYVpjYmdYZEJkTWJUZk1maWRvZjhjSWJnYnNicmJEZFVhNGdVaFVkU2RJY05jTWFEY2NiVWNBYjFiTWg1aE1iRmJNY05hV2VRYlVkWWNKYURmTWYyZk1oUWM0Y0NnRGN4ZHNjemVPZlFjMGgyYlBjQ2JnZ1JnR2VGaFpkWWZMZWtlb2hEZUxibGNkZlNiS2hRYllmMWNVYWdoRWJwaFVkd2RrYldiQmhsZllobmNOY0JnZGNUZUtoemFRY1FoTWRSZllmTWRWZ3ljOGVnYVVmRmhraGdmVmZTZEFlbmNKYXpjRWhUY0xjaGZ3Y0dlV2QxYndlVGJFZHpnSWZxZVBkQ2ZJZExkS2F3ZDFjT2RGZkZoRWdpYkRnVGVBYjNhRmRBYk5iVGJPZVRlQmNUY0RiVmFrZkZnR2FDZVFiemhOaGpoRWdPY0FiZ2U4Z2JnTWN6ZWtnTmZOYmpnd2hvZEVlUmhoZVdnV2hDZzViS2RBaHlmNWdYZFViaWdrYkdlTmRWYkljQmFLYlZkTWJKYUZoZ2ZaaFdoSmN6ZFFlWGZVZnlnc2cwYkViRGJFaFdlRGdGZ2NhdmZJY0ZnQmdaZklnRmNVaGdjSmN5Y2NheGJFaHlnNGVjZEJibGR0Y2NjRWR4aE1ieWVLZ2pjd2RpZUNkeWdzZU5nVGFoYVJlUmNJYmdoMGd3ZU5heGhRY0RkVWF6Z2tkd2hVYXdnMWZaZ0JlUmdnZ2tnTWJ6Z1lmeGNEYmdlSWZQZkdiemNNZDVlRGZUZ1llOGRLZUJiRWVZZlZnbGZnZXVhU2hnZk1ldWJWYjFnSWVwaEJjamVWYVNjQWJTYmxkVGNDZFJlWWFHYlZlaWVjZDBkRmYxYU1lcmNOYUJmQWh4Y0ZmZ2R4aFhmTGJ5ZUJoUWRXZVNkQmhWZEljQ2JjZm5oTWdSZU1ndWhIYkFkWmRiZlhhQmZNYlRhTWRpaG9jOGVJaGdjc2FyYURnVWc0YVViVWNTYklkTmZNZ0RnY2hVaEFjMWZNYjVkTWdGaE1hTmVXZlFiVWhZYkpkRGJNZjJoTWhRYjRlQ2dEYXhoc2F6ZU9lUWQwYzJjUGJDaGdiUmhHZ0ZkWmVZZUxla2VvYkRlTGFsYmRkU2JLZlFnWWcxZFViZ2JFaHBiVWF3ZWtoV2NCY2xoWWZuZ05kQmVkZFRnS2Z6YlFlUWNNZlJhWWhNZ1ZoeWM4Y2dhVWRGZ2thZ2JWYlNhQWVuaEpnemVFaFRkTGdoZndjR2VXZjFod2RUaEVjemhJZXFlUGZDYUlnTGZLZ3dnMWdPY0ZnRmhFZmlkRGFUYUFiM2ZGaEFkTmNUZU9mVGVCYVRlRGhWYWtmRmVHZENmUWV6ZE5iamZFY09iQWhnZjhoYmVNZXpna2dOZk5namh3Y29jRWJSYmhkV2FXaENmNWVLYkFkeWY1YlhiVWZpYmtoR2JOY1ZoSWJCY0tnVmRNZkpjRmNnY1poV2hKZHplUWdYaFVoeWZzZzBhRWFEZEVlV2dEYUZhY2h2aEllRmJCZVpiSWNGY1VjZ2JKZHliY2N4YkVleWQ0Z2NlQmVsZ3RkY2NFYXhlTWd5ZUtnamd3ZGliQ2Z5Y3NjTmRUaGhkUmNSZElnZ2EwZHdmTmZ4aFFmRGJVZnpha2R3aFVhd2UxZFpmQmVSY2dha2dNY3piWWd4YkRlZ2dJZVBlR2J6Zk1iNWREZVRhWWg4ZUtiQmdFYVlhVmVsZWdkdWRTYWdhTWN1Z1ZhMWZJZXBkQmdqZ1ZnU2JBZVNibGFUaENiUmNZZ0dnVmFpZWNoMGJGYzFiTWVyaE5lQmdBaHhlRmJnZnhnWGZMYnliQmFRZldkU2RCZVZlSWhDZWNhbmNNY1JhTWR1YkhmQWZaZmJiWGdCZE1iVGdNZWljb2Y4YUlhZ2ZzZXJiRGJVYTRjVWVVYlNhSWhOZ01oRGJjZlVnQWgxYU1jNWVNYkZjTWhOY1dhUWdVYllhSmREZU1nMmhNYVFoNGFDY0RjeGZzY3plT2JRZzBlMmJQZ0NhZ2JSYkdlRmhaZlloTGhrZm9iRGNMZmxmZGNTY0tiUWdZZDFjVWdnZ0VicGJVZHdja2hXZEJjbGVZYm5nTmVCaGRoVGVLY3phUWdRYk1iUmFZY01jVmN5YzhkZ2FVZkZma2FnZFZoU2VBZ25kSmF6ZEVlVGRMZ2hid2NHZFdmMWV3YVRiRWZ6YklkcWZQZENiSWVMYktod2QxZk9kRmhGYkVhaWJEYlRmQWYzYUZhQWROZFRjT2JUYUJiVGVEYVZla2hGZEdkQ2JRY3poTmdqYUVkT2VBYWdiOGdiZE1hemFrZU5jTmhqZndjb2hFZlJoaGdXZVdkQ2M1Y0toQWF5aDVnWGFVZGlna2dHYk5hVmNJZkJlS2ZWaE1mSmhGZGdkWmdXZUpnemdRaFhmVWh5aHNiMGRFYURjRWVXYURoRmVjY3ZoSWFGaEJlWmZJZkZmVWNnZ0pieWJjZXhhRWR5YjRhY2ZCY2xndGZjaEVkeGdNZHljS2FqYXdoaWRDaHlmc2NOY1RnaGZSZlJkSWhnYTBod2JOYnhhUWREYlVhemJrZXdhVWJ3YzFjWmdCZlJhZ2RrZU1iemdZY3hoRGNnZklkUGVHZXpmTWQ1ZkRhVGNZYThmS2JCZUVhWWJWZWxmZ2V1YlNjZ2ZNYXVnVmgxZklmcGZCZWpkVmFTYUFjU2dsZ1RhQ2hSaFlkR2NWYWllY2cwaEZhMWJNZXJnTmRCYUFkeGNGZWdkeGdYY0xleWJCYVFmV2FTY0JlVmZJYUNlY2RuZk1jUmNNYXVkSGdBZlplYmZYYUJoTWJUYU1jaWVvZThkSWVnYnNlcmFEZFViNGJVYVViU2RJZ05jTWFEZGNoVWJBZzFmTWI1Zk1iRmdNZE5oV2JRaFVlWWRKZERhTWMyZU1jUWY0YUNlRGJ4ZnNhemRPZlFkMGEyZlBlQ2dnaFJhR2hGZlpjWWNMZ2tmb2JEYkxjbGZkaFNiS2VRY1ljMWFVZmdnRWdwYVVid2hrZVdnQmJsYllobmFOYkJmZGdUZktlemNRaFFkTWFSZFllTWRWZnlnOGFnZVVjRmFrZGdnVmZTY0FlbmJKZ3plRWVUZ0xjaGZ3YUdkV2cxZHdmVGZFZXpkSWZxY1BhQ2RJYkxmS2N3ZjFoT2JGZEZmRWFpZ0RiVGhBZjNoRmVBYk5oVGZPYVRlQmZUZURnVmFrZkZjR2NDY1FoemJOYWpoRWhPZEFmZ2c4ZGJjTWJ6ZGtjTmZOaGphd2JvZ0VoUmhoZVdlV2hDaDVhS2JBaHlmNWdYaFVlaWZrZUdkTmFWYUlkQmVLZFZmTWNKZ0ZlZ2ZaYldhSmN6YVFiWGNVZHloc2YwZEVoRGVFYVdnRGVGY2NldmhJZkZhQmJaYUlmRmhVYWdjSmN5Z2NleGZFY3lkNGFjZUJlbGZ0YmNnRWh4Zk1jeWJLYWpjd2RpZUNjeWZzYU5kVGdoYVJkUmhJYWdoMGh3aE5keGdRZkRmVWN6ZGtjd2VVYndkMWVaZ0JlUmhnY2thTWJ6Z1lieGREZ2dhSWJQZkdkemRNZzVnRGJUYllkOGJLZUJmRWRZZVZmbGZnZnVmU2ZnY01mdWFWZDFlSWNwZ0JlamhWaFNjQWJTZWxmVGZDZFJmWWZHZFZiaWRjZjBoRmQxZU1kcmFOZUJkQWR4ZkZjZ2Z4Y1hmTGF5ZUJlUWVXZlNhQmdWZElnQ2ZjYm5oTWdSaE1idWZIYkFjWmJiZlhmQmVNYVRjTWJpZ29iOGhJZmdoc2hyZ0RkVWM0aFVoVWRTYUlkTmZNZURhY2NVY0FhMWNNYjVoTWVGY01nTmRXZVFoVWFZaEpkRGVNaDJlTWNRZzRhQ2ZEZ3hjc2Z6ZU9jUWgwYTJhUGhDY2doUmRHYUZjWmRZY0xla2hvY0RlTGhsZ2RlU2NLY1FkWWQxZ1ViZ2RFZHBhVWJ3Z2tnV2ZCYWxhWWhuZU5mQmhkY1RjS2R6YVFmUWZNZlJoWWZNaFZleWg4Y2dmVWVGZmtjZ2hWZFNkQWVuZEpoemNFZVRnTGNoY3diR2RXZDFid2NUZ0VjemhJZXFmUGVDZ0ljTGZLYXdiMWFPZ0ZnRmFFYmlmRGhUaEFoM2RGY0FiTmFUZ09iVGVCY1RkRGZWY2thRmFHZUNhUWh6Z05iamRFZk9oQWhnYzhmYmNNaHpla2ROYU5oamJ3Z29jRWRSZ2hmV2hXYkNkNWVLYkFneWE1YVhkVWVpY2tnR2FOYVZnSWhCY0tkVmJNZEpjRmVnYVpjV2FKaHpoUWJYY1VheWRzZzBlRWNEYkVmV2JEZEZkY2h2ZklhRmZCYlplSWZGYlVoZ2FKZXliY2J4aEVoeWE0ZGNkQmFsZ3RjY2dFaHhiTWd5aEthamJ3ZGlhQ2V5aHNiTmdUZWhjUmFSYklhZ2cwaHdiTmd4Z1FiRGdVY3pja2V3ZlVmd2UxZVphQmJSYWdoa2JNYXphWWh4Y0RhZ2JJZlBhR2F6Yk1hNWJEY1RnWWY4ZEthQmZFYllhVmFsZGdkdWVTY2dhTWR1Z1ZiMWRJZHBhQmZqaFZhU2hBZFNjbGNUZUNlUmNZZUdnVmNpZmNoMGVGYzFoTWZyYU5nQmVBZ3hlRmhnZ3hnWGFMYnllQmhRZVdkU2RCYlZhSWNDaGNjbmRNZ1JnTWd1Y0hmQWdaYmJhWGFCZ01oVGFNZmlmb2U4Z0lhZ2JzZnJnRGJVZDRlVWVVZFNlSWFOZE1hRGVjZ1VmQWcxYU1nNWNNZUZkTWdOZ1dhUWhVZllhSmZEZE1oMmFNZ1FiNGdDYkRkeGJzYnpiT2hRYTBhMmhQYkNoZ2hSaEdhRmZaYVloTGNrYm9lRGRMZWxmZGhTY0tkUWFZaDFoVWFnYUVkcGdVZXdia2hXYkJjbGJZZG5hTmNCYmRlVGNLYXphUWhRZE1iUmZZYU1jVmh5YjhkZ2VVYUZoa2JnZFZjU2RBY25kSmF6ZkVoVGNMZWhhd2hHZldkMWV3ZVRnRWd6ZklocWZQaENlSWdMaEtod2UxaE9lRmdGaEViaWREZlRhQWEzYkZnQWdOZlRkT2FUZ0JhVGFEYlZna2hGYkdjQ2FRZnphTmNqY0VnT2hBYmdkOGhiZE1memZrY05kTmZqZXdkb2NFZlJjaGhXaFdiQ2I1aEtjQWV5aDVjWGJVYmlha2FHZ05nVmRJaEJhS2FWZU1lSmNGaGdoWmFXZkpkemZRaFhjVWR5YXNiMGVFYkRjRWRXaERoRmNjZnZoSWJGYUJkWmRJaEZlVWRnY0pneWNjZHhlRWh5YTRoY2ZCYWxidGJjZ0VheGVNZnliS2FqZXdjaWdDZXllc2hOaFRlaGFSaFJnSWRnaDBhd2VOYnhjUWhEYVVkemhrZXdoVWV3YzFnWmhCY1JkZ2JrYU1iemJZYnhoRGVnZElnUGVHaHplTWU1YURnVGJZZThjS2hCZ0VkWWVWY2xoZ2V1ZlNoZ2FNZXVlVmExZElmcGFCYmpjVmdTZ0FjU2NsZ1RoQ2VSZFlhR2NWZmlhY2cwY0ZlMWdNYnJkTmFCZkFoeGVGZWdheGNYYkxjeWVCZVFhV2FTaEJiVmhJZ0NoY2JuZk1hUmRNZXVkSGdBZlplYmZYZEJnTWJUZE1maWJvYjhiSWdnaHNjcmJEZFVhNGFVZlVnU2ZJZE5nTWFEZmNnVWFBYzFoTWI1ZU1mRmFNZ05kV2dRZ1VjWWdKZ0RiTWUyZ01mUWg0YkNiRGd4ZHNmemFPaFFjMGcyZlBoQ2JnZ1JmR2ZGZ1phWWdMZWtjb2NEZExibGdkYVNoS2hRZ1lkMWJVZ2doRWdwZ1Vmd2draFdiQmJsY1ljbmNOZEJoZGZUaEtoemRRYVFjTWJSZFliTWhWYXliOGFnZFVhRmRrYWdoVmVTY0FkbmNKaHpiRWZUaExiaGd3Y0dkV2QxaHdhVGRFY3pmSWFxY1BlQ2JJZExjS2d3YzFoT2NGYkZiRWJpY0RhVGhBZjNnRmRBYk5iVGVPYVRiQmJUZkRiVmJrY0ZiR2VDZVFnemROYWpkRWJPZkFhZ2Y4Z2JnTWF6aGtjTmROZmpod2ZvY0VhUmVoZVdjV2NDYTVmS2RBZXljNWdYaFVhaWhrY0doTmJWZEliQmZLZFZoTWJKYkZnZ2FaZFdoSmR6YlFoWGhVaHloc2QwZ0VmRGJFYldjRGhGYWNmdmNJZkZhQmhaaEljRmJVZGdoSmZ5YWNkeGRFZHlhNGhjY0JjbGJ0ZWNjRWN4ZU1leWhLZWpnd2dpZUNheWVzYk5oVGZoZFJmUmZJYWdjMGV3Zk5leGNRYURoVWd6Zmtod2hVY3dnMWVaZUJnUmFnaGtiTWN6Y1lheGVEZWdkSWdQZUdnemJNZTVlRGJUYllhOGdLYUJnRWJZZlZobGZnZXVkU2RnY01ldWdWYjFnSWFwZkJjamhWZ1NoQWJTYmxlVGJDY1JkWWFHaFZnaWJjZTBiRmQxZk1ncmROZkJjQWN4aEZhZ2d4YVhiTGJ5YUJkUWFXZlNmQmhWZUlhQ2djYm5kTWFSY01idWdIYkFjWmRiZVhiQmZNZlRnTWdpaG9iOGVJZ2djc2VyZkRmVWc0ZlVoVWRTY0lhTmVNZERoY2NVZ0FhMWhNZTVhTWJGZk1iTmJXZFFkVWFZZ0poRGdNYzJlTWdRZjRoQ2REYnhkc2N6YU9iUWgwZjJnUGZDYmdjUmNHYkZjWmhZZkxma2dvZkRlTGhsYWRnU2JLY1FhWWMxY1VoZ2VFY3BmVWh3ZGtjV2RCZmxlWWFuZE5oQmNkZlRnS2V6aFFmUWRNZ1JhWWJNaFZieWQ4Z2dhVWhGZ2tmZ2NWaFNjQWRuZkpiemJFZlRiTGVoY3djR2JXZTFjd2dUaEVkemdJZ3FmUGZDZ0lkTGJLZHdhMWRPZEZjRmRFZ2ljRGVUZkFnM2RGZUFmTmZUZk9lVGNCZlRjRGNWYWtnRmJHZ0NlUWh6Yk5kamFFYU9nQWVnaDhlYmhNZnpka2NOaE5lamh3aG9kRWFSaGhhV2dXY0NoNWZLYkFoeWE1YlhjVWFpZ2tnR2dOZFZmSWFCY0tlVmdNaEpoRmJnZlpiV2JKYXpoUWNYaFVoeWFzYjBlRWhEZ0VmV2dEYkZlY2J2YUlnRmZCaFpkSWhGYlVkZ2dKZnllY2h4aEVjeWM0Z2NmQmNsZHRmY2JFaHhlTWF5Y0tnamd3ZWlmQ2N5ZXNlTmFUZWhhUmZSYUlmZ2EwYXdkTmV4ZlFnRGJVZ3pma2Z3Y1Vnd2cxZFpmQmFSZmdma2NNYXpiWWZ4YkRkZ2ZJZ1BjR2h6YU1hNWJEZlRlWWQ4YktlQmhFaFlkVmNsZ2dhdWJTZmdhTWV1ZlZhMWNJY3BlQmJqaFZnU2JBZlNjbGFUY0NkUmhZYkdhVmNpYmNkMGFGaDFhTWRyYU5mQmhBZ3hiRmFnZHhnWGFMaHloQmdRY1diU2dCYlZkSWVDY2NhbmJNYVJlTWF1ZEhhQWNaYWJlWGVCZU1kVGNNYWlob2g4ZklmZ2JzZnJmRGZVaDRoVWJVYlNkSWVOYk1jRGdjYVVnQWIxZE1hNWFNaEZiTWROZFdhUWZVYVlmSmZEZU1oMmZNZ1FnNGRDaERneGVzZHpoT2dRZjBjMmJQYkNmZ2ZSYUdkRmVaZVlnTGZrY29kRGVMZmxoZGVTZUtmUWdZZTFjVWFnaEVncGNVZXdka2FXZUJkbGVZZW5jTmRCZWRjVGVLaHpiUWNRZU1kUmVZZk1nVmZ5YThiZ2RVZkZha2VnZlZkU2hBaG5jSmN6YkVmVGRMY2hjd2VHZFdhMWF3aFRkRWZ6YUljcWdQYUNiSWhMYktnd2cxZU9mRmZGYUViaWJEYlRhQWgzZEZkQWFOYVRiT2dUYkJhVGNEaFZna2VGYkdiQ2hRaHpkTmRqYkVhT2NBZmdhOGRiZU1jemRrZk5jTmZqZndib2FFZlJiaGVXYVdiQ2M1YktmQWN5ZTViWGhVZGloa2dHY05hVmNJZkJjS2ZWZk1jSmNGY2diWmRXZkphemFRZ1hkVWV5ZHNkMGRFZ0RmRWRXZkRmRmRjYnZiSWZGZ0JlWmVJZkZnVWRnZkpieWRjYXhnRWN5ZDRkY2VCaGxidGdjYUVneGdNY3liS2FqZXdlaWhDZ3lmc2ZOYVRlaGhSY1JjSWNnZTBod2ZOYXhkUWFEYlVmemhrZXdlVWJ3ZDFlWmhCZ1JiZ2hrYU1jemFZZXhnRGhnZElkUGRHYnpiTWc1Y0RhVGRZZjhkS2FCZUViWWVWZGxlZ2R1YlNmZ2ZNYnVmVmQxZ0lhcGFCZmpmVmdTYkFnU2FsZFRlQ2FSYllmR2RWZWloY2IwZkZhMWVNZXJmTmhCaEFmeGZGaGdjeGVYZkxoeWRCY1FmV2VTZUJnVmVJaENkY2ZuY01kUmFNYXVlSGRBaFplYmRYaEJjTWRUYU1naWFvaDhkSWFnYnNkcmJEZlVnNGRVZVVkU2dJaE5nTWNEaGNhVWdBYzFjTWY1aE1mRmdNYU5jV2dRaFVmWWRKYkRlTWgyZk1nUWM0Y0NhRGZ4ZXNjemJPYVFlMGEyY1BiQ2RnZVJmR2RGY1pnWWFMZWtib2FEZkxlbGdkYlNjS2dRY1llMWZVZGdoRWZwZlVkd2FrYldmQmZsaFllbmFOYUJhZGFUaEtnemJRaFFkTWhSZ1lnTWdWaHllOGNnZVVmRmdraGdkVmZTZEFobmRKY3pjRWVUaExjaGZ3ZkdiV2MxaHdlVGZFZXpjSWhxZVBiQ2NJZExoS2h3YjFnT2RGYUZlRWhpaERmVGJBZjNhRmFBYU5jVGdPZFRjQmNUZkRiVmdraEZjR2JDaFFlemhOZmphRWFPZUFjZ2I4YmJnTWZ6aGtjTmdOYWpod2VvZkVkUmRoZVdmV2FDZDVjS2hBZXliNWhYYlVoaWFrZkdlTmVWYklmQmJLZVZiTWNKYkZiZ2FaZFdmSmV6YVFoWGJVZnlnc2UwZ0ViRGhFZVdoRGRGYWNkdmFJZkZhQmFaZEloRmRVY2dnSmd5Y2NleGFFZXliNGZjYkJmbGd0ZWNoRWF4Z01keWdLYmphd2NpZUNoeWRzZU5iVGNoZlJoUmZJaGdkMGh3aE5neGVRZERnVWN6Y2tkd2NVYndoMWhaYUJoUmhnYmtnTWF6ZVloeGJEZGdoSWNQaEdmemdNaDVlRGJUZllhOGJLZUJnRWNZY1ZjbGZnZHVmU2hnZE1jdWZWYjFjSWVwY0JiamNWZVNiQWJTZGxiVGFDY1JlWWZHZlZnaWVjZTBmRmMxY01ocmVOZ0JjQWJ4YkZjZ2Z4ZVhoTGN5Y0JnUWRXYVNiQmVWZ0lmQ2djY25jTWRSYU1mdWJIZ0FiWmFiaFhoQmJNYlRkTWVpYW9hOGZJZmdlc2ZyY0RkVWY0ZFVkVWRTZUloTmFNYURkY2JVZ0FnMWFNZTVoTWhGZU1hTmdXZVFnVWdZZEpiRGhNYjJoTWFRYzRlQ2JEY3hkc2N6Y09jUWQwYjJlUGVDZWdhUmVHYUZhWmVZYkxka2JvZURhTGRsZWRmU2FLZFFiWWYxY1VhZ2JFZ3BoVWJ3Y2tjV2dCaGxjWWRuZE5iQmNkYlRhS2R6Z1FlUWZNYVJiWWFNZFZkeWQ4ZWdhVWdGZWtiZ2ZWaFNnQWduZ0phemVFZVRlTGhoaHdkR2FXZDFjd2dUY0VjemZJYXFmUGFDYklkTGRLZndiMWNPZUZjRmZFZGlmRGNUZ0FhM2ZGZ0FkTmRUaE9kVGNCZVRlRGRWY2tjRmJHZ0NkUWh6Zk5kamFFZ09jQWJnZjhiYmJNZnpoa2NOYU5oamh3YW9iRWVSYmhiV2FXZkNlNWNLZkFieWI1Z1hoVWZpZ2tjR2FOaFZkSWVCaEthVmRNYUplRmJnYlpjV2VKYnpnUWVYYlVkeWJzYTBiRWFEYUVnV2ZEYUZnY2V2Y0lhRmhCZVpkSWhGZVVlZ2VKZXliY2V4ZUVheWc0Z2NlQmRsaHRmY2VFYXhhTWR5ZEtlamd3ZGlhQ2Z5Y3NlTmVUaGhnUmVSYklnZ2IwaHdlTmN4Y1FmRGFVaHpia2N3YVVkd2QxYVpnQmNSZmdja2NNZHphWWZ4ZERjZ2NJZlBlR2d6Y01kNWVEZVRoWWI4aEtnQmJFYVljVmJsaGdhdWFTYWdoTWZ1YVZmMWNJZHBnQmRqZVZnU2JBYVNlbGFUZkNlUmdZaEdjVmJpY2NnMGdGYTFoTWFyZ05oQmdBZHhiRmFnaHhnWGdMZnlmQmdRZVdiU2hCZlZnSWZDYWNobmZNYlJlTWh1aEhkQWJaYmJmWGJCY01iVGdNZmlnb2I4ZUlhZ2hzYXJnRGJVZTRkVWRVZFNhSWFOZk1nRGNjYlVoQWIxZk1nNWNNZ0ZoTWdOZldjUWhVZFlmSmFEYU1mMmhNY1FhNGdDY0RkeGJzY3piT2FRYzBmMmVQZENjZ2JSYkdhRmZaYlljTGdrZW9iRGVMZmxnZGFTYktlUWNZYjFoVWdnY0VlcGVVYndka2VXZEJobGRZZm5jTmJCaGRiVGhLZHphUWVRYk1oUmZZZE1hVmd5ZzhoZ2VVZEZka2ZnYVZlU2JBYm5mSmR6ZEVlVGZMYmhmd2ZHY1dmMWZ3aFRjRWV6ZklncWhQZUNlSWVMY0tid2cxaE9mRmVGZEVhaWFEYlRiQWIzZ0ZmQWVOZVRlT2JUZEJmVGZEaFZma2VGYkdjQ2RRZXpmTmhqYUVmT2dBYWdlOGdiZk1oemFrZk5hTmFqY3dib2JFZFJkaGZXZ1djQ2Y1Z0thQWd5ZDVoWGZVYmlma2JHZU5mVmNJZUJhS2VWYU1mSmFGZWdjWmVXZ0pjemdRY1hkVWJ5ZnNlMGhFaERiRWZXZ0RlRmRjZHZnSWdGaEJoWmZJYkZhVWNnZkpleWRjYnhhRWF5ZjRjY2FCaGxkdGhjZkVkeGVNYnlhS2dqYndoaWJDY3ljc2ROZVRjaGRSZVJkSWZnZjBhd2ROYXhlUWJEY1VlemZrYndiVWh3YjFoWmRCZFJkZ2VraE1nemVZZ3hlRGVnZUlnUGFHZXpjTWI1ZURoVGNZZDhmS2ZCZEVhWWhWZGxnZ2Z1ZlNmZ2VNZnVkVmgxYUlkcGNCZWplVmJTaEFnU2VsY1RnQ2RSYllmR2dWZ2lhY2gwZUZlMWJNZnJlTmVCYkFjeGFGaGdmeGNYYkxjeWdCYlFhV2ZTZ0JoVmZJZ0NiY2huZ01jUmdNZHVhSGFBY1phYmRYZkJlTWVUZk1kaWZvYzhoSWRnZHNmcmdEZlVlNGdVZVViU2RJZ05hTWVEZWNmVWdBaDFkTWM1Yk1mRmJNaE5jV2RRZlVlWWRKZ0RlTWIyZU1oUWM0ZENhRGF4aHNhemNPZFFjMGQyZ1BkQ2hnZlJjR2NGZFpkWWhMY2tlb2REYUxlbGRkZFNkS2RRYllhMWRVaGdiRWRwZlVhd2ZrYldjQmNsYVlmbmZOYkJiZGNUZkthemFRaFFkTWdSYVloTWNWYXlnOGhnZVVmRmFraGdoVmVTZ0FjbmhKaHpjRWdUYkxkaGd3ZkdoV2MxZHdiVGhFZ3pnSWdxaFBkQ2hJY0xoS2R3ZDFiT2RGZ0ZiRWZpaERoVGZBZjNmRmFBZU5mVGRPaFRkQmFUYkRnVmhrZUZhR2JDY1FmemROZWplRWFPZUFiZ2I4ZmJmTWJ6aGthTmVOaGpod2FvYUVjUmNoZldnV2VDYjVkS2VBY3ljNWJYYlVkaWJrY0diTmRWYklnQmJLZ1ZmTWRKZ0ZkZ2JaYldoSmJ6aFFiWGNVaHlmc2IwY0VhRGRFZ1dkRGVGYWNjdmRJYkZmQmFaZElmRmVVYWdlSmh5Y2NneGJFaHlhNGNjY0JnbGh0YmNmRWZ4Zk1heWhLZGpnd2NpZ0NneWZzY05lVGJoaFJjUmJJYWdnMGJ3Z05keGNRYkRlVWZ6aGtkd2dVZXdkMWRaY0JjUmVnZWtjTWJ6ZFloeGJEZ2djSWRQY0djemJNYTViRGNUZFloOGRLZEJoRWVZZFZibGdnZHVkU2FnY01mdWhWYjFjSWFwZUJhamZWaFNhQWRTaGxlVGhDZ1JiWWRHaFZmaWFjZDBiRmQxZk1hcmZOZkJhQWR4Z0ZmZ2d4Y1hhTGN5ZUJjUWNXYVNlQmFWZklhQ2FjZ25jTWhSZ01idWdIYUFhWmNiZlhiQmFNY1RiTWFpZG9jOGRJYmdkc2FyZ0RjVWU0ZFViVWhTYklhTmZNY0RjY2NVZEFmMWFNZzViTWVGY01lTmRXZ1FkVWFZZkpoRGhNZzJoTWJRZTRiQ2VEYnhmc2Z6Y09hUWYwZTJjUGJDZmdlUmFHZ0ZjWmFZaExla2RvZkRnTGFsZ2RiU2FLZ1FlWWUxY1VjZ2VFaHBhVWN3Z2thV2RCZ2xoWWRuYU5jQmZkY1RkS2R6YlFnUWFNZlJiWWFNZ1ZieWc4ZWdnVWRGZGtoZ2hWY1NoQWRuYkpjemVFY1RoTGFoYndhR2VXZTFld2JUYUVhemNJZ3FmUGhDZkloTGNLZHdnMWFPYUZjRmVFZmlnRGVUYkFiM2dGYkFhTmJUZE9oVGVCYVRlRGNWZmtnRmdHZkNhUWF6YU5hamVFY09oQWRnZjhiYmFNZXpja2ROZE5kamV3Zm9kRWJSYmhmV2JXYUNiNWRLYUFieWY1Z1hoVWhpY2tnR2dOYVZnSWRCYktiVmVNZUplRmhnaFphV2VKZ3pnUWNYYVVieWdzaDBkRWhEaEViV2NEZEZmY2d2ZkljRmVCZlpiSWZGYVVkZ2VKYnlhY2J4ZkVieWU0Z2NjQmNsZHRkY2dFYnhhTWR5ZktlamF3ZWloQ2F5ZnNnTmhUaGhjUmFSZkliZ2MwaHdiTmZ4ZlFnRGJVZ3pna2V3Y1Vid2cxY1pkQmNSYmdia2FNZHpjWWh4YkRkZ2ZJaFBiR2F6YU1lNWdEYVRjWWY4ZEtjQmhFYVlnVmZsaGdmdWFTYmdnTWZ1Y1ZlMWJJZXBmQmRqYlZkU2JBZVNjbGdUZkNkUmhZZkdmVmdpZGNkMGVGaDFiTWVyaE5jQmZBZXhkRmRnZHhiWGdMY3lkQmRRZldlU2hCZ1ZkSWRDaGNlbmRNY1JjTWR1ZEhmQWRaZ2JlWGRCYk1hVGZNZGlnb2Y4ZEliZ2VzY3JhRGVVYzRmVWZVZlNlSWhOYk1lRGNjZlVoQWExaE1mNWNNY0ZiTWFOY1dmUWdVZ1lhSmREZE1nMmFNY1FmNGJDY0RleGVzY3plT2RRZzBoMmJQaENmZ2JSZUdoRmJaY1lnTGZraG9lRGRMZGxhZGJTYktiUWVZZDFiVWZnYkVicGZVZndma2dXZUJmbGVZZG5jTmZCZmRkVGJLZHplUWdRZk1oUmRZaE1lVmh5YjhmZ2dVZUZha2JnZ1ZhU2RBaG5lSmF6ZEVkVGVMYmhhd2VHYldnMWF3YVRhRWJ6Y0llcWJQaENhSWRMYUtkd2QxaE9oRmFGYUVjaWZEZ1RkQWQzZ0ZmQWNOZ1RkT2RUZEJjVGVEZlZna2NGYUdiQ2dRZ3piTmVqYkVnT2JBZ2dlOGNiaE1nemFrYU5lTmVqZ3dob2VFYlJmaGFXYldnQ2U1Z0toQWd5YjVnWGVVaGlia2ZHZE5oVmNJZkJjS2VWZk1jSmJGZGdoWmNXY0phemRRYlhhVWd5aHNoMGZFZERhRWZXZkRkRmZjZnZlSWJGZUJlWmFJZUZiVWVnYkpieWNjY3hoRWh5aDRkY2FCZGxjdGZjY0VkeGhNZXlmS2NqZndiaWVDZHloc2NOaFRhaGVSZlJhSWVnZzBid2NOZnhjUWZEY1VhemhrYndlVWJ3YTFhWmdCZFJoZ2FrZk1hemRZZ3hoRGFnZElkUGhHaHplTWU1YURiVGZZaDhnS2dCZ0ViWWhWYWxhZ2J1Z1NhZ2JNYnVjVmcxY0lhcGZCZ2pkVmVTaEFhU2FsZ1RoQ2FSZ1loR2JWYmlhY2cwZUZoMWJNZ3JiTmFCZUFneGJGaGdieGJYZ0xkeWFCZVFoV2JTYkJhVmJJYUNmY2VuYU1nUmRNZnViSGFBYVpkYmhYZ0JkTWNUZk1oaWdvaDhmSWVnYnNjcmREYlVjNGZVYVVoU2FJYU5jTWREZWNnVWVBaDFlTWI1ZU1mRmdNZE5hV2VRY1VhWWZKZURjTWIyaE1nUWE0Z0NiRGZ4ZnNnemRPZlFnMGcyYVBnQ2NnZVJlR2JGaFpnWWFMZmtmb2hEYkxkbGNkYlNkS2JRY1lhMWhVZmdnRWFwZ1Vid2drZ1diQmVsZVlnbmFOZ0JjZGZUY0toemVRZlFoTWhSZFlkTWVWaHloOGFnYVVhRmhrYmdmVmJTZkFmbmZKZnpkRWNUZExmaGN3ZkdoV2IxYndjVGZFZnpjSWFxZVBmQ2ZJZUxiS2Z3ZzFlT2FGYUZlRWRpZ0RmVGJBZDNoRmNBY05lVGdPYlRlQmdUZURkVmNrZEZlR2ZDZ1FkemhOaGpnRWRPZUFmZ2Q4YmJnTWV6Z2toTmVOY2pmd2NvZ0VoUmdoZ1dlV2NDYjVnS2hBYnliNWVYaFVmaWhrZUdiTmZWZUlhQmFLYlZiTWhKZEZkZ2daZ1dkSmh6Z1FiWGZVaHlhc2cwYUViRGZFZ1dmRGJGYmNjdmJJZEZoQmFaYklhRmVVYmdlSmJ5aGNoeGNFaHllNGNjYUJhbGV0ZWNiRWJ4ZU1oeWhLYWpld2RpY0NjeWVzZk5oVGRoZVJoUmdJYWdlMGN3ZE5heGJRZkRkVWV6ZGtld2VVZXdoMWhaYUJiUmhnaGtlTWJ6ZFlleGNEY2doSWVQYkdoemdNYzVkRGZUZllmOGNLZkJoRWhZaFZkbGhnYXVlU2hnZ01ldWdWZDFjSWVwZ0JhamJWYVNlQWVTZ2xkVGRDYVJlWWNHaFZoaWFjZTBmRmIxZU1icmJOY0JnQWZ4aEZnZ2J4Z1hmTGR5Z0JoUWNXZFNkQmNWZEllQ2VjaG5nTWdSZE1odWVIY0FmWmViaFhlQmhNYlRkTWNpZm9kOGRJY2dnc2VyYURoVWI0YVVhVWZTZ0ljTmdNYURkY2ZVY0FnMWVNZTVnTWJGZU1kTmZXYlFjVWZZaEpnRGZNZTJjTWVRZTRnQ2hEYnhlc2R6aE9iUWMwZDJoUGZDZWdjUmVHYkZhWmNZZ0xma2hvY0RlTGhsZ2RhU2hLY1FjWWYxY1VjZ2VFZXBiVWJ3aGthV2JCYmxhWWNuaE5kQmdkY1RnS2N6ZlFhUWVNYVJhWWdNY1ZoeWE4ZGdlVWFGZWtkZ2dWZ1NoQWNuZkphemJFY1RkTGZoYndiR2FXZDFid2dUYUVkemhJYnFiUGZDaElmTGJLY3dhMWNPYUZiRmdFZ2loRGhUZ0FoM2dGZEFhTmNUYk9kVGNCYlRhRGRWaGtmRmJHZENnUWd6YU5iamRFZk9iQWFnZjhiYmhNZnpha2VOZE5hamJ3YW9mRWhSYmhnV2VXZkNnNWdLYUFjeWU1ZFhoVWhpaGtnR2JOY1ZkSWZCYUtlVmVNZ0pmRmFnY1piV2JKaHphUWNYZFVieWNzYjBiRWdEZUVkV2hEZEZnY2V2YUljRmdCYVpoSWhGZFVmZ2dKYnlnY2d4ZEVjeWI0YmNlQmFsaHRjY2hFaHhoTWh5YUtiamF3ZWloQ2Z5YnNkTmdUYWhiUmhSZklkZ2EwZ3dmTmV4Y1FjRGNVZnpia2V3aFVkd2UxaFpnQmFSaGdma2RNY3poWWR4YURjZ2VJZlBmR2d6Z01hNWJEZ1RkWWQ4aEtjQmZFY1lhVmFsZGdmdWhTYmdiTWN1YVZmMWFJZ3BlQmVqY1ZkU2hBYlNhbGhUaENoUmVZaEdiVmZpZ2NoMGdGZDFjTWhyZ05hQmVBYnhjRmZnZHhhWGFMY3liQmhRZ1dkU2FCZ1ZjSWFDZWNmbmVNZ1JnTWF1YUhlQWNaYWJoWGVCZE1kVGZNZ2lmb2g4ZEliZ2FzZnJiRGFVaDRlVWNVZ1NiSWROZE1mRGFjZlVlQWMxZU1mNWNNY0ZiTWZOZVdnUWZVZ1lnSmVEY01oMmdNZ1FkNGhDaERieGJzYnpjT2hRZTBlMmVQZkNmZ2NSZEdhRmdaZllkTGhrY29jRGhMZWxmZGNTYUtmUWNZZTFiVWNnZEVkcGdVZXdoa2dXZkJobGdZZW5iTmNCZmRiVGNLYnpiUWVRaE1hUmhZaE1nVmZ5YzhoZ2FVY0Zoa2NnZlZkU2hBYm5hSmd6Y0VlVGdMaGhld2RHYVdiMWZ3Y1RjRWN6aEljcWdQZUNlSWZMZEthd2cxZ09kRmNGaEVoaWJEaFRmQWgzZEZnQWNOaFRnT2VUYUJlVGJEYVZna2ZGY0diQ2RRZXpjTmJqY0ViT2dBZGdmOGdiYk1memJrZ05iTmNqaHdjb2NFYlJjaGNXZFdmQ2I1aEtnQWN5YTVoWGJVYWlma2RHYk5kVmVJaEJkS2JWaE1kSmRGaGdiWmdXY0pmemJRY1hoVWZ5ZHNmMGFFZ0RoRWdXYkRmRmZjaHZkSWRGYkJkWmdJYUZiVWNnZUpoeWdjYXhoRWZ5ZzRjY2dCYWxjdGNjYUVleGZNZnloS2ZqYndlaWhDZHllc2VOZ1RoaGdSZFJmSWVnYjBhd2JOZnhoUWJEYlVmemVrZXdnVWJ3YjFkWmJCZVJhZ2JrYU1nemFZZ3hjRGVnYUloUGhHZXpmTWg1ZERhVGJZaDhhS2JCYkViWWFWZGxhZ2J1ZFNlZ2RNZnVjVmMxY0lkcGdCaGpiVmdTZ0FmU2FsY1RnQ2ZSYVllR2FWaGljY2UwaEZnMWNNYnJlTmFCZkFleGhGYWdjeGFYZUxkeWhCZlFkV2FTZUJnVmRJZENiY2FuaE1nUmNNaHVhSGdBZlphYmRYZ0JkTWZUZ01maWZvZThkSWdnZnNkcmNEZ1VkNGNVY1VmU2NJY05jTWVEY2NjVWFBZTFjTWI1Z01iRmFNZ05oV2dRYVVkWWFKZ0RlTWgyZ01jUWg0Z0NkRGR4aHNkemhPaFFlMGQyYVBmQ2ZnZ1JiR2JGYlpkWWdMZmtmb2hEYUxobGVkZ1NkS2RRYlllMWZVaGdkRWZwYlVid2JrYVdjQmRsZFlnbmJOY0JkZGhUZUthemRRY1FjTWZSZFlmTWVWZ3liOGJnZVVlRmNrZmdlVmZTYUFmbmFKZXpnRWJUY0xnaGV3ZkdoV2cxZndmVGhFZnphSWFxaFBmQ2RJZExmS2J3aDFmT2JGZ0ZjRWNpaERlVGdBYzNmRmNBYU5kVGhPY1RjQmJUZ0RhVmdrZkZoR2NDZlFlemdOZmpkRWFPZ0FlZ2c4YmJhTWZ6Z2tmTmNOZWpmd2hvZkVoUmdoZ1dmV2FDaDViS2FBZHlkNWdYZFVjaWNraEdhTmZWZ0lnQmdLYlZkTWdKY0ZiZ2VaZldkSmh6YlFoWGZVZnlkc2cwYUVnRGhFZ1dnRGNGYmNmdmNJYUZmQmFaZUlmRmdVYWdhSmh5ZWNmeGRFY3ljNGFjZkJobGh0ZWNnRWF4aE1keWVLYWpnd2ZpYkNleWFzZk5oVGNoZFJjUmhJYWdmMGJ3Zk5oeGNRZURjVWR6Y2tjd2NVaHdkMWVaZkJkUmdnZGtkTWZ6Y1lmeGREZGdnSWJQZEdjemZNZTVjRGZUaFlmOGRLZUJnRWJZaFZobGdnYXViU2ZnZ01hdWhWZjFnSWZwYUJhamdWZVNnQWZTZWxnVGNDYlJkWWNHZFZmaWhjYTBhRmYxYk1kcmdOZ0JhQWV4ZkZhZ2V4Y1hjTGJ5Y0JiUWdXZVNiQmdWY0llQ2RjY25jTWdSZk1idWVIZkFmWmZiZVhmQmVNZlRkTWJpY29hOGFJZ2dhc2JyZkRnVWI0aFVjVWJTZ0lhTmFNaERhY2VVaEFkMWhNaDVjTWVGZk1nTmhXZ1FiVWVZY0poRGZNYTJnTWFRYjRkQ2dEaHhic2F6Zk9kUWgwaDJiUGVDZ2diUmdHYUZoWmdZZ0xoa2ZvZ0RjTGhsY2RnU2RLZ1FmWWgxYVVhZ2hFZHBiVWZ3aGtoV2hCYWxkWWduYk5kQmFkaFRhS2Z6YVFmUWdNZ1JnWWZNY1ZheWg4aGdnVWVGaGthZ2dWZ1NhQWhuZEpmemVFYlRnTGFoYXdnR2dXZjFnd2dUYkViemhJZXFhUGVDYkliTGVLZXdlMWdPZkZjRmhFZ2lnRGFUZkFnM2JGYkFlTmZUYk9kVGhCZlRlRGJWZWthRmhHZENlUWF6YU5kamNFZk9iQWhnYThmYmJNaHpha2dOY05namd3Ym9lRWNSaGhkV2dXZUNoNWNLYkFjeWI1ZlhkVWhpYWtnR2ROZFZjSWVCY0toVmVNZEpoRmJnZFplV2JKZHpjUWRYaFVleWRzZzBoRWNEZ0VmV2VEYUZiY2R2YklnRmhCaFpjSWNGZFVlZ2hKY3loY2V4ZUVoeWI0YWNoQmZsZ3RoY2hFZ3hnTWZ5YUtmamN3Z2lnQ2R5ZXNnTmdUZmhiUmJSZElkZ2IwYndiTmN4ZFFhRGNVYnpha2Z3aFVhd2gxaFpmQmFSZGdha2NNY3pnWWF4Z0RnZ2FJZ1BjR2h6Yk1hNWVEY1RlWWU4ZEtkQmhFZ1lkVmJsZGdodWdTY2dmTWF1YVZmMWNJY3BhQmhqYVZoU2ZBaFNhbGZUZkNmUmdZZkdnVmFpZGNoMGdGYjFmTWFyaE5oQmZBY3hoRmVnY3hkWGRMZ3lkQmZRZVdkU2RCYlZmSWFDY2NkbmZNZVJiTWR1ZUhlQWVaZmJjWGRCZE1hVGRNZWlob2c4ZkllZ2JzZHJjRGVVYjRoVWZVZFNmSWNOZU1hRGNjZFVoQWQxZE1jNWJNZUZjTWVOZVdiUWZVZFlhSmVEZ01iMmVNZ1FjNGVDZURneGRzZnpnT2hRZTBjMmhQZENmZ2hSaEdkRmFaZVllTGFrZm9iRGdMYWxlZGFTaEthUWJZZDFjVWdnY0VncGVVZndma2JXY0JnbGVZY25hTmVCZWRjVGRLYXpiUWZRZk1mUmVZY01oVmh5ZjhkZ2dVYUZha2RnZVZmU2NBZW5kSmV6YkVlVGhMaGhkd2dHZFdiMWR3ZlRkRWF6ZklocWZQZENkSWVMZktid2gxZ09nRmdGYUVnaWhEY1RnQWYzY0ZiQWdOYlRhT2dUaEJnVGREZVZka2NGY0diQ2dRZnphTmRqZEViT2NBYWdkOGRiZE1oemdrZU5lTmNqZ3djb2VFZ1JkaGVXYldiQ2I1ZUtoQWV5ZDVhWGFVYWlka2ZHZk5kVmVJZEJhS2hWaE1oSmNGZGdiWmRXZEpjemJRYVhhVWZ5YnNhMGJFYURjRWRXZkRhRmZjZHZlSWJGZEJlWmNJZkZmVWNnZ0pleWNjYXhjRWN5YzRlY2ZCZ2xldGFjY0VoeGRNZHlmS2FqaHdiaWJDZ3loc2FOYlRiaGNSaFJnSWhnYzBjd2VOZ3hoUWFEY1VjemVrZXdjVWV3YTFlWmFCYVJiZ2FrZ01nemZZZXhjRGdnaElnUGJHYXpnTWM1aERhVGNZYjhoS2ZCaEVkWWZWY2xhZ2F1ZVNjZ2dNZnViVmQxZ0locGNCZmpkVmVTZ0FmU2RsY1RnQ2VSZlliR2RWZmllY2gwZkZoMWVNZnJlTmJCYkFmeGJGZWdneGFYYkxoeWZCY1FoV2RTZUJnVmhJZkNnY2JuZU1jUmhNY3VkSGRBZFphYmhYaEJoTWJUZ01laWhvYjhnSWNnZXNicmJEY1VjNGJVaFVoU2NJZ05mTWJEYmNiVWFBYzFjTWY1Yk1lRmFNY05kV2ZRZlVjWWVKZkRlTWcyYk1oUWM0YkNiRGV4ZXNkemZPZVFjMGEyZVBlQ2NnZVJoR2VGZ1plWWZMaGtkb2REZkxlbGJkaFNkS2RRZVljMWhVZ2dmRWRwZlVid2RrZFdmQmhsYVljbmZOYUJmZGJUYUtnemdRYVFlTWRSYlliTWVWYXlmOGdnZ1VlRmJrZmdnVmNTYkFnbmFKYnphRWZUYUxiaGV3Y0dnV2ExY3dhVGhFZnpiSWZxZVBjQ2VJZkxiS2R3ZjFhT2VGZEZjRWRpY0RoVGVBZzNhRmdBZU5jVGRPYlRhQmFUZ0RlVmFraEZmR2hDZFFoemZOYmpoRWJPZUFnZ2E4YmJnTWN6aGthTmhOYmpjd2dvYkVhUmFoZldiV2dDaDVmS2dBZHlmNWVYZFVkaWZrYkdjTmdWY0llQmNLZVZmTWFKZEZkZ2RaYldkSmN6YlFhWGFVZ3lmc2YwZ0VnRGVFZVdnRGZGYmNjdmhJZUZoQmZaYUllRmNVZGdiSmZ5YmNkeGhFYXlkNGNjZ0JnbGF0Z2NoRWh4Y01ieWdLYmpmd2JpZ0NkeWdzYk5hVGZoaFJoUmZJYmdmMGV3Y05keGhRZERnVWZ6YWtjd2JVZ3dmMWNaYkJoUmZnZWtlTWF6YVlleGdEaGdoSWZQYkdnemJNaDVhRGZUY1lnOGFLYkJmRWNZZlZlbGhnYnViU2hnYU1odWhWYzFlSWFwZ0JhamZWY1NhQWhTZWxmVGRDYVJjWWRHZFZoaWVjYjBiRmQxZU1ocmNOaEJoQWV4ZUZlZ2d4aFhiTGF5Y0JnUWJXZlNoQmNWY0lhQ2ZjYm5jTWFSYU1jdWVIY0FoWmViY1hjQmJNaFRnTWRpaG9kOGNJaGdmc2NyYkRhVWI0Y1VjVWZTZ0liTmVNZURnY2FVZkFlMWFNZjVhTWVGaE1mTmZXZlFlVWdZY0phRGVNZDJiTWNRYTRlQ2dEZnhkc2V6ZE9hUWUwZzJlUGVDYmdnUmRHZkZoWmhZYkxha2ZvZkRjTGZsYmRiU2JLZlFiWWcxZFVoZ2ZFaHBiVWJ3ZWthV2FCYWxkWWVuY05nQmJkaFRiS2R6aFFlUWFNYlJoWWZNZ1ZieWM4ZmdlVWhGY2thZ2FWaFNmQWZuaEphemRFY1RlTGJoZHdiR2FXZjFhd2RUZ0VjemFJYXFnUGZDZUlmTGRLZ3djMWVPaEZiRmVFZ2lmRGJUZUFnM2dGY0FlTmZUZU9iVGRCZFRjRGVWZGthRmRHZkNhUWR6Yk5namJFZE9iQWZnZThkYmJNZnpha2JOaE5lamV3ZG9mRWRSY2hhV2hXZENiNWdLYUFieWQ1YlhkVWNpZGtkR2dOZlZhSWRCaEtnVmhNYkphRmJnZVphV2RKZ3pjUWZYZFVmeWhzYzBkRWFEZUVlV2JEZkZjY2Z2ZUllRmFCaFpmSWVGYVVnZ2NKZXlhY2R4ZUVneWE0YWNoQmJsZnRiY2FFZXhhTWN5YUtlamN3Z2loQ2J5ZHNmTmNUYWhhUmFSYUllZ2cwZXdmTmh4aFFoRGdVY3pka2J3ZlVid2UxZVpnQmRSY2dma2dNZnpjWWJ4ZURjZ2hJZFBlR2J6Zk1hNWZEYVRiWWc4ZUtjQmNFY1liVmhsYmdldWVTYWdmTWZ1Y1ZkMWNJYnBnQmRqaFZhU2hBYlNobGdUZ0NiUmJZY0doVmhpY2NiMGZGYjFoTWRyaE5nQmVBZXhmRmFnZnhkWGFMY3lnQmJRZ1dlU2hCYVZlSWRDZWNlbmVNZVJjTWZ1YkhiQWRaYmJjWGZCY01mVGhNZWllb2c4ZklmZ2NzYXJkRGJVZzRiVWJVY1NnSWFOaE1jRGVjaFVhQWUxZU1mNWVNYUZhTWVOZFdoUWhVYllhSmVEYU1hMmJNZVFjNGdDY0RmeGVzYXpkT2JRYjBjMmJQYkNlZ2NSYkdmRmRaY1llTGVrZG9oRGFMY2xiZGdTZEtoUWhZYzFkVWNnY0VncGhVaHdma2RXZUJnbGRZZW5iTmRCY2RkVGZLZXpoUWRRZk1iUmhZY01oVmh5ZzhiZ2FVaEZia2FnY1ZmU2hBYm5mSmZ6ZkViVGVMaGhmd2dHaFdjMWZ3aFRkRWR6aElocWFQY0NhSWFMaEtjd2ExZ09hRmJGYkVjaWhEZVRkQWczYkZoQWFOZ1RoT2ZUZEJkVGNEYlZka2NGY0doQ2ZRZHphTmFqYkVmT2RBZ2diOGJiY01nemRrY05lTmNqZ3dkb2dFZVJlaGdXYldiQ2c1YUtlQWJ5ZzViWGhVZ2loa2NHaE5mVmZJY0JlS2RWZE1nSmJGYmdkWmRXYkpiemhRZ1hnVWN5ZnNmMGJFZkRjRWVXYkRlRmhjYXZoSWJGaEJjWmVJZ0ZnVWNnaEpjeWVjZnhkRWd5ZzRnY2hCZmxndGZjZEVheGRNYnljS2RqZndmaWJDZXljc2VOaFRnaGVSYlJiSWRnYTBid2ROZnhkUWhEZ1VnemZrZndkVWZ3ZjFnWmJCY1JjZ2FrZ01kemJZY3hoRGZnaEliUGNHZXpjTWE1aERoVGdZYjhjS2NCZEVkWWVWZmxnZ2J1YlNkZ2JNYXVlVmMxZUlkcGdCYmpnVmVTZEFoU2FsZ1RnQ2RSZllhR2RWZ2ljY2UwYUZlMWNNZXJiTmFCY0FoeGFGZWdheGNYY0xleWNCY1FoV2RTaEJiVmRJaENiY2RuZE1lUmJNZXVjSGJBY1pjYmdYZUJjTWRUZk1maWdvYThiSWJnZXNocmVEZVVmNGNVZlVoU2VJZk5kTWFEZGNkVWZBaDFiTWY1ZU1jRmZNYk5jV2ZRZFVkWWZKZERkTWIyYk1kUWM0Y0NlRGh4ZnNhemFPZVFoMGEyY1BnQ2dnZFJoR2dGZ1pjWWNMY2tob2REZUxjbGFkYlNjS2ZRYllmMWZVY2djRWFwYVVod2drZldnQmRsYllnbmZOYUJhZGRUaEtjemdRYVFjTWFSZFlnTWVWYnliOGdnYVVnRmJrYWdhVmNTZEFkbmNKYnpnRWNUYUxhaGd3Z0djV2ExYXdnVGdFYnpnSWdxZFBiQ2ZJZkxiS2V3YzFhT2FGY0ZkRWRpZURhVGFBYzNjRmRBaE5kVGdPZ1RkQmNUYkRlVmRrYkZhR2JDZ1FjemdOZGpnRWhPYkFhZ2c4Y2JiTWd6ZGtoTmVOZWpnd2VvZkVjUmNoZldoV2VDZTVkS2VBZ3llNWFYaFVlaWZrZUdlTmhWaEliQmhLaFZjTWRKYUZlZ2NaYldmSmZ6ZFFjWGNVZnljc2UwZkVkRGNFY1dhRGJGZmNodmhJYkZlQmVaZEllRmNVZ2dkSmZ5YmNoeGNFY3lhNGFjY0JibGF0ZWNlRWJ4YU1heWFLaGphd2VpaENleWdzZU5jVGJoZFJjUmVJZGdlMGR3Zk5meGJRYURhVWh6Zmtmd2FVZHdmMWVaYkJmUmdnYWtoTWN6Y1lneGREY2djSWRQZUdiemhNZTViRGVUYVllOGhLZkJjRWNZZVZobGZnZHVoU2JnZU1kdWJWYTFhSWFwYUJhamVWYlNjQWNTY2xoVGhDZlJhWWZHZ1ZlaWZjYjBkRmgxZE1kcmFOaEJlQWF4ZUZhZ2J4ZlhiTGN5ZEJlUWdXaFNhQmhWYkloQ2djZm5nTWJSZE1hdWZIYUFiWmdiaFhhQmJNZ1RoTWNpYW9oOGdJZ2doc2NyZkRjVWI0YlVkVWdTaEljTmRNZ0RkY2NVYkFoMWhNaDVoTWVGaE1jTmRXaFFhVWVZZkpkRGFNZDJkTWRRZDRiQ2REYXhjc2J6aE9iUWQwYzJnUGdDZGdmUmFHYUZhWmNZaExka2dvY0RnTGZsZmRjU2hLY1FnWWIxZ1VlZ2NFYnBnVWh3Y2tiV2hCYWxoWWJuZU5nQmNkZVRkS2Z6ZlFhUWNNZVJoWWFNaFZkeWc4aGdnVWRGZmtlZ2JWZlNlQWRuYUphemZFYlRjTGVoZndhR2JXYTFod2dUY0VlemdJZnFlUGVDaElkTGhLZHdmMWVPYUZmRmVFZmloRGJUZ0FmM2ZGZ0FiTmVUZ09hVGNCaFRhRGRWaGtnRmVHY0NnUWF6ZU5iamZFZk9mQWNnZThoYmRNZHpha2dOY05jamV3aG9oRWRSaGhkV2dXZENjNWVLYUFleWQ1Z1hjVWFpYmtkR2ZOYVZmSWJCYUtiVmhNaEpiRmVnZFpmV2RKYXpjUWFYaFVneWRzZjBnRWVEZ0VlV2hEZEZlY2N2YklnRmZCZFpoSWdGZFVoZ2NKaHllY2h4Y0VjeWM0YmNkQmdsY3RiY2RFY3hoTWh5aEtiamR3ZGlnQ2V5ZXNmTmhUZGhhUmFSaElkZ2IwZXdmTmF4ZVFkRGFVZHpna2h3YlVkd2MxaFpkQmVSZGdia2dNZ3pjWWR4ZkRoZ2JJZFBjR2V6ZU1lNWdEZlRkWWY4Z0toQmZFZVljVmdsYmdhdWNTZ2dmTWJ1Y1ZnMWJJYXBhQmhqY1ZkU2VBaFNobGRUZ0NiUmZZZEdjVmNpYmNiMGZGYzFkTWRyY05jQmZBZXhlRmhnYXhlWGFMYnlnQmJRaFdhU2JCY1ZjSWVDZmNobmhNZlJlTWV1ZUhmQWZaZmJnWGFCZU1hVGJNaGlnb2U4ZUlnZ2ZzY3JnRGdVZzRnVWZVZ1NmSWZOYk1oRGVjaFViQWMxYU1jNWJNZUZkTWdOZ1djUWdVYVlnSmdEYk1iMmZNYlFjNGhDYkRkeGNzZXpiT2NRZDBlMmNQYkNlZ2ZSZ0doRmVaZVlnTGNrZ29hRGdMZWxlZGVTY0tnUWNZYzFjVWJnZ0VkcGVVZXdna2FXZkJjbGZZYW5iTmJCZGRmVGhLYnpmUWNRZE1mUmZZaE1iVmd5ZzhnZ2RVYkZia2RnZVZjU2ZBZW5oSmR6aEVmVGVMYmhkd2RHYVdjMWJ3ZFRmRWR6Y0ljcWNQZUNoSWdMZEtod2IxYU9iRmJGYUVnaWNEY1RmQWYzZ0ZjQWhOZ1RkT2ZUY0JkVGhEYVZna2VGaEdhQ2JRaHpjTmNqY0VjT2NBZmdmOGViaE1oemZrY05oTmJqYndlb2ZFY1JhaGVXY1dlQ2M1ZEtlQWN5ZTViWGNVZWlla2JHYU5jVmJJYkJjS2FWZ01iSmVGYWdmWmhXZkpiemRRZlhiVWJ5ZXNhMGdFYkRnRWVXYkRlRmdjYXZiSWVGZkJnWmZJZUZiVWRnY0pheWVjZXhmRWN5aDRnY2RCY2xndGFjYkVjeGRNYXllS2dqaHdhaWFDZXlmc2VOZlRjaGNSZFJjSWRnZjBld2ZOYnhiUWFEYlVnemFrZXdhVWR3YzFiWmRCZ1JkZ2FraE1oemNZZHhmRGhnYkllUGVHaHpoTWM1aERjVGRZZThnS2hCZEVlWWVWZWxmZ2d1ZlNnZ2ZNZnVoVmUxYklkcGdCYWpoVmdTY0FhU2ZsZFRiQ2hSaFlnR2hWYmlkY2QwZkZoMWRNY3JmTmFCYUFleGJGZGdneGZYZUxmeWRCZ1FjV2NTZkJiVmNJYUNkY2RuZ01nUmhNYnViSGhBZ1phYmVYZkJiTWhUaE1jaWdvZzhmSWFnZnNkcmNEYVVmNGJVZlVlU2hJZ05oTWJEYWNiVWVBYzFoTWc1Yk1kRmNNZE5kV2NRY1VmWWdKY0RkTWEyYk1lUWY0YUNhRGJ4aHNjemhPZ1FjMGUyY1BiQ2dnY1JhR2NGaFpnWWdMYmthb2VEYkxkbGVkZlNlS2RRZ1loMWRVZ2dhRWJwZ1Vmd2hrZ1djQmRsZllibmJOZEJoZGJUYktnemNRZ1FjTWVSYllnTWFWZ3lmOGhnaFVhRmVrYmdmVmZTZUFnbmFKZXpmRWJUYUxhaGh3Z0dkV2UxZndmVGJFYnpoSWdxZFBmQ2ZJZUxiS2Z3ZTFnT2hGZEZoRWdpaERmVGNBaDNnRmVBZk5kVGNPY1RjQmFUZURlVmhrYUZjR2RDY1FoemVOaGpnRWNPZ0FlZ2I4Z2JkTWd6ZGtlTmZOaGphd2hvZkVnUmVoYVdlV2ZDYTVmS2ZBZXloNWNYZFVoaWRraEdlTmNWZUljQmhLY1ZmTWRKZkZiZ2NaZ1dhSmR6ZFFlWGZVZXlkc2QwZ0VlRGNFYldhRGdGZWNmdmdJZEZjQmZaY0lnRmZVY2dmSmV5ZWNjeGZFaHlnNGJjZkJmbGV0ZGNkRWF4ZU1heWJLZGpjd2hpZ0NjeWhzZk5lVGFoaFJiUmdJaGdnMGd3Zk5oeGVRZERkVWN6Y2thd2FVZ3dmMWRaZkJmUmFnY2tmTWF6Z1loeGdEZmdjSWRQZEdnemFNZTVkRGFUZ1llOGhLYkJnRWZZYlZobGdnY3VjU2JnYk1jdWNWZjFiSWJwaEJoamFWYlNkQWZTYWxnVGFDZ1JiWWJHZ1ZoaWFjaDBhRmUxY01jcmROZEJmQWJ4ZEZiZ2N4ZVhkTGV5Z0JkUWZXYVNlQmFWYUlmQ2NjaG5kTWdSY01odWJIY0FhWmViZlhoQmhNZlRoTWdpYW9oOGdJZGdhc2dyZERhVWE0Z1VoVWNTYklnTmhNY0RhY2VVYUFjMWFNaDVmTWVGYk1kTmFXZlFoVWhZY0poRGVNZzJmTWFRZTRhQ2NEZnhlc2F6aE9oUWUwZjJnUGRDYWdnUmhHaEZnWmRZYkxla2FvY0RhTGVsZmRoU2VLZVFiWWQxZVVjZ2dFYXBlVWd3Z2tjV2VCYWxnWWNuZk5nQmVkZFRoS2J6ZFFiUWhNYVJkWWZNZ1ZmeWQ4ZmdkVWZGZmtjZ2FWZVNoQWFuZEpiemFFaFRhTGFoZHdkR2FXZDFnd2RUZ0VkemhJZnFmUGJDZklnTGdLYXdoMWRPZUZmRmFFY2lnRGRUZEFmM2FGYUFoTmFUYU9oVGhCZFRmRGFWZmtiRmNHYkNoUWV6aE5kamRFY09oQWJnZDhhYmVNZnpia2VOZE5hamR3Zm9jRWhSZWhlV2VXY0NjNWRLaEFmeWY1ZVhjVWFpZGtmR2ZOY1ZlSWZCYUthVmZNYkpjRmNnYlpkV2FKYnpmUWRYY1VleWJzZzBnRWFEZEVjV2REZUZlY2V2YUlhRmJCZ1pkSWhGYVVjZ2FKZHlnY2F4ZUVheWU0Y2NnQmRsYXRmY2NFY3hlTWh5Y0toamR3ZGlhQ2J5Z3NjTmRUZWhlUmNSY0lmZ2IwYndhTmd4aFFjRGhVYXpoa2Z3ZFVkd2gxY1phQmdSZmdka2JNZnpiWWd4Z0RlZ2dJZlBhR2V6Zk1iNWNEYVRlWWY4ZUtmQmRFY1llVmFsYWdmdWZTZGdjTWR1YlZmMWFJYXBhQmhqZlZoU2VBaFNkbGVUYUNnUmdZZUdkVmVpYmNmMGJGZjFjTWRyZk5lQmRBZnhoRmNnaHhjWGRMaHloQmJRaFdmU2JCYVZkSWdDY2NjbmVNYlJiTWV1Y0hmQWVaZGJlWGVCYk1kVGVNZGlnb2Q4ZElhZ2JzZ3JoRGNVYTRnVWRVZFNoSWVOZ01mRGVjaFVjQWYxZk1jNWRNZkZmTWROYldiUWFVZ1loSmNEYU1mMmNNZ1FkNGRDYkRmeGJzY3plT2dRaDBoMmVQZ0NmZ2NSaEdjRmJaYlloTGFrZm9kRGRMZWxnZGhTZUthUWFZYzFiVWNnZkVncGRVZHdna2JXYkJlbGNZZ25oTmFCZGRmVGRLZ3phUWZRYU1jUmRZZ01lVmR5YjhmZ2FVZUZna2ZnaFZkU2JBYW5hSmV6YkVjVGhMZGhjd2NHYVdhMWF3YlRlRWN6Z0locWRQaENhSWJMZktid2IxZU9kRmVGZUVnaWREZlRkQWczZ0ZlQWROYVRnT2JUZkJhVGVEYlZja2RGZkdoQ2NRZnpnTmFqZkVhT2ZBZGdhOGJiZk1jemFrZU5mTmhqZndhb2dFZ1JoaGFXZ1dnQ2E1aEtkQWJ5ZjVkWGNVYmlka2dHaE5kVmVJYkJoS2NWZE1jSmFGYWdlWmVXaEplemZRaFhjVWV5ZXNoMGVFaERmRWdXaERmRmdjZXZoSWhGYUJmWmhJaEZiVWNnY0poeWRjZ3hkRWV5aDRkY2dCZmxkdGNjYUVmeGJNZHlmS2hqZHdjaWRDZXlnc2dOZVRhaGFSYVJjSWZnZjBnd2FOZnhnUWFEZVVkemNrYXdhVWN3ZTFoWmNCZ1JiZ2JrZ01iemNZYnhlRGdnZklhUGhHZHplTWY1ZURhVGhZZjhnS2RCaEVoWWRWZmxmZ2R1aFNiZ2dNYnViVmgxYUlicGdCZGpnVmVTZ0FlU2hsZVRiQ2JSZFlhR2dWYWllY2gwaEZjMWNNZnJoTmdCZ0FoeGRGZGdleGJYaExmeWVCY1FiV2JTZEJiVmNJZ0NmY2duZE1oUmhNZnVkSGNBZlpoYmNYYUJnTWZUZ01haWVvYjhjSWhnZHNlcmdEYlVmNGdVZVVhU2VJYU5lTWFEYWNnVWNBZTFoTWY1aE1iRmJNY05jV2RRYlVmWWRKYkRjTWgyZk1jUWY0ZUNnRGJ4ZXNhemJPYVFiMGUyZlBhQ2ZnaFJlR2JGaFphWWNMYWtlb2JEZUxmbGdkZlNkS2dRZllkMWFVZGdmRWNwZFVjd2RrZ1dlQmhsaFlibmhOZUJlZGJUZUtkemRRZVFkTWRSaFlkTWdWZnlnOGhnZVVlRmFrYmdkVmhTZ0FhbmNKZHpmRWRUaExjaGN3YkdiV2QxZ3dkVGhFZXphSWVxZVBhQ2VJZExlS2J3YTFlT2dGYUZiRWNpZkRlVGFBZDNoRmNBY05nVGhPaFRkQmRUYkRjVmRrYUZhR2RDYVFoemROZGpnRWVPaEFmZ2Q4Z2JiTWR6ZmthTmJOZGpjd2NvZEVhUmRoYldiV2hDYjViS2VBYXlkNWFYY1VkaWFrZkdjTmdWZkloQmJLZ1ZmTWhKYUZiZ2ZaZFdiSmV6ZVFoWGJVZ3lmc2YwaEViRGNFZ1dlRGhGY2NhdmhJZ0ZhQmRaaElmRmhVZmdhSmd5Z2NneGVFYnlkNGJjZUJjbGd0YmNhRWh4YU1jeWZLY2pod2RpaENleWZzYk5jVGhoYlJhUmdJZWdlMGN3ZU5ieGVRaERnVWN6Ymtjd2ZVYndjMWNaYUJhUmFnY2tkTWR6Y1ljeGVEZmdmSWJQYkdnemNNZzVjRGJUZVljOGNLZUJhRWFZYVZhbGVnZHVhU2FnaE1ndWdWYTFmSWJwaEJlamdWYlNkQWhTY2xiVGdDZFJnWWhHZ1ZnaWVjZjBoRmcxZk1ncmROZUJiQWR4Y0ZoZ2d4YVhjTGJ5YUJnUWRXZlNmQmNWZEljQ2ZjYm5iTWdSZ01idWhIY0FoWmhiYlhjQmRNZlRoTWhpYm9hOGFJaGdjc2FyZ0RiVWQ0aFViVWJTZ0liTmJNZERlY2FVZ0FmMWFNYTVjTWFGYU1iTmNXZ1FlVWhZZkpjRGNNYzJlTWVRYTRlQ2NEZHhmc2d6Z09iUWYwZTJjUGNDYmdoUmFHYkZkWmNZYkxma2NvZURjTGdsY2RjU2NLZlFhWWExY1ViZ2dFZXBlVWN3YmthV2dCYWxnWWFuZU5jQmRkZ1RoS2R6ZVFnUWVNaFJkWWJNYVZkeWM4ZGdjVWNGZWtkZ2ZWYVNlQWNuZUpnemVFZVRoTGhoZHdlR2dXZTFld2RUYkVlemZJZnFjUGdDaEloTGRLZ3dmMWhPYkZiRmRFYmllRGFUY0FhM2dGZEFjTmhUZk9kVGJCZ1RiRGhWZmtkRmJHaENlUWN6YU5iamZFYk9oQWJnYzhhYmhNZXpja2VOZU5oamZ3Z29hRWNSZGhhV2NXaENoNWhLaEFkeWc1aFhoVWNpZmtiR2ROZVZkSWdCZktjVmNNZEpmRmVnZlplV2dKZHpiUWZYZ1VjeWRzYjBiRWZEYUVlV2REZEZoY2N2aEliRmJCYVpiSWJGYlVlZ2hKZ3loY2N4ZEVjeWE0YmNnQmVsaHRkY2ZFY3hmTWh5Z0tmamR3Z2llQ2Z5ZnNjTmVUY2hlUmZSaEllZ2MwZHdnTmF4Y1FkRGdVZHpia2F3Z1Vjd2gxYVpiQmZSY2dla2NNZ3pmWWR4YkRoZ2hJZVBoR2V6Zk1iNWNEaFRnWWE4YkthQmVFYVliVmZsYmdhdWZTaGdiTWF1aFZiMWNJY3BiQmdqZ1ZiU2VBYVNibGFUZUNjUmdZaEdlVmRpaGNjMGdGYjFkTWdyZE5lQmVBZnhnRmhnYnhjWGJMZXlmQmRRY1doU2NCZlZkSWVDY2NlbmVNZVJhTWN1Y0hiQWRaZmJmWGJCZk1iVGhNYmlmb2M4aElkZ2VzZHJlRGNVYjRjVWdVYlNhSWNOZE1mRGNjYlVjQWgxZE1lNWFNY0ZnTWJOZFdlUWVVY1liSmZEZ01jMmFNaFFoNGNDZURheGJzZHpjT2RRYzBjMmVQZENmZ2JSaEdkRmdaY1lnTGVrZ29hRGJMaGxjZGZTYUtjUWVZYjFlVWNnZ0VlcGdVY3dka2VXaEJlbGRZaG5mTmFCYWRmVGNLZHpoUWNRZ01jUmRZZU1jVmd5ZDhoZ2VVYkZla2NnZlZiU2ZBY25nSmN6aEVmVGJMZGhid2ZHZ1dlMWZ3Z1RnRWF6ZEljcWhQZkNhSWRMZkthd2UxaE9iRmJGYUVlaWdEZlRmQWgzYkZkQWhOaFRoT2dUY0JmVGVEYlZha2JGZkdlQ2hRYnpkTmZqaEViT2hBZWdkOGRiZ01lemdraE5nTmJqYndob2ZFZFJmaGRXZ1dnQ2E1aEtnQWd5ZzVlWGhVYWloa2JHY05iVmFJZ0JiS2NWZU1oSmJGYWdhWmVXZUpkemRRZFhmVWZ5YXNhMGFFY0RhRWZXaERnRmhjZnZmSWNGZUJnWmNJaEZkVWZnZ0pjeWJjYnhkRWN5aDRoY2dCYmxldGZjZEVneGJNZ3lhS2FqYXdhaWZDZXlnc2dOZ1RnaGRSY1JhSWRnYTBkd2VOZnhhUWhEaFViemdrZXdoVWJ3YjFjWmJCY1JlZ2JrZU1oemZZZXhlRGFnZklkUGdHZHpnTWI1Y0RlVGJZYThmS2FCZkVkWWZWYmxkZ2J1ZlNiZ2JNZHVlVmMxZUlmcGVCZ2poVmhTZkFiU2ZsZFRiQ2JSY1lmR2VWZ2loY2cwZEZjMWdNYXJmTmVCZEFkeGVGZGdjeGhYZkxmeWhCZlFmV2dTaEJkVmFJZkNnY2huZU1hUmVNZHVhSGRBZlpiYmFYZ0JoTWJUZk1jaWRvZzhmSWNnYnNmcmdEZ1VhNGVVaFVnU2hJYU5nTWJEZWNlVWNBYTFoTWI1Z01mRmVNZk5iV2JRZ1VkWWhKaERmTWUyZU1hUWg0YkNhRGV4YnNmemVPZFFjMGgyYlBhQ2RnZ1JnR2ZGYlphWWVMZWtjb2ZEZkxibGdkZVNjS2dRYVlhMWZVaGdiRWZwYlVld2drY1dnQmRsYllobmNOZ0JjZGVUYUtjemdRZlFmTWFSYVljTWFWZXloOGZnaFViRmhrZGdnVmdTZ0FibmRKaHphRWhUYUxiaGh3YkdiV2MxYXdmVGhFZnpjSWZxaFBlQ2dJZkxkS2R3ZjFiT2ZGaEZhRWVpaERmVGdBYzNjRmJBY05nVGhPaFRlQmRUYURmVmdraEZjR2hDYVFiemJOYWpiRWdPZUFnZ2g4Y2JmTWJ6YWtlTmVOaGpnd2FvaEVnUmNoYldoV2VDYzVmS2RBYnlkNWJYZlVoaWNrY0dnTmJWZ0lhQmNLY1ZnTWdKZ0ZmZ2JaY1dhSmZ6YlFnWGZVaHlmc2QwZkVkRGJFZ1dmRGhGZ2NhdmdJYUZoQmdaZElnRmVVZ2dnSmF5aGNmeGRFZ3lkNGdjZ0JmbGV0YmNmRWd4Z01ieWJLZGpld2hpZkNmeWZzYU5oVGVoZFJlUmRJZWdoMGV3aE5jeGVRZERlVWJ6Ymtnd2FVZndnMWRaYUJoUmJnY2thTWF6Y1lieGdEaGdmSWVQZkdmemZNZDViRGFUZ1loOGFLaEJkRWVZZlZjbGNnZ3VmU2dnYU1ldWZWaDFjSWdwZkJoamhWZVNiQWVTZ2xlVGdDY1JnWWFHaFZkaWdjZTBkRmExZ01ncmJOYkJiQWZ4ZUZlZ2F4YVhoTGV5aEJlUWdXZlNhQmJWZklnQ2NjZm5oTWRSaE1kdWJIaEFiWmJiYlhlQmFNZVRnTWdpY29lOGJJZmdhc2FyZ0RjVWc0ZlVmVWNTZklkTmhNZkRjY2ZVYkFhMWdNaDVkTWJGZk1oTmZXYVFlVWhZYkpnRGRNaDJjTWFRYTRhQ2NEYXhhc2h6ZU9nUWgwYzJkUGNDZWdhUmhHZUZlWmFZYUxna2VvY0RiTGFsZ2RmU2RLYVFoWWYxYVVkZ2JFZnBnVWN3YWtoV2hCZWxlWWRuYU5hQmZkZlRlS2J6YVFhUWdNY1JmWWJNYVZjeWg4Z2djVWVGYmtnZ2JWZFNmQWZuZEplemhFYVRiTGRoYndjR2dXZDFid2NUaEVkemdJY3FlUGdDZElmTGJLZHdoMWZPZ0ZoRmdFaGlmRGVUaEFjM2RGZkFiTmNUY09hVGJCYlRhRGdWYWtkRmNHY0NkUWV6Yk5lamdFZE9hQWZnZDhnYmFNZ3pha2NOZ05iamJ3aG9oRWNSY2hiV2RXY0NkNWdLYkFheWg1YlhlVWVpY2toR2dOaFZnSWhCZEtjVmNNaEphRmRnYVpkV2RKY3pmUWFYY1VieWVzYjBoRWhEaEVnV2dEZ0ZhY2Z2YUlhRmVCYlpjSWZGaFVoZ2NKYXloY2R4ZEVleWc0YWNoQmZsZ3RiY2VFaHhlTWF5YUtmamJ3ZmliQ2R5ZnNiTmJUZ2hnUmdSZ0ljZ2EwZ3dmTmZ4YlFlRGJVZHpla2R3Y1Vld2cxaFplQmhSZGdia2RNZnpiWWF4YURoZ2JJYlBnR2J6Z01hNWZEZlRlWWE4YktmQmdFYlliVmFsaGdkdWRTYmdkTWF1ZFZmMWdJYnBiQmVqZ1ZnU2VBZVNlbGNUYkNkUmFZYUdkVmFpaGNjMGFGYTFkTWJyYk5oQmZBZnhlRmJnZ3hjWGZMYnliQmVRYVdoU2dCZFZkSWhDaGNjbmdNZlJlTWZ1YUhiQWhaZmJjWGRCZk1hVGFNYWllb2M4YUlkZ2JzYXJjRGdVYjRkVWJVZlNlSWROYk1nRGJjZVVhQWYxYk1lNWVNYkZiTWROYldnUWJVaFlkSmdEZ01lMmVNZlFiNGVDZkRmeGhzYnplT2ZRYzBmMmVQZENiZ2RSZkdmRmVaZVlnTGJrZm9kRGRMY2xkZGJTYUtkUWdZaDFkVWJnZkVhcGZVYndka2dXY0JibGFZY25jTmVCZGRhVGdLYXplUWdRZE1jUmZZaE1oVmN5ZzhlZ2FVY0Zma2JnYVZmU2ZBZW5iSmd6YkViVGZMZGhkd2RHZldoMWh3Z1RlRWZ6YUlkcWhQYkNiSWZMZktid2ExYU9iRmFGYkVnaWVEYVRjQWgzY0ZnQWVOZlRlT2RUaEJhVGZEZlZoa2NGY0dkQ2JRY3piTmZqYUVmT2ZBZWdjOGFiYU1hemhrY05jTmNqZ3djb2dFZlJhaGJXZVdhQ2Q1YUtkQWZ5ZzVlWGRVZWlha2VHYU5lVmVJZ0JhS2JWZU1lSmNGZ2doWmhXZkpiemJRZFhmVWF5Y3NlMGdFaERhRWRXZkRmRmZjZ3ZiSWZGZkJlWmFJY0ZiVWZnZEpieWZjY3hnRWh5ZzRiY2JCYWxldGFjZUVmeGVNYnlkS2ZqYXdkaWZDYnlmc2ZOaFRhaGVSY1JoSWZnaDBid2dOZ3hhUWFEYVVkemRrY3djVWN3YjFhWmdCZVJmZ2NrY01kemhZZXhhRGdnZkliUGdHYXpoTWg1ZERoVGdZaDhiS2dCZ0VnWWNWY2xnZ2h1YlNkZ2JNY3ViVmIxaElmcGhCZmpoVmVTaEFkU2dsZ1RmQ2NSZVloR2RWZWloY2gwY0ZhMWRNZXJiTmFCZEFkeGdGZmdmeGFYYUxkeWJCYlFmV2RTY0JkVmdJZ0NlY2JuZU1oUmdNY3VjSGFBaFpmYmhYZEJnTWVUaE1naWhvYjhiSWFnY3NmcmVEaFVmNGVVZ1VmU2VJYU5hTWJEaGNoVWRBZTFoTWY1Z01lRmJNaE5iV2FRYVViWWVKYURjTWQyZE1mUWM0aENnRGR4ZHNjemNPY1FoMGMyZlBjQ2FnZ1JoR2ZGaFpoWWRMaGtkb2hEZ0xlbGZkZFNoS2FRY1lnMWVVYmdhRWJwZ1Vkd2VrY1dlQmhsYVlibmhOYkJiZGRUYktmemFRZ1FjTWhSYVliTWVWYnlnOGFnZ1VlRmhrZmdhVmNTZEFjbmNKZ3pnRWZUZExjaGZ3YUdjV2UxZHdlVGdFYXpkSWNxZVBiQ2VJZExkS2N3aDFlT2VGYkZiRWdpZURkVGVBZDNhRmdBaE5iVGRPZlRiQmdUYkRnVmFraEZnR2ZDZFFjemROZGpjRWFPaEFjZ2U4aGJoTWd6Z2thTmVOYmphd2FvY0VjUmdoY1dmV2FDZDVhS2FBZXlkNWRYaFVjaWZrY0diTmFWaElhQmFLYVZhTWJKaEZnZ2haZldmSmZ6Z1FiWGFVaHlkc2IwYUVlRGJFY1dnRGhGaGNkdmJJaEZnQmFaY0ljRmJVZGdlSmd5ZmNleGFFYnllNGFjaEJibGR0ZWNmRWN4Zk1keWNLZWpid2NpZUNleWJzZE5nVGhoaFJnUmRJZGdkMGh3Y05ieGJRZkRiVWd6Y2tmd2NVZndoMWJaZ0JkUmFnYmthTWh6YVlmeGFEZ2dnSWZQaEdlemdNYjVmRGdUaFljOGVLZUJjRWNZYVZhbGNnZ3VhU2JnZ01kdWhWYjFoSWVwYkJmamZWY1NnQWhTZGxmVGdDZ1JoWWVHY1ZjaWhjZjBhRmExY01hcmJOY0JjQWN4ZEZjZ2d4YlhjTGR5Y0JkUWdXaFNnQmdWZkljQ2hjZW5nTWRSZ01idWFIYkFkWmNiYVhiQmFNZ1RhTWhpZG9kOGFJYmdjc2NyZkRnVWU0Z1VjVWNTZ0loTmFNYURhY2NVZEFnMWFNZjVoTWVGYk1oTmhXZVFjVWhZYkpiRGdNZzJlTWhRYTRhQ2FEZHhic2F6YU9iUWQwYjJmUGNDZmdmUmNHYUZkWmVZZUxma2JvYURkTGNsaGRjU2hLZFFkWWMxY1VnZ2ZFZHBlVWV3Z2tjV2FCY2xiWWhuZE5lQmJkaFRoS2F6ZFFkUWFNZ1JiWWRNYVZheWc4Y2djVWhGaGtjZ2FWZlNnQWduZkpoemhFZFRlTGdoZndlR2JXZDFhd2JUZ0ViemhJY3FlUGRDZUlhTGFLYXdlMWdPZEZiRmhFYWlhRGZUYkFmM2hGaEFkTmRUZU9kVGdCZlRlRGFWZWthRmhHZUNkUWV6YU5namNFYU9kQWhnYThnYmVNZHpja2ZOZ05iamR3Ym9hRWNSYmhlV2hXYUNlNWhLYUFjeWg1YVhoVWVpYWtiR2hOYVZmSWJCYkthVmFNZEplRmZnaFphV2dKZnplUWdYY1VheWVzYzBiRWZEZkVhV2JEaEZkY2Z2aEllRmdCaFpoSWRGZVVkZ2ZKaHliY2V4Z0VkeWg0Z2NhQmhsaHRjY2RFZXhoTWN5ZEtiamZ3YWllQ2V5Y3NoTmFUZWhhUmRSY0ljZ2YwaHdmTmV4YVFlRGRVY3pma2h3ZlVjd2UxaFpnQmNSZmdka2JNZHpiWWh4ZURjZ2dJZlBmR2V6aE1hNWhEYVRlWWc4Z0tiQmhFZVllVmNsYWdidWVTZGdkTWF1YlZhMWZJZHBmQmVqYVZhU2ZBY1NibGFUaENiUmJZYkdoVmZpYmNoMGFGZzFkTWVyZ05mQmVBaHhmRmNnZ3hmWGZMYXlmQmNRZFdhU2ZCZFZmSWhDZWNnbmJNZVJnTWF1YUhoQWFaYmJoWGFCZk1iVGRNY2lhb2Q4Y0ljZ2dzZnJnRGNVZzRnVWVVZVNmSWNOZE1kRGZjZFVnQWgxYU1jNWNNYUZmTWZOZVdlUWJVZVlkSmJEZU1nMmRNZVFiNGJDYkRkeGZzZXpmT2RRZDBkMmhQZUNmZ2JSZkdlRmVaaFloTGNrZ29hRGFMZmxlZGFTZUtmUWdZZzFmVWRnY0VjcGJVZHdja2FXZEJmbGRZY25iTmdCZ2RiVGhLYXpoUWhRZE1nUmJZZE1iVmV5ZjhmZ2NVZEZia2ZnYlZkU2VBZm5mSmh6YkViVGRMZWhld2hHY1dkMWR3YVRkRWJ6ZUlncWVQY0NnSWhMYkthd2ExZk9hRmZGZEVkaWFEZlRhQWQzYkZmQWdOYlRmT2JUY0JlVGFEZFZha2FGaEdkQ2hRY3pjTmhqZkVnT2RBYmdiOGFiYk1iemdrZ05lTmFqYndjb2JFYVJmaGNXZ1doQ2g1ZUtmQWV5YzVjWGZVZGlha2NHZU5lVmhJaEJlS2FWYU1hSmhGY2dkWmhXYUpnemRRaFhhVWZ5Y3NkMGZFaERlRWdXZERiRmFjZHZhSWVGZUJiWmRJYUZmVWdnZEpneWhjaHhjRWR5YzRlY2FCZ2xldGVjZEVheGFNZXlkS2ZqZndkaWhDZXljc2ROaFRkaGFSYlJlSWVnZTBjd2ZOZnhoUWhEZVVhemJrZXdoVWZ3YTFlWmNCY1JmZ2hrY01hemdZYnhhRGJnY0lmUGdHZnpmTWY1ZERkVGZZZDhlS2RCY0VnWWZWZ2xmZ2R1ZFNiZ2VNZXVhVmExY0llcGVCYWpjVmVTZEFkU2ZsZFRhQ2RSZVljR2hWYmlmY2MwZ0ZkMWJNZXJhTmFCaEFneGdGZWdheGRYZ0xkeWJCaFFjV2ZTZkJkVmdJZENnY2FuY01mUmZNYnVoSGJBYVphYmJYZEJoTWRUaE1kaWRvZThlSWJnY3NncmZEZVVkNGhVY1VoU2VJZE5kTWREYWNjVWJBZTFhTWI1ZE1lRmJNYk5iV2dRZVVoWWNKY0RlTWcyZk1kUWc0ZUNiRGF4Y3NkemJPZ1FhMGQyZlBiQ2NnY1JjR2JGYlpnWWJMZmthb2NEZExmbGNkYVNoS2RRYlloMWZVYWdkRWRwYVVid2JrZldlQmVsY1ljbmFOZUJmZGZUaEtjemFRYlFhTWJSZ1loTWJWZHloOGhnYVVnRmJrZ2dlVmJTY0FkbmZKZnpjRWJUZUxhaGh3ZkdmV2YxYndkVGNFZXpjSWZxaFBjQ2NJZ0xnS2d3YzFmT2FGZUZlRWRpZERhVGdBZzNkRmhBZE5lVGdPZlRkQmdUZkRhVmFrZkZmR2NDaFFmemNOY2pnRWVPYUFnZ2U4YWJjTWN6aGtiTmJOYWpjd2JvaEVoUmhoY1dnV2JDZjVlS2JBY3llNWhYaFVnaWNraEdiTmhWYkllQmhLY1ZlTWRKZEZmZ2ZaZFdjSmh6YVFlWGZVY3loc2gwZkVjRGdFaFdlRGZGZGNjdmhJZEZmQmFaZ0lkRmRVYmdlSmV5aGNoeGRFYnloNGdjYUJnbGV0Z2NoRWd4Y01oeWNLY2pid2FpZUNjeWhzYU5iVGhoY1JiUmhJaGdhMGV3aE5keGJRZERoVWV6Ymtod2RVZ3dhMWRaYUJnUmZnZ2tiTWd6ZllheGNEYWdkSWNQaEdkemVNYTVmRGRUZ1llOGRLYkJlRWFZZ1ZobGZnY3VoU2RnaE1hdWFWaDFmSWhwY0JlamdWZFNmQWRTZGxiVGJDZlJhWWJHZFZiaWNjaDBiRmgxaE1ocmFOZEJlQWd4ZkZjZ2F4ZlhjTGZ5Y0JoUWhXZFNhQmJWY0loQ2FjaG5kTWFSaE1ndWVIaEFiWmJiZFhnQmdNYVRnTWdpZ29oOGFJZGdic2NyaERoVWE0Y1ViVWFTZUllTmJNZkRoY2ZVZEFoMWVNZzViTWJGY01oTmJXZ1FnVWFZZUpiRGNNZDJoTWNRYjRoQ2JEaHhnc2N6Zk9lUWUwYjJlUGRDYWdkUmZHZUZlWmhZYUxka2FvYURjTGdsZ2RiU2dLZ1FoWWgxY1VmZ2dFZnBkVWN3aGtjV2VCZGxlWWZuYU5jQmNkZ1RiS2N6ZFFkUWNNZlJiWWJNaFZkeWc4ZWdoVWJGZ2thZ2RWZ1NmQWhuZkpnemRFaFRnTGdoZndhR2ZXaDFid2RUZkViemhJZHFiUGRDZkliTGRLYndkMWNPZUZlRmNFZ2llRGJUYkFhM2VGaEFjTmJUYU9kVGhCY1RhRGJWZmtnRmZHaENnUWV6Y05hamJFZE9mQWJnZjhmYmNNZXpka2NOZU5hamJ3Zm9jRWdSZmhmV2dXZ0NkNWJLaEFkeWI1YlhlVWdpY2toR2VOZ1ZhSWdCYUtkVmhNZEpiRmFnYlpjV2ZKZXpmUWdYZ1VjeWFzaDBnRWJEYkVoV2ZEY0ZjY2Z2ZkliRmhCZVpmSWFGZVVkZ2NKZXlhY2F4YUVheWc0YmNmQmZsYXRlY2NFZHhkTWZ5YUtjamR3ZGliQ2N5Y3NmTmZUZ2hnUmRSZkliZ2YwZndmTmh4ZlFmRGNVZXpha2N3YVVid2ExZVpiQmhSYmdoa2JNZnpnWWJ4ZkRjZ2dJaFBnR2F6ZU1iNWREYlRnWWE4ZktkQmZFZFlhVmFsZWdndWZTYWdnTWh1ZFZhMWRJYXBiQmFqaFZjU2hBZ1NibGhUYkNkUmhZZUdjVmJpZGNoMGZGZDFiTWdyY05kQmVBY3hkRmVnZ3hiWGhMZ3loQmJRYldlU2JCZVZkSWdDZmNlbmJNZlJjTWF1YkhlQWhaYmJjWGNCaE1oVGhNZGljb2c4Z0liZ2VzZ3JiRGNVZzRmVWdVYlNlSWJOZU1lRGZjZ1VjQWMxZU1hNWdNYkZkTWJOaFdlUWVVZFllSmJEYU1kMmFNY1FmNGFDYURkeGFzaHplT2VRYzBlMmdQZkNlZ2NSZ0dkRmdaZlljTGRrZm9lRGhMaGxlZGFTZkthUWZZZzFnVWhnZEVkcGJVYndka2ZXYUJjbGdZZ25iTmFCZGRkVGVLZXpoUWRRY01oUmFZZ01mVmZ5ZjhiZ2NVZkZja2FnZlZkU2RBZG5nSmJ6ZUViVGRMZWhjd2FHZVdjMWR3Y1RiRWJ6Y0lmcWZQZkNoSWNMaEthd2ExYU9mRmZGZUViaWREZFRiQWUzZkZhQWZOYVRmT2JUaEJhVGNEZFZoa2hGZ0dhQ2dRZ3piTmNqaEVlT2FBYmdjOGNiZE1hemdrYk5kTmdqZHdnb2hFY1JiaGFXZVdjQ2M1aEtkQWR5aDVjWGdVZGlla2hHZE5nVmZJZ0JoS2FWYk1jSmFGaGdiWmVXY0pmemVRZlhmVWN5YXNmMGdFZURiRWZXaERoRmNjZ3ZhSWVGZ0JjWmNJZUZnVWFnY0pmeWFjaHhoRWN5YjRmY2RCYWxmdGZjY0VkeGVNY3lmS2JqZ3doaWFDY3loc2hOZVRlaGVSZ1JlSWFnZjBnd2FOYXhkUWFEY1VhemNrZHdhVWF3ZjFjWmdCaFJiZ2hrYU1nemFZZHhiRGRnZEloUGFHZHplTWg1Y0RmVGdZYzhiS2NCYUVmWWVWYWxhZ2V1ZlNoZ2FNZHVnVmUxZUlmcGNCZWpnVmFTaEFiU2dsZlRhQ2dSY1ljR2ZWYWlmY2UwZUZlMWZNZ3JiTmdCZkFoeGNGZ2doeGJYYkxleWJCYlFlV2VTZkJiVmhJZkNiY2VuZk1oUmNNYXVkSGZBZlplYmZYZ0JoTWJUZE1kaWFvYzhmSWVnYnNhcmZEZlVmNGRVZVVoU2dJZk5nTWREYWNjVWZBaDFhTWg1Z01lRmFNaE5nV2JRYVVlWWZKaERmTWQyZE1kUWU0YUNlRGR4ZHNmemNPYVFmMGUyaFBhQ2hnYlJiR2VGZVpiWWVMaGtib2VEYUxobGZkZFNmS2hRZllhMWJVZGdkRWNwY1Vod2drYVdhQmJsZVlmbmNOZkJoZGVUZktkemhRaFFiTWVSYVljTWVWZnlkOGNnZVVnRmdrZ2doVmdTYkFkbmFKZ3poRWhUYkxiaGJ3Y0doV2gxZndhVGRFZHpmSWRxY1BnQ2hJZUxnS2J3ZzFlT2NGZkZjRWVpZERkVGdBZjNmRmdBZ05jVGNPYlRoQmhUaERkVmdrZkZoR2FDY1FhemROZGplRWdPYUFoZ2Y4Y2JjTWV6ZWtkTmhOY2pid2ZvYUVjUmRoZFdkV2RDZjViS2VBY3loNWVYZ1VmaWZrZ0dkTmJWZElhQmJLYlZmTWJKZUZkZ2FaaFdkSmF6ZlFiWGhVZ3lkc2gwZEVkRGRFZldmRGZGZWNndmRJYUZhQmVaZ0lnRmhVYmdjSmJ5YmNheGdFZXliNGhjYUJhbGR0ZWNmRWh4Yk1leWRLZmpod2RpYkNheWJzZE5nVGZoYlJhUmhJY2diMGV3Zk5ieGZRaERhVWZ6ZGthd2FVYXdmMWRaYkJhUmJnY2tkTWJ6ZVlleGdEZGdoSWVQZkdjemJNZDVnRGFUYllmOGRLZ0JoRWJZYVZibGRnYnViU2JnYU1kdWJWZDFnSWdwZUJhamNWZVNnQWJTaGxiVGRDZVJjWWNHZFZhaWZjZzBjRmIxYk1hcmJOaEJmQWF4ZkZoZ2J4ZVhlTGJ5Z0JmUWJXaFNnQmVWZklhQ2RjZW5jTWRSYU1mdWVIZEFjWmdiY1hhQmZNZVRnTWRpYm9iOGNJYmdlc2VyZERoVWU0YlVkVWNTZ0lnTmhNY0RkY2dVZkFkMWhNZDVkTWRGY01mTmJXaFFiVWRZaEpoRGdNYzJhTWJRYzRhQ2REYXhhc2d6YU9jUWEwYjJkUGFDaGdmUmNHYUZoWmdZY0xka2ZvaERmTGRsZmRkU2hLaFFoWWYxZ1VhZ2JFZXBhVWJ3YmtlV2VCZ2xoWWFuYU5oQmRkZFRmS2Z6Y1FlUWVNYVJnWWVNYVZmeWE4YWdmVWJGZmtkZ2dWYVNoQWZuZkpoemNFZFRnTGdoZndoR2RXZDFhd2dUY0VjemNJY3FnUGFDYkllTGJLZndkMWZPYUZlRmdFZ2ljRGdUYUFnM2VGZEFiTmdUaE9nVGRCZFRoRGFWZGtmRmRHYkNiUWV6Zk5hamRFYk9oQWZnZThmYmNNaHpma2FOZ05kamZ3ZW9kRWhSZWhnV2FXZENiNWVLaEFleWE1YVhiVWZpZGtnR2VOZFZlSWZCZUthVmFNZ0plRmdnaFpkV2JKZ3plUWhYZFVneWVzaDBlRWhEaEVjV2REZUZjY2N2YklhRmZCY1poSWdGY1VhZ2VKZnllY2V4YkVneWY0YmNmQmhsYXRkY2VFaHhmTWF5Z0toamZ3ZWlmQ2J5aHNiTmdUZmhnUmRSZklnZ2MwYXdmTmJ4YlFhRGZVYXpja2h3YVVld2QxZlpmQmJSaGdna2hNaHpiWWd4ZURhZ2FJYVBmR2N6Y01oNWJEaFRmWWU4Z0tlQmhFZ1lkVmdsaGdndWNTZGdoTWJ1aFZoMWZJZ3BnQmNqZlZjU2VBZFNlbGNUY0NmUmZZYUdoVmZpZ2NoMGVGYTFkTWFyZ05nQmhBZ3hiRmdnZHhlWGFMYnllQmVRZ1dnU2RCaFZiSWdDZ2NnbmNNZ1JnTWJ1YUhjQWdaYmJoWGRCZk1oVGNNYmlob2M4ZUlhZ2RzYnJjRGVVYzRoVWZVZ1NnSWhOYU1iRGdjYVViQWIxYk1iNWNNY0ZmTWhOZldiUWVVZ1liSmFEZU1oMmVNZ1FoNGNDZ0RheGRzYnpkT2FRYjBoMmVQYUNmZ2JSZ0diRmZaaFlnTGJrZ29iRGFMZ2xhZGJTZ0tiUWhZYTFhVWFnZkVhcGVVZ3doa2FXZUJkbGVZZ25iTmFCZmRoVGZLYnphUWdRYk1hUmNZZk1nVmF5YzhhZ2ZVaEZia2JnaFZoU2JBZm5kSmJ6ZUVnVGRMZ2hnd2VHaFdnMWZ3ZVRjRWZ6YUlkcWRQZ0NhSWhMY0tkd2QxZE9lRmhGYUViaWZEYVRhQWMzZ0ZmQWVOYVRiT2RUY0JlVGhEZVZna2NGZ0djQ2NRZ3pnTmZqZkViT2VBY2doOGNiYk1lemNrZk5oTmdqZXdnb2hFZlJoaGhXYldjQ2M1Y0tnQWh5ZDVhWGZVYWlma2FHY05mVmVJYkJoS2FWYk1jSmVGaGdjWmJXZUpjemhRZlhjVWZ5YXNiMGNFaERjRWNXZkRoRmNjaHZoSWdGY0JjWmdJYkZlVWRnaEpieWZjYXhiRWV5ZTRoY2ZCZGxndGhjYkVjeGRNaHllS2dqZ3djaWhDY3lmc2ROZ1RnaGJSZlJoSWZnYTBjd2NOZHhnUWFEZVVoemZrZ3dnVWN3aDFhWmNCY1JhZ2RrYU1hemhZZ3hmRGRnaElmUGJHYXpkTWg1ZURkVGNZYThhS2dCY0VnWWVWY2xlZ2h1ZVNoZ2VNZXVlVmgxZklkcGJCYmpiVmJTZUFkU2JsZFRnQ2ZSZllkR2RWZ2liY2YwZ0ZiMWZNZHJlTmFCYkFleGRGYmdmeGhYY0xkeWdCZ1FkV2ZTZkJkVmNJY0NlY2VuYk1oUmZNZnVoSGVBZFplYmRYZkJoTWVUZE1naWZvZThkSWVnZnNjcmNEY1VlNGVVaFVkU2NJZU5lTWdEZmNjVWNBYTFlTWE1Y01mRmRNZ05jV2VRYVVoWWFKZkRoTWUyZE1jUWg0Y0NhRGZ4ZHNiemNPZ1FjMGQyZ1BiQ2dnZ1JhR2RGY1piWWJMZ2tlb2REZExibGVkYVNlS2FRZFlkMWdVaGdlRWZwZVVkd2NrY1dmQmhsZVlnbmZOZkJkZGVUY0toemRRZFFhTWVSZ1ljTWRWZHliOGhnZ1VoRmNrY2doVmNTYUFjbmFKYXpoRWJUZkxlaGh3aEdlV2MxZndlVGNFY3pkSWhxY1BoQ2JJYUxlS2d3YzFmT2VGZUZkRWhpaERkVGJBZjNkRmhBZ05nVGFPY1RoQmZUaERiVmVraEZmR2VDZlFkemZOaGpiRWZPaEFkZ2E4YmJkTWh6YWtnTmVOZGphd2ZvZEVkUmJoZVdkV2JDZjVoS2FBYnlkNWFYYVVoaWNrZ0dmTmdWZUllQmVLY1ZkTWJKZkZoZ2ZaZFdiSmh6ZlFlWGFVZXloc2IwZEViRGVFZVdkRGhGYmNndmJJaEZkQmZaYkllRmVVY2dmSmh5YmNieGdFZ3ljNGRjZkJobGh0Y2NhRWZ4Yk1leWFLaGpod2VpZENleWZzZ05jVGdoZ1JjUmJJYWdjMGV3Y05keGhRZERiVWh6YWtld2VVaHdkMWJaYkJoUmFnYWtiTWR6YVlneGdEY2dkSWZQY0dhemZNaDVjRGVUYllnOGhLZ0JhRWFZYVZlbGNnZnVkU2RnZU1odWdWYjFjSWRwZEJjamZWZFNoQWZTZ2xoVGdDYVJkWWdHaFZhaWRjZTBoRmExZE1kcmNOaEJjQWV4Z0ZoZ2Z4Z1hhTGZ5ZUJjUWJXY1NhQmVWaElmQ2FjYm5jTWJSYk1odWNIZUFoWmZiZVhmQmFNZVRiTWdpYm9hOGJJYWdmc2dyZURlVWM0YlViVWhTZUloTmdNYURiY2hVY0FjMWVNYjViTWhGZE1hTmNXYVFnVWRZZkpnRGhNZzJhTWJRZTRoQ2VEY3hic2h6Y09nUWEwaDJiUGNDZWdjUmhHZ0ZoWmJZZ0xha2dvZERlTGNsZGRhU2VLaFFmWWcxZlVkZ2RFaHBkVWJ3ZGtiV2RCZGxlWWRuYU5mQmZkYVRmS2N6Y1FnUWJNYlJjWWZNY1ZjeWQ4YWdmVWVGZGtiZ2ZWZ1NkQWJuY0poemZFaFRiTGJoaHdnR2VXYTFhd2dUZEVnemNJZnFmUGRDZUlmTGdLZXdhMWhPYUZmRmVFY2lhRGhUZkFnM2hGaEFkTmVUZ09nVGJCaFRiRGRWYmtjRmNHZENjUWZ6Y05lamRFY09iQWFnYzhoYmRNYnpia2ROZk5kamV3ZW9lRWhSYmhnV2dXY0NkNWVLYUFkeWM1Z1hhVWNpZmtiR2FOZVZhSWdCYktnVmNNaEpoRmdnZlpjV2FKYnphUWJYYVVheWFzYTBmRWdEZEVmV2dEYkZlY2R2aElkRmVCYlpmSWdGaFVhZ2VKYnlmY2J4YkVkeWg0ZGNnQmJsY3RhY2ZFaHhkTWJ5YUtlamN3YmljQ2d5ZnNmTmVUaGhhUmFSaEliZ2IwZ3djTmN4Z1FkRGRVZ3pna2J3ZlVnd2QxaFphQmVSYmdka2NNZHplWWF4ZURmZ2JJZlBnR2Z6Zk1iNWFEY1RiWWY4ZUthQmRFZ1loVmRsYmdndWhTaGdlTWd1ZVZjMWhJZ3BiQmdqYlZjU2FBYlNibGdUYUNhUmJZYUdhVmhpZmNjMGZGaDFiTWFyYk5oQmhBYXhiRmdnZXhjWGNMZHljQmRRYldhU2NCZlZjSWFDZGNjbmhNZ1JhTWZ1YkhmQWdaZGJoWGhCZU1lVGVNYmljb2Y4ZklhZ2VzYXJkRGJVaDRoVWhVZVNkSWROZE1iRGJjYlVnQWIxZU1kNWFNY0ZnTWJOZVdkUWdVaFlhSmNEYk1nMmFNZFFlNGRDaERkeGNzYnpkT2RRZTBhMmdQaENhZ2JSZkdkRmhaZ1ljTGhrYm9kRGdMZmxjZGNTaEtmUWdZZDFnVWZnY0VocGNVaHdja2JXZkJkbGFZY25lTmNCZmRiVGRLZ3pjUWZRaE1lUmZZZU1oVmV5YThnZ2ZVZ0Zja2JnYlZhU2hBYm5hSmJ6YkVhVGNMYWhhd2hHZldiMWJ3aFRjRWR6ZUllcWVQZUNjSWdMZktmd2gxYU9hRmNGZUVlaWVEZFRkQWQzYkZoQWVOZ1RjT2FUZ0JiVGJEY1Zka2hGZkdjQ2hRZHplTmJqYUVhT2RBZGdkOGdiYk1hemhraE5oTmZqYXdmb2NFZlJmaGFXYldkQ2I1aEtoQWd5YjVoWGRVZGlia2VHY05lVmRJaEJnS2VWYU1oSmJGaGdnWmhXaEpnemFRYVhmVWF5aHNoMGNFY0RjRWZXaERoRmRjaHZkSWRGZkJiWmNJaEZlVWJnYkpmeWJjaHhiRWN5ZzRlY2FCZmxhdGJjYUVoeGRNZnlhS2FqZndmaWdDZnlhc2ZOY1RlaGZSaFJnSWZnZDBld2NOZHhkUWVEZlViemVrYndnVWV3YzFjWmNCZVJoZ2drYk1memRZY3hmRGRnZElkUGZHZnpmTWE1ZERkVGVZZDhmS2RCZkVnWWVWYWxkZ2F1aFNnZ2RNZnVjVmExZklhcGRCZ2pkVmhTZ0FhU2hsZVRjQ2NSZ1liR2ZWaGlmY2EwZkZiMWJNZnJiTmZCYkFoeGZGZGdjeGNYaExoeWRCaFFnV2NTYUJkVmNJYkNmY2huZU1kUmdNaHVmSGRBZVpiYmJYYUJjTWZUYk1laWJvYjhjSWdnY3NmcmhEZVVkNGNVaFVjU2JJZk5oTWFEYWNmVWhBYTFoTWQ1ZE1kRmdNZE5jV2JRaFVoWWRKZ0RjTWQyZ01nUWQ0ZkNiRGF4Z3NmemFPYlFiMGUyZlBnQ2NnZlJlR2hGZFpjWWRMYmtib2JEZ0xibGFkYlNiS2VRZ1lhMWFVYWdkRWVwaFVmd2ZrZldhQmFsY1ljbmNOZUJjZGdUZ0tiemZRZlFmTWZSY1lkTWNWYnlkOGNnYlViRmNrY2djVmNTaEFkbmVKZXphRWhUZ0xmaGh3ZkdjV2QxZXdoVGdFYnpnSWhxY1BnQ2NJZUxiS2V3YjFoT2FGZEZiRWFpZkRiVGRBYTNjRmRBZU5lVGhPaFRhQmdUYURnVmRrZ0ZhR2NDaFFkemhOZGpkRWRPYUFoZ2U4aGJnTWN6aGtkTmROYmpid2FvaEVoUmZoZFdhV2hDYTViS2VBZHlmNWdYYlVmaWJrYkdhTmZWY0llQmZLZFZmTWVKZUZhZ2ZaYldiSmh6ZVFkWGhVYXlmc2gwZ0VhRGZFZ1dnRGVGZ2NkdmFJZEZoQmRaZklhRmhVZmdlSmV5ZmNkeGJFYnljNGJjZUJlbGF0ZGNlRWZ4Z01keWhLZWpmd2NpYkNieWdzZk5kVGJoZlJoUmVJY2djMGJ3Yk5neGZRZ0RnVWh6ZWtkd2ZVZXdlMWRaY0JjUmdnZ2tnTWh6aFloeGhEYmdnSWZQYUdlemVNZTVnRGNUZVlnOGdLZkJhRWZZZlZibGFnYXVjU2RnZU1jdWdWYzFlSWRwY0JjamZWZ1NoQWRTYWxlVGNDZVJnWWJHZ1ZjaWFjaDBhRmUxZE1ncmFOYkJlQWJ4aEZlZ2h4Z1hlTGJ5Z0JhUWhXZVNlQmJWZUloQ2JjaG5kTWZSZU1ldWVIZUFmWmJiZFhnQmZNZFRnTWJpY29jOGhJYWdoc2hyZkRmVWI0Y1ViVWdTZUlhTmVNZERlY2hVYkFhMWJNZzVhTWRGZk1jTmdXZFFnVWNZZ0pmRGNNZjJnTWVRZjRjQ2FEZ3hjc2Z6aE9kUWIwZzJhUGNDZWdjUmRHZ0ZoWmdZYUxha2RvYURnTGZsaGRnU2VLZFFhWWIxYVVnZ2hFY3BhVWZ3Y2tiV2VCZ2xoWWRuYU5hQmNkZ1RkS2h6Y1FnUWRNaFJkWWZNYlZoeWY4ZGdlVWdGaGthZ2FWZFNiQWhuZ0pnemFFZ1RmTGJoY3doR2NXYzFnd2JUZ0VlemJJaHFhUGhDZUlnTGFLY3doMWNPZkZkRmFFZmliRGFUZEFoM2JGY0FkTmVUYk9iVGRCY1RmRGRWY2thRmNHZENnUWF6Zk5iamFFZE9nQWFnZjhlYmdNY3pla2NOZU5lamN3YW9nRWdSZ2hnV2ZXaENhNWFLaEFjeWc1YlhnVWNpYWtnR2NOaFZkSWdCZ0tjVmVNYUpjRmFnZ1pnV2RKZHpiUWJYY1VkeWdzaDBmRWhEYkVkV2NEYUZlY2R2ZkloRmZCYlpnSWhGYlVjZ2FKZXliY2d4Z0VjeWg0ZGNjQmVsY3RiY2ZFYnhiTWZ5YktiamV3Z2llQ2V5YnNlTmVUZGhiUmFSYklkZ2cwZ3dhTmV4YlFlRGVVZnpka2d3ZFVod2ExYlpnQmhSZWdka2JNZnpoWWJ4Y0RkZ2NJZlBhR2R6Zk1hNWJEZ1RoWWg4Z0thQmZFYllnVmZsY2dodWdTZ2dlTWV1Z1ZhMWJJaHBmQmJqaFZkU2dBY1NibGZUZUNjUmhZaEdnVmRpYmNnMGNGYjFnTWVyZE5lQmNBZ3hhRmhnY3hnWGdMZXlnQmJRZVdiU2NCaFZhSWNDZWNjbmFNZVJmTWh1ZkhiQWZaZ2JiWGZCYU1kVGdNZGlkb2E4aElkZ2FzY3JlRGJVaDRkVWNVZVNjSWhOZU1lRGFjYlVmQWQxZk1nNWRNZEZiTWJOY1dnUWZVZlllSmNEaE1jMmZNYVFmNGNDYURjeGFzZnplT2RRZDBhMmZQZUNiZ2JSYUdiRmRaY1lmTGhrZW9jRGdMYWxnZGNTaEtiUWJZYzFkVWRnZEVicGdVaHdma2RXYUJhbGdZaG5nTmJCZ2RmVGhLYXpjUWFRYU1iUmRZZU1lVmF5YjhnZ2RVaEZna2ZnZVZoU2FBZ25iSmN6Y0ViVGhMYWhmd2ZHY1dlMWZ3Z1RiRWN6Y0lncWdQY0NjSWdMY0tod2UxZ09hRmRGZ0VkaWNEZFRhQWIzYkZmQWNOY1RjT2hUYkJlVGNEaFZoa2VGZUdkQ2ZRZHpjTmFqZUVlT2dBYmdiOGNiZE1oemVrYk5nTmJqZndhb2NFYVJiaGhXZ1diQ2E1ZktiQWR5ZzViWGVVZGlka2VHZU5nVmNJZUJnS2dWaE1mSmVGaGdiWmFXZ0piemFRZlhhVWF5aHNkMGZFYkRkRWhXaERnRmFjYXZkSWhGYkJoWmVJY0ZhVWJnYUpmeWdjY3hnRWd5ZDRlY2ZCaGxodGNjZUVieGhNYnllS2dqZXdhaWdDaHljc2FOaFRlaGhSZFJlSWFnZzBod2hOaHhmUWdEZFViemdrZndlVWV3YjFhWmNCYVJnZ2ZrY01jemNZYXhlRGVnYUlnUGZHaHpnTWM1Z0RjVGhZaDhhS2hCZEVjWWRWZmxiZ2Z1ZFNiZ2dNYnViVmUxY0lncGFCY2poVmhTZ0FjU2dsYVRlQ2NSaFlnR2JWY2lkY2QwZUZiMWRNZXJiTmdCYUFheGRGYmdheGJYY0xoeWhCZlFoV2JTZkJhVmhJZkNlY2VuYU1iUmFNYXViSGdBYlpiYmNYZEJnTWJUZ01kaWNvZzhlSWZnaHNhcmZEY1VhNGdVZ1VkU2dJZU5kTWdEaGNoVWZBZDFmTWY1ZU1iRmRNY05lV2RRZFVkWWJKYURhTWIyZU1iUWc0YkNiRGF4ZnNmemVPYVFjMGEyZlBjQ2FnYVJkR2hGY1plWWNMZmtmb2REYkxnbGhkZ1NjS2NRZ1llMWJVZmdjRWFwY1Vmd2drYldlQmFsZVlibmFOZkJoZGdUY0tmemFRY1FmTWdSaFlmTWNWZHlnOGRnYVVhRmhrZmdhVmFTZUFobmNKZXpkRWRUZExnaGJ3Z0djV2gxZ3dkVGRFY3phSWZxYlBlQ2ZJZExnS2h3ZTFnT2dGYkZjRWNpZkRjVGZBZDNlRmNBYU5oVGVPYlRkQmVUYURkVmRrZEZiR2RDZVFhemNOZGpjRWRPZkFlZ2M4ZGJnTWJ6ZWtkTmdOZWpkd2NvZEVlUmhoYVdkV2dDZDVkS2dBaHliNWRYZlVoaWJrZUdiTmhWYkllQmVLZFZlTWJKaEZoZ2ZaYVdnSmZ6ZlFkWGNVYnlic2MwZUVnRGNFYldjRGFGYmNmdmVJZkZkQmJaZEloRmZVaGdnSmR5aGNieGdFZ3loNGJjZ0JmbGR0YWNkRWd4Z01jeWRLYWpod2JpZ0NmeWFzYU5mVGFoaFJiUmJJZ2dmMGR3YU5meGhRZ0RjVWV6ZGtld2RVYXdlMWNaYkJlUmZnZ2toTWN6YVlheGREZ2dhSWRQY0dkemZNYzVnRGNUZ1loOGdLaEJoRWdZZ1ZnbGhnYXVhU2NnZk1odWZWZDFiSWJwY0JiamNWYlNkQWJTZGxkVGhDaFJhWWNHZFZmaWhjaDBjRmUxZ01icmZOaEJhQWR4Y0ZiZ2h4ZVhiTGZ5aEJlUWRXZVNnQmVWYklnQ2JjY25iTWZSZU1idWJIYUFnWmZiZVhoQmhNZVRiTWJpZm9jOGJJYmdlc2hyYURoVWU0aFVlVWJTZUloTmJNZkRjY2dVaEFkMWFNYjVnTWhGYk1lTmJXZlFhVWFZZUphRGZNYjJhTWRRZTRiQ2JEYXhkc2R6YU9oUWgwaDJiUGNDZGdoUmFHaEZlWmhZYkxha2hvZkRkTGhsZWRmU2FLY1FoWWgxYlVnZ2NFZXBkVWh3ZWtlV2hCYWxoWWduY05iQmNkaFRkS2R6ZlFmUWJNYlJiWWdNZFZjeWY4ZWdhVWRGY2tlZ2hWY1NoQWVuY0pmemhFYlRjTGZoaHdhR2dXYzFjd2NUZ0VkemdJYnFhUGFDZ0liTGhLZXdhMWZPYkZmRmJFYmljRGdUZEFlM2ZGYkFiTmhUYU9jVGhCZ1RnRGhWY2tiRmVHaENjUWV6Y05mamFFZU9nQWRnZDhhYmFNYnpka2NOZE5kamV3Y29jRWNSYmhnV2ZXZ0NlNWJLZkFmeWY1Y1hjVWhpYmtnR2FOY1ZkSWZCYUtjVmVNZUpoRmVnZFpjV2VKZHpkUWRYZVVneWhzZzBlRWVEY0VnV2REYUZnY2N2ZUloRmRCZ1plSWdGZFVhZ2JKYXlnY2N4Y0VleWc0ZWNmQmJsZHRlY2hFaHhoTWN5Z0tlamJ3Y2ljQ2F5aHNiTmVUaGhkUmhSZ0llZ2cwY3dhTmN4ZlFjRGZVZnpoa2F3ZlVnd2IxZVpkQmNSYmdla2ZNZnpiWWR4ZkRnZ2ZJYVBhR2R6ZU1iNWhEYlRjWWg4Y0tlQmdFaFlhVmFsZWdkdWVTYWdiTWJ1Y1ZiMWZJY3BkQmFqYVZmU2dBYlNobGNUaENmUmNZZkdhVmNpY2NoMGVGZDFlTWRyY05iQmhBYXhoRmFnYnhkWGVMYnljQmhRYVdhU2dCZVZiSWhDYWNibmJNZVJnTWV1Z0hjQWRaYWJlWGhCY01iVGVNY2lnb2g4ZEllZ2NzZXJhRGFVYTRhVWdVYVNiSWFOZ01jRGZjY1VhQWUxY01kNWNNaEZmTWVOaFdmUWZVY1loSmZEZk1oMmZNYlFmNGNDY0RleGJzZXpiT2JRYzBmMmdQZUNmZ2VSZ0dkRmVaYVlkTGhrZm9iRGNMZ2xhZGhTaEtjUWZZaDFhVWFnZUVncGRVZHdka2JXZUJobGVZZW5lTmVCYWRlVGFLZHphUWFRZ01mUmFZaE1lVmN5ZThkZ2VVZ0Zja2VnZlZhU2ZBZW5mSmZ6Y0VlVGNMYWhmd2RHZldlMWR3ZlRoRWJ6ZEllcWVQYUNnSWdMZEthd2gxYk9jRmhGaEVnaWZEZ1RlQWMzYUZnQWhOZ1RlT2FUaEJoVGVEaFZoa2VGZkdiQ2RRY3pmTmhqaEVhT2VBaGdjOGhiYk1hemVrZU5nTmFqY3dkb2VFZ1JmaGJXZFdjQ2Y1YkthQWd5ZzVlWGRVZmlma2hHZU5iVmJJZkJjS2VWZk1mSmNGYWdjWmZXZUpmemZRZlhoVWR5ZnNlMGZFY0RiRWhXY0RoRmNjZ3ZkSWVGZEJhWmNJYUZiVWNnZEpheWFjYnhkRWR5YzRlY2JCZWxodGFjYUVleGhNZHlhS2FqZndhaWdDY3ljc2hOZ1RkaGVSZ1JhSWRnYjBhd2FOYXhiUWZEZVVjemZrYXdiVWh3ZzFnWmRCZlJiZ2ZrYk1lemNZZXhhRGNnaEljUGNHZHpoTWE1YkRmVGJZZThnS2RCZkVkWWhWY2xmZ2h1ZVNmZ2VNY3VoVmQxYUlicGJCYWplVmZTZ0FkU2ZsZFRiQ2JSZlljR2dWaGllY2UwZUZjMWFNZ3JjTmdCY0FheGRGZGdoeGdYYUxieWdCZlFhV2NTYUJlVmZJY0NiY2duYk1iUmhNYXVoSGNBZlplYmZYYUJmTWVUYk1iaWJvYjhlSWZnZ3NhcmFEY1ViNGNVZFVlU2FJaE5jTWFEZWNoVWdBZDFhTWY1Yk1mRmNNY05hV2NRYlVjWWhKYURjTWIyaE1jUWE0Y0NoRGR4YnNlemdPZ1FjMGYyZVBkQ2NnZVJkR2FGZ1phWWdMYWthb2VEYkxobGNkYVNoS2FRZVlhMWdVYmdlRWVwZ1Vmd2ZrZFdjQmZsZVlobmdOZEJiZGhUYUtlemJRYlFoTWFSaFlmTWVWZXlmOGdnYVVhRmNraGdnVmNTaEFjbmFKZXpnRWhUZkxlaGN3aEdjV2QxZHdmVGNFZXplSWhxYlBnQ2dJaExnS2J3aDFjT2FGZEZnRWNpZERhVGRBYjNjRmhBYU5iVGhPaFRoQmVUaERiVmNrY0ZiR2JDaFFkemFOY2pkRWZPYUFiZ2I4aGJkTWV6ZmtlTmVOZGpld2FvZUVnUmJoZVdhV2FDYzVnS2JBYnlnNWdYZlVmaWNraEdmTmRWZEloQmNLZVZhTWVKZEZlZ2VaaFdiSmZ6ZlFmWGFVaHlmc2YwZUVhRGdFYVdiRGZGZWNldmFJY0ZlQmdaZUlkRmhVY2dhSmV5Y2NieGJFYXlmNGFjaEJmbGV0ZGNnRWV4Yk1meWRLY2pld2JpaENoeWJzZU5kVGFoaFJoUmJJZGdoMGJ3YU5leGVRYkRoVWN6ZWtnd2ZVYXdkMWRaZEJjUmFnaGtjTWJ6aFlneGZEZmdnSWhQaEdnemNNYjViRGFUZVljOGVLZEJkRWJZYlZkbGJnZXViU2hnZE1kdWNWYTFiSWNwZEJkamdWZFNnQWVTZ2xjVGVDZFJhWWJHaFZmaWRjZTBhRmQxYk1lcmROZEJhQWJ4ZUZiZ2N4Z1hiTGZ5ZkJlUWFXYlNnQmNWaElhQ2ZjZm5nTWZSZ01idWRIZEFoWmNiZ1hnQmNNZVRjTWJpYm9nOGZJaGdmc2dyZERoVWg0Y1VoVWVTZklkTmZNYURhY2dVY0FjMWJNYjVoTWNGY01kTmhXZFFjVWFZYkpiRGFNZDJhTWJRYTRmQ2FEZnhic2F6Y09nUWgwYTJoUGRDYmdlUmVHZUZnWmVZZkxia2NvZkRnTGdsZGRoU2NLYlFoWWIxZVVoZ2JFYXBlVWV3ZGtmV2JCaGxnWWVuZE5jQmVkZFRkS2d6ZVFmUWZNaFJiWWZNZFZieWI4ZGdiVWJGZWtmZ2VWaFNnQWVuZkphemZFZFRmTGFoZndnR2ZXYTFod2NUZUVlemhJZ3FkUGJDY0lnTGVLY3dnMWZPYUZmRmVFY2llRGNUZUFmM2hGYUFmTmRUZk9hVGJCYlRnRGVWZWthRmVHaENjUWR6ZU5jamFFYk9oQWJnYzhnYmRNaHpia2JOZ05jamh3aG9oRWJSZ2hoV2RXaENnNWVLaEFmeWE1aFhiVWVpYWtiR2NOZlZnSWdCYUtlVmdNaEplRmRnZVphV2JKYXplUWdYYlVneWdzZjBkRWVEaEVlV2JEZ0ZoY2F2Y0ljRmRCZ1plSWJGZ1VnZ2dKY3lhY2h4YUViMmMxZ0JkQWhGYUZjU2FGaHhmTWY0aEhmemVJZ3FhSGdtZ1FoMGNRY0FiSmFWaEtmZ2FrZWtlZGJrZDliQ2dVYWpjUWI1aFViQWFwZVVhTmR4Y0VlcmNJZFhlNGgvYkdnQWZZYkhhSGh5Z2RiamRZYlRoQWcyZEphaGFVZVlkWGdHZzBnZ2FRZWhoWmdoZVhia2dNYnFiQ2hUZ1pjQmRSZDNlVWdWYkVod2MxYWNiT2JrZHdkeGNHYlZnc2c1YUpkbGNFZmphR2NDZmRlUGNEZHllQmFZZVNmMmhZZEpiWmVpaFpjdWZlZGxoOWJGYVdia2QwY2RjZGNCZE5nU2VMaFNiUWV2Z1lod2hVZHJjSGFVZHBmU2RWZXlmc2dZZkloamJNYWNmUWhrZUVnd2VQYTBoRmNMZ1hoZ2JJaExmYmZuYkllN2NQY2diY2RVaFNmUWI0ZWliTmEwaHNmamdNY2lhQWRaaEhna2JNZURnUWZnZ3RmUGRSYlJjRWJaZGJoMWZaYjljRWUwZWNlQmVFZmdiVmJRZURjbGgwZzJiSWJCYk5lR2ZPZFRlY2RWYWVhWGIxYUtmSGZHZGxmemVHZEJoaGdtZllneWU0Y25kTmJUY1VoRGZLZWdjaGJIY1JnRmZJZ0FhQWRIZVFmN2FOY2lnSWJEYU9iVWZ0Z09jQWZGZlZlb2dUaERhOGFpZ1ZoUmZFYlZmTmVqYmxlR2FTZTBkOGJNZENiemNZZjZnY2hEZWtoY2hUZFdhTmJhZmZiMWZKYUxiZmVYZlVhcGVUZ0hoTWU2Y0ZobWVkZkRlRWFUZ3RhQmJRaEhoVmVJYmZlRmRRZ09hUGdGZTBkZGdFZGtkbGhUYktnVGQ5ZFpmUmNTYU1nM2ZBYXljVWVTYUNhUmdrY2piTWNoaHRnQWFQZmxmd2ZuYk5lU2hsY2FiVmNHaGNnY2VFZmxlTmhlZEFkUmhzZzdoSmhYZXBhcmNHYVdoWmNMZlhkVmVzY1FoUGgyYlpoMmFkYWdhWWZRYlFkRGIxZmNnRWdrZHNnWWJRZTBoWmFpYWVkamNjZzhkQmZ3aEVmSWRGZmdhRWV3Y0FkaWhSZzBmSmRnZWNhY2hYZWxkd2I2ZEJoVGNvYnRnUmNGZ1VmcGJEZjJnQWhCaFJnM2VVYlZoR2JsZWhoT2VIYmlhNWFrYlFmaGR4Y0FjY2FsZUZhM2hWZTFoQWRXY2FkeWhkZkRoVmhpZlZoQWdMZHlja2h2YWNobGZWZXlkUmQwZmRiSmNSY0FnVWFYZE9heWgxZTZnSmd3Zmdnc2dBZGtnRWhYYkVmR2VKZEtlZGNqZklhWGZCZEZod2YyZ01leGN3YktnVmRRaGRlemVZZW5oSmh3ZGNmRmJkYURjRGVSZjhiemhNY1FmVWJ5Z2NjaGZJYXFnVmhSZUJjTGRZZ1NlRmFGY2JieGFFZVRhZGNVYmRheGNYaEFhVWVpY1VmQWdzaEViUmdSZUJnN2diZDFhWmNCZU1keWJJZVVoT2JCaEZnS2ZVYnpoRWR4ZldkVWNvY3lnUmEwZXhobWVZaFhkQmFWZmNiRmVwY1BlV2FFZ1VhRmVIYlNnWWUvY0toV2MwaDFhRWZpZ01nUGVUYnhkQWQyYVJhSGQ5ZC9iZWRFY0lhVmRlYkhiWWJJYVNoeGZBY1hlVmZ4Z29nS2RHZkhjQmhWZFFneGZ0ZVNkZmdIY0ZnUWhYZlNhZGFnaFhhd2YxYllmVWREaHNlSGhSYlNkbGZFZVhjU2R3Y1RiT2FsYXdnSmRhYUJoMWRCZlVjQmF3YzZoWmRuY0loRWVVY0RmNGVuZUFiemhsY1hnUWdsYkFiOGZMZTFhVmhNZ0xlMWFzZW9hWmRtaGtia2ZYaEdoOGRCaGJkUmEwYmRmVmdWYklkeWJQZ2plUWRnZ0dnU2JNZUVoUWhWYUpjQ2FiY0FmbGgvZ2RnZ2JsYW9lRmNYZWhlMmVFZWtjc2NZZUNoaGQ5Z2liZWZqZWthTGVEY1RoNWFBZldiaWVjZTlnSGN5aEllb2RKaDFlY2ZRY2FmMWF3ZVZoQmJRZUFjM2JRZFZid2U5ZUVmeWdBYkllYmVXZGdlVmNTaEZoQmNIZEViRGVBaHpoQmhCY1VhbGJjYWtmeGUzaFhld2FOY3RhTGRCZ3diV2VCYVdkWmhQZFpmaWQ5YTdnY2RCYUJlamVXZ2dhc2NIZ0hmVmVSYkRoZWdHaHNnL2VPYXhiMGZsYUdjVmNzZUJoQ2JtZVFmWGhLYzNjWWZQZVNjd2c1ZFNoZGJoYUpoTGdHYUVjTmFaaE1kRGJjZ2tmSmhSYW9mTmhTY1FiNGdPaFBkVGNaYTVnT2JTZmdhYmZGY1JjaGdXZlpla2E0YmRoUGMxaDVkQmdPY3hhUmMvZ0Vjd2RoaGtlRmNRY2RlZWdBY2tnZ2YyZlBjUWVSaEJlT2ZYYzVmUmFKZlZmNWFHY0ZlbWdFYnVjR2VGYlJnbWdDaFdmWmFuYmNkWGFsaFpkYmV4ZFZiSmdXYkVlVWNGYUhkU2ZZZC9oS2FYZGhlbmJhYmtoc2NQaFVla2MxZU9oVGNIZlpoMmVVZmhmUmRVZkthbmZaZWJnU2V3Y1ZkRGhBYWpiOWFwaFdibmVCYUliUWIwYmtiSWdNYkNid2dlaEpjVGJSYXBnWGQzaE1iUWJHaFdhZ2NMYVJhV2U4YVpoUWVXY0VkS2VjZHdiNWVIZVBnQmR4ZEVlZWJraGNiUWdaZ25mSmJXZEZoV2NJY2dnWGh6YVJkWGNWaHhiWWRnYmFjQmJvY3lkWmVoaFJkbWZaYm1mRmV3Z1hkVGcxYVVhQWR4aDBkQWRWZFJhUWRoYkphVGdrYjNmQmFDZlVmRmREYTFjcGNFYWFmRWR3Zi9kZWRsZ0llSGZIYkhiZ2Z0aE9iRWZzYVloUWUxZGxjaWhjZW5iQmV3Ykdoa2gwZEdkVWNpZkZoMGJTZ3phNWR6YWFhUWZzZkZlT2RoZ2xlb2dDYzBlVmF2YUVjUmROZnZlUmQzZU5mOGhCZFNhSmJRZENod2dSZkpnVmFDZ01jMGhIZzFjc2Z2YkFmZ2FNYTRnQmV3YTllRWFQYlRmZ2RlZlRjR2VvYVVmTGcyYnBiaGdLYjNhOWZ2ZFdna2JjaGRhSGhWYlZoU2VkY0dodGM2ZFlmMGgwYXBiQmNFZ0VkVWdXZlNiTWVaY0poRGhjYlFmRGRsYUJiaWVkY2hkTmVhYkZkR2RsZ1piWWFuZ0phd2JjZEVhaGFEZ1NiVmdwZDFlZWFFZnNieWVOYURhd2ZhaEhiRWNKZFllS2hrZWNoQWRkZFJiRWFTZWZoMGZ0YlpiRWIwZGRib2FGYVViaGNRY1JieGdCZm1iY2FsZVlmVmJMYlRlY2NGZ2JoVmVjaFBkR2drYU5kaGNGY2hoaGNtZkZlR2NaZW1jWWdYZkJjVmNNYWxkTmVjY05heGgxaFZoVWRuYlJncmFlaGphNWhFaFpnbWhFZFBjVWVoZUJna2dUaEhkWmQrZkFhRWZ4aGJnZWZHY3NhU2hEYlVkMGJOZkdiamZZYTdhUGZ6ZDViSWVTZ3hmMWhUZmRoU2ROZWhjZGIzYXBocGRWZTFia2hRaEdjV2ZoZ2RnQmJEZTBhUmRXZW1lOWNhZFdnUmROaEhjYWNCZ1ZiSWJVYkVlY2NRZ1pmbmdJZENmRmFXZnhoMGRVYlNoTmNaZ05hV2NraHNhTWJuYnRmWGdJY2tlRWZxYUlkMGV0Y3dmVmVXZTliYWRSYXhlMGRkYlZlVmZKYzBoYWUzZnBiOGNUZ1Nkd2FlZ1FhUmdGYUVhTGZRZU1iNGJkZmxicGhMZEZnU2JOYmNmRWNrY3NoWWNRYjFmbGRpZGNkbmJCYndnU2dFZ05kSmFXYW5lVmM0Z1NneWdVZC9iUGdRYUlnTGRYZGhja2M4YmNkRWhjZXJjVmFGZVVjdWJFYWpmOWVIZVJmUmFVaE9jWWZsZEJlSGRFYkdlWmF5ZVZiaGJWYXFkY2JsZ0ZlM2VWZDBob2RXaE5jRWVzY1dkR2ZHZFlkVWRaaG1nWmVoZGNkRmdWYnZnV2JrY2NkSGFIZ1JlTWZIY09naWFnYXVhS2hnYUlla2VTY3diZGhiaEViRGI5ZG1hZGFuZVpkU2RRaGhlVmg0YmRjaGNKZ0xiR2dFYk5oWmRZZ25kSmR3ZGNiQmVvZ0doSGdRYThnbmVOZWtlc2RqYVloVWVOZFhoV2NSZEFkWmFhZUFndGJGYWJneGdFZFRjYmMwZ2RmemJFZXhhcGR6ZlBiMGhoZ1FmUmd4aEJhbWhjYWxnWWhWYU9iRGdjY0ZjSWFnYVVjRWhGZGpjdGF2YVVnaGhBYnZkR2ZHZ1pma2NJZ0hkSmRaY2JkeGhOZU9iRWFSYTBmY2dTZFZjNWVyZ2VnbWdOZ05nYWNrZnRoU2NXZ3hheGZPaFRkSGZaZDJnVWNrY0liVmZjZkNnUWhjZEJoQmVoZmVmV2FTZFFjbmdQZmpkTWhjZ0NiZ2FZaFVoZGRYaEFiZmFlYzNkb2E3ZlhibGFsYkxlTWIyaGdjTGNSZFdnOGNSYkVlMmU5Y0hlSWZWZlllVGZQYlVlY2NHaFVnQ2FoaFNoTGhEaGNoVmZRZFdoUWdpaEFlemRnaERkQmFVZUlhd2dNaFZkTWdXYkxlbGhVZzFmQ2FUYVljK2FKY1RiMGJWaEZlMWdoZ1BnQWRRYXRkNmVLZURic2R2ZkFlV2RJZ2ZmQWYxYkpoQ2diZlZmZGRjY2RlbGhKZUNjRmJYYWhhMmZUZDBiSWVVZ2FiVmhsZWljY2RuYUJmd2ZTZ0Vjc2JiZVZlQ2FWZjRmVmduZ2RjNGFhYTFjNWJWZk9iaGdsY29lQ2EwZFZhdmVFYVVhRmNuaFRheWNFZmRiRmFHYmdnSWJTZkVlSmVPZEdkVWh4Y3lhVmdoY1ZicWNlaDBjcGNkaFZoMGZwZkxlWWJHY2xmdGVNZG1nWWdVYVpkbWNZY25oSmZSYXNmc2REZGdkNWVTZFVnMWhWYmFiSWhHaGRnNmhNaFVnRmJxZUFnZ2JaZlNjU2IwaDViTWhkZ25oWmRTZFFkaGVWYTZoSWcwZEVhT2RHY0JlQWdOZk1jRGFzYXpiSmdFZHBkWWFZZjFlcGQxaGVoRWh0ZjNkZWFtZEVmUmFEZkZlNWRhYVBiRWdJZktnSWNSYkVkYmNPaDBjNWV6YlNlR2ExYm9oRmNVYmhoUWdSaHhlQmZtZ2NkaGRCY0FmSmJEYUVmRmJQYWhnZ2VFZEZnaWd4Z3BnSGh4Y2dkOWVQaG1lWmZtZFloWGVCZlZiYmgxY3BlSGdIZFJhMGZCYkFiQ2gxY3JhSWZVZWxhTmVhZGtmc2dQZ1VkaGNCZ2tiVGNIZFpjMmRVZmtnSmVEZE9mU2NRZlNiSGZ4ZmhnZWJXaFNhd2UzZEphM2NBYzljQ2dnY2NiT2diZFJia2RaZEpkVGhzZndhWGIwZ2dkWmRBZmtmSWZMZVJoV2E4YVJoRWIyYTliSGJjYXhnTmdIYWFoQmFVY2FmRmFSZE5mRmFOY0RneGRXY0hmVWFCZnlmVWRYaGRiWGRTZWhoWmNwZFllUmVZYlloWmJoZVJnbWRaY21ha2FrZVdmeGFBY2xoRmQwYjlnU2JBY1JoMGZMY0ZmSGFwaCtjVGVUZEZhaGdEaDFlSWhRZVpoRWd4ZTJhZGFsZkpnQ2dGY1hhaGcyaEVma2ZzZFloUWJ5Z1liZGJJY2lnSWIvYkhiQWN3ZjJmSmFXZTlkNGNQY2piNGIwZVBlVWg4ZDRkUWZrZXNlcGFVZmtoc2gvZFFiMWh3ZTdkQ2ZDZ2RlS2ZGaHlnMGhaaFlmbGRCYkhoRWVHZFpneWFWZ2hnVmdxYWNjbGdGZjNlVmgwZm9jV2VhZFdiRmFRaFZneWNrZ09lWmRpY0FlMGZQZ2hjWWc3YUVod2VoaFRlSGRWYjFkYmJkZ0RkQmJRaFlnMGMxYXFoU2Z3ZzlhU2VFZkdiUmNNYmRobmJaaFNkUWNoZ1ZhNGNkZGhjSmJMYVNnZ2JZZU5oTmV5Z0FnK2FjYUZjeGVSYlVnbmNCYzFlZWRFZHRjM2hlYm1jbGdYaFdmUmdBY1plYWRBYnRkRmdiZ3hmRWZUZE1ha2Z0ZlplRWUwZWRob2hGZlVjaGdRYVJneGNCYm1jY2dsYVloVmRhZm5oSWNNZGZlbGV0Y2djRmdtZmxhaGFGZmhhaGFtYUZmR2NaYW1iWWZYZEJnVmNiYzFjcGZUYURjeGMxZUloVGcyZGxmcmZMZm1kMGhMZUpiUWRRYUhnV2h4YUJhaWhTY2xneGIyYlVia2hJZ1ZhZWRIZFloU2RTZHhnaGVEaFdnV2VKYXloY2JIYUJlSWFRZFFmOGZQZ09iemVzZ2ZiUGJqaFVmbmdWZFZma2ZOZUJlR2VoZmZnSGVEYzlnVWJYYkNlbGZIZkpheGUwYlViUGFWaGNoSmhBZWhnVmZSZ1BhM2NKYlFjRWIwYkJieWFVZVhnZGhYZFNnaGVaYXBkWWNSYlliWWdaaGhjUmVtZlpnbWFGYXdjUmNXZjloSGJXYWdmQWdkZUFlVmR3Zm5iUGZqaGdkaWhIYnpmZ2FLaFZnbGNvYkJnYWNFZXhnbmVmYjFmd2RBaFRoQ2J3ZHpiZmVnaDVnV2RCZUFjMGRxYVdjSGZCZXdoU2NFaE5kSmRXZG5oVmQ0ZVNoM2RkZjZmYWdWaDViQ2ZPZ2hkbGNvYkNmMGJWaHZhRWVSYk5idmRSZTNoTmJPZ1JmeWd0aFVoSGZCZ01iUGFFYkdoNGVnaFhneGVVZHhhV2FGZEZhM2NWaDBmb2FXZGFlV2NFZldiR2hHYlloVWRaZWpiUWVrYkpmQWhBZDllRmJFZWNnY2JEYUVkNWg0Y2RhR2d0YTZiWWQwYTFocWdTZ3dkOWFTaEVoRGRsY21jZGFuaFphU2ZRYmhnVmI0Z2RnaGRJZ1dkTWNrYU5mWmhZaG5mSmV3aGNkRWVoY0RlRGd3YjhkN2dPaHhjOGgrZ05jU2ZkZlhhRmVoZ2doUWZhZ0ZlQmV2ZWJieGhFYlRkYmgwZGRoemJFZDBiZGJvY0ZkUmhvZlZoRWEwZFVnMGJQY0ZnWmJiYVpmQWFZY29oQmd6YkljdWhhZ1FoZ2NUYVpnSGRrZGZoYWh4ZlVjVGZFY1FoQWU2aEhiU2g1Y0hiQWRoaDFiSGZRZzJmQmM4Z2JnbmR0YWVkZmNGYThlWWRVaGdicGRrZ1hjV2RaYWhlUWdWaFVjQmRhZFdhNGdBZldlQWhOY3BjV2hXY0pjeWNjaEhmQmdJZlFiMGVrZkhkWGQzYWhnTGhkaDNjcGJwYVZoMWFrZ1FjWGF6YzFhRmJCaGpjdGVZZVhhQ2RGZEhmT2R4YnNmVGVaZ0JjVWhhYVdoVWRkY0xlVGhIYUpmV2RGZVdicGh5ZlVkWGFkYVhmU2NoZlljZ2NKYnhlWWdRZktlUmN4ZHZkWmFuZzFkd2ZCYzJlWmdhYkVlMWJWZVBjR2hnYVZiMGJKZ1RhOGcwZ1RjUmFnZktoUWhSZVZiVmVBZlJlNGFrZU9kUWVCYUtoRmd4Z0ViNGRSY0FkcGZVaENmaGgxYWliSmJpZGtiZ2NEYlFlZGFKaEdleWNjYXFjQ2JpZjVkNmZKZFJkSWFYZFZkMGEwZWdiQ2VVZHhmMGhPZHhjTmN2aFJmM2NNZ1RkUmQyYmdiVmJTYkZjQWZWZFZmVGJJYW5iQmFGY3RocWJlYm5ldGYzZVZkMGVvZFdmYWFXZEVlV2JHZ0dlWWJVYlpjbWNZYnZhZmhpZEVoV2JLZ2loSmI1Y1liamdRZWdlQmVnZG9oRGZIZURiNGFmY09hM2U4YjllWWNoY0JhbWhkY25nWmZTZlFjaGFWZjRoZGdoaEpjTGdHY0VkTmRaYVlobmdKZXZlY2NFZEJnTGNIZFZncGhvZWVlQWdVYXllTGRXZmtiaWNFaEZmNWNOaGNnR2NvZlhoUGVWaEJmS2NaaHhkVmc2ZUdna2V0YW9oSGRSaHhoZWhPaEdiOGEyZEloQmFsZEJmSmdRZjBhdWJkZzBlcGZLaFdiR2JjZXhnUmdGYWNheWFXYXpjSWEvYU1oVGFWYmNlWmFuZUJiSGFIYlJjMWNWYVVnbmJSY3JlZWJtaE5lTmJhaGtic2FQZVViZ2VwZWtnUmREY2dmamVIZWdiNGJWZVplV2ZzYVBjU2gwZ3hkRGNYZTJkUmN5aGVmQ2NSZklmWGNraGtlVWJNYkNnOWJMZk9lWGZJZDdmWGRsZkFnY2RHaFdmQmVmZ1NleWVOZFVjWGVTZWdnVGZPYnhhTmRhZ2FoRWFkY0JmV2NVYnNhNmRaaG5jSmZXZUZnV2NwYnlmVWhYZWRlWGJTYmhlWmRwaE5kVGJ3Z1lhWmdoZlJjbWhaYm1lRmh3ZVZnV2g5YWFlVGFnZllmM2FWZFZiSmgwY2FiM2VwZGplVGRXaG9iV2hKYlZjSWNRZlpoRWZ4ZjJiZGVsZUpjQ2hVY3ljMGQ0ZFVoUmg5YlJmRGJCZ2RjaWVQZkhiZ2drZlJlRWVNZmJiVmRuZlVheGRRaG5mY2hoZVFiMWJkZ1pkRWdCYmxjb2RDZzBoVmV2YUVoUmFNY21iQWNYZk1hYmVSYm1kQmViZlJoaWRRYytnWWJBZ01jV2hLZ1hoUWdZYUFlRGVBYk9mS2NEZWxlamVHZFJoRmQ1Z2FiaGdJYlVlT2VqYXBnaGJKaEJjMGVtYkNhVWRkYVViVWJ3YllkR2ZOYVNhVWU1ZUpoZ2VJZ3NlU2IwYUZnYmhHaFVlNWJNZWRnbmZaYVNoUWZoZFZiNGVkaGhjSmNMZkdhRWNNaExoSmV5Y1llbGRJaGdmWmdEYUJneGQ4ZGlmZWVBZ1ZmL2dMYW1lVmZYZ0NheGJ3ZFpiSWFRYkpjZWNSZVJlRWRUZGJjMGdkYnphRWEwZGRob2RGZlVnZ2ZaZUFjUmZCYnVjY2dCZ2hkQWZKYnplQWFVZkpkVmFWYUtmQ2gzYlJjaGJRY2tjRWIyaFVkU2hraGdnWWNTZ1JmY2NiZ3dlRmh0ZUhkUmYxYlZkVWJuaFJhcmJlaG1oTmROZGFna2VzY1BmR2IxaFpha2VSaEhhUWVsZUJhaGFCY2NhTmZqaEVlUWNTaHdjVmhlYVdnVGhZYXJkSWdEZ1VmSGRCZlVma2NJYWZjRmVKZExmZGgzZ3BkcGZWZjFia2RRaEdkV2JnYkxmUmNXYThnUmZFaHpjc2dQYklmVmF3YlFkYWRGZnNhTmhCZjBoZGcxYk5nQ2hBYlphUmgyZEplWWFVZ1hjZGZYZlNkaGhaZHBnWWdSZVllWWdaYWhlUmhtYVpjbWdGY3djVmJXYjBjemdBYlJhMWdZYUdleGhFZDdiTGh6Yk1ldGdDYm1hb2RDZ1hoRmFKYkRmTmJBZmthMWdQZXhmUWVMZVVhRGJ4ZjJjUmFnZk5lZGNEZFZha2gyYU9lamRWZXdkRGZnY29mYmRDYlNlRmQ0Z0NiaWdVZzlkUGRCZG9jY2NYaGtlMWVvY1JoaGZBZDhnUmZSZk1hdGVBYW5iTmZTYlJnemN0ZUJkR2JoYWtmSmFWYzJlUmJZaFZoaGhWZnFiY2VsZkZhM2VWYTBnb2hXYmFiV2JFZFdlR2dHaFlhZGRmZVVkeGhoYWNlRmVWZXZnV2FrZGNhZGVIZFZiVmdTZ2RjR2dzY29lSmhoYWtnL2JHaFVkRmVTYlZhbWh3YllmUGFqZDhiQmhUYWhlVWdzYmZkd2FsaGhlR2ZFaE5jWmJZZW5mSmN3Y2NhRWZoZERjU2RRZ2RkZmJlZUVjdGMzZGVlbWFsZFhmV2ZSYkFjWmNhYUZia2JBZk9lMGhSZEJkSWVVaGNkZ2RHYnhnTWVnZlhmQmd0YmNjUmEwYlJncWVjY2diUWNaZWFmamR0aFlkYmRIZTFlS2dGZ21obGJoYkZlaGFoZ21iRmZEYXRmTWRZY1hoQmZWZWJkMWVwY0hlSGNSaDBhVGJCZ3pob2NvY0xkaWNvZENnSmhFZHRnY2NXZ2tjUmZvY1RiQ2FSZTZkVWdnZXNnWmVlY0RnTWdiZVNkMGJOZnBiV2NXZkpleWhjYUhnQmNJZlFnMGVsZmFhZGNUZkVoTmNkYjNnSmZyZ0djUWd4ZGRkV2h5ZjFmWmRSYTJiOGhNaERkbWU4YVRjS2VrZU1oQ2ZKYjFjTmFJYkFla2Q0ZTZlWmduYUpmV2hGZVdkcGh5ZVVkWGJkZ1hlU2NoZVpocGJOYlZnNWdLY0toVWdOYm1oS2NDYVFnbmRWZ1Joc2hEZkZnMWNoZjRmQmF3YUFmN2ZPaFhoSmVrZFRlemF3ZEtnUWF3Y2RkVmNaaGtid2IzYUphQmRVaFhiV2REZDBjNGdSY2todGZWZEZhZ2VvYTJiY2hqZjRiL2RIY0VnTWJMZEhhM2hVZDVjU2J6YWthdmJKYkJmVWRjZFFjaGc1YWhiRWRHZzljdmVFZFJoTmV2Y1JoM2ZNaFRnUmcyZmdmVmJHYmhiVWVUaFJkVGVRYThhVmRoYmNkL2ZQZkJlVWV5Z0VjUWJOZlloTGhDZFViVWNHY0djY2NKZVplamZJZDRlSWRCYkFlZ2ZIaEViZGc4ZlRhd2djZ1RiTGRRZ2tmdmJKZFFmc2d2Z0dnUWY5ZlVoRmRtZVFiZWJkZ2pmOGhjZ0VkVWNFaDViT2NGZ0ViT2hWZ3dmVmVaY0FoeWdBaGlhTWVSZ0VjaGNIZUJkd2J6ZVBlUmdsZ2RnZWdtYmxhWGFXZlJoQWRaZmFmQWd0ZkZoYmh4Z0VlVGZjZUVjY2dqZEdneGJOYWtnRmhSYnBkY2NSYjFmbGNxZGNnaGhNY2NmUWNIZUpnUmZkZjFiZGdLZEZibWNsZmhhRmhoY2hkbWhGYkhieGhtaFlheWJNY0JjUGhSYU1nSmhXaGhlOWRWYlRhMmRsZnJkTGFqY29lZGRMYndmUmhKaFVna2VKaE9nVGFIY1pjMmVVZmtiSWhWZWVjSGJZZVNhU2J4YWhmRGZSZ21hSWUrZmViQ2dSaEVmUWZ4YnRnV2ZkZlRkRmJDaFhjWGZwYXBjVmUxZ2tiUWNHZldiZ2FMZlJiV2E4aFJmRWczYVZmSGZQaGhlc2NUYVpiQmFVZGFoV2VWZHdhNmVaZG5jSmdXY0ZhV2NwYXllVWRYZGNiS2ZZZEJnWmJwZlljUmJZYllhWmdoY1JnbWRJZkRlUWgrZkZkamVzaFRmQ2FGZk1jZGdGZkZjb2RnY1libmRvZzRnWmIyaHBhTGhEaDFmSWVRY1phRWJ4ZTJmZGRsZEloTGVVYjNnaGErYkVoQWJWZE5kRGZoaHNhbmJJZUhmSmR3ZFNlVmM1aEpiRGZpY3dib2REYWpmZ2Q4Y2FnUWZOYVFjT2RoZ2xob2ZDZjBjVmh2YkVmUmhOZHZlUmUzZk1nVGNSZnpkeGNkZ0diaGE4Y1FjRWZDYmdnM2JBYlJjVWhlYktod2JFaHloTWVoZWhoRWFKY2pjTWFlZkhhMmFSZUhjTGJ6ZXdha2djZ2xmVWN1Y0NjQWFCYUlkVWJCY0FhY2JJYkdic2EzYU5oaGc0ZCthU2UwaDBnWGJFYkNnVmVNZ09oQ2hNaGZkQWJGZ0FjcWRjZ1JmdGFRY01la2dOZlpoWWhuaEpkd2djY0VmaGhEZlNkVmhvaDhiUGhrY3RiL2JhYm1hbGZKZ1dhVWdRZlFlUWVnZ3RjRmhiYXhhRWhUY2JlMGRkZ3pjRWEwYWRlb2NGZFJid2RZY0ZoVmc4ZXhhY2doYmhmUWRQYlhmSWZqZ05maGhraE5jVWN3aHdmemRSZEZlY2cwYkhoR2VGY2tiTWJqY2tlUGZLZ2xlaGdIZVhhRWQ4YVNoQmN6ZGtldWNOZURnZGROY0pneGE1ZGNlQmNoZ0FhcWFBZXlnSmEyaEVlQWFjZ1ZhTmRqYk5jVmVDZmtod2hLZ0RneWJkaDFlZWVXaHRjaWZRZTBlbGVhZmRhWGJoZ0xiZGEzZm9mMGZmYVZia2NRYkdlV2JnZUxlUmVXYThmUmNWZVRib2dKZU1oRWhjY09mSmUxZnRhSWVCYVVjOWdFY2FibmZJY0VhR2hXY29oN2RYYVhlY2JTY1FjeGRZY3lmU2R4Y1llWWZaYmhkUmFtYlpkbWJGYndiVmVXYjhmSWdBZGtjbGhJZEJkeGF4ZDBlWWcxaEJhamdUZFdjcGdMZURiMWJJYVFnWmVFZnhmMmJkZWxhSWZEZUhjU2ZwZy9lSGhtZUVjWWRRZTFmbGhpZmNobmJCZndmU2VFZ05jSmFXYm5kVmFvYlNhMmhsZW5mYWhRZFZoemVFZUJibGFvYUNoMGRWYnZjRWJSZU5hdmJSZjNlTWZUaFJnMmFnZEtiU2JCZ2hhUGZSY0dhcGR5ZUJmQmR4aEFlY2dsYUZlM2FWYTBib2NXZmFjV2FFYVdjR2RHYVlhVWVaYW1iWmM3ZWNmQWhNaGdkRWR3Z01jZGJEaFZkVmhUZ2FoWGhaYzZkS2VtaGRncWNTZHdlOWhTZUVhR2hSZU1nZGZuaFpkU2hRaGhoVmQ0aGRkZ2ExaExjR2VoYkFnTmhNYURlc2MrZk5lMGJwYURiVmZFYmRlMWNMY0JkSWZuZlBoeWNZZlJkV2VWY1VoemFhYkFndGJGZGJneGdFZ1RlYmgwaGRlemNFYTBiZGJvY0ZnVWdoYlFlUmF3YzllbWVPZWxlNWdCZ1plbmJJZURmZmJsaGtiTWdYaHllVWF0Z0hnbGVGY3FjRmRDYU5idmRTYTNoQmZWZ2JnMWJwZ0hmSGZSaDFiVmRVYm5kUmZyZ2VhbWZOZ05lYWFrZXNlVmZVY2xiaGFzYkdiSGJwZzJkQWJFZXNkYmJQZ2pkOWZlZkJleGhBY0tlVWdFYmhmeWVjYkhlQmRJZFFmMGhsYWFjZGdYY2hlTGJkYTNhcGFwY1ZnMGhNYVFnVWJXYUJoZmZTYldlOWhEY0dka2VWaEhhY2J4Y05oSGNhZUJoVmFJY1ViRWJjaFFlYmUyaGxjOGVGZldkcGF5ZFVkWGZkZ1hlU2RoZ1lhMGhTZHhmWWJZY1phaGZSaG1jWmFtZEZld2dFZ3pib2ZVZ0JnRWVsaFVnR2doYXhhMGVMaFhiSWUzZFFlV2FvZFpnQmFsZ0pjTGFUYWtleGEyaGRmbGNKYkNiRmZYYmhhMmVFZWtjdGZSZ0JkVmRsZnFnZWZqYUZoNGRHZmtjcGNGY1dhbmQwZnNlU2IyaHBlNmhJZ1ZjOGZOZkhiQmRsYTRoQ2IxY3RhdmhRZXhmTmR3Z1JkMmFNZlRhWGNXZmdnRmRTY0FneGVIY1NoV2M0Z2dkWGV4YnhmamZmZGxjRmQyZkdlVWhSZWliRWFCYUZhemhmYUJkbGgxYkZkQmVRY0FkQ2VTYW9hY2ZMYXpoZGZ0aGNnaWRjY21kZmZXZ0piUWFZZTBoMWNxYlNnd2Y5aFNmRWhHY1JjTWNkZm5nWmhTYUJhRmZvaHFoZGVoY29nZGZXYVJkRmNaY0tnM2hKYnRjY2RGYWhlWWZTaFFkaGExYVpja2FzZitmWWNXZ2xlY2VVZGxla2FRYWFmRmc4ZytkSmRtZ3diVGZjZWtlZGRqZUNhR2YxYm9jRmFVZ2hiUWNSZHhkQmNtZmNibGJZZVZmT2ZEaGNjRmRJaGdkVWFFYkZkamcxaDZoUGRCYWhmbWdGZEdmWmJtaFlnWGNCY1ZoTWJuZkJkSGRIZVJnMWFWYlVkbmJSZXJiZWVpaFVkWWNKYUFkaGViZUdoMWI4aHFiVGREaHBoK2dCZWtiNGVWZUtobmhvYlNnQWdoY0ZkRGdBYmtlaGN5YmNjSGNCZ0loUWgwaGxkYWFkZVhnaGNMaFBhamh4Z3BjWGQzaE1iUWdHaFdjZ2hMZ1JiV2E4aFJhRWIyZjllSGRjYXhiTmVQZ1lmQmJjZmJjQmJCZVZoWmVLZkRkVmFVZEZkV2N0ZHZhVWZTYU1nT2JHaGxmTWhtY0pjeGFaYlJnWmhrZGdlNmhaZm1nTmV5ZFZmWGRKYkhmV2hoYTFlVWJYY0ZjSmh5ZWJkWGdwaHJlQmhHZnBoV2FEZDFoQmRGZU1lQWRwZXVnZGRGYnRoT2RQYTNjaGcyYkVia2FzZFllUWUxYWxjaWhjZ25mQmh3ZVNkRWdJZ0hlVmJEaHdlcmNMZWpma2Q1ZEpjaGhNY1FmWGJsYTVjZ2JRYWtheGVtZU9ieGFOZXZoUmczYk1lVGZSZTJkZ2RWZlNmRmJCaE9hT2dtY1pjeWNWZWhjVmhxY2NjbGVGZjNmVmgwZm9iV2FhaFRoVmJlYlNoaWVsaERnWmhpYmdma2hKYzFoVWJiY0FheGdkZ1ljZWhBY2NjQWdPYnpobGd5ZFpmRWU4ZXZlQmVVYXdkZGhWYUNkMGVDZk1iWGFSZVNmRGIwZUFlcmNJYWhkSWVKZ1hhVWNNaFlhWWRpZlFleGNQZ0FjRWRIZFNnUWhrY2hoS2VnYkloNWdQZVdoa2ZTYkZmMWVOZldkTGhFZ0llTGJLYkJmWWFhZWRlR2YxYXpjRWIwYmRlb2RGY1VkaGdRZlJjeGJCZW1hSmFCY2RlSGNhYmpjZGJSZmFibGJkaGFkRmFqZFZjaGNVYWhkQWIwYkdlR2dZaHZiYWFHZ3RjL2RiYTFmcGNIZkhnUmMxY1ZoVWhuaFJlcmJlY2piZGFOZWRhMGJ0ZEhjV2RrZ1Job2NUZ0RnTmQvYVNiV2VnYVZkZWVIY1ljU2JTZHhmaGREZVdnV2NKY3lkSmRqZkVmYWhRZHdhWmRhZWFiSGVnY2ZhZWZTYTBjN2NIZGdiMWNWZUVoVGZvZUhlUmVTYllkWWJDYkVjVmVIZWNneGROY0hmYWRCY1ZnSWFVYUVhY2JRaE5mRGhjZUNiUWhEZmdjOGVVZ1RnaGhYZFNod2F0YjBlWWdWZU1iWWVZZ0JnSmJtYWJjamNWY3djU2VHYzhmT2VTZlVkNWFSaEhmQmVFY3hhWWIyZXBndmhUZVNoVmRDaEJjbGE0aFFnTWhGY2RoY2ZkYmxnSmhDZkZjWGdoZDJjRWFrZ3RmRmFhaFZjbGFpYWNnbmJCZndlU2VFZk5jSmhIYkNoQWEyZENkQ2ZNaHpjSmNoaGxmWmFVZHhmRWE4Z0JoMGVVZTlmR2RCaE1hMGZiZ1hmTWJUYVJoMmFnY1ZlU2dGZEJjSGJFY0dnWWNrY0ZiMGRkZXFoT2gxaEZhcWRWZ3hlZ2VZZkpoU2dSZ1loWGd6YkpiY2RaaG5jcGRoYVlkRmVWZ3dnV2VsYmNjZGdCZTFmVmZDY2RoRGVkYTZnT2drYVVhNGdSZ1VoTWNYYlhnaWZNZllhUGFuYzljSmdhYkJoVmU0ZGRhaGZKZExhR2ZFZk5hWmdZZ25kSWJrZmNlRmdWaERhQWdWYUlhaGhkZUVhc2crZWNnM2FKYTljV2dSY0FoWmJhZ0FjdGVGZ2JieGRFY1RjYmV3YkVoOGhRYlVjZGJnY1Fjd2drZUNhUmgxZ1ZmbWFiZzFmWWZGaGNoWGRJZlllZGEwYWxoS2RVYjNoSmRoY1VjeGZoZXRkQ2JXZVpkM2FhY0hoQWJCYUZiQmY4ZTZkSGFRZ0JmVmVRYkdlRmgrZGVhbWJWZE5kT2FEZEJmS2FMZ3dldGdPZlRhSGJaYzJnVWVrY0llVmhlZkhnWWhTZFNiMGFvYkdlRGhUY2NnZ2JQZm5nQWdjZldoR2hOZmFiZGhYZ2hhTGZkYzNhcGRwZ1Zhd2JRZDZlR2NXY2dmTGNSZVdoOGdSZ0VkMmc4YUJjSmdsZzBnRWVQY0Zkd2VIaEhka2hkZUFiYmhpYVpnYWdGZVRmaGcrZ1VjVGQ1Z2JjU2ZsZE5oZ2dZZVVmMGV5Z1piaGNSYW1kWmhtY0Zkd2FWY1diOWVhaFJjMWFSZWJoVmNWY3BoOGRPZ1hjUWZoYUZmRGM0Y09jWWF4ZGRhZWZJZHhlZ2IrYWVkbGVKY1NhRmRXZVpkMmJXYTBhdGNFZEhlMWFrYndkZmdEYklkcGhIaEFlWWJsY0hlemJzaC9mSGN6YzlhNmNkYlZkY2FRaEdiUmZCZENmQ2MwaFZhdmFFYVJnTmh2Y1JoM2ZNZlRlUmIyYmdlVmFIZkJhZ2JWaFhoemRGZHlnR2VGZEFjOWZjYWlmTWcyYkdiUWMxYVRlRGdEYU5kRWRWaHpmUWRjaFpiR2dFY3VlTmFoY01jOGJIZHhoTWVhZ0hiUmR3ZUJhZGVDY1FkdmROZTBhMGdsZURhUWU4ZlFlWGZ6Y0VhQ2hNaGloVmFRaFNmd2I1aFNoZGRoYkpkTGFHZEVoTmJaZ1lhbmJKZXdiY2JBaEVmRmNTZVZnSWNuZ2RmZ2RrZHVhTGJpZ3dlN2ZIY0ZiNWRlZVBiRWZOZEZlY2R4YUZoYWNiZDBneGh6Zkdld2VKZm9mU2JSZFJkUWZWYnhmbGF2YldiRmRZaFZhYWJuZ0pkUmNkZTFlZGZLZ0ZibWJsZGhnRmFrZHdodWdSZWlha2J4Z1lkVGQ0ZFFjT2ZGY29lMWZYY0ZhTWJTY0ZoeGJFYTViS2FDYndiZmhZaGtla2JJYkhkbGFVYnFoQ2Z5ZklnK2JWZVVjSmhjZ0tnM2JaYmRoSGVrZXhnRGNGaGlmUmR5Y01oamQ4YWRlRGNRYTBlSmZkaDNoRmNRYlhoWGRwYXBjVmIxZGtkUWRHZ1djZ2hMZFJiV2c5YURkVmJqZnNmU2RJZVZkMWRIZllhRGE5ZEljVWZFZmNkUWVaZm5kSmVXZEZlV2FwYXllVWNYY2RlZmdHZUJlWmcwaFNmeGhZYllnWmZoZlJkbWNaYW1nRmV3YlZhV2c5Y2FkUmh4ZTBiZGZBZnhhMGM5Z0xiM2RwYnpnVGNYYmRnV2JFZGxkSmZaZ1piRWJwZndhZGJnZVFoTmNYZERheGgyZ0Fka2NzZEZnWGdrZVJiaWVOYTFncGN3YVNmRWhOaEpoV2JuYlZkNGNTYTNlZGg2YWFkVmRkZ1poRWhCYWxib2FGZUVmVWFoZlZjRWRSZHZmTWJqYnBnZGhFYzNlQmMwY0diZ2NJY0dlU2hXYTRlZ2hYZHplOWVxYmNhbGJGYTNhVmYwYm9kV2ZhYVdjRWFXZUdnR2ZZZ1ViWmdtZ1poaGdhZGxiVWE1Y0ZkUWg1Y1pkSGNVY1ZiU2NhY1hmWmVuYVlnd2hoY0FkU2J3YzliU2RFaEdhUmhNYmRlbmJaZVNkUWVoZ1ZjNGdkY2hlSmJMZkdnRmd4ZVphTGREZ2NhbmdjYURhMGJLZ0Jhd2g1aHRkR2RSZmtlbGNPaHpnQmZmY0NjeGh3Z1phSWZRZkpndmRiY3hnRWZUYmJlMGJkZHpnRWYwZWRob2JGaFVjaGFRY1JneGVCYm1jY2drZndiVmVKZERlY2FHYWRoeWFJYkRlV2VEYTFjNWJkYTBmb2cwZlZkVGI5YXVkTWIzYnhiVmZKaGxjWmJIZVdoQmdSYmNiWGNsaDVocmhlZW1jTmROZGFma2JzY1BhVWRoYkJka2hUY0hlWWc0YlhkRGdaaHNkQ2VCYU5lMmNOYUhla2F4ZEtid2FNYUxkRGd3aE1hOWRNZ3pia2gxZkJkd2V4Y2hjZGQzZXBmcGhWZDFia2FRY0diV2dnZkxnUmFXZjhhUmJFZDJlOWhZZGNoeGZ0YVBmUGRCY1ZnVmVVYkJoVWJaY2FlbmFKaGVlUWRXYVFjTmZMaGljY2dGZkJlVWRJYm1kSGhtYWtnWWJlZXhiUWhvZmFkRGhFZmljR2RqY3NnVmhFZjBhUmNOYUVmRmZ0ZDloUWRYY3BjamFUYVdjcGVMYkRhMWFJYVFnWmNFZHhhMmRkZWxmSmVDYkRmM2FoZCtjUmhrYXNkRmJRY3hncGFxaEpobmN4ZndkR2NrZ3BnQWFWY2xnOWQ0Y1NjM2FkaDZoYWhWYmRhWmRFZEJobGNvZ0NmMGZVZzdkT2Z4YU5ndmRSZDNmTWVUY1JjMmJnZVZhU2RGY0JoT2ZDZDBkeGV5Y1ZhaGRWZ3FlY2JsZkZhM2VWYnhiY2Y4ZWFoV2ZFYldjR2FHYVlhVWNaaG1mWWJuY0pmUmJzYXNhRGZnZDVjU2hVYzFoVWRmY2ZoRGM5ZDJnWWh4ZTliamJTZjFhUmE0YUVoR2ZSZ01nZGhuaFphU2FRZWhjVmI0Z2RibGhzZU5lR2ZFYXNhWGhiZERmc2hqYUVmaGEwZEZhRGN4YzhibmdjY0JnbGcrYmNmMmZrYk1hY2h4Z0FoWmNhZkFhdGJGZ2JoeGJFZFRhYmQwZmRkemFFZnhiRWVwY1JhMGNnYVpmUmR3ZjFnbWNZaGxhWmRKYmFkaWF0ZVpnSmRWZ2tnR2RVZnllY2ZtZ1FlbGhCaHZiRGIwYnhmbWhZYVhhQmdWYWJkMWFwY0hlSGFSYTFjVmhVZ25nUWQ1aFBjemJjZ1lmT2RBY1VlUGhXZGtlUmhrZVVoWGZZYythV2RoY1lhWmVlYkRjOGFiZ1FjaGVSZERkU2ZXZkpodmFiYldiMWZJZkZoMGdjY1dlTWdEZVliTWVJYXpkSmNwY1NiRmdsZkViR2hYYUlkTGhUYlRjMGNmaFVoQ2FBZ1hkS2ZoZXNmVGZaaEJoVmRZZFhkRWJjYkFnYWRuZ0lkZmVIYkdlWmN5ZEJlWGg1Y01lWWVCZlplcGZZZFJlWWJZZVpjaGVSZ21mWmNtaEVjdGVmYzJmOWZhZFJieGIwaGRmVmhWZ0pjMGdhaDNmb2NxYkNjMmdwZERmWGVWYXNnUWFQaDJhWmgyYWRlbGhKZENnRmhYZmhoMmZFYWthc2JZZlFlMWJrY3JhTmRIYUJkNGNZY2tkTmZKYVdjbmFWYjRjU2EzZWRkNmhhZlZjZGNaZUVhQmRsZG9lQWIwZGNhNmdYZTFlY2RxY0FoVGVwYWRnQWZpY3doWGdTaEZjRmZhZkVnRGdJYnJhQmRsY0FjbGhOZUZnRWVXYUJiUmhoaFhmTWFBZE5nRGZYaGlhQmZSZk5kR2RaY25jZGFuZDljdmZXZWtoY2RkZ0hnVmRWaFNkZGNHYnRiNmZZZTBoMWVxYVNhd2U5YlNkUWhtYm9oT2JJZXpiQWdVY0JnMGFkZTRiUGExYXdoWWZUaEFoSWhYZElmVGNjaC9mTmRrZWdmaWJHYXdjZ2UwZElhU2NrYmlhUGdDZThjU2hDZHhma2VaY05kRmdkY3ZjYmJ4Y0VnVGRiZTBlZGV6ZEVhMGVkZG9oRmhVZmhhUWhSZ3hoQmhrZFBhaGFOY2JmTGJTZVloWmJkYlZkY2ZEY1doR2RraHpkUGZCYWhkbWhGYkdoWmJtZlljWGdCZ1ZnYmIxZ3BhSGRIY1JnUmMvaFVobmVSaHJkZWhtYk5hTmJhZGtkc2FQY1VkaGFCYWthVGJIZllla2FGZXhmWmdBaEtkamVnZFNlU2RWYlloV2hGZ0NmQWMzZEljbmJKY0loUWdsaFJmYWNJZVNlRWNiZE1lamVVZXZnVmR3YXNoZWRWZVNjMWZGaEFhamJ0YlpkRWd6YU1iYmZjZjNiaGdQaE9oaGNzaEVlRmhRYWxiWGRNYWpjcGFmZVBnMmVwaHlmVWVYZmRkWGhTYmhkWmRwZllkUmdZZFlmWmJoYlJlbWRaY21kRmZ2ZFZiU2NkaFNnRWF4ZUVjZGhSY1ZkdGRlZ2FnM2FwZ2pnVGFXZnBoTGREYjFlSWNRZFphRWd4YTJhZGdsZkphQ2ZGZVdhSmQyZFVoVWhOZ01kVGUxYWtod2VlaDJmdGRhZlNlRWZOYUpiV2ZuYVZiNGhTZDNjZGQ2aGFkVmhkY1poV2NWZzlob2FBYzBiY2dOaFJjRmNVZ3BiQWFpZEVhUmNSYTNhVWhJYVZlVmVBZ1ZnSGFqYUlkcmZCYWxhQmFxYWRhRmRkZTNjVWMwYjRkZWNPZjJjOWVTZFdkVGJKZVZoYmIyZDliaGRJaGhoQWM3Z0RkeGhWZFRlSGNSZ1phYWJJZUdnZGg2aE1oVWdNZXVhQ2FsaHNlVGJHZFhlOWZtZGRmbmhaZ1NoUWZoY1ZjNGZkZ2hjSmNMZkdnQmQ1ZHpiWWNuYkpjd2ZjY0ViaGhEYlNiVmhwYzFiZWhCaDhnL2ZLZUNiWWFBZldhVmg1ZGNjUGh3YXNmeGVOZ2tmRmRXZ0NnaGRVZ2hkWGJCaFZlZ2ZQZDBnaGdRY1JmeGdCZ21nY2VsZFlmVmRhZG5kSmFSYWRoMWRVYnNjWGZ6YXNkeWRRYmhnZ2NuZ1JkaWFFZ3pjTGdEZ1VmYmVPaDFob2NLZ1NkRWc0ZUJmVWNqYVlndWdlZGloSmROY09oUmQ5ZWRmR2QxZTRjamFRZkhoWWhVYUJhd2ZSYVRnUGJTY1FiZWNTZTNja2VSZkNoeWhNZXJoRWFpZFVkT2hCZ1Fjd2hJYWVoWGFnY3FjSmJTZmdkb2FEZmxkVWVRYlZoamhvZExkQmJEZDFiRGRVZWpoWmNLYlBkMWVvYk1kTGFSYlVjSGRFZmdlMWVWZUpkU2daYVlmRmEwZ0JneWdVYVhnZGJYaFNkaGdaaHBlWWFSZ1liWWJiYndhOWRNY1pkbWZGYXdoVmZXYzllYWZSZnhiMWNBZGZkMWVKZzBjYWIzZHBnamNUZldocGNMZVNiUWJkYWVoSmZ4aGdhL2FPYVJkeGJDZlRhSGVBZGlnR2MwaHRlRGVhZVZhbGhpaGNlbmRCZndmU2RFZk5hSmZXYW5iVWF4YkRmWGJkYnlmUGZWaGRmSGREYlJia2NuYUFlMGd4aG1oT2Z4YU5mdmZSZzNoTWZUZ1JkMmhnZ1ZoU2VGZkJlSGFFZ0RmSWQ2Z0JoRmJvZjliY2NoYjhheWdBZkVicGVrZEtnQ2g5ZVJiWGRRYU5oR2VOYUNma2V6YWVoSGg5ZHZiV2NrYWNiZGFIZVZhVmRTaGRhR2F0YzZiWWcwYzFhcWdTaHdmMGV6Z1JnRGJBaEpiT2R5Y1lhR2ZRaGtkRWEzYmRnbGFNY0hhVmZBZ3doYWVJZ3llWWExZWNiQ2NvY1doRGJ4YXdld2FLZmtjc2g3ZU9oemZzZlFoSGhFZklnWmVQZkVnTWFFZUliUmVGZmVjTGVoZDhlNmZYZ2hiSWVsaEZiUmFzZ1pjSGVWZVZkOGdjY2tnWmROZ2FlSGhKZWFhWGZWZGRjS2VGYm1kbGdoaEZkaGhoZG1oRmNHYVpkbWdZYVhkQmZWZ2JjMWFvZ0loRmVSaFJkYmJCZ2pic2RZaExlamFFZkVhSmdBZndlSGhRYXdhWmZ0YVRmSGExaGNlVWZrYklmVmhlZ0hoWWFTY1NjeGhoYURlV2dXZUpleWVjZUhoQmhJaFFjMGV0Y2FnTmJ5Z0VkZmJNZ2lkbGNyY2ZjVmRrY1FlR2dXYmdhTGNSaFdlOGZSY0VkMmM5ZUhmY2R4ZXBmY2RRZmhiVmhJZVVoRWFjZlFoWmduYUpjV2RGYldib2JnYkZjQ2JNYkNhR2ZGZWhocGRjY1JiWmVFZVpma2hCZDlmVGVHY0Znd2dWZFdoOWdhZ1JjeGIwY2RnQ2hIZmhiMGJhYjNkcGNqZFRjV2hwYkxlRGV4Z1JlRmFLYWdnOGRpZVBoeGQwZE1iRmFRY2RjK2ZSZmtlSWFZYUdoSGFOaGljY2JuZEJmd2dTZ0VkTmJKZFdjbmNWYTRlR2ZUYklodWZQZUFkVWNYYkVlQmNJYThiQ2gwZVJmeWZFYlVlZGd2aFFhWGVVZ1RkVGR6ZndjVmFWY1ZiQmZYYUdlV2NwZHloR2NCYnNocmVQZGhiMGc0ZUZhRWFJYWRhUGFXZWdhTmNNZG1lWWdVaFpkbWRaaGhhY2JGYVZidmRCZDJnMGFkZ0hoVmZWZlNkZGhHYnRjNmJZZHdjc2YvYUJiVWd3aEdjV2FTaHNjQ2hkYmpnSmZhaEZoaGNsZDRmSmVCaHRhTGNRZTJmbGRaYllnbmZKY3dkY2RFaGhlRGFTYVZjcGgxZ01nUWcxZzNiY2dpZWRmWmRFaEVnTmQ3YVBiVWcwZERhS2NraE1kYmZPYjBkNWQ2ZUVoeGZVZ3RkUWRSaDBnQ2VDYVJnQWF5ZmZlQmdwZVFkSmZEaFVnRmNQZDBkeGVnYUZlbWJsZmhhRmFoY2hibWdGaEdmWmhtaFlnVGJraFRhYmgxYUpndGNIYVJhMWNWZ1VibmJSYnJiZWVtaE5hTmJhaGtjc2ZQaFVoRWFVY3FhQ2FEaE1md2JHZ3dieGZRaFBmSGZRY1NkU2hnaFZjRGNEaFRkc2JpZU5hVGE4Yk9oUWd5Z2dkSWVKYnpla2hTZEZkU2U4ZXZlRWVSYnhlQ2NHZVdnNGZOYWJhMmc4Y1JlRWQyZTliSGRjYXhoTmZIY2FiQmhWZUloVWRFZVZmV2RNZ3phd2ZWaFFnU2hNYzlkSGgzZlZjWGFWaHdidGZwZE5hVWQ5Z0lnSWIxZnNhZ2daZ2dnQWdpZ0JheWE0ZERnSmJVaGhkYmNFZ3hjY2FtZ1phVGZNZ3dmT2J5Zk1mT2RXZEZiSWNXY1lkbWNaYTJjZGVsY0piQ2dGZFhkaGcyY0Vha2VzZlliUWQxYmxkcWVFYXllSWhpYkNjUmZvaHJnRGN6Y01lK2NEY2ljVmMwYUlhQWZRZnZlV2RWaHdjL2NBZHhiRmZtZ0ViVWc4aHpkUmZ5aGNlVGVEY2ljWmNHZUhnQmZFZkpoVWN5ZU1kOWRFaEJnVWdMZUljQWVNaDJiRGhpZ2hmRGJMZ3ljZGhUZ1NhbWQ4YSthWmdtY1plaGZjYUZmVmN2ZVdka2NjZmRjSGJWY3hhNGFkZEdmdGc2YlllMGMxZ3FiU2d3ZjlnU2VFZEdhUmNNZ0pnRGRNaEdlRmEwYWNiMmJkY2tlWmJGY1dmaGdvaE5jSmJ4YjRoMWdQYWdiOGJYZkFlVWVGYWZmZWZFZnRhM2dlYm1mbGVYZldkUmFBZFpjYWVBZ2tnV2JPZDBiTmZhY0llUWZCaHhnRWYwZlphMWJGZFJod2ZKZUZkMWZVYnBjTmZGZ1pmQmRhaG5mUmNYY2RoMWQ4YWVnRmZuZFJoaGhGZEJmcGVtYUhnMmdZZXllYWFHY3RhL2NiZzFicGZIY0hhUmcxY1ZhVWZuZ1JkcmNlYWphVWJNYU9nRWN0YkdoVWNnZDFna2VHZUhkZ2Q2YkZod2R4ZlNnTGZEaDRhSmRZaFJhaGhEY1dmV2FKaHliY2dIZUJoSWJRZzBla2dUZ01oM2FoY0RiWmUzY3BmMGFTZGtoUWZRY1VlR2FFZkxoRmd5ZnBjRmJSYWphMGhKZGNjd2FOZGNjUWVoY1ZoSWdVYkViY2RRZ1pibmVKYldmRmdXYm9kMGVIZGlkVmdYZFFha2dBY29lTWZ4YlpmZGVaYmdmbGJtYlpjM2JCZHJlVmdYYVJnYWVUZGpoY2FkaFZjVmZKYjBlYWQzZ3BmamVUZ1docGFMYkRlMWNKZURhTWJ3aFVlaWVOYlJocGRDZ0hnU2NwZy9kRWJoZEFieWZRZzFobGFpZWNjbmVCYXdlU2FFYk5lSmVXZm5jVmg0aFNoM2NjYTVhS2hBY1FiY2VFZ0Jhc2NwZVdhQWhZYm1oV2FCYkZkMWJiZ1hkTWJUZ1JjMmNnZlZmU2RGZEJjSGVFaEdnWmN5YVZoaGFWYnFjTWVSYUFoa2VFZ2tib2dVYUpiU2VCY0NmVWZTYmdjRmdaZkhmeGJMYmNnRmVWYnZoV2FrZWNiZGFIZVZhVmJTaGRjR2N0ZDZlWWMwYjBlcGVDYmxod2JYZEVkR2RZZU9nUGF6Y2dnVGRFYUVjeGQ2YWJmRGVoZUxmR2ZFZ05iWmRZZG5nSmd3YmNiRWdoZERkU2hWZXBnMWZlYUVldGIzYktmQ2Z3Z0RoRGFFaEphWGRhZkVoSmJlZFJoUmZFZlRiYmMwYmRmemJFYzBhZGFvYUZnVWNoZlFnUmZ4ZEJnbWZNYlJkZGNHYkxmM2VKZFRkSWRnZU1iTWVEYW1odGQ3YlBkQmRoYm1nRmZHaFphbWFZY1hmQmFWYmJlMWhwZUhnSGVSaDFlVmdFYVRjVWM0YVBmMmZOZVBmUGR4aDljSmZYZndmaGFtY1ZlbGJ4ZzJlVWZrZUlkVmFlYUhnWWFTZlNieGdoZ0RjV2hXY0pmeWhjYkRkTWFKZ0VkQWR4Y2FhSWZ6ZmNhQ2ZNYjNjcGY1Y1RmWGFNZVFjR2RXYWdhTGNSYVdoOGZSZUViMmY5YkhoY2N4aE5mSGhhYkJhVmdJZ0FkZ2NKY0VlTWF5ZUFmWWVGaFFmSmY2YkJoWGM1YVpjQmFsZE1mbmNKZWtnSmNRYWZmVGg1Y21mWmhtaEZjd2VWYldhOWFhZlJheGcwYWRjVmFWZkpoMGdhZHpla2FpY0hmaWY5aExjRGVRY2RjVGNOZzFlNWEwYWJiSGZoYkNiRmVYYmhoMmVFZmtic2hZZ1FiMWRsY2ljY2JuaEJkd2ZTYUFmQWVJZ0NiVGRCYzRnU2FTYUlkNWRPZmxocGZMZEVoZ2JOaENjQ2YwYVZjdmJFZFJmTmF2Z1JjM2VNYVRkUmgyYmdhVmJTYkZhQWRFZVVnVGNVZTNiVmZoY2NlL2VKZ2hoZGhtYlFnUWRaZFRnYWYzZXNhOGNHZUdmWWNVZVpobWhaZmhoY2JGZ1ZjdmhXYmtjY2NkYkhoVmhVY1JiTmhUZmdiL2ZZZzBhOGgvYkhnMGNsZGZjQWRYY0llQWFNYTNjUmhJZWFkQmVWaDRkZGhoYUphTGFHZ0VoTmJaZlllbmNKZXdlY2dFZ2hjRGRTYVZjb2JuYVBjUmQ4aGlhS2JDYWRnWGZTaHhlQWVUYWFhRWZKZWViUmVSZkVoVGRiaDBjZGV6YUVnMGFkaG9hRmFVY2hiUWdSYXhlQmhtYk1mUmdkZUdjTGgzYUpjVGhQaHhoSWNTYkZjSGJOY0xkRmJoZ2hjbWZGYkdnWmVtZ1lkWGJCZlZnYmUxYnBoSGRIZlJkMWVWZ1VmaWJZY3VnTGJqZFliZmhKYUVodGNHYlViZ2g1ZzZkVWZuZlpmbmJTZldmZ2hWaGVlSGNZZFNhU2F4aGhkRGNXZ1djSmR5Z2NjSGZCY0liUWJ3YW9oYmJKYmpkMWRMYmRnVGJnYm9jQmdCaHdhR2VEY1djb2VSaGJnMmE4Y1JoRWgyYzlkSGhjZnhmTmRIYWFoQmJWZklnVWFFYWNhUWVaZG5oSWRFaFVkRGU0Y25iQWR6ZGxoWGNNYkJoNGE5Y2FiQmRoZVVmSWMxZm9naGhNY2ljbGRyZWZoMmE5Y2FjUmh4YzBiZGNWZlZnSmYwYWFkM2RwY2poVGRXYnBkTGFTZ3hjZGNXZUpnUmJrZjZmSWFrY2hlb2FGaFhjaGgyZEVja2hzYlliUWgxZ2xkaWZjZm5kQmd3ZFNiRWROY0plV2RqZHdjK2dTaDNiOGgvYllhRmZjZkxmVmFVZDBhOWhXY1FkdGZ2YmVjUmJzZDdlVGhuZDFkZmhBYmloWmVTaEhmQmhoaGNhT2RtYlpjeWFWZWhnVmdxZ2NjbGZGYzNmVmQwYW9iV2FhZFdjRWRXZ0diR2hZZGNhTmNHZVpiOGFjY0ZnMWN0aFdmRWhjZFdoSGZRZmRhYmRlYmpjOGMxY0Rmd2NJaDlhRGFsZzBleGZVZVRiY2hKaGZkbmE5aGJnVGhoYlZld2RNZ3hnSmRXYUdiRWFKYUplYWQyYmxmYWZjZUVlaGVEZFNoVmZwYzFnZWJFaHRnM2ZlZm1ibGdYYkJnRGRvZ1plYWNBY3RjRmZiZ3hjRWJUYWJleGdwZ1piRWcwZWRnb2JGaFVnaGdRYlJneGNBZWdlSmN4YmhiV2FQZGpjc2hlY09iVmJjYU5hSGhqZDFkdGdGZGtkcGhxY0ZnQ2c5ZHZoWWdTaHRnL2NiZjFicGJIZkhmUmQxaFZhVWFuZFJhcmJlZGpmVWNNZE9kRWh0YktmVWJnZDFia2dUZFdhZGJ0YWVlRWNJaFZkZWZIaFljU2VTY3hhaGJEaFdjV2VJYTdlTmFuZUJlQWZTYjBkRWdNZU9iamJFZVBjZGIyZHBjcGJTZWtmUWFOZkdnVGVvYkxiR2NUY01oUmhBZzJoOWdaaGNlMGVGZU9nYWZCaE5jT2NVaEVjOWRDZlplbWU5ZFdmQmFXYU5hK2dVYVNhVmZYYVZhQmdZZjlkS2JWZTlhTGdhZkZkZ2FqYktkQ2NZY2tjSGhXYVpmVGVSYTBnOWVZZEFlUWdjZm1oSmFYZnBmaGdUYTNkRmZoZERnMWFJZVFmWmZFZXhmMmJkZ2xlSmJDYUZjVGRFYndjRWFrZE1iUWVTZndjOGJ0Yk9nemZSYndkV2FFZU5mVWNSZzJhaGU0ZEFobmhjaG1kTmZWY2NoUWNFZkFjZGVvZ1hmd2QwZm1kUWVoZjBlamdBZWpmMWNVYkVjeWRBYWNnU2NGY1poQmNFZEdnNGQ3aFZjZ2FoYnFjSmZoZWtiK2JCZUViUmdhaExkQ2U5YlJjVGFDZjRhZGFhZG1mWmV4ZGNoRWZ0YnliV2NnYTRkVWdGYUhnOWhTY2RlR2d0YzZhWWYwZDFkcWNTZndoOWNTYkVnR2dRaGVkTWJ5Y0loSGFFaEZhdGY0ZmRlQmZCaFFmTWZrZU5hWmFZZG5jSmN3Z2NnRWJoZkRkU2VWZG9jOGNQaGtjdGQvYmNobWdFY2ViV2hRaDRiSGFkZWhnWmFGZ2ZleGRnZ2ZkYmgwYThhaGNFZzFlbGMyZENlMWJWY1FhVmJ4ZWxncWNjZ2dmUWZWYWRoR2U5YlJlUGJsZzVlRGdGYWpkc2VrYlFia2EwZTBoV2dtZFpha2dZZTJhdGEvZ2JnMWNwYkhlSGVSaDFhVmhVaG5jUmNyZ2VnaWJVZENlT2VFYXNmSGZCYWhkQWQ0ZEVoSGVaYStmQmNraEliSWRlZkhoUmJIY0hlMWE1Y2JkV2gyZnRmcGFjYUdidGRJYlNobWNOZmFlZGdYZ2hhTGNkaDNocGNwY1ZkMWZrYlFkR2hXZGhlWWFFZ2lmWmJGaFVoQ2hkY0hkZWQwZGRlT2RhaEVjNWRpZFVkRWJjZ1FhWmFuY0pmV2dGaFdocGJ5ZlVjWGhkaFhlU2ZoZlljcWdJZ0VhVmhkZVphaGZZaHVlSWN6ZWxheWdUYjBnVmZhYlJkeGIwZWRoVmNWYkpnMGVhZDNmcGVqaFRiV2JwZ0xmRGYxZUllUWFOaGdia2VpY0lid2ZBY01hRmFTZEpkK2dSYWdnTmNSZEVmRmJWZ2loSWFIYnhmd2FBYVVocGFTZWNmSGRWYzRhU2YzZWRkNmZhZlZhZGZaZkVkQmNsZW9hQ2IwY1ZhdmVVZGxnSWU4ZUFnbmVNZFJoRWZqYnhjVGdVZ0ZoSmJkZU9hbWZaZnllVmRoaFZmcWFjZmxjRmMzZ1ZjMGVvZVdhYWZXZUVoV2NXaHljZGJIaEllMmdaZGpiSmVRZ0VhcGZWZzFoOGJmaEJlM2I5YlNnZGNHY3RnNmdZZDBnMWhxZ1Nod2U5YlNhRWZHZ1JlTWhkY25kWmVTZkVoRmVBZXNjSWYwY0FlRmZHaERmTmVSZk5oamRvZjVkSWgwYVJkRGFHZDFhWmgxY01iVWhKZHNkVWRHaGxnWGVXZVJlQWRaZWFhQWN0ZEZjYmN4Y0VlVGdiYjBhZGZ6YVVoQWdZZzdnVWNFY2hhU2dCZGtmTWhsZU9leGQ4Z1hlY2NGYWhhUmFkaDFoZGZLYUZhbWJsZ2hhRmVoaGhlbWJGZ0dmWmdtZFljWGdCYVZkUGZSZThhVGZTZUVnOGJiYlVmZ2RkZ2poTGJpZnNmRWdPYlVkY2RQZ0FjQmZ4aGtnQmRYZTlodGhlZ0VhSWNWaGVhSGdZZFNkU2J4ZmhmRGZXaFdiSmh5ZGNjSGNCaEllQWhBY2diSmhNZUhkaGRKZU9oemRzZjlkSGFoYmNjQmRHZzNmSWFoZVJnV2Y4ZlJhRWMyZTlnSGNjZHhmTmJIaGFmQmRWaEljVWZFZGRjVGdKYnllRWZUY0ZnV2dnYXdmR2REY2thV2FHZ0VlOWdyZWVmemZ3YVlmWmJoYVJhbWNaYW1hRmd3ZFZjV2M5ZmFmUmN4YTBlZGhWZFZhSmUwaE9lVGU4YzNlR2NEZWdkRmZEY3poc2JZZU1oQWJRYy9oSmRWZzVmQ2RSZzNhUmYyZldlMGNJZURlYWdWYmxmaWdjZG5nQmJ3Y1NjRWdOZUpjV2huZ1ZnNGVTYzNhZGY2Z0thaGhZZktnVmdSZWxicWdTZFFiUWI4Y1ZlQWJWYjdhUmNXaGtjNWFSZDJjZ2ZWYlNkRmZCY0hoRWNHY1pjeWRWZmhiVmFxYWNkbGdGZTNmVmV4aGhjVGJQZFRmUmZFYlZjbWNaaGdnYmZqaElncGZPY1FoWmZqaFdiaGJVY1JjSGNSZ3hhYmhiYjBmRmI2aFllMGYxZXFjU2R3YjliU2RFZUdkUmZNZmRhbmdaZlNnUWVsZVlnNWNKaFZiZGFMaEdmaGJZZGFlTWdXYkJneWJhZW1nSmdEaFNnVmdwZzFnZWNFY3RhM2dlYm1lbGZYY1dlUmRBZlphYWNFZWdoRWNQZkZhUWFUaGJiUmFJZ3dnUWhFY3BkNmhGYjFnSmQ2ZFJheGVCYm1kY2NsY1lhVmZhZW5mSmNSZWRjMWVkY0tnRmJtY2thaWZWYTBjc2RqaEZkR2JRY3piTmNUZ1pnRWdlZVJoWWNDYkhnd2hkYy9lVWhuYVJocmhlZm1jTmZOZGFna2ZzZFBnVWVoY0Jja2FUaEhhWWIxYUVmeGhGZ1FoZWdIYlJmSGRIaDFoNWRPZlNkSGhRYithTmVYZ0pmU2ZhYVVlbGZhYmRjWGNoZ0xoZGczY3BicGdWaDFma2FRYkdjV2NnaExhUmdXZjlmRGdWZ2pmc2VTYUlkVmIxZ0hhRWRSYjBoY2NHZ0FnNWhEYmFibmRJaEVlR2RXZm9oN2dXYkdkeGU5Y1NhaGJaY3BiWWVSYVllWWZaYmhhUmJtZVpobWdGaHdiVmJXZjhnZWFBYWxndGZjYUFhQmY0Y2diY2FWZkJmamNUZFdhcGRMYkRiMWNJZlFjWmhFZXhoMmdkYWxiSmVDZ0ZmWGVoZDJkV2d3ZTBjWWhTY3hmeGFyY2NmaWJRZTRmR2ZnYndoZWRXY2pkc2Q5YUhjSGNjYk9hTWNBaGNhY2FkYlVhc2Y2ZlJmQmFkYm5nRWEyaFlhaGREYURnMWZjZUVkQ2VZZFZiRGhSYjRlRWdYY3ljSWQ3YkdoRmFKZndiY2VsZE5hM2ZYZUVlcGJDaFllSGZvZDhhR2VHZ1lmVWhaZm1lWmFoaGNkRmZWZ3ZmV2JrZWNlZGZIZFZiVmdTYmRoR2dNZ3VmWWgxZUJncWVRaDFkdGNTYkdnMmdSZk9lZGRIYTloY2ZGZmxlb2dVZE9jVWdVZU9nU2JpaEFoWWVNZlRiZGY0aGVhVWZGY1BhU2RWaElmd2hlYUZkWmgzZmVhM2JsZ2VnUWZqYm9hWmFhaEFidGVGZmJieGZFZFRkYmMwZmRiemFFYTBlY2IxYlBkMGZoZVFmUmV4ZUJmbWNjaGxhWWRWYU5iMWVoaFJnZGcxaGRjS2hGZm1ibGRoY0ZibGY0Y3pmV2NpZ1VieWRLYURjOGRiaGJnd2YxY1BiU2RSYUZmVmdBZEhnaGVyY01nMmNwYk5jTWdXZ0VkUGdVZ2hnQmhrZVRoSGJaZjJiVWJraEllVmZMaGpiZGJBYVNlMWMxZERlUmFHYUlhbWhDYXlhSWExaFdiR2ROZ2FkZGFYZ2hlTGVkYTNkcGFwZFZkMWRrZVFmRWdUYXhhd2NGZHhmSWFSZ0RjbWE4YVRoQ2FGZm9mNmVZZVJobGNJZ1djQmVOZHJmTGF3ZTljV2hDZkdnb2QzZFdkR2d4ZzllU2doYVpmcGZZZFJoWWdZY1pnaGRRZzdhVGZHZkZod2VWaFdhOWVhZ1JoeGEwY2RoRWN3YWNjNmZLZUNnNGRxZ0FmaWFSYkxmV2JWZHBiRWdhZ0Vnd2hrZWVobGZJZkxnR2FYaGdmemdIY2thdGFYZVNhbGRraDVoV2FIYUJkd2RTZkVjTmdKY1dhbmJWYjRjU2MzYWNiemdMYjFjZGdSZEFkQmVsZTFkRmdsaGhidmdSYVJmMGFqYkFoamcxZ1VnRWJ5aEFjY2dTY0FkSWhDZ1JkRGRNYWdiR2NCYVZibmhZYjBlcGJkYVZjMGVvZVdiYWZXZ0VhV2ZHZEdkWWhVY1pnaWQ4Ym5lY2ZGaDFoRmVXZGtnY2NkYUhnVmZWYlNjZGFHY3RmNmJZYzBlMWNxYlFod2gwZEJlUmFEZlliRmJPZURoRmdRZFFhZ2ZoZmxkZGZrZVljU2NTZ0FmWWFXaEpmSGhJYzViV2ZrZWhkRGRTYlZjcGIxZWVoRWh0ZzNkZWZtY2xjWGRXY1JmQWhaZ2Rmd2h0ZE5kWmQxY1FhVGFjZGtlY2I2Y0dja2N0Zm9jSGZRYkZlUWdXYWhiQmIyZWVhMWU4YS9kYWJuZEplUmVkZjFnZGFLaEZhbWVsYWhjRmVoZGhkbWhGZ0doWmc4YVlmVGFsZVZnY2JWYXBlVmVEY0FjbGRDaFJnbWZ4ZDRkYmhIZGRhYWVRZEVkc2VQaFVjaGZCYmtoVGFIZFpoMmVVYWtkSWFWZmVhSGNZZlNhVmZCZGhiTGRFY0doSmZ2aGNmR2VKZFpjVmIxaDVkT2FiaFdjdGFkaFlkMmUxZ2dhZmZWZ2toUWZHZFdkZ2dMYlJlV2U4ZlJlRWUyZTliSGVjYnhmTmFIYWNiaGhWZUZnUWNsZVlnRWFjaFdjWmdPZEJnbmJ4ZW1kU2hYZ2RiSmdTYmxiOWNwZlpjeGNBZVllYmhsYTFkbWZlaDJkRmY5ZVJkM2g1Yk9lVWVBYWtlRmRSaGtlUmdnYmNnM2hOYnZjWmQyaHBhTGNEYzFnSWdRYVphRWJ4aDJiZGRsY0pnQ2dGZVhoQWQvaEVmbGFZZFliU2FCaEJmcmFmZ2xmcGh3ZFNkRWNOZkpoV2ZuZ1ZiNGRTZTNkZGU2YWFnVmdjY1FnUWgzZ2NicGNaZVVlMGdtZUdjQmZOY3BmUWJYZU1nYmFEaG1oZ2VJZFNjQmU5ZUhkRGEyZFpnaWNWZmdnOWhxZEpjbGQ4YTdnRWFnZlJhUmVQZlNka2VXYUZoV2hZZUZjYmEyZ3BiTGZjY0ZiVmd2YVdma2hjYmRiSGFWZVZnU2FkYkdndGI2Z2NmMGExZDBhU2QwY1plU2RGYm1jSmZNZGZjamQ5Y1NiWGJ4YlVnc2FlZUZmNGVPYlZlZ2FRY05jS2NuYkphN2ZjYkFmRmZLYlJiWGVCYzFmZWFFYnRhM2JlY21mbGJYZVdkUmNBYVpmYWhBYXNhTWRiY3dkOGNPYmJmeGZOYTloWGd3ZklhbWJVYWhid2ZZY1RmamFwZ21oY2FsZFlkVmFhYW5lSmhSZWRkMWVkZEthSGUyZWtlNmRQZUJkaGNtaEZmR2VaZW1iWWZYY0JmVmhiYTFmcGhIZEhkVmZRaFRkVWhuZHdja2VjZjJjTWRmYkxkeGc5ZGFlQWFGZjVoa2VRaFdiZGF0YmVkRWJJZ1ZiZWNIZ1llU2RTZnhjaGJEZ1dnV2hKZXlhY2NEZ2xhSWJYY2tla2FPYWVmemRRZ09jT2RUZzBoOWdIYjFna2ZkYUdlWGZrZ1FkYmYyYThmUmNFYzJmOWNIZmNmeGdOYUhlYWZCaFVlVmdVYUFoSmVjZE5hVGFkY1dmWGdDaHhmeWRXZ1dhZGNYZlZjQmdZZmdkYWNCZlphRGZUYkJiUmJtZlpkbWRGZHdkVmJXZDlmYWVSZ3hnMGdkYlZoUmVzZHloYWMzZUphaWdBZm1nTmVMZ1hhUmdkYkVjTWFSZDRjNGdkaGxlOWJUYkRhbGVKYzJoRWFrZXNoWWdRZzFjbGdpZmNkbmJCYndlU2JFZk1mQWRXZ21iaGc0YVdmMmh4YVFkYWFWaGRnWmZFYkJmbGRvZ0NmMGZWZ3ZkRWVVYjVhRmZSaDNkTWVUY1JkMmVnZ1ZiU2dGZEJjSGRFYUNiOGMwYVZmaGQxaGlhY2VBY0liamZCZFFkTmNZZUxobWRNaFdnQmhYZHNiVWRNZGpjOGR4Zk5kUmRvZXBhV2hoYVVlZGdHaDFiTmZTYmZmRGZsaDZoZmZrZzBna2dSZVVoa2VBYlhheWJsY0VmSmdIZnBjU2JCZXhleGV4YWVkaGFJYkZhRmJnYW9mS2FBYkNjY2QyYU5oZ2UwZVJkUWFRaGhlOGRjY1VnSmZkZWVmbWVsZ1hmV2hSY0FnWmJhaEFmdGhGZWJkeGJFaFRlUGdRaElibmNSYWhmVWVtZUZhVmhoZVFiV2FnZDFmN2VjaGdoUWhiYkphamRjZmZoTWZBZE1jQ2JGY25mWmFoYUdhd2JsYW1iRGVtZFlmSGZhZlNoUmNaY2Jhd2doZUxnSGdWYVJlWmZVZ2pmRmVuYWVnaWN4aEVkY2NXZUVnUGFVZ2hlQmFrYlRoSGFaZzJmVWFrY0lnVmZNYVRlQWdTZFFjeGVvZk5jRGRDYzhmd2ZOYlNkSmJLZlFhMWVSZkhkZGNTY3dhU2ZKZHpiOGJtYUVkVmFsZUNhRWZFYklkTGFSZFdoOGZSZUVnMmE5aEhlY2Z4ZE5kSGhhZUJjVWRhZ0ZjUmROY0ZoTmJEaHhmV2dIZVVmQmd5ZFVmWGJkYlhoU2NoZFpocGRZaFJkWWNZY1piaGZSaG1kWmRtZGtoaWhWZFhiSmdhZlZiUWJnY0lnVmVWYlJoMGFPY1hhTmR2YVpiMmZwYUxjRGIxYkliUWJaZUVoeGcyZmRhbGJKYUNkRmNYYWhnMmZYYUViVmhzYk9iaWNrY0hhRmZnYzhkUmhPZGpjRWJvaElkd2RvZUxkUGJnaGNiS2NCYmliVWh0ZkVoQmU5Y3VmSWhVZ1ZndmJFZVJmTmd2YVJlM2ZNZFRhUmMyZWdmVmZTaEZjQmhIYUVhaWFBZ25jR2hGZ1lhK2FPZHhlNGQ1Z1ZiVWhvZ0xlZGVHYkZmQ2ZRY1RlWmNSaEtmU2VCYWhoQmRSZXdnaGREYWxoOWI4ZVRhd2VjZlRkTGJXZFVocWhNZFFhSWYrYUJmRmFzYUxhUWZDYkZoQ2RQZXphZ2hXZEJjMGIwZ1hmTWZEZmhjTGRHaEVhTmNaaFljbmZKZXdmY2RFY2hnRGFTYlZlcGcxZ2VmRWR0YTNnWmNXZWtlWWJjZnhkQWJaYmFiQWZ0YUZlYmJ4Y0VjVGJiZjBlZGh6YkVlMGFkYW9lRmJVZWhjUWhSY3dlOWRtZUJmeGQ5YmJiUGhtY29md2VKZlFiVWJMZlRjMmZjZnhhUmNGYWNieWRXZXpkSWEvYk1hVGdWZGJmSmdoY1FhRGNXZEVlVWE2YUZjSGdvZW9hT2d5ZzhhQmRZYWhjOGVEaFVja2RKYW9iVGREZzlkL2ZlYkVoSWZWZWVkSGFZYlNiU2F4ZWhjRGVXYldnSmN5Z2NnSGZCZkloUWIwZGxkYWRkZldkSmVMZEFnamhNZ25oQWMwYkZjeGdTY3pncGRLaEhiR2ZGYkJiUWFTZUFkVGJQZEVkY2JlZE9lRmhCZUdnSGdBZVpkRGdNaGhoc2JZYlVoU2c4YXFmUGZqY0ZkWmdDYlZhY2NsZ0xoUmg1YU1mYWVoZ1FmMGdhYW1mRWU1ZVhnRWdWZGFmUmd4YjBkZGJWYlZmSmcwY2FmM2ZwZWpmVGVXYXBjTGREZDFoSWRRZmZia2F3Z1hkZmhnZVpiT2hGZFFnTWJrZmJhMGdjYVlmQ2VsY1ZkaWJOZzNneGJ3ZkJnMGVwZGpjV2ZuZlZoNGZTYzNiZGg2YWFjVmNkZVpjRWRCYmxib2JBZmxoNWdGZEVlUmFOaHZmUmQzaE1nVGNSYjJjZ2RWYlNkQWhRZlBlUWFpY2thbGhWYWxoc2V2ZkpnVmZFaERoRGNoaHBjVGNEaERhTmdFY1ZlemNRYmNmWmZEZEFmZ2dQY0ZjVWFpYkRleGRSaEpiSGNSY2NhWGJkZURhZ2F1aE1iUWVRZmtkRGVBZE5hU2dYaGplRWZCYU5lRGRNZEFjUWFsZ29hcWhkZ25oQWVlZ1hjZ2JVZ2NjTWNIZ0JmNWVhYzJoSmVEYlNlVmVwZTFhZWRFY3RlM2hlZ2pkUmE5Z1djUmRBYlpnYWVBZXRnRmJiZXhoRmVWZ09hZ2ZrYXdiUmN3YzRjbmhXaDBoZ2V4ZFRiMGRSY3FlY2FnZFFlWmNhZ2pldGRkZmRoeGNKZkdiRmJpYlpkb2NGZ2thTmJNZEZoR2RaaG1nWWVYZkJoVmViYjFncGZIZkhiVmdzYUFhSGFEY2NhL2NNY3lid2REZ2FnZ2ZNZ0hnQmFoYXhoa2NIY25nOWcyZUNiV2dnY1ZkZWNIYVliU2FTYXhkaGNEYldjV2VKY3liY2hIZkFnYWhCZmhkMGJQZ0pkemZaZUxjWmVuY3BlMGRTZmtmUWhRYlZnMmRnYlVmUmJUZ3RicWhRZ1JjSmFIYmFlUmJNZVRlWmRraGNiTmdFZFFmTmVsZERkemR3Z0NjQmdIYXdlUWZOZ0hoOGJGY1NkaGZ4Z3BjTGZ4YjhmRGVUZEJjUmRtZVplbWZGZXdmVmVXZjlhYWZSY3hoMWNBY2ZjMWhKZTBoYWMzYXBjamhUYVdncGdMY0RiMWFKYkdmSmNSZDVhMmRPZkZkSmJmY0ZmV2VsYjZkT2hFaHNiWWFRYjFhbGVpYmNlbmRCZ3doU2FFZU5mSmJXY2liWmQ0YVZlbmVjYnVjWmZ4ZnNnY2FYZ2xjNGI4YVFhMGNsZUZiRWVSZE5odmRSZjNmTWRUYlJjMmhnZVZoU2ZGY0JlSGZVaFdhWmh2YVZna2JkYWtnUGVoaFFkNWNFZUJoNWRlZmNja2hzZVdiR2VHZ1lnVWdaZW1lWmVoZGNhRmJWZ3ZlRWZ3ZUVhZGZGY1hmOWZTZmRiR2V0YjZlWWIwaDFmcWhTZXdkOWJTYUVoR2VRaGFlT2FUYzhhV2NRZGdhVmg0ZGRld2E5ZFdkR2JBY1pkWmVaaEhiUmhhZGNiRWdoZ0RhU2dWZnBhMWdlZkVidGYzYWVjbWNsY1hnVWdSZmhoY2JhYkJlWmhGZUhnRWVWYUJmSmVnaGtoMGFHaHdoSmJoZUdkeGZ3ZmZhS2MxYzhneGFOZHdiUmMyZ0theWFFZlVmZmUxYTVjRGZHYmtlTmRoZ0ZjaGhoYW1nRmhHZFphbWFZYlhlQmdWY2JnMWhwaEZhU2JGYzRiR2JRYUhjWmhyZFphM2M1ZFFhYWdnZzRjUGNEZWtoeGdPYVRnSGdaYTJjVWhrZkljVmdlaEhnWWVTZlNleGJoYkRjV2VXYkphd2dKZVRlTWhiYVRmbGJ0YlliZGhXaFZmV2NhZm5jb2hzYlZjd2RWZ01hTWcyYWdnTGRSaFdlOGVSaEVjMmc5Z0hiY2h4Yk5lSGRhZUJlVmZJYlVhaGRKZkVoSWZHZ05nQWdXYVNiOWh3Y1VoV2dwYktlVmh4aFlkc2VZZ1VhcGZFZFRoQmFSZm1hWmhtZ0Zid2FWZFdjOWRhZFJmeGEwY2RiVmJWY0pnMGVhZ1NhOGYzaENmMmdkYWFnR2dSYTVhVmhaYmtjeGdyaGFhMGI5Z0NiVWRIZUZnY2hFZGtnc2VZZ1FhMWdsZGliY2NuY0Jld2NTZUVhcGVKZEFoVmc5YjRnU2MzY2RkNmJhZ1ZiZGRaZUViQmZsZW9lQ2QwaFVkbWhWZHhjTmFuZUVhM2gxZmZiQWZpY1poU2ZIZUJjaGNIYkRnR2NaZGdhVmVrY2tlMmFjZWdmTmE1Ykdhd2Q5aFllTGRqY1ZnZWNHZ0hhb2dVaGRnR2c5ZWhkSWZoYkFnN2NEYXhkVmJUZEhiVmJoY0RmYmIwYUZlNmRZZDBiMWhxYVNkd2g5YlNiRWFHZ1JlTWdkZW5oWmhhZURmQmNWYmxmZGhnYkJmQ2dGZUVkTmFSYk1lWGdKZy9nYmFVYWhkUmJRY0ZkWmQxZmNhQWdwZzNjZGJYZlJhWGZTaHhha2NWaGFkQWdNYU1oYmR4ZDRiT2ViZjFhVmM2Z0NnR2IxZm9oRmVVZ2hjUWJSYnhoQmJtZ2NlbGdZYVZhTmIxY2hoUmhkZTFkZGRLZEZibWJsYmhnRmFoZGhobWFRaGlhY2YwZlliU2JWYk9iUmRWZHBoSGFIaFJnMWdWaFVlbmNSZ3JkZWVtZ01mRWNMZ0Vlc2RIZUhiUmdsZWtjRmMxZXhkMmVVZGtnSWhWZmVmSGdZYlNlU2F4YmhoRGFXY1djSWdrZ01hU2JKZ0loQmdVYmxkSGdkZVhhVmVhY2JlRmRCY3BoVmUxZmtlUWJHYVdkZ2VMYlJhV2Q4YVJlRWYyYzhiQmZQYkVkRmFIY1ljRWVCY0lkVGdVYmRhWmhmaFhhSWhGZkZoWGNSY3lhQmFHZnhlWGNIY3hlMWZpY2FkRGR3Y1lmWmNoYlJmbWZaYm1kRmR3ZlZiV2E5ZWFlUmd4ZzBjZGJWYVJic2h5Y2FhM2NJZXJhUmJUZjVkSGhEYXdiY2FaZlphRmZGZnJkYWQxaEliS2NIY1NjcGc2YkVja2FZZ0poUWQwZFJkL2FiZTNmQWIyZlNmRmR4YkplU2RuaFZlaWNTYXliSmQ2Y1phRmFjZ2ZiR2ZSZEJib2JVYUdmOWF2YkViUmdOZnZiUmIzYk1hVGVSYjJiZ2hWZlNnRmJCZkhkRWNHY1pneWNIZDFmTmZxZ2VnbGJsZDZmUmNrY29kTGVkZkhnd2JXYlhjbWdZYVNmWWRHaFpicGNOZ2xjVmF5ZldoaGdJaFVlRWVWZVVhSGJkY0djWmc2ZEplVWUxZmhhU2F4aDVkU2VEY1hobGZSZmRkamZkYWJoU2h4ZFVmcWFNZTBoWWNlZFNoZ2YxZlpoSmVIZUpnNmdjZEFjWmRZaFlmMWZwZTFnZWNFZ3RmM2VlY21obGVYZ1dkUmVBY1piYWZBYXRnRmVNaGhkRmdXZElheGdRYTJiRWEwZXBoNWJGZlVkbGZOYldmaGhBZGdhY2JsYkFmVGNhZ25mb2hFY2RlMWFwY1hnRmNqZXhhaGFHZXhnZ2NnZUhiV2VwY21hYWVUY1pnVmhjZ2xmcGhLZERmQmRSYU9oZWZIZFJjcmZlaG1oTmROYWFoa2FzYlBhVWNoZ0FiNWNUaERoTWU2aEFkUWdjYy9hZWFIaFloU2RTZHhnaGJEYldlV2ZKZ3liY2FIZUJoSWJCYVFkWWJJZ2RkWGZBaENmZGEzY0ZlcGJGZGxna2dPZ0dlVGRzZUxlUWQyYWtnUmdHaHlmWmhIY2JkaGJNaFVhYWRCZGhjSWNFZFVnNGNjZFphaWFkZldoQ2hHZW9jN2NTZm5hY2ZDZFNmZ2NoaDBkWWhRY1lhRGJaZmtoRmNyZWFnMmdoY3dkRGRrY1ZlYWFSYnhoMGFkZ1ZjVmRKZzBjYWEzYXBnamhUaFdlcGdMZkRheGVSY2ZjTmZrZHhoK2JJZ0JoTWZRY0ZoVGFSaDJoRGEwaHNjWmZVYzFiVmFpZk1lWGdCaHRnU2dGZ05mU2dXYmpiUmU0ZVZhWGJjYzVkY2RsYWNoYWVHZHhoSmZoZklhVWVWZXZlRWJSZk5jdmRSZzNnTWJUZFJhMmFnZFZoU2ZGaEJkSGRFZUdjWWY3aEVmQmZWY2lnT2RsYmtnamZXZDBhcGZEZ2FoV2hvZFdlV2UyZDhlVWdaZDNodGQ4aGNhQmExZm5nQ2ZFZnNhZGRYZ2xneGViZGRiRGNCZlFnWWUwZjFmcWhTZndjOWNTY0VkR2NSYU1kZGZuZ1plU2dRYWhoVmc0aGRoaGhKZ0xhVmVFYk5nRWZZY25hTmhoZ2FhMmNKY0RnU2NWYXBhMWZlY0VmdGMzZmVnbWZsZFhnV2FSZkFjWmdhaEFkdGNGYmJmeGZGYlJkUGdRZklkeWZXZkZheGVDZkZjVWNoYlFhUmJ4Y0JibWFjZGxkWWNWZmFmbmhKYVJmZGgxZmRkS2RGZ2pkUmJMZUZoaGZoY21oRmNHaFpobWdZZ1hjQmhWZ2JhMWVwaEhmSGJSZjBlY2RGZUhjUmJqaE5kbWNwZk5kT2RBYTVnYmVCaDBiSWRxZ1RmQ2NOZHRiZWRFZElmVmdlZkhlWWVTaFNoeGVoYkRjV2ZXaEpoeWVjYkNjMWhpY1FhMGZsaGFiZGVYZGhiTGNkYzNjcGdwY1Zmd2d0aFZnVGJUYjFlWmdDaDJmOGZjZ0FlbmJSY3RkY2F4ZE5kSGNhZUJoVmdJZVVjRWZkZE5oVGFIY0pmV2JGZ1dhcGF5YVVlWGdkYlhkRGJFZ01obmVJZGtoSmVSY0tkVmhwZG1kQmhXZGtoa2JXZVdjOGJJZlNoeGMxY1ViV2hWZElheGZZZm5hb2Q0aFpiMmdwY0xiRGcxYUljUWRaY0VieGcyZ2RnbGVJY0xnRmZXZlZiMmhmZ0JlNWRWZ0FhUmd3YndhZWdqY2xkNWJTaEJhOGRWZVdnbWhWYWpnWWdYZGRmNmNhZlZlZGJaZUVmQmZsZW9kQ2EwZ1VjNWZVZ0VnRmN2YUNlSGRNYk9nUmh6YXdiYmVCZ0JlVWNKaFZkemFJZzZjVmFoYmhjcWVPZjBkcGJkZ1ZmMGZvYldiYWZXZEVoV2JHZkdlWWhVZFpkaWFOY2hoYmQxZFZkbmVVZ2dnSWRkZUFhRmZVaDhjSWJTZ1lmNGVKY2hnOWhpY0RjZ2ZaYmJkSGRHYVFnSmZkZG1naGdTaERkUmNWZStiY2VCYkplRGRYZVVlTmFFY1lmamQxYjVnZWZVZmhjWmNTZFZlSWJ3ZWVlRmRaZjNiTmNXY0JmTWVjZ3hnQWJaZGFjQWJ0Y0ZkYmZ4YkVnVGViYzBhY2dsZVViaGdWZ29mWGdVZ2hiTmZSZDBiSmNvZFBjaGFOY2JiTGNTaFliWmJiZUhoMWNLYUZobWdsZGhjRmhoZmhhbWJGZkdkWmFtaEtnRGNaYlZlWmh4ZUpoSGFHYUJiMWhIZlVhbmVWaDJkWmMyYk5mZGZZZzBjdGNiYUdia2dJZHJhR2IzZFlnNGVGZHhnVWJWZERnQ2I5Y0NmRGFuYzBoUmRDZnlmMGVnZ2VmSGhJYmhkRGRSYjhnYmFPaFRiRWhQZGRmemFJZ3NiRGMxZmxhRGdUZ1RhcGhDZENoeWhnaFRiR2VuZlJldGhjaHhlTmFIZmFjQmVWZElkVWVFZGNnUWNaZ2pnZGhXZ0NmMmFvZzZkVWFYZGhjWGJXZkJoWmN2ZFpkeGJZZFFkSWd4ZlJnN2NaZmlnbGh3ZVdibWc5aEljVGVnZllnM2ZWZlZoSmMwaGFhM2NwZ2pmVGhXaHBlTGVEZnhhUmNmZ05ia2V4YitmSWFCZ01iUWNGZFRjWmQyZURoMGVzZkljV2dGaGtnbmNjZW1nNWN3Z0JibGRoYkpnVWNYZjRkMmhRZW5mY2RoZFFiMWJkY1pmRWJCZ2xob2hDZTBlVmV2Z0VmUmNOYXZkUmN5ZFZoU2ZGY1dnaGhHZFNhRWExZUhjUWZDY2NjZ2dCZVZjQWNEYlBnQWdWZC9hQmdVYVJhRmVQZENjTmJGYVRnRGdRYWNnZGVHZVpmcmhjZ0JkdGVqYVdjbGZVYlVhRWZWZVZiRGVZYm1nSmJoYlNlVWYxYnFlU2h3YjliU2FFaEdnUmRNZWRjbmhaZVNlUWRsZXdoK2RkZmhmb2ZDZFNoeWQwYVllRGZIYW9mamFlZ1VmRmFEZ0dmeGc4ZGhoTGdSYWtnNWhlZGlkZGVNY2NkeGRBZ1pjYWhBYnRkRmViZnhiRWRUaGJkMGZkZnpmRWF4ZU1nVGNYZ0VnaGdiaFJmMWc0aGJkY2NrZHNnVmdPZVdobGI3Z2RoMWRkaEtkRmZtY2xlaGNGZmhjaGJtY0ZjRGR0ZU1oWWVYZUJnVmNiZzFmcGJIY0hlUmUxZVZlVWJpYllmdWVMaGphWWhmZUpmRWh0ZEJjU2ZUYnBha2FUZEhkWmMyZ1Vna2RJYVZnZWNDYnNoNGhTaHhkaGREZldhV2ZKY3liY2VIZEFnT2VGZmdoY2NaYklkVGdFYUVoT2FYaG9jcmZYYndnMGdjYkdlVGhvYUhkUmdTZ1lnZGhFYXlncGVPZGNoMGVoZnRoYWdCZ1ZlSWFVZ0VjY2NRZFphbmRKZldhRmFUY2djM2dCY1NiSWRGY0JoQmZZaE9mYWNYZjRkUWFOYkJoaGJtZE1hbWY4YzhnRWJDZEVnZGFFZjFoVWhkYVdmRmVJZzlhWWJuY1pnamVHaFdnWmZMZFJlbGc0ZFFkSWZVZ1ZndGhYZkZiSmVDZEZnWGNoZDJkRWhrZHNjWWhIaG5lTmFpZmNhbmZCZXdmU2FFYk5oSmZXYWpnTWd0YUJlVGJRZnVjSWJCYmdiWGdFZEhleGhnY1hoMGRsZXZnUWJ4YjlidmhEYm5hOGhUaEFibWVFY1ZmRWMzZHBiSGFFZ0dlWmJ5aFZnaGRWYnFoY2VsZUZoM2RCY1FnOWJDYlBiRGFOYllnR2JBZEVjY2RFZkdiNGZ6YWVmVmJsaHZmRGhrZ3NiZGRWZ0ZobGRTZ01mV2RKZWhkU2JVaDFkcWZTYndmOWFTaEViR2RSYU1iS2cxZHhhU2dRZ2hhVmQ0ZmRiaGNKZkxkR2JBaFVhTWNMY0RkRWVrYk9jUWFjZ05lU2dTYmhnOWdMY0VnZGgzZktkR2JWZVhnRWdCZndjWmdMZ1FjSmJGY05kRGJzYVRkYmQwZGRmemhFYzBoZGNvaEZiVWJoZVFhRmNWZVVkeWdKZ3dkUmViaGFkaGVkZFpiSWExY3RoS2ZSZUdoVmRoYlhjeGdSZG1kVWJXYzljOWNTYTNlQmVWZGJhMWdwZkhnSGZSaDFoVmJEYjFoNWNyY2VkbWNOZk5kYWNrZHNnUGhVaGxmWWJ4Y0FkamRVZmlmR2R3YzFjYmRlYkNmNGJhaEhmeGdSaERoQ2YyZDVmeWhPZlhleGFJaEJla2JCZ2FiTGhsYUpkTGNkYTNocGZwZlZoMWZrZ1FlR2FXYWdhTGhGZ3licGRGY1JmamIwZEpoY2IzaFJkUGJFaGhiMGFhZldmVWNzZlFnTWhuZzVhV2VYZ0doWmh5YkZiSGU1Z01lWWNCZVphcGJZY1JmWWdZZlpiaGdSaG1hT2YwZnRid2dWZldoOWFhZVJleGcwaGRiVmNSYlFhaGVKYVRja2UzYkJjQ2FVY0ZjRGF6Y0FlWWVNYUVmQmUyZEplRmE1ZENjWGhIZVJjMmdWZzBhSWJZZEdkSGZOYWljY2JuZkJld2dTZ0VmTmRKZ1dnbmhWYTRhR2JUZUlodWhQaEFjVWdYY0VkSGU1aGdlWWNVYzBnOWdIZlJhTWg3Y1NkVGI5YVdmQ2JTZDllQmJBY0ZjQmdLaEVlQ2Q5ZzdoV2JoY1VkK2hmZWxkRWQrZVdoMGNwaFRjWWZIYm9kOGdHZ0diWWJVZ1pjbWhaZ2hnY2ZGZ1VoeWJjY0ViY2NkaEhmVmdWZVNiZGhHZHRkNmVKZ1JnZ2ZrY0NhRmRzZ2JmWGR5YXBmTWZBZm5kNGJHY1RmaGZVYXFkZWJoZUllQ2JFZVVoTWRDZFNhSGZKaHdoY2ZFZ2hjRGNTYVZncGExYWVjRWhzY2xmUGF6ZzBoQ2hDZTFoNGJaZEdlUWVVZkRiUGhWaDViZWFEYVJoNGZuY1ZlaWhZZzZiUmR3aGtmSmNUYXdmQmdtZWJlMGJzaEliYWFpaEJnUmJjaFZiRmFLYVhmMmdsZThlQ2h3ZFZlbWRRZUdhZ2hxZ0pmRGc0ZVNhT2Z4Y0plSGJBZmhiMGZCYlVobWU1Z3JoTGZtYTBoZWVKZWdhSmJNYUZmeGZnaDJjUWhIZlllL2FXYTBmc2VPZlVhbmdZZ1NjU2d4ZWhiRGhXZldmSmV5aExlVmJwY0lnUWIwY2xoYWNkYVhmaGFMZGRjemZ3aDhhR2NSZnBkRWJVaENlZGJGZFJiUmE4ZVplUmIyZ05kSGRJZ1JjOWhIaElmUmV4Y0loQ2YyYjBkUWRaY25kSmNXZUZlV2hwZ3lhVWFYYWRoWGJBYXhhWmUwY1loWGd0aFpjTWhsZHhmb2NLZXlhZ2QrZVhlVGd0ZVVmQ2IxZWhmVGNFYmdjWWU4Z1pmM2NvZ3FmUmJIYUZkaGREZDFmSWNRYlplRWR4ZTJnZGhsaEpoQ2ZGaFRoNGc1ZFFoRWdzZFFkRmhSZ2dkd2FjZmpmVmN3Z1ZoVWhNY3ljSmUzYmxkNGNCZEhmZGhuZmFhUWdWYUNnRWJGY0Jlb2ZGZFVnVWFnY0NoaGJOZm1iUmh5ZGdlNWVSYjJnZ2VWaFNhRmFCYUhiRWJHYVpjeWZWZGhiVmZxY0plQmdBYmxkVmJ3YkljV2FkY0doRmJDZVloeWhsZXBoYWFrZ3hhaGJjZkZmVmF2Zldla2NjYmRmSGNWZlZjU2FkaEdldGU2ZFlkd2hOZXFhVmRnZDhhY2hSY1NiZ2RBaGVnbGF4Y1NoUWdoZVZhNGRkZ2hmSmZMZUdlRWFOaFphWWRuY0pld2RjYUJkdGJEYlZjRmVvYjlnZWNGaFZhM2JhY0hicGhPZVdhUWY4aFpnZmdBZnRjZmRiZDFma2NUYmNoVWVkYmhmQWFWZ1Jhb2JDZGtoaGVEYVJkd2RwYm1lT2JsYlloTGFhZG1kTmdJYlpmbGRkZVZlRmRuYXRkaGNEZkJhaGgzZURnMGV4Y21hWWdYYkJhVmdiZTFncGhIZkhoUmMxY1ZjVWduZlFhaWVQYkdjTmRGZ0lnMGdzZlJnVGJ4ZkFkcmJUaEhjMWMyZEFjVWVzaFZiSWQxY3diU2FTZnhkaGNEaFdmV2JKZHllY2dIYkJiSWNRZzBjbGFhYmRiU2I0ZEtmSmVYZW9hb2FXZDFjbGNGaEZhV2NoYk5kU2hXZjlmZGZDZ0VmVmFIZ2NheGROZ0hkYWJCZVZnSWZVY0VnY2ZRYlpibmZKYldlRmVUZGtlbGZHZENnTWVVaEFkaGRaZ2hkTWJoYjhjWWFQZFRhNWRtYlphbWZGZndnVmJXYjlmYWZSY3hoMGZkYlZnVmdKYTBmYWYzZ3BoamREYWlkc2hZZFNlbGNJZkJjZmVtaFpkMmJkZWxlSmdDZkZoWGFoZDJhRWVrZnNhWWdRYTFjbGJpYmNnbmZCZHdmU2hFaE5iWWJTZ0diMWY0Z1ZkWGhjZXljYWZWaEZoZmNFZ0JhRWJtZ0NnMWZoaHZnV2ZSYnBnMGRiYlhlTWdUZVJnMmVnZ1ZiU2VGY0JhSGVFZ0dkWmh5ZlZlaGJWY3FiY2JsZEZhM2FWaHdnaGFFZ0xmQ2hCZ2RnQWIwZHdhVWZaaG1lWmRoZGNiRmRWZXZkV2FrZ2NhZGhIZlZlVmdTY2RlR2J0ZTZjSWVBYXdjNWNEYmdlOWVBY0Nia2E1Y01jZGduYlphU2RRaGhiVmY0ZWRjaGFKY0xhR2VFZk5iWmdZaG5lSmN3ZWNhRWdoY0xoQ2ZGZXBob2RlZ0JkOGNNZU5jV2ZsZ2NjV2dRaEZka2ZZZVFlZGZ2Z2JleGZFZ1RhYmMwaGRiemZFZjBlZGVvZ0ZoVWZoaFFiUmV4ZEJhbWJjZmxhWWRWZ2FjbmZKYkFkWmRVYTlnS2ZDZTNhUmE4ZkZjaGNCYjNnRGhYYVJlbWdaYzNhQWdVaFpjbGZwZEJkR2V6YmRjVmNVYm5hUmJyZ2VibWJOZU5iYWVrYnNlUGdVZmhkQmZraFRiSGhaZzJkVWhrZUllVmJlZEhjWWNTZ1FieGZBYlBhV2ZYYzljeWRlYkhhaGFiYlVna2FsZGNlZGdUYUJhQ2ZkYTJhWmMxYVZoMGc4YlplR2FUYlFjTGRUYlhla2dDY0VoMmFsZEhjTWRoYXBoT2haaEJoVWZFY1ViRmdrZVFlZGYyZ0JhQmhGY1dneGIwZlVkWGM4Z1pkU2RnZnRocGFMZFJhOGRSZ2ZkVGM1YW1lWmRtaEZnd2VWYldhOWZhaFJneGMwZGRoVmJWZUpiMGNhZzNhcGVqZlRjV2hvZEplWGRSY2RkUmVMZjFiZGRjYmRjbGFKaENkRmZYZGhjMmdFZWtoc2FZYVFoMWhsYWliY2huZEJhd2FTYkFoQWNJYkNhVGFCYzRiV2VHYTFjUWdhZVZmZGRaZ0VoQmFsZ29iQ2gwY1ZkdmZFZ1JmTmd2ZFJjM2NNZVRhUmcyZGdmVmNRZUJjRmZIYkRoV2JZZm1oTGRWZHBjcWZlZVZkRmhtZUtka2JNZWFmUWEyZEVjV2dHZEdnWWZVYlpmbWhaYWhiY2JGZ1ZhdmJXYWtnY2hkY0hmVmVWYlNoZGRHYnRnNmRhZ3hlaGJxZVZjZ2U4ZUdlYWN5Z3RhTWhmaFhjWmJBYlBoeGd4ZzBiWGRCYkpiTGNHY0VoTmdaZ1libmhKZndkY2hFY2hlRGZTY1ZhcGUxZWVmRWd0ZjNoZWJtaGxjWGVTZ0FmSWVCZ2FmQmdaaFlnY2hoZEViYmFmaGxkNWVoYUVlMGVGYm9lVmRFYUZnUWhRYlJjWmRNZGNjbGRZZFZjYWNuZEpiUmNkYzFmZGRLZEZkbWdsZmhiRmNoYmhmbWJGaEdnWmVtZFlhWGdCY1ZmYmYwaHRlVmFCZVJmMWdJZVRnMmhsZnJjY2RuY0piVWFlZEVlc2hKZVVna2RWY3RkVGJIZUJjd2RlZEVhSWNWY2VnSGVZaFNkU2F4ZmhhRGdXZldiSmh5ZGNlSGFCZEllUWEwYWxiYWdkaFhjaGZMaGRlM2RwZWhhWGZ4ZFVlUWJCYkdjZ2ZEZ1RiWGM0ZUVmRWEyYWxlSGdPY3hjcGhIZmRkQWFsZUlkUWZWaFVnWmZaY2liNWVXZEhiV2ZKYWtiUWNuaGRiUmZTZmxjZGhnaFliUWNvYUVjWmhnZkpmdmFaZ2pkMWF3ZVhiWGRsZEpmUmd4ZHNnZGVBYUZjdGU5ZFpiMWhCZ2plVGhXZHBoTGZEZDFiSWRRZFpjRWZ4aDJlZGRsZEplQ2dGZlhhaGUyZkVka2dzYlljUWIxYmxiaWRQaG5iQmV1YVNjRmZGZFpmVGhtY0piNGFUYVhlRmc2Z1lmVWNKZE1lQWNnYkJnK2hDaDFkdGh2ZFhlUmhNZHpiR2IzZE5iZmFSaDNlWWJWaFhoVWNkZFVhQmZIYlZhN2hWYWhjTmZzZ2NkbGRrZTVlVmcxZWNnV2VKZldjZ2RmaEFhMGd3aFVnWmdtYlpmaGhjZUZnVmJ2Y1dia2djaGRlSGdWZVZhU2JkYkdkdGE2aFlnMGIwYm9lR2ZVY29mVGVXZTNoOWJtZWRjbmJaY1NjUWhoYlZiNGRkZGhoSmFMYUdjRWVOaFplWWhuaEpkd2JjYUFnc2VDYUdkaGI5ZTFhYmRGYUZoZGFlZW1nbGFYZldkUmRBaFplYWNBZHRlRmZiaHhkRWdUYWJhMGZkYnphRWYwaGRlb2NIaFFkbGFRZFdhaGRBYXlhQ2VSZWtmVmdZZ1hoSmVBYUNkbGI1YUdlUGJHYWxhaGVGYWhhaGhtZ0ZkR2NaZ21hWWFYYkJmVmZiYzFlcGhIZUhkUmExYlZmVWNuZ1JocmdjZmpiWmFOaGRmMGR0YmJnS2VWYTloa2hSZjNlWmRraExkMGVzaFpoVWRuZlliU2dTZ3hnaGFEZldiV2hKZHlhY2dIaEJhSWJRYjBobGhhYWRjWGNoaExoZGEzaHBncGNYZHhkOGRRYkJmR2VoZ2ZlUGZpYUFmUmJHZEdhOWJVZERiaGVwY0xlUWJoYlZmSWhVYUVoY2ZRZ1pibmRKZldiRmdXaHBoeWVVZFhiZGNYaFNoaGVaaHBmWWJSYVlhWWVkZndoWmcrYlpibmF4YXRnU2dHZjlmU2ZWY2diUWdQaFZmVmdSaDBhS2RuZE5kamVTZDJieGNoZ0RnMWdJaFFiWmJFZ3hhMmhkZWxlSmhDZkZjWGhoZjJhRWRrZ3NmWWFRYzFjbGFpY2NibmVCYXdoU2RGaEphYmdRY25hVmRsZVZjbWRwZzZlWWJVYlpiQWVBZ2hmbGV1aENheGdCY21lRWZSY1ZicGFiZ1hlTWFUZVJiMmRnZVZjU2FGZEJkSGhFY0dhWmh5ZlZlaGhWZHFmY2JsZ0ZlM2FWaDBjb2NXYWFmV2VFY0hlQ2duZzRjVWZlZDNidGI4ZWNnRmgxZytjUWExaFVhZGNHYTFjVWZVYmZnV2h0ZDhnWmNXZGRocWFTYndjOWFTYUVmR2VSZ01lZGduZ1pjU2FRYWhlVmg0ZGRiaGZKaExnR2ZFaE5mWmdZYW5oSmZ3YmVjRWJBZFBhU2dVZmRoZmJlaEVodGIzYWVmbWRsY1hkV2NSZUFjWmdhYUFmdGdGYWJieGNFZ1RkYmYwYmRlemdFZjBjZGRvZkZkVWZoaFFoVGh4Y2hmM2daYzFkWWdUYWFmamJwY1liZGMwYnRhV2RGYm5maGg1Y0hneGhnYzZmUGZtZlplbWRZZ1hkQmFWZ2JmMWdwaEhlSGVSYzFnVmRVZm5nUmFyaGVlbWFOZ05hYWhrY3NiUGFVY2hhQmVrZFRmSGI1YStjUmhGY0VoVmFmYm5jWmRUYVFiaGNoZmZiUmhXY0pmamVZZW5nbGdJZEhjMmVOZGFkZGhYZmhjTGFkZjNocGdwYVZlMWFrZ1FlR2NXZmdjTGZSZldlOGZSY0VlMmQ5YUhlY2F4Y05mSGRhZUJmVmJBaFdnRmNFYURhWmNuZ1JkV2VRZ0doTmF5YlRlV2F0ZVhmWGJCZDljcGJQYlRld2ZZZlpmaGNSZm1mWmdtaEZjd2dWZVdiOWNhY1JheGEwZ2RhVmZWaEpmMGhhYTNocGZqZ1RkV2RwY0xmRGgxZUliWWhjaGxiOWcyYWNiRmhJaEVlSGdIZUZhNmFPZkVic2NZY1FmMWdsY2ljY2JuaEJhd2VTYkVlTmNKZldjbmFWZTRnU2gzZ2RmNmRhaFZjZGZaZ0VoQmNrZGtkQ2gxZ3RmdmNCZXdnWmg2Z1ZnR2VZZFRkUWJXYzRkVmFXaFViRmVXaEJjSGJkY2pnUmRCYVZhMGFjZmhiMWEzZFVhVWZ3YldoWWRTYThmV2VCZVdhWmFZYmJnMmc5YzZnV2dsYlZkdmdXYmtmY2ZkZ0hhVmZWZ1NnZGNHYnRkNmFZaDBoMWJxYkZjaWVWY1NnRWNHYVJoTWhkaG5iWmNTZlFnaGJWYzRhZGdoZ0lhV2JNZ2tnTmNaY1lobmVKZndoY2FFYWhlRGdTZ1ZncGQxZ2ViQWdVZmllTmFpaFZhWGJSZEFkMGNFaGFiRWFWZ3ZiYmR4YUViVGJiZDBoZGJ6ZUVlMGNkYW9oRmRVY2hnUWVSZnhkQmQ1Z2NkbGQ0Z2RhSmhIYUpiTWRkYTBjRmhmY0FoM2FwZXljSGd4YVJjbWJIZERiVmhtYWZhSGdCZ0VnWmZsZ05ldGNIZVJoMWNWZ1VibmhSZnJlZWNtYU5jTmNhY2tmc2VQY1VhaGRCYStnVGJEaGhjMmNUZ0VnSWdEZmJmV2hNYUJnWGNoYWhiRmJYaDBlaGF5Y2NnSGVCZ0lhUWYwYmxmYWVkY1hnaGZMY2RlM2dwZ3BkVmcxZWtiUWVFY1dnQmhGZ1JmV2VJaE1oRWUzZmxmU2RaYWdlQmNSYllnUmRsaGllVWJFY2NiUWNaZG5oSmZXZ0ZkV2JwZnloVWVYY2RhWGFTZ2hhWmNwY1lkVmZNZ1dlTmJrY0VjMWFMZW1jbGU0ZFhmU2RGZ2FiV2dRaE1jRGRWZVVmTmdrZVllbmVwYmxoVGdYZHRiYmVIZ1VhRWhaZ1pnQmRCYTJjWWIwYWRjUWhEY0djNWIvZkhibWFFaFlnUWQxZGxjaWRjZG5jQmZ3Y1NkRWROYUpjV2JuYVZkNGVTZTNlZGU2Y1lnUmRsZVpmRGdSYWxjOWhIZlZhWmY5Y0FiUmFNZHpmUmEzZHNhQ2hWYTNkb2NHZVNlRmJaZ0hmWGRtZDloN2JYZnhibGZBY2NibGFGYTNkVmYwZW9oV2RhZ1dhRWNXZEdkR2JZY1VlWmNtY1loa2VmaGdkVWg2ZENoUWg4Z1ZlVWcxYXhlZWZYZW1ldGI2aFlnMGQxZnFiU2F3ZDlnU2FFZkdmUmZNZGRhbmhaYlNnU2VsYnBoNGdmZlFmOWZMZVNkMGRwYUNhU2VIY0pid2hjZUVjaGNEYVNnVmVwZzFiZWdFZHNlcWJVZ0dhbGhYYldlUmVBZFpiYWdBZnRjRmdiZHhkRmNCYUtjaGdNZ21mUWVRYmxnb2JZYUVlQWhWYVRkZ2R0Z01lY2RsZFlhVmdhYm5kSmJSZGRlMWFjYlhnUGFHY2xhaGRGYmhjaGVtY0ZjR2FaZG1mSmV5ZlVoYmVMZkFiNGdPYlVjbGVOZlZnSmEzZXdkL2hjZzJmTWJXZVFnRWZzZlBhVWhoZUJoa2dUZ0hoWmQyZVVha2hKaERhT2ZTY1FmU2VHY1JmaGVlZldnVGRaYThjUGFEZFVhR2ZCYkJkMGdTZmJkbGNKZkxnZGgzZ3BkcGJWZDFka2hRZEdoV2FnZ0xnRGRDZGtiUmZHZnplc2FUYmNnd2gxZmFkYWNFYmRhQmdVaEJmVmRWYU1laWZjYUVhV2EyYW9oQmVCaFNnVWhlZ0JoRmJGZm5nSmgwY1JoWGRLZTNiY2R1ZkpmemhNY1RmR2ZpZXNhZmdTZ1ZkeGJOZUJnUmc0ZHRmWWd3YWtjM2hIY3lkTWdGYVNkRmc0YlFmTWhFZlZodGNYZEZlSmhDZEZhWGhoYzJjRWRrY3NmWWJRZTFia2hrZFBiU2RKZndmUWVCZlVnSWRDYkhlVWF4aFNnMmNwZjZkYWIxZ1ZhVmJFZUZheGhvZ0Zka2ZWYi9mQ2JoaE1mOWhSZTJjMGZUY0FhbmRNZVZmUWRYZ3BhSGFFYUdiWmZ5ZFZjaGZWZXFjY2hsZEZmM2RWYjBmcGJmYmFiV2hvZkxlR2FCY1ZoQWZOYUNkOGN2Zk5jMWdzZnBjQ2RBY2hhUWJmZmhiMGJUYUpmZ2dnYjFmSmh3Z2hma2hDYmxiOGhDZVhkRGgxZEVlQmFTZUlmQWdDYjFic2IvaGVnaGZJZ2ZlRmNoY0FhVmZLaHphRWIxZmVkQWgxYlBmU2NWZklid2NlaEVoQmdxYmVlamcwZURlVWJCYmtjUWRjZHllRmVGaGJmeGFFZlRmYmYwZWRhemJFYTBoZGRvZVJhd2gwYUVjRWRrZklmb2hjZmhiOGZPZlFhSGdKYlJhZGgxZ2RkS2FGaG1nbGhoZ1NmemVKY21hRmdHYVpnbWJZYVhnQmFWYmJneGh3ZlNmVWExZDRkQmJHZnpoc2VsZGViaGZCZUZoUGhrZmNnUGNBZUJoeGJraEJnWGQ5ZzJlQ2JXaGdkVmRlZUhiWWFTYVNneGdoZ0RjV2hXY0pieWhKZmplRWFhYlFjd2h4ZWFlYWVIZmhnSmRkZVdmRmREZFZiMWNrZFFoR2hXZ2dhTGVSY1dmOGRSYUVmeWVaZ0hlYmRoY01hcWhLZVVjRWFBaFhlZ2dwZVpoS2VIZ29mQ2ZHYXlnWWMzYUhjemhBZkRhQWhoaHBncGdLaEJlOGhEYlRlQmhSZm1nWmVtZ0Znd2hWY1dhOWRhZ1JneGgxY2JlR2NnZUJkMGRZYnlhd2VpYUhmMmRvY0VnRGMwZzhmUWVOY2xmZGYyYVBkMWFKYmNlRmRUY2RodGNFZmtoQWhUYkRiRmRCZ2llTmQzaEJoN2VWZ1VlTWE2YURjaWhjaHhlQmNUYUJlMGRMY3diVWFXZFhnWGhvYWdnU2hoZmNhTWVYYWxiY2FxY1RhMmZJYUJkVWJHYWdiVGVTZ0FoUWg4Z1hkeGR0ZjdnVGdUZDlkcWFjZWxkRmMzY1ZoMGFvYVdjYWhXZEVkV2NTZmlkTmJBYk1kemRRYXZoY2VCZ0JlMGRjZEVjY2ZkZEhoVmJWaFNjZGNHYnRnNmNQZG1kZGJxYVNhd2Q5YVNjRWhHYlJiTWZkZmpjQWJIZ0RoRmZZYXNmUGExZDBlRmNHZ0NlcGJSYU5mbmI1Z3dmSWFrZVJlRGJBY0ZnTmExZkllMmVGZDNoZWNtZWxkWGNXZFJlQWVaZGFjQWJ0Y0ZiT2hWZUJoQmJiY3diSmN6Z0Rja2dkZHFkRmQxY05jNmFSZXhmQmZtYWNibGJZaFZiYWduY0piUmZkY3hoNWNLaENoMmhrZ01jVmQwYndkdWZHZ2lhc2R2Z0xnM2RnZkJnWWJSZFlnQ2dVYTFkb2VCZEdjbmNoZHJnTWcyZHBlV2RRZEVlc2dQZ1VnaGdCZmtiVGdIYVpmMmNVaGtmSmFUYU5keWRRYVNhUWQwYjRiQ2hDYjJkSWI5ZGNiR2ExYkljRWVWZEpkYWJQZ0hmaGdWaGRjemJWY3loVmQxZElmYmFWZ21oRWhMZ0FhR2I4aGFjRGVtYThjMGFKZTBnRWJPaEphbGJKZ0dnRmNoYlZkZmhLY3hhRWdlZFZoRGhnZVJiSGJqZ01lU2hRY2tjSWVTYkxnbWNzY1JmZmdUYzVnbWJaZG1jRmZ3aFZiV2U5ZWFhUmZ4YjBmZGVCYnhjY2ZnZFBiaWJnZnRjVGRTZTliUWFKZVZkSWRRZVpnRWZ4YjJiZGdsYUpnQ2hTZUZlSmUyZUVja2VzaFlmUWUxZGxiaWRjZWplWWVsZEJiZ2VBZGRlRWZ6Ym9oMmVTYXlnMWJ5aFBhVmR0aFpmUWJoaFZjb2dRZWtoeGF2aFNoamdsZnZoUmgzZE1lVGVSYjJiZ2JWZVNiRmhCZEhjUmZpY2NkZ2VWZGxhQmVxYmJlMWFFaGpmV2VRZFpjVGdKaHllWmhDY1VmSGUwaCtmWmFtaFpoaGRjY0ZmVmN2Z1doa2RjZWRhSGJWZjFoVGFKYm1ic2dtYVBjMGYxZDZnU2J4aEZlU2NRaG1hMWZNZmNiSGJCYlNjU2JrZmRnNGJhZXhlSmJiYUViVWM5aFpkYWNuZU1jNWhjZEJjUWFmZlNiVWhwZzFkWmdrZHNjK2NlZGpmVWhMYVdmVmVrZVpoZGVnZHNjQWRaYmhkRWJWaGFmVWFkZDdmV2hraGRiMWRGZFFnMWRaZVhiRGZwYW1lY2RsaFllVmdhZm5mSmJSYmRoMWNkZ0toVWJDZVlhemhGY2hlQWN3ZFZiVGVSYm1nTGduZEJlSWFiZzFhaGFGZ0VmUmYwaGRlVWZtYmxjcmhLYUhkaGNOY0lkMGdzYlJhVWNsYWhmL2RUZUhmMWI5Z0dia2RzZlZjTmYzYVljWmVWZGhlZ2U3ZVVhVGRZZEplT2hBYjFjQmZXZ0dkTmhhZGRiWGNoZkxkZGEzZ3BlcGdWaDFla2VRYlNjeWIxZmZnRWREZTFnZmRFZnllQmZjYldkUmFOYkhnYWVCYVZkSWVVY0VjY2hRZE9jMWZoZ1dmRmFXY3BheWRVY1hiZGhYZ1NibGZBZDhhTGgxYVZjTWVMaDFhc2FvaFphaGdoZDRiQWJXZU5jYWVGZVJjRWVkZkhkRmV0ZjBkTWhGaEJkamJUYldlcGFMZURlMWVJZ1FhWmhFZXhjMmNNY0JiMGZRZ0ZjWGZBZmdmVWZ4ZmtoWWZCaGxmbGEvZWNoaWVSYitlR2V3ZDhiQWJHaFRoQmd3ZUdkWGZ0ZjZoSWhGZTVnVmVFZkZoWmZvZUZha2dWYnRkRWh4ZDlodmJEYzNnTWNPaFJkM2ZnYU9hU2RCZmhmSGFEZ0diWWEzZ1dlRmFraHZiUGNCZ1lkamRIZTFoRWFXaEliV2hFYmRlQmdXYVljR2NiYzBoeGZoZ2NmRmhWY3ZnV2JrYmNmZGdIYlZkVmNTZGRlR2hzYTFkWWUwZFphM2ZTYjNjd2RHZlFoaWQwY0NiTWdYaGdkVWVFYUZmb2YxYkZoVmZvYkthU2RpYkFkV2FKZGpnZGI0Z05nVGNNY0xkTmVGZXBnK2FlY0ZjbGJpY2JkR2dsYWRmV2VWYVZhaWFJZkFndGZPZGJhd2VCZ3VhWmVsZnhmWmhFYTBiZGRvYkZoVWJoZ1FlUmZ4ZkJibWVjaGdnUmRRZVBnaWdjZERkT2RWYWNnRmhEYlVlTmRoZEZhaGFoZm1nRmNHY1phbWVZYVNhMWIvZGJhMWFwZ0hmSGRSZTFnVmZVZm5mUWF0aExneWIwYU9hUGJnYUpnQWJIZkJnQWRKZ1JmQ2RKZDZoVWVoZEFhWmFlZ0RhOGdiY1NiMGROZ3BlV2NXY0pheWhjZEhlQmdJYVFiMGdsZmFhZGdUaEViTmVkYTNkSWU5Y1ZkMWd3ZlFoQ2hHZWdlS2NXYUhkSWRSYUFoMmU4aGJnTGh4aE5mWGhhaEFidGRJZkJlRWM0ZVFhTWJqaG9mRWZXaGpnMWF5aEhlemRJYUFiU2RtYVFhb2dMZDFjRmJkYUFmMGhZaDBmS2FUZE5mNGhWaHllQWFjY0FoVWQ1YllmQWdWaElmOWRPYUhhb2N0YUFoamQ1Z0xhV2FoZXRjZWRNYUVjNWEvYmJhWGhoZENkRmFYZWhhMmhFYWtjc2NZY1FmMWhsY2lhT2Z6Y1pod2ZRY0JnZGdKZ1VlWGNVZHFnU2UyZmxnNmVJYkZkNWh6ZkVoQmFsYm9jQ2IwaFZndmZFZ1JoTmV2aFJkM2NNaFRmRWZ5Z0JhSGhCZHdlZGFIaFhhaWhNZWxiVmVtZGNkcmNQZ0JlWWV5ZE1maGdoZ0VjSmVqZE1jZWdHaGhkSmhHYlBleWc4Y3ZnTmgxYlVmN2FGZFVoZGFjZlhhaGdZY1hhSmZ6YmhkNmJJZlFiZ2J6ZEJjRWFFYldoRWVDZVloWmJNY0RoQWFYZkVkQmVVZTBoTWIxZHdlTWVUYUFndGdiZ2FmMmJsYWFmY2RFZGhlRGZTY1ZkcGYxZWVoRWFzZHFoVWFHYmxoWGFXYVJoQWJaZ2FkQWJ0ZkZhS2FVaFJkZGhMZUJmTWI2aFhmQWZsaG9hZWZVZUFjRWRTZ3hmQWEwZ2ZmbGhaZmNmWmFuZUliVWZlYjFjY2VGZEdobWZrYXBoSGJ4ZmdiOWdQZG1hWmJtZ1llWGdCYlZnYmIxZHBmSGdIYVJjMGNjZkZjSGFSZ2pkZWV5ZzFnRGhJZ3hiaGN0aEJmMWJZYWllQ2VTZlJhK2JCY2thc2hjaFVjbmFZY1NmU2V4aGhiRGJXYVdjSmR5ZmNkSGNCY0lnUWN4aDBoU2JKZXphY2JjZmRkemZRaHNnQWVGZmxoa2dRZERjaGZPYUlmRGExY0RkWGdEYjFhUGJkZEJjRWhGZFBoVmVNZU9mRmdSY1VmU2FaZWpoTWZFZVVlamQ4YS9hRmREYWtlRGNTZ2xic2I4ZE1ja2VJaFljSmdGY0ZlbWJKYzJkRWJTZUFnQ2FrY2NoQWJraDhkZGFIYkJnd2NuaFBjemVzY3RjRGhpZjlkTWdCaGtia2U2ZFpnRWV4aDJnZGNsZkpjQ2FGYlhiaGgyZUVlZ2RKYWViUWgxY0Vnd2NjZ21kNWJ3YkJoMGFNY1ZlQmFuZlVod2ZTYTJjbGY2Zk9mMWM1ZXpnRWRCZ2xmb2ZDYTBiVmd2YkVnUmJOZHZlUmEzY01mVGZFZHljQmZIZ0Jod2VkZ0hlWGRpYk1jbGNWZ21nY2JyY1BnQmdZZHlhTWVoaGhkRWNKYWpnTWZlaEhlMmJSZkNjSmh5Z29kMGROZlZmZGh2YUdheGVWZ2FhU2FCZGdoWGVPY2pkOWU2Z0tiaGQ1Z3FnQmhGZW9mR2ZFZkNnc2FLY2RkamNRY2RnRmcxZnNlOGdKYVJmVmFDZUFjMmhsZFphWWFuaEpod2djZ0VkaGJEZVNnVmVwYTFjTWFRYzFlM2hjYmlnQmdYY1VmaGJCZWNiYWFCY1ZoRmFPZ3hjOWVmYktmZ2NrYTBhUmN3YzlmaGNGY1Jkd2ZZYkZjVmQ4YXhlY2hoYmhlUWFQYVhkSWZqYU5maGFrY05nVWZ3YXdiemJSZkZmY2EwZUhjR2FRZVBlTGN6ZVFlUWROYjFlb2ZJZlNoRWNsYlZiSGJUZUphcmVLZENoSWNEYkxkUWY0Zk5oV2Z3YnRoT2VUZ0hiWmQyaFVma2JJaFZoZWFIYlplUGRZZlJiaGZEZVdjV2RKY3loY2RIaEJkSWJCYVJnd2ZVYU5naWF3ZUNjT2FEYlJicGZPaEZoRmVFZEZiV2JoZlpkU2RXaDllWWhIZDJjOGJDaGVjaGRNZGNhUWJoZlZnSWhVZkVoY2VRY1pobmFKZldhRmZXYXBmaWVVYVdobGdYZkdkQmJaYnZoWmR4aFljUWNOZUJjUmM3aFphbmFkZ2xhUWVIZHhlUGVSZHhkWWJkZEJkMWVKYi9jYWUyZXRhcWdWYmtjQmNMZURoMWdJYlFkWmZFaHhhMmJkZ2xoSmhDZFVmemFjZ2tnRWZrZk5lT2NBYmdodGZpZVBjWGRCZnRmU2hGaE5mRmFXZ2pmMWI0YlZibmNjZ1hiS2hBYk1iUmdIZ2xhUWJoZFJjVWMwZjdhSGIxZzhicWJDYlRhUmdIZURnMmdnZVloU2NCZmxnTGRFYUhjUmQ3ZFRmUmJVZWljY2drYzloM2VHZkZiRWJXYVlobWFwZFpoRWhVaHdmVWdaY21nWmJoYmNmRmhWZXZoV2JraGNmZGNIY1ZkVWVHZ0RieWNKZjZjYWhFaDBnbGdOaGdhOWNQZE9hbWVSZk1lZGZuaFpnU2dRY2hiVmQ0Z2RmaGNKZUxnR2VFZU5jWmZhY2lhQmF3ZWRja2JoZ0xnV2cwYTlkZ2dlYkZhZGVyZGVibWRGZFBlV2hSZm9oWmhZYkVjNWFGY2NjQmZGaGNhYmUxZDFiemJBZmtmZGZsYkZkUWZkZVpjVGRoYWxhdmVjYWtiZ2hMZGRmSGhKYlphYmExZWRlQWZGZG1hRWdrY0ZjZ2ZkZW1iV2YyYlpmOGdZY1doRmJWZFlmbGdvZUloRmhCYVJoT2VlYUhoUmNyZGVhbWNOZk5lYWdrZXNlUGREZHpncGFrZFRlSGFaYjJlVWZrYklkVmFlYURmQmhIYkJoVmVzZFhkRWNDZTBkOGRjZkJiNWFBZUZjMGVWZWFkSmczaFJnTGNQZm5lWmZwaEVibGdBZ1FiUWRrZkliTGNSY1dnOGdSYkViMmU5Y0hkY2N4Zk5iSGJlYkJhVmVXYlVkQmRVZVFmWWVIZ1JnV2hIZFRiaGd5ZFRlSGhkYkRiV2NBYTloOWhlZEFjQWdQZGRhQWYxZHplWmJtYnBld2FCZDJiOWRSZVJmd2F3YlVjVGZuZWhlMGhhYjNlcGFqaFRmV2NwYkxoRGIxZ0lnUWZJZ2djTWJrZmRobGFvZVVkVmFDY3BoMmdYZFVhc2FGY1FlMGJsYXVkY2ZqaGhkd2FWZ1VlTWRrY0dkeWVFZ3doUmNUY29kemdKZzFjOGNOZ0hkbGNVY3RmUmZRaEloN2NXYlJlTmRpZFJnemFvY2ZhUmUzY3djY2JVZTFmQWFQYkVoSGVoY3loR2NRaDVlcWhlZ1Zlb2c0ZFhobWhBYldmYWdXZEVlV2NHZUdhWWZVZ1plbWNaZ2hoY2ZGZlVoN2FJZVFhNGdkaEZjbGJVZWRiQ2RXaHRibmhZZTBnVWM0YVNleGhGZE1kRGhtYVJiRWNiYm5mWmRZZFFkaGEwZDllZGVnZTFhTGhWZTBkTmJEZVlhbWFGaHdjZmVVY2dhTWNRYkZiTmI4aGVkRWMxYzNkYWdIZHhhQ2hRZ2pob2daYWFmQWd0Y0ZhYmN4YUVhVGFiaHhocGdaYkViMGNkaG9oRmZVZmhmUWRSZHhoQWJnZkpmeGZoZldnUGJqY3NmZWZPYlZhY2V1aEhjamExYnRmRmJrZ3BlcWhGZENmOWFxZFllVGZWY2NoYmN3Z0ZhdGRIaFJkMWVWZlVnbmVSZXJoZWVtYU5nTmJhYWdiSmRKY1VnaGRnZHRjVGVIZjFnMmZGZTBhSWdMY2VoQ2hJZGNjQmUxYTBlTmNIZGpkWWE2ZmVoWGhBZmNmQ2J4ZHNlVmdJYm5kZ2NGYU1iaWExZ3BiSmhSYWhhZWFYYmlnMWN1Z0ZiemYxZGVnUWhXZmRkRmhHZmxoMGFEYUxkVWgxY0lmSGR4Z0pkRWhaZ2pnMGFRYkZmVGNnaHpiSGh6YUFmU2FTYkJnOWJ5Z1NoeGJZYlloWmNoZFJkbWRaZW1mRmV3aFZlV2Q4ZlRjQWdSZjBmVmFSY1ZoSmhxZWFkemNOYnFjVGJUYzRlRGZYaFJoMWNIZFphQWNJZ3pnSWFWZElld2dWaERlWWJ4Z1ZieWg1aEtiRWJSYlljd2ZlYm5kSWJaYkJoZ2RjZE1jQWVuZFVlM2RIYmlhTmE2Z0pjaGhGZ1pjUWdsY2dibWNUY0FkQmR0ZkdhQWRoYkZjUmgzZ01lVGNSZTJlZ2hWZ1NoRmNBaGFjT2NtZ1pieWRWY2hnVmhxYWNlbGVGYTNiRWJSZzloWWZLY2poVmVmZVZjeWJnZlVlTGFXZjRhMWRmYUZkVWQ5Z1Zoa2hkYlVjRWVWZlVlWGZlYUdmc2IxYmFma2cwZnhnWWVRZDlmU2FFYUdkUmZNZGRnbmJaaFNjUWZoZlVkcWhNZjBiWWJlaFNkZ2UxYVpkYWZsZmhjd2hjZkVnaGNEZVNmVmFwYTFoZWZFYXRiM2VlZW1oa2JZZFdkVWd4ZEZmYWVHYTlnTmZPZXhkMGhUZVBlVWN0YXpoV2RrZnRnb2RBYVVjUmRRYVZiQmI1ZXliWWNrZFFmTmNlZEdoRmhGZFlkVWdGYVphRGFuZ3hiemREZmdiQmR3YlVmWGhWZitmYmNYYUJiWWNmZUZkUmVUY0RlUWI5Y05oUWNHY2RiL2diZUhjVmhlZGNobGU0ZWRmU2ZnYWhheWFDZVdiVmN1ZFdlMGc0ZS9oZWZIYllnU2dTZHhnaGhEZFdmV2dKZXllY2JIZ0JkSWdOZkViY2VOY0poemZFaGZlTWNuaElhOWVXZTFobGRDZUZoV2NoZ0NhU2VXZzljVWVIZjJhOWRWYlljQmQ5Y0hoZmJCZXhiRWNlYmtmY2dRY1pibmJKYldoRmJXY3BoeWVVZVhiZGJYZFNnbGg5ZnBnYWZoZFlkTWVUYUJiUmVtYVpnbWdGZXdkVmZXYTloYWZSZXhkMGNVYlRkbmNoZjBhYWczZXBmamVUaFdhcGhMY0Rid2Q4aDZhWmhFZHhhMmNkZGxnSmJDZUZhWGNnY3dhUmN3aFZnYmdGY3hmQWN0ZlBnSGdBZDZkUWNCaGRlRmRXaGlkZGUwZlNoemc1ZjJiYWdSYUpoVmhFZ0ZhWmRoZ0NleGE1YkZkRWNSZE5jdmJSZjNhTWJUZFJjMmNnaFZiU2ZBZUlmQ2dSZERhTWRnY0dhQmhWYmllV2NGZ0ZkM2VWaDBjb2ZXZ2FkV2JFYldnR2ZHZllhVWRaZ2llbGhoZExiQWRsYnZlUGZrZDljSmFFZ1ZoVWVBYmVoR2VzZXpkYmgwYjFneWVSZXdkOWFEZEhnbmFOZFZkWWZXZ0JlTGRVZFFjUmZyZFlkZ2hwZ2RoQ2ZsYkJoSWRkYTJiVWgxYllkMWRoY2JkUmNWY3BlNGJhY1VmVmhnY1lnM2c1ZkJhUWdBZk1iSWNlYnhiOWFkYmVlUWVNYUFjZmdsaEpla2FWZmxoUmc0ZERnVWFGY2NoYmFSZkJobWJjYmxlWWZWZGFibmZKY1JiZGExY2RlS2NGZmhoNWh2Y1FoVWNvYXZiUWVDZk5mdWNOZFhleGVWaFBjVmZaY0hjVmdCZEZjVmdGZzNmaGZyYWJnM2RGaEJiYWFsYU1kR2RYaGpjcGJrYVRiSGVaaDJkVWRraEllVmVlYUhhWWRTZFNleGRnZkthV2NXZ2xkeWhhZ0ZmcGVJaFFmMGFsZWFjZGhYY2hoTGdkYTNicGFwZ1hla2ZJaDZkR2VXaGdoTGJSZ1dmOGVSZEVlMmM4ZmFmV2dSY05lSGFhZ0JlVmdJZ1VhRWNjYVFnSWFDYWNjWWZWZGphNGE3ZEhhamFsZ1hnTGJCYzRiOWVhZUJoWmhEZFRnQmVSZW1iWmNtZEZld2dWYVdkOWNhYVJkeGgxZVVlRWYxYUpkOGRZYTNkSWIzaFRoWGNkZkxiWGZsZ3BkRWdiZFViSWVrY01nd2FJYU9kVmNEYXNnemRHZWhmbGdNZlRlMWdsaGdlY2NIaGxnNWNSZ0VhTWVkZVZoRGJrYzllQmZUZEFjdWJJZFZmZGZGZEViQWN0Z2hoQWNrZlVnOWFWY0VjY2g2ZEZoVGYwZVRkUmVXY29nT2JZYmxoQmhIZ0VjR2ZaYnllVmdoYlZicWJjY2xnRWF4ZEdiQmRnZVdoWWdYZW9kV2hUZEdjaGdZYUloeWVnYW1hSmRCYTFjdmFYYjBiY2RKZUhnVmZSZlBlYWRXZXRkcWZlZkVjMWVqZ1NoMWh0YlNkR2MzY2xiTWdkYUdhdGhRZ1djVGg5YzRnZGdoZUpoTGZHZEVhTmVaZVllbmFKY3dnSWJnYjBoWGRIZkFlZ2E3aGVjQmY5ZHNjVWRHYmxiWGdXZVJjQWFaY2FlQWR0YUZnTWJqYXNlVGViZzBiZGF6ZEVkMGNkZm9jRmNRaDRlRmhDaFZkTWd5Zk9neGZsY2JmYWVpZk5lWmJJYTFhNWZLZlRnVWVOYWhiRmhoY2hjbWdGYUdlWmRtZllkWGFCZlZoUGJSYThoVGNTY0VkOGViYlVoaWdCaGxhTGRqZUVnRWhKYjBhc2RRZlVma2ZSY3FoR2VDYlFkL2VIYTBmb2djZmVkR2R3Y1NkSGV4ZlljUmdIY0RoSWcraE1lVGVNYU5oU2UwZllka2hDaFNodGZBYktjd2ZZYTZhWGNGaDBiVWVGaGliOGNIY1JlV2IwZ1RjR2RuZ1JkdGhjZXhnTmFIZWFiQmFWZUlkVWNFZWRkTmhUY0hjSmNXYUZnV2NwZXlhVWhYZWRhWGNEYkViTWNuaElla2FKZVJlS2NWY3BmbWNIZG1oa2VrYVhhR2I4aEJoYmhSZTBlZGRWYVZjSmMwYmFhM2JwZGpmVGRXYW9hWmZTYmdjWmJGZU5iZ2hKZDJoWmQwY1JnQ2FDYjNnZ2hpZ0VkbGJRZ1loUWVVZWxmZ2FjZm5idGd3aEhoRWIwY2RjRmdRYllhc2FHY1RhNGcwYUxlbGU5ZEllQmVoYUJmb2RFYVVoVWU3ZEhhMGRjZ2dkTmFDYmRnQmVEZGlkWmJTZFFmRWZGZVJoR2NYYTFjWWRWaGhoVmhxY2NibGFGaDNhVmYwZnBkTGVRaDJjRWRXZEdiR2NZYlVkWmdtaFpoaGZOY2dhQWJoY0djUmhOYVVmVWRoaHRoU2NIaEdkTWZ1Y2JhMGUwZzRoUWJnZDhhSmdPZ21lUmRNY2RmbmhaZVNnUWZoZVZhNGVkZmhhSWJaZkdmRmY1YVpkTWNIZUloc2RMYUVoaGNTZ1NlVmhWYzFhYWRGZUJmZGFlZm1nbGJYZ1dmUmVBYlpoYWJBY3RiRmJiaDFnZGJjZFBoVWRkYTdkUmRRZFlkNmNGZlFkRmdjaFJoMWZWZm1lYmgxYlpkQmJaZURmNGdVZU9mUmVBZmVmWGNtZlZkaGFXY1JoaGE3aEZmQ2FnaHpoTGdUYXhiWmNiZnhlSmhIYkFhQmgwZnVnTGEzZmhicmJOZ0doTmFRY2FibGJzZlVmVWZsZFZma2hVZW5mWWg0ZlNmVWdJZmVkY2J6aGdjYmZTZzBhTmVwYVdjV2JKZXliY2VIYkJjSWVRYzBlbGRhZGRlWGRoaExoUGZqZ3hlcGdYaDFhRWFZYlVkR2NnZVdnUmZUYnNlZmRVZ0NoY2RHZUliWGdBZElhTGhGZEFlcGVCZ0VlOWNlZGJhM2N0YWFjRmNTY05oeWRUYjNiZGhDY1hod2NSYXdhZGRCYVllZWJZZEJjUmR6YmNoWGJKaGtkUWdXaDlmRWhSZjFjUWJVYVhoRmVJZHZhUWVYZXBiamNUYVdkcGZMYURoMWdJYlFjWmNFZnhlMmdkYWxmSmhDZFhiRGg1aDJiR2drZ3BnWGRTZGxja2g1YldlSGJCYXdkU2dFZ05oSmdXYW5iVmI0ZFNjM2RkZjZkYWZWZ2RmWmNFaEJna2hoYVRkVWVWYm5jV2JCY05jeGFSZzJoWWNGZlZhSGRrZ01hUWFWYkFhY2RPZW1lWmZ5Y1ZhaGhWZnFoY2ZsaEZmM2RWYjBjb2RXYWFkV2dFY1dmR2dHZlloVWRaZ21iNGJ6Z2NlRmVoZnlkV2FsZ1FiVWVIZFVjdGNTZGViWGVwYjZiWmFVZ3RjcWRBZndnRWFDZFJhVGZjZ0VlZmdtZVJnQmRXZXhibGU0ZFpld2Z0aGFiRmdFYU5mSWRlZm1mdGU1Z2FoMmhKaERnU2JWYXBnMWFlZUVodGQzZWVhbWFsYVhkV2JSZEFjWmVhY0FidGNGZGJheGFGZlFhSWJBZmtkbmZXZ2dia2I5ZFViRmdOZzZjUmV4ZkJlbWJjZWxiWWNWaGFnbmVKZFJnZGQxZGRkS2VGZW1ibGRoZ0Zha2NWYU1oRmdHZlpjbWdZYVhjQmJWY2JmMWJwZUhnSGJSaDFnVmRVZW5iUmNyZGViaWhvZUxlYWRraE5mQmJVZmhjdGVrY1hmWGhaZ3JhVGUxZThmVmZQaFhjOGhTZ0VoRGdKaERhV2dXaEpneWJjZUhiQmZJZFFjMGZsYWFoZGhYZmhoTGFkaDNkcGJwY1ZiMWFrZVlmU2QyZWdiR2VXZEdhOGNDZUdobWc5Y1pjY2Z4ZjVkV2FhYkJkTmZPY1VkQWQ4Y2VmTmNpYmNhRmhYYldjSmNnY1FlbWY1YmJjU2hnYmRhd2djZEJib2hZZmRld2Z4Zy9oYmYzaHBjYWRWYVdjOWVhZlJmeGIwYWRkVmZWY0plMGJhZDNjcGRqYlRlV2dwZUxjRGcxaEliUWRKZ3dkTWI0Y0liaGVzYU1jUWVEZzFkdGJPaEVjc2JZY1FhMWRsYmliY2duZUJod2NTaEVkTmFKZldlbmRWYzRkU2IzYWNobmFRYjFjZGZaY0VnQmVsZm9kQ2cwZVZidmNFZFJlTmN2ZFJlM2hNYlRoUmcyZWhlYWVTZkVhMWJIZ1dkWGQxYVlmVmhoaFZkcWhjZGxkRmczaFZoMGFvYldlYWJXZ0VoV2dHZEdkWWVVZ1pkaWZVYnVnUGNnZ0VibWNGYkJkSmVZYkJmbmY5YVNhZGVHZXRmNmhZYjBhMWZxYlNnd2Y5ZFNoRWNHY1JjTWFkYmlidGY0ZFFjaGVWZzRhZGRoYkpjTGdHaEVmTmhaZVllbmFKaHdoY2FFYWdiS2JEZDFncGU5ZmJmVmYxZWtiYWZIaGxoWGhSY3hlQmNRZVlkUWdzZGVhUmFSYkViVGhiZzBjZGF6YkVnMGFkZ29lRmdVZWhhUWNSZ3hoQmNtaGNibGhZZmRoT2dIYUpjY2NhYmxjZGdaYUhiMmNsYy9jRmZoZFZiM2FGY0djQmNnY1lmVGFoYWJiUGF3YjhjVWZWZVJiVmhIZlFkV2IxZ25lZWRuZEpjVWZlaDBjY2JQY1Fhd2hoaDliUmNYY3BhMmhXY2djMGRWYlplWGFaYWJiUWJnZk5kcGZXY1dnSmd5Z2NkSGdCZElhUWIwYmxkYWRkZFhiaGdMY2RoM2FwaHBhVmZ4Y3BoZmVWYnpieGZDZ0NhemRwYVVoQ2hFZFZoSGNjZHhhTmFIaGFmQmNWZEloVWFFZWNhUWNaZm5jSmhXZ0ZkVGJkY1ljVWhYZWRmWGhTZWhmWmFwZFliUmRZY1lkWmFoaFJnbWhaZ21nRWM1ZFZiWGhKZmFlVGR4Z1VnVmFHYmxnSmU1Y2FhMmg5YzJlWGgzaE5lZGVCZ2xmSWVNZWViRWN4Zm5lWmZsZnRoQ2dTaFhiaGIrZldiMGhzZVZoUWgwZ3hnMGJZZVdoSmJnZVFjVWhwZEpkVWdYZVZndWFYZW1lSmVwaGZmMGN4YnpkRWFCYmxob2NDYzBlVmJ2YUVkUmhOZnZhUmIzY01jVGdHZW1naGZRZUJkQWZNYkNjRWdDYWxleWFVZ0JhTmZxYmVjZ2dOYTNlV2ZsZGNlV2FlZW1lZ2ZXYkJlbWVZZFpoZGUyZlpjbmhkZ2xkVWRuYVZlQmRkZUliVGJoYjFjYWNaZW5haGJqZ2JiMGMxZDdjVWZoZjVmZWVFYkhlVmhVZGJlM2c5YUpnYWNCZFZoNGZkaGhnSmZMY0dmRWdOZ1piWWduZ0pnd2RjY0FmRWVGZVNlVmJKZzliY2hBZ1JoM2JaYTJla2daZkRoRmh4ZVZmWWNRZGRiRmNmYWdoTWFMYWJhMWZsYXplV2FrZjVkaGNGZ1JnTmI2ZVJoeGJCZG1kY2ZsZ1lkVmhhZW5oSmJSZ2RhMWdkZ0tnRmdtZGtob2ZVZEJjaGJ1YUhhRGRSZW1kYmZHZzFkVmFmaGxoTmFIaEFhUmYxY0ZjV2czZFFicGZLZ0NkWWFNY0loVmRBZmxnVWFoZEJia2NUZ0hlWmYyY1Via2JJZVZjZWdIZVlnU2hTZHhhZ2NMYlZiemRJZ25nSWh6ZGhmQWNDZGtjQmVCY1hmM2VoZExhZGUzZHBocGVWYzFja2JRZEdoV2NnZ0xoUmVUZ0llUmFWZmllTWhVYk5naGNNYk9mTGZoYVZlQWhRZWxkY2VFYmZnbmZKZUlnRmVTYk5iN2RVZ1NneGY5Y1NhaGVaZ3BkWWhSY1lnWWZaYmhkUmJtYVplbWdGYndoVmFXaDhmVGNBZVJlMGhWYVhlUWNCYjBlWmZtaGRjamJYaDJkTmNMZkVhMWZJZEFnYmZVZ3diMGVKZUJiY2REYlhibWZOYWNjRWhrY3NiWWVRYzFlbGNpZGNhbmRCZXdkU2VFYk5mSmNXYW5nVWd3YVJhU2JjZHZlT2JoZjliUmRHZ0ZhQmRvYkZnVmR0ZHZhQmR4YnBmdmdHZjNmTWVDZVhibmZvZVpnU2RGYWhiUmhBYzJoWmcwZFZibGh4aGpjY2ZnZDFkM2dSZWxnZ2VPYllhSGNvYzhnR2RHYllkVWVaaG1mWmdoZmNjRmdWaHZoV2NrY2NjZGJRYkZlVWVYY09hRGFnYi9hWWh3Y1Fjc2RTaHdoZGJFZEJhWGZGaGZjWWhIY1pkTWhRY2xneGJ4Y2Rla2hsYWhlR2dFZE5jWmJZY25iSmR3aGNiRWhoYURoU2hWZXBnMWhlZ0Vmc2UrYVBhR2JsaGZoVWRVZ0loWmhaYVJiWmhGZWZiQmFnYVRkY2YwZWRkamFHZmthY2RxYlJhd2EwZ1JoRGhBYnRiTWZjZGxhWWRWY2FlbmRKY1JjZGYxZGRoS2dGY21nbGdoZEZnaGhnZXVlR2hqYllmemJNY2pkaGRkZVpieGVOZ0hjQWN3Z05oVmNRYzJnWmJpYmVjamI5Y05mZWFGZGtoYmZYZWhoQmFzYVJmRGE5ZTJiVGhGZ3dnVmViZG5hOGFTZ1RoUmVoYVZkU2FtZnRkeWRMZkhoQmdaZlVkVmVGZldlZGRYYkJjZGhaY0hkcGh2Z1ZneGZBZFpmR2NUZ1FiTGNWZEhlMGhKYkdobmhSYnRoY2F4Z05mSGRhY0JnVmZJYVVlRWdjZVFnWmFuY0plV2NTZUdlb2EzYUhmU2ZRZlNhU2RrZTFnRGhZZFJhWWhZZlphaGNSZW1hWmNtaEZid2dWZFdjOWVhZVJneGUxaFVlRWUxYkpjOGhhZ25oSmN5ZlhhSGV0ZWZlSGZraE1nQ2haZkZoSmgyYVBlMWJ0aExiRmhTYndlK2hRZEFmUmZQZVFleGVjYW5lSmFYaEFoVmJHaGhnRWNHaENkSGQxYjZlSWFqaGtnc2ZLZEJnc2VRZVZkQmVrYXJjUmdBYkVmcWNFZFVhTWNnY0RkamgxYUhoUmdXaEViT2JZY2xjQmNIYUVkR2FaYnllVmRoaFZlcWRjZmxoRmMzY1ZjMGRvZldhSWNDZGNjV2RFYUdjNWdHZlpnbWd0ZzhnY2VFY0ZibWhXZGxic2hkaERjVmZ4aFNlTmZqYmthL2RJZWdlWmJ4Z1lmUWE5YlNoRWNHYVJhTWNkaG5kWmZTaFFnaGdWYTRiZGRoY0plTGdVZkVjMGJKYk5leWhFaDRoZWJHYUpoRGRTZVZjcGMxZ2VhRWN0aDNkZWdtZ2xiWGhXYlJlQWdaZ2FiQWJ0ZUZnWmMxZ2dkVGRjYlZmbGR6ZkFjbGI5ZGhjRmdSZFJiUWdWYVFnUmgyY2ZobmZ3YlZkYWVuZkplUmVkaDFhZGFLaEZmbWFsZGhoRmdoY2hobWFGZUdoWmJtaGFnWGdnZWNmYmEwZFJhWmFIZFFjeGdIZ1dkM2JSYnRmZWVuZVZjZWVZYzBodGZUZVViZ2FGZTJoVmJIZHBoY2NVaGtiSWdWZmVlSGFZaFNiU2d4ZmhiRGFXaFdjSmR5ZWNhSGJCY0loUWUwY0ZlU2NQZUhkaGdWYmFmWGJwZC9kWGZsZGtoV2hHZlhjNGdZZlRnR2E5Y05mRWczYTVlVmJhY3hiOWR0ZGFkQmJWZElkVWVFZGNnUWhaZW5nSmVXZUZlV2ZwZnliVWRYYWRkWGFTZ2hlNWgvZ2NlaGFZY2VmWmZsZDFldmdaYWpoMWh3ZlJhSGQxaENkYmdSaDBlZGdWZFZmSmUwaGFiM2NwZ2phVGdXYnBlTGhEaDFoSWVRYmJmVmRkYmNlZGZsZ0pkQ2ZGYlhnaGQyZ0Via2dzY1llUWExY2xhaWZMaDFkcGN3ZFNmRWFOZ0pjV2duY1ZmNGFTZTNhZGU2aE5oSGQxaFpmRWZCY2xkb2NDZTBiVmV2YkVlUmdOZnZnRmdUaFpkSGdFY2pocGJiZlNmQmFoYWNjT2dtZVpjeWVWZWhhVmRxZ2NmbGZGYzNjQ2VtZEFmV2hhYVdnRWJXZ0dlR2ZZaFViWmRpZEFiMGNQZWhjWWI3YUVid2ZoY1RmSGNTYk5kYWNJZkdjSmY2Yk9lR2NkaHFhU2N3YzllU2dFZEdhUmZNZ2RhbmdaZFNnQmhGZ29hcWFkYmhmb2VkaFdhUmRGZlpiTWFIaEpidGZjYURkTWIrZ1JmVmZvZzhlZWdGaFpjM2NhZG5hSmZYZUViQmVBYUZhYWdGZjljTGFJZzFiUmNkZ0tlQmNNYTdjQ2ZFYmRiamhIZGdjRmFaaGJnUmhCYW1nY2hsYVlnVmdhYW5jSmZSZGRoMWhkaEthRmRqZXRidmhSYWtnMGMxZFhnR2g1aDBnZGdHaFZoVmVhYlZmb2VUY0VhMWY0ZWRnRWV5YllmSWZOZ1NoY2VJaENmeGI4ZEhkR2V4aGxkdGZWYjFheGYyZ1Voa2NJZ1ZlZWRIZ1loU2FTZXhmaGFEaENjeWJjYm1hSmdTZkljR2dRZ3hodGFCYVhjM2NoY0xkZGczZnBncGRWYjFna2ZRaFJiRWhJYUxnUmVXZzhmUmVFYzJhOWJIYmNmMWNVZFNkSmRsZVlhY2JHZVFmaGdlZ1pjaGdoZWVhUWhXaFpieWJBYzNlNWVYYkViVGV4ZnBiWWRSZlljWWZaYmhnUmdtYlpobWJGY3dkRWJ5Z0FlSWJSZ3hmVmFMY0ZjQWdCZTBhSWduYVpnamZDaEdkWmdMaFFoRmU0Z1FhTGVFaHhhcmZkaGlla2gvYkdiWGJnYjRiRWVsZVlmWWFVYTBjSmhpYlBjSGFCZ3NlU2ZCZmRoSGdGZGphQWMyaERiQ2hNYnlmYWNWaEZjZmNFZkJhaGdnaEFleGVkZ3ZhSGNBZjVmdmVWYlhmb2JUZldiMmVnYkZkUWJVYnRkSGNHZTJnMGY4Y1hjemU5aHFkY2JsZkZhM2RWaDBob2JXYmFoV2FFaFdjR2dHYllhY2NMZTJnWmc4Z2NjQWhGZGhiR2dRZTlnY2NUZnpnWWJkZU1kQ2U0aGJhTmIwZFVja2FRZ2dnWmJlZ09hbWdSZk1mZGVuaFpjU2FRaGhlVmE0Y2RiaGFKYUxlR2RFYU5kWmJhZ2plZGZ3YWJmVWhnYUtjU2hVY1JhcmJlYkZkTmIrZmRha2NOZVhiV2dSYkFoWmVhY0FjdGNGZGJheGZFaFRhYmEwZmRnemJFaDBiOGduZUZoVmVWZlFjRGVoZ0JnamNjZ2thUWVBZmZnSGh0ZmRoWGJWZWRmS2ZGZm1obGdoZUZmaGFoYW1hRmNHZlpnbWZZY1hkQmdWZkpkMWVRZVhkU2JFaDRhZGZXZmpodGNpY2Rla2VsaE5oYWZrYXNoUGVVZWhmQmhrZ1RiSGdaZzJmVWRrY0lhVmNlaERhNGRjYkdkMGIwZ1FjRWJXYm9kM2hlZ1dkdGNpaFFjMGNsYWFjZGRYYWhkTGRkZzNocGFwZlZjd2Z0ZFZmVGRUYTFiWmVDYzJlOWhaZ0NnRWhWZkhjY2R4ZU5nSGZhYkJlVmFJYlVjQmJvZTZmWmVuZkpnV2FGZldncGR5Y1VoWGhjaFJjSGYxZGdmcWdOZVZiOWFYYktjQmRRZWNhYmhqYVZkNWhWZlRlUmJ3ZlJjeGYwYmRmVmNWYUpoMGhhZjNlcGJqYlRlVGhnZk9lV2h3aGRnQ2VLYmtid2ZIYWVkQWFZZk5mZGR5aEVhaWdWaHlmcGRLZkVmUmdnZzdlZWZoYlplNGdIZ0VlcGJBZ1FlVmc5ZzRlU2czZWRhNmVhaFZkZGdaZEVjRWdSZUNjQ2gwaFZodmZFY1JmTmh2ZlJoM2ROZ1ZoRWVpYVpkV2ZIYUJma2VJY1hjbWdZYlZiWGFrYkZlbWZjYmdhTmU3ZFZnd2VNZWFmYWNTZlFnZmVHZkRnMGYrYVpkbWFaaGhmY2ZGaFZidmhXZGtnY2dkYUhkUmdNYmRjSmZtaHRieWNOYVFmd2g0Z1NjMGJCYlNmRGRXYlJkY2ViZ1hhWWNYYlFiZ2Z0YzRjT2VSZUpnTmZIYmthTmhZaGFjamYxY3doZWgwZmdkS2hTaFVlUmFvZ2VkQmhsZjVlTmJpZXdhWmFIYWtlUmZSYmFoRmdjYVpiYmMxaDRhVGRjZ1ZjcGh6YlJkMGZrZGtiVWdBZFloWGVFYjFkaGd2ZWFhVmZZYWVjWWZUYzFmWWFYY1ZhZGdLZEZobWdsZGhoRmVoZGhnbWdGY0dhWmJtZ1liU2ZJZHVmSWNGaHBmTWVIZ1ZjUWhvaFVnbWFsaHJkTGdoZGdnQ2JGaDFjQWhsY1VoaGRCZWtlVGZIYlphMmZVZmtkSWdWZ2VlQ2dSZVhjSGQwZjBlUmJGZzJhSWg5Y2FoMWhwYklhUWYwYmxnYWJkYlhjaGNMZ2RleWJkZkRoVmcxaGtlUWJHYldkZ2dMZFJmV2E5YlhkUmRpYUVnRWJKYTFhb2dJaEpoaGZVZGpnV2VCY01mWmVaZGlnbGQ4ZEZmV2RwaHljVWFYZmRlWGRTYWhhWmFwYlllVWdSY2RkTWJrZUVoMGRLZEdiRWdrZFZmV2Q1Z0hiV2NoYTFnSmFUYm5kaGIwY2FoM2VwZ2pjVGdXZ3BoTGdEZHdmOGQ2Z1phRWd4ZjJhZGVsZ0pmQ2hGZFhiZ2VnYlVmeGVrZFlnTWRsaGxmL2ZjYWphbGU0Y1hkVWVwYkZiY2hIYlZjNGdTYzNmZGE2ZmFhVmhkZlpkRWVCY2tmZmNDZzFiaGR2ZFdiQmJ0YTVjVGJuYzhmNWZSYjJoZ2ZWZlNlRmhCYkhkRWRHY1pkeWJWYWhnRmZ1ZmNja2F4ZzNmSGhrY0llQmRZYkhjb2U4Y0diR2ZZYlVmWmVtZVpmaGRjZ0ZlVmNuZENoRWFsZC9oU2FCaE1hVWZNYlRkbGc2ZWZma2UwYWtnUWNnYU5iNGJFY0dhUmJNZGRlbmVaaFNnUWhoYVZnNGZkZWhjb2ZaYkZkamJBYVZmTGVTYVVnU2NKYVFkNGRGYURjQWRoYjFoWmFVaHNoSWRjZTJjVmE5ZFdkUmJBaFpoYWRBaHRkRmRiYXhoRWFUaGJjMGQ4YWhhSGhTYjRiR2RaZGpmZ2UxYUphR2dRYVplSGR6Y2RkdGRGaFJlQWVvZ0FjemFJYjViRmZuZFJlaGRBY3doaGN2ZkdlRWR4Z21mWWRYaEJhVmZiZzFocGhIYUhnUmIxYlZjV2hqZnBnbGFEY2hnb2U5ZERneWc5ZXdmTWYyYklnV2VMYVFkOGJKZklnVGhkYWxkQ2FCYWxoZ2ZQYXhmaGJlY2NoMmdKZnlkY2dIZ0JoSWhRZjBibGVhYmRkWGhoYkxlZGZ5ZndjbWZIZ2hjMGdRZ0NhV2ZnZ0tlV2VIYkliUmJSZjJiRWR6YkNkbWFNYmllRGVHZ29ncGdJY2pnVmF4Ykhnd2cwYWxmWWVCYW9iQ2NQaGdmVWFqZ1NlZ2JsaHBnTmJSZWhkc2hIaDJkUWdEYkFmaGQ0ZFJjSmR4aDBhN2ZQZW1kSmh1YklmQ2hJZUVlQmZBYWdmWGdUZ1hnQmhMYVNmbGFvZ1poYmJVZUJiY2FkYWxnSmNDZUZlWGZoaDJjRWFrYnNkWWhRZDFnRWF3aGZoRGhzaGRnQ2VSZHNhbGZIYXpnc2EvZUhjemY5aDZiZGNGZWNhV2NHaEJkQmRoZUJnMmU5aHZoRWRSZE5ldmdSYzNmTWhUZ1JlMmFnZ1ZlUWdCYTViSmNRaENla2Y5ZkdlbWFZYmpoS2RCZ1JkM2RTY2tjb2NPZGViSGVnZEVoRWhXaG9oK2JaY21nWmRoZGNkRmNWZHZoV2FrZ2NoZGRIYVZjMGhjY2VmaGZRYzdmTmFnZW9lbmVEYWtkRWZHYkVlSGZsY01oTWNDZk1hY2FBaFViRWR4Zk9iVmR4YkxmRWRCZWRiUWNZZWlmbGFhZWNiRWRoZ0RiU2hWaHBmMWJlZkVkdGczZGVnbWVsYlhhQ2UxZFZiTmRQZ1Zja2RMYmJieGNsZkhjWWNUYWdmTWFRZXhkVWJuY1FoUWhjY3ZjT2dCYUJiN2JjZWhnZ2ViZ09jaWJBaGVlSWV4Z2diZWNUaHpha2JrZEhheGJSZm1iUWFIZDFhTWJZZlhjQmZWZGJiMWdwYUhlSGhSZTFjVmRVY2ljbGVpaGRma2JsaE5jYWJrZ3NnUGJVaGhnQmdrYlRkSGNaaDJiV2ZnYXdlYmRQYmljUmVkZkJhaGNoZGVnV2hTZlFjbmVQYWpoTWRjZkNkZ2VZY1VoZGZYZUFhZmhlYjNob2E3Y1djMWJsZVpnRWRHZ2hkUWdiZTJjOGZSY0VlMmU5YUhhY2R4Y05kSGFhYUJlVmdJYVVnQmdWZVZjTWJpYmNkRWJXZDJkb2hoZVdoVGFrZUNoQmVsZ3BjbGFZYVVmSWFVZ1pna2daZnFnWmJpZ2hjNWdUZ2tmVmNhZVJjeGcwZ2RnVmZWY0piMGNhZzNhcGJqZ0VlR2VOY0hnSmNWY0lhUWVaZEVjeGgyZWRibGFKZ0NoRmNYYmdjNGhIZERhOWhoYU1iemd3ZkdiRGNSZkVjQ2NPZWloSWZ3ZkpoUWRZaE5mT2V3ZmNnVmhHZHlhTmNaZ0ZnaGc5YUNkQ2UwY1ZmdmhFYVJnTmN2ZlJhM2dNaFRkUmMyZWdhVmdRZ0ZmZ2hKYkhjamhZZWdhR2hVZkVnbGZKZ2dnZ2RuZUVoa2dSZHBnRmFqZEZiRWdWaHpjSmRiaEdiUmVsZGhlYmJWZFVhYWJFZHdobGVKZEJiVGdRZ0FjSmRpYm9jamdiaFJhMGM0Y0JjRmVzZmRhUmdEZTBkY2VNZTNoOWVlaGFjQmZWaDRnZGJoYUpiTGhHZUVnTmZaZFlhbmFKZXdlY2dFZEFoTmZSYnlnVWJLZEtjQmJrZzRhTGhpY1lob2dKZWhkQWhFZ2FmSGc0YU1hSWRVZVVkTGREZWhnVWJoZVVhaGU1Z2hlR2VXY0pmUWFSY3hiQmdtZWNmbGJZYVZjYWZuYUpiUmVkZzFjZGNJZ1FieWdjYWxnVWMxZDRodmhXY2llTWhpZVlkM2ZCYVVkY2VsZ29kVGJSY0VjMGRRY0hoVGRKYXJmQ2FUZW9kQWJLaEFmUmREY1VjaGVaaGliWmhuY1pnMmVVZmthSWFWYmVoSGFZaFNnU2J4ZmhmRGNXZldhSmd5ZkFjeWNrYUZoQWJRZ1lhV2VlZHlnc2FiZE1namZrYmdkRWRnZ29mUWdIZjJlNGJoZ1JnV2g4Y1JjRWIyYTlhSGFjaHhjTmRIYmFlQmRWZUloVWVFZmRnZWVIY1FmRWRQY1diQ2ZnaDllSGdYY2thRWJHYWxhTWJxZEtoRmhOZkxoR2d4aFJnN2JlYzNmeGV3ZUdkMmE5aGNkUWFUaGNlZGRWaFZjSmYwYmFjM2hwYWplVGZXY3BmTGhEZDFoSWVRYlphQ2ZNZjBjUGVCZWNlQmRRYlhlWWN5YVZld2cxZVJiRGVSZHdhU2RJZkRoOGdnZURiUmNFZWRlQWMzZTBjMmdSYTNnY2NKY01iQmdvZWJlWGcxZVZkbWdXZEJhVWVxZlVmbGVvY3FnRmVIZThiVGhIYUVlSWZWYlNmRmZCZkhnRWRHY1pheWdWY2hmVmdxZGNibGdGYTNoVmMwaG9jV2dQZnllQmZhYlRiU2JNaE9kWmhpY2dnMGNQZUJnbGNqaGNlRWdjZmRjSGRWYVZlU2hkZkdidGY2aFlhMGIxY3FmU2V3YjlhU2hFZEdlUWhQaE9hVGhnYVVjQ2gxY0lldGRKZkZoTWJKY1ZnQWdaYURlWWduaE5oZ2RmY0dhSmJEY1NmVmNwaDFnZWVFZ3RhM2NlZ21jbGJYZldmUmhBZ1pkYWdGaFplTWdaY2hlMGc1YmJnMGFkaHpoRWIwYWRjb2RGZVViaGZRYVJheGZnZ29oZmZCZmRoWmdKZWplMGVTZGRnMGdwYktmVWNEZXdodmVWZFVkd2R2ZldkeWJoaG1mYWhTZVJoWmdiYXdhaGRMZ0hkVmJSZGNoVWNpZDlnQmFlYm1kTmhOYWFka2RzZ1BmVWVoYUJoa2JUY0hiWmEyY0FkQWJkZUJmTGdTY1JlY2JTZTBnMWdMZUZhemhjZStkUGZIZnhkSWZGZDBlVmJhZEpkM2ZSZUxmUGduZk5neWJmZlZla2dRaEdkV2hnZUxhUmFXaDhkUmhFZTJiOGdhY2VjaGU5ZHRjYWVCaFZnSWFVYUVkY2JRYVphbmdKYldlRmhXYUlkOGRYZHplWWZiZUJobGhrZHFoRmNGYmhjTGZKZDFjSWhqZlpmbmN4ZXdhRWF6aG9mVWdCZEVkbGNVZkdjaGF4aDBnWWZ5ZjVlcWVUaFRlRmNoZURnMWhJZlFmWmRFYXhmMmVkaGxnSmdDY0ZjWGdoZTJlUWdBaDVhTWZGZ2dnc2JzZ2NjamRaZTRjQmdoZVlmRmFGYm5nbGQ0aEhjM2g1ZmhlUWYxYWRhWmVFZkJobGFvYkNhMGVWY3ZoRWdSZU1keWZUY25jOGY1ZFJkMmRnYVZhU2VGYUJmSGNFY0diWmN5YVZoaGQwZmtjZmZCZEFlN2ZHZHdlVmFWZEhkQ2M5aEZlV2FTZUJkUmdGY1Nmb2F1YUpjMWdWYXljV2dnZEZkSWFVZnhkWWNHZVBmU2VRZDBlWWEwaFVoK2hRZWdlOGJKZU9lbWVSZk1hZGhuZlphU2hRZGhoVmc0YWRhaGVKYkxjR2JCZ0VoY2NOYWloY2JpZ1Bka2NnZEZoUWJSZFFkZ2JOY0FnZGI3ZWVlamExZ2ViUWZqZm9nWmZhZUFhdGJGYmJmeGhFZlRhYmQwYmRiemZUZWtkNWFraFBmMGZoZFFoUmZ4ZUJnbWJjY2xnWWJWZGFibmhKaFpjT2VWZmtoRGNSZ1Fjc2EwZFVoRmg0Z2pkUmNtY1pnN2dZZlRmWWFBZkljUmVrZlRnVmVGZElnYmFVZm5ld2MvYWNhMmRNY1dnUWJFYXNlUGFVZmhlQmJrYVRhSGJaZzJlVWZrY0lnVmNlYkNmUmdYaEhkMGQwZVJhRmgyZUpnemRlaERnNGdkZURid2dWaGFiYWFHZVZiTGRJaDNkb2ExaENoMWVrYVJlVGFXZVpmMGREZkRleGF6ZFJjaWJrZEJmTmJraEZjT2ZjYnpkOWNJZVVkRWRjYlFoWmZuYkplV2dGZVdncGF5YURlSGM1Z2JoWWVCaFpkcGRZYlJiWWhZaFphaGRSaG1jWmdtY0ZhNGFHZzJiRWJaaENhRmVCZU5jRmZBZkFkeGNhZDJkZGdqY0NjemE4Z0ZlVGhBY1phWmNLZndlSmIyY2ZkZ2NaZE9mRmZTaHBjL2hFZmhjQWJ5ZVFkMWdsZGlkY2duY0Jld2VTYUVjTmZKZFdnbmNWYjRmQWdqYkZjNmNZYlZoWWJYY0hobGRBZDdlYWJSZkFhcGJWYzFoWWQ5ZVRleWNjZWFjUmR6ZFJkSmJTaEZlRWVKZUhnaWg4YWhkTmVFaEFic2ZOZkJlUWNsYlhjeGdnZGZmWWRFZXNkV2RHYUdmWWFVYlpnbWdaZ2hhY2NGZ1ZldmNXZGthY2dkZ0hoUWVFYmFjSmNpaFFhdGFZYndhTWJ2Z0hiQWE4aG1oU2hUY1FhSmNFaHliUWVBZkRoVWZkaHdiZGVIY01mWmVYY3hkWWNVZ0pmemF3YWtlSWMwaGdiT2hIZEFja2RoZWVkQWFrY3lkZWJnZHNiQ2dIaDFhWmFjYk9ibGVoYkhkWmNnYm9kNWhiZjBkZGh6ZEVnMGFkZm9hRmNVYmhmUWFSYnhoQmRtZU9leGRBaFZjWWdpYlphUmVhZWtjcGRYYkZjamJ0Zm9hRmhrY29jamFRYURkTWIwaExkM2ZCY0ZlZGNIZ0JnSGVIYlJjMWVWZFVlbmRSY3JoZWVtZE5kTmFhZWtkdGhKY0hiVWJKZWtoUmJGZXhlMmVVZGtoSWNWaGVlSGVZYlNmU2F4YWhjRGRXYVdoSmZ5ZGNlQ2RZYUpjRWVVZ2tjVGFkYldmVmVMZ0ljM2RRYmxhRWVoYWRjWGVUYVNjQWNIZFJnU2VvZFJoRGFtYjhoVmZmZVZkOGVDZEpobGhJZWNkR2JFZnNiUWdLZlhiSmdMYkZjWGJwYStiVWNUZDlmWGFWZXhjWWZFZkljRWhKYVFhYWdGY2tndmdLY0dia2Q1aFdhV2c4Z2ZmVGhnaFllM2dWY1ZiSmQwZ2FmM2ZwZWpjVGRXZHBoTGdEZDFhSWVRZVpmRWZ3ZStoZGhrZ3hlQ2hXZm1nTmJjY0Vna2hzZ1loUWYxYmxiaWRjZ25iQmd3ZlNoRWJOY0pkV2ZuYVZnemdRY0RnaGZRY2FkVmhkYVplRWdCYWxkb2ZDaDBjVmN2Y0VhUmJOY3ZmVGVsY2tjVGNSZTJmZ2ZWZFNlRmZCZkhmRWdHYVpneWZWZWhjVmNxYmNhaGdnZXhkVmUwYUpjQ2dFYmloNWZyZUdoR2ZjaEpnZWIyY1lhemJDZ3hib2hTZFVnMGFkaEdnTmQxYlZjU2ZkYUdmdGI2ZllhMGcxZnFhU2h3aDllU2NFY0dlUmZNYWRkbmdaZGFkQ2d4YlZhbGhkZ2tiWWN3Z1ZiemU1YlFoYmhuZUphNGJOY1ViaGhlY1NnUWhnZ09nTmd6aFphK2VZZFVlTmRYZ1doUmZBZ1pkYWJBYnRlRmdiYnhiRWFUZWJkMGhkaHpjRWgwYmRlb2dWZ3hlb2FWZ0JobGN0ZDloV2FGZlliVmFhaG5lSmhSZGRnMWdkaEtlRmRtYWxnaGhGY2hnaGNtY1NlVWN4ZG1mWWhYZUJoVmFiZTFjcGFIYkhkUmcxYlZmVWNuZFFnNWFQYnpjY2JZZE9jQWhVZVBoRmN4aEJnNmFUZ0RhOWUyZ1RoVWFJaFloYWRYZllhSWZTZDFmRmJEZlJjMmdJZzNhY2hHYTlkSWNVZGtibGhBYWRkV2doYVFlWGhYaHBkcGJWZDFna2NRZkdnV2VnaExoUmdXZjloTWFHZm1iTmJ0YWNjeGdOaEhjYWVCZVZnSWFVZUViY2hRY1pobmhvY1liR2J5Yk1jaGJOZ0Ria2JVYUJjVmVJZmdnTGYxaEVoWWRlZHhlUWNnYU1jeWY4ZnplQWRTaFlkVmZDaFJjMGhWZUFnVmN0YTBnTWNGZUJjamhUaFdjcGVMZ0RhMWdJZVFmWmFFZXhnMmVkaGxiSWdSZVFjamVFY2ljVWJRZk1mWWRTZ3lib2EyY0llRGZrYytkRGQwaHNhZGVVYzNhc2RzZEJkQmFzZzFkUGRoaEloTGZjZTFjZ2M3ZVRia2ExZG1jR2hCYU1lMGFiYVhiTWZUYVJoMmJnZ1ZkU2VGYUJnSGhFZ0dlWmZ5Z1ZmaGdWZ3FhTWNSZ0Fja2hFZGtkb2dVY0lhU2FSY09lR2RuZHdlK2FaZW1iWmFoaGNoRmdWZnZoV2NrZWNhZGJIYVZmVmZTZWRnR2NzYzVoSWhoZjRodmRTZ3diMGhIZVJnQ2NKaFVjZGFHYnhlNGFRZWhmVmQ0ZmRjaGRKaExkR2NFYU5oWmRZaG5lSmh3YWNiRWhnY0FhQ2VBY2thd2JlaEVoa2NpYkxmaWg5YWFkUWVSaEliRGNRZGdndGRGZmJheGhFZVRjYmYwaGRhemhFZjBiZGZvYUZhVWdoaFFjQmdGYkVoMWdOZzFmWWdYYUtoeWZFZVNjUGdoaDVmSWNEZUVlTmFoZkZkaGFoZm1hRmVHY1phbWVZY1hlQmZWY2JmMWFwaEhmSGVWZjRmVWJBZlRkRmhyaGVmQ2Q4Yk1lUGJnY0poQmRRZnhiSmcrZ1pjbmJaYzJjVWJrZUlmVmNlZUhhWWZTZVNieGhoZ0RnV2VXYkpleWZNZXpjRWRiYkJha2RsaFlnTmd6ZkVhRmNOaGlhZ2V3Z1ZhVWJNZzZjR2ZXZWdkTGZSZVdnOGdSZUVhMmM5aEhlY2F4aE5mSGhhZ0JhVWhMYkViUmRSZlZjWmNuZkFhVWVWYURka2UzY1JmMmZOYlZoVWJEZnhkcGdZYlJjWWFZYVphaGJSZm1oWmhtaEZkd2VWZFdmOWRhY1JlMWI1YmNlQmVoYmRnMGdhYVNlOGFnZ0hjbmVoZEplRmhYZWdmUWhaZUVkeGcyY2RkbGdKYkNoRmVYY2hhMmdFYWtoc2NZaFFneGZvZmpmSWhUZ1Zkd2ZTZGhmWWZLZkNlWGJoZXFkU2dXZjFnUWdhYlZmZGJaY0VoQmFsaG9hQ2IwYlZodmJFYlJiTmh2ZFJnM2ROZ1FlQmVqYXRjUWFTZkZmSWVTYlJiQ2dCZWpoUWhGZ2tjdmZjaEVidGZkZVZnMGZvZFdnYWdXYkVnV2FHYkdoWWZVZlpjbWhaYWhlY2hGZ1Vjc2NHZnhnUmVZZkhlVmVjYkhjSWZDYTFkM2VjY2xhc2FtaERiZ2YxZUlmT2RtZVJnTWZkZG5oWmhTY1FiaGRWZzRlZGFoY0phTGhHZEVkTmRaY1lobmdJYWloTmhSYndjV2dHZHhlUmYxaGVmVmV0aHNlVWRHZmxoWGJXZFJiQWhaZGFiQWN0ZUZlYmN4ZUVoVGRiYTBiZGd6ZFZid2dJYXVlVmRCYTBoY2ZFZ3docGhNYmNibGZZZlZkYWFuaEpmUmdkZDFkZGRLaEZobWdsZ2hoRmVoZmhibWFGZURjUWRqZE5lU2VVY0hiSWZWZ3BoR2VEaEFjWmQvZFVibmdSZXJjZWZtZU5jTmdhYWtlc2VQZlVkaGdCZmthRWVWZXhnMmdVYmtlSWFWZGVkSGNZYVNjU2R4YWhnRGRCYkdkdGgrYldibmRCYUliUWEwYWxjYWNkZVhiaGVMaGRkM2JwZmhnR2hWYmRjVGZWZWlmWmdJZ0JnRGdzYVJkRGZtZThjQmZKaGxkMGZFZFBmRmZ3YkhoSGFrYmNkWWhNYm5oNWNXaFJnMmhOZXlhQ2dsZDFiWGFTYmhlWmNwZFlnUmdZaFlkWmdoZFJibWNaYm1jRWE1YkVkMmU5YVNmUmFoZ2tjWmdYYlFlWmM5ZVljbGZCZ2pkVGRXZXBmTGZEaDFmSWRRZ1pjRWN4ZDJnZGdsaEpjQ2hGYVNjd2YrZVFoQWFSZ1BnUWd4Z2NibmNKZFhiQWVFZEVnUmRNZk1kUGF5aGNkcWhCaENnVmJ5Z1FjMWFkZVpoRWNCZmxnb2hDZTBkVmd2ZEVoUmJOY3ZoUmYzY01mVGRSYjJoZ2dTYlNnaGJ3aE9lUWV6Zkphd2JWYmxjUWM0Yk5kUWJRYjZmRWNnZFJoQ2NhY1NkeGFEZ1NnemVJYVVlSmhDY05maGNNYVJodGh2YU9oeGFWZ1BnWGFBYXhlU2dPZ3lhMWg2YUFiUmhnYnNjRGdVY29hQWdRZTJnTmJtZmRmbmJaZ1NjUWVoZ1ZnNGFkYWhnSmNMZ0dkRWZOY1plWWVuY0piNWZhZjJhSmFEYlNlVmRwaDFnZWZFZXRjM2NlZm1lbGZYYldiUmdCZ1FlTGFnZXRjTmZmY3hiRWJPZGNkbGFwaHphUmYwYmtia2dVY0FkWWZYZkVhMWNoZXZkY2FnZFJhUWRQZWlkY2REZ09lVmFjZEVjR2FDaGdkdGZXY2xiY2NsY0hjSGNaaHZiZWhsZHBnVmdiYjFmcGFIYUhmUmExY1ZmVWduZ1JncmVlZG1nTWNiY0tneGdraFBnR2R3ZHRnT2FUZEhiWmIyY1Via2dJaFZlZWdIY1loU2hTYnhhaGNEYkVmQ2dSaHlmZWhDYlliSGNDZWdkMWVhZ1phWGZoZVdkYWRtZmRmcGVCYVZkQWY2ZUdhV2hnZExhUmJXaDhiUmVFaDJjOWJIZmNmeGNOZkhoYWVCZVVhT2dIaHhoVWJRZ2JkaWNCZFdmQ2NHZ3BiaWNYZ1hkY2FlY1NlZ2N0ZHBiY2hRZDBiWWRMaHhjUmI2YlpoamJWZytmR2ZTaG9mVWVBYkVkbGNWYVRibGJKZC9oWWVEZ05ncWZUYVRkaGFMZ0JmRWc4ZFFoTWJEY2NoL2JDZzFhd2ZPY1VmRGZZZnhmUmZnYU1nRGJhZFZnbGFpZGNibmNCYXdkU2dFYk5iSmVXY25hVmY0aFNjeWdFYTdnT2MxaGNiY2hFZkFlUmhvZFJiVWFzaHVlWGVWZThlZ2VCZkFhWmRkZUZkQ2NsY1RiRGZWaGdkVmZHYVdmcGJZZlZhaGhWY3FkY2JsZ0ZoM2JWZjBlb2hXYWFnV2dFYldmR2JHZVpjYmhaZm5odGRoZ1llRWY1YUZhV2NrZGNiZGZIYlZoVmVTYWRjR2J0YTZkWWcwaDFocWREZ1VmQWZBaEVlR2F3aEZhZGNtZnRhU2FVZmdiNWY0Z1BmeGFKZ1hoR2dCYmRiWGFMYmphY2IrY05leGF3ZkxnVWJsYXBhK2JjZ3diSmQrZmVjamNKZzllV2RSZEFmWmJhZEFjdGFGZGJleGFFY1RjYmcwZmRjemRFYjBnY2grZFZlQmhwYlFlRGJ4YUJiN2djYWdlSmd1Y0ljd2E5ZEtiWGNWaGRmS2ZGYm1ibGRoY0ZmaGFoZW1oRmJHZFphbWJZZ1hnQmRWYkpkaGh4YkhmRmhSZXdoYmZYZERiMGU0aEdhRGRZYUxlTGJBZzVhZGRXYmxnaGh0Z1JnVmV4ZjJmVWVrY0lkVmdlZkhiWWJTYlNheGFoaERnV2VXaEpleWdjYkhlQmRJYkZod2NFZ0lmT2VpZTlmTGhPYVRkOGErZFZheWExZkpkU2dTYjFndWJGaHpjMWdlaFFoV2NkZnRoY2F4Y05nSGVhZUJoVmFJZVVoRWhjaFFkWmduYUplV2hGYldlcGV5Y1VmWGdkYlhnVGJSaFFkbGdLZUVlVmFNZlphQmFRYW5mTmVDY1lnbGdHZkNkb2JVZkVjeGcxaFFmQWRBY0VnZ2JhaHpnZ2ZtaFRiU2JzaEZoRGJ6ZE5hQ2NOaGdnMGR2YWRlaGIwZ0VhRmVSZm9mamNWZ0FlMWZkZkVlUWNwYWxkV2NIZEJnd2NTYUVhTmVKaFdjbmZWZDRlU2YzaGRhNmJhYVZjZGNaZUViQmhsY2hhRWhHZzlldmZFYlJiTmV2aFJiM2VNZFRhUmEyY2dnVmRTYUZoQmFIZEVmQ2I1ZThnRmVWZ29mNmdLZjFia2J5ZVdhMGRwYVpiWWRHZDBlV2VFY0Noa2ZVYmJiWGd0Z2hjT2JGZXNmamJIYXdobGFhY1NmUmgxZWJiYmgwYkZoNmJZZzBnMWJxZlNhd2g5YVNmRWFHZ1JkTWdkZm5hWWNQYmFhQmVWYTRkZGJoY0plTGhHaEViTmZaZVlkbmFKYndoY2dCY29lR2ZIYlFjOGhuY05ia2ZzZ3llWWNVaE5nWGFXZlJmQWdaZWFmQWh0Z0ZmYmR4ZkViVGFNY2tiNWcvZk9lVWVkY29mRmZVZ2hiUWZSYXhoQmdtZWNlbGZZZmRkSmhIZ3diVGRMZGdiTWhQYmVlaWN3ZnZiVWdVZ3dmdWdGaEhmdGVtZkpnWGhsZlpiUmRWY3BoSGJIYVJlMWhWZVVmbmRSaHJoZWdtZ05jRmJKZkVlVmZmZ0FmRmg4ZndkQWF5YklndmFBaGdoY2ViaEJjemM5Z0JoS2NVYzBjRmZIZ3loY2dnZmNhR2ExYkliUWNsZWxlVGRlZlZiSmVMZmRkM2VwY3BhVmExYWtmUWZHY1dmZ2JMY1RkU2FFZmZoUWN6aDBkSWJKZDFod2VUYk1nVWVVYU5lWGdoYlJiSGFKZ3ljSmJIYkFhMmFwZHZmVWFUZEViQ2FCZ0ZlVWE5ZUtnRmdsYVdlWmVoZHhodmZaaGpncGVhYlZlV2g5Z2FjUmd4ZDBhZGhWaFZhSmcwZ2FoM2hwYmpkR2V5ZXNlWmFEZHdkWWJRY2VkVWd3ZmliUGJoYnNiUmhHYXpjUWF6YVhoQWJ4Z01mQ2EwZUpiSWNjYW5iQmN3aFNmRWdOZ0plV2VuYVZoNGJTZzNjZGc2Y0ljQmFGaFpmR2JFZjFnb2REZ2tnVmY5YkVoUmdKaHljV2VuY01nRGZUZWtiSWZWZVNkRmhCZUhkRWNHZ1pmeWRWYWhiVmVxaGNjbGhGZDNkVmd4aDVmZWZPaHlnNWhCZUdlQ2FoZ1JjTWVXZllhVGVNY1Jlc2VvZUhkeWVKY1BoVGh4Z29kQWhmaEdia2RZYk5kZ2JzZHNjRGNsZTFiU2NRYnloMGdXZU1iM2VZY2ZoRmIwaFlmc2dkZmxnQWZPZEdnQWRKZlpoTGd5ZWNhOGVKZkFiRWZUYkJmUmQ5ZDFnTmN3ZjFkM2ZhaDNoOWZhZ0dmMWRsZ05oT2V3ZmxjTWJkYURhc2dUZGJjMGRkZnpkRWUwYWRob2dGaFVoaGNRYlJleGhBZWdmUGdRaFFkVmZZZGlnUWhRYUphVmJjaFlkRmNuYVJoaGRCZ2dnTmhtZlFjR2FaYjRoWWhTZkpiT2diZXdmaGJIY0ZmZ2FCY1ZiUWVIZTFocmhMZldlc2NaYUliZ2VKZWNoWGFoY0FoMmRRYUhiWWhrY1Voa2RrZVZiYWFYZzhoSmJZYlJnaGREZVdlV2RKZnlnY2hIYUJoSWdRZTBlbGJhYmRiU2ZvZE9nSWN5YThoN2dHZFZmbGJFaFVhU2ZGZlloWGJrYVVoUmJFYjJnOWNIaGNleGhOZ0hjYWFCYVZhSWNEYlVjNGNjZ1RlSGRKZldnRmFXZHBieWNVZFhmZGVYZ1NnaGNaZ2hhTGN4ZmhlSWNOaEZkc2d5YktmVGNVY3BjQmRTZXBlVWNGY0VocGdjZUJlVWdGYW1hYWYyaGRoamRDYnpnOGdGaFRkQWhaYVpjS2Z3ZEphMmRmZmxndGFDYVRhbGVKYzJlRWJrZ3NjWWhRZDFibGJpZWNlbmhCY3diU2RFYk1lZmRHZ3lnZGU0YkhhM2VkZm5iYWFRYU1oUmRXZVVicGFtZ1Jkd2hBYWhmVmFrYWNobmhYZkZoa2JUZVJhMmNnYlZkU2dGYUJiSGJFYUdhWmV5ZlZjaGhVZmpoTmNGaEZnL2VBaDBlb2JUYmFhWGNVZFdnR2ZYaHNlSmRaZ25lWmdvZ1dmbGdWZHZmV2hrYWNkZGVIY1ZlVmZTY2RkR2R0aDZiWWcwZDFicWdIZDBmY2JBZFhnemdOZ01iT2ZEZk1lRmJRY21nY2U1ZE9iRmVVZU9lZmVSY0VjTGVMZlNnQmU0YWNmaWRvZldmRGF4YXdhd2RLZ2tmc2NrYk1jemhNZFNoV2FWZjFnTWFPZjFmOWZGY0xmVmJRZlRjTGhrZ2NhK2NSY2dkc2U4Y1hnQmhnZ2NnQWRoZEFmcGJOZUZjWWZHY2VjSGU4ZFRnUGZnZU1kWmhGZUdoQmU2Y1BhQmVoZ21mRmNHZFpobWRZYlhhQmdWaGJkMWRwYUhlSGdWY3NlYWJBY0hmUmZqY0xiQ2NJZGZkYWdoYWtoUGhUaHhhQmIwZ1ZjM2RZYWloVWhsY3dnVmdLYm1jMGFTZ0diUmNoYUliUmJHZ0pibWZlYVZicGNJZ1FnMGdsYmFnZGJYZGhhTGVkYTNmcGRwZlZkMWNrZ1FnR2hUZDhiRGVFZlNlZGdZZVFoR2VOYUhnSWdSYjlkSGVPaGhnVmdEZVVhRmNRZ1plYWRuaEliQmZIZVRoNGc2Z0dhQ2JSYWJlU2FrZ1JocGhhYmhoWWZKZ2FiaGhRZzBlWmJtZHBjd2JSZzJlWmVCZGJjUmcwYWRhVmJWY0piMGVhZDNkcGRqYlRlV2NwYUxnRGZ3YUJoVmZNZUJna2VraE9jRmNJZVdiWGdUY0VibGJDYVdkRWZZZlFlMWhsZmlnY2RuZkJkd2FTaEVmTmNKY0JnM2Z4YjBmWWRYYWRoNmRhY1ZhZGVaY0VmQmhsY29hQ2IwYlZkbmRYZXhoMGcvYUZjVGF4aEhiQ2hEaHhmTWdHZEJiVmVKZFFmemJFZ3pnQmRnaE5oK2RjZmtoeGQzZkVkUmc5Y1lnS2VqZVZnZmdWYnlhZ2dVZmJjbWE5YWhiS2MzYzlhdmZXaGtmY2FkZEhhVmNWZFNjZGJHaHRiNmdZZzBjMGY4aENjbGIxZFNiUmZHZVJnUmhkZ2liSWNhaENoMGZaYjJnT2NsYWNhRmNYZXhhY2hSZmVoVmFoaHdlY2ZFZWhhRGhTZFZjcGgxZGVoRWN0YjNjZWNtY2tnZWRIYXhmQWVSZFBnQWN0aEFoYmh3ZmtkVGNiZmxmcGZ1YUVjMWhkZ2hkUGgwYWhnUWRSY3hjQmdtZ2NkbGdZY1ZkYWVuY0pmUmdkZzFkZGZLYVFlaWZFYnplV2RVaDlmbWNXaGlmTWN4ZFloUWdJZFVoSWJSZDBkQ2JlZ0ViOGhIYUhiU2RaYWplZWRBYUVhWWRMYUFlMWRLYUFlQmJBZjNlQmVTYndhemRVZGdkOWVBZEtheWNJaFNkQ2JWZzFoRGRHZkdjSWQvYkpmVGF3Z2NhQ2VoZ2tnV2RNYUhjZ2hFZE1kWGFwYS9iUWgxZ1JkU2JVY0RkeGZZZVJlMmRZaEtoT2NXZTllSGRjZXhjTmJIaGFnQmhWY0lhVWdFZmNlUWJaYWphUWZaaFJmMmZwZDZjQmJ6Z1lnRmRTY2tmUmZwYWZiQmdZZElkZmNSY1FheWRaY25jOWR3YUJhM2VSZ2FmRmVSZzBkV2dTYkZkSmJzZ1ljbGNCZmpoVGdXY3BiTGFEYzFjSWNRZ1pmRWF4YTJmZGJsZEpkQ2JGY1NkOWMrYVJjZ2dOYlJnRWhGZVZmaWVJZkhoeGJ3ZUdka2ZOYkNkV2htY0pheGFSYzFoMWU2aGFjVmNkYlphRWRCYWxhb2FDYjBmVmV2ZUVmUmdOZHZhUmMzZE1jVGZFYkdiQmhCYUFkQmZrYlVmSGFHZ1liZ2dWYWhnNWFxYVloMWcxaDNnQmJVYW9oZGZhYVhnY2RmYUZnRWJ3YlVlWmdtYVpjaGJjZ0ZhVmh2YVdha2VjaGRjSGJWZVZkU2NkZ0djdGY2YU5nRWhVYitmQWcwZFloQmJIZ0dnUWNlZ2RkbmIxYVNjVWFCZGxoNGdKZUJmSmFBYkdlRmNaYlFlYmJsY2hld2djaEVlaGREY1NmVmdwYjFjZWVFYnRkM2hlZG1lbGdYYldhUmRBZVplUGZ3Z01jUmhKZzFoaGNBaFljMGRjZmhkRWUwY3hkb2NCYmthUmJRY0ZmUmJCZnRiY2drYUljY2JjZlZjaGJSZGRiMWJkZUtmRmNtYmxnaGhGZmhmaGZtZUZkR2RZaDBjSmdDYlFoQWdQZlJkUmRIZ1NoVmFVYWNjQWNXYTllQmRlaG1iTmNOaGFia2dzZlBmVWFoZUJka2JUZ0NjdGcvZFhobWVnZlZoZWJIYlljU2hTZ3hlaGVEYldhV2JKaHlmZWhEYzVnR2NFYnhic2ZWZ0llVGJjZmZmTGdpaG9hc2VXZ1FnMWhmZmFiamJ4Y1plRGdDYUZlV2dFYjNkSmJIZE5mVWRZaEphS2QwY0VnQmJIYndna2ZRZWJlbmJ0YVdmVGNrYUJjeWFVZFhoZGFYZFNmaGZaZHBjWWFSZVloWWdaaGhhUWR3aEplemNOZ3diQWFXZDlkSGhSY3doMGZkYUNmVmVJZWdjSWd6Y01id2ZRY3lkWWdPY1FjUmhWYkVlTGNGYWRjY2NkYWxmSmdDaEZhWGRoaDJjRWNrYnNoWWhRYjFibGdpYklhRGNVZmthSGJSY0VjSGRXY21iVmE0ZlZmbWJwZm5mYWdRZU5nemhFZkJmbGJvaENiMGJWZHZnRWVSYk5mdmdSaDNnTWNUYlJiMmNnZ0tkU2dGZEpmRmVPZG1oWmJ5Z1ZkaGRWZHFnY2RsYkZlM2ZWZjBnb2JXYWFkV2NFZVdmQWZtZ1lnRWVaZm5ndGM4ZWJjVmJVaHVmQ2NBZ0JlSWRVZUJoQWZjZElhRGFoZTBjTGN3aGdna2REZkZkc2VhY09jbWRSYU1hZGVuYlplU2NRaGhhVmI0Y2RjaGNKYUxmR2dFaE5iWmFmZ1hmSWRBY2VmQmR3ZUxlQWFBZ2xmNWdlYkZhdGI3Y2VnamgxaGViY2V4ZEFjWmFhZEFkdGJGZWJjeGZFY1RkYmcwYmRnemFFZzBmZGdvYURnMGhnZFhnU2hWaEVhMmVJY2hocGZNaFljaWdZaFpmUGZnZ1JlR2NGZGllZ2J6YVVnVWQwZHJoVWhTZmdheWdNaG5ibGRPYVJoVmNwZUhlSGNSZzFoVmdVY25jUmJyZWVhbWRNZFFhWWMwZGNjbGZVZ2hlQmRrZFRjSGdaYTJjVWdrZUlmVmNlYkhnNWdjZlJkVWRnaFJhRmNqY1lnOWZKYkNha2VZZkJoa2NjaGZlSmNDZDBiS2dPZ3libGZwY1NjbGhsZFdkVGhDZFpnSWJFYlNoWmdlZ1hlV2c5YlBkSmN4aHBjSGFNZnpmOWJJaFVhRWJjY1FmWmhuYkpiV2hGZldjcGh5YVVkWGhjZGVjRGNCZVpjaGFZYkZlZ2FXZkxiMGVjZUVhTWV5ZGNnMmVFY0RmMWJTZkVkeGFRZlVlZmExYkplMGVhZjNicGRqZVRoV2NwZkxnRGUxaElhUWVaZUVkeGIyZUljaGVvYlFjV2JpaDlhMmRYaEFmNWNQZ1FieWEwZjdnSWNqYVVjVmdHY2hkRWJHZ0NkSGcxZTZoS2NpYVVhOWdQZUJmb2hjYVhja2UxYW9hUmNoZkFhOGVSZFJiTWJ0Y0FjbmNOZVNoUmV3ZHBiQWhEYWhhWWJDZ1FnbWNSZzdjVGVUZDlhcWFjZ2xnRmEzZVZhMGVvaFdmYWhXaEVlV2ZHYkdnWmZHY0ljemdJZzBhSWhoY3RjdmVEaGdlOWRVaFRobGFWY1BnYWhYZ1pjNmZOYTBjMWIxYlNld2g1aENnRWJIYjVhTWFaZW5kWmhQZlhjd2RoZTRhT2JCZXdjSWRWY3diNGhKY0lieWFBZDFjZWdCZXdmTGdBZ0FobGM1ZmVnQmI5YytnWWJVY05oWGVXYVJiQWNaZ2FoQWZ0ZkZnYmR4Z0VkVGZNYmtiNWUvZ09nVWFkYW9nRmdVY2hlUWRSZ3hmQmNtYWNhbGZZaGRkSmdIYXdhQmRKaFJoZ2RlZFdmVGIwZjRoUmdsZTFkb2dYZ1NlZ2cxZk1kVGdVYVdoT2MxYXBkYWVIZVZmc2VBY0hlRGNjYy9iTWd5ZXdoRGZhZGtmTWdHZlVha2J0Yk9jVGNIZVpjMmFVY2thSWRWaGViSGZZYlNhU2d4aGhhRGhEaHljTWdnYWNhQ2NSZUljWGdraGxlWWZkZzNnUmJoYmRiM2VwZ3BiVmQxYWtmUWZHZFdkZ2hMZlJoV2Y4ZVJiRWEyZDhnT2hjZndmNWFIZk9iaGZzYmhoUGVqZ1JnZ2NBaHhkRWNpZGFkZ2NjaFRhS2RRZmdlMWZNZTJhSWdNZkVnZ2gwZnljWmhoZ1JobWNaY21jRmN3YVZkV2M5ZGFmUmR4YTBlZGNCZ3hmY2hnaFBoaWdnZXRhVGdXaEpnaGREaDFiSWZRYlpoRWZ4ZTJlZGFsZUplQ2FGZ1hnaGEyZ0Voa2N0aE1lQ2F4Z0FneGVmZ0Rod2gxZUJjZ2FRZWRlRWNuYlZhbWFTYTJlZGE2Z2JjMWdGYXpmRWNCaGxhb2hDZzBnVmV2YkVoUmVOaHZjUmgzY01mVGNSZjJhZ2FWYVNhRmFoYlBoUmNHaFpndmJWY2tmRWNpY09hd2dKZDVmQWR3Y1ZhbGJQaFRkTmhmYlZjaWNFZ2NoWmRDZjRna2dLYkZiZGdqYVdnbGJjYVJoSGZSZ3hlYmFlaGlmWWg3YU5md2c0ZmloUWN3ZUJiY2ZTZzNmWWZSYWVjVGVGZmJjVGJGZzhmM2RQYzFleGJEZkdma2FOYmJkYWIzZ3RoOGhXZGtmaGdEaFNoVmFwYzFjZWVFZXRnM2ZlZW1lbGJYZFdiUmJBY1plYWZBY3NlUmhKaDFoaGRBZ1liUWFzYzJnWGhRZ0FkOGdYaFVhaGJPZ1JiMWRsZ21hZGhGYkFlVmFZY2llWmhSZWZhRWFwYkthRmVHaGxhdmZHY0JmWmFtY0ZnbWQ5Y3ZoYmJWaHBhVmRiZzFmcGFIYUhhUmIxY1ZkVWNuaFJjcmhlY21jTmdOZGFka2JrYVRkTWhFZVVoaWRDaGplTWRrZlVha2VBZlZoY2UzZlpnR2VTaHhmTmJEaFdnM2d4YXdhV2duYkJlSWhRYjBjbGdhZ2RnWGdoYUxhZGUzZnBjcGZWaDFmQWZMZ01hMmVnZExjUmhXYjhjUmJFZDJmOWNIZ2NheGFNYmFnWWVSY2xmaWJVZEVoY2NRZlpkbmJKY1dmRmdXaHBmeWFVZ1hiOGVaYVJjRWJZZjdmTGhrZkpoWGZNZmtmMGQyZkljMmY4ZXpmR2ZpYklhS2NCYWtiOWhZaFZoVWQ5ZDBmTGhTZThhdGdEaGpoNGNDY1FjQmF3ZFFiYmZCZGhnNmZkZmdoQmFPYkZjVGRGaDZnRWhnZDRhVWJRZnhkWmdyZmNiaWN0ZGFkU2ZFYk5lSmVXYm5lVmM0YVNhM2JkZTZnYWZWYWRjWmZXaFZnOWhvZkFjMGNRZWhkSGExZ29lOGZKYlNkWmNWYkFiU2UxZ0hoUWdBY1JlT2JHYlVleGR5ZlZjaGZWZHFoY2VsZEZkM2dWZjBlb2dXZ2FlV2NFY1djR2JEZEplY2hOaENoa2EyY2NnQmhzYnFhRGJVZWRncGFSY0FnVWVYZ0VkVGRrZG9oTGdCYTljaWVTYldlNGRBZFZiemJFZEJiTWZ6Y2dkR2FRZmxjZ2Z0aEpjVWZaY0xlV2FnYlpjWmZJYTNiSWVTZUpmUWc0ZEZnRGVBZ2hiM2VjaFZmQmJkZGVmbWZsY1hjV2hSZEFkWmVhaEFkdGVGZ2JneGNFYVRiSmZnYUZmemJHYzJhMWNvYkZiVWZoYVFoUmV4Z0JibWdjaGxlWWRWYWFhbmdKZ1JlZGgxYThnY2RXYlNmQWJsYUZhZ2RoYW1jQ2RYZXRkN2JZYVNlSmVWZmFoVmN4ZkhoRmRVZjljVmJUYTNhUmY3ZmNlMmQ5ZG5jYWZrYXNlUGhVYWhhQmZrZlRjSGhaYzJnVWRraElnVmZlY0hiWmVFZkJmRmhFaEhnV2NYaEpheWJiY1doMWNWY1Fkd2dCYmFjY2QzZjVjTGJmYXpiTmRwZVNmbGFsZ0VkR2VYYmNmTGZFZVdlRmRkYVZoaWdFaEFjSmIxaHRjSGNjYWhnVmFZYVdhVWhzZTZkWmduZEplV2dGY1djcGF5aFVjWGZkZFhlU2FoZFplcGZZZFJlWmFPYktmVmcwY2lkWmZuZkZld2dTYUhoSmRIZVJnMWhnYmRhVWIxZFJlMGdZaHplOWFqZlViR2FwYWJoQmFsYTRhNmNaY0VkeGIyaGRmbGdKZUNkRmFYZGhiMmNFZWtnc2NZZ1FkMWJrYTBhUGFUZmtkMGNTaEZnTmRKZFJmMmRoYmxnU2F6aGhnNmRiYTFkRmFaZkdkRmJaaG9jRmRrY1VkN2hXZ1Zhb2Q4Z1NnVGM5Y1dkQ2hTZTloQmRBZEZnbGFMY09mbWFaaHljVmFoZFZncWZjY2xoRmMzYVZnMGhvZldmYWFXaEVoV2NDZkdnWWRLY1piamVSZ2hlTGFBaGxldmRFZTBlY2dEYUhlUWNGZGNoT2dDYzRnMGFKZkJia2RpY1NkMWVNY09iRWdIYlJkTWhhZUhlWWVYZVFna2FraGtkZGRsZjFlTGdCZmthTWhOY0tlamZzY2pmZmNnYlFoR2VCZHhhMGhoYU1mRWZKZGRoZWVtYWxhWGZXZlJoQWhaYWFlQWd0ZEZkYmd4YUVlVGZaYm1mMWN6YkVkMGdkYW9kRmNVZmhlUWhSaHhnQmdtZmNhbGhZZVZlYWFpYlliWmJKYVJjZ2ZkY0ZoaWdjYmtiUWhSZ2dhVWZWZVNkZ2ZoZEpkQmVVaEhjUGNSY1VoVmFGZFJkOGNhZEJleWdCY3JnTmJTZFZnTmFPYkFlcGNCYUZoVmNWaGtkQmFUZ2doeWhGZ3hjb2RYZmNmV2YwZTRlU2R4ZGhoRGNXY1doSmh5Z2NmSGRCZkloUWEwY2xhYWVQY0RiNWRMYmZjemc5ZXBjU2NVY1FmUWRWaG1kZ2JOYVFjMmc5Z0RjRWQzY0ZlYWJjZDFlcGFPZGFiRWNjYU5jQmNCY0piQ2FLYkhlSmhHZERma2FCYXljVWVYZGRkWGFTYmhhWmNwZ1lhUmJZYllnWmRoZVFjdmZJYUdlRmU0ZkViR2E5Y0VlV2JoZDFoU2VYaEZjSWRtZkxlaWI0aDJnSGV5YVJjTGVBZmthTWVMZlRha2d4ZjJlZGhsYkpkQ2JGZ1hnaGUyZkVka2JzZFlkUWV4YUFna2FjYm5iZ2dpY1NlRmYxYVVkV2VqYnhneGdTZnljVWUvZ1BlUWRJZkxmWGdoZGxhNWJFZ0diOWF2Y0VnUmZOZHZoUmQzZU1lVGJSYTJmZ2hWaFNjRmZBaE9iVmZtYVplNmJYZGhnMGI0aGNma2I5ZnBkU2dWZ2NlV2VlZ1diZ2VhZkdoR2U1ZGRkWmVuZWhiL2ZiZmtmaGZ2aFNha2Y0ZlJhSGFWYzBlWGFkYUhiVmRrZmZoVmVCYnFnV2R3Z1pjZWhFZ0djd2VEaGRibWdoaE1lWGRBY2hlNGZaZGhhdGFIY0dlQmVjYVJkS2Z5aEZod2RiaFZkVmFlYVNoUWE1ZThoY2ZXY0ZnM2RlZ21mbGJYZ1dkUmJBY1pmYWFBZXRjRmViZXhmRWRUZmJneGVVZDJnUmF4aEljNmRXYzBlaGdBYlhlRGVwaG1jY2NsYllkVmFhYm5lSmFSZGRhMWdkZktiRmNtZWtobmRXY1VlcGFtYUhoRWh4aG1hWWhYZkJnVmZiYTFkcGVIZkhhUmExaFZiVWZuaFJicmJlaGpiVWdNY09oRWN0aEhkVWdnZDFna2FBYzNnWmc3ZFVmZ2djZFpjVWJuYllkU2dTZXhhaGZEaFdiV2JKZnljY2dIY0JhSWNRYjBjbGJhZ2RiWGVnY1lnZGMyYWRlcGRIZ2xka2RkYUdhVGJvZkhnYmEyYjhoUmhFYzJkOWFIaGNoeGdOZkhlYWhCZFZkSWVVaEViY2hRZFpobmdJYlhoRmFYaGRheWhQZkRkWWFEYkFkaGFnZ2tlS2VGZWdoUWRMZWhiaGhtZ05nV2ZoYThnZmcyZTlnYWRSYnhjMGFkZ1ZjVmRKZzBkYWYzZHBlamhUaFdkcGJMZkRiMWdKZ0ZoWmJGZkZnMmNJZmhjb2FMZlJnbmRZZGxhWGZnaEpoYmhCZWxlRWhuY2ZhbmNBZi9jUWRVaDljamdXaG5oVmY0Y1NlM2hkYjZmYWhWZ2RmWmRFZkJobGhvZ0NiMGVWZ3ZhRWNWZFZidmZXY25mTmhIYlNhVGJ0YlpmQWhSZU1hQ2VHaERiUmgrZlZibGF4ZGpnZmFuZnRmM2hWZTBob2JXZmFnV2JFZFdiR2ZHYVljVWRaYm1oWmhoZ2NhRmVWZHZlRmFrZ2NiQWNIZlVnVmNKZFhibWJ0aDZmWWIwYjFlcWdTaHdhOWJTZUVnR2RSZk1oZGRuZFpmU2RBZXhiVmFtYWRmbGU1aFFlTWFrZE5lWmFZaG5oSmh3YWNmRWVoZURhU2RWaHBnMWdlZkVkdGEzZGNjV2RJaGJkY2h4ZUFjWmNhYkFndGNGY2JkeGdFYVRoYmcwZmRlemFFZjBmNWVDaEZlVWNoZlFjUmh4Y0JlbWZjZWxoWWNWaGFjbmhKY1JlZGYxYWNjRGNVYkdkbGNwZFFiMmFNZHFjYWhXYVpnbmVmZEdiMWdWYktjU2FFYkxiWWVCYVJoVmFDYVZjNWRyYmVmbWROYU5mYWFrZXNhUGhVZ2hlQmdrZ1RlSGRaZDJnVWJrYUloVmdjYkRiNGJTaFZiaGVnZFdkSWhpYzRiUGRlZVhmeGVJY1NmeGZwYmFkYWdIaGdlTmZEY0RoWWhVZVhia2RJaDZjR2hXYWdoTGRSZldiOGFSZ0VmMmM5ZEhkY2h4Y05oSGhhZUJkVmFJaFVmQWVWZkNkSWd6YU1kZGVEZGtjQmF5ZlVkWGNkaFhhU2FoZ1picGhZZ1JlWWNZZ1phaGRSaG1jWmFqYXhoYWhWYldhOWRhaFJmeGQwY2RhVmdWY0plMGFhYTNicGRqZEhoeWM4ZGZlV2RnaEJnZWNaZ0JoOWQyZGFlRmZJY0tkRmhXYmRjMmRIZDFjb2VZZ1dlVmFrZnFlY2JtZTVmd2ZHaDBnTmRXaFdmbWRSZjRlVWVYZ2RicWVjY25jMWFaZ0VmQmhsZG9iQ2IwYlZodmdFZVJnTmZ2YUdkbmVvY2ZhYmNXYmdlVmhTaEZkQmRIYkVjR2NaZ3llVmdoYlZkaWJQY0ZiOGduY0JiUWRWYUNhSmVqaFZlUGhTZ0NiTWZhYkxneWdnYmlnUGJBZkFncmRIZHhoUWhkYUFnRmVVYVVnSWdTZFViNWhOZXdlUWJsYkJmUWU5YWFmUmdHZGhmTWRKY0hmcGNTZENmeGJ4YTRjTGZUZGhmTGNHZEViTmNaZ1lhbmJKY3dkY2JFYmhoRGJTZFZkb2NuZFBjUmE4Y2liS2ZDZGRkWGdWaEFiRWdaZGFoUmVaZVljYmQwZFZoYmNKZ2hiUmU5YldlZ2drZHNoVWVCZEFmL2dBY1JkZ2V5Z2ZibGhaYkhhWmduZUllWWNmZmtmeGVnYUZibWJsaGhiRmNoZ2hlbWVGYUdnWmNtZllnU2UxZGNnWWgzZ0JoSGNIaFJkMWNWZFVmbmhSaHJiZWJtY05oTmVZaGdhVWhCZUFla2ZJYnJlR2dEZ2tiaWVDYnhlSmZRZGRhamM5aGNlRGcxZTBmYmVOYmljUmh5Y2JhWGZBZ09hRmNnZGNkWmdJYlRoRWNFY09nWGVwaGhnQWcxYVVoUWdTZTJoUWVMZURiR2hZZFJjU2RFaFZhSGdjZnhiTmdIZmFoQmRWaElkVWdFY2NoUWJaZ25hSWZFYVVlRGY0aG5iQWJ6Z2xiWGJIZUJnNGg5YUtmVmg5ZExlYWZoZVFneWdhZG1kRWNpaFdoV2g4aFRmU2R4ZzBhY2hSYlZldGR2Y1FnWGdwYmpnVGhXaHBoTGdEZzFkSWNRYlphRWF3YnJjZmgxaDVhb2VGZFhoaGUyYUVoa2hzZlloUWgxZmxkaWhjY25jZ2ErZFJiaGRNZWJkRmNTZkViM2hIZXljNGdxZExmRmFrYlZlVWdVYm9lOGJZZGdkc2ZyZVZiRWNzZkFiQWFYZU1nT2FSZnloNWJBZEJiaGFNYlRnV2NTaGthOGdWZGhoMGIrZmZhbGRFYmxoV2MwaHBhZmJZZkdnRmROYU1nbWRZYlVmWmZtYlpkaGdjZUZhVmh2Y1dna2VjZ2RlSGFRYWNhWGFJZERiNGRvaExkVWIwYzhnUWgxZHNhYWdXYVRkZGhBZmRnaWNKYmVnUWNrZGRnMGFkZGxndGZIZEdmRWhKYUljYWIyY2xnYWdjYkVoaGNEYlNmVmFwaDFmZWVFZnRhM2JlZWpkUmJlZFZlVGVvZVpiYWRBYnRlRmdiZnhnRWVUZGJoMGdkZ3poR2V3Y2xkbWFSYVJlb2dmZ0VoMWc4Z3lkS2F3YlplUWJaZUNiVWJEZ1BhZ2dNZFBnRmduY1JnaGdVZEViMGZvZVZoemZJY3ZoTGVqYzVjVmJaY3dlNWNMZkhlVWY5Y1pmVWFqYzFjbmhlaGloWmhFYmFjaGVBYWxhVWNoZkJoa2ZUZUhiWmYyZ1Via2hJZFZhZWJIY1loU2RBYWxkNWREY1VhVGdRYzllT2FUYVJhSWFVZTBibGdIYWFnR2ZWZExkSmNYY05jcGRYZnhod2VRZ0JoR2dnZEphRWVEZXRlWGZDYjJhMWVPY2ZheGZOZFBjSWRSYlZiVmhVZEJnTmhZYUxleWdGYVlnV2JTYzhiOGFGY2ljTWJmYVFneGZwZ3BlYWRVY1FnWWFlZHhjUmcyY2JlM2NwY2FiVmZXZTloYWhSZ3hiMGFkY1ZiVmhKYjBoYWEzYnBiamFDY0NnWWRZYVNlbGRKYlpmSWNraHhhK2hJZkJnMGZMaFVoWGRoZG1jRWZsZ1lhRmVYYWxoa2hyY2NnbmZaYjJmU2hFYUVoYWZEZGllY2J4ZEJjVGhCYzRjYWJVYXBoRWJFZUVkMGV4Y1dod2RBYWdoVmJ4Z01jOWVUZGxoa2NUZ1JnMmdnYVZlU2JGZEJjSGhFYkdmWmR5ZlZoaGdWZHFkY2ZsZGtkeWNWYzFkY2JXYk9nMmNnYmFoR2RHYTVjZGJaY25jdGJoYkpoQmcwZm1oQ2ZVY2xlUmhXYkJjc2FWZ0lnQ2dOY3phYmIwYzFjaWVHY1FhOWFQYUViSGJSZUZlYmNWZ3hmU2VRZGhnVmM0ZGRmaGFKYUxkR2FFYU5jWmRZZ25nSWgxZ1BlQmRzZkdmU2JRY0ZiZmFlZUVjdGIzYWVobWZsZ1hhV2VSaEFmWmFhYkFjdGdGY2JkeGVGaGFkS2FVaGRhN2FFY2dkNGI3Z2Nkd2hFYWVmRGRrZlFkamFlZ2dnUWRjaFliMWJoaFJkZGIxZ2RjS2dGZW1mbGdoaEZiaGhoZG1jRmZHYVplbWVZZFhjQmRWZU9ieGhJY1ZoVWNrZnBkVmdIZkRmRWE4aGVnZ2NZYmZjT2dBY1JjZGdXYWpncGhrYVRlSGhaYTJnVWJrZklmVmRlZ0hkWWNTZ1NieGFoYURoV2ZXaEpmeWNjZEhhQmNLaEliUmR3ZGNjTWV6YjBhWmVlYVNhMGM3YUhkZ2gxZFZmRWNUZnRiZmJGZHlkWmZmZVZlR2dOYkhhTmFsaDBiRWNKZjFoRWhCYUhiZ2RBYWNlWmVqYjBlUWRVZXpha2EzaEJmUWN4ZWJhU2ZsZW9lc2dMYzFmRmNNZ0xnbWRsY3ZnWmRpZ2djamhWZlNiRWZWaFJhMWNGY1NlR2h4YVVneGFPZlhkb2F3ZkdkRGJvZWJlUWNBZEJhRWdJYlFnaGMwYlhkRmFKZUNkRmNYZ2hlMmJFaGthc2dZZlFjMWRsYmllY2ZuYkJhd2JTZkVhTmRBYVFlVmY5ZjRmU2gzYWRoNmZhZlZoZGNaYUVhQmZsYW9iQ2MwYVZldmNFYlJnc2g5YVJiMmM0YVRkVmUyaGhhSmVTaEFlSmZPZ0hiRWd4Z3liVmNoYVZhcWJjZWxiRmgzZlZiMGNvZFdiYWVXZEVhV2dHaEdjWWhVY0xhemZVZ0hlT2JSZXNibWNEZ2dmSWdWaFZlRmZ4ZTRnZGRHYnRkNmFZYjBoMWRxY1Nid2Q5Z1NjRWFHZVJmTWNkZm5jWmZTZFFkaGhWZjRjYWNSY0pmRGJFZEFhcGhaY2ZlM2RKZGdhY2JCYVJiRGVBYUZhTmY1YmVoQmEwZDRlTWR5YjFlWGVTZFJjQWRFZ2RnUmdaYkZnS2NoZUVnVmZhZFVhZGY3ZlZka2FkZjFhRmFVYm9jRmVFZjFhWmUraGNnRmU4ZmNlUWVIY0pkUmVkYTFkZGRLZkZmbWdsaGhhRmhoY2hjbWVGYkdjWmZtaFlkWGhCZFZhYmEwZEJmSGdGZlJkVWVRY1VjbWNsYXJhTWYyYnBoQmdhYmtnTmZHYVVkZ2IxYWtoR2FqZWtoL2RGYmtlSWNGZWNmWGc4Y0pnWWRSZmhhRGVXYVdmSmJ5ZWNmSGZCZ0llUWgwZGxlYWhkYVNoVmdoZWRkM2RwaHBoVmMxZ2thUWZHY1djZ2hMY1JiV2g4ZVJmUmFTZDRjVmdjaDFheGNIYmRiUmhVZWNoR2JBZTVhRGhhZkRnNGNUZVdmeWQwYm1iR2FYYWRiYWRTZ2thUmR5Y1NheGhZZFlnWmNoYlJhbWZaYW1lRmR3ZVZoV2M5ZmFlUmMxaFJlYmZWZVZkcGdlYWFjM2FwYmpjVGFXY3BkTGJEZjFjSWFRYVplRWd4YjJlZGRsZ0pkS2ZIZFNlNGg1Y1dod2Y4Z1lmVWMxYWxiL2ZiYTJiMWR3ZEFhVWdNZVZmQmVuY1VkeGVTYTJnbGM2YUpnbGM1aFpoRmNoaDlhb2NBZndieGF2aERoQmFNZmdhVGJuYThkNWhSZzJoZ2VWZFNnRmRCZ0hiRWdHZFpjeWFWZGhiVmZxZmNibGFGYy9hQWEwY1JhYWVMZ0NlOWdSaFRkQ2M0YVVhZWRHZFpmeGNjaEZjTmdwZFdma2Y4Zk5mSGVVY3RjU2dQZ1dnc2htYVBjMGgxZjZnU2J4Y0ZlU2NRY21lMWVGaGRhaWNvZE9kUWVrYmRlNGhhZEJkSWFmZFVoQWJvZ0tmYmFEYTRiMWZQY2dhOGFYaEFkVmVOZGZhZWdFaHRnM2dlYW1kbGNYY1dmUmdBZlpmYWVBZHRiRmFaZWpic2hUaGJiMGNkZXpoRWUwYmRmb2hGZFVmaGVRYVJleGNCZW1iY2JnaEpiZGNPZkRoMGhHYWRleGNrYlBjUWZXZWtjVGNWYzFnWWNoY1VoUWdNZTBiTWV6ZjhmSGNaZzFnZ2dtaFNlVWdrZ1FlSGZ5ZFFoL2dlZGphY2RDYWFmaGh4YmRkR2EwaFFiaGRUZ0Ria2JqaEJoaGVGYWNiUGREZU1hU2ZDZFVkMGJGZ0hoeWNjYWdhY2dEYUliSGNGZ2doY2VlZ0pobmZwYkNjYmdGYkJicGdWYzFja2RRY0dkV2hnaExnUmJXZDhlUmVFYTJnOGFDZ2NkMGU4aGJhYWJCZzBmTmRVaEZob2RRZFphQ2VjZ0NmVWQzZkpnd2ZXZUdkeGY5YVNkaGNaaHBnWWRSZFloWWhaZ2hiUmNtY1pnbWNGY3diRWJ5YUFkSWhSaHhnVmhMZkZkQWdCZjBjSWgzZHBlK2RUZldmdGFhZUZhRmdJZkxiWmJFZlZoY2dkYmxmSmRDY0ZkWGRoYjJoRWZrY3NmWWdRaDFkbGNpYWNkbmRBYWpjSGJ3Y29lZGFHZVRoMWE0ZFFmemVKZHpjYWJRYXhmemNFZ0JobGJvZkNmMGJWY3ZjRWFSZ05hdmRSYjNlTWZUYVJkMmJnZlZoU2FCZU1lR2VRYnlkTmZ5ZFZoRmQwZHZiS2hsYU5ndGJmZ1Vjb2FXZWFkV2RFaFdkR2JHYVloVWdaZW1mWmFoY2NiRmFWZHZoV2FrZmNoZGdIZ1FlY2ZYZUlnRGY0aG9hTGhVZzBoSmhRZjFic2hhYVdmVGdkaEFoZGZpZUpoZWdRZGtkZGMwZWRmbGR0Z0NhQWcyZWxmWmJZYm5mSmR3Y2NmRWRoY0RoU2VWYnBmMWNlZ0VndGIzZmVjbWFsZFhhR2VsYUZnS2dMZVFndGhIZE9ka2hWYlZmZGcwY1ZocGFPYVVjZGhvZUZmVWJoYVFmUmJ4Z0JhbWZjYmxkWWVWYWFobmFKZFJjZGgxYmNoSmNWZHpob2hrZEZoaGJvZHpiUWdDY0JncmJlZVhjSmFQZlJoVmZwaEhnSGJSZDFhVmRVYW5iUmhyYWVkbWhOY05oYWdrZXNiUGRVZWhiQmVrZ1RjQ2JRYXpjQmVoYmRkSGZOZm5oWmNRaFFmMGZ3YUxoRWdEZ0ZmK2ZjZ0NlUmZFYlFkeGh0Y1diZGFUY0ZjQ2diY0ZmQmVwYVZjMWRrY1FlR2JXZWdmTGdSZFdjOGdSaEVmMmU5aEhoY2h4ZE5oSGNLZzFoUWdiZkZoVWZjZVNoSmZ5YkViVmVYZkNkTmh3Y1NnMWMxZFhjU2doYVphcGZZZlJkWWhZYlpiaGVSZW1iWmRtY0Zld2JWZVdnOWRhaFJleGUxZlBoRWhBaFlkaGRPZVRjUmZqZUtnR2VJaGZiUmd4ZnRlRGJhYUVod2dpZGVhbGJJY1FkR2VYYWdnL2dHZjFmQWN5Y1FnMWhsaGljY2FuZEJnd2ZTZEVkTmNKZFdhbmJWaDRjU2IzZGRjNmRhZ1JmUWZZY1FoMWV4Z29kQ2NRZGtkdWNSZFZhb2JoYlZnbmdFZUpmYmVXaGdmVmJTZEZjQmNIYUViR2VaZnlnVmFoZlZicWVjYmxiRmUzaFZoMGVwZFZmS2hEYkpkVGdHZkdmUmRXZ0xheWJnZ2dnSWJnYXhodGZRZEdnMGhkY0hlVmVWZFNoZGhHZ3RoNmVZZTBoMWRxYlNhd2c5Z1NiRWdHZlJmTWFkYW5iWWdBZkJhMGNFYXRnSmVGaHhmTGRhYWtic2VOY0tiamdzY2pkZmJFZGdlWGRSY1Zjb2NuZGRlRWZzYStiY2IzY0phOWRXYlJnQWNaZGFkQWJ0ZkZmYmN4YkVhVGFiYTBmZGN6ZUVkMGVkYW9kRmhRaHNmUmVGZUZiVmdtYWNiQmVSY1ViT2RUY2RmSGNZZjFmVmRRZVBkR2hsYmhmRmZoaGhlbWhGY0doWmRtZVljWGRCZVZoYmcxaHBjSGRIZVJkMWRWYVVlaWZZZ3VjTGhqYVlkZmFKaEVidGdYZVdna2JRaHNoQmdTY1ZhNmdVY2hhWWFaZGVjQ2VRYWVoU2UxZ0ZhS2JRaGthaGh5aGNjSGFCZ0lmUWMwYmxhYWZkZ1hkaGFMZWRhM2JwY3BoVmcxZWtjUWZXaGlnbGJZY0FoR2I4Y1RnUmNpZHdmVWdZZlJnRmNkaFFkaGRWZ0lhVWVFZWNkUWFaZG5jSmFXZkZnV2ZwZ3loVWZYZmRoWGdTZWhhWWhxZ0llRWRWYmRjWmZoZ1lhemFKY1RoSmU5Z1JmMmQxZUFlYmdSaDBnZGhWYVZiSmgwYmFhM2hwZ2phVGJXZXBoTGREYzFoSWVRZlpnRWJ3ZTFoTmd3ZkVjSGRGYVhjb2ZqZFJhZ2gwY0pkVmRSZ1VobmNjaEdjcGNhYlNmRWZOZEphV2JuY1ZlNGhTZTNkZGY2ZGFnVmdkZ1pmRWhCZmxmb2FDZndmWWh1ZFFmbGFaZXZnUmhTYVpkSGJBZVdmVWNFZ1hiaGF3YUNnRWRuZXhhWWhWZGhiVmhxZGNnbGNGYTNlVmMwZG9kV2JhaFdiRWJXYkdnR2dZaFVjWmRtYVpnaGJJZGhiQWQ3aERieGZWZlRnSGRUYWRhYWRJZUNnTWN6aE1mRWRGZ3FjSGh3ZU5lU2JRaG1haGdNaFBkM2g5ZkpjYWVCYlZiNGFkYmhiSmhMY0diRWZOZlpmWWJuY0pod2FjZEVoaGJEYlNmVmdvZnhmUGFRYTBoMmFMZ3ljVWhEZlFjemFvZlphYWdBZnRlRmJiZnhkRWVUZ2JjMGFkY3pnRWEwaGRib2NGY1VjaGVRaFJkeGZBZHZmTmVGZFlmZGRJYm5jdGZSY0ljeGM4Y1lkV2VUYjViaGhXY0ZhMGh4YUZoQmZJZS9oTWZUZFVmd2VQYlFnZ2dJYVRheGhWZVhlSmV6aG9iZ2dOZUNhd2VhZ0poRWR0Z0tiSGdGZk1hcmJDZkRkOGI0YUZhVmZnYVZiZWZuZlloWmJTZDFoMWRLZlFha2NoYnloY2dIY0JoSWRRZDBibGJhYWRhWGVoZUxoZGEzZXBhcGNWZTFka2dRZEdoV2JnZERmQWNHZThnTWVFYTJhZGRGYmNkUmdOYk1jYWVGZUJnQmZYZGhmTmJmZ0NmamIwY0JlVWZEZWdjUmRFZENmUWdTY1FiaGU5ZGdkYmVSY1lnUWVMZ2hiUmU3Y1pmbWZCYmdnWGFIZVJld2JSZXhjMGJkZVZjVmVKZTBhYWEzaHBoamJUZFdkcGRMY0RmMWVKZ05oVGFrZnhoMmRkY2xkSmVDZkZmWGZoYjJoRWNrZnRnRmFTZGxnVmRJaGNkbmZCZndiU2hFZU5jSmdXaG5oVmc0Z1NmM2Q4YjBiWmd3Z2NkTGdYYjBoMGNuaFhleGJ3aC9oVmNCZTBmN2ZDaEJmbGFnZktlQWJZYVZnVmdWaEFhQmFSZlNjZ2F4Z0FkbGZ3Y2xjUGFGY0ZjL2ZYZmtocGROaFFhMmRFYldkR2NHZFlmVWhaY21iWmhoZWNoRmRWZXZhV2FoYlZnWWZTYVFhQWVBZU9hbWZzY2hkU2RVYjFlcWdTYXdkOWVTY0VnR2FSZU1iZGRuZlpoU2VRY2hhVmQ0Y0lna2hzZGJmWGdWY2xlWmRZZUJiQWZsZU5iZ2Y0ZkdnR2YxYWhoNWZVaGtjdGMzZWVkbWRsZVhlV2hSZ0FkWmRhYUFodGhGaGJmeGdFY1RkS2J3YllhbmhVYWxkMWZvZWRoQmNvZkNiQmhrYmxhb2ZJY2doUmZhZ1BiamQwaEZkTGFnZmNhUGFHZERlb2J0ZVhjMWhzYWpoR2NpYVVhbmhMY1RjeGNkYk9neGdJYU9kVGNoZE1lcWVFY3ljWWQ1ZWVlamI4aFJhYWJoZjlmSGhHYTBoTmdvYVRnR2ZaYS9kWGdtZGdmVmFlZ0hhWWFTZ1NoeGZoZ0RiV2RXYUpjeWhjZ0hkQWdWZFdnR2FOYWFoZGVYZmhiTGFkYTNicGdwYlZnMWdraFFjUmNHaEVhUWFiZzJlOGhSY0VjMmI5ZEhoY2d4Y05lSGdQZWxnUWFhYVVkQmFOZEVlWmZtZzliV2RBZVhhcGdyY1JjMmN4YjloU2RoY1plcGVZaFJiWWZZY1poaGhSZ3ViS2hHZjhhZ2dCYXlhQWNPaENiRWJsZkVoQmRSYmRjNmZPaERkWWFxY0RiaWg5ZExlRWVsZUpkV2hNYVFjSWQxYklhaGZzYU5jV2EzZGhlK2JSYmthY2NZYUVmVmdCYWlkS2VWYXBhd2dTZUViTmhKY1dlbmFWZjRjU2czYmRiNmRQZnhoWWhMZEVnRmNCZ29kRmhraFVlN2dXZlZhb2Y4YVNmVGY5Z1dkQ2RTZjljQmRBYkVhdGV0aEVmR2RaZ3lhVmRoZVZicWdjZ2xhRmEzZ1ZhMGFKZUNhYWdYZHdoV2VSY2piaGFBY2JnMmFwZUxnY2ZGZ1ZjdmNXZ2tmY2JkY0hmVmVWZVNkZGVHZnRoNmdhYXhmOWRxaFZoZ2Y4aEVhWGN5YTBjSWFkYm1kWmdTZ1hjd2JoZmxjZGJrZEJlTGRCZDBjTWRRZ1lhbWdoaHdhTGZoZ1lkUmJRZEZiWmRmaGVkRWh0YjNjZWVtYWxhWGhXZ1JkQWhaYWFkQWR0ZUZoZmh4YUVlTmdiaHhkTmZ6aERoRWNkZGdnSGdSYXhoUWJUZEFnMWRtZU9mMWU4ZFpoYWJtYkplUmVhZlZoY2FlaEZhbWI5ZW5mRmJoZUFkeWFGZUhhdGZtYmNnWGRsYmNjYmMwZkJhSGdTZ1JhMWVMZVVkamMxYnJnZmRHYlZmTmhZaGhmOGVQZFRneGVBYXRkUmZYZnBmY2RVY2tkSWVWaGVlSGhZZ1NlU2R4ZGhmRGdXYVdlSmd5ZFljSGNCZFdoUWh4YnRoYWRhaG5maGdEZmZmeWFoYnBiWGdFZVFkUWVVYUdkRWNIZ1JoWGM4YlJmRGdXYjhnVmJjZHhjVmNCZ2FjQmEwZWFoVWFGZ29hUWdkYm5odGVmYUZnWGVCZ3lhQWUzZ2RkSmNTYmxkOWVwZlpheGRBYVlnYmJrY1pibWVlZzJkRWI1Z1hkR2hOZndhUmJ4ZzBoZGhWZ1ZlSmYwZ2FnM2RwYWpmVGhXYnBmTGRXYTFmSWNPZVpmQmQ1YzJiY2FGaFJkQ2FIZFNncGgyZkRkMGd0Z01iU2draEplSWZjZG5lQmJ3ZVNhRWhOZkpiV2RuZFZhNGNTZHllRWc3aE9hMWVjYWNkQ2N6Z05kb2JDZzBiVmV2Y0ViUmhOZnZiUmEzZ01mVGdEYmloNGJWZ1FkQmc1YkpjWmdCZzhjQ2hNZDNmRWNWZUVkeWRNZEZiTmdqZE5lcGdHZ2hmUmJtYWFjQWRsZW1mRWZtaDlnTGZjZUZiVmN2Y1dha2JjaGRhSGFWZVZiU2dkZUdhdGE2YmFmd2FoYnFnVmVnZThoR2VXY0NjMGFmZGVoQ2VVZUhnQWNGZVFlcWhKZ0ZkTWhTZ0VjQmFkZ1ZiWWFpZEJmNWRlZVVmUmZEaFFmUmc5YjdoQmV6ZlFlbmZLaENkWWFEYkZjbWE5ZW1hYWFCZlphRmFJYlJhOWNEZlBhUWNnaG5mWGVCZU1meGdSYlFiMWVaY1hkRGRwYW1jY2ZsY1loVmRhaG5oSmFSZmRoMWJkYktmVWh5Z1VheWVVZHhjZ2U5YVBhbWRaZ21iWWhYY0JmVmRiaDFjcGVIZEhoUmQxZlZjVWdpYUlkcWZLYUdjTWRDZGFhbGNZZlBkQWVCZkJlcGVUZUNmSmJ0ZWVmRWJJZFZoZWhIYVljU2dTZ3hhaGVEZ1diV2RKaHljY2FEYVZjSWhYaGtma2ZVY01hQ2E5ZUxiT2dYY0lhbWdXYTFhbGRHZlZnaWJGZFBoUmFYZDhlWWhDZkVlVmFIZ2NoeGNOYUhkYWhCY1ZiSWdVZ0VmY2VRY1pjbmdJZVFjV2RqZGhleWdXY1NoRWRXZUdmQmdZYmhoWWVRZHNoWWhkZWdjOWJtZUtjV2JGY3VjVmhTZ2RmQmFSZ3hhWWVXZUhkVmN0ZTBmTGFnaEVhcmVNY0djcGVXaERid2JaaFlmTGhSZjhlTmhQYmxlSmdKZUZmU2Z3Y0xoQ2ZXZkVmWWhRaDFobGFpYWNobmZCYndnU2NFZE5hSmRCYTFnOWM0ZVNmM2VkYzZlYWFWY2RmWmVFY0JmbGNvZ1dhUWdBYjdjUmNFYUViaGFSZXpnWWJJZmJnV2ZnYVZhU2hGZ0JiSGVFZkdkWmd5YkNneGd4Z21iV2JGZkZkM2hWYTBmb2hXZGFkV2NFYVdmR2JHaFljY2ZLZEdlZ2J4aElnaGFvYTdjRmVSZk5hRWdUYlJlQmdjY0phaWY0YzdnSmF6Z2dnRGNCYVZkc2YrY2RkV2RSZVJmZGRqZUFkSGhEY0ZhWWVzYlBlMWMwZEZnR2FFYXNoTmJiZG5lSWFpY2ZhRWVnaEtmUWhGaG9ldWNVZ2tmdGgzYWVkbWdsY1hoV2NSZ0FhWmVhaEFjdGNGZmJieGJsY0hmYmgxYXBkemVBaDBjY2QwZkZiUmV4Z1pjU2N4Y0JldWhJZUZmWWNJZmFjbWdKYlJiS2gxZWNkWWZIZjJnVmRoZ1hmeGJnaDZjU2JHaFliTGRhZ1NjUmdaZGJmd2JoZUxoSGFVY2tlZGNHZHljZGdsY05laWVZaERmTGJSYjlmSGJXZ3djdGNPZFRjSGJaZjJmVWdraEllVmhlYkhjWWhTaFNjeGdoZ0RiSGd5ZDBkZ2djYUhjZ2VlZEFnaGV0ZmFjTWRIZWhjV2FkY3lmNGhoYUhkZ2FwaHJhVGdSZVVkSGVSYlNjQWFSZURlbWc5ZFdkZmJ4ZU1lUGFhZUFnaGJJY1FiRmF3ZFFkYmNYZWtmZWVGY1hkWmN5aEFnM2hkaFJkVGNCYlphaGFMZGhkWWZTYmVneGZSZzBhY2czYmRlNWVUaG1iOWRUZGJiUmIwaGRiVmZWZ0pjMGdhYjNncGRqYVRkV2RwZUxkRGIxZElkUWhJZVVmeGM5YmFmMWJJYVdhWGVUZEVobGZhYVJhOGhZZFNoRmdrY3FlRGczYUJkNmNTZkFleGFTZmNhSGZWaDRhU2IzZGRoNmVhZVZnZGNaY0VnQmNsZ29iQ2h4YWNocWZSaFVhWWg5Z0NlWGhOYldkWGhFZklmVmFTZ0ZoQmJIZ0VhR2JaY3lkVmhoYlZmcWVMYzFmaGQ3Y2ZnVWNvZldoYWJXaEVjV2VHaEdmWWdVYVpkbWZaZXBlUGZsZ3NlL2dDYUFlaGJKZ1VoZ2ZFZUxiSmFDYjVnMGZNYVFnZ2NyaERlM2JvYjdjWGdqZEFidWRFYTNoWmVQZVFnbGFNYnRjT2VGY0VjZmRVZlFod2hYaFlibmFvY2tjZmVFaGdlUmVSaFZmb2E4aGNkVWNzaHNmVWdHZ2xjWGNXY1JoQWJaaGFiQWh0ZkZjYmR4Y0VmVGdiYjBhOGFuZ0VmMWNwZW9kQmVVY2dkTWdSZjBnUmJ2Z2ZkbGRZZWRhT2FIZkpnTWhkZzBnZGJLZVNmbWZrYXpnSGR4Z1JhbWdYZldoWWM2YlBlWGdBYzRmWmJ3ZDVjTGNIYVVnOWVaZVVnaWdBaGplTWF6YkJnRGNKYWdlNWRCYkZnVWNRY3NlUmZXZTFjY2JVZGtlSWdWZmViSGFZaFNnU2J4YmhkRGFXaFdjSmR5ZU5iamY4aGFhUWMwY0VlTWNOZkNjcGZMZU1kbmhwZTBkVmV3ZzFoWWFVZURldGZ3Y0ViV2Q4ZmFlRWMyZUphS2NJZ1dmNWJMYWFhRmVwZUljVGVVZmNmQmJmaFhiSWNFY0ZoWGRSYnlkUWNYZGRhUmNUZkJhWmJoZ0xiaGNZZlNkZWV4YVJhMGVjYjNoZGI1aFRhbWY5ZFRkYmNSYTBjZGhWaFZkSmQwZGFkM2JwYmpoVGVXZXBnTGZEYjFiSWhRZUloVWF4YjlkYWQxY0lnV2JYZ1RnRWhsZ2FoUmM4ZllmU2FGY2xkdmJmZXlhSWVOaFNjRWhsZ0poRmdXZzVmU2JTZDNhZGc2ZmFjVmdkaFpmRWZCY2xhb2RDZzBiVmJ2YlFoMWdZYzdhRWZpaEZoZGVSYXlnMGRPZVljbGhCaEhhRWJHYVpkeWFWZGhmVmFxZ2NobGFFY3FmWGVrZFliOGJhZVdhRWRXZ0dkR2dZYVVkWmFtZFpkaGhjZUZhMGRoYlZoQmRkYVBiVWZnaEViZGRJYURmSWdxaEpha2RNZTRkRGRrZDRhV2daYVFoMGFDYkllbWc1YVNlWGR4ZlVlK2ZJYTFjd2dJaFRmQWFvZVdlTGdIZkpnNGRKYkVmUmFEZEdnMWhOZTFiSWYyYkZoM2NlYm1hbGVYY1dnUmRBZVpnYWZBYXRkRmJiZnhlRmdCaEtiaGdNYW1jUWVRZWxlb2dSZDBhZ2dNZUdoeGhBZUxnZWFnaElkWmdhZ21iTmRkZWRid2hNZUNjWGV6ZXBjdmRXYWxjMGNvZ1VlemJJYXViYWFIYXhnVmNPZnhiSWFPYVRobWdZaEJhTGgyaDlhQmJlZG1iTmZOaGFla2ZzY1BjVWVoZUJoa2dUZkNodGcvaFhobWNnaFZnZWJIY1lnU2VTZXhjaGREYVdoV2RKZXljZWNEYjVoR2ZFYnhmc2FWYklmVGZjYmZoTGVpZG9oc2ZXZVFjdGJWZ1dhQ2h4YitoTGJDYkZlRmRBY25ja2NyZkZlaGROaGFhYWFGZk1lZGZIZ2doUmJFaExjemYwaFlhRmhXYUljbWVYZlhmY2FGYVFjeGJZYnliU2R4Z1llWWZaaGhnUmdtYlplbWVGYndhVmNXYzlnYWhSZzBhOWZZZUFiUWhjYm1oSmdYZm9meGJUZVRhWWNYaERoemc4YVlnTWhFZUJhMmZaZ0ZmNWJDYVFiVGhBZC9mUWVVY1ZlVWhCZWhnY2dsZUplamRoYjVmUmZFYk1kZGdFZGpid2ZyZU1jQ2JNYUhoYWJRZ3RmWmFHaEVoMGZnYVFoaGdZZVVnUmNSZk5ka2hSZDJnSmZ1ZlJlM2FRYkpiU2ZFYmhkT2hDYjBieGV5aFZkaGVWZ3FoY2NsY0ZjM2ZWYzBhb2hXYk5nR2hnYWFoTWdtaFliVWFaZW1mWmRoY2NmRmhWaHZmV2RrZGNnVmNVZDFoc2hDaEplaWhRZXViTGFCZWthemRHZzBocGRjYlFiaWNFZk5iTWVnaE1hN2NEZkVlRmZwYVliSGVBZ3ViR2JGYzVmWmZKZkNkY2QrZE1ieGh3ZUtjQmVoZlJlMWVjYkJoOWE3ZWVkamN0YWVhV2RVZHNnemNhY0FldGdGYWJoeGhFZ1RmYmEwYmRhemRFaDBmZGVvZVJld2YwY0VjRWRraElnb2djYmdnUWhWYU5iaWI1Y1JjR2hsYThhZWRHaG1lbGZ6ZkdjaGRnZHlhWGFDZjhlMWRiZHpld2dRYUlnUmcwYVRhVmNSY1JmWmFVaG5md2QvY01haWNvZ2VmRWZSZzlleWVVZmdkeGM0aFRlR2E1YS9mVWJoaDRiVmhMYkRhNWNiZUdnR2NNZ1hlV2ZXZGxleWZZZlFjMWFUYWFhVWdsZ2FhZGFYY2hjTGZkZjNmcGdwZFZhMWhsZU5mRWdHZlFjaGFSYldiOGRSZkVmMmE5aEhkY2d4ZU5lSGRhYUJmMGdHZVhhaGVkaENlS2JTYlloWmhRYlRjTWVpZ0ZkSGNrY0ZmRGExZGNmdGZGZUhlOWRXZ01oZ2dkZzBhQ2ZnaFJhd2NTZEdiOGRjZ0VjbGVOZGVjQWNSY3NiN2RKZ1hncGNyZ0dnV2NaYkxlWGNWYXNkUWJQaDJhWmQyaGRmbGFKaENjRmdYZWhmMmdFZGtic2VZYVFlMWJrZ3dmTmh5ZFFlbGhHZ2dhMWNKZlVkbGM5aDRhU2EzYmRkNmdhYVZjZGNaZkVhQmVsZW9iQ2gwY1ZndmRFYVVlRmN2Y0dmeWI4ZVRnS2JtZUJnQmVSY0ZhQmJUYUhjR2dZZ21nSGFsZndlNWVmZUJmMGV5ZkdjUWcxY0NnSWRXYmdhYWhNYW1lWWdVZFplbWhaZmhkY2ZGYlZldmNXYmtnY2RkaEhoVmhWZVNkZmZEaDhheWZLZ2hjNGFSZEhlM2hKYVNjVGdHaFJkRWhJY2pjNGJiYkVnV2I0YnNhZGJoaGxmTGVDZlRhNWNaYmZkbWI1ZXdmYWRFZEZkRGhGZlZjcGM5Y0xoQWhNYStlS2dSaElkRGVXYVJkc2ZaZmVobmRaYkZkY2h3ZzBlVGNmY2xnRmI2Ykdoa2JkZWpoUGcwaGhiUWJSZHhoQmZtZGNibGRZZ1ZoYWFuaEplUmhkZzFhZGFLZkZjbWFsZ3dmQWdBYjlneGRBZzNoUmEzZ2RnM2hCZWZmYmZ3ZzRoUGVWaEVmNGF1aEJjbmZSZGdlZWVuZ0Fmd2dRY0Vkc2VQZlVoaGRCZ2thVGdIY1pjMmRVYWthSWRWZGVjSGY4ZEplWWJSZmhoRGdXZVdnSmF5aGNoSGZCaEllUWQwYWtkSGFmY0hmUmFoY2RmM2dwYnBlVmIxZWtjUWRHYldhZ2ZMZ1JkV2RkY2ZkSGNUZzhoVmhQaEVhY2NJaFBnRWZ3ZllhRmRVZmxjQ2RJYnplTWZTZFlkQWFNZzhkQmRXZ1JoRmNLZEhnTmFwZ2ZlQmRaZGVnTWgxZW9hbGVNZWllZ2UvYUdnMmU5Z1NoRWV4ZEVhZGhCYzFodGQwZU1hRmVCYmplVGJXYXBlTGhEYjFoSWZRZ1piRWV4YTJhZGFsYkliUWRVZUNjd2ZqZ1FhQWNVZlljU2YzZE5laWFjZm5mQmR3ZVNoRWNOZUplV2FuZ1ZmNGhTZzNkZGQ2aGFjUWdWaFpiVGZFZ1Zkb2JaZ2tmMGc3ZkhkUmZOYTdkU2MzZU5nSGFEZ3lnRmFHY1JhaGd3Z0NnWGVpYkVnbWJIaGhheGNtY1dmRmhGZDNkVmEwZG9oV2ZhYVdkRWdXYkdiR2dZY1VlWmFtZVpiaGNZZ1VhTmM0aFRjVmFBY1BlRGVFZ05jU2RmYW1oc2F1ZUtjd2FRZTVmTWRGZ3NndmhFZEdlOWRtZWRhbmFaYVNhUWNoZ1ZnNGNkaGhhSmdMZkdjRWZOZVpmWWhuYUpid2VjZkVlQmNMZ0hjUmZJZThhS2R6Y0FkamhlZG1mSmhYY1NhR2IwaFplZGVCZ2RhRmhmaGdkY2dhZGJheGV0aHphR2V4ZU1oZ2NYZ0Jkc2VyY0VoeGhCYXRoY2drZVJkb2FhZG1nNWdOaGRlMGQ5ZERhRmVqZ1ZmaGNRaGxhQWh2Z1JkeGQwYnljWWdYYXRoVmVmYkNhZGRPaE5meGgxYVZnVWVuZlJmcmJlZ21lTmJOZWFla2NzZVBhVWdoZWxlL2RaZ25jWmMyY1Vha2VJZVZlZWdIZVlkU2NTZXhhZ2hlZVViR2c1ZFlmY2RIYkJlSWJRYjBhbGNhY2RmWGhoZUxiZGEzZklobmRXYVFjbGhDYlZiamV4ZEVjRWdUZlpnQmNWYW1kRWNWZE5jbGZJY0RnQWFWYXNkY2JQZkNkSWVRYmVmM2JJZVFkUWRDZ1FieGRCY1RnNGZZYkJlQmRaYmhmTmdSZG9kWWNOaEJhaGhtZkxnMmFoZ3diRGdrYVZkYWhSY3hkMGNkZlZiVmdKYjBlYWczZHBiamhUaFdicGFEZVdkMWRJY05nWmFGYXhkMmJLaGxiSWdXZ0hhSGNSZTJkR2ZoYWtnWWhYZGxobGV5YmNjaWd4Y3djR2hrYXBnRmJXZmpmeGg0Z0ZneWN0ZjZmQmhGZjhoTmdIYkJna2E2ZEJiMGhVYzdhV2FWZG9oOGRTZFRhOWFXaENjU2Q5ZEJlQWdGZWxoY2NPZ21hWmN5ZFZoaGRWYXFkY2FsYkZhM2NWYjBlb2hXY2FjU2dkaFpnU2NtYVlmY2dNYUNoY2V6aGNlQmdCaHZkUmcwYWRmSmZWZVJkd2JCY0RkemU4YkhnYmgwZzBobGVTY3hhSmNTaEFnV2RoY01iUGZuYVpoUGJRZmdoVmZqZWRmaGJsY0FnVWRFYU5hRmhZYmlhQmV3ZWRna2c1ZURmUWRSZVZhMWJjY2xiWmYzY2FiSGZ4aEJlVWVBZXNoWmVZYlNhRmRGY2JmeGhFY1RiYmYwY2RkemZFYTBoZGdvZkZkVWNoZlFoUmgxaFZhbWNlYVVnc2NWZVBlamdvY1lnSmhDaHdkZWhGYW1hSmJoZFhobWdWaG1jSGNtYVlicGZlaGxocGZWYWJhMWZwaEhiSGRSZzFkVmdVY25kUmFyYWVobWhNY2ZiTGZ4YTloYWNBaEZnNWVrZlJkRGRsaDJnV2hGYThjVmZhZ1dhUWFLZ1FhaGdSZkRjSGZHYkpkc2FiZlhnQWZIaFFlMGQ5YWNlZGRYYUFmT2FkYzNnZGQwZVZiemdSYlJoVGZTYUFnRmJGYlNoQmZHZUdjM2UxZExhY2F3ZHRiSGdZYWhnVWhhYVdiVWc0ZWNiWmhqZWRlTmFQYjJjcGF5YVVjWGhkZlhhU2FoaFpmcGZZYlJmWmJGZ2JkeGZoZE1jWmZtZEZld2hWZVdjOWRhZFJleGYwYmRkVmZWZG9iNmVaYVNjb2d4ZUFlamQ0YUVnV2J3Z3RiQWFJZ1ViSWdrZk1ieGRNZkdhZmVEYllhaWhjYUNjNGdZaFhobGJrZGthSmF6ZDRoemJIZkFib2hHY0ZhSGJWYndhSGMzY3RhNmVPaDFidGJaZ1dhUmFCaG9hVWJHYzlmdmFFYVJoTmN2ZFJjM2JNY1RlUmgyYWdhVmVTZEZmQmdQZVJiR2NaaHZjVmNnZlZkcWZMZ2xlRWNqYVhna2ZZZ1doWWZUY01lV2VCZVdjWWNFYVpjamFwZ2hkSWRsYXhhamdXZmdnNGRkYVFnUWRsYVNiR2VXZk1jdWJiaDBmMGY0YlJld2M4ZkdhV2dDYTBoZmhlaERkb2ZYZERkRmZJZHNmUGNoaHRhUWNNYmtoTmhaZllobmZKYXdhY2RFYWhhRGdTZVZkcGMxZGVmQWYwYTRnS2dHZmxnZmREZTFjRmRMZmFmRWQ1ZEZmY2doY0ZhQmhZZTBoY2Y4Y0VhMWZwYW9hQmhFaFJhUWVEZXhhQmg3ZmNnZ2ZKY2RhSWN5ZEVhcWRJYzFkZGZCZkZlbWFSY3NoVWcyZ1ZkOWFGYUNjTmRtZGZjM2FCZkZlYmQxZXhnQmdIZlJoVWFhZVVhbmg1ZTJlZWFuZEZoWWNmZ0VlSWVVZFVmaGdsYU9iVGNIZFpmMmdVYmtjSWdWY2VhSGNZZFNlU2F4ZWhmRGRXZ1diSWY2Z2NmSGd0ZlZkUWN4YTBjU2VQYUNmc2d3ZkloM2ZwYWljVmYxZVFiZGNYYkJmVWhMaFRmMmg5ZGVkQ2dFZVZhSGNjYXhmTmFIZ2FhQmhWYkloVWhFZWNmUWRaZG5oSWZFaFVmRGQ0Zm5jQWZ6ZGxmWGhRYmxibGJwYWFkd2hzY1ljZGN3Z1pkK2diYTJoMWR3ZUhnV2Y5ZUVjV2VoZDFnU2hWaFZjUmF5Y2FkM2VJZXJjVGdXYmRnV2ZEZHpkOWZSZU1jQWVSYzRnSmVoYzBiVmJIZFdkcGE2Y0VkbGVNZVlhU2dWZGtnd2FlYjNhbGI4Z1NoQWF0YVNhY2ZIYVZmNGNTZTNhZGc2ZGFhVmVkaFpiRWhCYmtlMWRBY2tjbGJGY0VoUmhOaHZhUmgzaE1kVGRSaDJjZ2JWY1NlRmFnYkphSGdqZlloZ2dHZFVkRWVsZEpkZ2JnY25iRWhrZFJlRWdMZ0NnQmNTY2NkU2NoYkFmZmZtZFpoOGZjZEJmTWc2ZkZkQWZSZkpiVmRCZG9hY2FkY0dlTWZ1Z2JiMGEwZDRjUWdnYThmSmNPZ21kUmdNaGRnbmhaY1NhUWZoY1ZjNGdkZ2hmSmJMYkdlQmRFZ2NmTmNpYWNhaWNQZ2tiaGhMZFlhMWVwYTFiZWVFZHRiM2JlYW1kbGVYYldiUmFBZVpoYWdBYnRnRmNQaFJoRmNQZU1lMGhjZGVjR2R4YU5ha2hGZlZjbGdjZlJoMGFRZ3VjT2J3ZlVoYmFKYWpnY2ZmZk1nQWhNY0NoSGUyZFZmTGRGaGhjaGFtY0ZlR2JaZm1oWWRYZUJjVmJiZDFncGhIZEhkUmUxZEVlUWFHY3hocmFmaEdmTWhaaEljZ2hKZWNoS2ZVaFFoWmZUZUdlbGIyZ1hjMWhNZFZiY2VuZVloYWJXYlFlMWFXY1dkV2Y5ZHlhSmNEZ2dlQmhFZERkSWdPZkNiSGZoZkFmZGgyZ3RlZ2FWZTBnTWRRZVRmU2JCZ0NmRmhoYlJjRmJiZWthVmFIZWNoeGhOYUhiYWFCZlZlSWNVZEVmY2VRaFpkbmJKY2ZlRGRrYkJmeWJVYVhjZGZYYlNkaGJaY3BiWWhSYVljWWJPZ3hoMWhxY1RmR2NGZXdhVmdXZjlhYWhSY3hkMGNkZ1ZnVmhKaDhkSmhYZVFlemFIaHlnVWNmZVFjQWVaZUpkTmdBYmxkNGRKaEJoY2FEZ1VhUmdFZTRiUmRsZW9oT2RMYXpieGVpY2JjM2NBZDJiSGJRYzBkS2dEZmpjd2MzY0JjWGVkZHlmUGJWZnRmWmZRZGhhQmFvY1VkR2U5aHZhRWRSYU5odmNSYzNjTWhUZ1JlMmhnZVZoU2ZGY0FlVmRFaERnb2h1ZVZlbmNoaGlmSmZsYzFnM2FSZVVoWWFXYVBjU2hsZWZiU2IyZ2hkWWhJaHlkZ2ZtZEpiQmExZW1nUWdXYTBhZGhIZFZmVmNTZ2RjR2Z0YzZjWWEwZzFkcWRTY3dhOGhFZVVhVGhaZ01nUGYzY1pnUGRRZ2tmRWR3Z1BiMGFFYXdkVGNEZTVoWmdQYW5mSmc0YkplQWZBZEtoR2dpY0VlaGVlZUViQmQzZGFieGRSZlhkUmNRY3dmWmNjZ0FoSmhlaFJnUmdFZ1RnYmgwYWRjemdFZTBoZGZvaEZjVWhoY1FmUmcwY0lkamhKZWdhTmRIZ0phSGRKZUNoWmhVY0JhY2hEYW1hbGduY0ZnbGFGY21lQ2UyY1pmeWRjaDJjbGFCZGRka2ZwYldhQ2FnYnRnRmVVZmloaGZyY01nMmJOZFhjYWVnZUlnVWFlYkJhQmJrYVRnSGRaYzJiVWZrY0lmVmNlYUhiWmFQZFFkaGVSYXBmV2hXaEpmeWFjYUhkQmJJZ1FlMGJsY2FkZGNYY0FoRmhlZFNkb2c3YkdhQWExZ2ZnVGZUYkZkYmRBY0dhRmJEYVZhaWY0ZURoR2hsYTBnVGdlY1FjTWNxZk5oVWhjZk5hWmdqZFFoRGVXYXlna2VtYUdkRGdnZVpnU2JoZzRmOWhiY1JiWmhLZGJoeGVRZzloVGJHZEZmd2RWaFdjOWNhY1JheGYwaGRnVmNWaEpmMGRhaHliaGRqYkViVGJaZ0xmWWRsZXBjRWhhZEVmeGJrY2VkbGdJYVdlWGNUZ0VmbGhIY0FoZGdkZ0RmUmY0YjJiT2JuY2xjcmJZY2tnTmdKaFdibmhWYTRoU2YzYWRmNmJhYlZhZGdaZEVhRWU4ZHBmV2NVaFVjbWJFaFFkNWV2ZUVnemF0ZmFhRmFCZU5hQmZTY0ZndGFIZkFhUmR0YXlhQ2hoZVZlaWhKYWhoa2QraEJmRGhGZENhRmZHY0VhS2VCYUdjWWhNYmJhM2QxZUxoY2JGZlZhdmhXZ2tjY2ZkZUhlVmFWY1NlZGJHaHRkNmdNYVFiZ2YrZUhmbGUwY2NkRWhIYmRlZWNZZVdkQmhLZVFhaGROZjRoUGR4Z0phVWJHY0ZlZGFMZWVjMmZaZnBlWWFGZ2xhVWFYZzBhcGgxZEpiRWZzaCtnZWZuZU5jWGZFZEFhc2d6YWFnQWN0Z0ZlYmN4YkVjVGJiZTBoZGh6YkVleGVwYWhmR2FXaEpjUWhSaHhnQmJtY2NmbGdZZlZhYWJuaEphUmdmY3hnbGVFYVJhamhzZnVmUWJsZ2NkeWJUY1RnWWNqZWJieWJJY1FlTGVoYzRmdWRVYTBnbGRHYVFiQmdnaE9kZWZuZTVnTmZMZkJoNWhCYkVnVWdRZnRmQWR6Y2hkMmFXY2hkWWNaZ2VkQ2dRZGJmU2MwYU5ocGJXYldlSmJ5YmNhSGVCaEloUWEwZ2xmYWZkYVhkaGNMY0phVGc4ZTlhQWdnZHRmZWFHYVdiQWZoYlJhV2I4Z1JmRWMyYjljSGhjY3hiTmRIaGFnQmVWaEllVWhFZWRjQ2JaY2lhNGJLZEZnUWFkZzZlQmhYYnRhWGRYZmhjcGFwZU5nVmI1YlJnTmFSY29kcWRJZ3lnOGMzY0FlU2hkaFRkU2h6Z2NjZGZWZ1ZiSmUwY2FnM2VwYWpiVGZXZHBkTGZEZzFiSWNRYVpkQmFnYStjUGd3ZEVlNWNRZFFnVmUyZlRmbWVFZ1loUWMxZGxhaWZjZm5iQmN3aFNlRWFOZEpnV2FuY1ZmNGNTZzNiZGU2Z1lkUWRNYVJlV2ZVZW9jVGJYZDBlVmFrZkViUWZJYVNoUmIyYjhhUGRSYTNmQWdjaFNjQWV4Y3RnRWRHYVpoeWNWZmhoVmNxZ2NibGRGZDNlVmgwY29nV2hhaFdhRWFXaEdoR2I1Z0FjTGVpYjhmeWJDaHdiRmV2ZFVkVWFjZVBnWWdGY1ZmT2dhY0didGRyZWRkVWZSZnFmRmh5YVZiU2NFZ0dkUmFNZ2RnbmNaZ1NkUWVoY1ZhNGJkZGhmSmdMY0djRWhOY1phYWRpY1lmNGFPaFJkc2Y0ZkhnVmhwZCthZWhGY2djS2NlZW5jVmdMZldiUWRJZE5hWWVTZkZiRmhiZ3hkRWdUaGJjMGhkZHphRWIwZmRhb2JGZ1ViaGFaYlhnRGNwZW1oY2VsZFliVmhhZm5kSmdSZGRmMWVkYUtiU2EyYUJjdGZQZkJoaGNtZEZiR2JaZm1nWWRYZUJnVmNiZDFjcGFQZFVieGJNZkZoQWNEYnNhL2dOZ1RoY2RVZE9mZ2E0Z0JiQWRGaFVnbGdDYUJlOGI0YkJmbGhFZkhoR2FoaE1jU2ZWYWhiZ2FGYURhQ2h3Z3hnSmhEZmtkSGJEZVVjbGRTaEljWGdSZExjSmdYZU5kcGZEaEhoTWVRZkdjV2FnZkxoUmdXYzhoUmhFZTJjOWVIZmNoeGNNYVZoTGdVZ0VmZGFBYmdna2VRZmJkbGNoYVdhRmJXYnBkeWdVYlhmZGRYZ1NiaGFaZ3BhWWhSaFliWWdaY2thWmFtYU9lamMxY3djT2FHY2NkT2RTYXhmMGNKYVdjVmZJZmdmSWh6YU1od2JRZXlhWWJPZ1FiUmFWaEVjTGRFaFZoNmdYY0ZoSmRDZEZoWGJoaDJlRWZraHNnWWZRZzFibGFpYmNibmRCYXdhUWZCZWNiQmRFZXlnWWREZ0hod2VwYjZkZGNVaHRlWmNBZWdmMWFoaENheGZsY0ZnRWNSYU5odmNSaDNjTWFUY1JkMmFnZVZiU2NGaEJhSGNFZUdkWmh5YVZlaGYwYytoT2doYmdka2FMYkJnNGhXZ1lkbWZFZUhnWmJXYVljSWFlYW1lWmV3YlpnbGZ4aHZhQmFtZTBjZGVIaFZoVmVTZmRiR2J0ZDZnWWEwYzFkcWRTZHdiOWhTZkVkR2NSYk1hZmVpZkliYWdDYzBmWWhEZkloaGdKY0FoR2ZGaEVka2NZY21jNWhzYmNiRmhCZ0tjU2dRZFplZmdlZ0VhdGYzYWVnbWFsZFhmV2FSZUFiWmFhZkFjdGFGZ2JjeGJFYVRhYmd4YU1kN2hXYWhkUWFUZFFjVWhoZGJjUmV3YU1iYmZXZEZoWWZWZmFlbmZKaFJnZGUxYWRiS2FGZW1hbGhoaEZlaGZGZDlhUGhtZlpmbWhZY1hiQmhWZ2JmMWFwYkhiSGhSaDBkSWVXZTNiaGRCYmVkbWFOZk5kYWZrY3NnUGRVZWhjQmFrZlRiSGU0YjRnWGJCYkpoSGVOZnlkSmhkYkhjMGRFY1RoSGVHZHdnZ2ZOY1RlRWFNZEpiUWhVZlZlTmRDY3dmbmRFYm5lcGUwYlZmeGQ5YUZkVmh5Y3RkZmZEZkNjQmhmZkVnMmRjZFRkZmh4Yk1kVmFZZFJnVWVUZ2Vma2hjaFFjWmduYUpkV2RGZVdocGV5YlVmWGZkYVhnU2JrYlFnc2NOZVVlTmVLZ0tnQmFRYjBhWmhqZzBkc2FWZVFjSmRTZ0VjeGhFaGRnUWZWYjVkMGFQZnphSWVxZkhlbWZRZkhnU2JoYXhlWGdNYkFiUmUvZ2VobGhJZjFnR2h5Ym9jemZVZXdlOGZRYUZjeGJFZnJkSWNYZ3hhd2FIaEVnOWhKZVdhMmdWZzBiU2IyZlZocGJaZ1ZkZGJOZEdmUWZKZ0NhQ2QwZFZndmRFZVJnTmV2aFJjM2NNZ1RiUmJ6YVVnY2NSZkhncGRIaEVhR2daZHlkVmdoY1ZocWJjYWxjRmEzZFhod2dRY1lmT2VUZ05kWmZUY0NibGJBZ1BoemNZZGtmZmJnYWNkcWZHYXdiTmI3Y1VnUmNvYVRmSWhBZ2toZmJZZDFlQmFxYkRhVmNvZGNhVWF6YkFnRmFPZ1RnaGVTaFNoa2ZGaDBkZGFrZ0JmQ2ZHYUJoaGd6ZFlhbmFKZXdoY2JFYmhnRGZTYlZncGQxY2VkRWV0ZDNlS2NDYXdnRGVEYUVjSmNYYmFhRmdsYUZjTWcwZTBkVGVBYWtnOGNuY0hkMGdkZDhhR2ZVZ2diRWVEaDFla2gxY2ZhQmhwYVFnSmJEZVVlRmRQYzFlNWRHZEZnaGQ1YnZlUmNGZzBobmNVZEdoNGF5YktjVGNrZEdhWWQxZW9oVGdFaFJnMWJVZFFoM2FoaHJjYWFIYkJmQmFhY2xnOGhHZ1NmVGhwZWtkVGFIaFplMmRVZ2toSWZWZGViSGhZZVNoRmNoY0ZnUGVjZDJkSmF5YmNkSGhCYklhUWgwZ2xmYWJkYlhkaGREZU9iWGhRZTVoQmVSYlpkRWFWZGpjeGRTYUZhU2FvZ2ZlUWNTZG9hR2dOZTNkY2RJaFBlVmVjYkVmRmdTYnRiMWNaZ21mOWVXY1VnemQ4ZjhiRWNpZE1nZWFCaFZlaGZwZGFlVWVJY1VoWmVrY1pmdmZaYWpicGFhYVZiV2Y5ZWFlUmV4aDBjZGZWYVZhSmUwYWFhM2RwaGpmSGF5YzhhZmdXaGdnQmdlZFplQmE1YjJmS2JnZzVnQ2dlZEhnQWZpaEhma2RzYkFhVGIxYWtmMmhPaGpoa2ZqZlJhZ2g4Zk1nRmFEYkllc2FBZjNnNWEyZWFkU2VCY1hjUWNsaHdncGhUYzBhMGc3ZVdkVmZvYThhU2IzY05lSGFTZzJnZ2FVZldoRmV4ZEhnQmRYYlJoK2FWZmdnMWVqY2FoWGh0ZjNjVmUwZ29jV2NhZVdmRWRXYUdoR2VZY1VkT2gyZzlidGZXZGxnVmd2Y1dna2ZjaGRiSGdWZ1ZlU2ZkZ0dldGR5ZUxoVWJNYjZoR2ZVZkFnR2ZYZnpnQWZWZ0pmamFOYmNmRWFGY0FmNWFNY25kWWJFYVRlUWRFY1ZhSmh4aEFnVmRjYkZnVmNEY0Rod2g4ZjdjT2h4YThhK2hOYVNlZGFYZ1VkVWdRaFZlYWRGY2xlTWViYjBnb2I1ZmJkMGFkYnplRWgwYWRlb2dGZVVhaGJRYlJieGdCaG1iSWFCZk5lQmFQYnlnQWFmY2Rod2ZWY0tnU2ZqZFZmaGNlY3hkQWR5YUdoR2NaZCtnYmdYY0FmQmVKY3hnTWZVZkVoMWhFaFFhSGNEYU1oL2ZNYm1ncGRCZmFkamd3ZEJoQWJGY1VhbGhDYUhiNGRpYkdoZ2d0ZUdhZGRIZlpjR2hSZXhiaGVDYlNoR2Q1Y3ljWmRXYkphRWNRZTFiRmRUZmJmbGFKYkxkZGEzaHBjcGRWZjFoa2JRYkdlV2RnY0xlR2RHZFllZGFPYldjOWdIY2NoeGNOZ0hlYWJCY1ZiSWFVZEVhY2dZZEtoSGV3YkdkUmJ5ZVVnbWJIZ2ljTWJPaEdhbGROZW5nTmFrZFJiUmRNZWxoRWNUZERjeWY4ZmtlT2JRYnBoYWNXZGhhMWhiYkFmQmF3ZjNnUGN6aE1ic2hBZjJkcGJEZFdiMWM0aFFjTmdrZEJiMmNQZjFnNWFDYVVmSGdGYjJmU2dXYkVnWWFRYjFjbGJpZGNobmRCZHdmU2VFYk5jSmNXZm5kVWZ4aERnWGJkZHlhWWNWYjhnTmFFZkFjUmZvZ0FiQmNGZW1jSGFSZE5hbmdGZ1hmTWJPZVJnM2dnZlZiRmZGZEFoVmZHZ1dmcGd5ZFhkbGJ4Z3FmYmIxYkZlbmdWZXhmWWFXYkliR2VnZWFoR2hHYmRlUmRiYTJnOWZoYUtnM2g5ZXZiV2drYmNkZGhIZFZiVmFTYWRlR2F0ZTZoWWgwZjFlcWFTYjFia2RUZVFhbWhRY0RiZGZtaHRlU2ZMYjFkUWRzZ1BoaGJ3aGJnVmh4YVJnUmRjZEhlNWV3ZWFiRWhoYUplU2FSYU5iOGVlYUVhWmUzY2FlM2JKZTlkV2FSY0FmWmZhYUFndGdGaGJkeGdFYlRmYmUwYmRiemNFZjBmY2FFZEhnUmh3YVlhRGFrYU5mcWVjZ2dmSWFaZ2FiaWJCZWRlZGN4ZzVlR2dGYWljWmR0ZkZjZ2RoaHZhRGUwZ3hhbWFZYlhnQmRWYWJkMWZwZ0hjSGdSZjFlVmJVZm5kUWYyYlVmR2JOZE5lYWJrY3NoUGJVZGhlQmhrY1RiSGFaYzJiVWRoZFJmVWhLaG5hWmNhZVNjd2NWZkRoU2VHZzVjWWNjZEhkQmhJYlFiMGVsaGFmZGVYZGhkTGRkYjNhcGVwZVZlMWFsZGVjR2RYZ1VoTGNWYlhjUWY3ZUVjMmE5aEhkY2J4Y05iSGVhZUJjVmJJaFViRWNjYlFjSWREZzBkRWVGY1djSWVtY0dlVGc0ZEVkTWZVY1FjVWhZY1Fic2JZZWRmQWNGaHplWmhtZ2Rod2RBZVhkUmZhaFRnQmZaaFRhVmVVYTVkMGJJaG5icGJsZVNiMmNwZERlUmYxZUljYWdlZlVkeGNrZlllMGJSZ0xiRGVuY2hmL2NPYkVnc2RZY1FkMWNsZmllY2JuaEJkd2dTYUVkTmZKaFdjbmhWYzRlSGR6ZThiemZPYWlld2hMYUVjQmNKaG9jUmdUZ2hodmhEZUJjTmNuaEVoM2dNY2NhUmF5Z0FoY2hTYUZjWmhIZEFnbmZOY25mVGJUZDlicWRjZGxiRmEzZlZoMGJvZFdkYWZXZUViV2ZHZ0diWmZHY0lhemdJYzBnSWJoZ3RidmFDY0VjY2FXaEhoUmF4ZkpmWGVtZHRjNmdZZDBkMWhxY1Nmd2Y5YVNjRWJHaFFmUmZmYTNjcGc0YlFoaGFWZTRoZGFoY0pmTGNHYUVoTmNaYVlibmVvZythZmNoaGdkUmZCZGdkNGY2Z0xhQmFJYW5iUGEyYmNmQWNDaDFibGROZkxlWGY0aHNkSWdVZ1ZieGFDYWtkZGJ1aEVnd2ZFYjlkV2J3Y3NmRWVEZmxoOGRvY2NobGM1Y0JjWmJuYUllRGdlZDFjY2ZEZEdnbWJrZWtoSGV4ZGdlOWNQZW1mWmVtZVlnWGNCZFZlYmcxZXBiSGVIaFJoMWZWZ1VnamQwZXRoZWVtZXRhRmNZYmhiOGZQZVRoeGVCaHZkR2RIaDlkNmdVZGtocGFIYmVmR2NzaFNkV2Z4YWdlZmVXYVRhQmc3Y2ZjSGJCYUFhQ2drZ2xhSGRkY1dmaGFMZEthM2dvaGdoWGJsZlVlUWVHY0NmMGVDYlRkR2Q5aEthT2dXYTlhSGhjZ3hmTmZIYWFlQmdWYklmVWZFYWNlUWdaY25mSmhXZ1FoeWZzZWdmVWJUaGhhWGNWZnhiWWhFZ0lhRWJKZ1FjYWdFZVFncGhNY1dkbGVpYVdlV2I5Z0NmUmR4YWNjZGdIZUZhdGcwZFphbmVwZ3loVmNrYUJiTGVEZzFlSWVRaFpjRWZ4aDJiZGNsY0poQ2ZGaFhlaGcyY0VlaWFjZlFhRmd4YkVicmRJZVhmeGZ3Y0hmRWM5YkpjQ2NIZ2xoNGhBY25ndGc2YkpibGJ0ZFpjQWNCYkJmemRJY1ViVmR2Y0VmUmZOaHZoUmQzYU1mVGNSYjJlZ2hWZVNoQWgxZHRmRWhHYlpheWhWYWhoVmJxZWNobGZGYzNjVmEwZG9jV2FQZ3lmQmRFZEdjQ2E0aFViZWUyYllob2JjZkZmaGd2ZFNoMGJzYjNhSGhWYVZoU2RkY0dmdGc2Y1lkMGMxYXFnU2F3YjljU2RFZUdnUWZDYmRjbWZ0Y1NmVWd3ZDVnU2NkYWhhSmhMYkdjRWNOY1phWWFuYUpod2FjY0VhaGNEZURmeGFVYm5mZWVFaE1mamJNZGllQWdFaElja2FJZVpkWWR3Y3NkTmNFYmhiRWhPZWJjMWdWYm1jQmJrYWRodWZGaFJleGRMY1JneGcxZXJnT2NsZlloTGZkaDNoSmRCZGRnMWdGaE1lRmdtZEVkdmRGZmhoSmc3ZkZkSGNSaHplZGMzYmxnT2hiaDFmTmd0ZUhkUmgxY1ZjVWZuZ1JkcmVlZW1hTmJOZWFha2dzaFBlVWFoaEFod2JCZ0RkOGVsZEtnUmZBZFZoY2IzaFpmYWNOZWhhaGVlZldiV2VvZ21hY2hIYjliSWZEZFVjQmdhZWNmM2FoYVphWWNtYjlneWNmZVZoa2JRYkdjV2dnYUxnUmhXZjhjUmVFYTJhOWVIY2NjMGJFZkNmUGVFYkFmYWJIZmtlZGdDZlpmbmRsZldjWGNIYUZkWWNVZlhhZGRYaFNlaGVaZ3BlWWJSYVlmWWNaYWtobGV2Y2Fia2h0YndlVmhXYzliYWdSZ3hjMGVkZVZlVmJKYTBjWWd6YlJjdGJIZVRnZ2NFYVdoeGQxZ0VhUGJSZXdlemJlZkFmVWVRZVhoQ2R3ZHphWmR5YUpjV2FGZTBmRmhpZmJiM2hBYTJiSGNRYzBoS2JEZ2pkd2czYkJhWGFkYXljUGFWZHRmWmNRZ2hmVmFvZFFna2F4ZHZmU2NqaGxmdmRSZTNoTWJUZFJnMmNnZlZjU2dGZUJjSGVFZEdlWWhnZEVmMGFFZC9iSWJCYTloM2RYYTJoQWhXZmFiV2JFZ1doR2FHYllmVWZaZW1jWmNoZ2NmRmdWaHZhV2NrZzlmSmZIZlVhaGhTYmZkemg5Z3pkYmEyZ2RncWhTZHdiOWVTZEVoR2NSZk1nZGNuaFpmU2RRY2hmVmc0aGRkaGVvY1pjR2VGaDVmWmhjaG5nSWJzaGNjQmFwYktmUmhYY0JlMWhlZ0VjdGYzZWVibWNsYVhkV2RSZkFhWmZhYUFkdGZGYmJnMWJnZlRoTWV4YnRiemdmYzBhOGQ4ZFhlUWVFZ0RoU2N4YUFieWFmY2xjWmFIZlpobmdKaEFnZWIxaGRhWWFBZTNieGV0Y0ZhZ2VoYXZiR2VFaHhmbWhZZlhkQmJWZWJmMWVwY0hoSGVSZjFoVmVVZ25hUmVyYmVhaWgxZ0RlSGRqZkpoL2FOYzNnUWViY0xoUWhRYUVmTWR6Y3RocWNDZHdiTmZpY09mM2VjY3hiTGNXYklndWJMZ0hhQmZBZUZlMGdsZkhoZGdSZVVjS2NJaHplSmhuaEVnUmJWY2ZjVmJqY29lRGhFZVdjWWZZZUhnMGdWYkhiY2h4ZU5oSGZhaEJiVmhJZ1VoRWJjZVFkWmFuaEpnV2NGYldiSWFtaEdhVGM0ZkViTWRVZlFhVWdZaFFkc2NZZWRhQWNGZnplWmRtZGRod2JBZFdjWmdXaGJkUmUwaGRoVmhWY0phMGRhZjNhcGJqYlRiV2FwaExkRGMxY0ljUWJOZWtjeGc5aGRla2FOZ29hRmRYaGhnMmRFYWtjc2JZZ1FiMWNsZmlkY2RuZUJmd2FRZFZkaGdqZldhbmRWZjRiU2IzaGRkNmZhZ1ZkZGVaYUVmRWdSaGhnQmgyYzlhdmZFZ1JoTmJ2Y1JhM2RNZ1RkUmEyYWdhVmVRZEJiNWRKYlFiRGVRZTllQWZsaG9oK2JLY3dkRWN5YldjUmExYUVnSWhEYlZoVGdiZVFjOWNhYU1lbmNkYzNnSGdEZUJldmRSYzBnZGZiZVNkQmVzaFJhSWNDZ0lhMWJMY1VmMWRpZkhid2ZOZVNhUWFtZGhiTWJQZzNhOWVTZ0dkVGE5ZDRiZGhoaEpoTGhHYUVjTmZaZllnbmVKZndiY2JFZGdiUmNEZ0FkNGFnZ0tkZ2FWYzNnY2NrZE5lWGVXZFJnQWdaZmFnQWF0ZkZiYmd4YUVjVGNiaDBiZGN6Z0VjMGg4ZThhRmZWZFZlUWZUaEViUmJ2ZGZibmZ3Z1ZiYWduYUpmUmhkYzFhZGRLaEZobWdsYWhiRmFoaGhibWZGZ0dnNGUwY1lkV2cxZFZlZmUxZm9iYmRIZ1VkOWNjZlhjbGE1YXJhZWVtY05hTmhhZmtjc2RQYlVnaGhCZmtkVGhIZ1poMmNVYWdlc2hWYkpiQ2hvZlNkSmJ4Y0FmWGNFYlNjc2NoaGZkSGZBZWNkVGEwZGtjSWhlZlhiaGFaZGViM2NwYi9oUWJraHdiRGFEaEdmUWZMYlZlV2RZY2RhT2NXaDljSGVjYXhkTmVIZWFjQmVWY0llVWZFYWNlUWVaYm5oSmJXYVdoMmZRY0dhS2dBYWNmeWFMZm1ja2hJZEVhMmVSaDVlSGQyZHNhVmZFYXhhRWFBYU9kaGcwZHVmYmJSYzBmZGRWYVZlSmYwZWFmM2RwYWphVGVXaHBkTGZEYTFhSWRRZ1pkRWJ4Y3BjZGJsYXBmS2ZRZVRjQWYvaFFoVGNCZktnUGhsZGxnL2djYW1kSmFsZ1hmVWFOYVBoV2dpaEZjeGJSYjNoZGN5ZlBlUmQ4Z1FoUWQyZEljNmVDYzBoNWh2aEFhR2M1ZHZmV2RuYk5kSGRSYjNnWWRMYVZhbGZCZWZhR2FXZjlnWWRWZGhhVmhxY2NkbGVGZTNoVmQwZW9jV2NhY1diRWFXZkdiR2hZZ1VmWmNuYnhmaGhIZjFmMGU3aEVlZ2I1Z09nRWdWYlViR2FlZEdmc2hvZGJiMGIxZnJhV2J3Y1piZWFPZG1nUmdNYmRjbmdaaFNkUWJoZlZmNGRkaGhlSmRMZEdkRWROZlpkTWVIYUpiN2VjYkZkcGJwZ1NjVmFwYjFjZWhFYXRhM2hlaG1mbGJYYVdiUmRBZFpjWWFSYkJidmViZHhmRWRUZmJjMGRkY3pmRWYwYmRib2RGZFJhVmdaaFNhemFwZm1lY2JsYVllVmZhYm5hSmhSZGRnMWZkYUtnSGJpZ2RhdmJSaGthb2NwZlFlQ2FrZXlhT2JDZEFnUWhZYlFmMGZWZlZkRWZrZlFkSmd4ZzBlbGFMZ25jSmJiZUNoQ2I0Z1BmVGF4aEFoaWZHZVRnZ2gxZEJlZ2R0Z2FhTmJuYllnYWhIZ3hiUmNEZUNmMmg1ZnllT2NYaGxlSWNHZkdiTmhhYWRoWGJoYkxhZGMzZnBlcGdWaDFia2ZRaEdnV2VoY1pnQWNEYnRlRWFRZ1NjRmZIYmViemNsYUhlYWFCYVZoSWJVZ0VmY2VRYlpibmZKY1djRmJXaHBjeWhVaFhnOGREZVNoZ2d0ZXBlYWdrZUljUmNhYmpmNWJtZVpkbWdGZXdhVmZXaDlkYWNSZ3hkMGFkZFZlVmRKZzBkYWMzY0lmeGJUZlhiZGdMaEhnMWhKZU1jWmFCaDViL2hlZ25jaGdDZUZkWGJoYTJmRWNrZnNkWWZRZzFlbGNpaGNlbmJCaHdlU2JBYnBhSmFCZ2ljbGU0Y0pkM2g4ZHVjSWJSZTRhS2hIYkJka2Q4YUJjMGdVYjlnSGZSYk5oOWJTZTNkTWNGYlVjbmYwYkdjWGVWZ3hhSGJBYkdjOWcrZGZkQmhWZ3FmY2NsZEZoM2FWYjBnb2RXZ2FjV2RFaFdmR2dHZ1liVWJLaEdiZ2FWaENlU2VVaEtnUGJqZmhjOGFiYXloY2V6YURlUmRRYkpiRmhqYzBiYWZKY0hhMGJtZk9obWdSZE1jZGJuY1piU2NRZ2hlVmI0ZWRiaGRKYUxnR2VFZE5mWmFZZm5iSmh2ZmNoRWVCZUxhSGdSZkloOGdLZXphQWJsZ0JkMmdsZktkV2FVaFFiWmVkZmhlVmhiZGJnd2RraGFmWWIwaGRkN2JSaHdlOGNoaFJoamhNZ0NnUmZ4YnRibWFZY3lic2NWaGRjM2ZKYkRmWWdrZ0phS2ZFZEdna2IxaEhkeGhGYU1mRmdHaFplbWFZZFhiQmRWZGJhMWFwZ0hhSGZSaDFjVmZVZ25hUmRyYWVhbmdsY05iQmNVZE5lYmdHYWxoa2EzYVFnSGhZZGljWGRrY0pmSGRkaEhjWWRUaFdkaGJGaFBlY2gyY0poeWdjZUhhQmFJZVFjMGVsZGFoZGZYZ2hjTGdkYTNmcGZwaEJkVmVrZmJhR2ZYZm9iaGhSYldiOGhSaEVlMmI5YkhjY2d4Yk5oSGZhY0JhVmNJYldnVmZ3ZDZlWmVuYUpjV2RGaFdlcGd5aFVhWGFkaFhkU2drZHRmZ2JiYVRhd2ZZZFpkaGFSYm1oWmhtZ0Zkd2RWZVdjOWRhZ1RoMWVNZ1RhQmRRZkFoN2JQZXplVWQzY0ZnRGFvYk9jQWdRZ1ZlQ2ZMZFJkZ2V6Z0FmemNzZ01lUWhXZXRma2RmYmllNGJZZFhkbGNrY2tnSmN6YjRkemJIZEFkb2hHZ0ZnSGRWYndkSGEzY3RnNmFPZzFmdGJaYVdlUmNCZ29oVWJHZjljdmVFZFJmTmd2ZVJmM2VNaFRnUmUyYmdjVmVTYUZkQWFWZFZjVGdJY25nQmhGZ3RocWRlZG5jdGMzYVZhMGdvYldlYWNXYkVkV2NHZ0djWWJVZVphbWFaYWhjY2hGaDBjN2FXaGxkb2RkZUZhZ2dGYWJlZWNFY0ZiNmZZZzBnMWJxZVNkd2g5YVNkRWZHaFJnTWhkY25jWmNTZ1FlaGMwZHFkZGZnaDlmTGdDZ0VkTWZGZVlhaWNCZDVhZmNHY0phRGJTZlZlcGgxZ2VlRWR0ZjNjZWFtY2xhWGVXY1JjQWdaZGFoRWZKYkZkTWUwYzBmVGRBZDBoOGRuZ1dhd2I0YTdlR2NVZWdhRWNTZnhhQWEwaGZibGRZZEJiWmVuaEpjRmFaZFVhNWZlZERoM2Y5YTJkQmRBZEZhemdHaEdjWmIyYWFjSGN4Yi9iYmgxaHBhSGhIZVJiMWFWY1VobmZSZHJoZWNtZE5lTmJhaGtmdGVCY1hkR2RRZ2RlUGRCYU1jU2dMZlNjTmRuZkNhaGJkaHJhTmJHZHNjMmhLZlJmSWVkZEFhZ2NSZGliUWEwYmxnYWFkYlhlaGFMaGRmM2dwYnBoVmUxY2tiUWhHYVdnZ2JMZVJnWGhBZlJiR2YyZWNnVGhPYjFjb2JVZ0VmMGhkYUlnV2YwZGNiRGZHYTNjSmRMZUZjVGM1ZXlkVGYyZmxlSmdTZGdiUmQ5ZWFkQmdvZnljWmhoY1JmbWZaY21oRmR3ZFZoV2g5aGFjUmh4aDBoZGVWZlZnSmQwZmFoM2RwZWpoUmNUZzRlRGRSZmdhRmVyZE5ia2Z4aDlkZGdrZUFkL2VGYVdhVmgyYVJja2RzY0dhWGhVYWRoaWFZZDJlWmc1Y1JkR2ZsZkpnV2NuYVZoNGhTaDNjZGE2ZWFhVmRkZVpkRWZCZGxib2NDZTBhVmN2YkVlUmFOZ25kRWF6Y3RmYWdGZkJhTmRIZlNjRmZ0Z0hnQWNSYnRneWFTZXhoVWIrZWNha2c5ZnBnU2NVZm9oT2ZZZEdnMGY4YkdmR2ZZZ1VkWmZtaFphaGNjY0ZlVmR2ZFdoa2VjYWRoSGZWZlZhU2JkY0dndGU2Y2FheGJrYWliQWFsZXdjcGdRZWhlbGVNYmFoM2ZaYUFkVmZ3Z0JjNGFjYkJmSWFmaEVkVWhwYXphWWVuZUpld2RjZ0VhaGZEYlNjVmNwYzFjZWRFZ3RjM2hlYm1mbGVYZldjUWFvZ1poQmhnaE1jUmZKYTFmaGdBY1lnMGdjZ25lSGEwYWNnNmZHZlVmaGRSYlZmeGdsYXFhV2JGZlliVmVhY25nSmRSZGRmMWNkaEtkRmZtZGxlaGdGZ2hhaGFtYlJobWFaaHRhWWhXZVJmL2hiZzFjcGdIY0hnUmExZVZjVWhuY1JhcmJlZ21jTmFOY1lnMWZBZmxhVWNoZkJka2hUaEhnWmcyZ1Vna2FJZlZnZWhDY3NkYmhSYXpjSmFEZldlV2FKZXlnY2NIZUJjSWZRZjBhbGRhZGZhVGVaZ0ZiSmR5aGdjbWdBZ3hmWmhFYlFnRGZoY09kU2d6ZWhjRGZXYWphc2JDaEJobmVvZkplUGVBYlphYWFNZ2ljSWRRYmVhM2NJaFFhUWNDYVFieGRCYVRkNGJZZ0JnQmFaZ2hoTmRSYW9hWWVOaEJoaGRtY0xjMmNoY3dmRGJrZVZmYWJSZXhmMGVkZVZkVmhKYTBiYWIzZ3BoamVUZFdkb2daZlNhZ2haZUZhTmdnZEpiMmVmZW5kaGVDZUZkWGFoZDJlRWNrZHNiWWRRZjFhbGdpYmNlbmhCYXdmU2FFaHNhZGhXYm1maGc0ZFFiQ2ROYnpjWmFYYTFhWmhFY0JmbGVvaENmMGJWYXZiRWJSYU5idmZSZDNjTWVUaFJhMmdCYkhmU2ZFYzFoSGNBZUdiWWR1ZFZha2JkYmpoZmVuY3RlM2NWZjBjb2RXZmFjV2hFYldoR2JHYVliVWFaZm1lWmRoZmNnQmN4Y3ZiQmRoZHNoZGdjZVZmMGNHZVBiQ2VJZ3BhYmgwYTBnK2dSZXdkOGRBY0hjR2FSZFloZWVuZlphR2hVZEFjeGhzZWJmd2dSZGNjQ2VsZHBjTWJiZm5kSmFnaGVkVWdSYnBoU2JWYXBkMWJlY0VodGczZGVlbWJsY1hiV2VSYUFoWmVhZkFhc2dMYllnV2FWZnFoSGh5aElhWGFiZ0NiWWNhZlpjeWFrYXBoT2RHZE1mVGFBZmloWmM2YUdlQWZaZTdlZGgxZWRhS2JGYW1mbGRoZEZkaGhoYW1mRmJHY1phbWVZZ1hoQmhWYWJiMGhWaEhlRmJSZFVoQmNHZ2pnMGc0Y0FmVGVFZHdhYWFsZ1lnUGJCZmhiQmU2YVVibWJoZzJkUWNGY1lkY2dkZUZhd2JTZ1NjeGZoZ0RkV2JXYkpneWJjZ0hnQmRJZFFoMGhsY2FkZGNYZmhhTGJkYTNlcGNoZ0FleGJGYlpmU2doYk5nWmNSY1diUWNSZEFjaGJKZUhoYmdoZ01nVGVhZEFmdGJXZ1Rka2FjZkJiY2JIYnRlYWhQYjJlcGZ5ZlVkWGRkZFhhU2ZoZ1picGJZYVJhWWFZYlpnaGJSZm1mWmdtYUZhd2JWYldoY2RPYURmMWNSYU9jTGdnZUJkMGJZZUhkcGJ4ZU1iR2hwZ1diRGZ3YllnUWJlY2xoSmdvZmRia2ZwZUxkR2dWY0poMmNFaGtmc2NZaFFjMWFsY2lhY2JuaEJjd2ZTYUViTmVKZldjbmJWYzRhU2EzZGRkeWZQZVJhOGJRY1FhMmJJZzZhQ2cwZjVldmhBZm1hNWh2Z1dibmdNZEJhVWhuZDBkVmJUZ2xmQWhUY0djV2M5Z1llVmdoaFZicWVjaGxiRmgzZFZoMGhvYldkYWVXZ0VoV2ZHYkdlWWZVZVpjbmJ4ZGhjSGdsYjBmN2JFZWdoNWhPYkVoVmZVZkdlZWJHaHNkb2hiZjBiMWZyYVdiZ2haZGVmT2VtZFJnTWhkY25iWmRTZlFnaGZWYzRkZGhoZ0pnTGRHZEVlTmdaY01kSGZKYTdmY2dGZXhncGJTZlZkcGUxaGVoRWN0YzNjZWRtZmxlWGFXZ1JjQWNaZVllUmNCZ3ZkYmd4YkViVGhiZTBnZGd6ZUVnMGhkZm9oRmZSZ1ZiWmRTYXplcGZtZWNnbGdZYVZnYWZuYkpnUmNkZDFmZGJLZ0hkaWFkY3ZjUmRrYW9jcGNRaENma2F5aE9lQ2FBZVFlWWVRYjBiVmFWaEVha2JRZk9iemNvZC9kRmdnYlpjTmdkZDBidGJKYUJmMWM0Ym5kR2hEZDhoNWJIYkVlSWdkZ0xoSGFvZFNiR2dSY1JkRGhFZ0doNWZ5aE5lWGNsaEljR2dHZk5iYWdkYVhmaGhMZ2RmM2VwY3BiVmMxYWtoUWZHYVdnaGNDZUFmMmg4ZVpkR2cyZWNnVGJjY3dnNWdIZVlhMGVGZ0JoWGhFaGNmWWJOZ0hjSmNMYkZhWGZwZ3lhRGFYY2NhRmFRZHhlcGhwZVllRmZNZ1JjYmV4ZVFiOWFUZ0diRmJ3ZlZiV2E5YWFnUmR4ZjBmZGhWZlZmSmgwZGFjM2ZwZ2piR2V5ZnNnWmdEY3hkMGJRY2VoVWd3Z2JnTmV3aFljS2ZHaHliZ2Y1YlJnVWRNZ0tlVGMxYWxmNmRjZm5icGZ3YUFmVWhOZEVmV2FtYlJneGFVYkZmMWU2ZWFmVmNkY1pjRWdCYmxib2JDZDBmVmV2Y0VjUmNOZXZkUmN4ZjhlYmJFYXlkQmNjZUdkMWV4YkhjUmVHY3BjeWVCZ0JnbGFxZU9lMWIxYTNlR2FFaG9kYmhhYlhlQWhhYUdnR2h0Z2JkYmYzZzFkTGRjY0ZkVmN2Y1dka2JjYmRkSGNWZFZjU2dkY0dndGM2ZlBnbWRkZXFkU2N3YTloU2dFYkdlUmVNZWRkbmJaY1NhUWZoYlVndWROaDBkQmhMYVVjRWFOZkVoWWZtZ0piOGhXaGtmaGZEZ1NoVmhwYjFjZWFFYnRmM2dlZW1lbGRYZFdlUmVBZlplSmVnZHRlWWNiZ3dlQWZmY1JhVWFkY3poRWgwZWRmb2NGZ1VoaGNRZ1JieGJCY21iY2dsZFlnVmdPZ1hlSmFNZmRiMGdkZ1JlUGJHYWxhaGdGZmhmaGdtZ0ZjR2VaYm1nWWFYYUJjVmhiZ3hod2VJZVRmeGExY2RjQmdqYXdjaWVLZFJiZ2dmY0ZmMGZzZ1NmVWJnZEpneGRXY1hlWmN3Z1VoaGhZZU9jZWdIYTBlWmJBZ3hlaGZmYldjU2J0ZnlkZGNuZlplSWZTY3diZGFhZmZlMmVWZExkWmZXaDllL2JYZ2tkSWVRZEVmRWdJZkxnUmJXYzhkUmRFZDJhOWJIZmNheGdOZUhjYWFCZVZnSWhVaEZnY2hRZ2VnSGZJY0NlRmNXZnhmMGZVZVdjZGVYZlZod2Z0ZjBnWWRVYlVkWWFZY0JoSmRtZ2RkbWdGYXhmU2NIZkpnYWZFZzFlVmFVZ0JoaWNrYW1oYWEzZEZkamdCZVdlcGJHZ0RjMGNOaHRkWmdFZnBmd2hkZWxob2ZSaEZmV2dWZzJlQWUwZ0liVWVhZFZkbGhpYmNlbmJCYXdhU2ZFYU5iSmZXZG5nVmc0aFNkM2ZkZTZnYWZWYWRnUmhSZ0ZnRWRoZFdmRGM0YzlmRWFSZWhjdmVEYndiNGRUYVdibWhnYWRhUWdGZmdmVGFFaEdnbGJ5YkdiQmJ4Y3FnYmJFaDlmM2RSZzBmTWdXY1plR2VGYUZnRWdXZFlmU2ZaYW5kUmMwYlpjVmh4aDBoY2ZFYmNkZGJIaFZmVmVTaGRlR2J0YTZhWWYwaDFocWNTZzFlMGNYY1JlRGNFYmVoT2FIY1llQWdRY2hkNWI0Z1Bnd2VsY2hlR2FFYU5jWmJZZW5iSmh3ZmNiRWJoZ0RkU2RRaGRnOGVkZEdlRmMzYmVnbWVsZFhoV2NSY0FiWmFhZUFjdGJGZlplMWg4Y2RnUGZ4YVVkOGhSZXdjZ2g4Z1RjQmRnYlZiU2ZVZmNhMGJPY3doSmRRY0FjemN3aEZjRmFUY0pnS2ZDZzJma2huY1FjMWdZY2xhUWhDZjhocGJMYTNoQmNkY09kMWFaZ0hkVGN4aEZlVmVHZjNnaGVyZVBiMmVwYU5kTWNXZUVjUGVVZGhiQmdraFRhSGNaZzJlVWZrYUljVmVlZEhlWmdiZURkUmVoY0xjVWJXaG9mbWFjY0diMWFJYlNiQmUxZ1RlZWFYZWhmRGVKYVhmcGMwZVZlMGZrZVFmUmRXY2hjWmRUZUdoTWRSZUVhaWFwZ09hZWFoaE1iY2JRZWhkVmVJZFViRWFjYVFnWmRuZEpmV2JGZldkcGN5YlVoWGhkYVhnSGVGZ2NkN2NZZlZla2NZaGVmeGdRZUxoSmF6ZFVlNGNXaHphOGhWZEViQmFVaFBnV2VWZ0pic2NhZDNnQmFqZkJjR2VwY0dnRGIwaE1oWmhmZDJoWmUyZGRkbGhKY0NmRmZYY2hmMmVFZGtmc2dZY1FhMWNsaGlnY2FoZXhnNGRIaEFlc2RBZENoWGVsZDRkSGQzZXRlNmNPaDFjdGZaYldhUmdWZm9mUmRFYlZmaWZFZVFhSmZqYlJlM2U1Z2NkVGFuZ01nL2JTYUZhQmFIZkVjR2NaZHloVmRoaFZncWJjY2xmRmQzZENlbWNBY1dkYWRXZEVjV2VHY0djWWRVZ1pobWVaaGhoY2JGYVVmNWNHZXhkVWFkZlZlVmRWY1BiZGNDZ0pkNmNiZ2tlMWQ3ZFJneWVWaFNkRWRHYVJnTWVkZG5iWmRTZ1FkaGVWZjRjZGdoaEpoTGdHaEFnMWFaZmZjM2NKZ2hiZmNHZkplRGNTYVZhcGExYmVhRWJ0ZjNmZWZtZWxjWGJXZFJoQWhaZGFiRmdoZEZiY2hoYUVmRGZkYUdlMWJ6Z0VoMGdkZW9oRmFVZmhiUWZSZXhiQmdtZGNibGRaZFRmSmNTYUJnUmZmZndoTWNDaFhkemZvZWFhUmhCYmhidGFGZkNhNGdiY1ljV2gxZlZnZmFVYTloU2FIY1JmdGJWaEJlbWQ5YXJhZGQyaDRnRmVhZWxkVWhTYVVoZ2dCZ2tkU2duaEJnMmhXYWdid2ZWZGNnbWZzYlNkV2FRZjFiVmhVZUhmbGh5ZmVoVmRwaElhUWQwY2xjYWRkZVhjaGVMY2RkM2RwZHBoVmExZ2tiUWVHZlhoZ2ZMYldmMmY5aEZkRWYyZWxoQmNjZndlTmdIaGRoUWdoZFZlVWhCZFFhUWZZaEhiUmVXZUJjV2hwZHpmVGJHZ3BkWGFIZmxnNGdnY01mbWMxYUtnWmRoYjlobWNMYW1iRmY3ZlZiWGY0Zm5iUmZ4YXNhYmJWZVZhb2FuZWFjMmdkYmpiWGhHY05lSGZKYlZiSWJRZVpmRWN4ZDJjZGVsYUpmQ2hGY1hiaGUyaEVka2NzYVllUWgxYWxmcWdKZmpnZ2E1YUdiemhnZmJiV2ZuZjVhNGJBY3dmcGY2Z2RmRmVkYVJnR2hCYkVjOGJDZTBncGV2aFhkeGRwaHZkV2JXZDBnVGhWZjJiRWRWZlJjVmRBYVVjR2JXYVpkMGhWZ2diZGUvaFpmMWhoZnNjZmRVYW9lV2RhZldkRWFXZ0dnR2dZYlVoWmFtYVphaGFjY0FiY2dxaERnaGZKYlBoVWcxYVVlQWZkZEdnQmg2YUtjbGRaZkFhU2R3YjlkU2JFZEdlUmdNZ2RjbmFaYVNiUWVrZmhjeGFlZGpiaGNMZEdiRWdOZ1pnWWZuZUpid2JjaEVjaGFEZlFiUmNSYjdhS2RCYmtmNGJMYmliWWNEY0FoRWhCaGNiWmJsZXdmWGVKZ2tkVmRXaEJkZ2drZG5hQ2UwYWRjMWNGYlFoNGZGYUNhVmFNY3llT2d4ZGxiYmVhYW5kb2JGYWVkMWRjZ1lnR2RtZ2tob2RIZnhiZ2Y5ZlBnbWJaZW1lWWdYY0JhVmZiYjFkcGVIZEhlUmgxYVZlVWVpZFlidWZMZGpmWWRmZ0pjRWdzY0hoZWZCY0Jla2dUZEhoWmIyZ1Vka2hJZ1ZkZWNIaFlmU2RTZHhoaGZEYlVkVGVaZ3llYmZYYUJkRGRGYzBhQmRXZ1hiM2JoZkxmZGQzYXBjcGVWaDFka2VRZkdlV2ZnY0xlUmZXZDhhUmhHZXpnMWZIYmJlaGhOZVhkYWZFZWxiSWFBZGtiNGVjYVRhSGFKZ1dlRmVXYnBmeWZVY1hjZGFYZVNnaGNaY3BiWWRSaFlhWWNMZHhmUWE2YU9jbWVFY2NhWGdUaHNkU2JEZ2tiNGRSYVZoUWdaYzRjYWZ5Z2hjdmFUZVhhdGhIYkRmMGRNZENnY2gwZEJoMmhlZjBnTmZRYkRkWGVGYTZmT2ZFZXNiWWRRZDFmbGZpZWNjbmVCYndhU2NFZk5jSmFXZm5oVmM0Z0JhWGhrY09oRWRDZmNhOGZkYkdhWWVKYmVjVGZjZE9nYWRHaHdnY2JNY2diTmVqYktlQmNwYmhkU2RBY3dlYmVFZ0dmNGNtZFZlZ2JoZXFjSGV4Y0FlamNIZjBlUmJRZEpiU2Y1Z1poU2dtYjVnQWdiYjJjOWV0aFdmbGRWZXZoV2NrYmNmZGRIZFZiVmFTZmRoR2N0YzZkWWEwZTFncWdXZ3dkOWdNYUVmRGFCaE1nY2FIYUJoU2hTZ2tjRmQ0YmFmeGFKaFpiRGVWZ1pjWmFhYlhhSWFrYWNnRWJOYkRmV2ZGY05iNWRVZGtjdGgzaGVjbWNsZ1hjV2ZSaEFnWmhhZEFndGhGY2JjeGNFYVRnWmV4Z01oN2dXYWhlUWVUZVJnemRWZVFjV2FoZEJmMGRaZDBlTWhWY2JhSGNJYkZjZmFsZnRnZ2VGaG1hbGdoZ0ZiaGRoYm1jRmdHZVplbWRZaFhkQmhWaGJlMWdvZFZhSGdSaFpoVmNRaDFlNWVyYmVhbWJOZk5lYWFrZXNhUGJVZWhmQmFrYVRlSGJaaC9mU2NXZWdjVmFlZ0hlWWZTY1NmeGhoZERkV2NXZEpoeWZMZFhkbGNFZmFkVWZsZ2FmZGdYZmhoTGFkZTNncGhwZVZnMWJrZlloVmEyZVpoYmFGaHlhQmNGY1hoRGJzaGVmSWYxaFpoSmJQZTBoY2FCYUJiQWVKaDVoS2RDZ1phSGJBYXdmWWNYZFVhV2ZwYVhhRGRFYU1ibmJJYmtjSmVSZUtjVmZwZ21iYmZqY1ZjOGZWZ1RmMWJXZlJlMWFRZ1VhVmRRZmxlZWhhZzNicGZqZFRlV2dwZUxhRGIxZ0lhUWVaYUVmeGQyZ0pkQmNjYldmUWZDZm9nNGNFZmtoTWd5Z1FjMWhsZGloY2NuZEJhd2NTYkVoTmNKZVdmbmRWZDRjU2QzY2RneWJQaFZjZGVFZ0VmQmZJZThjQWZrZGxkRmdFZVJhTmN2aFJiM2RNZFRoUmEyY2doVmRTZ0ZlQmJIaEVjR2NaYjZhQmFCYlZkM2RjZGtjRmQzaENoMGNwYUVnWWdHYTBmOGJHYkdmWWhVYVplbWFaZmhoY2dGZFZldmFXYWtoY2NkZ0hmVmZVZ2JoZGVEZGNibWZZaHlhRmdpYkhnMGZjYmJkUWcyYmhhTWNJY25icGdTY0VoQmFsZDRiWmVCZTVnTGFDYzFhRmFPZ2RiR2FWYThjY2JFZFZkUWJXZTBnMWJqY1lhRWRKaDdhVWdHY2xlWGZXYlJkQWhaZWFkQWh0ZEZkYmF4ZUVkVGFiZzBlZGh6Y1hhVWNrY2NmYmFEZmdjMWdJZzJnOGdIYkFnQ2dSaDBlRWh3ZjBlaWRBZ2ljY2g2aGVlUmRzZFZlUGZCZmhobWVGZEdhWmdtZFlhWGFCYlZjYmMxZnBkSGZIZlJlMWZWaFVhbmNSYTBlZWRtYnRjRmJQYWdjTmZHZEFjV2JzYjJnTWFYYVpjcmFVZ2xnQWJBaGJoWGhZY1VjU2EwZXhoS2hWZVdoSmY2Z0phRGFnaEJoRWFEZklkSWFkaFhlTmFMaFplZ2hkZXBhU2VsZmxiRWRHaFhhWWJWY1dkMmg4aEpnR2ZtZlpmdGNjZXhjTmdIZmFlQmhWYklmVWhFZWNlUWFaYm5mSmhXZ0ZlV2FwaHlmVWZXZTFnWGZKaFJnNGU5YUtkVmM5Z0xlYWVoZlFleWRhY21iRWZpY1diV2M5ZGJnVmN4aFFkUmJmZjFiSmgwYmFhM2JwZmpoVGFXZnBmTGREaDFoSWRRaFpkRWJ4ZzJlSmRGYkpiSmJGY1dmcGhjYUVia2ZzYVljUWYxZ2xoaWFjZW5lQmN3aFNlRWFOZUpmVWYyZzVoU2hTYTNmZGU2YmFhVmhkaFpnRWFCZGxib2FDZ3hkaGhtY0hkVGVsZ3ZjUmIzY01lVGdSaDJnZ2VWYVNiRmNCZkhjR2FDZmhmOGZCZ2tkY2dsZUpjaGI0YWpnRGhoaHBnVGNaYXpiWmRFZFViVGZKZ1JoRGd5ZGdhMWFZY1VlTWNOaFBnMGdjZ0FjSGNSYk1iSGZPaGlnZ2h1Z0tjZ2VJYWtjU2R3aGNhR2hIZkdmUWJlZGVnbmFZYmJmU2V4Z1VjamhYaEJlSmNMZ0dhRWdOZFpnWWduY0pld2NjZEVoaGhEY1NjUWVnZndmTGdCZDRnbGNOYkdkbGhmYWNoeGZBaFphYWRBZXRmRmZiZXhjRWNUZWJhMGRkaHplRWUwYmRnb2FIZFJkeGRRZFdoaGVCYXRiSmFsYjhiWmJRZ0hiSmJSZWRjMWVkZUthRmhtZmxiaGJGZGhjaGRtZUZkR2daaG1kYWZTYUpmVmZjZmxjcGVYZUhnVWFGYVZoQWRIZjFhbmJVZ0doTmdOZWFka2dzaFBkVWNoYkJja2JUZEhoWmYyZlVia2ZJY1ZkTWZYaFphT2FGZnhjZ2h2aFViVGVZYTZhT2dTZU5kRWVRZHhmMWFXaGRiU2ZwZkhiZGIyZWhmbGhWZzBib2FDZERibmY0YmNhU2VXaDhhY2JBY0hlMWJRYlphUWJ0Y09hWmdEaDloSWVVZ0VkY2RRZlpobmNKYldjRmFXZ3BjeWhVYVhnZGhYZVNobGJoZ25nRmJXZDlnb2VBZzNmQWFaYUJoeGJNZkNhTmZCZFljbGZOZ0diaGF0YUpkVGEwZkdoSGExZUJkamFUZldhcGFMZ0RiMWhJY1FjWmFFYXhjMmZkZ2xkSmJDY0ZoWGZoZDJlRGJVY3NhUWhTZXdlMGNxaE9leWhNZ0xoR2dqZjVnSmdSYTNiVWZzYlNmMmRsYWtmZGIxZGRhQmZHY1JoVmhvaEFjeGZFYm5iV2FFZUFnVWJGY1hhTWRZZVJkM2FsZ29nU2FFZjFlSGdBZm5mTmduYVZkaGNOZXFkSmZsY2hoK2ZmYVVlb2dXZ2FhV2hFZ1dlR2ZHZVlhVWVaY21kWmJoZ2NoRmNWYnZnV2hrYmNjSGFIY1RmcGNhY0liQ2RNZ3poTWJFaEZkcWdIY3dmTmVTZFFkbWFoYU1jZGEyYWRiYmRUaGphOWM0aGRnaGdKYUxjR2hFY05mWmhZY25oSmJ3aGNmRWVoZURlU2NRY2hlMWhjYTBmdGVsaFVhR2FsZVhlV2RSZkFjWmdhZkFhdGNGZmJleGZFYlRjYmIwaDVhb2dPZVVnZGdvZUZoVWZoaFFkUmd4YkJmbWVjZmxiWmNJaFljM2c1ZzdnZGYxY2RmS2FGYm1nbGhoZ0ZlaGVoaG1mRmVHZzRjb2RiYnllQWZIZ0ljQWg0ZklmU2VVZFFlRmJGZDNlb2Q4Z0thQ2hvYlplTGZ5ZUpiQmhCZWdiTmgyY0ljQmVOaDJlVGUwY0phVGVMYVRhaGFSZkhiMWVFZU1oRmMyY0plNmRKZUhieGNJZUVhVWJWYWFkUGdIZkZoTGVMYkZlQmFwZFZnMWVrYVFjR2JXYWdoTGhSYVdoOGhSY0VnMmQ4Y1ZiTmFrYWNnU2ZPYWxldGZJaFdlR2gwY1FnWmRuZUpmV2hGZ1djcGJ5Y1VlWGRkZlhnU2NoYVpocGFZZFJoNWdNaFphZ2NsYm1jYmRUZlZhNWhXY1VhVmdhYlJneGYwYmRjVmZWZUpmMGRhYzNlcGZqZlRiV2hwZkxiRGcxaHBkQ2NaYUZiRmcyZ1pnbGNJY2VkRmdTaHBiL2ZIaG1lRWRZY1FnMWRsZWlkY2VuZUJid2FTZEVlTmhKY1dobmdWZDRhU2h6ZzVoNmdOaFFldGdaY2ZhQmFFZzhoUWF3ZndhOGNIYVJiTWI3Z1NhM2JOaEJmU2YyaGdiQmdSZkZhQmJWaEFkWGVKZmxjUWdnZTFiNWFaZEVmVmRnYVdiMGdvY2JiZWgzYUFiQ2ZEaDNiSWRNYWRkWGhCYjFoYWdGZ3hkamRjYUVhY2hkY0hjVmVWZFNjZGdHYXRlNmdZYjBjMWZxZ1Nhd2U5ZVNiWGFtZm9jNGJEYndhWWgzZkpmbWNvZVphQmJHZUFjcWVZZ1Rhd2ZxZ0Zkd2ZJYkFmSGN6aG9oM2FZZTFmcGQxYWVnRWV0ZzNlZWFtZGxlWGJXZ1JlQWNaZmFjQWd0ZUZiYmF4Z0VkTWdiZDBkOWQ3aFJld2c4YmhnUmhqYk1iQ2VPYWhiQmI3YWNla2dRZUFmZmgzZUpkWGNkZXdlTmVEYUdla2NOaGhnRmRoZ2hobWhGYUdlWmJtY1ljWGdCZFZoYmMxY3BjSGVIY1JlMWdWYlVnbmhSZ2pkTGVpaHNkRWNPZFRlQmVkYlViaGV0aGtoWGNRZ3RiMmhUZDBhSmhCYWVlR2dnYk1lVmZSY2hiYmZVYUdnNWJZZmNhSGdCaEllUWUwZ2xjYWRkZFhiaGNMY2RkM2ZwZHBnVmIxaGtnUWZHZVdlZ2VMZVRoVGJ0Y1pmV2RqZ3doOGFJZlJkTmVNaGFmQWFjZzFlVWRGZW9kUWJNZG5jSmdJZ0NlM2dSZnliUWRHZUZkZWNSYmpkeGNwaFlhUmRZZllmWmhoY1JibWRaZG1kRmF3YlZhV2M5ZmFmUmR4ZDBjZGRWY1ZjSmc4ZFBiemhJZHFoSGdoaEVjWmJEaDFja2FRY2RmemdGZDJkYWUxYUlnV2JGY1dkWmRvY0RiRWRzY0tmVmQxYUJkcmhXYUhnQmJ3Z1NmRWROZEpiV2duYlZoNGNTZjNlZGQ2Y2FhVmZkY1pnRWZCYmxjeWNDZnlmdGhuY1JlVmJzZm1oRmRIYjhiVGJFaDJjUWJWZkdkbGN4ZEhjRWRYZ1piN2hXY2pkOWNxY2NibGdGaDNiVmEwY29hV2FhZVdmRWVXZEdjR2JZZFVhWmRqZlJmaGJlZjFmVmY3Y2NiRWFjZGRlSGFWY1ZhU2dkZ0dmdGU2YlljMGIxaHFkU2V3ZVpiSmdPZW1oUmJNYmRobmVaY1NjUWVoZ1ZnNGhkZ2hkSWRXZUVjVWM5Z3piWWNuaEphd2hjY0VjaGREZFNlVmRwYTFoZWZFaE1hNWVkZURka2hGYkZma2RSZldhUGNGZkloVmdLYWhoOWVFY1BhUWg0Zm5kVmRpZzRlbWZRZVZjdGhDY0pkWGJWZG1oYmUxY1pkVGFQYXpkd2JTYUlmeGU0aEZiV2NHY2xocGFRYWhiUmRtYVJhbWJwY21iS2JIYmxlVmZOZkhiQmhIYUhiUmMxY1ZoVWFuZVJkcmJlYm1kTmZOZ2Fka2Z0aGRmRmUwYVFieGhIYWpkaGMyYVdnbWRnZ1ZoZWJIZFloU2ZTY3hkaGVEZ1dnV2FKYnlhY2JIaEJlSWRRZDBmRWRPZmRnV2ZWYUxhZmFDZjVmZ2NXYTNjTWZRZ0dnV2FnZkxnUmNXYThoUmJFZjJmOWFIY2NmeGJOYkhnYWNCYTBjYWNVYUZjb2JRZGRjbmFJZEtjRmRUZGhmN2FYZVZmMWRYYlNkaGdaYXBnWWNSYVlmWWRaYWhlUmZtY1pnbWZGaHdjVmdTZVplYWRHaDBkRWRkZE9mVmFvZmdiSWd6Zk1id2JRaFdjb2JmZEFoMWdKZkNoYWRFZXhmaWJlaGxnSmFRYkJjR2d4ZmhhQmJsaE1mTGJWaFVjMWExZ2ZobmdCYTllV2RsZ0poZGZUaFdnRmhnZldoR2RGZHVoY2RWYzVmVmdPZGhhbGVvYkNmMGJWY3ZkRWJSZE5ldmFSZTNhTWNUZFJiMmdnZlZkV2hGaEJoWmVFZkRkSmR5YVVhQmROZ3FoZWJnaFZhM2FTZWtmb2hDZmVkM2RnYkNoQWhYYUFnRGRkZkhnOWUwZWNnRmM1ZnZlRGZrZWNmV2dIYVViUmJiZmVjRWNGYzZhWWcwYTFlcWFTZXdoOWFTaEVkR2NSZ01lZGJuZlpnU2RRZWxldGcyZEFobWZzaDdoZmdTZWNnbWdBaHdlQWZDZ0VjVGZFZThhT2hpYzhoRmhDY0NiUWNGZERna2FOYlhjV2dSaEFmWmZhZUFjdGRGZWJleGNFY1RhYmYwZ2RmemNFZzBhZGhvaENna2VoY1ljVGcwYlFodWVPZHdjVmR1YU9mQWE5Z1JnYWNsZGNmZWRGY25hZGMvYUNkQmJoYzBiQWZHYzlmcWhTZDNkQmdWYWJlMWdwY0hkSGFSZjFnVmFVaG5hUmJyY2VjbWZOZU5jYWNrZ3NhUGJVYWhiZ2F3YkJoRGQ4YmxmS2VSYUFiVmFjZDNiWWNEZ05laGZoZmVnV2NUYlpleWdiZm1nNWFXZVFhMWFoZE1lZmNIZVJhaGNkaDNicGFwY1ZiMWZrZVFkR2FXZWdoTGZSY1djOGZSZEVjMmE5aEhhY2Z4ZU5lSGNZY0VjRWVBZUdlUmZSZHJmTmZIYkpoZGdGZFhhZ2RQZ1VlV2ZwZ1hjSGVoYlpjM2hmaHdoZ2hZYWZlaGMxZXFlVGJHaEZhd2NWYVdjOWVhZVJkeGUwZmRhVmFWaEpmMGRhYzNocGFqZlRiV2FwY0xnRGcxY3BnRWhMZkFlVWhsaERjUWdCY0NjSGhuZWhlbGNiYTBmc2RGZFFkMGN0ZTNhWmYzZ0JnMmZTY0JnZGdBZ1VhMWQ5ZDRlU2YzY2RlNmNhYlZiZGFaZEVjQmNsY29kQ2UwY1ZhdmVFYVJkTmV2ZFhkWGhOZTlmVGV6aHhkZGRBZ1FhTmdMaEVkRGdKZytlVmhrZ2RibWRjYmxjQmRtZVhka2hZZDhhYWRXZUVjV2dHY0dnWWJVY1pjbWVaZmhnY2VGZlZhdmVXaGtlZGhQZ0hlVmc1aFNkWWRFZ0ZiNmVZaDBhMWNxaFNhd2c5YVNkRWZHY1JjTWFkZ25jWmZiYVdnVGc5YzRjZGZoYUplTGVHY0ViTmdaZ1lobmhKYXdoTGdVZ0ZoUGVZYTFjcGgxZ2VhRWN0YTNlZWdtZWxlWGhXZ1JlQWRSYUpnZ2JVYVZiUGJWYTVmSGJJYUJhTWJxYlFkd2JKZm1lUWhoZW9jWmJFYTFnVWNBY1BhaGRsZlVoUGdoZTRlMGNkZDBncGJLZFVoRGF3ZXZiVmVVYndodmdXaHljaGdtZ2FnU2NSYlpiYmZ3YmhnTGNIZFZoUmhjZ1VnaWU5Z0JnZWRtZE5mTmRhYmtic2hQZFVoaGFCaGtjVGFIZlpnMmFBYkFhZGJCZ0xkU2VSaGNmU2QxYU5iTGVEaFNob2U3Z0lhM2Z4ZEliRmcwZ1ZmYWhKZjNoUmFMY2RmbWVwYmxhVmF4YUFoWmFBZ2tiSWFMZFJnV2Y4YVJnRWMyYzlkSGNjZ3hjTmdIZE5nUmZ4Z0VhZWhrYmNhUWZaYW5hSmRXaEZkV2FwZXlhVWNYZGRnZmRCYkJkZ2c1YU1iMWZsZE1mS2dVZ0FhL2VOZ2liUmUrY0FoamMwYVRnRWMxZGhnN2FHZVJiMGIxaFBneGJnZkdiVGVYZ2RhTGNTYVFjZGFlZ0pleGdnZy9lT2ZSYnhoQ2RIaFNneGI2ZkViaGRrZFVoUWd4Z0JjcmRjaGlkdGhhaFNmRWhOZkpiV2duZlZlNGhTYzNmZGY2Y2FkVmhkZVpkUWdsZHdmOGNYZWhjY2JoYUViVmZoZG5oRWV6ZXRjYWNGZ0dmUWZWaEhhRmR4Z0hmUWJtYnBkeWdWZndnUmRtZmNlaGJoaCthVGFHYkFoV2RhZldoRWRXaEdnR2NZZFVmWmJtYlphaGJMZ1ZkeGdqZWNhRWFjZmRnSGVWZFZoU2hkY0dmdGM2aFljMGYxaGlmQmhRZkVlQ2RRYmlnc2ZZYU9hU2VJYUxkRWRsY0JiMmZJaFVlQWJDZ1RjQWZZYTlkTGdTY2NleWNQYkFmMGR2aExnRmVwZW9nZWFBYjBnaWZOZkNib2VEYkVjRmY5Y1hlYWdBZ01lUmZZZHhoRmdCZVlkMGFjZjZoR2RrY2NiemhQYzBoaGhRZVJoeGJCY21mY2dsZFllVmNhYW5kSmNSaGRjd2NVZ1BlUWZqaHdoemRXZUJnZ2RzY0hiRGFJZXVoS2VDZE5kWmFiZXdoNWNMYUhkVWM5YVpkVWVuZFZhN2hkZ21oTWNFZVlnMWRBY2xkVWNoYkJja2NUZ0hlWmMyZlVoa2ZJY1ZnZWFDZ3NoYmJSY3plSmFEZVdmV2JKZnlnY2NIYUJjSWJRYjBkbGRhY2ZhVGJaZEZhSmZ5Y2dhbWVBZHhoWmJFZlFhRGZoZ09mU2N6aGhhRGVXZWplc2FDZUZlMWZ3ZlNoS2dsY2tlTmFNYWlkSWFRaGVnM2hJZVFjUWFDZVFmeGhCYVRoNGhZY0JhQmdaZ2hoTmVSZW9hWWhOZ0JlaGFtaExiMmZoZXdjRGFrZlZiYWNSZ3hhMGhkZVZnVmhKZjBnYWYzZ3BiamJUYVdob2haZVNnZ2JaZ0ZkTmFnZUpmMmNQYUZlb2VXZFhlVGdFYWxlSGVrZXRnTWJUZTFka2d3ZGZhbmJCYXhiV2VVYjlmSmVFZDNleGdqZ1lkWGhkZjZiYWhWZWRmWmdFaEJkbGdvY0NnMGFVaHlkR2hCZTljRmJSaDNlTWJUY1JlMmJnZFZkU2dGZ0JjSGJFYUdjNGE4ZVdhRWdVYTRiUGZRaFVkNGhBZHhoTmFHZExoR2E5ZVZhVmJ6ZFphTmFaY25ndGZoZU5iZ2dBYmhnR2dSZk5iVWNVYmhhdGRTZmZjRGc5ZTJnWWh4ZjlnbWRTZTBkWmZlZEVnQ2hGYkZjZGhpZzFlNGJRaGhoVmQ0Z2RjaGNKY0xhR2JFYk5hWmNZZ25mSmV3Y09kUWQ1Z0RiUWFYZUJjMWRlZEVkdGUzY2VobWRsaFhoV2hSZ0FkWmJhZkFmdGNGZWJneGJsZmFiYmZ4ZnNodmdFZjBhOGhoaEZiVmRWY1FoVmZ4Z2xmcWRXY0ZjWWhWaGFobmFKaFJhZGUxZmRmS2RGYW1kbGhoYUZhaGJoZm1mVWVXY1loNmhQZ1hkQmhGYmJkMGVkYWFkQWJCYjBjUWZVZmljZ2MzZ2VnbWRzZklmYWVsaFlkUGRCZWxkZ2Z0aEhoM2VnZTZjRmR3Z3hlU2VMY0RlNGRiY1JhemdKZ0RhV2VXYUpmeWhjY0hjQmhJZFFmMGhsaGFiZGNYZmhhTGhkZnliaGNwZFNiVWdRYVFhVGFXZlpiSGhBYUNhRmhXaFJleWJkZ0hoZGdSZVZoSGdZZEVmZGdJYlRjVWJkZUVnYWJEZTRhVGJXYnllMGRtaEdoWGE1YmJoWWZCZlphcGhZaFJiWWVZZFpoaGNSaG1kWmdtYkZnd2hWY1dmOWFhZkZiUmIxZEJhQ2JWaEpiOGJPaFhjcGgrYVRkWGZwZUNiQWMzY2dnUWdaYkVkeGQyYWRjbGNKYkNkRmdYaGhkMmdFYmtoc2FZZ1FleGV4YmlnYmdIZEJlZ2FTY0VlVmJQY1djamZ4ZjRlVmRYYmNnL2FhaFZlRmhmZ0VmQmJFYnRlQ2MxYmhkdmJXYkJmcGNqaGJmWGJNZFRnUmIyaGdhVmhTYUZoQmVIaEViR2JaY3loVmdoYVZhcWVOZjFlRmFxYVNnbGFjZldjSWdHZmdnOGRHZ0dhWWZVZFpibWFaaGhmY2JGYVZmdmhXZWtnY2RkZ0ZmSGg5aFNiZGNHY3RnNmRZYzBjMWNxZlNld2Q5ZlNoRWRHZFJnTWhkZmliUWVYZEZka2dBY3FnT2NCZ0plYmdBYzJnbGVaZVlobmJKYndnY2ZFZmhkRGZTY1ZicGIxZWVkRWNzYitmUGVHYmxjZmZTZ1JkQWhFY2RnUmFaYkZmT2V4ZjloZmVLaGdna2UwY1Jhd2U5aG9nU2NSYlJlUWJWaHhnQmc3ZGJoMGRzYlZkUGNqZ29mWWdKYkZka2RHYlVleWdjZW1jUWJsYkJjdmRGZERlUWdqZ05mU2ZVZUhiSWRWZXBmWGRCZWpoZGRWZVVkbmVSZ3JoZWFtZU5iTmNhaGtoc2VQYlVoaGhBY3RoQ2huZVpoK2ZRY2toSWVMY2ViQ2ZRZGJkU2UwZndlTGJDZ3lkMGNsYWNlRGc0ZU5jRmNFaGtkb2ROZ0RoWWZNZU1jaGc4ZjdkQmJSZFpiQ2hFaFdjcGVmZ0JoRGUxYVdlVmhqZXNmMGhKZTFlSWZWaFBjQmdVZEhmQmNSYk1kUWFLZlRnUmhXY1ZoeWZVYW5iSGh6ZE1nRWRTYkJoOWF5YVNieGhZZFlnWmRoYVJobWNaZW1oRmZ3YVZnV2Q5Y2FlUmExY1JkYmNWZlZkcGFrZ2FiMmhSZ2pnQmRHYm9oWGJVYjFlSmZaZ1pmRmhKZnJoZGZnYllmS2FYYUNidGQ0ZlhkZ2g1ZVdmQmFBZTBocWZlYzFlcGh3YVNjRWhOYUpmV2huZlZmNGFTYjNiZGI2aGFhVmZkY1piRWFFZjBjZ2NXZ1Fjb2U0YkVmVmQwZ3FoRWRIYU5kaGdCZGlkWmNTaERnVGRVaFZhUWRpYmtlZ2RYaGhjY2U1ZVBjUWFRY2xhRmZBYzlhbGJQYVNkQmJFYlRnR2VaZmJoTWV6ZEpmaGVQY3hiTmN2ZUdkQWJoaEloVWJ4aEVhQmhkY21mSmZoZlNjVWUxaHFiU2N3YjlhU2hFYkdoUmhNZGRkbmdaYVNlUWNsZXdiK2JkZ2hlcGhiZUdjRmUxZFpnSmgzYnRod2NKZUFoQWFSZEJkZ2YxZTFkTmVnaDRlZ2RlaGhnc2JXZkZmMWNkZWNmRGZWYWtjWGFJY0VkTWViYmJoUmVRZzhnUmZoZlVkcmdVYkNnMGNlZkFoeGNBZ3BhSmh3ZkljVmFKYVRoUmRSZk5iUmRnY2ZjV2dDYjBjeWRGYUJkRmI5ZVBkbWJaYW1lWWJYYUJnVmRiYTFmcGRIZUhoUmcxYVZoVWJqY0ZncmNaYUdhTWFaZ0lmZ2dKY2NjWGNGY3dlaGZBYmpiRWVpZkdla2dJYVRhZmZuYlljYWREaGhjaGZlZldkVGNZZjZmT2ZTZE5nR2VEZXdid2NVZk1oaWR3Y0RoZmhuZlpmRGRWYjFka2dRY0dnV2VnaExlUmZXYzhkUmRFZTJmOWZIZGNoeGdNYlRiWmhsZmtjTmdIY2diQmNFZ0xlbmRKaGJiRmhUZ2hmeWFUYVhnY2dTYlNlaGJ0Y3BiS2JCaFllZWZZaEJoUmd1ZUloMmFGYXRoVmNUYnRmVWdDZzFoaGVUZUVmZ2VZZDhoYWIzZGRjamNIaDJhcGFBaERieGdzYVpiZmQyYVpjMmZkYmxjSmFDZEZlWGhoZjJhRWRrZXNnWWJRZzFla2EwZU1meWJKY3diQmYwaDlnamRXaG5iVmM0aFNoM2JkZjZhYWVWZGRjWmdFZ0JhbGJvY0NiMGdVZ25kRWhRZjVodmhBZm5iTWVlY1JheWRFZ09lWWdsYkJnSGNFYkdoWmN5YlZmaGFWYXFjY2JsZkZiM2dWaHdjTmhRYWFnV2NsaENlVWZDZzlnSGJaYm5kdGg4ZmJiVmhVZTdkV2hrZEVnYmFIZVFmZGVTYmFlbWJzZXpkWWQwZ3Ric2NTaDBicGJTYURjbWFRYmVnZmUxYnhmU2ZRY2hkVmU0Y2RiaGNKY0xmR2ZFY05iWmhZY25iSmd3ZmNjQWc0ZE1hR2YxZ3BjOWROaDBjdGRxaGVlaWZGZ1hiVmNCY0FiSWRjZndoc2VLZGJmd2Y4Z09lYmExZmRib2RFYTBjcGFsaFdla2FGZ1FnRWUyZXNmcGRjZmxmMGNWaE9nQWE5YlJnYWVsYWNmZWZYZGllQWZ5YmJkVmRkYW1iSGcyZVlidmFIaEdmdGUvZGJoMWVwY0hiSGNSYjFiVmZVaG5mUmhyZ2VlbWdOYk5mTGN3YmRnY2JGYXhjQWJ0ZENibmdaYytnUWJ3aGNoR2FlZUdlZ2JTYUFkeGVnZGZhQmNXaEpmemNQZm5hNGI4ZE9lamRrYy9oRWdRYWNkcWNCY1FnZ2VJYUxnaWRaY2piYmhCZWhnN2RLZWhiMWhsZ0dna2JWaEhjY2F4ZE5mSGVhYkJhVmNJYVVhRWdjYVFkWmZuZUpiV2VGZFNnd2E5YkFhM2ZkZmZmQmNSZlpmMGdZZFFlWWJEaFpmbGd4ZG1mZWFHZEVkL2ZUZG1nOWJSY1RiRmJJYVVoVmhRYVlkUGVKaEhhcGNvZFRnVGNnZTJoRGEwYzhoUWRNZ0FnUWcvZUpkU2VraE5hRmJYZE5lMmFXY3plWWFEaGFhVmRsZmlnY2ZuY0Jkd2VTY0VlTmFKZldlbmhWYzRoU2V6Z0loMmFPY2hmSmFaY1piVmNBZW1hWGUxYjBjT2hRYTBlRWZ1ZEhlbmMxZkRlRmJTYWRlQmVCZXdoUWhlZVFnQ2ZOZThlQmFWZkFkK2VmZEJkSWEyYkdkd2FZZmVlUGNXYzBhV2RUY0NlNWdkZU5hV2VnZnljSmdSaGNhdWVDYUJjVmVjZlJjRmQwaGJiZWRHZnNjemhZZzBjWmZxZ0Fnd2NaZmViRWVEZlpmRmdiZlZoeGRTZVFjaGJWZzRlZGFoZUpjTGZHYUVkTmZaaFlkbmNJZ2loTmZSYndoV2dHZHhhUmYxZk1mRmdCaGRmZWhtZGxjWGNXZlJjQWRaY2FoQWd0aEZjYmYwZHdiYWJZZDJiMWd6YkVmMGNkaG9hRmhVYWhnUWFSY3hhQmZtZWVhaGZnZGJkT2VpaEFmZWVJZnhnZ2hlYVRmemZrYWthR2NGYTRodmRXYUNocGZtZWZjSGVBY1RnT2JoYVFnRWZTaFZlUWRhZ0hlSGZSYmpjTGhtYzliTmVPY0VjY2hQYkdieGd4YmtmQ2ZYaDloMmJDZVdkZ2JWaGVkSGNZYlNmU2R4aGhmRGhXZFdiSmd5YWNlSGhBYkJmQmJVYWxoU2hkaHlkc2VmYkphVGJNY25jRWhGaHNlUWdCZkhlVWdMY0VnVGRaZUJhVmVpZEFlQmFjYjBjZGFPZmFmRWc1YmliVWFFYWNoUWZaZG5hSmVXZUZlV2JwaHlmVWZYYmRjWGVTZGhmWWRnY0poeGNZYVFoVGdCYlJlbWhaZW1hRmJ3ZlZmV2g5ZGFnUmd4ZzBiZGZWYVZhSmIwZWFnM2FwZnJnVGJ6YmtnZmZYY1JhdGVlYUllMGg1ZzJmYWIwZDljQ2RRaFNjRWZtZVZkd2VSZWViUWF3Z3RnSWNjaG5jQmF3YVNhRWdOZkpnV2ZuYVZoNGRTZTNkZGE2Y2FlVmVkZVplRWVCYWxkb2JGaEVmVmZuY0dkVmZaY3ZiV2FuYk5lQmNUZW1kUWVWZlFhQWRKYkhhRGZXYVphaWNYaHhnbGZxaGVlaGNoZTNmU2FrZHBjQ2dJY1NnaGdGZEZnaWFwZVJhS2NDYkVmMWZPYUZjeGJtZ2NmRWFjY2RkSGhWY1ZlU2JkYkdmdGU2aFllMGMxZHFlU2h3YjloU2dFaEdmUmZNZWRkbWJ4YlNiUWdFYllic2RKYkZkc2FGZFhmMGRGYVpmZmEyYjlld2RKYUJjRWdUYkRkQmZVYXplZWdBZkpnM2hmZkdiOWFYYlVnUmdoYmNoYWJCZFpjRmJKaGhoZ2RmYWJiMGQ4YzZkRWQxZnBkb2JRYlFkQWZaY0ZnQmU0ZnFnTmh4Y2hoU2hQaGpocGJZYmZmbGZ0Z2dnRmdtY2xiaGZGZWhjaGZtZEZnR2haYm1lWWZYaEJjVmZiYTFncGRIYUhhUWJ4aFZkVGIyYmxlMmdlZmpiZGREYkpkZ2Q1Z0JkRmVVZlFjc2NSZVZieGYyZFVia2VJYlZjZWRIZVloU2NTYXhlaGdEZVdhV2hKYXlmY2dIZGxiSWVHYUdlTmJhYmRkWGZoZUxlZGEzaHBjcGdWYTFia2FRYkdlV2ZnY0xmUmVXZzhnUmdSaFNhNGJWZWNiMWh4ZUhkZGVSY1VlY2JYZWdmUmFZaEpmeWdBZjFmV2RpZjRiM2NNZENiTmRmZFdjaGM5Z3loU2h4aFloWWRaYmhmUmhtZlphbWFGZ3diVmdXZTllYWJSY3hiMGVkZFZlVmZKaG1nZmhtZHhhamJVZzJhb2JFaERmMWJRZ1doWmFFaFFkaWRkZWtkOWNDaFdnbmNGYnRmT2ZFZ3NhWWFRaDFhbGdpZGNnbmVCZ3djU2dFYU5lSmFXY25nVmg0YkZnbGQxZzZjYWVWaGRlWmhFYUJnbGNvY0NkMGZWYXZhRWVSaE5mdmJSYXpncGhWYlJlMmJCYkRmQmd4aGtmRGhFZkhjWmZ5Y1Znd2hoaDNiY2doZ1JnM2dVaFVjd2RXYWFoemZKZ0NoU2ZpaDljYWdJYVdkUmNoaGNmVWdoY3ZmRGdoaDVmTmZXZUJkb2dVZ2RiQ2M1Z3pmU2VVYzFmcWVTZ3dlOWFTYkVhR2ZSaE1mZGduYVplU2JRZGhlVmU0ZWRoaGNJaGZlVWNCZ0ViV2NOY1hlSWgrZk5lUmE5ZERjUGVRaE1hbGhQZVNhNGhsZktiQ2RZY0ZnVWVSZUpiY2ZKZmtoZ2FLZktjMWdoY2RmS2hFZmNjK2JSYWhoUWY4Z0ZnUWFvZlZhUmgxaEZlbWVJZ1FjSmJIZUliemJ3ZVdnZGNWaDVlUmNQYUdjbGZoaEZoaGFoZG1lRmJHY1pibWFZaFhiQmhWZWJmMWNwaEhlVmRGZXRjVmNXZW5hWWY0YkxhamdFaEVhSmdBZ3dhTmRVYWdkMWI1Z1RhQ2ZJZHZmQWFnZ2RkYWJQZW5lWmVYYlNoeGI1YUZmV2VXZE1jOGRmYWpma2RiaEplZ2djYVpmT2FqZndmQ2ZPYVRlMWNoZEVibGRBYVpoTWMyZGdkTGdSYldoOGVSZEVoMmU5aEhlY2Z4YU5nSGVhZUJoVmZJZVVoRWZkYUVmTGhpZ0FmWmNRYm1jb2E4aEZiQ2JCZlhkUGRrYzhnNWhKZEhjTmRLZU5oRmdzZjBoYmRtZk1kRmhHZ3lhUWdVYkNmRWRwZ1RjVmhSaGNoNmRLZERkVWJuYkJoQ2dRZk1iRmRWZ0lhU2RaYkVjZGUyYU1jMWJ0Y1piUGMzY2hhMmJFZGthc2NZYVFhMWFsZmljY2JuaEJhd2dTaEJlNWRKYkhiemdrYXJiRGJuY2RiNGVKY3dlSWVVZVVkbGZ3ZDZiQ2RVZ1ZoeWNEZUJoTWc3YUhnaWFOZFdoQ2FDZjRoVmZIZ0ZkQmJCZ0ZibWFaYjZiQWVoZFZnM2VjYWtjTmVpZ1Fma2VvZlFmYWJUYVVkZmZBaDBjd2FVZVpjbWhaZmhmY2FGaFZidmhXaGtlY2JkYUhiVmdVYWJoTWhtZHRneWVjYjBiMWgwZ1NnMWUxZVNlVGZEZmhlTWVJYWpnNGViZkVmUmFzYzBhTWIxYXdnTWJUY0FhdGNaZ2ZjbmFJYmlhY2ZCaFFnZmZTaFFmNGY5ZU1hUmhoYzVjTmJpYXdkWmVIYWtnUmVSZWFhQmJkY0ZlSmFoaGdnNWRiZTBlZGh6YkVnMGFkZm9mRmdVYWhiUWVSZ3hnQmFtYWNnbGJaYkJkSWhpZ0FnZWFJZEZhY2dFZVViemc1ZmhhWmRGYmtkb2FVZHlkTWNEZ01jeWZJaGFoUGJWYkpmRmJjZ2tnZ2JCY1VkamVzZXRhZWZqaEVlTWdKY0FheGhLZlVkbGVrZXFkQ2ZEY01ndWVVY0Vkc2dPYVVjbmRZZVNhU2d4Y2hlRGhXY1dmSmR5YmNhSGhCYUlhUWh3YUFoY2NkZFhhQWFaZWRmMmJSYzBmVmZ4ZUFkWmNHaFRmcGZPaEViVGhwYkRlWGhXZThmVGFPZDFib2NVY2Noemc5Z0lkVWZFaGNiUWNaZm5hSmhXaEZjV2RwYnlhVWNYY2RiZmRHYkJmWmIzZmZjd2dnYUZjWmZnZ1JldmFhZ2tmdGZ3YVZlV2Q5ZWFiUmV4ZTBoZGhWYVZjSmUwY2FjM2hwYmphVGJXZ0lkQ2JEZDBmOGdRZU1nZ2NNZi9oTWVsZ0pnU2NGZVdmVmhyZURkMGF0Y1JiUWgwY1plaWdKZGpiZ2Y1aEdnMGcwaEZlSGJ6YXNkL2JIYnpiOWI2ZWNkMWJjZ1FlRWFBZGRoMmhGZlVoVmcvZ0dkQmQ5ZEZhUmgzYk1jVGdSZDJjZ2RWY1NhRmRCZUhmRWJHZlpoeWFWY2hmVWIrZWNiZ2EwZHJoVmUwZUpoQ2RhZlhld2FXZ0NnR2I4YlBnVGNHaFpmaGdjaEZhVmN2ZFdla2RjZGRnSGZWYlZkU2ZkaERhMGQ3Zk1iVWQwYmlnVWhDY1ZlU2VFZUdoUmVNYWRlbmhaY1NkUWVoZlZnNGFkY2hjSWNDZ1hla2hOZ1JjWWNEZXdibGVQY1Fkb2RHZEdhMWdoZzFjWmZWZVpoM2JMZGpmQWFIYUhmRmY5YmZjYWJGYjljTWJiZzFnZGJjZFBkVWRkZDdlV2cwYmRnMWRGYlJmcGJMaFJkMWFsZW1mYmdGYlpoZGRjYVhiSmJhaGZmQmc5ZkRmRmJqZjBncGhYZTBmc2ZkYVhnQmd0aG1hZmFIYkFlQmhkZUhoQmZIaEhhUmMxYVZnVWNuZVJmcmRlY21mTmhOY2Fka2Z0ZEtmSGhrZE1maGdUYkNhMWFjZVVja2JJYlZmZWRIZlllU2JTYnhhaGhEY1dkV2NKY3lmY2hIZEFiZWhBZWhidGhhaEphbmNoaFdhZGV6ZVJjbmhIZ2dmcGV5Y1RjQ2g1ZU5kQWFEZDBjWmdSaDJkWmNIZ2JnQmNNZlRkYWZBZjliSWZPZ0VmOWVlZ0lleWVWZldiV2cyZUlmbWNYZlhkY2FTaFFheGVnZjlkTGhtZlZmTWFOZ0ZmMGhvY0lkV2NsZzVkWGVHaE5jd2VSZHhiMGRkZVZhVmVKZzBiYWMzZXBnamRUYVdkcGRMZERkMWZJZ1FiWmVBYTFoMmNhYzFnSWZSZkdjemNRZ3piWGdBYnhlTWJDYTBiSmRJZWNjbmVCZ3dmU2JFZU5kSmRXZG5oVmc0YlNoM2dkZDZjYWRWZGNmZmVYZDBmdGRvZUFnd2UxZ3ZkRGhCZ05kL2dYZUhmTmVhY1JnMmJVZlZnR2VsaEJlWmdFaENoNWZwaFZoaGY1ZWhiT2RsY2hiM2hBYXdiSmJmZE9naGVwYmVhR2dHYjBnVWVOZkJodGZoZWJnVmJVYThlSWZRZDhmZGdHYkZjVWRUaENnWGZCYlFoWWMwYjFmcWhTZ3diOWVTY0VjR2NSZE1iZGJuaFpiU2ZIZnpoOWM0ZWRiaGZKZkxnR2JFY05kWmVZYW5lSmV3YmNoRWFnZFJjRGZBZzRiZ2dLZWdkVmgzY0xjaWhFYmVkQ2FnY3NjemNhYUFmdGRGYmJjeGhFY1RjYmUwZ2RlemFFYXhlcGRoaERkbWFKYVFiUmF4YkJhbWFjYWxmWWFWYWFnaWZRYVFmSmRWYmNmWWdRaG1ibGI4Y0ZiaGFjZGRnYWFtYjBhYWNiZG1hQmdZaGRlamN0ZEtmWmMxYnhhWWhDYkhja2FVZUJnMmN3YktiY2JXaEVhUGZVY2hkQmRrZVRiSGFZaHJhWGVBaEZhVWNOZkRib2ZhYkdoUmVSZkRjRWNHYXBnbWFlYVhibGZCZldoR2VOZ2FjZGdYZWhlTGNLYm5oWmVEZFZkMWRraFFjR2dTYTVkZWZDYXlmeGdGZVdnaWFBaEphY2d4ZHNoVGRaYkJmVWJhZVhnRWhkY1pmYmUzYUlmTmdQYzJjcGd5ZFVkWGFkZFhlU2NoZjRmN2NiZjJkTmh4YkNjR2NCYzFoZGhHZEZodGNWYlNjWmJTY1hjeGNRZlVjV2RWYkpiOGJPZFhoUWFXZkpnQWFRZi9hR2VVZlliUWZlY1Vod2gvZWZoa2Z0ZUxiSGFHZ05lY2NFZmthc2VZY1Fjd2FSZnVlV2VIYkJhd2ZTYkVlTWdQYURhemZzYzdkSGN6ZjRkMWVKYTFiZGZSZ1JkQmdWYm9oV2hVZWxhdmRXYkJicGh2ZEhlRmRrZFRmUmIyZ2dmVmNTYkZoQWRUZkhkaWVNZXFnQmdsZG9jNGhKZGdnSmQzYVNha2FwZk5nYWNTYWtiRmVDYW5md2NVaExkMmE1Z3lnZWNWZ2xodmhFZGxmRWVKYUJiMWFVYmJkZmJIZHBocWVhY2toMGIzYlVmQ2VWZVNiRWJHYVJhTWhLYjNncGY0YlFoaGZWZDRoZGdsYVFmZWRWZGdnQWROYktiemYwZitjY2RFY0FlWGNSYVZmb2RuZWRnRWFzYytoY2cyZ2tmTWJjYnhmQWdaY2FoQWh0Z0ZkYmJ4aGxoVmJPY2dma2J3ZlJod2E0Z25jV2YwaGhjWWFGZVJhbGdtZ0tiWGR3YlZhYWFuZ0pkUmFkaDFhZGdLY0ZkaWE4ZDBiV2RGZnNmeWJYZ1Nia2RvZ1lhVGdWZWRjT2QxYk5lSGRSaGplZGFWZlVobmRSZ3JoZWFtZE5hTmJhaGtlc2ZQZEZhRmg4ZDJhVGVIaDRiZ2dFY3hlQWJWY0tnbmFZaFBlU2QyYU1jK2ZWYVdoSWM3ZmNmR2ExZUlmVWIwYVZmYWNNZEhmaGJXZGRneWU1YW5mR2Z4YnhiZWJYY2pieGJEZlhhbWg5ZVVkRWYzZUZmSGNPY2dkaGVIYkliUmg1ZkRmV2NVY2RoTGhUaEhjSmFXZUZnV2FwZ3ljVWhYZ2RkWGZTZmhiWmJwY1lhVWdCZlpoTmZCYVFlcGJaZ25meGh3YUFlV2FFYlpmRGcxY3hiUGJOZGhnMGd3ZExhaGdzYjNmUmdTZ05jQ2dGY0hjZ2RRaFpiRWV4aDJjZGVsZEpkQ2dGZVhhaGEyYUVna2dzYUpiVWdVZ0ZoaWViZ0hmQWQvZllja2JOY0piV2duZVZmNGdTZjNiZGc2ZWFmVmdkaFpmRWhCZWxmb2hGYkVmVWM5YkhhMGZNZzZhRmREZ3NnYmRDZ0dmRWIvY1NoRmZCZEhjRWVHY1pieWFWYmhnVmNxY2NjbGhGZTNnVmMwY29oTWRhZVhnTWVHYURmSGg0ZVVjZWNHZ1lhdWRXZmxlVmd2ZVdla2hjZWRlSGFWaFZjU2hkZUdhdGc2ZllkMGYxZHFlVmhBZjhlQWhIZWpnUWJaaEpnVGI1aGFhVWd3Z3hlcWZkZGtlNWRMZkVhQWd4ZlpmZmNHZHhkd2NaZGtkRmFQZ1NmVWh0Y25kWWhFZ3NlcmJlZ21kRmFCY1NlaGJBZ2ZoYWhFY1JjTWRaYmpoc2JUYWJnMGZkaHpkRWEwZmRlb2RGaFVmaGNRZ1JoeGZCYW1mY2hrZHdjVmZmYjJmZGJEYmJna2VGY0tlQ2ZHY2thdWhGZmtjUWQ2ZUZmQ2NsYm1hZmYyZDFjVmVlaGtlMWZVYUNjUWRsYy9mVWduYlJocmZlZW1mTmZOZWFha2NzZVBmVWNoYkJha2NUZ0hoWmNwY1VmaGZBYmJoS2JDZ05lQmNBZXhoQmJSYVNmM2ZaZ3lnTGdIZEJkQWdEYUVmbGZFYmFnM2ZoYWFhWmZYZU5obGZWZTBiZ2RDYkFhV2JoY1hiUmVXaGNoWmVYYUdoOWZaZmJjUmVOYVJjWWdSY1ZhT2ZVZkZlRWFEaGJlM2I1ZldjQmFIZmhicWNVYlNhdGRYYlFmZ2FCaDZmWWdSYkFlWWdLYlJoMWJ2YVRlR2FGYndnVmdXZjljYWhSZ3hiMGVkZVZiVmhKYzBlYWQzZnBkamZWZjJicGFEaFJmbGJraGJjYWVHYVpjMmhkYWxnSmJDY0ZhWGdoZzJnRWZrZXNmWWZRaDFlbGhpaGNjbmhCZXdnUWJBYXhhSmhSZDNhVmV1aFhlbWFKZnBhZmgxZWRhU2RFZ0JlRmZnZEFiMWNSYi9mQWN3ZkJldmFRZ1hhTmNjZ1RhbWhnZUpkVmFGZkJmV2NBaEdjOWZ5ZUNlaGNWYWliWWMwY0ZhbGNSZkVhb2ZRYmFmVGZVZ1lhV2J5YTVjVmVOZEFhVWF1Zk5jQmNBZk9iRGdrZTliVWVGZUZmeGhiYmZlV2FkYVFkWWgwYzFocWFTY3dhOWNTaEVoR2RSZ01mZGVuY1poU2ZRYWhmVmI0Z2Rja2VCZEZoU2RCYVljS2FLaG5icGhhYWNkRWhoYkRiU2JWaHBhMWhlaEVodGMzZ2VnbWRsZlhkV2VSZEFoWmRhYkFkdGFGY2ZmUWhVaERmYmV4ZnRoemZHaHdjaGJvYkNoMWNaY1FlVmdnZWhodmhmZm5od2NWYmFmbmRKY1JkZGQxZGRoS2ZGaG1obGRoYUZnaGJoY21mRmRHZlpnbWRZY1hkQmJFYWZiVWVKYUhoUWRSYzFoZGdXZ2pmdGJyZFpoSGMxZk5jZWUxY2tmR2VVZGhoWmdrYVdhbWFWZi9lWGRtZmdhVmFlZ0hkWWVTZ1NleGJoY0RoV2VXYkpmeWdjZ0hmQmhJZlFmMGhsZGFnZGRYZWhhYWFaZldkSmFwZUNkMWZrY1lhRWJTY2NlTGhXYTNoRWZSZ0JiV2FaY0hmZGVSZk5nUmJlYXhkeGRFY2Voa2djZ1FhWmFuY0poV2hGYVdkcGh5YVVkWGdkZFhhU2doaFpncGFZZFJlWWVZZlpkZ2RWZjBkZmJtYkVic2FWZFdmZGdNZlZnQmYwYWJoVmhSZjFnOWdRZ1hncGFqY1RjV2hwZUxjRGMxZUljUWJaYUVmeGgyaGRmbGZKZUNkRmhYYWhhL2JHZjFoQWR5Y1FoMWhsY2loY2FuY0Jhd2NTZ0VnTmJKZFdkaWFoZVNmU2MzZGRhNmdhYlZlZGRaaEVhQmNsZm9iQ2V4ZWNncWNSYVVnWWY5Y0NmWGZOZmRmQWRqYThnVmNQZVJoa2hKaFJoSGg0Y1RoQmhFZmNjcmZLZzFna2RsaFhnbGNFZzhnYWZXaEVkV2NHYUdoWWZVY1pibWRZZDhkV2ZsZlZkdmhXY2thY2FkZUhkVmVWZVNhTWhqaDRjMGFJaEJla2dqZUJmRWVGY1NjWGQyZnhnRmNkZGlhMWY0Y1FnaGdWYzRoZGRoYkphTGJHY0VmTmRaZlliaWFBYzFhSmRCZDBhUmhCZjFocGduZGVkRmFaZHFoZWNpZWdoRmVIY2tlVmJVZkxkVWJVZFJoUGdCZjliZmNLYWdna2EwYlJid2E5YUNhRmdVYmhkUWhSYnhjQmJtZ2NhbGZZZFZkYWFuYkpjUmZhY0ZoY2FFYVVhemc1Y2hoV2RSZ0FmbmdSZGlmRWR6Y0xmRGJVZ2JhT2d3ZmtiOGhEZkdhQmZjZVhoQ2hFYjdnUGNpaElmWmFMZzBnTmJPZkFhRmJjZ3hnQWNUaE1lNGdCYmhjRmJ1Z2FnQWdzYmJmUmhWYndmS2JIZWllY2FoY0pjSGRoZEJnYWZVZGxnYWNkY1hnaGhMYWRkM2RwZXBlVmgxZWtnUWRHZVhnSWhMZEVjU2FkZVlhUWhHaDhoT2dQYVVoQWhUZUthVmJzYUxiRmRRZ2hoV2VaYmphMWg4YUZhV2JwaHliVWZYYmRoWGZTYWhhWmVwZFllUmdZY1lnZWZSZ1Fhd2dLZFNoZ2EwY1ZmU2hkZlVkQmRGY3hiUmZHZlZib2RnaElkemNNZHdhUWZXY29lS2JYZFJkVmJGaEtoUWZrZjRiSWRnZUVkNWRCZ1FnVmYvaE9kRWRzZFlkUWExYWxoaWRjZm5hQmN3Y1NjRWhOaEpiV2FtaDlnNGJCY1RhSWJ0YmFkUmFoZVJkVWVVYnNkdmdYZ2dhZ2RxYlhjMGJjYjhnUGdHY05ldWdUZm5lTWEvaFNhRmJCZ0hiRWVHYVpieWhWYmhlVWUzaFdoRmZGZjNjVmQwY29iV2hhYldlRWZXYlhmamZOYWFiSmZUYUlnb2JQZHhodGF2YUVla2E5Z0plRmhGaFVoSmJYY21idGc2ZlljMGExYnFiU2Z3YjlnU2NFY0dmUWVlY01leWJJYkhoRWVGZXRoNGJmaGpoaGhMZEdoRWJOYVpnWWFuY0pjd2VjaEVoaGJEZFNiVmRwaDlkTGZBaE1iK2JLZ1doY2VFZEhiRmVWZWRkYWVCYlpiRmdPYnhjRmJhYUlmUmNRZW5iVWVnY2tkcmVVYkFkY2FXaFJkMWM1Zm1iYmNWZlpjQmVaZERoRWdkZ09jQmVrZlBjSGFtZUJhaGVEZ0JjZ2VvZkhoRGdKYXZjYWRIaHhlL2JiaDFmcGZIaEhlUmMxYlZnVWFuZ1JmcmRlYm1oTmdOZ1lhaGY5ZkhnR2MwYk5lcWFHaG1mZGQyYlRoMGZKZUJjTWhEZjllQmVSZlVlc2NHYkhlQ2RaYThnTWN6Y3dkSGhEZVFmeGNTYmZkSGZZYktmTWV6aDVoaGRCZUZjQWdlZVdhQ2R4ZVBlVGhTYTRiWWZHYW1nTmF0Z2NleGdOZkhjYWFCY1ZkSWJVZ0VnY2ZRY1pjbmhKZldjSGhUYjRkNmZHYkNnUmRaY0hmQWhSZXBhZmZCZ1pkTWFMYWxoMGExZ2FkRGRJZjFiRWNDYXRoVWFCY0ZiRmZTYkdkeGFkYjhlWWJuY1FiaWZDZFNlNWhEZlRmbGhzY1pnYWhHZlpkMmVkYWxkSmFDaEZoWGZoYTJoRWZrZXNkWWZRaDFobGJxZkphamNnYzVjR2YwZTBnZmVTYlhhVmhsYlNheWJNZnliSWJBYVJnWGhRZDFid2Z0ZVRoMGFzZHNoWGFWZXdhaGJBZm5lc2VhY1RlbWhRYy9iU2dGYkJlSGdFYkdiWmZ5ZFZhaGhWZnFoY2ZsZEZhM2NYZ3hmNWNlY0lnRGZJZ1lkVGFuY0ljVWJlZDJkWWExYU9iQmV3aDhiVmNCaFJhWWFXYUJmRmVjYk5heWRjZDFjTGVRYmhiaWdRaGdiRWFCZVJkU2NZZ1lnSmREZ2NoUmdGZ2hnMGNyY2ZneGV0aEhiTWRrY05jWmVZZW5lSmF3Z2NnRWVoY0RkU2JWYXBjMWVlYUVlTWNqY01maWhBY0VmVmYwZFJjV2JQaEVjb2VKZEVhRmIxZFdoSWVVZ2RjdWVFYTFhZGdoYUdmV2NKYVFnUmF4ZEJhbWFjZmxoWWVWZ2FlbmZKY1JnZGQxZWRhQ2hRYmllRWhvY1JkUmVZY3JiVWdTY3NmMWJLY0Nlb2FRY2JoMGFkY0hiRGVSZVJnWmVlZ0hjUmRyZWVlbWJOaE5hYWVrYnNjUGRVZGhiQmRrZVRkSGM0YmljR2NnZ3RhR2ZkZmpkdGRYYkJjbGhjaFJlQWNHZEpmdmVjYURoNGhkZERnd2RWYVRkZWdWZEpmTGRkYjNocGFwZVZlMWdrYVFjR2NXY2dkTGdSaFdoOWJGY1dieWNZZ1VnV2FSZE5mSGdhYUJhVmJJZVVhRWZjYVFnWmhuZEpiZmREYWtkQmd5ZFVnWGFkZ1hnU2ZoaFpncGRZYlVic2d5YVpjaGJSZG1mWmVtYkZkd2FWZVdhOGFNaEJla2Y4Y2RhR2QxZUplcGJhaHpoTmhyYVhoR2ROYkZjZWRqaHRlK2dFZ0ZlOWFraGJoWGJoZ0NkRmVYZ2hlMmRFZ2thc2ZZZlFmeGJkZHNhSWFpYUliL2NIZ0Fld2JkYkFkeWVVZjlnUmJTaDhlaWZJYlNlZ2dNZ1FiRmgwYXBnWGN3aEJodmhEYUJnTWhwYkVoamExZlFnRWJ5Y0ZnYWFCZmxiQmdQZVJnR2dwZnlkQmRCY3hjcWRLZFhhdGEzYVZnMGVvYldoYWhXY0VlV2RHZEdjWWhVZE1iQ2hjYXplY2VCaHhiamVjYkVnY2ZkY0hhVmdWYVNiZGZHZHRnNmhZZzBoMWdxYlNkMGdwY2VlT2JtZVJjTWZkaG5mWmZTYVFkaGFWYjRmZGFoZkpoTGFHZ0FoeGJaZmZoM2JJZnhoZmZqYWNmUGhCZWdnMWQ1YlVoa2J0ZDNlZWJtZ2xkWGRXYlJmQWJaY2FjQWh0YUZhYmUxZGtkVGZjZ2tkY2J5YUhoVGJnY2dmWGNBZDhmWWdYY0RhcGRtYmNkbGJZZVZlYWZuZUpoUmhkZzFkZGVLYkhlaWR4ZWhhQ2F4YmdheWhGaEdkeGJtYkxkbmZsZ1pjYmUxaElhT2NIZlFnQmJWYkZiM2dSaDFoWmJIZjFoTmhlZTFjMGNHY1hlaGNCY3NiQmFYZVpmOWJUYTBhSmZIZ2VoSGZ3aFNhQmNCZUZnUGZXZFdlb2Y3ZGNiSGZaZ1ZnUWYxZTllUGdZZEdjdGZlYWZkbmRaaHBoWGJ4ZkFlUWdFZm5mVWVMYkVkV2M4ZmJkRWF5ZWRiT2ZhYURibGNIYmFnQmJWYkljVWNFYmNoUWdaYW5mSmhXZ1FjeWdzYWdiVWhUZGxkWGhWY3hlWWQ5Y0thVmc5ZkxmYWRHaHNmcWZLYVRlWmR3Z1hobWc5YVNnVWNRYWdhSWZSZWtoZGQwZGJlWGZvYW1mUmJHYVpkaGNEZjFmSWVRYVpjRWV4ZTJnZGRsZEpkQ2NGYVhkaGYyY1JkMGRzaEZmUWJ4aGRhaWhiZkdkNWR1Z1NnRmFKZGZlUWhWaDloNGJTZTNmZGQ2YmFiVmNkYVpkRWRCZWxob2dYYmtjVmNrZkRjQmJNZTdlRGN6Z3BjQWVTZlJiZGVkZkFnUmhjZ1BkRWVHZTFheWJYYmdlTmEvYVpmMGJKZGlkVmIwYndnV2hJZUdmZ2hOZE1lbWNZZlVlWmRtYlpiaGZjYkZnVmd2Zldka2NkZUxjWGFBZmRkU2FNYW1odGJuY1lkMGhVZi9iU2N4Z05hT2NFZkhlVmJhaGZlM2dZZE9lUWZoYjFndWZZY3dnZGVZaERmVWVOZWZnWWVqZ3hmNWJhZzJhSmVEY1NiVmNwZzFiZWNFZnRoM2FlaG1mbGFYYVVlVmZZYVpiZGVRYXRjTmJLYlJlRWhQZmNnMGhkaGlhQWhFYTVlb2VTYlVlaGNZZkFkUmJCZDRhYmNFZmdkVmhlYTJldGdZZmZobGZ0Z2dmRmFtZGxiaGVGZ2hoaGZtZUZjR2JaZG1jWWdYYkJnVmZaZXhoUmJIZkFjQmUxYkRhUmEyZkZjNGFiZjJmTmRMZGFhZ2QwYUdjWGZqaHBka2RUZEhhWmgyYlVja2dJZVZnZWVIZFlhU2hTZ3hlaGhMYURjR2dKYXZkY2ZEY1phSWdYY1ZnZGdFZWRnV2RsYWRoZmRuZ1pnRGNWYTFha2VRY0dnV2hnY0xlUmJXZjhlUmRFZzJiOWhIaGVoMWh4ZUhjZGNSZlVhYmZYY2poaGdjZUtjU2ZWZ2ZkR2FVY0JjeWZVZFhiZGFYZlNmaGZaYnBlWWVSYlljWWNaZGhhUmR1ZUxmbWRGZ3RmVmFUYnhjVWhPYUZjVmhVZ0VoaGhwZjllWmMxZUJiamFUYldhcGZMZ0RmMWRJY1FjWmdFZnhkMmRkZ2xnSmRLZ1VkSGFoaHJkRWZnZ1VjWWhTZ1Zha2F0YmVmM2Z4YmFoU2VFZU5jSmZXZm5lVmI0YVNkM2ZkaDZhYWNWZGRmWmdHZUZoQmhvY0Zma2VVYnFoRWJRZzFoeGZXY1hmTWdDZ1VjV2FFZFphWWVsYkJnSGdFY0dmWmJ5Y1ZjaGhWZ3FnY2FsY0ZkM2dWZzBnSmFmYWFnV2JvY0xjR2VEZE1jVWRiYkdkWWZ1YmVkVmVsaEZoV2RraGNhZGhIY1ZnVmhTZWRmR2F0YzZmWWcwYjFmcWhRZjBoWmhTZUZjbmVsZ01iWWZHZU5jSGdVYlFiQmh4Z2ViamJoZUxhR2NFZ05mWmZZZW5oSmd3Y2NmRWFoYURlU2FWZnBoOWVNZ1VmdGQ4ZFpjMmNrZlpnV2dSYW9iWmdJaEFiSmhKYVJkUmhFY1RjYmUwY2RjemFFaDBlZGJvYUZhVWJoY1FhUmF4ZmdneWZPY2hmOWJHZ1pjQWcwaGRlT2dBZEJjS2FDZzJhbGIzZEFhd2UxYzFlQWhXZVphZ2VZZVRmVmFjYlljM2VCZ0hkSGJSZDFmVmhVaG5jUmFyYWVmbWFOZk5mYWZrZnNkSGhCY2xiZ2F0Z0hjM2JnZkpmR2RnZXRoU2FNZ0hnWWdQZlNjd2E1Z1dlVGdIY0ZhbmRjZkhlWmVJY0Nka2hCYkJmWGQzZ2hmTGhkZTNlcGVwYlZjMWJrYlFjUmhIZ01jaGJSaFdmOGFSZEVlMmg5YkhiY2J4Z01kUmdLZlVmZGFJaEFlMGVjY05oWmZqZXhoZWZGYzNjaGRrZVJlR2NOaERhV2NRZk5mK2JkZXdhY2NhYmJjeGVoYU1oWmRtYkZod2dWZVdmOWJhY1JjeGYwYmRmVmRSaE5oMGVkYW5kb2h0YlJoV2JoYVphSGRVYVllR2JmZ0ZoNWRrZFlmMGNOZWJiRmIzZkZmNmVPZkVoc2RZZVFkMWdsY2lkY2JuYUJld2hTZkViTWNjYldmbWVoZjRoQmNYaDlkNGhlY2tiVmJQY0JiZ2cxaHdkRWhsZXhmK2JCZ2hnRmhtZlNmMWVraFRoUmcyY2dkVmRTZEZnQmdIZEVmR2RaYXlnRWVCYVZkM2djZmhmOWUvaFZkVmN3YkFoY2VYZE1hQWREY1hjUWVDZ2RhV2hSYW9iZmJIZTlodmVXZ2tmY2JkZ0hhVmhWaFNjZGNHaHRkNmdMYzBlMWczYlNnMGdGZGFhRWhuaGRnYmNZZG1lRmhFaFVhd2VaZmhiWmhSY0JmQ2RBZTJmbGZaZllibmFKYXdkY2JFZmhoRGhTaFZiSWc2YWRhaGFzY2xkTmdUYzBoWWFEZFVobGZKZExnUWNVZE1jSWRWY2hjSGNiZDFmcGd6YVdlMGI1YmtoUGIwZ2hhUWVSY3hmQmdtZGNnbGRZZFZjYWhuYUpnWmRPY0Zoa2NhZVJhQ2dZZTFjV2hVZHdiL2FSZ0NlTmNvZk5lQ2JBZFJnTGZnYTRlQ2NIZlFjQmZWZUZiQ2RFZWxiT2FUaGNmRWdKZFFnVWFQYVdha2FSaHRjVGNDYjFkY2dVZ2tjSWdWYmVoSGNZZVNiU2J4YWhnRGVXYVdkSmV5ZUpiamJFYWFmUWV3ZkJiV2ZYYjNhaGZMaGRmM2VwZnBoVmIxY2tiUWZHYldhZ2FMZVJkV2I4aFJiWGNHZTljYWRjYXhjRWZVZlBjRWFjZkJiSGFnYkFjU2VaYW1oOWRMaEZkVGM0Z3JhQWRUZElnWWhEYkJiWWE5YWViamh3YlloWmFoY1JmbWdaY21mRmZ3ZlZnV2Q5ZmFnUmZ4ZjFkU2FWYlZnUmZ5ZWFjM2VKZXJhR2JXYnBlV2JEYXhlY2dZYU1kRWRWZy9mZWRsZ0pnS2hXYW5kaGFyZUVia2FvZEpoU2NsaFZoaWdlZWpobGd3ZVZkVWhOYkloU2NuYnhmeGFSYzFhMWI2aGFkVmdkYVpkRWRCYmxib2dDZjBlVmV2ZEVkUmZOZnZnUmczZEZkR2dDYVNheGJRaERjaGZrY0phVmdTYkpnd2VWaGhlUmczZGNhZ2VVYnVnQmZ3aDlkWmdMZDJnRmEzZlNiamZSY1ZoUGh3ZFFnMGJOY2hlTWNxZkNkRWdjZmJlR2QzZjllU2hkYkdmdGI2ZFloMGMxY3FnU2F3ZTlnU2VFY0dmUmJNYWRmbmdaaFNhRmdoZlVleGJPZUVlRWJmZFdjUWUwZGFlSmd6aDBiMmhjYUNla2NSY0dheGhzYXNkR2VoZDRleGFQaENhd2FGaFdhUmZZZGZnUWNnY3RnRmViZ3hoRWdUZWJjMGZkZHpoRWEwZmRmb2NGY1VmaGFRY1JheGNCZHVlZWdoZzhhVmdkZDNnSmdRYVpoMWU1aEdkRmhtZkVhMWdGYWdjVmZtZVdiaWZNaHhjWWRRYlVhY2RJZ1FoNWNmYWZjRWE4Y0hlRWR5aDFhamJMY21hcGNFaFllMWRBZWxiVWJoYkJla2hUZkhkWmEyY1Vla2RJZlZnZWJIaFlhU2dIZFZma2dSZ1dmU2FwZnlnYmJYaEJnWWNUYzJiTmJhaGRlWGVoYkxiZGYzYXBmcGZWYTFha2dRZkdjV2ZnZ0xlUmNTZkVhUmdEZm1lOGJUaGZlVmI4aENmSmJsY0lhY2ZHZkVic2Y2ZlpobmhKZFdoRmJXaHBieWZVYlhnZGFYZ1NnaGFaZXBlWWhSZFpjTGVaZ2dlbGFtZExibWJGZTdkVmZTYUZmQmdiZlJkMGRkZlZoVmFKZTBnYWYzZHBlamFUZVdmcGRMYkRkeGJ0YldoWmdFY1JnbWFkaGtnOWNmZEZlVGZaZS9iRWhoZWxkZGRGZHdnd2V3aFBoSGZBZGtjQWhBaG9jYWJRaFZiOWM0ZFNlM2dkZDZmYWVWZ2RoWmFFaEJmbGRvYUNjMGNVaG1hVmV4aE5hbmJiYlhmTWJUZVJhMmZnYVZnU2NGaEJlSGJFY0doWmR5ZFZlaGFWZ3FkZWNsaGthamVIZ3diTmNGZ1pjemhWaFpjVGhDYmRlWWFHYVNlb2ZrZ1BmbGJWZWtjUmUwYWRoVGFGZUZlbGE0YWRiR2F0aDZoWWMwZTFhcWNTY3dkOWJTYUVmR2VSZ01iZGNuZFplQ2RRYmdnaGhsZmRma2dZYkRoVWFSY0JlWGFMYnpnY2M5ZUlid2JFY1pmRGVGaHBkemVmZG1hRmQzaGVmbWFsYVhoV2VSZ0FoWmRhYUFjdGVGaGJjeGhFY1RiYmQwZWRhemZHZnhlTWFnZ1hjQmR0ZGVjQ2JsZlVjcmFQZFFkUmhNZGFmbWQ5ZlJnT2RGZGRhVmNGY21mdGFqY0ZoZ2FKaG1nWGhXaFpnNWVZaFRmNGRRZk9lRmJvYXlnVmVGZE1mQmRTaGhoVWE1ZktoQ2dJYVVkWWJsY29jWmNXZXhiQmcraFRiRGZnYnpmQmhVZ0phSGVjYUdhY2dFZFFjaGNGZFBhY2gyaEpieWFjZ0hnQmRJYVFiMGRsZ2FnZGVYY2hnTGRkaDNicGJwZkFoeGFGYVpoU2FtaFpjR2hBZkNmSmNDZVdnamVVaENiY2Z4Y2hiSGJKaGhiVmJVZVVoRmJZZ0doYmgxYWhmV2RGaFdkcGN5Y1VjWGhkZVhmU2doZlpocGRZZlJkWWZSZ1RoQmNSYW1kWmhtZ0Zid2FWZ1djOWZhZ1JneGIwZGRhVmhWY0pjMGZPZFRkOGEzaEdmRGNnZ0ZjRGQxZ29mNmZaZEVoeGgyYmRmbGNKZ0NlRmdYY2hnMmVFY2tlc2NZaFFhMWVsZWlhY2ZqZDllYWJTYUVjTmZKYldmbmVWYzRnU2UzaGRmNmdhZ1ZhZGRaY0ViQmZsYW9oQ2UwYVZidmREZWhhTmduZUVnemF0aGFhRmVHZ1poWWREY1JiMGJJaFFmamc5aHloWGhRY2hncWJKYmxiaGVkYlZhMGZvZ1dmYWFXYUVkV2RHY0dnWWhVaFpkbWRaY2hiY2hGZFZldmFXZWtoY2FkZUJiMWdVYWJnWGJtZHRnNmJZZTBiMWZxaFNnd2c5ZFNiRWFHZVJiTWhkYW5iWmdTYVFkaGhWYjRoZGZnZDFkTGFUYkFnc2VRZ01nWGZ3YzljTmFRZ1VkTWFHYXdhTmc3Z0tid2E0ZWpoY2dqYTFiWmdDYWtmVmViY0tiVmJraFhlTGNrZWdmYmJmZDBmdGZ6Z1hlVWE1YmtmRmFSaHdnWWhEZWtoTmNvY1BleGROZVljT2ZUYXNmTGhNYWxlNWZnY0ZibWNsY2hmRmNoZGhjbWRGZkdmWmJtZ1liWGhCZVZiYmMxaHBoSGVIZ1JiMWNWZVNkSGFRZC9nZGJDY0FoQ2NPYWhjSWZIZUJlbGJnZHRhSGUzY2dmN2dGYndlOWZhZEtkaWM4ZmVkU2QwaHdhTGZFY0RlRmM4YlBiVGRVY0ZmRWJBYUFkQWVNZ0hnUmFMZlplM2VaaHBiR2ZWZ0FhY2JNZjJnZ2ZMYVJjV2M4aFJkRWQyZzljSGZjYnhlTmdIZmFhQmVWZEljVWZFYWNmWWhNZGpib2RmYlJibWJRYi9nRmJEZW9mRWZBaDBnd2ZzY1lhUmUwYkZhWmFsYnBldmZhZmthdGV3Y1ZjV2E5Z2FhUmh4ZTBiZGVWZlZnSmgwZWFlM2FwZmphVGVXaHBhTGFXYXhncGJaZk5oMmZaYzJmZGVsY0pmQ2hGaFhoaGYyZEVka2hzZ1lkUWYxYmxjaWZjYm5hbGNyYllna2ROYUpkV2NuZVZiNGhTYjNoZGg2ZmFmVmZkYlplRWNGZUFhdWhDZzBiMGU3aFdoVmFvZjhkU2hUZDVkV2RDZmpndGdjYkVjaGNWZEhhRGRtY1phaWFYYnhlVWZ4YldoRmVGYTNiVmUwY29lV2NhYldlRWRXZUdhR2ZZZVViWmRtZlpnaGVQZzNnOWN2aFdla2RjY2RnSGZWZFZlU2FkYkdndGQ2Y1llMGgxZXFlU2h3YzljU2JEZzJlUmhFaElhamc0ZWJlRWdSZXNiMWNNYTFjOGVFZVNjaGVwZVpjYWZXZTlld2RKZEVkWWhRYUJoUmNNYTJjUGJVYk5kbmZkZm1hbGNHZFRmeGJBZ1ViYWRGZjhjTmZKZGthSWhkaElkZ2RJYitnUWNBYzRjeWRVY0ViRmFaZGJlUmZCZW1jY2RsYllnVmNhaG5nSmFSYWRmMWdkYUtmRmVtZGxnaGVGZWhjaGg4aEZjQ2I5Yk1jWWNYZkJoVmdiZDFhcGNIZUhlUmUxZ1ZhVWRuY1JncmVlZm1lTmZOZmFobGdRZVBnQmJsYmdmdGRIYzNkZ2I3ZkZkd2Q5Z2FiS2NpZjhjY2dHaEZlMGhYZFVhVWhoZXlhY2dIZEJmSWdRZzBlbGFhY2RlWGVoZ0xhZGMzYXBocGRWZTFja2dRYUdjV2JnYUxkUmdUYXNlZmZRZERmb2ZGZU1ka2ZFaFZmS2FVZ3hnQWNRYkVjc2JRYmRmMmhSZldoR2ZHYW9nbWdHYVRkNGVFZlJlRmRzaHNiTGhFZlZnUmVQY0ZlRmN2ZmFoa2h0ZXdhVmhXYzllYWFSYXhoMGZkYVZjVmRKZjBlYWUzaHBhamNUY1dncGZMZURiMWZJZFFhWmRCZGdhK2ZQaHdmRmFNZVdjRGcwYTdkUWRRYkpoQ2NCZW5mTmJpZ2NibmJCZXdoU2ZFaE5nSmVXZ25lVmE0ZlNiM2NkYjZnYWRWYWRlWmhFYUJibGRoaEloVWZWYXZjRWdSYk5ndmNSZzNlTWFUY1JiMmRnaFZmU2hGZkJiSGVFYUdlWmhvZVZma2FGYmtmTWdSYTRkbmNEZ2tiSmRDaElhU2VoaEZoRmdpaHRhUmhLY3lna2J6YUtoVmZsY3ZhRGFnYzlnVWdUY2xic2JmaE1lU2NZZ3BkS2VoZmNkdmRSZndhOWJDY0hjR2FSYmRmWWFIZlpkZmJRaGtiRWR3Z1BoMGJGYkZkVmVRY1lnVWRNZlRnc2FxY05oVWdGZllmWWExZnBlMWdlaEVndGIzY2VobWdsY1hmV2dSY0FiWmFhY0FidGdGZE9kVmdCY0JmYmJ3YlplemREZ2toZGQ0ZURnbWVKaFFnUmZ4ZEJnbWVjYWxkWWVWYWFmbmhKZVJjZGIxZmRlS2VGZGlmWmdMYkZmaGRoYm1kRmVHZ1phbWFZZFhoQmNWYWJhMWZwYUhkSGdSZjFhVmdVYm1hdGVyaGNhamhjZEZiSWV4ZmdhQmhCYUFmRmVxYkZiQ2E0YSthTGJSaGRkRmVQYURoZGhHZURoaGJCZ3BhV2hXYkpkeWhjYkhnQmZJZlFiMGFsZGFnZGRYZWhoTGVkZjNlcGNwZlZlMWRrZ1FhR2JXYmdnRGZFY1NhZGJZY1FkR2dFZ0tkTmNsZTRkSWNPYmtieGZHY0Vmd2Q5YVJnTmFCY0ViWmVVZFNlOGJUYkJhWGg4ZldkU2hoZzFncGVjZkJiOGZZZmVnZ2hoZ21nZmhtZWhjd2dDYVViVmRhYlJjeGEwZmRiVmNWYUpiMGVhZDNocGRqZlRoV2RwaExkRGIxZ0loUWhaZEVoeGUyZWRmbGVKYkNkUWNUZkFmL2FRY1VlVmNWaEJnaGhRZ3RnSWNDYWxhK2dDZ3djc2RJY0NlQmhZZzNhRGR6YUlnYmJQZFZkOGJZaEdoUmFWaENoQ2UwYlZndmhFY1JnTmJ2ZVJhM2FNaFRnUmMyYWdiVmZTYUZjQmJIZEVnR2haY3liVmRoZVZlaWNKZWhia2grZkJhRWFSZGJnTGZDZXhlWmFTY2pnOGhhaEphU2c0YmdoSWhqZVlhZ2JIY2dkSmQ4ZlNnVmYwZ1RhZGVHZUJiNmNjZEVoUmFxYVZheGFOZFNmQ2JHZTFiTWJLZWxleGdTaFFnaGVWaDRoZGVoZkpiTGRHZ0VjTmNaZllnbmdKZXdiY2hFZmhiRGZTYVZicGQxZmVoRWR0YjNjTGhpaEVoZWJDY2hkNWNVYkxkVWRZY0tjUGdVY2dhZGFMZkFoOGF5YlFjU2ZRY25iVWJRZjBmeGdFZHhlZ2ZuYmNmbGcwZlZhZWhIYXRjN2JkYjFlZGhLYkZlbWhsZGhoRmNoZ2hhbWhGZUdmWmFtY1loWGFCaFZlYmUxaHBmSGJGZ0JkRmcvYlVmbmJSZHJkZWNtaE5hTmhhZ2tkc2VQYlVmaGVCZGtiVGNIZVpnMmdVZ2thSWJWaGNnRGdjZlNlUWdBaFZhRGJUY1didGQrYldjbmVCZklhUWEwZWxnYWhkY1hnaGZMZmRoM2dwZnBmVmYxaGtnUWdHaFdlZ2ZMYVJoVGF0ZVpiV2RqZnhhSmhKZ1FmRmJKY01iRWQwZ0FiTGZ4aEplQWFJZ2phTWFDY1VnR2FKYVlnVWZYYWRlWGRTYWhhWmNwYVlmUmNZY1liWmRoY1JkbWFaZ21nRmd3aFZmV2g5YWFnUmZ4ZTBmVmNBY1Jhb2g5ZE9oSGRRYnVoQ2ZDZ2NhRWVYaFFhc2RlY0pmd2VRZTNjSmREaEVlTmZVZ1RlMGNYZ1Jma2FOZFpjUWgxaEpjaWZZZDNlbGR3Z1ZlRmE5aEphUWRuYXhkNGRGYjFoMWI2ZWFhVmVkZ1phRWFCY2xlb2VDZjBmVmJ2YkViUmNOZXZlUmMzZk1kVGFSZDJhZ2hWY1NkRmdCYkhkUmZDYjRkN2NCYlJic2FuaE5meGV3YzRkQmRSYU1iWWhLYWlhbGdYZVNnZ2VWZWJoSWJpZU1hQWNKY0ZnMGN1ZlVkMGFzYzNjSGVWaFZnU2dkY0dkdGU2ZVllMGMxZnFoU2d3ZzlnU2hFaEdhUmhNZGRobmJaYVNlUWVoYVZod2dJZmxmb2FDZFNjMGcwZVVlSmN6YThkL2VJY2hhRmJOYkNmaGNJYjBkS2ZpaGdlNGhQY2lkd2EyY0RmUmhoYllnYWJBZUJiRmJmZEJmZ2FUYWNmMWR0ZHpkQ2UwaDVhb2RTZ1doSmdRaFJjeGJCYW1hY2RsaFllVmFhYm5hSmNSYWRoMWRkYUtlRmNtaGxmaGhGaGhnaGdtYkZiR2FaZm1oTmNUZmdkY2NQZkZnUWNLYVdlRmFBaGFkQWFDaDFlbGNPZ1Nhc2dNaE9jQ2hoYUFkRmFsZlVnRmZHZ0hoNGUzaFVna2VrZVZkYWJuYThnNGNTY3hmaGdEZ1djV2ZKYXljY2VIYkJnSWNRaDBhbGRhYWRmWGJoY0xkZGEzYXBocGVYZmxkVWc2ZkdiV2NnZUxnUmRXZjhlUmRFaDJmOWFIYmNheGVOZkhoYWFCZVZnSWZVZUVhY2FRYmJjamZOZldmSGduZmRkeWVSZ1hjNWdiZllhQmVaZ3BhWWNSZFlnWWdaYmhkUmVtYVpibWNGY3dhVmFXZDlhYWNSY3hmMGdkZVZlUWRZYjhkSWVpZGxodGJHZjNmbGhGZlZkd2ZwZFloR2Z4ZWtmbWRNYmhlTWRXaFVlSGFCY2NjRWVrZHNkWWZRZjFlbGFpYmNkbmRCYndoU2RFYU5kSmdXZm5mVmg0Y1NkM2hkZjZiYWJWZWRmUmFSYUZjRWdoZVdnRWFzZWloVmhGYjRlZ2RGYlNkb2ZkZEJjQ2RCY1VnR2JqZk1nSWdWZ0NoTWVUYkFnaGcwZXJoY2hsaHBlM2dSY2tnTWJXaGRhWGUwY1djQWJHZDhjVWhPY2toeGdoZ2NiRmdWZXZkV2FrY2NiZGRIZVZhVmVTZmRnR2J0YjZjWWIwZzFicWZTZ3doOWJTZEVmR2FSZU1lSWFqYTRiYmRFZFJic2gxZE1jMWM4ZUVjU2JoZnBnWGRJZFRnb2Z4YUlkaWRzY01iRGNSZjhoVWZMZkVhTWIyaGNmMmdWYzllV2NSYUFiWmJhYkFndGhGYWJneGJFYlRhYmcwYmRnemFFYzBhZGdvYkZlVWZoYVFjUmN4YkJodWNKZmhjNWFjZk9mWGN3Y2NoTWRoZm9mRmNSZkRnQmF2YlZnVmZBaG5lUmhnZFVlcGhKZVRlVWUwYU9lMWZJY0dhSGZSZVpkVmFRYVhkMWZyaFpobmc5ZU5lY2JrZ0llUGNEYWpjcGJrYVRoSGVaYTJhVWdrYklmVmJlaEhnWWdTYlNoeGNoYkRiV2JXYUpieWZjZ0hnQmhJYVFjMGZsZGFmSWVUZEFhQ2FKYkhmUWFrYkVnaGRSZmZmU2h6Z0VkRmNCYmlkZGVRaFFlUWh3aElmTmgxZVlmbWJQY0JjMGJKZFVhRWF3YlFoZGdIYnRmOGZGYldjcGR5ZVVnWGhkYVhmU2hoY1pncGZZYlJnWWVZZlpjaGVSZW1jWmNtYUZod2FYYUdmTmJ3YVJjeGYwaGRiVmhWZ0phMGNhZzNmcGhqZVRnV2hwZExiRGExaElnUWhaZUVheGgyZ2ZhaGFOZUNjSGRtZlZmMmNCaGtlSWRVZGFjVmJsZ2liY2FuY0Jmd2FTaEViTmdKaFdmbmdWYTRoU2gzYmRmNmdhY1ZkZGNaYkVmRWEwZWdjUWdoZFpmaGJSYndkZGhoY0hoeWh0aGJiT2ZEYzFmRmdEYkJlRWJUZ1ZnV2c1ZlllVmZoYlZocWZjaGxiRmEzZlZmMGNvZldoYWVXYkVoV2dHaEdmWWhVaFpibWhaYWhlY2VGZFZhbmhEYmdlOWdVYlRnbGhzaGZnTWNTZFloMWJNZVJhUmhrZENkRWNjYlRjUWZnZGNkRGVNY2phTWh6YUZmaGQwaDVkZGhoZWxlTGRDYlVjcGRaZWZmbWY1YndmYWRFZ0ZlRGNGaFhiQmcxZmVkRWN0ZzNlZWdtYmxkWGVXYlJmQWVaZ2FnQWF0Y0ZnYmd4ZkViVGZiaDBmZGN6YUVnMGJkZG9jUWJRYkFlWmRGYUJhNGhyaE5heGJ0YWFoT2VDZHRkZmhOZ0JjOGdMZlJnQWdvYnVlVWhsYjBoSGZRYUdhNGZuYmFhSGZ4Yi9nYmUxZHBnSGRIYVJnMWJWZFVlbmhSZnJnZWdtZU5kTmhhZGtoc2VQZ1VkaGdCY2tkVGdIYVpjK2FCZWdocGFjZUtoM2JoZGZiRGFsZVVnTWhDaHpidGc4ZE1memhnaEplRWVTYW9jVmNNYlRoMGZxYkljM2hJY29kVmcxZElnUWhDZ21hRWJMaFdjWGFNZVJhQ2UyZ1poSGRMaHpnbGJIZWFnQmZWYUliVWhFZ2NjUWdaZG5nSmRXZEZhV2dwYXloVWZYaGRhWGRTZmhoWmZwZFlnUmZZYllhTWFsYndodmdOYldhOGg5YkVlQ2ZJZ1ZmRmJVZFFoVGFGZWhkb2UxYU9lUmZrZ3NmQ2ZTYThkcWdXYjFmcGJSZlpkRWVkYjJmWmNGaHRob2VGaFhoaGgyaEVha2VzaFliUWExZ2xnaWdjZm5oQmV3aFNhRWdOZkpjV2JuZFZmNGZRZm5iNWdRYmFiVmhkYlpkRWJCYmxkb2hDZjBkVmF2ZUVlUmNOYXZmUmQzYk1jVGhSYzNmSWVWZVFnQWVRYVBkV2dUZ1ZlOGZBYkFhUmdrYUtlZ2FrZC9mS2JCZzlnR2FMZVNhQmNDYVhkV2Q0YitnWmFtYVpnaGdjY0ZoVmh2aFdha2JjYmRlSGFWaFZjU2NkZEdldGc2Y1loMGQxZXFnU2h3ZzlnYWNSYkNod2RGZEplWGJnYWZhQmMxZ2doM2VKZkVlc2N3ZldkVWJOYVNiWWdtZU1lTmZjZEZnUmdmZFNhVWZKYzhhZWVCZmRiM2ZMZWlmRWJlZENoaGE1YlVmTGdVaFllS2ZQZ1VnaGdvZExiamJwYy9lT2hVZWRib2ZGYlVjaGJRYlJjeGFCZ21mY2NsYVlnVmNhYW5lSmNSZmRmMWVkY0thRmFtYWxoaGdIZGtmd2F1aFhnVGZWYW9iTGFEZVVlWWZJZUFoZ2hlYVpmbGd4aFZmV2dYaFJjNGRCZTJhTmNSZWRka2VzZlhiV2d4ZkFmNGFUYkNkSWQrY0dheGdFaGJlTmVUZE5iZmZCYkVmb2FhZ0lmaWhOYnllZWIzZ0JmYWhQY21jTmZhZGRmWGNoZ0xiZGQzYnBicGhWZjFoa2RRZEdlV2dnY0xjUmJXYjhnUmRFaDJhOWhPY2ZmemZsYkhjYWJCZVZoSWNVaEVnY2FRZVpkbmJKYVdiRmNXZXBieWRVYlhkZGRYaFNiaGFaYWhlSWZCZllhVGJlYnhjUmV5Y2JjMmcxZGFnVmZXYzllYWZSaHhnMGNkZ1ZnVmRKaDBhYWYzZXBhamVUZ1dncGNMaERkMWhJY1FoTWNBYVFhL2JKYVZld2VVaEJjM2hZYnVkU2ZnZU5mbmhGYWdia2NtY01keWhRYzFlUWdHZmxnSmVXYW5lVmU0Z1NhM2VkYTZmYWVWZGRlWmNFYkJnbGNvZUNoMGFWY3ZoRWFSYU5ldmRSZTNidGhIZURjeWZGYkdhUmJoZzBiQ2dYZVNoa2ZnZ0RhMmM0aHJjY2dsY3BnM2JSYWpnY2VXZ2RkWGMwYVdjQWRHZjhnVWZPZW1oWWcxYk9lQmJ3ZDhmVmhBaHBjWWZVYUJkb2RBYkxmUmVBYTdlSGFrZkZkQWJTZHdkOWVTZUVjR2NSaE1nZGhuZ1piU2VRYWhnVmU0Z2RiaGVKaExlR2FFZE5mWmdZaG5lSmU0ZEpiQWRBY0tiR2NsZlFiNGRQYVFhWWI0Y0tjRGZBaHNkR2VCZ0FlU2RhZUJkZ2E0Z2Jnd2EwZFBlYmgxYjlkNmNFYnhkdGVvZlFlUWRBZ1piRmJCZjRkcmJOY3hjdGVhZE9hQ2dzZnFoTmNsZmRmQmNGZG5mc2ZjZlBnQmVoYm1kRmJHYVpibWZZYlhhQmNWaGJnMWJwZUhkSGRSZzFoVmJVZ25oUmVyYmVibWNwYUJiUWFFYnNoUGRVYmhoQmFrZFRhSGNaZjJiVWNraEllVmJlZUhnWWFTaFNjeGZoY0RoV2VXY29hemVjYUhhdGZWYVFhMWgxaFRmZWNWZkpjTGJkZTNjcGVwYlZjMWRrZ1FlR2dXYWdhTGZSYVdiOGFSYUVjMmY5YUhmY2V4YU1lVGVJZkZld2NiZ1hiaGJFZERjYWFDYm9hT2ZYaFJmVWduYkFkVGdNaFdhSGhsYU5oaGNTZnhmWWJZY1piaGZSYW1mWmhtZEZhd2RWZldoOWdhYlJjeGUwYmRnVmFWZkplMGJhZDNocGJqZlJlVGE0ZERnUmRnYUVjZWdLYlFha2U3aE9lUWZBYWJoYmhqY2xjMmJHaFVoc2hKZFBibGhsYStiYmRuZkJmb2RRY1ViTWFWZFdnaWRFZndhQWRpZFJlMGJKZ0JkSWdVYlhhMGRzY3hnY2FBZlFhU2hIYVRobGZ2Y1JlM2RNZlRhUmEyZmdlVmVTZ0ZkQmZIZEViR2VaZ3ljVmZoZVZjcWJjZGxnRmgzZlZiMGFKZ0NjSWhTZmhmRmVGZWlidGhSZUtkeWRrYnpoS2FTYTRodWJXZWtld2hkY0RjaWNoaFNoYWZIYWRhNmFlYzBmUmFxaEZkd2U4YUdkV2ZDZjBhZmNlaERnc2RYZERmMWRvZHFoTGcyaGtjS2hHY0VlaGFaZ2NmQWQ5Z2FlY2VFZmhiRGNTZlZhcGgxZWViRWR0ZTNnZWJtZmxiWGhXYlJjQWhaaGFlQWZ0YUZhWmhoZTBkNWRiYzBiZGZ6ZUVkMGZkYm9mRmVVZGhoUWhSZnhiQmdtZ2NibGhZZFZjYWNuY0poUmVmY3hhWmhLYUhjWGNSaGhiQWJoY0ZocWRQYm1hWmhtaFllWGNCZVZlYmMxZnBkSGFIZ1JoMWZWaFVobmFSYnJmZWVtY05hTmdhY2hiOWZIZkdnMGVOaHFhR2ZtZ0plNGNDZWhmcGNkaEJjeWZOaENjRGcxZ2toWGFIaEdhcGFZZWNiSGNCaElnUWIwaGxhYWJkYVhoaGRMY2RlM2hwZXBhVmQxYWtlUWNHZ1dkZ2dMZFJiV2c4Y1pnUmN5ZGNkT2dJZEJmMGhLY0xhVmZnaEhkQWRoYTVlcmNKZTNiSmVkZUZoWGhzZlBiVWhXaHRiTGVTY2dnNWVnYVlmVWRvZFloTWhsZ3dkdmROZ1diOGg5aEVlQ2FJaFZjRmhVYlJjbWJGZkNhOWM0aFFkWGFwZmplVGhXaHBmTGNEZTFlSWFRZVpjRWh4YTJhZGFsZEpmQ2hGaFhhaGEyZEVha2FzZ1lnU2R3ZjBncWdPZ3lhTmcrYkJlUWdZYUVnRmRTYWNoaGNNYkRiWmU2YllkbGJkYUtiYmJSYWxkMGZGaDBoVmUzZkdlQmZNZ3pnUmV5YmRoYmFEZGplc2JiYUJnUmZVZUthWGN6Z1FkcmdMaFZoUmhxYmVoVmZGaGxkS2RtZ0FmV2VhYldjRWJXZEdhR2hZaFVoWmhtYlphaGhjZEZkVmh2Yldja2JjaGRoSGRWZFZlYmJmZldmZGRRZllnMGgxY3FmU2N3ZTllU2dFYUdhUmJNZWRjbmFaYlNjUWZoZVZoNGVkYWhkb2REYUdoRWRoZUViWWFtZE5lbWJjZ0VjVmhEZ0hnUmNJZThkS2UwY1VlNmNQZHlhUWhFZEVoRWdwZGNiWWFRZ2RkdmNiZXhlRWVUYWJjMGJkaHpkRWUwZ2Rjb2hGZlVoaGJRYVJkeGZCZm1jY2RsYjViQmJJZmpic2JDZWVnUmVvaFBmV2J6aG9kb2hUYkZjMWJtYUNoV2VaYTJnYWVIZnhlL2ZiZDFicGNIZUhlUmQxZlZhVWJuZlJmcmJlZ21nTmZOZGFka2dzZFBnVWhsZzlla2JTYW5mQmYyZFdkaGZaZWRmTWRTaFVlY2NCZWxlMGVPYkZhamJBYXJoY2FHZjFiSWZRaFVodGNUYWJobGVKYkxjZGMzaHBmcGhWZjFna2RRZEdmV2RnZExlUmRXYjliTWRPZ1dmOWNIZmNheGNOYUhkYWJCY1ZkSWJVY0VoY2NRZlpkamJzZlFiRmVXZElmaGFVaFhmcGFYaFdmd2FCZHBiZmd3ZHNlWWhMZGhoMWVtYVBkVWV0Y3doVmJXZDljYWFSZ3hmMGdkZlZoVmdKYjBjYWYzZHBnamVUZFRid2FLZVhiVmJKaEZoWmNGZ0ZnMmRKZVZnSmFQYkZiV2RsZmdlQ2RXZUViWWZRZTFhbGhpaGNobmFCZHdoU2FFZk5jSmRXZm5iVmU0YlNiemFNYTFoUWIxYmRhWmFFYUJkbGdvZkNoMGhWYnZlRWdSZ05odmJSYzNoTWhUYVJmMmRoYWFkWWNsaEJkSGNFZEdlWmd5aFZnaGFWZHFmY2ZsaEZhM2ZWZjBjb2VXYmFmV2JFZFdnR2VIZGtmVWRiY2pkSWNwY09jUWhaZ2hhRGFGZVlmVGNSYVFnMGdhYUNoemI0YnFoSmR3YndhK2REZWdnZGU0aEVkR2VSZU1oZGRuZFplU2dRZ2hiVmU0YWRoaGNKYUxlR2VFZ05iWmdZZW5hSmh3ZGNoRWhoZURmU2NWaEljaGNkZGdkZ2IvZ09iemFzZjBlRmNsZlJlY2dDaFZnOWVOZEpmeGJFZ1lnYmYxZVpkNmdFYjFodGgwYkZnVmVCZVphUmEwY3hnbWRKZ2xkaGJXZ0lmamNNaERmRmFCaGdlT2VVaHdoZ2ExYUhhbGVCZ3ZjR2JFaHhibWdZZlhlQmFWaGJlMWhwZUhhSGFSZDFkVmNVaG5nUmJyaGVnbWROZU5jYWJraHNmUGNVYWhoQmNrYlJiQ2RKZzRiRWNRYnBnVWdLZ2hmVmNkYURlMWcwYmlnRGRXZm9nNmRjZ0hkdGFJZ1VnRWFCYmFoYWZXZFJiTGhiZjNjTmZwZUNmMWdsaEVlRmR5YnRjRGZCaERhMWV5ZFhnQ2JzYkNmRWVrYmRkUGRJZUJlVmZEYlVkRmNVZFplVGJIY0plV2FGZVdkcGV5Y1VmWGFkZ1hhU2FoY1pocGdZY1JkWWRZY1pmaGdSZG1oWmVtZ0Zmd2RYaEdkTmV3Y1JjeGMwYWRnVmNWZUpnMGNhZTNocGVqZFRoV2JwZkxnRGIxZ0liUWVaYkVjeGUyY2RlbGdKY0thWGNYZ2hkOWNEaDBkc2NNZ1NhbGJWYkliY2VuY0Jkd2hTY0ViTmZKZldjbmFWYjRnU2UzZ2RkNmRhaFZjZGRaZ0ViQmVsZm9kQ2UwaFVlN2ZXZlZnb2c4aFNoU2RVY0JnU2ZUYUJmTmRBYkNiOGdTYlFmQ2NJaHpoQWNsZ0JmaWVXaEZiRmczaFZnMGRvZ1dmYWVXZEVlV2dHYkdjWWJVY1pobWNaZmhhY2VGZFZodmdXZWtlY2JkaEhiVmRWZmFnSWVHY1VoNWhLZHdkd2c0Y0tmRWRBY1dnVmdRZlVkWWJmaGphNWNTZFNhUmVWZXBjZmd4Z0poWGZCZUVoTmdCZWFmM2JJYnNjY2ZCZ3hiTmZDYWhkSWEwY0thaWVnZTRlUGhpYndjMmJEZ1JlaGFSYVlnUWFkaHZhYmJ4YUViVGRiYzBlZGZ6ZUVoMGZkZ29lRmJVZWhjUWJSYXhiQmNtZGNmbGhZZ1ZoYWhuaEphUmVkYTFiOGhlZEdlQ2FvZXBkVmEwaG9oRmJXYnlmSWFqZkFnQ2FSZWRhSmExYXBkTWdIaFFmNWRjZFVhbWhoZjNlZWhuY3RjRWFhZmhnY2ZQZkJiaGg0Ym5mQmNEYWNha2FNZFFhMWNSYVBjUmdkY0dnUWExaEJiRGZVZm1iSmNnZGVnVmJwaElkUWMwaGxoYWRkYlhhaGNMYmRnM2FwY3BkVmcxZGtnUWdHYVdmZ2JMYlJhV2I4Z1JkRWIyZlpkTGdXYVJoTmVIYmFoQmNWYUljVWhFZmNhUWFaaG5jSmNXY0ZnV2dwZXljVWZYYWRnWGdTYWhjWmNwZGFhVmg0ZVlnYmJRZGxjbWFjZG1kaGI4ZGZlMmQ5Y2FnUmh4YTBnZGRWaFZhSmQwZ2FjM2FwaGplVGdXYXBjTGhEZjFoSWJRaFpoRWd4YTJnSWJoY29kTGNSYW5mWWFnaEFkVWNWYkFhR2J4YkVmZGdKaHllQWEwZUNmUmdjaE1oVWdsZjllNGRTYjNiZGY2ZmFlVmRkYVpjRWhCZGxnb2ZDZzBoVmV2Z0VoUmZOY3ZiUmIzZ01lVGVSZjJoZ2JWY1FoQWZSZ0plVWh5ZDRjemZCYkhmWWFsZ05maGJRY1dmQWMwZ0poZWFhZldlb2VXaENjV2M4ZFVhZWZuZXBkaGVhYUZleGJ2ZUJja2dkZ0pkRWh4ZFlmYWhOZlRka2ZaZkxmQWVraHZoS2JsZXRnYWhXZEdkMWNBY1hkSGVaY1NjUWZoYlZnNGJkZGhnSmdMZEdjRWFOY1pmWWduYUpid2NjYUVlaGFEZ1NhVmZwaDFoZWdFZnRiL2VMZG1nY2VVZUVnVmRGZExkQ2UwZVFmQmdLaG5mQmhIZ1pnd2M5Z3phR2hFYWRmN2NIZUViaGhNZ1djeGZCZStoZWcxYlpkSmRhYmljWmhmZ05lQmU4ZExnUmVBaG9ndWdVaGxoMGFIZVFhR2M0ZXVkWWdYZXRhVmJmZVZnTmJ0YUhlUmQxZVZnVWhuYlJlcmJlZm1hTmdOYWFna2ZzYVBkVWJoaEJja2VUYkhiWmYyYlVja2RJYmNmZGFGZHdoU2RTZnhiaGZEZ1dnV2RKZHlmY2RIYUJmSWNRYTBlbGFhY2RkWGVoZkxnZGczZHBmcGRWZTFjRmFZZ0dkV2NNaFdhUmNYYXNhWWFIZjBiVmdIZ2NneGNOZkhmYWFCZFZlSWdVZkViY2dRZVpnbmZKY1diRmhXZHBmeWVVZlhmZGZYZlNoa2ZJY2hkS2FFZFVmV2hNY0FhQmJvYVBjamRraDRoS2RqaG9hS2VBYzFjeGdKYUVoRmdwYWVoYWMzZnBnamZUZldicGRMZkRoMWNJZVFnWmRFYXhlMmZkaGxkSmNDZ0ZjWGVoaDJiRWZrZ3NmWWdRZzFhRWcyYWZmRGhNYTRkQ2RSZkVmcWdGY1RkRWE5ZkthaWFOYnllSWNWZGRlU2ZFYkFmaGNoZUNjMWhsZHpjRWhRZHRkbWJSZ3liOGNUZkVoMmZaZFdnQWRCZ0VnVmhjZHlma2QyZUViM2NRYStnZWRoZWxjK2hXZTJlQWhXZWFlV2hFYVdjR2RHZllnVWFaY21mWmJoYmNnRmJWZ3ZlV2ZrYWNlZGhIYlZmVmhTY2RmR2V0YjZlYWJ4aGxia2NDZEVhY2NUZVFhZ2djYkRnTWZqaE1memNGZmhnMGR3Z2RjaGdsZ0xnQ2gwYnBmWmVmZW1oNWh3YWFjRWNGYURhRmRWYW9oaGhkZWdhZ2QvYk9jemZzYTBkRmVsZVJmY2hDYlZhOWJOYkpjeGJFY1liYmcxYlZnNmVPZFVjZGRvaEZkVWNoYVFlUmh4ZUJibWFjYmxlWWhWZGFmbmJKZFJiZGIxYWRjS2ZGZG1kbGZoYkhkeGZGZk1nRmRHaFpnbWhZZFhoQmJWZ2JkMWVwZkhnSGJSZTFiVmFVZm5jUmFyY2VjbWJOYU5oY2RFYXNkSGJCY2xmZ2d0ZEhjM2dnZmdjUWEwZXhnTmVJYURhNWJ0Z0hha2dnY0hiR2ZEZVlhM2FlaEZhcGNJZFFiMGdsYWFiZGRYYmhlTGNkYzNocGdwY1ZmMWFrZ1FkR2ZXZWdjTGRSYVdmOGNSYkVjMmU5ZEhjZWgwY2NiOGJJaEJoVmJEYlVnRmRaZ3RmWmJtYjVjS2JGaFhhSmg3YVVmU2h0ZlhkSGhtYzBiaGVIZEJib2h5ZlplaGFSZG1mWmVtY0Zkd2dWaFdhOWNhZFJjeGcwYmRhVmNWZ0pmMGNhZjNmcGhqYVRoV2JwYkxmRGIxZHBoRWdIZXdkUmYyaGZnVmZKYlJnYWVIZmhmcWhEYmtoc2hBYlNhbGRrYytjY2ZpaFFmTGRBY0VlTmVDYldmbWJjYUZhWWdYZGRlNmRhYlZkZGNaZUVnQmVsZm9kQ2EwY1ZodmVFYVJoTmR2YlJjM2FNYlRiUmgyZGdoVmFRZFZjeGd0ZkVhR2NaYnlhVmFoZ1ZmcWhjYWxmRmMzYlZnMGhvZ1dmYWZXaEVmV2hHZ0diWWhVZ1pibWZaYnBlT2ZGY1Zma2FSZTBiY2FKZkZhRmNsYzRnZGZHY3RjNmZZZzBlMWRxYVNid2E5ZFNkRWJHZ1JiTWdkZ25kWmVTZ1FnaGRWYzRkZGhoZElmZmFVZ0Fjb2RLYWJkQ2dSY2lmZmJoY0FnYmRBY1NmVWJnZUtkQWg4ZTJjTGZpY3hhZmJjaHhhQWRaY2FhQWF0YkZmYmZ4YUVjVGhiYTBiZGJ6YkVkMGRkZW9lRmZVZmhkUWVSZXhkQmNtZmNobGZZZWRnUGRnY2tlWmFkZjFieGRLYkJieGNSZWhiQ2NnaFJkbWZEZUdkOWVtZVBjWGZBZ0JnRmZCYklmNmhFYVRmZGJWY1VkbmZSZnJhZWdtaE5lTmZhaGtoc2hQZ1VhaGdCZWtmVGVIZVpjMmhVYWtiSWdWZmVlSGhZZ1NnUWEwZ3dkNGZFZFdjSmU1YmNkR2hNYTFlUWgxaFZjR2RkZ1dnQmNDY2RieWdaY3BjQWN5ZUpoWWZHYldlTWVMZ1ZmeGRJYjdhRWgyZjliSGhjZ3hnTmRIZ2FiQmVWYkljVWJFZmNjUWRaZG5mSmNXZkZhV2FwYnlhVWVYZmRkZWRSYWpoeGJwYVlmUmRZaFljWmRoZFJkbWFaYW1oRmN3Y1ZiV2I5Z2FmUmV4YjBmZGVWYlZnSmcwY2FkM2JJZ3JoVGRXZkZhV2JEYTBkWWdaZGFlR2haYzJlZGJsYkpmQ2JGY1hhaGMyYkVja2FzY1loUWcxZmxhaWdjZm5jQmN3Y1NnRWVOZEpjV2VpZ0Vid2VBZmlkUmcwYVBiMGdSZVhmU2NFZUVjZ2hkYUJjQWUvYlZhVmNJZDdnQWFuZXNnNWdSYjJhZ2hWYlNhRmRCZkhkRWFHY1pjeWdWZ2hoVmRxYmNlbGNGYTNjVmYwY29iV2FhZVdmRWdXaEdhR2I1ZUFjSGFTZzVmaGhlYTFoVmUrZkpoMGdjZkJlQWFWYlZjS2FmZFdic2htZ1lmeGdrZ1JnQWYzaEpoZWdPYm1lUmhNaGRkbmRaYlNjUWdoZFZoNGdkZWhmSmNMYkdjRWdOaFpiWWJuYkphd2FjZkVnaGJEaFNnVmFwZTlmTGFEZEFmL2RlYm1hSmJYYVNkbWcwYVpmZGFCZ2RmRmZkYnhkZ2NUZ01mMGhjYm5lYWVBYzlkb2JIYmtlaGhDY09jamRwaG1jY2RsY1lkVmJhaG5hSmFSYmRoMWVkYktoRmNtY2xnaGZGaGhhaGhtZUZhR2daZm1jWWZYaGxhWmRSYVZocGNIYkhjUmgxaFZkVWJuYlJjcmRlZG1iTmROZGFia2dzZlBjVWhoYkJja2hUZkhiWmYyYVdkZ2FvYlZiY2MyaHNlU2RYZXhkRmNQaGNkMmhKYXllY2VIZUJiSWVRZDBkbGFhZ2RlWGRoYkxjZGUzaHBmcGhWYTFia2hRZkdiV2NnZExoRWRTZ2RjWWVRZUdoRWRSZlpneGgwZ2ZlTWdGYTBoM2dCZ1JhZGhVYkpmeWVZYVRkSGNVZUJoeWRVZ1hnZGZYZFNmaGZaY3BhWWFSZ1lhWWVaY2hiUmVtY1phbWhGYndhVmRXYjljYWNSZ3hkMGdkZlhiUWdZZ1BkSWQzZ3Bob2JUZFhhc2cyaERiMGc0Zk1kWmhGYVJhL2hkYmdiNWJDaFFiUWZNYytlYmMwZmNleWRRZzFnbGZpaGNnbmZCZXdnU2hFZU5oSmhXYW5kVmY0ZFNmM2hkaDZjYWVWZWRjWmdFZ0JhbGhvYkNoMGcwYTdoYWJsaHRmdmFUZ0hkTWJBaE9obWhnYkpjVmVGYUJnZmFHZldoWWF1YVZia2FFYlJkT2NsYkZhOGVWZDFjaGFyYlFlMmNFZFdnR2dHY1loVWJaZG1kWmJoZWNlRmVWZXZmV2FrZWNkZGJIYVZiVmhTZWRhR2F0aDZmYWFrYVJlbWNZZVFoOWJTZkVjR2RSZ01hZGFuY1phU2hRZGhlVmg0Z2RnaGhKZkxjR2ZFaE5jWmZZYm5jb2g0Z2NlRWROZGViU2dVZDVmOGJZZTJiRmYzZ2VjbWhsZVhlV2VSYkFiWmhhZ0FkdGdGYmJmeGRFYVRoYmd4Y0FlN2NXYmdlc2F0YkZmVWRBaEZoUmR3ZjVmN2RjYWhmNGdjYWNmVmdoaFJjZGMxY2RmS2FGZm1nbGJoZEZnaGRoYW1iRmdHZVlmN2FTYTNmQmFWZmJnMWZwaEhmSGVSYjFmVmhVZW5kUmVyZGVnamFFZEloUGJoYzVnZGNIZ0JoQmVzZVphbmdaZzJlVWdrZklhVmZlY0hkWWRTZlNieGJoZURkV2RXYUpleWVJYzNoQmdXZlFld2ZGZWFoY2YzZTViaGZkYTNhcGhwZFZmMWhrZFFiR2RXYmdkTGNSY1djOGVSaEVnMmc5ZEhkY2V4Z3NnSWNRY2hnVmVJZlVhRWFjaFFjWmFuZUpmV2JGZVdkcGR5ZlViWGZkYlhjU2JoY1pmcGNZZ1Fja2FZZWJja2FBZnVkTGJ6Z0poK2dHZENkb2hYaENoRWU5ZEVkVmdWaGxlcGRhZXlnNWV0aEhkaWJZZkNkVGNCZ2NhWWNMZkVlVmQvYVhlRmFKYkNlRmFYYWhiMmVFaGtoc2ZZZ1FmMWZsYmljY2RuZkJmd2VTY0VnTmFKY1dkbWU5ZTRiQWJsZDFkNmZhZVZkZGRaZUVhQmRsaG9lQ2EwZlZjdmFFaFJkTmh2ZlJkM2hNYVRhUmEyZ2dnS2hTZkFnUWhQZVdiVGNWaDhnR2gxY0FjbmNQY1FhTWJ1aFdnUmNsZVRkUGhXZmxmQ2ZGY2pnVmJCZUpiQ2FjZXplSWhoY1FlMmZVYWdiOGZSZEhiUWRaZ2JlZWFHZ3NodWNLZndoUWc1ZVJlVWhJZVhnWGNUZ2NiRmhMZURoTmNiYWFnQmNWYzRhZGRoYUpmTGhHZkVjTmdaZFlmbmVKYXdnY2RFY2hkRGNTZ1ZjcGgxZ2VlRmZGYTNjTGNtYmNmVWJGYmtiQmJBYlljRmY4YU5lSmRrZklkZGJJYmdmSWUrYlhlQmNVY3hjR2hVZGdiRWVEZTFla2UxaGZlQmZ0ZVFmSmh5ZUVnWWJMYVJhSmNHYkZnaWNGaHRkRmJrZnRjdmVHYkVleGJtYlloWGdCZFZiYmIxaHBmSGVIZFJkMWRWY1VmbmNSZ3JnZWFtY05nTmZZY2hjOWJIYkdhMGhOZXFoQWhUZE1mN2VBZ1FmdGJQZFBiWGRZYVBjU2UwZ3RoRGhWZUdjSWc2ZmVoWGVsZUVkYWRVaGxjYWRkZ1hjaGZMYWRkM2VwaHBnVmYxaGtmUWVHZFdjZ2ZMYUViU2NkY1liUWhFY1ZjSGFjaHhmTmRIZmFlQmVWZklkVWVFZmNhUWJaZW5nSmZmYURna2dCZXlnVWNYZWRnWGZTaGhlWmJwYVlkUmdZZVloT2N4ZDFkcWJUaEdmRmR3YlZmV2Q5YWFkUmJ4ZTBlZGdWY1ZiSmg4ZkphSGFRZnpoSGN5YVVkZmhRYUFiWmdKZk5iQWFsaDRmTWZoZHNoRmdVYUNkc2JpYUVmbGJZZlllQmNRZ3dmc2NNaFNnUWM1ZUJhd2QxY0poVWJuZ3hiNGRFYUZnMWE2Z2FkVmNkZlpkRWVCaGxmb2FDZDBjVmF2YkVoUmJNZDVkQmhpZkVoVGNFZDJoUWIvZFNjRmJCZ0hiRWJHZFpieWFWZGhjVmdxaGNnbGRGYjNlVmEwYnBkRWNaYlVhc2dXYUdlR2FZaFVlWmhtYVpjaGVjY0ZiVmV2YVdna2RjZGRoSGJSY3hoU2hhZVdnc2Z1ZUtjd2dRZTVjUmNVZklkWGJYaFNkc2NlZ0xiM2JwZTRiUWJoZFZjNGhkY2hnSmNMZEdkRWhOZFpiWWhuZEpjd2NjYkVnZ2VHaFNnVWZkYjFhZWZoZGdhamVLYkNmQWRaZ0hlaGZJYlphZGJSZlpiRmNPZjBhaGZEZEtiZ2VnYTFoRWF3ZDVma2VQZTBoaGNRYVJjeGVCYW1iY2ZsZFlkVmRhZG5oSmRSZGRkMWFkaEtlV2VXYmxkOGZGZ2diaGVxYlBmbWZaZm1lWWdYZUJmVmViYjFjcGFIaEhiUmMxY1ZmVWVuZlJicmNNYm1lTmJRYWFlaGg5ZEhnR2MwY05kcWZBYVRhTWc3ZUFhUWZ0Z1BnUGVYY29oNGJTYXhoaGhEZldjV2NKaHllY2ZIZ0JnSWRRYTBjbGdhZmRlWGRnZUlkZGQyZWRhcGVHaFJoeGJIYUdjU2ZZYURiVGJIZ1FnN2NFYjJkOWhIYmNoeGZOYUhlYWNCZFZhSWRVZUVhY2hRYUlkRGMwZEViRmNXYUphWWVVYlhiZGhYYVNoaGhaZ3BoWWJSZFloWWdaY2hlUmhtZlpmbWhFZmthVmZYY0pid2NSY3hoMGJkaFZjVmVKaDBoYWQzYnBlamNUZldhcGhMZERhMWFJYVFhWmNCY2dkK2dQaHdoRmNNZVFkVGJjYmllVWF3aGRlbmVEYnhnd2RzZGNmbWc1Z3RnU2ZGZ0pnZmVjZEhiVmI0Y1NkM2FkZjZkYWRWYmRlWmdFZEJmbGVvZENiMGVWZXZnRWFSYU5odmRSZDJhd2RUY0VneWFCY2NlR2gxZjRnUmRBZVVjeGR5aFZiaGdWZnFhY2NsY0ZhM2hWaDBlb2VXYWFhV2VFZVdoR2NHZllmVWZaY21nWmFoaGNiRmhWY3ZkVmhCZlZoU2FTaFJhbGFhZVpiV2hKaFFmWWIwYzFncWdTZXdnOWJTaEVnR2dSYU1lZGJuaFpmU2JRYmhlVmM0Z2RlaGhKYUxnR2hFaE5mWmZZY25hd2N4ZU5oQWF4Y0xoWWUxZ3BnMWFlY0VmdGIzYmVibWNsZlhhV2hSZUFjWmNhaEFndGZGYWJneGVFYlRkYmUwZmRjemVFZjBoZGVvZEZjUmR3Y1ljRGdrZU5mb2RKZ0VmUWMvaGFmbmdKY1JiZGExZWRiS2FGZW1jbGFoaEZiaGVoY21nRmVHY1pmbWdZZlhmQmVWZWJlMWhwZUhlSGVSZjFjVmJVaG5jUmNsYktmQ2F3ZlpkSmNrZU1nWWFXZHpjcGRrYlRiSGVaZjJiVWJrZEloVmFlYkhiWWFTYVNleGdoaERiV2NXY0pleWNjZEhlQmJJZVFhMGdsZWFhZGRYZmhoTGZkYTNiUWZvY0VheGYwZFljVGFTaEJmQ2NGaG1nRmdIY0FiR2dFZFZlUGNFZWNoTGZZZEFlUmFhaFdlVWRsYlJlSWdqZVpkZWhRYVNjSWQ3YUFibmhrY0JoWGRoYmdiN2NMZGtjSmhVY2JoZ2ZWZitnYmMyZmhnNWFmZzJnOWJhZVJieGYwYWRmVmVWZUpmMGZhZzNncGdqYVRlV2RwY0xkRGYxaElhUWRaZUVheGYyZGRnbGFKZkxiUGczZ2hoMmhFZ2tkc2VZY1FoMWRsY2lkY2JuYkJhd2NTaEVhTmZKYVdnbmRWZTRlU2EyZTFoNmRQZFJjOGVRYVFleGdjZzdjVGFnY0FicmRIZjFhQWJqY0NlRGUxYVdnVGUyYUViYmJDZFJoUWJEY0dnQ2ZwZDdlV2NqYzlkcWhjZmxnRmczYVZoMGhvZ1dkYWFXZEVhV2FHZUdiWWhVZFpibWdaZWhmSmJGYnNmdWRIZWdkTWhWaFhjbGNzZ1VjSmFpYlFkM2JEY1JlZ2FuZ0NmVWVvZEFkR2REaEFkRWNQZHliVmNjZUZjbGZvaHNiTmExZDRjMGhWYkFoWWhYZmFoM2R0Y3JkV2VrYmhlRGRTaFZjcGQxZGViRWF0ZDNlZWFtYWxjWGhXZ1JkQWZaaEllQWR0ZkloYmJ3Z1VlVGNjZVZocGR6YVhoRmd4ZENhUGUwZ2hnUWFSYnhkQmVtYWNlbGFZZFZkYWJuZUpmUmhkZTFlNWVnaEZhbWFsaGhjRmRoZmhjbWhGYkdhWmZtY1loWGZCYVZoYmYxZm9lQ2FOZHhoMWJWYVVibmZSZ3JoZWNtYk5jTmJhaGtic2NQZ1VlaGVCYWthVGNIaFpmcGVVaGdhRWViaFBhaWVSYWRoQmhuY29kS2dEY1RkRmI2YldobmZCZUlhUWUwZWxjYWJkaFhmaGVMY2RlM2JwZHBnVmcxY2tjUWVHYVdkZ2FMYlJlV2E4Y1JmR2R5YlpiSmRNZEZkc2hHaE9obmFZZkhlRmZBZUpjeGVNY25jb2FaYkZiV2hGZHlkUWdIYTVoWGJWY2dicGVwY2VlUmc4ZVllT2VoZFFkdmZhZUNoSWI0Y0ZiRGMwZjVnQ2hGZ2xkWWJOZkFoWmc4ZkpnSGJOY3ZkWmEyZnBhTGVEaDFoSWdRY1pkRWZ4ZzJmZGVsZUpiQ2NGY1hhaGIyZEVoa2dzYllhUWQxZWxiaWJlZmpjbGIrZUNjd2ZzZUlhQ2hCYllnM2REYnpnSWNiY1BlVmg4aFdhRWVCZEpib2hHZEVleGF2Z0RnUWU5aHZhWGUzYW9lVGRHZzJnaGdjY1JhaGJNZlBkVWJUYVFnUmdHaFZkRWh2Y0Vhd2hWZy9iR2JFZm9iZGFhZFhlTWhmaE1mbWdZYlVkWmVtY1phaGhjYUZoVmN2Z1dia2NjYWRjSGNWYVZkU2JkZUdldGE2ZlllMGRSZ0FiU2N3ZjljU2RFY0djUmNNYWRlbmRaaFNnUWNoZ1ZoNGZkZ2hlSmVMZ0dnRmVsZlpmSWRYZ3doMmZJY2dkY2FPZEtmeGRNYWhkS2YwYk5iZGhlYm1ibGRYYVdnUmJBZVpkYWVBYXRjRmViaHhmRWFUaGJnMGJkYXpmRWcwZmRmb2NGZ1VlaGFZY0RkbWNzZXBlY2RsYzBiVmhlaHdhOWFSY2FnMGZ0ZEtjRGVtZUJoaGNTZmhoZ2J2Y2JmeWZrZmJoYmRWYXBoVmJiZjFicGJIZ0hhUmcxZ1ZjVWJuYlJocmZlZW1hTmJOZWFna2hzaFBjVWhoaEJia2hUZEhmNGcvZUthUWgwZVZmY2YzZllnQmROY2hiaGRmYlJnV2FKZXFkZWhYY0FoVWdRYXdhQWZoZ09hbmNoZEFoZGcyZmdoVWRmZFZka2ZRZkdhV2FnY0xiUmZXaDhlUmNFZDJiOWZIYmNoeGROY0hhYWZCZFZjSWNVZEVmNGRjYlRhSGZKZldiRmhXZHBjeWVVYVhkZGZYYVNiaGNaYXBoWWNSZlljWWRaZWhnUWh5ZWFoQ2RBZTBkRWdXYmNjWmZTZFZhQmNJY0djUWRZZjllT2N6YVlnNmdSY1RjOWFDZUJlbGV4Y0NnS2Z4aGdlNmVmZGtmTmRWaEhkSGRZYTdhUmF3Y2RlTWhDY2dma2d1ZktoM2RnYzJnUWZVZzlhamdXaG5iVmE0ZVNlM2VkZjZhYWJWZGRjWmJFYkJhbGFvYUNhMGNWZXZnRWVSZHNlZ2JSYTNlZ2FPZVJiM2d3ZGNkVWMzYXBnSGVFZkdiWmJ5Y1ZnaGVWZXFhY2RsZUZkM2JWZzBicGJRZUpnamNNZldnRWVIZDBmVWVMaG1jWmMvYWNjQmNwZzBhV2NrYTRjM2VIYlZlVmJTZWRkR2Z0ZTZlWWYwaDFhcWVTZ3dmOWNTYUVkR2RRaFBmZWJEZkFoQWREZVZlZ2JhaFBkMGVZaFloRWRBZlphWmFmYVhhSWI1Y2ZjZ2hzYUxkQ2FBZmdmV2hOaHdmOGN5aEdlemIxY2ZkRmRoZXNmU2FZZFFmdGZmZGJnMWNoZm9hSWRFZnhhNGViZWtldGVvYkJnVWJGYWNjYmRSZEJnbWNjY2xkWWZWY2FibmNKZlJiZGcxYWRmS2FGZm1obGJoZ0ZiaGdnZXlhR2RpZmNlaWNKZVhlZ2hXY1ljUmNjZFNoVWNVZGtoY2JBYmphZ2Z5ZWNhaWE5YUViWWIwY1ZiZGJIaFVmUWZvaFJkR2dkYm5lV2MwaHhlWWFMaFRlcGhHZUFna2hnZVBjQWZHYm9kaGZlZVdkdGNpZ1FmMGJsZWFkZGRYZ2hmTGdkYTNjcGJwaFZlMWJrZVFmU2Z5ZjFlZmVFZkRnMWRmZkVnMmNkYXRnY2F4ZU5oSGZhY0JjVmNJZFVhRWZjZVFlWmJuZUpnV2dGaFdlcGc2Y0FjM2hkaEtmU2ZrY0pjbmdJaGxlcGJYZEtnRmJGZHVlYmEyZzhjamVIZVNjWWZjZEVjMmY5ZlViRWhoZm9lZ2VZaDJmdGUyZVJoR2hOZkhnSmhWY0lnUWNaZkVieGQyZWRmbGVKYkNmRmJYZWhhMmRFYmtlc2RZY0ZjMWdjZDZlUGRTZ0pmNGZHaGtmcGhIZUZkeWNBZjBmSGN6aDRocWhKYlFkNWhSZ1VlUmFCY2tnSWNVZVZndmJFYVJmTmh2Z1JlM2hNYlRhUmcyZWdmVmdTZ0ZiQmZIYUdiRGFSaHlhU2Z4ZFVlK2VmYUJnSWU3ZEdoQWFSZFRkWWRXZGdhWWFTZHliNWVkZ0lkRGVJY1RjT2FSZUllbmVEZmtmOGFNZkRkbGJ4aGJmZWFFaEZjNmFZZDBkMWhxZ1Nmd2Q5YlNjRWhHZFJoTWRkZG5jWmNTZVFna2FGZjJjTGZsZDBkWmZFZEJhRmJRZWJhRGY4ZGxmUGFCZndkS2ZHZFJkWWVzYWNkQmE1ZytoZGhrZ05lWGNXYVJhQWZaZmFkQWN0ZkZlYmd4aEVmVGViYzBjZGR6ZkVhMGY4YTZoRmVWYlZhUWNFZXhoNGFsY1BiaGRsYWJhTGczZXBkWWRlZVFkUWhDZ1hieWY4aDFjWmFGZUVlaGRYaERnSmZ1ZWNoR2VaY2NkWmRsYVpkdGNIZ1JoMWJWY1VlbmhSaHJoZWRtZU5nTmdhZmtkc2dQY1ViaGhBY3doUWFpZDRnNWhBZUVjcGFIaGNhWGVvZTRkU2N4YWhhRGhXZFdmSmJ5YWNhSGVCaEloUWcwZ2xnYWJkY1hhZ2NmZ1BmemhNYzZiV2ZSYkJhZWRVYkRnd2FEYkVhU2NkZFloUWZHZ0VmVWVOZmxjWWVEZFljUmhsYmlhVWdFaGNoUWhaZW5kSmhXaEZnV2ZwZXllVWZYY2RnWGRTZmhkWWU5ZlNneGVZYllhWmhoZFJlbWFaZW1nRmN3aFZhV2c5YWFhUmJ4Y1FiR2ZmZzFkSmUwZGFmM2dwYmplVGRXZnBnTGVEaDFnSmROYWJlVWhCZmNkZGhsaEpmQ2NGaFhnaGcyYUVia2FzaFljUWcxaEViMmZmY0RkVWNvZkdkQWR3Z2JnRGJpZlphNGFWYm5lY2UxaFliRWN4ZnpiRWZCYmxib2NDYzBkVmV2ZlRjQmYwY3NoQmZqZzliZmRUZHpib2JaZ1NnQmFsYlBnQWFHZjlhOGVOZkVhQWNzaE5nQmNRaGxjWGZrY01lTmdRZjJmRWhXZ0doR2RaZkpiYWFrZXhlaGhjYUZlVmZ2ZkhkQmJKZlRlWGVnZkVoYmdPZnllVmY2aGFieGZsZmpkU2UxYlJlNGZFZkdjUmVNZGRhbmJaZlNkRmdGY1FicWJkZ2toQmdRaE1oa2ZOY1piWWVuY0pjd2NjZUJmcGNEZ1ZmRmdwYjlnUGhoZDRlNWRPZlRjMGdlZ0ZkbGQ0ZVpkWWZBYkpiRmNOaERic2RUZ2JnMGNkZXpjRWUwZWRkb2RGY1Jlb2JWYkVhMGdVYjBmUGdGY1plQmNJY2poc2dDZmJmSGgxZUtkRmdtYmxhaGRGZGhlZ2c3Z0hjV2I1ZnZlZWNsY3BlVmRiZzFjcGJIYkhjUmgwYUJiQWdDZjFicmhJZlVhbGhOYmFia2NzYlBmVWVoZUJna2FUZkNjUmMyZlRoMGhKaEhkZWJDaHBhT2NTaDNhNGNXYUZieWFFZW1nT2dUZzhjR2dTZDBmc2ZJZk1kQ2N3Y2VjSmJUZFJicGNBZnhmRmhaZVNibWRvYkNoVGRXZFloUmFUYnpjTmNIZ2Vod2dKY0xnYWFGZkFmZWVFaFFmc2haaGJobmZBZENnWGhTZU1maGJVZjNoNWJNY1ljQmRaY3BmWWVSZlloWWZaYWtobGFtZkpnU2hBZmthRmFpZGRkYWdUZjFkUWNVY1ZjUWFsZGVkYWEzZXBnamNUZldhcGVMY0RiMWZJZ1NkS2R3ZTRhOGZNZHhlRWVXYkZhM2doZnJmRGcwZ3RiTWZHZmdia2duY1BnVGJaYXdoSGF3Y29iSGJIY2pmb2F2Z1NiM2RGYThlYWNWYzhoTGdFYkFoUmVvZlhhQWV3ZmhlVmdWZXdkNGNUZW1lZ2M1ZlJiMmZnZVZnU2NGZkJjSGhUY1VleGZ5ZVZmaGZWZHFhY2JsYkVkamFXZFFkOWFPZ09hU2U1ZEVhVGhEYlVnVWJlZzJoWWJ6YWFjM2E5Y3ZlV2drZmNjZGVRaEZmbGE0Y2RkR2d0ZzZiWWV3ZnNjL2dCaFVld2FHZldkU2ZzaENlZGFuYjRkR2FUZmhiVWFxZ2ZmeGdJaFFkTWFrZU5lWmRZZ25hSmR3YmNhRWJvYVdnR2RoZTliMWJLZ3hoOGRsYk1meWZvYURiV2h3ZHNjemFhYkFkdGZGZmJoeGdFY1RjS2FSZUloOWJVZEJmTWhoY1djZ2daZVFoRGVoZ2doeWFlZjFkWmdPZFFoSGNKZ1JnZGQxYWRjS2dGZ21obGNoZ1FhRmFrYzBiRmREZFJjbWdmZUhhQWNCZlloUmhZZENlVWYxZ29jQmdHY21lOWJCZ2VlbWFOZE5hYWRrZ3NoUGdVZGhlQWV0ZUNmbmVaYytmQWhFZ0liUWhlZEdjSWZTZVZkUmRoZVRmVWdFZWhneWdjZkhjQmNJYlFiMGRsZmFkZGRYY2hnTGZJYnphSWQ3ZUdnQWM0Y1FoVmZ5YTFlY2RSY1FhcGREaFFmU2NBYVZjZWh4ZEVldWFKYWtnTWdKZ0hjQWQ1aFVkWmFpZkVnQ2FSZHllTWg4Z0ZibmZsYVhkSmVsY01obmdKYWtlSmdRZFpobGVraHpjTmdUZFZld2ZGYXlkcGhhZkJlaGIxaFFkQWJCZDRmZ2FJYmlob2N2aENkR2FvY0VhU2FWY0loRWVaYmthVmR0YlhhRmJKaENjRmdYY2hnMmRFZWtnc2VZZkVhUmF3YjJjSmN5YUljK2ZTZ0VmRmNVYVdkSGdWYmxlVmNtY3BmNmZQYVNnd2JMZEVjQmdSYm9hR2JUZmhidmhEYmhnTmY5aFJiMmZrZlRhUmVYZVVlWGJTYUViMWRhZURhV2JZZW1iTGNVZ2RncWFmZDFmRmdtYktka2ZvZ0pnYWJYZ0FoV2FBaG1oWWNFZ2ZjVWJ4YWhlY2NGZFZndmFXaGtmZGFBZU5lMWZWZlNjZGFHZHRlNmhZZHdhc2YvZUJkVWh3ZEdjV2RTZXNjQ2dkYWpiTmhhYUZoaGJ4ZjRjTGhUZ2hhTGdHZkVnTmRaZFlhbmFKZHdnY2RCZG9kR2ZIaFFhOGhuZE5na2V0Zi9lYWdXY2xjZGVXaFVoUWJYYkpoRWI0Z0xkS2RFY1ZiYmVaYmtjZGc4ZkVkMWhOYm9jR2FFZWdmWmZUZzBjUmJ2Y2FhWGF3aFZoYWhuY0pjUmNkZzFhY2VYYlBhR2NsYWhkRmNoY2hnbWhGY0NmQWV6Z0xlemhNZEJhSmJoaFVlSmNIaFZnSmdkZkJnbmYxZ3JnSWJVaGxmTmRhZWtnc2hQY1VhaGZCYWtiVGdDYkFlM2RBZkVoSmJIYmRnRmh3Z1NmU2d4ZWhjRGRXYVdlSmN5Z2NhSGVCZUllQmRrYVZod2RkYVhjaGRMYmRoM2VwY3BkVmcxYWtiUWdHYVNnY2JIYWJoMmg4aFJhRWMyYTlhSGRjZ3hhTmJIZGFoQmRVZ0FlWGVHYjBnUWZaY25kSmRXZUZkV2RwZ3liVWVYaGRhWGRCZUJmcGZEY1lnUmZZZFliWmVoYlJibWZaZm1hRmF3YlZjVGV4YmFkV2doZzFoSmVXaHhoNGN4ZEpoVGcwZDNoQmhYYUZmaGNEYTFoSWRRZ1piRWV4ZzJlZGVsY0pnS2JYaFhoaGZyZkVjZ2dJZ1FlRmIxZkJhcmhmZW5hQmE0aEJha2ZOZFVoV2hqZ3NmOWNIZEhnY2Y4aFlnVmE5ZktnRWJCY05hb2ZXYUVneGJ2Z0hjaGROaDdmUmYzYjRnVGFEZzJhRWZjY1JjRmFCY1BmVmJXYVpidmZWZmxiMWJxYWJoRmRGaG5hVmcxZlVhV2FPY21mRWViZEdhSGdJYlVmZmNHaFlheWZlZVVoNWRGY1dla2FjZGRoSGZWZFZkU2VkZUdic2dzZElhaGE5aHFkQ2RnZDlnUGJFYkhjUmRYZ1hiSGZaYVNiUWZoaFZiNGJkZmhmSmVMZVhnZ2R3YUxiWWVuZW9haWFjY0ZnVmFEZVdiVWVGYTFjUGFVYnRmcGFlZ2pjdGdNZFdjVWZJYlplWWd4YVpmRmRlZXhjZ2c1aGJoMGZkYnpiRWgwY2Rhb2RGYlVjaGVRaFJleGVnYXBoY2hrZXNmL2hhZG5hSmdSaGRhMWNkY0tmRmVtYmxiaGFGYmhlaGFtYkhoRGFNZ2RiTmdYZDRhV2hKZHhmc2NWZGZnbGhJZVJoRmV4aFVlL2JjY2pkRmRFZkZhMGdzZlRkVGZoZUJhMWdWZ0hlOWgyYURkbWNnZFZkZWhIZ1loU2JTZXhiaGdEYldnV2NKZXloY2ZIZ0JnQWdGY2pnSWdPaGVmemhzZERjTmFpY2dnS2NHaEJjMWhWYWVoRGN3Z0RnRmIyZThhYWRFZzNlNWZPZURkaGROZWJjZGZCYVZhWmhRYmtjNGRRaE9hbGNoZldoRmhXZXBneWRVY1hkZGRYYVNiaGRaYXBmWWJSZVlmUWJNZDJlOGN5YWFnQ2hJZjRjRmREZzBnNWRDZUZhbGRZZU5lQWNaZDhnT2FYY3Bhb2hUZlhnaGZDZGNlbGhJaE1hZWFFZXhjZ2hmZTFhSWZlaFBhM2VoZDJiRWdrYXNmWWJRZDFmbGdpZmNobmhCY3dhU2dCYVloeWVEZm5hc2M3ZkFnemhZaG9mQ2ZoZGdkZGRWYVhkZ2U4ZUFieGZkYXZhR2NoaE5oOGJUaGdjNGVhZ1NoMGNJZFZkU2FGYUJhSGRFYkdoWmZ5ZlZkaGZWYXFmY2VsZEZmL2NHYVRnRmhYYVljbWRwY3JhR2dIYnNjVWhiZWlkbGZoaGJla2V0ZXZhU2QxYkVkVWZIZlZlTmRTZlpibmM1Z3ZlYWVrZEZhQWdTZ3doOWdTZ0VjR2FSYk1lZGhuZlpmU2VRZ2hkVmU0aGZnbGF3YndoV2RVZmhkU2hIZjNmSmd0Y2NjRWVBYk1hU2ZVYVJncmVlZ0ZoTmcrZGVobWE5aFhhU2V3YVVoTWdZZVFiZGh2ZmJkeGNFaFRlYmYwYmRiemdFYjBjZGFvaEZnVWRoZVFjVGQxZTRlZGZNYTFoMGhlZkZiM2hKZ01iZGMwZFZlZmFBZzJnbGduZEZobGVkYnZkRGQwYXhkbWJZZFhhQmRWZWJlMWJwYkhkSGZVYThjUWFCZmliRWE1Yk5iR2ROZUZnUWhFaHNlUGRVZ2hkQmZrZlRmSGdaZjJlVWNraElmSGRlY0dkc2JQYVZmaGFnYkxkY2QyZUpjeWJjYkhmQmNJYlFmMGdsaGFjZGRYaGhhTGJkYTJiVmZwaFhiMWVGZmZjR2ZYZlViTGNUYlRhcGRxYVJhMmJFY0VjT2MxaEllVmRDYzFkb2JNaEZkU2VaYkVlYmdpZUJlZmRhYkdhcGN1Z1RiWGVkY0ZhUWF4ZlliMWJZZ1JiNWZOYkhoVWdCY29jSmdTY2theGNCZHdhd2JWZkFjMWJoZzhnQWRWZW9mbWNhYzNhRmZqZlhnR2dNYTJkRGUwZXdiT2VaYkZnaGcvZmZnMWY1ZG9jRmNYZmhmMmRFZmtmc2VZYlFhMWFsaGlhY2ZuYUJid2dTYUVjTmVCaEZoQWg0YzVlUWRIaHdiSGVhYVVmcGNaYUFjZ2F4ZzliQ2gwYU5jdmhYY2hocGVtaGJkWGJNZFRmUmUyaGdlVmRTZEZiQmNIY0VmR2VaY3ljVmFnZjllcWFZYTFhRmNxZ1NlbGRjYVdnSWRXZ0VkUWFIZmtod2RVaFpjbWNaZGhkY2ZGZlZldmRXZGtkY2FkZUhkVmVWaFNmZGVHYU5meWZMaEViMWYzYllnUWY5Y1NkRWVHaFJoTWdkaG5iWmFTYVFkaGVWYTRkZGFoZUplTGZHY0VlTmdSaE5md2FrYmtmZmRnZHNlTGNDYUFlZ2hXZ05nd2U4Z3lmR2Z6ZTFhZmVDYnhobGNrYmFoQmNkZVpiYmh3ZkFmRGVaYWthY2V2Yk9nVWJkZ29mRmVVZ2hlUWNSZHhoQmJtYWNmbGNZZVZnYWVuZUpmUmZkZTFkZGhDZlFmeGFJaDFkR2hGZ3NmdWVWYVRmUWRGZExjamdRZFFlRGFnYTViUGdUZnhlMWRlYlVibWRWZWlnQmIyZU5nUmZkZWtoc2ViZldieGRBYTRmWmduZVpnMmRVZ2tnSWZWZWVmSGZZaFNiU2F4Z2hhRGVXZFdhSmd5YmNhSGJCYkFlRmVqY0loT2RlZ3pkc2hEaE5maWdnZktnR2RCZDFoVmZlZkRkd2hEaEZlMmM4ZWFkRWYzYTFoT2dEZWhkTmJaYmRkaGNWZ2FnV2dVZzRhY2dUY0hmSmhXYUZoV2dwYXliVWNYZ2RjWGVTYmhlWmhwaFllUmVZZVljYmVsaG9hZGFKYzJicGc3ZUtnR2c5ZEhkUmJ4YVZiU2FWYVVjeGFxZWFiMmVKYXFkVGFXYnhnTGFIY1VjY2dGZmJmVWFCZmNmZGRsYkphQ2RGZlhoaGgyZEVma2ZzYVloUWExYWxkaWJjYW5nQmg0Z0JnamFnZ0loVWdYYzRnRmVTZDJhcGQ2ZmVnMGVKZE1hRWJCYjllb2FSZUVmeGNtYUhmVGdsaHZnUmczZE1kVGJSYjJmZ2JWZFNmRmdCYUhoWGRrZ3hieWdWZGhnVmFxYWNnbGJGaDNoVmUwY01nTmFRYjJoRWhXZUdkR2JZZlVoWmFqZnRmTGNjY0ZoVmF2YVdna2JjYWRjV2V3ZEFkY2FOZXpoOGR6ZUxiQWNOZnFjQWR3ZWNnR2RHaFdhUWdYZVhiSGZaY1NiUWFoZFZmNGZkZ2hoSmNMaFNnZ2JZYU5kTmN5Z0FkK2hjYUVkQmdwZFNjVmFwZTFkZWhFZ3RiM2NlY21hbGNYYVdhVmJGYWljWWZGZDloRmJjZFFhOGJUZ2ZobGg5YTZnRWIwYUZjb2dBZjFhc2N0Y1JjeGd0aG1nTWJ5ZjBnZGRQZm5kSmdQZmFnVmZkYmJlQmFHZEJnaGFFZEJjaGJ3YkJoeGJ0ZG1jYWNuZ0FjVWFGZEZmSWZUZ0hmUWNOZExmVWdtY0pkaWRlY21oVmVOZ2ZiRmRoZHlhVWhoZnRia2ZEZVFmMWNnaFFnVWVJYVRoZWVDZEpldmNZZVJhaGNEaFdoV2hKYnlnY2hIZEJmSWJTaGxkSmV3ZGRlWGNoYkxhZGYzZHBncGhDZG5jTWFRYkdmV2dnZkxkUmJXZDlmWGJSZWlkRWVFZ0pnMWhvY0llSmJoZ1ViR2dXaEJmTWFjZ1plaWFCZ2FlRmhTY05jN2VVaFNjeGM5YVNiaGVaYnBmWWRSY1loWWFaZWhjUWdnY0tjVGJOY3dhWGVUZmtmYmVGYVJjMWVZZFdlVmFJYTdlYWMyZWRiamROYmhjZGhIZ0RoeGR3ZFFnZWJVYXdka2ViaFZhSWVMYUZmV2FaYjJlWGVGZEFkWWNEY1ZjbGhwYmJlM2ZCZWpiUWFXY2xlSmFXZm5mVmc0ZVNhM2dkZTZoYWFWaGRhWmVHZ0ZmeGFvZEZia2JWY25oUmVXYWdhaGJPYW5kTWZQaFdhMmZnaEVhWGJsY2xlSGFHYjJkWmE2ZUFhbWM0Y2toY2hsY3BnM2NSaGpjY2NXZWRlWGcwY1doQWdHYThoVWZiZVdmWWMxYkNoeGN0YnZnVWFVZGNiUGdZZUZmeGNlZmRkQ2dSYzBlTWd4ZmdjNWRBZHdjY2FhZ0dhQ2NGZkZhZmYyaDFhNGdRZGhhVmE0ZmRoaGJKYkxnR2hFY01lTGNKZXljWWNsYklkZ2JaZERjQmRsZVFiL2ZOZXdmSWQ1aGNnbWh0ZVZiVWNBYXNoemZhaEFkdGZGY2JkeGZFZVRnTWRtaDFmemNFYTBkZGFvYkZhVWRnZ1dlRWVsZjRmbGVKYWhmOWJhZ0phSGFJYkNoZmh3ZU5kRGdGYmpjSmNMaEZhaGhoZW1lRmhHZVpnbWRZYlhjQWZUYklkQWNoaEhjRmNUaGRkVmFVYW5jUmZyZmVobWROZ05lYWJrYnNmUGJCZkZjRWMyZlRkQ2FSZjZjZWhFYklkVmdlYkhlWWZTZFNoeGhoY0RnV2JXYkpneWVjYURlbGVJYlhja2RrYk9lZWV6ZlFjT2ZPZVRkMGg5ZkhjMWJVZzZhR2dXZWdhTGdSZldoOGFSZUViMmY5Y0hhY2J4Z05jSGVMYVJnVmNWaFVhQWU0YlFlWWczYUplRmZHaFVlQmN5ZVVmWGZkYVhnU2JoZFpncGdZZ1JnWWJZZFpoaGdRYnBnWmZuZHhod2JWZTJhMWVXaGJkUmQwY2RiVmNWaEplMGVhZjNkcGdqZVRkV2FwZUxjRGJ4ZW9nUWdlZlVid2NOZkNhMWg1Y29oRmVYY2hjMmVFZmtnc2RZaFFkMWVsZGlmY2JuZ0Jhd2RHYjBlTmNVaFdlbWZSZ3VlV2JHZTljcGdaYVhlMWRaYUVhQmdsZm9oQ2cwZ1ZldmNFZlJmTmN2aFJhM2FOZEdhUmgzZFVkVmJXaEZkeGR0aEVkR2JaZHlmVmNoZlZocWZjZGxhRmEzZVZjMGNvYldiTGgyZ0VmTGdHZUNjOGdVYWFoMmdZZ2tiYWUzYjlndmJXY2tkY2NkYUhlVmVWZFNhZGFHYXRhNmVKYVVjMWcwZFNhMWFwYUpoT2VtYlJhTWdkZG5jWmVTYVFoaGZWZzRiZGFoYklkZWdHZUVmaGZFYVloaWdGZWFnY2dFaGhhRGJTY1ZjcGgxZWVjRWN0YStoVWVHZGxmWGdXaFJmQWNaZWFkQWN0ZkZnYmZ4YUZmYmJZYVJjY2FtZ1FlQWQ5Y2dnV2MwZEFjRWVTZnhjQWR6ZmZkbGNaaEFoYWFuY2xoUmRKZUZnZGdVaEZlaWQ5YmhhQ2ZSZWdiZ2dGYUhleGZtZ05jSGNCZ2VjYmF3ZGxkT2VGaEFkWmIvY1VkbmNSZ3JmZWVtZk5nTmFhY2tidGZkZUZiMGJRY3hiSGdqZmhnMmVXZG1kZ2RWaGVnSGVZYVNoU2R4Z2hlRGNXZFdoSmR5YllkWGVCaFZjWGhsY1JhYWdNYkZkSmJMZ2RmM2RwYXBiVmMxZGtmUWRHZldlZ2VMY1JlV2U4Z09mRWQyZGRkUGdJYlJjTmdhZGFjRWhFaHpnR2RVYWNmZGhaaG1hTWRyZ0hoR2RaYVljVWhYaGRnWGZTY2hoWmJwZllhUmdZZVlmWmdoYlJobWJaZW1lRmM0Z0dmbWE5ZVJlV2VoaDFoY2NMYWdmQmEwaGRhV2VSYWpiWGN4ZmRnQ2VBYjNiZ2ZRY1piRWV4YjJiZGdsYkpoQ2dGY1hnaGcyZkVla2JzZllhUWExaEVkdGFjZW5hdGd0ZlNjQWJJZ3llVWVpYWRoNGhWZjJhdGE2ZGZoVmI1ZVphRmVoaGxmK2VHZURlaGJtZUhiVGdsaHZkUmQzZU1nVGZSZTJhZ2VWYlNoRmFCZUhnRWFHYVpmeWZWYWhjMGVsZGNibGRwZ3FkVmEwYmdnTGNkZkdmTWZmYUVlVWh3YVVkWmRtZ1piaGNjaEZiVmh2ZVdoa2djYWRiSGRWZVZoSWZkZkhobGU2ZGZobGJCZDNhU2QwY3BiU2hGZG1kSmVtZGRkbmdaYlNnUWFoZFZlNGdkZGhhSmFMaEdiRWJOYVpnWWNuZEplNGNlY0JncGFEaFZmRmFwZjlkTGJEZUFhK2RlZW1oUmRYaFNlMmgwZFpnZGJCaGRjRmdkY3hmZ2hUZlpiRWZjZ25iYWhBZDVjb2RHY0VjaGFCY09laGZsZXFhV2VGY1llVmZhY25jSmdSaGRjMWRkZ0tiRmRtZmxoaGNGYmhmaGhtaEhkQ2VsZ21kYWRtYjFoVmNMZmlkRWdWZkhoUWFOaExmVWFtYVZkN2ZCYTJhcGFCZVFlRWFzYlBiVWFoZEJma2VUZEhhWmYyaFVla2ZJZ1ZlZWdIYlllU2RRYTFlZGVEZVVkbmU5ZnlhTWVRZ3RnQWRFZFVjbGNFZGFlM2NoZmZiZmNuZnBmdmRWZTBkOGZEaFphR2RFYkhmYmUyZjhmUmVFYTJmOWhIaGNieGZOaEhlYWFCZlZhSWJVZkVnY2JRaGJmamcxZldmSGFuYmRjeWJFYkFjeGZmY0dmQmVaYjFnZmNSYVlmS2JiaHhmUmRnZlpnbmhkZGpkS2JHZlphV2hiZ1JkMGFkZVZiVmZKZDBiYWYzZnBoamJUY1dmcGZMZURiMWdJZVFlYmZBZU5iMmFmZ1ViOWJDZkZmMmNWYjBhR2cwYkliVWRhZFZobGVpY2NnbmZCZXdiU2VFYk5kSmVXZ25kVWF3YlJmU2FjZnZnT2ZoZjlmUmZYZnhoQmdrYUllVWFWZnZmRWdSZE5jdmdSYjNlTWhUYlJmMmZoZ2RnUmRoZW9jSWhXaFNmaGM2ZlZmQmhkYWpoV2RGaEZlM2hWZDBlb2VXY2FhV2RFY1dkRWVYaDBlK2haaG1mWmVoYWNkRmRWY3ZiQmcyZjBlZGZIaFZmVmFTY2RoR2Z0Z3llTWZVYU1mb2VFYmxoc2VYZmZmQ2NFYUNoTWdTY0liYWdRYWdhaGc0ZE1jeGF0Y0hhR2NFZnNkTGRiaENjWWgvY0VlaGRFZVhoRGZEY3NlbmFLaGdkb2h1ZGVhbmRSZVhlRmFoZmtjVmdhZUFiTWZYYVliVmNkY0JkSWRBaG9mUmhTY2hjTWN0ZGRoQmVvZENlQmhrZGxlbWhiaDFnWmZHYVlhMmhsZjdoZGIxZGRlS2VGYm1hbGhoZlVhRmFjZzBiRmdHZTVmTWFZZVhlQmVWYWJoMWhwYUhjSGdSZTBoRGVFY3lhWmVyZ09mMmVOZlFnYWhqYkJkeWRYZ2pjcGdrY1RjSGNaYzJiVWRraEllVmhlaEhoWWRTZ0hlaGNoYWVnV2dSZmtkUGdmYkZocGZJY1FmMGZsZGFjZGhYZ2hiTGVkZjNhcGZwZEVlVmdrZE5oR2dXZXBjZWZDY3ljdGNVZVZkU2JZZEplTmZsZmRhRmNhZEJoUmFWY1VoQmZOZkphTmhqY2NiWmJVYjJlb2NIZEdjRGFrZkRkVWhuZ2NiN2FNZTFiZGVCY1pjZ2R0aG1mRWJ5YWdmK2JBZ1hhY2c3ZEZhVWE5Z2NnRGhGZEpmdWhhZXhmc2R4Y0hmeWRzYlNmQWUzZWdlUWVaYkVjeGQyZmRibGNKaENiRmdYZGhhMmRYZmtoc2JGYWFlVmNsaGlkY2RuZ0Jkd2RTZkVjTmVKZldibmNWZDRoU2IzZ1VlYmNDZXphUWY5Y2RoWGI4YVBnWWV5YXdoRmRlZW5mOGNDZ0toUmh4aGphTmdoY3BjbWZQZENiVWh4Z1pkeGQ0ZExoTGRGaFFkb2JNZlJoVWZ5YUVoUWYxZ2VmSWVDZXRnZGVWaENodGRhaEtiVGNZZHdlSWNnZ1lnN2FEZXhmRmRLZlJlUWJ3ZUlnWmdIZXBib2RjZ0ZhbGcvZlhmUmRoaEthQ2RXZzljRGhkZkhncGc0YVFoaGhWaDRjZGFoYUplTGZHZEViTmdaZFlnamJGaHdiYmNVYmhmVGdSZ1hmQmQxYmVmRWJ0YjNjZWZtaGxhWGZXZ1JnQWNaYU9kQWZ0Z1lnYmExZzBnZGVJYndlSWE5ZlZkQmNNYWdiRGJtZ0phUWZSZnhiQmRtY2NlbGRZYlZmYWZpZ0poUmdhaFZlY2NKZURnVWFOZ2hmRmhoZWhibWhGZEdiWmRtZFloWGV0YmVjTGFIYUJhSGhIZVJkMWRWaFVhbmhSZ2ljVWhHY05kTmNhZGtmc2JQYVVkaGVCZGtlUmdEZWNkTmdFYVRkOGFWZ1pmWGJaaGVnTWZGZnNhK2FVZUdnNWZ5Y2VhQ2JVaHpkRGEwZmNkWmZQYVRla2ZaaEZmRGNVZXRiRWFqZmhoRWdFZlNjc2FDZE9nR2I4Zk1oRWd5YnhmT2VhZERibGdIZmFlQmVWaElhVWhFZWNoWWdNZXdobGdVZUdoR2RoYjhnRWNqZDhjV2JHY0hlVWNtZ0pkVmNOYjVhTWJoYnhmMmNiYnhoeGJ3YVNnR2Y5ZE1nVmJSYlFhUmRWZFZnb2hoY0VmSGVnZmNnVGMyaFFlSWNSZXhoTmhDaEJld2ZNZXlkTWF6Y01nV2NIZFdjaGcvZ2JjMGVzZEZlUWcwYzljeGFlZzJidGdhZlNmRWFOYkphV2ZpYmhhMGJZYlhlZGg2YmFnVmVjZmZkUmVWYmNicmdYZndmd2VnZFhieGROZm5lRWYzZjhnVGdGZVdkRWNWY0ViM2RwYkhnRWRHZFpieWRWY2hmVmFpYUlhRmU4Z2xiRWhnYnRhU2JhZFhod2NXZ1hnamFOZWFhSmFUZUlib2dQYnhkdGR2Z1VkaGZNaFJiSGRRZmRhZWVkZENiSmUyZVlnd2FoZG1hU2UwY0JlYmFFZ0RkOWdtZmRibmdaZ1NoUWRoZFZnNGVkYWhmSWVkaFdnUmhGYlpiS2ZuZjVmYWFjZ0VmaGhEY1NnVmdwZjFkZWFFY3RkM2ZlaGloZGNiYWNheGFBYVpoYWFBZ3RiRmRiZ3hhRWRUYWJlMGdjY2dnRWQxaHBhb2REZFVmaGZhaFJlMWE5ZG1iZmMxYlpnUWRhZ25iOWFSY1pjbGV0ZGdlRmdtY2xlaGVGZmhjaGVtaEZnR2daY21iWWdUZkZhVmZjZ2xhcGFQYURmQmUxZEplVGVuaFFiNGdjZTJjTmJBZmFkbGdvY0RnZWRCYkJma2dUZUhnWmQyZ1Via2FJZFZkZWhIYlpmSGdTZ3dmVmZEYUdoR2hKZnNlYmJuZ0JkWmZUZjJnTmFhZmRjWGRoZExmZGgzZ3BjcGZWZTFoa2JRZFhmMmJnY1dmUmJXZklhR2ZIZjBmVmJIZGNieGZOZ0hjYWRCY1ZkSWJVZEVhY2dRYktmbmFKZ0xlRmNTY05ieWdUZG5hY2NZYlNiaGN0Z3BnY2ZCY1lnQ2haZWdlUmVxYlRlR2VGZndjVmRXYTlkYWNSY3hjMGRkY1ZiVmNJZDNnYWUyaGRlamJCaEdocGFVZURoMWU4ZEJjWmRGZ1poMmZaZTFiNWFvY0ZmWGJoYjJjRWFrZHNiWWNRYTFnbGNpZmNmaWZCZXdjVmRVYU1oZGFJZ1NiZGg0ZVFmSGVjZjJnRmdFYXhmemNFZEJjbGhvZENnMGhWZnZkRWZSYU1lcGdDZENmRWdUZlRlMGZJY1ZkU2ZGYUJnSGJFY0diWmN5ZVZjaGVWZnFkUGJsaEZmOGhTY2tncGdWZlpiV2RGY2ViR2hIZXNlVWVOZW1kWmRuZmNiRmExZm5nU2IwZWNmQmRBZlZoVmVmaE1kbWZKZDZjYmdrZTFiN2ZRZWdlTmNTZFFnR2FSZFNjYWhHZHRiU2NUaDFnTmMwaGRhbGVSZUxlRWYxZzViWmdNZ1dhbGNhZ2NkRWJoY0RmU2NWYnBhMWdlZ0VjdGEzaGVnaWg5YlhjUmZ4ZUFkSmFjZ3lhRmdGZGJmeGZFYlRkYmUwaGRlemdFZzBjZGZvZVhmVWdoYU5jUmR3Y0pjemhaY0ZiWWRmYWFiamZwZ1JmZmhGY2NjZWViYlRjdGJoYUhnUmZnZnFkYWZXY3BibWFMY1hiQmNlY2NibGhvY0VoRWRSaDBhVGVVZG5lbGQyY2VobmJ0Ym5nYWdraHNiUGRVY2hhQmdrY1RnSGNaYi9kU2hXYmdkVmNlYkhoWWJTZ1NleGFoY0RiV2ZTYVFlOWVJZm5nQmJBZWFlVWRsaGFhZGRYYmhlTGZkYTNmcGVwZFZoMWNsZWVmR2FYYVVhTGdEY1dhOGhYaEViMmRkY1BkWWFoZ05oYmRkZ0JoVmFGZEZoa2Q0YVFlYWgzZkpmSGRIZkdjWmR5YkdkWGVkY0pkVmFBZHRjcGNiZkZhQWVVYVpibGVKYm1hYmJYYXhjd2NFZUhiUmh3ZFJoeGMwZGRiVmFWZUpnMGFhZDNhcGhqaFRnU2d4ZExlRWhWYUlhQWFmYzJiWmcyaGRmbGJKYkNiRmFYaGhlMmZFY2tmc2FZZkRoVmdsYS9nY2JtZEpobGZYZmthTmdEY1doamd0ZTRhUWhIZGNhdWVFZGdlVmNaZ0dieGdrZmtoZGhrZWxldmVYZFJjTmZrZFdkbmFOZFFoU2UyZWhhVGFTaEZlMWVhZ0VmSGU1YVlnVmNoY1ZncWFjZ2xoRmQzZ1ZkMGdvZ2ZnY2VrY3NjV2RHZkdoWWVVaFpnbWFaZWhhY2NCYndocGdXZ2tkOGNOaEhhVWFoZVBkYWVXYnNoeWZhZGthMGhpZ1NheGhKYlNkQWRXZFJhQmZkZWlkTmFKZGFnQmFWaDRoZGFoZ0phTGNHaEVjTmNaZ0phemY0YWpiTmJVZ2dkWWZZZzFmcGYxZ2VjRWZ0ZDNmZWNtYmxoWGRXYlJmQmRRZUxmZ2J0YU5mSmF4ZkViT2FjZmxjcGh6ZFVja2g1ZG9iUmZ3ZjBhRWNFY2tlSWJvYmNnaGVnYVZjZGhYZEplQmZkYzFiaGJLZ0JnbWRsZjdiRmJoYUFlMmFGY0hlbGhtZGJlR2dGZFZnZGZWaHBlV2JGZ0JjMWRmYVVjbmN4YzZjZWVtaHhlTmdlZWtoSWVVYmVmQmZCY2tlVGNIYVplMmdVZGthSWNWZWVjSGVZZmFnQmZSZWhmSWdSY0dlSWdmZU1nU2ZRYUFnVGdSYmtnVmRJYW5kQmZaY2VlM2hvZXNlWGdsY0FkY2RHaFdkQmREZVJmV2RJZk1lRWV6Y3BlT2FhYURlbGJIYmFlQmRWaElkVWVFYmNoUWZaZ2llOWg4Y0ZhV2VwZnlkVWVYZmRkWGhTaGhiWWQ3YkpiRWJKZU5jTmFGYnBlbWZiZ2phRmZ3Z1NhbWQ5ZVhhVmhoZDBjSGhWZ1VlTmg5aGFnM2hCZGpoQWIyaHBjQmZEYXpmOWFSZk1kQWdSZDRoSmVoYTBjVmZIY1dncGU2aEVhZ2VNZFliVGVsaGthbmVlYjJldGNhaFNkRWFOYkphV2huYVZjNGdGYW5hNWgyYlFkMWdkZVpiRWRCYmxkb2JDaDBhVmF2YUdnVWNGZmhkRWZDZ0ZkYWhFYnlmMGZWZVZkVmJBYkJhUmJTYWdheGhBZWxhd2ZsYlBkRmZGYi9kQWYwY1ljV2ZPZTJnMGhXaFVhV2JvZFVkSWEyYnBoaGZQZzFobGN2aEVna2Q0YmRhUmRuZzlnU2VkYUdkdGc2ZVloMGExZnFjU2R3YzlnU2FSYmlmVWdlYmRlamNoZ2VlYWJCaFZoNGVkYWhkSmRMZUdkRWZOYVplWWhuaEpid2JjZUJndGNQY1llMWFwYjFlZWJFaHRkM2VlYW1kbGZYZVdnUmVBYlpjYWFFY3BhSmRSYlJjRWhUZ2JkMGhkYXpoRWcwY2Rmb2ZGYVVlaGFRYVJlMGFWYW1nYmUxZlllTmVhaG5oaGFSZ1BiMWJkZEhiRmdpZFpnaGhHY3hlaGczYkdjRWF4Z21jWWhYaEJoVmdiZzFncGhIZ0hnUmcxZFZoVWVuYVFldGhlZ25lNWdOYVlobGNvaFBlVGhnaHhna2hHZFhjOWMyZFhmMGNJY0VkZGFGZHdhU2RTaHhnaGVEY1dlV2FKYnlnY2RIaEJmSWZRZDBja2FXZmRnV2ZWZUxkTWNYY3BoM2NTaFZoa2JCY0ZoVWFJZkxlUmZXZzhoUmVFZzJjOWRIZGNieGhOZ0hnYWRCaFVoTGJVYUZob2VRaGRkR2hGYldmQ2NIZmRodmNVaFRhaGNYYVZkUmZZaEVkSWdFZkpiUWJhYkVjUWVwYU1kV2VsYWlhV2NXYTlnWGJWZVFka2NVZlZmVmQ5YjBkQmVqYnNnM2FCZldlUWJiYlFjQWZVYlljZGRrZUJoMmFlYzBoVmJWYUhjSGRoYnNhRWZsZnNoVWJhZ1ZmbGRpYWNlbmRCZndiU2NFZE5nSmFXYW5hVmI0ZVNieWZkZjZiZGNGZWNjY2NFZUFmWmNvY0dhMGNWYTFjRWVWYnRhdmhTZ25nTWZDZFNmMGZJZlZnU2VGYUJlSGVFZ0diWmV5ZVZiaGdWY3FmY2NsY0VnNmhWaDFnY2VXY0xhR2NFYkpiR2JIaGNlVWhmZ0dmWmNzY1lhVmZsaEZoV2NrZmNhZGNIZlZoVmhTZmRiR2V0aDZnWWQwZTFmcWJFZ2doOWNQZEVjSGhSaE1nYWZIaFliQWdRZ2tha2VrZWRkaGNwZ2JhR2dGYTVkRWhmZzNoSWVpY2NnRWU1aEZmU2RVZXBkMWRaZGtkdGJtZGVibWhaZ1hlQ2N4YmthWmJkZndndGdVYWJkd2hzZlRjZmgxYXhlWmhFZjBkZGFvZ0ZkVWJoaFFkUmV4ZUJibWRjYmhnQmdhaE9lSGRKZlpiWGNWYWRnS2hGYW1jbGZoZEZmaGFoZG1lRmVHYVpobWFZZlNjSmdWY2NjbGNvaHFmWGVFY2toZGJYYURiVWdwZUtoV2RzZ2ZoWWYwZGNmbGNVYmhoQmVrZlRkSGRaZzJoVWRrZkliVmhlZUhjWWdTZFNjeGJnZktoQ2VnZ3dlemRIZ25nZ2VhY1Nma2VrZ0diS2NYZWdjWmZkZjJhZGIwZlNibGRrZUJjR2RXZmNiTGVWZVVmVWJSY0VjMmM5ZUhkY2Z4Y05iSGRhYUJiVmNJZVVnRWJjYlFmWmRuZUphV2FDZ21icGY2Y1dmU2NSYlhmVmV4ZFlhZ2NNZW5kaGJaZENhQmh3ZTBiYmQyZUZkdmFWZFhlNWJhY1hjUmgwZU5lWGJGYzVjMGNZY3plUmhqZVVhR2JvYk5lQmdsYXNhNmhaYUVieGEyZmRnbGVKZENmRmVYY2hoMmVFZ2toc2VZZlFnMWZsYWlkY2htaHBid2FRZ0Voc2NIaFdhbWJoZTRhSmFqZVlldWdJZ1Zna2VmZlhnRmNZaG5hV2dVZTBmQ2NVZ0VmY2ZuYVNiVGY5ZGNlQWJHZ0JmSGVRY1ZnQmdJZkVmQWVzZHpmQWZsZzFma2NIZWpiOWVsYlhma2hNaGFiUWcyZ0VhV2FHZEdoWWVVZFpmbWhaZGhkY2VGaFZjdmdXZWtlY2dkYUhjVmFWaFNnZGVEYWxkNmJhaFVlMWNpZENmZ2Y5ZFBiRWVBZ2tiTmdJZ2pnNWJjYUVlbGZvZnZlZmhnY0JnSGVHYUVnNGNYYmFlM2R0YndoYmZFYmhhU2JTY1ZmeGd6YmVoRWZNZzVjZGMyZlJlYmdXZFJmaGNZaGFoQWRGZFlmYmd3Y01jYWNaZmtjdGZaYkVjMGFkZm9kRmhVZ2hkUWNSZHhkQmJtaGNhbGNZYlZoYWZuZEpnUmhkZDFoZGZLYUhkamR0ZGhiSGNRaFZlbWJXYm1oWmV0ZFllVGZ4Y1ZoY2VVZWRjSGdEYkJoMWRLZFVnamNkY3JoZGdXZk1kTWFhaGxiRWVQYUVlUmhCZnViVGdCYnNiM2ZCYmdjb2JiZktlRGVsZ0ZnUWN3ZXBjUGNXZVhoTmR5Z2ZkWGhBZ0VnU2hrZEJmV2FYZjNkaGJMYWRjM2hwYnBlVmMxY2tlUWVHZldjZ2hMY1JlV2M4aFJoRWIyYzllSGFjZzBhRmNIY1lnaGJVZ0pkVWFGY2tkTmNaZW1nQmdXYUVnMmh4ZHljV2JUY2xhY2ZRYlJlcGRwaGFoVmdjZFloYWdRZWxnbWhkY0dlaGI1Y1dnVWdWZmFjUmR4aDBjZGhWZ1ZkSmQwYmFoM2JwaGpkVGdXY3BiTGdEZjFlSWFRZ1phRWV3ZjRjZGZsaGxhQ2dXZ1hoaGNvZERoMGZ0YWVlYWZWYWxoaWdjYm5mQmR3Z1NmRWNOYkphV2FuZlZhNGJTZzNhZGI2Y2FhVmNkZlpmRWJCZmxob2JGYUVmVmJuYkdjVWFCZHZmV2VuaE1nRGRUZW1hUWJWZ1FoQmM1aEhjRGdXaFlnMGJYZ3hieGZBYWNjbGNGaDNmVmIwZ29iV2ZhZVdiRWhXY0dlR2NZZ1VnWmRtaFpiaGNjaEZiVmV2aFdja2NjZUhlSGNSZnRiU2dmYjJkc2EyYlloMWZOZTNlU2N4aDVjNGVFYUdmUmVNZ2RibmRaZVNkUWFoZVZiNGhkZWhnSmdMZEdnRWdOZlphWWRuZEpjd2hjaEVlaGNjYlNmVmNKZjloS2UwZnRmcWZlYW1kRWJGaFdjUmNvYlpkS2JRZXRkSWRiYndnQWNhaGJhMGQxZnpnZmFnYVlmOGRYZ1VhWWFBZkNnRWNkYXVoWWZGYW9oVmhKZVhkdGJZZGViMWJkZ0NhV2FHaGxlcWRDZHhkZ2RxZ0hmV2Q5YU1nWWNYZUJlVmhiZTFkcGJIZEhoUmcxY1ZjVWZuZ1JocmFlaG1nTmZOZmFna2FzZFBhVWRoYUJhK2VUZEhiNWUrZ0FoVWhJZkloZWNDYlFjU2dRYVJmZ2R1Y0dmRGdZZzZhZmFpaEFnSGFGY0ViRmJJZmVjWGZnYkhoZGQzZGRmcGRSZGxjQWZRY0VnMmFoaG1lQmREYnRhWmRIaFRjOGdJZUpoQmd0YlZmWmJCYlVlSGNXZFVlNGVjYlpnbmRvYllmRmdYZGRmeWRRaFhlNWJlZVFod2QxZURjWWVSYllnWWZaYWhkUmdtZFpnbWdGYXdkVmZXYTlnYWVDZUJmMGJEaFNkRmJKZnNlY2VGYUJhamRUZFdjcGRMZkRkMWVJY1FoWmZFZHhnMmJkYWxlSWdXYWJiamVGYjJoR2hVYnRhSWNQYmxjbGMvZGNhbWVKY2xhWGFVZk5mUGJXZmloWmUwYVNoeWVkYzZkWWJraHBlWmVYY1JmVmJvZldhRWFWZmdoRGNCaE5nOWVVZm1hVWJmZVJheWFjYlZnUmhVZDFoSGJDaEVneGF5Z1ZlaGJWYnFkY2dsZUZnM2NWaDBnb2FXY1llSGNvZzhhR2NHZ1ljVWFaZm1mWmJoYWNmRmRWZ3ZoV2JnZkZkU2VUYTFlVmNhYlhjbWN0YTZiWWgwYTFocWhTZXdiOWVTZ0VhR2FSYk1mZGNqZGhkU2dYZnhiVmZ3YU9oQmZKYlhnQmdFaE1jV2dhYjNmSWZzZmNhQmN0ZFBiU2NRaDliMWVjaDFhWmEzaE5jWGRKZjllV2FSaEFjWmJhY0FjdGdGY2JleGRFZ1RiYmQwZ2RoemJSaGtlZGYyYkZoVmhoZUxlYmJSZUJibWFjYWxoWWJWYWFlbmVKYVJkZGgxZ2RhS2dGYWphMGFhZFhjeGJoZnRjRmZEZVlmYmVZYVdnMWRWYmZhVWI5Y1NjSGVSY3RkVmFIYUhiaGhyYktobWROZkdkZGMwaHRkQ2hYaGhoQWJxZ1RjSGJsZnJmVWJsZkFlQWFiZG5kb2RTYUhkaGJoaE9jUmhHaEpocWZXZm5hQmhJZ1FmMGdsY2FiZGdYZ2hhTGFkZzNhcGhnZ1RoSGdNZVFkR2FXYWdnTGZSaFdiOGRSYkVhMmM5ZEhlSmIyZmdjT2NhYUJnNWFJZUFnRWZjZGRiWmJqYzhicmFGYVRkWmd2Y1VkV2FaaEZmVWRoY1phamhZYlVoOGhEZ1RhQmhSY21nWmdtZEZod2VWZ1dnOWRhaEdlaGZRZEdmZmYxaEpmMGNhaDNhb2QrZFFhVWdCYUxkRGUxYklmUWZJYmhka2c0YU5iUWZZYkxnV2VqZlpkMmdHZGhnOGVSYVFid2RKZUlhY2NuY0Jmd2RTZ0VnTmZKZkRoRGZRZXFjU2Z5ZFZoNmhkZUZiY2ZDYlRkUmNjYzhiUmNEYlljN2NRZTFhb2NoZkFmR2ZnYTVnUmYyZ2djVmFTaEZoQmdIZVJiR2ZnZjNhRGhrY1VnbGhJYkFjVWZraFZjMWJjZDhoYWhXZkVlV2FHZkdiWWhVY1pkbWFZYkFiSWZnYWNldWJBYjBjbGFVYlRjamFRZEFkSmhpZG9kamJZYXhlRWYyZFlmUWg5Z1NnRWhHYVJiTWNkZm5jWmVTYkJkRWJBaDJoTmhVY1lnQ2hWY3diMWFaY2FlaWVaZzVmY2FCZE5jcGhTYlZocGYxZmVhRWh0ZjNnZWZtaGxoWGFXZVVnSmNjZFBnRmM0ZVhlSWVSZ0VhUmRGYkFoZ2V4ZldmUWZJYnJiUWJVY2dleGhGZ1VnSWhuaEtleWNzY1hmYWNtYjljTWRkZndjVmNFYVZiU2FnZnRiV2JoZUFoeWJIY1hoMWdNZ1liWGNCZ1ZjYmQxaHBnSGJIZlJkMGdJaFNjVmg1Y3JjZWJtZk5jTmZOYzBjY2RsZFVmaGRCYmtmVGZEZkFhamNIaEFmRmFCZ01mVGhsaGNjU2N4aEFhWGZWZ1dmSWZnaGVhWGVBZVRkYWdVZGxkYWFkZ1hnaGdMZWRneWR3Z29iQmhWYWxhWmRGZldoaGRPZ1hoa2FVZFJhRWMyZzlhSGJjY3hjTmVHYVljRmhNZmRlSGdnZ1JhRWVMY3pjMGVZY0ZnV2RJYTlhV2ZIaGNnTWdZaEJnWmFwY1lhUmRZZFlmWmJoZ1JjbWJJZ0RhUWcrZEZnamZzZFRhQ2VGY01nZGFIYlZob2RnY1pjM2ZvaHhmUmhHY29oUWdKaFZhSWNRZlpjRWR4YTJjZGZsZEpnQ2ZGZVhiZ2RrZFZieGY5YU5kRWRSZWRkaWdKZ2phZ2g1ZEdiMGFNZUFhRmhDZVljc2VDZWpoa2Q1ZExkQmFnZGZhRWJGYkZjQ2ZDYTBjVmV2ZEVjUmdOY3ZlUmEzY01kVGhSZDJmZ2NWZVZhMWhCZlBkR2ZEZUloNmNIZzBnWmZrZURkUmUwZzRkQWFFYm9lTGVhaFhnRWhmZEZiRWJ3Y1ViWmZtZFpoaGZjYUZlVmJ2aFdma2VjaGRiSGJWaFZjU2VkZEdlTWF1Zktkd2VRYTVlUmFYYUFhYWJXYlNoTWhFZGRobWZ0YVNlVWFoZ3hmMGhYYUJoSmNMY0doRWhOYlphWWJuY0phd2RjaEVnaGREYVNnVmRwZDFmY2VCZDhjL2hNZHpmcGNaZENiMWZWZVVmS2ZVYUlmTGZLaDFkUmJCY2JhMWZwZ3piWGNSZElla2VXZVVhRmVjZ2JnUmhCZm1lY2NsZFllVmNhZG5oSmdSYmRhMWFkZktkRmNtZ2xhaGhGY0ViMGhvaFVjQ2hNZGdlS2VEZTRhUWVLZzFlaGRIYUFiQWJCaFZkQmFpZDBmN2dQaHlhd2VMZmFhaGhrZ2xjVWVoaEJla2FUZkhlWmgyZVVna2FJZFZnZWdIY1loU2VTZnhhaGhEZVdmWGYxYXllSWMzZzRhTGhBY2dlVWVXaGZhU2V3Z0RoUGhpYmxobGhWY3dhMGJaZE1kMmFnYkxlUmVXYzhoUmdFYjJkOWNIYmNheGROaEhiYWhCZ1ZmSWNVZEVmY2FLYlphbmhBZkZoUWhUZmdiN2FIY3pkQmVWZFNhZ2N0YjBnWWZVZUpiQmZOYmxkRWNwZ0lmR2hFZWtkZmIyZjliYWhSZnhhMGNkZlZnVmFKaDBkYWYzYnBlamFUZ1dmcGVMY0RjMWNJY1BhWmRBYjFmNGJOYVJiTWVPY1doWGdBZWloV2RnYkpnTGhUaDFja2cyZmZibmhBY2ljUWNXY2xkSmRXY25kVmQ0ZFNjM2NkYjZlYWNWZmRiWmhFZEJibGdvaENnMGhWZnZlQ2J4Zk1oNWVDYkRmcGdYYVJkeWZZY2JhQ2R4ZkVmTGhYYkdhNGJtYkhobGR3ZzVhZmVsZkVoamhXaDBicGRFZFlmR2VnZDhlR2NHY1loVWVaYW1nWmNoZWNiRmdWZnZjV2NraGNjZGhCZzFoVWRjYk1oVGh4ZDZjS2gwZ1VoK2NSYXdiOGZBYUdnWGU5Zm1lZGduY1pnU2JRaGhoVmc0ZWRmaGZJY1djTWhrZE5lWmdZZm5lSmN3ZGNmRWdoZkRnRGh3aDhkN2ZPY3hoOGErZ05mU2FkaFhmRmJ4Y2hlTmFaZEFhc2NYZlpnaGdGaEllUmRVY2RkemhFaDBjZGZvZ0ZlVWNoZ1FiUmZ4ZkFoMGJOYndnSmdBZU9mRGV4YlJnZmJ3aE1nQ2hYZXplcGV2Z2FkVmdRYnBhUWMyZVplN2hZY1dkQmZWY01jMWNvYlRjRmFCZ0ZmVmFXYWllQWVqaE1lemhCYkRoRmhRYk5kR2dGY1ZhaGFrZVVjWGhaY21nVWJoYjRoVmhLaG5kOGJlaFNiMGV3aExiRWZEaEZkcGVXZG5mQmJJZlFjMGdsaGFnZGRYZ2hnTGVLY2xnQmdwZVZmMWFraFFlR2hXZ2dlTGdSZlNjbGFFYlhjU2Z3YVRjT2JsZndhSmhhZUVkWmNBZUJjRWg0aFFiUGZWZmhoV2VGZFdjcGV5Y1ViWGRkaFhoU2NoZ1pncGNNaDFmTmFNY01iMGRZZ29kWmJtaGtoa2hIY1NiWWRKZVNoV2hKYVJmR2RnYVZkMGJkZW5mcGExYVdmSGM5ZlliR2VsYUlnV2RaYUJoaGgvZ2VobGdKYkthUWZUYUFnL2hRY1VjVmFuZ0NmeGRBYWxoT2FuZ0JodGVTZ0JkZGRKZ1JhR2F0Zm1kU2gyZVphc2JZZkZjdGhaaFJjRmFFYmhiV2hGYzVhRmJFYlJiTmh2aFJjM2hNYVRjUmIyZWhiSWFZZ2xoQmZIaEViR2JaY3lhVmZoZ1ZmcWVOYUFiUWc1Y0ZhQmc1ZGZkSmdpYjhjV2JXZldmNWdBZGFibWFZZnplZWdWZlVjMGdjY0ViY2JkY0hkVmhWZ1NnZGFHZ3RjNmZZZDBnMGY4aENkbGgxY1NiV2ZXZFJkUmRkZGlmWWNUYUVnRWRZZzlhSGQxY3dmZmhFYkJnZGVWaFlkaWJCYndoTGdCaFJiRGRXZUVlcGI4YVljMmhGZzNnZWJtZmxkWGRXY1JhQWRaZmFlQWR0YkZiUGdWY1JiSGJPZmhhVWI5YUVhMGQ4YjhkWGJRZEViRGRTY1diOGJxZ1BlUWNFZ1ZhZGczZkphSGFZZWtoSmJaZEFlMmRsZW5hRmhsZUZkdmRHaEdmWmF1YU5oVGhnaGNoUGZGZ1FiNGRWYlZhUWhTaEdmbmhSZjJnZWdpZHBoTmZkZkZmVWRSY1VlZ2dGaHlkUmNYY3BkMmdCYmdicGFjZUtoMmcwZTRoU2Z4ZmhoRGhXZFdiSmF5ZWNnSGZBY1ZhYWVVZWxkYWNkZVhjaGFMZWRhM2FwaHBnWGJ3ZklhNmNHZldlZ2FMY1JnV2U4aFJkRWMyaDloSGRjZXdjQmVSYmNlaGhVYUFkV2RDYnBoUmRNZGpjcGRZYlJnU2JVZGxlV2FXZ1JiQmVSYmhkWmE4Z2FkQmI4aFVjVGNCZ1JnbWdaaG1nRmN3ZVZlV2I5Y2FmUmd4ZTBlTWNRYzBnaGUwZUllM2VJZ09mRGFEZzRmRGVBZlFhSmhmYk1lMGRSYm5jWWRGZzVjQ2RBYm5lRmQvZEhmbWRFY1lmUWgxZWxkaWVjY25hQmh3aFNkRWFOYkpnU2YyZ1ZoaWNTY3piOWd5aEJmQmZZYk5lV2hCZ2NkNGVSY0JmSmRuaEFlQWdOY2pjUmQyZG9hYWZUZW1mUWcvY1NlRmhCZ0hmRWFHY1pleWNWY2hoVmRxZmNoa2JOZnRoVmF3YUlkZWZCZENlQmFDY1ViR2ZoaEVhS2RUZ0ZocGdZZGxkbGd2YVNoVmVjYVVlRmJGY2xkNGNkYUdidGI2Y1llMGIxZ3FhU2h3aDhjUGdIZUVkNWJNY2RibmFaY1NkUWNoYlZjNGhkZ2hhSmVMY1FjMGFOYUtnZGFHY2hmd2ZPZUVhQmJRaFhhMWJOYjVoZWZGZHBjaGVZYUdha2RmY1VlUWZFYlBiWWdRaGRoRmhmYWdlRWRKZmJod2U5ZjdiQWJsZWRiaGNHZFVjaGFDY1hkUmRBZHVhZWRrZlFoY2ZhZmloOWFZZWJhSGgxY0tiRmJtZGxlaGZGZmhhaGJtYUZkR2E0ZHVkYmZ5YkFlSGNJY0FlNGZJaFNnVWNRZEZkRmUzY29ldGRLY0Nid2VBZkNnQWFKZGJkQWdSaEJhNWFUYURoaGIvY1hibWZnZlZkZWNIZVlkU2JTZ3hoaGREZldjV2RKZ3lnZWREaGhkR2ZFZnhmc2dWZUlmVGRjYWZlTGdpaG9hc2NXaFJlOWhDaFZhaWhWYmxiRWFDaEpiVGdWaGpjMWFIZ2JiaGNNaFVmWWVSY2xhaWFVZkVkY2NRYVpibmZKaFdhRmhXYXBkeWZVYVhkOGFmYVJhRWRZZzdoTGFrZkpoWGJNYmtkMGIyYkloMmg4YzJjQmN5Y0FkWGdOZ0VlbGNQZkhoQmJ3Y3poYWMyY2RkamVEY0doTmJIY0pmVmFJYVFkWmFFZHhmMmZkaGxnSmFDYkZlWGdoaCtoV2VrY1ZoSWRFYlJlWWcyZFBjU2FRY3BiR2VBZ1poSGZEYWplb2hXZkhkamJvYTRmTGJBYlZoWmFEZlJka2V1ZVhjZ2RzYnNoUmRWYm9iZ2JDYlhjTWJiZ1RjbWFoZE9kWWFsY0JlSGRFZkdlWmJ5YlZiaGNWaHFnY2FsY0ZkM2dWZXhnaGFUZVBjVGNSZkVoVmRtZ1liQ2VjZTNnTmF5YlpkbGJWZ2xnV2FoYk5kVmJWZUFjWmZjZ0NleWJNZnpkSmhBY1ZhcWNRZ0FjOGVHZFdiQ2gwaGZoZWZBY2tkZWVEYlVkSmVqaFhoQmdKY0xoR2VFZ05lWmVZY25hSmd3YWNiRWNnYmVlUWVGYVpmZmRlZEVjdGMzZWVkbWJsaFhjV2hSZkFoWmhhZkFmTWNOY1lhVWFGYkJlSWhCYU1nOGNSY3hiNGM0ZFVlRWdZaEVhQ2ZHY01oeWdJZkJhOWZiYUxhWGhKYU1kZGJ4Z0VjZmFXYUNib2gxaFhlMWRjY29hRmNHYjRkeWVhYkhmQWFPYVJjVmFwZkhoSGdSYTFlVmhVZ25lUmhyZGVlbWdOZE5jYWNoYmxjS2VCY2tmVWUyZkFobmRZZ2liR2VnZXRiR2JkZWliSmVkY0piVWgwY09iR2Z5Y2NnZ2JlZkhhbGJHZ0Zmd2hZZ3BkSWhTYW9jQ2dPZFRlMWVoZ0FoMWVsZE1nUmZXZ2dkYWRWZVdoWWFLZ09oV2E5YUhoY2F4YU5nSGdhaEJlVmdJZVVlRWFkaE5nYmgzZjVhOGZGZVdlcGZ5ZVViWGNkZ1hkU2FoZVplcGhZYVJjNWdRZ2FiRWVRZTBhS2VUZFVlL2VBZ1RiWWFLYkFiaGJOZmNnRWdSY1pjMGdkY25ib2hsZEdoQ2dRYUlmV2N4Z3RiZmdLY2tmeGErY0lnbGZ0YkNkVGhsZ0pmMmZFZ2tlc2RZZVFhMWFsaGlkY2JuYkJkd2RTZ0VkTWZmZUdkeWFkZzRiR2FYZWRobmRhZ1FkTWJSZFdmVWJwaG1lZGZBaGtnZ2ZSaGhmTmVrZlJkeWVjZWRnT2dDZ1JoYWZIZzFheGJ0aEVnR2ZaZnlmVmdoZ1ZncWRjZmxkRmQzYlZoMGhvY1dmYWVXZkZoZmJHY0hhc2NVYU5iR2RaZC9iYmdrYXRmdmhTZjFmRWVHaE5kMWJWaFNoZGJHaHRmNmZZZDBnMWNxY1Nid2Q5ZVNhRWVEY1lnSmVJZmlmTWVBZURlQmVWZHdhWGVCZ0piTGJHZUVoTmFaY1lobmhKZndjY2dFZmhhRGNTZVZjcGMxZWNoQWNKYTNmY2hYYVJlWGREY1ZiaGVRZU9jd2NVYzZiSmMxZmhlVWRKYjBjZGQ0Y0VneGhOZW1jYWJnaEFlWmJBYUZlaGd2Y2Zmbmh3aFZnYWRuZUpnUmZkZzFhZGhLZEZlbWVsZ2hmRmdoYWhlbWhGZEdhNGZ5YUthVGJrYUdoWWdTYlVoTGZVYWthcGhWYlRhM2NSYjlhYmMzZlplZWdmYzBic2JKZFVka2hKZHRnUWRGYXhnMmNVZmthSWhWYmVmSGhZY1NiU2R4YmhjRGZXZVdlSmd5ZmNoSGJnaGNjQ2N3ZEFjSmRlYndmY2JEYlBkamIwYWhlVmcwY1FhUWREZTNnMGJlZFZibmVvZVJiRmFXYzhmT2JlYmhmOWh0Z2FkQmNWZkliVWNFZGNlUWdaY25oSmZXYkZnV2FwZnlmVWJYYmNnRGNBY2xlOGg2Z1NkeGNZaFliWmZoZVJhbWdaZ21nRmh3ZlZoV2I5YmFnUmd4Y1FiR2FmZjFiSmcwZ2FkM2NwYmplVGNXY3BlTGdEaDFmSmNOY2JiVWFCYWNkZGJsYUpnQ2ZGZ1hkaGEyZEVoa2ZzY1liUWUxY0VlcWNmZENjQWhpZEJheGFjZEdkRGZpZ3dlb2JEZG5ka2hwZVBkQmhVYU5iUWRsYmdmcmhYZDBhVmN5YkVlVmZVZDZkQ2dUY0JkSGVEaGlkZGJiYlNkRmJnY1RmR2VXaFlmcGNmYUJnVmJxZ2NlbGVGZDNnVmYwZG9jV2ZhZVdnRWNXZkdjRGFSZ1JmTWNqYU1kemVQZWxkVWg3Y0VnZ2c1ZU9nRWV4Y1FnV2dNZUdoTWR1ZWJoUWM0aG1nQmZFZEVlWGJHZ0dkMWZDYU9jRGNNaFZlQWgwZkVjOWNmY2hkdGhDYkFoMmNsZVpoWWZuZkpkd2hjaEVhaGNEaFNnVmJwZzFiSmdVZkphN2dVZkdobGFYY1dkUmFBYlpmYWhBaHRkRmViYnhkRWhiY0poMGRrYmphUWJRZ2dmOGdXZ2hld2RKZUZkMWdWZW9iUGh3Zk5jWmhQaGphc2RCYU9ld2g1YUtmQ2cyaGtkbmZRYjFoWWRsaFFmQ2M4Z3BoTGUzZUJhZGNPZTFkTmFIYlJlamhkZVZnVWhuZ1JmcmRlZG1nTmZOYmFla2NzZ1BjVWJoY0FneWREZ1NiUmgyYUFjRWM0Zy9hZWRIZlliU2dTY3hjaGhEYldjV2RKZ3liY2JIZ0JlSWJRYzBla2VUZ2VhVmdKYkxnZGMzYXBkcGhWZDFja2VRZkdnV2RnZUxkUmRXYzhmUmNFZnlmcGNIZ2JkaGFNY1RmSWFGZ3diYmNYY2plaGdZZkxjemRVYWVhR2FVY0JieWZVYlhiZGhYaFNhaGFaZXBoWWRSYlllWWJaaGhiUmVtYVpkaWU1YndoU2JHYzhnT2dEZzFlUmRPYVdneWQwZjRhSmVDYTFmdmdaZjJocGhMY0RhMWFJZ1FhWmhFYnhhMmdkZGxoSmVDaEZiWGRoZjJhV2hrYXNkRmdRYXdhMWNzaERmVGZnZjViRGJ3YnRmRmVjY0hkVmM0YlNlM2FkZzZiYWdWZGRmWmNFaEJlbGFvY0NjMGZWZHZhWGF4Zk5meWRSZXljY2NkZU9hQ2NSYWFjSGQwY3RidGFFY0doWmN5ZFZnaGZWZXFjY2FsYUZoM2VWYjBob2hXZU9keWNSZENnVGJUYlJhYWZaYW1nNWdMZmNoRmNWZXZhV2ZrZmNjZGZIYlZlVmFTY2RmR2J0YTZiWWgwaDFnaWdBYWdlOWVQaEVlQ2F0YU1hZmJIaFljY2FTZnhmbGFTYmRoaGNKZExjR2ZFYk5mWmVZYm5iSmV3ZWNlRWhoZERkU2hWZnBhOWhLZmtodGdxYmViaWhCZFhoUmV3aDRjSGdhYUJocGZUY1poaGgwZjVoYmIwYWRlemVFZzBjZGRvYkZkVWZoZVFiUmN4Z0JkbWJjZ2xjWWJkZ09lSGRKZ2FhYWNsZGNiUGNGaG1lTmVoaFdmQmdGZHFiUGRtZ1pjbWdZaFhkQmNWYmJiMWhwZUhnSGFSZDFlVmdVY25iUmVyY2NoamhGZE5nYmFGZlloUGVSZ0FiVmZ4YlhjMmVOYy9jWGhtYmdnVmhlaEhkWWRTYlNoeGNoZERhV2VXaEpieWJjZkhlQmhJaFFkMGRFZUlnZGNYZk5mV2VkZXplVmFwZFhkVmVsZllmRWRHZFFlaGJSZ1dkOGJSZ0VmMmQ5Y0hoY2N4aE5mSGVhZkJlVmFJYVVlRWdjYVlkTWRqZm9hZmdSaG1jUWhOZkhiVGhnZEFnU2dnYnRlcGFkZHdjTWVOYmRkUWdGZW1mWWFHZUVkNWRYYkdoTmd3YlJneGQwYWRnVmVWZkpiMGZhZjNjcGVqZlRnV2VwaExmRGQxYklmWWRNaEFjUWQvZ0pkVmR3YjlhWGdUZ0VmeGdXZ2toc2ZGYlFoMGQ5ZjNiWmUyYU5jbGZTaEVhVmJKZ0NnSGd4ZTBoWWNYZWRoNmdhYVZjZGVaZ0VjQmVsYm9mQ2YwZFZkdmNFY1JmTmd2ZkVkemF0aGFnRmdFZkloVmRTZ0ZjQmRIZUVmR2VaYnllVmVoZ1ZncWhjY2xoRmgrYlRlR2NBYldmYWVXY0VmV2NHZUdkWWNVaFplbWNaZWhiTGFWZHhoamhjY0VmY2JkY0hnVmFWY1NoZGRHZ3RoNmVZaDBkMWZpYkFid2JFYUNkUWFpZ3NiWWJPaFNhSWVMZEVkbGJCYTJiTWJsZ3NmZGRHaEZoNWJaZUphQ2RjZytoTWF4ZXdjS2FCZ2hkUmUxY2NlQmc5YytlZWRqZkphOWNXZFJnQWNaaGFhQWJ0ZEZnYmV4Y0VoVGViZDBmZGV6Y1dhZ2JGaG9iSGJWaGhhUWFXY2dnMWRtYUpjbGJoaHFjSmhqYTBkR2FkYTFlRmhNZEZhbmZsZWhhQ2N3ZVZkbWhRaEdoZ2haZ0tiVGFrYVNiSmcxY05hSGdTYlZkVWdIY0hnU2ZOZHJiSGJ6aEVhZmhKZ1Jha2NIYVVkRmhRZ3RnR2JqZDhlbGVHZndjMWNiaGVhRGRSZExhU2gwZUloR2hDaHlnMWR3Z2VnV2d0ZGloUWYwZGxkYWNkY1hnaGVMY2RkM2JwaHBiVmgxZ2tmUWJVYkNmNGhMYVRjWGE4ZlJmRGFuY0phSGRKaHhjMGc0YkliRmh3ZFBnR2dFZGNkV2RZZkhhSmJIY0ZmWGhkYXZlVWhTYU5mWmZOZlZmb2dtYk5kaGM4ZXlkWmNoZVJnbWNaZG1jRmR3aFZmV2I5ZWFjUmV4YTBnZGdWZlZjSWNtZExhaWU0YjJoSGh5Z1JlTGdCZ3dnWmFZaExnUmU5ZjRmSmJCZmNoUGFWZ0RiRWU0YVZlZ2U1YUtkUWEwaFJnaWFQYURlVWduZFNnQWJ0ZkJlU2NuaHhoeGNSZDNoY2Z1ZEllUmI0aEtoQ2d6YU5ib2NDZDBhVmh2aEVlUmVOaHZmUmIzZE1mVGFSZzJiaGZjY0RkbGFCZVBlUmdHYWdoMWZBZGhhMGIrY09kaGdnZWthWGdrZ01nOGNhZFdkRWRXY0djR2JZYVVmWmZtZVpmaGdjZ0ZmVmR2Yldma2VkZFBnV2FBZUVjSGNKYmlhVmg2YmFlMmNkY3FiU2N3YzlmU2ZFZ0djUmJNYWRibmJaZlNnUWZoYlZjNGJkYmhjSmhMZEVlQmhjaFJhS2J5ZkZkK2JJZWdiMGVPY0NmQmFNZTdjUGJBYzRjbGZlZW5hUmdYZURkVmVoZFFmT2J3ZFVhR2dJZTFmNWVkYktla2M5ZTZoR2VraHRoQ2ZGZ1VlaGZRYVJleGFCZG1hY2ZsZlllVmRhZ25lSmZSZ2RkMWRkY0tjRmNtYkVnMWRYZmxnRWYxYkdoaGVrZnFjTGRpaGRhVmVjZ2xicGhYYUZmQmZGZi9kVWFuYlJncmRlaG1kTmFOaGFja2JzYVBkVWRoYkJka2ZUZkhkWmEyYlVja2NwZ0JmTWREaDlmQmZSZ1diY2dMZUVkQ2FVaDZlY2NHYjFkSWZVYzBoQmFXZVhkM2JoZ0xjZGczZnBjcGRWZTFia2JRY0dlV2RnYkxmUmVXYjhhUmFFaDJjOGVUY09jMWVvZ1VoUWVoZ1ZnSWJVZkVoY2FRZlpibmNKY1dmRmdXZnBkeWdVYVhjZGhYZ1Fod2cxZkRkWWFSaFlnWWRaaGhjUmNtZVpobWZGZHdlVmRXZDllYWREYWxnc2NkYVhiUWFZYzhkSWdpZmxndGZDZERkdGFEYVdjMWRzZ1piVGZrZ3hnMmhkZ2xhSmRDYkZjWGFoZTJoRWRraHNnWWRRYjFjbGFpZUlmRGhVZmtmSGVSYkVmSGRXZG5nMWZTZVNiM2hkaDZhYWZWZ2RiWmRFZkJnbGVvZ0NnMGRWaHZoRWNSZE5odmJSZjNjdGhIZURneWZGZ0diUmhnZUlnQ2JYY1NkY2Y3YkdkRmNFaHZlSWVGZkZlcWhWZHdlUmRUYVBobWRGZGViRWJIYllhZGRiZjJicGdMYmNoRmFWZnZlV2NrYWNmZGFIZlZnVmZTZ2RiR2h0ZjZhWWIwYzFicWZTaHdjY2RHYVdlQ2QwYWZlZWVBZGthZWJEZ1VmSmM0ZGFieGFKYWFoRWhVaDlmemhZYm5iSmF3YmNoRWVoYURmU2FWY3BkMWZlYkVjdGQzZmVibWVsZlhkV2RSZWhnTmNJZkVhSWdXYlliV2Y1ZWJjSmNnZkFiN2RFZTFmcGJvZ0JiVWdGY2NjYmhSZUJlbWNjY2xnWWFWY2FnbmFKYlJnZGMxZmRhS2hGZW1jbGRoYkZjaGJnY3lmWGRDaDhoMWVTYzNlQmFWYWJhMWNwaEhiSGNSZTFmVmZVYm5iUmRyYmVhbWZOZE5kWWIxZUFibGRVYmhhQmRrZFRlSGNaYjJjVWRrZUllVmFlZEhmWWVTZkRhVmZjYlJkV2ZXZW9oa2dNaFNnSmZJZUVhVWVsY0hlZGJTZnhiRmNOY0RkWWJtZkdlUmF3ZlllRWdHZVFhTGREYkdhOGVNYkViMmJKYVdnYWZCZU5nR2FQZEZhMGJCZUFkMGJsYWNlTWduaG9kRWZIZEhjRmZ5Z1doRmgxYlhmU2ZoZFpicGJZaFJnWWVZaFpjaGRSZm1hWmFtZUZld2VWY1RmMWZVZ0ZkRmNWY1VoRWF3aFliWWVMZWpnd2YzaFJiWGF0ZEhiRGgxY01kQWNiYlViQmcyZFBiMWFsY0plRGZsaEpmMmRFaGthc2FZYVFhMWVsZWliY2VuZ0Jld2VTYkVnTWVQaEZlU2RkZTRoUWMxZTFlNmNhZ1ZhZGVaYUVjQmhsY29lQ2IwZlZjdmFFaFJjTmJ2Y1JieWRkZ2JhRGdqZnNmYmNHZmhlVWVLZFVhU2Q4ZThmRWVsY0FiNGVjZmtleGgzZkFmd2JKYmZnT2ZtYzlmVmhWYUNibGRhY0ljMmU1Z29jZmdGZVVkN2VFYWdkNWVPYkVjeWVvYWVkT2F6ZHhjNmhmZmtlMWY2Z1Jmd2I4ZkdnV2dDYTBkZmZlZkFna2ZhYUNhMWZJY3dnZGNnZTlmTGVDYkZjaGd6ZVljbmFKZ3djY2VFZWhkRGFTZ1ZocGQxaGVoRWF0ZzNnZWVtZWtkZWdXZ1FkNGFFY2FkQmF0Z2VoUmNSZ0VhVGNiaDBoZGd6ZkVlMGNkY29nRmRVZ2hjUWJSYnhjQmdtZ09kMWhzY1ljUWZIZEpoUmRkYjFnZGZLZEZmbWdsY2hiRmFoZ2hnbWFGZEdmOWJNZVlnWGRCYlZiYmQxZXBiSGFIYlJmMWVWZlVnbmhSYXJkZWZtZk1oZmVaZUJnaGhIaEdhMWdZYXdnUGNqaDhkeGRHYWhmWWJkZGFhWGg4ZWVnWWJSY2hoRGNXZldlSmh5ZWNkSGhCZkllUWEwYmxiYWNkZFhhaGZMY2RhM2hvYjlhSGd4aEJiRGJGZ3phcGZPYUNlQ2Q1aFlkWGRTY3NjQ2NJYVJhMGVMZlBnQmEwYWFjV2RVZGRhTWFPZ2xiaGNXZ0ZoV2FwZHllVWJYZWRoWGZTZ2hjWmRwY1liUmhZYVlmWmFoZFJmbWVaZG1hRmQ0Y0FjU2FjYlRkRmRCZk5mUGNFYUJoOGQxaElnamRRY25nQ2JEYmhmRmVYYkFkZGNTZU1mQmg0ZzNmTmhRY1pnS2FSaDNhRmQ2aE9oRWVzZFlkUWUxZmxjaWJjYm5iQmV3YlNmRWJOaEpiV2duZ1ZlNGhTaDNlZGg2aGFmUmE1aFplRGVnZFJnb2JHYmxoTmJGaEViUmVOZHZkUmMzZk1oVGhSZDJoZ2hWZFNlRmdCZEhmRWJHZ1pjeWRWY2hoVmFxZGNjbGVGYm9lVmMwYUpnQ2RJY1NjaGdGYkZoaGZsaGNmTGR5ZEVkcGdjZkFlbGJ5YldkbGZZY2RlQWZVZGxnU2VmaENiSmI2ZWJia2cxYjdmWGVRZVphYmhPZW1nUmZNaGRibmdaY1NiUWNoZlZnNGFkZWhiSmJMYkdmRWhOYVphWWhuZkpid2djZUVmaGhEYlVmMWZwZDlnTGJBZE1kK2dLZ1dnY2dvaEZiVmM5YU9oYWJGYmRnWWViZHdiQWRUZGNmMWF0ZHpiV2ZrYTVmaGREZ21nSmJRaFJjeGZCZm1lY2JsZVllVmRhY25iSmVSZ2RoMWJjZlljVWR6aDBnMGRSZkZiWmJtZlFhQ2M0Y3ZiTWVtZnRiL2RiYjFkcGhIZEhnUmcxZFZjVWZuYVJhcmVlYWpnNWdFZVpnbWdFZ1BmVWNoYUJma2VUZ0hoWmEyYVVoa2FJZlZmY2hEZzRkY2hHaDBlb2NNYURiU2UwaG1lS2NTZ0FiTmRUYlFhY2JmZE1mamZraGZhTWRuY3BhMGJWZnhkOWdGZlZjeWV0aGZhRGRDYkJmZmNFZTJkZGNPZmNhMGRoaHRmYWdCYVZhSWFVZUVoY2dRZ1pnbmRKY1dlRmhXZHBneWVCZ3plWWFGaFNka2VKYXBoZmdCZ1lmUWNjaEFoRmV6ZWRkWGdSZXdoVWYyZjhjRWhFZzFkVmFVY0JkbGZ3aExoSmR6aFVhMGNSZ0dicGZBZ0RkMGVNZExlVGFrY3hoMmVkZmxmSmFDZEZhWGRoYTJlRWhrYnNhWWJRZndnc2VuY0poaWdVYWliQmhrZk5lQmJjY0hnVmM0Y1NnM2VkZjZnYWNWZ2RhWmJFZkJobGdvZ0NhMGJWYnZoR2FVaGNlbmhEZWlmQWJkZU9lQ2hSZWFhSGcxZUJmYWJFZEhlQmZuZVFid2daZi9nY2dsZ2RmM2FBYTBiTWZhaFFmMmNFZldlR2ZHZllmVWNaZm1mWmNoZmNhRmhWaHZnV2JrZGNiZGRGZFFjRWhhY1BnVGVoZzBoSGRBZFVmamZEZEVkZGdTZ0RlV2VSYUViS2RDZ0loYWVDaDBlWmEyZkNiVmNvZkNlWGR3aHRjWmJhZlhmSmY0Y0piRWdoY2RjVmUwYlJiMWVhY1ZkMWIraGNhMmZsYlJmV2hRZVlhTWJmZ1JnaGRRYVpiaGgwZzVjYmcwZmRiemNFYjBoZGFvY0ZhVWNoZlFnUmF4YkJobWFjZWxoWmhCYklhamZzZUNmWGNWaGRiS2hGZW1hbGRoZUZjaGRoZW1mRmNHaFpmbWhZZlhibGJPaFJiVmdwYkhjSGJSZDFoVmJVZm5kUmhyZGVlbWVNZ1FnWWYwZ2NnbGNVYWhkQmZrZlRiSGFaYzJkVWFrZkllVmJlZUhlNWNhZ1JiVWZnZVJjRmVqY1loOWdKZkNja2RZY0Joa2RjY2ZkSmRDYjBiS2FPZXljbGdwZVNobGZsaFliRmF6Y2hkWmVDYWphdGZlYlJoemZZaFhoTmVoYTBjQ2FPZFJmVmNWZlVhQWJGYUZhS2NEaEVhQ2RYY0NmVWU4Y1ViWGg4ZERjUWR4YVlheWNTaHhhWWNZZFphaGVSY21lWmJtYUZid2NWYldoOWRhY1JjMGE5ZlljQWdRY2NibWVKZ1hib2UzZEJnU2JNY1lkQWZTZzFoY2dLZnhjdGQyZmFhMGY5ZkNjUWNYYVljSmVYZGdiUmhQZ1FmMWg5YWtmY2dpZ1FiNGFBY1JhQmhIZ0poVGcwZnhiRGVEYTliNmRkZEVocGRaaFJkQmFjYVhiUWd3ZXdnb2VXYlFmaGVGYVJjM2NNZlRoUmMyZWdiVmRTYUZmQmdIaEViRGR0ZzdjV2dqaDlicWdjZmxmRmQzYlZkMGNvY1diYWdXZkVjV2JFY0NoNGdhYk5oamRRZXVlSmZCZW9hN2VBY3hmZGVZaEVmeGFJYkFmTWJTYW9mdWdKY2hiOGdlYkFhMGQ0ZGNiRWFIZWxiTWZQZm5lZ2hDZ0VmRmdvYXNlT2FVaFlkU2dTZkFmWmFYZ0plU2VaYndjYmRVYmdkRmFIYUJnUWEyYkxlQWZJYjRiTmNHYWxlZmREZFJna2ZaYk1keWJGYUZiYmd4ZEViVGNiZTBiZGN6YUVoMGZkZW9lRmRVaGdlQ2RBY2tlUWh6ZElnQmRnYlZiUGdqZ29hWWZKYUZja2cxY1hiaWZBYW1kWGhoY2hlNGdGZERkSmZvaEhoamVnaGNjS2FCYkpmdGdIZ1JlMWNWaFVmbmNSYXJiZWFtZk5oTmdhY2tnc2hQZlViaGFCZjdoVGJIZGRmbWFlZkVoSWVWYmVoSGRZZFNjU2F4Z2hhRGNXZ1djSmJ5YWNkSGdCZklhV2NVYWtkT2FQaFRoRWJZZ2VjUWJVY2hiSGVoZzViWWRHZFhjUWRMaEVlV2NGYnVoV2d5Z1llQWVPZ3pkbGVIYWFhQmZWZEljVWFFYWNiUWVaY25kSmhXZkZlV2JwaHllVWVXYmhkWGZTYndkZGZEY1lnUmJZY1lkWmFoZlJkbWFaZm1iRmF3aFZkV2I5YmFkUmV4ZjBhSGNWaFFlWWM4Y0loaWdsaHRkTWZpaFlkRWVXZEZjSWFPYlpkQmZoaDRjQ2FSZjRnTmZRYm1hTmRjZEVna2VzZ1lmUWgxYmxjaWhjZm5lQmh3Y1NlQmE1Y0FjVmJsYjlhNGRTYjNjZGE2aGFlVmZkZ1pmRWJCZGxkb2RBZHdoMWdoZVFhVWZFaGdhRWd6aHhiSGFIaGpnaGdRaFJiaGN3ZkNiUWh6Y1VlR2JIZmxhUWdrYWNma2d4YjNkSGcwY1JlR2dPYXliNWJDY1ZhemhKZE5lTmVpZE5idmRQaEFmRmF2ZlJkMGVkY2JmU2dCY3NlUmNJYkNoSWQxZUxnVWgxZWljSGV3Z1phU2RTYzBhNWRNYWRlbmRaZlNjUWVoZ1ZhNGZkZmhmSmZMZUdlRWJNZ0xoSmN5Z1libGJJYmdhWmFEaEhkUmhJZzhjS2YwZlVhSWdNY2loQWFRYkVhUmRBZkZoYWhGaDllTGZFZkZobGFhZEtnQWI5ZVpmRWIwZmRkb2FGaFVoaGhRY1JoeGNCZm1jY2hsYllmVmNhZm5oSmNPZmRiMWJaZWFjUGRHY2xlaGdGZGhkaGhtYkZoR2daZG1kWWRYZkJmVmZiYzFocGFIY0JkeGMwZUJkR2FqZjBlNGVkYkJhd2RGYklmd2h4ZEhoVWdnYzVla2ZHZUhnZ2dKZEdmZ2R0ZlNjTWVGZXdiU2dTYXhkaGFEYldlV2FKZXliY2hIaEJiSWNRZDBmbGdhY2RjV2JkYkxiZGNtYXRmRGVWZDFha2FRZ0dhV2NnYUxoUmhXYzhiUmFFZDJoOWdIZ2NneGNOZWRkYWhFZEVlQWZHYVJmUWdlZkdlVGg0ZFpmUWdtZ3BkdWVVaFNhTmFaaE5oVmVvaG1oTmNnYzBjeWZaZWhoUmhtZ1pibWdGZHdhVmNXYTljYWZSZjBiQWhVYldiWGVoZzBjYWgzYXBhamNUaFdlcGdMYURiMWNJZlFkYmJBYVJiNGJKZGdjQWNOZVFhVGFjaGlhU2h4Z3RnZGdUZlJmWWF3YWNibWgxY3dhRGRoYVlhSGZHYVNiRWZ4ZEJmRGNsYzZhWWNRZ05nUWVFZ0VlSmhDZ0NiMGJWZ3ZnRWVSZU5idmNSZDNnTWJUYlJiMmVnZlZlR2FoZFVoVGJSZlRkUWU4Z1ZoaGgwYytoT2VoZGdia2VXZlRoVmFhYUplamdZZVdmUmdIZHNjVWFNZm1jZ2VlZFBoQmFvZDRnVWQwY3NnZGVGZ1FoRWZhZVBjVGZoYzBmSGhBZFVjamZEY0VnZGhTYlRhSGJsZ01iSWJuYmdjdGZDaGxod2YvZVBnaGZ0ZkhnR2NCYmNkUmRLYXlmRmNyYldja2RoY0RhU2dWZXBnMWdlZkVjdGMzZGVibWNrY0tkVWRCZ3dkemFhY0FjdGVGY2JneGFFZFRiYmYwYWRnemdFZDBoOGRnaEdoeGhnZ0NiQ2RFaFFmcGNKZmdmOWRGZ0xhM2d3ZVFoT2ZSY05lS2RDZjJha2ZuZ1FnMWZZYmxhUWdDYjhmcGRMYjNlQmZkaE9oMWZOYkhnUmNqYWRkVmRVYW5kUmhyZmVobWJOYk5kYWVrYXNiUGRVZ2hiQWcyZUNlU2ZJZmpoQWNBY3dlVmJjZENiSmdhYUFma2Z0Zk5hSmRpaDRnOWhKZTNoQmhPZ1hha2drY09nZWJ3YmNkSGZPY0NlMWNnY1djMWNrZFlnVGJTaEJmQ2ZGZW1hRmh1YVdleWFZYkFkT2F4Yk5hQmJkYlJjVWVjY1hnamNoYVloTGR6YlVmZWVIZEdnWmV5Y0JlVGE4YWVhR2FRZDFlRGdZZVJhWWdZZ1pmaGdSZ21oWmhtZ0Zkd2FWZFRhSmhUZ1NlemNjZ2RoVmZWZkpiMGhhYzNocGRqZ1RiV2dwYkxlQmN4ZG9hZWJOYUJkNGE1YUllaGcwYldhVGdDYmdjemJIY0FkVmZYZEZnMWNsZi9kY2RqZllobGhCY2djQWFkYUVkemNvYjJlU2UzZzlhemRhZFFkeGR6aEVhQmhsZG9iQ2IwYVZidmhFZlJlTmd2ZVJhM2ZNYVRnRmVTZDFiQmNIZ1FhSWdKZEVkR2Y1YVllVmRoYlZjcWdjZWxjRmQzY1ZlMGZvYVdoYWNXY0VhV2NHYUdhWWJjZ01haWQ0Ym9lSWIxZnNoUWNGZWdhaGdLZkhnVWdoYVNjWWduZzVldmdjaEZlaGRxZFRnUWQ4Zk1lUmZDaHdlRmJKZVhiZ2F0YkRmbGZvZnZnZmJ4ZTViaGFHaEVmTmFaYllnbmZKZndiY2FFZ2hlRGRTYlZicGYxZ2VkRWF0ZS9hTGdpYkVmZWNDY2hhNWFtZ0llRWZJaENjSmJ4ZEVoT2diYTFoRmJtZ0JobGdSaDlmRmdVZTViUWZHY1VhUWF1Y09id2dVY2JjRmZUZW9kWWVNZkJlOWVEYUdoa2hOZGhmRmNoZWhmbWJGaEdiWmRtZ1ljWGNCYlZnYmgxZXBiSGFIZlVia2dkaEdheWVkYUJkZWRtYk5jTmRhY2tmc2hQaFViaGVCaGthVGhIZFpoMmJXZjFma2MvYmVhSGFZZFNiU2h4ZmhkRGhXaFdnSmZ5ZmNjQ2IxYkJhVGgyYk5mYWFkY1hoaGRMY2RnM2RwZHBkVmIxaGtmUWJFaFNmQWNGaEZkVGgxZGVmUmN5YUFnVGFLZGthTWRDYVpoa2EwYUhoQWNrZmNjTmNaZmpiUWZEY1dkeWNrZG1mR2REYWdlWmJTY2hoNGU5ZWFjQmJaYkRmVGFCaFJkbWhaZ21mRmR3Y1ZhV2Q5YWFkUmd4YTBjZGhWZVFoQWN4ZlBleWM4ZXhkQWEyZXBlRGhXaHhmcGZaaE5nMGhJZkpmT2NoZTBlVmJGYVFlWmNyZEVjaGU4Y1diUGVCZFVodGdKY1hibGg4Y1NiRWFzYWRmRWdqZXdocmZSYVFiZ2R5Z0liQmRBY1JlRWVHY2RoMWhDaHhiRmRoaGJlbGRzZm1hQWVEYXNhYWNTZTJmaGRCZUFhQmRrZFVnQ2IwZnhieWJWZWhjVmFxY2NhbGZGYTNhVmYwY29kV2ROYkdlZ2JhYk1kbWhZZFVhWmZtaFpnaGRjZkZoVmd2Z1doa2JjZlZmVmVWZHNiQ2ZKYWlkUWd1ZkxhQmNrZHpkR2UwZHBnY2RRaHlid2hGZU1hQ2hJZ2dkQ2ExaElld2FJYmhjSmdXYUdmQWd0Z1hiTWdpY0FhL2ZKZUFiY2JYY0VjQWVvZndoZGFoY2dnL2dNYXloOGJEYkNmeGdBYUVlYWdFYjBoUWZJYlZlSmNIZkphZ2hnZTllRWQwYThnOGFIY0VoZ2VMZ2JnUmZCaG1iY2RsaFllVmhhZW5mSmNSaGRoMWRkZktjRmFqY3Nka2hRYWtoMGMwZFdkbWNaZ3VjU2YzYkJmVmNiYTFncGhIZUhiUmIxYVZjVWhuYVJocmFlZ21oTmhOZlBka2hzY1JmVWNnY0ZmeWhaYW5kWmgyZFVla2ZJY1ZnZWhIZVliU2JTZXhiaGJEYVdnV2ZKYnlhY2hIZEJmWGZRYTBmRmZTZkloVGdBZ0NoSmdIZFFmV2dHYnhlWmhIZ0dkWGRVYUxnRWFTY2RiWWRRYkdjRWE0Yk9jMWdvY0FiSWhCZVZkV2JUY2tmY2VZaE1obmhKZmJlRmdYZnRma2JXZEhlNWhiZVNkaGU0aDlhS2FWYTljTGhhYUdhc2R1Y0xmeWRZYTRkVmNYZ0piYWJWYnhmUWVVYWZhMWZKYjBlYWQzZHBnamdUZldkcGRMZURoMWhJZVFnWmFFaHhlMmJkYmxnSmdZY0ZmV2VsYmdjRWFsY1ljRmhRYndkMWdJY2NobmRCZHdlU2dFY05hSmZXZ25oVmE0ZVNjM2FkYjZmYWNWYmRiWmJFYUFoWmFvYkFjMGYwZjdkV2VWZm9mOGVTZlFheGZmZUNhRGc4YVZhVmRWYkFjVGRXZENiOGdoYVdoR2JvaGllT2V4ZFliL2NYaGtoWWhXaFliVGdWY2VnVWNUZ1VmYWFHZFNiNGJvYk5neGQxYnZnUmYwaGNjTmVGY0ZleGY0YWRoR2R0ZTZlWWMwaDFicWNTZHdkOWFTZUViR2FSZE1kZGZuZFpnU2ZRZGdiOWQ0Y2ZoaGZvZmZkVWFBY29jS2JiZ0FhMGI4Z1BneGg5YkRoVmZIZEJnMWZlY0VidGIzYWVobWNsZFhiV2JSYkFoWmhhYkFhdGhGZWJkeGVFZlRiYmMwYmRhemVFZzBlOGQ4ZVhnUWRFYURoU2ZXYjhncWRQZFFnRWdWY2RhR2h4YVJiSWIxZzVlS2NTZW1kbGRwY0hla2N3aHVkWGdUZVZhb2JIYmpiZ2ZjZEthQmRKZ0hmQWNRZEZnVmVXYW1mVmc5ZWVhbWg1Yk5lUGJrYUlkR2JVYWhnWmFrZVdkbWZOZmplUWhWYWNmY2VjYlhob2I0YVNkeGVoZERhV2ZXY0pleWFjZ0hhQmJJZFFkMGdsaGFoZGJYYWhnTGhkZTNicGZwZlhld2gxY1liVWVEaHNjRmFPZ2llZGhZY1ZmQ2FkaEhoYmhRYzFnYWVhY0VmRmNCYVdoVWVzZTZkWmFuYkpnV2FGZ1dkcGh5ZFVjWGNkZlhmU2NoY1plcGhZZ1JiWmhNZUxhbGgwZzFhVGdHY0Zid2dWZ1djOWFhZlJneGQwYWRkVmJWYkplMGRhZDNoTmM0ZlpnMmNwZExmRGgxZUlmUWVaY0VleGUyY2RibGRJYmZmSGhIYVJmY2dFZ2tmc2ZZZ1FhMWRsaGlkY2RuYkJkd2hTZ0Vic2hCZlZlQ2ZVYXFoQmNDYU1oMWZQaFFjNGdKYVZhUmRjYjdiUWh3aHdlcGhSZFhjOGNxYUFiU2hjZlRkV2htZWhnZGRSYmdhQWhWY1hkemFJYzljQWZrZ3dhNmZOZDFoOGFrZEhld2hOY1FlUGJTYzBiV2NCZldoWmdTaE1jeWJnZGlkSmRCY3dlZ2RGaEVlY2RWY1NhVmVsZVNhSmZtZUpoNmNPZ0dhZGJxZFNjd2U5ZlNnRWNHZFJiTWRkYW5kWmdTZ1FmaGRVYnFhTWcwZFloZWNTZGdhMWhaZWFkbGZoZndnY2JFZ2hoRGZTZFZlcGExYmVoRWR0YjNhZWNtZmxkWGZXYVViUWdaZWRjZ2V0YVVoZWVUZ3NmVGdiZDBhZGd6ZkVjMGNkZ29hRmZVZGhhUWJSaHhiQmNtaGNnbGJZYlZjZGhYZ0poWmFmaHdlTWZDY1hoemhwYnZoYWdWYkFodmdVaHlnNWZtYmZlSGJBaEJjSmR4Y01nVWVFZzJkSWRaY0hkU2FOaHJiWmNuZDlkTmZZYWhnOGhQZlhoeGdCZzFhV2huZjlhL2NYYW1jZ2FWYmVnSGhZZFNiU2J4aGhnRGdXZ1dkSmN5ZmNmSGVCZEliUWcwaGxiYWZkYlhnaGZEZElmemJJZmdmQmNGYWRmdmhWYlNhZGJjYlJjWGJJYlJmQWQyZVplTGFXYVJhTmhIaGFlQmJWZElkVWFFYWNnUWNaYW5oSmdXZEZhV2dwZnliVWZYZGRhWGFTY2toUmFwZlBiVWJvZFloYmNrY0FhdWJMYXphSmQrZUtkaWNjY1RhQWdGZlVjZGZVYTBjOWgwYWZoV2I5ZjJkWGJuZjliQ2FCZm5nZ2NRZFpjRWR4YTJkZGdsY0pnQ2RGY1hmaGUyYkVja2dzaFlhUWQxaGxmaWNhZEhoQmRoZFhla2NOYlVmUmYzZVVmc2dZYlhkZGY2ZWFiVmVkZ1poRWNCY2xob2JDZzBhVmN2YUVjUmZOZnZmUmgzZk1hTWVSYTJlQWFkZkhkQmNnZU9mUWEyZWdkTmVIZmxnd2h0Y09kbGVGYnFnVmZ4ZDViZWFJZERlSWNZYVpjeWFwY2JjTWVXYTlodGhjZkZjMGQ3ZUVkZ2g1Yk9lRWN5Y29jZWVPZnpieGU2YWZna2YxZzZkUWNnY1pmNGhFZUdmUmhNYWRlbmZaY1NjUWRoY1ZmNGRkYmhlSmdMZUdiRWhOYlplWWJtYWhod2hlY0VlQWNYZ0FnUmdNZG1kZGNqYVFmL2FNYXlhNGRmZ1dmUWEwYVpkWWNGYzhnTmZKY2tiSWNkZkVlQWQ4YzZjVmZBYjlib2JDZVZhUmFRaEVieGJsZW1kTGVsaFllZGFQZ2plb2ZZYkpiRmFrYjFjV2FpYVlmMmFGYmdlWmU0ZUZjR2c1ZzNjZGEzaEJmWWRiZXdmNWNPZ0ZmQmFSY1plZWNIaFJncmZlZ21hTmNOZGFoa2dzZlBiVWVoZUJka2ZUZUhoWmUyZ1Vja2RJZlZnZWFIZjVjR2VBZTFmRWRRZ1ZkeGgwZCthUGN5Y2RoSWVYaGtibGdTYUlnVGFBY0NjSmNIZlFjV2ZHYXhlWmZIY0djWGFRaFhlUmVUZXNnWWFFYzJobGFIYVpjUWhaYlNnZWd3ZEJoQmJYYkdjMGdRYVpobmdKaFdlRmZXaHBheWRVZlhiZGVYYlNoaGJaZXBjWWRSY1liWWVaaGhmUWMwYlpkamEwY3NnVmRXY2NhT2ZEYzFoUmdPYldleWMwaDhkSWdqZjBocmRUY1doeGFXaERkMGJRZUZmY2dWaDljamVmaDFjdGZPZ1BhM2FoYjJiRWZraHNoWWdRYzFobGFpYWNlbmRCYndkU2ZFY05oSmREY2plMGV4Z0dmRmgxYjZoYWFWZ2RlWmJFaEJhbGdvYkNjMGhWZnZmRWZSYU5nbWRYY0Zoa2dUY1JkMmJnYlZjU2JGaEJiSGFFZUdoWmd5YUNmeGh4Zm1nV2hGZkZiM2JWZDBob2FXYmFiV2RFZldiR2NHZFljY2NMZG1mZ2V4YUljaGNvYzdhRmVSZE5mRWNUZVJhQmZjZkpoaWZRZnVnSWNoaGtndmZKYTBhb2FVZFJkR2JSY1JjZGJqZzVlY2ZFY2thY2UzZEllbGYwYWZlUWJSZU1mY2ViZENiQWYvZEpmQWVSZURiVmNGZW9kemNMYlFoVWQwZUxjaWZBYVliRmV4Y0FmUmFQYkFnSmhGZE5nRGRzZlRoYmQwZWRnemFFZTBjZGNvYkZoVWFoZVFnUmR4YUFmd2dNY3dmUWVWaE9kSGZKY01oZGQxYjhiZWNYZGlnQWF5YkdkR2RjZHVkWGVTZUVhdWZZYVdleGFKYmJiMGJ0YlJjRmhCYzBhSmJVZGllQWRqZU1iemNCaERhRmJRYWRhQWNCY1FmdGdPZ1RhSGJaYzJmVWhrY0lnVmJlY0hjWWVTZ1NneGZoaERmQ2F5YmNlbWdKYVNiSWZHZ1FkMGNGY3diZGRYaGhnTGFkZTNjcGFwZlZmMWdraFFjR2hXZWdoTGFSZ1dhOGNaaFFnV2I5ZGFoY2F4Z3NnVmhhYkFjbGZVY1VlQmNNZ1pjWmJpZzVoV2VIYlRjaGF5YlRhMmVsZ0pnU2ZoZzVmNmJjZHhiWWVWY1pja2VCZ3ZmYmEyYmhlOGNmZDJkOWhhZlJheGEwYWRhVmFWYUpoMGdhZDNocGJqYVRoV2VwYkxlQmN3YVpmWWVMZ1JoOWQ0aENkUmU0YU5mUWNuY2hocmRFY2xoMGZOZFZha2hwaDNjY2VuY1pjd2VHaGtmcGNGaGNkSGNWYTRiU2QzZ2RlNmNhYVZkZGFaZkVoQmJsZG9lQ2EwaFZmdmNHZVVkY2JuYkRhaWZBYmRjT2FDYkJkY2FEZXhnaGhIaERoV2VZY2dmVmNnZnRkMGJiZ0ZmRmdtZ1FlVWJNYmFlUWcyYUVlV2FHY0djWWVVYVphbWdaZWhmY2dGYlZldmhXZmtlY2FkYVNkUmMwZ2JoSmMwY0ZlNmZZZDBkMWFxYVNld2U5ZlNlRWdHZ1JiTWVkaG5hWmhiaFdnVGI5ZzRlZGJoYkplTGVHZUVlTmJaaFllbmZKZHdiTGJVZEZjUGdZYTFmcGgxYWVoRWF0ZTNhZWVtZGxlWGZXYlJmQWFSZUliQWFVZlZmUGdWYzVkSGFJY0JmTWhxaFFjd2dKZ21hUmd3YWNjRWdCYmtoUWdqZEFiQmM5ZVNjSWZpZ1pmUmZhYmxiY2FDYUdiRGRrYnpoV2dVY3dicGhRY0RlOGMyZ0pkSGc0Z0hlSWFBZzRjVmNIaFFmQmRWaEZiQ2RFZWxnT2dUaGNnRWZKYlFoVWZQZldna2NSY3RhVGZDZzFiY2dVY2tlSWJWZ2VlSGJZZ1NnU2h4ZGhjRGhXZVdhSmZ5ZEpiamZFZGFnUWJ4Y3RhYWRhZ0hjaGVEZkliemVJYWdmQmRGZGRldmRVZFNmRmJNZkRlV2I4Yk5iRGYyYzloV2FaY1JicGFIYU5hQmhVZmNmR2NBYTVkRGFhYkFhMGNhZVdkamMxZXBoZWMzZGRlWGZTZGhjWmZwaFllUmVZYlliWmFoYlJmbWdaYWplTWExYUFoVGhvZkllQ2RSZTBiVmFmZzFkSmMwZ2FiM2ZwZGphVGNXaHBiTGVEZzFiSWJRZFpjRWR4YTJnZmZnaEJnQ2RDZkhlaGMrYVFlRWVzZkdoWGRVZGRlaWVKZW5ibGd3aEZmRWROYkJmQ2RIZlZla2VWaDNhZGd5ZmVia2RWYVpoSGVSZWtoOGFBZ2tieGRtaEhjVGRsZHZlUmEzaE1lVGFSYTJiZ2FWYVNhRmRCZUhnRWJHZ1pheWhWZ2hnMGYrZU9laGFnYmtmV2hUYlZkYWdKZmphWWhXYkJlV2RZZkNoY2YzY05ieWFaYlZhVmJwZldhaGdVZlVjRWRYZzloU2NkY0dndGE2YllnMGIxY3FhU2V3YjlmU2ZFY0dkUmRNZWRnbmU0Z0dhQ2ZsZXdlcmJlaEdlMGNEYVVjUWFRaFJiWWRtYjlid2FJYmtmaGJkZVZkMGNSaDFnYWJWYjFiK2hkZWtiTmdYYVdiUmNBaFpnYWRBYXRlRmNiZXhlRWFUZGJlMGRkZHphRWV4ZE1lZ2dYYUJldGQ2YVJmeGJCZ21oY2VsZ1lmVmZhZG5oSmRSaGRkMWdkZktoSGYzY0pmTGdGZWhlaGJtZ0ZjR2NaY21lWWNYZEJiVmZiZ3dnZGhPYUVlVGJkZFZmVWJuYlJkcmZlaG1jTmJOaGFia2JzYlBiV2FsZGhjcWFIZENjUWU1Y0JnZ2ExY0JhSWhTZVpmWGFSZ1Zlc2RQYUZkaWF3ZzNiY2FHYjFmSWNCY1Jmd2FVZk5haWF3YkNkT2ZEZFJkcGRYYjFnQWJRYlFja2VJZ0xlUmNXaDhhUmdFZzJlOWFIY2NheGdOZUhjYWFCZ1VlYWdGZ1JiTmFGZ05nRGJ4Y1dlV2R5ZDhmbGRVZlRkOWdmY0hobGU0Z2djTWdoZGhlbmVLY2xmc2J4ZWFjbWFFZGthSGRTZVlkSmJTZVdmSmNWYkhoQmNVZjhhWWhtYUZkSmRUYVdhcGFMYURmMWZJZVFkWmdFZ3hmMmRkYmdnOWJMZEdmVmNKZTJmRWNrYXNoWWZRZDFhbGNpYWNlbmNCY3dkUWRBYnBiSmVSaDNiVWdEZk5kbmE1YTJjUWQxZGRiWmNFZ0JkbGZvYUNiMGJWZXZnRWhSaE5mbmZBYW5hTWRPY1JheWM1Z0FhQmJoZ01mVGVXY1Nka2M4ZVZjaGcxZWpiY2JnYXBhZGdWZzBib2NXZGFnV2VFZFdkR2JHaFllVWFaaG1hWmZoZElhaGNBYjdlRGV4Y1ZnVGJIZ1JoMWVKYlhkbWV0aDZkWWEwZTFocWFTZ3dmOWJTYkVoR2JRZFJnZWNEZmNlQ2NFY2xma2RoYWZoa2FCY0hnR2hBZHBoUWRhYjNjNWdhY2NjRWJoY0RlU2VWZHBiMWdlY0VldGIzYmVkbWRoY2ZlRGIxZjliUWFMZ0FndGVWaGJleGNBZ09mY2draGNlMmhFYjBoRmZ1Z0ZjVWdBY0ViU2hWZ1VmK2hJZWhobGdIYVBnaWZGYVJmYWRsZWNiUGFIYzJjQmU2ZFBoQmVoYm1oRmhHZ1pnbWNZaFNlMWJjZ1pld2Y0ZVBiVmRFYTVnY2JTZlZnNWFyZmVobWJOYk5hTmIwaGNhbGFVaGhhQmNraFRoRGJBaGpmSGFBZkZiQmJNZFRjbGVjZ1NmeGdBZFhhVmNXaEllZ2JlZVhmQWhUZWFoVWVsY2FhZGVYZmhoTGVkaHlmd2FvZ0JiVmZsZVpoRmFXZ2hoT2dYYmtlVWRSYUVoMmY5Y0hjY2V4ZE5kR2VZZUZnTWZkY0hjZ2NSZEVkTGV6ZjBjWWFGZldmSWI5ZVdoSGhjY01jWWFCaFplcGNZZlJlWWRZZFplaGhSZG1kSWJEZlFmK2VGZWpnc2RUZ0NlRmhNZmRkSGJWYW9kZ2haZTNnb2J4ZlFhV2NvaENlQWcxaEpjVmJiaFVld2N0ZVhlRmdKZUNkRmJYaGhkMmJFZmtkc2NZYlFoMWZrYndnTmZ5ZFFkbGNHYmdjMWNKYURmamEwZXhnR2hIZmNoemVKZndoUWVOY1VoVmZjY3JmVGVnZG9jcGJFZ1ZjdGhGY1JoM2ZNZlRiUmUyY2doVmdTYUZjQmZIYUVkR2RaY3llU2JSZlZmaWdlY2dkVWEvZkhkaGdrYVlhT2V5ZFJmYmJXZ1NhOWFhYUllaWJNZ3piY2ZFYmhmdmVGZ0JjSmZSY1VkVmF4ZWVlWGZtZ3RhNmNZaDBmMWdxZFNjd2c5YVNiRWhHZVJmTWRkaG5jWmVTYlFnRWdZYXNmSmdGZnNkRmNYYTBhRmFaYmZkMmQ5ZXdkSmhCaEVoVGREY0JmVWd6Y2VlQmY5aGRiZWRtZmxmWGVXZ1JoQWhaZ2FoQWh0ZEZmYmR4ZEVjVGRiYTBhZGF6YkVlMWdoZm9mVmFFZ1loVGNCYmxid2RxZmVkZ2NKaGRoSWR5Z0ZkZGZkZ3dmTmdHYUZmamd0Zm9hUGZCYWhnbWhGZUdiWmJtZFliWGdCaFZhYmgxZnBlSGZIYlJkMWNWYVVhbmJSaHhnZWFtY0VlWWVKZEFkOWVLZ0ZkRmhraHFlQ2FUZkpmMGRVaGxjOGdJZGVmQ2FKYkxnR2QxaDBhTWNIaDJhSWFnZVdibmRCZUlmUWQwZmxnYWRkZ1hhaGFMZGRlM2FwZHBkVmMxZ2tmUWJHY1dhZ2NVYVJhVGF3ZmZnVWZDZzRoTGFQZ3hmc2NUZkljRmd3aGJkWGhFYmRoRWRiYzFmaGJXZkZkV2dwY3lkVWRYY2RnWGRTYWhoWmRwaFliUmZZY1ljWmdoaFJobWdmZkdoRWZtYkdoaWFZY2VoUmIxY01oVGZGZkFiSWhrZkpjeWFOZXJlR2FTZElmQ2VYZEZlNGdRZkpiUmU0ZHhmSWh4ZDhoSGNXZ3ljd2FsZkdjMGhJZ3lmUWExZWxlaWFjZG5mQmV3YVNkRWZOYUpiV2duZVZjNGhVaFhmY2MwYkxhQWJCZ1pmV2RCYUVkOGZCZTBmVWI5ZUhmUmZNY21nU2YzYU5jV2ZUZW5nTWcvaFNoRmVCaEhjRWRHZFpjeWdWYWhhVWczZldkRmNGYzNnVmUwaG9oV2VhZ1dhRWRXYVhhamdOZ2FoSmVUZUlnb2dQZXhldGh2aEZiRWQ5Y0pmRWJWZlVmQWJlYUdic2h6Z2JjMGgwaHZnUWJnYjhmSmVPY21hUmVNZmRjbmRaaFNhUWNoZFZjNGRkZ2hmSWdaY1hoUmJjZ01mTWJEaHhnd2NjY2hnMGNOY0RiUmE4YXpjTWhRYVVleWZQZ21kdGNYZFJmQWIwZlphUGVGZUljVmJLY2xhNWFWYmJod2E1ZlpiRWIwY2Rnb2hGYVVhaGRRY1JoeGFCZW1iY2JsaFlkVmJkZVhlSmZaZGZhd2FNYkNnWGF6aHBldmFhYlZmbGEyYkJiR2NaZDdiWWZXZlpoQWdlY2tmbGNTZEhnUmJ0YlZoQmhuZTFobmFVaEdiTmVOZGFla2VzYVBjVWhoZEJla2dUYkhhWmgyYlVia2NJZFZkY2VDY0pmYWFBZ2thdGJOYkphaWZOZ2pjWmNuY0JnVmJRaHhoMWRhZWFlMmJaZFZjZGUyZXRkL2VYZ2xhVWY2Y0dkV2ZnaExhUmdXYjhmUmFFZDJlOWZIYmNleGFOY0hnYWFCZVZoQWZCZUFnOWZaZE5jWGN3YXBkVmFIYmxhZ2RVaFdlcGVYZVhlQWROZDhiY2NnaE1mWWRZZkJkUWgwYmJhMmYxYWFjVmZXaDljYWJSZHhiMGVkZlZlVmNKZDBmYWYzYnBiamhUZldicGZEYldneGdwY1piTmMwaEliSmdOYTBhWmJhZEZhV2NWZTJoUWRFaHNnR2VYZlVkZGVpZ1loMmdaYzVjUmJHaGxhSmhXYm5mVmM0aFNkM2NkaDZhYWdWZmRmWmRFZEJmbGhvZUNheGFFaG5oV2NFYkJobWdiYlhoTWNUZlJiMmVnYVZoU2FGZEJiSGhFZkdiWmJ5Y1ZkZ2Y5Z3FkZWhsZmtoamFIYXdoTmVGY1pieGY1aFhlQ2ZIZFllVWJlYjJoWmN4ZWNoQWhsZHZlRGFraDRnUmVOYzFiVmZTY2RoR2h0ZTZjWWEwYzFjcWJTY3dkOWVTYkVhR2dSYk1nZmNpY0lmYWJDYjBnWmEyY0NlVmJOYWFhRGRraE5nRWdZY21nSmV3aExnRWdnZFJkUWdGY1phZmdlZkVldGgzYWVnbWFsYVhhV2ZSY0FjWmJhZ0FodGRGY2JleGFFaGJhT2d3ZzhhNmhRYUVma2VYZ1ZlRmR0YUNiUmZ3ZTFlbWNZYWxkWmZKZ2FnamF0YVloZWgzYzFhS2RGZW1nbGhoZUZkaGJoZW1nRmFHZlpkbWdZZFhmQmRWZmJiMWhJYlRkVmdWZlFhR2hYaEFnc2FxYmJhbmJ0aE5nZGgwZHNmZmRVaGtheGZrY0NhWGI5YjZiZWVFZkliVmVlZUhhWWRTZ1NkeGdoY0RjV2NXZEpieWRjZEhmQmNJZ0Zod2VFaFRlSmRuYkZlUWdYZVhmcGhwY1ZkMWhrZ1FnR2hXY2djTGdHYUVhVWNSY0VoMmQ5ZkhoY2h4Zk5mSGJhZEZiTWRkY0hlZ2FSYUVoTGd6YTBhWWZGY1RkbGg2ZEJnWGI1aFhmRWdUaHhhcGVZaFJoWWVZY1pmaGhSYW1oWmVtaEZhd2RCZ3lhb2dPYkVna2c5YlRiVmdWZXBjZWZhYjNmcGdqYVRhV2VwZUxjRGQxYUlmUWVaZkVieGcyY2ZoZ2ZZYktnWGZDZXRlNGZiYlFlb2NJYVVnMWNsaC9nY2FtZVplbGdYZ1ZnQmhjY1dlbmZOYzRnSGIzaDVkMmFRYzFlZGdaY0VmQmRsZG9mQ2MwZFZidmRFZFJnTmN2YVJjM2Z0Z0hoRGZ5ZkZmR2JSYWlmOGdHY0FhWGNCaHljU2J4Y1VhK2JjYmtnOWZwZ1NkVWNvZEhiZmYyZGdjYWdNZG1mWWRVZFpkbWdaZWhhY2ZGZ1ZidmNXZmthY2NkaEhiVmEwYUdmUGRDYklhcGhiZ1RnSWZyZ1doQmIxaFNnRGVXZlJkY2RmYzNmcGc0Z1FnaGZWYjRjZGRoY0piTGFHZkVmTmNaZlljbmZKZXdnZWJCZXdlTGZBY0FnbGQ3ZkJhd2NwYWpoWWhtY2xkS2VXZVFhQWRRYlpiQ2VGZ0ZjYmJ4Y0ViVGJiYzBoZGN6Z0VjMGhkaG9jRmZVZ2diRWNEYjFia2IxZFdoRmNZYlZmYWFuaEpkUmJkZjFkZGRLZUZmbWhsYW9kRGFUZkpibWFGZ0dmWmhtZ1lmWGdCaFZjYmJ3Y2RkdGFIZFJlMWNWYlVmbmNSZ3JnZWRtaE1nTGdQZXdlVmZNaEJnbGdraHJnQWRuY1lmM2dXZ2hnWWhaZWVkQ2dRYmJlU2YwaE5lcGJXY1dlSmF5ZWNnSGRCYkloUWEwYWxoYWZkYVhnQWFaY2RiMmNkaHBmQmJWaGxiTWVSZFdmZ2RhaFZiV2JZZGRlT2VXZzlnSGVjYXhjTmRIYWFmQmhWYUlmVWFFYmNiUWNaZW5ob2hDZVhoU2NNZGhjWGN3YWdmV2JXZGdiWmZwZWZlQmFZZEloYmZ4aGhoTWRaY21iRmV3ZlZiV2g5ZGFhUmR4ZzBlZGZWY1ZjSmQwY1loeWM0ZHJiQmREZWxiRmFjYUJiTWRCaGNla2d4Y3JlZGJrZEpjTGZHZlZkSmEyZ0Vna2FzYVloUWgxZmxjaWJjZW5nQmF3Z1NjRWFOYkJoRGdqZzBieGdHZUhha2VGZEtmRWhSZExlRWVBZVJib2RHYjBjeGJqZk9heGJOZHZiUmczY01mVGJSZzJjZ2RWY1NoRmhCZEhjRWZHZDRibWRIYWxld2g1ZmZiQ2E0YjJkUWYxZUliV2hkYUdnRWdHYkVnWGEwYytnWmhtZ1pkaGJjaEZnVmF2Zldja2djYmRiSGRSZE1iZGJKZW1hdGV5aFNlVWcxY3FnU2d3ZTljU2VFZEdmUmhNYWRlbmRaZ1NmUWRraE1nNWJKY0JoSWJDZEdmRmM1Y1pnTmV3ZGthaWFEZ1VmZ2RmY0ZlVmVvYjdkUGNSZnhnM2hNZW1lRWY2Y0dnRWJSZlJlWmJsYXNkS2ZPYUJlbGhCZFljMGFkYW1nR2NraDVia2dGYlFiMWVRYldoaGhCZTJiZmdsZFpnYWVhYm1oOWZSYklnMWFrZkdiVWF5aGNhbWZRZ2xiQmE5Z1BkbWRaYW1oWWNYZkJhVmdiYzFncGVIZ0hkUmMxZ1ZjVWVqZXRocmNaY0djTWVJaGNmV2NFZVBhVWNoYkJoa2hUZUhoWmUyZFVia2RJZVZlZWZIYVphWGNTZ3hhTmFlYVdjWGVkYVlkY2VIZ0JjSWFRaDBkbGNhZGRoWGhoZExnZGMzZk5kcGVEZkhjTWFRYkdmV2JnYUxjUmVXZjhmUmJFZjJoOWhIZmNneGhNZFJjS2dVYWRnSWRIYWtoY2NOaFplaGI4ZlhiUWhTaEpnOGFIZURhNGhaZlFmZ2ROYmxmWWFWYmtkWWZhZnhkUWNqZ2JnMmcxY2FhVmJXZjlkYWRSYXhnMGhkZFZhVmRKZDBlYWgzY3BjamJUZVdob2ZZaERnMGU4ZVFkTmNBZTBoa2hKY1JiY2ZyZFdkeWV4ZCtiUmdrY1ZmTGdEZHhnQWhoY05iM2VnYTFkUmRFY01mTWNXY25iNWU0Y0JlWGI1YzJkYWhRZlZlUWhDaHpmTmhvZ0NnMGZWZHZnRWJSYk5hdmZSZTNnTWVUYlJnMmRoZkJiQWJCZGthVWdIZ2loc2huYUdoa2VFYmpoSWNoaDBkdWVYaDFoOGJXYWRnMmZGZFliR2NIZ2tiVWNLY0NhTWcyY2NhQmgxaG5jTmZ3Z1pnSmdWYVZoc2JDaE9iemJ4Y3lkTWJVYkZhcWZCaFFhWmFiYUVmSGU1Yk1iUGIzYzljY2JBZzFkRWM4Z2ZlbGN3ZE9mVGMwZ01nUmdhYWllRmg1ZGVlVmhOZXBjU2hWYnBoMWFlaEVmdGMzYWVmbWRsYlhoV2dVYzBoemFhYkFldGJGZWJmeGhFZVRnYmYwZ2RhemdFY3hjVWh0Z1FlUmgwY0NnQ2VSZ0FleWVPZWhjOWFHYWNmVmVoYVJlZGgxZWRiS2dGZG1nbGNoaEZma2RWZ01kRmdHZlpjbWRZZVhoQmVWZWJkMWhvY1JnWGRFZzlnVmJCYzNmUmUyZGVkamJoZW5lYWRrZ3NhUGdVaGhiQmJrZVRoSGRaaDJnVWdrZkloVmdhZ1djQWZJZlNkMWFCYkxnTmZDY01lbWFPYUhmNGhZY0RiQmY1Y1NnWmdHZTViSGNkZTJlOWNnZ1hibGRVYzZiR2VXZGdiTGZSYVdjOGJSY0VlMmc5Y0hhY2N4ZU5hSGhlaFFoVmJTYlVnQWI4Z1liQ2F6Yk1kQ2RYYldlUWhpaEhnaWVCZmZoV2J3ZlpibGRZZlFoTWJSZWJheGFoY01oWmhtYkZkd2NWZFdhOWFhYlJmeGEwZmRjVmFWY0pkMGRlZFdmQmNqYUJjV2RJZG1hVGdnYVpkWWdhYWhhd2E1YkljVmdwYVFhR2VYZmhoamRHZDBiSWVVZ2FjVmNsZ2lnY2VuYkJnd2ZTaEVnTmFKZ1dkbmZVZGxnUmYxYzFlNmJhaFZnZGJaY0VoQmZsZm9oQ2QwZlZmdmhWZ3hhTmR5Z1JleWhnYlRiVmVuZDRoUGJTYkJiaGNQYkFkWGJCZDdlV2hoYlZmN2dZY2tkdGEzY0hnMGdJaEhmZWJXZmdnYWNHZUhkUWZPZ1piaWg1ZHBjWWVsY3hodmRCYjFnd2MzYUhkVmNWZlNkZGVHZ3RlNmJZYzBmMWNpZkFnd2FFaENlUWRpZ3NlWWJPZlNlSWRMY0VlbGJCZDJjTWZFY0FlRWhWYlNoRWhRYU5naWVGZndiYmNVZmdmTmJRZEZlWmFmYmVjRWJ0YTNjZWJtYmxkWGFXYlJkQWZaZWFkQWRNaE5lWWNVYkZmQmRJaEJlTWE4ZVJkeGc0ZDRmVWhFYllnV2ZGYlZoOGNyaEhiQWdOaFllS2dEZGNkRGNkZTBjcGNLZlJmV2hCYXRkUGVCZGhmbWZGY0dmWmRtaFloWGFCYVZiYmQxZHBkUGhWYlJiTWJGaEFkRGRzZi9nTmRUZGNlVWRPZGdoNGJCZEZmRWdJZnJoQWZRaFVmaWdBZkFjdGhiYlBiM2hZZVBhU2QxZWxlS2hWYlVkaGZ5aGNkSGVCY0lnUWUwaGxmYWhkY1hnaGhMaGZnemNKYW5hQmd3Z3RkZmJUYlNjZGRmY0hhRGE5ZFVlSGVUYnNlSWNIZlVmWWdLZkthbGhBYmFoVWdGY29kUWRJZUNmY2NZaFZlamI0ZTdhSGFqZWxlWGhRaGhjOWVwZE9lamF3ZVlkWmdoY1JibWVaaG1hRmV3ZVZhV2c5Y2FhUmJ4ZTFiUGhFZEFhWWFoZk9nVGdSZGplV2YzZTljZWZIZUVoUWdRY2Jia2R3Y2lkUGZoYXNnUmNHZHdnY2gzZEFoMWEwYVljU2VGZGtoMmRPZGpha2dqZVJkamF3ZEljU2FtZ1ZkamdZYlhjZGY2Z2FiVmRkaFpiRWRCY2xkb2RDYzBjVWR5aEdhQmY5YUZnUmYzZk1kVGJSZDJkZ2hWZFNoRmFCYkhnRWJHZTRlNmRXZUVmVWE0ZlBjUWJVZzRiQWR4Z05nR2hMaEdlOWhDZlZkeGRWZkFiTmVDZThodmZOZDFoVmZ5Y1djZ2hGZ0lkVWR4Z1lkR2dQY1NhUWUwaFlnMGZVZStmUWZnZThmSmNPZ21hUmVNZGRjbmNaYVNhUWdoZlZjNGRkYWhiSmFMY0dlQmhkZlpnZmczZ0lha2FjZkJjUWVmY1NmVWZ0YmxnWWEyZUZiM2RlaG1ibGRYZ1dnUmRBZ1plYWVBZHRkRmViYnhmRmVGZExkaGVWY3poUWVVZGRlMWZGYlFjNGhyY0VmMmQxaG1lTGFnZm9lVmdKZ0RnY2dHY2RkeGU5YUNiUWVtZkJlNmJQZkJhaGdtZUZkR2RaZ21oWWZYZEJkVmRiaDFjcGVIYkhlVmRRaFRkVWduZ3hlcWRMaGlhc2NFY09jVWdWY0lmQmJoZWdkMmNSZFhkOWIyZUFkQWVkZkJnTGhTaFJmY2VTYTBmd2JMY0VjRGVGZDhoSmNEYThjbWRGY2dkUWVZZU1nQ2FwZURhZmduZlFiOWVHaENmcGdFZFNkeWFGZkZoQWJtaGRjRmdHYW5hUmR0ZGNneGdOYUhlYWFCZVZiSWhVZ0VmY2JRZVplbmFKYldiVWV5Z1VjZ2dVYlhiOWE5YVNhaGhaZXBhWWVSZFlhWWZaZWhmUmFtYVpibWZGaHdjVmdXaDhhTWVCZGtiOGJkY0hjRmZKYnBjYWh5ZjRocmFCZURjbGJGZVRlQmg1Y2ZhS2ZnZGxlK2FmZzFoNWJDY1VmSGRoYXJhRWNnaFZmZGZGZkZka2dEZUllQ2hJaHhlRWFVZXRlZmRUZ25meGcwYlNnemJoYjZoZGVGYmRnUGVBZXdjSmNDY0NnMGFWY3ZnRWhSYk5hdmRSaDNhTWdUY1JjMmZnZFZlU2ZGZ0FjSWhFaEhoaGd2aFZoZ2VWZ3FjZGRGYmRlZGZWZTBjb2RXaGFhV2VFZVdlR2JHaFlhVWhaZ21nWmVoY2NnRmNWZG5nRWQwZmxmWmFWYUFoTmhhYUpobWZKYTJiWWMwY1VkdmdNZUVlQWR2ZUVnSGZsYU1hUGMzYWdnQWJCYTFmZ2U1Y1BlMWN3ZlBkWGRSY0ZoWGVOYmphMGZlY0pjUWVVZEJnRGdBYmhnOWVjZVVkVWhqaE5nUmdvZURlQ2IxZmxiWGFMZndlTWhSZ1pkaGdnZ2ZnYmh3ZjViOWdWaEJkTmJnZFJkMGdGZVpiWGNEaHBhbWJjY2xlWWVWY2FjbmZKaFJlZGExZmRiS2JGaG1nbGJoYUZmbGhkZ3JmR2hVZXhibWFZZVhiQmNWZGJmMWRwZUhhSGJSaDFmVmZVYW5nUmFpZVlkVWJsZE5kYWNrZXNhUGdVZWhjQmNrZ1RkSGNaYzJoVWRrZ0phSGFQY1NkSmdIZEdhVmJaYkRnVWJTZ2NjSmJQZTNhQmdGaFFiMWNnYW5jZGJXZFZhTGdQZG5kUWY5YUdiRGNkY0ZnVmdDZnBjT2FGYzJmY2hZZ0hjVGhzY0lkQWNFYWNiVmNJZlZkc2hQZldlQmRNZ1poYmUzZjVkV2VVZkdjUWI0YkhjamY0ZlpnUWRoaFJmcmZhaEFnMGZ5YVpnaGdSaG1iWmVtY0Zod2dWaFdlOWNhZFJmMGJBaFVlV2dYYWhmMGJhZDNmcGhqaFRmV2FwaExkRGIxZklmUWRiZEFjUmY0Z0phZ2JBYk5oUWdUZWNlaWVTaHhkdGVkY1RiUmNnZW1kTmhuZEJldGNTZ0FiVWVjZUZnRGJZYXNmQWdqYWdhMGdhZlZoOGdOYkdlUmVrZ3poSWRVZlZidmRFYVJhTmV2aFJoM2VNY1RkUmIyY2diVmVTaEFhWWNHaFFmbWdZZGdlVmVnZmhmcWJKYWhla2YraEJlRWNSZHBlS2dIZEViR2FHZEdiMGNVZE1jbWFnZGVkTWJVYVZoL2VWYm1mMGFkZ0hhVmZWY1NmZGhHY3RoNmZZYTBkMWNxYlNhd2E5ZlNjRWVDZjFjTWJhZzNoWWVBZFFmZ2F0ZW1hYWRCZkpnYWREYmxjaGV6ZlllbmdKZXdmY2VFZmhmRGJTaFZjcGcxaGVjRWV0ZDNhTWUyYmxlY2NSZ0JlQmdOZUlmRWNJZVdjWWdXaDVkU2NmYmxoRmJ6Y0dlRWRjZThkR2Z6aGNhUmhWYmdlWmg5aFdiRmVZZVZjYWRuY0pnUmZkaDFkZGNLaEZobWhsZGhhRmdrZjRmbmRSaG1oWWJqaFlmV2gxYVZhSmJsYnBmWmVBY3dlTmdWYlFlMmhKYndlVWNHaE5iTmRhYmtic2FQaFVkaGZCaGtkVGZIZlplMmZVYWdhY2dWZGNiMmFzZFNjSGUxZ0FmS2ZDZm1od2VOZE1hV2FOZWFhUWUwaEpjYWZJYlhhWWYwZ05hbWFsZzdlVGVIaE1hUWRHYldhZ2RMYlJoV2M4ZVJjRWQyYjllSGFjY3hkTWZSY0tmVWNkY0ljSGUwaGNhTmRaZWplZGVXZ0NlM2VSZHNiVWJXY1pnQmNVZlRheGdwYVlnUmRZZ1liWmJoZlJjbWFaZG1kRmZ3YVZhV2U4YkljQWZrZWxhSWRCZHhleGcwYlllMWJCZGpnVGhXYnBjTGNEZDFjSWhRZ1pjRWZ4ZTJhZGRsZ0pmQ2NGZ1hlQWE1Y0Via2RBZUZiUWZ3YTBncWhPaHlmTmYrYk5id2VKYWRiUWhuZlZmemZTYnlnTmQwY0ZnaGFaZ05jQ2VCZUJia2FJZlViVmJ2Y0VlUmZOY3ZjUmUzYk1jVGZSYzJnZ2NWZlNlRmhCZUhlR2REZUlnNmNIYjBhWmNrY0RkUmZCYW5kUmUwZ29oTGNhZFhlY2JEZkRnWGVVY0JjWmFtZUJlaGVJYmxoeGRqaGNmRWVjaGRkSGZWZlZhU2JkY0didGg2YllmMGIxaHFlU2F3ZDlkU2JHZERiQWhFZlBoeWRWZWNkUGNWYlJjcGJZZEJlSmZXYUdoRmJWYk1lZGgyZkZhbGdjZ0VjNWVEYUFmRmFOYjVkVWJrYXRoM2JlaG1nbGVYZVdlUmJBYVpmYWVBaHRiRmZiaHhnRWdUZFpkeGhNYTdoV2NoZFJibWZhZGdnbGZEZ1ZkUmRCZDdoY2JrYUFoQWRmaDJjRmZFZGRnMWZGZUtjVWgyYUJmdGRQYkJnaGRtYUZnR2ZaZm1nWWRYYUJoVmZiZDFmcGdIZkhiUmgxY1ZoV2JpZEFjamRNaHpkQmJEYUZmUWJvaGJkU2JoaEJhNWZUZ0dlQmVqZ1JoMWVFZkFkZWdIZUFlU2hCZUJkRmVQaGNiMmRKZHljY2RIZ0JoSWJRaDBkbGZhYmRlWGdoZkxnZGUzaHBhcGVBYnhoRmZaZlNha2ZJYUxlUmhXaDhhUmZFYTJiOWdIZmNjeGROYUhkYWdCZlZlQmdTYTJnMGZRZ1pjbmFKZldoRmFXZXBkeWhVZVhhZGdYZUZmeGM5Y2xnU2R4Z1lmWWNaaGhiUmRtZ1pibWdGZ3dnVmZXYjllU2hEaHhiTmJOYkJleGgwZmdnSmVDaDRhNmhIZVNlOWFGaFhoQWJkY1NjTWdCYzRlM2hOZ1FoWmhDZUNhSGVnZXdnUmJ3YlZoYmdGZHhoQWN0YVBhSGZCYjRjSGNFZXBiSmdBaFZjOWY0ZlNjM2dkZjZoYWhWYWRjWmRFZkJnbGNvYkNoMGZVZzllVmRFYmNjNmFGY1RmMGVUY0VneWNCY2NkR2YxYjRjR2dWZENlSmI2YkFiaGJzY3BhUGNoZjRoNWJFZGtiSWZmaFpkeWI5YVRlWGR5ZGRhQWFJaDJlNWVvZmViVWE1YkZjV2draGNjZGZIYVZjVmZTYWRmR2d0ZzZhWWF4YUJlamZSY3liVmZTZEVnR2hSZk1nZGVuZFpoU2RRZWhnVmc0ZWZhbGVwZEZoU2JCZkVkV2NOZmpoMGJrZ0tkUmhnYUdkUmZ4YWNiZ2hOYkJmOGErZUtlaWFVYU9hV2dRZzBlWmRMZmxmNGFMYUxmRWFWYmFhSWNBY2xiemdHY3hkTmNoZkZnUmdOZzZnUmR4YUJobWFjZWxiWWVWZWFlbmZKZlJmZGgxaGRhS2ZRZENjZ2R6Y0Zha2ZwZ21iQ2RXZVlkeWJLYlRha2FHZVliU2JVZ0dhRGFRYjFmWmhlZUhhUmNyZGVnbWhOaE5jYWJrZ3NnUGFVY2hhQmZraFRiSGFaZDJmR2YwZ0ljSWhlZkNiSmdhZEFma2F0Z05jSmVpZU5lamdaaG5leGVpZVFjMGdsYmFiZGVYY2hlTGVkaDNlcGRwZFZkMWhrZVFnR2VXZWhkT2hSYVhnSWNSZFJoeWZjYk9mSWZCZTBjNGFLaFFlWmdhY1hkR2UwY1FlWmFuaEpkV2ZGZ1dlcGd5ZVVnWGRkZVhiU2NoZlpmcGNZYlZka2RZYmVmeGVRZ3lmTGVpZmdhamNXYXhoQWhiY1Vid2hVYlJjZmcxZkpkMGJhaDNjcGVqZ1RhV2hwZUxhRGYxaEllUWhaYkVjeGYyZlBibGJKaGZlRmVTYXhiNGViaFFnb2ZJZVVkMWNWZkloY2JuaEJid2RTZEVjTmhKZ1dlbmRWZzRiU2QzaGRjNmZhYVZkY2dYZ0VlQWJSZm9hWGEwZHNjUWRVaEFmSmY1YVNjMWVrZlRhUmYyZGdjVmdTZ0ZlQmFIZkVjR2FaY3loVmVoZFZkcWVjYWdiSmMzZ1Noa2dwZ0NlWmJ4ZzVmWGZDYzNnUWRZZ1RnR2VaZ2hlY2FGaFZkdmdXZWtnY2hkZUhjVmFWYVNmZGFHZ3RmNmNJY2thMWgzY1NmMWZ0ZWNmYmN5ZVZmWWViaG5mcGQ0ZVFlaGZWZDRnZGFoZUpmTGVHZ0VlTmFaYVlmbmZKZndnY2FFZWdjV2VTZFVjZGYxaEtla2Z0YTlhZWNpZ0ZkYmJjY3hnQWVaZGFmQWF0YUZkYmN4ZUViVGdiYTBkZGR6YkVoMGRkYW9hVWQwYmhiTmFSZTBoVmJtZ2JoRWZnZExkYWFtYU5oSGhiZEhjMWRLZEZobWFsY2hjRmVoYWhjbWhGZUdhWmRtY1liWGZBY1RoYmMxZUZnYWVIZVVlOWhWY1djSGhRZWxmWWVVaGxoTmJhZ2tic2VQZFVkaGdCZmthVGFIY1pnMmVVYWtnSmNEYk9mU2JRZVNhQmV4Z2hlZWRXYlNhUmR5YWJhbWI1ZFdkUWIxZmhnTWJiYmxlSmdMZWRhM2RwaHBkVmgxaGtlUWRHZFdmZ2dMZFJmV2g4YVpjVmNXZzljQmhiY2hiTmhSY2ZlUWZCZmJnUmhVYTRiY2FaZG5ob2VRaEZkV2RGYXZjVWJUYzVoWGVRaEJlWWVoZ2FnQmFvYVlkYmdsYWhobWRiZFhjeGR3ZUVjMmM5YUViV2dRZ01jZGNSaEVoUmM5YlpjM2hwaHJlQWRXaHBnQWNFYmxkSmNDZFpjRWVaYzJhSmFWaHRmWmdQYTNoaGcyZUVma2ZzY1liUWQxYmxlaWJjZm5lQmh3ZVNmQmhVZElnQ2dIYlVmN2RTaDJicGg2ZkpoVmVkYUhhRGNnaGRjb2hHZWxlTmQwY09jeGROZHZkUmczaE1mVGFSZDJkZ2FWYVNjRmZCY0hnRWREYlFnM2hBaGthQWQ0YVBmRmhGYi9iZmZVY29lV2ZhZldkRWJXZEdhR2ZZZVVhWmhtZ1piaGFjZkZoVmJ2ZFVmZ2FzaGRoR2cwY2hnU2FZaG5hNWh2ZGNkRmdoZ2poUmZ5YlZnU2dFY0dlUmdNZ2RmbmVaY1NmUWJoZVZhNGhkZGhmSmFMZEdhRWVzZlZoWWJuZWxidGZjY0FlRmdEYlFhMWFvYTdhY2ZVZGRiZGdlY21hbGdYZVdoUmVBZlpnYWJBZnRhRmNiZnhnRWdUZ2JiMGFkZzdlVWdFYWRhamdDZ0VkZ2djY1Jhd2U1ZDRoYmRGZFllRWRmZUhmdGNkZlhiVmFkaEtmRmNtaGxmaGJGZmhhaGJtY0ZhR2daaG1jWWNYZkJnVmNaZ3hmWmFIY0dhd2JCaFZlUmZHaEZhK2FhaFhhWmJFaFpibWdFYVBiVWVoZUJha2dUZUhlWmYyZFVia2dJYlZhZWVIZFloU2hTZnhoQWFQYVdoV2FsaHZnY2FEZ1ZiSWFTZVVla2VTY2ZkSGZSZmhlZGUzYnBncGZWYjFka2VRYkdiV2JnYkxmUmdXZjhjUmdFYzJlOWFQZE1mQmJOZ01iZGFSaFVhRWdVZEZoa2hPYmVhSGRKZkhhQWMyZk5jK2hlZTNkZGFYYlNmaGhaYXBiWWNSYVllWWdaZWhmUmJtaFplbWZGYndoWGZTYXhkYWdUZ0FiQWJkYkJkMWRKZytmYWd6YXRjcWdRYlVoQmRMZkRiMWJJZlFlWmJFZ3hiMmNkYmxhSmdDY0ZkWGhoZDJmRWJraE5nYmRRYzFhOWgvZWNibWJaZWxkWGVWY0JnY2JVZzNkbGRTY1NnM2FkZDZjYWJWZGRiWmFFY0JkbGZvYUNiMGhWaHZmRWZSZk5kbmhCaEhjTWFZZVdhbWNoYWNkU2RGZnBoSGhRZzJnOWYrZGZmQmNWaHFmY2ZsaEZkM2FWZTBib2dXZGFlV2RFYVdjR2FHaFllVWdiYmliVmdoaGRna2doZnZmVGdGYUliSWREY2tjQmJiZ2ViRWdGZzZhWWIwYTFlcWVTaHdjOWZTYkVnR2ZSZk1hZGNuZlpoU2dRYWhkMGI3ZGRoaGJsZVdmR2hBaFpkWmRhZkhjSWYrZmVoVWhSYnBnU2JWZ3BoMWFlZEVhdGYzZmVjbWVsYVhlV2hSZkFnWmFhYUFndGdOaExmQmFFY1ZiY2RrZ2RhbGhCaGxjSmQ3Y0FjRWhGaGNmYmdSYUJlbWNjZGxlWWFWY2FnbmRKZ1JiZGgxZGRhS2ZGYW1nbGdoZkhnbGF0Z21lSGUzYXRobWdMaG5kQmhmZ2JmeGhKZE9hRWFUZGRoVmJVY25hUmhyaGVobWVOaE5hYWZrYXNiUGdVaGhjQmJrZ1RnSGM0aGliR2ZnZ3RmR2ZkY2dhbGZUZVdnd2FoZkRhUmNHY0pna2JaZFdoVmJiZVZoa2NsZ2NkZGFTYjFkQ2RlYzFkQmhwZlZiMWFrYVFlR2ZXYmdlTGZSZ1dnOGdSZ0VmMmY5Y0hlY2J4ZnNoVGhJYkZjd2RiaFhkamdoZ1JmZGYyY1JoV2hDZkdicGFrZ1JmR2VKYUVoWGN4YlpjdmRZZVZiQWhSZmFmamU1Y21lWmFtY0Zld2FWZFdlOWZhZlJleGMwZGRiVmZWZ0pkMGNhZzNoSWgzaEJlU2FNZ1lmQWdTYTFmUmNkYjFjNWMyY2FnMWNKaFVkQWdHYTFobGdCYTBnc2FlY1FmeGdWZ3JoZmZsY3Bkd2JTaEVnTmJKYldmbmNWaDRjU2MzZWRlNmVhYVZlZGZaaEVmQmRFZzhnUWh3ZHdhOGNIYzJid2h1Y1VlMmNzaFRkV2dtaGdiRGhYZFVjVmZVYkJmV2ZaZzBmVmRsZVpkamZmZm5hdGQzY1ZmMGZvZFdiYWRXZEVlV2FHZ0doWWJVY1phbWFaYWhlY2hBaEVibmFFZ3hhUWgzZEhnVmhWaFNkZGZHZXRjNmJZaDBjMWdxY1Nld2I5ZlNoR2dYZTlibWNkZm5hWmNTZVFmaGNWYjRiZGdoZUpkTGZHYUJnNWZRZGJjbGRoZXdiY2hFYmhmRGhTZlZjcGExZmVjRWZ0YjNhY2ZpZ0ZkWmFDZVVmSmJXY1BlRWRRaFJlTmhrZ0ZmV2NZY1FoTWE2Y1JoVWJkZTFhRmNRZTRlRmdDYlZjTWV5Yk9oeGVsYmJkYWZuYW9kRmFmYmxmY2NSYVBkR2NsY2hiRmhoZmhmbWdGY0dkWmJtY1llWGVCZVZjYmh4Yk1kQmVIZFJmVmRGY1VhbWNsZjJkZWdqZWRnRGZGaFFjb2ZlZVJhQmhCZGloU2huY1phbWZVZmxkOGJJZWVjQ2NJYmNnTmJGZGxkUWFTZDJlSmYwZWRmbmRCY1liUWgxZlJoSGVkYVNleGdGZ0NkRGd0ZjliVGUxZEFmUWFRaGthSWJMYlJjV2g4ZVJiRWEyaDlnSGVjY3hoTmJIZ2FnQmFWZ0lkVWdBZDVkV2haZm5lcGVHaEZoWGFkaHZoVWJTYk5iWmNOY1ZlZGE1Z2NoUmE4Y1loTWFsZHdnMGdLaFRiWmZ3Y01jRGMwYUljQ2hFZjhkVmdWZ3hmWWE5Z1BkVGFNYXdlQmVDYlViRmNEZHhoQmhKZ1pkQmRZZnphSmFCYjFkQWJIZkdoTmFjZUVoa2VzY1lmUWUxaGxmaWFjZm5jQmd3Y1NoRWROYUpmV2ZuZVVieGJEZ1hmZGZ5ZGVkRmdkYkVoRGNSYWtiOGVCZlRmb2R1Y0FjUWhOaG1jUmR5ZUZhV2FFaHpjMWhIYkJobGZCYlBlUmRDaDRlN2FCZVJmc2M0Yk5ieGh3aDJjSGNnZVJkU2FMYURlTWhXY0JjV2haZWFnSWh6aEZlaGhPYUZjMWQvY1VkMGE0ZlJnSGVRYUVnYWNQaFRoaGRoZFNjVWMxYXFiU2V3YjliU2NFZUdjUmVNZGRibmRaYlNnUWhrZ2hmU2FkY2hkSmFMYkdlRWJOYVpkWWNuY0pld2JjYkVjaGFEY0FhQmF4ZjFiY2ZCZjliNWRQYlRlMWdmZERmVmVoZ1FnT2h3Z0piTWVSZlJmRWFUZGJmMGhkZ3pnRWQwY2Rmb2RGZ1VmaGRRYlJieGRCY21mSWdCYk5nQmVQZXljQWRmZWRjMWI5Y2dhRmdtZ2xjaGRGYmhiaGJtYkZmR2ZaZ21lWWhYYUJjVmhiZDFmcGhIYkhoUmJVZkJmR2ZqYzBjNGhkYkRmRWNJYkpjd2ZwZUdhSGJGZFFhaGFIZG5iWmZyYlVoaGRaZ2RhTWFTYVVhY2ZDY0ZlUWJNZkZleWJkYjZiZWFYYWxjRWVhY1VlbGRhZGRlWGRoY0xhZGQzaHBncGZWYzFka2FRYUdiV2hnZUxmUmRXZDhlWmFSaHloY2ZPZkllQmgwYjRkS2hRaFZiWWRVYkZmb2RRZWRobmF0Y2FhUGgyZnBkeWRVY1hoZGdYY1NmaGFaZXBjWWJSYllkWWhaaGhhUmRtZlplbWVGZzRoQWdTYWNiVGdGYUJhTmZpaEZoRWZOZ2lhYWMyZmRkamNYZVdlTmFIYUpmVmNJY1FhWmJFZ3hiMmhkYmxjSmFDZ0ZjWGNoZzJkRWJrYXNiWWJRaDFibGNxaEpoamNnZjVjR2MwYTBiMmNHaDJlWmZxY1NnMmJwZjZnZWRWZzVnVmFPZmhobGRvYkNlMGZWY3ZjRWdSY05ldmZSZzNjTWhUZVJkMmRnZVZnU2NGY0JmUGdSZ0NmNGI3YkJnUmRzaFZmTWIwZ1ZldmdWZDFmY2NXZGVlV2NnaGFhTWZtY1liVWFaYW1iWmdoYWNnRmFWaHZjV2NrYmNoZGdIZVZhVmFTZGRnR2JzZHVoS2Z3YVFoNWdZZFFoOWFTZEVnR2RSYk1mZGZuZFpkU2hRYmhjVmU0ZmRoaGRKYUxnRWJWZWhhemNZaG5kSmJ3ZWNmRWFoYURhU2hWYnBlMWZlYkVkdGUzZU1leWI5Z1hmVWRVZ1JiUmNJZlZiaGVMZ0toa2RBZmJiT2YwYjVoNmRPYlViZGdvY0ZjVWZoaFFmUmJ4ZEJkbWZjY2xkWWZWY2FobmJKYlJmSmdSZElkZWhRY3pic2F2Y0ZlaGdCZk1mRmFHY1pobWdZY1hoQmVWaGJkMWRwYUhhSGJSYzFhVmZVZ25nUmdyZ2VibWdzZ1poSWNnZUpoY2hYZEVoSWFoZUFhVGFjYS9jSGhBZ1poUWhLZm5nWWFQZlNjMWJZZEdhRGZtYUlmNmRlZUdkQmFCaFNna2hWZ3doZGdYZWhmTGhkZjNmcGVwaFZiMWNrZ1FiR2dXZmdnTGJSY1djOGRSY0VmMmJjY1RiT2MxZG9lVWJaYW1kb2hKYlFkRmRjYVFnZWIzZkpmSGVIaEdoWmVZaFVhWGRkZ1hlU2NoaFpmcGZZYVJoWWdZZ1pkaGRSaG1mWmVtZEZmd2JWY1dhY2NPZkRmMWhSZE9kV2V5aDBhMWZlYm1meGhqYVVlR2FwZ2JmQmRsZTRoNmVaaEVheGgyYmRkbGNKYkNlRmdYZGhmMmNFZGtmc2ZZYlFjMWdsZWlkY2VuZGdja2dBZEFkb2VhYlZhQWJvZjVnV2dHZFZnNmJkYkZjZGZKaEdlUmNWZUNmQ2IwZFZhdmNFYVJkTmZ2YlJlM2VNZFRiUmMyZmdiVmhTYkZiQmZIY0ViR2I0Ym1jSGNsZndnNWdmY0NiNGMyZFFhMWhJaFdkZGNHZUVlR2NFZVdib2UrZVpobWhaYmhmY2ZGYVZndmRXaGtmY2RkY0hoVmFWYlNkZGhHZnRjNmFZYXhia2FpY0FkbGN4YzRoRWZHYlJnTWhkZ25jWmdTZFFiaGhWZDRoZGdoZkpkTGRHZ0VnTmZRZmVjVmRoZ3dhY2dFY2hoRGJTaFZmcGIxaGVnRWZ0aDNkZWRtaGtmUmVGZWtkSWZaZlloRmYwaEVhUGJSZUZiQmNiZjFmcGF6aFJjMGZrZXJiV2FRY2NnZWJBZWhnaGd2YmZnbGFaZWNnYWRtYjlkUmVlZmtkWmhSaEZkbWJnYzFhWGdsaEVmMWFHaGllb2R5Y2FoU2FKZ2NkZGRGYXBkT2dOY3hnMWZWZlVkbmZSZnJkZWdtZU5hTmJhYmtic2dQaFVkaGVCZGthSGduY2dmbGRHZGdjdGRUY0xmQmZwY1hkRGNVY3hiTGdTZ0dmNWJ5Z2NiV2dCZkJlVGMwZWtnVGNmY25kTmhRaFhmWGZwYXBiVmcxZWtnUWJHZFdkZ2ZMYVJlV2g4Y1JoRWh5ZWtiSWNJZlJhTmNQZ1FjaGNWZElkVWFFZGNkUWVaZ25jSmNXZkZmV2JwZXlkVWFYYmRhWGZIaGxjNGhnZ01jaGdoZ0toSWgxZGtjbmdMY3ljOGYwZUVhRGYxZGFhV2RoYzFjSmJIZlJmc2huYVphVGdrZHZlQWhpY1FhT2VCYzFnc2hjYlRia2N4aDJlZGVsaEpoQ2JGYVhiaGUyZkVna2dzaFloUWIxY2xnaWRjZm5lQWdrY0FmQWNvaGFoVmhBYW9oNWdXYzJhZGc2ZmRlRmRkZkpoSGFEZE5lb2ZDZTBhVmV2ZUVmUmZOYnZhUmYzZ01kVGZSYTJlZ2dWZFNnRmJCYUhhUmVDYzRjN2ZCZVJlc2dWYk1oMGJCZGhiVmMxYmNkV2NlZ1dhMGQ4YkdmR2FZYlVlWmZtY1pmaGJjZ0ZjVmR2ZVdma2djZ2RlSGNWZ1ZlU2hkZ0RnOGV5ZUtiaGM1YWthTmNFZDVlQmFBZm1mUmFSZmRobWRaY2VkYWZCZVZjNGZkY2hiSmRMZEdiRWFOZlpjWWFuZkpid2JjYkVhaGVEYVNjVmdvZGhoTWNBYklna2hkZkJkWWhXZVRiUWNnY1pmZGhRZHRiVmZkY0Rjc2JUZGJlMGNkaHplRWcwZGRnb2JGZVViaGhRaFJoeGJCYW1mY2FoYzhiVmdkYkdiOWNSZlpjMGF4aGdlRmNtY2xnaGVGYWhnaGNtaEZnR2daZG1nWWVYZkJiVmNiaDFmb2ZPY0VoQmRCYS9iVWRuZFJocmFlZm1iTmJOZGFia2hzYVBoVWhoZkJka2dSYVZleGMyZ1Vha2FJZ1ZnZWZIYlljU2dTYXhkaGhEZFdmV2NKZXliY2hDYkpiR2VFZEFiRWJUZE1ieWZ3ZTVjUGZqaDBiaGNBaDFlRWVCaEViR2FRZ2hmUmhXZThoUmZFZTJoOWNIaGNieGdOY0hoYWhCY1ZkSWFVZEVoY2hRZlpjaWRZYmVoWGZEZWxkOGNBZ3pmSWVhZkNlMWY4Ym5mSmdWZk5nS2FhZkZiZ2J5Y2JmamNOZzVkVmRUY01iR2hiZFJkMGFkaFZnVmRKZTBjYWIzYXBhamJUZldlcGhMZ0RhMWVJZVFiWmJFZnhoMmJkYWxhb2ZXZlhhVGZFZWxjSGJCaGxiZGREZ2hnZ2RyYlBoRGJRZjFkR2RrZzBkYWNEYnpmY2RzZUdmVGVZZDVnUGJWZThhTGhHZVJkVmNDZUNkMGdWZ3ZnRWVSY05idmFSYzNjTWRUZ1JjMmNnY1ZmU2RGaEJjSGZFYUdjWmJ5ZkhieGFWaDBlYmUxYkZlamNUYjJhQWVXZGFhV2VFZldiR2NHZFlnVWFaaG1jWmZoY2NkRmhWZXZlV2VrZmNiZGFIZlZoVmJTY2RoSGVSZDZnYWd4Y2thaWJBY2xheGFjZ2JoeWJWY1loYmNuZFlnT2RYZHhnVmdwZmRiZ2M1ZVhnR2NFYnNmUWVZYm5mOWZ3YlpnRmNCZEtnUWFIZkJlMWhlY0VidGQzYmVobWdsZFhhV2JSaEFlWmZhZkFmdGFGYmJoeGVFYlRjYmMwZ2RkemFFYzFjMWdvaFhiRWFoZU9kV2RoYkJjMWhZYUhjd2RWZ2FobmhKZ1JoZGIxZWRkS2dGZW1obGdoYkZlaGRoZW1nRmdHZFpmbWhZZVhmQmRWZ2JmMGNWYUhhRmVVZ2tnZGhHZnliZGJsZUJjU2ZKYmViZWdFZHRnVGhUZnhlQmUxY1RoR2JwYXFoVWJrZnBkY2FlYUhjc2NTY1dnQWFwYktoVWRFYWhneWdjZkhoQmdJYlFnMGVsYmFhZGhYZmhiTGFkYzNhcGVwYlZoMWJrY1FmR2hXZWdjTGZSYlhjVWZSYVdjbWg5YlphYmhoaE5jV2VmYWpiOWZJY1VmRWNjZVFjWmFuYkpoV2JGaFdmcGd5Y1VkWGJkZlhjU2JoZVpjcGJZZFJlWWhZZlpnZ2N0aG1jYmVqYlVjNGJIaERleGZVZ09jRmN3aE1kUWExYklkb2dkYm5kcGJ5Y1RjWGNaYVhhRGUxYXBnWmFaYkVkRmcyYlpnMGZSZExhSGhGY0pkMmhFZWtoc2FZZFFnMWVsY2lmY2RuZ0Jid2dTYkVlTmhKZVdkbmdWYzRkU2EzYmRoNmFhZlVjMWFaZ0dnRWEwYmdjUWJoZFphaGViYWxmSmEvZlZoM2FOY1BmV2ZtaGdmRWFTaEVneGhiZ0VnQ2I5YjdhWGR3ZDViQWJjZGxlRmYzYlZmMGRvaFdkYWJXaEVoV2hHZ0dlWWFVYU5mQ2FNYTFkSmdRZmNkaGVXZ2hlTmRWZlZlQWRaZ0pjWGhtYXRlNmhZZzBmMWdxaFNnd2Y5Z1NjRWJHYlFmUmFmaDNmcGM0YVFoaGRWYjRkZGNoYkpjTGZHYUVkTmRaYVlnbmJvZzRmZmhoZWdjUmhCY2dnNGg2ZUxlQmJJZW5kUGIyZmNjWmhIY0ZoZGNZZVBjRWg1Y0ZnY2NoZkZhVmZPZmdka2N3aFJid2I0ZW5oV2gwY2hjWWRUYWhmQWg5Y1diRmZZZlZnYWNuaEplUmNkZjFiZGRLZEZnbWRsZmhkRmVrZzRhbmdSYW1mWWR5ZllkV2QxZ1ZnWmcwZ3hoU2ZDY0FkNWZBZlVobmZKY3JjSmhEZmNiRmVJZ3hlZ2VCZUxoVmRGZDBlWGRIYTlkMmNXYlVhSWJFZFloMWh3ZVNjU2R4ZGhmRGVXY1dhSmR5aGNmSGRCZElhUWUwYWtiSWhNY0Nkd2VlZ0pkVGVSYXBnWGUzZ01iUWFHZFdiZ2NMYlJkV2g4ZFJoRWEyZjljSGFjZXhlTmVIaGFlQmYwY2NlR2NBYzVhRGRhZEFiMGFYZkJiWGRwZXllVGFIY2RiQmJYZXdiTmY2aGRlQmRZZGVmWmNrY0JodmRhYWtjdGF3Y1ZmV2c5YWFhUmJ4ZjBlZGdWYlZkSmUwY2FnM2ZwZGpjVGdXYUlnZmZEZjBjOGhRZmJhRmVwYWpjWWUwZUZjWGFGZFhmNWYyYVRmQmM5Y1FkQ2VnYXBlc2VEZVRoRmdoaFhla2VwY0pmVWhYZ1Zid2NIYzNmZGZrZGRjMGJsaFpnQWdRZDlnaGVBYWtjbGNGZkVmUmhOZ3ZmUmYzZk1kVGZSZjJmZ2hWYVNiRmNCZkhiRWJHYlpmNmNBZWxhMGRqaElhVmc4Y0lmRmZsZHNiQWVhZlhkd2FXZ0RjbmFNZ0JkZGdYY05kaGdkZWxoVWI3Z1VmMGZzYTNmSGJWY1ZhU2dkZEdldGQ2ZllnMGExaHFhU2V3YTljU2ZFYUdiUmJFY0lobmRaZFBoUWFoaDFmdWdZaHdlZGFZZ0RlVWROZ2ZiWWJpYXdna2NPaEFhRWhRZlJmeWFVYTBkYWcxYWxlK2JlZ21nSmZYZ1ViVWZRZ1pnZGVoZlZkYmhiZndlQWdGZ1pma2Q1Zy9iT2NVZGRob2hGZFVlaGdRY1JneGNCZW1kY2FsZllkVmZhZW5kSmRSZWZhd2NNZkNhWGR6ZXBkdmJhY1ZnbGExaEJlbWhaYjdoWWRXaFpkQWhlYWtjbGRTYUhiUmF0YVZiQmRuZjFibmNVY0dkTmhOYWFla2NzZFBiVWVoZ0Jia2hUZUhlWmYyY1Vma2NJYlZhY2ZDZkpiYWFBZGtndGZOaEphaWVOZW1mYWhIYUJoVmhRYjBmRWRFZkljVGNBZUNnSmFIZFFmV2JGZWtiMGdJZUdkV2FNaExhVGRUZXNkUmREaFhhRmhaaGNjd2VKYVJmWWFSaHhmSWFWY2tkY2FHZmNiMmJkZkZlQWFHZE5kK2FlYTNlZGdYYVNnaGJaZXBoWWhSYVlmWWFaZ2hiUmRtZ1pibWJGYndhQWdTYmNiVGZGY0RhY2ZkaFZmVmJKZzBkYWUzY3BnamNUaFdicGRMY0RkMWhJZlphZmcyZ1poMmRkZ2xjSmhDZUZlWGRoZDJiRWNrZHNhWWNIYWxoQmJ1ZVdoSGRCZ3doU2dFYU5kSmNXaG5lVmM0Y1NmM2VkYnloSWNWZGtoSmdRaGxjWWg4aFJoQmZFZTJnUWRWaFplaGhBYWloSmJHYkJlaWNSYUdoU2ZFZzFoSGRXYkdlZ2dpZ0JhRmhvYStlUGFRZlVkdWVCZXdoOGhZaExjRGFBZFdiQmFXZ1pjU2RNZnlmZ2JpZkpkQmR3ZGdmRmNFZGNoVmNTYVZjeGNTYUxnMGZGYjZmWWEwZTFicWJTZHdkOWhTYUViR2JSY01hZGhuaFlmQWdCYzBoRWJ0Z0pkRmR4YUxnRWRHZ2xmWmNZaG5lSmV3aGNkRWRoYkRnU2NWaHBoMWFlYkVodGIzZ2VkamUwYWZlRWZFZE1jWGVGZTBhcGZSZmRkeGJFYk9hY2ZrZmNhbmVIZFRhZ2VwY0FjVmVCYVFmUWJSYlpkTWhjYWxlWWVWZWFnbmJKYlJoZGQxaGRkS2JGZm1nbGRoYUZjaGNnaHlkWGNDZzhlMWNiZHdnOGdVYWZnMGNwY0hlQWJBZUJlVmZCZ25mb2VVaE9kM2FOZGRiYWhrZjBhSmZlZUJhQmJrZVRoSGFaYzJjVWZrZkloVmFlY0hiWWVTZVNoeGVoZ0RnRGhTZG9kN2NJZjNhNGczZ0FkbGZwaElmZGFXaFZmV2hkYXliNWhuaEtjQmVnYURmQ2QyZ2diTmVRYjBjVWRSYkVhMmU5aEhhY2N4Yk5oSGhhYkJiVmNJZVVkRWJjZVFkWmRpaFliZWdYYkRhbGY4Z0xnamVaaEdhWGdCY1pkMGNmYUJjWmZNY2FjR2NzZm5hZGYzZmRkYWVWaFdnOWVhZ1JleGEwZWRmVmhWZ0phMGVhaDNocGRqZVJjSGFGYWhnRGIxZkllUWJaZ0VieGQyaGRibGZKZkNnRmhTY1ZkL2ZIZ21oRWdZZFFnMWJsaGlmY2huZEJmd2hTaEViTmRKY1ViamYxYjJhR2R5Y1VjMWZQZFJjZ2ROZVNhVWVrZXRlQmVRZ0lkOWVWaEZiSWE3YUFoaWZGZW5nRGZ5YWxnYmVTZEViMWhIZ1dhR2dnZGlmQmVGYm9hK2RQY1FlVWd1YUJmd2Q4YVljTGRqYVVnV2hCY1djWmdTYU1ieWJnY2ljSmhCYXdiZ2VGZEVjY2VWYVNhVmV4aFNoTGEwYUZjNmNZYjBoMWZxYVNjd2Q5YVNjRWFHaFJiTWRkYm5mWWVBZEJmMGdFYnRkSmZGZHhlTGZUZkFic2dRYU1kWGh3ZFBoTWhWZ3hlYmRTZlVkUmYxZkxmRWdVaEllT2IzYjFmUGFjZ3hhQWZaYWFnQWR0ZEZiYmV4YkViVGJiYzBoZGZ6ZEVoMGhkZW9kQ2drYWhmUmdWY3pkcGRtaGNhbGJZYlZmYWVuY0pmUmZkYjFjZGFLZUZnbWhsZGhoRmZnZkpjbWFRZkNmNGV2aE1nbmU0Z3FoTGNrYTViZmFIY1FhRmNWZkJkbmdvZ1VmT2gzZ2RjVmRRZ0Voc2RQZFVjaGFCZmtmVGRIYlpjMmVVZWtlSWhWaGVlSGFZZlNoVmNCYmhoQ2NTZ0VmaGh5ZGNlSGVCYUliUWYwZWxiYWhkZlhjaGJMZGRlM2RwY3BoVmEwZU1jUWZUaFNlQmNDZ0ZibWdGZXVmVWNuZHhnVmRjZHdiMWZIZVBnQmZzaDNmRWNWaFFjQ2JUYUhnSmJXY0ZlV2JwZ3lkVWVYaGRhWGJTY2hmWmdwZFloUmRZZVloZWhSYVJkbmhkY2tmdGZ3ZFZlV2g5ZGFnUmJ4YzBmZGdWYlZjSmMwZmFhM2hwYmpjVGVYaEJlTGhXZnhjcGhaZ05oMGFJZ0phTmEwZ0ZoUWNGZVdkUmMyZFJka2NWYW5nQWZrZXBnd2FXYkhlQmJ3ZFNkRWFOY0pkV2NuZlZkNGNTZTNjZGE2ZWFmVmVkYVphRGZ4Z2xjcGNHYm1nOWh2aEVoUmNOZnZiUmEzZU1kVGRSZDJkZ2ZWZ1NlRmFCZ0hkRWZIY3hjeWZBaGxhMGNqZUlhVmY4Z0ljRmdsZ3NhQWZhZFhoOGJXaFRjR2RoZ3JjSmQzY2RhM2hXYWxnVmZ2Z1dka2VjaGRlSGNWYlZnU2FkYkdodGY2YVlmMGUxY3FjVmhBZjlhVGZBYkVkNWRNY2RhbmNaaFNlUWFoZ1ZoNGZkaGhnSmdMYUdjRWJOYVpjWWVtYmhkd2dKYUFiQWVLZEdhbGVRaEtiT2hWY3BnaGFlZ25oVmFYZ0RiUmY1Y21kS2hSZ3BhVGdSYVJiRWNUY2JkMGdkZHpmRWIwZWRjb2dGZFViaGRRZVJmeGRCYm1lYmFWY1lkVWdlZDFoaGFSY2RkMWNkY0thRmNtYWxhaGhGaGhnaGVtZkZiR2ZaYW1nWWJXYXBoVmRPZHhmSWZPY1RkaGhNZXFmRWQyZ1JmN2ZlZG5nMWhOY1Bia2ZWY3diRWV3YkJnMGJWZzFieGQyZFVma2NJZ1ZnZWdIYllkU2ZTYnhiaGdEZ0JiR2Z0ZCtnV2NuZ0JoSWZRYTBjbGdhYmRnWGZoZUxhZGQzZXBiaGdIYjFmZGRBZFNheWRkYmZlQ2VqZXRmSWJRaHlmcGZKZFBiMWdZZ1VlT2EyYkVnQWRFY1Fia2dRYWVhM2JJZ2VkR2d6ZG9lZ2dIYmljTWVZYUhha2E4ZzViSmFCY2hnVWZNZGhiUmM3aFpoaWVjYWxkR2J5Z3dkT2VEZmxkSmdUZVZiVmhvaGdlWWZuZG9jNGRaZDJjcGZMYURjMWRJZVFoWmZFY3hmMmFkZGxhSmZDZUZlU2NvZHpnUmFoZDVhS2dEYVZla2YyZk9namhrZmpjUmFqY3djSWFUY21oMWM0ZFZkM2FjZXVkWmZ5Y2djWWhCZEFjRmRDZ0NnMGdWY3ZnRWFSYU5jdmZSYzNjTWdUYVJmMmJnZ1ZmU2hGZEJkWWVFYkdkZGRpZWZmQmFWY3FiY2RsZEZkM2ZWZTBnb2dXaGFiV2dFY1dmR2RHaFlhVWdmYUdlWWYxZ09kQmV3YzhlVmNEZmhoY2JDaFVhMWVTZWFkbWdzZnVkYmJUZUlkcmNYY3hnZGE0ZkViR2VSYU1mZGduY1pkU2JRY2hlVmQ0YWRiaGdKYUxhR2hFZ05jR2JZZm5oTmdoZ1dia2FoZERnU2dWaHBmMWNlY0VldGIzZmVhbWRsZVhkV2hSZUFnWmhjZGdhc2NSYUpiMWRoY0FiWWdUYmdoeWNBZkZkVmZvYUNkVWZnZkVoU2VXYzhnbmNZY1VmUWIvYmFobmVKZlJjZGYxY2RlS2dGZ21kbGhoYkZkaGZoZW1mRmNHZVplNWRZZlhoRmZGY1JmVmZwZEhmSGNSZjFnVmRVZ25kUmVyaGVjbWJOYU5hYWRrZXNoUGVTYUJoQWd3ZUJnRGE4YWxmWGFEaDFlVWRhYTJlUWNTYVZhUmhnZlhlVmV4YzBmemJZYjJjSmhpaFFhMGRsYmFhZGFYYmhiTGFkYjNlcGRwZlZjMWJrZlFjR2JXZGdhVWRSZVdnNGRBY09hV2E5ZUhlY2F4Y05nSGNhZEJjVmdJaFVlRWhjZlFhWmRuYUpkV2NEZDJib2RtZUdjVGI0ZUVkUmZHYWtnb2FjZUFoQWRZZ2VkaGdRZ3lhYWJCZjRneGhSZ0hhbGJ3ZlJkeGUwY2RiVmRWYkpjMGhhYjNocGFqY1RoV2NwYUxoRGIxY0ljUGhaZUVlMWdtY1hkRmJKZENnRmRYYWhjMmhFZ2tmc2hZZ1FmMWJsYmloY2NuZ0Jid2JVZGtjTWZkYkVnamJ3YXJiUmJRZGdlN2dlaEVjRmhaY0RmaGdrYThjQmRUZm9hdWRBZkFkVmRGZFJlM2NNZlRnUmMyZGdjVmdTZkZoQmVIZ0VhR2haY3lhVmZoZFZjMWNjZmxjQmNtZ2ZjVWZvaFdiYWRXYUViV2FHYUdhWWhVZlpibWhaZGhlY2JGYlZidmNRYkVjZGZKaFZiUmZ3aEJoZWZoZ1FiN2JjZzFkMWFxZ1Zid2M4ZEdiSGZoYnNhTmNaZW1kWmVKZGFoQmhWYzRlZGFoYkpiTGVHY0ViTmRaYlllbmRJYnRkZWdVZ1JocGVTZlZhcGgxYmVkRWZ0ZjNlZWNtZWxhWGJXZVJnaGJSY1pjbGFzZVhjSWdFZlZmY2ZPaHhkNGFqZVZha2drZ25hUmgwaGhnTmVSZjFjWWN6Y1BmQmNWYkJmSWJ6ZjBlZmJkZTFjOGFlY0hmMmZraDZjUGNCZmhjbWFGZ0dkWmhtZ1liWGdCZVZnYmUxY3BoSGNIaFVoOGZRZUJkaWJFYjVlTmVHZE5oRmVRY0Vmc2NQY1VlaGRCY2tiVGJIZlpjMmNVZmthSWNWY2VjSGhZYVNoUWIwZndoTGdFZURhRmg4YURnemJGYVlnVWEwZmtnR2NhZ0hiZ2NmY2VhUWdVY29oUmcwYWtmWmVGaFViSWZMaFJoV2Q4aFJoRWMyYzlkSGFjZnhnTmNIZmFiQmhWaElkVWNFZTllRWNMZWpmc2FGaEdmeGZVYXpjUWFHZ0ZjWGhGZWdkdGZwaE5jUmVoYW5oSmF3Z1Zid2ViaDJlMWFhYlZiV2Q5ZGFjUmd4YjBmZGFWZVZlSmUwYWFkM2NwY2poVGVXZXBmRGRXZHhicGRaYU5oMGhJYkpiTmUwZ0ZlUWFGZVNoUmFyZUVlaGY4ZVdnUGhCZ2hleGZZZ0hibGQ4Z1lna2ZOZ0pnV2RuYVZoNGFTZTNlZGU2YmFmVmFkZ1piRWFCYWxib2hBY3hhRWZuYldnRWhCZmhoT2VEY0lhSGhYaDJnaGJKYVZmVmZBYVRoSGNoYmtlemFRaGdjMWhqYmZkbmR0ZjNjVmMwaG9mV2RhZFdiRWJXZ0dlR2FZaFVhWmdtZFpoaGNjZ0FiRWNuZEVmeGZRaDNhSGRWYVZmU2RkYkdmdGE2ZVlkMGQxYnFmU2N3ZjllU2NHZVhkOWVtZGRobmNaaFNhUWNoYlZjNGNkYWhkSmhMZEdlQmY1aFFlYmdsZ2hmd2RjYUViaGVEZFNlVmJwYzFjZWFFZHRnM2hjZWlmRmhaZUNiVWZKZldnUGFFZ1FlUmJOYWthRmVXZVlmUWRZZDlmVmgwaGRiMWhGYlFnNGVGYkNoVmRNY3liT2d4Y2xnYmRhZW5ib2VGZGZnbGZjZlJoUGhHZ2xhaGRGZ2hoaGZtYkZnR2JaYm1iWWNYaEJkVmViZXdkZ2VDaFNnVWZnZkhkSGRIYlJjamFVZUdnTmNOaGFna2dzY1BiVWNoZkJia2JUYkhiWmcyZVVha2RJZVZhY2FDaEpmYWVBY2todGdOZEpmaWJOZWlhWWZIY0JnT2FYaGtma2VPYWVjd2djYktiWmcyY3BoZ2RXYTNjTWhRZEdoV2ZnYkxnUmNXZzhoUmNFZzJkOWNIYmNneGZOZUhlYWhCYzBoY2ZHZUFkNWdEYmFoQWcwZ1hnQmdIZ3hieWdWZDJncGJYZEhmaGdnYVdnSWdBZGNlT2ViZ3hhaGNNZlpnbWZGZ3dlVmVXYTloYWhSY3hjMGdkY1ZiVmZKYzBiYWMzYnBjcmNHYVNoSWNDYVhhRmd4ZXZnSmdWYjloa2VkZ2xiUmFmYkZmU2N4YjRoYmJRaG9nTGFVZFZoQmN1ZVdhSGFCYXdoU2dFaE5iSmdXZW5oVmc0ZFNiM2NkYzZmYWZWY2RjWmRHZ0VkMGZnY1FmaGVaY2hnYmhsYUpjN2VYaDNjTWVWaFdmbWFoZkJmUmRpZjhnR2hCY0hoNWY3ZldmamI5ZnFiY2NsZUZjM2NWYzBnb2VXYWFmV2hFaFdiR2FHYVlhVWFaZGpoSWNwZE9lUWZaY0ZlV2drZmNhZGVIZlZlVmJTYmRkR2V0ZzZjWWQwZTFocWJRZGhkUmM0ZUVhR2hSZU1kZGRuZlpnU2RRZGhnVmM0Z2Rla2I5YkNjRmdHYWxkWmdZaG5iSmN3ZmNiRWZoYURmU2hWY3BlMWZjYkFjTmM1ZUtiamdzZFlhRGVWYjlmTmFNYlZjc2dBZFlhVWVsY2NjUGVVZmRjdWFFaHdkRWg5Y1djd2JzZ0VkRGZsZjhhb2VjY2xhNWNCYlljM2NJZ0tmWGFWaGRjS2FGZG1lbGhoYUZiaGZoY21mRmNHYVplbWNZY1NjSWVRZE9hd2M4Y1ZjVWJ4ZjFnZGdlZEhnUmVyY2VkbWVOZk5oYWhrZHNhUGVVZmhiQmNrZ1RnSGVaYzJmV2FoZ1piZGVNaFNiVWRjZ05nRmVsYlRiU2JXYklmTWFiaFhnQWJjZFRhVGRZZGJoWmRXaGhjQ2NlYTFlQmdwY1ZjMWRrYlFnR2NXY2dhTGRSYVdiOGRSaEVjMmU5ZEhmY2Z4YnNhVGVJYkZhd2RiZFhiamZoZFJoZGMyZFJlV2hhYzNnZGN5Y0JmWGVrYm9mQ2R3Z2RjL2JhaEJlb2N5YlpiaGZSZ21iWmVtZUZhd2ZWYldkOWJhYVJheGIwZ2RkVmVWZUphOGdQaHplSWhxZEhmbWNRYjBmVGJrZ0VlQ2daZURiSmNyY2RhZ2JaYk1nYWZqaGxlbGRBYUVmSWhVZWFoVmJsZGloY2duZEJnd2RTYUVoTmNKaFdmbmdWaDRjU2UzZGRkNmFZaFFlTWFSZFdmVWVwYm1mZGRBYlJoN2dDYVJkTWVSZldhbmhOYkhmU2JSaGRiVWFYaEVjaGhPZUhmRWh4Z3ljVmNoYlZlcWJjY2xhRmMzZlZiMGhvZldjYWFXZEVnV2dHYkRhSmFjZUxjemdWYkxlY2RGZlZldmVXY2tiY2VkY0hoVmJWZVNnZGJHYnRnNmhhZWxoWmFBYVNld2g5YVNkRWNHYVJiTWhkYW5mWmRTZlFma2ZoZ3hoZWJqZWhnTGdHZ0VnTmhaZllibmZKYXdlY2JFaGhnRGNRZFJmSmY3YUtjQmhrZTRhTGFpYVlmRGNBYkVoQmVjaFpma2hVYkthT2J4Z0VkT2hiZXdiRWRtZFhnUWdRYzhkWGRBaGNjZWNSYnhkaGZ2YmNhZ2EwYS9oYWVuZUpkUmFkYjFnZGFLZkZhbWNsZmhnRmdoY2hibWRSY2lmTWJ5ZU5mQ2hJY2JlYmMxZUpodGFIZ1JlMWNWZVVibmNSYXJmZWZtYk5oTmNhaGtmc2NQYlViaGhCYXNjR2ZEYjRmL2RBYVVieGZxY09nV2FZZENmU2R3ZlZiRGRUZzNnZGZuZlllMmdWZUljUmFVZmtiRWFJaFRkQWdDZ0plSGRRZ1dhRmhraGtmQWVFZkdiUWJoZVJiV2I4aFJiRWcyYTlnSGVjZ3hlTmZIaGFnQmNWZklmVWRFZ2NjWWFNaGpob2JmZlJnbWhRZ05oRWJHZlpkQmJTZGdidGhwY2Rod2ZNYU5hZGFRZ0ZibWZZZkdnRWJ1YkFjU2ZjaFRiRmFCY05kaWZGZ0VmTmJpZ1libmRaZEplVGdXYnBnTGFEaDFhSWRRZlpjRWF4ZjJmZGRsaEpiQ2dGYVhmaGQrZFJnZ2dOZlJnRWVGZWNlZGZNZzJlTmJpZFNjRmU1YUpmVGRHZkJndGFXYkdkSmM2Y2JnMWhjYUhnUmRGZUVmaGFXYUVnc2VRZlVjQWFCaDliVGZuZjhkNWdSZDJnZ2JWYVNlRmNCYkhkRWdHaFpoeWVWYWhhVmZxZ2NnbGNGZy9iQWN3Z0poZmNPYm1lOWNwaFdoWGhJYk1oWmZuYXRnaGRaYWtjQmY2ZlNkVmVJYmRkR2MxZlVjTWZJY0NhTWV6ZE1oRWdNZ1ZlQ2doaHRnS2FHZFdkaGVtZmRnbmNaZ1NlUWhoY1ZkNGVkYmhhSmFMYkdkRWVOZVpnWWVuZklla2RPZUFnRWZRZVliMWVwZDFiZWFFZ3RiM2ZlZ21mbGRYZ1diUmZBaFplYWJBYkpoZWFSZFJjRWNUZ2JoMGFkZnplRWQwZ2Rhb2VGZVVlZ2NOZVRlaGF4Yk1nY2FsZFlhVmJhY25jSmFSYmRhMWRkYktkRmFtY0VmcGFHZEVmZ2MwYldiemhJY3BkTmZTYWtoRmVLZmxoUWhVZFZhVmRRZFRmQmJnaFljaWJQYlNoc2NaYmFlbGNZZlBkR2ZoZzRoMGNIaGpja2ZpY0hnUmFaZU1jS2NEYk1nY2ZHZ0ZjQWJLYUhlemRZZGdlY2ZHaDFlSWVCZFJhd2VVaE5haWh3Y0NjT2JEZlJkcGJYYXdnMGNaY0dlVGNNZ2hoUmFXYzhiUmNFYTJhOWJIZGNleGROYUhmYWhCZlZhSWdBY2dnSmVFaE1leWZBY1lhRmRXZEplWWNVYlhiZGJYY1NiaGJaYnBjWWVSYVlnWWhaZWhhUmJtYVpkbWJGZDRmQWFXZzljZmVXZ2hmMGJMYlFiVmZ0aDRnUWZYYnBnamNUYldkcGZMZURmMWRJZ1FoWmJFY3hjMmdkYWxkSmRDZlFiWGdoZ29jRGMwaHNlTWZXYTNlTmJpZ2NobmRCZXdhU2JFZk5jSmFXYm5nVmc0ZlNmM2RkZjZiYWRWZGRmWmNEZnhlbGJnZ0FkeGhFZG5nV2ZFZEJmaGdPYURiSWhEaFZkMmhnYUllU2ZBZ1FnUGJXZVRhVmE4YUtjVmVSZCthYWhsZkZmcGRTZFVib2FlYVBlV2NFaGJoR2VIY0lmTWdiZTJhOWR0YldkbGdWaHZmV2VrZWNmZGZIYVZnVmRTYWRlR2Z0YTZkWWcwYTFlcWNTZ3dlOWRTaEVmR2N3YVlhUGNqZDhoQmJUZEdib2U1Y1phd2dSZUxkQmRVZ05nSmdhZDNiNWJhaGNjRWJoYkRmU2RWYXBmMWJlYUVjdGYzYWVkbWFsYlhmV2VSZEFiWmVhYkFidGNGaFphMGRWYmJnSmJoYVJmOWRiY0FiWmc3YUJmMGJoZE5lUmF3YkJndmJmZ25id2dWYmFobmJKY1JoZGgxYmRmS2dGZm1nbGRoZEZiaGNoZG1mRmJHZVpibWhZaFhmQmJkYk9neGFJZk9kVGRoY01ocWRFZDJhQmN6Y2Vkbmg1ZE5iZWZrZUllR2RlaEJiQmFrZVRhSGNaZjJmVWNrZklnVmNlY0hhWWFTaFNjeGhoYkRkV2NXZ0pob2NjY0NlUmdJZVhkVmNSY2FoWmZtY3BlaGNkYjNicGNwYlZoMWNrYlFmR2NXaGdhTGJSaFdjOGVSZUVhMmM5Z0hlY2J3aHhjSGFZYkJhMGdjY1VlRWVvZE5lWmFtZkZmRWRIY0djWmdZYVVkWGZkZFhiU2FoYVpkcGhZY1JjWWhZYVpiaGhSaG1nWmhtZ0Zid2VWZldhOWRhZlRkMGVsYlZiSGZBYkZiNmFGZURmdGR6ZlhlV2dwZldjSmVWYUliUWVaZUVjeGUyYWRjbGRKZUNmRmhYZGhnMmJFYWtnc2dZZlFnMWhsYmlkY2JuaEJnd2FYaGxjWmdjYlNhV2NCZjRlVGFYaGRoeWhZZFFmTWNSYldiVWZwZG1kZGhBY1JhOGhBY3hjTmd4aFdmWGdOY0hmVGNtZ2hmSmZTY0ZkZ2NUZFdhQ2Y4ZmhmV2FHZm9kcmZaZGtnbGIzZ1NkMWNZaFdlWWVYYkFnQWJHZ0dmc2hVZU1kbWg5ZW9oZWVWY3hiamRjYkVkY2JkZUhmVmJWZ1NiZGJHYnRjNmJZZTBoMWRxZFNid2g5ZVNkRWdHZlJhTWRkYW5jNGNHaENlbGZ3Z3JoZWJHYzBkS2dDZFZnVmNaYWZlM2hKaDRiSmFBZEFmS2dHZmxiUWJLYU9nVmM5ZHZnZWduZWRhSmhXZFViUWdRYmFoQWcxZUZjZWhRZVFoR2VmZEZlSmg2ZkhjMmMxZW9oRmZVZmhmUWVSZnhjQmZtZGNjbGdZZFZhYWJuYUphUmdkYzFkZGZLZ0ZhbWRsZnBjUWJsZ0FjdmFSZzJhZ2haZUllR2ROYkhmYmgwaGRiSGZEaFJhUmZaY2ViSGNSZ3JnZWRtYk5nTmdhYmtic2dQZVViaGNCaGtlVGJIZFpkMmRVY2tkSWFWYWViSGU1Z0doQWExZEVoUWdWZXhoMGd6Z1phR2doY0liWGJrZGxoS2dmZkhmRmJoYmRlM2hwYnBnVmMxYWtnUWZHZVdnZ2JMYlJlV2g4ZFJoRWMyYjloSGhjZ3djbGJIYlBhQmhWYldmVGFVY2NkQmJjYkZoaGRXaEZjV2NwZ3ljVWdYYmRmWGhTaGhoWmVwaFlkUmhZZVlmWmdoZ1JjbWJlaFdmRmc0YVhhVGh0YmFmU2NnYUFhZGhSZUVkUmY5YVpoMWJCZmpnVGhXZXBnTGhEZTFmSWRRZFpkRWV4YTJiZGhsY0phQ2VGY1hhaGIyYkVma2hzYVFlRmd4Z0VlcmFJaFhjNGFQZkNlVmZOZVpiV2RtYmhoU2VTYjNoZGU2ZGFiVmFkYlpnRWVCZWxkb2VDYTBoVmh2ZkVhUmhOZHZiUmgzYk1lVGdSZjJnZ2dEZVhjVWdWaFViQmRXZ1pmMGdWZ2hjMWhpaEplaGZrYitnQmhFZ1JncGFLZ0hjQWZBZ0dlSGZnZEtnWmNqZkphb2djYUFibGJ2Z1VlaGhOZlZlVmRBYlplY2hDYnlmcGJwZGNnVWMxZzJoVmN3ZDllYWJBZVhmSmVNaGVhM2hZaEdnU2J4Z3hleGhmYnhoNWRoZEdlRWVOYVplWWFuaEpid2NjYUVlaGNEZFNhVmVwZDFhZWZFYnRkM2FlYW1kbGRYY1ViVWNSZFJlSWRWZWhiTGVFYUZnQWVDZ2VlVWJkYnVjT2hVY2Rjb2VGYlVkaGRRYVJmeGJCYW1mY2VsZVlmVmZhZm5nSmNSY2RkMWhkaEtjRmdtYmxjaGJBZkFnMWd6ZkJnM2JOYW1kWmQzYkJkZGNaYndhNGNQYlZoRWg1Z2JnTGFUZlZmNGRhZkdiTmNUZmRkRWh0ZmJoV2V4aEFjNGJUZkhiNGJpZEdoZ2N0ZkdhZGhnZ2xiVGJYYndlQmNEYVJkWGU1Y3lkZWRHY0ZhZWNRaDBjUmhhZkliWGVGaENkZmNuZU5hbGdmZVZoa2FRY0dmV2ZnZkxhUmZXYThlUmdFYzJmOWNIZmNneGJOZEhiYWZCYlZmSWVVZEVnOWRFYkxiamNzZkZkR2R4ZVVmemNRY21lVmNYaFZmeGRaZmhiTmZWZTVlUmVOYVJmb2FaaEpoM2ZWZW9mVmNYYUZoRWFSZzBia2dVYlZoVmJSYzBjZmVXZzljMmVYZm5mOWFDZkFiM2RnY1FkWmNFZXhhMmVkZWxnSmZDZUZjWGRoZDJhRWhrZ3NiWWFRZzFlbGNpY2NjbmFCYjRkSGVBYXNmQWhDZlhic2ZIZkNhbWZOZWlkYWNVY3BlWmJBZEJnQmdoZUlmVWZWZnZoRWRSZE5jdmFSZDNkTWhUZFJnMmVnZVZoU2JGZ0JoSGZFZkdoWmNvYVZhaGQxZmloSmNoY2tkK2VCYkVoUmNwZUtiSGdFZUdkR2JIZHNhK2ZaaG1oWmdoY2NhRmdWZ3ZiV2ZrYmNlZGdIZFZkVmJTZGRoR2h0ZTZlWWMwaDFocWVTZndoOWhFZEJkWGFGZGZiWWUzZ1pmVWNRZGhoMWF3ZElkbGNvZUNjU2cwaDBlbWRJYjJnSmRnZGNlRmVaZ2RiU2RRZTVhOGNlYUJjZGUzY2NoamQwYWZjRWFFZ01iWGRGaDBkcGhVZWVlUmFFZ1BhY2gwZGRoN2JBY2xkRmRvaEdlRWhnaEVoVGVoYWxkdmRlYjFkb2cvaGFlbmFKZVJnZGExYmRiS2dGaG1nbGVoZEZlaGhoZG1iRmZHYlpjbWFZYVhlQmdWY1pnd2U0YlBkVmFFZTVhYmNMZlRlVmY2Z2JoR2hOY1FhUWhFZnNjUGJVZGhhQmZrYVRjSGZaZDJnVWFrZUlkVmJlYkhhWWZTZFNleGVoZ0RoV2VXaEpjeWFaYm1kVmhkZ1VoRmR4Y2FkY2czYWhhRGJmYXlmNGJoYkhkZ2dvYmVkWmNpaGtlYWdVZzJoOGNQY0RoV2E4ZlRmZWNoYk1oYmhhaEJjMGhjZUdkQWQ1Z0RoYWdBZzBnWGZCYm5kaGN5Z1RnV2F0Y1hoUWFnY2RhL2NZZVJkc2dZZU1laGYxaHZiYmEyZ2hiOGhmZDJoOWFhYlJmeGcwZmRmVmNWZ0pkMGVhZDNjcGJqZlRiV2ZwYUxiRGYxYklnUWRaYUVlUWNpZ1BiaGVzZFJiR2d3YmNlM2dBZ1Zna2ZZY1hlbmNOY2lnY2huYkJmd2JTYUViTmdKZ1dhbmdWZjRlU2gzYWRjNmFhYVZiZGRaZ0ViQmhsZm9oQ2YxYk5lNmFCZ0FnQmQ2Y1JjM2VVZFRkVGUyZEJiQmJBY0Jma2JVaEhnaGdrY3piUmdRYmRhcWJiZUVlOWUzYkFoMGJNaFdiTmZXYkVnZWNUZUNoNWVkYU5kV2dnZ2ViTWNVZEZhM2dXZ2xjc2JCZUhoVmExZkRkWWRtaHRkM2VZZHhhbGFqZ1FnZ2JaZWJhSGZFYTVlTWJkZW5hWmRTY1FkaGJWZjRnZGRoYkphTGJHZ0VkTmdaZllmbmZKZ3djY2VFZmhlTGhIYlJoSWM4Z0tnMGNVaEloT2MzZjFnUGNXZ1FoMGRaYVlmRmE4ZE5oSmFrZUlhZGFFZEFkWmhuZENkMGJkYzJnQ2YwZGdmRWdUZmhlQmhnYmNia2hBaEFoZmMyZkZmRWdmZmxiNWVHY1BkR2NsZGhoRmdoZ2hhbWZGZEdjWmFtZlljWGVCZlZlYmIxZ3BhSGhTZ1ZiVWFjZEFjVmU1Z3JhZWRtY05oTmFhYmtic2JQZlVhaGJCZWtkVGNIYlphL2NTYldhZ2FWZWViSGFZY1NnU2J4ZmhmRGdXaFdlSmd5YkxjWGNsYUVhYWJVZ2xjYWJkZVhmaGRMY2RoM2dwZnBhVmcxZmtnWWhVZFdiWmdiZ0ZkeWhCY0ZoWGJEaHNiZWZJZjFlWmJKZ09nMWgwaEJjRmZoZE5jOGdJYXphUWVDZ0ZjWGhkZnljR2NYY2tnSGNHZkZla2E5Ykxla2RKaEJnTmRsZEZjb2NOYVNia2E1ZEVhemJzYldiUmd3YUFlZGVFZXdlY2c2YktlQ2I0Z3FkQWRpZlJkTGdCaHdhWWNjZlpoQmg1Yi9hZGRnZWxmb2JGaFhjaGcyZ0Vna2FzZlliUWUxZmxjaWNjaG5jQmd3YkdnZ2RZaGRmRGJ5ZWNkMmJTYTNjOWdRaGFmVmNkZlpmRWJCZ2xib2ZDYjBkVmN2YkVlUmhOYXZhUmYzZk1jYmFFYzJlZ2NRYlZhVmdCZFJjQmFHYTlhK2VmZUJnVmJxaGNibGdGZTNoVmUwZG9lV2JhZ1dkRWhXYkdoR2ZZZVVlTWRtZVpkL2ViY1ZiVmU3Y1FhbWQwYWRjSGdWY1ZkU2ZkYUdjdGI2Z1lhMGIxZXFlU2d3YjlnU2VFZUdjUmNNYWFoWGNaYWFkU2hrZEVld2ZQZDBhRmNGY1pnd2VKY05lZWduZEpkdGdjZUJmd2FMZUFiQWRsYzdjQmN3YnBlbmVhZW1hbGdMZ1JmUmJBZFJkUGdBaHRiSWFiZHdlVWdMZVpna2E1ZS9mT2dVZWRmb2dGYlVmaGJRZlJoeGRCZW1lY2hsYVlkVmZhZG5kSmhSYmRnMWFkaEtjRmFtZ0VmMWRYZGxmRWUxYUdkaGFraG5kY2FtaEpkVmNjZmxhcGhYY0ZhQmNGZy9jVWduaFJncmZlY21lTmNOY2Fja2dzZVBlVWFoZ0Jla2ZUZ0hhWmEyZFVja2hJY1ZjY2VDYkplYWVBYWtjdGJOYUpoaWJOZGplWmRuZkJoVmRRZzFkbGFUYWVoVmhKZkxmZGUzZ3BkcGNWZzFoa2VRZkdkV2dnZkxjUmRXZDhiUmFFYjJkOWNIZWNjeGROZVBlUGVGYzBiQmFBYzBlbGZ2YUpnMmhKYkdiRmVYZ2RheWZRYlhnNWZlZFllQmNaYXBlWWNSZ1liWWNaYmhmUmhtZVpnbWFGZ3doVmJXaDlmYWJSY3hiMGJIZVZmUWNaYjBnZGdXY2RjamFYZG5iaGhoaERkMWhJY1FmWmVFZXhhMmhkZGxiSmVDZ0ZiWGVoYjJnRWNrZXNmWWZRaDBhWmFpYmVmbmFnaGtnU2JFYjVoVWRXYm1hWmRxZVFjbmV0Z1FmYWNWYWRhWmNFY0JkbGhvZ0NlMGRWZnZmRWRSZU5idmJSYTNlTWdUYVJjMmhnZlZkUWhBYVFoUGJXZlRnVmM4ZEtjVmRSaCtiYWJsZkZlcWNWaDBkSmVDZUloU2ZoYkZhRmJoYWxmVmRkYjNmQmJoY2JkRWRsY3ZoRGJrZDRhZGRRaFZoVmhhY0lhQ2NNYnpkTWFFYU1hVmdDaGhjOWdDYUVjSGJwYVNhZGZuZzVjRGJWZUJnVmMxZ2Rna2RaY0NnRWJVZnBkVmRTY0hnSmF3YmNnRWdoYkRhU2RWaHBmMWVlaEVidGUzY2VlbWdsYlhkV2VSZ0FlWmJhZUFmTWVSYkpmMWJoY0FmWWZUZGdneWVBYUZmVmdvaENjRWNoaFlhRWYxZ2djdmdJZ1ZoaGJxaEtmMmVKaEJnZGYwYXRjV2JGZ2pmMWZvZEZoaGY1Y21jQWRuY05jemJjY21hVmJjYlliM2JCaEhmSGhSZjFlVmdVZ25nUmVyZWVmbWFOZU5nYWdrYXNkUGhVY2hoQmRraFRnSGdaZythQmJnaHBkY2FLYTNjaGR0ZkNoZ2ZsZFZhV2RYZzlleWNZZUhibGJFYmFjVWNsZ2FoZGdYZGhjTGVkZTNkcGhwYVZlMWdrZVFnR2NXZGdnTGRSY1djOGNSY0VkMmdjYlRhT2UxZW9jVWRaZW1kb2ZKaFFlRmVjZVFlZWMzaEpkR2VIaEdoTmRZaFVhWGdkZlhjU2JoYlplcGhZYVJlWWhZYlpkaGZSaG1kWmVtY0Znd2RWYVhnVmhhYkVneGgwYkRjU2RGZkphbGhmY1ZmQmZqY1RiV2JwZUxhRGUxY0liUWZaYkVleGYyZ2RkbGhKYUNnRmRYZ2hiMmVEZFVlc2FRZ1Nkd2gxZWlkZmUyYzFnd2VXaFZiVmRBYVZkbGM5YjRmU2MzY2RhNmRhZ1ZkZGVaZEVoQmRsZW9jQ2MwZlZkdmRFZVJhTmR2ZVJlM2JNaGJiRWF5ZkJjY2RHZDFiNGY0ZlViWGVKYnFiVmFnZmhjcWdlZGdnVWcvaEhmaGVrZVlkRmRpZkFlRmFDZG1jWWdJZWVkbWVZaDFnZWZWZlViemhXZGtnOWJKZFZnUmZ3aEJnZWhoZlFhN2FjYWxidGZxaFZiUmhGZlNlR2hIZ1ZnYWdkZG5jdGFTZEZkaGN4YnhhZmd4aDViaGJHYkViTmdaY1lnbmJKZXdjY2dFZ2hhRGZTaFZicGExZ2VkRWF0YjNiZWdtYWxoWGRVZFVlUmFSY0liVmRoY0xkRWJGYUFoQWNmaFVhZGF1Z09mVWVkZ29kRmNVYmhlUWZSZHhnQmJtZmNlbGVZY1ZhYWZuZkpnUmRkZzFkZGdLZ0ZobWZsYmhiQWJBZTFjemNCYzNoTmdtaFphM2RCYmRlWmF3aDRiUGVWaEVlNWFiY0xoVGFWZDZnYmJHZ05hUmdkYmtkdGhiZ1doeGNBZTRmVGhIYzRmaWVHZWdldGJHZWRnZ2JsZ1RhV2d3ZGhnRGRSYjNheGZ5YWVlR2hGZGVjUWUwZlJkYWZJaFhiRmhDZ2ZhbmdOZGxlZmRWZmtoUWFHZldmZ2hMY1JmV2M4Y1JkRWYyZzlhSGRjZ3hmTmVIYmFjQmFWY0lhVWhFZjljRWhMZ2poc2hGZUdieGhVYXphUWdHY0ZkWGNWZnhoWmJoZk5hVmI1YVJhTmJSYW9iWmRKYzNmRmZnY1ZlWGVOYUdhUmIwaGtlVWRWZFZlUmYwaGZhV2U5ZjJhWGRuZjlhQ2VBYTNhZ2ZRYVphRWd4ZzJoZGZsY0plQ2RGYVhmaGEyY0Vla2ZzY1lnUWcxZGxoaWhjYm5mQmU0ZkhiQWhzZEFlQ2JYZnNoSGJDaG1hZGFxaGFjVWhwZ1pnQWFCZkJlaGJJZVVjVmF2YUVlUmVOZnZhUmIzZU1hVGNSaDJmZ2JWZ1NhRmRCY0hhRWJHZ1pob2dWYWhnMWRpZkpiaGVrYStiQmNFYlJncGVLZEhkVWhPY0dnSGFzaFVmYmZqZklmcGVPYVFlWmRoZ0phUWZZZUpiQmhWZ1ZnT2JhaEdic2J1YWFna2MwYjJkU2Z3Y2NiR2ZXZUNoMGhmZ2VhQWZrYVRlVWdRYWRlNGRhYUFmeGNMZkVhRmVKZFBoWWRuZzlod2FKYUVlRmZLZVFhRmRaaGZiZWVFYXRiM2NlYW1lbGVYaFdjUmVBY1phYWVBaHRnRmFiaHhmRWhUY2JhMGJkYXpjR2Z4ZE1iZ2RYZ0JkdGJlZk9oRmdGYjFlWWRGZllkSWhRaEhnSmRSZmRkMWFkYktkRmRtYWxiaGdGaGhiaGNtZ0ZoR2ZaaG1iWWhYY0JjVmNiZTFmcGNIaENhd2doZ0FhUWNXZUZjcmFmY0diTmJGZFllaGQ5YUhhR2QwZ05ncWdNZHpkZGFsZlFhRWFJYUpjWmVIZFpkR2ZRYmhiZ2FmZFdhV2RvZ21oT2VEY2toYmNUZ1RkWWdiZVpiR2Q1Z0xjYWVXZlJocGZYYzBnZ2dHZkdjV2JVaExoRWZXZ1llWWFHYm1nWmZMYldmUmJOZkhhYWJCZFZjSWFVZ0VkY2ZRZVphbmhKYVdiRmdXZnBmeWdVaFhlZGhYZVNiaGU0ZTljS2NWZzlmTGZhY0dic2duZ2RiM2FkY3dkU2NFZlZlYWVSY3hjMGdkY1ZkVmFKZzBnYWIzYnBkamdUYVdlcGFMZERnMWVJZFFmWmVFaHhiMmJkZWtlUmVYY0FjR2Z0YWpoRWZrYzBlWWRTZTFnRWcyZU9lamJrZmpoUmJqaHdiSWJTZjJnTmc0ZVZiMmN0ZzZjUGJWYjVhWmhUZkJhbGdnZlhjd2QwZm1hUWhoZDBjUWRCaG1iTWhEYlJhM2hZaExmU2JGZ2hmV2JCZW1hWmEvZFZoa2JGZmpiZWExY2hkK2JXYjJlQWFXY2FmV2VFZldnR2RHZ1loVWFaYm1jWmVoYmNkRmZWYnZoV2NrZWNhZGVIY1ZhVmZhY0llQ2FNZnpjTWNFZ01lVmZDaGhkOWFDZkVlSGFsZk1hZmNpYUlmYWZDYTBhWmIyZ0NhVmVOaGJhQ2RFY05kRmhmYW5kSWJrZmVoVWRoYkZoU2hVaHhkZ2RiZ1ZmaGdpYmNoMmZCZ2JmY2F4ZUFmWmFhZUFldGhGZmJneGVFZ1RjYmcwZmRnemdFaDBmZGJvY1JkMGJnY01lR2V4Y0JjdWdKaGhiNWZjYU9nWGN3ZnVmTmZrZE5iU2dGY21jOWI4aEZkZ2g1Y3pmQWVYYlZoemJhY0hmeGYvaGJjMWRwZEhnSGJSZjFoVmJVYm5nUmdyYmVobWdOYU5hYWNrZXRhYmRHZmxla2gzZlpmbmZaYzJnVWVrZUljVmdlZUhlWWhTY1NneGJoZERjV2dXY3RncGFXZG5nQmhJZVFhMGVsZWFmZGFYYWhlTGRkYjNlb2QwaFhobGhVYzZlR2FXYmdmTGdSZldnOGFSYUVlMmc5Y0hkY2d4ZHNlUGRaaGtlVWVhY0hoeGhOZmZiTWVpYnNmR2JVZ0dkUWhnZEhkaWNNZFdoSGdsZE1kRmFKZUZiQmJNZ1pkZ2dsYm1iTGJtYjhkZ2JCZnljQWdPY0NmRWFsZEVlQmZSZmRiNmdPZ1RnVWczZ0FoV2JwY1dlRGd4YVJhRmVLYWdlOGZpYlBoeGUwY01oRmVYYkFnaWZHZDBjdGdEZWFlVmFsY2lhY2NuZ0Jjd2VTZUVnTmVKaFdhbmhWZjRnU2d6ZTRlOGZhZVZkOWJSZUdnRWYxZG9kRGJsZGhldmZCaHdhZGZtYlNoM2dNYURiUmczaFVmSWJTZkFmUmFPZ0diV2ZZZmdhRWYwZ0VlL2NJZUJoOWEzY0Fnd2dKZ2ZlT2NuY29jOGZHZEdmWWdVYlpibWJaaGhmY2VGZ1ZhdmRXY2tiY2ZkY1ZkQmROY1NmZmREZDlnNmNmZlZnQmhxZVdjQmExZWJkRWNEaDlnbWdkaG5mWmRTZ1FoaGZWaDRoZGNoZkpkTGZHY0VmTmJaZVlobmVJZm1iTWNSZXBnRGhHZjFocGhvY2VhQmM4Zi9lTWN6ZHBmWmFKZ2xhRWZKZGVmQmhCYnZiYmV4Y0VmVGJiZzBiZGV6aEVnMGJkYm9kRmVVYWhoUWNSZnhnQWh2Yk5hRmhZZWRjUWNIZEpoUmNkZDFhZGZLY0ZkbWhsZWhkRmVoZmhjbWdGZUdnWmNtZVljWGFCYmRlWmd3YjRlUGdWZ0VkNWNiYkxkVGdWYjdiYWFtaE5iUWVhZWhhOWFIY0dmMGdOYnFiTWJ6ZWRkbGhRaEVhc2daY1VjbmRZYlNmU2R4YmhlRGVXYldlSmF5YWNiSGZCZkliUWMwaGxoYWNkZ1hhaGFEYklnemdJZWdhQmRGZmRidmdXYUhhc2RaZlJmWGhJZFJhUWRXYVpoTGRXY1JjTmZIZWFoQmdWZ0llVWFFYWNoUWFaZ25iSmNXZEZnV2JwaHlkVWFYZ2RjZmFHZ0JnWmEwaFlhVWdKZ1FjTGQwaGRjb2hHaFNkQmdrYVRnV2FaaFdkYmFSYTBiZGhWYVZmSmQwZ2FkM2VwZ2phVGFXaHBkTGVEaDFjSWNRYlphRWF4aCtnSWVoYW9lTGZSaG5hWWJKZlVmMWI4ZEFjUWcwZFJnaWRKZ2piZ2M1ZUdiMGEwYzJmR2YyY1JkdWJRZ25mdGRRZ2FjVmdkaFpjRWFCZGxmb2dDYzBjVmJ2YkVlUmVOaHZjUmEzaE1lVGhSaDJlQmFCY0FoQmdrZlViSGZoYmtkemFSY3djTmhxYmJoMWZFZmxmWGJraFljOGFhaFdmRWVXZkdhR2FZaFVkWmFtYVpiaGdjZ0ZjVmd2ZFdla2VjY2RnSGNVZlpnQWhkY0hmWmhuaFlleGhsYmpoWWdRZDlhU2hFZkdkUmJNYWRkbmRaZlNjUWhoaFZiNGFkaGhhSmdMZ0ViV2RsZFplWWhuY0pod2NjYUViaGVEY1NhVmJwYTFkZWVFZnRhM2RlYW1lbGhYY0NjMWVWZk5mUGhWZ2thTGJiZzBkVmZiZUpoaGVSYm9nT2FVYmRmb2JGYVViaGdRaFJjeGFCY21hY2hsYVloVmdhY25nSmVSZ0llMWVkaEhnQ2UyYWxneWRCYUFkTmFNZUZnR2ZaZW1nWWRYZ0JkVmdiZjFocGRIZEhoUmgxY1ZnRGcxZjVhcmhlYm1kTmJOZGFka2NzZlBiVWVoYkJja2JUZUhjWWhnYkVneGhBZlZhTWNYZVloUGVTaHhhQWJYZkVjU2FzaGhoZmJnZDhoSmRWZjFjRmhhZmFjV2NSYkxmWmJtYnhmZ2hWZHdhVWZRZlRlU2JCZkNiRmVtYUZkdWVVY25keGVWY2ZkemZsZEhnYWJCaFZhSWVVYkVnY2JRYlphbmRKZVdjRmZXYnBleWRVZ1RoSmRYZVZneGFaZGhmTmRWZTVhUmVOZ1Jkb2ZaY0pkM2NCZ21nVmdYZk5iR2ZSaHdid2VMZ1hoRmRJaG9iYWR5ZzRjcmNCZURmbGJGZGNkQmJNZUFnZGJFZ0JhY2dkZ2xjSmhDYkZiWGZoZDJmRWFrY3NmWWVRYzFlbGdpYmNlbmJBZi9oU2hGZTVlSmFVY2pneGY0ZlZjMmh0ZjZiUGZWYjVnWmVUYkJkbGJnaFRka2ZWYXhmRGh3YTFmdmRUYzJnQWVCZVJnMmhVY1ZnSGVGZWxlT2ZIY0VleGF5Y1ZkaGNWYXFhY2ZsZEZnM2hWZTBib2VXY2FlV2ZFZFdnR2JDZjRjVWhlZTJmWmdwYU5mVmNWaHpkUmRrZ2RmSmZGZUZlVWZPZmRoR2FNaHpkWWcxYU5oMGNWYVFkOWhhY0FoM2RaYk1iZWMzZllkR2VTZHhoeGdqYlhlQmdKZExhR2RFY05kWmFZZW5jSmJ3Z2NiRWhoZ0RkU2NRZ2dmd2VMZEJjNGRsaE5iR2FsZGZjY2h4ZEFnWmJhY0FldGVGZmJjeGFFZ1RjYmIwZWRhemZFYjBlZGVvYUhoUmJ3YlliRGNrZk5jb2VEZFJnY2ZGaGVhbmJKZU1iZGYwYkZoZmdBYjNhcGEwZkZlaGQ1ZW1iWGNHZTlocWJTZjNhQmVWYWJlMWRwZUhmSGJSZTFiVmFVZW5kUmRyaGVmbWROYU5jWWhoYjlnSGhHZDBiTmdxYk1kemVkYm5oUmZFZkllSWRlZERjNGZTZVZnUWRaZWRiV2ZYY05ia2hlYlhkeGNpaFFkMGZsZWFjZGVYZ2hnTGJkZTNhcGJwZ1ZoMWdraFFnR2FXZmdlRGZFZlNkZGRZY1FnR2ZFaDRhTWZnZUJjVmNhZ0FjaGdJZlJhbGJJYUZlZGhXYWRiV2hFYjJnb2U5ZldlSGJ0YzljU2JoaFplcGhZZFJoWWVZZVpkaGVSZW1hWmVtZ0Zld2JWYVdiOWZTY0VkMWhWYVVnQmhsZHdjTGNLYm1jNWI3YVRnWGRkYUxnUWVGYkloT2hlZGxoSmgyYlpoMGZSZExiR2hWY0poMmZFZ2tic2RZYVFkMWJsYWljY2NuaEJnd2dTZkVlTmNKY1diaWJFYndiQWRpZ1JiUWNhaFZjZGhaZ0VkQmdsZm9iQ2cwYVZndmFFaFJjTmh2YlRnbWNnZjVmUmYyZGdmVmZTZkZnQmFIY0VmR2haZHliVmhrY2hhamVmY25idGMzYlZnMGJvYldhYWRXZkVnV2hHYkdjWWNVY2JjaWI1ZHZjSWRBaGNmZ2FEY2dmaGJKZlJjQWVVYlhiZWJqYWtoMWFOZ3djd2crZURkbmMwZ2JiVmN5YndmWWZkY21mdGFTZUNmaGhzY29kSmJGZzBjZmhWYXhiY2ZBYU1kamZkZStlSWRnYWNkWGdHZDFicGZvaGVlQWMwZWljTmFDYW9jRGhFZ0ZjOWdYZ2FmQWdNaFJnWmRoZEZlSWFSZFVnZGN6YkVlMGdkZG9mRmZVZGhkUWdSaHhiQmVtYWNoaGQ5Z1RlYWduaHBiWmhmYndhTmFLZ0VoM2RSZWhiQWRBaHhkdmNHaEdhWmUyZlllV2MxZklhYmN3ZTVmT2hGYUJnMGhIZEZieWhBZStoS2hDZzFkTmJQZmdjTmZHaEFmUWd0aE9iVGhIYVpjMmdVZGtkSWZWZGVhSGNZZFNmU2R4YWhkRGZFZUNiUmZ5ZmVmQ2JSZUlnWGZWYlJhYWhaaG1icGZDZ2RieWZGY0RkVmYxZGtjUWRHYldnZ2hMYlJnV2Q4ZVJjRWgyZjljSGNjZXhjTWVSaEtnVWJkZUloQWNrZWNiTmVaYmlmWWZlZVhjRGNsYjhlTGFqZVpoSGRXYWdiMWJEYVlnUmdZZFllWmRoZVJkbWFaaG1lRmJ3ZFZjV2Y5YmFoUmR4YzFoVWZFYjFnSmE4YVFiWGhwZ2pjVGNXZXBlTGVEYjFoSWdRZVpjRWZ4aDJlZGNsZUpkQ2dGZlhjaGErYkdjaGQ5Z1FkQ2dnaHBhc2NEYlRiRmZnYldhRWJOY1VjV2RpYUVod2JBZmliUmgwZUZlaGFaZ0thQWVoZkJla2dJZ1VkVmV2ZkVnUmJOYnZnUmEzZU1jVGdSZzJnZ2RWZVNiRmJCY0hmRWdHZ1pjNmdBaGxiMGhqYkljVmI4ZEloRmRsY2tkRWhhaFhmd2RXZVNhbWY4ZlliVGhHaFplaGNjZ0ZoVmR2aFdha2NjaGRlSGNWYVZjU2dkZkdmdGM2YVlmMGExYWliR2dRZDliUGFFaERoQWNFY1BheWdWZmNjUGhWZFJhc2diZ2hkdGdIZ01la2ROZVphWWRuYkpld2djYUVkaGhEZ1NhVmVwZTFoZWdFZHRkM2FlZW1jbGJmYkRkVmZoZFFoT2Z3ZFVmNmNMZmdlVWRMZWJmMWdwYnpkUmZ3YThiaGdSZWtkWWh2Z0JmZ2NGY3dmZWIxZG9oL2JhZG5iSmhSYmRlMWRkZUtmRmJtYWxjaGRGaGhlaGJtZkZmR2FaZm1kWWZYaGdoQmJKaHhmTWhVZ0VmMmRJZ1VoUWEyaEpjcmJaZzJoTWhmYlloMGZjaGxiVWVoY0Joa2NUZUhkWmcyZlVia2NJZlZoZWhIY1loU2hTZ3hkaGZEZ1djWGJGY2doY2FHZjFhVmZRYXhiMWJUYVhiM2JoZ0xhZGEzZnBhcGZWYzFha2NRZ0dkV2RnYkxjUmFXYzhkUmJHZGtiVmhIaGNneGROYkhiYWhCaFZhSWZVaEVnY2FRYVpjbmJKZVdnRmZXZnBmeWFBZ3phSWVEZEhhMGhRYm5nWWVVZkpiUWVMZDBnZGQ5aFRjR2VGZ3dhVmVXaDlmYWVSZXhjMGVkY1ZlVmVKaDBlYWQzaHBlamJHaFdicGdHZUVhbGVJZkRjZGhsYWRjY2FkYmxlSmRDaEZiWGVoZjJlRWZrZ3NmWWhRYjFlbGJpZ0xjMWNwY3diU2FFYU5lSmdXZG5lVmQ0ZFNmM2VkZDZiYWFWZGNkUGZVZ1VhdGhvZlFna2dWYXljRWhSaHNmN2REaHpjcGFBYlNlUmJkZlVlWGZFYWhiSGdEYUhjcGh5Y1Jmd2FOZ2phY2NnZzFhM2FBaHdnSmNmZE9kbWI5YnBoV2RYYlVnR2RhY2tjeGVoZmNnRmdWaHZiV2RrZmNjZGRIZlZlVmZTZ2RhR2V0YjZkWWZ3YWhocWFWYWdiOWVhZlJoQ2h3aEZjSmFYY2dkdGRBY3dhUmh1YmRnZ2c1ZlhlR2VGZUpjUGZhZTNkSWJzZ2NiQmF3YkxkQWJBYmxmN2dCYXdhcGJuY2FmbWhWZzliV2NSY0FkWmhhYkFjdGRGZ2JjeGFFZFRoYmUwYmRhemdFZjBnY2ZuZkZoVmNWYVFnVGIxZWxkbWNiYUVoZ2JMZWFmaWNaaFllZGh3aHRiS2RIYWljeGFoYUNnZ2VSZ21oSGhIYlZhMGRZY1hjMWNWY09jMWVOZU9kRWFUZ2RhVmZVYm5jUmFyZ2VnbWROaE5iYWNrZHNnUGdVY2hmQmNrZVRmRGQ1aDJkVGQwZklkZGNQZVhiWWhNYVZoUWdaZkRnRGFXY3RheWRMaEhmQmNBZUNma2hsaEdjYWVYYmhmRGZaZEdlaGVwaFdnbGFsZ0VjRWRHZEViUWViZDJkOGRSZkVjMmM5ZEhhY2V4YU5jSGRhYkJnVmdJZlViQmVWZ1ZoTWFpZWNjRWNXaDJkcGY2ZmVnM2ZkYVhjU2FoZVplcGFZaFJiWWRZZ1pmaGhSZW1kWmNtZ0Zid2NYZlRlc2RTZkRna2Y0ZVRoS2FoY05ma2JlYTNhcGErYVRiWGV4Z2VnR2ZrZ0VlRmJaYUVhcGYyZFBkbGN0Zk9iUGMzZWhlMmRFYWtlc2JZZlFoMWVsaGlkY2VuYkJkd2dTZUVkTmZKZ1VnaWVFZHdnQWNpY1JmMGZGZGhmWmJJZ0JmaGVsYTFjQ2h3ZzFkdmVEaHdoMWh4ZVJjMmNJYkZkVGZtY1FoL2ZTYkZiQmNIZkVjR2VaZnlkVmZoY1ZlcWVjaGxiRmMzaFZlMGhvZGVmUGFTZWxiZmVTZjJnaGNyZkpmM2VWZHplY2dFZGhhdmRUY0ZoSWVJZ0Rla2RCYVNiY2FtZXNhMWJhYmthRmNBZFNjd2Y5ZFNhRWRHZ1JhTWdkYm5lWmFTaFFmaGhWZzRlZGNoYkpoRGJUZkFjc2hRY01mWGd3YVBnTWNWZnhiYmhTYlVlZGcxY05jMGN0ZXBjWmRIZGRhWGRTZ0FmWWNRZVplQ2ZGZkZoYmJ4YkVjVGFiZjBnZGd6YUViMGhkYm9jRmJVaGhiUWFSYjBiUWN1ZE9hd2dVZC9jYWFuZEpkUmNkZjFjZGhLYkZmbWhsYmhjRmFoZmhnbWFIaFhkMWRNY1ljWGJCZlZlYmExYnBjSGZIYlJkMWFWaFVkaWFsZ2lmZGRrZ2xnTmNhYWtkc2NQY1VmaGJCZGtjVGJIZ1pmMmhXZWdob2FiYUtnQ2hSZGRnSGUxZWNlWGdBY0RmSWMzaGZhamdNZUVjRGdBZmNjZmdkaFdlVmFMYU1kU2Q4Y25lRmZBaDFhWmdWZWlkWWRMYlRmV2NZZlJlU2dFZVZmSGFjY3hlTmJIZ2FkQmRWY0lnVWRFZWNnUWdaZ25hSWZFZVVnRGU0Zm5nQWN6aGxoWGhCZEZnTWYrYlllVmg0ZFFiTWFsYXdodmNOaFdnOGhQYkZjSGY5ZEthU2d4aDFmSmNIZ1Jic2huaFpoUWdVYWlnWGJIYXhnSGNEZHdlWmJZaExmUmM5ZDRlQ2dSZk5kUmdCYTNlUmYyZFJiZ2JOYVJjRWdGY2NhZGFNZzJjUmVvaFFnVmRoY2pmV2RuYlZkNGNTaDNmZGI2YWFhVmhkZlpoRWVFYlJoaGhCYzJhOWd2aEVkUmNOYnZhUmUzZE1hVGVSYTJoZ2RWZ1FhQmJsZEhhRGRXaFlnSmRLaHhieGhtZFdkRmZGYjNiVmQwZG9mV2FhZFdhRWNXZkdlR2NZaGNkSWIyYVpiOGRjYUJmTWE2ZEZkQWdSYUpjVmhCYm9mY2VkZEdlTmR6YVlkeGFaZkFoU2R3YTllU2ZFZ0djUmRNaGRmbmJaZlNjUWFoZFZhNGZKZUZkY2ZmaFRnUmJFY1hnWWhqYXBhcmdXZmtkaGNEZ1NkVmZwYzFnZWVFZHRhM2RlZW1ma2hLZFZhMWZGaEpmT2RFZmNnY2haZDBoTWdmY2Jld2g1ZjZlR2hraHRhQ2hGYVViaGJRZVJieGVCZm1hY2dsY1lnVmVhaG5oTmRaZUllUmVnaERlVWdtYWxleGNGaGhnbGU3Y0NmV2NZZ2phWWZYZlpoVGZiYzFkSWNUZUVhMWFnYU5iQWNqY3NiNWZMaGpkQmNOY2RiMGF0ZktoV2F4ZmxlL2JaY25lWmIyZVVha2VJYVZiZWFDY3NnYmhRZDBld2FMYUVoRGhGZDdlYWYxZHBkSWZRYTBjbGRhZktmSGdSaGhkZGQzYXBlcGJWY3hhOWRGY1ZoeWh0aGZiRGdDY0JoZmNFYzJnY2VUYWZheGhNYlZiWmRCY1ViQmFXZVVlZGFMZ1RkSGVKYldjRmhXZXBheWhVYVhnOGNSYkhjMWVnYnFoTmdWZjlkWGNLZkJmUmN1YU5nR2ZoZndiRGNrYlZmYWNSY3hiMGhkZ1ZjVmdKYjBnYWh6Y3dnMmZBY3lia2JmYlJnaGMxYWVmWmJBYWxiK2JJZ2xkdGRDaFRobGVKZjJlRWZrZHNiWWFRaDFnbGFpYWNlbmNCZndhRGhnZ3doYmZXZG5lMGR1YUNhaWRWZzZmT2cxYmRhRWdFaEdjSWFWYkJlMGhVY21mRWdRYzVidmFWZjNkOGFUYkFhbWNnYkliU2NBZlJnSmhYZENoTWU4YUVmVWRFY2lkYWJWYUVneWJWYTFoUWhXZUllSGFvY1dmVWNXaDBoZmViZTJmWWU2YVdkbGdWZ3ZlV2FrZGNjZGFIYlZjVmRTZGRhR2R0YzZkWWF4aHNicmJHZFFmOGdkZUViSGJsZk1mSWNuaGdoUmFDZWxkUWVxaEZkVmUwaFBnWGNTY0lnTmZhZGpkdGg1YWFlMmJKZ0RkU2VWY3BoMWZlZkVmdGQzZGVobWRsY1hmV2NSY0FiSWZlZ2hlTmhGZ2NlUmRGaGNmUmdVaGRjemNFYjBkZGRvY0ZiVWJoZ1FjUmd4ZUJmbWVjaGxmWWhWZGRhWGJJZERoZWVRZWNhZmdSZ1NhRmNwZFdoUmJGZE1iRmNHZVpjbWNZZ1hiQmFWYmJmMWJwYUhmSGZSZDFkVmhVZG5jUmV4Y2VlbmRGZWRmZmNsZU1iUGVUYUJmQWhyaFpkbmJaZzJhVWZrYklkVmFlZkhjWWNTZ1NneGZoY0RmV2JXYkpheWRiaDNlQWdhaFRnUmFrZ1BkSmdqZ0JiRGdaYm1iTmc3ZVZhd2FVZFFhRWNTYWNmTGVXZDNnRWZSZUJkV2haaExlY2N3YkpjVmVjZUJnVWdVYlVoRWc4aEdiZGRYY0pkUWVGZFNiVmI3ZVdoRmUxZFhlU2doYlphcGZZYlJhWWhZZFpnaGhSZ21hWmdtZ0Zid2hWY1hoVmZhZVVjZ2FnaFBnVGRFYVJnMGJkY1hmb2NzaFRlVGVZZ1hhRGd4ZzBhUWVlaGxlRmUyZ1lmMGhWZFJnQWdXZnhiY2VFaGtkc2VZYVFlMWZsYmljY2FuZkJod2VTZEVoTmRKZFdmbmZWZG5jU2R5Z1ZlMGVPZlFkSWhLY1djQmhGZjZmR2JWYUZkdmJUZ1JhTmJuZ0NnSGRNaE5hV2RXYWdoRWRXY2xkbGhMY0ViSGRkYWdkVGJoZlViMmRjY2xkbGUvYkdoRWVvYkloZGQyZEViQWdFaFdkWWNTZlpmbmJCaHliZWRWYmxidmVTZDFhVWZGZkhkUWVsZVNlZmdIYjFncGJZZDBidGJxZUJoQWFaZ2JlT2htZlJhTWJkYm5iWmJTYVFoaGhWaDRoZGdoYUpkTGhHYkVjTmFaZGVoSGhKYTRhT2ZVY05jSWRSZFhiQmMxaGVkRWJ0YzNhZWJtYWxmWGZXZFJhQWFaZWFkQWJ0ZEZkYmh4Z0VoVGVaZndnaGJ6Y0Rma2VkZCtoQWNGZjFoRGhVYlJiQmF0Y2NibGM0ZmRoWWhtZk5oQmZaZlVkUmNLZEVoR2ZrZXVnSGZ4Z2hnNmZDaEdoWmgzZ2NhWGdsYVZlTWYxZ3BnUGREZUFoMWdIYlFiWGdSYXRhZWVqY2RnRGdLaFFmTmFPZkFlSGFNYnJlQ2JEZE1jWGJCZ2tmcGRjYWNmWGY4YWJkUWNoYlJmcGNXYldoSmh5YWNoSGFCZkliUWcwYWxjYWdkYVhjaGNMaGRkM2ZwZnBhVmR3ZHNlZWFTaFRlMWNZYURmV2RjYjdlRWEyZDliSGdjZXhnTmZIaGFhQmdWYUloVWZFaGNiUWRaZ25lSmNXZ0ZhV2JwZXliUWcyZE5oSGJTZWtocGRwYmFmVmFrYVliZWRBYXBkbWJkZTNibGE1Y1dmVWJWaGFmUmN4ZTBjZGhWZFZmSmEwY2FoM2FwZWpiVGVXZ3BkTGNEYzFmSWNRY1poRWV4YW5kWmJFZXBmQ2RTZ1hnaGErZEdnZ2JRZllnWGZVaGRiaWVZaDJjSmM1YVNkRWZWaEpkVGRHZlpieGdSaDFiMWI2aGFoVmZkZ1plRWZCZ2xmb2JDYTBiVmZ2YUVhUmFOYnZkUmYzYk1kVGZSYTJkZ2NFZFdka2hoZkhmVGZHZFpiNmFYZWxjcGVxaGJkRWU5ZzNnUWVVZk1mV2JiZjJnRWVBY0NiMmI4YlloVGJHaFpjaGVjaEZnVmR2aFdla2RjaGRiSGhWYlZoU2JkZ0dldGY2YlloMGExZXFlU2d4ZjVoQWJDY0dmUWFRZ2RmbmI1ZEVnVWdSYVZmK2VkYmxnMWNDYU1ka2VOZ1pkWWRuaEpmd2NjYUViaGVEY1NkVmFwYjFlZWdFZHRmM2FlaG1kbGNlYlVnQWJzZXpmYWRBaHRiRmZiYnhoRWFUYmJhMGhkYnphRWZ4ZHBhQ2FGYlVhaGRRZVJoeGFCZG1mY2RsZFlnVmdhZmlhQWdVZklkd2ZJY1lmV2NHZGtidmFVYjBiOWFtZ1lmU2U4Y29oTmhXZGdnMGdQZ1FiZ2hHYVJoQmJVaEhnV2gyZjloQmJlYW1kTmZOZWFla2hzZ1BkVWZoYkFlNWVaZ25hWmEyZFVoa2NJaFZoZWFIaFlhU2dEZlVoMGVOZEdjamNZZDdjUGF6ZjVoSWVEZ0VhRmhUZWRmU2VOYmhkZGMzY3BicGZWZDFka2dRZkdmV2JnZkxlUmFUZTFnVWVSY3pkb2VWY1BmUmROZlZhYWRBZ2hoVmNVZkFnWmJDaElhU2FjYmJlVWhDYlFobWNBZm5ma2RiZERjMWJnYnVhTmNWZTRkeWJaY2hiUmRtZFpobWZGYXdjVmZXYzlmYWdSYnhjMGFkZlNnbGdJZjZnTGdpZjFlamZBZG1mSWRLZlhlUmNWZEZjS2FRYmtmNGdJY2dkRWE1YkJkQWVWaC9kSGZCZDViSWNCZXhmZ2IyYU5nM2RnZXhnR2RnZVFiY2NGaHpkQWYyYkhneWVRZkJlZWdTZnBlUWRIZGxiMGJoY1RhQWFBZzhlUmJSYnRibWJiY1hjTWdUZFJlMmhnZlZnU2VGZUJoSGFFZ0diWmd5YlZlZ2U5YnFhSmZoYmtkK2RCZ0VjcGVmYkplemFKYUNiV2hTZ2hmWGNJZ3lja2duZ2NnQmVwaEZhV2hraGNmZGJIY1ZkVmJTYmRkR2d0ZzZjWWMwZzFlcWFWZ0FkOGRFYlhneWMwY0llZGZqYjVlY2RBaFZiUWYwaE9laGNvYWZmVWRBY29jS2diYm5jSWV4YklhZ2Q4ZFdkQmhCZDhkN2FMZEJhZ2JNYWFhaGRSZWVnY2N4Y0FkWmdhYkFjdGJGaGJjeGhFYlRlYmgwZGRkemZFZTFhMWNvZ1dld2MwZUhkUmMxYzlndWJNYXdkUmNTZ1BhemI4ZlVlT2RRYk1iWmhiYlhna2djaEhmd2hOYk1iRmVHZVpjbWVZYVhhQmJWYmJjMWRvZmFlTmh4ZDFnVmhVZW5iUmVyZGVmbWVOYk5lTGFCZDVnQmdFZFVhUWR0aEFlemZoZTJmR2VrZ3BnQmRjZVhmWmhKZlliUmFoY0RmV2dXY0poeWhjYkhoQmVJZFFmMGFraElkTWhDZXdlZWNKYVRoUmZwaFhlM2hNZlFhR2dXaGdjTGZSZldhOGNSY0VnMmM5ZkhlY2Z4Z05iUGFQaEZhMGRCYkFnMGVsYURlSWN6ZWNkU2FGZFhoZGZ5aEJlWGNjY2VmQmhFaFVhOWJJZ0ZhaGFiZEloMWhzZmdoWmVpZjlhd2NTZG1lOGRPZVNmVmc1YVJoR2JoZHdheGFZZDNhTmhqY1ZlMmNvYkZkQmV3Z1loWmViYlVnQmdjaGRjbGNKY0NoRmVYZGhnMmFFaGtjc2FZaFFlMWFsZmlhZWdpY1FnNGNBZVJjQmFIY0RhR2RSZzRnVmNuZmNhdWFJZ1JkNGhLYUhla2NvYnRoVGdnZ0ZhaGVVZWxoOGFnY0NmVGhZY2JnVGFtYlpoVWhEYkJiUmRQYlFjMmg5ZjhkRmgxZkVndWRlZWhiQmYrZ1hja2ZZYThjYWhXZ0VkV2dHZEdiWWdVY1pnbWhaZWhlY2VGYlZodmhVZGhjTmJWaFZiQWNaZ2NnSWhuZ2xmNmhmaGtmMGErZ0FiMGJZZkJnSGJqZGNjSmhNYXpjSmhjaEFlVmVrZzNjT2NGaGRnRGFFYlVkMGZZYkpnamNaYjRjTWVVZ0ZhS2VSZFhhQmYxY2VoRWN0YzNmZWJtYWxnWGZXZlJlQWZaY2FhQWF0ZE5iT2IxZmxnYWJQZkVia2NsY0FnRWFkYzFhRmhSY3dnWWVEZ2toTmJvZ0llUmROZFFiTGhuZndnU2dPZ3hiZ2VFZVViMmFGZm9hSGF4aFJiTWJGYkdjWmZtZllhWGZCYVZnYmgxZXBlSGhIYlJkMWNWZFdmaWNBZWpmTWh6ZUJmRGRQYUZhOGNQZ1RheGFBZHdkQmdEZThkbGhYYUJhRmhRZVBlVGNJZGNhQ2hGaFFiTWVGY3llZGI2Z2ViWGc0ZWJoRmFnZnNiT2hKZXpoa2JJaEljM2NJZjZiWGRsYUFmY2JNaDJmZ2hMaFJmV2U4YVJoRWYyYTllSGJjY3hkTmVIaGFjQmMwY2NoR2ZBZjVlRGNhYkNiWWRaZlFjU2ZzZCtnTGRqY3NoU2RCZkJlWmMwZFlhUWRZZ1JkYWZqYTVobWhaYW1iRmV3Y1ZiV2E5ZWFjUmJ4YjBnZGJWY1ZjSmQ4Y1BoemFJYnFiSGdtaFFiR2hTYmhmOWNEaExmUmdZYXpoZGZraDllQ2hCZFhmRmE2Zk9nRWJzYVlnUWYxaGxlaWFjaG5nQmR3ZlNiRWJOZUpjV2RuZTBic2JBZ3plNGFwZVpkeGNvZmNoWGNWYVloNmRVZmtlVmZ5ZkVkVmUwZjZnQ2d6YjhmYWdTaDBnSWJWZVNnRmVCYUhkRWRHZ1poeWNWaGhkVmZxZ2NnbGFFY2phSGV3ZU5jRmhRZDJmRWNXYkdkR2dZZVVjWmNtZ1phaGRjY0ZhVmNtY1FlV2gwYWRoSGRWYVZoU2hkZ0dkdGI2YVloeGhCYUFoU2N3aDlkU2JFZEdjUmdNZmRlbmFZYkVkQWYwYmRhNGdPY0JmSmNXZkdoQWRwYlJnY2QzZ3RjK2dCY1NoRWF0ZlBiVWR4Y2hmZGVHaEZmM2ZlZm1jbGJYY1dnUmhBaFpiYWVBYnRlRmRQaEJhRWdPYWJkd2ZsZzdhRWRWYVplNWdBYlZiaGJBaFVjQWhGZHliWmRVZjRhQWZlZW1nVmRGZFljVWI1ZGVkQWRYYkJid2RGZEJlRmVxZFBjbWdaY21nWWhYYkJmVmJiYzFicGVIZkhiUmIwYlVmVWNtZGxhcmVOZ0didGJQYWViMWU4Z2ZnUWVBZmxjd2FXYm1lRmNsZFJhRmhRaE5hWWFXZ0VnQ2hXYWdoRmdVYVNlM2JWZndmZWdYYXhlaWRRaDBibGZhYmRoWGZoaExoZGgzZnBmcGdWZXdod2VRZUJoR2ZoZEZnVGZXZzBmQWVCaFhlOWJlYlplZ2V0YlFmY2RRYmRiUmNRYzFiNGJDYmZjbWVGYVBkQmdIY3hmamRVZTNiNWJiZVlhQmhaaHBjWWdSY1ljWWNaZmhjUmJtZlpmbWdFZjJmVmJYZUpnYWZDYVJoVWFmZVRoRWRSaGhjZWgyZXBheGZWZ0hhaGdmZEhoVWFBZklmY2UxZFJla2diaGtiZGhWZERiSGVwYS9kSGJtYUVnWWNRZTFobGJpYmNibmhCZXdmU2dFYk5mSmVGZW5iVmRsYVNjemFsYXlhYWEwZFZoQmFCaHdobGM1YUhnRmNKZDdmQmFBZU5lL2hWZG1kRWRGYVZoM2NnZ0hhWGJrYUZlRmFHY1hmMWhZZlZmaGdWYnFiY2hsYUZoM2VWYTBob2FlZEpmbWM5aEdiU2RpZGxnQWdLYVRoSWM0YkliQmRCaGhhRWZ3YmxkVWJTY1ZlVmZQZWRnQ2FOZnphYmUyZ2RhcWdTY3dmOWZTY0VmR2FSZk1hZGduZFpnU2hTY2xocGUyYUpoa2NBZUVnVGhBaHdmTmVPZHlkSWMxaGZoaGQwYVRlRGhSaHNoaGdQYlVhdGVxZmVhaWM4Y0NjRmIxaE5jTmVJYVVhUWNMZWJjeGhsY0hoWmNrYmNob2NPYVVkZGFvZkZhVWVoZlFhUmd4ZkJobWdjaGxlWWRWY2FnaWFRYlFhSmNWZ2NoRGZHZmtnTmhoYkZjaGNoaG1mRmZHZVplbWZZaFhhQmJWaGJkMWRwYkhlSGJWZEpmVmZUYzNiUmNwY0thVGZjZGZnSWZ3ZlZhSWRVZ0JlQmM1ZlViWGNZaGliQ2J4YkplUWROY3pmQWNTYUhnd2FOYnBmV2JXZkpheWJjYkhkQmdJYVFhMGJsaGFiZGJYZmhnTGVPZUhocGZ2Z1VnVmFrZVllRWVUZXdnTGNXZEdjOWJVZkdiemd0ZE9lZWJoZTlmSGdZZ0ZocGNJY1RjVWNjY1JiZGEzZHRkYWZGYVdkSWQ3ZlVjV2hwYVhjU2Z3YlpmZ2JhYUJlb2V5YVpiaGNSYW1kWmhtZkZjd2ZWZ1dhOWFhZ1JkeGgwZWRiVmJWZ0phMmRQY2pmUWhuY0NiQ2d3ZUNkUWNSZmRlVWRaZmtmeGgzZWFlMWRJZVdoVGhDaGdhemJYaFFmMGZZZ0ljZ2dzZHdoTWh5aGtiU2NIY1FhVWRQYkhleWJkZzRkVGhYZ0ZjUWdhZVZlZGdaYUVlQmZsZG9oQ2gwYVZhdmVFZ1JjTmV2YVJkM2dNZFRmUmd6ZndhVmRBYVJkNGVVZVJlQ2NjZjhlRmhWYUFibGhOZ0ZiRWJXZEJjUmVoZVhiTWFBYk5nRGRYZGliQmFSaE5mR2NaZG5oZGNuZTljdmdXZWthY2VkZkhmVmRWYlNiZGJHZ3RnNmhZYTBhMWZxZFNnd2U5ZVNmR2RHYndnRmZkZm1hdGNTZ1Fnd2ZWYnhoZWNoZUpjRGdUZkVjTmRFaFlkamh3YzFkSmMwZWdoMmZBYkJiUWVoZFliQ2FvZGxiS2JDYmdhT2RVaFVmUWRRYVloUWJKZWVnUmRSZEVjVGRiZDBiZGd6YUVjMGRkaG9kRmhVZWhlUWRSaDBhWWVuY0llRmdaYmRmYWZtYzljUmdaZjFhdGVnZEZkbWhsYmhjRmZoYWhjbWFGYkdhWmRtYVloWGdCZFZoYmMxY29nU2NIZ1FjQmRWaEJnbmRvYW5oUGF5ZzBnS2RQZmdjTWJEZGVmQmdCZWtiVGNIZ1plMmdVZmtoSWdWZmViSGhZYVNnU2d4ZWhkRGNIZDJoSmV2ZmNoRGVoY0liU2VFZ2tlUGdiYWxiSmNMZmRlM2NwYXBoVmgxZ2tmUWZHY1dhZ2dMY1JkV2E5ZFllVmZXYzljUGhZaHhkTmhhYmRjUmhVYmRhV2NVZWRoQ2JJY3lmWWhEY1JheWJSYnljQmhUYThkZWJHaFFiMWJEZlloUmRZaFlmWmZoZlJibWNaZm1kRmV3aFZiV2E5ZGFkRGNsZ3NkZGFYZ1hoaGgwaGFnM2NwYWpmVGJXaHBjTGVEYTFjSWRRZlpkRWV4aDJlZGhsYXBnS2VRY1RkQWgvaFFmVWVWZU1lRGNBZzBiamFQZ2dhOGM4Y0RlUWMxY0phVWZXZ2hhNGdIYW5hNWEyYVFhMWFkZFpkRWZCZGxkb2FDZDBiVmh2ZkVmUmhOZXZmUmczZU1iVGdWZjJnZ2VJY1ZoVmZBYlRmV2dDZThnaGhXYUZnZ2J2ZFBod2VJZCtjRGZRaDhnV2JiZDJoY2M4ZUdhR2FZYVVlWmZtZVplaGZjZEZkVmh2ZFdma2JjY2RiSGFWaFZlU2VkYUdnTWZ1Yktld2NRYzVmUmVVZ0lhWGVYZ1Nkc2hlZ0xoM2JaZlBiUWZsZnBhNGNhaFJhSmJKZkdka2JOY0RjWWdqZ3Rmd2NiZDBiZ2ROZ0RnQWExZTFlRGhRZUlmNWdMZ25mRWMyZUNkMGRKZ1loTWZRZE5oV2JmZFJlZ2VUYWRkVWZjZTloVmNoYkJkb2dSYTBlQmdEYlZlUmVsZnZmZmVuZndnVmNhZ25mSmZSZWRnMWFkZEtkRmFtYmxhaGZGZGhhaGNtZUZjRGFJZnVoS2NDYk5lYmFJZmhnOGdLYVRhbGJRZ1BmRmUzaFJhZ2VlZGpoWmdOZGRna2VzZGNmUWNCYmxlT2VUZkhmWmYyZ1Vna2RJZ1ZiZWhIZ1lnU2ZTZHhiaGREZ1VnRWFoZ3loY2VIY0JnSWVRYjBibGdhaGRiWGFoZ0xkZGIzZ3BjcGNWZHdkdGRWZlRnVGQxYVpkQ2YyZzhhWmFPYVdiOWdIaGNmeGhOYUhiYWZCZVZmSWhVZEVhY2RRZlplbmRKZFdlRmNXZm9iOWRlZDNnZGFYZVNkaGRaYXBlWWNSZlliWWJaY2hiUmNtYlpibWdGaHdmVmRXZTlnYWJSZHdoSWdkY1hjUWNZZThjSWNpaGxidGdBYkNmOGZHZFFkQWRCZkpoWmRFZWRicmdkZmdjWmZMYVBhM2FoZTJnRWRraHNoWWFRZDFibGJpZGNlbmhCZndjU2RFZU5hSmhXZ25nVmE0YlNjMmIxYTZiSWdIZzFhWmRFaEJmbGFvYUNnMGJWZ3ZlRWNSYk5odmJSZjNkTWZUZFJiMmRnZVZlU2ZGZEJnWWJFZURmSWM2ZEhkMGZaZWtoUGJ4ZFFiNmFHZ0JoaGdQZlpnemhKY1RhVGNHZDVoQWZhZkRiVWIwZE1haGFRaDlhQ2VBZlpoRWJGZFVmVmNlZmRiRGg1aHpnYmIwaDBnK2ZBZTBmWWNCYUhlaWdrYkpnT2N5ZVViYmZHZkZhQmh4ZFhkQmdKY0xhR2VFY05hWmJZZW5mSmd3Z2NjRWNoY0RhU2ZWaHBoMWZlZ0VidGYzY2VjbmdOZ1hnRGFSZjVlYWRKaDFhc2VjZFpiMGNWYWJmSmRoZVJoOWRYZGdlSWJsYVdmaGZvZUpjU2R4ZEFkeWRPZWhlOWhHaFpnRGQ4YVVjT2FnY1FmRGVUY0NoeGJ0ZEZlZ2doZXFhRmVEYk5ldmJiaFZhcGFWaGJiMWFwZkhmSGNSYjFhVmJVaG5iUmdyZ2VlbWZOZE5lYWhrZnNmUGJXZmtiUWRzY0JoU2VWZjRnSGJ3ZGRjWWhLZXplOWRJZkRjaGZoZkliUmdHY0ljbmZlYVhieGZpZFFlMGJsZGFhZGFYY2hlTGVkZjNlcGZwZlZlMWNraFFlR2hXZWdiTGZSYVRhdGJaY1dkamN4YnRhY2d4Y05jSGVhZUJkVmhJZ1VlRWNjYVFlWmhuZEpoV2RGZ1dmcGI3ZlNkbGcxZVhnU2VoZVpicGZZYVJmWWRZZFplaGhSZ21lWmFtZUVhNWFFYzJoOWRTY0ViMWVWY1VnQmFsZndhNWFMZmpoY2h3Y0JkRGdBZU9mRGcwY3djUWRkaEVlVmUyYUxnWGZoY0NlRmJYZWhlMmhFaGthc2ZZZVFmMWJsZ2loY2RuZkJhd2NTaEFjeGFqZldlbmZWaDRmU2QzYWRoNmdhZVZhZGFaZ0VkQmdsYW9jQ2YwYlZndmdFYlFieGN2ZVRkeWdkZWJiRGdqZXNnYmhCaFJnVWdLYVhjemZRYXJlVmFoZDVhM2FjZmdnVmY1ZkJmQWJaZmZnS2NpZ1FoZWRDYUdob2RVZGRmWGdSY2hjZmhWY1VlN2NFZmdhNWFPZkVheGRnaFhkT2ZUZGdkemZPZFFiaGJqY1FjaWJWY1NiRWRHZFJiTWRkZW5mWmNTaFFmaGNWZjRmZGNoZkpmTGJHZUVlTmRaZGViSGJJZjVmV2RrZ2hnRGhTY1ZicGgxZ2VkRWd0ZjNlZWFtYmxmWGNXaFJlQWFaZmFnQWF0Y2FnYmgwY1ZhYmhKZ2hhUmE5ZFhhZ2FJZ2xmV2hoY29hSmFTZFVoTWNqaEphbGQ0YS9nYWduYkpkUmJkaDFhZGhLY0ZhbWJsZmhoRmVoYWhobWVGZEdhWmhtYlljWGhCZ1ZiYmMxZG9oVGFFZTBkNGhBYkVkRGVVYjVoS2hDY0llVWFZYWxkc2VEYlVmZ2NOZTJkVGJIYXRmMmFCZGdicGJjZktkM2ZoZ2ZhRGRsYVViUWRFYURmZ2QzY2VjWGF4ZmliUWUwZWxnYWhkZ1hoaGNMZ2RkM2NwZHBoVmQxaGtnUWRHZldmZ2VMaFJnV2g4ZlJoRWIyYzhnVGRPYTFnb2NVaFplbGRnaE5kSGdSYlJnWmJQYURnZGQ4YkZnV2dwZXlhVWJYZGRiWGRTZWhkWmVwZVliUmJZZlllWmRoaFJibWdaZ21nRmF3ZVhoRWJWZGFkUmh4YTBkZGFWZFZoSmYwYmFiM2hwY2poVGNXYXBiTGZEYTFhSWVRYWZha2Z3ZmlnZWVCZUViTmZSYlNiRmQrYlJkZ2JOaFJoRWNGYmNidmFOYXpoMGgvYkdnaGZwZUZjV2NpZUVld2hBaGljUmQwZEpiQmNJYVVkUWExaEFleWRUYmtkbGF2ZkFoUmg5aHZkVmJHZEVhVGNTZ21oaGFCYUFnQmZrZFViSGNpZXNjM2dHZjBlWWZqYktiQmJSZCtlVGZHYkFkV2dhaFdoRWhXZkdjR2ZZZFVnWmNtYVpmaGFjY0ZjVmN2aFdhaGdGY2NmVGExZlVjZWJkY0hjWmI2YmNlMWNaYkFoU2R3YzlmU2VFZ0dkUmNNZWRjbmdaZFNhUWNoZlZjNGFkYWhlSWVDZVhia2ZOZFJjTGZYZ3Rhd2hLZjJlSmdEZ1NlVmVwZTFiZWNFYXRjM2hlYm1kbGdYaFdiUmNBZFplYWVBZHRhRmNPZlZkQmVCY2Jkd2RSY29lT2hVZGRkb2ZGY1VjaGRRYVJoeGhCYW1jY2FsZFlkVmJhaG5mSmVSZWRkMWZkZ0NnVmVXZ2xnOGhGYmxkWmd1ZlBhbWFaY21hWWJYYkJiVmRiZzFocGJIZkhhUmMxZVZkVWNuZFJhcmFlZm1nTmNOYmFoa2hOZ2JhR2RsZWtnM2NRYmphc2V6Z0hhd2cxY0hnSWNYZmhkUmZBZTFka2hSZk9haWEwYjJkTmVSYUVlY2dTZHdlVmJhZ2ZhbmNoYWFkZmhuZHBmMWJTYTFna2NJYkVoR2JoaFhnYmgyYzhmUmdFYzJoOWNIY2NheGVOZUhoYWRCY1ZnSWVVYkViY2JRZlpobmVKaFdnRmNXZnBheWFCYlRkOGFlZUdjUmZnZmtoSmRGZXRjWGROZkVoMWhvZkpmU2hrYnhhQmV3ZHdiVmRBZTFkaGg4ZUFjVmZvYzRoWWVuZlpmSmJUZFdhcGZMZkRkMWVJY1FhWmZFZXhoMmVkZWxkSmZDYkZiWGZoZDJmRWNrZXNjWWNTaHdiMGRxYU9ieWNOZitlQmJRYVloRWVGaFNmY2FoZVJmVGhRaHljS2NBYlVhNmZYYTFlMGN0ZWFiaGZGYW5nWGZSZE5la2dSZjJoQWZhY1JhM2VRZkpoU2FFZGhkT2FFZkRkcGJZYVZlaGVWZnFnY2ZsZkZmM2JWZjBob2dXYmFmV2VFZFdjR2dHZVlmVWRaYW1kWmNoZ2NoRmVVaDdmRWRnYTVlT2FFZ3hoZ2VYYU9oU2JRZ29iT2JrY01hcGFBZTBoNGFBYmNmeWdzZUlmTWN4YWNnR2dTaGxlbGY0aGZmUmVKZFphRWdVaDllemdZYW5oSmh3YWNlRWNoZERiU2FWZ3BiMWRlZ0VodGIzZGVibWRsZ1hhV2ZSY0FnWmNZZ0ZlOGNOaEpia2FJY2RnSWJnZ0lmK2JYYkJmVWF4Ykdjd2RzZVlnQmZrYUloRmFQaFJmSmFRaENoeWdaYVplT2IxY2RoQmFGZG5meGRvZkZkZ2VSZjZoRmZIYjVodmNZYVNleGUvZWJmMWRwYkhmSGRSZjFnVmJVZ25mUmFyY2VibWJOZE5iYWhrYnNlUGRVYWhkQmhrZlRlSGdZZmlnR2ZnYXRhR2hkYmpldGNYZUJjbGJjYVJkQWRHZHdieGdPY0RjRWVhY0lmQWZZYWVlTWVCYmtnZmRmZHplWmhwY1hiRmdrZkVnRWZHYlFoaGhSaFdoOGZSaEVoMmQ5ZEhlY2V4Yk5mSGRhaEJnVmVJZVVlRWdjZ1FnWmVuZEpjV2FIZ1RiNGc2Y0djQ2FSaFphQmQxZk1ma2NMZGtiUmZCYWFnRmFjYnVhSmV6YU1jVGRHZ2lic2JmZ0pma2VrZ1ZnR2ZWYkpkL2JhZzJiMWFxZVRjWGRaY1hiRGQwaG9mWmdaYkJhQmVjZGRhbGJKY0NlRmJYaGhmMmhFZmthc2NZaFFhMWFsZmlnY2duZUJkd2FTZUVjTmRKZ1djbmVVZXNjQWd6YjRlcGVaaHhjb2FjY1hkVmhZZzZoVWhrYXNjc2VXZVZnSWU5ZUpkRGF4Y1hjQWZnYmxkQmZRZkJheGdIaEdlMmdaYmtkWGV6YTlmcWhjZmxmRmQzY1ZkMGNvYVdlYWFXYkVjV2dHZkdlWWFVZ1plbWRaYWhoZWhWY3hhamhjY0ViY2NkZUhjVmVWZlNiZGZHZXRkNmFZZzBjMWhxY1Nhd2g5ZVNoRWdHZFJmTWVkZ2lnSWdhYUNmMGFaaDJnSWdBZU5iRmhXZVFjY2NkY2FiamNGaCtjUGNSYjBnUGRIZlJhTWVsZk5nQmZKYS9iT2YyZEJoZWVWZTBmSmFXZ1BjRWVkYk5kZmRBZ0FiYWdZZFFib2FtZlhheGVNZGhoUmFRZFFkSmFUZTBnTmV2Y2ZkbmF3ZVZkYWNuYUpiUmFkaDFlZGFLZ0ZmbWJsZWhhRmNoZmhobWZGYkdjWmRtZ1loWGNCaGRhSWQxZ3BlTWJBZEJlMWhOaFdlM2FoZUJhZWhtaE5oTmdhY2tjc2NQYVVhaGNCYmtnVGdIaFpkMmVVYmtjSWZWZWVkSGZZYVNiUWQxZ3RjRGdSY0djSWU4ZmVmRmVwYUlhUWgwZGxkYWdkZFhiaGdMZmRkM2dwaHBoVmMxZmtkUWZHaFdiZ2RMaFJiV2U4aFJnRWIyYWNmVGdPaDFhb2ZVYVpobGFnYU5iSGFRZmhjQ2dQYTNod2dWaFhkU2ZzZGdmTWJqZWdnVGdEaDNnY2E5YWFiVmFvZlloYmRSYVJnM2diZDJjRmhzZ1NiV2c5ZkNkVGNoZTFiQmRmaDFiSmYwZ2FhM2RwZmplVGNXZ3BkTGJEZjFiSWJRZ1pjRWR4ZTJoZGVsZ0pnQ2RGYVhkaGgyZEVia2Z0Yk1iQ2F4Z0FjeGRmZkRoMGcxZ0JlUWJ3YmJoQWczZHNoN2hBYnpkWWVvYkNlaGZnYWRjVmdYYWdkOGNBZXdjbGFtaEhjVGNsZnZkUmQzZE1lVGZSZDJjZ2NWY1NkRmJCZkhnRWVHZVpmeWhWYWhlVmJxZmNjbGZGYTNnVmMwZ0poQ2RJaFNnaGJGaEZkaWJ0Y1JiS2h5ZmtiemFLZ1Znc2NzZEVkZ2haYVBoZmdoaG9kV2NNZFFnb2d1Y2Fhd2ZGZnFkUWdBYjloQmVHZ1djUmFRYmFibmRaZ0tnU2Z4ZlVoa2dYYkJiSmFMaEdlRWROYlpkWWduZ0pid2hjYUVlaGNEZ1NhVmRwZjFiZWFFaHRoM2NlaG1mbGNYaFdkUmhCYk5lSWJFZElnV2NZaFZmeGNXY0llZ2hnY2hkU2FraGtocmFYZ1Fha2VDZUpiRmY4Y2lhTmd6Z2RnQmhZZ2pjNWZSYmZoRmhkZ1lnSGMyY1ZoTGJGZ2hnaGVtZEZnR2VaZ21lWWJYZ0JiVmZiZTFncGVIYUhkUmYxZFZnVWhuZVJicmRlYW1jTmFGZFBnZ2JOZ0dnQWNSZjRlcGJDZ1Ric2Y1ZEFkQmJzYWJmT2Z6aDVoVGFHYVhnc2dNZUhiU2VjZVRlSmFIYWdnRWVRZjBnSmRhYVlmSGhGaExmYWMyY1plcGRUYjFiQWJRZVJlVWJJZkxjUmVXYThiUmNFYTJoOWRIZGNoeGJOaEhiYWVCZ1ZoSWZVaEVkY2ZRZlpmbmdKY1djRmhXZXBoeWRCYlRmOGdlZUdmUmdnZGtiSmRGZXRkWGNOZkVlMWJvZEpmU2ZrZXhiQmh3ZXdkVmZBZjFlaGI4YkFkVmNvZzRjYWIzY0ZiamJXYVdoTmFIaEpkVmhJY1FnWmdFYnhkMmJkZ2xlSmdDZkZlWGdoYTJiRWZrY3NkWWNRYzFkbGZpZ2NibmhCZHdjUWJCaGNkQmRFZ3ljWmgyZkJlamRJZDNiSmhnYVViQWZIZmxnb2RnYVNnaGRjZU1jWGFsZWNncWZKaGljY2JiZUNkMmZnZWViU2JFZGRoT2FFYkhicGJ1ZlZmZ2MxY2pmY2ZnZjFmZGFWYTBjb2NXZ2FlV2NFZVdoR2VHaFlnVWVaYm1jWmZoZGNkRmdWY3ZjV2FrZ2NhZGJIaFZjVmJTY2RiRGE4YnlmS2NoaDVka2dCZ2tmb2ZmZlhkemZZY1ZoZWdEY1VhYWFBaDBhY2diZU9oVmdZZ09mZWVSYmRjUmdMZW5mSmY3ZmNiRmc1Z0toWWUxYnBnMWdlYkVldGczYmVibWRsYVhlV2FSZkFlWmdhZEFidGhGY2JmeGRFZFRmYmUwYjVhNmRIaDJoMWNvZ0ZkVWhoYlFmUmJ4YkJmbWNjYmxmWWRWYWFnbmNKYVJmZGUxZmRiS2dGZW1ma2cxZFhmbGNFYTFmR2ZqZUJjMGRiYnpnRWVSZ0tnMWdJZEVmRWcxZ0FnQWFIZmljQWZpYktmaWc4ZlVhWWhnYm9iR2hXY3hmNGEyZEFmeWhJYjZiV2RsYUVlRWhjZ1hkaGdmaEhkbGdRYlhhRWREYUlnK2RLZlhjZ2ViZVNha2JWYXdlZGZYZGhoTGVkZzNjcGdwZFZjMWdrYVFnR2dXZmdoTGFSZFdkOGNSZkViMmI5Z0hlZWIxYzloSGdZZndmaGJJZFNoRWE0ZWNhVGhIZ0pkV2NGZFdocGN5YlVnWGhkYVhiU2RoYVpocGFZaFJiWWRZZlpjaGVSaG1nWmJtaGtjemVWZFhoSmNhY0NoUmhVYjNhVmFWZEpjMGFhYzNhcGZqZVRlV2hwY0xmRGcxYkllUWVaZkVleGYyYWRkbGRKYUNiRmJYYWhmK2JSaGdoTmdSYkVhRmVjZ3ZkTmZ6YzBhL2hHZmhocGhIaEdnVGgwZzVjR2RSY1FkMWNMZVJlSWE0ZFJhQmVFYmtkQ2gwaDVndmRBYkJncGJ2Z1doMmY4ZVRkWGYyZkVmVmZGZEhncGVIY0VlR2VaZ3loVmFoZ1ZjcWhjY2xlRmEzY1ZhMGFvYVdmYWVXZ0VoV2RHZUdnWWJVYVpmbWdaaGhlSmVCZjBmbWdDYlVmbGhRaFdkQmJnYWRjSmdqZ0piMGNJaEFiVWdyaEdhV2h3ZWRiVmVDZ0VjdGdJYm5hNGZlaFNjeGJsYVNkZGRoYkpmTGdHZUViTmZaZVlnbmVKYndnY2hFYWhjRGRTYlZocGYxZWVoRWJ0ZDNiZWJtZ2xiZmREY1ZhaGNRZU9jd2JVZkloS2dsZnhmY2JQZ1JlNWc5ZlVlQWc4ZXBjUmJ5Y3NlZmZBZTFoVWdIY0phbGQ1Z1piYWhuY2xhUmJaY0ZjNWRLY0NjbmFWY2hiRGhoZ0ZkbWVTY0VleGFtYllmWGdCZ1ZmYmUxZXBlSGdIZlJiMWZWZlVmbmJSZXJmZWVtYU5lTmJhaGtkc2NQZVVoaGFCY2tkR2NEYTRhL2FBZFVoeGJZZ1BmVGh0aGRnR2RVY0ZoTmJHZWlib2R6ZUllaGdNZkhoQmN3ZndjN2RJY1hkQWFIZWRhM2dGZXBhUmJWZkFlY2VNZjJnZ2ZMZlJnV2M4YlJhRWcyYzljSGVjaHhjTmVIZ2FhQmVWY0lmVWhFZGNhUWZaY25iSmFXZkhhVGQ0ZjZhR2ZDZVJlWmhCYjFhTWNraExha2VSZ0JkYWNGYWNodWdKYXpmTWVUY0dmaWZzaGZlSmNrZGtlVmZHZVZoSmYvYmFjMmY5ZXFnVGJYaFpiWGREYzBmb2NaZ1poQmdCaGNiZGdsaEphQ2FGZlhhaGIyZUVha2JzZllmUWMxYmxhaWdjYW5iQmZ3Z1NoRWhOZ0poV2RuZFZoNGNTZnliTWJ5Y0ljQWFSZ1hnWGZWaHdmbGdSYkJnY2QyY0hmMWJBaG5iQmJpYkZkd2JDZUNneGhRZ0tnUWZSY1BjWGFHYVphNWdWZmdhRmhqZ2ZibmR0ZDNkVmIwYm9jV2dhYldhRWFXaEdlR2NZZlVoWmJtaFphaGVjY0ZkVmV2ZFdma2JjZGRoSGNWaDBnR2dQYkNjSWZwaGJkUWNBYnZhQmZrZkFlQWFTY1dhb2NQZFBhamZjZEFkSWhWaG9hOGFNZzNlTWNmY0VlQWE5Y1poYWhYYkpobmJlZ1VjaGNmZlZiVmFwZ3RmY2NVY3NhcmdVZ0djbGZYYVdnUmJBaFpiYWhBY3RiRmRiZnhiRWVUZGJlMGhkaHplRWYwYWRib2ZGZ1VmaGZRYlJneGRBYnloT2NoZzljR2JaZkRnOGZVaE9jaGVnZllkVGQyaGNjaWZYYmxha2MwaGRjeWRrYmliSmNCaEVnQmJaZXhiWmdIaEZlaGgxaERlV2YxYjVjcmFlYW1jTmROYmFia2ZzaFBoVWdoYkJha2FUaEhiWmMyZFVna2ZJY1ZkZWhIY1lnYmdRY2hjUmRwYVdkV2JKYnloY2dIZEJiSWdRZjBhbGNhZmRiWGFoZExnZGczZXBlcGVWZjFia2NRYlRmU2ZCZUNhRmFtYkZlSGRBZ0djRWFHZU5nMWRkaFBoS2N4YXNoRmFCZlFmdGRFYUxleWNJZWFkVGRHZEliemRXZEhnNWJaZUdjRmFraDlhTGNSYjRoTGZkYnhjMWZvZUtiemdRZjhoQWZTZVljS2FDZjBlUWFWZ0JjbGV0ZTRoUWVYZHBkamFUZFdmcGhMYURiMWhJZ1FkWmJFYnhlMmZkYWxlSmdDaEZkWGFoZTJkRWZrY05iVWRRZTFnSmYvY2NmbWFoaDVkUmNHZmxiSmhXZW5nVmc0ZVNnM2dkZjZlYWZWZGRhWmJFZEJlbGVvZkNhMGdWaHZlRWVSZ05ibmFCaEhiTWdPZ1JkeWRZYmRkWWhsZEJjSGRFYkdiWmV5ZFZhaGhWZ3FhY2VsZUZlM2FWZTBnb2VXYmFoV2NFZ1doR2VHaFljVWJiZ2pjSWJwZU9hUWRaZ2hoRmd3YkpiUWFVY2djY2dMZGVjaWJnaHljSWRoZjhhSmJCZ0Vnc2VYYWNjVGhCZ0VnT2FuZFplWmFRaGdoUmV4ZWRjZ2E1Y1hjR2NGZXRkUWZZYmlhNWJhYmNhRWZoZ0RkU2hWZnBmMWFlYkVmdGQzYmVjbWdsZ1hjV2NSYUFjWmdhY0FjdGVGZmJheGdFY1RhYmJ4aE1iN2VXYmhoUmdtZVdmQWQwZGRlQ2dFY0lkL2RmZ0JmVmJkZUtkeWNBaHlkT2ZCaE1nUGdkZ3pnMWVwZ1diaGdGZnFjUGZtaFphbWhZZVhoQmdWZmJnMWVwZkhhSGFSYTFlVmVVZW5lUmhyaGVhbWVOZk5nYWhrYXNkUGhXY2thUWRzZEJmU2FWYjRhSGd3ZGRlWWdOYnlmUmFMZVJkVmVzY0xkR2JEY0FmUmdQZXplUWJOY0ljaGMxZFNiT2NYYmhoQWRkYTJmbGVnZVZkMGdVYk1oR2FYZkFjQ2NSZFRlTWY3aEVjMmg5YkhlY2F4aE5iSGNhYkJiVmJJYVVlRWNjZFFoWmJuZEplV2NGY1dkcGF5aFViWGJkZVhiU2NrYkljaGVLYUVkVWdXY0tnMWhFYXJjS2ZUY01lcGdXYnlnd2NTY0Joa2E5ZCtoR2RoY1loeGdDZ2ljNWdyYkFnV2hwZ0FjRGQwaEFnWmhhYkdiWmYyYWRjbGNKY0NkRmRYZGhmMmFFYWtlc2NZZ1FoMWJsYWlkY2VuZ0Jjd2NTY0VnTmdKZ1dhbmMwYnNmQWJ6YTRmcGNaYXhhb2hjZlhiVmhZZTZnVWNrZXNkc2ZXZFZiSWU5ZkplRGZ4Y1hnQWdnZWxoQmZRYUJleGdIY0dhMmVaZW5iWGd4aFZlMmRiY2xkRmV2aFhla2JwYUtiUWYyZ0VnV2NHY0dmWWRVZVpjbWVaYWhoY2VGZ1ZldmZXY2tnY2VkY0hiVmhWY1NkZGRHY3RhNmVZZzBkMGErZUFmMGdZZUJiSGZpZGthSmNPZHpia2ZBY0dleGZzZzdiUGVsZ01iWmVlYndjd2ZkYkpjeGFNZGtlZWZBYlJnRGhRYmxocGdoZGNiVWRkYmRjZWFtZGxjWGFXYVJkQWZaYWFhQWN0Z0ZkYmF4Z0ViVGZiZDBnZGh6Y0VoMGJkYm9jRmdVZGhlWWRFZzFoZ2V2YklmVmJoZ1lhTGh6aDhjZWRKY1FnNWdFaFZhU2RFYWdmUmRIYnNlcGJVYkNmTWJIYk5lWGhnZlplYmUxZkZiSGRDYmhoUmRWZFRibWhoZHJjWWNtYXBkTmJOY21mRWVQZFVnaGVCY2tlVGNIZVphMmRVaGtlSWNWZ2VoSGdZZFNmU2F4aGhlRGNXZldlSmR5ZGNkSGNCY0lmRmJ3ZkVkVGdKYW5oWWZHY01jamhjY21iQmRRZEFoZWRXYWlmQmRLZ0Zmd2Z4Z2VmVmR5ZG9obWFKYnhjc2hMYmFkQmU1ZUlkUmRrZDRiNmdaZW5lSmdXY0ZmV2FwZXlhVWFYYmRlWGJTYmhiWmFwYVliUmJZZFlmWmRoY1JjbWViaDJnaGE4Y2ZiMmI5ZGFmUmN4aDBiZGRWZVZmSmUwY2FiM2VwYmphVGNXZHBoTGJEZTFhSWhRZ1pmQmhnZStkUGV3Y0ZoTWNRYzJneGg0Y1Vmd2Y5Y2NlU2V4ZXBic2RQZ3liVWQ4YkhnQWVvaFpiRmJpYXhod2dDZW5mNWd6YVpid2hVaFdkUmNGZFZkZ2hHZEZnUmZtZUhmMWE0YzZoQ2V5aGRnYWVGZHlmUmJNaFFkQWFOYk9nQ2IwZ3hheWJWYWhmVmVxaGNnbGdGaDNlVmIwZ29kV2FhY1dlRWZXYkdmRGNzYVVlSWF5Y29heWJOZ1ZlVWYwZmNnRWZjZGRiSGRWYVZjU2RkZ0dmdGE2ZFlnMGIxZHFkU2Z3YzlmU2ZFYkdlUWNhZ05keWFSZlNiQWNRZjVlU2hkaGhnSmhMY0djRWROZ1piWWNuZUpjd2djYkVlaGZEaFNkVmVwZDFkZWJFZk1iMGhlaG5hUmFYYkZkeGZnZXpnYWdBaHRiRmZiYnhnRWJUZGJiMGNkY3poRWcwYWRjb2dGZFVmaGZRYlJleGdCYm1jZWZnaEpmZGZJZXloRmNmYk9kaGNJZkhnV2NUZnNlNGZiZVZnUmNtZ0hmMmNaZDNlSGNIZUJkSmFjaDFicGhmZkZiQmMwZEpiVWJpZEFkamVNY3plQmREZkpod2g1aENjSGRVY0lnOWFOaHpkb2VMZlhobWhnYlZiZWhIZVljU2JTYXhhaGREYVdmV2hKYnllY2NIZ0JkSWdRYzBjbGRhYWRiWGZoZ0RnSWJ6YUlnZ2RCaEZmZGJkZ1hkQ2hWZUVhRmJ6ZVpjcWdYZzJlOWZNZWNkd2RBYTZkYWFBY2xkVWRVYkZjOGRaZlpjaWY1ZldhUWVTYklnN2NBZG5ma2NhZERmMWZzZm1lTWQwaDlkamJLY2hiUmN0ZlphbmJNaE5iV2hVZ1ZnYWdSZXhiMGJkZ1ZmVmhKZTBhYWYzYXBkamFUYldmcGdMaERnMWZJZ1FhWmFFY3hlK2dJY2hlb2NMZ1JjbmZZZDdjVmN3ZlpnWGVFZFFjQWVaZFBjbmdCYjdjU2dGZ1lkMGFXaG1jbGFraFNiMmM5ZXpjYWdRZXRkWmdSZUZkRWVoZldnRWZzZWlnVmNGYzRmZ2RGY1NhcGVvaENoMmVnaGVlU2dFYVFmNmZIYkVkeGZ5YlZkaGRWZnFkY2RsYkZiM2FWYTBob2ZXZmFiV2hFYldjR2FHY1loVWFaZ21mWmZwZEpnQmcwZ21kQ2JVaGxoUWJXYUJkZ2NkYUpnamdJYkJhTGIwZjFhaGZTYnhhZ2V2Z0VjSGNoYVFlZGNtYzVnYmJRZ2tjbGE0Z0lmbGZvZkNoU2EwaDBhVWFKaHplOGUvZ0lkaGFFYjRnQmhWY3BkK2dlZ0ZmMGhLZ1VkR2RsY1hiV2hSaEFoWmdhZEFodGRGZGJoeGRFZFRmYmIwaGRoemFFZTBoZGJoY0hhRWNSYjZhUmJ4aEJkbWZjZ2xlWWdWaGFobmdKZFJlZGYxZWRmS2NGYW1obGVoZEZkaGRoYm1nUWZDYzRhdmNNaG5oNGhEY2ZibGhRZEdiV2RWaGxiZGZFZVhmb2FtYUxkeWc4YVpiSWN4YnRiRGVDZXhmZ2VsZlJlWGI5ZzRhQWZBZzFiQmFOY0hlNGNCZldjaGJGZ05hRmJEZGNkK2ZKZERha2FZY0RheGJCZVNmSmZuY0ZjSGZYaFhicGdwYlZmMWZrY1FoR2NXZWdlTGNSYVdlOGJSZEVoMmY5YUhhY2h4aE5iSGZhZEJoMGFFYlVoRWF3Zk5nWmZtYXBhZmhHYVVkQmh5ZlVkWGVkYVhnU2FoY1pocGhZZlJkWWFZYlpmaGhSZW1kWmhtYUZmd2FWaFdlOWRTZ0JjQmUwYUFjVmZSZnhkOGRRZFhlcGZqZ1RmV2hwYUxmRGExZUloUWFaaEVoeGYyaGRobGVKaENiRmVYZWhnMmhFZWtlc2VZY1Nnd2MwaHFoT2N5Zk5hK2RCZ1FoWWFFYkZkU2djZWhkTWFEYnRnNmFZYmxhZGNJZWJnUmdsYjBoRmMwY1ZmM2hHYUJmTWZ6ZlJneWRkZ2JoRGdqYXNiYmJCZlJnVWFLY1hoemhRY3JmTGRWZWthWGVmZG5hdGQzaFZlMGdvZldlYWFXZ0VlV2dHZUdjWWhVaFpibWVaYmhhY2dGYVZldmdXYmtmY2dkZUhoVmQwZUdnUGdDY0llcGFiY1FkQWd2ZkJoa2ZBaEFhU2ZSYThjQWhkZ25hMWhTZFViV2JoZDRmYWFnaDVlTGVBZkVmcGZaY1BkbmNJZGtmT2hBYkVnUWNSY3hmY2d3YU5lUWdRY2xiSWJ4Z0lhYmdXZVJic2ZaaGVhbmJaZEpmUmVSY0VhVGRiYjBlZGd6YUVnMGRkZm9hRmFVY2hoUWhSYnhjQmRtZ2NkbGJZY1ZlYWZuYUpiUmhmaHdnTWNDaFhoemRwY3ZjV2YxYjBjcmRXY3piUWYvZ0diamd4Z1ZhWmFGZ3BkU2NZZEJkMWZKZVRkbmhSYnpjY2cyY01iUmdhZWhoOWVIaEdiMGROZHFnQWVUaE1kN2ZIZFJlQmhNYUFkemRvZ1NlUWVCZ2hlWGRKYUdoNWhZYmNnSGRCaEliUWUwYmxlYWJkaFhoaGVMZ2RmM2dwZHBoVmgxZ2tnUWZHZldkZ2RMZVJkV2Y4ZVplUmd5ZGNkT2RJY0JjMGNLYkxmVmdnYUhmQWdoYjVjcmJLZm5hSmVkZkZoWGYwaFBkVWNXZ3RhTGNTY2dnNWJnY1lhVWRvZllnTWNsYXdidmhOYVdkOGc5Z0VjQ2FJYVZkRmVVZVJkbWRHYlZmSmYvYmFjMmh3aGVoWmgyZXBhTGNEYjFhSWNRYlpkRWR4ZzJnZGNsZEpkQ2dGYVhoaGUyYkVja2dzY1lkUWYxaEJlcmJmYmxmcGJ3ZFNiRWhOZUpmV2ZuZVZjNGZTZjNnZGY2ZWFiVmdkYVpmRWJCYmxhb2VDYjBlVWY3aFdnVmNvYzhhU2JTYVVoQmJTZ1NhbGFSaERoRmhnYUVnSGNpaHNjbmVHYWtmRWJqY0llaGIwYXVmWGJ3ZXNnZmhZYUdkOWRFZlZkemJKZVlkYmhuYVZmd2NlZlZlc2JpaERhd2V0Z0pjVmZBaFViZWVMZldmTWhwZWFla2FGZ0FjU2Z3ZTloU2NFZEdiUmFNZWRnbmRaZ1NmUWNoZ1ZnNGJkYWhoSmNMZEdlRWROY1phYWJqYzVhd2JlYzFiVmREZ1ViVmZOYzVlVWNraHRhM2hlZm1jbGFYZldlUmNBZ1pnYWZBY3RnRmViZXhjRWZUZGJmMGJkZnpmRWgwYzhhcmZGZFZmVmdRZUNoUmFoZk1nY2hsYllhVmJhY25mSmhSZ2RhMWFkY0tnRmNtYmxjaGhGYWhmaGhtZ0ZmR2NaYm1hWWRYZUJlZGdPZnhmSWdPZVRmaGhNaFliRmF6Ymtla2RLY0Rob2UyZEpha2VzZ0VnVWNnYUVkWmdUYUdjcGVxZFVibGJvY2NjZWRDZm9hU2FIYTFmQWNLZ0NobWZ3aC9lTmFUYzBmSGRFZlJnQWRoYk9nUWRWZUhiWGRYZXBocGhWZzFja2VRZ0diV2NnY0xoUmVXZDhoUmJFYzJiOWhIYWNmeGFOYUhhYWdCYlZjSWRXYkJhTmZZYkxheWFGaFloV2NDYzhmL2NIY2lkVWVPY01oVmFwY3BnYWZoYllhTGZHaHhmUmM2Y2VobWdGZm9oWGhHZjhhR2FSZDBjbGJWZkhiQWNGZjZiSmZqYzhidWhBZGpnZ2NTYmRoQmg0ZFFnYmgwZ3hia2VDZzFmNWJvZUZiWGdoaDJmRWVrY3NkWWVRYTFhbGZpaGNibmdCZndjU2dFZk5oSmRXZG5jVmU0YlNiM2hkYXliUGdSZjhmUWJRZHhmY2NsZ1RnZ2hnZ2djUWIwY29oVWhDaDNnTWNZZlJlM2UxZG9mU2VFY3hhYmdFYkhkNWM3Z1Zla2dsY3FnSmdoY2tkK2VCYkVlUmJiZkxnQ2V4ZVplU2dqZzljdmNLYm1nWmZxZGNlRWVFZlNhVmNtYjBnZGZIZ1ZjVmhTaGRiR2Z0ZTZlWWQwYjFmcWJTZndoOWJTZ0VkR2JSYU1iZGFuYVphU2dRYmhoMGhzZVBhbGhzZFlnRmNnYTRnY2hMYXpkMGdpYktmVGNNY1BhU2VWY0ZnMWRiZXpjWmUzZVpibmFWZ1hkUWhSZGtoWmhOZEFhc2NSaEpnMWdoZEFoWWFRZm9mMmZYYmdnZ2Q2ZlRnRGZNaGNjUmR4aHRmbWhaZUNnc2UvY2FibmJKZlJnZGIxaGRlS2ZGZ21kbGVoY0ZhaGNoYm1kRmhHYVpmbWFZYlhiQmhWZ1pibGdOZkxhTmJ4YTFlVmZVZG5kUmhyZmVlbWVOY05kYWVrZ3NoUGZVZWhnQmJrYVRkSGJaZTJlVWdoZ1poZGNNYVNlVWVjY0hlUWN0ZE5iR2NDZllnMmdlZERlTmdHYkRjaGZ3Y1dkSWNUZEVhYmdPZnljTmhoaEZlbGhBZ1pnRmF6ZXBiRWdFZlNhTWhaZkFmSGY1Zk9oZmZWYjRnU2dKZ0VmRWVCZEFjQWJ0YkpoYmJpaEZmZmNHY1ViQmZ5YVVlWGdkYlhmU2doaFplcGJZaFJhWWNZZ1pkaGZSZG1iWmNtY0Zhd2ZWY1dmOWFTYUNmeGYwZldlU2dGaEpmc2ZZZW5kWmRKZFRiV2RwZ0xoRGQxYUlkUWdaaEVieGcyaGRnbGFKZkNlRmZYYmhlMmdFZWtkc2ZZYlNneGZwYWloYmIzZUFjK2hRYkdobGJKaFdibmFWYTRoU2MzY2RnNmhhY1ZlZGdaY0VoQmRsaG9iQ2QwZlZodmFFZlJiTmZ2ZVJhM2R0ZUhlRGN5aEZoR2FSY2hmMGVDZVhjU2JrZmdkRGUyZTRkbWZjaGxncGczYlJoamhjYldmZGhYZzBiV2RBYkdhOGJVZE9hbWJZZDFhT2JCZ3dlOGdWY0FicGJZYlViQmhvY0FmTGFSYkFnMmFIZmtnRmJBZ1Nid2Y5aFNnRWVHZ1JkTWRkZm5iWmdTYlFnaGJWZTRkZGFoZEpoTGVHaEVhTmFaZVlibmdKYTRmSmNBY0FjS2FHYmxkUWI0aFBmUWVZYTRiS2hEZkFlc2hGY1JkQWNTZmFmQmJnZjRiYmR3ZTBmUGZiZjFiOWc2Y0VoeGZ0ZW9oUWJRZkFoWmZGZkJhNGVyZE5meGh0YWFjT2VDZXNocWhPZjFiZGNCZEZnbmVzZWNnR2VqZ0pjbWVGY0dlWmFtZFljWGVCZVZkYmcxaHBlSGFIYlJnMWFWaFVnbmdSYXJnZWhtYU5hTmZhYmtlTmhiZUdibGJrZzNoUWRqaHNnemNIYndhMWNIYkloUWUxYWVnU2F4aE5lRGRUZEJkOWJ5ZmJjR2d4ZklhV2IwYkJoYWdLYVhnZ2FmYlBhemJNYTZmV2NSY1JjVmRWYUNjZGZaYUhiQmJSaGRhRWUyZFJiSGdaZTJnNWJMZVFoaGdWZEljVWhFaGNoUWRaaG5iSmRXZ0ZnV2ZwZXllVWRYY2RhWGhTYWhhWmJwZ1loUmRZZVlnYmJraEFkdWRMYnpkSmYrZkdkQ2ZvZ1hiQ2JFZjlhRWZMYWhnNWIwaFlnSGRwYTBlTWRHZnBoWGNFZzFnSWdJaGJkVWF3YnFlZGdnY1lkS2hYYkNkdGI0ZVhod2Y1Z1ZiRGJBZHNnN2JDYlRneGJ3ZFFlMGROZmZjSmgxYzljNGRTZDNoZGQ2ZGFhVmZkYlphRWVCZ2xjb2RDaDBnVmF2ZkVkUmVOZHZiUmQzZ01nYWZUY21jUWMvYVNnRmRCZ0hkRWdHaFpneWRWZ2hjVmFxYmNnbGdGYzNlVmIwY29iV2FhYVdjRWZXZFRmQ2I1ZWRkTmJXY2diM2daZkZic2d1YkhlZ2hNYlZmWGFsZ3NoZmJJZlNmY2Z1ZUtkaGYwY21jRWhnZWNnVGVHZ1dnMWFDZEphRGRrZ0djRGFoYzFncmhaZXhhdGVGZVZoUmNZYVZiTmVqaHNnZ2ZQaEJlRmZMYkdhbGZOYXVhVWNrZXRkM2VlY21jbGdYZFdjUmdBYVpkYWNBYXRmRmdiZXhiRWZUZE1jbWgxaHpkRWIwZ2Rib2ZGY1VkaGRRZlJkeGhCZ21kY2JsZFlnVmNhaG5mb2VaZGRiMWJ4ZVhoRmduYnBlemFGZWhhVmNtZVFiQ2M0ZXZoTWduZjRhWWVLYWhmY2hVYVZnRWhjZlFhV2MzaGhhQmZlZm1oTmhOZmFja2ZzY1BkVWVoYUJka2NUZkhhWmgyZVVma2FJYlZmZWVIaDVnR2FBaDFmRWZRYVZjeWI4ZTNoUGdTaE1iQmJHaFFneGRhYmFlSGVoZGJiZmduZlpjRGNWZzFma2ZRYUdmV2hnZExiUmhXaDhjUmZFaDJjOWFIYmNmeGROZkhhYWVGZXBoSWNWZWtjRWFRaGJoaWhZZmVoWGREY2xoOGhIZERiSWVhYUJmVWRRYndjWWJRZHNnWWNaYkJiWmZ2ZWZlVWR0YXdlVmJXYTloYWZSYnhmMGJkZVZlVmJKYTBlYWQzZG9mK2FaYjJkcGdMZ0RnMWhJY1FmWmhFZXhiMmFkYWxlSmNDZkZiVGVFZndkRWRrYU5iZWdRYjFnUmZpZ1lhV2NKZ3djVmZsaDVlSmdFZG5oeGM0YUVlRmUxZDZjYWdWY2RoWmFFaEJkbGJvYUNiMGNWZ3ZkRWNSYk5kdmVSZHloVmdTY0ZjV2VoZEZhU2FFYTFkSGdWaG1jWmYvZVZkZ2VaYzRkYWZYYXRiM2JWZDBib2FXYmFhV2NFZVdjR2JHZVljVWRaaG1oWmVoY2NmQmFFZWdiV2VoZHdmM2JIYVZhVmhTZmRjR2F0ZzZiWWYwYzFlcWdTY3diOWdTZkVoR2ZSY01nZGhqYzhoVWZRZGhhMGgzZGZkeGNJZlFlTWdrYk5jWmNZYW5mSmd3YmNlRWFoZkRhU2hWZHBjMWZlZUVjdGIzaGVnbWVsYlhhV2NVYVplWWNPaGdic2RHYWRjRGNzZVRkYmUwZmRlemNFaDBnZGhvYkZnVWJoZFFmUmF4ZUJnbWZjZmxiWWZWaGFmbmZKZlpiTmdGYmRhWGZGYWllZGNwY1BkQmVoZm1iRmRHYVplbWdZZVhnQmJWY2JhMWdwYUhhSGhSZTFmVmhVYm5oUmJyZmVmbWZOYU5oWWVoZDhlQmhFY1ZjZ2dsZEhkaGZVZjVoRmFnZGRjMGJMZEhlNWFhZFNoeGROZ0RnU2hHZXRieWViZ0dneGZJZ1dlMGNCZWFiS2FYY2dkZmZlY1Rka2doYUZkZ2V0YXphVmJpYXhjT2FKZ0Rlc2RaaFdnMmNaYUxjV2RSZ05nSGNhZ0JoVmRJaFVhRWFjYVFoWmhuZUpmV2JGZldlcGJ5ZlVkWGZkZVhhU2VoZlpncGNhZ1VjSWZXZUphVmd3Ym5hTmRBZ0liL2ZFYVNlb2Q3YkVheGJWYlZiVmdWaGxhMGFlZUhnTmdqaFVnWGNaY0xmRmYxZ3NjUWRPZEVjd2JpZGVmQmJFaEtnVmRDZm9kVmRYZFFoOWhkYklkZ2MxZXFjT2VuaEJkN2FTYUZhRmRBaFZhbGQ5YjRoU2QzYmRjNmFhY1ZhZGVaaEVjQmFsY29kQ2EwZlZjdmFFZlJkTmF2ZFJhM2JNY1RkUmEyYkJhQmNSYmhmTWVQYVVnVGZRYlJlR2dWY0VhdmVFZHdoVmEvYUhlMGZvYWRiYWdYZlFlZmVHZUhkb2dJZVpmbmE1YW9iY2VBY2xidmJEYWtibGhlZVZnUmhRaEFkRmR5ZVFmK2JKYWlld2MrZVFiMGdkZVNlR2IyaFJhWWZmaDNhcGU0ZVFiaGZWZzRoZGRoYUplTGFHY0VoTmZaYVllbmVKYXdiY2dFaGhoRGhTZ1ZocGcxaGVoRWF0Yy9nTGRtZ2NnVWJFYVZmRmRMZENiMGZRZEJjS2RuaEJiSGNaZXdlOWd6aEdoRWNkYy9iSGhFYWhmTWFXZXhlQmMrY2VkMWVaZUpkYWVpY1poZmZOZEJhOGhMYVJkQWRvYnVhVWFsaDBjSGhRZEdmNGR1ZllmWGZ0ZFZkZWRWYU5mdGVIYlJhMWRWZFVmbmNSZnJlZWRtYk5kTmFhaGtnc2FQZ1VlaGdCYWtiVGhIYVpnMmdXZjBic2FaZFVkbmRZYlNjU2V4YWhkRGNXZldnSmF5ZWNlSGZCZklkUWYwaGxlYWdkYlhkaGNMYWRhM2FwYXBnQWV4YkZjWmJTY21lWmdkY1ZnR2ZGYVFkVmJ5Z3RlUGZNYUJhMGhLaFBnVmZrZWNjR2RSYmRmY2RQZjNjb2dYaEhoR2ZOYzhlQWJ6aGdlRGdCY2hmNWU2ZmNlQmI4ZldjS2MwY0VjcWFNZ2lnZ2VnYkdjVGdaYVNhRmdCZlFhUmdmZDFlSmgwYWFoM2dwZWpiVGJXZnBlTGREZjFoSWVRZFpoRWJ4YzJoZGdsYUpmQ2ZGYVhmaGIyY0djZ2hNZ1llU2FFYVJhaWVhYW5mbGU4YVlka2hOYUpnV2NuZVZmNGJTZjNlZGQ2YmFjVmdkaFphRWJCZmxjb2VDYjBoVmF2ZEVoUmdOZ3ZnVGd6aEFiVGhXZW1kaGRiY1FmSGZwY0hnRWRHY1pheWZWYWhnVmRxaGNkbGdGYTNmVmEwZ29jV2JhZ1doRWJXYkdkR2RZZFVmWmZtZlpiaGhlY0FjRmVoaEdlUWE5ZGNoVGJ6Y1lnZGdNaENhNGFiaE5iMGFVY2lnU2d3ZVJiU2VBYVdjMWVNY2FhbWZwZlNlV2hoYnhmNGRLYmhmSWdmYkZhZ2RBYVJlSWd5ZUFjVGNQZ3dod2dHY0thQWI1YTljTWNFZUpkN2FVZEdnbGNYZFdmUmFBZVpmYWZBZ3RhRmhiYnhnRWZUYWJjMGJkaHpjRWUwYmRnb2RGZ1VmaGhRYlJjeGhCaHVkSmFsYWhhV2RJYWplTWJEYkZnQmhnZk9mVWh3ZWdiMWhIZ2xhQmVtZ0hiMmNaZzFnYWFIaEJlSmdjZzFicGJmZ0ZiQmUwZEpjVWFpZkJmbGZPYlNhc2FNZU9iQ2ZoY0FlRmFsZ1VnRmVHZUhnNGUrZ1Vha2drZFZnYWduZzhnZWVZY1JhaGdEZFdkV2RKZHlhY2hIZ0JoSWhRaDBhbGZhY2RjWGhoaExlZGgzZnBncGVWYzFia2VRZEdlV2RnZERkRWhXZ0ZmU2hXZnlnNGZWZEVhRmF3Y0RiTGZYY1FjY2NXZUFiOGNRZmJnWGZKZERnSGRHZnBndWNUaFhlZGVQZFFmeGFZYTFjWWFVZUliV2JKaFZkd2huYk5oQWVJZC9jRWNTZG9lN2VFaHhmVmVWZlZkVmFsYjBhZmQzYk5odmFaYTJhcGdMYkRnMWFJaFFjWmhFYXhkMmJkZWxjSmFDYUZlWGJoZDJhRWhraHNlWWhRZDFnbGdpZmNobmNCYzRkSGNFaDBlS2VFaGpjUWZxZ0tjRGVnZStiTGREaFlhTmdHaEZiRmVvY0FhRWRWYTRnR2NCZ05oemFXZzNnTWNMZ1RjbWNoZUpkU2ZBYVJiSmVVZ3lkNGh6aEJjSGFZY2xmTmRoZFFhV2RBaDBkSmFlZGFjV2RvYldiRGhtYThjK2JaZ21jWmVoZGNkRmNWYXZnV2JraGNnZGRIaFZhVmRTZ2RjR2F0ZTZmWWIwZTFlcWdTZXdmOWJiYkdkV2hoZG1iZGNuY1plU2FRZWhnVmc0Y2RjaGZKaExnR2RFY05oWmZZZG5lSmd3aGNmRWJoZURoU2JWY29haGFNZEFkSWFrY2RhRGg5ZUZmVmExYUZlZGFMZkFlTWhHZFliVmF4YkdiSWd4Yk1jNmVRaHdkc2d4Z0hhUWVsY1pjVGNoaDRhMGNQZlFhSmZaaFlmbWhGZEFnZmFsYmtnSGRRYXlmVWYxZlhoMGNnYnFhVGJXYzRoMWVhZkhleGQvaGJlMWZwaEhoSGNSYTFkVmhVZW5oUmZyYWVmbWVOZ05kYWFraHNhUGdVY2hhQmJrZFRjSGhaZStmR2drZklnZWVaYVhhWWJLY1FmaGFSYnBoV2RXY0pleWdjYUhmQmFJZVFmMGJsYWFmZGdYZmhoTGdkaDNlcGdwaFZmMWFrYlFhR2dXYWdhRGNCYW1jOGFNZEVkeWJGZVBkV2hSYU5jSGJhZ0JlVmZJaFVmRWdjYlFjWmZuZUplV2JGYVdkcGd5ZFVlWGJkZlhnU2RoZFpkcGNZYlJkWWNRaE1naGZvZ2xjTGdpZUFkaWdOYmliQWJlY0FkbmV4YkpkWGdSZ3BjMGNZY0hicGV5YVJhR2hwZ1hjRWcxZEliSWhiYlVld2dxY2RoZ2JaZ01kVmdqZUFiM2NRaENiaGRYZEJleGV3YkRjSmduZmdmNGFRYVVmOWhqZVdhbmFWaDRhU2MzZWRjNmNhY1ZhZGFaZUVjQmVsZG9iQ2EwaFZkdmVFaFJlTmh2Z1JlM2dNYlRiUmUyYUJlQmhSZmhmTWRQY1VhVGRRZVJkR2hWZkVjdmVFZndnVmIvYkhiMGRvZWRiYWdYZUlnZmJHZ0hnb2ZJZlpobmg1Zm9mY2ZBZmxndmFEZWtmbGJlYlZmUmRRY0FnRmF5ZFFjK2hKZGljd2IraFFoMGRkZVNoR2UyZlJnZWNmZjNhcGI0ZVFoaGFWYjRkZGFoZUpkTGZHZEViTmVaZllobmRKZXdiY2NFZmhlRGNTYVZicGMxYWVlRWJ0ZzNkZWVtYUVnRGJWZDFkTmJSYkthVmRrYm1jSWNGaFZnV2REY2hkTmg3aFdkMGNkYmpjRmdWZjFnWmdSZ3dleGQ2aGNja2Q0YWNmYWNpYjVoUmNJYjFma2VKaFhkaWhnZ3piZGFWZWNmaWdVYlFhY2N5YmFiVGJoZFZoWmFGZXBlVGRGZkJoRmEvZVVnbmhSYnJjZWhtYU5nTmZhYWtlc2FQYlVhaGdCZ2tkVGhIZFpnMmNVaGtlSWdWaGViSGFZYVNkU2F4aEFhWGRWYnlmRWc2Z01nU2hJYnJkRGNBZjBmZmFGaENoeGdEY1BiM2hwY2ljVmYwYzRkWmNHZVhjUWdYYVJkWGdjZ1lmRWR6ZU5lSGNKZ3hnMGNFZklnRmhRYmFnTWF3YWhiVWZJZ3hkTWRDZ0hkU2hKZnliV2RuZGRmQmVRZnpmeGNwaFlnUmNZZllhWmFoaFJkbWNaZG1nRmh3YlZiV2U5ZWFiUmh4ZTBjZGZWYVZkSmQwZ2FlM2hOZnFkUWFVZ0JoTGFEYTFkSWNRZVplRWd4ZTJhZGNsYUpjQ2JGYlhiaGEyYkVna2hzY1lhUWIxZWxiaWNjY2lkUWY0Z0FiUmVCYkhjRGRHZVphMmhDZGpmTWErYVllUmNSY1hlWGNVZHdla2JYY3dkd2cvZVhhVWVwaG5hQmduaG9nYWVTYlRncGFhZEhnQmN4Z1BiQWYzaGRlN2JXaEZmZ2IvZVBkZ2NVaCtkQmF3ZlpkUGhZZlRoSWhmZ0ZnRWJ3ZVVnWmdtYVplaGVjYkZiVmZ2ZFdoa2hjYWRmSGNWZ1ZkU2dkZ0dodGg2YlllMGQxZXFlU2d3ZmNlYWJFZ0dlOWFSYWRnbWE1ZmJnVGJqYTlhNGNkZWhkSmVMYkdkRWdOZ1poWWZuZkpkd2JjZ0ViaGNEZFNoVmVwYzFnZWdFZHRkM2JlY21kRWNVaFdhUWYwYVpiSmhnYk5odmViYXhkRWdUYWJiMGVkZnpkRWQwY2Rhb2dGaFVjaGVRYlJneGJCYm1oY2hsZ1llVmRhY25mSmhSZWRoMWQ4YmVjR2VDY29kcGhWaDBhb2JGZ1dleWZJaGpoQWJDZlJmZGVKZDFmcGhNY0hjUWN4Z2NnVWJtYWhlM2VlY25hdGRFZGFjaGZjZlBjQmNoZTRnbmJCZ0RhY2RrZU1kUWUxYlJlUGJSZ2RhR2NRYjFhQmRLZlZjVWdoY3liY2VIZ0JoSWZRaDBobGhhZWRhWGZoZ0xoZGczYXBhcGdWYTFha2ZRaEdkV2hnZ0xkUmVXZzhiUmZHZXpndGdKZE1kRmhzZ0diT2FuaFlnSGVGZUFnSmF4Y01jbmNvY2VhRmJXZ0ZmeWdRZW5mNWdYYVZjZ2NwZnBkZWhSaDhoWWNPZWhlUWN5YmFnQ2NJZzRoRmREaDBiNWJDY0ZmbGZZaE5jQWJaZjhnSWMzYnBhb2hUZlhiaGFDZEFlM2FnYVFnWmNFZHhlMmVkY2xmSmdDZ0ZnWGFoYTJkRWNrZ3NmWWFRZTFhbGZpY2NibmZCY3dmU2FFYU5jSmhVZWljRmgyaENlRGE4YzdjT2V6Y1FkV2JWZUZod2FKYVhjMGQwZW5lRWRSZmhidmhVYW5mb2ZUZVdiM2ZRZ1ZlVWRGYmxoSGdUZ0doWWFtZldnRmJZYWlmTWJ3Y01mVWhHYUFhNWRUYkNkRGZVY2ViVWFHZllnZmFaYm5mSmJvY2ZjSGc5ZXZiV2ZraGNlZGRIZFZmVmZTaGRoR2h0ZjZjWWMwZTFncWJTYXdoOWhTZUVjR2RSZk1mZGduZFpnU2NTYWthRmMyZU5lVmJvZ0tlU2FpaEFnV2NKZ2phY2FSZkpnRWZBZUxnU2dWZUZlMWJiZTBmSmMzZVpmbmhWYlhjUWRSY2thWmhOY0Flc2dSZ1lnVmZKYWJhTGNoY1ViUWFYZEFkTWd0aGRnQmR4YllhRGh4Z0JndGdjZmtoQWZjZFFlSGdKYVJhZGcxY2RkS2hGZm1jbGVoYkZkaGNoYW1kRmRHZ1pobWJZYlhmQmNWaGJjMWVwZkhmRmJCaFJoWmJlZ0hkUmJyY2VjbWdOZU5mYWVrYnNkUGJVaGhlQmdrZlRnSGVaZDJiVWVraEllVmJlYUhhWWJTY0hiMWRBYUtoQ2FtZndna2VaZ0hjNGhKaEJid2gxY1NmTmduYVloR2NJYmphWWM5Y0hhZ2dsYWNkUWdHZkJmS2ZUZEdnWWRmZVFjU2JBZFRmUGZ4ZnRnVWdlZFJleGNHYUhnUmhKZmNmTWhqY3NoR2ZXYlRhTmU2ZUFhbmI1Zk1lWWZCZlpkcGVZZFJoWWhZZ1plaGFSZW1hWmRtZEZnd2VWY1dlOWhhYVJheGYxY0FnVmdSY2NiNGJPYURoOWdqaEZla2NCZUxoRGMxZ0lmUWNaZkVjeGMyY2RlbGdKaENkRmRYZGhhMmVFYWtjc2RZaFFlMWFrYjBlTWN5ZEpjd2hDYTFiaGhqZVdnbmNWYzRjU2YzZGRhNmZhZVZlZGJaYUVoQmRsaG9nQ2IwZFZmdmJFZlJlTmh2Y1RnemJBYlRkV2htZmhlYmhRZEhmcGJIZUViR2FaZnlmVmhoZ1ZmcWZjY2xkRmYzYlZlMGNvYldiYWVXYUVnV2JHZ0dhWWNVYlplbWI0ZTFmQ2N4YjFkdmFVYlVoY2JNZVlkRmhWY09kYWFHY3RkaWJhY2toMGgyYlNmMWRzYnBlV2hCZmxjQWVYZkhoWmdTYlFoaGVWZDRkZGdoZkplTGNHY0VjTmFaZ1lnbmNKaHdmY2ZFYWhiRGRTYVZmcGYxaGNjQmY4Y01jTWJtZmxnY2JXaFFhTmhrYmFiQmJkYlpmYmd3aGthYWJiaHhmdGN6Z1JiemF3Y2dlRmNVZU5mUWNWZldiMWdxYVdoRmdZZlZkYWVuZEplUmVkZzFmZGFLaEZibWJsY2hnRmhoaGhnbWJGZEdkWmdtZFlmWGhCZFZiWmF3YzRhOGRWZFJiMWRlZVVhbWdFZFdhZWhuYTlhUmFhY2xoTWVHYlVoa2Z4aGtiR2NBZDBiK2hVZGtja2dWZWJmQWdzZWVkWWRSaGhjRGZXZVdoSmd5ZGNiSGRCZklhUWYwZGxmYWhkZVhkaGVMZmRmM2hwaHBnVmYxZWtoUWFFYlRjeGJ3Z0RiV2Q4aGFhRWEzY2djNmJjZ3dmOWZiZWFkQWQxZEJoVWRCZXNoUWNNZGdia2hlZEZoV2dGaHlkUmF3aHBmOWhTZGhiWmVwZFloUmNZY1lhWmhoYVJibWJaZ21hRmR3aFZiV2I5ZmFiUmV4ZzBhZGhYaEZmdGg0Y1FjWGNwYmpnVGVXYnBoTGFEYTFlSWJRZFpkRWR4ZjJmZGVsYkpkQ2FGYVhnaGUyZUVla2hzYlljRmN4ZEVkcmNJZ1hjNGFtY1dhVWEwZElnSGZqYUZmd2FDYkhoa2IzZFBoQmRzY05lV2NVY2tma2NVaGtjMGd1ZkdhQmhwZWhhRmRUZnhoSGNDZjJhQWVHaFdnVmZsYUpiWGJUZ01lK2JBaGxnd2c2Y1BmZ2VoYi9kQmRFY01iYWNRZzJiRWFXaEdiR2hZZlVmWmZtYlpnaGVjZUZmVmh2ZFdia2djaGRmSGhWYVZjU2RkZkdhdGg2YWFmd2ZWZXFkUWhCZUpnU2JDYUdlMWdBZlhoSGFaY1NjUWZoYVZnNGZkZGhlSmdMZEdiRWFOaFphWWRuYUphd2NjZUVlaGREZ1NmVmZwZDFnY2JBZWhjM2daaDJla2VaY1VmVGRvZ1poYWRBZ3RkRmFiZ3hiRWNUY2JmMGdkYnpnRWEwZ2Rob2RGZ1VoaGRRaFJleGdCaG1mY2RsZ1llVmFZZGlkWWFxZlBmMWNkZkJiRmZuZ2dmY2dGY2dmUmQ2ZUZhSGc1aHZjWWdTYXhnVmhPYXlnRWNQY1lkQmRGYS9nVWVuZlJocmFlaG1nTmJOYWFma2ZzaFBjVWdoaEJia2hUY0hnWmEyYVVja2ZJYVZhZWZIY1lnU2VTZnhoQWRYZkllaWdwYXlmZWUzZUJnYmZQYWtkbGVHZGFmWGRoYVRiZmZuYm9kMWRWYndmMWZyaFVoV2FnZUFhUmVYYzFkc2hIYTBiVmJIYWNoeGFOYkhnYWVCZ1ZhSWhVaEVhY2VRZlplbmNKY1dnRmJXZnBoeWRVZFhlZGFYYlNhaGhaYnBiYWRVaEpjamVMY2hnUmJ0ZlpjbmJRaE5mVmNYYk5mR2hSY3djVWFVY1ZoUWg1ZDBnUGJ3aEVjcmJUYldnRmdMZkdoeWU4Y2NmVGVrZXhiMmFkZGxmSmhDZUZkWGNoYTJnRWVrZXNjWWVRaDFhbGVpZGNmbmRCZHdiU2ZFYU5mSmZXY25lVmd3Ykhmd2Z3ZXloYWJWYnhlWmRCYjJiUmVvZkZoMWJsaHZkQ2JSY3BidmVHYTNiTmNIY1BoQ2JBZlZiUWYxYkJkUmdiaFVjeGR5Y1ZjaGRWY3FoY2VsYUZkM2hWZjBib2FXZmFhV2hFZ1dlR2RHZ1lmVWJaYW1nWmJoaGNkRmF4Y21lVmdtZTBjZGZIZ1ZlVmZTZGRmR2h0ZjZnWWcwZzFhcWdTY3diOWVTZEViR2RSZE1nZGhuZFpnU2dRZWthRWh3Z1BiMGdGaEZoVGRsZUZlWGNJYnpkWWcwaGVjQWF0Yk5kQmZBZDhlNWNMZ0FmSWJuY05iamJCZWZmR2hCZWtjUWhaZGxia2VLZ09oMWMwYmJiZmJGZFpnNmJIYVFkb2I5ZVdmUmR3ZFpkRmYxZ3doL2dlZWdmVWJjZFpjbGZoYVJkZGUxZWRkS2hGZ21lbGRoYkZnaGdoaG1iRmdHYVplbWVZY1hiQmVWZmJkMWFwaEhlSGFSZFVlZGJVZm5iOWEyZWVnbmd0YkVhWmdtYkVjUGRVY2hjQmNrYlRoSGNaZTJhVWFrYklnVmJlZUhkWWFTZVNieGZoZURjV2RXZEpkeWNjZkhnZ2JMY1FnMWdSZ2FhT2gzYUJoaGdkZDNkcGZwYlZhMWhrY1FhR2VXZGdoTGVSY1dkOGZSZkVhMmI5ZUhkY2N4ZE5iSGZhY0JhVmRJZlVnRWQ5Y0VnSGRUaHBiV2RIYm1lcGVqY0xmSGZkYkxhVmVoZlpoeGJhYUJmWmRFaFpla2JBZWRiTGRoZXhjOGVmZjJoOWdhZlJheGMwZWRlVmRWZEplMGhhYTNlcGNqZFRmV2NwaExmRGcxZklhUWNaZUVneGYyZmRnbGFKYUtlUWVRZ01lK2JFZmtmQWRZZlVkQ2hSZWljYmVtZHhld2ZVaEVjcGdKZEJlbmNVYnNlTWJEZzloNmhZZmxhZGhMZGJnUmNWZENlQ2YwZFZldmdFYlJhTmh2YVJhM2RNZFRiUmgyZGdlVmRTaEZnQmhIaEVhR2FaYXlhVmFoYlZkcWFjZmxka2ZqZUxoQWZJYVdlWWZtYUVkRGZaZ1dkWWhJZ2VibWFaZjVhZWRWZ1VoemJXZGhkTmFtY1ZjVmVWaFphZGJIZThmSGViZjJlZGJxaFNld2Q5ZlNkRWJHYlJkTWZkZm5kWmVTZ1FjaGZWYTRnZGRoYUpjTGRHYUVnTmZaZllhbmZKZndmZWVCY3dkNGJBaFZhcGgraGViRmV3Z0tnZWVuY1ZiTGhXYlFoZ2RRZmFlRmRkYkZjT2QyYnBlYmFiYjBkeGN6Y0JkVGdwZ0NiRmhVYWhlUWFSZnhoQmhtaGNjbGZZYlZnYWRuZ0piUmdkYTFjZGhLZkZmbWNsZGhhRmNoY2hmdmdIY1dhcGRNZllhWGFCY1ZnYmcxZnBmSGRIaFJmMWFWYVVobmFSZnJmZWJtZ05kTmRhYWtmc2RQYVVnaGhBYndiQmVEZjhibGhYYkJlUWhHYWRjamNkY1dkRGV4YUFkQWhWZHlmOGFuZ1BkQ2ZRZUJjRWJ3YlVkRGNmYlRlbGhDZWZmbmJRZjdjR2hBYzFoY2JFY1hlc2dhYVRjR2hGZ2NiUmhpZ01lVGdPY2tlTWFMYk1lUmMwYmJmV2RVZnNhNmZaYW5nSmdXZkZoV2ZwZXljVWhYY2RjWGVTaGhlWmVwZ1lmUmJZaFljWmZoY1JobWhaZ21jRmU0YkhlV2g5YlJjV2doZTBnRmFYZ0ZlNWhlYWFjM2dwYWplVGZXZHBjTGhEYTFmSWRRYlpkRWR4ZTJmZGFsZEpjQ2NGYlhiaGQyYUVha2ZzZFFmQWdGY2xoL2RjZ2pmNWM0ZVlka2dOYUphV2huY1ZoNGhTZDNnZGI2YWFkVmhkZ1plRWJCYmxnb2RDZDBiVmF2ZkVjUmVOZnZkUmgzZU1hYmdFZHhjTmJkZVNlRmh0Z0hnQWdSY3RleWZTYmdmbGFxYWFmbGRoZDNiQ2MwZnBhQ2NFZWljbGNyZkZiRWR3Y1VjWmRtY1pkaGNjYUZmVmN2Z1dma2djZWRlSGdWZ1ZiU2ZkYUdndGQ2ZFlnMGQxZXFlU2F3ZzlmU2FHY0RlQWczZFBobmFaYVpiUWRnZVlhRmVkYmdnNWVYaEdjRmd0aFFiWWFpZzVld2RKZ0RlTWdMZ1NlVmdGaDFiYWhqYlphN2ZVZEdnbGJYYVdiUmdBZFpjYWhBYXRoRmJiYXhlRWFUZWJnMGhkZXplRWgwY2Rjb2VGZ1ViaGNRY1JneGZCYnVnSmVpYTFhZGVhZG5hbGRSZFlhaWZwZEtoQ2VuYVZjaGZEZGhmRmJtYlNiR2ZZYnlkR2FqaGhlVmZaYkZicGZUZllmQmFGZS9lVWJuZFJmcmdlYW1kTmROZmFka2VzY1BlVWVoYkJma2JUZEhlWmYyYVVna2ZJYlZjZWVIZ1loU2hTYnhnQWJYZUlnaWRwY3lnZWMzZEJnZmNQZmtobGRHZmFjWGFoYVRoZmFuZm9jMWdWZHdoMWZyZ1VjV2ZnZEFlUmVYZGxoc2RPY1diOWNIZWNieGROY0hlYWRCZFZmSWVVZ0VnY2dRZ1phbmdKaFdlRmNXY3BheWZVYVhnZGRYZVFleGU5YmxjU2F4Z1lmWWdaYWhkUmdtZFpjbWFGZHdkVmNXZTloYWFSYXhoMGZkZVZkVmRKZTBjYWQzZnBmamZHZFNlSWNDYVhiRmN4Z0doY2dFYUljM2ZNY2hiWmZLZ1ZhbmFZYTdhUmd3YmRjTWVDZWdma2N1ZEtjM2RnYnhhUWVVYnBhSGRDaERmb2RzZ0JjM2U5ZHBnZWhGYjVjWGhYYlVkd2VrZlhjd2R3Zy9iWGhVYnBobmZGaEhkb2JJZWJnV2ZnZVZkU2RGZUJoSGVFaEdmWmZ5Y1ZlaGRWZHFiY2JsZEZhM2JWYTBocGFMYVFmMmNFYVdoR2hHaFllVWFaY21oWmFoYWNoRmFWZHZmV2JraGNnZGdIYlZnVWRhYmRiR2RCZW5nWWIxZFZoeGJZY1FhOWZTZ0VoR2hSaE1jZGFuYlpiU2ZRZmhiVmg0aGRlaGFKY0xjUmZVY01hT2VLaGplc2M4Y05iVWNoZkxkR2FWYXBncmZaYVVoc2UvYmNnM2ZKZDlnV2FSY0FmWmNhZUFldGFGYWJleGhFZFRiYmUwaGRkemNUZ21oMWNvZkZmVWNoY1FjUmV4aEJobWhjZWxmWWNWaGFkbmFJZERiTWFnZ01jZmNSZUNmZGRoY0hhamFKYW1oRmRHaFpobWRZZFhmQmRWY2JkMWdwZUhlSGFSYjFjVmRVYmpnSmZyYlpmR2VNZEZoYWNrZDBlSmJlZUJhQmVraFRjSGZaZzJjVWRrY0lmVmZlZUhhWWNTZVNjeGJoY0RjV2ZXY0pkNmJQZzFjcGhJZlFiMGZsZ2FjZGRYZWhlTGNkZTNncGRwYVZnMWZrZ1FjR2dXaGdmTGdSZ1diOGNPY0VnMmVjaFRmT2IxYW9kVWRaY2xnZ2ZOYkhoUWdoZkNjUGIzY0plZGRDYkdlb2dtYVhoeWZRaGJnQWgxZlVic2NhZ1ZmNGZSZ2Jhemc1Z21hWmFtY0Zjd2hWYVdoOWhhYlJheGMwYWRkVmdWY0phMGdhZzNhcGdqZFRhV2FwY1JlRGN4aHNkNmVaZkVkeGEyZ2RhbGVKZUNlRmNYY2hiMmFFZGthc2JZYVFnMWVsaGlmY2NuZ0Jid2dWYzBmTWZkZUVkamJ3Z3JnUmhUaG9kL2RKaEJnZ2dMZlNnUmVjZzdoVGhoY0ZnbmNSZ1JoMGc4ZkVoamNGZ1NmRmNUZnBlVWhFYVZnZ2FQZEhiR2dZZTBkWGN4YmxmcWZKZmhka2UraEJhRWVSZWJmTGVDaHhkRmdVY1RjeGVSYmJjMGh4aGhjY2NGYVZhdmVXZGtjY2ZkZ0hhVmdWY1NkZGhHZ3RkNmRZZDBmMWJxZVNkd2I5ZUliRWJEZ0JhQ2FOZVRja2dDZ0djeGQwZXNnUGZsYXNiWWJGYmdjNGZjZkxnemUwZmlhS2VVYlJjRGRIZVJoSWI4YUtkMGRVZDZjUGF5ZVFmRWhFZEVkcGhjZlpnQWVzYk5hWWJ4ZkZnVmRaZGthdGhaZ0VmMGVkZm9iRmdVZGhoUWNSYnhiQmRtY2NlbGNZaFZkYWNuZ0pnUmdkYjFjOGhlYVhmaWJBaHliR2hGYlViamZXZFRlVWR2Z09kemNWZlZhY2VsZ29nQmJIZ1JlQmhWZUdjbmgxYmlnZGNrYWxnTmFhYmtic2ZQZlVjaGZCZ2tnVGRIZ1piMmJVY2tiSWFWZGVoQ2dKY2FiQWRraHRncGJXZFdjSmJ5ZGNjSGRCZUljUWcwaGxjYWNkZ1hmaGFMY2ZobWhGZ0RiVmgxZmtmUWJHZFdjZ2hMaFJnV2U4ZVJoRWJ6ZUplT2VmY3pjbGNIZmFkQmhWZElkVWNFaGNoUWdaaG5kSmFXZ0hnU2RWYThoQWNTY1VlWWdIaGxna2E5Yk9lRWZaZmRjYWVGZkFndmJJZ1NiUWNqY0FjV2Q5ZUhjUmExZnRmSWZHY3hiRWJnZ0liamVVaHRiVGFXZUpiQ2hEZndka2Q2ZlphRWd4YzJoZGVsZEpoQ2VGZ1hhaGQyZkVna2ZzYllnRmZSY2dhd2FjYWllUmQ4Y1lia2JOZUpmV2RuaFZnNGFTaDNiZGc2ZWFmVmNkZFpkRWhCZ2xnb2hXY1VibGJGYUVmUmROZXZlUmczZU1hVGhSaDJjZ2FWYVNhRmJCYkhlRWdHZFloN2VWZGdjaGJxaEpjaGhrYStnQmdFYlJoYmNMZENoeGZaYVNoamQ4ZlliVGhHZFplaGJjZEZiVmJ2ZFdia2VjYWRmSGFWZVZlU2JkZkdodGE2ZUpoa2ExZDNmU2J3ZzBhQmFSZkRnWWdGY09iRGJGZ1FmUWFnYmhlbGRkYWthWWRTZVNmQWVZZFdoSmVIaEloNWRmZEdiSmNEYlNkVmJwaDFmZWRFYXRnM2dlY21nbGNYYVdnUmNBZ1poYWhFYlJjRmFjZ2hkRWNEY1loMmcxaHplRWgwYmRhb2JGYVVkaGVRYVJkeGVCY21jY2VsYlloVmVhaGpjcGNSaGFjbGVjYmVnWGdpZUFheWVHZ0ZiVWdqZVdnVGRVZXZiT2Z6ZVZkWmdSZlZmcGNIYUhhUmcxZFZiVWRuZFJkcmhlZG1jTmJOYWFia2FzY1BkRWFSaEJnNWVUZkRhZ2R6YkJmVWFKYmJhY2ZIYThkSmZZYlJoaGREYldiV2RKYXliY2FIaEJmSWJRZjBnbGdhYmRoVGY0Y0ViSmhYZ3BmaGFmaFZha2hRZkdiV2NnZUxnUmVXZjhnUmVFZTJoOWVIYmNoeGNOYkhnUGNGZjBlQmJBZTBnbGVFZktlU2FZZlhmV2NSaFVkK2RGY0RibGFYZ1ZhQWh0aHBiY2JnZVFkeWZaaGhjUmRtZVpibWZGY3doVmNXZjllYWFSY3hiMGRkYVZmVmZKYjBkYWUyaFZhamJSaFdlSWZmY0RhMGQ4ZVFhTWZBY1FkL2ZKaFZhd2FVY0JiSGNZZDFoWGhnY1JlV2RCZGxjRmNyZ2ZnQ2ZJYy9nSGFBYjljQmFTaDNieGR4ZlJoMWExaDZnYWdWZGRmWmFFYUJkbGNvaENiMGdWY3ZjRWVSYU5mdmdSYzNmTWVUZ1JoMmFoYUJkUmVoY0VoRGdWZUdnNGVtYUhibGV3YzVlZmhBaGRibGJXYlFhbGJhZkplaWQ5ZVRhRWJHZThkYWZOYkNha2YxZFBiRmQxYjRnVWUwYjRnUmVOZTFkVmJTY2RmR2h0YzZhWWEwaDFmcWRTYXdkOWZTZ0VmR2RSZk1lZGVuZVphU2JRY2tnRmgyZU5oMWVZZVBlRWJCaGNnUmVLZnljRmIrZUpnbGZ0Y05nQ2VoZllnNmdOZmdmNWgvaGNlMmRjY0ZhRmRrZFJmVmdZY0JncGdYZVpiaGFnaGZhUmZVY2RkemRFZDBlZGRvZkZiVWFoaFFjUmZ4ZkJjbWdjZWxiWWRWZmFnbmZKYlJnZGJ3Zk5iRWZWZ3lmMGVsZkhha2Z3YXVkWGZUZFZhb2dOYTJoUmViY0xiQmdZYUloVWQxaGhnZGhXZDNnb2M1Y05mVGRjZkJkWWJsaG9mWGRXaHhibGZvaFpnbmRaYTJnVWRrYklhVmNlZEhoWWNTY1NmeGZoaERlV2NXaEpjeWdjYUhnQmNJZ1FkeGIxZVVmTGhUaGNnWmFmZXllNGVoY0hlZ2VvZmVkVGczY2tlRmhDZkRhcGRkZVJjeWhZZlhiUGEwYnBoUGFLZlJjeGVHZ0FiZ2NoZEVkS2JuZ3BmRmhCZ0dhTmE4ZUhoQ2NJZGJnSGdsYzhhNWRMaFVlOGdRY05jUmgxZHZhYWdrZnRod2RWZldhOWFhZVJjeGQwZWRmVmFWZUpiMGZhaDNkcGNqY1RlV2hwZUxhRGcxZ0pmRWFhZmdmRWFqY09nZ2hZZUxlUmZUZ1FkdmZHYmhnZ2hSZFRkUmhnZW1lTmZuYmdkMmFRZFVnOWdqaFdobmFWZTRnU2gzZ2RlNmFhZFZnZGNaYUViQmFsZG9iQ2YwY1ZldmRFYlJhTmR2aEVkM2IxYUxlQ2VEYm9mZGVIYkJoZ2ZPZlFkMmhnZmtoUmVCZHNhbmFKYXhjMGhqaEhnaGVwZWFnTWJHY2xhWGdFYldjaGFHZ0tiVGNJYXRhZWNFZ1pmK2hVZDBnbGJRaFNoQmZrZEdoUGdUY3NiMmhPY2toVWc1ZVFkZ2daY2VlT2JtZVJmTWdkYW5iWmNTZFFlaGZWYzRmZGRoYUplTGhHZkVoTmRaZFlhbmhKZndjY2RCZHhkTmFCZEFmOGU1Z0xlQWVJY25jTmRqaEJnZmVDaGhia2hYZ0tjVWg4YUJiWmIxaGNlYWVZYjJkMWZ6YUVnMGZkYm9nRmNVaGhmUWZSaHhoQmJtYmNlbGFZYVZmYWNuaEpoUmRkZTFiY2JlZEdjRGJFZXViUmdCYUFneWhYYkNiOGYxZ2JneWRaY0doWWJSZmNnU2NVYVVoa2NjY0FkamJnYnliY2NpZkpjRWZaYkJkbGhBY0JkbGN4YnNmWGMyaGRhL2ZYY0FkOWVBYU5kQ2ZKaGJiR2QxaFFkYWJVZlRjRmg3YWVkWGR4YWliUWUwaGxjYWVkZVhjaGNMYWRnM2FwZXBjVmgxYmtmUWFHZldiZ2hMZVJlV2U4ZFJlUmEyZkVlS2NKZWxmOGhUYUloVWJVaEVkQ2hVYTlkRGNiZjNld2hYaFVlU2c1ZjZkRmYzZDVlYmJZZ0JoWmNwZVljUmFZY1lkWmVoZ1JkbWVaYm1mRmV3YVZkV2c5YmFiUmh4ZzBoZGhWaFFkWmI2YU1lemdVZnhiUmdUYzRmRGNSY2dhRWJlYU1nbGRoYjRiT2d3ZGNkT2VRY1RnRWZtYlhhaGRJZlFiQWdsZkJic2JJZERoOGZrY0JmRWJ0Z2FlU2YzY3hmMmdCY2llSWMyYVBnUmg0aEpjWGJFYkJhZ2VXZ0VleGVtZUhjVGNsZ3ZjUmMzZk1jVGJSZzJmZ2dWYVNhRmhCY0hkRWNHYVpoeWJWYWhjVmdxZmNjbGFFZ2plV2JRaGRhRGNKZlRjVmdmYVNiQ2ZwZ05kYmFqZ1Zhb2ZmZGhmUWRyYkhla2U5ZmJnRmZGaHhhNGNkZEdndGI2ZFlmMGUxYnFnU2F3YjloU2ZFZkdoUmhNYmRmbmFaaFNlUWJnaDljNGJmZGtnWmFMY0JmVWVNZU5hS2FqYnNhamZmYmhoc2hHY0RhQmM1ZDdkT2V3YWNiNGJOZkNieGRmYVVnQmY1YVloTGVFYTllTmRJYXhiZ2FhYllhMmMxYnpmRWMwZmRkb2RGZ1VjaGNRZVJkeGJCZW1hY2NsY1lkVmdhYm5kSmJSYUlhMWFrYUxhVWVpZDFocGVWYVJnWWhnYVJoaWhrYXJjRGF5ZlVlWWJMYVJiOGZWZ0ZhVWZrYmRoR2J5ZWRkbGVMZWlid2JaYUtnd2RkYXdhSGdsYlVocWRSZFhoOWd0Y2VjRWRJYlZkZWJIaFllU2NTaHhkaGFEYldkV2VKZnloY2VIY0JlSWJDaDBjbGdYZ2RnV2NCaExoYWJXYWRkcGFHZ0ViSWc2ZE1jMmJnZkxkUmVXYzhjUmZFYjJmOWFIZGNheGNOZEhoYWFCY3hiaWhVZUVmY2ZRZVphbmdKY1dlRmRXYnBheWJVY1hnZGNYZlNiaGdZZnNhU2F4ZFljWWNaaGhmUmRtZlphbWdGYXdiVmdXZjlnYWRSaHhjMGJkYVZlVmZKY3JiYWd6Z2xodGVDZXpoZ2FFYlFjamZCaFpkTWFCZTloK2ZYZ0ZjSmdDZUZjWGRoYTJkRWdrYnNhWWJRZDFhbGVpYWNnbmVCZXdoU2hFZE5mSmdXZG5hVmU0ZlFnemc1YjBlS2NoZjhhWWRRZW5nb2VuaFRnd2NBYU9kUmFSZnNiZ2VSYjNmZ2dUYlZjbWRFZVZjVmRFYnhjSGdDY0djOWJ5ZUNnaGZVZ2pmZmJCZUlkL2VGZ2hlaGcxY0poaWZWZVRjZWRUZ0loY2JLZFdjOWR0ZVdnbGVWZnZmV2FraGNlZGdIZlZmVmRTZmRnR2Z0ZDZiWWYwZTFocWJTZXdkOWdTZEViR2ZSYU1iZmJqaDlhY2NBY1ZkMGQ1YUpkSGFFaEVoWGJBYlljNGdOYW5ib2IvZWNoRWROZ0RnV2FsYk5lMWZaYUZkZGIzZVlmbWNCaFhoQmZSY0JjUWRaZmtmZ2FOZ0xoa2ROZXdlSWZBZ01nMmNjZGhhTmJnZ1dna2ZoZWJkUmh3Y0pndmRmYm5md2VWZ2FlbmRKaFJlZGYxZ2RnS2RGaG1hbGNoZEZlaGJoZ21jRmVHZlphbWhZYlhnQmdWZmJoMWJJZE9hRWQxYjRnZGVFYnlmWWNJY05hU2djZEljQ2N4YThjSGJIZ1JoQmh2Y1RkR2hOZi9jVWZsaDRhSmJlaEdkNGhiZlNlMGRSaERiRWhHaHdmeGNPYkRoRWFhZUlhQWdZZGVoTWFCY2tmZmFmZHpjVmRwZlhmRmNrZ0VlRWFHYVFjaGdSZVdiOGFSYkVlMmQ5YkhhY2R4Y05kSGZhZkJjVmNJYVVhRWRjYVFlWmJuYkpoV2VGY1docGU2aEdjSGJrZFVhQWJsZ2NkN2VBZGxlbGdjZ0llM2VVZ3lnYmFpZTVkd2NYZ21jOWZOY1RoaGUwY0JlU2hWZ0pnc2FZY25jb2EvYlRnU2dOZEZoVGdCY3BnUmNOaGlhOGY1Yk1jaGRjZ2poUWhYZUFlNWNFZ2tlQWJZZFZjVmZCZ0lnY2JuYUJmd2FTaEVmTmNKZVdhbmVWZzRhU2IzZ2RnNmJhaFZiZGFaYkVnQmRsYW9hQWNtaDlidmJFZVJnTmN2YVJiM2RNYlRkUmgyY2doVmFTZ0ZoQmJIZ0VhR2RaZHloVGNCZVVjcGZmZkJnY2JsZEdjQWVkZzBkSWNEZVZiRmNFaEVmd2RVYlpnbWJaZGhjY2dGYVZmdmJXZ2tmY2dkZ0hnVmZWZlNoZGhHZ3RmNmRZZjBlMWhxZVNod2VjaGJiYWR5ZXRkTWNmYVhiWmJEaFBkeGJWZ2tmYWdoYkpjVGFFZlVjTWVGZ1lmamRzZ0xiUGJ6Z1ZhUGJZYzFocGcxZWVkRWF0ZDNhZWVtZmxoWGFXYlJhQWRaYmFlQWd0YkZnYmR4ZEVoVGdiZTBkZGV6YUdod2Y0Z1RnV2RrYWhhYmRSaHdmTWFiaGNja2hvZkphYWNtZ3BnWWhkZHdmdGFLZ1hoeGNJYXVlRmhoaE5mbWJCaGhkdGRxZFNiM2dCZ1ZjYmYxZ3BjSGhIYlJlMWZWaFVnbmZSY3JjZWVtZ05iTmJhZWtkc2VQZFVoaGVCZWtmUmZEYzhiTmNIZ1VnSWZlaGVkR2hOY3ZlU2Z3Z1JiZmNXYlhmcGQ3Z2NiQ2F4Y0ljQ2FqZEllVmNkZ1hhTmhMZllkd2ZkYmxlZmVWaGthUWJHYldjZ2NMZVJlV2I4ZlJoRWQyYzllSGZjY3hnTmhIY2FmQmhWYUlnVWhFZGNiUWJiYmpjc2J0YldobWhwYjVoVWRXZEFncWJTY2dmcGExZ1lmUWY0ZFJkWmVrYmhjbWJMY3hlb2gvZ1ZhV2ZSYmFmVWJXY0FhM2FWYlZnSmgwaGFlM2dwaGpkVGdXZHBmTGFEZTFmSWZRZFpmRWJ4YzJoZGNsZ0plQ2RIaEhmUmVjYkVna2dzZFllUWUxYWxnaWVjYm5oQmF3ZlNlRWhOZ0pmV2JuYlZjNGhTaHpiUmYwZ0plQWZJaFZhUmNGZEFjNGRSY3hoeGduZVVoQmFwaGhhRmZUZXhjSGdDYjJjQWRHYVdiVmVsYUpjWGVUZk1nK2NBYmxjd2Q2Y1BnZ2VoYy9nQmhFZ01oYWJRZTJmRWFXZ0dmR2dZYlVmWmRtZVpmaGdjZkZoVmd2aFdma2VjZ2RjSGJWaFViR2dlaGpkTWYxZE1oVWZVYXBkUWhnYkVhQWdYYXphQWdBZWZibWhSYkZhU2R4aHNoMWhJYjFkNGVmZlViUmFNYVZlT2czaG9lamVlZVVhWWhDZURhUmc1aDlhUGZraEpnN2hVaEdkbGdYY1dmUmVBaFphYWZBZHRiRmNiZnhiRWNUYWJmMGJkZXpiRWIwaGRkZ2ZXZ2thaGZiZVdmaGRCYitjZWIwZDBhL2ZhYm5lSmdSZWRmMWhkYktoRmNtZGxjaGFGZ2hkaGFtZlVmaWNrZjBmWWdYZGhmL2diYTFlcGRIYkhmUmMxY1ZkVWJuZlJocmhlZm1oTmZOZGFoa2Z0aEhoVWNnZDVjNWdUZERmbGUyY1djVWNJZkJmZWhIZ0FhVWhZYlJjaGhEZ1dnV2FKYXljY2RIZkJhSWFRZDBjbGJhZGRhWGFoYkxlZmN6YTlkRGhWZzFla2dRZ0dhV2hnZ0xmUmVXYzhjUmVFZjJnOWFIZGNkeGROZ0hoYWVBYnBmSWVFZzBlbGZXZE5hRGgwZWJlZGR5Zk1jbWNBZm5mOWI5ZVNiaGJaY3BmWWNSZ1liWWNaZGhkUmNtZVpkbWRGYndmVmJXYTljYWJSYXhjMGdkYVZkVmRKYjhmSWRuY1FlZ2RCZFNkc2ZaY2JoQmMxZlVjSWJTYzBkaWRmZWhhMWdDaEhjbmhoaG5jR2UwY3NiRWFYZDFhbGY2ZGVkM2RBZ3NnU2VBYnBhSGFHZVRhMGc1ZkdmUmhRYjFoTGhSZEloNGJSZUJnRWNuZEFha2JsaEZoRWJSY05mdmZSZDNiTWRUZ1JlMmJnZVZoU2NGZ0JlSGZFZ0dnWmF5Z1ZlaGdWZnFkY2hsYUZhL2ZIZ2tiUmdWZkllU2dCaEVoZWR5Z2xiUWRJaHdjY2ExZmVjQmJwYnZhVWVVZWNiT2dGZEZmVmNPY2FnR2V0Y2lnYWVrZTBjMmZTZzBmWmJjY1VieWV3Yk5iSmVCaFViZGZCZ2xnQWFaZUlnaGdvaEVhR2hFY2hiWmRjZkhhdGg4ZFdka2VoZURoU2JWZ3BnMWVlYkVhdGEzZWVobWhsZFhjV2dSZkFiWmdhY0FjdGhGZWJkeGZFZlRnZmUwaHRiWmVFaDBkZGNvZEZjVWJoZlFoUmZ4ZEJibWhjY2xlWWdWYWFlbmRKZVJoZGYxZGRhS2dGZG1hbGN4YlBkQmZoZ21kRmJHY1pjbWJZY1hmQmZWY2JlMWZwY0hnSGVSYzFnVmFVYW5nUmdyZmVjbWVwZG5hYWdraHNhUGVVZGhiQmRrY1RjSGdaZTJoVWRrYkljVmFlZUhjWWdTZVNld2VKaERlR2NtaHdnMGNJZGplOGJGY0lmUWNBYk9jSmJuZ0JnaGVkYTNncGFwYVZkMWVrZVFmR2RXZ2dkTGVSZVdlOGZSaEVoMmM5Z0hjY2F4ZU5iSGNhZkJoVmRBYUdjVGh4aGZiWmNuZGxlV2JCYkJhZGV5YVRjV2V0YVhjVWZoZTlhcGhQYVJjWmZSY0hlVmJzZWJoYWJrYXRod2JWZldkOWRhaFJjeGcwZ2RkVmRWaEplMGVhZTNlcGRqaFRoV2JwZUxlRGUxZ0liUWZaZEVoUWEvYURmUmMxY0NmSGduaGhobGhiYjBoc2FFYVhnMWdsZjZnZWMzZUFkc2JTYkFkb2V5ZEZoWGNWYnpiU2QyZlViSGVaYVhiMWhaYkVhQmJsaG9kQ2MwYlZodmhFY1JlTmJ2Y1JmM2NNYlRoUmQyZWdnVmNTYkZlQmdIZ0VjSGZaZythZmVCZ1ZjcWVjaGxmRmgzYVZkMGFvY1dkYWJXZUVlV2hHYUdlWWdVYlpkbWdaZGhkY2FGYlZkdmFTZm1oMGNkZEhlVmJWaFNmZGJHaHRmNmhZYjBiMWRxZ1Nld2g5Y1NlRWNHZ1JkTWhkYm5mWmFiZ1RlamY5ZDRiZGdoY0pjTGNHaEVhTmFaZFljbmZKZndkY2NFZWhjRGNTZVFhNWc3YklhQWFRYWxjY2NpZnBkWmFGaEVnVmJWYVBhRWNJZFZnSWUwYmdlYmZQZkVjNWc2ZUhiUmNVZm5oUWZRZlJnWWFWaFFmTmh2ZmZiQmN0Y0FlSmZpZ1llWWJKZXhnc2hUZkhhaWFoZW9kR2VGZ2tlaWVVZ0dhNGV6Y2FiSGV4aC9jYmcxZ3BiSGdIZ1JjMWRWZFVobmhSaHJkZWhtZk5iTmhhY2toc2dIYkhjUmdCZ3ZhVWdYYlplaWFXYzBic2VPY1VnbmZZZlNkU2N4ZmhkRGNXZldjSmV5ZmNmSGZCYkliUWEwZmxnYWJQZ1hlaGdWZGRhemJWYXlmZmRYZk1lUWZHZldhZ2NMY1JlV2U4YlJoRWQyaDlhSGNjZ3hoTmNPZFFnaGNWaEllVWJFY2NiUWJaaG5hSmdXZUZiV2dwZ3llVWdYZmRkWGVDZFJjZ2h2Yk1lMWNsaFZlQmNGZjBoeWZOZ1dia2QxZlZnWGNCY2FhRGJoZk5lZWZIY1JjTWRtZkNlRGhVYW5iQ2RBaHNiZmVCYXhmMGJiZmJnMGhWYzJnYmhGZklhTGhiaGphZGU5ZEdmVGRZZ1VlUWEwYmxhdWJjYm1lQmY4ZlNoRmJOYUFjVmhsZDljNGVTZzNnZGE2Y2FiVmJkYVpiRWNCZWxob2JDYjBjVmh2Z0VkUmFOZXZkRWczZjFkTGVDZURkb2ZkYUNhMWY0YktlUmZTY29jbWhIZDBkVWFtZUtoMWZraDdmWGNrZE1lWWZPYXllNWhDYVZiR2g0ZEZmZGQyYjlkdmZQZFFoQWJqaERnZ2Q1Y05oVWNRY3hjYWJKZDJjSmVoY1NlVWExZ3FoU2V3ZjllU2NFYUdnUmFNZmRmbmFaZ1NmUWVraGNjOWdJZ2thY2VaZ1Zma2dOZlJjU2dIZUpjd2JjaEVjaGJEZlNoVmRwZTFjZWNFZHRhM2dlZm1kbGJYYlVhVWVJYlphZGJRZHNoUmNZY1ZiSmdmZklkQWRrYTJhR2cwZDVlbWdSZ2diQWJaYUFiVWZRYlVjT2J4Y0ZnZGNQaG5kcGhDaFpiRmQ1ZERiR2hrYU5maGhGZmhiaGhtYkZjR2JaZm1oWWZYZ0JoVmdiYzFmcGRIZ0hkVWVsaGJoQ2RqaHNkNWJjZGpjRmhFZ1pkQWNaZmFkSGFrZFFhdGFIZkRob2V2ZldhZ2NNZ2NoZGRGYndkU2FTYnhmaGZEZldlV2FKYXljY2VIZEJnSWdRZDBkbGFhZ2RnWGZBZ1plZGQyZmRocGFBZDFhZGJUZVZjU2RkYkZlQWVHZmNnWWJIYlRod2RQYU9obGNVZVRjR2NsaHdiUGRHZkJkTWFZZ2RlR2d0Z2ZiSGNHZVpnWWZVYlhoZGVYYlNhaGVaZnBnWWNSZVloWWdaYmhnUmNtaFpjbWRFaGtmV2Z6aGNlVmZGY1JiVmhQYVhlRmh3ZDVnUGFqZFloM2VCaERmb2JIZ1ZhbGNwZUZmYmRVYUJjY2VkY2xjSmJDZkZoWGJoaDJoRWNrZnNiWWRRZTFibGZpY2NibmJCaDRlR2JrZk5hVWZXY2ljRmEyZUNhRGFzZDFlSmF4Z0plUmFHZVJjY2Y3YlFnd2N3YnBmUmJXZ0VhbWFBZERodGFIZFRkM2FzY0hhUWZWZWxiTGFPZW1kWmN5YlZoaGdWZHFlY2NsZEZnM2FWZTBlb2ZXZGFoV2hFYldnVGJHYmhmTWFLZVRmUmJwY0lkbGN4YmpmY2hFY2NmZGZIYlZiVmZTYmRmR2d0ZTZnWWEwYTFmcWZTZHdhOWFTZlJlQ2h3ZEZmSmhYZmdnYmhEYkZmd2RzZGZha2RZZ0RlVWVSZUJhWGJNZ1RlY2IxY05kRWRGZlBjWWUxY3BlMWRlZUVkdGUzYWVnbWhsY1hmV2JSYkFnWmFhZ0FidGdGYU9lemhzYlRmYmMwYmRjemZFZDBmZGNvZkZlVWRoYlFiUmR4aEJkdmJhYlhod2VWZWFobmRKY1JhZGMxZGRnS2RGZG1mbGFoZFNkeGZGZXFoUGVtY1pibWNZZ1hnQmVWaGJkMWNwYUhiSGJSZTFlZGhCaG5hb2V1ZElhamVNY0NkT2RCZzlkY2ZVZ2djMWJrYkFhM2E5YXRiZWVFZUliVmRlaEhiWWZTaFNjMGhWZE5iR2hpaE1nK2hQZEhmZ2FhZVRoMGJrZlRkZmdXZGhkQ2ZlYVJkZ2E4Z0VhUmQ5ZlZnU2gyaEVnQ2ZYZmtmVWVSaEVkMmc5YUhmTGNoZzljdGNhY0JkVWgxZFdlVmh3YzZiT2gzY3RnTmVQZTBmQWIrZEZiQ2ROY1hjQWdsaGthNmVOZVZoaGNaZ0thMWFGZ21mZWgyZEZoM2hVaG5hUmh3ZERmbGZzZ2RlWGRRZ1lodGJPZ3pkOGdzYUNkMmdvY2NoUmVoZXhhVWVLZXhhdGQyZ2FnMGI5aGZhRmhYaDhjamhYZUFjOWJkYkJnUmNBYnNiTmZ6Z1JkM2ZTaEJiOGhWZVdoaWFzZzBnQmdEZ1FkN2VQZlJiNGhXaFhnaGFjZWdiV2JRYkFhcGdIZDFkb2VoZUFkemNaZUxnS2FDYjRjZGdTY2hhSWVMaFhoeWFSY29hVmhCZnhlamRjaGdicGJkYVZoMGJwaGVlSmZqYUpjQ2RWZWlhZGNaZkloMmdaZzhnY2RGZmNoNGhGaFJiVmZXZVdmQWNkZVFiYmIwZkVjbmNZZXdmZ2NtaEdoRWNwaFNmU2UwYjViTWhkaGlhSWhBY0dheGZVZ2plWGZCaEpkTGFHZ0ViTWVSYkxkU2ZFZmtnUGNnYWtkT2VEY0ZocGhvaGVhRWdNZDVhUGZ6ZDVmWGhMaEdoSmUxaFlnRWVjZUtnTGNGYkJlSGVKZWdlZ2Q5YkhoUWc4ZTZmVWJBZTVoWmhUZ2hhNGJ1aFBiUWJWY0JiSmZEYU1mY2FNZ2xjY2hXZFNobWdsYmphVmRGY2toaWdGZG5mMWVNY1ljWGRBYkllYmR4ZGtmR2VTZFZmNGRkYVVibmV3Y3ViY2gyZk1hV2hRZUVjc2NQY1VlaGJBYnNoQWh5YlVmaWZIZkFjTmVZY1BlWGdZZlBnU2V4Y29mVWRGYWpjQWc1Zk5kU2JKZUtiV2JHYU5jYWJkZFNoVmFoaEtmbGNCY0RmR2R4Z3hjRWhHY1RoeGFmZFJhWGVJZlJjRWVtYzRhQWZQYzFid2VGYktkVmhrYThiR2RBZDVoRGRhZURmY2VBY1ZkQ2VZZEphSWdpaE1iRmJBZDFmZ2V1Z2JmMWRCYktkS2hWYmtnRmdLZVNkVWMxYkpoU2dBaFRmQ2dVZ2tlVmhUYVVjTmd0ZmZjbmFNZWVmVGVYZFZlTGFTYkJmNWJmY0pnZ2UwYjZhQWNoZ29hTGVSZm5lWWNaaFlnQ2hsZW9mTWVUYllmZGdHY1JjVWZKZlNiQmg4ZFZnV2VqaDBnM2hHY0NmTWgwY0tiQmNvYWNhRWJBaE5hb2NBaHdkSWFqYlhmbGhFaHVmQ2F3Z2RjYmdEZGpic2NiZkpheWJJYmxoWWJCaFFiZGFLYlhiNGZQZ0NoMWVFaHJjQ2cwYXBhZWZKYmpnSmVDY1ZjaWhkZVpnSWYyZzllaGZlYTFlVmF0Y1dka2FVZ0dmTmd4ZVljZGRPZGpiZ2V1Z1lhd2FzZXNoU2Z4YkpjU2JWY3ljZ2FEZk5nRGJjZ2VjTmJsYzBmeGNKZVJod2VFZlNjQWhZY1hhSmJ5ZkJiK2JEZ3dib2ZXZkRleGV3aDliYWcxZmxjL2FhYW1kQmVaaERmRWJCY2RjS2hWYThjQWFaaDBhVmZIY1pja2RrZjNiV2hnZUFhdGhSZWhkeGhZaFRhaGc0YXllUGFTZlZoQmJPY0Ric2NmZU1oRmg5Y2JjQWZHYUJjdmZSZ2xna2NpYVpiemFJZm5iTWd5aFJiZGZmaGtmeGNMYUhiUWMxZWNmWGdDY0Fja2dGYWljd2FhZkxieGVsY3NhRWIwZk1oaGhSZUhoOWh0YmVoQWZWZlpiTmZ6YlJhVGRCZzJod2dMY0VmRGFGZzhjUGd5ZEFiTmhEZ1Fkd2dJaGRmV2ZWYUxmTWNEYVljbWNGZFJhaGFjYmJhU2hCZENlRmZtYUZndWdYYkRlOGVDZlBnVmJZaFZmY2V6ZDhiTWJGZFFidGhWY01namZkY1dlVWRpZ1lkOWZFYnpmWWdiZFBjbGU0YmdjTWZoZmhiZGJNZkZkVWVxYUhiUmhJY2tnQmJ5Y1loVWdBaEJiTmFiaEJjeGYwZTViQ2JEZFVhbmFDZUJlb2NFZFJlaGR4YUVnYmVGaFJobmRiZDBiZGZMZmFmR2hOYmNnR2VnYjFjTmJEZFJjb2UyZU9jemQ4YytkUWdEaHhmWmFBYm1oZGh2ZldiRGhRYjdiZmZWaHNkbWNBYUViRmM3ZEVhbGRGaCtiVWcxY1phbWVIYkNkVmJTZ0ZoV2RoZ3FkV2VBY2hiVmZWZWlkUmNtZlRkbGVCZzNmRGJVZkVjdmJSYWxla2ZFaGNlV2QxZHBhQ2dEZjRkQWZKZ0NnTWdsZU5nRWVCaHliSmFWY2RlRmNEYzBhSmdCZE5heWRwaHVoYWgwZFJkeGNIZ0VjY2JiZ1hmQ2NGYUVlZGEzZGNlcGdQYnhnd2hqaElia2ZBaFNlUWR4Y1VhWWNNZEhjSWFQY1lhQmNCZ1dmV2IwZTVka2RiZGxnaGVxY0tmaWdnY0ZiQ2NsZVZid2FKY2xlOWJOZEViQWRGZkxlZmRRZEVmeGhCZTFiOGd0Z0hmVmFnZkloVmhnZk5jMGVlZDFhOGdhaGViaWZwYkFjZmhWaDhnYWRWYXpnc2V5YlVmM2hFZm9kUWdHZDRnWmJjaFNiaGNIY0tjUmVoZ1RjQmRWZWhkZGVRYWlneGM2Y2FkQ2dCaEVhWWQwZlFhZmNDZWdmSmR0aFJieWhZZjNiQWNCYkZoUWFFY1RiaGRHZlFiMmRkZFRhQWVYaEFlMGJNYW1mUmNRZUJka2JGZUtjTGJXZ2xoWWdZYm5kTmZnYldoRWJsZEljQ2VtY0lkRGhTYURkOWNRYlFoVGV3ZUNoR2dsZzBnVGNZZkdncGhZaENjRmdWZldkSmZHaFphT2dVaEdnSmFpYkNmV2FaYkVhWGZoZTllZ2hiZmdlWmFBZmNnaGMxZnRiTmVpYUFhaWRCZGlhb2F6YkNoVWNrZFZkS2drZEloc2JlZVRnd2doZ1dnWGJJaE9nQmcwYkpkSWFkZlZlNGgwZmZnMWh0ZE5mQmNTZUJiamFHYUVnTmhJZkFlZ2hzZHhlTmF4ZGtlK2VIY0Vhc2YyYVNoaWUxZ3FkRGJUZFZmdWdjYlJhSmRSaEFkRWRGZDVnR2dGYkpkbWZHZEJneGIvZEhkMmFVYWFhVGZHZlZmRmJDYlFhSWhVaFZoUWM4ZDhnQWZoYjBnVmZZYmdmbGNsZUVmUWNnaENoY2FTY1FoZWhDZ0RhNGVGZ2RmQ2JOZW9hZWdWY3BnL2FBYmxlQWhXYUVlQWJVZlRoSmhqZmdkL2JDZGdhTWcrYVFlM2ZCYkNnU2RIZlliS2VOYkdkSmRLY0JieGUxZm9iTGNnY05kWWdDZTBjcGhRaGJiV2ZJY29mYWRFY01hVGNDYUFoZ2VtZ1BlU2RJYzVjTGNtZUVkb2JTZ1ViZ2NMYkxla2VsYVJjZGIxZFFmYmRmZXhkOWVpZEFoUWJOY2hoSGhFY2RkQWNIZXdjbGVzZGVhbGF0YUZjS2d5YUFmQ2JNZWplNGZFaFFibWhFYWVjQmhrZ0JiMGFVZGlkUmd5YWVmVGdWY2RkZmN3aEpkV2hEYjFjdGNjZ1dnM2h0ZzdlSWJpZ0poRWFZaFJodGFPaEFoRWFNZ2hiSmVUZGdiaWVXZGpnMGVGaElkR2dSZFVkQ2VRaHhoYmVIZEdlcGFpYktoR2FGYmJiVWVrY0JlVGZlYW1lZ2NUZ05jV2RFYmdnRWRWaEZodmZDYlRkQWdlYVZoM2VzYUFmQmZYZHhjYWRiYmdoNGU0YWVkRWcxaGJoU2hWZE1mQmVKZURkZGJmYlZjemZnZjNjRWZEZ3hlTWREYjFob2E2ZEplQmJaY25iZGNrYnhieWNKZENiUWMwYkVjWGJvZmhlUWZFYjFiSWRCaGhicGZ6ZEZmbmhJaGNhWGFUY0pkZmRUY1JiZGFVYkloRmVrYU5jY2NRZkVhS2FYZURjNGFpZkZoVGZZZVFlU2ZsYUJkNWNMY3piTWR4ZEhhQWVBZ0JnVWNnY3Blb2ZFZTJnUmF0Z2VjeGhNZVlmVWd4ZkFiemJkYkZnVWEzZ0JnVmdFZ3FiQWZ6Y2NjR2VQZkdoOWJGaEhhUWVNZFBmRmh4ZnRnNmVLYlFoVWF5ZVplaGhNaHliRWZ3YTRiRGVFZW1iWmFGY1VhQ2M5aFNkTWRtYkVlY2NlZkZjeGRtY1FmUmNwaEFiUWZGZjBkdGRaZURmTmh2ZElhVmJ4aHpmUmR4ZThoS2dBYWllVWZJZ1lnV2hKZGJiU2Z3YzRnK2FJaDFkd2ZJZlRiQWFvZldoTGZIZEllb2VLZ0JkQWRSYkNiQWVrZnhoUGJnYVZja2NjZm1lQWdNZkJkRmJaYU1oSmFrZmdnUmJKZmxiNWRkY2JjemZoY2plU2MxY0lncWVCaEZiRmhZZFRha2NzZHdiTWZ3aFFhVmdGZ1dhSWNKY01hMGVVZU9jQWhIZGxmemhDZDJlTmNoY0JmbmhKYS9oZGhtZUZnTmhlZHloQWMxYWRjbWdRZW1jRmVuY05ibmVmYlhjQmJVYmZiRmJOYmlnSGVuY3NkbGVDY2dkOWN4aFhia2FVZEhjYmYyaFZmYmVNZVVnb2JraEtiU2h4ZzFnZmJIYWNlZ2dCZWdnVWFXZk9jZ2RRZFRjWmZXZW9lZWZHYkFmdGdjY1hoV2hrYk1iU2JXYmdhQ2RBYW5nY2drZE1lRmVrZUNkR2IyZ1ZnUGNYZ0VnQWJDZWNoMmhKZEFmQmJRYTBja2dJZFJoVWVFY0RjUmRGZ2xmWmFnYWNiS2dkaFFkSWZsYkVieGdJYWdkSWZnYk5nZGJTZHhhb2FKaFFkVWJSYXRlZmV4YzhlcmFIZ2hkZ2ZOZGFkMWRVY2NjWWcxaDVobWJaY0VicGdhZUJiMmN3YWNmV2h6YXRjV2FGY0FodGFsY2ZnbmdkY2lkWGRsYU1lemhFYkFlRWF1aE1oUmdWZjlnWmdWZ0FmVmRYZjFnNWh2YkJhMGZKZjRiQ2dBZ1poN2VYZ21hSWZIYkNmQmRCZTljTGREZU1jZWFGZDJicGQxYlJid2JZZVpoR2JoZVViVmVQZWljWWNSZ0ZlSGNwZHBkQ2VEYTRlQmZKYkhkZGE0Z2JjUmJNZjZiRmZBZlJkSmZWY0Jlb2ZjYWZnR2VJZmhnTWZRYWdmK2FIZmxkMGRjZ0VlQmZ0YWNjTGhqY0pjQWJCZGdkTmVvYVpoQWNrZFdkQWd4YkVlY2ROZWlkY2VpZ1Bja2RnZjhkV2ZRaEpkZ2VPZGxhcGh1YmNobWVCaE1kQmhGYlplTWhKY2thZ2RSZEpnbGE1ZWRhYmJ6ZGhnamVTZDFnWmQ3Y0JoMWRCZ1llT2hBY0FjK2FZYlVmVWhDZmNnMmdjaFNkZWF5YmhmYWRUaG5nd2JsYkFiVmUxaDNjQmJHZDhjOWFOYnpmRWZIZGJieWFWYVhnUmhRZGdoWGFRZTJkMGV2ZFBoSGU0aHlhZWJoaE1hYWdFY0FoRmE5ZVJjSGc5ZXRiQWhBZ2RkQmJMZVNjUmhjZVNjMmhkZ1RnQWRYZU5maGhZZW1iaGFWYUJjUmZ3ZFViTmVpZ3dmQ2FPZ0RkUmNoYUtmRWJsY0liQ2dIZ3NoWmRYZ1hjY2JCZ0hjeGZCaFhlS2R3YlpjV2hmZkZoRWNPY1JoRWM1ZkxmR2RXaElnT2FCZUhhbGFnYlNkV2E5Y0hnVmgyZ2xmNWhPZVFnY2RMaGRiQWV4aCtjZGZtY3hhZ2dEZlhkNWdJYkJnUWZaYUxiRmFBYkJiMGFGYUdob2U3Z1hhM2NJZk5kR2hVYWNkRWRlYlRhTmRtZUxja2ZjZEFmQmNHZEVheWhWZ0RoQmJuZVVnd2RGYnpoWWhXZ0pib2FVYUZhTWcwY1FjU2djYzliSGN5Ykllb2ZKZTFmY2htY0FjRWRGZzZmRWh3Y05jNWhCZEFmZGcwZUdmbmQ5ZHNoVmZ6YkFiRWFXYTBiSmFmZEdhQmVsZ2lmRGZnYlpkNWJaaFVhaGhpYUZmRWZaaHBkZWVUZmtnRGRYaEhlRmVSY2RoM2NaZG9lYWd3YWdoM2VBZWhjOWJQZVhoQWZZYVdnTWVpY1ZicGZhZjBkUmJ4YllmVWNFZVhkUmIyZlFkdGFKZUNnUWdUYUdieGExYnVoWWhoZXRiRmRVZ2dod2FRZkxkSGRvZzJlTmNrZkZlWWRTZVZhcGY2YmRmMGdzZkRmTWNpYUFiRWVXYlVlZGZRZkpkRWNkYkZoTGNWaFFlVGVPZHdnOGUyZ0VoeGVFZnBjV2NSZTBiVmdSZTBhSWZqY0plZ2FOYkhkSmNEaGNmVmhkZ3hmVWNUZ0ZjaWZ3ZjNmVmMxY1JkTWRQZmdmPWc9AHVyVEtaQ21Kay9yMERsVlZyYjVYVjJrOGN5QlJQUGhjaXpVWGtXWkl3eTA5SCtlTzEzT2dTM2dINWhwZzBGUnY1SlJxV3dqNklBNjhGNEZGQVB1T3pnPT0AMDEyMzQ1Njc4OQBDLlVURi04AEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaYWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXowMTIzNDU2Nzg5Ky8ALgAobnVsbCkAUHVyZSB2aXJ0dWFsIGZ1bmN0aW9uIGNhbGxlZCEAbGliYysrYWJpOiAAAAAAAAAAnLMEAGUAAAAyNlByb3BhZ2F0ZWRQb3NpdGlvblByb3BlcnR5AAAAAGz9BAB8swQA2LYEAFAyNlByb3BhZ2F0ZWRQb3NpdGlvblByb3BlcnR5AAAANPwEAKizBAAAAAAAnLMEAFBLMjZQcm9wYWdhdGVkUG9zaXRpb25Qcm9wZXJ0eQAANPwEANizBAABAAAAnLMEAMizBAAw+wQAyLMEAKS4BABpaWlpAGRpaQB2aWlkAFAxNkVudGl0eUNvbGxlY3Rpb24AAAA0/AQAJrQEAAAAAADotQQAUEsxNkVudGl0eUNvbGxlY3Rpb24AAAAANPwEAEy0BAABAAAA6LUEADy0BABgtwQAAAAAANi2BABmAAAAMTZQb3NpdGlvblByb3BlcnR5AFBLMTZQb3NpdGlvblByb3BlcnR5ADT8BACbtAQAAQAAANi2BADgtgQAZPsEAOC2BACU+wQANEJhc2UAAAAs/QQA0LQEAFA0QmFzZQAANPwEAOC0BAAAAAAA2LQEAFBLNEJhc2UANPwEAPi0BAABAAAA2LQEAHYAAADotAQAAAAAANi0BABnAAAAaAAAAGkAAABgtwQAALUEADhTdWJjbGFzcwAAAGz9BAA0tQQA2LQEAFA4U3ViY2xhc3MAADT8BABMtQQAAAAAAEC1BABQSzhTdWJjbGFzcwA0/AQAaLUEAAEAAABAtQQAWLUEADD7BAAAAAAAQLUEAGcAAABqAAAAawAAAGC3BAB0tQQA0PoEANi0BAAAAAAA8LUEAGwAAABtAAAAaQAxNlBvc2l0aW9uUmVnaXN0cnkAMTZFbnRpdHlDb2xsZWN0aW9uACz9BADVtQQAbP0EAMK1BADotQQAAAAAAOi1BABuAAAAbwAAAFAxNlBvc2l0aW9uUmVnaXN0cnkANPwEAAy2BAAAAAAA8LUEAFBLMTZQb3NpdGlvblJlZ2lzdHJ5AAAAADT8BAAwtgQAAQAAAPC1BABpaQB2aQAAACC2BABgtwQAaWlpAGT7BABItgQA0PoEACC2BABQ+wQAdmlpaQAAAADQ+gQAILYEAHZpaQBk+wQAILYEAJT7BABpaWlkAEGw7RILgwhk+wQAILYEAOC2BACU+wQA6PoEAFAxNlBvc2l0aW9uUHJvcGVydHkALP0EAIi0BAA0/AQAxLYEAAAAAADYtgQAaWlpaWRpAABk+wQAILYEAND6BAAw+wQAMPsEAJT7BAAw+wQAMPsEAHZpaWlkaWkATlN0M19fMjEyYmFzaWNfc3RyaW5nSWNOU18xMWNoYXJfdHJhaXRzSWNFRU5TXzlhbGxvY2F0b3JJY0VFRUUAACz9BAAgtwQATlN0M19fMjEyYmFzaWNfc3RyaW5nSWhOU18xMWNoYXJfdHJhaXRzSWhFRU5TXzlhbGxvY2F0b3JJaEVFRUUAACz9BABotwQATlN0M19fMjEyYmFzaWNfc3RyaW5nSXdOU18xMWNoYXJfdHJhaXRzSXdFRU5TXzlhbGxvY2F0b3JJd0VFRUUAACz9BACwtwQATlN0M19fMjEyYmFzaWNfc3RyaW5nSURzTlNfMTFjaGFyX3RyYWl0c0lEc0VFTlNfOWFsbG9jYXRvcklEc0VFRUUAAAAs/QQA+LcEAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0lEaU5TXzExY2hhcl90cmFpdHNJRGlFRU5TXzlhbGxvY2F0b3JJRGlFRUVFAAAALP0EAES4BABOMTBlbXNjcmlwdGVuM3ZhbEUAACz9BACQuAQATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJY0VFAAAs/QQArLgEAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SWFFRQAALP0EANS4BABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0loRUUAACz9BAD8uAQATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJc0VFAAAs/QQAJLkEAE4xMGVtc2Ny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FABBjZATCwEWAEGZkBML/wIVAAAAABUAAAAACRYAAAAAABYAABYAADAxMjM0NTY3ODlBQkNERUb/////////////////////////////////////////////////////////////////AAECAwQFBgcICf////////8KCwwNDg8QERITFBUWFxgZGhscHR4fICEiI////////woLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIj/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////wABAgQHAwYFAAAAAAAAANF0ngBXnb0qgHBSD///PicKAAAAZAAAAOgDAAAQJwAAoIYBAEBCDwCAlpgAAOH1BRgAAAA1AAAAcQAAAGv////O+///kr///wBBvJMTCwFSAEHkkxMLCP//////////AEGslBML+AmEzAQAdgAAAHcAAAB4AAAAeQAAAHoAAAB7AAAAfAAAAH0AAAB+AAAAfwAAAIAAAACBAAAAggAAAIMAAAAAAAAADM4EAIQAAACFAAAAhgAAAIcAAACIAAAAiQAAAIoAAACLAAAAjAAAAI0AAACOAAAAjwAAAJAAAACRAAAATlN0M19fMjliYXNpY19pb3NJY05TXzExY2hhcl90cmFpdHNJY0VFRUUATlN0M19fMjE1YmFzaWNfc3RyZWFtYnVmSWNOU18xMWNoYXJfdHJhaXRzSWNFRUVFAE5TdDNfXzIxM2Jhc2ljX2lzdHJlYW1JY05TXzExY2hhcl90cmFpdHNJY0VFRUUATlN0M19fMjEzYmFzaWNfb3N0cmVhbUljTlNfMTFjaGFyX3RyYWl0c0ljRUVFRQBOU3QzX18yOWJhc2ljX2lvc0l3TlNfMTFjaGFyX3RyYWl0c0l3RUVFRQBOU3QzX18yMTViYXNpY19zdHJlYW1idWZJd05TXzExY2hhcl90cmFpdHNJd0VFRUUATlN0M19fMjEzYmFzaWNfaXN0cmVhbUl3TlNfMTFjaGFyX3RyYWl0c0l3RUVFRQBOU3QzX18yMTNiYXNpY19vc3RyZWFtSXdOU18xMWNoYXJfdHJhaXRzSXdFRUVFAE5TdDNfXzI4aW9zX2Jhc2VFAAAAAACMzAQAdgAAAJIAAACTAAAAeQAAAHoAAAB7AAAAfAAAAH0AAAB+AAAAlAAAAJUAAACWAAAAggAAAIMAAABOU3QzX18yMTBfX3N0ZGluYnVmSWNFRQAs/QQA0soEAGz9BABszAQAhMwEAAgAAAAAAAAAwMwEAJcAAACYAAAA+P////j////AzAQAmQAAAJoAAADY+wQAA8sEAAAAAAABAAAA6MwEAAP0//8AAAAA6MwEAJsAAACcAAAAbP0EAKjKBAAEzQQAAAAAAATNBACdAAAAngAAACz9BAAazAQAAAAAAGjNBAB2AAAAnwAAAKAAAAB5AAAAegAAAHsAAAChAAAAfQAAAH4AAAB/AAAAgAAAAIEAAACiAAAAowAAAE5TdDNfXzIxMV9fc3Rkb3V0YnVmSWNFRQAAAABs/QQATM0EAITMBAAEAAAAAAAAAJzNBACkAAAApQAAAPz////8////nM0EAKYAAACnAAAA2PsEADLLBAAAAAAAAQAAAOjMBAAD9P//AAAAABTOBACEAAAAqAAAAKkAAACHAAAAiAAAAIkAAACKAAAAiwAAAIwAAACqAAAAqwAAAKwAAACQAAAAkQAAAE5TdDNfXzIxMF9fc3RkaW5idWZJd0VFACz9BACLywQAbP0EAPTNBAAMzgQACAAAAAAAAABIzgQArQAAAK4AAAD4////+P///0jOBACvAAAAsAAAANj7BAC8ywQAAAAAAAEAAABwzgQAA/T//wAAAABwzgQAsQAAALIAAABs/QQAYcsEAATNBAAAAAAA2M4EAIQAAACzAAAAtAAAAIcAAACIAAAAiQAAALUAAACLAAAAjAAAAI0AAACOAAAAjwAAALYAAAC3AAAATlN0M19fMjExX19zdGRvdXRidWZJd0VFAAAAAGz9BAC8zgQADM4EAAQAAAAAAAAADM8EALgAAAC5AAAA/P////z///8MzwQAugAAALsAAADY+wQA68sEAAAAAAABAAAAcM4EAAP0//8AQbCeEwsU3hIElQAAAAD///////////////8AQdCeEwtXTENfQ1RZUEUAAAAATENfTlVNRVJJQwAATENfVElNRQAAAAAATENfQ09MTEFURQAATENfTU9ORVRBUlkATENf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",Ri(Vi)||(Vi=R(Vi));function gn(u){if(u==Vi&&G)return new Uint8Array(G);var S=C8(u);if(S)return S;if(N)return N(u);throw"both async and sync fetching of the wasm failed"}function De(u){return Promise.resolve().then(()=>gn(u))}function Ye(u,S,W){return De(u).then(P=>WebAssembly.instantiate(P,S)).then(P=>P).then(W,P=>{b("failed to asynchronously prepare wasm: "+P),si(Vi)&&b("warning: Loading from a file URI ("+Vi+") is not supported in most browsers. See https://emscripten.org/docs/getting_started/FAQ.html#how-do-i-run-a-local-webserver-for-testing-why-does-my-program-stall-in-downloading-or-preparing"),Ge(P)})}function Bi(u,S,W,P){return Ye(S,W,P)}function An(){var u={env:wB,wasi_snapshot_preview1:wB};function S($,ht){var dt=$.exports;return U=dt,Q=U.memory,c(Q,"memory not found in wasm exports"),tt(),B=U.__indirect_function_table,c(B,"table not found in wasm exports"),ce(U.__wasm_call_ctors),ze("wasm-instantiate"),dt}ni("wasm-instantiate");var W=i;function P($){c(i===W,"the Module object should not be replaced during async compilation - perhaps the order of HTML elements is wrong?"),W=null,S($.instance)}if(i.instantiateWasm)try{return i.instantiateWasm(u,S)}catch($){b("Module.instantiateWasm callback failed with error: "+$),s($)}return Bi(G,Vi,u,P).catch(s),{}}var Ne,ei;function _n(u,S,W=!0){Object.getOwnPropertyDescriptor(i,u)||Object.defineProperty(i,u,{configurable:!0,get(){let P=W?" (the initial value can be provided on Module, but after startup the value is only looked for on a local variable of that name)":"";Ge(`\`Module.${u}\` has been replaced by \`${S}\``+P)}})}function hs(u){Object.getOwnPropertyDescriptor(i,u)&&Ge(`\`Module.${u}\` was supplied but \`${u}\` not included in INCOMING_MODULE_JS_API`)}function Qi(u){return u==="FS_createPath"||u==="FS_createDataFile"||u==="FS_createPreloadedFile"||u==="FS_unlink"||u==="addRunDependency"||u==="FS_createLazyFile"||u==="FS_createDevice"||u==="removeRunDependency"}function nn(u,S){typeof globalThis<"u"&&Object.defineProperty(globalThis,u,{configurable:!0,get(){Ai("`"+u+"` is not longer defined by emscripten. "+S)}})}nn("buffer","Please use HEAP8.buffer or wasmMemory.buffer");function ki(u){typeof globalThis<"u"&&!Object.getOwnPropertyDescriptor(globalThis,u)&&Object.defineProperty(globalThis,u,{configurable:!0,get(){var S="`"+u+"` is a library symbol and not included by default; add it to your library.js __deps or to DEFAULT_LIBRARY_FUNCS_TO_INCLUDE on the command line",W=u;W.startsWith("_")||(W="$"+u),S+=" (e.g. -sDEFAULT_LIBRARY_FUNCS_TO_INCLUDE='"+W+"')",Qi(u)&&(S+=". Alternatively, forcing filesystem support (-sFORCE_FILESYSTEM) can export this for you"),Ai(S)}}),sn(u)}function sn(u){Object.getOwnPropertyDescriptor(i,u)||Object.defineProperty(i,u,{configurable:!0,get(){var S="'"+u+"' was not exported. add it to EXPORTED_RUNTIME_METHODS (see the Emscripten FAQ)";Qi(u)&&(S+=". Alternatively, forcing filesystem support (-sFORCE_FILESYSTEM) can export this for you"),Ge(S)}})}var Cs={327548:()=>{console.log("no show")}};function cs(u){this.name="ExitStatus",this.message=`Program terminated with exit(${u})`,this.status=u}var xn=u=>{for(;u.length>0;)u.shift()(i)},Pn=u=>(c(typeof u=="number"),u>>>=0,"0x"+u.toString(16).padStart(8,"0")),Ai=u=>{Ai.shown||(Ai.shown={}),Ai.shown[u]||(Ai.shown[u]=1,b(u))};function Ci(u){this.excPtr=u,this.ptr=u-24,this.set_type=function(S){H[this.ptr+4>>2]=S},this.get_type=function(){return H[this.ptr+4>>2]},this.set_destructor=function(S){H[this.ptr+8>>2]=S},this.get_destructor=function(){return H[this.ptr+8>>2]},this.set_caught=function(S){S=S?1:0,g[this.ptr+12>>0]=S},this.get_caught=function(){return g[this.ptr+12>>0]!=0},this.set_rethrown=function(S){S=S?1:0,g[this.ptr+13>>0]=S},this.get_rethrown=function(){return g[this.ptr+13>>0]!=0},this.init=function(S,W){this.set_adjusted_ptr(0),this.set_type(S),this.set_destructor(W)},this.set_adjusted_ptr=function(S){H[this.ptr+16>>2]=S},this.get_adjusted_ptr=function(){return H[this.ptr+16>>2]},this.get_exception_ptr=function(){var S=p8(this.get_type());if(S)return H[this.excPtr>>2];var W=this.get_adjusted_ptr();return W!==0?W:this.excPtr}}var Jn=0,ls=0;function ao(u,S,W){var P=new Ci(u);P.init(S,W),Jn=u,ls++,c(!1,"Exception thrown, but exception catching is not enabled. Compile with -sNO_DISABLE_EXCEPTION_CATCHING or -sEXCEPTION_CATCHING_ALLOWED=[..] to catch.")}function qi(u,S,W,P,$){}function hn(u){switch(u){case 1:return 0;case 2:return 1;case 4:return 2;case 8:return 3;default:throw new TypeError(`Unknown type size: ${u}`)}}function jo(){for(var u=new Array(256),S=0;S<256;++S)u[S]=String.fromCharCode(S);ds=u}var ds=void 0;function on(u){for(var S="",W=u;V[W];)S+=ds[V[W++]];return S}var ws={},So={},Fr={},Oo=void 0;function $e(u){throw new Oo(u)}var aa=void 0;function Yr(u){throw new aa(u)}function xs(u,S,W){u.forEach(function(ft){Fr[ft]=S});function P(ft){var Bt=W(ft);Bt.length!==u.length&&Yr("Mismatched type converter count");for(var Lt=0;Lt<u.length;++Lt)Tn(u[Lt],Bt[Lt])}var $=new Array(S.length),ht=[],dt=0;S.forEach((ft,Bt)=>{So.hasOwnProperty(ft)?$[Bt]=So[ft]:(ht.push(ft),ws.hasOwnProperty(ft)||(ws[ft]=[]),ws[ft].push(()=>{$[Bt]=So[ft],++dt,dt===ht.length&&P($)}))}),ht.length===0&&P($)}function gs(u,S,W={}){var P=S.name;if(u||$e(`type "${P}" must have a positive integer typeid pointer`),So.hasOwnProperty(u)){if(W.ignoreDuplicateRegistrations)return;$e(`Cannot register type '${P}' twice`)}if(So[u]=S,delete Fr[u],ws.hasOwnProperty(u)){var $=ws[u];delete ws[u],$.forEach(ht=>ht())}}function Tn(u,S,W={}){if(!("argPackAdvance"in S))throw new TypeError("registerType registeredInstance requires argPackAdvance");return gs(u,S,W)}function hr(u,S,W,P,$){var ht=hn(W);S=on(S),Tn(u,{name:S,fromWireType:function(dt){return!!dt},toWireType:function(dt,ft){return ft?P:$},argPackAdvance:8,readValueFromPointer:function(dt){var ft;if(W===1)ft=g;else if(W===2)ft=D;else if(W===4)ft=x;else throw new TypeError("Unknown boolean type size: "+S);return this.fromWireType(ft[dt>>ht])},destructorFunction:null})}function Mh(u){if(!(this instanceof mr)||!(u instanceof mr))return!1;for(var S=this.$$.ptrType.registeredClass,W=this.$$.ptr,P=u.$$.ptrType.registeredClass,$=u.$$.ptr;S.baseClass;)W=S.upcast(W),S=S.baseClass;for(;P.baseClass;)$=P.upcast($),P=P.baseClass;return S===P&&W===$}function Uh(u){return{count:u.count,deleteScheduled:u.deleteScheduled,preservePointerOnDelete:u.preservePointerOnDelete,ptr:u.ptr,ptrType:u.ptrType,smartPtr:u.smartPtr,smartPtrType:u.smartPtrType}}function Vn(u){function S(W){return W.$$.ptrType.registeredClass.name}$e(S(u)+" instance already deleted")}var cr=!1;function Ii(u){}function Vo(u){u.smartPtr?u.smartPtrType.rawDestructor(u.smartPtr):u.ptrType.registeredClass.rawDestructor(u.ptr)}function Kc(u){u.count.value-=1;var S=u.count.value===0;S&&Vo(u)}function Xc(u,S,W){if(S===W)return u;if(W.baseClass===void 0)return null;var P=Xc(u,S,W.baseClass);return P===null?null:W.downcast(P)}var qc={};function Qh(){return Object.keys(Xa).length}function kh(){var u=[];for(var S in Xa)Xa.hasOwnProperty(S)&&u.push(Xa[S]);return u}var Aa=[];function Lh(){for(;Aa.length;){var u=Aa.pop();u.$$.deleteScheduled=!1,u.delete()}}var ha=void 0;function Ka(u){ha=u,Aa.length&&ha&&ha(Lh)}function Sd(){i.getInheritedInstanceCount=Qh,i.getLiveInheritedInstances=kh,i.flushPendingDeletes=Lh,i.setDelayFunction=Ka}var Xa={};function Od(u,S){for(S===void 0&&$e("ptr should not be undefined");u.baseClass;)S=u.upcast(S),u=u.baseClass;return S}function qa(u,S){return S=Od(u,S),Xa[S]}function lr(u,S){(!S.ptrType||!S.ptr)&&Yr("makeClassHandle requires ptr and ptrType");var W=!!S.smartPtrType,P=!!S.smartPtr;return W!==P&&Yr("Both smartPtrType and smartPtr must be specified"),S.count={value:1},$a(Object.create(u,{$$:{value:S}}))}function kA(u){var S=this.getPointee(u);if(!S)return this.destructor(u),null;var W=qa(this.registeredClass,S);if(W!==void 0){if(W.$$.count.value===0)return W.$$.ptr=S,W.$$.smartPtr=u,W.clone();var P=W.clone();return this.destructor(u),P}function $(){return this.isSmartPointer?lr(this.registeredClass.instancePrototype,{ptrType:this.pointeeType,ptr:S,smartPtrType:this,smartPtr:u}):lr(this.registeredClass.instancePrototype,{ptrType:this,ptr:u})}var ht=this.registeredClass.getActualType(S),dt=qc[ht];if(!dt)return $.call(this);var ft;this.isConst?ft=dt.constPointerType:ft=dt.pointerType;var Bt=Xc(S,this.registeredClass,ft.registeredClass);return Bt===null?$.call(this):this.isSmartPointer?lr(ft.registeredClass.instancePrototype,{ptrType:ft,ptr:Bt,smartPtrType:this,smartPtr:u}):lr(ft.registeredClass.instancePrototype,{ptrType:ft,ptr:Bt})}var $a=function(u){return typeof FinalizationRegistry>"u"?($a=S=>S,u):(cr=new FinalizationRegistry(S=>{console.warn(S.leakWarning.stack.replace(/^Error: /,"")),Kc(S.$$)}),$a=S=>{var W=S.$$,P=!!W.smartPtr;if(P){var $={$$:W},ht=W.ptrType.registeredClass;$.leakWarning=new Error(`Embind found a leaked C++ instance ${ht.name} <${Pn(W.ptr)}>.
We'll free it automatically in this case, but this functionality is not reliable across various environments.
Make sure to invoke .delete() manually once you're done with the instance instead.
Originally allocated`),"captureStackTrace"in Error&&Error.captureStackTrace($.leakWarning,kA),cr.register(S,$,S)}return S},Ii=S=>cr.unregister(S),$a(u))};function Vd(){if(this.$$.ptr||Vn(this),this.$$.preservePointerOnDelete)return this.$$.count.value+=1,this;var u=$a(Object.create(Object.getPrototypeOf(this),{$$:{value:Uh(this.$$)}}));return u.$$.count.value+=1,u.$$.deleteScheduled=!1,u}function dr(){this.$$.ptr||Vn(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&$e("Object already scheduled for deletion"),Ii(this),Kc(this.$$),this.$$.preservePointerOnDelete||(this.$$.smartPtr=void 0,this.$$.ptr=void 0)}function $c(){return!this.$$.ptr}function tl(){return this.$$.ptr||Vn(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&$e("Object already scheduled for deletion"),Aa.push(this),Aa.length===1&&ha&&ha(Lh),this.$$.deleteScheduled=!0,this}function yh(){mr.prototype.isAliasOf=Mh,mr.prototype.clone=Vd,mr.prototype.delete=dr,mr.prototype.isDeleted=$c,mr.prototype.deleteLater=tl}function mr(){}var wh=48,Gd=57;function xh(u){if(u===void 0)return"_unknown";u=u.replace(/[^a-zA-Z0-9_]/g,"$");var S=u.charCodeAt(0);return S>=wh&&S<=Gd?`_${u}`:u}function Ph(u,S){return u=xh(u),{[u]:function(){return S.apply(this,arguments)}}[u]}function el(u,S,W){if(u[S].overloadTable===void 0){var P=u[S];u[S]=function(){return u[S].overloadTable.hasOwnProperty(arguments.length)||$e(`Function '${W}' called with an invalid number of arguments (${arguments.length}) - expects one of (${u[S].overloadTable})!`),u[S].overloadTable[arguments.length].apply(this,arguments)},u[S].overloadTable=[],u[S].overloadTable[P.argCount]=P}}function il(u,S,W){i.hasOwnProperty(u)?((W===void 0||i[u].overloadTable!==void 0&&i[u].overloadTable[W]!==void 0)&&$e(`Cannot register public name '${u}' twice`),el(i,u,u),i.hasOwnProperty(W)&&$e(`Cannot register multiple overloads of a function with the same number of arguments (${W})!`),i[u].overloadTable[W]=S):(i[u]=S,W!==void 0&&(i[u].numArguments=W))}function Bd(u,S,W,P,$,ht,dt,ft){this.name=u,this.constructor=S,this.instancePrototype=W,this.rawDestructor=P,this.baseClass=$,this.getActualType=ht,this.upcast=dt,this.downcast=ft,this.pureVirtualFunctions=[]}function tA(u,S,W){for(;S!==W;)S.upcast||$e(`Expected null or instance of ${W.name}, got an instance of ${S.name}`),u=S.upcast(u),S=S.baseClass;return u}function Wd(u,S){if(S===null)return this.isReference&&$e(`null is not a valid ${this.name}`),0;S.$$||$e(`Cannot pass "${la(S)}" as a ${this.name}`),S.$$.ptr||$e(`Cannot pass deleted object as a pointer of type ${this.name}`);var W=S.$$.ptrType.registeredClass,P=tA(S.$$.ptr,W,this.registeredClass);return P}function Dd(u,S){var W;if(S===null)return this.isReference&&$e(`null is not a valid ${this.name}`),this.isSmartPointer?(W=this.rawConstructor(),u!==null&&u.push(this.rawDestructor,W),W):0;S.$$||$e(`Cannot pass "${la(S)}" as a ${this.name}`),S.$$.ptr||$e(`Cannot pass deleted object as a pointer of type ${this.name}`),!this.isConst&&S.$$.ptrType.isConst&&$e(`Cannot convert argument of type ${S.$$.smartPtrType?S.$$.smartPtrType.name:S.$$.ptrType.name} to parameter type ${this.name}`);var P=S.$$.ptrType.registeredClass;if(W=tA(S.$$.ptr,P,this.registeredClass),this.isSmartPointer)switch(S.$$.smartPtr===void 0&&$e("Passing raw pointer to smart pointer is illegal"),this.sharingPolicy){case 0:S.$$.smartPtrType===this?W=S.$$.smartPtr:$e(`Cannot convert argument of type ${S.$$.smartPtrType?S.$$.smartPtrType.name:S.$$.ptrType.name} to parameter type ${this.name}`);break;case 1:W=S.$$.smartPtr;break;case 2:if(S.$$.smartPtrType===this)W=S.$$.smartPtr;else{var $=S.clone();W=this.rawShare(W,Go.toHandle(function(){$.delete()})),u!==null&&u.push(this.rawDestructor,W)}break;default:$e("Unsupporting sharing policy")}return W}function Md(u,S){if(S===null)return this.isReference&&$e(`null is not a valid ${this.name}`),0;S.$$||$e(`Cannot pass "${la(S)}" as a ${this.name}`),S.$$.ptr||$e(`Cannot pass deleted object as a pointer of type ${this.name}`),S.$$.ptrType.isConst&&$e(`Cannot convert argument of type ${S.$$.ptrType.name} to parameter type ${this.name}`);var W=S.$$.ptrType.registeredClass,P=tA(S.$$.ptr,W,this.registeredClass);return P}function LA(u){return this.fromWireType(x[u>>2])}function eA(u){return this.rawGetPointee&&(u=this.rawGetPointee(u)),u}function Ud(u){this.rawDestructor&&this.rawDestructor(u)}function Qd(u){u!==null&&u.delete()}function yA(){Ho.prototype.getPointee=eA,Ho.prototype.destructor=Ud,Ho.prototype.argPackAdvance=8,Ho.prototype.readValueFromPointer=LA,Ho.prototype.deleteObject=Qd,Ho.prototype.fromWireType=kA}function Ho(u,S,W,P,$,ht,dt,ft,Bt,Lt,re){this.name=u,this.registeredClass=S,this.isReference=W,this.isConst=P,this.isSmartPointer=$,this.pointeeType=ht,this.sharingPolicy=dt,this.rawGetPointee=ft,this.rawConstructor=Bt,this.rawShare=Lt,this.rawDestructor=re,!$&&S.baseClass===void 0?P?(this.toWireType=Wd,this.destructorFunction=null):(this.toWireType=Md,this.destructorFunction=null):this.toWireType=Dd}function nl(u,S,W){i.hasOwnProperty(u)||Yr("Replacing nonexistant public symbol"),i[u].overloadTable!==void 0&&W!==void 0?i[u].overloadTable[W]=S:(i[u]=S,i[u].argCount=W)}var vo=(u,S,W)=>{c("dynCall_"+u in i,`bad function pointer type - dynCall function not found for sig '${u}'`),W&&W.length?c(W.length===u.substring(1).replace(/j/g,"--").length):c(u.length==1);var P=i["dynCall_"+u];return W&&W.length?P.apply(null,[S].concat(W)):P.call(null,S)},iA=[],Jh=u=>{var S=iA[u];return S||(u>=iA.length&&(iA.length=u+1),iA[u]=S=B.get(u)),c(B.get(u)==S,"JavaScript-side Wasm function table mirror is out of date!"),S},kd=(u,S,W)=>{if(u.includes("j"))return vo(u,S,W);c(Jh(S),`missing table entry in dynCall: ${S}`);var P=Jh(S).apply(null,W);return P},Ld=(u,S)=>{c(u.includes("j")||u.includes("p"),"getDynCaller should only be called with i64 sigs");var W=[];return function(){return W.length=0,Object.assign(W,arguments),kd(u,S,W)}};function jn(u,S){u=on(u);function W(){return u.includes("j")?Ld(u,S):Jh(S)}var P=W();return typeof P!="function"&&$e(`unknown function pointer with signature ${u}: ${S}`),P}function sl(u,S){var W=Ph(S,function(P){this.name=S,this.message=P;var $=new Error(P).stack;$!==void 0&&(this.stack=this.toString()+`
`+$.replace(/^Error(:[^\n]*)?\n/,""))});return W.prototype=Object.create(u.prototype),W.prototype.constructor=W,W.prototype.toString=function(){return this.message===void 0?this.name:`${this.name}: ${this.message}`},W}var jh=void 0;function nA(u){var S=m8(u),W=on(S);return HA(S),W}function ca(u,S){var W=[],P={};function $(ht){if(!P[ht]&&!So[ht]){if(Fr[ht]){Fr[ht].forEach($);return}W.push(ht),P[ht]=!0}}throw S.forEach($),new jh(`${u}: `+W.map(nA).join([", "]))}function Hh(u,S,W,P,$,ht,dt,ft,Bt,Lt,re,ue,fe){re=on(re),ht=jn($,ht),ft&&(ft=jn(dt,ft)),Lt&&(Lt=jn(Bt,Lt)),fe=jn(ue,fe);var Ee=xh(re);il(Ee,function(){ca(`Cannot construct ${re} due to unbound types`,[P])}),xs([u,S,W],P?[P]:[],function(Se){Se=Se[0];var di,ln;P?(di=Se.registeredClass,ln=di.instancePrototype):ln=mr.prototype;var Rn=Ph(Ee,function(){if(Object.getPrototypeOf(this)!==qt)throw new Oo("Use 'new' to construct "+re);if(Fe.constructor_body===void 0)throw new Oo(re+" has no accessible constructor");var ms=Fe.constructor_body[arguments.length];if(ms===void 0)throw new Oo(`Tried to invoke ctor of ${re} with invalid number of parameters (${arguments.length}) - expected (${Object.keys(Fe.constructor_body).toString()}) parameters instead!`);return ms.apply(this,arguments)}),qt=Object.create(ln,{constructor:{value:Rn}});Rn.prototype=qt;var Fe=new Bd(re,Rn,qt,fe,di,ht,ft,Lt);Fe.baseClass&&(Fe.baseClass.__derivedClasses===void 0&&(Fe.baseClass.__derivedClasses=[]),Fe.baseClass.__derivedClasses.push(Fe));var Ts=new Ho(re,Fe,!0,!1,!1),Zn=new Ho(re+"*",Fe,!1,!1,!1),Ko=new Ho(re+" const*",Fe,!1,!0,!1);return qc[u]={pointerType:Zn,constPointerType:Ko},nl(Ee,Rn),[Ts,Zn,Ko]})}function vh(u,S){for(var W=[],P=0;P<u;P++)W.push(H[S+P*4>>2]);return W}function wA(u){for(;u.length;){var S=u.pop(),W=u.pop();W(S)}}function ol(u,S){if(!(u instanceof Function))throw new TypeError(`new_ called with constructor type ${typeof u} which is not a function`);var W=Ph(u.name||"unknownFunctionName",function(){});W.prototype=u.prototype;var P=new W,$=u.apply(P,S);return $ instanceof Object?$:P}function zh(u,S,W,P,$,ht){var dt=S.length;dt<2&&$e("argTypes array size mismatch! Must at least get return value and 'this' types!"),c(!ht,"Async bindings are only supported with JSPI.");for(var ft=S[1]!==null&&W!==null,Bt=!1,Lt=1;Lt<S.length;++Lt)if(S[Lt]!==null&&S[Lt].destructorFunction===void 0){Bt=!0;break}for(var re=S[0].name!=="void",ue="",fe="",Lt=0;Lt<dt-2;++Lt)ue+=(Lt!==0?", ":"")+"arg"+Lt,fe+=(Lt!==0?", ":"")+"arg"+Lt+"Wired";var Ee=`
        return function ${xh(u)}(${ue}) {
        if (arguments.length !== ${dt-2}) {
          throwBindingError('function ${u} called with ${arguments.length} arguments, expected ${dt-2} args!');
        }`;Bt&&(Ee+=`var destructors = [];
`);var Se=Bt?"destructors":"null",di=["throwBindingError","invoker","fn","runDestructors","retType","classParam"],ln=[$e,P,$,wA,S[0],S[1]];ft&&(Ee+="var thisWired = classParam.toWireType("+Se+`, this);
`);for(var Lt=0;Lt<dt-2;++Lt)Ee+="var arg"+Lt+"Wired = argType"+Lt+".toWireType("+Se+", arg"+Lt+"); // "+S[Lt+2].name+`
`,di.push("argType"+Lt),ln.push(S[Lt+2]);if(ft&&(fe="thisWired"+(fe.length>0?", ":"")+fe),Ee+=(re||ht?"var rv = ":"")+"invoker(fn"+(fe.length>0?", ":"")+fe+`);
`,Bt)Ee+=`runDestructors(destructors);
`;else for(var Lt=ft?1:2;Lt<S.length;++Lt){var Rn=Lt===1?"thisWired":"arg"+(Lt-2)+"Wired";S[Lt].destructorFunction!==null&&(Ee+=Rn+"_dtor("+Rn+"); // "+S[Lt].name+`
`,di.push(Rn+"_dtor"),ln.push(S[Lt].destructorFunction))}return re&&(Ee+=`var ret = retType.fromWireType(rv);
return ret;
`),Ee+=`}
`,di.push(Ee),ol(Function,di).apply(null,ln)}function yd(u,S,W,P,$,ht){c(S>0);var dt=vh(S,W);$=jn(P,$),xs([],[u],function(ft){ft=ft[0];var Bt=`constructor ${ft.name}`;if(ft.registeredClass.constructor_body===void 0&&(ft.registeredClass.constructor_body=[]),ft.registeredClass.constructor_body[S-1]!==void 0)throw new Oo(`Cannot register multiple constructors with identical number of parameters (${S-1}) for class '${ft.name}'! Overload resolution is currently only performed using the parameter count, not actual type info!`);return ft.registeredClass.constructor_body[S-1]=()=>{ca(`Cannot construct ${ft.name} due to unbound types`,dt)},xs([],dt,function(Lt){return Lt.splice(1,0,null),ft.registeredClass.constructor_body[S-1]=zh(Bt,Lt,null,$,ht),[]}),[]})}function Kh(u,S,W,P,$,ht,dt,ft,Bt){var Lt=vh(W,P);S=on(S),ht=jn($,ht),xs([],[u],function(re){re=re[0];var ue=`${re.name}.${S}`;S.startsWith("@@")&&(S=Symbol[S.substring(2)]),ft&&re.registeredClass.pureVirtualFunctions.push(S);function fe(){ca(`Cannot call ${ue} due to unbound types`,Lt)}var Ee=re.registeredClass.instancePrototype,Se=Ee[S];return Se===void 0||Se.overloadTable===void 0&&Se.className!==re.name&&Se.argCount===W-2?(fe.argCount=W-2,fe.className=re.name,Ee[S]=fe):(el(Ee,S,ue),Ee[S].overloadTable[W-2]=fe),xs([],Lt,function(di){var ln=zh(ue,di,re,ht,dt,Bt);return Ee[S].overloadTable===void 0?(ln.argCount=W-2,Ee[S]=ln):Ee[S].overloadTable[W-2]=ln,[]}),[]})}function Ss(u,S,W){return u instanceof Object||$e(`${W} with invalid "this": ${u}`),u instanceof S.registeredClass.constructor||$e(`${W} incompatible with "this" of type ${u.constructor.name}`),u.$$.ptr||$e(`cannot call emscripten binding method ${W} on deleted object`),tA(u.$$.ptr,u.$$.ptrType.registeredClass,S.registeredClass)}function Xh(u,S,W,P,$,ht,dt,ft,Bt,Lt){S=on(S),$=jn(P,$),xs([],[u],function(re){re=re[0];var ue=`${re.name}.${S}`,fe={get(){ca(`Cannot access ${ue} due to unbound types`,[W,dt])},enumerable:!0,configurable:!0};return Bt?fe.set=()=>{ca(`Cannot access ${ue} due to unbound types`,[W,dt])}:fe.set=Ee=>{$e(ue+" is a read-only property")},Object.defineProperty(re.registeredClass.instancePrototype,S,fe),xs([],Bt?[W,dt]:[W],function(Ee){var Se=Ee[0],di={get(){var Rn=Ss(this,re,ue+" getter");return Se.fromWireType($(ht,Rn))},enumerable:!0};if(Bt){Bt=jn(ft,Bt);var ln=Ee[1];di.set=function(Rn){var qt=Ss(this,re,ue+" setter"),Fe=[];Bt(Lt,qt,ln.toWireType(Fe,Rn)),wA(Fe)}}return Object.defineProperty(re.registeredClass.instancePrototype,S,di),[]}),[]})}function wd(){Object.assign(rl.prototype,{get(u){return c(this.allocated[u]!==void 0,`invalid handle: ${u}`),this.allocated[u]},has(u){return this.allocated[u]!==void 0},allocate(u){var S=this.freelist.pop()||this.allocated.length;return this.allocated[S]=u,S},free(u){c(this.allocated[u]!==void 0),this.allocated[u]=void 0,this.freelist.push(u)}})}function rl(){this.allocated=[void 0],this.freelist=[]}var Ao=new rl;function ho(u){u>=Ao.reserved&&--Ao.get(u).refcount===0&&Ao.free(u)}function xd(){for(var u=0,S=Ao.reserved;S<Ao.allocated.length;++S)Ao.allocated[S]!==void 0&&++u;return u}function Pd(){Ao.allocated.push({value:void 0},{value:null},{value:!0},{value:!1}),Ao.reserved=Ao.allocated.length,i.count_emval_handles=xd}var Go={toValue:u=>(u||$e("Cannot use deleted val. handle = "+u),Ao.get(u).value),toHandle:u=>{switch(u){case void 0:return 1;case null:return 2;case!0:return 3;case!1:return 4;default:return Ao.allocate({refcount:1,value:u})}}};function xA(u,S){S=on(S),Tn(u,{name:S,fromWireType:function(W){var P=Go.toValue(W);return ho(W),P},toWireType:function(W,P){return Go.toHandle(P)},argPackAdvance:8,readValueFromPointer:LA,destructorFunction:null})}function la(u){if(u===null)return"null";var S=typeof u;return S==="object"||S==="array"||S==="function"?u.toString():""+u}function da(u,S){switch(S){case 2:return function(W){return this.fromWireType(j[W>>2])};case 3:return function(W){return this.fromWireType(X[W>>3])};default:throw new TypeError("Unknown float type: "+u)}}function Jd(u,S,W){var P=hn(W);S=on(S),Tn(u,{name:S,fromWireType:function($){return $},toWireType:function($,ht){if(typeof ht!="number"&&typeof ht!="boolean")throw new TypeError(`Cannot convert ${la(ht)} to ${this.name}`);return ht},argPackAdvance:8,readValueFromPointer:da(S,P),destructorFunction:null})}function jd(u,S,W,P,$,ht,dt){var ft=vh(S,W);u=on(u),$=jn(P,$),il(u,function(){ca(`Cannot call ${u} due to unbound types`,ft)},S-1),xs([],ft,function(Bt){var Lt=[Bt[0],null].concat(Bt.slice(1));return nl(u,zh(u,Lt,null,$,ht,dt),S-1),[]})}function Hd(u,S,W){switch(S){case 0:return W?function($){return g[$]}:function($){return V[$]};case 1:return W?function($){return D[$>>1]}:function($){return w[$>>1]};case 2:return W?function($){return x[$>>2]}:function($){return H[$>>2]};default:throw new TypeError("Unknown integer type: "+u)}}function vd(u,S,W,P,$){S=on(S),$===-1&&($=4294967295);var ht=hn(W),dt=ue=>ue;if(P===0){var ft=32-8*W;dt=ue=>ue<<ft>>>ft}var Bt=S.includes("unsigned"),Lt=(ue,fe)=>{if(typeof ue!="number"&&typeof ue!="boolean")throw new TypeError(`Cannot convert "${la(ue)}" to ${fe}`);if(ue<P||ue>$)throw new TypeError(`Passing a number "${la(ue)}" from JS side to C/C++ side to an argument of type "${S}", which is outside the valid range [${P}, ${$}]!`)},re;Bt?re=function(ue,fe){return Lt(fe,this.name),fe>>>0}:re=function(ue,fe){return Lt(fe,this.name),fe},Tn(u,{name:S,fromWireType:dt,toWireType:re,argPackAdvance:8,readValueFromPointer:Hd(S,ht,P!==0),destructorFunction:null})}function zd(u,S,W){var P=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],$=P[S];function ht(dt){dt=dt>>2;var ft=H,Bt=ft[dt],Lt=ft[dt+1];return new $(ft.buffer,Lt,Bt)}W=on(W),Tn(u,{name:W,fromWireType:ht,argPackAdvance:8,readValueFromPointer:ht},{ignoreDuplicateRegistrations:!0})}var qh=(u,S,W,P)=>{if(c(typeof u=="string"),!(P>0))return 0;for(var $=W,ht=W+P-1,dt=0;dt<u.length;++dt){var ft=u.charCodeAt(dt);if(ft>=55296&&ft<=57343){var Bt=u.charCodeAt(++dt);ft=65536+((ft&1023)<<10)|Bt&1023}if(ft<=127){if(W>=ht)break;S[W++]=ft}else if(ft<=2047){if(W+1>=ht)break;S[W++]=192|ft>>6,S[W++]=128|ft&63}else if(ft<=65535){if(W+2>=ht)break;S[W++]=224|ft>>12,S[W++]=128|ft>>6&63,S[W++]=128|ft&63}else{if(W+3>=ht)break;ft>1114111&&Ai("Invalid Unicode code point "+Pn(ft)+" encountered when serializing a JS string to a UTF-8 string in wasm memory! (Valid unicode code points should be in range 0-0x10FFFF)."),S[W++]=240|ft>>18,S[W++]=128|ft>>12&63,S[W++]=128|ft>>6&63,S[W++]=128|ft&63}}return S[W]=0,W-$},PA=(u,S,W)=>(c(typeof W=="number","stringToUTF8(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),qh(u,V,S,W)),ma=u=>{for(var S=0,W=0;W<u.length;++W){var P=u.charCodeAt(W);P<=127?S++:P<=2047?S+=2:P>=55296&&P<=57343?(S+=4,++W):S+=3}return S},al=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,fa=(u,S,W)=>{for(var P=S+W,$=S;u[$]&&!($>=P);)++$;if($-S>16&&u.buffer&&al)return al.decode(u.subarray(S,$));for(var ht="";S<$;){var dt=u[S++];if(!(dt&128)){ht+=String.fromCharCode(dt);continue}var ft=u[S++]&63;if((dt&224)==192){ht+=String.fromCharCode((dt&31)<<6|ft);continue}var Bt=u[S++]&63;if((dt&240)==224?dt=(dt&15)<<12|ft<<6|Bt:((dt&248)!=240&&Ai("Invalid UTF-8 leading byte "+Pn(dt)+" encountered when deserializing a UTF-8 string in wasm memory to a JS string!"),dt=(dt&7)<<18|ft<<12|Bt<<6|u[S++]&63),dt<65536)ht+=String.fromCharCode(dt);else{var Lt=dt-65536;ht+=String.fromCharCode(55296|Lt>>10,56320|Lt&1023)}}return ht},Ea=(u,S)=>(c(typeof u=="number"),u?fa(V,u,S):"");function sA(u,S){S=on(S);var W=S==="std::string";Tn(u,{name:S,fromWireType:function(P){var $=H[P>>2],ht=P+4,dt;if(W)for(var ft=ht,Bt=0;Bt<=$;++Bt){var Lt=ht+Bt;if(Bt==$||V[Lt]==0){var re=Lt-ft,ue=Ea(ft,re);dt===void 0?dt=ue:(dt+="\0",dt+=ue),ft=Lt+1}}else{for(var fe=new Array($),Bt=0;Bt<$;++Bt)fe[Bt]=String.fromCharCode(V[ht+Bt]);dt=fe.join("")}return HA(P),dt},toWireType:function(P,$){$ instanceof ArrayBuffer&&($=new Uint8Array($));var ht,dt=typeof $=="string";dt||$ instanceof Uint8Array||$ instanceof Uint8ClampedArray||$ instanceof Int8Array||$e("Cannot pass non-string to std::string"),W&&dt?ht=ma($):ht=$.length;var ft=KR(4+ht+1),Bt=ft+4;if(H[ft>>2]=ht,W&&dt)PA($,Bt,ht+1);else if(dt)for(var Lt=0;Lt<ht;++Lt){var re=$.charCodeAt(Lt);re>255&&(HA(Bt),$e("String has UTF-16 code units that do not fit in 8 bits")),V[Bt+Lt]=re}else for(var Lt=0;Lt<ht;++Lt)V[Bt+Lt]=$[Lt];return P!==null&&P.push(HA,ft),ft},argPackAdvance:8,readValueFromPointer:LA,destructorFunction:function(P){HA(P)}})}var Al=typeof TextDecoder<"u"?new TextDecoder("utf-16le"):void 0,Kd=(u,S)=>{c(u%2==0,"Pointer passed to UTF16ToString must be aligned to two bytes!");for(var W=u,P=W>>1,$=P+S/2;!(P>=$)&&w[P];)++P;if(W=P<<1,W-u>32&&Al)return Al.decode(V.subarray(u,W));for(var ht="",dt=0;!(dt>=S/2);++dt){var ft=D[u+dt*2>>1];if(ft==0)break;ht+=String.fromCharCode(ft)}return ht},JA=(u,S,W)=>{if(c(S%2==0,"Pointer passed to stringToUTF16 must be aligned to two bytes!"),c(typeof W=="number","stringToUTF16(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),W===void 0&&(W=2147483647),W<2)return 0;W-=2;for(var P=S,$=W<u.length*2?W/2:u.length,ht=0;ht<$;++ht){var dt=u.charCodeAt(ht);D[S>>1]=dt,S+=2}return D[S>>1]=0,S-P},$h=u=>u.length*2,Xd=(u,S)=>{c(u%4==0,"Pointer passed to UTF32ToString must be aligned to four bytes!");for(var W=0,P="";!(W>=S/4);){var $=x[u+W*4>>2];if($==0)break;if(++W,$>=65536){var ht=$-65536;P+=String.fromCharCode(55296|ht>>10,56320|ht&1023)}else P+=String.fromCharCode($)}return P},hl=(u,S,W)=>{if(c(S%4==0,"Pointer passed to stringToUTF32 must be aligned to four bytes!"),c(typeof W=="number","stringToUTF32(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),W===void 0&&(W=2147483647),W<4)return 0;for(var P=S,$=P+W-4,ht=0;ht<u.length;++ht){var dt=u.charCodeAt(ht);if(dt>=55296&&dt<=57343){var ft=u.charCodeAt(++ht);dt=65536+((dt&1023)<<10)|ft&1023}if(x[S>>2]=dt,S+=4,S+4>$)break}return x[S>>2]=0,S-P},qd=u=>{for(var S=0,W=0;W<u.length;++W){var P=u.charCodeAt(W);P>=55296&&P<=57343&&++W,S+=4}return S},$d=function(u,S,W){W=on(W);var P,$,ht,dt,ft;S===2?(P=Kd,$=JA,dt=$h,ht=()=>w,ft=1):S===4&&(P=Xd,$=hl,dt=qd,ht=()=>H,ft=2),Tn(u,{name:W,fromWireType:function(Bt){for(var Lt=H[Bt>>2],re=ht(),ue,fe=Bt+4,Ee=0;Ee<=Lt;++Ee){var Se=Bt+4+Ee*S;if(Ee==Lt||re[Se>>ft]==0){var di=Se-fe,ln=P(fe,di);ue===void 0?ue=ln:(ue+="\0",ue+=ln),fe=Se+S}}return HA(Bt),ue},toWireType:function(Bt,Lt){typeof Lt!="string"&&$e(`Cannot pass non-string to C++ string type ${W}`);var re=dt(Lt),ue=KR(4+re+S);return H[ue>>2]=re>>ft,$(Lt,ue+4,re+S),Bt!==null&&Bt.push(HA,ue),ue},argPackAdvance:8,readValueFromPointer:LA,destructorFunction:function(Bt){HA(Bt)}})};function tm(u,S){S=on(S),Tn(u,{isVoid:!0,name:S,argPackAdvance:0,fromWireType:function(){},toWireType:function(W,P){}})}var em=!0,im=()=>em;function nm(u,S){var W=So[u];return W===void 0&&$e(S+" has unknown type "+nA(u)),W}function sm(u,S,W){u=Go.toValue(u),S=nm(S,"emval::as");var P=[],$=Go.toHandle(P);return H[W>>2]=$,S.toWireType(P,u)}function om(u,S){return u=Go.toValue(u),S=Go.toValue(S),Go.toHandle(u[S])}var cl={};function rm(u){var S=cl[u];return S===void 0?on(u):S}function am(u){return Go.toHandle(rm(u))}function Am(u){var S=Go.toValue(u);wA(S),ho(u)}function ll(u,S){return c(u==u>>>0||u==(u|0)),c(S===(S|0)),S+2097152>>>0<4194305-!!u?(u>>>0)+S*4294967296:NaN}function hm(u,S,W){var P=ll(u,S),$=new Date(P*1e3);x[W>>2]=$.getUTCSeconds(),x[W+4>>2]=$.getUTCMinutes(),x[W+8>>2]=$.getUTCHours(),x[W+12>>2]=$.getUTCDate(),x[W+16>>2]=$.getUTCMonth(),x[W+20>>2]=$.getUTCFullYear()-1900,x[W+24>>2]=$.getUTCDay();var ht=Date.UTC($.getUTCFullYear(),0,1,0,0,0,0),dt=($.getTime()-ht)/(1e3*60*60*24)|0;x[W+28>>2]=dt}var oA=u=>u%4===0&&(u%100!==0||u%400===0),cm=[0,31,60,91,121,152,182,213,244,274,305,335],jA=[0,31,59,90,120,151,181,212,243,273,304,334],lm=u=>{var S=oA(u.getFullYear()),W=S?cm:jA,P=W[u.getMonth()]+u.getDate()-1;return P},dm=function(u){var S=(()=>{var W=new Date(x[u+20>>2]+1900,x[u+16>>2],x[u+12>>2],x[u+8>>2],x[u+4>>2],x[u>>2],0),P=x[u+32>>2],$=W.getTimezoneOffset(),ht=new Date(W.getFullYear(),0,1),dt=new Date(W.getFullYear(),6,1).getTimezoneOffset(),ft=ht.getTimezoneOffset(),Bt=Math.min(ft,dt);if(P<0)x[u+32>>2]=+(dt!=ft&&Bt==$);else if(P>0!=(Bt==$)){var Lt=Math.max(ft,dt),re=P>0?Bt:Lt;W.setTime(W.getTime()+(re-$)*6e4)}x[u+24>>2]=W.getDay();var ue=lm(W)|0;return x[u+28>>2]=ue,x[u>>2]=W.getSeconds(),x[u+4>>2]=W.getMinutes(),x[u+8>>2]=W.getHours(),x[u+12>>2]=W.getDate(),x[u+16>>2]=W.getMonth(),x[u+20>>2]=W.getYear(),W.getTime()/1e3})();return f8((Ne=S,+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)),S>>>0},dl=u=>{var S=ma(u)+1,W=KR(S);return W&&PA(u,W,S),W},mm=(u,S,W)=>{var P=new Date().getFullYear(),$=new Date(P,0,1),ht=new Date(P,6,1),dt=$.getTimezoneOffset(),ft=ht.getTimezoneOffset(),Bt=Math.max(dt,ft);H[u>>2]=Bt*60,x[S>>2]=+(dt!=ft);function Lt(Se){var di=Se.toTimeString().match(/\(([A-Za-z ]+)\)$/);return di?di[1]:"GMT"}var re=Lt($),ue=Lt(ht),fe=dl(re),Ee=dl(ue);ft<dt?(H[W>>2]=fe,H[W+4>>2]=Ee):(H[W>>2]=Ee,H[W+4>>2]=fe)},fm=()=>{Ge("native code called abort()")},rA=[],fi=(u,S)=>{c(Array.isArray(rA)),c(S%16==0),rA.length=0;var W;for(S>>=2;W=V[u++];){var P=String.fromCharCode(W),$=["d","f","i"];c($.includes(P),`Invalid character ${W}("${P}") in readEmAsmArgs! Use only [${$}], and do not specify "v" for void return argument.`),S+=W!=105&S,rA.push(W==105?x[S]:X[S++>>1]),++S}return rA},z=(u,S,W)=>{var P=fi(S,W);return Cs.hasOwnProperty(u)||Ge(`No EM_ASM constant found at address ${u}`),Cs[u].apply(null,P)},et=(u,S,W)=>z(u,S,W);function pt(){return Date.now()}var $t;$t=()=>performance.now();var ve=(u,S,W)=>V.copyWithin(u,S,S+W),hi=()=>2147483648,_a=u=>{var S=Q.buffer,W=u-S.byteLength+65535>>>16;try{return Q.grow(W),tt(),1}catch(P){b(`growMemory: Attempted to grow heap from ${S.byteLength} bytes to ${u} bytes, but got error: ${P}`)}},tc=u=>{var S=V.length;u>>>=0,c(u>S);var W=hi();if(u>W)return b(`Cannot enlarge memory, asked to go up to ${u} bytes, but the limit is ${W} bytes!`),!1;for(var P=(Bt,Lt)=>Bt+(Lt-Bt%Lt)%Lt,$=1;$<=4;$*=2){var ht=S*(1+.2/$);ht=Math.min(ht,u+100663296);var dt=Math.min(W,P(Math.max(u,ht),65536)),ft=_a(dt);if(ft)return!0}return b(`Failed to grow the heap from ${S} bytes to ${dt} bytes, not enough memory!`),!1},J=u=>{var S=(globalThis.eval["\u2003"]=globalThis.eval)(Ea(u));if(S==null)return 0;S+="";var W=J,P=ma(S);return(!W.bufferSize||W.bufferSize<P+1)&&(W.bufferSize&&HA(W.buffer),W.bufferSize=P+1,W.buffer=KR(W.bufferSize)),PA(S,W.buffer,W.bufferSize),W.buffer},v={},st=()=>a||"./this.program",Rt=()=>{if(!Rt.strings){var u=(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",S={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:u,_:st()};for(var W in v)v[W]===void 0?delete S[W]:S[W]=v[W];var P=[];for(var W in S)P.push(`${W}=${S[W]}`);Rt.strings=P}return Rt.strings},St=(u,S)=>{for(var W=0;W<u.length;++W)c(u.charCodeAt(W)===(u.charCodeAt(W)&255)),g[S++>>0]=u.charCodeAt(W);g[S>>0]=0},Gt={isAbs:u=>u.charAt(0)==="/",splitPath:u=>{var S=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;return S.exec(u).slice(1)},normalizeArray:(u,S)=>{for(var W=0,P=u.length-1;P>=0;P--){var $=u[P];$==="."?u.splice(P,1):$===".."?(u.splice(P,1),W++):W&&(u.splice(P,1),W--)}if(S)for(;W;W--)u.unshift("..");return u},normalize:u=>{var S=Gt.isAbs(u),W=u.substr(-1)==="/";return u=Gt.normalizeArray(u.split("/").filter(P=>!!P),!S).join("/"),!u&&!S&&(u="."),u&&W&&(u+="/"),(S?"/":"")+u},dirname:u=>{var S=Gt.splitPath(u),W=S[0],P=S[1];return!W&&!P?".":(P&&(P=P.substr(0,P.length-1)),W+P)},basename:u=>{if(u==="/")return"/";u=Gt.normalize(u),u=u.replace(/\/$/,"");var S=u.lastIndexOf("/");return S===-1?u:u.substr(S+1)},join:function(){var u=Array.prototype.slice.call(arguments);return Gt.normalize(u.join("/"))},join2:(u,S)=>Gt.normalize(u+"/"+S)},jt=()=>{if(typeof crypto=="object"&&typeof crypto.getRandomValues=="function")return u=>crypto.getRandomValues(u);Ge("no cryptographic support found for randomDevice. consider polyfilling it if you want to use something insecure like Math.random(), e.g. put this in a --pre-js: var crypto = { getRandomValues: (array) => { for (var i = 0; i < array.length; i++) array[i] = (Math.random()*256)|0 } };")},Ut=u=>(Ut=jt())(u),Dt={resolve:function(){for(var u="",S=!1,W=arguments.length-1;W>=-1&&!S;W--){var P=W>=0?arguments[W]:K.cwd();if(typeof P!="string")throw new TypeError("Arguments to path.resolve must be strings");if(!P)return"";u=P+"/"+u,S=Gt.isAbs(P)}return u=Gt.normalizeArray(u.split("/").filter($=>!!$),!S).join("/"),(S?"/":"")+u||"."},relative:(u,S)=>{u=Dt.resolve(u).substr(1),S=Dt.resolve(S).substr(1);function W(Lt){for(var re=0;re<Lt.length&&Lt[re]==="";re++);for(var ue=Lt.length-1;ue>=0&&Lt[ue]==="";ue--);return re>ue?[]:Lt.slice(re,ue-re+1)}for(var P=W(u.split("/")),$=W(S.split("/")),ht=Math.min(P.length,$.length),dt=ht,ft=0;ft<ht;ft++)if(P[ft]!==$[ft]){dt=ft;break}for(var Bt=[],ft=dt;ft<P.length;ft++)Bt.push("..");return Bt=Bt.concat($.slice(dt)),Bt.join("/")}},pe=[];function Be(u,S,W){var P=W>0?W:ma(u)+1,$=new Array(P),ht=qh(u,$,0,$.length);return S&&($.length=ht),$}var ci=()=>{if(!pe.length){var u=null;if(typeof window<"u"&&typeof window.prompt=="function"?(u=window.prompt("Input: "),u!==null&&(u+=`
`)):typeof readline=="function"&&(u=readline(),u!==null&&(u+=`
`)),!u)return null;pe=Be(u,!0)}return pe.shift()},pi={ttys:[],init:function(){},shutdown:function(){},register:function(u,S){pi.ttys[u]={input:[],output:[],ops:S},K.registerDevice(u,pi.stream_ops)},stream_ops:{open:function(u){var S=pi.ttys[u.node.rdev];if(!S)throw new K.ErrnoError(43);u.tty=S,u.seekable=!1},close:function(u){u.tty.ops.fsync(u.tty)},fsync:function(u){u.tty.ops.fsync(u.tty)},read:function(u,S,W,P,$){if(!u.tty||!u.tty.ops.get_char)throw new K.ErrnoError(60);for(var ht=0,dt=0;dt<P;dt++){var ft;try{ft=u.tty.ops.get_char(u.tty)}catch{throw new K.ErrnoError(29)}if(ft===void 0&&ht===0)throw new K.ErrnoError(6);if(ft==null)break;ht++,S[W+dt]=ft}return ht&&(u.node.timestamp=Date.now()),ht},write:function(u,S,W,P,$){if(!u.tty||!u.tty.ops.put_char)throw new K.ErrnoError(60);try{for(var ht=0;ht<P;ht++)u.tty.ops.put_char(u.tty,S[W+ht])}catch{throw new K.ErrnoError(29)}return P&&(u.node.timestamp=Date.now()),ht}},default_tty_ops:{get_char:function(u){return ci()},put_char:function(u,S){S===null||S===10?(F(fa(u.output,0)),u.output=[]):S!=0&&u.output.push(S)},fsync:function(u){u.output&&u.output.length>0&&(F(fa(u.output,0)),u.output=[])},ioctl_tcgets:function(u){return{c_iflag:25856,c_oflag:5,c_cflag:191,c_lflag:35387,c_cc:[3,28,127,21,4,0,1,0,17,19,26,0,18,15,23,22,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]}},ioctl_tcsets:function(u,S,W){return 0},ioctl_tiocgwinsz:function(u){return[24,80]}},default_tty1_ops:{put_char:function(u,S){S===null||S===10?(b(fa(u.output,0)),u.output=[]):S!=0&&u.output.push(S)},fsync:function(u){u.output&&u.output.length>0&&(b(fa(u.output,0)),u.output=[])}}},cn=u=>{Ge("internal error: mmapAlloc called but `emscripten_builtin_memalign` native symbol not exported")},Qe={ops_table:null,mount(u){return Qe.createNode(null,"/",16895,0)},createNode(u,S,W,P){if(K.isBlkdev(W)||K.isFIFO(W))throw new K.ErrnoError(63);Qe.ops_table||(Qe.ops_table={dir:{node:{getattr:Qe.node_ops.getattr,setattr:Qe.node_ops.setattr,lookup:Qe.node_ops.lookup,mknod:Qe.node_ops.mknod,rename:Qe.node_ops.rename,unlink:Qe.node_ops.unlink,rmdir:Qe.node_ops.rmdir,readdir:Qe.node_ops.readdir,symlink:Qe.node_ops.symlink},stream:{llseek:Qe.stream_ops.llseek}},file:{node:{getattr:Qe.node_ops.getattr,setattr:Qe.node_ops.setattr},stream:{llseek:Qe.stream_ops.llseek,read:Qe.stream_ops.read,write:Qe.stream_ops.write,allocate:Qe.stream_ops.allocate,mmap:Qe.stream_ops.mmap,msync:Qe.stream_ops.msync}},link:{node:{getattr:Qe.node_ops.getattr,setattr:Qe.node_ops.setattr,readlink:Qe.node_ops.readlink},stream:{}},chrdev:{node:{getattr:Qe.node_ops.getattr,setattr:Qe.node_ops.setattr},stream:K.chrdev_stream_ops}});var $=K.createNode(u,S,W,P);return K.isDir($.mode)?($.node_ops=Qe.ops_table.dir.node,$.stream_ops=Qe.ops_table.dir.stream,$.contents={}):K.isFile($.mode)?($.node_ops=Qe.ops_table.file.node,$.stream_ops=Qe.ops_table.file.stream,$.usedBytes=0,$.contents=null):K.isLink($.mode)?($.node_ops=Qe.ops_table.link.node,$.stream_ops=Qe.ops_table.link.stream):K.isChrdev($.mode)&&($.node_ops=Qe.ops_table.chrdev.node,$.stream_ops=Qe.ops_table.chrdev.stream),$.timestamp=Date.now(),u&&(u.contents[S]=$,u.timestamp=$.timestamp),$},getFileDataAsTypedArray(u){return u.contents?u.contents.subarray?u.contents.subarray(0,u.usedBytes):new Uint8Array(u.contents):new Uint8Array(0)},expandFileStorage(u,S){var W=u.contents?u.contents.length:0;if(!(W>=S)){var P=1024*1024;S=Math.max(S,W*(W<P?2:1.125)>>>0),W!=0&&(S=Math.max(S,256));var $=u.contents;u.contents=new Uint8Array(S),u.usedBytes>0&&u.contents.set($.subarray(0,u.usedBytes),0)}},resizeFileStorage(u,S){if(u.usedBytes!=S)if(S==0)u.contents=null,u.usedBytes=0;else{var W=u.contents;u.contents=new Uint8Array(S),W&&u.contents.set(W.subarray(0,Math.min(S,u.usedBytes))),u.usedBytes=S}},node_ops:{getattr(u){var S={};return S.dev=K.isChrdev(u.mode)?u.id:1,S.ino=u.id,S.mode=u.mode,S.nlink=1,S.uid=0,S.gid=0,S.rdev=u.rdev,K.isDir(u.mode)?S.size=4096:K.isFile(u.mode)?S.size=u.usedBytes:K.isLink(u.mode)?S.size=u.link.length:S.size=0,S.atime=new Date(u.timestamp),S.mtime=new Date(u.timestamp),S.ctime=new Date(u.timestamp),S.blksize=4096,S.blocks=Math.ceil(S.size/S.blksize),S},setattr(u,S){S.mode!==void 0&&(u.mode=S.mode),S.timestamp!==void 0&&(u.timestamp=S.timestamp),S.size!==void 0&&Qe.resizeFileStorage(u,S.size)},lookup(u,S){throw K.genericErrors[44]},mknod(u,S,W,P){return Qe.createNode(u,S,W,P)},rename(u,S,W){if(K.isDir(u.mode)){var P;try{P=K.lookupNode(S,W)}catch{}if(P)for(var $ in P.contents)throw new K.ErrnoError(55)}delete u.parent.contents[u.name],u.parent.timestamp=Date.now(),u.name=W,S.contents[W]=u,S.timestamp=u.parent.timestamp,u.parent=S},unlink(u,S){delete u.contents[S],u.timestamp=Date.now()},rmdir(u,S){var W=K.lookupNode(u,S);for(var P in W.contents)throw new K.ErrnoError(55);delete u.contents[S],u.timestamp=Date.now()},readdir(u){var S=[".",".."];for(var W in u.contents)u.contents.hasOwnProperty(W)&&S.push(W);return S},symlink(u,S,W){var P=Qe.createNode(u,S,41471,0);return P.link=W,P},readlink(u){if(!K.isLink(u.mode))throw new K.ErrnoError(28);return u.link}},stream_ops:{read(u,S,W,P,$){var ht=u.node.contents;if($>=u.node.usedBytes)return 0;var dt=Math.min(u.node.usedBytes-$,P);if(c(dt>=0),dt>8&&ht.subarray)S.set(ht.subarray($,$+dt),W);else for(var ft=0;ft<dt;ft++)S[W+ft]=ht[$+ft];return dt},write(u,S,W,P,$,ht){if(c(!(S instanceof ArrayBuffer)),S.buffer===g.buffer&&(ht=!1),!P)return 0;var dt=u.node;if(dt.timestamp=Date.now(),S.subarray&&(!dt.contents||dt.contents.subarray)){if(ht)return c($===0,"canOwn must imply no weird position inside the file"),dt.contents=S.subarray(W,W+P),dt.usedBytes=P,P;if(dt.usedBytes===0&&$===0)return dt.contents=S.slice(W,W+P),dt.usedBytes=P,P;if($+P<=dt.usedBytes)return dt.contents.set(S.subarray(W,W+P),$),P}if(Qe.expandFileStorage(dt,$+P),dt.contents.subarray&&S.subarray)dt.contents.set(S.subarray(W,W+P),$);else for(var ft=0;ft<P;ft++)dt.contents[$+ft]=S[W+ft];return dt.usedBytes=Math.max(dt.usedBytes,$+P),P},llseek(u,S,W){var P=S;if(W===1?P+=u.position:W===2&&K.isFile(u.node.mode)&&(P+=u.node.usedBytes),P<0)throw new K.ErrnoError(28);return P},allocate(u,S,W){Qe.expandFileStorage(u.node,S+W),u.node.usedBytes=Math.max(u.node.usedBytes,S+W)},mmap(u,S,W,P,$){if(!K.isFile(u.node.mode))throw new K.ErrnoError(43);var ht,dt,ft=u.node.contents;if(!($&2)&&ft.buffer===g.buffer)dt=!1,ht=ft.byteOffset;else{if((W>0||W+S<ft.length)&&(ft.subarray?ft=ft.subarray(W,W+S):ft=Array.prototype.slice.call(ft,W,W+S)),dt=!0,ht=cn(S),!ht)throw new K.ErrnoError(48);g.set(ft,ht)}return{ptr:ht,allocated:dt}},msync(u,S,W,P,$){return Qe.stream_ops.write(u,S,0,P,W,!1),0}}},Xs=(u,S,W,P)=>{var $=P?"":be(`al ${u}`);C(u,ht=>{c(ht,`Loading data file "${u}" failed (no arrayBuffer).`),S(new Uint8Array(ht)),$&&ze($)},ht=>{if(W)W();else throw`Loading data file "${u}" failed.`}),$&&ni($)},zo=i.preloadPlugins||[];function Sr(u,S,W,P){typeof Browser<"u"&&Browser.init();var $=!1;return zo.forEach(function(ht){$||ht.canHandle(S)&&(ht.handle(u,S,W,P),$=!0)}),$}function ml(u,S,W,P,$,ht,dt,ft,Bt,Lt){var re=S?Dt.resolve(Gt.join2(u,S)):u,ue=be(`cp ${re}`);function fe(Ee){function Se(di){Lt&&Lt(),ft||K.createDataFile(u,S,di,P,$,Bt),ht&&ht(),ze(ue)}Sr(Ee,re,Se,()=>{dt&&dt(),ze(ue)})||Se(Ee)}ni(ue),typeof W=="string"?Xs(W,Ee=>fe(Ee),dt):fe(W)}function Ra(u){var S={r:0,"r+":2,w:577,"w+":578,a:1089,"a+":1090},W=S[u];if(typeof W>"u")throw new Error(`Unknown file open mode: ${u}`);return W}function iE(u,S){var W=0;return u&&(W|=365),S&&(W|=146),W}var jR={0:"Success",1:"Arg list too long",2:"Permission denied",3:"Address already in use",4:"Address not available",5:"Address family not supported by protocol family",6:"No more processes",7:"Socket already connected",8:"Bad file number",9:"Trying to read unreadable message",10:"Mount device busy",11:"Operation canceled",12:"No children",13:"Connection aborted",14:"Connection refused",15:"Connection reset by peer",16:"File locking deadlock error",17:"Destination address required",18:"Math arg out of domain of func",19:"Quota exceeded",20:"File exists",21:"Bad address",22:"File too large",23:"Host is unreachable",24:"Identifier removed",25:"Illegal byte sequence",26:"Connection already in progress",27:"Interrupted system call",28:"Invalid argument",29:"I/O error",30:"Socket is already connected",31:"Is a directory",32:"Too many symbolic links",33:"Too many open files",34:"Too many links",35:"Message too long",36:"Multihop attempted",37:"File or path name too long",38:"Network interface is not configured",39:"Connection reset by network",40:"Network is unreachable",41:"Too many open files in system",42:"No buffer space available",43:"No such device",44:"No such file or directory",45:"Exec format error",46:"No record locks available",47:"The link has been severed",48:"Not enough core",49:"No message of desired type",50:"Protocol not available",51:"No space left on device",52:"Function not implemented",53:"Socket is not connected",54:"Not a directory",55:"Directory not empty",56:"State not recoverable",57:"Socket operation on non-socket",59:"Not a typewriter",60:"No such device or address",61:"Value too large for defined data type",62:"Previous owner died",63:"Not super-user",64:"Broken pipe",65:"Protocol error",66:"Unknown protocol",67:"Protocol wrong type for socket",68:"Math result not representable",69:"Read only file system",70:"Illegal seek",71:"No such process",72:"Stale file handle",73:"Connection timed out",74:"Text file busy",75:"Cross-device link",100:"Device not a stream",101:"Bad font file fmt",102:"Invalid slot",103:"Invalid request code",104:"No anode",105:"Block device required",106:"Channel number out of range",107:"Level 3 halted",108:"Level 3 reset",109:"Link number out of range",110:"Protocol driver not attached",111:"No CSI structure available",112:"Level 2 halted",113:"Invalid exchange",114:"Invalid request descriptor",115:"Exchange full",116:"No data (for no delay io)",117:"Timer expired",118:"Out of streams resources",119:"Machine is not on the network",120:"Package not installed",121:"The object is remote",122:"Advertise error",123:"Srmount error",124:"Communication error on send",125:"Cross mount point (not really error)",126:"Given log. name not unique",127:"f.d. invalid for this operation",128:"Remote address changed",129:"Can   access a needed shared lib",130:"Accessing a corrupted shared lib",131:".lib section in a.out corrupted",132:"Attempting to link in too many libs",133:"Attempting to exec a shared library",135:"Streams pipe error",136:"Too many users",137:"Socket type not supported",138:"Not supported",139:"Protocol family not supported",140:"Can't send after socket shutdown",141:"Too many references",142:"Host is down",148:"No medium (in tape drive)",156:"Level 2 not synchronized"},Em={};function HR(u){return Ai("warning: build with -sDEMANGLE_SUPPORT to link in libcxxabi demangling"),u}function zX(u){var S=/\b_Z[\w\d_]+/g;return u.replace(S,function(W){var P=HR(W);return W===P?W:P+" ["+W+"]"})}var K={root:null,mounts:[],devices:{},streams:[],nextInode:1,nameTable:null,currentPath:"/",initialized:!1,ignorePermissions:!0,ErrnoError:null,genericErrors:{},filesystems:null,syncFSRequests:0,lookupPath:(u,S={})=>{if(u=Dt.resolve(u),!u)return{path:"",node:null};var W={follow_mount:!0,recurse_count:0};if(S=Object.assign(W,S),S.recurse_count>8)throw new K.ErrnoError(32);for(var P=u.split("/").filter(ue=>!!ue),$=K.root,ht="/",dt=0;dt<P.length;dt++){var ft=dt===P.length-1;if(ft&&S.parent)break;if($=K.lookupNode($,P[dt]),ht=Gt.join2(ht,P[dt]),K.isMountpoint($)&&(!ft||ft&&S.follow_mount)&&($=$.mounted.root),!ft||S.follow)for(var Bt=0;K.isLink($.mode);){var Lt=K.readlink(ht);ht=Dt.resolve(Gt.dirname(ht),Lt);var re=K.lookupPath(ht,{recurse_count:S.recurse_count+1});if($=re.node,Bt++>40)throw new K.ErrnoError(32)}}return{path:ht,node:$}},getPath:u=>{for(var S;;){if(K.isRoot(u)){var W=u.mount.mountpoint;return S?W[W.length-1]!=="/"?`${W}/${S}`:W+S:W}S=S?`${u.name}/${S}`:u.name,u=u.parent}},hashName:(u,S)=>{for(var W=0,P=0;P<S.length;P++)W=(W<<5)-W+S.charCodeAt(P)|0;return(u+W>>>0)%K.nameTable.length},hashAddNode:u=>{var S=K.hashName(u.parent.id,u.name);u.name_next=K.nameTable[S],K.nameTable[S]=u},hashRemoveNode:u=>{var S=K.hashName(u.parent.id,u.name);if(K.nameTable[S]===u)K.nameTable[S]=u.name_next;else for(var W=K.nameTable[S];W;){if(W.name_next===u){W.name_next=u.name_next;break}W=W.name_next}},lookupNode:(u,S)=>{var W=K.mayLookup(u);if(W)throw new K.ErrnoError(W,u);for(var P=K.hashName(u.id,S),$=K.nameTable[P];$;$=$.name_next){var ht=$.name;if($.parent.id===u.id&&ht===S)return $}return K.lookup(u,S)},createNode:(u,S,W,P)=>{c(typeof u=="object");var $=new K.FSNode(u,S,W,P);return K.hashAddNode($),$},destroyNode:u=>{K.hashRemoveNode(u)},isRoot:u=>u===u.parent,isMountpoint:u=>!!u.mounted,isFile:u=>(u&61440)===32768,isDir:u=>(u&61440)===16384,isLink:u=>(u&61440)===40960,isChrdev:u=>(u&61440)===8192,isBlkdev:u=>(u&61440)===24576,isFIFO:u=>(u&61440)===4096,isSocket:u=>(u&49152)===49152,flagsToPermissionString:u=>{var S=["r","w","rw"][u&3];return u&512&&(S+="w"),S},nodePermissions:(u,S)=>K.ignorePermissions?0:S.includes("r")&&!(u.mode&292)||S.includes("w")&&!(u.mode&146)||S.includes("x")&&!(u.mode&73)?2:0,mayLookup:u=>{var S=K.nodePermissions(u,"x");return S||(u.node_ops.lookup?0:2)},mayCreate:(u,S)=>{try{var W=K.lookupNode(u,S);return 20}catch{}return K.nodePermissions(u,"wx")},mayDelete:(u,S,W)=>{var P;try{P=K.lookupNode(u,S)}catch(ht){return ht.errno}var $=K.nodePermissions(u,"wx");if($)return $;if(W){if(!K.isDir(P.mode))return 54;if(K.isRoot(P)||K.getPath(P)===K.cwd())return 10}else if(K.isDir(P.mode))return 31;return 0},mayOpen:(u,S)=>u?K.isLink(u.mode)?32:K.isDir(u.mode)&&(K.flagsToPermissionString(S)!=="r"||S&512)?31:K.nodePermissions(u,K.flagsToPermissionString(S)):44,MAX_OPEN_FDS:4096,nextfd:()=>{for(var u=0;u<=K.MAX_OPEN_FDS;u++)if(!K.streams[u])return u;throw new K.ErrnoError(33)},getStreamChecked:u=>{var S=K.getStream(u);if(!S)throw new K.ErrnoError(8);return S},getStream:u=>K.streams[u],createStream:(u,S=-1)=>(K.FSStream||(K.FSStream=function(){this.shared={}},K.FSStream.prototype={},Object.defineProperties(K.FSStream.prototype,{object:{get(){return this.node},set(W){this.node=W}},isRead:{get(){return(this.flags&2097155)!==1}},isWrite:{get(){return(this.flags&2097155)!==0}},isAppend:{get(){return this.flags&1024}},flags:{get(){return this.shared.flags},set(W){this.shared.flags=W}},position:{get(){return this.shared.position},set(W){this.shared.position=W}}})),u=Object.assign(new K.FSStream,u),S==-1&&(S=K.nextfd()),u.fd=S,K.streams[S]=u,u),closeStream:u=>{K.streams[u]=null},chrdev_stream_ops:{open:u=>{var S=K.getDevice(u.node.rdev);u.stream_ops=S.stream_ops,u.stream_ops.open&&u.stream_ops.open(u)},llseek:()=>{throw new K.ErrnoError(70)}},major:u=>u>>8,minor:u=>u&255,makedev:(u,S)=>u<<8|S,registerDevice:(u,S)=>{K.devices[u]={stream_ops:S}},getDevice:u=>K.devices[u],getMounts:u=>{for(var S=[],W=[u];W.length;){var P=W.pop();S.push(P),W.push.apply(W,P.mounts)}return S},syncfs:(u,S)=>{typeof u=="function"&&(S=u,u=!1),K.syncFSRequests++,K.syncFSRequests>1&&b(`warning: ${K.syncFSRequests} FS.syncfs operations in flight at once, probably just doing extra work`);var W=K.getMounts(K.root.mount),P=0;function $(dt){return c(K.syncFSRequests>0),K.syncFSRequests--,S(dt)}function ht(dt){if(dt)return ht.errored?void 0:(ht.errored=!0,$(dt));++P>=W.length&&$(null)}W.forEach(dt=>{if(!dt.type.syncfs)return ht(null);dt.type.syncfs(dt,u,ht)})},mount:(u,S,W)=>{if(typeof u=="string")throw u;var P=W==="/",$=!W,ht;if(P&&K.root)throw new K.ErrnoError(10);if(!P&&!$){var dt=K.lookupPath(W,{follow_mount:!1});if(W=dt.path,ht=dt.node,K.isMountpoint(ht))throw new K.ErrnoError(10);if(!K.isDir(ht.mode))throw new K.ErrnoError(54)}var ft={type:u,opts:S,mountpoint:W,mounts:[]},Bt=u.mount(ft);return Bt.mount=ft,ft.root=Bt,P?K.root=Bt:ht&&(ht.mounted=ft,ht.mount&&ht.mount.mounts.push(ft)),Bt},unmount:u=>{var S=K.lookupPath(u,{follow_mount:!1});if(!K.isMountpoint(S.node))throw new K.ErrnoError(28);var W=S.node,P=W.mounted,$=K.getMounts(P);Object.keys(K.nameTable).forEach(dt=>{for(var ft=K.nameTable[dt];ft;){var Bt=ft.name_next;$.includes(ft.mount)&&K.destroyNode(ft),ft=Bt}}),W.mounted=null;var ht=W.mount.mounts.indexOf(P);c(ht!==-1),W.mount.mounts.splice(ht,1)},lookup:(u,S)=>u.node_ops.lookup(u,S),mknod:(u,S,W)=>{var P=K.lookupPath(u,{parent:!0}),$=P.node,ht=Gt.basename(u);if(!ht||ht==="."||ht==="..")throw new K.ErrnoError(28);var dt=K.mayCreate($,ht);if(dt)throw new K.ErrnoError(dt);if(!$.node_ops.mknod)throw new K.ErrnoError(63);return $.node_ops.mknod($,ht,S,W)},create:(u,S)=>(S=S!==void 0?S:438,S&=4095,S|=32768,K.mknod(u,S,0)),mkdir:(u,S)=>(S=S!==void 0?S:511,S&=1023,S|=16384,K.mknod(u,S,0)),mkdirTree:(u,S)=>{for(var W=u.split("/"),P="",$=0;$<W.length;++$)if(W[$]){P+="/"+W[$];try{K.mkdir(P,S)}catch(ht){if(ht.errno!=20)throw ht}}},mkdev:(u,S,W)=>(typeof W>"u"&&(W=S,S=438),S|=8192,K.mknod(u,S,W)),symlink:(u,S)=>{if(!Dt.resolve(u))throw new K.ErrnoError(44);var W=K.lookupPath(S,{parent:!0}),P=W.node;if(!P)throw new K.ErrnoError(44);var $=Gt.basename(S),ht=K.mayCreate(P,$);if(ht)throw new K.ErrnoError(ht);if(!P.node_ops.symlink)throw new K.ErrnoError(63);return P.node_ops.symlink(P,$,u)},rename:(u,S)=>{var W=Gt.dirname(u),P=Gt.dirname(S),$=Gt.basename(u),ht=Gt.basename(S),dt,ft,Bt;if(dt=K.lookupPath(u,{parent:!0}),ft=dt.node,dt=K.lookupPath(S,{parent:!0}),Bt=dt.node,!ft||!Bt)throw new K.ErrnoError(44);if(ft.mount!==Bt.mount)throw new K.ErrnoError(75);var Lt=K.lookupNode(ft,$),re=Dt.relative(u,P);if(re.charAt(0)!==".")throw new K.ErrnoError(28);if(re=Dt.relative(S,W),re.charAt(0)!==".")throw new K.ErrnoError(55);var ue;try{ue=K.lookupNode(Bt,ht)}catch{}if(Lt!==ue){var fe=K.isDir(Lt.mode),Ee=K.mayDelete(ft,$,fe);if(Ee)throw new K.ErrnoError(Ee);if(Ee=ue?K.mayDelete(Bt,ht,fe):K.mayCreate(Bt,ht),Ee)throw new K.ErrnoError(Ee);if(!ft.node_ops.rename)throw new K.ErrnoError(63);if(K.isMountpoint(Lt)||ue&&K.isMountpoint(ue))throw new K.ErrnoError(10);if(Bt!==ft&&(Ee=K.nodePermissions(ft,"w"),Ee))throw new K.ErrnoError(Ee);K.hashRemoveNode(Lt);try{ft.node_ops.rename(Lt,Bt,ht)}catch(Se){throw Se}finally{K.hashAddNode(Lt)}}},rmdir:u=>{var S=K.lookupPath(u,{parent:!0}),W=S.node,P=Gt.basename(u),$=K.lookupNode(W,P),ht=K.mayDelete(W,P,!0);if(ht)throw new K.ErrnoError(ht);if(!W.node_ops.rmdir)throw new K.ErrnoError(63);if(K.isMountpoint($))throw new K.ErrnoError(10);W.node_ops.rmdir(W,P),K.destroyNode($)},readdir:u=>{var S=K.lookupPath(u,{follow:!0}),W=S.node;if(!W.node_ops.readdir)throw new K.ErrnoError(54);return W.node_ops.readdir(W)},unlink:u=>{var S=K.lookupPath(u,{parent:!0}),W=S.node;if(!W)throw new K.ErrnoError(44);var P=Gt.basename(u),$=K.lookupNode(W,P),ht=K.mayDelete(W,P,!1);if(ht)throw new K.ErrnoError(ht);if(!W.node_ops.unlink)throw new K.ErrnoError(63);if(K.isMountpoint($))throw new K.ErrnoError(10);W.node_ops.unlink(W,P),K.destroyNode($)},readlink:u=>{var S=K.lookupPath(u),W=S.node;if(!W)throw new K.ErrnoError(44);if(!W.node_ops.readlink)throw new K.ErrnoError(28);return Dt.resolve(K.getPath(W.parent),W.node_ops.readlink(W))},stat:(u,S)=>{var W=K.lookupPath(u,{follow:!S}),P=W.node;if(!P)throw new K.ErrnoError(44);if(!P.node_ops.getattr)throw new K.ErrnoError(63);return P.node_ops.getattr(P)},lstat:u=>K.stat(u,!0),chmod:(u,S,W)=>{var P;if(typeof u=="string"){var $=K.lookupPath(u,{follow:!W});P=$.node}else P=u;if(!P.node_ops.setattr)throw new K.ErrnoError(63);P.node_ops.setattr(P,{mode:S&4095|P.mode&-4096,timestamp:Date.now()})},lchmod:(u,S)=>{K.chmod(u,S,!0)},fchmod:(u,S)=>{var W=K.getStreamChecked(u);K.chmod(W.node,S)},chown:(u,S,W,P)=>{var $;if(typeof u=="string"){var ht=K.lookupPath(u,{follow:!P});$=ht.node}else $=u;if(!$.node_ops.setattr)throw new K.ErrnoError(63);$.node_ops.setattr($,{timestamp:Date.now()})},lchown:(u,S,W)=>{K.chown(u,S,W,!0)},fchown:(u,S,W)=>{var P=K.getStreamChecked(u);K.chown(P.node,S,W)},truncate:(u,S)=>{if(S<0)throw new K.ErrnoError(28);var W;if(typeof u=="string"){var P=K.lookupPath(u,{follow:!0});W=P.node}else W=u;if(!W.node_ops.setattr)throw new K.ErrnoError(63);if(K.isDir(W.mode))throw new K.ErrnoError(31);if(!K.isFile(W.mode))throw new K.ErrnoError(28);var $=K.nodePermissions(W,"w");if($)throw new K.ErrnoError($);W.node_ops.setattr(W,{size:S,timestamp:Date.now()})},ftruncate:(u,S)=>{var W=K.getStreamChecked(u);if(!(W.flags&2097155))throw new K.ErrnoError(28);K.truncate(W.node,S)},utime:(u,S,W)=>{var P=K.lookupPath(u,{follow:!0}),$=P.node;$.node_ops.setattr($,{timestamp:Math.max(S,W)})},open:(u,S,W)=>{if(u==="")throw new K.ErrnoError(44);S=typeof S=="string"?Ra(S):S,W=typeof W>"u"?438:W,S&64?W=W&4095|32768:W=0;var P;if(typeof u=="object")P=u;else{u=Gt.normalize(u);try{var $=K.lookupPath(u,{follow:!(S&131072)});P=$.node}catch{}}var ht=!1;if(S&64)if(P){if(S&128)throw new K.ErrnoError(20)}else P=K.mknod(u,W,0),ht=!0;if(!P)throw new K.ErrnoError(44);if(K.isChrdev(P.mode)&&(S&=-513),S&65536&&!K.isDir(P.mode))throw new K.ErrnoError(54);if(!ht){var dt=K.mayOpen(P,S);if(dt)throw new K.ErrnoError(dt)}S&512&&!ht&&K.truncate(P,0),S&=-131713;var ft=K.createStream({node:P,path:K.getPath(P),flags:S,seekable:!0,position:0,stream_ops:P.stream_ops,ungotten:[],error:!1});return ft.stream_ops.open&&ft.stream_ops.open(ft),i.logReadFiles&&!(S&1)&&(K.readFiles||(K.readFiles={}),u in K.readFiles||(K.readFiles[u]=1)),ft},close:u=>{if(K.isClosed(u))throw new K.ErrnoError(8);u.getdents&&(u.getdents=null);try{u.stream_ops.close&&u.stream_ops.close(u)}catch(S){throw S}finally{K.closeStream(u.fd)}u.fd=null},isClosed:u=>u.fd===null,llseek:(u,S,W)=>{if(K.isClosed(u))throw new K.ErrnoError(8);if(!u.seekable||!u.stream_ops.llseek)throw new K.ErrnoError(70);if(W!=0&&W!=1&&W!=2)throw new K.ErrnoError(28);return u.position=u.stream_ops.llseek(u,S,W),u.ungotten=[],u.position},read:(u,S,W,P,$)=>{if(c(W>=0),P<0||$<0)throw new K.ErrnoError(28);if(K.isClosed(u))throw new K.ErrnoError(8);if((u.flags&2097155)===1)throw new K.ErrnoError(8);if(K.isDir(u.node.mode))throw new K.ErrnoError(31);if(!u.stream_ops.read)throw new K.ErrnoError(28);var ht=typeof $<"u";if(!ht)$=u.position;else if(!u.seekable)throw new K.ErrnoError(70);var dt=u.stream_ops.read(u,S,W,P,$);return ht||(u.position+=dt),dt},write:(u,S,W,P,$,ht)=>{if(c(W>=0),P<0||$<0)throw new K.ErrnoError(28);if(K.isClosed(u))throw new K.ErrnoError(8);if(!(u.flags&2097155))throw new K.ErrnoError(8);if(K.isDir(u.node.mode))throw new K.ErrnoError(31);if(!u.stream_ops.write)throw new K.ErrnoError(28);u.seekable&&u.flags&1024&&K.llseek(u,0,2);var dt=typeof $<"u";if(!dt)$=u.position;else if(!u.seekable)throw new K.ErrnoError(70);var ft=u.stream_ops.write(u,S,W,P,$,ht);return dt||(u.position+=ft),ft},allocate:(u,S,W)=>{if(K.isClosed(u))throw new K.ErrnoError(8);if(S<0||W<=0)throw new K.ErrnoError(28);if(!(u.flags&2097155))throw new K.ErrnoError(8);if(!K.isFile(u.node.mode)&&!K.isDir(u.node.mode))throw new K.ErrnoError(43);if(!u.stream_ops.allocate)throw new K.ErrnoError(138);u.stream_ops.allocate(u,S,W)},mmap:(u,S,W,P,$)=>{if(P&2&&!($&2)&&(u.flags&2097155)!==2)throw new K.ErrnoError(2);if((u.flags&2097155)===1)throw new K.ErrnoError(2);if(!u.stream_ops.mmap)throw new K.ErrnoError(43);return u.stream_ops.mmap(u,S,W,P,$)},msync:(u,S,W,P,$)=>(c(W>=0),u.stream_ops.msync?u.stream_ops.msync(u,S,W,P,$):0),munmap:u=>0,ioctl:(u,S,W)=>{if(!u.stream_ops.ioctl)throw new K.ErrnoError(59);return u.stream_ops.ioctl(u,S,W)},readFile:(u,S={})=>{if(S.flags=S.flags||0,S.encoding=S.encoding||"binary",S.encoding!=="utf8"&&S.encoding!=="binary")throw new Error(`Invalid encoding type "${S.encoding}"`);var W,P=K.open(u,S.flags),$=K.stat(u),ht=$.size,dt=new Uint8Array(ht);return K.read(P,dt,0,ht,0),S.encoding==="utf8"?W=fa(dt,0):S.encoding==="binary"&&(W=dt),K.close(P),W},writeFile:(u,S,W={})=>{W.flags=W.flags||577;var P=K.open(u,W.flags,W.mode);if(typeof S=="string"){var $=new Uint8Array(ma(S)+1),ht=qh(S,$,0,$.length);K.write(P,$,0,ht,void 0,W.canOwn)}else if(ArrayBuffer.isView(S))K.write(P,S,0,S.byteLength,void 0,W.canOwn);else throw new Error("Unsupported data type");K.close(P)},cwd:()=>K.currentPath,chdir:u=>{var S=K.lookupPath(u,{follow:!0});if(S.node===null)throw new K.ErrnoError(44);if(!K.isDir(S.node.mode))throw new K.ErrnoError(54);var W=K.nodePermissions(S.node,"x");if(W)throw new K.ErrnoError(W);K.currentPath=S.path},createDefaultDirectories:()=>{K.mkdir("/tmp"),K.mkdir("/home"),K.mkdir("/home/web_user")},createDefaultDevices:()=>{K.mkdir("/dev"),K.registerDevice(K.makedev(1,3),{read:()=>0,write:(P,$,ht,dt,ft)=>dt}),K.mkdev("/dev/null",K.makedev(1,3)),pi.register(K.makedev(5,0),pi.default_tty_ops),pi.register(K.makedev(6,0),pi.default_tty1_ops),K.mkdev("/dev/tty",K.makedev(5,0)),K.mkdev("/dev/tty1",K.makedev(6,0));var u=new Uint8Array(1024),S=0,W=()=>(S===0&&(S=Ut(u).byteLength),u[--S]);K.createDevice("/dev","random",W),K.createDevice("/dev","urandom",W),K.mkdir("/dev/shm"),K.mkdir("/dev/shm/tmp")},createSpecialDirectories:()=>{K.mkdir("/proc");var u=K.mkdir("/proc/self");K.mkdir("/proc/self/fd"),K.mount({mount:()=>{var S=K.createNode(u,"fd",16895,73);return S.node_ops={lookup:(W,P)=>{var $=+P,ht=K.getStreamChecked($),dt={parent:null,mount:{mountpoint:"fake"},node_ops:{readlink:()=>ht.path}};return dt.parent=dt,dt}},S}},{},"/proc/self/fd")},createStandardStreams:()=>{i.stdin?K.createDevice("/dev","stdin",i.stdin):K.symlink("/dev/tty","/dev/stdin"),i.stdout?K.createDevice("/dev","stdout",null,i.stdout):K.symlink("/dev/tty","/dev/stdout"),i.stderr?K.createDevice("/dev","stderr",null,i.stderr):K.symlink("/dev/tty1","/dev/stderr");var u=K.open("/dev/stdin",0),S=K.open("/dev/stdout",1),W=K.open("/dev/stderr",1);c(u.fd===0,`invalid handle for stdin (${u.fd})`),c(S.fd===1,`invalid handle for stdout (${S.fd})`),c(W.fd===2,`invalid handle for stderr (${W.fd})`)},ensureErrnoError:()=>{K.ErrnoError||(K.ErrnoError=function(S,W){this.name="ErrnoError",this.node=W,this.setErrno=function(P){this.errno=P;for(var $ in Em)if(Em[$]===P){this.code=$;break}},this.setErrno(S),this.message=jR[S],this.stack&&(Object.defineProperty(this,"stack",{value:new Error().stack,writable:!0}),this.stack=zX(this.stack))},K.ErrnoError.prototype=new Error,K.ErrnoError.prototype.constructor=K.ErrnoError,[44].forEach(u=>{K.genericErrors[u]=new K.ErrnoError(u),K.genericErrors[u].stack="<generic error, no stack>"}))},staticInit:()=>{K.ensureErrnoError(),K.nameTable=new Array(4096),K.mount(Qe,{},"/"),K.createDefaultDirectories(),K.createDefaultDevices(),K.createSpecialDirectories(),K.filesystems={MEMFS:Qe}},init:(u,S,W)=>{c(!K.init.initialized,"FS.init was previously called. If you want to initialize later with custom parameters, remove any earlier calls (note that one is automatically added to the generated code)"),K.init.initialized=!0,K.ensureErrnoError(),i.stdin=u||i.stdin,i.stdout=S||i.stdout,i.stderr=W||i.stderr,K.createStandardStreams()},quit:()=>{K.init.initialized=!1,d8(0);for(var u=0;u<K.streams.length;u++){var S=K.streams[u];S&&K.close(S)}},findObject:(u,S)=>{var W=K.analyzePath(u,S);return W.exists?W.object:null},analyzePath:(u,S)=>{try{var W=K.lookupPath(u,{follow:!S});u=W.path}catch{}var P={isRoot:!1,exists:!1,error:0,name:null,path:null,object:null,parentExists:!1,parentPath:null,parentObject:null};try{var W=K.lookupPath(u,{parent:!0});P.parentExists=!0,P.parentPath=W.path,P.parentObject=W.node,P.name=Gt.basename(u),W=K.lookupPath(u,{follow:!S}),P.exists=!0,P.path=W.path,P.object=W.node,P.name=W.node.name,P.isRoot=W.path==="/"}catch($){P.error=$.errno}return P},createPath:(u,S,W,P)=>{u=typeof u=="string"?u:K.getPath(u);for(var $=S.split("/").reverse();$.length;){var ht=$.pop();if(ht){var dt=Gt.join2(u,ht);try{K.mkdir(dt)}catch{}u=dt}}return dt},createFile:(u,S,W,P,$)=>{var ht=Gt.join2(typeof u=="string"?u:K.getPath(u),S),dt=iE(P,$);return K.create(ht,dt)},createDataFile:(u,S,W,P,$,ht)=>{var dt=S;u&&(u=typeof u=="string"?u:K.getPath(u),dt=S?Gt.join2(u,S):u);var ft=iE(P,$),Bt=K.create(dt,ft);if(W){if(typeof W=="string"){for(var Lt=new Array(W.length),re=0,ue=W.length;re<ue;++re)Lt[re]=W.charCodeAt(re);W=Lt}K.chmod(Bt,ft|146);var fe=K.open(Bt,577);K.write(fe,W,0,W.length,0,ht),K.close(fe),K.chmod(Bt,ft)}return Bt},createDevice:(u,S,W,P)=>{var $=Gt.join2(typeof u=="string"?u:K.getPath(u),S),ht=iE(!!W,!!P);K.createDevice.major||(K.createDevice.major=64);var dt=K.makedev(K.createDevice.major++,0);return K.registerDevice(dt,{open:ft=>{ft.seekable=!1},close:ft=>{P&&P.buffer&&P.buffer.length&&P(10)},read:(ft,Bt,Lt,re,ue)=>{for(var fe=0,Ee=0;Ee<re;Ee++){var Se;try{Se=W()}catch{throw new K.ErrnoError(29)}if(Se===void 0&&fe===0)throw new K.ErrnoError(6);if(Se==null)break;fe++,Bt[Lt+Ee]=Se}return fe&&(ft.node.timestamp=Date.now()),fe},write:(ft,Bt,Lt,re,ue)=>{for(var fe=0;fe<re;fe++)try{P(Bt[Lt+fe])}catch{throw new K.ErrnoError(29)}return re&&(ft.node.timestamp=Date.now()),fe}}),K.mkdev($,ht,dt)},forceLoadFile:u=>{if(u.isDevice||u.isFolder||u.link||u.contents)return!0;if(typeof XMLHttpRequest<"u")throw new Error("Lazy loading should have been performed (contents set) in createLazyFile, but it was not. Lazy loading only works in web workers. Use --embed-file or --preload-file in emcc on the main thread.");if(I)try{u.contents=Be(I(u.url),!0),u.usedBytes=u.contents.length}catch{throw new K.ErrnoError(29)}else throw new Error("Cannot load without read() or XMLHttpRequest.")},createLazyFile:(u,S,W,P,$)=>{function ht(){this.lengthKnown=!1,this.chunks=[]}if(ht.prototype.get=function(Ee){if(!(Ee>this.length-1||Ee<0)){var Se=Ee%this.chunkSize,di=Ee/this.chunkSize|0;return this.getter(di)[Se]}},ht.prototype.setDataGetter=function(Ee){this.getter=Ee},ht.prototype.cacheLength=function(){var Ee=new XMLHttpRequest;if(Ee.open("HEAD",W,!1),Ee.send(null),!(Ee.status>=200&&Ee.status<300||Ee.status===304))throw new Error("Couldn't load "+W+". Status: "+Ee.status);var Se=Number(Ee.getResponseHeader("Content-length")),di,ln=(di=Ee.getResponseHeader("Accept-Ranges"))&&di==="bytes",Rn=(di=Ee.getResponseHeader("Content-Encoding"))&&di==="gzip",qt=1024*1024;ln||(qt=Se);var Fe=(Zn,Ko)=>{if(Zn>Ko)throw new Error("invalid range ("+Zn+", "+Ko+") or no bytes requested!");if(Ko>Se-1)throw new Error("only "+Se+" bytes available! programmer error!");var ms=new XMLHttpRequest;if(ms.open("GET",W,!1),Se!==qt&&ms.setRequestHeader("Range","bytes="+Zn+"-"+Ko),ms.responseType="arraybuffer",ms.overrideMimeType&&ms.overrideMimeType("text/plain; charset=x-user-defined"),ms.send(null),!(ms.status>=200&&ms.status<300||ms.status===304))throw new Error("Couldn't load "+W+". Status: "+ms.status);return ms.response!==void 0?new Uint8Array(ms.response||[]):Be(ms.responseText||"",!0)},Ts=this;Ts.setDataGetter(Zn=>{var Ko=Zn*qt,ms=(Zn+1)*qt-1;if(ms=Math.min(ms,Se-1),typeof Ts.chunks[Zn]>"u"&&(Ts.chunks[Zn]=Fe(Ko,ms)),typeof Ts.chunks[Zn]>"u")throw new Error("doXHR failed!");return Ts.chunks[Zn]}),(Rn||!Se)&&(qt=Se=1,Se=this.getter(0).length,qt=Se,F("LazyFiles on gzip forces download of the whole file when length is accessed")),this._length=Se,this._chunkSize=qt,this.lengthKnown=!0},typeof XMLHttpRequest<"u"){if(!d)throw"Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";var dt=new ht;Object.defineProperties(dt,{length:{get:function(){return this.lengthKnown||this.cacheLength(),this._length}},chunkSize:{get:function(){return this.lengthKnown||this.cacheLength(),this._chunkSize}}});var ft={isDevice:!1,contents:dt}}else var ft={isDevice:!1,url:W};var Bt=K.createFile(u,S,ft,P,$);ft.contents?Bt.contents=ft.contents:ft.url&&(Bt.contents=null,Bt.url=ft.url),Object.defineProperties(Bt,{usedBytes:{get:function(){return this.contents.length}}});var Lt={},re=Object.keys(Bt.stream_ops);re.forEach(fe=>{var Ee=Bt.stream_ops[fe];Lt[fe]=function(){return K.forceLoadFile(Bt),Ee.apply(null,arguments)}});function ue(fe,Ee,Se,di,ln){var Rn=fe.node.contents;if(ln>=Rn.length)return 0;var qt=Math.min(Rn.length-ln,di);if(c(qt>=0),Rn.slice)for(var Fe=0;Fe<qt;Fe++)Ee[Se+Fe]=Rn[ln+Fe];else for(var Fe=0;Fe<qt;Fe++)Ee[Se+Fe]=Rn.get(ln+Fe);return qt}return Lt.read=(fe,Ee,Se,di,ln)=>(K.forceLoadFile(Bt),ue(fe,Ee,Se,di,ln)),Lt.mmap=(fe,Ee,Se,di,ln)=>{K.forceLoadFile(Bt);var Rn=cn(Ee);if(!Rn)throw new K.ErrnoError(48);return ue(fe,g,Rn,Ee,Se),{ptr:Rn,allocated:!0}},Bt.stream_ops=Lt,Bt},absolutePath:()=>{Ge("FS.absolutePath has been removed; use PATH_FS.resolve instead")},createFolder:()=>{Ge("FS.createFolder has been removed; use FS.mkdir instead")},createLink:()=>{Ge("FS.createLink has been removed; use FS.symlink instead")},joinPath:()=>{Ge("FS.joinPath has been removed; use PATH.join instead")},mmapAlloc:()=>{Ge("FS.mmapAlloc has been replaced by the top level function mmapAlloc")},standardizePath:()=>{Ge("FS.standardizePath has been removed; use PATH.normalize instead")}},ec={DEFAULT_POLLMASK:5,calculateAt:function(u,S,W){if(Gt.isAbs(S))return S;var P;if(u===-100)P=K.cwd();else{var $=ec.getStreamFromFD(u);P=$.path}if(S.length==0){if(!W)throw new K.ErrnoError(44);return P}return Gt.join2(P,S)},doStat:function(u,S,W){try{var P=u(S)}catch(ft){if(ft&&ft.node&&Gt.normalize(S)!==Gt.normalize(K.getPath(ft.node)))return-54;throw ft}x[W>>2]=P.dev,x[W+4>>2]=P.mode,H[W+8>>2]=P.nlink,x[W+12>>2]=P.uid,x[W+16>>2]=P.gid,x[W+20>>2]=P.rdev,ei=[P.size>>>0,(Ne=P.size,+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[W+24>>2]=ei[0],x[W+28>>2]=ei[1],x[W+32>>2]=4096,x[W+36>>2]=P.blocks;var $=P.atime.getTime(),ht=P.mtime.getTime(),dt=P.ctime.getTime();return ei=[Math.floor($/1e3)>>>0,(Ne=Math.floor($/1e3),+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[W+40>>2]=ei[0],x[W+44>>2]=ei[1],H[W+48>>2]=$%1e3*1e3,ei=[Math.floor(ht/1e3)>>>0,(Ne=Math.floor(ht/1e3),+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[W+56>>2]=ei[0],x[W+60>>2]=ei[1],H[W+64>>2]=ht%1e3*1e3,ei=[Math.floor(dt/1e3)>>>0,(Ne=Math.floor(dt/1e3),+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[W+72>>2]=ei[0],x[W+76>>2]=ei[1],H[W+80>>2]=dt%1e3*1e3,ei=[P.ino>>>0,(Ne=P.ino,+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[W+88>>2]=ei[0],x[W+92>>2]=ei[1],0},doMsync:function(u,S,W,P,$){if(!K.isFile(S.node.mode))throw new K.ErrnoError(43);if(P&2)return 0;var ht=V.slice(u,u+W);K.msync(S,ht,$,W,P)},varargs:void 0,get(){c(ec.varargs!=null),ec.varargs+=4;var u=x[ec.varargs-4>>2];return u},getStr(u){var S=Ea(u);return S},getStreamFromFD:function(u){var S=K.getStreamChecked(u);return S}},KX=(u,S)=>{var W=0;return Rt().forEach(function(P,$){var ht=S+W;H[u+$*4>>2]=ht,St(P,ht),W+=P.length+1}),0},XX=(u,S)=>{var W=Rt();H[u>>2]=W.length;var P=0;return W.forEach(function($){P+=$.length+1}),H[S>>2]=P,0};function qX(u){try{var S=ec.getStreamFromFD(u);return K.close(S),0}catch(W){if(typeof K>"u"||W.name!=="ErrnoError")throw W;return W.errno}}var $X=(u,S,W,P)=>{for(var $=0,ht=0;ht<W;ht++){var dt=H[S>>2],ft=H[S+4>>2];S+=8;var Bt=K.read(u,g,dt,ft,P);if(Bt<0)return-1;if($+=Bt,Bt<ft)break;typeof P<"u"&&(P+=Bt)}return $};function t8(u,S,W,P){try{var $=ec.getStreamFromFD(u),ht=$X($,S,W);return H[P>>2]=ht,0}catch(dt){if(typeof K>"u"||dt.name!=="ErrnoError")throw dt;return dt.errno}}function e8(u,S,W,P,$){var ht=ll(S,W);try{if(isNaN(ht))return 61;var dt=ec.getStreamFromFD(u);return K.llseek(dt,ht,P),ei=[dt.position>>>0,(Ne=dt.position,+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[$>>2]=ei[0],x[$+4>>2]=ei[1],dt.getdents&&ht===0&&P===0&&(dt.getdents=null),0}catch(ft){if(typeof K>"u"||ft.name!=="ErrnoError")throw ft;return ft.errno}}var i8=(u,S,W,P)=>{for(var $=0,ht=0;ht<W;ht++){var dt=H[S>>2],ft=H[S+4>>2];S+=8;var Bt=K.write(u,g,dt,ft,P);if(Bt<0)return-1;$+=Bt,typeof P<"u"&&(P+=Bt)}return $};function n8(u,S,W,P){try{var $=ec.getStreamFromFD(u),ht=i8($,S,W);return H[P>>2]=ht,0}catch(dt){if(typeof K>"u"||dt.name!=="ErrnoError")throw dt;return dt.errno}}var s8=(u,S)=>{for(var W=0,P=0;P<=S;W+=u[P++]);return W},UB=[31,29,31,30,31,30,31,31,30,31,30,31],QB=[31,28,31,30,31,30,31,31,30,31,30,31],o8=(u,S)=>{for(var W=new Date(u.getTime());S>0;){var P=oA(W.getFullYear()),$=W.getMonth(),ht=(P?UB:QB)[$];if(S>ht-W.getDate())S-=ht-W.getDate()+1,W.setDate(1),$<11?W.setMonth($+1):(W.setMonth(0),W.setFullYear(W.getFullYear()+1));else return W.setDate(W.getDate()+S),W}return W},kB=(u,S)=>{c(u.length>=0,"writeArrayToMemory array must have a length (should be an array or typed array)"),g.set(u,S)},r8=(u,S,W,P)=>{var $=x[P+40>>2],ht={tm_sec:x[P>>2],tm_min:x[P+4>>2],tm_hour:x[P+8>>2],tm_mday:x[P+12>>2],tm_mon:x[P+16>>2],tm_year:x[P+20>>2],tm_wday:x[P+24>>2],tm_yday:x[P+28>>2],tm_isdst:x[P+32>>2],tm_gmtoff:x[P+36>>2],tm_zone:$?Ea($):""},dt=Ea(W),ft={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var Bt in ft)dt=dt.replace(new RegExp(Bt,"g"),ft[Bt]);var Lt=["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],re=["January","February","March","April","May","June","July","August","September","October","November","December"];function ue(qt,Fe,Ts){for(var Zn=typeof qt=="number"?qt.toString():qt||"";Zn.length<Fe;)Zn=Ts[0]+Zn;return Zn}function fe(qt,Fe){return ue(qt,Fe,"0")}function Ee(qt,Fe){function Ts(Ko){return Ko<0?-1:Ko>0?1:0}var Zn;return(Zn=Ts(qt.getFullYear()-Fe.getFullYear()))===0&&(Zn=Ts(qt.getMonth()-Fe.getMonth()))===0&&(Zn=Ts(qt.getDate()-Fe.getDate())),Zn}function Se(qt){switch(qt.getDay()){case 0:return new Date(qt.getFullYear()-1,11,29);case 1:return qt;case 2:return new Date(qt.getFullYear(),0,3);case 3:return new Date(qt.getFullYear(),0,2);case 4:return new Date(qt.getFullYear(),0,1);case 5:return new Date(qt.getFullYear()-1,11,31);case 6:return new Date(qt.getFullYear()-1,11,30)}}function di(qt){var Fe=o8(new Date(qt.tm_year+1900,0,1),qt.tm_yday),Ts=new Date(Fe.getFullYear(),0,4),Zn=new Date(Fe.getFullYear()+1,0,4),Ko=Se(Ts),ms=Se(Zn);return Ee(Ko,Fe)<=0?Ee(ms,Fe)<=0?Fe.getFullYear()+1:Fe.getFullYear():Fe.getFullYear()-1}var ln={"%a":qt=>Lt[qt.tm_wday].substring(0,3),"%A":qt=>Lt[qt.tm_wday],"%b":qt=>re[qt.tm_mon].substring(0,3),"%B":qt=>re[qt.tm_mon],"%C":qt=>{var Fe=qt.tm_year+1900;return fe(Fe/100|0,2)},"%d":qt=>fe(qt.tm_mday,2),"%e":qt=>ue(qt.tm_mday,2," "),"%g":qt=>di(qt).toString().substring(2),"%G":qt=>di(qt),"%H":qt=>fe(qt.tm_hour,2),"%I":qt=>{var Fe=qt.tm_hour;return Fe==0?Fe=12:Fe>12&&(Fe-=12),fe(Fe,2)},"%j":qt=>fe(qt.tm_mday+s8(oA(qt.tm_year+1900)?UB:QB,qt.tm_mon-1),3),"%m":qt=>fe(qt.tm_mon+1,2),"%M":qt=>fe(qt.tm_min,2),"%n":()=>`
`,"%p":qt=>qt.tm_hour>=0&&qt.tm_hour<12?"AM":"PM","%S":qt=>fe(qt.tm_sec,2),"%t":()=>"	","%u":qt=>qt.tm_wday||7,"%U":qt=>{var Fe=qt.tm_yday+7-qt.tm_wday;return fe(Math.floor(Fe/7),2)},"%V":qt=>{var Fe=Math.floor((qt.tm_yday+7-(qt.tm_wday+6)%7)/7);if((qt.tm_wday+371-qt.tm_yday-2)%7<=2&&Fe++,Fe){if(Fe==53){var Zn=(qt.tm_wday+371-qt.tm_yday)%7;Zn!=4&&(Zn!=3||!oA(qt.tm_year))&&(Fe=1)}}else{Fe=52;var Ts=(qt.tm_wday+7-qt.tm_yday-1)%7;(Ts==4||Ts==5&&oA(qt.tm_year%400-1))&&Fe++}return fe(Fe,2)},"%w":qt=>qt.tm_wday,"%W":qt=>{var Fe=qt.tm_yday+7-(qt.tm_wday+6)%7;return fe(Math.floor(Fe/7),2)},"%y":qt=>(qt.tm_year+1900).toString().substring(2),"%Y":qt=>qt.tm_year+1900,"%z":qt=>{var Fe=qt.tm_gmtoff,Ts=Fe>=0;return Fe=Math.abs(Fe)/60,Fe=Fe/60*100+Fe%60,(Ts?"+":"-")+("0000"+Fe).slice(-4)},"%Z":qt=>qt.tm_zone,"%%":()=>"%"};dt=dt.replace(/%%/g,"\0\0");for(var Bt in ln)dt.includes(Bt)&&(dt=dt.replace(new RegExp(Bt,"g"),ln[Bt](ht)));dt=dt.replace(/\0\0/g,"%");var Rn=Be(dt,!1);return Rn.length>S?0:(kB(Rn,u),Rn.length-1)},a8=(u,S,W,P,$)=>r8(u,S,W,P);function A8(u){var S=i["_"+u];return c(S,"Cannot call unknown function "+u+", make sure it is exported"),S}var h8=u=>{var S=ma(u)+1,W=PB(S);return PA(u,W,S),W},LB=function(u,S,W,P,$){var ht={string:Se=>{var di=0;return Se!=null&&Se!==0&&(di=h8(Se)),di},array:Se=>{var di=PB(Se.length);return kB(Se,di),di}};function dt(Se){return S==="string"?Ea(Se):S==="boolean"?!!Se:Se}var ft=A8(u),Bt=[],Lt=0;if(c(S!=="array",'Return type should not be "array".'),P)for(var re=0;re<P.length;re++){var ue=ht[W[re]];ue?(Lt===0&&(Lt=R8()),Bt[re]=ue(P[re])):Bt[re]=P[re]}var fe=ft.apply(null,Bt);function Ee(Se){return Lt!==0&&Z8(Lt),dt(Se)}return fe=Ee(fe),fe};function c8(u,S,W,P){return function(){return LB(u,S,W,arguments,P)}}jo(),Oo=i.BindingError=class extends Error{constructor(S){super(S),this.name="BindingError"}},aa=i.InternalError=class extends Error{constructor(S){super(S),this.name="InternalError"}},yh(),Sd(),yA(),jh=i.UnboundTypeError=sl(Error,"UnboundTypeError"),wd(),Pd();var yB=function(u,S,W,P){u||(u=this),this.parent=u,this.mount=u.mount,this.mounted=null,this.id=K.nextInode++,this.name=S,this.mode=W,this.node_ops={},this.stream_ops={},this.rdev=P},vR=365,zR=146;Object.defineProperties(yB.prototype,{read:{get:function(){return(this.mode&vR)===vR},set:function(u){u?this.mode|=vR:this.mode&=~vR}},write:{get:function(){return(this.mode&zR)===zR},set:function(u){u?this.mode|=zR:this.mode&=~zR}},isFolder:{get:function(){return K.isDir(this.mode)}},isDevice:{get:function(){return K.isChrdev(this.mode)}}}),K.FSNode=yB,K.createPreloadedFile=ml,K.staticInit(),Em={EPERM:63,ENOENT:44,ESRCH:71,EINTR:27,EIO:29,ENXIO:60,E2BIG:1,ENOEXEC:45,EBADF:8,ECHILD:12,EAGAIN:6,EWOULDBLOCK:6,ENOMEM:48,EACCES:2,EFAULT:21,ENOTBLK:105,EBUSY:10,EEXIST:20,EXDEV:75,ENODEV:43,ENOTDIR:54,EISDIR:31,EINVAL:28,ENFILE:41,EMFILE:33,ENOTTY:59,ETXTBSY:74,EFBIG:22,ENOSPC:51,ESPIPE:70,EROFS:69,EMLINK:34,EPIPE:64,EDOM:18,ERANGE:68,ENOMSG:49,EIDRM:24,ECHRNG:106,EL2NSYNC:156,EL3HLT:107,EL3RST:108,ELNRNG:109,EUNATCH:110,ENOCSI:111,EL2HLT:112,EDEADLK:16,ENOLCK:46,EBADE:113,EBADR:114,EXFULL:115,ENOANO:104,EBADRQC:103,EBADSLT:102,EDEADLOCK:16,EBFONT:101,ENOSTR:100,ENODATA:116,ETIME:117,ENOSR:118,ENONET:119,ENOPKG:120,EREMOTE:121,ENOLINK:47,EADV:122,ESRMNT:123,ECOMM:124,EPROTO:65,EMULTIHOP:36,EDOTDOT:125,EBADMSG:9,ENOTUNIQ:126,EBADFD:127,EREMCHG:128,ELIBACC:129,ELIBBAD:130,ELIBSCN:131,ELIBMAX:132,ELIBEXEC:133,ENOSYS:52,ENOTEMPTY:55,ENAMETOOLONG:37,ELOOP:32,EOPNOTSUPP:138,EPFNOSUPPORT:139,ECONNRESET:15,ENOBUFS:42,EAFNOSUPPORT:5,EPROTOTYPE:67,ENOTSOCK:57,ENOPROTOOPT:50,ESHUTDOWN:140,ECONNREFUSED:14,EADDRINUSE:3,ECONNABORTED:13,ENETUNREACH:40,ENETDOWN:38,ETIMEDOUT:73,EHOSTDOWN:142,EHOSTUNREACH:23,EINPROGRESS:26,EALREADY:7,EDESTADDRREQ:17,EMSGSIZE:35,EPROTONOSUPPORT:66,ESOCKTNOSUPPORT:137,EADDRNOTAVAIL:4,ENETRESET:39,EISCONN:30,ENOTCONN:53,ETOOMANYREFS:141,EUSERS:136,EDQUOT:19,ESTALE:72,ENOTSUP:138,ENOMEDIUM:148,EILSEQ:25,EOVERFLOW:61,ECANCELED:11,ENOTRECOVERABLE:56,EOWNERDEAD:62,ESTRPIPE:135};function l8(){hs("fetchSettings")}var wB={__cxa_throw:ao,_embind_register_bigint:qi,_embind_register_bool:hr,_embind_register_class:Hh,_embind_register_class_constructor:yd,_embind_register_class_function:Kh,_embind_register_class_property:Xh,_embind_register_emval:xA,_embind_register_float:Jd,_embind_register_function:jd,_embind_register_integer:vd,_embind_register_memory_view:zd,_embind_register_std_string:sA,_embind_register_std_wstring:$d,_embind_register_void:tm,_emscripten_get_now_is_monotonic:im,_emval_as:sm,_emval_decref:ho,_emval_get_property:om,_emval_new_cstring:am,_emval_run_destructors:Am,_gmtime_js:hm,_mktime_js:dm,_tzset_js:mm,abort:fm,emscripten_asm_const_int:et,emscripten_date_now:pt,emscripten_get_now:$t,emscripten_memcpy_big:ve,emscripten_resize_heap:tc,emscripten_run_script_string:J,environ_get:KX,environ_sizes_get:XX,fd_close:qX,fd_read:t8,fd_seek:e8,fd_write:n8,strftime_l:a8},LIt=An(),yIt=qe("__wasm_call_ctors"),KR=i._malloc=qe("malloc"),HA=i._free=qe("free"),wIt=i._inflateEllipsoid=qe("inflateEllipsoid"),xIt=i._getCoveragePositions=qe("getCoveragePositions"),d8=i._fflush=qe("fflush"),m8=qe("__getTypeName"),PIt=i.__embind_initialize_bindings=qe("_embind_initialize_bindings"),JIt=qe("__errno_location"),f8=qe("setTempRet0"),xB=()=>(xB=U.emscripten_stack_init)(),E8=()=>(E8=U.emscripten_stack_get_free)(),_8=()=>(_8=U.emscripten_stack_get_base)(),$g=()=>($g=U.emscripten_stack_get_end)(),R8=qe("stackSave"),Z8=qe("stackRestore"),PB=qe("stackAlloc"),I8=()=>(I8=U.emscripten_stack_get_current)(),jIt=qe("__cxa_increment_exception_refcount"),p8=qe("__cxa_is_pointer_type"),HIt=i.dynCall_jiji=qe("dynCall_jiji"),vIt=i.dynCall_viijii=qe("dynCall_viijii"),zIt=i.dynCall_iiiiij=qe("dynCall_iiiiij"),KIt=i.dynCall_iiiiijj=qe("dynCall_iiiiijj"),XIt=i.dynCall_iiiiiijj=qe("dynCall_iiiiiijj");function u8(u){try{for(var S=atob(u),W=new Uint8Array(S.length),P=0;P<S.length;++P)W[P]=S.charCodeAt(P);return W}catch{throw new Error("Converting base64 string to bytes failed.")}}function C8(u){if(Ri(u))return u8(u.slice(Ui.length))}i.ccall=LB,i.cwrap=c8;var g8=["writeI53ToI64","writeI53ToI64Clamped","writeI53ToI64Signaling","writeI53ToU64Clamped","writeI53ToU64Signaling","readI53FromI64","readI53FromU64","convertI32PairToI53","convertU32PairToI53","exitJS","setErrNo","inetPton4","inetNtop4","inetPton6","inetNtop6","readSockaddr","writeSockaddr","getHostByName","getCallstack","emscriptenLog","convertPCtoSourceLocation","runMainThreadEmAsm","jstoi_q","jstoi_s","listenOnce","autoResumeAudioContext","handleException","runtimeKeepalivePush","runtimeKeepalivePop","callUserCallback","maybeExit","safeSetTimeout","asmjsMangle","getNativeTypeSize","STACK_SIZE","STACK_ALIGN","POINTER_SIZE","ASSERTIONS","uleb128Encode","sigToWasmTypes","generateFuncType","convertJsFunctionToWasm","getEmptyTableSlot","updateTableMap","getFunctionAddress","addFunction","removeFunction","reallyNegative","unSign","strLen","reSign","formatString","intArrayToString","AsciiToString","registerKeyEventCallback","maybeCStringToJsString","findEventTarget","findCanvasEventTarget","getBoundingClientRect","fillMouseEventData","registerMouseEventCallback","registerWheelEventCallback","registerUiEventCallback","registerFocusEventCallback","fillDeviceOrientationEventData","registerDeviceOrientationEventCallback","fillDeviceMotionEventData","registerDeviceMotionEventCallback","screenOrientation","fillOrientationChangeEventData","registerOrientationChangeEventCallback","fillFullscreenChangeEventData","registerFullscreenChangeEventCallback","JSEvents_requestFullscreen","JSEvents_resizeCanvasForFullscreen","registerRestoreOldStyle","hideEverythingExceptGivenElement","restoreHiddenElements","setLetterbox","softFullscreenResizeWebGLRenderTarget","doRequestFullscreen","fillPointerlockChangeEventData","registerPointerlockChangeEventCallback","registerPointerlockErrorEventCallback","requestPointerLock","fillVisibilityChangeEventData","registerVisibilityChangeEventCallback","registerTouchEventCallback","fillGamepadEventData","registerGamepadEventCallback","registerBeforeUnloadEventCallback","fillBatteryEventData","battery","registerBatteryEventCallback","setCanvasElementSize","getCanvasElementSize","jsStackTrace","stackTrace","checkWasiClock","wasiRightsToMuslOFlags","wasiOFlagsToMuslOFlags","createDyncallWrapper","setImmediateWrapped","clearImmediateWrapped","polyfillSetImmediate","getPromise","makePromise","idsToPromises","makePromiseCallback","findMatchingCatch","setMainLoop","getSocketFromFD","getSocketAddress","_setNetworkCallback","heapObjectForWebGLType","heapAccessShiftForWebGLHeap","webgl_enable_ANGLE_instanced_arrays","webgl_enable_OES_vertex_array_object","webgl_enable_WEBGL_draw_buffers","webgl_enable_WEBGL_multi_draw","emscriptenWebGLGet","computeUnpackAlignedImageSize","colorChannelsInGlTextureFormat","emscriptenWebGLGetTexPixelData","__glGenObject","emscriptenWebGLGetUniform","webglGetUniformLocation","webglPrepareUniformLocationsBeforeFirstUse","webglGetLeftBracePos","emscriptenWebGLGetVertexAttrib","__glGetActiveAttribOrUniform","writeGLArray","registerWebGlEventCallback","runAndAbortIfError","SDL_unicode","SDL_ttfContext","SDL_audio","GLFW_Window","ALLOC_NORMAL","ALLOC_STACK","allocate","writeStringToMemory","writeAsciiToMemory","registerInheritedInstance","unregisterInheritedInstance","enumReadValueFromPointer","craftEmvalAllocator","emval_get_global","emval_lookupTypes","emval_allocateDestructors","emval_addMethodCaller"];g8.forEach(ki);var T8=["run","addOnPreRun","addOnInit","addOnPreMain","addOnExit","addOnPostRun","addRunDependency","removeRunDependency","FS_createFolder","FS_createPath","FS_createDataFile","FS_createLazyFile","FS_createLink","FS_createDevice","FS_unlink","out","err","callMain","abort","keepRuntimeAlive","wasmMemory","wasmTable","wasmExports","stackAlloc","stackSave","stackRestore","getTempRet0","setTempRet0","writeStackCookie","checkStackCookie","intArrayFromBase64","tryParseAsDataURI","convertI32PairToI53Checked","ptrToString","zeroMemory","getHeapMax","growMemory","ENV","MONTH_DAYS_REGULAR","MONTH_DAYS_LEAP","MONTH_DAYS_REGULAR_CUMULATIVE","MONTH_DAYS_LEAP_CUMULATIVE","isLeapYear","ydayFromDate","arraySum","addDays","ERRNO_CODES","ERRNO_MESSAGES","DNS","Protocols","Sockets","initRandomFill","randomFill","timers","warnOnce","UNWIND_CACHE","readEmAsmArgsArray","readEmAsmArgs","runEmAsmFunction","getExecutableName","dynCallLegacy","getDynCaller","dynCall","asyncLoad","alignMemory","mmapAlloc","handleAllocatorInit","HandleAllocator","getCFunc","freeTableIndexes","functionsInTableMap","setValue","getValue","PATH","PATH_FS","UTF8Decoder","UTF8ArrayToString","UTF8ToString","stringToUTF8Array","stringToUTF8","lengthBytesUTF8","intArrayFromString","stringToAscii","UTF16Decoder","UTF16ToString","stringToUTF16","lengthBytesUTF16","UTF32ToString","stringToUTF32","lengthBytesUTF32","stringToNewUTF8","stringToUTF8OnStack","writeArrayToMemory","JSEvents","specialHTMLTargets","currentFullscreenStrategy","restoreOldWindowedStyle","demangle","demangleAll","ExitStatus","getEnvStrings","doReadv","doWritev","promiseMap","uncaughtExceptionCount","exceptionLast","exceptionCaught","ExceptionInfo","Browser","wget","SYSCALLS","preloadPlugins","FS_createPreloadedFile","FS_modeStringToFlags","FS_getMode","FS_stdin_getChar_buffer","FS_stdin_getChar","FS","MEMFS","TTY","PIPEFS","SOCKFS","tempFixedLengthArray","miniTempWebGLFloatBuffers","miniTempWebGLIntBuffers","GL","emscripten_webgl_power_preferences","AL","GLUT","EGL","GLEW","IDBStore","SDL","SDL_gfx","GLFW","allocateUTF8","allocateUTF8OnStack","InternalError","BindingError","throwInternalError","throwBindingError","registeredTypes","awaitingDependencies","typeDependencies","tupleRegistrations","structRegistrations","sharedRegisterType","whenDependentTypesAreResolved","embind_charCodes","embind_init_charCodes","readLatin1String","getTypeName","heap32VectorToArray","requireRegisteredType","UnboundTypeError","PureVirtualError","init_embind","throwUnboundTypeError","ensureOverloadTable","exposePublicSymbol","replacePublicSymbol","extendError","createNamedFunction","embindRepr","registeredInstances","getBasestPointer","getInheritedInstance","getInheritedInstanceCount","getLiveInheritedInstances","registeredPointers","registerType","getShiftFromSize","integerReadValueFromPointer","floatReadValueFromPointer","simpleReadValueFromPointer","runDestructors","newFunc","craftInvokerFunction","embind__requireFunction","genericPointerToWireType","constNoSmartPtrRawPointerToWireType","nonConstNoSmartPtrRawPointerToWireType","init_RegisteredPointer","RegisteredPointer","RegisteredPointer_getPointee","RegisteredPointer_destructor","RegisteredPointer_deleteObject","RegisteredPointer_fromWireType","runDestructor","releaseClassHandle","finalizationRegistry","detachFinalizer_deps","detachFinalizer","attachFinalizer","makeClassHandle","init_ClassHandle","ClassHandle","ClassHandle_isAliasOf","throwInstanceAlreadyDeleted","ClassHandle_clone","ClassHandle_delete","deletionQueue","ClassHandle_isDeleted","ClassHandle_deleteLater","flushPendingDeletes","delayFunction","setDelayFunction","RegisteredClass","shallowCopyInternalPointer","downcastPointer","upcastPointer","validateThis","char_0","char_9","makeLegalFunctionName","emval_handles","emval_symbols","init_emval","count_emval_handles","getStringOrSymbol","Emval","emval_newers","emval_methodCallers","emval_registeredMethods"];T8.forEach(sn);var XR;Ue=function u(){XR||JB(),XR||(Ue=u)};function N8(){xB(),It()}function JB(){if(Oe>0||(N8(),Jt(),Oe>0))return;function u(){XR||(XR=!0,i.calledRun=!0,!k&&(Wt(),n(i),i.onRuntimeInitialized&&i.onRuntimeInitialized(),c(!i._main,'compiled without a main, but one is present. if you added it from JS, use Module["onRuntimeInitialized"]'),Ft()))}i.setStatus?(i.setStatus("Running..."),setTimeout(function(){setTimeout(function(){i.setStatus("")},1),u()},1)):u(),gt()}if(i.preInit)for(typeof i.preInit=="function"&&(i.preInit=[i.preInit]);i.preInit.length>0;)i.preInit.pop()();return JB(),e.ready}})(),GC=Sht});var dv,mv=O(()=>{lv();globalThis.Buffer=globalThis.Buffer||{};dv=(GC.hasOwnProperty("then")?GC:Promise.resolve(GC())).then(t=>{let e={find_nearby_indices:{rval:"boolean",params:["number","number"]},getCoveragePositions:{rval:null,params:["number","number","number","number","number"]},inflateEllipsoid:{rval:null,params:["number"]}},i={wasm:t};return Object.keys(e).forEach(n=>{i[n]=e[n].params?t.cwrap(n,e[n].rval,e[n].params):t.cwrap(n,e[n].rval)}),i})});var Vht,KS,fv,Lfe,Ev=O(()=>{mv();Vt();Vr();({FinalizationRegistry:Vht}=globalThis),KS={_previousLoad:!1,_instance:void 0,_wasmModule:void 0,_positionPointer:-1,_precisionMode:75,async initInstance(){let t="default";if(!this._previousLoad)try{this._wasmModule=(await dv).wasm,this._previousLoad=!0}catch(e){throw new Y(`Failed to load the WASM module: ${e.message}`)}if(!this._instance){let{PositionRegistry:e}=this._wasmModule;this._instance=new e(t)}return{instance:this._instance,wasmModule:this._wasmModule}},get instance(){return this._instance},get wasmModule(){return this._wasmModule},get positionPointer(){return this._positionPointer},update(t){if(!this._instance)return 0;let e=Math.round(t/this._precisionMode)*this._precisionMode;return this._lastUpdate!==e&&(this._lastUpdate=e,this._positionPointer=this._instance.update(e)),this._positionPointer||0},updateJulianDate(t){if(!this._instance)return 0;if(!(t instanceof Ze))throw new TypeError("Expected julianDate to be an instance of JulianDate");let e=Ze.toDate(t).getTime();return this.update(e)},get precisionMode(){return this._precisionMode},set precisionMode(t){if(typeof t!="number"||t<=0)throw new TypeError("Precision mode must be a positive number.");this._precisionMode=t}},fv={},Lfe=new Vht(t=>{let e=fv[t];e&&(KS._wasmModule.wasm.removePosition(e),delete fv[t],console.log(`Entity with ID ${t} has been garbage collected, pointer ${e}`))})});function _v(t){let e=[],i=t.properties.CAT.getValue(),n=t.properties.OMM.getValue(),s=n.SEMI_MAJOR_AXIS;if(i.PERIOD<128*60&&n.ECCENTRICITY<.25&&e.push(Ni.LEO),s>36e3){let o=Ze.now(),r=Ze.addMinutes(o,1440,new Ze),a=10,h=1/0,A=-1/0;for(let d=o;Ze.lessThan(d,r);d=Ze.addMinutes(d,a,new Ze)){let f=t.position.getValue(d),{latitude:E}=ut.fromCartesian(f,ot.WGS84)||{latitude:0},_=L.toDegrees(E);h=Math.min(h,_),A=Math.max(A,_)}i.PERIOD>XS-60&&i.PERIOD<XS+60&&(n.INCLINATION<1?e.push(Ni.GEO):e.push(Ni.GEOSYNC)),n.INCLINATION>=25&&n.INCLINATION<=180&&s>=37948&&s<=46380&&n.ECCENTRICITY<=.25&&e.push(Ni.IGO),n.INCLINATION>=0&&n.INCLINATION<=25&&s>=37948&&s<=46380&&n.ECCENTRICITY<=.25&&e.push(Ni.EGO),h>=-15&&A<=15&&i.PERIGEE>=35586&&i.PERIGEE<=35986&&e.push(Ni.GEOIADC)}return i.PERIGEE>=2e3&&i.PERIGEE<35700?e.push(Ni.MEO):i.PERIGEE>35786&&e.push(Ni.HEO),n.INCLINATION>97&&n.INCLINATION<99&&e.push(Ni.SUNSYNC),Math.abs(i.PERIOD-.5*XS)<1&&e.push(Ni.SEMISYNC),n.INCLINATION>=80&&n.INCLINATION<=100&&e.push(Ni.POLAR),e.length===0&&e.push(Ni.UNKNOWN),e}var Ni,XS,Rv=O(()=>{Vr();_e();ri();Ve();Ni={LEO:"Low Earth Orbit",MEO:"Medium Earth Orbit",HEO:"Highly Elliptical Orbit",GEO:"Geostationary Orbit",IGO:"Inclined Geosynchronous Orbit",EGO:"Extended Geostationary Orbit",GEOIADC:"IADC GEO Protected Region",GEOSYNC:"Geosynchronous Orbit",SUNSYNC:"Sun Synchronous Orbit",SEMISYNC:"Semi Synchronous Orbit",POLAR:"POLAR Orbit",UNKNOWN:"UNKNOWN"},XS=86164.0905});function Cf(t,e){this._callback=void 0,this._isConstant=void 0,this._definitionChanged=new We,this.setCallback(t,e)}var Zv,Iv=O(()=>{mt();Vt();xi();Object.defineProperties(Cf.prototype,{isConstant:{get:function(){return this._isConstant}},definitionChanged:{get:function(){return this._definitionChanged}}});Cf.prototype.getValue=function(t,e){return this._callback(t,e)};Cf.prototype.setCallback=function(t,e){if(!m(t))throw new Y("callback is required.");if(!m(e))throw new Y("isConstant is required.");let i=this._callback!==t||this._isConstant!==e;this._callback=t,this._isConstant=e,i&&this._definitionChanged.raiseEvent(this)};Cf.prototype.equals=function(t){return this===t||t instanceof Cf&&this._callback===t._callback&&this._isConstant===t._isConstant};Zv=Cf});var qS,pv,uv=O(()=>{Qn();cp();Ht();Vt();Gb();Iv();qS=class extends S_{constructor(e){if(!(e.sdc instanceof S_)||!e.sdc._wasmModule)throw new Y("Invalid SpaceCatalogDataSource");super(`${e.sdc.name}_coverageGroup`),this.objectList=[],this.sdc=e.sdc,this.sdc.entities.collectionChanged.addEventListener((i,n,s,o)=>{for(let r=0;r<s.length;r++)~this.objectList.indexOf(s[r])&&this.remove(s[r]);for(let r=0;r<n.length;r++)!~this.objectList.indexOf(n[r])&&n[r]._coverageShowing&&this.push(n[r])}),this.coverageType=e.coverageType||0,this.color=e.color||Zt.fromRandom({alpha:.3}),this.groundCoverageOnly=e.groundCoverageOnly||!1,this.angle=e.angle,this.lastIntersectionTime=null,this.cachedPositions=[],this.wasmModule=this.sdc._wasmModule,this.samples=e.samples||10,this.ecefPointer=this.wasmModule._malloc(24),this.ecefPoints=new Float64Array(this.wasmModule.HEAP8.buffer,this.ecefPointer,3),this.positions=new Float64Array(this.wasmModule.HEAP8.buffer,this.posArrayPointer,this._size),this.result=new l,this.ph=new sf,this.c3array=[]}get viewer(){return this._viewer}get samples(){return this._samples}set samples(e){this._samples=e,this._size=6*this._samples,this._bytesSize=this._size*8,this.posArrayPointer&&this.wasmModule._free(this.posArrayPointer),this.posArrayPointer=this.wasmModule._malloc(this._bytesSize),this.positions=new Float64Array(this.wasmModule.HEAP8.buffer,this.posArrayPointer,this._size)}createGeometry(){let e="noclick:CoverageEntity";if(this.ph.satpos=[],!this.entities.getById(e)){let i=this.entities.add({id:e,polygon:{hierarchy:new Zv(n=>{this.ph.positionsArray=[],this.ph.positions=[];for(let s=0;s<this.objectList.length;++s)if(this.objectList[s].show){if(this.c3array=[],this.result=this.objectList[s].position.getValue(n,this.result,!1),this.modelMatrix=this.objectList[s].computeModelMatrix(n),l.pack(this.result,this.ecefPoints),this.wasmModule.getCoveragePositions(this.ecefPointer,this.coverageType,this.angle,this.samples,this.posArrayPointer),this.positions.length%3===0){let o=l.unpackArray(this.positions,this.c3array);this.ph.positionsArray[s]=o}else continue;this.groundCoverageOnly||(this.ph.satpos[s]=l.clone(this.result))}return this.ph},!1),perPositionHeight:!0,material:this.color},properties:{unselectable:!0}});Object.defineProperties(i,{show:{get:()=>!0,set:()=>{}}})}}getById(e){return this.objectList.filter(i=>i.id===e)}push(e){this.objectList.filter(i=>i.id===e.id).length||(this.objectList.push(e),this.createGeometry())}remove(e){this.objectList=this.objectList.filter(i=>i.id!==e.id),Object.defineProperties(e,{show:{configurable:!0,get:()=>e._show,set:i=>{e._show=i}}}),this.createGeometry()}},pv=qS});var ZEe,IEe,pEe,Ght,BC,Cv=O(()=>{ic();Gb();cv();Qn();Ht();IE();Vm();Ev();Rv();uv();ih();Vt();Z3();zS();({OMMT:ZEe,OMMCOLLECTIONT:IEe}=rd),{CATT:pEe,CATCOLLECTIONT:Ght}=ed,BC=class extends S_{constructor(e={name=Gs(),referenceFrame=$i.FIXED,calcVelocity=!1,entityDefault={}}={}){super(e.name),this._viewer=void 0,this.OMM=null,this.CATRAW=null,this.CAT=null,this.COMBINEDOMMCAT=[],this.lastLoaded=null,this.options=e,this._wasmModule=null,this._registered=!1,this._entityCollection.referenceFrame=$i.FIXED,this._entityCollection.calcVelocity=e.calcVelocity||!1;let i=(n,s,o,r)=>{o.filter(a=>a.properties?.pointer).forEach(a=>{this._wasmModule.removeEntity(a.properties.pointer)}),this._entityCollection.referenceFrame=this._viewer?.scene.referenceFrame||this._entityCollection.referenceFrame};this._entityCollection.collectionChanged.addEventListener(i,this),this._orbits={[Ni.LEO]:[],[Ni.MEO]:[],[Ni.HEO]:[],[Ni.GEO]:[],[Ni.IGO]:[],[Ni.EGO]:[],[Ni.GEOIADC]:[],[Ni.GEOSYNC]:[],[Ni.SUNSYNC]:[],[Ni.SEMISYNC]:[],[Ni.POLAR]:[],[Ni.UNKNOWN]:[]}}onAdd(e){~e.getByName(this._coverageGroup.name).length&&e.add(this._coverageGroup)}onRemove(e){e.getByName(this._coverageGroup.name).length&&e.remove(this._coverageGroup)}async load(e){return await this.loadOMM(e,"tle")}loadOMM(e,i,n=!1){if(!e)throw new Y('The parameter "omm" is required.');if(!i)throw new Y('The parameter "satcat" is required.');return new Promise(async s=>{let o=await KS.initInstance();if(this._wasmModule=o.wasmModule,this._coverageGroup=this._coverageGroup||new pv({samples:72,sdc:this,coverageType:1,angle:90,groundCoverageOnly:!1,color:Zt.LIMEGREEN.withAlpha(.5)}),this.entities.suspendEvents(),this._wasmSatelliteCatalog=this._wasmSatelliteCatalog||o.instance,(e instanceof ArrayBuffer||e instanceof Uint8Array)&&(e instanceof ArrayBuffer&&(e=new Uint8Array(e)),this.OMM=Mb(e,"OMM",rd)),(e.RECORDS||Array.isArray(e))&&(this.OMM={RECORDS:e?.RECORDS||e}),!this.OMM)throw Error("OMMCOLLECTIONT invalid");let r=[];this.CAT=new Ght,(i instanceof ArrayBuffer||e instanceof Uint8Array)&&(i instanceof ArrayBuffer&&(i=new Uint8Array(i)),this.CATRAW=Mb(i,"CAT",ed)),(i.RECORDS||Array.isArray(i))&&(this.CATRAW={RECORDS:i?.RECORDS||i});for(let a=0;a<this.CATRAW.RECORDS.length;a++)r[this.CATRAW.RECORDS[a].NORAD_CAT_ID]=a;for(let a=0;a<this.OMM.RECORDS.length;a++){let h=this.OMM.RECORDS[a];this.CAT.RECORDS[a]=this.CATRAW.RECORDS[r[h.NORAD_CAT_ID]],this.COMBINEDOMMCAT[a]={};for(let f in h)h.hasOwnProperty(f)&&(this.COMBINEDOMMCAT[a][f]=h[f]);for(let f in this.CAT.RECORDS[a])this.CAT.RECORDS[a].hasOwnProperty(f)&&(this.COMBINEDOMMCAT[a][f]=this.CAT.RECORDS[a][f]);let A,d=h.NORAD_CAT_ID;if(A=this.entities.getById(d))A.loadOMM(h);else{let f={id:d,name:this.CAT.RECORDS[a]?.OBJECT_NAME||d,properties:{INDEX:a,CAT:this.CAT.RECORDS[a],OMM:h},point:{pixelSize:1,scaleByDistance:null},label:{show:!1,text:`${h.OBJECT_ID.toString().padStart(5,0)}`,font:"1rem Helvetica",showBackground:!0,horizontalOrigin:to.LEFT,backgroundColor:new Zt(.1,.1,.1,.9),pixelOffset:new l(10,0),scaleByDistance:new gi(150,1.5,13e7,0),pixelOffsetScaleByDistance:new gi(150,3,15e6,.5)}};for(let E in this.options.entityDefault)this.options.entityDefault[E]&&(f[E]=Object.assign({},f[E]||{},this.options.entityDefault[E]));if(f&&this._wasmModule&&h)try{let E=new VC(f,this._wasmModule,this._wasmSatelliteCatalog,h);A=this.entities.add(E,a);let{APOGEE:_,PERIGEE:R}=E.properties.CAT.getValue(),{SEMI_MAJOR_AXIS:I,SEMI_MINOR_AXIS:C}=E.properties.OMM.getValue(),{ECCENTRICITY:N}=E.properties.OMM.getValue();_/=1e3,R/=1e3,this.CAT.RECORDS[a]&&(this.CAT.RECORDS[a].APOGEE=_,this.CAT.RECORDS[a].PERIGEE=R),this.OMM.RECORDS[a]&&(this.OMM.RECORDS[a].SEMI_MAJOR_AXIS=I,this.OMM.RECORDS[a].SEMI_MINOR_AXIS=C,this.OMM.RECORDS[a].ECCENTRICITY=N),this.COMBINEDOMMCAT[a]={...this.COMBINEDOMMCAT[a],APOGEE:_,PERIGEE:R,SEMI_MAJOR_AXIS:I,SEMI_MINOR_AXIS:C,ECCENTRICITY:N}}catch(E){globalThis.error||(console.log(E),globalThis.error=E)}}}this.entities._suspendCount&&this.entities.resumeEvents(),this.entities.referenceFrame=this._viewer?.scene.referenceFrame,s(this)})}getEntitiesByOrbitType(e){return this._orbits[e]}categorizeSatellites(){for(let e in Ni)this._orbits[e]&&(this._orbits[e]=[]);for(let e=0;e<this.entities.values.length;e++){let i=this.entities.values[e],n=_v(i);for(let s in n)if(n[s]){let o=n[s];o===Ni.LEO?this.LEO.push(i):o===Ni.MEO?this.MEO.push(i):o===Ni.HEO?this.HEO.push(i):o===Ni.GEO?this.GEO.push(i):o===Ni.IGO?this.IGO.push(i):o===Ni.EGO?this.EGO.push(i):o===Ni.GEOIADC?this.GEOIADC.push(i):o===Ni.GEOSYNC?this.GEOSYNC.push(i):o===Ni.SUNSYNC?this.SUNSYNC.push(i):o===Ni.SEMISYNC?this.SEMISYNC.push(i):o===Ni.POLAR?this.POLAR.push(i):o===Ni.UNKNOWN&&this.UNKNOWN.push(i)}}}}});var $S={};He($S,{default:()=>Wht});async function Bht(t){let{transferEntities:e,screeningObjectIds:i}=t,n=[],{OMM:s,CAT:o}=e,r=new BC({name:"workerCatalog"});await r.loadOMM(s,o);let a=r._wasmSatelliteCatalog.conjunctionAssessment(t.start,t.stop,t.step,t.radius,i);for(let h=0;h<a.size();h++){let A=a.get(h);n.push({primary:A.primary.catalogNumber,secondary:A.secondary.catalogNumber,TCA:A.TCA,distance:A.distance})}return n}var Wht,tO=O(()=>{Ns();Cv();Wht=Wi(Bht)});var eO={};He(eO,{default:()=>Mht});function Dht(t,e){let i=TA.unpackCombineGeometryParameters(t),n=TA.combineGeometry(i);return TA.packCombineGeometryResults(n,e)}var Mht,iO=O(()=>{KI();Ns();Mht=Wi(Dht)});function gr(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.minimum,i=t.maximum;if(p.typeOf.object("min",e),p.typeOf.object("max",i),m(t.offsetAttribute)&&t.offsetAttribute===Pe.TOP)throw new Y("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");let n=Z(t.vertexFormat,Ot.DEFAULT);this._minimum=l.clone(e),this._maximum=l.clone(i),this._vertexFormat=n,this._offsetAttribute=t.offsetAttribute,this._workerName="createBoxGeometry"}var Uht,Tv,Nv,bv,gv,nO,cR,sO=O(()=>{_i();Ht();ae();oi();bt();mt();Vt();yi();ji();En();go();Xi();Ls();Uht=new l;gr.fromDimensions=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.dimensions;p.typeOf.object("dimensions",e),p.typeOf.number.greaterThanOrEquals("dimensions.x",e.x,0),p.typeOf.number.greaterThanOrEquals("dimensions.y",e.y,0),p.typeOf.number.greaterThanOrEquals("dimensions.z",e.z,0);let i=l.multiplyByScalar(e,.5,new l);return new gr({minimum:l.negate(i,new l),maximum:i,vertexFormat:t.vertexFormat,offsetAttribute:t.offsetAttribute})};gr.fromAxisAlignedBoundingBox=function(t){return p.typeOf.object("boundingBox",t),new gr({minimum:t.minimum,maximum:t.maximum})};gr.packedLength=2*l.packedLength+Ot.packedLength+1;gr.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),l.pack(t._minimum,e,i),l.pack(t._maximum,e,i+l.packedLength),Ot.pack(t._vertexFormat,e,i+2*l.packedLength),e[i+2*l.packedLength+Ot.packedLength]=Z(t._offsetAttribute,-1),e};Tv=new l,Nv=new l,bv=new Ot,gv={minimum:Tv,maximum:Nv,vertexFormat:bv,offsetAttribute:void 0};gr.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=l.unpack(t,e,Tv),s=l.unpack(t,e+l.packedLength,Nv),o=Ot.unpack(t,e+2*l.packedLength,bv),r=t[e+2*l.packedLength+Ot.packedLength];return m(i)?(i._minimum=l.clone(n,i._minimum),i._maximum=l.clone(s,i._maximum),i._vertexFormat=Ot.clone(o,i._vertexFormat),i._offsetAttribute=r===-1?void 0:r,i):(gv.offsetAttribute=r===-1?void 0:r,new gr(gv))};gr.createGeometry=function(t){let e=t._minimum,i=t._maximum,n=t._vertexFormat;if(l.equals(e,i))return;let s=new we,o,r;if(n.position&&(n.st||n.normal||n.tangent||n.bitangent)){if(n.position&&(r=new Float64Array(6*4*3),r[0]=e.x,r[1]=e.y,r[2]=i.z,r[3]=i.x,r[4]=e.y,r[5]=i.z,r[6]=i.x,r[7]=i.y,r[8]=i.z,r[9]=e.x,r[10]=i.y,r[11]=i.z,r[12]=e.x,r[13]=e.y,r[14]=e.z,r[15]=i.x,r[16]=e.y,r[17]=e.z,r[18]=i.x,r[19]=i.y,r[20]=e.z,r[21]=e.x,r[22]=i.y,r[23]=e.z,r[24]=i.x,r[25]=e.y,r[26]=e.z,r[27]=i.x,r[28]=i.y,r[29]=e.z,r[30]=i.x,r[31]=i.y,r[32]=i.z,r[33]=i.x,r[34]=e.y,r[35]=i.z,r[36]=e.x,r[37]=e.y,r[38]=e.z,r[39]=e.x,r[40]=i.y,r[41]=e.z,r[42]=e.x,r[43]=i.y,r[44]=i.z,r[45]=e.x,r[46]=e.y,r[47]=i.z,r[48]=e.x,r[49]=i.y,r[50]=e.z,r[51]=i.x,r[52]=i.y,r[53]=e.z,r[54]=i.x,r[55]=i.y,r[56]=i.z,r[57]=e.x,r[58]=i.y,r[59]=i.z,r[60]=e.x,r[61]=e.y,r[62]=e.z,r[63]=i.x,r[64]=e.y,r[65]=e.z,r[66]=i.x,r[67]=e.y,r[68]=i.z,r[69]=e.x,r[70]=e.y,r[71]=i.z,s.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:r})),n.normal){let A=new Float32Array(72);A[0]=0,A[1]=0,A[2]=1,A[3]=0,A[4]=0,A[5]=1,A[6]=0,A[7]=0,A[8]=1,A[9]=0,A[10]=0,A[11]=1,A[12]=0,A[13]=0,A[14]=-1,A[15]=0,A[16]=0,A[17]=-1,A[18]=0,A[19]=0,A[20]=-1,A[21]=0,A[22]=0,A[23]=-1,A[24]=1,A[25]=0,A[26]=0,A[27]=1,A[28]=0,A[29]=0,A[30]=1,A[31]=0,A[32]=0,A[33]=1,A[34]=0,A[35]=0,A[36]=-1,A[37]=0,A[38]=0,A[39]=-1,A[40]=0,A[41]=0,A[42]=-1,A[43]=0,A[44]=0,A[45]=-1,A[46]=0,A[47]=0,A[48]=0,A[49]=1,A[50]=0,A[51]=0,A[52]=1,A[53]=0,A[54]=0,A[55]=1,A[56]=0,A[57]=0,A[58]=1,A[59]=0,A[60]=0,A[61]=-1,A[62]=0,A[63]=0,A[64]=-1,A[65]=0,A[66]=0,A[67]=-1,A[68]=0,A[69]=0,A[70]=-1,A[71]=0,s.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:A})}if(n.st){let A=new Float32Array(48);A[0]=0,A[1]=0,A[2]=1,A[3]=0,A[4]=1,A[5]=1,A[6]=0,A[7]=1,A[8]=1,A[9]=0,A[10]=0,A[11]=0,A[12]=0,A[13]=1,A[14]=1,A[15]=1,A[16]=0,A[17]=0,A[18]=1,A[19]=0,A[20]=1,A[21]=1,A[22]=0,A[23]=1,A[24]=1,A[25]=0,A[26]=0,A[27]=0,A[28]=0,A[29]=1,A[30]=1,A[31]=1,A[32]=1,A[33]=0,A[34]=0,A[35]=0,A[36]=0,A[37]=1,A[38]=1,A[39]=1,A[40]=0,A[41]=0,A[42]=1,A[43]=0,A[44]=1,A[45]=1,A[46]=0,A[47]=1,s.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:A})}if(n.tangent){let A=new Float32Array(72);A[0]=1,A[1]=0,A[2]=0,A[3]=1,A[4]=0,A[5]=0,A[6]=1,A[7]=0,A[8]=0,A[9]=1,A[10]=0,A[11]=0,A[12]=-1,A[13]=0,A[14]=0,A[15]=-1,A[16]=0,A[17]=0,A[18]=-1,A[19]=0,A[20]=0,A[21]=-1,A[22]=0,A[23]=0,A[24]=0,A[25]=1,A[26]=0,A[27]=0,A[28]=1,A[29]=0,A[30]=0,A[31]=1,A[32]=0,A[33]=0,A[34]=1,A[35]=0,A[36]=0,A[37]=-1,A[38]=0,A[39]=0,A[40]=-1,A[41]=0,A[42]=0,A[43]=-1,A[44]=0,A[45]=0,A[46]=-1,A[47]=0,A[48]=-1,A[49]=0,A[50]=0,A[51]=-1,A[52]=0,A[53]=0,A[54]=-1,A[55]=0,A[56]=0,A[57]=-1,A[58]=0,A[59]=0,A[60]=1,A[61]=0,A[62]=0,A[63]=1,A[64]=0,A[65]=0,A[66]=1,A[67]=0,A[68]=0,A[69]=1,A[70]=0,A[71]=0,s.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:A})}if(n.bitangent){let A=new Float32Array(72);A[0]=0,A[1]=1,A[2]=0,A[3]=0,A[4]=1,A[5]=0,A[6]=0,A[7]=1,A[8]=0,A[9]=0,A[10]=1,A[11]=0,A[12]=0,A[13]=1,A[14]=0,A[15]=0,A[16]=1,A[17]=0,A[18]=0,A[19]=1,A[20]=0,A[21]=0,A[22]=1,A[23]=0,A[24]=0,A[25]=0,A[26]=1,A[27]=0,A[28]=0,A[29]=1,A[30]=0,A[31]=0,A[32]=1,A[33]=0,A[34]=0,A[35]=1,A[36]=0,A[37]=0,A[38]=1,A[39]=0,A[40]=0,A[41]=1,A[42]=0,A[43]=0,A[44]=1,A[45]=0,A[46]=0,A[47]=1,A[48]=0,A[49]=0,A[50]=1,A[51]=0,A[52]=0,A[53]=1,A[54]=0,A[55]=0,A[56]=1,A[57]=0,A[58]=0,A[59]=1,A[60]=0,A[61]=0,A[62]=1,A[63]=0,A[64]=0,A[65]=1,A[66]=0,A[67]=0,A[68]=1,A[69]=0,A[70]=0,A[71]=1,s.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:A})}o=new Uint16Array(6*2*3),o[0]=0,o[1]=1,o[2]=2,o[3]=0,o[4]=2,o[5]=3,o[6]=6,o[7]=5,o[8]=4,o[9]=7,o[10]=6,o[11]=4,o[12]=8,o[13]=9,o[14]=10,o[15]=8,o[16]=10,o[17]=11,o[18]=14,o[19]=13,o[20]=12,o[21]=15,o[22]=14,o[23]=12,o[24]=18,o[25]=17,o[26]=16,o[27]=19,o[28]=18,o[29]=16,o[30]=20,o[31]=21,o[32]=22,o[33]=20,o[34]=22,o[35]=23}else r=new Float64Array(8*3),r[0]=e.x,r[1]=e.y,r[2]=e.z,r[3]=i.x,r[4]=e.y,r[5]=e.z,r[6]=i.x,r[7]=i.y,r[8]=e.z,r[9]=e.x,r[10]=i.y,r[11]=e.z,r[12]=e.x,r[13]=e.y,r[14]=i.z,r[15]=i.x,r[16]=e.y,r[17]=i.z,r[18]=i.x,r[19]=i.y,r[20]=i.z,r[21]=e.x,r[22]=i.y,r[23]=i.z,s.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:r}),o=new Uint16Array(6*2*3),o[0]=4,o[1]=5,o[2]=6,o[3]=4,o[4]=6,o[5]=7,o[6]=1,o[7]=0,o[8]=3,o[9]=1,o[10]=3,o[11]=2,o[12]=1,o[13]=6,o[14]=5,o[15]=1,o[16]=2,o[17]=6,o[18]=2,o[19]=3,o[20]=7,o[21]=2,o[22]=7,o[23]=6,o[24]=3,o[25]=0,o[26]=4,o[27]=3,o[28]=4,o[29]=7,o[30]=0,o[31]=1,o[32]=5,o[33]=0,o[34]=5,o[35]=4;let a=l.subtract(i,e,Uht),h=l.magnitude(a)*.5;if(m(t._offsetAttribute)){let A=r.length,d=t._offsetAttribute===Pe.NONE?0:1,f=new Uint8Array(A/3).fill(d);s.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:f})}return new se({attributes:s,indices:o,primitiveType:ne.TRIANGLES,boundingSphere:new Nt(l.ZERO,h),offsetAttribute:t._offsetAttribute})};gr.getUnitBox=function(){return m(nO)||(nO=gr.createGeometry(gr.fromDimensions({dimensions:new l(1,1,1),vertexFormat:Ot.POSITION_ONLY}))),nO};cR=gr});var oO={};He(oO,{default:()=>kht});function Qht(t,e){return m(e)&&(t=cR.unpack(t,e)),cR.createGeometry(t)}var kht,rO=O(()=>{sO();mt();kht=Qht});function SA(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.minimum,i=t.maximum;if(p.typeOf.object("min",e),p.typeOf.object("max",i),m(t.offsetAttribute)&&t.offsetAttribute===Pe.TOP)throw new Y("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");this._min=l.clone(e),this._max=l.clone(i),this._offsetAttribute=t.offsetAttribute,this._workerName="createBoxOutlineGeometry"}var Lht,Yv,Sv,Fv,aO,Ov=O(()=>{_i();Ht();ae();oi();bt();mt();Vt();yi();ji();En();go();Xi();Lht=new l;SA.fromDimensions=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.dimensions;p.typeOf.object("dimensions",e),p.typeOf.number.greaterThanOrEquals("dimensions.x",e.x,0),p.typeOf.number.greaterThanOrEquals("dimensions.y",e.y,0),p.typeOf.number.greaterThanOrEquals("dimensions.z",e.z,0);let i=l.multiplyByScalar(e,.5,new l);return new SA({minimum:l.negate(i,new l),maximum:i,offsetAttribute:t.offsetAttribute})};SA.fromAxisAlignedBoundingBox=function(t){return p.typeOf.object("boundindBox",t),new SA({minimum:t.minimum,maximum:t.maximum})};SA.packedLength=2*l.packedLength+1;SA.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),l.pack(t._min,e,i),l.pack(t._max,e,i+l.packedLength),e[i+l.packedLength*2]=Z(t._offsetAttribute,-1),e};Yv=new l,Sv=new l,Fv={minimum:Yv,maximum:Sv,offsetAttribute:void 0};SA.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=l.unpack(t,e,Yv),s=l.unpack(t,e+l.packedLength,Sv),o=t[e+l.packedLength*2];return m(i)?(i._min=l.clone(n,i._min),i._max=l.clone(s,i._max),i._offsetAttribute=o===-1?void 0:o,i):(Fv.offsetAttribute=o===-1?void 0:o,new SA(Fv))};SA.createGeometry=function(t){let e=t._min,i=t._max;if(l.equals(e,i))return;let n=new we,s=new Uint16Array(12*2),o=new Float64Array(8*3);o[0]=e.x,o[1]=e.y,o[2]=e.z,o[3]=i.x,o[4]=e.y,o[5]=e.z,o[6]=i.x,o[7]=i.y,o[8]=e.z,o[9]=e.x,o[10]=i.y,o[11]=e.z,o[12]=e.x,o[13]=e.y,o[14]=i.z,o[15]=i.x,o[16]=e.y,o[17]=i.z,o[18]=i.x,o[19]=i.y,o[20]=i.z,o[21]=e.x,o[22]=i.y,o[23]=i.z,n.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:o}),s[0]=4,s[1]=5,s[2]=5,s[3]=6,s[4]=6,s[5]=7,s[6]=7,s[7]=4,s[8]=0,s[9]=1,s[10]=1,s[11]=2,s[12]=2,s[13]=3,s[14]=3,s[15]=0,s[16]=0,s[17]=4,s[18]=1,s[19]=5,s[20]=2,s[21]=6,s[22]=3,s[23]=7;let r=l.subtract(i,e,Lht),a=l.magnitude(r)*.5;if(m(t._offsetAttribute)){let h=o.length,A=t._offsetAttribute===Pe.NONE?0:1,d=new Uint8Array(h/3).fill(A);n.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:d})}return new se({attributes:n,indices:s,primitiveType:ne.LINES,boundingSphere:new Nt(l.ZERO,a),offsetAttribute:t._offsetAttribute})};aO=SA});var AO={};He(AO,{default:()=>wht});function yht(t,e){return m(e)&&(t=aO.unpack(t,e)),aO.createGeometry(t)}var wht,hO=O(()=>{Ov();mt();wht=yht});function gf(t,e,i,n,s,o,r,a,h,A){let d=t+e;l.multiplyByScalar(n,Math.cos(d),WC),l.multiplyByScalar(i,Math.sin(d),Vv),l.add(WC,Vv,WC);let f=Math.cos(t);f=f*f;let E=Math.sin(t);E=E*E;let R=o/Math.sqrt(r*f+s*E)/a;return Ae.fromAxisAngle(WC,R,Gv),lt.fromQuaternion(Gv,Bv),lt.multiplyByVector(Bv,h,A),l.normalize(A,A),l.multiplyByScalar(A,a,A),A}var lO,WC,Vv,Gv,Bv,Wv,Dv,cO,xht,Pht,Jht,jht,ya,dO=O(()=>{Ht();_e();dn();$s();lO={},WC=new l,Vv=new l,Gv=new Ae,Bv=new lt;Wv=new l,Dv=new l,cO=new l,xht=new l;lO.raisePositionsToHeight=function(t,e,i){let n=e.ellipsoid,s=e.height,o=e.extrudedHeight,r=i?t.length/3*2:t.length/3,a=new Float64Array(r*3),h=t.length,A=i?h:0;for(let d=0;d<h;d+=3){let f=d+1,E=d+2,_=l.fromArray(t,d,Wv);n.scaleToGeodeticSurface(_,_);let R=l.clone(_,Dv),I=n.geodeticSurfaceNormal(_,xht),C=l.multiplyByScalar(I,s,cO);l.add(_,C,_),i&&(l.multiplyByScalar(I,o,C),l.add(R,C,R),a[d+A]=R.x,a[f+A]=R.y,a[E+A]=R.z),a[d]=_.x,a[f]=_.y,a[E]=_.z}return a};Pht=new l,Jht=new l,jht=new l;lO.computeEllipsePositions=function(t,e,i){let n=t.semiMinorAxis,s=t.semiMajorAxis,o=t.rotation,r=t.center,a=t.granularity*8,h=n*n,A=s*s,d=s*n,f=l.magnitude(r),E=l.normalize(r,Pht),_=l.cross(l.UNIT_Z,r,Jht);_=l.normalize(_,_);let R=l.cross(E,_,jht),I=1+Math.ceil(L.PI_OVER_TWO/a),C=L.PI_OVER_TWO/(I-1),N=L.PI_OVER_TWO-I*C;N<0&&(I-=Math.ceil(Math.abs(N)/C));let T=2*(I*(I+2)),F=e?new Array(T*3):void 0,b=0,G=Wv,M=Dv,Q=I*4*3,U=Q-1,k=0,y=i?new Array(Q):void 0,c,g,V,D,w;for(N=L.PI_OVER_TWO,G=gf(N,o,R,_,h,d,A,f,E,G),e&&(F[b++]=G.x,F[b++]=G.y,F[b++]=G.z),i&&(y[U--]=G.z,y[U--]=G.y,y[U--]=G.x),N=L.PI_OVER_TWO-C,c=1;c<I+1;++c){if(G=gf(N,o,R,_,h,d,A,f,E,G),M=gf(Math.PI-N,o,R,_,h,d,A,f,E,M),e){for(F[b++]=G.x,F[b++]=G.y,F[b++]=G.z,V=2*c+2,g=1;g<V-1;++g)D=g/(V-1),w=l.lerp(G,M,D,cO),F[b++]=w.x,F[b++]=w.y,F[b++]=w.z;F[b++]=M.x,F[b++]=M.y,F[b++]=M.z}i&&(y[U--]=G.z,y[U--]=G.y,y[U--]=G.x,y[k++]=M.x,y[k++]=M.y,y[k++]=M.z),N=L.PI_OVER_TWO-(c+1)*C}for(c=I;c>1;--c){if(N=L.PI_OVER_TWO-(c-1)*C,G=gf(-N,o,R,_,h,d,A,f,E,G),M=gf(N+Math.PI,o,R,_,h,d,A,f,E,M),e){for(F[b++]=G.x,F[b++]=G.y,F[b++]=G.z,V=2*(c-1)+2,g=1;g<V-1;++g)D=g/(V-1),w=l.lerp(G,M,D,cO),F[b++]=w.x,F[b++]=w.y,F[b++]=w.z;F[b++]=M.x,F[b++]=M.y,F[b++]=M.z}i&&(y[U--]=G.z,y[U--]=G.y,y[U--]=G.x,y[k++]=M.x,y[k++]=M.y,y[k++]=M.z)}N=L.PI_OVER_TWO,G=gf(-N,o,R,_,h,d,A,f,E,G);let x={};return e&&(F[b++]=G.x,F[b++]=G.y,F[b++]=G.z,x.positions=F,x.numPts=I),i&&(y[U--]=G.z,y[U--]=G.y,y[U--]=G.x,x.outerPositions=y),x};ya=lO});function Pv(t,e,i){let n=e.vertexFormat,s=e.center,o=e.semiMajorAxis,r=e.semiMinorAxis,a=e.ellipsoid,h=e.stRotation,A=i?t.length/3*2:t.length/3,d=e.shadowVolume,f=n.st?new Float32Array(A*2):void 0,E=n.normal?new Float32Array(A*3):void 0,_=n.tangent?new Float32Array(A*3):void 0,R=n.bitangent?new Float32Array(A*3):void 0,I=d?new Float32Array(A*3):void 0,C=0,N=Qv,T=kv,F=Lv,b=new Os(a),G=b.project(a.cartesianToCartographic(s,UC),yv),M=a.scaleToGeodeticSurface(s,Tf);a.geodeticSurfaceNormal(M,M);let Q=Uv,U=Hht;if(h!==0){let w=Ae.fromAxisAngle(M,h,EO);Q=lt.fromQuaternion(w,Q),w=Ae.fromAxisAngle(M,-h,EO),U=lt.fromQuaternion(w,U)}else Q=lt.clone(lt.IDENTITY,Q),U=lt.clone(lt.IDENTITY,U);let k=nt.fromElements(Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY,wv),y=nt.fromElements(Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY,xv),c=t.length,g=i?c:0,V=g/3*2;for(let w=0;w<c;w+=3){let x=w+1,H=w+2,j=l.fromArray(t,w,Tf);if(n.st){let X=lt.multiplyByVector(Q,j,mO),tt=b.project(a.cartesianToCartographic(X,UC),fO);l.subtract(tt,G,tt),Fs.x=(tt.x+o)/(2*o),Fs.y=(tt.y+r)/(2*r),k.x=Math.min(Fs.x,k.x),k.y=Math.min(Fs.y,k.y),y.x=Math.max(Fs.x,y.x),y.y=Math.max(Fs.y,y.y),i&&(f[C+V]=Fs.x,f[C+1+V]=Fs.y),f[C++]=Fs.x,f[C++]=Fs.y}(n.normal||n.tangent||n.bitangent||d)&&(N=a.geodeticSurfaceNormal(j,N),d&&(I[w+g]=-N.x,I[x+g]=-N.y,I[H+g]=-N.z),(n.normal||n.tangent||n.bitangent)&&((n.tangent||n.bitangent)&&(T=l.normalize(l.cross(l.UNIT_Z,N,T),T),lt.multiplyByVector(U,T,T)),n.normal&&(E[w]=N.x,E[x]=N.y,E[H]=N.z,i&&(E[w+g]=-N.x,E[x+g]=-N.y,E[H+g]=-N.z)),n.tangent&&(_[w]=T.x,_[x]=T.y,_[H]=T.z,i&&(_[w+g]=-T.x,_[x+g]=-T.y,_[H+g]=-T.z)),n.bitangent&&(F=l.normalize(l.cross(N,T,F),F),R[w]=F.x,R[x]=F.y,R[H]=F.z,i&&(R[w+g]=F.x,R[x+g]=F.y,R[H+g]=F.z))))}if(n.st){c=f.length;for(let w=0;w<c;w+=2)f[w]=(f[w]-k.x)/(y.x-k.x),f[w+1]=(f[w+1]-k.y)/(y.y-k.y)}let D=new we;if(n.position){let w=ya.raisePositionsToHeight(t,e,i);D.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:w})}if(n.st&&(D.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:f})),n.normal&&(D.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:E})),n.tangent&&(D.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_})),n.bitangent&&(D.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:R})),d&&(D.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:I})),i&&m(e.offsetAttribute)){let w=new Uint8Array(A);if(e.offsetAttribute===Pe.TOP)w=w.fill(1,0,A/2);else{let x=e.offsetAttribute===Pe.NONE?0:1;w=w.fill(x)}D.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:w})}return D}function Jv(t){let e=new Array(12*(t*(t+1))-6),i=0,n,s,o,r,a;for(n=0,o=1,r=0;r<3;r++)e[i++]=o++,e[i++]=n,e[i++]=o;for(r=2;r<t+1;++r){for(o=r*(r+1)-1,n=(r-1)*r-1,e[i++]=o++,e[i++]=n,e[i++]=o,s=2*r,a=0;a<s-1;++a)e[i++]=o,e[i++]=n++,e[i++]=n,e[i++]=o++,e[i++]=n,e[i++]=o;e[i++]=o++,e[i++]=n,e[i++]=o}for(s=t*2,++o,++n,r=0;r<s-1;++r)e[i++]=o,e[i++]=n++,e[i++]=n,e[i++]=o++,e[i++]=n,e[i++]=o;for(e[i++]=o,e[i++]=n++,e[i++]=n,e[i++]=o++,e[i++]=n++,e[i++]=n,++n,r=t-1;r>1;--r){for(e[i++]=n++,e[i++]=n,e[i++]=o,s=2*r,a=0;a<s-1;++a)e[i++]=o,e[i++]=n++,e[i++]=n,e[i++]=o++,e[i++]=n,e[i++]=o;e[i++]=n++,e[i++]=n++,e[i++]=o++}for(r=0;r<3;r++)e[i++]=n++,e[i++]=n,e[i++]=o;return e}function vht(t){let e=t.center;Ad=l.multiplyByScalar(t.ellipsoid.geodeticSurfaceNormal(e,Ad),t.height,Ad),Ad=l.add(e,Ad,Ad);let i=new Nt(Ad,t.semiMajorAxis),n=ya.computeEllipsePositions(t,!0,!1),s=n.positions,o=n.numPts,r=Pv(s,t,!1),a=Jv(o);return a=te.createTypedArray(s.length/3,a),{boundingSphere:i,attributes:r,indices:a}}function zht(t,e){let i=e.vertexFormat,n=e.center,s=e.semiMajorAxis,o=e.semiMinorAxis,r=e.ellipsoid,a=e.height,h=e.extrudedHeight,A=e.stRotation,d=t.length/3*2,f=new Float64Array(d*3),E=i.st?new Float32Array(d*2):void 0,_=i.normal?new Float32Array(d*3):void 0,R=i.tangent?new Float32Array(d*3):void 0,I=i.bitangent?new Float32Array(d*3):void 0,C=e.shadowVolume,N=C?new Float32Array(d*3):void 0,T=0,F=Qv,b=kv,G=Lv,M=new Os(r),Q=M.project(r.cartesianToCartographic(n,UC),yv),U=r.scaleToGeodeticSurface(n,Tf);r.geodeticSurfaceNormal(U,U);let k=Ae.fromAxisAngle(U,A,EO),y=lt.fromQuaternion(k,Uv),c=nt.fromElements(Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY,wv),g=nt.fromElements(Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY,xv),V=t.length,D=V/3*2;for(let x=0;x<V;x+=3){let H=x+1,j=x+2,X=l.fromArray(t,x,Tf),tt;if(i.st){let It=lt.multiplyByVector(y,X,mO),gt=M.project(r.cartesianToCartographic(It,UC),fO);l.subtract(gt,Q,gt),Fs.x=(gt.x+s)/(2*s),Fs.y=(gt.y+o)/(2*o),c.x=Math.min(Fs.x,c.x),c.y=Math.min(Fs.y,c.y),g.x=Math.max(Fs.x,g.x),g.y=Math.max(Fs.y,g.y),E[T+D]=Fs.x,E[T+1+D]=Fs.y,E[T++]=Fs.x,E[T++]=Fs.y}X=r.scaleToGeodeticSurface(X,X),tt=l.clone(X,mO),F=r.geodeticSurfaceNormal(X,F),C&&(N[x+V]=-F.x,N[H+V]=-F.y,N[j+V]=-F.z);let B=l.multiplyByScalar(F,a,Mv);if(X=l.add(X,B,X),B=l.multiplyByScalar(F,h,B),tt=l.add(tt,B,tt),i.position&&(f[x+V]=tt.x,f[H+V]=tt.y,f[j+V]=tt.z,f[x]=X.x,f[H]=X.y,f[j]=X.z),i.normal||i.tangent||i.bitangent){G=l.clone(F,G);let It=l.fromArray(t,(x+3)%V,Mv);l.subtract(It,X,It);let gt=l.subtract(tt,X,fO);F=l.normalize(l.cross(gt,It,F),F),i.normal&&(_[x]=F.x,_[H]=F.y,_[j]=F.z,_[x+V]=F.x,_[H+V]=F.y,_[j+V]=F.z),i.tangent&&(b=l.normalize(l.cross(G,F,b),b),R[x]=b.x,R[H]=b.y,R[j]=b.z,R[x+V]=b.x,R[x+1+V]=b.y,R[x+2+V]=b.z),i.bitangent&&(I[x]=G.x,I[H]=G.y,I[j]=G.z,I[x+V]=G.x,I[H+V]=G.y,I[j+V]=G.z)}}if(i.st){V=E.length;for(let x=0;x<V;x+=2)E[x]=(E[x]-c.x)/(g.x-c.x),E[x+1]=(E[x+1]-c.y)/(g.y-c.y)}let w=new we;if(i.position&&(w.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:f})),i.st&&(w.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:E})),i.normal&&(w.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_})),i.tangent&&(w.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:R})),i.bitangent&&(w.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:I})),C&&(w.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:N})),m(e.offsetAttribute)){let x=new Uint8Array(d);if(e.offsetAttribute===Pe.TOP)x=x.fill(1,0,d/2);else{let H=e.offsetAttribute===Pe.NONE?0:1;x=x.fill(H)}w.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:x})}return w}function Kht(t){let e=t.length/3,i=te.createTypedArray(e,e*6),n=0;for(let s=0;s<e;s++){let o=s,r=s+e,a=(o+1)%e,h=a+e;i[n++]=o,i[n++]=r,i[n++]=a,i[n++]=a,i[n++]=r,i[n++]=h}return i}function Xht(t){let e=t.center,i=t.ellipsoid,n=t.semiMajorAxis,s=l.multiplyByScalar(i.geodeticSurfaceNormal(e,Tf),t.height,Tf);DC.center=l.add(e,s,DC.center),DC.radius=n,s=l.multiplyByScalar(i.geodeticSurfaceNormal(e,s),t.extrudedHeight,s),MC.center=l.add(e,s,MC.center),MC.radius=n;let o=ya.computeEllipsePositions(t,!0,!0),r=o.positions,a=o.numPts,h=o.outerPositions,A=Nt.union(DC,MC),d=Pv(r,t,!0),f=Jv(a),E=f.length;f.length=E*2;let _=r.length/3;for(let b=0;b<E;b+=3)f[b+E]=f[b+2]+_,f[b+1+E]=f[b+1]+_,f[b+2+E]=f[b]+_;let R=te.createTypedArray(_*2/3,f),I=new se({attributes:d,indices:R,primitiveType:ne.TRIANGLES}),C=zht(h,t);f=Kht(h);let N=te.createTypedArray(h.length*2/3,f),T=new se({attributes:C,indices:N,primitiveType:ne.TRIANGLES}),F=wi.combineInstances([new Ln({geometry:I}),new Ln({geometry:T})]);return{boundingSphere:A,attributes:F[0].attributes,indices:F[0].indices}}function jv(t,e,i,n,s,o,r){let h=ya.computeEllipsePositions({center:t,semiMajorAxis:e,semiMinorAxis:i,rotation:n,granularity:s},!1,!0).outerPositions,A=h.length/3,d=new Array(A);for(let E=0;E<A;++E)d[E]=l.fromArray(h,E*3);let f=Xt.fromCartesianArray(d,o,r);return f.width>L.PI&&(f.north=f.north>0?L.PI_OVER_TWO-L.EPSILON7:f.north,f.south=f.south<0?L.EPSILON7-L.PI_OVER_TWO:f.south,f.east=L.PI,f.west=-L.PI),f}function VA(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.center,i=Z(t.ellipsoid,ot.WGS84),n=t.semiMajorAxis,s=t.semiMinorAxis,o=Z(t.granularity,L.RADIANS_PER_DEGREE),r=Z(t.vertexFormat,Ot.DEFAULT);if(p.defined("options.center",e),p.typeOf.number("options.semiMajorAxis",n),p.typeOf.number("options.semiMinorAxis",s),n<s)throw new Y("semiMajorAxis must be greater than or equal to the semiMinorAxis.");if(o<=0)throw new Y("granularity must be greater than zero.");let a=Z(t.height,0),h=Z(t.extrudedHeight,a);this._center=l.clone(e),this._semiMajorAxis=n,this._semiMinorAxis=s,this._ellipsoid=ot.clone(i),this._rotation=Z(t.rotation,0),this._stRotation=Z(t.stRotation,0),this._height=Math.max(h,a),this._granularity=o,this._vertexFormat=Ot.clone(r),this._extrudedHeight=Math.min(h,a),this._shadowVolume=Z(t.shadowVolume,!1),this._workerName="createEllipseGeometry",this._offsetAttribute=t.offsetAttribute,this._rectangle=void 0,this._textureCoordinateRotationPoints=void 0}function qht(t){let e=-t._stRotation;if(e===0)return[0,0,0,1,1,0];let n=ya.computeEllipsePositions({center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,rotation:t._rotation,granularity:t._granularity},!1,!0).outerPositions,s=n.length/3,o=new Array(s);for(let h=0;h<s;++h)o[h]=l.fromArray(n,h*3);let r=t._ellipsoid,a=t.rectangle;return se._textureCoordinateRotationPoints(o,e,r,a)}var Tf,mO,fO,Mv,Fs,Uv,Hht,EO,Qv,kv,Lv,UC,yv,wv,xv,Ad,DC,MC,Hv,vv,zv,OA,wa,_O=O(()=>{_i();Xe();Ht();ri();ae();oi();bt();mt();Vt();dO();Ve();zA();yi();ji();En();uA();go();gA();Di();_e();dn();Xi();$s();pn();Ls();Tf=new l,mO=new l,fO=new l,Mv=new l,Fs=new nt,Uv=new lt,Hht=new lt,EO=new Ae,Qv=new l,kv=new l,Lv=new l,UC=new ut,yv=new l,wv=new nt,xv=new nt;Ad=new l;DC=new Nt,MC=new Nt;VA.packedLength=l.packedLength+ot.packedLength+Ot.packedLength+9;VA.pack=function(t,e,i){return p.defined("value",t),p.defined("array",e),i=Z(i,0),l.pack(t._center,e,i),i+=l.packedLength,ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,Ot.pack(t._vertexFormat,e,i),i+=Ot.packedLength,e[i++]=t._semiMajorAxis,e[i++]=t._semiMinorAxis,e[i++]=t._rotation,e[i++]=t._stRotation,e[i++]=t._height,e[i++]=t._granularity,e[i++]=t._extrudedHeight,e[i++]=t._shadowVolume?1:0,e[i]=Z(t._offsetAttribute,-1),e};Hv=new l,vv=new ot,zv=new Ot,OA={center:Hv,ellipsoid:vv,vertexFormat:zv,semiMajorAxis:void 0,semiMinorAxis:void 0,rotation:void 0,stRotation:void 0,height:void 0,granularity:void 0,extrudedHeight:void 0,shadowVolume:void 0,offsetAttribute:void 0};VA.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=l.unpack(t,e,Hv);e+=l.packedLength;let s=ot.unpack(t,e,vv);e+=ot.packedLength;let o=Ot.unpack(t,e,zv);e+=Ot.packedLength;let r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++],E=t[e++],_=t[e++]===1,R=t[e];return m(i)?(i._center=l.clone(n,i._center),i._ellipsoid=ot.clone(s,i._ellipsoid),i._vertexFormat=Ot.clone(o,i._vertexFormat),i._semiMajorAxis=r,i._semiMinorAxis=a,i._rotation=h,i._stRotation=A,i._height=d,i._granularity=f,i._extrudedHeight=E,i._shadowVolume=_,i._offsetAttribute=R===-1?void 0:R,i):(OA.height=d,OA.extrudedHeight=E,OA.granularity=f,OA.stRotation=A,OA.rotation=h,OA.semiMajorAxis=r,OA.semiMinorAxis=a,OA.shadowVolume=_,OA.offsetAttribute=R===-1?void 0:R,new VA(OA))};VA.computeRectangle=function(t,e){t=Z(t,Z.EMPTY_OBJECT);let i=t.center,n=Z(t.ellipsoid,ot.WGS84),s=t.semiMajorAxis,o=t.semiMinorAxis,r=Z(t.granularity,L.RADIANS_PER_DEGREE),a=Z(t.rotation,0);if(p.defined("options.center",i),p.typeOf.number("options.semiMajorAxis",s),p.typeOf.number("options.semiMinorAxis",o),s<o)throw new Y("semiMajorAxis must be greater than or equal to the semiMinorAxis.");if(r<=0)throw new Y("granularity must be greater than zero.");return jv(i,s,o,a,r,n,e)};VA.createGeometry=function(t){if(t._semiMajorAxis<=0||t._semiMinorAxis<=0)return;let e=t._height,i=t._extrudedHeight,n=!L.equalsEpsilon(e,i,0,L.EPSILON2);t._center=t._ellipsoid.scaleToGeodeticSurface(t._center,t._center);let s={center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,ellipsoid:t._ellipsoid,rotation:t._rotation,height:e,granularity:t._granularity,vertexFormat:t._vertexFormat,stRotation:t._stRotation},o;if(n)s.extrudedHeight=i,s.shadowVolume=t._shadowVolume,s.offsetAttribute=t._offsetAttribute,o=Xht(s);else if(o=vht(s),m(t._offsetAttribute)){let r=o.attributes.position.values.length,a=t._offsetAttribute===Pe.NONE?0:1,h=new Uint8Array(r/3).fill(a);o.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:h})}return new se({attributes:o.attributes,indices:o.indices,primitiveType:ne.TRIANGLES,boundingSphere:o.boundingSphere,offsetAttribute:t._offsetAttribute})};VA.createShadowVolume=function(t,e,i){let n=t._granularity,s=t._ellipsoid,o=e(n,s),r=i(n,s);return new VA({center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,ellipsoid:s,rotation:t._rotation,stRotation:t._stRotation,granularity:n,extrudedHeight:o,height:r,vertexFormat:Ot.POSITION_ONLY,shadowVolume:!0})};Object.defineProperties(VA.prototype,{rectangle:{get:function(){return m(this._rectangle)||(this._rectangle=jv(this._center,this._semiMajorAxis,this._semiMinorAxis,this._rotation,this._granularity,this._ellipsoid)),this._rectangle}},textureCoordinateRotationPoints:{get:function(){return m(this._textureCoordinateRotationPoints)||(this._textureCoordinateRotationPoints=qht(this)),this._textureCoordinateRotationPoints}}});wa=VA});function Th(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.radius;p.typeOf.number("radius",e);let i={center:t.center,semiMajorAxis:e,semiMinorAxis:e,ellipsoid:t.ellipsoid,height:t.height,extrudedHeight:t.extrudedHeight,granularity:t.granularity,vertexFormat:t.vertexFormat,stRotation:t.stRotation,shadowVolume:t.shadowVolume};this._ellipseGeometry=new wa(i),this._workerName="createCircleGeometry"}var $ht,No,RO,Kv=O(()=>{Ht();ae();bt();mt();_O();Ve();Ls();Th.packedLength=wa.packedLength;Th.pack=function(t,e,i){return p.typeOf.object("value",t),wa.pack(t._ellipseGeometry,e,i)};$ht=new wa({center:new l,semiMajorAxis:1,semiMinorAxis:1}),No={center:new l,radius:void 0,ellipsoid:ot.clone(ot.UNIT_SPHERE),height:void 0,extrudedHeight:void 0,granularity:void 0,vertexFormat:new Ot,stRotation:void 0,semiMajorAxis:void 0,semiMinorAxis:void 0,shadowVolume:void 0};Th.unpack=function(t,e,i){let n=wa.unpack(t,e,$ht);return No.center=l.clone(n._center,No.center),No.ellipsoid=ot.clone(n._ellipsoid,No.ellipsoid),No.height=n._height,No.extrudedHeight=n._extrudedHeight,No.granularity=n._granularity,No.vertexFormat=Ot.clone(n._vertexFormat,No.vertexFormat),No.stRotation=n._stRotation,No.shadowVolume=n._shadowVolume,m(i)?(No.semiMajorAxis=n._semiMajorAxis,No.semiMinorAxis=n._semiMinorAxis,i._ellipseGeometry=new wa(No),i):(No.radius=n._semiMajorAxis,new Th(No))};Th.createGeometry=function(t){return wa.createGeometry(t._ellipseGeometry)};Th.createShadowVolume=function(t,e,i){let n=t._ellipseGeometry._granularity,s=t._ellipseGeometry._ellipsoid,o=e(n,s),r=i(n,s);return new Th({center:t._ellipseGeometry._center,radius:t._ellipseGeometry._semiMajorAxis,ellipsoid:s,stRotation:t._ellipseGeometry._stRotation,granularity:n,extrudedHeight:o,height:r,vertexFormat:Ot.POSITION_ONLY,shadowVolume:!0})};Object.defineProperties(Th.prototype,{rectangle:{get:function(){return this._ellipseGeometry.rectangle}},textureCoordinateRotationPoints:{get:function(){return this._ellipseGeometry.textureCoordinateRotationPoints}}});RO=Th});var ZO={};He(ZO,{default:()=>ect});function tct(t,e){return m(e)&&(t=RO.unpack(t,e)),t._ellipseGeometry._center=l.clone(t._ellipseGeometry._center),t._ellipseGeometry._ellipsoid=ot.clone(t._ellipseGeometry._ellipsoid),RO.createGeometry(t)}var ect,IO=O(()=>{Ht();Kv();mt();Ve();ect=tct});function ict(t){let e=t.center;hd=l.multiplyByScalar(t.ellipsoid.geodeticSurfaceNormal(e,hd),t.height,hd),hd=l.add(e,hd,hd);let i=new Nt(hd,t.semiMajorAxis),n=ya.computeEllipsePositions(t,!1,!0).outerPositions,s=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:ya.raisePositionsToHeight(n,t,!1)})}),o=n.length/3,r=te.createTypedArray(o,o*2),a=0;for(let h=0;h<o;++h)r[a++]=h,r[a++]=(h+1)%o;return{boundingSphere:i,attributes:s,indices:r}}function nct(t){let e=t.center,i=t.ellipsoid,n=t.semiMajorAxis,s=l.multiplyByScalar(i.geodeticSurfaceNormal(e,Xv),t.height,Xv);QC.center=l.add(e,s,QC.center),QC.radius=n,s=l.multiplyByScalar(i.geodeticSurfaceNormal(e,s),t.extrudedHeight,s),kC.center=l.add(e,s,kC.center),kC.radius=n;let o=ya.computeEllipsePositions(t,!1,!0).outerPositions,r=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:ya.raisePositionsToHeight(o,t,!0)})});o=r.position.values;let a=Nt.union(QC,kC),h=o.length/3;if(m(t.offsetAttribute)){let R=new Uint8Array(h);if(t.offsetAttribute===Pe.TOP)R=R.fill(1,0,h/2);else{let I=t.offsetAttribute===Pe.NONE?0:1;R=R.fill(I)}r.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:R})}let A=Z(t.numberOfVerticalLines,16);A=L.clamp(A,0,h/2);let d=te.createTypedArray(h,h*2+A*2);h/=2;let f=0,E;for(E=0;E<h;++E)d[f++]=E,d[f++]=(E+1)%h,d[f++]=E+h,d[f++]=(E+1)%h+h;let _;if(A>0){let R=Math.min(A,h);_=Math.round(h/R);let I=Math.min(_*A,h);for(E=0;E<I;E+=_)d[f++]=E,d[f++]=E+h}return{boundingSphere:a,attributes:r,indices:d}}function Nf(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.center,i=Z(t.ellipsoid,ot.WGS84),n=t.semiMajorAxis,s=t.semiMinorAxis,o=Z(t.granularity,L.RADIANS_PER_DEGREE);if(!m(e))throw new Y("center is required.");if(!m(n))throw new Y("semiMajorAxis is required.");if(!m(s))throw new Y("semiMinorAxis is required.");if(n<s)throw new Y("semiMajorAxis must be greater than or equal to the semiMinorAxis.");if(o<=0)throw new Y("granularity must be greater than zero.");let r=Z(t.height,0),a=Z(t.extrudedHeight,r);this._center=l.clone(e),this._semiMajorAxis=n,this._semiMinorAxis=s,this._ellipsoid=ot.clone(i),this._rotation=Z(t.rotation,0),this._height=Math.max(a,r),this._granularity=o,this._extrudedHeight=Math.min(a,r),this._numberOfVerticalLines=Math.max(Z(t.numberOfVerticalLines,16),0),this._offsetAttribute=t.offsetAttribute,this._workerName="createEllipseOutlineGeometry"}var Xv,hd,QC,kC,qv,$v,Nh,xa,pO=O(()=>{_i();Ht();oi();bt();mt();Vt();dO();Ve();yi();ji();En();go();Di();_e();Xi();Xv=new l,hd=new l;QC=new Nt,kC=new Nt;Nf.packedLength=l.packedLength+ot.packedLength+8;Nf.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),l.pack(t._center,e,i),i+=l.packedLength,ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._semiMajorAxis,e[i++]=t._semiMinorAxis,e[i++]=t._rotation,e[i++]=t._height,e[i++]=t._granularity,e[i++]=t._extrudedHeight,e[i++]=t._numberOfVerticalLines,e[i]=Z(t._offsetAttribute,-1),e};qv=new l,$v=new ot,Nh={center:qv,ellipsoid:$v,semiMajorAxis:void 0,semiMinorAxis:void 0,rotation:void 0,height:void 0,granularity:void 0,extrudedHeight:void 0,numberOfVerticalLines:void 0,offsetAttribute:void 0};Nf.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n=l.unpack(t,e,qv);e+=l.packedLength;let s=ot.unpack(t,e,$v);e+=ot.packedLength;let o=t[e++],r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++],E=t[e];return m(i)?(i._center=l.clone(n,i._center),i._ellipsoid=ot.clone(s,i._ellipsoid),i._semiMajorAxis=o,i._semiMinorAxis=r,i._rotation=a,i._height=h,i._granularity=A,i._extrudedHeight=d,i._numberOfVerticalLines=f,i._offsetAttribute=E===-1?void 0:E,i):(Nh.height=h,Nh.extrudedHeight=d,Nh.granularity=A,Nh.rotation=a,Nh.semiMajorAxis=o,Nh.semiMinorAxis=r,Nh.numberOfVerticalLines=f,Nh.offsetAttribute=E===-1?void 0:E,new Nf(Nh))};Nf.createGeometry=function(t){if(t._semiMajorAxis<=0||t._semiMinorAxis<=0)return;let e=t._height,i=t._extrudedHeight,n=!L.equalsEpsilon(e,i,0,L.EPSILON2);t._center=t._ellipsoid.scaleToGeodeticSurface(t._center,t._center);let s={center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,ellipsoid:t._ellipsoid,rotation:t._rotation,height:e,granularity:t._granularity,numberOfVerticalLines:t._numberOfVerticalLines},o;if(n)s.extrudedHeight=i,s.offsetAttribute=t._offsetAttribute,o=nct(s);else if(o=ict(s),m(t._offsetAttribute)){let r=o.attributes.position.values.length,a=t._offsetAttribute===Pe.NONE?0:1,h=new Uint8Array(r/3).fill(a);o.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:h})}return new se({attributes:o.attributes,indices:o.indices,primitiveType:ne.LINES,boundingSphere:o.boundingSphere,offsetAttribute:t._offsetAttribute})};xa=Nf});function bf(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.radius;p.typeOf.number("radius",e);let i={center:t.center,semiMajorAxis:e,semiMinorAxis:e,ellipsoid:t.ellipsoid,height:t.height,extrudedHeight:t.extrudedHeight,granularity:t.granularity,numberOfVerticalLines:t.numberOfVerticalLines};this._ellipseGeometry=new xa(i),this._workerName="createCircleOutlineGeometry"}var sct,Tr,uO,tz=O(()=>{Ht();ae();bt();mt();pO();Ve();bf.packedLength=xa.packedLength;bf.pack=function(t,e,i){return p.typeOf.object("value",t),xa.pack(t._ellipseGeometry,e,i)};sct=new xa({center:new l,semiMajorAxis:1,semiMinorAxis:1}),Tr={center:new l,radius:void 0,ellipsoid:ot.clone(ot.UNIT_SPHERE),height:void 0,extrudedHeight:void 0,granularity:void 0,numberOfVerticalLines:void 0,semiMajorAxis:void 0,semiMinorAxis:void 0};bf.unpack=function(t,e,i){let n=xa.unpack(t,e,sct);return Tr.center=l.clone(n._center,Tr.center),Tr.ellipsoid=ot.clone(n._ellipsoid,Tr.ellipsoid),Tr.height=n._height,Tr.extrudedHeight=n._extrudedHeight,Tr.granularity=n._granularity,Tr.numberOfVerticalLines=n._numberOfVerticalLines,m(i)?(Tr.semiMajorAxis=n._semiMajorAxis,Tr.semiMinorAxis=n._semiMinorAxis,i._ellipseGeometry=new xa(Tr),i):(Tr.radius=n._semiMajorAxis,new bf(Tr))};bf.createGeometry=function(t){return xa.createGeometry(t._ellipseGeometry)};uO=bf});var CO={};He(CO,{default:()=>rct});function oct(t,e){return m(e)&&(t=uO.unpack(t,e)),t._ellipseGeometry._center=l.clone(t._ellipseGeometry._center),t._ellipseGeometry._ellipsoid=ot.clone(t._ellipseGeometry._ellipsoid),uO.createGeometry(t)}var rct,gO=O(()=>{Ht();tz();mt();Ve();rct=oct});function oz(t,e,i,n,s){let o=l.subtract(t,e,act),r=l.dot(i,o),a=l.dot(n,o);return nt.fromElements(r,a,s)}var lR,act,ez,iz,nz,sz,Ff,TO=O(()=>{Xe();Ht();ae();dn();Jl();lR={},act=new l,ez=new l,iz=new l,nz=new l,sz=new zs;lR.validOutline=function(t){p.defined("positions",t);let i=zs.fromPoints(t,sz).halfAxes,n=lt.getColumn(i,0,ez),s=lt.getColumn(i,1,iz),o=lt.getColumn(i,2,nz),r=l.magnitude(n),a=l.magnitude(s),h=l.magnitude(o);return!(r===0&&(a===0||h===0)||a===0&&h===0)};lR.computeProjectTo2DArguments=function(t,e,i,n){p.defined("positions",t),p.defined("centerResult",e),p.defined("planeAxis1Result",i),p.defined("planeAxis2Result",n);let s=zs.fromPoints(t,sz),o=s.halfAxes,r=lt.getColumn(o,0,ez),a=lt.getColumn(o,1,iz),h=lt.getColumn(o,2,nz),A=l.magnitude(r),d=l.magnitude(a),f=l.magnitude(h),E=Math.min(A,d,f);if(A===0&&(d===0||f===0)||d===0&&f===0)return!1;let _,R;return(E===d||E===f)&&(_=r),E===A?_=a:E===f&&(R=a),(E===A||E===d)&&(R=h),l.normalize(_,i),l.normalize(R,n),l.clone(s.center,e),!0};lR.createProjectPointsTo2DFunction=function(t,e,i){return function(n){let s=new Array(n.length);for(let o=0;o<n.length;o++)s[o]=oz(n[o],t,e,i);return s}};lR.createProjectPointTo2DFunction=function(t,e,i){return function(n,s){return oz(n,t,e,i,s)}};Ff=lR});var cz=ts((NRe,YO)=>{"use strict";YO.exports=wC;YO.exports.default=wC;function wC(t,e,i){i=i||2;var n=e&&e.length,s=n?e[0]*i:t.length,o=az(t,0,s,i,!0),r=[];if(!o||o.next===o.prev)return r;var a,h,A,d,f,E,_;if(n&&(o=dct(t,e,o,i)),t.length>80*i){a=A=t[0],h=d=t[1];for(var R=i;R<s;R+=i)f=t[R],E=t[R+1],f<a&&(a=f),E<h&&(h=E),f>A&&(A=f),E>d&&(d=E);_=Math.max(A-a,d-h),_=_!==0?32767/_:0}return dR(o,r,i,a,h,_,0),r}function az(t,e,i,n,s){var o,r;if(s===FO(t,e,i,n)>0)for(o=e;o<i;o+=n)r=rz(o,t[o],t[o+1],r);else for(o=i-n;o>=e;o-=n)r=rz(o,t[o],t[o+1],r);return r&&xC(r,r.next)&&(fR(r),r=r.next),r}function cd(t,e){if(!t)return t;e||(e=t);var i=t,n;do if(n=!1,!i.steiner&&(xC(i,i.next)||as(i.prev,i,i.next)===0)){if(fR(i),i=e=i.prev,i===i.next)break;n=!0}else i=i.next;while(n||i!==e);return e}function dR(t,e,i,n,s,o,r){if(t){!r&&o&&Rct(t,n,s,o);for(var a=t,h,A;t.prev!==t.next;){if(h=t.prev,A=t.next,o?hct(t,n,s,o):Act(t)){e.push(h.i/i|0),e.push(t.i/i|0),e.push(A.i/i|0),fR(t),t=A.next,a=A.next;continue}if(t=A,t===a){r?r===1?(t=cct(cd(t),e,i),dR(t,e,i,n,s,o,2)):r===2&&lct(t,e,i,n,s,o):dR(cd(t),e,i,n,s,o,1);break}}}}function Act(t){var e=t.prev,i=t,n=t.next;if(as(e,i,n)>=0)return!1;for(var s=e.x,o=i.x,r=n.x,a=e.y,h=i.y,A=n.y,d=s<o?s<r?s:r:o<r?o:r,f=a<h?a<A?a:A:h<A?h:A,E=s>o?s>r?s:r:o>r?o:r,_=a>h?a>A?a:A:h>A?h:A,R=n.next;R!==e;){if(R.x>=d&&R.x<=E&&R.y>=f&&R.y<=_&&Yf(s,a,o,h,r,A,R.x,R.y)&&as(R.prev,R,R.next)>=0)return!1;R=R.next}return!0}function hct(t,e,i,n){var s=t.prev,o=t,r=t.next;if(as(s,o,r)>=0)return!1;for(var a=s.x,h=o.x,A=r.x,d=s.y,f=o.y,E=r.y,_=a<h?a<A?a:A:h<A?h:A,R=d<f?d<E?d:E:f<E?f:E,I=a>h?a>A?a:A:h>A?h:A,C=d>f?d>E?d:E:f>E?f:E,N=NO(_,R,e,i,n),T=NO(I,C,e,i,n),F=t.prevZ,b=t.nextZ;F&&F.z>=N&&b&&b.z<=T;){if(F.x>=_&&F.x<=I&&F.y>=R&&F.y<=C&&F!==s&&F!==r&&Yf(a,d,h,f,A,E,F.x,F.y)&&as(F.prev,F,F.next)>=0||(F=F.prevZ,b.x>=_&&b.x<=I&&b.y>=R&&b.y<=C&&b!==s&&b!==r&&Yf(a,d,h,f,A,E,b.x,b.y)&&as(b.prev,b,b.next)>=0))return!1;b=b.nextZ}for(;F&&F.z>=N;){if(F.x>=_&&F.x<=I&&F.y>=R&&F.y<=C&&F!==s&&F!==r&&Yf(a,d,h,f,A,E,F.x,F.y)&&as(F.prev,F,F.next)>=0)return!1;F=F.prevZ}for(;b&&b.z<=T;){if(b.x>=_&&b.x<=I&&b.y>=R&&b.y<=C&&b!==s&&b!==r&&Yf(a,d,h,f,A,E,b.x,b.y)&&as(b.prev,b,b.next)>=0)return!1;b=b.nextZ}return!0}function cct(t,e,i){var n=t;do{var s=n.prev,o=n.next.next;!xC(s,o)&&Az(s,n,n.next,o)&&mR(s,o)&&mR(o,s)&&(e.push(s.i/i|0),e.push(n.i/i|0),e.push(o.i/i|0),fR(n),fR(n.next),n=t=o),n=n.next}while(n!==t);return cd(n)}function lct(t,e,i,n,s,o){var r=t;do{for(var a=r.next.next;a!==r.prev;){if(r.i!==a.i&&pct(r,a)){var h=hz(r,a);r=cd(r,r.next),h=cd(h,h.next),dR(r,e,i,n,s,o,0),dR(h,e,i,n,s,o,0);return}a=a.next}r=r.next}while(r!==t)}function dct(t,e,i,n){var s=[],o,r,a,h,A;for(o=0,r=e.length;o<r;o++)a=e[o]*n,h=o<r-1?e[o+1]*n:t.length,A=az(t,a,h,n,!1),A===A.next&&(A.steiner=!0),s.push(Ict(A));for(s.sort(mct),o=0;o<s.length;o++)i=fct(s[o],i);return i}function mct(t,e){return t.x-e.x}function fct(t,e){var i=Ect(t,e);if(!i)return e;var n=hz(i,t);return cd(n,n.next),cd(i,i.next)}function Ect(t,e){var i=e,n=t.x,s=t.y,o=-1/0,r;do{if(s<=i.y&&s>=i.next.y&&i.next.y!==i.y){var a=i.x+(s-i.y)*(i.next.x-i.x)/(i.next.y-i.y);if(a<=n&&a>o&&(o=a,r=i.x<i.next.x?i:i.next,a===n))return r}i=i.next}while(i!==e);if(!r)return null;var h=r,A=r.x,d=r.y,f=1/0,E;i=r;do n>=i.x&&i.x>=A&&n!==i.x&&Yf(s<d?n:o,s,A,d,s<d?o:n,s,i.x,i.y)&&(E=Math.abs(s-i.y)/(n-i.x),mR(i,t)&&(E<f||E===f&&(i.x>r.x||i.x===r.x&&_ct(r,i)))&&(r=i,f=E)),i=i.next;while(i!==h);return r}function _ct(t,e){return as(t.prev,t,e.prev)<0&&as(e.next,t,t.next)<0}function Rct(t,e,i,n){var s=t;do s.z===0&&(s.z=NO(s.x,s.y,e,i,n)),s.prevZ=s.prev,s.nextZ=s.next,s=s.next;while(s!==t);s.prevZ.nextZ=null,s.prevZ=null,Zct(s)}function Zct(t){var e,i,n,s,o,r,a,h,A=1;do{for(i=t,t=null,o=null,r=0;i;){for(r++,n=i,a=0,e=0;e<A&&(a++,n=n.nextZ,!!n);e++);for(h=A;a>0||h>0&&n;)a!==0&&(h===0||!n||i.z<=n.z)?(s=i,i=i.nextZ,a--):(s=n,n=n.nextZ,h--),o?o.nextZ=s:t=s,s.prevZ=o,o=s;i=n}o.nextZ=null,A*=2}while(r>1);return t}function NO(t,e,i,n,s){return t=(t-i)*s|0,e=(e-n)*s|0,t=(t|t<<8)&16711935,t=(t|t<<4)&252645135,t=(t|t<<2)&858993459,t=(t|t<<1)&1431655765,e=(e|e<<8)&16711935,e=(e|e<<4)&252645135,e=(e|e<<2)&858993459,e=(e|e<<1)&1431655765,t|e<<1}function Ict(t){var e=t,i=t;do(e.x<i.x||e.x===i.x&&e.y<i.y)&&(i=e),e=e.next;while(e!==t);return i}function Yf(t,e,i,n,s,o,r,a){return(s-r)*(e-a)>=(t-r)*(o-a)&&(t-r)*(n-a)>=(i-r)*(e-a)&&(i-r)*(o-a)>=(s-r)*(n-a)}function pct(t,e){return t.next.i!==e.i&&t.prev.i!==e.i&&!uct(t,e)&&(mR(t,e)&&mR(e,t)&&Cct(t,e)&&(as(t.prev,t,e.prev)||as(t,e.prev,e))||xC(t,e)&&as(t.prev,t,t.next)>0&&as(e.prev,e,e.next)>0)}function as(t,e,i){return(e.y-t.y)*(i.x-e.x)-(e.x-t.x)*(i.y-e.y)}function xC(t,e){return t.x===e.x&&t.y===e.y}function Az(t,e,i,n){var s=yC(as(t,e,i)),o=yC(as(t,e,n)),r=yC(as(i,n,t)),a=yC(as(i,n,e));return!!(s!==o&&r!==a||s===0&&LC(t,i,e)||o===0&&LC(t,n,e)||r===0&&LC(i,t,n)||a===0&&LC(i,e,n))}function LC(t,e,i){return e.x<=Math.max(t.x,i.x)&&e.x>=Math.min(t.x,i.x)&&e.y<=Math.max(t.y,i.y)&&e.y>=Math.min(t.y,i.y)}function yC(t){return t>0?1:t<0?-1:0}function uct(t,e){var i=t;do{if(i.i!==t.i&&i.next.i!==t.i&&i.i!==e.i&&i.next.i!==e.i&&Az(i,i.next,t,e))return!0;i=i.next}while(i!==t);return!1}function mR(t,e){return as(t.prev,t,t.next)<0?as(t,e,t.next)>=0&&as(t,t.prev,e)>=0:as(t,e,t.prev)<0||as(t,t.next,e)<0}function Cct(t,e){var i=t,n=!1,s=(t.x+e.x)/2,o=(t.y+e.y)/2;do i.y>o!=i.next.y>o&&i.next.y!==i.y&&s<(i.next.x-i.x)*(o-i.y)/(i.next.y-i.y)+i.x&&(n=!n),i=i.next;while(i!==t);return n}function hz(t,e){var i=new bO(t.i,t.x,t.y),n=new bO(e.i,e.x,e.y),s=t.next,o=e.prev;return t.next=e,e.prev=t,i.next=s,s.prev=i,n.next=i,i.prev=n,o.next=n,n.prev=o,n}function rz(t,e,i,n){var s=new bO(t,e,i);return n?(s.next=n.next,s.prev=n,n.next.prev=s,n.next=s):(s.prev=s,s.next=s),s}function fR(t){t.next.prev=t.prev,t.prev.next=t.next,t.prevZ&&(t.prevZ.nextZ=t.nextZ),t.nextZ&&(t.nextZ.prevZ=t.prevZ)}function bO(t,e,i){this.i=t,this.x=e,this.y=i,this.prev=null,this.next=null,this.z=0,this.prevZ=null,this.nextZ=null,this.steiner=!1}wC.deviation=function(t,e,i,n){var s=e&&e.length,o=s?e[0]*i:t.length,r=Math.abs(FO(t,0,o,i));if(s)for(var a=0,h=e.length;a<h;a++){var A=e[a]*i,d=a<h-1?e[a+1]*i:t.length;r-=Math.abs(FO(t,A,d,i))}var f=0;for(a=0;a<n.length;a+=3){var E=n[a]*i,_=n[a+1]*i,R=n[a+2]*i;f+=Math.abs((t[E]-t[R])*(t[_+1]-t[E+1])-(t[E]-t[_])*(t[R+1]-t[E+1]))}return r===0&&f===0?0:Math.abs((f-r)/r)};function FO(t,e,i,n){for(var s=0,o=e,r=i-n;o<i;o+=n)s+=(t[r]-t[o])*(t[o+1]+t[r+1]),r=o;return s}wC.flatten=function(t){for(var e=t[0][0].length,i={vertices:[],holes:[],dimensions:e},n=0,s=0;s<t.length;s++){for(var o=0;o<t[s].length;o++)for(var r=0;r<e;r++)i.vertices.push(t[s][o][r]);s>0&&(n+=t[s-1].length,i.holes.push(n))}return i}});var fz,gct,Tct,Mc,Ez,_z,Rz,lz,dz,mz,bh,Zz,Iz,pz,Sf,Nct,bct,Fct,SO,ui,Pa=O(()=>{fz=co(cz(),1);Xe();Ht();ri();ae();oi();bt();mt();Ve();HE();yi();ji();_e();Xi();fc();gct=new l,Tct=new l,Mc={};Mc.computeArea2D=function(t){p.defined("positions",t),p.typeOf.number.greaterThanOrEquals("positions.length",t.length,3);let e=t.length,i=0;for(let n=e-1,s=0;s<e;n=s++){let o=t[n],r=t[s];i+=o.x*r.y-r.x*o.y}return i*.5};Mc.computeWindingOrder2D=function(t){return Mc.computeArea2D(t)>0?Ms.COUNTER_CLOCKWISE:Ms.CLOCKWISE};Mc.triangulate=function(t,e){p.defined("positions",t);let i=nt.packArray(t);return(0,fz.default)(i,e,2)};Ez=new l,_z=new l,Rz=new l,lz=new l,dz=new l,mz=new l,bh=new l,Zz=new nt,Iz=new nt,pz=new nt,Sf=new nt;Mc.computeSubdivision=function(t,e,i,n,s){s=Z(s,L.RADIANS_PER_DEGREE);let o=m(n);p.typeOf.object("ellipsoid",t),p.defined("positions",e),p.defined("indices",i),p.typeOf.number.greaterThanOrEquals("indices.length",i.length,3),p.typeOf.number.equals("indices.length % 3","0",i.length%3,0),p.typeOf.number.greaterThan("granularity",s,0);let r=i.slice(0),a,h=e.length,A=new Array(h*3),d=new Array(h*2),f=0,E=0;for(a=0;a<h;a++){let F=e[a];if(A[f++]=F.x,A[f++]=F.y,A[f++]=F.z,o){let b=n[a];d[E++]=b.x,d[E++]=b.y}}let _=[],R={},I=t.maximumRadius,C=L.chordLength(s,I),N=C*C;for(;r.length>0;){let F=r.pop(),b=r.pop(),G=r.pop(),M=l.fromArray(A,G*3,Ez),Q=l.fromArray(A,b*3,_z),U=l.fromArray(A,F*3,Rz),k,y,c;o&&(k=nt.fromArray(d,G*2,Zz),y=nt.fromArray(d,b*2,Iz),c=nt.fromArray(d,F*2,pz));let g=l.multiplyByScalar(l.normalize(M,lz),I,lz),V=l.multiplyByScalar(l.normalize(Q,dz),I,dz),D=l.multiplyByScalar(l.normalize(U,mz),I,mz),w=l.magnitudeSquared(l.subtract(g,V,bh)),x=l.magnitudeSquared(l.subtract(V,D,bh)),H=l.magnitudeSquared(l.subtract(D,g,bh)),j=Math.max(w,x,H),X,tt,B;j>N?w===j?(X=`${Math.min(G,b)} ${Math.max(G,b)}`,a=R[X],m(a)||(tt=l.add(M,Q,bh),l.multiplyByScalar(tt,.5,tt),A.push(tt.x,tt.y,tt.z),a=A.length/3-1,R[X]=a,o&&(B=nt.add(k,y,Sf),nt.multiplyByScalar(B,.5,B),d.push(B.x,B.y))),r.push(G,a,F),r.push(a,b,F)):x===j?(X=`${Math.min(b,F)} ${Math.max(b,F)}`,a=R[X],m(a)||(tt=l.add(Q,U,bh),l.multiplyByScalar(tt,.5,tt),A.push(tt.x,tt.y,tt.z),a=A.length/3-1,R[X]=a,o&&(B=nt.add(y,c,Sf),nt.multiplyByScalar(B,.5,B),d.push(B.x,B.y))),r.push(b,a,G),r.push(a,F,G)):H===j&&(X=`${Math.min(F,G)} ${Math.max(F,G)}`,a=R[X],m(a)||(tt=l.add(U,M,bh),l.multiplyByScalar(tt,.5,tt),A.push(tt.x,tt.y,tt.z),a=A.length/3-1,R[X]=a,o&&(B=nt.add(c,k,Sf),nt.multiplyByScalar(B,.5,B),d.push(B.x,B.y))),r.push(F,a,b),r.push(a,G,b)):(_.push(G),_.push(b),_.push(F))}let T={attributes:{position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:A})},indices:_,primitiveType:ne.TRIANGLES};return o&&(T.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:d})),new se(T)};Nct=new ut,bct=new ut,Fct=new ut,SO=new ut;Mc.computeRhumbLineSubdivision=function(t,e,i,n,s){s=Z(s,L.RADIANS_PER_DEGREE);let o=m(n);p.typeOf.object("ellipsoid",t),p.defined("positions",e),p.defined("indices",i),p.typeOf.number.greaterThanOrEquals("indices.length",i.length,3),p.typeOf.number.equals("indices.length % 3","0",i.length%3,0),p.typeOf.number.greaterThan("granularity",s,0);let r=i.slice(0),a,h=e.length,A=new Array(h*3),d=new Array(h*2),f=0,E=0;for(a=0;a<h;a++){let G=e[a];if(A[f++]=G.x,A[f++]=G.y,A[f++]=G.z,o){let M=n[a];d[E++]=M.x,d[E++]=M.y}}let _=[],R={},I=t.maximumRadius,C=L.chordLength(s,I),N=new er(void 0,void 0,t),T=new er(void 0,void 0,t),F=new er(void 0,void 0,t);for(;r.length>0;){let G=r.pop(),M=r.pop(),Q=r.pop(),U=l.fromArray(A,Q*3,Ez),k=l.fromArray(A,M*3,_z),y=l.fromArray(A,G*3,Rz),c,g,V;o&&(c=nt.fromArray(d,Q*2,Zz),g=nt.fromArray(d,M*2,Iz),V=nt.fromArray(d,G*2,pz));let D=t.cartesianToCartographic(U,Nct),w=t.cartesianToCartographic(k,bct),x=t.cartesianToCartographic(y,Fct);N.setEndPoints(D,w);let H=N.surfaceDistance;T.setEndPoints(w,x);let j=T.surfaceDistance;F.setEndPoints(x,D);let X=F.surfaceDistance,tt=Math.max(H,j,X),B,It,gt,Yt,Mt;tt>C?H===tt?(B=`${Math.min(Q,M)} ${Math.max(Q,M)}`,a=R[B],m(a)||(It=N.interpolateUsingFraction(.5,SO),gt=(D.height+w.height)*.5,Yt=l.fromRadians(It.longitude,It.latitude,gt,t,bh),A.push(Yt.x,Yt.y,Yt.z),a=A.length/3-1,R[B]=a,o&&(Mt=nt.add(c,g,Sf),nt.multiplyByScalar(Mt,.5,Mt),d.push(Mt.x,Mt.y))),r.push(Q,a,G),r.push(a,M,G)):j===tt?(B=`${Math.min(M,G)} ${Math.max(M,G)}`,a=R[B],m(a)||(It=T.interpolateUsingFraction(.5,SO),gt=(w.height+x.height)*.5,Yt=l.fromRadians(It.longitude,It.latitude,gt,t,bh),A.push(Yt.x,Yt.y,Yt.z),a=A.length/3-1,R[B]=a,o&&(Mt=nt.add(g,V,Sf),nt.multiplyByScalar(Mt,.5,Mt),d.push(Mt.x,Mt.y))),r.push(M,a,Q),r.push(a,G,Q)):X===tt&&(B=`${Math.min(G,Q)} ${Math.max(G,Q)}`,a=R[B],m(a)||(It=F.interpolateUsingFraction(.5,SO),gt=(x.height+D.height)*.5,Yt=l.fromRadians(It.longitude,It.latitude,gt,t,bh),A.push(Yt.x,Yt.y,Yt.z),a=A.length/3-1,R[B]=a,o&&(Mt=nt.add(V,c,Sf),nt.multiplyByScalar(Mt,.5,Mt),d.push(Mt.x,Mt.y))),r.push(G,a,M),r.push(a,Q,M)):(_.push(Q),_.push(M),_.push(G))}let b={attributes:{position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:A})},indices:_,primitiveType:ne.TRIANGLES};return o&&(b.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:d})),new se(b)};Mc.scaleToGeodeticHeight=function(t,e,i,n){i=Z(i,ot.WGS84);let s=gct,o=Tct;if(e=Z(e,0),n=Z(n,!0),m(t)){let r=t.length;for(let a=0;a<r;a+=3)l.fromArray(t,a,o),n&&(o=i.scaleToGeodeticSurface(o,o)),e!==0&&(s=i.geodeticSurfaceNormal(o,s),l.multiplyByScalar(s,e,s),l.add(o,s,o)),t[a]=o.x,t[a+1]=o.y,t[a+2]=o.z}return t};ui=Mc});function Uc(){this._array=[],this._offset=0,this._length=0}var OO,uz=O(()=>{Object.defineProperties(Uc.prototype,{length:{get:function(){return this._length}}});Uc.prototype.enqueue=function(t){this._array.push(t),this._length++};Uc.prototype.dequeue=function(){if(this._length===0)return;let t=this._array,e=this._offset,i=t[e];return t[e]=void 0,e++,e>10&&e*2>t.length&&(this._array=t.slice(e),e=0),this._offset=e,this._length--,i};Uc.prototype.peek=function(){if(this._length!==0)return this._array[this._offset]};Uc.prototype.contains=function(t){return this._array.indexOf(t)!==-1};Uc.prototype.clear=function(){this._array.length=this._offset=this._length=0};Uc.prototype.sort=function(t){this._offset>0&&(this._array=this._array.slice(this._offset),this._offset=0),this._array.sort(t)};OO=Uc});function Tz(t,e,i,n){return nt.subtract(e,t,ld),nt.multiplyByScalar(ld,i/n,ld),nt.add(t,ld,ld),[ld.x,ld.y]}function Yct(t,e,i,n){return l.subtract(e,t,Qc),l.multiplyByScalar(Qc,i/n,Qc),l.add(t,Qc,Qc),[Qc.x,Qc.y,Qc.z]}function Mct(t,e,i){let n=i.cartesianToCartographic(t,JC),s=i.cartesianToCartographic(e,jC);if(Math.sign(n.latitude)===Math.sign(s.latitude))return;PC.setEndPoints(n,s);let o=PC.findIntersectionWithLatitude(0,Dct);if(!m(o))return;let r=Math.min(n.longitude,s.longitude),a=Math.max(n.longitude,s.longitude);if(Math.abs(a-r)>L.PI){let h=r;r=a,a=h}if(!(o.longitude<r||o.longitude>a))return i.cartographicToCartesian(o)}function Uct(t,e,i,n){if(n===ti.RHUMB)return Mct(t,e,i);let s=no.lineSegmentPlane(t,e,Ki.ORIGIN_XY_PLANE);if(m(s))return i.scaleToGeodeticSurface(s,s)}function kct(t,e,i){let n=[],s,o,r,a,h,A=0;for(;A<t.length;){s=t[A],o=t[(A+1)%t.length],r=L.sign(s.z),a=L.sign(o.z);let d=f=>e.cartesianToCartographic(f,Qct).longitude;if(r===0)n.push({position:A,type:r,visited:!1,next:a,theta:d(s)});else if(a!==0){if(h=Uct(s,o,e,i),++A,!m(h))continue;t.splice(A,0,h),n.push({position:A,type:r,visited:!1,next:a,theta:d(h)})}++A}return n}function Nz(t,e,i,n,s,o,r){let a=[],h=o,A=f=>E=>E.position===f,d=[];do{let f=i[h];a.push(f);let E=n.findIndex(A(h)),_=n[E];if(!m(_)){++h;continue}let{visited:R,type:I,next:C}=_;if(_.visited=!0,I===0){if(C===0){let b=n[E-(r?1:-1)];if(b?.position===h+1)b.visited=!0;else{++h;continue}}if(!R&&r&&C>0||o===h&&!r&&C<0){++h;continue}}if(!(r?I>=0:I<=0)){++h;continue}R||d.push(h);let T=E+(r?1:-1),F=n[T];if(!m(F)){++h;continue}h=F.position}while(h<i.length&&h>=0&&h!==o&&a.length<i.length);t.splice(e,s,a);for(let f of d)e=Nz(t,++e,i,n,0,f,!r);return e}var Mn,ld,Qc,JC,jC,Sct,Oct,PC,Vct,Gct,Bct,Wct,Dct,Qct,Lct,yct,wct,xct,Cz,gz,Pct,Jct,ii,ER=O(()=>{Bl();Oa();Xe();Ht();ri();oi();bt();mt();Ve();HE();yi();ji();En();gA();Di();Ml();_e();dn();nh();cp();Pa();Xi();$s();uz();fc();Mn={};Mn.computeHierarchyPackedLength=function(t,e){let i=0,n=[t];for(;n.length>0;){let s=n.pop();if(!m(s))continue;i+=2;let o=s.positions,r=s.holes;if(m(o)&&o.length>0&&(i+=o.length*e.packedLength),m(r)){let a=r.length;for(let h=0;h<a;++h)n.push(r[h])}}return i};Mn.packPolygonHierarchy=function(t,e,i,n){let s=[t];for(;s.length>0;){let o=s.pop();if(!m(o))continue;let r=o.positions,a=o.holes;if(e[i++]=m(r)?r.length:0,e[i++]=m(a)?a.length:0,m(r)){let h=r.length;for(let A=0;A<h;++A,i+=n.packedLength)n.pack(r[A],e,i)}if(m(a)){let h=a.length;for(let A=0;A<h;++A)s.push(a[A])}}return i};Mn.unpackPolygonHierarchy=function(t,e,i){let n=t[e++],s=t[e++],o=new Array(n),r=s>0?new Array(s):void 0;for(let a=0;a<n;++a,e+=i.packedLength)o[a]=i.unpack(t,e);for(let a=0;a<s;++a)r[a]=Mn.unpackPolygonHierarchy(t,e,i),e=r[a].startingIndex,delete r[a].startingIndex;return{positions:o,holes:r,startingIndex:e}};ld=new nt;Qc=new l;Mn.subdivideLineCount=function(t,e,i){let s=l.distance(t,e)/i,o=Math.max(0,Math.ceil(L.log2(s)));return Math.pow(2,o)};JC=new ut,jC=new ut,Sct=new ut,Oct=new l,PC=new er;Mn.subdivideRhumbLineCount=function(t,e,i,n){let s=t.cartesianToCartographic(e,JC),o=t.cartesianToCartographic(i,jC),a=new er(s,o,t).surfaceDistance/n,h=Math.max(0,Math.ceil(L.log2(a)));return Math.pow(2,h)};Mn.subdivideTexcoordLine=function(t,e,i,n,s,o){let r=Mn.subdivideLineCount(i,n,s),a=nt.distance(t,e),h=a/r,A=o;A.length=r*2;let d=0;for(let f=0;f<r;f++){let E=Tz(t,e,f*h,a);A[d++]=E[0],A[d++]=E[1]}return A};Mn.subdivideLine=function(t,e,i,n){let s=Mn.subdivideLineCount(t,e,i),o=l.distance(t,e),r=o/s;m(n)||(n=[]);let a=n;a.length=s*3;let h=0;for(let A=0;A<s;A++){let d=Yct(t,e,A*r,o);a[h++]=d[0],a[h++]=d[1],a[h++]=d[2]}return a};Mn.subdivideTexcoordRhumbLine=function(t,e,i,n,s,o,r){let a=i.cartesianToCartographic(n,JC),h=i.cartesianToCartographic(s,jC);PC.setEndPoints(a,h);let A=PC.surfaceDistance/o,d=Math.max(0,Math.ceil(L.log2(A))),f=Math.pow(2,d),E=nt.distance(t,e),_=E/f,R=r;R.length=f*2;let I=0;for(let C=0;C<f;C++){let N=Tz(t,e,C*_,E);R[I++]=N[0],R[I++]=N[1]}return R};Mn.subdivideRhumbLine=function(t,e,i,n,s){let o=t.cartesianToCartographic(e,JC),r=t.cartesianToCartographic(i,jC),a=new er(o,r,t),h=a.surfaceDistance/n,A=Math.max(0,Math.ceil(L.log2(h))),d=Math.pow(2,A),f=a.surfaceDistance/d;m(s)||(s=[]);let E=s;E.length=d*3;let _=0;for(let R=0;R<d;R++){let I=a.interpolateUsingSurfaceDistance(R*f,Sct),C=t.cartographicToCartesian(I,Oct);E[_++]=C.x,E[_++]=C.y,E[_++]=C.z}return E};Vct=new l,Gct=new l,Bct=new l,Wct=new l;Mn.scaleToGeodeticHeightExtruded=function(t,e,i,n,s){n=Z(n,ot.WGS84);let o=Vct,r=Gct,a=Bct,h=Wct;if(m(t)&&m(t.attributes)&&m(t.attributes.position)){let A=t.attributes.position.values,d=A.length/2;for(let f=0;f<d;f+=3)l.fromArray(A,f,a),n.geodeticSurfaceNormal(a,o),h=n.scaleToGeodeticSurface(a,h),r=l.multiplyByScalar(o,i,r),r=l.add(h,r,r),A[f+d]=r.x,A[f+1+d]=r.y,A[f+2+d]=r.z,s&&(h=l.clone(a,h)),r=l.multiplyByScalar(o,e,r),r=l.add(h,r,r),A[f]=r.x,A[f+1]=r.y,A[f+2]=r.z}return t};Mn.polygonOutlinesFromHierarchy=function(t,e,i){let n=[],s=new OO;s.enqueue(t);let o,r,a;for(;s.length!==0;){let h=s.dequeue(),A=h.positions;if(e)for(a=A.length,o=0;o<a;o++)i.scaleToGeodeticSurface(A[o],A[o]);if(A=Xn(A,l.equalsEpsilon,!0),A.length<3)continue;let d=h.holes?h.holes.length:0;for(o=0;o<d;o++){let f=h.holes[o],E=f.positions;if(e)for(a=E.length,r=0;r<a;++r)i.scaleToGeodeticSurface(E[r],E[r]);if(E=Xn(E,l.equalsEpsilon,!0),E.length<3)continue;n.push(E);let _=0;for(m(f.holes)&&(_=f.holes.length),r=0;r<_;r++)s.enqueue(f.holes[r])}n.push(A)}return n};Dct=new ut;Qct=new ut;Mn.splitPolygonsOnEquator=function(t,e,i,n){m(n)||(n=[]),n.splice(0,0,...t),n.length=t.length;let s=0;for(;s<n.length;){let o=n[s],r=o.slice();if(o.length<3){n[s]=r,++s;continue}let a=kct(r,e,i);if(r.length===o.length||a.length<=1){n[s]=r,++s;continue}a.sort((A,d)=>A.theta-d.theta);let h=r[0].z>=0;s=Nz(n,s,r,a,1,0,h)}return n};Mn.polygonsFromHierarchy=function(t,e,i,n,s,o){let r=[],a=[],h=new OO;h.enqueue(t);let A=m(o);for(;h.length!==0;){let d=h.dequeue(),f=d.positions,E=d.holes,_,R;if(n)for(R=f.length,_=0;_<R;_++)s.scaleToGeodeticSurface(f[_],f[_]);if(e||(f=Xn(f,l.equalsEpsilon,!0)),f.length<3)continue;let I=i(f);if(!m(I))continue;let C=[],N=ui.computeWindingOrder2D(I);if(N===Ms.CLOCKWISE&&(I.reverse(),f=f.slice().reverse()),A){A=!1;let M=[f];if(M=o(M,M),M.length>1){for(let Q of M)h.enqueue(new sf(Q,E));continue}}let T=f.slice(),F=m(E)?E.length:0,b=[],G;for(_=0;_<F;_++){let M=E[_],Q=M.positions;if(n)for(R=Q.length,G=0;G<R;++G)s.scaleToGeodeticSurface(Q[G],Q[G]);if(e||(Q=Xn(Q,l.equalsEpsilon,!0)),Q.length<3)continue;let U=i(Q);if(!m(U))continue;N=ui.computeWindingOrder2D(U),N===Ms.CLOCKWISE&&(U.reverse(),Q=Q.slice().reverse()),b.push(Q),C.push(T.length),T=T.concat(Q),I=I.concat(U);let k=0;for(m(M.holes)&&(k=M.holes.length),G=0;G<k;G++)h.enqueue(M.holes[G])}r.push({outerRing:f,holes:b}),a.push({positions:T,positions2D:I,holes:C})}return{hierarchy:r,polygons:a}};Lct=new nt,yct=new l,wct=new Ae,xct=new lt;Mn.computeBoundingRectangle=function(t,e,i,n,s){let o=Ae.fromAxisAngle(t,n,wct),r=lt.fromQuaternion(o,xct),a=Number.POSITIVE_INFINITY,h=Number.NEGATIVE_INFINITY,A=Number.POSITIVE_INFINITY,d=Number.NEGATIVE_INFINITY,f=i.length;for(let E=0;E<f;++E){let _=l.clone(i[E],yct);lt.multiplyByVector(r,_,_);let R=e(_,Lct);m(R)&&(a=Math.min(a,R.x),h=Math.max(h,R.x),A=Math.min(A,R.y),d=Math.max(d,R.y))}return s.x=a,s.y=A,s.width=h-a,s.height=d-A,s};Mn.createGeometryFromPositions=function(t,e,i,n,s,o,r){let a=ui.triangulate(e.positions2D,e.holes);a.length<3&&(a=[0,1,2]);let h=e.positions,A=m(i),d=A?i.positions:void 0;if(s){let f=h.length,E=new Array(f*3),_=0;for(let C=0;C<f;C++){let N=h[C];E[_++]=N.x,E[_++]=N.y,E[_++]=N.z}let R={attributes:{position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:E})},indices:a,primitiveType:ne.TRIANGLES};A&&(R.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:nt.packArray(d)}));let I=new se(R);return o.normal?wi.computeNormal(I):I}if(r===ti.GEODESIC)return ui.computeSubdivision(t,h,a,d,n);if(r===ti.RHUMB)return ui.computeRhumbLineSubdivision(t,h,a,d,n)};Cz=[],gz=[],Pct=new l,Jct=new l;Mn.computeWallGeometry=function(t,e,i,n,s,o){let r,a,h,A,d,f,E,_,R,I=t.length,C=0,N=0,T=m(e),F=T?e.positions:void 0;if(s)for(a=I*3*2,r=new Array(a*2),T&&(R=I*2*2,_=new Array(R*2)),h=0;h<I;h++)A=t[h],d=t[(h+1)%I],r[C]=r[C+a]=A.x,++C,r[C]=r[C+a]=A.y,++C,r[C]=r[C+a]=A.z,++C,r[C]=r[C+a]=d.x,++C,r[C]=r[C+a]=d.y,++C,r[C]=r[C+a]=d.z,++C,T&&(f=F[h],E=F[(h+1)%I],_[N]=_[N+R]=f.x,++N,_[N]=_[N+R]=f.y,++N,_[N]=_[N+R]=E.x,++N,_[N]=_[N+R]=E.y,++N);else{let U=L.chordLength(n,i.maximumRadius),k=0;if(o===ti.GEODESIC)for(h=0;h<I;h++)k+=Mn.subdivideLineCount(t[h],t[(h+1)%I],U);else if(o===ti.RHUMB)for(h=0;h<I;h++)k+=Mn.subdivideRhumbLineCount(i,t[h],t[(h+1)%I],U);for(a=(k+I)*3,r=new Array(a*2),T&&(R=(k+I)*2,_=new Array(R*2)),h=0;h<I;h++){A=t[h],d=t[(h+1)%I];let y,c;T&&(f=F[h],E=F[(h+1)%I]),o===ti.GEODESIC?(y=Mn.subdivideLine(A,d,U,gz),T&&(c=Mn.subdivideTexcoordLine(f,E,A,d,U,Cz))):o===ti.RHUMB&&(y=Mn.subdivideRhumbLine(i,A,d,U,gz),T&&(c=Mn.subdivideTexcoordRhumbLine(f,E,i,A,d,U,Cz)));let g=y.length;for(let V=0;V<g;++V,++C)r[C]=y[V],r[C+a]=y[V];if(r[C]=d.x,r[C+a]=d.x,++C,r[C]=d.y,r[C+a]=d.y,++C,r[C]=d.z,r[C+a]=d.z,++C,T){let V=c.length;for(let D=0;D<V;++D,++N)_[N]=c[D],_[N+R]=c[D];_[N]=E.x,_[N+R]=E.x,++N,_[N]=E.y,_[N+R]=E.y,++N}}}I=r.length;let b=te.createTypedArray(I/3,I-t.length*6),G=0;for(I/=6,h=0;h<I;h++){let U=h,k=U+1,y=U+I,c=y+1;A=l.fromArray(r,U*3,Pct),d=l.fromArray(r,k*3,Jct),!l.equalsEpsilon(A,d,L.EPSILON10,L.EPSILON10)&&(b[G++]=U,b[G++]=y,b[G++]=k,b[G++]=k,b[G++]=y,b[G++]=c)}let M={attributes:new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:r})}),indices:b,primitiveType:ne.TRIANGLES};return T&&(M.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:_})),new se(M)};ii=Mn});function slt(t,e,i,n,s,o,r,a,h){let A=t.positions,d=ui.triangulate(t.positions2D,t.holes);d.length<3&&(d=[0,1,2]);let f=te.createTypedArray(A.length,d.length);f.set(d);let E=elt;if(n!==0){let c=Ae.fromAxisAngle(r,n,bz);if(E=lt.fromQuaternion(c,E),e.tangent||e.bitangent){c=Ae.fromAxisAngle(r,-n,bz);let g=lt.fromQuaternion(c,ilt);a=l.normalize(lt.multiplyByVector(g,a,a),a),e.bitangent&&(h=l.normalize(l.cross(r,a,h),h))}}else E=lt.clone(lt.IDENTITY,E);let _=zct;e.st&&(_.x=i.x,_.y=i.y);let R=A.length,I=R*3,C=new Float64Array(I),N=e.normal?new Float32Array(I):void 0,T=e.tangent?new Float32Array(I):void 0,F=e.bitangent?new Float32Array(I):void 0,b=e.st?new Float32Array(R*2):void 0,G=0,M=0,Q=0,U=0,k=0;for(let c=0;c<R;c++){let g=A[c];if(C[G++]=g.x,C[G++]=g.y,C[G++]=g.z,e.st)if(m(s)&&s.positions.length===R)b[k++]=s.positions[c].x,b[k++]=s.positions[c].y;else{let V=lt.multiplyByVector(E,g,jct),D=o(V,vct);nt.subtract(D,_,D);let w=L.clamp(D.x/i.width,0,1),x=L.clamp(D.y/i.height,0,1);b[k++]=w,b[k++]=x}e.normal&&(N[M++]=r.x,N[M++]=r.y,N[M++]=r.z),e.tangent&&(T[U++]=a.x,T[U++]=a.y,T[U++]=a.z),e.bitangent&&(F[Q++]=h.x,F[Q++]=h.y,F[Q++]=h.z)}let y=new we;return e.position&&(y.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:C})),e.normal&&(y.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:N})),e.tangent&&(y.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:T})),e.bitangent&&(y.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:F})),e.st&&(y.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:b})),new se({attributes:y,indices:f,primitiveType:ne.TRIANGLES})}function dd(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.polygonHierarchy,i=t.textureCoordinates;p.defined("options.polygonHierarchy",e);let n=Z(t.vertexFormat,Ot.DEFAULT);this._vertexFormat=Ot.clone(n),this._polygonHierarchy=e,this._stRotation=Z(t.stRotation,0),this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._workerName="createCoplanarPolygonGeometry",this._textureCoordinates=i,this.packedLength=ii.computeHierarchyPackedLength(e,l)+Ot.packedLength+ot.packedLength+(m(i)?ii.computeHierarchyPackedLength(i,nt):1)+2}var jct,Hct,vct,zct,Kct,Xct,qct,_R,$ct,tlt,bz,elt,ilt,nlt,olt,rlt,alt,VO,Fz=O(()=>{Oa();Er();_i();Xe();Ht();ae();oi();TO();bt();mt();Ve();yi();ji();En();uA();gA();Di();_e();dn();ER();Pa();Xi();$s();Ls();jct=new l,Hct=new mi,vct=new nt,zct=new nt,Kct=new l,Xct=new l,qct=new l,_R=new l,$ct=new l,tlt=new l,bz=new Ae,elt=new lt,ilt=new lt,nlt=new l;dd.fromPositions=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.positions",t.positions);let e={polygonHierarchy:{positions:t.positions},vertexFormat:t.vertexFormat,stRotation:t.stRotation,ellipsoid:t.ellipsoid,textureCoordinates:t.textureCoordinates};return new dd(e)};dd.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),i=ii.packPolygonHierarchy(t._polygonHierarchy,e,i,l),ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,Ot.pack(t._vertexFormat,e,i),i+=Ot.packedLength,e[i++]=t._stRotation,m(t._textureCoordinates)?i=ii.packPolygonHierarchy(t._textureCoordinates,e,i,nt):e[i++]=-1,e[i++]=t.packedLength,e};olt=ot.clone(ot.UNIT_SPHERE),rlt=new Ot,alt={polygonHierarchy:{}};dd.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=ii.unpackPolygonHierarchy(t,e,l);e=n.startingIndex,delete n.startingIndex;let s=ot.unpack(t,e,olt);e+=ot.packedLength;let o=Ot.unpack(t,e,rlt);e+=Ot.packedLength;let r=t[e++],a=t[e]===-1?void 0:ii.unpackPolygonHierarchy(t,e,nt);m(a)?(e=a.startingIndex,delete a.startingIndex):e++;let h=t[e++];return m(i)||(i=new dd(alt)),i._polygonHierarchy=n,i._ellipsoid=ot.clone(s,i._ellipsoid),i._vertexFormat=Ot.clone(o,i._vertexFormat),i._stRotation=r,i._textureCoordinates=a,i.packedLength=h,i};dd.createGeometry=function(t){let e=t._vertexFormat,i=t._polygonHierarchy,n=t._stRotation,s=t._textureCoordinates,o=m(s),r=i.positions;if(r=Xn(r,l.equalsEpsilon,!0),r.length<3)return;let a=Kct,h=Xct,A=qct,d=$ct,f=tlt;if(!Ff.computeProjectTo2DArguments(r,_R,d,f))return;if(a=l.cross(d,f,a),a=l.normalize(a,a),!l.equalsEpsilon(_R,l.ZERO,L.EPSILON6)){let k=t._ellipsoid.geodeticSurfaceNormal(_R,nlt);l.dot(a,k)<0&&(a=l.negate(a,a),d=l.negate(d,d))}let _=Ff.createProjectPointsTo2DFunction(_R,d,f),R=Ff.createProjectPointTo2DFunction(_R,d,f);e.tangent&&(h=l.clone(d,h)),e.bitangent&&(A=l.clone(f,A));let I=ii.polygonsFromHierarchy(i,o,_,!1),C=I.hierarchy,N=I.polygons,T=function(k){return k},F=o?ii.polygonsFromHierarchy(s,!0,T,!1).polygons:void 0;if(C.length===0)return;r=C[0].outerRing;let b=Nt.fromPoints(r),G=ii.computeBoundingRectangle(a,R,r,n,Hct),M=[];for(let k=0;k<N.length;k++){let y=new Ln({geometry:slt(N[k],e,G,n,o?F[k]:void 0,R,a,h,A)});M.push(y)}let Q=wi.combineInstances(M)[0];Q.attributes.position.values=new Float64Array(Q.attributes.position.values),Q.indices=te.createTypedArray(Q.attributes.position.values.length/3,Q.indices);let U=Q.attributes;return e.position||delete U.position,new se({attributes:U,indices:Q.indices,primitiveType:Q.primitiveType,boundingSphere:b})};VO=dd});var GO={};He(GO,{default:()=>hlt});function Alt(t,e){return m(e)&&(t=VO.unpack(t,e)),VO.createGeometry(t)}var hlt,BO=O(()=>{Fz();mt();hlt=Alt});function clt(t){let e=t.length,i=new Float64Array(e*3),n=te.createTypedArray(e,e*2),s=0,o=0;for(let a=0;a<e;a++){let h=t[a];i[s++]=h.x,i[s++]=h.y,i[s++]=h.z,n[o++]=a,n[o++]=(a+1)%e}let r=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:i})});return new se({attributes:r,indices:n,primitiveType:ne.LINES})}function md(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.polygonHierarchy;p.defined("options.polygonHierarchy",e),this._polygonHierarchy=e,this._workerName="createCoplanarPolygonOutlineGeometry",this.packedLength=ii.computeHierarchyPackedLength(e,l)+1}var llt,WO,Yz=O(()=>{Oa();_i();Ht();ae();oi();TO();bt();mt();yi();ji();En();uA();gA();Di();ER();Xi();md.fromPositions=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.positions",t.positions);let e={polygonHierarchy:{positions:t.positions}};return new md(e)};md.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),i=ii.packPolygonHierarchy(t._polygonHierarchy,e,i,l),e[i]=t.packedLength,e};llt={polygonHierarchy:{}};md.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=ii.unpackPolygonHierarchy(t,e,l);e=n.startingIndex,delete n.startingIndex;let s=t[e];return m(i)||(i=new md(llt)),i._polygonHierarchy=n,i.packedLength=s,i};md.createGeometry=function(t){let e=t._polygonHierarchy,i=e.positions;if(i=Xn(i,l.equalsEpsilon,!0),i.length<3||!Ff.validOutline(i))return;let s=ii.polygonOutlinesFromHierarchy(e,!1);if(s.length===0)return;let o=[];for(let h=0;h<s.length;h++){let A=new Ln({geometry:clt(s[h])});o.push(A)}let r=wi.combineInstances(o)[0],a=Nt.fromPoints(e.positions);return new se({attributes:r.attributes,indices:r.indices,primitiveType:r.primitiveType,boundingSphere:a})};WO=md});var DO={};He(DO,{default:()=>mlt});function dlt(t,e){return m(e)&&(t=WO.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),WO.createGeometry(t)}var mlt,MO=O(()=>{Yz();mt();Ve();mlt=dlt});var flt,Cn,fd=O(()=>{flt={ROUNDED:0,MITERED:1,BEVELED:2},Cn=Object.freeze(flt)});function Gz(t,e,i){let n=QO;n.length=t;let s;if(e===i){for(s=0;s<t;s++)n[s]=e;return n}let r=(i-e)/t;for(s=0;s<t;s++){let a=e+s*r;n[s]=a}return n}function glt(t,e,i,n,s,o,r,a){let h=n.scaleToGeodeticSurface(t,kO),A=n.scaleToGeodeticSurface(e,Clt),d=yo.numberOfPoints(t,e,i),f=n.cartesianToCartographic(h,vC),E=n.cartesianToCartographic(A,HC),_=Gz(d,s,o);UO.setEndPoints(f,E);let R=UO.surfaceDistance/d,I=a;f.height=s;let C=n.cartographicToCartesian(f,kc);l.pack(C,r,I),I+=3;for(let N=1;N<d;N++){let T=UO.interpolateUsingSurfaceDistance(N*R,HC);T.height=_[N],C=n.cartographicToCartesian(T,kc),l.pack(C,r,I),I+=3}return I}function Tlt(t,e,i,n,s,o,r,a){let h=n.cartesianToCartographic(t,vC),A=n.cartesianToCartographic(e,HC),d=yo.numberOfPointsRhumbLine(h,A,i);h.height=0,A.height=0;let f=Gz(d,s,o);RR.ellipsoid.equals(n)||(RR=new er(void 0,void 0,n)),RR.setEndPoints(h,A);let E=RR.surfaceDistance/d,_=a;h.height=s;let R=n.cartographicToCartesian(h,kc);l.pack(R,r,_),_+=3;for(let I=1;I<d;I++){let C=RR.interpolateUsingSurfaceDistance(I*E,HC);C.height=f[I],R=n.cartographicToCartesian(C,kc),l.pack(R,r,_),_+=3}return _}var yo,Elt,_lt,Rlt,Sz,Zlt,Oz,Ilt,plt,ult,QO,vC,HC,kc,kO,Clt,UO,RR,Vz,Nlt,On,Of=O(()=>{Ht();ri();bt();mt();Vt();Ve();EN();HE();Ml();_e();Fi();nh();yo={};yo.numberOfPoints=function(t,e,i){let n=l.distance(t,e);return Math.ceil(n/i)};yo.numberOfPointsRhumbLine=function(t,e,i){let n=Math.pow(t.longitude-e.longitude,2)+Math.pow(t.latitude-e.latitude,2);return Math.max(1,Math.ceil(Math.sqrt(n/(i*i))))};Elt=new ut;yo.extractHeights=function(t,e){let i=t.length,n=new Array(i);for(let s=0;s<i;s++){let o=t[s];n[s]=e.cartesianToCartographic(o,Elt).height}return n};_lt=new at,Rlt=new l,Sz=new l,Zlt=new Ki(l.UNIT_X,0),Oz=new l,Ilt=new Ki(l.UNIT_X,0),plt=new l,ult=new l,QO=[];vC=new ut,HC=new ut,kc=new l,kO=new l,Clt=new l,UO=new bI,RR=new er;yo.wrapLongitude=function(t,e){let i=[],n=[];if(m(t)&&t.length>0){e=Z(e,at.IDENTITY);let s=at.inverseTransformation(e,_lt),o=at.multiplyByPoint(s,l.ZERO,Rlt),r=l.normalize(at.multiplyByPointAsVector(s,l.UNIT_Y,Sz),Sz),a=Ki.fromPointNormal(o,r,Zlt),h=l.normalize(at.multiplyByPointAsVector(s,l.UNIT_X,Oz),Oz),A=Ki.fromPointNormal(o,h,Ilt),d=1;i.push(l.clone(t[0]));let f=i[0],E=t.length;for(let _=1;_<E;++_){let R=t[_];if(Ki.getPointDistance(A,f)<0||Ki.getPointDistance(A,R)<0){let I=no.lineSegmentPlane(f,R,a,plt);if(m(I)){let C=l.multiplyByScalar(r,5e-9,ult);Ki.getPointDistance(a,f)<0&&l.negate(C,C),i.push(l.add(I,C,new l)),n.push(d+1),l.negate(C,C),i.push(l.add(I,C,new l)),d=1}}i.push(l.clone(t[_])),d++,f=R}n.push(d)}return{positions:i,lengths:n}};yo.generateArc=function(t){m(t)||(t={});let e=t.positions;if(!m(e))throw new Y("options.positions is required.");let i=e.length,n=Z(t.ellipsoid,ot.WGS84),s=Z(t.height,0),o=Array.isArray(s);if(i<1)return[];if(i===1){let I=n.scaleToGeodeticSurface(e[0],kO);if(s=o?s[0]:s,s!==0){let C=n.geodeticSurfaceNormal(I,kc);l.multiplyByScalar(C,s,C),l.add(I,C,I)}return[I.x,I.y,I.z]}let r=t.minDistance;if(!m(r)){let I=Z(t.granularity,L.RADIANS_PER_DEGREE);r=L.chordLength(I,n.maximumRadius)}let a=0,h;for(h=0;h<i-1;h++)a+=yo.numberOfPoints(e[h],e[h+1],r);let A=(a+1)*3,d=new Array(A),f=0;for(h=0;h<i-1;h++){let I=e[h],C=e[h+1],N=o?s[h]:s,T=o?s[h+1]:s;f=glt(I,C,r,n,N,T,d,f)}QO.length=0;let E=e[i-1],_=n.cartesianToCartographic(E,vC);_.height=o?s[i-1]:s;let R=n.cartographicToCartesian(_,kc);return l.pack(R,d,A-3),d};Vz=new ut,Nlt=new ut;yo.generateRhumbArc=function(t){m(t)||(t={});let e=t.positions;if(!m(e))throw new Y("options.positions is required.");let i=e.length,n=Z(t.ellipsoid,ot.WGS84),s=Z(t.height,0),o=Array.isArray(s);if(i<1)return[];if(i===1){let N=n.scaleToGeodeticSurface(e[0],kO);if(s=o?s[0]:s,s!==0){let T=n.geodeticSurfaceNormal(N,kc);l.multiplyByScalar(T,s,T),l.add(N,T,N)}return[N.x,N.y,N.z]}let r=Z(t.granularity,L.RADIANS_PER_DEGREE),a=0,h,A=n.cartesianToCartographic(e[0],Vz),d;for(h=0;h<i-1;h++)d=n.cartesianToCartographic(e[h+1],Nlt),a+=yo.numberOfPointsRhumbLine(A,d,r),A=ut.clone(d,Vz);let f=(a+1)*3,E=new Array(f),_=0;for(h=0;h<i-1;h++){let N=e[h],T=e[h+1],F=o?s[h]:s,b=o?s[h+1]:s;_=Tlt(N,T,r,n,F,b,E,_)}QO.length=0;let R=e[i-1],I=n.cartesianToCartographic(R,vC);I.height=o?s[i-1]:s;let C=n.cartographicToCartesian(I,kc);return l.pack(C,E,f-3),E};yo.generateCartesianArc=function(t){let e=yo.generateArc(t),i=e.length/3,n=new Array(i);for(let s=0;s<i;s++)n[s]=l.unpack(e,s*3);return n};yo.generateCartesianRhumbArc=function(t){let e=yo.generateRhumbArc(t),i=e.length/3,n=new Array(i);for(let s=0;s<i;s++)n[s]=l.unpack(e,s*3);return n};On=yo});function ZR(t,e){if(!m(t))throw new Y("identifier is required.");m(Bz[t])||(Bz[t]=!0,console.warn(Z(e,t)))}var Bz,zC,LO=O(()=>{bt();mt();Vt();Bz={};ZR.geometryOutlines="Entity geometry outlines are unsupported on terrain. Outlines will be disabled. To enable outlines, disable geometry terrain clamping by explicitly setting height to 0.";ZR.geometryZIndex="Entity geometry with zIndex are unsupported when height or extrudedHeight are defined.  zIndex will be ignored";ZR.geometryHeightReference="Entity corridor, ellipse, polygon or rectangle with heightReference must also have a defined height.  heightReference will be ignored";ZR.geometryExtrudedHeightReference="Entity corridor, ellipse, polygon or rectangle with extrudedHeightReference must also have a defined extrudedHeight.  extrudedHeightReference will be ignored";zC=ZR});function Dlt(t,e){let i=new Array(t.length);for(let n=0;n<t.length;n++){let s=t[n];yO=e.cartesianToCartographic(s,yO),i[n]=yO.height,t[n]=e.scaleToGeodeticSurface(s,s)}return i}function wO(t,e,i,n){let s=t[0],o=t[1],r=l.angleBetween(s,o),a=Math.ceil(r/n),h=new Array(a),A;if(e===i){for(A=0;A<a;A++)h[A]=e;return h.push(i),h}let f=(i-e)/a;for(A=1;A<a;A++){let E=e+A*f;h[A]=E}return h[0]=e,h.push(i),h}function Mlt(t,e,i,n){let s=new oo(i,n),o=s.projectPointOntoPlane(l.add(i,t,XC),XC),r=s.projectPointOntoPlane(l.add(i,e,qC),qC),a=nt.angleBetween(o,r);return r.x*o.y-r.y*o.x>=0?-a:a}function Fh(t,e,i,n,s,o,r,a){let h=Llt,A=ylt;Ed=In.eastNorthUpToFixedFrame(t,s,Ed),h=at.multiplyByPointAsVector(Ed,Ult,h),h=l.normalize(h,h);let d=Mlt(h,e,t,s);xO=lt.fromRotationZ(d,xO),Wz.z=o,Ed=at.multiplyTransformation(Ed,at.fromRotationTranslation(xO,Wz,Qlt),Ed);let f=klt;f[0]=r;for(let E=0;E<a;E++)for(let _=0;_<i.length;_+=3)A=l.fromArray(i,_,A),A=lt.multiplyByVector(f,A,A),A=at.multiplyByPoint(Ed,A,A),n.push(A.x,A.y,A.z);return n}function PO(t,e,i,n,s,o,r){for(let a=0;a<t.length;a+=3){let h=l.fromArray(t,a,wlt);n=Fh(h,e,i,n,s,o[a/3],r,1)}return n}function xlt(t,e){let i=t.length,n=new Array(i*6),s=0,o=e.x+e.width/2,r=e.y+e.height/2,a=t[0];n[s++]=a.x-o,n[s++]=0,n[s++]=a.y-r;for(let h=1;h<i;h++){a=t[h];let A=a.x-o,d=a.y-r;n[s++]=A,n[s++]=0,n[s++]=d,n[s++]=A,n[s++]=0,n[s++]=d}return a=t[0],n[s++]=a.x-o,n[s++]=0,n[s++]=a.y-r,n}function Dz(t,e){let i=t.length,n=new Array(i*3),s=0,o=e.x+e.width/2,r=e.y+e.height/2;for(let a=0;a<i;a++)n[s++]=t[a].x-o,n[s++]=0,n[s++]=t[a].y-r;return n}function kz(t,e,i,n,s,o,r,a,h,A){let d=l.angleBetween(l.subtract(e,t,Vf),l.subtract(i,t,KC)),f=n===Cn.BEVELED?0:Math.ceil(d/L.toRadians(5)),E;s?E=lt.fromQuaternion(Ae.fromAxisAngle(l.negate(t,Vf),d/(f+1),Mz),Qz):E=lt.fromQuaternion(Ae.fromAxisAngle(t,d/(f+1),Mz),Qz);let _,R;if(e=l.clone(e,Uz),f>0){let I=A?2:1;for(let C=0;C<f;C++)e=lt.multiplyByVector(E,e,e),_=l.subtract(e,t,Vf),_=l.normalize(_,_),s||(_=l.negate(_,_)),R=o.scaleToGeodeticSurface(e,KC),r=Fh(R,_,a,r,o,h,1,I)}else _=l.subtract(e,t,Vf),_=l.normalize(_,_),s||(_=l.negate(_,_)),R=o.scaleToGeodeticSurface(e,KC),r=Fh(R,_,a,r,o,h,1,1),i=l.clone(i,Uz),_=l.subtract(i,t,Vf),_=l.normalize(_,_),s||(_=l.negate(_,_)),R=o.scaleToGeodeticSurface(i,KC),r=Fh(R,_,a,r,o,h,1,1);return r}var Ks,blt,Flt,Ylt,Slt,Olt,Vlt,Glt,Blt,Wlt,Vf,KC,IR,yO,XC,qC,Ult,Ed,Qlt,xO,klt,Llt,ylt,Wz,wlt,Mz,Uz,Qz,Plt,Jlt,Lc,$C=O(()=>{Xe();Ht();Vs();ri();fd();Xm();_e();dn();Fi();Of();$s();fr();LO();Ks=[new l,new l],blt=new l,Flt=new l,Ylt=new l,Slt=new l,Olt=new l,Vlt=new l,Glt=new l,Blt=new l,Wlt=new l,Vf=new l,KC=new l,IR={},yO=new ut;XC=new l,qC=new l;Ult=new l(-1,0,0),Ed=new at,Qlt=new at,xO=new lt,klt=lt.IDENTITY.clone(),Llt=new l,ylt=new ie,Wz=new l;wlt=new l;Mz=new Ae,Uz=new l,Qz=new lt;IR.removeDuplicatesFromShape=function(t){let e=t.length,i=[];for(let n=e-1,s=0;s<e;n=s++){let o=t[n],r=t[s];nt.equals(o,r)||i.push(r)}return i};IR.angleIsGreaterThanPi=function(t,e,i,n){let s=new oo(i,n),o=s.projectPointOntoPlane(l.add(i,t,XC),XC),r=s.projectPointOntoPlane(l.add(i,e,qC),qC);return r.x*o.y-r.y*o.x>=0};Plt=new l,Jlt=new l;IR.computePositions=function(t,e,i,n,s){let o=n._ellipsoid,r=Dlt(t,o),a=n._granularity,h=n._cornerType,A=s?xlt(e,i):Dz(e,i),d=s?Dz(e,i):void 0,f=i.height/2,E=i.width/2,_=t.length,R=[],I=s?[]:void 0,C=blt,N=Flt,T=Ylt,F=Slt,b=Olt,G=Vlt,M=Glt,Q=Blt,U=Wlt,k=t[0],y=t[1];F=o.geodeticSurfaceNormal(k,F),C=l.subtract(y,k,C),C=l.normalize(C,C),Q=l.cross(F,C,Q),Q=l.normalize(Q,Q);let c=r[0],g=r[1];s&&(I=Fh(k,Q,d,I,o,c+f,1,1)),U=l.clone(k,U),k=y,N=l.negate(C,N);let V,D;for(let H=1;H<_-1;H++){let j=s?2:1;if(y=t[H+1],k.equals(y)){zC("Positions are too close and are considered equivalent with rounding error.");continue}C=l.subtract(y,k,C),C=l.normalize(C,C),T=l.add(C,N,T),T=l.normalize(T,T),F=o.geodeticSurfaceNormal(k,F);let X=l.multiplyByScalar(F,l.dot(C,F),Plt);l.subtract(C,X,X),l.normalize(X,X);let tt=l.multiplyByScalar(F,l.dot(N,F),Jlt);if(l.subtract(N,tt,tt),l.normalize(tt,tt),!L.equalsEpsilon(Math.abs(l.dot(X,tt)),1,L.EPSILON7)){T=l.cross(T,F,T),T=l.cross(F,T,T),T=l.normalize(T,T);let It=1/Math.max(.25,l.magnitude(l.cross(T,N,Vf))),gt=IR.angleIsGreaterThanPi(C,N,k,o);gt?(b=l.add(k,l.multiplyByScalar(T,It*E,T),b),G=l.add(b,l.multiplyByScalar(Q,E,G),G),Ks[0]=l.clone(U,Ks[0]),Ks[1]=l.clone(G,Ks[1]),V=wO(Ks,c+f,g+f,a),D=On.generateArc({positions:Ks,granularity:a,ellipsoid:o}),R=PO(D,Q,A,R,o,V,1),Q=l.cross(F,C,Q),Q=l.normalize(Q,Q),M=l.add(b,l.multiplyByScalar(Q,E,M),M),h===Cn.ROUNDED||h===Cn.BEVELED?kz(b,G,M,h,gt,o,R,A,g+f,s):(T=l.negate(T,T),R=Fh(k,T,A,R,o,g+f,It,j)),U=l.clone(M,U)):(b=l.add(k,l.multiplyByScalar(T,It*E,T),b),G=l.add(b,l.multiplyByScalar(Q,-E,G),G),Ks[0]=l.clone(U,Ks[0]),Ks[1]=l.clone(G,Ks[1]),V=wO(Ks,c+f,g+f,a),D=On.generateArc({positions:Ks,granularity:a,ellipsoid:o}),R=PO(D,Q,A,R,o,V,1),Q=l.cross(F,C,Q),Q=l.normalize(Q,Q),M=l.add(b,l.multiplyByScalar(Q,-E,M),M),h===Cn.ROUNDED||h===Cn.BEVELED?kz(b,G,M,h,gt,o,R,A,g+f,s):R=Fh(k,T,A,R,o,g+f,It,j),U=l.clone(M,U)),N=l.negate(C,N)}else R=Fh(U,Q,A,R,o,c+f,1,1),U=k;c=g,g=r[H+1],k=y}Ks[0]=l.clone(U,Ks[0]),Ks[1]=l.clone(k,Ks[1]),V=wO(Ks,c+f,g+f,a),D=On.generateArc({positions:Ks,granularity:a,ellipsoid:o}),R=PO(D,Q,A,R,o,V,1),s&&(I=Fh(k,Q,d,I,o,g+f,1,1)),_=R.length;let w=s?_+I.length:_,x=new Float64Array(w);return x.set(R),s&&x.set(I,_),x};Lc=IR});function tg(t,e,i,n,s){let o=l.angleBetween(l.subtract(e,t,Gf),l.subtract(i,t,Pz)),r=n===Cn.BEVELED?1:Math.ceil(o/L.toRadians(5))+1,a=r*3,h=new Array(a);h[a-3]=i.x,h[a-2]=i.y,h[a-1]=i.z;let A;s?A=lt.fromQuaternion(Ae.fromAxisAngle(l.negate(t,Gf),o/r,yz),wz):A=lt.fromQuaternion(Ae.fromAxisAngle(t,o/r,yz),wz);let d=0;e=l.clone(e,Gf);for(let f=0;f<r;f++)e=lt.multiplyByVector(A,e,e),h[d++]=e.x,h[d++]=e.y,h[d++]=e.z;return h}function tdt(t){let e=Jz,i=jz,n=Hz,s=t[1];i=l.fromArray(t[1],s.length-3,i),n=l.fromArray(t[0],0,n),e=l.midpoint(i,n,e);let o=tg(e,i,n,Cn.ROUNDED,!1),r=t.length-1,a=t[r-1];s=t[r],i=l.fromArray(a,a.length-3,i),n=l.fromArray(s,0,n),e=l.midpoint(i,n,e);let h=tg(e,i,n,Cn.ROUNDED,!1);return[o,h]}function xz(t,e,i,n){let s=Gf;return n?s=l.add(t,e,s):(e=l.negate(e,e),s=l.add(t,e,s)),[s.x,s.y,s.z,i.x,i.y,i.z]}function JO(t,e,i,n){let s=new Array(t.length),o=new Array(t.length),r=l.multiplyByScalar(e,i,Gf),a=l.negate(r,Pz),h=0,A=t.length-1;for(let d=0;d<t.length;d+=3){let f=l.fromArray(t,d,jlt),E=l.add(f,a,Lz);s[h++]=E.x,s[h++]=E.y,s[h++]=E.z;let _=l.add(f,r,Lz);o[A--]=_.z,o[A--]=_.y,o[A--]=_.x}return n.push(s,o),n}var jO,Gf,Pz,jlt,Lz,wo,Jz,jz,Hz,Hlt,vlt,zlt,Klt,Xlt,qlt,$lt,yz,wz,edt,idt,vi,HO=O(()=>{Ht();fd();mt();_e();dn();Of();$C();$s();jO={},Gf=new l,Pz=new l,jlt=new l,Lz=new l,wo=[new l,new l],Jz=new l,jz=new l,Hz=new l,Hlt=new l,vlt=new l,zlt=new l,Klt=new l,Xlt=new l,qlt=new l,$lt=new l,yz=new Ae,wz=new lt;jO.addAttribute=function(t,e,i,n){let s=e.x,o=e.y,r=e.z;m(i)&&(t[i]=s,t[i+1]=o,t[i+2]=r),m(n)&&(t[n]=r,t[n-1]=o,t[n-2]=s)};edt=new l,idt=new l;jO.computePositions=function(t){let e=t.granularity,i=t.positions,n=t.ellipsoid,s=t.width/2,o=t.cornerType,r=t.saveAttributes,a=Jz,h=jz,A=Hz,d=Hlt,f=vlt,E=zlt,_=Klt,R=Xlt,I=qlt,C=$lt,N=[],T=r?[]:void 0,F=r?[]:void 0,b=i[0],G=i[1];h=l.normalize(l.subtract(G,b,h),h),a=n.geodeticSurfaceNormal(b,a),d=l.normalize(l.cross(a,h,d),d),r&&(T.push(d.x,d.y,d.z),F.push(a.x,a.y,a.z)),_=l.clone(b,_),b=G,A=l.negate(h,A);let M,Q=[],U,k=i.length;for(U=1;U<k-1;U++){a=n.geodeticSurfaceNormal(b,a),G=i[U+1],h=l.normalize(l.subtract(G,b,h),h),f=l.normalize(l.add(h,A,f),f);let c=l.multiplyByScalar(a,l.dot(h,a),edt);l.subtract(h,c,c),l.normalize(c,c);let g=l.multiplyByScalar(a,l.dot(A,a),idt);if(l.subtract(A,g,g),l.normalize(g,g),!L.equalsEpsilon(Math.abs(l.dot(c,g)),1,L.EPSILON7)){f=l.cross(f,a,f),f=l.cross(a,f,f),f=l.normalize(f,f);let D=s/Math.max(.25,l.magnitude(l.cross(f,A,Gf))),w=Lc.angleIsGreaterThanPi(h,A,b,n);f=l.multiplyByScalar(f,D,f),w?(R=l.add(b,f,R),C=l.add(R,l.multiplyByScalar(d,s,C),C),I=l.add(R,l.multiplyByScalar(d,s*2,I),I),wo[0]=l.clone(_,wo[0]),wo[1]=l.clone(C,wo[1]),M=On.generateArc({positions:wo,granularity:e,ellipsoid:n}),N=JO(M,d,s,N),r&&(T.push(d.x,d.y,d.z),F.push(a.x,a.y,a.z)),E=l.clone(I,E),d=l.normalize(l.cross(a,h,d),d),I=l.add(R,l.multiplyByScalar(d,s*2,I),I),_=l.add(R,l.multiplyByScalar(d,s,_),_),o===Cn.ROUNDED||o===Cn.BEVELED?Q.push({leftPositions:tg(R,E,I,o,w)}):Q.push({leftPositions:xz(b,l.negate(f,f),I,w)})):(I=l.add(b,f,I),C=l.add(I,l.negate(l.multiplyByScalar(d,s,C),C),C),R=l.add(I,l.negate(l.multiplyByScalar(d,s*2,R),R),R),wo[0]=l.clone(_,wo[0]),wo[1]=l.clone(C,wo[1]),M=On.generateArc({positions:wo,granularity:e,ellipsoid:n}),N=JO(M,d,s,N),r&&(T.push(d.x,d.y,d.z),F.push(a.x,a.y,a.z)),E=l.clone(R,E),d=l.normalize(l.cross(a,h,d),d),R=l.add(I,l.negate(l.multiplyByScalar(d,s*2,R),R),R),_=l.add(I,l.negate(l.multiplyByScalar(d,s,_),_),_),o===Cn.ROUNDED||o===Cn.BEVELED?Q.push({rightPositions:tg(I,E,R,o,w)}):Q.push({rightPositions:xz(b,f,R,w)})),A=l.negate(h,A)}b=G}a=n.geodeticSurfaceNormal(b,a),wo[0]=l.clone(_,wo[0]),wo[1]=l.clone(b,wo[1]),M=On.generateArc({positions:wo,granularity:e,ellipsoid:n}),N=JO(M,d,s,N),r&&(T.push(d.x,d.y,d.z),F.push(a.x,a.y,a.z));let y;return o===Cn.ROUNDED&&(y=tdt(N)),{positions:N,corners:Q,lefts:T,normals:F,endPositions:y}};vi=jO});function $z(t,e){for(let i=0;i<t.length;i++)t[i]=e.scaleToGeodeticSurface(t[i],t[i]);return t}function Ja(t,e,i,n,s,o){let r=t.normals,a=t.tangents,h=t.bitangents,A=l.normalize(l.cross(i,e,yc),yc);o.normal&&vi.addAttribute(r,e,n,s),o.tangent&&vi.addAttribute(a,A,n,s),o.bitangent&&vi.addAttribute(h,i,n,s)}function t5(t,e,i){let n=t.positions,s=t.corners,o=t.endPositions,r=t.lefts,a=t.normals,h=new we,A,d=0,f=0,E,_=0,R;for(E=0;E<n.length;E+=2)R=n[E].length-3,d+=R,_+=R*2,f+=n[E+1].length-3;for(d+=3,f+=3,E=0;E<s.length;E++){A=s[E];let Ct=s[E].leftPositions;m(Ct)?(R=Ct.length,d+=R,_+=R):(R=s[E].rightPositions.length,f+=R,_+=R)}let I=m(o),C;I&&(C=o[0].length-3,d+=C,f+=C,C/=3,_+=C*6);let N=d+f,T=new Float64Array(N),F=e.normal?new Float32Array(N):void 0,b=e.tangent?new Float32Array(N):void 0,G=e.bitangent?new Float32Array(N):void 0,M={normals:F,tangents:b,bitangents:G},Q=0,U=N-1,k,y,c,g,V=Kz,D=Xz,w,x,H=C/2,j=te.createTypedArray(N/3,_),X=0;if(I){x=eg,w=ig;let Ct=o[0];for(V=l.fromArray(a,0,V),D=l.fromArray(r,0,D),E=0;E<H;E++)x=l.fromArray(Ct,(H-1-E)*3,x),w=l.fromArray(Ct,(H+E)*3,w),vi.addAttribute(T,w,Q),vi.addAttribute(T,x,void 0,U),Ja(M,V,D,Q,U,e),y=Q/3,g=y+1,k=(U-2)/3,c=k-1,j[X++]=k,j[X++]=y,j[X++]=c,j[X++]=c,j[X++]=y,j[X++]=g,Q+=3,U-=3}let tt=0,B=0,It=n[tt++],gt=n[tt++];T.set(It,Q),T.set(gt,U-gt.length+1),D=l.fromArray(r,B,D);let Yt,Mt;for(R=gt.length-3,E=0;E<R;E+=3)Yt=i.geodeticSurfaceNormal(l.fromArray(It,E,yc),yc),Mt=i.geodeticSurfaceNormal(l.fromArray(gt,R-E,Bf),Bf),V=l.normalize(l.add(Yt,Mt,V),V),Ja(M,V,D,Q,U,e),y=Q/3,g=y+1,k=(U-2)/3,c=k-1,j[X++]=k,j[X++]=y,j[X++]=c,j[X++]=c,j[X++]=y,j[X++]=g,Q+=3,U-=3;for(Yt=i.geodeticSurfaceNormal(l.fromArray(It,R,yc),yc),Mt=i.geodeticSurfaceNormal(l.fromArray(gt,R,Bf),Bf),V=l.normalize(l.add(Yt,Mt,V),V),B+=3,E=0;E<s.length;E++){let Ct;A=s[E];let zt=A.leftPositions,kt=A.rightPositions,Jt,Wt,Ft=qz,ee=eg,ce=ig;if(V=l.fromArray(a,B,V),m(zt)){for(Ja(M,V,D,void 0,U,e),U-=3,Jt=g,Wt=c,Ct=0;Ct<zt.length/3;Ct++)Ft=l.fromArray(zt,Ct*3,Ft),j[X++]=Jt,j[X++]=Wt-Ct-1,j[X++]=Wt-Ct,vi.addAttribute(T,Ft,void 0,U),ee=l.fromArray(T,(Wt-Ct-1)*3,ee),ce=l.fromArray(T,Jt*3,ce),D=l.normalize(l.subtract(ee,ce,D),D),Ja(M,V,D,void 0,U,e),U-=3;Ft=l.fromArray(T,Jt*3,Ft),ee=l.subtract(l.fromArray(T,Wt*3,ee),Ft,ee),ce=l.subtract(l.fromArray(T,(Wt-Ct)*3,ce),Ft,ce),D=l.normalize(l.add(ee,ce,D),D),Ja(M,V,D,Q,void 0,e),Q+=3}else{for(Ja(M,V,D,Q,void 0,e),Q+=3,Jt=c,Wt=g,Ct=0;Ct<kt.length/3;Ct++)Ft=l.fromArray(kt,Ct*3,Ft),j[X++]=Jt,j[X++]=Wt+Ct,j[X++]=Wt+Ct+1,vi.addAttribute(T,Ft,Q),ee=l.fromArray(T,Jt*3,ee),ce=l.fromArray(T,(Wt+Ct)*3,ce),D=l.normalize(l.subtract(ee,ce,D),D),Ja(M,V,D,Q,void 0,e),Q+=3;Ft=l.fromArray(T,Jt*3,Ft),ee=l.subtract(l.fromArray(T,(Wt+Ct)*3,ee),Ft,ee),ce=l.subtract(l.fromArray(T,Wt*3,ce),Ft,ce),D=l.normalize(l.negate(l.add(ce,ee,D),D),D),Ja(M,V,D,void 0,U,e),U-=3}for(It=n[tt++],gt=n[tt++],It.splice(0,3),gt.splice(gt.length-3,3),T.set(It,Q),T.set(gt,U-gt.length+1),R=gt.length-3,B+=3,D=l.fromArray(r,B,D),Ct=0;Ct<gt.length;Ct+=3)Yt=i.geodeticSurfaceNormal(l.fromArray(It,Ct,yc),yc),Mt=i.geodeticSurfaceNormal(l.fromArray(gt,R-Ct,Bf),Bf),V=l.normalize(l.add(Yt,Mt,V),V),Ja(M,V,D,Q,U,e),g=Q/3,y=g-1,c=(U-2)/3,k=c+1,j[X++]=k,j[X++]=y,j[X++]=c,j[X++]=c,j[X++]=y,j[X++]=g,Q+=3,U-=3;Q-=3,U+=3}if(V=l.fromArray(a,a.length-3,V),Ja(M,V,D,Q,U,e),I){Q+=3,U-=3,x=eg,w=ig;let Ct=o[1];for(E=0;E<H;E++)x=l.fromArray(Ct,(C-E-1)*3,x),w=l.fromArray(Ct,E*3,w),vi.addAttribute(T,x,void 0,U),vi.addAttribute(T,w,Q),Ja(M,V,D,Q,U,e),g=Q/3,y=g-1,c=(U-2)/3,k=c+1,j[X++]=k,j[X++]=y,j[X++]=c,j[X++]=c,j[X++]=y,j[X++]=g,Q+=3,U-=3}if(h.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:T}),e.st){let Ct=new Float32Array(N/3*2),zt,kt,Jt=0;if(I){d/=3,f/=3;let Wt=Math.PI/(C+1);kt=1/(d-C+1),zt=1/(f-C+1);let Ft,ee=C/2;for(E=ee+1;E<C+1;E++)Ft=L.PI_OVER_TWO+Wt*E,Ct[Jt++]=zt*(1+Math.cos(Ft)),Ct[Jt++]=.5*(1+Math.sin(Ft));for(E=1;E<f-C+1;E++)Ct[Jt++]=E*zt,Ct[Jt++]=0;for(E=C;E>ee;E--)Ft=L.PI_OVER_TWO-E*Wt,Ct[Jt++]=1-zt*(1+Math.cos(Ft)),Ct[Jt++]=.5*(1+Math.sin(Ft));for(E=ee;E>0;E--)Ft=L.PI_OVER_TWO-Wt*E,Ct[Jt++]=1-kt*(1+Math.cos(Ft)),Ct[Jt++]=.5*(1+Math.sin(Ft));for(E=d-C;E>0;E--)Ct[Jt++]=E*kt,Ct[Jt++]=1;for(E=1;E<ee+1;E++)Ft=L.PI_OVER_TWO+Wt*E,Ct[Jt++]=kt*(1+Math.cos(Ft)),Ct[Jt++]=.5*(1+Math.sin(Ft))}else{for(d/=3,f/=3,kt=1/(d-1),zt=1/(f-1),E=0;E<f;E++)Ct[Jt++]=E*zt,Ct[Jt++]=0;for(E=d;E>0;E--)Ct[Jt++]=(E-1)*kt,Ct[Jt++]=1}h.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:Ct})}return e.normal&&(h.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:M.normals})),e.tangent&&(h.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:M.tangents})),e.bitangent&&(h.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:M.bitangents})),{attributes:h,indices:j}}function sdt(t,e){if(!e.normal&&!e.tangent&&!e.bitangent&&!e.st)return t;let i=t.position.values,n,s;(e.normal||e.bitangent)&&(n=t.normal.values,s=t.bitangent.values);let o=t.position.values.length/18,r=o*3,a=o*2,h=r*2,A;if(e.normal||e.bitangent||e.tangent){let d=e.normal?new Float32Array(r*6):void 0,f=e.tangent?new Float32Array(r*6):void 0,E=e.bitangent?new Float32Array(r*6):void 0,_=Kz,R=Xz,I=eg,C=ig,N=ndt,T=qz,F=h;for(A=0;A<r;A+=3){let b=F+h;_=l.fromArray(i,A,_),R=l.fromArray(i,A+r,R),I=l.fromArray(i,(A+3)%r,I),R=l.subtract(R,_,R),I=l.subtract(I,_,I),C=l.normalize(l.cross(R,I,C),C),e.normal&&(vi.addAttribute(d,C,b),vi.addAttribute(d,C,b+3),vi.addAttribute(d,C,F),vi.addAttribute(d,C,F+3)),(e.tangent||e.bitangent)&&(T=l.fromArray(n,A,T),e.bitangent&&(vi.addAttribute(E,T,b),vi.addAttribute(E,T,b+3),vi.addAttribute(E,T,F),vi.addAttribute(E,T,F+3)),e.tangent&&(N=l.normalize(l.cross(T,C,N),N),vi.addAttribute(f,N,b),vi.addAttribute(f,N,b+3),vi.addAttribute(f,N,F),vi.addAttribute(f,N,F+3))),F+=6}if(e.normal){for(d.set(n),A=0;A<r;A+=3)d[A+r]=-n[A],d[A+r+1]=-n[A+1],d[A+r+2]=-n[A+2];t.normal.values=d}else t.normal=void 0;if(e.bitangent?(E.set(s),E.set(s,r),t.bitangent.values=E):t.bitangent=void 0,e.tangent){let b=t.tangent.values;f.set(b),f.set(b,r),t.tangent.values=f}}if(e.st){let d=t.st.values,f=new Float32Array(a*6);f.set(d),f.set(d,a);let E=a*2;for(let _=0;_<2;_++){for(f[E++]=d[0],f[E++]=d[1],A=2;A<a;A+=2){let R=d[A],I=d[A+1];f[E++]=R,f[E++]=I,f[E++]=R,f[E++]=I}f[E++]=d[0],f[E++]=d[1]}t.st.values=f}return t}function vO(t,e,i){i[e++]=t[0],i[e++]=t[1],i[e++]=t[2];for(let n=3;n<t.length;n+=3){let s=t[n],o=t[n+1],r=t[n+2];i[e++]=s,i[e++]=o,i[e++]=r,i[e++]=s,i[e++]=o,i[e++]=r}return i[e++]=t[0],i[e++]=t[1],i[e++]=t[2],i}function odt(t,e){let i=new Ot({position:e.position,normal:e.normal||e.bitangent||t.shadowVolume,tangent:e.tangent,bitangent:e.normal||e.bitangent,st:e.st}),n=t.ellipsoid,s=vi.computePositions(t),o=t5(s,i,n),r=t.height,a=t.extrudedHeight,h=o.attributes,A=o.indices,d=h.position.values,f=d.length,E=new Float64Array(f*6),_=new Float64Array(f);_.set(d);let R=new Float64Array(f*4);d=ui.scaleToGeodeticHeight(d,r,n),R=vO(d,0,R),_=ui.scaleToGeodeticHeight(_,a,n),R=vO(_,f*2,R),E.set(d),E.set(_,f),E.set(R,f*2),h.position.values=E,h=sdt(h,e);let I,C=f/3;if(t.shadowVolume){let k=h.normal.values;f=k.length;let y=new Float32Array(f*6);for(I=0;I<f;I++)k[I]=-k[I];y.set(k,f),y=vO(k,f*4,y),h.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:y}),e.normal||(h.normal=void 0)}if(m(t.offsetAttribute)){let k=new Uint8Array(C*6);if(t.offsetAttribute===Pe.TOP)k=k.fill(1,0,C).fill(1,C*2,C*4);else{let y=t.offsetAttribute===Pe.NONE?0:1;k=k.fill(y)}h.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:k})}let N=A.length,T=C+C,F=te.createTypedArray(E.length/3,N*2+T*3);F.set(A);let b=N;for(I=0;I<N;I+=3){let k=A[I],y=A[I+1],c=A[I+2];F[b++]=c+C,F[b++]=y+C,F[b++]=k+C}let G,M,Q,U;for(I=0;I<T;I+=2)G=I+T,M=G+T,Q=G+1,U=M+1,F[b++]=G,F[b++]=M,F[b++]=Q,F[b++]=Q,F[b++]=M,F[b++]=U;return{attributes:h,indices:F}}function zz(t,e,i,n,s,o){let r=l.subtract(e,t,vz);l.normalize(r,r);let a=i.geodeticSurfaceNormal(t,pR),h=l.cross(r,a,vz);l.multiplyByScalar(h,n,h);let A=s.latitude,d=s.longitude,f=o.latitude,E=o.longitude;l.add(t,h,pR),i.cartesianToCartographic(pR,$r);let _=$r.latitude,R=$r.longitude;A=Math.min(A,_),d=Math.min(d,R),f=Math.max(f,_),E=Math.max(E,R),l.subtract(t,h,pR),i.cartesianToCartographic(pR,$r),_=$r.latitude,R=$r.longitude,A=Math.min(A,_),d=Math.min(d,R),f=Math.max(f,_),E=Math.max(E,R),s.latitude=A,s.longitude=d,o.latitude=f,o.longitude=E}function e5(t,e,i,n,s){t=$z(t,e);let o=Xn(t,l.equalsEpsilon),r=o.length;if(r<2||i<=0)return new Xt;let a=i*.5;rr.latitude=Number.POSITIVE_INFINITY,rr.longitude=Number.POSITIVE_INFINITY,ar.latitude=Number.NEGATIVE_INFINITY,ar.longitude=Number.NEGATIVE_INFINITY;let h,A;if(n===Cn.ROUNDED){let E=o[0];l.subtract(E,o[1],qr),l.normalize(qr,qr),l.multiplyByScalar(qr,a,qr),l.add(E,qr,uR),e.cartesianToCartographic(uR,$r),h=$r.latitude,A=$r.longitude,rr.latitude=Math.min(rr.latitude,h),rr.longitude=Math.min(rr.longitude,A),ar.latitude=Math.max(ar.latitude,h),ar.longitude=Math.max(ar.longitude,A)}for(let E=0;E<r-1;++E)zz(o[E],o[E+1],e,a,rr,ar);let d=o[r-1];l.subtract(d,o[r-2],qr),l.normalize(qr,qr),l.multiplyByScalar(qr,a,qr),l.add(d,qr,uR),zz(d,uR,e,a,rr,ar),n===Cn.ROUNDED&&(e.cartesianToCartographic(uR,$r),h=$r.latitude,A=$r.longitude,rr.latitude=Math.min(rr.latitude,h),rr.longitude=Math.min(rr.longitude,A),ar.latitude=Math.max(ar.latitude,h),ar.longitude=Math.max(ar.longitude,A));let f=m(s)?s:new Xt;return f.north=ar.latitude,f.south=rr.latitude,f.east=ar.longitude,f.west=rr.longitude,f}function Sh(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.width;p.defined("options.positions",e),p.defined("options.width",i);let n=Z(t.height,0),s=Z(t.extrudedHeight,n);this._positions=e,this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._vertexFormat=Ot.clone(Z(t.vertexFormat,Ot.DEFAULT)),this._width=i,this._height=Math.max(n,s),this._extrudedHeight=Math.min(n,s),this._cornerType=Z(t.cornerType,Cn.ROUNDED),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._shadowVolume=Z(t.shadowVolume,!1),this._workerName="createCorridorGeometry",this._offsetAttribute=t.offsetAttribute,this._rectangle=void 0,this.packedLength=1+e.length*l.packedLength+ot.packedLength+Ot.packedLength+7}var Kz,Xz,eg,ig,ndt,qz,yc,Bf,vz,pR,$r,qr,uR,rr,ar,i5,n5,Yh,zO,s5=O(()=>{Oa();_i();Ht();ri();ae();oi();fd();HO();bt();mt();Ve();yi();ji();En();go();Di();_e();Pa();Xi();pn();Ls();Kz=new l,Xz=new l,eg=new l,ig=new l,ndt=new l,qz=new l,yc=new l,Bf=new l;vz=new l,pR=new l,$r=new ut;qr=new l,uR=new l,rr=new ut,ar=new ut;Sh.pack=function(t,e,i){p.defined("value",t),p.defined("array",e),i=Z(i,0);let n=t._positions,s=n.length;e[i++]=s;for(let o=0;o<s;++o,i+=l.packedLength)l.pack(n[o],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,Ot.pack(t._vertexFormat,e,i),i+=Ot.packedLength,e[i++]=t._width,e[i++]=t._height,e[i++]=t._extrudedHeight,e[i++]=t._cornerType,e[i++]=t._granularity,e[i++]=t._shadowVolume?1:0,e[i]=Z(t._offsetAttribute,-1),e};i5=ot.clone(ot.UNIT_SPHERE),n5=new Ot,Yh={positions:void 0,ellipsoid:i5,vertexFormat:n5,width:void 0,height:void 0,extrudedHeight:void 0,cornerType:void 0,granularity:void 0,shadowVolume:void 0,offsetAttribute:void 0};Sh.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=t[e++],s=new Array(n);for(let R=0;R<n;++R,e+=l.packedLength)s[R]=l.unpack(t,e);let o=ot.unpack(t,e,i5);e+=ot.packedLength;let r=Ot.unpack(t,e,n5);e+=Ot.packedLength;let a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++],E=t[e++]===1,_=t[e];return m(i)?(i._positions=s,i._ellipsoid=ot.clone(o,i._ellipsoid),i._vertexFormat=Ot.clone(r,i._vertexFormat),i._width=a,i._height=h,i._extrudedHeight=A,i._cornerType=d,i._granularity=f,i._shadowVolume=E,i._offsetAttribute=_===-1?void 0:_,i):(Yh.positions=s,Yh.width=a,Yh.height=h,Yh.extrudedHeight=A,Yh.cornerType=d,Yh.granularity=f,Yh.shadowVolume=E,Yh.offsetAttribute=_===-1?void 0:_,new Sh(Yh))};Sh.computeRectangle=function(t,e){t=Z(t,Z.EMPTY_OBJECT);let i=t.positions,n=t.width;p.defined("options.positions",i),p.defined("options.width",n);let s=Z(t.ellipsoid,ot.WGS84),o=Z(t.cornerType,Cn.ROUNDED);return e5(i,s,n,o,e)};Sh.createGeometry=function(t){let e=t._positions,i=t._width,n=t._ellipsoid;e=$z(e,n);let s=Xn(e,l.equalsEpsilon);if(s.length<2||i<=0)return;let o=t._height,r=t._extrudedHeight,a=!L.equalsEpsilon(o,r,0,L.EPSILON2),h=t._vertexFormat,A={ellipsoid:n,positions:s,width:i,cornerType:t._cornerType,granularity:t._granularity,saveAttributes:!0},d;if(a)A.height=o,A.extrudedHeight=r,A.shadowVolume=t._shadowVolume,A.offsetAttribute=t._offsetAttribute,d=odt(A,h);else{let _=vi.computePositions(A);if(d=t5(_,h,n),d.attributes.position.values=ui.scaleToGeodeticHeight(d.attributes.position.values,o,n),m(t._offsetAttribute)){let R=t._offsetAttribute===Pe.NONE?0:1,I=d.attributes.position.values.length,C=new Uint8Array(I/3).fill(R);d.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:C})}}let f=d.attributes,E=Nt.fromVertices(f.position.values,void 0,3);return h.position||(d.attributes.position.values=void 0),new se({attributes:f,indices:d.indices,primitiveType:ne.TRIANGLES,boundingSphere:E,offsetAttribute:t._offsetAttribute})};Sh.createShadowVolume=function(t,e,i){let n=t._granularity,s=t._ellipsoid,o=e(n,s),r=i(n,s);return new Sh({positions:t._positions,width:t._width,cornerType:t._cornerType,ellipsoid:s,granularity:n,extrudedHeight:o,height:r,vertexFormat:Ot.POSITION_ONLY,shadowVolume:!0})};Object.defineProperties(Sh.prototype,{rectangle:{get:function(){return m(this._rectangle)||(this._rectangle=e5(this._positions,this._ellipsoid,this._width,this._cornerType)),this._rectangle}},textureCoordinateRotationPoints:{get:function(){return[0,0,0,1,1,0]}}});zO=Sh});var KO={};He(KO,{default:()=>adt});function rdt(t,e){return m(e)&&(t=zO.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),zO.createGeometry(t)}var adt,XO=O(()=>{s5();mt();Ve();adt=rdt});function hdt(t,e){for(let i=0;i<t.length;i++)t[i]=e.scaleToGeodeticSurface(t[i],t[i]);return t}function a5(t,e){let i=[],n=t.positions,s=t.corners,o=t.endPositions,r=new we,a,h=0,A=0,d,f=0,E;for(d=0;d<n.length;d+=2)E=n[d].length-3,h+=E,f+=E/3*4,A+=n[d+1].length-3;for(h+=3,A+=3,d=0;d<s.length;d++){a=s[d];let w=s[d].leftPositions;m(w)?(E=w.length,h+=E,f+=E/3*2):(E=s[d].rightPositions.length,A+=E,f+=E/3*2)}let _=m(o),R;_&&(R=o[0].length-3,h+=R,A+=R,R/=3,f+=R*4);let I=h+A,C=new Float64Array(I),N=0,T=I-1,F,b,G,M,Q,U,k=R/2,y=te.createTypedArray(I/3,f+4),c=0;if(y[c++]=N/3,y[c++]=(T-2)/3,_){i.push(N/3),U=o5,Q=r5;let w=o[0];for(d=0;d<k;d++)U=l.fromArray(w,(k-1-d)*3,U),Q=l.fromArray(w,(k+d)*3,Q),vi.addAttribute(C,Q,N),vi.addAttribute(C,U,void 0,T),b=N/3,M=b+1,F=(T-2)/3,G=F-1,y[c++]=F,y[c++]=G,y[c++]=b,y[c++]=M,N+=3,T-=3}let g=0,V=n[g++],D=n[g++];for(C.set(V,N),C.set(D,T-D.length+1),E=D.length-3,i.push(N/3,(T-2)/3),d=0;d<E;d+=3)b=N/3,M=b+1,F=(T-2)/3,G=F-1,y[c++]=F,y[c++]=G,y[c++]=b,y[c++]=M,N+=3,T-=3;for(d=0;d<s.length;d++){let w;a=s[d];let x=a.leftPositions,H=a.rightPositions,j,X=Adt;if(m(x)){for(T-=3,j=G,i.push(M),w=0;w<x.length/3;w++)X=l.fromArray(x,w*3,X),y[c++]=j-w-1,y[c++]=j-w,vi.addAttribute(C,X,void 0,T),T-=3;i.push(j-Math.floor(x.length/6)),e===Cn.BEVELED&&i.push((T-2)/3+1),N+=3}else{for(N+=3,j=M,i.push(G),w=0;w<H.length/3;w++)X=l.fromArray(H,w*3,X),y[c++]=j+w,y[c++]=j+w+1,vi.addAttribute(C,X,N),N+=3;i.push(j+Math.floor(H.length/6)),e===Cn.BEVELED&&i.push(N/3-1),T-=3}for(V=n[g++],D=n[g++],V.splice(0,3),D.splice(D.length-3,3),C.set(V,N),C.set(D,T-D.length+1),E=D.length-3,w=0;w<D.length;w+=3)M=N/3,b=M-1,G=(T-2)/3,F=G+1,y[c++]=F,y[c++]=G,y[c++]=b,y[c++]=M,N+=3,T-=3;N-=3,T+=3,i.push(N/3,(T-2)/3)}if(_){N+=3,T-=3,U=o5,Q=r5;let w=o[1];for(d=0;d<k;d++)U=l.fromArray(w,(R-d-1)*3,U),Q=l.fromArray(w,d*3,Q),vi.addAttribute(C,U,void 0,T),vi.addAttribute(C,Q,N),M=N/3,b=M-1,G=(T-2)/3,F=G+1,y[c++]=F,y[c++]=G,y[c++]=b,y[c++]=M,N+=3,T-=3;i.push(N/3)}else i.push(N/3,(T-2)/3);return y[c++]=N/3,y[c++]=(T-2)/3,r.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:C}),{attributes:r,indices:y,wallIndices:i}}function cdt(t){let e=t.ellipsoid,i=vi.computePositions(t),n=a5(i,t.cornerType),s=n.wallIndices,o=t.height,r=t.extrudedHeight,a=n.attributes,h=n.indices,A=a.position.values,d=A.length,f=new Float64Array(d);f.set(A);let E=new Float64Array(d*2);if(A=ui.scaleToGeodeticHeight(A,o,e),f=ui.scaleToGeodeticHeight(f,r,e),E.set(A),E.set(f,d),a.position.values=E,d/=3,m(t.offsetAttribute)){let F=new Uint8Array(d*2);if(t.offsetAttribute===Pe.TOP)F=F.fill(1,0,d);else{let b=t.offsetAttribute===Pe.NONE?0:1;F=F.fill(b)}a.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:F})}let _,R=h.length,I=te.createTypedArray(E.length/3,(R+s.length)*2);I.set(h);let C=R;for(_=0;_<R;_+=2){let F=h[_],b=h[_+1];I[C++]=F+d,I[C++]=b+d}let N,T;for(_=0;_<s.length;_++)N=s[_],T=N+d,I[C++]=N,I[C++]=T;return{attributes:a,indices:I}}function CR(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.width;p.typeOf.object("options.positions",e),p.typeOf.number("options.width",i);let n=Z(t.height,0),s=Z(t.extrudedHeight,n);this._positions=e,this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._width=i,this._height=Math.max(n,s),this._extrudedHeight=Math.min(n,s),this._cornerType=Z(t.cornerType,Cn.ROUNDED),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._offsetAttribute=t.offsetAttribute,this._workerName="createCorridorOutlineGeometry",this.packedLength=1+e.length*l.packedLength+ot.packedLength+6}var o5,r5,Adt,A5,wc,qO,h5=O(()=>{Oa();_i();Ht();ae();oi();fd();HO();bt();mt();Ve();yi();ji();En();go();Di();_e();Pa();Xi();o5=new l,r5=new l,Adt=new l;CR.pack=function(t,e,i){p.typeOf.object("value",t),p.typeOf.object("array",e),i=Z(i,0);let n=t._positions,s=n.length;e[i++]=s;for(let o=0;o<s;++o,i+=l.packedLength)l.pack(n[o],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._width,e[i++]=t._height,e[i++]=t._extrudedHeight,e[i++]=t._cornerType,e[i++]=t._granularity,e[i]=Z(t._offsetAttribute,-1),e};A5=ot.clone(ot.UNIT_SPHERE),wc={positions:void 0,ellipsoid:A5,width:void 0,height:void 0,extrudedHeight:void 0,cornerType:void 0,granularity:void 0,offsetAttribute:void 0};CR.unpack=function(t,e,i){p.typeOf.object("array",t),e=Z(e,0);let n=t[e++],s=new Array(n);for(let E=0;E<n;++E,e+=l.packedLength)s[E]=l.unpack(t,e);let o=ot.unpack(t,e,A5);e+=ot.packedLength;let r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e];return m(i)?(i._positions=s,i._ellipsoid=ot.clone(o,i._ellipsoid),i._width=r,i._height=a,i._extrudedHeight=h,i._cornerType=A,i._granularity=d,i._offsetAttribute=f===-1?void 0:f,i):(wc.positions=s,wc.width=r,wc.height=a,wc.extrudedHeight=h,wc.cornerType=A,wc.granularity=d,wc.offsetAttribute=f===-1?void 0:f,new CR(wc))};CR.createGeometry=function(t){let e=t._positions,i=t._width,n=t._ellipsoid;e=hdt(e,n);let s=Xn(e,l.equalsEpsilon);if(s.length<2||i<=0)return;let o=t._height,r=t._extrudedHeight,a=!L.equalsEpsilon(o,r,0,L.EPSILON2),h={ellipsoid:n,positions:s,width:i,cornerType:t._cornerType,granularity:t._granularity,saveAttributes:!1},A;if(a)h.height=o,h.extrudedHeight=r,h.offsetAttribute=t._offsetAttribute,A=cdt(h);else{let E=vi.computePositions(h);if(A=a5(E,h.cornerType),A.attributes.position.values=ui.scaleToGeodeticHeight(A.attributes.position.values,o,n),m(t._offsetAttribute)){let _=A.attributes.position.values.length,R=t._offsetAttribute===Pe.NONE?0:1,I=new Uint8Array(_/3).fill(R);A.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:I})}}let d=A.attributes,f=Nt.fromVertices(d.position.values,void 0,3);return new se({attributes:d,indices:A.indices,primitiveType:ne.LINES,boundingSphere:f,offsetAttribute:t._offsetAttribute})};qO=CR});var $O={};He($O,{default:()=>ddt});function ldt(t,e){return m(e)&&(t=qO.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),qO.createGeometry(t)}var ddt,tV=O(()=>{h5();mt();Ve();ddt=ldt});var c5,ng,eV=O(()=>{_e();c5={};c5.computePositions=function(t,e,i,n,s){let o=t*.5,r=-o,a=n+n,h=s?2*a:a,A=new Float64Array(h*3),d,f=0,E=0,_=s?a*3:0,R=s?(a+n)*3:n*3;for(d=0;d<n;d++){let I=d/n*L.TWO_PI,C=Math.cos(I),N=Math.sin(I),T=C*i,F=N*i,b=C*e,G=N*e;A[E+_]=T,A[E+_+1]=F,A[E+_+2]=r,A[E+R]=b,A[E+R+1]=G,A[E+R+2]=o,E+=3,s&&(A[f++]=T,A[f++]=F,A[f++]=r,A[f++]=b,A[f++]=G,A[f++]=o)}return A};ng=c5});function Oh(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.length,i=t.topRadius,n=t.bottomRadius,s=Z(t.vertexFormat,Ot.DEFAULT),o=Z(t.slices,128);if(!m(e))throw new Y("options.length must be defined.");if(!m(i))throw new Y("options.topRadius must be defined.");if(!m(n))throw new Y("options.bottomRadius must be defined.");if(o<3)throw new Y("options.slices must be greater than or equal to 3.");if(m(t.offsetAttribute)&&t.offsetAttribute===Pe.TOP)throw new Y("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");this._length=e,this._topRadius=i,this._bottomRadius=n,this._vertexFormat=Ot.clone(s),this._slices=o,this._offsetAttribute=t.offsetAttribute,this._workerName="createCylinderGeometry"}var iV,mdt,fdt,Edt,_dt,l5,Wf,nV,gR,sV=O(()=>{_i();Xe();Ht();oi();eV();bt();mt();Vt();yi();ji();En();go();Di();_e();Xi();Ls();iV=new nt,mdt=new l,fdt=new l,Edt=new l,_dt=new l;Oh.packedLength=Ot.packedLength+5;Oh.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),Ot.pack(t._vertexFormat,e,i),i+=Ot.packedLength,e[i++]=t._length,e[i++]=t._topRadius,e[i++]=t._bottomRadius,e[i++]=t._slices,e[i]=Z(t._offsetAttribute,-1),e};l5=new Ot,Wf={vertexFormat:l5,length:void 0,topRadius:void 0,bottomRadius:void 0,slices:void 0,offsetAttribute:void 0};Oh.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n=Ot.unpack(t,e,l5);e+=Ot.packedLength;let s=t[e++],o=t[e++],r=t[e++],a=t[e++],h=t[e];return m(i)?(i._vertexFormat=Ot.clone(n,i._vertexFormat),i._length=s,i._topRadius=o,i._bottomRadius=r,i._slices=a,i._offsetAttribute=h===-1?void 0:h,i):(Wf.length=s,Wf.topRadius=o,Wf.bottomRadius=r,Wf.slices=a,Wf.offsetAttribute=h===-1?void 0:h,new Oh(Wf))};Oh.createGeometry=function(t){let e=t._length,i=t._topRadius,n=t._bottomRadius,s=t._vertexFormat,o=t._slices;if(e<=0||i<0||n<0||i===0&&n===0)return;let r=o+o,a=o+r,h=r+r,A=ng.computePositions(e,i,n,o,!0),d=s.st?new Float32Array(h*2):void 0,f=s.normal?new Float32Array(h*3):void 0,E=s.tangent?new Float32Array(h*3):void 0,_=s.bitangent?new Float32Array(h*3):void 0,R,I=s.normal||s.tangent||s.bitangent;if(I){let Q=s.tangent||s.bitangent,U=0,k=0,y=0,c=Math.atan2(n-i,e),g=mdt;g.z=Math.sin(c);let V=Math.cos(c),D=Edt,w=fdt;for(R=0;R<o;R++){let x=R/o*L.TWO_PI,H=V*Math.cos(x),j=V*Math.sin(x);I&&(g.x=H,g.y=j,Q&&(D=l.normalize(l.cross(l.UNIT_Z,g,D),D)),s.normal&&(f[U++]=g.x,f[U++]=g.y,f[U++]=g.z,f[U++]=g.x,f[U++]=g.y,f[U++]=g.z),s.tangent&&(E[k++]=D.x,E[k++]=D.y,E[k++]=D.z,E[k++]=D.x,E[k++]=D.y,E[k++]=D.z),s.bitangent&&(w=l.normalize(l.cross(g,D,w),w),_[y++]=w.x,_[y++]=w.y,_[y++]=w.z,_[y++]=w.x,_[y++]=w.y,_[y++]=w.z))}for(R=0;R<o;R++)s.normal&&(f[U++]=0,f[U++]=0,f[U++]=-1),s.tangent&&(E[k++]=1,E[k++]=0,E[k++]=0),s.bitangent&&(_[y++]=0,_[y++]=-1,_[y++]=0);for(R=0;R<o;R++)s.normal&&(f[U++]=0,f[U++]=0,f[U++]=1),s.tangent&&(E[k++]=1,E[k++]=0,E[k++]=0),s.bitangent&&(_[y++]=0,_[y++]=1,_[y++]=0)}let C=12*o-12,N=te.createTypedArray(h,C),T=0,F=0;for(R=0;R<o-1;R++)N[T++]=F,N[T++]=F+2,N[T++]=F+3,N[T++]=F,N[T++]=F+3,N[T++]=F+1,F+=2;for(N[T++]=r-2,N[T++]=0,N[T++]=1,N[T++]=r-2,N[T++]=1,N[T++]=r-1,R=1;R<o-1;R++)N[T++]=r+R+1,N[T++]=r+R,N[T++]=r;for(R=1;R<o-1;R++)N[T++]=a,N[T++]=a+R,N[T++]=a+R+1;let b=0;if(s.st){let Q=Math.max(i,n);for(R=0;R<h;R++){let U=l.fromArray(A,R*3,_dt);d[b++]=(U.x+Q)/(2*Q),d[b++]=(U.y+Q)/(2*Q)}}let G=new we;s.position&&(G.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:A})),s.normal&&(G.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:f})),s.tangent&&(G.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:E})),s.bitangent&&(G.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_})),s.st&&(G.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:d})),iV.x=e*.5,iV.y=Math.max(n,i);let M=new Nt(l.ZERO,nt.magnitude(iV));if(m(t._offsetAttribute)){e=A.length;let Q=t._offsetAttribute===Pe.NONE?0:1,U=new Uint8Array(e/3).fill(Q);G.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:U})}return new se({attributes:G,indices:N,primitiveType:ne.TRIANGLES,boundingSphere:M,offsetAttribute:t._offsetAttribute})};Oh.getUnitCylinder=function(){return m(nV)||(nV=Oh.createGeometry(new Oh({topRadius:1,bottomRadius:1,length:1,vertexFormat:Ot.POSITION_ONLY}))),nV};gR=Oh});var oV={};He(oV,{default:()=>Zdt});function Rdt(t,e){return m(e)&&(t=gR.unpack(t,e)),gR.createGeometry(t)}var Zdt,rV=O(()=>{sV();mt();Zdt=Rdt});function Df(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.length,i=t.topRadius,n=t.bottomRadius,s=Z(t.slices,128),o=Math.max(Z(t.numberOfVerticalLines,16),0);if(p.typeOf.number("options.positions",e),p.typeOf.number("options.topRadius",i),p.typeOf.number("options.bottomRadius",n),p.typeOf.number.greaterThanOrEquals("options.slices",s,3),m(t.offsetAttribute)&&t.offsetAttribute===Pe.TOP)throw new Y("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");this._length=e,this._topRadius=i,this._bottomRadius=n,this._slices=s,this._numberOfVerticalLines=o,this._offsetAttribute=t.offsetAttribute,this._workerName="createCylinderOutlineGeometry"}var aV,_d,AV,d5=O(()=>{_i();Xe();Ht();ae();oi();eV();bt();mt();Vt();yi();ji();En();go();Di();Xi();aV=new nt;Df.packedLength=6;Df.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t._length,e[i++]=t._topRadius,e[i++]=t._bottomRadius,e[i++]=t._slices,e[i++]=t._numberOfVerticalLines,e[i]=Z(t._offsetAttribute,-1),e};_d={length:void 0,topRadius:void 0,bottomRadius:void 0,slices:void 0,numberOfVerticalLines:void 0,offsetAttribute:void 0};Df.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=t[e++],s=t[e++],o=t[e++],r=t[e++],a=t[e++],h=t[e];return m(i)?(i._length=n,i._topRadius=s,i._bottomRadius=o,i._slices=r,i._numberOfVerticalLines=a,i._offsetAttribute=h===-1?void 0:h,i):(_d.length=n,_d.topRadius=s,_d.bottomRadius=o,_d.slices=r,_d.numberOfVerticalLines=a,_d.offsetAttribute=h===-1?void 0:h,new Df(_d))};Df.createGeometry=function(t){let e=t._length,i=t._topRadius,n=t._bottomRadius,s=t._slices,o=t._numberOfVerticalLines;if(e<=0||i<0||n<0||i===0&&n===0)return;let r=s*2,a=ng.computePositions(e,i,n,s,!1),h=s*2,A;if(o>0){let I=Math.min(o,s);A=Math.round(s/I),h+=I}let d=te.createTypedArray(r,h*2),f=0,E;for(E=0;E<s-1;E++)d[f++]=E,d[f++]=E+1,d[f++]=E+s,d[f++]=E+1+s;if(d[f++]=s-1,d[f++]=0,d[f++]=s+s-1,d[f++]=s,o>0)for(E=0;E<s;E+=A)d[f++]=E,d[f++]=E+s;let _=new we;_.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:a}),aV.x=e*.5,aV.y=Math.max(n,i);let R=new Nt(l.ZERO,nt.magnitude(aV));if(m(t._offsetAttribute)){e=a.length;let I=t._offsetAttribute===Pe.NONE?0:1,C=new Uint8Array(e/3).fill(I);_.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:C})}return new se({attributes:_,indices:d,primitiveType:ne.LINES,boundingSphere:R,offsetAttribute:t._offsetAttribute})};AV=Df});var hV={};He(hV,{default:()=>pdt});function Idt(t,e){return m(e)&&(t=AV.unpack(t,e)),AV.createGeometry(t)}var pdt,cV=O(()=>{d5();mt();pdt=Idt});var lV={};He(lV,{default:()=>Cdt});function udt(t,e){return m(e)&&(t=wa.unpack(t,e)),t._center=l.clone(t._center),t._ellipsoid=ot.clone(t._ellipsoid),wa.createGeometry(t)}var Cdt,dV=O(()=>{Ht();mt();_O();Ve();Cdt=udt});var mV={};He(mV,{default:()=>Tdt});function gdt(t,e){return m(e)&&(t=xa.unpack(t,e)),t._center=l.clone(t._center),t._ellipsoid=ot.clone(t._ellipsoid),xa.createGeometry(t)}var Tdt,fV=O(()=>{Ht();mt();pO();Ve();Tdt=gdt});function Vh(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.radii,Odt),i=Z(t.innerRadii,e),n=Z(t.minimumClock,0),s=Z(t.maximumClock,L.TWO_PI),o=Z(t.minimumCone,0),r=Z(t.maximumCone,L.PI),a=Math.round(Z(t.stackPartitions,64)),h=Math.round(Z(t.slicePartitions,64)),A=Z(t.vertexFormat,Ot.DEFAULT);if(h<3)throw new Y("options.slicePartitions cannot be less than three.");if(a<3)throw new Y("options.stackPartitions cannot be less than three.");this._radii=l.clone(e),this._innerRadii=l.clone(i),this._minimumClock=n,this._maximumClock=s,this._minimumCone=o,this._maximumCone=r,this._stackPartitions=a,this._slicePartitions=h,this._vertexFormat=Ot.clone(A),this._offsetAttribute=t.offsetAttribute,this._workerName="createEllipsoidGeometry"}var Ndt,bdt,Fdt,Ydt,Sdt,Odt,m5,f5,E5,_5,R5,xc,EV,Nr,sg=O(()=>{_i();Xe();Ht();oi();bt();mt();Vt();Ve();yi();ji();En();go();Di();_e();Xi();Ls();Ndt=new l,bdt=new l,Fdt=new l,Ydt=new l,Sdt=new l,Odt=new l(1,1,1),m5=Math.cos,f5=Math.sin;Vh.packedLength=2*l.packedLength+Ot.packedLength+7;Vh.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),l.pack(t._radii,e,i),i+=l.packedLength,l.pack(t._innerRadii,e,i),i+=l.packedLength,Ot.pack(t._vertexFormat,e,i),i+=Ot.packedLength,e[i++]=t._minimumClock,e[i++]=t._maximumClock,e[i++]=t._minimumCone,e[i++]=t._maximumCone,e[i++]=t._stackPartitions,e[i++]=t._slicePartitions,e[i]=Z(t._offsetAttribute,-1),e};E5=new l,_5=new l,R5=new Ot,xc={radii:E5,innerRadii:_5,vertexFormat:R5,minimumClock:void 0,maximumClock:void 0,minimumCone:void 0,maximumCone:void 0,stackPartitions:void 0,slicePartitions:void 0,offsetAttribute:void 0};Vh.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n=l.unpack(t,e,E5);e+=l.packedLength;let s=l.unpack(t,e,_5);e+=l.packedLength;let o=Ot.unpack(t,e,R5);e+=Ot.packedLength;let r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++],E=t[e];return m(i)?(i._radii=l.clone(n,i._radii),i._innerRadii=l.clone(s,i._innerRadii),i._vertexFormat=Ot.clone(o,i._vertexFormat),i._minimumClock=r,i._maximumClock=a,i._minimumCone=h,i._maximumCone=A,i._stackPartitions=d,i._slicePartitions=f,i._offsetAttribute=E===-1?void 0:E,i):(xc.minimumClock=r,xc.maximumClock=a,xc.minimumCone=h,xc.maximumCone=A,xc.stackPartitions=d,xc.slicePartitions=f,xc.offsetAttribute=E===-1?void 0:E,new Vh(xc))};Vh.createGeometry=function(t){let e=t._radii;if(e.x<=0||e.y<=0||e.z<=0)return;let i=t._innerRadii;if(i.x<=0||i.y<=0||i.z<=0)return;let n=t._minimumClock,s=t._maximumClock,o=t._minimumCone,r=t._maximumCone,a=t._vertexFormat,h=t._slicePartitions+1,A=t._stackPartitions+1;h=Math.round(h*Math.abs(s-n)/L.TWO_PI),A=Math.round(A*Math.abs(r-o)/L.PI),h<2&&(h=2),A<2&&(A=2);let d,f,E=0,_=[o],R=[n];for(d=0;d<A;d++)_.push(o+d*(r-o)/(A-1));for(_.push(r),f=0;f<h;f++)R.push(n+f*(s-n)/(h-1));R.push(s);let I=_.length,C=R.length,N=0,T=1,F=i.x!==e.x||i.y!==e.y||i.z!==e.z,b=!1,G=!1,M=!1;F&&(T=2,o>0&&(b=!0,N+=h-1),r<Math.PI&&(G=!0,N+=h-1),(s-n)%L.TWO_PI?(M=!0,N+=(A-1)*2+1):N+=1);let Q=C*I*T,U=new Float64Array(Q*3),k=new Array(Q).fill(!1),y=new Array(Q).fill(!1),c=h*A*T,g=6*(c+N+1-(h+A)*T),V=te.createTypedArray(c,g),D=a.normal?new Float32Array(Q*3):void 0,w=a.tangent?new Float32Array(Q*3):void 0,x=a.bitangent?new Float32Array(Q*3):void 0,H=a.st?new Float32Array(Q*2):void 0,j=new Array(I),X=new Array(I);for(d=0;d<I;d++)j[d]=f5(_[d]),X[d]=m5(_[d]);let tt=new Array(C),B=new Array(C);for(f=0;f<C;f++)B[f]=m5(R[f]),tt[f]=f5(R[f]);for(d=0;d<I;d++)for(f=0;f<C;f++)U[E++]=e.x*j[d]*B[f],U[E++]=e.y*j[d]*tt[f],U[E++]=e.z*X[d];let It=Q/2;if(F)for(d=0;d<I;d++)for(f=0;f<C;f++)U[E++]=i.x*j[d]*B[f],U[E++]=i.y*j[d]*tt[f],U[E++]=i.z*X[d],k[It]=!0,d>0&&d!==I-1&&f!==0&&f!==C-1&&(y[It]=!0),It++;E=0;let gt,Yt;for(d=1;d<I-2;d++)for(gt=d*C,Yt=(d+1)*C,f=1;f<C-2;f++)V[E++]=Yt+f,V[E++]=Yt+f+1,V[E++]=gt+f+1,V[E++]=Yt+f,V[E++]=gt+f+1,V[E++]=gt+f;if(F){let Me=I*C;for(d=1;d<I-2;d++)for(gt=Me+d*C,Yt=Me+(d+1)*C,f=1;f<C-2;f++)V[E++]=Yt+f,V[E++]=gt+f,V[E++]=gt+f+1,V[E++]=Yt+f,V[E++]=gt+f+1,V[E++]=Yt+f+1}let Mt,Ct;if(F){if(b)for(Ct=I*C,d=1;d<C-2;d++)V[E++]=d,V[E++]=d+1,V[E++]=Ct+d+1,V[E++]=d,V[E++]=Ct+d+1,V[E++]=Ct+d;if(G)for(Mt=I*C-C,Ct=I*C*T-C,d=1;d<C-2;d++)V[E++]=Mt+d+1,V[E++]=Mt+d,V[E++]=Ct+d,V[E++]=Mt+d+1,V[E++]=Ct+d,V[E++]=Ct+d+1}if(M){for(d=1;d<I-2;d++)Ct=C*I+C*d,Mt=C*d,V[E++]=Ct,V[E++]=Mt+C,V[E++]=Mt,V[E++]=Ct,V[E++]=Ct+C,V[E++]=Mt+C;for(d=1;d<I-2;d++)Ct=C*I+C*(d+1)-1,Mt=C*(d+1)-1,V[E++]=Mt+C,V[E++]=Ct,V[E++]=Mt,V[E++]=Mt+C,V[E++]=Ct+C,V[E++]=Ct}let zt=new we;a.position&&(zt.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:U}));let kt=0,Jt=0,Wt=0,Ft=0,ee=Q/2,ce,je=ot.fromCartesian3(e),Oe=ot.fromCartesian3(i);if(a.st||a.normal||a.tangent||a.bitangent){for(d=0;d<Q;d++){ce=k[d]?Oe:je;let Me=l.fromArray(U,d*3,Ndt),Ue=ce.geodeticSurfaceNormal(Me,bdt);if(y[d]&&l.negate(Ue,Ue),a.st){let Ce=nt.negate(Ue,Sdt);H[kt++]=Math.atan2(Ce.y,Ce.x)/L.TWO_PI+.5,H[kt++]=Math.asin(Ue.z)/Math.PI+.5}if(a.normal&&(D[Jt++]=Ue.x,D[Jt++]=Ue.y,D[Jt++]=Ue.z),a.tangent||a.bitangent){let Ce=Fdt,be=0,ni;if(k[d]&&(be=ee),!b&&d>=be&&d<be+C*2?ni=l.UNIT_X:ni=l.UNIT_Z,l.cross(ni,Ue,Ce),l.normalize(Ce,Ce),a.tangent&&(w[Wt++]=Ce.x,w[Wt++]=Ce.y,w[Wt++]=Ce.z),a.bitangent){let ze=l.cross(Ue,Ce,Ydt);l.normalize(ze,ze),x[Ft++]=ze.x,x[Ft++]=ze.y,x[Ft++]=ze.z}}}a.st&&(zt.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:H})),a.normal&&(zt.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:D})),a.tangent&&(zt.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:w})),a.bitangent&&(zt.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:x}))}if(m(t._offsetAttribute)){let Me=U.length,Ue=t._offsetAttribute===Pe.NONE?0:1,Ce=new Uint8Array(Me/3).fill(Ue);zt.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:Ce})}return new se({attributes:zt,indices:V,primitiveType:ne.TRIANGLES,boundingSphere:Nt.fromEllipsoid(je),offsetAttribute:t._offsetAttribute})};Vh.getUnitEllipsoid=function(){return m(EV)||(EV=Vh.createGeometry(new Vh({radii:new l(1,1,1),vertexFormat:Ot.POSITION_ONLY}))),EV};Nr=Vh});var _V={};He(_V,{default:()=>Gdt});function Vdt(t,e){return m(e)&&(t=Nr.unpack(t,e)),Nr.createGeometry(t)}var Gdt,RV=O(()=>{mt();sg();Gdt=Vdt});function Mf(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.radii,Bdt),i=Z(t.innerRadii,e),n=Z(t.minimumClock,0),s=Z(t.maximumClock,L.TWO_PI),o=Z(t.minimumCone,0),r=Z(t.maximumCone,L.PI),a=Math.round(Z(t.stackPartitions,10)),h=Math.round(Z(t.slicePartitions,8)),A=Math.round(Z(t.subdivisions,128));if(a<1)throw new Y("options.stackPartitions cannot be less than 1");if(h<0)throw new Y("options.slicePartitions cannot be less than 0");if(A<0)throw new Y("options.subdivisions must be greater than or equal to zero.");if(m(t.offsetAttribute)&&t.offsetAttribute===Pe.TOP)throw new Y("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");this._radii=l.clone(e),this._innerRadii=l.clone(i),this._minimumClock=n,this._maximumClock=s,this._minimumCone=o,this._maximumCone=r,this._stackPartitions=a,this._slicePartitions=h,this._subdivisions=A,this._offsetAttribute=t.offsetAttribute,this._workerName="createEllipsoidOutlineGeometry"}var Bdt,og,rg,Z5,I5,Gh,ja,ZV=O(()=>{_i();Ht();oi();bt();mt();Vt();Ve();yi();ji();En();go();Di();_e();Xi();Bdt=new l(1,1,1),og=Math.cos,rg=Math.sin;Mf.packedLength=2*l.packedLength+8;Mf.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),l.pack(t._radii,e,i),i+=l.packedLength,l.pack(t._innerRadii,e,i),i+=l.packedLength,e[i++]=t._minimumClock,e[i++]=t._maximumClock,e[i++]=t._minimumCone,e[i++]=t._maximumCone,e[i++]=t._stackPartitions,e[i++]=t._slicePartitions,e[i++]=t._subdivisions,e[i]=Z(t._offsetAttribute,-1),e};Z5=new l,I5=new l,Gh={radii:Z5,innerRadii:I5,minimumClock:void 0,maximumClock:void 0,minimumCone:void 0,maximumCone:void 0,stackPartitions:void 0,slicePartitions:void 0,subdivisions:void 0,offsetAttribute:void 0};Mf.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n=l.unpack(t,e,Z5);e+=l.packedLength;let s=l.unpack(t,e,I5);e+=l.packedLength;let o=t[e++],r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++],E=t[e];return m(i)?(i._radii=l.clone(n,i._radii),i._innerRadii=l.clone(s,i._innerRadii),i._minimumClock=o,i._maximumClock=r,i._minimumCone=a,i._maximumCone=h,i._stackPartitions=A,i._slicePartitions=d,i._subdivisions=f,i._offsetAttribute=E===-1?void 0:E,i):(Gh.minimumClock=o,Gh.maximumClock=r,Gh.minimumCone=a,Gh.maximumCone=h,Gh.stackPartitions=A,Gh.slicePartitions=d,Gh.subdivisions=f,Gh.offsetAttribute=E===-1?void 0:E,new Mf(Gh))};Mf.createGeometry=function(t){let e=t._radii;if(e.x<=0||e.y<=0||e.z<=0)return;let i=t._innerRadii;if(i.x<=0||i.y<=0||i.z<=0)return;let n=t._minimumClock,s=t._maximumClock,o=t._minimumCone,r=t._maximumCone,a=t._subdivisions,h=ot.fromCartesian3(e),A=t._slicePartitions+1,d=t._stackPartitions+1;A=Math.round(A*Math.abs(s-n)/L.TWO_PI),d=Math.round(d*Math.abs(r-o)/L.PI),A<2&&(A=2),d<2&&(d=2);let f=0,E=1,_=i.x!==e.x||i.y!==e.y||i.z!==e.z,R=!1,I=!1;_&&(E=2,o>0&&(R=!0,f+=A),r<Math.PI&&(I=!0,f+=A));let C=a*E*(d+A),N=new Float64Array(C*3),T=2*(C+f-(A+d)*E),F=te.createTypedArray(C,T),b,G,M,Q,U=0,k=new Array(d),y=new Array(d);for(b=0;b<d;b++)Q=o+b*(r-o)/(d-1),k[b]=rg(Q),y[b]=og(Q);let c=new Array(a),g=new Array(a);for(b=0;b<a;b++)M=n+b*(s-n)/(a-1),c[b]=rg(M),g[b]=og(M);for(b=0;b<d;b++)for(G=0;G<a;G++)N[U++]=e.x*k[b]*g[G],N[U++]=e.y*k[b]*c[G],N[U++]=e.z*y[b];if(_)for(b=0;b<d;b++)for(G=0;G<a;G++)N[U++]=i.x*k[b]*g[G],N[U++]=i.y*k[b]*c[G],N[U++]=i.z*y[b];for(k.length=a,y.length=a,b=0;b<a;b++)Q=o+b*(r-o)/(a-1),k[b]=rg(Q),y[b]=og(Q);for(c.length=A,g.length=A,b=0;b<A;b++)M=n+b*(s-n)/(A-1),c[b]=rg(M),g[b]=og(M);for(b=0;b<a;b++)for(G=0;G<A;G++)N[U++]=e.x*k[b]*g[G],N[U++]=e.y*k[b]*c[G],N[U++]=e.z*y[b];if(_)for(b=0;b<a;b++)for(G=0;G<A;G++)N[U++]=i.x*k[b]*g[G],N[U++]=i.y*k[b]*c[G],N[U++]=i.z*y[b];for(U=0,b=0;b<d*E;b++){let w=b*a;for(G=0;G<a-1;G++)F[U++]=w+G,F[U++]=w+G+1}let V=d*a*E;for(b=0;b<A;b++)for(G=0;G<a-1;G++)F[U++]=V+b+G*A,F[U++]=V+b+(G+1)*A;if(_)for(V=d*a*E+A*a,b=0;b<A;b++)for(G=0;G<a-1;G++)F[U++]=V+b+G*A,F[U++]=V+b+(G+1)*A;if(_){let w=d*a*E,x=w+a*A;if(R)for(b=0;b<A;b++)F[U++]=w+b,F[U++]=x+b;if(I)for(w+=a*A-A,x+=a*A-A,b=0;b<A;b++)F[U++]=w+b,F[U++]=x+b}let D=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:N})});if(m(t._offsetAttribute)){let w=N.length,x=t._offsetAttribute===Pe.NONE?0:1,H=new Uint8Array(w/3).fill(x);D.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:H})}return new se({attributes:D,indices:F,primitiveType:ne.LINES,boundingSphere:Nt.fromEllipsoid(h),offsetAttribute:t._offsetAttribute})};ja=Mf});var IV={};He(IV,{default:()=>Ddt});function Wdt(t,e){return m(t.buffer,e)&&(t=ja.unpack(t,e)),ja.createGeometry(t)}var Ddt,pV=O(()=>{mt();ZV();Ddt=Wdt});function GA(t){t=Z(t,Z.EMPTY_OBJECT),this.left=t.left,this._left=void 0,this.right=t.right,this._right=void 0,this.top=t.top,this._top=void 0,this.bottom=t.bottom,this._bottom=void 0,this.near=Z(t.near,1),this._near=this.near,this.far=Z(t.far,5e8),this._far=this.far,this._cullingVolume=new XZ,this._perspectiveMatrix=new at,this._infinitePerspective=new at}function uV(t){if(!m(t.right)||!m(t.left)||!m(t.top)||!m(t.bottom)||!m(t.near)||!m(t.far))throw new Y("right, left, top, bottom, near, or far parameters are not set.");let e=t.top,i=t.bottom,n=t.right,s=t.left,o=t.near,r=t.far;if(e!==t._top||i!==t._bottom||s!==t._left||n!==t._right||o!==t._near||r!==t._far){if(t.near<=0||t.near>t.far)throw new Y("near must be greater than zero and less than far.");t._left=s,t._right=n,t._top=e,t._bottom=i,t._near=o,t._far=r,t._perspectiveMatrix=at.computePerspectiveOffCenter(s,n,i,e,o,r,t._perspectiveMatrix),t._infinitePerspective=at.computeInfinitePerspectiveOffCenter(s,n,i,e,o,t._infinitePerspective)}}var Mdt,Udt,Qdt,kdt,p5,u5=O(()=>{Ht();Vs();ZT();bt();mt();Vt();_e();Fi();Object.defineProperties(GA.prototype,{projectionMatrix:{get:function(){return uV(this),this._perspectiveMatrix}},infiniteProjectionMatrix:{get:function(){return uV(this),this._infinitePerspective}}});Mdt=new l,Udt=new l,Qdt=new l,kdt=new l;GA.prototype.computeCullingVolume=function(t,e,i){if(!m(t))throw new Y("position is required.");if(!m(e))throw new Y("direction is required.");if(!m(i))throw new Y("up is required.");let n=this._cullingVolume.planes,s=this.top,o=this.bottom,r=this.right,a=this.left,h=this.near,A=this.far,d=l.cross(e,i,Mdt),f=Udt;l.multiplyByScalar(e,h,f),l.add(t,f,f);let E=Qdt;l.multiplyByScalar(e,A,E),l.add(t,E,E);let _=kdt;l.multiplyByScalar(d,a,_),l.add(f,_,_),l.subtract(_,t,_),l.normalize(_,_),l.cross(_,i,_),l.normalize(_,_);let R=n[0];return m(R)||(R=n[0]=new ie),R.x=_.x,R.y=_.y,R.z=_.z,R.w=-l.dot(_,t),l.multiplyByScalar(d,r,_),l.add(f,_,_),l.subtract(_,t,_),l.cross(i,_,_),l.normalize(_,_),R=n[1],m(R)||(R=n[1]=new ie),R.x=_.x,R.y=_.y,R.z=_.z,R.w=-l.dot(_,t),l.multiplyByScalar(i,o,_),l.add(f,_,_),l.subtract(_,t,_),l.cross(d,_,_),l.normalize(_,_),R=n[2],m(R)||(R=n[2]=new ie),R.x=_.x,R.y=_.y,R.z=_.z,R.w=-l.dot(_,t),l.multiplyByScalar(i,s,_),l.add(f,_,_),l.subtract(_,t,_),l.cross(_,d,_),l.normalize(_,_),R=n[3],m(R)||(R=n[3]=new ie),R.x=_.x,R.y=_.y,R.z=_.z,R.w=-l.dot(_,t),R=n[4],m(R)||(R=n[4]=new ie),R.x=e.x,R.y=e.y,R.z=e.z,R.w=-l.dot(e,f),l.negate(e,_),R=n[5],m(R)||(R=n[5]=new ie),R.x=_.x,R.y=_.y,R.z=_.z,R.w=-l.dot(_,E),this._cullingVolume};GA.prototype.getPixelDimensions=function(t,e,i,n,s){if(uV(this),!m(t)||!m(e))throw new Y("Both drawingBufferWidth and drawingBufferHeight are required.");if(t<=0)throw new Y("drawingBufferWidth must be greater than zero.");if(e<=0)throw new Y("drawingBufferHeight must be greater than zero.");if(!m(i))throw new Y("distance is required.");if(!m(n))throw new Y("pixelRatio is required");if(n<=0)throw new Y("pixelRatio must be greater than zero.");if(!m(s))throw new Y("A result object is required.");let o=1/this.near,r=this.top*o,a=2*n*i*r/e;r=this.right*o;let h=2*n*i*r/t;return s.x=h,s.y=a,s};GA.prototype.clone=function(t){return m(t)||(t=new GA),t.right=this.right,t.left=this.left,t.top=this.top,t.bottom=this.bottom,t.near=this.near,t.far=this.far,t._left=void 0,t._right=void 0,t._top=void 0,t._bottom=void 0,t._near=void 0,t._far=void 0,t};GA.prototype.equals=function(t){return m(t)&&t instanceof GA&&this.right===t.right&&this.left===t.left&&this.top===t.top&&this.bottom===t.bottom&&this.near===t.near&&this.far===t.far};GA.prototype.equalsEpsilon=function(t,e,i){return t===this||m(t)&&t instanceof GA&&L.equalsEpsilon(this.right,t.right,e,i)&&L.equalsEpsilon(this.left,t.left,e,i)&&L.equalsEpsilon(this.top,t.top,e,i)&&L.equalsEpsilon(this.bottom,t.bottom,e,i)&&L.equalsEpsilon(this.near,t.near,e,i)&&L.equalsEpsilon(this.far,t.far,e,i)};p5=GA});function Ar(t){t=Z(t,Z.EMPTY_OBJECT),this._offCenterFrustum=new p5,this.fov=t.fov,this._fov=void 0,this._fovy=void 0,this._sseDenominator=void 0,this.aspectRatio=t.aspectRatio,this._aspectRatio=void 0,this.near=Z(t.near,1),this._near=this.near,this.far=Z(t.far,5e8),this._far=this.far,this.xOffset=Z(t.xOffset,0),this._xOffset=this.xOffset,this.yOffset=Z(t.yOffset,0),this._yOffset=this.yOffset}function Ha(t){if(!m(t.fov)||!m(t.aspectRatio)||!m(t.near)||!m(t.far))throw new Y("fov, aspectRatio, near, or far parameters are not set.");let e=t._offCenterFrustum;if(t.fov!==t._fov||t.aspectRatio!==t._aspectRatio||t.near!==t._near||t.far!==t._far||t.xOffset!==t._xOffset||t.yOffset!==t._yOffset){if(t.fov<0||t.fov>=Math.PI)throw new Y("fov must be in the range [0, PI).");if(t.aspectRatio<0)throw new Y("aspectRatio must be positive.");if(t.near<0||t.near>t.far)throw new Y("near must be greater than zero and less than far.");t._aspectRatio=t.aspectRatio,t._fov=t.fov,t._fovy=t.aspectRatio<=1?t.fov:Math.atan(Math.tan(t.fov*.5)/t.aspectRatio)*2,t._near=t.near,t._far=t.far,t._sseDenominator=2*Math.tan(.5*t._fovy),t._xOffset=t.xOffset,t._yOffset=t.yOffset,e.top=t.near*Math.tan(.5*t._fovy),e.bottom=-e.top,e.right=t.aspectRatio*e.top,e.left=-e.right,e.near=t.near,e.far=t.far,e.right+=t.xOffset,e.left+=t.xOffset,e.top+=t.yOffset,e.bottom+=t.yOffset}}var bo,CV=O(()=>{ae();bt();mt();Vt();_e();u5();Ar.packedLength=6;Ar.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.fov,e[i++]=t.aspectRatio,e[i++]=t.near,e[i++]=t.far,e[i++]=t.xOffset,e[i]=t.yOffset,e};Ar.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Ar),i.fov=t[e++],i.aspectRatio=t[e++],i.near=t[e++],i.far=t[e++],i.xOffset=t[e++],i.yOffset=t[e],i};Object.defineProperties(Ar.prototype,{projectionMatrix:{get:function(){return Ha(this),this._offCenterFrustum.projectionMatrix}},infiniteProjectionMatrix:{get:function(){return Ha(this),this._offCenterFrustum.infiniteProjectionMatrix}},fovy:{get:function(){return Ha(this),this._fovy}},sseDenominator:{get:function(){return Ha(this),this._sseDenominator}},offCenterFrustum:{get:function(){return Ha(this),this._offCenterFrustum}}});Ar.prototype.computeCullingVolume=function(t,e,i){return Ha(this),this._offCenterFrustum.computeCullingVolume(t,e,i)};Ar.prototype.getPixelDimensions=function(t,e,i,n,s){return Ha(this),this._offCenterFrustum.getPixelDimensions(t,e,i,n,s)};Ar.prototype.clone=function(t){return m(t)||(t=new Ar),t.aspectRatio=this.aspectRatio,t.fov=this.fov,t.near=this.near,t.far=this.far,t._aspectRatio=void 0,t._fov=void 0,t._near=void 0,t._far=void 0,this._offCenterFrustum.clone(t._offCenterFrustum),t};Ar.prototype.equals=function(t){return!m(t)||!(t instanceof Ar)?!1:(Ha(this),Ha(t),this.fov===t.fov&&this.aspectRatio===t.aspectRatio&&this._offCenterFrustum.equals(t._offCenterFrustum))};Ar.prototype.equalsEpsilon=function(t,e,i){return!m(t)||!(t instanceof Ar)?!1:(Ha(this),Ha(t),L.equalsEpsilon(this.fov,t.fov,e,i)&&L.equalsEpsilon(this.aspectRatio,t.aspectRatio,e,i)&&this._offCenterFrustum.equalsEpsilon(t._offCenterFrustum,e,i))};bo=Ar});function Rd(t){p.typeOf.object("options",t),p.typeOf.object("options.frustum",t.frustum),p.typeOf.object("options.origin",t.origin),p.typeOf.object("options.orientation",t.orientation);let e=t.frustum,i=t.orientation,n=t.origin,s=Z(t.vertexFormat,Ot.DEFAULT),o=Z(t._drawNearPlane,!0),r,a;e instanceof bo?(r=ag,a=bo.packedLength):e instanceof js&&(r=Ldt,a=js.packedLength),this._frustumType=r,this._frustum=e.clone(),this._origin=l.clone(n),this._orientation=Ae.clone(i),this._drawNearPlane=o,this._vertexFormat=s,this._workerName="createFrustumGeometry",this.packedLength=2+a+l.packedLength+Ae.packedLength+Ot.packedLength}function Uf(t,e,i,n,s,o,r,a){let h=t/3*2;for(let A=0;A<4;++A)m(e)&&(e[t]=o.x,e[t+1]=o.y,e[t+2]=o.z),m(i)&&(i[t]=r.x,i[t+1]=r.y,i[t+2]=r.z),m(n)&&(n[t]=a.x,n[t+1]=a.y,n[t+2]=a.z),t+=3;s[h]=0,s[h+1]=0,s[h+2]=1,s[h+3]=0,s[h+4]=1,s[h+5]=1,s[h+6]=0,s[h+7]=1}var ag,Ldt,ydt,wdt,xdt,Pdt,Jdt,jdt,Hdt,gV,C5,g5,T5,vdt,zdt,Kdt,Pc,TR,N5,NR,TV=O(()=>{_i();Ht();Vs();ae();oi();bt();mt();yi();ji();En();dn();Fi();$Z();CV();Xi();$s();Ls();ag=0,Ldt=1;Rd.pack=function(t,e,i){p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0);let n=t._frustumType,s=t._frustum;return e[i++]=n,n===ag?(bo.pack(s,e,i),i+=bo.packedLength):(js.pack(s,e,i),i+=js.packedLength),l.pack(t._origin,e,i),i+=l.packedLength,Ae.pack(t._orientation,e,i),i+=Ae.packedLength,Ot.pack(t._vertexFormat,e,i),i+=Ot.packedLength,e[i]=t._drawNearPlane?1:0,e};ydt=new bo,wdt=new js,xdt=new Ae,Pdt=new l,Jdt=new Ot;Rd.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=t[e++],s;n===ag?(s=bo.unpack(t,e,ydt),e+=bo.packedLength):(s=js.unpack(t,e,wdt),e+=js.packedLength);let o=l.unpack(t,e,Pdt);e+=l.packedLength;let r=Ae.unpack(t,e,xdt);e+=Ae.packedLength;let a=Ot.unpack(t,e,Jdt);e+=Ot.packedLength;let h=t[e]===1;if(!m(i))return new Rd({frustum:s,origin:o,orientation:r,vertexFormat:a,_drawNearPlane:h});let A=n===i._frustumType?i._frustum:void 0;return i._frustum=s.clone(A),i._frustumType=n,i._origin=l.clone(o,i._origin),i._orientation=Ae.clone(r,i._orientation),i._vertexFormat=Ot.clone(a,i._vertexFormat),i._drawNearPlane=h,i};jdt=new lt,Hdt=new at,gV=new at,C5=new l,g5=new l,T5=new l,vdt=new l,zdt=new l,Kdt=new l,Pc=new Array(3),TR=new Array(4);TR[0]=new ie(-1,-1,1,1);TR[1]=new ie(1,-1,1,1);TR[2]=new ie(1,1,1,1);TR[3]=new ie(-1,1,1,1);N5=new Array(4);for(let t=0;t<4;++t)N5[t]=new ie;Rd._computeNearFarPlanes=function(t,e,i,n,s,o,r,a){let h=lt.fromQuaternion(e,jdt),A=Z(o,C5),d=Z(r,g5),f=Z(a,T5);A=lt.getColumn(h,0,A),d=lt.getColumn(h,1,d),f=lt.getColumn(h,2,f),l.normalize(A,A),l.normalize(d,d),l.normalize(f,f),l.negate(A,A);let E=at.computeView(t,f,d,A,Hdt),_,R,I=n.projectionMatrix;if(i===ag){let C=at.multiply(I,E,gV);R=at.inverse(C,gV)}else _=at.inverseTransformation(E,gV);m(R)?(Pc[0]=n.near,Pc[1]=n.far):(Pc[0]=0,Pc[1]=n.near,Pc[2]=n.far);for(let C=0;C<2;++C)for(let N=0;N<4;++N){let T=ie.clone(TR[N],N5[N]);if(m(R)){T=at.multiplyByVector(R,T,T);let F=1/T.w;l.multiplyByScalar(T,F,T),l.subtract(T,t,T),l.normalize(T,T);let b=l.dot(f,T);l.multiplyByScalar(T,Pc[C]/b,T),l.add(T,t,T)}else{let F=n.offCenterFrustum;m(F)&&(n=F);let b=Pc[C],G=Pc[C+1];T.x=(T.x*(n.right-n.left)+n.left+n.right)*.5,T.y=(T.y*(n.top-n.bottom)+n.bottom+n.top)*.5,T.z=(T.z*(b-G)-b-G)*.5,T.w=1,at.multiplyByVector(_,T,T)}s[12*C+N*3]=T.x,s[12*C+N*3+1]=T.y,s[12*C+N*3+2]=T.z}};Rd.createGeometry=function(t){let e=t._frustumType,i=t._frustum,n=t._origin,s=t._orientation,o=t._drawNearPlane,r=t._vertexFormat,a=o?6:5,h=new Float64Array(3*4*6);Rd._computeNearFarPlanes(n,s,e,i,h);let A=3*4*2;h[A]=h[3*4],h[A+1]=h[3*4+1],h[A+2]=h[3*4+2],h[A+3]=h[0],h[A+4]=h[1],h[A+5]=h[2],h[A+6]=h[3*3],h[A+7]=h[3*3+1],h[A+8]=h[3*3+2],h[A+9]=h[3*7],h[A+10]=h[3*7+1],h[A+11]=h[3*7+2],A+=3*4,h[A]=h[3*5],h[A+1]=h[3*5+1],h[A+2]=h[3*5+2],h[A+3]=h[3],h[A+4]=h[4],h[A+5]=h[5],h[A+6]=h[0],h[A+7]=h[1],h[A+8]=h[2],h[A+9]=h[3*4],h[A+10]=h[3*4+1],h[A+11]=h[3*4+2],A+=3*4,h[A]=h[3],h[A+1]=h[4],h[A+2]=h[5],h[A+3]=h[3*5],h[A+4]=h[3*5+1],h[A+5]=h[3*5+2],h[A+6]=h[3*6],h[A+7]=h[3*6+1],h[A+8]=h[3*6+2],h[A+9]=h[3*2],h[A+10]=h[3*2+1],h[A+11]=h[3*2+2],A+=3*4,h[A]=h[3*2],h[A+1]=h[3*2+1],h[A+2]=h[3*2+2],h[A+3]=h[3*6],h[A+4]=h[3*6+1],h[A+5]=h[3*6+2],h[A+6]=h[3*7],h[A+7]=h[3*7+1],h[A+8]=h[3*7+2],h[A+9]=h[3*3],h[A+10]=h[3*3+1],h[A+11]=h[3*3+2],o||(h=h.subarray(3*4));let d=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:h})});if(m(r.normal)||m(r.tangent)||m(r.bitangent)||m(r.st)){let E=m(r.normal)?new Float32Array(12*a):void 0,_=m(r.tangent)?new Float32Array(3*4*a):void 0,R=m(r.bitangent)?new Float32Array(3*4*a):void 0,I=m(r.st)?new Float32Array(2*4*a):void 0,C=C5,N=g5,T=T5,F=l.negate(C,vdt),b=l.negate(N,zdt),G=l.negate(T,Kdt);A=0,o&&(Uf(A,E,_,R,I,G,C,N),A+=3*4),Uf(A,E,_,R,I,T,F,N),A+=3*4,Uf(A,E,_,R,I,F,G,N),A+=3*4,Uf(A,E,_,R,I,b,G,F),A+=3*4,Uf(A,E,_,R,I,C,T,N),A+=3*4,Uf(A,E,_,R,I,N,T,F),m(E)&&(d.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:E})),m(_)&&(d.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_})),m(R)&&(d.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:R})),m(I)&&(d.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:I}))}let f=new Uint16Array(6*a);for(let E=0;E<a;++E){let _=E*6,R=E*4;f[_]=R,f[_+1]=R+1,f[_+2]=R+2,f[_+3]=R,f[_+4]=R+2,f[_+5]=R+3}return new se({attributes:d,indices:f,primitiveType:ne.TRIANGLES,boundingSphere:Nt.fromVertices(h)})};NR=Rd});var NV={};He(NV,{default:()=>qdt});function Xdt(t,e){return m(e)&&(t=NR.unpack(t,e)),NR.createGeometry(t)}var qdt,bV=O(()=>{mt();TV();qdt=Xdt});function bR(t){p.typeOf.object("options",t),p.typeOf.object("options.frustum",t.frustum),p.typeOf.object("options.origin",t.origin),p.typeOf.object("options.orientation",t.orientation);let e=t.frustum,i=t.orientation,n=t.origin,s=Z(t._drawNearPlane,!0),o,r;e instanceof bo?(o=FV,r=bo.packedLength):e instanceof js&&(o=$dt,r=js.packedLength),this._frustumType=o,this._frustum=e.clone(),this._origin=l.clone(n),this._orientation=Ae.clone(i),this._drawNearPlane=s,this._workerName="createFrustumOutlineGeometry",this.packedLength=2+r+l.packedLength+Ae.packedLength}var FV,$dt,tmt,emt,imt,nmt,YV,b5=O(()=>{_i();Ht();ae();oi();bt();mt();TV();yi();ji();En();$Z();CV();Xi();$s();FV=0,$dt=1;bR.pack=function(t,e,i){p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0);let n=t._frustumType,s=t._frustum;return e[i++]=n,n===FV?(bo.pack(s,e,i),i+=bo.packedLength):(js.pack(s,e,i),i+=js.packedLength),l.pack(t._origin,e,i),i+=l.packedLength,Ae.pack(t._orientation,e,i),i+=Ae.packedLength,e[i]=t._drawNearPlane?1:0,e};tmt=new bo,emt=new js,imt=new Ae,nmt=new l;bR.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=t[e++],s;n===FV?(s=bo.unpack(t,e,tmt),e+=bo.packedLength):(s=js.unpack(t,e,emt),e+=js.packedLength);let o=l.unpack(t,e,nmt);e+=l.packedLength;let r=Ae.unpack(t,e,imt);e+=Ae.packedLength;let a=t[e]===1;if(!m(i))return new bR({frustum:s,origin:o,orientation:r,_drawNearPlane:a});let h=n===i._frustumType?i._frustum:void 0;return i._frustum=s.clone(h),i._frustumType=n,i._origin=l.clone(o,i._origin),i._orientation=Ae.clone(r,i._orientation),i._drawNearPlane=a,i};bR.createGeometry=function(t){let e=t._frustumType,i=t._frustum,n=t._origin,s=t._orientation,o=t._drawNearPlane,r=new Float64Array(3*4*2);NR._computeNearFarPlanes(n,s,e,i,r);let a=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:r})}),h,A,d=o?2:1,f=new Uint16Array(8*(d+1)),E=o?0:1;for(;E<2;++E)h=o?E*8:0,A=E*4,f[h]=A,f[h+1]=A+1,f[h+2]=A+1,f[h+3]=A+2,f[h+4]=A+2,f[h+5]=A+3,f[h+6]=A+3,f[h+7]=A;for(E=0;E<2;++E)h=(d+E)*8,A=E*4,f[h]=A,f[h+1]=A+4,f[h+2]=A+1,f[h+3]=A+5,f[h+4]=A+2,f[h+5]=A+6,f[h+6]=A+3,f[h+7]=A+7;return new se({attributes:a,indices:f,primitiveType:ne.LINES,boundingSphere:Nt.fromVertices(r)})};YV=bR});var SV={};He(SV,{default:()=>omt});function smt(t,e){return m(e)&&(t=YV.unpack(t,e)),YV.createGeometry(t)}var omt,OV=O(()=>{mt();b5();omt=smt});var VV={};He(VV,{default:()=>amt});function rmt(t,e){return Do.initialize().then(function(){return m(e)&&(t=KE.unpack(t,e)),KE.createGeometry(t)})}var amt,GV=O(()=>{JE();mt();VN();amt=rmt});function Qf(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.vertexFormat,Ot.DEFAULT);this._vertexFormat=e,this._workerName="createPlaneGeometry"}var F5,Amt,Ag,hg,BV,Y5=O(()=>{_i();Ht();ae();oi();bt();mt();yi();ji();En();Xi();Ls();Qf.packedLength=Ot.packedLength;Qf.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),Ot.pack(t._vertexFormat,e,i),e};F5=new Ot,Amt={vertexFormat:F5};Qf.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=Ot.unpack(t,e,F5);return m(i)?(i._vertexFormat=Ot.clone(n,i._vertexFormat),i):new Qf(Amt)};Ag=new l(-.5,-.5,0),hg=new l(.5,.5,0);Qf.createGeometry=function(t){let e=t._vertexFormat,i=new we,n,s;if(e.position){if(s=new Float64Array(4*3),s[0]=Ag.x,s[1]=Ag.y,s[2]=0,s[3]=hg.x,s[4]=Ag.y,s[5]=0,s[6]=hg.x,s[7]=hg.y,s[8]=0,s[9]=Ag.x,s[10]=hg.y,s[11]=0,i.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:s}),e.normal){let o=new Float32Array(12);o[0]=0,o[1]=0,o[2]=1,o[3]=0,o[4]=0,o[5]=1,o[6]=0,o[7]=0,o[8]=1,o[9]=0,o[10]=0,o[11]=1,i.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:o})}if(e.st){let o=new Float32Array(8);o[0]=0,o[1]=0,o[2]=1,o[3]=0,o[4]=1,o[5]=1,o[6]=0,o[7]=1,i.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:o})}if(e.tangent){let o=new Float32Array(12);o[0]=1,o[1]=0,o[2]=0,o[3]=1,o[4]=0,o[5]=0,o[6]=1,o[7]=0,o[8]=0,o[9]=1,o[10]=0,o[11]=0,i.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:o})}if(e.bitangent){let o=new Float32Array(12);o[0]=0,o[1]=1,o[2]=0,o[3]=0,o[4]=1,o[5]=0,o[6]=0,o[7]=1,o[8]=0,o[9]=0,o[10]=1,o[11]=0,i.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:o})}n=new Uint16Array(2*3),n[0]=0,n[1]=1,n[2]=2,n[3]=0,n[4]=2,n[5]=3}return new se({attributes:i,indices:n,primitiveType:ne.TRIANGLES,boundingSphere:new Nt(l.ZERO,Math.sqrt(2))})};BV=Qf});var WV={};He(WV,{default:()=>cmt});function hmt(t,e){return m(e)&&(t=BV.unpack(t,e)),BV.createGeometry(t)}var cmt,DV=O(()=>{mt();Y5();cmt=hmt});function kf(){this._workerName="createPlaneOutlineGeometry"}var Jc,cg,MV,S5=O(()=>{_i();Ht();ae();oi();mt();yi();ji();En();Xi();kf.packedLength=0;kf.pack=function(t,e){return p.defined("value",t),p.defined("array",e),e};kf.unpack=function(t,e,i){return p.defined("array",t),m(i)?i:new kf};Jc=new l(-.5,-.5,0),cg=new l(.5,.5,0);kf.createGeometry=function(){let t=new we,e=new Uint16Array(4*2),i=new Float64Array(4*3);return i[0]=Jc.x,i[1]=Jc.y,i[2]=Jc.z,i[3]=cg.x,i[4]=Jc.y,i[5]=Jc.z,i[6]=cg.x,i[7]=cg.y,i[8]=Jc.z,i[9]=Jc.x,i[10]=cg.y,i[11]=Jc.z,t.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:i}),e[0]=0,e[1]=1,e[2]=1,e[3]=2,e[4]=2,e[5]=3,e[6]=3,e[7]=0,new se({attributes:t,indices:e,primitiveType:ne.LINES,boundingSphere:new Nt(l.ZERO,Math.sqrt(2))})};MV=kf});var UV={};He(UV,{default:()=>dmt});function lmt(t,e){return m(e)&&(t=MV.unpack(t,e)),MV.createGeometry(t)}var dmt,QV=O(()=>{mt();S5();dmt=lmt});function As(t,e){this.position=t,m(this.position)||(this.position=new nt),this.tangentPlane=e,m(this.tangentPlane)||(this.tangentPlane=As.NORTH_POLE_TANGENT_PLANE)}var Lf,mmt,fmt,Emt,_mt,br,O5=O(()=>{Xe();Ht();ri();ae();mt();Ve();Xm();Ml();_e();OI();Object.defineProperties(As.prototype,{ellipsoid:{get:function(){return this.tangentPlane.ellipsoid}},x:{get:function(){return this.position.x}},y:{get:function(){return this.position.y}},conformalLatitude:{get:function(){let t=nt.magnitude(this.position),e=2*this.ellipsoid.maximumRadius;return this.tangentPlane.plane.normal.z*(L.PI_OVER_TWO-2*Math.atan2(t,e))}},longitude:{get:function(){let t=L.PI_OVER_TWO+Math.atan2(this.y,this.x);return t>Math.PI&&(t-=L.TWO_PI),t}}});Lf=new ut,mmt=new l;As.prototype.getLatitude=function(t){m(t)||(t=ot.WGS84),Lf.latitude=this.conformalLatitude,Lf.longitude=this.longitude,Lf.height=0;let e=this.ellipsoid.cartographicToCartesian(Lf,mmt);return t.cartesianToCartographic(e,Lf),Lf.latitude};fmt=new Wl,Emt=new l,_mt=new l;As.fromCartesian=function(t,e){p.defined("cartesian",t);let i=L.signNotZero(t.z),n=As.NORTH_POLE_TANGENT_PLANE,s=As.SOUTH_POLE;i<0&&(n=As.SOUTH_POLE_TANGENT_PLANE,s=As.NORTH_POLE);let o=fmt;o.origin=n.ellipsoid.scaleToGeocentricSurface(t,o.origin),o.direction=l.subtract(o.origin,s,Emt),l.normalize(o.direction,o.direction);let r=no.rayPlane(o,n.plane,_mt),a=l.subtract(r,s,r),h=l.dot(n.xAxis,a),A=i*l.dot(n.yAxis,a);return m(e)?(e.position=new nt(h,A),e.tangentPlane=n,e):new As(new nt(h,A),n)};As.fromCartesianArray=function(t,e){p.defined("cartesians",t);let i=t.length;m(e)?e.length=i:e=new Array(i);for(let n=0;n<i;n++)e[n]=As.fromCartesian(t[n],e[n]);return e};As.clone=function(t,e){if(m(t))return m(e)?(e.position=t.position,e.tangentPlane=t.tangentPlane,e):new As(t.position,t.tangentPlane)};As.HALF_UNIT_SPHERE=Object.freeze(new ot(.5,.5,.5));As.NORTH_POLE=Object.freeze(new l(0,0,.5));As.SOUTH_POLE=Object.freeze(new l(0,0,-.5));As.NORTH_POLE_TANGENT_PLANE=Object.freeze(new oo(As.NORTH_POLE,As.HALF_UNIT_SPHERE));As.SOUTH_POLE_TANGENT_PLANE=Object.freeze(new oo(As.SOUTH_POLE,As.HALF_UNIT_SPHERE));br=As});function Zmt(t,e,i,n){let o=n.cartesianToCartographic(t,Rmt).height,r=n.cartesianToCartographic(e,V5);r.height=o,n.cartographicToCartesian(r,e);let a=n.cartesianToCartographic(i,V5);a.height=o-100,n.cartographicToCartesian(a,i)}function kV(t){let e=t.vertexFormat,i=t.geometry,n=t.shadowVolume,s=i.attributes.position.values,o=m(i.attributes.st)?i.attributes.st.values:void 0,r=s.length,a=t.wall,h=t.top||a,A=t.bottom||a;if(e.st||e.normal||e.tangent||e.bitangent||n){let d=t.boundingRectangle,f=t.rotationAxis,E=t.projectTo2d,_=t.ellipsoid,R=t.stRotation,I=t.perPositionHeight,C=Nmt;C.x=d.x,C.y=d.y;let N=e.st?new Float32Array(2*(r/3)):void 0,T;e.normal&&(I&&h&&!a?T=i.attributes.normal.values:T=new Float32Array(r));let F=e.tangent?new Float32Array(r):void 0,b=e.bitangent?new Float32Array(r):void 0,G=n?new Float32Array(r):void 0,M=0,Q=0,U=pmt,k=umt,y=Cmt,c=!0,g=Ymt,V=Smt;if(R!==0){let x=Ae.fromAxisAngle(f,R,B5);g=lt.fromQuaternion(x,g),x=Ae.fromAxisAngle(f,-R,B5),V=lt.fromQuaternion(x,V)}else g=lt.clone(lt.IDENTITY,g),V=lt.clone(lt.IDENTITY,V);let D=0,w=0;h&&A&&(D=r/2,w=r/3,r/=2);for(let x=0;x<r;x+=3){let H=l.fromArray(s,x,Fmt);if(e.st&&!m(o)){let j=lt.multiplyByVector(g,H,Imt);j=_.scaleToGeodeticSurface(j,j);let X=E([j],bmt)[0];nt.subtract(X,C,X);let tt=L.clamp(X.x/d.width,0,1),B=L.clamp(X.y/d.height,0,1);A&&(N[M+w]=tt,N[M+1+w]=B),h&&(N[M]=tt,N[M+1]=B),M+=2}if(e.normal||e.tangent||e.bitangent||n){let j=Q+1,X=Q+2;if(a){if(x+3<r){let tt=l.fromArray(s,x+3,gmt);if(c){let B=l.fromArray(s,x+r,Tmt);I&&Zmt(H,tt,B,_),l.subtract(tt,H,tt),l.subtract(B,H,B),U=l.normalize(l.cross(B,tt,U),U),c=!1}l.equalsEpsilon(tt,H,L.EPSILON10)&&(c=!0)}(e.tangent||e.bitangent)&&(y=_.geodeticSurfaceNormal(H,y),e.tangent&&(k=l.normalize(l.cross(y,U,k),k)))}else U=_.geodeticSurfaceNormal(H,U),(e.tangent||e.bitangent)&&(I&&(lg=l.fromArray(T,Q,lg),BA=l.cross(l.UNIT_Z,lg,BA),BA=l.normalize(lt.multiplyByVector(V,BA,BA),BA),e.bitangent&&(yf=l.normalize(l.cross(lg,BA,yf),yf))),k=l.cross(l.UNIT_Z,U,k),k=l.normalize(lt.multiplyByVector(V,k,k),k),e.bitangent&&(y=l.normalize(l.cross(U,k,y),y)));e.normal&&(t.wall?(T[Q+D]=U.x,T[j+D]=U.y,T[X+D]=U.z):A&&(T[Q+D]=-U.x,T[j+D]=-U.y,T[X+D]=-U.z),(h&&!I||a)&&(T[Q]=U.x,T[j]=U.y,T[X]=U.z)),n&&(a&&(U=_.geodeticSurfaceNormal(H,U)),G[Q+D]=-U.x,G[j+D]=-U.y,G[X+D]=-U.z),e.tangent&&(t.wall?(F[Q+D]=k.x,F[j+D]=k.y,F[X+D]=k.z):A&&(F[Q+D]=-k.x,F[j+D]=-k.y,F[X+D]=-k.z),h&&(I?(F[Q]=BA.x,F[j]=BA.y,F[X]=BA.z):(F[Q]=k.x,F[j]=k.y,F[X]=k.z))),e.bitangent&&(A&&(b[Q+D]=y.x,b[j+D]=y.y,b[X+D]=y.z),h&&(I?(b[Q]=yf.x,b[j]=yf.y,b[X]=yf.z):(b[Q]=y.x,b[j]=y.y,b[X]=y.z))),Q+=3}}e.st&&!m(o)&&(i.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:N})),e.normal&&(i.attributes.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:T})),e.tangent&&(i.attributes.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:F})),e.bitangent&&(i.attributes.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:b})),n&&(i.attributes.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:G}))}if(t.extrude&&m(t.offsetAttribute)){let d=s.length/3,f=new Uint8Array(d);if(t.offsetAttribute===Pe.TOP)h&&A||a?f=f.fill(1,0,d/2):h&&(f=f.fill(1));else{let E=t.offsetAttribute===Pe.NONE?0:1;f=f.fill(E)}i.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:f})}return i}function Omt(t,e,i,n,s,o,r,a,h,A){let d={walls:[]},f;if(r||a){let T=ii.createGeometryFromPositions(t,e,i,n,o,h,A),F=T.attributes.position.values,b=T.indices,G,M;if(r&&a){let Q=F.concat(F);G=Q.length/3,M=te.createTypedArray(G,b.length*2),M.set(b);let U=b.length,k=G/2;for(f=0;f<U;f+=3){let y=M[f]+k,c=M[f+1]+k,g=M[f+2]+k;M[f+U]=g,M[f+1+U]=c,M[f+2+U]=y}if(T.attributes.position.values=Q,o&&h.normal){let y=T.attributes.normal.values;T.attributes.normal.values=new Float32Array(Q.length),T.attributes.normal.values.set(y)}if(h.st&&m(i)){let y=T.attributes.st.values;T.attributes.st.values=new Float32Array(G*2),T.attributes.st.values=y.concat(y)}T.indices=M}else if(a){for(G=F.length/3,M=te.createTypedArray(G,b.length),f=0;f<b.length;f+=3)M[f]=b[f+2],M[f+1]=b[f+1],M[f+2]=b[f];T.indices=M}d.topAndBottom=new Ln({geometry:T})}let E=s.outerRing,_=oo.fromPoints(E,t),R=_.projectPointsOntoPlane(E,W5),I=ui.computeWindingOrder2D(R);I===Ms.CLOCKWISE&&(E=E.slice().reverse());let C=ii.computeWallGeometry(E,i,t,n,o,A);d.walls.push(new Ln({geometry:C}));let N=s.holes;for(f=0;f<N.length;f++){let T=N[f];R=_.projectPointsOntoPlane(T,W5),I=ui.computeWindingOrder2D(R),I===Ms.COUNTER_CLOCKWISE&&(T=T.slice().reverse()),C=ii.computeWallGeometry(T,i,t,n,o,A),d.walls.push(new Ln({geometry:C}))}return d}function ea(t){if(p.typeOf.object("options",t),p.typeOf.object("options.polygonHierarchy",t.polygonHierarchy),m(t.perPositionHeight)&&t.perPositionHeight&&m(t.height))throw new Y("Cannot use both options.perPositionHeight and options.height");if(m(t.arcType)&&t.arcType!==ti.GEODESIC&&t.arcType!==ti.RHUMB)throw new Y("Invalid arcType. Valid options are ArcType.GEODESIC and ArcType.RHUMB.");let e=t.polygonHierarchy,i=Z(t.vertexFormat,Ot.DEFAULT),n=Z(t.ellipsoid,ot.WGS84),s=Z(t.granularity,L.RADIANS_PER_DEGREE),o=Z(t.stRotation,0),r=t.textureCoordinates,a=Z(t.perPositionHeight,!1),h=a&&m(t.extrudedHeight),A=Z(t.height,0),d=Z(t.extrudedHeight,A);if(!h){let f=Math.max(A,d);d=Math.min(A,d),A=f}this._vertexFormat=Ot.clone(i),this._ellipsoid=ot.clone(n),this._granularity=s,this._stRotation=o,this._height=A,this._extrudedHeight=d,this._closeTop=Z(t.closeTop,!0),this._closeBottom=Z(t.closeBottom,!0),this._polygonHierarchy=e,this._perPositionHeight=a,this._perPositionHeightExtrude=h,this._shadowVolume=Z(t.shadowVolume,!1),this._workerName="createPolygonGeometry",this._offsetAttribute=t.offsetAttribute,this._arcType=Z(t.arcType,ti.GEODESIC),this._rectangle=void 0,this._textureCoordinateRotationPoints=void 0,this._textureCoordinates=r,this.packedLength=ii.computeHierarchyPackedLength(e,l)+ot.packedLength+Ot.packedLength+(r?ii.computeHierarchyPackedLength(r,nt):1)+12}function D5(t,e,i,n,s,o){let r=t.longitude,a=r>=0?r:r+L.TWO_PI;s.westOverIdl=Math.min(s.westOverIdl,a),s.eastOverIdl=Math.max(s.eastOverIdl,a),o.west=Math.min(o.west,r),o.east=Math.max(o.east,r);let h=t.getLatitude(i),A=h;if(o.south=Math.min(o.south,h),o.north=Math.max(o.north,h),n!==ti.RHUMB){let E=nt.subtract(e.position,t.position,Wmt),_=nt.dot(e.position,E)/nt.dot(E,E);if(_>0&&_<1){let R=nt.add(e.position,nt.multiplyByScalar(E,-_,E),Dmt),I=br.clone(e,Mmt);I.position=R;let C=I.getLatitude(i);o.south=Math.min(o.south,C),o.north=Math.max(o.north,C),Math.abs(h)>Math.abs(C)&&(A=C)}}let d=e.x*t.y-t.x*e.y,f=Math.sign(d);f!==0&&(f*=nt.angleBetween(e.position,t.position)),A>=0&&(s.northAngle+=f),A<=0&&(s.southAngle+=f)}function kmt(t,e,i){return t.height>=L.PI||t.width>=L.PI?br.fromCartesian(e[0],Qmt).tangentPlane:oo.fromPoints(e,i)}function Lmt(t,e,i){return(n,s)=>{if(t.height>=L.PI||t.width>=L.PI){if(t.south<0&&t.north>0){m(s)||(s=[]);for(let r=0;r<n.length;++r){let a=i.cartesianToCartographic(n[r],U5);s[r]=new nt(a.longitude/L.PI,a.latitude/L.PI_OVER_TWO)}return s.length=n.length,s}return br.fromCartesianArray(n,s)}return oo.fromPoints(e,i).projectPointsOntoPlane(n,s)}}function ymt(t,e,i){if(t.height>=L.PI||t.width>=L.PI)return(s,o)=>{if(t.south<0&&t.north>0){let r=i.cartesianToCartographic(s,U5);return m(o)||(o=new nt),o.x=r.longitude/L.PI,o.y=r.latitude/L.PI_OVER_TWO,o}return br.fromCartesian(s,o)};let n=oo.fromPoints(e,i);return(s,o)=>n.projectPointsOntoPlane(s,o)}function wmt(t,e,i,n){return(s,o)=>!n&&(t.height>=L.PI_OVER_TWO||t.width>=2*L.PI_OVER_THREE)?ii.splitPolygonsOnEquator(s,e,i,o):s}function xmt(t,e,i,n){if(e.height>=L.PI||e.width>=L.PI)return mi.fromRectangle(e,void 0,G5);let s=t,o=oo.fromPoints(s,i);return ii.computeBoundingRectangle(o.plane.normal,o.projectPointOntoPlane.bind(o),s,n,G5)}function Pmt(t){let e=-t._stRotation;if(e===0)return[0,0,0,1,1,0];let i=t._ellipsoid,n=t._polygonHierarchy.positions,s=t.rectangle;return se._textureCoordinateRotationPoints(n,e,i,s)}var Rmt,V5,G5,Imt,pmt,umt,Cmt,gmt,Tmt,lg,BA,yf,Nmt,bmt,Fmt,B5,Ymt,Smt,W5,Vmt,Gmt,Bmt,Wmt,Dmt,Mmt,M5,Umt,ta,Qmt,U5,LV,Q5=O(()=>{Bl();Er();_i();Xe();Ht();ri();ae();oi();bt();mt();Vt();Ve();Xm();yi();ji();uA();go();gA();Di();_e();dn();ER();Pa();$s();pn();O5();Ls();fc();Rmt=new ut,V5=new ut;G5=new mi,Imt=new l,pmt=new l,umt=new l,Cmt=new l,gmt=new l,Tmt=new l,lg=new l,BA=new l,yf=new l,Nmt=new nt,bmt=new nt,Fmt=new l,B5=new Ae,Ymt=new lt,Smt=new lt;W5=[];ea.fromPositions=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.positions",t.positions);let e={polygonHierarchy:{positions:t.positions},height:t.height,extrudedHeight:t.extrudedHeight,vertexFormat:t.vertexFormat,stRotation:t.stRotation,ellipsoid:t.ellipsoid,granularity:t.granularity,perPositionHeight:t.perPositionHeight,closeTop:t.closeTop,closeBottom:t.closeBottom,offsetAttribute:t.offsetAttribute,arcType:t.arcType,textureCoordinates:t.textureCoordinates};return new ea(e)};ea.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),i=ii.packPolygonHierarchy(t._polygonHierarchy,e,i,l),ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,Ot.pack(t._vertexFormat,e,i),i+=Ot.packedLength,e[i++]=t._height,e[i++]=t._extrudedHeight,e[i++]=t._granularity,e[i++]=t._stRotation,e[i++]=t._perPositionHeightExtrude?1:0,e[i++]=t._perPositionHeight?1:0,e[i++]=t._closeTop?1:0,e[i++]=t._closeBottom?1:0,e[i++]=t._shadowVolume?1:0,e[i++]=Z(t._offsetAttribute,-1),e[i++]=t._arcType,m(t._textureCoordinates)?i=ii.packPolygonHierarchy(t._textureCoordinates,e,i,nt):e[i++]=-1,e[i++]=t.packedLength,e};Vmt=ot.clone(ot.UNIT_SPHERE),Gmt=new Ot,Bmt={polygonHierarchy:{}};ea.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=ii.unpackPolygonHierarchy(t,e,l);e=n.startingIndex,delete n.startingIndex;let s=ot.unpack(t,e,Vmt);e+=ot.packedLength;let o=Ot.unpack(t,e,Gmt);e+=Ot.packedLength;let r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++]===1,f=t[e++]===1,E=t[e++]===1,_=t[e++]===1,R=t[e++]===1,I=t[e++],C=t[e++],N=t[e]===-1?void 0:ii.unpackPolygonHierarchy(t,e,nt);m(N)?(e=N.startingIndex,delete N.startingIndex):e++;let T=t[e++];return m(i)||(i=new ea(Bmt)),i._polygonHierarchy=n,i._ellipsoid=ot.clone(s,i._ellipsoid),i._vertexFormat=Ot.clone(o,i._vertexFormat),i._height=r,i._extrudedHeight=a,i._granularity=h,i._stRotation=A,i._perPositionHeightExtrude=d,i._perPositionHeight=f,i._closeTop=E,i._closeBottom=_,i._shadowVolume=R,i._offsetAttribute=I===-1?void 0:I,i._arcType=C,i._textureCoordinates=N,i.packedLength=T,i};Wmt=new nt,Dmt=new nt,Mmt=new br;M5=new br,Umt=new br,ta={northAngle:0,southAngle:0,westOverIdl:0,eastOverIdl:0};ea.computeRectangleFromPositions=function(t,e,i,n){if(p.defined("positions",t),m(n)||(n=new Xt),t.length<3)return n;n.west=Number.POSITIVE_INFINITY,n.east=Number.NEGATIVE_INFINITY,n.south=Number.POSITIVE_INFINITY,n.north=Number.NEGATIVE_INFINITY,ta.northAngle=0,ta.southAngle=0,ta.westOverIdl=Number.POSITIVE_INFINITY,ta.eastOverIdl=Number.NEGATIVE_INFINITY;let s=t.length,o=br.fromCartesian(t[0],Umt);for(let r=1;r<s;r++){let a=br.fromCartesian(t[r],M5);D5(a,o,e,i,ta,n),o=br.clone(a,o)}return D5(br.fromCartesian(t[0],M5),o,e,i,ta,n),n.east-n.west>ta.eastOverIdl-ta.westOverIdl&&(n.west=ta.westOverIdl,n.east=ta.eastOverIdl,n.east>L.PI&&(n.east=n.east-L.TWO_PI),n.west>L.PI&&(n.west=n.west-L.TWO_PI)),L.equalsEpsilon(Math.abs(ta.northAngle),L.TWO_PI,L.EPSILON10)&&(n.north=L.PI_OVER_TWO,n.east=L.PI,n.west=-L.PI),L.equalsEpsilon(Math.abs(ta.southAngle),L.TWO_PI,L.EPSILON10)&&(n.south=-L.PI_OVER_TWO,n.east=L.PI,n.west=-L.PI),n};Qmt=new br;U5=new ut;ea.createGeometry=function(t){let e=t._vertexFormat,i=t._ellipsoid,n=t._granularity,s=t._stRotation,o=t._polygonHierarchy,r=t._perPositionHeight,a=t._closeTop,h=t._closeBottom,A=t._arcType,d=t._textureCoordinates,f=m(d),E=o.positions;if(E.length<3)return;let _=t.rectangle,R=ii.polygonsFromHierarchy(o,f,Lmt(_,E,i),!r,i,wmt(_,i,A,r)),I=R.hierarchy,C=R.polygons,N=function(D){return D},T=f?ii.polygonsFromHierarchy(d,!0,N,!1,i).polygons:void 0;if(I.length===0)return;let F=I[0].outerRing,b=xmt(F,_,i,s),G=[],M=t._height,Q=t._extrudedHeight,U=t._perPositionHeightExtrude||!L.equalsEpsilon(M,Q,0,L.EPSILON2),k={perPositionHeight:r,vertexFormat:e,geometry:void 0,rotationAxis:kmt(_,F,i).plane.normal,projectTo2d:ymt(_,F,i),boundingRectangle:b,ellipsoid:i,stRotation:s,textureCoordinates:void 0,bottom:!1,top:!0,wall:!1,extrude:!1,arcType:A},y;if(U)for(k.extrude=!0,k.top=a,k.bottom=h,k.shadowVolume=t._shadowVolume,k.offsetAttribute=t._offsetAttribute,y=0;y<C.length;y++){let D=Omt(i,C[y],f?T[y]:void 0,n,I[y],r,a,h,e,A),w;a&&h?(w=D.topAndBottom,k.geometry=ii.scaleToGeodeticHeightExtruded(w.geometry,M,Q,i,r)):a?(w=D.topAndBottom,w.geometry.attributes.position.values=ui.scaleToGeodeticHeight(w.geometry.attributes.position.values,M,i,!r),k.geometry=w.geometry):h&&(w=D.topAndBottom,w.geometry.attributes.position.values=ui.scaleToGeodeticHeight(w.geometry.attributes.position.values,Q,i,!0),k.geometry=w.geometry),(a||h)&&(k.wall=!1,w.geometry=kV(k),G.push(w));let x=D.walls;k.wall=!0;for(let H=0;H<x.length;H++){let j=x[H];k.geometry=ii.scaleToGeodeticHeightExtruded(j.geometry,M,Q,i,r),j.geometry=kV(k),G.push(j)}}else for(y=0;y<C.length;y++){let D=new Ln({geometry:ii.createGeometryFromPositions(i,C[y],f?T[y]:void 0,n,r,e,A)});if(D.geometry.attributes.position.values=ui.scaleToGeodeticHeight(D.geometry.attributes.position.values,M,i,!r),k.geometry=D.geometry,D.geometry=kV(k),m(t._offsetAttribute)){let w=D.geometry.attributes.position.values.length,x=t._offsetAttribute===Pe.NONE?0:1,H=new Uint8Array(w/3).fill(x);D.geometry.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:H})}G.push(D)}let c=wi.combineInstances(G)[0];c.attributes.position.values=new Float64Array(c.attributes.position.values),c.indices=te.createTypedArray(c.attributes.position.values.length/3,c.indices);let g=c.attributes,V=Nt.fromVertices(g.position.values);return e.position||delete g.position,new se({attributes:g,indices:c.indices,primitiveType:c.primitiveType,boundingSphere:V,offsetAttribute:t._offsetAttribute})};ea.createShadowVolume=function(t,e,i){let n=t._granularity,s=t._ellipsoid,o=e(n,s),r=i(n,s);return new ea({polygonHierarchy:t._polygonHierarchy,ellipsoid:s,stRotation:t._stRotation,granularity:n,perPositionHeight:!1,extrudedHeight:o,height:r,vertexFormat:Ot.POSITION_ONLY,shadowVolume:!0,arcType:t._arcType})};Object.defineProperties(ea.prototype,{rectangle:{get:function(){if(!m(this._rectangle)){let t=this._polygonHierarchy.positions;this._rectangle=ea.computeRectangleFromPositions(t,this._ellipsoid,this._arcType)}return this._rectangle}},textureCoordinateRotationPoints:{get:function(){return m(this._textureCoordinateRotationPoints)||(this._textureCoordinateRotationPoints=Pmt(this)),this._textureCoordinateRotationPoints}}});LV=ea});var yV={};He(yV,{default:()=>jmt});function Jmt(t,e){return m(e)&&(t=LV.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),LV.createGeometry(t)}var jmt,wV=O(()=>{mt();Ve();Q5();jmt=Jmt});function Hmt(t,e,i,n,s){let r=oo.fromPoints(e,t).projectPointsOntoPlane(e,k5);ui.computeWindingOrder2D(r)===Ms.CLOCKWISE&&(r.reverse(),e=e.slice().reverse());let h,A,d=e.length,f=0;if(n)for(h=new Float64Array(d*2*3),A=0;A<d;A++){let R=e[A],I=e[(A+1)%d];h[f++]=R.x,h[f++]=R.y,h[f++]=R.z,h[f++]=I.x,h[f++]=I.y,h[f++]=I.z}else{let R=0;if(s===ti.GEODESIC)for(A=0;A<d;A++)R+=ii.subdivideLineCount(e[A],e[(A+1)%d],i);else if(s===ti.RHUMB)for(A=0;A<d;A++)R+=ii.subdivideRhumbLineCount(t,e[A],e[(A+1)%d],i);for(h=new Float64Array(R*3),A=0;A<d;A++){let I;s===ti.GEODESIC?I=ii.subdivideLine(e[A],e[(A+1)%d],i,dg):s===ti.RHUMB&&(I=ii.subdivideRhumbLine(t,e[A],e[(A+1)%d],i,dg));let C=I.length;for(let N=0;N<C;++N)h[f++]=I[N]}}d=h.length/3;let E=d*2,_=te.createTypedArray(d,E);for(f=0,A=0;A<d-1;A++)_[f++]=A,_[f++]=A+1;return _[f++]=d-1,_[f++]=0,new Ln({geometry:new se({attributes:new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:h})}),indices:_,primitiveType:ne.LINES})})}function vmt(t,e,i,n,s){let r=oo.fromPoints(e,t).projectPointsOntoPlane(e,k5);ui.computeWindingOrder2D(r)===Ms.CLOCKWISE&&(r.reverse(),e=e.slice().reverse());let h,A,d=e.length,f=new Array(d),E=0;if(n)for(h=new Float64Array(d*2*3*2),A=0;A<d;++A){f[A]=E/3;let C=e[A],N=e[(A+1)%d];h[E++]=C.x,h[E++]=C.y,h[E++]=C.z,h[E++]=N.x,h[E++]=N.y,h[E++]=N.z}else{let C=0;if(s===ti.GEODESIC)for(A=0;A<d;A++)C+=ii.subdivideLineCount(e[A],e[(A+1)%d],i);else if(s===ti.RHUMB)for(A=0;A<d;A++)C+=ii.subdivideRhumbLineCount(t,e[A],e[(A+1)%d],i);for(h=new Float64Array(C*3*2),A=0;A<d;++A){f[A]=E/3;let N;s===ti.GEODESIC?N=ii.subdivideLine(e[A],e[(A+1)%d],i,dg):s===ti.RHUMB&&(N=ii.subdivideRhumbLine(t,e[A],e[(A+1)%d],i,dg));let T=N.length;for(let F=0;F<T;++F)h[E++]=N[F]}}d=h.length/(3*2);let _=f.length,R=(d*2+_)*2,I=te.createTypedArray(d+_,R);for(E=0,A=0;A<d;++A)I[E++]=A,I[E++]=(A+1)%d,I[E++]=A+d,I[E++]=(A+1)%d+d;for(A=0;A<_;A++){let C=f[A];I[E++]=C,I[E++]=C+d}return new Ln({geometry:new se({attributes:new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:h})}),indices:I,primitiveType:ne.LINES})})}function Zd(t){if(p.typeOf.object("options",t),p.typeOf.object("options.polygonHierarchy",t.polygonHierarchy),t.perPositionHeight&&m(t.height))throw new Y("Cannot use both options.perPositionHeight and options.height");if(m(t.arcType)&&t.arcType!==ti.GEODESIC&&t.arcType!==ti.RHUMB)throw new Y("Invalid arcType. Valid options are ArcType.GEODESIC and ArcType.RHUMB.");let e=t.polygonHierarchy,i=Z(t.ellipsoid,ot.WGS84),n=Z(t.granularity,L.RADIANS_PER_DEGREE),s=Z(t.perPositionHeight,!1),o=s&&m(t.extrudedHeight),r=Z(t.arcType,ti.GEODESIC),a=Z(t.height,0),h=Z(t.extrudedHeight,a);if(!o){let A=Math.max(a,h);h=Math.min(a,h),a=A}this._ellipsoid=ot.clone(i),this._granularity=n,this._height=a,this._extrudedHeight=h,this._arcType=r,this._polygonHierarchy=e,this._perPositionHeight=s,this._perPositionHeightExtrude=o,this._offsetAttribute=t.offsetAttribute,this._workerName="createPolygonOutlineGeometry",this.packedLength=ii.computeHierarchyPackedLength(e,l)+ot.packedLength+8}var k5,dg,zmt,Kmt,xV,L5=O(()=>{Bl();_i();Ht();ae();oi();bt();mt();Vt();Ve();Xm();yi();ji();En();uA();go();gA();Di();_e();ER();Pa();Xi();fc();k5=[],dg=[];Zd.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),i=ii.packPolygonHierarchy(t._polygonHierarchy,e,i,l),ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._height,e[i++]=t._extrudedHeight,e[i++]=t._granularity,e[i++]=t._perPositionHeightExtrude?1:0,e[i++]=t._perPositionHeight?1:0,e[i++]=t._arcType,e[i++]=Z(t._offsetAttribute,-1),e[i]=t.packedLength,e};zmt=ot.clone(ot.UNIT_SPHERE),Kmt={polygonHierarchy:{}};Zd.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=ii.unpackPolygonHierarchy(t,e,l);e=n.startingIndex,delete n.startingIndex;let s=ot.unpack(t,e,zmt);e+=ot.packedLength;let o=t[e++],r=t[e++],a=t[e++],h=t[e++]===1,A=t[e++]===1,d=t[e++],f=t[e++],E=t[e];return m(i)||(i=new Zd(Kmt)),i._polygonHierarchy=n,i._ellipsoid=ot.clone(s,i._ellipsoid),i._height=o,i._extrudedHeight=r,i._granularity=a,i._perPositionHeight=A,i._perPositionHeightExtrude=h,i._arcType=d,i._offsetAttribute=f===-1?void 0:f,i.packedLength=E,i};Zd.fromPositions=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.positions",t.positions);let e={polygonHierarchy:{positions:t.positions},height:t.height,extrudedHeight:t.extrudedHeight,ellipsoid:t.ellipsoid,granularity:t.granularity,perPositionHeight:t.perPositionHeight,arcType:t.arcType,offsetAttribute:t.offsetAttribute};return new Zd(e)};Zd.createGeometry=function(t){let e=t._ellipsoid,i=t._granularity,n=t._polygonHierarchy,s=t._perPositionHeight,o=t._arcType,r=ii.polygonOutlinesFromHierarchy(n,!s,e);if(r.length===0)return;let a,h=[],A=L.chordLength(i,e.maximumRadius),d=t._height,f=t._extrudedHeight,E=t._perPositionHeightExtrude||!L.equalsEpsilon(d,f,0,L.EPSILON2),_,R;if(E)for(R=0;R<r.length;R++){if(a=vmt(e,r[R],A,s,o),a.geometry=ii.scaleToGeodeticHeightExtruded(a.geometry,d,f,e,s),m(t._offsetAttribute)){let N=a.geometry.attributes.position.values.length/3,T=new Uint8Array(N);t._offsetAttribute===Pe.TOP?T=T.fill(1,0,N/2):(_=t._offsetAttribute===Pe.NONE?0:1,T=T.fill(_)),a.geometry.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:T})}h.push(a)}else for(R=0;R<r.length;R++){if(a=Hmt(e,r[R],A,s,o),a.geometry.attributes.position.values=ui.scaleToGeodeticHeight(a.geometry.attributes.position.values,d,e,!s),m(t._offsetAttribute)){let N=a.geometry.attributes.position.values.length;_=t._offsetAttribute===Pe.NONE?0:1;let T=new Uint8Array(N/3).fill(_);a.geometry.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:T})}h.push(a)}let I=wi.combineInstances(h)[0],C=Nt.fromVertices(I.attributes.position.values);return new se({attributes:I.attributes,indices:I.indices,primitiveType:I.primitiveType,boundingSphere:C,offsetAttribute:t._offsetAttribute})};xV=Zd});var PV={};He(PV,{default:()=>qmt});function Xmt(t,e){return m(e)&&(t=xV.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),xV.createGeometry(t)}var qmt,JV=O(()=>{mt();Ve();L5();qmt=Xmt});function $mt(t,e,i,n,s){let o=J5;o.length=s;let r,a=i.red,h=i.green,A=i.blue,d=i.alpha,f=n.red,E=n.green,_=n.blue,R=n.alpha;if(Zt.equals(i,n)){for(r=0;r<s;r++)o[r]=Zt.clone(i);return o}let I=(f-a)/s,C=(E-h)/s,N=(_-A)/s,T=(R-d)/s;for(r=0;r<s;r++)o[r]=new Zt(a+r*I,h+r*C,A+r*N,d+r*T);return o}function FR(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.colors,n=Z(t.width,1),s=Z(t.colorsPerVertex,!1);if(!m(e)||e.length<2)throw new Y("At least two positions are required.");if(typeof n!="number")throw new Y("width must be a number");if(m(i)&&(s&&i.length<e.length||!s&&i.length<e.length-1))throw new Y("colors has an invalid length.");this._positions=e,this._colors=i,this._width=n,this._colorsPerVertex=s,this._vertexFormat=Ot.clone(Z(t.vertexFormat,Ot.DEFAULT)),this._arcType=Z(t.arcType,ti.GEODESIC),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._workerName="createPolylineGeometry";let o=1+e.length*l.packedLength;o+=m(i)?1+i.length*Zt.packedLength:1,this.packedLength=o+ot.packedLength+Ot.packedLength+4}var J5,j5,H5,Id,y5,w5,x5,P5,jV,v5=O(()=>{Bl();Oa();_i();Ht();Qn();oi();bt();mt();Vt();Ve();yi();ji();En();dI();Di();_e();Of();Xi();Ls();J5=[];FR.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._colors;for(o=m(r)?r.length:0,e[i++]=o,n=0;n<o;++n,i+=Zt.packedLength)Zt.pack(r[n],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,Ot.pack(t._vertexFormat,e,i),i+=Ot.packedLength,e[i++]=t._width,e[i++]=t._colorsPerVertex?1:0,e[i++]=t._arcType,e[i]=t._granularity,e};j5=ot.clone(ot.UNIT_SPHERE),H5=new Ot,Id={positions:void 0,colors:void 0,ellipsoid:j5,vertexFormat:H5,width:void 0,colorsPerVertex:void 0,arcType:void 0,granularity:void 0};FR.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r=s>0?new Array(s):void 0;for(n=0;n<s;++n,e+=Zt.packedLength)r[n]=Zt.unpack(t,e);let a=ot.unpack(t,e,j5);e+=ot.packedLength;let h=Ot.unpack(t,e,H5);e+=Ot.packedLength;let A=t[e++],d=t[e++]===1,f=t[e++],E=t[e];return m(i)?(i._positions=o,i._colors=r,i._ellipsoid=ot.clone(a,i._ellipsoid),i._vertexFormat=Ot.clone(h,i._vertexFormat),i._width=A,i._colorsPerVertex=d,i._arcType=f,i._granularity=E,i):(Id.positions=o,Id.colors=r,Id.width=A,Id.colorsPerVertex=d,Id.arcType=f,Id.granularity=E,new FR(Id))};y5=new l,w5=new l,x5=new l,P5=new l;FR.createGeometry=function(t){let e=t._width,i=t._vertexFormat,n=t._colors,s=t._colorsPerVertex,o=t._arcType,r=t._granularity,a=t._ellipsoid,h,A,d,f=[],E=Xn(t._positions,l.equalsEpsilon,!1,f);if(m(n)&&f.length>0){let w=0,x=f[0];n=n.filter(function(H,j){let X=!1;return s?X=j===x||j===0&&x===1:X=j+1===x,X?(w++,x=f[w],!1):!0})}let _=E.length;if(_<2||e<=0)return;if(o===ti.GEODESIC||o===ti.RHUMB){let w,x;o===ti.GEODESIC?(w=L.chordLength(r,a.maximumRadius),x=On.numberOfPoints):(w=r,x=On.numberOfPointsRhumbLine);let H=On.extractHeights(E,a);if(m(n)){let j=1;for(h=0;h<_-1;++h)j+=x(E[h],E[h+1],w);let X=new Array(j),tt=0;for(h=0;h<_-1;++h){let B=E[h],It=E[h+1],gt=n[h],Yt=x(B,It,w);if(s&&h<j){let Mt=n[h+1],Ct=$mt(B,It,gt,Mt,Yt),zt=Ct.length;for(A=0;A<zt;++A)X[tt++]=Ct[A]}else for(A=0;A<Yt;++A)X[tt++]=Zt.clone(gt)}X[tt]=Zt.clone(n[n.length-1]),n=X,J5.length=0}o===ti.GEODESIC?E=On.generateCartesianArc({positions:E,minDistance:w,ellipsoid:a,height:H}):E=On.generateCartesianRhumbArc({positions:E,granularity:w,ellipsoid:a,height:H})}_=E.length;let R=_*4-4,I=new Float64Array(R*3),C=new Float64Array(R*3),N=new Float64Array(R*3),T=new Float32Array(R*2),F=i.st?new Float32Array(R*2):void 0,b=m(n)?new Uint8Array(R*4):void 0,G=0,M=0,Q=0,U=0,k;for(A=0;A<_;++A){A===0?(k=y5,l.subtract(E[0],E[1],k),l.add(E[0],k,k)):k=E[A-1],l.clone(k,x5),l.clone(E[A],w5),A===_-1?(k=y5,l.subtract(E[_-1],E[_-2],k),l.add(E[_-1],k,k)):k=E[A+1],l.clone(k,P5);let w,x;m(b)&&(A!==0&&!s?w=n[A-1]:w=n[A],A!==_-1&&(x=n[A]));let H=A===0?2:0,j=A===_-1?2:4;for(d=H;d<j;++d){l.pack(w5,I,G),l.pack(x5,C,G),l.pack(P5,N,G),G+=3;let X=d-2<0?-1:1;if(T[M++]=2*(d%2)-1,T[M++]=X*e,i.st&&(F[Q++]=A/(_-1),F[Q++]=Math.max(T[M-2],0)),m(b)){let tt=d<2?w:x;b[U++]=Zt.floatToByte(tt.red),b[U++]=Zt.floatToByte(tt.green),b[U++]=Zt.floatToByte(tt.blue),b[U++]=Zt.floatToByte(tt.alpha)}}}let y=new we;y.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:I}),y.prevPosition=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:C}),y.nextPosition=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:N}),y.expandAndWidth=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:T}),i.st&&(y.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:F})),m(b)&&(y.color=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:4,values:b,normalize:!0}));let c=te.createTypedArray(R,_*6-6),g=0,V=0,D=_-1;for(A=0;A<D;++A)c[V++]=g,c[V++]=g+2,c[V++]=g+1,c[V++]=g+1,c[V++]=g+2,c[V++]=g+3,g+=4;return new se({attributes:y,indices:c,primitiveType:ne.TRIANGLES,boundingSphere:Nt.fromPoints(E),geometryType:Ah.POLYLINES})};jV=FR});var HV={};He(HV,{default:()=>eft});function tft(t,e){return m(e)&&(t=jV.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),jV.createGeometry(t)}var eft,vV=O(()=>{mt();Ve();v5();eft=tft});function ift(t,e,i,n){let s=new we;n.position&&(s.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:t}));let o=e.length,r=t.length/3,a=(r-o*2)/(o*2),h=ui.triangulate(e),A=(a-1)*o*6+h.length*2,d=te.createTypedArray(r,A),f,E,_,R,I,C,N=o*2,T=0;for(f=0;f<a-1;f++){for(E=0;E<o-1;E++)_=E*2+f*o*2,C=_+N,R=_+1,I=R+N,d[T++]=R,d[T++]=_,d[T++]=I,d[T++]=I,d[T++]=_,d[T++]=C;_=o*2-2+f*o*2,R=_+1,I=R+N,C=_+N,d[T++]=R,d[T++]=_,d[T++]=I,d[T++]=I,d[T++]=_,d[T++]=C}if(n.st||n.tangent||n.bitangent){let G=new Float32Array(r*2),M=1/(a-1),Q=1/i.height,U=i.height/2,k,y,c=0;for(f=0;f<a;f++){for(k=f*M,y=Q*(e[0].y+U),G[c++]=k,G[c++]=y,E=1;E<o;E++)y=Q*(e[E].y+U),G[c++]=k,G[c++]=y,G[c++]=k,G[c++]=y;y=Q*(e[0].y+U),G[c++]=k,G[c++]=y}for(E=0;E<o;E++)k=0,y=Q*(e[E].y+U),G[c++]=k,G[c++]=y;for(E=0;E<o;E++)k=(a-1)*M,y=Q*(e[E].y+U),G[c++]=k,G[c++]=y;s.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:new Float32Array(G)})}let F=r-o*2;for(f=0;f<h.length;f+=3){let G=h[f]+F,M=h[f+1]+F,Q=h[f+2]+F;d[T++]=G,d[T++]=M,d[T++]=Q,d[T++]=Q+o,d[T++]=M+o,d[T++]=G+o}let b=new se({attributes:s,indices:d,boundingSphere:Nt.fromVertices(t),primitiveType:ne.TRIANGLES});if(n.normal&&(b=wi.computeNormal(b)),n.tangent||n.bitangent){try{b=wi.computeTangentAndBitangent(b)}catch{zC("polyline-volume-tangent-bitangent","Unable to compute tangents and bitangents for polyline volume geometry")}n.tangent||(b.attributes.tangent=void 0),n.bitangent||(b.attributes.bitangent=void 0),n.st||(b.attributes.st=void 0)}return b}function SR(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.polylinePositions,i=t.shapePositions;if(!m(e))throw new Y("options.polylinePositions is required.");if(!m(i))throw new Y("options.shapePositions is required.");this._positions=e,this._shape=i,this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._cornerType=Z(t.cornerType,Cn.ROUNDED),this._vertexFormat=Ot.clone(Z(t.vertexFormat,Ot.DEFAULT)),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._workerName="createPolylineVolumeGeometry";let n=1+e.length*l.packedLength;n+=1+i.length*nt.packedLength,this.packedLength=n+ot.packedLength+Ot.packedLength+2}var z5,K5,YR,nft,zV,X5=O(()=>{Oa();Er();_i();Xe();Ht();oi();fd();bt();mt();Vt();Ve();yi();ji();En();gA();Di();_e();LO();Pa();$C();Xi();Ls();fc();SR.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._shape;for(o=r.length,e[i++]=o,n=0;n<o;++n,i+=nt.packedLength)nt.pack(r[n],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,Ot.pack(t._vertexFormat,e,i),i+=Ot.packedLength,e[i++]=t._cornerType,e[i]=t._granularity,e};z5=ot.clone(ot.UNIT_SPHERE),K5=new Ot,YR={polylinePositions:void 0,shapePositions:void 0,ellipsoid:z5,vertexFormat:K5,cornerType:void 0,granularity:void 0};SR.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r=new Array(s);for(n=0;n<s;++n,e+=nt.packedLength)r[n]=nt.unpack(t,e);let a=ot.unpack(t,e,z5);e+=ot.packedLength;let h=Ot.unpack(t,e,K5);e+=Ot.packedLength;let A=t[e++],d=t[e];return m(i)?(i._positions=o,i._shape=r,i._ellipsoid=ot.clone(a,i._ellipsoid),i._vertexFormat=Ot.clone(h,i._vertexFormat),i._cornerType=A,i._granularity=d,i):(YR.polylinePositions=o,YR.shapePositions=r,YR.cornerType=A,YR.granularity=d,new SR(YR))};nft=new mi;SR.createGeometry=function(t){let e=t._positions,i=Xn(e,l.equalsEpsilon),n=t._shape;if(n=Lc.removeDuplicatesFromShape(n),i.length<2||n.length<3)return;ui.computeWindingOrder2D(n)===Ms.CLOCKWISE&&n.reverse();let s=mi.fromPoints(n,nft),o=Lc.computePositions(i,n,s,t,!0);return ift(o,n,s,t._vertexFormat)};zV=SR});var KV={};He(KV,{default:()=>oft});function sft(t,e){return m(e)&&(t=zV.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),zV.createGeometry(t)}var oft,XV=O(()=>{mt();Ve();X5();oft=sft});function rft(t,e){let i=new we;i.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:t});let n=e.length,s=i.position.values.length/3,r=t.length/3/n,a=te.createTypedArray(s,2*n*(r+1)),h,A,d=0;h=0;let f=h*n;for(A=0;A<n-1;A++)a[d++]=A+f,a[d++]=A+f+1;for(a[d++]=n-1+f,a[d++]=f,h=r-1,f=h*n,A=0;A<n-1;A++)a[d++]=A+f,a[d++]=A+f+1;for(a[d++]=n-1+f,a[d++]=f,h=0;h<r-1;h++){let _=n*h,R=_+n;for(A=0;A<n;A++)a[d++]=A+_,a[d++]=A+R}return new se({attributes:i,indices:te.createTypedArray(s,a),boundingSphere:Nt.fromVertices(t),primitiveType:ne.LINES})}function VR(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.polylinePositions,i=t.shapePositions;if(!m(e))throw new Y("options.polylinePositions is required.");if(!m(i))throw new Y("options.shapePositions is required.");this._positions=e,this._shape=i,this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._cornerType=Z(t.cornerType,Cn.ROUNDED),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._workerName="createPolylineVolumeOutlineGeometry";let n=1+e.length*l.packedLength;n+=1+i.length*nt.packedLength,this.packedLength=n+ot.packedLength+2}var q5,OR,aft,qV,$5=O(()=>{Oa();Er();_i();Xe();Ht();oi();fd();bt();mt();Vt();Ve();yi();ji();En();Di();_e();Pa();$C();Xi();fc();VR.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._shape;for(o=r.length,e[i++]=o,n=0;n<o;++n,i+=nt.packedLength)nt.pack(r[n],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._cornerType,e[i]=t._granularity,e};q5=ot.clone(ot.UNIT_SPHERE),OR={polylinePositions:void 0,shapePositions:void 0,ellipsoid:q5,height:void 0,cornerType:void 0,granularity:void 0};VR.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r=new Array(s);for(n=0;n<s;++n,e+=nt.packedLength)r[n]=nt.unpack(t,e);let a=ot.unpack(t,e,q5);e+=ot.packedLength;let h=t[e++],A=t[e];return m(i)?(i._positions=o,i._shape=r,i._ellipsoid=ot.clone(a,i._ellipsoid),i._cornerType=h,i._granularity=A,i):(OR.polylinePositions=o,OR.shapePositions=r,OR.cornerType=h,OR.granularity=A,new VR(OR))};aft=new mi;VR.createGeometry=function(t){let e=t._positions,i=Xn(e,l.equalsEpsilon),n=t._shape;if(n=Lc.removeDuplicatesFromShape(n),i.length<2||n.length<3)return;ui.computeWindingOrder2D(n)===Ms.CLOCKWISE&&n.reverse();let s=mi.fromPoints(n,aft),o=Lc.computePositions(i,n,s,t,!1);return rft(o,n)};qV=VR});var $V={};He($V,{default:()=>hft});function Aft(t,e){return m(e)&&(t=qV.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),qV.createGeometry(t)}var hft,tG=O(()=>{mt();Ve();$5();hft=Aft});function i6(t,e,i,n,s,o,r){let a=Math.cos(e),h=n*a,A=i*a,d=Math.sin(e),f=n*d,E=i*d;ia=eG.project(t,ia),ia=l.subtract(ia,mg,ia);let _=Hn.fromRotation(e,lft);ia=Hn.multiplyByVector(_,ia,ia),ia=l.add(ia,mg,ia),t=eG.unproject(ia,t),o-=1,r-=1;let R=t.latitude,I=R+o*E,C=R-h*r,N=R-h*r+o*E,T=Math.max(R,I,C,N),F=Math.min(R,I,C,N),b=t.longitude,G=b+o*A,M=b+r*f,Q=b+r*f+o*A,U=Math.max(b,G,M,Q),k=Math.min(b,G,M,Q);return{north:T,south:F,east:U,west:k,granYCos:h,granYSin:f,granXCos:A,granXSin:E,nwCorner:t}}var t6,e6,cft,iG,lft,ia,dft,mg,eG,ro,nG=O(()=>{Ht();ri();mt();Vt();zA();_e();dc();pn();t6=Math.cos,e6=Math.sin,cft=Math.sqrt,iG={};iG.computePosition=function(t,e,i,n,s,o,r){let a=e.radiiSquared,h=t.nwCorner,A=t.boundingRectangle,d=h.latitude-t.granYCos*n+s*t.granXSin,f=t6(d),E=e6(d),_=a.z*E,R=h.longitude+n*t.granYSin+s*t.granXCos,I=f*t6(R),C=f*e6(R),N=a.x*I,T=a.y*C,F=cft(N*I+T*C+_*E);if(o.x=N/F,o.y=T/F,o.z=_/F,i){let b=t.stNwCorner;m(b)?(d=b.latitude-t.stGranYCos*n+s*t.stGranXSin,R=b.longitude+n*t.stGranYSin+s*t.stGranXCos,r.x=(R-t.stWest)*t.lonScalar,r.y=(d-t.stSouth)*t.latScalar):(r.x=(R-A.west)*t.lonScalar,r.y=(d-A.south)*t.latScalar)}};lft=new Hn,ia=new l,dft=new ut,mg=new l,eG=new Os;iG.computeOptions=function(t,e,i,n,s,o,r){let a=t.east,h=t.west,A=t.north,d=t.south,f=!1,E=!1;A===L.PI_OVER_TWO&&(f=!0),d===-L.PI_OVER_TWO&&(E=!0);let _,R=A-d;h>a?_=L.TWO_PI-h+a:_=a-h;let I=Math.ceil(_/e)+1,C=Math.ceil(R/e)+1,N=_/(I-1),T=R/(C-1),F=Xt.northwest(t,o),b=Xt.center(t,dft);(i!==0||n!==0)&&(b.longitude<F.longitude&&(b.longitude+=L.TWO_PI),mg=eG.project(b,mg));let G=T,M=N,Q=0,U=0,k=Xt.clone(t,s),y={granYCos:G,granYSin:Q,granXCos:M,granXSin:U,nwCorner:F,boundingRectangle:k,width:I,height:C,northCap:f,southCap:E};if(i!==0){let c=i6(F,i,N,T,b,I,C);if(A=c.north,d=c.south,a=c.east,h=c.west,A<-L.PI_OVER_TWO||A>L.PI_OVER_TWO||d<-L.PI_OVER_TWO||d>L.PI_OVER_TWO)throw new Y("Rotated rectangle is invalid.  It crosses over either the north or south pole.");y.granYCos=c.granYCos,y.granYSin=c.granYSin,y.granXCos=c.granXCos,y.granXSin=c.granXSin,k.north=A,k.south=d,k.east=a,k.west=h}if(n!==0){i=i-n;let c=Xt.northwest(k,r),g=i6(c,i,N,T,b,I,C);y.stGranYCos=g.granYCos,y.stGranXCos=g.granXCos,y.stGranYSin=g.granYSin,y.stGranXSin=g.granXSin,y.stNwCorner=c,y.stWest=g.west,y.stSouth=g.south}return y};ro=iG});function h6(t,e){let i=new se({attributes:new we,primitiveType:ne.TRIANGLES});return i.attributes.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:e.positions}),t.normal&&(i.attributes.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:e.normals})),t.tangent&&(i.attributes.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:e.tangents})),t.bitangent&&(i.attributes.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:e.bitangents})),i}function _ft(t,e,i,n){let s=t.length,o=e.normal?new Float32Array(s):void 0,r=e.tangent?new Float32Array(s):void 0,a=e.bitangent?new Float32Array(s):void 0,h=0,A=a6,d=r6,f=o6;if(e.normal||e.tangent||e.bitangent)for(let E=0;E<s;E+=3){let _=l.fromArray(t,E,sG),R=h+1,I=h+2;f=i.geodeticSurfaceNormal(_,f),(e.tangent||e.bitangent)&&(l.cross(l.UNIT_Z,f,d),lt.multiplyByVector(n,d,d),l.normalize(d,d),e.bitangent&&l.normalize(l.cross(f,d,A),A)),e.normal&&(o[h]=f.x,o[R]=f.y,o[I]=f.z),e.tangent&&(r[h]=d.x,r[R]=d.y,r[I]=d.z),e.bitangent&&(a[h]=A.x,a[R]=A.y,a[I]=A.z),h+=3}return h6(e,{positions:t,normals:o,tangents:r,bitangents:a})}function Rft(t,e,i){let n=t.length,s=e.normal?new Float32Array(n):void 0,o=e.tangent?new Float32Array(n):void 0,r=e.bitangent?new Float32Array(n):void 0,a=0,h=0,A=0,d=!0,f=a6,E=r6,_=o6;if(e.normal||e.tangent||e.bitangent)for(let R=0;R<n;R+=6){let I=l.fromArray(t,R,sG),C=l.fromArray(t,(R+6)%n,oG);if(d){let N=l.fromArray(t,(R+3)%n,c6);l.subtract(C,I,C),l.subtract(N,I,N),_=l.normalize(l.cross(N,C,_),_),d=!1}l.equalsEpsilon(C,I,L.EPSILON10)&&(d=!0),(e.tangent||e.bitangent)&&(f=i.geodeticSurfaceNormal(I,f),e.tangent&&(E=l.normalize(l.cross(f,_,E),E))),e.normal&&(s[a++]=_.x,s[a++]=_.y,s[a++]=_.z,s[a++]=_.x,s[a++]=_.y,s[a++]=_.z),e.tangent&&(o[h++]=E.x,o[h++]=E.y,o[h++]=E.z,o[h++]=E.x,o[h++]=E.y,o[h++]=E.z),e.bitangent&&(r[A++]=f.x,r[A++]=f.y,r[A++]=f.z,r[A++]=f.x,r[A++]=f.y,r[A++]=f.z)}return h6(e,{positions:t,normals:s,tangents:o,bitangents:r})}function l6(t,e){let i=t._vertexFormat,n=t._ellipsoid,s=e.height,o=e.width,r=e.northCap,a=e.southCap,h=0,A=s,d=s,f=0;r&&(h=1,d-=1,f+=1),a&&(A-=1,d-=1,f+=1),f+=o*d;let E=i.position?new Float64Array(f*3):void 0,_=i.st?new Float32Array(f*2):void 0,R=0,I=0,C=sG,N=mft,T=Number.MAX_VALUE,F=Number.MAX_VALUE,b=-Number.MAX_VALUE,G=-Number.MAX_VALUE;for(let g=h;g<A;++g)for(let V=0;V<o;++V)ro.computePosition(e,n,i.st,g,V,C,N),E[R++]=C.x,E[R++]=C.y,E[R++]=C.z,i.st&&(_[I++]=N.x,_[I++]=N.y,T=Math.min(T,N.x),F=Math.min(F,N.y),b=Math.max(b,N.x),G=Math.max(G,N.y));if(r&&(ro.computePosition(e,n,i.st,0,0,C,N),E[R++]=C.x,E[R++]=C.y,E[R++]=C.z,i.st&&(_[I++]=N.x,_[I++]=N.y,T=N.x,F=N.y,b=N.x,G=N.y)),a&&(ro.computePosition(e,n,i.st,s-1,0,C,N),E[R++]=C.x,E[R++]=C.y,E[R]=C.z,i.st&&(_[I++]=N.x,_[I]=N.y,T=Math.min(T,N.x),F=Math.min(F,N.y),b=Math.max(b,N.x),G=Math.max(G,N.y))),i.st&&(T<0||F<0||b>1||G>1))for(let g=0;g<_.length;g+=2)_[g]=(_[g]-T)/(b-T),_[g+1]=(_[g+1]-F)/(G-F);let M=_ft(E,i,n,e.tangentRotationMatrix),Q=6*(o-1)*(d-1);r&&(Q+=3*(o-1)),a&&(Q+=3*(o-1));let U=te.createTypedArray(f,Q),k=0,y=0,c;for(c=0;c<d-1;++c){for(let g=0;g<o-1;++g){let V=k,D=V+o,w=D+1,x=V+1;U[y++]=V,U[y++]=D,U[y++]=x,U[y++]=x,U[y++]=D,U[y++]=w,++k}++k}if(r||a){let g=f-1,V=f-1;r&&a&&(g=f-2);let D,w;if(k=0,r)for(c=0;c<o-1;c++)D=k,w=D+1,U[y++]=g,U[y++]=D,U[y++]=w,++k;if(a)for(k=(d-1)*o,c=0;c<o-1;c++)D=k,w=D+1,U[y++]=D,U[y++]=V,U[y++]=w,++k}return M.indices=U,i.st&&(M.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:_})),M}function wf(t,e,i,n,s){return t[e++]=n[i],t[e++]=n[i+1],t[e++]=n[i+2],t[e++]=s[i],t[e++]=s[i+1],t[e]=s[i+2],t}function xf(t,e,i,n){return t[e++]=n[i],t[e++]=n[i+1],t[e++]=n[i],t[e]=n[i+1],t}function Zft(t,e){let i=t._shadowVolume,n=t._offsetAttribute,s=t._vertexFormat,o=t._extrudedHeight,r=t._surfaceHeight,a=t._ellipsoid,h=e.height,A=e.width,d;if(i){let be=Ot.clone(s,rG);be.normal=!0,t._vertexFormat=be}let f=l6(t,e);i&&(t._vertexFormat=s);let E=ui.scaleToGeodeticHeight(f.attributes.position.values,r,a,!1);E=new Float64Array(E);let _=E.length,R=_*2,I=new Float64Array(R);I.set(E);let C=ui.scaleToGeodeticHeight(f.attributes.position.values,o,a);I.set(C,_),f.attributes.position.values=I;let N=s.normal?new Float32Array(R):void 0,T=s.tangent?new Float32Array(R):void 0,F=s.bitangent?new Float32Array(R):void 0,b=s.st?new Float32Array(R/3*2):void 0,G,M;if(s.normal){for(M=f.attributes.normal.values,N.set(M),d=0;d<_;d++)M[d]=-M[d];N.set(M,_),f.attributes.normal.values=N}if(i){M=f.attributes.normal.values,s.normal||(f.attributes.normal=void 0);let be=new Float32Array(R);for(d=0;d<_;d++)M[d]=-M[d];be.set(M,_),f.attributes.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:be})}let Q,U=m(n);if(U){let be=_/3*2,ni=new Uint8Array(be);n===Pe.TOP?ni=ni.fill(1,0,be/2):(Q=n===Pe.NONE?0:1,ni=ni.fill(Q)),f.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:ni})}if(s.tangent){let be=f.attributes.tangent.values;for(T.set(be),d=0;d<_;d++)be[d]=-be[d];T.set(be,_),f.attributes.tangent.values=T}if(s.bitangent){let be=f.attributes.bitangent.values;F.set(be),F.set(be,_),f.attributes.bitangent.values=F}s.st&&(G=f.attributes.st.values,b.set(G),b.set(G,_/3*2),f.attributes.st.values=b);let k=f.indices,y=k.length,c=_/3,g=te.createTypedArray(R/3,y*2);for(g.set(k),d=0;d<y;d+=3)g[d+y]=k[d+2]+c,g[d+1+y]=k[d+1]+c,g[d+2+y]=k[d]+c;f.indices=g;let V=e.northCap,D=e.southCap,w=h,x=2,H=0,j=4,X=4;V&&(x-=1,w-=1,H+=1,j-=2,X-=1),D&&(x-=1,w-=1,H+=1,j-=2,X-=1),H+=x*A+2*w-j;let tt=(H+X)*2,B=new Float64Array(tt*3),It=i?new Float32Array(tt*3):void 0,gt=U?new Uint8Array(tt):void 0,Yt=s.st?new Float32Array(tt*2):void 0,Mt=n===Pe.TOP;U&&!Mt&&(Q=n===Pe.ALL?1:0,gt=gt.fill(Q));let Ct=0,zt=0,kt=0,Jt=0,Wt=A*w,Ft;for(d=0;d<Wt;d+=A)Ft=d*3,B=wf(B,Ct,Ft,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,d*2,G),zt+=4),i&&(kt+=3,It[kt++]=M[Ft],It[kt++]=M[Ft+1],It[kt++]=M[Ft+2]),Mt&&(gt[Jt++]=1,Jt+=1);if(D){let be=V?Wt+1:Wt;for(Ft=be*3,d=0;d<2;d++)B=wf(B,Ct,Ft,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,be*2,G),zt+=4),i&&(kt+=3,It[kt++]=M[Ft],It[kt++]=M[Ft+1],It[kt++]=M[Ft+2]),Mt&&(gt[Jt++]=1,Jt+=1)}else for(d=Wt-A;d<Wt;d++)Ft=d*3,B=wf(B,Ct,Ft,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,d*2,G),zt+=4),i&&(kt+=3,It[kt++]=M[Ft],It[kt++]=M[Ft+1],It[kt++]=M[Ft+2]),Mt&&(gt[Jt++]=1,Jt+=1);for(d=Wt-1;d>0;d-=A)Ft=d*3,B=wf(B,Ct,Ft,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,d*2,G),zt+=4),i&&(kt+=3,It[kt++]=M[Ft],It[kt++]=M[Ft+1],It[kt++]=M[Ft+2]),Mt&&(gt[Jt++]=1,Jt+=1);if(V){let be=Wt;for(Ft=be*3,d=0;d<2;d++)B=wf(B,Ct,Ft,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,be*2,G),zt+=4),i&&(kt+=3,It[kt++]=M[Ft],It[kt++]=M[Ft+1],It[kt++]=M[Ft+2]),Mt&&(gt[Jt++]=1,Jt+=1)}else for(d=A-1;d>=0;d--)Ft=d*3,B=wf(B,Ct,Ft,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,d*2,G),zt+=4),i&&(kt+=3,It[kt++]=M[Ft],It[kt++]=M[Ft+1],It[kt++]=M[Ft+2]),Mt&&(gt[Jt++]=1,Jt+=1);let ee=Rft(B,s,a);s.st&&(ee.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:Yt})),i&&(ee.attributes.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:It})),U&&(ee.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:gt}));let ce=te.createTypedArray(tt,H*6),je,Oe,Me,Ue;_=B.length/3;let Ce=0;for(d=0;d<_-1;d+=2){je=d,Ue=(je+2)%_;let be=l.fromArray(B,je*3,oG),ni=l.fromArray(B,Ue*3,c6);l.equalsEpsilon(be,ni,L.EPSILON10)||(Oe=(je+1)%_,Me=(Oe+2)%_,ce[Ce++]=je,ce[Ce++]=Oe,ce[Ce++]=Ue,ce[Ce++]=Ue,ce[Ce++]=Oe,ce[Ce++]=Me)}return ee.indices=ce,ee=wi.combineInstances([new Ln({geometry:f}),new Ln({geometry:ee})]),ee[0]}function aG(t,e,i,n,s){if(i===0)return Xt.clone(t,s);let o=ro.computeOptions(t,e,i,0,A6,d6),r=o.height,a=o.width,h=Ift;return ro.computePosition(o,n,!1,0,0,h[0]),ro.computePosition(o,n,!1,0,a-1,h[1]),ro.computePosition(o,n,!1,r-1,0,h[2]),ro.computePosition(o,n,!1,r-1,a-1,h[3]),Xt.fromCartesianArray(h,n,s)}function WA(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.rectangle;if(p.typeOf.object("rectangle",e),Xt.validate(e),e.north<e.south)throw new Y("options.rectangle.north must be greater than or equal to options.rectangle.south");let i=Z(t.height,0),n=Z(t.extrudedHeight,i);this._rectangle=Xt.clone(e),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._surfaceHeight=Math.max(i,n),this._rotation=Z(t.rotation,0),this._stRotation=Z(t.stRotation,0),this._vertexFormat=Ot.clone(Z(t.vertexFormat,Ot.DEFAULT)),this._extrudedHeight=Math.min(i,n),this._shadowVolume=Z(t.shadowVolume,!1),this._workerName="createRectangleGeometry",this._offsetAttribute=t.offsetAttribute,this._rotatedRectangle=void 0,this._textureCoordinateRotationPoints=void 0}function bft(t){if(t._stRotation===0)return[0,0,0,1,1,0];let e=Xt.clone(t._rectangle,s6),i=t._granularity,n=t._ellipsoid,s=t._rotation-t._stRotation,o=aG(e,i,s,n,s6),r=gft;r[0].x=o.west,r[0].y=o.south,r[1].x=o.west,r[1].y=o.north,r[2].x=o.east,r[2].y=o.south;let a=t.rectangle,h=Hn.fromRotation(t._stRotation,Tft),A=Xt.center(a,Nft);for(let R=0;R<3;++R){let I=r[R];I.x-=A.longitude,I.y-=A.latitude,Hn.multiplyByVector(h,I,I),I.x+=A.longitude,I.y+=A.latitude,I.x=(I.x-a.west)/a.width,I.y=(I.y-a.south)/a.height}let d=r[0],f=r[1],E=r[2],_=new Array(6);return nt.pack(d,_),nt.pack(f,_,2),nt.pack(E,_,4),_}var sG,o6,r6,a6,A6,mft,fft,Eft,oG,c6,rG,Ift,d6,pft,m6,f6,jc,uft,n6,Cft,s6,gft,Tft,Nft,AG,E6=O(()=>{_i();Xe();Ht();ri();ae();oi();bt();mt();Vt();Ve();yi();ji();En();uA();go();gA();Di();_e();dc();dn();Pa();Xi();$s();pn();nG();Ls();sG=new l,o6=new l,r6=new l,a6=new l,A6=new Xt,mft=new nt,fft=new Nt,Eft=new Nt;oG=new l,c6=new l;rG=new Ot;Ift=[new l,new l,new l,new l],d6=new ut,pft=new ut;WA.packedLength=Xt.packedLength+ot.packedLength+Ot.packedLength+7;WA.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),Xt.pack(t._rectangle,e,i),i+=Xt.packedLength,ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,Ot.pack(t._vertexFormat,e,i),i+=Ot.packedLength,e[i++]=t._granularity,e[i++]=t._surfaceHeight,e[i++]=t._rotation,e[i++]=t._stRotation,e[i++]=t._extrudedHeight,e[i++]=t._shadowVolume?1:0,e[i]=Z(t._offsetAttribute,-1),e};m6=new Xt,f6=ot.clone(ot.UNIT_SPHERE),jc={rectangle:m6,ellipsoid:f6,vertexFormat:rG,granularity:void 0,height:void 0,rotation:void 0,stRotation:void 0,extrudedHeight:void 0,shadowVolume:void 0,offsetAttribute:void 0};WA.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=Xt.unpack(t,e,m6);e+=Xt.packedLength;let s=ot.unpack(t,e,f6);e+=ot.packedLength;let o=Ot.unpack(t,e,rG);e+=Ot.packedLength;let r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++]===1,E=t[e];return m(i)?(i._rectangle=Xt.clone(n,i._rectangle),i._ellipsoid=ot.clone(s,i._ellipsoid),i._vertexFormat=Ot.clone(o,i._vertexFormat),i._granularity=r,i._surfaceHeight=a,i._rotation=h,i._stRotation=A,i._extrudedHeight=d,i._shadowVolume=f,i._offsetAttribute=E===-1?void 0:E,i):(jc.granularity=r,jc.height=a,jc.rotation=h,jc.stRotation=A,jc.extrudedHeight=d,jc.shadowVolume=f,jc.offsetAttribute=E===-1?void 0:E,new WA(jc))};WA.computeRectangle=function(t,e){t=Z(t,Z.EMPTY_OBJECT);let i=t.rectangle;if(p.typeOf.object("rectangle",i),Xt.validate(i),i.north<i.south)throw new Y("options.rectangle.north must be greater than or equal to options.rectangle.south");let n=Z(t.granularity,L.RADIANS_PER_DEGREE),s=Z(t.ellipsoid,ot.WGS84),o=Z(t.rotation,0);return aG(i,n,o,s,e)};uft=new lt,n6=new Ae,Cft=new ut;WA.createGeometry=function(t){if(L.equalsEpsilon(t._rectangle.north,t._rectangle.south,L.EPSILON10)||L.equalsEpsilon(t._rectangle.east,t._rectangle.west,L.EPSILON10))return;let e=t._rectangle,i=t._ellipsoid,n=t._rotation,s=t._stRotation,o=t._vertexFormat,r=ro.computeOptions(e,t._granularity,n,s,A6,d6,pft),a=uft;if(s!==0||n!==0){let _=Xt.center(e,Cft),R=i.geodeticSurfaceNormalCartographic(_,oG);Ae.fromAxisAngle(R,-s,n6),lt.fromQuaternion(n6,a)}else lt.clone(lt.IDENTITY,a);let h=t._surfaceHeight,A=t._extrudedHeight,d=!L.equalsEpsilon(h,A,0,L.EPSILON2);r.lonScalar=1/t._rectangle.width,r.latScalar=1/t._rectangle.height,r.tangentRotationMatrix=a;let f,E;if(e=t._rectangle,d){f=Zft(t,r);let _=Nt.fromRectangle3D(e,i,h,Eft),R=Nt.fromRectangle3D(e,i,A,fft);E=Nt.union(_,R)}else{if(f=l6(t,r),f.attributes.position.values=ui.scaleToGeodeticHeight(f.attributes.position.values,h,i,!1),m(t._offsetAttribute)){let _=f.attributes.position.values.length,R=t._offsetAttribute===Pe.NONE?0:1,I=new Uint8Array(_/3).fill(R);f.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:I})}E=Nt.fromRectangle3D(e,i,h)}return o.position||delete f.attributes.position,new se({attributes:f.attributes,indices:f.indices,primitiveType:f.primitiveType,boundingSphere:E,offsetAttribute:t._offsetAttribute})};WA.createShadowVolume=function(t,e,i){let n=t._granularity,s=t._ellipsoid,o=e(n,s),r=i(n,s);return new WA({rectangle:t._rectangle,rotation:t._rotation,ellipsoid:s,stRotation:t._stRotation,granularity:n,extrudedHeight:r,height:o,vertexFormat:Ot.POSITION_ONLY,shadowVolume:!0})};s6=new Xt,gft=[new nt,new nt,new nt],Tft=new Hn,Nft=new ut;Object.defineProperties(WA.prototype,{rectangle:{get:function(){return m(this._rotatedRectangle)||(this._rotatedRectangle=aG(this._rectangle,this._granularity,this._rotation,this._ellipsoid)),this._rotatedRectangle}},textureCoordinateRotationPoints:{get:function(){return m(this._textureCoordinateRotationPoints)||(this._textureCoordinateRotationPoints=bft(this)),this._textureCoordinateRotationPoints}}});AG=WA});var hG={};He(hG,{default:()=>Yft});function Fft(t,e){return m(e)&&(t=AG.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),t._rectangle=Xt.clone(t._rectangle),AG.createGeometry(t)}var Yft,cG=O(()=>{mt();Ve();pn();E6();Yft=Fft});function _6(t,e){let i=t._ellipsoid,n=e.height,s=e.width,o=e.northCap,r=e.southCap,a=n,h=2,A=0,d=4;o&&(h-=1,a-=1,A+=1,d-=2),r&&(h-=1,a-=1,A+=1,d-=2),A+=h*s+2*a-d;let f=new Float64Array(A*3),E=0,_=0,R,I=Vft;if(o)ro.computePosition(e,i,!1,_,0,I),f[E++]=I.x,f[E++]=I.y,f[E++]=I.z;else for(R=0;R<s;R++)ro.computePosition(e,i,!1,_,R,I),f[E++]=I.x,f[E++]=I.y,f[E++]=I.z;for(R=s-1,_=1;_<n;_++)ro.computePosition(e,i,!1,_,R,I),f[E++]=I.x,f[E++]=I.y,f[E++]=I.z;if(_=n-1,!r)for(R=s-2;R>=0;R--)ro.computePosition(e,i,!1,_,R,I),f[E++]=I.x,f[E++]=I.y,f[E++]=I.z;for(R=0,_=n-2;_>0;_--)ro.computePosition(e,i,!1,_,R,I),f[E++]=I.x,f[E++]=I.y,f[E++]=I.z;let C=f.length/3*2,N=te.createTypedArray(f.length/3,C),T=0;for(let b=0;b<f.length/3-1;b++)N[T++]=b,N[T++]=b+1;N[T++]=f.length/3-1,N[T++]=0;let F=new se({attributes:new we,primitiveType:ne.LINES});return F.attributes.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:f}),F.indices=N,F}function Bft(t,e){let i=t._surfaceHeight,n=t._extrudedHeight,s=t._ellipsoid,o=_6(t,e),r=e.height,a=e.width,h=ui.scaleToGeodeticHeight(o.attributes.position.values,i,s,!1),A=h.length,d=new Float64Array(A*2);d.set(h);let f=ui.scaleToGeodeticHeight(o.attributes.position.values,n,s);d.set(f,A),o.attributes.position.values=d;let E=e.northCap,_=e.southCap,R=4;E&&(R-=1),_&&(R-=1);let I=(d.length/3+R)*2,C=te.createTypedArray(d.length/3,I);A=d.length/6;let N=0;for(let F=0;F<A-1;F++)C[N++]=F,C[N++]=F+1,C[N++]=F+A,C[N++]=F+A+1;C[N++]=A-1,C[N++]=0,C[N++]=A+A-1,C[N++]=A,C[N++]=0,C[N++]=A;let T;if(E)T=r-1;else{let F=a-1;C[N++]=F,C[N++]=F+A,T=a+r-2}if(C[N++]=T,C[N++]=T+A,!_){let F=a+T-1;C[N++]=F,C[N]=F+A}return o.indices=C,o}function Jf(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.rectangle,i=Z(t.granularity,L.RADIANS_PER_DEGREE),n=Z(t.ellipsoid,ot.WGS84),s=Z(t.rotation,0);if(!m(e))throw new Y("rectangle is required.");if(Xt.validate(e),e.north<e.south)throw new Y("options.rectangle.north must be greater than options.rectangle.south");let o=Z(t.height,0),r=Z(t.extrudedHeight,o);this._rectangle=Xt.clone(e),this._granularity=i,this._ellipsoid=n,this._surfaceHeight=Math.max(o,r),this._rotation=s,this._extrudedHeight=Math.min(o,r),this._offsetAttribute=t.offsetAttribute,this._workerName="createRectangleOutlineGeometry"}var Sft,Oft,Vft,Gft,R6,Z6,Pf,Wft,lG,I6=O(()=>{_i();Ht();ri();oi();bt();mt();Vt();Ve();yi();ji();En();go();Di();_e();Pa();Xi();pn();nG();Sft=new Nt,Oft=new Nt,Vft=new l,Gft=new Xt;Jf.packedLength=Xt.packedLength+ot.packedLength+5;Jf.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),Xt.pack(t._rectangle,e,i),i+=Xt.packedLength,ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._granularity,e[i++]=t._surfaceHeight,e[i++]=t._rotation,e[i++]=t._extrudedHeight,e[i]=Z(t._offsetAttribute,-1),e};R6=new Xt,Z6=ot.clone(ot.UNIT_SPHERE),Pf={rectangle:R6,ellipsoid:Z6,granularity:void 0,height:void 0,rotation:void 0,extrudedHeight:void 0,offsetAttribute:void 0};Jf.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n=Xt.unpack(t,e,R6);e+=Xt.packedLength;let s=ot.unpack(t,e,Z6);e+=ot.packedLength;let o=t[e++],r=t[e++],a=t[e++],h=t[e++],A=t[e];return m(i)?(i._rectangle=Xt.clone(n,i._rectangle),i._ellipsoid=ot.clone(s,i._ellipsoid),i._surfaceHeight=r,i._rotation=a,i._extrudedHeight=h,i._offsetAttribute=A===-1?void 0:A,i):(Pf.granularity=o,Pf.height=r,Pf.rotation=a,Pf.extrudedHeight=h,Pf.offsetAttribute=A===-1?void 0:A,new Jf(Pf))};Wft=new ut;Jf.createGeometry=function(t){let e=t._rectangle,i=t._ellipsoid,n=ro.computeOptions(e,t._granularity,t._rotation,0,Gft,Wft),s,o;if(L.equalsEpsilon(e.north,e.south,L.EPSILON10)||L.equalsEpsilon(e.east,e.west,L.EPSILON10))return;let r=t._surfaceHeight,a=t._extrudedHeight,h=!L.equalsEpsilon(r,a,0,L.EPSILON2),A;if(h){if(s=Bft(t,n),m(t._offsetAttribute)){let E=s.attributes.position.values.length/3,_=new Uint8Array(E);t._offsetAttribute===Pe.TOP?_=_.fill(1,0,E/2):(A=t._offsetAttribute===Pe.NONE?0:1,_=_.fill(A)),s.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:_})}let d=Nt.fromRectangle3D(e,i,r,Oft),f=Nt.fromRectangle3D(e,i,a,Sft);o=Nt.union(d,f)}else{if(s=_6(t,n),s.attributes.position.values=ui.scaleToGeodeticHeight(s.attributes.position.values,r,i,!1),m(t._offsetAttribute)){let d=s.attributes.position.values.length;A=t._offsetAttribute===Pe.NONE?0:1;let f=new Uint8Array(d/3).fill(A);s.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:f})}o=Nt.fromRectangle3D(e,i,r)}return new se({attributes:s.attributes,indices:s.indices,primitiveType:ne.LINES,boundingSphere:o,offsetAttribute:t._offsetAttribute})};lG=Jf});var dG={};He(dG,{default:()=>Mft});function Dft(t,e){return m(e)&&(t=lG.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),t._rectangle=Xt.clone(t._rectangle),lG.createGeometry(t)}var Mft,mG=O(()=>{mt();Ve();pn();I6();Mft=Dft});function Uft(t,e,i,n,s,o,r){let a=On.numberOfPoints(t,e,s),h,A=i.red,d=i.green,f=i.blue,E=i.alpha,_=n.red,R=n.green,I=n.blue,C=n.alpha;if(Zt.equals(i,n)){for(h=0;h<a;h++)o[r++]=Zt.floatToByte(A),o[r++]=Zt.floatToByte(d),o[r++]=Zt.floatToByte(f),o[r++]=Zt.floatToByte(E);return r}let N=(_-A)/a,T=(R-d)/a,F=(I-f)/a,b=(C-E)/a,G=r;for(h=0;h<a;h++)o[G++]=Zt.floatToByte(A+h*N),o[G++]=Zt.floatToByte(d+h*T),o[G++]=Zt.floatToByte(f+h*F),o[G++]=Zt.floatToByte(E+h*b);return G}function GR(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.colors,n=Z(t.colorsPerVertex,!1);if(!m(e)||e.length<2)throw new Y("At least two positions are required.");if(m(i)&&(n&&i.length<e.length||!n&&i.length<e.length-1))throw new Y("colors has an invalid length.");this._positions=e,this._colors=i,this._colorsPerVertex=n,this._arcType=Z(t.arcType,ti.GEODESIC),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._ellipsoid=Z(t.ellipsoid,ot.WGS84),this._workerName="createSimplePolylineGeometry";let s=1+e.length*l.packedLength;s+=m(i)?1+i.length*Zt.packedLength:1,this.packedLength=s+ot.packedLength+3}var fg,Eg,Qft,fG,p6=O(()=>{Bl();_i();Ht();Qn();oi();bt();mt();Vt();Ve();yi();ji();En();Di();_e();Of();Xi();GR.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._colors;for(o=m(r)?r.length:0,e[i++]=o,n=0;n<o;++n,i+=Zt.packedLength)Zt.pack(r[n],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._colorsPerVertex?1:0,e[i++]=t._arcType,e[i]=t._granularity,e};GR.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r=s>0?new Array(s):void 0;for(n=0;n<s;++n,e+=Zt.packedLength)r[n]=Zt.unpack(t,e);let a=ot.unpack(t,e);e+=ot.packedLength;let h=t[e++]===1,A=t[e++],d=t[e];return m(i)?(i._positions=o,i._colors=r,i._ellipsoid=a,i._colorsPerVertex=h,i._arcType=A,i._granularity=d,i):new GR({positions:o,colors:r,ellipsoid:a,colorsPerVertex:h,arcType:A,granularity:d})};fg=new Array(2),Eg=new Array(2),Qft={positions:fg,height:Eg,ellipsoid:void 0,minDistance:void 0,granularity:void 0};GR.createGeometry=function(t){let e=t._positions,i=t._colors,n=t._colorsPerVertex,s=t._arcType,o=t._granularity,r=t._ellipsoid,a=L.chordLength(o,r.maximumRadius),h=m(i)&&!n,A,d=e.length,f,E,_,R,I=0;if(s===ti.GEODESIC||s===ti.RHUMB){let b,G,M;s===ti.GEODESIC?(b=L.chordLength(o,r.maximumRadius),G=On.numberOfPoints,M=On.generateArc):(b=o,G=On.numberOfPointsRhumbLine,M=On.generateRhumbArc);let Q=On.extractHeights(e,r),U=Qft;if(s===ti.GEODESIC?U.minDistance=a:U.granularity=o,U.ellipsoid=r,h){let k=0;for(A=0;A<d-1;A++)k+=G(e[A],e[A+1],b)+1;f=new Float64Array(k*3),_=new Uint8Array(k*4),U.positions=fg,U.height=Eg;let y=0;for(A=0;A<d-1;++A){fg[0]=e[A],fg[1]=e[A+1],Eg[0]=Q[A],Eg[1]=Q[A+1];let c=M(U);if(m(i)){let g=c.length/3;R=i[A];for(let V=0;V<g;++V)_[y++]=Zt.floatToByte(R.red),_[y++]=Zt.floatToByte(R.green),_[y++]=Zt.floatToByte(R.blue),_[y++]=Zt.floatToByte(R.alpha)}f.set(c,I),I+=c.length}}else if(U.positions=e,U.height=Q,f=new Float64Array(M(U)),m(i)){for(_=new Uint8Array(f.length/3*4),A=0;A<d-1;++A){let y=e[A],c=e[A+1],g=i[A],V=i[A+1];I=Uft(y,c,g,V,a,_,I)}let k=i[d-1];_[I++]=Zt.floatToByte(k.red),_[I++]=Zt.floatToByte(k.green),_[I++]=Zt.floatToByte(k.blue),_[I++]=Zt.floatToByte(k.alpha)}}else{E=h?d*2-2:d,f=new Float64Array(E*3),_=m(i)?new Uint8Array(E*4):void 0;let b=0,G=0;for(A=0;A<d;++A){let M=e[A];if(h&&A>0&&(l.pack(M,f,b),b+=3,R=i[A-1],_[G++]=Zt.floatToByte(R.red),_[G++]=Zt.floatToByte(R.green),_[G++]=Zt.floatToByte(R.blue),_[G++]=Zt.floatToByte(R.alpha)),h&&A===d-1)break;l.pack(M,f,b),b+=3,m(i)&&(R=i[A],_[G++]=Zt.floatToByte(R.red),_[G++]=Zt.floatToByte(R.green),_[G++]=Zt.floatToByte(R.blue),_[G++]=Zt.floatToByte(R.alpha))}}let C=new we;C.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:f}),m(i)&&(C.color=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:4,values:_,normalize:!0})),E=f.length/3;let N=(E-1)*2,T=te.createTypedArray(E,N),F=0;for(A=0;A<E-1;++A)T[F++]=A,T[F++]=A+1;return new se({attributes:C,indices:T,primitiveType:ne.LINES,boundingSphere:Nt.fromPoints(e)})};fG=GR});var EG={};He(EG,{default:()=>Lft});function kft(t,e){return m(e)&&(t=fG.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),fG.createGeometry(t)}var Lft,_G=O(()=>{mt();Ve();p6();Lft=kft});function jf(t){let e=Z(t.radius,1),n={radii:new l(e,e,e),stackPartitions:t.stackPartitions,slicePartitions:t.slicePartitions,vertexFormat:t.vertexFormat};this._ellipsoidGeometry=new Nr(n),this._workerName="createSphereGeometry"}var yft,Hc,RG,u6=O(()=>{Ht();ae();bt();mt();sg();Ls();jf.packedLength=Nr.packedLength;jf.pack=function(t,e,i){return p.typeOf.object("value",t),Nr.pack(t._ellipsoidGeometry,e,i)};yft=new Nr,Hc={radius:void 0,radii:new l,vertexFormat:new Ot,stackPartitions:void 0,slicePartitions:void 0};jf.unpack=function(t,e,i){let n=Nr.unpack(t,e,yft);return Hc.vertexFormat=Ot.clone(n._vertexFormat,Hc.vertexFormat),Hc.stackPartitions=n._stackPartitions,Hc.slicePartitions=n._slicePartitions,m(i)?(l.clone(n._radii,Hc.radii),i._ellipsoidGeometry=new Nr(Hc),i):(Hc.radius=n._radii.x,new jf(Hc))};jf.createGeometry=function(t){return Nr.createGeometry(t._ellipsoidGeometry)};RG=jf});var ZG={};He(ZG,{default:()=>xft});function wft(t,e){return m(e)&&(t=RG.unpack(t,e)),RG.createGeometry(t)}var xft,IG=O(()=>{mt();u6();xft=wft});function Hf(t){let e=Z(t.radius,1),n={radii:new l(e,e,e),stackPartitions:t.stackPartitions,slicePartitions:t.slicePartitions,subdivisions:t.subdivisions};this._ellipsoidGeometry=new ja(n),this._workerName="createSphereOutlineGeometry"}var Pft,pd,pG,C6=O(()=>{Ht();ae();bt();mt();ZV();Hf.packedLength=ja.packedLength;Hf.pack=function(t,e,i){return p.typeOf.object("value",t),ja.pack(t._ellipsoidGeometry,e,i)};Pft=new ja,pd={radius:void 0,radii:new l,stackPartitions:void 0,slicePartitions:void 0,subdivisions:void 0};Hf.unpack=function(t,e,i){let n=ja.unpack(t,e,Pft);return pd.stackPartitions=n._stackPartitions,pd.slicePartitions=n._slicePartitions,pd.subdivisions=n._subdivisions,m(i)?(l.clone(n._radii,pd.radii),i._ellipsoidGeometry=new ja(pd),i):(pd.radius=n._radii.x,new Hf(pd))};Hf.createGeometry=function(t){return ja.createGeometry(t._ellipsoidGeometry)};pG=Hf});var uG={};He(uG,{default:()=>jft});function Jft(t,e){return m(e)&&(t=pG.unpack(t,e)),pG.createGeometry(t)}var jft,CG=O(()=>{mt();C6();jft=Jft});var gG={};He(gG,{default:()=>dEt});function Kft(t,e,i,n,s,o,r){let a=t.length,h=new Float64Array(a*3);for(let A=0;A<a;++A){let d=t[A],f=e[A],E=i[A],_=L.lerp(n.west,n.east,d/BR),R=L.lerp(n.south,n.north,f/BR),I=L.lerp(s,o,E/BR),C=ut.fromRadians(_,R,I,vft),N=r.cartographicToCartesian(C,zft);l.pack(N,h,A*3)}return h}function Xft(t){let e=t.length,i=new Uint32Array(e+1),n=0;for(let s=0;s<e;++s)i[s]=n,n+=t[s];return i[e]=n,i}function tEt(t,e,i,n){let s=n.length,o=t.length,r=new Uint8Array(o),a=qft,h=$ft,A=0;for(let f=0;f<s;f++){let E=n[f],_=E;for(let R=1;R<E;R++){let I=A+R,C=I-1;h.longitude=t[I],h.latitude=e[I],a.longitude=t[C],a.latitude=e[C],ut.equals(h,a)&&(_--,r[C]=1)}n[f]=_,A+=E}let d=0;for(let f=0;f<o;f++)r[f]!==1&&(t[d]=t[f],e[d]=e[f],i[d]=i[f],d++)}function F6(t){let e=t*8,i=e*3,n=e*4;this.startEllipsoidNormals=new Float32Array(i),this.endEllipsoidNormals=new Float32Array(i),this.startPositionAndHeights=new Float32Array(n),this.startFaceNormalAndVertexCornerIds=new Float32Array(n),this.endPositionAndHeights=new Float32Array(n),this.endFaceNormalAndHalfWidths=new Float32Array(n),this.vertexBatchIds=new Uint16Array(e),this.indices=te.createTypedArray(e,36*t),this.vec3Offset=0,this.vec4Offset=0,this.batchIdOffset=0,this.indexOffset=0,this.volumeStartIndex=0}function T6(t,e,i,n,s){let o=l.subtract(i,e,eEt),r=l.subtract(e,t,g6);return l.normalize(o,o),l.normalize(r,r),l.dot(o,r)<Hft&&(r=l.multiplyByScalar(r,-1,g6)),l.add(o,r,s),l.equals(s,l.ZERO)&&(s=l.subtract(t,e)),l.cross(s,n,s),l.cross(n,s,s),l.normalize(s,s),s}function lEt(t,e){let i=new Uint16Array(t.positions),n=new Uint16Array(t.widths),s=new Uint32Array(t.counts),o=new Uint16Array(t.batchIds),r=rEt,a=aEt,h=AEt,A=new Float64Array(t.packedBuffer),d=0,f=A[d++],E=A[d++];Xt.unpack(A,d,r),d+=Xt.packedLength,ot.unpack(A,d,a),d+=ot.packedLength,l.unpack(A,d,h);let _,R=i.length/3,I=i.subarray(0,R),C=i.subarray(R,2*R),N=i.subarray(2*R,3*R);Yi.zigZagDeltaDecode(I,C,N),tEt(I,C,N,s);let T=s.length,F=0;for(_=0;_<T;_++){let c=s[_];F+=c-1}let b=new F6(F),G=Kft(I,C,N,r,f,E,a,h);R=I.length;let M=new Float32Array(R*3);for(_=0;_<R;++_)M[_*3]=G[_*3]-h.x,M[_*3+1]=G[_*3+1]-h.y,M[_*3+2]=G[_*3+2]-h.z;let Q=0,U=0;for(_=0;_<T;_++){let c=s[_]-1,g=n[_]*.5,V=o[_],D=Q;for(let w=0;w<c;w++){let x=l.unpack(M,Q,hEt),H=l.unpack(M,Q+3,cEt),j=N[U],X=N[U+1];j=L.lerp(f,E,j/BR),X=L.lerp(f,E,X/BR),U++;let tt=_g,B=Rg;if(w===0){let It=D+c*3,gt=l.unpack(M,It,_g);if(l.equals(gt,x))l.unpack(M,It-3,tt);else{let Yt=l.subtract(x,H,_g);tt=l.add(Yt,x,_g)}}else l.unpack(M,Q-3,tt);if(w===c-1){let It=l.unpack(M,D,Rg);if(l.equals(It,H))l.unpack(M,D+3,B);else{let gt=l.subtract(H,x,Rg);B=l.add(gt,H,Rg)}}else l.unpack(M,Q+6,B);b.addVolume(tt,x,H,B,j,X,g,V,h,a),Q+=3}Q+=3,U++}let k=b.indices;e.push(b.startEllipsoidNormals.buffer),e.push(b.endEllipsoidNormals.buffer),e.push(b.startPositionAndHeights.buffer),e.push(b.startFaceNormalAndVertexCornerIds.buffer),e.push(b.endPositionAndHeights.buffer),e.push(b.endFaceNormalAndHalfWidths.buffer),e.push(b.vertexBatchIds.buffer),e.push(k.buffer);let y={indexDatatype:k.BYTES_PER_ELEMENT===2?te.UNSIGNED_SHORT:te.UNSIGNED_INT,startEllipsoidNormals:b.startEllipsoidNormals.buffer,endEllipsoidNormals:b.endEllipsoidNormals.buffer,startPositionAndHeights:b.startPositionAndHeights.buffer,startFaceNormalAndVertexCornerIds:b.startFaceNormalAndVertexCornerIds.buffer,endPositionAndHeights:b.endPositionAndHeights.buffer,endFaceNormalAndHalfWidths:b.endFaceNormalAndHalfWidths.buffer,vertexBatchIds:b.vertexBatchIds.buffer,indices:k.buffer};if(t.keepDecodedPositions){let c=Xft(s);e.push(G.buffer,c.buffer),y=es(y,{decodedPositions:G.buffer,decodedPositionOffsets:c.buffer})}return y}var BR,Hft,vft,zft,qft,$ft,g6,eEt,Y6,N6,b6,iEt,nEt,sEt,oEt,rEt,aEt,AEt,_g,hEt,cEt,Rg,dEt,TG=O(()=>{oh();Ht();ri();KA();Ve();Di();_e();pn();Ns();BR=32767,Hft=Math.cos(L.toRadians(150)),vft=new ut,zft=new l;qft=new ut,$ft=new ut;g6=new l,eEt=new l;Y6=[0,2,6,0,6,4,0,1,3,0,3,2,0,4,5,0,5,1,5,3,1,5,7,3,7,5,4,7,4,6,7,6,2,7,2,3],N6=Y6.length,b6=new l,iEt=new l,nEt=new l,sEt=new l,oEt=new l;F6.prototype.addVolume=function(t,e,i,n,s,o,r,a,h,A){let d=l.add(e,h,b6),f=A.geodeticSurfaceNormal(d,iEt);d=l.add(i,h,b6);let E=A.geodeticSurfaceNormal(d,sEt),_=T6(t,e,i,f,nEt),R=T6(n,i,e,E,oEt),I=this.startEllipsoidNormals,C=this.endEllipsoidNormals,N=this.startPositionAndHeights,T=this.startFaceNormalAndVertexCornerIds,F=this.endPositionAndHeights,b=this.endFaceNormalAndHalfWidths,G=this.vertexBatchIds,M=this.batchIdOffset,Q=this.vec3Offset,U=this.vec4Offset,k;for(k=0;k<8;k++)l.pack(f,I,Q),l.pack(E,C,Q),l.pack(e,N,U),N[U+3]=s,l.pack(i,F,U),F[U+3]=o,l.pack(_,T,U),T[U+3]=k,l.pack(R,b,U),b[U+3]=r,G[M++]=a,Q+=3,U+=4;this.batchIdOffset=M,this.vec3Offset=Q,this.vec4Offset=U;let y=this.indices,c=this.volumeStartIndex,g=this.indexOffset;for(k=0;k<N6;k++)y[g+k]=Y6[k]+c;this.volumeStartIndex+=8,this.indexOffset+=N6};rEt=new Xt,aEt=new ot,AEt=new l,_g=new l,hEt=new l,cEt=new l,Rg=new l;dEt=Wi(lEt)});function mEt(t){this.offset=t.offset,this.count=t.count,this.color=t.color,this.batchIds=t.batchIds}var S6,O6=O(()=>{S6=mEt});var NG={};He(NG,{default:()=>FEt});function ZEt(t,e){let i=e*fEt,n=l.unpack(t,i,Ig);i+=l.packedLength;let s=at.unpack(t,i,na.modelMatrix);at.multiplyByScale(s,n,s);let o=na.boundingVolume;return l.clone(l.ZERO,o.center),o.radius=Math.sqrt(3),na}function IEt(t,e){let i=e*EEt,n=t[i++],s=t[i++],o=l.fromElements(n,n,s,Ig),r=at.unpack(t,i,na.modelMatrix);at.multiplyByScale(r,o,r);let a=na.boundingVolume;return l.clone(l.ZERO,a.center),a.radius=Math.sqrt(2),na}function pEt(t,e){let i=e*_Et,n=l.unpack(t,i,Ig);i+=l.packedLength;let s=at.unpack(t,i,na.modelMatrix);at.multiplyByScale(s,n,s);let o=na.boundingVolume;return l.clone(l.ZERO,o.center),o.radius=1,na}function uEt(t,e){let i=e*REt,n=t[i++],s=l.unpack(t,i,Ig),o=at.fromTranslation(s,na.modelMatrix);at.multiplyByUniformScale(o,n,o);let r=na.boundingVolume;return l.clone(l.ZERO,r.center),r.radius=1,na}function Zg(t,e,i,n,s){if(!m(e))return;let o=i.length,r=n.attributes.position.values,a=n.indices,h=t.positions,A=t.vertexBatchIds,d=t.indices,f=t.batchIds,E=t.batchTableColors,_=t.batchedIndices,R=t.indexOffsets,I=t.indexCounts,C=t.boundingVolumes,N=t.modelMatrix,T=t.center,F=t.positionOffset,b=t.batchIdIndex,G=t.indexOffset,M=t.batchedIndicesOffset;for(let Q=0;Q<o;++Q){let U=s(e,Q),k=U.modelMatrix;at.multiply(N,k,k);let y=i[Q],c=r.length;for(let D=0;D<c;D+=3){let w=l.unpack(r,D,CEt);at.multiplyByPoint(k,w,w),l.subtract(w,T,w),l.pack(w,h,F*3+D),A[b++]=y}let g=a.length;for(let D=0;D<g;++D)d[G+D]=a[D]+F;let V=Q+M;_[V]=new S6({offset:G,count:g,color:Zt.fromRgba(E[y]),batchIds:[y]}),f[V]=y,R[V]=G,I[V]=g,C[V]=Nt.transform(U.boundingVolume,k),F+=c/3,G+=g}t.positionOffset=F,t.batchIdIndex=b,t.indexOffset=G,t.batchedIndicesOffset+=o}function gEt(t){let e=new Float64Array(t),i=0;l.unpack(e,i,V6),i+=l.packedLength,at.unpack(e,i,G6)}function TEt(t){let e=t.length,i=0;for(let n=0;n<e;++n)i+=Zt.packedLength+3+t[n].batchIds.length;return i}function NEt(t,e,i){let n=i.length,s=2+n*Nt.packedLength+1+TEt(e),o=new Float64Array(s),r=0;o[r++]=t,o[r++]=n;for(let h=0;h<n;++h)Nt.pack(i[h],o,r),r+=Nt.packedLength;let a=e.length;o[r++]=a;for(let h=0;h<a;++h){let A=e[h];Zt.pack(A.color,o,r),r+=Zt.packedLength,o[r++]=A.offset,o[r++]=A.count;let d=A.batchIds,f=d.length;o[r++]=f;for(let E=0;E<f;++E)o[r++]=d[E]}return o}function bEt(t,e){let i=m(t.boxes)?new Float32Array(t.boxes):void 0,n=m(t.boxBatchIds)?new Uint16Array(t.boxBatchIds):void 0,s=m(t.cylinders)?new Float32Array(t.cylinders):void 0,o=m(t.cylinderBatchIds)?new Uint16Array(t.cylinderBatchIds):void 0,r=m(t.ellipsoids)?new Float32Array(t.ellipsoids):void 0,a=m(t.ellipsoidBatchIds)?new Uint16Array(t.ellipsoidBatchIds):void 0,h=m(t.spheres)?new Float32Array(t.spheres):void 0,A=m(t.sphereBatchIds)?new Uint16Array(t.sphereBatchIds):void 0,d=m(i)?n.length:0,f=m(s)?o.length:0,E=m(r)?a.length:0,_=m(h)?A.length:0,R=cR.getUnitBox(),I=gR.getUnitCylinder(),C=Nr.getUnitEllipsoid(),N=R.attributes.position.values,T=I.attributes.position.values,F=C.attributes.position.values,b=N.length*d;b+=T.length*f,b+=F.length*(E+_);let G=R.indices,M=I.indices,Q=C.indices,U=G.length*d;U+=M.length*f,U+=Q.length*(E+_);let k=new Float32Array(b),y=new Uint16Array(b/3),c=te.createTypedArray(b/3,U),g=d+f+E+_,V=new Uint16Array(g),D=new Array(g),w=new Uint32Array(g),x=new Uint32Array(g),H=new Array(g);gEt(t.packedBuffer);let j={batchTableColors:new Uint32Array(t.batchTableColors),positions:k,vertexBatchIds:y,indices:c,batchIds:V,batchedIndices:D,indexOffsets:w,indexCounts:x,boundingVolumes:H,positionOffset:0,batchIdIndex:0,indexOffset:0,batchedIndicesOffset:0,modelMatrix:G6,center:V6};Zg(j,i,n,R,ZEt),Zg(j,s,o,I,IEt),Zg(j,r,a,C,pEt),Zg(j,h,A,C,uEt);let X=NEt(c.BYTES_PER_ELEMENT,D,H);return e.push(k.buffer,y.buffer,c.buffer),e.push(V.buffer,w.buffer,x.buffer),e.push(X.buffer),{positions:k.buffer,vertexBatchIds:y.buffer,indices:c.buffer,indexOffsets:w.buffer,indexCounts:x.buffer,batchIds:V.buffer,packedBuffer:X.buffer}}var Ig,fEt,EEt,_Et,REt,na,CEt,V6,G6,FEt,bG=O(()=>{_i();sO();Ht();Qn();sV();mt();sg();Di();Fi();O6();Ns();Ig=new l,fEt=at.packedLength+l.packedLength,EEt=at.packedLength+2,_Et=at.packedLength+l.packedLength,REt=l.packedLength+1,na={modelMatrix:new at,boundingVolume:new Nt};CEt=new l;V6=new l,G6=new at;FEt=Wi(bEt)});var YG={};He(YG,{default:()=>GEt});function OEt(t){t=new Float64Array(t);let e=0;pg.min=t[e++],pg.max=t[e++],Xt.unpack(t,e,B6),e+=Xt.packedLength,ot.unpack(t,e,W6)}function VEt(t,e){let i=new Uint16Array(t.positions);OEt(t.packedBuffer);let n=B6,s=W6,o=pg.min,r=pg.max,a=i.length/3,h=i.subarray(0,a),A=i.subarray(a,2*a),d=i.subarray(2*a,3*a);Yi.zigZagDeltaDecode(h,A,d);let f=new Float64Array(i.length);for(let E=0;E<a;++E){let _=h[E],R=A[E],I=d[E],C=L.lerp(n.west,n.east,_/FG),N=L.lerp(n.south,n.north,R/FG),T=L.lerp(o,r,I/FG),F=ut.fromRadians(C,N,T,YEt),b=s.cartographicToCartesian(F,SEt);l.pack(b,f,E*3)}return e.push(f.buffer),{positions:f.buffer}}var FG,YEt,SEt,B6,W6,pg,GEt,SG=O(()=>{oh();Ht();ri();Ve();_e();pn();Ns();FG=32767,YEt=new ut,SEt=new l,B6=new Xt,W6=new ot,pg={min:void 0,max:void 0};GEt=Wi(VEt)});var OG={};He(OG,{default:()=>wEt});function BEt(t){let e=new Float64Array(t),i=0;vf.indexBytesPerElement=e[i++],vf.min=e[i++],vf.max=e[i++],l.unpack(e,i,Q6),i+=l.packedLength,ot.unpack(e,i,k6),i+=ot.packedLength,Xt.unpack(e,i,L6)}function WEt(t){let e=t.length,i=0;for(let n=0;n<e;++n)i+=Zt.packedLength+3+t[n].batchIds.length;return i}function DEt(t,e,i){let n=e.length,s=2+n*zs.packedLength+1+WEt(i),o=new Float64Array(s),r=0;o[r++]=t,o[r++]=n;for(let h=0;h<n;++h)zs.pack(e[h],o,r),r+=zs.packedLength;let a=i.length;o[r++]=a;for(let h=0;h<a;++h){let A=i[h];Zt.pack(A.color,o,r),r+=Zt.packedLength,o[r++]=A.offset,o[r++]=A.count;let d=A.batchIds,f=d.length;o[r++]=f;for(let E=0;E<f;++E)o[r++]=d[E]}return o}function yEt(t,e){BEt(t.packedBuffer);let i;vf.indexBytesPerElement===2?i=new Uint16Array(t.indices):i=new Uint32Array(t.indices);let s=new Uint16Array(t.positions),o=new Uint32Array(t.counts),r=new Uint32Array(t.indexCounts),a=new Uint32Array(t.batchIds),h=new Uint32Array(t.batchTableColors),A=new Array(o.length),d=Q6,f=k6,E=L6,_=vf.min,R=vf.max,I=t.minimumHeights,C=t.maximumHeights;m(I)&&m(C)&&(I=new Float32Array(I),C=new Float32Array(C));let N,T,F,b=s.length/2,G=s.subarray(0,b),M=s.subarray(b,2*b);Yi.zigZagDeltaDecode(G,M);let Q=new Float64Array(b*3);for(N=0;N<b;++N){let Ct=G[N],zt=M[N],kt=L.lerp(E.west,E.east,Ct/D6),Jt=L.lerp(E.south,E.north,zt/D6),Wt=ut.fromRadians(kt,Jt,0,U6),Ft=f.cartographicToCartesian(Wt,M6);l.pack(Ft,Q,N*3)}let U=o.length,k=new Array(U),y=new Array(U),c=0,g=0;for(N=0;N<U;++N)k[N]=c,y[N]=g,c+=o[N],g+=r[N];let V=new Float32Array(b*3*2),D=new Uint16Array(b*2),w=new Uint32Array(y.length),x=new Uint32Array(r.length),H=[],j={};for(N=0;N<U;++N)F=h[N],m(j[F])?(j[F].positionLength+=o[N],j[F].indexLength+=r[N],j[F].batchIds.push(N)):j[F]={positionLength:o[N],indexLength:r[N],offset:0,indexOffset:0,batchIds:[N]};let X,tt=0,B=0;for(F in j)if(j.hasOwnProperty(F)){X=j[F],X.offset=tt,X.indexOffset=B;let Ct=X.positionLength*2,zt=X.indexLength*2+X.positionLength*6;tt+=Ct,B+=zt,X.indexLength=zt}let It=[];for(F in j)j.hasOwnProperty(F)&&(X=j[F],It.push({color:Zt.fromRgba(parseInt(F)),offset:X.indexOffset,count:X.indexLength,batchIds:X.batchIds}));for(N=0;N<U;++N){F=h[N],X=j[F];let Ct=X.offset,zt=Ct*3,kt=Ct,Jt=k[N],Wt=o[N],Ft=a[N],ee=_,ce=R;m(I)&&m(C)&&(ee=I[N],ce=C[N]);let je=Number.POSITIVE_INFINITY,Oe=Number.NEGATIVE_INFINITY,Me=Number.POSITIVE_INFINITY,Ue=Number.NEGATIVE_INFINITY;for(T=0;T<Wt;++T){let ze=l.unpack(Q,Jt*3+T*3,M6);f.scaleToGeodeticSurface(ze,ze);let Ge=f.cartesianToCartographic(ze,U6),Ui=Ge.latitude,Ri=Ge.longitude;je=Math.min(Ui,je),Oe=Math.max(Ui,Oe),Me=Math.min(Ri,Me),Ue=Math.max(Ri,Ue);let si=f.geodeticSurfaceNormal(ze,MEt),qe=l.multiplyByScalar(si,ee,UEt),Vi=l.add(ze,qe,QEt);qe=l.multiplyByScalar(si,ce,qe);let gn=l.add(ze,qe,kEt);l.subtract(gn,d,gn),l.subtract(Vi,d,Vi),l.pack(gn,V,zt),l.pack(Vi,V,zt+3),D[kt]=Ft,D[kt+1]=Ft,zt+=6,kt+=2}E=LEt,E.west=Me,E.east=Ue,E.south=je,E.north=Oe,A[N]=zs.fromRectangle(E,_,R,f);let Ce=X.indexOffset,be=y[N],ni=r[N];for(w[N]=Ce,T=0;T<ni;T+=3){let ze=i[be+T]-Jt,Ge=i[be+T+1]-Jt,Ui=i[be+T+2]-Jt;H[Ce++]=ze*2+Ct,H[Ce++]=Ge*2+Ct,H[Ce++]=Ui*2+Ct,H[Ce++]=Ui*2+1+Ct,H[Ce++]=Ge*2+1+Ct,H[Ce++]=ze*2+1+Ct}for(T=0;T<Wt;++T){let ze=T,Ge=(T+1)%Wt;H[Ce++]=ze*2+1+Ct,H[Ce++]=Ge*2+Ct,H[Ce++]=ze*2+Ct,H[Ce++]=ze*2+1+Ct,H[Ce++]=Ge*2+1+Ct,H[Ce++]=Ge*2+Ct}X.offset+=Wt*2,X.indexOffset=Ce,x[N]=Ce-w[N]}H=te.createTypedArray(V.length/3,H);let gt=It.length;for(let Ct=0;Ct<gt;++Ct){let zt=It[Ct].batchIds,kt=0,Jt=zt.length;for(let Wt=0;Wt<Jt;++Wt)kt+=x[zt[Wt]];It[Ct].count=kt}let Yt=H.BYTES_PER_ELEMENT===2?te.UNSIGNED_SHORT:te.UNSIGNED_INT,Mt=DEt(Yt,A,It);return e.push(V.buffer,H.buffer,w.buffer,x.buffer,D.buffer,Mt.buffer),{positions:V.buffer,indices:H.buffer,indexOffsets:w.buffer,indexCounts:x.buffer,batchIds:D.buffer,packedBuffer:Mt.buffer}}var Q6,k6,L6,vf,D6,M6,MEt,UEt,QEt,kEt,U6,LEt,wEt,VG=O(()=>{oh();Ht();ri();Qn();mt();Ve();Di();_e();Jl();pn();Ns();Q6=new l,k6=new ot,L6=new Xt,vf={min:void 0,max:void 0,indexBytesPerElement:void 0};D6=32767,M6=new l,MEt=new l,UEt=new l,QEt=new l,kEt=new l,U6=new ut,LEt=new Xt;wEt=Wi(yEt)});function JEt(t,e,i,n,s){let o=t.length/3,r=t.subarray(0,o),a=t.subarray(o,2*o),h=t.subarray(2*o,3*o);Yi.zigZagDeltaDecode(r,a,h);let A=new Float64Array(t.length);for(let d=0;d<o;++d){let f=r[d],E=a[d],_=h[d],R=L.lerp(e.west,e.east,f/GG),I=L.lerp(e.south,e.north,E/GG),C=L.lerp(i,n,_/GG),N=ut.fromRadians(R,I,C,xEt),T=s.cartographicToCartesian(N,PEt);l.pack(T,A,d*3)}return A}var GG,xEt,PEt,y6,w6=O(()=>{oh();Ht();ri();_e();GG=32767,xEt=new ut,PEt=new l;y6=JEt});var BG={};He(BG,{default:()=>KEt});function jEt(t){t=new Float64Array(t);let e=0;ug.min=t[e++],ug.max=t[e++],Xt.unpack(t,e,H6),e+=Xt.packedLength,ot.unpack(t,e,v6),e+=ot.packedLength,l.unpack(t,e,z6)}function HEt(t){let e=t.length,i=new Uint32Array(e+1),n=0;for(let s=0;s<e;++s)i[s]=n,n+=t[s];return i[e]=n,i}function zEt(t,e){let i=new Uint16Array(t.positions),n=new Uint16Array(t.widths),s=new Uint32Array(t.counts),o=new Uint16Array(t.batchIds);jEt(t.packedBuffer);let r=H6,a=v6,h=z6,A=ug.min,d=ug.max,f=y6(i,r,A,d,a),E=f.length/3,_=E*4-4,R=new Float32Array(_*3),I=new Float32Array(_*3),C=new Float32Array(_*3),N=new Float32Array(_*2),T=new Uint16Array(_),F=0,b=0,G=0,M,Q=0,U=s.length;for(M=0;M<U;++M){let V=s[M],D=n[M],w=o[M];for(let x=0;x<V;++x){let H;if(x===0){let It=l.unpack(f,Q*3,x6),gt=l.unpack(f,(Q+1)*3,P6);H=l.subtract(It,gt,J6),l.add(It,H,H)}else H=l.unpack(f,(Q+x-1)*3,J6);let j=l.unpack(f,(Q+x)*3,vEt),X;if(x===V-1){let It=l.unpack(f,(Q+V-1)*3,x6),gt=l.unpack(f,(Q+V-2)*3,P6);X=l.subtract(It,gt,j6),l.add(It,X,X)}else X=l.unpack(f,(Q+x+1)*3,j6);l.subtract(H,h,H),l.subtract(j,h,j),l.subtract(X,h,X);let tt=x===0?2:0,B=x===V-1?2:4;for(let It=tt;It<B;++It){l.pack(j,R,F),l.pack(H,I,F),l.pack(X,C,F),F+=3;let gt=It-2<0?-1:1;N[b++]=2*(It%2)-1,N[b++]=gt*D,T[G++]=w}}Q+=V}let k=te.createTypedArray(_,E*6-6),y=0,c=0;for(U=E-1,M=0;M<U;++M)k[c++]=y,k[c++]=y+2,k[c++]=y+1,k[c++]=y+1,k[c++]=y+2,k[c++]=y+3,y+=4;e.push(R.buffer,I.buffer,C.buffer),e.push(N.buffer,T.buffer,k.buffer);let g={indexDatatype:k.BYTES_PER_ELEMENT===2?te.UNSIGNED_SHORT:te.UNSIGNED_INT,currentPositions:R.buffer,previousPositions:I.buffer,nextPositions:C.buffer,expandAndWidth:N.buffer,batchIds:T.buffer,indices:k.buffer};if(t.keepDecodedPositions){let V=HEt(s);e.push(f.buffer,V.buffer),g=es(g,{decodedPositions:f.buffer,decodedPositionOffsets:V.buffer})}return g}var H6,v6,z6,ug,x6,P6,J6,vEt,j6,KEt,WG=O(()=>{Ht();KA();w6();Ve();Di();pn();Ns();H6=new Xt,v6=new ot,z6=new l,ug={min:void 0,max:void 0};x6=new l,P6=new l,J6=new l,vEt=new l,j6=new l;KEt=Wi(zEt)});var XEt,sa,K6=O(()=>{XEt={NONE:0,BITS12:1},sa=Object.freeze(XEt)});function Fo(t,e,i,n,s,o,r,a,h,A){let d=sa.NONE,f,E;if(m(e)&&m(i)&&m(n)&&m(s)){let _=e.minimum,R=e.maximum,I=l.subtract(R,_,qEt),C=n-i;Math.max(l.maximumComponent(I),C)<t_t-1?d=sa.BITS12:d=sa.NONE,f=at.inverseTransformation(s,new at);let T=l.negate(_,ud);at.multiply(at.fromTranslation(T,Cg),f,f);let F=ud;F.x=1/I.x,F.y=1/I.y,F.z=1/I.z,at.multiply(at.fromScale(F,Cg),f,f),E=at.clone(s),at.setTranslation(E,l.ZERO,E),s=at.clone(s,new at);let b=at.fromTranslation(_,Cg),G=at.fromScale(I,$Et),M=at.multiply(b,G,Cg);at.multiply(s,M,s),at.multiply(E,M,E)}this.quantization=d,this.minimumHeight=i,this.maximumHeight=n,this.center=l.clone(t),this.toScaledENU=f,this.fromScaledENU=s,this.matrix=E,this.hasVertexNormals=o,this.hasWebMercatorT=Z(r,!1),this.hasGeodeticSurfaceNormals=Z(a,!1),this.exaggeration=Z(h,1),this.exaggerationRelativeHeight=Z(A,0),this.stride=0,this._offsetGeodeticSurfaceNormal=0,this._offsetVertexNormal=0,this._calculateStrideAndOffsets()}var ud,qEt,oa,Cg,$Et,t_t,e_t,X6,gg,Tg,vc,WR=O(()=>{oh();Xe();Ht();oi();bt();mt();_e();Fi();hb();K6();ud=new l,qEt=new l,oa=new nt,Cg=new at,$Et=new at,t_t=Math.pow(2,12);Fo.prototype.encode=function(t,e,i,n,s,o,r,a){let h=n.x,A=n.y;if(this.quantization===sa.BITS12){i=at.multiplyByPoint(this.toScaledENU,i,ud),i.x=L.clamp(i.x,0,1),i.y=L.clamp(i.y,0,1),i.z=L.clamp(i.z,0,1);let d=this.maximumHeight-this.minimumHeight,f=L.clamp((s-this.minimumHeight)/d,0,1);nt.fromElements(i.x,i.y,oa);let E=Yi.compressTextureCoordinates(oa);nt.fromElements(i.z,f,oa);let _=Yi.compressTextureCoordinates(oa);nt.fromElements(h,A,oa);let R=Yi.compressTextureCoordinates(oa);if(t[e++]=E,t[e++]=_,t[e++]=R,this.hasWebMercatorT){nt.fromElements(r,0,oa);let I=Yi.compressTextureCoordinates(oa);t[e++]=I}}else l.subtract(i,this.center,ud),t[e++]=ud.x,t[e++]=ud.y,t[e++]=ud.z,t[e++]=s,t[e++]=h,t[e++]=A,this.hasWebMercatorT&&(t[e++]=r);return this.hasVertexNormals&&(t[e++]=Yi.octPackFloat(o)),this.hasGeodeticSurfaceNormals&&(t[e++]=a.x,t[e++]=a.y,t[e++]=a.z),e};e_t=new l,X6=new l;Fo.prototype.addGeodeticSurfaceNormals=function(t,e,i){if(this.hasGeodeticSurfaceNormals)return;let n=this.stride,s=t.length/n;this.hasGeodeticSurfaceNormals=!0,this._calculateStrideAndOffsets();let o=this.stride;for(let r=0;r<s;r++){for(let d=0;d<n;d++){let f=r*n+d,E=r*o+d;e[E]=t[f]}let a=this.decodePosition(e,r,e_t),h=i.geodeticSurfaceNormal(a,X6),A=r*o+this._offsetGeodeticSurfaceNormal;e[A]=h.x,e[A+1]=h.y,e[A+2]=h.z}};Fo.prototype.removeGeodeticSurfaceNormals=function(t,e){if(!this.hasGeodeticSurfaceNormals)return;let i=this.stride,n=t.length/i;this.hasGeodeticSurfaceNormals=!1,this._calculateStrideAndOffsets();let s=this.stride;for(let o=0;o<n;o++)for(let r=0;r<s;r++){let a=o*i+r,h=o*s+r;e[h]=t[a]}};Fo.prototype.decodePosition=function(t,e,i){if(m(i)||(i=new l),e*=this.stride,this.quantization===sa.BITS12){let n=Yi.decompressTextureCoordinates(t[e],oa);i.x=n.x,i.y=n.y;let s=Yi.decompressTextureCoordinates(t[e+1],oa);return i.z=s.x,at.multiplyByPoint(this.fromScaledENU,i,i)}return i.x=t[e],i.y=t[e+1],i.z=t[e+2],l.add(i,this.center,i)};Fo.prototype.getExaggeratedPosition=function(t,e,i){i=this.decodePosition(t,e,i);let n=this.exaggeration,s=this.exaggerationRelativeHeight;if(n!==1&&this.hasGeodeticSurfaceNormals){let r=this.decodeGeodeticSurfaceNormal(t,e,X6),a=this.decodeHeight(t,e),h=A_.getHeight(a,n,s)-a;i.x+=r.x*h,i.y+=r.y*h,i.z+=r.z*h}return i};Fo.prototype.decodeTextureCoordinates=function(t,e,i){return m(i)||(i=new nt),e*=this.stride,this.quantization===sa.BITS12?Yi.decompressTextureCoordinates(t[e+2],i):nt.fromElements(t[e+4],t[e+5],i)};Fo.prototype.decodeHeight=function(t,e){return e*=this.stride,this.quantization===sa.BITS12?Yi.decompressTextureCoordinates(t[e+1],oa).y*(this.maximumHeight-this.minimumHeight)+this.minimumHeight:t[e+3]};Fo.prototype.decodeWebMercatorT=function(t,e){return e*=this.stride,this.quantization===sa.BITS12?Yi.decompressTextureCoordinates(t[e+3],oa).x:t[e+6]};Fo.prototype.getOctEncodedNormal=function(t,e,i){e=e*this.stride+this._offsetVertexNormal;let n=t[e]/256,s=Math.floor(n),o=(n-s)*256;return nt.fromElements(s,o,i)};Fo.prototype.decodeGeodeticSurfaceNormal=function(t,e,i){return e=e*this.stride+this._offsetGeodeticSurfaceNormal,i.x=t[e],i.y=t[e+1],i.z=t[e+2],i};Fo.prototype._calculateStrideAndOffsets=function(){let t=0;switch(this.quantization){case sa.BITS12:t+=3;break;default:t+=6}this.hasWebMercatorT&&(t+=1),this.hasVertexNormals&&(this._offsetVertexNormal=t,t+=1),this.hasGeodeticSurfaceNormals&&(this._offsetGeodeticSurfaceNormal=t,t+=3),this.stride=t};gg={position3DAndHeight:0,textureCoordAndEncodedNormals:1,geodeticSurfaceNormal:2},Tg={compressed0:0,compressed1:1,geodeticSurfaceNormal:2};Fo.prototype.getAttributes=function(t){let e=At.FLOAT,i=At.getSizeInBytes(e),n=this.stride*i,s=0,o=[];function r(a,h){o.push({index:a,vertexBuffer:t,componentDatatype:e,componentsPerAttribute:h,offsetInBytes:s,strideInBytes:n}),s+=h*i}if(this.quantization===sa.NONE){r(gg.position3DAndHeight,4);let a=2;a+=this.hasWebMercatorT?1:0,a+=this.hasVertexNormals?1:0,r(gg.textureCoordAndEncodedNormals,a),this.hasGeodeticSurfaceNormals&&r(gg.geodeticSurfaceNormal,3)}else{let a=this.hasWebMercatorT||this.hasVertexNormals,h=this.hasWebMercatorT&&this.hasVertexNormals;r(Tg.compressed0,a?4:3),h&&r(Tg.compressed1,1),this.hasGeodeticSurfaceNormals&&r(Tg.geodeticSurfaceNormal,3)}return o};Fo.prototype.getAttributeLocations=function(){return this.quantization===sa.NONE?gg:Tg};Fo.clone=function(t,e){if(m(t))return m(e)||(e=new Fo),e.quantization=t.quantization,e.minimumHeight=t.minimumHeight,e.maximumHeight=t.maximumHeight,e.center=l.clone(t.center),e.toScaledENU=at.clone(t.toScaledENU),e.fromScaledENU=at.clone(t.fromScaledENU),e.matrix=at.clone(t.matrix),e.hasVertexNormals=t.hasVertexNormals,e.hasWebMercatorT=t.hasWebMercatorT,e.hasGeodeticSurfaceNormals=t.hasGeodeticSurfaceNormals,e.exaggeration=t.exaggeration,e.exaggerationRelativeHeight=t.exaggerationRelativeHeight,e._calculateStrideAndOffsets(),e};vc=Fo});var MG={};He(MG,{default:()=>h_t});function DR(t,e,i){i=Z(i,L);let n=t.length;for(let s=0;s<n;++s)if(i.equalsEpsilon(t[s],e,L.EPSILON12))return s;return-1}function s_t(t,e){t.ellipsoid=ot.clone(t.ellipsoid),t.rectangle=Xt.clone(t.rectangle);let i=A_t(t.buffer,t.relativeToCenter,t.ellipsoid,t.rectangle,t.nativeRectangle,t.exaggeration,t.exaggerationRelativeHeight,t.skirtHeight,t.includeWebMercatorT,t.negativeAltitudeExponentBias,t.negativeElevationThreshold),n=i.vertices;e.push(n.buffer);let s=i.indices;return e.push(s.buffer),{vertices:n.buffer,indices:s.buffer,numberOfAttributes:i.encoding.stride,minimumHeight:i.minimumHeight,maximumHeight:i.maximumHeight,boundingSphere3D:i.boundingSphere3D,orientedBoundingBox:i.orientedBoundingBox,occludeePointInScaledSpace:i.occludeePointInScaledSpace,encoding:i.encoding,vertexCountWithoutSkirts:i.vertexCountWithoutSkirts,indexCountWithoutSkirts:i.indexCountWithoutSkirts,westIndicesSouthToNorth:i.westIndicesSouthToNorth,southIndicesEastToWest:i.southIndicesEastToWest,eastIndicesNorthToSouth:i.eastIndicesNorthToSouth,northIndicesWestToEast:i.northIndicesWestToEast}}function A_t(t,e,i,n,s,o,r,a,h,A,d){let f,E,_,R,I,C;m(n)?(f=n.west,E=n.south,_=n.east,R=n.north,I=n.width,C=n.height):(f=L.toRadians(s.west),E=L.toRadians(s.south),_=L.toRadians(s.east),R=L.toRadians(s.north),I=L.toRadians(n.width),C=L.toRadians(n.height));let N=[E,R],T=[f,_],F=In.eastNorthUpToFixedFrame(e,i),b=at.inverseTransformation(F,a_t),G,M;h&&(G=ks.geodeticLatitudeToMercatorAngle(E),M=1/(ks.geodeticLatitudeToMercatorAngle(R)-G));let U=o!==1,k=new DataView(t),y=Number.POSITIVE_INFINITY,c=Number.NEGATIVE_INFINITY,g=o_t;g.x=Number.POSITIVE_INFINITY,g.y=Number.POSITIVE_INFINITY,g.z=Number.POSITIVE_INFINITY;let V=r_t;V.x=Number.NEGATIVE_INFINITY,V.y=Number.NEGATIVE_INFINITY,V.z=Number.NEGATIVE_INFINITY;let D=0,w=0,x=0,H,j;for(j=0;j<4;++j){let De=D;H=k.getUint32(De,!0),De+=DG;let Ye=L.toRadians(k.getFloat64(De,!0)*180);De+=Cd,DR(T,Ye)===-1&&T.push(Ye);let Bi=L.toRadians(k.getFloat64(De,!0)*180);De+=Cd,DR(N,Bi)===-1&&N.push(Bi),De+=2*Cd;let An=k.getInt32(De,!0);De+=Ng,w+=An,An=k.getInt32(De,!0),x+=An*3,D+=H+DG}let X=[],tt=[],B=new Array(w),It=new Array(w),gt=new Array(w),Yt=h?new Array(w):[],Mt=U?new Array(w):[],Ct=new Array(x),zt=[],kt=[],Jt=[],Wt=[],Ft=0,ee=0;for(D=0,j=0;j<4;++j){H=k.getUint32(D,!0),D+=DG;let De=D,Ye=L.toRadians(k.getFloat64(D,!0)*180);D+=Cd;let Bi=L.toRadians(k.getFloat64(D,!0)*180);D+=Cd;let An=L.toRadians(k.getFloat64(D,!0)*180),Ne=An*.5;D+=Cd;let ei=L.toRadians(k.getFloat64(D,!0)*180),_n=ei*.5;D+=Cd;let hs=k.getInt32(D,!0);D+=Ng;let Qi=k.getInt32(D,!0);D+=Ng,D+=Ng;let nn=new Array(hs);for(let sn=0;sn<hs;++sn){let Cs=Ye+k.getUint8(D++)*An;Yo.longitude=Cs;let cs=Bi+k.getUint8(D++)*ei;Yo.latitude=cs;let xn=k.getFloat32(D,!0);if(D+=n_t,xn!==0&&xn<d&&(xn*=-Math.pow(2,A)),xn*=6371010,Yo.height=xn,DR(T,Cs)!==-1||DR(N,cs)!==-1){let Jn=DR(X,Yo,ut);if(Jn===-1)X.push(ut.clone(Yo)),tt.push(Ft);else{nn[sn]=tt[Jn];continue}}nn[sn]=Ft,Math.abs(Cs-f)<Ne?zt.push({index:Ft,cartographic:ut.clone(Yo)}):Math.abs(Cs-_)<Ne?Jt.push({index:Ft,cartographic:ut.clone(Yo)}):Math.abs(cs-E)<_n?kt.push({index:Ft,cartographic:ut.clone(Yo)}):Math.abs(cs-R)<_n&&Wt.push({index:Ft,cartographic:ut.clone(Yo)}),y=Math.min(xn,y),c=Math.max(xn,c),gt[Ft]=xn;let Pn=i.cartographicToCartesian(Yo);if(B[Ft]=Pn,h&&(Yt[Ft]=(ks.geodeticLatitudeToMercatorAngle(cs)-G)*M),U){let Jn=i.geodeticSurfaceNormal(Pn);Mt[Ft]=Jn}at.multiplyByPoint(b,Pn,zf),l.minimumByComponent(zf,g,g),l.maximumByComponent(zf,V,V);let Ai=(Cs-f)/(_-f);Ai=L.clamp(Ai,0,1);let Ci=(cs-E)/(R-E);Ci=L.clamp(Ci,0,1),It[Ft]=new nt(Ai,Ci),++Ft}let ki=Qi*3;for(let sn=0;sn<ki;++sn,++ee)Ct[ee]=nn[k.getUint16(D,!0)],D+=i_t;if(H!==D-De)throw new ke("Invalid terrain tile.")}B.length=Ft,It.length=Ft,gt.length=Ft,h&&(Yt.length=Ft),U&&(Mt.length=Ft);let ce=Ft,je=ee,Oe={hMin:y,lastBorderPoint:void 0,skirtHeight:a,toENU:b,ellipsoid:i,minimum:g,maximum:V};zt.sort(function(De,Ye){return Ye.cartographic.latitude-De.cartographic.latitude}),kt.sort(function(De,Ye){return De.cartographic.longitude-Ye.cartographic.longitude}),Jt.sort(function(De,Ye){return De.cartographic.latitude-Ye.cartographic.latitude}),Wt.sort(function(De,Ye){return Ye.cartographic.longitude-De.cartographic.longitude});let Me=1e-5;if(bg(B,gt,It,Yt,Mt,Ct,Oe,zt,-Me*I,!0,-Me*C),bg(B,gt,It,Yt,Mt,Ct,Oe,kt,-Me*C,!1),bg(B,gt,It,Yt,Mt,Ct,Oe,Jt,Me*I,!0,Me*C),bg(B,gt,It,Yt,Mt,Ct,Oe,Wt,Me*C,!1),zt.length>0&&Wt.length>0){let De=zt[0].index,Ye=ce,Bi=Wt[Wt.length-1].index,An=B.length-1;Ct.push(Bi,An,Ye,Ye,De,Bi)}w=B.length;let Ue=Nt.fromPoints(B),Ce;m(n)&&(Ce=zs.fromRectangle(n,y,c,i));let ni=new dA(i).computeHorizonCullingPointPossiblyUnderEllipsoid(e,B,y),ze=new ph(g,V,e),Ge=new vc(e,ze,Oe.hMin,c,F,!1,h,U,o,r),Ui=new Float32Array(w*Ge.stride),Ri=0;for(let De=0;De<w;++De)Ri=Ge.encode(Ui,Ri,B[De],It[De],gt[De],void 0,Yt[De],Mt[De]);let si=zt.map(function(De){return De.index}).reverse(),qe=kt.map(function(De){return De.index}).reverse(),Vi=Jt.map(function(De){return De.index}).reverse(),gn=Wt.map(function(De){return De.index}).reverse();return qe.unshift(Vi[Vi.length-1]),qe.push(si[0]),gn.unshift(si[si.length-1]),gn.push(Vi[0]),{vertices:Ui,indices:new Uint16Array(Ct),maximumHeight:c,minimumHeight:y,encoding:Ge,boundingSphere3D:Ue,orientedBoundingBox:Ce,occludeePointInScaledSpace:ni,vertexCountWithoutSkirts:ce,indexCountWithoutSkirts:je,westIndicesSouthToNorth:si,southIndicesEastToWest:qe,eastIndicesNorthToSouth:Vi,northIndicesWestToEast:gn}}function bg(t,e,i,n,s,o,r,a,h,A,d){let f=a.length;for(let E=0;E<f;++E){let _=a[E],R=_.cartographic,I=_.index,C=t.length,N=R.longitude,T=R.latitude;T=L.clamp(T,-L.PI_OVER_TWO,L.PI_OVER_TWO);let F=R.height-r.skirtHeight;r.hMin=Math.min(r.hMin,F),ut.fromRadians(N,T,F,Yo),A&&(Yo.longitude+=h),A?E===f-1?Yo.latitude+=d:E===0&&(Yo.latitude-=d):Yo.latitude+=h;let b=r.ellipsoid.cartographicToCartesian(Yo);t.push(b),e.push(F),i.push(nt.clone(i[I])),n.length>0&&n.push(n[I]),s.length>0&&s.push(s[I]),at.multiplyByPoint(r.toENU,b,zf);let G=r.minimum,M=r.maximum;l.minimumByComponent(zf,G,G),l.maximumByComponent(zf,M,M);let Q=r.lastBorderPoint;if(m(Q)){let U=Q.index;o.push(U,C-1,C,C,I,U)}r.lastBorderPoint=_}}var i_t,Ng,DG,n_t,Cd,Yo,zf,o_t,r_t,a_t,h_t,UG=O(()=>{a_();_i();Xe();Ht();ri();bt();mt();Ve();Sm();_e();Fi();Jl();pn();Ps();WR();fr();Ul();Ns();i_t=Uint16Array.BYTES_PER_ELEMENT,Ng=Int32Array.BYTES_PER_ELEMENT,DG=Uint32Array.BYTES_PER_ELEMENT,n_t=Float32Array.BYTES_PER_ELEMENT,Cd=Float64Array.BYTES_PER_ELEMENT;Yo=new ut,zf=new l,o_t=new l,r_t=new l,a_t=new at;h_t=Wi(s_t)});var c_t,q6,$6=O(()=>{c_t={NONE:0,LERC:1},q6=Object.freeze(c_t)});var DA,QG,l_t,d_t,m_t,tK,eK=O(()=>{a_();_i();Xe();Ht();bt();mt();Vt();Ve();Sm();_e();Fi();Jl();pn();WR();fr();Ul();DA={};DA.DEFAULT_STRUCTURE=Object.freeze({heightScale:1,heightOffset:0,elementsPerHeight:1,stride:1,elementMultiplier:256,isBigEndian:!1});QG=new l,l_t=new at,d_t=new l,m_t=new l;DA.computeVertices=function(t){if(!m(t)||!m(t.heightmap))throw new Y("options.heightmap is required.");if(!m(t.width)||!m(t.height))throw new Y("options.width and options.height are required.");if(!m(t.nativeRectangle))throw new Y("options.nativeRectangle is required.");if(!m(t.skirtHeight))throw new Y("options.skirtHeight is required.");let e=Math.cos,i=Math.sin,n=Math.sqrt,s=Math.atan,o=Math.exp,r=L.PI_OVER_TWO,a=L.toRadians,h=t.heightmap,A=t.width,d=t.height,f=t.skirtHeight,E=f>0,_=Z(t.isGeographic,!0),R=Z(t.ellipsoid,ot.WGS84),I=1/R.maximumRadius,C=Xt.clone(t.nativeRectangle),N=Xt.clone(t.rectangle),T,F,b,G;m(N)?(T=N.west,F=N.south,b=N.east,G=N.north):_?(T=a(C.west),F=a(C.south),b=a(C.east),G=a(C.north)):(T=C.west*I,F=r-2*s(o(-C.south*I)),b=C.east*I,G=r-2*s(o(-C.north*I)));let M=t.relativeToCenter,Q=m(M);M=Q?M:l.ZERO;let U=Z(t.includeWebMercatorT,!1),k=Z(t.exaggeration,1),y=Z(t.exaggerationRelativeHeight,0),g=k!==1,V=Z(t.structure,DA.DEFAULT_STRUCTURE),D=Z(V.heightScale,DA.DEFAULT_STRUCTURE.heightScale),w=Z(V.heightOffset,DA.DEFAULT_STRUCTURE.heightOffset),x=Z(V.elementsPerHeight,DA.DEFAULT_STRUCTURE.elementsPerHeight),H=Z(V.stride,DA.DEFAULT_STRUCTURE.stride),j=Z(V.elementMultiplier,DA.DEFAULT_STRUCTURE.elementMultiplier),X=Z(V.isBigEndian,DA.DEFAULT_STRUCTURE.isBigEndian),tt=Xt.computeWidth(C),B=Xt.computeHeight(C),It=tt/(A-1),gt=B/(d-1);_||(tt*=I,B*=I);let Yt=R.radiiSquared,Mt=Yt.x,Ct=Yt.y,zt=Yt.z,kt=65536,Jt=-65536,Wt=In.eastNorthUpToFixedFrame(M,R),Ft=at.inverseTransformation(Wt,l_t),ee,ce;U&&(ee=ks.geodeticLatitudeToMercatorAngle(F),ce=1/(ks.geodeticLatitudeToMercatorAngle(G)-ee));let je=d_t;je.x=Number.POSITIVE_INFINITY,je.y=Number.POSITIVE_INFINITY,je.z=Number.POSITIVE_INFINITY;let Oe=m_t;Oe.x=Number.NEGATIVE_INFINITY,Oe.y=Number.NEGATIVE_INFINITY,Oe.z=Number.NEGATIVE_INFINITY;let Me=Number.POSITIVE_INFINITY,Ue=A*d,Ce=f>0?A*2+d*2:0,be=Ue+Ce,ni=new Array(be),ze=new Array(be),Ge=new Array(be),Ui=U?new Array(be):[],Ri=g?new Array(be):[],si=0,qe=d,Vi=0,gn=A;E&&(--si,++qe,--Vi,++gn);let De=1e-5;for(let Qi=si;Qi<qe;++Qi){let nn=Qi;nn<0&&(nn=0),nn>=d&&(nn=d-1);let ki=C.north-gt*nn;_?ki=a(ki):ki=r-2*s(o(-ki*I));let sn=(ki-F)/(G-F);sn=L.clamp(sn,0,1);let Cs=Qi===si,cs=Qi===qe-1;f>0&&(Cs?ki+=De*B:cs&&(ki-=De*B));let xn=e(ki),Pn=i(ki),Ai=zt*Pn,Ci;U&&(Ci=(ks.geodeticLatitudeToMercatorAngle(ki)-ee)*ce);for(let Jn=Vi;Jn<gn;++Jn){let ls=Jn;ls<0&&(ls=0),ls>=A&&(ls=A-1);let ao=nn*(A*H)+ls*H,qi;if(x===1)qi=h[ao];else{qi=0;let Tn;if(X)for(Tn=0;Tn<x;++Tn)qi=qi*j+h[ao+Tn];else for(Tn=x-1;Tn>=0;--Tn)qi=qi*j+h[ao+Tn]}qi=qi*D+w,Jt=Math.max(Jt,qi),kt=Math.min(kt,qi);let hn=C.west+It*ls;_?hn=a(hn):hn=hn*I;let jo=(hn-T)/(b-T);jo=L.clamp(jo,0,1);let ds=nn*A+ls;if(f>0){let Tn=Jn===Vi,hr=Jn===gn-1,Mh=Cs||cs||Tn||hr;if((Cs||cs)&&(Tn||hr))continue;Mh&&(qi-=f,Tn?(ds=Ue+(d-nn-1),hn-=De*tt):cs?ds=Ue+d+(A-ls-1):hr?(ds=Ue+d+A+nn,hn+=De*tt):Cs&&(ds=Ue+d+A+d+ls))}let on=xn*e(hn),ws=xn*i(hn),So=Mt*on,Fr=Ct*ws,$e=1/n(So*on+Fr*ws+Ai*Pn),aa=So*$e,Yr=Fr*$e,xs=Ai*$e,gs=new l;gs.x=aa+on*qi,gs.y=Yr+ws*qi,gs.z=xs+Pn*qi,at.multiplyByPoint(Ft,gs,QG),l.minimumByComponent(QG,je,je),l.maximumByComponent(QG,Oe,Oe),Me=Math.min(Me,qi),ni[ds]=gs,Ge[ds]=new nt(jo,sn),ze[ds]=qi,U&&(Ui[ds]=Ci),g&&(Ri[ds]=R.geodeticSurfaceNormal(gs))}}let Ye=Nt.fromPoints(ni),Bi;m(N)&&(Bi=zs.fromRectangle(N,kt,Jt,R));let An;Q&&(An=new dA(R).computeHorizonCullingPointPossiblyUnderEllipsoid(M,ni,kt));let Ne=new ph(je,Oe,M),ei=new vc(M,Ne,Me,Jt,Wt,!1,U,g,k,y),_n=new Float32Array(be*ei.stride),hs=0;for(let Qi=0;Qi<be;++Qi)hs=ei.encode(_n,hs,ni[Qi],Ge[Qi],ze[Qi],void 0,Ui[Qi],Ri[Qi]);return{vertices:_n,maximumHeight:Jt,minimumHeight:kt,encoding:ei,boundingSphere3D:Ye,orientedBoundingBox:Bi,occludeePointInScaledSpace:An}};tK=DA});var iK=ts((ASe,Fg)=>{/* Copyright 2015-2018 Esri. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 @preserve */(function(){var t=function(){var s={};s.defaultNoDataValue=-34027999387901484e22,s.decode=function(d,f){f=f||{};var E=f.encodedMaskData||f.encodedMaskData===null,_=h(d,f.inputOffset||0,E),R=f.noDataValue!==null?f.noDataValue:s.defaultNoDataValue,I=o(_,f.pixelType||Float32Array,f.encodedMaskData,R,f.returnMask),C={width:_.width,height:_.height,pixelData:I.resultPixels,minValue:I.minValue,maxValue:_.pixels.maxValue,noDataValue:R};return I.resultMask&&(C.maskData=I.resultMask),f.returnEncodedMask&&_.mask&&(C.encodedMaskData=_.mask.bitset?_.mask.bitset:null),f.returnFileInfo&&(C.fileInfo=r(_),f.computeUsedBitDepths&&(C.fileInfo.bitDepths=a(_))),C};var o=function(d,f,E,_,R){var I=0,C=d.pixels.numBlocksX,N=d.pixels.numBlocksY,T=Math.floor(d.width/C),F=Math.floor(d.height/N),b=2*d.maxZError,G=Number.MAX_VALUE,M;E=E||(d.mask?d.mask.bitset:null);var Q,U;Q=new f(d.width*d.height),R&&E&&(U=new Uint8Array(d.width*d.height));for(var k=new Float32Array(T*F),y,c,g=0;g<=N;g++){var V=g!==N?F:d.height%N;if(V!==0)for(var D=0;D<=C;D++){var w=D!==C?T:d.width%C;if(w!==0){var x=g*d.width*F+D*T,H=d.width-w,j=d.pixels.blocks[I],X,tt,B;j.encoding<2?(j.encoding===0?X=j.rawData:(A(j.stuffedData,j.bitsPerPixel,j.numValidPixels,j.offset,b,k,d.pixels.maxValue),X=k),tt=0):j.encoding===2?B=0:B=j.offset;var It;if(E)for(c=0;c<V;c++){for(x&7&&(It=E[x>>3],It<<=x&7),y=0;y<w;y++)x&7||(It=E[x>>3]),It&128?(U&&(U[x]=1),M=j.encoding<2?X[tt++]:B,G=G>M?M:G,Q[x++]=M):(U&&(U[x]=0),Q[x++]=_),It<<=1;x+=H}else if(j.encoding<2)for(c=0;c<V;c++){for(y=0;y<w;y++)M=X[tt++],G=G>M?M:G,Q[x++]=M;x+=H}else for(G=G>B?B:G,c=0;c<V;c++){for(y=0;y<w;y++)Q[x++]=B;x+=H}if(j.encoding===1&&tt!==j.numValidPixels)throw"Block and Mask do not match";I++}}}return{resultPixels:Q,resultMask:U,minValue:G}},r=function(d){return{fileIdentifierString:d.fileIdentifierString,fileVersion:d.fileVersion,imageType:d.imageType,height:d.height,width:d.width,maxZError:d.maxZError,eofOffset:d.eofOffset,mask:d.mask?{numBlocksX:d.mask.numBlocksX,numBlocksY:d.mask.numBlocksY,numBytes:d.mask.numBytes,maxValue:d.mask.maxValue}:null,pixels:{numBlocksX:d.pixels.numBlocksX,numBlocksY:d.pixels.numBlocksY,numBytes:d.pixels.numBytes,maxValue:d.pixels.maxValue,noDataValue:d.noDataValue}}},a=function(d){for(var f=d.pixels.numBlocksX*d.pixels.numBlocksY,E={},_=0;_<f;_++){var R=d.pixels.blocks[_];R.encoding===0?E.float32=!0:R.encoding===1?E[R.bitsPerPixel]=!0:E[0]=!0}return Object.keys(E)},h=function(d,f,E){var _={},R=new Uint8Array(d,f,10);if(_.fileIdentifierString=String.fromCharCode.apply(null,R),_.fileIdentifierString.trim()!=="CntZImage")throw"Unexpected file identifier string: "+_.fileIdentifierString;f+=10;var I=new DataView(d,f,24);if(_.fileVersion=I.getInt32(0,!0),_.imageType=I.getInt32(4,!0),_.height=I.getUint32(8,!0),_.width=I.getUint32(12,!0),_.maxZError=I.getFloat64(16,!0),f+=24,!E)if(I=new DataView(d,f,16),_.mask={},_.mask.numBlocksY=I.getUint32(0,!0),_.mask.numBlocksX=I.getUint32(4,!0),_.mask.numBytes=I.getUint32(8,!0),_.mask.maxValue=I.getFloat32(12,!0),f+=16,_.mask.numBytes>0){var C=new Uint8Array(Math.ceil(_.width*_.height/8));I=new DataView(d,f,_.mask.numBytes);var N=I.getInt16(0,!0),T=2,F=0;do{if(N>0)for(;N--;)C[F++]=I.getUint8(T++);else{var b=I.getUint8(T++);for(N=-N;N--;)C[F++]=b}N=I.getInt16(T,!0),T+=2}while(T<_.mask.numBytes);if(N!==-32768||F<C.length)throw"Unexpected end of mask RLE encoding";_.mask.bitset=C,f+=_.mask.numBytes}else _.mask.numBytes|_.mask.numBlocksY|_.mask.maxValue||(_.mask.bitset=new Uint8Array(Math.ceil(_.width*_.height/8)));I=new DataView(d,f,16),_.pixels={},_.pixels.numBlocksY=I.getUint32(0,!0),_.pixels.numBlocksX=I.getUint32(4,!0),_.pixels.numBytes=I.getUint32(8,!0),_.pixels.maxValue=I.getFloat32(12,!0),f+=16;var G=_.pixels.numBlocksX,M=_.pixels.numBlocksY,Q=G+(_.width%G>0?1:0),U=M+(_.height%M>0?1:0);_.pixels.blocks=new Array(Q*U);for(var k=0,y=0;y<U;y++)for(var c=0;c<Q;c++){var g=0,V=d.byteLength-f;I=new DataView(d,f,Math.min(10,V));var D={};_.pixels.blocks[k++]=D;var w=I.getUint8(0);if(g++,D.encoding=w&63,D.encoding>3)throw"Invalid block encoding ("+D.encoding+")";if(D.encoding===2){f++;continue}if(w!==0&&w!==2){if(w>>=6,D.offsetType=w,w===2)D.offset=I.getInt8(1),g++;else if(w===1)D.offset=I.getInt16(1,!0),g+=2;else if(w===0)D.offset=I.getFloat32(1,!0),g+=4;else throw"Invalid block offset type";if(D.encoding===1)if(w=I.getUint8(g),g++,D.bitsPerPixel=w&63,w>>=6,D.numValidPixelsType=w,w===2)D.numValidPixels=I.getUint8(g),g++;else if(w===1)D.numValidPixels=I.getUint16(g,!0),g+=2;else if(w===0)D.numValidPixels=I.getUint32(g,!0),g+=4;else throw"Invalid valid pixel count type"}if(f+=g,D.encoding!==3){var x,H;if(D.encoding===0){var j=(_.pixels.numBytes-1)/4;if(j!==Math.floor(j))throw"uncompressed block has invalid length";x=new ArrayBuffer(j*4),H=new Uint8Array(x),H.set(new Uint8Array(d,f,j*4));var X=new Float32Array(x);D.rawData=X,f+=j*4}else if(D.encoding===1){var tt=Math.ceil(D.numValidPixels*D.bitsPerPixel/8),B=Math.ceil(tt/4);x=new ArrayBuffer(B*4),H=new Uint8Array(x),H.set(new Uint8Array(d,f,tt)),D.stuffedData=new Uint32Array(x),f+=tt}}}return _.eofOffset=f,_},A=function(d,f,E,_,R,I,C){var N=(1<<f)-1,T=0,F,b=0,G,M,Q=Math.ceil((C-_)/R),U=d.length*4-Math.ceil(f*E/8);for(d[d.length-1]<<=8*U,F=0;F<E;F++){if(b===0&&(M=d[T++],b=32),b>=f)G=M>>>b-f&N,b-=f;else{var k=f-b;G=(M&N)<<k&N,M=d[T++],b=32-k,G+=M>>>b}I[F]=G<Q?_+G*R:C}return I};return s}(),e=function(){"use strict";var s={unstuff:function(h,A,d,f,E,_,R,I){var C=(1<<d)-1,N=0,T,F=0,b,G,M,Q,U=h.length*4-Math.ceil(d*f/8);if(h[h.length-1]<<=8*U,E)for(T=0;T<f;T++)F===0&&(G=h[N++],F=32),F>=d?(b=G>>>F-d&C,F-=d):(M=d-F,b=(G&C)<<M&C,G=h[N++],F=32-M,b+=G>>>F),A[T]=E[b];else for(Q=Math.ceil((I-_)/R),T=0;T<f;T++)F===0&&(G=h[N++],F=32),F>=d?(b=G>>>F-d&C,F-=d):(M=d-F,b=(G&C)<<M&C,G=h[N++],F=32-M,b+=G>>>F),A[T]=b<Q?_+b*R:I},unstuffLUT:function(h,A,d,f,E,_){var R=(1<<A)-1,I=0,C=0,N=0,T=0,F=0,b,G=[],M=h.length*4-Math.ceil(A*d/8);h[h.length-1]<<=8*M;var Q=Math.ceil((_-f)/E);for(C=0;C<d;C++)T===0&&(b=h[I++],T=32),T>=A?(F=b>>>T-A&R,T-=A):(N=A-T,F=(b&R)<<N&R,b=h[I++],T=32-N,F+=b>>>T),G[C]=F<Q?f+F*E:_;return G.unshift(f),G},unstuff2:function(h,A,d,f,E,_,R,I){var C=(1<<d)-1,N=0,T,F=0,b=0,G,M,Q;if(E)for(T=0;T<f;T++)F===0&&(M=h[N++],F=32,b=0),F>=d?(G=M>>>b&C,F-=d,b+=d):(Q=d-F,G=M>>>b&C,M=h[N++],F=32-Q,G|=(M&(1<<Q)-1)<<d-Q,b=Q),A[T]=E[G];else{var U=Math.ceil((I-_)/R);for(T=0;T<f;T++)F===0&&(M=h[N++],F=32,b=0),F>=d?(G=M>>>b&C,F-=d,b+=d):(Q=d-F,G=M>>>b&C,M=h[N++],F=32-Q,G|=(M&(1<<Q)-1)<<d-Q,b=Q),A[T]=G<U?_+G*R:I}return A},unstuffLUT2:function(h,A,d,f,E,_){var R=(1<<A)-1,I=0,C=0,N=0,T=0,F=0,b=0,G,M=[],Q=Math.ceil((_-f)/E);for(C=0;C<d;C++)T===0&&(G=h[I++],T=32,b=0),T>=A?(F=G>>>b&R,T-=A,b+=A):(N=A-T,F=G>>>b&R,G=h[I++],T=32-N,F|=(G&(1<<N)-1)<<A-N,b=N),M[C]=F<Q?f+F*E:_;return M.unshift(f),M},originalUnstuff:function(h,A,d,f){var E=(1<<d)-1,_=0,R,I=0,C,N,T,F=h.length*4-Math.ceil(d*f/8);for(h[h.length-1]<<=8*F,R=0;R<f;R++)I===0&&(N=h[_++],I=32),I>=d?(C=N>>>I-d&E,I-=d):(T=d-I,C=(N&E)<<T&E,N=h[_++],I=32-T,C+=N>>>I),A[R]=C;return A},originalUnstuff2:function(h,A,d,f){var E=(1<<d)-1,_=0,R,I=0,C=0,N,T,F;for(R=0;R<f;R++)I===0&&(T=h[_++],I=32,C=0),I>=d?(N=T>>>C&E,I-=d,C+=d):(F=d-I,N=T>>>C&E,T=h[_++],I=32-F,N|=(T&(1<<F)-1)<<d-F,C=F),A[R]=N;return A}},o={HUFFMAN_LUT_BITS_MAX:12,computeChecksumFletcher32:function(h){for(var A=65535,d=65535,f=h.length,E=Math.floor(f/2),_=0;E;){var R=E>=359?359:E;E-=R;do A+=h[_++]<<8,d+=A+=h[_++];while(--R);A=(A&65535)+(A>>>16),d=(d&65535)+(d>>>16)}return f&1&&(d+=A+=h[_]<<8),A=(A&65535)+(A>>>16),d=(d&65535)+(d>>>16),(d<<16|A)>>>0},readHeaderInfo:function(h,A){var d=A.ptr,f=new Uint8Array(h,d,6),E={};if(E.fileIdentifierString=String.fromCharCode.apply(null,f),E.fileIdentifierString.lastIndexOf("Lerc2",0)!==0)throw"Unexpected file identifier string (expect Lerc2 ): "+E.fileIdentifierString;d+=6;var _=new DataView(h,d,8),R=_.getInt32(0,!0);E.fileVersion=R,d+=4,R>=3&&(E.checksum=_.getUint32(4,!0),d+=4),_=new DataView(h,d,12),E.height=_.getUint32(0,!0),E.width=_.getUint32(4,!0),d+=8,R>=4?(E.numDims=_.getUint32(8,!0),d+=4):E.numDims=1,_=new DataView(h,d,40),E.numValidPixel=_.getUint32(0,!0),E.microBlockSize=_.getInt32(4,!0),E.blobSize=_.getInt32(8,!0),E.imageType=_.getInt32(12,!0),E.maxZError=_.getFloat64(16,!0),E.zMin=_.getFloat64(24,!0),E.zMax=_.getFloat64(32,!0),d+=40,A.headerInfo=E,A.ptr=d;var I,C;if(R>=3&&(C=R>=4?52:48,I=this.computeChecksumFletcher32(new Uint8Array(h,d-C,E.blobSize-14)),I!==E.checksum))throw"Checksum failed.";return!0},checkMinMaxRanges:function(h,A){var d=A.headerInfo,f=this.getDataTypeArray(d.imageType),E=d.numDims*this.getDataTypeSize(d.imageType),_=this.readSubArray(h,A.ptr,f,E),R=this.readSubArray(h,A.ptr+E,f,E);A.ptr+=2*E;var I,C=!0;for(I=0;I<d.numDims;I++)if(_[I]!==R[I]){C=!1;break}return d.minValues=_,d.maxValues=R,C},readSubArray:function(h,A,d,f){var E;if(d===Uint8Array)E=new Uint8Array(h,A,f);else{var _=new ArrayBuffer(f),R=new Uint8Array(_);R.set(new Uint8Array(h,A,f)),E=new d(_)}return E},readMask:function(h,A){var d=A.ptr,f=A.headerInfo,E=f.width*f.height,_=f.numValidPixel,R=new DataView(h,d,4),I={};if(I.numBytes=R.getUint32(0,!0),d+=4,(_===0||E===_)&&I.numBytes!==0)throw"invalid mask";var C,N;if(_===0)C=new Uint8Array(Math.ceil(E/8)),I.bitset=C,N=new Uint8Array(E),A.pixels.resultMask=N,d+=I.numBytes;else if(I.numBytes>0){C=new Uint8Array(Math.ceil(E/8)),R=new DataView(h,d,I.numBytes);var T=R.getInt16(0,!0),F=2,b=0,G=0;do{if(T>0)for(;T--;)C[b++]=R.getUint8(F++);else for(G=R.getUint8(F++),T=-T;T--;)C[b++]=G;T=R.getInt16(F,!0),F+=2}while(F<I.numBytes);if(T!==-32768||b<C.length)throw"Unexpected end of mask RLE encoding";N=new Uint8Array(E);var M=0,Q=0;for(Q=0;Q<E;Q++)Q&7?(M=C[Q>>3],M<<=Q&7):M=C[Q>>3],M&128&&(N[Q]=1);A.pixels.resultMask=N,I.bitset=C,d+=I.numBytes}return A.ptr=d,A.mask=I,!0},readDataOneSweep:function(h,A,d){var f=A.ptr,E=A.headerInfo,_=E.numDims,R=E.width*E.height,I=E.imageType,C=E.numValidPixel*o.getDataTypeSize(I)*_,N,T=A.pixels.resultMask;if(d===Uint8Array)N=new Uint8Array(h,f,C);else{var F=new ArrayBuffer(C),b=new Uint8Array(F);b.set(new Uint8Array(h,f,C)),N=new d(F)}if(N.length===R*_)A.pixels.resultPixels=N;else{A.pixels.resultPixels=new d(R*_);var G=0,M=0,Q=0,U=0;if(_>1)for(Q=0;Q<_;Q++)for(U=Q*R,M=0;M<R;M++)T[M]&&(A.pixels.resultPixels[U+M]=N[G++]);else for(M=0;M<R;M++)T[M]&&(A.pixels.resultPixels[M]=N[G++])}return f+=C,A.ptr=f,!0},readHuffmanTree:function(h,A){var d=this.HUFFMAN_LUT_BITS_MAX,f=new DataView(h,A.ptr,16);A.ptr+=16;var E=f.getInt32(0,!0);if(E<2)throw"unsupported Huffman version";var _=f.getInt32(4,!0),R=f.getInt32(8,!0),I=f.getInt32(12,!0);if(R>=I)return!1;var C=new Uint32Array(I-R);o.decodeBits(h,A,C);var N=[],T,F,b,G;for(T=R;T<I;T++)F=T-(T<_?0:_),N[F]={first:C[T-R],second:null};var M=h.byteLength-A.ptr,Q=Math.ceil(M/4),U=new ArrayBuffer(Q*4),k=new Uint8Array(U);k.set(new Uint8Array(h,A.ptr,M));var y=new Uint32Array(U),c=0,g,V=0;for(g=y[0],T=R;T<I;T++)F=T-(T<_?0:_),G=N[F].first,G>0&&(N[F].second=g<<c>>>32-G,32-c>=G?(c+=G,c===32&&(c=0,V++,g=y[V])):(c+=G-32,V++,g=y[V],N[F].second|=g>>>32-c));var D=0,w=0,x=new r;for(T=0;T<N.length;T++)N[T]!==void 0&&(D=Math.max(D,N[T].first));D>=d?w=d:w=D,D>=30&&console.log("WARning, large NUM LUT BITS IS "+D);var H=[],j,X,tt,B,It,gt;for(T=R;T<I;T++)if(F=T-(T<_?0:_),G=N[F].first,G>0)if(j=[G,F],G<=w)for(X=N[F].second<<w-G,tt=1<<w-G,b=0;b<tt;b++)H[X|b]=j;else for(X=N[F].second,gt=x,B=G-1;B>=0;B--)It=X>>>B&1,It?(gt.right||(gt.right=new r),gt=gt.right):(gt.left||(gt.left=new r),gt=gt.left),B===0&&!gt.val&&(gt.val=j[1]);return{decodeLut:H,numBitsLUTQick:w,numBitsLUT:D,tree:x,stuffedData:y,srcPtr:V,bitPos:c}},readHuffman:function(h,A,d){var f=A.headerInfo,E=f.numDims,_=A.headerInfo.height,R=A.headerInfo.width,I=R*_,C=this.readHuffmanTree(h,A),N=C.decodeLut,T=C.tree,F=C.stuffedData,b=C.srcPtr,G=C.bitPos,M=C.numBitsLUTQick,Q=C.numBitsLUT,U=A.headerInfo.imageType===0?128:0,k,y,c,g=A.pixels.resultMask,V,D,w,x,H,j,X,tt=0;G>0&&(b++,G=0);var B=F[b],It=A.encodeMode===1,gt=new d(I*E),Yt=gt,Mt;for(Mt=0;Mt<f.numDims;Mt++){if(E>1&&(Yt=new d(gt.buffer,I*Mt,I),tt=0),A.headerInfo.numValidPixel===R*_)for(j=0,x=0;x<_;x++)for(H=0;H<R;H++,j++){if(y=0,V=B<<G>>>32-M,D=V,32-G<M&&(V|=F[b+1]>>>64-G-M,D=V),N[D])y=N[D][1],G+=N[D][0];else for(V=B<<G>>>32-Q,D=V,32-G<Q&&(V|=F[b+1]>>>64-G-Q,D=V),k=T,X=0;X<Q;X++)if(w=V>>>Q-X-1&1,k=w?k.right:k.left,!(k.left||k.right)){y=k.val,G=G+X+1;break}G>=32&&(G-=32,b++,B=F[b]),c=y-U,It?(H>0?c+=tt:x>0?c+=Yt[j-R]:c+=tt,c&=255,Yt[j]=c,tt=c):Yt[j]=c}else for(j=0,x=0;x<_;x++)for(H=0;H<R;H++,j++)if(g[j]){if(y=0,V=B<<G>>>32-M,D=V,32-G<M&&(V|=F[b+1]>>>64-G-M,D=V),N[D])y=N[D][1],G+=N[D][0];else for(V=B<<G>>>32-Q,D=V,32-G<Q&&(V|=F[b+1]>>>64-G-Q,D=V),k=T,X=0;X<Q;X++)if(w=V>>>Q-X-1&1,k=w?k.right:k.left,!(k.left||k.right)){y=k.val,G=G+X+1;break}G>=32&&(G-=32,b++,B=F[b]),c=y-U,It?(H>0&&g[j-1]?c+=tt:x>0&&g[j-R]?c+=Yt[j-R]:c+=tt,c&=255,Yt[j]=c,tt=c):Yt[j]=c}A.ptr=A.ptr+(b+1)*4+(G>0?4:0)}A.pixels.resultPixels=gt},decodeBits:function(h,A,d,f,E){{var _=A.headerInfo,R=_.fileVersion,I=0,C=new DataView(h,A.ptr,5),N=C.getUint8(0);I++;var T=N>>6,F=T===0?4:3-T,b=(N&32)>0,G=N&31,M=0;if(F===1)M=C.getUint8(I),I++;else if(F===2)M=C.getUint16(I,!0),I+=2;else if(F===4)M=C.getUint32(I,!0),I+=4;else throw"Invalid valid pixel count type";var Q=2*_.maxZError,U,k,y,c,g,V,D,w,x,H,j=_.numDims>1?_.maxValues[E]:_.zMax;if(b){for(A.counter.lut++,w=C.getUint8(I),x=G,I++,c=Math.ceil((w-1)*G/8),g=Math.ceil(c/4),k=new ArrayBuffer(g*4),y=new Uint8Array(k),A.ptr+=I,y.set(new Uint8Array(h,A.ptr,c)),D=new Uint32Array(k),A.ptr+=c,H=0;w-1>>>H;)H++;c=Math.ceil(M*H/8),g=Math.ceil(c/4),k=new ArrayBuffer(g*4),y=new Uint8Array(k),y.set(new Uint8Array(h,A.ptr,c)),U=new Uint32Array(k),A.ptr+=c,R>=3?V=s.unstuffLUT2(D,G,w-1,f,Q,j):V=s.unstuffLUT(D,G,w-1,f,Q,j),R>=3?s.unstuff2(U,d,H,M,V):s.unstuff(U,d,H,M,V)}else A.counter.bitstuffer++,H=G,A.ptr+=I,H>0&&(c=Math.ceil(M*H/8),g=Math.ceil(c/4),k=new ArrayBuffer(g*4),y=new Uint8Array(k),y.set(new Uint8Array(h,A.ptr,c)),U=new Uint32Array(k),A.ptr+=c,R>=3?f==null?s.originalUnstuff2(U,d,H,M):s.unstuff2(U,d,H,M,!1,f,Q,j):f==null?s.originalUnstuff(U,d,H,M):s.unstuff(U,d,H,M,!1,f,Q,j))}},readTiles:function(h,A,d){var f=A.headerInfo,E=f.width,_=f.height,R=f.microBlockSize,I=f.imageType,C=o.getDataTypeSize(I),N=Math.ceil(E/R),T=Math.ceil(_/R);A.pixels.numBlocksY=T,A.pixels.numBlocksX=N,A.pixels.ptr=0;var F=0,b=0,G=0,M=0,Q=0,U=0,k=0,y=0,c=0,g=0,V=0,D=0,w=0,x=0,H=0,j=0,X,tt,B,It,gt,Yt,Mt=new d(R*R),Ct=_%R||R,zt=E%R||R,kt,Jt,Wt=f.numDims,Ft,ee=A.pixels.resultMask,ce=A.pixels.resultPixels;for(G=0;G<T;G++)for(Q=G!==T-1?R:Ct,M=0;M<N;M++)for(U=M!==N-1?R:zt,V=G*E*R+M*R,D=E-U,Ft=0;Ft<Wt;Ft++){if(Wt>1&&(ce=new d(A.pixels.resultPixels.buffer,E*_*Ft*C,E*_)),k=h.byteLength-A.ptr,X=new DataView(h,A.ptr,Math.min(10,k)),tt={},j=0,y=X.getUint8(0),j++,c=y>>6&255,g=y>>2&15,g!==(M*R>>3&15))throw"integrity issue";if(Yt=y&3,Yt>3)throw A.ptr+=j,"Invalid block encoding ("+Yt+")";if(Yt===2){A.counter.constant++,A.ptr+=j;continue}else if(Yt===0){if(A.counter.uncompressed++,A.ptr+=j,w=Q*U*C,x=h.byteLength-A.ptr,w=w<x?w:x,B=new ArrayBuffer(w%C===0?w:w+C-w%C),It=new Uint8Array(B),It.set(new Uint8Array(h,A.ptr,w)),gt=new d(B),H=0,ee)for(F=0;F<Q;F++){for(b=0;b<U;b++)ee[V]&&(ce[V]=gt[H++]),V++;V+=D}else for(F=0;F<Q;F++){for(b=0;b<U;b++)ce[V++]=gt[H++];V+=D}A.ptr+=H*C}else if(kt=o.getDataTypeUsed(I,c),Jt=o.getOnePixel(tt,j,kt,X),j+=o.getDataTypeSize(kt),Yt===3)if(A.ptr+=j,A.counter.constantoffset++,ee)for(F=0;F<Q;F++){for(b=0;b<U;b++)ee[V]&&(ce[V]=Jt),V++;V+=D}else for(F=0;F<Q;F++){for(b=0;b<U;b++)ce[V++]=Jt;V+=D}else if(A.ptr+=j,o.decodeBits(h,A,Mt,Jt,Ft),j=0,ee)for(F=0;F<Q;F++){for(b=0;b<U;b++)ee[V]&&(ce[V]=Mt[j++]),V++;V+=D}else for(F=0;F<Q;F++){for(b=0;b<U;b++)ce[V++]=Mt[j++];V+=D}}},formatFileInfo:function(h){return{fileIdentifierString:h.headerInfo.fileIdentifierString,fileVersion:h.headerInfo.fileVersion,imageType:h.headerInfo.imageType,height:h.headerInfo.height,width:h.headerInfo.width,numValidPixel:h.headerInfo.numValidPixel,microBlockSize:h.headerInfo.microBlockSize,blobSize:h.headerInfo.blobSize,maxZError:h.headerInfo.maxZError,pixelType:o.getPixelType(h.headerInfo.imageType),eofOffset:h.eofOffset,mask:h.mask?{numBytes:h.mask.numBytes}:null,pixels:{numBlocksX:h.pixels.numBlocksX,numBlocksY:h.pixels.numBlocksY,maxValue:h.headerInfo.zMax,minValue:h.headerInfo.zMin,noDataValue:h.noDataValue}}},constructConstantSurface:function(h){var A=h.headerInfo.zMax,d=h.headerInfo.numDims,f=h.headerInfo.height*h.headerInfo.width,E=f*d,_=0,R=0,I=0,C=h.pixels.resultMask;if(C)if(d>1)for(_=0;_<d;_++)for(I=_*f,R=0;R<f;R++)C[R]&&(h.pixels.resultPixels[I+R]=A);else for(R=0;R<f;R++)C[R]&&(h.pixels.resultPixels[R]=A);else if(h.pixels.resultPixels.fill)h.pixels.resultPixels.fill(A);else for(R=0;R<E;R++)h.pixels.resultPixels[R]=A},getDataTypeArray:function(h){var A;switch(h){case 0:A=Int8Array;break;case 1:A=Uint8Array;break;case 2:A=Int16Array;break;case 3:A=Uint16Array;break;case 4:A=Int32Array;break;case 5:A=Uint32Array;break;case 6:A=Float32Array;break;case 7:A=Float64Array;break;default:A=Float32Array}return A},getPixelType:function(h){var A;switch(h){case 0:A="S8";break;case 1:A="U8";break;case 2:A="S16";break;case 3:A="U16";break;case 4:A="S32";break;case 5:A="U32";break;case 6:A="F32";break;case 7:A="F64";break;default:A="F32"}return A},isValidPixelValue:function(h,A){if(A==null)return!1;var d;switch(h){case 0:d=A>=-128&&A<=127;break;case 1:d=A>=0&&A<=255;break;case 2:d=A>=-32768&&A<=32767;break;case 3:d=A>=0&&A<=65536;break;case 4:d=A>=-2147483648&&A<=2147483647;break;case 5:d=A>=0&&A<=4294967296;break;case 6:d=A>=-34027999387901484e22&&A<=34027999387901484e22;break;case 7:d=A>=5e-324&&A<=17976931348623157e292;break;default:d=!1}return d},getDataTypeSize:function(h){var A=0;switch(h){case 0:case 1:A=1;break;case 2:case 3:A=2;break;case 4:case 5:case 6:A=4;break;case 7:A=8;break;default:A=h}return A},getDataTypeUsed:function(h,A){var d=h;switch(h){case 2:case 4:d=h-A;break;case 3:case 5:d=h-2*A;break;case 6:A===0?d=h:A===1?d=2:d=1;break;case 7:A===0?d=h:d=h-2*A+1;break;default:d=h;break}return d},getOnePixel:function(h,A,d,f){var E=0;switch(d){case 0:E=f.getInt8(A);break;case 1:E=f.getUint8(A);break;case 2:E=f.getInt16(A,!0);break;case 3:E=f.getUint16(A,!0);break;case 4:E=f.getInt32(A,!0);break;case 5:E=f.getUInt32(A,!0);break;case 6:E=f.getFloat32(A,!0);break;case 7:E=f.getFloat64(A,!0);break;default:throw"the decoder does not understand this pixel type"}return E}},r=function(h,A,d){this.val=h,this.left=A,this.right=d},a={decode:function(h,A){A=A||{};var d=A.noDataValue,f=0,E={};if(E.ptr=A.inputOffset||0,E.pixels={},!!o.readHeaderInfo(h,E)){var _=E.headerInfo,R=_.fileVersion,I=o.getDataTypeArray(_.imageType);o.readMask(h,E),_.numValidPixel!==_.width*_.height&&!E.pixels.resultMask&&(E.pixels.resultMask=A.maskData);var C=_.width*_.height;if(E.pixels.resultPixels=new I(C*_.numDims),E.counter={onesweep:0,uncompressed:0,lut:0,bitstuffer:0,constant:0,constantoffset:0},_.numValidPixel!==0)if(_.zMax===_.zMin)o.constructConstantSurface(E);else if(R>=4&&o.checkMinMaxRanges(h,E))o.constructConstantSurface(E);else{var N=new DataView(h,E.ptr,2),T=N.getUint8(0);if(E.ptr++,T)o.readDataOneSweep(h,E,I);else if(R>1&&_.imageType<=1&&Math.abs(_.maxZError-.5)<1e-5){var F=N.getUint8(1);if(E.ptr++,E.encodeMode=F,F>2||R<4&&F>1)throw"Invalid Huffman flag "+F;F?o.readHuffman(h,E,I):o.readTiles(h,E,I)}else o.readTiles(h,E,I)}E.eofOffset=E.ptr;var b;A.inputOffset?(b=E.headerInfo.blobSize+A.inputOffset-E.ptr,Math.abs(b)>=1&&(E.eofOffset=A.inputOffset+E.headerInfo.blobSize)):(b=E.headerInfo.blobSize-E.ptr,Math.abs(b)>=1&&(E.eofOffset=E.headerInfo.blobSize));var G={width:_.width,height:_.height,pixelData:E.pixels.resultPixels,minValue:_.zMin,maxValue:_.zMax,validPixelCount:_.numValidPixel,dimCount:_.numDims,dimStats:{minValues:_.minValues,maxValues:_.maxValues},maskData:E.pixels.resultMask};if(E.pixels.resultMask&&o.isValidPixelValue(_.imageType,d)){var M=E.pixels.resultMask;for(f=0;f<C;f++)M[f]||(G.pixelData[f]=d);G.noDataValue=d}return E.noDataValue=d,A.returnFileInfo&&(G.fileInfo=o.formatFileInfo(E)),G}},getBandCount:function(h){var A=0,d=0,f={};for(f.ptr=0,f.pixels={};d<h.byteLength-58;)o.readHeaderInfo(h,f),d+=f.headerInfo.blobSize,A++,f.ptr=d;return A}};return a}(),i=function(){var s=new ArrayBuffer(4),o=new Uint8Array(s),r=new Uint32Array(s);return r[0]=1,o[0]===1}(),n={decode:function(s,o){if(!i)throw"Big endian system is not supported.";o=o||{};var r=o.inputOffset||0,a=new Uint8Array(s,r,10),h=String.fromCharCode.apply(null,a),A,d;if(h.trim()==="CntZImage")A=t,d=1;else if(h.substring(0,5)==="Lerc2")A=e,d=2;else throw"Unexpected file identifier string: "+h;for(var f=0,E=s.byteLength-10,_,R=[],I,C,N={width:0,height:0,pixels:[],pixelType:o.pixelType,mask:null,statistics:[]};r<E;){var T=A.decode(s,{inputOffset:r,encodedMaskData:_,maskData:C,returnMask:f===0,returnEncodedMask:f===0,returnFileInfo:!0,pixelType:o.pixelType||null,noDataValue:o.noDataValue||null});r=T.fileInfo.eofOffset,f===0&&(_=T.encodedMaskData,C=T.maskData,N.width=T.width,N.height=T.height,N.dimCount=T.dimCount||1,N.pixelType=T.pixelType||T.fileInfo.pixelType,N.mask=T.maskData),d>1&&T.fileInfo.mask&&T.fileInfo.mask.numBytes>0&&R.push(T.maskData),f++,N.pixels.push(T.pixelData),N.statistics.push({minValue:T.minValue,maxValue:T.maxValue,noDataValue:T.noDataValue,dimStats:T.dimStats})}var F,b,G;if(d>1&&R.length>1){for(G=N.width*N.height,N.bandMasks=R,C=new Uint8Array(G),C.set(R[0]),F=1;F<R.length;F++)for(I=R[F],b=0;b<G;b++)C[b]=C[b]&I[b];N.maskData=C}return N}};typeof define=="function"&&define.amd?define([],function(){return n}):typeof Fg<"u"&&Fg.exports?Fg.exports=n:this.Lerc=n})()});var kG={};He(kG,{default:()=>E_t});function f_t(t,e){if(t.encoding===q6.LERC){let s;try{s=nK.default.decode(t.heightmap)}catch(r){throw new ke(r)}if(s.statistics[0].minValue===Number.MAX_VALUE)throw new ke("Invalid tile data");t.heightmap=s.pixels[0],t.width=s.width,t.height=s.height}t.ellipsoid=ot.clone(t.ellipsoid),t.rectangle=Xt.clone(t.rectangle);let i=tK.computeVertices(t),n=i.vertices;return e.push(n.buffer),{vertices:n.buffer,numberOfAttributes:i.encoding.stride,minimumHeight:i.minimumHeight,maximumHeight:i.maximumHeight,gridWidth:t.width,gridHeight:t.height,boundingSphere3D:i.boundingSphere3D,orientedBoundingBox:i.orientedBoundingBox,occludeePointInScaledSpace:i.occludeePointInScaledSpace,encoding:i.encoding,westIndicesSouthToNorth:i.westIndicesSouthToNorth,southIndicesEastToWest:i.southIndicesEastToWest,eastIndicesNorthToSouth:i.eastIndicesNorthToSouth,northIndicesWestToEast:i.northIndicesWestToEast}}var nK,E_t,LG=O(()=>{Ve();$6();eK();pn();Ps();nK=co(iK(),1);Ns();E_t=Wi(f_t)});function xo(){Y.throwInstantiationError()}function aK(t,e){let i=new Array(e),n=new Array(t),s=new Array(e),o=new Array(t),r;for(r=0;r<t;++r)o[r]=r,n[r]=t*e-1-r;for(r=0;r<e;++r)s[r]=(r+1)*t-1,i[r]=(e-r-1)*t;return{westIndicesSouthToNorth:i,southIndicesEastToWest:n,eastIndicesNorthToSouth:s,northIndicesWestToEast:o}}function AK(t,e,i,n){let s=0;for(let o=0;o<e-1;++o){for(let r=0;r<t-1;++r){let a=s,h=a+t,A=h+1,d=a+1;i[n++]=a,i[n++]=h,i[n++]=d,i[n++]=d,i[n++]=h,i[n++]=A,++s}++s}}function Yg(t,e,i,n){let s=t[0],o=t.length;for(let r=1;r<o;++r){let a=t[r];i[n++]=s,i[n++]=a,i[n++]=e,i[n++]=e,i[n++]=a,i[n++]=e+1,s=a,++e}return n}var sK,oK,rK,hK,cK=O(()=>{mt();Vt();Di();_e();Object.defineProperties(xo.prototype,{errorEvent:{get:Y.throwInstantiationError},credit:{get:Y.throwInstantiationError},tilingScheme:{get:Y.throwInstantiationError},hasWaterMask:{get:Y.throwInstantiationError},hasVertexNormals:{get:Y.throwInstantiationError},availability:{get:Y.throwInstantiationError}});sK=[];xo.getRegularGridIndices=function(t,e){if(t*e>=L.FOUR_GIGABYTES)throw new Y("The total number of vertices (width * height) must be less than 4,294,967,296.");let i=sK[t];m(i)||(sK[t]=i=[]);let n=i[e];return m(n)||(t*e<L.SIXTY_FOUR_KILOBYTES?n=i[e]=new Uint16Array((t-1)*(e-1)*6):n=i[e]=new Uint32Array((t-1)*(e-1)*6),AK(t,e,n,0)),n};oK=[];xo.getRegularGridIndicesAndEdgeIndices=function(t,e){if(t*e>=L.FOUR_GIGABYTES)throw new Y("The total number of vertices (width * height) must be less than 4,294,967,296.");let i=oK[t];m(i)||(oK[t]=i=[]);let n=i[e];if(!m(n)){let s=xo.getRegularGridIndices(t,e),o=aK(t,e),r=o.westIndicesSouthToNorth,a=o.southIndicesEastToWest,h=o.eastIndicesNorthToSouth,A=o.northIndicesWestToEast;n=i[e]={indices:s,westIndicesSouthToNorth:r,southIndicesEastToWest:a,eastIndicesNorthToSouth:h,northIndicesWestToEast:A}}return n};rK=[];xo.getRegularGridAndSkirtIndicesAndEdgeIndices=function(t,e){if(t*e>=L.FOUR_GIGABYTES)throw new Y("The total number of vertices (width * height) must be less than 4,294,967,296.");let i=rK[t];m(i)||(rK[t]=i=[]);let n=i[e];if(!m(n)){let s=t*e,o=(t-1)*(e-1)*6,r=t*2+e*2,a=Math.max(0,r-4)*6,h=s+r,A=o+a,d=aK(t,e),f=d.westIndicesSouthToNorth,E=d.southIndicesEastToWest,_=d.eastIndicesNorthToSouth,R=d.northIndicesWestToEast,I=te.createTypedArray(h,A);AK(t,e,I,0),xo.addSkirtIndices(f,E,_,R,s,I,o),n=i[e]={indices:I,westIndicesSouthToNorth:f,southIndicesEastToWest:E,eastIndicesNorthToSouth:_,northIndicesWestToEast:R,indexCountWithoutSkirts:o}}return n};xo.addSkirtIndices=function(t,e,i,n,s,o,r){let a=s;r=Yg(t,a,o,r),a+=t.length,r=Yg(e,a,o,r),a+=e.length,r=Yg(i,a,o,r),a+=i.length,Yg(n,a,o,r)};xo.heightmapTerrainQuality=.25;xo.getEstimatedLevelZeroGeometricErrorForAHeightmap=function(t,e,i){return t.maximumRadius*2*Math.PI*xo.heightmapTerrainQuality/(e*i)};xo.prototype.requestTileGeometry=Y.throwInstantiationError;xo.prototype.getLevelMaximumGeometricError=Y.throwInstantiationError;xo.prototype.getTileDataAvailable=Y.throwInstantiationError;xo.prototype.loadTileDataAvailability=Y.throwInstantiationError;hK=xo});var wG={};He(wG,{default:()=>I_t});function Z_t(t,e){let i=t.quantizedVertices,n=i.length/3,s=t.octEncodedNormals,o=t.westIndices.length+t.eastIndices.length+t.southIndices.length+t.northIndices.length,r=t.includeWebMercatorT,a=t.exaggeration,h=t.exaggerationRelativeHeight,d=a!==1,f=Xt.clone(t.rectangle),E=f.west,_=f.south,R=f.east,I=f.north,C=ot.clone(t.ellipsoid),N=t.minimumHeight,T=t.maximumHeight,F=t.relativeToCenter,b=In.eastNorthUpToFixedFrame(F,C),G=at.inverseTransformation(b,new at),M,Q;r&&(M=ks.geodeticLatitudeToMercatorAngle(_),Q=1/(ks.geodeticLatitudeToMercatorAngle(I)-M));let U=i.subarray(0,n),k=i.subarray(n,2*n),y=i.subarray(n*2,3*n),c=m(s),g=new Array(n),V=new Array(n),D=new Array(n),w=r?new Array(n):[],x=d?new Array(n):[],H=__t;H.x=Number.POSITIVE_INFINITY,H.y=Number.POSITIVE_INFINITY,H.z=Number.POSITIVE_INFINITY;let j=R_t;j.x=Number.NEGATIVE_INFINITY,j.y=Number.NEGATIVE_INFINITY,j.z=Number.NEGATIVE_INFINITY;let X=Number.POSITIVE_INFINITY,tt=Number.NEGATIVE_INFINITY,B=Number.POSITIVE_INFINITY,It=Number.NEGATIVE_INFINITY;for(let Ye=0;Ye<n;++Ye){let Bi=U[Ye],An=k[Ye],Ne=Bi/yG,ei=An/yG,_n=L.lerp(N,T,y[Ye]/yG);Ys.longitude=L.lerp(E,R,Ne),Ys.latitude=L.lerp(_,I,ei),Ys.height=_n,X=Math.min(Ys.longitude,X),tt=Math.max(Ys.longitude,tt),B=Math.min(Ys.latitude,B),It=Math.max(Ys.latitude,It);let hs=C.cartographicToCartesian(Ys);g[Ye]=new nt(Ne,ei),V[Ye]=_n,D[Ye]=hs,r&&(w[Ye]=(ks.geodeticLatitudeToMercatorAngle(Ys.latitude)-M)*Q),d&&(x[Ye]=C.geodeticSurfaceNormal(hs)),at.multiplyByPoint(G,hs,MR),l.minimumByComponent(MR,H,H),l.maximumByComponent(MR,j,j)}let gt=Vg(t.westIndices,function(Ye,Bi){return g[Ye].y-g[Bi].y}),Yt=Vg(t.eastIndices,function(Ye,Bi){return g[Bi].y-g[Ye].y}),Mt=Vg(t.southIndices,function(Ye,Bi){return g[Bi].x-g[Ye].x}),Ct=Vg(t.northIndices,function(Ye,Bi){return g[Ye].x-g[Bi].x}),zt;N<0&&(zt=new dA(C).computeHorizonCullingPointPossiblyUnderEllipsoid(F,D,N));let kt=N;kt=Math.min(kt,Sg(t.westIndices,t.westSkirtHeight,V,g,f,C,G,H,j)),kt=Math.min(kt,Sg(t.southIndices,t.southSkirtHeight,V,g,f,C,G,H,j)),kt=Math.min(kt,Sg(t.eastIndices,t.eastSkirtHeight,V,g,f,C,G,H,j)),kt=Math.min(kt,Sg(t.northIndices,t.northSkirtHeight,V,g,f,C,G,H,j));let Jt=new ph(H,j,F),Wt=new vc(F,Jt,kt,T,b,c,r,d,a,h),Ft=Wt.stride,ee=n*Ft+o*Ft,ce=new Float32Array(ee),je=0;for(let Ye=0;Ye<n;++Ye){if(c){let Bi=Ye*2;Kf.x=s[Bi],Kf.y=s[Bi+1]}je=Wt.encode(ce,je,D[Ye],g[Ye],V[Ye],Kf,w[Ye],x[Ye])}let Oe=Math.max(0,(o-4)*2),Me=t.indices.length+Oe*3,Ue=te.createTypedArray(n+o,Me);Ue.set(t.indices,0);let Ce=1e-4,be=(tt-X)*Ce,ni=(It-B)*Ce,ze=-be,Ge=0,Ui=be,Ri=0,si=0,qe=ni,Vi=0,gn=-ni,De=n*Ft;return Og(ce,De,gt,Wt,V,g,s,C,f,t.westSkirtHeight,M,Q,ze,Ge),De+=t.westIndices.length*Ft,Og(ce,De,Mt,Wt,V,g,s,C,f,t.southSkirtHeight,M,Q,Vi,gn),De+=t.southIndices.length*Ft,Og(ce,De,Yt,Wt,V,g,s,C,f,t.eastSkirtHeight,M,Q,Ui,Ri),De+=t.eastIndices.length*Ft,Og(ce,De,Ct,Wt,V,g,s,C,f,t.northSkirtHeight,M,Q,si,qe),hK.addSkirtIndices(gt,Mt,Yt,Ct,n,Ue,t.indices.length),e.push(ce.buffer,Ue.buffer),{vertices:ce.buffer,indices:Ue.buffer,westIndicesSouthToNorth:gt,southIndicesEastToWest:Mt,eastIndicesNorthToSouth:Yt,northIndicesWestToEast:Ct,vertexStride:Ft,center:F,minimumHeight:N,maximumHeight:T,occludeePointInScaledSpace:zt,encoding:Wt,indexCountWithoutSkirts:t.indices.length}}function Sg(t,e,i,n,s,o,r,a,h){let A=Number.POSITIVE_INFINITY,d=s.north,f=s.south,E=s.east,_=s.west;E<_&&(E+=L.TWO_PI);let R=t.length;for(let I=0;I<R;++I){let C=t[I],N=i[C],T=n[C];Ys.longitude=L.lerp(_,E,T.x),Ys.latitude=L.lerp(f,d,T.y),Ys.height=N-e;let F=o.cartographicToCartesian(Ys,MR);at.multiplyByPoint(r,F,F),l.minimumByComponent(F,a,a),l.maximumByComponent(F,h,h),A=Math.min(A,Ys.height)}return A}function Og(t,e,i,n,s,o,r,a,h,A,d,f,E,_){let R=m(r),I=h.north,C=h.south,N=h.east,T=h.west;N<T&&(N+=L.TWO_PI);let F=i.length;for(let b=0;b<F;++b){let G=i[b],M=s[G],Q=o[G];Ys.longitude=L.lerp(T,N,Q.x)+E,Ys.latitude=L.lerp(C,I,Q.y)+_,Ys.height=M-A;let U=a.cartographicToCartesian(Ys,MR);if(R){let c=G*2;Kf.x=r[c],Kf.y=r[c+1]}let k;n.hasWebMercatorT&&(k=(ks.geodeticLatitudeToMercatorAngle(Ys.latitude)-d)*f);let y;n.hasGeodeticSurfaceNormals&&(y=a.geodeticSurfaceNormal(U)),e=n.encode(t,e,U,Q,Ys.height,Kf,k,y)}}function Vg(t,e){let i;return typeof t.slice=="function"&&(i=t.slice(),typeof i.sort!="function"&&(i=void 0)),m(i)||(i=Array.prototype.slice.call(t)),i.sort(e),i}var yG,MR,__t,R_t,Ys,Kf,I_t,xG=O(()=>{a_();Xe();Ht();ri();mt();Ve();Sm();Di();_e();Fi();pn();WR();cK();fr();Ul();Ns();yG=32767,MR=new l,__t=new l,R_t=new l,Ys=new ut,Kf=new nt;I_t=Wi(Z_t)});function p_t(t,e){return L.equalsEpsilon(t.latitude,e.latitude,L.EPSILON10)&&L.equalsEpsilon(t.longitude,e.longitude,L.EPSILON10)}function g_t(t,e,i,n){e=Xn(e,l.equalsEpsilon);let s=e.length;if(s<2)return;let o=m(n),r=m(i),a=new Array(s),h=new Array(s),A=new Array(s),d=e[0];a[0]=d;let f=t.cartesianToCartographic(d,u_t);r&&(f.height=i[0]),h[0]=f.height,o?A[0]=n[0]:A[0]=0;let E=h[0],_=A[0],R=E===_,I=1;for(let C=1;C<s;++C){let N=e[C],T=t.cartesianToCartographic(N,C_t);r&&(T.height=i[C]),R=R&&T.height===0,p_t(f,T)?f.height<T.height&&(h[I-1]=T.height):(a[I]=N,h[I]=T.height,o?A[I]=n[C]:A[I]=0,R=R&&h[I]===A[I],ut.clone(T,f),++I)}if(!(R||I<2))return a.length=I,h.length=I,A.length=I,{positions:a,topHeights:h,bottomHeights:A}}var lK,u_t,C_t,T_t,N_t,b_t,Gg,PG=O(()=>{Oa();Ht();ri();mt();_e();Of();lK={};u_t=new ut,C_t=new ut;T_t=new Array(2),N_t=new Array(2),b_t={positions:void 0,height:void 0,granularity:void 0,ellipsoid:void 0};lK.computePositions=function(t,e,i,n,s,o){let r=g_t(t,e,i,n);if(!m(r))return;e=r.positions,i=r.topHeights,n=r.bottomHeights;let a=e.length,h=a-2,A,d,f=L.chordLength(s,t.maximumRadius),E=b_t;if(E.minDistance=f,E.ellipsoid=t,o){let _=0,R;for(R=0;R<a-1;R++)_+=On.numberOfPoints(e[R],e[R+1],f)+1;A=new Float64Array(_*3),d=new Float64Array(_*3);let I=T_t,C=N_t;E.positions=I,E.height=C;let N=0;for(R=0;R<a-1;R++){I[0]=e[R],I[1]=e[R+1],C[0]=i[R],C[1]=i[R+1];let T=On.generateArc(E);A.set(T,N),C[0]=n[R],C[1]=n[R+1],d.set(On.generateArc(E),N),N+=T.length}}else E.positions=e,E.height=i,A=new Float64Array(On.generateArc(E)),E.height=n,d=new Float64Array(On.generateArc(E));return{bottomPositions:d,topPositions:A,numCorners:h}};Gg=lK});function gd(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.maximumHeights,n=t.minimumHeights;if(!m(e))throw new Y("options.positions is required.");if(m(i)&&i.length!==e.length)throw new Y("options.positions and options.maximumHeights must have the same length.");if(m(n)&&n.length!==e.length)throw new Y("options.positions and options.minimumHeights must have the same length.");let s=Z(t.vertexFormat,Ot.DEFAULT),o=Z(t.granularity,L.RADIANS_PER_DEGREE),r=Z(t.ellipsoid,ot.WGS84);this._positions=e,this._minimumHeights=n,this._maximumHeights=i,this._vertexFormat=Ot.clone(s),this._granularity=o,this._ellipsoid=ot.clone(r),this._workerName="createWallGeometry";let a=1+e.length*l.packedLength+2;m(n)&&(a+=n.length),m(i)&&(a+=i.length),this.packedLength=a+ot.packedLength+Ot.packedLength+1}var JG,Bg,F_t,dK,Y_t,S_t,O_t,mK,fK,UR,jG,EK=O(()=>{_i();Ht();oi();bt();mt();Vt();Ve();yi();ji();En();Di();_e();Xi();Ls();PG();JG=new l,Bg=new l,F_t=new l,dK=new l,Y_t=new l,S_t=new l,O_t=new l;gd.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._minimumHeights;if(o=m(r)?r.length:0,e[i++]=o,m(r))for(n=0;n<o;++n)e[i++]=r[n];let a=t._maximumHeights;if(o=m(a)?a.length:0,e[i++]=o,m(a))for(n=0;n<o;++n)e[i++]=a[n];return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,Ot.pack(t._vertexFormat,e,i),i+=Ot.packedLength,e[i]=t._granularity,e};mK=ot.clone(ot.UNIT_SPHERE),fK=new Ot,UR={positions:void 0,minimumHeights:void 0,maximumHeights:void 0,ellipsoid:mK,vertexFormat:fK,granularity:void 0};gd.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r;if(s>0)for(r=new Array(s),n=0;n<s;++n)r[n]=t[e++];s=t[e++];let a;if(s>0)for(a=new Array(s),n=0;n<s;++n)a[n]=t[e++];let h=ot.unpack(t,e,mK);e+=ot.packedLength;let A=Ot.unpack(t,e,fK);e+=Ot.packedLength;let d=t[e];return m(i)?(i._positions=o,i._minimumHeights=r,i._maximumHeights=a,i._ellipsoid=ot.clone(h,i._ellipsoid),i._vertexFormat=Ot.clone(A,i._vertexFormat),i._granularity=d,i):(UR.positions=o,UR.minimumHeights=r,UR.maximumHeights=a,UR.granularity=d,new gd(UR))};gd.fromConstantHeights=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions;if(!m(e))throw new Y("options.positions is required.");let i,n,s=t.minimumHeight,o=t.maximumHeight,r=m(s),a=m(o);if(r||a){let A=e.length;i=r?new Array(A):void 0,n=a?new Array(A):void 0;for(let d=0;d<A;++d)r&&(i[d]=s),a&&(n[d]=o)}let h={positions:e,maximumHeights:n,minimumHeights:i,ellipsoid:t.ellipsoid,vertexFormat:t.vertexFormat};return new gd(h)};gd.createGeometry=function(t){let e=t._positions,i=t._minimumHeights,n=t._maximumHeights,s=t._vertexFormat,o=t._granularity,r=t._ellipsoid,a=Gg.computePositions(r,e,n,i,o,!0);if(!m(a))return;let h=a.bottomPositions,A=a.topPositions,d=a.numCorners,f=A.length,E=f*2,_=s.position?new Float64Array(E):void 0,R=s.normal?new Float32Array(E):void 0,I=s.tangent?new Float32Array(E):void 0,C=s.bitangent?new Float32Array(E):void 0,N=s.st?new Float32Array(E/3*2):void 0,T=0,F=0,b=0,G=0,M=0,Q=O_t,U=S_t,k=Y_t,y=!0;f/=3;let c,g=0,V=1/(f-d-1);for(c=0;c<f;++c){let j=c*3,X=l.fromArray(A,j,JG),tt=l.fromArray(h,j,Bg);if(s.position&&(_[T++]=tt.x,_[T++]=tt.y,_[T++]=tt.z,_[T++]=X.x,_[T++]=X.y,_[T++]=X.z),s.st&&(N[M++]=g,N[M++]=0,N[M++]=g,N[M++]=1),s.normal||s.tangent||s.bitangent){let B=l.clone(l.ZERO,dK),It=l.subtract(X,r.geodeticSurfaceNormal(X,Bg),Bg);if(c+1<f&&(B=l.fromArray(A,j+3,dK)),y){let gt=l.subtract(B,X,F_t),Yt=l.subtract(It,X,JG);Q=l.normalize(l.cross(Yt,gt,Q),Q),y=!1}l.equalsEpsilon(X,B,L.EPSILON10)?y=!0:(g+=V,s.tangent&&(U=l.normalize(l.subtract(B,X,U),U)),s.bitangent&&(k=l.normalize(l.cross(Q,U,k),k))),s.normal&&(R[F++]=Q.x,R[F++]=Q.y,R[F++]=Q.z,R[F++]=Q.x,R[F++]=Q.y,R[F++]=Q.z),s.tangent&&(I[G++]=U.x,I[G++]=U.y,I[G++]=U.z,I[G++]=U.x,I[G++]=U.y,I[G++]=U.z),s.bitangent&&(C[b++]=k.x,C[b++]=k.y,C[b++]=k.z,C[b++]=k.x,C[b++]=k.y,C[b++]=k.z)}}let D=new we;s.position&&(D.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:_})),s.normal&&(D.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:R})),s.tangent&&(D.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:I})),s.bitangent&&(D.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:C})),s.st&&(D.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:N}));let w=E/3;E-=6*(d+1);let x=te.createTypedArray(w,E),H=0;for(c=0;c<w-2;c+=2){let j=c,X=c+2,tt=l.fromArray(_,j*3,JG),B=l.fromArray(_,X*3,Bg);if(l.equalsEpsilon(tt,B,L.EPSILON10))continue;let It=c+1,gt=c+3;x[H++]=It,x[H++]=j,x[H++]=gt,x[H++]=gt,x[H++]=j,x[H++]=X}return new se({attributes:D,indices:x,primitiveType:ne.TRIANGLES,boundingSphere:new Nt.fromVertices(_)})};jG=gd});var HG={};He(HG,{default:()=>G_t});function V_t(t,e){return m(e)&&(t=jG.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),jG.createGeometry(t)}var G_t,vG=O(()=>{mt();Ve();EK();G_t=V_t});function Td(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.maximumHeights,n=t.minimumHeights;if(!m(e))throw new Y("options.positions is required.");if(m(i)&&i.length!==e.length)throw new Y("options.positions and options.maximumHeights must have the same length.");if(m(n)&&n.length!==e.length)throw new Y("options.positions and options.minimumHeights must have the same length.");let s=Z(t.granularity,L.RADIANS_PER_DEGREE),o=Z(t.ellipsoid,ot.WGS84);this._positions=e,this._minimumHeights=n,this._maximumHeights=i,this._granularity=s,this._ellipsoid=ot.clone(o),this._workerName="createWallOutlineGeometry";let r=1+e.length*l.packedLength+2;m(n)&&(r+=n.length),m(i)&&(r+=i.length),this.packedLength=r+ot.packedLength+1}var _K,RK,ZK,QR,zG,IK=O(()=>{_i();Ht();oi();bt();mt();Vt();Ve();yi();ji();En();Di();_e();Xi();PG();_K=new l,RK=new l;Td.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._minimumHeights;if(o=m(r)?r.length:0,e[i++]=o,m(r))for(n=0;n<o;++n)e[i++]=r[n];let a=t._maximumHeights;if(o=m(a)?a.length:0,e[i++]=o,m(a))for(n=0;n<o;++n)e[i++]=a[n];return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i]=t._granularity,e};ZK=ot.clone(ot.UNIT_SPHERE),QR={positions:void 0,minimumHeights:void 0,maximumHeights:void 0,ellipsoid:ZK,granularity:void 0};Td.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r;if(s>0)for(r=new Array(s),n=0;n<s;++n)r[n]=t[e++];s=t[e++];let a;if(s>0)for(a=new Array(s),n=0;n<s;++n)a[n]=t[e++];let h=ot.unpack(t,e,ZK);e+=ot.packedLength;let A=t[e];return m(i)?(i._positions=o,i._minimumHeights=r,i._maximumHeights=a,i._ellipsoid=ot.clone(h,i._ellipsoid),i._granularity=A,i):(QR.positions=o,QR.minimumHeights=r,QR.maximumHeights=a,QR.granularity=A,new Td(QR))};Td.fromConstantHeights=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions;if(!m(e))throw new Y("options.positions is required.");let i,n,s=t.minimumHeight,o=t.maximumHeight,r=m(s),a=m(o);if(r||a){let A=e.length;i=r?new Array(A):void 0,n=a?new Array(A):void 0;for(let d=0;d<A;++d)r&&(i[d]=s),a&&(n[d]=o)}let h={positions:e,maximumHeights:n,minimumHeights:i,ellipsoid:t.ellipsoid};return new Td(h)};Td.createGeometry=function(t){let e=t._positions,i=t._minimumHeights,n=t._maximumHeights,s=t._granularity,o=t._ellipsoid,r=Gg.computePositions(o,e,n,i,s,!1);if(!m(r))return;let a=r.bottomPositions,h=r.topPositions,A=h.length,d=A*2,f=new Float64Array(d),E=0;A/=3;let _;for(_=0;_<A;++_){let T=_*3,F=l.fromArray(h,T,_K),b=l.fromArray(a,T,RK);f[E++]=b.x,f[E++]=b.y,f[E++]=b.z,f[E++]=F.x,f[E++]=F.y,f[E++]=F.z}let R=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:f})}),I=d/3;d=2*I-4+I;let C=te.createTypedArray(I,d),N=0;for(_=0;_<I-2;_+=2){let T=_,F=_+2,b=l.fromArray(f,T*3,_K),G=l.fromArray(f,F*3,RK);if(l.equalsEpsilon(b,G,L.EPSILON10))continue;let M=_+1,Q=_+3;C[N++]=M,C[N++]=T,C[N++]=M,C[N++]=Q,C[N++]=T,C[N++]=F}return C[N++]=I-2,C[N++]=I-1,new se({attributes:R,indices:C,primitiveType:ne.LINES,boundingSphere:new Nt.fromVertices(f)})};zG=Td});var KG={};He(KG,{default:()=>W_t});function B_t(t,e){return m(e)&&(t=zG.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),zG.createGeometry(t)}var W_t,XG=O(()=>{mt();Ve();IK();W_t=B_t});var tB=ts((kR,$G)=>{var he=he||{};he.scope={};he.arrayIteratorImpl=function(t){var e=0;return function(){return e<t.length?{done:!1,value:t[e++]}:{done:!0}}};he.arrayIterator=function(t){return{next:he.arrayIteratorImpl(t)}};he.makeIterator=function(t){var e=typeof Symbol<"u"&&Symbol.iterator&&t[Symbol.iterator];return e?e.call(t):he.arrayIterator(t)};he.ASSUME_ES5=!1;he.ASSUME_NO_NATIVE_MAP=!1;he.ASSUME_NO_NATIVE_SET=!1;he.SIMPLE_FROUND_POLYFILL=!1;he.ISOLATE_POLYFILLS=!1;he.FORCE_POLYFILL_PROMISE=!1;he.FORCE_POLYFILL_PROMISE_WHEN_NO_UNHANDLED_REJECTION=!1;he.getGlobal=function(t){t=[typeof globalThis=="object"&&globalThis,t,typeof window=="object"&&window,typeof self=="object"&&self,typeof global=="object"&&global];for(var e=0;e<t.length;++e){var i=t[e];if(i&&i.Math==Math)return i}throw Error("Cannot find global object")};he.global=he.getGlobal(kR);he.defineProperty=he.ASSUME_ES5||typeof Object.defineProperties=="function"?Object.defineProperty:function(t,e,i){return t==Array.prototype||t==Object.prototype||(t[e]=i.value),t};he.IS_SYMBOL_NATIVE=typeof Symbol=="function"&&typeof Symbol("x")=="symbol";he.TRUST_ES6_POLYFILLS=!he.ISOLATE_POLYFILLS||he.IS_SYMBOL_NATIVE;he.polyfills={};he.propertyToPolyfillSymbol={};he.POLYFILL_PREFIX="$jscp$";he.polyfill=function(t,e,i,n){e&&(he.ISOLATE_POLYFILLS?he.polyfillIsolated(t,e,i,n):he.polyfillUnisolated(t,e,i,n))};he.polyfillUnisolated=function(t,e,i,n){for(i=he.global,t=t.split("."),n=0;n<t.length-1;n++){var s=t[n];if(!(s in i))return;i=i[s]}t=t[t.length-1],n=i[t],e=e(n),e!=n&&e!=null&&he.defineProperty(i,t,{configurable:!0,writable:!0,value:e})};he.polyfillIsolated=function(t,e,i,n){var s=t.split(".");t=s.length===1,n=s[0],n=!t&&n in he.polyfills?he.polyfills:he.global;for(var o=0;o<s.length-1;o++){var r=s[o];if(!(r in n))return;n=n[r]}s=s[s.length-1],i=he.IS_SYMBOL_NATIVE&&i==="es6"?n[s]:null,e=e(i),e!=null&&(t?he.defineProperty(he.polyfills,s,{configurable:!0,writable:!0,value:e}):e!==i&&(he.propertyToPolyfillSymbol[s]===void 0&&(i=1e9*Math.random()>>>0,he.propertyToPolyfillSymbol[s]=he.IS_SYMBOL_NATIVE?he.global.Symbol(s):he.POLYFILL_PREFIX+i+"$"+s),he.defineProperty(n,he.propertyToPolyfillSymbol[s],{configurable:!0,writable:!0,value:e})))};he.polyfill("Promise",function(t){function e(){this.batch_=null}function i(r){return r instanceof s?r:new s(function(a,h){a(r)})}if(t&&(!(he.FORCE_POLYFILL_PROMISE||he.FORCE_POLYFILL_PROMISE_WHEN_NO_UNHANDLED_REJECTION&&typeof he.global.PromiseRejectionEvent>"u")||!he.global.Promise||he.global.Promise.toString().indexOf("[native code]")===-1))return t;e.prototype.asyncExecute=function(r){if(this.batch_==null){this.batch_=[];var a=this;this.asyncExecuteFunction(function(){a.executeBatch_()})}this.batch_.push(r)};var n=he.global.setTimeout;e.prototype.asyncExecuteFunction=function(r){n(r,0)},e.prototype.executeBatch_=function(){for(;this.batch_&&this.batch_.length;){var r=this.batch_;this.batch_=[];for(var a=0;a<r.length;++a){var h=r[a];r[a]=null;try{h()}catch(A){this.asyncThrow_(A)}}}this.batch_=null},e.prototype.asyncThrow_=function(r){this.asyncExecuteFunction(function(){throw r})};var s=function(r){this.state_=0,this.result_=void 0,this.onSettledCallbacks_=[],this.isRejectionHandled_=!1;var a=this.createResolveAndReject_();try{r(a.resolve,a.reject)}catch(h){a.reject(h)}};s.prototype.createResolveAndReject_=function(){function r(A){return function(d){h||(h=!0,A.call(a,d))}}var a=this,h=!1;return{resolve:r(this.resolveTo_),reject:r(this.reject_)}},s.prototype.resolveTo_=function(r){if(r===this)this.reject_(new TypeError("A Promise cannot resolve to itself"));else if(r instanceof s)this.settleSameAsPromise_(r);else{t:switch(typeof r){case"object":var a=r!=null;break t;case"function":a=!0;break t;default:a=!1}a?this.resolveToNonPromiseObj_(r):this.fulfill_(r)}},s.prototype.resolveToNonPromiseObj_=function(r){var a=void 0;try{a=r.then}catch(h){this.reject_(h);return}typeof a=="function"?this.settleSameAsThenable_(a,r):this.fulfill_(r)},s.prototype.reject_=function(r){this.settle_(2,r)},s.prototype.fulfill_=function(r){this.settle_(1,r)},s.prototype.settle_=function(r,a){if(this.state_!=0)throw Error("Cannot settle("+r+", "+a+"): Promise already settled in state"+this.state_);this.state_=r,this.result_=a,this.state_===2&&this.scheduleUnhandledRejectionCheck_(),this.executeOnSettledCallbacks_()},s.prototype.scheduleUnhandledRejectionCheck_=function(){var r=this;n(function(){if(r.notifyUnhandledRejection_()){var a=he.global.console;typeof a<"u"&&a.error(r.result_)}},1)},s.prototype.notifyUnhandledRejection_=function(){if(this.isRejectionHandled_)return!1;var r=he.global.CustomEvent,a=he.global.Event,h=he.global.dispatchEvent;return typeof h>"u"?!0:(typeof r=="function"?r=new r("unhandledrejection",{cancelable:!0}):typeof a=="function"?r=new a("unhandledrejection",{cancelable:!0}):(r=he.global.document.createEvent("CustomEvent"),r.initCustomEvent("unhandledrejection",!1,!0,r)),r.promise=this,r.reason=this.result_,h(r))},s.prototype.executeOnSettledCallbacks_=function(){if(this.onSettledCallbacks_!=null){for(var r=0;r<this.onSettledCallbacks_.length;++r)o.asyncExecute(this.onSettledCallbacks_[r]);this.onSettledCallbacks_=null}};var o=new e;return s.prototype.settleSameAsPromise_=function(r){var a=this.createResolveAndReject_();r.callWhenSettled_(a.resolve,a.reject)},s.prototype.settleSameAsThenable_=function(r,a){var h=this.createResolveAndReject_();try{r.call(a,h.resolve,h.reject)}catch(A){h.reject(A)}},s.prototype.then=function(r,a){function h(E,_){return typeof E=="function"?function(R){try{A(E(R))}catch(I){d(I)}}:_}var A,d,f=new s(function(E,_){A=E,d=_});return this.callWhenSettled_(h(r,A),h(a,d)),f},s.prototype.catch=function(r){return this.then(void 0,r)},s.prototype.callWhenSettled_=function(r,a){function h(){switch(A.state_){case 1:r(A.result_);break;case 2:a(A.result_);break;default:throw Error("Unexpected state: "+A.state_)}}var A=this;this.onSettledCallbacks_==null?o.asyncExecute(h):this.onSettledCallbacks_.push(h),this.isRejectionHandled_=!0},s.resolve=i,s.reject=function(r){return new s(function(a,h){h(r)})},s.race=function(r){return new s(function(a,h){for(var A=he.makeIterator(r),d=A.next();!d.done;d=A.next())i(d.value).callWhenSettled_(a,h)})},s.all=function(r){var a=he.makeIterator(r),h=a.next();return h.done?i([]):new s(function(A,d){function f(R){return function(I){E[R]=I,_--,_==0&&A(E)}}var E=[],_=0;do E.push(void 0),_++,i(h.value).callWhenSettled_(f(E.length-1),d),h=a.next();while(!h.done)})},s},"es6","es3");he.owns=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)};he.assign=he.TRUST_ES6_POLYFILLS&&typeof Object.assign=="function"?Object.assign:function(t,e){for(var i=1;i<arguments.length;i++){var n=arguments[i];if(n)for(var s in n)he.owns(n,s)&&(t[s]=n[s])}return t};he.polyfill("Object.assign",function(t){return t||he.assign},"es6","es3");he.checkStringArgs=function(t,e,i){if(t==null)throw new TypeError("The 'this' value for String.prototype."+i+" must not be null or undefined");if(e instanceof RegExp)throw new TypeError("First argument to String.prototype."+i+" must not be a regular expression");return t+""};he.polyfill("String.prototype.startsWith",function(t){return t||function(e,i){var n=he.checkStringArgs(this,e,"startsWith");e+="";var s=n.length,o=e.length;i=Math.max(0,Math.min(i|0,n.length));for(var r=0;r<o&&i<s;)if(n[i++]!=e[r++])return!1;return r>=o}},"es6","es3");he.polyfill("Array.prototype.copyWithin",function(t){function e(i){return i=Number(i),i===1/0||i===-1/0?i:i|0}return t||function(i,n,s){var o=this.length;if(i=e(i),n=e(n),s=s===void 0?o:e(s),i=0>i?Math.max(o+i,0):Math.min(i,o),n=0>n?Math.max(o+n,0):Math.min(n,o),s=0>s?Math.max(o+s,0):Math.min(s,o),i<n)for(;n<s;)n in this?this[i++]=this[n++]:(delete this[i++],n++);else for(s=Math.min(s,o+n-i),i+=s-n;s>n;)--s in this?this[--i]=this[s]:delete this[--i];return this}},"es6","es3");he.typedArrayCopyWithin=function(t){return t||Array.prototype.copyWithin};he.polyfill("Int8Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Uint8Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Uint8ClampedArray.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Int16Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Uint16Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Int32Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Uint32Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Float32Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Float64Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");var qG=function(){var t=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename<"u"&&(t=t||__filename),function(e){function i(z){return B.locateFile?B.locateFile(z,Wt):Wt+z}function n(z,et,pt){var $t=et+pt;for(pt=et;z[pt]&&!(pt>=$t);)++pt;if(16<pt-et&&z.buffer&&ze)return ze.decode(z.subarray(et,pt));for($t="";et<pt;){var ve=z[et++];if(ve&128){var hi=z[et++]&63;if((ve&224)==192)$t+=String.fromCharCode((ve&31)<<6|hi);else{var _a=z[et++]&63;ve=(ve&240)==224?(ve&15)<<12|hi<<6|_a:(ve&7)<<18|hi<<12|_a<<6|z[et++]&63,65536>ve?$t+=String.fromCharCode(ve):(ve-=65536,$t+=String.fromCharCode(55296|ve>>10,56320|ve&1023))}}else $t+=String.fromCharCode(ve)}return $t}function s(z,et){return z?n(Ui,z,et):""}function o(){var z=be.buffer;B.HEAP8=Ge=new Int8Array(z),B.HEAP16=new Int16Array(z),B.HEAP32=Ri=new Int32Array(z),B.HEAPU8=Ui=new Uint8Array(z),B.HEAPU16=new Uint16Array(z),B.HEAPU32=si=new Uint32Array(z),B.HEAPF32=new Float32Array(z),B.HEAPF64=new Float64Array(z)}function r(z){throw B.onAbort&&B.onAbort(z),z="Aborted("+z+")",Ue(z),ni=!0,z=new WebAssembly.RuntimeError(z+". Build with -sASSERTIONS for more info."),gt(z),z}function a(z){try{if(z==Ne&&Ce)return new Uint8Array(Ce);if(je)return je(z);throw"both async and sync fetching of the wasm failed"}catch(et){r(et)}}function h(){if(!Ce&&(zt||kt)){if(typeof fetch=="function"&&!Ne.startsWith("file://"))return fetch(Ne,{credentials:"same-origin"}).then(function(z){if(!z.ok)throw"failed to load wasm binary file at '"+Ne+"'";return z.arrayBuffer()}).catch(function(){return a(Ne)});if(Oe)return new Promise(function(z,et){Oe(Ne,function(pt){z(new Uint8Array(pt))},et)})}return Promise.resolve().then(function(){return a(Ne)})}function A(z){for(;0<z.length;)z.shift()(B)}function d(z){this.excPtr=z,this.ptr=z-24,this.set_type=function(et){si[this.ptr+4>>2]=et},this.get_type=function(){return si[this.ptr+4>>2]},this.set_destructor=function(et){si[this.ptr+8>>2]=et},this.get_destructor=function(){return si[this.ptr+8>>2]},this.set_refcount=function(et){Ri[this.ptr>>2]=et},this.set_caught=function(et){Ge[this.ptr+12>>0]=et?1:0},this.get_caught=function(){return Ge[this.ptr+12>>0]!=0},this.set_rethrown=function(et){Ge[this.ptr+13>>0]=et?1:0},this.get_rethrown=function(){return Ge[this.ptr+13>>0]!=0},this.init=function(et,pt){this.set_adjusted_ptr(0),this.set_type(et),this.set_destructor(pt),this.set_refcount(0),this.set_caught(!1),this.set_rethrown(!1)},this.add_ref=function(){Ri[this.ptr>>2]+=1},this.release_ref=function(){var et=Ri[this.ptr>>2];return Ri[this.ptr>>2]=et-1,et===1},this.set_adjusted_ptr=function(et){si[this.ptr+16>>2]=et},this.get_adjusted_ptr=function(){return si[this.ptr+16>>2]},this.get_exception_ptr=function(){if(fm(this.get_type()))return si[this.excPtr>>2];var et=this.get_adjusted_ptr();return et!==0?et:this.excPtr}}function f(){function z(){if(!rA&&(rA=!0,B.calledRun=!0,!ni)){if(De=!0,A(Vi),It(B),B.onRuntimeInitialized&&B.onRuntimeInitialized(),B.postRun)for(typeof B.postRun=="function"&&(B.postRun=[B.postRun]);B.postRun.length;)gn.unshift(B.postRun.shift());A(gn)}}if(!(0<Ye)){if(B.preRun)for(typeof B.preRun=="function"&&(B.preRun=[B.preRun]);B.preRun.length;)qe.unshift(B.preRun.shift());A(qe),0<Ye||(B.setStatus?(B.setStatus("Running..."),setTimeout(function(){setTimeout(function(){B.setStatus("")},1),z()},1)):z())}}function E(){}function _(z){return(z||E).__cache__}function R(z,et){var pt=_(et),$t=pt[z];return $t||($t=Object.create((et||E).prototype),$t.ptr=z,pt[z]=$t)}function I(z){if(typeof z=="string"){for(var et=0,pt=0;pt<z.length;++pt){var $t=z.charCodeAt(pt);127>=$t?et++:2047>=$t?et+=2:55296<=$t&&57343>=$t?(et+=4,++pt):et+=3}if(et=Array(et+1),pt=0,$t=et.length,0<$t){$t=pt+$t-1;for(var ve=0;ve<z.length;++ve){var hi=z.charCodeAt(ve);if(55296<=hi&&57343>=hi){var _a=z.charCodeAt(++ve);hi=65536+((hi&1023)<<10)|_a&1023}if(127>=hi){if(pt>=$t)break;et[pt++]=hi}else{if(2047>=hi){if(pt+1>=$t)break;et[pt++]=192|hi>>6}else{if(65535>=hi){if(pt+2>=$t)break;et[pt++]=224|hi>>12}else{if(pt+3>=$t)break;et[pt++]=240|hi>>18,et[pt++]=128|hi>>12&63}et[pt++]=128|hi>>6&63}et[pt++]=128|hi&63}}et[pt]=0}return z=fi.alloc(et,Ge),fi.copy(et,Ge,z),z}return z}function C(z){if(typeof z=="object"){var et=fi.alloc(z,Ge);return fi.copy(z,Ge,et),et}return z}function N(){throw"cannot construct a VoidPtr, no constructor in IDL"}function T(){this.ptr=nn(),_(T)[this.ptr]=this}function F(){this.ptr=Cs(),_(F)[this.ptr]=this}function b(){this.ptr=Pn(),_(b)[this.ptr]=this}function G(){this.ptr=Ci(),_(G)[this.ptr]=this}function M(){this.ptr=Fr(),_(M)[this.ptr]=this}function Q(){this.ptr=gs(),_(Q)[this.ptr]=this}function U(){this.ptr=Uh(),_(U)[this.ptr]=this}function k(){this.ptr=Vo(),_(k)[this.ptr]=this}function y(){this.ptr=kh(),_(y)[this.ptr]=this}function c(){throw"cannot construct a Status, no constructor in IDL"}function g(){this.ptr=Xa(),_(g)[this.ptr]=this}function V(){this.ptr=kA(),_(V)[this.ptr]=this}function D(){this.ptr=$c(),_(D)[this.ptr]=this}function w(){this.ptr=wh(),_(w)[this.ptr]=this}function x(){this.ptr=el(),_(x)[this.ptr]=this}function H(){this.ptr=Wd(),_(H)[this.ptr]=this}function j(){this.ptr=eA(),_(j)[this.ptr]=this}function X(){this.ptr=Ho(),_(X)[this.ptr]=this}function tt(){this.ptr=jh(),_(tt)[this.ptr]=this}e=e===void 0?{}:e;var B=typeof e<"u"?e:{},It,gt;B.ready=new Promise(function(z,et){It=z,gt=et});var Yt=!1,Mt=!1;B.onRuntimeInitialized=function(){Yt=!0,Mt&&typeof B.onModuleLoaded=="function"&&B.onModuleLoaded(B)},B.onModuleParsed=function(){Mt=!0,Yt&&typeof B.onModuleLoaded=="function"&&B.onModuleLoaded(B)},B.isVersionSupported=function(z){return typeof z!="string"?!1:(z=z.split("."),2>z.length||3<z.length?!1:z[0]==1&&0<=z[1]&&5>=z[1]?!0:!(z[0]!=0||10<z[1]))};var Ct=Object.assign({},B),zt=typeof window=="object",kt=typeof importScripts=="function",Jt=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",Wt="";if(Jt){var Ft=Xo("fs"),ee=Xo("path");Wt=kt?ee.dirname(Wt)+"/":__dirname+"/";var ce=function(z,et){return z=z.startsWith("file://")?new URL(z):ee.normalize(z),Ft.readFileSync(z,et?void 0:"utf8")},je=function(z){return z=ce(z,!0),z.buffer||(z=new Uint8Array(z)),z},Oe=function(z,et,pt){z=z.startsWith("file://")?new URL(z):ee.normalize(z),Ft.readFile(z,function($t,ve){$t?pt($t):et(ve.buffer)})};1<process.argv.length&&process.argv[1].replace(/\\/g,"/"),process.argv.slice(2),B.inspect=function(){return"[Emscripten Module object]"}}else(zt||kt)&&(kt?Wt=self.location.href:typeof document<"u"&&document.currentScript&&(Wt=document.currentScript.src),t&&(Wt=t),Wt=Wt.indexOf("blob:")!==0?Wt.substr(0,Wt.replace(/[?#].*/,"").lastIndexOf("/")+1):"",ce=function(z){var et=new XMLHttpRequest;return et.open("GET",z,!1),et.send(null),et.responseText},kt&&(je=function(z){var et=new XMLHttpRequest;return et.open("GET",z,!1),et.responseType="arraybuffer",et.send(null),new Uint8Array(et.response)}),Oe=function(z,et,pt){var $t=new XMLHttpRequest;$t.open("GET",z,!0),$t.responseType="arraybuffer",$t.onload=function(){$t.status==200||$t.status==0&&$t.response?et($t.response):pt()},$t.onerror=pt,$t.send(null)});var Me=B.print||console.log.bind(console),Ue=B.printErr||console.warn.bind(console);Object.assign(B,Ct),Ct=null;var Ce;B.wasmBinary&&(Ce=B.wasmBinary),typeof WebAssembly!="object"&&r("no native wasm support detected");var be,ni=!1,ze=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,Ge,Ui,Ri,si,qe=[],Vi=[],gn=[],De=!1,Ye=0,Bi=null,An=null,Ne="draco_decoder.wasm";Ne.startsWith("data:application/octet-stream;base64,")||(Ne=i(Ne));var ei=0,_n=[null,[],[]],hs={b:function(z,et,pt){throw new d(z).init(et,pt),ei++,z},a:function(){r("")},g:function(z,et,pt){Ui.copyWithin(z,et,et+pt)},e:function(z){var et=Ui.length;if(z>>>=0,2147483648<z)return!1;for(var pt=1;4>=pt;pt*=2){var $t=et*(1+.2/pt);$t=Math.min($t,z+100663296);var ve=Math;$t=Math.max(z,$t),ve=ve.min.call(ve,2147483648,$t+(65536-$t%65536)%65536);t:{$t=be.buffer;try{be.grow(ve-$t.byteLength+65535>>>16),o();var hi=1;break t}catch{}hi=void 0}if(hi)return!0}return!1},f:function(z){return 52},d:function(z,et,pt,$t,ve){return 70},c:function(z,et,pt,$t){for(var ve=0,hi=0;hi<pt;hi++){var _a=si[et>>2],tc=si[et+4>>2];et+=8;for(var J=0;J<tc;J++){var v=Ui[_a+J],st=_n[z];v===0||v===10?((z===1?Me:Ue)(n(st,0)),st.length=0):st.push(v)}ve+=tc}return si[$t>>2]=ve,0}};(function(){function z(ve,hi){B.asm=ve.exports,be=B.asm.h,o(),Vi.unshift(B.asm.i),Ye--,B.monitorRunDependencies&&B.monitorRunDependencies(Ye),Ye==0&&(Bi!==null&&(clearInterval(Bi),Bi=null),An&&(ve=An,An=null,ve()))}function et(ve){z(ve.instance)}function pt(ve){return h().then(function(hi){return WebAssembly.instantiate(hi,$t)}).then(function(hi){return hi}).then(ve,function(hi){Ue("failed to asynchronously prepare wasm: "+hi),r(hi)})}var $t={a:hs};if(Ye++,B.monitorRunDependencies&&B.monitorRunDependencies(Ye),B.instantiateWasm)try{return B.instantiateWasm($t,z)}catch(ve){Ue("Module.instantiateWasm callback failed with error: "+ve),gt(ve)}return function(){return Ce||typeof WebAssembly.instantiateStreaming!="function"||Ne.startsWith("data:application/octet-stream;base64,")||Ne.startsWith("file://")||Jt||typeof fetch!="function"?pt(et):fetch(Ne,{credentials:"same-origin"}).then(function(ve){return WebAssembly.instantiateStreaming(ve,$t).then(et,function(hi){return Ue("wasm streaming compile failed: "+hi),Ue("falling back to ArrayBuffer instantiation"),pt(et)})})}().catch(gt),{}})();var Qi=B._emscripten_bind_VoidPtr___destroy___0=function(){return(Qi=B._emscripten_bind_VoidPtr___destroy___0=B.asm.k).apply(null,arguments)},nn=B._emscripten_bind_DecoderBuffer_DecoderBuffer_0=function(){return(nn=B._emscripten_bind_DecoderBuffer_DecoderBuffer_0=B.asm.l).apply(null,arguments)},ki=B._emscripten_bind_DecoderBuffer_Init_2=function(){return(ki=B._emscripten_bind_DecoderBuffer_Init_2=B.asm.m).apply(null,arguments)},sn=B._emscripten_bind_DecoderBuffer___destroy___0=function(){return(sn=B._emscripten_bind_DecoderBuffer___destroy___0=B.asm.n).apply(null,arguments)},Cs=B._emscripten_bind_AttributeTransformData_AttributeTransformData_0=function(){return(Cs=B._emscripten_bind_AttributeTransformData_AttributeTransformData_0=B.asm.o).apply(null,arguments)},cs=B._emscripten_bind_AttributeTransformData_transform_type_0=function(){return(cs=B._emscripten_bind_AttributeTransformData_transform_type_0=B.asm.p).apply(null,arguments)},xn=B._emscripten_bind_AttributeTransformData___destroy___0=function(){return(xn=B._emscripten_bind_AttributeTransformData___destroy___0=B.asm.q).apply(null,arguments)},Pn=B._emscripten_bind_GeometryAttribute_GeometryAttribute_0=function(){return(Pn=B._emscripten_bind_GeometryAttribute_GeometryAttribute_0=B.asm.r).apply(null,arguments)},Ai=B._emscripten_bind_GeometryAttribute___destroy___0=function(){return(Ai=B._emscripten_bind_GeometryAttribute___destroy___0=B.asm.s).apply(null,arguments)},Ci=B._emscripten_bind_PointAttribute_PointAttribute_0=function(){return(Ci=B._emscripten_bind_PointAttribute_PointAttribute_0=B.asm.t).apply(null,arguments)},Jn=B._emscripten_bind_PointAttribute_size_0=function(){return(Jn=B._emscripten_bind_PointAttribute_size_0=B.asm.u).apply(null,arguments)},ls=B._emscripten_bind_PointAttribute_GetAttributeTransformData_0=function(){return(ls=B._emscripten_bind_PointAttribute_GetAttributeTransformData_0=B.asm.v).apply(null,arguments)},ao=B._emscripten_bind_PointAttribute_attribute_type_0=function(){return(ao=B._emscripten_bind_PointAttribute_attribute_type_0=B.asm.w).apply(null,arguments)},qi=B._emscripten_bind_PointAttribute_data_type_0=function(){return(qi=B._emscripten_bind_PointAttribute_data_type_0=B.asm.x).apply(null,arguments)},hn=B._emscripten_bind_PointAttribute_num_components_0=function(){return(hn=B._emscripten_bind_PointAttribute_num_components_0=B.asm.y).apply(null,arguments)},jo=B._emscripten_bind_PointAttribute_normalized_0=function(){return(jo=B._emscripten_bind_PointAttribute_normalized_0=B.asm.z).apply(null,arguments)},ds=B._emscripten_bind_PointAttribute_byte_stride_0=function(){return(ds=B._emscripten_bind_PointAttribute_byte_stride_0=B.asm.A).apply(null,arguments)},on=B._emscripten_bind_PointAttribute_byte_offset_0=function(){return(on=B._emscripten_bind_PointAttribute_byte_offset_0=B.asm.B).apply(null,arguments)},ws=B._emscripten_bind_PointAttribute_unique_id_0=function(){return(ws=B._emscripten_bind_PointAttribute_unique_id_0=B.asm.C).apply(null,arguments)},So=B._emscripten_bind_PointAttribute___destroy___0=function(){return(So=B._emscripten_bind_PointAttribute___destroy___0=B.asm.D).apply(null,arguments)},Fr=B._emscripten_bind_AttributeQuantizationTransform_AttributeQuantizationTransform_0=function(){return(Fr=B._emscripten_bind_AttributeQuantizationTransform_AttributeQuantizationTransform_0=B.asm.E).apply(null,arguments)},Oo=B._emscripten_bind_AttributeQuantizationTransform_InitFromAttribute_1=function(){return(Oo=B._emscripten_bind_AttributeQuantizationTransform_InitFromAttribute_1=B.asm.F).apply(null,arguments)},$e=B._emscripten_bind_AttributeQuantizationTransform_quantization_bits_0=function(){return($e=B._emscripten_bind_AttributeQuantizationTransform_quantization_bits_0=B.asm.G).apply(null,arguments)},aa=B._emscripten_bind_AttributeQuantizationTransform_min_value_1=function(){return(aa=B._emscripten_bind_AttributeQuantizationTransform_min_value_1=B.asm.H).apply(null,arguments)},Yr=B._emscripten_bind_AttributeQuantizationTransform_range_0=function(){return(Yr=B._emscripten_bind_AttributeQuantizationTransform_range_0=B.asm.I).apply(null,arguments)},xs=B._emscripten_bind_AttributeQuantizationTransform___destroy___0=function(){return(xs=B._emscripten_bind_AttributeQuantizationTransform___destroy___0=B.asm.J).apply(null,arguments)},gs=B._emscripten_bind_AttributeOctahedronTransform_AttributeOctahedronTransform_0=function(){return(gs=B._emscripten_bind_AttributeOctahedronTransform_AttributeOctahedronTransform_0=B.asm.K).apply(null,arguments)},Tn=B._emscripten_bind_AttributeOctahedronTransform_InitFromAttribute_1=function(){return(Tn=B._emscripten_bind_AttributeOctahedronTransform_InitFromAttribute_1=B.asm.L).apply(null,arguments)},hr=B._emscripten_bind_AttributeOctahedronTransform_quantization_bits_0=function(){return(hr=B._emscripten_bind_AttributeOctahedronTransform_quantization_bits_0=B.asm.M).apply(null,arguments)},Mh=B._emscripten_bind_AttributeOctahedronTransform___destroy___0=function(){return(Mh=B._emscripten_bind_AttributeOctahedronTransform___destroy___0=B.asm.N).apply(null,arguments)},Uh=B._emscripten_bind_PointCloud_PointCloud_0=function(){return(Uh=B._emscripten_bind_PointCloud_PointCloud_0=B.asm.O).apply(null,arguments)},Vn=B._emscripten_bind_PointCloud_num_attributes_0=function(){return(Vn=B._emscripten_bind_PointCloud_num_attributes_0=B.asm.P).apply(null,arguments)},cr=B._emscripten_bind_PointCloud_num_points_0=function(){return(cr=B._emscripten_bind_PointCloud_num_points_0=B.asm.Q).apply(null,arguments)},Ii=B._emscripten_bind_PointCloud___destroy___0=function(){return(Ii=B._emscripten_bind_PointCloud___destroy___0=B.asm.R).apply(null,arguments)},Vo=B._emscripten_bind_Mesh_Mesh_0=function(){return(Vo=B._emscripten_bind_Mesh_Mesh_0=B.asm.S).apply(null,arguments)},Kc=B._emscripten_bind_Mesh_num_faces_0=function(){return(Kc=B._emscripten_bind_Mesh_num_faces_0=B.asm.T).apply(null,arguments)},Xc=B._emscripten_bind_Mesh_num_attributes_0=function(){return(Xc=B._emscripten_bind_Mesh_num_attributes_0=B.asm.U).apply(null,arguments)},qc=B._emscripten_bind_Mesh_num_points_0=function(){return(qc=B._emscripten_bind_Mesh_num_points_0=B.asm.V).apply(null,arguments)},Qh=B._emscripten_bind_Mesh___destroy___0=function(){return(Qh=B._emscripten_bind_Mesh___destroy___0=B.asm.W).apply(null,arguments)},kh=B._emscripten_bind_Metadata_Metadata_0=function(){return(kh=B._emscripten_bind_Metadata_Metadata_0=B.asm.X).apply(null,arguments)},Aa=B._emscripten_bind_Metadata___destroy___0=function(){return(Aa=B._emscripten_bind_Metadata___destroy___0=B.asm.Y).apply(null,arguments)},Lh=B._emscripten_bind_Status_code_0=function(){return(Lh=B._emscripten_bind_Status_code_0=B.asm.Z).apply(null,arguments)},ha=B._emscripten_bind_Status_ok_0=function(){return(ha=B._emscripten_bind_Status_ok_0=B.asm._).apply(null,arguments)},Ka=B._emscripten_bind_Status_error_msg_0=function(){return(Ka=B._emscripten_bind_Status_error_msg_0=B.asm.$).apply(null,arguments)},Sd=B._emscripten_bind_Status___destroy___0=function(){return(Sd=B._emscripten_bind_Status___destroy___0=B.asm.aa).apply(null,arguments)},Xa=B._emscripten_bind_DracoFloat32Array_DracoFloat32Array_0=function(){return(Xa=B._emscripten_bind_DracoFloat32Array_DracoFloat32Array_0=B.asm.ba).apply(null,arguments)},Od=B._emscripten_bind_DracoFloat32Array_GetValue_1=function(){return(Od=B._emscripten_bind_DracoFloat32Array_GetValue_1=B.asm.ca).apply(null,arguments)},qa=B._emscripten_bind_DracoFloat32Array_size_0=function(){return(qa=B._emscripten_bind_DracoFloat32Array_size_0=B.asm.da).apply(null,arguments)},lr=B._emscripten_bind_DracoFloat32Array___destroy___0=function(){return(lr=B._emscripten_bind_DracoFloat32Array___destroy___0=B.asm.ea).apply(null,arguments)},kA=B._emscripten_bind_DracoInt8Array_DracoInt8Array_0=function(){return(kA=B._emscripten_bind_DracoInt8Array_DracoInt8Array_0=B.asm.fa).apply(null,arguments)},$a=B._emscripten_bind_DracoInt8Array_GetValue_1=function(){return($a=B._emscripten_bind_DracoInt8Array_GetValue_1=B.asm.ga).apply(null,arguments)},Vd=B._emscripten_bind_DracoInt8Array_size_0=function(){return(Vd=B._emscripten_bind_DracoInt8Array_size_0=B.asm.ha).apply(null,arguments)},dr=B._emscripten_bind_DracoInt8Array___destroy___0=function(){return(dr=B._emscripten_bind_DracoInt8Array___destroy___0=B.asm.ia).apply(null,arguments)},$c=B._emscripten_bind_DracoUInt8Array_DracoUInt8Array_0=function(){return($c=B._emscripten_bind_DracoUInt8Array_DracoUInt8Array_0=B.asm.ja).apply(null,arguments)},tl=B._emscripten_bind_DracoUInt8Array_GetValue_1=function(){return(tl=B._emscripten_bind_DracoUInt8Array_GetValue_1=B.asm.ka).apply(null,arguments)},yh=B._emscripten_bind_DracoUInt8Array_size_0=function(){return(yh=B._emscripten_bind_DracoUInt8Array_size_0=B.asm.la).apply(null,arguments)},mr=B._emscripten_bind_DracoUInt8Array___destroy___0=function(){return(mr=B._emscripten_bind_DracoUInt8Array___destroy___0=B.asm.ma).apply(null,arguments)},wh=B._emscripten_bind_DracoInt16Array_DracoInt16Array_0=function(){return(wh=B._emscripten_bind_DracoInt16Array_DracoInt16Array_0=B.asm.na).apply(null,arguments)},Gd=B._emscripten_bind_DracoInt16Array_GetValue_1=function(){return(Gd=B._emscripten_bind_DracoInt16Array_GetValue_1=B.asm.oa).apply(null,arguments)},xh=B._emscripten_bind_DracoInt16Array_size_0=function(){return(xh=B._emscripten_bind_DracoInt16Array_size_0=B.asm.pa).apply(null,arguments)},Ph=B._emscripten_bind_DracoInt16Array___destroy___0=function(){return(Ph=B._emscripten_bind_DracoInt16Array___destroy___0=B.asm.qa).apply(null,arguments)},el=B._emscripten_bind_DracoUInt16Array_DracoUInt16Array_0=function(){return(el=B._emscripten_bind_DracoUInt16Array_DracoUInt16Array_0=B.asm.ra).apply(null,arguments)},il=B._emscripten_bind_DracoUInt16Array_GetValue_1=function(){return(il=B._emscripten_bind_DracoUInt16Array_GetValue_1=B.asm.sa).apply(null,arguments)},Bd=B._emscripten_bind_DracoUInt16Array_size_0=function(){return(Bd=B._emscripten_bind_DracoUInt16Array_size_0=B.asm.ta).apply(null,arguments)},tA=B._emscripten_bind_DracoUInt16Array___destroy___0=function(){return(tA=B._emscripten_bind_DracoUInt16Array___destroy___0=B.asm.ua).apply(null,arguments)},Wd=B._emscripten_bind_DracoInt32Array_DracoInt32Array_0=function(){return(Wd=B._emscripten_bind_DracoInt32Array_DracoInt32Array_0=B.asm.va).apply(null,arguments)},Dd=B._emscripten_bind_DracoInt32Array_GetValue_1=function(){return(Dd=B._emscripten_bind_DracoInt32Array_GetValue_1=B.asm.wa).apply(null,arguments)},Md=B._emscripten_bind_DracoInt32Array_size_0=function(){return(Md=B._emscripten_bind_DracoInt32Array_size_0=B.asm.xa).apply(null,arguments)},LA=B._emscripten_bind_DracoInt32Array___destroy___0=function(){return(LA=B._emscripten_bind_DracoInt32Array___destroy___0=B.asm.ya).apply(null,arguments)},eA=B._emscripten_bind_DracoUInt32Array_DracoUInt32Array_0=function(){return(eA=B._emscripten_bind_DracoUInt32Array_DracoUInt32Array_0=B.asm.za).apply(null,arguments)},Ud=B._emscripten_bind_DracoUInt32Array_GetValue_1=function(){return(Ud=B._emscripten_bind_DracoUInt32Array_GetValue_1=B.asm.Aa).apply(null,arguments)},Qd=B._emscripten_bind_DracoUInt32Array_size_0=function(){return(Qd=B._emscripten_bind_DracoUInt32Array_size_0=B.asm.Ba).apply(null,arguments)},yA=B._emscripten_bind_DracoUInt32Array___destroy___0=function(){return(yA=B._emscripten_bind_DracoUInt32Array___destroy___0=B.asm.Ca).apply(null,arguments)},Ho=B._emscripten_bind_MetadataQuerier_MetadataQuerier_0=function(){return(Ho=B._emscripten_bind_MetadataQuerier_MetadataQuerier_0=B.asm.Da).apply(null,arguments)},nl=B._emscripten_bind_MetadataQuerier_HasEntry_2=function(){return(nl=B._emscripten_bind_MetadataQuerier_HasEntry_2=B.asm.Ea).apply(null,arguments)},vo=B._emscripten_bind_MetadataQuerier_GetIntEntry_2=function(){return(vo=B._emscripten_bind_MetadataQuerier_GetIntEntry_2=B.asm.Fa).apply(null,arguments)},iA=B._emscripten_bind_MetadataQuerier_GetIntEntryArray_3=function(){return(iA=B._emscripten_bind_MetadataQuerier_GetIntEntryArray_3=B.asm.Ga).apply(null,arguments)},Jh=B._emscripten_bind_MetadataQuerier_GetDoubleEntry_2=function(){return(Jh=B._emscripten_bind_MetadataQuerier_GetDoubleEntry_2=B.asm.Ha).apply(null,arguments)},kd=B._emscripten_bind_MetadataQuerier_GetStringEntry_2=function(){return(kd=B._emscripten_bind_MetadataQuerier_GetStringEntry_2=B.asm.Ia).apply(null,arguments)},Ld=B._emscripten_bind_MetadataQuerier_NumEntries_1=function(){return(Ld=B._emscripten_bind_MetadataQuerier_NumEntries_1=B.asm.Ja).apply(null,arguments)},jn=B._emscripten_bind_MetadataQuerier_GetEntryName_2=function(){return(jn=B._emscripten_bind_MetadataQuerier_GetEntryName_2=B.asm.Ka).apply(null,arguments)},sl=B._emscripten_bind_MetadataQuerier___destroy___0=function(){return(sl=B._emscripten_bind_MetadataQuerier___destroy___0=B.asm.La).apply(null,arguments)},jh=B._emscripten_bind_Decoder_Decoder_0=function(){return(jh=B._emscripten_bind_Decoder_Decoder_0=B.asm.Ma).apply(null,arguments)},nA=B._emscripten_bind_Decoder_DecodeArrayToPointCloud_3=function(){return(nA=B._emscripten_bind_Decoder_DecodeArrayToPointCloud_3=B.asm.Na).apply(null,arguments)},ca=B._emscripten_bind_Decoder_DecodeArrayToMesh_3=function(){return(ca=B._emscripten_bind_Decoder_DecodeArrayToMesh_3=B.asm.Oa).apply(null,arguments)},Hh=B._emscripten_bind_Decoder_GetAttributeId_2=function(){return(Hh=B._emscripten_bind_Decoder_GetAttributeId_2=B.asm.Pa).apply(null,arguments)},vh=B._emscripten_bind_Decoder_GetAttributeIdByName_2=function(){return(vh=B._emscripten_bind_Decoder_GetAttributeIdByName_2=B.asm.Qa).apply(null,arguments)},wA=B._emscripten_bind_Decoder_GetAttributeIdByMetadataEntry_3=function(){return(wA=B._emscripten_bind_Decoder_GetAttributeIdByMetadataEntry_3=B.asm.Ra).apply(null,arguments)},ol=B._emscripten_bind_Decoder_GetAttribute_2=function(){return(ol=B._emscripten_bind_Decoder_GetAttribute_2=B.asm.Sa).apply(null,arguments)},zh=B._emscripten_bind_Decoder_GetAttributeByUniqueId_2=function(){return(zh=B._emscripten_bind_Decoder_GetAttributeByUniqueId_2=B.asm.Ta).apply(null,arguments)},yd=B._emscripten_bind_Decoder_GetMetadata_1=function(){return(yd=B._emscripten_bind_Decoder_GetMetadata_1=B.asm.Ua).apply(null,arguments)},Kh=B._emscripten_bind_Decoder_GetAttributeMetadata_2=function(){return(Kh=B._emscripten_bind_Decoder_GetAttributeMetadata_2=B.asm.Va).apply(null,arguments)},Ss=B._emscripten_bind_Decoder_GetFaceFromMesh_3=function(){return(Ss=B._emscripten_bind_Decoder_GetFaceFromMesh_3=B.asm.Wa).apply(null,arguments)},Xh=B._emscripten_bind_Decoder_GetTriangleStripsFromMesh_2=function(){return(Xh=B._emscripten_bind_Decoder_GetTriangleStripsFromMesh_2=B.asm.Xa).apply(null,arguments)},wd=B._emscripten_bind_Decoder_GetTrianglesUInt16Array_3=function(){return(wd=B._emscripten_bind_Decoder_GetTrianglesUInt16Array_3=B.asm.Ya).apply(null,arguments)},rl=B._emscripten_bind_Decoder_GetTrianglesUInt32Array_3=function(){return(rl=B._emscripten_bind_Decoder_GetTrianglesUInt32Array_3=B.asm.Za).apply(null,arguments)},Ao=B._emscripten_bind_Decoder_GetAttributeFloat_3=function(){return(Ao=B._emscripten_bind_Decoder_GetAttributeFloat_3=B.asm._a).apply(null,arguments)},ho=B._emscripten_bind_Decoder_GetAttributeFloatForAllPoints_3=function(){return(ho=B._emscripten_bind_Decoder_GetAttributeFloatForAllPoints_3=B.asm.$a).apply(null,arguments)},xd=B._emscripten_bind_Decoder_GetAttributeIntForAllPoints_3=function(){return(xd=B._emscripten_bind_Decoder_GetAttributeIntForAllPoints_3=B.asm.ab).apply(null,arguments)},Pd=B._emscripten_bind_Decoder_GetAttributeInt8ForAllPoints_3=function(){return(Pd=B._emscripten_bind_Decoder_GetAttributeInt8ForAllPoints_3=B.asm.bb).apply(null,arguments)},Go=B._emscripten_bind_Decoder_GetAttributeUInt8ForAllPoints_3=function(){return(Go=B._emscripten_bind_Decoder_GetAttributeUInt8ForAllPoints_3=B.asm.cb).apply(null,arguments)},xA=B._emscripten_bind_Decoder_GetAttributeInt16ForAllPoints_3=function(){return(xA=B._emscripten_bind_Decoder_GetAttributeInt16ForAllPoints_3=B.asm.db).apply(null,arguments)},la=B._emscripten_bind_Decoder_GetAttributeUInt16ForAllPoints_3=function(){return(la=B._emscripten_bind_Decoder_GetAttributeUInt16ForAllPoints_3=B.asm.eb).apply(null,arguments)},da=B._emscripten_bind_Decoder_GetAttributeInt32ForAllPoints_3=function(){return(da=B._emscripten_bind_Decoder_GetAttributeInt32ForAllPoints_3=B.asm.fb).apply(null,arguments)},Jd=B._emscripten_bind_Decoder_GetAttributeUInt32ForAllPoints_3=function(){return(Jd=B._emscripten_bind_Decoder_GetAttributeUInt32ForAllPoints_3=B.asm.gb).apply(null,arguments)},jd=B._emscripten_bind_Decoder_GetAttributeDataArrayForAllPoints_5=function(){return(jd=B._emscripten_bind_Decoder_GetAttributeDataArrayForAllPoints_5=B.asm.hb).apply(null,arguments)},Hd=B._emscripten_bind_Decoder_SkipAttributeTransform_1=function(){return(Hd=B._emscripten_bind_Decoder_SkipAttributeTransform_1=B.asm.ib).apply(null,arguments)},vd=B._emscripten_bind_Decoder_GetEncodedGeometryType_Deprecated_1=function(){return(vd=B._emscripten_bind_Decoder_GetEncodedGeometryType_Deprecated_1=B.asm.jb).apply(null,arguments)},zd=B._emscripten_bind_Decoder_DecodeBufferToPointCloud_2=function(){return(zd=B._emscripten_bind_Decoder_DecodeBufferToPointCloud_2=B.asm.kb).apply(null,arguments)},qh=B._emscripten_bind_Decoder_DecodeBufferToMesh_2=function(){return(qh=B._emscripten_bind_Decoder_DecodeBufferToMesh_2=B.asm.lb).apply(null,arguments)},PA=B._emscripten_bind_Decoder___destroy___0=function(){return(PA=B._emscripten_bind_Decoder___destroy___0=B.asm.mb).apply(null,arguments)},ma=B._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_INVALID_TRANSFORM=function(){return(ma=B._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_INVALID_TRANSFORM=B.asm.nb).apply(null,arguments)},al=B._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_NO_TRANSFORM=function(){return(al=B._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_NO_TRANSFORM=B.asm.ob).apply(null,arguments)},fa=B._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_QUANTIZATION_TRANSFORM=function(){return(fa=B._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_QUANTIZATION_TRANSFORM=B.asm.pb).apply(null,arguments)},Ea=B._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_OCTAHEDRON_TRANSFORM=function(){return(Ea=B._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_OCTAHEDRON_TRANSFORM=B.asm.qb).apply(null,arguments)},sA=B._emscripten_enum_draco_GeometryAttribute_Type_INVALID=function(){return(sA=B._emscripten_enum_draco_GeometryAttribute_Type_INVALID=B.asm.rb).apply(null,arguments)},Al=B._emscripten_enum_draco_GeometryAttribute_Type_POSITION=function(){return(Al=B._emscripten_enum_draco_GeometryAttribute_Type_POSITION=B.asm.sb).apply(null,arguments)},Kd=B._emscripten_enum_draco_GeometryAttribute_Type_NORMAL=function(){return(Kd=B._emscripten_enum_draco_GeometryAttribute_Type_NORMAL=B.asm.tb).apply(null,arguments)},JA=B._emscripten_enum_draco_GeometryAttribute_Type_COLOR=function(){return(JA=B._emscripten_enum_draco_GeometryAttribute_Type_COLOR=B.asm.ub).apply(null,arguments)},$h=B._emscripten_enum_draco_GeometryAttribute_Type_TEX_COORD=function(){return($h=B._emscripten_enum_draco_GeometryAttribute_Type_TEX_COORD=B.asm.vb).apply(null,arguments)},Xd=B._emscripten_enum_draco_GeometryAttribute_Type_GENERIC=function(){return(Xd=B._emscripten_enum_draco_GeometryAttribute_Type_GENERIC=B.asm.wb).apply(null,arguments)},hl=B._emscripten_enum_draco_EncodedGeometryType_INVALID_GEOMETRY_TYPE=function(){return(hl=B._emscripten_enum_draco_EncodedGeometryType_INVALID_GEOMETRY_TYPE=B.asm.xb).apply(null,arguments)},qd=B._emscripten_enum_draco_EncodedGeometryType_POINT_CLOUD=function(){return(qd=B._emscripten_enum_draco_EncodedGeometryType_POINT_CLOUD=B.asm.yb).apply(null,arguments)},$d=B._emscripten_enum_draco_EncodedGeometryType_TRIANGULAR_MESH=function(){return($d=B._emscripten_enum_draco_EncodedGeometryType_TRIANGULAR_MESH=B.asm.zb).apply(null,arguments)},tm=B._emscripten_enum_draco_DataType_DT_INVALID=function(){return(tm=B._emscripten_enum_draco_DataType_DT_INVALID=B.asm.Ab).apply(null,arguments)},em=B._emscripten_enum_draco_DataType_DT_INT8=function(){return(em=B._emscripten_enum_draco_DataType_DT_INT8=B.asm.Bb).apply(null,arguments)},im=B._emscripten_enum_draco_DataType_DT_UINT8=function(){return(im=B._emscripten_enum_draco_DataType_DT_UINT8=B.asm.Cb).apply(null,arguments)},nm=B._emscripten_enum_draco_DataType_DT_INT16=function(){return(nm=B._emscripten_enum_draco_DataType_DT_INT16=B.asm.Db).apply(null,arguments)},sm=B._emscripten_enum_draco_DataType_DT_UINT16=function(){return(sm=B._emscripten_enum_draco_DataType_DT_UINT16=B.asm.Eb).apply(null,arguments)},om=B._emscripten_enum_draco_DataType_DT_INT32=function(){return(om=B._emscripten_enum_draco_DataType_DT_INT32=B.asm.Fb).apply(null,arguments)},cl=B._emscripten_enum_draco_DataType_DT_UINT32=function(){return(cl=B._emscripten_enum_draco_DataType_DT_UINT32=B.asm.Gb).apply(null,arguments)},rm=B._emscripten_enum_draco_DataType_DT_INT64=function(){return(rm=B._emscripten_enum_draco_DataType_DT_INT64=B.asm.Hb).apply(null,arguments)},am=B._emscripten_enum_draco_DataType_DT_UINT64=function(){return(am=B._emscripten_enum_draco_DataType_DT_UINT64=B.asm.Ib).apply(null,arguments)},Am=B._emscripten_enum_draco_DataType_DT_FLOAT32=function(){return(Am=B._emscripten_enum_draco_DataType_DT_FLOAT32=B.asm.Jb).apply(null,arguments)},ll=B._emscripten_enum_draco_DataType_DT_FLOAT64=function(){return(ll=B._emscripten_enum_draco_DataType_DT_FLOAT64=B.asm.Kb).apply(null,arguments)},hm=B._emscripten_enum_draco_DataType_DT_BOOL=function(){return(hm=B._emscripten_enum_draco_DataType_DT_BOOL=B.asm.Lb).apply(null,arguments)},oA=B._emscripten_enum_draco_DataType_DT_TYPES_COUNT=function(){return(oA=B._emscripten_enum_draco_DataType_DT_TYPES_COUNT=B.asm.Mb).apply(null,arguments)},cm=B._emscripten_enum_draco_StatusCode_OK=function(){return(cm=B._emscripten_enum_draco_StatusCode_OK=B.asm.Nb).apply(null,arguments)},jA=B._emscripten_enum_draco_StatusCode_DRACO_ERROR=function(){return(jA=B._emscripten_enum_draco_StatusCode_DRACO_ERROR=B.asm.Ob).apply(null,arguments)},lm=B._emscripten_enum_draco_StatusCode_IO_ERROR=function(){return(lm=B._emscripten_enum_draco_StatusCode_IO_ERROR=B.asm.Pb).apply(null,arguments)},dm=B._emscripten_enum_draco_StatusCode_INVALID_PARAMETER=function(){return(dm=B._emscripten_enum_draco_StatusCode_INVALID_PARAMETER=B.asm.Qb).apply(null,arguments)},dl=B._emscripten_enum_draco_StatusCode_UNSUPPORTED_VERSION=function(){return(dl=B._emscripten_enum_draco_StatusCode_UNSUPPORTED_VERSION=B.asm.Rb).apply(null,arguments)},mm=B._emscripten_enum_draco_StatusCode_UNKNOWN_VERSION=function(){return(mm=B._emscripten_enum_draco_StatusCode_UNKNOWN_VERSION=B.asm.Sb).apply(null,arguments)};B._malloc=function(){return(B._malloc=B.asm.Tb).apply(null,arguments)},B._free=function(){return(B._free=B.asm.Ub).apply(null,arguments)};var fm=function(){return(fm=B.asm.Vb).apply(null,arguments)};B.___start_em_js=15856,B.___stop_em_js=15954;var rA;if(An=function z(){rA||f(),rA||(An=z)},B.preInit)for(typeof B.preInit=="function"&&(B.preInit=[B.preInit]);0<B.preInit.length;)B.preInit.pop()();f(),E.prototype=Object.create(E.prototype),E.prototype.constructor=E,E.prototype.__class__=E,E.__cache__={},B.WrapperObject=E,B.getCache=_,B.wrapPointer=R,B.castObject=function(z,et){return R(z.ptr,et)},B.NULL=R(0),B.destroy=function(z){if(!z.__destroy__)throw"Error: Cannot destroy object. (Did you create it yourself?)";z.__destroy__(),delete _(z.__class__)[z.ptr]},B.compare=function(z,et){return z.ptr===et.ptr},B.getPointer=function(z){return z.ptr},B.getClass=function(z){return z.__class__};var fi={buffer:0,size:0,pos:0,temps:[],needed:0,prepare:function(){if(fi.needed){for(var z=0;z<fi.temps.length;z++)B._free(fi.temps[z]);fi.temps.length=0,B._free(fi.buffer),fi.buffer=0,fi.size+=fi.needed,fi.needed=0}fi.buffer||(fi.size+=128,fi.buffer=B._malloc(fi.size),fi.buffer||r(void 0)),fi.pos=0},alloc:function(z,et){return fi.buffer||r(void 0),z=z.length*et.BYTES_PER_ELEMENT,z=z+7&-8,fi.pos+z>=fi.size?(0<z||r(void 0),fi.needed+=z,et=B._malloc(z),fi.temps.push(et)):(et=fi.buffer+fi.pos,fi.pos+=z),et},copy:function(z,et,pt){switch(pt>>>=0,et.BYTES_PER_ELEMENT){case 2:pt>>>=1;break;case 4:pt>>>=2;break;case 8:pt>>>=3}for(var $t=0;$t<z.length;$t++)et[pt+$t]=z[$t]}};return N.prototype=Object.create(E.prototype),N.prototype.constructor=N,N.prototype.__class__=N,N.__cache__={},B.VoidPtr=N,N.prototype.__destroy__=N.prototype.__destroy__=function(){Qi(this.ptr)},T.prototype=Object.create(E.prototype),T.prototype.constructor=T,T.prototype.__class__=T,T.__cache__={},B.DecoderBuffer=T,T.prototype.Init=T.prototype.Init=function(z,et){var pt=this.ptr;fi.prepare(),typeof z=="object"&&(z=C(z)),et&&typeof et=="object"&&(et=et.ptr),ki(pt,z,et)},T.prototype.__destroy__=T.prototype.__destroy__=function(){sn(this.ptr)},F.prototype=Object.create(E.prototype),F.prototype.constructor=F,F.prototype.__class__=F,F.__cache__={},B.AttributeTransformData=F,F.prototype.transform_type=F.prototype.transform_type=function(){return cs(this.ptr)},F.prototype.__destroy__=F.prototype.__destroy__=function(){xn(this.ptr)},b.prototype=Object.create(E.prototype),b.prototype.constructor=b,b.prototype.__class__=b,b.__cache__={},B.GeometryAttribute=b,b.prototype.__destroy__=b.prototype.__destroy__=function(){Ai(this.ptr)},G.prototype=Object.create(E.prototype),G.prototype.constructor=G,G.prototype.__class__=G,G.__cache__={},B.PointAttribute=G,G.prototype.size=G.prototype.size=function(){return Jn(this.ptr)},G.prototype.GetAttributeTransformData=G.prototype.GetAttributeTransformData=function(){return R(ls(this.ptr),F)},G.prototype.attribute_type=G.prototype.attribute_type=function(){return ao(this.ptr)},G.prototype.data_type=G.prototype.data_type=function(){return qi(this.ptr)},G.prototype.num_components=G.prototype.num_components=function(){return hn(this.ptr)},G.prototype.normalized=G.prototype.normalized=function(){return!!jo(this.ptr)},G.prototype.byte_stride=G.prototype.byte_stride=function(){return ds(this.ptr)},G.prototype.byte_offset=G.prototype.byte_offset=function(){return on(this.ptr)},G.prototype.unique_id=G.prototype.unique_id=function(){return ws(this.ptr)},G.prototype.__destroy__=G.prototype.__destroy__=function(){So(this.ptr)},M.prototype=Object.create(E.prototype),M.prototype.constructor=M,M.prototype.__class__=M,M.__cache__={},B.AttributeQuantizationTransform=M,M.prototype.InitFromAttribute=M.prototype.InitFromAttribute=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),!!Oo(et,z)},M.prototype.quantization_bits=M.prototype.quantization_bits=function(){return $e(this.ptr)},M.prototype.min_value=M.prototype.min_value=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),aa(et,z)},M.prototype.range=M.prototype.range=function(){return Yr(this.ptr)},M.prototype.__destroy__=M.prototype.__destroy__=function(){xs(this.ptr)},Q.prototype=Object.create(E.prototype),Q.prototype.constructor=Q,Q.prototype.__class__=Q,Q.__cache__={},B.AttributeOctahedronTransform=Q,Q.prototype.InitFromAttribute=Q.prototype.InitFromAttribute=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),!!Tn(et,z)},Q.prototype.quantization_bits=Q.prototype.quantization_bits=function(){return hr(this.ptr)},Q.prototype.__destroy__=Q.prototype.__destroy__=function(){Mh(this.ptr)},U.prototype=Object.create(E.prototype),U.prototype.constructor=U,U.prototype.__class__=U,U.__cache__={},B.PointCloud=U,U.prototype.num_attributes=U.prototype.num_attributes=function(){return Vn(this.ptr)},U.prototype.num_points=U.prototype.num_points=function(){return cr(this.ptr)},U.prototype.__destroy__=U.prototype.__destroy__=function(){Ii(this.ptr)},k.prototype=Object.create(E.prototype),k.prototype.constructor=k,k.prototype.__class__=k,k.__cache__={},B.Mesh=k,k.prototype.num_faces=k.prototype.num_faces=function(){return Kc(this.ptr)},k.prototype.num_attributes=k.prototype.num_attributes=function(){return Xc(this.ptr)},k.prototype.num_points=k.prototype.num_points=function(){return qc(this.ptr)},k.prototype.__destroy__=k.prototype.__destroy__=function(){Qh(this.ptr)},y.prototype=Object.create(E.prototype),y.prototype.constructor=y,y.prototype.__class__=y,y.__cache__={},B.Metadata=y,y.prototype.__destroy__=y.prototype.__destroy__=function(){Aa(this.ptr)},c.prototype=Object.create(E.prototype),c.prototype.constructor=c,c.prototype.__class__=c,c.__cache__={},B.Status=c,c.prototype.code=c.prototype.code=function(){return Lh(this.ptr)},c.prototype.ok=c.prototype.ok=function(){return!!ha(this.ptr)},c.prototype.error_msg=c.prototype.error_msg=function(){return s(Ka(this.ptr))},c.prototype.__destroy__=c.prototype.__destroy__=function(){Sd(this.ptr)},g.prototype=Object.create(E.prototype),g.prototype.constructor=g,g.prototype.__class__=g,g.__cache__={},B.DracoFloat32Array=g,g.prototype.GetValue=g.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),Od(et,z)},g.prototype.size=g.prototype.size=function(){return qa(this.ptr)},g.prototype.__destroy__=g.prototype.__destroy__=function(){lr(this.ptr)},V.prototype=Object.create(E.prototype),V.prototype.constructor=V,V.prototype.__class__=V,V.__cache__={},B.DracoInt8Array=V,V.prototype.GetValue=V.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),$a(et,z)},V.prototype.size=V.prototype.size=function(){return Vd(this.ptr)},V.prototype.__destroy__=V.prototype.__destroy__=function(){dr(this.ptr)},D.prototype=Object.create(E.prototype),D.prototype.constructor=D,D.prototype.__class__=D,D.__cache__={},B.DracoUInt8Array=D,D.prototype.GetValue=D.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),tl(et,z)},D.prototype.size=D.prototype.size=function(){return yh(this.ptr)},D.prototype.__destroy__=D.prototype.__destroy__=function(){mr(this.ptr)},w.prototype=Object.create(E.prototype),w.prototype.constructor=w,w.prototype.__class__=w,w.__cache__={},B.DracoInt16Array=w,w.prototype.GetValue=w.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),Gd(et,z)},w.prototype.size=w.prototype.size=function(){return xh(this.ptr)},w.prototype.__destroy__=w.prototype.__destroy__=function(){Ph(this.ptr)},x.prototype=Object.create(E.prototype),x.prototype.constructor=x,x.prototype.__class__=x,x.__cache__={},B.DracoUInt16Array=x,x.prototype.GetValue=x.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),il(et,z)},x.prototype.size=x.prototype.size=function(){return Bd(this.ptr)},x.prototype.__destroy__=x.prototype.__destroy__=function(){tA(this.ptr)},H.prototype=Object.create(E.prototype),H.prototype.constructor=H,H.prototype.__class__=H,H.__cache__={},B.DracoInt32Array=H,H.prototype.GetValue=H.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),Dd(et,z)},H.prototype.size=H.prototype.size=function(){return Md(this.ptr)},H.prototype.__destroy__=H.prototype.__destroy__=function(){LA(this.ptr)},j.prototype=Object.create(E.prototype),j.prototype.constructor=j,j.prototype.__class__=j,j.__cache__={},B.DracoUInt32Array=j,j.prototype.GetValue=j.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),Ud(et,z)},j.prototype.size=j.prototype.size=function(){return Qd(this.ptr)},j.prototype.__destroy__=j.prototype.__destroy__=function(){yA(this.ptr)},X.prototype=Object.create(E.prototype),X.prototype.constructor=X,X.prototype.__class__=X,X.__cache__={},B.MetadataQuerier=X,X.prototype.HasEntry=X.prototype.HasEntry=function(z,et){var pt=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),!!nl(pt,z,et)},X.prototype.GetIntEntry=X.prototype.GetIntEntry=function(z,et){var pt=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),vo(pt,z,et)},X.prototype.GetIntEntryArray=X.prototype.GetIntEntryArray=function(z,et,pt){var $t=this.ptr;fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),pt&&typeof pt=="object"&&(pt=pt.ptr),iA($t,z,et,pt)},X.prototype.GetDoubleEntry=X.prototype.GetDoubleEntry=function(z,et){var pt=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),Jh(pt,z,et)},X.prototype.GetStringEntry=X.prototype.GetStringEntry=function(z,et){var pt=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),s(kd(pt,z,et))},X.prototype.NumEntries=X.prototype.NumEntries=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),Ld(et,z)},X.prototype.GetEntryName=X.prototype.GetEntryName=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),s(jn(pt,z,et))},X.prototype.__destroy__=X.prototype.__destroy__=function(){sl(this.ptr)},tt.prototype=Object.create(E.prototype),tt.prototype.constructor=tt,tt.prototype.__class__=tt,tt.__cache__={},B.Decoder=tt,tt.prototype.DecodeArrayToPointCloud=tt.prototype.DecodeArrayToPointCloud=function(z,et,pt){var $t=this.ptr;return fi.prepare(),typeof z=="object"&&(z=C(z)),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),R(nA($t,z,et,pt),c)},tt.prototype.DecodeArrayToMesh=tt.prototype.DecodeArrayToMesh=function(z,et,pt){var $t=this.ptr;return fi.prepare(),typeof z=="object"&&(z=C(z)),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),R(ca($t,z,et,pt),c)},tt.prototype.GetAttributeId=tt.prototype.GetAttributeId=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),Hh(pt,z,et)},tt.prototype.GetAttributeIdByName=tt.prototype.GetAttributeIdByName=function(z,et){var pt=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),vh(pt,z,et)},tt.prototype.GetAttributeIdByMetadataEntry=tt.prototype.GetAttributeIdByMetadataEntry=function(z,et,pt){var $t=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),pt=pt&&typeof pt=="object"?pt.ptr:I(pt),wA($t,z,et,pt)},tt.prototype.GetAttribute=tt.prototype.GetAttribute=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),R(ol(pt,z,et),G)},tt.prototype.GetAttributeByUniqueId=tt.prototype.GetAttributeByUniqueId=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),R(zh(pt,z,et),G)},tt.prototype.GetMetadata=tt.prototype.GetMetadata=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),R(yd(et,z),y)},tt.prototype.GetAttributeMetadata=tt.prototype.GetAttributeMetadata=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),R(Kh(pt,z,et),y)},tt.prototype.GetFaceFromMesh=tt.prototype.GetFaceFromMesh=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!Ss($t,z,et,pt)},tt.prototype.GetTriangleStripsFromMesh=tt.prototype.GetTriangleStripsFromMesh=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),Xh(pt,z,et)},tt.prototype.GetTrianglesUInt16Array=tt.prototype.GetTrianglesUInt16Array=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!wd($t,z,et,pt)},tt.prototype.GetTrianglesUInt32Array=tt.prototype.GetTrianglesUInt32Array=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!rl($t,z,et,pt)},tt.prototype.GetAttributeFloat=tt.prototype.GetAttributeFloat=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!Ao($t,z,et,pt)},tt.prototype.GetAttributeFloatForAllPoints=tt.prototype.GetAttributeFloatForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!ho($t,z,et,pt)},tt.prototype.GetAttributeIntForAllPoints=tt.prototype.GetAttributeIntForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!xd($t,z,et,pt)},tt.prototype.GetAttributeInt8ForAllPoints=tt.prototype.GetAttributeInt8ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!Pd($t,z,et,pt)},tt.prototype.GetAttributeUInt8ForAllPoints=tt.prototype.GetAttributeUInt8ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!Go($t,z,et,pt)},tt.prototype.GetAttributeInt16ForAllPoints=tt.prototype.GetAttributeInt16ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!xA($t,z,et,pt)},tt.prototype.GetAttributeUInt16ForAllPoints=tt.prototype.GetAttributeUInt16ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!la($t,z,et,pt)},tt.prototype.GetAttributeInt32ForAllPoints=tt.prototype.GetAttributeInt32ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!da($t,z,et,pt)},tt.prototype.GetAttributeUInt32ForAllPoints=tt.prototype.GetAttributeUInt32ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!Jd($t,z,et,pt)},tt.prototype.GetAttributeDataArrayForAllPoints=tt.prototype.GetAttributeDataArrayForAllPoints=function(z,et,pt,$t,ve){var hi=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),$t&&typeof $t=="object"&&($t=$t.ptr),ve&&typeof ve=="object"&&(ve=ve.ptr),!!jd(hi,z,et,pt,$t,ve)},tt.prototype.SkipAttributeTransform=tt.prototype.SkipAttributeTransform=function(z){var et=this.ptr;z&&typeof z=="object"&&(z=z.ptr),Hd(et,z)},tt.prototype.GetEncodedGeometryType_Deprecated=tt.prototype.GetEncodedGeometryType_Deprecated=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),vd(et,z)},tt.prototype.DecodeBufferToPointCloud=tt.prototype.DecodeBufferToPointCloud=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),R(zd(pt,z,et),c)},tt.prototype.DecodeBufferToMesh=tt.prototype.DecodeBufferToMesh=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),R(qh(pt,z,et),c)},tt.prototype.__destroy__=tt.prototype.__destroy__=function(){PA(this.ptr)},function(){function z(){B.ATTRIBUTE_INVALID_TRANSFORM=ma(),B.ATTRIBUTE_NO_TRANSFORM=al(),B.ATTRIBUTE_QUANTIZATION_TRANSFORM=fa(),B.ATTRIBUTE_OCTAHEDRON_TRANSFORM=Ea(),B.INVALID=sA(),B.POSITION=Al(),B.NORMAL=Kd(),B.COLOR=JA(),B.TEX_COORD=$h(),B.GENERIC=Xd(),B.INVALID_GEOMETRY_TYPE=hl(),B.POINT_CLOUD=qd(),B.TRIANGULAR_MESH=$d(),B.DT_INVALID=tm(),B.DT_INT8=em(),B.DT_UINT8=im(),B.DT_INT16=nm(),B.DT_UINT16=sm(),B.DT_INT32=om(),B.DT_UINT32=cl(),B.DT_INT64=rm(),B.DT_UINT64=am(),B.DT_FLOAT32=Am(),B.DT_FLOAT64=ll(),B.DT_BOOL=hm(),B.DT_TYPES_COUNT=oA(),B.OK=cm(),B.DRACO_ERROR=jA(),B.IO_ERROR=lm(),B.INVALID_PARAMETER=dm(),B.UNSUPPORTED_VERSION=dl(),B.UNKNOWN_VERSION=mm()}De?z():Vi.unshift(z)}(),typeof B.onModuleParsed=="function"&&B.onModuleParsed(),B.Decoder.prototype.GetEncodedGeometryType=function(z){if(z.__class__&&z.__class__===B.DecoderBuffer)return B.Decoder.prototype.GetEncodedGeometryType_Deprecated(z);if(8>z.byteLength)return B.INVALID_GEOMETRY_TYPE;switch(z[7]){case 0:return B.POINT_CLOUD;case 1:return B.TRIANGULAR_MESH;default:return B.INVALID_GEOMETRY_TYPE}},e.ready}}();typeof kR=="object"&&typeof $G=="object"?$G.exports=qG:typeof define=="function"&&define.amd?define([],function(){return qG}):typeof kR=="object"&&(kR.DracoDecoderModule=qG)});var iB={};He(iB,{default:()=>x_t});function D_t(t,e){let i=t.num_points(),n=t.num_faces(),s=new bi.DracoInt32Array,o=n*3,r=te.createTypedArray(i,o),a=0;for(let h=0;h<n;++h)e.GetFaceFromMesh(t,h,s),r[a+0]=s.GetValue(0),r[a+1]=s.GetValue(1),r[a+2]=s.GetValue(2),a+=3;return bi.destroy(s),{typedArray:r,numberOfIndices:o}}function M_t(t,e,i,n,s){let o,r;n.quantizationBits<=8?(r=new bi.DracoUInt8Array,o=new Uint8Array(s),e.GetAttributeUInt8ForAllPoints(t,i,r)):n.quantizationBits<=16?(r=new bi.DracoUInt16Array,o=new Uint16Array(s),e.GetAttributeUInt16ForAllPoints(t,i,r)):(r=new bi.DracoFloat32Array,o=new Float32Array(s),e.GetAttributeFloatForAllPoints(t,i,r));for(let a=0;a<s;++a)o[a]=r.GetValue(a);return bi.destroy(r),o}function U_t(t,e,i,n){let s,o;switch(i.data_type()){case 1:case 11:o=new bi.DracoInt8Array,s=new Int8Array(n),e.GetAttributeInt8ForAllPoints(t,i,o);break;case 2:o=new bi.DracoUInt8Array,s=new Uint8Array(n),e.GetAttributeUInt8ForAllPoints(t,i,o);break;case 3:o=new bi.DracoInt16Array,s=new Int16Array(n),e.GetAttributeInt16ForAllPoints(t,i,o);break;case 4:o=new bi.DracoUInt16Array,s=new Uint16Array(n),e.GetAttributeUInt16ForAllPoints(t,i,o);break;case 5:case 7:o=new bi.DracoInt32Array,s=new Int32Array(n),e.GetAttributeInt32ForAllPoints(t,i,o);break;case 6:case 8:o=new bi.DracoUInt32Array,s=new Uint32Array(n),e.GetAttributeUInt32ForAllPoints(t,i,o);break;case 9:case 10:o=new bi.DracoFloat32Array,s=new Float32Array(n),e.GetAttributeFloatForAllPoints(t,i,o);break}for(let r=0;r<n;++r)s[r]=o.GetValue(r);return bi.destroy(o),s}function pK(t,e,i){let n=t.num_points(),s=i.num_components(),o,r=new bi.AttributeQuantizationTransform;if(r.InitFromAttribute(i)){let d=new Array(s);for(let f=0;f<s;++f)d[f]=r.min_value(f);o={quantizationBits:r.quantization_bits(),minValues:d,range:r.range(),octEncoded:!1}}bi.destroy(r),r=new bi.AttributeOctahedronTransform,r.InitFromAttribute(i)&&(o={quantizationBits:r.quantization_bits(),octEncoded:!0}),bi.destroy(r);let a=n*s,h;m(o)?h=M_t(t,e,i,o,a):h=U_t(t,e,i,a);let A=At.fromTypedArray(h);return{array:h,data:{componentsPerAttribute:s,componentDatatype:A,byteOffset:i.byte_offset(),byteStride:At.getSizeInBytes(A)*s,normalized:i.normalized(),quantization:o}}}function Q_t(t){let e=new bi.Decoder;t.dequantizeInShader&&(e.SkipAttributeTransform(bi.POSITION),e.SkipAttributeTransform(bi.NORMAL));let i=new bi.DecoderBuffer;if(i.Init(t.buffer,t.buffer.length),e.GetEncodedGeometryType(i)!==bi.POINT_CLOUD)throw new ke("Draco geometry type must be POINT_CLOUD.");let s=new bi.PointCloud,o=e.DecodeBufferToPointCloud(i,s);if(!o.ok()||s.ptr===0)throw new ke(`Error decoding draco point cloud: ${o.error_msg()}`);bi.destroy(i);let r={},a=t.properties;for(let h in a)if(a.hasOwnProperty(h)){let A;if(h==="POSITION"||h==="NORMAL"){let d=e.GetAttributeId(s,bi[h]);A=e.GetAttribute(s,d)}else{let d=a[h];A=e.GetAttributeByUniqueId(s,d)}r[h]=pK(s,e,A)}return bi.destroy(s),bi.destroy(e),r}function k_t(t){let e=new bi.Decoder,i=["POSITION","NORMAL","COLOR","TEX_COORD"];if(t.dequantizeInShader)for(let f=0;f<i.length;++f)e.SkipAttributeTransform(bi[i[f]]);let n=t.bufferView,s=new bi.DecoderBuffer;if(s.Init(t.array,n.byteLength),e.GetEncodedGeometryType(s)!==bi.TRIANGULAR_MESH)throw new ke("Unsupported draco mesh geometry type.");let r=new bi.Mesh,a=e.DecodeBufferToMesh(s,r);if(!a.ok()||r.ptr===0)throw new ke(`Error decoding draco mesh geometry: ${a.error_msg()}`);bi.destroy(s);let h={},A=t.compressedAttributes;for(let f in A)if(A.hasOwnProperty(f)){let E=A[f],_=e.GetAttributeByUniqueId(r,E);h[f]=pK(r,e,_)}let d={indexArray:D_t(r,e),attributeData:h};return bi.destroy(r),bi.destroy(e),d}async function L_t(t,e){return m(t.bufferView)?k_t(t):Q_t(t)}async function y_t(t,e){let i=t.webAssemblyConfig;return m(i)&&m(i.wasmBinaryFile)?bi=await(0,eB.default)(i):bi=await(0,eB.default)(),!0}async function w_t(t,e){let i=t.webAssemblyConfig;return m(i)?y_t(t,e):L_t(t,e)}var eB,bi,x_t,nB=O(()=>{oi();mt();Di();Ps();Ns();eB=co(tB(),1);x_t=Wi(w_t)});function sB(t,e){if(sB.passThroughDataForTesting)return e;p.typeOf.object("key",t),p.typeOf.object("data",e);let i=t.byteLength;if(i===0||i%4!==0)throw new ke("The length of key must be greater than 0 and a multiple of 4.");let n=new DataView(e),s=n.getUint32(0,!0);if(s===P_t||s===J_t)return e;let o=new DataView(t),r=0,a=e.byteLength,h=a-a%8,A=i,d,f=8;for(;r<h;)for(f=(f+8)%24,d=f;r<h&&d<A;)n.setUint32(r,n.getUint32(r,!0)^o.getUint32(d,!0),!0),n.setUint32(r+4,n.getUint32(r+4,!0)^o.getUint32(d+4,!0),!0),r+=8,d+=24;if(r<a)for(d>=A&&(f=(f+8)%24,d=f);r<a;)n.setUint8(r,n.getUint8(r)^o.getUint8(d)),r++,d++}var P_t,J_t,uK,CK=O(()=>{ae();Ps();P_t=1953029805,J_t=2917034100;sB.passThroughDataForTesting=!1;uK=sB});function j_t(t,e){return(t&e)!==0}var Xf,gK=O(()=>{Xf=j_t});function MA(t,e,i,n,s,o){this._bits=t,this.cnodeVersion=e,this.imageryVersion=i,this.terrainVersion=n,this.imageryProvider=s,this.terrainProvider=o,this.ancestorHasTerrain=!1,this.terrainState=void 0}var H_t,TK,v_t,z_t,K_t,NK,bK=O(()=>{mt();gK();H_t=[1,2,4,8],TK=15,v_t=16,z_t=64,K_t=128;MA.clone=function(t,e){return m(e)?(e._bits=t._bits,e.cnodeVersion=t.cnodeVersion,e.imageryVersion=t.imageryVersion,e.terrainVersion=t.terrainVersion,e.imageryProvider=t.imageryProvider,e.terrainProvider=t.terrainProvider):e=new MA(t._bits,t.cnodeVersion,t.imageryVersion,t.terrainVersion,t.imageryProvider,t.terrainProvider),e.ancestorHasTerrain=t.ancestorHasTerrain,e.terrainState=t.terrainState,e};MA.prototype.setParent=function(t){this.ancestorHasTerrain=t.ancestorHasTerrain||this.hasTerrain()};MA.prototype.hasSubtree=function(){return Xf(this._bits,v_t)};MA.prototype.hasImagery=function(){return Xf(this._bits,z_t)};MA.prototype.hasTerrain=function(){return Xf(this._bits,K_t)};MA.prototype.hasChildren=function(){return Xf(this._bits,TK)};MA.prototype.hasChild=function(t){return Xf(this._bits,H_t[t])};MA.prototype.getChildBitmask=function(){return this._bits&TK};NK=MA});var YK=ts((QOe,FK)=>{"use strict";var X_t=(t,e,i,n)=>{let s=t&65535|0,o=t>>>16&65535|0,r=0;for(;i!==0;){r=i>2e3?2e3:i,i-=r;do s=s+e[n++]|0,o=o+s|0;while(--r);s%=65521,o%=65521}return s|o<<16|0};FK.exports=X_t});var OK=ts((kOe,SK)=>{"use strict";var q_t=()=>{let t,e=[];for(var i=0;i<256;i++){t=i;for(var n=0;n<8;n++)t=t&1?3988292384^t>>>1:t>>>1;e[i]=t}return e},$_t=new Uint32Array(q_t()),tRt=(t,e,i,n)=>{let s=$_t,o=n+i;t^=-1;for(let r=n;r<o;r++)t=t>>>8^s[(t^e[r])&255];return t^-1};SK.exports=tRt});var GK=ts((LOe,VK)=>{"use strict";VK.exports=function(e,i){let n,s,o,r,a,h,A,d,f,E,_,R,I,C,N,T,F,b,G,M,Q,U,k,y,c=e.state;n=e.next_in,k=e.input,s=n+(e.avail_in-5),o=e.next_out,y=e.output,r=o-(i-e.avail_out),a=o+(e.avail_out-257),h=c.dmax,A=c.wsize,d=c.whave,f=c.wnext,E=c.window,_=c.hold,R=c.bits,I=c.lencode,C=c.distcode,N=(1<<c.lenbits)-1,T=(1<<c.distbits)-1;t:do{R<15&&(_+=k[n++]<<R,R+=8,_+=k[n++]<<R,R+=8),F=I[_&N];e:for(;;){if(b=F>>>24,_>>>=b,R-=b,b=F>>>16&255,b===0)y[o++]=F&65535;else if(b&16){G=F&65535,b&=15,b&&(R<b&&(_+=k[n++]<<R,R+=8),G+=_&(1<<b)-1,_>>>=b,R-=b),R<15&&(_+=k[n++]<<R,R+=8,_+=k[n++]<<R,R+=8),F=C[_&T];i:for(;;){if(b=F>>>24,_>>>=b,R-=b,b=F>>>16&255,b&16){if(M=F&65535,b&=15,R<b&&(_+=k[n++]<<R,R+=8,R<b&&(_+=k[n++]<<R,R+=8)),M+=_&(1<<b)-1,M>h){e.msg="invalid distance too far back",c.mode=16209;break t}if(_>>>=b,R-=b,b=o-r,M>b){if(b=M-b,b>d&&c.sane){e.msg="invalid distance too far back",c.mode=16209;break t}if(Q=0,U=E,f===0){if(Q+=A-b,b<G){G-=b;do y[o++]=E[Q++];while(--b);Q=o-M,U=y}}else if(f<b){if(Q+=A+f-b,b-=f,b<G){G-=b;do y[o++]=E[Q++];while(--b);if(Q=0,f<G){b=f,G-=b;do y[o++]=E[Q++];while(--b);Q=o-M,U=y}}}else if(Q+=f-b,b<G){G-=b;do y[o++]=E[Q++];while(--b);Q=o-M,U=y}for(;G>2;)y[o++]=U[Q++],y[o++]=U[Q++],y[o++]=U[Q++],G-=3;G&&(y[o++]=U[Q++],G>1&&(y[o++]=U[Q++]))}else{Q=o-M;do y[o++]=y[Q++],y[o++]=y[Q++],y[o++]=y[Q++],G-=3;while(G>2);G&&(y[o++]=y[Q++],G>1&&(y[o++]=y[Q++]))}}else if(b&64){e.msg="invalid distance code",c.mode=16209;break t}else{F=C[(F&65535)+(_&(1<<b)-1)];continue i}break}}else if(b&64)if(b&32){c.mode=16191;break t}else{e.msg="invalid literal/length code",c.mode=16209;break t}else{F=I[(F&65535)+(_&(1<<b)-1)];continue e}break}}while(n<s&&o<a);G=R>>3,n-=G,R-=G<<3,_&=(1<<R)-1,e.next_in=n,e.next_out=o,e.avail_in=n<s?5+(s-n):5-(n-s),e.avail_out=o<a?257+(a-o):257-(o-a),c.hold=_,c.bits=R}});var WK=ts((yOe,BK)=>{"use strict";var eRt=new Uint16Array([3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258,0,0]),iRt=new Uint8Array([16,16,16,16,16,16,16,16,17,17,17,17,18,18,18,18,19,19,19,19,20,20,20,20,21,21,21,21,16,72,78]),nRt=new Uint16Array([1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577,0,0]),sRt=new Uint8Array([16,16,16,16,17,17,18,18,19,19,20,20,21,21,22,22,23,23,24,24,25,25,26,26,27,27,28,28,29,29,64,64]),oRt=(t,e,i,n,s,o,r,a)=>{let h=a.bits,A=0,d=0,f=0,E=0,_=0,R=0,I=0,C=0,N=0,T=0,F,b,G,M,Q,U=null,k,y=new Uint16Array(16),c=new Uint16Array(16),g=null,V,D,w;for(A=0;A<=15;A++)y[A]=0;for(d=0;d<n;d++)y[e[i+d]]++;for(_=h,E=15;E>=1&&y[E]===0;E--);if(_>E&&(_=E),E===0)return s[o++]=1<<24|64<<16|0,s[o++]=1<<24|64<<16|0,a.bits=1,0;for(f=1;f<E&&y[f]===0;f++);for(_<f&&(_=f),C=1,A=1;A<=15;A++)if(C<<=1,C-=y[A],C<0)return-1;if(C>0&&(t===0||E!==1))return-1;for(c[1]=0,A=1;A<15;A++)c[A+1]=c[A]+y[A];for(d=0;d<n;d++)e[i+d]!==0&&(r[c[e[i+d]]++]=d);if(t===0?(U=g=r,k=20):t===1?(U=eRt,g=iRt,k=257):(U=nRt,g=sRt,k=0),T=0,d=0,A=f,Q=o,R=_,I=0,G=-1,N=1<<_,M=N-1,t===1&&N>852||t===2&&N>592)return 1;for(;;){V=A-I,r[d]+1<k?(D=0,w=r[d]):r[d]>=k?(D=g[r[d]-k],w=U[r[d]-k]):(D=96,w=0),F=1<<A-I,b=1<<R,f=b;do b-=F,s[Q+(T>>I)+b]=V<<24|D<<16|w|0;while(b!==0);for(F=1<<A-1;T&F;)F>>=1;if(F!==0?(T&=F-1,T+=F):T=0,d++,--y[A]===0){if(A===E)break;A=e[i+r[d]]}if(A>_&&(T&M)!==G){for(I===0&&(I=_),Q+=f,R=A-I,C=1<<R;R+I<E&&(C-=y[R+I],!(C<=0));)R++,C<<=1;if(N+=1<<R,t===1&&N>852||t===2&&N>592)return 1;G=T&M,s[G]=_<<24|R<<16|Q-o|0}}return T!==0&&(s[Q+T]=A-I<<24|64<<16|0),a.bits=_,0};BK.exports=oRt});var Wg=ts((wOe,DK)=>{"use strict";DK.exports={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_TREES:6,Z_OK:0,Z_STREAM_END:1,Z_NEED_DICT:2,Z_ERRNO:-1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_MEM_ERROR:-4,Z_BUF_ERROR:-5,Z_NO_COMPRESSION:0,Z_BEST_SPEED:1,Z_BEST_COMPRESSION:9,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8}});var _X=ts((xOe,va)=>{"use strict";var cB=YK(),UA=OK(),rRt=GK(),LR=WK(),aRt=0,aX=1,AX=2,{Z_FINISH:MK,Z_BLOCK:ARt,Z_TREES:Dg,Z_OK:Nd,Z_STREAM_END:hRt,Z_NEED_DICT:cRt,Z_STREAM_ERROR:ra,Z_DATA_ERROR:hX,Z_MEM_ERROR:lB,Z_BUF_ERROR:lRt,Z_DEFLATED:UK}=Wg(),kg=16180,QK=16181,kK=16182,LK=16183,yK=16184,wK=16185,xK=16186,PK=16187,JK=16188,jK=16189,Qg=16190,Bh=16191,oB=16192,HK=16193,rB=16194,vK=16195,zK=16196,KK=16197,XK=16198,Mg=16199,Ug=16200,qK=16201,$K=16202,tX=16203,eX=16204,iX=16205,aB=16206,nX=16207,sX=16208,$n=16209,dB=16210,cX=16211,dRt=852,mRt=592,fRt=15,ERt=fRt,oX=t=>(t>>>24&255)+(t>>>8&65280)+((t&65280)<<8)+((t&255)<<24);function _Rt(){this.strm=null,this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,this.flags=0,this.dmax=0,this.check=0,this.total=0,this.head=null,this.wbits=0,this.wsize=0,this.whave=0,this.wnext=0,this.window=null,this.hold=0,this.bits=0,this.length=0,this.offset=0,this.extra=0,this.lencode=null,this.distcode=null,this.lenbits=0,this.distbits=0,this.ncode=0,this.nlen=0,this.ndist=0,this.have=0,this.next=null,this.lens=new Uint16Array(320),this.work=new Uint16Array(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}var bd=t=>{if(!t)return 1;let e=t.state;return!e||e.strm!==t||e.mode<kg||e.mode>cX?1:0},lX=t=>{if(bd(t))return ra;let e=t.state;return t.total_in=t.total_out=e.total=0,t.msg="",e.wrap&&(t.adler=e.wrap&1),e.mode=kg,e.last=0,e.havedict=0,e.flags=-1,e.dmax=32768,e.head=null,e.hold=0,e.bits=0,e.lencode=e.lendyn=new Int32Array(dRt),e.distcode=e.distdyn=new Int32Array(mRt),e.sane=1,e.back=-1,Nd},dX=t=>{if(bd(t))return ra;let e=t.state;return e.wsize=0,e.whave=0,e.wnext=0,lX(t)},mX=(t,e)=>{let i;if(bd(t))return ra;let n=t.state;return e<0?(i=0,e=-e):(i=(e>>4)+5,e<48&&(e&=15)),e&&(e<8||e>15)?ra:(n.window!==null&&n.wbits!==e&&(n.window=null),n.wrap=i,n.wbits=e,dX(t))},fX=(t,e)=>{if(!t)return ra;let i=new _Rt;t.state=i,i.strm=t,i.window=null,i.mode=kg;let n=mX(t,e);return n!==Nd&&(t.state=null),n},RRt=t=>fX(t,ERt),rX=!0,AB,hB,ZRt=t=>{if(rX){AB=new Int32Array(512),hB=new Int32Array(32);let e=0;for(;e<144;)t.lens[e++]=8;for(;e<256;)t.lens[e++]=9;for(;e<280;)t.lens[e++]=7;for(;e<288;)t.lens[e++]=8;for(LR(aX,t.lens,0,288,AB,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;LR(AX,t.lens,0,32,hB,0,t.work,{bits:5}),rX=!1}t.lencode=AB,t.lenbits=9,t.distcode=hB,t.distbits=5},EX=(t,e,i,n)=>{let s,o=t.state;return o.window===null&&(o.wsize=1<<o.wbits,o.wnext=0,o.whave=0,o.window=new Uint8Array(o.wsize)),n>=o.wsize?(o.window.set(e.subarray(i-o.wsize,i),0),o.wnext=0,o.whave=o.wsize):(s=o.wsize-o.wnext,s>n&&(s=n),o.window.set(e.subarray(i-n,i-n+s),o.wnext),n-=s,n?(o.window.set(e.subarray(i-n,i),0),o.wnext=n,o.whave=o.wsize):(o.wnext+=s,o.wnext===o.wsize&&(o.wnext=0),o.whave<o.wsize&&(o.whave+=s))),0},IRt=(t,e)=>{let i,n,s,o,r,a,h,A,d,f,E,_,R,I,C=0,N,T,F,b,G,M,Q,U,k=new Uint8Array(4),y,c,g=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(bd(t)||!t.output||!t.input&&t.avail_in!==0)return ra;i=t.state,i.mode===Bh&&(i.mode=oB),r=t.next_out,s=t.output,h=t.avail_out,o=t.next_in,n=t.input,a=t.avail_in,A=i.hold,d=i.bits,f=a,E=h,U=Nd;t:for(;;)switch(i.mode){case kg:if(i.wrap===0){i.mode=oB;break}for(;d<16;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(i.wrap&2&&A===35615){i.wbits===0&&(i.wbits=15),i.check=0,k[0]=A&255,k[1]=A>>>8&255,i.check=UA(i.check,k,2,0),A=0,d=0,i.mode=QK;break}if(i.head&&(i.head.done=!1),!(i.wrap&1)||(((A&255)<<8)+(A>>8))%31){t.msg="incorrect header check",i.mode=$n;break}if((A&15)!==UK){t.msg="unknown compression method",i.mode=$n;break}if(A>>>=4,d-=4,Q=(A&15)+8,i.wbits===0&&(i.wbits=Q),Q>15||Q>i.wbits){t.msg="invalid window size",i.mode=$n;break}i.dmax=1<<i.wbits,i.flags=0,t.adler=i.check=1,i.mode=A&512?jK:Bh,A=0,d=0;break;case QK:for(;d<16;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(i.flags=A,(i.flags&255)!==UK){t.msg="unknown compression method",i.mode=$n;break}if(i.flags&57344){t.msg="unknown header flags set",i.mode=$n;break}i.head&&(i.head.text=A>>8&1),i.flags&512&&i.wrap&4&&(k[0]=A&255,k[1]=A>>>8&255,i.check=UA(i.check,k,2,0)),A=0,d=0,i.mode=kK;case kK:for(;d<32;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.head&&(i.head.time=A),i.flags&512&&i.wrap&4&&(k[0]=A&255,k[1]=A>>>8&255,k[2]=A>>>16&255,k[3]=A>>>24&255,i.check=UA(i.check,k,4,0)),A=0,d=0,i.mode=LK;case LK:for(;d<16;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.head&&(i.head.xflags=A&255,i.head.os=A>>8),i.flags&512&&i.wrap&4&&(k[0]=A&255,k[1]=A>>>8&255,i.check=UA(i.check,k,2,0)),A=0,d=0,i.mode=yK;case yK:if(i.flags&1024){for(;d<16;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.length=A,i.head&&(i.head.extra_len=A),i.flags&512&&i.wrap&4&&(k[0]=A&255,k[1]=A>>>8&255,i.check=UA(i.check,k,2,0)),A=0,d=0}else i.head&&(i.head.extra=null);i.mode=wK;case wK:if(i.flags&1024&&(_=i.length,_>a&&(_=a),_&&(i.head&&(Q=i.head.extra_len-i.length,i.head.extra||(i.head.extra=new Uint8Array(i.head.extra_len)),i.head.extra.set(n.subarray(o,o+_),Q)),i.flags&512&&i.wrap&4&&(i.check=UA(i.check,n,_,o)),a-=_,o+=_,i.length-=_),i.length))break t;i.length=0,i.mode=xK;case xK:if(i.flags&2048){if(a===0)break t;_=0;do Q=n[o+_++],i.head&&Q&&i.length<65536&&(i.head.name+=String.fromCharCode(Q));while(Q&&_<a);if(i.flags&512&&i.wrap&4&&(i.check=UA(i.check,n,_,o)),a-=_,o+=_,Q)break t}else i.head&&(i.head.name=null);i.length=0,i.mode=PK;case PK:if(i.flags&4096){if(a===0)break t;_=0;do Q=n[o+_++],i.head&&Q&&i.length<65536&&(i.head.comment+=String.fromCharCode(Q));while(Q&&_<a);if(i.flags&512&&i.wrap&4&&(i.check=UA(i.check,n,_,o)),a-=_,o+=_,Q)break t}else i.head&&(i.head.comment=null);i.mode=JK;case JK:if(i.flags&512){for(;d<16;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(i.wrap&4&&A!==(i.check&65535)){t.msg="header crc mismatch",i.mode=$n;break}A=0,d=0}i.head&&(i.head.hcrc=i.flags>>9&1,i.head.done=!0),t.adler=i.check=0,i.mode=Bh;break;case jK:for(;d<32;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}t.adler=i.check=oX(A),A=0,d=0,i.mode=Qg;case Qg:if(i.havedict===0)return t.next_out=r,t.avail_out=h,t.next_in=o,t.avail_in=a,i.hold=A,i.bits=d,cRt;t.adler=i.check=1,i.mode=Bh;case Bh:if(e===ARt||e===Dg)break t;case oB:if(i.last){A>>>=d&7,d-=d&7,i.mode=aB;break}for(;d<3;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}switch(i.last=A&1,A>>>=1,d-=1,A&3){case 0:i.mode=HK;break;case 1:if(ZRt(i),i.mode=Mg,e===Dg){A>>>=2,d-=2;break t}break;case 2:i.mode=zK;break;case 3:t.msg="invalid block type",i.mode=$n}A>>>=2,d-=2;break;case HK:for(A>>>=d&7,d-=d&7;d<32;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if((A&65535)!==(A>>>16^65535)){t.msg="invalid stored block lengths",i.mode=$n;break}if(i.length=A&65535,A=0,d=0,i.mode=rB,e===Dg)break t;case rB:i.mode=vK;case vK:if(_=i.length,_){if(_>a&&(_=a),_>h&&(_=h),_===0)break t;s.set(n.subarray(o,o+_),r),a-=_,o+=_,h-=_,r+=_,i.length-=_;break}i.mode=Bh;break;case zK:for(;d<14;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(i.nlen=(A&31)+257,A>>>=5,d-=5,i.ndist=(A&31)+1,A>>>=5,d-=5,i.ncode=(A&15)+4,A>>>=4,d-=4,i.nlen>286||i.ndist>30){t.msg="too many length or distance symbols",i.mode=$n;break}i.have=0,i.mode=KK;case KK:for(;i.have<i.ncode;){for(;d<3;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.lens[g[i.have++]]=A&7,A>>>=3,d-=3}for(;i.have<19;)i.lens[g[i.have++]]=0;if(i.lencode=i.lendyn,i.lenbits=7,y={bits:i.lenbits},U=LR(aRt,i.lens,0,19,i.lencode,0,i.work,y),i.lenbits=y.bits,U){t.msg="invalid code lengths set",i.mode=$n;break}i.have=0,i.mode=XK;case XK:for(;i.have<i.nlen+i.ndist;){for(;C=i.lencode[A&(1<<i.lenbits)-1],N=C>>>24,T=C>>>16&255,F=C&65535,!(N<=d);){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(F<16)A>>>=N,d-=N,i.lens[i.have++]=F;else{if(F===16){for(c=N+2;d<c;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(A>>>=N,d-=N,i.have===0){t.msg="invalid bit length repeat",i.mode=$n;break}Q=i.lens[i.have-1],_=3+(A&3),A>>>=2,d-=2}else if(F===17){for(c=N+3;d<c;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}A>>>=N,d-=N,Q=0,_=3+(A&7),A>>>=3,d-=3}else{for(c=N+7;d<c;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}A>>>=N,d-=N,Q=0,_=11+(A&127),A>>>=7,d-=7}if(i.have+_>i.nlen+i.ndist){t.msg="invalid bit length repeat",i.mode=$n;break}for(;_--;)i.lens[i.have++]=Q}}if(i.mode===$n)break;if(i.lens[256]===0){t.msg="invalid code -- missing end-of-block",i.mode=$n;break}if(i.lenbits=9,y={bits:i.lenbits},U=LR(aX,i.lens,0,i.nlen,i.lencode,0,i.work,y),i.lenbits=y.bits,U){t.msg="invalid literal/lengths set",i.mode=$n;break}if(i.distbits=6,i.distcode=i.distdyn,y={bits:i.distbits},U=LR(AX,i.lens,i.nlen,i.ndist,i.distcode,0,i.work,y),i.distbits=y.bits,U){t.msg="invalid distances set",i.mode=$n;break}if(i.mode=Mg,e===Dg)break t;case Mg:i.mode=Ug;case Ug:if(a>=6&&h>=258){t.next_out=r,t.avail_out=h,t.next_in=o,t.avail_in=a,i.hold=A,i.bits=d,rRt(t,E),r=t.next_out,s=t.output,h=t.avail_out,o=t.next_in,n=t.input,a=t.avail_in,A=i.hold,d=i.bits,i.mode===Bh&&(i.back=-1);break}for(i.back=0;C=i.lencode[A&(1<<i.lenbits)-1],N=C>>>24,T=C>>>16&255,F=C&65535,!(N<=d);){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(T&&!(T&240)){for(b=N,G=T,M=F;C=i.lencode[M+((A&(1<<b+G)-1)>>b)],N=C>>>24,T=C>>>16&255,F=C&65535,!(b+N<=d);){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}A>>>=b,d-=b,i.back+=b}if(A>>>=N,d-=N,i.back+=N,i.length=F,T===0){i.mode=iX;break}if(T&32){i.back=-1,i.mode=Bh;break}if(T&64){t.msg="invalid literal/length code",i.mode=$n;break}i.extra=T&15,i.mode=qK;case qK:if(i.extra){for(c=i.extra;d<c;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.length+=A&(1<<i.extra)-1,A>>>=i.extra,d-=i.extra,i.back+=i.extra}i.was=i.length,i.mode=$K;case $K:for(;C=i.distcode[A&(1<<i.distbits)-1],N=C>>>24,T=C>>>16&255,F=C&65535,!(N<=d);){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(!(T&240)){for(b=N,G=T,M=F;C=i.distcode[M+((A&(1<<b+G)-1)>>b)],N=C>>>24,T=C>>>16&255,F=C&65535,!(b+N<=d);){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}A>>>=b,d-=b,i.back+=b}if(A>>>=N,d-=N,i.back+=N,T&64){t.msg="invalid distance code",i.mode=$n;break}i.offset=F,i.extra=T&15,i.mode=tX;case tX:if(i.extra){for(c=i.extra;d<c;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.offset+=A&(1<<i.extra)-1,A>>>=i.extra,d-=i.extra,i.back+=i.extra}if(i.offset>i.dmax){t.msg="invalid distance too far back",i.mode=$n;break}i.mode=eX;case eX:if(h===0)break t;if(_=E-h,i.offset>_){if(_=i.offset-_,_>i.whave&&i.sane){t.msg="invalid distance too far back",i.mode=$n;break}_>i.wnext?(_-=i.wnext,R=i.wsize-_):R=i.wnext-_,_>i.length&&(_=i.length),I=i.window}else I=s,R=r-i.offset,_=i.length;_>h&&(_=h),h-=_,i.length-=_;do s[r++]=I[R++];while(--_);i.length===0&&(i.mode=Ug);break;case iX:if(h===0)break t;s[r++]=i.length,h--,i.mode=Ug;break;case aB:if(i.wrap){for(;d<32;){if(a===0)break t;a--,A|=n[o++]<<d,d+=8}if(E-=h,t.total_out+=E,i.total+=E,i.wrap&4&&E&&(t.adler=i.check=i.flags?UA(i.check,s,E,r-E):cB(i.check,s,E,r-E)),E=h,i.wrap&4&&(i.flags?A:oX(A))!==i.check){t.msg="incorrect data check",i.mode=$n;break}A=0,d=0}i.mode=nX;case nX:if(i.wrap&&i.flags){for(;d<32;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(i.wrap&4&&A!==(i.total&4294967295)){t.msg="incorrect length check",i.mode=$n;break}A=0,d=0}i.mode=sX;case sX:U=hRt;break t;case $n:U=hX;break t;case dB:return lB;case cX:default:return ra}return t.next_out=r,t.avail_out=h,t.next_in=o,t.avail_in=a,i.hold=A,i.bits=d,(i.wsize||E!==t.avail_out&&i.mode<$n&&(i.mode<aB||e!==MK))&&EX(t,t.output,t.next_out,E-t.avail_out)?(i.mode=dB,lB):(f-=t.avail_in,E-=t.avail_out,t.total_in+=f,t.total_out+=E,i.total+=E,i.wrap&4&&E&&(t.adler=i.check=i.flags?UA(i.check,s,E,t.next_out-E):cB(i.check,s,E,t.next_out-E)),t.data_type=i.bits+(i.last?64:0)+(i.mode===Bh?128:0)+(i.mode===Mg||i.mode===rB?256:0),(f===0&&E===0||e===MK)&&U===Nd&&(U=lRt),U)},pRt=t=>{if(bd(t))return ra;let e=t.state;return e.window&&(e.window=null),t.state=null,Nd},uRt=(t,e)=>{if(bd(t))return ra;let i=t.state;return i.wrap&2?(i.head=e,e.done=!1,Nd):ra},CRt=(t,e)=>{let i=e.length,n,s,o;return bd(t)||(n=t.state,n.wrap!==0&&n.mode!==Qg)?ra:n.mode===Qg&&(s=1,s=cB(s,e,i,0),s!==n.check)?hX:(o=EX(t,e,i,i),o?(n.mode=dB,lB):(n.havedict=1,Nd))};va.exports.inflateReset=dX;va.exports.inflateReset2=mX;va.exports.inflateResetKeep=lX;va.exports.inflateInit=RRt;va.exports.inflateInit2=fX;va.exports.inflate=IRt;va.exports.inflateEnd=pRt;va.exports.inflateGetHeader=uRt;va.exports.inflateSetDictionary=CRt;va.exports.inflateInfo="pako inflate (from Nodeca project)"});var RX=ts((POe,mB)=>{"use strict";var gRt=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);mB.exports.assign=function(t){let e=Array.prototype.slice.call(arguments,1);for(;e.length;){let i=e.shift();if(i){if(typeof i!="object")throw new TypeError(i+"must be non-object");for(let n in i)gRt(i,n)&&(t[n]=i[n])}}return t};mB.exports.flattenChunks=t=>{let e=0;for(let n=0,s=t.length;n<s;n++)e+=t[n].length;let i=new Uint8Array(e);for(let n=0,s=0,o=t.length;n<o;n++){let r=t[n];i.set(r,s),s+=r.length}return i}});var IX=ts((JOe,Lg)=>{"use strict";var ZX=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch{ZX=!1}var yR=new Uint8Array(256);for(let t=0;t<256;t++)yR[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;yR[254]=yR[254]=1;Lg.exports.string2buf=t=>{if(typeof TextEncoder=="function"&&TextEncoder.prototype.encode)return new TextEncoder().encode(t);let e,i,n,s,o,r=t.length,a=0;for(s=0;s<r;s++)i=t.charCodeAt(s),(i&64512)===55296&&s+1<r&&(n=t.charCodeAt(s+1),(n&64512)===56320&&(i=65536+(i-55296<<10)+(n-56320),s++)),a+=i<128?1:i<2048?2:i<65536?3:4;for(e=new Uint8Array(a),o=0,s=0;o<a;s++)i=t.charCodeAt(s),(i&64512)===55296&&s+1<r&&(n=t.charCodeAt(s+1),(n&64512)===56320&&(i=65536+(i-55296<<10)+(n-56320),s++)),i<128?e[o++]=i:i<2048?(e[o++]=192|i>>>6,e[o++]=128|i&63):i<65536?(e[o++]=224|i>>>12,e[o++]=128|i>>>6&63,e[o++]=128|i&63):(e[o++]=240|i>>>18,e[o++]=128|i>>>12&63,e[o++]=128|i>>>6&63,e[o++]=128|i&63);return e};var TRt=(t,e)=>{if(e<65534&&t.subarray&&ZX)return String.fromCharCode.apply(null,t.length===e?t:t.subarray(0,e));let i="";for(let n=0;n<e;n++)i+=String.fromCharCode(t[n]);return i};Lg.exports.buf2string=(t,e)=>{let i=e||t.length;if(typeof TextDecoder=="function"&&TextDecoder.prototype.decode)return new TextDecoder().decode(t.subarray(0,e));let n,s,o=new Array(i*2);for(s=0,n=0;n<i;){let r=t[n++];if(r<128){o[s++]=r;continue}let a=yR[r];if(a>4){o[s++]=65533,n+=a-1;continue}for(r&=a===2?31:a===3?15:7;a>1&&n<i;)r=r<<6|t[n++]&63,a--;if(a>1){o[s++]=65533;continue}r<65536?o[s++]=r:(r-=65536,o[s++]=55296|r>>10&1023,o[s++]=56320|r&1023)}return TRt(o,s)};Lg.exports.utf8border=(t,e)=>{e=e||t.length,e>t.length&&(e=t.length);let i=e-1;for(;i>=0&&(t[i]&192)===128;)i--;return i<0||i===0?e:i+yR[t[i]]>e?i:e}});var uX=ts((jOe,pX)=>{"use strict";pX.exports={2:"need dictionary",1:"stream end",0:"","-1":"file error","-2":"stream error","-3":"data error","-4":"insufficient memory","-5":"buffer error","-6":"incompatible version"}});var gX=ts((HOe,CX)=>{"use strict";function NRt(){this.input=null,this.next_in=0,this.avail_in=0,this.total_in=0,this.output=null,this.next_out=0,this.avail_out=0,this.total_out=0,this.msg="",this.state=null,this.data_type=2,this.adler=0}CX.exports=NRt});var NX=ts((vOe,TX)=>{"use strict";function bRt(){this.text=0,this.time=0,this.xflags=0,this.os=0,this.extra=null,this.extra_len=0,this.name="",this.comment="",this.hcrc=0,this.done=!1}TX.exports=bRt});var SX=ts((zOe,qf)=>{"use strict";var Wh=_X(),FX=RX(),_B=IX(),RB=uX(),FRt=gX(),YRt=NX(),YX=Object.prototype.toString,{Z_NO_FLUSH:SRt,Z_FINISH:ORt,Z_OK:wR,Z_STREAM_END:fB,Z_NEED_DICT:EB,Z_STREAM_ERROR:VRt,Z_DATA_ERROR:bX,Z_MEM_ERROR:GRt}=Wg();function xR(t){this.options=FX.assign({chunkSize:1024*64,windowBits:15,to:""},t||{});let e=this.options;e.raw&&e.windowBits>=0&&e.windowBits<16&&(e.windowBits=-e.windowBits,e.windowBits===0&&(e.windowBits=-15)),e.windowBits>=0&&e.windowBits<16&&!(t&&t.windowBits)&&(e.windowBits+=32),e.windowBits>15&&e.windowBits<48&&(e.windowBits&15||(e.windowBits|=15)),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new FRt,this.strm.avail_out=0;let i=Wh.inflateInit2(this.strm,e.windowBits);if(i!==wR)throw new Error(RB[i]);if(this.header=new YRt,Wh.inflateGetHeader(this.strm,this.header),e.dictionary&&(typeof e.dictionary=="string"?e.dictionary=_B.string2buf(e.dictionary):YX.call(e.dictionary)==="[object ArrayBuffer]"&&(e.dictionary=new Uint8Array(e.dictionary)),e.raw&&(i=Wh.inflateSetDictionary(this.strm,e.dictionary),i!==wR)))throw new Error(RB[i])}xR.prototype.push=function(t,e){let i=this.strm,n=this.options.chunkSize,s=this.options.dictionary,o,r,a;if(this.ended)return!1;for(e===~~e?r=e:r=e===!0?ORt:SRt,YX.call(t)==="[object ArrayBuffer]"?i.input=new Uint8Array(t):i.input=t,i.next_in=0,i.avail_in=i.input.length;;){for(i.avail_out===0&&(i.output=new Uint8Array(n),i.next_out=0,i.avail_out=n),o=Wh.inflate(i,r),o===EB&&s&&(o=Wh.inflateSetDictionary(i,s),o===wR?o=Wh.inflate(i,r):o===bX&&(o=EB));i.avail_in>0&&o===fB&&i.state.wrap>0&&t[i.next_in]!==0;)Wh.inflateReset(i),o=Wh.inflate(i,r);switch(o){case VRt:case bX:case EB:case GRt:return this.onEnd(o),this.ended=!0,!1}if(a=i.avail_out,i.next_out&&(i.avail_out===0||o===fB))if(this.options.to==="string"){let h=_B.utf8border(i.output,i.next_out),A=i.next_out-h,d=_B.buf2string(i.output,h);i.next_out=A,i.avail_out=n-A,A&&i.output.set(i.output.subarray(h,h+A),0),this.onData(d)}else this.onData(i.output.length===i.next_out?i.output:i.output.subarray(0,i.next_out));if(!(o===wR&&a===0)){if(o===fB)return o=Wh.inflateEnd(this.strm),this.onEnd(o),this.ended=!0,!0;if(i.avail_in===0)break}}return!0};xR.prototype.onData=function(t){this.chunks.push(t)};xR.prototype.onEnd=function(t){t===wR&&(this.options.to==="string"?this.result=this.chunks.join(""):this.result=FX.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};function ZB(t,e){let i=new xR(e);if(i.push(t),i.err)throw i.msg||RB[i.err];return i.result}function BRt(t,e){return e=e||{},e.raw=!0,ZB(t,e)}qf.exports.Inflate=xR;qf.exports.inflate=ZB;qf.exports.inflateRaw=BRt;qf.exports.ungzip=ZB;qf.exports.constants=Wg()});var IB={};He(IB,{default:()=>wRt});function WRt(t,e){let i=zc.fromString(t.type),n=t.buffer;uK(t.key,n);let s=yRt(n);n=s.buffer;let o=s.length;switch(i){case zc.METADATA:return MRt(n,o,t.quadKey);case zc.TERRAIN:return kRt(n,o,e);case zc.DBROOT:return e.push(n),{buffer:n}}}function MRt(t,e,i){let n=new DataView(t),s=0,o=n.getUint32(s,!0);if(s+=tE,o!==DRt)throw new ke("Invalid magic");let r=n.getUint32(s,!0);if(s+=tE,r!==1)throw new ke("Invalid data type. Must be 1 for QuadTreePacket");let a=n.getUint32(s,!0);if(s+=tE,a!==2)throw new ke("Invalid QuadTreePacket version. Only version 2 is supported.");let h=n.getInt32(s,!0);s+=Fd;let A=n.getInt32(s,!0);if(s+=Fd,A!==32)throw new ke("Invalid instance size.");let d=n.getInt32(s,!0);s+=Fd;let f=n.getInt32(s,!0);s+=Fd;let E=n.getInt32(s,!0);if(s+=Fd,d!==h*A+s)throw new ke("Invalid dataBufferOffset");if(d+f+E!==e)throw new ke("Invalid packet offsets");let _=[];for(let F=0;F<h;++F){let b=n.getUint8(s);++s,++s;let G=n.getUint16(s,!0);s+=$f;let M=n.getUint16(s,!0);s+=$f;let Q=n.getUint16(s,!0);s+=$f,s+=$f,s+=$f,s+=Fd,s+=Fd,s+=8;let U=n.getUint8(s++),k=n.getUint8(s++);s+=$f,_.push(new NK(b,G,M,Q,U,k))}let R=[],I=0;function C(F,b,G){let M=!1;if(G===4){if(b.hasSubtree())return;M=!0}for(let Q=0;Q<4;++Q){let U=F+Q.toString();if(M)R[U]=null;else if(G<4)if(!b.hasChild(Q))R[U]=null;else{if(I===h){console.log("Incorrect number of instances");return}let k=_[I++];R[U]=k,C(U,k,G+1)}}}let N=0,T=_[I++];return i===""?++N:R[i]=T,C(i,T,N),R}function kRt(t,e,i){let n=new DataView(t),s=function(a){for(let h=0;h<QRt;++h){let A=n.getUint32(a,!0);if(a+=tE,a+=A,a>e)throw new ke("Malformed terrain packet found.")}return a},o=0,r=[];for(;r.length<URt;){let a=o;o=s(o);let h=t.slice(a,o);i.push(h),r.push(h)}return r}function yRt(t){let e=new DataView(t),i=0,n=e.getUint32(i,!0);if(i+=tE,n!==OX&&n!==LRt)throw new ke("Invalid magic");let s=e.getUint32(i,n===OX);i+=tE;let o=new Uint8Array(t,i),r=VX.default.inflate(o);if(r.length!==s)throw new ke("Size of packet doesn't match header");return r}var VX,$f,Fd,tE,zc,DRt,URt,QRt,OX,LRt,wRt,pB=O(()=>{CK();bK();Ps();VX=co(SX(),1);Ns();$f=Uint16Array.BYTES_PER_ELEMENT,Fd=Int32Array.BYTES_PER_ELEMENT,tE=Uint32Array.BYTES_PER_ELEMENT,zc={METADATA:0,TERRAIN:1,DBROOT:2};zc.fromString=function(t){if(t==="Metadata")return zc.METADATA;if(t==="Terrain")return zc.TERRAIN;if(t==="DbRoot")return zc.DBROOT};DRt=32301;URt=5,QRt=4;OX=1953029805,LRt=2917034100;wRt=Wi(WRt)});function xRt(t){return p.defined("value",t),t<=.04045?t*.07739938080495357:Math.pow((t+.055)*.9478672985781991,2.4)}var yg,GX=O(()=>{ae();yg=xRt});var TB={};He(TB,{default:()=>EZt});function PRt(t,e,i,n,s,o){let r=i*(1-t)+n*t,a=s*(1-t)+o*t;return r*(1-e)+a*e}function wg(t,e,i,n){let s=t+e*i;return n[s]}function JRt(t,e,i){let n=i.nativeExtent,s=(t-n.west)/(n.east-n.west)*(i.width-1),o=(e-n.south)/(n.north-n.south)*(i.height-1),r=Math.floor(s),a=Math.floor(o);s-=r,o-=a;let h=r<i.width?r+1:r,A=a<i.height?a+1:a;a=i.height-1-a,A=i.height-1-A;let d=wg(r,a,i.width,i.buffer),f=wg(h,a,i.width,i.buffer),E=wg(r,A,i.width,i.buffer),_=wg(h,A,i.width,i.buffer),R=PRt(s,o,d,f,E,_);return R=R*i.scale+i.offset,R}function BX(t,e,i){for(let n=0;n<i.length;n++){let s=i[n].nativeExtent,o=new l;if(i[n].projectionType==="WebMercator"){let r=i[n].projection._ellipsoid._radii;o=new ks(new ot(r.x,r.y,r.z)).project(new ut(t,e,0))}else o.x=t,o.y=e;if(o.x>s.west&&o.x<s.east&&o.y>s.south&&o.y<s.north)return JRt(o.x,o.y,i[n])}return 0}function jRt(t,e,i,n,s,o,r){if(r)return;let a=BX(s.longitude,s.latitude,o);for(let h=0;h<t;++h){let A=BX(s.longitude+L.toRadians(i*e[h*3]),s.latitude+L.toRadians(n*e[h*3+1]),o);e[h*3+2]+=A-a}}function HRt(t,e,i,n,s,o,r,a,h){if(t===0||!m(e)||e.length===0)return;let A=new ot(Math.sqrt(r.x),Math.sqrt(r.y),Math.sqrt(r.z));for(let d=0;d<t;++d){let f=d*3,E=f+1,_=f+2,R=new ut;R.longitude=n.longitude+L.toRadians(a*e[f]),R.latitude=n.latitude+L.toRadians(h*e[E]),R.height=n.height+e[_];let I={};A.cartographicToCartesian(R,I),I.x-=s.x,I.y-=s.y,I.z-=s.z;let C={};if(lt.multiplyByVector(o,I,C),e[f]=C.x,e[E]=C.y,e[_]=C.z,m(i)){let N=new l(i[f],i[E],i[_]),T={};lt.multiplyByVector(o,N,T),i[f]=T.x,i[E]=T.y,i[_]=T.z}}}function vRt(t,e,i){for(let n=0;n<t;++n){let s=i[n*4]/65535,o=i[n*4+1]/65535,r=(i[n*4+2]-i[n*4])/65535,a=(i[n*4+3]-i[n*4+1])/65535;e[n*2]*=r,e[n*2]+=s,e[n*2+1]*=a,e[n*2+1]+=o}}function zRt(t,e,i,n){let s=new Uint32Array(t),o=m(e)?a=>e[a]:a=>a,r=0;if(n&&m(i)){let a=h=>i[o(h)*4+3]<255;for(let h=0;h<t;h+=3)!a(h)&&!a(h+1)&&!a(h+2)&&(s[r++]=o(h),s[r++]=o(h+1),s[r++]=o(h+2));if(r>0){let h=r;for(let A=0;A<t;A+=3)(a(A)||a(A+1)||a(A+2))&&(s[h++]=o(A),s[h++]=o(A+1),s[h++]=o(A+2))}else for(let h=0;h<t;++h)s[h]=o(h)}else{r=t;for(let a=0;a<t;++a)s[a]=o(a)}return{indexArray:s,transparentVertexOffset:r}}function KRt(t,e,i){let n=e[i];if(m(n))return n;let s=e[i]={positions:{},indices:{},edges:{}},o=Z(t[i],t.default);return s.hasOutline=m(o?.edges),s}function XRt(t,e,i,n){if(!m(t[i])){let s=i*3,o=e;for(let r=0;r<3;r++){let a=n[s+r];m(o[a])||(o[a]={}),o=o[a]}m(o.index)||(o.index=i),t[i]=o.index}}function qRt(t,e,i,n,s,o){let r,a;n<s?(r=n,a=s):(r=s,a=n);let h=t[r];m(h)||(h=t[r]={});let A=h[a];m(A)||(A=h[a]={normalsIndex:[],outlines:[]}),A.normalsIndex.push(o),(A.outlines.length===0||e!==n||i!==s)&&A.outlines.push(e,i)}function $Rt(t,e,i,n){let s=[];for(let o=0;o<i.length;o+=3){let r=m(e)?e[i[o]]:"default",a=KRt(t,s,r);if(!a.hasOutline)continue;let h=a.indices,A=a.positions;for(let f=0;f<3;f++){let E=i[o+f];XRt(h,A,E,n)}let d=a.edges;for(let f=0;f<3;f++){let E=i[o+f],_=i[o+(f+1)%3],R=h[E],I=h[_];qRt(d,E,_,R,I,o)}}return s}function WX(t,e,i,n){let s=i[e]*3,o=i[e+1]*3,r=i[e+2]*3;l.fromArray(n,s,QA),l.fromArray(n,o,xg),l.fromArray(n,r,Pg),l.subtract(xg,QA,xg),l.subtract(Pg,QA,Pg),l.cross(xg,Pg,QA);let a=l.magnitude(QA);a!==0&&l.divideByScalar(QA,a,QA);let h=e*3,A=(e+1)*3,d=(e+2)*3;l.pack(QA,t,h),l.pack(QA,t,A),l.pack(QA,t,d)}function tZt(t,e,i){l.fromArray(t,e,Jg),l.fromArray(t,i,uB);let n=l.dot(Jg,uB),s=l.magnitude(l.cross(Jg,uB,Jg));return Math.atan2(s,n)<.25}function eZt(t,e,i,n,s){if(e.normalsIndex.length>1){let o=n.length===s.length;for(let r=0;r<e.normalsIndex.length;r++){let a=e.normalsIndex[r];if(m(s[a*3])||WX(s,a,i,n),r!==0)for(let h=0;h<r;h++){let A=e.normalsIndex[h],d=o?i[a]*3:a*3,f=o?i[A]*3:A*3;if(tZt(s,d,f))return}}}t.push(...e.outlines)}function iZt(t,e,i,n,s){let o=Object.keys(e);for(let r=0;r<o.length;r++){let a=e[o[r]],h=Object.keys(a);for(let A=0;A<h.length;A++){let d=a[h[A]];eZt(t,d,i,n,s)}}}function nZt(t,e,i,n){let s=[],o=Object.keys(t);for(let r=0;r<o.length;r++){let a=t[o[r]].edges;iZt(s,a,e,i,n)}return s}function sZt(t,e,i,n,s){if(!m(t)||Object.keys(t).length===0)return;let o=$Rt(t,e,i,n);(!m(s)||i.length*3!==s.length)&&(s=[]);let r=nZt(o,i,n,s);return r.length>0?new Uint32Array(r):void 0}function oZt(t){let e=new Float32Array(t.length);for(let i=0;i<t.length;i+=4)e[i]=yg(Zt.byteToFloat(t[i])),e[i+1]=yg(Zt.byteToFloat(t[i+1])),e[i+2]=yg(Zt.byteToFloat(t[i+2])),e[i+3]=Zt.byteToFloat(t[i+3]);return e}function rZt(t,e,i,n,s,o,r){let a={normals:void 0,positions:void 0,uv0s:void 0,colors:void 0,featureIndex:void 0,vertexCount:void 0};if(t===0||!m(i)||i.length===0||m(n))return a;if(m(e)){a.vertexCount=e.length,a.positions=new Float32Array(e.length*3),a.uv0s=m(s)?new Float32Array(e.length*2):void 0,a.colors=m(o)?new Uint8Array(e.length*4):void 0,a.featureIndex=m(r)?new Array(e.length):void 0;for(let h=0;h<e.length;h++){let A=e[h];a.positions[h*3]=i[A*3],a.positions[h*3+1]=i[A*3+1],a.positions[h*3+2]=i[A*3+2],m(a.uv0s)&&(a.uv0s[h*2]=s[A*2],a.uv0s[h*2+1]=s[A*2+1]),m(a.colors)&&(a.colors[h*4]=o[A*4],a.colors[h*4+1]=o[A*4+1],a.colors[h*4+2]=o[A*4+2],a.colors[h*4+3]=o[A*4+3]),m(a.featureIndex)&&(a.featureIndex[h]=r[A])}t=e.length,i=a.positions}e=new Array(t);for(let h=0;h<t;h++)e[h]=h;a.normals=new Float32Array(e.length*3);for(let h=0;h<e.length;h+=3)WX(a.normals,h,e,i);return a}function aZt(t,e,i,n,s,o,r,a){if(t===0||!m(i)||i.length===0)return{buffers:[],bufferViews:[],accessors:[],meshes:[],nodes:[],nodesInScene:[]};let h=[],A=[],d=[],f=[],E=[],_=[],R={},I=[];m(e)&&(t=e.length);let{indexArray:C,transparentVertexOffset:N}=zRt(t,e,o,a.splitGeometryByColorTransparency),T=new Blob([C],{type:"application/binary"}),F=URL.createObjectURL(T),b=t,G=a.enableFeatures&&m(r)?new Float32Array(r.length):void 0,M=0;if(m(G))for(let Ft=0;Ft<r.length;++Ft){G[Ft]=r[Ft];let ee=r[Ft]+1;M<ee&&(M=ee)}let Q,U=sZt(a.symbologyData,r,C,i,n);if(m(U)){let Ft=new Blob([U],{type:"application/binary"});Q=URL.createObjectURL(Ft)}let k=i.subarray(0,b*3),y=new Blob([k],{type:"application/binary"}),c=URL.createObjectURL(y),g=Number.POSITIVE_INFINITY,V=Number.NEGATIVE_INFINITY,D=Number.POSITIVE_INFINITY,w=Number.NEGATIVE_INFINITY,x=Number.POSITIVE_INFINITY,H=Number.NEGATIVE_INFINITY;for(let Ft=0;Ft<k.length/3;Ft++)g=Math.min(g,k[Ft*3+0]),V=Math.max(V,k[Ft*3+0]),D=Math.min(D,k[Ft*3+1]),w=Math.max(w,k[Ft*3+1]),x=Math.min(x,k[Ft*3+2]),H=Math.max(H,k[Ft*3+2]);let j=n?n.subarray(0,b*3):void 0,X;if(m(j)){let Ft=new Blob([j],{type:"application/binary"});X=URL.createObjectURL(Ft)}let tt=s?s.subarray(0,b*2):void 0,B;if(m(tt)){let Ft=new Blob([tt],{type:"application/binary"});B=URL.createObjectURL(Ft)}let It=m(o)?oZt(o.subarray(0,b*4)):void 0,gt;if(m(It)){let Ft=new Blob([It],{type:"application/binary"});gt=URL.createObjectURL(Ft)}let Yt=m(G)?G.subarray(0,b):void 0,Mt;if(m(Yt)){let Ft=new Blob([Yt],{type:"application/binary"});Mt=URL.createObjectURL(Ft)}let Ct=m(G)?new Float32Array(M):void 0,zt;if(m(Ct)){for(let ee=0;ee<Ct.length;++ee)Ct[ee]=ee;let Ft=new Blob([Ct],{type:"application/binary"});zt=URL.createObjectURL(Ft)}let kt={},Jt={};kt.POSITION=d.length,h.push({uri:c,byteLength:k.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:k.byteLength,target:34962}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5126,count:k.length/3,type:"VEC3",max:[g,D,x],min:[V,w,H]}),m(X)&&(kt.NORMAL=d.length,h.push({uri:X,byteLength:j.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:j.byteLength,target:34962}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5126,count:j.length/3,type:"VEC3"})),m(B)&&(kt.TEXCOORD_0=d.length,h.push({uri:B,byteLength:tt.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:tt.byteLength,target:34962}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5126,count:tt.length/2,type:"VEC2"})),m(gt)&&(kt.COLOR_0=d.length,h.push({uri:gt,byteLength:It.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:It.byteLength,target:34962}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5126,count:It.length/4,type:"VEC4"})),m(Mt)&&(kt._FEATURE_ID_0=d.length,h.push({uri:Mt,byteLength:Yt.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:Yt.byteLength,target:34963}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5126,count:Yt.length,type:"SCALAR"}),Jt.EXT_mesh_features={featureIds:[{attribute:0,propertyTable:0,featureCount:M}]},I.push("EXT_mesh_features")),m(zt)&&(h.push({uri:zt,byteLength:Ct.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:Ct.byteLength,target:34963}),R.EXT_structural_metadata={schema:{id:"i3s-metadata-schema-001",name:"I3S metadata schema 001",description:"The schema for I3S metadata",version:"1.0",classes:{feature:{name:"feature",description:"Feature metadata",properties:{index:{description:"The feature index",type:"SCALAR",componentType:"FLOAT32",required:!0}}}}},propertyTables:[{name:"feature-indices-mapping",class:"feature",count:M,properties:{index:{values:A.length-1}}}]},I.push("EXT_structural_metadata")),m(Q)&&(h.push({uri:Q,byteLength:U.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:U.byteLength,target:34963}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5125,count:U.length,type:"SCALAR"}),Jt.CESIUM_primitive_outline={indices:d.length-1},I.push("CESIUM_primitive_outline")),h.push({uri:F,byteLength:C.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:C.byteLength,target:34963});let Wt=[];return N>0&&(d.push({bufferView:A.length-1,byteOffset:0,componentType:5125,count:N,type:"SCALAR"}),Wt.push({attributes:kt,indices:d.length-1,material:Wt.length,extensions:Jt})),N<t&&(d.push({bufferView:A.length-1,byteOffset:4*N,componentType:5125,count:t-N,type:"SCALAR"}),Wt.push({attributes:kt,indices:d.length-1,material:Wt.length,extensions:Jt,extra:{isTransparent:!0}})),f.push({primitives:Wt}),_.push(0),E.push({mesh:0}),{buffers:h,bufferViews:A,accessors:d,meshes:f,nodes:E,nodesInScene:_,rootExtensions:R,extensionsUsed:I}}function AZt(t,e,i,n){let s=new Uint8Array(t,0,5);return s[0]===68&&s[1]===82&&s[2]===65&&s[3]===67&&s[4]===79?hZt(t,i):lZt(t,e,i,n)}function hZt(t){let e=gB,i=new e.DecoderBuffer,n=new Uint8Array(t);i.Init(n,n.length);let s=new e.Decoder,o=s.GetEncodedGeometryType(i),r=new e.MetadataQuerier,a,h;o===e.TRIANGULAR_MESH&&(a=new e.Mesh,h=s.DecodeBufferToMesh(i,a));let A={vertexCount:[0],featureCount:0};if(m(h)&&h.ok()&&a.ptr!==0){let d=a.num_faces(),f=a.num_attributes(),E=a.num_points();A.indices=new Uint32Array(d*3);let _=A.indices;A.vertexCount[0]=E,A.scale_x=1,A.scale_y=1;let R=new e.DracoInt32Array(3);for(let I=0;I<d;++I)s.GetFaceFromMesh(a,I,R),_[I*3]=R.GetValue(0),_[I*3+1]=R.GetValue(1),_[I*3+2]=R.GetValue(2);e.destroy(R);for(let I=0;I<f;++I){let C=s.GetAttribute(a,I),N=cZt(e,s,a,C,E),T=C.attribute_type(),F="unknown";T===e.POSITION?F="positions":T===e.NORMAL?F="normals":T===e.COLOR?F="colors":T===e.TEX_COORD&&(F="uv0s");let b=s.GetAttributeMetadata(a,I);if(b.ptr!==0){let G=r.NumEntries(b);for(let M=0;M<G;++M){let Q=r.GetEntryName(b,M);Q==="i3s-scale_x"?A.scale_x=r.GetDoubleEntry(b,"i3s-scale_x"):Q==="i3s-scale_y"?A.scale_y=r.GetDoubleEntry(b,"i3s-scale_y"):Q==="i3s-attribute-type"&&(F=r.GetStringEntry(b,"i3s-attribute-type"))}}m(A[F])&&console.log("Attribute already exists",F),A[F]=N,F==="feature-index"&&A.featureCount++}e.destroy(a)}return e.destroy(r),e.destroy(s),A}function cZt(t,e,i,n,s){let o=n.num_components()*s,r,h=[function(){},function(){r=new t.DracoInt8Array(o),e.GetAttributeInt8ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Int8Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){r=new t.DracoInt8Array(o),e.GetAttributeUInt8ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Uint8Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){r=new t.DracoInt16Array(o),e.GetAttributeInt16ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Int16Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){r=new t.DracoInt16Array(o),e.GetAttributeUInt16ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Uint16Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){r=new t.DracoInt32Array(o),e.GetAttributeInt32ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Int32Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){r=new t.DracoInt32Array(o),e.GetAttributeUInt32ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Uint32Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){},function(){},function(){r=new t.DracoFloat32Array(o),e.GetAttributeFloatForAllPoints(i,n,r)||console.error("Bad stream");let d=new Float32Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){},function(){r=new t.DracoUInt8Array(o),e.GetAttributeUInt8ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Uint8Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d}][n.data_type()]();return m(r)&&t.destroy(r),h}function lZt(t,e,i,n){let s={vertexCount:0},o=new DataView(t);try{let r=0;if(s.vertexCount=o.getUint32(r,1),r+=4,s.featureCount=o.getUint32(r,1),r+=4,m(i))for(let a=0;a<i.attributes.length;a++)m(jg[i.attributes[a]])?r=jg[i.attributes[a]](s,t,r):console.error("Unknown decoder for",i.attributes[a]);else{let a=e.ordering,h=e.featureAttributeOrder;m(n)&&m(n.geometryData)&&m(n.geometryData[0])&&m(n.geometryData[0].params)&&(a=Object.keys(n.geometryData[0].params.vertexAttributes),h=Object.keys(n.geometryData[0].params.featureAttributes));for(let A=0;A<a.length;A++){let d=jg[a[A]];r=d(s,t,r)}for(let A=0;A<h.length;A++){let d=jg[h[A]];r=d(s,t,r)}}}catch(r){console.error(r)}return s.scale_x=1,s.scale_y=1,s}function dZt(t){let e=AZt(t.binaryData,t.schema,t.bufferInfo,t.featureData);m(t.geoidDataList)&&t.geoidDataList.length>0&&jRt(e.vertexCount,e.positions,e.scale_x,e.scale_y,t.cartographicCenter,t.geoidDataList,!1),HRt(e.vertexCount,e.positions,e.normals,t.cartographicCenter,t.cartesianCenter,t.parentRotation,t.ellipsoidRadiiSquare,e.scale_x,e.scale_y),m(e.uv0s)&&m(e["uv-region"])&&vRt(e.vertexCount,e.uv0s,e["uv-region"]);let i;if(m(e["feature-index"]))i=e["feature-index"];else if(m(e.faceRange)){i=new Array(e.vertexCount);for(let r=0;r<e.faceRange.length-1;r+=2){let a=r/2,h=e.faceRange[r],A=e.faceRange[r+1];for(let d=h;d<=A;d++)i[d*3]=a,i[d*3+1]=a,i[d*3+2]=a}}if(t.calculateNormals){let r=rZt(e.vertexCount,e.indices,e.positions,e.normals,e.uv0s,e.colors,i);m(r.normals)&&(e.normals=r.normals,m(r.vertexCount)&&(e.vertexCount=r.vertexCount,e.indices=r.indices,e.positions=r.positions,e.uv0s=r.uv0s,e.colors=r.colors,i=r.featureIndex))}let n=aZt(e.vertexCount,e.indices,e.positions,e.normals,e.uv0s,e.colors,i,t),s={positions:e.positions,indices:e.indices,featureIndex:i,sourceURL:t.url,cartesianCenter:t.cartesianCenter,parentRotation:t.parentRotation};return n._customAttributes=s,{meshData:n}}async function mZt(t,e){let i=t.webAssemblyConfig;return m(i)&&m(i.wasmBinaryFile)?gB=await(0,CB.default)(i):gB=await(0,CB.default)(),!0}function fZt(t,e){let i=t.webAssemblyConfig;return m(i)?mZt(t,e):dZt(t,e)}var CB,gB,QA,xg,Pg,Jg,uB,jg,EZt,NB=O(()=>{Ns();bt();mt();Ul();Ve();ri();Ht();Qn();dn();_e();CB=co(tB(),1);GX();QA=new l,xg=new l,Pg=new l;Jg=new l,uB=new l;jg={position:function(t,e,i){let n=t.vertexCount*3;return t.positions=new Float32Array(e,i,n),i+=n*4,i},normal:function(t,e,i){let n=t.vertexCount*3;return t.normals=new Float32Array(e,i,n),i+=n*4,i},uv0:function(t,e,i){let n=t.vertexCount*2;return t.uv0s=new Float32Array(e,i,n),i+=n*4,i},color:function(t,e,i){let n=t.vertexCount*4;return t.colors=new Uint8Array(e,i,n),i+=n,i},featureId:function(t,e,i){let n=t.featureCount;return i+=n*8,i},id:function(t,e,i){let n=t.featureCount;return i+=n*8,i},faceRange:function(t,e,i){let n=t.featureCount*2;return t.faceRange=new Uint32Array(e,i,n),i+=n*4,i},uvRegion:function(t,e,i){let n=t.vertexCount*4;return t["uv-region"]=new Uint16Array(e,i,n),i+=n*2,i},region:function(t,e,i){let n=t.vertexCount*4;return t["uv-region"]=new Uint16Array(e,i,n),i+=n*2,i}};EZt=Wi(fZt)});var _Zt,PR,DX=O(()=>{_Zt={VK_FORMAT_UNDEFINED:0,VK_FORMAT_R4G4_UNORM_PACK8:1,VK_FORMAT_R4G4B4A4_UNORM_PACK16:2,VK_FORMAT_B4G4R4A4_UNORM_PACK16:3,VK_FORMAT_R5G6B5_UNORM_PACK16:4,VK_FORMAT_B5G6R5_UNORM_PACK16:5,VK_FORMAT_R5G5B5A1_UNORM_PACK16:6,VK_FORMAT_B5G5R5A1_UNORM_PACK16:7,VK_FORMAT_A1R5G5B5_UNORM_PACK16:8,VK_FORMAT_R8_UNORM:9,VK_FORMAT_R8_SNORM:10,VK_FORMAT_R8_USCALED:11,VK_FORMAT_R8_SSCALED:12,VK_FORMAT_R8_UINT:13,VK_FORMAT_R8_SINT:14,VK_FORMAT_R8_SRGB:15,VK_FORMAT_R8G8_UNORM:16,VK_FORMAT_R8G8_SNORM:17,VK_FORMAT_R8G8_USCALED:18,VK_FORMAT_R8G8_SSCALED:19,VK_FORMAT_R8G8_UINT:20,VK_FORMAT_R8G8_SINT:21,VK_FORMAT_R8G8_SRGB:22,VK_FORMAT_R8G8B8_UNORM:23,VK_FORMAT_R8G8B8_SNORM:24,VK_FORMAT_R8G8B8_USCALED:25,VK_FORMAT_R8G8B8_SSCALED:26,VK_FORMAT_R8G8B8_UINT:27,VK_FORMAT_R8G8B8_SINT:28,VK_FORMAT_R8G8B8_SRGB:29,VK_FORMAT_B8G8R8_UNORM:30,VK_FORMAT_B8G8R8_SNORM:31,VK_FORMAT_B8G8R8_USCALED:32,VK_FORMAT_B8G8R8_SSCALED:33,VK_FORMAT_B8G8R8_UINT:34,VK_FORMAT_B8G8R8_SINT:35,VK_FORMAT_B8G8R8_SRGB:36,VK_FORMAT_R8G8B8A8_UNORM:37,VK_FORMAT_R8G8B8A8_SNORM:38,VK_FORMAT_R8G8B8A8_USCALED:39,VK_FORMAT_R8G8B8A8_SSCALED:40,VK_FORMAT_R8G8B8A8_UINT:41,VK_FORMAT_R8G8B8A8_SINT:42,VK_FORMAT_R8G8B8A8_SRGB:43,VK_FORMAT_B8G8R8A8_UNORM:44,VK_FORMAT_B8G8R8A8_SNORM:45,VK_FORMAT_B8G8R8A8_USCALED:46,VK_FORMAT_B8G8R8A8_SSCALED:47,VK_FORMAT_B8G8R8A8_UINT:48,VK_FORMAT_B8G8R8A8_SINT:49,VK_FORMAT_B8G8R8A8_SRGB:50,VK_FORMAT_A8B8G8R8_UNORM_PACK32:51,VK_FORMAT_A8B8G8R8_SNORM_PACK32:52,VK_FORMAT_A8B8G8R8_USCALED_PACK32:53,VK_FORMAT_A8B8G8R8_SSCALED_PACK32:54,VK_FORMAT_A8B8G8R8_UINT_PACK32:55,VK_FORMAT_A8B8G8R8_SINT_PACK32:56,VK_FORMAT_A8B8G8R8_SRGB_PACK32:57,VK_FORMAT_A2R10G10B10_UNORM_PACK32:58,VK_FORMAT_A2R10G10B10_SNORM_PACK32:59,VK_FORMAT_A2R10G10B10_USCALED_PACK32:60,VK_FORMAT_A2R10G10B10_SSCALED_PACK32:61,VK_FORMAT_A2R10G10B10_UINT_PACK32:62,VK_FORMAT_A2R10G10B10_SINT_PACK32:63,VK_FORMAT_A2B10G10R10_UNORM_PACK32:64,VK_FORMAT_A2B10G10R10_SNORM_PACK32:65,VK_FORMAT_A2B10G10R10_USCALED_PACK32:66,VK_FORMAT_A2B10G10R10_SSCALED_PACK32:67,VK_FORMAT_A2B10G10R10_UINT_PACK32:68,VK_FORMAT_A2B10G10R10_SINT_PACK32:69,VK_FORMAT_R16_UNORM:70,VK_FORMAT_R16_SNORM:71,VK_FORMAT_R16_USCALED:72,VK_FORMAT_R16_SSCALED:73,VK_FORMAT_R16_UINT:74,VK_FORMAT_R16_SINT:75,VK_FORMAT_R16_SFLOAT:76,VK_FORMAT_R16G16_UNORM:77,VK_FORMAT_R16G16_SNORM:78,VK_FORMAT_R16G16_USCALED:79,VK_FORMAT_R16G16_SSCALED:80,VK_FORMAT_R16G16_UINT:81,VK_FORMAT_R16G16_SINT:82,VK_FORMAT_R16G16_SFLOAT:83,VK_FORMAT_R16G16B16_UNORM:84,VK_FORMAT_R16G16B16_SNORM:85,VK_FORMAT_R16G16B16_USCALED:86,VK_FORMAT_R16G16B16_SSCALED:87,VK_FORMAT_R16G16B16_UINT:88,VK_FORMAT_R16G16B16_SINT:89,VK_FORMAT_R16G16B16_SFLOAT:90,VK_FORMAT_R16G16B16A16_UNORM:91,VK_FORMAT_R16G16B16A16_SNORM:92,VK_FORMAT_R16G16B16A16_USCALED:93,VK_FORMAT_R16G16B16A16_SSCALED:94,VK_FORMAT_R16G16B16A16_UINT:95,VK_FORMAT_R16G16B16A16_SINT:96,VK_FORMAT_R16G16B16A16_SFLOAT:97,VK_FORMAT_R32_UINT:98,VK_FORMAT_R32_SINT:99,VK_FORMAT_R32_SFLOAT:100,VK_FORMAT_R32G32_UINT:101,VK_FORMAT_R32G32_SINT:102,VK_FORMAT_R32G32_SFLOAT:103,VK_FORMAT_R32G32B32_UINT:104,VK_FORMAT_R32G32B32_SINT:105,VK_FORMAT_R32G32B32_SFLOAT:106,VK_FORMAT_R32G32B32A32_UINT:107,VK_FORMAT_R32G32B32A32_SINT:108,VK_FORMAT_R32G32B32A32_SFLOAT:109,VK_FORMAT_R64_UINT:110,VK_FORMAT_R64_SINT:111,VK_FORMAT_R64_SFLOAT:112,VK_FORMAT_R64G64_UINT:113,VK_FORMAT_R64G64_SINT:114,VK_FORMAT_R64G64_SFLOAT:115,VK_FORMAT_R64G64B64_UINT:116,VK_FORMAT_R64G64B64_SINT:117,VK_FORMAT_R64G64B64_SFLOAT:118,VK_FORMAT_R64G64B64A64_UINT:119,VK_FORMAT_R64G64B64A64_SINT:120,VK_FORMAT_R64G64B64A64_SFLOAT:121,VK_FORMAT_B10G11R11_UFLOAT_PACK32:122,VK_FORMAT_E5B9G9R9_UFLOAT_PACK32:123,VK_FORMAT_D16_UNORM:124,VK_FORMAT_X8_D24_UNORM_PACK32:125,VK_FORMAT_D32_SFLOAT:126,VK_FORMAT_S8_UINT:127,VK_FORMAT_D16_UNORM_S8_UINT:128,VK_FORMAT_D24_UNORM_S8_UINT:129,VK_FORMAT_D32_SFLOAT_S8_UINT:130,VK_FORMAT_BC1_RGB_UNORM_BLOCK:131,VK_FORMAT_BC1_RGB_SRGB_BLOCK:132,VK_FORMAT_BC1_RGBA_UNORM_BLOCK:133,VK_FORMAT_BC1_RGBA_SRGB_BLOCK:134,VK_FORMAT_BC2_UNORM_BLOCK:135,VK_FORMAT_BC2_SRGB_BLOCK:136,VK_FORMAT_BC3_UNORM_BLOCK:137,VK_FORMAT_BC3_SRGB_BLOCK:138,VK_FORMAT_BC4_UNORM_BLOCK:139,VK_FORMAT_BC4_SNORM_BLOCK:140,VK_FORMAT_BC5_UNORM_BLOCK:141,VK_FORMAT_BC5_SNORM_BLOCK:142,VK_FORMAT_BC6H_UFLOAT_BLOCK:143,VK_FORMAT_BC6H_SFLOAT_BLOCK:144,VK_FORMAT_BC7_UNORM_BLOCK:145,VK_FORMAT_BC7_SRGB_BLOCK:146,VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK:147,VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK:148,VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK:149,VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK:150,VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK:151,VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK:152,VK_FORMAT_EAC_R11_UNORM_BLOCK:153,VK_FORMAT_EAC_R11_SNORM_BLOCK:154,VK_FORMAT_EAC_R11G11_UNORM_BLOCK:155,VK_FORMAT_EAC_R11G11_SNORM_BLOCK:156,VK_FORMAT_ASTC_4x4_UNORM_BLOCK:157,VK_FORMAT_ASTC_4x4_SRGB_BLOCK:158,VK_FORMAT_ASTC_5x4_UNORM_BLOCK:159,VK_FORMAT_ASTC_5x4_SRGB_BLOCK:160,VK_FORMAT_ASTC_5x5_UNORM_BLOCK:161,VK_FORMAT_ASTC_5x5_SRGB_BLOCK:162,VK_FORMAT_ASTC_6x5_UNORM_BLOCK:163,VK_FORMAT_ASTC_6x5_SRGB_BLOCK:164,VK_FORMAT_ASTC_6x6_UNORM_BLOCK:165,VK_FORMAT_ASTC_6x6_SRGB_BLOCK:166,VK_FORMAT_ASTC_8x5_UNORM_BLOCK:167,VK_FORMAT_ASTC_8x5_SRGB_BLOCK:168,VK_FORMAT_ASTC_8x6_UNORM_BLOCK:169,VK_FORMAT_ASTC_8x6_SRGB_BLOCK:170,VK_FORMAT_ASTC_8x8_UNORM_BLOCK:171,VK_FORMAT_ASTC_8x8_SRGB_BLOCK:172,VK_FORMAT_ASTC_10x5_UNORM_BLOCK:173,VK_FORMAT_ASTC_10x5_SRGB_BLOCK:174,VK_FORMAT_ASTC_10x6_UNORM_BLOCK:175,VK_FORMAT_ASTC_10x6_SRGB_BLOCK:176,VK_FORMAT_ASTC_10x8_UNORM_BLOCK:177,VK_FORMAT_ASTC_10x8_SRGB_BLOCK:178,VK_FORMAT_ASTC_10x10_UNORM_BLOCK:179,VK_FORMAT_ASTC_10x10_SRGB_BLOCK:180,VK_FORMAT_ASTC_12x10_UNORM_BLOCK:181,VK_FORMAT_ASTC_12x10_SRGB_BLOCK:182,VK_FORMAT_ASTC_12x12_UNORM_BLOCK:183,VK_FORMAT_ASTC_12x12_SRGB_BLOCK:184,VK_FORMAT_G8B8G8R8_422_UNORM:1000156e3,VK_FORMAT_B8G8R8G8_422_UNORM:1000156001,VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM:1000156002,VK_FORMAT_G8_B8R8_2PLANE_420_UNORM:1000156003,VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM:1000156004,VK_FORMAT_G8_B8R8_2PLANE_422_UNORM:1000156005,VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM:1000156006,VK_FORMAT_R10X6_UNORM_PACK16:1000156007,VK_FORMAT_R10X6G10X6_UNORM_2PACK16:1000156008,VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16:1000156009,VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16:1000156010,VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16:1000156011,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16:1000156012,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16:1000156013,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16:1000156014,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16:1000156015,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16:1000156016,VK_FORMAT_R12X4_UNORM_PACK16:1000156017,VK_FORMAT_R12X4G12X4_UNORM_2PACK16:1000156018,VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16:1000156019,VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16:1000156020,VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16:1000156021,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16:1000156022,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16:1000156023,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16:1000156024,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16:1000156025,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16:1000156026,VK_FORMAT_G16B16G16R16_422_UNORM:1000156027,VK_FORMAT_B16G16R16G16_422_UNORM:1000156028,VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM:1000156029,VK_FORMAT_G16_B16R16_2PLANE_420_UNORM:1000156030,VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM:1000156031,VK_FORMAT_G16_B16R16_2PLANE_422_UNORM:1000156032,VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM:1000156033,VK_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG:1000054e3,VK_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG:1000054001,VK_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG:1000054002,VK_FORMAT_PVRTC2_4BPP_UNORM_BLOCK_IMG:1000054003,VK_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG:1000054004,VK_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG:1000054005,VK_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG:1000054006,VK_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG:1000054007,VK_FORMAT_ASTC_4x4_SFLOAT_BLOCK_EXT:1000066e3,VK_FORMAT_ASTC_5x4_SFLOAT_BLOCK_EXT:1000066001,VK_FORMAT_ASTC_5x5_SFLOAT_BLOCK_EXT:1000066002,VK_FORMAT_ASTC_6x5_SFLOAT_BLOCK_EXT:1000066003,VK_FORMAT_ASTC_6x6_SFLOAT_BLOCK_EXT:1000066004,VK_FORMAT_ASTC_8x5_SFLOAT_BLOCK_EXT:1000066005,VK_FORMAT_ASTC_8x6_SFLOAT_BLOCK_EXT:1000066006,VK_FORMAT_ASTC_8x8_SFLOAT_BLOCK_EXT:1000066007,VK_FORMAT_ASTC_10x5_SFLOAT_BLOCK_EXT:1000066008,VK_FORMAT_ASTC_10x6_SFLOAT_BLOCK_EXT:1000066009,VK_FORMAT_ASTC_10x8_SFLOAT_BLOCK_EXT:1000066010,VK_FORMAT_ASTC_10x10_SFLOAT_BLOCK_EXT:1000066011,VK_FORMAT_ASTC_12x10_SFLOAT_BLOCK_EXT:1000066012,VK_FORMAT_ASTC_12x12_SFLOAT_BLOCK_EXT:1000066013,VK_FORMAT_G8B8G8R8_422_UNORM_KHR:1000156e3,VK_FORMAT_B8G8R8G8_422_UNORM_KHR:1000156001,VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM_KHR:1000156002,VK_FORMAT_G8_B8R8_2PLANE_420_UNORM_KHR:1000156003,VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM_KHR:1000156004,VK_FORMAT_G8_B8R8_2PLANE_422_UNORM_KHR:1000156005,VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM_KHR:1000156006,VK_FORMAT_R10X6_UNORM_PACK16_KHR:1000156007,VK_FORMAT_R10X6G10X6_UNORM_2PACK16_KHR:1000156008,VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16_KHR:1000156009,VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16_KHR:1000156010,VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16_KHR:1000156011,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16_KHR:1000156012,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16_KHR:1000156013,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16_KHR:1000156014,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16_KHR:1000156015,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16_KHR:1000156016,VK_FORMAT_R12X4_UNORM_PACK16_KHR:1000156017,VK_FORMAT_R12X4G12X4_UNORM_2PACK16_KHR:1000156018,VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16_KHR:1000156019,VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16_KHR:1000156020,VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16_KHR:1000156021,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16_KHR:1000156022,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16_KHR:1000156023,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16_KHR:1000156024,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16_KHR:1000156025,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16_KHR:1000156026,VK_FORMAT_G16B16G16R16_422_UNORM_KHR:1000156027,VK_FORMAT_B16G16R16G16_422_UNORM_KHR:1000156028,VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM_KHR:1000156029,VK_FORMAT_G16_B16R16_2PLANE_420_UNORM_KHR:1000156030,VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM_KHR:1000156031,VK_FORMAT_G16_B16R16_2PLANE_422_UNORM_KHR:1000156032,VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM_KHR:1000156033},PR=Object.freeze(_Zt)});function MX(t){return typeof TextDecoder<"u"?new TextDecoder().decode(t):Buffer.from(t).toString("utf8")}function UX(t){let e=new Uint8Array(t.buffer,t.byteOffset,Po.length);if(e[0]!==Po[0]||e[1]!==Po[1]||e[2]!==Po[2]||e[3]!==Po[3]||e[4]!==Po[4]||e[5]!==Po[5]||e[6]!==Po[6]||e[7]!==Po[7]||e[8]!==Po[8]||e[9]!==Po[9]||e[10]!==Po[10]||e[11]!==Po[11])throw new Error("Missing KTX 2.0 identifier.");let i=new bB,n=17*Uint32Array.BYTES_PER_ELEMENT,s=new Yd(t,Po.length,n,!0);i.vkFormat=s._nextUint32(),i.typeSize=s._nextUint32(),i.pixelWidth=s._nextUint32(),i.pixelHeight=s._nextUint32(),i.pixelDepth=s._nextUint32(),i.layerCount=s._nextUint32(),i.faceCount=s._nextUint32();let o=s._nextUint32();i.supercompressionScheme=s._nextUint32();let r=s._nextUint32(),a=s._nextUint32(),h=s._nextUint32(),A=s._nextUint32(),d=s._nextUint64(),f=s._nextUint64(),E=o*3*8,_=new Yd(t,Po.length+n,E,!0);for(let tt=0;tt<o;tt++)i.levels.push({levelData:new Uint8Array(t.buffer,t.byteOffset+_._nextUint64(),_._nextUint64()),uncompressedByteLength:_._nextUint64()});let R=new Yd(t,r,a,!0),I={vendorId:R._skip(4)._nextUint16(),descriptorType:R._nextUint16(),versionNumber:R._nextUint16(),descriptorBlockSize:R._nextUint16(),colorModel:R._nextUint8(),colorPrimaries:R._nextUint8(),transferFunction:R._nextUint8(),flags:R._nextUint8(),texelBlockDimension:[R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8()],bytesPlane:[R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8()],samples:[]},T=(I.descriptorBlockSize/4-6)/4;for(let tt=0;tt<T;tt++){let B={bitOffset:R._nextUint16(),bitLength:R._nextUint8(),channelType:R._nextUint8(),samplePosition:[R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8()],sampleLower:-1/0,sampleUpper:1/0};B.channelType&64?(B.sampleLower=R._nextInt32(),B.sampleUpper=R._nextInt32()):(B.sampleLower=R._nextUint32(),B.sampleUpper=R._nextUint32()),I.samples[tt]=B}i.dataFormatDescriptor.length=0,i.dataFormatDescriptor.push(I);let F=new Yd(t,h,A,!0);for(;F._offset<A;){let tt=F._nextUint32(),B=F._scan(tt),It=MX(B);if(i.keyValue[It]=F._nextUint8Array(tt-B.byteLength-1),It.match(/^ktx/i)){let Yt=MX(i.keyValue[It]);i.keyValue[It]=Yt.substring(0,Yt.lastIndexOf("\0"))}let gt=tt%4?4-tt%4:0;F._skip(gt)}if(f<=0)return i;let b=new Yd(t,d,f,!0),G=b._nextUint16(),M=b._nextUint16(),Q=b._nextUint32(),U=b._nextUint32(),k=b._nextUint32(),y=b._nextUint32(),c=[];for(let tt=0;tt<o;tt++)c.push({imageFlags:b._nextUint32(),rgbSliceByteOffset:b._nextUint32(),rgbSliceByteLength:b._nextUint32(),alphaSliceByteOffset:b._nextUint32(),alphaSliceByteLength:b._nextUint32()});let g=d+b._offset,V=g+Q,D=V+U,w=D+k,x=new Uint8Array(t.buffer,t.byteOffset+g,Q),H=new Uint8Array(t.buffer,t.byteOffset+V,U),j=new Uint8Array(t.buffer,t.byteOffset+D,k),X=new Uint8Array(t.buffer,t.byteOffset+w,y);return i.globalData={endpointCount:G,selectorCount:M,imageDescs:c,endpointsData:x,selectorsData:H,tablesData:j,extendedData:X},i}var bB,Yd,fVe,Po,QX=O(()=>{bB=class{constructor(){this.vkFormat=0,this.typeSize=1,this.pixelWidth=0,this.pixelHeight=0,this.pixelDepth=0,this.layerCount=0,this.faceCount=1,this.supercompressionScheme=0,this.levels=[],this.dataFormatDescriptor=[{vendorId:0,descriptorType:0,descriptorBlockSize:0,versionNumber:2,colorModel:0,colorPrimaries:1,transferFunction:2,flags:0,texelBlockDimension:[0,0,0,0],bytesPlane:[0,0,0,0,0,0,0,0],samples:[]}],this.keyValue={},this.globalData=null}},Yd=class{constructor(e,i,n,s){this._dataView=void 0,this._littleEndian=void 0,this._offset=void 0,this._dataView=new DataView(e.buffer,e.byteOffset+i,n),this._littleEndian=s,this._offset=0}_nextUint8(){let e=this._dataView.getUint8(this._offset);return this._offset+=1,e}_nextUint16(){let e=this._dataView.getUint16(this._offset,this._littleEndian);return this._offset+=2,e}_nextUint32(){let e=this._dataView.getUint32(this._offset,this._littleEndian);return this._offset+=4,e}_nextUint64(){let e=this._dataView.getUint32(this._offset,this._littleEndian),i=this._dataView.getUint32(this._offset+4,this._littleEndian),n=e+2**32*i;return this._offset+=8,n}_nextInt32(){let e=this._dataView.getInt32(this._offset,this._littleEndian);return this._offset+=4,e}_nextUint8Array(e){let i=new Uint8Array(this._dataView.buffer,this._dataView.byteOffset+this._offset,e);return this._offset+=e,i}_skip(e){return this._offset+=e,this}_scan(e,i=0){let n=this._offset,s=0;for(;this._dataView.getUint8(this._offset)!==i&&s<e;)s++,this._offset++;return s<e&&this._offset++,new Uint8Array(this._dataView.buffer,this._dataView.byteOffset+n,s)}},fVe=new Uint8Array([0]),Po=[171,75,84,88,32,50,48,187,13,10,26,10]});var kX=ts((Hg,YB)=>{var FB=function(){var t=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename<"u"&&(t=t||__filename),function(e){e=e||{};var i=typeof e<"u"?e:{},n,s;i.ready=new Promise(function(J,v){n=J,s=v});var o={},r;for(r in i)i.hasOwnProperty(r)&&(o[r]=i[r]);var a=[],h="./this.program",A=function(J,v){throw v},d=!1,f=!1,E=!1,_=!1;d=typeof window=="object",f=typeof importScripts=="function",E=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",_=!d&&!E&&!f;var R="";function I(J){return i.locateFile?i.locateFile(J,R):R+J}var C,N,T,F,b,G;E?(f?R=Xo("path").dirname(R)+"/":R=__dirname+"/",C=function(v,st){return b||(b=Xo("fs")),G||(G=Xo("path")),v=G.normalize(v),b.readFileSync(v,st?null:"utf8")},T=function(v){var st=C(v,!0);return st.buffer||(st=new Uint8Array(st)),w(st.buffer),st},process.argv.length>1&&(h=process.argv[1].replace(/\\/g,"/")),a=process.argv.slice(2),process.on("uncaughtException",function(J){if(!(J instanceof _a))throw J}),process.on("unhandledRejection",ki),A=function(J){process.exit(J)},i.inspect=function(){return"[Emscripten Module object]"}):_?(typeof read<"u"&&(C=function(v){return read(v)}),T=function(v){var st;return typeof readbuffer=="function"?new Uint8Array(readbuffer(v)):(st=read(v,"binary"),w(typeof st=="object"),st)},typeof scriptArgs<"u"?a=scriptArgs:typeof arguments<"u"&&(a=arguments),typeof quit=="function"&&(A=function(J){quit(J)}),typeof print<"u"&&(typeof console>"u"&&(console={}),console.log=print,console.warn=console.error=typeof printErr<"u"?printErr:print)):(d||f)&&(f?R=self.location.href:typeof document<"u"&&document.currentScript&&(R=document.currentScript.src),t&&(R=t),R.indexOf("blob:")!==0?R=R.substr(0,R.lastIndexOf("/")+1):R="",C=function(J){var v=new XMLHttpRequest;return v.open("GET",J,!1),v.send(null),v.responseText},f&&(T=function(J){var v=new XMLHttpRequest;return v.open("GET",J,!1),v.responseType="arraybuffer",v.send(null),new Uint8Array(v.response)}),N=function(J,v,st){var Rt=new XMLHttpRequest;Rt.open("GET",J,!0),Rt.responseType="arraybuffer",Rt.onload=function(){if(Rt.status==200||Rt.status==0&&Rt.response){v(Rt.response);return}st()},Rt.onerror=st,Rt.send(null)},F=function(J){document.title=J});var M=i.print||console.log.bind(console),Q=i.printErr||console.warn.bind(console);for(r in o)o.hasOwnProperty(r)&&(i[r]=o[r]);o=null,i.arguments&&(a=i.arguments),i.thisProgram&&(h=i.thisProgram),i.quit&&(A=i.quit);var U=0,k=function(J){U=J},y;i.wasmBinary&&(y=i.wasmBinary);var c=i.noExitRuntime||!0;typeof WebAssembly!="object"&&ki("no native wasm support detected");var g,V=!1,D;function w(J,v){J||ki("Assertion failed: "+v)}var x=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0;function H(J,v,st){for(var Rt=v+st,St=v;J[St]&&!(St>=Rt);)++St;if(St-v>16&&J.subarray&&x)return x.decode(J.subarray(v,St));for(var Gt="";v<St;){var jt=J[v++];if(!(jt&128)){Gt+=String.fromCharCode(jt);continue}var Ut=J[v++]&63;if((jt&224)==192){Gt+=String.fromCharCode((jt&31)<<6|Ut);continue}var Dt=J[v++]&63;if((jt&240)==224?jt=(jt&15)<<12|Ut<<6|Dt:jt=(jt&7)<<18|Ut<<12|Dt<<6|J[v++]&63,jt<65536)Gt+=String.fromCharCode(jt);else{var pe=jt-65536;Gt+=String.fromCharCode(55296|pe>>10,56320|pe&1023)}}return Gt}function j(J,v){return J?H(ee,J,v):""}function X(J,v,st,Rt){if(!(Rt>0))return 0;for(var St=st,Gt=st+Rt-1,jt=0;jt<J.length;++jt){var Ut=J.charCodeAt(jt);if(Ut>=55296&&Ut<=57343){var Dt=J.charCodeAt(++jt);Ut=65536+((Ut&1023)<<10)|Dt&1023}if(Ut<=127){if(st>=Gt)break;v[st++]=Ut}else if(Ut<=2047){if(st+1>=Gt)break;v[st++]=192|Ut>>6,v[st++]=128|Ut&63}else if(Ut<=65535){if(st+2>=Gt)break;v[st++]=224|Ut>>12,v[st++]=128|Ut>>6&63,v[st++]=128|Ut&63}else{if(st+3>=Gt)break;v[st++]=240|Ut>>18,v[st++]=128|Ut>>12&63,v[st++]=128|Ut>>6&63,v[st++]=128|Ut&63}}return v[st]=0,st-St}function tt(J,v,st){return X(J,ee,v,st)}function B(J){for(var v=0,st=0;st<J.length;++st){var Rt=J.charCodeAt(st);Rt>=55296&&Rt<=57343&&(Rt=65536+((Rt&1023)<<10)|J.charCodeAt(++st)&1023),Rt<=127?++v:Rt<=2047?v+=2:Rt<=65535?v+=3:v+=4}return v}var It=typeof TextDecoder<"u"?new TextDecoder("utf-16le"):void 0;function gt(J,v){for(var st=J,Rt=st>>1,St=Rt+v/2;!(Rt>=St)&&je[Rt];)++Rt;if(st=Rt<<1,st-J>32&&It)return It.decode(ee.subarray(J,st));for(var Gt="",jt=0;!(jt>=v/2);++jt){var Ut=ce[J+jt*2>>1];if(Ut==0)break;Gt+=String.fromCharCode(Ut)}return Gt}function Yt(J,v,st){if(st===void 0&&(st=2147483647),st<2)return 0;st-=2;for(var Rt=v,St=st<J.length*2?st/2:J.length,Gt=0;Gt<St;++Gt){var jt=J.charCodeAt(Gt);ce[v>>1]=jt,v+=2}return ce[v>>1]=0,v-Rt}function Mt(J){return J.length*2}function Ct(J,v){for(var st=0,Rt="";!(st>=v/4);){var St=Oe[J+st*4>>2];if(St==0)break;if(++st,St>=65536){var Gt=St-65536;Rt+=String.fromCharCode(55296|Gt>>10,56320|Gt&1023)}else Rt+=String.fromCharCode(St)}return Rt}function zt(J,v,st){if(st===void 0&&(st=2147483647),st<4)return 0;for(var Rt=v,St=Rt+st-4,Gt=0;Gt<J.length;++Gt){var jt=J.charCodeAt(Gt);if(jt>=55296&&jt<=57343){var Ut=J.charCodeAt(++Gt);jt=65536+((jt&1023)<<10)|Ut&1023}if(Oe[v>>2]=jt,v+=4,v+4>St)break}return Oe[v>>2]=0,v-Rt}function kt(J){for(var v=0,st=0;st<J.length;++st){var Rt=J.charCodeAt(st);Rt>=55296&&Rt<=57343&&++st,v+=4}return v}function Jt(J,v){return J%v>0&&(J+=v-J%v),J}var Wt,Ft,ee,ce,je,Oe,Me,Ue,Ce;function be(J){Wt=J,i.HEAP8=Ft=new Int8Array(J),i.HEAP16=ce=new Int16Array(J),i.HEAP32=Oe=new Int32Array(J),i.HEAPU8=ee=new Uint8Array(J),i.HEAPU16=je=new Uint16Array(J),i.HEAPU32=Me=new Uint32Array(J),i.HEAPF32=Ue=new Float32Array(J),i.HEAPF64=Ce=new Float64Array(J)}var ni=i.INITIAL_MEMORY||16777216,ze,Ge=[],Ui=[],Ri=[],si=[],qe=!1;function Vi(){if(i.preRun)for(typeof i.preRun=="function"&&(i.preRun=[i.preRun]);i.preRun.length;)Bi(i.preRun.shift());ao(Ge)}function gn(){qe=!0,ao(Ui)}function De(){ao(Ri)}function Ye(){if(i.postRun)for(typeof i.postRun=="function"&&(i.postRun=[i.postRun]);i.postRun.length;)Ne(i.postRun.shift());ao(si)}function Bi(J){Ge.unshift(J)}function An(J){Ui.unshift(J)}function Ne(J){si.unshift(J)}var ei=0,_n=null,hs=null;function Qi(J){ei++,i.monitorRunDependencies&&i.monitorRunDependencies(ei)}function nn(J){if(ei--,i.monitorRunDependencies&&i.monitorRunDependencies(ei),ei==0&&(_n!==null&&(clearInterval(_n),_n=null),hs)){var v=hs;hs=null,v()}}i.preloadedImages={},i.preloadedAudios={};function ki(J){i.onAbort&&i.onAbort(J),J+="",Q(J),V=!0,D=1,J="abort("+J+"). Build with -s ASSERTIONS=1 for more info.";var v=new WebAssembly.RuntimeError(J);throw s(v),v}function sn(J,v){return String.prototype.startsWith?J.startsWith(v):J.indexOf(v)===0}var Cs="data:application/octet-stream;base64,";function cs(J){return sn(J,Cs)}var xn="file://";function Pn(J){return sn(J,xn)}var Ai="basis_transcoder.wasm";cs(Ai)||(Ai=I(Ai));function Ci(J){try{if(J==Ai&&y)return new Uint8Array(y);if(T)return T(J);throw"both async and sync fetching of the wasm failed"}catch(v){ki(v)}}function Jn(){if(!y&&(d||f)){if(typeof fetch=="function"&&!Pn(Ai))return fetch(Ai,{credentials:"same-origin"}).then(function(J){if(!J.ok)throw"failed to load wasm binary file at '"+Ai+"'";return J.arrayBuffer()}).catch(function(){return Ci(Ai)});if(N)return new Promise(function(J,v){N(Ai,function(st){J(new Uint8Array(st))},v)})}return Promise.resolve().then(function(){return Ci(Ai)})}function ls(){var J={a:fm};function v(jt,Ut){var Dt=jt.exports;i.asm=Dt,g=i.asm.K,be(g.buffer),ze=i.asm.O,An(i.asm.L),nn("wasm-instantiate")}Qi("wasm-instantiate");function st(jt){v(jt.instance)}function Rt(jt){return Jn().then(function(Ut){var Dt=WebAssembly.instantiate(Ut,J);return Dt}).then(jt,function(Ut){Q("failed to asynchronously prepare wasm: "+Ut),ki(Ut)})}function St(){return!y&&typeof WebAssembly.instantiateStreaming=="function"&&!cs(Ai)&&!Pn(Ai)&&typeof fetch=="function"?fetch(Ai,{credentials:"same-origin"}).then(function(jt){var Ut=WebAssembly.instantiateStreaming(jt,J);return Ut.then(st,function(Dt){return Q("wasm streaming compile failed: "+Dt),Q("falling back to ArrayBuffer instantiation"),Rt(st)})}):Rt(st)}if(i.instantiateWasm)try{var Gt=i.instantiateWasm(J,v);return Gt}catch(jt){return Q("Module.instantiateWasm callback failed with error: "+jt),!1}return St().catch(s),{}}function ao(J){for(;J.length>0;){var v=J.shift();if(typeof v=="function"){v(i);continue}var st=v.func;typeof st=="number"?v.arg===void 0?ze.get(st)():ze.get(st)(v.arg):st(v.arg===void 0?null:v.arg)}}var qi={};function hn(J){for(;J.length;){var v=J.pop(),st=J.pop();st(v)}}function jo(J){return this.fromWireType(Me[J>>2])}var ds={},on={},ws={},So=48,Fr=57;function Oo(J){if(J===void 0)return"_unknown";J=J.replace(/[^a-zA-Z0-9_]/g,"$");var v=J.charCodeAt(0);return v>=So&&v<=Fr?"_"+J:J}function $e(J,v){return J=Oo(J),new Function("body","return function "+J+`() {
    "use strict";    return body.apply(this, arguments);
};
`)(v)}function aa(J,v){var st=$e(v,function(Rt){this.name=v,this.message=Rt;var St=new Error(Rt).stack;St!==void 0&&(this.stack=this.toString()+`
`+St.replace(/^Error(:[^\n]*)?\n/,""))});return st.prototype=Object.create(J.prototype),st.prototype.constructor=st,st.prototype.toString=function(){return this.message===void 0?this.name:this.name+": "+this.message},st}var Yr=void 0;function xs(J){throw new Yr(J)}function gs(J,v,st){J.forEach(function(Ut){ws[Ut]=v});function Rt(Ut){var Dt=st(Ut);Dt.length!==J.length&&xs("Mismatched type converter count");for(var pe=0;pe<J.length;++pe)Vo(J[pe],Dt[pe])}var St=new Array(v.length),Gt=[],jt=0;v.forEach(function(Ut,Dt){on.hasOwnProperty(Ut)?St[Dt]=on[Ut]:(Gt.push(Ut),ds.hasOwnProperty(Ut)||(ds[Ut]=[]),ds[Ut].push(function(){St[Dt]=on[Ut],++jt,jt===Gt.length&&Rt(St)}))}),Gt.length===0&&Rt(St)}function Tn(J){var v=qi[J];delete qi[J];var st=v.rawConstructor,Rt=v.rawDestructor,St=v.fields,Gt=St.map(function(jt){return jt.getterReturnType}).concat(St.map(function(jt){return jt.setterArgumentType}));gs([J],Gt,function(jt){var Ut={};return St.forEach(function(Dt,pe){var Be=Dt.fieldName,ci=jt[pe],pi=Dt.getter,cn=Dt.getterContext,Qe=jt[pe+St.length],Xs=Dt.setter,zo=Dt.setterContext;Ut[Be]={read:function(Sr){return ci.fromWireType(pi(cn,Sr))},write:function(Sr,ml){var Ra=[];Xs(zo,Sr,Qe.toWireType(Ra,ml)),hn(Ra)}}}),[{name:v.name,fromWireType:function(Dt){var pe={};for(var Be in Ut)pe[Be]=Ut[Be].read(Dt);return Rt(Dt),pe},toWireType:function(Dt,pe){for(var Be in Ut)if(!(Be in pe))throw new TypeError('Missing field:  "'+Be+'"');var ci=st();for(Be in Ut)Ut[Be].write(ci,pe[Be]);return Dt!==null&&Dt.push(Rt,ci),ci},argPackAdvance:8,readValueFromPointer:jo,destructorFunction:Rt}]})}function hr(J){switch(J){case 1:return 0;case 2:return 1;case 4:return 2;case 8:return 3;default:throw new TypeError("Unknown type size: "+J)}}function Mh(){for(var J=new Array(256),v=0;v<256;++v)J[v]=String.fromCharCode(v);Uh=J}var Uh=void 0;function Vn(J){for(var v="",st=J;ee[st];)v+=Uh[ee[st++]];return v}var cr=void 0;function Ii(J){throw new cr(J)}function Vo(J,v,st){if(st=st||{},!("argPackAdvance"in v))throw new TypeError("registerType registeredInstance requires argPackAdvance");var Rt=v.name;if(J||Ii('type "'+Rt+'" must have a positive integer typeid pointer'),on.hasOwnProperty(J)){if(st.ignoreDuplicateRegistrations)return;Ii("Cannot register type '"+Rt+"' twice")}if(on[J]=v,delete ws[J],ds.hasOwnProperty(J)){var St=ds[J];delete ds[J],St.forEach(function(Gt){Gt()})}}function Kc(J,v,st,Rt,St){var Gt=hr(st);v=Vn(v),Vo(J,{name:v,fromWireType:function(jt){return!!jt},toWireType:function(jt,Ut){return Ut?Rt:St},argPackAdvance:8,readValueFromPointer:function(jt){var Ut;if(st===1)Ut=Ft;else if(st===2)Ut=ce;else if(st===4)Ut=Oe;else throw new TypeError("Unknown boolean type size: "+v);return this.fromWireType(Ut[jt>>Gt])},destructorFunction:null})}function Xc(J){if(!(this instanceof dr)||!(J instanceof dr))return!1;for(var v=this.$$.ptrType.registeredClass,st=this.$$.ptr,Rt=J.$$.ptrType.registeredClass,St=J.$$.ptr;v.baseClass;)st=v.upcast(st),v=v.baseClass;for(;Rt.baseClass;)St=Rt.upcast(St),Rt=Rt.baseClass;return v===Rt&&st===St}function qc(J){return{count:J.count,deleteScheduled:J.deleteScheduled,preservePointerOnDelete:J.preservePointerOnDelete,ptr:J.ptr,ptrType:J.ptrType,smartPtr:J.smartPtr,smartPtrType:J.smartPtrType}}function Qh(J){function v(st){return st.$$.ptrType.registeredClass.name}Ii(v(J)+" instance already deleted")}var kh=!1;function Aa(J){}function Lh(J){J.smartPtr?J.smartPtrType.rawDestructor(J.smartPtr):J.ptrType.registeredClass.rawDestructor(J.ptr)}function ha(J){J.count.value-=1;var v=J.count.value===0;v&&Lh(J)}function Ka(J){return typeof FinalizationGroup>"u"?(Ka=function(v){return v},J):(kh=new FinalizationGroup(function(v){for(var st=v.next();!st.done;st=v.next()){var Rt=st.value;Rt.ptr?ha(Rt):console.warn("object already deleted: "+Rt.ptr)}}),Ka=function(v){return kh.register(v,v.$$,v.$$),v},Aa=function(v){kh.unregister(v.$$)},Ka(J))}function Sd(){if(this.$$.ptr||Qh(this),this.$$.preservePointerOnDelete)return this.$$.count.value+=1,this;var J=Ka(Object.create(Object.getPrototypeOf(this),{$$:{value:qc(this.$$)}}));return J.$$.count.value+=1,J.$$.deleteScheduled=!1,J}function Xa(){this.$$.ptr||Qh(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&Ii("Object already scheduled for deletion"),Aa(this),ha(this.$$),this.$$.preservePointerOnDelete||(this.$$.smartPtr=void 0,this.$$.ptr=void 0)}function Od(){return!this.$$.ptr}var qa=void 0,lr=[];function kA(){for(;lr.length;){var J=lr.pop();J.$$.deleteScheduled=!1,J.delete()}}function $a(){return this.$$.ptr||Qh(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&Ii("Object already scheduled for deletion"),lr.push(this),lr.length===1&&qa&&qa(kA),this.$$.deleteScheduled=!0,this}function Vd(){dr.prototype.isAliasOf=Xc,dr.prototype.clone=Sd,dr.prototype.delete=Xa,dr.prototype.isDeleted=Od,dr.prototype.deleteLater=$a}function dr(){}var $c={};function tl(J,v,st){if(J[v].overloadTable===void 0){var Rt=J[v];J[v]=function(){return J[v].overloadTable.hasOwnProperty(arguments.length)||Ii("Function '"+st+"' called with an invalid number of arguments ("+arguments.length+") - expects one of ("+J[v].overloadTable+")!"),J[v].overloadTable[arguments.length].apply(this,arguments)},J[v].overloadTable=[],J[v].overloadTable[Rt.argCount]=Rt}}function yh(J,v,st){i.hasOwnProperty(J)?((st===void 0||i[J].overloadTable!==void 0&&i[J].overloadTable[st]!==void 0)&&Ii("Cannot register public name '"+J+"' twice"),tl(i,J,J),i.hasOwnProperty(st)&&Ii("Cannot register multiple overloads of a function with the same number of arguments ("+st+")!"),i[J].overloadTable[st]=v):(i[J]=v,st!==void 0&&(i[J].numArguments=st))}function mr(J,v,st,Rt,St,Gt,jt,Ut){this.name=J,this.constructor=v,this.instancePrototype=st,this.rawDestructor=Rt,this.baseClass=St,this.getActualType=Gt,this.upcast=jt,this.downcast=Ut,this.pureVirtualFunctions=[]}function wh(J,v,st){for(;v!==st;)v.upcast||Ii("Expected null or instance of "+st.name+", got an instance of "+v.name),J=v.upcast(J),v=v.baseClass;return J}function Gd(J,v){if(v===null)return this.isReference&&Ii("null is not a valid "+this.name),0;v.$$||Ii('Cannot pass "'+da(v)+'" as a '+this.name),v.$$.ptr||Ii("Cannot pass deleted object as a pointer of type "+this.name);var st=v.$$.ptrType.registeredClass,Rt=wh(v.$$.ptr,st,this.registeredClass);return Rt}function xh(J,v){var st;if(v===null)return this.isReference&&Ii("null is not a valid "+this.name),this.isSmartPointer?(st=this.rawConstructor(),J!==null&&J.push(this.rawDestructor,st),st):0;v.$$||Ii('Cannot pass "'+da(v)+'" as a '+this.name),v.$$.ptr||Ii("Cannot pass deleted object as a pointer of type "+this.name),!this.isConst&&v.$$.ptrType.isConst&&Ii("Cannot convert argument of type "+(v.$$.smartPtrType?v.$$.smartPtrType.name:v.$$.ptrType.name)+" to parameter type "+this.name);var Rt=v.$$.ptrType.registeredClass;if(st=wh(v.$$.ptr,Rt,this.registeredClass),this.isSmartPointer)switch(v.$$.smartPtr===void 0&&Ii("Passing raw pointer to smart pointer is illegal"),this.sharingPolicy){case 0:v.$$.smartPtrType===this?st=v.$$.smartPtr:Ii("Cannot convert argument of type "+(v.$$.smartPtrType?v.$$.smartPtrType.name:v.$$.ptrType.name)+" to parameter type "+this.name);break;case 1:st=v.$$.smartPtr;break;case 2:if(v.$$.smartPtrType===this)st=v.$$.smartPtr;else{var St=v.clone();st=this.rawShare(st,ho(function(){St.delete()})),J!==null&&J.push(this.rawDestructor,st)}break;default:Ii("Unsupporting sharing policy")}return st}function Ph(J,v){if(v===null)return this.isReference&&Ii("null is not a valid "+this.name),0;v.$$||Ii('Cannot pass "'+da(v)+'" as a '+this.name),v.$$.ptr||Ii("Cannot pass deleted object as a pointer of type "+this.name),v.$$.ptrType.isConst&&Ii("Cannot convert argument of type "+v.$$.ptrType.name+" to parameter type "+this.name);var st=v.$$.ptrType.registeredClass,Rt=wh(v.$$.ptr,st,this.registeredClass);return Rt}function el(J){return this.rawGetPointee&&(J=this.rawGetPointee(J)),J}function il(J){this.rawDestructor&&this.rawDestructor(J)}function Bd(J){J!==null&&J.delete()}function tA(J,v,st){if(v===st)return J;if(st.baseClass===void 0)return null;var Rt=tA(J,v,st.baseClass);return Rt===null?null:st.downcast(Rt)}function Wd(){return Object.keys(eA).length}function Dd(){var J=[];for(var v in eA)eA.hasOwnProperty(v)&&J.push(eA[v]);return J}function Md(J){qa=J,lr.length&&qa&&qa(kA)}function LA(){i.getInheritedInstanceCount=Wd,i.getLiveInheritedInstances=Dd,i.flushPendingDeletes=kA,i.setDelayFunction=Md}var eA={};function Ud(J,v){for(v===void 0&&Ii("ptr should not be undefined");J.baseClass;)v=J.upcast(v),J=J.baseClass;return v}function Qd(J,v){return v=Ud(J,v),eA[v]}function yA(J,v){(!v.ptrType||!v.ptr)&&xs("makeClassHandle requires ptr and ptrType");var st=!!v.smartPtrType,Rt=!!v.smartPtr;return st!==Rt&&xs("Both smartPtrType and smartPtr must be specified"),v.count={value:1},Ka(Object.create(J,{$$:{value:v}}))}function Ho(J){var v=this.getPointee(J);if(!v)return this.destructor(J),null;var st=Qd(this.registeredClass,v);if(st!==void 0){if(st.$$.count.value===0)return st.$$.ptr=v,st.$$.smartPtr=J,st.clone();var Rt=st.clone();return this.destructor(J),Rt}function St(){return this.isSmartPointer?yA(this.registeredClass.instancePrototype,{ptrType:this.pointeeType,ptr:v,smartPtrType:this,smartPtr:J}):yA(this.registeredClass.instancePrototype,{ptrType:this,ptr:J})}var Gt=this.registeredClass.getActualType(v),jt=$c[Gt];if(!jt)return St.call(this);var Ut;this.isConst?Ut=jt.constPointerType:Ut=jt.pointerType;var Dt=tA(v,this.registeredClass,Ut.registeredClass);return Dt===null?St.call(this):this.isSmartPointer?yA(Ut.registeredClass.instancePrototype,{ptrType:Ut,ptr:Dt,smartPtrType:this,smartPtr:J}):yA(Ut.registeredClass.instancePrototype,{ptrType:Ut,ptr:Dt})}function nl(){vo.prototype.getPointee=el,vo.prototype.destructor=il,vo.prototype.argPackAdvance=8,vo.prototype.readValueFromPointer=jo,vo.prototype.deleteObject=Bd,vo.prototype.fromWireType=Ho}function vo(J,v,st,Rt,St,Gt,jt,Ut,Dt,pe,Be){this.name=J,this.registeredClass=v,this.isReference=st,this.isConst=Rt,this.isSmartPointer=St,this.pointeeType=Gt,this.sharingPolicy=jt,this.rawGetPointee=Ut,this.rawConstructor=Dt,this.rawShare=pe,this.rawDestructor=Be,!St&&v.baseClass===void 0?Rt?(this.toWireType=Gd,this.destructorFunction=null):(this.toWireType=Ph,this.destructorFunction=null):this.toWireType=xh}function iA(J,v,st){i.hasOwnProperty(J)||xs("Replacing nonexistant public symbol"),i[J].overloadTable!==void 0&&st!==void 0?i[J].overloadTable[st]=v:(i[J]=v,i[J].argCount=st)}function Jh(J,v,st){var Rt=i["dynCall_"+J];return st&&st.length?Rt.apply(null,[v].concat(st)):Rt.call(null,v)}function kd(J,v,st){return J.indexOf("j")!=-1?Jh(J,v,st):ze.get(v).apply(null,st)}function Ld(J,v){var st=[];return function(){st.length=arguments.length;for(var Rt=0;Rt<arguments.length;Rt++)st[Rt]=arguments[Rt];return kd(J,v,st)}}function jn(J,v){J=Vn(J);function st(){return J.indexOf("j")!=-1?Ld(J,v):ze.get(v)}var Rt=st();return typeof Rt!="function"&&Ii("unknown function pointer with signature "+J+": "+v),Rt}var sl=void 0;function jh(J){var v=pt(J),st=Vn(v);return et(v),st}function nA(J,v){var st=[],Rt={};function St(Gt){if(!Rt[Gt]&&!on[Gt]){if(ws[Gt]){ws[Gt].forEach(St);return}st.push(Gt),Rt[Gt]=!0}}throw v.forEach(St),new sl(J+": "+st.map(jh).join([", "]))}function ca(J,v,st,Rt,St,Gt,jt,Ut,Dt,pe,Be,ci,pi){Be=Vn(Be),Gt=jn(St,Gt),Ut&&(Ut=jn(jt,Ut)),pe&&(pe=jn(Dt,pe)),pi=jn(ci,pi);var cn=Oo(Be);yh(cn,function(){nA("Cannot construct "+Be+" due to unbound types",[Rt])}),gs([J,v,st],Rt?[Rt]:[],function(Qe){Qe=Qe[0];var Xs,zo;Rt?(Xs=Qe.registeredClass,zo=Xs.instancePrototype):zo=dr.prototype;var Sr=$e(cn,function(){if(Object.getPrototypeOf(this)!==ml)throw new cr("Use 'new' to construct "+Be);if(Ra.constructor_body===void 0)throw new cr(Be+" has no accessible constructor");var HR=Ra.constructor_body[arguments.length];if(HR===void 0)throw new cr("Tried to invoke ctor of "+Be+" with invalid number of parameters ("+arguments.length+") - expected ("+Object.keys(Ra.constructor_body).toString()+") parameters instead!");return HR.apply(this,arguments)}),ml=Object.create(zo,{constructor:{value:Sr}});Sr.prototype=ml;var Ra=new mr(Be,Sr,ml,pi,Xs,Gt,Ut,pe),iE=new vo(Be,Ra,!0,!1,!1),jR=new vo(Be+"*",Ra,!1,!1,!1),Em=new vo(Be+" const*",Ra,!1,!0,!1);return $c[J]={pointerType:jR,constPointerType:Em},iA(cn,Sr),[iE,jR,Em]})}function Hh(J,v){for(var st=[],Rt=0;Rt<J;Rt++)st.push(Oe[(v>>2)+Rt]);return st}function vh(J,v,st,Rt,St,Gt){w(v>0);var jt=Hh(v,st);St=jn(Rt,St);var Ut=[Gt],Dt=[];gs([],[J],function(pe){pe=pe[0];var Be="constructor "+pe.name;if(pe.registeredClass.constructor_body===void 0&&(pe.registeredClass.constructor_body=[]),pe.registeredClass.constructor_body[v-1]!==void 0)throw new cr("Cannot register multiple constructors with identical number of parameters ("+(v-1)+") for class '"+pe.name+"'! Overload resolution is currently only performed using the parameter count, not actual type info!");return pe.registeredClass.constructor_body[v-1]=function(){nA("Cannot construct "+pe.name+" due to unbound types",jt)},gs([],jt,function(ci){return pe.registeredClass.constructor_body[v-1]=function(){arguments.length!==v-1&&Ii(Be+" called with "+arguments.length+" arguments, expected "+(v-1)),Dt.length=0,Ut.length=v;for(var cn=1;cn<v;++cn)Ut[cn]=ci[cn].toWireType(Dt,arguments[cn-1]);var Qe=St.apply(null,Ut);return hn(Dt),ci[0].fromWireType(Qe)},[]}),[]})}function wA(J,v){if(!(J instanceof Function))throw new TypeError("new_ called with constructor type "+typeof J+" which is not a function");var st=$e(J.name||"unknownFunctionName",function(){});st.prototype=J.prototype;var Rt=new st,St=J.apply(Rt,v);return St instanceof Object?St:Rt}function ol(J,v,st,Rt,St){var Gt=v.length;Gt<2&&Ii("argTypes array size mismatch! Must at least get return value and 'this' types!");for(var jt=v[1]!==null&&st!==null,Ut=!1,Dt=1;Dt<v.length;++Dt)if(v[Dt]!==null&&v[Dt].destructorFunction===void 0){Ut=!0;break}for(var pe=v[0].name!=="void",Be="",ci="",Dt=0;Dt<Gt-2;++Dt)Be+=(Dt!==0?", ":"")+"arg"+Dt,ci+=(Dt!==0?", ":"")+"arg"+Dt+"Wired";var pi="return function "+Oo(J)+"("+Be+`) {
if (arguments.length !== `+(Gt-2)+`) {
throwBindingError('function `+J+" called with ' + arguments.length + ' arguments, expected "+(Gt-2)+` args!');
}
`;Ut&&(pi+=`var destructors = [];
`);var cn=Ut?"destructors":"null",Qe=["throwBindingError","invoker","fn","runDestructors","retType","classParam"],Xs=[Ii,Rt,St,hn,v[0],v[1]];jt&&(pi+="var thisWired = classParam.toWireType("+cn+`, this);
`);for(var Dt=0;Dt<Gt-2;++Dt)pi+="var arg"+Dt+"Wired = argType"+Dt+".toWireType("+cn+", arg"+Dt+"); // "+v[Dt+2].name+`
`,Qe.push("argType"+Dt),Xs.push(v[Dt+2]);if(jt&&(ci="thisWired"+(ci.length>0?", ":"")+ci),pi+=(pe?"var rv = ":"")+"invoker(fn"+(ci.length>0?", ":"")+ci+`);
`,Ut)pi+=`runDestructors(destructors);
`;else for(var Dt=jt?1:2;Dt<v.length;++Dt){var zo=Dt===1?"thisWired":"arg"+(Dt-2)+"Wired";v[Dt].destructorFunction!==null&&(pi+=zo+"_dtor("+zo+"); // "+v[Dt].name+`
`,Qe.push(zo+"_dtor"),Xs.push(v[Dt].destructorFunction))}pe&&(pi+=`var ret = retType.fromWireType(rv);
return ret;
`),pi+=`}
`,Qe.push(pi);var Sr=wA(Function,Qe).apply(null,Xs);return Sr}function zh(J,v,st,Rt,St,Gt,jt,Ut){var Dt=Hh(st,Rt);v=Vn(v),Gt=jn(St,Gt),gs([],[J],function(pe){pe=pe[0];var Be=pe.name+"."+v;Ut&&pe.registeredClass.pureVirtualFunctions.push(v);function ci(){nA("Cannot call "+Be+" due to unbound types",Dt)}var pi=pe.registeredClass.instancePrototype,cn=pi[v];return cn===void 0||cn.overloadTable===void 0&&cn.className!==pe.name&&cn.argCount===st-2?(ci.argCount=st-2,ci.className=pe.name,pi[v]=ci):(tl(pi,v,Be),pi[v].overloadTable[st-2]=ci),gs([],Dt,function(Qe){var Xs=ol(Be,Qe,pe,Gt,jt);return pi[v].overloadTable===void 0?(Xs.argCount=st-2,pi[v]=Xs):pi[v].overloadTable[st-2]=Xs,[]}),[]})}function yd(J,v,st){J=Vn(J),gs([],[v],function(Rt){return Rt=Rt[0],i[J]=Rt.fromWireType(st),[]})}var Kh=[],Ss=[{},{value:void 0},{value:null},{value:!0},{value:!1}];function Xh(J){J>4&&--Ss[J].refcount===0&&(Ss[J]=void 0,Kh.push(J))}function wd(){for(var J=0,v=5;v<Ss.length;++v)Ss[v]!==void 0&&++J;return J}function rl(){for(var J=5;J<Ss.length;++J)if(Ss[J]!==void 0)return Ss[J];return null}function Ao(){i.count_emval_handles=wd,i.get_first_emval=rl}function ho(J){switch(J){case void 0:return 1;case null:return 2;case!0:return 3;case!1:return 4;default:{var v=Kh.length?Kh.pop():Ss.length;return Ss[v]={refcount:1,value:J},v}}}function xd(J,v){v=Vn(v),Vo(J,{name:v,fromWireType:function(st){var Rt=Ss[st].value;return Xh(st),Rt},toWireType:function(st,Rt){return ho(Rt)},argPackAdvance:8,readValueFromPointer:jo,destructorFunction:null})}function Pd(J,v,st){switch(v){case 0:return function(Rt){var St=st?Ft:ee;return this.fromWireType(St[Rt])};case 1:return function(Rt){var St=st?ce:je;return this.fromWireType(St[Rt>>1])};case 2:return function(Rt){var St=st?Oe:Me;return this.fromWireType(St[Rt>>2])};default:throw new TypeError("Unknown integer type: "+J)}}function Go(J,v,st,Rt){var St=hr(st);v=Vn(v);function Gt(){}Gt.values={},Vo(J,{name:v,constructor:Gt,fromWireType:function(jt){return this.constructor.values[jt]},toWireType:function(jt,Ut){return Ut.value},argPackAdvance:8,readValueFromPointer:Pd(v,St,Rt),destructorFunction:null}),yh(v,Gt)}function xA(J,v){var st=on[J];return st===void 0&&Ii(v+" has unknown type "+jh(J)),st}function la(J,v,st){var Rt=xA(J,"enum");v=Vn(v);var St=Rt.constructor,Gt=Object.create(Rt.constructor.prototype,{value:{value:st},constructor:{value:$e(Rt.name+"_"+v,function(){})}});St.values[st]=Gt,St[v]=Gt}function da(J){if(J===null)return"null";var v=typeof J;return v==="object"||v==="array"||v==="function"?J.toString():""+J}function Jd(J,v){switch(v){case 2:return function(st){return this.fromWireType(Ue[st>>2])};case 3:return function(st){return this.fromWireType(Ce[st>>3])};default:throw new TypeError("Unknown float type: "+J)}}function jd(J,v,st){var Rt=hr(st);v=Vn(v),Vo(J,{name:v,fromWireType:function(St){return St},toWireType:function(St,Gt){if(typeof Gt!="number"&&typeof Gt!="boolean")throw new TypeError('Cannot convert "'+da(Gt)+'" to '+this.name);return Gt},argPackAdvance:8,readValueFromPointer:Jd(v,Rt),destructorFunction:null})}function Hd(J,v,st,Rt,St,Gt){var jt=Hh(v,st);J=Vn(J),St=jn(Rt,St),yh(J,function(){nA("Cannot call "+J+" due to unbound types",jt)},v-1),gs([],jt,function(Ut){var Dt=[Ut[0],null].concat(Ut.slice(1));return iA(J,ol(J,Dt,null,St,Gt),v-1),[]})}function vd(J,v,st){switch(v){case 0:return st?function(St){return Ft[St]}:function(St){return ee[St]};case 1:return st?function(St){return ce[St>>1]}:function(St){return je[St>>1]};case 2:return st?function(St){return Oe[St>>2]}:function(St){return Me[St>>2]};default:throw new TypeError("Unknown integer type: "+J)}}function zd(J,v,st,Rt,St){v=Vn(v),St===-1&&(St=4294967295);var Gt=hr(st),jt=function(pe){return pe};if(Rt===0){var Ut=32-8*st;jt=function(pe){return pe<<Ut>>>Ut}}var Dt=v.indexOf("unsigned")!=-1;Vo(J,{name:v,fromWireType:jt,toWireType:function(pe,Be){if(typeof Be!="number"&&typeof Be!="boolean")throw new TypeError('Cannot convert "'+da(Be)+'" to '+this.name);if(Be<Rt||Be>St)throw new TypeError('Passing a number "'+da(Be)+'" from JS side to C/C++ side to an argument of type "'+v+'", which is outside the valid range ['+Rt+", "+St+"]!");return Dt?Be>>>0:Be|0},argPackAdvance:8,readValueFromPointer:vd(v,Gt,Rt!==0),destructorFunction:null})}function qh(J,v,st){var Rt=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],St=Rt[v];function Gt(jt){jt=jt>>2;var Ut=Me,Dt=Ut[jt],pe=Ut[jt+1];return new St(Wt,pe,Dt)}st=Vn(st),Vo(J,{name:st,fromWireType:Gt,argPackAdvance:8,readValueFromPointer:Gt},{ignoreDuplicateRegistrations:!0})}function PA(J,v){v=Vn(v);var st=v==="std::string";Vo(J,{name:v,fromWireType:function(Rt){var St=Me[Rt>>2],Gt;if(st)for(var jt=Rt+4,Ut=0;Ut<=St;++Ut){var Dt=Rt+4+Ut;if(Ut==St||ee[Dt]==0){var pe=Dt-jt,Be=j(jt,pe);Gt===void 0?Gt=Be:(Gt+="\0",Gt+=Be),jt=Dt+1}}else{for(var ci=new Array(St),Ut=0;Ut<St;++Ut)ci[Ut]=String.fromCharCode(ee[Rt+4+Ut]);Gt=ci.join("")}return et(Rt),Gt},toWireType:function(Rt,St){St instanceof ArrayBuffer&&(St=new Uint8Array(St));var Gt,jt=typeof St=="string";jt||St instanceof Uint8Array||St instanceof Uint8ClampedArray||St instanceof Int8Array||Ii("Cannot pass non-string to std::string"),st&&jt?Gt=function(){return B(St)}:Gt=function(){return St.length};var Ut=Gt(),Dt=z(4+Ut+1);if(Me[Dt>>2]=Ut,st&&jt)tt(St,Dt+4,Ut+1);else if(jt)for(var pe=0;pe<Ut;++pe){var Be=St.charCodeAt(pe);Be>255&&(et(Dt),Ii("String has UTF-16 code units that do not fit in 8 bits")),ee[Dt+4+pe]=Be}else for(var pe=0;pe<Ut;++pe)ee[Dt+4+pe]=St[pe];return Rt!==null&&Rt.push(et,Dt),Dt},argPackAdvance:8,readValueFromPointer:jo,destructorFunction:function(Rt){et(Rt)}})}function ma(J,v,st){st=Vn(st);var Rt,St,Gt,jt,Ut;v===2?(Rt=gt,St=Yt,jt=Mt,Gt=function(){return je},Ut=1):v===4&&(Rt=Ct,St=zt,jt=kt,Gt=function(){return Me},Ut=2),Vo(J,{name:st,fromWireType:function(Dt){for(var pe=Me[Dt>>2],Be=Gt(),ci,pi=Dt+4,cn=0;cn<=pe;++cn){var Qe=Dt+4+cn*v;if(cn==pe||Be[Qe>>Ut]==0){var Xs=Qe-pi,zo=Rt(pi,Xs);ci===void 0?ci=zo:(ci+="\0",ci+=zo),pi=Qe+v}}return et(Dt),ci},toWireType:function(Dt,pe){typeof pe!="string"&&Ii("Cannot pass non-string to C++ string type "+st);var Be=jt(pe),ci=z(4+Be+v);return Me[ci>>2]=Be>>Ut,St(pe,ci+4,Be+v),Dt!==null&&Dt.push(et,ci),ci},argPackAdvance:8,readValueFromPointer:jo,destructorFunction:function(Dt){et(Dt)}})}function al(J,v,st,Rt,St,Gt){qi[J]={name:Vn(v),rawConstructor:jn(st,Rt),rawDestructor:jn(St,Gt),fields:[]}}function fa(J,v,st,Rt,St,Gt,jt,Ut,Dt,pe){qi[J].fields.push({fieldName:Vn(v),getterReturnType:st,getter:jn(Rt,St),getterContext:Gt,setterArgumentType:jt,setter:jn(Ut,Dt),setterContext:pe})}function Ea(J,v){v=Vn(v),Vo(J,{isVoid:!0,name:v,argPackAdvance:0,fromWireType:function(){},toWireType:function(st,Rt){}})}function sA(J){return J||Ii("Cannot use deleted val. handle = "+J),Ss[J].value}function Al(J,v,st){J=sA(J),v=xA(v,"emval::as");var Rt=[],St=ho(Rt);return Oe[st>>2]=St,v.toWireType(Rt,J)}var Kd={};function JA(J){var v=Kd[J];return v===void 0?Vn(J):v}var $h=[];function Xd(J,v,st,Rt){J=$h[J],v=sA(v),st=JA(st),J(v,st,null,Rt)}function hl(){return typeof globalThis=="object"?globalThis:function(){return Function}()("return this")()}function qd(J){return J===0?ho(hl()):(J=JA(J),ho(hl()[J]))}function $d(J){var v=$h.length;return $h.push(J),v}function tm(J,v){for(var st=new Array(J),Rt=0;Rt<J;++Rt)st[Rt]=xA(Oe[(v>>2)+Rt],"parameter "+Rt);return st}function em(J,v){for(var st=tm(J,v),Rt=st[0],St=Rt.name+"_$"+st.slice(1).map(function(cn){return cn.name}).join("_")+"$",Gt=["retType"],jt=[Rt],Ut="",Dt=0;Dt<J-1;++Dt)Ut+=(Dt!==0?", ":"")+"arg"+Dt,Gt.push("argType"+Dt),jt.push(st[1+Dt]);for(var pe=Oo("methodCaller_"+St),Be="return function "+pe+`(handle, name, destructors, args) {
`,ci=0,Dt=0;Dt<J-1;++Dt)Be+="    var arg"+Dt+" = argType"+Dt+".readValueFromPointer(args"+(ci?"+"+ci:"")+`);
`,ci+=st[Dt+1].argPackAdvance;Be+="    var rv = handle[name]("+Ut+`);
`;for(var Dt=0;Dt<J-1;++Dt)st[Dt+1].deleteObject&&(Be+="    argType"+Dt+".deleteObject(arg"+Dt+`);
`);Rt.isVoid||(Be+=`    return retType.toWireType(destructors, rv);
`),Be+=`};
`,Gt.push(Be);var pi=wA(Function,Gt).apply(null,jt);return $d(pi)}function im(J){return J=JA(J),ho(i[J])}function nm(J,v){return J=sA(J),v=sA(v),ho(J[v])}function sm(J){J>4&&(Ss[J].refcount+=1)}function om(J){for(var v="",st=0;st<J;++st)v+=(st!==0?", ":"")+"arg"+st;for(var Rt="return function emval_allocator_"+J+`(constructor, argTypes, args) {
`,st=0;st<J;++st)Rt+="var argType"+st+" = requireRegisteredType(Module['HEAP32'][(argTypes >>> 2) + "+st+'], "parameter '+st+`");
var arg`+st+" = argType"+st+`.readValueFromPointer(args);
args += argType`+st+`['argPackAdvance'];
`;return Rt+="var obj = new constructor("+v+`);
return __emval_register(obj);
}
`,new Function("requireRegisteredType","Module","__emval_register",Rt)(xA,i,ho)}var cl={};function rm(J,v,st,Rt){J=sA(J);var St=cl[v];return St||(St=om(v),cl[v]=St),St(J,st,Rt)}function am(J){return ho(JA(J))}function Am(J){var v=Ss[J].value;hn(v),Xh(J)}function ll(){ki()}function hm(J,v,st){ee.copyWithin(J,v,v+st)}function oA(J){try{return g.grow(J-Wt.byteLength+65535>>>16),be(g.buffer),1}catch{}}function cm(J){var v=ee.length;J=J>>>0;var st=2147483648;if(J>st)return!1;for(var Rt=1;Rt<=4;Rt*=2){var St=v*(1+.2/Rt);St=Math.min(St,J+100663296);var Gt=Math.min(st,Jt(Math.max(J,St),65536)),jt=oA(Gt);if(jt)return!0}return!1}var jA={mappings:{},buffers:[null,[],[]],printChar:function(J,v){var st=jA.buffers[J];v===0||v===10?((J===1?M:Q)(H(st,0)),st.length=0):st.push(v)},varargs:void 0,get:function(){jA.varargs+=4;var J=Oe[jA.varargs-4>>2];return J},getStr:function(J){var v=j(J);return v},get64:function(J,v){return J}};function lm(J){return 0}function dm(J,v,st,Rt,St){}function dl(J,v,st,Rt){for(var St=0,Gt=0;Gt<st;Gt++){for(var jt=Oe[v+Gt*8>>2],Ut=Oe[v+(Gt*8+4)>>2],Dt=0;Dt<Ut;Dt++)jA.printChar(J,ee[jt+Dt]);St+=Ut}return Oe[Rt>>2]=St,0}function mm(J){k(J|0)}Yr=i.InternalError=aa(Error,"InternalError"),Mh(),cr=i.BindingError=aa(Error,"BindingError"),Vd(),nl(),LA(),sl=i.UnboundTypeError=aa(Error,"UnboundTypeError"),Ao();var fm={t:Tn,I:Kc,x:ca,w:vh,d:zh,k:yd,H:xd,n:Go,a:la,A:jd,i:Hd,j:zd,h:qh,B:PA,v:ma,u:al,c:fa,J:Ea,m:Al,s:Xd,b:Xh,y:qd,p:em,r:im,e:nm,g:sm,q:rm,f:am,l:Am,o:ll,E:hm,F:cm,G:lm,C:dm,z:dl,D:mm},rA=ls(),fi=i.___wasm_call_ctors=function(){return(fi=i.___wasm_call_ctors=i.asm.L).apply(null,arguments)},z=i._malloc=function(){return(z=i._malloc=i.asm.M).apply(null,arguments)},et=i._free=function(){return(et=i._free=i.asm.N).apply(null,arguments)},pt=i.___getTypeName=function(){return(pt=i.___getTypeName=i.asm.P).apply(null,arguments)},$t=i.___embind_register_native_and_builtin_types=function(){return($t=i.___embind_register_native_and_builtin_types=i.asm.Q).apply(null,arguments)},ve=i.dynCall_jiji=function(){return(ve=i.dynCall_jiji=i.asm.R).apply(null,arguments)},hi;function _a(J){this.name="ExitStatus",this.message="Program terminated with exit("+J+")",this.status=J}hs=function J(){hi||tc(),hi||(hs=J)};function tc(J){if(J=J||a,ei>0||(Vi(),ei>0))return;function v(){hi||(hi=!0,i.calledRun=!0,!V&&(gn(),De(),n(i),i.onRuntimeInitialized&&i.onRuntimeInitialized(),Ye()))}i.setStatus?(i.setStatus("Running..."),setTimeout(function(){setTimeout(function(){i.setStatus("")},1),v()},1)):v()}if(i.run=tc,i.preInit)for(typeof i.preInit=="function"&&(i.preInit=[i.preInit]);i.preInit.length>0;)i.preInit.pop()();return tc(),e.ready}}();typeof Hg=="object"&&typeof YB=="object"?YB.exports=FB:typeof define=="function"&&define.amd?define([],function(){return FB}):typeof Hg=="object"&&(Hg.BASIS=FB)});var SB={};He(SB,{default:()=>CZt});function RZt(t,e){p.typeOf.object("transcoderModule",JR);let i=t.ktx2Buffer,n=t.supportedTargetFormats,s;try{s=UX(i)}catch{throw new ke("Invalid KTX2 file.")}if(s.layerCount!==0)throw new ke("KTX2 texture arrays are not supported.");if(s.pixelDepth!==0)throw new ke("KTX2 3D textures are unsupported.");let o=s.dataFormatDescriptor[0],r=new Array(s.levelCount);return s.vkFormat===0&&(o.colorModel===wX||o.colorModel===xX)?IZt(i,s,n,JR,e,r):(e.push(i.buffer),ZZt(s,r)),r}function ZZt(t,e){let i=t.vkFormat===PR.VK_FORMAT_R8G8B8_SRGB?Ie.RGB:Ie.RGBA,n;t.vkFormat===PR.VK_FORMAT_R8G8B8A8_UNORM?n=ge.UNSIGNED_BYTE:t.vkFormat===PR.VK_FORMAT_R16G16B16A16_SFLOAT?n=ge.HALF_FLOAT:t.vkFormat===PR.VK_FORMAT_R32G32B32A32_SFLOAT&&(n=ge.FLOAT);for(let s=0;s<t.levels.length;++s){let o={};e[s]=o;let r=t.levels[s].levelData,a=t.pixelWidth>>s,h=t.pixelHeight>>s,A=a*h*Ie.componentsLength(i);for(let d=0;d<t.faceCount;++d){let f=r.byteOffset+A*t.typeSize*d,E;!m(n)||ge.sizeInBytes(n)===1?E=new Uint8Array(r.buffer,f,A):ge.sizeInBytes(n)===2?E=new Uint16Array(r.buffer,f,A):E=new Float32Array(r.buffer,f,A),o[yX[d]]={internalFormat:i,datatype:n,width:a,height:h,levelBuffer:E}}}}function IZt(t,e,i,n,s,o){let r=new n.KTX2File(t),a=r.getWidth(),h=r.getHeight(),A=r.getLevels(),d=r.getHasAlpha();if(!(a>0)||!(h>0)||!(A>0))throw r.close(),r.delete(),new ke("Invalid KTX2 file");let f,E,_=e.dataFormatDescriptor[0],R=n.transcoder_texture_format;if(_.colorModel===wX)if(i.etc)f=d?Ie.RGBA8_ETC2_EAC:Ie.RGB8_ETC2,E=d?R.cTFETC2_RGBA:R.cTFETC1_RGB;else if(i.etc1&&!d)f=Ie.RGB_ETC1,E=R.cTFETC1_RGB;else if(i.s3tc)f=d?Ie.RGBA_DXT5:Ie.RGB_DXT1,E=d?R.cTFBC3_RGBA:R.cTFBC1_RGB;else if(i.pvrtc)f=d?Ie.RGBA_PVRTC_4BPPV1:Ie.RGB_PVRTC_4BPPV1,E=d?R.cTFPVRTC1_4_RGBA:R.cTFPVRTC1_4_RGB;else if(i.astc)f=Ie.RGBA_ASTC,E=R.cTFASTC_4x4_RGBA;else if(i.bc7)f=Ie.RGBA_BC7,E=R.cTFBC7_RGBA;else throw new ke("No transcoding format target available for ETC1S compressed ktx2.");else if(_.colorModel===xX)if(i.astc)f=Ie.RGBA_ASTC,E=R.cTFASTC_4x4_RGBA;else if(i.bc7)f=Ie.RGBA_BC7,E=R.cTFBC7_RGBA;else if(i.s3tc)f=d?Ie.RGBA_DXT5:Ie.RGB_DXT1,E=d?R.cTFBC3_RGBA:R.cTFBC1_RGB;else if(i.etc)f=d?Ie.RGBA8_ETC2_EAC:Ie.RGB8_ETC2,E=d?R.cTFETC2_RGBA:R.cTFETC1_RGB;else if(i.etc1&&!d)f=Ie.RGB_ETC1,E=R.cTFETC1_RGB;else if(i.pvrtc)f=d?Ie.RGBA_PVRTC_4BPPV1:Ie.RGB_PVRTC_4BPPV1,E=d?R.cTFPVRTC1_4_RGBA:R.cTFPVRTC1_4_RGB;else throw new ke("No transcoding format target available for UASTC compressed ktx2.");if(!r.startTranscoding())throw r.close(),r.delete(),new ke("startTranscoding() failed");for(let I=0;I<e.levels.length;++I){let C={};o[I]=C,a=e.pixelWidth>>I,h=e.pixelHeight>>I;let N=r.getImageTranscodedSizeInBytes(I,0,0,E.value),T=new Uint8Array(N),F=r.transcodeImage(T,I,0,0,E.value,0,-1,-1);if(!m(F))throw new ke("transcodeImage() failed.");s.push(T.buffer),C[yX[0]]={internalFormat:f,width:a,height:h,levelBuffer:T}}return r.close(),r.delete(),o}async function pZt(t,e){let i=t.webAssemblyConfig,n=Z(LX.default,self.BASIS);return m(i.wasmBinaryFile)?JR=await n(i):JR=await n(),JR.initializeBasis(),!0}function uZt(t,e){let i=t.webAssemblyConfig;return m(i)?pZt(t,e):RZt(t,e)}var LX,yX,wX,xX,JR,CZt,OB=O(()=>{bt();mt();ae();_c();Ps();DX();Ec();Ns();QX();LX=co(kX(),1),yX=["positiveX","negativeX","positiveY","negativeY","positiveZ","negativeZ"],wX=163,xX=166;CZt=Wi(uZt)});var PX={};var VB=O(()=>{self.onmessage=function(t){let e=t.data.array,i=self.webkitPostMessage||self.postMessage;try{i({array:e},[e.buffer])}catch{i({})}}});var vg,zg,JX=O(()=>{Xe();Ht();ae();mt();Vt();vg={};vg.clipTriangleAtAxisAlignedThreshold=function(t,e,i,n,s,o){if(!m(t))throw new Y("threshold is required.");if(!m(e))throw new Y("keepAbove is required.");if(!m(i))throw new Y("u0 is required.");if(!m(n))throw new Y("u1 is required.");if(!m(s))throw new Y("u2 is required.");m(o)?o.length=0:o=[];let r,a,h;e?(r=i<t,a=n<t,h=s<t):(r=i>t,a=n>t,h=s>t);let A=r+a+h,d,f,E,_,R,I;return A===1?r?(d=(t-i)/(n-i),f=(t-i)/(s-i),o.push(1),o.push(2),f!==1&&(o.push(-1),o.push(0),o.push(2),o.push(f)),d!==1&&(o.push(-1),o.push(0),o.push(1),o.push(d))):a?(E=(t-n)/(s-n),_=(t-n)/(i-n),o.push(2),o.push(0),_!==1&&(o.push(-1),o.push(1),o.push(0),o.push(_)),E!==1&&(o.push(-1),o.push(1),o.push(2),o.push(E))):h&&(R=(t-s)/(i-s),I=(t-s)/(n-s),o.push(0),o.push(1),I!==1&&(o.push(-1),o.push(2),o.push(1),o.push(I)),R!==1&&(o.push(-1),o.push(2),o.push(0),o.push(R))):A===2?!r&&i!==t?(_=(t-n)/(i-n),R=(t-s)/(i-s),o.push(0),o.push(-1),o.push(1),o.push(0),o.push(_),o.push(-1),o.push(2),o.push(0),o.push(R)):!a&&n!==t?(I=(t-s)/(n-s),d=(t-i)/(n-i),o.push(1),o.push(-1),o.push(2),o.push(1),o.push(I),o.push(-1),o.push(0),o.push(1),o.push(d)):!h&&s!==t&&(f=(t-i)/(s-i),E=(t-n)/(s-n),o.push(2),o.push(-1),o.push(0),o.push(2),o.push(f),o.push(-1),o.push(1),o.push(2),o.push(E)):A!==3&&(o.push(0),o.push(1),o.push(2)),o};vg.computeBarycentricCoordinates=function(t,e,i,n,s,o,r,a,h){if(!m(t))throw new Y("x is required.");if(!m(e))throw new Y("y is required.");if(!m(i))throw new Y("x1 is required.");if(!m(n))throw new Y("y1 is required.");if(!m(s))throw new Y("x2 is required.");if(!m(o))throw new Y("y2 is required.");if(!m(r))throw new Y("x3 is required.");if(!m(a))throw new Y("y3 is required.");let A=i-r,d=r-s,f=o-a,E=n-a,_=1/(f*A+d*E),R=e-a,I=t-r,C=(f*I+d*R)*_,N=(-E*I+A*R)*_,T=1-C-N;return m(h)?(h.x=C,h.y=N,h.z=T,h):new l(C,N,T)};vg.computeLineSegmentLineSegmentIntersection=function(t,e,i,n,s,o,r,a,h){p.typeOf.number("x00",t),p.typeOf.number("y00",e),p.typeOf.number("x01",i),p.typeOf.number("y01",n),p.typeOf.number("x10",s),p.typeOf.number("y10",o),p.typeOf.number("x11",r),p.typeOf.number("y11",a);let A=(r-s)*(e-o)-(a-o)*(t-s),d=(i-t)*(e-o)-(n-e)*(t-s),f=(a-o)*(i-t)-(r-s)*(n-e);if(f===0)return;let E=A/f,_=d/f;if(E>=0&&E<=1&&_>=0&&_<=1)return m(h)||(h=new nt),h.x=t+E*(i-t),h.y=e+E*(n-e),h};zg=vg});var GB={};He(GB,{default:()=>QZt});function DZt(t,e){let i=t.isEastChild,n=t.isNorthChild,s=i?za:0,o=i?ps:za,r=n?za:0,a=n?ps:za,h=NZt,A=bZt,d=FZt,f=SZt;h.length=0,A.length=0,d.length=0,f.length=0;let E=YZt;E.length=0;let _={},R=t.vertices,I=t.indices;I=I.subarray(0,t.indexCountWithoutSkirts);let C=vc.clone(t.encoding),N=C.hasVertexNormals,T=0,F=t.vertexCountWithoutSkirts,b=t.minimumHeight,G=t.maximumHeight,M=new Array(F),Q=new Array(F),U=new Array(F),k=N?new Array(F*2):void 0,y=20,c,g,V,D,w;for(g=0,V=0;g<F;++g,V+=2){let Ri=C.decodeTextureCoordinates(R,g,BZt);if(c=C.decodeHeight(R,g),D=L.clamp(Ri.x*ps|0,0,ps),w=L.clamp(Ri.y*ps|0,0,ps),U[g]=L.clamp((c-b)/(G-b)*ps|0,0,ps),D<y&&(D=0),w<y&&(w=0),ps-D<y&&(D=ps),ps-w<y&&(w=ps),M[g]=D,Q[g]=w,N){let si=C.getOctEncodedNormal(R,g,WZt);k[V]=si.x,k[V+1]=si.y}(i&&D>=za||!i&&D<=za)&&(n&&w>=za||!n&&w<=za)&&(_[g]=T,h.push(D),A.push(w),d.push(U[g]),N&&(f.push(k[V]),f.push(k[V+1])),++T)}let x=[];x.push(new us),x.push(new us),x.push(new us);let H=[];H.push(new us),H.push(new us),H.push(new us);let j,X;for(g=0;g<I.length;g+=3){let Ri=I[g],si=I[g+1],qe=I[g+2],Vi=M[Ri],gn=M[si],De=M[qe];x[0].initializeIndexed(M,Q,U,k,Ri),x[1].initializeIndexed(M,Q,U,k,si),x[2].initializeIndexed(M,Q,U,k,qe);let Ye=zg.clipTriangleAtAxisAlignedThreshold(za,i,Vi,gn,De,gZt);j=0,!(j>=Ye.length)&&(j=H[0].initializeFromClipResult(Ye,j,x),!(j>=Ye.length)&&(j=H[1].initializeFromClipResult(Ye,j,x),!(j>=Ye.length)&&(j=H[2].initializeFromClipResult(Ye,j,x),X=zg.clipTriangleAtAxisAlignedThreshold(za,n,H[0].getV(),H[1].getV(),H[2].getV(),jX),HX(h,A,d,f,E,_,X,H,N),j<Ye.length&&(H[2].clone(H[1]),H[2].initializeFromClipResult(Ye,j,x),X=zg.clipTriangleAtAxisAlignedThreshold(za,n,H[0].getV(),H[1].getV(),H[2].getV(),jX),HX(h,A,d,f,E,_,X,H,N)))))}let tt=i?-ps:0,B=n?-ps:0,It=[],gt=[],Yt=[],Mt=[],Ct=Number.MAX_VALUE,zt=-Ct,kt=TZt;kt.length=0;let Jt=ot.clone(t.ellipsoid),Wt=Xt.clone(t.childRectangle),Ft=Wt.north,ee=Wt.south,ce=Wt.east,je=Wt.west;for(ce<je&&(ce+=L.TWO_PI),g=0;g<h.length;++g)D=Math.round(h[g]),D<=s?(It.push(g),D=0):D>=o?(Yt.push(g),D=ps):D=D*2+tt,h[g]=D,w=Math.round(A[g]),w<=r?(gt.push(g),w=0):w>=a?(Mt.push(g),w=ps):w=w*2+B,A[g]=w,c=L.lerp(b,G,d[g]/ps),c<Ct&&(Ct=c),c>zt&&(zt=c),d[g]=c,Kg.longitude=L.lerp(je,ce,D/ps),Kg.latitude=L.lerp(ee,Ft,w/ps),Kg.height=c,Jt.cartographicToCartesian(Kg,Dh),kt.push(Dh.x),kt.push(Dh.y),kt.push(Dh.z);let Oe=Nt.fromVertices(kt,l.ZERO,3,VZt),Me=zs.fromRectangle(Wt,Ct,zt,Jt,GZt),Ce=new dA(Jt).computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid(Oe.center,kt,3,Oe.center,Ct,OZt),be=zt-Ct,ni=new Uint16Array(h.length+A.length+d.length);for(g=0;g<h.length;++g)ni[g]=h[g];let ze=h.length;for(g=0;g<A.length;++g)ni[ze+g]=A[g];for(ze+=A.length,g=0;g<d.length;++g)ni[ze+g]=ps*(d[g]-Ct)/be;let Ge=te.createTypedArray(h.length,E),Ui;if(N){let Ri=new Uint8Array(f);e.push(ni.buffer,Ge.buffer,Ri.buffer),Ui=Ri.buffer}else e.push(ni.buffer,Ge.buffer);return{vertices:ni.buffer,encodedNormals:Ui,indices:Ge.buffer,minimumHeight:Ct,maximumHeight:zt,westIndices:It,southIndices:gt,eastIndices:Yt,northIndices:Mt,boundingSphere:Oe,orientedBoundingBox:Me,horizonOcclusionPoint:Ce}}function us(){this.vertexBuffer=void 0,this.index=void 0,this.first=void 0,this.second=void 0,this.ratio=void 0}function vX(t,e){++Xg;let i=MZt[Xg],n=UZt[Xg];return i=Yi.octDecode(t.first.getNormalX(),t.first.getNormalY(),i),n=Yi.octDecode(t.second.getNormalX(),t.second.getNormalY(),n),Dh=l.lerp(i,n,t.ratio,Dh),l.normalize(Dh,Dh),Yi.octEncode(Dh,e),--Xg,e}function HX(t,e,i,n,s,o,r,a,h){if(r.length===0)return;let A=0,d=0;for(;d<r.length;)d=Jo[A++].initializeFromClipResult(r,d,a);for(let f=0;f<A;++f){let E=Jo[f];if(E.isIndexed())E.newIndex=o[E.index],E.uBuffer=t,E.vBuffer=e,E.heightBuffer=i,h&&(E.normalBuffer=n);else{let _=E.getKey();if(m(o[_]))E.newIndex=o[_];else{let R=t.length;t.push(E.getU()),e.push(E.getV()),i.push(E.getH()),h&&(n.push(E.getNormalX()),n.push(E.getNormalY())),E.newIndex=R,o[_]=R}}}A===3?(s.push(Jo[0].newIndex),s.push(Jo[1].newIndex),s.push(Jo[2].newIndex)):A===4&&(s.push(Jo[0].newIndex),s.push(Jo[1].newIndex),s.push(Jo[2].newIndex),s.push(Jo[0].newIndex),s.push(Jo[2].newIndex),s.push(Jo[3].newIndex))}var ps,za,gZt,jX,TZt,Kg,Dh,NZt,bZt,FZt,YZt,SZt,OZt,VZt,GZt,BZt,WZt,eE,Xg,MZt,UZt,Jo,QZt,BB=O(()=>{oh();_i();Xe();Ht();ri();mt();Ve();Sm();Di();JX();_e();Jl();pn();WR();Ns();ps=32767,za=ps/2|0,gZt=[],jX=[],TZt=[],Kg=new ut,Dh=new l,NZt=[],bZt=[],FZt=[],YZt=[],SZt=[],OZt=new l,VZt=new Nt,GZt=new zs,BZt=new nt,WZt=new l;us.prototype.clone=function(t){return m(t)||(t=new us),t.uBuffer=this.uBuffer,t.vBuffer=this.vBuffer,t.heightBuffer=this.heightBuffer,t.normalBuffer=this.normalBuffer,t.index=this.index,t.first=this.first,t.second=this.second,t.ratio=this.ratio,t};us.prototype.initializeIndexed=function(t,e,i,n,s){this.uBuffer=t,this.vBuffer=e,this.heightBuffer=i,this.normalBuffer=n,this.index=s,this.first=void 0,this.second=void 0,this.ratio=void 0};us.prototype.initializeFromClipResult=function(t,e,i){let n=e+1;return t[e]!==-1?i[t[e]].clone(this):(this.vertexBuffer=void 0,this.index=void 0,this.first=i[t[n]],++n,this.second=i[t[n]],++n,this.ratio=t[n],++n),n};us.prototype.getKey=function(){return this.isIndexed()?this.index:JSON.stringify({first:this.first.getKey(),second:this.second.getKey(),ratio:this.ratio})};us.prototype.isIndexed=function(){return m(this.index)};us.prototype.getH=function(){return m(this.index)?this.heightBuffer[this.index]:L.lerp(this.first.getH(),this.second.getH(),this.ratio)};us.prototype.getU=function(){return m(this.index)?this.uBuffer[this.index]:L.lerp(this.first.getU(),this.second.getU(),this.ratio)};us.prototype.getV=function(){return m(this.index)?this.vBuffer[this.index]:L.lerp(this.first.getV(),this.second.getV(),this.ratio)};eE=new nt,Xg=-1,MZt=[new l,new l],UZt=[new l,new l];us.prototype.getNormalX=function(){return m(this.index)?this.normalBuffer[this.index*2]:(eE=vX(this,eE),eE.x)};us.prototype.getNormalY=function(){return m(this.index)?this.normalBuffer[this.index*2+1]:(eE=vX(this,eE),eE.y)};Jo=[];Jo.push(new us);Jo.push(new us);Jo.push(new us);Jo.push(new us);QZt=Wi(DZt)});var kZt,WB=O(()=>{kZt=jB({"./AnalysisWorker.js":()=>Promise.resolve().then(()=>(i0(),e0)),"./ConjunctionAssessment.js":()=>Promise.resolve().then(()=>(tO(),$S)),"./combineGeometry.js":()=>Promise.resolve().then(()=>(iO(),eO)),"./createBoxGeometry.js":()=>Promise.resolve().then(()=>(rO(),oO)),"./createBoxOutlineGeometry.js":()=>Promise.resolve().then(()=>(hO(),AO)),"./createCircleGeometry.js":()=>Promise.resolve().then(()=>(IO(),ZO)),"./createCircleOutlineGeometry.js":()=>Promise.resolve().then(()=>(gO(),CO)),"./createCoplanarPolygonGeometry.js":()=>Promise.resolve().then(()=>(BO(),GO)),"./createCoplanarPolygonOutlineGeometry.js":()=>Promise.resolve().then(()=>(MO(),DO)),"./createCorridorGeometry.js":()=>Promise.resolve().then(()=>(XO(),KO)),"./createCorridorOutlineGeometry.js":()=>Promise.resolve().then(()=>(tV(),$O)),"./createCylinderGeometry.js":()=>Promise.resolve().then(()=>(rV(),oV)),"./createCylinderOutlineGeometry.js":()=>Promise.resolve().then(()=>(cV(),hV)),"./createEllipseGeometry.js":()=>Promise.resolve().then(()=>(dV(),lV)),"./createEllipseOutlineGeometry.js":()=>Promise.resolve().then(()=>(fV(),mV)),"./createEllipsoidGeometry.js":()=>Promise.resolve().then(()=>(RV(),_V)),"./createEllipsoidOutlineGeometry.js":()=>Promise.resolve().then(()=>(pV(),IV)),"./createFrustumGeometry.js":()=>Promise.resolve().then(()=>(bV(),NV)),"./createFrustumOutlineGeometry.js":()=>Promise.resolve().then(()=>(OV(),SV)),"./createGeometry.js":()=>Promise.resolve().then(()=>(MB(),DB)),"./createGroundPolylineGeometry.js":()=>Promise.resolve().then(()=>(GV(),VV)),"./createPlaneGeometry.js":()=>Promise.resolve().then(()=>(DV(),WV)),"./createPlaneOutlineGeometry.js":()=>Promise.resolve().then(()=>(QV(),UV)),"./createPolygonGeometry.js":()=>Promise.resolve().then(()=>(wV(),yV)),"./createPolygonOutlineGeometry.js":()=>Promise.resolve().then(()=>(JV(),PV)),"./createPolylineGeometry.js":()=>Promise.resolve().then(()=>(vV(),HV)),"./createPolylineVolumeGeometry.js":()=>Promise.resolve().then(()=>(XV(),KV)),"./createPolylineVolumeOutlineGeometry.js":()=>Promise.resolve().then(()=>(tG(),$V)),"./createRectangleGeometry.js":()=>Promise.resolve().then(()=>(cG(),hG)),"./createRectangleOutlineGeometry.js":()=>Promise.resolve().then(()=>(mG(),dG)),"./createSimplePolylineGeometry.js":()=>Promise.resolve().then(()=>(_G(),EG)),"./createSphereGeometry.js":()=>Promise.resolve().then(()=>(IG(),ZG)),"./createSphereOutlineGeometry.js":()=>Promise.resolve().then(()=>(CG(),uG)),"./createTaskProcessorWorker.js":()=>Promise.resolve().then(()=>(Ns(),t0)),"./createVectorTileClampedPolylines.js":()=>Promise.resolve().then(()=>(TG(),gG)),"./createVectorTileGeometries.js":()=>Promise.resolve().then(()=>(bG(),NG)),"./createVectorTilePoints.js":()=>Promise.resolve().then(()=>(SG(),YG)),"./createVectorTilePolygons.js":()=>Promise.resolve().then(()=>(VG(),OG)),"./createVectorTilePolylines.js":()=>Promise.resolve().then(()=>(WG(),BG)),"./createVerticesFromGoogleEarthEnterpriseBuffer.js":()=>Promise.resolve().then(()=>(UG(),MG)),"./createVerticesFromHeightmap.js":()=>Promise.resolve().then(()=>(LG(),kG)),"./createVerticesFromQuantizedTerrainMesh.js":()=>Promise.resolve().then(()=>(xG(),wG)),"./createWallGeometry.js":()=>Promise.resolve().then(()=>(vG(),HG)),"./createWallOutlineGeometry.js":()=>Promise.resolve().then(()=>(XG(),KG)),"./decodeDraco.js":()=>Promise.resolve().then(()=>(nB(),iB)),"./decodeGoogleEarthEnterprisePacket.js":()=>Promise.resolve().then(()=>(pB(),IB)),"./decodeI3S.js":()=>Promise.resolve().then(()=>(NB(),TB)),"./transcodeKTX2.js":()=>Promise.resolve().then(()=>(OB(),SB)),"./transferTypedArrayTest.js":()=>Promise.resolve().then(()=>(VB(),PX)),"./upsampleQuantizedTerrainMesh.js":()=>Promise.resolve().then(()=>(BB(),GB))})});var DB={};He(DB,{default:()=>wZt});async function LZt(t,e){let i=Z(qg[e],qg[t]);return m(i)?i:m(e)?(typeof exports=="object"?i=Xo(e):i=(await import(e)).default,qg[e]=i,i):(typeof exports=="object"?i=Xo(`Workers/${t}`):i=(m(e)?await import(e):await kZt(`./${t}.js`)).default,qg[t]=i,i)}async function yZt(t,e){let i=t.subTasks,n=i.length,s=new Array(n);for(let o=0;o<n;o++){let r=i[o],a=r.geometry,h=r.moduleName,A=r.modulePath;if(m(h)&&m(A))throw new Y("Must only set moduleName or modulePath");m(h)||m(A)?s[o]=LZt(h,A).then(d=>d(a,r.offset)):s[o]=a}return Promise.all(s).then(function(o){return TA.packCreateGeometryResults(o,e)})}var qg,wZt,MB=O(()=>{Vt();bt();mt();KI();Ns();WB();qg={};wZt=Wi(yZt)});var kIt={};He(kIt,{AnalysisWorker:()=>xZt,ConjunctionAssessment:()=>PZt,combineGeometry:()=>JZt,createBoxGeometry:()=>jZt,createBoxOutlineGeometry:()=>HZt,createCircleGeometry:()=>vZt,createCircleOutlineGeometry:()=>zZt,createCoplanarPolygonGeometry:()=>KZt,createCoplanarPolygonOutlineGeometry:()=>XZt,createCorridorGeometry:()=>qZt,createCorridorOutlineGeometry:()=>$Zt,createCylinderGeometry:()=>tIt,createCylinderOutlineGeometry:()=>eIt,createEllipseGeometry:()=>iIt,createEllipseOutlineGeometry:()=>nIt,createEllipsoidGeometry:()=>sIt,createEllipsoidOutlineGeometry:()=>oIt,createFrustumGeometry:()=>rIt,createFrustumOutlineGeometry:()=>aIt,createGeometry:()=>AIt,createGroundPolylineGeometry:()=>hIt,createPlaneGeometry:()=>cIt,createPlaneOutlineGeometry:()=>lIt,createPolygonGeometry:()=>dIt,createPolygonOutlineGeometry:()=>mIt,createPolylineGeometry:()=>fIt,createPolylineVolumeGeometry:()=>EIt,createPolylineVolumeOutlineGeometry:()=>_It,createRectangleGeometry:()=>RIt,createRectangleOutlineGeometry:()=>ZIt,createSimplePolylineGeometry:()=>IIt,createSphereGeometry:()=>pIt,createSphereOutlineGeometry:()=>uIt,createTaskProcessorWorker:()=>CIt,createVectorTileClampedPolylines:()=>gIt,createVectorTileGeometries:()=>TIt,createVectorTilePoints:()=>NIt,createVectorTilePolygons:()=>bIt,createVectorTilePolylines:()=>FIt,createVerticesFromGoogleEarthEnterpriseBuffer:()=>YIt,createVerticesFromHeightmap:()=>SIt,createVerticesFromQuantizedTerrainMesh:()=>OIt,createWallGeometry:()=>VIt,createWallOutlineGeometry:()=>GIt,decodeDraco:()=>BIt,decodeGoogleEarthEnterprisePacket:()=>WIt,decodeI3S:()=>DIt,transcodeKTX2:()=>MIt,transferTypedArrayTest:()=>UIt,upsampleQuantizedTerrainMesh:()=>QIt});var xZt=()=>{Promise.resolve().then(()=>i0())},PZt=()=>{Promise.resolve().then(()=>tO())},JZt=()=>{Promise.resolve().then(()=>iO())},jZt=()=>{Promise.resolve().then(()=>rO())},HZt=()=>{Promise.resolve().then(()=>hO())},vZt=()=>{Promise.resolve().then(()=>IO())},zZt=()=>{Promise.resolve().then(()=>gO())},KZt=()=>{Promise.resolve().then(()=>BO())},XZt=()=>{Promise.resolve().then(()=>MO())},qZt=()=>{Promise.resolve().then(()=>XO())},$Zt=()=>{Promise.resolve().then(()=>tV())},tIt=()=>{Promise.resolve().then(()=>rV())},eIt=()=>{Promise.resolve().then(()=>cV())},iIt=()=>{Promise.resolve().then(()=>dV())},nIt=()=>{Promise.resolve().then(()=>fV())},sIt=()=>{Promise.resolve().then(()=>RV())},oIt=()=>{Promise.resolve().then(()=>pV())},rIt=()=>{Promise.resolve().then(()=>bV())},aIt=()=>{Promise.resolve().then(()=>OV())},AIt=()=>{Promise.resolve().then(()=>MB())},hIt=()=>{Promise.resolve().then(()=>GV())},cIt=()=>{Promise.resolve().then(()=>DV())},lIt=()=>{Promise.resolve().then(()=>QV())},dIt=()=>{Promise.resolve().then(()=>wV())},mIt=()=>{Promise.resolve().then(()=>JV())},fIt=()=>{Promise.resolve().then(()=>vV())},EIt=()=>{Promise.resolve().then(()=>XV())},_It=()=>{Promise.resolve().then(()=>tG())},RIt=()=>{Promise.resolve().then(()=>cG())},ZIt=()=>{Promise.resolve().then(()=>mG())},IIt=()=>{Promise.resolve().then(()=>_G())},pIt=()=>{Promise.resolve().then(()=>IG())},uIt=()=>{Promise.resolve().then(()=>CG())},CIt=()=>{Promise.resolve().then(()=>Ns())},gIt=()=>{Promise.resolve().then(()=>TG())},TIt=()=>{Promise.resolve().then(()=>bG())},NIt=()=>{Promise.resolve().then(()=>SG())},bIt=()=>{Promise.resolve().then(()=>VG())},FIt=()=>{Promise.resolve().then(()=>WG())},YIt=()=>{Promise.resolve().then(()=>UG())},SIt=()=>{Promise.resolve().then(()=>LG())},OIt=()=>{Promise.resolve().then(()=>xG())},VIt=()=>{Promise.resolve().then(()=>vG())},GIt=()=>{Promise.resolve().then(()=>XG())},BIt=()=>{Promise.resolve().then(()=>nB())},WIt=()=>{Promise.resolve().then(()=>pB())},DIt=()=>{Promise.resolve().then(()=>NB())},MIt=()=>{Promise.resolve().then(()=>OB())},UIt=()=>{Promise.resolve().then(()=>VB())},QIt=()=>{Promise.resolve().then(()=>BB())};return V8(kIt);})();
")});var KO=Vo((tOe,wct)=>{var eOe=R(W()),VR=function(t){t==null&&(t=new Date().getTime()),this.N=624,this.M=397,this.MATRIX_A=2567483615,this.UPPER_MASK=2147483648,this.LOWER_MASK=2147483647,this.mt=new Array(this.N),this.mti=this.N+1,t.constructor==Array?this.init_by_array(t,t.length):this.init_seed(t)};VR.prototype.init_seed=function(t){for(this.mt[0]=t>>>0,this.mti=1;this.mti>>30;this.mt[this.mti]=(((t&4294901760)>>>16)*1812433253<<16)+(t&65535)*1812433253+this.mti,this.mt[this.mti]>>>=0}};VR.prototype.init_by_array=function(t,e){var n,i,o;for(this.init_seed(19650218),n=1,i=0,o=this.N>e?this.N:e;o;o--){var a=this.mt[n-1]^this.mt[n-1]>>>30;this.mt[n]=(this.mt[n]^(((a&4294901760)>>>16)*1664525<<16)+(a&65535)*1664525)+t[i]+i,this.mt[n]>>>=0,n++,i++,n>=this.N&&(this.mt[0]=this.mt[this.N-1],n=1),i>=e&&(i=0)}for(o=this.N-1;o;o--){var a=this.mt[n-1]^this.mt[n-1]>>>30;this.mt[n]=(this.mt[n]^(((a&4294901760)>>>16)*1566083941<<16)+(a&65535)*1566083941)-n,this.mt[n]>>>=0,n++,n>=this.N&&(this.mt[0]=this.mt[this.N-1],n=1)}this.mt[0]=2147483648};VR.prototype.random_int=function(){var t,e=new Array(0,this.MATRIX_A);if(this.mti>=this.N){var n;for(this.mti==this.N+1&&this.init_seed(5489),n=0;n>>1^e[t&1];for(;n>>1^e[t&1];t=this.mt[this.N-1]&this.UPPER_MASK|this.mt[0]&this.LOWER_MASK,this.mt[this.N-1]=this.mt[this.M-1]^t>>>1^e[t&1],this.mti=0}return t=this.mt[this.mti++],t^=t>>>11,t^=t<<7&2636928640,t^=t<<15&4022730752,t^=t>>>18,t>>>0};VR.prototype.random_int31=function(){return this.random_int()>>>1};VR.prototype.random_incl=function(){return this.random_int()*(1/4294967295)};VR.prototype.random=function(){return this.random_int()*(1/4294967296)};VR.prototype.random_excl=function(){return(this.random_int()+.5)*(1/4294967296)};VR.prototype.random_long=function(){var t=this.random_int()>>>5,e=this.random_int()>>>6;return(t*67108864+e)*(1/9007199254740992)};wct.exports=VR});var bmt=Vo((jg,qg)=>{var Lwe=R(W());/*! https://mths.be/punycode v1.4.0 by @mathias */(function(t){var e=typeof jg=="object"&&jg&&!jg.nodeType&&jg,n=typeof qg=="object"&&qg&&!qg.nodeType&&qg,i=typeof global=="object"&&global;(i.global===i||i.window===i||i.self===i)&&(t=i);var o,a=2147483647,s=36,l=1,r=26,d=38,m=700,h=72,Z=128,b="-",u=/^xn--/,F=/[^\x20-\x7E]/,U=/[\x2E\u3002\uFF0E\uFF61]/g,G={overflow:"Overflow: input needs wider integers to process","not-basic":"Illegal input >= 0x80 (not a basic code point)","invalid-input":"Invalid input"},A=s-l,T=Math.floor,g=String.fromCharCode,C;function y(w){throw new RangeError(G[w])}function Y(w,z){for(var H=w.length,nt=[];H--;)nt[H]=z(w[H]);return nt}function Q(w,z){var H=w.split("@"),nt="";H.length>1&&(nt=H[0]+"@",w=H[1]),w=w.replace(U,".");var $=w.split("."),dt=Y($,z).join(".");return nt+dt}function J(w){for(var z=[],H=0,nt=w.length,$,dt;H=55296&&$<=56319&&H65535&&(z-=65536,H+=g(z>>>10&1023|55296),z=56320|z&1023),H+=g(z),H}).join("")}function V(w){return w-48<10?w-22:w-65<26?w-65:w-97<26?w-97:s}function E(w,z){return w+22+75*(w<26)-((z!=0)<<5)}function I(w,z,H){var nt=0;for(w=H?T(w/m):w>>1,w+=T(w/z);w>A*r>>1;nt+=s)w=T(w/A);return T(nt+(A+1)*w/(w+d))}function B(w){var z=[],H=w.length,nt,$=0,dt=Z,q=h,at,st,Et,Qt,Wt,Nt,kt,Mt,qt;for(at=w.lastIndexOf(b),at<0&&(at=0),st=0;st=128&&y("not-basic"),z.push(w.charCodeAt(st));for(Et=at>0?at+1:0;Et=H&&y("invalid-input"),kt=V(w.charCodeAt(Et++)),(kt>=s||kt>T((a-$)/Wt))&&y("overflow"),$+=kt*Wt,Mt=Nt<=q?l:Nt>=q+r?r:Nt-q,!(ktT(a/qt)&&y("overflow"),Wt*=qt;nt=z.length+1,q=I($-Qt,nt,Qt==0),T($/nt)>a-dt&&y("overflow"),dt+=T($/nt),$%=nt,z.splice($++,0,dt)}return M(z)}function X(w){var z,H,nt,$,dt,q,at,st,Et,Qt,Wt,Nt=[],kt,Mt,qt,ie;for(w=J(w),kt=w.length,z=Z,H=0,dt=h,q=0;q=z&&WtT((a-H)/Mt)&&y("overflow"),H+=(at-z)*Mt,z=at,q=0;qa&&y("overflow"),Wt==z){for(st=H,Et=s;Qt=Et<=dt?l:Et>=dt+r?r:Et-dt,!(st{var Mwe=R(W());/*! +var Cesium=(()=>{var pMt=Object.create;var PO=Object.defineProperty;var VMt=Object.getOwnPropertyDescriptor;var uMt=Object.getOwnPropertyNames;var ZMt=Object.getPrototypeOf,RMt=Object.prototype.hasOwnProperty;var Og=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,n)=>(typeof require<"u"?require:e)[n]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var Zo=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),vO=(t,e)=>{for(var n in e)PO(t,n,{get:e[n],enumerable:!0})},Oct=(t,e,n,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of uMt(e))!RMt.call(t,o)&&o!==n&&PO(t,o,{get:()=>e[o],enumerable:!(i=VMt(e,o))||i.enumerable});return t};var b=(t,e,n)=>(n=t!=null?pMt(ZMt(t)):{},Oct(e||!t||!t.__esModule?PO(n,"default",{value:t,enumerable:!0}):n,t)),bMt=t=>Oct(PO({},"__esModule",{value:!0}),t);var W=Zo(()=>{globalThis.CESIUM_WORKERS=atob("var CesiumWorkers=(()=>{var FX=Object.create;var qR=Object.defineProperty;var bX=Object.getOwnPropertyDescriptor;var YX=Object.getOwnPropertyNames;var VX=Object.getPrototypeOf,SX=Object.prototype.hasOwnProperty;var Xo=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,i)=>(typeof require<"u"?require:e)[i]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')}),jG=t=>e=>{var i=t[e];if(i)return i();throw new Error("Module not found in bundle: "+e)};var S=(t,e)=>()=>(t&&(e=t(t=0)),e);var ts=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),He=(t,e)=>{for(var i in e)qR(t,i,{get:e[i],enumerable:!0})},HG=(t,e,i,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of YX(e))!SX.call(t,s)&&s!==i&&qR(t,s,{get:()=>e[s],enumerable:!(n=bX(e,s))||n.enumerable});return t};var co=(t,e,i)=>(i=t!=null?FX(VX(t)):{},HG(e||!t||!t.__esModule?qR(i,"default",{value:t,enumerable:!0}):i,t)),OX=t=>HG(qR({},"__esModule",{value:!0}),t);function BX(t){return t!=null}var m,mt=S(()=>{m=BX});function GX(t){let e,i=t.name,n=t.message;m(i)&&m(n)?e=`${i}: ${n}`:e=t.toString();let s=t.stack;return m(s)&&(e+=`
${s}`),e}var vG,zG=S(()=>{mt();vG=GX});var t0={};He(t0,{default:()=>Wi});function WX(t){async function e({data:n}){let s=[],o={id:n.id,result:void 0,error:void 0};self.CESIUM_BASE_URL=n.baseUrl;try{let r=await t(n.parameters,s);o.result=r}catch(r){r instanceof Error?o.error={name:r.name,message:r.message,stack:r.stack}:o.error=r}n.canTransferArrayBuffer||(s.length=0);try{postMessage(o,s)}catch(r){o.result=void 0,o.error=`postMessage failed with error: ${vG(r)}
  with responseMessage: ${JSON.stringify(o)}`,postMessage(o)}}function i(n){postMessage({id:n.data?.id,error:`postMessage failed with error: ${JSON.stringify(n)}`})}return self.onmessage=e,self.onmessageerror=i,self}var Wi,Ns=S(()=>{zG();Wi=WX});var e0={};He(e0,{default:()=>UX});async function DX(){return[]}var UX,i0=S(()=>{Ns();UX=Wi(DX)});var KG,XG,$i,ic=S(()=>{KG={FIXED:0,INERTIAL:1,TEME:2,VVLH:3,ENU:4,NED:5,NEU:6,RIC:7},XG=[KG.NEU],$i=Object.freeze(KG)});function fl(t){this.name="DeveloperError",this.message=t;let e;try{throw new Error}catch(i){e=i.stack}this.stack=e}var Y,Ot=S(()=>{mt();m(Object.create)&&(fl.prototype=Object.create(Error.prototype),fl.prototype.constructor=fl);fl.prototype.toString=function(){let t=`${this.name}: ${this.message}`;return m(this.stack)&&(t+=`
${this.stack.toString()}`),t};fl.throwInstantiationError=function(){throw new fl("This function defines an interface and should not be called directly.")};Y=fl});function MX(t){return`${t} is required, actual value was undefined`}function _m(t,e,i){return`Expected ${i} to be typeof ${e}, actual typeof was ${t}`}var Fs,p,ae=S(()=>{mt();Ot();Fs={};Fs.typeOf={};Fs.defined=function(t,e){if(!m(e))throw new Y(MX(t))};Fs.typeOf.func=function(t,e){if(typeof e!="function")throw new Y(_m(typeof e,"function",t))};Fs.typeOf.string=function(t,e){if(typeof e!="string")throw new Y(_m(typeof e,"string",t))};Fs.typeOf.number=function(t,e){if(typeof e!="number")throw new Y(_m(typeof e,"number",t))};Fs.typeOf.number.lessThan=function(t,e,i){if(Fs.typeOf.number(t,e),e>=i)throw new Y(`Expected ${t} to be less than ${i}, actual value was ${e}`)};Fs.typeOf.number.lessThanOrEquals=function(t,e,i){if(Fs.typeOf.number(t,e),e>i)throw new Y(`Expected ${t} to be less than or equal to ${i}, actual value was ${e}`)};Fs.typeOf.number.greaterThan=function(t,e,i){if(Fs.typeOf.number(t,e),e<=i)throw new Y(`Expected ${t} to be greater than ${i}, actual value was ${e}`)};Fs.typeOf.number.greaterThanOrEquals=function(t,e,i){if(Fs.typeOf.number(t,e),e<i)throw new Y(`Expected ${t} to be greater than or equal to ${i}, actual value was ${e}`)};Fs.typeOf.object=function(t,e){if(typeof e!="object")throw new Y(_m(typeof e,"object",t))};Fs.typeOf.bool=function(t,e){if(typeof e!="boolean")throw new Y(_m(typeof e,"boolean",t))};Fs.typeOf.bigint=function(t,e){if(typeof e!="bigint")throw new Y(_m(typeof e,"bigint",t))};Fs.typeOf.number.equals=function(t,e,i,n){if(Fs.typeOf.number(t,i),Fs.typeOf.number(e,n),i!==n)throw new Y(`${t} must be equal to ${e}, the actual values are ${i} and ${n}`)};p=Fs});function nE(){this._listeners=[],this._scopes=[],this._toRemove=[],this._insideRaiseEvent=!1}function QX(t,e){return e-t}var We,xi=S(()=>{ae();mt();Object.defineProperties(nE.prototype,{numberOfListeners:{get:function(){return this._listeners.length-this._toRemove.length}}});nE.prototype.addEventListener=function(t,e){p.typeOf.func("listener",t),this._listeners.push(t),this._scopes.push(e);let i=this;return function(){i.removeEventListener(t,e)}};nE.prototype.removeEventListener=function(t,e){p.typeOf.func("listener",t);let i=this._listeners,n=this._scopes,s=-1;for(let o=0;o<i.length;o++)if(i[o]===t&&n[o]===e){s=o;break}return s!==-1?(this._insideRaiseEvent?(this._toRemove.push(s),i[s]=void 0,n[s]=void 0):(i.splice(s,1),n.splice(s,1)),!0):!1};nE.prototype.raiseEvent=function(){this._insideRaiseEvent=!0;let t,e=this._listeners,i=this._scopes,n=e.length;for(t=0;t<n;t++){let o=e[t];m(o)&&e[t].apply(i[t],arguments)}let s=this._toRemove;if(n=s.length,n>0){for(s.sort(QX),t=0;t<n;t++){let o=s[t];e.splice(o,1),i.splice(o,1)}s.length=0}this._insideRaiseEvent=!1};We=nE});function $R(){Y.throwInstantiationError()}var qG,$G=S(()=>{Ot();Object.defineProperties($R.prototype,{name:{get:Y.throwInstantiationError},clock:{get:Y.throwInstantiationError},entities:{get:Y.throwInstantiationError},isLoading:{get:Y.throwInstantiationError},changedEvent:{get:Y.throwInstantiationError},errorEvent:{get:Y.throwInstantiationError},loadingEvent:{get:Y.throwInstantiationError},show:{get:Y.throwInstantiationError},clustering:{get:Y.throwInstantiationError}});$R.prototype.update=function(t){Y.throwInstantiationError()};$R.setLoading=function(t,e){t._isLoading!==e&&(e?t._entityCollection.suspendEvents():t._entityCollection.resumeEvents(),t._isLoading=e,t._loading.raiseEvent(t,e))};qG=$R});function t2(t,e){return t??e}var Z,Ft=S(()=>{t2.EMPTY_OBJECT=Object.freeze({});Z=t2});var i2=ts((_pt,e2)=>{var vA=function(t){t==null&&(t=new Date().getTime()),this.N=624,this.M=397,this.MATRIX_A=2567483615,this.UPPER_MASK=2147483648,this.LOWER_MASK=2147483647,this.mt=new Array(this.N),this.mti=this.N+1,t.constructor==Array?this.init_by_array(t,t.length):this.init_seed(t)};vA.prototype.init_seed=function(t){for(this.mt[0]=t>>>0,this.mti=1;this.mti<this.N;this.mti++){var t=this.mt[this.mti-1]^this.mt[this.mti-1]>>>30;this.mt[this.mti]=(((t&4294901760)>>>16)*1812433253<<16)+(t&65535)*1812433253+this.mti,this.mt[this.mti]>>>=0}};vA.prototype.init_by_array=function(t,e){var i,n,s;for(this.init_seed(19650218),i=1,n=0,s=this.N>e?this.N:e;s;s--){var o=this.mt[i-1]^this.mt[i-1]>>>30;this.mt[i]=(this.mt[i]^(((o&4294901760)>>>16)*1664525<<16)+(o&65535)*1664525)+t[n]+n,this.mt[i]>>>=0,i++,n++,i>=this.N&&(this.mt[0]=this.mt[this.N-1],i=1),n>=e&&(n=0)}for(s=this.N-1;s;s--){var o=this.mt[i-1]^this.mt[i-1]>>>30;this.mt[i]=(this.mt[i]^(((o&4294901760)>>>16)*1566083941<<16)+(o&65535)*1566083941)-i,this.mt[i]>>>=0,i++,i>=this.N&&(this.mt[0]=this.mt[this.N-1],i=1)}this.mt[0]=2147483648};vA.prototype.random_int=function(){var t,e=new Array(0,this.MATRIX_A);if(this.mti>=this.N){var i;for(this.mti==this.N+1&&this.init_seed(5489),i=0;i<this.N-this.M;i++)t=this.mt[i]&this.UPPER_MASK|this.mt[i+1]&this.LOWER_MASK,this.mt[i]=this.mt[i+this.M]^t>>>1^e[t&1];for(;i<this.N-1;i++)t=this.mt[i]&this.UPPER_MASK|this.mt[i+1]&this.LOWER_MASK,this.mt[i]=this.mt[i+(this.M-this.N)]^t>>>1^e[t&1];t=this.mt[this.N-1]&this.UPPER_MASK|this.mt[0]&this.LOWER_MASK,this.mt[this.N-1]=this.mt[this.M-1]^t>>>1^e[t&1],this.mti=0}return t=this.mt[this.mti++],t^=t>>>11,t^=t<<7&2636928640,t^=t<<15&4022730752,t^=t>>>18,t>>>0};vA.prototype.random_int31=function(){return this.random_int()>>>1};vA.prototype.random_incl=function(){return this.random_int()*(1/4294967295)};vA.prototype.random=function(){return this.random_int()*(1/4294967296)};vA.prototype.random_excl=function(){return(this.random_int()+.5)*(1/4294967296)};vA.prototype.random_long=function(){var t=this.random_int()>>>5,e=this.random_int()>>>6;return(t*67108864+e)*(1/9007199254740992)};e2.exports=vA});var n0,Kt,tZ,n2,L,_e=S(()=>{n0=co(i2(),1);ae();Ft();mt();Ot();Kt={};Kt.EPSILON1=.1;Kt.EPSILON2=.01;Kt.EPSILON3=.001;Kt.EPSILON4=1e-4;Kt.EPSILON5=1e-5;Kt.EPSILON6=1e-6;Kt.EPSILON7=1e-7;Kt.EPSILON8=1e-8;Kt.EPSILON9=1e-9;Kt.EPSILON10=1e-10;Kt.EPSILON11=1e-11;Kt.EPSILON12=1e-12;Kt.EPSILON13=1e-13;Kt.EPSILON14=1e-14;Kt.EPSILON15=1e-15;Kt.EPSILON16=1e-16;Kt.EPSILON17=1e-17;Kt.EPSILON18=1e-18;Kt.EPSILON19=1e-19;Kt.EPSILON20=1e-20;Kt.EPSILON21=1e-21;Kt.GRAVITATIONALPARAMETER=3986004418e5;Kt.SOLAR_RADIUS=6955e5;Kt.LUNAR_RADIUS=1737400;Kt.SIXTY_FOUR_KILOBYTES=64*1024;Kt.FOUR_GIGABYTES=4*1024*1024*1024;Kt.sign=Z(Math.sign,function(e){return e=+e,e===0||e!==e?e:e>0?1:-1});Kt.signNotZero=function(t){return t<0?-1:1};Kt.toSNorm=function(t,e){return e=Z(e,255),Math.round((Kt.clamp(t,-1,1)*.5+.5)*e)};Kt.fromSNorm=function(t,e){return e=Z(e,255),Kt.clamp(t,0,e)/e*2-1};Kt.normalize=function(t,e,i){return i=Math.max(i-e,0),i===0?0:Kt.clamp((t-e)/i,0,1)};Kt.sinh=Z(Math.sinh,function(e){return(Math.exp(e)-Math.exp(-e))/2});Kt.cosh=Z(Math.cosh,function(e){return(Math.exp(e)+Math.exp(-e))/2});Kt.lerp=function(t,e,i){return(1-i)*t+i*e};Kt.PI=Math.PI;Kt.ONE_OVER_PI=1/Math.PI;Kt.PI_OVER_TWO=Math.PI/2;Kt.PI_OVER_THREE=Math.PI/3;Kt.PI_OVER_FOUR=Math.PI/4;Kt.PI_OVER_SIX=Math.PI/6;Kt.THREE_PI_OVER_TWO=3*Math.PI/2;Kt.TWO_PI=2*Math.PI;Kt.ONE_OVER_TWO_PI=1/(2*Math.PI);Kt.RADIANS_PER_DEGREE=Math.PI/180;Kt.DEGREES_PER_RADIAN=180/Math.PI;Kt.RADIANS_PER_ARCSECOND=Kt.RADIANS_PER_DEGREE/3600;Kt.toRadians=function(t){if(!m(t))throw new Y("degrees is required.");return t*Kt.RADIANS_PER_DEGREE};Kt.toDegrees=function(t){if(!m(t))throw new Y("radians is required.");return t*Kt.DEGREES_PER_RADIAN};Kt.convertLongitudeRange=function(t){if(!m(t))throw new Y("angle is required.");let e=Kt.TWO_PI,i=t-Math.floor(t/e)*e;return i<-Math.PI?i+e:i>=Math.PI?i-e:i};Kt.clampToLatitudeRange=function(t){if(!m(t))throw new Y("angle is required.");return Kt.clamp(t,-1*Kt.PI_OVER_TWO,Kt.PI_OVER_TWO)};Kt.negativePiToPi=function(t){if(!m(t))throw new Y("angle is required.");return t>=-Kt.PI&&t<=Kt.PI?t:Kt.zeroToTwoPi(t+Kt.PI)-Kt.PI};Kt.zeroToTwoPi=function(t){if(!m(t))throw new Y("angle is required.");if(t>=0&&t<=Kt.TWO_PI)return t;let e=Kt.mod(t,Kt.TWO_PI);return Math.abs(e)<Kt.EPSILON14&&Math.abs(t)>Kt.EPSILON14?Kt.TWO_PI:e};Kt.mod=function(t,e){if(!m(t))throw new Y("m is required.");if(!m(e))throw new Y("n is required.");if(e===0)throw new Y("divisor cannot be 0.");return Kt.sign(t)===Kt.sign(e)&&Math.abs(t)<Math.abs(e)?t:(t%e+e)%e};Kt.equalsEpsilon=function(t,e,i,n){if(!m(t))throw new Y("left is required.");if(!m(e))throw new Y("right is required.");i=Z(i,0),n=Z(n,i);let s=Math.abs(t-e);return s<=n||s<=i*Math.max(Math.abs(t),Math.abs(e))};Kt.lessThan=function(t,e,i){if(!m(t))throw new Y("first is required.");if(!m(e))throw new Y("second is required.");if(!m(i))throw new Y("absoluteEpsilon is required.");return t-e<-i};Kt.lessThanOrEquals=function(t,e,i){if(!m(t))throw new Y("first is required.");if(!m(e))throw new Y("second is required.");if(!m(i))throw new Y("absoluteEpsilon is required.");return t-e<i};Kt.greaterThan=function(t,e,i){if(!m(t))throw new Y("first is required.");if(!m(e))throw new Y("second is required.");if(!m(i))throw new Y("absoluteEpsilon is required.");return t-e>i};Kt.greaterThanOrEquals=function(t,e,i){if(!m(t))throw new Y("first is required.");if(!m(e))throw new Y("second is required.");if(!m(i))throw new Y("absoluteEpsilon is required.");return t-e>-i};tZ=[1];Kt.factorial=function(t){if(typeof t!="number"||t<0)throw new Y("A number greater than or equal to 0 is required.");let e=tZ.length;if(t>=e){let i=tZ[e-1];for(let n=e;n<=t;n++){let s=i*n;tZ.push(s),i=s}}return tZ[t]};Kt.incrementWrap=function(t,e,i){if(i=Z(i,0),!m(t))throw new Y("n is required.");if(e<=i)throw new Y("maximumValue must be greater than minimumValue.");return++t,t>e&&(t=i),t};Kt.isPowerOfTwo=function(t){if(typeof t!="number"||t<0||t>4294967295)throw new Y("A number between 0 and (2^32)-1 is required.");return t!==0&&(t&t-1)===0};Kt.nextPowerOfTwo=function(t){if(typeof t!="number"||t<0||t>2147483648)throw new Y("A number between 0 and 2^31 is required.");return--t,t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,++t,t};Kt.previousPowerOfTwo=function(t){if(typeof t!="number"||t<0||t>4294967295)throw new Y("A number between 0 and (2^32)-1 is required.");return t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,t|=t>>32,t=(t>>>0)-(t>>>1),t};Kt.clamp=function(t,e,i){return p.typeOf.number("value",t),p.typeOf.number("min",e),p.typeOf.number("max",i),t<e?e:t>i?i:t};n2=new n0.default;Kt.setRandomNumberSeed=function(t){if(!m(t))throw new Y("seed is required.");n2=new n0.default(t)};Kt.nextRandomNumber=function(){return n2.random()};Kt.randomBetween=function(t,e){return Kt.nextRandomNumber()*(e-t)+t};Kt.acosClamped=function(t){if(!m(t))throw new Y("value is required.");return Math.acos(Kt.clamp(t,-1,1))};Kt.asinClamped=function(t){if(!m(t))throw new Y("value is required.");return Math.asin(Kt.clamp(t,-1,1))};Kt.chordLength=function(t,e){if(!m(t))throw new Y("angle is required.");if(!m(e))throw new Y("radius is required.");return 2*e*Math.sin(t*.5)};Kt.logBase=function(t,e){if(!m(t))throw new Y("number is required.");if(!m(e))throw new Y("base is required.");return Math.log(t)/Math.log(e)};Kt.cbrt=Z(Math.cbrt,function(e){let i=Math.pow(Math.abs(e),.3333333333333333);return e<0?-i:i});Kt.log2=Z(Math.log2,function(e){return Math.log(e)*Math.LOG2E});Kt.fog=function(t,e){let i=t*e;return 1-Math.exp(-(i*i))};Kt.fastApproximateAtan=function(t){return p.typeOf.number("x",t),t*(-.1784*Math.abs(t)-.0663*t*t+1.0301)};Kt.fastApproximateAtan2=function(t,e){p.typeOf.number("x",t),p.typeOf.number("y",e);let i,n=Math.abs(t);i=Math.abs(e);let s=Math.max(n,i);i=Math.min(n,i);let o=i/s;if(isNaN(o))throw new Y("either x or y must be nonzero");return n=Kt.fastApproximateAtan(o),n=Math.abs(e)>Math.abs(t)?Kt.PI_OVER_TWO-n:n,n=t<0?Kt.PI-n:n,n=e<0?-n:n,n};L=Kt});function Re(t,e){this.x=Z(t,0),this.y=Z(e,0)}var eZ,s2,o2,r2,kX,nt,Xe=S(()=>{ae();Ft();mt();Ot();_e();Re.fromElements=function(t,e,i){return m(i)?(i.x=t,i.y=e,i):new Re(t,e)};Re.clone=function(t,e){if(m(t))return m(e)?(e.x=t.x,e.y=t.y,e):new Re(t.x,t.y)};Re.fromCartesian3=Re.clone;Re.fromCartesian4=Re.clone;Re.packedLength=2;Re.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.x,e[i]=t.y,e};Re.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Re),i.x=t[e++],i.y=t[e],i};Re.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*2;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 2 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)Re.pack(t[s],e,s*2);return e};Re.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,2),t.length%2!==0)throw new Y("array length must be a multiple of 2.");let i=t.length;m(e)?e.length=i/2:e=new Array(i/2);for(let n=0;n<i;n+=2){let s=n/2;e[s]=Re.unpack(t,n,e[s])}return e};Re.fromArray=Re.unpack;Re.maximumComponent=function(t){return p.typeOf.object("cartesian",t),Math.max(t.x,t.y)};Re.minimumComponent=function(t){return p.typeOf.object("cartesian",t),Math.min(t.x,t.y)};Re.minimumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.min(t.x,e.x),i.y=Math.min(t.y,e.y),i};Re.maximumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.max(t.x,e.x),i.y=Math.max(t.y,e.y),i};Re.clamp=function(t,e,i,n){p.typeOf.object("value",t),p.typeOf.object("min",e),p.typeOf.object("max",i),p.typeOf.object("result",n);let s=L.clamp(t.x,e.x,i.x),o=L.clamp(t.y,e.y,i.y);return n.x=s,n.y=o,n};Re.magnitudeSquared=function(t){return p.typeOf.object("cartesian",t),t.x*t.x+t.y*t.y};Re.magnitude=function(t){return Math.sqrt(Re.magnitudeSquared(t))};eZ=new Re;Re.distance=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),Re.subtract(t,e,eZ),Re.magnitude(eZ)};Re.distanceSquared=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),Re.subtract(t,e,eZ),Re.magnitudeSquared(eZ)};Re.normalize=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=Re.magnitude(t);if(e.x=t.x/i,e.y=t.y/i,isNaN(e.x)||isNaN(e.y))throw new Y("normalized result is not a number");return e};Re.dot=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.x*e.x+t.y*e.y};Re.cross=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.x*e.y-t.y*e.x};Re.multiplyComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x*e.x,i.y=t.y*e.y,i};Re.divideComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x/e.x,i.y=t.y/e.y,i};Re.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x+e.x,i.y=t.y+e.y,i};Re.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x-e.x,i.y=t.y-e.y,i};Re.multiplyByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x*e,i.y=t.y*e,i};Re.divideByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x/e,i.y=t.y/e,i};Re.negate=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=-t.x,e.y=-t.y,e};Re.abs=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=Math.abs(t.x),e.y=Math.abs(t.y),e};s2=new Re;Re.lerp=function(t,e,i,n){return p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n),Re.multiplyByScalar(e,i,s2),n=Re.multiplyByScalar(t,1-i,n),Re.add(s2,n,n)};o2=new Re,r2=new Re;Re.angleBetween=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),Re.normalize(t,o2),Re.normalize(e,r2),L.acosClamped(Re.dot(o2,r2))};kX=new Re;Re.mostOrthogonalAxis=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=Re.normalize(t,kX);return Re.abs(i,i),i.x<=i.y?e=Re.clone(Re.UNIT_X,e):e=Re.clone(Re.UNIT_Y,e),e};Re.equals=function(t,e){return t===e||m(t)&&m(e)&&t.x===e.x&&t.y===e.y};Re.equalsArray=function(t,e,i){return t.x===e[i]&&t.y===e[i+1]};Re.equalsEpsilon=function(t,e,i,n){return t===e||m(t)&&m(e)&&L.equalsEpsilon(t.x,e.x,i,n)&&L.equalsEpsilon(t.y,e.y,i,n)};Re.ZERO=Object.freeze(new Re(0,0));Re.ONE=Object.freeze(new Re(1,1));Re.UNIT_X=Object.freeze(new Re(1,0));Re.UNIT_Y=Object.freeze(new Re(0,1));Re.prototype.clone=function(t){return Re.clone(this,t)};Re.prototype.equals=function(t){return Re.equals(this,t)};Re.prototype.equalsEpsilon=function(t,e,i){return Re.equalsEpsilon(this,t,e,i)};Re.prototype.toString=function(){return`(${this.x}, ${this.y})`};nt=Re});function wt(t,e,i){this.x=Z(t,0),this.y=Z(e,0),this.z=Z(i,0)}var nZ,a2,iZ,s0,LX,Sr,Rm,yX,l,Ht=S(()=>{ae();Ft();mt();Ot();_e();wt.fromSpherical=function(t,e){p.typeOf.object("spherical",t),m(e)||(e=new wt);let i=t.clock,n=t.cone,s=Z(t.magnitude,1),o=s*Math.sin(n);return e.x=o*Math.cos(i),e.y=o*Math.sin(i),e.z=s*Math.cos(n),e};wt.fromElements=function(t,e,i,n){return m(n)?(n.x=t,n.y=e,n.z=i,n):new wt(t,e,i)};wt.clone=function(t,e){if(m(t))return m(e)?(e.x=t.x,e.y=t.y,e.z=t.z,e):new wt(t.x,t.y,t.z)};wt.fromCartesian4=wt.clone;wt.packedLength=3;wt.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.x,e[i++]=t.y,e[i]=t.z,e};wt.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new wt),i.x=t[e++],i.y=t[e++],i.z=t[e],i};wt.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*3;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 3 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)wt.pack(t[s],e,s*3);return e};wt.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,3),t.length%3!==0)throw new Y("array length must be a multiple of 3.");let i=t.length;m(e)?e.length=i/3:e=new Array(i/3);for(let n=0;n<i;n+=3){let s=n/3;e[s]=wt.unpack(t,n,e[s])}return e};wt.fromArray=wt.unpack;wt.maximumComponent=function(t){return p.typeOf.object("cartesian",t),Math.max(t.x,t.y,t.z)};wt.minimumComponent=function(t){return p.typeOf.object("cartesian",t),Math.min(t.x,t.y,t.z)};wt.minimumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.min(t.x,e.x),i.y=Math.min(t.y,e.y),i.z=Math.min(t.z,e.z),i};wt.maximumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.max(t.x,e.x),i.y=Math.max(t.y,e.y),i.z=Math.max(t.z,e.z),i};wt.clamp=function(t,e,i,n){p.typeOf.object("value",t),p.typeOf.object("min",e),p.typeOf.object("max",i),p.typeOf.object("result",n);let s=L.clamp(t.x,e.x,i.x),o=L.clamp(t.y,e.y,i.y),r=L.clamp(t.z,e.z,i.z);return n.x=s,n.y=o,n.z=r,n};wt.magnitudeSquared=function(t){return p.typeOf.object("cartesian",t),t.x*t.x+t.y*t.y+t.z*t.z};wt.magnitude=function(t){return Math.sqrt(wt.magnitudeSquared(t))};nZ=new wt;wt.distance=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),wt.subtract(t,e,nZ),wt.magnitude(nZ)};wt.distanceSquared=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),wt.subtract(t,e,nZ),wt.magnitudeSquared(nZ)};wt.normalize=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=wt.magnitude(t);if(e.x=t.x/i,e.y=t.y/i,e.z=t.z/i,isNaN(e.x)||isNaN(e.y)||isNaN(e.z))throw new Y("normalized result is not a number");return e};wt.dot=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.x*e.x+t.y*e.y+t.z*e.z};wt.multiplyComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x*e.x,i.y=t.y*e.y,i.z=t.z*e.z,i};wt.divideComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x/e.x,i.y=t.y/e.y,i.z=t.z/e.z,i};wt.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x+e.x,i.y=t.y+e.y,i.z=t.z+e.z,i};wt.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x-e.x,i.y=t.y-e.y,i.z=t.z-e.z,i};wt.multiplyByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x*e,i.y=t.y*e,i.z=t.z*e,i};wt.divideByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x/e,i.y=t.y/e,i.z=t.z/e,i};wt.negate=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=-t.x,e.y=-t.y,e.z=-t.z,e};wt.abs=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=Math.abs(t.x),e.y=Math.abs(t.y),e.z=Math.abs(t.z),e};a2=new wt;wt.lerp=function(t,e,i,n){return p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n),wt.multiplyByScalar(e,i,a2),n=wt.multiplyByScalar(t,1-i,n),wt.add(a2,n,n)};iZ=new wt,s0=new wt;wt.angleBetween=function(t,e){p.typeOf.object("left",t),p.typeOf.object("right",e),wt.normalize(t,iZ),wt.normalize(e,s0);let i=wt.dot(iZ,s0),n=wt.magnitude(wt.cross(iZ,s0,iZ));return Math.atan2(n,i)};LX=new wt;wt.mostOrthogonalAxis=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=wt.normalize(t,LX);return wt.abs(i,i),i.x<=i.y?i.x<=i.z?e=wt.clone(wt.UNIT_X,e):e=wt.clone(wt.UNIT_Z,e):i.y<=i.z?e=wt.clone(wt.UNIT_Y,e):e=wt.clone(wt.UNIT_Z,e),e};wt.projectVector=function(t,e,i){p.defined("a",t),p.defined("b",e),p.defined("result",i);let n=wt.dot(t,e)/wt.dot(e,e);return wt.multiplyByScalar(e,n,i)};wt.equals=function(t,e){return t===e||m(t)&&m(e)&&t.x===e.x&&t.y===e.y&&t.z===e.z};wt.equalsArray=function(t,e,i){return t.x===e[i]&&t.y===e[i+1]&&t.z===e[i+2]};wt.equalsEpsilon=function(t,e,i,n){return t===e||m(t)&&m(e)&&L.equalsEpsilon(t.x,e.x,i,n)&&L.equalsEpsilon(t.y,e.y,i,n)&&L.equalsEpsilon(t.z,e.z,i,n)};wt.cross=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t.x,s=t.y,o=t.z,r=e.x,a=e.y,h=e.z,A=s*h-o*a,d=o*r-n*h,f=n*a-s*r;return i.x=A,i.y=d,i.z=f,i};wt.midpoint=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=(t.x+e.x)*.5,i.y=(t.y+e.y)*.5,i.z=(t.z+e.z)*.5,i};wt.fromDegrees=function(t,e,i,n,s){return p.typeOf.number("longitude",t),p.typeOf.number("latitude",e),t=L.toRadians(t),e=L.toRadians(e),wt.fromRadians(t,e,i,n,s)};Sr=new wt,Rm=new wt,yX=new wt(6378137*6378137,6378137*6378137,6356752314245179e-9*6356752314245179e-9);wt.fromRadians=function(t,e,i,n,s){p.typeOf.number("longitude",t),p.typeOf.number("latitude",e),i=Z(i,0);let o=m(n)?n.radiiSquared:yX,r=Math.cos(e);Sr.x=r*Math.cos(t),Sr.y=r*Math.sin(t),Sr.z=Math.sin(e),Sr=wt.normalize(Sr,Sr),wt.multiplyComponents(o,Sr,Rm);let a=Math.sqrt(wt.dot(Sr,Rm));return Rm=wt.divideByScalar(Rm,a,Rm),Sr=wt.multiplyByScalar(Sr,i,Sr),m(s)||(s=new wt),wt.add(Rm,Sr,s)};wt.fromDegreesArray=function(t,e,i){if(p.defined("coordinates",t),t.length<2||t.length%2!==0)throw new Y("the number of coordinates must be a multiple of 2 and at least 2");let n=t.length;m(i)?i.length=n/2:i=new Array(n/2);for(let s=0;s<n;s+=2){let o=t[s],r=t[s+1],a=s/2;i[a]=wt.fromDegrees(o,r,0,e,i[a])}return i};wt.fromRadiansArray=function(t,e,i){if(p.defined("coordinates",t),t.length<2||t.length%2!==0)throw new Y("the number of coordinates must be a multiple of 2 and at least 2");let n=t.length;m(i)?i.length=n/2:i=new Array(n/2);for(let s=0;s<n;s+=2){let o=t[s],r=t[s+1],a=s/2;i[a]=wt.fromRadians(o,r,0,e,i[a])}return i};wt.fromDegreesArrayHeights=function(t,e,i){if(p.defined("coordinates",t),t.length<3||t.length%3!==0)throw new Y("the number of coordinates must be a multiple of 3 and at least 3");let n=t.length;m(i)?i.length=n/3:i=new Array(n/3);for(let s=0;s<n;s+=3){let o=t[s],r=t[s+1],a=t[s+2],h=s/3;i[h]=wt.fromDegrees(o,r,a,e,i[h])}return i};wt.fromRadiansArrayHeights=function(t,e,i){if(p.defined("coordinates",t),t.length<3||t.length%3!==0)throw new Y("the number of coordinates must be a multiple of 3 and at least 3");let n=t.length;m(i)?i.length=n/3:i=new Array(n/3);for(let s=0;s<n;s+=3){let o=t[s],r=t[s+1],a=t[s+2],h=s/3;i[h]=wt.fromRadians(o,r,a,e,i[h])}return i};wt.ZERO=Object.freeze(new wt(0,0,0));wt.ONE=Object.freeze(new wt(1,1,1));wt.UNIT_X=Object.freeze(new wt(1,0,0));wt.UNIT_Y=Object.freeze(new wt(0,1,0));wt.UNIT_Z=Object.freeze(new wt(0,0,1));wt.prototype.clone=function(t){return wt.clone(this,t)};wt.prototype.equals=function(t){return wt.equals(this,t)};wt.prototype.equalsEpsilon=function(t,e,i){return wt.equalsEpsilon(this,t,e,i)};wt.prototype.toString=function(){return`(${this.x}, ${this.y}, ${this.z})`};l=wt});function PX(t,e,i,n,s){if(!m(t))throw new Y("cartesian is required.");if(!m(e))throw new Y("oneOverRadii is required.");if(!m(i))throw new Y("oneOverRadiiSquared is required.");if(!m(n))throw new Y("centerToleranceSquared is required.");let o=t.x,r=t.y,a=t.z,h=e.x,A=e.y,d=e.z,f=o*o*h*h,E=r*r*A*A,_=a*a*d*d,R=f+E+_,I=Math.sqrt(1/R),C=l.multiplyByScalar(t,I,wX);if(R<n)return isFinite(I)?l.clone(C,s):void 0;let N=i.x,T=i.y,b=i.z,F=xX;F.x=C.x*N*2,F.y=C.y*T*2,F.z=C.z*b*2;let B=(1-I)*l.magnitude(t)/(.5*l.magnitude(F)),U=0,Q,M,k,y,c,g,O,D,w,x,H;do{B-=U,k=1/(1+B*N),y=1/(1+B*T),c=1/(1+B*b),g=k*k,O=y*y,D=c*c,w=g*k,x=O*y,H=D*c,Q=f*g+E*O+_*D-1,M=f*w*N+E*x*T+_*H*b;let j=-2*M;U=Q/j}while(Math.abs(Q)>L.EPSILON12);return m(s)?(s.x=o*k,s.y=r*y,s.z=a*c,s):new l(o*k,r*y,a*c)}var wX,xX,sZ,o0=S(()=>{Ht();mt();Ot();_e();wX=new l,xX=new l;sZ=PX});function fs(t,e,i){this.longitude=Z(t,0),this.latitude=Z(e,0),this.height=Z(i,0)}var JX,jX,HX,vX,zX,KX,ut,ri=S(()=>{Ht();ae();Ft();mt();_e();o0();fs.fromRadians=function(t,e,i,n){return p.typeOf.number("longitude",t),p.typeOf.number("latitude",e),i=Z(i,0),m(n)?(n.longitude=t,n.latitude=e,n.height=i,n):new fs(t,e,i)};fs.fromDegrees=function(t,e,i,n){return p.typeOf.number("longitude",t),p.typeOf.number("latitude",e),t=L.toRadians(t),e=L.toRadians(e),fs.fromRadians(t,e,i,n)};JX=new l,jX=new l,HX=new l,vX=new l(1/6378137,1/6378137,1/6356752314245179e-9),zX=new l(1/(6378137*6378137),1/(6378137*6378137),1/(6356752314245179e-9*6356752314245179e-9)),KX=L.EPSILON1;fs.fromCartesian=function(t,e,i){let n=m(e)?e.oneOverRadii:vX,s=m(e)?e.oneOverRadiiSquared:zX,o=m(e)?e._centerToleranceSquared:KX,r=sZ(t,n,s,o,jX);if(!m(r))return;let a=l.multiplyComponents(r,s,JX);a=l.normalize(a,a);let h=l.subtract(t,r,HX),A=Math.atan2(a.y,a.x),d=Math.asin(a.z),f=L.sign(l.dot(h,t))*l.magnitude(h);return m(i)?(i.longitude=A,i.latitude=d,i.height=f,i):new fs(A,d,f)};fs.toCartesian=function(t,e,i){return p.defined("cartographic",t),l.fromRadians(t.longitude,t.latitude,t.height,e,i)};fs.clone=function(t,e){if(m(t))return m(e)?(e.longitude=t.longitude,e.latitude=t.latitude,e.height=t.height,e):new fs(t.longitude,t.latitude,t.height)};fs.equals=function(t,e){return t===e||m(t)&&m(e)&&t.longitude===e.longitude&&t.latitude===e.latitude&&t.height===e.height};fs.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t.longitude-e.longitude)<=i&&Math.abs(t.latitude-e.latitude)<=i&&Math.abs(t.height-e.height)<=i};fs.ZERO=Object.freeze(new fs(0,0,0));fs.prototype.clone=function(t){return fs.clone(this,t)};fs.prototype.equals=function(t){return fs.equals(this,t)};fs.prototype.equalsEpsilon=function(t,e){return fs.equalsEpsilon(this,t,e)};fs.prototype.toString=function(){return`(${this.longitude}, ${this.latitude}, ${this.height})`};ut=fs});function h2(t,e,i,n){e=Z(e,0),i=Z(i,0),n=Z(n,0),p.typeOf.number.greaterThanOrEquals("x",e,0),p.typeOf.number.greaterThanOrEquals("y",i,0),p.typeOf.number.greaterThanOrEquals("z",n,0),t._radii=new l(e,i,n),t._radiiSquared=new l(e*e,i*i,n*n),t._radiiToTheFourth=new l(e*e*e*e,i*i*i*i,n*n*n*n),t._oneOverRadii=new l(e===0?0:1/e,i===0?0:1/i,n===0?0:1/n),t._oneOverRadiiSquared=new l(e===0?0:1/(e*e),i===0?0:1/(i*i),n===0?0:1/(n*n)),t._minimumRadius=Math.min(e,i,n),t._maximumRadius=Math.max(e,i,n),t._centerToleranceSquared=L.EPSILON1,t._radiiSquared.z!==0&&(t._squaredXOverSquaredZ=t._radiiSquared.x/t._radiiSquared.z)}function Li(t,e,i){this._radii=void 0,this._radiiSquared=void 0,this._radiiToTheFourth=void 0,this._oneOverRadii=void 0,this._oneOverRadiiSquared=void 0,this._minimumRadius=void 0,this._maximumRadius=void 0,this._centerToleranceSquared=void 0,this._squaredXOverSquaredZ=void 0,h2(this,t,e,i)}function A2(t,e,i){p.typeOf.number("a",t),p.typeOf.number("b",e),p.typeOf.func("func",i);let n=.5*(e+t),s=.5*(e-t),o=0;for(let r=0;r<5;r++){let a=s*nq[r];o+=sq[r]*(i(n+a)+i(n-a))}return o*=s,o}var XX,qX,$X,tq,eq,iq,nq,sq,ot,Oe=S(()=>{Xe();Ht();ri();ae();Ft();mt();Ot();_e();o0();Object.defineProperties(Li.prototype,{radii:{get:function(){return this._radii}},radiiSquared:{get:function(){return this._radiiSquared}},radiiToTheFourth:{get:function(){return this._radiiToTheFourth}},oneOverRadii:{get:function(){return this._oneOverRadii}},oneOverRadiiSquared:{get:function(){return this._oneOverRadiiSquared}},minimumRadius:{get:function(){return this._minimumRadius}},maximumRadius:{get:function(){return this._maximumRadius}}});Li.clone=function(t,e){if(!m(t))return;let i=t._radii;return m(e)?(l.clone(i,e._radii),l.clone(t._radiiSquared,e._radiiSquared),l.clone(t._radiiToTheFourth,e._radiiToTheFourth),l.clone(t._oneOverRadii,e._oneOverRadii),l.clone(t._oneOverRadiiSquared,e._oneOverRadiiSquared),e._minimumRadius=t._minimumRadius,e._maximumRadius=t._maximumRadius,e._centerToleranceSquared=t._centerToleranceSquared,e):new Li(i.x,i.y,i.z)};Li.fromCartesian3=function(t,e){return m(e)||(e=new Li),m(t)&&h2(e,t.x,t.y,t.z),e};Li.WGS84=Object.freeze(new Li(6378137,6378137,6356752314245179e-9));Li.UNIT_SPHERE=Object.freeze(new Li(1,1,1));Li.MOON=Object.freeze(new Li(L.LUNAR_RADIUS,L.LUNAR_RADIUS,L.LUNAR_RADIUS));Li.prototype.clone=function(t){return Li.clone(this,t)};Li.packedLength=l.packedLength;Li.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),l.pack(t._radii,e,i),e};Li.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=l.unpack(t,e);return Li.fromCartesian3(n,i)};Li.prototype.geocentricSurfaceNormal=l.normalize;Li.prototype.geodeticSurfaceNormalCartographic=function(t,e){p.typeOf.object("cartographic",t);let i=t.longitude,n=t.latitude,s=Math.cos(n),o=s*Math.cos(i),r=s*Math.sin(i),a=Math.sin(n);return m(e)||(e=new l),e.x=o,e.y=r,e.z=a,l.normalize(e,e)};Li.prototype.geodeticSurfaceNormal=function(t,e){if(p.typeOf.object("cartesian",t),isNaN(t.x)||isNaN(t.y)||isNaN(t.z))throw new Y("cartesian has a NaN component");if(!l.equalsEpsilon(t,l.ZERO,L.EPSILON14))return m(e)||(e=new l),e=l.multiplyComponents(t,this._oneOverRadiiSquared,e),l.normalize(e,e)};XX=new l,qX=new l;Li.prototype.cartographicToCartesian=function(t,e){let i=XX,n=qX;this.geodeticSurfaceNormalCartographic(t,i),l.multiplyComponents(this._radiiSquared,i,n);let s=Math.sqrt(l.dot(i,n));return l.divideByScalar(n,s,n),l.multiplyByScalar(i,t.height,i),m(e)||(e=new l),l.add(n,i,e)};Li.prototype.cartographicArrayToCartesianArray=function(t,e){p.defined("cartographics",t);let i=t.length;m(e)?e.length=i:e=new Array(i);for(let n=0;n<i;n++)e[n]=this.cartographicToCartesian(t[n],e[n]);return e};$X=new l,tq=new l,eq=new l;Li.prototype.cartesianToCartographic=function(t,e){let i=this.scaleToGeodeticSurface(t,tq);if(!m(i))return;let n=this.geodeticSurfaceNormal(i,$X),s=l.subtract(t,i,eq),o=Math.atan2(n.y,n.x),r=Math.asin(n.z),a=L.sign(l.dot(s,t))*l.magnitude(s);return m(e)?(e.longitude=o,e.latitude=r,e.height=a,e):new ut(o,r,a)};Li.prototype.cartesianArrayToCartographicArray=function(t,e){p.defined("cartesians",t);let i=t.length;m(e)?e.length=i:e=new Array(i);for(let n=0;n<i;++n)e[n]=this.cartesianToCartographic(t[n],e[n]);return e};Li.prototype.scaleToGeodeticSurface=function(t,e){return sZ(t,this._oneOverRadii,this._oneOverRadiiSquared,this._centerToleranceSquared,e)};Li.prototype.scaleToGeocentricSurface=function(t,e){p.typeOf.object("cartesian",t),m(e)||(e=new l);let i=t.x,n=t.y,s=t.z,o=this._oneOverRadiiSquared,r=1/Math.sqrt(i*i*o.x+n*n*o.y+s*s*o.z);return l.multiplyByScalar(t,r,e)};Li.prototype.transformPositionToScaledSpace=function(t,e){return m(e)||(e=new l),l.multiplyComponents(t,this._oneOverRadii,e)};Li.prototype.transformPositionFromScaledSpace=function(t,e){return m(e)||(e=new l),l.multiplyComponents(t,this._radii,e)};Li.prototype.equals=function(t){return this===t||m(t)&&l.equals(this._radii,t._radii)};Li.prototype.toString=function(){return this._radii.toString()};Li.prototype.getSurfaceNormalIntersectionWithZAxis=function(t,e,i){if(p.typeOf.object("position",t),!L.equalsEpsilon(this._radii.x,this._radii.y,L.EPSILON15))throw new Y("Ellipsoid must be an ellipsoid of revolution (radii.x == radii.y)");p.typeOf.number.greaterThan("Ellipsoid.radii.z",this._radii.z,0),e=Z(e,0);let n=this._squaredXOverSquaredZ;if(m(i)||(i=new l),i.x=0,i.y=0,i.z=t.z*(1-n),!(Math.abs(i.z)>=this._radii.z-e))return i};iq=new l;Li.prototype.getLocalCurvature=function(t,e){p.typeOf.object("surfacePosition",t),m(e)||(e=new nt);let i=this.getSurfaceNormalIntersectionWithZAxis(t,0,iq),n=l.distance(t,i),s=this.minimumRadius*n/this.maximumRadius**2,o=n*s**2;return nt.fromElements(1/n,1/o,e)};nq=[.14887433898163,.43339539412925,.67940956829902,.86506336668898,.97390652851717,0],sq=[.29552422471475,.26926671930999,.21908636251598,.14945134915058,.066671344308684,0];Li.prototype.surfaceArea=function(t){p.typeOf.object("rectangle",t);let e=t.west,i=t.east,n=t.south,s=t.north;for(;i<e;)i+=L.TWO_PI;let o=this._radiiSquared,r=o.x,a=o.y,h=o.z,A=r*a;return A2(n,s,function(d){let f=Math.cos(d),E=Math.sin(d);return Math.cos(d)*A2(e,i,function(_){let R=Math.cos(_),I=Math.sin(_);return Math.sqrt(A*E*E+h*(a*R*R+r*I*I)*f*f)})})};ot=Li});function oZ(t){this._ellipsoid=Z(t,ot.WGS84),this._semimajorAxis=this._ellipsoid.maximumRadius,this._oneOverSemimajorAxis=1/this._semimajorAxis}var Ss,zA=S(()=>{Ht();ri();Ft();mt();Ot();Oe();Object.defineProperties(oZ.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});oZ.prototype.project=function(t,e){let i=this._semimajorAxis,n=t.longitude*i,s=t.latitude*i,o=t.height;return m(e)?(e.x=n,e.y=s,e.z=o,e):new l(n,s,o)};oZ.prototype.unproject=function(t,e){if(!m(t))throw new Y("cartesian is required");let i=this._oneOverSemimajorAxis,n=t.x*i,s=t.y*i,o=t.z;return m(e)?(e.longitude=n,e.latitude=s,e.height=o,e):new ut(n,s,o)};Ss=oZ});var oq,Nn,nc=S(()=>{oq={OUTSIDE:-1,INTERSECTING:0,INSIDE:1},Nn=Object.freeze(oq)});function oe(t,e,i,n){this.x=Z(t,0),this.y=Z(e,0),this.z=Z(i,0),this.w=Z(n,0)}var rZ,c2,rq,r0,lo,aq,Aq,l2,ie,Os=S(()=>{ae();Ft();mt();Ot();_e();oe.fromElements=function(t,e,i,n,s){return m(s)?(s.x=t,s.y=e,s.z=i,s.w=n,s):new oe(t,e,i,n)};oe.fromColor=function(t,e){return p.typeOf.object("color",t),m(e)?(e.x=t.red,e.y=t.green,e.z=t.blue,e.w=t.alpha,e):new oe(t.red,t.green,t.blue,t.alpha)};oe.clone=function(t,e){if(m(t))return m(e)?(e.x=t.x,e.y=t.y,e.z=t.z,e.w=t.w,e):new oe(t.x,t.y,t.z,t.w)};oe.packedLength=4;oe.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.x,e[i++]=t.y,e[i++]=t.z,e[i]=t.w,e};oe.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new oe),i.x=t[e++],i.y=t[e++],i.z=t[e++],i.w=t[e],i};oe.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*4;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 4 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)oe.pack(t[s],e,s*4);return e};oe.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,4),t.length%4!==0)throw new Y("array length must be a multiple of 4.");let i=t.length;m(e)?e.length=i/4:e=new Array(i/4);for(let n=0;n<i;n+=4){let s=n/4;e[s]=oe.unpack(t,n,e[s])}return e};oe.fromArray=oe.unpack;oe.maximumComponent=function(t){return p.typeOf.object("cartesian",t),Math.max(t.x,t.y,t.z,t.w)};oe.minimumComponent=function(t){return p.typeOf.object("cartesian",t),Math.min(t.x,t.y,t.z,t.w)};oe.minimumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.min(t.x,e.x),i.y=Math.min(t.y,e.y),i.z=Math.min(t.z,e.z),i.w=Math.min(t.w,e.w),i};oe.maximumByComponent=function(t,e,i){return p.typeOf.object("first",t),p.typeOf.object("second",e),p.typeOf.object("result",i),i.x=Math.max(t.x,e.x),i.y=Math.max(t.y,e.y),i.z=Math.max(t.z,e.z),i.w=Math.max(t.w,e.w),i};oe.clamp=function(t,e,i,n){p.typeOf.object("value",t),p.typeOf.object("min",e),p.typeOf.object("max",i),p.typeOf.object("result",n);let s=L.clamp(t.x,e.x,i.x),o=L.clamp(t.y,e.y,i.y),r=L.clamp(t.z,e.z,i.z),a=L.clamp(t.w,e.w,i.w);return n.x=s,n.y=o,n.z=r,n.w=a,n};oe.magnitudeSquared=function(t){return p.typeOf.object("cartesian",t),t.x*t.x+t.y*t.y+t.z*t.z+t.w*t.w};oe.magnitude=function(t){return Math.sqrt(oe.magnitudeSquared(t))};rZ=new oe;oe.distance=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),oe.subtract(t,e,rZ),oe.magnitude(rZ)};oe.distanceSquared=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),oe.subtract(t,e,rZ),oe.magnitudeSquared(rZ)};oe.normalize=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=oe.magnitude(t);if(e.x=t.x/i,e.y=t.y/i,e.z=t.z/i,e.w=t.w/i,isNaN(e.x)||isNaN(e.y)||isNaN(e.z)||isNaN(e.w))throw new Y("normalized result is not a number");return e};oe.dot=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.x*e.x+t.y*e.y+t.z*e.z+t.w*e.w};oe.multiplyComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x*e.x,i.y=t.y*e.y,i.z=t.z*e.z,i.w=t.w*e.w,i};oe.divideComponents=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x/e.x,i.y=t.y/e.y,i.z=t.z/e.z,i.w=t.w/e.w,i};oe.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x+e.x,i.y=t.y+e.y,i.z=t.z+e.z,i.w=t.w+e.w,i};oe.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x-e.x,i.y=t.y-e.y,i.z=t.z-e.z,i.w=t.w-e.w,i};oe.multiplyByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x*e,i.y=t.y*e,i.z=t.z*e,i.w=t.w*e,i};oe.divideByScalar=function(t,e,i){return p.typeOf.object("cartesian",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x/e,i.y=t.y/e,i.z=t.z/e,i.w=t.w/e,i};oe.negate=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=-t.x,e.y=-t.y,e.z=-t.z,e.w=-t.w,e};oe.abs=function(t,e){return p.typeOf.object("cartesian",t),p.typeOf.object("result",e),e.x=Math.abs(t.x),e.y=Math.abs(t.y),e.z=Math.abs(t.z),e.w=Math.abs(t.w),e};c2=new oe;oe.lerp=function(t,e,i,n){return p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n),oe.multiplyByScalar(e,i,c2),n=oe.multiplyByScalar(t,1-i,n),oe.add(c2,n,n)};rq=new oe;oe.mostOrthogonalAxis=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=oe.normalize(t,rq);return oe.abs(i,i),i.x<=i.y?i.x<=i.z?i.x<=i.w?e=oe.clone(oe.UNIT_X,e):e=oe.clone(oe.UNIT_W,e):i.z<=i.w?e=oe.clone(oe.UNIT_Z,e):e=oe.clone(oe.UNIT_W,e):i.y<=i.z?i.y<=i.w?e=oe.clone(oe.UNIT_Y,e):e=oe.clone(oe.UNIT_W,e):i.z<=i.w?e=oe.clone(oe.UNIT_Z,e):e=oe.clone(oe.UNIT_W,e),e};oe.equals=function(t,e){return t===e||m(t)&&m(e)&&t.x===e.x&&t.y===e.y&&t.z===e.z&&t.w===e.w};oe.equalsArray=function(t,e,i){return t.x===e[i]&&t.y===e[i+1]&&t.z===e[i+2]&&t.w===e[i+3]};oe.equalsEpsilon=function(t,e,i,n){return t===e||m(t)&&m(e)&&L.equalsEpsilon(t.x,e.x,i,n)&&L.equalsEpsilon(t.y,e.y,i,n)&&L.equalsEpsilon(t.z,e.z,i,n)&&L.equalsEpsilon(t.w,e.w,i,n)};oe.ZERO=Object.freeze(new oe(0,0,0,0));oe.ONE=Object.freeze(new oe(1,1,1,1));oe.UNIT_X=Object.freeze(new oe(1,0,0,0));oe.UNIT_Y=Object.freeze(new oe(0,1,0,0));oe.UNIT_Z=Object.freeze(new oe(0,0,1,0));oe.UNIT_W=Object.freeze(new oe(0,0,0,1));oe.prototype.clone=function(t){return oe.clone(this,t)};oe.prototype.equals=function(t){return oe.equals(this,t)};oe.prototype.equalsEpsilon=function(t,e,i){return oe.equalsEpsilon(this,t,e,i)};oe.prototype.toString=function(){return`(${this.x}, ${this.y}, ${this.z}, ${this.w})`};r0=new Float32Array(1),lo=new Uint8Array(r0.buffer),aq=new Uint32Array([287454020]),Aq=new Uint8Array(aq.buffer),l2=Aq[0]===68;oe.packFloat=function(t,e){return p.typeOf.number("value",t),m(e)||(e=new oe),r0[0]=t,l2?(e.x=lo[0],e.y=lo[1],e.z=lo[2],e.w=lo[3]):(e.x=lo[3],e.y=lo[2],e.z=lo[1],e.w=lo[0]),e};oe.unpackFloat=function(t){return p.typeOf.object("packedFloat",t),l2?(lo[0]=t.x,lo[1]=t.y,lo[2]=t.z,lo[3]=t.w):(lo[0]=t.w,lo[1]=t.z,lo[2]=t.y,lo[3]=t.x),r0[0]};ie=oe});function hq(t,e,i){p.defined("array",t),p.defined("itemToFind",e),p.defined("comparator",i);let n=0,s=t.length-1,o,r;for(;n<=s;){if(o=~~((n+s)/2),r=i(t[o],e),r<0){n=o+1;continue}if(r>0){s=o-1;continue}return o}return~(s+1)}var Go,sE=S(()=>{ae();Go=hq});function cq(t,e,i,n,s){this.xPoleWander=t,this.yPoleWander=e,this.xPoleOffset=i,this.yPoleOffset=n,this.ut1MinusUtc=s}var oE,a0=S(()=>{oE=cq});function lq(t){if(t===null||isNaN(t))throw new Y("year is required and must be a number.");return t%4===0&&t%100!==0||t%400===0}var rE,A0=S(()=>{Ot();rE=lq});function dq(t,e,i,n,s,o,r,a){t=Z(t,1),e=Z(e,1),i=Z(i,1),n=Z(n,0),s=Z(s,0),o=Z(o,0),r=Z(r,0),a=Z(a,!1),I(),C(),this.year=t,this.month=e,this.day=i,this.hour=n,this.minute=s,this.second=o,this.millisecond=r,this.isLeapSecond=a;function I(){p.typeOf.number.greaterThanOrEquals("Year",t,1),p.typeOf.number.lessThanOrEquals("Year",t,9999),p.typeOf.number.greaterThanOrEquals("Month",e,1),p.typeOf.number.lessThanOrEquals("Month",e,12),p.typeOf.number.greaterThanOrEquals("Day",i,1),p.typeOf.number.lessThanOrEquals("Day",i,31),p.typeOf.number.greaterThanOrEquals("Hour",n,0),p.typeOf.number.lessThanOrEquals("Hour",n,23),p.typeOf.number.greaterThanOrEquals("Minute",s,0),p.typeOf.number.lessThanOrEquals("Minute",s,59),p.typeOf.bool("IsLeapSecond",a),p.typeOf.number.greaterThanOrEquals("Second",o,0),p.typeOf.number.lessThanOrEquals("Second",o,a?60:59),p.typeOf.number.greaterThanOrEquals("Millisecond",r,0),p.typeOf.number.lessThan("Millisecond",r,1e3)}function C(){let N=e===2&&rE(t)?d2[e-1]+1:d2[e-1];if(i>N)throw new Y("Month and Day represents invalid date")}}var d2,aZ,m2=S(()=>{ae();Ft();Ot();A0();d2=[31,28,31,30,31,30,31,31,30,31,30,31];aZ=dq});function mq(t,e){this.julianDate=t,this.offset=e}var zi,h0=S(()=>{zi=mq});var fq,Fn,AZ=S(()=>{fq={SECONDS_PER_MILLISECOND:.001,SECONDS_PER_MINUTE:60,MINUTES_PER_HOUR:60,HOURS_PER_DAY:24,SECONDS_PER_HOUR:3600,MINUTES_PER_DAY:1440,SECONDS_PER_DAY:86400,DAYS_PER_JULIAN_CENTURY:36525,PICOSECOND:1e-9,MODIFIED_JULIAN_DATE_DIFFERENCE:24000005e-1},Fn=Object.freeze(fq)});var Eq,Ei,hZ=S(()=>{Eq={UTC:0,TAI:1},Ei=Object.freeze(Eq)});function c0(t,e){return me.compare(t.julianDate,e.julianDate)}function mZ(t){Zm.julianDate=t;let e=me.leapSeconds,i=Go(e,Zm,c0);i<0&&(i=~i),i>=e.length&&(i=e.length-1);let n=e[i].offset;i>0&&me.secondsDifference(e[i].julianDate,t)>n&&(i--,n=e[i].offset),me.addSeconds(t,n,t)}function f2(t,e){Zm.julianDate=t;let i=me.leapSeconds,n=Go(i,Zm,c0);if(n<0&&(n=~n),n===0)return me.addSeconds(t,-i[0].offset,e);if(n>=i.length)return me.addSeconds(t,-i[n-1].offset,e);let s=me.secondsDifference(i[n].julianDate,t);if(s===0)return me.addSeconds(t,-i[n].offset,e);if(!(s<=1))return me.addSeconds(t,-i[--n].offset,e)}function sc(t,e,i){let n=e/Fn.SECONDS_PER_DAY|0;return t+=n,e-=Fn.SECONDS_PER_DAY*n,e<0&&(t--,e+=Fn.SECONDS_PER_DAY),i.dayNumber=t,i.secondsOfDay=e,i}function l0(t,e,i,n,s,o,r){let a=(e-14)/12|0,h=t+4800+a,A=(1461*h/4|0)+(367*(e-2-12*a)/12|0)-(3*((h+100)/100|0)/4|0)+i-32075;n=n-12,n<0&&(n+=24);let d=o+(n*Fn.SECONDS_PER_HOUR+s*Fn.SECONDS_PER_MINUTE+r*Fn.SECONDS_PER_MILLISECOND);return d>=43200&&(A-=1),[A,d]}function me(t,e,i){this.dayNumber=void 0,this.secondsOfDay=void 0,t=Z(t,0),e=Z(e,0),i=Z(i,Ei.UTC);let n=t|0;e=e+(t-n)*Fn.SECONDS_PER_DAY,sc(n,e,this),i===Ei.UTC&&mZ(this)}var E2,cZ,lZ,Zm,_q,Rq,Zq,Iq,pq,d0,uq,Cq,gq,Za,dZ,Ze,Or=S(()=>{sE();Ft();mt();Ot();m2();A0();h0();AZ();hZ();E2=new aZ,cZ=[31,28,31,30,31,30,31,31,30,31,30,31],lZ=29;Zm=new zi;_q=/^(\d{4})$/,Rq=/^(\d{4})-(\d{2})$/,Zq=/^(\d{4})-?(\d{3})$/,Iq=/^(\d{4})-?W(\d{2})-?(\d{1})?$/,pq=/^(\d{4})-?(\d{2})-?(\d{2})$/,d0=/([Z+\-])?(\d{2})?:?(\d{2})?$/,uq=/^(\d{2})(\.\d+)?/.source+d0.source,Cq=/^(\d{2}):?(\d{2})(\.\d+)?/.source+d0.source,gq=/^(\d{2}):?(\d{2}):?(\d{2})(\.\d+)?/.source+d0.source,Za="Invalid ISO 8601 date.";me.fromGregorianDate=function(t,e){if(!(t instanceof aZ))throw new Y("date must be a valid GregorianDate.");let i=l0(t.year,t.month,t.day,t.hour,t.minute,t.second,t.millisecond);return m(e)?(sc(i[0],i[1],e),mZ(e),e):new me(i[0],i[1],Ei.UTC)};me.fromDate=function(t,e){if(!(t instanceof Date)||isNaN(t.getTime()))throw new Y("date must be a valid JavaScript Date.");let i=l0(t.getUTCFullYear(),t.getUTCMonth()+1,t.getUTCDate(),t.getUTCHours(),t.getUTCMinutes(),t.getUTCSeconds(),t.getUTCMilliseconds());return m(e)?(sc(i[0],i[1],e),mZ(e),e):new me(i[0],i[1],Ei.UTC)};me.fromIso8601=function(t,e){if(typeof t!="string")throw new Y(Za);t=t.replace(",",".");let i=t.split("T"),n,s=1,o=1,r=0,a=0,h=0,A=0,d=i[0],f=i[1],E,_;if(!m(d))throw new Y(Za);let R;if(i=d.match(pq),i!==null){if(R=d.split("-").length-1,R>0&&R!==2)throw new Y(Za);n=+i[1],s=+i[2],o=+i[3]}else if(i=d.match(Rq),i!==null)n=+i[1],s=+i[2];else if(i=d.match(_q),i!==null)n=+i[1];else{let T;if(i=d.match(Zq),i!==null){if(n=+i[1],T=+i[2],_=rE(n),T<1||_&&T>366||!_&&T>365)throw new Y(Za)}else if(i=d.match(Iq),i!==null){n=+i[1];let b=+i[2],F=+i[3]||0;if(R=d.split("-").length-1,R>0&&(!m(i[3])&&R!==1||m(i[3])&&R!==2))throw new Y(Za);let B=new Date(Date.UTC(n,0,4));T=b*7+F-B.getUTCDay()-3}else throw new Y(Za);E=new Date(Date.UTC(n,0,1)),E.setUTCDate(T),s=E.getUTCMonth()+1,o=E.getUTCDate()}if(_=rE(n),s<1||s>12||o<1||(s!==2||!_)&&o>cZ[s-1]||_&&s===2&&o>lZ)throw new Y(Za);let I;if(m(f)){if(i=f.match(gq),i!==null){if(R=f.split(":").length-1,R>0&&R!==2&&R!==3)throw new Y(Za);r=+i[1],a=+i[2],h=+i[3],A=+(i[4]||0)*1e3,I=5}else if(i=f.match(Cq),i!==null){if(R=f.split(":").length-1,R>2)throw new Y(Za);r=+i[1],a=+i[2],h=+(i[3]||0)*60,I=4}else if(i=f.match(uq),i!==null)r=+i[1],a=+(i[2]||0)*60,I=3;else throw new Y(Za);if(a>=60||h>=61||r>24||r===24&&(a>0||h>0||A>0))throw new Y(Za);let T=i[I],b=+i[I+1],F=+(i[I+2]||0);switch(T){case"+":r=r-b,a=a-F;break;case"-":r=r+b,a=a+F;break;case"Z":break;default:a=a+new Date(Date.UTC(n,s-1,o,r,a)).getTimezoneOffset();break}}let C=h===60;for(C&&h--;a>=60;)a-=60,r++;for(;r>=24;)r-=24,o++;for(E=_&&s===2?lZ:cZ[s-1];o>E;)o-=E,s++,s>12&&(s-=12,n++),E=_&&s===2?lZ:cZ[s-1];for(;a<0;)a+=60,r--;for(;r<0;)r+=24,o--;for(;o<1;)s--,s<1&&(s+=12,n--),E=_&&s===2?lZ:cZ[s-1],o+=E;let N=l0(n,s,o,r,a,h,A);return m(e)?(sc(N[0],N[1],e),mZ(e)):e=new me(N[0],N[1],Ei.UTC),C&&me.addSeconds(e,1,e),e};me.now=function(t){return me.fromDate(new Date,t)};dZ=new me(0,0,Ei.TAI);me.toGregorianDate=function(t,e){if(!m(t))throw new Y("julianDate is required.");let i=!1,n=f2(t,dZ);m(n)||(me.addSeconds(t,-1,dZ),n=f2(dZ,dZ),i=!0);let s=n.dayNumber,o=n.secondsOfDay;o>=43200&&(s+=1);let r=s+68569|0,a=4*r/146097|0;r=r-((146097*a+3)/4|0)|0;let h=4e3*(r+1)/1461001|0;r=r-(1461*h/4|0)+31|0;let A=80*r/2447|0,d=r-(2447*A/80|0)|0;r=A/11|0;let f=A+2-12*r|0,E=100*(a-49)+h+r|0,_=o/Fn.SECONDS_PER_HOUR|0,R=o-_*Fn.SECONDS_PER_HOUR,I=R/Fn.SECONDS_PER_MINUTE|0;R=R-I*Fn.SECONDS_PER_MINUTE;let C=R|0,N=(R-C)/Fn.SECONDS_PER_MILLISECOND;return _+=12,_>23&&(_-=24),i&&(C+=1),m(e)?(e.year=E,e.month=f,e.day=d,e.hour=_,e.minute=I,e.second=C,e.millisecond=N,e.isLeapSecond=i,e):new aZ(E,f,d,_,I,C,N,i)};me.toDate=function(t){if(!m(t))throw new Y("julianDate is required.");let e=me.toGregorianDate(t,E2),i=e.second;return e.isLeapSecond&&(i-=1),new Date(Date.UTC(e.year,e.month-1,e.day,e.hour,e.minute,i,e.millisecond))};me.toIso8601=function(t,e){if(!m(t))throw new Y("julianDate is required.");let i=me.toGregorianDate(t,E2),n=i.year,s=i.month,o=i.day,r=i.hour,a=i.minute,h=i.second,A=i.millisecond;n===1e4&&s===1&&o===1&&r===0&&a===0&&h===0&&A===0&&(n=9999,s=12,o=31,r=24);let d;return!m(e)&&A!==0?(d=(A*.01).toString().replace(".",""),`${n.toString().padStart(4,"0")}-${s.toString().padStart(2,"0")}-${o.toString().padStart(2,"0")}T${r.toString().padStart(2,"0")}:${a.toString().padStart(2,"0")}:${h.toString().padStart(2,"0")}.${d}Z`):!m(e)||e===0?`${n.toString().padStart(4,"0")}-${s.toString().padStart(2,"0")}-${o.toString().padStart(2,"0")}T${r.toString().padStart(2,"0")}:${a.toString().padStart(2,"0")}:${h.toString().padStart(2,"0")}Z`:(d=(A*.01).toFixed(e).replace(".","").slice(0,e),`${n.toString().padStart(4,"0")}-${s.toString().padStart(2,"0")}-${o.toString().padStart(2,"0")}T${r.toString().padStart(2,"0")}:${a.toString().padStart(2,"0")}:${h.toString().padStart(2,"0")}.${d}Z`)};me.clone=function(t,e){if(m(t))return m(e)?(e.dayNumber=t.dayNumber,e.secondsOfDay=t.secondsOfDay,e):new me(t.dayNumber,t.secondsOfDay,Ei.TAI)};me.compare=function(t,e){if(!m(t))throw new Y("left is required.");if(!m(e))throw new Y("right is required.");let i=t.dayNumber-e.dayNumber;return i!==0?i:t.secondsOfDay-e.secondsOfDay};me.equals=function(t,e){return t===e||m(t)&&m(e)&&t.dayNumber===e.dayNumber&&t.secondsOfDay===e.secondsOfDay};me.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(me.secondsDifference(t,e))<=i};me.totalDays=function(t){if(!m(t))throw new Y("julianDate is required.");return t.dayNumber+t.secondsOfDay/Fn.SECONDS_PER_DAY};me.secondsDifference=function(t,e){if(!m(t))throw new Y("left is required.");if(!m(e))throw new Y("right is required.");return(t.dayNumber-e.dayNumber)*Fn.SECONDS_PER_DAY+(t.secondsOfDay-e.secondsOfDay)};me.daysDifference=function(t,e){if(!m(t))throw new Y("left is required.");if(!m(e))throw new Y("right is required.");let i=t.dayNumber-e.dayNumber,n=(t.secondsOfDay-e.secondsOfDay)/Fn.SECONDS_PER_DAY;return i+n};me.computeTaiMinusUtc=function(t){Zm.julianDate=t;let e=me.leapSeconds,i=Go(e,Zm,c0);return i<0&&(i=~i,--i,i<0&&(i=0)),e[i].offset};me.addSeconds=function(t,e,i){if(!m(t))throw new Y("julianDate is required.");if(!m(e))throw new Y("seconds is required.");if(!m(i))throw new Y("result is required.");return sc(t.dayNumber,t.secondsOfDay+e,i)};me.addMinutes=function(t,e,i){if(!m(t))throw new Y("julianDate is required.");if(!m(e))throw new Y("minutes is required.");if(!m(i))throw new Y("result is required.");let n=t.secondsOfDay+e*Fn.SECONDS_PER_MINUTE;return sc(t.dayNumber,n,i)};me.addHours=function(t,e,i){if(!m(t))throw new Y("julianDate is required.");if(!m(e))throw new Y("hours is required.");if(!m(i))throw new Y("result is required.");let n=t.secondsOfDay+e*Fn.SECONDS_PER_HOUR;return sc(t.dayNumber,n,i)};me.addDays=function(t,e,i){if(!m(t))throw new Y("julianDate is required.");if(!m(e))throw new Y("days is required.");if(!m(i))throw new Y("result is required.");let n=t.dayNumber+e;return sc(n,t.secondsOfDay,i)};me.lessThan=function(t,e){return me.compare(t,e)<0};me.lessThanOrEquals=function(t,e){return me.compare(t,e)<=0};me.greaterThan=function(t,e){return me.compare(t,e)>0};me.greaterThanOrEquals=function(t,e){return me.compare(t,e)>=0};me.prototype.clone=function(t){return me.clone(this,t)};me.prototype.equals=function(t){return me.equals(this,t)};me.prototype.equalsEpsilon=function(t,e){return me.equalsEpsilon(this,t,e)};me.prototype.toString=function(){return me.toIso8601(this)};me.leapSeconds=[new zi(new me(2441317,43210,Ei.TAI),10),new zi(new me(2441499,43211,Ei.TAI),11),new zi(new me(2441683,43212,Ei.TAI),12),new zi(new me(2442048,43213,Ei.TAI),13),new zi(new me(2442413,43214,Ei.TAI),14),new zi(new me(2442778,43215,Ei.TAI),15),new zi(new me(2443144,43216,Ei.TAI),16),new zi(new me(2443509,43217,Ei.TAI),17),new zi(new me(2443874,43218,Ei.TAI),18),new zi(new me(2444239,43219,Ei.TAI),19),new zi(new me(2444786,43220,Ei.TAI),20),new zi(new me(2445151,43221,Ei.TAI),21),new zi(new me(2445516,43222,Ei.TAI),22),new zi(new me(2446247,43223,Ei.TAI),23),new zi(new me(2447161,43224,Ei.TAI),24),new zi(new me(2447892,43225,Ei.TAI),25),new zi(new me(2448257,43226,Ei.TAI),26),new zi(new me(2448804,43227,Ei.TAI),27),new zi(new me(2449169,43228,Ei.TAI),28),new zi(new me(2449534,43229,Ei.TAI),29),new zi(new me(2450083,43230,Ei.TAI),30),new zi(new me(2450630,43231,Ei.TAI),31),new zi(new me(2451179,43232,Ei.TAI),32),new zi(new me(2453736,43233,Ei.TAI),33),new zi(new me(2454832,43234,Ei.TAI),34),new zi(new me(2456109,43235,Ei.TAI),35),new zi(new me(2457204,43236,Ei.TAI),36),new zi(new me(2457754,43237,Ei.TAI),37)];Ze=me});var _2=ts((Im,pm)=>{/*! https://mths.be/punycode v1.4.0 by @mathias */(function(t){var e=typeof Im=="object"&&Im&&!Im.nodeType&&Im,i=typeof pm=="object"&&pm&&!pm.nodeType&&pm,n=typeof global=="object"&&global;(n.global===n||n.window===n||n.self===n)&&(t=n);var s,o=2147483647,r=36,a=1,h=26,A=38,d=700,f=72,E=128,_="-",R=/^xn--/,I=/[^\x20-\x7E]/,C=/[\x2E\u3002\uFF0E\uFF61]/g,N={overflow:"Overflow: input needs wider integers to process","not-basic":"Illegal input >= 0x80 (not a basic code point)","invalid-input":"Invalid input"},T=r-a,b=Math.floor,F=String.fromCharCode,B;function U(j){throw new RangeError(N[j])}function Q(j,X){for(var tt=j.length,G=[];tt--;)G[tt]=X(j[tt]);return G}function M(j,X){var tt=j.split("@"),G="";tt.length>1&&(G=tt[0]+"@",j=tt[1]),j=j.replace(C,".");var It=j.split("."),gt=Q(It,X).join(".");return G+gt}function k(j){for(var X=[],tt=0,G=j.length,It,gt;tt<G;)It=j.charCodeAt(tt++),It>=55296&&It<=56319&&tt<G?(gt=j.charCodeAt(tt++),(gt&64512)==56320?X.push(((It&1023)<<10)+(gt&1023)+65536):(X.push(It),tt--)):X.push(It);return X}function y(j){return Q(j,function(X){var tt="";return X>65535&&(X-=65536,tt+=F(X>>>10&1023|55296),X=56320|X&1023),tt+=F(X),tt}).join("")}function c(j){return j-48<10?j-22:j-65<26?j-65:j-97<26?j-97:r}function g(j,X){return j+22+75*(j<26)-((X!=0)<<5)}function O(j,X,tt){var G=0;for(j=tt?b(j/d):j>>1,j+=b(j/X);j>T*h>>1;G+=r)j=b(j/T);return b(G+(T+1)*j/(j+A))}function D(j){var X=[],tt=j.length,G,It=0,gt=E,Yt=f,Ut,Ct,zt,kt,Jt,Wt,bt,ee,ce;for(Ut=j.lastIndexOf(_),Ut<0&&(Ut=0),Ct=0;Ct<Ut;++Ct)j.charCodeAt(Ct)>=128&&U("not-basic"),X.push(j.charCodeAt(Ct));for(zt=Ut>0?Ut+1:0;zt<tt;){for(kt=It,Jt=1,Wt=r;zt>=tt&&U("invalid-input"),bt=c(j.charCodeAt(zt++)),(bt>=r||bt>b((o-It)/Jt))&&U("overflow"),It+=bt*Jt,ee=Wt<=Yt?a:Wt>=Yt+h?h:Wt-Yt,!(bt<ee);Wt+=r)ce=r-ee,Jt>b(o/ce)&&U("overflow"),Jt*=ce;G=X.length+1,Yt=O(It-kt,G,kt==0),b(It/G)>o-gt&&U("overflow"),gt+=b(It/G),It%=G,X.splice(It++,0,gt)}return y(X)}function w(j){var X,tt,G,It,gt,Yt,Ut,Ct,zt,kt,Jt,Wt=[],bt,ee,ce,je;for(j=k(j),bt=j.length,X=E,tt=0,gt=f,Yt=0;Yt<bt;++Yt)Jt=j[Yt],Jt<128&&Wt.push(F(Jt));for(G=It=Wt.length,It&&Wt.push(_);G<bt;){for(Ut=o,Yt=0;Yt<bt;++Yt)Jt=j[Yt],Jt>=X&&Jt<Ut&&(Ut=Jt);for(ee=G+1,Ut-X>b((o-tt)/ee)&&U("overflow"),tt+=(Ut-X)*ee,X=Ut,Yt=0;Yt<bt;++Yt)if(Jt=j[Yt],Jt<X&&++tt>o&&U("overflow"),Jt==X){for(Ct=tt,zt=r;kt=zt<=gt?a:zt>=gt+h?h:zt-gt,!(Ct<kt);zt+=r)je=Ct-kt,ce=r-kt,Wt.push(F(g(kt+je%ce,0))),Ct=b(je/ce);Wt.push(F(g(Ct,0))),gt=O(tt,ee,G==It),tt=0,++G}++tt,++X}return Wt.join("")}function x(j){return M(j,function(X){return R.test(X)?D(X.slice(4).toLowerCase()):X})}function H(j){return M(j,function(X){return I.test(X)?"xn--"+w(X):X})}if(s={version:"1.3.2",ucs2:{decode:k,encode:y},decode:D,encode:w,toASCII:H,toUnicode:x},typeof define=="function"&&typeof define.amd=="object"&&define.amd)define("punycode",function(){return s});else if(e&&i)if(pm.exports==e)i.exports=s;else for(B in s)s.hasOwnProperty(B)&&(e[B]=s[B]);else t.punycode=s})(Im)});var Z2=ts((R2,fZ)=>{/*!
 * URI.js - Mutating URLs
 * IPv6 Support
 *
 * Version: 1.19.11
 *
 * Author: Rodney Rehm
 * Web: http://medialize.github.io/URI.js/
 *
 * Licensed under
 *   MIT License http://www.opensource.org/licenses/mit-license
 *
 */(function(t,e){"use strict";typeof fZ=="object"&&fZ.exports?fZ.exports=e():typeof define=="function"&&define.amd?define(e):t.IPv6=e(t)})(R2,function(t){"use strict";var e=t&&t.IPv6;function i(s){var o=s.toLowerCase(),r=o.split(":"),a=r.length,h=8;r[0]===""&&r[1]===""&&r[2]===""?(r.shift(),r.shift()):r[0]===""&&r[1]===""?r.shift():r[a-1]===""&&r[a-2]===""&&r.pop(),a=r.length,r[a-1].indexOf(".")!==-1&&(h=7);var A;for(A=0;A<a&&r[A]!=="";A++);if(A<h)for(r.splice(A,1,"0000");r.length<h;)r.splice(A,0,"0000");for(var d,f=0;f<h;f++){d=r[f].split("");for(var E=0;E<3&&(d[0]==="0"&&d.length>1);E++)d.splice(0,1);r[f]=d.join("")}var _=-1,R=0,I=0,C=-1,N=!1;for(f=0;f<h;f++)N?r[f]==="0"?I+=1:(N=!1,I>R&&(_=C,R=I)):r[f]==="0"&&(N=!0,C=f,I=1);I>R&&(_=C,R=I),R>1&&r.splice(_,R,""),a=r.length;var T="";for(r[0]===""&&(T=":"),f=0;f<a&&(T+=r[f],f!==a-1);f++)T+=":";return r[a-1]===""&&(T+=":"),T}function n(){return t.IPv6===this&&(t.IPv6=e),this}return{best:i,noConflict:n}})});var p2=ts((I2,EZ)=>{/*!
 * URI.js - Mutating URLs
 * Second Level Domain (SLD) Support
 *
 * Version: 1.19.11
 *
 * Author: Rodney Rehm
 * Web: http://medialize.github.io/URI.js/
 *
 * Licensed under
 *   MIT License http://www.opensource.org/licenses/mit-license
 *
 */(function(t,e){"use strict";typeof EZ=="object"&&EZ.exports?EZ.exports=e():typeof define=="function"&&define.amd?define(e):t.SecondLevelDomains=e(t)})(I2,function(t){"use strict";var e=t&&t.SecondLevelDomains,i={list:{ac:" com gov mil net org ",ae:" ac co gov mil name net org pro sch ",af:" com edu gov net org ",al:" com edu gov mil net org ",ao:" co ed gv it og pb ",ar:" com edu gob gov int mil net org tur ",at:" ac co gv or ",au:" asn com csiro edu gov id net org ",ba:" co com edu gov mil net org rs unbi unmo unsa untz unze ",bb:" biz co com edu gov info net org store tv ",bh:" biz cc com edu gov info net org ",bn:" com edu gov net org ",bo:" com edu gob gov int mil net org tv ",br:" adm adv agr am arq art ato b bio blog bmd cim cng cnt com coop ecn edu eng esp etc eti far flog fm fnd fot fst g12 ggf gov imb ind inf jor jus lel mat med mil mus net nom not ntr odo org ppg pro psc psi qsl rec slg srv tmp trd tur tv vet vlog wiki zlg ",bs:" com edu gov net org ",bz:" du et om ov rg ",ca:" ab bc mb nb nf nl ns nt nu on pe qc sk yk ",ck:" biz co edu gen gov info net org ",cn:" ac ah bj com cq edu fj gd gov gs gx gz ha hb he hi hl hn jl js jx ln mil net nm nx org qh sc sd sh sn sx tj tw xj xz yn zj ",co:" com edu gov mil net nom org ",cr:" ac c co ed fi go or sa ",cy:" ac biz com ekloges gov ltd name net org parliament press pro tm ",do:" art com edu gob gov mil net org sld web ",dz:" art asso com edu gov net org pol ",ec:" com edu fin gov info med mil net org pro ",eg:" com edu eun gov mil name net org sci ",er:" com edu gov ind mil net org rochest w ",es:" com edu gob nom org ",et:" biz com edu gov info name net org ",fj:" ac biz com info mil name net org pro ",fk:" ac co gov net nom org ",fr:" asso com f gouv nom prd presse tm ",gg:" co net org ",gh:" com edu gov mil org ",gn:" ac com gov net org ",gr:" com edu gov mil net org ",gt:" com edu gob ind mil net org ",gu:" com edu gov net org ",hk:" com edu gov idv net org ",hu:" 2000 agrar bolt casino city co erotica erotika film forum games hotel info ingatlan jogasz konyvelo lakas media news org priv reklam sex shop sport suli szex tm tozsde utazas video ",id:" ac co go mil net or sch web ",il:" ac co gov idf k12 muni net org ",in:" ac co edu ernet firm gen gov i ind mil net nic org res ",iq:" com edu gov i mil net org ",ir:" ac co dnssec gov i id net org sch ",it:" edu gov ",je:" co net org ",jo:" com edu gov mil name net org sch ",jp:" ac ad co ed go gr lg ne or ",ke:" ac co go info me mobi ne or sc ",kh:" com edu gov mil net org per ",ki:" biz com de edu gov info mob net org tel ",km:" asso com coop edu gouv k medecin mil nom notaires pharmaciens presse tm veterinaire ",kn:" edu gov net org ",kr:" ac busan chungbuk chungnam co daegu daejeon es gangwon go gwangju gyeongbuk gyeonggi gyeongnam hs incheon jeju jeonbuk jeonnam k kg mil ms ne or pe re sc seoul ulsan ",kw:" com edu gov net org ",ky:" com edu gov net org ",kz:" com edu gov mil net org ",lb:" com edu gov net org ",lk:" assn com edu gov grp hotel int ltd net ngo org sch soc web ",lr:" com edu gov net org ",lv:" asn com conf edu gov id mil net org ",ly:" com edu gov id med net org plc sch ",ma:" ac co gov m net org press ",mc:" asso tm ",me:" ac co edu gov its net org priv ",mg:" com edu gov mil nom org prd tm ",mk:" com edu gov inf name net org pro ",ml:" com edu gov net org presse ",mn:" edu gov org ",mo:" com edu gov net org ",mt:" com edu gov net org ",mv:" aero biz com coop edu gov info int mil museum name net org pro ",mw:" ac co com coop edu gov int museum net org ",mx:" com edu gob net org ",my:" com edu gov mil name net org sch ",nf:" arts com firm info net other per rec store web ",ng:" biz com edu gov mil mobi name net org sch ",ni:" ac co com edu gob mil net nom org ",np:" com edu gov mil net org ",nr:" biz com edu gov info net org ",om:" ac biz co com edu gov med mil museum net org pro sch ",pe:" com edu gob mil net nom org sld ",ph:" com edu gov i mil net ngo org ",pk:" biz com edu fam gob gok gon gop gos gov net org web ",pl:" art bialystok biz com edu gda gdansk gorzow gov info katowice krakow lodz lublin mil net ngo olsztyn org poznan pwr radom slupsk szczecin torun warszawa waw wroc wroclaw zgora ",pr:" ac biz com edu est gov info isla name net org pro prof ",ps:" com edu gov net org plo sec ",pw:" belau co ed go ne or ",ro:" arts com firm info nom nt org rec store tm www ",rs:" ac co edu gov in org ",sb:" com edu gov net org ",sc:" com edu gov net org ",sh:" co com edu gov net nom org ",sl:" com edu gov net org ",st:" co com consulado edu embaixada gov mil net org principe saotome store ",sv:" com edu gob org red ",sz:" ac co org ",tr:" av bbs bel biz com dr edu gen gov info k12 name net org pol tel tsk tv web ",tt:" aero biz cat co com coop edu gov info int jobs mil mobi museum name net org pro tel travel ",tw:" club com ebiz edu game gov idv mil net org ",mu:" ac co com gov net or org ",mz:" ac co edu gov org ",na:" co com ",nz:" ac co cri geek gen govt health iwi maori mil net org parliament school ",pa:" abo ac com edu gob ing med net nom org sld ",pt:" com edu gov int net nome org publ ",py:" com edu gov mil net org ",qa:" com edu gov mil net org ",re:" asso com nom ",ru:" ac adygeya altai amur arkhangelsk astrakhan bashkiria belgorod bir bryansk buryatia cbg chel chelyabinsk chita chukotka chuvashia com dagestan e-burg edu gov grozny int irkutsk ivanovo izhevsk jar joshkar-ola kalmykia kaluga kamchatka karelia kazan kchr kemerovo khabarovsk khakassia khv kirov koenig komi kostroma kranoyarsk kuban kurgan kursk lipetsk magadan mari mari-el marine mil mordovia mosreg msk murmansk nalchik net nnov nov novosibirsk nsk omsk orenburg org oryol penza perm pp pskov ptz rnd ryazan sakhalin samara saratov simbirsk smolensk spb stavropol stv surgut tambov tatarstan tom tomsk tsaritsyn tsk tula tuva tver tyumen udm udmurtia ulan-ude vladikavkaz vladimir vladivostok volgograd vologda voronezh vrn vyatka yakutia yamal yekaterinburg yuzhno-sakhalinsk ",rw:" ac co com edu gouv gov int mil net ",sa:" com edu gov med net org pub sch ",sd:" com edu gov info med net org tv ",se:" a ac b bd c d e f g h i k l m n o org p parti pp press r s t tm u w x y z ",sg:" com edu gov idn net org per ",sn:" art com edu gouv org perso univ ",sy:" com edu gov mil net news org ",th:" ac co go in mi net or ",tj:" ac biz co com edu go gov info int mil name net nic org test web ",tn:" agrinet com defense edunet ens fin gov ind info intl mincom nat net org perso rnrt rns rnu tourism ",tz:" ac co go ne or ",ua:" biz cherkassy chernigov chernovtsy ck cn co com crimea cv dn dnepropetrovsk donetsk dp edu gov if in ivano-frankivsk kh kharkov kherson khmelnitskiy kiev kirovograd km kr ks kv lg lugansk lutsk lviv me mk net nikolaev od odessa org pl poltava pp rovno rv sebastopol sumy te ternopil uzhgorod vinnica vn zaporizhzhe zhitomir zp zt ",ug:" ac co go ne or org sc ",uk:" ac bl british-library co cym gov govt icnet jet lea ltd me mil mod national-library-scotland nel net nhs nic nls org orgn parliament plc police sch scot soc ",us:" dni fed isa kids nsn ",uy:" com edu gub mil net org ",ve:" co com edu gob info mil net org web ",vi:" co com k12 net org ",vn:" ac biz com edu gov health info int name net org pro ",ye:" co com gov ltd me net org plc ",yu:" ac co edu gov org ",za:" ac agric alt bourse city co cybernet db edu gov grondar iaccess imt inca landesign law mil net ngo nis nom olivetti org pix school tm web ",zm:" ac co com edu gov net org sch ",com:"ar br cn de eu gb gr hu jpn kr no qc ru sa se uk us uy za ",net:"gb jp se uk ",org:"ae",de:"com "},has:function(n){var s=n.lastIndexOf(".");if(s<=0||s>=n.length-1)return!1;var o=n.lastIndexOf(".",s-1);if(o<=0||o>=s-1)return!1;var r=i.list[n.slice(s+1)];return r?r.indexOf(" "+n.slice(o+1,s)+" ")>=0:!1},is:function(n){var s=n.lastIndexOf(".");if(s<=0||s>=n.length-1)return!1;var o=n.lastIndexOf(".",s-1);if(o>=0)return!1;var r=i.list[n.slice(s+1)];return r?r.indexOf(" "+n.slice(0,s)+" ")>=0:!1},get:function(n){var s=n.lastIndexOf(".");if(s<=0||s>=n.length-1)return null;var o=n.lastIndexOf(".",s-1);if(o<=0||o>=s-1)return null;var r=i.list[n.slice(s+1)];return!r||r.indexOf(" "+n.slice(o+1,s)+" ")<0?null:n.slice(o+1)},noConflict:function(){return t.SecondLevelDomains===this&&(t.SecondLevelDomains=e),this}};return i})});var oc=ts((u2,_Z)=>{/*!
 * URI.js - Mutating URLs
 *
 * Version: 1.19.11
 *
 * Author: Rodney Rehm
 * Web: http://medialize.github.io/URI.js/
 *
 * Licensed under
 *   MIT License http://www.opensource.org/licenses/mit-license
 *
 */(function(t,e){"use strict";typeof _Z=="object"&&_Z.exports?_Z.exports=e(_2(),Z2(),p2()):typeof define=="function"&&define.amd?define(["./punycode","./IPv6","./SecondLevelDomains"],e):t.URI=e(t.punycode,t.IPv6,t.SecondLevelDomains,t)})(u2,function(t,e,i,n){"use strict";var s=n&&n.URI;function o(g,O){var D=arguments.length>=1,w=arguments.length>=2;if(!(this instanceof o))return D?w?new o(g,O):new o(g):new o;if(g===void 0){if(D)throw new TypeError("undefined is not a valid argument for URI");typeof location<"u"?g=location.href+"":g=""}if(g===null&&D)throw new TypeError("null is not a valid argument for URI");return this.href(g),O!==void 0?this.absoluteTo(O):this}function r(g){return/^[0-9]+$/.test(g)}o.version="1.19.11";var a=o.prototype,h=Object.prototype.hasOwnProperty;function A(g){return g.replace(/([.*+?^=!:${}()|[\]\/\\])/g,"\\$1")}function d(g){return g===void 0?"Undefined":String(Object.prototype.toString.call(g)).slice(8,-1)}function f(g){return d(g)==="Array"}function E(g,O){var D={},w,x;if(d(O)==="RegExp")D=null;else if(f(O))for(w=0,x=O.length;w<x;w++)D[O[w]]=!0;else D[O]=!0;for(w=0,x=g.length;w<x;w++){var H=D&&D[g[w]]!==void 0||!D&&O.test(g[w]);H&&(g.splice(w,1),x--,w--)}return g}function _(g,O){var D,w;if(f(O)){for(D=0,w=O.length;D<w;D++)if(!_(g,O[D]))return!1;return!0}var x=d(O);for(D=0,w=g.length;D<w;D++)if(x==="RegExp"){if(typeof g[D]=="string"&&g[D].match(O))return!0}else if(g[D]===O)return!0;return!1}function R(g,O){if(!f(g)||!f(O)||g.length!==O.length)return!1;g.sort(),O.sort();for(var D=0,w=g.length;D<w;D++)if(g[D]!==O[D])return!1;return!0}function I(g){var O=/^\/+|\/+$/g;return g.replace(O,"")}o._parts=function(){return{protocol:null,username:null,password:null,hostname:null,urn:null,port:null,path:null,query:null,fragment:null,preventInvalidHostname:o.preventInvalidHostname,duplicateQueryParameters:o.duplicateQueryParameters,escapeQuerySpace:o.escapeQuerySpace}},o.preventInvalidHostname=!1,o.duplicateQueryParameters=!1,o.escapeQuerySpace=!0,o.protocol_expression=/^[a-z][a-z0-9.+-]*$/i,o.idn_expression=/[^a-z0-9\._-]/i,o.punycode_expression=/(xn--)/i,o.ip4_expression=/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/,o.ip6_expression=/^\s*((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9A-Fa-f]{1,4}:){6}(:[0-9A-Fa-f]{1,4}|((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){5}(((:[0-9A-Fa-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){4}(((:[0-9A-Fa-f]{1,4}){1,3})|((:[0-9A-Fa-f]{1,4})?:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){3}(((:[0-9A-Fa-f]{1,4}){1,4})|((:[0-9A-Fa-f]{1,4}){0,2}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){2}(((:[0-9A-Fa-f]{1,4}){1,5})|((:[0-9A-Fa-f]{1,4}){0,3}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){1}(((:[0-9A-Fa-f]{1,4}){1,6})|((:[0-9A-Fa-f]{1,4}){0,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(:(((:[0-9A-Fa-f]{1,4}){1,7})|((:[0-9A-Fa-f]{1,4}){0,5}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(%.+)?\s*$/,o.find_uri_expression=/\b((?:[a-z][\w-]+:(?:\/{1,3}|[a-z0-9%])|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))/ig,o.findUri={start:/\b(?:([a-z][a-z0-9.+-]*:\/\/)|www\.)/gi,end:/[\s\r\n]|$/,trim:/[`!()\[\]{};:'".,<>?«»“”„‘’]+$/,parens:/(\([^\)]*\)|\[[^\]]*\]|\{[^}]*\}|<[^>]*>)/g},o.leading_whitespace_expression=/^[\x00-\x20\u00a0\u1680\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff]+/,o.ascii_tab_whitespace=/[\u0009\u000A\u000D]+/g,o.defaultPorts={http:"80",https:"443",ftp:"21",gopher:"70",ws:"80",wss:"443"},o.hostProtocols=["http","https"],o.invalid_hostname_characters=/[^a-zA-Z0-9\.\-:_]/,o.domAttributes={a:"href",blockquote:"cite",link:"href",base:"href",script:"src",form:"action",img:"src",area:"href",iframe:"src",embed:"src",source:"src",track:"src",input:"src",audio:"src",video:"src"},o.getDomAttribute=function(g){if(!(!g||!g.nodeName)){var O=g.nodeName.toLowerCase();if(!(O==="input"&&g.type!=="image"))return o.domAttributes[O]}};function C(g){return escape(g)}function N(g){return encodeURIComponent(g).replace(/[!'()*]/g,C).replace(/\*/g,"%2A")}o.encode=N,o.decode=decodeURIComponent,o.iso8859=function(){o.encode=escape,o.decode=unescape},o.unicode=function(){o.encode=N,o.decode=decodeURIComponent},o.characters={pathname:{encode:{expression:/%(24|26|2B|2C|3B|3D|3A|40)/ig,map:{"%24":"$","%26":"&","%2B":"+","%2C":",","%3B":";","%3D":"=","%3A":":","%40":"@"}},decode:{expression:/[\/\?#]/g,map:{"/":"%2F","?":"%3F","#":"%23"}}},reserved:{encode:{expression:/%(21|23|24|26|27|28|29|2A|2B|2C|2F|3A|3B|3D|3F|40|5B|5D)/ig,map:{"%3A":":","%2F":"/","%3F":"?","%23":"#","%5B":"[","%5D":"]","%40":"@","%21":"!","%24":"$","%26":"&","%27":"'","%28":"(","%29":")","%2A":"*","%2B":"+","%2C":",","%3B":";","%3D":"="}}},urnpath:{encode:{expression:/%(21|24|27|28|29|2A|2B|2C|3B|3D|40)/ig,map:{"%21":"!","%24":"$","%27":"'","%28":"(","%29":")","%2A":"*","%2B":"+","%2C":",","%3B":";","%3D":"=","%40":"@"}},decode:{expression:/[\/\?#:]/g,map:{"/":"%2F","?":"%3F","#":"%23",":":"%3A"}}}},o.encodeQuery=function(g,O){var D=o.encode(g+"");return O===void 0&&(O=o.escapeQuerySpace),O?D.replace(/%20/g,"+"):D},o.decodeQuery=function(g,O){g+="",O===void 0&&(O=o.escapeQuerySpace);try{return o.decode(O?g.replace(/\+/g,"%20"):g)}catch{return g}};var T={encode:"encode",decode:"decode"},b,F=function(g,O){return function(D){try{return o[O](D+"").replace(o.characters[g][O].expression,function(w){return o.characters[g][O].map[w]})}catch{return D}}};for(b in T)o[b+"PathSegment"]=F("pathname",T[b]),o[b+"UrnPathSegment"]=F("urnpath",T[b]);var B=function(g,O,D){return function(w){var x;D?x=function(tt){return o[O](o[D](tt))}:x=o[O];for(var H=(w+"").split(g),j=0,X=H.length;j<X;j++)H[j]=x(H[j]);return H.join(g)}};o.decodePath=B("/","decodePathSegment"),o.decodeUrnPath=B(":","decodeUrnPathSegment"),o.recodePath=B("/","encodePathSegment","decode"),o.recodeUrnPath=B(":","encodeUrnPathSegment","decode"),o.encodeReserved=F("reserved","encode"),o.parse=function(g,O){var D;return O||(O={preventInvalidHostname:o.preventInvalidHostname}),g=g.replace(o.leading_whitespace_expression,""),g=g.replace(o.ascii_tab_whitespace,""),D=g.indexOf("#"),D>-1&&(O.fragment=g.substring(D+1)||null,g=g.substring(0,D)),D=g.indexOf("?"),D>-1&&(O.query=g.substring(D+1)||null,g=g.substring(0,D)),g=g.replace(/^(https?|ftp|wss?)?:+[/\\]*/i,"$1://"),g=g.replace(/^[/\\]{2,}/i,"//"),g.substring(0,2)==="//"?(O.protocol=null,g=g.substring(2),g=o.parseAuthority(g,O)):(D=g.indexOf(":"),D>-1&&(O.protocol=g.substring(0,D)||null,O.protocol&&!O.protocol.match(o.protocol_expression)?O.protocol=void 0:g.substring(D+1,D+3).replace(/\\/g,"/")==="//"?(g=g.substring(D+3),g=o.parseAuthority(g,O)):(g=g.substring(D+1),O.urn=!0))),O.path=g,O},o.parseHost=function(g,O){g||(g=""),g=g.replace(/\\/g,"/");var D=g.indexOf("/"),w,x;if(D===-1&&(D=g.length),g.charAt(0)==="[")w=g.indexOf("]"),O.hostname=g.substring(1,w)||null,O.port=g.substring(w+2,D)||null,O.port==="/"&&(O.port=null);else{var H=g.indexOf(":"),j=g.indexOf("/"),X=g.indexOf(":",H+1);X!==-1&&(j===-1||X<j)?(O.hostname=g.substring(0,D)||null,O.port=null):(x=g.substring(0,D).split(":"),O.hostname=x[0]||null,O.port=x[1]||null)}return O.hostname&&g.substring(D).charAt(0)!=="/"&&(D++,g="/"+g),O.preventInvalidHostname&&o.ensureValidHostname(O.hostname,O.protocol),O.port&&o.ensureValidPort(O.port),g.substring(D)||"/"},o.parseAuthority=function(g,O){return g=o.parseUserinfo(g,O),o.parseHost(g,O)},o.parseUserinfo=function(g,O){var D=g,w=g.indexOf("\\");w!==-1&&(g=g.replace(/\\/g,"/"));var x=g.indexOf("/"),H=g.lastIndexOf("@",x>-1?x:g.length-1),j;return H>-1&&(x===-1||H<x)?(j=g.substring(0,H).split(":"),O.username=j[0]?o.decode(j[0]):null,j.shift(),O.password=j[0]?o.decode(j.join(":")):null,g=D.substring(H+1)):(O.username=null,O.password=null),g},o.parseQuery=function(g,O){if(!g)return{};if(g=g.replace(/&+/g,"&").replace(/^\?*&*|&+$/g,""),!g)return{};for(var D={},w=g.split("&"),x=w.length,H,j,X,tt=0;tt<x;tt++)H=w[tt].split("="),j=o.decodeQuery(H.shift(),O),X=H.length?o.decodeQuery(H.join("="),O):null,j!=="__proto__"&&(h.call(D,j)?((typeof D[j]=="string"||D[j]===null)&&(D[j]=[D[j]]),D[j].push(X)):D[j]=X);return D},o.build=function(g){var O="",D=!1;return g.protocol&&(O+=g.protocol+":"),!g.urn&&(O||g.hostname)&&(O+="//",D=!0),O+=o.buildAuthority(g)||"",typeof g.path=="string"&&(g.path.charAt(0)!=="/"&&D&&(O+="/"),O+=g.path),typeof g.query=="string"&&g.query&&(O+="?"+g.query),typeof g.fragment=="string"&&g.fragment&&(O+="#"+g.fragment),O},o.buildHost=function(g){var O="";if(g.hostname)o.ip6_expression.test(g.hostname)?O+="["+g.hostname+"]":O+=g.hostname;else return"";return g.port&&(O+=":"+g.port),O},o.buildAuthority=function(g){return o.buildUserinfo(g)+o.buildHost(g)},o.buildUserinfo=function(g){var O="";return g.username&&(O+=o.encode(g.username)),g.password&&(O+=":"+o.encode(g.password)),O&&(O+="@"),O},o.buildQuery=function(g,O,D){var w="",x,H,j,X;for(H in g)if(H!=="__proto__"&&h.call(g,H))if(f(g[H]))for(x={},j=0,X=g[H].length;j<X;j++)g[H][j]!==void 0&&x[g[H][j]+""]===void 0&&(w+="&"+o.buildQueryParameter(H,g[H][j],D),O!==!0&&(x[g[H][j]+""]=!0));else g[H]!==void 0&&(w+="&"+o.buildQueryParameter(H,g[H],D));return w.substring(1)},o.buildQueryParameter=function(g,O,D){return o.encodeQuery(g,D)+(O!==null?"="+o.encodeQuery(O,D):"")},o.addQuery=function(g,O,D){if(typeof O=="object")for(var w in O)h.call(O,w)&&o.addQuery(g,w,O[w]);else if(typeof O=="string"){if(g[O]===void 0){g[O]=D;return}else typeof g[O]=="string"&&(g[O]=[g[O]]);f(D)||(D=[D]),g[O]=(g[O]||[]).concat(D)}else throw new TypeError("URI.addQuery() accepts an object, string as the name parameter")},o.setQuery=function(g,O,D){if(typeof O=="object")for(var w in O)h.call(O,w)&&o.setQuery(g,w,O[w]);else if(typeof O=="string")g[O]=D===void 0?null:D;else throw new TypeError("URI.setQuery() accepts an object, string as the name parameter")},o.removeQuery=function(g,O,D){var w,x,H;if(f(O))for(w=0,x=O.length;w<x;w++)g[O[w]]=void 0;else if(d(O)==="RegExp")for(H in g)O.test(H)&&(g[H]=void 0);else if(typeof O=="object")for(H in O)h.call(O,H)&&o.removeQuery(g,H,O[H]);else if(typeof O=="string")D!==void 0?d(D)==="RegExp"?!f(g[O])&&D.test(g[O])?g[O]=void 0:g[O]=E(g[O],D):g[O]===String(D)&&(!f(D)||D.length===1)?g[O]=void 0:f(g[O])&&(g[O]=E(g[O],D)):g[O]=void 0;else throw new TypeError("URI.removeQuery() accepts an object, string, RegExp as the first parameter")},o.hasQuery=function(g,O,D,w){switch(d(O)){case"String":break;case"RegExp":for(var x in g)if(h.call(g,x)&&O.test(x)&&(D===void 0||o.hasQuery(g,x,D)))return!0;return!1;case"Object":for(var H in O)if(h.call(O,H)&&!o.hasQuery(g,H,O[H]))return!1;return!0;default:throw new TypeError("URI.hasQuery() accepts a string, regular expression or object as the name parameter")}switch(d(D)){case"Undefined":return O in g;case"Boolean":var j=!!(f(g[O])?g[O].length:g[O]);return D===j;case"Function":return!!D(g[O],O,g);case"Array":if(!f(g[O]))return!1;var X=w?_:R;return X(g[O],D);case"RegExp":return f(g[O])?w?_(g[O],D):!1:!!(g[O]&&g[O].match(D));case"Number":D=String(D);case"String":return f(g[O])?w?_(g[O],D):!1:g[O]===D;default:throw new TypeError("URI.hasQuery() accepts undefined, boolean, string, number, RegExp, Function as the value parameter")}},o.joinPaths=function(){for(var g=[],O=[],D=0,w=0;w<arguments.length;w++){var x=new o(arguments[w]);g.push(x);for(var H=x.segment(),j=0;j<H.length;j++)typeof H[j]=="string"&&O.push(H[j]),H[j]&&D++}if(!O.length||!D)return new o("");var X=new o("").segment(O);return(g[0].path()===""||g[0].path().slice(0,1)==="/")&&X.path("/"+X.path()),X.normalize()},o.commonPath=function(g,O){var D=Math.min(g.length,O.length),w;for(w=0;w<D;w++)if(g.charAt(w)!==O.charAt(w)){w--;break}return w<1?g.charAt(0)===O.charAt(0)&&g.charAt(0)==="/"?"/":"":((g.charAt(w)!=="/"||O.charAt(w)!=="/")&&(w=g.substring(0,w).lastIndexOf("/")),g.substring(0,w+1))},o.withinString=function(g,O,D){D||(D={});var w=D.start||o.findUri.start,x=D.end||o.findUri.end,H=D.trim||o.findUri.trim,j=D.parens||o.findUri.parens,X=/[a-z0-9-]=["']?$/i;for(w.lastIndex=0;;){var tt=w.exec(g);if(!tt)break;var G=tt.index;if(D.ignoreHtml){var It=g.slice(Math.max(G-3,0),G);if(It&&X.test(It))continue}for(var gt=G+g.slice(G).search(x),Yt=g.slice(G,gt),Ut=-1;;){var Ct=j.exec(Yt);if(!Ct)break;var zt=Ct.index+Ct[0].length;Ut=Math.max(Ut,zt)}if(Ut>-1?Yt=Yt.slice(0,Ut)+Yt.slice(Ut).replace(H,""):Yt=Yt.replace(H,""),!(Yt.length<=tt[0].length)&&!(D.ignore&&D.ignore.test(Yt))){gt=G+Yt.length;var kt=O(Yt,G,gt,g);if(kt===void 0){w.lastIndex=gt;continue}kt=String(kt),g=g.slice(0,G)+kt+g.slice(gt),w.lastIndex=G+kt.length}}return w.lastIndex=0,g},o.ensureValidHostname=function(g,O){var D=!!g,w=!!O,x=!1;if(w&&(x=_(o.hostProtocols,O)),x&&!D)throw new TypeError("Hostname cannot be empty, if protocol is "+O);if(g&&g.match(o.invalid_hostname_characters)){if(!t)throw new TypeError('Hostname "'+g+'" contains characters other than [A-Z0-9.-:_] and Punycode.js is not available');if(t.toASCII(g).match(o.invalid_hostname_characters))throw new TypeError('Hostname "'+g+'" contains characters other than [A-Z0-9.-:_]')}},o.ensureValidPort=function(g){if(g){var O=Number(g);if(!(r(O)&&O>0&&O<65536))throw new TypeError('Port "'+g+'" is not a valid port')}},o.noConflict=function(g){if(g){var O={URI:this.noConflict()};return n.URITemplate&&typeof n.URITemplate.noConflict=="function"&&(O.URITemplate=n.URITemplate.noConflict()),n.IPv6&&typeof n.IPv6.noConflict=="function"&&(O.IPv6=n.IPv6.noConflict()),n.SecondLevelDomains&&typeof n.SecondLevelDomains.noConflict=="function"&&(O.SecondLevelDomains=n.SecondLevelDomains.noConflict()),O}else n.URI===this&&(n.URI=s);return this},a.build=function(g){return g===!0?this._deferred_build=!0:(g===void 0||this._deferred_build)&&(this._string=o.build(this._parts),this._deferred_build=!1),this},a.clone=function(){return new o(this)},a.valueOf=a.toString=function(){return this.build(!1)._string};function U(g){return function(O,D){return O===void 0?this._parts[g]||"":(this._parts[g]=O||null,this.build(!D),this)}}function Q(g,O){return function(D,w){return D===void 0?this._parts[g]||"":(D!==null&&(D=D+"",D.charAt(0)===O&&(D=D.substring(1))),this._parts[g]=D,this.build(!w),this)}}a.protocol=U("protocol"),a.username=U("username"),a.password=U("password"),a.hostname=U("hostname"),a.port=U("port"),a.query=Q("query","?"),a.fragment=Q("fragment","#"),a.search=function(g,O){var D=this.query(g,O);return typeof D=="string"&&D.length?"?"+D:D},a.hash=function(g,O){var D=this.fragment(g,O);return typeof D=="string"&&D.length?"#"+D:D},a.pathname=function(g,O){if(g===void 0||g===!0){var D=this._parts.path||(this._parts.hostname?"/":"");return g?(this._parts.urn?o.decodeUrnPath:o.decodePath)(D):D}else return this._parts.urn?this._parts.path=g?o.recodeUrnPath(g):"":this._parts.path=g?o.recodePath(g):"/",this.build(!O),this},a.path=a.pathname,a.href=function(g,O){var D;if(g===void 0)return this.toString();this._string="",this._parts=o._parts();var w=g instanceof o,x=typeof g=="object"&&(g.hostname||g.path||g.pathname);if(g.nodeName){var H=o.getDomAttribute(g);g=g[H]||"",x=!1}if(!w&&x&&g.pathname!==void 0&&(g=g.toString()),typeof g=="string"||g instanceof String)this._parts=o.parse(String(g),this._parts);else if(w||x){var j=w?g._parts:g;for(D in j)D!=="query"&&h.call(this._parts,D)&&(this._parts[D]=j[D]);j.query&&this.query(j.query,!1)}else throw new TypeError("invalid input");return this.build(!O),this},a.is=function(g){var O=!1,D=!1,w=!1,x=!1,H=!1,j=!1,X=!1,tt=!this._parts.urn;switch(this._parts.hostname&&(tt=!1,D=o.ip4_expression.test(this._parts.hostname),w=o.ip6_expression.test(this._parts.hostname),O=D||w,x=!O,H=x&&i&&i.has(this._parts.hostname),j=x&&o.idn_expression.test(this._parts.hostname),X=x&&o.punycode_expression.test(this._parts.hostname)),g.toLowerCase()){case"relative":return tt;case"absolute":return!tt;case"domain":case"name":return x;case"sld":return H;case"ip":return O;case"ip4":case"ipv4":case"inet4":return D;case"ip6":case"ipv6":case"inet6":return w;case"idn":return j;case"url":return!this._parts.urn;case"urn":return!!this._parts.urn;case"punycode":return X}return null};var M=a.protocol,k=a.port,y=a.hostname;a.protocol=function(g,O){if(g&&(g=g.replace(/:(\/\/)?$/,""),!g.match(o.protocol_expression)))throw new TypeError('Protocol "'+g+`" contains characters other than [A-Z0-9.+-] or doesn't start with [A-Z]`);return M.call(this,g,O)},a.scheme=a.protocol,a.port=function(g,O){return this._parts.urn?g===void 0?"":this:(g!==void 0&&(g===0&&(g=null),g&&(g+="",g.charAt(0)===":"&&(g=g.substring(1)),o.ensureValidPort(g))),k.call(this,g,O))},a.hostname=function(g,O){if(this._parts.urn)return g===void 0?"":this;if(g!==void 0){var D={preventInvalidHostname:this._parts.preventInvalidHostname},w=o.parseHost(g,D);if(w!=="/")throw new TypeError('Hostname "'+g+'" contains characters other than [A-Z0-9.-]');g=D.hostname,this._parts.preventInvalidHostname&&o.ensureValidHostname(g,this._parts.protocol)}return y.call(this,g,O)},a.origin=function(g,O){if(this._parts.urn)return g===void 0?"":this;if(g===void 0){var D=this.protocol(),w=this.authority();return w?(D?D+"://":"")+this.authority():""}else{var x=o(g);return this.protocol(x.protocol()).authority(x.authority()).build(!O),this}},a.host=function(g,O){if(this._parts.urn)return g===void 0?"":this;if(g===void 0)return this._parts.hostname?o.buildHost(this._parts):"";var D=o.parseHost(g,this._parts);if(D!=="/")throw new TypeError('Hostname "'+g+'" contains characters other than [A-Z0-9.-]');return this.build(!O),this},a.authority=function(g,O){if(this._parts.urn)return g===void 0?"":this;if(g===void 0)return this._parts.hostname?o.buildAuthority(this._parts):"";var D=o.parseAuthority(g,this._parts);if(D!=="/")throw new TypeError('Hostname "'+g+'" contains characters other than [A-Z0-9.-]');return this.build(!O),this},a.userinfo=function(g,O){if(this._parts.urn)return g===void 0?"":this;if(g===void 0){var D=o.buildUserinfo(this._parts);return D&&D.substring(0,D.length-1)}else return g[g.length-1]!=="@"&&(g+="@"),o.parseUserinfo(g,this._parts),this.build(!O),this},a.resource=function(g,O){var D;return g===void 0?this.path()+this.search()+this.hash():(D=o.parse(g),this._parts.path=D.path,this._parts.query=D.query,this._parts.fragment=D.fragment,this.build(!O),this)},a.subdomain=function(g,O){if(this._parts.urn)return g===void 0?"":this;if(g===void 0){if(!this._parts.hostname||this.is("IP"))return"";var D=this._parts.hostname.length-this.domain().length-1;return this._parts.hostname.substring(0,D)||""}else{var w=this._parts.hostname.length-this.domain().length,x=this._parts.hostname.substring(0,w),H=new RegExp("^"+A(x));if(g&&g.charAt(g.length-1)!=="."&&(g+="."),g.indexOf(":")!==-1)throw new TypeError("Domains cannot contain colons");return g&&o.ensureValidHostname(g,this._parts.protocol),this._parts.hostname=this._parts.hostname.replace(H,g),this.build(!O),this}},a.domain=function(g,O){if(this._parts.urn)return g===void 0?"":this;if(typeof g=="boolean"&&(O=g,g=void 0),g===void 0){if(!this._parts.hostname||this.is("IP"))return"";var D=this._parts.hostname.match(/\./g);if(D&&D.length<2)return this._parts.hostname;var w=this._parts.hostname.length-this.tld(O).length-1;return w=this._parts.hostname.lastIndexOf(".",w-1)+1,this._parts.hostname.substring(w)||""}else{if(!g)throw new TypeError("cannot set domain empty");if(g.indexOf(":")!==-1)throw new TypeError("Domains cannot contain colons");if(o.ensureValidHostname(g,this._parts.protocol),!this._parts.hostname||this.is("IP"))this._parts.hostname=g;else{var x=new RegExp(A(this.domain())+"$");this._parts.hostname=this._parts.hostname.replace(x,g)}return this.build(!O),this}},a.tld=function(g,O){if(this._parts.urn)return g===void 0?"":this;if(typeof g=="boolean"&&(O=g,g=void 0),g===void 0){if(!this._parts.hostname||this.is("IP"))return"";var D=this._parts.hostname.lastIndexOf("."),w=this._parts.hostname.substring(D+1);return O!==!0&&i&&i.list[w.toLowerCase()]&&i.get(this._parts.hostname)||w}else{var x;if(g)if(g.match(/[^a-zA-Z0-9-]/))if(i&&i.is(g))x=new RegExp(A(this.tld())+"$"),this._parts.hostname=this._parts.hostname.replace(x,g);else throw new TypeError('TLD "'+g+'" contains characters other than [A-Z0-9]');else{if(!this._parts.hostname||this.is("IP"))throw new ReferenceError("cannot set TLD on non-domain host");x=new RegExp(A(this.tld())+"$"),this._parts.hostname=this._parts.hostname.replace(x,g)}else throw new TypeError("cannot set TLD empty");return this.build(!O),this}},a.directory=function(g,O){if(this._parts.urn)return g===void 0?"":this;if(g===void 0||g===!0){if(!this._parts.path&&!this._parts.hostname)return"";if(this._parts.path==="/")return"/";var D=this._parts.path.length-this.filename().length-1,w=this._parts.path.substring(0,D)||(this._parts.hostname?"/":"");return g?o.decodePath(w):w}else{var x=this._parts.path.length-this.filename().length,H=this._parts.path.substring(0,x),j=new RegExp("^"+A(H));return this.is("relative")||(g||(g="/"),g.charAt(0)!=="/"&&(g="/"+g)),g&&g.charAt(g.length-1)!=="/"&&(g+="/"),g=o.recodePath(g),this._parts.path=this._parts.path.replace(j,g),this.build(!O),this}},a.filename=function(g,O){if(this._parts.urn)return g===void 0?"":this;if(typeof g!="string"){if(!this._parts.path||this._parts.path==="/")return"";var D=this._parts.path.lastIndexOf("/"),w=this._parts.path.substring(D+1);return g?o.decodePathSegment(w):w}else{var x=!1;g.charAt(0)==="/"&&(g=g.substring(1)),g.match(/\.?\//)&&(x=!0);var H=new RegExp(A(this.filename())+"$");return g=o.recodePath(g),this._parts.path=this._parts.path.replace(H,g),x?this.normalizePath(O):this.build(!O),this}},a.suffix=function(g,O){if(this._parts.urn)return g===void 0?"":this;if(g===void 0||g===!0){if(!this._parts.path||this._parts.path==="/")return"";var D=this.filename(),w=D.lastIndexOf("."),x,H;return w===-1?"":(x=D.substring(w+1),H=/^[a-z0-9%]+$/i.test(x)?x:"",g?o.decodePathSegment(H):H)}else{g.charAt(0)==="."&&(g=g.substring(1));var j=this.suffix(),X;if(j)g?X=new RegExp(A(j)+"$"):X=new RegExp(A("."+j)+"$");else{if(!g)return this;this._parts.path+="."+o.recodePath(g)}return X&&(g=o.recodePath(g),this._parts.path=this._parts.path.replace(X,g)),this.build(!O),this}},a.segment=function(g,O,D){var w=this._parts.urn?":":"/",x=this.path(),H=x.substring(0,1)==="/",j=x.split(w);if(g!==void 0&&typeof g!="number"&&(D=O,O=g,g=void 0),g!==void 0&&typeof g!="number")throw new Error('Bad segment "'+g+'", must be 0-based integer');if(H&&j.shift(),g<0&&(g=Math.max(j.length+g,0)),O===void 0)return g===void 0?j:j[g];if(g===null||j[g]===void 0)if(f(O)){j=[];for(var X=0,tt=O.length;X<tt;X++)!O[X].length&&(!j.length||!j[j.length-1].length)||(j.length&&!j[j.length-1].length&&j.pop(),j.push(I(O[X])))}else(O||typeof O=="string")&&(O=I(O),j[j.length-1]===""?j[j.length-1]=O:j.push(O));else O?j[g]=I(O):j.splice(g,1);return H&&j.unshift(""),this.path(j.join(w),D)},a.segmentCoded=function(g,O,D){var w,x,H;if(typeof g!="number"&&(D=O,O=g,g=void 0),O===void 0){if(w=this.segment(g,O,D),!f(w))w=w!==void 0?o.decode(w):void 0;else for(x=0,H=w.length;x<H;x++)w[x]=o.decode(w[x]);return w}if(!f(O))O=typeof O=="string"||O instanceof String?o.encode(O):O;else for(x=0,H=O.length;x<H;x++)O[x]=o.encode(O[x]);return this.segment(g,O,D)};var c=a.query;return a.query=function(g,O){if(g===!0)return o.parseQuery(this._parts.query,this._parts.escapeQuerySpace);if(typeof g=="function"){var D=o.parseQuery(this._parts.query,this._parts.escapeQuerySpace),w=g.call(this,D);return this._parts.query=o.buildQuery(w||D,this._parts.duplicateQueryParameters,this._parts.escapeQuerySpace),this.build(!O),this}else return g!==void 0&&typeof g!="string"?(this._parts.query=o.buildQuery(g,this._parts.duplicateQueryParameters,this._parts.escapeQuerySpace),this.build(!O),this):c.call(this,g,O)},a.setQuery=function(g,O,D){var w=o.parseQuery(this._parts.query,this._parts.escapeQuerySpace);if(typeof g=="string"||g instanceof String)w[g]=O!==void 0?O:null;else if(typeof g=="object")for(var x in g)h.call(g,x)&&(w[x]=g[x]);else throw new TypeError("URI.addQuery() accepts an object, string as the name parameter");return this._parts.query=o.buildQuery(w,this._parts.duplicateQueryParameters,this._parts.escapeQuerySpace),typeof g!="string"&&(D=O),this.build(!D),this},a.addQuery=function(g,O,D){var w=o.parseQuery(this._parts.query,this._parts.escapeQuerySpace);return o.addQuery(w,g,O===void 0?null:O),this._parts.query=o.buildQuery(w,this._parts.duplicateQueryParameters,this._parts.escapeQuerySpace),typeof g!="string"&&(D=O),this.build(!D),this},a.removeQuery=function(g,O,D){var w=o.parseQuery(this._parts.query,this._parts.escapeQuerySpace);return o.removeQuery(w,g,O),this._parts.query=o.buildQuery(w,this._parts.duplicateQueryParameters,this._parts.escapeQuerySpace),typeof g!="string"&&(D=O),this.build(!D),this},a.hasQuery=function(g,O,D){var w=o.parseQuery(this._parts.query,this._parts.escapeQuerySpace);return o.hasQuery(w,g,O,D)},a.setSearch=a.setQuery,a.addSearch=a.addQuery,a.removeSearch=a.removeQuery,a.hasSearch=a.hasQuery,a.normalize=function(){return this._parts.urn?this.normalizeProtocol(!1).normalizePath(!1).normalizeQuery(!1).normalizeFragment(!1).build():this.normalizeProtocol(!1).normalizeHostname(!1).normalizePort(!1).normalizePath(!1).normalizeQuery(!1).normalizeFragment(!1).build()},a.normalizeProtocol=function(g){return typeof this._parts.protocol=="string"&&(this._parts.protocol=this._parts.protocol.toLowerCase(),this.build(!g)),this},a.normalizeHostname=function(g){return this._parts.hostname&&(this.is("IDN")&&t?this._parts.hostname=t.toASCII(this._parts.hostname):this.is("IPv6")&&e&&(this._parts.hostname=e.best(this._parts.hostname)),this._parts.hostname=this._parts.hostname.toLowerCase(),this.build(!g)),this},a.normalizePort=function(g){return typeof this._parts.protocol=="string"&&this._parts.port===o.defaultPorts[this._parts.protocol]&&(this._parts.port=null,this.build(!g)),this},a.normalizePath=function(g){var O=this._parts.path;if(!O)return this;if(this._parts.urn)return this._parts.path=o.recodeUrnPath(this._parts.path),this.build(!g),this;if(this._parts.path==="/")return this;O=o.recodePath(O);var D,w="",x,H;for(O.charAt(0)!=="/"&&(D=!0,O="/"+O),(O.slice(-3)==="/.."||O.slice(-2)==="/.")&&(O+="/"),O=O.replace(/(\/(\.\/)+)|(\/\.$)/g,"/").replace(/\/{2,}/g,"/"),D&&(w=O.substring(1).match(/^(\.\.\/)+/)||"",w&&(w=w[0]));x=O.search(/\/\.\.(\/|$)/),x!==-1;){if(x===0){O=O.substring(3);continue}H=O.substring(0,x).lastIndexOf("/"),H===-1&&(H=x),O=O.substring(0,H)+O.substring(x+3)}return D&&this.is("relative")&&(O=w+O.substring(1)),this._parts.path=O,this.build(!g),this},a.normalizePathname=a.normalizePath,a.normalizeQuery=function(g){return typeof this._parts.query=="string"&&(this._parts.query.length?this.query(o.parseQuery(this._parts.query,this._parts.escapeQuerySpace)):this._parts.query=null,this.build(!g)),this},a.normalizeFragment=function(g){return this._parts.fragment||(this._parts.fragment=null,this.build(!g)),this},a.normalizeSearch=a.normalizeQuery,a.normalizeHash=a.normalizeFragment,a.iso8859=function(){var g=o.encode,O=o.decode;o.encode=escape,o.decode=decodeURIComponent;try{this.normalize()}finally{o.encode=g,o.decode=O}return this},a.unicode=function(){var g=o.encode,O=o.decode;o.encode=N,o.decode=unescape;try{this.normalize()}finally{o.encode=g,o.decode=O}return this},a.readable=function(){var g=this.clone();g.username("").password("").normalize();var O="";if(g._parts.protocol&&(O+=g._parts.protocol+"://"),g._parts.hostname&&(g.is("punycode")&&t?(O+=t.toUnicode(g._parts.hostname),g._parts.port&&(O+=":"+g._parts.port)):O+=g.host()),g._parts.hostname&&g._parts.path&&g._parts.path.charAt(0)!=="/"&&(O+="/"),O+=g.path(!0),g._parts.query){for(var D="",w=0,x=g._parts.query.split("&"),H=x.length;w<H;w++){var j=(x[w]||"").split("=");D+="&"+o.decodeQuery(j[0],this._parts.escapeQuerySpace).replace(/&/g,"%26"),j[1]!==void 0&&(D+="="+o.decodeQuery(j[1],this._parts.escapeQuerySpace).replace(/&/g,"%26"))}O+="?"+D.substring(1)}return O+=o.decodeQuery(g.hash(),!0),O},a.absoluteTo=function(g){var O=this.clone(),D=["protocol","username","password","hostname","port"],w,x,H;if(this._parts.urn)throw new Error("URNs do not have any generally defined hierarchical components");if(g instanceof o||(g=new o(g)),O._parts.protocol||(O._parts.protocol=g._parts.protocol,this._parts.hostname))return O;for(x=0;H=D[x];x++)O._parts[H]=g._parts[H];return O._parts.path?(O._parts.path.substring(-2)===".."&&(O._parts.path+="/"),O.path().charAt(0)!=="/"&&(w=g.directory(),w=w||(g.path().indexOf("/")===0?"/":""),O._parts.path=(w?w+"/":"")+O._parts.path,O.normalizePath())):(O._parts.path=g._parts.path,O._parts.query||(O._parts.query=g._parts.query)),O.build(),O},a.relativeTo=function(g){var O=this.clone().normalize(),D,w,x,H,j;if(O._parts.urn)throw new Error("URNs do not have any generally defined hierarchical components");if(g=new o(g).normalize(),D=O._parts,w=g._parts,H=O.path(),j=g.path(),H.charAt(0)!=="/")throw new Error("URI is already relative");if(j.charAt(0)!=="/")throw new Error("Cannot calculate a URI relative to another relative URI");if(D.protocol===w.protocol&&(D.protocol=null),D.username!==w.username||D.password!==w.password||D.protocol!==null||D.username!==null||D.password!==null)return O.build();if(D.hostname===w.hostname&&D.port===w.port)D.hostname=null,D.port=null;else return O.build();if(H===j)return D.path="",O.build();if(x=o.commonPath(H,j),!x)return O.build();var X=w.path.substring(x.length).replace(/[^\/]*$/,"").replace(/.*?\//g,"../");return D.path=X+D.path.substring(x.length)||"./",O.build()},a.equals=function(g){var O=this.clone(),D=new o(g),w={},x={},H={},j,X,tt;if(O.normalize(),D.normalize(),O.toString()===D.toString())return!0;if(j=O.query(),X=D.query(),O.query(""),D.query(""),O.toString()!==D.toString()||j.length!==X.length)return!1;w=o.parseQuery(j,this._parts.escapeQuerySpace),x=o.parseQuery(X,this._parts.escapeQuerySpace);for(tt in w)if(h.call(w,tt)){if(f(w[tt])){if(!R(w[tt],x[tt]))return!1}else if(w[tt]!==x[tt])return!1;H[tt]=!0}for(tt in x)if(h.call(x,tt)&&!H[tt])return!1;return!0},a.preventInvalidHostname=function(g){return this._parts.preventInvalidHostname=!!g,this},a.duplicateQueryParameters=function(g){return this._parts.duplicateQueryParameters=!!g,this},a.escapeQuerySpace=function(g){return this._parts.escapeQuerySpace=!!g,this},o})});function Tq(t){return(t.length===0||t[t.length-1]!=="/")&&(t=`${t}/`),t}var C2,g2=S(()=>{C2=Tq});function T2(t,e){if(t===null||typeof t!="object")return t;e=Z(e,!1);let i=new t.constructor;for(let n in t)if(t.hasOwnProperty(n)){let s=t[n];e&&(s=T2(s,e)),i[n]=s}return i}var qs,aE=S(()=>{Ft();qs=T2});function N2(t,e,i){i=Z(i,!1);let n={},s=m(t),o=m(e),r,a,h;if(s)for(r in t)t.hasOwnProperty(r)&&(a=t[r],o&&i&&typeof a=="object"&&e.hasOwnProperty(r)?(h=e[r],typeof h=="object"?n[r]=N2(a,h,i):n[r]=a):n[r]=a);if(o)for(r in e)e.hasOwnProperty(r)&&!n.hasOwnProperty(r)&&(h=e[r],n[r]=h);return n}var es,KA=S(()=>{Ft();mt();es=N2});function Nq(){let t,e,i=new Promise(function(n,s){t=n,e=s});return{resolve:t,reject:e,promise:i}}var El,m0=S(()=>{El=Nq});function f0(t,e){let i;return typeof document<"u"&&(i=document),f0._implementation(t,e,i)}var F2,AE,E0=S(()=>{F2=co(oc(),1);Ft();mt();Ot();f0._implementation=function(t,e,i){if(!m(t))throw new Y("relative uri is required.");if(!m(e)){if(typeof i>"u")return t;e=Z(i.baseURI,i.location.href)}let n=new F2.default(t);return n.scheme()!==""?n.toString():n.absoluteTo(e).toString()};AE=f0});function Fq(t,e){if(!m(t))throw new Y("uri is required.");let i="",n=t.lastIndexOf("/");return n!==-1&&(i=t.substring(0,n+1)),e&&(t=new b2.default(t),t.query().length!==0&&(i+=`?${t.query()}`),t.fragment().length!==0&&(i+=`#${t.fragment()}`)),i}var b2,Y2,V2=S(()=>{b2=co(oc(),1);mt();Ot();Y2=Fq});function bq(t){if(!m(t))throw new Y("uri is required.");let e=new S2.default(t);e.normalize();let i=e.path(),n=i.lastIndexOf("/");return n!==-1&&(i=i.substr(n+1)),n=i.lastIndexOf("."),n===-1?i="":i=i.substr(n+1),i}var S2,O2,B2=S(()=>{S2=co(oc(),1);mt();Ot();O2=bq});function Yq(t,e,i){m(e)||(e=t.width),m(i)||(i=t.height);let n=G2[e];m(n)||(n={},G2[e]=n);let s=n[i];if(!m(s)){let o=document.createElement("canvas");o.width=e,o.height=i,s=o.getContext("2d",{willReadFrequently:!0}),s.globalCompositeOperation="copy",n[i]=s}return s.drawImage(t,0,0,e,i),s.getImageData(0,0,e,i).data}var G2,_0,W2=S(()=>{mt();G2={};_0=Yq});function Sq(t){return p.typeOf.string("uri",t),Vq.test(t)}var Vq,RZ,R0=S(()=>{ae();Vq=/^blob:/i;RZ=Sq});function Oq(t){m(aA)||(aA=document.createElement("a")),aA.href=window.location.href;let e=aA.host,i=aA.protocol;return aA.href=t,aA.href=aA.href,i!==aA.protocol||e!==aA.host}var aA,ZZ,Z0=S(()=>{mt();ZZ=Oq});function Gq(t){return p.typeOf.string("uri",t),Bq.test(t)}var Bq,IZ,I0=S(()=>{ae();Bq=/^data:/i;IZ=Gq});function Wq(t){let e=document.createElement("script");return e.async=!0,e.src=t,new Promise((i,n)=>{window.crossOriginIsolated&&e.setAttribute("crossorigin","anonymous");let s=document.getElementsByTagName("head")[0];e.onload=function(){e.onload=void 0,s.removeChild(e),i()},e.onerror=function(o){n(o)},s.appendChild(e)})}var D2,U2=S(()=>{D2=Wq});function Dq(t){if(!m(t))throw new Y("obj is required.");let e="";for(let i in t)if(t.hasOwnProperty(i)){let n=t[i],s=`${encodeURIComponent(i)}=`;if(Array.isArray(n))for(let o=0,r=n.length;o<r;++o)e+=`${s+encodeURIComponent(n[o])}&`;else e+=`${s+encodeURIComponent(n)}&`}return e=e.slice(0,-1),e}var M2,Q2=S(()=>{mt();Ot();M2=Dq});function Uq(t){if(!m(t))throw new Y("queryString is required.");let e={};if(t==="")return e;let i=t.replace(/\+/g,"%20").split(/[&;]/);for(let n=0,s=i.length;n<s;++n){let o=i[n].split("="),r=decodeURIComponent(o[0]),a=o[1];m(a)?a=decodeURIComponent(a):a="";let h=e[r];typeof h=="string"?e[r]=[h,a]:Array.isArray(h)?h.push(a):e[r]=a}return e}var k2,L2=S(()=>{mt();Ot();k2=Uq});var Mq,Mn,pZ=S(()=>{Mq={UNISSUED:0,ISSUED:1,ACTIVE:2,RECEIVED:3,CANCELLED:4,FAILED:5},Mn=Object.freeze(Mq)});var Qq,y2,w2=S(()=>{Qq={TERRAIN:0,IMAGERY:1,TILES3D:2,OTHER:3},y2=Object.freeze(Qq)});function uZ(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.throttleByServer,!1),i=Z(t.throttle,!1);this.url=t.url,this.requestFunction=t.requestFunction,this.cancelFunction=t.cancelFunction,this.priorityFunction=t.priorityFunction,this.priority=Z(t.priority,0),this.throttle=i,this.throttleByServer=e,this.type=Z(t.type,y2.OTHER),this.serverKey=t.serverKey,this.state=Mn.UNISSUED,this.deferred=void 0,this.cancelled=!1}var x2,P2=S(()=>{Ft();mt();pZ();w2();uZ.prototype.cancel=function(){this.cancelled=!0};uZ.prototype.clone=function(t){return m(t)?(t.url=this.url,t.requestFunction=this.requestFunction,t.cancelFunction=this.cancelFunction,t.priorityFunction=this.priorityFunction,t.priority=this.priority,t.throttle=this.throttle,t.throttleByServer=this.throttleByServer,t.type=this.type,t.serverKey=this.serverKey,t.state=Mn.UNISSUED,t.deferred=void 0,t.cancelled=!1,t):new uZ(this)};x2=uZ});function kq(t){let e={};if(!t)return e;let i=t.split(`\r
`);for(let n=0;n<i.length;++n){let s=i[n],o=s.indexOf(": ");if(o>0){let r=s.substring(0,o),a=s.substring(o+2);e[r]=a}}return e}var J2,j2=S(()=>{J2=kq});function H2(t,e,i){this.statusCode=t,this.response=e,this.responseHeaders=i,typeof this.responseHeaders=="string"&&(this.responseHeaders=J2(this.responseHeaders))}var hE,v2=S(()=>{mt();j2();H2.prototype.toString=function(){let t="Request has failed.";return m(this.statusCode)&&(t+=` Status Code: ${this.statusCode}`),t};hE=H2});function _l(t){p.typeOf.object("options",t),p.defined("options.comparator",t.comparator),this._comparator=t.comparator,this._array=[],this._length=0,this._maximumLength=void 0}function p0(t,e,i){let n=t[e];t[e]=t[i],t[i]=n}var z2,K2=S(()=>{ae();Ft();mt();Object.defineProperties(_l.prototype,{length:{get:function(){return this._length}},internalArray:{get:function(){return this._array}},maximumLength:{get:function(){return this._maximumLength},set:function(t){p.typeOf.number.greaterThanOrEquals("maximumLength",t,0);let e=this._length;if(t<e){let i=this._array;for(let n=t;n<e;++n)i[n]=void 0;this._length=t,i.length=t}this._maximumLength=t}},comparator:{get:function(){return this._comparator}}});_l.prototype.reserve=function(t){t=Z(t,this._length),this._array.length=t};_l.prototype.heapify=function(t){t=Z(t,0);let e=this._length,i=this._comparator,n=this._array,s=-1,o=!0;for(;o;){let r=2*(t+1),a=r-1;a<e&&i(n[a],n[t])<0?s=a:s=t,r<e&&i(n[r],n[s])<0&&(s=r),s!==t?(p0(n,s,t),t=s):o=!1}};_l.prototype.resort=function(){let t=this._length;for(let e=Math.ceil(t/2);e>=0;--e)this.heapify(e)};_l.prototype.insert=function(t){p.defined("element",t);let e=this._array,i=this._comparator,n=this._maximumLength,s=this._length++;for(s<e.length?e[s]=t:e.push(t);s!==0;){let r=Math.floor((s-1)/2);if(i(e[s],e[r])<0)p0(e,s,r),s=r;else break}let o;return m(n)&&this._length>n&&(o=e[n],this._length=n),o};_l.prototype.pop=function(t){if(t=Z(t,0),this._length===0)return;p.typeOf.number.lessThan("index",t,this._length);let e=this._array,i=e[t];return p0(e,t,--this._length),this.heapify(t),e[this._length]=void 0,i};z2=_l});function Lq(t,e){return t.priority-e.priority}function Bn(){}function X2(t){m(t.priorityFunction)&&(t.priority=t.priorityFunction())}function q2(t){return t.state===Mn.UNISSUED&&(t.state=Mn.ISSUED,t.deferred=El()),t.deferred.promise}function wq(t){return function(e){if(t.state===Mn.CANCELLED)return;let i=t.deferred;--Pi.numberOfActiveRequests,--XA[t.serverKey],gZ.raiseEvent(),t.state=Mn.RECEIVED,t.deferred=void 0,i.resolve(e)}}function xq(t){return function(e){t.state!==Mn.CANCELLED&&(++Pi.numberOfFailedRequests,--Pi.numberOfActiveRequests,--XA[t.serverKey],gZ.raiseEvent(e),t.state=Mn.FAILED,t.deferred.reject(e))}}function $2(t){let e=q2(t);return t.state=Mn.ACTIVE,AA.push(t),++Pi.numberOfActiveRequests,++Pi.numberOfActiveRequestsEver,++XA[t.serverKey],t.requestFunction().then(wq(t)).catch(xq(t)),e}function Rl(t){let e=t.state===Mn.ACTIVE;if(t.state=Mn.CANCELLED,++Pi.numberOfCancelledRequests,m(t.deferred)){let i=t.deferred;t.deferred=void 0,i.reject()}e&&(--Pi.numberOfActiveRequests,--XA[t.serverKey],++Pi.numberOfCancelledActiveRequests),m(t.cancelFunction)&&t.cancelFunction()}function Pq(){Bn.debugShowStatistics&&(Pi.numberOfActiveRequests===0&&Pi.lastNumberOfActiveRequests>0&&(Pi.numberOfAttemptedRequests>0&&(console.log(`Number of attempted requests: ${Pi.numberOfAttemptedRequests}`),Pi.numberOfAttemptedRequests=0),Pi.numberOfCancelledRequests>0&&(console.log(`Number of cancelled requests: ${Pi.numberOfCancelledRequests}`),Pi.numberOfCancelledRequests=0),Pi.numberOfCancelledActiveRequests>0&&(console.log(`Number of cancelled active requests: ${Pi.numberOfCancelledActiveRequests}`),Pi.numberOfCancelledActiveRequests=0),Pi.numberOfFailedRequests>0&&(console.log(`Number of failed requests: ${Pi.numberOfFailedRequests}`),Pi.numberOfFailedRequests=0)),Pi.lastNumberOfActiveRequests=Pi.numberOfActiveRequests)}var CZ,Pi,um,mo,AA,XA,yq,gZ,TZ,tW=S(()=>{CZ=co(oc(),1);ae();Ft();m0();mt();xi();K2();R0();I0();pZ();Pi={numberOfAttemptedRequests:0,numberOfActiveRequests:0,numberOfCancelledRequests:0,numberOfCancelledActiveRequests:0,numberOfFailedRequests:0,numberOfActiveRequestsEver:0,lastNumberOfActiveRequests:0},um=20,mo=new z2({comparator:Lq});mo.maximumLength=um;mo.reserve(um);AA=[],XA={},yq=typeof document<"u"?new CZ.default(document.location.href):new CZ.default,gZ=new We;Bn.maximumRequests=50;Bn.maximumRequestsPerServer=18;Bn.requestsByServer={};Bn.throttleRequests=!0;Bn.debugShowStatistics=!1;Bn.requestCompletedEvent=gZ;Object.defineProperties(Bn,{statistics:{get:function(){return Pi}},priorityHeapLength:{get:function(){return um},set:function(t){if(t<um)for(;mo.length>t;){let e=mo.pop();Rl(e)}um=t,mo.maximumLength=t,mo.reserve(t)}}});Bn.serverHasOpenSlots=function(t,e){e=Z(e,1);let i=Z(Bn.requestsByServer[t],Bn.maximumRequestsPerServer);return XA[t]+e<=i};Bn.heapHasOpenSlots=function(t){return mo.length+t<=um};Bn.update=function(){let t,e,i=0,n=AA.length;for(t=0;t<n;++t){if(e=AA[t],e.cancelled&&Rl(e),e.state!==Mn.ACTIVE){++i;continue}i>0&&(AA[t-i]=e)}AA.length-=i;let s=mo.internalArray,o=mo.length;for(t=0;t<o;++t)X2(s[t]);mo.resort();let r=Math.max(Bn.maximumRequests-AA.length,0),a=0;for(;a<r&&mo.length>0;){if(e=mo.pop(),e.cancelled){Rl(e);continue}if(e.throttleByServer&&!Bn.serverHasOpenSlots(e.serverKey)){Rl(e);continue}$2(e),++a}Pq()};Bn.getServerKey=function(t){p.typeOf.string("url",t);let e=new CZ.default(t);e.scheme()===""&&(e=e.absoluteTo(yq),e.normalize());let i=e.authority();/:/.test(i)||(i=`${i}:${e.scheme()==="https"?"443":"80"}`);let n=XA[i];return m(n)||(XA[i]=0),i};Bn.request=function(t){if(p.typeOf.object("request",t),p.typeOf.string("request.url",t.url),p.typeOf.func("request.requestFunction",t.requestFunction),IZ(t.url)||RZ(t.url))return gZ.raiseEvent(),t.state=Mn.RECEIVED,t.requestFunction();if(++Pi.numberOfAttemptedRequests,m(t.serverKey)||(t.serverKey=Bn.getServerKey(t.url)),Bn.throttleRequests&&t.throttleByServer&&!Bn.serverHasOpenSlots(t.serverKey))return;if(!Bn.throttleRequests||!t.throttle)return $2(t);if(AA.length>=Bn.maximumRequests)return;X2(t);let e=mo.insert(t);if(m(e)){if(e===t)return;Rl(e)}return q2(t)};Bn.clearForSpecs=function(){for(;mo.length>0;){let e=mo.pop();Rl(e)}let t=AA.length;for(let e=0;e<t;++e)Rl(AA[e]);AA.length=0,XA={},Pi.numberOfAttemptedRequests=0,Pi.numberOfActiveRequests=0,Pi.numberOfCancelledRequests=0,Pi.numberOfCancelledActiveRequests=0,Pi.numberOfFailedRequests=0,Pi.numberOfActiveRequestsEver=0,Pi.lastNumberOfActiveRequests=0};Bn.numberOfActiveRequestsByServer=function(t){return XA[t]};Bn.requestHeap=mo;TZ=Bn});function cE(t){this.name="RuntimeError",this.message=t;let e;try{throw new Error}catch(i){e=i.stack}this.stack=e}var ke,Ps=S(()=>{mt();m(Object.create)&&(cE.prototype=Object.create(Error.prototype),cE.prototype.constructor=cE);cE.prototype.toString=function(){let t=`${this.name}: ${this.message}`;return m(this.stack)&&(t+=`
${this.stack.toString()}`),t};ke=cE});function Jq(t){let e=new eW.default(t);e.normalize();let i=e.authority();if(i.length!==0){if(e.authority(i),i.indexOf("@")!==-1&&(i=i.split("@")[1]),i.indexOf(":")===-1){let n=e.scheme();if(n.length===0&&(n=window.location.protocol,n=n.substring(0,n.length-1)),n==="http")i+=":80";else if(n==="https")i+=":443";else return}return i}}var eW,lE,Cm,u0,iW=S(()=>{eW=co(oc(),1);mt();Ot();lE={},Cm={};lE.add=function(t,e){if(!m(t))throw new Y("host is required.");if(!m(e)||e<=0)throw new Y("port is required to be greater than 0.");let i=`${t.toLowerCase()}:${e}`;m(Cm[i])||(Cm[i]=!0)};lE.remove=function(t,e){if(!m(t))throw new Y("host is required.");if(!m(e)||e<=0)throw new Y("port is required to be greater than 0.");let i=`${t.toLowerCase()}:${e}`;m(Cm[i])&&delete Cm[i]};lE.contains=function(t){if(!m(t))throw new Y("url is required.");let e=Jq(t);return!!(m(e)&&m(Cm[e]))};lE.clear=function(){Cm={}};u0=lE});function le(t){t=Z(t,Z.EMPTY_OBJECT),typeof t=="string"&&(t={url:t}),p.typeOf.string("options.url",t.url),this._url=void 0,this._templateValues=hA(t.templateValues,{}),this._queryParameters=hA(t.queryParameters,{}),this.headers=hA(t.headers,{}),this.request=Z(t.request,new x2),this.proxy=t.proxy,this.retryCallback=t.retryCallback,this.retryAttempts=Z(t.retryAttempts,0),this._retryCount=0,Z(t.parseUrl,!0)?this.parseUrl(t.url,!0,!0):this._url=t.url,this._credits=t.credits}function hA(t,e){return m(t)?qs(t):e}function jq(t){return t.length===0?{}:t.indexOf("=")===-1?{[t]:void 0}:k2(t)}function FZ(t,e,i){if(!i)return es(t,e);let n=qs(t,!0);for(let s in e)if(e.hasOwnProperty(s)){let o=n[s],r=e[s];m(o)?(Array.isArray(o)||(o=n[s]=[o]),n[s]=o.concat(r)):n[s]=Array.isArray(r)?r.slice():r}return n}function Hq(t){let e=Object.keys(t);return e.length===0?"":e.length===1&&!m(t[e[0]])?`?${e[0]}`:`?${M2(t)}`}function C0(t){let e=t.resource,i=t.flipY,n=t.skipColorSpaceConversion,s=t.preferImageBitmap,o=e.request;o.url=e.url,o.requestFunction=function(){let a=!1;!e.isDataUri&&!e.isBlobUri&&(a=e.isCrossOriginUrl);let h=El();return le._Implementations.createImage(o,a,h,i,n,s),h.promise};let r=TZ.request(o);if(m(r))return r.catch(function(a){return o.state!==Mn.FAILED?Promise.reject(a):e.retryOnError(a).then(function(h){return h?(o.state=Mn.UNISSUED,o.deferred=void 0,C0({resource:e,flipY:i,skipColorSpaceConversion:n,preferImageBitmap:s})):Promise.reject(a)})})}function rW(t,e,i){let n={};n[e]=i,t.setQueryParameters(n);let s=t.request,o=t.url;s.url=o,s.requestFunction=function(){let a=El();return window[i]=function(h){a.resolve(h);try{delete window[i]}catch{window[i]=void 0}},le._Implementations.loadAndExecuteScript(o,i,a),a.promise};let r=TZ.request(s);if(m(r))return r.catch(function(a){return s.state!==Mn.FAILED?Promise.reject(a):t.retryOnError(a).then(function(h){return h?(s.state=Mn.UNISSUED,s.deferred=void 0,rW(t,e,i)):Promise.reject(a)})})}function g0(t){if(t.state===Mn.ISSUED||t.state===Mn.ACTIVE)throw new ke("The Resource is already being fetched.");t.state=Mn.UNISSUED,t.deferred=void 0}function NZ(t,e){let i=decodeURIComponent(e);return t?atob(i):i}function nW(t,e){let i=NZ(t,e),n=new ArrayBuffer(i.length),s=new Uint8Array(n);for(let o=0;o<i.length;o++)s[o]=i.charCodeAt(o);return n}function zq(t,e){e=Z(e,"");let i=t[1],n=!!t[2],s=t[3],o,r;switch(e){case"":case"text":return NZ(n,s);case"arraybuffer":return nW(n,s);case"blob":return o=nW(n,s),new Blob([o],{type:i});case"document":return r=new DOMParser,r.parseFromString(NZ(n,s),i);case"json":return JSON.parse(NZ(n,s));default:throw new Y(`Unhandled responseType: ${e}`)}}function Kq(t,e,i,n,s,o,r){fetch(t,{method:i,headers:s}).then(async a=>{if(!a.ok){let h={};a.headers.forEach((A,d)=>{h[d]=A}),o.reject(new hE(a.status,a,h));return}switch(e){case"text":o.resolve(a.text());break;case"json":o.resolve(a.json());break;default:o.resolve(new Uint8Array(await a.arrayBuffer()).buffer);break}}).catch(()=>{o.reject(new hE)})}var sW,oW,gm,vq,Xq,tn,Ia=S(()=>{sW=co(oc(),1);g2();ae();aE();KA();Ft();m0();mt();Ot();E0();V2();B2();W2();R0();Z0();I0();U2();_e();Q2();L2();P2();v2();tW();pZ();Ps();iW();oW=function(){try{let t=new XMLHttpRequest;return t.open("GET","#",!0),t.responseType="blob",t.responseType==="blob"}catch{return!1}}();le.createIfNeeded=function(t){return t instanceof le?t.getDerivedResource({request:t.request}):typeof t!="string"?t:new le({url:t})};le.supportsImageBitmapOptions=function(){return m(gm)?gm:typeof createImageBitmap!="function"?(gm=Promise.resolve(!1),gm):(gm=le.fetchBlob({url:"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAIAAACQd1PeAAAABGdBTUEAAE4g3rEiDgAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAADElEQVQI12Ng6GAAAAEUAIngE3ZiAAAAAElFTkSuQmCC"}).then(function(e){let i={imageOrientation:"flipY",premultiplyAlpha:"none",colorSpaceConversion:"none"};return Promise.all([createImageBitmap(e,i),createImageBitmap(e)])}).then(function(e){let i=_0(e[0]),n=_0(e[1]);return i[1]!==n[1]}).catch(function(){return!1}),gm)};Object.defineProperties(le,{isBlobSupported:{get:function(){return oW}}});Object.defineProperties(le.prototype,{queryParameters:{get:function(){return this._queryParameters}},templateValues:{get:function(){return this._templateValues}},url:{get:function(){return this.getUrlComponent(!0,!0)},set:function(t){this.parseUrl(t,!1,!1)}},extension:{get:function(){return O2(this._url)}},isDataUri:{get:function(){return IZ(this._url)}},isBlobUri:{get:function(){return RZ(this._url)}},isCrossOriginUrl:{get:function(){return ZZ(this._url)}},hasHeaders:{get:function(){return Object.keys(this.headers).length>0}},credits:{get:function(){return this._credits}}});le.prototype.toString=function(){return this.getUrlComponent(!0,!0)};le.prototype.parseUrl=function(t,e,i,n){let s=new sW.default(t),o=jq(s.query());this._queryParameters=e?FZ(o,this.queryParameters,i):o,s.search(""),s.fragment(""),m(n)&&s.scheme()===""&&(s=s.absoluteTo(AE(n))),this._url=s.toString()};le.prototype.getUrlComponent=function(t,e){if(this.isDataUri)return this._url;let i=this._url;t&&(i=`${i}${Hq(this.queryParameters)}`),i=i.replace(/%7B/g,"{").replace(/%7D/g,"}");let n=this._templateValues;return Object.keys(n).length>0&&(i=i.replace(/{(.*?)}/g,function(s,o){let r=n[o];return m(r)?encodeURIComponent(r):s})),e&&m(this.proxy)&&(i=this.proxy.getURL(i)),i};le.prototype.setQueryParameters=function(t,e){e?this._queryParameters=FZ(this._queryParameters,t,!1):this._queryParameters=FZ(t,this._queryParameters,!1)};le.prototype.appendQueryParameters=function(t){this._queryParameters=FZ(t,this._queryParameters,!0)};le.prototype.setTemplateValues=function(t,e){e?this._templateValues=es(this._templateValues,t):this._templateValues=es(t,this._templateValues)};le.prototype.getDerivedResource=function(t){let e=this.clone();if(e._retryCount=0,m(t.url)){let i=Z(t.preserveQueryParameters,!1);e.parseUrl(t.url,!0,i,this._url)}return m(t.queryParameters)&&(e._queryParameters=es(t.queryParameters,e.queryParameters)),m(t.templateValues)&&(e._templateValues=es(t.templateValues,e.templateValues)),m(t.headers)&&(e.headers=es(t.headers,e.headers)),m(t.proxy)&&(e.proxy=t.proxy),m(t.request)&&(e.request=t.request),m(t.retryCallback)&&(e.retryCallback=t.retryCallback),m(t.retryAttempts)&&(e.retryAttempts=t.retryAttempts),e};le.prototype.retryOnError=function(t){let e=this.retryCallback;if(typeof e!="function"||this._retryCount>=this.retryAttempts)return Promise.resolve(!1);let i=this;return Promise.resolve(e(this,t)).then(function(n){return++i._retryCount,n})};le.prototype.clone=function(t){return m(t)?(t._url=this._url,t._queryParameters=qs(this._queryParameters),t._templateValues=qs(this._templateValues),t.headers=qs(this.headers),t.proxy=this.proxy,t.retryCallback=this.retryCallback,t.retryAttempts=this.retryAttempts,t._retryCount=0,t.request=this.request.clone(),t):new le({url:this._url,queryParameters:this.queryParameters,templateValues:this.templateValues,headers:this.headers,proxy:this.proxy,retryCallback:this.retryCallback,retryAttempts:this.retryAttempts,request:this.request.clone(),parseUrl:!1,credits:m(this.credits)?this.credits.slice():void 0})};le.prototype.getBaseUri=function(t){return Y2(this.getUrlComponent(t),t)};le.prototype.appendForwardSlash=function(){this._url=C2(this._url)};le.prototype.fetchArrayBuffer=function(){return this.fetch({responseType:"arraybuffer"})};le.fetchArrayBuffer=function(t){return new le(t).fetchArrayBuffer()};le.prototype.fetchBlob=function(){return this.fetch({responseType:"blob"})};le.fetchBlob=function(t){return new le(t).fetchBlob()};le.prototype.fetchImage=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.preferImageBitmap,!1),i=Z(t.preferBlob,!1),n=Z(t.flipY,!1),s=Z(t.skipColorSpaceConversion,!1);if(g0(this.request),!oW||this.isDataUri||this.isBlobUri||!this.hasHeaders&&!i)return C0({resource:this,flipY:n,skipColorSpaceConversion:s,preferImageBitmap:e});let o=this.fetchBlob();if(!m(o))return;let r,a,h,A;return le.supportsImageBitmapOptions().then(function(d){return r=d,a=r&&e,o}).then(function(d){if(!m(d))return;if(A=d,a)return le.createImageBitmapFromBlob(d,{flipY:n,premultiplyAlpha:!1,skipColorSpaceConversion:s});let f=window.URL.createObjectURL(d);return h=new le({url:f}),C0({resource:h,flipY:n,skipColorSpaceConversion:s,preferImageBitmap:!1})}).then(function(d){if(m(d))return d.blob=A,a||window.URL.revokeObjectURL(h.url),d}).catch(function(d){return m(h)&&window.URL.revokeObjectURL(h.url),d.blob=A,Promise.reject(d)})};le.fetchImage=function(t){return new le(t).fetchImage({flipY:t.flipY,skipColorSpaceConversion:t.skipColorSpaceConversion,preferBlob:t.preferBlob,preferImageBitmap:t.preferImageBitmap})};le.prototype.fetchText=function(){return this.fetch({responseType:"text"})};le.fetchText=function(t){return new le(t).fetchText()};le.prototype.fetchJson=function(){let t=this.fetch({responseType:"text",headers:{Accept:"application/json,*/*;q=0.01"}});if(m(t))return t.then(function(e){if(m(e))return JSON.parse(e)})};le.fetchJson=function(t){return new le(t).fetchJson()};le.prototype.fetchXML=function(){return this.fetch({responseType:"document",overrideMimeType:"text/xml"})};le.fetchXML=function(t){return new le(t).fetchXML()};le.prototype.fetchJsonp=function(t){t=Z(t,"callback"),g0(this.request);let e;do e=`loadJsonp${L.nextRandomNumber().toString().substring(2,8)}`;while(m(window[e]));return rW(this,t,e)};le.fetchJsonp=function(t){return new le(t).fetchJsonp(t.callbackParameterName)};le.prototype._makeRequest=function(t){let e=this;g0(e.request);let i=e.request,n=e.url;i.url=n,i.requestFunction=function(){let o=t.responseType,r=es(t.headers,e.headers),a=t.overrideMimeType,h=t.method,A=t.data,d=El(),f=le._Implementations.loadWithXhr(n,o,h,A,r,d,a);return m(f)&&m(f.abort)&&(i.cancelFunction=function(){f.abort()}),d.promise};let s=TZ.request(i);if(m(s))return s.then(function(o){return i.cancelFunction=void 0,o}).catch(function(o){return i.cancelFunction=void 0,i.state!==Mn.FAILED?Promise.reject(o):e.retryOnError(o).then(function(r){return r?(i.state=Mn.UNISSUED,i.deferred=void 0,e.fetch(t)):Promise.reject(o)})})};vq=/^data:(.*?)(;base64)?,(.*)$/;le.prototype.fetch=function(t){return t=hA(t,{}),t.method="GET",this._makeRequest(t)};le.fetch=function(t){return new le(t).fetch({responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le.prototype.delete=function(t){return t=hA(t,{}),t.method="DELETE",this._makeRequest(t)};le.delete=function(t){return new le(t).delete({responseType:t.responseType,overrideMimeType:t.overrideMimeType,data:t.data})};le.prototype.head=function(t){return t=hA(t,{}),t.method="HEAD",this._makeRequest(t)};le.head=function(t){return new le(t).head({responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le.prototype.options=function(t){return t=hA(t,{}),t.method="OPTIONS",this._makeRequest(t)};le.options=function(t){return new le(t).options({responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le.prototype.post=function(t,e){return p.defined("data",t),e=hA(e,{}),e.method="POST",e.data=t,this._makeRequest(e)};le.post=function(t){return new le(t).post(t.data,{responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le.prototype.put=function(t,e){return p.defined("data",t),e=hA(e,{}),e.method="PUT",e.data=t,this._makeRequest(e)};le.put=function(t){return new le(t).put(t.data,{responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le.prototype.patch=function(t,e){return p.defined("data",t),e=hA(e,{}),e.method="PATCH",e.data=t,this._makeRequest(e)};le.patch=function(t){return new le(t).patch(t.data,{responseType:t.responseType,overrideMimeType:t.overrideMimeType})};le._Implementations={};le._Implementations.loadImageElement=function(t,e,i){let n=new Image;n.onload=function(){n.naturalWidth===0&&n.naturalHeight===0&&n.width===0&&n.height===0&&(n.width=300,n.height=150),i.resolve(n)},n.onerror=function(s){i.reject(s)},e&&(u0.contains(t)?n.crossOrigin="use-credentials":n.crossOrigin=""),n.src=t};le._Implementations.createImage=function(t,e,i,n,s,o){let r=t.url;le.supportsImageBitmapOptions().then(function(a){if(!(a&&o)){le._Implementations.loadImageElement(r,e,i);return}let h="blob",A="GET",d=El(),f=le._Implementations.loadWithXhr(r,h,A,void 0,void 0,d,void 0,void 0,void 0);return m(f)&&m(f.abort)&&(t.cancelFunction=function(){f.abort()}),d.promise.then(function(E){if(!m(E)){i.reject(new ke(`Successfully retrieved ${r} but it contained no content.`));return}return le.createImageBitmapFromBlob(E,{flipY:n,premultiplyAlpha:!1,skipColorSpaceConversion:s})}).then(function(E){i.resolve(E)})}).catch(function(a){i.reject(a)})};le.createImageBitmapFromBlob=function(t,e){return p.defined("options",e),p.typeOf.bool("options.flipY",e.flipY),p.typeOf.bool("options.premultiplyAlpha",e.premultiplyAlpha),p.typeOf.bool("options.skipColorSpaceConversion",e.skipColorSpaceConversion),createImageBitmap(t,{imageOrientation:e.flipY?"flipY":"none",premultiplyAlpha:e.premultiplyAlpha?"premultiply":"none",colorSpaceConversion:e.skipColorSpaceConversion?"none":"default"})};Xq=typeof XMLHttpRequest>"u";le._Implementations.loadWithXhr=function(t,e,i,n,s,o,r){let a=vq.exec(t);if(a!==null){o.resolve(zq(a,e));return}if(Xq){Kq(t,e,i,n,s,o,r);return}let h=new XMLHttpRequest;if(u0.contains(t)&&(h.withCredentials=!0),h.open(i,t,!0),m(r)&&m(h.overrideMimeType)&&h.overrideMimeType(r),m(s))for(let d in s)s.hasOwnProperty(d)&&h.setRequestHeader(d,s[d]);m(e)&&(h.responseType=e);let A=!1;return typeof t=="string"&&(A=t.indexOf("file://")===0||typeof window<"u"&&window.location.origin==="file://"),h.onload=function(){if((h.status<200||h.status>=300)&&!(A&&h.status===0)){o.reject(new hE(h.status,h.response,h.getAllResponseHeaders()));return}let d=h.response,f=h.responseType;if(i==="HEAD"||i==="OPTIONS"){let _=h.getAllResponseHeaders().trim().split(/[\r\n]+/),R={};_.forEach(function(I){let C=I.split(": "),N=C.shift();R[N]=C.join(": ")}),o.resolve(R);return}if(h.status===204)o.resolve(void 0);else if(m(d)&&(!m(e)||f===e))o.resolve(d);else if(e==="json"&&typeof d=="string")try{o.resolve(JSON.parse(d))}catch(E){o.reject(E)}else(f===""||f==="document")&&m(h.responseXML)&&h.responseXML.hasChildNodes()?o.resolve(h.responseXML):(f===""||f==="text")&&m(h.responseText)?o.resolve(h.responseText):o.reject(new ke("Invalid XMLHttpRequest response type."))},h.onerror=function(d){o.reject(new hE)},h.send(n),h};le._Implementations.loadAndExecuteScript=function(t,e,i){return D2(t,e).catch(function(n){i.reject(n)})};le._DefaultImplementations={};le._DefaultImplementations.createImage=le._Implementations.createImage;le._DefaultImplementations.loadWithXhr=le._Implementations.loadWithXhr;le._DefaultImplementations.loadAndExecuteScript=le._Implementations.loadAndExecuteScript;le.DEFAULT=Object.freeze(new le({url:typeof document>"u"?"":document.location.href.split("?")[0]}));tn=le});function mE(t){t=Z(t,Z.EMPTY_OBJECT),this._dates=void 0,this._samples=void 0,this._dateColumn=-1,this._xPoleWanderRadiansColumn=-1,this._yPoleWanderRadiansColumn=-1,this._ut1MinusUtcSecondsColumn=-1,this._xCelestialPoleOffsetRadiansColumn=-1,this._yCelestialPoleOffsetRadiansColumn=-1,this._taiMinusUtcSecondsColumn=-1,this._columnCount=0,this._lastIndex=-1,this._addNewLeapSeconds=Z(t.addNewLeapSeconds,!0),m(t.data)?aW(this,t.data):aW(this,{columnNames:["dateIso8601","modifiedJulianDateUtc","xPoleWanderRadians","yPoleWanderRadians","ut1MinusUtcSeconds","lengthOfDayCorrectionSeconds","xCelestialPoleOffsetRadians","yCelestialPoleOffsetRadians","taiMinusUtcSeconds"],samples:[]})}function qq(t,e){return Ze.compare(t.julianDate,e)}function aW(t,e){if(!m(e.columnNames))throw new ke("Error in loaded EOP data: The columnNames property is required.");if(!m(e.samples))throw new ke("Error in loaded EOP data: The samples property is required.");let i=e.columnNames.indexOf("modifiedJulianDateUtc"),n=e.columnNames.indexOf("xPoleWanderRadians"),s=e.columnNames.indexOf("yPoleWanderRadians"),o=e.columnNames.indexOf("ut1MinusUtcSeconds"),r=e.columnNames.indexOf("xCelestialPoleOffsetRadians"),a=e.columnNames.indexOf("yCelestialPoleOffsetRadians"),h=e.columnNames.indexOf("taiMinusUtcSeconds");if(i<0||n<0||s<0||o<0||r<0||a<0||h<0)throw new ke("Error in loaded EOP data: The columnNames property must include modifiedJulianDateUtc, xPoleWanderRadians, yPoleWanderRadians, ut1MinusUtcSeconds, xCelestialPoleOffsetRadians, yCelestialPoleOffsetRadians, and taiMinusUtcSeconds columns");let A=t._samples=e.samples,d=t._dates=[];t._dateColumn=i,t._xPoleWanderRadiansColumn=n,t._yPoleWanderRadiansColumn=s,t._ut1MinusUtcSecondsColumn=o,t._xCelestialPoleOffsetRadiansColumn=r,t._yCelestialPoleOffsetRadiansColumn=a,t._taiMinusUtcSecondsColumn=h,t._columnCount=e.columnNames.length,t._lastIndex=void 0;let f,E=t._addNewLeapSeconds;for(let _=0,R=A.length;_<R;_+=t._columnCount){let I=A[_+i],C=A[_+h],N=I+Fn.MODIFIED_JULIAN_DATE_DIFFERENCE,T=new Ze(N,C,Ei.TAI);if(d.push(T),E){if(C!==f&&m(f)){let b=Ze.leapSeconds,F=Go(b,T,qq);if(F<0){let B=new zi(T,C);b.splice(~F,0,B)}}f=C}}}function AW(t,e,i,n,s){let o=i*n;s.xPoleWander=e[o+t._xPoleWanderRadiansColumn],s.yPoleWander=e[o+t._yPoleWanderRadiansColumn],s.xPoleOffset=e[o+t._xCelestialPoleOffsetRadiansColumn],s.yPoleOffset=e[o+t._yCelestialPoleOffsetRadiansColumn],s.ut1MinusUtc=e[o+t._ut1MinusUtcSecondsColumn]}function dE(t,e,i){return e+t*(i-e)}function hW(t,e,i,n,s,o,r){let a=t._columnCount;if(o>e.length-1)return r.xPoleWander=0,r.yPoleWander=0,r.xPoleOffset=0,r.yPoleOffset=0,r.ut1MinusUtc=0,r;let h=e[s],A=e[o];if(h.equals(A)||n.equals(h))return AW(t,i,s,a,r),r;if(n.equals(A))return AW(t,i,o,a,r),r;let d=Ze.secondsDifference(n,h)/Ze.secondsDifference(A,h),f=s*a,E=o*a,_=i[f+t._ut1MinusUtcSecondsColumn],R=i[E+t._ut1MinusUtcSecondsColumn],I=R-_;if(I>.5||I<-.5){let C=i[f+t._taiMinusUtcSecondsColumn],N=i[E+t._taiMinusUtcSecondsColumn];C!==N&&(A.equals(n)?_=R:R-=N-C)}return r.xPoleWander=dE(d,i[f+t._xPoleWanderRadiansColumn],i[E+t._xPoleWanderRadiansColumn]),r.yPoleWander=dE(d,i[f+t._yPoleWanderRadiansColumn],i[E+t._yPoleWanderRadiansColumn]),r.xPoleOffset=dE(d,i[f+t._xCelestialPoleOffsetRadiansColumn],i[E+t._xCelestialPoleOffsetRadiansColumn]),r.yPoleOffset=dE(d,i[f+t._yCelestialPoleOffsetRadiansColumn],i[E+t._yCelestialPoleOffsetRadiansColumn]),r.ut1MinusUtc=dE(d,_,R),r}var cW,lW=S(()=>{sE();ae();Ft();mt();a0();Or();h0();Ia();Ps();AZ();hZ();mE.fromUrl=async function(t,e){p.defined("url",t),e=Z(e,Z.EMPTY_OBJECT);let i=tn.createIfNeeded(t),n;try{n=await i.fetchJson()}catch{throw new ke(`An error occurred while retrieving the EOP data from the URL ${i.url}.`)}return new mE({addNewLeapSeconds:e.addNewLeapSeconds,data:n})};mE.NONE=Object.freeze({compute:function(t,e){return m(e)?(e.xPoleWander=0,e.yPoleWander=0,e.xPoleOffset=0,e.yPoleOffset=0,e.ut1MinusUtc=0):e=new oE(0,0,0,0,0),e}});mE.prototype.compute=function(t,e){if(!m(this._samples))return;if(m(e)||(e=new oE(0,0,0,0,0)),this._samples.length===0)return e.xPoleWander=0,e.yPoleWander=0,e.xPoleOffset=0,e.yPoleOffset=0,e.ut1MinusUtc=0,e;let i=this._dates,n=this._lastIndex,s=0,o=0;if(m(n)){let a=i[n],h=i[n+1],A=Ze.lessThanOrEquals(a,t),d=!m(h),f=d||Ze.greaterThanOrEquals(h,t);if(A&&f)return s=n,!d&&h.equals(t)&&++s,o=s+1,hW(this,i,this._samples,t,s,o,e),e}let r=Go(i,t,Ze.compare,this._dateColumn);return r>=0?(r<i.length-1&&i[r+1].equals(t)&&++r,s=r,o=r):(o=~r,s=o-1,s<0&&(s=0)),this._lastIndex=s,hW(this,i,this._samples,t,s,o,e),e};cW=mE});function xt(t,e,i,n,s,o,r,a,h){this[0]=Z(t,0),this[1]=Z(n,0),this[2]=Z(r,0),this[3]=Z(e,0),this[4]=Z(s,0),this[5]=Z(a,0),this[6]=Z(i,0),this[7]=Z(o,0),this[8]=Z(h,0)}function n9(t){let e=0;for(let i=0;i<9;++i){let n=t[i];e+=n*n}return Math.sqrt(e)}function s9(t){let e=0;for(let i=0;i<3;++i){let n=t[xt.getElementIndex(F0[i],N0[i])];e+=2*n*n}return Math.sqrt(e)}function o9(t,e){let i=L.EPSILON15,n=0,s=1;for(let A=0;A<3;++A){let d=Math.abs(t[xt.getElementIndex(F0[A],N0[A])]);d>n&&(s=A,n=d)}let o=1,r=0,a=N0[s],h=F0[s];if(Math.abs(t[xt.getElementIndex(h,a)])>i){let A=t[xt.getElementIndex(h,h)],d=t[xt.getElementIndex(a,a)],f=t[xt.getElementIndex(h,a)],E=(A-d)/2/f,_;E<0?_=-1/(-E+Math.sqrt(1+E*E)):_=1/(E+Math.sqrt(1+E*E)),o=1/Math.sqrt(1+_*_),r=_*o}return e=xt.clone(xt.IDENTITY,e),e[xt.getElementIndex(a,a)]=e[xt.getElementIndex(h,h)]=o,e[xt.getElementIndex(h,a)]=r,e[xt.getElementIndex(a,h)]=-r,e}var $q,t9,T0,dW,e9,i9,N0,F0,bZ,mW,r9,lt,dn=S(()=>{Ht();ae();Ft();mt();Ot();_e();xt.packedLength=9;xt.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t[0],e[i++]=t[1],e[i++]=t[2],e[i++]=t[3],e[i++]=t[4],e[i++]=t[5],e[i++]=t[6],e[i++]=t[7],e[i++]=t[8],e};xt.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new xt),i[0]=t[e++],i[1]=t[e++],i[2]=t[e++],i[3]=t[e++],i[4]=t[e++],i[5]=t[e++],i[6]=t[e++],i[7]=t[e++],i[8]=t[e++],i};xt.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*9;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 9 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)xt.pack(t[s],e,s*9);return e};xt.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,9),t.length%9!==0)throw new Y("array length must be a multiple of 9.");let i=t.length;m(e)?e.length=i/9:e=new Array(i/9);for(let n=0;n<i;n+=9){let s=n/9;e[s]=xt.unpack(t,n,e[s])}return e};xt.clone=function(t,e){if(m(t))return m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e):new xt(t[0],t[3],t[6],t[1],t[4],t[7],t[2],t[5],t[8])};xt.fromArray=xt.unpack;xt.fromColumnMajorArray=function(t,e){return p.defined("values",t),xt.clone(t,e)};xt.fromRowMajorArray=function(t,e){return p.defined("values",t),m(e)?(e[0]=t[0],e[1]=t[3],e[2]=t[6],e[3]=t[1],e[4]=t[4],e[5]=t[7],e[6]=t[2],e[7]=t[5],e[8]=t[8],e):new xt(t[0],t[1],t[2],t[3],t[4],t[5],t[6],t[7],t[8])};xt.fromQuaternion=function(t,e){p.typeOf.object("quaternion",t);let i=t.x*t.x,n=t.x*t.y,s=t.x*t.z,o=t.x*t.w,r=t.y*t.y,a=t.y*t.z,h=t.y*t.w,A=t.z*t.z,d=t.z*t.w,f=t.w*t.w,E=i-r-A+f,_=2*(n-d),R=2*(s+h),I=2*(n+d),C=-i+r-A+f,N=2*(a-o),T=2*(s-h),b=2*(a+o),F=-i-r+A+f;return m(e)?(e[0]=E,e[1]=I,e[2]=T,e[3]=_,e[4]=C,e[5]=b,e[6]=R,e[7]=N,e[8]=F,e):new xt(E,_,R,I,C,N,T,b,F)};xt.fromHeadingPitchRoll=function(t,e){p.typeOf.object("headingPitchRoll",t);let i=Math.cos(-t.pitch),n=Math.cos(-t.heading),s=Math.cos(t.roll),o=Math.sin(-t.pitch),r=Math.sin(-t.heading),a=Math.sin(t.roll),h=i*n,A=-s*r+a*o*n,d=a*r+s*o*n,f=i*r,E=s*n+a*o*r,_=-a*n+s*o*r,R=-o,I=a*i,C=s*i;return m(e)?(e[0]=h,e[1]=f,e[2]=R,e[3]=A,e[4]=E,e[5]=I,e[6]=d,e[7]=_,e[8]=C,e):new xt(h,A,d,f,E,_,R,I,C)};xt.fromScale=function(t,e){return p.typeOf.object("scale",t),m(e)?(e[0]=t.x,e[1]=0,e[2]=0,e[3]=0,e[4]=t.y,e[5]=0,e[6]=0,e[7]=0,e[8]=t.z,e):new xt(t.x,0,0,0,t.y,0,0,0,t.z)};xt.fromUniformScale=function(t,e){return p.typeOf.number("scale",t),m(e)?(e[0]=t,e[1]=0,e[2]=0,e[3]=0,e[4]=t,e[5]=0,e[6]=0,e[7]=0,e[8]=t,e):new xt(t,0,0,0,t,0,0,0,t)};xt.fromCrossProduct=function(t,e){return p.typeOf.object("vector",t),m(e)?(e[0]=0,e[1]=t.z,e[2]=-t.y,e[3]=-t.z,e[4]=0,e[5]=t.x,e[6]=t.y,e[7]=-t.x,e[8]=0,e):new xt(0,-t.z,t.y,t.z,0,-t.x,-t.y,t.x,0)};xt.fromRotationX=function(t,e){p.typeOf.number("angle",t);let i=Math.cos(t),n=Math.sin(t);return m(e)?(e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=i,e[5]=n,e[6]=0,e[7]=-n,e[8]=i,e):new xt(1,0,0,0,i,-n,0,n,i)};xt.fromRotationY=function(t,e){p.typeOf.number("angle",t);let i=Math.cos(t),n=Math.sin(t);return m(e)?(e[0]=i,e[1]=0,e[2]=-n,e[3]=0,e[4]=1,e[5]=0,e[6]=n,e[7]=0,e[8]=i,e):new xt(i,0,n,0,1,0,-n,0,i)};xt.fromRotationZ=function(t,e){p.typeOf.number("angle",t);let i=Math.cos(t),n=Math.sin(t);return m(e)?(e[0]=i,e[1]=n,e[2]=0,e[3]=-n,e[4]=i,e[5]=0,e[6]=0,e[7]=0,e[8]=1,e):new xt(i,-n,0,n,i,0,0,0,1)};xt.toArray=function(t,e){return p.typeOf.object("matrix",t),m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e):[t[0],t[1],t[2],t[3],t[4],t[5],t[6],t[7],t[8]]};xt.getElementIndex=function(t,e){return p.typeOf.number.greaterThanOrEquals("row",e,0),p.typeOf.number.lessThanOrEquals("row",e,2),p.typeOf.number.greaterThanOrEquals("column",t,0),p.typeOf.number.lessThanOrEquals("column",t,2),t*3+e};xt.getColumn=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,2),p.typeOf.object("result",i);let n=e*3,s=t[n],o=t[n+1],r=t[n+2];return i.x=s,i.y=o,i.z=r,i};xt.setColumn=function(t,e,i,n){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,2),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=xt.clone(t,n);let s=e*3;return n[s]=i.x,n[s+1]=i.y,n[s+2]=i.z,n};xt.getRow=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,2),p.typeOf.object("result",i);let n=t[e],s=t[e+3],o=t[e+6];return i.x=n,i.y=s,i.z=o,i};xt.setRow=function(t,e,i,n){return p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,2),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=xt.clone(t,n),n[e]=i.x,n[e+3]=i.y,n[e+6]=i.z,n};$q=new l;xt.setScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i);let n=xt.getScale(t,$q),s=e.x/n.x,o=e.y/n.y,r=e.z/n.z;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*s,i[3]=t[3]*o,i[4]=t[4]*o,i[5]=t[5]*o,i[6]=t[6]*r,i[7]=t[7]*r,i[8]=t[8]*r,i};t9=new l;xt.setUniformScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i);let n=xt.getScale(t,t9),s=e/n.x,o=e/n.y,r=e/n.z;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*s,i[3]=t[3]*o,i[4]=t[4]*o,i[5]=t[5]*o,i[6]=t[6]*r,i[7]=t[7]*r,i[8]=t[8]*r,i};T0=new l;xt.getScale=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e.x=l.magnitude(l.fromElements(t[0],t[1],t[2],T0)),e.y=l.magnitude(l.fromElements(t[3],t[4],t[5],T0)),e.z=l.magnitude(l.fromElements(t[6],t[7],t[8],T0)),e};dW=new l;xt.getMaximumScale=function(t){return xt.getScale(t,dW),l.maximumComponent(dW)};e9=new l;xt.setRotation=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("result",i);let n=xt.getScale(t,e9);return i[0]=e[0]*n.x,i[1]=e[1]*n.x,i[2]=e[2]*n.x,i[3]=e[3]*n.y,i[4]=e[4]*n.y,i[5]=e[5]*n.y,i[6]=e[6]*n.z,i[7]=e[7]*n.z,i[8]=e[8]*n.z,i};i9=new l;xt.getRotation=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=xt.getScale(t,i9);return e[0]=t[0]/i.x,e[1]=t[1]/i.x,e[2]=t[2]/i.x,e[3]=t[3]/i.y,e[4]=t[4]/i.y,e[5]=t[5]/i.y,e[6]=t[6]/i.z,e[7]=t[7]/i.z,e[8]=t[8]/i.z,e};xt.multiply=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t[0]*e[0]+t[3]*e[1]+t[6]*e[2],s=t[1]*e[0]+t[4]*e[1]+t[7]*e[2],o=t[2]*e[0]+t[5]*e[1]+t[8]*e[2],r=t[0]*e[3]+t[3]*e[4]+t[6]*e[5],a=t[1]*e[3]+t[4]*e[4]+t[7]*e[5],h=t[2]*e[3]+t[5]*e[4]+t[8]*e[5],A=t[0]*e[6]+t[3]*e[7]+t[6]*e[8],d=t[1]*e[6]+t[4]*e[7]+t[7]*e[8],f=t[2]*e[6]+t[5]*e[7]+t[8]*e[8];return i[0]=n,i[1]=s,i[2]=o,i[3]=r,i[4]=a,i[5]=h,i[6]=A,i[7]=d,i[8]=f,i};xt.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]+e[0],i[1]=t[1]+e[1],i[2]=t[2]+e[2],i[3]=t[3]+e[3],i[4]=t[4]+e[4],i[5]=t[5]+e[5],i[6]=t[6]+e[6],i[7]=t[7]+e[7],i[8]=t[8]+e[8],i};xt.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]-e[0],i[1]=t[1]-e[1],i[2]=t[2]-e[2],i[3]=t[3]-e[3],i[4]=t[4]-e[4],i[5]=t[5]-e[5],i[6]=t[6]-e[6],i[7]=t[7]-e[7],i[8]=t[8]-e[8],i};xt.multiplyByVector=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("cartesian",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z,r=t[0]*n+t[3]*s+t[6]*o,a=t[1]*n+t[4]*s+t[7]*o,h=t[2]*n+t[5]*s+t[8]*o;return i.x=r,i.y=a,i.z=h,i};xt.multiplyByScalar=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3]*e,i[4]=t[4]*e,i[5]=t[5]*e,i[6]=t[6]*e,i[7]=t[7]*e,i[8]=t[8]*e,i};xt.multiplyByScale=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i),i[0]=t[0]*e.x,i[1]=t[1]*e.x,i[2]=t[2]*e.x,i[3]=t[3]*e.y,i[4]=t[4]*e.y,i[5]=t[5]*e.y,i[6]=t[6]*e.z,i[7]=t[7]*e.z,i[8]=t[8]*e.z,i};xt.multiplyByUniformScale=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3]*e,i[4]=t[4]*e,i[5]=t[5]*e,i[6]=t[6]*e,i[7]=t[7]*e,i[8]=t[8]*e,i};xt.negate=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=-t[0],e[1]=-t[1],e[2]=-t[2],e[3]=-t[3],e[4]=-t[4],e[5]=-t[5],e[6]=-t[6],e[7]=-t[7],e[8]=-t[8],e};xt.transpose=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[0],n=t[3],s=t[6],o=t[1],r=t[4],a=t[7],h=t[2],A=t[5],d=t[8];return e[0]=i,e[1]=n,e[2]=s,e[3]=o,e[4]=r,e[5]=a,e[6]=h,e[7]=A,e[8]=d,e};N0=[1,0,0],F0=[2,2,1];bZ=new xt,mW=new xt;xt.computeEigenDecomposition=function(t,e){p.typeOf.object("matrix",t);let i=L.EPSILON20,n=10,s=0,o=0;m(e)||(e={});let r=e.unitary=xt.clone(xt.IDENTITY,e.unitary),a=e.diagonal=xt.clone(t,e.diagonal),h=i*n9(a);for(;o<n&&s9(a)>h;)o9(a,bZ),xt.transpose(bZ,mW),xt.multiply(a,bZ,a),xt.multiply(mW,a,a),xt.multiply(r,bZ,r),++s>2&&(++o,s=0);return e};xt.abs=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=Math.abs(t[0]),e[1]=Math.abs(t[1]),e[2]=Math.abs(t[2]),e[3]=Math.abs(t[3]),e[4]=Math.abs(t[4]),e[5]=Math.abs(t[5]),e[6]=Math.abs(t[6]),e[7]=Math.abs(t[7]),e[8]=Math.abs(t[8]),e};xt.determinant=function(t){p.typeOf.object("matrix",t);let e=t[0],i=t[3],n=t[6],s=t[1],o=t[4],r=t[7],a=t[2],h=t[5],A=t[8];return e*(o*A-h*r)+s*(h*n-i*A)+a*(i*r-o*n)};xt.inverse=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[0],n=t[1],s=t[2],o=t[3],r=t[4],a=t[5],h=t[6],A=t[7],d=t[8],f=xt.determinant(t);if(Math.abs(f)<=L.EPSILON15)throw new Y("matrix is not invertible");e[0]=r*d-A*a,e[1]=A*s-n*d,e[2]=n*a-r*s,e[3]=h*a-o*d,e[4]=i*d-h*s,e[5]=o*s-i*a,e[6]=o*A-h*r,e[7]=h*n-i*A,e[8]=i*r-o*n;let E=1/f;return xt.multiplyByScalar(e,E,e)};r9=new xt;xt.inverseTranspose=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),xt.inverse(xt.transpose(t,r9),e)};xt.equals=function(t,e){return t===e||m(t)&&m(e)&&t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]&&t[4]===e[4]&&t[5]===e[5]&&t[6]===e[6]&&t[7]===e[7]&&t[8]===e[8]};xt.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t[0]-e[0])<=i&&Math.abs(t[1]-e[1])<=i&&Math.abs(t[2]-e[2])<=i&&Math.abs(t[3]-e[3])<=i&&Math.abs(t[4]-e[4])<=i&&Math.abs(t[5]-e[5])<=i&&Math.abs(t[6]-e[6])<=i&&Math.abs(t[7]-e[7])<=i&&Math.abs(t[8]-e[8])<=i};xt.IDENTITY=Object.freeze(new xt(1,0,0,0,1,0,0,0,1));xt.ZERO=Object.freeze(new xt(0,0,0,0,0,0,0,0,0));xt.COLUMN0ROW0=0;xt.COLUMN0ROW1=1;xt.COLUMN0ROW2=2;xt.COLUMN1ROW0=3;xt.COLUMN1ROW1=4;xt.COLUMN1ROW2=5;xt.COLUMN2ROW0=6;xt.COLUMN2ROW1=7;xt.COLUMN2ROW2=8;Object.defineProperties(xt.prototype,{length:{get:function(){return xt.packedLength}}});xt.prototype.clone=function(t){return xt.clone(this,t)};xt.prototype.equals=function(t){return xt.equals(this,t)};xt.equalsArray=function(t,e,i){return t[0]===e[i]&&t[1]===e[i+1]&&t[2]===e[i+2]&&t[3]===e[i+3]&&t[4]===e[i+4]&&t[5]===e[i+5]&&t[6]===e[i+6]&&t[7]===e[i+7]&&t[8]===e[i+8]};xt.prototype.equalsEpsilon=function(t,e){return xt.equalsEpsilon(this,t,e)};xt.prototype.toString=function(){return`(${this[0]}, ${this[3]}, ${this[6]})
(${this[1]}, ${this[4]}, ${this[7]})
(${this[2]}, ${this[5]}, ${this[8]})`};lt=xt});function yt(t,e,i,n,s,o,r,a,h,A,d,f,E,_,R,I){this[0]=Z(t,0),this[1]=Z(s,0),this[2]=Z(h,0),this[3]=Z(E,0),this[4]=Z(e,0),this[5]=Z(o,0),this[6]=Z(A,0),this[7]=Z(_,0),this[8]=Z(i,0),this[9]=Z(r,0),this[10]=Z(d,0),this[11]=Z(R,0),this[12]=Z(n,0),this[13]=Z(a,0),this[14]=Z(f,0),this[15]=Z(I,0)}var Tm,Nm,fE,a9,A9,b0,fW,h9,c9,l9,d9,m9,f9,E9,at,bi=S(()=>{Ht();Os();ae();Ft();mt();Ot();_e();dn();Ps();yt.packedLength=16;yt.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t[0],e[i++]=t[1],e[i++]=t[2],e[i++]=t[3],e[i++]=t[4],e[i++]=t[5],e[i++]=t[6],e[i++]=t[7],e[i++]=t[8],e[i++]=t[9],e[i++]=t[10],e[i++]=t[11],e[i++]=t[12],e[i++]=t[13],e[i++]=t[14],e[i]=t[15],e};yt.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new yt),i[0]=t[e++],i[1]=t[e++],i[2]=t[e++],i[3]=t[e++],i[4]=t[e++],i[5]=t[e++],i[6]=t[e++],i[7]=t[e++],i[8]=t[e++],i[9]=t[e++],i[10]=t[e++],i[11]=t[e++],i[12]=t[e++],i[13]=t[e++],i[14]=t[e++],i[15]=t[e],i};yt.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*16;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 16 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)yt.pack(t[s],e,s*16);return e};yt.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,16),t.length%16!==0)throw new Y("array length must be a multiple of 16.");let i=t.length;m(e)?e.length=i/16:e=new Array(i/16);for(let n=0;n<i;n+=16){let s=n/16;e[s]=yt.unpack(t,n,e[s])}return e};yt.clone=function(t,e){if(m(t))return m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e):new yt(t[0],t[4],t[8],t[12],t[1],t[5],t[9],t[13],t[2],t[6],t[10],t[14],t[3],t[7],t[11],t[15])};yt.fromArray=yt.unpack;yt.fromColumnMajorArray=function(t,e){return p.defined("values",t),yt.clone(t,e)};yt.fromRowMajorArray=function(t,e){return p.defined("values",t),m(e)?(e[0]=t[0],e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=t[1],e[5]=t[5],e[6]=t[9],e[7]=t[13],e[8]=t[2],e[9]=t[6],e[10]=t[10],e[11]=t[14],e[12]=t[3],e[13]=t[7],e[14]=t[11],e[15]=t[15],e):new yt(t[0],t[1],t[2],t[3],t[4],t[5],t[6],t[7],t[8],t[9],t[10],t[11],t[12],t[13],t[14],t[15])};yt.fromRotationTranslation=function(t,e,i){return p.typeOf.object("rotation",t),e=Z(e,l.ZERO),m(i)?(i[0]=t[0],i[1]=t[1],i[2]=t[2],i[3]=0,i[4]=t[3],i[5]=t[4],i[6]=t[5],i[7]=0,i[8]=t[6],i[9]=t[7],i[10]=t[8],i[11]=0,i[12]=e.x,i[13]=e.y,i[14]=e.z,i[15]=1,i):new yt(t[0],t[3],t[6],e.x,t[1],t[4],t[7],e.y,t[2],t[5],t[8],e.z,0,0,0,1)};yt.fromTranslationQuaternionRotationScale=function(t,e,i,n){p.typeOf.object("translation",t),p.typeOf.object("rotation",e),p.typeOf.object("scale",i),m(n)||(n=new yt);let s=i.x,o=i.y,r=i.z,a=e.x*e.x,h=e.x*e.y,A=e.x*e.z,d=e.x*e.w,f=e.y*e.y,E=e.y*e.z,_=e.y*e.w,R=e.z*e.z,I=e.z*e.w,C=e.w*e.w,N=a-f-R+C,T=2*(h-I),b=2*(A+_),F=2*(h+I),B=-a+f-R+C,U=2*(E-d),Q=2*(A-_),M=2*(E+d),k=-a-f+R+C;return n[0]=N*s,n[1]=F*s,n[2]=Q*s,n[3]=0,n[4]=T*o,n[5]=B*o,n[6]=M*o,n[7]=0,n[8]=b*r,n[9]=U*r,n[10]=k*r,n[11]=0,n[12]=t.x,n[13]=t.y,n[14]=t.z,n[15]=1,n};yt.fromTranslationRotationScale=function(t,e){return p.typeOf.object("translationRotationScale",t),yt.fromTranslationQuaternionRotationScale(t.translation,t.rotation,t.scale,e)};yt.fromTranslation=function(t,e){return p.typeOf.object("translation",t),yt.fromRotationTranslation(lt.IDENTITY,t,e)};yt.fromScale=function(t,e){return p.typeOf.object("scale",t),m(e)?(e[0]=t.x,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=t.y,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=t.z,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e):new yt(t.x,0,0,0,0,t.y,0,0,0,0,t.z,0,0,0,0,1)};yt.fromUniformScale=function(t,e){return p.typeOf.number("scale",t),m(e)?(e[0]=t,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=t,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=t,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e):new yt(t,0,0,0,0,t,0,0,0,0,t,0,0,0,0,1)};yt.fromRotation=function(t,e){return p.typeOf.object("rotation",t),m(e)||(e=new yt),e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=0,e[4]=t[3],e[5]=t[4],e[6]=t[5],e[7]=0,e[8]=t[6],e[9]=t[7],e[10]=t[8],e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e};Tm=new l,Nm=new l,fE=new l;yt.fromCamera=function(t,e){p.typeOf.object("camera",t);let i=t.position,n=t.direction,s=t.up;p.typeOf.object("camera.position",i),p.typeOf.object("camera.direction",n),p.typeOf.object("camera.up",s),l.normalize(n,Tm),l.normalize(l.cross(Tm,s,Nm),Nm),l.normalize(l.cross(Nm,Tm,fE),fE);let o=Nm.x,r=Nm.y,a=Nm.z,h=Tm.x,A=Tm.y,d=Tm.z,f=fE.x,E=fE.y,_=fE.z,R=i.x,I=i.y,C=i.z,N=o*-R+r*-I+a*-C,T=f*-R+E*-I+_*-C,b=h*R+A*I+d*C;return m(e)?(e[0]=o,e[1]=f,e[2]=-h,e[3]=0,e[4]=r,e[5]=E,e[6]=-A,e[7]=0,e[8]=a,e[9]=_,e[10]=-d,e[11]=0,e[12]=N,e[13]=T,e[14]=b,e[15]=1,e):new yt(o,r,a,N,f,E,_,T,-h,-A,-d,b,0,0,0,1)};yt.computePerspectiveFieldOfView=function(t,e,i,n,s){p.typeOf.number.greaterThan("fovY",t,0),p.typeOf.number.lessThan("fovY",t,Math.PI),p.typeOf.number.greaterThan("near",i,0),p.typeOf.number.greaterThan("far",n,0),p.typeOf.object("result",s);let r=1/Math.tan(t*.5),a=r/e,h=(n+i)/(i-n),A=2*n*i/(i-n);return s[0]=a,s[1]=0,s[2]=0,s[3]=0,s[4]=0,s[5]=r,s[6]=0,s[7]=0,s[8]=0,s[9]=0,s[10]=h,s[11]=-1,s[12]=0,s[13]=0,s[14]=A,s[15]=0,s};yt.computeOrthographicOffCenter=function(t,e,i,n,s,o,r){p.typeOf.number("left",t),p.typeOf.number("right",e),p.typeOf.number("bottom",i),p.typeOf.number("top",n),p.typeOf.number("near",s),p.typeOf.number("far",o),p.typeOf.object("result",r);let a=1/(e-t),h=1/(n-i),A=1/(o-s),d=-(e+t)*a,f=-(n+i)*h,E=-(o+s)*A;return a*=2,h*=2,A*=-2,r[0]=a,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=h,r[6]=0,r[7]=0,r[8]=0,r[9]=0,r[10]=A,r[11]=0,r[12]=d,r[13]=f,r[14]=E,r[15]=1,r};yt.computePerspectiveOffCenter=function(t,e,i,n,s,o,r){p.typeOf.number("left",t),p.typeOf.number("right",e),p.typeOf.number("bottom",i),p.typeOf.number("top",n),p.typeOf.number("near",s),p.typeOf.number("far",o),p.typeOf.object("result",r);let a=2*s/(e-t),h=2*s/(n-i),A=(e+t)/(e-t),d=(n+i)/(n-i),f=-(o+s)/(o-s),E=-1,_=-2*o*s/(o-s);return r[0]=a,r[1]=0,r[2]=0,r[3]=0,r[4]=0,r[5]=h,r[6]=0,r[7]=0,r[8]=A,r[9]=d,r[10]=f,r[11]=E,r[12]=0,r[13]=0,r[14]=_,r[15]=0,r};yt.computeInfinitePerspectiveOffCenter=function(t,e,i,n,s,o){p.typeOf.number("left",t),p.typeOf.number("right",e),p.typeOf.number("bottom",i),p.typeOf.number("top",n),p.typeOf.number("near",s),p.typeOf.object("result",o);let r=2*s/(e-t),a=2*s/(n-i),h=(e+t)/(e-t),A=(n+i)/(n-i),d=-1,f=-1,E=-2*s;return o[0]=r,o[1]=0,o[2]=0,o[3]=0,o[4]=0,o[5]=a,o[6]=0,o[7]=0,o[8]=h,o[9]=A,o[10]=d,o[11]=f,o[12]=0,o[13]=0,o[14]=E,o[15]=0,o};yt.computeViewportTransformation=function(t,e,i,n){m(n)||(n=new yt),t=Z(t,Z.EMPTY_OBJECT);let s=Z(t.x,0),o=Z(t.y,0),r=Z(t.width,0),a=Z(t.height,0);e=Z(e,0),i=Z(i,1);let h=r*.5,A=a*.5,d=(i-e)*.5,f=h,E=A,_=d,R=s+h,I=o+A,C=e+d,N=1;return n[0]=f,n[1]=0,n[2]=0,n[3]=0,n[4]=0,n[5]=E,n[6]=0,n[7]=0,n[8]=0,n[9]=0,n[10]=_,n[11]=0,n[12]=R,n[13]=I,n[14]=C,n[15]=N,n};yt.computeView=function(t,e,i,n,s){return p.typeOf.object("position",t),p.typeOf.object("direction",e),p.typeOf.object("up",i),p.typeOf.object("right",n),p.typeOf.object("result",s),s[0]=n.x,s[1]=i.x,s[2]=-e.x,s[3]=0,s[4]=n.y,s[5]=i.y,s[6]=-e.y,s[7]=0,s[8]=n.z,s[9]=i.z,s[10]=-e.z,s[11]=0,s[12]=-l.dot(n,t),s[13]=-l.dot(i,t),s[14]=l.dot(e,t),s[15]=1,s};yt.toArray=function(t,e){return p.typeOf.object("matrix",t),m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e):[t[0],t[1],t[2],t[3],t[4],t[5],t[6],t[7],t[8],t[9],t[10],t[11],t[12],t[13],t[14],t[15]]};yt.getElementIndex=function(t,e){return p.typeOf.number.greaterThanOrEquals("row",e,0),p.typeOf.number.lessThanOrEquals("row",e,3),p.typeOf.number.greaterThanOrEquals("column",t,0),p.typeOf.number.lessThanOrEquals("column",t,3),t*4+e};yt.getColumn=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,3),p.typeOf.object("result",i);let n=e*4,s=t[n],o=t[n+1],r=t[n+2],a=t[n+3];return i.x=s,i.y=o,i.z=r,i.w=a,i};yt.setColumn=function(t,e,i,n){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,3),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=yt.clone(t,n);let s=e*4;return n[s]=i.x,n[s+1]=i.y,n[s+2]=i.z,n[s+3]=i.w,n};yt.getRow=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,3),p.typeOf.object("result",i);let n=t[e],s=t[e+4],o=t[e+8],r=t[e+12];return i.x=n,i.y=s,i.z=o,i.w=r,i};yt.setRow=function(t,e,i,n){return p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,3),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=yt.clone(t,n),n[e]=i.x,n[e+4]=i.y,n[e+8]=i.z,n[e+12]=i.w,n};yt.setTranslation=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.object("translation",e),p.typeOf.object("result",i),i[0]=t[0],i[1]=t[1],i[2]=t[2],i[3]=t[3],i[4]=t[4],i[5]=t[5],i[6]=t[6],i[7]=t[7],i[8]=t[8],i[9]=t[9],i[10]=t[10],i[11]=t[11],i[12]=e.x,i[13]=e.y,i[14]=e.z,i[15]=t[15],i};a9=new l;yt.setScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i);let n=yt.getScale(t,a9),s=e.x/n.x,o=e.y/n.y,r=e.z/n.z;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*s,i[3]=t[3],i[4]=t[4]*o,i[5]=t[5]*o,i[6]=t[6]*o,i[7]=t[7],i[8]=t[8]*r,i[9]=t[9]*r,i[10]=t[10]*r,i[11]=t[11],i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i};A9=new l;yt.setUniformScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i);let n=yt.getScale(t,A9),s=e/n.x,o=e/n.y,r=e/n.z;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*s,i[3]=t[3],i[4]=t[4]*o,i[5]=t[5]*o,i[6]=t[6]*o,i[7]=t[7],i[8]=t[8]*r,i[9]=t[9]*r,i[10]=t[10]*r,i[11]=t[11],i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i};b0=new l;yt.getScale=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e.x=l.magnitude(l.fromElements(t[0],t[1],t[2],b0)),e.y=l.magnitude(l.fromElements(t[4],t[5],t[6],b0)),e.z=l.magnitude(l.fromElements(t[8],t[9],t[10],b0)),e};fW=new l;yt.getMaximumScale=function(t){return yt.getScale(t,fW),l.maximumComponent(fW)};h9=new l;yt.setRotation=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("result",i);let n=yt.getScale(t,h9);return i[0]=e[0]*n.x,i[1]=e[1]*n.x,i[2]=e[2]*n.x,i[3]=t[3],i[4]=e[3]*n.y,i[5]=e[4]*n.y,i[6]=e[5]*n.y,i[7]=t[7],i[8]=e[6]*n.z,i[9]=e[7]*n.z,i[10]=e[8]*n.z,i[11]=t[11],i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i};c9=new l;yt.getRotation=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=yt.getScale(t,c9);return e[0]=t[0]/i.x,e[1]=t[1]/i.x,e[2]=t[2]/i.x,e[3]=t[4]/i.y,e[4]=t[5]/i.y,e[5]=t[6]/i.y,e[6]=t[8]/i.z,e[7]=t[9]/i.z,e[8]=t[10]/i.z,e};yt.multiply=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t[0],s=t[1],o=t[2],r=t[3],a=t[4],h=t[5],A=t[6],d=t[7],f=t[8],E=t[9],_=t[10],R=t[11],I=t[12],C=t[13],N=t[14],T=t[15],b=e[0],F=e[1],B=e[2],U=e[3],Q=e[4],M=e[5],k=e[6],y=e[7],c=e[8],g=e[9],O=e[10],D=e[11],w=e[12],x=e[13],H=e[14],j=e[15],X=n*b+a*F+f*B+I*U,tt=s*b+h*F+E*B+C*U,G=o*b+A*F+_*B+N*U,It=r*b+d*F+R*B+T*U,gt=n*Q+a*M+f*k+I*y,Yt=s*Q+h*M+E*k+C*y,Ut=o*Q+A*M+_*k+N*y,Ct=r*Q+d*M+R*k+T*y,zt=n*c+a*g+f*O+I*D,kt=s*c+h*g+E*O+C*D,Jt=o*c+A*g+_*O+N*D,Wt=r*c+d*g+R*O+T*D,bt=n*w+a*x+f*H+I*j,ee=s*w+h*x+E*H+C*j,ce=o*w+A*x+_*H+N*j,je=r*w+d*x+R*H+T*j;return i[0]=X,i[1]=tt,i[2]=G,i[3]=It,i[4]=gt,i[5]=Yt,i[6]=Ut,i[7]=Ct,i[8]=zt,i[9]=kt,i[10]=Jt,i[11]=Wt,i[12]=bt,i[13]=ee,i[14]=ce,i[15]=je,i};yt.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]+e[0],i[1]=t[1]+e[1],i[2]=t[2]+e[2],i[3]=t[3]+e[3],i[4]=t[4]+e[4],i[5]=t[5]+e[5],i[6]=t[6]+e[6],i[7]=t[7]+e[7],i[8]=t[8]+e[8],i[9]=t[9]+e[9],i[10]=t[10]+e[10],i[11]=t[11]+e[11],i[12]=t[12]+e[12],i[13]=t[13]+e[13],i[14]=t[14]+e[14],i[15]=t[15]+e[15],i};yt.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]-e[0],i[1]=t[1]-e[1],i[2]=t[2]-e[2],i[3]=t[3]-e[3],i[4]=t[4]-e[4],i[5]=t[5]-e[5],i[6]=t[6]-e[6],i[7]=t[7]-e[7],i[8]=t[8]-e[8],i[9]=t[9]-e[9],i[10]=t[10]-e[10],i[11]=t[11]-e[11],i[12]=t[12]-e[12],i[13]=t[13]-e[13],i[14]=t[14]-e[14],i[15]=t[15]-e[15],i};yt.multiplyTransformation=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t[0],s=t[1],o=t[2],r=t[4],a=t[5],h=t[6],A=t[8],d=t[9],f=t[10],E=t[12],_=t[13],R=t[14],I=e[0],C=e[1],N=e[2],T=e[4],b=e[5],F=e[6],B=e[8],U=e[9],Q=e[10],M=e[12],k=e[13],y=e[14],c=n*I+r*C+A*N,g=s*I+a*C+d*N,O=o*I+h*C+f*N,D=n*T+r*b+A*F,w=s*T+a*b+d*F,x=o*T+h*b+f*F,H=n*B+r*U+A*Q,j=s*B+a*U+d*Q,X=o*B+h*U+f*Q,tt=n*M+r*k+A*y+E,G=s*M+a*k+d*y+_,It=o*M+h*k+f*y+R;return i[0]=c,i[1]=g,i[2]=O,i[3]=0,i[4]=D,i[5]=w,i[6]=x,i[7]=0,i[8]=H,i[9]=j,i[10]=X,i[11]=0,i[12]=tt,i[13]=G,i[14]=It,i[15]=1,i};yt.multiplyByMatrix3=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("rotation",e),p.typeOf.object("result",i);let n=t[0],s=t[1],o=t[2],r=t[4],a=t[5],h=t[6],A=t[8],d=t[9],f=t[10],E=e[0],_=e[1],R=e[2],I=e[3],C=e[4],N=e[5],T=e[6],b=e[7],F=e[8],B=n*E+r*_+A*R,U=s*E+a*_+d*R,Q=o*E+h*_+f*R,M=n*I+r*C+A*N,k=s*I+a*C+d*N,y=o*I+h*C+f*N,c=n*T+r*b+A*F,g=s*T+a*b+d*F,O=o*T+h*b+f*F;return i[0]=B,i[1]=U,i[2]=Q,i[3]=0,i[4]=M,i[5]=k,i[6]=y,i[7]=0,i[8]=c,i[9]=g,i[10]=O,i[11]=0,i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i};yt.multiplyByTranslation=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("translation",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z,r=n*t[0]+s*t[4]+o*t[8]+t[12],a=n*t[1]+s*t[5]+o*t[9]+t[13],h=n*t[2]+s*t[6]+o*t[10]+t[14];return i[0]=t[0],i[1]=t[1],i[2]=t[2],i[3]=t[3],i[4]=t[4],i[5]=t[5],i[6]=t[6],i[7]=t[7],i[8]=t[8],i[9]=t[9],i[10]=t[10],i[11]=t[11],i[12]=r,i[13]=a,i[14]=h,i[15]=t[15],i};yt.multiplyByScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z;return n===1&&s===1&&o===1?yt.clone(t,i):(i[0]=n*t[0],i[1]=n*t[1],i[2]=n*t[2],i[3]=t[3],i[4]=s*t[4],i[5]=s*t[5],i[6]=s*t[6],i[7]=t[7],i[8]=o*t[8],i[9]=o*t[9],i[10]=o*t[10],i[11]=t[11],i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i)};yt.multiplyByUniformScale=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3],i[4]=t[4]*e,i[5]=t[5]*e,i[6]=t[6]*e,i[7]=t[7],i[8]=t[8]*e,i[9]=t[9]*e,i[10]=t[10]*e,i[11]=t[11],i[12]=t[12],i[13]=t[13],i[14]=t[14],i[15]=t[15],i};yt.multiplyByVector=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("cartesian",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z,r=e.w,a=t[0]*n+t[4]*s+t[8]*o+t[12]*r,h=t[1]*n+t[5]*s+t[9]*o+t[13]*r,A=t[2]*n+t[6]*s+t[10]*o+t[14]*r,d=t[3]*n+t[7]*s+t[11]*o+t[15]*r;return i.x=a,i.y=h,i.z=A,i.w=d,i};yt.multiplyByPointAsVector=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("cartesian",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z,r=t[0]*n+t[4]*s+t[8]*o,a=t[1]*n+t[5]*s+t[9]*o,h=t[2]*n+t[6]*s+t[10]*o;return i.x=r,i.y=a,i.z=h,i};yt.multiplyByPoint=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("cartesian",e),p.typeOf.object("result",i);let n=e.x,s=e.y,o=e.z,r=t[0]*n+t[4]*s+t[8]*o+t[12],a=t[1]*n+t[5]*s+t[9]*o+t[13],h=t[2]*n+t[6]*s+t[10]*o+t[14];return i.x=r,i.y=a,i.z=h,i};yt.multiplyByScalar=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3]*e,i[4]=t[4]*e,i[5]=t[5]*e,i[6]=t[6]*e,i[7]=t[7]*e,i[8]=t[8]*e,i[9]=t[9]*e,i[10]=t[10]*e,i[11]=t[11]*e,i[12]=t[12]*e,i[13]=t[13]*e,i[14]=t[14]*e,i[15]=t[15]*e,i};yt.negate=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=-t[0],e[1]=-t[1],e[2]=-t[2],e[3]=-t[3],e[4]=-t[4],e[5]=-t[5],e[6]=-t[6],e[7]=-t[7],e[8]=-t[8],e[9]=-t[9],e[10]=-t[10],e[11]=-t[11],e[12]=-t[12],e[13]=-t[13],e[14]=-t[14],e[15]=-t[15],e};yt.transpose=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[1],n=t[2],s=t[3],o=t[6],r=t[7],a=t[11];return e[0]=t[0],e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=i,e[5]=t[5],e[6]=t[9],e[7]=t[13],e[8]=n,e[9]=o,e[10]=t[10],e[11]=t[14],e[12]=s,e[13]=r,e[14]=a,e[15]=t[15],e};yt.abs=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=Math.abs(t[0]),e[1]=Math.abs(t[1]),e[2]=Math.abs(t[2]),e[3]=Math.abs(t[3]),e[4]=Math.abs(t[4]),e[5]=Math.abs(t[5]),e[6]=Math.abs(t[6]),e[7]=Math.abs(t[7]),e[8]=Math.abs(t[8]),e[9]=Math.abs(t[9]),e[10]=Math.abs(t[10]),e[11]=Math.abs(t[11]),e[12]=Math.abs(t[12]),e[13]=Math.abs(t[13]),e[14]=Math.abs(t[14]),e[15]=Math.abs(t[15]),e};yt.equals=function(t,e){return t===e||m(t)&&m(e)&&t[12]===e[12]&&t[13]===e[13]&&t[14]===e[14]&&t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[4]===e[4]&&t[5]===e[5]&&t[6]===e[6]&&t[8]===e[8]&&t[9]===e[9]&&t[10]===e[10]&&t[3]===e[3]&&t[7]===e[7]&&t[11]===e[11]&&t[15]===e[15]};yt.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t[0]-e[0])<=i&&Math.abs(t[1]-e[1])<=i&&Math.abs(t[2]-e[2])<=i&&Math.abs(t[3]-e[3])<=i&&Math.abs(t[4]-e[4])<=i&&Math.abs(t[5]-e[5])<=i&&Math.abs(t[6]-e[6])<=i&&Math.abs(t[7]-e[7])<=i&&Math.abs(t[8]-e[8])<=i&&Math.abs(t[9]-e[9])<=i&&Math.abs(t[10]-e[10])<=i&&Math.abs(t[11]-e[11])<=i&&Math.abs(t[12]-e[12])<=i&&Math.abs(t[13]-e[13])<=i&&Math.abs(t[14]-e[14])<=i&&Math.abs(t[15]-e[15])<=i};yt.getTranslation=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e.x=t[12],e.y=t[13],e.z=t[14],e};yt.getMatrix3=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[4],e[4]=t[5],e[5]=t[6],e[6]=t[8],e[7]=t[9],e[8]=t[10],e};l9=new lt,d9=new lt,m9=new ie,f9=new ie(0,0,0,1);yt.inverse=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[0],n=t[4],s=t[8],o=t[12],r=t[1],a=t[5],h=t[9],A=t[13],d=t[2],f=t[6],E=t[10],_=t[14],R=t[3],I=t[7],C=t[11],N=t[15],T=E*N,b=_*C,F=f*N,B=_*I,U=f*C,Q=E*I,M=d*N,k=_*R,y=d*C,c=E*R,g=d*I,O=f*R,D=T*a+B*h+U*A-(b*a+F*h+Q*A),w=b*r+M*h+c*A-(T*r+k*h+y*A),x=F*r+k*a+g*A-(B*r+M*a+O*A),H=Q*r+y*a+O*h-(U*r+c*a+g*h),j=b*n+F*s+Q*o-(T*n+B*s+U*o),X=T*i+k*s+y*o-(b*i+M*s+c*o),tt=B*i+M*n+O*o-(F*i+k*n+g*o),G=U*i+c*n+g*s-(Q*i+y*n+O*s);T=s*A,b=o*h,F=n*A,B=o*a,U=n*h,Q=s*a,M=i*A,k=o*r,y=i*h,c=s*r,g=i*a,O=n*r;let It=T*I+B*C+U*N-(b*I+F*C+Q*N),gt=b*R+M*C+c*N-(T*R+k*C+y*N),Yt=F*R+k*I+g*N-(B*R+M*I+O*N),Ut=Q*R+y*I+O*C-(U*R+c*I+g*C),Ct=F*E+Q*_+b*f-(U*_+T*f+B*E),zt=y*_+T*d+k*E-(M*E+c*_+b*d),kt=M*f+O*_+B*d-(g*_+F*d+k*f),Jt=g*E+U*d+c*f-(y*f+O*E+Q*d),Wt=i*D+n*w+s*x+o*H;if(Math.abs(Wt)<L.EPSILON21){if(lt.equalsEpsilon(yt.getMatrix3(t,l9),d9,L.EPSILON7)&&ie.equals(yt.getRow(t,3,m9),f9))return e[0]=0,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=0,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=0,e[11]=0,e[12]=-t[12],e[13]=-t[13],e[14]=-t[14],e[15]=1,e;throw new ke("matrix is not invertible because its determinate is zero.")}return Wt=1/Wt,e[0]=D*Wt,e[1]=w*Wt,e[2]=x*Wt,e[3]=H*Wt,e[4]=j*Wt,e[5]=X*Wt,e[6]=tt*Wt,e[7]=G*Wt,e[8]=It*Wt,e[9]=gt*Wt,e[10]=Yt*Wt,e[11]=Ut*Wt,e[12]=Ct*Wt,e[13]=zt*Wt,e[14]=kt*Wt,e[15]=Jt*Wt,e};yt.inverseTransformation=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[0],n=t[1],s=t[2],o=t[4],r=t[5],a=t[6],h=t[8],A=t[9],d=t[10],f=t[12],E=t[13],_=t[14],R=-i*f-n*E-s*_,I=-o*f-r*E-a*_,C=-h*f-A*E-d*_;return e[0]=i,e[1]=o,e[2]=h,e[3]=0,e[4]=n,e[5]=r,e[6]=A,e[7]=0,e[8]=s,e[9]=a,e[10]=d,e[11]=0,e[12]=R,e[13]=I,e[14]=C,e[15]=1,e};E9=new yt;yt.inverseTranspose=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),yt.inverse(yt.transpose(t,E9),e)};yt.IDENTITY=Object.freeze(new yt(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1));yt.ZERO=Object.freeze(new yt(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0));yt.COLUMN0ROW0=0;yt.COLUMN0ROW1=1;yt.COLUMN0ROW2=2;yt.COLUMN0ROW3=3;yt.COLUMN1ROW0=4;yt.COLUMN1ROW1=5;yt.COLUMN1ROW2=6;yt.COLUMN1ROW3=7;yt.COLUMN2ROW0=8;yt.COLUMN2ROW1=9;yt.COLUMN2ROW2=10;yt.COLUMN2ROW3=11;yt.COLUMN3ROW0=12;yt.COLUMN3ROW1=13;yt.COLUMN3ROW2=14;yt.COLUMN3ROW3=15;Object.defineProperties(yt.prototype,{length:{get:function(){return yt.packedLength}}});yt.prototype.clone=function(t){return yt.clone(this,t)};yt.prototype.equals=function(t){return yt.equals(this,t)};yt.equalsArray=function(t,e,i){return t[0]===e[i]&&t[1]===e[i+1]&&t[2]===e[i+2]&&t[3]===e[i+3]&&t[4]===e[i+4]&&t[5]===e[i+5]&&t[6]===e[i+6]&&t[7]===e[i+7]&&t[8]===e[i+8]&&t[9]===e[i+9]&&t[10]===e[i+10]&&t[11]===e[i+11]&&t[12]===e[i+12]&&t[13]===e[i+13]&&t[14]===e[i+14]&&t[15]===e[i+15]};yt.prototype.equalsEpsilon=function(t,e){return yt.equalsEpsilon(this,t,e)};yt.prototype.toString=function(){return`(${this[0]}, ${this[4]}, ${this[8]}, ${this[12]})
(${this[1]}, ${this[5]}, ${this[9]}, ${this[13]})
(${this[2]}, ${this[6]}, ${this[10]}, ${this[14]})
(${this[3]}, ${this[7]}, ${this[11]}, ${this[15]})`};at=yt});var rc,is,qo,EW,_W=S(()=>{mt();is={requestFullscreen:void 0,exitFullscreen:void 0,fullscreenEnabled:void 0,fullscreenElement:void 0,fullscreenchange:void 0,fullscreenerror:void 0},qo={};Object.defineProperties(qo,{element:{get:function(){if(qo.supportsFullscreen())return document[is.fullscreenElement]}},changeEventName:{get:function(){if(qo.supportsFullscreen())return is.fullscreenchange}},errorEventName:{get:function(){if(qo.supportsFullscreen())return is.fullscreenerror}},enabled:{get:function(){if(qo.supportsFullscreen())return document[is.fullscreenEnabled]}},fullscreen:{get:function(){if(qo.supportsFullscreen())return qo.element!==null}}});qo.supportsFullscreen=function(){if(m(rc))return rc;rc=!1;let t=document.body;if(typeof t.requestFullscreen=="function")return is.requestFullscreen="requestFullscreen",is.exitFullscreen="exitFullscreen",is.fullscreenEnabled="fullscreenEnabled",is.fullscreenElement="fullscreenElement",is.fullscreenchange="fullscreenchange",is.fullscreenerror="fullscreenerror",rc=!0,rc;let e=["webkit","moz","o","ms","khtml"],i;for(let n=0,s=e.length;n<s;++n){let o=e[n];i=`${o}RequestFullscreen`,typeof t[i]=="function"?(is.requestFullscreen=i,rc=!0):(i=`${o}RequestFullScreen`,typeof t[i]=="function"&&(is.requestFullscreen=i,rc=!0)),i=`${o}ExitFullscreen`,typeof document[i]=="function"?is.exitFullscreen=i:(i=`${o}CancelFullScreen`,typeof document[i]=="function"&&(is.exitFullscreen=i)),i=`${o}FullscreenEnabled`,document[i]!==void 0?is.fullscreenEnabled=i:(i=`${o}FullScreenEnabled`,document[i]!==void 0&&(is.fullscreenEnabled=i)),i=`${o}FullscreenElement`,document[i]!==void 0?is.fullscreenElement=i:(i=`${o}FullScreenElement`,document[i]!==void 0&&(is.fullscreenElement=i)),i=`${o}fullscreenchange`,document[`on${i}`]!==void 0&&(o==="ms"&&(i="MSFullscreenChange"),is.fullscreenchange=i),i=`${o}fullscreenerror`,document[`on${i}`]!==void 0&&(o==="ms"&&(i="MSFullscreenError"),is.fullscreenerror=i)}return rc};qo.requestFullscreen=function(t,e){qo.supportsFullscreen()&&t[is.requestFullscreen]({vrDisplay:e})};qo.exitFullscreen=function(){qo.supportsFullscreen()&&document[is.exitFullscreen]()};qo._names=is;EW=qo});function Zl(t){let e=t.split(".");for(let i=0,n=e.length;i<n;++i)e[i]=parseInt(e[i],10);return e}function G0(){if(!m(YZ)&&(YZ=!1,!WZ())){let t=/ Chrome\/([\.0-9]+)/.exec(Eo.userAgent);t!==null&&(YZ=!0,RW=Zl(t[1]))}return YZ}function _9(){return G0()&&RW}function IW(){if(!m(VZ)&&(VZ=!1,!G0()&&!WZ()&&/ Safari\/[\.0-9]+/.test(Eo.userAgent))){let t=/ Version\/([\.0-9]+)/.exec(Eo.userAgent);t!==null&&(VZ=!0,ZW=Zl(t[1]))}return VZ}function R9(){return IW()&&ZW}function pW(){if(!m(SZ)){SZ=!1;let t=/ AppleWebKit\/([\.0-9]+)(\+?)/.exec(Eo.userAgent);t!==null&&(SZ=!0,O0=Zl(t[1]),O0.isNightly=!!t[2])}return SZ}function Z9(){return pW()&&O0}function uW(){if(!m(EE)){EE=!1;let t;Eo.appName==="Microsoft Internet Explorer"?(t=/MSIE ([0-9]{1,}[\.0-9]{0,})/.exec(Eo.userAgent),t!==null&&(EE=!0,B0=Zl(t[1]))):Eo.appName==="Netscape"&&(t=/Trident\/.*rv:([0-9]{1,}[\.0-9]{0,})/.exec(Eo.userAgent),t!==null&&(EE=!0,B0=Zl(t[1])))}return EE}function I9(){return uW()&&B0}function WZ(){if(!m(OZ)){OZ=!1;let t=/ Edg\/([\.0-9]+)/.exec(Eo.userAgent);t!==null&&(OZ=!0,CW=Zl(t[1]))}return OZ}function p9(){return WZ()&&CW}function DZ(){if(!m(BZ)){BZ=!1;let t=/Firefox\/([\.0-9]+)/.exec(Eo.userAgent);t!==null&&(BZ=!0,W0=Zl(t[1]))}return BZ}function u9(){return m(Y0)||(Y0=/Windows/i.test(Eo.appVersion)),Y0}function C9(){return m(V0)||(V0=navigator.platform==="iPhone"||navigator.platform==="iPod"||navigator.platform==="iPad"),V0}function g9(){return DZ()&&W0}function T9(){return m(S0)||(S0=!DZ()&&typeof PointerEvent<"u"&&(!m(Eo.pointerEnabled)||Eo.pointerEnabled)),S0}function TW(){if(!m(GZ)){let t=document.createElement("canvas");t.setAttribute("style","image-rendering: -moz-crisp-edges;image-rendering: pixelated;");let e=t.style.imageRendering;GZ=m(e)&&e!=="",GZ&&(gW=e)}return GZ}function N9(){return TW()?gW:void 0}function fo(){if(!fo.initialized)throw new Y("You must call FeatureDetection.supportsWebP.initialize and wait for the promise to resolve before calling FeatureDetection.supportsWebP");return fo._result}var Eo,YZ,RW,VZ,ZW,SZ,O0,EE,B0,OZ,CW,BZ,W0,Y0,V0,S0,gW,GZ,Fm,Br,_o,Il=S(()=>{ae();Ft();mt();Ot();_W();typeof navigator<"u"?Eo=navigator:Eo={};fo._promise=void 0;fo._result=void 0;fo.initialize=function(){return m(fo._promise)||(fo._promise=new Promise(t=>{let e=new Image;e.onload=function(){fo._result=e.width>0&&e.height>0,t(fo._result)},e.onerror=function(){fo._result=!1,t(fo._result)},e.src="data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA"})),fo._promise};Object.defineProperties(fo,{initialized:{get:function(){return m(fo._result)}}});Fm=[];typeof ArrayBuffer<"u"&&(Fm.push(Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array),typeof Uint8ClampedArray<"u"&&Fm.push(Uint8ClampedArray),typeof Uint8ClampedArray<"u"&&Fm.push(Uint8ClampedArray),typeof BigInt64Array<"u"&&Fm.push(BigInt64Array),typeof BigUint64Array<"u"&&Fm.push(BigUint64Array));Br={isChrome:G0,chromeVersion:_9,isSafari:IW,safariVersion:R9,isWebkit:pW,webkitVersion:Z9,isInternetExplorer:uW,internetExplorerVersion:I9,isEdge:WZ,edgeVersion:p9,isFirefox:DZ,firefoxVersion:g9,isWindows:u9,isIPadOrIOS:C9,hardwareConcurrency:Z(Eo.hardwareConcurrency,3),supportsPointerEvents:T9,supportsImageRenderingPixelated:TW,supportsWebP:fo,imageRenderingValue:N9,typedArrayTypes:Fm};Br.supportsBasis=function(t){return Br.supportsWebAssembly()&&t.context.supportsBasis};Br.supportsFullscreen=function(){return EW.supportsFullscreen()};Br.supportsTypedArrays=function(){return typeof ArrayBuffer<"u"};Br.supportsBigInt64Array=function(){return typeof BigInt64Array<"u"};Br.supportsBigUint64Array=function(){return typeof BigUint64Array<"u"};Br.supportsBigInt=function(){return typeof BigInt<"u"};Br.supportsWebWorkers=function(){return typeof Worker<"u"};Br.supportsWebAssembly=function(){return typeof WebAssembly<"u"};Br.supportsWebgl2=function(t){return p.defined("scene",t),t.context.webgl2};Br.supportsEsmWebWorkers=function(){return!DZ()||parseInt(W0)>=114};_o=Br});function Pt(t,e,i,n){this.x=Z(t,0),this.y=Z(e,0),this.z=Z(i,0),this.w=Z(n,0)}var _E,F9,b9,NW,FW,D0,bW,UZ,U0,pa,YW,MZ,M0,VW,Q0,k0,Y9,V9,RE,bm,S9,SW,QZ,kZ,qA,$A,Ae,$s=S(()=>{Ht();ae();Ft();mt();Il();_e();dn();_E=new l;Pt.fromAxisAngle=function(t,e,i){p.typeOf.object("axis",t),p.typeOf.number("angle",e);let n=e/2,s=Math.sin(n);_E=l.normalize(t,_E);let o=_E.x*s,r=_E.y*s,a=_E.z*s,h=Math.cos(n);return m(i)?(i.x=o,i.y=r,i.z=a,i.w=h,i):new Pt(o,r,a,h)};F9=[1,2,0],b9=new Array(3);Pt.fromRotationMatrix=function(t,e){p.typeOf.object("matrix",t);let i,n,s,o,r,a=t[lt.COLUMN0ROW0],h=t[lt.COLUMN1ROW1],A=t[lt.COLUMN2ROW2],d=a+h+A;if(d>0)i=Math.sqrt(d+1),r=.5*i,i=.5/i,n=(t[lt.COLUMN1ROW2]-t[lt.COLUMN2ROW1])*i,s=(t[lt.COLUMN2ROW0]-t[lt.COLUMN0ROW2])*i,o=(t[lt.COLUMN0ROW1]-t[lt.COLUMN1ROW0])*i;else{let f=F9,E=0;h>a&&(E=1),A>a&&A>h&&(E=2);let _=f[E],R=f[_];i=Math.sqrt(t[lt.getElementIndex(E,E)]-t[lt.getElementIndex(_,_)]-t[lt.getElementIndex(R,R)]+1);let I=b9;I[E]=.5*i,i=.5/i,r=(t[lt.getElementIndex(R,_)]-t[lt.getElementIndex(_,R)])*i,I[_]=(t[lt.getElementIndex(_,E)]+t[lt.getElementIndex(E,_)])*i,I[R]=(t[lt.getElementIndex(R,E)]+t[lt.getElementIndex(E,R)])*i,n=-I[0],s=-I[1],o=-I[2]}return m(e)?(e.x=n,e.y=s,e.z=o,e.w=r,e):new Pt(n,s,o,r)};NW=new Pt,FW=new Pt,D0=new Pt,bW=new Pt;Pt.fromHeadingPitchRoll=function(t,e){return p.typeOf.object("headingPitchRoll",t),bW=Pt.fromAxisAngle(l.UNIT_X,t.roll,NW),D0=Pt.fromAxisAngle(l.UNIT_Y,-t.pitch,e),e=Pt.multiply(D0,bW,D0),FW=Pt.fromAxisAngle(l.UNIT_Z,-t.heading,NW),Pt.multiply(FW,e,e)};UZ=new l,U0=new l,pa=new Pt,YW=new Pt,MZ=new Pt;Pt.packedLength=4;Pt.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.x,e[i++]=t.y,e[i++]=t.z,e[i]=t.w,e};Pt.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Pt),i.x=t[e],i.y=t[e+1],i.z=t[e+2],i.w=t[e+3],i};Pt.packedInterpolationLength=3;Pt.convertPackedArrayForInterpolation=function(t,e,i,n){Pt.unpack(t,i*4,MZ),Pt.conjugate(MZ,MZ);for(let s=0,o=i-e+1;s<o;s++){let r=s*3;Pt.unpack(t,(e+s)*4,pa),Pt.multiply(pa,MZ,pa),pa.w<0&&Pt.negate(pa,pa),Pt.computeAxis(pa,UZ);let a=Pt.computeAngle(pa);m(n)||(n=[]),n[r]=UZ.x*a,n[r+1]=UZ.y*a,n[r+2]=UZ.z*a}};Pt.unpackInterpolationResult=function(t,e,i,n,s){m(s)||(s=new Pt),l.fromArray(t,0,U0);let o=l.magnitude(U0);return Pt.unpack(e,n*4,YW),o===0?Pt.clone(Pt.IDENTITY,pa):Pt.fromAxisAngle(U0,o,pa),Pt.multiply(pa,YW,s)};Pt.clone=function(t,e){if(m(t))return m(e)?(e.x=t.x,e.y=t.y,e.z=t.z,e.w=t.w,e):new Pt(t.x,t.y,t.z,t.w)};Pt.conjugate=function(t,e){return p.typeOf.object("quaternion",t),p.typeOf.object("result",e),e.x=-t.x,e.y=-t.y,e.z=-t.z,e.w=t.w,e};Pt.magnitudeSquared=function(t){return p.typeOf.object("quaternion",t),t.x*t.x+t.y*t.y+t.z*t.z+t.w*t.w};Pt.magnitude=function(t){return Math.sqrt(Pt.magnitudeSquared(t))};Pt.normalize=function(t,e){p.typeOf.object("result",e);let i=1/Pt.magnitude(t),n=t.x*i,s=t.y*i,o=t.z*i,r=t.w*i;return e.x=n,e.y=s,e.z=o,e.w=r,e};Pt.inverse=function(t,e){p.typeOf.object("result",e);let i=Pt.magnitudeSquared(t);return e=Pt.conjugate(t,e),Pt.multiplyByScalar(e,1/i,e)};Pt.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x+e.x,i.y=t.y+e.y,i.z=t.z+e.z,i.w=t.w+e.w,i};Pt.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.x=t.x-e.x,i.y=t.y-e.y,i.z=t.z-e.z,i.w=t.w-e.w,i};Pt.negate=function(t,e){return p.typeOf.object("quaternion",t),p.typeOf.object("result",e),e.x=-t.x,e.y=-t.y,e.z=-t.z,e.w=-t.w,e};Pt.dot=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.x*e.x+t.y*e.y+t.z*e.z+t.w*e.w};Pt.multiply=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t.x,s=t.y,o=t.z,r=t.w,a=e.x,h=e.y,A=e.z,d=e.w,f=r*a+n*d+s*A-o*h,E=r*h-n*A+s*d+o*a,_=r*A+n*h-s*a+o*d,R=r*d-n*a-s*h-o*A;return i.x=f,i.y=E,i.z=_,i.w=R,i};Pt.multiplyByScalar=function(t,e,i){return p.typeOf.object("quaternion",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x*e,i.y=t.y*e,i.z=t.z*e,i.w=t.w*e,i};Pt.divideByScalar=function(t,e,i){return p.typeOf.object("quaternion",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.x=t.x/e,i.y=t.y/e,i.z=t.z/e,i.w=t.w/e,i};Pt.computeAxis=function(t,e){p.typeOf.object("quaternion",t),p.typeOf.object("result",e);let i=t.w;if(Math.abs(i-1)<L.EPSILON6||Math.abs(i+1)<L.EPSILON6)return e.x=1,e.y=e.z=0,e;let n=1/Math.sqrt(1-i*i);return e.x=t.x*n,e.y=t.y*n,e.z=t.z*n,e};Pt.computeAngle=function(t){return p.typeOf.object("quaternion",t),Math.abs(t.w-1)<L.EPSILON6?0:2*Math.acos(t.w)};M0=new Pt;Pt.lerp=function(t,e,i,n){return p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n),M0=Pt.multiplyByScalar(e,i,M0),n=Pt.multiplyByScalar(t,1-i,n),Pt.add(M0,n,n)};VW=new Pt,Q0=new Pt,k0=new Pt;Pt.slerp=function(t,e,i,n){p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n);let s=Pt.dot(t,e),o=e;if(s<0&&(s=-s,o=VW=Pt.negate(e,VW)),1-s<L.EPSILON6)return Pt.lerp(t,o,i,n);let r=Math.acos(s);return Q0=Pt.multiplyByScalar(t,Math.sin((1-i)*r),Q0),k0=Pt.multiplyByScalar(o,Math.sin(i*r),k0),n=Pt.add(Q0,k0,n),Pt.multiplyByScalar(n,1/Math.sin(r),n)};Pt.log=function(t,e){p.typeOf.object("quaternion",t),p.typeOf.object("result",e);let i=L.acosClamped(t.w),n=0;return i!==0&&(n=i/Math.sin(i)),l.multiplyByScalar(t,n,e)};Pt.exp=function(t,e){p.typeOf.object("cartesian",t),p.typeOf.object("result",e);let i=l.magnitude(t),n=0;return i!==0&&(n=Math.sin(i)/i),e.x=t.x*n,e.y=t.y*n,e.z=t.z*n,e.w=Math.cos(i),e};Y9=new l,V9=new l,RE=new Pt,bm=new Pt;Pt.computeInnerQuadrangle=function(t,e,i,n){p.typeOf.object("q0",t),p.typeOf.object("q1",e),p.typeOf.object("q2",i),p.typeOf.object("result",n);let s=Pt.conjugate(e,RE);Pt.multiply(s,i,bm);let o=Pt.log(bm,Y9);Pt.multiply(s,t,bm);let r=Pt.log(bm,V9);return l.add(o,r,o),l.multiplyByScalar(o,.25,o),l.negate(o,o),Pt.exp(o,RE),Pt.multiply(e,RE,n)};Pt.squad=function(t,e,i,n,s,o){p.typeOf.object("q0",t),p.typeOf.object("q1",e),p.typeOf.object("s0",i),p.typeOf.object("s1",n),p.typeOf.number("t",s),p.typeOf.object("result",o);let r=Pt.slerp(t,e,s,RE),a=Pt.slerp(i,n,s,bm);return Pt.slerp(r,a,2*s*(1-s),o)};S9=new Pt,SW=1.9011074535173003,QZ=_o.supportsTypedArrays()?new Float32Array(8):[],kZ=_o.supportsTypedArrays()?new Float32Array(8):[],qA=_o.supportsTypedArrays()?new Float32Array(8):[],$A=_o.supportsTypedArrays()?new Float32Array(8):[];for(let t=0;t<7;++t){let e=t+1,i=2*e+1;QZ[t]=1/(e*i),kZ[t]=e/i}QZ[7]=SW/(8*17);kZ[7]=SW*8/17;Pt.fastSlerp=function(t,e,i,n){p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n);let s=Pt.dot(t,e),o;s>=0?o=1:(o=-1,s=-s);let r=s-1,a=1-i,h=i*i,A=a*a;for(let _=7;_>=0;--_)qA[_]=(QZ[_]*h-kZ[_])*r,$A[_]=(QZ[_]*A-kZ[_])*r;let d=o*i*(1+qA[0]*(1+qA[1]*(1+qA[2]*(1+qA[3]*(1+qA[4]*(1+qA[5]*(1+qA[6]*(1+qA[7])))))))),f=a*(1+$A[0]*(1+$A[1]*(1+$A[2]*(1+$A[3]*(1+$A[4]*(1+$A[5]*(1+$A[6]*(1+$A[7])))))))),E=Pt.multiplyByScalar(t,f,S9);return Pt.multiplyByScalar(e,d,n),Pt.add(E,n,n)};Pt.fastSquad=function(t,e,i,n,s,o){p.typeOf.object("q0",t),p.typeOf.object("q1",e),p.typeOf.object("s0",i),p.typeOf.object("s1",n),p.typeOf.number("t",s),p.typeOf.object("result",o);let r=Pt.fastSlerp(t,e,s,RE),a=Pt.fastSlerp(i,n,s,bm);return Pt.fastSlerp(r,a,2*s*(1-s),o)};Pt.equals=function(t,e){return t===e||m(t)&&m(e)&&t.x===e.x&&t.y===e.y&&t.z===e.z&&t.w===e.w};Pt.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t.x-e.x)<=i&&Math.abs(t.y-e.y)<=i&&Math.abs(t.z-e.z)<=i&&Math.abs(t.w-e.w)<=i};Pt.ZERO=Object.freeze(new Pt(0,0,0,0));Pt.IDENTITY=Object.freeze(new Pt(0,0,0,1));Pt.prototype.clone=function(t){return Pt.clone(this,t)};Pt.prototype.equals=function(t){return Pt.equals(this,t)};Pt.prototype.equalsEpsilon=function(t,e){return Pt.equalsEpsilon(this,t,e)};Pt.prototype.toString=function(){return`(${this.x}, ${this.y}, ${this.z}, ${this.w})`};Ae=Pt});function Ro(t,e,i){this.heading=Z(t,0),this.pitch=Z(e,0),this.roll=Z(i,0)}var ZE,OW=S(()=>{Ft();mt();Ot();_e();dn();bi();$s();Ro.fromQuaternion=function(t,e,i){if(!m(t))throw new Y("quaternion is required");m(e)||(e=new Ro);let n,s;if(m(i)){if(typeof i=="function")n=i();else if(i instanceof at)n=i;else throw new Y("referenceFrame must be a Matrix4 or a function returning a Matrix4");let d=at.inverse(n,new at),f=at.getRotation(d,new lt),E=Ae.fromRotationMatrix(f,new Ae);s=Ae.multiply(E,t,new Ae)}else s=t;let o=2*(s.w*s.y-s.z*s.x),r=1-2*(s.x*s.x+s.y*s.y),a=2*(s.w*s.x+s.y*s.z),h=1-2*(s.y*s.y+s.z*s.z),A=2*(s.w*s.z+s.x*s.y);return e.heading=-Math.atan2(A,h),e.roll=Math.atan2(a,r),e.pitch=-L.asinClamped(o),e};Ro.fromDegrees=function(t,e,i,n){if(!m(t))throw new Y("heading is required");if(!m(e))throw new Y("pitch is required");if(!m(i))throw new Y("roll is required");return m(n)||(n=new Ro),n.heading=t*L.RADIANS_PER_DEGREE,n.pitch=e*L.RADIANS_PER_DEGREE,n.roll=i*L.RADIANS_PER_DEGREE,n};Ro.clone=function(t,e){if(m(t))return m(e)?(e.heading=t.heading,e.pitch=t.pitch,e.roll=t.roll,e):new Ro(t.heading,t.pitch,t.roll)};Ro.equals=function(t,e){return t===e||m(t)&&m(e)&&t.heading===e.heading&&t.pitch===e.pitch&&t.roll===e.roll};Ro.equalsEpsilon=function(t,e,i,n){return t===e||m(t)&&m(e)&&L.equalsEpsilon(t.heading,e.heading,i,n)&&L.equalsEpsilon(t.pitch,e.pitch,i,n)&&L.equalsEpsilon(t.roll,e.roll,i,n)};Ro.prototype.clone=function(t){return Ro.clone(this,t)};Ro.prototype.equals=function(t){return Ro.equals(this,t)};Ro.prototype.equalsEpsilon=function(t,e,i){return Ro.equalsEpsilon(this,t,e,i)};Ro.prototype.toString=function(){return`(${this.heading}, ${this.pitch}, ${this.roll})`};ZE=Ro});var L0,LZ,BW,yZ=S(()=>{L0={},LZ=[],BW={}});function O9(){let t=document.getElementsByTagName("script");for(let e=0,i=t.length;e<i;++e){let n=t[e].getAttribute("src"),s=WW.exec(n);if(s!==null)return s[1]}}function DW(t){return typeof document>"u"?t:(m(wZ)||(wZ=document.createElement("a")),wZ.href=t,wZ.href)}function UW(){if(m(pl))return pl;let t;return typeof CESIUM_BASE_URL<"u"?t=CESIUM_BASE_URL:m(GW?.url)?t=AE(".",GW.url):typeof define=="object"&&m(define.amd)&&!define.amd.toUrlUndefined&&m(Xo.toUrl)?t=AE("..",ul("Core/buildModuleUrl.js")):t=O9(),m(t)||(t="/"),pl=new tn({url:DW(t)}),pl.appendForwardSlash(),pl}function B9(t){return DW(Xo.toUrl(`../${t}`))}function MW(t){return UW().getDerivedResource({url:t}).url}function ul(t){return L0[t]?L0[t]:(m(xZ)||(typeof define=="object"&&m(define.amd)&&!define.amd.toUrlUndefined&&m(Xo.toUrl)?xZ=B9:xZ=MW),xZ(t))}var GW,WW,wZ,pl,xZ,th,PZ=S(()=>{mt();E0();Ia();yZ();GW={},WW=/((?:.*\/)|^)Cesium\.js(?:\?|\#|$)/;ul._cesiumScriptRegex=WW;ul._buildModuleUrlFromBaseUrl=MW;ul._clearBaseResource=function(){pl=void 0};ul.setBaseUrl=function(t){pl=tn.DEFAULT.getDerivedResource({url:t})};ul.getCesiumBaseUrl=UW;th=ul});function G9(t,e,i){this.x=t,this.y=e,this.s=i}var JZ,y0=S(()=>{JZ=G9});function P0(t){t=Z(t,Z.EMPTY_OBJECT),this._xysFileUrlTemplate=tn.createIfNeeded(t.xysFileUrlTemplate),this._interpolationOrder=Z(t.interpolationOrder,9),this._sampleZeroJulianEphemerisDate=Z(t.sampleZeroJulianEphemerisDate,24423965e-1),this._sampleZeroDateTT=new Ze(this._sampleZeroJulianEphemerisDate,0,Ei.TAI),this._stepSizeDays=Z(t.stepSizeDays,1),this._samplesPerXysFile=Z(t.samplesPerXysFile,1e3),this._totalSamples=Z(t.totalSamples,27426),this._samples=BW||new Array(this._totalSamples*3),this._chunkDownloadsInProgress=[];let e=this._interpolationOrder,i=this._denominators=new Array(e+1),n=this._xTable=new Array(e+1),s=Math.pow(this._stepSizeDays,e);for(let o=0;o<=e;++o){i[o]=s,n[o]=o*this._stepSizeDays;for(let r=0;r<=e;++r)r!==o&&(i[o]*=o-r);i[o]=1/i[o]}this._work=new Array(e+1),this._coef=new Array(e+1)}function w0(t,e,i){let n=W9;return n.dayNumber=e,n.secondsOfDay=i,Ze.daysDifference(n,t._sampleZeroDateTT)}function x0(t,e){if(t._chunkDownloadsInProgress[e])return t._chunkDownloadsInProgress[e];let i,n=t._xysFileUrlTemplate;m(n)?i=n.getDerivedResource({templateValues:{0:e}}):i=new tn({url:th(`Assets/IAU2006_XYS/IAU2006_XYS_${e}.json`)});let s=i.fetchJson().then(function(o){t._chunkDownloadsInProgress[e]=!1;let r=t._samples,a=o.samples,h=e*t._samplesPerXysFile*3;for(let A=0,d=a.length;A<d;++A)r[h+A]=a[A]});return t._chunkDownloadsInProgress[e]=s,s}var W9,QW,kW=S(()=>{PZ();Ft();mt();y0();Or();Ia();hZ();yZ();W9=new Ze(0,0,Ei.TAI);P0.prototype.preload=function(t,e,i,n){let s=w0(this,t,e),o=w0(this,i,n),r=s/this._stepSizeDays-this._interpolationOrder/2|0;r<0&&(r=0);let a=o/this._stepSizeDays-this._interpolationOrder/2|0+this._interpolationOrder;a>=this._totalSamples&&(a=this._totalSamples-1);let h=r/this._samplesPerXysFile|0,A=a/this._samplesPerXysFile|0,d=[];for(let f=h;f<=A;++f)d.push(x0(this,f));return Promise.all(d)};P0.prototype.computeXysRadians=function(t,e,i){let n=w0(this,t,e);if(n<0)return;let s=n/this._stepSizeDays|0;if(s>=this._totalSamples)return;let o=this._interpolationOrder,r=s-(o/2|0);r<0&&(r=0);let a=r+o;a>=this._totalSamples&&(a=this._totalSamples-1,r=a-o,r<0&&(r=0));let h=!1,A=this._samples;if(m(A[r*3])||(x0(this,r/this._samplesPerXysFile|0),h=!0),m(A[a*3])||(x0(this,a/this._samplesPerXysFile|0),h=!0),h)return;m(i)?(i.x=0,i.y=0,i.s=0):i=new JZ(0,0,0);let d=n-r*this._stepSizeDays,f=this._work,E=this._denominators,_=this._coef,R=this._xTable,I,C;for(I=0;I<=o;++I)f[I]=d-R[I];for(I=0;I<=o;++I){for(_[I]=1,C=0;C<=o;++C)C!==I&&(_[I]*=f[C]);_[I]*=E[I];let N=(r+I)*3;i.x+=_[I]*A[N++],i.y+=_[I]*A[N++],i.s+=_[I]*A[N]}return i};QW=P0});var Ke,J0,Ym,j0,$o,ac,Ac,hc,D9,U9,M9,Q9,k9,L9,y9,LW,w9,x9,P9,J9,j9,H9,v9,z9,K9,X9,jZ,K0,q9,$9,t7,H0,v0,e7,i7,n7,s7,wW,xW,X0,o7,r7,q0,PW,a7,A7,h7,c7,l7,d7,m7,f7,z0,E7,_7,R7,iTt,yW,In,fr=S(()=>{Xe();Ht();Os();ri();ae();Ft();mt();Ot();lW();a0();Oe();OW();kW();y0();Or();_e();dn();bi();$s();AZ();ic();Ke={},J0={up:{south:"east",north:"west",west:"south",east:"north"},down:{south:"west",north:"east",west:"north",east:"south"},south:{up:"west",down:"east",west:"down",east:"up"},north:{up:"east",down:"west",west:"up",east:"down"},west:{up:"north",down:"south",north:"down",south:"up"},east:{up:"south",down:"north",north:"up",south:"down"}},Ym={north:[-1,0,0],east:[0,1,0],up:[0,0,1],south:[1,0,0],west:[0,-1,0],down:[0,0,-1]},j0={},$o={east:new l,north:new l,up:new l,west:new l,south:new l,down:new l},ac=new l,Ac=new l,hc=new l;Ke.localFrameToFixedFrameGenerator=function(t,e){if(!J0.hasOwnProperty(t)||!J0[t].hasOwnProperty(e))throw new Y("firstAxis and secondAxis must be east, north, up, west, south or down.");let i=J0[t][e],n,s=t+e;return m(j0[s])?n=j0[s]:(n=function(o,r,a){if(!m(o))throw new Y("origin is required.");if(isNaN(o.x)||isNaN(o.y)||isNaN(o.z))throw new Y("origin has a NaN component");if(m(a)||(a=new at),l.equalsEpsilon(o,l.ZERO,L.EPSILON14))l.unpack(Ym[t],0,ac),l.unpack(Ym[e],0,Ac),l.unpack(Ym[i],0,hc);else if(L.equalsEpsilon(o.x,0,L.EPSILON14)&&L.equalsEpsilon(o.y,0,L.EPSILON14)){let h=L.sign(o.z);l.unpack(Ym[t],0,ac),t!=="east"&&t!=="west"&&l.multiplyByScalar(ac,h,ac),l.unpack(Ym[e],0,Ac),e!=="east"&&e!=="west"&&l.multiplyByScalar(Ac,h,Ac),l.unpack(Ym[i],0,hc),i!=="east"&&i!=="west"&&l.multiplyByScalar(hc,h,hc)}else{r=Z(r,ot.WGS84),r.geodeticSurfaceNormal(o,$o.up);let h=$o.up,A=$o.east;A.x=-o.y,A.y=o.x,A.z=0,l.normalize(A,$o.east),l.cross(h,A,$o.north),l.multiplyByScalar($o.up,-1,$o.down),l.multiplyByScalar($o.east,-1,$o.west),l.multiplyByScalar($o.north,-1,$o.south),ac=$o[t],Ac=$o[e],hc=$o[i]}return a[0]=ac.x,a[1]=ac.y,a[2]=ac.z,a[3]=0,a[4]=Ac.x,a[5]=Ac.y,a[6]=Ac.z,a[7]=0,a[8]=hc.x,a[9]=hc.y,a[10]=hc.z,a[11]=0,a[12]=o.x,a[13]=o.y,a[14]=o.z,a[15]=1,a},j0[s]=n),n};Ke.eastNorthUpToFixedFrame=Ke.localFrameToFixedFrameGenerator("east","north");Ke.northEastDownToFixedFrame=Ke.localFrameToFixedFrameGenerator("north","east");Ke.northUpEastToFixedFrame=Ke.localFrameToFixedFrameGenerator("north","up");Ke.northWestUpToFixedFrame=Ke.localFrameToFixedFrameGenerator("north","west");D9=new Ae,U9=new l(1,1,1),M9=new at;Ke.headingPitchRollToFixedFrame=function(t,e,i,n,s){p.typeOf.object("HeadingPitchRoll",e),n=Z(n,Ke.eastNorthUpToFixedFrame);let o=Ae.fromHeadingPitchRoll(e,D9),r=at.fromTranslationQuaternionRotationScale(l.ZERO,o,U9,M9);return s=n(t,i,s),at.multiply(s,r,s)};Ke.localToFixedFrameQuaternion=function(t,e,i,n,s){if(!m(e))throw new Y("localQuaternion is required");n=Z(n,Ke.eastNorthUpToFixedFrame);let o=n(t,i),r=at.getMatrix3(o,new lt),a=Ae.fromRotationMatrix(r);return s=m(s)?s:new Ae,Ae.multiply(a,e,s)};Q9=new at,k9=new lt;Ke.headingPitchRollQuaternion=function(t,e,i,n,s){p.typeOf.object("HeadingPitchRoll",e);let o=Ke.headingPitchRollToFixedFrame(t,e,i,n,Q9),r=at.getMatrix3(o,k9);return Ae.fromRotationMatrix(r,s)};L9=new l(1,1,1),y9=new l,LW=new at,w9=new at,x9=new lt,P9=new Ae;Ke.fixedFrameToHeadingPitchRoll=function(t,e,i,n){p.defined("transform",t),e=Z(e,ot.WGS84),i=Z(i,Ke.eastNorthUpToFixedFrame),m(n)||(n=new ZE);let s=at.getTranslation(t,y9);if(l.equals(s,l.ZERO))return n.heading=0,n.pitch=0,n.roll=0,n;let o=at.inverseTransformation(i(s,e,LW),LW),r=at.setScale(t,L9,w9);r=at.setTranslation(r,l.ZERO,r),o=at.multiply(o,r,o);let a=Ae.fromRotationMatrix(at.getMatrix3(o,x9),P9);return a=Ae.normalize(a,a),ZE.fromQuaternion(a,n)};J9=6*3600+41*60+50.54841,j9=8640184812866e-6,H9=.093104,v9=-62e-7,z9=11772758384668e-32,K9=72921158553e-15,X9=L.TWO_PI/86400,jZ=new Ze;Ke.computeTemeToPseudoFixedMatrix=function(t,e){if(!m(t))throw new Y("date is required.");jZ=Ze.addSeconds(t,-Ze.computeTaiMinusUtc(t),jZ);let i=jZ.dayNumber,n=jZ.secondsOfDay,s,o=i-2451545;n>=43200?s=(o+.5)/Fn.DAYS_PER_JULIAN_CENTURY:s=(o-.5)/Fn.DAYS_PER_JULIAN_CENTURY;let a=(J9+s*(j9+s*(H9+s*v9)))*X9%L.TWO_PI,h=K9+z9*(i-24515455e-1),A=(n+Fn.SECONDS_PER_DAY*.5)%Fn.SECONDS_PER_DAY,d=a+h*A,f=Math.cos(d),E=Math.sin(d);return m(e)?(e[0]=f,e[1]=-E,e[2]=0,e[3]=E,e[4]=f,e[5]=0,e[6]=0,e[7]=0,e[8]=1,e):new lt(f,E,0,-E,f,0,0,0,1)};Ke.iau2006XysData=new QW;Ke.earthOrientationParameters=cW.NONE;K0=32.184,q9=2451545;Ke.preloadIcrfFixed=function(t){let e=t.start.dayNumber,i=t.start.secondsOfDay+K0,n=t.stop.dayNumber,s=t.stop.secondsOfDay+K0;return Ke.iau2006XysData.preload(e,i,n,s)};Ke.computeIcrfToFixedMatrix=function(t,e){if(!m(t))throw new Y("date is required.");m(e)||(e=new lt);let i=Ke.computeFixedToIcrfMatrix(t,e);if(m(i))return lt.transpose(i,e)};$9=new JZ(0,0,0),t7=new oE(0,0,0,0,0,0),H0=new lt,v0=new lt;Ke.computeFixedToIcrfMatrix=function(t,e){if(!m(t))throw new Y("date is required.");m(e)||(e=new lt);let i=Ke.earthOrientationParameters.compute(t,t7);if(!m(i))return;let n=t.dayNumber,s=t.secondsOfDay+K0,o=Ke.iau2006XysData.computeXysRadians(n,s,$9);if(!m(o))return;let r=o.x+i.xPoleOffset,a=o.y+i.yPoleOffset,h=1/(1+Math.sqrt(1-r*r-a*a)),A=H0;A[0]=1-h*r*r,A[3]=-h*r*a,A[6]=r,A[1]=-h*r*a,A[4]=1-h*a*a,A[7]=a,A[2]=-r,A[5]=-a,A[8]=1-h*(r*r+a*a);let d=lt.fromRotationZ(-o.s,v0),f=lt.multiply(A,d,H0),E=t.dayNumber,_=t.secondsOfDay-Ze.computeTaiMinusUtc(t)+i.ut1MinusUtc,R=E-2451545,I=_/Fn.SECONDS_PER_DAY,C=.779057273264+I+.00273781191135448*(R+I);C=C%1*L.TWO_PI;let N=lt.fromRotationZ(C,v0),T=lt.multiply(f,N,H0),b=Math.cos(i.xPoleWander),F=Math.cos(i.yPoleWander),B=Math.sin(i.xPoleWander),U=Math.sin(i.yPoleWander),Q=n-q9+s/Fn.SECONDS_PER_DAY;Q/=36525;let M=-47e-6*Q*L.RADIANS_PER_DEGREE/3600,k=Math.cos(M),y=Math.sin(M),c=v0;return c[0]=b*k,c[1]=b*y,c[2]=B,c[3]=-F*y+U*B*k,c[4]=F*k+U*B*y,c[5]=-U*b,c[6]=-U*y-F*B*k,c[7]=U*k-F*B*y,c[8]=F*b,lt.multiply(T,c,e)};e7=new ie;Ke.pointToWindowCoordinates=function(t,e,i,n){return n=Ke.pointToGLWindowCoordinates(t,e,i,n),n.y=2*e[5]-n.y,n};Ke.pointToGLWindowCoordinates=function(t,e,i,n){if(!m(t))throw new Y("modelViewProjectionMatrix is required.");if(!m(e))throw new Y("viewportTransformation is required.");if(!m(i))throw new Y("point is required.");m(n)||(n=new nt);let s=e7;return at.multiplyByVector(t,ie.fromElements(i.x,i.y,i.z,1,s),s),ie.multiplyByScalar(s,1/s.w,s),at.multiplyByVector(e,s,s),nt.fromCartesian4(s,n)};i7=new l,n7=new l,s7=new l;Ke.rotationMatrixFromPositionVelocity=function(t,e,i,n){if(!m(t))throw new Y("position is required.");if(!m(e))throw new Y("velocity is required.");let s=Z(i,ot.WGS84).geodeticSurfaceNormal(t,i7),o=l.cross(e,s,n7);l.equalsEpsilon(o,l.ZERO,L.EPSILON6)&&(o=l.clone(l.UNIT_X,o));let r=l.cross(o,e,s7);return l.normalize(r,r),l.cross(e,r,o),l.negate(o,o),l.normalize(o,o),m(n)||(n=new lt),n[0]=e.x,n[1]=e.y,n[2]=e.z,n[3]=o.x,n[4]=o.y,n[5]=o.z,n[6]=r.x,n[7]=r.y,n[8]=r.z,n};wW=new at(0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1),xW=new ut,X0=new l,o7=new l,r7=new lt,q0=new at,PW=new at;Ke.basisTo2D=function(t,e,i){if(!m(t))throw new Y("projection is required.");if(!m(e))throw new Y("matrix is required.");if(!m(i))throw new Y("result is required.");let n=at.getTranslation(e,o7),s=t.ellipsoid,o;if(l.equals(n,l.ZERO))o=l.clone(l.ZERO,X0);else{let d=s.cartesianToCartographic(n,xW);o=t.project(d,X0),l.fromElements(o.z,o.x,o.y,o)}let r=Ke.eastNorthUpToFixedFrame(n,s,q0),a=at.inverseTransformation(r,PW),h=at.getMatrix3(e,r7),A=at.multiplyByMatrix3(a,h,i);return at.multiply(wW,A,i),at.setTranslation(i,o,i),i};Ke.wgs84To2DModelMatrix=function(t,e,i){if(!m(t))throw new Y("projection is required.");if(!m(e))throw new Y("center is required.");if(!m(i))throw new Y("result is required.");let n=t.ellipsoid,s=Ke.eastNorthUpToFixedFrame(e,n,q0),o=at.inverseTransformation(s,PW),r=n.cartesianToCartographic(e,xW),a=t.project(r,X0);l.fromElements(a.z,a.x,a.y,a);let h=at.fromTranslation(a,q0);return at.multiply(wW,o,i),at.multiply(h,i,i),i};a7=new l,A7=new l,h7=new l,c7=new l,l7=new l,d7=new l,m7=new l,f7=new l,z0=new Ze,E7=new lt,_7=new lt,R7=new lt;Ke.vvlhToFixed=function(t,e,i){let n=t.getValue(e,a7);Ze.addSeconds(e,.01,z0);let s=t.getValue(z0,A7),o=ot.WGS84,r=o.maximumRadius+1e5;if(m(i)||(i=new at),l.magnitude(n)<=r){let E=l.subtract(s,n,new l),_;if(l.magnitude(E)===0){let C=Ke.eastNorthUpToFixedFrame(n,o);_=new l(C[0],C[1],C[2])}else _=l.normalize(E,new l);let R=o.geodeticSurfaceNormal(n,new l),I=l.cross(R,_,new l);return i[0]=_.x,i[1]=_.y,i[2]=_.z,i[3]=0,i[4]=I.x,i[5]=I.y,i[6]=I.z,i[7]=0,i[8]=R.x,i[9]=R.y,i[10]=R.z,i[11]=0,i[12]=n.x,i[13]=n.y,i[14]=n.z,i[15]=1,i}let a=Ke.computeFixedToIcrfMatrix(e,E7);if(!a)return new at;let h=Ke.computeFixedToIcrfMatrix(z0,_7),A=lt.transpose(a,R7),d=lt.multiplyByVector(a,n,h7),f=lt.multiplyByVector(h,s,c7);if(!l.equalsEpsilon(d,f,L.EPSILON14)){let E=l.subtract(f,d,l7),_=d7;try{l.negate(l.normalize(d,_),_)}catch{console.log(d,_)}let R=l.cross(E,_,m7);l.negate(R,R);let I=l.cross(R,_,f7);try{lt.multiplyByVector(A,I,I),lt.multiplyByVector(A,R,R),lt.multiplyByVector(A,_,_),l.normalize(I,I),l.normalize(R,R),l.normalize(_,_),i[0]=I.x,i[1]=I.y,i[2]=I.z,i[3]=0,i[4]=R.x,i[5]=R.y,i[6]=R.z,i[7]=0,i[8]=_.x,i[9]=_.y,i[10]=_.z,i[11]=0,i[12]=n.x,i[13]=n.y,i[14]=n.z,i[15]=1}catch(C){return console.log(C,I,R,_,E,n,s,t),new Array(16).fill(0)}}return at.multiply(i,new at(1,0,0,0,0,-1,0,0,0,0,-1,0,0,0,0,1),i),i};Ke.reverseHeadingQuaternion=function(t){if(!m(t))throw new Y("orientation is required");let e=new ZE;ZE.fromQuaternion(t,e),e.heading=-e.heading,e.roll=-e.roll;let i=new Ae;return Ae.fromHeadingPitchRoll(e,i),i};iTt=new at(0,0,1,0,0,1,0,0,-1,0,0,0,0,0,0,1);Ke.getPositionInVVLH=function(t,e,i,n,s=$i.FIXED){let o=e.position.getValueInReferenceFrame(i,s.FIXED),r=t.position.getValueInReferenceFrame(n,s.FIXED),a;try{a=at.inverse(Ke.vvlhToFixed(t.position,i),new at)}catch{a=new at}let h=at.multiplyByPoint(a,o,new l),A=at.getRotation(Ke.vvlhToFixed(t.position,n),new lt),d=lt.multiplyByVector(A,h,new l),f=l.add(r,d,new l);if(s===$i.INERTIAL){let E=Ke.computeFixedToIcrfMatrix(n);E&&(f=lt.multiplyByVector(E,f,new l))}return f};yW=Ke.localFrameToFixedFrameGenerator("north","west");Ke.getTransformToFixedFrame=function(t,e,i){let n,s={[$i.FIXED]:()=>at.IDENTITY,[$i.INERTIAL]:()=>{if(!m(e))throw new Y("Conversion from INERTIAL to FIXED requires a time.");return Ke.computeIcrfToFixedMatrix(e)},[$i.TEME]:()=>{throw new Y("Conversion from TEME to FIXED is not implemented.")},[$i.VVLH]:()=>{if(!m(e)||!m(i))throw new Y("Conversion from VVLH to FIXED requires both time and position.");let o=Ke.vvlhToFixed(i,e),r=at.fromScale(new l(1,-1,-1));return at.multiply(o,r,new at)},[$i.NED]:()=>{if(!m(e)||!m(i))throw new Y("Conversion from NED to FIXED requires both time and position.");let o=yW(i.getValue(e)),r=at.fromScale(new l(1,-1,-1));return at.multiply(o,r,new at)},[$i.NEU]:()=>{if(!m(e)||!m(i))throw new Y("Conversion from NEU to FIXED requires both time and position.");let o=yW(i.getValue(e)),r=at.fromScale(new l(1,-1,1));return at.multiply(o,r,new at)},[$i.RIC]:()=>{if(!m(e)||!m(i))throw new Y("Conversion from RIC to FIXED requires both time and position.");let o=Ke.vvlhToFixed(i,e),r=at.fromArray([0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1]);return at.multiply(o,r,new at)}};return s.hasOwnProperty(t)?n=s[t]:n=Ke.eastNorthUpToFixedFrame,n};In=Ke});function Je(t,e,i,n){this.west=Z(t,0),this.south=Z(e,0),this.east=Z(i,0),this.north=Z(n,0)}var Z7,I7,p7,u7,C7,$0,g7,Xt,pn=S(()=>{Ht();ri();ae();Ft();mt();Oe();_e();fr();bi();Object.defineProperties(Je.prototype,{width:{get:function(){return Je.computeWidth(this)}},height:{get:function(){return Je.computeHeight(this)}}});Je.packedLength=4;Je.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.west,e[i++]=t.south,e[i++]=t.east,e[i]=t.north,e};Je.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Je),i.west=t[e++],i.south=t[e++],i.east=t[e++],i.north=t[e],i};Je.computeWidth=function(t){p.typeOf.object("rectangle",t);let e=t.east,i=t.west;return e<i&&(e+=L.TWO_PI),e-i};Je.computeHeight=function(t){return p.typeOf.object("rectangle",t),t.north-t.south};Je.fromDegrees=function(t,e,i,n,s){return t=L.toRadians(Z(t,0)),e=L.toRadians(Z(e,0)),i=L.toRadians(Z(i,0)),n=L.toRadians(Z(n,0)),m(s)?(s.west=t,s.south=e,s.east=i,s.north=n,s):new Je(t,e,i,n)};Je.fromRadians=function(t,e,i,n,s){return m(s)?(s.west=Z(t,0),s.south=Z(e,0),s.east=Z(i,0),s.north=Z(n,0),s):new Je(t,e,i,n)};Je.fromCartographicArray=function(t,e){p.defined("cartographics",t);let i=Number.MAX_VALUE,n=-Number.MAX_VALUE,s=Number.MAX_VALUE,o=-Number.MAX_VALUE,r=Number.MAX_VALUE,a=-Number.MAX_VALUE;for(let h=0,A=t.length;h<A;h++){let d=t[h];i=Math.min(i,d.longitude),n=Math.max(n,d.longitude),r=Math.min(r,d.latitude),a=Math.max(a,d.latitude);let f=d.longitude>=0?d.longitude:d.longitude+L.TWO_PI;s=Math.min(s,f),o=Math.max(o,f)}return n-i>o-s&&(i=s,n=o,n>L.PI&&(n=n-L.TWO_PI),i>L.PI&&(i=i-L.TWO_PI)),m(e)?(e.west=i,e.south=r,e.east=n,e.north=a,e):new Je(i,r,n,a)};Je.fromCartesianArray=function(t,e,i){p.defined("cartesians",t),e=Z(e,ot.WGS84);let n=Number.MAX_VALUE,s=-Number.MAX_VALUE,o=Number.MAX_VALUE,r=-Number.MAX_VALUE,a=Number.MAX_VALUE,h=-Number.MAX_VALUE;for(let A=0,d=t.length;A<d;A++){let f=e.cartesianToCartographic(t[A]);n=Math.min(n,f.longitude),s=Math.max(s,f.longitude),a=Math.min(a,f.latitude),h=Math.max(h,f.latitude);let E=f.longitude>=0?f.longitude:f.longitude+L.TWO_PI;o=Math.min(o,E),r=Math.max(r,E)}return s-n>r-o&&(n=o,s=r,s>L.PI&&(s=s-L.TWO_PI),n>L.PI&&(n=n-L.TWO_PI)),m(i)?(i.west=n,i.south=a,i.east=s,i.north=h,i):new Je(n,a,s,h)};Z7=new l,I7=new l,p7=new l,u7=new l,C7=new l,$0=new Array(5);for(let t=0;t<$0.length;++t)$0[t]=new l;Je.fromBoundingSphere=function(t,e,i){p.typeOf.object("boundingSphere",t);let n=t.center,s=t.radius;if(m(e)||(e=ot.WGS84),m(i)||(i=new Je),l.equals(n,l.ZERO))return Je.clone(Je.MAX_VALUE,i),i;let o=In.eastNorthUpToFixedFrame(n,e,Z7),r=at.multiplyByPointAsVector(o,l.UNIT_X,I7);l.normalize(r,r);let a=at.multiplyByPointAsVector(o,l.UNIT_Y,p7);l.normalize(a,a),l.multiplyByScalar(a,s,a),l.multiplyByScalar(r,s,r);let h=l.negate(a,C7),A=l.negate(r,u7),d=$0,f=d[0];return l.add(n,a,f),f=d[1],l.add(n,A,f),f=d[2],l.add(n,h,f),f=d[3],l.add(n,r,f),d[4]=n,Je.fromCartesianArray(d,e,i)};Je.clone=function(t,e){if(m(t))return m(e)?(e.west=t.west,e.south=t.south,e.east=t.east,e.north=t.north,e):new Je(t.west,t.south,t.east,t.north)};Je.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t.west-e.west)<=i&&Math.abs(t.south-e.south)<=i&&Math.abs(t.east-e.east)<=i&&Math.abs(t.north-e.north)<=i};Je.prototype.clone=function(t){return Je.clone(this,t)};Je.prototype.equals=function(t){return Je.equals(this,t)};Je.equals=function(t,e){return t===e||m(t)&&m(e)&&t.west===e.west&&t.south===e.south&&t.east===e.east&&t.north===e.north};Je.prototype.equalsEpsilon=function(t,e){return Je.equalsEpsilon(this,t,e)};Je.validate=function(t){p.typeOf.object("rectangle",t);let e=t.north;p.typeOf.number.greaterThanOrEquals("north",e,-L.PI_OVER_TWO),p.typeOf.number.lessThanOrEquals("north",e,L.PI_OVER_TWO);let i=t.south;p.typeOf.number.greaterThanOrEquals("south",i,-L.PI_OVER_TWO),p.typeOf.number.lessThanOrEquals("south",i,L.PI_OVER_TWO);let n=t.west;p.typeOf.number.greaterThanOrEquals("west",n,-Math.PI),p.typeOf.number.lessThanOrEquals("west",n,Math.PI);let s=t.east;p.typeOf.number.greaterThanOrEquals("east",s,-Math.PI),p.typeOf.number.lessThanOrEquals("east",s,Math.PI)};Je.southwest=function(t,e){return p.typeOf.object("rectangle",t),m(e)?(e.longitude=t.west,e.latitude=t.south,e.height=0,e):new ut(t.west,t.south)};Je.northwest=function(t,e){return p.typeOf.object("rectangle",t),m(e)?(e.longitude=t.west,e.latitude=t.north,e.height=0,e):new ut(t.west,t.north)};Je.northeast=function(t,e){return p.typeOf.object("rectangle",t),m(e)?(e.longitude=t.east,e.latitude=t.north,e.height=0,e):new ut(t.east,t.north)};Je.southeast=function(t,e){return p.typeOf.object("rectangle",t),m(e)?(e.longitude=t.east,e.latitude=t.south,e.height=0,e):new ut(t.east,t.south)};Je.center=function(t,e){p.typeOf.object("rectangle",t);let i=t.east,n=t.west;i<n&&(i+=L.TWO_PI);let s=L.negativePiToPi((n+i)*.5),o=(t.south+t.north)*.5;return m(e)?(e.longitude=s,e.latitude=o,e.height=0,e):new ut(s,o)};Je.intersection=function(t,e,i){p.typeOf.object("rectangle",t),p.typeOf.object("otherRectangle",e);let n=t.east,s=t.west,o=e.east,r=e.west;n<s&&o>0?n+=L.TWO_PI:o<r&&n>0&&(o+=L.TWO_PI),n<s&&r<0?r+=L.TWO_PI:o<r&&s<0&&(s+=L.TWO_PI);let a=L.negativePiToPi(Math.max(s,r)),h=L.negativePiToPi(Math.min(n,o));if((t.west<t.east||e.west<e.east)&&h<=a)return;let A=Math.max(t.south,e.south),d=Math.min(t.north,e.north);if(!(A>=d))return m(i)?(i.west=a,i.south=A,i.east=h,i.north=d,i):new Je(a,A,h,d)};Je.simpleIntersection=function(t,e,i){p.typeOf.object("rectangle",t),p.typeOf.object("otherRectangle",e);let n=Math.max(t.west,e.west),s=Math.max(t.south,e.south),o=Math.min(t.east,e.east),r=Math.min(t.north,e.north);if(!(s>=r||n>=o))return m(i)?(i.west=n,i.south=s,i.east=o,i.north=r,i):new Je(n,s,o,r)};Je.union=function(t,e,i){p.typeOf.object("rectangle",t),p.typeOf.object("otherRectangle",e),m(i)||(i=new Je);let n=t.east,s=t.west,o=e.east,r=e.west;n<s&&o>0?n+=L.TWO_PI:o<r&&n>0&&(o+=L.TWO_PI),n<s&&r<0?r+=L.TWO_PI:o<r&&s<0&&(s+=L.TWO_PI);let a=L.negativePiToPi(Math.min(s,r)),h=L.negativePiToPi(Math.max(n,o));return i.west=a,i.south=Math.min(t.south,e.south),i.east=h,i.north=Math.max(t.north,e.north),i};Je.expand=function(t,e,i){return p.typeOf.object("rectangle",t),p.typeOf.object("cartographic",e),m(i)||(i=new Je),i.west=Math.min(t.west,e.longitude),i.south=Math.min(t.south,e.latitude),i.east=Math.max(t.east,e.longitude),i.north=Math.max(t.north,e.latitude),i};Je.contains=function(t,e){p.typeOf.object("rectangle",t),p.typeOf.object("cartographic",e);let i=e.longitude,n=e.latitude,s=t.west,o=t.east;return o<s&&(o+=L.TWO_PI,i<0&&(i+=L.TWO_PI)),(i>s||L.equalsEpsilon(i,s,L.EPSILON14))&&(i<o||L.equalsEpsilon(i,o,L.EPSILON14))&&n>=t.south&&n<=t.north};g7=new ut;Je.subsample=function(t,e,i,n){p.typeOf.object("rectangle",t),e=Z(e,ot.WGS84),i=Z(i,0),m(n)||(n=[]);let s=0,o=t.north,r=t.south,a=t.east,h=t.west,A=g7;A.height=i,A.longitude=h,A.latitude=o,n[s]=e.cartographicToCartesian(A,n[s]),s++,A.longitude=a,n[s]=e.cartographicToCartesian(A,n[s]),s++,A.latitude=r,n[s]=e.cartographicToCartesian(A,n[s]),s++,A.longitude=h,n[s]=e.cartographicToCartesian(A,n[s]),s++,o<0?A.latitude=o:r>0?A.latitude=r:A.latitude=0;for(let d=1;d<8;++d)A.longitude=-Math.PI+d*L.PI_OVER_TWO,Je.contains(t,A)&&(n[s]=e.cartographicToCartesian(A,n[s]),s++);return A.latitude===0&&(A.longitude=h,n[s]=e.cartographicToCartesian(A,n[s]),s++,A.longitude=a,n[s]=e.cartographicToCartesian(A,n[s]),s++),n.length=s,n};Je.subsection=function(t,e,i,n,s,o){if(p.typeOf.object("rectangle",t),p.typeOf.number.greaterThanOrEquals("westLerp",e,0),p.typeOf.number.lessThanOrEquals("westLerp",e,1),p.typeOf.number.greaterThanOrEquals("southLerp",i,0),p.typeOf.number.lessThanOrEquals("southLerp",i,1),p.typeOf.number.greaterThanOrEquals("eastLerp",n,0),p.typeOf.number.lessThanOrEquals("eastLerp",n,1),p.typeOf.number.greaterThanOrEquals("northLerp",s,0),p.typeOf.number.lessThanOrEquals("northLerp",s,1),p.typeOf.number.lessThanOrEquals("westLerp",e,n),p.typeOf.number.lessThanOrEquals("southLerp",i,s),m(o)||(o=new Je),t.west<=t.east){let a=t.east-t.west;o.west=t.west+e*a,o.east=t.west+n*a}else{let a=L.TWO_PI+t.east-t.west;o.west=L.negativePiToPi(t.west+e*a),o.east=L.negativePiToPi(t.west+n*a)}let r=t.north-t.south;return o.south=t.south+i*r,o.north=t.south+s*r,e===1&&(o.west=t.east),n===1&&(o.east=t.east),i===1&&(o.south=t.north),s===1&&(o.north=t.north),o};Je.MAX_VALUE=Object.freeze(new Je(-Math.PI,-L.PI_OVER_TWO,Math.PI,L.PI_OVER_TWO));Xt=Je});function ns(t,e,i,n){this.x=Z(t,0),this.y=Z(e,0),this.width=Z(i,0),this.height=Z(n,0)}var T7,N7,F7,mi,Er=S(()=>{Xe();ri();ae();Ft();mt();zA();nc();pn();ns.packedLength=4;ns.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.x,e[i++]=t.y,e[i++]=t.width,e[i]=t.height,e};ns.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new ns),i.x=t[e++],i.y=t[e++],i.width=t[e++],i.height=t[e],i};ns.fromPoints=function(t,e){if(m(e)||(e=new ns),!m(t)||t.length===0)return e.x=0,e.y=0,e.width=0,e.height=0,e;let i=t.length,n=t[0].x,s=t[0].y,o=t[0].x,r=t[0].y;for(let a=1;a<i;a++){let h=t[a],A=h.x,d=h.y;n=Math.min(A,n),o=Math.max(A,o),s=Math.min(d,s),r=Math.max(d,r)}return e.x=n,e.y=s,e.width=o-n,e.height=r-s,e};T7=new Ss,N7=new ut,F7=new ut;ns.fromRectangle=function(t,e,i){if(m(i)||(i=new ns),!m(t))return i.x=0,i.y=0,i.width=0,i.height=0,i;e=Z(e,T7);let n=e.project(Xt.southwest(t,N7)),s=e.project(Xt.northeast(t,F7));return nt.subtract(s,n,s),i.x=n.x,i.y=n.y,i.width=s.x,i.height=s.y,i};ns.clone=function(t,e){if(m(t))return m(e)?(e.x=t.x,e.y=t.y,e.width=t.width,e.height=t.height,e):new ns(t.x,t.y,t.width,t.height)};ns.union=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),m(i)||(i=new ns);let n=Math.min(t.x,e.x),s=Math.min(t.y,e.y),o=Math.max(t.x+t.width,e.x+e.width),r=Math.max(t.y+t.height,e.y+e.height);return i.x=n,i.y=s,i.width=o-n,i.height=r-s,i};ns.expand=function(t,e,i){p.typeOf.object("rectangle",t),p.typeOf.object("point",e),i=ns.clone(t,i);let n=e.x-i.x,s=e.y-i.y;return n>i.width?i.width=n:n<0&&(i.width-=n,i.x=e.x),s>i.height?i.height=s:s<0&&(i.height-=s,i.y=e.y),i};ns.intersect=function(t,e){p.typeOf.object("left",t),p.typeOf.object("right",e);let i=t.x,n=t.y,s=e.x,o=e.y;return i>s+e.width||i+t.width<s||n+t.height<o||n>o+e.height?Nn.OUTSIDE:Nn.INTERSECTING};ns.equals=function(t,e){return t===e||m(t)&&m(e)&&t.x===e.x&&t.y===e.y&&t.width===e.width&&t.height===e.height};ns.prototype.clone=function(t){return ns.clone(this,t)};ns.prototype.intersect=function(t){return ns.intersect(this,t)};ns.prototype.equals=function(t){return ns.equals(this,t)};mi=ns});function b7(t,e){this.start=Z(t,0),this.stop=Z(e,0)}var cA,HZ=S(()=>{Ft();cA=b7});function Le(t,e){this.center=l.clone(Z(t,l.ZERO)),this.radius=Z(e,0)}var iT,nT,sT,oT,rT,aT,AT,Js,hT,cT,lT,dT,Y7,V7,S7,O7,tT,eT,B7,G7,W7,D7,U7,M7,Q7,k7,L7,y7,w7,x7,JW,P7,J7,j7,H7,v7,jW,z7,Nt,_i=S(()=>{Ht();ri();ae();Ft();mt();Oe();zA();nc();HZ();_e();dn();bi();pn();iT=new l,nT=new l,sT=new l,oT=new l,rT=new l,aT=new l,AT=new l,Js=new l,hT=new l,cT=new l,lT=new l,dT=new l,Y7=4/3*L.PI;Le.fromPoints=function(t,e){if(m(e)||(e=new Le),!m(t)||t.length===0)return e.center=l.clone(l.ZERO,e.center),e.radius=0,e;let i=l.clone(t[0],AT),n=l.clone(i,iT),s=l.clone(i,nT),o=l.clone(i,sT),r=l.clone(i,oT),a=l.clone(i,rT),h=l.clone(i,aT),A=t.length,d;for(d=1;d<A;d++){l.clone(t[d],i);let M=i.x,k=i.y,y=i.z;M<n.x&&l.clone(i,n),M>r.x&&l.clone(i,r),k<s.y&&l.clone(i,s),k>a.y&&l.clone(i,a),y<o.z&&l.clone(i,o),y>h.z&&l.clone(i,h)}let f=l.magnitudeSquared(l.subtract(r,n,Js)),E=l.magnitudeSquared(l.subtract(a,s,Js)),_=l.magnitudeSquared(l.subtract(h,o,Js)),R=n,I=r,C=f;E>C&&(C=E,R=s,I=a),_>C&&(C=_,R=o,I=h);let N=hT;N.x=(R.x+I.x)*.5,N.y=(R.y+I.y)*.5,N.z=(R.z+I.z)*.5;let T=l.magnitudeSquared(l.subtract(I,N,Js)),b=Math.sqrt(T),F=cT;F.x=n.x,F.y=s.y,F.z=o.z;let B=lT;B.x=r.x,B.y=a.y,B.z=h.z;let U=l.midpoint(F,B,dT),Q=0;for(d=0;d<A;d++){l.clone(t[d],i);let M=l.magnitude(l.subtract(i,U,Js));M>Q&&(Q=M);let k=l.magnitudeSquared(l.subtract(i,N,Js));if(k>T){let y=Math.sqrt(k);b=(b+y)*.5,T=b*b;let c=y-b;N.x=(b*N.x+c*i.x)/y,N.y=(b*N.y+c*i.y)/y,N.z=(b*N.z+c*i.z)/y}}return b<Q?(l.clone(N,e.center),e.radius=b):(l.clone(U,e.center),e.radius=Q),e};V7=new Ss,S7=new l,O7=new l,tT=new ut,eT=new ut;Le.fromRectangle2D=function(t,e,i){return Le.fromRectangleWithHeights2D(t,e,0,0,i)};Le.fromRectangleWithHeights2D=function(t,e,i,n,s){if(m(s)||(s=new Le),!m(t))return s.center=l.clone(l.ZERO,s.center),s.radius=0,s;e=Z(e,V7),Xt.southwest(t,tT),tT.height=i,Xt.northeast(t,eT),eT.height=n;let o=e.project(tT,S7),r=e.project(eT,O7),a=r.x-o.x,h=r.y-o.y,A=r.z-o.z;s.radius=Math.sqrt(a*a+h*h+A*A)*.5;let d=s.center;return d.x=o.x+a*.5,d.y=o.y+h*.5,d.z=o.z+A*.5,s};B7=[];Le.fromRectangle3D=function(t,e,i,n){if(e=Z(e,ot.WGS84),i=Z(i,0),m(n)||(n=new Le),!m(t))return n.center=l.clone(l.ZERO,n.center),n.radius=0,n;let s=Xt.subsample(t,e,i,B7);return Le.fromPoints(s,n)};Le.fromVertices=function(t,e,i,n){if(m(n)||(n=new Le),!m(t)||t.length===0)return n.center=l.clone(l.ZERO,n.center),n.radius=0,n;e=Z(e,l.ZERO),i=Z(i,3),p.typeOf.number.greaterThanOrEquals("stride",i,3);let s=AT;s.x=t[0]+e.x,s.y=t[1]+e.y,s.z=t[2]+e.z;let o=l.clone(s,iT),r=l.clone(s,nT),a=l.clone(s,sT),h=l.clone(s,oT),A=l.clone(s,rT),d=l.clone(s,aT),f=t.length,E;for(E=0;E<f;E+=i){let y=t[E]+e.x,c=t[E+1]+e.y,g=t[E+2]+e.z;s.x=y,s.y=c,s.z=g,y<o.x&&l.clone(s,o),y>h.x&&l.clone(s,h),c<r.y&&l.clone(s,r),c>A.y&&l.clone(s,A),g<a.z&&l.clone(s,a),g>d.z&&l.clone(s,d)}let _=l.magnitudeSquared(l.subtract(h,o,Js)),R=l.magnitudeSquared(l.subtract(A,r,Js)),I=l.magnitudeSquared(l.subtract(d,a,Js)),C=o,N=h,T=_;R>T&&(T=R,C=r,N=A),I>T&&(T=I,C=a,N=d);let b=hT;b.x=(C.x+N.x)*.5,b.y=(C.y+N.y)*.5,b.z=(C.z+N.z)*.5;let F=l.magnitudeSquared(l.subtract(N,b,Js)),B=Math.sqrt(F),U=cT;U.x=o.x,U.y=r.y,U.z=a.z;let Q=lT;Q.x=h.x,Q.y=A.y,Q.z=d.z;let M=l.midpoint(U,Q,dT),k=0;for(E=0;E<f;E+=i){s.x=t[E]+e.x,s.y=t[E+1]+e.y,s.z=t[E+2]+e.z;let y=l.magnitude(l.subtract(s,M,Js));y>k&&(k=y);let c=l.magnitudeSquared(l.subtract(s,b,Js));if(c>F){let g=Math.sqrt(c);B=(B+g)*.5,F=B*B;let O=g-B;b.x=(B*b.x+O*s.x)/g,b.y=(B*b.y+O*s.y)/g,b.z=(B*b.z+O*s.z)/g}}return B<k?(l.clone(b,n.center),n.radius=B):(l.clone(M,n.center),n.radius=k),n};Le.fromEncodedCartesianVertices=function(t,e,i){if(m(i)||(i=new Le),!m(t)||!m(e)||t.length!==e.length||t.length===0)return i.center=l.clone(l.ZERO,i.center),i.radius=0,i;let n=AT;n.x=t[0]+e[0],n.y=t[1]+e[1],n.z=t[2]+e[2];let s=l.clone(n,iT),o=l.clone(n,nT),r=l.clone(n,sT),a=l.clone(n,oT),h=l.clone(n,rT),A=l.clone(n,aT),d=t.length,f;for(f=0;f<d;f+=3){let k=t[f]+e[f],y=t[f+1]+e[f+1],c=t[f+2]+e[f+2];n.x=k,n.y=y,n.z=c,k<s.x&&l.clone(n,s),k>a.x&&l.clone(n,a),y<o.y&&l.clone(n,o),y>h.y&&l.clone(n,h),c<r.z&&l.clone(n,r),c>A.z&&l.clone(n,A)}let E=l.magnitudeSquared(l.subtract(a,s,Js)),_=l.magnitudeSquared(l.subtract(h,o,Js)),R=l.magnitudeSquared(l.subtract(A,r,Js)),I=s,C=a,N=E;_>N&&(N=_,I=o,C=h),R>N&&(N=R,I=r,C=A);let T=hT;T.x=(I.x+C.x)*.5,T.y=(I.y+C.y)*.5,T.z=(I.z+C.z)*.5;let b=l.magnitudeSquared(l.subtract(C,T,Js)),F=Math.sqrt(b),B=cT;B.x=s.x,B.y=o.y,B.z=r.z;let U=lT;U.x=a.x,U.y=h.y,U.z=A.z;let Q=l.midpoint(B,U,dT),M=0;for(f=0;f<d;f+=3){n.x=t[f]+e[f],n.y=t[f+1]+e[f+1],n.z=t[f+2]+e[f+2];let k=l.magnitude(l.subtract(n,Q,Js));k>M&&(M=k);let y=l.magnitudeSquared(l.subtract(n,T,Js));if(y>b){let c=Math.sqrt(y);F=(F+c)*.5,b=F*F;let g=c-F;T.x=(F*T.x+g*n.x)/c,T.y=(F*T.y+g*n.y)/c,T.z=(F*T.z+g*n.z)/c}}return F<M?(l.clone(T,i.center),i.radius=F):(l.clone(Q,i.center),i.radius=M),i};Le.fromCornerPoints=function(t,e,i){p.typeOf.object("corner",t),p.typeOf.object("oppositeCorner",e),m(i)||(i=new Le);let n=l.midpoint(t,e,i.center);return i.radius=l.distance(n,e),i};Le.fromEllipsoid=function(t,e){return p.typeOf.object("ellipsoid",t),m(e)||(e=new Le),l.clone(l.ZERO,e.center),e.radius=t.maximumRadius,e};G7=new l;Le.fromBoundingSpheres=function(t,e){if(m(e)||(e=new Le),!m(t)||t.length===0)return e.center=l.clone(l.ZERO,e.center),e.radius=0,e;let i=t.length;if(i===1)return Le.clone(t[0],e);if(i===2)return Le.union(t[0],t[1],e);let n=[],s;for(s=0;s<i;s++)n.push(t[s].center);e=Le.fromPoints(n,e);let o=e.center,r=e.radius;for(s=0;s<i;s++){let a=t[s];r=Math.max(r,l.distance(o,a.center,G7)+a.radius)}return e.radius=r,e};W7=new l,D7=new l,U7=new l;Le.fromOrientedBoundingBox=function(t,e){p.defined("orientedBoundingBox",t),m(e)||(e=new Le);let i=t.halfAxes,n=lt.getColumn(i,0,W7),s=lt.getColumn(i,1,D7),o=lt.getColumn(i,2,U7);return l.add(n,s,n),l.add(n,o,n),e.center=l.clone(t.center,e.center),e.radius=l.magnitude(n),e};M7=new l,Q7=new l;Le.fromTransformation=function(t,e){p.typeOf.object("transformation",t),m(e)||(e=new Le);let i=at.getTranslation(t,M7),n=at.getScale(t,Q7),s=.5*l.magnitude(n);return e.center=l.clone(i,e.center),e.radius=s,e};Le.clone=function(t,e){if(m(t))return m(e)?(e.center=l.clone(t.center,e.center),e.radius=t.radius,e):new Le(t.center,t.radius)};Le.packedLength=4;Le.pack=function(t,e,i){p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0);let n=t.center;return e[i++]=n.x,e[i++]=n.y,e[i++]=n.z,e[i]=t.radius,e};Le.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0),m(i)||(i=new Le);let n=i.center;return n.x=t[e++],n.y=t[e++],n.z=t[e++],i.radius=t[e],i};k7=new l,L7=new l;Le.union=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),m(i)||(i=new Le);let n=t.center,s=t.radius,o=e.center,r=e.radius,a=l.subtract(o,n,k7),h=l.magnitude(a);if(s>=h+r)return t.clone(i),i;if(r>=h+s)return e.clone(i),i;let A=(s+h+r)*.5,d=l.multiplyByScalar(a,(-s+A)/h,L7);return l.add(d,n,d),l.clone(d,i.center),i.radius=A,i};y7=new l;Le.expand=function(t,e,i){p.typeOf.object("sphere",t),p.typeOf.object("point",e),i=Le.clone(t,i);let n=l.magnitude(l.subtract(e,i.center,y7));return n>i.radius&&(i.radius=n),i};Le.intersectPlane=function(t,e){p.typeOf.object("sphere",t),p.typeOf.object("plane",e);let i=t.center,n=t.radius,s=e.normal,o=l.dot(s,i)+e.distance;return o<-n?Nn.OUTSIDE:o<n?Nn.INTERSECTING:Nn.INSIDE};Le.transform=function(t,e,i){return p.typeOf.object("sphere",t),p.typeOf.object("transform",e),m(i)||(i=new Le),i.center=at.multiplyByPoint(e,t.center,i.center),i.radius=at.getMaximumScale(e)*t.radius,i};w7=new l;Le.distanceSquaredTo=function(t,e){p.typeOf.object("sphere",t),p.typeOf.object("cartesian",e);let i=l.subtract(t.center,e,w7),n=l.magnitude(i)-t.radius;return n<=0?0:n*n};Le.transformWithoutScale=function(t,e,i){return p.typeOf.object("sphere",t),p.typeOf.object("transform",e),m(i)||(i=new Le),i.center=at.multiplyByPoint(e,t.center,i.center),i.radius=t.radius,i};x7=new l;Le.computePlaneDistances=function(t,e,i,n){p.typeOf.object("sphere",t),p.typeOf.object("position",e),p.typeOf.object("direction",i),m(n)||(n=new cA);let s=l.subtract(t.center,e,x7),o=l.dot(i,s);return n.start=o-t.radius,n.stop=o+t.radius,n};JW=new l,P7=new l,J7=new l,j7=new l,H7=new l,v7=new ut,jW=new Array(8);for(let t=0;t<8;++t)jW[t]=new l;z7=new Ss;Le.projectTo2D=function(t,e,i){p.typeOf.object("sphere",t),e=Z(e,z7);let n=e.ellipsoid,s=t.center,o=t.radius,r;l.equals(s,l.ZERO)?r=l.clone(l.UNIT_X,JW):r=n.geodeticSurfaceNormal(s,JW);let a=l.cross(l.UNIT_Z,r,P7);l.normalize(a,a);let h=l.cross(r,a,J7);l.normalize(h,h),l.multiplyByScalar(r,o,r),l.multiplyByScalar(h,o,h),l.multiplyByScalar(a,o,a);let A=l.negate(h,H7),d=l.negate(a,j7),f=jW,E=f[0];l.add(r,h,E),l.add(E,a,E),E=f[1],l.add(r,h,E),l.add(E,d,E),E=f[2],l.add(r,A,E),l.add(E,d,E),E=f[3],l.add(r,A,E),l.add(E,a,E),l.negate(r,r),E=f[4],l.add(r,h,E),l.add(E,a,E),E=f[5],l.add(r,h,E),l.add(E,d,E),E=f[6],l.add(r,A,E),l.add(E,d,E),E=f[7],l.add(r,A,E),l.add(E,a,E);let _=f.length;for(let N=0;N<_;++N){let T=f[N];l.add(s,T,T);let b=n.cartesianToCartographic(T,v7);e.project(b,T)}i=Le.fromPoints(f,i),s=i.center;let R=s.x,I=s.y,C=s.z;return s.x=C,s.y=R,s.z=I,i};Le.isOccluded=function(t,e){return p.typeOf.object("sphere",t),p.typeOf.object("occluder",e),!e.isBoundingSphereVisible(t)};Le.equals=function(t,e){return t===e||m(t)&&m(e)&&l.equals(t.center,e.center)&&t.radius===e.radius};Le.prototype.intersectPlane=function(t){return Le.intersectPlane(this,t)};Le.prototype.distanceSquaredTo=function(t){return Le.distanceSquaredTo(this,t)};Le.prototype.computePlaneDistances=function(t,e,i){return Le.computePlaneDistances(this,t,e,i)};Le.prototype.isOccluded=function(t){return Le.isOccluded(this,t)};Le.prototype.equals=function(t){return Le.equals(this,t)};Le.prototype.clone=function(t){return Le.clone(this,t)};Le.prototype.volume=function(){let t=this.radius;return Y7*t*t*t};Nt=Le});function lA(t,e){p.typeOf.object("ellipsoid",t),this._ellipsoid=t,this._cameraPosition=new l,this._cameraPositionInScaledSpace=new l,this._distanceToLimbInScaledSpaceSquared=0,m(e)&&(this.cameraPosition=e)}function zW(t,e,i){if(m(e)&&e<0&&t.minimumRadius>-e){let n=l.fromElements(t.radii.x+e,t.radii.y+e,t.radii.z+e,q7);t=ot.fromCartesian3(n,i)}return t}function KW(t,e,i,n){p.typeOf.object("directionToPoint",e),p.defined("positions",i),m(n)||(n=new l);let s=tD(t,e),o=0;for(let r=0,a=i.length;r<a;++r){let h=i[r],A=qW(t,h,s);if(A<0)return;o=Math.max(o,A)}return $W(s,o,n)}function XW(t,e,i,n,s,o){p.typeOf.object("directionToPoint",e),p.defined("vertices",i),p.typeOf.number("stride",n),m(o)||(o=new l),n=Z(n,3),s=Z(s,l.ZERO);let r=tD(t,e),a=0;for(let h=0,A=i.length;h<A;h+=n){vZ.x=i[h]+s.x,vZ.y=i[h+1]+s.y,vZ.z=i[h+2]+s.z;let d=qW(t,vZ,r);if(d<0)return;a=Math.max(a,d)}return $W(r,a,o)}function fT(t,e,i){let n=e,s=i,o=l.subtract(t,n,HW),r=-l.dot(o,n);return!(s<0?r>0:r>s&&r*r/l.magnitudeSquared(o)>s)}function qW(t,e,i){let n=t.transformPositionToScaledSpace(e,$7),s=l.magnitudeSquared(n),o=Math.sqrt(s),r=l.divideByScalar(n,o,t$);s=Math.max(1,s),o=Math.max(1,o);let a=l.dot(r,i),h=l.magnitude(l.cross(r,i,r)),A=1/o,d=Math.sqrt(s-1)*A;return 1/(a*A-h*d)}function $W(t,e,i){if(!(e<=0||e===1/0||e!==e))return l.multiplyByScalar(t,e,i)}function tD(t,e){return l.equals(e,l.ZERO)?e:(t.transformPositionToScaledSpace(e,mT),l.normalize(mT,mT))}var HW,K7,vW,X7,q7,vZ,$7,t$,mT,dA,Vm=S(()=>{_i();Ht();ae();Ft();mt();Oe();pn();Object.defineProperties(lA.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},cameraPosition:{get:function(){return this._cameraPosition},set:function(t){let i=this._ellipsoid.transformPositionToScaledSpace(t,this._cameraPositionInScaledSpace),n=l.magnitudeSquared(i)-1;l.clone(t,this._cameraPosition),this._cameraPositionInScaledSpace=i,this._distanceToLimbInScaledSpaceSquared=n}}});HW=new l;lA.prototype.isPointVisible=function(t){let i=this._ellipsoid.transformPositionToScaledSpace(t,HW);return fT(i,this._cameraPositionInScaledSpace,this._distanceToLimbInScaledSpaceSquared)};lA.prototype.isScaledSpacePointVisible=function(t){return fT(t,this._cameraPositionInScaledSpace,this._distanceToLimbInScaledSpaceSquared)};K7=new l;lA.prototype.isScaledSpacePointVisiblePossiblyUnderEllipsoid=function(t,e){let i=this._ellipsoid,n,s;return m(e)&&e<0&&i.minimumRadius>-e?(s=K7,s.x=this._cameraPosition.x/(i.radii.x+e),s.y=this._cameraPosition.y/(i.radii.y+e),s.z=this._cameraPosition.z/(i.radii.z+e),n=s.x*s.x+s.y*s.y+s.z*s.z-1):(s=this._cameraPositionInScaledSpace,n=this._distanceToLimbInScaledSpaceSquared),fT(t,s,n)};lA.prototype.computeHorizonCullingPoint=function(t,e,i){return KW(this._ellipsoid,t,e,i)};vW=ot.clone(ot.UNIT_SPHERE);lA.prototype.computeHorizonCullingPointPossiblyUnderEllipsoid=function(t,e,i,n){let s=zW(this._ellipsoid,i,vW);return KW(s,t,e,n)};lA.prototype.computeHorizonCullingPointFromVertices=function(t,e,i,n,s){return XW(this._ellipsoid,t,e,i,n,s)};lA.prototype.computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid=function(t,e,i,n,s,o){let r=zW(this._ellipsoid,s,vW);return XW(r,t,e,i,n,o)};X7=[];lA.prototype.computeHorizonCullingPointFromRectangle=function(t,e,i){p.typeOf.object("rectangle",t);let n=Xt.subsample(t,e,0,X7),s=Nt.fromPoints(n);if(!(l.magnitude(s.center)<.1*e.minimumRadius))return this.computeHorizonCullingPoint(s.center,n,i)};q7=new l;vZ=new l;$7=new l,t$=new l;mT=new l;dA=lA});function ET(t,e,i){return i<0&&(i+=1),i>1&&(i-=1),i*6<1?t+(e-t)*6*i:i*2<1?e:i*3<2?t+(e-t)*(2/3-i)*6:t}function q(t,e,i,n){this.red=Z(t,1),this.green=Z(e,1),this.blue=Z(i,1),this.alpha=Z(n,1)}var _T,RT,eh,e$,i$,n$,s$,Zt,Qn=S(()=>{ae();Ft();mt();Il();_e();q.fromCartesian4=function(t,e){return p.typeOf.object("cartesian",t),m(e)?(e.red=t.x,e.green=t.y,e.blue=t.z,e.alpha=t.w,e):new q(t.x,t.y,t.z,t.w)};q.fromBytes=function(t,e,i,n,s){return t=q.byteToFloat(Z(t,255)),e=q.byteToFloat(Z(e,255)),i=q.byteToFloat(Z(i,255)),n=q.byteToFloat(Z(n,255)),m(s)?(s.red=t,s.green=e,s.blue=i,s.alpha=n,s):new q(t,e,i,n)};q.fromAlpha=function(t,e,i){return p.typeOf.object("color",t),p.typeOf.number("alpha",e),m(i)?(i.red=t.red,i.green=t.green,i.blue=t.blue,i.alpha=e,i):new q(t.red,t.green,t.blue,e)};_o.supportsTypedArrays()&&(_T=new ArrayBuffer(4),RT=new Uint32Array(_T),eh=new Uint8Array(_T));q.fromRgba=function(t,e){return RT[0]=t,q.fromBytes(eh[0],eh[1],eh[2],eh[3],e)};q.fromHsl=function(t,e,i,n,s){t=Z(t,0)%1,e=Z(e,0),i=Z(i,0),n=Z(n,1);let o=i,r=i,a=i;if(e!==0){let h;i<.5?h=i*(1+e):h=i+e-i*e;let A=2*i-h;o=ET(A,h,t+1/3),r=ET(A,h,t),a=ET(A,h,t-1/3)}return m(s)?(s.red=o,s.green=r,s.blue=a,s.alpha=n,s):new q(o,r,a,n)};q.fromRandom=function(t,e){t=Z(t,Z.EMPTY_OBJECT);let i=t.red;if(!m(i)){let r=Z(t.minimumRed,0),a=Z(t.maximumRed,1);p.typeOf.number.lessThanOrEquals("minimumRed",r,a),i=r+L.nextRandomNumber()*(a-r)}let n=t.green;if(!m(n)){let r=Z(t.minimumGreen,0),a=Z(t.maximumGreen,1);p.typeOf.number.lessThanOrEquals("minimumGreen",r,a),n=r+L.nextRandomNumber()*(a-r)}let s=t.blue;if(!m(s)){let r=Z(t.minimumBlue,0),a=Z(t.maximumBlue,1);p.typeOf.number.lessThanOrEquals("minimumBlue",r,a),s=r+L.nextRandomNumber()*(a-r)}let o=t.alpha;if(!m(o)){let r=Z(t.minimumAlpha,0),a=Z(t.maximumAlpha,1);p.typeOf.number.lessThanOrEquals("minumumAlpha",r,a),o=r+L.nextRandomNumber()*(a-r)}return m(e)?(e.red=i,e.green=n,e.blue=s,e.alpha=o,e):new q(i,n,s,o)};e$=/^#([0-9a-f])([0-9a-f])([0-9a-f])([0-9a-f])?$/i,i$=/^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})?$/i,n$=/^rgba?\s*\(\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i,s$=/^hsla?\s*\(\s*([0-9.]+)\s*[,\s]+\s*([0-9.]+%)\s*[,\s]+\s*([0-9.]+%)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i;q.fromCssColorString=function(t,e){p.typeOf.string("color",t),m(e)||(e=new q),t=t.trim();let i=q[t.toUpperCase()];if(m(i))return q.clone(i,e),e;let n=e$.exec(t);return n!==null?(e.red=parseInt(n[1],16)/15,e.green=parseInt(n[2],16)/15,e.blue=parseInt(n[3],16)/15,e.alpha=parseInt(Z(n[4],"f"),16)/15,e):(n=i$.exec(t),n!==null?(e.red=parseInt(n[1],16)/255,e.green=parseInt(n[2],16)/255,e.blue=parseInt(n[3],16)/255,e.alpha=parseInt(Z(n[4],"ff"),16)/255,e):(n=n$.exec(t),n!==null?(e.red=parseFloat(n[1])/(n[1].substr(-1)==="%"?100:255),e.green=parseFloat(n[2])/(n[2].substr(-1)==="%"?100:255),e.blue=parseFloat(n[3])/(n[3].substr(-1)==="%"?100:255),e.alpha=parseFloat(Z(n[4],"1.0")),e):(n=s$.exec(t),n!==null?q.fromHsl(parseFloat(n[1])/360,parseFloat(n[2])/100,parseFloat(n[3])/100,parseFloat(Z(n[4],"1.0")),e):(e=void 0,e))))};q.packedLength=4;q.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.red,e[i++]=t.green,e[i++]=t.blue,e[i]=t.alpha,e};q.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new q),i.red=t[e++],i.green=t[e++],i.blue=t[e++],i.alpha=t[e],i};q.byteToFloat=function(t){return t/255};q.floatToByte=function(t){return t===1?255:t*256|0};q.clone=function(t,e){if(m(t))return m(e)?(e.red=t.red,e.green=t.green,e.blue=t.blue,e.alpha=t.alpha,e):new q(t.red,t.green,t.blue,t.alpha)};q.equals=function(t,e){return t===e||m(t)&&m(e)&&t.red===e.red&&t.green===e.green&&t.blue===e.blue&&t.alpha===e.alpha};q.equalsArray=function(t,e,i){return t.red===e[i]&&t.green===e[i+1]&&t.blue===e[i+2]&&t.alpha===e[i+3]};q.prototype.clone=function(t){return q.clone(this,t)};q.prototype.equals=function(t){return q.equals(this,t)};q.prototype.equalsEpsilon=function(t,e){return this===t||m(t)&&Math.abs(this.red-t.red)<=e&&Math.abs(this.green-t.green)<=e&&Math.abs(this.blue-t.blue)<=e&&Math.abs(this.alpha-t.alpha)<=e};q.prototype.toString=function(){return`(${this.red}, ${this.green}, ${this.blue}, ${this.alpha})`};q.prototype.toCssColorString=function(){let t=q.floatToByte(this.red),e=q.floatToByte(this.green),i=q.floatToByte(this.blue);return this.alpha===1?`rgb(${t},${e},${i})`:`rgba(${t},${e},${i},${this.alpha})`};q.prototype.toCssHexString=function(){let t=q.floatToByte(this.red).toString(16);t.length<2&&(t=`0${t}`);let e=q.floatToByte(this.green).toString(16);e.length<2&&(e=`0${e}`);let i=q.floatToByte(this.blue).toString(16);if(i.length<2&&(i=`0${i}`),this.alpha<1){let n=q.floatToByte(this.alpha).toString(16);return n.length<2&&(n=`0${n}`),`#${t}${e}${i}${n}`}return`#${t}${e}${i}`};q.prototype.toBytes=function(t){let e=q.floatToByte(this.red),i=q.floatToByte(this.green),n=q.floatToByte(this.blue),s=q.floatToByte(this.alpha);return m(t)?(t[0]=e,t[1]=i,t[2]=n,t[3]=s,t):[e,i,n,s]};q.prototype.toRgba=function(){return eh[0]=q.floatToByte(this.red),eh[1]=q.floatToByte(this.green),eh[2]=q.floatToByte(this.blue),eh[3]=q.floatToByte(this.alpha),RT[0]};q.prototype.brighten=function(t,e){return p.typeOf.number("magnitude",t),p.typeOf.number.greaterThanOrEquals("magnitude",t,0),p.typeOf.object("result",e),t=1-t,e.red=1-(1-this.red)*t,e.green=1-(1-this.green)*t,e.blue=1-(1-this.blue)*t,e.alpha=this.alpha,e};q.prototype.darken=function(t,e){return p.typeOf.number("magnitude",t),p.typeOf.number.greaterThanOrEquals("magnitude",t,0),p.typeOf.object("result",e),t=1-t,e.red=this.red*t,e.green=this.green*t,e.blue=this.blue*t,e.alpha=this.alpha,e};q.prototype.withAlpha=function(t,e){return q.fromAlpha(this,t,e)};q.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.red=t.red+e.red,i.green=t.green+e.green,i.blue=t.blue+e.blue,i.alpha=t.alpha+e.alpha,i};q.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.red=t.red-e.red,i.green=t.green-e.green,i.blue=t.blue-e.blue,i.alpha=t.alpha-e.alpha,i};q.multiply=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.red=t.red*e.red,i.green=t.green*e.green,i.blue=t.blue*e.blue,i.alpha=t.alpha*e.alpha,i};q.divide=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.red=t.red/e.red,i.green=t.green/e.green,i.blue=t.blue/e.blue,i.alpha=t.alpha/e.alpha,i};q.mod=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i.red=t.red%e.red,i.green=t.green%e.green,i.blue=t.blue%e.blue,i.alpha=t.alpha%e.alpha,i};q.lerp=function(t,e,i,n){return p.typeOf.object("start",t),p.typeOf.object("end",e),p.typeOf.number("t",i),p.typeOf.object("result",n),n.red=L.lerp(t.red,e.red,i),n.green=L.lerp(t.green,e.green,i),n.blue=L.lerp(t.blue,e.blue,i),n.alpha=L.lerp(t.alpha,e.alpha,i),n};q.multiplyByScalar=function(t,e,i){return p.typeOf.object("color",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.red=t.red*e,i.green=t.green*e,i.blue=t.blue*e,i.alpha=t.alpha*e,i};q.divideByScalar=function(t,e,i){return p.typeOf.object("color",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i.red=t.red/e,i.green=t.green/e,i.blue=t.blue/e,i.alpha=t.alpha/e,i};q.ALICEBLUE=Object.freeze(q.fromCssColorString("#F0F8FF"));q.ANTIQUEWHITE=Object.freeze(q.fromCssColorString("#FAEBD7"));q.AQUA=Object.freeze(q.fromCssColorString("#00FFFF"));q.AQUAMARINE=Object.freeze(q.fromCssColorString("#7FFFD4"));q.AZURE=Object.freeze(q.fromCssColorString("#F0FFFF"));q.BEIGE=Object.freeze(q.fromCssColorString("#F5F5DC"));q.BISQUE=Object.freeze(q.fromCssColorString("#FFE4C4"));q.BLACK=Object.freeze(q.fromCssColorString("#000000"));q.BLANCHEDALMOND=Object.freeze(q.fromCssColorString("#FFEBCD"));q.BLUE=Object.freeze(q.fromCssColorString("#0000FF"));q.BLUEVIOLET=Object.freeze(q.fromCssColorString("#8A2BE2"));q.BROWN=Object.freeze(q.fromCssColorString("#A52A2A"));q.BURLYWOOD=Object.freeze(q.fromCssColorString("#DEB887"));q.CADETBLUE=Object.freeze(q.fromCssColorString("#5F9EA0"));q.CHARTREUSE=Object.freeze(q.fromCssColorString("#7FFF00"));q.CHOCOLATE=Object.freeze(q.fromCssColorString("#D2691E"));q.CORAL=Object.freeze(q.fromCssColorString("#FF7F50"));q.CORNFLOWERBLUE=Object.freeze(q.fromCssColorString("#6495ED"));q.CORNSILK=Object.freeze(q.fromCssColorString("#FFF8DC"));q.CRIMSON=Object.freeze(q.fromCssColorString("#DC143C"));q.CYAN=Object.freeze(q.fromCssColorString("#00FFFF"));q.DARKBLUE=Object.freeze(q.fromCssColorString("#00008B"));q.DARKCYAN=Object.freeze(q.fromCssColorString("#008B8B"));q.DARKGOLDENROD=Object.freeze(q.fromCssColorString("#B8860B"));q.DARKGRAY=Object.freeze(q.fromCssColorString("#A9A9A9"));q.DARKGREEN=Object.freeze(q.fromCssColorString("#006400"));q.DARKGREY=q.DARKGRAY;q.DARKKHAKI=Object.freeze(q.fromCssColorString("#BDB76B"));q.DARKMAGENTA=Object.freeze(q.fromCssColorString("#8B008B"));q.DARKOLIVEGREEN=Object.freeze(q.fromCssColorString("#556B2F"));q.DARKORANGE=Object.freeze(q.fromCssColorString("#FF8C00"));q.DARKORCHID=Object.freeze(q.fromCssColorString("#9932CC"));q.DARKRED=Object.freeze(q.fromCssColorString("#8B0000"));q.DARKSALMON=Object.freeze(q.fromCssColorString("#E9967A"));q.DARKSEAGREEN=Object.freeze(q.fromCssColorString("#8FBC8F"));q.DARKSLATEBLUE=Object.freeze(q.fromCssColorString("#483D8B"));q.DARKSLATEGRAY=Object.freeze(q.fromCssColorString("#2F4F4F"));q.DARKSLATEGREY=q.DARKSLATEGRAY;q.DARKTURQUOISE=Object.freeze(q.fromCssColorString("#00CED1"));q.DARKVIOLET=Object.freeze(q.fromCssColorString("#9400D3"));q.DEEPPINK=Object.freeze(q.fromCssColorString("#FF1493"));q.DEEPSKYBLUE=Object.freeze(q.fromCssColorString("#00BFFF"));q.DIMGRAY=Object.freeze(q.fromCssColorString("#696969"));q.DIMGREY=q.DIMGRAY;q.DODGERBLUE=Object.freeze(q.fromCssColorString("#1E90FF"));q.FIREBRICK=Object.freeze(q.fromCssColorString("#B22222"));q.FLORALWHITE=Object.freeze(q.fromCssColorString("#FFFAF0"));q.FORESTGREEN=Object.freeze(q.fromCssColorString("#228B22"));q.FUCHSIA=Object.freeze(q.fromCssColorString("#FF00FF"));q.GAINSBORO=Object.freeze(q.fromCssColorString("#DCDCDC"));q.GHOSTWHITE=Object.freeze(q.fromCssColorString("#F8F8FF"));q.GOLD=Object.freeze(q.fromCssColorString("#FFD700"));q.GOLDENROD=Object.freeze(q.fromCssColorString("#DAA520"));q.GRAY=Object.freeze(q.fromCssColorString("#808080"));q.GREEN=Object.freeze(q.fromCssColorString("#008000"));q.GREENYELLOW=Object.freeze(q.fromCssColorString("#ADFF2F"));q.GREY=q.GRAY;q.HONEYDEW=Object.freeze(q.fromCssColorString("#F0FFF0"));q.HOTPINK=Object.freeze(q.fromCssColorString("#FF69B4"));q.INDIANRED=Object.freeze(q.fromCssColorString("#CD5C5C"));q.INDIGO=Object.freeze(q.fromCssColorString("#4B0082"));q.IVORY=Object.freeze(q.fromCssColorString("#FFFFF0"));q.KHAKI=Object.freeze(q.fromCssColorString("#F0E68C"));q.LAVENDER=Object.freeze(q.fromCssColorString("#E6E6FA"));q.LAVENDAR_BLUSH=Object.freeze(q.fromCssColorString("#FFF0F5"));q.LAWNGREEN=Object.freeze(q.fromCssColorString("#7CFC00"));q.LEMONCHIFFON=Object.freeze(q.fromCssColorString("#FFFACD"));q.LIGHTBLUE=Object.freeze(q.fromCssColorString("#ADD8E6"));q.LIGHTCORAL=Object.freeze(q.fromCssColorString("#F08080"));q.LIGHTCYAN=Object.freeze(q.fromCssColorString("#E0FFFF"));q.LIGHTGOLDENRODYELLOW=Object.freeze(q.fromCssColorString("#FAFAD2"));q.LIGHTGRAY=Object.freeze(q.fromCssColorString("#D3D3D3"));q.LIGHTGREEN=Object.freeze(q.fromCssColorString("#90EE90"));q.LIGHTGREY=q.LIGHTGRAY;q.LIGHTPINK=Object.freeze(q.fromCssColorString("#FFB6C1"));q.LIGHTSEAGREEN=Object.freeze(q.fromCssColorString("#20B2AA"));q.LIGHTSKYBLUE=Object.freeze(q.fromCssColorString("#87CEFA"));q.LIGHTSLATEGRAY=Object.freeze(q.fromCssColorString("#778899"));q.LIGHTSLATEGREY=q.LIGHTSLATEGRAY;q.LIGHTSTEELBLUE=Object.freeze(q.fromCssColorString("#B0C4DE"));q.LIGHTYELLOW=Object.freeze(q.fromCssColorString("#FFFFE0"));q.LIME=Object.freeze(q.fromCssColorString("#00FF00"));q.LIMEGREEN=Object.freeze(q.fromCssColorString("#32CD32"));q.LINEN=Object.freeze(q.fromCssColorString("#FAF0E6"));q.MAGENTA=Object.freeze(q.fromCssColorString("#FF00FF"));q.MAROON=Object.freeze(q.fromCssColorString("#800000"));q.MEDIUMAQUAMARINE=Object.freeze(q.fromCssColorString("#66CDAA"));q.MEDIUMBLUE=Object.freeze(q.fromCssColorString("#0000CD"));q.MEDIUMORCHID=Object.freeze(q.fromCssColorString("#BA55D3"));q.MEDIUMPURPLE=Object.freeze(q.fromCssColorString("#9370DB"));q.MEDIUMSEAGREEN=Object.freeze(q.fromCssColorString("#3CB371"));q.MEDIUMSLATEBLUE=Object.freeze(q.fromCssColorString("#7B68EE"));q.MEDIUMSPRINGGREEN=Object.freeze(q.fromCssColorString("#00FA9A"));q.MEDIUMTURQUOISE=Object.freeze(q.fromCssColorString("#48D1CC"));q.MEDIUMVIOLETRED=Object.freeze(q.fromCssColorString("#C71585"));q.MIDNIGHTBLUE=Object.freeze(q.fromCssColorString("#191970"));q.MINTCREAM=Object.freeze(q.fromCssColorString("#F5FFFA"));q.MISTYROSE=Object.freeze(q.fromCssColorString("#FFE4E1"));q.MOCCASIN=Object.freeze(q.fromCssColorString("#FFE4B5"));q.NAVAJOWHITE=Object.freeze(q.fromCssColorString("#FFDEAD"));q.NAVY=Object.freeze(q.fromCssColorString("#000080"));q.OLDLACE=Object.freeze(q.fromCssColorString("#FDF5E6"));q.OLIVE=Object.freeze(q.fromCssColorString("#808000"));q.OLIVEDRAB=Object.freeze(q.fromCssColorString("#6B8E23"));q.ORANGE=Object.freeze(q.fromCssColorString("#FFA500"));q.ORANGERED=Object.freeze(q.fromCssColorString("#FF4500"));q.ORCHID=Object.freeze(q.fromCssColorString("#DA70D6"));q.PALEGOLDENROD=Object.freeze(q.fromCssColorString("#EEE8AA"));q.PALEGREEN=Object.freeze(q.fromCssColorString("#98FB98"));q.PALETURQUOISE=Object.freeze(q.fromCssColorString("#AFEEEE"));q.PALEVIOLETRED=Object.freeze(q.fromCssColorString("#DB7093"));q.PAPAYAWHIP=Object.freeze(q.fromCssColorString("#FFEFD5"));q.PEACHPUFF=Object.freeze(q.fromCssColorString("#FFDAB9"));q.PERU=Object.freeze(q.fromCssColorString("#CD853F"));q.PINK=Object.freeze(q.fromCssColorString("#FFC0CB"));q.PLUM=Object.freeze(q.fromCssColorString("#DDA0DD"));q.POWDERBLUE=Object.freeze(q.fromCssColorString("#B0E0E6"));q.PURPLE=Object.freeze(q.fromCssColorString("#800080"));q.RED=Object.freeze(q.fromCssColorString("#FF0000"));q.ROSYBROWN=Object.freeze(q.fromCssColorString("#BC8F8F"));q.ROYALBLUE=Object.freeze(q.fromCssColorString("#4169E1"));q.SADDLEBROWN=Object.freeze(q.fromCssColorString("#8B4513"));q.SALMON=Object.freeze(q.fromCssColorString("#FA8072"));q.SANDYBROWN=Object.freeze(q.fromCssColorString("#F4A460"));q.SEAGREEN=Object.freeze(q.fromCssColorString("#2E8B57"));q.SEASHELL=Object.freeze(q.fromCssColorString("#FFF5EE"));q.SIENNA=Object.freeze(q.fromCssColorString("#A0522D"));q.SILVER=Object.freeze(q.fromCssColorString("#C0C0C0"));q.SKYBLUE=Object.freeze(q.fromCssColorString("#87CEEB"));q.SLATEBLUE=Object.freeze(q.fromCssColorString("#6A5ACD"));q.SLATEGRAY=Object.freeze(q.fromCssColorString("#708090"));q.SLATEGREY=q.SLATEGRAY;q.SNOW=Object.freeze(q.fromCssColorString("#FFFAFA"));q.SPRINGGREEN=Object.freeze(q.fromCssColorString("#00FF7F"));q.STEELBLUE=Object.freeze(q.fromCssColorString("#4682B4"));q.TAN=Object.freeze(q.fromCssColorString("#D2B48C"));q.TEAL=Object.freeze(q.fromCssColorString("#008080"));q.THISTLE=Object.freeze(q.fromCssColorString("#D8BFD8"));q.TOMATO=Object.freeze(q.fromCssColorString("#FF6347"));q.TURQUOISE=Object.freeze(q.fromCssColorString("#40E0D0"));q.VIOLET=Object.freeze(q.fromCssColorString("#EE82EE"));q.WHEAT=Object.freeze(q.fromCssColorString("#F5DEB3"));q.WHITE=Object.freeze(q.fromCssColorString("#FFFFFF"));q.WHITESMOKE=Object.freeze(q.fromCssColorString("#F5F5F5"));q.YELLOW=Object.freeze(q.fromCssColorString("#FFFF00"));q.YELLOWGREEN=Object.freeze(q.fromCssColorString("#9ACD32"));q.TRANSPARENT=Object.freeze(new q(0,0,0,0));Zt=q});function o$(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(t){let e=Math.random()*16|0;return(t==="x"?e:e&3|8).toString(16)})}var Bs,ih=S(()=>{Bs=o$});function _r(t,e){t=Z(t,0),this._near=t,e=Z(e,Number.MAX_VALUE),this._far=e}var Wo,zZ=S(()=>{Ft();mt();Ot();Object.defineProperties(_r.prototype,{near:{get:function(){return this._near},set:function(t){this._near=t}},far:{get:function(){return this._far},set:function(t){this._far=t}}});_r.packedLength=2;_r.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),e[i++]=t.near,e[i]=t.far,e};_r.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");return e=Z(e,0),m(i)||(i=new _r),i.near=t[e++],i.far=t[e],i};_r.equals=function(t,e){return t===e||m(t)&&m(e)&&t.near===e.near&&t.far===e.far};_r.clone=function(t,e){if(m(t))return m(e)||(e=new _r),e.near=t.near,e.far=t.far,e};_r.prototype.clone=function(t){return _r.clone(this,t)};_r.prototype.equals=function(t){return _r.equals(this,t)};Wo=_r});function Gr(t,e,i,n){this.near=Z(t,0),this.nearValue=Z(e,0),this.far=Z(i,1),this.farValue=Z(n,0)}var gi,IE=S(()=>{Ft();mt();Ot();Gr.clone=function(t,e){if(m(t))return m(e)?(e.near=t.near,e.nearValue=t.nearValue,e.far=t.far,e.farValue=t.farValue,e):new Gr(t.near,t.nearValue,t.far,t.farValue)};Gr.packedLength=4;Gr.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),e[i++]=t.near,e[i++]=t.nearValue,e[i++]=t.far,e[i]=t.farValue,e};Gr.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");return e=Z(e,0),m(i)||(i=new Gr),i.near=t[e++],i.nearValue=t[e++],i.far=t[e++],i.farValue=t[e],i};Gr.equals=function(t,e){return t===e||m(t)&&m(e)&&t.near===e.near&&t.nearValue===e.nearValue&&t.far===e.far&&t.farValue===e.farValue};Gr.prototype.clone=function(t){return Gr.clone(this,t)};Gr.prototype.equals=function(t){return Gr.equals(this,t)};gi=Gr});function gl(t){return t===Cl.CLAMP_TO_GROUND||t===Cl.CLAMP_TO_3D_TILE||t===Cl.CLAMP_TO_TERRAIN}function eD(t){return t===Cl.RELATIVE_TO_GROUND||t===Cl.RELATIVE_TO_3D_TILE||t===Cl.RELATIVE_TO_TERRAIN}var Cl,Wr,Sm=S(()=>{Cl={NONE:0,CLAMP_TO_GROUND:1,RELATIVE_TO_GROUND:2,CLAMP_TO_TERRAIN:3,RELATIVE_TO_TERRAIN:4,CLAMP_TO_3D_TILE:5,RELATIVE_TO_3D_TILE:6},Wr=Object.freeze(Cl)});var r$,to,Om=S(()=>{r$={CENTER:0,LEFT:1,RIGHT:-1},to=Object.freeze(r$)});var KZ,ye,ua=S(()=>{KZ={MORPHING:0,COLUMBUS_VIEW:1,SCENE2D:2,SCENE3D:3};KZ.getMorphTime=function(t){return t===KZ.SCENE3D?1:t===KZ.MORPHING?void 0:0};ye=Object.freeze(KZ)});function Gs(t,e){if(p.typeOf.object("normal",t),!L.equalsEpsilon(l.magnitude(t),1,L.EPSILON6))throw new Y("normal must be normalized.");p.typeOf.number("distance",e),this.normal=l.clone(t),this.distance=e}var a$,A$,h$,c$,l$,Ki,nh=S(()=>{Ht();Os();ae();mt();Ot();_e();bi();Gs.fromPointNormal=function(t,e,i){if(p.typeOf.object("point",t),p.typeOf.object("normal",e),!L.equalsEpsilon(l.magnitude(e),1,L.EPSILON6))throw new Y("normal must be normalized.");let n=-l.dot(e,t);return m(i)?(l.clone(e,i.normal),i.distance=n,i):new Gs(e,n)};a$=new l;Gs.fromCartesian4=function(t,e){p.typeOf.object("coefficients",t);let i=l.fromCartesian4(t,a$),n=t.w;if(!L.equalsEpsilon(l.magnitude(i),1,L.EPSILON6))throw new Y("normal must be normalized.");return m(e)?(l.clone(i,e.normal),e.distance=n,e):new Gs(i,n)};Gs.getPointDistance=function(t,e){return p.typeOf.object("plane",t),p.typeOf.object("point",e),l.dot(t.normal,e)+t.distance};A$=new l;Gs.projectPointOntoPlane=function(t,e,i){p.typeOf.object("plane",t),p.typeOf.object("point",e),m(i)||(i=new l);let n=Gs.getPointDistance(t,e),s=l.multiplyByScalar(t.normal,n,A$);return l.subtract(e,s,i)};h$=new at,c$=new ie,l$=new l;Gs.transform=function(t,e,i){p.typeOf.object("plane",t),p.typeOf.object("transform",e);let n=t.normal,s=t.distance,o=at.inverseTranspose(e,h$),r=ie.fromElements(n.x,n.y,n.z,s,c$);r=at.multiplyByVector(o,r,r);let a=l.fromCartesian4(r,l$);return r=ie.divideByScalar(r,l.magnitude(a),r),Gs.fromCartesian4(r,i)};Gs.clone=function(t,e){return p.typeOf.object("plane",t),m(e)?(l.clone(t.normal,e.normal),e.distance=t.distance,e):new Gs(t.normal,t.distance)};Gs.equals=function(t,e){return p.typeOf.object("left",t),p.typeOf.object("right",e),t.distance===e.distance&&l.equals(t.normal,e.normal)};Gs.ORIGIN_XY_PLANE=Object.freeze(new Gs(l.UNIT_Z,0));Gs.ORIGIN_YZ_PLANE=Object.freeze(new Gs(l.UNIT_X,0));Gs.ORIGIN_ZX_PLANE=Object.freeze(new Gs(l.UNIT_Y,0));Ki=Gs});function Dr(t){this.planes=Z(t,[])}var pE,cc,d$,iD,XZ,ZT=S(()=>{Ht();Os();Ft();mt();Ot();nc();nh();pE=[new l,new l,new l];l.clone(l.UNIT_X,pE[0]);l.clone(l.UNIT_Y,pE[1]);l.clone(l.UNIT_Z,pE[2]);cc=new l,d$=new l,iD=new Ki(new l(1,0,0),0);Dr.fromBoundingSphere=function(t,e){if(!m(t))throw new Y("boundingSphere is required.");m(e)||(e=new Dr);let i=pE.length,n=e.planes;n.length=2*i;let s=t.center,o=t.radius,r=0;for(let a=0;a<i;++a){let h=pE[a],A=n[r],d=n[r+1];m(A)||(A=n[r]=new ie),m(d)||(d=n[r+1]=new ie),l.multiplyByScalar(h,-o,cc),l.add(s,cc,cc),A.x=h.x,A.y=h.y,A.z=h.z,A.w=-l.dot(h,cc),l.multiplyByScalar(h,o,cc),l.add(s,cc,cc),d.x=-h.x,d.y=-h.y,d.z=-h.z,d.w=-l.dot(l.negate(h,d$),cc),r+=2}return e};Dr.prototype.computeVisibility=function(t){if(!m(t))throw new Y("boundingVolume is required.");let e=this.planes,i=!1;for(let n=0,s=e.length;n<s;++n){let o=t.intersectPlane(Ki.fromCartesian4(e[n],iD));if(o===Nn.OUTSIDE)return Nn.OUTSIDE;o===Nn.INTERSECTING&&(i=!0)}return i?Nn.INTERSECTING:Nn.INSIDE};Dr.prototype.computeVisibilityWithPlaneMask=function(t,e){if(!m(t))throw new Y("boundingVolume is required.");if(!m(e))throw new Y("parentPlaneMask is required.");if(e===Dr.MASK_OUTSIDE||e===Dr.MASK_INSIDE)return e;let i=Dr.MASK_INSIDE,n=this.planes;for(let s=0,o=n.length;s<o;++s){let r=s<31?1<<s:0;if(s<31&&!(e&r))continue;let a=t.intersectPlane(Ki.fromCartesian4(n[s],iD));if(a===Nn.OUTSIDE)return Dr.MASK_OUTSIDE;a===Nn.INTERSECTING&&(i|=r)}return i};Dr.MASK_OUTSIDE=4294967295;Dr.MASK_INSIDE=0;Dr.MASK_INDETERMINATE=2147483647;XZ=Dr});function mA(t){t=Z(t,Z.EMPTY_OBJECT),this.left=t.left,this._left=void 0,this.right=t.right,this._right=void 0,this.top=t.top,this._top=void 0,this.bottom=t.bottom,this._bottom=void 0,this.near=Z(t.near,1),this._near=this.near,this.far=Z(t.far,5e8),this._far=this.far,this._cullingVolume=new XZ,this._orthographicMatrix=new at}function nD(t){if(!m(t.right)||!m(t.left)||!m(t.top)||!m(t.bottom)||!m(t.near)||!m(t.far))throw new Y("right, left, top, bottom, near, or far parameters are not set.");if(t.top!==t._top||t.bottom!==t._bottom||t.left!==t._left||t.right!==t._right||t.near!==t._near||t.far!==t._far){if(t.left>t.right)throw new Y("right must be greater than left.");if(t.bottom>t.top)throw new Y("top must be greater than bottom.");if(t.near<=0||t.near>t.far)throw new Y("near must be greater than zero and less than far.");t._left=t.left,t._right=t.right,t._top=t.top,t._bottom=t.bottom,t._near=t.near,t._far=t.far,t._orthographicMatrix=at.computeOrthographicOffCenter(t.left,t.right,t.bottom,t.top,t.near,t.far,t._orthographicMatrix)}}var m$,f$,E$,IT,qZ,pT=S(()=>{Ht();Os();ZT();Ft();mt();Ot();_e();bi();Object.defineProperties(mA.prototype,{projectionMatrix:{get:function(){return nD(this),this._orthographicMatrix}}});m$=new l,f$=new l,E$=new l,IT=new l;mA.prototype.computeCullingVolume=function(t,e,i){if(!m(t))throw new Y("position is required.");if(!m(e))throw new Y("direction is required.");if(!m(i))throw new Y("up is required.");let n=this._cullingVolume.planes,s=this.top,o=this.bottom,r=this.right,a=this.left,h=this.near,A=this.far,d=l.cross(e,i,m$);l.normalize(d,d);let f=f$;l.multiplyByScalar(e,h,f),l.add(t,f,f);let E=E$;l.multiplyByScalar(d,a,E),l.add(f,E,E);let _=n[0];return m(_)||(_=n[0]=new ie),_.x=d.x,_.y=d.y,_.z=d.z,_.w=-l.dot(d,E),l.multiplyByScalar(d,r,E),l.add(f,E,E),_=n[1],m(_)||(_=n[1]=new ie),_.x=-d.x,_.y=-d.y,_.z=-d.z,_.w=-l.dot(l.negate(d,IT),E),l.multiplyByScalar(i,o,E),l.add(f,E,E),_=n[2],m(_)||(_=n[2]=new ie),_.x=i.x,_.y=i.y,_.z=i.z,_.w=-l.dot(i,E),l.multiplyByScalar(i,s,E),l.add(f,E,E),_=n[3],m(_)||(_=n[3]=new ie),_.x=-i.x,_.y=-i.y,_.z=-i.z,_.w=-l.dot(l.negate(i,IT),E),_=n[4],m(_)||(_=n[4]=new ie),_.x=e.x,_.y=e.y,_.z=e.z,_.w=-l.dot(e,f),l.multiplyByScalar(e,A,E),l.add(t,E,E),_=n[5],m(_)||(_=n[5]=new ie),_.x=-e.x,_.y=-e.y,_.z=-e.z,_.w=-l.dot(l.negate(e,IT),E),this._cullingVolume};mA.prototype.getPixelDimensions=function(t,e,i,n,s){if(nD(this),!m(t)||!m(e))throw new Y("Both drawingBufferWidth and drawingBufferHeight are required.");if(t<=0)throw new Y("drawingBufferWidth must be greater than zero.");if(e<=0)throw new Y("drawingBufferHeight must be greater than zero.");if(!m(i))throw new Y("distance is required.");if(!m(n))throw new Y("pixelRatio is required.");if(n<=0)throw new Y("pixelRatio must be greater than zero.");if(!m(s))throw new Y("A result object is required.");let o=this.right-this.left,r=this.top-this.bottom,a=n*o/t,h=n*r/e;return s.x=a,s.y=h,s};mA.prototype.clone=function(t){return m(t)||(t=new mA),t.left=this.left,t.right=this.right,t.top=this.top,t.bottom=this.bottom,t.near=this.near,t.far=this.far,t._left=void 0,t._right=void 0,t._top=void 0,t._bottom=void 0,t._near=void 0,t._far=void 0,t};mA.prototype.equals=function(t){return m(t)&&t instanceof mA&&this.right===t.right&&this.left===t.left&&this.top===t.top&&this.bottom===t.bottom&&this.near===t.near&&this.far===t.far};mA.prototype.equalsEpsilon=function(t,e,i){return t===this||m(t)&&t instanceof mA&&L.equalsEpsilon(this.right,t.right,e,i)&&L.equalsEpsilon(this.left,t.left,e,i)&&L.equalsEpsilon(this.top,t.top,e,i)&&L.equalsEpsilon(this.bottom,t.bottom,e,i)&&L.equalsEpsilon(this.near,t.near,e,i)&&L.equalsEpsilon(this.far,t.far,e,i)};qZ=mA});function tr(t){t=Z(t,Z.EMPTY_OBJECT),this._offCenterFrustum=new qZ,this.width=t.width,this._width=void 0,this.aspectRatio=t.aspectRatio,this._aspectRatio=void 0,this.near=Z(t.near,1),this._near=this.near,this.far=Z(t.far,5e8),this._far=this.far}function lc(t){if(!m(t.width)||!m(t.aspectRatio)||!m(t.near)||!m(t.far))throw new Y("width, aspectRatio, near, or far parameters are not set.");let e=t._offCenterFrustum;if(t.width!==t._width||t.aspectRatio!==t._aspectRatio||t.near!==t._near||t.far!==t._far){if(t.aspectRatio<0)throw new Y("aspectRatio must be positive.");if(t.near<0||t.near>t.far)throw new Y("near must be greater than zero and less than far.");t._aspectRatio=t.aspectRatio,t._width=t.width,t._near=t.near,t._far=t.far;let i=1/t.aspectRatio;e.right=t.width*.5,e.left=-e.right,e.top=i*e.right,e.bottom=-e.top,e.near=t.near,e.far=t.far}}var js,$Z=S(()=>{ae();Ft();mt();Ot();_e();pT();tr.packedLength=4;tr.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.width,e[i++]=t.aspectRatio,e[i++]=t.near,e[i]=t.far,e};tr.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new tr),i.width=t[e++],i.aspectRatio=t[e++],i.near=t[e++],i.far=t[e],i};Object.defineProperties(tr.prototype,{projectionMatrix:{get:function(){return lc(this),this._offCenterFrustum.projectionMatrix}},offCenterFrustum:{get:function(){return lc(this),this._offCenterFrustum}}});tr.prototype.computeCullingVolume=function(t,e,i){return lc(this),this._offCenterFrustum.computeCullingVolume(t,e,i)};tr.prototype.getPixelDimensions=function(t,e,i,n,s){return lc(this),this._offCenterFrustum.getPixelDimensions(t,e,i,n,s)};tr.prototype.clone=function(t){return m(t)||(t=new tr),t.aspectRatio=this.aspectRatio,t.width=this.width,t.near=this.near,t.far=this.far,t._aspectRatio=void 0,t._width=void 0,t._near=void 0,t._far=void 0,this._offCenterFrustum.clone(t._offCenterFrustum),t};tr.prototype.equals=function(t){return!m(t)||!(t instanceof tr)?!1:(lc(this),lc(t),this.width===t.width&&this.aspectRatio===t.aspectRatio&&this._offCenterFrustum.equals(t._offCenterFrustum))};tr.prototype.equalsEpsilon=function(t,e,i){return!m(t)||!(t instanceof tr)?!1:(lc(this),lc(t),L.equalsEpsilon(this.width,t.width,e,i)&&L.equalsEpsilon(this.aspectRatio,t.aspectRatio,e,i)&&this._offCenterFrustum.equalsEpsilon(t._offCenterFrustum,e,i))};js=tr});function uE(t,e,i,n){let s=i.viewMatrix,o=at.multiplyByVector(s,ie.fromElements(t.x,t.y,t.z,1,sD),sD),r=l.multiplyComponents(e,l.normalize(o,oD),oD);return o.x+=e.x+r.x,o.y+=e.y+r.y,o.z+=r.z,at.multiplyByVector(i.frustum.projectionMatrix,o,n)}var eo,_$,Zo,R$,uT,CT,sD,oD,Z$,I$,p$,sh,u$,rD,aD,AD,C$,hD,Bm,gT=S(()=>{Er();Xe();Ht();Os();ri();mt();Ot();_e();bi();$Z();pT();fr();ua();eo={},_$=new ie(0,0,0,1),Zo=new ie,R$=new mi,uT=new nt,CT=new nt;eo.wgs84ToWindowCoordinates=function(t,e,i){return eo.wgs84WithEyeOffsetToWindowCoordinates(t,e,l.ZERO,i)};sD=new ie,oD=new l;Z$=new ut(Math.PI,L.PI_OVER_TWO),I$=new l,p$=new l;eo.wgs84WithEyeOffsetToWindowCoordinates=function(t,e,i,n){if(!m(t))throw new Y("scene is required.");if(!m(e))throw new Y("position is required.");let s=t.frameState,o=eo.computeActualWgs84Position(s,e,_$);if(!m(o))return;let r=t.canvas,a=R$;a.x=0,a.y=0,a.width=r.clientWidth,a.height=r.clientHeight;let h=t.camera,A=!1;if(s.mode===ye.SCENE2D){let d=t.mapProjection,f=Z$,E=d.project(f,I$),_=l.clone(h.position,p$),R=h.frustum.clone(),I=at.computeViewportTransformation(a,0,1,new at),C=h.frustum.projectionMatrix,N=h.positionWC.y,T=l.fromElements(L.sign(N)*E.x-N,0,-h.positionWC.x),b=In.pointToGLWindowCoordinates(C,I,T);if(N===0||b.x<=0||b.x>=r.clientWidth)A=!0;else{if(b.x>r.clientWidth*.5){a.width=b.x,h.frustum.right=E.x-N,Zo=uE(o,i,h,Zo),eo.clipToGLWindowCoordinates(a,Zo,uT),a.x+=b.x,h.position.x=-h.position.x;let F=h.frustum.right;h.frustum.right=-h.frustum.left,h.frustum.left=-F,Zo=uE(o,i,h,Zo),eo.clipToGLWindowCoordinates(a,Zo,CT)}else{a.x+=b.x,a.width-=b.x,h.frustum.left=-E.x-N,Zo=uE(o,i,h,Zo),eo.clipToGLWindowCoordinates(a,Zo,uT),a.x=a.x-a.width,h.position.x=-h.position.x;let F=h.frustum.left;h.frustum.left=-h.frustum.right,h.frustum.right=-F,Zo=uE(o,i,h,Zo),eo.clipToGLWindowCoordinates(a,Zo,CT)}l.clone(_,h.position),h.frustum=R.clone(),n=nt.clone(uT,n),(n.x<0||n.x>r.clientWidth)&&(n.x=CT.x)}}if(s.mode!==ye.SCENE2D||A){if(Zo=uE(o,i,h,Zo),Zo.z<0&&!(h.frustum instanceof js)&&!(h.frustum instanceof qZ))return;n=eo.clipToGLWindowCoordinates(a,Zo,n)}return n.y=r.clientHeight-n.y,n};eo.wgs84ToDrawingBufferCoordinates=function(t,e,i){if(i=eo.wgs84ToWindowCoordinates(t,e,i),!!m(i))return eo.transformWindowToDrawingBuffer(t,i,i)};sh=new l,u$=new ut;eo.computeActualWgs84Position=function(t,e,i){let n=t.mode;if(n===ye.SCENE3D)return l.clone(e,i);let s=t.mapProjection,o=s.ellipsoid.cartesianToCartographic(e,u$);if(!m(o))return;if(s.project(o,sh),n===ye.COLUMBUS_VIEW)return l.fromElements(sh.z,sh.x,sh.y,i);if(n===ye.SCENE2D)return l.fromElements(0,sh.x,sh.y,i);let r=t.morphTime;return l.fromElements(L.lerp(sh.z,e.x,r),L.lerp(sh.x,e.y,r),L.lerp(sh.y,e.z,r),i)};rD=new l,aD=new l,AD=new at;eo.clipToGLWindowCoordinates=function(t,e,i){return l.divideByScalar(e,e.w,rD),at.computeViewportTransformation(t,0,1,AD),at.multiplyByPoint(AD,rD,aD),nt.fromCartesian3(aD,i)};eo.transformWindowToDrawingBuffer=function(t,e,i){let n=t.canvas,s=t.drawingBufferWidth/n.clientWidth,o=t.drawingBufferHeight/n.clientHeight;return nt.fromElements(e.x*s,e.y*o,i)};C$=new ie,hD=new ie;eo.drawingBufferToWgs84Coordinates=function(t,e,i,n){let o=t.context.uniformState,r=o.currentFrustum,a=r.x,h=r.y;if(t.frameState.useLogDepth){let _=i*o.log2FarDepthFromNearPlusOne,R=Math.pow(2,_)-1;i=h*(1-a/(R+a))/(h-a)}let A=t.view.passState.viewport,d=ie.clone(ie.UNIT_W,C$);d.x=(e.x-A.x)/A.width*2-1,d.y=(e.y-A.y)/A.height*2-1,d.z=i*2-1,d.w=1;let f,E=t.camera.frustum;if(m(E.fovy)){f=at.multiplyByVector(o.inverseViewProjection,d,hD);let _=1/f.w;l.multiplyByScalar(f,_,f)}else{let _=E.offCenterFrustum;m(_)&&(E=_),f=hD,f.x=(d.x*(E.right-E.left)+E.left+E.right)*.5,f.y=(d.y*(E.top-E.bottom)+E.bottom+E.top)*.5,f.z=(d.z*(a-h)-a-h)*.5,f.w=1,f=at.multiplyByVector(o.inverseView,f,f)}return l.fromCartesian4(f,n)};Bm=eo});var g$,mn,CE=S(()=>{g$={CENTER:0,BOTTOM:1,BASELINE:2,TOP:-1},mn=Object.freeze(g$)});function Ti(t,e){if(t=Z(t,Z.EMPTY_OBJECT),m(t.disableDepthTestDistance)&&t.disableDepthTestDistance<0)throw new Y("disableDepthTestDistance must be greater than or equal to 0.0.");let i=t.translucencyByDistance,n=t.pixelOffsetScaleByDistance,s=t.scaleByDistance,o=t.distanceDisplayCondition;if(m(i)){if(i.far<=i.near)throw new Y("translucencyByDistance.far must be greater than translucencyByDistance.near.");i=gi.clone(i)}if(m(n)){if(n.far<=n.near)throw new Y("pixelOffsetScaleByDistance.far must be greater than pixelOffsetScaleByDistance.near.");n=gi.clone(n)}if(m(s)){if(s.far<=s.near)throw new Y("scaleByDistance.far must be greater than scaleByDistance.near.");s=gi.clone(s)}if(m(o)){if(o.far<=o.near)throw new Y("distanceDisplayCondition.far must be greater than distanceDisplayCondition.near.");o=Wo.clone(o)}this._show=Z(t.show,!0),this._position=l.clone(Z(t.position,l.ZERO)),this._actualPosition=l.clone(this._position),this._pixelOffset=nt.clone(Z(t.pixelOffset,nt.ZERO)),this._translate=new nt(0,0),this._eyeOffset=l.clone(Z(t.eyeOffset,l.ZERO)),this._heightReference=Z(t.heightReference,Wr.NONE),this._verticalOrigin=Z(t.verticalOrigin,mn.CENTER),this._horizontalOrigin=Z(t.horizontalOrigin,to.CENTER),this._scale=Z(t.scale,1),this._color=Zt.clone(Z(t.color,Zt.WHITE)),this._rotation=Z(t.rotation,0),this._alignedAxis=l.clone(Z(t.alignedAxis,l.ZERO)),this._width=t.width,this._height=t.height,this._scaleByDistance=s,this._translucencyByDistance=i,this._pixelOffsetScaleByDistance=n,this._sizeInMeters=Z(t.sizeInMeters,!1),this._distanceDisplayCondition=o,this._disableDepthTestDistance=t.disableDepthTestDistance,this._id=t.id,this._collection=Z(t.collection,e),this._pickId=void 0,this._pickPrimitive=Z(t._pickPrimitive,this),this._billboardCollection=e,this._dirty=!1,this._index=-1,this._batchIndex=void 0,this._imageIndex=-1,this._imageIndexPromise=void 0,this._imageId=void 0,this._image=void 0,this._imageSubRegion=void 0,this._imageWidth=void 0,this._imageHeight=void 0,this._labelDimensions=void 0,this._labelHorizontalOrigin=void 0,this._labelTranslate=void 0;let r=t.image,a=t.imageId;m(r)&&(m(a)||(typeof r=="string"?a=r:m(r.src)?a=r.src:a=Bs()),this._imageId=a,this._image=r),m(t.imageSubRegion)&&(this._imageId=a,this._imageSubRegion=t.imageSubRegion),m(this._billboardCollection._textureAtlas)&&this._loadImage(),this._actualClampedPosition=void 0,this._removeCallbackFunc=void 0,this._mode=ye.SCENE3D,this._clusterShow=!0,this._outlineColor=Zt.clone(Z(t.outlineColor,Zt.BLACK)),this._outlineWidth=Z(t.outlineWidth,0),this._updateClamping()}function bn(t,e){let i=t._billboardCollection;m(i)&&(i._updateBillboard(t,e),t._dirty=!0)}var cD,eI,fD,T$,N$,F$,b$,iI,lD,Y$,V$,S$,O$,B$,G$,W$,dD,nI,mD,ED,tI,un,sI=S(()=>{Er();Xe();Ht();Os();ri();ae();Qn();ih();Ft();mt();Ot();zZ();Oe();bi();IE();Ia();Sm();Om();ua();gT();CE();cD=Ti.SHOW_INDEX=0,eI=Ti.POSITION_INDEX=1,fD=Ti.PIXEL_OFFSET_INDEX=2,T$=Ti.EYE_OFFSET_INDEX=3,N$=Ti.HORIZONTAL_ORIGIN_INDEX=4,F$=Ti.VERTICAL_ORIGIN_INDEX=5,b$=Ti.SCALE_INDEX=6,iI=Ti.IMAGE_INDEX_INDEX=7,lD=Ti.COLOR_INDEX=8,Y$=Ti.ROTATION_INDEX=9,V$=Ti.ALIGNED_AXIS_INDEX=10,S$=Ti.SCALE_BY_DISTANCE_INDEX=11,O$=Ti.TRANSLUCENCY_BY_DISTANCE_INDEX=12,B$=Ti.PIXEL_OFFSET_SCALE_BY_DISTANCE_INDEX=13,G$=Ti.DISTANCE_DISPLAY_CONDITION=14,W$=Ti.DISABLE_DEPTH_DISTANCE=15;Ti.TEXTURE_COORDINATE_BOUNDS=16;dD=Ti.SDF_INDEX=17;Ti.NUMBER_OF_PROPERTIES=18;Object.defineProperties(Ti.prototype,{show:{get:function(){return this._show},set:function(t){p.typeOf.bool("value",t),this._show!==t&&(this._show=t,bn(this,cD))}},position:{get:function(){return this._position},set:function(t){p.typeOf.object("value",t);let e=this._position;l.equals(e,t)||(l.clone(t,e),l.clone(t,this._actualPosition),this._updateClamping(),bn(this,eI))}},heightReference:{get:function(){return this._heightReference},set:function(t){p.typeOf.number("value",t);let e=this._heightReference;t!==e&&(this._heightReference=t,this._updateClamping(),bn(this,eI))}},pixelOffset:{get:function(){return this._pixelOffset},set:function(t){p.typeOf.object("value",t);let e=this._pixelOffset;nt.equals(e,t)||(nt.clone(t,e),bn(this,fD))}},scaleByDistance:{get:function(){return this._scaleByDistance},set:function(t){if(m(t)&&(p.typeOf.object("value",t),t.far<=t.near))throw new Y("far distance must be greater than near distance.");let e=this._scaleByDistance;gi.equals(e,t)||(this._scaleByDistance=gi.clone(t,e),bn(this,S$))}},translucencyByDistance:{get:function(){return this._translucencyByDistance},set:function(t){if(m(t)&&(p.typeOf.object("value",t),t.far<=t.near))throw new Y("far distance must be greater than near distance.");let e=this._translucencyByDistance;gi.equals(e,t)||(this._translucencyByDistance=gi.clone(t,e),bn(this,O$))}},pixelOffsetScaleByDistance:{get:function(){return this._pixelOffsetScaleByDistance},set:function(t){if(m(t)&&(p.typeOf.object("value",t),t.far<=t.near))throw new Y("far distance must be greater than near distance.");let e=this._pixelOffsetScaleByDistance;gi.equals(e,t)||(this._pixelOffsetScaleByDistance=gi.clone(t,e),bn(this,B$))}},eyeOffset:{get:function(){return this._eyeOffset},set:function(t){p.typeOf.object("value",t);let e=this._eyeOffset;l.equals(e,t)||(l.clone(t,e),bn(this,T$))}},horizontalOrigin:{get:function(){return this._horizontalOrigin},set:function(t){p.typeOf.number("value",t),this._horizontalOrigin!==t&&(this._horizontalOrigin=t,bn(this,N$))}},verticalOrigin:{get:function(){return this._verticalOrigin},set:function(t){p.typeOf.number("value",t),this._verticalOrigin!==t&&(this._verticalOrigin=t,bn(this,F$))}},scale:{get:function(){return this._scale},set:function(t){p.typeOf.number("value",t),this._scale!==t&&(this._scale=t,bn(this,b$))}},color:{get:function(){return this._color},set:function(t){p.typeOf.object("value",t);let e=this._color;Zt.equals(e,t)||(Zt.clone(t,e),bn(this,lD))}},rotation:{get:function(){return this._rotation},set:function(t){p.typeOf.number("value",t),this._rotation!==t&&(this._rotation=t,bn(this,Y$))}},alignedAxis:{get:function(){return this._alignedAxis},set:function(t){p.typeOf.object("value",t);let e=this._alignedAxis;l.equals(e,t)||(l.clone(t,e),bn(this,V$))}},width:{get:function(){return Z(this._width,this._imageWidth)},set:function(t){m(t)&&p.typeOf.number("value",t),this._width!==t&&(this._width=t,bn(this,iI))}},height:{get:function(){return Z(this._height,this._imageHeight)},set:function(t){m(t)&&p.typeOf.number("value",t),this._height!==t&&(this._height=t,bn(this,iI))}},sizeInMeters:{get:function(){return this._sizeInMeters},set:function(t){p.typeOf.bool("value",t),this._sizeInMeters!==t&&(this._sizeInMeters=t,bn(this,lD))}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){if(!Wo.equals(t,this._distanceDisplayCondition)){if(m(t)&&(p.typeOf.object("value",t),t.far<=t.near))throw new Y("far distance must be greater than near distance.");this._distanceDisplayCondition=Wo.clone(t,this._distanceDisplayCondition),bn(this,G$)}}},disableDepthTestDistance:{get:function(){return this._disableDepthTestDistance},set:function(t){if(m(t)&&(p.typeOf.number("value",t),t<0))throw new Y("disableDepthTestDistance must be greater than or equal to 0.0.");this._disableDepthTestDistance!==t&&(this._disableDepthTestDistance=t,bn(this,W$))}},id:{get:function(){return this._id},set:function(t){this._id=t,m(this._pickId)&&(this._pickId.object.id=t)}},pickPrimitive:{get:function(){return this._pickPrimitive},set:function(t){this._pickPrimitive=t,m(this._pickId)&&(this._pickId.object.primitive=t)}},pickId:{get:function(){return this._pickId}},image:{get:function(){return this._imageId},set:function(t){m(t)?typeof t=="string"?this.setImage(t,t):t instanceof tn?this.setImage(t.url,t):m(t.src)?this.setImage(t.src,t):this.setImage(Bs(),t):(this._imageIndex=-1,this._imageSubRegion=void 0,this._imageId=void 0,this._image=void 0,this._imageIndexPromise=void 0,bn(this,iI))}},ready:{get:function(){return this._imageIndex!==-1}},_clampedPosition:{get:function(){return this._actualClampedPosition},set:function(t){this._actualClampedPosition=l.clone(t,this._actualClampedPosition),bn(this,eI)}},clusterShow:{get:function(){return this._clusterShow},set:function(t){this._clusterShow!==t&&(this._clusterShow=t,bn(this,cD))}},outlineColor:{get:function(){return this._outlineColor},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._outlineColor;Zt.equals(e,t)||(Zt.clone(t,e),bn(this,dD))}},outlineWidth:{get:function(){return this._outlineWidth},set:function(t){this._outlineWidth!==t&&(this._outlineWidth=t,bn(this,dD))}}});Ti.prototype.getPickId=function(t){return m(this._pickId)||(this._pickId=t.createPickId({primitive:this._pickPrimitive,collection:this._collection,id:this._id})),this._pickId};Ti.prototype._updateClamping=function(){Ti._updateClamping(this._billboardCollection,this)};nI=new ut;Ti._updateClamping=function(t,e){let i=t._scene;if(!m(i)){if(e._heightReference!==Wr.NONE)throw new Y("Height reference is not supported without a scene.");return}let n=i.globe,s=Z(n?.ellipsoid,ot.WGS84),o=i.frameState.mode,r=o!==e._mode;if(e._mode=o,(e._heightReference===Wr.NONE||r)&&m(e._removeCallbackFunc)&&(e._removeCallbackFunc(),e._removeCallbackFunc=void 0,e._clampedPosition=void 0),e._heightReference===Wr.NONE||!m(e._position))return;m(e._removeCallbackFunc)&&e._removeCallbackFunc();let a=s.cartesianToCartographic(e._position);if(!m(a)){e._actualClampedPosition=void 0;return}function h(d){let f=s.cartographicToCartesian(d,e._clampedPosition);eD(e._heightReference)&&(e._mode===ye.SCENE3D?(d.height+=a.height,s.cartographicToCartesian(d,f)):f.x+=a.height),e._clampedPosition=f}e._removeCallbackFunc=i.updateHeight(a,h,e._heightReference),ut.clone(a,nI);let A=i.getHeight(a,e._heightReference);m(A)&&(nI.height=A),h(nI)};Ti.prototype._loadImage=function(){let t=this._billboardCollection._textureAtlas,e=this._imageId,i=this._image,n=this._imageSubRegion,s,o=this;function r(h){if(o._imageId!==e||o._image!==i||!mi.equals(o._imageSubRegion,n))return;let A=t.textureCoordinates[h];o._imageWidth=t.texture.width*A.width,o._imageHeight=t.texture.height*A.height,o._imageIndex=h,o._ready=!0,o._image=void 0,o._imageIndexPromise=void 0,bn(o,iI);let d=o._billboardCollection._scene;m(d)&&d.frameState.afterRender.push(()=>!0)}if(m(i)&&(s=t.addImage(e,i)),m(n)&&(s=t.addSubRegion(e,n)),this._imageIndexPromise=s,!m(s))return;let a=t.getImageIndex(e);if(m(a)&&!m(n)){r(a);return}s.then(r).catch(function(h){console.error(`Error loading image for billboard: ${h}`),o._imageIndexPromise=void 0})};Ti.prototype.setImage=function(t,e){if(!m(t))throw new Y("id is required.");if(!m(e))throw new Y("image is required.");this._imageId!==t&&(this._imageIndex=-1,this._imageSubRegion=void 0,this._imageId=t,this._image=e,m(this._billboardCollection._textureAtlas)&&this._loadImage())};Ti.prototype.setImageSubRegion=function(t,e){if(!m(t))throw new Y("id is required.");if(!m(e))throw new Y("subRegion is required.");this._imageId===t&&mi.equals(this._imageSubRegion,e)||(this._imageIndex=-1,this._imageId=t,this._imageSubRegion=mi.clone(e),m(this._billboardCollection._textureAtlas)&&this._loadImage())};Ti.prototype._setTranslate=function(t){if(!m(t))throw new Y("value is required.");let e=this._translate;nt.equals(e,t)||(nt.clone(t,e),bn(this,fD))};Ti.prototype._getActualPosition=function(){return m(this._clampedPosition)?this._clampedPosition:this._actualPosition};Ti.prototype._setActualPosition=function(t){m(this._clampedPosition)||l.clone(t,this._actualPosition),bn(this,eI)};mD=new ie;Ti._computeActualPosition=function(t,e,i,n){return m(t._clampedPosition)?(i.mode!==t._mode&&t._updateClamping(),t._clampedPosition):i.mode===ye.SCENE3D?e:(at.multiplyByPoint(n,e,mD),Bm.computeActualWgs84Position(i,mD))};ED=new l;Ti._computeScreenSpacePosition=function(t,e,i,n,s,o){let r=at.multiplyByPoint(t,e,ED),a=Bm.wgs84WithEyeOffsetToWindowCoordinates(s,r,i,o);if(m(a))return nt.add(a,n,a),a};tI=new nt(0,0);Ti.prototype.computeScreenSpacePosition=function(t,e){let i=this._billboardCollection;if(m(e)||(e=new nt),!m(i))throw new Y("Billboard must be in a collection.  Was it removed?");if(!m(t))throw new Y("scene is required.");nt.clone(this._pixelOffset,tI),nt.add(tI,this._translate,tI);let n=i.modelMatrix,s=this._position;if(m(this._clampedPosition)&&(s=this._clampedPosition,t.mode!==ye.SCENE3D)){let r=t.mapProjection,a=r.ellipsoid,h=r.unproject(s,nI);s=a.cartographicToCartesian(h,ED),n=at.IDENTITY}return Ti._computeScreenSpacePosition(n,s,this._eyeOffset,tI,t,e)};Ti.getScreenSpaceBoundingBox=function(t,e,i){let n=t.width,s=t.height,o=t.scale;n*=o,s*=o;let r=e.x;t.horizontalOrigin===to.RIGHT?r-=n:t.horizontalOrigin===to.CENTER&&(r-=n*.5);let a=e.y;return t.verticalOrigin===mn.BOTTOM||t.verticalOrigin===mn.BASELINE?a-=s:t.verticalOrigin===mn.CENTER&&(a-=s*.5),m(i)||(i=new mi),i.x=r,i.y=a,i.width=n,i.height=s,i};Ti.prototype.equals=function(t){return this===t||m(t)&&this._id===t._id&&l.equals(this._position,t._position)&&this._imageId===t._imageId&&this._show===t._show&&this._scale===t._scale&&this._verticalOrigin===t._verticalOrigin&&this._horizontalOrigin===t._horizontalOrigin&&this._heightReference===t._heightReference&&mi.equals(this._imageSubRegion,t._imageSubRegion)&&Zt.equals(this._color,t._color)&&nt.equals(this._pixelOffset,t._pixelOffset)&&nt.equals(this._translate,t._translate)&&l.equals(this._eyeOffset,t._eyeOffset)&&gi.equals(this._scaleByDistance,t._scaleByDistance)&&gi.equals(this._translucencyByDistance,t._translucencyByDistance)&&gi.equals(this._pixelOffsetScaleByDistance,t._pixelOffsetScaleByDistance)&&Wo.equals(this._distanceDisplayCondition,t._distanceDisplayCondition)&&this._disableDepthTestDistance===t._disableDepthTestDistance};Ti.prototype._destroy=function(){m(this._customData)&&(this._billboardCollection._scene.globe._surface.removeTileCustomData(this._customData),this._customData=void 0),m(this._removeCallbackFunc)&&(this._removeCallbackFunc(),this._removeCallbackFunc=void 0),this.image=void 0,this._pickId=this._pickId&&this._pickId.destroy(),this._billboardCollection=void 0};un=Ti});var D$,it,ss=S(()=>{D$={DEPTH_BUFFER_BIT:256,STENCIL_BUFFER_BIT:1024,COLOR_BUFFER_BIT:16384,POINTS:0,LINES:1,LINE_LOOP:2,LINE_STRIP:3,TRIANGLES:4,TRIANGLE_STRIP:5,TRIANGLE_FAN:6,ZERO:0,ONE:1,SRC_COLOR:768,ONE_MINUS_SRC_COLOR:769,SRC_ALPHA:770,ONE_MINUS_SRC_ALPHA:771,DST_ALPHA:772,ONE_MINUS_DST_ALPHA:773,DST_COLOR:774,ONE_MINUS_DST_COLOR:775,SRC_ALPHA_SATURATE:776,FUNC_ADD:32774,BLEND_EQUATION:32777,BLEND_EQUATION_RGB:32777,BLEND_EQUATION_ALPHA:34877,FUNC_SUBTRACT:32778,FUNC_REVERSE_SUBTRACT:32779,BLEND_DST_RGB:32968,BLEND_SRC_RGB:32969,BLEND_DST_ALPHA:32970,BLEND_SRC_ALPHA:32971,CONSTANT_COLOR:32769,ONE_MINUS_CONSTANT_COLOR:32770,CONSTANT_ALPHA:32771,ONE_MINUS_CONSTANT_ALPHA:32772,BLEND_COLOR:32773,ARRAY_BUFFER:34962,ELEMENT_ARRAY_BUFFER:34963,ARRAY_BUFFER_BINDING:34964,ELEMENT_ARRAY_BUFFER_BINDING:34965,STREAM_DRAW:35040,STATIC_DRAW:35044,DYNAMIC_DRAW:35048,BUFFER_SIZE:34660,BUFFER_USAGE:34661,CURRENT_VERTEX_ATTRIB:34342,FRONT:1028,BACK:1029,FRONT_AND_BACK:1032,CULL_FACE:2884,BLEND:3042,DITHER:3024,STENCIL_TEST:2960,DEPTH_TEST:2929,SCISSOR_TEST:3089,POLYGON_OFFSET_FILL:32823,SAMPLE_ALPHA_TO_COVERAGE:32926,SAMPLE_COVERAGE:32928,NO_ERROR:0,INVALID_ENUM:1280,INVALID_VALUE:1281,INVALID_OPERATION:1282,OUT_OF_MEMORY:1285,CW:2304,CCW:2305,LINE_WIDTH:2849,ALIASED_POINT_SIZE_RANGE:33901,ALIASED_LINE_WIDTH_RANGE:33902,CULL_FACE_MODE:2885,FRONT_FACE:2886,DEPTH_RANGE:2928,DEPTH_WRITEMASK:2930,DEPTH_CLEAR_VALUE:2931,DEPTH_FUNC:2932,STENCIL_CLEAR_VALUE:2961,STENCIL_FUNC:2962,STENCIL_FAIL:2964,STENCIL_PASS_DEPTH_FAIL:2965,STENCIL_PASS_DEPTH_PASS:2966,STENCIL_REF:2967,STENCIL_VALUE_MASK:2963,STENCIL_WRITEMASK:2968,STENCIL_BACK_FUNC:34816,STENCIL_BACK_FAIL:34817,STENCIL_BACK_PASS_DEPTH_FAIL:34818,STENCIL_BACK_PASS_DEPTH_PASS:34819,STENCIL_BACK_REF:36003,STENCIL_BACK_VALUE_MASK:36004,STENCIL_BACK_WRITEMASK:36005,VIEWPORT:2978,SCISSOR_BOX:3088,COLOR_CLEAR_VALUE:3106,COLOR_WRITEMASK:3107,UNPACK_ALIGNMENT:3317,PACK_ALIGNMENT:3333,MAX_TEXTURE_SIZE:3379,MAX_VIEWPORT_DIMS:3386,SUBPIXEL_BITS:3408,RED_BITS:3410,GREEN_BITS:3411,BLUE_BITS:3412,ALPHA_BITS:3413,DEPTH_BITS:3414,STENCIL_BITS:3415,POLYGON_OFFSET_UNITS:10752,POLYGON_OFFSET_FACTOR:32824,TEXTURE_BINDING_2D:32873,SAMPLE_BUFFERS:32936,SAMPLES:32937,SAMPLE_COVERAGE_VALUE:32938,SAMPLE_COVERAGE_INVERT:32939,COMPRESSED_TEXTURE_FORMATS:34467,DONT_CARE:4352,FASTEST:4353,NICEST:4354,GENERATE_MIPMAP_HINT:33170,BYTE:5120,UNSIGNED_BYTE:5121,SHORT:5122,UNSIGNED_SHORT:5123,INT:5124,UNSIGNED_INT:5125,FLOAT:5126,DEPTH_COMPONENT:6402,ALPHA:6406,RGB:6407,RGBA:6408,LUMINANCE:6409,LUMINANCE_ALPHA:6410,UNSIGNED_SHORT_4_4_4_4:32819,UNSIGNED_SHORT_5_5_5_1:32820,UNSIGNED_SHORT_5_6_5:33635,FRAGMENT_SHADER:35632,VERTEX_SHADER:35633,MAX_VERTEX_ATTRIBS:34921,MAX_VERTEX_UNIFORM_VECTORS:36347,MAX_VARYING_VECTORS:36348,MAX_COMBINED_TEXTURE_IMAGE_UNITS:35661,MAX_VERTEX_TEXTURE_IMAGE_UNITS:35660,MAX_TEXTURE_IMAGE_UNITS:34930,MAX_FRAGMENT_UNIFORM_VECTORS:36349,SHADER_TYPE:35663,DELETE_STATUS:35712,LINK_STATUS:35714,VALIDATE_STATUS:35715,ATTACHED_SHADERS:35717,ACTIVE_UNIFORMS:35718,ACTIVE_ATTRIBUTES:35721,SHADING_LANGUAGE_VERSION:35724,CURRENT_PROGRAM:35725,NEVER:512,LESS:513,EQUAL:514,LEQUAL:515,GREATER:516,NOTEQUAL:517,GEQUAL:518,ALWAYS:519,KEEP:7680,REPLACE:7681,INCR:7682,DECR:7683,INVERT:5386,INCR_WRAP:34055,DECR_WRAP:34056,VENDOR:7936,RENDERER:7937,VERSION:7938,NEAREST:9728,LINEAR:9729,NEAREST_MIPMAP_NEAREST:9984,LINEAR_MIPMAP_NEAREST:9985,NEAREST_MIPMAP_LINEAR:9986,LINEAR_MIPMAP_LINEAR:9987,TEXTURE_MAG_FILTER:10240,TEXTURE_MIN_FILTER:10241,TEXTURE_WRAP_S:10242,TEXTURE_WRAP_T:10243,TEXTURE_2D:3553,TEXTURE:5890,TEXTURE_CUBE_MAP:34067,TEXTURE_BINDING_CUBE_MAP:34068,TEXTURE_CUBE_MAP_POSITIVE_X:34069,TEXTURE_CUBE_MAP_NEGATIVE_X:34070,TEXTURE_CUBE_MAP_POSITIVE_Y:34071,TEXTURE_CUBE_MAP_NEGATIVE_Y:34072,TEXTURE_CUBE_MAP_POSITIVE_Z:34073,TEXTURE_CUBE_MAP_NEGATIVE_Z:34074,MAX_CUBE_MAP_TEXTURE_SIZE:34076,TEXTURE0:33984,TEXTURE1:33985,TEXTURE2:33986,TEXTURE3:33987,TEXTURE4:33988,TEXTURE5:33989,TEXTURE6:33990,TEXTURE7:33991,TEXTURE8:33992,TEXTURE9:33993,TEXTURE10:33994,TEXTURE11:33995,TEXTURE12:33996,TEXTURE13:33997,TEXTURE14:33998,TEXTURE15:33999,TEXTURE16:34e3,TEXTURE17:34001,TEXTURE18:34002,TEXTURE19:34003,TEXTURE20:34004,TEXTURE21:34005,TEXTURE22:34006,TEXTURE23:34007,TEXTURE24:34008,TEXTURE25:34009,TEXTURE26:34010,TEXTURE27:34011,TEXTURE28:34012,TEXTURE29:34013,TEXTURE30:34014,TEXTURE31:34015,ACTIVE_TEXTURE:34016,REPEAT:10497,CLAMP_TO_EDGE:33071,MIRRORED_REPEAT:33648,FLOAT_VEC2:35664,FLOAT_VEC3:35665,FLOAT_VEC4:35666,INT_VEC2:35667,INT_VEC3:35668,INT_VEC4:35669,BOOL:35670,BOOL_VEC2:35671,BOOL_VEC3:35672,BOOL_VEC4:35673,FLOAT_MAT2:35674,FLOAT_MAT3:35675,FLOAT_MAT4:35676,SAMPLER_2D:35678,SAMPLER_CUBE:35680,VERTEX_ATTRIB_ARRAY_ENABLED:34338,VERTEX_ATTRIB_ARRAY_SIZE:34339,VERTEX_ATTRIB_ARRAY_STRIDE:34340,VERTEX_ATTRIB_ARRAY_TYPE:34341,VERTEX_ATTRIB_ARRAY_NORMALIZED:34922,VERTEX_ATTRIB_ARRAY_POINTER:34373,VERTEX_ATTRIB_ARRAY_BUFFER_BINDING:34975,IMPLEMENTATION_COLOR_READ_TYPE:35738,IMPLEMENTATION_COLOR_READ_FORMAT:35739,COMPILE_STATUS:35713,LOW_FLOAT:36336,MEDIUM_FLOAT:36337,HIGH_FLOAT:36338,LOW_INT:36339,MEDIUM_INT:36340,HIGH_INT:36341,FRAMEBUFFER:36160,RENDERBUFFER:36161,RGBA4:32854,RGB5_A1:32855,RGB565:36194,DEPTH_COMPONENT16:33189,STENCIL_INDEX:6401,STENCIL_INDEX8:36168,DEPTH_STENCIL:34041,RENDERBUFFER_WIDTH:36162,RENDERBUFFER_HEIGHT:36163,RENDERBUFFER_INTERNAL_FORMAT:36164,RENDERBUFFER_RED_SIZE:36176,RENDERBUFFER_GREEN_SIZE:36177,RENDERBUFFER_BLUE_SIZE:36178,RENDERBUFFER_ALPHA_SIZE:36179,RENDERBUFFER_DEPTH_SIZE:36180,RENDERBUFFER_STENCIL_SIZE:36181,FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE:36048,FRAMEBUFFER_ATTACHMENT_OBJECT_NAME:36049,FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL:36050,FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE:36051,COLOR_ATTACHMENT0:36064,DEPTH_ATTACHMENT:36096,STENCIL_ATTACHMENT:36128,DEPTH_STENCIL_ATTACHMENT:33306,NONE:0,FRAMEBUFFER_COMPLETE:36053,FRAMEBUFFER_INCOMPLETE_ATTACHMENT:36054,FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:36055,FRAMEBUFFER_INCOMPLETE_DIMENSIONS:36057,FRAMEBUFFER_UNSUPPORTED:36061,FRAMEBUFFER_BINDING:36006,RENDERBUFFER_BINDING:36007,MAX_RENDERBUFFER_SIZE:34024,INVALID_FRAMEBUFFER_OPERATION:1286,UNPACK_FLIP_Y_WEBGL:37440,UNPACK_PREMULTIPLY_ALPHA_WEBGL:37441,CONTEXT_LOST_WEBGL:37442,UNPACK_COLORSPACE_CONVERSION_WEBGL:37443,BROWSER_DEFAULT_WEBGL:37444,COMPRESSED_RGB_S3TC_DXT1_EXT:33776,COMPRESSED_RGBA_S3TC_DXT1_EXT:33777,COMPRESSED_RGBA_S3TC_DXT3_EXT:33778,COMPRESSED_RGBA_S3TC_DXT5_EXT:33779,COMPRESSED_RGB_PVRTC_4BPPV1_IMG:35840,COMPRESSED_RGB_PVRTC_2BPPV1_IMG:35841,COMPRESSED_RGBA_PVRTC_4BPPV1_IMG:35842,COMPRESSED_RGBA_PVRTC_2BPPV1_IMG:35843,COMPRESSED_RGBA_ASTC_4x4_WEBGL:37808,COMPRESSED_RGB_ETC1_WEBGL:36196,COMPRESSED_RGBA_BPTC_UNORM:36492,HALF_FLOAT_OES:36193,DOUBLE:5130,READ_BUFFER:3074,UNPACK_ROW_LENGTH:3314,UNPACK_SKIP_ROWS:3315,UNPACK_SKIP_PIXELS:3316,PACK_ROW_LENGTH:3330,PACK_SKIP_ROWS:3331,PACK_SKIP_PIXELS:3332,COLOR:6144,DEPTH:6145,STENCIL:6146,RED:6403,RGB8:32849,RGBA8:32856,RGB10_A2:32857,TEXTURE_BINDING_3D:32874,UNPACK_SKIP_IMAGES:32877,UNPACK_IMAGE_HEIGHT:32878,TEXTURE_3D:32879,TEXTURE_WRAP_R:32882,MAX_3D_TEXTURE_SIZE:32883,UNSIGNED_INT_2_10_10_10_REV:33640,MAX_ELEMENTS_VERTICES:33e3,MAX_ELEMENTS_INDICES:33001,TEXTURE_MIN_LOD:33082,TEXTURE_MAX_LOD:33083,TEXTURE_BASE_LEVEL:33084,TEXTURE_MAX_LEVEL:33085,MIN:32775,MAX:32776,DEPTH_COMPONENT24:33190,MAX_TEXTURE_LOD_BIAS:34045,TEXTURE_COMPARE_MODE:34892,TEXTURE_COMPARE_FUNC:34893,CURRENT_QUERY:34917,QUERY_RESULT:34918,QUERY_RESULT_AVAILABLE:34919,STREAM_READ:35041,STREAM_COPY:35042,STATIC_READ:35045,STATIC_COPY:35046,DYNAMIC_READ:35049,DYNAMIC_COPY:35050,MAX_DRAW_BUFFERS:34852,DRAW_BUFFER0:34853,DRAW_BUFFER1:34854,DRAW_BUFFER2:34855,DRAW_BUFFER3:34856,DRAW_BUFFER4:34857,DRAW_BUFFER5:34858,DRAW_BUFFER6:34859,DRAW_BUFFER7:34860,DRAW_BUFFER8:34861,DRAW_BUFFER9:34862,DRAW_BUFFER10:34863,DRAW_BUFFER11:34864,DRAW_BUFFER12:34865,DRAW_BUFFER13:34866,DRAW_BUFFER14:34867,DRAW_BUFFER15:34868,MAX_FRAGMENT_UNIFORM_COMPONENTS:35657,MAX_VERTEX_UNIFORM_COMPONENTS:35658,SAMPLER_3D:35679,SAMPLER_2D_SHADOW:35682,FRAGMENT_SHADER_DERIVATIVE_HINT:35723,PIXEL_PACK_BUFFER:35051,PIXEL_UNPACK_BUFFER:35052,PIXEL_PACK_BUFFER_BINDING:35053,PIXEL_UNPACK_BUFFER_BINDING:35055,FLOAT_MAT2x3:35685,FLOAT_MAT2x4:35686,FLOAT_MAT3x2:35687,FLOAT_MAT3x4:35688,FLOAT_MAT4x2:35689,FLOAT_MAT4x3:35690,SRGB:35904,SRGB8:35905,SRGB8_ALPHA8:35907,COMPARE_REF_TO_TEXTURE:34894,RGBA32F:34836,RGB32F:34837,RGBA16F:34842,RGB16F:34843,VERTEX_ATTRIB_ARRAY_INTEGER:35069,MAX_ARRAY_TEXTURE_LAYERS:35071,MIN_PROGRAM_TEXEL_OFFSET:35076,MAX_PROGRAM_TEXEL_OFFSET:35077,MAX_VARYING_COMPONENTS:35659,TEXTURE_2D_ARRAY:35866,TEXTURE_BINDING_2D_ARRAY:35869,R11F_G11F_B10F:35898,UNSIGNED_INT_10F_11F_11F_REV:35899,RGB9_E5:35901,UNSIGNED_INT_5_9_9_9_REV:35902,TRANSFORM_FEEDBACK_BUFFER_MODE:35967,MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS:35968,TRANSFORM_FEEDBACK_VARYINGS:35971,TRANSFORM_FEEDBACK_BUFFER_START:35972,TRANSFORM_FEEDBACK_BUFFER_SIZE:35973,TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN:35976,RASTERIZER_DISCARD:35977,MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS:35978,MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS:35979,INTERLEAVED_ATTRIBS:35980,SEPARATE_ATTRIBS:35981,TRANSFORM_FEEDBACK_BUFFER:35982,TRANSFORM_FEEDBACK_BUFFER_BINDING:35983,RGBA32UI:36208,RGB32UI:36209,RGBA16UI:36214,RGB16UI:36215,RGBA8UI:36220,RGB8UI:36221,RGBA32I:36226,RGB32I:36227,RGBA16I:36232,RGB16I:36233,RGBA8I:36238,RGB8I:36239,RED_INTEGER:36244,RGB_INTEGER:36248,RGBA_INTEGER:36249,SAMPLER_2D_ARRAY:36289,SAMPLER_2D_ARRAY_SHADOW:36292,SAMPLER_CUBE_SHADOW:36293,UNSIGNED_INT_VEC2:36294,UNSIGNED_INT_VEC3:36295,UNSIGNED_INT_VEC4:36296,INT_SAMPLER_2D:36298,INT_SAMPLER_3D:36299,INT_SAMPLER_CUBE:36300,INT_SAMPLER_2D_ARRAY:36303,UNSIGNED_INT_SAMPLER_2D:36306,UNSIGNED_INT_SAMPLER_3D:36307,UNSIGNED_INT_SAMPLER_CUBE:36308,UNSIGNED_INT_SAMPLER_2D_ARRAY:36311,DEPTH_COMPONENT32F:36012,DEPTH32F_STENCIL8:36013,FLOAT_32_UNSIGNED_INT_24_8_REV:36269,FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING:33296,FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE:33297,FRAMEBUFFER_ATTACHMENT_RED_SIZE:33298,FRAMEBUFFER_ATTACHMENT_GREEN_SIZE:33299,FRAMEBUFFER_ATTACHMENT_BLUE_SIZE:33300,FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE:33301,FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE:33302,FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE:33303,FRAMEBUFFER_DEFAULT:33304,UNSIGNED_INT_24_8:34042,DEPTH24_STENCIL8:35056,UNSIGNED_NORMALIZED:35863,DRAW_FRAMEBUFFER_BINDING:36006,READ_FRAMEBUFFER:36008,DRAW_FRAMEBUFFER:36009,READ_FRAMEBUFFER_BINDING:36010,RENDERBUFFER_SAMPLES:36011,FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER:36052,MAX_COLOR_ATTACHMENTS:36063,COLOR_ATTACHMENT1:36065,COLOR_ATTACHMENT2:36066,COLOR_ATTACHMENT3:36067,COLOR_ATTACHMENT4:36068,COLOR_ATTACHMENT5:36069,COLOR_ATTACHMENT6:36070,COLOR_ATTACHMENT7:36071,COLOR_ATTACHMENT8:36072,COLOR_ATTACHMENT9:36073,COLOR_ATTACHMENT10:36074,COLOR_ATTACHMENT11:36075,COLOR_ATTACHMENT12:36076,COLOR_ATTACHMENT13:36077,COLOR_ATTACHMENT14:36078,COLOR_ATTACHMENT15:36079,FRAMEBUFFER_INCOMPLETE_MULTISAMPLE:36182,MAX_SAMPLES:36183,HALF_FLOAT:5131,RG:33319,RG_INTEGER:33320,R8:33321,RG8:33323,R16F:33325,R32F:33326,RG16F:33327,RG32F:33328,R8I:33329,R8UI:33330,R16I:33331,R16UI:33332,R32I:33333,R32UI:33334,RG8I:33335,RG8UI:33336,RG16I:33337,RG16UI:33338,RG32I:33339,RG32UI:33340,VERTEX_ARRAY_BINDING:34229,R8_SNORM:36756,RG8_SNORM:36757,RGB8_SNORM:36758,RGBA8_SNORM:36759,SIGNED_NORMALIZED:36764,COPY_READ_BUFFER:36662,COPY_WRITE_BUFFER:36663,COPY_READ_BUFFER_BINDING:36662,COPY_WRITE_BUFFER_BINDING:36663,UNIFORM_BUFFER:35345,UNIFORM_BUFFER_BINDING:35368,UNIFORM_BUFFER_START:35369,UNIFORM_BUFFER_SIZE:35370,MAX_VERTEX_UNIFORM_BLOCKS:35371,MAX_FRAGMENT_UNIFORM_BLOCKS:35373,MAX_COMBINED_UNIFORM_BLOCKS:35374,MAX_UNIFORM_BUFFER_BINDINGS:35375,MAX_UNIFORM_BLOCK_SIZE:35376,MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS:35377,MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS:35379,UNIFORM_BUFFER_OFFSET_ALIGNMENT:35380,ACTIVE_UNIFORM_BLOCKS:35382,UNIFORM_TYPE:35383,UNIFORM_SIZE:35384,UNIFORM_BLOCK_INDEX:35386,UNIFORM_OFFSET:35387,UNIFORM_ARRAY_STRIDE:35388,UNIFORM_MATRIX_STRIDE:35389,UNIFORM_IS_ROW_MAJOR:35390,UNIFORM_BLOCK_BINDING:35391,UNIFORM_BLOCK_DATA_SIZE:35392,UNIFORM_BLOCK_ACTIVE_UNIFORMS:35394,UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES:35395,UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER:35396,UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER:35398,INVALID_INDEX:4294967295,MAX_VERTEX_OUTPUT_COMPONENTS:37154,MAX_FRAGMENT_INPUT_COMPONENTS:37157,MAX_SERVER_WAIT_TIMEOUT:37137,OBJECT_TYPE:37138,SYNC_CONDITION:37139,SYNC_STATUS:37140,SYNC_FLAGS:37141,SYNC_FENCE:37142,SYNC_GPU_COMMANDS_COMPLETE:37143,UNSIGNALED:37144,SIGNALED:37145,ALREADY_SIGNALED:37146,TIMEOUT_EXPIRED:37147,CONDITION_SATISFIED:37148,WAIT_FAILED:37149,SYNC_FLUSH_COMMANDS_BIT:1,VERTEX_ATTRIB_ARRAY_DIVISOR:35070,ANY_SAMPLES_PASSED:35887,ANY_SAMPLES_PASSED_CONSERVATIVE:36202,SAMPLER_BINDING:35097,RGB10_A2UI:36975,INT_2_10_10_10_REV:36255,TRANSFORM_FEEDBACK:36386,TRANSFORM_FEEDBACK_PAUSED:36387,TRANSFORM_FEEDBACK_ACTIVE:36388,TRANSFORM_FEEDBACK_BINDING:36389,COMPRESSED_R11_EAC:37488,COMPRESSED_SIGNED_R11_EAC:37489,COMPRESSED_RG11_EAC:37490,COMPRESSED_SIGNED_RG11_EAC:37491,COMPRESSED_RGB8_ETC2:37492,COMPRESSED_SRGB8_ETC2:37493,COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2:37494,COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2:37495,COMPRESSED_RGBA8_ETC2_EAC:37496,COMPRESSED_SRGB8_ALPHA8_ETC2_EAC:37497,TEXTURE_IMMUTABLE_FORMAT:37167,MAX_ELEMENT_INDEX:36203,TEXTURE_IMMUTABLE_LEVELS:33503,MAX_TEXTURE_MAX_ANISOTROPY_EXT:34047},it=Object.freeze(D$)});var xe,At,oi=S(()=>{Ft();mt();Ot();ss();xe={BYTE:it.BYTE,UNSIGNED_BYTE:it.UNSIGNED_BYTE,SHORT:it.SHORT,UNSIGNED_SHORT:it.UNSIGNED_SHORT,INT:it.INT,UNSIGNED_INT:it.UNSIGNED_INT,FLOAT:it.FLOAT,DOUBLE:it.DOUBLE};xe.getSizeInBytes=function(t){if(!m(t))throw new Y("value is required.");switch(t){case xe.BYTE:return Int8Array.BYTES_PER_ELEMENT;case xe.UNSIGNED_BYTE:return Uint8Array.BYTES_PER_ELEMENT;case xe.SHORT:return Int16Array.BYTES_PER_ELEMENT;case xe.UNSIGNED_SHORT:return Uint16Array.BYTES_PER_ELEMENT;case xe.INT:return Int32Array.BYTES_PER_ELEMENT;case xe.UNSIGNED_INT:return Uint32Array.BYTES_PER_ELEMENT;case xe.FLOAT:return Float32Array.BYTES_PER_ELEMENT;case xe.DOUBLE:return Float64Array.BYTES_PER_ELEMENT;default:throw new Y("componentDatatype is not a valid value.")}};xe.fromTypedArray=function(t){if(t instanceof Int8Array)return xe.BYTE;if(t instanceof Uint8Array)return xe.UNSIGNED_BYTE;if(t instanceof Int16Array)return xe.SHORT;if(t instanceof Uint16Array)return xe.UNSIGNED_SHORT;if(t instanceof Int32Array)return xe.INT;if(t instanceof Uint32Array)return xe.UNSIGNED_INT;if(t instanceof Float32Array)return xe.FLOAT;if(t instanceof Float64Array)return xe.DOUBLE;throw new Y("array must be an Int8Array, Uint8Array, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, or Float64Array.")};xe.validate=function(t){return m(t)&&(t===xe.BYTE||t===xe.UNSIGNED_BYTE||t===xe.SHORT||t===xe.UNSIGNED_SHORT||t===xe.INT||t===xe.UNSIGNED_INT||t===xe.FLOAT||t===xe.DOUBLE)};xe.createTypedArray=function(t,e){if(!m(t))throw new Y("componentDatatype is required.");if(!m(e))throw new Y("valuesOrLength is required.");switch(t){case xe.BYTE:return new Int8Array(e);case xe.UNSIGNED_BYTE:return new Uint8Array(e);case xe.SHORT:return new Int16Array(e);case xe.UNSIGNED_SHORT:return new Uint16Array(e);case xe.INT:return new Int32Array(e);case xe.UNSIGNED_INT:return new Uint32Array(e);case xe.FLOAT:return new Float32Array(e);case xe.DOUBLE:return new Float64Array(e);default:throw new Y("componentDatatype is not a valid value.")}};xe.createArrayBufferView=function(t,e,i,n){if(!m(t))throw new Y("componentDatatype is required.");if(!m(e))throw new Y("buffer is required.");switch(i=Z(i,0),n=Z(n,(e.byteLength-i)/xe.getSizeInBytes(t)),t){case xe.BYTE:return new Int8Array(e,i,n);case xe.UNSIGNED_BYTE:return new Uint8Array(e,i,n);case xe.SHORT:return new Int16Array(e,i,n);case xe.UNSIGNED_SHORT:return new Uint16Array(e,i,n);case xe.INT:return new Int32Array(e,i,n);case xe.UNSIGNED_INT:return new Uint32Array(e,i,n);case xe.FLOAT:return new Float32Array(e,i,n);case xe.DOUBLE:return new Float64Array(e,i,n);default:throw new Y("componentDatatype is not a valid value.")}};xe.fromName=function(t){switch(t){case"BYTE":return xe.BYTE;case"UNSIGNED_BYTE":return xe.UNSIGNED_BYTE;case"SHORT":return xe.SHORT;case"UNSIGNED_SHORT":return xe.UNSIGNED_SHORT;case"INT":return xe.INT;case"UNSIGNED_INT":return xe.UNSIGNED_INT;case"FLOAT":return xe.FLOAT;case"DOUBLE":return xe.DOUBLE;default:throw new Y("name is not a valid value.")}};At=Object.freeze(xe)});function Te(t,e,i,n){this[0]=Z(t,0),this[1]=Z(i,0),this[2]=Z(e,0),this[3]=Z(n,0)}var U$,M$,_D,RD,Q$,k$,Hn,dc=S(()=>{Xe();ae();Ft();mt();Ot();Te.packedLength=4;Te.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t[0],e[i++]=t[1],e[i++]=t[2],e[i++]=t[3],e};Te.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Te),i[0]=t[e++],i[1]=t[e++],i[2]=t[e++],i[3]=t[e++],i};Te.packArray=function(t,e){p.defined("array",t);let i=t.length,n=i*4;if(!m(e))e=new Array(n);else{if(!Array.isArray(e)&&e.length!==n)throw new Y("If result is a typed array, it must have exactly array.length * 4 elements");e.length!==n&&(e.length=n)}for(let s=0;s<i;++s)Te.pack(t[s],e,s*4);return e};Te.unpackArray=function(t,e){if(p.defined("array",t),p.typeOf.number.greaterThanOrEquals("array.length",t.length,4),t.length%4!==0)throw new Y("array length must be a multiple of 4.");let i=t.length;m(e)?e.length=i/4:e=new Array(i/4);for(let n=0;n<i;n+=4){let s=n/4;e[s]=Te.unpack(t,n,e[s])}return e};Te.clone=function(t,e){if(m(t))return m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e):new Te(t[0],t[2],t[1],t[3])};Te.fromArray=Te.unpack;Te.fromColumnMajorArray=function(t,e){return p.defined("values",t),Te.clone(t,e)};Te.fromRowMajorArray=function(t,e){return p.defined("values",t),m(e)?(e[0]=t[0],e[1]=t[2],e[2]=t[1],e[3]=t[3],e):new Te(t[0],t[1],t[2],t[3])};Te.fromScale=function(t,e){return p.typeOf.object("scale",t),m(e)?(e[0]=t.x,e[1]=0,e[2]=0,e[3]=t.y,e):new Te(t.x,0,0,t.y)};Te.fromUniformScale=function(t,e){return p.typeOf.number("scale",t),m(e)?(e[0]=t,e[1]=0,e[2]=0,e[3]=t,e):new Te(t,0,0,t)};Te.fromRotation=function(t,e){p.typeOf.number("angle",t);let i=Math.cos(t),n=Math.sin(t);return m(e)?(e[0]=i,e[1]=n,e[2]=-n,e[3]=i,e):new Te(i,-n,n,i)};Te.toArray=function(t,e){return p.typeOf.object("matrix",t),m(e)?(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e):[t[0],t[1],t[2],t[3]]};Te.getElementIndex=function(t,e){return p.typeOf.number.greaterThanOrEquals("row",e,0),p.typeOf.number.lessThanOrEquals("row",e,1),p.typeOf.number.greaterThanOrEquals("column",t,0),p.typeOf.number.lessThanOrEquals("column",t,1),t*2+e};Te.getColumn=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,1),p.typeOf.object("result",i);let n=e*2,s=t[n],o=t[n+1];return i.x=s,i.y=o,i};Te.setColumn=function(t,e,i,n){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,1),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=Te.clone(t,n);let s=e*2;return n[s]=i.x,n[s+1]=i.y,n};Te.getRow=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,1),p.typeOf.object("result",i);let n=t[e],s=t[e+2];return i.x=n,i.y=s,i};Te.setRow=function(t,e,i,n){return p.typeOf.object("matrix",t),p.typeOf.number.greaterThanOrEquals("index",e,0),p.typeOf.number.lessThanOrEquals("index",e,1),p.typeOf.object("cartesian",i),p.typeOf.object("result",n),n=Te.clone(t,n),n[e]=i.x,n[e+2]=i.y,n};U$=new nt;Te.setScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i);let n=Te.getScale(t,U$),s=e.x/n.x,o=e.y/n.y;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*o,i[3]=t[3]*o,i};M$=new nt;Te.setUniformScale=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i);let n=Te.getScale(t,M$),s=e/n.x,o=e/n.y;return i[0]=t[0]*s,i[1]=t[1]*s,i[2]=t[2]*o,i[3]=t[3]*o,i};_D=new nt;Te.getScale=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e.x=nt.magnitude(nt.fromElements(t[0],t[1],_D)),e.y=nt.magnitude(nt.fromElements(t[2],t[3],_D)),e};RD=new nt;Te.getMaximumScale=function(t){return Te.getScale(t,RD),nt.maximumComponent(RD)};Q$=new nt;Te.setRotation=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("result",i);let n=Te.getScale(t,Q$);return i[0]=e[0]*n.x,i[1]=e[1]*n.x,i[2]=e[2]*n.y,i[3]=e[3]*n.y,i};k$=new nt;Te.getRotation=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=Te.getScale(t,k$);return e[0]=t[0]/i.x,e[1]=t[1]/i.x,e[2]=t[2]/i.y,e[3]=t[3]/i.y,e};Te.multiply=function(t,e,i){p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i);let n=t[0]*e[0]+t[2]*e[1],s=t[0]*e[2]+t[2]*e[3],o=t[1]*e[0]+t[3]*e[1],r=t[1]*e[2]+t[3]*e[3];return i[0]=n,i[1]=o,i[2]=s,i[3]=r,i};Te.add=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]+e[0],i[1]=t[1]+e[1],i[2]=t[2]+e[2],i[3]=t[3]+e[3],i};Te.subtract=function(t,e,i){return p.typeOf.object("left",t),p.typeOf.object("right",e),p.typeOf.object("result",i),i[0]=t[0]-e[0],i[1]=t[1]-e[1],i[2]=t[2]-e[2],i[3]=t[3]-e[3],i};Te.multiplyByVector=function(t,e,i){p.typeOf.object("matrix",t),p.typeOf.object("cartesian",e),p.typeOf.object("result",i);let n=t[0]*e.x+t[2]*e.y,s=t[1]*e.x+t[3]*e.y;return i.x=n,i.y=s,i};Te.multiplyByScalar=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scalar",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3]*e,i};Te.multiplyByScale=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.object("scale",e),p.typeOf.object("result",i),i[0]=t[0]*e.x,i[1]=t[1]*e.x,i[2]=t[2]*e.y,i[3]=t[3]*e.y,i};Te.multiplyByUniformScale=function(t,e,i){return p.typeOf.object("matrix",t),p.typeOf.number("scale",e),p.typeOf.object("result",i),i[0]=t[0]*e,i[1]=t[1]*e,i[2]=t[2]*e,i[3]=t[3]*e,i};Te.negate=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=-t[0],e[1]=-t[1],e[2]=-t[2],e[3]=-t[3],e};Te.transpose=function(t,e){p.typeOf.object("matrix",t),p.typeOf.object("result",e);let i=t[0],n=t[2],s=t[1],o=t[3];return e[0]=i,e[1]=n,e[2]=s,e[3]=o,e};Te.abs=function(t,e){return p.typeOf.object("matrix",t),p.typeOf.object("result",e),e[0]=Math.abs(t[0]),e[1]=Math.abs(t[1]),e[2]=Math.abs(t[2]),e[3]=Math.abs(t[3]),e};Te.equals=function(t,e){return t===e||m(t)&&m(e)&&t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]};Te.equalsArray=function(t,e,i){return t[0]===e[i]&&t[1]===e[i+1]&&t[2]===e[i+2]&&t[3]===e[i+3]};Te.equalsEpsilon=function(t,e,i){return i=Z(i,0),t===e||m(t)&&m(e)&&Math.abs(t[0]-e[0])<=i&&Math.abs(t[1]-e[1])<=i&&Math.abs(t[2]-e[2])<=i&&Math.abs(t[3]-e[3])<=i};Te.IDENTITY=Object.freeze(new Te(1,0,0,1));Te.ZERO=Object.freeze(new Te(0,0,0,0));Te.COLUMN0ROW0=0;Te.COLUMN0ROW1=1;Te.COLUMN1ROW0=2;Te.COLUMN1ROW1=3;Object.defineProperties(Te.prototype,{length:{get:function(){return Te.packedLength}}});Te.prototype.clone=function(t){return Te.clone(this,t)};Te.prototype.equals=function(t){return Te.equals(this,t)};Te.prototype.equalsEpsilon=function(t,e){return Te.equalsEpsilon(this,t,e)};Te.prototype.toString=function(){return`(${this[0]}, ${this[2]})
(${this[1]}, ${this[3]})`};Hn=Te});var Ji,ZD,ID=S(()=>{Xe();Ht();Os();ae();Ot();dc();dn();bi();Ji={SCALAR:"SCALAR",VEC2:"VEC2",VEC3:"VEC3",VEC4:"VEC4",MAT2:"MAT2",MAT3:"MAT3",MAT4:"MAT4"};Ji.getMathType=function(t){switch(t){case Ji.SCALAR:return Number;case Ji.VEC2:return nt;case Ji.VEC3:return l;case Ji.VEC4:return ie;case Ji.MAT2:return Hn;case Ji.MAT3:return lt;case Ji.MAT4:return at;default:throw new Y("attributeType is not a valid value.")}};Ji.getNumberOfComponents=function(t){switch(t){case Ji.SCALAR:return 1;case Ji.VEC2:return 2;case Ji.VEC3:return 3;case Ji.VEC4:case Ji.MAT2:return 4;case Ji.MAT3:return 9;case Ji.MAT4:return 16;default:throw new Y("attributeType is not a valid value.")}};Ji.getAttributeLocationCount=function(t){switch(t){case Ji.SCALAR:case Ji.VEC2:case Ji.VEC3:case Ji.VEC4:return 1;case Ji.MAT2:return 2;case Ji.MAT3:return 3;case Ji.MAT4:return 4;default:throw new Y("attributeType is not a valid value.")}};Ji.getGlslType=function(t){switch(p.typeOf.string("attributeType",t),t){case Ji.SCALAR:return"float";case Ji.VEC2:return"vec2";case Ji.VEC3:return"vec3";case Ji.VEC4:return"vec4";case Ji.MAT2:return"mat2";case Ji.MAT3:return"mat3";case Ji.MAT4:return"mat4";default:throw new Y("attributeType is not a valid value.")}};ZD=Object.freeze(Ji)});function oI(t){return CD[0]=t,CD[0]}function TT(t){return t>>1^-(t&1)}var pD,uD,rn,gE,CD,NT,Yi,oh=S(()=>{Xe();Ht();oi();ae();mt();Ot();_e();ID();pD=1/256,uD=256,rn={};rn.octEncodeInRange=function(t,e,i){p.defined("vector",t),p.defined("result",i);let n=l.magnitudeSquared(t);if(Math.abs(n-1)>L.EPSILON6)throw new Y("vector must be normalized.");if(i.x=t.x/(Math.abs(t.x)+Math.abs(t.y)+Math.abs(t.z)),i.y=t.y/(Math.abs(t.x)+Math.abs(t.y)+Math.abs(t.z)),t.z<0){let s=i.x,o=i.y;i.x=(1-Math.abs(o))*L.signNotZero(s),i.y=(1-Math.abs(s))*L.signNotZero(o)}return i.x=L.toSNorm(i.x,e),i.y=L.toSNorm(i.y,e),i};rn.octEncode=function(t,e){return rn.octEncodeInRange(t,255,e)};gE=new nt,CD=new Uint8Array(1);rn.octEncodeToCartesian4=function(t,e){return rn.octEncodeInRange(t,65535,gE),e.x=oI(gE.x*pD),e.y=oI(gE.x),e.z=oI(gE.y*pD),e.w=oI(gE.y),e};rn.octDecodeInRange=function(t,e,i,n){if(p.defined("result",n),t<0||t>i||e<0||e>i)throw new Y(`x and y must be unsigned normalized integers between 0 and ${i}`);if(n.x=L.fromSNorm(t,i),n.y=L.fromSNorm(e,i),n.z=1-(Math.abs(n.x)+Math.abs(n.y)),n.z<0){let s=n.x;n.x=(1-Math.abs(n.y))*L.signNotZero(s),n.y=(1-Math.abs(s))*L.signNotZero(n.y)}return l.normalize(n,n)};rn.octDecode=function(t,e,i){return rn.octDecodeInRange(t,e,255,i)};rn.octDecodeFromCartesian4=function(t,e){p.typeOf.object("encoded",t),p.typeOf.object("result",e);let i=t.x,n=t.y,s=t.z,o=t.w;if(i<0||i>255||n<0||n>255||s<0||s>255||o<0||o>255)throw new Y("x, y, z, and w must be unsigned normalized integers between 0 and 255");let r=i*uD+n,a=s*uD+o;return rn.octDecodeInRange(r,a,65535,e)};rn.octPackFloat=function(t){return p.defined("encoded",t),256*t.x+t.y};NT=new nt;rn.octEncodeFloat=function(t){return rn.octEncode(t,NT),rn.octPackFloat(NT)};rn.octDecodeFloat=function(t,e){p.defined("value",t);let i=t/256,n=Math.floor(i),s=(i-n)*256;return rn.octDecode(n,s,e)};rn.octPack=function(t,e,i,n){p.defined("v1",t),p.defined("v2",e),p.defined("v3",i),p.defined("result",n);let s=rn.octEncodeFloat(t),o=rn.octEncodeFloat(e),r=rn.octEncode(i,NT);return n.x=65536*r.x+s,n.y=65536*r.y+o,n};rn.octUnpack=function(t,e,i,n){p.defined("packed",t),p.defined("v1",e),p.defined("v2",i),p.defined("v3",n);let s=t.x/65536,o=Math.floor(s),r=(s-o)*65536;s=t.y/65536;let a=Math.floor(s),h=(s-a)*65536;rn.octDecodeFloat(r,e),rn.octDecodeFloat(h,i),rn.octDecode(o,a,n)};rn.compressTextureCoordinates=function(t){p.defined("textureCoordinates",t);let e=t.x*4095|0,i=t.y*4095|0;return 4096*e+i};rn.decompressTextureCoordinates=function(t,e){p.defined("compressed",t),p.defined("result",e);let i=t/4096,n=Math.floor(i);return e.x=n/4095,e.y=(t-n*4096)/4095,e};rn.zigZagDeltaDecode=function(t,e,i){p.defined("uBuffer",t),p.defined("vBuffer",e),p.typeOf.number.equals("uBuffer.length","vBuffer.length",t.length,e.length),m(i)&&p.typeOf.number.equals("uBuffer.length","heightBuffer.length",t.length,i.length);let n=t.length,s=0,o=0,r=0;for(let a=0;a<n;++a)s+=TT(t[a]),o+=TT(e[a]),t[a]=s,e[a]=o,m(i)&&(r+=TT(i[a]),i[a]=r)};rn.dequantize=function(t,e,i,n){p.defined("typedArray",t),p.defined("componentDatatype",e),p.defined("type",i),p.defined("count",n);let s=ZD.getNumberOfComponents(i),o;switch(e){case At.BYTE:o=127;break;case At.UNSIGNED_BYTE:o=255;break;case At.SHORT:o=32767;break;case At.UNSIGNED_SHORT:o=65535;break;case At.INT:o=2147483647;break;case At.UNSIGNED_INT:o=4294967295;break;default:throw new Y(`Cannot dequantize component datatype: ${e}`)}let r=new Float32Array(n*s);for(let a=0;a<n;a++)for(let h=0;h<s;h++){let A=a*s+h;r[A]=Math.max(t[A]/o,-1)}return r};rn.decodeRGB565=function(t,e){p.defined("typedArray",t);let i=t.length*3;m(e)&&p.typeOf.number.equals("result.length","typedArray.length * 3",e.length,i);let n=t.length;m(e)||(e=new Float32Array(n*3));let s=31,o=63,r=1/31,a=1/63;for(let h=0;h<n;h++){let A=t[h],d=A>>11,f=A>>5&o,E=A&s,_=3*h;e[_]=d*r,e[_+1]=f*a,e[_+2]=E*r}return e};Yi=rn});function L$(){return!0}function y$(t,e){e=Z(e,"This object was destroyed, i.e., destroy() was called.");function i(){throw new Y(e)}for(let n in t)typeof t[n]=="function"&&(t[n]=i);t.isDestroyed=L$}var li,Ws=S(()=>{Ft();Ot();li=y$});function fA(){this.high=l.clone(l.ZERO),this.low=l.clone(l.ZERO)}var rh,FT,Gn,Tl=S(()=>{Ht();ae();mt();fA.encode=function(t,e){p.typeOf.number("value",t),m(e)||(e={high:0,low:0});let i;return t>=0?(i=Math.floor(t/65536)*65536,e.high=i,e.low=t-i):(i=Math.floor(-t/65536)*65536,e.high=-i,e.low=t+i),e};rh={high:0,low:0};fA.fromCartesian=function(t,e){p.typeOf.object("cartesian",t),m(e)||(e=new fA);let i=e.high,n=e.low;return fA.encode(t.x,rh),i.x=rh.high,n.x=rh.low,fA.encode(t.y,rh),i.y=rh.high,n.y=rh.low,fA.encode(t.z,rh),i.z=rh.high,n.z=rh.low,e};FT=new fA;fA.writeElements=function(t,e,i){p.defined("cartesianArray",e),p.typeOf.number("index",i),p.typeOf.number.greaterThanOrEquals("index",i,0),fA.fromCartesian(t,FT);let n=FT.high,s=FT.low;e[i]=n.x,e[i+1]=n.y,e[i+2]=n.z,e[i+3]=s.x,e[i+4]=s.y,e[i+5]=s.z};Gn=fA});var Ds,te,Di=S(()=>{mt();Ot();_e();ss();Ds={UNSIGNED_BYTE:it.UNSIGNED_BYTE,UNSIGNED_SHORT:it.UNSIGNED_SHORT,UNSIGNED_INT:it.UNSIGNED_INT};Ds.getSizeInBytes=function(t){switch(t){case Ds.UNSIGNED_BYTE:return Uint8Array.BYTES_PER_ELEMENT;case Ds.UNSIGNED_SHORT:return Uint16Array.BYTES_PER_ELEMENT;case Ds.UNSIGNED_INT:return Uint32Array.BYTES_PER_ELEMENT}throw new Y("indexDatatype is required and must be a valid IndexDatatype constant.")};Ds.fromSizeInBytes=function(t){switch(t){case 2:return Ds.UNSIGNED_SHORT;case 4:return Ds.UNSIGNED_INT;case 1:return Ds.UNSIGNED_BYTE;default:throw new Y("Size in bytes cannot be mapped to an IndexDatatype")}};Ds.validate=function(t){return m(t)&&(t===Ds.UNSIGNED_BYTE||t===Ds.UNSIGNED_SHORT||t===Ds.UNSIGNED_INT)};Ds.createTypedArray=function(t,e){if(!m(t))throw new Y("numberOfVertices is required.");return t>=L.SIXTY_FOUR_KILOBYTES?new Uint32Array(e):new Uint16Array(e)};Ds.createTypedArrayFromArrayBuffer=function(t,e,i,n){if(!m(t))throw new Y("numberOfVertices is required.");if(!m(e))throw new Y("sourceArray is required.");if(!m(i))throw new Y("byteOffset is required.");return t>=L.SIXTY_FOUR_KILOBYTES?new Uint32Array(e,i,n):new Uint16Array(e,i,n)};Ds.fromTypedArray=function(t){if(t instanceof Uint8Array)return Ds.UNSIGNED_BYTE;if(t instanceof Uint16Array)return Ds.UNSIGNED_SHORT;if(t instanceof Uint32Array)return Ds.UNSIGNED_INT;throw new Y("array must be a Uint8Array, Uint16Array, or Uint32Array.")};te=Object.freeze(Ds)});var rI,ai,Nl=S(()=>{ss();rI={STREAM_DRAW:it.STREAM_DRAW,STATIC_DRAW:it.STATIC_DRAW,DYNAMIC_DRAW:it.DYNAMIC_DRAW,validate:function(t){return t===rI.STREAM_DRAW||t===rI.STATIC_DRAW||t===rI.DYNAMIC_DRAW}},ai=Object.freeze(rI)});function Ur(t){if(t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context),!m(t.typedArray)&&!m(t.sizeInBytes))throw new Y("Either options.sizeInBytes or options.typedArray is required.");if(m(t.typedArray)&&m(t.sizeInBytes))throw new Y("Cannot pass in both options.sizeInBytes and options.typedArray.");if(m(t.typedArray)&&(p.typeOf.object("options.typedArray",t.typedArray),p.typeOf.number("options.typedArray.byteLength",t.typedArray.byteLength)),!ai.validate(t.usage))throw new Y("usage is invalid.");let e=t.context._gl,i=t.bufferTarget,n=t.typedArray,s=t.sizeInBytes,o=t.usage,r=m(n);r&&(s=n.byteLength),p.typeOf.number.greaterThan("sizeInBytes",s,0);let a=e.createBuffer();e.bindBuffer(i,a),e.bufferData(i,r?n:s,o),e.bindBuffer(i,null),this._id=Bs(),this._gl=e,this._webgl2=t.context._webgl2,this._bufferTarget=i,this._sizeInBytes=s,this._usage=o,this._buffer=a,this.vertexArrayDestroyable=!0}var Ca,aI=S(()=>{ae();ih();Ft();mt();Ws();Ot();Di();ss();Nl();Ur.createVertexBuffer=function(t){return p.defined("options.context",t.context),new Ur({context:t.context,bufferTarget:it.ARRAY_BUFFER,typedArray:t.typedArray,sizeInBytes:t.sizeInBytes,usage:t.usage})};Ur.createIndexBuffer=function(t){if(p.defined("options.context",t.context),!te.validate(t.indexDatatype))throw new Y("Invalid indexDatatype.");if(t.indexDatatype===te.UNSIGNED_INT&&!t.context.elementIndexUint)throw new Y("IndexDatatype.UNSIGNED_INT requires OES_element_index_uint, which is not supported on this system.  Check context.elementIndexUint.");let e=t.context,i=t.indexDatatype,n=te.getSizeInBytes(i),s=new Ur({context:e,bufferTarget:it.ELEMENT_ARRAY_BUFFER,typedArray:t.typedArray,sizeInBytes:t.sizeInBytes,usage:t.usage}),o=s.sizeInBytes/n;return Object.defineProperties(s,{indexDatatype:{get:function(){return i}},bytesPerIndex:{get:function(){return n}},numberOfIndices:{get:function(){return o}}}),s};Object.defineProperties(Ur.prototype,{sizeInBytes:{get:function(){return this._sizeInBytes}},usage:{get:function(){return this._usage}}});Ur.prototype._getBuffer=function(){return this._buffer};Ur.prototype.copyFromArrayView=function(t,e){e=Z(e,0),p.defined("arrayView",t),p.typeOf.number.lessThanOrEquals("offsetInBytes + arrayView.byteLength",e+t.byteLength,this._sizeInBytes);let i=this._gl,n=this._bufferTarget;i.bindBuffer(n,this._buffer),i.bufferSubData(n,e,t),i.bindBuffer(n,null)};Ur.prototype.copyFromBuffer=function(t,e,i,n){if(!this._webgl2)throw new Y("A WebGL 2 context is required.");if(!m(t))throw new Y("readBuffer must be defined.");if(!m(n)||n<=0)throw new Y("sizeInBytes must be defined and be greater than zero.");if(!m(e)||e<0||e+n>t._sizeInBytes)throw new Y("readOffset must be greater than or equal to zero and readOffset + sizeInBytes must be less than of equal to readBuffer.sizeInBytes.");if(!m(i)||i<0||i+n>this._sizeInBytes)throw new Y("writeOffset must be greater than or equal to zero and writeOffset + sizeInBytes must be less than of equal to this.sizeInBytes.");if(this._buffer===t._buffer&&(i>=e&&i<e+n||e>i&&e<i+n))throw new Y("When readBuffer is equal to this, the ranges [readOffset + sizeInBytes) and [writeOffset, writeOffset + sizeInBytes) must not overlap.");if(this._bufferTarget===it.ELEMENT_ARRAY_BUFFER&&t._bufferTarget!==it.ELEMENT_ARRAY_BUFFER||this._bufferTarget!==it.ELEMENT_ARRAY_BUFFER&&t._bufferTarget===it.ELEMENT_ARRAY_BUFFER)throw new Y("Can not copy an index buffer into another buffer type.");let s=it.COPY_READ_BUFFER,o=it.COPY_WRITE_BUFFER,r=this._gl;r.bindBuffer(o,this._buffer),r.bindBuffer(s,t._buffer),r.copyBufferSubData(s,o,e,i,n),r.bindBuffer(o,null),r.bindBuffer(s,null)};Ur.prototype.getBufferData=function(t,e,i,n){if(e=Z(e,0),i=Z(i,0),!this._webgl2)throw new Y("A WebGL 2 context is required.");if(!m(t))throw new Y("arrayView is required.");let s,o,r=t.byteLength;if(m(n)?(s=n,m(r)?o=1:(r=t.length,o=t.BYTES_PER_ELEMENT)):m(r)?(s=r-i,o=1):(r=t.length,s=r-i,o=t.BYTES_PER_ELEMENT),i<0||i>r)throw new Y("destinationOffset must be greater than zero and less than the arrayView length.");if(i+s>r)throw new Y("destinationOffset + length must be less than or equal to the arrayViewLength.");if(e<0||e>this._sizeInBytes)throw new Y("sourceOffset must be greater than zero and less than the buffers size.");if(e+s*o>this._sizeInBytes)throw new Y("sourceOffset + length must be less than the buffers size.");let a=this._gl,h=it.COPY_READ_BUFFER;a.bindBuffer(h,this._buffer),a.getBufferSubData(h,e,t,i,n),a.bindBuffer(h,null)};Ur.prototype.isDestroyed=function(){return!1};Ur.prototype.destroy=function(){return this._gl.deleteBuffer(this._buffer),li(this)};Ca=Ur});var vn,en,ga=S(()=>{vn={_maximumCombinedTextureImageUnits:0,_maximumCubeMapSize:0,_maximumFragmentUniformVectors:0,_maximumTextureImageUnits:0,_maximumRenderbufferSize:0,_maximumTextureSize:0,_maximumVaryingVectors:0,_maximumVertexAttributes:0,_maximumVertexTextureImageUnits:0,_maximumVertexUniformVectors:0,_minimumAliasedLineWidth:0,_maximumAliasedLineWidth:0,_minimumAliasedPointSize:0,_maximumAliasedPointSize:0,_maximumViewportWidth:0,_maximumViewportHeight:0,_maximumTextureFilterAnisotropy:0,_maximumDrawBuffers:0,_maximumColorAttachments:0,_maximumSamples:0,_highpFloatSupported:!1,_highpIntSupported:!1};Object.defineProperties(vn,{maximumCombinedTextureImageUnits:{get:function(){return vn._maximumCombinedTextureImageUnits}},maximumCubeMapSize:{get:function(){return vn._maximumCubeMapSize}},maximumFragmentUniformVectors:{get:function(){return vn._maximumFragmentUniformVectors}},maximumTextureImageUnits:{get:function(){return vn._maximumTextureImageUnits}},maximumRenderbufferSize:{get:function(){return vn._maximumRenderbufferSize}},maximumTextureSize:{get:function(){return vn._maximumTextureSize}},maximumVaryingVectors:{get:function(){return vn._maximumVaryingVectors}},maximumVertexAttributes:{get:function(){return vn._maximumVertexAttributes}},maximumVertexTextureImageUnits:{get:function(){return vn._maximumVertexTextureImageUnits}},maximumVertexUniformVectors:{get:function(){return vn._maximumVertexUniformVectors}},minimumAliasedLineWidth:{get:function(){return vn._minimumAliasedLineWidth}},maximumAliasedLineWidth:{get:function(){return vn._maximumAliasedLineWidth}},minimumAliasedPointSize:{get:function(){return vn._minimumAliasedPointSize}},maximumAliasedPointSize:{get:function(){return vn._maximumAliasedPointSize}},maximumViewportWidth:{get:function(){return vn._maximumViewportWidth}},maximumViewportHeight:{get:function(){return vn._maximumViewportHeight}},maximumTextureFilterAnisotropy:{get:function(){return vn._maximumTextureFilterAnisotropy}},maximumDrawBuffers:{get:function(){return vn._maximumDrawBuffers}},maximumColorAttachments:{get:function(){return vn._maximumColorAttachments}},maximumSamples:{get:function(){return vn._maximumSamples}},highpFloatSupported:{get:function(){return vn._highpFloatSupported}},highpIntSupported:{get:function(){return vn._highpIntSupported}}});en=vn});var io,ne,Xi=S(()=>{ss();io={POINTS:it.POINTS,LINES:it.LINES,LINE_LOOP:it.LINE_LOOP,LINE_STRIP:it.LINE_STRIP,TRIANGLES:it.TRIANGLES,TRIANGLE_STRIP:it.TRIANGLE_STRIP,TRIANGLE_FAN:it.TRIANGLE_FAN};io.isLines=function(t){return t===io.LINES||t===io.LINE_LOOP||t===io.LINE_STRIP};io.isTriangles=function(t){return t===io.TRIANGLES||t===io.TRIANGLE_STRIP||t===io.TRIANGLE_FAN};io.validate=function(t){return t===io.POINTS||t===io.LINES||t===io.LINE_LOOP||t===io.LINE_STRIP||t===io.TRIANGLES||t===io.TRIANGLE_STRIP||t===io.TRIANGLE_FAN};ne=Object.freeze(io)});function TE(t){t=Z(t,Z.EMPTY_OBJECT),this._boundingVolume=t.boundingVolume,this._orientedBoundingBox=t.orientedBoundingBox,this._modelMatrix=t.modelMatrix,this._primitiveType=Z(t.primitiveType,ne.TRIANGLES),this._vertexArray=t.vertexArray,this._count=t.count,this._offset=Z(t.offset,0),this._instanceCount=Z(t.instanceCount,0),this._shaderProgram=t.shaderProgram,this._uniformMap=t.uniformMap,this._renderState=t.renderState,this._framebuffer=t.framebuffer,this._pass=t.pass,this._owner=t.owner,this._debugOverlappingFrustums=0,this._pickId=t.pickId,this._flags=0,this.cull=Z(t.cull,!0),this.occlude=Z(t.occlude,!0),this.executeInClosestFrustum=Z(t.executeInClosestFrustum,!1),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.castShadows=Z(t.castShadows,!1),this.receiveShadows=Z(t.receiveShadows,!1),this.pickOnly=Z(t.pickOnly,!1),this.depthForTranslucentClassification=Z(t.depthForTranslucentClassification,!1),this.dirty=!0,this.lastDirtyTime=0,this.derivedCommands={}}function Io(t,e){return(t._flags&e)===e}function mc(t,e,i){i?t._flags|=e:t._flags&=~e}var zn,fn,Gm=S(()=>{Ft();mt();Xi();zn={CULL:1,OCCLUDE:2,EXECUTE_IN_CLOSEST_FRUSTUM:4,DEBUG_SHOW_BOUNDING_VOLUME:8,CAST_SHADOWS:16,RECEIVE_SHADOWS:32,PICK_ONLY:64,DEPTH_FOR_TRANSLUCENT_CLASSIFICATION:128};Object.defineProperties(TE.prototype,{boundingVolume:{get:function(){return this._boundingVolume},set:function(t){this._boundingVolume!==t&&(this._boundingVolume=t,this.dirty=!0)}},orientedBoundingBox:{get:function(){return this._orientedBoundingBox},set:function(t){this._orientedBoundingBox!==t&&(this._orientedBoundingBox=t,this.dirty=!0)}},cull:{get:function(){return Io(this,zn.CULL)},set:function(t){Io(this,zn.CULL)!==t&&(mc(this,zn.CULL,t),this.dirty=!0)}},occlude:{get:function(){return Io(this,zn.OCCLUDE)},set:function(t){Io(this,zn.OCCLUDE)!==t&&(mc(this,zn.OCCLUDE,t),this.dirty=!0)}},modelMatrix:{get:function(){return this._modelMatrix},set:function(t){this._modelMatrix!==t&&(this._modelMatrix=t,this.dirty=!0)}},primitiveType:{get:function(){return this._primitiveType},set:function(t){this._primitiveType!==t&&(this._primitiveType=t,this.dirty=!0)}},vertexArray:{get:function(){return this._vertexArray},set:function(t){this._vertexArray!==t&&(this._vertexArray=t,this.dirty=!0)}},count:{get:function(){return this._count},set:function(t){this._count!==t&&(this._count=t,this.dirty=!0)}},offset:{get:function(){return this._offset},set:function(t){this._offset!==t&&(this._offset=t,this.dirty=!0)}},instanceCount:{get:function(){return this._instanceCount},set:function(t){this._instanceCount!==t&&(this._instanceCount=t,this.dirty=!0)}},shaderProgram:{get:function(){return this._shaderProgram},set:function(t){this._shaderProgram!==t&&(this._shaderProgram=t,this.dirty=!0)}},castShadows:{get:function(){return Io(this,zn.CAST_SHADOWS)},set:function(t){Io(this,zn.CAST_SHADOWS)!==t&&(mc(this,zn.CAST_SHADOWS,t),this.dirty=!0)}},receiveShadows:{get:function(){return Io(this,zn.RECEIVE_SHADOWS)},set:function(t){Io(this,zn.RECEIVE_SHADOWS)!==t&&(mc(this,zn.RECEIVE_SHADOWS,t),this.dirty=!0)}},uniformMap:{get:function(){return this._uniformMap},set:function(t){this._uniformMap!==t&&(this._uniformMap=t,this.dirty=!0)}},renderState:{get:function(){return this._renderState},set:function(t){this._renderState!==t&&(this._renderState=t,this.dirty=!0)}},framebuffer:{get:function(){return this._framebuffer},set:function(t){this._framebuffer!==t&&(this._framebuffer=t,this.dirty=!0)}},pass:{get:function(){return this._pass},set:function(t){this._pass!==t&&(this._pass=t,this.dirty=!0)}},executeInClosestFrustum:{get:function(){return Io(this,zn.EXECUTE_IN_CLOSEST_FRUSTUM)},set:function(t){Io(this,zn.EXECUTE_IN_CLOSEST_FRUSTUM)!==t&&(mc(this,zn.EXECUTE_IN_CLOSEST_FRUSTUM,t),this.dirty=!0)}},owner:{get:function(){return this._owner},set:function(t){this._owner!==t&&(this._owner=t,this.dirty=!0)}},debugShowBoundingVolume:{get:function(){return Io(this,zn.DEBUG_SHOW_BOUNDING_VOLUME)},set:function(t){Io(this,zn.DEBUG_SHOW_BOUNDING_VOLUME)!==t&&(mc(this,zn.DEBUG_SHOW_BOUNDING_VOLUME,t),this.dirty=!0)}},debugOverlappingFrustums:{get:function(){return this._debugOverlappingFrustums},set:function(t){this._debugOverlappingFrustums!==t&&(this._debugOverlappingFrustums=t,this.dirty=!0)}},pickId:{get:function(){return this._pickId},set:function(t){this._pickId!==t&&(this._pickId=t,this.dirty=!0)}},pickOnly:{get:function(){return Io(this,zn.PICK_ONLY)},set:function(t){Io(this,zn.PICK_ONLY)!==t&&(mc(this,zn.PICK_ONLY,t),this.dirty=!0)}},depthForTranslucentClassification:{get:function(){return Io(this,zn.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION)},set:function(t){Io(this,zn.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION)!==t&&(mc(this,zn.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION,t),this.dirty=!0)}}});TE.shallowClone=function(t,e){if(m(t))return m(e)||(e=new TE),e._boundingVolume=t._boundingVolume,e._orientedBoundingBox=t._orientedBoundingBox,e._modelMatrix=t._modelMatrix,e._primitiveType=t._primitiveType,e._vertexArray=t._vertexArray,e._count=t._count,e._offset=t._offset,e._instanceCount=t._instanceCount,e._shaderProgram=t._shaderProgram,e._uniformMap=t._uniformMap,e._renderState=t._renderState,e._framebuffer=t._framebuffer,e._pass=t._pass,e._owner=t._owner,e._debugOverlappingFrustums=t._debugOverlappingFrustums,e._pickId=t._pickId,e._flags=t._flags,e.dirty=!0,e.lastDirtyTime=0,e};TE.prototype.execute=function(t,e){t.draw(this,e)};fn=TE});var w$,os,Wm=S(()=>{w$={ENVIRONMENT:0,COMPUTE:1,GLOBE:2,TERRAIN_CLASSIFICATION:3,CESIUM_3D_TILE:4,CESIUM_3D_TILE_CLASSIFICATION:5,CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW:6,OPAQUE:7,TRANSLUCENT:8,VOXELS:9,OVERLAY:10,NUMBER_OF_PASSES:11},os=Object.freeze(w$)});var AI,Us,fc=S(()=>{ss();AI={CLOCKWISE:it.CW,COUNTER_CLOCKWISE:it.CCW};AI.validate=function(t){return t===AI.CLOCKWISE||t===AI.COUNTER_CLOCKWISE};Us=Object.freeze(AI)});function gD(t){if(typeof t!="object"||t===null)return t;let e,i=Object.keys(t);for(let n=0;n<i.length;n++)e=i[n],t.hasOwnProperty(e)&&e!=="_applyFunctions"&&(t[e]=gD(t[e]));return Object.freeze(t)}var TD,ND=S(()=>{TD=gD});function FD(t){return t===it.FUNC_ADD||t===it.FUNC_SUBTRACT||t===it.FUNC_REVERSE_SUBTRACT||t===it.MIN||t===it.MAX}function hI(t){return t===it.ZERO||t===it.ONE||t===it.SRC_COLOR||t===it.ONE_MINUS_SRC_COLOR||t===it.DST_COLOR||t===it.ONE_MINUS_DST_COLOR||t===it.SRC_ALPHA||t===it.ONE_MINUS_SRC_ALPHA||t===it.DST_ALPHA||t===it.ONE_MINUS_DST_ALPHA||t===it.CONSTANT_COLOR||t===it.ONE_MINUS_CONSTANT_COLOR||t===it.CONSTANT_ALPHA||t===it.ONE_MINUS_CONSTANT_ALPHA||t===it.SRC_ALPHA_SATURATE}function x$(t){return t===it.FRONT||t===it.BACK||t===it.FRONT_AND_BACK}function P$(t){return t===it.NEVER||t===it.LESS||t===it.EQUAL||t===it.LEQUAL||t===it.GREATER||t===it.NOTEQUAL||t===it.GEQUAL||t===it.ALWAYS}function bD(t){return t===it.NEVER||t===it.LESS||t===it.EQUAL||t===it.LEQUAL||t===it.GREATER||t===it.NOTEQUAL||t===it.GEQUAL||t===it.ALWAYS}function Dm(t){return t===it.ZERO||t===it.KEEP||t===it.REPLACE||t===it.INCR||t===it.DECR||t===it.INVERT||t===it.INCR_WRAP||t===it.DECR_WRAP}function _A(t){let e=Z(t,Z.EMPTY_OBJECT),i=Z(e.cull,Z.EMPTY_OBJECT),n=Z(e.polygonOffset,Z.EMPTY_OBJECT),s=Z(e.scissorTest,Z.EMPTY_OBJECT),o=Z(s.rectangle,Z.EMPTY_OBJECT),r=Z(e.depthRange,Z.EMPTY_OBJECT),a=Z(e.depthTest,Z.EMPTY_OBJECT),h=Z(e.colorMask,Z.EMPTY_OBJECT),A=Z(e.blending,Z.EMPTY_OBJECT),d=Z(A.color,Z.EMPTY_OBJECT),f=Z(e.stencilTest,Z.EMPTY_OBJECT),E=Z(f.frontOperation,Z.EMPTY_OBJECT),_=Z(f.backOperation,Z.EMPTY_OBJECT),R=Z(e.sampleCoverage,Z.EMPTY_OBJECT),I=e.viewport;if(this.frontFace=Z(e.frontFace,Us.COUNTER_CLOCKWISE),this.cull={enabled:Z(i.enabled,!1),face:Z(i.face,it.BACK)},this.lineWidth=Z(e.lineWidth,1),this.polygonOffset={enabled:Z(n.enabled,!1),factor:Z(n.factor,0),units:Z(n.units,0)},this.scissorTest={enabled:Z(s.enabled,!1),rectangle:mi.clone(o)},this.depthRange={near:Z(r.near,0),far:Z(r.far,1)},this.depthTest={enabled:Z(a.enabled,!1),func:Z(a.func,it.LESS)},this.colorMask={red:Z(h.red,!0),green:Z(h.green,!0),blue:Z(h.blue,!0),alpha:Z(h.alpha,!0)},this.depthMask=Z(e.depthMask,!0),this.stencilMask=Z(e.stencilMask,-1),this.blending={enabled:Z(A.enabled,!1),color:new Zt(Z(d.red,0),Z(d.green,0),Z(d.blue,0),Z(d.alpha,0)),equationRgb:Z(A.equationRgb,it.FUNC_ADD),equationAlpha:Z(A.equationAlpha,it.FUNC_ADD),functionSourceRgb:Z(A.functionSourceRgb,it.ONE),functionSourceAlpha:Z(A.functionSourceAlpha,it.ONE),functionDestinationRgb:Z(A.functionDestinationRgb,it.ZERO),functionDestinationAlpha:Z(A.functionDestinationAlpha,it.ZERO)},this.stencilTest={enabled:Z(f.enabled,!1),frontFunction:Z(f.frontFunction,it.ALWAYS),backFunction:Z(f.backFunction,it.ALWAYS),reference:Z(f.reference,0),mask:Z(f.mask,-1),frontOperation:{fail:Z(E.fail,it.KEEP),zFail:Z(E.zFail,it.KEEP),zPass:Z(E.zPass,it.KEEP)},backOperation:{fail:Z(_.fail,it.KEEP),zFail:Z(_.zFail,it.KEEP),zPass:Z(_.zPass,it.KEEP)}},this.sampleCoverage={enabled:Z(R.enabled,!1),value:Z(R.value,1),invert:Z(R.invert,!1)},this.viewport=m(I)?new mi(I.x,I.y,I.width,I.height):void 0,this.lineWidth<en.minimumAliasedLineWidth||this.lineWidth>en.maximumAliasedLineWidth)throw new Y("renderState.lineWidth is out of range.  Check minimumAliasedLineWidth and maximumAliasedLineWidth.");if(!Us.validate(this.frontFace))throw new Y("Invalid renderState.frontFace.");if(!x$(this.cull.face))throw new Y("Invalid renderState.cull.face.");if(this.scissorTest.rectangle.width<0||this.scissorTest.rectangle.height<0)throw new Y("renderState.scissorTest.rectangle.width and renderState.scissorTest.rectangle.height must be greater than or equal to zero.");if(this.depthRange.near>this.depthRange.far)throw new Y("renderState.depthRange.near can not be greater than renderState.depthRange.far.");if(this.depthRange.near<0)throw new Y("renderState.depthRange.near must be greater than or equal to zero.");if(this.depthRange.far>1)throw new Y("renderState.depthRange.far must be less than or equal to one.");if(!P$(this.depthTest.func))throw new Y("Invalid renderState.depthTest.func.");if(this.blending.color.red<0||this.blending.color.red>1||this.blending.color.green<0||this.blending.color.green>1||this.blending.color.blue<0||this.blending.color.blue>1||this.blending.color.alpha<0||this.blending.color.alpha>1)throw new Y("renderState.blending.color components must be greater than or equal to zero and less than or equal to one.");if(!FD(this.blending.equationRgb))throw new Y("Invalid renderState.blending.equationRgb.");if(!FD(this.blending.equationAlpha))throw new Y("Invalid renderState.blending.equationAlpha.");if(!hI(this.blending.functionSourceRgb))throw new Y("Invalid renderState.blending.functionSourceRgb.");if(!hI(this.blending.functionSourceAlpha))throw new Y("Invalid renderState.blending.functionSourceAlpha.");if(!hI(this.blending.functionDestinationRgb))throw new Y("Invalid renderState.blending.functionDestinationRgb.");if(!hI(this.blending.functionDestinationAlpha))throw new Y("Invalid renderState.blending.functionDestinationAlpha.");if(!bD(this.stencilTest.frontFunction))throw new Y("Invalid renderState.stencilTest.frontFunction.");if(!bD(this.stencilTest.backFunction))throw new Y("Invalid renderState.stencilTest.backFunction.");if(!Dm(this.stencilTest.frontOperation.fail))throw new Y("Invalid renderState.stencilTest.frontOperation.fail.");if(!Dm(this.stencilTest.frontOperation.zFail))throw new Y("Invalid renderState.stencilTest.frontOperation.zFail.");if(!Dm(this.stencilTest.frontOperation.zPass))throw new Y("Invalid renderState.stencilTest.frontOperation.zPass.");if(!Dm(this.stencilTest.backOperation.fail))throw new Y("Invalid renderState.stencilTest.backOperation.fail.");if(!Dm(this.stencilTest.backOperation.zFail))throw new Y("Invalid renderState.stencilTest.backOperation.zFail.");if(!Dm(this.stencilTest.backOperation.zPass))throw new Y("Invalid renderState.stencilTest.backOperation.zPass.");if(m(this.viewport)){if(this.viewport.width<0)throw new Y("renderState.viewport.width must be greater than or equal to zero.");if(this.viewport.height<0)throw new Y("renderState.viewport.height must be greater than or equal to zero.");if(this.viewport.width>en.maximumViewportWidth)throw new Y(`renderState.viewport.width must be less than or equal to the maximum viewport width (${en.maximumViewportWidth.toString()}).  Check maximumViewportWidth.`);if(this.viewport.height>en.maximumViewportHeight)throw new Y(`renderState.viewport.height must be less than or equal to the maximum viewport height (${en.maximumViewportHeight.toString()}).  Check maximumViewportHeight.`)}this.id=0,this._applyFunctions=[]}function Fl(t,e,i){i?t.enable(e):t.disable(e)}function YD(t,e){t.frontFace(e.frontFace)}function VD(t,e){let i=e.cull,n=i.enabled;Fl(t,t.CULL_FACE,n),n&&t.cullFace(i.face)}function SD(t,e){t.lineWidth(e.lineWidth)}function OD(t,e){let i=e.polygonOffset,n=i.enabled;Fl(t,t.POLYGON_OFFSET_FILL,n),n&&t.polygonOffset(i.factor,i.units)}function BD(t,e,i){let n=e.scissorTest,s=m(i.scissorTest)?i.scissorTest.enabled:n.enabled;if(Fl(t,t.SCISSOR_TEST,s),s){let o=m(i.scissorTest)?i.scissorTest.rectangle:n.rectangle;t.scissor(o.x,o.y,o.width,o.height)}}function GD(t,e){let i=e.depthRange;t.depthRange(i.near,i.far)}function WD(t,e){let i=e.depthTest,n=i.enabled;Fl(t,t.DEPTH_TEST,n),n&&t.depthFunc(i.func)}function DD(t,e){let i=e.colorMask;t.colorMask(i.red,i.green,i.blue,i.alpha)}function UD(t,e){t.depthMask(e.depthMask)}function MD(t,e){t.stencilMask(e.stencilMask)}function j$(t,e){t.blendColor(e.red,e.green,e.blue,e.alpha)}function QD(t,e,i){let n=e.blending,s=m(i.blendingEnabled)?i.blendingEnabled:n.enabled;Fl(t,t.BLEND,s),s&&(j$(t,n.color),t.blendEquationSeparate(n.equationRgb,n.equationAlpha),t.blendFuncSeparate(n.functionSourceRgb,n.functionDestinationRgb,n.functionSourceAlpha,n.functionDestinationAlpha))}function kD(t,e){let i=e.stencilTest,n=i.enabled;if(Fl(t,t.STENCIL_TEST,n),n){let s=i.frontFunction,o=i.backFunction,r=i.reference,a=i.mask;t.stencilFunc(s,r,a),t.stencilFuncSeparate(t.BACK,o,r,a),t.stencilFuncSeparate(t.FRONT,s,r,a);let h=i.frontOperation,A=h.fail,d=h.zFail,f=h.zPass;t.stencilOpSeparate(t.FRONT,A,d,f);let E=i.backOperation,_=E.fail,R=E.zFail,I=E.zPass;t.stencilOpSeparate(t.BACK,_,R,I)}}function LD(t,e){let i=e.sampleCoverage,n=i.enabled;Fl(t,t.SAMPLE_COVERAGE,n),n&&t.sampleCoverage(i.value,i.invert)}function yD(t,e,i){let n=Z(e.viewport,i.viewport);m(n)||(n=H$,n.width=i.context.drawingBufferWidth,n.height=i.context.drawingBufferHeight),i.context.uniformState.viewport=n,t.viewport(n.x,n.y,n.width,n.height)}function v$(t,e){let i=[];return t.frontFace!==e.frontFace&&i.push(YD),(t.cull.enabled!==e.cull.enabled||t.cull.face!==e.cull.face)&&i.push(VD),t.lineWidth!==e.lineWidth&&i.push(SD),(t.polygonOffset.enabled!==e.polygonOffset.enabled||t.polygonOffset.factor!==e.polygonOffset.factor||t.polygonOffset.units!==e.polygonOffset.units)&&i.push(OD),(t.depthRange.near!==e.depthRange.near||t.depthRange.far!==e.depthRange.far)&&i.push(GD),(t.depthTest.enabled!==e.depthTest.enabled||t.depthTest.func!==e.depthTest.func)&&i.push(WD),(t.colorMask.red!==e.colorMask.red||t.colorMask.green!==e.colorMask.green||t.colorMask.blue!==e.colorMask.blue||t.colorMask.alpha!==e.colorMask.alpha)&&i.push(DD),t.depthMask!==e.depthMask&&i.push(UD),t.stencilMask!==e.stencilMask&&i.push(MD),(t.stencilTest.enabled!==e.stencilTest.enabled||t.stencilTest.frontFunction!==e.stencilTest.frontFunction||t.stencilTest.backFunction!==e.stencilTest.backFunction||t.stencilTest.reference!==e.stencilTest.reference||t.stencilTest.mask!==e.stencilTest.mask||t.stencilTest.frontOperation.fail!==e.stencilTest.frontOperation.fail||t.stencilTest.frontOperation.zFail!==e.stencilTest.frontOperation.zFail||t.stencilTest.backOperation.fail!==e.stencilTest.backOperation.fail||t.stencilTest.backOperation.zFail!==e.stencilTest.backOperation.zFail||t.stencilTest.backOperation.zPass!==e.stencilTest.backOperation.zPass)&&i.push(kD),(t.sampleCoverage.enabled!==e.sampleCoverage.enabled||t.sampleCoverage.value!==e.sampleCoverage.value||t.sampleCoverage.invert!==e.sampleCoverage.invert)&&i.push(LD),i}var J$,EA,H$,Yn,Um=S(()=>{Er();Qn();Ft();mt();Ot();ss();fc();ga();ND();J$=0,EA={};_A.fromCache=function(t){let e=JSON.stringify(t),i=EA[e];if(m(i))return++i.referenceCount,i.state;let n=new _A(t),s=JSON.stringify(n);return i=EA[s],m(i)||(n.id=J$++,n=TD(n),i={referenceCount:0,state:n},EA[s]=i),++i.referenceCount,EA[e]={referenceCount:1,state:i.state},i.state};_A.removeFromCache=function(t){let e=new _A(t),i=JSON.stringify(e),n=EA[i],s=JSON.stringify(t),o=EA[s];m(o)&&(--o.referenceCount,o.referenceCount===0&&(delete EA[s],m(n)&&--n.referenceCount)),m(n)&&n.referenceCount===0&&delete EA[i]};_A.getCache=function(){return EA};_A.clearCache=function(){EA={}};H$=new mi;_A.apply=function(t,e,i){YD(t,e),VD(t,e),SD(t,e),OD(t,e),GD(t,e),WD(t,e),DD(t,e),UD(t,e),MD(t,e),kD(t,e),LD(t,e),BD(t,e,i),QD(t,e,i),yD(t,e,i)};_A.partialApply=function(t,e,i,n,s,o){if(e!==i){let d=i._applyFunctions[e.id];m(d)||(d=v$(e,i),i._applyFunctions[e.id]=d);let f=d.length;for(let E=0;E<f;++E)d[E](t,i)}let r=m(n.scissorTest)?n.scissorTest:e.scissorTest,a=m(s.scissorTest)?s.scissorTest:i.scissorTest;(r!==a||o)&&BD(t,i,s);let h=m(n.blendingEnabled)?n.blendingEnabled:e.blending.enabled,A=m(s.blendingEnabled)?s.blendingEnabled:i.blending.enabled;(h!==A||A&&e.blending!==i.blending)&&QD(t,i,s),(e!==i||n!==s||n.context!==s.context)&&yD(t,i,s)};_A.getState=function(t){if(!m(t))throw new Y("renderState is required.");return{frontFace:t.frontFace,cull:{enabled:t.cull.enabled,face:t.cull.face},lineWidth:t.lineWidth,polygonOffset:{enabled:t.polygonOffset.enabled,factor:t.polygonOffset.factor,units:t.polygonOffset.units},scissorTest:{enabled:t.scissorTest.enabled,rectangle:mi.clone(t.scissorTest.rectangle)},depthRange:{near:t.depthRange.near,far:t.depthRange.far},depthTest:{enabled:t.depthTest.enabled,func:t.depthTest.func},colorMask:{red:t.colorMask.red,green:t.colorMask.green,blue:t.colorMask.blue,alpha:t.colorMask.alpha},depthMask:t.depthMask,stencilMask:t.stencilMask,blending:{enabled:t.blending.enabled,color:Zt.clone(t.blending.color),equationRgb:t.blending.equationRgb,equationAlpha:t.blending.equationAlpha,functionSourceRgb:t.blending.functionSourceRgb,functionSourceAlpha:t.blending.functionSourceAlpha,functionDestinationRgb:t.blending.functionDestinationRgb,functionDestinationAlpha:t.blending.functionDestinationAlpha},stencilTest:{enabled:t.stencilTest.enabled,frontFunction:t.stencilTest.frontFunction,backFunction:t.stencilTest.backFunction,reference:t.stencilTest.reference,mask:t.stencilTest.mask,frontOperation:{fail:t.stencilTest.frontOperation.fail,zFail:t.stencilTest.frontOperation.zFail,zPass:t.stencilTest.frontOperation.zPass},backOperation:{fail:t.stencilTest.backOperation.fail,zFail:t.stencilTest.backOperation.zFail,zPass:t.stencilTest.backOperation.zPass}},sampleCoverage:{enabled:t.sampleCoverage.enabled,value:t.sampleCoverage.value,invert:t.sampleCoverage.invert},viewport:m(t.viewport)?mi.clone(t.viewport):void 0}};Yn=_A});function de(t){this._size=t.size,this._datatype=t.datatype,this.getValue=t.getValue}var z$,Hs,K$,Mm,bT=S(()=>{Ht();bi();ss();z$=new l;Hs={};Hs[it.FLOAT]="float";Hs[it.FLOAT_VEC2]="vec2";Hs[it.FLOAT_VEC3]="vec3";Hs[it.FLOAT_VEC4]="vec4";Hs[it.INT]="int";Hs[it.INT_VEC2]="ivec2";Hs[it.INT_VEC3]="ivec3";Hs[it.INT_VEC4]="ivec4";Hs[it.BOOL]="bool";Hs[it.BOOL_VEC2]="bvec2";Hs[it.BOOL_VEC3]="bvec3";Hs[it.BOOL_VEC4]="bvec4";Hs[it.FLOAT_MAT2]="mat2";Hs[it.FLOAT_MAT3]="mat3";Hs[it.FLOAT_MAT4]="mat4";Hs[it.SAMPLER_2D]="sampler2D";Hs[it.SAMPLER_CUBE]="samplerCube";de.prototype.getDeclaration=function(t){let e=`uniform ${Hs[this._datatype]} ${t}`,i=this._size;return i===1?e+=";":e+=`[${i.toString()}];`,e};K$={czm_viewport:new de({size:1,datatype:it.FLOAT_VEC4,getValue:function(t){return t.viewportCartesian4}}),czm_viewportOrthographic:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.viewportOrthographic}}),czm_viewportTransformation:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.viewportTransformation}}),czm_globeDepthTexture:new de({size:1,datatype:it.SAMPLER_2D,getValue:function(t){return t.globeDepthTexture}}),czm_model:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.model}}),czm_inverseModel:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseModel}}),czm_view:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.view}}),czm_view3D:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.view3D}}),czm_viewRotation:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.viewRotation}}),czm_viewRotation3D:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.viewRotation3D}}),czm_inverseView:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseView}}),czm_inverseView3D:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseView3D}}),czm_inverseViewRotation:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.inverseViewRotation}}),czm_inverseViewRotation3D:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.inverseViewRotation3D}}),czm_projection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.projection}}),czm_inverseProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseProjection}}),czm_infiniteProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.infiniteProjection}}),czm_modelView:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelView}}),czm_modelView3D:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelView3D}}),czm_modelViewRelativeToEye:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelViewRelativeToEye}}),czm_inverseModelView:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseModelView}}),czm_inverseModelView3D:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseModelView3D}}),czm_viewProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.viewProjection}}),czm_inverseViewProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseViewProjection}}),czm_modelViewProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelViewProjection}}),czm_inverseModelViewProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.inverseModelViewProjection}}),czm_modelViewProjectionRelativeToEye:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelViewProjectionRelativeToEye}}),czm_modelViewInfiniteProjection:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelViewInfiniteProjection}}),czm_orthographicIn3D:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.orthographicIn3D?1:0}}),czm_normal:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.normal}}),czm_normal3D:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.normal3D}}),czm_inverseNormal:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.inverseNormal}}),czm_inverseNormal3D:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.inverseNormal3D}}),czm_eyeHeight:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.eyeHeight}}),czm_eyeHeight2D:new de({size:1,datatype:it.FLOAT_VEC2,getValue:function(t){return t.eyeHeight2D}}),czm_eyeEllipsoidNormalEC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.eyeEllipsoidNormalEC}}),czm_eyeEllipsoidCurvature:new de({size:1,datatype:it.FLOAT_VEC2,getValue:function(t){return t.eyeEllipsoidCurvature}}),czm_modelToEnu:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.modelToEnu}}),czm_enuToModel:new de({size:1,datatype:it.FLOAT_MAT4,getValue:function(t){return t.enuToModel}}),czm_entireFrustum:new de({size:1,datatype:it.FLOAT_VEC2,getValue:function(t){return t.entireFrustum}}),czm_currentFrustum:new de({size:1,datatype:it.FLOAT_VEC2,getValue:function(t){return t.currentFrustum}}),czm_frustumPlanes:new de({size:1,datatype:it.FLOAT_VEC4,getValue:function(t){return t.frustumPlanes}}),czm_farDepthFromNearPlusOne:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.farDepthFromNearPlusOne}}),czm_log2FarDepthFromNearPlusOne:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.log2FarDepthFromNearPlusOne}}),czm_oneOverLog2FarDepthFromNearPlusOne:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.oneOverLog2FarDepthFromNearPlusOne}}),czm_sunPositionWC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.sunPositionWC}}),czm_sunPositionColumbusView:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.sunPositionColumbusView}}),czm_sunDirectionEC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.sunDirectionEC}}),czm_sunDirectionWC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.sunDirectionWC}}),czm_moonDirectionEC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.moonDirectionEC}}),czm_lightDirectionEC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.lightDirectionEC}}),czm_lightDirectionWC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.lightDirectionWC}}),czm_lightColor:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.lightColor}}),czm_lightColorHdr:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.lightColorHdr}}),czm_encodedCameraPositionMCHigh:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.encodedCameraPositionMCHigh}}),czm_encodedCameraPositionMCLow:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.encodedCameraPositionMCLow}}),czm_viewerPositionWC:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return at.getTranslation(t.inverseView,z$)}}),czm_frameNumber:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.frameState.frameNumber}}),czm_morphTime:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.frameState.morphTime}}),czm_sceneMode:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.frameState.mode}}),czm_pass:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.pass}}),czm_backgroundColor:new de({size:1,datatype:it.FLOAT_VEC4,getValue:function(t){return t.backgroundColor}}),czm_brdfLut:new de({size:1,datatype:it.SAMPLER_2D,getValue:function(t){return t.brdfLut}}),czm_environmentMap:new de({size:1,datatype:it.SAMPLER_CUBE,getValue:function(t){return t.environmentMap}}),czm_specularEnvironmentMaps:new de({size:1,datatype:it.SAMPLER_2D,getValue:function(t){return t.specularEnvironmentMaps}}),czm_specularEnvironmentMapSize:new de({size:1,datatype:it.FLOAT_VEC2,getValue:function(t){return t.specularEnvironmentMapsDimensions}}),czm_specularEnvironmentMapsMaximumLOD:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.specularEnvironmentMapsMaximumLOD}}),czm_sphericalHarmonicCoefficients:new de({size:9,datatype:it.FLOAT_VEC3,getValue:function(t){return t.sphericalHarmonicCoefficients}}),czm_temeToPseudoFixed:new de({size:1,datatype:it.FLOAT_MAT3,getValue:function(t){return t.temeToPseudoFixedMatrix}}),czm_pixelRatio:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.pixelRatio}}),czm_fogDensity:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.fogDensity}}),czm_fogMinimumBrightness:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.fogMinimumBrightness}}),czm_atmosphereHsbShift:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.atmosphereHsbShift}}),czm_atmosphereLightIntensity:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.atmosphereLightIntensity}}),czm_atmosphereRayleighCoefficient:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.atmosphereRayleighCoefficient}}),czm_atmosphereRayleighScaleHeight:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.atmosphereRayleighScaleHeight}}),czm_atmosphereMieCoefficient:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.atmosphereMieCoefficient}}),czm_atmosphereMieScaleHeight:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.atmosphereMieScaleHeight}}),czm_atmosphereMieAnisotropy:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.atmosphereMieAnisotropy}}),czm_atmosphereDynamicLighting:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.atmosphereDynamicLighting}}),czm_splitPosition:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.splitPosition}}),czm_geometricToleranceOverMeter:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.geometricToleranceOverMeter}}),czm_minimumDisableDepthTestDistance:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.minimumDisableDepthTestDistance}}),czm_invertClassificationColor:new de({size:1,datatype:it.FLOAT_VEC4,getValue:function(t){return t.invertClassificationColor}}),czm_gamma:new de({size:1,datatype:it.FLOAT,getValue:function(t){return t.gamma}}),czm_ellipsoidRadii:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.ellipsoid.radii}}),czm_ellipsoidInverseRadii:new de({size:1,datatype:it.FLOAT_VEC3,getValue:function(t){return t.ellipsoid.oneOverRadii}})},Mm=K$});function X$(t,e,i,n){switch(e.type){case t.FLOAT:return new wD(t,e,i,n);case t.FLOAT_VEC2:return new xD(t,e,i,n);case t.FLOAT_VEC3:return new PD(t,e,i,n);case t.FLOAT_VEC4:return new JD(t,e,i,n);case t.SAMPLER_2D:case t.SAMPLER_CUBE:return new YT(t,e,i,n);case t.INT:case t.BOOL:return new jD(t,e,i,n);case t.INT_VEC2:case t.BOOL_VEC2:return new HD(t,e,i,n);case t.INT_VEC3:case t.BOOL_VEC3:return new vD(t,e,i,n);case t.INT_VEC4:case t.BOOL_VEC4:return new zD(t,e,i,n);case t.FLOAT_MAT2:return new KD(t,e,i,n);case t.FLOAT_MAT3:return new XD(t,e,i,n);case t.FLOAT_MAT4:return new qD(t,e,i,n);default:throw new ke(`Unrecognized uniform type: ${e.type} for uniform "${i}".`)}}function wD(t,e,i,n){this.name=i,this.value=void 0,this._value=0,this._gl=t,this._location=n}function xD(t,e,i,n){this.name=i,this.value=void 0,this._value=new nt,this._gl=t,this._location=n}function PD(t,e,i,n){this.name=i,this.value=void 0,this._value=void 0,this._gl=t,this._location=n}function JD(t,e,i,n){this.name=i,this.value=void 0,this._value=void 0,this._gl=t,this._location=n}function YT(t,e,i,n){this.name=i,this.value=void 0,this._gl=t,this._location=n,this.textureUnitIndex=void 0}function jD(t,e,i,n){this.name=i,this.value=void 0,this._value=0,this._gl=t,this._location=n}function HD(t,e,i,n){this.name=i,this.value=void 0,this._value=new nt,this._gl=t,this._location=n}function vD(t,e,i,n){this.name=i,this.value=void 0,this._value=new l,this._gl=t,this._location=n}function zD(t,e,i,n){this.name=i,this.value=void 0,this._value=new ie,this._gl=t,this._location=n}function KD(t,e,i,n){this.name=i,this.value=void 0,this._value=new Hn,this._gl=t,this._location=n}function XD(t,e,i,n){this.name=i,this.value=void 0,this._value=new lt,this._gl=t,this._location=n}function qD(t,e,i,n){this.name=i,this.value=void 0,this._value=new at,this._gl=t,this._location=n}var q$,$$,ttt,$D,tU=S(()=>{Xe();Ht();Os();Qn();mt();Ot();dc();dn();bi();Ps();wD.prototype.set=function(){this.value!==this._value&&(this._value=this.value,this._gl.uniform1f(this._location,this.value))};xD.prototype.set=function(){let t=this.value;nt.equals(t,this._value)||(nt.clone(t,this._value),this._gl.uniform2f(this._location,t.x,t.y))};PD.prototype.set=function(){let t=this.value;if(m(t.red))Zt.equals(t,this._value)||(this._value=Zt.clone(t,this._value),this._gl.uniform3f(this._location,t.red,t.green,t.blue));else if(m(t.x))l.equals(t,this._value)||(this._value=l.clone(t,this._value),this._gl.uniform3f(this._location,t.x,t.y,t.z));else throw new Y(`Invalid vec3 value for uniform "${this.name}".`)};JD.prototype.set=function(){let t=this.value;if(m(t.red))Zt.equals(t,this._value)||(this._value=Zt.clone(t,this._value),this._gl.uniform4f(this._location,t.red,t.green,t.blue,t.alpha));else if(m(t.x))ie.equals(t,this._value)||(this._value=ie.clone(t,this._value),this._gl.uniform4f(this._location,t.x,t.y,t.z,t.w));else throw new Y(`Invalid vec4 value for uniform "${this.name}".`)};YT.prototype.set=function(){let t=this._gl;t.activeTexture(t.TEXTURE0+this.textureUnitIndex);let e=this.value;t.bindTexture(e._target,e._texture)};YT.prototype._setSampler=function(t){return this.textureUnitIndex=t,this._gl.uniform1i(this._location,t),t+1};jD.prototype.set=function(){this.value!==this._value&&(this._value=this.value,this._gl.uniform1i(this._location,this.value))};HD.prototype.set=function(){let t=this.value;nt.equals(t,this._value)||(nt.clone(t,this._value),this._gl.uniform2i(this._location,t.x,t.y))};vD.prototype.set=function(){let t=this.value;l.equals(t,this._value)||(l.clone(t,this._value),this._gl.uniform3i(this._location,t.x,t.y,t.z))};zD.prototype.set=function(){let t=this.value;ie.equals(t,this._value)||(ie.clone(t,this._value),this._gl.uniform4i(this._location,t.x,t.y,t.z,t.w))};q$=new Float32Array(4);KD.prototype.set=function(){if(!Hn.equalsArray(this.value,this._value,0)){Hn.clone(this.value,this._value);let t=Hn.toArray(this.value,q$);this._gl.uniformMatrix2fv(this._location,!1,t)}};$$=new Float32Array(9);XD.prototype.set=function(){if(!lt.equalsArray(this.value,this._value,0)){lt.clone(this.value,this._value);let t=lt.toArray(this.value,$$);this._gl.uniformMatrix3fv(this._location,!1,t)}};ttt=new Float32Array(16);qD.prototype.set=function(){if(!at.equalsArray(this.value,this._value,0)){at.clone(this.value,this._value);let t=at.toArray(this.value,ttt);this._gl.uniformMatrix4fv(this._location,!1,t)}};$D=X$});function ett(t,e,i,n){switch(e.type){case t.FLOAT:return new eU(t,e,i,n);case t.FLOAT_VEC2:return new iU(t,e,i,n);case t.FLOAT_VEC3:return new nU(t,e,i,n);case t.FLOAT_VEC4:return new sU(t,e,i,n);case t.SAMPLER_2D:case t.SAMPLER_CUBE:return new VT(t,e,i,n);case t.INT:case t.BOOL:return new oU(t,e,i,n);case t.INT_VEC2:case t.BOOL_VEC2:return new rU(t,e,i,n);case t.INT_VEC3:case t.BOOL_VEC3:return new aU(t,e,i,n);case t.INT_VEC4:case t.BOOL_VEC4:return new AU(t,e,i,n);case t.FLOAT_MAT2:return new hU(t,e,i,n);case t.FLOAT_MAT3:return new cU(t,e,i,n);case t.FLOAT_MAT4:return new lU(t,e,i,n);default:throw new ke(`Unrecognized uniform type: ${e.type} for uniform "${i}".`)}}function eU(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s),this._gl=t,this._location=n[0]}function iU(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*2),this._gl=t,this._location=n[0]}function nU(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*3),this._gl=t,this._location=n[0]}function sU(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*4),this._gl=t,this._location=n[0]}function VT(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s),this._gl=t,this._locations=n,this.textureUnitIndex=void 0}function oU(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Int32Array(s),this._gl=t,this._location=n[0]}function rU(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Int32Array(s*2),this._gl=t,this._location=n[0]}function aU(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Int32Array(s*3),this._gl=t,this._location=n[0]}function AU(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Int32Array(s*4),this._gl=t,this._location=n[0]}function hU(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*4),this._gl=t,this._location=n[0]}function cU(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*9),this._gl=t,this._location=n[0]}function lU(t,e,i,n){let s=n.length;this.name=i,this.value=new Array(s),this._value=new Float32Array(s*16),this._gl=t,this._location=n[0]}var dU,mU=S(()=>{Xe();Ht();Os();Qn();mt();Ot();dc();dn();bi();Ps();eU.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1;for(let s=0;s<e;++s){let o=t[s];o!==i[s]&&(i[s]=o,n=!0)}n&&this._gl.uniform1fv(this._location,i)};iU.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];nt.equalsArray(r,i,s)||(nt.pack(r,i,s),n=!0),s+=2}n&&this._gl.uniform2fv(this._location,i)};nU.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];if(m(r.red))(r.red!==i[s]||r.green!==i[s+1]||r.blue!==i[s+2])&&(i[s]=r.red,i[s+1]=r.green,i[s+2]=r.blue,n=!0);else if(m(r.x))l.equalsArray(r,i,s)||(l.pack(r,i,s),n=!0);else throw new Y("Invalid vec3 value.");s+=3}n&&this._gl.uniform3fv(this._location,i)};sU.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];if(m(r.red))Zt.equalsArray(r,i,s)||(Zt.pack(r,i,s),n=!0);else if(m(r.x))ie.equalsArray(r,i,s)||(ie.pack(r,i,s),n=!0);else throw new Y("Invalid vec4 value.");s+=4}n&&this._gl.uniform4fv(this._location,i)};VT.prototype.set=function(){let t=this._gl,e=t.TEXTURE0+this.textureUnitIndex,i=this.value,n=i.length;for(let s=0;s<n;++s){let o=i[s];t.activeTexture(e+s),t.bindTexture(o._target,o._texture)}};VT.prototype._setSampler=function(t){this.textureUnitIndex=t;let e=this._locations,i=e.length;for(let n=0;n<i;++n){let s=t+n;this._gl.uniform1i(e[n],s)}return t+i};oU.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1;for(let s=0;s<e;++s){let o=t[s];o!==i[s]&&(i[s]=o,n=!0)}n&&this._gl.uniform1iv(this._location,i)};rU.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];nt.equalsArray(r,i,s)||(nt.pack(r,i,s),n=!0),s+=2}n&&this._gl.uniform2iv(this._location,i)};aU.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];l.equalsArray(r,i,s)||(l.pack(r,i,s),n=!0),s+=3}n&&this._gl.uniform3iv(this._location,i)};AU.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];ie.equalsArray(r,i,s)||(ie.pack(r,i,s),n=!0),s+=4}n&&this._gl.uniform4iv(this._location,i)};hU.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];Hn.equalsArray(r,i,s)||(Hn.pack(r,i,s),n=!0),s+=4}n&&this._gl.uniformMatrix2fv(this._location,!1,i)};cU.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];lt.equalsArray(r,i,s)||(lt.pack(r,i,s),n=!0),s+=9}n&&this._gl.uniformMatrix3fv(this._location,!1,i)};lU.prototype.set=function(){let t=this.value,e=t.length,i=this._value,n=!1,s=0;for(let o=0;o<e;++o){let r=t[o];at.equalsArray(r,i,s)||(at.pack(r,i,s),n=!0),s+=16}n&&this._gl.uniformMatrix4fv(this._location,!1,i)};dU=ett});function ah(t){let e=t.vertexShaderText,i=t.fragmentShaderText;typeof spector<"u"&&(e=e.replace(/^#line/gm,"//#line"),i=i.replace(/^#line/gm,"//#line"));let n=ntt(e,i);this._gl=t.gl,this._logShaderCompilation=t.logShaderCompilation,this._debugShaders=t.debugShaders,this._attributeLocations=t.attributeLocations,this._program=void 0,this._numberOfVertexAttributes=void 0,this._vertexAttributes=void 0,this._uniformsByName=void 0,this._uniforms=void 0,this._automaticUniforms=void 0,this._manualUniforms=void 0,this._duplicateUniformNames=n.duplicateUniformNames,this._cachedShader=void 0,this.maximumTextureUnitIndex=void 0,this._vertexShaderSource=t.vertexShaderSource,this._vertexShaderText=t.vertexShaderText,this._fragmentShaderSource=t.fragmentShaderSource,this._fragmentShaderText=n.fragmentShaderText,this.id=itt++}function fU(t){let e=[],i=t.match(/uniform.*?(?![^{]*})(?=[=\[;])/g);if(m(i)){let n=i.length;for(let s=0;s<n;s++){let o=i[s].trim(),r=o.slice(o.lastIndexOf(" ")+1);e.push(r)}}return e}function ntt(t,e){let i={};if(!en.highpFloatSupported||!en.highpIntSupported){let n,s,o,r,a=fU(t),h=fU(e),A=a.length,d=h.length;for(n=0;n<A;n++)for(s=0;s<d;s++)if(a[n]===h[s]){o=a[n],r=`czm_mediump_${o}`;let f=new RegExp(`${o}\\b`,"g");e=e.replace(f,r),i[r]=o}}return{fragmentShaderText:e,duplicateUniformNames:i}}function stt(t,e){let i=e._vertexShaderText,n=e._fragmentShaderText,s=t.createShader(t.VERTEX_SHADER);t.shaderSource(s,i),t.compileShader(s);let o=t.createShader(t.FRAGMENT_SHADER);t.shaderSource(o,n),t.compileShader(o);let r=t.createProgram();t.attachShader(r,s),t.attachShader(r,o);let a=e._attributeLocations;if(m(a))for(let E in a)a.hasOwnProperty(E)&&t.bindAttribLocation(r,a[E],E);t.linkProgram(r);let h;if(t.getProgramParameter(r,t.LINK_STATUS))return e._logShaderCompilation&&(h=t.getShaderInfoLog(s),m(h)&&h.length>0&&console.log(`${RA}Vertex shader compile log: ${h}`),h=t.getShaderInfoLog(o),m(h)&&h.length>0&&console.log(`${RA}Fragment shader compile log: ${h}`),h=t.getProgramInfoLog(r),m(h)&&h.length>0&&console.log(`${RA}Shader program link log: ${h}`)),t.deleteShader(s),t.deleteShader(o),r;let A,d=e._debugShaders;throw t.getShaderParameter(o,t.COMPILE_STATUS)?t.getShaderParameter(s,t.COMPILE_STATUS)?(h=t.getProgramInfoLog(r),console.error(`${RA}Shader program link log: ${h}`),f(s,"vertex"),f(o,"fragment"),A=`Program failed to link.  Link log: ${h}`):(h=t.getShaderInfoLog(s),console.error(`${RA}Vertex shader compile log: ${h}`),console.error(`${RA} Vertex shader source:
${i}`),A=`Vertex shader failed to compile.  Compile log: ${h}`):(h=t.getShaderInfoLog(o),console.error(`${RA}Fragment shader compile log: ${h}`),console.error(`${RA} Fragment shader source:
${n}`),A=`Fragment shader failed to compile.  Compile log: ${h}`),t.deleteShader(s),t.deleteShader(o),t.deleteProgram(r),new ke(A);function f(E,_){if(!m(d))return;let R=d.getTranslatedShaderSource(E);if(R===""){console.error(`${RA}${_} shader translation failed.`);return}console.error(`${RA}Translated ${_} shaderSource:
${R}`)}}function ott(t,e,i){let n={};for(let s=0;s<i;++s){let o=t.getActiveAttrib(e,s),r=t.getAttribLocation(e,o.name);n[o.name]={name:o.name,type:o.type,index:r}}return n}function rtt(t,e){let i={},n=[],s=[],o=t.getProgramParameter(e,t.ACTIVE_UNIFORMS);for(let r=0;r<o;++r){let a=t.getActiveUniform(e,r),h="[0]",A=a.name.indexOf(h,a.name.length-h.length)!==-1?a.name.slice(0,a.name.length-3):a.name;if(A.indexOf("gl_")!==0)if(a.name.indexOf("[")<0){let d=t.getUniformLocation(e,A);if(d!==null){let f=$D(t,a,A,d);i[A]=f,n.push(f),f._setSampler&&s.push(f)}}else{let d,f,E,_,R=A.indexOf("[");if(R>=0){if(d=i[A.slice(0,R)],!m(d))continue;f=d._locations,f.length<=1&&(E=d.value,_=t.getUniformLocation(e,A),_!==null&&(f.push(_),E.push(t.getUniform(e,_))))}else{f=[];for(let I=0;I<a.size;++I)_=t.getUniformLocation(e,`${A}[${I}]`),_!==null&&f.push(_);d=dU(t,a,A,f),i[A]=d,n.push(d),d._setSampler&&s.push(d)}}}return{uniformsByName:i,uniforms:n,samplerUniforms:s}}function att(t,e){let i=[],n=[];for(let s in e)if(e.hasOwnProperty(s)){let o=e[s],r=s,a=t._duplicateUniformNames[r];m(a)&&(o.name=a,r=a);let h=Mm[r];m(h)?i.push({uniform:o,automaticUniform:h}):n.push(o)}return{automaticUniforms:i,manualUniforms:n}}function Att(t,e,i){t.useProgram(e);let n=0,s=i.length;for(let o=0;o<s;++o)n=i[o]._setSampler(n);return t.useProgram(null),n}function cI(t){m(t._program)||EU(t)}function EU(t){let e=t._program,i=t._gl,n=stt(i,t,t._debugShaders),s=i.getProgramParameter(n,i.ACTIVE_ATTRIBUTES),o=rtt(i,n),r=att(t,o.uniformsByName);t._program=n,t._numberOfVertexAttributes=s,t._vertexAttributes=ott(i,n,s),t._uniformsByName=o.uniformsByName,t._uniforms=o.uniforms,t._automaticUniforms=r.automaticUniforms,t._manualUniforms=r.manualUniforms,t.maximumTextureUnitIndex=Att(i,n,o.samplerUniforms),e&&t._gl.deleteProgram(e),typeof spector<"u"&&(t._program.__SPECTOR_rebuildProgram=function(a,h,A,d){let f=t._vertexShaderText,E=t._fragmentShaderText,_=/ ! = /g;t._vertexShaderText=a.replace(_," != "),t._fragmentShaderText=h.replace(_," != ");try{EU(t),A(t._program)}catch(R){t._vertexShaderText=f,t._fragmentShaderText=E;let C=/(?:Compile|Link) error: ([^]*)/.exec(R.message);d(C?C[1]:R.message)}})}var itt,RA,Es,Qm=S(()=>{ae();Ft();mt();Ws();Ot();Ps();bT();ga();tU();mU();itt=0;ah.fromCache=function(t){return t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context),t.context.shaderCache.getShaderProgram(t)};ah.replaceCache=function(t){return t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context),t.context.shaderCache.replaceShaderProgram(t)};Object.defineProperties(ah.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},vertexAttributes:{get:function(){return cI(this),this._vertexAttributes}},numberOfVertexAttributes:{get:function(){return cI(this),this._numberOfVertexAttributes}},allUniforms:{get:function(){return cI(this),this._uniformsByName}}});RA="[Cesium WebGL] ";ah.prototype._bind=function(){cI(this),this._gl.useProgram(this._program)};ah.prototype._setUniforms=function(t,e,i){let n,s;if(m(t)){let a=this._manualUniforms;for(n=a.length,s=0;s<n;++s){let h=a[s];h.value=t[h.name]()}}let o=this._automaticUniforms;for(n=o.length,s=0;s<n;++s){let a=o[s];a.uniform.value=a.automaticUniform.getValue(e)}let r=this._uniforms;for(n=r.length,s=0;s<n;++s)r[s].set();if(i){let a=this._gl,h=this._program;if(a.validateProgram(h),!a.getProgramParameter(h,a.VALIDATE_STATUS))throw new Y(`Program validation failed.  Program info log: ${a.getProgramInfoLog(h)}`)}};ah.prototype.isDestroyed=function(){return!1};ah.prototype.destroy=function(){this._cachedShader.cache.releaseShaderProgram(this)};ah.prototype.finalDestroy=function(){return this._gl.deleteProgram(this._program),li(this)};Es=ah});var _U,RU=S(()=>{_U=`/**
 * A built-in GLSL floating-point constant for converting radians to degrees.
 *
 * @alias czm_degreesPerRadian
 * @glslConstant
 *
 * @see CesiumMath.DEGREES_PER_RADIAN
 *
 * @example
 * // GLSL declaration
 * const float czm_degreesPerRadian = ...;
 *
 * // Example
 * float deg = czm_degreesPerRadian * rad;
 */
const float czm_degreesPerRadian = 57.29577951308232;
`});var ZU,IU=S(()=>{ZU=`/**
 * A built-in GLSL vec2 constant for defining the depth range.
 * This is a workaround to a bug where IE11 does not implement gl_DepthRange.
 *
 * @alias czm_depthRange
 * @glslConstant
 *
 * @example
 * // GLSL declaration
 * float depthRangeNear = czm_depthRange.near;
 * float depthRangeFar = czm_depthRange.far;
 *
 */
const czm_depthRangeStruct czm_depthRange = czm_depthRangeStruct(0.0, 1.0);
`});var pU,uU=S(()=>{pU=`/**
 * 0.1
 *
 * @name czm_epsilon1
 * @glslConstant
 */
const float czm_epsilon1 = 0.1;
`});var CU,gU=S(()=>{CU=`/**
 * 0.01
 *
 * @name czm_epsilon2
 * @glslConstant
 */
const float czm_epsilon2 = 0.01;
`});var TU,NU=S(()=>{TU=`/**
 * 0.001
 *
 * @name czm_epsilon3
 * @glslConstant
 */
const float czm_epsilon3 = 0.001;
`});var FU,bU=S(()=>{FU=`/**
 * 0.0001
 *
 * @name czm_epsilon4
 * @glslConstant
 */
const float czm_epsilon4 = 0.0001;
`});var YU,VU=S(()=>{YU=`/**
 * 0.00001
 *
 * @name czm_epsilon5
 * @glslConstant
 */
const float czm_epsilon5 = 0.00001;
`});var SU,OU=S(()=>{SU=`/**
 * 0.000001
 *
 * @name czm_epsilon6
 * @glslConstant
 */
const float czm_epsilon6 = 0.000001;
`});var BU,GU=S(()=>{BU=`/**
 * 0.0000001
 *
 * @name czm_epsilon7
 * @glslConstant
 */
const float czm_epsilon7 = 0.0000001;
`});var WU,DU=S(()=>{WU=`/**
 * DOC_TBA
 *
 * @name czm_infinity
 * @glslConstant
 */
const float czm_infinity = 5906376272000.0;  // Distance from the Sun to Pluto in meters.  TODO: What is best given lowp, mediump, and highp?
`});var UU,MU=S(()=>{UU=`/**
 * A built-in GLSL floating-point constant for <code>1/pi</code>.
 *
 * @alias czm_oneOverPi
 * @glslConstant
 *
 * @see CesiumMath.ONE_OVER_PI
 *
 * @example
 * // GLSL declaration
 * const float czm_oneOverPi = ...;
 *
 * // Example
 * float pi = 1.0 / czm_oneOverPi;
 */
const float czm_oneOverPi = 0.3183098861837907;
`});var QU,kU=S(()=>{QU=`/**
 * A built-in GLSL floating-point constant for <code>1/2pi</code>.
 *
 * @alias czm_oneOverTwoPi
 * @glslConstant
 *
 * @see CesiumMath.ONE_OVER_TWO_PI
 *
 * @example
 * // GLSL declaration
 * const float czm_oneOverTwoPi = ...;
 *
 * // Example
 * float pi = 2.0 * czm_oneOverTwoPi;
 */
const float czm_oneOverTwoPi = 0.15915494309189535;
`});var LU,yU=S(()=>{LU=`/**
 * The automatic GLSL constant for {@link Pass#CESIUM_3D_TILE}
 *
 * @name czm_passCesium3DTile
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passCesium3DTile = 4.0;
`});var wU,xU=S(()=>{wU=`/**
 * The automatic GLSL constant for {@link Pass#CESIUM_3D_TILE_CLASSIFICATION}
 *
 * @name czm_passCesium3DTileClassification
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passCesium3DTileClassification = 5.0;
`});var PU,JU=S(()=>{PU=`/**
 * The automatic GLSL constant for {@link Pass#CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW}
 *
 * @name czm_passCesium3DTileClassificationIgnoreShow
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passCesium3DTileClassificationIgnoreShow = 6.0;
`});var jU,HU=S(()=>{jU=`/**
 * The automatic GLSL constant for {@link Pass#CLASSIFICATION}
 *
 * @name czm_passClassification
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passClassification = 7.0;
`});var vU,zU=S(()=>{vU=`/**
 * The automatic GLSL constant for {@link Pass#COMPUTE}
 *
 * @name czm_passCompute
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passCompute = 1.0;
`});var KU,XU=S(()=>{KU=`/**
 * The automatic GLSL constant for {@link Pass#ENVIRONMENT}
 *
 * @name czm_passEnvironment
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passEnvironment = 0.0;
`});var qU,$U=S(()=>{qU=`/**
 * The automatic GLSL constant for {@link Pass#GLOBE}
 *
 * @name czm_passGlobe
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passGlobe = 2.0;
`});var tM,eM=S(()=>{tM=`/**
 * The automatic GLSL constant for {@link Pass#OPAQUE}
 *
 * @name czm_passOpaque
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passOpaque = 7.0;
`});var iM,nM=S(()=>{iM=`/**
 * The automatic GLSL constant for {@link Pass#OVERLAY}
 *
 * @name czm_passOverlay
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passOverlay = 10.0;
`});var sM,oM=S(()=>{sM=`/**
 * The automatic GLSL constant for {@link Pass#TERRAIN_CLASSIFICATION}
 *
 * @name czm_passTerrainClassification
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passTerrainClassification = 3.0;
`});var rM,aM=S(()=>{rM=`/**
 * The automatic GLSL constant for {@link Pass#TRANSLUCENT}
 *
 * @name czm_passTranslucent
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passTranslucent = 8.0;
`});var AM,hM=S(()=>{AM=`/**
 * The automatic GLSL constant for {@link Pass#VOXELS}
 *
 * @name czm_passVoxels
 * @glslConstant
 *
 * @see czm_pass
 */
const float czm_passVoxels = 9.0;
`});var cM,lM=S(()=>{cM=`/**
 * A built-in GLSL floating-point constant for <code>Math.PI</code>.
 *
 * @alias czm_pi
 * @glslConstant
 *
 * @see CesiumMath.PI
 *
 * @example
 * // GLSL declaration
 * const float czm_pi = ...;
 *
 * // Example
 * float twoPi = 2.0 * czm_pi;
 */
const float czm_pi = 3.141592653589793;
`});var dM,mM=S(()=>{dM=`/**
 * A built-in GLSL floating-point constant for <code>pi/4</code>.
 *
 * @alias czm_piOverFour
 * @glslConstant
 *
 * @see CesiumMath.PI_OVER_FOUR
 *
 * @example
 * // GLSL declaration
 * const float czm_piOverFour = ...;
 *
 * // Example
 * float pi = 4.0 * czm_piOverFour;
 */
const float czm_piOverFour = 0.7853981633974483;
`});var fM,EM=S(()=>{fM=`/**
 * A built-in GLSL floating-point constant for <code>pi/6</code>.
 *
 * @alias czm_piOverSix
 * @glslConstant
 *
 * @see CesiumMath.PI_OVER_SIX
 *
 * @example
 * // GLSL declaration
 * const float czm_piOverSix = ...;
 *
 * // Example
 * float pi = 6.0 * czm_piOverSix;
 */
const float czm_piOverSix = 0.5235987755982988;
`});var _M,RM=S(()=>{_M=`/**
 * A built-in GLSL floating-point constant for <code>pi/3</code>.
 *
 * @alias czm_piOverThree
 * @glslConstant
 *
 * @see CesiumMath.PI_OVER_THREE
 *
 * @example
 * // GLSL declaration
 * const float czm_piOverThree = ...;
 *
 * // Example
 * float pi = 3.0 * czm_piOverThree;
 */
const float czm_piOverThree = 1.0471975511965976;
`});var ZM,IM=S(()=>{ZM=`/**
 * A built-in GLSL floating-point constant for <code>pi/2</code>.
 *
 * @alias czm_piOverTwo
 * @glslConstant
 *
 * @see CesiumMath.PI_OVER_TWO
 *
 * @example
 * // GLSL declaration
 * const float czm_piOverTwo = ...;
 *
 * // Example
 * float pi = 2.0 * czm_piOverTwo;
 */
const float czm_piOverTwo = 1.5707963267948966;
`});var pM,uM=S(()=>{pM=`/**
 * A built-in GLSL floating-point constant for converting degrees to radians.
 *
 * @alias czm_radiansPerDegree
 * @glslConstant
 *
 * @see CesiumMath.RADIANS_PER_DEGREE
 *
 * @example
 * // GLSL declaration
 * const float czm_radiansPerDegree = ...;
 *
 * // Example
 * float rad = czm_radiansPerDegree * deg;
 */
const float czm_radiansPerDegree = 0.017453292519943295;
`});var CM,gM=S(()=>{CM=`/**
 * The constant identifier for the 2D {@link SceneMode}
 *
 * @name czm_sceneMode2D
 * @glslConstant
 * @see czm_sceneMode
 * @see czm_sceneModeColumbusView
 * @see czm_sceneMode3D
 * @see czm_sceneModeMorphing
 */
const float czm_sceneMode2D = 2.0;
`});var TM,NM=S(()=>{TM=`/**
 * The constant identifier for the 3D {@link SceneMode}
 *
 * @name czm_sceneMode3D
 * @glslConstant
 * @see czm_sceneMode
 * @see czm_sceneMode2D
 * @see czm_sceneModeColumbusView
 * @see czm_sceneModeMorphing
 */
const float czm_sceneMode3D = 3.0;
`});var FM,bM=S(()=>{FM=`/**
 * The constant identifier for the Columbus View {@link SceneMode}
 *
 * @name czm_sceneModeColumbusView
 * @glslConstant
 * @see czm_sceneMode
 * @see czm_sceneMode2D
 * @see czm_sceneMode3D
 * @see czm_sceneModeMorphing
 */
const float czm_sceneModeColumbusView = 1.0;
`});var YM,VM=S(()=>{YM=`/**
 * The constant identifier for the Morphing {@link SceneMode}
 *
 * @name czm_sceneModeMorphing
 * @glslConstant
 * @see czm_sceneMode
 * @see czm_sceneMode2D
 * @see czm_sceneModeColumbusView
 * @see czm_sceneMode3D
 */
const float czm_sceneModeMorphing = 0.0;
`});var SM,OM=S(()=>{SM=`/**
 * A built-in GLSL floating-point constant for one solar radius.
 *
 * @alias czm_solarRadius
 * @glslConstant
 *
 * @see CesiumMath.SOLAR_RADIUS
 *
 * @example
 * // GLSL declaration
 * const float czm_solarRadius = ...;
 */
const float czm_solarRadius = 695500000.0;
`});var BM,GM=S(()=>{BM=`/**
 * A built-in GLSL floating-point constant for <code>3pi/2</code>.
 *
 * @alias czm_threePiOver2
 * @glslConstant
 *
 * @see CesiumMath.THREE_PI_OVER_TWO
 *
 * @example
 * // GLSL declaration
 * const float czm_threePiOver2 = ...;
 *
 * // Example
 * float pi = (2.0 / 3.0) * czm_threePiOver2;
 */
const float czm_threePiOver2 = 4.71238898038469;
`});var WM,DM=S(()=>{WM=`/**
 * A built-in GLSL floating-point constant for <code>2pi</code>.
 *
 * @alias czm_twoPi
 * @glslConstant
 *
 * @see CesiumMath.TWO_PI
 *
 * @example
 * // GLSL declaration
 * const float czm_twoPi = ...;
 *
 * // Example
 * float pi = czm_twoPi / 2.0;
 */
const float czm_twoPi = 6.283185307179586;
`});var UM,MM=S(()=>{UM=`/**
 * The maximum latitude, in radians, both North and South, supported by a Web Mercator
 * (EPSG:3857) projection.  Technically, the Mercator projection is defined
 * for any latitude up to (but not including) 90 degrees, but it makes sense
 * to cut it off sooner because it grows exponentially with increasing latitude.
 * The logic behind this particular cutoff value, which is the one used by
 * Google Maps, Bing Maps, and Esri, is that it makes the projection
 * square.  That is, the rectangle is equal in the X and Y directions.
 *
 * The constant value is computed as follows:
 *   czm_pi * 0.5 - (2.0 * atan(exp(-czm_pi)))
 *
 * @name czm_webMercatorMaxLatitude
 * @glslConstant
 */
const float czm_webMercatorMaxLatitude = 1.4844222297453324;
`});var QM,kM=S(()=>{QM=`/**
 * @name czm_depthRangeStruct
 * @glslStruct
 */
struct czm_depthRangeStruct
{
    float near;
    float far;
};
`});var LM,yM=S(()=>{LM=`/**
 * Holds material information that can be used for lighting. Returned by all czm_getMaterial functions.
 *
 * @name czm_material
 * @glslStruct
 *
 * @property {vec3} diffuse Incoming light that scatters evenly in all directions.
 * @property {float} specular Intensity of incoming light reflecting in a single direction.
 * @property {float} shininess The sharpness of the specular reflection.  Higher values create a smaller, more focused specular highlight.
 * @property {vec3} normal Surface's normal in eye coordinates. It is used for effects such as normal mapping. The default is the surface's unmodified normal.
 * @property {vec3} emission Light emitted by the material equally in all directions. The default is vec3(0.0), which emits no light.
 * @property {float} alpha Alpha of this material. 0.0 is completely transparent; 1.0 is completely opaque.
 */
struct czm_material
{
    vec3 diffuse;
    float specular;
    float shininess;
    vec3 normal;
    vec3 emission;
    float alpha;
};
`});var wM,xM=S(()=>{wM=`/**
 * Used as input to every material's czm_getMaterial function.
 *
 * @name czm_materialInput
 * @glslStruct
 *
 * @property {float} s 1D texture coordinates.
 * @property {vec2} st 2D texture coordinates.
 * @property {vec3} str 3D texture coordinates.
 * @property {vec3} normalEC Unperturbed surface normal in eye coordinates.
 * @property {mat3} tangentToEyeMatrix Matrix for converting a tangent space normal to eye space.
 * @property {vec3} positionToEyeEC Vector from the fragment to the eye in eye coordinates.  The magnitude is the distance in meters from the fragment to the eye.
 * @property {float} height The height of the terrain in meters above or below the WGS84 ellipsoid.  Only available for globe materials.
 * @property {float} slope The slope of the terrain in radians.  0 is flat; pi/2 is vertical.  Only available for globe materials.
 * @property {float} aspect The aspect of the terrain in radians.  0 is East, pi/2 is North, pi is West, 3pi/2 is South.  Only available for globe materials.
 */
struct czm_materialInput
{
    float s;
    vec2 st;
    vec3 str;
    vec3 normalEC;
    mat3 tangentToEyeMatrix;
    vec3 positionToEyeEC;
    float height;
    float slope;
    float aspect;
};
`});var PM,JM=S(()=>{PM=`/**
 * Struct for representing a material for a {@link Model}. The model
 * rendering pipeline will pass this struct between material, custom shaders,
 * and lighting stages. This is not to be confused with {@link czm_material}
 * which is used by the older Fabric materials system, although they are similar.
 * <p>
 * All color values (diffuse, specular, emissive) are in linear color space.
 * </p>
 *
 * @name czm_modelMaterial
 * @glslStruct
 *
 * @property {vec3} diffuse Incoming light that scatters evenly in all directions.
 * @property {float} alpha Alpha of this material. 0.0 is completely transparent; 1.0 is completely opaque.
 * @property {vec3} specular Color of reflected light at normal incidence in PBR materials. This is sometimes referred to as f0 in the literature.
 * @property {float} roughness A number from 0.0 to 1.0 representing how rough the surface is. Values near 0.0 produce glossy surfaces, while values near 1.0 produce rough surfaces.
 * @property {vec3} normalEC Surface's normal in eye coordinates. It is used for effects such as normal mapping. The default is the surface's unmodified normal.
 * @property {float} occlusion Ambient occlusion recieved at this point on the material. 1.0 means fully lit, 0.0 means fully occluded.
 * @property {vec3} emissive Light emitted by the material equally in all directions. The default is vec3(0.0), which emits no light.
 */
struct czm_modelMaterial {
    vec3 diffuse;
    float alpha;
    vec3 specular;
    float roughness;
    vec3 normalEC;
    float occlusion;
    vec3 emissive;
};
`});var jM,HM=S(()=>{jM=`/**
 * Struct for representing the output of a custom vertex shader.
 * 
 * @name czm_modelVertexOutput
 * @glslStruct
 *
 * @see {@link CustomShader}
 * @see {@link Model}
 *
 * @property {vec3} positionMC The position of the vertex in model coordinates
 * @property {float} pointSize A custom value for gl_PointSize. This is only used for point primitives. 
 */
struct czm_modelVertexOutput {
  vec3 positionMC;
  float pointSize;
};
`});var vM,zM=S(()=>{vM=`/**
 * Parameters for {@link czm_pbrLighting}
 *
 * @name czm_material
 * @glslStruct
 *
 * @property {vec3} diffuseColor the diffuse color of the material for the lambert term of the rendering equation
 * @property {float} roughness a value from 0.0 to 1.0 that indicates how rough the surface of the material is.
 * @property {vec3} f0 The reflectance of the material at normal incidence
 */
struct czm_pbrParameters
{
    vec3 diffuseColor;
    float roughness;
    vec3 f0;
};
`});var KM,XM=S(()=>{KM=`/**
 * DOC_TBA
 *
 * @name czm_ray
 * @glslStruct
 */
struct czm_ray
{
    vec3 origin;
    vec3 direction;
};
`});var qM,$M=S(()=>{qM=`/**
 * DOC_TBA
 *
 * @name czm_raySegment
 * @glslStruct
 */
struct czm_raySegment
{
    float start;
    float stop;
};

/**
 * DOC_TBA
 *
 * @name czm_emptyRaySegment
 * @glslConstant 
 */
const czm_raySegment czm_emptyRaySegment = czm_raySegment(-czm_infinity, -czm_infinity);

/**
 * DOC_TBA
 *
 * @name czm_fullRaySegment
 * @glslConstant 
 */
const czm_raySegment czm_fullRaySegment = czm_raySegment(0.0, czm_infinity);
`});var tQ,eQ=S(()=>{tQ=`struct czm_shadowParameters
{
#ifdef USE_CUBE_MAP_SHADOW
    vec3 texCoords;
#else
    vec2 texCoords;
#endif

    float depthBias;
    float depth;
    float nDotL;
    vec2 texelStepSize;
    float normalShadingSmooth;
    float darkness;
};
`});var iQ,nQ=S(()=>{iQ=`/**
 * Converts an HSB color (hue, saturation, brightness) to RGB
 * HSB <-> RGB conversion with minimal branching: {@link http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl}
 *
 * @name czm_HSBToRGB
 * @glslFunction
 * 
 * @param {vec3} hsb The color in HSB.
 *
 * @returns {vec3} The color in RGB.
 *
 * @example
 * vec3 hsb = czm_RGBToHSB(rgb);
 * hsb.z *= 0.1;
 * rgb = czm_HSBToRGB(hsb);
 */

const vec4 K_HSB2RGB = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);

vec3 czm_HSBToRGB(vec3 hsb)
{
    vec3 p = abs(fract(hsb.xxx + K_HSB2RGB.xyz) * 6.0 - K_HSB2RGB.www);
    return hsb.z * mix(K_HSB2RGB.xxx, clamp(p - K_HSB2RGB.xxx, 0.0, 1.0), hsb.y);
}
`});var sQ,oQ=S(()=>{sQ=`/**
 * Converts an HSL color (hue, saturation, lightness) to RGB
 * HSL <-> RGB conversion: {@link http://www.chilliant.com/rgb2hsv.html}
 *
 * @name czm_HSLToRGB
 * @glslFunction
 * 
 * @param {vec3} rgb The color in HSL.
 *
 * @returns {vec3} The color in RGB.
 *
 * @example
 * vec3 hsl = czm_RGBToHSL(rgb);
 * hsl.z *= 0.1;
 * rgb = czm_HSLToRGB(hsl);
 */

vec3 hueToRGB(float hue)
{
    float r = abs(hue * 6.0 - 3.0) - 1.0;
    float g = 2.0 - abs(hue * 6.0 - 2.0);
    float b = 2.0 - abs(hue * 6.0 - 4.0);
    return clamp(vec3(r, g, b), 0.0, 1.0);
}

vec3 czm_HSLToRGB(vec3 hsl)
{
    vec3 rgb = hueToRGB(hsl.x);
    float c = (1.0 - abs(2.0 * hsl.z - 1.0)) * hsl.y;
    return (rgb - 0.5) * c + hsl.z;
}
`});var rQ,aQ=S(()=>{rQ=`/**
 * Converts an RGB color to HSB (hue, saturation, brightness)
 * HSB <-> RGB conversion with minimal branching: {@link http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl}
 *
 * @name czm_RGBToHSB
 * @glslFunction
 * 
 * @param {vec3} rgb The color in RGB.
 *
 * @returns {vec3} The color in HSB.
 *
 * @example
 * vec3 hsb = czm_RGBToHSB(rgb);
 * hsb.z *= 0.1;
 * rgb = czm_HSBToRGB(hsb);
 */

const vec4 K_RGB2HSB = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);

vec3 czm_RGBToHSB(vec3 rgb)
{
    vec4 p = mix(vec4(rgb.bg, K_RGB2HSB.wz), vec4(rgb.gb, K_RGB2HSB.xy), step(rgb.b, rgb.g));
    vec4 q = mix(vec4(p.xyw, rgb.r), vec4(rgb.r, p.yzx), step(p.x, rgb.r));

    float d = q.x - min(q.w, q.y);
    return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + czm_epsilon7)), d / (q.x + czm_epsilon7), q.x);
}
`});var AQ,hQ=S(()=>{AQ=`/**
 * Converts an RGB color to HSL (hue, saturation, lightness)
 * HSL <-> RGB conversion: {@link http://www.chilliant.com/rgb2hsv.html}
 *
 * @name czm_RGBToHSL
 * @glslFunction
 * 
 * @param {vec3} rgb The color in RGB.
 *
 * @returns {vec3} The color in HSL.
 *
 * @example
 * vec3 hsl = czm_RGBToHSL(rgb);
 * hsl.z *= 0.1;
 * rgb = czm_HSLToRGB(hsl);
 */
 
vec3 RGBtoHCV(vec3 rgb)
{
    // Based on work by Sam Hocevar and Emil Persson
    vec4 p = (rgb.g < rgb.b) ? vec4(rgb.bg, -1.0, 2.0 / 3.0) : vec4(rgb.gb, 0.0, -1.0 / 3.0);
    vec4 q = (rgb.r < p.x) ? vec4(p.xyw, rgb.r) : vec4(rgb.r, p.yzx);
    float c = q.x - min(q.w, q.y);
    float h = abs((q.w - q.y) / (6.0 * c + czm_epsilon7) + q.z);
    return vec3(h, c, q.x);
}

vec3 czm_RGBToHSL(vec3 rgb)
{
    vec3 hcv = RGBtoHCV(rgb);
    float l = hcv.z - hcv.y * 0.5;
    float s = hcv.y / (1.0 - abs(l * 2.0 - 1.0) + czm_epsilon7);
    return vec3(hcv.x, s, l);
}
`});var cQ,lQ=S(()=>{cQ=`/**
 * Converts an RGB color to CIE Yxy.
 * <p>The conversion is described in
 * {@link http://content.gpwiki.org/index.php/D3DBook:High-Dynamic_Range_Rendering#Luminance_Transform|Luminance Transform}
 * </p>
 * 
 * @name czm_RGBToXYZ
 * @glslFunction
 * 
 * @param {vec3} rgb The color in RGB.
 *
 * @returns {vec3} The color in CIE Yxy.
 *
 * @example
 * vec3 xyz = czm_RGBToXYZ(rgb);
 * xyz.x = max(xyz.x - luminanceThreshold, 0.0);
 * rgb = czm_XYZToRGB(xyz);
 */
vec3 czm_RGBToXYZ(vec3 rgb)
{
    const mat3 RGB2XYZ = mat3(0.4124, 0.2126, 0.0193,
                              0.3576, 0.7152, 0.1192,
                              0.1805, 0.0722, 0.9505);
    vec3 xyz = RGB2XYZ * rgb;
    vec3 Yxy;
    Yxy.r = xyz.g;
    float temp = dot(vec3(1.0), xyz);
    Yxy.gb = xyz.rg / temp;
    return Yxy;
}
`});var dQ,mQ=S(()=>{dQ=`/**
 * Converts a CIE Yxy color to RGB.
 * <p>The conversion is described in
 * {@link http://content.gpwiki.org/index.php/D3DBook:High-Dynamic_Range_Rendering#Luminance_Transform|Luminance Transform}
 * </p>
 * 
 * @name czm_XYZToRGB
 * @glslFunction
 * 
 * @param {vec3} Yxy The color in CIE Yxy.
 *
 * @returns {vec3} The color in RGB.
 *
 * @example
 * vec3 xyz = czm_RGBToXYZ(rgb);
 * xyz.x = max(xyz.x - luminanceThreshold, 0.0);
 * rgb = czm_XYZToRGB(xyz);
 */
vec3 czm_XYZToRGB(vec3 Yxy)
{
    const mat3 XYZ2RGB = mat3( 3.2405, -0.9693,  0.0556,
                              -1.5371,  1.8760, -0.2040,
                              -0.4985,  0.0416,  1.0572);
    vec3 xyz;
    xyz.r = Yxy.r * Yxy.g / Yxy.b;
    xyz.g = Yxy.r;
    xyz.b = Yxy.r * (1.0 - Yxy.g - Yxy.b) / Yxy.b;
    
    return XYZ2RGB * xyz;
}
`});var fQ,EQ=S(()=>{fQ=`// See:
//    https://knarkowicz.wordpress.com/2016/01/06/aces-filmic-tone-mapping-curve/

vec3 czm_acesTonemapping(vec3 color) {
    float g = 0.985;
    float a = 0.065;
    float b = 0.0001;
    float c = 0.433;
    float d = 0.238;

    color = (color * (color + a) - b) / (color * (g * color + c) + d);

    color = clamp(color, 0.0, 1.0);

    return color;
}
`});var _Q,RQ=S(()=>{_Q=`/**
 * @private
 */
float czm_alphaWeight(float a)
{
    float z = (gl_FragCoord.z - czm_viewportTransformation[3][2]) / czm_viewportTransformation[2][2];

    // See Weighted Blended Order-Independent Transparency for examples of different weighting functions:
    // http://jcgt.org/published/0002/02/09/
    return pow(a + 0.01, 4.0) + max(1e-2, min(3.0 * 1e3, 0.003 / (1e-5 + pow(abs(z) / 200.0, 4.0))));
}
`});var ZQ,IQ=S(()=>{ZQ=`/**
 * Procedural anti-aliasing by blurring two colors that meet at a sharp edge.
 *
 * @name czm_antialias
 * @glslFunction
 *
 * @param {vec4} color1 The color on one side of the edge.
 * @param {vec4} color2 The color on the other side of the edge.
 * @param {vec4} currentcolor The current color, either <code>color1</code> or <code>color2</code>.
 * @param {float} dist The distance to the edge in texture coordinates.
 * @param {float} [fuzzFactor=0.1] Controls the blurriness between the two colors.
 * @returns {vec4} The anti-aliased color.
 *
 * @example
 * // GLSL declarations
 * vec4 czm_antialias(vec4 color1, vec4 color2, vec4 currentColor, float dist, float fuzzFactor);
 * vec4 czm_antialias(vec4 color1, vec4 color2, vec4 currentColor, float dist);
 *
 * // get the color for a material that has a sharp edge at the line y = 0.5 in texture space
 * float dist = abs(textureCoordinates.t - 0.5);
 * vec4 currentColor = mix(bottomColor, topColor, step(0.5, textureCoordinates.t));
 * vec4 color = czm_antialias(bottomColor, topColor, currentColor, dist, 0.1);
 */
vec4 czm_antialias(vec4 color1, vec4 color2, vec4 currentColor, float dist, float fuzzFactor)
{
    float val1 = clamp(dist / fuzzFactor, 0.0, 1.0);
    float val2 = clamp((dist - 0.5) / fuzzFactor, 0.0, 1.0);
    val1 = val1 * (1.0 - val2);
    val1 = val1 * val1 * (3.0 - (2.0 * val1));
    val1 = pow(val1, 0.5); //makes the transition nicer
    
    vec4 midColor = (color1 + color2) * 0.5;
    return mix(midColor, currentColor, val1);
}

vec4 czm_antialias(vec4 color1, vec4 color2, vec4 currentColor, float dist)
{
    return czm_antialias(color1, color2, currentColor, dist, 0.1);
}
`});var pQ,uQ=S(()=>{pQ=`/**
 * Apply a HSB color shift to an RGB color.
 *
 * @param {vec3} rgb The color in RGB space.
 * @param {vec3} hsbShift The amount to shift each component. The xyz components correspond to hue, saturation, and brightness. Shifting the hue by +/- 1.0 corresponds to shifting the hue by a full cycle. Saturation and brightness are clamped between 0 and 1 after the adjustment
 * @param {bool} ignoreBlackPixels If true, black pixels will be unchanged. This is necessary in some shaders such as atmosphere-related effects.
 *
 * @return {vec3} The RGB color after shifting in HSB space and clamping saturation and brightness to a valid range.
 */
vec3 czm_applyHSBShift(vec3 rgb, vec3 hsbShift, bool ignoreBlackPixels) {
    // Convert rgb color to hsb
    vec3 hsb = czm_RGBToHSB(rgb);

    // Perform hsb shift
    // Hue cycles around so no clamp is needed.
    hsb.x += hsbShift.x; // hue
    hsb.y = clamp(hsb.y + hsbShift.y, 0.0, 1.0); // saturation

    // brightness
    //
    // Some shaders such as atmosphere-related effects need to leave black
    // pixels unchanged
    if (ignoreBlackPixels) {
        hsb.z = hsb.z > czm_epsilon7 ? hsb.z + hsbShift.z : 0.0;
    } else {
        hsb.z = hsb.z + hsbShift.z;
    }
    hsb.z = clamp(hsb.z, 0.0, 1.0);

    // Convert shifted hsb back to rgb
    return czm_HSBToRGB(hsb);
}
`});var CQ,gQ=S(()=>{CQ=`/**
 * Approximately computes spherical coordinates given a normal.
 * Uses approximate inverse trigonometry for speed and consistency,
 * since inverse trigonometry can differ from vendor-to-vendor and when compared with the CPU.
 *
 * @name czm_approximateSphericalCoordinates
 * @glslFunction
 *
 * @param {vec3} normal arbitrary-length normal.
 *
 * @returns {vec2} Approximate latitude and longitude spherical coordinates.
 */
vec2 czm_approximateSphericalCoordinates(vec3 normal) {
    // Project into plane with vertical for latitude
    float latitudeApproximation = czm_fastApproximateAtan(sqrt(normal.x * normal.x + normal.y * normal.y), normal.z);
    float longitudeApproximation = czm_fastApproximateAtan(normal.x, normal.y);
    return vec2(latitudeApproximation, longitudeApproximation);
}
`});var TQ,NQ=S(()=>{TQ=`/**
 * Compute a rational approximation to tanh(x)
 *
 * @param {float} x A real number input
 * @returns {float} An approximation for tanh(x)
*/
float czm_approximateTanh(float x) {
    float x2 = x * x;
    return max(-1.0, min(1.0, x * (27.0 + x2) / (27.0 + 9.0 * x2)));
}
`});var FQ,bQ=S(()=>{FQ=`/**
 * Determines if the fragment is back facing
 *
 * @name czm_backFacing
 * @glslFunction 
 * 
 * @returns {bool} <code>true</code> if the fragment is back facing; otherwise, <code>false</code>.
 */
bool czm_backFacing()
{
    // !gl_FrontFacing doesn't work as expected on Mac/Intel so use the more verbose form instead. See https://github.com/CesiumGS/cesium/pull/8494.
    return gl_FrontFacing == false;
}
`});var YQ,VQ=S(()=>{YQ=`/**
 * Branchless ternary operator to be used when it's inexpensive to explicitly
 * evaluate both possibilities for a float expression.
 *
 * @name czm_branchFreeTernary
 * @glslFunction
 *
 * @param {bool} comparison A comparison statement
 * @param {float} a Value to return if the comparison is true.
 * @param {float} b Value to return if the comparison is false.
 *
 * @returns {float} equivalent of comparison ? a : b
 */
float czm_branchFreeTernary(bool comparison, float a, float b) {
    float useA = float(comparison);
    return a * useA + b * (1.0 - useA);
}

/**
 * Branchless ternary operator to be used when it's inexpensive to explicitly
 * evaluate both possibilities for a vec2 expression.
 *
 * @name czm_branchFreeTernary
 * @glslFunction
 *
 * @param {bool} comparison A comparison statement
 * @param {vec2} a Value to return if the comparison is true.
 * @param {vec2} b Value to return if the comparison is false.
 *
 * @returns {vec2} equivalent of comparison ? a : b
 */
vec2 czm_branchFreeTernary(bool comparison, vec2 a, vec2 b) {
    float useA = float(comparison);
    return a * useA + b * (1.0 - useA);
}

/**
 * Branchless ternary operator to be used when it's inexpensive to explicitly
 * evaluate both possibilities for a vec3 expression.
 *
 * @name czm_branchFreeTernary
 * @glslFunction
 *
 * @param {bool} comparison A comparison statement
 * @param {vec3} a Value to return if the comparison is true.
 * @param {vec3} b Value to return if the comparison is false.
 *
 * @returns {vec3} equivalent of comparison ? a : b
 */
vec3 czm_branchFreeTernary(bool comparison, vec3 a, vec3 b) {
    float useA = float(comparison);
    return a * useA + b * (1.0 - useA);
}

/**
 * Branchless ternary operator to be used when it's inexpensive to explicitly
 * evaluate both possibilities for a vec4 expression.
 *
 * @name czm_branchFreeTernary
 * @glslFunction
 *
 * @param {bool} comparison A comparison statement
 * @param {vec3} a Value to return if the comparison is true.
 * @param {vec3} b Value to return if the comparison is false.
 *
 * @returns {vec3} equivalent of comparison ? a : b
 */
vec4 czm_branchFreeTernary(bool comparison, vec4 a, vec4 b) {
    float useA = float(comparison);
    return a * useA + b * (1.0 - useA);
}
`});var SQ,OQ=S(()=>{SQ=`
vec4 czm_cascadeColor(vec4 weights)
{
    return vec4(1.0, 0.0, 0.0, 1.0) * weights.x +
           vec4(0.0, 1.0, 0.0, 1.0) * weights.y +
           vec4(0.0, 0.0, 1.0, 1.0) * weights.z +
           vec4(1.0, 0.0, 1.0, 1.0) * weights.w;
}
`});var BQ,GQ=S(()=>{BQ=`
uniform vec4 shadowMap_cascadeDistances;

float czm_cascadeDistance(vec4 weights)
{
    return dot(shadowMap_cascadeDistances, weights);
}
`});var WQ,DQ=S(()=>{WQ=`
uniform mat4 shadowMap_cascadeMatrices[4];

mat4 czm_cascadeMatrix(vec4 weights)
{
    return shadowMap_cascadeMatrices[0] * weights.x +
           shadowMap_cascadeMatrices[1] * weights.y +
           shadowMap_cascadeMatrices[2] * weights.z +
           shadowMap_cascadeMatrices[3] * weights.w;
}
`});var UQ,MQ=S(()=>{UQ=`
uniform vec4 shadowMap_cascadeSplits[2];

vec4 czm_cascadeWeights(float depthEye)
{
    // One component is set to 1.0 and all others set to 0.0.
    vec4 near = step(shadowMap_cascadeSplits[0], vec4(depthEye));
    vec4 far = step(depthEye, shadowMap_cascadeSplits[1]);
    return near * far;
}
`});var QQ,kQ=S(()=>{QQ=`float getSignedDistance(vec2 uv, highp sampler2D clippingDistance) {
    float signedDistance = texture(clippingDistance, uv).r;
    return (signedDistance - 0.5) * 2.0;
}

void czm_clipPolygons(highp sampler2D clippingDistance, int extentsLength, vec2 clippingPosition, int regionIndex) {
    // Position is completely outside of polygons bounds
    vec2 rectUv = clippingPosition;
    if (regionIndex < 0 || rectUv.x <= 0.0 || rectUv.y <= 0.0 || rectUv.x >= 1.0 || rectUv.y >= 1.0) {
        #ifdef CLIPPING_INVERSE 
            discard;
        #endif
        return;
    }

    vec2 clippingDistanceTextureDimensions = vec2(textureSize(clippingDistance, 0));
    vec2 sampleOffset = max(1.0 / clippingDistanceTextureDimensions, vec2(0.005));
    float dimension = float(extentsLength);
    if (extentsLength > 2) {
       dimension = ceil(log2(float(extentsLength)));
    }

    vec2 textureOffset = vec2(mod(float(regionIndex), dimension), floor(float(regionIndex) / dimension)) / dimension;
    vec2 uv = textureOffset + rectUv / dimension;

    float signedDistance = getSignedDistance(uv, clippingDistance);

    #ifdef CLIPPING_INVERSE
    if (signedDistance > 0.0)  {
        discard;
    }
    #else
    if (signedDistance < 0.0)  {
        discard;
    }
    #endif
}
`});var LQ,yQ=S(()=>{LQ=`/**
 * DOC_TBA
 *
 * @name czm_columbusViewMorph
 * @glslFunction
 */
vec4 czm_columbusViewMorph(vec4 position2D, vec4 position3D, float time)
{
    // Just linear for now.
    vec3 p = mix(position2D.xyz, position3D.xyz, time);
    return vec4(p, 1.0);
}
`});var wQ,xQ=S(()=>{wQ=`/**
 * Compute the atmosphere color, applying Rayleigh and Mie scattering. This
 * builtin uses automatic uniforms so the atmophere settings are synced with the
 * state of the Scene, even in other contexts like Model.
 *
 * @name czm_computeAtmosphereColor
 * @glslFunction
 *
 * @param {vec3} positionWC Position of the fragment in world coords (low precision)
 * @param {vec3} lightDirection Light direction from the sun or other light source.
 * @param {vec3} rayleighColor The Rayleigh scattering color computed by a scattering function
 * @param {vec3} mieColor The Mie scattering color computed by a scattering function
 * @param {float} opacity The opacity computed by a scattering function.
 */
vec4 czm_computeAtmosphereColor(
    vec3 positionWC,
    vec3 lightDirection,
    vec3 rayleighColor,
    vec3 mieColor,
    float opacity
) {
    // Setup the primary ray: from the camera position to the vertex position.
    vec3 cameraToPositionWC = positionWC - czm_viewerPositionWC;
    vec3 cameraToPositionWCDirection = normalize(cameraToPositionWC);

    float cosAngle = dot(cameraToPositionWCDirection, lightDirection);
    float cosAngleSq = cosAngle * cosAngle;

    float G = czm_atmosphereMieAnisotropy;
    float GSq = G * G;

    // The Rayleigh phase function.
    float rayleighPhase = 3.0 / (50.2654824574) * (1.0 + cosAngleSq);
    // The Mie phase function.
    float miePhase = 3.0 / (25.1327412287) * ((1.0 - GSq) * (cosAngleSq + 1.0)) / (pow(1.0 + GSq - 2.0 * cosAngle * G, 1.5) * (2.0 + GSq));

    // The final color is generated by combining the effects of the Rayleigh and Mie scattering.
    vec3 rayleigh = rayleighPhase * rayleighColor;
    vec3 mie = miePhase * mieColor;

    vec3 color = (rayleigh + mie) * czm_atmosphereLightIntensity;

    return vec4(color, opacity);
}
`});var PQ,JQ=S(()=>{PQ=`/**
 * Compute atmosphere scattering for the ground atmosphere and fog. This method
 * uses automatic uniforms so it is always synced with the scene settings.
 *
 * @name czm_computeGroundAtmosphereScattering
 * @glslfunction
 *
 * @param {vec3} positionWC The position of the fragment in world coordinates.
 * @param {vec3} lightDirection The direction of the light to calculate the scattering from.
 * @param {vec3} rayleighColor The variable the Rayleigh scattering will be written to.
 * @param {vec3} mieColor The variable the Mie scattering will be written to.
 * @param {float} opacity The variable the transmittance will be written to.
 */
void czm_computeGroundAtmosphereScattering(vec3 positionWC, vec3 lightDirection, out vec3 rayleighColor, out vec3 mieColor, out float opacity) {
    vec3 cameraToPositionWC = positionWC - czm_viewerPositionWC;
    vec3 cameraToPositionWCDirection = normalize(cameraToPositionWC);
    czm_ray primaryRay = czm_ray(czm_viewerPositionWC, cameraToPositionWCDirection);

    float atmosphereInnerRadius = length(positionWC);

    czm_computeScattering(
        primaryRay,
        length(cameraToPositionWC),
        lightDirection,
        atmosphereInnerRadius,
        rayleighColor,
        mieColor,
        opacity
    );
}
`});var jQ,HQ=S(()=>{jQ=`/**
 * Returns a position in model coordinates relative to eye taking into
 * account the current scene mode: 3D, 2D, or Columbus view.
 * <p>
 * This uses standard position attributes, <code>position3DHigh</code>, 
 * <code>position3DLow</code>, <code>position2DHigh</code>, and <code>position2DLow</code>, 
 * and should be used when writing a vertex shader for an {@link Appearance}.
 * </p>
 *
 * @name czm_computePosition
 * @glslFunction
 *
 * @returns {vec4} The position relative to eye.
 *
 * @example
 * vec4 p = czm_computePosition();
 * v_positionEC = (czm_modelViewRelativeToEye * p).xyz;
 * gl_Position = czm_modelViewProjectionRelativeToEye * p;
 *
 * @see czm_translateRelativeToEye
 */
vec4 czm_computePosition();
`});var vQ,zQ=S(()=>{vQ=`/**
 * This function computes the colors contributed by Rayliegh and Mie scattering on a given ray, as well as
 * the transmittance value for the ray. This function uses automatic uniforms
 * so the atmosphere settings are always synced with the current scene.
 *
 * @name czm_computeScattering
 * @glslfunction
 *
 * @param {czm_ray} primaryRay The ray from the camera to the position.
 * @param {float} primaryRayLength The length of the primary ray.
 * @param {vec3} lightDirection The direction of the light to calculate the scattering from.
 * @param {vec3} rayleighColor The variable the Rayleigh scattering will be written to.
 * @param {vec3} mieColor The variable the Mie scattering will be written to.
 * @param {float} opacity The variable the transmittance will be written to.
 */
void czm_computeScattering(
    czm_ray primaryRay,
    float primaryRayLength,
    vec3 lightDirection,
    float atmosphereInnerRadius,
    out vec3 rayleighColor,
    out vec3 mieColor,
    out float opacity
) {
    const float ATMOSPHERE_THICKNESS = 111e3; // The thickness of the atmosphere in meters.
    const int PRIMARY_STEPS_MAX = 16; // Maximum number of times the ray from the camera to the world position (primary ray) is sampled.
    const int LIGHT_STEPS_MAX = 4; // Maximum number of times the light is sampled from the light source's intersection with the atmosphere to a sample position on the primary ray.

    // Initialize the default scattering amounts to 0.
    rayleighColor = vec3(0.0);
    mieColor = vec3(0.0);
    opacity = 0.0;

    float atmosphereOuterRadius = atmosphereInnerRadius + ATMOSPHERE_THICKNESS;

    vec3 origin = vec3(0.0);

    // Calculate intersection from the camera to the outer ring of the atmosphere.
    czm_raySegment primaryRayAtmosphereIntersect = czm_raySphereIntersectionInterval(primaryRay, origin, atmosphereOuterRadius);

    // Return empty colors if no intersection with the atmosphere geometry.
    if (primaryRayAtmosphereIntersect == czm_emptyRaySegment) {
        rayleighColor = vec3(1.0, 0.0, 1.0);
        return;
    }

    // To deal with smaller values of PRIMARY_STEPS (e.g. 4)
    // we implement a split strategy: sky or horizon.
    // For performance reasons, instead of a if/else branch
    // a soft choice is implemented through a weight 0.0 <= w_stop_gt_lprl <= 1.0
    float x = 1e-7 * primaryRayAtmosphereIntersect.stop / length(primaryRayLength);
    // Value close to 0.0: close to the horizon
    // Value close to 1.0: above in the sky
    float w_stop_gt_lprl = 0.5 * (1.0 + czm_approximateTanh(x));

    // The ray should start from the first intersection with the outer atmopshere, or from the camera position, if it is inside the atmosphere.
    float start_0 = primaryRayAtmosphereIntersect.start;
    primaryRayAtmosphereIntersect.start = max(primaryRayAtmosphereIntersect.start, 0.0);
    // The ray should end at the exit from the atmosphere or at the distance to the vertex, whichever is smaller.
    primaryRayAtmosphereIntersect.stop = min(primaryRayAtmosphereIntersect.stop, length(primaryRayLength));

    // For the number of ray steps, distinguish inside or outside atmosphere (outer space)
    // (1) from outer space we have to use more ray steps to get a realistic rendering
    // (2) within atmosphere we need fewer steps for faster rendering
    float x_o_a = start_0 - ATMOSPHERE_THICKNESS; // ATMOSPHERE_THICKNESS used as an ad-hoc constant, no precise meaning here, only the order of magnitude matters
    float w_inside_atmosphere = 1.0 - 0.5 * (1.0 + czm_approximateTanh(x_o_a));
    int PRIMARY_STEPS = PRIMARY_STEPS_MAX - int(w_inside_atmosphere * 12.0); // Number of times the ray from the camera to the world position (primary ray) is sampled.
    int LIGHT_STEPS = LIGHT_STEPS_MAX - int(w_inside_atmosphere * 2.0); // Number of times the light is sampled from the light source's intersection with the atmosphere to a sample position on the primary ray.

    // Setup for sampling positions along the ray - starting from the intersection with the outer ring of the atmosphere.
    float rayPositionLength = primaryRayAtmosphereIntersect.start;
    // (1) Outside the atmosphere: constant rayStepLength
    // (2) Inside atmosphere: variable rayStepLength to compensate the rough rendering of the smaller number of ray steps
    float totalRayLength = primaryRayAtmosphereIntersect.stop - rayPositionLength;
    float rayStepLengthIncrease = w_inside_atmosphere * ((1.0 - w_stop_gt_lprl) * totalRayLength / (float(PRIMARY_STEPS * (PRIMARY_STEPS + 1)) / 2.0));
    float rayStepLength = max(1.0 - w_inside_atmosphere, w_stop_gt_lprl) * totalRayLength / max(7.0 * w_inside_atmosphere, float(PRIMARY_STEPS));

    vec3 rayleighAccumulation = vec3(0.0);
    vec3 mieAccumulation = vec3(0.0);
    vec2 opticalDepth = vec2(0.0);
    vec2 heightScale = vec2(czm_atmosphereRayleighScaleHeight, czm_atmosphereMieScaleHeight);

    // Sample positions on the primary ray.
    for (int i = 0; i < PRIMARY_STEPS_MAX; ++i) {

        // The loop should be: for (int i = 0; i < PRIMARY_STEPS; ++i) {...} but WebGL1 cannot
        // loop with non-constant condition, so it has to break early instead
        if (i >= PRIMARY_STEPS) {
            break;
        }

        // Calculate sample position along viewpoint ray.
        vec3 samplePosition = primaryRay.origin + primaryRay.direction * (rayPositionLength + rayStepLength);

        // Calculate height of sample position above ellipsoid.
        float sampleHeight = length(samplePosition) - atmosphereInnerRadius;

        // Calculate and accumulate density of particles at the sample position.
        vec2 sampleDensity = exp(-sampleHeight / heightScale) * rayStepLength;
        opticalDepth += sampleDensity;

        // Generate ray from the sample position segment to the light source, up to the outer ring of the atmosphere.
        czm_ray lightRay = czm_ray(samplePosition, lightDirection);
        czm_raySegment lightRayAtmosphereIntersect = czm_raySphereIntersectionInterval(lightRay, origin, atmosphereOuterRadius);

        float lightStepLength = lightRayAtmosphereIntersect.stop / float(LIGHT_STEPS);
        float lightPositionLength = 0.0;

        vec2 lightOpticalDepth = vec2(0.0);

        // Sample positions along the light ray, to accumulate incidence of light on the latest sample segment.
        for (int j = 0; j < LIGHT_STEPS_MAX; ++j) {

            // The loop should be: for (int j = 0; i < LIGHT_STEPS; ++j) {...} but WebGL1 cannot
            // loop with non-constant condition, so it has to break early instead
            if (j >= LIGHT_STEPS) {
                break;
            }

            // Calculate sample position along light ray.
            vec3 lightPosition = samplePosition + lightDirection * (lightPositionLength + lightStepLength * 0.5);

            // Calculate height of the light sample position above ellipsoid.
            float lightHeight = length(lightPosition) - atmosphereInnerRadius;

            // Calculate density of photons at the light sample position.
            lightOpticalDepth += exp(-lightHeight / heightScale) * lightStepLength;

            // Increment distance on light ray.
            lightPositionLength += lightStepLength;
        }

        // Compute attenuation via the primary ray and the light ray.
        vec3 attenuation = exp(-((czm_atmosphereMieCoefficient * (opticalDepth.y + lightOpticalDepth.y)) + (czm_atmosphereRayleighCoefficient * (opticalDepth.x + lightOpticalDepth.x))));

        // Accumulate the scattering.
        rayleighAccumulation += sampleDensity.x * attenuation;
        mieAccumulation += sampleDensity.y * attenuation;

        // Increment distance on primary ray.
        rayPositionLength += (rayStepLength += rayStepLengthIncrease);
    }

    // Compute the scattering amount.
    rayleighColor = czm_atmosphereRayleighCoefficient * rayleighAccumulation;
    mieColor = czm_atmosphereMieCoefficient * mieAccumulation;

    // Compute the transmittance i.e. how much light is passing through the atmosphere.
    opacity = length(exp(-((czm_atmosphereMieCoefficient * opticalDepth.y) + (czm_atmosphereRayleighCoefficient * opticalDepth.x))));
}
`});var KQ,XQ=S(()=>{KQ=`/**
 * @private
 */
vec2 cordic(float angle)
{
// Scale the vector by the appropriate factor for the 24 iterations to follow.
    vec2 vector = vec2(6.0725293500888267e-1, 0.0);
// Iteration 1
    float sense = (angle < 0.0) ? -1.0 : 1.0;
 //   float factor = sense * 1.0;  // 2^-0
    mat2 rotation = mat2(1.0, sense, -sense, 1.0);
    vector = rotation * vector;
    angle -= sense * 7.8539816339744828e-1;  // atan(2^-0)
// Iteration 2
    sense = (angle < 0.0) ? -1.0 : 1.0;
    float factor = sense * 5.0e-1;  // 2^-1
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 4.6364760900080609e-1;  // atan(2^-1)
// Iteration 3
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 2.5e-1;  // 2^-2
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 2.4497866312686414e-1;  // atan(2^-2)
// Iteration 4
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.25e-1;  // 2^-3
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.2435499454676144e-1;  // atan(2^-3)
// Iteration 5
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 6.25e-2;  // 2^-4
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 6.2418809995957350e-2;  // atan(2^-4)
// Iteration 6
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 3.125e-2;  // 2^-5
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 3.1239833430268277e-2;  // atan(2^-5)
// Iteration 7
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.5625e-2;  // 2^-6
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.5623728620476831e-2;  // atan(2^-6)
// Iteration 8
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 7.8125e-3;  // 2^-7
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 7.8123410601011111e-3;  // atan(2^-7)
// Iteration 9
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 3.90625e-3;  // 2^-8
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 3.9062301319669718e-3;  // atan(2^-8)
// Iteration 10
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.953125e-3;  // 2^-9
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.9531225164788188e-3;  // atan(2^-9)
// Iteration 11
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 9.765625e-4;  // 2^-10
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 9.7656218955931946e-4;  // atan(2^-10)
// Iteration 12
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 4.8828125e-4;  // 2^-11
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 4.8828121119489829e-4;  // atan(2^-11)
// Iteration 13
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 2.44140625e-4;  // 2^-12
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 2.4414062014936177e-4;  // atan(2^-12)
// Iteration 14
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.220703125e-4;  // 2^-13
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.2207031189367021e-4;  // atan(2^-13)
// Iteration 15
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 6.103515625e-5;  // 2^-14
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 6.1035156174208773e-5;  // atan(2^-14)
// Iteration 16
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 3.0517578125e-5;  // 2^-15
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 3.0517578115526096e-5;  // atan(2^-15)
// Iteration 17
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.52587890625e-5;  // 2^-16
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.5258789061315762e-5;  // atan(2^-16)
// Iteration 18
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 7.62939453125e-6;  // 2^-17
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 7.6293945311019700e-6;  // atan(2^-17)
// Iteration 19
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 3.814697265625e-6;  // 2^-18
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 3.8146972656064961e-6;  // atan(2^-18)
// Iteration 20
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.9073486328125e-6;  // 2^-19
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 1.9073486328101870e-6;  // atan(2^-19)
// Iteration 21
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 9.5367431640625e-7;  // 2^-20
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 9.5367431640596084e-7;  // atan(2^-20)
// Iteration 22
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 4.76837158203125e-7;  // 2^-21
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 4.7683715820308884e-7;  // atan(2^-21)
// Iteration 23
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 2.384185791015625e-7;  // 2^-22
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
    angle -= sense * 2.3841857910155797e-7;  // atan(2^-22)
// Iteration 24
    sense = (angle < 0.0) ? -1.0 : 1.0;
    factor = sense * 1.1920928955078125e-7;  // 2^-23
    rotation[0][1] = factor;
    rotation[1][0] = -factor;
    vector = rotation * vector;
//    angle -= sense * 1.1920928955078068e-7;  // atan(2^-23)

    return vector;
}

/**
 * Computes the cosine and sine of the provided angle using the CORDIC algorithm.
 *
 * @name czm_cosineAndSine
 * @glslFunction
 *
 * @param {float} angle The angle in radians.
 *
 * @returns {vec2} The resulting cosine of the angle (as the x coordinate) and sine of the angle (as the y coordinate).
 *
 * @example
 * vec2 v = czm_cosineAndSine(czm_piOverSix);
 * float cosine = v.x;
 * float sine = v.y;
 */
vec2 czm_cosineAndSine(float angle)
{
    if (angle < -czm_piOverTwo || angle > czm_piOverTwo)
    {
        if (angle < 0.0)
        {
            return -cordic(angle + czm_pi);
        }
        else
        {
            return -cordic(angle - czm_pi);
        }
    }
    else
    {
        return cordic(angle);
    }
}
`});var qQ,$Q=S(()=>{qQ=`/**
 * Decompresses texture coordinates that were packed into a single float.
 *
 * @name czm_decompressTextureCoordinates
 * @glslFunction
 *
 * @param {float} encoded The compressed texture coordinates.
 * @returns {vec2} The decompressed texture coordinates.
 */
 vec2 czm_decompressTextureCoordinates(float encoded)
 {
    float temp = encoded / 4096.0;
    float xZeroTo4095 = floor(temp);
    float stx = xZeroTo4095 / 4095.0;
    float sty = (encoded - xZeroTo4095 * 4096.0) / 4095.0;
    return vec2(stx, sty);
 }
`});var t1,e1=S(()=>{t1=`/**
 * Get default parameters for physically based rendering. These defaults
 * describe a rough dielectric (non-metal) surface (e.g. rough plastic).
 *
 * @return {czm_pbrParameters} Default parameters for {@link czm_pbrLighting}
 */
czm_pbrParameters czm_defaultPbrMaterial()
{
    czm_pbrParameters results;
    results.diffuseColor = vec3(1.0);
    results.roughness = 1.0;

    const vec3 REFLECTANCE_DIELECTRIC = vec3(0.04);
    results.f0 = REFLECTANCE_DIELECTRIC;
    return results;
}
`});var i1,n1=S(()=>{i1=`// emulated noperspective
#if (__VERSION__ == 300 || defined(GL_EXT_frag_depth)) && !defined(LOG_DEPTH)
out float v_WindowZ;
#endif

/**
 * Emulates GL_DEPTH_CLAMP, which is not available in WebGL 1 or 2.
 * GL_DEPTH_CLAMP clamps geometry that is outside the near and far planes, 
 * capping the shadow volume. More information here: 
 * https://www.khronos.org/registry/OpenGL/extensions/ARB/ARB_depth_clamp.txt.
 *
 * When GL_EXT_frag_depth is available we emulate GL_DEPTH_CLAMP by ensuring 
 * no geometry gets clipped by setting the clip space z value to 0.0 and then
 * sending the unaltered screen space z value (using emulated noperspective
 * interpolation) to the frag shader where it is clamped to [0,1] and then
 * written with gl_FragDepth (see czm_writeDepthClamp). This technique is based on:
 * https://stackoverflow.com/questions/5960757/how-to-emulate-gl-depth-clamp-nv.
 *
 * When GL_EXT_frag_depth is not available, which is the case on some mobile 
 * devices, we must attempt to fix this only in the vertex shader. 
 * The approach is to clamp the z value to the far plane, which closes the 
 * shadow volume but also distorts the geometry, so there can still be artifacts
 * on frustum seams.
 *
 * @name czm_depthClamp
 * @glslFunction
 *
 * @param {vec4} coords The vertex in clip coordinates.
 * @returns {vec4} The modified vertex.
 *
 * @example
 * gl_Position = czm_depthClamp(czm_modelViewProjection * vec4(position, 1.0));
 *
 * @see czm_writeDepthClamp
 */
vec4 czm_depthClamp(vec4 coords)
{
#ifndef LOG_DEPTH
#if __VERSION__ == 300 || defined(GL_EXT_frag_depth)
    v_WindowZ = (0.5 * (coords.z / coords.w) + 0.5) * coords.w;
    coords.z = 0.0;
#else
    coords.z = min(coords.z, coords.w);
#endif
#endif
    return coords;
}
`});var s1,o1=S(()=>{s1=`/**
 * Computes a 3x3 rotation matrix that transforms vectors from an ellipsoid's east-north-up coordinate system 
 * to eye coordinates.  In east-north-up coordinates, x points east, y points north, and z points along the 
 * surface normal.  East-north-up can be used as an ellipsoid's tangent space for operations such as bump mapping.
 * <br /><br />
 * The ellipsoid is assumed to be centered at the model coordinate's origin.
 *
 * @name czm_eastNorthUpToEyeCoordinates
 * @glslFunction
 *
 * @param {vec3} positionMC The position on the ellipsoid in model coordinates.
 * @param {vec3} normalEC The normalized ellipsoid surface normal, at <code>positionMC</code>, in eye coordinates.
 *
 * @returns {mat3} A 3x3 rotation matrix that transforms vectors from the east-north-up coordinate system to eye coordinates.
 *
 * @example
 * // Transform a vector defined in the east-north-up coordinate 
 * // system, (0, 0, 1) which is the surface normal, to eye 
 * // coordinates.
 * mat3 m = czm_eastNorthUpToEyeCoordinates(positionMC, normalEC);
 * vec3 normalEC = m * vec3(0.0, 0.0, 1.0);
 */
mat3 czm_eastNorthUpToEyeCoordinates(vec3 positionMC, vec3 normalEC)
{
    vec3 tangentMC = normalize(vec3(-positionMC.y, positionMC.x, 0.0));  // normalized surface tangent in model coordinates
    vec3 tangentEC = normalize(czm_normal3D * tangentMC);                // normalized surface tangent in eye coordinates
    vec3 bitangentEC = normalize(cross(normalEC, tangentEC));            // normalized surface bitangent in eye coordinates

    return mat3(
        tangentEC.x,   tangentEC.y,   tangentEC.z,
        bitangentEC.x, bitangentEC.y, bitangentEC.z,
        normalEC.x,    normalEC.y,    normalEC.z);
}
`});var r1,a1=S(()=>{r1=`/**
 * DOC_TBA
 *
 * @name czm_ellipsoidContainsPoint
 * @glslFunction
 *
 */
bool czm_ellipsoidContainsPoint(vec3 ellipsoid_inverseRadii, vec3 point)
{
    vec3 scaled = ellipsoid_inverseRadii * (czm_inverseModelView * vec4(point, 1.0)).xyz;
    return (dot(scaled, scaled) <= 1.0);
}
`});var A1,h1=S(()=>{A1=`/**
 * DOC_TBA
 *
 * @name czm_ellipsoidWgs84TextureCoordinates
 * @glslFunction
 */
vec2 czm_ellipsoidWgs84TextureCoordinates(vec3 normal)
{
    return vec2(atan(normal.y, normal.x) * czm_oneOverTwoPi + 0.5, asin(normal.z) * czm_oneOverPi + 0.5);
}
`});var c1,l1=S(()=>{c1=`/**
 * Compares <code>left</code> and <code>right</code> componentwise. Returns <code>true</code>
 * if they are within <code>epsilon</code> and <code>false</code> otherwise. The inputs
 * <code>left</code> and <code>right</code> can be <code>float</code>s, <code>vec2</code>s,
 * <code>vec3</code>s, or <code>vec4</code>s.
 *
 * @name czm_equalsEpsilon
 * @glslFunction
 *
 * @param {} left The first vector.
 * @param {} right The second vector.
 * @param {float} epsilon The epsilon to use for equality testing.
 * @returns {bool} <code>true</code> if the components are within <code>epsilon</code> and <code>false</code> otherwise.
 *
 * @example
 * // GLSL declarations
 * bool czm_equalsEpsilon(float left, float right, float epsilon);
 * bool czm_equalsEpsilon(vec2 left, vec2 right, float epsilon);
 * bool czm_equalsEpsilon(vec3 left, vec3 right, float epsilon);
 * bool czm_equalsEpsilon(vec4 left, vec4 right, float epsilon);
 */
bool czm_equalsEpsilon(vec4 left, vec4 right, float epsilon) {
    return all(lessThanEqual(abs(left - right), vec4(epsilon)));
}

bool czm_equalsEpsilon(vec3 left, vec3 right, float epsilon) {
    return all(lessThanEqual(abs(left - right), vec3(epsilon)));
}

bool czm_equalsEpsilon(vec2 left, vec2 right, float epsilon) {
    return all(lessThanEqual(abs(left - right), vec2(epsilon)));
}

bool czm_equalsEpsilon(float left, float right, float epsilon) {
    return (abs(left - right) <= epsilon);
}
`});var d1,m1=S(()=>{d1=`/**
 * DOC_TBA
 *
 * @name czm_eyeOffset
 * @glslFunction
 *
 * @param {vec4} positionEC DOC_TBA.
 * @param {vec3} eyeOffset DOC_TBA.
 *
 * @returns {vec4} DOC_TBA.
 */
vec4 czm_eyeOffset(vec4 positionEC, vec3 eyeOffset)
{
    // This equation is approximate in x and y.
    vec4 p = positionEC;
    vec4 zEyeOffset = normalize(p) * eyeOffset.z;
    p.xy += eyeOffset.xy + zEyeOffset.xy;
    p.z += zEyeOffset.z;
    return p;
}
`});var f1,E1=S(()=>{f1=`/**
 * Transforms a position from eye to window coordinates.  The transformation
 * from eye to clip coordinates is done using {@link czm_projection}.
 * The transform from normalized device coordinates to window coordinates is
 * done using {@link czm_viewportTransformation}, which assumes a depth range
 * of <code>near = 0</code> and <code>far = 1</code>.
 * <br /><br />
 * This transform is useful when there is a need to manipulate window coordinates
 * in a vertex shader as done by {@link BillboardCollection}.
 *
 * @name czm_eyeToWindowCoordinates
 * @glslFunction
 *
 * @param {vec4} position The position in eye coordinates to transform.
 *
 * @returns {vec4} The transformed position in window coordinates.
 *
 * @see czm_modelToWindowCoordinates
 * @see czm_projection
 * @see czm_viewportTransformation
 * @see BillboardCollection
 *
 * @example
 * vec4 positionWC = czm_eyeToWindowCoordinates(positionEC);
 */
vec4 czm_eyeToWindowCoordinates(vec4 positionEC)
{
    vec4 q = czm_projection * positionEC;                        // clip coordinates
    q.xyz /= q.w;                                                // normalized device coordinates
    q.xyz = (czm_viewportTransformation * vec4(q.xyz, 1.0)).xyz; // window coordinates
    return q;
}
`});var _1,R1=S(()=>{_1=`/**
 * Approxiamtes atan over the range [0, 1]. Safe to flip output for negative input.
 *
 * Based on Michal Drobot's approximation from ShaderFastLibs, which in turn is based on
 * "Efficient approximations for the arctangent function," Rajan, S. Sichun Wang Inkol, R. Joyal, A., May 2006.
 * Adapted from ShaderFastLibs under MIT License.
 *
 * Chosen for the following characteristics over range [0, 1]:
 * - basically no error at 0 and 1, important for getting around range limit (naive atan2 via atan requires infinite range atan)
 * - no visible artifacts from first-derivative discontinuities, unlike latitude via range-reduced sqrt asin approximations (at equator)
 *
 * The original code is x * (-0.1784 * abs(x) - 0.0663 * x * x + 1.0301);
 * Removed the abs() in here because it isn't needed, the input range is guaranteed as [0, 1] by how we're approximating atan2.
 *
 * @name czm_fastApproximateAtan
 * @glslFunction
 *
 * @param {float} x Value between 0 and 1 inclusive.
 *
 * @returns {float} Approximation of atan(x)
 */
float czm_fastApproximateAtan(float x) {
    return x * (-0.1784 * x - 0.0663 * x * x + 1.0301);
}

/**
 * Approximation of atan2.
 *
 * Range reduction math based on nvidia's cg reference implementation for atan2: http://developer.download.nvidia.com/cg/atan2.html
 * However, we replaced their atan curve with Michael Drobot's (see above).
 *
 * @name czm_fastApproximateAtan
 * @glslFunction
 *
 * @param {float} x Value between -1 and 1 inclusive.
 * @param {float} y Value between -1 and 1 inclusive.
 *
 * @returns {float} Approximation of atan2(x, y)
 */
float czm_fastApproximateAtan(float x, float y) {
    // atan approximations are usually only reliable over [-1, 1], or, in our case, [0, 1] due to modifications.
    // So range-reduce using abs and by flipping whether x or y is on top.
    float t = abs(x); // t used as swap and atan result.
    float opposite = abs(y);
    float adjacent = max(t, opposite);
    opposite = min(t, opposite);

    t = czm_fastApproximateAtan(opposite / adjacent);

    // Undo range reduction
    t = czm_branchFreeTernary(abs(y) > abs(x), czm_piOverTwo - t, t);
    t = czm_branchFreeTernary(x < 0.0, czm_pi - t, t);
    t = czm_branchFreeTernary(y < 0.0, -t, t);
    return t;
}
`});var Z1,I1=S(()=>{Z1=`/**
 * Gets the color with fog at a distance from the camera.
 *
 * @name czm_fog
 * @glslFunction
 *
 * @param {float} distanceToCamera The distance to the camera in meters.
 * @param {vec3} color The original color.
 * @param {vec3} fogColor The color of the fog.
 *
 * @returns {vec3} The color adjusted for fog at the distance from the camera.
 */
vec3 czm_fog(float distanceToCamera, vec3 color, vec3 fogColor)
{
    float scalar = distanceToCamera * czm_fogDensity;
    float fog = 1.0 - exp(-(scalar * scalar));
    return mix(color, fogColor, fog);
}

/**
 * Gets the color with fog at a distance from the camera.
 *
 * @name czm_fog
 * @glslFunction
 *
 * @param {float} distanceToCamera The distance to the camera in meters.
 * @param {vec3} color The original color.
 * @param {vec3} fogColor The color of the fog.
 * @param {float} fogModifierConstant A constant to modify the appearance of fog.
 *
 * @returns {vec3} The color adjusted for fog at the distance from the camera.
 */
vec3 czm_fog(float distanceToCamera, vec3 color, vec3 fogColor, float fogModifierConstant)
{
    float scalar = distanceToCamera * czm_fogDensity;
    float fog = 1.0 - exp(-((fogModifierConstant * scalar + fogModifierConstant) * (scalar * (1.0 + fogModifierConstant))));
    return mix(color, fogColor, fog);
}
`});var p1,u1=S(()=>{p1=`/**
 * Converts a color from RGB space to linear space.
 *
 * @name czm_gammaCorrect
 * @glslFunction
 *
 * @param {vec3} color The color in RGB space.
 * @returns {vec3} The color in linear space.
 */
vec3 czm_gammaCorrect(vec3 color) {
#ifdef HDR
    color = pow(color, vec3(czm_gamma));
#endif
    return color;
}

vec4 czm_gammaCorrect(vec4 color) {
#ifdef HDR
    color.rgb = pow(color.rgb, vec3(czm_gamma));
#endif
    return color;
}
`});var C1,g1=S(()=>{C1=`/**
 * DOC_TBA
 *
 * @name czm_geodeticSurfaceNormal
 * @glslFunction
 *
 * @param {vec3} positionOnEllipsoid DOC_TBA
 * @param {vec3} ellipsoidCenter DOC_TBA
 * @param {vec3} oneOverEllipsoidRadiiSquared DOC_TBA
 * 
 * @returns {vec3} DOC_TBA.
 */
vec3 czm_geodeticSurfaceNormal(vec3 positionOnEllipsoid, vec3 ellipsoidCenter, vec3 oneOverEllipsoidRadiiSquared)
{
    return normalize((positionOnEllipsoid - ellipsoidCenter) * oneOverEllipsoidRadiiSquared);
}
`});var T1,N1=S(()=>{T1=`/**
 * An czm_material with default values. Every material's czm_getMaterial
 * should use this default material as a base for the material it returns.
 * The default normal value is given by materialInput.normalEC.
 *
 * @name czm_getDefaultMaterial
 * @glslFunction
 *
 * @param {czm_materialInput} input The input used to construct the default material.
 *
 * @returns {czm_material} The default material.
 *
 * @see czm_materialInput
 * @see czm_material
 * @see czm_getMaterial
 */
czm_material czm_getDefaultMaterial(czm_materialInput materialInput)
{
    czm_material material;
    material.diffuse = vec3(0.0);
    material.specular = 0.0;
    material.shininess = 1.0;
    material.normal = materialInput.normalEC;
    material.emission = vec3(0.0);
    material.alpha = 1.0;
    return material;
}
`});var F1,b1=S(()=>{F1=`/**
 * Select which direction vector to use for dynamic atmosphere lighting based on an enum value
 *
 * @name czm_getDynamicAtmosphereLightDirection
 * @glslfunction
 * @see DynamicAtmosphereLightingType.js
 *
 * @param {vec3} positionWC the position of the vertex/fragment in world coordinates. This is normalized and returned when dynamic lighting is turned off.
 * @param {float} lightEnum The enum value for selecting between light sources.
 * @return {vec3} The normalized light direction vector. Depending on the enum value, it is either positionWC, czm_lightDirectionWC or czm_sunDirectionWC
 */
vec3 czm_getDynamicAtmosphereLightDirection(vec3 positionWC, float lightEnum) {
    const float NONE = 0.0;
    const float SCENE_LIGHT = 1.0;
    const float SUNLIGHT = 2.0;

    vec3 lightDirection =
        positionWC * float(lightEnum == NONE) +
        czm_lightDirectionWC * float(lightEnum == SCENE_LIGHT) +
        czm_sunDirectionWC * float(lightEnum == SUNLIGHT);
    return normalize(lightDirection);
}
`});var Y1,V1=S(()=>{Y1=`/**
 * Calculates the intensity of diffusely reflected light.
 *
 * @name czm_getLambertDiffuse
 * @glslFunction
 *
 * @param {vec3} lightDirectionEC Unit vector pointing to the light source in eye coordinates.
 * @param {vec3} normalEC The surface normal in eye coordinates.
 *
 * @returns {float} The intensity of the diffuse reflection.
 *
 * @see czm_phong
 *
 * @example
 * float diffuseIntensity = czm_getLambertDiffuse(lightDirectionEC, normalEC);
 * float specularIntensity = czm_getSpecular(lightDirectionEC, toEyeEC, normalEC, 200);
 * vec3 color = (diffuseColor * diffuseIntensity) + (specularColor * specularIntensity);
 */
float czm_getLambertDiffuse(vec3 lightDirectionEC, vec3 normalEC)
{
    return max(dot(lightDirectionEC, normalEC), 0.0);
}
`});var S1,O1=S(()=>{S1=`/**
 * Calculates the specular intensity of reflected light.
 *
 * @name czm_getSpecular
 * @glslFunction
 *
 * @param {vec3} lightDirectionEC Unit vector pointing to the light source in eye coordinates.
 * @param {vec3} toEyeEC Unit vector pointing to the eye position in eye coordinates.
 * @param {vec3} normalEC The surface normal in eye coordinates.
 * @param {float} shininess The sharpness of the specular reflection.  Higher values create a smaller, more focused specular highlight.
 *
 * @returns {float} The intensity of the specular highlight.
 *
 * @see czm_phong
 *
 * @example
 * float diffuseIntensity = czm_getLambertDiffuse(lightDirectionEC, normalEC);
 * float specularIntensity = czm_getSpecular(lightDirectionEC, toEyeEC, normalEC, 200);
 * vec3 color = (diffuseColor * diffuseIntensity) + (specularColor * specularIntensity);
 */
float czm_getSpecular(vec3 lightDirectionEC, vec3 toEyeEC, vec3 normalEC, float shininess)
{
    vec3 toReflectedLight = reflect(-lightDirectionEC, normalEC);
    float specular = max(dot(toReflectedLight, toEyeEC), 0.0);

    // pow has undefined behavior if both parameters <= 0.
    // Prevent this by making sure shininess is at least czm_epsilon2.
    return pow(specular, max(shininess, czm_epsilon2));
}
`});var B1,G1=S(()=>{B1=`/**
 * @private
 */
vec4 czm_getWaterNoise(sampler2D normalMap, vec2 uv, float time, float angleInRadians)
{
    float cosAngle = cos(angleInRadians);
    float sinAngle = sin(angleInRadians);

    // time dependent sampling directions
    vec2 s0 = vec2(1.0/17.0, 0.0);
    vec2 s1 = vec2(-1.0/29.0, 0.0);
    vec2 s2 = vec2(1.0/101.0, 1.0/59.0);
    vec2 s3 = vec2(-1.0/109.0, -1.0/57.0);

    // rotate sampling direction by specified angle
    s0 = vec2((cosAngle * s0.x) - (sinAngle * s0.y), (sinAngle * s0.x) + (cosAngle * s0.y));
    s1 = vec2((cosAngle * s1.x) - (sinAngle * s1.y), (sinAngle * s1.x) + (cosAngle * s1.y));
    s2 = vec2((cosAngle * s2.x) - (sinAngle * s2.y), (sinAngle * s2.x) + (cosAngle * s2.y));
    s3 = vec2((cosAngle * s3.x) - (sinAngle * s3.y), (sinAngle * s3.x) + (cosAngle * s3.y));

    vec2 uv0 = (uv/103.0) + (time * s0);
    vec2 uv1 = uv/107.0 + (time * s1) + vec2(0.23);
    vec2 uv2 = uv/vec2(897.0, 983.0) + (time * s2) + vec2(0.51);
    vec2 uv3 = uv/vec2(991.0, 877.0) + (time * s3) + vec2(0.71);

    uv0 = fract(uv0);
    uv1 = fract(uv1);
    uv2 = fract(uv2);
    uv3 = fract(uv3);
    vec4 noise = (texture(normalMap, uv0)) +
                 (texture(normalMap, uv1)) +
                 (texture(normalMap, uv2)) +
                 (texture(normalMap, uv3));

    // average and scale to between -1 and 1
    return ((noise / 4.0) - 0.5) * 2.0;
}
`});var W1,D1=S(()=>{W1=`/**
 * Adjusts the hue of a color.
 * 
 * @name czm_hue
 * @glslFunction
 * 
 * @param {vec3} rgb The color.
 * @param {float} adjustment The amount to adjust the hue of the color in radians.
 *
 * @returns {float} The color with the hue adjusted.
 *
 * @example
 * vec3 adjustHue = czm_hue(color, czm_pi); // The same as czm_hue(color, -czm_pi)
 */
vec3 czm_hue(vec3 rgb, float adjustment)
{
    const mat3 toYIQ = mat3(0.299,     0.587,     0.114,
                            0.595716, -0.274453, -0.321263,
                            0.211456, -0.522591,  0.311135);
    const mat3 toRGB = mat3(1.0,  0.9563,  0.6210,
                            1.0, -0.2721, -0.6474,
                            1.0, -1.107,   1.7046);
    
    vec3 yiq = toYIQ * rgb;
    float hue = atan(yiq.z, yiq.y) + adjustment;
    float chroma = sqrt(yiq.z * yiq.z + yiq.y * yiq.y);
    
    vec3 color = vec3(yiq.x, chroma * cos(hue), chroma * sin(hue));
    return toRGB * color;
}
`});var U1,M1=S(()=>{U1=`/**
 * Converts a color in linear space to RGB space.
 *
 * @name czm_inverseGamma
 * @glslFunction
 *
 * @param {vec3} color The color in linear space.
 * @returns {vec3} The color in RGB space.
 */
vec3 czm_inverseGamma(vec3 color) {
    return pow(color, vec3(1.0 / czm_gamma));
}
`});var Q1,k1=S(()=>{Q1=`/**
 * Determines if a time interval is empty.
 *
 * @name czm_isEmpty
 * @glslFunction 
 * 
 * @param {czm_raySegment} interval The interval to test.
 * 
 * @returns {bool} <code>true</code> if the time interval is empty; otherwise, <code>false</code>.
 *
 * @example
 * bool b0 = czm_isEmpty(czm_emptyRaySegment);      // true
 * bool b1 = czm_isEmpty(czm_raySegment(0.0, 1.0)); // false
 * bool b2 = czm_isEmpty(czm_raySegment(1.0, 1.0)); // false, contains 1.0.
 */
bool czm_isEmpty(czm_raySegment interval)
{
    return (interval.stop < 0.0);
}
`});var L1,y1=S(()=>{L1=`/**
 * Determines if a time interval is empty.
 *
 * @name czm_isFull
 * @glslFunction 
 * 
 * @param {czm_raySegment} interval The interval to test.
 * 
 * @returns {bool} <code>true</code> if the time interval is empty; otherwise, <code>false</code>.
 *
 * @example
 * bool b0 = czm_isEmpty(czm_emptyRaySegment);      // true
 * bool b1 = czm_isEmpty(czm_raySegment(0.0, 1.0)); // false
 * bool b2 = czm_isEmpty(czm_raySegment(1.0, 1.0)); // false, contains 1.0.
 */
bool czm_isFull(czm_raySegment interval)
{
    return (interval.start == 0.0 && interval.stop == czm_infinity);
}
`});var w1,x1=S(()=>{w1=`/**
 * Computes the fraction of a Web Wercator rectangle at which a given geodetic latitude is located.
 *
 * @name czm_latitudeToWebMercatorFraction
 * @glslFunction
 *
 * @param {float} latitude The geodetic latitude, in radians.
 * @param {float} southMercatorY The Web Mercator coordinate of the southern boundary of the rectangle.
 * @param {float} oneOverMercatorHeight The total height of the rectangle in Web Mercator coordinates.
 *
 * @returns {float} The fraction of the rectangle at which the latitude occurs.  If the latitude is the southern
 *          boundary of the rectangle, the return value will be zero.  If it is the northern boundary, the return
 *          value will be 1.0.  Latitudes in between are mapped according to the Web Mercator projection.
 */ 
float czm_latitudeToWebMercatorFraction(float latitude, float southMercatorY, float oneOverMercatorHeight)
{
    float sinLatitude = sin(latitude);
    float mercatorY = 0.5 * log((1.0 + sinLatitude) / (1.0 - sinLatitude));
    
    return (mercatorY - southMercatorY) * oneOverMercatorHeight;
}
`});var P1,J1=S(()=>{P1=`/**
 * Computes distance from an point in 2D to a line in 2D.
 *
 * @name czm_lineDistance
 * @glslFunction
 *
 * param {vec2} point1 A point along the line.
 * param {vec2} point2 A point along the line.
 * param {vec2} point A point that may or may not be on the line.
 * returns {float} The distance from the point to the line.
 */
float czm_lineDistance(vec2 point1, vec2 point2, vec2 point) {
    return abs((point2.y - point1.y) * point.x - (point2.x - point1.x) * point.y + point2.x * point1.y - point2.y * point1.x) / distance(point2, point1);
}
`});var j1,H1=S(()=>{j1=`/**
 * Converts a linear RGB color to an sRGB color.
 *
 * @param {vec3|vec4} linearIn The color in linear color space.
 * @returns {vec3|vec4} The color in sRGB color space. The vector type matches the input.
 */
vec3 czm_linearToSrgb(vec3 linearIn) 
{
    return pow(linearIn, vec3(1.0/2.2));
}

vec4 czm_linearToSrgb(vec4 linearIn) 
{
    vec3 srgbOut = pow(linearIn.rgb, vec3(1.0/2.2));
    return vec4(srgbOut, linearIn.a);
}
`});var v1,z1=S(()=>{v1=`/**
 * Computes the luminance of a color. 
 *
 * @name czm_luminance
 * @glslFunction
 *
 * @param {vec3} rgb The color.
 * 
 * @returns {float} The luminance.
 *
 * @example
 * float light = czm_luminance(vec3(0.0)); // 0.0
 * float dark = czm_luminance(vec3(1.0));  // ~1.0 
 */
float czm_luminance(vec3 rgb)
{
    // Algorithm from Chapter 10 of Graphics Shaders.
    const vec3 W = vec3(0.2125, 0.7154, 0.0721);
    return dot(rgb, W);
}
`});var K1,X1=S(()=>{K1=`/**
 * Computes the size of a pixel in meters at a distance from the eye.
 * <p>
 * Use this version when passing in a custom pixel ratio. For example, passing in 1.0 will return meters per native device pixel.
 * </p>
 * @name czm_metersPerPixel
 * @glslFunction
 *
 * @param {vec3} positionEC The position to get the meters per pixel in eye coordinates.
 * @param {float} pixelRatio The scaling factor from pixel space to coordinate space
 *
 * @returns {float} The meters per pixel at positionEC.
 */
float czm_metersPerPixel(vec4 positionEC, float pixelRatio)
{
    float width = czm_viewport.z;
    float height = czm_viewport.w;
    float pixelWidth;
    float pixelHeight;

    float top = czm_frustumPlanes.x;
    float bottom = czm_frustumPlanes.y;
    float left = czm_frustumPlanes.z;
    float right = czm_frustumPlanes.w;

    if (czm_sceneMode == czm_sceneMode2D || czm_orthographicIn3D == 1.0)
    {
        float frustumWidth = right - left;
        float frustumHeight = top - bottom;
        pixelWidth = frustumWidth / width;
        pixelHeight = frustumHeight / height;
    }
    else
    {
        float distanceToPixel = -positionEC.z;
        float inverseNear = 1.0 / czm_currentFrustum.x;
        float tanTheta = top * inverseNear;
        pixelHeight = 2.0 * distanceToPixel * tanTheta / height;
        tanTheta = right * inverseNear;
        pixelWidth = 2.0 * distanceToPixel * tanTheta / width;
    }

    return max(pixelWidth, pixelHeight) * pixelRatio;
}

/**
 * Computes the size of a pixel in meters at a distance from the eye.
 * <p>
 * Use this version when scaling by pixel ratio.
 * </p>
 * @name czm_metersPerPixel
 * @glslFunction
 *
 * @param {vec3} positionEC The position to get the meters per pixel in eye coordinates.
 *
 * @returns {float} The meters per pixel at positionEC.
 */
float czm_metersPerPixel(vec4 positionEC)
{
    return czm_metersPerPixel(positionEC, czm_pixelRatio);
}
`});var q1,$1=S(()=>{q1=`/**
 * Transforms a position from model to window coordinates.  The transformation
 * from model to clip coordinates is done using {@link czm_modelViewProjection}.
 * The transform from normalized device coordinates to window coordinates is
 * done using {@link czm_viewportTransformation}, which assumes a depth range
 * of <code>near = 0</code> and <code>far = 1</code>.
 * <br /><br />
 * This transform is useful when there is a need to manipulate window coordinates
 * in a vertex shader as done by {@link BillboardCollection}.
 * <br /><br />
 * This function should not be confused with {@link czm_viewportOrthographic},
 * which is an orthographic projection matrix that transforms from window 
 * coordinates to clip coordinates.
 *
 * @name czm_modelToWindowCoordinates
 * @glslFunction
 *
 * @param {vec4} position The position in model coordinates to transform.
 *
 * @returns {vec4} The transformed position in window coordinates.
 *
 * @see czm_eyeToWindowCoordinates
 * @see czm_modelViewProjection
 * @see czm_viewportTransformation
 * @see czm_viewportOrthographic
 * @see BillboardCollection
 *
 * @example
 * vec4 positionWC = czm_modelToWindowCoordinates(positionMC);
 */
vec4 czm_modelToWindowCoordinates(vec4 position)
{
    vec4 q = czm_modelViewProjection * position;                // clip coordinates
    q.xyz /= q.w;                                                // normalized device coordinates
    q.xyz = (czm_viewportTransformation * vec4(q.xyz, 1.0)).xyz; // window coordinates
    return q;
}
`});var tk,ek=S(()=>{tk=`/**
 * DOC_TBA
 *
 * @name czm_multiplyWithColorBalance
 * @glslFunction
 */
vec3 czm_multiplyWithColorBalance(vec3 left, vec3 right)
{
    // Algorithm from Chapter 10 of Graphics Shaders.
    const vec3 W = vec3(0.2125, 0.7154, 0.0721);
    
    vec3 target = left * right;
    float leftLuminance = dot(left, W);
    float rightLuminance = dot(right, W);
    float targetLuminance = dot(target, W);
    
    return ((leftLuminance + rightLuminance) / (2.0 * targetLuminance)) * target;
}
`});var ik,nk=S(()=>{ik=`/**
 * Computes a value that scales with distance.  The scaling is clamped at the near and
 * far distances, and does not extrapolate.  This function works with the
 * {@link NearFarScalar} JavaScript class.
 *
 * @name czm_nearFarScalar
 * @glslFunction
 *
 * @param {vec4} nearFarScalar A vector with 4 components: Near distance (x), Near value (y), Far distance (z), Far value (w).
 * @param {float} cameraDistSq The square of the current distance from the camera.
 *
 * @returns {float} The value at this distance.
 */
float czm_nearFarScalar(vec4 nearFarScalar, float cameraDistSq)
{
    float valueAtMin = nearFarScalar.y;
    float valueAtMax = nearFarScalar.w;
    float nearDistanceSq = nearFarScalar.x * nearFarScalar.x;
    float farDistanceSq = nearFarScalar.z * nearFarScalar.z;

    float t = (cameraDistSq - nearDistanceSq) / (farDistanceSq - nearDistanceSq);

    t = pow(clamp(t, 0.0, 1.0), 0.2);

    return mix(valueAtMin, valueAtMax, t);
}
`});var sk,ok=S(()=>{sk=` /**
  * Decodes a unit-length vector in 'oct' encoding to a normalized 3-component Cartesian vector.
  * The 'oct' encoding is described in "A Survey of Efficient Representations of Independent Unit Vectors",
  * Cigolle et al 2014: http://jcgt.org/published/0003/02/01/
  *
  * @name czm_octDecode
  * @param {vec2} encoded The oct-encoded, unit-length vector
  * @param {float} range The maximum value of the SNORM range. The encoded vector is stored in log2(rangeMax+1) bits.
  * @returns {vec3} The decoded and normalized vector
  */
  vec3 czm_octDecode(vec2 encoded, float range)
  {
      if (encoded.x == 0.0 && encoded.y == 0.0) {
          return vec3(0.0, 0.0, 0.0);
      }

     encoded = encoded / range * 2.0 - 1.0;
     vec3 v = vec3(encoded.x, encoded.y, 1.0 - abs(encoded.x) - abs(encoded.y));
     if (v.z < 0.0)
     {
         v.xy = (1.0 - abs(v.yx)) * czm_signNotZero(v.xy);
     }

     return normalize(v);
  }

/**
 * Decodes a unit-length vector in 'oct' encoding to a normalized 3-component Cartesian vector.
 * The 'oct' encoding is described in "A Survey of Efficient Representations of Independent Unit Vectors",
 * Cigolle et al 2014: http://jcgt.org/published/0003/02/01/
 *
 * @name czm_octDecode
 * @param {vec2} encoded The oct-encoded, unit-length vector
 * @returns {vec3} The decoded and normalized vector
 */
 vec3 czm_octDecode(vec2 encoded)
 {
    return czm_octDecode(encoded, 255.0);
 }

 /**
 * Decodes a unit-length vector in 'oct' encoding packed into a floating-point number to a normalized 3-component Cartesian vector.
 * The 'oct' encoding is described in "A Survey of Efficient Representations of Independent Unit Vectors",
 * Cigolle et al 2014: http://jcgt.org/published/0003/02/01/
 *
 * @name czm_octDecode
 * @param {float} encoded The oct-encoded, unit-length vector
 * @returns {vec3} The decoded and normalized vector
 */
 vec3 czm_octDecode(float encoded)
 {
    float temp = encoded / 256.0;
    float x = floor(temp);
    float y = (temp - x) * 256.0;
    return czm_octDecode(vec2(x, y));
 }

/**
 * Decodes three unit-length vectors in 'oct' encoding packed into two floating-point numbers to normalized 3-component Cartesian vectors.
 * The 'oct' encoding is described in "A Survey of Efficient Representations of Independent Unit Vectors",
 * Cigolle et al 2014: http://jcgt.org/published/0003/02/01/
 *
 * @name czm_octDecode
 * @param {vec2} encoded The packed oct-encoded, unit-length vectors.
 * @param {vec3} vector1 One decoded and normalized vector.
 * @param {vec3} vector2 One decoded and normalized vector.
 * @param {vec3} vector3 One decoded and normalized vector.
 */
  void czm_octDecode(vec2 encoded, out vec3 vector1, out vec3 vector2, out vec3 vector3)
 {
    float temp = encoded.x / 65536.0;
    float x = floor(temp);
    float encodedFloat1 = (temp - x) * 65536.0;

    temp = encoded.y / 65536.0;
    float y = floor(temp);
    float encodedFloat2 = (temp - y) * 65536.0;

    vector1 = czm_octDecode(encodedFloat1);
    vector2 = czm_octDecode(encodedFloat2);
    vector3 = czm_octDecode(vec2(x, y));
 }

`});var rk,ak=S(()=>{rk=`/**
 * Packs a depth value into a vec3 that can be represented by unsigned bytes.
 *
 * @name czm_packDepth
 * @glslFunction
 *
 * @param {float} depth The floating-point depth.
 * @returns {vec3} The packed depth.
 */
vec4 czm_packDepth(float depth)
{
    // See Aras Pranckevi\u010Dius' post Encoding Floats to RGBA
    // http://aras-p.info/blog/2009/07/30/encoding-floats-to-rgba-the-final/
    vec4 enc = vec4(1.0, 255.0, 65025.0, 16581375.0) * depth;
    enc = fract(enc);
    enc -= enc.yzww * vec4(1.0 / 255.0, 1.0 / 255.0, 1.0 / 255.0, 0.0);
    return enc;
}
`});var Ak,hk=S(()=>{Ak=`vec3 lambertianDiffuse(vec3 diffuseColor)
{
    return diffuseColor / czm_pi;
}

vec3 fresnelSchlick2(vec3 f0, vec3 f90, float VdotH)
{
    return f0 + (f90 - f0) * pow(clamp(1.0 - VdotH, 0.0, 1.0), 5.0);
}

float smithVisibilityG1(float NdotV, float roughness)
{
    // this is the k value for direct lighting.
    // for image based lighting it will be roughness^2 / 2
    float k = (roughness + 1.0) * (roughness + 1.0) / 8.0;
    return NdotV / (NdotV * (1.0 - k) + k);
}

float smithVisibilityGGX(float roughness, float NdotL, float NdotV)
{
    return (
        smithVisibilityG1(NdotL, roughness) *
        smithVisibilityG1(NdotV, roughness)
    );
}

float GGX(float roughness, float NdotH)
{
    float roughnessSquared = roughness * roughness;
    float f = (NdotH * roughnessSquared - NdotH) * NdotH + 1.0;
    return roughnessSquared / (czm_pi * f * f);
}

/**
 * Compute the diffuse and specular contributions using physically based
 * rendering. This function only handles direct lighting.
 * <p>
 * This function only handles the lighting calculations. Metallic/roughness
 * and specular/glossy must be handled separately. See {@czm_pbrMetallicRoughnessMaterial}, {@czm_pbrSpecularGlossinessMaterial} and {@czm_defaultPbrMaterial}
 * </p>
 *
 * @name czm_pbrlighting
 * @glslFunction
 *
 * @param {vec3} positionEC The position of the fragment in eye coordinates
 * @param {vec3} normalEC The surface normal in eye coordinates
 * @param {vec3} lightDirectionEC Unit vector pointing to the light source in eye coordinates.
 * @param {vec3} lightColorHdr radiance of the light source. This is a HDR value.
 * @param {czm_pbrParameters} The computed PBR parameters.
 * @return {vec3} The computed HDR color
 *
 * @example
 * czm_pbrParameters pbrParameters = czm_pbrMetallicRoughnessMaterial(
 *  baseColor,
 *  metallic,
 *  roughness
 * );
 * vec3 color = czm_pbrlighting(
 *  positionEC,
 *  normalEC,
 *  lightDirectionEC,
 *  lightColorHdr,
 *  pbrParameters);
 */
vec3 czm_pbrLighting(
    vec3 positionEC,
    vec3 normalEC,
    vec3 lightDirectionEC,
    vec3 lightColorHdr,
    czm_pbrParameters pbrParameters
)
{
    vec3 v = -normalize(positionEC);
    vec3 l = normalize(lightDirectionEC);
    vec3 h = normalize(v + l);
    vec3 n = normalEC;
    float NdotL = clamp(dot(n, l), 0.001, 1.0);
    float NdotV = abs(dot(n, v)) + 0.001;
    float NdotH = clamp(dot(n, h), 0.0, 1.0);
    float LdotH = clamp(dot(l, h), 0.0, 1.0);
    float VdotH = clamp(dot(v, h), 0.0, 1.0);

    vec3 f0 = pbrParameters.f0;
    float reflectance = max(max(f0.r, f0.g), f0.b);
    vec3 f90 = vec3(clamp(reflectance * 25.0, 0.0, 1.0));
    vec3 F = fresnelSchlick2(f0, f90, VdotH);

    float alpha = pbrParameters.roughness;
    float G = smithVisibilityGGX(alpha, NdotL, NdotV);
    float D = GGX(alpha, NdotH);
    vec3 specularContribution = F * G * D / (4.0 * NdotL * NdotV);

    vec3 diffuseColor = pbrParameters.diffuseColor;
    // F here represents the specular contribution
    vec3 diffuseContribution = (1.0 - F) * lambertianDiffuse(diffuseColor);

    // Lo = (diffuse + specular) * Li * NdotL
    return (diffuseContribution + specularContribution) * NdotL * lightColorHdr;
}
`});var ck,lk=S(()=>{ck=`/**
 * Compute parameters for physically based rendering using the
 * metallic/roughness workflow. All inputs are linear; sRGB texture values must
 * be decoded beforehand
 *
 * @name czm_pbrMetallicRoughnessMaterial
 * @glslFunction
 *
 * @param {vec3} baseColor For dielectrics, this is the base color. For metals, this is the f0 value (reflectance at normal incidence)
 * @param {float} metallic 0.0 indicates dielectric. 1.0 indicates metal. Values in between are allowed (e.g. to model rust or dirt);
 * @param {float} roughness A value between 0.0 and 1.0
 * @return {czm_pbrParameters} parameters to pass into {@link czm_pbrLighting}
 */
czm_pbrParameters czm_pbrMetallicRoughnessMaterial(
    vec3 baseColor,
    float metallic,
    float roughness
) 
{
    czm_pbrParameters results;

    // roughness is authored as perceptual roughness
    // square it to get material roughness
    roughness = clamp(roughness, 0.0, 1.0);
    results.roughness = roughness * roughness;

    // dielectrics use f0 = 0.04, metals use albedo as f0
    metallic = clamp(metallic, 0.0, 1.0);
    const vec3 REFLECTANCE_DIELECTRIC = vec3(0.04);
    vec3 f0 = mix(REFLECTANCE_DIELECTRIC, baseColor, metallic);
    results.f0 = f0;

    // diffuse only applies to dielectrics.
    results.diffuseColor = baseColor * (1.0 - f0) * (1.0 - metallic);

    return results;
}
`});var dk,mk=S(()=>{dk=`/**
 * Compute parameters for physically based rendering using the
 * specular/glossy workflow. All inputs are linear; sRGB texture values must
 * be decoded beforehand
 *
 * @name czm_pbrSpecularGlossinessMaterial
 * @glslFunction
 *
 * @param {vec3} diffuse The diffuse color for dielectrics (non-metals)
 * @param {vec3} specular The reflectance at normal incidence (f0)
 * @param {float} glossiness A number from 0.0 to 1.0 indicating how smooth the surface is.
 * @return {czm_pbrParameters} parameters to pass into {@link czm_pbrLighting}
 */
czm_pbrParameters czm_pbrSpecularGlossinessMaterial(
    vec3 diffuse,
    vec3 specular,
    float glossiness
) 
{
    czm_pbrParameters results;

    // glossiness is the opposite of roughness, but easier for artists to use.
    float roughness = 1.0 - glossiness;
    results.roughness = roughness * roughness;

    results.diffuseColor = diffuse * (1.0 - max(max(specular.r, specular.g), specular.b));
    results.f0 = specular;

    return results;
}
`});var fk,Ek=S(()=>{fk=`float czm_private_getLambertDiffuseOfMaterial(vec3 lightDirectionEC, czm_material material)
{
    return czm_getLambertDiffuse(lightDirectionEC, material.normal);
}

float czm_private_getSpecularOfMaterial(vec3 lightDirectionEC, vec3 toEyeEC, czm_material material)
{
    return czm_getSpecular(lightDirectionEC, toEyeEC, material.normal, material.shininess);
}

/**
 * Computes a color using the Phong lighting model.
 *
 * @name czm_phong
 * @glslFunction
 *
 * @param {vec3} toEye A normalized vector from the fragment to the eye in eye coordinates.
 * @param {czm_material} material The fragment's material.
 *
 * @returns {vec4} The computed color.
 *
 * @example
 * vec3 positionToEyeEC = // ...
 * czm_material material = // ...
 * vec3 lightDirectionEC = // ...
 * out_FragColor = czm_phong(normalize(positionToEyeEC), material, lightDirectionEC);
 *
 * @see czm_getMaterial
 */
vec4 czm_phong(vec3 toEye, czm_material material, vec3 lightDirectionEC)
{
    // Diffuse from directional light sources at eye (for top-down)
    float diffuse = czm_private_getLambertDiffuseOfMaterial(vec3(0.0, 0.0, 1.0), material);
    if (czm_sceneMode == czm_sceneMode3D) {
        // (and horizon views in 3D)
        diffuse += czm_private_getLambertDiffuseOfMaterial(vec3(0.0, 1.0, 0.0), material);
    }

    float specular = czm_private_getSpecularOfMaterial(lightDirectionEC, toEye, material);

    // Temporary workaround for adding ambient.
    vec3 materialDiffuse = material.diffuse * 0.5;

    vec3 ambient = materialDiffuse;
    vec3 color = ambient + material.emission;
    color += materialDiffuse * diffuse * czm_lightColor;
    color += material.specular * specular * czm_lightColor;

    return vec4(color, material.alpha);
}

vec4 czm_private_phong(vec3 toEye, czm_material material, vec3 lightDirectionEC)
{
    float diffuse = czm_private_getLambertDiffuseOfMaterial(lightDirectionEC, material);
    float specular = czm_private_getSpecularOfMaterial(lightDirectionEC, toEye, material);

    vec3 ambient = vec3(0.0);
    vec3 color = ambient + material.emission;
    color += material.diffuse * diffuse * czm_lightColor;
    color += material.specular * specular * czm_lightColor;

    return vec4(color, material.alpha);
}
`});var _k,Rk=S(()=>{_k=`/**
 * Computes distance from a point to a plane.
 *
 * @name czm_planeDistance
 * @glslFunction
 *
 * param {vec4} plane A Plane in Hessian Normal Form. See Plane.js
 * param {vec3} point A point in the same space as the plane.
 * returns {float} The distance from the point to the plane.
 */
float czm_planeDistance(vec4 plane, vec3 point) {
    return (dot(plane.xyz, point) + plane.w);
}

/**
 * Computes distance from a point to a plane.
 *
 * @name czm_planeDistance
 * @glslFunction
 *
 * param {vec3} planeNormal Normal for a plane in Hessian Normal Form. See Plane.js
 * param {float} planeDistance Distance for a plane in Hessian Normal form. See Plane.js
 * param {vec3} point A point in the same space as the plane.
 * returns {float} The distance from the point to the plane.
 */
float czm_planeDistance(vec3 planeNormal, float planeDistance, vec3 point) {
    return (dot(planeNormal, point) + planeDistance);
}
`});var Zk,Ik=S(()=>{Zk=`/**
 * Computes the point along a ray at the given time.  <code>time</code> can be positive, negative, or zero.
 *
 * @name czm_pointAlongRay
 * @glslFunction
 *
 * @param {czm_ray} ray The ray to compute the point along.
 * @param {float} time The time along the ray.
 * 
 * @returns {vec3} The point along the ray at the given time.
 * 
 * @example
 * czm_ray ray = czm_ray(vec3(0.0), vec3(1.0, 0.0, 0.0)); // origin, direction
 * vec3 v = czm_pointAlongRay(ray, 2.0); // (2.0, 0.0, 0.0)
 */
vec3 czm_pointAlongRay(czm_ray ray, float time)
{
    return ray.origin + (time * ray.direction);
}
`});var pk,uk=S(()=>{pk=`/**
 * DOC_TBA
 *
 * @name czm_rayEllipsoidIntersectionInterval
 * @glslFunction
 */
czm_raySegment czm_rayEllipsoidIntersectionInterval(czm_ray ray, vec3 ellipsoid_center, vec3 ellipsoid_inverseRadii)
{
   // ray and ellipsoid center in eye coordinates.  radii in model coordinates.
    vec3 q = ellipsoid_inverseRadii * (czm_inverseModelView * vec4(ray.origin, 1.0)).xyz;
    vec3 w = ellipsoid_inverseRadii * (czm_inverseModelView * vec4(ray.direction, 0.0)).xyz;

    q = q - ellipsoid_inverseRadii * (czm_inverseModelView * vec4(ellipsoid_center, 1.0)).xyz;

    float q2 = dot(q, q);
    float qw = dot(q, w);

    if (q2 > 1.0) // Outside ellipsoid.
    {
        if (qw >= 0.0) // Looking outward or tangent (0 intersections).
        {
            return czm_emptyRaySegment;
        }
        else // qw < 0.0.
        {
            float qw2 = qw * qw;
            float difference = q2 - 1.0; // Positively valued.
            float w2 = dot(w, w);
            float product = w2 * difference;

            if (qw2 < product) // Imaginary roots (0 intersections).
            {
                return czm_emptyRaySegment;
            }
            else if (qw2 > product) // Distinct roots (2 intersections).
            {
                float discriminant = qw * qw - product;
                float temp = -qw + sqrt(discriminant); // Avoid cancellation.
                float root0 = temp / w2;
                float root1 = difference / temp;
                if (root0 < root1)
                {
                    czm_raySegment i = czm_raySegment(root0, root1);
                    return i;
                }
                else
                {
                    czm_raySegment i = czm_raySegment(root1, root0);
                    return i;
                }
            }
            else // qw2 == product.  Repeated roots (2 intersections).
            {
                float root = sqrt(difference / w2);
                czm_raySegment i = czm_raySegment(root, root);
                return i;
            }
        }
    }
    else if (q2 < 1.0) // Inside ellipsoid (2 intersections).
    {
        float difference = q2 - 1.0; // Negatively valued.
        float w2 = dot(w, w);
        float product = w2 * difference; // Negatively valued.
        float discriminant = qw * qw - product;
        float temp = -qw + sqrt(discriminant); // Positively valued.
        czm_raySegment i = czm_raySegment(0.0, temp / w2);
        return i;
    }
    else // q2 == 1.0. On ellipsoid.
    {
        if (qw < 0.0) // Looking inward.
        {
            float w2 = dot(w, w);
            czm_raySegment i = czm_raySegment(0.0, -qw / w2);
            return i;
        }
        else // qw >= 0.0.  Looking outward or tangent.
        {
            return czm_emptyRaySegment;
        }
    }
}
`});var Ck,gk=S(()=>{Ck=`/**
 * Compute the intersection interval of a ray with a sphere.
 *
 * @name czm_raySphereIntersectionInterval
 * @glslFunction
 *
 * @param {czm_ray} ray The ray.
 * @param {vec3} center The center of the sphere.
 * @param {float} radius The radius of the sphere.
 * @return {czm_raySegment} The intersection interval of the ray with the sphere.
 */
czm_raySegment czm_raySphereIntersectionInterval(czm_ray ray, vec3 center, float radius)
{
    vec3 o = ray.origin;
    vec3 d = ray.direction;

    vec3 oc = o - center;

    float a = dot(d, d);
    float b = 2.0 * dot(d, oc);
    float c = dot(oc, oc) - (radius * radius);

    float det = (b * b) - (4.0 * a * c);

    if (det < 0.0) {
        return czm_emptyRaySegment;
    }

    float sqrtDet = sqrt(det);

    float t0 = (-b - sqrtDet) / (2.0 * a);
    float t1 = (-b + sqrtDet) / (2.0 * a);

    czm_raySegment result = czm_raySegment(t0, t1);
    return result;
}
`});var Tk,Nk=S(()=>{Tk=`float czm_readDepth(sampler2D depthTexture, vec2 texCoords)
{
    return czm_reverseLogDepth(texture(depthTexture, texCoords).r);
}
`});var Fk,bk=S(()=>{Fk=`/**
 * Reads a value previously transformed with {@link czm_writeNonPerspective}
 * by dividing it by \`w\`, the value used in the perspective divide.
 * This function is intended to be called in a fragment shader to access a
 * \`varying\` that should not be subject to perspective interpolation.
 * For example, screen-space texture coordinates. The value should have been
 * previously written in the vertex shader with a call to
 * {@link czm_writeNonPerspective}.
 *
 * @name czm_readNonPerspective
 * @glslFunction
 *
 * @param {float|vec2|vec3|vec4} value The non-perspective value to be read.
 * @param {float} oneOverW One over the perspective divide value, \`w\`. Usually this is simply \`gl_FragCoord.w\`.
 * @returns {float|vec2|vec3|vec4} The usable value.
 */
float czm_readNonPerspective(float value, float oneOverW) {
    return value * oneOverW;
}

vec2 czm_readNonPerspective(vec2 value, float oneOverW) {
    return value * oneOverW;
}

vec3 czm_readNonPerspective(vec3 value, float oneOverW) {
    return value * oneOverW;
}

vec4 czm_readNonPerspective(vec4 value, float oneOverW) {
    return value * oneOverW;
}
`});var Yk,Vk=S(()=>{Yk=`float czm_reverseLogDepth(float logZ)
{
#ifdef LOG_DEPTH
    float near = czm_currentFrustum.x;
    float far = czm_currentFrustum.y;
    float log2Depth = logZ * czm_log2FarDepthFromNearPlusOne;
    float depthFromNear = pow(2.0, log2Depth) - 1.0;
    return far * (1.0 - near / (depthFromNear + near)) / (far - near);
#endif
    return logZ;
}
`});var Sk,Ok=S(()=>{Sk=`/**
 * Round a floating point value. This function exists because round() doesn't
 * exist in GLSL 1.00. 
 *
 * @param {float|vec2|vec3|vec4} value The value to round
 * @param {float|vec2|vec3|vec3} The rounded value. The type matches the input.
 */
float czm_round(float value) {
  return floor(value + 0.5);
}

vec2 czm_round(vec2 value) {
  return floor(value + 0.5);
}

vec3 czm_round(vec3 value) {
  return floor(value + 0.5);
}

vec4 czm_round(vec4 value) {
  return floor(value + 0.5);
}
`});var Bk,Gk=S(()=>{Bk=`/**
 * Samples the 4 neighboring pixels and return the weighted average.
 *
 * @private
 */
vec3 czm_sampleOctahedralProjectionWithFiltering(sampler2D projectedMap, vec2 textureSize, vec3 direction, float lod)
{
    direction /= dot(vec3(1.0), abs(direction));
    vec2 rev = abs(direction.zx) - vec2(1.0);
    vec2 neg = vec2(direction.x < 0.0 ? rev.x : -rev.x,
                    direction.z < 0.0 ? rev.y : -rev.y);
    vec2 uv = direction.y < 0.0 ? neg : direction.xz;
    vec2 coord = 0.5 * uv + vec2(0.5);
    vec2 pixel = 1.0 / textureSize;

    if (lod > 0.0)
    {
        // Each subseqeuent mip level is half the size
        float scale = 1.0 / pow(2.0, lod);
        float offset = ((textureSize.y + 1.0) / textureSize.x);

        coord.x *= offset;
        coord *= scale;

        coord.x += offset + pixel.x;
        coord.y += (1.0 - (1.0 / pow(2.0, lod - 1.0))) + pixel.y * (lod - 1.0) * 2.0;
    }
    else
    {
        coord.x *= (textureSize.y / textureSize.x);
    }

    // Do bilinear filtering
    #ifndef OES_texture_float_linear
        vec3 color1 = texture(projectedMap, coord + vec2(0.0, pixel.y)).rgb;
        vec3 color2 = texture(projectedMap, coord + vec2(pixel.x, 0.0)).rgb;
        vec3 color3 = texture(projectedMap, coord + pixel).rgb;
        vec3 color4 = texture(projectedMap, coord).rgb;

        vec2 texturePosition = coord * textureSize;

        float fu = fract(texturePosition.x);
        float fv = fract(texturePosition.y);

        vec3 average1 = mix(color4, color2, fu);
        vec3 average2 = mix(color1, color3, fu);

        vec3 color = mix(average1, average2, fv);
    #else
        vec3 color = texture(projectedMap, coord).rgb;
    #endif

    return color;
}


/**
 * Samples from a cube map that has been projected using an octahedral projection from the given direction.
 *
 * @name czm_sampleOctahedralProjection
 * @glslFunction
 *
 * @param {sampler2D} projectedMap The texture with the octahedral projected cube map.
 * @param {vec2} textureSize The width and height dimensions in pixels of the projected map.
 * @param {vec3} direction The normalized direction used to sample the cube map.
 * @param {float} lod The level of detail to sample.
 * @param {float} maxLod The maximum level of detail.
 * @returns {vec3} The color of the cube map at the direction.
 */
vec3 czm_sampleOctahedralProjection(sampler2D projectedMap, vec2 textureSize, vec3 direction, float lod, float maxLod) {
    float currentLod = floor(lod + 0.5);
    float nextLod = min(currentLod + 1.0, maxLod);

    vec3 colorCurrentLod = czm_sampleOctahedralProjectionWithFiltering(projectedMap, textureSize, direction, currentLod);
    vec3 colorNextLod = czm_sampleOctahedralProjectionWithFiltering(projectedMap, textureSize, direction, nextLod);

    return mix(colorNextLod, colorCurrentLod, nextLod - lod);
}
`});var Wk,Dk=S(()=>{Wk=`/**
 * Adjusts the saturation of a color.
 * 
 * @name czm_saturation
 * @glslFunction
 * 
 * @param {vec3} rgb The color.
 * @param {float} adjustment The amount to adjust the saturation of the color.
 *
 * @returns {float} The color with the saturation adjusted.
 *
 * @example
 * vec3 greyScale = czm_saturation(color, 0.0);
 * vec3 doubleSaturation = czm_saturation(color, 2.0);
 */
vec3 czm_saturation(vec3 rgb, float adjustment)
{
    // Algorithm from Chapter 16 of OpenGL Shading Language
    const vec3 W = vec3(0.2125, 0.7154, 0.0721);
    vec3 intensity = vec3(dot(rgb, W));
    return mix(intensity, rgb, adjustment);
}
`});var Uk,Mk=S(()=>{Uk=`
float czm_sampleShadowMap(highp samplerCube shadowMap, vec3 d)
{
    return czm_unpackDepth(czm_textureCube(shadowMap, d));
}

float czm_sampleShadowMap(highp sampler2D shadowMap, vec2 uv)
{
#ifdef USE_SHADOW_DEPTH_TEXTURE
    return texture(shadowMap, uv).r;
#else
    return czm_unpackDepth(texture(shadowMap, uv));
#endif
}

float czm_shadowDepthCompare(samplerCube shadowMap, vec3 uv, float depth)
{
    return step(depth, czm_sampleShadowMap(shadowMap, uv));
}

float czm_shadowDepthCompare(sampler2D shadowMap, vec2 uv, float depth)
{
    return step(depth, czm_sampleShadowMap(shadowMap, uv));
}
`});var Qk,kk=S(()=>{Qk=`
float czm_private_shadowVisibility(float visibility, float nDotL, float normalShadingSmooth, float darkness)
{
#ifdef USE_NORMAL_SHADING
#ifdef USE_NORMAL_SHADING_SMOOTH
    float strength = clamp(nDotL / normalShadingSmooth, 0.0, 1.0);
#else
    float strength = step(0.0, nDotL);
#endif
    visibility *= strength;
#endif

    visibility = max(visibility, darkness);
    return visibility;
}

#ifdef USE_CUBE_MAP_SHADOW
float czm_shadowVisibility(samplerCube shadowMap, czm_shadowParameters shadowParameters)
{
    float depthBias = shadowParameters.depthBias;
    float depth = shadowParameters.depth;
    float nDotL = shadowParameters.nDotL;
    float normalShadingSmooth = shadowParameters.normalShadingSmooth;
    float darkness = shadowParameters.darkness;
    vec3 uvw = shadowParameters.texCoords;

    depth -= depthBias;
    float visibility = czm_shadowDepthCompare(shadowMap, uvw, depth);
    return czm_private_shadowVisibility(visibility, nDotL, normalShadingSmooth, darkness);
}
#else
float czm_shadowVisibility(sampler2D shadowMap, czm_shadowParameters shadowParameters)
{
    float depthBias = shadowParameters.depthBias;
    float depth = shadowParameters.depth;
    float nDotL = shadowParameters.nDotL;
    float normalShadingSmooth = shadowParameters.normalShadingSmooth;
    float darkness = shadowParameters.darkness;
    vec2 uv = shadowParameters.texCoords;

    depth -= depthBias;
#ifdef USE_SOFT_SHADOWS
    vec2 texelStepSize = shadowParameters.texelStepSize;
    float radius = 1.0;
    float dx0 = -texelStepSize.x * radius;
    float dy0 = -texelStepSize.y * radius;
    float dx1 = texelStepSize.x * radius;
    float dy1 = texelStepSize.y * radius;
    float visibility = (
        czm_shadowDepthCompare(shadowMap, uv, depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx0, dy0), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(0.0, dy0), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx1, dy0), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx0, 0.0), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx1, 0.0), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx0, dy1), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(0.0, dy1), depth) +
        czm_shadowDepthCompare(shadowMap, uv + vec2(dx1, dy1), depth)
    ) * (1.0 / 9.0);
#else
    float visibility = czm_shadowDepthCompare(shadowMap, uv, depth);
#endif

    return czm_private_shadowVisibility(visibility, nDotL, normalShadingSmooth, darkness);
}
#endif
`});var Lk,yk=S(()=>{Lk=`/**
 * Returns 1.0 if the given value is positive or zero, and -1.0 if it is negative.  This is similar to the GLSL
 * built-in function <code>sign</code> except that returns 1.0 instead of 0.0 when the input value is 0.0.
 * 
 * @name czm_signNotZero
 * @glslFunction
 *
 * @param {} value The value for which to determine the sign.
 * @returns {} 1.0 if the value is positive or zero, -1.0 if the value is negative.
 */
float czm_signNotZero(float value)
{
    return value >= 0.0 ? 1.0 : -1.0;
}

vec2 czm_signNotZero(vec2 value)
{
    return vec2(czm_signNotZero(value.x), czm_signNotZero(value.y));
}

vec3 czm_signNotZero(vec3 value)
{
    return vec3(czm_signNotZero(value.x), czm_signNotZero(value.y), czm_signNotZero(value.z));
}

vec4 czm_signNotZero(vec4 value)
{
    return vec4(czm_signNotZero(value.x), czm_signNotZero(value.y), czm_signNotZero(value.z), czm_signNotZero(value.w));
}
`});var wk,xk=S(()=>{wk=`/**
 * Computes a color from the third order spherical harmonic coefficients and a normalized direction vector.
 * <p>
 * The order of the coefficients is [L00, L1_1, L10, L11, L2_2, L2_1, L20, L21, L22].
 * </p>
 *
 * @name czm_sphericalHarmonics
 * @glslFunction
 *
 * @param {vec3} normal The normalized direction.
 * @param {vec3[9]} coefficients The third order spherical harmonic coefficients.
 * @returns {vec3} The color at the direction.
 *
 * @see https://graphics.stanford.edu/papers/envmap/envmap.pdf
 */
vec3 czm_sphericalHarmonics(vec3 normal, vec3 coefficients[9])
{
    vec3 L00 = coefficients[0];
    vec3 L1_1 = coefficients[1];
    vec3 L10 = coefficients[2];
    vec3 L11 = coefficients[3];
    vec3 L2_2 = coefficients[4];
    vec3 L2_1 = coefficients[5];
    vec3 L20 = coefficients[6];
    vec3 L21 = coefficients[7];
    vec3 L22 = coefficients[8];

    float x = normal.x;
    float y = normal.y;
    float z = normal.z;

    return
          L00
        + L1_1 * y
        + L10 * z
        + L11 * x
        + L2_2 * (y * x)
        + L2_1 * (y * z)
        + L20 * (3.0 * z * z - 1.0)
        + L21 * (z * x)
        + L22 * (x * x - y * y);
}
`});var Pk,Jk=S(()=>{Pk=`/**
 * Converts an sRGB color to a linear RGB color.
 *
 * @param {vec3|vec4} srgbIn The color in sRGB space
 * @returns {vec3|vec4} The color in linear color space. The vector type matches the input.
 */
vec3 czm_srgbToLinear(vec3 srgbIn)
{
    return pow(srgbIn, vec3(2.2));
}

vec4 czm_srgbToLinear(vec4 srgbIn) 
{
    vec3 linearOut = pow(srgbIn.rgb, vec3(2.2));
    return vec4(linearOut, srgbIn.a);
}
`});var jk,Hk=S(()=>{jk=`/**
 * Creates a matrix that transforms vectors from tangent space to eye space.
 *
 * @name czm_tangentToEyeSpaceMatrix
 * @glslFunction
 *
 * @param {vec3} normalEC The normal vector in eye coordinates.
 * @param {vec3} tangentEC The tangent vector in eye coordinates.
 * @param {vec3} bitangentEC The bitangent vector in eye coordinates.
 *
 * @returns {mat3} The matrix that transforms from tangent space to eye space.
 *
 * @example
 * mat3 tangentToEye = czm_tangentToEyeSpaceMatrix(normalEC, tangentEC, bitangentEC);
 * vec3 normal = tangentToEye * texture(normalMap, st).xyz;
 */
mat3 czm_tangentToEyeSpaceMatrix(vec3 normalEC, vec3 tangentEC, vec3 bitangentEC)
{
    vec3 normal = normalize(normalEC);
    vec3 tangent = normalize(tangentEC);
    vec3 bitangent = normalize(bitangentEC);
    return mat3(tangent.x  , tangent.y  , tangent.z,
                bitangent.x, bitangent.y, bitangent.z,
                normal.x   , normal.y   , normal.z);
}
`});var vk,zk=S(()=>{vk=`/**
 * A wrapper around the texture (WebGL2) / textureCube (WebGL1)
 * function to allow for WebGL 1 support.
 * 
 * @name czm_textureCube
 * @glslFunction
 *
 * @param {samplerCube} sampler The sampler.
 * @param {vec3} p The coordinates to sample the texture at.
 */
vec4 czm_textureCube(samplerCube sampler, vec3 p) {
#if __VERSION__ == 300
    return texture(sampler, p);
#else  
    return textureCube(sampler, p);
#endif
}`});var Kk,Xk=S(()=>{Kk=`/**
 * Transforms a plane.
 * 
 * @name czm_transformPlane
 * @glslFunction
 *
 * @param {vec4} plane The plane in Hessian Normal Form.
 * @param {mat4} transform The inverse-transpose of a transformation matrix.
 */
vec4 czm_transformPlane(vec4 plane, mat4 transform) {
    vec4 transformedPlane = transform * plane;
    // Convert the transformed plane to Hessian Normal Form
    float normalMagnitude = length(transformedPlane.xyz);
    return transformedPlane / normalMagnitude;
}
`});var qk,$k=S(()=>{qk=`/**
 * Translates a position (or any <code>vec3</code>) that was encoded with {@link EncodedCartesian3},
 * and then provided to the shader as separate <code>high</code> and <code>low</code> bits to
 * be relative to the eye.  As shown in the example, the position can then be transformed in eye
 * or clip coordinates using {@link czm_modelViewRelativeToEye} or {@link czm_modelViewProjectionRelativeToEye},
 * respectively.
 * <p>
 * This technique, called GPU RTE, eliminates jittering artifacts when using large coordinates as
 * described in {@link http://help.agi.com/AGIComponents/html/BlogPrecisionsPrecisions.htm|Precisions, Precisions}.
 * </p>
 *
 * @name czm_translateRelativeToEye
 * @glslFunction
 *
 * @param {vec3} high The position's high bits.
 * @param {vec3} low The position's low bits.
 * @returns {vec3} The position translated to be relative to the camera's position.
 *
 * @example
 * in vec3 positionHigh;
 * in vec3 positionLow;
 *
 * void main()
 * {
 *   vec4 p = czm_translateRelativeToEye(positionHigh, positionLow);
 *   gl_Position = czm_modelViewProjectionRelativeToEye * p;
 * }
 *
 * @see czm_modelViewRelativeToEye
 * @see czm_modelViewProjectionRelativeToEye
 * @see czm_computePosition
 * @see EncodedCartesian3
 */
vec4 czm_translateRelativeToEye(vec3 high, vec3 low)
{
    vec3 highDifference = high - czm_encodedCameraPositionMCHigh;
    // This check handles the case when NaN values have gotten into \`highDifference\`.
    // Such a thing could happen on devices running iOS.
    if (length(highDifference) == 0.0) {  
        highDifference = vec3(0);  
    }
    vec3 lowDifference = low - czm_encodedCameraPositionMCLow;

    return vec4(highDifference + lowDifference, 1.0);
}
`});var tL,eL=S(()=>{tL=`/**
 * @private
 */
vec4 czm_translucentPhong(vec3 toEye, czm_material material, vec3 lightDirectionEC)
{
    // Diffuse from directional light sources at eye (for top-down and horizon views)
    float diffuse = czm_getLambertDiffuse(vec3(0.0, 0.0, 1.0), material.normal);

    if (czm_sceneMode == czm_sceneMode3D) {
        // (and horizon views in 3D)
        diffuse += czm_getLambertDiffuse(vec3(0.0, 1.0, 0.0), material.normal);
    }

    diffuse = clamp(diffuse, 0.0, 1.0);

    float specular = czm_getSpecular(lightDirectionEC, toEye, material.normal, material.shininess);

    // Temporary workaround for adding ambient.
    vec3 materialDiffuse = material.diffuse * 0.5;

    vec3 ambient = materialDiffuse;
    vec3 color = ambient + material.emission;
    color += materialDiffuse * diffuse * czm_lightColor;
    color += material.specular * specular * czm_lightColor;

    return vec4(color, material.alpha);
}
`});var iL,nL=S(()=>{iL=`/**
 * Returns the transpose of the matrix.  The input <code>matrix</code> can be
 * a <code>mat2</code>, <code>mat3</code>, or <code>mat4</code>.
 *
 * @name czm_transpose
 * @glslFunction
 *
 * @param {} matrix The matrix to transpose.
 *
 * @returns {} The transposed matrix.
 *
 * @example
 * // GLSL declarations
 * mat2 czm_transpose(mat2 matrix);
 * mat3 czm_transpose(mat3 matrix);
 * mat4 czm_transpose(mat4 matrix);
 *
 * // Transpose a 3x3 rotation matrix to find its inverse.
 * mat3 eastNorthUpToEye = czm_eastNorthUpToEyeCoordinates(
 *     positionMC, normalEC);
 * mat3 eyeToEastNorthUp = czm_transpose(eastNorthUpToEye);
 */
mat2 czm_transpose(mat2 matrix)
{
    return mat2(
        matrix[0][0], matrix[1][0],
        matrix[0][1], matrix[1][1]);
}

mat3 czm_transpose(mat3 matrix)
{
    return mat3(
        matrix[0][0], matrix[1][0], matrix[2][0],
        matrix[0][1], matrix[1][1], matrix[2][1],
        matrix[0][2], matrix[1][2], matrix[2][2]);
}

mat4 czm_transpose(mat4 matrix)
{
    return mat4(
        matrix[0][0], matrix[1][0], matrix[2][0], matrix[3][0],
        matrix[0][1], matrix[1][1], matrix[2][1], matrix[3][1],
        matrix[0][2], matrix[1][2], matrix[2][2], matrix[3][2],
        matrix[0][3], matrix[1][3], matrix[2][3], matrix[3][3]);
}
`});var sL,oL=S(()=>{sL=`vec2 getLookupUv(vec2 dimensions, int i) {
    int pixY = i / int(dimensions.x);
    int pixX = i - (pixY * int(dimensions.x));
    float pixelWidth = 1.0 / dimensions.x;
    float pixelHeight = 1.0 / dimensions.y;
    float u = (float(pixX) + 0.5) * pixelWidth; // sample from center of pixel
    float v = (float(pixY) + 0.5) * pixelHeight;
    return vec2(u, v);
}

vec4 czm_unpackClippingExtents(highp sampler2D extentsTexture, int index) {
    vec2 textureDimensions = vec2(textureSize(extentsTexture, 0));
    return texture(extentsTexture, getLookupUv(textureDimensions, index));
}`});var rL,aL=S(()=>{rL=`/**
 * Unpacks a vec4 depth value to a float in [0, 1) range.
 *
 * @name czm_unpackDepth
 * @glslFunction
 *
 * @param {vec4} packedDepth The packed depth.
 *
 * @returns {float} The floating-point depth in [0, 1) range.
 */
 float czm_unpackDepth(vec4 packedDepth)
 {
    // See Aras Pranckevi\u010Dius' post Encoding Floats to RGBA
    // http://aras-p.info/blog/2009/07/30/encoding-floats-to-rgba-the-final/
    return dot(packedDepth, vec4(1.0, 1.0 / 255.0, 1.0 / 65025.0, 1.0 / 16581375.0));
 }
`});var AL,hL=S(()=>{AL=`/**
 * Unpack an IEEE 754 single-precision float that is packed as a little-endian unsigned normalized vec4.
 *
 * @name czm_unpackFloat
 * @glslFunction
 *
 * @param {vec4} packedFloat The packed float.
 *
 * @returns {float} The floating-point depth in arbitrary range.
 */
float czm_unpackFloat(vec4 packedFloat)
{
    // Convert to [0.0, 255.0] and round to integer
    packedFloat = floor(packedFloat * 255.0 + 0.5);
    float sign = 1.0 - step(128.0, packedFloat[3]) * 2.0;
    float exponent = 2.0 * mod(packedFloat[3], 128.0) + step(128.0, packedFloat[2]) - 127.0;    
    if (exponent == -127.0)
    {
        return 0.0;
    }
    float mantissa = mod(packedFloat[2], 128.0) * 65536.0 + packedFloat[1] * 256.0 + packedFloat[0] + float(0x800000);
    float result = sign * exp2(exponent - 23.0) * mantissa;
    return result;
}
`});var cL,lL=S(()=>{cL=`/**
 * Unpack unsigned integers of 1-4 bytes. in WebGL 1, there is no uint type,
 * so the return value is an int.
 * <p>
 * There are also precision limitations in WebGL 1. highp int is still limited
 * to 24 bits. Above the value of 2^24 = 16777216, precision loss may occur.
 * </p>
 *
 * @param {float|vec2|vec3|vec4} packed The packed value. For vectors, the components are listed in little-endian order.
 *
 * @return {int} The unpacked value.
 */
 int czm_unpackUint(float packedValue) {
   float rounded = czm_round(packedValue * 255.0);
   return int(rounded);
 }

 int czm_unpackUint(vec2 packedValue) {
   vec2 rounded = czm_round(packedValue * 255.0);
   return int(dot(rounded, vec2(1.0, 256.0)));
 }

 int czm_unpackUint(vec3 packedValue) {
   vec3 rounded = czm_round(packedValue * 255.0);
   return int(dot(rounded, vec3(1.0, 256.0, 65536.0)));
 }

 int czm_unpackUint(vec4 packedValue) {
   vec4 rounded = czm_round(packedValue * 255.0);
   return int(dot(rounded, vec4(1.0, 256.0, 65536.0, 16777216.0)));
 }
`});var dL,mL=S(()=>{dL=`/**
 * Transform metadata values following the EXT_structural_metadata spec
 * by multiplying by scale and adding the offset. Operations are always
 * performed component-wise, even for matrices.
 * 
 * @param {float|vec2|vec3|vec4|mat2|mat3|mat4} offset The offset to add
 * @param {float|vec2|vec3|vec4|mat2|mat3|mat4} scale The scale factor to multiply
 * @param {float|vec2|vec3|vec4|mat2|mat3|mat4} value The original value.
 *
 * @return {float|vec2|vec3|vec4|mat2|mat3|mat4} The transformed value of the same scalar/vector/matrix type as the input.
 */
float czm_valueTransform(float offset, float scale, float value) {
  return scale * value + offset;
}

vec2 czm_valueTransform(vec2 offset, vec2 scale, vec2 value) {
  return scale * value + offset;
}

vec3 czm_valueTransform(vec3 offset, vec3 scale, vec3 value) {
  return scale * value + offset;
}

vec4 czm_valueTransform(vec4 offset, vec4 scale, vec4 value) {
  return scale * value + offset;
}

mat2 czm_valueTransform(mat2 offset, mat2 scale, mat2 value) {
  return matrixCompMult(scale, value) + offset;
}

mat3 czm_valueTransform(mat3 offset, mat3 scale, mat3 value) {
  return matrixCompMult(scale, value) + offset;
}

mat4 czm_valueTransform(mat4 offset, mat4 scale, mat4 value) {
  return matrixCompMult(scale, value) + offset;
}
`});var fL,EL=S(()=>{fL=`#ifdef LOG_DEPTH
// 1.0 at the near plane, increasing linearly from there.
out float v_depthFromNearPlusOne;
#ifdef SHADOW_MAP
out vec3 v_logPositionEC;
#endif
#endif

vec4 czm_updatePositionDepth(vec4 coords) {
#if defined(LOG_DEPTH)

#ifdef SHADOW_MAP
    vec3 logPositionEC = (czm_inverseProjection * coords).xyz;
    v_logPositionEC = logPositionEC;
#endif

    // With the very high far/near ratios used with the logarithmic depth
    // buffer, floating point rounding errors can cause linear depth values
    // to end up on the wrong side of the far plane, even for vertices that
    // are really nowhere near it. Since we always write a correct logarithmic
    // depth value in the fragment shader anyway, we just need to make sure
    // such errors don't cause the primitive to be clipped entirely before
    // we even get to the fragment shader.
    coords.z = clamp(coords.z / coords.w, -1.0, 1.0) * coords.w;
#endif

    return coords;
}

/**
 * Writes the logarithmic depth to gl_Position using the already computed gl_Position.
 *
 * @name czm_vertexLogDepth
 * @glslFunction
 */
void czm_vertexLogDepth()
{
#ifdef LOG_DEPTH
    v_depthFromNearPlusOne = (gl_Position.w - czm_currentFrustum.x) + 1.0;
    gl_Position = czm_updatePositionDepth(gl_Position);
#endif
}

/**
 * Writes the logarithmic depth to gl_Position using the provided clip coordinates.
 * <p>
 * An example use case for this function would be moving the vertex in window coordinates
 * before converting back to clip coordinates. Use the original vertex clip coordinates.
 * </p>
 * @name czm_vertexLogDepth
 * @glslFunction
 *
 * @param {vec4} clipCoords The vertex in clip coordinates.
 *
 * @example
 * czm_vertexLogDepth(czm_projection * vec4(positionEyeCoordinates, 1.0));
 */
void czm_vertexLogDepth(vec4 clipCoords)
{
#ifdef LOG_DEPTH
    v_depthFromNearPlusOne = (clipCoords.w - czm_currentFrustum.x) + 1.0;
    czm_updatePositionDepth(clipCoords);
#endif
}
`});var _L,RL=S(()=>{_L=`vec4 czm_screenToEyeCoordinates(vec4 screenCoordinate)
{
    // Reconstruct NDC coordinates
    float x = 2.0 * screenCoordinate.x - 1.0;
    float y = 2.0 * screenCoordinate.y - 1.0;
    float z = (screenCoordinate.z - czm_viewportTransformation[3][2]) / czm_viewportTransformation[2][2];
    vec4 q = vec4(x, y, z, 1.0);

    // Reverse the perspective division to obtain clip coordinates.
    q /= screenCoordinate.w;

    // Reverse the projection transformation to obtain eye coordinates.
    if (!(czm_inverseProjection == mat4(0.0))) // IE and Edge sometimes do something weird with != between mat4s
    {
        q = czm_inverseProjection * q;
    }
    else
    {
        float top = czm_frustumPlanes.x;
        float bottom = czm_frustumPlanes.y;
        float left = czm_frustumPlanes.z;
        float right = czm_frustumPlanes.w;

        float near = czm_currentFrustum.x;
        float far = czm_currentFrustum.y;

        q.x = (q.x * (right - left) + left + right) * 0.5;
        q.y = (q.y * (top - bottom) + bottom + top) * 0.5;
        q.z = (q.z * (near - far) - near - far) * 0.5;
        q.w = 1.0;
    }

    return q;
}

/**
 * Transforms a position from window to eye coordinates.
 * The transform from window to normalized device coordinates is done using components
 * of (@link czm_viewport} and {@link czm_viewportTransformation} instead of calculating
 * the inverse of <code>czm_viewportTransformation</code>. The transformation from
 * normalized device coordinates to clip coordinates is done using <code>fragmentCoordinate.w</code>,
 * which is expected to be the scalar used in the perspective divide. The transformation
 * from clip to eye coordinates is done using {@link czm_inverseProjection}.
 *
 * @name czm_windowToEyeCoordinates
 * @glslFunction
 *
 * @param {vec4} fragmentCoordinate The position in window coordinates to transform.
 *
 * @returns {vec4} The transformed position in eye coordinates.
 *
 * @see czm_modelToWindowCoordinates
 * @see czm_eyeToWindowCoordinates
 * @see czm_inverseProjection
 * @see czm_viewport
 * @see czm_viewportTransformation
 *
 * @example
 * vec4 positionEC = czm_windowToEyeCoordinates(gl_FragCoord);
 */
vec4 czm_windowToEyeCoordinates(vec4 fragmentCoordinate)
{
    vec2 screenCoordXY = (fragmentCoordinate.xy - czm_viewport.xy) / czm_viewport.zw;
    return czm_screenToEyeCoordinates(vec4(screenCoordXY, fragmentCoordinate.zw));
}

vec4 czm_screenToEyeCoordinates(vec2 screenCoordinateXY, float depthOrLogDepth)
{
    // See reverseLogDepth.glsl. This is separate to re-use the pow.
#if defined(LOG_DEPTH) || defined(LOG_DEPTH_READ_ONLY)
    float near = czm_currentFrustum.x;
    float far = czm_currentFrustum.y;
    float log2Depth = depthOrLogDepth * czm_log2FarDepthFromNearPlusOne;
    float depthFromNear = pow(2.0, log2Depth) - 1.0;
    float depthFromCamera = depthFromNear + near;
    vec4 screenCoord = vec4(screenCoordinateXY, far * (1.0 - near / depthFromCamera) / (far - near), 1.0);
    vec4 eyeCoordinate = czm_screenToEyeCoordinates(screenCoord);
    eyeCoordinate.w = 1.0 / depthFromCamera; // Better precision
    return eyeCoordinate;
#else
    vec4 screenCoord = vec4(screenCoordinateXY, depthOrLogDepth, 1.0);
    vec4 eyeCoordinate = czm_screenToEyeCoordinates(screenCoord);
#endif
    return eyeCoordinate;
}

/**
 * Transforms a position given as window x/y and a depth or a log depth from window to eye coordinates.
 * This function produces more accurate results for window positions with log depth than
 * conventionally unpacking the log depth using czm_reverseLogDepth and using the standard version
 * of czm_windowToEyeCoordinates.
 *
 * @name czm_windowToEyeCoordinates
 * @glslFunction
 *
 * @param {vec2} fragmentCoordinateXY The XY position in window coordinates to transform.
 * @param {float} depthOrLogDepth A depth or log depth for the fragment.
 *
 * @see czm_modelToWindowCoordinates
 * @see czm_eyeToWindowCoordinates
 * @see czm_inverseProjection
 * @see czm_viewport
 * @see czm_viewportTransformation
 *
 * @returns {vec4} The transformed position in eye coordinates.
 */
vec4 czm_windowToEyeCoordinates(vec2 fragmentCoordinateXY, float depthOrLogDepth)
{
    vec2 screenCoordXY = (fragmentCoordinateXY.xy - czm_viewport.xy) / czm_viewport.zw;
    return czm_screenToEyeCoordinates(screenCoordXY, depthOrLogDepth);
}
`});var ZL,IL=S(()=>{ZL=`// emulated noperspective
#if !defined(LOG_DEPTH)
in float v_WindowZ;
#endif

/**
 * Emulates GL_DEPTH_CLAMP. Clamps a fragment to the near and far plane
 * by writing the fragment's depth. See czm_depthClamp for more details.
 *
 * @name czm_writeDepthClamp
 * @glslFunction
 *
 * @example
 * out_FragColor = color;
 * czm_writeDepthClamp();
 *
 * @see czm_depthClamp
 */
void czm_writeDepthClamp()
{
#if (!defined(LOG_DEPTH) && (__VERSION__ == 300 || defined(GL_EXT_frag_depth)))
    gl_FragDepth = clamp(v_WindowZ * gl_FragCoord.w, 0.0, 1.0);
#endif
}
`});var pL,uL=S(()=>{pL=`#ifdef LOG_DEPTH
in float v_depthFromNearPlusOne;

#ifdef POLYGON_OFFSET
uniform vec2 u_polygonOffset;
#endif

#endif

/**
 * Writes the fragment depth to the logarithmic depth buffer.
 * <p>
 * Use this when the vertex shader does not call {@link czm_vertexlogDepth}, for example, when
 * ray-casting geometry using a full screen quad.
 * </p>
 * @name czm_writeLogDepth
 * @glslFunction
 *
 * @param {float} depth The depth coordinate, where 1.0 is on the near plane and
 *                      depth increases in eye-space units from there
 *
 * @example
 * czm_writeLogDepth((czm_projection * v_positionEyeCoordinates).w + 1.0);
 */
void czm_writeLogDepth(float depth)
{
#if (defined(LOG_DEPTH) && (__VERSION__ == 300 || defined(GL_EXT_frag_depth)))
    // Discard the vertex if it's not between the near and far planes.
    // We allow a bit of epsilon on the near plane comparison because a 1.0
    // from the vertex shader (indicating the vertex should be _on_ the near
    // plane) will not necessarily come here as exactly 1.0.
    if (depth <= 0.9999999 || depth > czm_farDepthFromNearPlusOne) {
        discard;
    }

#ifdef POLYGON_OFFSET
    // Polygon offset: m * factor + r * units
    float factor = u_polygonOffset[0];
    float units = u_polygonOffset[1];

#if (__VERSION__ == 300 || defined(GL_OES_standard_derivatives))
    // This factor doesn't work in IE 10
    if (factor != 0.0) {
        // m = sqrt(dZdX^2 + dZdY^2);
        float x = dFdx(depth);
        float y = dFdy(depth);
        float m = sqrt(x * x + y * y);

        // Apply the factor before computing the log depth.
        depth += m * factor;
    }
#endif

#endif

    gl_FragDepth = log2(depth) * czm_oneOverLog2FarDepthFromNearPlusOne;

#ifdef POLYGON_OFFSET
    // Apply the units after the log depth.
    gl_FragDepth += czm_epsilon7 * units;
#endif

#endif
}

/**
 * Writes the fragment depth to the logarithmic depth buffer.
 * <p>
 * Use this when the vertex shader calls {@link czm_vertexlogDepth}.
 * </p>
 *
 * @name czm_writeLogDepth
 * @glslFunction
 */
void czm_writeLogDepth() {
#ifdef LOG_DEPTH
    czm_writeLogDepth(v_depthFromNearPlusOne);
#endif
}
`});var CL,gL=S(()=>{CL=`/**
 * Transforms a value for non-perspective interpolation by multiplying
 * it by w, the value used in the perspective divide. This function is
 * intended to be called in a vertex shader to compute the value of a
 * \`varying\` that should not be subject to perspective interpolation.
 * For example, screen-space texture coordinates. The fragment shader
 * must call {@link czm_readNonPerspective} to retrieve the final
 * non-perspective value.
 *
 * @name czm_writeNonPerspective
 * @glslFunction
 *
 * @param {float|vec2|vec3|vec4} value The value to be interpolated without accounting for perspective.
 * @param {float} w The perspective divide value. Usually this is the computed \`gl_Position.w\`.
 * @returns {float|vec2|vec3|vec4} The transformed value, intended to be stored in a \`varying\` and read in the
 *          fragment shader with {@link czm_readNonPerspective}.
 */
float czm_writeNonPerspective(float value, float w) {
    return value * w;
}

vec2 czm_writeNonPerspective(vec2 value, float w) {
    return value * w;
}

vec3 czm_writeNonPerspective(vec3 value, float w) {
    return value * w;
}

vec4 czm_writeNonPerspective(vec4 value, float w) {
    return value * w;
}
`});var lI,TL=S(()=>{RU();IU();uU();gU();NU();bU();VU();OU();GU();DU();MU();kU();yU();xU();JU();HU();zU();XU();$U();eM();nM();oM();aM();hM();lM();mM();EM();RM();IM();uM();gM();NM();bM();VM();OM();GM();DM();MM();kM();yM();xM();JM();HM();zM();XM();$M();eQ();nQ();oQ();aQ();hQ();lQ();mQ();EQ();RQ();IQ();uQ();gQ();NQ();bQ();VQ();OQ();GQ();DQ();MQ();kQ();yQ();xQ();JQ();HQ();zQ();XQ();$Q();e1();n1();o1();a1();h1();l1();m1();E1();R1();I1();u1();g1();N1();b1();V1();O1();G1();D1();M1();k1();y1();x1();J1();H1();z1();X1();$1();ek();nk();ok();ak();hk();lk();mk();Ek();Rk();Ik();uk();gk();Nk();bk();Vk();Ok();Gk();Dk();Mk();kk();yk();xk();Jk();Hk();zk();Xk();$k();eL();nL();oL();aL();hL();lL();mL();EL();RL();IL();uL();gL();lI={czm_degreesPerRadian:_U,czm_depthRange:ZU,czm_epsilon1:pU,czm_epsilon2:CU,czm_epsilon3:TU,czm_epsilon4:FU,czm_epsilon5:YU,czm_epsilon6:SU,czm_epsilon7:BU,czm_infinity:WU,czm_oneOverPi:UU,czm_oneOverTwoPi:QU,czm_passCesium3DTile:LU,czm_passCesium3DTileClassification:wU,czm_passCesium3DTileClassificationIgnoreShow:PU,czm_passClassification:jU,czm_passCompute:vU,czm_passEnvironment:KU,czm_passGlobe:qU,czm_passOpaque:tM,czm_passOverlay:iM,czm_passTerrainClassification:sM,czm_passTranslucent:rM,czm_passVoxels:AM,czm_pi:cM,czm_piOverFour:dM,czm_piOverSix:fM,czm_piOverThree:_M,czm_piOverTwo:ZM,czm_radiansPerDegree:pM,czm_sceneMode2D:CM,czm_sceneMode3D:TM,czm_sceneModeColumbusView:FM,czm_sceneModeMorphing:YM,czm_solarRadius:SM,czm_threePiOver2:BM,czm_twoPi:WM,czm_webMercatorMaxLatitude:UM,czm_depthRangeStruct:QM,czm_material:LM,czm_materialInput:wM,czm_modelMaterial:PM,czm_modelVertexOutput:jM,czm_pbrParameters:vM,czm_ray:KM,czm_raySegment:qM,czm_shadowParameters:tQ,czm_HSBToRGB:iQ,czm_HSLToRGB:sQ,czm_RGBToHSB:rQ,czm_RGBToHSL:AQ,czm_RGBToXYZ:cQ,czm_XYZToRGB:dQ,czm_acesTonemapping:fQ,czm_alphaWeight:_Q,czm_antialias:ZQ,czm_applyHSBShift:pQ,czm_approximateSphericalCoordinates:CQ,czm_approximateTanh:TQ,czm_backFacing:FQ,czm_branchFreeTernary:YQ,czm_cascadeColor:SQ,czm_cascadeDistance:BQ,czm_cascadeMatrix:WQ,czm_cascadeWeights:UQ,czm_clipPolygons:QQ,czm_columbusViewMorph:LQ,czm_computeAtmosphereColor:wQ,czm_computeGroundAtmosphereScattering:PQ,czm_computePosition:jQ,czm_computeScattering:vQ,czm_cosineAndSine:KQ,czm_decompressTextureCoordinates:qQ,czm_defaultPbrMaterial:t1,czm_depthClamp:i1,czm_eastNorthUpToEyeCoordinates:s1,czm_ellipsoidContainsPoint:r1,czm_ellipsoidWgs84TextureCoordinates:A1,czm_equalsEpsilon:c1,czm_eyeOffset:d1,czm_eyeToWindowCoordinates:f1,czm_fastApproximateAtan:_1,czm_fog:Z1,czm_gammaCorrect:p1,czm_geodeticSurfaceNormal:C1,czm_getDefaultMaterial:T1,czm_getDynamicAtmosphereLightDirection:F1,czm_getLambertDiffuse:Y1,czm_getSpecular:S1,czm_getWaterNoise:B1,czm_hue:W1,czm_inverseGamma:U1,czm_isEmpty:Q1,czm_isFull:L1,czm_latitudeToWebMercatorFraction:w1,czm_lineDistance:P1,czm_linearToSrgb:j1,czm_luminance:v1,czm_metersPerPixel:K1,czm_modelToWindowCoordinates:q1,czm_multiplyWithColorBalance:tk,czm_nearFarScalar:ik,czm_octDecode:sk,czm_packDepth:rk,czm_pbrLighting:Ak,czm_pbrMetallicRoughnessMaterial:ck,czm_pbrSpecularGlossinessMaterial:dk,czm_phong:fk,czm_planeDistance:_k,czm_pointAlongRay:Zk,czm_rayEllipsoidIntersectionInterval:pk,czm_raySphereIntersectionInterval:Ck,czm_readDepth:Tk,czm_readNonPerspective:Fk,czm_reverseLogDepth:Yk,czm_round:Sk,czm_sampleOctahedralProjection:Bk,czm_saturation:Wk,czm_shadowDepthCompare:Uk,czm_shadowVisibility:Qk,czm_signNotZero:Lk,czm_sphericalHarmonics:wk,czm_srgbToLinear:Pk,czm_tangentToEyeSpaceMatrix:jk,czm_textureCube:vk,czm_transformPlane:Kk,czm_translateRelativeToEye:qk,czm_translucentPhong:tL,czm_transpose:iL,czm_unpackClippingExtents:sL,czm_unpackDepth:rL,czm_unpackFloat:AL,czm_unpackUint:cL,czm_valueTransform:dL,czm_vertexLogDepth:fL,czm_windowToEyeCoordinates:_L,czm_writeDepthClamp:ZL,czm_writeLogDepth:pL,czm_writeNonPerspective:CL}});function htt(t,e){let i=t;return i=i.replaceAll("version 300 es",""),i=i.replaceAll(/(texture\()/g,"texture2D("),e?(i=i.replaceAll(/\n\s*(in)\s+(vec\d|mat\d|float)/g,`
varying $2`),/out_FragData_(\d+)/.test(i)&&(i=`#extension GL_EXT_draw_buffers : enable
${i}`,i=i.replaceAll(/layout\s+\(location\s*=\s*\d+\)\s*out\s+vec4\s+out_FragData_\d+;/g,""),i=i.replaceAll(/out_FragData_(\d+)/g,"gl_FragData[$1]")),i=i.replaceAll(/layout\s+\(location\s*=\s*0\)\s*out\s+vec4\s+out_FragColor;/g,""),i=i.replaceAll(/out_FragColor/g,"gl_FragColor"),i=i.replaceAll(/out_FragColor\[(\d+)\]/g,"gl_FragColor[$1]"),/gl_FragDepth/.test(i)&&(i=`#extension GL_EXT_frag_depth : enable
${i}`,i=i.replaceAll(/gl_FragDepth/g,"gl_FragDepthEXT")),i=`#ifdef GL_OES_standard_derivatives
#extension GL_OES_standard_derivatives : enable
#endif
${i}`):(i=i.replaceAll(/(in)\s+(vec\d|mat\d|float)/g,"attribute $2"),i=i.replaceAll(/(out)\s+(vec\d|mat\d|float)\s+([\w]+);/g,"varying $2 $3;")),i=`#version 100
${i}`,i}var NL,FL=S(()=>{NL=htt});function bL(t){return t=t.replace(/\/\/.*/g,""),t.replace(/\/\*\*[\s\S]*?\*\//gm,function(e){let i=e.match(/\n/gm).length,n="";for(let s=0;s<i;++s)n+=`
`;return n})}function YL(t,e,i){let n;for(let s=0;s<i.length;++s)i[s].name===t&&(n=i[s]);return m(n)||(e=bL(e),n={name:t,glslSource:e,dependsOn:[],requiredBy:[],evaluated:!1},i.push(n)),n}function VL(t,e){if(t.evaluated)return;t.evaluated=!0;let i=t.glslSource.match(/\bczm_[a-zA-Z0-9_]*/g);m(i)&&i!==null&&(i=i.filter(function(n,s){return i.indexOf(n)===s}),i.forEach(function(n){if(n!==t.name&&Ms._czmBuiltinsAndUniforms.hasOwnProperty(n)){let s=YL(n,Ms._czmBuiltinsAndUniforms[n],e);t.dependsOn.push(s),s.requiredBy.push(t),VL(s,e)}}))}function ctt(t){let e=[],i=[];for(;t.length>0;){let s=t.pop();i.push(s),s.requiredBy.length===0&&e.push(s)}for(;e.length>0;){let s=e.shift();t.push(s);for(let o=0;o<s.dependsOn.length;++o){let r=s.dependsOn[o],a=r.requiredBy.indexOf(s);r.requiredBy.splice(a,1),r.requiredBy.length===0&&e.push(r)}}let n=[];for(let s=0;s<i.length;++s)i[s].requiredBy.length!==0&&n.push(i[s]);if(n.length!==0){let s=`A circular dependency was found in the following built-in functions/structs/constants: 
`;for(let o=0;o<n.length;++o)s=`${s+n[o].name}
`;throw new Y(s)}}function ltt(t){let e=[],i=YL("main",t,e);VL(i,e),ctt(e);let n="";for(let s=e.length-1;s>=0;--s)n=`${n+e[s].glslSource}
`;return n.replace(i.glslSource,"")}function SL(t,e,i){let n,s,o="",r=t.sources;if(m(r))for(n=0,s=r.length;n<s;++n)o+=`
#line 0
${r[n]}`;o=bL(o);let a;o=o.replace(/#version\s+(.*?)\n/gm,function(I,C){if(m(a)&&a!==C)throw new Y(`inconsistent versions found: ${a} and ${C}`);return a=C,`
`});let h=[];o=o.replace(/#extension.*\n/gm,function(I){return h.push(I),`
`}),o=o.replace(/precision\s(lowp|mediump|highp)\s(float|int);/,"");let A=t.pickColorQualifier;m(A)&&(o=Ms.createPickFragmentShaderSource(o,A));let d="",f=h.length;for(n=0;n<f;n++)d+=h[n];e&&(d+=`#ifdef GL_FRAGMENT_PRECISION_HIGH
    precision highp float;
    precision highp int;
#else
    precision mediump float;
    precision mediump int;
    #define highp mediump
#endif

`);let E=t.defines;if(m(E))for(n=0,s=E.length;n<s;++n){let I=E[n];I.length!==0&&(d+=`#define ${I}
`)}i.textureFloatLinear&&(d+=`#define OES_texture_float_linear

`),i.floatingPointTexture&&(d+=`#define OES_texture_float

`);let _="";t.includeBuiltIns&&(_=ltt(o)),d+=`
#line 0
`;let R=_+o;return i.webgl2&&e&&!/layout\s*\(location\s*=\s*0\)\s*out\s+vec4\s+out_FragColor;/g.test(R)&&!/czm_out_FragColor/g.test(R)&&/out_FragColor/g.test(R)&&(d+=`layout(location = 0) out vec4 out_FragColor;

`),d+=_,d+=o,i.webgl2?d=`#version 300 es
${d}`:d=NL(d,e),d}function Ms(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.pickColorQualifier;if(m(e)&&e!=="uniform"&&e!=="in")throw new Y("options.pickColorQualifier must be 'uniform' or 'in'.");this.defines=m(t.defines)?t.defines.slice(0):[],this.sources=m(t.sources)?t.sources.slice(0):[],this.pickColorQualifier=e,this.includeBuiltIns=Z(t.includeBuiltIns,!0)}function dtt(t,e){let i=t.defines,n=i.length;for(let s=0;s<n;++s)if(i[s]===e)return!0;return!1}function OL(t,e){let i=t.sources,n=i.length;for(let s=0;s<n;++s)if(i[s].indexOf(e)!==-1)return!0;return!1}function BL(t,e){let i=e.length;for(let n=0;n<i;++n){let s=e[n];if(OL(t,s))return s}}var mtt,ftt,Ui,bl=S(()=>{Ft();mt();Ot();TL();bT();FL();Ms.prototype.clone=function(){return new Ms({sources:this.sources,defines:this.defines,pickColorQualifier:this.pickColorQualifier,includeBuiltIns:this.includeBuiltIns})};Ms.replaceMain=function(t,e){return e=`void ${e}()`,t.replace(/void\s+main\s*\(\s*(?:void)?\s*\)/g,e)};Ms.prototype.getCacheKey=function(){let e=this.defines.slice().sort().join(","),i=this.pickColorQualifier,n=this.includeBuiltIns,s=this.sources.join(`
`);return`${e}:${i}:${n}:${s}`};Ms.prototype.createCombinedVertexShader=function(t){return SL(this,!1,t)};Ms.prototype.createCombinedFragmentShader=function(t){return SL(this,!0,t)};Ms._czmBuiltinsAndUniforms={};for(let t in lI)lI.hasOwnProperty(t)&&(Ms._czmBuiltinsAndUniforms[t]=lI[t]);for(let t in Mm)if(Mm.hasOwnProperty(t)){let e=Mm[t];typeof e.getDeclaration=="function"&&(Ms._czmBuiltinsAndUniforms[t]=e.getDeclaration(t))}Ms.createPickVertexShaderSource=function(t){return`${Ms.replaceMain(t,"czm_old_main")}
in vec4 pickColor; 
out vec4 czm_pickColor; 
void main() 
{ 
    czm_old_main(); 
    czm_pickColor = pickColor; 
}`};Ms.createPickFragmentShaderSource=function(t,e){let i=Ms.replaceMain(t,"czm_old_main"),n=`${e} vec4 czm_pickColor; 
void main() 
{ 
    czm_old_main(); 
    if (out_FragColor.a == 0.0) { 
       discard; 
    } 
    out_FragColor = czm_pickColor; 
}`;return`${i}
${n}`};mtt=["v_normalEC","v_normal"];Ms.findNormalVarying=function(t){return OL(t,"#ifdef HAS_NORMALS")?dtt(t,"HAS_NORMALS")?"v_normalEC":void 0:BL(t,mtt)};ftt=["v_positionEC"];Ms.findPositionVarying=function(t){return BL(t,ftt)};Ui=Ms});var Ett,Ah,dI=S(()=>{Ett={NONE:0,TRIANGLES:1,LINES:2,POLYLINES:3},Ah=Object.freeze(Ett)});function ST(t){t=Z(t,Z.EMPTY_OBJECT),p.typeOf.object("options.attributes",t.attributes),this.attributes=t.attributes,this.indices=t.indices,this.primitiveType=Z(t.primitiveType,ne.TRIANGLES),this.boundingSphere=t.boundingSphere,this.geometryType=Z(t.geometryType,Ah.NONE),this.boundingSphereCV=t.boundingSphereCV,this.offsetAttribute=t.offsetAttribute}var _tt,Rtt,GL,Ztt,Itt,ptt,utt,Ctt,gtt,Ttt,se,yi=S(()=>{Xe();Ht();ri();ae();Ft();mt();dI();dc();dn();bi();Xi();$s();pn();fr();ST.computeNumberOfVertices=function(t){p.typeOf.object("geometry",t);let e=-1;for(let i in t.attributes)if(t.attributes.hasOwnProperty(i)&&m(t.attributes[i])&&m(t.attributes[i].values)){let n=t.attributes[i],s=n.values.length/n.componentsPerAttribute;e=s}return e};_tt=new ut,Rtt=new l,GL=new at,Ztt=[new ut,new ut,new ut],Itt=[new nt,new nt,new nt],ptt=[new nt,new nt,new nt],utt=new l,Ctt=new Ae,gtt=new at,Ttt=new Hn;ST._textureCoordinateRotationPoints=function(t,e,i,n){let s,o=Xt.center(n,_tt),r=ut.toCartesian(o,i,Rtt),a=In.eastNorthUpToFixedFrame(r,i,GL),h=at.inverse(a,GL),A=Itt,d=Ztt;d[0].longitude=n.west,d[0].latitude=n.south,d[1].longitude=n.west,d[1].latitude=n.north,d[2].longitude=n.east,d[2].latitude=n.south;let f=utt;for(s=0;s<3;s++)ut.toCartesian(d[s],i,f),f=at.multiplyByPointAsVector(h,f,f),A[s].x=f.x,A[s].y=f.y;let E=Ae.fromAxisAngle(l.UNIT_Z,-e,Ctt),_=lt.fromQuaternion(E,gtt),R=t.length,I=Number.POSITIVE_INFINITY,C=Number.POSITIVE_INFINITY,N=Number.NEGATIVE_INFINITY,T=Number.NEGATIVE_INFINITY;for(s=0;s<R;s++)f=at.multiplyByPointAsVector(h,t[s],f),f=lt.multiplyByVector(_,f,f),I=Math.min(I,f.x),C=Math.min(C,f.y),N=Math.max(N,f.x),T=Math.max(T,f.y);let b=Hn.fromRotation(e,Ttt),F=ptt;F[0].x=I,F[0].y=C,F[1].x=I,F[1].y=T,F[2].x=N,F[2].y=C;let B=A[0],U=A[2].x-B.x,Q=A[1].y-B.y;for(s=0;s<3;s++){let g=F[s];Hn.multiplyByVector(b,g,g),g.x=(g.x-B.x)/U,g.y=(g.y-B.y)/Q}let M=F[0],k=F[1],y=F[2],c=new Array(6);return nt.pack(M,c),nt.pack(k,c,2),nt.pack(y,c,4),c};se=ST});function Ntt(t,e,i,n){let s=m(e.vertexBuffer),o=m(e.value),r=e.value?e.value.length:e.componentsPerAttribute;if(!s&&!o)throw new Y("attribute must have a vertexBuffer or a value.");if(s&&o)throw new Y("attribute cannot have both a vertexBuffer and a value.  It must have either a vertexBuffer property defining per-vertex data or a value property defining data for all vertices.");if(r!==1&&r!==2&&r!==3&&r!==4)throw o?new Y("attribute.value.length must be in the range [1, 4]."):new Y("attribute.componentsPerAttribute must be in the range [1, 4].");if(m(e.componentDatatype)&&!At.validate(e.componentDatatype))throw new Y("attribute must have a valid componentDatatype or not specify it.");if(m(e.strideInBytes)&&e.strideInBytes>255)throw new Y("attribute must have a strideInBytes less than or equal to 255 or not specify it.");if(m(e.instanceDivisor)&&e.instanceDivisor>0&&!n.instancedArrays)throw new Y("instanced arrays is not supported");if(m(e.instanceDivisor)&&e.instanceDivisor<0)throw new Y("attribute must have an instanceDivisor greater than or equal to zero");if(m(e.instanceDivisor)&&o)throw new Y("attribute cannot have have an instanceDivisor if it is not backed by a buffer");if(m(e.instanceDivisor)&&e.instanceDivisor>0&&e.index===0)throw new Y("attribute zero cannot have an instanceDivisor greater than 0");let a={index:Z(e.index,i),enabled:Z(e.enabled,!0),vertexBuffer:e.vertexBuffer,value:o?e.value.slice(0):void 0,componentsPerAttribute:r,componentDatatype:Z(e.componentDatatype,At.FLOAT),normalize:Z(e.normalize,!1),offsetInBytes:Z(e.offsetInBytes,0),strideInBytes:Z(e.strideInBytes,0),instanceDivisor:Z(e.instanceDivisor,0)};if(s)a.vertexAttrib=function(h){let A=this.index;h.bindBuffer(h.ARRAY_BUFFER,this.vertexBuffer._getBuffer()),h.vertexAttribPointer(A,this.componentsPerAttribute,this.componentDatatype,this.normalize,this.strideInBytes,this.offsetInBytes),h.enableVertexAttribArray(A),this.instanceDivisor>0&&(n.glVertexAttribDivisor(A,this.instanceDivisor),n._vertexAttribDivisors[A]=this.instanceDivisor,n._previousDrawInstanced=!0)},a.disableVertexAttribArray=function(h){h.disableVertexAttribArray(this.index),this.instanceDivisor>0&&n.glVertexAttribDivisor(i,0)};else{switch(a.componentsPerAttribute){case 1:a.vertexAttrib=function(h){h.vertexAttrib1fv(this.index,this.value)};break;case 2:a.vertexAttrib=function(h){h.vertexAttrib2fv(this.index,this.value)};break;case 3:a.vertexAttrib=function(h){h.vertexAttrib3fv(this.index,this.value)};break;case 4:a.vertexAttrib=function(h){h.vertexAttrib4fv(this.index,this.value)};break}a.disableVertexAttribArray=function(h){}}t.push(a)}function DL(t,e,i){for(let n=0;n<e.length;++n){let s=e[n];s.enabled&&s.vertexAttrib(t)}m(i)&&t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,i._getBuffer())}function hh(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context),p.defined("options.attributes",t.attributes);let e=t.context,i=e._gl,n=t.attributes,s=t.indexBuffer,o,r=[],a=1,h=!1,A=!1,d=n.length;for(o=0;o<d;++o)Ntt(r,n[o],o,e);for(d=r.length,o=0;o<d;++o){let _=r[o];if(m(_.vertexBuffer)&&_.instanceDivisor===0){let R=_.strideInBytes||_.componentsPerAttribute*At.getSizeInBytes(_.componentDatatype);a=_.vertexBuffer.sizeInBytes/R;break}}for(o=0;o<d;++o)r[o].instanceDivisor>0&&(h=!0),m(r[o].value)&&(A=!0);let f={};for(o=0;o<d;++o){let _=r[o].index;if(f[_])throw new Y(`Index ${_} is used by more than one attribute.`);f[_]=!0}let E;e.vertexArrayObject&&(E=e.glCreateVertexArray(),e.glBindVertexArray(E),DL(i,r,s),e.glBindVertexArray(null)),this._numberOfVertices=a,this._hasInstancedAttributes=h,this._hasConstantAttributes=A,this._context=e,this._gl=i,this._vao=E,this._attributes=r,this._indexBuffer=s}function WL(t){return t.values.length/t.componentsPerAttribute}function Ftt(t){return At.getSizeInBytes(t.componentDatatype)*t.componentsPerAttribute}function btt(t){let e,i,n,s=[];for(i in t)t.hasOwnProperty(i)&&m(t[i])&&m(t[i].values)&&(s.push(i),t[i].componentDatatype===At.DOUBLE&&(t[i].componentDatatype=At.FLOAT,t[i].values=At.createTypedArray(At.FLOAT,t[i].values)));let o,r=s.length;if(r>0)for(o=WL(t[s[0]]),e=1;e<r;++e){let A=WL(t[s[e]]);if(A!==o)throw new ke(`Each attribute list must have the same number of vertices.  Attribute ${s[e]} has a different number of vertices (${A.toString()}) than attribute ${s[0]} (${o.toString()}).`)}s.sort(function(A,d){return At.getSizeInBytes(t[d].componentDatatype)-At.getSizeInBytes(t[A].componentDatatype)});let a=0,h={};for(e=0;e<r;++e)i=s[e],n=t[i],h[i]=a,a+=Ftt(n);if(a>0){let A=At.getSizeInBytes(t[s[0]].componentDatatype),d=a%A;d!==0&&(a+=A-d);let f=o*a,E=new ArrayBuffer(f),_={};for(e=0;e<r;++e){i=s[e];let R=At.getSizeInBytes(t[i].componentDatatype);_[i]={pointer:At.createTypedArray(t[i].componentDatatype,E),index:h[i]/R,strideInComponentType:a/R}}for(e=0;e<o;++e)for(let R=0;R<r;++R){i=s[R],n=t[i];let I=n.values,C=_[i],N=C.pointer,T=n.componentsPerAttribute;for(let b=0;b<T;++b)N[C.index+b]=I[e*T+b];C.index+=C.strideInComponentType}return{buffer:E,offsetsInBytes:h,vertexSizeInBytes:a}}}function Ytt(t){let e=t._context,i=t._hasInstancedAttributes;if(!i&&!e._previousDrawInstanced)return;e._previousDrawInstanced=i;let n=e._vertexAttribDivisors,s=t._attributes,o=en.maximumVertexAttributes,r;if(i){let a=s.length;for(r=0;r<a;++r){let h=s[r];if(h.enabled){let A=h.instanceDivisor,d=h.index;A!==n[d]&&(e.glVertexAttribDivisor(d,A),n[d]=A)}}}else for(r=0;r<o;++r)n[r]>0&&(e.glVertexAttribDivisor(r,0),n[r]=0)}function Vtt(t,e){let i=t._attributes,n=i.length;for(let s=0;s<n;++s){let o=i[s];o.enabled&&m(o.value)&&o.vertexAttrib(e)}}var mI,OT=S(()=>{ae();oi();Ft();mt();Ws();Ot();yi();Di();_e();Ps();aI();Nl();ga();hh.fromGeometry=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context);let e=t.context,i=Z(t.geometry,Z.EMPTY_OBJECT),n=Z(t.bufferUsage,ai.DYNAMIC_DRAW),s=Z(t.attributeLocations,Z.EMPTY_OBJECT),o=Z(t.interleave,!1),r=t.vertexArrayAttributes,a,h,A,d=m(r)?r:[],f=i.attributes;if(o){let R=btt(f);if(m(R)){A=Ca.createVertexBuffer({context:e,typedArray:R.buffer,usage:n});let I=R.offsetsInBytes,C=R.vertexSizeInBytes;for(a in f)f.hasOwnProperty(a)&&m(f[a])&&(h=f[a],m(h.values)?d.push({index:s[a],vertexBuffer:A,componentDatatype:h.componentDatatype,componentsPerAttribute:h.componentsPerAttribute,normalize:h.normalize,offsetInBytes:I[a],strideInBytes:C}):d.push({index:s[a],value:h.value,componentDatatype:h.componentDatatype,normalize:h.normalize}))}}else for(a in f)if(f.hasOwnProperty(a)&&m(f[a])){h=f[a];let R=h.componentDatatype;R===At.DOUBLE&&(R=At.FLOAT),A=void 0,m(h.values)&&(A=Ca.createVertexBuffer({context:e,typedArray:At.createTypedArray(R,h.values),usage:n})),d.push({index:s[a],vertexBuffer:A,value:h.value,componentDatatype:R,componentsPerAttribute:h.componentsPerAttribute,normalize:h.normalize})}let E,_=i.indices;return m(_)&&(se.computeNumberOfVertices(i)>=L.SIXTY_FOUR_KILOBYTES&&e.elementIndexUint?E=Ca.createIndexBuffer({context:e,typedArray:new Uint32Array(_),usage:n,indexDatatype:te.UNSIGNED_INT}):E=Ca.createIndexBuffer({context:e,typedArray:new Uint16Array(_),usage:n,indexDatatype:te.UNSIGNED_SHORT})),new hh({context:e,attributes:d,indexBuffer:E})};Object.defineProperties(hh.prototype,{numberOfAttributes:{get:function(){return this._attributes.length}},numberOfVertices:{get:function(){return this._numberOfVertices}},indexBuffer:{get:function(){return this._indexBuffer}}});hh.prototype.getAttribute=function(t){return p.defined("index",t),this._attributes[t]};hh.prototype._bind=function(){m(this._vao)?(this._context.glBindVertexArray(this._vao),this._context.instancedArrays&&Ytt(this),this._hasConstantAttributes&&Vtt(this,this._gl)):DL(this._gl,this._attributes,this._indexBuffer)};hh.prototype._unBind=function(){if(m(this._vao))this._context.glBindVertexArray(null);else{let t=this._attributes,e=this._gl;for(let i=0;i<t.length;++i){let n=t[i];n.enabled&&n.disableVertexAttribArray(e)}this._indexBuffer&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null)}};hh.prototype.isDestroyed=function(){return!1};hh.prototype.destroy=function(){let t=this._attributes;for(let i=0;i<t.length;++i){let n=t[i].vertexBuffer;m(n)&&!n.isDestroyed()&&n.vertexArrayDestroyable&&n.destroy()}let e=this._indexBuffer;return m(e)&&!e.isDestroyed()&&e.vertexArrayDestroyable&&e.destroy(),m(this._vao)&&this._context.glDeleteVertexArray(this._vao),li(this)};mI=hh});function Qs(t,e,i,n){if(p.defined("context",t),!e||e.length===0)throw new Y("At least one attribute is required.");let s=Qs._verifyAttributes(e);i=Z(i,0);let o=[],r={},a,h,A=s.length;for(let f=0;f<A;++f){let E=s[f];if(E.vertexBuffer){o.push(E);continue}h=E.usage,a=r[h],m(a)||(a=r[h]=[]),a.push(E)}function d(f,E){return At.getSizeInBytes(E.componentDatatype)-At.getSizeInBytes(f.componentDatatype)}this._allBuffers=[];for(h in r)if(r.hasOwnProperty(h)){a=r[h],a.sort(d);let f=Qs._vertexSizeInBytes(a),E=a[0].usage,_={vertexSizeInBytes:f,vertexBuffer:void 0,usage:E,needsCommit:!1,arrayBuffer:void 0,arrayViews:Qs._createArrayViews(a,f)};this._allBuffers.push(_)}this._size=0,this._instanced=Z(n,!1),this._precreated=o,this._context=t,this.writers=void 0,this.va=void 0,this.resize(i)}function Ott(t,e){if(e.needsCommit&&e.vertexSizeInBytes>0){e.needsCommit=!1;let i=e.vertexBuffer,n=t._size*e.vertexSizeInBytes,s=m(i);if(!s||i.sizeInBytes<n)return s&&i.destroy(),e.vertexBuffer=Ca.createVertexBuffer({context:t._context,typedArray:e.arrayBuffer,usage:e.usage}),e.vertexBuffer.vertexArrayDestroyable=!1,!0;e.vertexBuffer.copyFromArrayView(e.arrayBuffer)}return!1}function Btt(t,e,i){if(t.needsCommit&&t.vertexSizeInBytes>0){let n=t.vertexSizeInBytes*e,s=t.vertexSizeInBytes*i;t.vertexBuffer.copyFromArrayView(new Uint8Array(t.arrayBuffer,n,s),n)}}function BT(t){let e=t.va;if(!m(e))return;let i=e.length;for(let n=0;n<i;++n)e[n].va.destroy();t.va=void 0}var Stt,fI,GT=S(()=>{ae();oi();Ft();mt();Ws();Ot();_e();aI();Nl();OT();Qs._verifyAttributes=function(t){let e=[];for(let n=0;n<t.length;++n){let s=t[n],o={index:Z(s.index,n),enabled:Z(s.enabled,!0),componentsPerAttribute:s.componentsPerAttribute,componentDatatype:Z(s.componentDatatype,At.FLOAT),normalize:Z(s.normalize,!1),vertexBuffer:s.vertexBuffer,usage:Z(s.usage,ai.STATIC_DRAW)};if(e.push(o),o.componentsPerAttribute!==1&&o.componentsPerAttribute!==2&&o.componentsPerAttribute!==3&&o.componentsPerAttribute!==4)throw new Y("attribute.componentsPerAttribute must be in the range [1, 4].");let r=o.componentDatatype;if(!At.validate(r))throw new Y("Attribute must have a valid componentDatatype or not specify it.");if(!ai.validate(o.usage))throw new Y("Attribute must have a valid usage or not specify it.")}let i=new Array(e.length);for(let n=0;n<e.length;++n){let o=e[n].index;if(i[o])throw new Y(`Index ${o} is used by more than one attribute.`);i[o]=!0}return e};Qs._vertexSizeInBytes=function(t){let e=0,i=t.length;for(let r=0;r<i;++r){let a=t[r];e+=a.componentsPerAttribute*At.getSizeInBytes(a.componentDatatype)}let n=i>0?At.getSizeInBytes(t[0].componentDatatype):0,s=n>0?e%n:0,o=s===0?0:n-s;return e+=o,e};Qs._createArrayViews=function(t,e){let i=[],n=0,s=t.length;for(let o=0;o<s;++o){let r=t[o],a=r.componentDatatype;i.push({index:r.index,enabled:r.enabled,componentsPerAttribute:r.componentsPerAttribute,componentDatatype:a,normalize:r.normalize,offsetInBytes:n,vertexSizeInComponentType:e/At.getSizeInBytes(a),view:void 0}),n+=r.componentsPerAttribute*At.getSizeInBytes(a)}return i};Qs.prototype.resize=function(t){this._size=t;let e=this._allBuffers;this.writers=[];for(let i=0,n=e.length;i<n;++i){let s=e[i];Qs._resize(s,this._size),Qs._appendWriters(this.writers,s)}BT(this)};Qs._resize=function(t,e){if(t.vertexSizeInBytes>0){let i=new ArrayBuffer(e*t.vertexSizeInBytes);if(m(t.arrayBuffer)){let o=new Uint8Array(i),r=new Uint8Array(t.arrayBuffer),a=r.length;for(let h=0;h<a;++h)o[h]=r[h]}let n=t.arrayViews,s=n.length;for(let o=0;o<s;++o){let r=n[o];r.view=At.createArrayBufferView(r.componentDatatype,i,r.offsetInBytes)}t.arrayBuffer=i}};Stt=[function(t,e,i){return function(n,s){e[n*i]=s,t.needsCommit=!0}},function(t,e,i){return function(n,s,o){let r=n*i;e[r]=s,e[r+1]=o,t.needsCommit=!0}},function(t,e,i){return function(n,s,o,r){let a=n*i;e[a]=s,e[a+1]=o,e[a+2]=r,t.needsCommit=!0}},function(t,e,i){return function(n,s,o,r,a){let h=n*i;e[h]=s,e[h+1]=o,e[h+2]=r,e[h+3]=a,t.needsCommit=!0}}];Qs._appendWriters=function(t,e){let i=e.arrayViews,n=i.length;for(let s=0;s<n;++s){let o=i[s];t[o.index]=Stt[o.componentsPerAttribute-1](e,o.view,o.vertexSizeInComponentType)}};Qs.prototype.commit=function(t){let e=!1,i=this._allBuffers,n,s,o;for(s=0,o=i.length;s<o;++s)n=i[s],e=Ott(this,n)||e;if(e||!m(this.va)){BT(this);let r=this.va=[],a=L.SIXTY_FOUR_KILOBYTES-4,h=m(t)&&!this._instanced?Math.ceil(this._size/a):1;for(let A=0;A<h;++A){let d=[];for(s=0,o=i.length;s<o;++s){n=i[s];let f=A*(n.vertexSizeInBytes*a);Qs._appendAttributes(d,n,f,this._instanced)}d=d.concat(this._precreated),r.push({va:new mI({context:this._context,attributes:d,indexBuffer:t}),indicesCount:1.5*(A!==h-1?a:this._size%a)})}}};Qs._appendAttributes=function(t,e,i,n){let s=e.arrayViews,o=s.length;for(let r=0;r<o;++r){let a=s[r];t.push({index:a.index,enabled:a.enabled,componentsPerAttribute:a.componentsPerAttribute,componentDatatype:a.componentDatatype,normalize:a.normalize,vertexBuffer:e.vertexBuffer,offsetInBytes:i+a.offsetInBytes,strideInBytes:e.vertexSizeInBytes,instanceDivisor:n?1:0})}};Qs.prototype.subCommit=function(t,e){if(t<0||t>=this._size)throw new Y("offsetInVertices must be greater than or equal to zero and less than the vertex array size.");if(t+e>this._size)throw new Y("offsetInVertices + lengthInVertices cannot exceed the vertex array size.");let i=this._allBuffers;for(let n=0,s=i.length;n<s;++n)Btt(i[n],t,e)};Qs.prototype.endSubCommits=function(){let t=this._allBuffers;for(let e=0,i=t.length;e<i;++e)t[e].needsCommit=!1};Qs.prototype.isDestroyed=function(){return!1};Qs.prototype.destroy=function(){let t=this._allBuffers;for(let e=0,i=t.length;e<i;++e){let n=t[e];n.vertexBuffer=n.vertexBuffer&&n.vertexBuffer.destroy()}return BT(this),li(this)};fI=Qs});var UL,ML=S(()=>{UL=`uniform sampler2D u_atlas;

#ifdef VECTOR_TILE
uniform vec4 u_highlightColor;
#endif

in vec2 v_textureCoordinates;
in vec4 v_pickColor;
in vec4 v_color;

#ifdef SDF
in vec4 v_outlineColor;
in float v_outlineWidth;
#endif

#ifdef FRAGMENT_DEPTH_CHECK
in vec4 v_textureCoordinateBounds;                  // the min and max x and y values for the texture coordinates
in vec4 v_originTextureCoordinateAndTranslate;      // texture coordinate at the origin, billboard translate (used for label glyphs)
in vec4 v_compressed;                               // x: eyeDepth, y: applyTranslate & enableDepthCheck, z: dimensions, w: imageSize
in mat2 v_rotationMatrix;

const float SHIFT_LEFT12 = 4096.0;
const float SHIFT_LEFT1 = 2.0;

const float SHIFT_RIGHT12 = 1.0 / 4096.0;
const float SHIFT_RIGHT1 = 1.0 / 2.0;

float getGlobeDepth(vec2 adjustedST, vec2 depthLookupST, bool applyTranslate, vec2 dimensions, vec2 imageSize)
{
    vec2 lookupVector = imageSize * (depthLookupST - adjustedST);
    lookupVector = v_rotationMatrix * lookupVector;
    vec2 labelOffset = (dimensions - imageSize) * (depthLookupST - vec2(0.0, v_originTextureCoordinateAndTranslate.y)); // aligns label glyph with bounding rectangle.  Will be zero for billboards because dimensions and imageSize will be equal

    vec2 translation = v_originTextureCoordinateAndTranslate.zw;

    if (applyTranslate)
    {
        // this is only needed for labels where the horizontal origin is not LEFT
        // it moves the label back to where the "origin" should be since all label glyphs are set to HorizontalOrigin.LEFT
        translation += (dimensions * v_originTextureCoordinateAndTranslate.xy * vec2(1.0, 0.0));
    }

    vec2 st = ((lookupVector - translation + labelOffset) + gl_FragCoord.xy) / czm_viewport.zw;
    float logDepthOrDepth = czm_unpackDepth(texture(czm_globeDepthTexture, st));

    if (logDepthOrDepth == 0.0)
    {
        return 0.0; // not on the globe
    }

    vec4 eyeCoordinate = czm_windowToEyeCoordinates(gl_FragCoord.xy, logDepthOrDepth);
    return eyeCoordinate.z / eyeCoordinate.w;
}
#endif


#ifdef SDF

// Get the distance from the edge of a glyph at a given position sampling an SDF texture.
float getDistance(vec2 position)
{
    return texture(u_atlas, position).r;
}

// Samples the sdf texture at the given position and produces a color based on the fill color and the outline.
vec4 getSDFColor(vec2 position, float outlineWidth, vec4 outlineColor, float smoothing)
{
    float distance = getDistance(position);

    if (outlineWidth > 0.0)
    {
        // Don't get the outline edge exceed the SDF_EDGE
        float outlineEdge = clamp(SDF_EDGE - outlineWidth, 0.0, SDF_EDGE);
        float outlineFactor = smoothstep(SDF_EDGE - smoothing, SDF_EDGE + smoothing, distance);
        vec4 sdfColor = mix(outlineColor, v_color, outlineFactor);
        float alpha = smoothstep(outlineEdge - smoothing, outlineEdge + smoothing, distance);
        return vec4(sdfColor.rgb, sdfColor.a * alpha);
    }
    else
    {
        float alpha = smoothstep(SDF_EDGE - smoothing, SDF_EDGE + smoothing, distance);
        return vec4(v_color.rgb, v_color.a * alpha);
    }
}
#endif

void main()
{
    vec4 color = texture(u_atlas, v_textureCoordinates);

#ifdef SDF
    float outlineWidth = v_outlineWidth;
    vec4 outlineColor = v_outlineColor;

    // Get the current distance
    float distance = getDistance(v_textureCoordinates);

#if (__VERSION__ == 300 || defined(GL_OES_standard_derivatives))
    float smoothing = fwidth(distance);
    // Get an offset that is approximately half the distance to the neighbor pixels
    // 0.354 is approximately half of 1/sqrt(2)
    vec2 sampleOffset = 0.354 * vec2(dFdx(v_textureCoordinates) + dFdy(v_textureCoordinates));

    // Sample the center point
    vec4 center = getSDFColor(v_textureCoordinates, outlineWidth, outlineColor, smoothing);

    // Sample the 4 neighbors
    vec4 color1 = getSDFColor(v_textureCoordinates + vec2(sampleOffset.x, sampleOffset.y), outlineWidth, outlineColor, smoothing);
    vec4 color2 = getSDFColor(v_textureCoordinates + vec2(-sampleOffset.x, sampleOffset.y), outlineWidth, outlineColor, smoothing);
    vec4 color3 = getSDFColor(v_textureCoordinates + vec2(-sampleOffset.x, -sampleOffset.y), outlineWidth, outlineColor, smoothing);
    vec4 color4 = getSDFColor(v_textureCoordinates + vec2(sampleOffset.x, -sampleOffset.y), outlineWidth, outlineColor, smoothing);

    // Equally weight the center sample and the 4 neighboring samples
    color = (center + color1 + color2 + color3 + color4)/5.0;
#else
    // If no derivatives available (IE 10?), just do a single sample
    float smoothing = 1.0/32.0;
    color = getSDFColor(v_textureCoordinates, outlineWidth, outlineColor, smoothing);
#endif

    color = czm_gammaCorrect(color);
#else
    color = czm_gammaCorrect(color);
    color *= czm_gammaCorrect(v_color);
#endif

// Fully transparent parts of the billboard are not pickable.
#if !defined(OPAQUE) && !defined(TRANSLUCENT)
    if (color.a < 0.005)   // matches 0/255 and 1/255
    {
        discard;
    }
#else
// The billboard is rendered twice. The opaque pass discards translucent fragments
// and the translucent pass discards opaque fragments.
#ifdef OPAQUE
    if (color.a < 0.995)   // matches < 254/255
    {
        discard;
    }
#else
    if (color.a >= 0.995)  // matches 254/255 and 255/255
    {
        discard;
    }
#endif
#endif

#ifdef VECTOR_TILE
    color *= u_highlightColor;
#endif
    out_FragColor = color;

#ifdef LOG_DEPTH
    czm_writeLogDepth();
#endif

#ifdef FRAGMENT_DEPTH_CHECK
    float temp = v_compressed.y;

    temp = temp * SHIFT_RIGHT1;

    float temp2 = (temp - floor(temp)) * SHIFT_LEFT1;
    bool enableDepthTest = temp2 != 0.0;
    bool applyTranslate = floor(temp) != 0.0;

    if (enableDepthTest) {
        temp = v_compressed.z;
        temp = temp * SHIFT_RIGHT12;

        vec2 dimensions;
        dimensions.y = (temp - floor(temp)) * SHIFT_LEFT12;
        dimensions.x = floor(temp);

        temp = v_compressed.w;
        temp = temp * SHIFT_RIGHT12;

        vec2 imageSize;
        imageSize.y = (temp - floor(temp)) * SHIFT_LEFT12;
        imageSize.x = floor(temp);

        vec2 adjustedST = v_textureCoordinates - v_textureCoordinateBounds.xy;
        adjustedST = adjustedST / vec2(v_textureCoordinateBounds.z - v_textureCoordinateBounds.x, v_textureCoordinateBounds.w - v_textureCoordinateBounds.y);

        float epsilonEyeDepth = v_compressed.x + czm_epsilon1;
        float globeDepth1 = getGlobeDepth(adjustedST, v_originTextureCoordinateAndTranslate.xy, applyTranslate, dimensions, imageSize);

        // negative values go into the screen
        if (globeDepth1 != 0.0 && globeDepth1 > epsilonEyeDepth)
        {
            float globeDepth2 = getGlobeDepth(adjustedST, vec2(0.0, 1.0), applyTranslate, dimensions, imageSize); // top left corner
            if (globeDepth2 != 0.0 && globeDepth2 > epsilonEyeDepth)
            {
                float globeDepth3 = getGlobeDepth(adjustedST, vec2(1.0, 1.0), applyTranslate, dimensions, imageSize); // top right corner
                if (globeDepth3 != 0.0 && globeDepth3 > epsilonEyeDepth)
                {
                    discard;
                }
            }
        }
    }
#endif

}
`});var QL,kL=S(()=>{QL=`#ifdef INSTANCED
in vec2 direction;
#endif
in vec4 positionHighAndScale;
in vec4 positionLowAndRotation;
in vec4 compressedAttribute0;                       // pixel offset, translate, horizontal origin, vertical origin, show, direction, texture coordinates (texture offset)
in vec4 compressedAttribute1;                       // aligned axis, translucency by distance, image width
in vec4 compressedAttribute2;                       // label horizontal origin, image height, color, pick color, size in meters, valid aligned axis, 13 bits free
in vec4 eyeOffset;                                  // eye offset in meters, 4 bytes free (texture range)
in vec4 scaleByDistance;                            // near, nearScale, far, farScale
in vec4 pixelOffsetScaleByDistance;                 // near, nearScale, far, farScale
in vec4 compressedAttribute3;                       // distance display condition near, far, disableDepthTestDistance, dimensions
in vec2 sdf;                                        // sdf outline color (rgb) and width (w)
#if defined(VERTEX_DEPTH_CHECK) || defined(FRAGMENT_DEPTH_CHECK)
in vec4 textureCoordinateBoundsOrLabelTranslate;    // the min and max x and y values for the texture coordinates
#endif
#ifdef VECTOR_TILE
in float a_batchId;
#endif

out vec2 v_textureCoordinates;
#ifdef FRAGMENT_DEPTH_CHECK
out vec4 v_textureCoordinateBounds;
out vec4 v_originTextureCoordinateAndTranslate;
out vec4 v_compressed;                                 // x: eyeDepth, y: applyTranslate & enableDepthCheck, z: dimensions, w: imageSize
out mat2 v_rotationMatrix;
#endif

out vec4 v_pickColor;
out vec4 v_color;
#ifdef SDF
out vec4 v_outlineColor;
out float v_outlineWidth;
#endif

const float UPPER_BOUND = 32768.0;

const float SHIFT_LEFT16 = 65536.0;
const float SHIFT_LEFT12 = 4096.0;
const float SHIFT_LEFT8 = 256.0;
const float SHIFT_LEFT7 = 128.0;
const float SHIFT_LEFT5 = 32.0;
const float SHIFT_LEFT3 = 8.0;
const float SHIFT_LEFT2 = 4.0;
const float SHIFT_LEFT1 = 2.0;

const float SHIFT_RIGHT12 = 1.0 / 4096.0;
const float SHIFT_RIGHT8 = 1.0 / 256.0;
const float SHIFT_RIGHT7 = 1.0 / 128.0;
const float SHIFT_RIGHT5 = 1.0 / 32.0;
const float SHIFT_RIGHT3 = 1.0 / 8.0;
const float SHIFT_RIGHT2 = 1.0 / 4.0;
const float SHIFT_RIGHT1 = 1.0 / 2.0;

vec4 addScreenSpaceOffset(vec4 positionEC, vec2 imageSize, float scale, vec2 direction, vec2 origin, vec2 translate, vec2 pixelOffset, vec3 alignedAxis, bool validAlignedAxis, float rotation, bool sizeInMeters, out mat2 rotationMatrix, out float mpp)
{
    // Note the halfSize cannot be computed in JavaScript because it is sent via
    // compressed vertex attributes that coerce it to an integer.
    vec2 halfSize = imageSize * scale * 0.5;
    halfSize *= ((direction * 2.0) - 1.0);

    vec2 originTranslate = origin * abs(halfSize);

#if defined(ROTATION) || defined(ALIGNED_AXIS)
    if (validAlignedAxis || rotation != 0.0)
    {
        float angle = rotation;
        if (validAlignedAxis)
        {
            vec4 projectedAlignedAxis = czm_modelView3D * vec4(alignedAxis, 0.0);
            angle += sign(-projectedAlignedAxis.x) * acos(sign(projectedAlignedAxis.y) * (projectedAlignedAxis.y * projectedAlignedAxis.y) /
                    (projectedAlignedAxis.x * projectedAlignedAxis.x + projectedAlignedAxis.y * projectedAlignedAxis.y));
        }

        float cosTheta = cos(angle);
        float sinTheta = sin(angle);
        rotationMatrix = mat2(cosTheta, sinTheta, -sinTheta, cosTheta);
        halfSize = rotationMatrix * halfSize;
    }
    else
    {
        rotationMatrix = mat2(1.0, 0.0, 0.0, 1.0);
    }
#endif

    mpp = czm_metersPerPixel(positionEC);
    positionEC.xy += (originTranslate + halfSize) * czm_branchFreeTernary(sizeInMeters, 1.0, mpp);
    positionEC.xy += (translate + pixelOffset) * mpp;

    return positionEC;
}

#ifdef VERTEX_DEPTH_CHECK
float getGlobeDepth(vec4 positionEC)
{
    vec4 posWC = czm_eyeToWindowCoordinates(positionEC);

    float globeDepth = czm_unpackDepth(texture(czm_globeDepthTexture, posWC.xy / czm_viewport.zw));

    if (globeDepth == 0.0)
    {
        return 0.0; // not on the globe
    }

    vec4 eyeCoordinate = czm_windowToEyeCoordinates(posWC.xy, globeDepth);
    return eyeCoordinate.z / eyeCoordinate.w;
}
#endif
void main()
{
    // Modifying this shader may also require modifications to Billboard._computeScreenSpacePosition

    // unpack attributes
    vec3 positionHigh = positionHighAndScale.xyz;
    vec3 positionLow = positionLowAndRotation.xyz;
    float scale = positionHighAndScale.w;

#if defined(ROTATION) || defined(ALIGNED_AXIS)
    float rotation = positionLowAndRotation.w;
#else
    float rotation = 0.0;
#endif

    float compressed = compressedAttribute0.x;

    vec2 pixelOffset;
    pixelOffset.x = floor(compressed * SHIFT_RIGHT7);
    compressed -= pixelOffset.x * SHIFT_LEFT7;
    pixelOffset.x -= UPPER_BOUND;

    vec2 origin;
    origin.x = floor(compressed * SHIFT_RIGHT5);
    compressed -= origin.x * SHIFT_LEFT5;

    origin.y = floor(compressed * SHIFT_RIGHT3);
    compressed -= origin.y * SHIFT_LEFT3;

#ifdef FRAGMENT_DEPTH_CHECK
    vec2 depthOrigin = origin.xy;
#endif
    origin -= vec2(1.0);

    float show = floor(compressed * SHIFT_RIGHT2);
    compressed -= show * SHIFT_LEFT2;

#ifdef INSTANCED
    vec2 textureCoordinatesBottomLeft = czm_decompressTextureCoordinates(compressedAttribute0.w);
    vec2 textureCoordinatesRange = czm_decompressTextureCoordinates(eyeOffset.w);
    vec2 textureCoordinates = textureCoordinatesBottomLeft + direction * textureCoordinatesRange;
#else
    vec2 direction;
    direction.x = floor(compressed * SHIFT_RIGHT1);
    direction.y = compressed - direction.x * SHIFT_LEFT1;

    vec2 textureCoordinates = czm_decompressTextureCoordinates(compressedAttribute0.w);
#endif

    float temp = compressedAttribute0.y  * SHIFT_RIGHT8;
    pixelOffset.y = -(floor(temp) - UPPER_BOUND);

    vec2 translate;
    translate.y = (temp - floor(temp)) * SHIFT_LEFT16;

    temp = compressedAttribute0.z * SHIFT_RIGHT8;
    translate.x = floor(temp) - UPPER_BOUND;

    translate.y += (temp - floor(temp)) * SHIFT_LEFT8;
    translate.y -= UPPER_BOUND;

    temp = compressedAttribute1.x * SHIFT_RIGHT8;
    float temp2 = floor(compressedAttribute2.w * SHIFT_RIGHT2);

    vec2 imageSize = vec2(floor(temp), temp2);

#ifdef FRAGMENT_DEPTH_CHECK
    float labelHorizontalOrigin = floor(compressedAttribute2.w - (temp2 * SHIFT_LEFT2));
    float applyTranslate = 0.0;
    if (labelHorizontalOrigin != 0.0) // is a billboard, so set apply translate to false
    {
        applyTranslate = 1.0;
        labelHorizontalOrigin -= 2.0;
        depthOrigin.x = labelHorizontalOrigin + 1.0;
    }

    depthOrigin = vec2(1.0) - (depthOrigin * 0.5);
#endif

#ifdef EYE_DISTANCE_TRANSLUCENCY
    vec4 translucencyByDistance;
    translucencyByDistance.x = compressedAttribute1.z;
    translucencyByDistance.z = compressedAttribute1.w;

    translucencyByDistance.y = ((temp - floor(temp)) * SHIFT_LEFT8) / 255.0;

    temp = compressedAttribute1.y * SHIFT_RIGHT8;
    translucencyByDistance.w = ((temp - floor(temp)) * SHIFT_LEFT8) / 255.0;
#endif

#if defined(VERTEX_DEPTH_CHECK) || defined(FRAGMENT_DEPTH_CHECK)
    temp = compressedAttribute3.w;
    temp = temp * SHIFT_RIGHT12;

    vec2 dimensions;
    dimensions.y = (temp - floor(temp)) * SHIFT_LEFT12;
    dimensions.x = floor(temp);
#endif

#ifdef ALIGNED_AXIS
    vec3 alignedAxis = czm_octDecode(floor(compressedAttribute1.y * SHIFT_RIGHT8));
    temp = compressedAttribute2.z * SHIFT_RIGHT5;
    bool validAlignedAxis = (temp - floor(temp)) * SHIFT_LEFT1 > 0.0;
#else
    vec3 alignedAxis = vec3(0.0);
    bool validAlignedAxis = false;
#endif

    vec4 pickColor;
    vec4 color;

    temp = compressedAttribute2.y;
    temp = temp * SHIFT_RIGHT8;
    pickColor.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    pickColor.g = (temp - floor(temp)) * SHIFT_LEFT8;
    pickColor.r = floor(temp);

    temp = compressedAttribute2.x;
    temp = temp * SHIFT_RIGHT8;
    color.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    color.g = (temp - floor(temp)) * SHIFT_LEFT8;
    color.r = floor(temp);

    temp = compressedAttribute2.z * SHIFT_RIGHT8;
    bool sizeInMeters = floor((temp - floor(temp)) * SHIFT_LEFT7) > 0.0;
    temp = floor(temp) * SHIFT_RIGHT8;

    pickColor.a = (temp - floor(temp)) * SHIFT_LEFT8;
    pickColor /= 255.0;

    color.a = floor(temp);
    color /= 255.0;

    ///////////////////////////////////////////////////////////////////////////

    vec4 p = czm_translateRelativeToEye(positionHigh, positionLow);
    vec4 positionEC = czm_modelViewRelativeToEye * p;

#if defined(FRAGMENT_DEPTH_CHECK) || defined(VERTEX_DEPTH_CHECK)
    float eyeDepth = positionEC.z;
#endif

    positionEC = czm_eyeOffset(positionEC, eyeOffset.xyz);
    positionEC.xyz *= show;

    ///////////////////////////////////////////////////////////////////////////

#if defined(EYE_DISTANCE_SCALING) || defined(EYE_DISTANCE_TRANSLUCENCY) || defined(EYE_DISTANCE_PIXEL_OFFSET) || defined(DISTANCE_DISPLAY_CONDITION) || defined(DISABLE_DEPTH_DISTANCE)
    float lengthSq;
    if (czm_sceneMode == czm_sceneMode2D)
    {
        // 2D camera distance is a special case
        // treat all billboards as flattened to the z=0.0 plane
        lengthSq = czm_eyeHeight2D.y;
    }
    else
    {
        lengthSq = dot(positionEC.xyz, positionEC.xyz);
    }
#endif

#ifdef EYE_DISTANCE_SCALING
    float distanceScale = czm_nearFarScalar(scaleByDistance, lengthSq);
    scale *= distanceScale;
    translate *= distanceScale;
    // push vertex behind near plane for clipping
    if (scale == 0.0)
    {
        positionEC.xyz = vec3(0.0);
    }
#endif

    float translucency = 1.0;
#ifdef EYE_DISTANCE_TRANSLUCENCY
    translucency = czm_nearFarScalar(translucencyByDistance, lengthSq);
    // push vertex behind near plane for clipping
    if (translucency == 0.0)
    {
        positionEC.xyz = vec3(0.0);
    }
#endif

#ifdef EYE_DISTANCE_PIXEL_OFFSET
    float pixelOffsetScale = czm_nearFarScalar(pixelOffsetScaleByDistance, lengthSq);
    pixelOffset *= pixelOffsetScale;
#endif

#ifdef DISTANCE_DISPLAY_CONDITION
    float nearSq = compressedAttribute3.x;
    float farSq = compressedAttribute3.y;
    if (lengthSq < nearSq || lengthSq > farSq)
    {
        positionEC.xyz = vec3(0.0);
    }
#endif

    mat2 rotationMatrix;
    float mpp;

#ifdef DISABLE_DEPTH_DISTANCE
    float disableDepthTestDistance = compressedAttribute3.z;
#endif

#ifdef VERTEX_DEPTH_CHECK
if (lengthSq < disableDepthTestDistance) {
    float depthsilon = 10.0;

    vec2 labelTranslate = textureCoordinateBoundsOrLabelTranslate.xy;
    vec4 pEC1 = addScreenSpaceOffset(positionEC, dimensions, scale, vec2(0.0), origin, labelTranslate, pixelOffset, alignedAxis, validAlignedAxis, rotation, sizeInMeters, rotationMatrix, mpp);
    float globeDepth1 = getGlobeDepth(pEC1);

    if (globeDepth1 != 0.0 && pEC1.z + depthsilon < globeDepth1)
    {
        vec4 pEC2 = addScreenSpaceOffset(positionEC, dimensions, scale, vec2(0.0, 1.0), origin, labelTranslate, pixelOffset, alignedAxis, validAlignedAxis, rotation, sizeInMeters, rotationMatrix, mpp);
        float globeDepth2 = getGlobeDepth(pEC2);

        if (globeDepth2 != 0.0 && pEC2.z + depthsilon < globeDepth2)
        {
            vec4 pEC3 = addScreenSpaceOffset(positionEC, dimensions, scale, vec2(1.0), origin, labelTranslate, pixelOffset, alignedAxis, validAlignedAxis, rotation, sizeInMeters, rotationMatrix, mpp);
            float globeDepth3 = getGlobeDepth(pEC3);
            if (globeDepth3 != 0.0 && pEC3.z + depthsilon < globeDepth3)
            {
                positionEC.xyz = vec3(0.0);
            }
        }
    }
}
#endif

    positionEC = addScreenSpaceOffset(positionEC, imageSize, scale, direction, origin, translate, pixelOffset, alignedAxis, validAlignedAxis, rotation, sizeInMeters, rotationMatrix, mpp);
    gl_Position = czm_projection * positionEC;
    v_textureCoordinates = textureCoordinates;

#ifdef LOG_DEPTH
    czm_vertexLogDepth();
#endif

#ifdef DISABLE_DEPTH_DISTANCE
    if (disableDepthTestDistance == 0.0 && czm_minimumDisableDepthTestDistance != 0.0)
    {
        disableDepthTestDistance = czm_minimumDisableDepthTestDistance;
    }

    if (disableDepthTestDistance != 0.0)
    {
        // Don't try to "multiply both sides" by w.  Greater/less-than comparisons won't work for negative values of w.
        float zclip = gl_Position.z / gl_Position.w;
        bool clipped = (zclip < -1.0 || zclip > 1.0);
        if (!clipped && (disableDepthTestDistance < 0.0 || (lengthSq > 0.0 && lengthSq < disableDepthTestDistance)))
        {
            // Position z on the near plane.
            gl_Position.z = -gl_Position.w;
#ifdef LOG_DEPTH
            v_depthFromNearPlusOne = 1.0;
#endif
        }
    }
#endif

#ifdef FRAGMENT_DEPTH_CHECK
    if (sizeInMeters) {
        translate /= mpp;
        dimensions /= mpp;
        imageSize /= mpp;
    }

#if defined(ROTATION) || defined(ALIGNED_AXIS)
    v_rotationMatrix = rotationMatrix;
#else
    v_rotationMatrix = mat2(1.0, 0.0, 0.0, 1.0);
#endif

    float enableDepthCheck = 0.0;
    if (lengthSq < disableDepthTestDistance)
    {
        enableDepthCheck = 1.0;
    }

    float dw = floor(clamp(dimensions.x, 0.0, SHIFT_LEFT12));
    float dh = floor(clamp(dimensions.y, 0.0, SHIFT_LEFT12));

    float iw = floor(clamp(imageSize.x, 0.0, SHIFT_LEFT12));
    float ih = floor(clamp(imageSize.y, 0.0, SHIFT_LEFT12));

    v_compressed.x = eyeDepth;
    v_compressed.y = applyTranslate * SHIFT_LEFT1 + enableDepthCheck;
    v_compressed.z = dw * SHIFT_LEFT12 + dh;
    v_compressed.w = iw * SHIFT_LEFT12 + ih;
    v_originTextureCoordinateAndTranslate.xy = depthOrigin;
    v_originTextureCoordinateAndTranslate.zw = translate;
    v_textureCoordinateBounds = textureCoordinateBoundsOrLabelTranslate;

#endif

#ifdef SDF
    vec4 outlineColor;
    float outlineWidth;

    temp = sdf.x;
    temp = temp * SHIFT_RIGHT8;
    outlineColor.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    outlineColor.g = (temp - floor(temp)) * SHIFT_LEFT8;
    outlineColor.r = floor(temp);

    temp = sdf.y;
    temp = temp * SHIFT_RIGHT8;
    float temp3 = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    outlineWidth = (temp - floor(temp)) * SHIFT_LEFT8;
    outlineColor.a = floor(temp);
    outlineColor /= 255.0;

    v_outlineWidth = outlineWidth / 255.0;
    v_outlineColor = outlineColor;
    v_outlineColor.a *= translucency;
#endif

    v_pickColor = pickColor;

    v_color = color;
    v_color.a *= translucency;

}
`});var Gtt,Yl,LL=S(()=>{ss();Gtt={ADD:it.FUNC_ADD,SUBTRACT:it.FUNC_SUBTRACT,REVERSE_SUBTRACT:it.FUNC_REVERSE_SUBTRACT,MIN:it.MIN,MAX:it.MAX},Yl=Object.freeze(Gtt)});var Wtt,Rr,yL=S(()=>{ss();Wtt={ZERO:it.ZERO,ONE:it.ONE,SOURCE_COLOR:it.SRC_COLOR,ONE_MINUS_SOURCE_COLOR:it.ONE_MINUS_SRC_COLOR,DESTINATION_COLOR:it.DST_COLOR,ONE_MINUS_DESTINATION_COLOR:it.ONE_MINUS_DST_COLOR,SOURCE_ALPHA:it.SRC_ALPHA,ONE_MINUS_SOURCE_ALPHA:it.ONE_MINUS_SRC_ALPHA,DESTINATION_ALPHA:it.DST_ALPHA,ONE_MINUS_DESTINATION_ALPHA:it.ONE_MINUS_DST_ALPHA,CONSTANT_COLOR:it.CONSTANT_COLOR,ONE_MINUS_CONSTANT_COLOR:it.ONE_MINUS_CONSTANT_COLOR,CONSTANT_ALPHA:it.CONSTANT_ALPHA,ONE_MINUS_CONSTANT_ALPHA:it.ONE_MINUS_CONSTANT_ALPHA,SOURCE_ALPHA_SATURATE:it.SRC_ALPHA_SATURATE},Rr=Object.freeze(Wtt)});var Dtt,Mr,km=S(()=>{LL();yL();Dtt={DISABLED:Object.freeze({enabled:!1}),ALPHA_BLEND:Object.freeze({enabled:!0,equationRgb:Yl.ADD,equationAlpha:Yl.ADD,functionSourceRgb:Rr.SOURCE_ALPHA,functionSourceAlpha:Rr.ONE,functionDestinationRgb:Rr.ONE_MINUS_SOURCE_ALPHA,functionDestinationAlpha:Rr.ONE_MINUS_SOURCE_ALPHA}),PRE_MULTIPLIED_ALPHA_BLEND:Object.freeze({enabled:!0,equationRgb:Yl.ADD,equationAlpha:Yl.ADD,functionSourceRgb:Rr.ONE,functionSourceAlpha:Rr.ONE,functionDestinationRgb:Rr.ONE_MINUS_SOURCE_ALPHA,functionDestinationAlpha:Rr.ONE_MINUS_SOURCE_ALPHA}),ADDITIVE_BLEND:Object.freeze({enabled:!0,equationRgb:Yl.ADD,equationAlpha:Yl.ADD,functionSourceRgb:Rr.SOURCE_ALPHA,functionSourceAlpha:Rr.ONE,functionDestinationRgb:Rr.ONE,functionDestinationAlpha:Rr.ONE})},Mr=Object.freeze(Dtt)});var Utt,Wn,EI=S(()=>{Utt={OPAQUE:0,TRANSLUCENT:1,OPAQUE_AND_TRANSLUCENT:2},Wn=Object.freeze(Utt)});var Mtt,po,_I=S(()=>{Mtt={FONT_SIZE:48,PADDING:10,RADIUS:8,CUTOFF:.25},po=Object.freeze(Mtt)});var Vi,ge,Ec=S(()=>{ss();Vi={UNSIGNED_BYTE:it.UNSIGNED_BYTE,UNSIGNED_SHORT:it.UNSIGNED_SHORT,UNSIGNED_INT:it.UNSIGNED_INT,FLOAT:it.FLOAT,HALF_FLOAT:it.HALF_FLOAT_OES,UNSIGNED_INT_24_8:it.UNSIGNED_INT_24_8,UNSIGNED_SHORT_4_4_4_4:it.UNSIGNED_SHORT_4_4_4_4,UNSIGNED_SHORT_5_5_5_1:it.UNSIGNED_SHORT_5_5_5_1,UNSIGNED_SHORT_5_6_5:it.UNSIGNED_SHORT_5_6_5};Vi.toWebGLConstant=function(t,e){switch(t){case Vi.UNSIGNED_BYTE:return it.UNSIGNED_BYTE;case Vi.UNSIGNED_SHORT:return it.UNSIGNED_SHORT;case Vi.UNSIGNED_INT:return it.UNSIGNED_INT;case Vi.FLOAT:return it.FLOAT;case Vi.HALF_FLOAT:return e.webgl2?it.HALF_FLOAT:it.HALF_FLOAT_OES;case Vi.UNSIGNED_INT_24_8:return it.UNSIGNED_INT_24_8;case Vi.UNSIGNED_SHORT_4_4_4_4:return it.UNSIGNED_SHORT_4_4_4_4;case Vi.UNSIGNED_SHORT_5_5_5_1:return it.UNSIGNED_SHORT_5_5_5_1;case Vi.UNSIGNED_SHORT_5_6_5:return Vi.UNSIGNED_SHORT_5_6_5}};Vi.isPacked=function(t){return t===Vi.UNSIGNED_INT_24_8||t===Vi.UNSIGNED_SHORT_4_4_4_4||t===Vi.UNSIGNED_SHORT_5_5_5_1||t===Vi.UNSIGNED_SHORT_5_6_5};Vi.sizeInBytes=function(t){switch(t){case Vi.UNSIGNED_BYTE:return 1;case Vi.UNSIGNED_SHORT:case Vi.UNSIGNED_SHORT_4_4_4_4:case Vi.UNSIGNED_SHORT_5_5_5_1:case Vi.UNSIGNED_SHORT_5_6_5:case Vi.HALF_FLOAT:return 2;case Vi.UNSIGNED_INT:case Vi.FLOAT:case Vi.UNSIGNED_INT_24_8:return 4}};Vi.validate=function(t){return t===Vi.UNSIGNED_BYTE||t===Vi.UNSIGNED_SHORT||t===Vi.UNSIGNED_INT||t===Vi.FLOAT||t===Vi.HALF_FLOAT||t===Vi.UNSIGNED_INT_24_8||t===Vi.UNSIGNED_SHORT_4_4_4_4||t===Vi.UNSIGNED_SHORT_5_5_5_1||t===Vi.UNSIGNED_SHORT_5_6_5};ge=Object.freeze(Vi)});var vt,Ie,_c=S(()=>{Ec();ss();vt={DEPTH_COMPONENT:it.DEPTH_COMPONENT,DEPTH_STENCIL:it.DEPTH_STENCIL,ALPHA:it.ALPHA,RED:it.RED,RG:it.RG,RGB:it.RGB,RGBA:it.RGBA,LUMINANCE:it.LUMINANCE,LUMINANCE_ALPHA:it.LUMINANCE_ALPHA,RGB_DXT1:it.COMPRESSED_RGB_S3TC_DXT1_EXT,RGBA_DXT1:it.COMPRESSED_RGBA_S3TC_DXT1_EXT,RGBA_DXT3:it.COMPRESSED_RGBA_S3TC_DXT3_EXT,RGBA_DXT5:it.COMPRESSED_RGBA_S3TC_DXT5_EXT,RGB_PVRTC_4BPPV1:it.COMPRESSED_RGB_PVRTC_4BPPV1_IMG,RGB_PVRTC_2BPPV1:it.COMPRESSED_RGB_PVRTC_2BPPV1_IMG,RGBA_PVRTC_4BPPV1:it.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG,RGBA_PVRTC_2BPPV1:it.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG,RGBA_ASTC:it.COMPRESSED_RGBA_ASTC_4x4_WEBGL,RGB_ETC1:it.COMPRESSED_RGB_ETC1_WEBGL,RGB8_ETC2:it.COMPRESSED_RGB8_ETC2,RGBA8_ETC2_EAC:it.COMPRESSED_RGBA8_ETC2_EAC,RGBA_BC7:it.COMPRESSED_RGBA_BPTC_UNORM};vt.componentsLength=function(t){switch(t){case vt.RGB:return 3;case vt.RGBA:return 4;case vt.LUMINANCE_ALPHA:case vt.RG:return 2;case vt.ALPHA:case vt.RED:case vt.LUMINANCE:return 1;default:return 1}};vt.validate=function(t){return t===vt.DEPTH_COMPONENT||t===vt.DEPTH_STENCIL||t===vt.ALPHA||t===vt.RED||t===vt.RG||t===vt.RGB||t===vt.RGBA||t===vt.LUMINANCE||t===vt.LUMINANCE_ALPHA||t===vt.RGB_DXT1||t===vt.RGBA_DXT1||t===vt.RGBA_DXT3||t===vt.RGBA_DXT5||t===vt.RGB_PVRTC_4BPPV1||t===vt.RGB_PVRTC_2BPPV1||t===vt.RGBA_PVRTC_4BPPV1||t===vt.RGBA_PVRTC_2BPPV1||t===vt.RGBA_ASTC||t===vt.RGB_ETC1||t===vt.RGB8_ETC2||t===vt.RGBA8_ETC2_EAC||t===vt.RGBA_BC7};vt.isColorFormat=function(t){return t===vt.RED||t===vt.ALPHA||t===vt.RGB||t===vt.RGBA||t===vt.LUMINANCE||t===vt.LUMINANCE_ALPHA};vt.isDepthFormat=function(t){return t===vt.DEPTH_COMPONENT||t===vt.DEPTH_STENCIL};vt.isCompressedFormat=function(t){return t===vt.RGB_DXT1||t===vt.RGBA_DXT1||t===vt.RGBA_DXT3||t===vt.RGBA_DXT5||t===vt.RGB_PVRTC_4BPPV1||t===vt.RGB_PVRTC_2BPPV1||t===vt.RGBA_PVRTC_4BPPV1||t===vt.RGBA_PVRTC_2BPPV1||t===vt.RGBA_ASTC||t===vt.RGB_ETC1||t===vt.RGB8_ETC2||t===vt.RGBA8_ETC2_EAC||t===vt.RGBA_BC7};vt.isDXTFormat=function(t){return t===vt.RGB_DXT1||t===vt.RGBA_DXT1||t===vt.RGBA_DXT3||t===vt.RGBA_DXT5};vt.isPVRTCFormat=function(t){return t===vt.RGB_PVRTC_4BPPV1||t===vt.RGB_PVRTC_2BPPV1||t===vt.RGBA_PVRTC_4BPPV1||t===vt.RGBA_PVRTC_2BPPV1};vt.isASTCFormat=function(t){return t===vt.RGBA_ASTC};vt.isETC1Format=function(t){return t===vt.RGB_ETC1};vt.isETC2Format=function(t){return t===vt.RGB8_ETC2||t===vt.RGBA8_ETC2_EAC};vt.isBC7Format=function(t){return t===vt.RGBA_BC7};vt.compressedTextureSizeInBytes=function(t,e,i){switch(t){case vt.RGB_DXT1:case vt.RGBA_DXT1:case vt.RGB_ETC1:case vt.RGB8_ETC2:return Math.floor((e+3)/4)*Math.floor((i+3)/4)*8;case vt.RGBA_DXT3:case vt.RGBA_DXT5:case vt.RGBA_ASTC:case vt.RGBA8_ETC2_EAC:return Math.floor((e+3)/4)*Math.floor((i+3)/4)*16;case vt.RGB_PVRTC_4BPPV1:case vt.RGBA_PVRTC_4BPPV1:return Math.floor((Math.max(e,8)*Math.max(i,8)*4+7)/8);case vt.RGB_PVRTC_2BPPV1:case vt.RGBA_PVRTC_2BPPV1:return Math.floor((Math.max(e,16)*Math.max(i,8)*2+7)/8);case vt.RGBA_BC7:return Math.ceil(e/4)*Math.ceil(i/4)*16;default:return 0}};vt.textureSizeInBytes=function(t,e,i,n){let s=vt.componentsLength(t);return ge.isPacked(e)&&(s=1),s*ge.sizeInBytes(e)*i*n};vt.alignmentInBytes=function(t,e,i){let n=vt.textureSizeInBytes(t,e,i,1)%4;return n===0?4:n===2?2:1};vt.createTypedArray=function(t,e,i,n){let s,o=ge.sizeInBytes(e);o===Uint8Array.BYTES_PER_ELEMENT?s=Uint8Array:o===Uint16Array.BYTES_PER_ELEMENT?s=Uint16Array:o===Float32Array.BYTES_PER_ELEMENT&&e===ge.FLOAT?s=Float32Array:s=Uint32Array;let r=vt.componentsLength(t)*i*n;return new s(r)};vt.flipY=function(t,e,i,n,s){if(s===1)return t;let o=vt.createTypedArray(e,i,n,s),r=vt.componentsLength(e),a=n*r;for(let h=0;h<s;++h){let A=h*n*r,d=(s-h-1)*n*r;for(let f=0;f<a;++f)o[d+f]=t[A+f]}return o};vt.toInternalFormat=function(t,e,i){if(!i.webgl2)return t;if(t===vt.DEPTH_STENCIL)return it.DEPTH24_STENCIL8;if(t===vt.DEPTH_COMPONENT){if(e===ge.UNSIGNED_SHORT)return it.DEPTH_COMPONENT16;if(e===ge.UNSIGNED_INT)return it.DEPTH_COMPONENT24}if(e===ge.FLOAT)switch(t){case vt.RGBA:return it.RGBA32F;case vt.RGB:return it.RGB32F;case vt.RG:return it.RG32F;case vt.RED:return it.R32F}if(e===ge.HALF_FLOAT)switch(t){case vt.RGBA:return it.RGBA16F;case vt.RGB:return it.RGB16F;case vt.RG:return it.RG16F;case vt.RED:return it.R16F}return t};Ie=Object.freeze(vt)});function WT(t,e,i){let n=t._gl;n.framebufferTexture2D(n.FRAMEBUFFER,e,i._target,i._texture,0)}function RI(t,e,i){let n=t._gl;n.framebufferRenderbuffer(n.FRAMEBUFFER,e,n.RENDERBUFFER,i._getRenderbuffer())}function Ta(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.context;p.defined("options.context",e);let i=e._gl,n=en.maximumColorAttachments;if(this._gl=i,this._framebuffer=i.createFramebuffer(),this._colorTextures=[],this._colorRenderbuffers=[],this._activeColorAttachments=[],this._depthTexture=void 0,this._depthRenderbuffer=void 0,this._stencilRenderbuffer=void 0,this._depthStencilTexture=void 0,this._depthStencilRenderbuffer=void 0,this.destroyAttachments=Z(t.destroyAttachments,!0),m(t.colorTextures)&&m(t.colorRenderbuffers))throw new Y("Cannot have both color texture and color renderbuffer attachments.");if(m(t.depthTexture)&&m(t.depthRenderbuffer))throw new Y("Cannot have both a depth texture and depth renderbuffer attachment.");if(m(t.depthStencilTexture)&&m(t.depthStencilRenderbuffer))throw new Y("Cannot have both a depth-stencil texture and depth-stencil renderbuffer attachment.");let s=m(t.depthTexture)||m(t.depthRenderbuffer),o=m(t.depthStencilTexture)||m(t.depthStencilRenderbuffer);if(s&&o)throw new Y("Cannot have both a depth and depth-stencil attachment.");if(m(t.stencilRenderbuffer)&&o)throw new Y("Cannot have both a stencil and depth-stencil attachment.");if(s&&m(t.stencilRenderbuffer))throw new Y("Cannot have both a depth and stencil attachment.");this._bind();let r,a,h,A,d;if(m(t.colorTextures)){let f=t.colorTextures;if(A=this._colorTextures.length=this._activeColorAttachments.length=f.length,A>n)throw new Y("The number of color attachments exceeds the number supported.");for(h=0;h<A;++h){if(r=f[h],!Ie.isColorFormat(r.pixelFormat))throw new Y("The color-texture pixel-format must be a color format.");if(r.pixelDatatype===ge.FLOAT&&!e.colorBufferFloat)throw new Y("The color texture pixel datatype is FLOAT and the WebGL implementation does not support the EXT_color_buffer_float or WEBGL_color_buffer_float extensions. See Context.colorBufferFloat.");if(r.pixelDatatype===ge.HALF_FLOAT&&!e.colorBufferHalfFloat)throw new Y("The color texture pixel datatype is HALF_FLOAT and the WebGL implementation does not support the EXT_color_buffer_half_float extension. See Context.colorBufferHalfFloat.");d=this._gl.COLOR_ATTACHMENT0+h,WT(this,d,r),this._activeColorAttachments[h]=d,this._colorTextures[h]=r}}if(m(t.colorRenderbuffers)){let f=t.colorRenderbuffers;if(A=this._colorRenderbuffers.length=this._activeColorAttachments.length=f.length,A>n)throw new Y("The number of color attachments exceeds the number supported.");for(h=0;h<A;++h)a=f[h],d=this._gl.COLOR_ATTACHMENT0+h,RI(this,d,a),this._activeColorAttachments[h]=d,this._colorRenderbuffers[h]=a}if(m(t.depthTexture)){if(r=t.depthTexture,r.pixelFormat!==Ie.DEPTH_COMPONENT)throw new Y("The depth-texture pixel-format must be DEPTH_COMPONENT.");WT(this,this._gl.DEPTH_ATTACHMENT,r),this._depthTexture=r}if(m(t.depthRenderbuffer)&&(a=t.depthRenderbuffer,RI(this,this._gl.DEPTH_ATTACHMENT,a),this._depthRenderbuffer=a),m(t.stencilRenderbuffer)&&(a=t.stencilRenderbuffer,RI(this,this._gl.STENCIL_ATTACHMENT,a),this._stencilRenderbuffer=a),m(t.depthStencilTexture)){if(r=t.depthStencilTexture,r.pixelFormat!==Ie.DEPTH_STENCIL)throw new Y("The depth-stencil pixel-format must be DEPTH_STENCIL.");WT(this,this._gl.DEPTH_STENCIL_ATTACHMENT,r),this._depthStencilTexture=r}m(t.depthStencilRenderbuffer)&&(a=t.depthStencilRenderbuffer,RI(this,this._gl.DEPTH_STENCIL_ATTACHMENT,a),this._depthStencilRenderbuffer=a),this._unBind()}var wL,xL=S(()=>{ae();Ft();mt();Ws();Ot();_c();ga();Ec();Object.defineProperties(Ta.prototype,{status:{get:function(){this._bind();let t=this._gl.checkFramebufferStatus(this._gl.FRAMEBUFFER);return this._unBind(),t}},numberOfColorAttachments:{get:function(){return this._activeColorAttachments.length}},depthTexture:{get:function(){return this._depthTexture}},depthRenderbuffer:{get:function(){return this._depthRenderbuffer}},stencilRenderbuffer:{get:function(){return this._stencilRenderbuffer}},depthStencilTexture:{get:function(){return this._depthStencilTexture}},depthStencilRenderbuffer:{get:function(){return this._depthStencilRenderbuffer}},hasDepthAttachment:{get:function(){return!!(this.depthTexture||this.depthRenderbuffer||this.depthStencilTexture||this.depthStencilRenderbuffer)}}});Ta.prototype._bind=function(){let t=this._gl;t.bindFramebuffer(t.FRAMEBUFFER,this._framebuffer)};Ta.prototype._unBind=function(){let t=this._gl;t.bindFramebuffer(t.FRAMEBUFFER,null)};Ta.prototype.bindDraw=function(){let t=this._gl;t.bindFramebuffer(t.DRAW_FRAMEBUFFER,this._framebuffer)};Ta.prototype.bindRead=function(){let t=this._gl;t.bindFramebuffer(t.READ_FRAMEBUFFER,this._framebuffer)};Ta.prototype._getActiveColorAttachments=function(){return this._activeColorAttachments};Ta.prototype.getColorTexture=function(t){if(!m(t)||t<0||t>=this._colorTextures.length)throw new Y("index is required, must be greater than or equal to zero and must be less than the number of color attachments.");return this._colorTextures[t]};Ta.prototype.getColorRenderbuffer=function(t){if(!m(t)||t<0||t>=this._colorRenderbuffers.length)throw new Y("index is required, must be greater than or equal to zero and must be less than the number of color attachments.");return this._colorRenderbuffers[t]};Ta.prototype.isDestroyed=function(){return!1};Ta.prototype.destroy=function(){if(this.destroyAttachments){let t=0,e=this._colorTextures,i=e.length;for(;t<i;++t){let s=e[t];m(s)&&s.destroy()}let n=this._colorRenderbuffers;for(i=n.length,t=0;t<i;++t){let s=n[t];m(s)&&s.destroy()}this._depthTexture=this._depthTexture&&this._depthTexture.destroy(),this._depthRenderbuffer=this._depthRenderbuffer&&this._depthRenderbuffer.destroy(),this._stencilRenderbuffer=this._stencilRenderbuffer&&this._stencilRenderbuffer.destroy(),this._depthStencilTexture=this._depthStencilTexture&&this._depthStencilTexture.destroy(),this._depthStencilRenderbuffer=this._depthStencilRenderbuffer&&this._depthStencilRenderbuffer.destroy()}return this._gl.deleteFramebuffer(this._framebuffer),li(this)};wL=Ta});var ZI,Lm,DT=S(()=>{ss();ZI={DONT_CARE:it.DONT_CARE,FASTEST:it.FASTEST,NICEST:it.NICEST,validate:function(t){return t===ZI.DONT_CARE||t===ZI.FASTEST||t===ZI.NICEST}},Lm=Object.freeze(ZI)});var II,Na,NE=S(()=>{ss();II={NEAREST:it.NEAREST,LINEAR:it.LINEAR};II.validate=function(t){return t===II.NEAREST||t===II.LINEAR};Na=Object.freeze(II)});var Rc,_s,FE=S(()=>{ss();Rc={NEAREST:it.NEAREST,LINEAR:it.LINEAR,NEAREST_MIPMAP_NEAREST:it.NEAREST_MIPMAP_NEAREST,LINEAR_MIPMAP_NEAREST:it.LINEAR_MIPMAP_NEAREST,NEAREST_MIPMAP_LINEAR:it.NEAREST_MIPMAP_LINEAR,LINEAR_MIPMAP_LINEAR:it.LINEAR_MIPMAP_LINEAR};Rc.validate=function(t){return t===Rc.NEAREST||t===Rc.LINEAR||t===Rc.NEAREST_MIPMAP_NEAREST||t===Rc.LINEAR_MIPMAP_NEAREST||t===Rc.NEAREST_MIPMAP_LINEAR||t===Rc.LINEAR_MIPMAP_LINEAR};_s=Object.freeze(Rc)});var pI,Vl,PL=S(()=>{ss();pI={CLAMP_TO_EDGE:it.CLAMP_TO_EDGE,REPEAT:it.REPEAT,MIRRORED_REPEAT:it.MIRRORED_REPEAT,validate:function(t){return t===pI.CLAMP_TO_EDGE||t===pI.REPEAT||t===pI.MIRRORED_REPEAT}},Vl=Object.freeze(pI)});function bE(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.wrapS,Vl.CLAMP_TO_EDGE),i=Z(t.wrapT,Vl.CLAMP_TO_EDGE),n=Z(t.minificationFilter,_s.LINEAR),s=Z(t.magnificationFilter,Na.LINEAR),o=m(t.maximumAnisotropy)?t.maximumAnisotropy:1;if(!Vl.validate(e))throw new Y("Invalid sampler.wrapS.");if(!Vl.validate(i))throw new Y("Invalid sampler.wrapT.");if(!_s.validate(n))throw new Y("Invalid sampler.minificationFilter.");if(!Na.validate(s))throw new Y("Invalid sampler.magnificationFilter.");p.typeOf.number.greaterThanOrEquals("maximumAnisotropy",o,1),this._wrapS=e,this._wrapT=i,this._minificationFilter=n,this._magnificationFilter=s,this._maximumAnisotropy=o}var ZA,YE=S(()=>{ae();Ft();mt();Ot();NE();FE();PL();Object.defineProperties(bE.prototype,{wrapS:{get:function(){return this._wrapS}},wrapT:{get:function(){return this._wrapT}},minificationFilter:{get:function(){return this._minificationFilter}},magnificationFilter:{get:function(){return this._magnificationFilter}},maximumAnisotropy:{get:function(){return this._maximumAnisotropy}}});bE.equals=function(t,e){return t===e||m(t)&&m(e)&&t._wrapS===e._wrapS&&t._wrapT===e._wrapT&&t._minificationFilter===e._minificationFilter&&t._magnificationFilter===e._magnificationFilter&&t._maximumAnisotropy===e._maximumAnisotropy};bE.NEAREST=Object.freeze(new bE({wrapS:Vl.CLAMP_TO_EDGE,wrapT:Vl.CLAMP_TO_EDGE,minificationFilter:_s.NEAREST,magnificationFilter:Na.NEAREST}));ZA=bE});function Fa(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context);let e=t.context,i=t.width,n=t.height,s=t.source;m(s)&&(m(i)||(i=Z(s.videoWidth,s.width)),m(n)||(n=Z(s.videoHeight,s.height)));let o=Z(t.pixelFormat,Ie.RGBA),r=Z(t.pixelDatatype,ge.UNSIGNED_BYTE),a=Ie.toInternalFormat(o,r,e),h=Ie.isCompressedFormat(a);if(!m(i)||!m(n))throw new Y("options requires a source field to create an initialized texture or width and height fields to create a blank texture.");if(p.typeOf.number.greaterThan("width",i,0),i>en.maximumTextureSize)throw new Y(`Width must be less than or equal to the maximum texture size (${en.maximumTextureSize}).  Check maximumTextureSize.`);if(p.typeOf.number.greaterThan("height",n,0),n>en.maximumTextureSize)throw new Y(`Height must be less than or equal to the maximum texture size (${en.maximumTextureSize}).  Check maximumTextureSize.`);if(!Ie.validate(o))throw new Y("Invalid options.pixelFormat.");if(!h&&!ge.validate(r))throw new Y("Invalid options.pixelDatatype.");if(o===Ie.DEPTH_COMPONENT&&r!==ge.UNSIGNED_SHORT&&r!==ge.UNSIGNED_INT)throw new Y("When options.pixelFormat is DEPTH_COMPONENT, options.pixelDatatype must be UNSIGNED_SHORT or UNSIGNED_INT.");if(o===Ie.DEPTH_STENCIL&&r!==ge.UNSIGNED_INT_24_8)throw new Y("When options.pixelFormat is DEPTH_STENCIL, options.pixelDatatype must be UNSIGNED_INT_24_8.");if(r===ge.FLOAT&&!e.floatingPointTexture)throw new Y("When options.pixelDatatype is FLOAT, this WebGL implementation must support the OES_texture_float extension.  Check context.floatingPointTexture.");if(r===ge.HALF_FLOAT&&!e.halfFloatingPointTexture)throw new Y("When options.pixelDatatype is HALF_FLOAT, this WebGL implementation must support the OES_texture_half_float extension. Check context.halfFloatingPointTexture.");if(Ie.isDepthFormat(o)){if(m(s))throw new Y("When options.pixelFormat is DEPTH_COMPONENT or DEPTH_STENCIL, source cannot be provided.");if(!e.depthTexture)throw new Y("When options.pixelFormat is DEPTH_COMPONENT or DEPTH_STENCIL, this WebGL implementation must support WEBGL_depth_texture.  Check context.depthTexture.")}if(h){if(!m(s)||!m(s.arrayBufferView))throw new Y("When options.pixelFormat is compressed, options.source.arrayBufferView must be defined.");if(Ie.isDXTFormat(a)&&!e.s3tc)throw new Y("When options.pixelFormat is S3TC compressed, this WebGL implementation must support the WEBGL_compressed_texture_s3tc extension. Check context.s3tc.");if(Ie.isPVRTCFormat(a)&&!e.pvrtc)throw new Y("When options.pixelFormat is PVRTC compressed, this WebGL implementation must support the WEBGL_compressed_texture_pvrtc extension. Check context.pvrtc.");if(Ie.isASTCFormat(a)&&!e.astc)throw new Y("When options.pixelFormat is ASTC compressed, this WebGL implementation must support the WEBGL_compressed_texture_astc extension. Check context.astc.");if(Ie.isETC2Format(a)&&!e.etc)throw new Y("When options.pixelFormat is ETC2 compressed, this WebGL implementation must support the WEBGL_compressed_texture_etc extension. Check context.etc.");if(Ie.isETC1Format(a)&&!e.etc1)throw new Y("When options.pixelFormat is ETC1 compressed, this WebGL implementation must support the WEBGL_compressed_texture_etc1 extension. Check context.etc1.");if(Ie.isBC7Format(a)&&!e.bc7)throw new Y("When options.pixelFormat is BC7 compressed, this WebGL implementation must support the EXT_texture_compression_bptc extension. Check context.bc7.");if(Ie.compressedTextureSizeInBytes(a,i,n)!==s.arrayBufferView.byteLength)throw new Y("The byte length of the array buffer is invalid for the compressed texture with the given width and height.")}let A=t.preMultiplyAlpha||o===Ie.RGB||o===Ie.LUMINANCE,d=Z(t.flipY,!0),f=Z(t.skipColorSpaceConversion,!1),E=!0,_=e._gl,R=_.TEXTURE_2D,I=_.createTexture();_.activeTexture(_.TEXTURE0),_.bindTexture(R,I);let C=4;if(m(s)&&m(s.arrayBufferView)&&!h&&(C=Ie.alignmentInBytes(o,r,i)),_.pixelStorei(_.UNPACK_ALIGNMENT,C),f?_.pixelStorei(_.UNPACK_COLORSPACE_CONVERSION_WEBGL,_.NONE):_.pixelStorei(_.UNPACK_COLORSPACE_CONVERSION_WEBGL,_.BROWSER_DEFAULT_WEBGL),m(s))if(m(s.arrayBufferView)){_.pixelStorei(_.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),_.pixelStorei(_.UNPACK_FLIP_Y_WEBGL,!1);let T=s.arrayBufferView,b,F,B;if(h){if(_.compressedTexImage2D(R,0,a,i,n,0,T),m(s.mipLevels))for(F=i,B=n,b=0;b<s.mipLevels.length;++b)F=Math.floor(F/2)|0,F<1&&(F=1),B=Math.floor(B/2)|0,B<1&&(B=1),_.compressedTexImage2D(R,b+1,a,F,B,0,s.mipLevels[b])}else if(d&&(T=Ie.flipY(T,o,r,i,n)),_.texImage2D(R,0,a,i,n,0,o,ge.toWebGLConstant(r,e),T),m(s.mipLevels))for(F=i,B=n,b=0;b<s.mipLevels.length;++b)F=Math.floor(F/2)|0,F<1&&(F=1),B=Math.floor(B/2)|0,B<1&&(B=1),_.texImage2D(R,b+1,a,F,B,0,o,ge.toWebGLConstant(r,e),s.mipLevels[b])}else m(s.framebuffer)?(_.pixelStorei(_.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),_.pixelStorei(_.UNPACK_FLIP_Y_WEBGL,!1),s.framebuffer!==e.defaultFramebuffer&&s.framebuffer._bind(),_.copyTexImage2D(R,0,a,s.xOffset,s.yOffset,i,n,0),s.framebuffer!==e.defaultFramebuffer&&s.framebuffer._unBind()):(_.pixelStorei(_.UNPACK_PREMULTIPLY_ALPHA_WEBGL,A),_.pixelStorei(_.UNPACK_FLIP_Y_WEBGL,d),_.texImage2D(R,0,a,o,ge.toWebGLConstant(r,e),s));else _.texImage2D(R,0,a,i,n,0,o,ge.toWebGLConstant(r,e),null),E=!1;_.bindTexture(R,null);let N;h?N=Ie.compressedTextureSizeInBytes(o,i,n):N=Ie.textureSizeInBytes(o,r,i,n),this._id=Bs(),this._context=e,this._textureFilterAnisotropic=e._textureFilterAnisotropic,this._textureTarget=R,this._texture=I,this._internalFormat=a,this._pixelFormat=o,this._pixelDatatype=r,this._width=i,this._height=n,this._dimensions=new nt(i,n),this._hasMipmap=!1,this._sizeInBytes=N,this._preMultiplyAlpha=A,this._flipY=d,this._initialized=E,this._sampler=void 0,this.sampler=m(t.sampler)?t.sampler:new ZA}var ba,uI=S(()=>{Xe();ae();ih();Ft();mt();Ws();Ot();_e();_c();ga();DT();Ec();YE();NE();FE();Fa.create=function(t){return new Fa(t)};Fa.fromFramebuffer=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context);let e=t.context,i=e._gl,n=Z(t.pixelFormat,Ie.RGB),s=Z(t.framebufferXOffset,0),o=Z(t.framebufferYOffset,0),r=Z(t.width,i.drawingBufferWidth),a=Z(t.height,i.drawingBufferHeight),h=t.framebuffer;if(!Ie.validate(n))throw new Y("Invalid pixelFormat.");if(Ie.isDepthFormat(n)||Ie.isCompressedFormat(n))throw new Y("pixelFormat cannot be DEPTH_COMPONENT, DEPTH_STENCIL or a compressed format.");if(p.defined("options.context",t.context),p.typeOf.number.greaterThanOrEquals("framebufferXOffset",s,0),p.typeOf.number.greaterThanOrEquals("framebufferYOffset",o,0),s+r>i.drawingBufferWidth)throw new Y("framebufferXOffset + width must be less than or equal to drawingBufferWidth");if(o+a>i.drawingBufferHeight)throw new Y("framebufferYOffset + height must be less than or equal to drawingBufferHeight.");return new Fa({context:e,width:r,height:a,pixelFormat:n,source:{framebuffer:m(h)?h:e.defaultFramebuffer,xOffset:s,yOffset:o,width:r,height:a}})};Object.defineProperties(Fa.prototype,{id:{get:function(){return this._id}},sampler:{get:function(){return this._sampler},set:function(t){let e=t.minificationFilter,i=t.magnificationFilter,n=this._context,s=this._pixelFormat,o=this._pixelDatatype,r=e===_s.NEAREST_MIPMAP_NEAREST||e===_s.NEAREST_MIPMAP_LINEAR||e===_s.LINEAR_MIPMAP_NEAREST||e===_s.LINEAR_MIPMAP_LINEAR;(o===ge.FLOAT&&!n.textureFloatLinear||o===ge.HALF_FLOAT&&!n.textureHalfFloatLinear)&&(e=r?_s.NEAREST_MIPMAP_NEAREST:_s.NEAREST,i=Na.NEAREST),n.webgl2&&Ie.isDepthFormat(s)&&(e=_s.NEAREST,i=Na.NEAREST);let a=n._gl,h=this._textureTarget;a.activeTexture(a.TEXTURE0),a.bindTexture(h,this._texture),a.texParameteri(h,a.TEXTURE_MIN_FILTER,e),a.texParameteri(h,a.TEXTURE_MAG_FILTER,i),a.texParameteri(h,a.TEXTURE_WRAP_S,t.wrapS),a.texParameteri(h,a.TEXTURE_WRAP_T,t.wrapT),m(this._textureFilterAnisotropic)&&a.texParameteri(h,this._textureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT,t.maximumAnisotropy),a.bindTexture(h,null),this._sampler=t}},pixelFormat:{get:function(){return this._pixelFormat}},pixelDatatype:{get:function(){return this._pixelDatatype}},dimensions:{get:function(){return this._dimensions}},preMultiplyAlpha:{get:function(){return this._preMultiplyAlpha}},flipY:{get:function(){return this._flipY}},width:{get:function(){return this._width}},height:{get:function(){return this._height}},sizeInBytes:{get:function(){return this._hasMipmap?Math.floor(this._sizeInBytes*4/3):this._sizeInBytes}},_target:{get:function(){return this._textureTarget}}});Fa.prototype.copyFrom=function(t){p.defined("options",t);let e=Z(t.xOffset,0),i=Z(t.yOffset,0);if(p.defined("options.source",t.source),Ie.isDepthFormat(this._pixelFormat))throw new Y("Cannot call copyFrom when the texture pixel format is DEPTH_COMPONENT or DEPTH_STENCIL.");if(Ie.isCompressedFormat(this._pixelFormat))throw new Y("Cannot call copyFrom with a compressed texture pixel format.");p.typeOf.number.greaterThanOrEquals("xOffset",e,0),p.typeOf.number.greaterThanOrEquals("yOffset",i,0),p.typeOf.number.lessThanOrEquals("xOffset + options.source.width",e+t.source.width,this._width),p.typeOf.number.lessThanOrEquals("yOffset + options.source.height",i+t.source.height,this._height);let n=t.source,s=this._context,o=s._gl,r=this._textureTarget;o.activeTexture(o.TEXTURE0),o.bindTexture(r,this._texture);let a=n.width,h=n.height,A=n.arrayBufferView,d=this._width,f=this._height,E=this._internalFormat,_=this._pixelFormat,R=this._pixelDatatype,I=this._preMultiplyAlpha,C=this._flipY,N=Z(t.skipColorSpaceConversion,!1),T=4;m(A)&&(T=Ie.alignmentInBytes(_,R,a)),o.pixelStorei(o.UNPACK_ALIGNMENT,T),N?o.pixelStorei(o.UNPACK_COLORSPACE_CONVERSION_WEBGL,o.NONE):o.pixelStorei(o.UNPACK_COLORSPACE_CONVERSION_WEBGL,o.BROWSER_DEFAULT_WEBGL);let b=!1;if(!this._initialized){if(e===0&&i===0&&a===d&&h===f)m(A)?(o.pixelStorei(o.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),o.pixelStorei(o.UNPACK_FLIP_Y_WEBGL,!1),C&&(A=Ie.flipY(A,_,R,d,f)),o.texImage2D(r,0,E,d,f,0,_,ge.toWebGLConstant(R,s),A)):(o.pixelStorei(o.UNPACK_PREMULTIPLY_ALPHA_WEBGL,I),o.pixelStorei(o.UNPACK_FLIP_Y_WEBGL,C),o.texImage2D(r,0,E,_,ge.toWebGLConstant(R,s),n)),b=!0;else{o.pixelStorei(o.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),o.pixelStorei(o.UNPACK_FLIP_Y_WEBGL,!1);let F=Ie.createTypedArray(_,R,d,f);o.texImage2D(r,0,E,d,f,0,_,ge.toWebGLConstant(R,s),F)}this._initialized=!0}b||(m(A)?(o.pixelStorei(o.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),o.pixelStorei(o.UNPACK_FLIP_Y_WEBGL,!1),C&&(A=Ie.flipY(A,_,R,a,h)),o.texSubImage2D(r,0,e,i,a,h,_,ge.toWebGLConstant(R,s),A)):(o.pixelStorei(o.UNPACK_PREMULTIPLY_ALPHA_WEBGL,I),o.pixelStorei(o.UNPACK_FLIP_Y_WEBGL,C),o.texSubImage2D(r,0,e,i,_,ge.toWebGLConstant(R,s),n))),o.bindTexture(r,null)};Fa.prototype.copyFromFramebuffer=function(t,e,i,n,s,o){if(t=Z(t,0),e=Z(e,0),i=Z(i,0),n=Z(n,0),s=Z(s,this._width),o=Z(o,this._height),Ie.isDepthFormat(this._pixelFormat))throw new Y("Cannot call copyFromFramebuffer when the texture pixel format is DEPTH_COMPONENT or DEPTH_STENCIL.");if(this._pixelDatatype===ge.FLOAT)throw new Y("Cannot call copyFromFramebuffer when the texture pixel data type is FLOAT.");if(this._pixelDatatype===ge.HALF_FLOAT)throw new Y("Cannot call copyFromFramebuffer when the texture pixel data type is HALF_FLOAT.");if(Ie.isCompressedFormat(this._pixelFormat))throw new Y("Cannot call copyFrom with a compressed texture pixel format.");p.typeOf.number.greaterThanOrEquals("xOffset",t,0),p.typeOf.number.greaterThanOrEquals("yOffset",e,0),p.typeOf.number.greaterThanOrEquals("framebufferXOffset",i,0),p.typeOf.number.greaterThanOrEquals("framebufferYOffset",n,0),p.typeOf.number.lessThanOrEquals("xOffset + width",t+s,this._width),p.typeOf.number.lessThanOrEquals("yOffset + height",e+o,this._height);let r=this._context._gl,a=this._textureTarget;r.activeTexture(r.TEXTURE0),r.bindTexture(a,this._texture),r.copyTexSubImage2D(a,0,t,e,i,n,s,o),r.bindTexture(a,null),this._initialized=!0};Fa.prototype.generateMipmap=function(t){if(t=Z(t,Lm.DONT_CARE),Ie.isDepthFormat(this._pixelFormat))throw new Y("Cannot call generateMipmap when the texture pixel format is DEPTH_COMPONENT or DEPTH_STENCIL.");if(Ie.isCompressedFormat(this._pixelFormat))throw new Y("Cannot call generateMipmap with a compressed pixel format.");if(!this._context.webgl2){if(this._width>1&&!L.isPowerOfTwo(this._width))throw new Y("width must be a power of two to call generateMipmap() in a WebGL1 context.");if(this._height>1&&!L.isPowerOfTwo(this._height))throw new Y("height must be a power of two to call generateMipmap() in a WebGL1 context.")}if(!Lm.validate(t))throw new Y("hint is invalid.");this._hasMipmap=!0;let e=this._context._gl,i=this._textureTarget;e.hint(e.GENERATE_MIPMAP_HINT,t),e.activeTexture(e.TEXTURE0),e.bindTexture(i,this._texture),e.generateMipmap(i),e.bindTexture(i,null)};Fa.prototype.isDestroyed=function(){return!1};Fa.prototype.destroy=function(){return this._context._gl.deleteTexture(this._texture),li(this)};ba=Fa});function ch(t,e,i,n,s){this.bottomLeft=Z(t,nt.ZERO),this.topRight=Z(e,nt.ZERO),this.childNode1=i,this.childNode2=n,this.imageIndex=s}function Zc(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.borderWidthInPixels,1),i=Z(t.initialSize,Qtt);if(!m(t.context))throw new Y("context is required.");if(e<0)throw new Y("borderWidthInPixels must be greater than or equal to zero.");if(i.x<1||i.y<1)throw new Y("initialSize must be greater than zero.");this._context=t.context,this._pixelFormat=Z(t.pixelFormat,Ie.RGBA),this._borderWidthInPixels=e,this._textureCoordinates=[],this._guid=Bs(),this._idHash={},this._indexHash={},this._initialSize=i,this._root=void 0}function ktt(t,e){let i=t._context,n=t.numberOfImages,s=2,o=t._borderWidthInPixels;if(n>0){let r=t._texture.width,a=t._texture.height,h=s*(r+e.width+o),A=s*(a+e.height+o),d=r/h,f=a/A,E=new ch(new nt(r+o,o),new nt(h,a)),_=new ch(new nt,new nt(h,a),t._root,E),R=new ch(new nt(o,a+o),new nt(h,A)),I=new ch(new nt,new nt(h,A),_,R);for(let T=0;T<t._textureCoordinates.length;T++){let b=t._textureCoordinates[T];m(b)&&(b.x*=d,b.y*=f,b.width*=d,b.height*=f)}let C=new ba({context:t._context,width:h,height:A,pixelFormat:t._pixelFormat}),N=new wL({context:i,colorTextures:[t._texture],destroyAttachments:!1});N._bind(),C.copyFromFramebuffer(0,0,0,0,h,A),N._unBind(),N.destroy(),t._texture=t._texture&&t._texture.destroy(),t._texture=C,t._root=I}else{let r=s*(e.width+2*o),a=s*(e.height+2*o);r<t._initialSize.x&&(r=t._initialSize.x),a<t._initialSize.y&&(a=t._initialSize.y),t._texture=t._texture&&t._texture.destroy(),t._texture=new ba({context:t._context,width:r,height:a,pixelFormat:t._pixelFormat}),t._root=new ch(new nt(o,o),new nt(r,a))}}function CI(t,e,i){if(m(e)){if(!m(e.childNode1)&&!m(e.childNode2)){if(m(e.imageIndex))return;let n=e.topRight.x-e.bottomLeft.x,s=e.topRight.y-e.bottomLeft.y,o=n-i.width,r=s-i.height;if(o<0||r<0)return;if(o===0&&r===0)return e;if(o>r){e.childNode1=new ch(new nt(e.bottomLeft.x,e.bottomLeft.y),new nt(e.bottomLeft.x+i.width,e.topRight.y));let a=e.bottomLeft.x+i.width+t._borderWidthInPixels;a<e.topRight.x&&(e.childNode2=new ch(new nt(a,e.bottomLeft.y),new nt(e.topRight.x,e.topRight.y)))}else{e.childNode1=new ch(new nt(e.bottomLeft.x,e.bottomLeft.y),new nt(e.topRight.x,e.bottomLeft.y+i.height));let a=e.bottomLeft.y+i.height+t._borderWidthInPixels;a<e.topRight.y&&(e.childNode2=new ch(new nt(e.bottomLeft.x,a),new nt(e.topRight.x,e.topRight.y)))}return CI(t,e.childNode1,i)}return CI(t,e.childNode1,i)||CI(t,e.childNode2,i)}}function JL(t,e,i){let n=CI(t,t._root,e);if(m(n)){n.imageIndex=i;let s=t._texture.width,o=t._texture.height,r=n.topRight.x-n.bottomLeft.x,a=n.topRight.y-n.bottomLeft.y,h=n.bottomLeft.x/s,A=n.bottomLeft.y/o,d=r/s,f=a/o;t._textureCoordinates[i]=new mi(h,A,d,f),t._texture.copyFrom({source:e,xOffset:n.bottomLeft.x,yOffset:n.bottomLeft.y})}else ktt(t,e),JL(t,e,i);t._guid=Bs()}function jL(t,e){if(!m(t)||t.isDestroyed())return-1;let i=t.numberOfImages;return JL(t,e,i),i}var Qtt,VE,UT=S(()=>{Er();Xe();ih();Ft();mt();Ws();Ot();_c();Ia();Ps();xL();uI();Qtt=new nt(16,16);Object.defineProperties(Zc.prototype,{borderWidthInPixels:{get:function(){return this._borderWidthInPixels}},textureCoordinates:{get:function(){return this._textureCoordinates}},texture:{get:function(){return m(this._texture)||(this._texture=new ba({context:this._context,width:this._initialSize.x,height:this._initialSize.y,pixelFormat:this._pixelFormat})),this._texture}},numberOfImages:{get:function(){return this._textureCoordinates.length}},guid:{get:function(){return this._guid}}});Zc.prototype.getImageIndex=function(t){if(!m(t))throw new Y("id is required.");return this._indexHash[t]};Zc.prototype.addImageSync=function(t,e){if(!m(t))throw new Y("id is required.");if(!m(e))throw new Y("image is required.");let i=this._indexHash[t];return m(i)||(i=jL(this,e),this._idHash[t]=Promise.resolve(i),this._indexHash[t]=i),i};Zc.prototype.addImage=function(t,e){if(!m(t))throw new Y("id is required.");if(!m(e))throw new Y("image is required.");let i=this._idHash[t];if(m(i))return i;if(typeof e=="function"){if(e=e(t),!m(e))throw new Y("image is required.")}else(typeof e=="string"||e instanceof tn)&&(e=tn.createIfNeeded(e).fetchImage());let n=this;return i=Promise.resolve(e).then(function(s){let o=jL(n,s);return n._indexHash[t]=o,o}),this._idHash[t]=i,i};Zc.prototype.addSubRegion=function(t,e){if(!m(t))throw new Y("id is required.");if(!m(e))throw new Y("subRegion is required.");let i=this._idHash[t];if(!m(i))throw new ke(`image with id "${t}" not found in the atlas.`);let n=this;return Promise.resolve(i).then(function(s){if(s===-1)return-1;let o=n._texture.width,r=n._texture.height,a=n._textureCoordinates[s],h=a.x+e.x/o,A=a.y+e.y/r,d=e.width/o,f=e.height/r,E=n._textureCoordinates.push(new mi(h,A,d,f))-1;return n._indexHash[t]=E,n._guid=Bs(),E})};Zc.prototype.isDestroyed=function(){return!1};Zc.prototype.destroy=function(){return this._texture=this._texture&&this._texture.destroy(),li(this)};VE=Zc});function Lr(t){t=Z(t,Z.EMPTY_OBJECT),this._scene=t.scene,this._batchTable=t.batchTable,this._textureAtlas=void 0,this._textureAtlasGUID=void 0,this._destroyTextureAtlas=!0,this._sp=void 0,this._spTranslucent=void 0,this._rsOpaque=void 0,this._rsTranslucent=void 0,this._vaf=void 0,this._billboards=[],this._billboardsToUpdate=[],this._billboardsToUpdateIndex=0,this._billboardsRemoved=!1,this._createVertexArray=!1,this._shaderRotation=!1,this._compiledShaderRotation=!1,this._shaderAlignedAxis=!1,this._compiledShaderAlignedAxis=!1,this._shaderScaleByDistance=!1,this._compiledShaderScaleByDistance=!1,this._shaderTranslucencyByDistance=!1,this._compiledShaderTranslucencyByDistance=!1,this._shaderPixelOffsetScaleByDistance=!1,this._compiledShaderPixelOffsetScaleByDistance=!1,this._shaderDistanceDisplayCondition=!1,this._compiledShaderDistanceDisplayCondition=!1,this._shaderDisableDepthDistance=!1,this._compiledShaderDisableDepthDistance=!1,this._shaderClampToGround=!1,this._compiledShaderClampToGround=!1,this._propertiesChanged=new Uint32Array(xT),this._maxSize=0,this._maxEyeOffset=0,this._maxScale=1,this._maxPixelOffset=0,this._allHorizontalCenter=!0,this._allVerticalCenter=!0,this._allSizedInMeters=!0,this._baseVolume=new Nt,this._baseVolumeWC=new Nt,this._baseVolume2D=new Nt,this._boundingVolume=new Nt,this._boundingVolumeDirty=!1,this._colorCommands=[],this.show=Z(t.show,!0),this.modelMatrix=at.clone(Z(t.modelMatrix,at.IDENTITY)),this._modelMatrix=at.clone(at.IDENTITY),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.debugShowTextureAtlas=Z(t.debugShowTextureAtlas,!1),this.blendOption=Z(t.blendOption,Wn.OPAQUE_AND_TRANSLUCENT),this._blendOption=void 0,this._mode=ye.SCENE3D,this._buffersUsage=[ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW],this._highlightColor=Zt.clone(Zt.WHITE);let e=this;this._uniforms={u_atlas:function(){return e._textureAtlas.texture},u_highlightColor:function(){return e._highlightColor}};let i=this._scene;m(i)&&m(i.terrainProviderChanged)&&(this._removeCallbackFunc=i.terrainProviderChanged.addEventListener(function(){let n=this._billboards,s=n.length;for(let o=0;o<s;++o)m(n[o])&&n[o]._updateClamping()},this))}function ey(t){let e=t.length;for(let i=0;i<e;++i)t[i]&&t[i]._destroy()}function PT(t){if(t._billboardsRemoved){t._billboardsRemoved=!1;let e=[],i=t._billboards,n=i.length;for(let s=0,o=0;s<n;++s){let r=i[s];m(r)&&(r._index=o++,e.push(r))}t._billboards=e}}function Ktt(t){let i=t.cache.billboardCollection_indexBufferBatched;if(m(i))return i;let n=16384*6-6,s=new Uint16Array(n);for(let o=0,r=0;o<n;o+=6,r+=4)s[o]=r,s[o+1]=r+1,s[o+2]=r+2,s[o+3]=r+0,s[o+4]=r+2,s[o+5]=r+3;return i=Ca.createIndexBuffer({context:t,typedArray:s,usage:ai.STATIC_DRAW,indexDatatype:te.UNSIGNED_SHORT}),i.vertexArrayDestroyable=!1,t.cache.billboardCollection_indexBufferBatched=i,i}function Xtt(t){let e=t.cache.billboardCollection_indexBufferInstanced;return m(e)||(e=Ca.createIndexBuffer({context:t,typedArray:new Uint16Array([0,1,2,0,2,3]),usage:ai.STATIC_DRAW,indexDatatype:te.UNSIGNED_SHORT}),e.vertexArrayDestroyable=!1,t.cache.billboardCollection_indexBufferInstanced=e),e}function qtt(t){let e=t.cache.billboardCollection_vertexBufferInstanced;return m(e)||(e=Ca.createVertexBuffer({context:t,typedArray:new Float32Array([0,0,1,0,1,1,0,1]),usage:ai.STATIC_DRAW}),e.vertexArrayDestroyable=!1,t.cache.billboardCollection_vertexBufferInstanced=e),e}function $tt(t,e,i,n,s,o){let r=[{index:an.positionHighAndScale,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[OE]},{index:an.positionLowAndRotation,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[OE]},{index:an.compressedAttribute0,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[HL]},{index:an.compressedAttribute1,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[XL]},{index:an.compressedAttribute2,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[zL]},{index:an.eyeOffset,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[vL]},{index:an.scaleByDistance,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[KL]},{index:an.pixelOffsetScaleByDistance,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[qL]},{index:an.compressedAttribute3,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[$L]},{index:an.textureCoordinateBoundsOrLabelTranslate,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[Htt]}];n&&r.push({index:an.direction,componentsPerAttribute:2,componentDatatype:At.FLOAT,vertexBuffer:qtt(t)}),m(s)&&r.push({index:an.a_batchId,componentsPerAttribute:1,componentDatatype:At.FLOAT,bufferUsage:ai.STATIC_DRAW}),o&&r.push({index:an.sdf,componentsPerAttribute:2,componentDatatype:At.FLOAT,usage:i[ty]});let a=n?e:4*e;return new fI(t,r,a,n)}function iy(t,e,i,n,s){let o,r=n[an.positionHighAndScale],a=n[an.positionLowAndRotation],h=s._getActualPosition();t._mode===ye.SCENE3D&&(Nt.expand(t._baseVolume,h,t._baseVolume),t._boundingVolumeDirty=!0),Gn.fromCartesian(h,QT);let A=s.scale,d=s.rotation;d!==0&&(t._shaderRotation=!0),t._maxScale=Math.max(t._maxScale,A);let f=QT.high,E=QT.low;t._instanced?(o=s._index,r(o,f.x,f.y,f.z,A),a(o,E.x,E.y,E.z,d)):(o=s._index*4,r(o+0,f.x,f.y,f.z,A),r(o+1,f.x,f.y,f.z,A),r(o+2,f.x,f.y,f.z,A),r(o+3,f.x,f.y,f.z,A),a(o+0,E.x,E.y,E.z,d),a(o+1,E.x,E.y,E.z,d),a(o+2,E.x,E.y,E.z,d),a(o+3,E.x,E.y,E.z,d))}function Ay(t,e,i,n,s){let o,r=n[an.compressedAttribute0],a=s.pixelOffset,h=a.x,A=a.y,d=s._translate,f=d.x,E=d.y;t._maxPixelOffset=Math.max(t._maxPixelOffset,Math.abs(h+f),Math.abs(-A+E));let _=s.horizontalOrigin,R=s._verticalOrigin,I=s.show&&s.clusterShow;s.color.alpha===0&&(I=!1),R===mn.BASELINE&&(R=mn.BOTTOM),t._allHorizontalCenter=t._allHorizontalCenter&&_===to.CENTER,t._allVerticalCenter=t._allVerticalCenter&&R===mn.CENTER;let C=0,N=0,T=0,b=0,F=s._imageIndex;if(F!==-1){let H=i[F];if(!m(H))throw new Y(`Invalid billboard image index: ${F}`);C=H.x,N=H.y,T=H.width,b=H.height}let B=C+T,U=N+b,Q=Math.floor(L.clamp(h,-Qr,Qr)+Qr)*tet;Q+=(_+1)*eet,Q+=(R+1)*iet,Q+=(I?1:0)*ny;let M=Math.floor(L.clamp(A,-Qr,Qr)+Qr)*IA,k=Math.floor(L.clamp(f,-Qr,Qr)+Qr)*IA,y=(L.clamp(E,-Qr,Qr)+Qr)*net,c=Math.floor(y),g=Math.floor((y-c)*IA);M+=c,k+=g,kr.x=C,kr.y=N;let O=Yi.compressTextureCoordinates(kr);kr.x=B;let D=Yi.compressTextureCoordinates(kr);kr.y=U;let w=Yi.compressTextureCoordinates(kr);kr.x=C;let x=Yi.compressTextureCoordinates(kr);t._instanced?(o=s._index,r(o,Q,M,k,O)):(o=s._index*4,r(o+0,Q+sy,M,k,O),r(o+1,Q+oy,M,k,D),r(o+2,Q+ry,M,k,w),r(o+3,Q+ay,M,k,x))}function hy(t,e,i,n,s){let o,r=n[an.compressedAttribute1],a=s.alignedAxis;l.equals(a,l.ZERO)||(t._shaderAlignedAxis=!0);let h=0,A=1,d=1,f=1,E=s.translucencyByDistance;m(E)&&(h=E.near,A=E.nearValue,d=E.far,f=E.farValue,(A!==1||f!==1)&&(t._shaderTranslucencyByDistance=!0));let _=0,R=s._imageIndex;if(R!==-1){let b=i[R];if(!m(b))throw new Y(`Invalid billboard image index: ${R}`);_=b.width}let I=t._textureAtlas.texture.width,C=Math.round(Z(s.width,I*_));t._maxSize=Math.max(t._maxSize,C);let N=L.clamp(C,0,ym),T=0;Math.abs(l.magnitudeSquared(a)-1)<L.EPSILON6&&(T=Yi.octEncodeFloat(a)),A=L.clamp(A,0,1),A=A===1?255:A*255|0,N=N*IA+A,f=L.clamp(f,0,1),f=f===1?255:f*255|0,T=T*IA+f,t._instanced?(o=s._index,r(o,N,T,h,d)):(o=s._index*4,r(o+0,N,T,h,d),r(o+1,N,T,h,d),r(o+2,N,T,h,d),r(o+3,N,T,h,d))}function yT(t,e,i,n,s){let o,r=n[an.compressedAttribute2],a=s.color,h=m(t._batchTable)?Zt.WHITE:s.getPickId(e.context).color,A=s.sizeInMeters?1:0,d=Math.abs(l.magnitudeSquared(s.alignedAxis)-1)<L.EPSILON6?1:0;t._allSizedInMeters=t._allSizedInMeters&&A===1;let f=0,E=s._imageIndex;if(E!==-1){let Q=i[E];if(!m(Q))throw new Y(`Invalid billboard image index: ${E}`);f=Q.height}let _=t._textureAtlas.texture.dimensions,R=Math.round(Z(s.height,_.y*f));t._maxSize=Math.max(t._maxSize,R);let I=Z(s._labelHorizontalOrigin,-2);I+=2;let C=R*ny+I,N=Zt.floatToByte(a.red),T=Zt.floatToByte(a.green),b=Zt.floatToByte(a.blue),F=N*ym+T*IA+b;N=Zt.floatToByte(h.red),T=Zt.floatToByte(h.green),b=Zt.floatToByte(h.blue);let B=N*ym+T*IA+b,U=Zt.floatToByte(a.alpha)*ym+Zt.floatToByte(h.alpha)*IA;U+=A*2+d,t._instanced?(o=s._index,r(o,F,B,U,C)):(o=s._index*4,r(o+0,F,B,U,C),r(o+1,F,B,U,C),r(o+2,F,B,U,C),r(o+3,F,B,U,C))}function wT(t,e,i,n,s){let o,r=n[an.eyeOffset],a=s.eyeOffset,h=a.z;if(s._heightReference!==Wr.NONE&&(h*=1.005),t._maxEyeOffset=Math.max(t._maxEyeOffset,Math.abs(a.x),Math.abs(a.y),Math.abs(h)),t._instanced){let A=0,d=0,f=s._imageIndex;if(f!==-1){let _=i[f];if(!m(_))throw new Y(`Invalid billboard image index: ${f}`);A=_.width,d=_.height}kr.x=A,kr.y=d;let E=Yi.compressTextureCoordinates(kr);o=s._index,r(o,a.x,a.y,h,E)}else o=s._index*4,r(o+0,a.x,a.y,h,0),r(o+1,a.x,a.y,h,0),r(o+2,a.x,a.y,h,0),r(o+3,a.x,a.y,h,0)}function cy(t,e,i,n,s){let o,r=n[an.scaleByDistance],a=0,h=1,A=1,d=1,f=s.scaleByDistance;m(f)&&(a=f.near,h=f.nearValue,A=f.far,d=f.farValue,(h!==1||d!==1)&&(t._shaderScaleByDistance=!0)),t._instanced?(o=s._index,r(o,a,h,A,d)):(o=s._index*4,r(o+0,a,h,A,d),r(o+1,a,h,A,d),r(o+2,a,h,A,d),r(o+3,a,h,A,d))}function ly(t,e,i,n,s){let o,r=n[an.pixelOffsetScaleByDistance],a=0,h=1,A=1,d=1,f=s.pixelOffsetScaleByDistance;m(f)&&(a=f.near,h=f.nearValue,A=f.far,d=f.farValue,(h!==1||d!==1)&&(t._shaderPixelOffsetScaleByDistance=!0)),t._instanced?(o=s._index,r(o,a,h,A,d)):(o=s._index*4,r(o+0,a,h,A,d),r(o+1,a,h,A,d),r(o+2,a,h,A,d),r(o+3,a,h,A,d))}function dy(t,e,i,n,s){let o,r=n[an.compressedAttribute3],a=0,h=Number.MAX_VALUE,A=s.distanceDisplayCondition;m(A)&&(a=A.near,h=A.far,a*=a,h*=h,t._shaderDistanceDisplayCondition=!0);let d=s.disableDepthTestDistance,f=gl(s.heightReference)&&e.context.depthTexture;m(d)||(d=f?5e3:0),d*=d,(f||d>0)&&(t._shaderDisableDepthDistance=!0,d===Number.POSITIVE_INFINITY&&(d=-1));let E,_;if(m(s._labelDimensions))_=s._labelDimensions.x,E=s._labelDimensions.y;else{let N=0,T=0,b=s._imageIndex;if(b!==-1){let B=i[b];if(!m(B))throw new Y(`Invalid billboard image index: ${b}`);N=B.height,T=B.width}E=Math.round(Z(s.height,t._textureAtlas.texture.dimensions.y*N));let F=t._textureAtlas.texture.width;_=Math.round(Z(s.width,F*T))}let R=Math.floor(L.clamp(_,0,kT)),I=Math.floor(L.clamp(E,0,kT)),C=R*kT+I;t._instanced?(o=s._index,r(o,a,h,d,C)):(o=s._index*4,r(o+0,a,h,d,C),r(o+1,a,h,d,C),r(o+2,a,h,d,C),r(o+3,a,h,d,C))}function my(t,e,i,n,s){if(gl(s.heightReference)){let R=t._scene,I=e.context,C=e.globeTranslucencyState.translucent,N=m(R.globe)&&R.globe.depthTestAgainstTerrain;t._shaderClampToGround=I.depthTexture&&!C&&N}let o,r=n[an.textureCoordinateBoundsOrLabelTranslate];if(en.maximumVertexTextureImageUnits>0){let R=0,I=0;m(s._labelTranslate)&&(R=s._labelTranslate.x,I=s._labelTranslate.y),t._instanced?(o=s._index,r(o,R,I,0,0)):(o=s._index*4,r(o+0,R,I,0,0),r(o+1,R,I,0,0),r(o+2,R,I,0,0),r(o+3,R,I,0,0));return}let a=0,h=0,A=0,d=0,f=s._imageIndex;if(f!==-1){let R=i[f];if(!m(R))throw new Y(`Invalid billboard image index: ${f}`);a=R.x,h=R.y,A=R.width,d=R.height}let E=a+A,_=h+d;t._instanced?(o=s._index,r(o,a,h,E,_)):(o=s._index*4,r(o+0,a,h,E,_),r(o+1,a,h,E,_),r(o+2,a,h,E,_),r(o+3,a,h,E,_))}function set(t,e,i,n,s){if(!m(t._batchTable))return;let o=n[an.a_batchId],r=s._batchIndex,a;t._instanced?(a=s._index,o(a,r)):(a=s._index*4,o(a+0,r),o(a+1,r),o(a+2,r),o(a+3,r))}function fy(t,e,i,n,s){if(!t._sdf)return;let o,r=n[an.sdf],a=s.outlineColor,h=s.outlineWidth,A=Zt.floatToByte(a.red),d=Zt.floatToByte(a.green),f=Zt.floatToByte(a.blue),E=A*ym+d*IA+f,_=h/po.RADIUS,R=Zt.floatToByte(a.alpha)*ym+Zt.floatToByte(_)*IA;t._instanced?(o=s._index,r(o,E,R)):(o=s._index*4,r(o+0,E+sy,R),r(o+1,E+oy,R),r(o+2,E+ry,R),r(o+3,E+ay,R))}function oet(t,e,i,n,s){iy(t,e,i,n,s),Ay(t,e,i,n,s),hy(t,e,i,n,s),yT(t,e,i,n,s),wT(t,e,i,n,s),cy(t,e,i,n,s),ly(t,e,i,n,s),dy(t,e,i,n,s),my(t,e,i,n,s),set(t,e,i,n,s),fy(t,e,i,n,s)}function LT(t,e,i,n,s,o){let r;n.mode===ye.SCENE3D?(r=t._baseVolume,t._boundingVolumeDirty=!0):r=t._baseVolume2D;let a=[];for(let h=0;h<i;++h){let A=e[h],d=A.position,f=un._computeActualPosition(A,d,n,s);m(f)&&(A._setActualPosition(f),o?a.push(f):Nt.expand(r,f,r))}o&&Nt.fromPoints(a,r)}function ret(t,e){let i=e.mode,n=t._billboards,s=t._billboardsToUpdate,o=t._modelMatrix;t._createVertexArray||t._mode!==i||i!==ye.SCENE3D&&!at.equals(o,t.modelMatrix)?(t._mode=i,at.clone(t.modelMatrix,o),t._createVertexArray=!0,(i===ye.SCENE3D||i===ye.SCENE2D||i===ye.COLUMBUS_VIEW)&&LT(t,n,n.length,e,o,!0)):i===ye.MORPHING?LT(t,n,n.length,e,o,!0):(i===ye.SCENE2D||i===ye.COLUMBUS_VIEW)&&LT(t,s,t._billboardsToUpdateIndex,e,o,!1)}function aet(t,e,i){let n=1;(!t._allSizedInMeters||t._maxPixelOffset!==0)&&(n=e.camera.getPixelSize(i,e.context.drawingBufferWidth,e.context.drawingBufferHeight));let s=n*t._maxScale*t._maxSize*2;t._allHorizontalCenter&&t._allVerticalCenter&&(s*=.5);let o=n*t._maxPixelOffset+t._maxEyeOffset;i.radius+=s+o}function Aet(t,e){let n=e.createViewportQuadCommand(`uniform sampler2D billboard_texture; 
in vec2 v_textureCoordinates; 
void main() 
{ 
    out_FragColor = texture(billboard_texture, v_textureCoordinates); 
} 
`,{uniformMap:{billboard_texture:function(){return t._textureAtlas.texture}}});return n.pass=os.OVERLAY,n}var Ltt,OE,HL,vL,ytt,wtt,xtt,SE,zL,Ptt,Jtt,KL,XL,qL,$L,jtt,Htt,ty,xT,an,vtt,ztt,MT,QT,kr,Qr,ym,kT,IA,tet,eet,iet,ny,net,sy,oy,ry,ay,het,wm,JT=S(()=>{oh();_i();Xe();Ht();ae();Qn();oi();Ft();mt();Ws();Ot();Tl();Di();_e();bi();ss();aI();Nl();ga();Gm();Wm();Um();Qm();bl();GT();ML();kL();sI();km();EI();Sm();Om();ua();_I();UT();CE();Ltt=un.SHOW_INDEX,OE=un.POSITION_INDEX,HL=un.PIXEL_OFFSET_INDEX,vL=un.EYE_OFFSET_INDEX,ytt=un.HORIZONTAL_ORIGIN_INDEX,wtt=un.VERTICAL_ORIGIN_INDEX,xtt=un.SCALE_INDEX,SE=un.IMAGE_INDEX_INDEX,zL=un.COLOR_INDEX,Ptt=un.ROTATION_INDEX,Jtt=un.ALIGNED_AXIS_INDEX,KL=un.SCALE_BY_DISTANCE_INDEX,XL=un.TRANSLUCENCY_BY_DISTANCE_INDEX,qL=un.PIXEL_OFFSET_SCALE_BY_DISTANCE_INDEX,$L=un.DISTANCE_DISPLAY_CONDITION,jtt=un.DISABLE_DEPTH_DISTANCE,Htt=un.TEXTURE_COORDINATE_BOUNDS,ty=un.SDF_INDEX,xT=un.NUMBER_OF_PROPERTIES,vtt={positionHighAndScale:0,positionLowAndRotation:1,compressedAttribute0:2,compressedAttribute1:3,compressedAttribute2:4,eyeOffset:5,scaleByDistance:6,pixelOffsetScaleByDistance:7,compressedAttribute3:8,textureCoordinateBoundsOrLabelTranslate:9,a_batchId:10,sdf:11},ztt={direction:0,positionHighAndScale:1,positionLowAndRotation:2,compressedAttribute0:3,compressedAttribute1:4,compressedAttribute2:5,eyeOffset:6,scaleByDistance:7,pixelOffsetScaleByDistance:8,compressedAttribute3:9,textureCoordinateBoundsOrLabelTranslate:10,a_batchId:11,sdf:12};Object.defineProperties(Lr.prototype,{length:{get:function(){return PT(this),this._billboards.length}},textureAtlas:{get:function(){return this._textureAtlas},set:function(t){this._textureAtlas!==t&&(this._textureAtlas=this._destroyTextureAtlas&&this._textureAtlas&&this._textureAtlas.destroy(),this._textureAtlas=t,this._createVertexArray=!0)}},destroyTextureAtlas:{get:function(){return this._destroyTextureAtlas},set:function(t){this._destroyTextureAtlas=t}}});Lr.prototype.add=function(t){let e=new un(t,this);return e._index=this._billboards.length,this._billboards.push(e),this._createVertexArray=!0,e};Lr.prototype.remove=function(t){return this.contains(t)?(this._billboards[t._index]=void 0,this._billboardsRemoved=!0,this._createVertexArray=!0,t._destroy(),!0):!1};Lr.prototype.removeAll=function(){ey(this._billboards),this._billboards=[],this._billboardsToUpdate=[],this._billboardsToUpdateIndex=0,this._billboardsRemoved=!1,this._createVertexArray=!0};Lr.prototype._updateBillboard=function(t,e){t._dirty||(this._billboardsToUpdate[this._billboardsToUpdateIndex++]=t),++this._propertiesChanged[e]};Lr.prototype.contains=function(t){return m(t)&&t._billboardCollection===this};Lr.prototype.get=function(t){return p.typeOf.number("index",t),PT(this),this._billboards[t]};Lr.prototype.computeNewBuffersUsage=function(){let t=this._buffersUsage,e=!1,i=this._propertiesChanged;for(let n=0;n<xT;++n){let s=i[n]===0?ai.STATIC_DRAW:ai.STREAM_DRAW;e=e||t[n]!==s,t[n]=s}return e};QT=new Gn;kr=new nt,Qr=32768,ym=65536,kT=4096,IA=256,tet=128,eet=32,iet=8,ny=4,net=1/256,sy=0,oy=2,ry=3,ay=1;het=[];Lr.prototype.update=function(t){if(PT(this),!this.show)return;let e=this._billboards,i=e.length,n=t.context;this._instanced=n.instancedArrays,an=this._instanced?ztt:vtt,MT=this._instanced?Xtt:Ktt;let s=this._textureAtlas;if(!m(s)){s=this._textureAtlas=new VE({context:n});for(let M=0;M<i;++M)e[M]._loadImage()}let o=s.textureCoordinates;if(o.length===0)return;ret(this,t),e=this._billboards,i=e.length;let r=this._billboardsToUpdate,a=this._billboardsToUpdateIndex,h=this._propertiesChanged,A=s.guid,d=this._createVertexArray||this._textureAtlasGUID!==A;this._textureAtlasGUID=A;let f,E=t.passes,_=E.pick;if(d||!_&&this.computeNewBuffersUsage()){this._createVertexArray=!1;for(let M=0;M<xT;++M)h[M]=0;if(this._vaf=this._vaf&&this._vaf.destroy(),i>0){this._vaf=$tt(n,i,this._buffersUsage,this._instanced,this._batchTable,this._sdf),f=this._vaf.writers;for(let M=0;M<i;++M){let k=this._billboards[M];k._dirty=!1,oet(this,t,o,f,k)}this._vaf.commit(MT(n))}this._billboardsToUpdateIndex=0}else if(a>0){let M=het;M.length=0,(h[OE]||h[Ptt]||h[xtt])&&M.push(iy),(h[SE]||h[HL]||h[ytt]||h[wtt]||h[Ltt])&&(M.push(Ay),this._instanced&&M.push(wT)),(h[SE]||h[Jtt]||h[XL])&&(M.push(hy),M.push(yT)),(h[SE]||h[zL])&&M.push(yT),h[vL]&&M.push(wT),h[KL]&&M.push(cy),h[qL]&&M.push(ly),(h[$L]||h[jtt]||h[SE]||h[OE])&&M.push(dy),(h[SE]||h[OE])&&M.push(my),h[ty]&&M.push(fy);let k=M.length;if(f=this._vaf.writers,a/i>.1){for(let y=0;y<a;++y){let c=r[y];c._dirty=!1;for(let g=0;g<k;++g)M[g](this,t,o,f,c)}this._vaf.commit(MT(n))}else{for(let y=0;y<a;++y){let c=r[y];c._dirty=!1;for(let g=0;g<k;++g)M[g](this,t,o,f,c);this._instanced?this._vaf.subCommit(c._index,1):this._vaf.subCommit(c._index*4,4)}this._vaf.endSubCommits()}this._billboardsToUpdateIndex=0}if(a>i*1.5&&(r.length=i),!m(this._vaf)||!m(this._vaf.va))return;this._boundingVolumeDirty&&(this._boundingVolumeDirty=!1,Nt.transform(this._baseVolume,this.modelMatrix,this._baseVolumeWC));let R,I=at.IDENTITY;t.mode===ye.SCENE3D?(I=this.modelMatrix,R=Nt.clone(this._baseVolumeWC,this._boundingVolume)):R=Nt.clone(this._baseVolume2D,this._boundingVolume),aet(this,t,R);let C=this._blendOption!==this.blendOption;if(this._blendOption=this.blendOption,C){this._blendOption===Wn.OPAQUE||this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT?this._rsOpaque=Yn.fromCache({depthTest:{enabled:!0,func:it.LESS},depthMask:!0}):this._rsOpaque=void 0;let M=this._blendOption===Wn.TRANSLUCENT;this._blendOption===Wn.TRANSLUCENT||this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT?this._rsTranslucent=Yn.fromCache({depthTest:{enabled:!0,func:M?it.LEQUAL:it.LESS},depthMask:M,blending:Mr.ALPHA_BLEND}):this._rsTranslucent=void 0}this._shaderDisableDepthDistance=this._shaderDisableDepthDistance||t.minimumDisableDepthTestDistance!==0;let N,T,b,F,B,U=en.maximumVertexTextureImageUnits>0;if(C||this._shaderRotation!==this._compiledShaderRotation||this._shaderAlignedAxis!==this._compiledShaderAlignedAxis||this._shaderScaleByDistance!==this._compiledShaderScaleByDistance||this._shaderTranslucencyByDistance!==this._compiledShaderTranslucencyByDistance||this._shaderPixelOffsetScaleByDistance!==this._compiledShaderPixelOffsetScaleByDistance||this._shaderDistanceDisplayCondition!==this._compiledShaderDistanceDisplayCondition||this._shaderDisableDepthDistance!==this._compiledShaderDisableDepthDistance||this._shaderClampToGround!==this._compiledShaderClampToGround||this._sdf!==this._compiledSDF){N=QL,T=UL,B=[],m(this._batchTable)&&(B.push("VECTOR_TILE"),N=this._batchTable.getVertexShaderCallback(!1,"a_batchId",void 0)(N),T=this._batchTable.getFragmentShaderCallback(!1,void 0)(T)),b=new Ui({defines:B,sources:[N]}),this._instanced&&b.defines.push("INSTANCED"),this._shaderRotation&&b.defines.push("ROTATION"),this._shaderAlignedAxis&&b.defines.push("ALIGNED_AXIS"),this._shaderScaleByDistance&&b.defines.push("EYE_DISTANCE_SCALING"),this._shaderTranslucencyByDistance&&b.defines.push("EYE_DISTANCE_TRANSLUCENCY"),this._shaderPixelOffsetScaleByDistance&&b.defines.push("EYE_DISTANCE_PIXEL_OFFSET"),this._shaderDistanceDisplayCondition&&b.defines.push("DISTANCE_DISPLAY_CONDITION"),this._shaderDisableDepthDistance&&b.defines.push("DISABLE_DEPTH_DISTANCE"),this._shaderClampToGround&&(U?b.defines.push("VERTEX_DEPTH_CHECK"):b.defines.push("FRAGMENT_DEPTH_CHECK"));let M=1-po.CUTOFF;this._sdf&&b.defines.push("SDF");let k=m(this._batchTable)?"VECTOR_TILE":"";this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT&&(F=new Ui({defines:["OPAQUE",k],sources:[T]}),this._shaderClampToGround&&(U?F.defines.push("VERTEX_DEPTH_CHECK"):F.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(F.defines.push("SDF"),F.defines.push(`SDF_EDGE ${M}`)),this._sp=Es.replaceCache({context:n,shaderProgram:this._sp,vertexShaderSource:b,fragmentShaderSource:F,attributeLocations:an}),F=new Ui({defines:["TRANSLUCENT",k],sources:[T]}),this._shaderClampToGround&&(U?F.defines.push("VERTEX_DEPTH_CHECK"):F.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(F.defines.push("SDF"),F.defines.push(`SDF_EDGE ${M}`)),this._spTranslucent=Es.replaceCache({context:n,shaderProgram:this._spTranslucent,vertexShaderSource:b,fragmentShaderSource:F,attributeLocations:an})),this._blendOption===Wn.OPAQUE&&(F=new Ui({defines:[k],sources:[T]}),this._shaderClampToGround&&(U?F.defines.push("VERTEX_DEPTH_CHECK"):F.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(F.defines.push("SDF"),F.defines.push(`SDF_EDGE ${M}`)),this._sp=Es.replaceCache({context:n,shaderProgram:this._sp,vertexShaderSource:b,fragmentShaderSource:F,attributeLocations:an})),this._blendOption===Wn.TRANSLUCENT&&(F=new Ui({defines:[k],sources:[T]}),this._shaderClampToGround&&(U?F.defines.push("VERTEX_DEPTH_CHECK"):F.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(F.defines.push("SDF"),F.defines.push(`SDF_EDGE ${M}`)),this._spTranslucent=Es.replaceCache({context:n,shaderProgram:this._spTranslucent,vertexShaderSource:b,fragmentShaderSource:F,attributeLocations:an})),this._compiledShaderRotation=this._shaderRotation,this._compiledShaderAlignedAxis=this._shaderAlignedAxis,this._compiledShaderScaleByDistance=this._shaderScaleByDistance,this._compiledShaderTranslucencyByDistance=this._shaderTranslucencyByDistance,this._compiledShaderPixelOffsetScaleByDistance=this._shaderPixelOffsetScaleByDistance,this._compiledShaderDistanceDisplayCondition=this._shaderDistanceDisplayCondition,this._compiledShaderDisableDepthDistance=this._shaderDisableDepthDistance,this._compiledShaderClampToGround=this._shaderClampToGround,this._compiledSDF=this._sdf}let Q=t.commandList;if(E.render||E.pick){let M=this._colorCommands,k=this._blendOption===Wn.OPAQUE,y=this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT,c=this._vaf.va,g=c.length,O=this._uniforms,D;m(this._batchTable)?(O=this._batchTable.getUniformMapCallback()(O),D=this._batchTable.getPickId()):D="v_pickColor",M.length=g;let w=y?g*2:g;for(let x=0;x<w;++x){let H=M[x];m(H)||(H=M[x]=new fn);let j=k||y&&x%2===0;H.pass=j||!y?os.OPAQUE:os.TRANSLUCENT,H.owner=this;let X=y?Math.floor(x/2):x;H.boundingVolume=R,H.modelMatrix=I,H.count=c[X].indicesCount,H.shaderProgram=j?this._sp:this._spTranslucent,H.uniformMap=O,H.vertexArray=c[X].va,H.renderState=j?this._rsOpaque:this._rsTranslucent,H.debugShowBoundingVolume=this.debugShowBoundingVolume,H.pickId=D,this._instanced&&(H.count=6,H.instanceCount=i),Q.push(H)}this.debugShowTextureAtlas&&(m(this.debugCommand)||(this.debugCommand=Aet(this,t.context)),Q.push(this.debugCommand))}};Lr.prototype.isDestroyed=function(){return!1};Lr.prototype.destroy=function(){return m(this._removeCallbackFunc)&&(this._removeCallbackFunc(),this._removeCallbackFunc=void 0),this._textureAtlas=this._destroyTextureAtlas&&this._textureAtlas&&this._textureAtlas.destroy(),this._sp=this._sp&&this._sp.destroy(),this._spTranslucent=this._spTranslucent&&this._spTranslucent.destroy(),this._vaf=this._vaf&&this._vaf.destroy(),ey(this._billboards),li(this)};wm=Lr});var cet,Ya,jT=S(()=>{cet={FILL:0,OUTLINE:1,FILL_AND_OUTLINE:2},Ya=Object.freeze(cet)});function Sl(t){!t._rebindAllGlyphs&&!t._repositionAllGlyphs&&t._labelCollection._labelsToUpdate.push(t),t._rebindAllGlyphs=!0}function BE(t){!t._rebindAllGlyphs&&!t._repositionAllGlyphs&&t._labelCollection._labelsToUpdate.push(t),t._repositionAllGlyphs=!0}function GE(t,e){return document.defaultView.getComputedStyle(t,null).getPropertyValue(e)}function Zy(t){let e=Ey[t._font];if(!m(e)){let i=document.createElement("div");i.style.position="absolute",i.style.opacity=0,i.style.font=t._font,document.body.appendChild(i);let n=parseFloat(GE(i,"line-height"));isNaN(n)&&(n=void 0),e={family:GE(i,"font-family"),size:GE(i,"font-size").replace("px",""),style:GE(i,"font-style"),weight:GE(i,"font-weight"),lineHeight:n},document.body.removeChild(i),_y<det&&(Ey[t._font]=e,_y++)}t._fontFamily=e.family,t._fontSize=e.size,t._fontStyle=e.style,t._fontWeight=e.weight,t._lineHeight=e.lineHeight}function lh(t,e){if(t=Z(t,Z.EMPTY_OBJECT),m(t.disableDepthTestDistance)&&t.disableDepthTestDistance<0)throw new Y("disableDepthTestDistance must be greater than 0.0.");let i=t.translucencyByDistance,n=t.pixelOffsetScaleByDistance,s=t.scaleByDistance,o=t.distanceDisplayCondition;if(m(i)){if(i.far<=i.near)throw new Y("translucencyByDistance.far must be greater than translucencyByDistance.near.");i=gi.clone(i)}if(m(n)){if(n.far<=n.near)throw new Y("pixelOffsetScaleByDistance.far must be greater than pixelOffsetScaleByDistance.near.");n=gi.clone(n)}if(m(s)){if(s.far<=s.near)throw new Y("scaleByDistance.far must be greater than scaleByDistance.near.");s=gi.clone(s)}if(m(o)){if(o.far<=o.near)throw new Y("distanceDisplayCondition.far must be greater than distanceDisplayCondition.near.");o=Wo.clone(o)}this._renderedText=void 0,this._text=void 0,this._show=Z(t.show,!0),this._font=Z(t.font,"30px sans-serif"),this._fillColor=Zt.clone(Z(t.fillColor,Zt.WHITE)),this._outlineColor=Zt.clone(Z(t.outlineColor,Zt.BLACK)),this._outlineWidth=Z(t.outlineWidth,1),this._showBackground=Z(t.showBackground,!1),this._backgroundColor=Zt.clone(Z(t.backgroundColor,met)),this._backgroundPadding=nt.clone(Z(t.backgroundPadding,fet)),this._style=Z(t.style,Ya.FILL),this._verticalOrigin=Z(t.verticalOrigin,mn.BASELINE),this._horizontalOrigin=Z(t.horizontalOrigin,to.LEFT),this._pixelOffset=nt.clone(Z(t.pixelOffset,nt.ZERO)),this._eyeOffset=l.clone(Z(t.eyeOffset,l.ZERO)),this._position=l.clone(Z(t.position,l.ZERO)),this._scale=Z(t.scale,1),this._id=t.id,this._translucencyByDistance=i,this._pixelOffsetScaleByDistance=n,this._scaleByDistance=s,this._heightReference=Z(t.heightReference,Wr.NONE),this._distanceDisplayCondition=o,this._disableDepthTestDistance=t.disableDepthTestDistance,this._labelCollection=e,this._glyphs=[],this._backgroundBillboard=void 0,this._batchIndex=void 0,this._rebindAllGlyphs=!0,this._repositionAllGlyphs=!0,this._actualClampedPosition=void 0,this._removeCallbackFunc=void 0,this._mode=void 0,this._clusterShow=!0,this.text=Z(t.text,""),this._relativeSize=1,Zy(this),this._updateClamping()}function Eet(t,e){let i=/[a-zA-Z0-9]/,n=/[()[\]{}<>]/,s=[],o="",r=Rs.LTR,a="",h=t.length;for(let A=0;A<h;++A){let d=t.charAt(A);e.test(d)?a=Rs.RTL:i.test(d)?a=Rs.LTR:n.test(d)?a=Rs.BRACKETS:a=Rs.WEAK,A===0&&(r=a),r===a&&a!==Rs.BRACKETS?o+=d:(o!==""&&s.push({Type:r,Word:o}),r=a,o=d)}return s.push({Type:a,Word:o}),s}function _et(t){return t.split("").reverse().join("")}function WE(t,e,i){return t.slice(0,e)+i+t.slice(e)}function Ret(t){switch(t){case"(":return")";case")":return"(";case"[":return"]";case"]":return"[";case"{":return"}";case"}":return"{";case"<":return">";case">":return"<"}}function pet(t){let e=t.split(`
`),i="";for(let n=0;n<e.length;n++){let s=e[n],o=Ry.test(s.charAt(0)),r=Eet(s,Ry),a=0,h="";for(let A=0;A<r.length;++A){let d=r[A],f=d.Type===Rs.BRACKETS?Ret(d.Word):_et(d.Word);o?d.Type===Rs.RTL?(h=f+h,a=0):d.Type===Rs.LTR?(h=WE(h,a,d.Word),a+=d.Word.length):(d.Type===Rs.WEAK||d.Type===Rs.BRACKETS)&&(d.Type===Rs.WEAK&&r[A-1].Type===Rs.BRACKETS?h=f+h:r[A-1].Type===Rs.RTL?(h=f+h,a=0):r.length>A+1?r[A+1].Type===Rs.RTL?(h=f+h,a=0):(h=WE(h,a,d.Word),a+=d.Word.length):h=WE(h,0,f)):d.Type===Rs.RTL?h=WE(h,a,f):d.Type===Rs.LTR?(h+=d.Word,a=h.length):(d.Type===Rs.WEAK||d.Type===Rs.BRACKETS)&&(A>0&&r[A-1].Type===Rs.RTL?r.length>A+1?r[A+1].Type===Rs.RTL?h=WE(h,a,f):(h+=d.Word,a=h.length):h+=d.Word:(h+=d.Word,a=h.length))}i+=h,n<e.length-1&&(i+=`
`)}return i}var Ey,_y,det,met,fet,Rs,Zet,Iet,Ry,DE,HT=S(()=>{Er();Xe();Ht();Qn();Ft();mt();Ot();zZ();IE();sI();Sm();Om();jT();_I();CE();Ey={},_y=0,det=256,met=new Zt(.165,.165,.165,.8),fet=new nt(7,5),Rs=Object.freeze({LTR:0,RTL:1,WEAK:2,BRACKETS:3});Object.defineProperties(lh.prototype,{show:{get:function(){return this._show},set:function(t){if(!m(t))throw new Y("value is required.");if(this._show!==t){this._show=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n].billboard;m(o)&&(o.show=t)}let i=this._backgroundBillboard;m(i)&&(i.show=t)}}},position:{get:function(){return this._position},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._position;if(!l.equals(e,t)){l.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s].billboard;m(r)&&(r.position=t)}let n=this._backgroundBillboard;m(n)&&(n.position=t),this._updateClamping()}}},heightReference:{get:function(){return this._heightReference},set:function(t){if(!m(t))throw new Y("value is required.");if(t!==this._heightReference){this._heightReference=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n].billboard;m(o)&&(o.heightReference=t)}let i=this._backgroundBillboard;m(i)&&(i.heightReference=t),BE(this),this._updateClamping()}}},text:{get:function(){return this._text},set:function(t){if(!m(t))throw new Y("value is required.");if(this._text!==t){this._text=t;let e=t.replace(/\u00ad/g,"");this._renderedText=lh.enableRightToLeftDetection?pet(e):e,Sl(this)}}},font:{get:function(){return this._font},set:function(t){if(!m(t))throw new Y("value is required.");this._font!==t&&(this._font=t,Sl(this),Zy(this))}},fillColor:{get:function(){return this._fillColor},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._fillColor;Zt.equals(e,t)||(Zt.clone(t,e),Sl(this))}},outlineColor:{get:function(){return this._outlineColor},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._outlineColor;Zt.equals(e,t)||(Zt.clone(t,e),Sl(this))}},outlineWidth:{get:function(){return this._outlineWidth},set:function(t){if(!m(t))throw new Y("value is required.");this._outlineWidth!==t&&(this._outlineWidth=t,Sl(this))}},showBackground:{get:function(){return this._showBackground},set:function(t){if(!m(t))throw new Y("value is required.");this._showBackground!==t&&(this._showBackground=t,Sl(this))}},backgroundColor:{get:function(){return this._backgroundColor},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._backgroundColor;if(!Zt.equals(e,t)){Zt.clone(t,e);let i=this._backgroundBillboard;m(i)&&(i.color=e)}}},backgroundPadding:{get:function(){return this._backgroundPadding},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._backgroundPadding;nt.equals(e,t)||(nt.clone(t,e),BE(this))}},style:{get:function(){return this._style},set:function(t){if(!m(t))throw new Y("value is required.");this._style!==t&&(this._style=t,Sl(this))}},pixelOffset:{get:function(){return this._pixelOffset},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._pixelOffset;if(!nt.equals(e,t)){nt.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s];m(r.billboard)&&(r.billboard.pixelOffset=t)}let n=this._backgroundBillboard;m(n)&&(n.pixelOffset=t)}}},translucencyByDistance:{get:function(){return this._translucencyByDistance},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far distance must be greater than near distance.");let e=this._translucencyByDistance;if(!gi.equals(e,t)){this._translucencyByDistance=gi.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s];m(r.billboard)&&(r.billboard.translucencyByDistance=t)}let n=this._backgroundBillboard;m(n)&&(n.translucencyByDistance=t)}}},pixelOffsetScaleByDistance:{get:function(){return this._pixelOffsetScaleByDistance},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far distance must be greater than near distance.");let e=this._pixelOffsetScaleByDistance;if(!gi.equals(e,t)){this._pixelOffsetScaleByDistance=gi.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s];m(r.billboard)&&(r.billboard.pixelOffsetScaleByDistance=t)}let n=this._backgroundBillboard;m(n)&&(n.pixelOffsetScaleByDistance=t)}}},scaleByDistance:{get:function(){return this._scaleByDistance},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far distance must be greater than near distance.");let e=this._scaleByDistance;if(!gi.equals(e,t)){this._scaleByDistance=gi.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s];m(r.billboard)&&(r.billboard.scaleByDistance=t)}let n=this._backgroundBillboard;m(n)&&(n.scaleByDistance=t)}}},eyeOffset:{get:function(){return this._eyeOffset},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._eyeOffset;if(!l.equals(e,t)){l.clone(t,e);let i=this._glyphs;for(let s=0,o=i.length;s<o;s++){let r=i[s];m(r.billboard)&&(r.billboard.eyeOffset=t)}let n=this._backgroundBillboard;m(n)&&(n.eyeOffset=t)}}},horizontalOrigin:{get:function(){return this._horizontalOrigin},set:function(t){if(!m(t))throw new Y("value is required.");this._horizontalOrigin!==t&&(this._horizontalOrigin=t,BE(this))}},verticalOrigin:{get:function(){return this._verticalOrigin},set:function(t){if(!m(t))throw new Y("value is required.");if(this._verticalOrigin!==t){this._verticalOrigin=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.verticalOrigin=t)}let i=this._backgroundBillboard;m(i)&&(i.verticalOrigin=t),BE(this)}}},scale:{get:function(){return this._scale},set:function(t){if(!m(t))throw new Y("value is required.");if(this._scale!==t){this._scale=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.scale=t*this._relativeSize)}let i=this._backgroundBillboard;m(i)&&(i.scale=t*this._relativeSize),BE(this)}}},totalScale:{get:function(){return this._scale*this._relativeSize}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far must be greater than near");if(!Wo.equals(t,this._distanceDisplayCondition)){this._distanceDisplayCondition=Wo.clone(t,this._distanceDisplayCondition);let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.distanceDisplayCondition=t)}let i=this._backgroundBillboard;m(i)&&(i.distanceDisplayCondition=t)}}},disableDepthTestDistance:{get:function(){return this._disableDepthTestDistance},set:function(t){if(this._disableDepthTestDistance!==t){if(m(t)&&t<0)throw new Y("disableDepthTestDistance must be greater than 0.0.");this._disableDepthTestDistance=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.disableDepthTestDistance=t)}let i=this._backgroundBillboard;m(i)&&(i.disableDepthTestDistance=t)}}},id:{get:function(){return this._id},set:function(t){if(this._id!==t){this._id=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.id=t)}let i=this._backgroundBillboard;m(i)&&(i.id=t)}}},pickId:{get:function(){if(!(this._glyphs.length===0||!m(this._glyphs[0].billboard)))return this._glyphs[0].billboard.pickId}},_clampedPosition:{get:function(){return this._actualClampedPosition},set:function(t){this._actualClampedPosition=l.clone(t,this._actualClampedPosition);let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard._clampedPosition=t)}let i=this._backgroundBillboard;m(i)&&(i._clampedPosition=t)}},clusterShow:{get:function(){return this._clusterShow},set:function(t){if(this._clusterShow!==t){this._clusterShow=t;let e=this._glyphs;for(let n=0,s=e.length;n<s;n++){let o=e[n];m(o.billboard)&&(o.billboard.clusterShow=t)}let i=this._backgroundBillboard;m(i)&&(i.clusterShow=t)}}}});lh.prototype._updateClamping=function(){un._updateClamping(this._labelCollection,this)};lh.prototype.computeScreenSpacePosition=function(t,e){if(!m(t))throw new Y("scene is required.");m(e)||(e=new nt);let n=this._labelCollection.modelMatrix,s=m(this._actualClampedPosition)?this._actualClampedPosition:this._position;return un._computeScreenSpacePosition(n,s,this._eyeOffset,this._pixelOffset,t,e)};lh.getScreenSpaceBoundingBox=function(t,e,i){let n=0,s=0,o=0,r=0,a=t.totalScale,h=t._backgroundBillboard;if(m(h))n=e.x+h._translate.x,s=e.y-h._translate.y,o=h.width*a,r=h.height*a,t.verticalOrigin===mn.BOTTOM||t.verticalOrigin===mn.BASELINE?s-=r:t.verticalOrigin===mn.CENTER&&(s-=r*.5);else{n=Number.POSITIVE_INFINITY,s=Number.POSITIVE_INFINITY;let A=0,d=0,f=t._glyphs,E=f.length;for(let _=0;_<E;++_){let R=f[_],I=R.billboard;if(!m(I))continue;let C=e.x+I._translate.x,N=e.y-I._translate.y,T=R.dimensions.width*a,b=R.dimensions.height*a;t.verticalOrigin===mn.BOTTOM||t.verticalOrigin===mn.BASELINE?N-=b:t.verticalOrigin===mn.CENTER&&(N-=b*.5),t._verticalOrigin===mn.TOP?N+=po.PADDING*a:(t._verticalOrigin===mn.BOTTOM||t._verticalOrigin===mn.BASELINE)&&(N-=po.PADDING*a),n=Math.min(n,C),s=Math.min(s,N),A=Math.max(A,C+T),d=Math.max(d,N+b)}o=A-n,r=d-s}return m(i)||(i=new mi),i.x=n,i.y=s,i.width=o,i.height=r,i};lh.prototype.equals=function(t){return this===t||m(t)&&this._show===t._show&&this._scale===t._scale&&this._outlineWidth===t._outlineWidth&&this._showBackground===t._showBackground&&this._style===t._style&&this._verticalOrigin===t._verticalOrigin&&this._horizontalOrigin===t._horizontalOrigin&&this._heightReference===t._heightReference&&this._renderedText===t._renderedText&&this._font===t._font&&l.equals(this._position,t._position)&&Zt.equals(this._fillColor,t._fillColor)&&Zt.equals(this._outlineColor,t._outlineColor)&&Zt.equals(this._backgroundColor,t._backgroundColor)&&nt.equals(this._backgroundPadding,t._backgroundPadding)&&nt.equals(this._pixelOffset,t._pixelOffset)&&l.equals(this._eyeOffset,t._eyeOffset)&&gi.equals(this._translucencyByDistance,t._translucencyByDistance)&&gi.equals(this._pixelOffsetScaleByDistance,t._pixelOffsetScaleByDistance)&&gi.equals(this._scaleByDistance,t._scaleByDistance)&&Wo.equals(this._distanceDisplayCondition,t._distanceDisplayCondition)&&this._disableDepthTestDistance===t._disableDepthTestDistance&&this._id===t._id};lh.prototype.isDestroyed=function(){return!1};lh.enableRightToLeftDetection=!1;Zet="\u05D0-\u05EA",Iet="\u0600-\u06FF\u0750-\u077F\u08A0-\u08FF",Ry=new RegExp(`[${Zet}${Iet}]`);DE=lh});function uet(t,e,i,n,s){let o=t.measureText(e);if(!!/\S/.test(e)){let a=document.defaultView.getComputedStyle(t.canvas).getPropertyValue("font-size").replace("px",""),h=document.createElement("canvas"),A=100,d=o.width+A|0,f=3*a,E=f/2;h.width=d,h.height=f;let _=h.getContext("2d");_.font=i,_.fillStyle="white",_.fillRect(0,0,h.width+1,h.height+1),n&&(_.strokeStyle="black",_.lineWidth=t.lineWidth,_.strokeText(e,A/2,E)),s&&(_.fillStyle="black",_.fillText(e,A/2,E));let R=_.getImageData(0,0,d,f).data,I=R.length,C=d*4,N,T,b,F;for(N=0;N<I;++N)if(R[N]!==255){b=N/C|0;break}for(N=I-1;N>=0;--N)if(R[N]!==255){F=N/C|0;break}let B=-1;for(N=0;N<d&&B===-1;++N)for(T=0;T<f;++T){let U=N*4+T*C;if(R[U]!==255||R[U+1]!==255||R[U+2]!==255||R[U+3]!==255){B=N;break}}return{width:o.width,height:F-b,ascent:E-b,descent:F-E,minx:B-A/2}}return{width:o.width,height:0,ascent:0,descent:0,minx:0}}function Cet(t,e){if(!m(t))throw new Y("text is required.");if(t==="")return;e=Z(e,Z.EMPTY_OBJECT);let i=Z(e.font,"10px sans-serif"),n=Z(e.stroke,!1),s=Z(e.fill,!0),o=Z(e.strokeWidth,1),r=Z(e.backgroundColor,Zt.TRANSPARENT),a=Z(e.padding,0),h=a*2,A=document.createElement("canvas");A.width=1,A.height=1,A.style.font=i;let d=A.getContext("2d",{willReadFrequently:!0});m(Ol)||(m(d.imageSmoothingEnabled)?Ol="imageSmoothingEnabled":m(d.mozImageSmoothingEnabled)?Ol="mozImageSmoothingEnabled":m(d.webkitImageSmoothingEnabled)?Ol="webkitImageSmoothingEnabled":m(d.msImageSmoothingEnabled)&&(Ol="msImageSmoothingEnabled")),d.font=i,d.lineJoin="round",d.lineWidth=o,d[Ol]=!1,A.style.visibility="hidden",document.body.appendChild(A);let f=uet(d,t,i,n,s);A.dimensions=f,document.body.removeChild(A),A.style.visibility="";let E=-f.minx,_=Math.ceil(f.width)+E+h,R=f.height+h,I=R-f.ascent+a,C=R-I+h;if(A.width=_,A.height=R,d.font=i,d.lineJoin="round",d.lineWidth=o,d[Ol]=!1,r!==Zt.TRANSPARENT&&(d.fillStyle=r.toCssColorString(),d.fillRect(0,0,A.width,A.height)),n){let N=Z(e.strokeColor,Zt.BLACK);d.strokeStyle=N.toCssColorString(),d.strokeText(t,E+a,C)}if(s){let N=Z(e.fillColor,Zt.WHITE);d.fillStyle=N.toCssColorString(),d.fillText(t,E+a,C)}return A}var Ol,Iy,py=S(()=>{Qn();Ft();mt();Ot();Iy=Cet});var Ty=ts((eUt,gy)=>{"use strict";gy.exports=get;var UE=1e20;function get(t,e){e||(e={});var i=e.cutoff==null?.25:e.cutoff,n=e.radius==null?8:e.radius,s=e.channel||0,o,r,a,h,A,d,f,E,_,R,I;if(ArrayBuffer.isView(t)||Array.isArray(t)){if(!e.width||!e.height)throw Error("For raw data width and height should be provided by options");o=e.width,r=e.height,h=t,e.stride?d=e.stride:d=Math.floor(t.length/o/r)}else window.HTMLCanvasElement&&t instanceof window.HTMLCanvasElement?(E=t,f=E.getContext("2d"),o=E.width,r=E.height,_=f.getImageData(0,0,o,r),h=_.data,d=4):window.CanvasRenderingContext2D&&t instanceof window.CanvasRenderingContext2D?(E=t.canvas,f=t,o=E.width,r=E.height,_=f.getImageData(0,0,o,r),h=_.data,d=4):window.ImageData&&t instanceof window.ImageData&&(_=t,o=t.width,r=t.height,h=_.data,d=4);if(a=Math.max(o,r),window.Uint8ClampedArray&&h instanceof window.Uint8ClampedArray||window.Uint8Array&&h instanceof window.Uint8Array)for(A=h,h=Array(o*r),R=0,I=Math.floor(A.length/d);R<I;R++)h[R]=A[R*d+s]/255;else if(d!==1)throw Error("Raw data can have only 1 value per pixel");var C=Array(o*r),N=Array(o*r),T=Array(a),b=Array(a),F=Array(a+1),B=Array(a);for(R=0,I=o*r;R<I;R++){var U=h[R];C[R]=U===1?0:U===0?UE:Math.pow(Math.max(0,.5-U),2),N[R]=U===1?UE:U===0?0:Math.pow(Math.max(0,U-.5),2)}uy(C,o,r,T,b,B,F),uy(N,o,r,T,b,B,F);var Q=window.Float32Array?new Float32Array(o*r):new Array(o*r);for(R=0,I=o*r;R<I;R++)Q[R]=Math.min(Math.max(1-((C[R]-N[R])/n+i),0),1);return Q}function uy(t,e,i,n,s,o,r){for(var a=0;a<e;a++){for(var h=0;h<i;h++)n[h]=t[h*e+a];for(Cy(n,s,o,r,i),h=0;h<i;h++)t[h*e+a]=s[h]}for(h=0;h<i;h++){for(a=0;a<e;a++)n[a]=t[h*e+a];for(Cy(n,s,o,r,e),a=0;a<e;a++)t[h*e+a]=Math.sqrt(s[a])}}function Cy(t,e,i,n,s){i[0]=0,n[0]=-UE,n[1]=+UE;for(var o=1,r=0;o<s;o++){for(var a=(t[o]+o*o-(t[i[r]]+i[r]*i[r]))/(2*o-2*i[r]);a<=n[r];)r--,a=(t[o]+o*o-(t[i[r]]+i[r]*i[r]))/(2*o-2*i[r]);r++,i[r]=o,n[r]=a,n[r+1]=+UE}for(o=0,r=0;o<s;o++){for(;n[r+1]<o;)r++;e[o]=(o-i[r])*(o-i[r])+t[i[r]]}}});var Ny=ts((iUt,gI)=>{function Tet(){var t=0,e=1,i=2,n=3,s=4,o=5,r=6,a=7,h=8,A=9,d=10,f=11,E=12,_=13,R=14,I=15,C=16,N=17,T=0,b=1,F=2,B=3,U=4;function Q(c,g){return 55296<=c.charCodeAt(g)&&c.charCodeAt(g)<=56319&&56320<=c.charCodeAt(g+1)&&c.charCodeAt(g+1)<=57343}function M(c,g){g===void 0&&(g=0);var O=c.charCodeAt(g);if(55296<=O&&O<=56319&&g<c.length-1){var D=O,w=c.charCodeAt(g+1);return 56320<=w&&w<=57343?(D-55296)*1024+(w-56320)+65536:D}if(56320<=O&&O<=57343&&g>=1){var D=c.charCodeAt(g-1),w=O;return 55296<=D&&D<=56319?(D-55296)*1024+(w-56320)+65536:w}return O}function k(c,g,O){var D=[c].concat(g).concat([O]),w=D[D.length-2],x=O,H=D.lastIndexOf(R);if(H>1&&D.slice(1,H).every(function(tt){return tt==n})&&[n,_,N].indexOf(c)==-1)return F;var j=D.lastIndexOf(s);if(j>0&&D.slice(1,j).every(function(tt){return tt==s})&&[E,s].indexOf(w)==-1)return D.filter(function(tt){return tt==s}).length%2==1?B:U;if(w==t&&x==e)return T;if(w==i||w==t||w==e)return x==R&&g.every(function(tt){return tt==n})?F:b;if(x==i||x==t||x==e)return b;if(w==r&&(x==r||x==a||x==A||x==d))return T;if((w==A||w==a)&&(x==a||x==h))return T;if((w==d||w==h)&&x==h)return T;if(x==n||x==I)return T;if(x==o)return T;if(w==E)return T;var X=D.indexOf(n)!=-1?D.lastIndexOf(n)-1:D.length-2;return[_,N].indexOf(D[X])!=-1&&D.slice(X+1,-1).every(function(tt){return tt==n})&&x==R||w==I&&[C,N].indexOf(x)!=-1?T:g.indexOf(s)!=-1?F:w==s&&x==s?T:b}this.nextBreak=function(c,g){if(g===void 0&&(g=0),g<0)return 0;if(g>=c.length-1)return c.length;for(var O=y(M(c,g)),D=[],w=g+1;w<c.length;w++)if(!Q(c,w-1)){var x=y(M(c,w));if(k(O,D,x))return w;D.push(x)}return c.length},this.splitGraphemes=function(c){for(var g=[],O=0,D;(D=this.nextBreak(c,O))<c.length;)g.push(c.slice(O,D)),O=D;return O<c.length&&g.push(c.slice(O)),g},this.iterateGraphemes=function(c){var g=0,O={next:function(){var D,w;return(w=this.nextBreak(c,g))<c.length?(D=c.slice(g,w),g=w,{value:D,done:!1}):g<c.length?(D=c.slice(g),g=c.length,{value:D,done:!1}):{value:void 0,done:!0}}.bind(this)};return typeof Symbol<"u"&&Symbol.iterator&&(O[Symbol.iterator]=function(){return O}),O},this.countGraphemes=function(c){for(var g=0,O=0,D;(D=this.nextBreak(c,O))<c.length;)O=D,g++;return O<c.length&&g++,g};function y(c){return 1536<=c&&c<=1541||c==1757||c==1807||c==2274||c==3406||c==69821||70082<=c&&c<=70083||c==72250||72326<=c&&c<=72329||c==73030?E:c==13?t:c==10?e:0<=c&&c<=9||11<=c&&c<=12||14<=c&&c<=31||127<=c&&c<=159||c==173||c==1564||c==6158||c==8203||8206<=c&&c<=8207||c==8232||c==8233||8234<=c&&c<=8238||8288<=c&&c<=8292||c==8293||8294<=c&&c<=8303||55296<=c&&c<=57343||c==65279||65520<=c&&c<=65528||65529<=c&&c<=65531||113824<=c&&c<=113827||119155<=c&&c<=119162||c==917504||c==917505||917506<=c&&c<=917535||917632<=c&&c<=917759||918e3<=c&&c<=921599?i:768<=c&&c<=879||1155<=c&&c<=1159||1160<=c&&c<=1161||1425<=c&&c<=1469||c==1471||1473<=c&&c<=1474||1476<=c&&c<=1477||c==1479||1552<=c&&c<=1562||1611<=c&&c<=1631||c==1648||1750<=c&&c<=1756||1759<=c&&c<=1764||1767<=c&&c<=1768||1770<=c&&c<=1773||c==1809||1840<=c&&c<=1866||1958<=c&&c<=1968||2027<=c&&c<=2035||2070<=c&&c<=2073||2075<=c&&c<=2083||2085<=c&&c<=2087||2089<=c&&c<=2093||2137<=c&&c<=2139||2260<=c&&c<=2273||2275<=c&&c<=2306||c==2362||c==2364||2369<=c&&c<=2376||c==2381||2385<=c&&c<=2391||2402<=c&&c<=2403||c==2433||c==2492||c==2494||2497<=c&&c<=2500||c==2509||c==2519||2530<=c&&c<=2531||2561<=c&&c<=2562||c==2620||2625<=c&&c<=2626||2631<=c&&c<=2632||2635<=c&&c<=2637||c==2641||2672<=c&&c<=2673||c==2677||2689<=c&&c<=2690||c==2748||2753<=c&&c<=2757||2759<=c&&c<=2760||c==2765||2786<=c&&c<=2787||2810<=c&&c<=2815||c==2817||c==2876||c==2878||c==2879||2881<=c&&c<=2884||c==2893||c==2902||c==2903||2914<=c&&c<=2915||c==2946||c==3006||c==3008||c==3021||c==3031||c==3072||3134<=c&&c<=3136||3142<=c&&c<=3144||3146<=c&&c<=3149||3157<=c&&c<=3158||3170<=c&&c<=3171||c==3201||c==3260||c==3263||c==3266||c==3270||3276<=c&&c<=3277||3285<=c&&c<=3286||3298<=c&&c<=3299||3328<=c&&c<=3329||3387<=c&&c<=3388||c==3390||3393<=c&&c<=3396||c==3405||c==3415||3426<=c&&c<=3427||c==3530||c==3535||3538<=c&&c<=3540||c==3542||c==3551||c==3633||3636<=c&&c<=3642||3655<=c&&c<=3662||c==3761||3764<=c&&c<=3769||3771<=c&&c<=3772||3784<=c&&c<=3789||3864<=c&&c<=3865||c==3893||c==3895||c==3897||3953<=c&&c<=3966||3968<=c&&c<=3972||3974<=c&&c<=3975||3981<=c&&c<=3991||3993<=c&&c<=4028||c==4038||4141<=c&&c<=4144||4146<=c&&c<=4151||4153<=c&&c<=4154||4157<=c&&c<=4158||4184<=c&&c<=4185||4190<=c&&c<=4192||4209<=c&&c<=4212||c==4226||4229<=c&&c<=4230||c==4237||c==4253||4957<=c&&c<=4959||5906<=c&&c<=5908||5938<=c&&c<=5940||5970<=c&&c<=5971||6002<=c&&c<=6003||6068<=c&&c<=6069||6071<=c&&c<=6077||c==6086||6089<=c&&c<=6099||c==6109||6155<=c&&c<=6157||6277<=c&&c<=6278||c==6313||6432<=c&&c<=6434||6439<=c&&c<=6440||c==6450||6457<=c&&c<=6459||6679<=c&&c<=6680||c==6683||c==6742||6744<=c&&c<=6750||c==6752||c==6754||6757<=c&&c<=6764||6771<=c&&c<=6780||c==6783||6832<=c&&c<=6845||c==6846||6912<=c&&c<=6915||c==6964||6966<=c&&c<=6970||c==6972||c==6978||7019<=c&&c<=7027||7040<=c&&c<=7041||7074<=c&&c<=7077||7080<=c&&c<=7081||7083<=c&&c<=7085||c==7142||7144<=c&&c<=7145||c==7149||7151<=c&&c<=7153||7212<=c&&c<=7219||7222<=c&&c<=7223||7376<=c&&c<=7378||7380<=c&&c<=7392||7394<=c&&c<=7400||c==7405||c==7412||7416<=c&&c<=7417||7616<=c&&c<=7673||7675<=c&&c<=7679||c==8204||8400<=c&&c<=8412||8413<=c&&c<=8416||c==8417||8418<=c&&c<=8420||8421<=c&&c<=8432||11503<=c&&c<=11505||c==11647||11744<=c&&c<=11775||12330<=c&&c<=12333||12334<=c&&c<=12335||12441<=c&&c<=12442||c==42607||42608<=c&&c<=42610||42612<=c&&c<=42621||42654<=c&&c<=42655||42736<=c&&c<=42737||c==43010||c==43014||c==43019||43045<=c&&c<=43046||43204<=c&&c<=43205||43232<=c&&c<=43249||43302<=c&&c<=43309||43335<=c&&c<=43345||43392<=c&&c<=43394||c==43443||43446<=c&&c<=43449||c==43452||c==43493||43561<=c&&c<=43566||43569<=c&&c<=43570||43573<=c&&c<=43574||c==43587||c==43596||c==43644||c==43696||43698<=c&&c<=43700||43703<=c&&c<=43704||43710<=c&&c<=43711||c==43713||43756<=c&&c<=43757||c==43766||c==44005||c==44008||c==44013||c==64286||65024<=c&&c<=65039||65056<=c&&c<=65071||65438<=c&&c<=65439||c==66045||c==66272||66422<=c&&c<=66426||68097<=c&&c<=68099||68101<=c&&c<=68102||68108<=c&&c<=68111||68152<=c&&c<=68154||c==68159||68325<=c&&c<=68326||c==69633||69688<=c&&c<=69702||69759<=c&&c<=69761||69811<=c&&c<=69814||69817<=c&&c<=69818||69888<=c&&c<=69890||69927<=c&&c<=69931||69933<=c&&c<=69940||c==70003||70016<=c&&c<=70017||70070<=c&&c<=70078||70090<=c&&c<=70092||70191<=c&&c<=70193||c==70196||70198<=c&&c<=70199||c==70206||c==70367||70371<=c&&c<=70378||70400<=c&&c<=70401||c==70460||c==70462||c==70464||c==70487||70502<=c&&c<=70508||70512<=c&&c<=70516||70712<=c&&c<=70719||70722<=c&&c<=70724||c==70726||c==70832||70835<=c&&c<=70840||c==70842||c==70845||70847<=c&&c<=70848||70850<=c&&c<=70851||c==71087||71090<=c&&c<=71093||71100<=c&&c<=71101||71103<=c&&c<=71104||71132<=c&&c<=71133||71219<=c&&c<=71226||c==71229||71231<=c&&c<=71232||c==71339||c==71341||71344<=c&&c<=71349||c==71351||71453<=c&&c<=71455||71458<=c&&c<=71461||71463<=c&&c<=71467||72193<=c&&c<=72198||72201<=c&&c<=72202||72243<=c&&c<=72248||72251<=c&&c<=72254||c==72263||72273<=c&&c<=72278||72281<=c&&c<=72283||72330<=c&&c<=72342||72344<=c&&c<=72345||72752<=c&&c<=72758||72760<=c&&c<=72765||c==72767||72850<=c&&c<=72871||72874<=c&&c<=72880||72882<=c&&c<=72883||72885<=c&&c<=72886||73009<=c&&c<=73014||c==73018||73020<=c&&c<=73021||73023<=c&&c<=73029||c==73031||92912<=c&&c<=92916||92976<=c&&c<=92982||94095<=c&&c<=94098||113821<=c&&c<=113822||c==119141||119143<=c&&c<=119145||119150<=c&&c<=119154||119163<=c&&c<=119170||119173<=c&&c<=119179||119210<=c&&c<=119213||119362<=c&&c<=119364||121344<=c&&c<=121398||121403<=c&&c<=121452||c==121461||c==121476||121499<=c&&c<=121503||121505<=c&&c<=121519||122880<=c&&c<=122886||122888<=c&&c<=122904||122907<=c&&c<=122913||122915<=c&&c<=122916||122918<=c&&c<=122922||125136<=c&&c<=125142||125252<=c&&c<=125258||917536<=c&&c<=917631||917760<=c&&c<=917999?n:127462<=c&&c<=127487?s:c==2307||c==2363||2366<=c&&c<=2368||2377<=c&&c<=2380||2382<=c&&c<=2383||2434<=c&&c<=2435||2495<=c&&c<=2496||2503<=c&&c<=2504||2507<=c&&c<=2508||c==2563||2622<=c&&c<=2624||c==2691||2750<=c&&c<=2752||c==2761||2763<=c&&c<=2764||2818<=c&&c<=2819||c==2880||2887<=c&&c<=2888||2891<=c&&c<=2892||c==3007||3009<=c&&c<=3010||3014<=c&&c<=3016||3018<=c&&c<=3020||3073<=c&&c<=3075||3137<=c&&c<=3140||3202<=c&&c<=3203||c==3262||3264<=c&&c<=3265||3267<=c&&c<=3268||3271<=c&&c<=3272||3274<=c&&c<=3275||3330<=c&&c<=3331||3391<=c&&c<=3392||3398<=c&&c<=3400||3402<=c&&c<=3404||3458<=c&&c<=3459||3536<=c&&c<=3537||3544<=c&&c<=3550||3570<=c&&c<=3571||c==3635||c==3763||3902<=c&&c<=3903||c==3967||c==4145||4155<=c&&c<=4156||4182<=c&&c<=4183||c==4228||c==6070||6078<=c&&c<=6085||6087<=c&&c<=6088||6435<=c&&c<=6438||6441<=c&&c<=6443||6448<=c&&c<=6449||6451<=c&&c<=6456||6681<=c&&c<=6682||c==6741||c==6743||6765<=c&&c<=6770||c==6916||c==6965||c==6971||6973<=c&&c<=6977||6979<=c&&c<=6980||c==7042||c==7073||7078<=c&&c<=7079||c==7082||c==7143||7146<=c&&c<=7148||c==7150||7154<=c&&c<=7155||7204<=c&&c<=7211||7220<=c&&c<=7221||c==7393||7410<=c&&c<=7411||c==7415||43043<=c&&c<=43044||c==43047||43136<=c&&c<=43137||43188<=c&&c<=43203||43346<=c&&c<=43347||c==43395||43444<=c&&c<=43445||43450<=c&&c<=43451||43453<=c&&c<=43456||43567<=c&&c<=43568||43571<=c&&c<=43572||c==43597||c==43755||43758<=c&&c<=43759||c==43765||44003<=c&&c<=44004||44006<=c&&c<=44007||44009<=c&&c<=44010||c==44012||c==69632||c==69634||c==69762||69808<=c&&c<=69810||69815<=c&&c<=69816||c==69932||c==70018||70067<=c&&c<=70069||70079<=c&&c<=70080||70188<=c&&c<=70190||70194<=c&&c<=70195||c==70197||70368<=c&&c<=70370||70402<=c&&c<=70403||c==70463||70465<=c&&c<=70468||70471<=c&&c<=70472||70475<=c&&c<=70477||70498<=c&&c<=70499||70709<=c&&c<=70711||70720<=c&&c<=70721||c==70725||70833<=c&&c<=70834||c==70841||70843<=c&&c<=70844||c==70846||c==70849||71088<=c&&c<=71089||71096<=c&&c<=71099||c==71102||71216<=c&&c<=71218||71227<=c&&c<=71228||c==71230||c==71340||71342<=c&&c<=71343||c==71350||71456<=c&&c<=71457||c==71462||72199<=c&&c<=72200||c==72249||72279<=c&&c<=72280||c==72343||c==72751||c==72766||c==72873||c==72881||c==72884||94033<=c&&c<=94078||c==119142||c==119149?o:4352<=c&&c<=4447||43360<=c&&c<=43388?r:4448<=c&&c<=4519||55216<=c&&c<=55238?a:4520<=c&&c<=4607||55243<=c&&c<=55291?h:c==44032||c==44060||c==44088||c==44116||c==44144||c==44172||c==44200||c==44228||c==44256||c==44284||c==44312||c==44340||c==44368||c==44396||c==44424||c==44452||c==44480||c==44508||c==44536||c==44564||c==44592||c==44620||c==44648||c==44676||c==44704||c==44732||c==44760||c==44788||c==44816||c==44844||c==44872||c==44900||c==44928||c==44956||c==44984||c==45012||c==45040||c==45068||c==45096||c==45124||c==45152||c==45180||c==45208||c==45236||c==45264||c==45292||c==45320||c==45348||c==45376||c==45404||c==45432||c==45460||c==45488||c==45516||c==45544||c==45572||c==45600||c==45628||c==45656||c==45684||c==45712||c==45740||c==45768||c==45796||c==45824||c==45852||c==45880||c==45908||c==45936||c==45964||c==45992||c==46020||c==46048||c==46076||c==46104||c==46132||c==46160||c==46188||c==46216||c==46244||c==46272||c==46300||c==46328||c==46356||c==46384||c==46412||c==46440||c==46468||c==46496||c==46524||c==46552||c==46580||c==46608||c==46636||c==46664||c==46692||c==46720||c==46748||c==46776||c==46804||c==46832||c==46860||c==46888||c==46916||c==46944||c==46972||c==47e3||c==47028||c==47056||c==47084||c==47112||c==47140||c==47168||c==47196||c==47224||c==47252||c==47280||c==47308||c==47336||c==47364||c==47392||c==47420||c==47448||c==47476||c==47504||c==47532||c==47560||c==47588||c==47616||c==47644||c==47672||c==47700||c==47728||c==47756||c==47784||c==47812||c==47840||c==47868||c==47896||c==47924||c==47952||c==47980||c==48008||c==48036||c==48064||c==48092||c==48120||c==48148||c==48176||c==48204||c==48232||c==48260||c==48288||c==48316||c==48344||c==48372||c==48400||c==48428||c==48456||c==48484||c==48512||c==48540||c==48568||c==48596||c==48624||c==48652||c==48680||c==48708||c==48736||c==48764||c==48792||c==48820||c==48848||c==48876||c==48904||c==48932||c==48960||c==48988||c==49016||c==49044||c==49072||c==49100||c==49128||c==49156||c==49184||c==49212||c==49240||c==49268||c==49296||c==49324||c==49352||c==49380||c==49408||c==49436||c==49464||c==49492||c==49520||c==49548||c==49576||c==49604||c==49632||c==49660||c==49688||c==49716||c==49744||c==49772||c==49800||c==49828||c==49856||c==49884||c==49912||c==49940||c==49968||c==49996||c==50024||c==50052||c==50080||c==50108||c==50136||c==50164||c==50192||c==50220||c==50248||c==50276||c==50304||c==50332||c==50360||c==50388||c==50416||c==50444||c==50472||c==50500||c==50528||c==50556||c==50584||c==50612||c==50640||c==50668||c==50696||c==50724||c==50752||c==50780||c==50808||c==50836||c==50864||c==50892||c==50920||c==50948||c==50976||c==51004||c==51032||c==51060||c==51088||c==51116||c==51144||c==51172||c==51200||c==51228||c==51256||c==51284||c==51312||c==51340||c==51368||c==51396||c==51424||c==51452||c==51480||c==51508||c==51536||c==51564||c==51592||c==51620||c==51648||c==51676||c==51704||c==51732||c==51760||c==51788||c==51816||c==51844||c==51872||c==51900||c==51928||c==51956||c==51984||c==52012||c==52040||c==52068||c==52096||c==52124||c==52152||c==52180||c==52208||c==52236||c==52264||c==52292||c==52320||c==52348||c==52376||c==52404||c==52432||c==52460||c==52488||c==52516||c==52544||c==52572||c==52600||c==52628||c==52656||c==52684||c==52712||c==52740||c==52768||c==52796||c==52824||c==52852||c==52880||c==52908||c==52936||c==52964||c==52992||c==53020||c==53048||c==53076||c==53104||c==53132||c==53160||c==53188||c==53216||c==53244||c==53272||c==53300||c==53328||c==53356||c==53384||c==53412||c==53440||c==53468||c==53496||c==53524||c==53552||c==53580||c==53608||c==53636||c==53664||c==53692||c==53720||c==53748||c==53776||c==53804||c==53832||c==53860||c==53888||c==53916||c==53944||c==53972||c==54e3||c==54028||c==54056||c==54084||c==54112||c==54140||c==54168||c==54196||c==54224||c==54252||c==54280||c==54308||c==54336||c==54364||c==54392||c==54420||c==54448||c==54476||c==54504||c==54532||c==54560||c==54588||c==54616||c==54644||c==54672||c==54700||c==54728||c==54756||c==54784||c==54812||c==54840||c==54868||c==54896||c==54924||c==54952||c==54980||c==55008||c==55036||c==55064||c==55092||c==55120||c==55148||c==55176?A:44033<=c&&c<=44059||44061<=c&&c<=44087||44089<=c&&c<=44115||44117<=c&&c<=44143||44145<=c&&c<=44171||44173<=c&&c<=44199||44201<=c&&c<=44227||44229<=c&&c<=44255||44257<=c&&c<=44283||44285<=c&&c<=44311||44313<=c&&c<=44339||44341<=c&&c<=44367||44369<=c&&c<=44395||44397<=c&&c<=44423||44425<=c&&c<=44451||44453<=c&&c<=44479||44481<=c&&c<=44507||44509<=c&&c<=44535||44537<=c&&c<=44563||44565<=c&&c<=44591||44593<=c&&c<=44619||44621<=c&&c<=44647||44649<=c&&c<=44675||44677<=c&&c<=44703||44705<=c&&c<=44731||44733<=c&&c<=44759||44761<=c&&c<=44787||44789<=c&&c<=44815||44817<=c&&c<=44843||44845<=c&&c<=44871||44873<=c&&c<=44899||44901<=c&&c<=44927||44929<=c&&c<=44955||44957<=c&&c<=44983||44985<=c&&c<=45011||45013<=c&&c<=45039||45041<=c&&c<=45067||45069<=c&&c<=45095||45097<=c&&c<=45123||45125<=c&&c<=45151||45153<=c&&c<=45179||45181<=c&&c<=45207||45209<=c&&c<=45235||45237<=c&&c<=45263||45265<=c&&c<=45291||45293<=c&&c<=45319||45321<=c&&c<=45347||45349<=c&&c<=45375||45377<=c&&c<=45403||45405<=c&&c<=45431||45433<=c&&c<=45459||45461<=c&&c<=45487||45489<=c&&c<=45515||45517<=c&&c<=45543||45545<=c&&c<=45571||45573<=c&&c<=45599||45601<=c&&c<=45627||45629<=c&&c<=45655||45657<=c&&c<=45683||45685<=c&&c<=45711||45713<=c&&c<=45739||45741<=c&&c<=45767||45769<=c&&c<=45795||45797<=c&&c<=45823||45825<=c&&c<=45851||45853<=c&&c<=45879||45881<=c&&c<=45907||45909<=c&&c<=45935||45937<=c&&c<=45963||45965<=c&&c<=45991||45993<=c&&c<=46019||46021<=c&&c<=46047||46049<=c&&c<=46075||46077<=c&&c<=46103||46105<=c&&c<=46131||46133<=c&&c<=46159||46161<=c&&c<=46187||46189<=c&&c<=46215||46217<=c&&c<=46243||46245<=c&&c<=46271||46273<=c&&c<=46299||46301<=c&&c<=46327||46329<=c&&c<=46355||46357<=c&&c<=46383||46385<=c&&c<=46411||46413<=c&&c<=46439||46441<=c&&c<=46467||46469<=c&&c<=46495||46497<=c&&c<=46523||46525<=c&&c<=46551||46553<=c&&c<=46579||46581<=c&&c<=46607||46609<=c&&c<=46635||46637<=c&&c<=46663||46665<=c&&c<=46691||46693<=c&&c<=46719||46721<=c&&c<=46747||46749<=c&&c<=46775||46777<=c&&c<=46803||46805<=c&&c<=46831||46833<=c&&c<=46859||46861<=c&&c<=46887||46889<=c&&c<=46915||46917<=c&&c<=46943||46945<=c&&c<=46971||46973<=c&&c<=46999||47001<=c&&c<=47027||47029<=c&&c<=47055||47057<=c&&c<=47083||47085<=c&&c<=47111||47113<=c&&c<=47139||47141<=c&&c<=47167||47169<=c&&c<=47195||47197<=c&&c<=47223||47225<=c&&c<=47251||47253<=c&&c<=47279||47281<=c&&c<=47307||47309<=c&&c<=47335||47337<=c&&c<=47363||47365<=c&&c<=47391||47393<=c&&c<=47419||47421<=c&&c<=47447||47449<=c&&c<=47475||47477<=c&&c<=47503||47505<=c&&c<=47531||47533<=c&&c<=47559||47561<=c&&c<=47587||47589<=c&&c<=47615||47617<=c&&c<=47643||47645<=c&&c<=47671||47673<=c&&c<=47699||47701<=c&&c<=47727||47729<=c&&c<=47755||47757<=c&&c<=47783||47785<=c&&c<=47811||47813<=c&&c<=47839||47841<=c&&c<=47867||47869<=c&&c<=47895||47897<=c&&c<=47923||47925<=c&&c<=47951||47953<=c&&c<=47979||47981<=c&&c<=48007||48009<=c&&c<=48035||48037<=c&&c<=48063||48065<=c&&c<=48091||48093<=c&&c<=48119||48121<=c&&c<=48147||48149<=c&&c<=48175||48177<=c&&c<=48203||48205<=c&&c<=48231||48233<=c&&c<=48259||48261<=c&&c<=48287||48289<=c&&c<=48315||48317<=c&&c<=48343||48345<=c&&c<=48371||48373<=c&&c<=48399||48401<=c&&c<=48427||48429<=c&&c<=48455||48457<=c&&c<=48483||48485<=c&&c<=48511||48513<=c&&c<=48539||48541<=c&&c<=48567||48569<=c&&c<=48595||48597<=c&&c<=48623||48625<=c&&c<=48651||48653<=c&&c<=48679||48681<=c&&c<=48707||48709<=c&&c<=48735||48737<=c&&c<=48763||48765<=c&&c<=48791||48793<=c&&c<=48819||48821<=c&&c<=48847||48849<=c&&c<=48875||48877<=c&&c<=48903||48905<=c&&c<=48931||48933<=c&&c<=48959||48961<=c&&c<=48987||48989<=c&&c<=49015||49017<=c&&c<=49043||49045<=c&&c<=49071||49073<=c&&c<=49099||49101<=c&&c<=49127||49129<=c&&c<=49155||49157<=c&&c<=49183||49185<=c&&c<=49211||49213<=c&&c<=49239||49241<=c&&c<=49267||49269<=c&&c<=49295||49297<=c&&c<=49323||49325<=c&&c<=49351||49353<=c&&c<=49379||49381<=c&&c<=49407||49409<=c&&c<=49435||49437<=c&&c<=49463||49465<=c&&c<=49491||49493<=c&&c<=49519||49521<=c&&c<=49547||49549<=c&&c<=49575||49577<=c&&c<=49603||49605<=c&&c<=49631||49633<=c&&c<=49659||49661<=c&&c<=49687||49689<=c&&c<=49715||49717<=c&&c<=49743||49745<=c&&c<=49771||49773<=c&&c<=49799||49801<=c&&c<=49827||49829<=c&&c<=49855||49857<=c&&c<=49883||49885<=c&&c<=49911||49913<=c&&c<=49939||49941<=c&&c<=49967||49969<=c&&c<=49995||49997<=c&&c<=50023||50025<=c&&c<=50051||50053<=c&&c<=50079||50081<=c&&c<=50107||50109<=c&&c<=50135||50137<=c&&c<=50163||50165<=c&&c<=50191||50193<=c&&c<=50219||50221<=c&&c<=50247||50249<=c&&c<=50275||50277<=c&&c<=50303||50305<=c&&c<=50331||50333<=c&&c<=50359||50361<=c&&c<=50387||50389<=c&&c<=50415||50417<=c&&c<=50443||50445<=c&&c<=50471||50473<=c&&c<=50499||50501<=c&&c<=50527||50529<=c&&c<=50555||50557<=c&&c<=50583||50585<=c&&c<=50611||50613<=c&&c<=50639||50641<=c&&c<=50667||50669<=c&&c<=50695||50697<=c&&c<=50723||50725<=c&&c<=50751||50753<=c&&c<=50779||50781<=c&&c<=50807||50809<=c&&c<=50835||50837<=c&&c<=50863||50865<=c&&c<=50891||50893<=c&&c<=50919||50921<=c&&c<=50947||50949<=c&&c<=50975||50977<=c&&c<=51003||51005<=c&&c<=51031||51033<=c&&c<=51059||51061<=c&&c<=51087||51089<=c&&c<=51115||51117<=c&&c<=51143||51145<=c&&c<=51171||51173<=c&&c<=51199||51201<=c&&c<=51227||51229<=c&&c<=51255||51257<=c&&c<=51283||51285<=c&&c<=51311||51313<=c&&c<=51339||51341<=c&&c<=51367||51369<=c&&c<=51395||51397<=c&&c<=51423||51425<=c&&c<=51451||51453<=c&&c<=51479||51481<=c&&c<=51507||51509<=c&&c<=51535||51537<=c&&c<=51563||51565<=c&&c<=51591||51593<=c&&c<=51619||51621<=c&&c<=51647||51649<=c&&c<=51675||51677<=c&&c<=51703||51705<=c&&c<=51731||51733<=c&&c<=51759||51761<=c&&c<=51787||51789<=c&&c<=51815||51817<=c&&c<=51843||51845<=c&&c<=51871||51873<=c&&c<=51899||51901<=c&&c<=51927||51929<=c&&c<=51955||51957<=c&&c<=51983||51985<=c&&c<=52011||52013<=c&&c<=52039||52041<=c&&c<=52067||52069<=c&&c<=52095||52097<=c&&c<=52123||52125<=c&&c<=52151||52153<=c&&c<=52179||52181<=c&&c<=52207||52209<=c&&c<=52235||52237<=c&&c<=52263||52265<=c&&c<=52291||52293<=c&&c<=52319||52321<=c&&c<=52347||52349<=c&&c<=52375||52377<=c&&c<=52403||52405<=c&&c<=52431||52433<=c&&c<=52459||52461<=c&&c<=52487||52489<=c&&c<=52515||52517<=c&&c<=52543||52545<=c&&c<=52571||52573<=c&&c<=52599||52601<=c&&c<=52627||52629<=c&&c<=52655||52657<=c&&c<=52683||52685<=c&&c<=52711||52713<=c&&c<=52739||52741<=c&&c<=52767||52769<=c&&c<=52795||52797<=c&&c<=52823||52825<=c&&c<=52851||52853<=c&&c<=52879||52881<=c&&c<=52907||52909<=c&&c<=52935||52937<=c&&c<=52963||52965<=c&&c<=52991||52993<=c&&c<=53019||53021<=c&&c<=53047||53049<=c&&c<=53075||53077<=c&&c<=53103||53105<=c&&c<=53131||53133<=c&&c<=53159||53161<=c&&c<=53187||53189<=c&&c<=53215||53217<=c&&c<=53243||53245<=c&&c<=53271||53273<=c&&c<=53299||53301<=c&&c<=53327||53329<=c&&c<=53355||53357<=c&&c<=53383||53385<=c&&c<=53411||53413<=c&&c<=53439||53441<=c&&c<=53467||53469<=c&&c<=53495||53497<=c&&c<=53523||53525<=c&&c<=53551||53553<=c&&c<=53579||53581<=c&&c<=53607||53609<=c&&c<=53635||53637<=c&&c<=53663||53665<=c&&c<=53691||53693<=c&&c<=53719||53721<=c&&c<=53747||53749<=c&&c<=53775||53777<=c&&c<=53803||53805<=c&&c<=53831||53833<=c&&c<=53859||53861<=c&&c<=53887||53889<=c&&c<=53915||53917<=c&&c<=53943||53945<=c&&c<=53971||53973<=c&&c<=53999||54001<=c&&c<=54027||54029<=c&&c<=54055||54057<=c&&c<=54083||54085<=c&&c<=54111||54113<=c&&c<=54139||54141<=c&&c<=54167||54169<=c&&c<=54195||54197<=c&&c<=54223||54225<=c&&c<=54251||54253<=c&&c<=54279||54281<=c&&c<=54307||54309<=c&&c<=54335||54337<=c&&c<=54363||54365<=c&&c<=54391||54393<=c&&c<=54419||54421<=c&&c<=54447||54449<=c&&c<=54475||54477<=c&&c<=54503||54505<=c&&c<=54531||54533<=c&&c<=54559||54561<=c&&c<=54587||54589<=c&&c<=54615||54617<=c&&c<=54643||54645<=c&&c<=54671||54673<=c&&c<=54699||54701<=c&&c<=54727||54729<=c&&c<=54755||54757<=c&&c<=54783||54785<=c&&c<=54811||54813<=c&&c<=54839||54841<=c&&c<=54867||54869<=c&&c<=54895||54897<=c&&c<=54923||54925<=c&&c<=54951||54953<=c&&c<=54979||54981<=c&&c<=55007||55009<=c&&c<=55035||55037<=c&&c<=55063||55065<=c&&c<=55091||55093<=c&&c<=55119||55121<=c&&c<=55147||55149<=c&&c<=55175||55177<=c&&c<=55203?d:c==9757||c==9977||9994<=c&&c<=9997||c==127877||127938<=c&&c<=127940||c==127943||127946<=c&&c<=127948||128066<=c&&c<=128067||128070<=c&&c<=128080||c==128110||128112<=c&&c<=128120||c==128124||128129<=c&&c<=128131||128133<=c&&c<=128135||c==128170||128372<=c&&c<=128373||c==128378||c==128400||128405<=c&&c<=128406||128581<=c&&c<=128583||128587<=c&&c<=128591||c==128675||128692<=c&&c<=128694||c==128704||c==128716||129304<=c&&c<=129308||129310<=c&&c<=129311||c==129318||129328<=c&&c<=129337||129341<=c&&c<=129342||129489<=c&&c<=129501?_:127995<=c&&c<=127999?R:c==8205?I:c==9792||c==9794||9877<=c&&c<=9878||c==9992||c==10084||c==127752||c==127806||c==127859||c==127891||c==127908||c==127912||c==127979||c==127981||c==128139||128187<=c&&c<=128188||c==128295||c==128300||c==128488||c==128640||c==128658?C:128102<=c&&c<=128105?N:f}return this}typeof gI<"u"&&gI.exports&&(gI.exports=Tet)});function Net(){this.textureInfo=void 0,this.dimensions=void 0,this.billboard=void 0}function Fet(t,e,i){this.labelCollection=t,this.index=e,this.dimensions=i}function Vet(t){let e=document.createElement("canvas");e.width=vT.x,e.height=vT.y;let i=e.getContext("2d");return i.fillStyle="#fff",i.fillRect(0,0,e.width,e.height),t.addImage(Vy,e)}function Set(t,e,i,n,s,o,r){return yr.font=e,yr.fillColor=i,yr.strokeColor=n,yr.strokeWidth=s,yr.padding=po.PADDING,r===mn.CENTER?yr.textBaseline="middle":r===mn.TOP?yr.textBaseline="top":yr.textBaseline="bottom",yr.fill=o===Ya.FILL||o===Ya.FILL_AND_OUTLINE,yr.stroke=o===Ya.OUTLINE||o===Ya.FILL_AND_OUTLINE,yr.backgroundColor=Zt.BLACK,Iy(t,yr)}function zT(t,e){e.textureInfo=void 0,e.dimensions=void 0;let i=e.billboard;m(i)&&(i.show=!1,i.image=void 0,m(i._removeCallbackFunc)&&(i._removeCallbackFunc(),i._removeCallbackFunc=void 0),t._spareBillboards.push(i),e.billboard=void 0)}function Oet(t,e,i,n){n.index=t.addImageSync(e,i)}function Get(t,e){let i=e._renderedText,n=Bet.splitGraphemes(i),s=n.length,o=e._glyphs,r=o.length,a,h,A;if(e._relativeSize=e._fontSize/po.FONT_SIZE,s<r)for(h=s;h<r;++h)zT(t,o[h]);o.length=s;let d=e.show&&e._showBackground&&i.split(`
`).join("").length>0,f=e._backgroundBillboard,E=t._backgroundBillboardCollection;d?(m(f)||(f=E.add({collection:t,image:Vy,imageSubRegion:Yet}),e._backgroundBillboard=f),f.color=e._backgroundColor,f.show=e._show,f.position=e._position,f.eyeOffset=e._eyeOffset,f.pixelOffset=e._pixelOffset,f.horizontalOrigin=to.LEFT,f.verticalOrigin=e._verticalOrigin,f.heightReference=e._heightReference,f.scale=e.totalScale,f.pickPrimitive=e,f.id=e._id,f.translucencyByDistance=e._translucencyByDistance,f.pixelOffsetScaleByDistance=e._pixelOffsetScaleByDistance,f.scaleByDistance=e._scaleByDistance,f.distanceDisplayCondition=e._distanceDisplayCondition,f.disableDepthTestDistance=e._disableDepthTestDistance,f.clusterShow=e.clusterShow):m(f)&&(E.remove(f),e._backgroundBillboard=f=void 0);let _=t._glyphTextureCache;for(A=0;A<s;++A){let R=n[A],I=e._verticalOrigin,C=JSON.stringify([R,e._fontFamily,e._fontStyle,e._fontWeight,+I]),N=_[C];if(!m(N)){let T=`${e._fontStyle} ${e._fontWeight} ${po.FONT_SIZE}px ${e._fontFamily}`,b=Set(R,T,Zt.WHITE,Zt.WHITE,0,Ya.FILL,I);if(N=new Fet(t,-1,b.dimensions),_[C]=N,b.width>0&&b.height>0){let F=(0,by.default)(b,{cutoff:po.CUTOFF,radius:po.RADIUS}),B=b.getContext("2d"),U=b.width,Q=b.height,M=B.getImageData(0,0,U,Q);for(let k=0;k<U;k++)for(let y=0;y<Q;y++){let c=y*U+k,g=F[c]*255,O=c*4;M.data[O+0]=g,M.data[O+1]=g,M.data[O+2]=g,M.data[O+3]=g}B.putImageData(M,0,0),R!==" "&&Oet(t._textureAtlas,C,b,N)}}if(a=o[A],m(a)?N.index===-1?zT(t,a):m(a.textureInfo)&&(a.textureInfo=void 0):(a=new Net,o[A]=a),a.textureInfo=N,a.dimensions=N.dimensions,N.index!==-1){let T=a.billboard,b=t._spareBillboards;m(T)||(b.length>0?T=b.pop():(T=t._billboardCollection.add({collection:t}),T._labelDimensions=new nt,T._labelTranslate=new nt),a.billboard=T),T.show=e._show,T.position=e._position,T.eyeOffset=e._eyeOffset,T.pixelOffset=e._pixelOffset,T.horizontalOrigin=to.LEFT,T.verticalOrigin=e._verticalOrigin,T.heightReference=e._heightReference,T.scale=e.totalScale,T.pickPrimitive=e,T.id=e._id,T.image=C,T.translucencyByDistance=e._translucencyByDistance,T.pixelOffsetScaleByDistance=e._pixelOffsetScaleByDistance,T.scaleByDistance=e._scaleByDistance,T.distanceDisplayCondition=e._distanceDisplayCondition,T.disableDepthTestDistance=e._disableDepthTestDistance,T._batchIndex=e._batchIndex,T.outlineColor=e.outlineColor,e.style===Ya.FILL_AND_OUTLINE?(T.color=e._fillColor,T.outlineWidth=e.outlineWidth):e.style===Ya.FILL?(T.color=e._fillColor,T.outlineWidth=0):e.style===Ya.OUTLINE&&(T.color=Zt.TRANSPARENT,T.outlineWidth=e.outlineWidth)}}e._repositionAllGlyphs=!0}function Fy(t,e,i){return e===to.CENTER?-t/2:e===to.RIGHT?-(t+i.x):i.x}function Det(t){let e=t._glyphs,i=t._renderedText,n,s,o=0,r=0,a=[],h=Number.NEGATIVE_INFINITY,A=0,d=1,f,E=e.length,_=t._backgroundBillboard,R=nt.clone(m(_)?t._backgroundPadding:nt.ZERO,Wet);for(R.x/=t._relativeSize,R.y/=t._relativeSize,f=0;f<E;++f)i.charAt(f)===`
`?(a.push(o),++d,o=0):(n=e[f],s=n.dimensions,A=Math.max(A,s.height-s.descent),h=Math.max(h,s.descent),o+=s.width-s.minx,f<E-1&&(o+=e[f+1].dimensions.minx),r=Math.max(r,o));a.push(o);let I=A+h,C=t.totalScale,N=t._horizontalOrigin,T=t._verticalOrigin,b=0,F=a[b],B=Fy(F,N,R),U=(m(t._lineHeight)?t._lineHeight:bet*t._fontSize)/t._relativeSize,Q=U*(d-1),M=r,k=I+Q;m(_)&&(M+=R.x*2,k+=R.y*2,_._labelHorizontalOrigin=N),kn.x=B*C,kn.y=0;let y=!0,c=0;for(f=0;f<E;++f)if(i.charAt(f)===`
`)++b,c+=U,F=a[b],B=Fy(F,N,R),kn.x=B*C,y=!0;else if(n=e[f],s=n.dimensions,T===mn.TOP?(kn.y=s.height-A-R.y,kn.y+=po.PADDING):T===mn.CENTER?kn.y=(Q+s.height-A)/2:T===mn.BASELINE?(kn.y=Q,kn.y-=po.PADDING):(kn.y=Q+h+R.y,kn.y-=po.PADDING),kn.y=(kn.y-s.descent-c)*C,y&&(kn.x-=po.PADDING*C,y=!1),m(n.billboard)&&(n.billboard._setTranslate(kn),n.billboard._labelDimensions.x=M,n.billboard._labelDimensions.y=k,n.billboard._labelHorizontalOrigin=N),f<E-1){let g=e[f+1];kn.x+=(s.width-s.minx+g.dimensions.minx)*C}if(m(_)&&i.split(`
`).join("").length>0&&(N===to.CENTER?B=-r/2-R.x:N===to.RIGHT?B=-(r+R.x*2):B=0,kn.x=B*C,T===mn.TOP?kn.y=I-A-h:T===mn.CENTER?kn.y=(I-A)/2-h:T===mn.BASELINE?kn.y=-R.y-h:kn.y=0,kn.y=kn.y*C,_.width=M,_.height=k,_._setTranslate(kn),_._labelTranslate=nt.clone(kn,_._labelTranslate)),gl(t.heightReference))for(f=0;f<E;++f){n=e[f];let g=n.billboard;m(g)&&(g._labelTranslate=nt.clone(kn,g._labelTranslate))}}function Sy(t,e){let i=e._glyphs;for(let n=0,s=i.length;n<s;++n)zT(t,i[n]);m(e._backgroundBillboard)&&(t._backgroundBillboardCollection.remove(e._backgroundBillboard),e._backgroundBillboard=void 0),e._labelCollection=void 0,m(e._removeCallbackFunc)&&e._removeCallbackFunc(),li(e)}function pA(t){t=Z(t,Z.EMPTY_OBJECT),this._scene=t.scene,this._batchTable=t.batchTable,this._textureAtlas=void 0,this._backgroundTextureAtlas=void 0,this._backgroundBillboardCollection=new wm({scene:this._scene}),this._backgroundBillboardCollection.destroyTextureAtlas=!1,this._billboardCollection=new wm({scene:this._scene,batchTable:this._batchTable}),this._billboardCollection.destroyTextureAtlas=!1,this._billboardCollection._sdf=!0,this._spareBillboards=[],this._glyphTextureCache={},this._labels=[],this._labelsToUpdate=[],this._totalGlyphCount=0,this._highlightColor=Zt.clone(Zt.WHITE),this.show=Z(t.show,!0),this.modelMatrix=at.clone(Z(t.modelMatrix,at.IDENTITY)),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.blendOption=Z(t.blendOption,Wn.OPAQUE_AND_TRANSLUCENT)}var by,Yy,bet,Vy,vT,Yet,yr,Bet,kn,Wet,KT,Oy=S(()=>{Er();Xe();Qn();Ft();mt();Ws();Ot();bi();py();by=co(Ty(),1);JT();EI();Sm();Om();HT();jT();_I();UT();CE();Yy=co(Ny(),1);bet=1.2,Vy="ID_WHITE_PIXEL",vT=new nt(4,4),Yet=new mi(1,1,1,1);yr={};Bet=new Yy.default;kn=new nt,Wet=new nt;Object.defineProperties(pA.prototype,{length:{get:function(){return this._labels.length}}});pA.prototype.add=function(t){let e=new DE(t,this);return this._labels.push(e),this._labelsToUpdate.push(e),e};pA.prototype.remove=function(t){if(m(t)&&t._labelCollection===this){let e=this._labels.indexOf(t);if(e!==-1)return this._labels.splice(e,1),Sy(this,t),!0}return!1};pA.prototype.removeAll=function(){let t=this._labels;for(let e=0,i=t.length;e<i;++e)Sy(this,t[e]);t.length=0};pA.prototype.contains=function(t){return m(t)&&t._labelCollection===this};pA.prototype.get=function(t){if(!m(t))throw new Y("index is required.");return this._labels[t]};pA.prototype.update=function(t){if(!this.show)return;let e=this._billboardCollection,i=this._backgroundBillboardCollection;e.modelMatrix=this.modelMatrix,e.debugShowBoundingVolume=this.debugShowBoundingVolume,i.modelMatrix=this.modelMatrix,i.debugShowBoundingVolume=this.debugShowBoundingVolume;let n=t.context;m(this._textureAtlas)||(this._textureAtlas=new VE({context:n}),e.textureAtlas=this._textureAtlas),m(this._backgroundTextureAtlas)||(this._backgroundTextureAtlas=new VE({context:n,initialSize:vT}),i.textureAtlas=this._backgroundTextureAtlas,Vet(this._backgroundTextureAtlas));let s=this._labelsToUpdate.length;for(let r=0;r<s;++r){let a=this._labelsToUpdate[r];if(a.isDestroyed())continue;let h=a._glyphs.length;a._rebindAllGlyphs&&(Get(this,a),a._rebindAllGlyphs=!1),a._repositionAllGlyphs&&(Det(a),a._repositionAllGlyphs=!1);let A=a._glyphs.length-h;this._totalGlyphCount+=A}let o=i.length>0?Wn.TRANSLUCENT:this.blendOption;e.blendOption=o,i.blendOption=o,e._highlightColor=this._highlightColor,i._highlightColor=this._highlightColor,this._labelsToUpdate.length=0,i.update(t),e.update(t)};pA.prototype.isDestroyed=function(){return!1};pA.prototype.destroy=function(){return this.removeAll(),this._billboardCollection=this._billboardCollection.destroy(),this._textureAtlas=this._textureAtlas&&this._textureAtlas.destroy(),this._backgroundBillboardCollection=this._backgroundBillboardCollection.destroy(),this._backgroundTextureAtlas=this._backgroundTextureAtlas&&this._backgroundTextureAtlas.destroy(),li(this)};KT=pA});function rs(t,e){if(t=Z(t,Z.EMPTY_OBJECT),m(t.disableDepthTestDistance)&&t.disableDepthTestDistance<0)throw new Y("disableDepthTestDistance must be greater than or equal to 0.0.");let i=t.translucencyByDistance,n=t.scaleByDistance,s=t.distanceDisplayCondition;if(m(i)){if(i.far<=i.near)throw new Y("translucencyByDistance.far must be greater than translucencyByDistance.near.");i=gi.clone(i)}if(m(n)){if(n.far<=n.near)throw new Y("scaleByDistance.far must be greater than scaleByDistance.near.");n=gi.clone(n)}if(m(s)){if(s.far<=s.near)throw new Y("distanceDisplayCondition.far must be greater than distanceDisplayCondition.near.");s=Wo.clone(s)}this._show=Z(t.show,!0),this._position=l.clone(Z(t.position,l.ZERO)),this._actualPosition=l.clone(this._position),this._color=Zt.clone(Z(t.color,Zt.WHITE)),this._outlineColor=Zt.clone(Z(t.outlineColor,Zt.TRANSPARENT)),this._outlineWidth=Z(t.outlineWidth,0),this._pixelSize=Z(t.pixelSize,10),this._scaleByDistance=n,this._translucencyByDistance=i,this._distanceDisplayCondition=s,this._disableDepthTestDistance=Z(t.disableDepthTestDistance,0),this._id=t.id,this._collection=Z(t.collection,e),this._clusterShow=!0,this._pickId=void 0,this._pointPrimitiveCollection=e,this._dirty=!1,this._index=-1}function wr(t,e){let i=t._pointPrimitiveCollection;m(i)&&(i._updatePointPrimitive(t,e),t._dirty=!0)}var By,Dy,Uet,Met,Qet,ket,Let,yet,wet,xet,Gy,Wy,uo,XT=S(()=>{Er();Xe();Ht();Os();Qn();Ft();mt();Ot();zZ();bi();IE();ua();gT();By=rs.SHOW_INDEX=0,Dy=rs.POSITION_INDEX=1,Uet=rs.COLOR_INDEX=2,Met=rs.OUTLINE_COLOR_INDEX=3,Qet=rs.OUTLINE_WIDTH_INDEX=4,ket=rs.PIXEL_SIZE_INDEX=5,Let=rs.SCALE_BY_DISTANCE_INDEX=6,yet=rs.TRANSLUCENCY_BY_DISTANCE_INDEX=7,wet=rs.DISTANCE_DISPLAY_CONDITION_INDEX=8,xet=rs.DISABLE_DEPTH_DISTANCE_INDEX=9;rs.NUMBER_OF_PROPERTIES=10;Object.defineProperties(rs.prototype,{show:{get:function(){return this._show},set:function(t){if(!m(t))throw new Y("value is required.");this._show!==t&&(this._show=t,wr(this,By))}},position:{get:function(){return this._position},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._position;l.equals(e,t)||(l.clone(t,e),l.clone(t,this._actualPosition),wr(this,Dy))}},scaleByDistance:{get:function(){return this._scaleByDistance},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far distance must be greater than near distance.");let e=this._scaleByDistance;gi.equals(e,t)||(this._scaleByDistance=gi.clone(t,e),wr(this,Let))}},translucencyByDistance:{get:function(){return this._translucencyByDistance},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far distance must be greater than near distance.");let e=this._translucencyByDistance;gi.equals(e,t)||(this._translucencyByDistance=gi.clone(t,e),wr(this,yet))}},pixelSize:{get:function(){return this._pixelSize},set:function(t){if(!m(t))throw new Y("value is required.");this._pixelSize!==t&&(this._pixelSize=t,wr(this,ket))}},color:{get:function(){return this._color},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._color;Zt.equals(e,t)||(Zt.clone(t,e),wr(this,Uet))}},outlineColor:{get:function(){return this._outlineColor},set:function(t){if(!m(t))throw new Y("value is required.");let e=this._outlineColor;Zt.equals(e,t)||(Zt.clone(t,e),wr(this,Met))}},outlineWidth:{get:function(){return this._outlineWidth},set:function(t){if(!m(t))throw new Y("value is required.");this._outlineWidth!==t&&(this._outlineWidth=t,wr(this,Qet))}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){if(m(t)&&t.far<=t.near)throw new Y("far must be greater than near");Wo.equals(this._distanceDisplayCondition,t)||(this._distanceDisplayCondition=Wo.clone(t,this._distanceDisplayCondition),wr(this,wet))}},disableDepthTestDistance:{get:function(){return this._disableDepthTestDistance},set:function(t){if(this._disableDepthTestDistance!==t){if(!m(t)||t<0)throw new Y("disableDepthTestDistance must be greater than or equal to 0.0.");this._disableDepthTestDistance=t,wr(this,xet)}}},id:{get:function(){return this._id},set:function(t){this._id=t,m(this._pickId)&&(this._pickId.object.id=t)}},pickId:{get:function(){return this._pickId}},clusterShow:{get:function(){return this._clusterShow},set:function(t){this._clusterShow!==t&&(this._clusterShow=t,wr(this,By))}}});rs.prototype.getPickId=function(t){return m(this._pickId)||(this._pickId=t.createPickId({primitive:this,collection:this._collection,id:this._id})),this._pickId};rs.prototype._getActualPosition=function(){return this._actualPosition};rs.prototype._setActualPosition=function(t){l.clone(t,this._actualPosition),wr(this,Dy)};Gy=new ie;rs._computeActualPosition=function(t,e,i){return e.mode===ye.SCENE3D?t:(at.multiplyByPoint(i,t,Gy),Bm.computeActualWgs84Position(e,Gy))};Wy=new ie;rs._computeScreenSpacePosition=function(t,e,i,n){let s=at.multiplyByVector(t,ie.fromElements(e.x,e.y,e.z,1,Wy),Wy);return Bm.wgs84ToWindowCoordinates(i,s,n)};rs.prototype.computeScreenSpacePosition=function(t,e){let i=this._pointPrimitiveCollection;if(m(e)||(e=new nt),!m(i))throw new Y("PointPrimitive must be in a collection.");if(!m(t))throw new Y("scene is required.");let n=i.modelMatrix,s=rs._computeScreenSpacePosition(n,this._actualPosition,t,e);if(m(s))return s.y=t.canvas.clientHeight-s.y,s};rs.getScreenSpaceBoundingBox=function(t,e,i){let n=t.pixelSize,s=n*.5,o=e.x-s,r=e.y-s,a=n,h=n;return m(i)||(i=new mi),i.x=o,i.y=r,i.width=a,i.height=h,i};rs.prototype.equals=function(t){return this===t||m(t)&&this._id===t._id&&l.equals(this._position,t._position)&&Zt.equals(this._color,t._color)&&this._pixelSize===t._pixelSize&&this._outlineWidth===t._outlineWidth&&this._show===t._show&&Zt.equals(this._outlineColor,t._outlineColor)&&gi.equals(this._scaleByDistance,t._scaleByDistance)&&gi.equals(this._translucencyByDistance,t._translucencyByDistance)&&Wo.equals(this._distanceDisplayCondition,t._distanceDisplayCondition)&&this._disableDepthTestDistance===t._disableDepthTestDistance};rs.prototype._destroy=function(){this._pickId=this._pickId&&this._pickId.destroy(),this._pointPrimitiveCollection=void 0};uo=rs});var ME,Uy=S(()=>{ME=`in vec4 v_color;
in vec4 v_outlineColor;
in float v_innerPercent;
in float v_pixelDistance;
in vec4 v_pickColor;

void main()
{
    // The distance in UV space from this fragment to the center of the point, at most 0.5.
    float distanceToCenter = length(gl_PointCoord - vec2(0.5));
    // The max distance stops one pixel shy of the edge to leave space for anti-aliasing.
    float maxDistance = max(0.0, 0.5 - v_pixelDistance);
    float wholeAlpha = 1.0 - smoothstep(maxDistance, 0.5, distanceToCenter);
    float innerAlpha = 1.0 - smoothstep(maxDistance * v_innerPercent, 0.5 * v_innerPercent, distanceToCenter);

    vec4 color = mix(v_outlineColor, v_color, innerAlpha);
    color.a *= wholeAlpha;

// Fully transparent parts of the billboard are not pickable.
#if !defined(OPAQUE) && !defined(TRANSLUCENT)
    if (color.a < 0.005)   // matches 0/255 and 1/255
    {
        discard;
    }
#else
// The billboard is rendered twice. The opaque pass discards translucent fragments
// and the translucent pass discards opaque fragments.
#ifdef OPAQUE
    if (color.a < 0.995)   // matches < 254/255
    {
        discard;
    }
#else
    if (color.a >= 0.995)  // matches 254/255 and 255/255
    {
        discard;
    }
#endif
#endif

    out_FragColor = czm_gammaCorrect(color);
    czm_writeLogDepth();
}
`});var My,Qy=S(()=>{My=`uniform float u_maxTotalPointSize;

in vec4 positionHighAndSize;
in vec4 positionLowAndOutline;
in vec4 compressedAttribute0;                       // color, outlineColor, pick color
in vec4 compressedAttribute1;                       // show, translucency by distance, some free space
in vec4 scaleByDistance;                            // near, nearScale, far, farScale
in vec3 distanceDisplayConditionAndDisableDepth;    // near, far, disableDepthTestDistance

out vec4 v_color;
out vec4 v_outlineColor;
out float v_innerPercent;
out float v_pixelDistance;
out vec4 v_pickColor;

const float SHIFT_LEFT8 = 256.0;
const float SHIFT_RIGHT8 = 1.0 / 256.0;

void main()
{
    // Modifying this shader may also require modifications to PointPrimitive._computeScreenSpacePosition

    // unpack attributes
    vec3 positionHigh = positionHighAndSize.xyz;
    vec3 positionLow = positionLowAndOutline.xyz;
    float outlineWidthBothSides = 2.0 * positionLowAndOutline.w;
    float totalSize = positionHighAndSize.w + outlineWidthBothSides;
    float outlinePercent = outlineWidthBothSides / totalSize;
    // Scale in response to browser-zoom.
    totalSize *= czm_pixelRatio;

    float temp = compressedAttribute1.x * SHIFT_RIGHT8;
    float show = floor(temp);

#ifdef EYE_DISTANCE_TRANSLUCENCY
    vec4 translucencyByDistance;
    translucencyByDistance.x = compressedAttribute1.z;
    translucencyByDistance.z = compressedAttribute1.w;

    translucencyByDistance.y = ((temp - floor(temp)) * SHIFT_LEFT8) / 255.0;

    temp = compressedAttribute1.y * SHIFT_RIGHT8;
    translucencyByDistance.w = ((temp - floor(temp)) * SHIFT_LEFT8) / 255.0;
#endif

    ///////////////////////////////////////////////////////////////////////////

    vec4 color;
    vec4 outlineColor;
    vec4 pickColor;

    // compressedAttribute0.z => pickColor.rgb

    temp = compressedAttribute0.z * SHIFT_RIGHT8;
    pickColor.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    pickColor.g = (temp - floor(temp)) * SHIFT_LEFT8;
    pickColor.r = floor(temp);

    // compressedAttribute0.x => color.rgb

    temp = compressedAttribute0.x * SHIFT_RIGHT8;
    color.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    color.g = (temp - floor(temp)) * SHIFT_LEFT8;
    color.r = floor(temp);

    // compressedAttribute0.y => outlineColor.rgb

    temp = compressedAttribute0.y * SHIFT_RIGHT8;
    outlineColor.b = (temp - floor(temp)) * SHIFT_LEFT8;
    temp = floor(temp) * SHIFT_RIGHT8;
    outlineColor.g = (temp - floor(temp)) * SHIFT_LEFT8;
    outlineColor.r = floor(temp);

    // compressedAttribute0.w => color.a, outlineColor.a, pickColor.a

    temp = compressedAttribute0.w * SHIFT_RIGHT8;
    pickColor.a = (temp - floor(temp)) * SHIFT_LEFT8;
    pickColor = pickColor / 255.0;

    temp = floor(temp) * SHIFT_RIGHT8;
    outlineColor.a = (temp - floor(temp)) * SHIFT_LEFT8;
    outlineColor /= 255.0;
    color.a = floor(temp);
    color /= 255.0;

    ///////////////////////////////////////////////////////////////////////////

    vec4 p = czm_translateRelativeToEye(positionHigh, positionLow);
    vec4 positionEC = czm_modelViewRelativeToEye * p;

    ///////////////////////////////////////////////////////////////////////////

#if defined(EYE_DISTANCE_SCALING) || defined(EYE_DISTANCE_TRANSLUCENCY) || defined(DISTANCE_DISPLAY_CONDITION) || defined(DISABLE_DEPTH_DISTANCE)
    float lengthSq;
    if (czm_sceneMode == czm_sceneMode2D)
    {
        // 2D camera distance is a special case
        // treat all billboards as flattened to the z=0.0 plane
        lengthSq = czm_eyeHeight2D.y;
    }
    else
    {
        lengthSq = dot(positionEC.xyz, positionEC.xyz);
    }
#endif

#ifdef EYE_DISTANCE_SCALING
    totalSize *= czm_nearFarScalar(scaleByDistance, lengthSq);
#endif
    if (totalSize > 0.0) {
        // Add padding for anti-aliasing on both sides.
        totalSize += 3.0;
    }

    // Clamp to max point size.
    totalSize = min(totalSize, u_maxTotalPointSize);
    // If size is too small, push vertex behind near plane for clipping.
    // Note that context.minimumAliasedPointSize "will be at most 1.0".
    if (totalSize < 1.0)
    {
        positionEC.xyz = vec3(0.0);
        totalSize = 1.0;
    }

    float translucency = 1.0;
#ifdef EYE_DISTANCE_TRANSLUCENCY
    translucency = czm_nearFarScalar(translucencyByDistance, lengthSq);
    // push vertex behind near plane for clipping
    if (translucency < 0.004)
    {
        positionEC.xyz = vec3(0.0);
    }
#endif

#ifdef DISTANCE_DISPLAY_CONDITION
    float nearSq = distanceDisplayConditionAndDisableDepth.x;
    float farSq = distanceDisplayConditionAndDisableDepth.y;
    if (lengthSq < nearSq || lengthSq > farSq) {
        // push vertex behind camera to force it to be clipped
        positionEC.xyz = vec3(0.0, 0.0, 1.0);
    }
#endif

    gl_Position = czm_projection * positionEC;
    czm_vertexLogDepth();

#ifdef DISABLE_DEPTH_DISTANCE
    float disableDepthTestDistance = distanceDisplayConditionAndDisableDepth.z;
    if (disableDepthTestDistance == 0.0 && czm_minimumDisableDepthTestDistance != 0.0)
    {
        disableDepthTestDistance = czm_minimumDisableDepthTestDistance;
    }

    if (disableDepthTestDistance != 0.0)
    {
        // Don't try to "multiply both sides" by w.  Greater/less-than comparisons won't work for negative values of w.
        float zclip = gl_Position.z / gl_Position.w;
        bool clipped = (zclip < -1.0 || zclip > 1.0);
        if (!clipped && (disableDepthTestDistance < 0.0 || (lengthSq > 0.0 && lengthSq < disableDepthTestDistance)))
        {
            // Position z on the near plane.
            gl_Position.z = -gl_Position.w;
#ifdef LOG_DEPTH
            czm_vertexLogDepth(vec4(czm_currentFrustum.x));
#endif
        }
    }
#endif

    v_color = color;
    v_color.a *= translucency * show;
    v_outlineColor = outlineColor;
    v_outlineColor.a *= translucency * show;

    v_innerPercent = 1.0 - outlinePercent;
    v_pixelDistance = 2.0 / totalSize;
    gl_PointSize = totalSize * show;
    gl_Position *= show;

    v_pickColor = pickColor;
}
`});function xr(t){t=Z(t,Z.EMPTY_OBJECT),this._sp=void 0,this._spTranslucent=void 0,this._rsOpaque=void 0,this._rsTranslucent=void 0,this._vaf=void 0,this._pointPrimitives=[],this._pointPrimitivesToUpdate=[],this._pointPrimitivesToUpdateIndex=0,this._pointPrimitivesRemoved=!1,this._createVertexArray=!1,this._shaderScaleByDistance=!1,this._compiledShaderScaleByDistance=!1,this._shaderTranslucencyByDistance=!1,this._compiledShaderTranslucencyByDistance=!1,this._shaderDistanceDisplayCondition=!1,this._compiledShaderDistanceDisplayCondition=!1,this._shaderDisableDepthDistance=!1,this._compiledShaderDisableDepthDistance=!1,this._propertiesChanged=new Uint32Array(eN),this._maxPixelSize=1,this._baseVolume=new Nt,this._baseVolumeWC=new Nt,this._baseVolume2D=new Nt,this._boundingVolume=new Nt,this._boundingVolumeDirty=!1,this._colorCommands=[],this.show=Z(t.show,!0),this.modelMatrix=at.clone(Z(t.modelMatrix,at.IDENTITY)),this._modelMatrix=at.clone(at.IDENTITY),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.blendOption=Z(t.blendOption,Wn.OPAQUE_AND_TRANSLUCENT),this._blendOption=void 0,this._mode=ye.SCENE3D,this._maxTotalPointSize=1,this._buffersUsage=[ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW,ai.STATIC_DRAW];let e=this;this._uniforms={u_maxTotalPointSize:function(){return e._maxTotalPointSize}}}function xy(t){let e=t.length;for(let i=0;i<e;++i)t[i]&&t[i]._destroy()}function iN(t){if(t._pointPrimitivesRemoved){t._pointPrimitivesRemoved=!1;let e=[],i=t._pointPrimitives,n=i.length;for(let s=0,o=0;s<n;++s){let r=i[s];r&&(r._index=o++,e.push(r))}t._pointPrimitives=e}}function zet(t,e,i){return new fI(t,[{index:Co.positionHighAndSize,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[tN]},{index:Co.positionLowAndShow,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[tN]},{index:Co.compressedAttribute0,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[ky]},{index:Co.compressedAttribute1,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[yy]},{index:Co.scaleByDistance,componentsPerAttribute:4,componentDatatype:At.FLOAT,usage:i[Ly]},{index:Co.distanceDisplayConditionAndDisableDepth,componentsPerAttribute:3,componentDatatype:At.FLOAT,usage:i[wy]}],e)}function Py(t,e,i,n){let s=n._index,o=n._getActualPosition();t._mode===ye.SCENE3D&&(Nt.expand(t._baseVolume,o,t._baseVolume),t._boundingVolumeDirty=!0),Gn.fromCartesian(o,qT);let r=n.pixelSize,a=n.outlineWidth;t._maxPixelSize=Math.max(t._maxPixelSize,r+a);let h=i[Co.positionHighAndSize],A=qT.high;h(s,A.x,A.y,A.z,r);let d=i[Co.positionLowAndOutline],f=qT.low;d(s,f.x,f.y,f.z,a)}function Jy(t,e,i,n){let s=n._index,o=n.color,r=n.getPickId(e).color,a=n.outlineColor,h=Zt.floatToByte(o.red),A=Zt.floatToByte(o.green),d=Zt.floatToByte(o.blue),f=h*TI+A*QE+d;h=Zt.floatToByte(a.red),A=Zt.floatToByte(a.green),d=Zt.floatToByte(a.blue);let E=h*TI+A*QE+d;h=Zt.floatToByte(r.red),A=Zt.floatToByte(r.green),d=Zt.floatToByte(r.blue);let _=h*TI+A*QE+d,R=Zt.floatToByte(o.alpha)*TI+Zt.floatToByte(a.alpha)*QE+Zt.floatToByte(r.alpha),I=i[Co.compressedAttribute0];I(s,f,E,_,R)}function jy(t,e,i,n){let s=n._index,o=0,r=1,a=1,h=1,A=n.translucencyByDistance;m(A)&&(o=A.near,r=A.nearValue,a=A.far,h=A.farValue,(r!==1||h!==1)&&(t._shaderTranslucencyByDistance=!0));let d=n.show&&n.clusterShow;n.color.alpha===0&&n.outlineColor.alpha===0&&(d=!1),r=L.clamp(r,0,1),r=r===1?255:r*255|0;let f=(d?1:0)*QE+r;h=L.clamp(h,0,1),h=h===1?255:h*255|0;let E=h,_=i[Co.compressedAttribute1];_(s,f,E,o,a)}function Hy(t,e,i,n){let s=n._index,o=i[Co.scaleByDistance],r=0,a=1,h=1,A=1,d=n.scaleByDistance;m(d)&&(r=d.near,a=d.nearValue,h=d.far,A=d.farValue,(a!==1||A!==1)&&(t._shaderScaleByDistance=!0)),o(s,r,a,h,A)}function vy(t,e,i,n){let s=n._index,o=i[Co.distanceDisplayConditionAndDisableDepth],r=0,a=Number.MAX_VALUE,h=n.distanceDisplayCondition;m(h)&&(r=h.near,a=h.far,r*=r,a*=a,t._shaderDistanceDisplayCondition=!0);let A=n.disableDepthTestDistance;A*=A,A>0&&(t._shaderDisableDepthDistance=!0,A===Number.POSITIVE_INFINITY&&(A=-1)),o(s,r,a,A)}function Ket(t,e,i,n){Py(t,e,i,n),Jy(t,e,i,n),jy(t,e,i,n),Hy(t,e,i,n),vy(t,e,i,n)}function $T(t,e,i,n,s,o){let r;n.mode===ye.SCENE3D?(r=t._baseVolume,t._boundingVolumeDirty=!0):r=t._baseVolume2D;let a=[];for(let h=0;h<i;++h){let A=e[h],d=A.position,f=uo._computeActualPosition(d,n,s);m(f)&&(A._setActualPosition(f),o?a.push(f):Nt.expand(r,f,r))}o&&Nt.fromPoints(a,r)}function Xet(t,e){let i=e.mode,n=t._pointPrimitives,s=t._pointPrimitivesToUpdate,o=t._modelMatrix;t._createVertexArray||t._mode!==i||i!==ye.SCENE3D&&!at.equals(o,t.modelMatrix)?(t._mode=i,at.clone(t.modelMatrix,o),t._createVertexArray=!0,(i===ye.SCENE3D||i===ye.SCENE2D||i===ye.COLUMBUS_VIEW)&&$T(t,n,n.length,e,o,!0)):i===ye.MORPHING?$T(t,n,n.length,e,o,!0):(i===ye.SCENE2D||i===ye.COLUMBUS_VIEW)&&$T(t,s,t._pointPrimitivesToUpdateIndex,e,o,!1)}function qet(t,e,i){let s=e.camera.getPixelSize(i,e.context.drawingBufferWidth,e.context.drawingBufferHeight)*t._maxPixelSize;i.radius+=s}var Pet,tN,ky,Jet,jet,Het,Ly,yy,wy,vet,eN,Co,qT,TI,QE,$et,nN,zy=S(()=>{_i();Qn();oi();Ft();mt();Ws();Ot();Tl();_e();bi();Xi();ss();Nl();ga();Gm();Wm();Um();Qm();bl();GT();Uy();Qy();km();EI();XT();ua();Pet=uo.SHOW_INDEX,tN=uo.POSITION_INDEX,ky=uo.COLOR_INDEX,Jet=uo.OUTLINE_COLOR_INDEX,jet=uo.OUTLINE_WIDTH_INDEX,Het=uo.PIXEL_SIZE_INDEX,Ly=uo.SCALE_BY_DISTANCE_INDEX,yy=uo.TRANSLUCENCY_BY_DISTANCE_INDEX,wy=uo.DISTANCE_DISPLAY_CONDITION_INDEX,vet=uo.DISABLE_DEPTH_DISTANCE_INDEX,eN=uo.NUMBER_OF_PROPERTIES,Co={positionHighAndSize:0,positionLowAndOutline:1,compressedAttribute0:2,compressedAttribute1:3,scaleByDistance:4,distanceDisplayConditionAndDisableDepth:5};Object.defineProperties(xr.prototype,{length:{get:function(){return iN(this),this._pointPrimitives.length}}});xr.prototype.add=function(t){let e=new uo(t,this);return e._index=this._pointPrimitives.length,this._pointPrimitives.push(e),this._createVertexArray=!0,e};xr.prototype.remove=function(t){return this.contains(t)?(this._pointPrimitives[t._index]=null,this._pointPrimitivesRemoved=!0,this._createVertexArray=!0,t._destroy(),!0):!1};xr.prototype.removeAll=function(){xy(this._pointPrimitives),this._pointPrimitives=[],this._pointPrimitivesToUpdate=[],this._pointPrimitivesToUpdateIndex=0,this._pointPrimitivesRemoved=!1,this._createVertexArray=!0};xr.prototype._updatePointPrimitive=function(t,e){t._dirty||(this._pointPrimitivesToUpdate[this._pointPrimitivesToUpdateIndex++]=t),++this._propertiesChanged[e]};xr.prototype.contains=function(t){return m(t)&&t._pointPrimitiveCollection===this};xr.prototype.get=function(t){if(!m(t))throw new Y("index is required.");return iN(this),this._pointPrimitives[t]};xr.prototype.computeNewBuffersUsage=function(){let t=this._buffersUsage,e=!1,i=this._propertiesChanged;for(let n=0;n<eN;++n){let s=i[n]===0?ai.STATIC_DRAW:ai.STREAM_DRAW;e=e||t[n]!==s,t[n]=s}return e};qT=new Gn;TI=65536,QE=256;$et=[];xr.prototype.update=function(t){if(iN(this),!this.show)return;this._maxTotalPointSize=en.maximumAliasedPointSize,Xet(this,t);let i=this._pointPrimitives.length,n=this._pointPrimitivesToUpdate,s=this._pointPrimitivesToUpdateIndex,o=this._propertiesChanged,r=this._createVertexArray,a,h=t.context,A=t.passes,d=A.pick;if(r||!d&&this.computeNewBuffersUsage()){this._createVertexArray=!1;for(let B=0;B<eN;++B)o[B]=0;if(this._vaf=this._vaf&&this._vaf.destroy(),i>0){this._vaf=zet(h,i,this._buffersUsage),a=this._vaf.writers;for(let B=0;B<i;++B){let U=this._pointPrimitives[B];U._dirty=!1,Ket(this,h,a,U)}this._vaf.commit()}this._pointPrimitivesToUpdateIndex=0}else if(s>0){let B=$et;B.length=0,(o[tN]||o[jet]||o[Het])&&B.push(Py),(o[ky]||o[Jet])&&B.push(Jy),(o[Pet]||o[yy])&&B.push(jy),o[Ly]&&B.push(Hy),(o[wy]||o[vet])&&B.push(vy);let U=B.length;if(a=this._vaf.writers,s/i>.1){for(let Q=0;Q<s;++Q){let M=n[Q];M._dirty=!1;for(let k=0;k<U;++k)B[k](this,h,a,M)}this._vaf.commit()}else{for(let Q=0;Q<s;++Q){let M=n[Q];M._dirty=!1;for(let k=0;k<U;++k)B[k](this,h,a,M);this._vaf.subCommit(M._index,1)}this._vaf.endSubCommits()}this._pointPrimitivesToUpdateIndex=0}if(s>i*1.5&&(n.length=i),!m(this._vaf)||!m(this._vaf.va))return;this._boundingVolumeDirty&&(this._boundingVolumeDirty=!1,Nt.transform(this._baseVolume,this.modelMatrix,this._baseVolumeWC));let f,E=at.IDENTITY;t.mode===ye.SCENE3D?(E=this.modelMatrix,f=Nt.clone(this._baseVolumeWC,this._boundingVolume)):f=Nt.clone(this._baseVolume2D,this._boundingVolume),qet(this,t,f);let _=this._blendOption!==this.blendOption;this._blendOption=this.blendOption,_&&(this._blendOption===Wn.OPAQUE||this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT?this._rsOpaque=Yn.fromCache({depthTest:{enabled:!0,func:it.LEQUAL},depthMask:!0}):this._rsOpaque=void 0,this._blendOption===Wn.TRANSLUCENT||this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT?this._rsTranslucent=Yn.fromCache({depthTest:{enabled:!0,func:it.LEQUAL},depthMask:!1,blending:Mr.ALPHA_BLEND}):this._rsTranslucent=void 0),this._shaderDisableDepthDistance=this._shaderDisableDepthDistance||t.minimumDisableDepthTestDistance!==0;let R,I;(_||this._shaderScaleByDistance&&!this._compiledShaderScaleByDistance||this._shaderTranslucencyByDistance&&!this._compiledShaderTranslucencyByDistance||this._shaderDistanceDisplayCondition&&!this._compiledShaderDistanceDisplayCondition||this._shaderDisableDepthDistance!==this._compiledShaderDisableDepthDistance)&&(R=new Ui({sources:[My]}),this._shaderScaleByDistance&&R.defines.push("EYE_DISTANCE_SCALING"),this._shaderTranslucencyByDistance&&R.defines.push("EYE_DISTANCE_TRANSLUCENCY"),this._shaderDistanceDisplayCondition&&R.defines.push("DISTANCE_DISPLAY_CONDITION"),this._shaderDisableDepthDistance&&R.defines.push("DISABLE_DEPTH_DISTANCE"),this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT&&(I=new Ui({defines:["OPAQUE"],sources:[ME]}),this._sp=Es.replaceCache({context:h,shaderProgram:this._sp,vertexShaderSource:R,fragmentShaderSource:I,attributeLocations:Co}),I=new Ui({defines:["TRANSLUCENT"],sources:[ME]}),this._spTranslucent=Es.replaceCache({context:h,shaderProgram:this._spTranslucent,vertexShaderSource:R,fragmentShaderSource:I,attributeLocations:Co})),this._blendOption===Wn.OPAQUE&&(I=new Ui({sources:[ME]}),this._sp=Es.replaceCache({context:h,shaderProgram:this._sp,vertexShaderSource:R,fragmentShaderSource:I,attributeLocations:Co})),this._blendOption===Wn.TRANSLUCENT&&(I=new Ui({sources:[ME]}),this._spTranslucent=Es.replaceCache({context:h,shaderProgram:this._spTranslucent,vertexShaderSource:R,fragmentShaderSource:I,attributeLocations:Co})),this._compiledShaderScaleByDistance=this._shaderScaleByDistance,this._compiledShaderTranslucencyByDistance=this._shaderTranslucencyByDistance,this._compiledShaderDistanceDisplayCondition=this._shaderDistanceDisplayCondition,this._compiledShaderDisableDepthDistance=this._shaderDisableDepthDistance);let C,N,T,b,F=t.commandList;if(A.render||d){let B=this._colorCommands,U=this._blendOption===Wn.OPAQUE,Q=this._blendOption===Wn.OPAQUE_AND_TRANSLUCENT;C=this._vaf.va,N=C.length,B.length=N;let M=Q?N*2:N;for(b=0;b<M;++b){let k=U||Q&&b%2===0;T=B[b],m(T)||(T=B[b]=new fn),T.primitiveType=ne.POINTS,T.pass=k||!Q?os.OPAQUE:os.TRANSLUCENT,T.owner=this;let y=Q?Math.floor(b/2):b;T.boundingVolume=f,T.modelMatrix=E,T.shaderProgram=k?this._sp:this._spTranslucent,T.uniformMap=this._uniforms,T.vertexArray=C[y].va,T.renderState=k?this._rsOpaque:this._rsTranslucent,T.debugShowBoundingVolume=this.debugShowBoundingVolume,T.pickId="v_pickColor",F.push(T)}}};xr.prototype.isDestroyed=function(){return!1};xr.prototype.destroy=function(){return this._sp=this._sp&&this._sp.destroy(),this._spTranslucent=this._spTranslucent&&this._spTranslucent.destroy(),this._spPick=this._spPick&&this._spPick.destroy(),this._vaf=this._vaf&&this._vaf.destroy(),xy(this._pointPrimitives),li(this)};nN=xr});function rN(t,e,i,n,s,o){if(s-n<=i)return;let r=n+s>>1;qy(t,e,r,n,s,o),rN(t,e,i,n,r-1,1-o),rN(t,e,i,r+1,s,1-o)}function qy(t,e,i,n,s,o){for(;s>n;){if(s-n>600){let A=s-n+1,d=i-n+1,f=Math.log(A),E=.5*Math.exp(2*f/3),_=.5*Math.sqrt(f*E*(A-E)/A)*(d-A/2<0?-1:1),R=Math.max(n,Math.floor(i-d*E/A+_)),I=Math.min(s,Math.floor(i+(A-d)*E/A+_));qy(t,e,i,R,I,o)}let r=e[2*i+o],a=n,h=s;for(LE(t,e,n,i),e[2*s+o]>r&&LE(t,e,n,s);a<h;){for(LE(t,e,a,h),a++,h--;e[2*a+o]<r;)a++;for(;e[2*h+o]>r;)h--}e[2*n+o]===r?LE(t,e,n,h):(h++,LE(t,e,h,s)),h<=i&&(n=h+1),i<=h&&(s=h-1)}}function LE(t,e,i,n){oN(t,i,n),oN(e,2*i,2*n),oN(e,2*i+1,2*n+1)}function oN(t,e,i){let n=t[e];t[e]=t[i],t[i]=n}function Xy(t,e,i,n){let s=t-i,o=e-n;return s*s+o*o}var Ky,sN,kE,yE,$y=S(()=>{Ky=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],sN=1,kE=8,yE=class t{static from(e){if(!(e instanceof ArrayBuffer))throw new Error("Data must be an instance of ArrayBuffer.");let[i,n]=new Uint8Array(e,0,2);if(i!==219)throw new Error("Data does not appear to be in a KDBush format.");let s=n>>4;if(s!==sN)throw new Error(`Got v${s} data when expected v${sN}.`);let o=Ky[n&15];if(!o)throw new Error("Unrecognized array type.");let[r]=new Uint16Array(e,2,1),[a]=new Uint32Array(e,4,1);return new t(a,r,o,e)}constructor(e,i=64,n=Float64Array,s){if(isNaN(e)||e<0)throw new Error(`Unpexpected numItems value: ${e}.`);this.numItems=+e,this.nodeSize=Math.min(Math.max(+i,2),65535),this.ArrayType=n,this.IndexArrayType=e<65536?Uint16Array:Uint32Array;let o=Ky.indexOf(this.ArrayType),r=e*2*this.ArrayType.BYTES_PER_ELEMENT,a=e*this.IndexArrayType.BYTES_PER_ELEMENT,h=(8-a%8)%8;if(o<0)throw new Error(`Unexpected typed array class: ${n}.`);s&&s instanceof ArrayBuffer?(this.data=s,this.ids=new this.IndexArrayType(this.data,kE,e),this.coords=new this.ArrayType(this.data,kE+a+h,e*2),this._pos=e*2,this._finished=!0):(this.data=new ArrayBuffer(kE+r+a+h),this.ids=new this.IndexArrayType(this.data,kE,e),this.coords=new this.ArrayType(this.data,kE+a+h,e*2),this._pos=0,this._finished=!1,new Uint8Array(this.data,0,2).set([219,(sN<<4)+o]),new Uint16Array(this.data,2,1)[0]=i,new Uint32Array(this.data,4,1)[0]=e)}add(e,i){let n=this._pos>>1;return this.ids[n]=n,this.coords[this._pos++]=e,this.coords[this._pos++]=i,n}finish(){let e=this._pos>>1;if(e!==this.numItems)throw new Error(`Added ${e} items when expected ${this.numItems}.`);return rN(this.ids,this.coords,this.nodeSize,0,this.numItems-1,0),this._finished=!0,this}range(e,i,n,s){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");let{ids:o,coords:r,nodeSize:a}=this,h=[0,o.length-1,0],A=[];for(;h.length;){let d=h.pop()||0,f=h.pop()||0,E=h.pop()||0;if(f-E<=a){for(let C=E;C<=f;C++){let N=r[2*C],T=r[2*C+1];N>=e&&N<=n&&T>=i&&T<=s&&A.push(o[C])}continue}let _=E+f>>1,R=r[2*_],I=r[2*_+1];R>=e&&R<=n&&I>=i&&I<=s&&A.push(o[_]),(d===0?e<=R:i<=I)&&(h.push(E),h.push(_-1),h.push(1-d)),(d===0?n>=R:s>=I)&&(h.push(_+1),h.push(f),h.push(1-d))}return A}within(e,i,n){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");let{ids:s,coords:o,nodeSize:r}=this,a=[0,s.length-1,0],h=[],A=n*n;for(;a.length;){let d=a.pop()||0,f=a.pop()||0,E=a.pop()||0;if(f-E<=r){for(let C=E;C<=f;C++)Xy(o[2*C],o[2*C+1],e,i)<=A&&h.push(s[C]);continue}let _=E+f>>1,R=o[2*_],I=o[2*_+1];Xy(R,I,e,i)<=A&&h.push(s[_]),(d===0?e-n<=R:i-n<=I)&&(a.push(E),a.push(_-1),a.push(1-d)),(d===0?e+n>=R:i+n>=I)&&(a.push(_+1),a.push(f),a.push(1-d))}return h}}});function Va(t){t=Z(t,Z.EMPTY_OBJECT),this._enabled=Z(t.enabled,!1),this._pixelRange=Z(t.pixelRange,80),this._minimumClusterSize=Z(t.minimumClusterSize,2),this._clusterBillboards=Z(t.clusterBillboards,!0),this._clusterLabels=Z(t.clusterLabels,!0),this._clusterPoints=Z(t.clusterPoints,!0),this._labelCollection=void 0,this._billboardCollection=void 0,this._pointCollection=void 0,this._clusterBillboardCollection=void 0,this._clusterLabelCollection=void 0,this._clusterPointCollection=void 0,this._collectionIndicesByEntity={},this._unusedLabelIndices=[],this._unusedBillboardIndices=[],this._unusedPointIndices=[],this._previousClusters=[],this._previousHeight=void 0,this._enabledDirty=!1,this._clusterDirty=!1,this._cluster=void 0,this._removeEventListener=void 0,this._clusterEvent=new We,this.show=Z(t.show,!0)}function tw(t,e){t.x-=e,t.y-=e,t.width+=e*2,t.height+=e*2}function ew(t,e,i,n,s){if(m(t._labelCollection)&&n._clusterLabels?s=DE.getScreenSpaceBoundingBox(t,e,s):m(t._billboardCollection)&&n._clusterBillboards?s=un.getScreenSpaceBoundingBox(t,e,s):m(t._pointPrimitiveCollection)&&n._clusterPoints&&(s=uo.getScreenSpaceBoundingBox(t,e,s)),tw(s,i),n._clusterLabels&&!m(t._labelCollection)&&m(t.id)&&nw(n,t.id.id)&&m(t.id._label)){let o=n._collectionIndicesByEntity[t.id.id].labelIndex,r=n._labelCollection.get(o),a=DE.getScreenSpaceBoundingBox(r,e,tit);tw(a,i),s=mi.union(s,a,s)}return s}function eit(t,e){if(t.clusterShow=!0,!m(t._labelCollection)&&m(t.id)&&nw(e,t.id.id)&&m(t.id._label)){let i=e._collectionIndicesByEntity[t.id.id].labelIndex,n=e._labelCollection.get(i);n.clusterShow=!0}}function iw(t,e,i,n){let s={billboard:n._clusterBillboardCollection.add(),label:n._clusterLabelCollection.add(),point:n._clusterPointCollection.add()};s.billboard.show=!1,s.point.show=!1,s.label.show=!0,s.label.text=e.toLocaleString(),s.label.id=i,s.billboard.position=s.label.position=s.point.position=t,n._clusterEvent.raiseEvent(i,s)}function nw(t,e){return m(t)&&m(t._collectionIndicesByEntity[e])&&m(t._collectionIndicesByEntity[e].labelIndex)}function aN(t,e,i,n,s){if(!m(t))return;let o=t.length;for(let r=0;r<o;++r){let a=t.get(r);if(a.clusterShow=!1,!a.show||s._scene.mode===ye.SCENE3D&&!n.isPointVisible(a.position))continue;let h=s._clusterLabels&&m(a._labelCollection),A=s._clusterBillboards&&m(a.id._billboard),d=s._clusterPoints&&m(a.id._point);if(h&&(d||A))continue;let f=a.computeScreenSpacePosition(i);m(f)&&e.push({index:r,collection:t,clustered:!1,coord:f})}}function oit(t){return function(e){if(m(e)&&e<.05||!t.enabled)return;let i=t._scene,n=t._labelCollection,s=t._billboardCollection,o=t._pointCollection;if(!m(n)&&!m(s)&&!m(o)||!t._clusterBillboards&&!t._clusterLabels&&!t._clusterPoints)return;let r=t._clusterLabelCollection,a=t._clusterBillboardCollection,h=t._clusterPointCollection;m(r)?r.removeAll():r=t._clusterLabelCollection=new KT({scene:i}),m(a)?a.removeAll():a=t._clusterBillboardCollection=new wm({scene:i}),m(h)?h.removeAll():h=t._clusterPointCollection=new nN;let A=t._pixelRange,d=t._minimumClusterSize,f=t._previousClusters,E=[],_=t._previousHeight,R=i.camera.positionCartographic.height,I=i.mapProjection.ellipsoid,C=i.camera.positionWC,N=new dA(I,C),T=[];t._clusterLabels&&aN(n,T,i,N,t),t._clusterBillboards&&aN(s,T,i,N,t),t._clusterPoints&&aN(o,T,i,N,t);let b,F,B,U,Q,M,k,y,c,g,O,D;if(T.length>0){let w=new yE(T.length,64,Uint32Array);for(let x=0;x<T.length;++x)w.add(T[x].coord.x,T[x].coord.y);if(w.finish(),R<_)for(B=f.length,b=0;b<B;++b){let x=f[b];if(!N.isPointVisible(x.position))continue;let H=un._computeScreenSpacePosition(at.IDENTITY,x.position,l.ZERO,nt.ZERO,i);if(!m(H))continue;let j=1-R/_,X=x.width=x.width*j,tt=x.height=x.height*j;X=Math.max(X,x.minimumWidth),tt=Math.max(tt,x.minimumHeight);let G=H.x-X*.5,It=H.y-tt*.5,gt=H.x+X,Yt=H.y+tt;for(Q=w.range(G,It,gt,Yt),M=Q.length,g=0,c=[],F=0;F<M;++F)k=Q[F],y=T[k],y.clustered||(++g,O=y.collection,D=y.index,c.push(O.get(D).id));if(g>=d)for(iw(x.position,g,c,t),E.push(x),F=0;F<M;++F)T[Q[F]].clustered=!0}for(B=T.length,b=0;b<B;++b){let x=T[b];if(x.clustered)continue;x.clustered=!0,O=x.collection,D=x.index;let H=O.get(D);U=ew(H,x.coord,A,t,iit);let j=mi.clone(U,nit);Q=w.range(U.x,U.y,U.x+U.width,U.y+U.height),M=Q.length;let X=l.clone(H.position);for(g=1,c=[H.id],F=0;F<M;++F)if(k=Q[F],y=T[k],!y.clustered){let tt=y.collection.get(y.index),G=ew(tt,y.coord,A,t,sit);l.add(tt.position,X,X),mi.union(j,G,j),++g,c.push(tt.id)}if(g>=d){let tt=l.multiplyByScalar(X,1/g,X);for(iw(tt,g,c,t),E.push({position:tt,width:j.width,height:j.height,minimumWidth:U.width,minimumHeight:U.height}),F=0;F<M;++F)T[Q[F]].clustered=!0}else eit(H,t)}}r.length===0&&(r.destroy(),t._clusterLabelCollection=void 0),a.length===0&&(a.destroy(),t._clusterBillboardCollection=void 0),h.length===0&&(h.destroy(),t._clusterPointCollection=void 0),t._previousClusters=E,t._previousHeight=R}}function hN(t,e,i,n){return function(s){let o=this[t];m(this._collectionIndicesByEntity)||(this._collectionIndicesByEntity={});let r=this._collectionIndicesByEntity[s.id];if(m(r)||(r=this._collectionIndicesByEntity[s.id]={billboardIndex:void 0,labelIndex:void 0,pointIndex:void 0}),m(o)&&m(r[n]))return o.get(r[n]);m(o)||(o=this[t]=new e({scene:this._scene}));let a,h,A=this[i];A.length>0?(a=A.shift(),h=o.get(a)):(h=o.add(),a=o.length-1),r[n]=a;let d=this;return Promise.resolve().then(function(){d._clusterDirty=!0}),h}}function cN(t,e){let i=t._collectionIndicesByEntity[e];!m(i.billboardIndex)&&!m(i.labelIndex)&&!m(i.pointIndex)&&delete t._collectionIndicesByEntity[e]}function AN(t){if(!m(t))return;let e=t.length;for(let i=0;i<e;++i)t.get(i).clusterShow=!0}function rit(t){t.enabled||(m(t._clusterLabelCollection)&&t._clusterLabelCollection.destroy(),m(t._clusterBillboardCollection)&&t._clusterBillboardCollection.destroy(),m(t._clusterPointCollection)&&t._clusterPointCollection.destroy(),t._clusterLabelCollection=void 0,t._clusterBillboardCollection=void 0,t._clusterPointCollection=void 0,AN(t._labelCollection),AN(t._billboardCollection),AN(t._pointCollection))}var tit,iit,nit,sit,sw,ow=S(()=>{Er();Xe();Ht();Ft();mt();Vm();xi();bi();sI();JT();HT();Oy();XT();zy();ua();$y();tit=new mi;iit=new mi,nit=new mi,sit=new mi;Va.prototype._initialize=function(t){this._scene=t;let e=oit(this);this._cluster=e,this._removeEventListener=t.camera.changed.addEventListener(e)};Object.defineProperties(Va.prototype,{enabled:{get:function(){return this._enabled},set:function(t){this._enabledDirty=t!==this._enabled,this._enabled=t}},pixelRange:{get:function(){return this._pixelRange},set:function(t){this._clusterDirty=this._clusterDirty||t!==this._pixelRange,this._pixelRange=t}},minimumClusterSize:{get:function(){return this._minimumClusterSize},set:function(t){this._clusterDirty=this._clusterDirty||t!==this._minimumClusterSize,this._minimumClusterSize=t}},clusterEvent:{get:function(){return this._clusterEvent}},clusterBillboards:{get:function(){return this._clusterBillboards},set:function(t){this._clusterDirty=this._clusterDirty||t!==this._clusterBillboards,this._clusterBillboards=t}},clusterLabels:{get:function(){return this._clusterLabels},set:function(t){this._clusterDirty=this._clusterDirty||t!==this._clusterLabels,this._clusterLabels=t}},clusterPoints:{get:function(){return this._clusterPoints},set:function(t){this._clusterDirty=this._clusterDirty||t!==this._clusterPoints,this._clusterPoints=t}}});Va.prototype.getLabel=hN("_labelCollection",KT,"_unusedLabelIndices","labelIndex");Va.prototype.removeLabel=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!m(this._labelCollection)||!m(e)||!m(e.labelIndex))return;let i=e.labelIndex;e.labelIndex=void 0,cN(this,t.id);let n=this._labelCollection.get(i);n.show=!1,n.text="",n.id=void 0,this._unusedLabelIndices.push(i),this._clusterDirty=!0};Va.prototype.getBillboard=hN("_billboardCollection",wm,"_unusedBillboardIndices","billboardIndex");Va.prototype.removeBillboard=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!m(this._billboardCollection)||!m(e)||!m(e.billboardIndex))return;let i=e.billboardIndex;e.billboardIndex=void 0,cN(this,t.id);let n=this._billboardCollection.get(i);n.id=void 0,n.show=!1,n.image=void 0,this._unusedBillboardIndices.push(i),this._clusterDirty=!0};Va.prototype.getPoint=hN("_pointCollection",nN,"_unusedPointIndices","pointIndex");Va.prototype.removePoint=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!m(this._pointCollection)||!m(e)||!m(e.pointIndex))return;let i=e.pointIndex;e.pointIndex=void 0,cN(this,t.id);let n=this._pointCollection.get(i);n.show=!1,n.id=void 0,this._unusedPointIndices.push(i),this._clusterDirty=!0};Va.prototype.update=function(t){if(!this.show)return;let e;m(this._labelCollection)&&this._labelCollection.length>0&&this._labelCollection.get(0)._glyphs.length===0&&(e=t.commandList,t.commandList=[],this._labelCollection.update(t),t.commandList=e),m(this._billboardCollection)&&this._billboardCollection.length>0&&!m(this._billboardCollection.get(0).width)&&(e=t.commandList,t.commandList=[],this._billboardCollection.update(t),t.commandList=e),this._enabledDirty&&(this._enabledDirty=!1,rit(this),this._clusterDirty=!0),this._clusterDirty&&(this._clusterDirty=!1,this._cluster()),m(this._clusterLabelCollection)&&this._clusterLabelCollection.update(t),m(this._clusterBillboardCollection)&&this._clusterBillboardCollection.update(t),m(this._clusterPointCollection)&&this._clusterPointCollection.update(t),m(this._labelCollection)&&this._labelCollection.update(t),m(this._billboardCollection)&&this._billboardCollection.update(t),m(this._pointCollection)&&this._pointCollection.update(t)};Va.prototype.destroy=function(){this._labelCollection=this._labelCollection&&this._labelCollection.destroy(),this._billboardCollection=this._billboardCollection&&this._billboardCollection.destroy(),this._pointCollection=this._pointCollection&&this._pointCollection.destroy(),this._clusterLabelCollection=this._clusterLabelCollection&&this._clusterLabelCollection.destroy(),this._clusterBillboardCollection=this._clusterBillboardCollection&&this._clusterBillboardCollection.destroy(),this._clusterPointCollection=this._clusterPointCollection&&this._clusterPointCollection.destroy(),m(this._removeEventListener)&&(this._removeEventListener(),this._removeEventListener=void 0),this._labelCollection=void 0,this._billboardCollection=void 0,this._pointCollection=void 0,this._clusterBillboardCollection=void 0,this._clusterLabelCollection=void 0,this._clusterPointCollection=void 0,this._collectionIndicesByEntity=void 0,this._unusedLabelIndices=[],this._unusedBillboardIndices=[],this._unusedPointIndices=[],this._previousClusters=[],this._previousHeight=void 0,this._enabledDirty=!1,this._pixelRangeDirty=!1,this._minimumClusterSizeDirty=!1};sw=Va});function Bl(){this._array=[],this._hash={}}var wE,rw=S(()=>{mt();Ot();Object.defineProperties(Bl.prototype,{length:{get:function(){return this._array.length}},values:{get:function(){return this._array}}});Bl.prototype.contains=function(t){if(typeof t!="string"&&typeof t!="number")throw new Y("key is required to be a string or number.");return m(this._hash[t])};Bl.prototype.set=function(t,e){if(typeof t!="string"&&typeof t!="number")throw new Y("key is required to be a string or number.");let i=this._hash[t];e!==i&&(this.remove(t),this._hash[t]=e,this._array.push(e))};Bl.prototype.get=function(t){if(typeof t!="string"&&typeof t!="number")throw new Y("key is required to be a string or number.");return this._hash[t]};Bl.prototype.remove=function(t){if(m(t)&&typeof t!="string"&&typeof t!="number")throw new Y("key is required to be a string or number.");let e=this._hash[t],i=m(e);if(i){let n=this._array;n.splice(n.indexOf(e),1),delete this._hash[t]}return i};Bl.prototype.removeAll=function(){let t=this._array;t.length>0&&(this._hash={},t.length=0)};wE=Bl});function Dn(t){t=Z(t,Z.EMPTY_OBJECT),this.start=m(t.start)?Ze.clone(t.start):new Ze,this.stop=m(t.stop)?Ze.clone(t.stop):new Ze,this.data=t.data,this.isStartIncluded=Z(t.isStartIncluded,!0),this.isStopIncluded=Z(t.isStopIncluded,!0)}var xm,NI,lN=S(()=>{ae();Ft();mt();Ot();Or();Object.defineProperties(Dn.prototype,{isEmpty:{get:function(){let t=Ze.compare(this.stop,this.start);return t<0||t===0&&(!this.isStartIncluded||!this.isStopIncluded)}}});xm={start:void 0,stop:void 0,isStartIncluded:void 0,isStopIncluded:void 0,data:void 0};Dn.fromIso8601=function(t,e){p.typeOf.object("options",t),p.typeOf.string("options.iso8601",t.iso8601);let i=t.iso8601.split("/");if(i.length!==2)throw new Y("options.iso8601 is an invalid ISO 8601 interval.");let n=Ze.fromIso8601(i[0]),s=Ze.fromIso8601(i[1]),o=Z(t.isStartIncluded,!0),r=Z(t.isStopIncluded,!0),a=t.data;return m(e)?(e.start=n,e.stop=s,e.isStartIncluded=o,e.isStopIncluded=r,e.data=a,e):(xm.start=n,xm.stop=s,xm.isStartIncluded=o,xm.isStopIncluded=r,xm.data=a,new Dn(xm))};Dn.toIso8601=function(t,e){return p.typeOf.object("timeInterval",t),`${Ze.toIso8601(t.start,e)}/${Ze.toIso8601(t.stop,e)}`};Dn.clone=function(t,e){if(m(t))return m(e)?(e.start=t.start,e.stop=t.stop,e.isStartIncluded=t.isStartIncluded,e.isStopIncluded=t.isStopIncluded,e.data=t.data,e):new Dn(t)};Dn.equals=function(t,e,i){return t===e||m(t)&&m(e)&&(t.isEmpty&&e.isEmpty||t.isStartIncluded===e.isStartIncluded&&t.isStopIncluded===e.isStopIncluded&&Ze.equals(t.start,e.start)&&Ze.equals(t.stop,e.stop)&&(t.data===e.data||m(i)&&i(t.data,e.data)))};Dn.equalsEpsilon=function(t,e,i,n){return i=Z(i,0),t===e||m(t)&&m(e)&&(t.isEmpty&&e.isEmpty||t.isStartIncluded===e.isStartIncluded&&t.isStopIncluded===e.isStopIncluded&&Ze.equalsEpsilon(t.start,e.start,i)&&Ze.equalsEpsilon(t.stop,e.stop,i)&&(t.data===e.data||m(n)&&n(t.data,e.data)))};Dn.intersect=function(t,e,i,n){if(p.typeOf.object("left",t),!m(e))return Dn.clone(Dn.EMPTY,i);let s=t.start,o=t.stop,r=e.start,a=e.stop,h=Ze.greaterThanOrEquals(r,s)&&Ze.greaterThanOrEquals(o,r),A=!h&&Ze.lessThanOrEquals(r,s)&&Ze.lessThanOrEquals(s,a);if(!h&&!A)return Dn.clone(Dn.EMPTY,i);let d=t.isStartIncluded,f=t.isStopIncluded,E=e.isStartIncluded,_=e.isStopIncluded,R=Ze.lessThan(o,a);return m(i)||(i=new Dn),i.start=h?r:s,i.isStartIncluded=d&&E||!Ze.equals(r,s)&&(h&&E||A&&d),i.stop=R?o:a,i.isStopIncluded=R?f:f&&_||!Ze.equals(a,o)&&_,i.data=m(n)?n(t.data,e.data):t.data,i};Dn.contains=function(t,e){if(p.typeOf.object("timeInterval",t),p.typeOf.object("julianDate",e),t.isEmpty)return!1;let i=Ze.compare(t.start,e);if(i===0)return t.isStartIncluded;let n=Ze.compare(e,t.stop);return n===0?t.isStopIncluded:i<0&&n<0};Dn.prototype.clone=function(t){return Dn.clone(this,t)};Dn.prototype.equals=function(t,e){return Dn.equals(this,t,e)};Dn.prototype.equalsEpsilon=function(t,e,i){return Dn.equalsEpsilon(this,t,e,i)};Dn.prototype.toString=function(){return Dn.toIso8601(this)};Dn.EMPTY=Object.freeze(new Dn({start:new Ze,stop:new Ze,isStartIncluded:!1,isStopIncluded:!1}));NI=Dn});var aw,Aw,ait,Ait,dh,hw=S(()=>{Or();lN();aw=Object.freeze(Ze.fromIso8601("0000-01-01T00:00:00Z")),Aw=Object.freeze(Ze.fromIso8601("9999-12-31T24:00:00Z")),ait=Object.freeze(new NI({start:aw,stop:Aw})),Ait={MINIMUM_VALUE:aw,MAXIMUM_VALUE:Aw,MAXIMUM_INTERVAL:ait},dh=Ait});function Ic(t){t=Z(t,Z.EMPTY_OBJECT),this._ellipsoid=Z(t.ellipsoid,ot.WGS84),this._rectangle=Z(t.rectangle,Xt.MAX_VALUE),this._projection=new Ss(this._ellipsoid),this._numberOfLevelZeroTilesX=Z(t.numberOfLevelZeroTilesX,2),this._numberOfLevelZeroTilesY=Z(t.numberOfLevelZeroTilesY,1)}var cw,lw=S(()=>{Xe();ae();Ft();mt();Oe();zA();_e();pn();Object.defineProperties(Ic.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},rectangle:{get:function(){return this._rectangle}},projection:{get:function(){return this._projection}}});Ic.prototype.getNumberOfXTilesAtLevel=function(t){return this._numberOfLevelZeroTilesX<<t};Ic.prototype.getNumberOfYTilesAtLevel=function(t){return this._numberOfLevelZeroTilesY<<t};Ic.prototype.rectangleToNativeRectangle=function(t,e){p.defined("rectangle",t);let i=L.toDegrees(t.west),n=L.toDegrees(t.south),s=L.toDegrees(t.east),o=L.toDegrees(t.north);return m(e)?(e.west=i,e.south=n,e.east=s,e.north=o,e):new Xt(i,n,s,o)};Ic.prototype.tileXYToNativeRectangle=function(t,e,i,n){let s=this.tileXYToRectangle(t,e,i,n);return s.west=L.toDegrees(s.west),s.south=L.toDegrees(s.south),s.east=L.toDegrees(s.east),s.north=L.toDegrees(s.north),s};Ic.prototype.tileXYToRectangle=function(t,e,i,n){let s=this._rectangle,o=this.getNumberOfXTilesAtLevel(i),r=this.getNumberOfYTilesAtLevel(i),a=s.width/o,h=t*a+s.west,A=(t+1)*a+s.west,d=s.height/r,f=s.north-e*d,E=s.north-(e+1)*d;return m(n)||(n=new Xt(h,E,A,f)),n.west=h,n.south=E,n.east=A,n.north=f,n};Ic.prototype.positionToTileXY=function(t,e,i){let n=this._rectangle;if(!Xt.contains(n,t))return;let s=this.getNumberOfXTilesAtLevel(e),o=this.getNumberOfYTilesAtLevel(e),r=n.width/s,a=n.height/o,h=t.longitude;n.east<n.west&&(h+=L.TWO_PI);let A=(h-n.west)/r|0;A>=s&&(A=s-1);let d=(n.north-t.latitude)/a|0;return d>=o&&(d=o-1),m(i)?(i.x=A,i.y=d,i):new nt(A,d)};cw=Ic});function _w(t){ut.fromRadians(t.east,t.north,0,xE[0]),ut.fromRadians(t.west,t.north,0,xE[1]),ut.fromRadians(t.east,t.south,0,xE[2]),ut.fromRadians(t.west,t.south,0,xE[3]);let e=0,i=0,n=0,s=0,o=Kn._terrainHeightsMaxLevel,r;for(r=0;r<=o;++r){let a=!1;for(let h=0;h<4;++h){let A=xE[h];if(cit.positionToTileXY(A,r,PE),h===0)n=PE.x,s=PE.y;else if(n!==PE.x||s!==PE.y){a=!0;break}}if(a)break;e=n,i=s}if(r!==0)return{x:e,y:i,level:r>o?o:r-1}}var dw,mw,fw,dN,hit,Ew,cit,xE,PE,Kn,Do,JE=S(()=>{_i();PZ();Xe();Ht();ri();ae();Ft();mt();Ot();Oe();lw();pn();Ia();yZ();dw=new l,mw=new l,fw=new ut,dN=new l,hit=new l,Ew=new Nt,cit=new cw,xE=[new ut,new ut,new ut,new ut],PE=new nt,Kn={};Kn.initialize=function(){let t=Kn._initPromise;return m(t)||(t=tn.fetchJson(th("Assets/approximateTerrainHeights.json")).then(function(e){Kn._terrainHeights=e}),Kn._initPromise=t),t};Kn.getMinimumMaximumHeights=function(t,e){if(p.defined("rectangle",t),!m(Kn._terrainHeights))throw new Y("You must call ApproximateTerrainHeights.initialize and wait for the promise to resolve before using this function");e=Z(e,ot.WGS84);let i=_w(t),n=Kn._defaultMinTerrainHeight,s=Kn._defaultMaxTerrainHeight;if(m(i)){let o=`${i.level}-${i.x}-${i.y}`,r=Kn._terrainHeights[o];m(r)&&(n=r[0],s=r[1]),e.cartographicToCartesian(Xt.northeast(t,fw),dw),e.cartographicToCartesian(Xt.southwest(t,fw),mw),l.midpoint(mw,dw,dN);let a=e.scaleToGeodeticSurface(dN,hit);if(m(a)){let h=l.distance(dN,a);n=Math.min(n,-h)}else n=Kn._defaultMinTerrainHeight}return n=Math.max(Kn._defaultMinTerrainHeight,n),{minimumTerrainHeight:n,maximumTerrainHeight:s}};Kn.getBoundingSphere=function(t,e){if(p.defined("rectangle",t),!m(Kn._terrainHeights))throw new Y("You must call ApproximateTerrainHeights.initialize and wait for the promise to resolve before using this function");e=Z(e,ot.WGS84);let i=_w(t),n=Kn._defaultMaxTerrainHeight;if(m(i)){let o=`${i.level}-${i.x}-${i.y}`,r=Kn._terrainHeights[o];m(r)&&(n=r[1])}let s=Nt.fromRectangle3D(t,e,0);return Nt.fromRectangle3D(t,e,n,Ew),Nt.union(s,Ew,s)};Kn._terrainHeightsMaxLevel=6;Kn._defaultMaxTerrainHeight=9e3;Kn._defaultMinTerrainHeight=-1e5;Kn._terrainHeights=LZ?LZ:void 0;Kn._initPromise=LZ?new Promise(function(t){t()}):void 0;Object.defineProperties(Kn,{initialized:{get:function(){return m(Kn._terrainHeights)}}});Do=Kn});function lit(t){if(t=Z(t,Z.EMPTY_OBJECT),!m(t.geometry))throw new Y("options.geometry is required.");this.geometry=t.geometry,this.modelMatrix=at.clone(Z(t.modelMatrix,at.IDENTITY)),this.id=t.id,this.pickPrimitive=t.pickPrimitive,this.attributes=Z(t.attributes,{}),this.westHemisphereGeometry=void 0,this.eastHemisphereGeometry=void 0}var Ln,uA=S(()=>{Ft();mt();Ot();bi();Ln=lit});function dit(t){if(t=Z(t,Z.EMPTY_OBJECT),!m(t.componentDatatype))throw new Y("options.componentDatatype is required.");if(!m(t.componentsPerAttribute))throw new Y("options.componentsPerAttribute is required.");if(t.componentsPerAttribute<1||t.componentsPerAttribute>4)throw new Y("options.componentsPerAttribute must be between 1 and 4.");if(!m(t.value))throw new Y("options.value is required.");this.componentDatatype=t.componentDatatype,this.componentsPerAttribute=t.componentsPerAttribute,this.normalize=Z(t.normalize,!1),this.value=t.value}var Zr,mN=S(()=>{Ft();mt();Ot();Zr=dit});var mit,ti,Gl=S(()=>{mit={NONE:0,GEODESIC:1,RHUMB:2},ti=Object.freeze(mit)});function fit(t,e,i,n){if(p.defined("equalsEpsilon",e),!m(t))return;i=Z(i,!1);let s=m(n),o=t.length;if(o<2)return t;let r,a=t[0],h,A,d=0,f=-1;for(r=1;r<o;++r)h=t[r],e(a,h,Rw)?(m(A)||(A=t.slice(0,r),d=r-1,f=0),s&&n.push(r)):(m(A)&&(A.push(h),d=r,s&&(f=n.length)),a=h);return i&&e(t[0],t[o-1],Rw)&&(s&&(m(A)?n.splice(f,0,d):n.push(o-1)),m(A)?A.length-=1:A=t.slice(0,-1)),m(A)?A:t}var Rw,Xn,Sa=S(()=>{ae();Ft();mt();_e();Rw=L.EPSILON10;Xn=fit});function Eit(t){let e=t._uSquared,i=t._ellipsoid.maximumRadius,n=t._ellipsoid.minimumRadius,s=(i-n)/i,o=Math.cos(t._startHeading),r=Math.sin(t._startHeading),a=(1-s)*Math.tan(t._start.latitude),h=1/Math.sqrt(1+a*a),A=h*a,d=Math.atan2(a,o),f=h*r,E=f*f,_=1-E,R=Math.sqrt(_),I=e/4,C=I*I,N=C*I,T=C*C,b=1+I-3*C/4+5*N/4-175*T/64,F=1-I+15*C/8-35*N/8,B=1-3*I+35*C/4,U=1-5*I,Q=b*d-F*Math.sin(2*d)*I/2-B*Math.sin(4*d)*C/16-U*Math.sin(6*d)*N/48-Math.sin(8*d)*5*T/512,M=t._constants;M.a=i,M.b=n,M.f=s,M.cosineHeading=o,M.sineHeading=r,M.tanU=a,M.cosineU=h,M.sineU=A,M.sigma=d,M.sineAlpha=f,M.sineSquaredAlpha=E,M.cosineSquaredAlpha=_,M.cosineAlpha=R,M.u2Over4=I,M.u4Over16=C,M.u6Over64=N,M.u8Over256=T,M.a0=b,M.a1=F,M.a2=B,M.a3=U,M.distanceRatio=Q}function _it(t,e){return t*e*(4+t*(4-3*e))/16}function Zw(t,e,i,n,s,o,r){let a=_it(t,i);return(1-a)*t*e*(n+a*s*(r+a*o*(2*r*r-1)))}function Rit(t,e,i,n,s,o,r){let a=(e-i)/e,h=o-n,A=Math.atan((1-a)*Math.tan(s)),d=Math.atan((1-a)*Math.tan(r)),f=Math.cos(A),E=Math.sin(A),_=Math.cos(d),R=Math.sin(d),I=f*_,C=f*R,N=E*R,T=E*_,b=h,F=L.TWO_PI,B=Math.cos(b),U=Math.sin(b),Q,M,k,y,c;do{B=Math.cos(b),U=Math.sin(b);let tt=C-T*B;k=Math.sqrt(_*_*U*U+tt*tt),M=N+I*B,Q=Math.atan2(k,M);let G;k===0?(G=0,y=1):(G=I*U/k,y=1-G*G),F=b,c=M-2*N/y,isFinite(c)||(c=0),b=h+Zw(a,G,y,Q,k,M,c)}while(Math.abs(b-F)>L.EPSILON12);let g=y*(e*e-i*i)/(i*i),O=1+g*(4096+g*(g*(320-175*g)-768))/16384,D=g*(256+g*(g*(74-47*g)-128))/1024,w=c*c,x=D*k*(c+D*(M*(2*w-1)-D*c*(4*k*k-3)*(4*w-3)/6)/4),H=i*O*(Q-x),j=Math.atan2(_*U,C-T*B),X=Math.atan2(f*U,C*B-T);t._distance=H,t._startHeading=j,t._endHeading=X,t._uSquared=g}function Iw(t,e,i,n){let s=l.normalize(n.cartographicToCartesian(e,fN),Zit),o=l.normalize(n.cartographicToCartesian(i,fN),fN);p.typeOf.number.greaterThanOrEquals("value",Math.abs(Math.abs(l.angleBetween(s,o))-Math.PI),.0125),Rit(t,n.maximumRadius,n.minimumRadius,e.longitude,e.latitude,i.longitude,i.latitude),t._start=ut.clone(e,t._start),t._end=ut.clone(i,t._end),t._start.height=0,t._end.height=0,Eit(t)}function jE(t,e,i){let n=Z(i,ot.WGS84);this._ellipsoid=n,this._start=new ut,this._end=new ut,this._constants={},this._startHeading=void 0,this._endHeading=void 0,this._distance=void 0,this._uSquared=void 0,m(t)&&m(e)&&Iw(this,t,e,n)}var Zit,fN,FI,EN=S(()=>{Ht();ri();ae();Ft();mt();Oe();_e();Zit=new l,fN=new l;Object.defineProperties(jE.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},surfaceDistance:{get:function(){return p.defined("distance",this._distance),this._distance}},start:{get:function(){return this._start}},end:{get:function(){return this._end}},startHeading:{get:function(){return p.defined("distance",this._distance),this._startHeading}},endHeading:{get:function(){return p.defined("distance",this._distance),this._endHeading}}});jE.prototype.setEndPoints=function(t,e){p.defined("start",t),p.defined("end",e),Iw(this,t,e,this._ellipsoid)};jE.prototype.interpolateUsingFraction=function(t,e){return this.interpolateUsingSurfaceDistance(this._distance*t,e)};jE.prototype.interpolateUsingSurfaceDistance=function(t,e){p.defined("distance",this._distance);let i=this._constants,n=i.distanceRatio+t/i.b,s=Math.cos(2*n),o=Math.cos(4*n),r=Math.cos(6*n),a=Math.sin(2*n),h=Math.sin(4*n),A=Math.sin(6*n),d=Math.sin(8*n),f=n*n,E=n*f,_=i.u8Over256,R=i.u2Over4,I=i.u6Over64,C=i.u4Over16,N=2*E*_*s/3+n*(1-R+7*C/4-15*I/4+579*_/64-(C-15*I/4+187*_/16)*s-(5*I/4-115*_/16)*o-29*_*r/16)+(R/2-C+71*I/32-85*_/16)*a+(5*C/16-5*I/4+383*_/96)*h-f*((I-11*_/2)*a+5*_*h/2)+(29*I/96-29*_/16)*A+539*_*d/1536,T=Math.asin(Math.sin(N)*i.cosineAlpha),b=Math.atan(i.a/i.b*Math.tan(T));N=N-i.sigma;let F=Math.cos(2*i.sigma+N),B=Math.sin(N),U=Math.cos(N),Q=i.cosineU*U,M=i.sineU*B,y=Math.atan2(B*i.sineHeading,Q-M*i.cosineHeading)-Zw(i.f,i.sineAlpha,i.cosineSquaredAlpha,N,B,U,F);return m(e)?(e.longitude=this._start.longitude+y,e.latitude=b,e.height=0,e):new ut(this._start.longitude+y,b,0)};FI=jE});function RN(t,e,i){if(t===0)return e*i;let n=t*t,s=n*n,o=s*n,r=o*n,a=r*n,h=a*n,A=i,d=Math.sin(2*A),f=Math.sin(4*A),E=Math.sin(6*A),_=Math.sin(8*A),R=Math.sin(10*A),I=Math.sin(12*A);return e*((1-n/4-3*s/64-5*o/256-175*r/16384-441*a/65536-4851*h/1048576)*A-(3*n/8+3*s/32+45*o/1024+105*r/4096+2205*a/131072+6237*h/524288)*d+(15*s/256+45*o/1024+525*r/16384+1575*a/65536+155925*h/8388608)*f-(35*o/3072+175*r/12288+3675*a/262144+13475*h/1048576)*E+(315*r/131072+2205*a/524288+43659*h/8388608)*_-(693*a/1310720+6237*h/5242880)*R+1001*h/8388608*I)}function Iit(t,e,i){let n=t/i;if(e===0)return n;let s=n*n,o=s*n,r=o*n,a=e,h=a*a,A=h*h,d=A*h,f=d*h,E=f*h,_=E*h,R=Math.sin(2*n),I=Math.cos(2*n),C=Math.sin(4*n),N=Math.cos(4*n),T=Math.sin(6*n),b=Math.cos(6*n),F=Math.sin(8*n),B=Math.cos(8*n),U=Math.sin(10*n),Q=Math.cos(10*n),M=Math.sin(12*n);return n+n*h/4+7*n*A/64+15*n*d/256+579*n*f/16384+1515*n*E/65536+16837*n*_/1048576+(3*n*A/16+45*n*d/256-n*(32*s-561)*f/4096-n*(232*s-1677)*E/16384+n*(399985-90560*s+512*r)*_/5242880)*I+(21*n*d/256+483*n*f/4096-n*(224*s-1969)*E/16384-n*(33152*s-112599)*_/1048576)*N+(151*n*f/4096+4681*n*E/65536+1479*n*_/16384-453*o*_/32768)*b+(1097*n*E/65536+42783*n*_/1048576)*B+8011*n*_/1048576*Q+(3*h/8+3*A/16+213*d/2048-3*s*d/64+255*f/4096-33*s*f/512+20861*E/524288-33*s*E/512+r*E/1024+28273*_/1048576-471*s*_/8192+9*r*_/4096)*R+(21*A/256+21*d/256+533*f/8192-21*s*f/512+197*E/4096-315*s*E/4096+584039*_/16777216-12517*s*_/131072+7*r*_/2048)*C+(151*d/6144+151*f/4096+5019*E/131072-453*s*E/16384+26965*_/786432-8607*s*_/131072)*T+(1097*f/131072+1097*E/65536+225797*_/10485760-1097*s*_/65536)*F+(8011*E/2621440+8011*_/1048576)*U+293393*_/251658240*M}function Pm(t,e){if(t===0)return Math.log(Math.tan(.5*(L.PI_OVER_TWO+e)));let i=t*Math.sin(e);return Math.log(Math.tan(.5*(L.PI_OVER_TWO+e)))-t/2*Math.log((1+i)/(1-i))}function pit(t,e,i,n,s){let o=Pm(t._ellipticity,i),r=Pm(t._ellipticity,s);return Math.atan2(L.negativePiToPi(n-e),r-o)}function uit(t,e,i,n,s,o,r){let a=t._heading,h=o-n,A=0;if(L.equalsEpsilon(Math.abs(a),L.PI_OVER_TWO,L.EPSILON8))if(e===i)A=e*Math.cos(s)*L.negativePiToPi(h);else{let d=Math.sin(s);A=e*Math.cos(s)*L.negativePiToPi(h)/Math.sqrt(1-t._ellipticitySquared*d*d)}else{let d=RN(t._ellipticity,e,s);A=(RN(t._ellipticity,e,r)-d)/Math.cos(a)}return Math.abs(A)}function pw(t,e,i,n){let s=l.normalize(n.cartographicToCartesian(e,_N),Cit),o=l.normalize(n.cartographicToCartesian(i,_N),_N);p.typeOf.number.greaterThanOrEquals("value",Math.abs(Math.abs(l.angleBetween(s,o))-Math.PI),.0125);let r=n.maximumRadius,a=n.minimumRadius,h=r*r,A=a*a;t._ellipticitySquared=(h-A)/h,t._ellipticity=Math.sqrt(t._ellipticitySquared),t._start=ut.clone(e,t._start),t._start.height=0,t._end=ut.clone(i,t._end),t._end.height=0,t._heading=pit(t,e.longitude,e.latitude,i.longitude,i.latitude),t._distance=uit(t,n.maximumRadius,n.minimumRadius,e.longitude,e.latitude,i.longitude,i.latitude)}function uw(t,e,i,n,s,o){if(i===0)return ut.clone(t,o);let r=s*s,a,h,A;if(Math.abs(L.PI_OVER_TWO-Math.abs(e))>L.EPSILON8){let d=RN(s,n,t.latitude),f=i*Math.cos(e),E=d+f;if(h=Iit(E,s,n),Math.abs(e)<L.EPSILON10)a=L.negativePiToPi(t.longitude);else{let _=Pm(s,t.latitude),R=Pm(s,h);A=Math.tan(e)*(R-_),a=L.negativePiToPi(t.longitude+A)}}else{h=t.latitude;let d;if(s===0)d=n*Math.cos(t.latitude);else{let f=Math.sin(t.latitude);d=n*Math.cos(t.latitude)/Math.sqrt(1-r*f*f)}A=i/d,e>0?a=L.negativePiToPi(t.longitude+A):a=L.negativePiToPi(t.longitude-A)}return m(o)?(o.longitude=a,o.latitude=h,o.height=0,o):new ut(a,h,0)}function mh(t,e,i){let n=Z(i,ot.WGS84);this._ellipsoid=n,this._start=new ut,this._end=new ut,this._heading=void 0,this._distance=void 0,this._ellipticity=void 0,this._ellipticitySquared=void 0,m(t)&&m(e)&&pw(this,t,e,n)}var Cit,_N,er,HE=S(()=>{Ht();ri();ae();Ft();mt();Ot();Oe();_e();Cit=new l,_N=new l;Object.defineProperties(mh.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},surfaceDistance:{get:function(){return p.defined("distance",this._distance),this._distance}},start:{get:function(){return this._start}},end:{get:function(){return this._end}},heading:{get:function(){return p.defined("distance",this._distance),this._heading}}});mh.fromStartHeadingDistance=function(t,e,i,n,s){p.defined("start",t),p.defined("heading",e),p.defined("distance",i),p.typeOf.number.greaterThan("distance",i,0);let o=Z(n,ot.WGS84),r=o.maximumRadius,a=o.minimumRadius,h=r*r,A=a*a,d=Math.sqrt((h-A)/h);e=L.negativePiToPi(e);let f=uw(t,e,i,o.maximumRadius,d);return!m(s)||m(n)&&!n.equals(s.ellipsoid)?new mh(t,f,o):(s.setEndPoints(t,f),s)};mh.prototype.setEndPoints=function(t,e){p.defined("start",t),p.defined("end",e),pw(this,t,e,this._ellipsoid)};mh.prototype.interpolateUsingFraction=function(t,e){return this.interpolateUsingSurfaceDistance(t*this._distance,e)};mh.prototype.interpolateUsingSurfaceDistance=function(t,e){if(p.typeOf.number("distance",t),!m(this._distance)||this._distance===0)throw new Y("EllipsoidRhumbLine must have distinct start and end set.");return uw(this._start,this._heading,t,this._ellipsoid.maximumRadius,this._ellipticity,e)};mh.prototype.findIntersectionWithLongitude=function(t,e){if(p.typeOf.number("intersectionLongitude",t),!m(this._distance)||this._distance===0)throw new Y("EllipsoidRhumbLine must have distinct start and end set.");let i=this._ellipticity,n=this._heading,s=Math.abs(n),o=this._start;if(t=L.negativePiToPi(t),L.equalsEpsilon(Math.abs(t),Math.PI,L.EPSILON14)&&(t=L.sign(o.longitude)*Math.PI),m(e)||(e=new ut),Math.abs(L.PI_OVER_TWO-s)<=L.EPSILON8)return e.longitude=t,e.latitude=o.latitude,e.height=0,e;if(L.equalsEpsilon(Math.abs(L.PI_OVER_TWO-s),L.PI_OVER_TWO,L.EPSILON8))return L.equalsEpsilon(t,o.longitude,L.EPSILON12)?void 0:(e.longitude=t,e.latitude=L.PI_OVER_TWO*L.sign(L.PI_OVER_TWO-n),e.height=0,e);let r=o.latitude,a=i*Math.sin(r),h=Math.tan(.5*(L.PI_OVER_TWO+r))*Math.exp((t-o.longitude)/Math.tan(n)),A=(1+a)/(1-a),d=o.latitude,f;do{f=d;let E=i*Math.sin(f),_=(1+E)/(1-E);d=2*Math.atan(h*Math.pow(_/A,i/2))-L.PI_OVER_TWO}while(!L.equalsEpsilon(d,f,L.EPSILON12));return e.longitude=t,e.latitude=d,e.height=0,e};mh.prototype.findIntersectionWithLatitude=function(t,e){if(p.typeOf.number("intersectionLatitude",t),!m(this._distance)||this._distance===0)throw new Y("EllipsoidRhumbLine must have distinct start and end set.");let i=this._ellipticity,n=this._heading,s=this._start;if(L.equalsEpsilon(Math.abs(n),L.PI_OVER_TWO,L.EPSILON8))return;let o=Pm(i,s.latitude),r=Pm(i,t),a=Math.tan(n)*(r-o),h=L.negativePiToPi(s.longitude+a);return m(e)?(e.longitude=h,e.latitude=t,e.height=0,e):new ut(h,t,0)};er=mh});function git(t){if(t=Z(t,Z.EMPTY_OBJECT),!m(t.componentDatatype))throw new Y("options.componentDatatype is required.");if(!m(t.componentsPerAttribute))throw new Y("options.componentsPerAttribute is required.");if(t.componentsPerAttribute<1||t.componentsPerAttribute>4)throw new Y("options.componentsPerAttribute must be between 1 and 4.");if(!m(t.values))throw new Y("options.values is required.");this.componentDatatype=t.componentDatatype,this.componentsPerAttribute=t.componentsPerAttribute,this.normalize=Z(t.normalize,!1),this.values=t.values}var Tt,ji=S(()=>{Ft();mt();Ot();Tt=git});function Cw(t,e,i){let n=t+e;return L.sign(t)!==L.sign(e)&&Math.abs(n/Math.max(Math.abs(t),Math.abs(e)))<i?0:n}var ZN,Pr,bI=S(()=>{Ot();_e();ZN={};ZN.computeDiscriminant=function(t,e,i){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");return e*e-4*t*i};ZN.computeRealRoots=function(t,e,i){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");let n;if(t===0)return e===0?[]:[-i/e];if(e===0){if(i===0)return[0,0];let h=Math.abs(i),A=Math.abs(t);if(h<A&&h/A<L.EPSILON14)return[0,0];if(h>A&&A/h<L.EPSILON14)return[];if(n=-i/t,n<0)return[];let d=Math.sqrt(n);return[-d,d]}else if(i===0)return n=-e/t,n<0?[n,0]:[0,n];let s=e*e,o=4*t*i,r=Cw(s,-o,L.EPSILON14);if(r<0)return[];let a=-.5*Cw(e,L.sign(e)*Math.sqrt(r),L.EPSILON14);return e>0?[a/t,i/a]:[i/a,a/t]};Pr=ZN});function IN(t,e,i,n){let s=t,o=e/3,r=i/3,a=n,h=s*r,A=o*a,d=o*o,f=r*r,E=s*r-d,_=s*a-o*r,R=o*a-f,I=4*E*R-_*_,C,N;if(I<0){let G,It,gt;d*A>=h*f?(G=s,It=E,gt=-2*o*E+s*_):(G=a,It=R,gt=-a*_+2*r*R);let Ut=-(gt<0?-1:1)*Math.abs(G)*Math.sqrt(-I);N=-gt+Ut;let Ct=N/2,zt=Ct<0?-Math.pow(-Ct,1/3):Math.pow(Ct,1/3),kt=N===Ut?-zt:-It/zt;return C=It<=0?zt+kt:-gt/(zt*zt+kt*kt+It),d*A>=h*f?[(C-o)/s]:[-a/(C+r)]}let T=E,b=-2*o*E+s*_,F=R,B=-a*_+2*r*R,U=Math.sqrt(I),Q=Math.sqrt(3)/2,M=Math.abs(Math.atan2(s*U,-b)/3);C=2*Math.sqrt(-T);let k=Math.cos(M);N=C*k;let y=C*(-k/2-Q*Math.sin(M)),c=N+y>2*o?N-o:y-o,g=s,O=c/g;M=Math.abs(Math.atan2(a*U,-B)/3),C=2*Math.sqrt(-F),k=Math.cos(M),N=C*k,y=C*(-k/2-Q*Math.sin(M));let D=-a,w=N+y<2*r?N+r:y+r,x=D/w,H=g*w,j=-c*w-g*D,X=c*D,tt=(r*j-o*X)/(-o*j+r*H);return O<=tt?O<=x?tt<=x?[O,tt,x]:[O,x,tt]:[x,O,tt]:O<=x?[tt,O,x]:tt<=x?[tt,x,O]:[x,tt,O]}var pN,YI,gw=S(()=>{Ot();bI();pN={};pN.computeDiscriminant=function(t,e,i,n){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");if(typeof n!="number")throw new Y("d is a required number.");let s=t*t,o=e*e,r=i*i,a=n*n;return 18*t*e*i*n+o*r-27*s*a-4*(t*r*i+o*e*n)};pN.computeRealRoots=function(t,e,i,n){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");if(typeof n!="number")throw new Y("d is a required number.");let s,o;if(t===0)return Pr.computeRealRoots(e,i,n);if(e===0){if(i===0){if(n===0)return[0,0,0];o=-n/t;let r=o<0?-Math.pow(-o,1/3):Math.pow(o,1/3);return[r,r,r]}else if(n===0)return s=Pr.computeRealRoots(t,0,i),s.Length===0?[0]:[s[0],0,s[1]];return IN(t,0,i,n)}else{if(i===0)return n===0?(o=-e/t,o<0?[o,0,0]:[0,0,o]):IN(t,e,0,n);if(n===0)return s=Pr.computeRealRoots(t,e,i),s.length===0?[0]:s[1]<=0?[s[0],s[1],0]:s[0]>=0?[0,s[0],s[1]]:[s[0],0,s[1]]}return IN(t,e,i,n)};YI=pN});function Oa(t,e,i,n){let s=t*t,o=e-3*s/8,r=i-e*t/2+s*t/8,a=n-i*t/4+e*s/16-3*s*s/256,h=YI.computeRealRoots(1,2*o,o*o-4*a,-r*r);if(h.length>0){let A=-t/4,d=h[h.length-1];if(Math.abs(d)<L.EPSILON14){let f=Pr.computeRealRoots(1,o,a);if(f.length===2){let E=f[0],_=f[1],R;if(E>=0&&_>=0){let I=Math.sqrt(E),C=Math.sqrt(_);return[A-C,A-I,A+I,A+C]}else{if(E>=0&&_<0)return R=Math.sqrt(E),[A-R,A+R];if(E<0&&_>=0)return R=Math.sqrt(_),[A-R,A+R]}}return[]}else if(d>0){let f=Math.sqrt(d),E=(o+d-r/f)/2,_=(o+d+r/f)/2,R=Pr.computeRealRoots(1,f,E),I=Pr.computeRealRoots(1,-f,_);return R.length!==0?(R[0]+=A,R[1]+=A,I.length!==0?(I[0]+=A,I[1]+=A,R[1]<=I[0]?[R[0],R[1],I[0],I[1]]:I[1]<=R[0]?[I[0],I[1],R[0],R[1]]:R[0]>=I[0]&&R[1]<=I[1]?[I[0],R[0],R[1],I[1]]:I[0]>=R[0]&&I[1]<=R[1]?[R[0],I[0],I[1],R[1]]:R[0]>I[0]&&R[0]<I[1]?[I[0],R[0],I[1],R[1]]:[R[0],I[0],R[1],I[1]]):R):I.length!==0?(I[0]+=A,I[1]+=A,I):[]}}return[]}function vE(t,e,i,n){let s=i*i,o=e*e,r=t*t,a=-2*e,h=i*t+o-4*n,A=r*n-i*e*t+s,d=YI.computeRealRoots(1,a,h,A);if(d.length>0){let f=d[0],E=e-f,_=E*E,R=t/2,I=E/2,C=_-4*n,N=_+4*Math.abs(n),T=r-4*f,b=r+4*Math.abs(f),F,B;if(f<0||C*b<T*N){let g=Math.sqrt(T);F=g/2,B=g===0?0:(t*I-i)/g}else{let g=Math.sqrt(C);F=g===0?0:(t*I-i)/g,B=g/2}let U,Q;R===0&&F===0?(U=0,Q=0):L.sign(R)===L.sign(F)?(U=R+F,Q=f/U):(Q=R-F,U=f/Q);let M,k;I===0&&B===0?(M=0,k=0):L.sign(I)===L.sign(B)?(M=I+B,k=n/M):(k=I-B,M=n/k);let y=Pr.computeRealRoots(1,U,M),c=Pr.computeRealRoots(1,Q,k);if(y.length!==0)return c.length!==0?y[1]<=c[0]?[y[0],y[1],c[0],c[1]]:c[1]<=y[0]?[c[0],c[1],y[0],y[1]]:y[0]>=c[0]&&y[1]<=c[1]?[c[0],y[0],y[1],c[1]]:c[0]>=y[0]&&c[1]<=y[1]?[y[0],c[0],c[1],y[1]]:y[0]>c[0]&&y[0]<c[1]?[c[0],y[0],c[1],y[1]]:[y[0],c[0],y[1],c[1]]:y;if(c.length!==0)return c}return[]}var uN,Tw,Nw=S(()=>{gw();Ot();_e();bI();uN={};uN.computeDiscriminant=function(t,e,i,n,s){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");if(typeof n!="number")throw new Y("d is a required number.");if(typeof s!="number")throw new Y("e is a required number.");let o=t*t,r=o*t,a=e*e,h=a*e,A=i*i,d=A*i,f=n*n,E=f*n,_=s*s,R=_*s;return a*A*f-4*h*E-4*t*d*f+18*t*e*i*E-27*o*f*f+256*r*R+s*(18*h*i*n-4*a*d+16*t*A*A-80*t*e*A*n-6*t*a*f+144*o*i*f)+_*(144*t*a*i-27*a*a-128*o*A-192*o*e*n)};uN.computeRealRoots=function(t,e,i,n,s){if(typeof t!="number")throw new Y("a is a required number.");if(typeof e!="number")throw new Y("b is a required number.");if(typeof i!="number")throw new Y("c is a required number.");if(typeof n!="number")throw new Y("d is a required number.");if(typeof s!="number")throw new Y("e is a required number.");if(Math.abs(t)<L.EPSILON15)return YI.computeRealRoots(e,i,n,s);let o=e/t,r=i/t,a=n/t,h=s/t,A=o<0?1:0;switch(A+=r<0?A+1:A,A+=a<0?A+1:A,A+=h<0?A+1:A,A){case 0:return Oa(o,r,a,h);case 1:return vE(o,r,a,h);case 2:return vE(o,r,a,h);case 3:return Oa(o,r,a,h);case 4:return Oa(o,r,a,h);case 5:return vE(o,r,a,h);case 6:return Oa(o,r,a,h);case 7:return Oa(o,r,a,h);case 8:return vE(o,r,a,h);case 9:return Oa(o,r,a,h);case 10:return Oa(o,r,a,h);case 11:return vE(o,r,a,h);case 12:return Oa(o,r,a,h);case 13:return Oa(o,r,a,h);case 14:return Oa(o,r,a,h);case 15:return Oa(o,r,a,h);default:return}};Tw=uN});function VI(t,e){e=l.clone(Z(e,l.ZERO)),l.equals(e,l.ZERO)||l.normalize(e,e),this.origin=l.clone(Z(t,l.ZERO)),this.direction=e}var Wl,SI=S(()=>{Ht();ae();Ft();mt();VI.clone=function(t,e){if(m(t))return m(e)?(e.origin=l.clone(t.origin),e.direction=l.clone(t.direction),e):new VI(t.origin,t.direction)};VI.getPoint=function(t,e,i){return p.typeOf.object("ray",t),p.typeOf.number("t",e),m(i)||(i=new l),i=l.multiplyByScalar(t.direction,e,i),l.add(t.origin,i,i)};Wl=VI});function bit(t,e,i,n){let s=e*e-4*t*i;if(s<0)return;if(s>0){let r=1/(2*t),a=Math.sqrt(s),h=(-e+a)*r,A=(-e-a)*r;return h<A?(n.root0=h,n.root1=A):(n.root0=A,n.root1=h),n}let o=-e/(2*t);if(o!==0)return n.root0=n.root1=o,n}function Ww(t,e,i){m(i)||(i=new cA);let n=t.origin,s=t.direction,o=e.center,r=e.radius*e.radius,a=l.subtract(n,o,Gw),h=l.dot(s,s),A=2*l.dot(s,a),d=l.magnitudeSquared(a)-r,f=bit(h,A,d,Yit);if(m(f))return i.start=f.root0,i.stop=f.root1,i}function Dl(t,e,i){let n=t+e;return L.sign(t)!==L.sign(e)&&Math.abs(n/Math.max(Math.abs(t),Math.abs(e)))<i?0:n}var Vn,Tit,Nit,Gw,Fw,bw,Fit,Yit,Vit,Sit,Oit,CN,Yw,Vw,OI,Bit,Git,Wit,Dit,Uit,Mit,Sw,Ow,Bw,Qit,kit,Lit,no,Ul=S(()=>{Ht();ri();Ft();mt();Ot();HZ();_e();dn();bI();Nw();SI();Vn={};Vn.rayPlane=function(t,e,i){if(!m(t))throw new Y("ray is required.");if(!m(e))throw new Y("plane is required.");m(i)||(i=new l);let n=t.origin,s=t.direction,o=e.normal,r=l.dot(o,s);if(Math.abs(r)<L.EPSILON15)return;let a=(-e.distance-l.dot(o,n))/r;if(!(a<0))return i=l.multiplyByScalar(s,a,i),l.add(n,i,i)};Tit=new l,Nit=new l,Gw=new l,Fw=new l,bw=new l;Vn.rayTriangleParametric=function(t,e,i,n,s){if(!m(t))throw new Y("ray is required.");if(!m(e))throw new Y("p0 is required.");if(!m(i))throw new Y("p1 is required.");if(!m(n))throw new Y("p2 is required.");s=Z(s,!1);let o=t.origin,r=t.direction,a=l.subtract(i,e,Tit),h=l.subtract(n,e,Nit),A=l.cross(r,h,Gw),d=l.dot(a,A),f,E,_,R,I;if(s){if(d<L.EPSILON6||(f=l.subtract(o,e,Fw),_=l.dot(f,A),_<0||_>d)||(E=l.cross(f,a,bw),R=l.dot(r,E),R<0||_+R>d))return;I=l.dot(h,E)/d}else{if(Math.abs(d)<L.EPSILON6)return;let C=1/d;if(f=l.subtract(o,e,Fw),_=l.dot(f,A)*C,_<0||_>1||(E=l.cross(f,a,bw),R=l.dot(r,E)*C,R<0||_+R>1))return;I=l.dot(h,E)*C}return I};Vn.rayTriangle=function(t,e,i,n,s,o){let r=Vn.rayTriangleParametric(t,e,i,n,s);if(!(!m(r)||r<0))return m(o)||(o=new l),l.multiplyByScalar(t.direction,r,o),l.add(t.origin,o,o)};Fit=new Wl;Vn.lineSegmentTriangle=function(t,e,i,n,s,o,r){if(!m(t))throw new Y("v0 is required.");if(!m(e))throw new Y("v1 is required.");if(!m(i))throw new Y("p0 is required.");if(!m(n))throw new Y("p1 is required.");if(!m(s))throw new Y("p2 is required.");let a=Fit;l.clone(t,a.origin),l.subtract(e,t,a.direction),l.normalize(a.direction,a.direction);let h=Vn.rayTriangleParametric(a,i,n,s,o);if(!(!m(h)||h<0||h>l.distance(t,e)))return m(r)||(r=new l),l.multiplyByScalar(a.direction,h,r),l.add(a.origin,r,r)};Yit={root0:0,root1:0};Vn.raySphere=function(t,e,i){if(!m(t))throw new Y("ray is required.");if(!m(e))throw new Y("sphere is required.");if(i=Ww(t,e,i),!(!m(i)||i.stop<0))return i.start=Math.max(i.start,0),i};Vit=new Wl;Vn.lineSegmentSphere=function(t,e,i,n){if(!m(t))throw new Y("p0 is required.");if(!m(e))throw new Y("p1 is required.");if(!m(i))throw new Y("sphere is required.");let s=Vit;l.clone(t,s.origin);let o=l.subtract(e,t,s.direction),r=l.magnitude(o);if(l.normalize(o,o),n=Ww(s,i,n),!(!m(n)||n.stop<0||n.start>r))return n.start=Math.max(n.start,0),n.stop=Math.min(n.stop,r),n};Sit=new l,Oit=new l;Vn.rayEllipsoid=function(t,e){if(!m(t))throw new Y("ray is required.");if(!m(e))throw new Y("ellipsoid is required.");let i=e.oneOverRadii,n=l.multiplyComponents(i,t.origin,Sit),s=l.multiplyComponents(i,t.direction,Oit),o=l.magnitudeSquared(n),r=l.dot(n,s),a,h,A,d,f;if(o>1){if(r>=0)return;let E=r*r;if(a=o-1,h=l.magnitudeSquared(s),A=h*a,E<A)return;if(E>A){d=r*r-A,f=-r+Math.sqrt(d);let R=f/h,I=a/f;return R<I?new cA(R,I):{start:I,stop:R}}let _=Math.sqrt(a/h);return new cA(_,_)}else if(o<1)return a=o-1,h=l.magnitudeSquared(s),A=h*a,d=r*r-A,f=-r+Math.sqrt(d),new cA(0,f/h);if(r<0)return h=l.magnitudeSquared(s),new cA(0,-r/h)};Vn.quadraticVectorExpression=function(t,e,i,n,s){let o=n*n,r=s*s,a=(t[lt.COLUMN1ROW1]-t[lt.COLUMN2ROW2])*r,h=s*(n*Dl(t[lt.COLUMN1ROW0],t[lt.COLUMN0ROW1],L.EPSILON15)+e.y),A=t[lt.COLUMN0ROW0]*o+t[lt.COLUMN2ROW2]*r+n*e.x+i,d=r*Dl(t[lt.COLUMN2ROW1],t[lt.COLUMN1ROW2],L.EPSILON15),f=s*(n*Dl(t[lt.COLUMN2ROW0],t[lt.COLUMN0ROW2])+e.z),E,_=[];if(f===0&&d===0){if(E=Pr.computeRealRoots(a,h,A),E.length===0)return _;let M=E[0],k=Math.sqrt(Math.max(1-M*M,0));if(_.push(new l(n,s*M,s*-k)),_.push(new l(n,s*M,s*k)),E.length===2){let y=E[1],c=Math.sqrt(Math.max(1-y*y,0));_.push(new l(n,s*y,s*-c)),_.push(new l(n,s*y,s*c))}return _}let R=f*f,I=d*d,C=a*a,N=f*d,T=C+I,b=2*(h*a+N),F=2*A*a+h*h-I+R,B=2*(A*h-N),U=A*A-R;if(T===0&&b===0&&F===0&&B===0)return _;E=Tw.computeRealRoots(T,b,F,B,U);let Q=E.length;if(Q===0)return _;for(let M=0;M<Q;++M){let k=E[M],y=k*k,c=Math.max(1-y,0),g=Math.sqrt(c),O;L.sign(a)===L.sign(A)?O=Dl(a*y+A,h*k,L.EPSILON12):L.sign(A)===L.sign(h*k)?O=Dl(a*y,h*k+A,L.EPSILON12):O=Dl(a*y+h*k,A,L.EPSILON12);let D=Dl(d*k,f,L.EPSILON15),w=O*D;w<0?_.push(new l(n,s*k,s*g)):w>0?_.push(new l(n,s*k,s*-g)):g!==0?(_.push(new l(n,s*k,s*-g)),_.push(new l(n,s*k,s*g)),++M):_.push(new l(n,s*k,s*g))}return _};CN=new l,Yw=new l,Vw=new l,OI=new l,Bit=new l,Git=new lt,Wit=new lt,Dit=new lt,Uit=new lt,Mit=new lt,Sw=new lt,Ow=new lt,Bw=new l,Qit=new l,kit=new ut;Vn.grazingAltitudeLocation=function(t,e){if(!m(t))throw new Y("ray is required.");if(!m(e))throw new Y("ellipsoid is required.");let i=t.origin,n=t.direction;if(!l.equals(i,l.ZERO)){let U=e.geodeticSurfaceNormal(i,CN);if(l.dot(n,U)>=0)return i}let s=m(this.rayEllipsoid(t,e)),o=e.transformPositionToScaledSpace(n,CN),r=l.normalize(o,o),a=l.mostOrthogonalAxis(o,OI),h=l.normalize(l.cross(a,r,Yw),Yw),A=l.normalize(l.cross(r,h,Vw),Vw),d=Git;d[0]=r.x,d[1]=r.y,d[2]=r.z,d[3]=h.x,d[4]=h.y,d[5]=h.z,d[6]=A.x,d[7]=A.y,d[8]=A.z;let f=lt.transpose(d,Wit),E=lt.fromScale(e.radii,Dit),_=lt.fromScale(e.oneOverRadii,Uit),R=Mit;R[0]=0,R[1]=-n.z,R[2]=n.y,R[3]=n.z,R[4]=0,R[5]=-n.x,R[6]=-n.y,R[7]=n.x,R[8]=0;let I=lt.multiply(lt.multiply(f,_,Sw),R,Sw),C=lt.multiply(lt.multiply(I,E,Ow),d,Ow),N=lt.multiplyByVector(I,i,Bit),T=Vn.quadraticVectorExpression(C,l.negate(N,CN),0,0,1),b,F,B=T.length;if(B>0){let U=l.clone(l.ZERO,Qit),Q=Number.NEGATIVE_INFINITY;for(let k=0;k<B;++k){b=lt.multiplyByVector(E,lt.multiplyByVector(d,T[k],Bw),Bw);let y=l.normalize(l.subtract(b,i,OI),OI),c=l.dot(y,n);c>Q&&(Q=c,U=l.clone(b,U))}let M=e.cartesianToCartographic(U,kit);return Q=L.clamp(Q,0,1),F=l.magnitude(l.subtract(U,i,OI))*Math.sqrt(1-Q*Q),F=s?-F:F,M.height=F,e.cartographicToCartesian(M,new l)}};Lit=new l;Vn.lineSegmentPlane=function(t,e,i,n){if(!m(t))throw new Y("endPoint0 is required.");if(!m(e))throw new Y("endPoint1 is required.");if(!m(i))throw new Y("plane is required.");m(n)||(n=new l);let s=l.subtract(e,t,Lit),o=i.normal,r=l.dot(o,s);if(Math.abs(r)<L.EPSILON6)return;let a=l.dot(o,t),h=-(i.distance+a)/r;if(!(h<0||h>1))return l.multiplyByScalar(s,h,n),l.add(t,n,n),n};Vn.trianglePlaneIntersection=function(t,e,i,n){if(!m(t)||!m(e)||!m(i)||!m(n))throw new Y("p0, p1, p2, and plane are required.");let s=n.normal,o=n.distance,r=l.dot(s,t)+o<0,a=l.dot(s,e)+o<0,h=l.dot(s,i)+o<0,A=0;A+=r?1:0,A+=a?1:0,A+=h?1:0;let d,f;if((A===1||A===2)&&(d=new l,f=new l),A===1){if(r)return Vn.lineSegmentPlane(t,e,n,d),Vn.lineSegmentPlane(t,i,n,f),{positions:[t,e,i,d,f],indices:[0,3,4,1,2,4,1,4,3]};if(a)return Vn.lineSegmentPlane(e,i,n,d),Vn.lineSegmentPlane(e,t,n,f),{positions:[t,e,i,d,f],indices:[1,3,4,2,0,4,2,4,3]};if(h)return Vn.lineSegmentPlane(i,t,n,d),Vn.lineSegmentPlane(i,e,n,f),{positions:[t,e,i,d,f],indices:[2,3,4,0,1,4,0,4,3]}}else if(A===2)if(r)if(a){if(!h)return Vn.lineSegmentPlane(t,i,n,d),Vn.lineSegmentPlane(e,i,n,f),{positions:[t,e,i,d,f],indices:[0,1,4,0,4,3,2,3,4]}}else return Vn.lineSegmentPlane(i,e,n,d),Vn.lineSegmentPlane(t,e,n,f),{positions:[t,e,i,d,f],indices:[2,0,4,2,4,3,1,3,4]};else return Vn.lineSegmentPlane(e,t,n,d),Vn.lineSegmentPlane(i,t,n,f),{positions:[t,e,i,d,f],indices:[1,2,4,1,4,3,0,3,4]}};no=Vn});function ir(t){this._ellipsoid=Z(t,ot.WGS84),this._semimajorAxis=this._ellipsoid.maximumRadius,this._oneOverSemimajorAxis=1/this._semimajorAxis}var ks,Ml=S(()=>{Ht();ri();Ft();mt();Ot();Oe();_e();Object.defineProperties(ir.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});ir.mercatorAngleToGeodeticLatitude=function(t){return L.PI_OVER_TWO-2*Math.atan(Math.exp(-t))};ir.geodeticLatitudeToMercatorAngle=function(t){t>ir.MaximumLatitude?t=ir.MaximumLatitude:t<-ir.MaximumLatitude&&(t=-ir.MaximumLatitude);let e=Math.sin(t);return .5*Math.log((1+e)/(1-e))};ir.MaximumLatitude=ir.mercatorAngleToGeodeticLatitude(Math.PI);ir.prototype.project=function(t,e){let i=this._semimajorAxis,n=t.longitude*i,s=ir.geodeticLatitudeToMercatorAngle(t.latitude)*i,o=t.height;return m(e)?(e.x=n,e.y=s,e.z=o,e):new l(n,s,o)};ir.prototype.unproject=function(t,e){if(!m(t))throw new Y("cartesian is required");let i=this._oneOverSemimajorAxis,n=t.x*i,s=ir.mercatorAngleToGeodeticLatitude(t.y*i),o=t.z;return m(e)?(e.longitude=n,e.latitude=s,e.height=o,e):new ut(n,s,o)};ks=ir});function uc(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions;if(!m(e)||e.length<2)throw new Y("At least two positions are required.");if(m(t.arcType)&&t.arcType!==ti.GEODESIC&&t.arcType!==ti.RHUMB)throw new Y("Valid options for arcType are ArcType.GEODESIC and ArcType.RHUMB.");this.width=Z(t.width,1),this._positions=e,this.granularity=Z(t.granularity,9999),this.loop=Z(t.loop,!1),this.arcType=Z(t.arcType,ti.GEODESIC),this._ellipsoid=ot.WGS84,this._projectionIndex=0,this._workerName="createGroundPolylineGeometry",this._scene3DOnly=!1}function VN(t,e,i,n,s){let o=Uo(n,t,0,wit),r=Uo(n,t,i,Uw),a=Uo(n,e,0,Mw),h=fh(r,o,Uw),A=fh(a,o,Mw);return l.cross(A,h,s),l.normalize(s,s)}function gN(t,e,i,n,s,o,r,a,h,A,d){if(s===0)return;let f;o===ti.GEODESIC?f=new FI(t,e,r):o===ti.RHUMB&&(f=new er(t,e,r));let E=f.surfaceDistance;if(E<s)return;let _=VN(t,e,n,r,jit),R=Math.ceil(E/s),I=E/R,C=I,N=R-1,T=a.length;for(let b=0;b<N;b++){let F=f.interpolateUsingSurfaceDistance(C,xit),B=Uo(r,F,i,Pit),U=Uo(r,F,n,Jit);l.pack(_,a,T),l.pack(B,h,T),l.pack(U,A,T),d.push(F.latitude),d.push(F.longitude),T+=3,C+=I}}function Uo(t,e,i,n){return ut.clone(e,TN),TN.height=i,ut.toCartesian(TN,t,n)}function fh(t,e,i){return l.subtract(t,e,i),l.normalize(i,i),i}function Qw(t,e,i,n){return n=fh(t,e,n),n=l.cross(n,i,n),n=l.normalize(n,n),n=l.cross(i,n,n),n}function NN(t,e,i,n,s){let o=fh(i,e,nx),r=Qw(t,e,o,Hit),a=Qw(n,e,o,vit);if(L.equalsEpsilon(l.dot(r,a),Xit,L.EPSILON5))return s=l.cross(o,r,s),s=l.normalize(s,s),s;s=l.add(a,r,s),s=l.normalize(s,s);let h=l.cross(o,s,zit);return l.dot(a,h)<Kit&&(s=l.negate(s,s)),s}function yw(t,e,i,n){let s=fh(i,e,nnt),o=l.dot(s,t);if(o>tx||o<Dw){let r=fh(n,i,nx),a=o<Dw?L.PI_OVER_TWO:-L.PI_OVER_TWO,h=Ae.fromAxisAngle(r,a,ont),A=lt.fromQuaternion(h,snt);return lt.multiplyByVector(A,t,t),!0}return!1}function zE(t,e,i,n,s){let o=ut.toCartesian(e,t._ellipsoid,rnt),r=l.add(o,i,xw),a=!1,h=t._ellipsoid,A=h.cartesianToCartographic(r,ww);Math.abs(e.longitude-A.longitude)>L.PI_OVER_TWO&&(a=!0,r=l.subtract(o,i,xw),A=h.cartesianToCartographic(r,ww)),A.height=0;let d=t.project(A,s);return s=l.subtract(d,n,s),s.z=0,s=l.normalize(s,s),a&&l.negate(s,s),s}function Jw(t,e,i,n,s,o){let r=l.subtract(e,t,ant);l.normalize(r,r);let a=i-ex,h=l.multiplyByScalar(r,a,Pw);l.add(t,h,s);let A=n-ix;h=l.multiplyByScalar(r,A,Pw),l.add(e,h,o)}function WI(t,e){let i=Ki.getPointDistance(DI,t),n=Ki.getPointDistance(DI,e),s=Ant;L.equalsEpsilon(i,0,L.EPSILON2)?(s=fh(e,t,s),l.multiplyByScalar(s,L.EPSILON2,s),l.add(t,s,t)):L.equalsEpsilon(n,0,L.EPSILON2)&&(s=fh(t,e,s),l.multiplyByScalar(s,L.EPSILON2,s),l.add(e,s,e))}function hnt(t,e){let i=Math.abs(t.longitude),n=Math.abs(e.longitude);if(L.equalsEpsilon(i,L.PI,L.EPSILON11)){let s=L.sign(e.longitude);return t.longitude=s*(i-L.EPSILON11),1}else if(L.equalsEpsilon(n,L.PI,L.EPSILON11)){let s=L.sign(t.longitude);return e.longitude=s*(n-L.EPSILON11),2}return 0}function Ynt(t,e,i,n,s,o,r){let a,h,A=e._ellipsoid,d=i.length/3-1,f=d*8,E=f*4,_=d*36,R=f>65535?new Uint32Array(_):new Uint16Array(_),I=new Float64Array(f*3),C=new Float32Array(E),N=new Float32Array(E),T=new Float32Array(E),b=new Float32Array(E),F=new Float32Array(E),B,U,Q,M;r&&(B=new Float32Array(E),U=new Float32Array(E),Q=new Float32Array(E),M=new Float32Array(f*2));let k=o.length/2,y=0,c=sx;c.height=0;let g=ox;g.height=0;let O=jw,D=FN;if(r)for(h=0,a=1;a<k;a++)c.latitude=o[h],c.longitude=o[h+1],g.latitude=o[h+2],g.longitude=o[h+3],O=e.project(c,O),D=e.project(g,D),y+=l.distance(O,D),h+=2;let w=n.length/3;D=l.unpack(n,0,D);let x=0;for(h=3,a=1;a<w;a++)O=l.clone(D,O),D=l.unpack(n,h,D),x+=l.distance(O,D),h+=3;let H;h=3;let j=0,X=0,tt=0,G=0,It=!1,gt=l.unpack(i,0,vw),Yt=l.unpack(n,0,FN),Ut=l.unpack(s,0,zw);if(t){let ce=l.unpack(i,i.length-6,Hw);yw(Ut,ce,gt,Yt)&&(Ut=l.negate(Ut,Ut))}let Ct=0,zt=0,kt=0;for(a=0;a<d;a++){let ce=l.clone(gt,Hw),je=l.clone(Yt,jw),Se=l.clone(Ut,cnt);It&&(Se=l.negate(Se,Se)),gt=l.unpack(i,h,vw),Yt=l.unpack(n,h,FN),Ut=l.unpack(s,h,zw),It=yw(Ut,ce,gt,Yt),c.latitude=o[j],c.longitude=o[j+1],g.latitude=o[j+2],g.longitude=o[j+3];let Ue,Me,Ce,Fe;if(r){let Ci=hnt(c,g);Ue=e.project(c,Rnt),Me=e.project(g,Znt);let Jn=fh(Me,Ue,Xw);Jn.y=Math.abs(Jn.y),Ce=bN,Fe=YN,Ci===0||l.dot(Jn,l.UNIT_Y)>tx?(Ce=zE(e,c,Se,Ue,bN),Fe=zE(e,g,Ut,Me,YN)):Ci===1?(Fe=zE(e,g,Ut,Me,YN),Ce.x=0,Ce.y=L.sign(c.longitude-Math.abs(g.longitude)),Ce.z=0):(Ce=zE(e,c,Se,Ue,bN),Fe.x=0,Fe.y=L.sign(c.longitude-g.longitude),Fe.z=0)}let ni=l.distance(je,Yt),ze=Gn.fromCartesian(ce,Tnt),Be=l.subtract(gt,ce,Int),Mi=l.normalize(Be,Kw),Ri=l.subtract(je,ce,pnt);Ri=l.normalize(Ri,Ri);let si=l.cross(Mi,Ri,Kw);si=l.normalize(si,si);let qe=l.cross(Ri,Se,Cnt);qe=l.normalize(qe,qe);let Oi=l.subtract(Yt,gt,unt);Oi=l.normalize(Oi,Oi);let gn=l.cross(Ut,Oi,gnt);gn=l.normalize(gn,gn);let De=ni/x,Ye=Ct/x,Gi=0,An,Ne,ei,_n=0,hs=0;if(r){Gi=l.distance(Ue,Me),An=Gn.fromCartesian(Ue,Nnt),Ne=l.subtract(Me,Ue,Xw),ei=l.normalize(Ne,Fnt);let Ci=ei.x;ei.x=ei.y,ei.y=-Ci,_n=Gi/y,hs=zt/y}for(H=0;H<8;H++){let Ci=G+H*4,Jn=X+H*2,ls=Ci+3,ao=H<4?1:-1,qi=H===2||H===3||H===6||H===7?1:-1;l.pack(ze.high,C,Ci),C[ls]=Be.x,l.pack(ze.low,N,Ci),N[ls]=Be.y,l.pack(qe,T,Ci),T[ls]=Be.z,l.pack(gn,b,Ci),b[ls]=De*ao,l.pack(si,F,Ci);let hn=Ye*qi;hn===0&&qi<0&&(hn=9),F[ls]=hn,r&&(B[Ci]=An.high.x,B[Ci+1]=An.high.y,B[Ci+2]=An.low.x,B[Ci+3]=An.low.y,Q[Ci]=-Ce.y,Q[Ci+1]=Ce.x,Q[Ci+2]=Fe.y,Q[Ci+3]=-Fe.x,U[Ci]=Ne.x,U[Ci+1]=Ne.y,U[Ci+2]=ei.x,U[Ci+3]=ei.y,M[Jn]=_n*ao,hn=hs*qi,hn===0&&qi<0&&(hn=9),M[Jn+1]=hn)}let Qi=Ent,nn=_nt,ki=mnt,sn=fnt,Cs=Xt.fromCartographicArray(lnt,dnt),cs=Do.getMinimumMaximumHeights(Cs,A),xn=cs.minimumTerrainHeight,Pn=cs.maximumTerrainHeight;kt+=Math.abs(xn),kt+=Math.abs(Pn),Jw(ce,je,xn,Pn,Qi,ki),Jw(gt,Yt,xn,Pn,nn,sn);let Ai=l.multiplyByScalar(si,L.EPSILON5,qw);l.add(Qi,Ai,Qi),l.add(nn,Ai,nn),l.add(ki,Ai,ki),l.add(sn,Ai,sn),WI(Qi,nn),WI(ki,sn),l.pack(Qi,I,tt),l.pack(nn,I,tt+3),l.pack(sn,I,tt+6),l.pack(ki,I,tt+9),Ai=l.multiplyByScalar(si,-2*L.EPSILON5,qw),l.add(Qi,Ai,Qi),l.add(nn,Ai,nn),l.add(ki,Ai,ki),l.add(sn,Ai,sn),WI(Qi,nn),WI(ki,sn),l.pack(Qi,I,tt+12),l.pack(nn,I,tt+15),l.pack(sn,I,tt+18),l.pack(ki,I,tt+21),j+=2,h+=3,X+=16,tt+=24,G+=32,Ct+=ni,zt+=Gi}h=0;let Jt=0;for(a=0;a<d;a++){for(H=0;H<$w;H++)R[h+H]=rx[H]+Jt;Jt+=8,h+=$w}let Wt=bnt;Nt.fromVertices(i,l.ZERO,3,Wt[0]),Nt.fromVertices(n,l.ZERO,3,Wt[1]);let bt=Nt.fromBoundingSpheres(Wt);bt.radius+=kt/(d*2);let ee={position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,normalize:!1,values:I}),startHiAndForwardOffsetX:pc(C),startLoAndForwardOffsetY:pc(N),startNormalAndForwardOffsetZ:pc(T),endNormalAndTextureCoordinateNormalizationX:pc(b),rightNormalAndTextureCoordinateNormalizationY:pc(F)};return r&&(ee.startHiLo2D=pc(B),ee.offsetAndRight2D=pc(U),ee.startEndNormals2D=pc(Q),ee.texcoordNormalization2D=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,normalize:!1,values:M})),new se({attributes:ee,indices:R,boundingSphere:bt})}function pc(t){return new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,values:t})}var SN,yit,tx,Dw,ex,ix,wit,Uw,Mw,xit,Pit,Jit,jit,TN,Hit,vit,zit,nx,Kit,Xit,DI,qit,$it,tnt,ent,int,BI,GI,kw,Lw,nnt,snt,ont,ww,rnt,xw,ant,Pw,Ant,sx,ox,jw,FN,Hw,vw,cnt,zw,lnt,dnt,mnt,fnt,Ent,_nt,Rnt,Znt,bN,YN,Int,pnt,unt,Kw,Cnt,gnt,Tnt,Nnt,Xw,Fnt,qw,bnt,rx,$w,KE,ON=S(()=>{JE();Gl();Sa();_i();Ht();ri();ae();oi();Ft();mt();Ot();Oe();EN();HE();Tl();zA();yi();ji();Ul();_e();dn();nh();$s();pn();Ml();SN=[Ss,ks],yit=SN.length,tx=Math.cos(L.toRadians(30)),Dw=Math.cos(L.toRadians(150)),ex=0,ix=1e3;Object.defineProperties(uc.prototype,{packedLength:{get:function(){return 1+this._positions.length*3+1+1+1+ot.packedLength+1+1}}});uc.setProjectionAndEllipsoid=function(t,e){let i=0;for(let n=0;n<yit;n++)if(e instanceof SN[n]){i=n;break}t._projectionIndex=i,t._ellipsoid=e.ellipsoid};wit=new l,Uw=new l,Mw=new l;xit=new ut,Pit=new l,Jit=new l,jit=new l;TN=new ut;uc.pack=function(t,e,i){p.typeOf.object("value",t),p.defined("array",e);let n=Z(i,0),s=t._positions,o=s.length;e[n++]=o;for(let r=0;r<o;++r){let a=s[r];l.pack(a,e,n),n+=3}return e[n++]=t.granularity,e[n++]=t.loop?1:0,e[n++]=t.arcType,ot.pack(t._ellipsoid,e,n),n+=ot.packedLength,e[n++]=t._projectionIndex,e[n++]=t._scene3DOnly?1:0,e};uc.unpack=function(t,e,i){p.defined("array",t);let n=Z(e,0),s=t[n++],o=new Array(s);for(let E=0;E<s;E++)o[E]=l.unpack(t,n),n+=3;let r=t[n++],a=t[n++]===1,h=t[n++],A=ot.unpack(t,n);n+=ot.packedLength;let d=t[n++],f=t[n++]===1;return m(i)||(i=new uc({positions:o})),i._positions=o,i.granularity=r,i.loop=a,i.arcType=h,i._ellipsoid=A,i._projectionIndex=d,i._scene3DOnly=f,i};Hit=new l,vit=new l,zit=new l,nx=new l,Kit=0,Xit=-1;DI=Ki.fromPointNormal(l.ZERO,l.UNIT_Y),qit=new l,$it=new l,tnt=new l,ent=new l,int=new l,BI=new l,GI=new ut,kw=new ut,Lw=new ut;uc.createGeometry=function(t){let e=!t._scene3DOnly,i=t.loop,n=t._ellipsoid,s=t.granularity,o=t.arcType,r=new SN[t._projectionIndex](n),a=ex,h=ix,A,d,f=t._positions,E=f.length;E===2&&(i=!1);let _,R,I,C,N=new er(void 0,void 0,n),T,b,F,B=[f[0]];for(d=0;d<E-1;d++)_=f[d],R=f[d+1],T=no.lineSegmentPlane(_,R,DI,BI),m(T)&&!l.equalsEpsilon(T,_,L.EPSILON7)&&!l.equalsEpsilon(T,R,L.EPSILON7)&&(t.arcType===ti.GEODESIC?B.push(l.clone(T)):t.arcType===ti.RHUMB&&(F=n.cartesianToCartographic(T,GI).longitude,I=n.cartesianToCartographic(_,GI),C=n.cartesianToCartographic(R,kw),N.setEndPoints(I,C),b=N.findIntersectionWithLongitude(F,Lw),T=n.cartographicToCartesian(b,BI),m(T)&&!l.equalsEpsilon(T,_,L.EPSILON7)&&!l.equalsEpsilon(T,R,L.EPSILON7)&&B.push(l.clone(T)))),B.push(R);i&&(_=f[E-1],R=f[0],T=no.lineSegmentPlane(_,R,DI,BI),m(T)&&!l.equalsEpsilon(T,_,L.EPSILON7)&&!l.equalsEpsilon(T,R,L.EPSILON7)&&(t.arcType===ti.GEODESIC?B.push(l.clone(T)):t.arcType===ti.RHUMB&&(F=n.cartesianToCartographic(T,GI).longitude,I=n.cartesianToCartographic(_,GI),C=n.cartesianToCartographic(R,kw),N.setEndPoints(I,C),b=N.findIntersectionWithLongitude(F,Lw),T=n.cartographicToCartesian(b,BI),m(T)&&!l.equalsEpsilon(T,_,L.EPSILON7)&&!l.equalsEpsilon(T,R,L.EPSILON7)&&B.push(l.clone(T)))));let U=B.length,Q=new Array(U);for(d=0;d<U;d++){let It=ut.fromCartesian(B[d],n);It.height=0,Q[d]=It}if(Q=Xn(Q,ut.equalsEpsilon),U=Q.length,U<2)return;let M=[],k=[],y=[],c=[],g=qit,O=$it,D=tnt,w=ent,x=int,H=Q[0],j=Q[1],X=Q[U-1];for(g=Uo(n,X,a,g),w=Uo(n,j,a,w),O=Uo(n,H,a,O),D=Uo(n,H,h,D),i?x=NN(g,O,D,w,x):x=VN(H,j,h,n,x),l.pack(x,k,0),l.pack(O,y,0),l.pack(D,c,0),M.push(H.latitude),M.push(H.longitude),gN(H,j,a,h,s,o,n,k,y,c,M),d=1;d<U-1;++d){g=l.clone(O,g),O=l.clone(w,O);let It=Q[d];Uo(n,It,h,D),Uo(n,Q[d+1],a,w),NN(g,O,D,w,x),A=k.length,l.pack(x,k,A),l.pack(O,y,A),l.pack(D,c,A),M.push(It.latitude),M.push(It.longitude),gN(Q[d],Q[d+1],a,h,s,o,n,k,y,c,M)}let tt=Q[U-1],G=Q[U-2];if(O=Uo(n,tt,a,O),D=Uo(n,tt,h,D),i){let It=Q[0];g=Uo(n,G,a,g),w=Uo(n,It,a,w),x=NN(g,O,D,w,x)}else x=VN(G,tt,h,n,x);if(A=k.length,l.pack(x,k,A),l.pack(O,y,A),l.pack(D,c,A),M.push(tt.latitude),M.push(tt.longitude),i){for(gN(tt,H,a,h,s,o,n,k,y,c,M),A=k.length,d=0;d<3;++d)k[A+d]=k[d],y[A+d]=y[d],c[A+d]=c[d];M.push(H.latitude),M.push(H.longitude)}return Ynt(i,r,y,c,k,M,e)};nnt=new l,snt=new lt,ont=new Ae;ww=new ut,rnt=new l,xw=new l;ant=new l,Pw=new l;Ant=new l;sx=new ut,ox=new ut,jw=new l,FN=new l,Hw=new l,vw=new l,cnt=new l,zw=new l,lnt=[sx,ox],dnt=new Xt,mnt=new l,fnt=new l,Ent=new l,_nt=new l,Rnt=new l,Znt=new l,bN=new l,YN=new l,Int=new l,pnt=new l,unt=new l,Kw=new l,Cnt=new l,gnt=new l,Tnt=new Gn,Nnt=new Gn,Xw=new l,Fnt=new l,qw=new l,bnt=[new Nt,new Nt],rx=[0,2,1,0,3,2,0,7,3,0,4,7,0,5,4,0,1,5,5,7,4,5,6,7,5,2,6,5,1,2,3,6,2,3,7,6],$w=rx.length;uc._projectNormal=zE;KE=uc});var ax,Ax=S(()=>{ax=`in vec4 v_startPlaneNormalEcAndHalfWidth;
in vec4 v_endPlaneNormalEcAndBatchId;
in vec4 v_rightPlaneEC; // Technically can compute distance for this here
in vec4 v_endEcAndStartEcX;
in vec4 v_texcoordNormalizationAndStartEcYZ;

#ifdef PER_INSTANCE_COLOR
in vec4 v_color;
#endif

void main(void)
{
    float logDepthOrDepth = czm_branchFreeTernary(czm_sceneMode == czm_sceneMode2D, gl_FragCoord.z, czm_unpackDepth(texture(czm_globeDepthTexture, gl_FragCoord.xy / czm_viewport.zw)));
    vec3 ecStart = vec3(v_endEcAndStartEcX.w, v_texcoordNormalizationAndStartEcYZ.zw);

    // Discard for sky
    if (logDepthOrDepth == 0.0) {
#ifdef DEBUG_SHOW_VOLUME
        out_FragColor = vec4(1.0, 0.0, 0.0, 0.5);
        return;
#else // DEBUG_SHOW_VOLUME
        discard;
#endif // DEBUG_SHOW_VOLUME
    }

    vec4 eyeCoordinate = czm_windowToEyeCoordinates(gl_FragCoord.xy, logDepthOrDepth);
    eyeCoordinate /= eyeCoordinate.w;

    float halfMaxWidth = v_startPlaneNormalEcAndHalfWidth.w * czm_metersPerPixel(eyeCoordinate);
    // Check distance of the eye coordinate against the right-facing plane
    float widthwiseDistance = czm_planeDistance(v_rightPlaneEC, eyeCoordinate.xyz);

    // Check eye coordinate against the mitering planes
    float distanceFromStart = czm_planeDistance(v_startPlaneNormalEcAndHalfWidth.xyz, -dot(ecStart, v_startPlaneNormalEcAndHalfWidth.xyz), eyeCoordinate.xyz);
    float distanceFromEnd = czm_planeDistance(v_endPlaneNormalEcAndBatchId.xyz, -dot(v_endEcAndStartEcX.xyz, v_endPlaneNormalEcAndBatchId.xyz), eyeCoordinate.xyz);

    if (abs(widthwiseDistance) > halfMaxWidth || distanceFromStart < 0.0 || distanceFromEnd < 0.0) {
#ifdef DEBUG_SHOW_VOLUME
        out_FragColor = vec4(1.0, 0.0, 0.0, 0.5);
        return;
#else // DEBUG_SHOW_VOLUME
        discard;
#endif // DEBUG_SHOW_VOLUME
    }

    // Check distance of the eye coordinate against start and end planes with normals in the right plane.
    // For computing unskewed lengthwise texture coordinate.
    // Can also be used for clipping extremely pointy miters, but in practice unnecessary because of miter breaking.

    // aligned plane: cross the right plane normal with miter plane normal, then cross the result with right again to point it more "forward"
    vec3 alignedPlaneNormal;

    // start aligned plane
    alignedPlaneNormal = cross(v_rightPlaneEC.xyz, v_startPlaneNormalEcAndHalfWidth.xyz);
    alignedPlaneNormal = normalize(cross(alignedPlaneNormal, v_rightPlaneEC.xyz));
    distanceFromStart = czm_planeDistance(alignedPlaneNormal, -dot(alignedPlaneNormal, ecStart), eyeCoordinate.xyz);

    // end aligned plane
    alignedPlaneNormal = cross(v_rightPlaneEC.xyz, v_endPlaneNormalEcAndBatchId.xyz);
    alignedPlaneNormal = normalize(cross(alignedPlaneNormal, v_rightPlaneEC.xyz));
    distanceFromEnd = czm_planeDistance(alignedPlaneNormal, -dot(alignedPlaneNormal, v_endEcAndStartEcX.xyz), eyeCoordinate.xyz);

#ifdef PER_INSTANCE_COLOR
    out_FragColor = czm_gammaCorrect(v_color);
#else // PER_INSTANCE_COLOR
    // Clamp - distance to aligned planes may be negative due to mitering,
    // so fragment texture coordinate might be out-of-bounds.
    float s = clamp(distanceFromStart / (distanceFromStart + distanceFromEnd), 0.0, 1.0);
    s = (s * v_texcoordNormalizationAndStartEcYZ.x) + v_texcoordNormalizationAndStartEcYZ.y;
    float t = (widthwiseDistance + halfMaxWidth) / (2.0 * halfMaxWidth);

    czm_materialInput materialInput;

    materialInput.s = s;
    materialInput.st = vec2(s, t);
    materialInput.str = vec3(s, t, 0.0);

    czm_material material = czm_getMaterial(materialInput);
    out_FragColor = vec4(material.diffuse + material.emission, material.alpha);
#endif // PER_INSTANCE_COLOR

    // Premultiply alpha. Required for classification primitives on translucent globe.
    out_FragColor.rgb *= out_FragColor.a;

    czm_writeDepthClamp();
}
`});var hx,cx=S(()=>{hx=`in vec3 v_forwardDirectionEC;
in vec3 v_texcoordNormalizationAndHalfWidth;
in float v_batchId;

#ifdef PER_INSTANCE_COLOR
in vec4 v_color;
#else
in vec2 v_alignedPlaneDistances;
in float v_texcoordT;
#endif

float rayPlaneDistanceUnsafe(vec3 origin, vec3 direction, vec3 planeNormal, float planeDistance) {
    // We don't expect the ray to ever be parallel to the plane
    return (-planeDistance - dot(planeNormal, origin)) / dot(planeNormal, direction);
}

void main(void)
{
    vec4 eyeCoordinate = gl_FragCoord;
    eyeCoordinate /= eyeCoordinate.w;

#ifdef PER_INSTANCE_COLOR
    out_FragColor = czm_gammaCorrect(v_color);
#else // PER_INSTANCE_COLOR
    // Use distances for planes aligned with segment to prevent skew in dashing
    float distanceFromStart = rayPlaneDistanceUnsafe(eyeCoordinate.xyz, -v_forwardDirectionEC, v_forwardDirectionEC.xyz, v_alignedPlaneDistances.x);
    float distanceFromEnd = rayPlaneDistanceUnsafe(eyeCoordinate.xyz, v_forwardDirectionEC, -v_forwardDirectionEC.xyz, v_alignedPlaneDistances.y);

    // Clamp - distance to aligned planes may be negative due to mitering
    distanceFromStart = max(0.0, distanceFromStart);
    distanceFromEnd = max(0.0, distanceFromEnd);

    float s = distanceFromStart / (distanceFromStart + distanceFromEnd);
    s = (s * v_texcoordNormalizationAndHalfWidth.x) + v_texcoordNormalizationAndHalfWidth.y;

    czm_materialInput materialInput;

    materialInput.s = s;
    materialInput.st = vec2(s, v_texcoordT);
    materialInput.str = vec3(s, v_texcoordT, 0.0);

    czm_material material = czm_getMaterial(materialInput);
    out_FragColor = vec4(material.diffuse + material.emission, material.alpha);
#endif // PER_INSTANCE_COLOR
}
`});var lx,dx=S(()=>{lx=`in vec3 position3DHigh;
in vec3 position3DLow;

in vec4 startHiAndForwardOffsetX;
in vec4 startLoAndForwardOffsetY;
in vec4 startNormalAndForwardOffsetZ;
in vec4 endNormalAndTextureCoordinateNormalizationX;
in vec4 rightNormalAndTextureCoordinateNormalizationY;
in vec4 startHiLo2D;
in vec4 offsetAndRight2D;
in vec4 startEndNormals2D;
in vec2 texcoordNormalization2D;

in float batchId;

out vec3 v_forwardDirectionEC;
out vec3 v_texcoordNormalizationAndHalfWidth;
out float v_batchId;

// For materials
#ifdef WIDTH_VARYING
out float v_width;
#endif
#ifdef ANGLE_VARYING
out float v_polylineAngle;
#endif

#ifdef PER_INSTANCE_COLOR
out vec4 v_color;
#else
out vec2 v_alignedPlaneDistances;
out float v_texcoordT;
#endif

// Morphing planes using SLERP or NLERP doesn't seem to work, so instead draw the material directly on the shadow volume.
// Morph views are from very far away and aren't meant to be used precisely, so this should be sufficient.
void main()
{
    v_batchId = batchId;

    // Start position
    vec4 posRelativeToEye2D = czm_translateRelativeToEye(vec3(0.0, startHiLo2D.xy), vec3(0.0, startHiLo2D.zw));
    vec4 posRelativeToEye3D = czm_translateRelativeToEye(startHiAndForwardOffsetX.xyz, startLoAndForwardOffsetY.xyz);
    vec4 posRelativeToEye = czm_columbusViewMorph(posRelativeToEye2D, posRelativeToEye3D, czm_morphTime);
    vec3 posEc2D = (czm_modelViewRelativeToEye * posRelativeToEye2D).xyz;
    vec3 posEc3D = (czm_modelViewRelativeToEye * posRelativeToEye3D).xyz;
    vec3 startEC = (czm_modelViewRelativeToEye * posRelativeToEye).xyz;

    // Start plane
    vec4 startPlane2D;
    vec4 startPlane3D;
    startPlane2D.xyz = czm_normal * vec3(0.0, startEndNormals2D.xy);
    startPlane3D.xyz = czm_normal * startNormalAndForwardOffsetZ.xyz;
    startPlane2D.w = -dot(startPlane2D.xyz, posEc2D);
    startPlane3D.w = -dot(startPlane3D.xyz, posEc3D);

    // Right plane
    vec4 rightPlane2D;
    vec4 rightPlane3D;
    rightPlane2D.xyz = czm_normal * vec3(0.0, offsetAndRight2D.zw);
    rightPlane3D.xyz = czm_normal * rightNormalAndTextureCoordinateNormalizationY.xyz;
    rightPlane2D.w = -dot(rightPlane2D.xyz, posEc2D);
    rightPlane3D.w = -dot(rightPlane3D.xyz, posEc3D);

    // End position
    posRelativeToEye2D = posRelativeToEye2D + vec4(0.0, offsetAndRight2D.xy, 0.0);
    posRelativeToEye3D = posRelativeToEye3D + vec4(startHiAndForwardOffsetX.w, startLoAndForwardOffsetY.w, startNormalAndForwardOffsetZ.w, 0.0);
    posRelativeToEye = czm_columbusViewMorph(posRelativeToEye2D, posRelativeToEye3D, czm_morphTime);
    posEc2D = (czm_modelViewRelativeToEye * posRelativeToEye2D).xyz;
    posEc3D = (czm_modelViewRelativeToEye * posRelativeToEye3D).xyz;
    vec3 endEC = (czm_modelViewRelativeToEye * posRelativeToEye).xyz;
    vec3 forwardEc3D = czm_normal * normalize(vec3(startHiAndForwardOffsetX.w, startLoAndForwardOffsetY.w, startNormalAndForwardOffsetZ.w));
    vec3 forwardEc2D = czm_normal * normalize(vec3(0.0, offsetAndRight2D.xy));

    // End plane
    vec4 endPlane2D;
    vec4 endPlane3D;
    endPlane2D.xyz = czm_normal * vec3(0.0, startEndNormals2D.zw);
    endPlane3D.xyz = czm_normal * endNormalAndTextureCoordinateNormalizationX.xyz;
    endPlane2D.w = -dot(endPlane2D.xyz, posEc2D);
    endPlane3D.w = -dot(endPlane3D.xyz, posEc3D);

    // Forward direction
    v_forwardDirectionEC = normalize(endEC - startEC);

    vec2 cleanTexcoordNormalization2D;
    cleanTexcoordNormalization2D.x = abs(texcoordNormalization2D.x);
    cleanTexcoordNormalization2D.y = czm_branchFreeTernary(texcoordNormalization2D.y > 1.0, 0.0, abs(texcoordNormalization2D.y));
    vec2 cleanTexcoordNormalization3D;
    cleanTexcoordNormalization3D.x = abs(endNormalAndTextureCoordinateNormalizationX.w);
    cleanTexcoordNormalization3D.y = rightNormalAndTextureCoordinateNormalizationY.w;
    cleanTexcoordNormalization3D.y = czm_branchFreeTernary(cleanTexcoordNormalization3D.y > 1.0, 0.0, abs(cleanTexcoordNormalization3D.y));

    v_texcoordNormalizationAndHalfWidth.xy = mix(cleanTexcoordNormalization2D, cleanTexcoordNormalization3D, czm_morphTime);

#ifdef PER_INSTANCE_COLOR
    v_color = czm_batchTable_color(batchId);
#else // PER_INSTANCE_COLOR
    // For computing texture coordinates

    v_alignedPlaneDistances.x = -dot(v_forwardDirectionEC, startEC);
    v_alignedPlaneDistances.y = -dot(-v_forwardDirectionEC, endEC);
#endif // PER_INSTANCE_COLOR

#ifdef WIDTH_VARYING
    float width = czm_batchTable_width(batchId);
    float halfWidth = width * 0.5;
    v_width = width;
    v_texcoordNormalizationAndHalfWidth.z = halfWidth;
#else
    float halfWidth = 0.5 * czm_batchTable_width(batchId);
    v_texcoordNormalizationAndHalfWidth.z = halfWidth;
#endif

    // Compute a normal along which to "push" the position out, extending the miter depending on view distance.
    // Position has already been "pushed" by unit length along miter normal, and miter normals are encoded in the planes.
    // Decode the normal to use at this specific vertex, push the position back, and then push to where it needs to be.
    // Since this is morphing, compute both 3D and 2D positions and then blend.

    // ****** 3D ******
    // Check distance to the end plane and start plane, pick the plane that is closer
    vec4 positionEc3D = czm_modelViewRelativeToEye * czm_translateRelativeToEye(position3DHigh, position3DLow); // w = 1.0, see czm_computePosition
    float absStartPlaneDistance = abs(czm_planeDistance(startPlane3D, positionEc3D.xyz));
    float absEndPlaneDistance = abs(czm_planeDistance(endPlane3D, positionEc3D.xyz));
    vec3 planeDirection = czm_branchFreeTernary(absStartPlaneDistance < absEndPlaneDistance, startPlane3D.xyz, endPlane3D.xyz);
    vec3 upOrDown = normalize(cross(rightPlane3D.xyz, planeDirection)); // Points "up" for start plane, "down" at end plane.
    vec3 normalEC = normalize(cross(planeDirection, upOrDown));         // In practice, the opposite seems to work too.

    // Nudge the top vertex upwards to prevent flickering
    vec3 geodeticSurfaceNormal = normalize(cross(normalEC, forwardEc3D));
    geodeticSurfaceNormal *= float(0.0 <= rightNormalAndTextureCoordinateNormalizationY.w && rightNormalAndTextureCoordinateNormalizationY.w <= 1.0);
    geodeticSurfaceNormal *= MAX_TERRAIN_HEIGHT;
    positionEc3D.xyz += geodeticSurfaceNormal;

    // Determine if this vertex is on the "left" or "right"
    normalEC *= sign(endNormalAndTextureCoordinateNormalizationX.w);

    // A "perfect" implementation would push along normals according to the angle against forward.
    // In practice, just pushing the normal out by halfWidth is sufficient for morph views.
    positionEc3D.xyz += halfWidth * max(0.0, czm_metersPerPixel(positionEc3D)) * normalEC; // prevent artifacts when czm_metersPerPixel is negative (behind camera)

    // ****** 2D ******
    // Check distance to the end plane and start plane, pick the plane that is closer
    vec4 positionEc2D = czm_modelViewRelativeToEye * czm_translateRelativeToEye(position2DHigh.zxy, position2DLow.zxy); // w = 1.0, see czm_computePosition
    absStartPlaneDistance = abs(czm_planeDistance(startPlane2D, positionEc2D.xyz));
    absEndPlaneDistance = abs(czm_planeDistance(endPlane2D, positionEc2D.xyz));
    planeDirection = czm_branchFreeTernary(absStartPlaneDistance < absEndPlaneDistance, startPlane2D.xyz, endPlane2D.xyz);
    upOrDown = normalize(cross(rightPlane2D.xyz, planeDirection)); // Points "up" for start plane, "down" at end plane.
    normalEC = normalize(cross(planeDirection, upOrDown));         // In practice, the opposite seems to work too.

    // Nudge the top vertex upwards to prevent flickering
    geodeticSurfaceNormal = normalize(cross(normalEC, forwardEc2D));
    geodeticSurfaceNormal *= float(0.0 <= texcoordNormalization2D.y && texcoordNormalization2D.y <= 1.0);
    geodeticSurfaceNormal *= MAX_TERRAIN_HEIGHT;
    positionEc2D.xyz += geodeticSurfaceNormal;

    // Determine if this vertex is on the "left" or "right"
    normalEC *= sign(texcoordNormalization2D.x);
#ifndef PER_INSTANCE_COLOR
    // Use vertex's sidedness to compute its texture coordinate.
    v_texcoordT = clamp(sign(texcoordNormalization2D.x), 0.0, 1.0);
#endif

    // A "perfect" implementation would push along normals according to the angle against forward.
    // In practice, just pushing the normal out by halfWidth is sufficient for morph views.
    positionEc2D.xyz += halfWidth * max(0.0, czm_metersPerPixel(positionEc2D)) * normalEC; // prevent artifacts when czm_metersPerPixel is negative (behind camera)

    // Blend for actual position
    gl_Position = czm_projection * mix(positionEc2D, positionEc3D, czm_morphTime);

#ifdef ANGLE_VARYING
    // Approximate relative screen space direction of the line.
    vec2 approxLineDirection = normalize(vec2(v_forwardDirectionEC.x, -v_forwardDirectionEC.y));
    approxLineDirection.y = czm_branchFreeTernary(approxLineDirection.x == 0.0 && approxLineDirection.y == 0.0, -1.0, approxLineDirection.y);
    v_polylineAngle = czm_fastApproximateAtan(approxLineDirection.x, approxLineDirection.y);
#endif
}
`});var mx,fx=S(()=>{mx=`in vec3 position3DHigh;
in vec3 position3DLow;

// In 2D and in 3D, texture coordinate normalization component signs encodes:
// * X sign - sidedness relative to right plane
// * Y sign - is negative OR magnitude is greater than 1.0 if vertex is on bottom of volume
#ifndef COLUMBUS_VIEW_2D
in vec4 startHiAndForwardOffsetX;
in vec4 startLoAndForwardOffsetY;
in vec4 startNormalAndForwardOffsetZ;
in vec4 endNormalAndTextureCoordinateNormalizationX;
in vec4 rightNormalAndTextureCoordinateNormalizationY;
#else
in vec4 startHiLo2D;
in vec4 offsetAndRight2D;
in vec4 startEndNormals2D;
in vec2 texcoordNormalization2D;
#endif

in float batchId;

out vec4 v_startPlaneNormalEcAndHalfWidth;
out vec4 v_endPlaneNormalEcAndBatchId;
out vec4 v_rightPlaneEC;
out vec4 v_endEcAndStartEcX;
out vec4 v_texcoordNormalizationAndStartEcYZ;

// For materials
#ifdef WIDTH_VARYING
out float v_width;
#endif
#ifdef ANGLE_VARYING
out float v_polylineAngle;
#endif

#ifdef PER_INSTANCE_COLOR
out vec4 v_color;
#endif

void main()
{
#ifdef COLUMBUS_VIEW_2D
    vec3 ecStart = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(vec3(0.0, startHiLo2D.xy), vec3(0.0, startHiLo2D.zw))).xyz;

    vec3 forwardDirectionEC = czm_normal * vec3(0.0, offsetAndRight2D.xy);
    vec3 ecEnd = forwardDirectionEC + ecStart;
    forwardDirectionEC = normalize(forwardDirectionEC);

    // Right plane
    v_rightPlaneEC.xyz = czm_normal * vec3(0.0, offsetAndRight2D.zw);
    v_rightPlaneEC.w = -dot(v_rightPlaneEC.xyz, ecStart);

    // start plane
    vec4 startPlaneEC;
    startPlaneEC.xyz =  czm_normal * vec3(0.0, startEndNormals2D.xy);
    startPlaneEC.w = -dot(startPlaneEC.xyz, ecStart);

    // end plane
    vec4 endPlaneEC;
    endPlaneEC.xyz =  czm_normal * vec3(0.0, startEndNormals2D.zw);
    endPlaneEC.w = -dot(endPlaneEC.xyz, ecEnd);

    v_texcoordNormalizationAndStartEcYZ.x = abs(texcoordNormalization2D.x);
    v_texcoordNormalizationAndStartEcYZ.y = texcoordNormalization2D.y;

#else // COLUMBUS_VIEW_2D
    vec3 ecStart = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(startHiAndForwardOffsetX.xyz, startLoAndForwardOffsetY.xyz)).xyz;
    vec3 offset = czm_normal * vec3(startHiAndForwardOffsetX.w, startLoAndForwardOffsetY.w, startNormalAndForwardOffsetZ.w);
    vec3 ecEnd = ecStart + offset;

    vec3 forwardDirectionEC = normalize(offset);

    // start plane
    vec4 startPlaneEC;
    startPlaneEC.xyz = czm_normal * startNormalAndForwardOffsetZ.xyz;
    startPlaneEC.w = -dot(startPlaneEC.xyz, ecStart);

    // end plane
    vec4 endPlaneEC;
    endPlaneEC.xyz = czm_normal * endNormalAndTextureCoordinateNormalizationX.xyz;
    endPlaneEC.w = -dot(endPlaneEC.xyz, ecEnd);

    // Right plane
    v_rightPlaneEC.xyz = czm_normal * rightNormalAndTextureCoordinateNormalizationY.xyz;
    v_rightPlaneEC.w = -dot(v_rightPlaneEC.xyz, ecStart);

    v_texcoordNormalizationAndStartEcYZ.x = abs(endNormalAndTextureCoordinateNormalizationX.w);
    v_texcoordNormalizationAndStartEcYZ.y = rightNormalAndTextureCoordinateNormalizationY.w;

#endif // COLUMBUS_VIEW_2D

    v_endEcAndStartEcX.xyz = ecEnd;
    v_endEcAndStartEcX.w = ecStart.x;
    v_texcoordNormalizationAndStartEcYZ.zw = ecStart.yz;

#ifdef PER_INSTANCE_COLOR
    v_color = czm_batchTable_color(batchId);
#endif // PER_INSTANCE_COLOR

    // Compute a normal along which to "push" the position out, extending the miter depending on view distance.
    // Position has already been "pushed" by unit length along miter normal, and miter normals are encoded in the planes.
    // Decode the normal to use at this specific vertex, push the position back, and then push to where it needs to be.
    vec4 positionRelativeToEye = czm_computePosition();

    // Check distance to the end plane and start plane, pick the plane that is closer
    vec4 positionEC = czm_modelViewRelativeToEye * positionRelativeToEye; // w = 1.0, see czm_computePosition
    float absStartPlaneDistance = abs(czm_planeDistance(startPlaneEC, positionEC.xyz));
    float absEndPlaneDistance = abs(czm_planeDistance(endPlaneEC, positionEC.xyz));
    vec3 planeDirection = czm_branchFreeTernary(absStartPlaneDistance < absEndPlaneDistance, startPlaneEC.xyz, endPlaneEC.xyz);
    vec3 upOrDown = normalize(cross(v_rightPlaneEC.xyz, planeDirection)); // Points "up" for start plane, "down" at end plane.
    vec3 normalEC = normalize(cross(planeDirection, upOrDown));           // In practice, the opposite seems to work too.

    // Extrude bottom vertices downward for far view distances, like for GroundPrimitives
    upOrDown = cross(forwardDirectionEC, normalEC);
    upOrDown = float(czm_sceneMode == czm_sceneMode3D) * upOrDown;
    upOrDown = float(v_texcoordNormalizationAndStartEcYZ.y > 1.0 || v_texcoordNormalizationAndStartEcYZ.y < 0.0) * upOrDown;
    upOrDown = min(GLOBE_MINIMUM_ALTITUDE, czm_geometricToleranceOverMeter * length(positionRelativeToEye.xyz)) * upOrDown;
    positionEC.xyz += upOrDown;

    v_texcoordNormalizationAndStartEcYZ.y = czm_branchFreeTernary(v_texcoordNormalizationAndStartEcYZ.y > 1.0, 0.0, abs(v_texcoordNormalizationAndStartEcYZ.y));

    // Determine distance along normalEC to push for a volume of appropriate width.
    // Make volumes about double pixel width for a conservative fit - in practice the
    // extra cost here is minimal compared to the loose volume heights.
    //
    // N = normalEC (guaranteed "right-facing")
    // R = rightEC
    // p = angle between N and R
    // w = distance to push along R if R == N
    // d = distance to push along N
    //
    //   N   R
    //  {  p| }      * cos(p) = dot(N, R) = w / d
    //  d  |  |w    * d = w / dot(N, R)
    //    { | }
    //       o---------- polyline segment ---->
    //
    float width = czm_batchTable_width(batchId);
#ifdef WIDTH_VARYING
    v_width = width;
#endif

    v_startPlaneNormalEcAndHalfWidth.xyz = startPlaneEC.xyz;
    v_startPlaneNormalEcAndHalfWidth.w = width * 0.5;

    v_endPlaneNormalEcAndBatchId.xyz = endPlaneEC.xyz;
    v_endPlaneNormalEcAndBatchId.w = batchId;

    width = width * max(0.0, czm_metersPerPixel(positionEC)); // width = distance to push along R
    width = width / dot(normalEC, v_rightPlaneEC.xyz); // width = distance to push along N

    // Determine if this vertex is on the "left" or "right"
#ifdef COLUMBUS_VIEW_2D
        normalEC *= sign(texcoordNormalization2D.x);
#else
        normalEC *= sign(endNormalAndTextureCoordinateNormalizationX.w);
#endif

    positionEC.xyz += width * normalEC;
    gl_Position = czm_depthClamp(czm_projection * positionEC);

#ifdef ANGLE_VARYING
    // Approximate relative screen space direction of the line.
    vec2 approxLineDirection = normalize(vec2(forwardDirectionEC.x, -forwardDirectionEC.y));
    approxLineDirection.y = czm_branchFreeTernary(approxLineDirection.x == 0.0 && approxLineDirection.y == 0.0, -1.0, approxLineDirection.y);
    v_polylineAngle = czm_fastApproximateAtan(approxLineDirection.x, approxLineDirection.y);
#endif
}
`});var Ex,Jr,UI=S(()=>{Ex={TERRAIN:0,CESIUM_3D_TILE:1,BOTH:2};Ex.NUMBER_OF_CLASSIFICATION_TYPES=3;Jr=Object.freeze(Ex)});var Vnt,Eh,MI=S(()=>{ss();Vnt={FRONT:it.FRONT,BACK:it.BACK,FRONT_AND_BACK:it.FRONT_AND_BACK},Eh=Object.freeze(Vnt)});function Zs(t){t=Z(t,Z.EMPTY_OBJECT),this.position=Z(t.position,!1),this.normal=Z(t.normal,!1),this.st=Z(t.st,!1),this.bitangent=Z(t.bitangent,!1),this.tangent=Z(t.tangent,!1),this.color=Z(t.color,!1)}var St,Ls=S(()=>{Ft();mt();Ot();Zs.POSITION_ONLY=Object.freeze(new Zs({position:!0}));Zs.POSITION_AND_NORMAL=Object.freeze(new Zs({position:!0,normal:!0}));Zs.POSITION_NORMAL_AND_ST=Object.freeze(new Zs({position:!0,normal:!0,st:!0}));Zs.POSITION_AND_ST=Object.freeze(new Zs({position:!0,st:!0}));Zs.POSITION_AND_COLOR=Object.freeze(new Zs({position:!0,color:!0}));Zs.ALL=Object.freeze(new Zs({position:!0,normal:!0,st:!0,tangent:!0,bitangent:!0}));Zs.DEFAULT=Zs.POSITION_NORMAL_AND_ST;Zs.packedLength=6;Zs.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),e[i++]=t.position?1:0,e[i++]=t.normal?1:0,e[i++]=t.st?1:0,e[i++]=t.tangent?1:0,e[i++]=t.bitangent?1:0,e[i]=t.color?1:0,e};Zs.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");return e=Z(e,0),m(i)||(i=new Zs),i.position=t[e++]===1,i.normal=t[e++]===1,i.st=t[e++]===1,i.tangent=t[e++]===1,i.bitangent=t[e++]===1,i.color=t[e]===1,i};Zs.clone=function(t,e){if(m(t))return m(e)||(e=new Zs),e.position=t.position,e.normal=t.normal,e.st=t.st,e.tangent=t.tangent,e.bitangent=t.bitangent,e.color=t.color,e};St=Zs});var QI,BN=S(()=>{QI=`in vec4 v_color;

void main()
{
    out_FragColor = czm_gammaCorrect(v_color);
}
`});var _x,Rx=S(()=>{_x=`in vec3 position3DHigh;
in vec3 position3DLow;
in vec3 prevPosition3DHigh;
in vec3 prevPosition3DLow;
in vec3 nextPosition3DHigh;
in vec3 nextPosition3DLow;
in vec2 expandAndWidth;
in vec4 color;
in float batchId;

out vec4 v_color;

void main()
{
    float expandDir = expandAndWidth.x;
    float width = abs(expandAndWidth.y) + 0.5;
    bool usePrev = expandAndWidth.y < 0.0;

    vec4 p = czm_computePosition();
    vec4 prev = czm_computePrevPosition();
    vec4 next = czm_computeNextPosition();

    float angle;
    vec4 positionWC = getPolylineWindowCoordinates(p, prev, next, expandDir, width, usePrev, angle);
    gl_Position = czm_viewportOrthographic * positionWC;

    v_color = color;
}
`});var kI,GN=S(()=>{kI=`void clipLineSegmentToNearPlane(
    vec3 p0,
    vec3 p1,
    out vec4 positionWC,
    out bool clipped,
    out bool culledByNearPlane,
    out vec4 clippedPositionEC)
{
    culledByNearPlane = false;
    clipped = false;

    vec3 p0ToP1 = p1 - p0;
    float magnitude = length(p0ToP1);
    vec3 direction = normalize(p0ToP1);

    // Distance that p0 is behind the near plane. Negative means p0 is
    // in front of the near plane.
    float endPoint0Distance =  czm_currentFrustum.x + p0.z;

    // Camera looks down -Z.
    // When moving a point along +Z: LESS VISIBLE
    //   * Points in front of the camera move closer to the camera.
    //   * Points behind the camrea move farther away from the camera.
    // When moving a point along -Z: MORE VISIBLE
    //   * Points in front of the camera move farther away from the camera.
    //   * Points behind the camera move closer to the camera.

    // Positive denominator: -Z, becoming more visible
    // Negative denominator: +Z, becoming less visible
    // Nearly zero: parallel to near plane
    float denominator = -direction.z;

    if (endPoint0Distance > 0.0 && abs(denominator) < czm_epsilon7)
    {
        // p0 is behind the near plane and the line to p1 is nearly parallel to
        // the near plane, so cull the segment completely.
        culledByNearPlane = true;
    }
    else if (endPoint0Distance > 0.0)
    {
        // p0 is behind the near plane, and the line to p1 is moving distinctly
        // toward or away from it.

        // t = (-plane distance - dot(plane normal, ray origin)) / dot(plane normal, ray direction)
        float t = endPoint0Distance / denominator;
        if (t < 0.0 || t > magnitude)
        {
            // Near plane intersection is not between the two points.
            // We already confirmed p0 is behind the naer plane, so now
            // we know the entire segment is behind it.
            culledByNearPlane = true;
        }
        else
        {
            // Segment crosses the near plane, update p0 to lie exactly on it.
            p0 = p0 + t * direction;

            // Numerical noise might put us a bit on the wrong side of the near plane.
            // Don't let that happen.
            p0.z = min(p0.z, -czm_currentFrustum.x);

            clipped = true;
        }
    }

    clippedPositionEC = vec4(p0, 1.0);
    positionWC = czm_eyeToWindowCoordinates(clippedPositionEC);
}

vec4 getPolylineWindowCoordinatesEC(vec4 positionEC, vec4 prevEC, vec4 nextEC, float expandDirection, float width, bool usePrevious, out float angle)
{
    // expandDirection +1 is to the _left_ when looking from positionEC toward nextEC.

#ifdef POLYLINE_DASH
    // Compute the window coordinates of the points.
    vec4 positionWindow = czm_eyeToWindowCoordinates(positionEC);
    vec4 previousWindow = czm_eyeToWindowCoordinates(prevEC);
    vec4 nextWindow = czm_eyeToWindowCoordinates(nextEC);

    // Determine the relative screen space direction of the line.
    vec2 lineDir;
    if (usePrevious) {
        lineDir = normalize(positionWindow.xy - previousWindow.xy);
    }
    else {
        lineDir = normalize(nextWindow.xy - positionWindow.xy);
    }
    angle = atan(lineDir.x, lineDir.y) - 1.570796327; // precomputed atan(1,0)

    // Quantize the angle so it doesn't change rapidly between segments.
    angle = floor(angle / czm_piOverFour + 0.5) * czm_piOverFour;
#endif

    vec4 clippedPrevWC, clippedPrevEC;
    bool prevSegmentClipped, prevSegmentCulled;
    clipLineSegmentToNearPlane(prevEC.xyz, positionEC.xyz, clippedPrevWC, prevSegmentClipped, prevSegmentCulled, clippedPrevEC);

    vec4 clippedNextWC, clippedNextEC;
    bool nextSegmentClipped, nextSegmentCulled;
    clipLineSegmentToNearPlane(nextEC.xyz, positionEC.xyz, clippedNextWC, nextSegmentClipped, nextSegmentCulled, clippedNextEC);

    bool segmentClipped, segmentCulled;
    vec4 clippedPositionWC, clippedPositionEC;
    clipLineSegmentToNearPlane(positionEC.xyz, usePrevious ? prevEC.xyz : nextEC.xyz, clippedPositionWC, segmentClipped, segmentCulled, clippedPositionEC);

    if (segmentCulled)
    {
        return vec4(0.0, 0.0, 0.0, 1.0);
    }

    vec2 directionToPrevWC = normalize(clippedPrevWC.xy - clippedPositionWC.xy);
    vec2 directionToNextWC = normalize(clippedNextWC.xy - clippedPositionWC.xy);

    // If a segment was culled, we can't use the corresponding direction
    // computed above. We should never see both of these be true without
    // \`segmentCulled\` above also being true.
    if (prevSegmentCulled)
    {
        directionToPrevWC = -directionToNextWC;
    }
    else if (nextSegmentCulled)
    {
        directionToNextWC = -directionToPrevWC;
    }

    vec2 thisSegmentForwardWC, otherSegmentForwardWC;
    if (usePrevious)
    {
        thisSegmentForwardWC = -directionToPrevWC;
        otherSegmentForwardWC = directionToNextWC;
    }
    else
    {
        thisSegmentForwardWC = directionToNextWC;
        otherSegmentForwardWC =  -directionToPrevWC;
    }

    vec2 thisSegmentLeftWC = vec2(-thisSegmentForwardWC.y, thisSegmentForwardWC.x);

    vec2 leftWC = thisSegmentLeftWC;
    float expandWidth = width * 0.5;

    // When lines are split at the anti-meridian, the position may be at the
    // same location as the next or previous position, and we need to handle
    // that to avoid producing NaNs.
    if (!czm_equalsEpsilon(prevEC.xyz - positionEC.xyz, vec3(0.0), czm_epsilon1) && !czm_equalsEpsilon(nextEC.xyz - positionEC.xyz, vec3(0.0), czm_epsilon1))
    {
        vec2 otherSegmentLeftWC = vec2(-otherSegmentForwardWC.y, otherSegmentForwardWC.x);

        vec2 leftSumWC = thisSegmentLeftWC + otherSegmentLeftWC;
        float leftSumLength = length(leftSumWC);
        leftWC = leftSumLength < czm_epsilon6 ? thisSegmentLeftWC : (leftSumWC / leftSumLength);

        // The sine of the angle between the two vectors is given by the formula
        //         |a x b| = |a||b|sin(theta)
        // which is
        //     float sinAngle = length(cross(vec3(leftWC, 0.0), vec3(-thisSegmentForwardWC, 0.0)));
        // Because the z components of both vectors are zero, the x and y coordinate will be zero.
        // Therefore, the sine of the angle is just the z component of the cross product.
        vec2 u = -thisSegmentForwardWC;
        vec2 v = leftWC;
        float sinAngle = abs(u.x * v.y - u.y * v.x);
        expandWidth = clamp(expandWidth / sinAngle, 0.0, width * 2.0);
    }

    vec2 offset = leftWC * expandDirection * expandWidth * czm_pixelRatio;
    return vec4(clippedPositionWC.xy + offset, -clippedPositionWC.z, 1.0) * (czm_projection * clippedPositionEC).w;
}

vec4 getPolylineWindowCoordinates(vec4 position, vec4 previous, vec4 next, float expandDirection, float width, bool usePrevious, out float angle)
{
    vec4 positionEC = czm_modelViewRelativeToEye * position;
    vec4 prevEC = czm_modelViewRelativeToEye * previous;
    vec4 nextEC = czm_modelViewRelativeToEye * next;
    return getPolylineWindowCoordinatesEC(positionEC, prevEC, nextEC, expandDirection, width, usePrevious, angle);
}
`});function Jm(t){t=Z(t,Z.EMPTY_OBJECT),this.material=t.material,this.translucent=Z(t.translucent,!0),this._vertexShaderSource=t.vertexShaderSource,this._fragmentShaderSource=t.fragmentShaderSource,this._renderState=t.renderState,this._closed=Z(t.closed,!1)}var Mo,LI=S(()=>{aE();KA();Ft();mt();km();MI();Object.defineProperties(Jm.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}}});Jm.prototype.getFragmentShaderSource=function(){let t=[];return this.flat&&t.push("#define FLAT"),this.faceForward&&t.push("#define FACE_FORWARD"),m(this.material)&&t.push(this.material.shaderSource),t.push(this.fragmentShaderSource),t.join(`
`)};Jm.prototype.isTranslucent=function(){return m(this.material)&&this.material.isTranslucent()||!m(this.material)&&this.translucent};Jm.prototype.getRenderState=function(){let t=this.isTranslucent(),e=qs(this.renderState,!1);return t?(e.depthMask=!1,e.blending=Mr.ALPHA_BLEND):e.depthMask=!0,e};Jm.getDefaultRenderState=function(t,e,i){let n={depthTest:{enabled:!0}};return t&&(n.depthMask=!1,n.blending=Mr.ALPHA_BLEND),e&&(n.cull={enabled:!0,face:Eh.BACK}),m(i)&&(n=es(i,n,!0)),n};Mo=Jm});function Ql(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.translucent,!0),i=!1,n=Ql.VERTEX_FORMAT;this.material=void 0,this.translucent=e,this._vertexShaderSource=Z(t.vertexShaderSource,WN),this._fragmentShaderSource=Z(t.fragmentShaderSource,Snt),this._renderState=Mo.getDefaultRenderState(e,i,t.renderState),this._closed=i,this._vertexFormat=n}var WN,Snt,DN,Zx=S(()=>{Ft();Il();Ls();BN();Rx();GN();LI();WN=`${kI}
${_x}`,Snt=QI;_o.isInternetExplorer()||(WN=`#define CLIP_POLYLINE 
${WN}`);Object.defineProperties(Ql.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},vertexFormat:{get:function(){return this._vertexFormat}}});Ql.VERTEX_FORMAT=St.POSITION_ONLY;Ql.prototype.getFragmentShaderSource=Mo.prototype.getFragmentShaderSource;Ql.prototype.isTranslucent=Mo.prototype.isTranslucent;Ql.prototype.getRenderState=Mo.prototype.getRenderState;DN=Ql});var Ix,px=S(()=>{Ix=`in vec3 position3DHigh;
in vec3 position3DLow;
in vec3 prevPosition3DHigh;
in vec3 prevPosition3DLow;
in vec3 nextPosition3DHigh;
in vec3 nextPosition3DLow;
in vec2 expandAndWidth;
in vec2 st;
in float batchId;

out float v_width;
out vec2 v_st;
out float v_polylineAngle;

void main()
{
    float expandDir = expandAndWidth.x;
    float width = abs(expandAndWidth.y) + 0.5;
    bool usePrev = expandAndWidth.y < 0.0;

    vec4 p = czm_computePosition();
    vec4 prev = czm_computePrevPosition();
    vec4 next = czm_computeNextPosition();

    float angle;
    vec4 positionWC = getPolylineWindowCoordinates(p, prev, next, expandDir, width, usePrev, angle);
    gl_Position = czm_viewportOrthographic * positionWC;

    v_width = width;
    v_st.s = st.s;
    v_st.t = czm_writeNonPerspective(st.t, gl_Position.w);
    v_polylineAngle = angle;
}
`});var ux,Cx=S(()=>{ux=`#ifdef VECTOR_TILE
uniform vec4 u_highlightColor;
#endif

in vec2 v_st;

void main()
{
    czm_materialInput materialInput;

    vec2 st = v_st;
    st.t = czm_readNonPerspective(st.t, gl_FragCoord.w);

    materialInput.s = st.s;
    materialInput.st = st;
    materialInput.str = vec3(st, 0.0);

    czm_material material = czm_getMaterial(materialInput);
    out_FragColor = vec4(material.diffuse + material.emission, material.alpha);
#ifdef VECTOR_TILE
    out_FragColor *= u_highlightColor;
#endif

    czm_writeLogDepth();
}
`});function jm(t,e,i,n,s){this._format=t,this._datatype=e,this._width=i,this._height=n,this._buffer=s}var gx,Tx=S(()=>{mt();Object.defineProperties(jm.prototype,{internalFormat:{get:function(){return this._format}},pixelDatatype:{get:function(){return this._datatype}},width:{get:function(){return this._width}},height:{get:function(){return this._height}},bufferView:{get:function(){return this._buffer}}});jm.clone=function(t){if(m(t))return new jm(t._format,t._datatype,t._width,t._height,t._buffer)};jm.prototype.clone=function(){return jm.clone(this)};gx=jm});function Fx(){if(!m(so._canTransferArrayBuffer)){let t=QN("transferTypedArrayTest");t.postMessage=Z(t.webkitPostMessage,t.postMessage);let e=99,i=new Int8Array([e]);try{t.postMessage({array:i},[i.buffer])}catch{return so._canTransferArrayBuffer=!1,so._canTransferArrayBuffer}so._canTransferArrayBuffer=new Promise(n=>{t.onmessage=function(s){let o=s.data.array,r=m(o)&&o[0]===e;n(r),t.terminate(),so._canTransferArrayBuffer=r}})}return so._canTransferArrayBuffer}function UN(t){let e;try{e=new Blob([t],{type:"application/javascript"})}catch{let s=window.BlobBuilder||window.WebKitBlobBuilder||window.MozBlobBuilder||window.MSBlobBuilder,o=new s;o.append(t),e=o.getBlob("application/javascript")}return(window.URL||window.webkitURL).createObjectURL(e)}function QN(t){let e=new Nx.default(t),i=e.scheme().length!==0&&e.fragment().length===0,n={},s;if(ZZ(t)){let r=`importScripts("${t}");`;return s=UN(r),new Worker(s,n)}let o=t.replace(/\.js$/,"");if(!i&&typeof CESIUM_WORKERS<"u"){let r=`
      importScripts("${UN(CESIUM_WORKERS)}");
      CesiumWorkers["${o}"]();
    `;return s=UN(r),new Worker(s,n)}if(s=t,i||(s=th(`${so._workerModulePrefix+o}.js`)),!_o.supportsEsmWebWorkers())throw new ke("This browser is not supported. Please update your browser to continue.");return n.type="module",new Worker(s,n)}async function Ont(t,e){let i={modulePath:void 0,wasmBinaryFile:void 0,wasmBinary:void 0};if(!_o.supportsWebAssembly()){if(!m(e.fallbackModulePath))throw new ke(`This browser does not support Web Assembly, and no backup module was provided for ${t._workerPath}`);return i.modulePath=th(e.fallbackModulePath),i}i.wasmBinaryFile=th(e.wasmBinaryFile);let n=await tn.fetchArrayBuffer({url:i.wasmBinaryFile});return i.wasmBinary=n,i}function so(t,e){this._workerPath=t,this._maximumActiveTasks=Z(e,Number.POSITIVE_INFINITY),this._activeTasks=0,this._nextID=0,this._webAssemblyPromise=void 0}async function Wnt(t,e,i){let n=await Promise.resolve(Fx());m(i)?n||(i.length=0):i=Gnt;let s=t._nextID++,o=new Promise((r,a)=>{t._worker.addEventListener("message",Bnt(t._worker,s,r,a))});return t._worker.postMessage({id:s,baseUrl:th.getCesiumBaseUrl().url,parameters:e,canTransferArrayBuffer:n},i),o}async function Dnt(t,e,i){++t._activeTasks;try{let n=await Wnt(t,e,i);return--t._activeTasks,n}catch(n){throw--t._activeTasks,n}}var Nx,MN,Bnt,Gnt,XE,kN=S(()=>{Nx=co(oc(),1);PZ();Ft();mt();Ws();Ot();xi();Il();Z0();Ia();Ps();MN=new We;Bnt=(t,e,i,n)=>{let s=({data:o})=>{if(o.id===e){if(m(o.error)){let r=o.error;r.name==="RuntimeError"?(r=new ke(o.error.message),r.stack=o.error.stack):r.name==="DeveloperError"?(r=new Y(o.error.message),r.stack=o.error.stack):r.name==="Error"&&(r=new Error(o.error.message),r.stack=o.error.stack),MN.raiseEvent(r),n(r)}else MN.raiseEvent(),i(o.result);t.removeEventListener("message",s)}};return s},Gnt=[];so.prototype.scheduleTask=function(t,e){if(m(this._worker)||(this._worker=QN(this._workerPath)),!(this._activeTasks>=this._maximumActiveTasks))return Dnt(this,t,e)};so.prototype.initWebAssemblyModule=async function(t){if(m(this._webAssemblyPromise))return this._webAssemblyPromise;let e=async()=>{let i=this._worker=QN(this._workerPath),n=await Ont(this,t),s=await Promise.resolve(Fx()),o,r=n.wasmBinary;m(r)&&s&&(o=[r]);let a=new Promise((h,A)=>{i.onmessage=function({data:d}){m(d)?h(d.result):A(new ke("Could not configure wasm module"))}});return i.postMessage({canTransferArrayBuffer:s,parameters:{webAssemblyConfig:n}},o),a};return this._webAssemblyPromise=e(),this._webAssemblyPromise};so.prototype.isDestroyed=function(){return!1};so.prototype.destroy=function(){return m(this._worker)&&this._worker.terminate(),li(this)};so.taskCompletedEvent=MN;so._defaultWorkerModulePrefix="Workers/";so._workerModulePrefix=so._defaultWorkerModulePrefix;so._canTransferArrayBuffer=void 0;XE=so});function _h(){}function Unt(){let t=_h._transcodeTaskProcessor.initWebAssemblyModule({wasmBinaryFile:"ThirdParty/basis_transcoder.wasm"}).then(function(e){if(e)return _h._transcodeTaskProcessor;throw new ke("KTX2 transcoder could not be initialized.")});_h._readyPromise=t}var bx,Yx=S(()=>{ae();Tx();mt();Ps();kN();_h._transcodeTaskProcessor=new XE("transcodeKTX2",Number.POSITIVE_INFINITY);_h._readyPromise=void 0;_h.transcode=function(t,e){return p.defined("supportedTargetFormats",e),m(_h._readyPromise)||Unt(),_h._readyPromise.then(function(i){let n;if(t instanceof ArrayBuffer){let s=new Uint8Array(t);return n={supportedTargetFormats:e,ktx2Buffer:s},i.scheduleTask(n,[t])}return n={supportedTargetFormats:e,ktx2Buffer:t},i.scheduleTask(n,[t.buffer])}).then(function(i){let n=i.length,s=Object.keys(i[0]),o=s.length,r;for(r=0;r<n;r++){let a=i[r];for(let h=0;h<o;h++){let A=a[s[h]];a[s[h]]=new gx(A.internalFormat,A.datatype,A.width,A.height,A.levelBuffer)}}if(o===1){for(r=0;r<n;++r)i[r]=i[r][s[0]];n===1&&(i=i[0])}return i}).catch(function(i){throw i})};bx=_h});function Sx(t){p.defined("resourceOrUrlOrBuffer",t);let e;return t instanceof ArrayBuffer||ArrayBuffer.isView(t)?e=Promise.resolve(t):e=tn.createIfNeeded(t).fetchArrayBuffer(),e.then(function(i){return bx.transcode(i,Vx)})}var Vx,Ox,Bx=S(()=>{ae();Ia();Yx();Sx.setKTX2SupportedFormats=function(t,e,i,n,s,o){Vx={s3tc:t,pvrtc:e,astc:i,etc:n,etc1:s,bc7:o}};Ox=Sx});function yI(t,e,i,n,s,o,r,a,h,A,d){this._context=t,this._texture=e,this._textureTarget=i,this._targetFace=n,this._pixelDatatype=r,this._internalFormat=s,this._pixelFormat=o,this._size=a,this._preMultiplyAlpha=h,this._flipY=A,this._initialized=d}var kl,Gx=S(()=>{ae();Ft();mt();Ot();_c();Ec();Object.defineProperties(yI.prototype,{pixelFormat:{get:function(){return this._pixelFormat}},pixelDatatype:{get:function(){return this._pixelDatatype}},_target:{get:function(){return this._targetFace}}});yI.prototype.copyFrom=function(t){p.defined("options",t);let e=Z(t.xOffset,0),i=Z(t.yOffset,0);if(p.defined("options.source",t.source),p.typeOf.number.greaterThanOrEquals("xOffset",e,0),p.typeOf.number.greaterThanOrEquals("yOffset",i,0),e+t.source.width>this._size)throw new Y("xOffset + options.source.width must be less than or equal to width.");if(i+t.source.height>this._size)throw new Y("yOffset + options.source.height must be less than or equal to height.");let n=t.source,s=this._context._gl,o=this._textureTarget,r=this._targetFace;s.activeTexture(s.TEXTURE0),s.bindTexture(o,this._texture);let a=n.width,h=n.height,A=n.arrayBufferView,d=this._size,f=this._pixelFormat,E=this._internalFormat,_=this._pixelDatatype,R=this._preMultiplyAlpha,I=this._flipY,C=Z(t.skipColorSpaceConversion,!1),N=4;m(A)&&(N=Ie.alignmentInBytes(f,_,a)),s.pixelStorei(s.UNPACK_ALIGNMENT,N),C?s.pixelStorei(s.UNPACK_COLORSPACE_CONVERSION_WEBGL,s.NONE):s.pixelStorei(s.UNPACK_COLORSPACE_CONVERSION_WEBGL,s.BROWSER_DEFAULT_WEBGL);let T=!1;if(!this._initialized){if(e===0&&i===0&&a===d&&h===d)m(A)?(s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL,!1),I&&(A=Ie.flipY(A,f,_,d,d)),s.texImage2D(r,0,E,d,d,0,f,ge.toWebGLConstant(_,this._context),A)):(s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,R),s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL,I),s.texImage2D(r,0,E,f,ge.toWebGLConstant(_,this._context),n)),T=!0;else{s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL,!1);let b=Ie.createTypedArray(f,_,d,d);s.texImage2D(r,0,E,d,d,0,f,ge.toWebGLConstant(_,this._context),b)}this._initialized=!0}T||(m(A)?(s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL,!1),I&&(A=Ie.flipY(A,f,_,a,h)),s.texSubImage2D(r,0,e,i,a,h,f,ge.toWebGLConstant(_,this._context),A)):(s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,R),s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL,I),s.texSubImage2D(r,0,e,i,f,ge.toWebGLConstant(_,this._context),n))),s.bindTexture(o,null)};yI.prototype.copyFromFramebuffer=function(t,e,i,n,s,o){if(t=Z(t,0),e=Z(e,0),i=Z(i,0),n=Z(n,0),s=Z(s,this._size),o=Z(o,this._size),p.typeOf.number.greaterThanOrEquals("xOffset",t,0),p.typeOf.number.greaterThanOrEquals("yOffset",e,0),p.typeOf.number.greaterThanOrEquals("framebufferXOffset",i,0),p.typeOf.number.greaterThanOrEquals("framebufferYOffset",n,0),t+s>this._size)throw new Y("xOffset + source.width must be less than or equal to width.");if(e+o>this._size)throw new Y("yOffset + source.height must be less than or equal to height.");if(this._pixelDatatype===ge.FLOAT)throw new Y("Cannot call copyFromFramebuffer when the texture pixel data type is FLOAT.");if(this._pixelDatatype===ge.HALF_FLOAT)throw new Y("Cannot call copyFromFramebuffer when the texture pixel data type is HALF_FLOAT.");let r=this._context._gl,a=this._textureTarget;r.activeTexture(r.TEXTURE0),r.bindTexture(a,this._texture),r.copyTexSubImage2D(this._targetFace,0,t,e,i,n,s,o),r.bindTexture(a,null),this._initialized=!0};kl=yI});function qE(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.context",t.context);let e=t.context,i=t.source,n,s;if(m(i)){let T=[i.positiveX,i.negativeX,i.positiveY,i.negativeY,i.positiveZ,i.negativeZ];if(!T[0]||!T[1]||!T[2]||!T[3]||!T[4]||!T[5])throw new Y("options.source requires positiveX, negativeX, positiveY, negativeY, positiveZ, and negativeZ faces.");n=T[0].width,s=T[0].height;for(let b=1;b<6;++b)if(Number(T[b].width)!==n||Number(T[b].height)!==s)throw new Y("Each face in options.source must have the same width and height.")}else n=t.width,s=t.height;let o=n,r=Z(t.pixelDatatype,ge.UNSIGNED_BYTE),a=Z(t.pixelFormat,Ie.RGBA),h=Ie.toInternalFormat(a,r,e);if(!m(n)||!m(s))throw new Y("options requires a source field to create an initialized cube map or width and height fields to create a blank cube map.");if(n!==s)throw new Y("Width must equal height.");if(o<=0)throw new Y("Width and height must be greater than zero.");if(o>en.maximumCubeMapSize)throw new Y(`Width and height must be less than or equal to the maximum cube map size (${en.maximumCubeMapSize}).  Check maximumCubeMapSize.`);if(!Ie.validate(a))throw new Y("Invalid options.pixelFormat.");if(Ie.isDepthFormat(a))throw new Y("options.pixelFormat cannot be DEPTH_COMPONENT or DEPTH_STENCIL.");if(!ge.validate(r))throw new Y("Invalid options.pixelDatatype.");if(r===ge.FLOAT&&!e.floatingPointTexture)throw new Y("When options.pixelDatatype is FLOAT, this WebGL implementation must support the OES_texture_float extension.");if(r===ge.HALF_FLOAT&&!e.halfFloatingPointTexture)throw new Y("When options.pixelDatatype is HALF_FLOAT, this WebGL implementation must support the OES_texture_half_float extension.");let A=Ie.textureSizeInBytes(a,r,o,o)*6,d=t.preMultiplyAlpha||a===Ie.RGB||a===Ie.LUMINANCE,f=Z(t.flipY,!0),E=Z(t.skipColorSpaceConversion,!1),_=e._gl,R=_.TEXTURE_CUBE_MAP,I=_.createTexture();_.activeTexture(_.TEXTURE0),_.bindTexture(R,I);function C(T,b,F,B,U){let Q=b.arrayBufferView;m(Q)||(Q=b.bufferView);let M=4;m(Q)&&(M=Ie.alignmentInBytes(a,r,n)),_.pixelStorei(_.UNPACK_ALIGNMENT,M),U?_.pixelStorei(_.UNPACK_COLORSPACE_CONVERSION_WEBGL,_.NONE):_.pixelStorei(_.UNPACK_COLORSPACE_CONVERSION_WEBGL,_.BROWSER_DEFAULT_WEBGL),m(Q)?(_.pixelStorei(_.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),_.pixelStorei(_.UNPACK_FLIP_Y_WEBGL,!1),B&&(Q=Ie.flipY(Q,a,r,o,o)),_.texImage2D(T,0,h,o,o,0,a,ge.toWebGLConstant(r,e),Q)):(_.pixelStorei(_.UNPACK_PREMULTIPLY_ALPHA_WEBGL,F),_.pixelStorei(_.UNPACK_FLIP_Y_WEBGL,B),_.texImage2D(T,0,h,a,ge.toWebGLConstant(r,e),b))}m(i)?(C(_.TEXTURE_CUBE_MAP_POSITIVE_X,i.positiveX,d,f,E),C(_.TEXTURE_CUBE_MAP_NEGATIVE_X,i.negativeX,d,f,E),C(_.TEXTURE_CUBE_MAP_POSITIVE_Y,i.positiveY,d,f,E),C(_.TEXTURE_CUBE_MAP_NEGATIVE_Y,i.negativeY,d,f,E),C(_.TEXTURE_CUBE_MAP_POSITIVE_Z,i.positiveZ,d,f,E),C(_.TEXTURE_CUBE_MAP_NEGATIVE_Z,i.negativeZ,d,f,E)):(_.texImage2D(_.TEXTURE_CUBE_MAP_POSITIVE_X,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null),_.texImage2D(_.TEXTURE_CUBE_MAP_NEGATIVE_X,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null),_.texImage2D(_.TEXTURE_CUBE_MAP_POSITIVE_Y,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null),_.texImage2D(_.TEXTURE_CUBE_MAP_NEGATIVE_Y,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null),_.texImage2D(_.TEXTURE_CUBE_MAP_POSITIVE_Z,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null),_.texImage2D(_.TEXTURE_CUBE_MAP_NEGATIVE_Z,0,h,o,o,0,a,ge.toWebGLConstant(r,e),null)),_.bindTexture(R,null),this._context=e,this._textureFilterAnisotropic=e._textureFilterAnisotropic,this._textureTarget=R,this._texture=I,this._pixelFormat=a,this._pixelDatatype=r,this._size=o,this._hasMipmap=!1,this._sizeInBytes=A,this._preMultiplyAlpha=d,this._flipY=f,this._sampler=void 0;let N=m(i);this._positiveX=new kl(e,I,R,_.TEXTURE_CUBE_MAP_POSITIVE_X,h,a,r,o,d,f,N),this._negativeX=new kl(e,I,R,_.TEXTURE_CUBE_MAP_NEGATIVE_X,h,a,r,o,d,f,N),this._positiveY=new kl(e,I,R,_.TEXTURE_CUBE_MAP_POSITIVE_Y,h,a,r,o,d,f,N),this._negativeY=new kl(e,I,R,_.TEXTURE_CUBE_MAP_NEGATIVE_Y,h,a,r,o,d,f,N),this._positiveZ=new kl(e,I,R,_.TEXTURE_CUBE_MAP_POSITIVE_Z,h,a,r,o,d,f,N),this._negativeZ=new kl(e,I,R,_.TEXTURE_CUBE_MAP_NEGATIVE_Z,h,a,r,o,d,f,N),this.sampler=m(t.sampler)?t.sampler:new ZA}var LN,Wx=S(()=>{ae();Ft();mt();Ws();Ot();_e();_c();ga();Gx();DT();Ec();YE();NE();FE();Object.defineProperties(qE.prototype,{positiveX:{get:function(){return this._positiveX}},negativeX:{get:function(){return this._negativeX}},positiveY:{get:function(){return this._positiveY}},negativeY:{get:function(){return this._negativeY}},positiveZ:{get:function(){return this._positiveZ}},negativeZ:{get:function(){return this._negativeZ}},sampler:{get:function(){return this._sampler},set:function(t){let e=t.minificationFilter,i=t.magnificationFilter,n=e===_s.NEAREST_MIPMAP_NEAREST||e===_s.NEAREST_MIPMAP_LINEAR||e===_s.LINEAR_MIPMAP_NEAREST||e===_s.LINEAR_MIPMAP_LINEAR,s=this._context,o=this._pixelDatatype;(o===ge.FLOAT&&!s.textureFloatLinear||o===ge.HALF_FLOAT&&!s.textureHalfFloatLinear)&&(e=n?_s.NEAREST_MIPMAP_NEAREST:_s.NEAREST,i=Na.NEAREST);let r=s._gl,a=this._textureTarget;r.activeTexture(r.TEXTURE0),r.bindTexture(a,this._texture),r.texParameteri(a,r.TEXTURE_MIN_FILTER,e),r.texParameteri(a,r.TEXTURE_MAG_FILTER,i),r.texParameteri(a,r.TEXTURE_WRAP_S,t.wrapS),r.texParameteri(a,r.TEXTURE_WRAP_T,t.wrapT),m(this._textureFilterAnisotropic)&&r.texParameteri(a,this._textureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT,t.maximumAnisotropy),r.bindTexture(a,null),this._sampler=t}},pixelFormat:{get:function(){return this._pixelFormat}},pixelDatatype:{get:function(){return this._pixelDatatype}},width:{get:function(){return this._size}},height:{get:function(){return this._size}},sizeInBytes:{get:function(){return this._hasMipmap?Math.floor(this._sizeInBytes*4/3):this._sizeInBytes}},preMultiplyAlpha:{get:function(){return this._preMultiplyAlpha}},flipY:{get:function(){return this._flipY}},_target:{get:function(){return this._textureTarget}}});qE.prototype.generateMipmap=function(t){if(t=Z(t,Lm.DONT_CARE),this._size>1&&!L.isPowerOfTwo(this._size))throw new Y("width and height must be a power of two to call generateMipmap().");if(!Lm.validate(t))throw new Y("hint is invalid.");this._hasMipmap=!0;let e=this._context._gl,i=this._textureTarget;e.hint(e.GENERATE_MIPMAP_HINT,t),e.activeTexture(e.TEXTURE0),e.bindTexture(i,this._texture),e.generateMipmap(i),e.bindTexture(i,null)};qE.prototype.isDestroyed=function(){return!1};qE.prototype.destroy=function(){return this._context._gl.deleteTexture(this._texture),this._positiveX=li(this._positiveX),this._negativeX=li(this._negativeX),this._positiveY=li(this._positiveY),this._negativeY=li(this._negativeY),this._positiveZ=li(this._positiveZ),this._negativeZ=li(this._negativeZ),li(this)};LN=qE});var Dx,Ux=S(()=>{Dx=`uniform sampler2D image;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);
    vec4 rampColor = texture(image, vec2(materialInput.aspect / (2.0 * czm_pi), 0.5));
    rampColor = czm_gammaCorrect(rampColor);
    material.diffuse = rampColor.rgb;
    material.alpha = rampColor.a;
    return material;
}
`});var Mx,Qx=S(()=>{Mx=`uniform sampler2D image;
uniform float strength;
uniform vec2 repeat;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;

    vec2 centerPixel = fract(repeat * st);
    float centerBump = texture(image, centerPixel).channel;

    float imageWidth = float(imageDimensions.x);
    vec2 rightPixel = fract(repeat * (st + vec2(1.0 / imageWidth, 0.0)));
    float rightBump = texture(image, rightPixel).channel;

    float imageHeight = float(imageDimensions.y);
    vec2 leftPixel = fract(repeat * (st + vec2(0.0, 1.0 / imageHeight)));
    float topBump = texture(image, leftPixel).channel;

    vec3 normalTangentSpace = normalize(vec3(centerBump - rightBump, centerBump - topBump, clamp(1.0 - strength, 0.1, 1.0)));
    vec3 normalEC = materialInput.tangentToEyeMatrix * normalTangentSpace;

    material.normal = normalEC;
    material.diffuse = vec3(0.01);

    return material;
}
`});var kx,Lx=S(()=>{kx=`uniform vec4 lightColor;
uniform vec4 darkColor;
uniform vec2 repeat;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;

    // From Stefan Gustavson's Procedural Textures in GLSL in OpenGL Insights
    float b = mod(floor(repeat.s * st.s) + floor(repeat.t * st.t), 2.0);  // 0.0 or 1.0

    // Find the distance from the closest separator (region between two colors)
    float scaledWidth = fract(repeat.s * st.s);
    scaledWidth = abs(scaledWidth - floor(scaledWidth + 0.5));
    float scaledHeight = fract(repeat.t * st.t);
    scaledHeight = abs(scaledHeight - floor(scaledHeight + 0.5));
    float value = min(scaledWidth, scaledHeight);

    vec4 currentColor = mix(lightColor, darkColor, b);
    vec4 color = czm_antialias(lightColor, darkColor, currentColor, value, 0.03);

    color = czm_gammaCorrect(color);
    material.diffuse = color.rgb;
    material.alpha = color.a;

    return material;
}
`});var yx,wx=S(()=>{yx=`uniform vec4 lightColor;
uniform vec4 darkColor;
uniform vec2 repeat;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    // From Stefan Gustavson's Procedural Textures in GLSL in OpenGL Insights
    float b = smoothstep(0.3, 0.32, length(fract(repeat * materialInput.st) - 0.5));  // 0.0 or 1.0

    vec4 color = mix(lightColor, darkColor, b);
    color = czm_gammaCorrect(color);
    material.diffuse = color.rgb;
    material.alpha = color.a;

    return material;
}
`});var xx,Px=S(()=>{xx=`uniform sampler2D heights;
uniform sampler2D colors;

// This material expects heights to be sorted from lowest to highest.

float getHeight(int idx, float invTexSize)
{
    vec2 uv = vec2((float(idx) + 0.5) * invTexSize, 0.5);
#ifdef OES_texture_float
    return texture(heights, uv).x;
#else
    return czm_unpackFloat(texture(heights, uv));
#endif
}

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    float height = materialInput.height;
    float invTexSize = 1.0 / float(heightsDimensions.x);

    float minHeight = getHeight(0, invTexSize);
    float maxHeight = getHeight(heightsDimensions.x - 1, invTexSize);

    // early-out when outside the height range
    if (height < minHeight || height > maxHeight) {
        material.diffuse = vec3(0.0);
        material.alpha = 0.0;
        return material;
    }

    // Binary search to find heights above and below.
    int idxBelow = 0;
    int idxAbove = heightsDimensions.x;
    float heightBelow = minHeight;
    float heightAbove = maxHeight;

    // while loop not allowed, so use for loop with max iterations.
    // maxIterations of 16 supports a texture size up to 65536 (2^16).
    const int maxIterations = 16;
    for (int i = 0; i < maxIterations; i++) {
        if (idxBelow >= idxAbove - 1) {
            break;
        }

        int idxMid = (idxBelow + idxAbove) / 2;
        float heightTex = getHeight(idxMid, invTexSize);

        if (height > heightTex) {
            idxBelow = idxMid;
            heightBelow = heightTex;
        } else {
            idxAbove = idxMid;
            heightAbove = heightTex;
        }
    }

    float lerper = heightBelow == heightAbove ? 1.0 : (height - heightBelow) / (heightAbove - heightBelow);
    vec2 colorUv = vec2(invTexSize * (float(idxBelow) + 0.5 + lerper), 0.5);
    vec4 color = texture(colors, colorUv);

    // undo preumultiplied alpha
    if (color.a > 0.0) 
    {
        color.rgb /= color.a;
    }
    
    color.rgb = czm_gammaCorrect(color.rgb);

    material.diffuse = color.rgb;
    material.alpha = color.a;
    return material;
}
`});var Jx,jx=S(()=>{Jx=`uniform vec4 color;
uniform float spacing;
uniform float width;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    float distanceToContour = mod(materialInput.height, spacing);

#if (__VERSION__ == 300 || defined(GL_OES_standard_derivatives))
    float dxc = abs(dFdx(materialInput.height));
    float dyc = abs(dFdy(materialInput.height));
    float dF = max(dxc, dyc) * czm_pixelRatio * width;
    float alpha = (distanceToContour < dF) ? 1.0 : 0.0;
#else
    // If no derivatives available (IE 10?), use pixel ratio
    float alpha = (distanceToContour < (czm_pixelRatio * width)) ? 1.0 : 0.0;
#endif

    vec4 outColor = czm_gammaCorrect(vec4(color.rgb, alpha * color.a));
    material.diffuse = outColor.rgb;
    material.alpha = outColor.a;

    return material;
}
`});var Hx,vx=S(()=>{Hx=`uniform sampler2D image;
uniform float minimumHeight;
uniform float maximumHeight;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);
    float scaledHeight = clamp((materialInput.height - minimumHeight) / (maximumHeight - minimumHeight), 0.0, 1.0);
    vec4 rampColor = texture(image, vec2(scaledHeight, 0.5));
    rampColor = czm_gammaCorrect(rampColor);
    material.diffuse = rampColor.rgb;
    material.alpha = rampColor.a;
    return material;
}
`});var zx,Kx=S(()=>{zx=`uniform vec4 fadeInColor;
uniform vec4 fadeOutColor;
uniform float maximumDistance;
uniform bool repeat;
uniform vec2 fadeDirection;
uniform vec2 time;

float getTime(float t, float coord)
{
    float scalar = 1.0 / maximumDistance;
    float q  = distance(t, coord) * scalar;
    if (repeat)
    {
        float r = distance(t, coord + 1.0) * scalar;
        float s = distance(t, coord - 1.0) * scalar;
        q = min(min(r, s), q);
    }
    return clamp(q, 0.0, 1.0);
}

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;
    float s = getTime(time.x, st.s) * fadeDirection.s;
    float t = getTime(time.y, st.t) * fadeDirection.t;

    float u = length(vec2(s, t));
    vec4 color = mix(fadeInColor, fadeOutColor, u);

    color = czm_gammaCorrect(color);
    material.emission = color.rgb;
    material.alpha = color.a;

    return material;
}
`});var Xx,qx=S(()=>{Xx=`uniform vec4 color;
uniform float cellAlpha;
uniform vec2 lineCount;
uniform vec2 lineThickness;
uniform vec2 lineOffset;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;

    float scaledWidth = fract(lineCount.s * st.s - lineOffset.s);
    scaledWidth = abs(scaledWidth - floor(scaledWidth + 0.5));
    float scaledHeight = fract(lineCount.t * st.t - lineOffset.t);
    scaledHeight = abs(scaledHeight - floor(scaledHeight + 0.5));

    float value;

    // Fuzz Factor - Controls blurriness of lines
#if (__VERSION__ == 300 || defined(GL_OES_standard_derivatives))
    const float fuzz = 1.2;
    vec2 thickness = (lineThickness * czm_pixelRatio) - 1.0;

    // From "3D Engine Design for Virtual Globes" by Cozzi and Ring, Listing 4.13.
    vec2 dx = abs(dFdx(st));
    vec2 dy = abs(dFdy(st));
    vec2 dF = vec2(max(dx.s, dy.s), max(dx.t, dy.t)) * lineCount;
    value = min(
        smoothstep(dF.s * thickness.s, dF.s * (fuzz + thickness.s), scaledWidth),
        smoothstep(dF.t * thickness.t, dF.t * (fuzz + thickness.t), scaledHeight));
#else
    // If no derivatives available (IE 10?), revert to view-dependent fuzz
    const float fuzz = 0.05;

    vec2 range = 0.5 - (lineThickness * 0.05);
    value = min(
        1.0 - smoothstep(range.s, range.s + fuzz, scaledWidth),
        1.0 - smoothstep(range.t, range.t + fuzz, scaledHeight));
#endif

    // Edges taken from RimLightingMaterial.glsl
    // See http://www.fundza.com/rman_shaders/surface/fake_rim/fake_rim1.html
    float dRim = 1.0 - abs(dot(materialInput.normalEC, normalize(materialInput.positionToEyeEC)));
    float sRim = smoothstep(0.8, 1.0, dRim);
    value *= (1.0 - sRim);

    vec4 halfColor;
    halfColor.rgb = color.rgb * 0.5;
    halfColor.a = color.a * (1.0 - ((1.0 - cellAlpha) * value));
    halfColor = czm_gammaCorrect(halfColor);
    material.diffuse = halfColor.rgb;
    material.emission = halfColor.rgb;
    material.alpha = halfColor.a;

    return material;
}
`});var $x,tP=S(()=>{$x=`uniform sampler2D image;
uniform float strength;
uniform vec2 repeat;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);
    
    vec4 textureValue = texture(image, fract(repeat * materialInput.st));
    vec3 normalTangentSpace = textureValue.channels;
    normalTangentSpace.xy = normalTangentSpace.xy * 2.0 - 1.0;
    normalTangentSpace.z = clamp(1.0 - strength, 0.1, 1.0);
    normalTangentSpace = normalize(normalTangentSpace);
    vec3 normalEC = materialInput.tangentToEyeMatrix * normalTangentSpace;
    
    material.normal = normalEC;
    
    return material;
}
`});var eP,iP=S(()=>{eP=`uniform vec4 color;

float getPointOnLine(vec2 p0, vec2 p1, float x)
{
    float slope = (p0.y - p1.y) / (p0.x - p1.x);
    return slope * (x - p0.x) + p0.y;
}

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;

#if (__VERSION__ == 300 || defined(GL_OES_standard_derivatives))
    float base = 1.0 - abs(fwidth(st.s)) * 10.0 * czm_pixelRatio;
#else
     // If no derivatives available (IE 10?), 2.5% of the line will be the arrow head
    float base = 0.975;
#endif

    vec2 center = vec2(1.0, 0.5);
    float ptOnUpperLine = getPointOnLine(vec2(base, 1.0), center, st.s);
    float ptOnLowerLine = getPointOnLine(vec2(base, 0.0), center, st.s);

    float halfWidth = 0.15;
    float s = step(0.5 - halfWidth, st.t);
    s *= 1.0 - step(0.5 + halfWidth, st.t);
    s *= 1.0 - step(base, st.s);

    float t = step(base, materialInput.st.s);
    t *= 1.0 - step(ptOnUpperLine, st.t);
    t *= step(ptOnLowerLine, st.t);

    // Find the distance from the closest separator (region between two colors)
    float dist;
    if (st.s < base)
    {
        float d1 = abs(st.t - (0.5 - halfWidth));
        float d2 = abs(st.t - (0.5 + halfWidth));
        dist = min(d1, d2);
    }
    else
    {
        float d1 = czm_infinity;
        if (st.t < 0.5 - halfWidth && st.t > 0.5 + halfWidth)
        {
            d1 = abs(st.s - base);
        }
        float d2 = abs(st.t - ptOnUpperLine);
        float d3 = abs(st.t - ptOnLowerLine);
        dist = min(min(d1, d2), d3);
    }

    vec4 outsideColor = vec4(0.0);
    vec4 currentColor = mix(outsideColor, color, clamp(s + t, 0.0, 1.0));
    vec4 outColor = czm_antialias(outsideColor, color, currentColor, dist);

    outColor = czm_gammaCorrect(outColor);
    material.diffuse = outColor.rgb;
    material.alpha = outColor.a;
    return material;
}
`});var nP,sP=S(()=>{nP=`uniform vec4 color;
uniform vec4 gapColor;
uniform float dashLength;
uniform float dashPattern;
in float v_polylineAngle;

const float maskLength = 16.0;

mat2 rotate(float rad) {
    float c = cos(rad);
    float s = sin(rad);
    return mat2(
        c, s,
        -s, c
    );
}

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 pos = rotate(v_polylineAngle) * gl_FragCoord.xy;

    // Get the relative position within the dash from 0 to 1
    float dashPosition = fract(pos.x / (dashLength * czm_pixelRatio));
    // Figure out the mask index.
    float maskIndex = floor(dashPosition * maskLength);
    // Test the bit mask.
    float maskTest = floor(dashPattern / pow(2.0, maskIndex));
    vec4 fragColor = (mod(maskTest, 2.0) < 1.0) ? gapColor : color;
    if (fragColor.a < 0.005) {   // matches 0/255 and 1/255
        discard;
    }

    fragColor = czm_gammaCorrect(fragColor);
    material.emission = fragColor.rgb;
    material.alpha = fragColor.a;
    return material;
}
`});var oP,rP=S(()=>{oP=`uniform vec4 color;
uniform float glowPower;
uniform float taperPower;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;
    float glow = glowPower / abs(st.t - 0.5) - (glowPower / 0.5);

    if (taperPower <= 0.99999) {
        glow *= min(1.0, taperPower / (0.5 - st.s * 0.5) - (taperPower / 0.5));
    }

    vec4 fragColor;
    fragColor.rgb = max(vec3(glow - 1.0 + color.rgb), color.rgb);
    fragColor.a = clamp(0.0, 1.0, glow) * color.a;
    fragColor = czm_gammaCorrect(fragColor);

    material.emission = fragColor.rgb;
    material.alpha = fragColor.a;

    return material;
}
`});var aP,AP=S(()=>{aP=`uniform vec4 color;
uniform vec4 outlineColor;
uniform float outlineWidth;

in float v_width;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    vec2 st = materialInput.st;
    float halfInteriorWidth =  0.5 * (v_width - outlineWidth) / v_width;
    float b = step(0.5 - halfInteriorWidth, st.t);
    b *= 1.0 - step(0.5 + halfInteriorWidth, st.t);

    // Find the distance from the closest separator (region between two colors)
    float d1 = abs(st.t - (0.5 - halfInteriorWidth));
    float d2 = abs(st.t - (0.5 + halfInteriorWidth));
    float dist = min(d1, d2);

    vec4 currentColor = mix(outlineColor, color, b);
    vec4 outColor = czm_antialias(outlineColor, color, currentColor, dist);
    outColor = czm_gammaCorrect(outColor);

    material.diffuse = outColor.rgb;
    material.alpha = outColor.a;

    return material;
}
`});var hP,cP=S(()=>{hP=`uniform vec4 color;
uniform vec4 rimColor;
uniform float width;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    // See http://www.fundza.com/rman_shaders/surface/fake_rim/fake_rim1.html
    float d = 1.0 - dot(materialInput.normalEC, normalize(materialInput.positionToEyeEC));
    float s = smoothstep(1.0 - width, 1.0, d);

    vec4 outColor = czm_gammaCorrect(color);
    vec4 outRimColor = czm_gammaCorrect(rimColor);

    material.diffuse = outColor.rgb;
    material.emission = outRimColor.rgb * s;
    material.alpha = mix(outColor.a, outRimColor.a, s);

    return material;
}
`});var lP,dP=S(()=>{lP=`uniform sampler2D image;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);
    vec4 rampColor = texture(image, vec2(materialInput.slope / (czm_pi / 2.0), 0.5));
    rampColor = czm_gammaCorrect(rampColor);
    material.diffuse = rampColor.rgb;
    material.alpha = rampColor.a;
    return material;
}
`});var mP,fP=S(()=>{mP=`uniform vec4 evenColor;
uniform vec4 oddColor;
uniform float offset;
uniform float repeat;
uniform bool horizontal;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    // Based on the Stripes Fragment Shader in the Orange Book (11.1.2)
    float coord = mix(materialInput.st.s, materialInput.st.t, float(horizontal));
    float value = fract((coord - offset) * (repeat * 0.5));
    float dist = min(value, min(abs(value - 0.5), 1.0 - value));

    vec4 currentColor = mix(evenColor, oddColor, step(0.5, value));
    vec4 color = czm_antialias(evenColor, oddColor, currentColor, dist);
    color = czm_gammaCorrect(color);

    material.diffuse = color.rgb;
    material.alpha = color.a;

    return material;
}
`});var EP,_P=S(()=>{EP=`// Thanks for the contribution Jonas
// http://29a.ch/2012/7/19/webgl-terrain-rendering-water-fog

uniform sampler2D specularMap;
uniform sampler2D normalMap;
uniform vec4 baseWaterColor;
uniform vec4 blendColor;
uniform float frequency;
uniform float animationSpeed;
uniform float amplitude;
uniform float specularIntensity;
uniform float fadeFactor;

czm_material czm_getMaterial(czm_materialInput materialInput)
{
    czm_material material = czm_getDefaultMaterial(materialInput);

    float time = czm_frameNumber * animationSpeed;

    // fade is a function of the distance from the fragment and the frequency of the waves
    float fade = max(1.0, (length(materialInput.positionToEyeEC) / 10000000000.0) * frequency * fadeFactor);

    float specularMapValue = texture(specularMap, materialInput.st).r;

    // note: not using directional motion at this time, just set the angle to 0.0;
    vec4 noise = czm_getWaterNoise(normalMap, materialInput.st * frequency, time, 0.0);
    vec3 normalTangentSpace = noise.xyz * vec3(1.0, 1.0, (1.0 / amplitude));

    // fade out the normal perturbation as we move further from the water surface
    normalTangentSpace.xy /= fade;

    // attempt to fade out the normal perturbation as we approach non water areas (low specular map value)
    normalTangentSpace = mix(vec3(0.0, 0.0, 50.0), normalTangentSpace, specularMapValue);

    normalTangentSpace = normalize(normalTangentSpace);

    // get ratios for alignment of the new normal vector with a vector perpendicular to the tangent plane
    float tsPerturbationRatio = clamp(dot(normalTangentSpace, vec3(0.0, 0.0, 1.0)), 0.0, 1.0);

    // fade out water effect as specular map value decreases
    material.alpha = mix(blendColor.a, baseWaterColor.a, specularMapValue) * specularMapValue;

    // base color is a blend of the water and non-water color based on the value from the specular map
    // may need a uniform blend factor to better control this
    material.diffuse = mix(blendColor.rgb, baseWaterColor.rgb, specularMapValue);

    // diffuse highlights are based on how perturbed the normal is
    material.diffuse += (0.1 * tsPerturbationRatio);

    material.diffuse = material.diffuse;

    material.normal = normalize(materialInput.tangentToEyeMatrix * normalTangentSpace);

    material.specular = specularIntensity;
    material.shininess = 10.0;

    return material;
}
`});function Qt(t){this.type=void 0,this.shaderSource=void 0,this.materials=void 0,this.uniforms=void 0,this._uniforms=void 0,this.translucent=void 0,this._minificationFilter=Z(t.minificationFilter,_s.LINEAR),this._magnificationFilter=Z(t.magnificationFilter,Na.LINEAR),this._strict=void 0,this._template=void 0,this._count=void 0,this._texturePaths={},this._loadedImages=[],this._loadedCubeMaps=[],this._textures={},this._updateFunctions=[],this._defaultTexture=void 0,Mnt(t,this),Object.defineProperties(this,{type:{value:this.type,writable:!1}}),m(Qt._uniformList[this.type])||(Qt._uniformList[this.type]=Object.keys(this._uniforms))}function Mnt(t,e){t=Z(t,Z.EMPTY_OBJECT),e._strict=Z(t.strict,!1),e._count=Z(t.count,0),e._template=qs(Z(t.fabric,Z.EMPTY_OBJECT)),e._template.uniforms=qs(Z(e._template.uniforms,Z.EMPTY_OBJECT)),e._template.materials=qs(Z(e._template.materials,Z.EMPTY_OBJECT)),e.type=m(e._template.type)?e._template.type:Bs(),e.shaderSource="",e.materials={},e.uniforms={},e._uniforms={},e._translucentFunctions=[];let i,n=Qt._materialCache.getMaterial(e.type);if(m(n)){let o=qs(n.fabric,!0);e._template=es(e._template,o,!0),i=n.translucent}ynt(e),m(n)||Qt._materialCache.addMaterial(e.type,e),xnt(e),Hnt(e),znt(e);let s=e._translucentFunctions.length===0?!0:void 0;if(i=Z(i,s),i=Z(t.translucent,i),m(i))if(typeof i=="function"){let o=function(){return i(e)};e._translucentFunctions.push(o)}else e._translucentFunctions.push(i)}function yN(t,e,i,n){if(m(t)){for(let s in t)if(t.hasOwnProperty(s)){let o=e.indexOf(s)!==-1;(n&&!o||!n&&o)&&i(s,e)}}}function RP(t,e){let i=`fabric: property name '${t}' is not valid. It should be `;for(let n=0;n<e.length;n++){let s=`'${e[n]}'`;i+=n===e.length-1?`or ${s}.`:`${s}, `}throw new Y(i)}function Qnt(t,e){let i=`fabric: uniforms and materials cannot share the same property '${t}'`;throw new Y(i)}function ynt(t){let e=t._template,i=e.uniforms,n=e.materials,s=e.components;if(m(s)&&m(e.source))throw new Y("fabric: cannot have source and components in the same template.");yN(e,knt,RP,!0),yN(s,Lnt,RP,!0);let o=[];for(let r in n)n.hasOwnProperty(r)&&o.push(r);yN(i,o,Qnt,!1)}function wnt(t,e){let i=e._template.materials;for(let n in i)if(i.hasOwnProperty(n)&&t.indexOf(n)>-1)return!0;return!1}function xnt(t){let e=t._template.components,i=t._template.source;if(m(i))t.shaderSource+=`${i}
`;else{if(t.shaderSource+=`czm_material czm_getMaterial(czm_materialInput materialInput)
{
`,t.shaderSource+=`czm_material material = czm_getDefaultMaterial(materialInput);
`,m(e)){let n=Object.keys(t._template.materials).length>0;for(let s in e)if(e.hasOwnProperty(s))if(s==="diffuse"||s==="emission"){let r=n&&wnt(e[s],t)?e[s]:`czm_gammaCorrect(${e[s]})`;t.shaderSource+=`material.${s} = ${r}; 
`}else s==="alpha"?t.shaderSource+=`material.alpha = ${e.alpha}; 
`:t.shaderSource+=`material.${s} = ${e[s]};
`}t.shaderSource+=`return material;
}
`}}function Jnt(t){let e;return function(i,n){let s=i.uniforms,o=s[t],r=e!==o,a=!m(o)||o===Qt.DefaultImageId;e=o;let h=i._textures[t],A,d;if(o instanceof HTMLVideoElement){if(o.readyState>=2){if(r&&m(h)&&(h!==n.defaultTexture&&h.destroy(),h=void 0),!m(h)||h===n.defaultTexture){let E=new ZA({minificationFilter:i._minificationFilter,magnificationFilter:i._magnificationFilter});h=new ba({context:n,source:o,sampler:E}),i._textures[t]=h;return}h.copyFrom({source:o})}else m(h)||(i._textures[t]=n.defaultTexture);return}if(o instanceof ba&&o!==h){i._texturePaths[t]=void 0;let E=i._textures[t];m(E)&&E!==i._defaultTexture&&E.destroy(),i._textures[t]=o,A=`${t}Dimensions`,s.hasOwnProperty(A)&&(d=s[A],d.x=o._width,d.y=o._height);return}if(r&&m(h)&&a&&(h!==i._defaultTexture&&h.destroy(),h=void 0),m(h)||(i._texturePaths[t]=void 0,h=i._textures[t]=i._defaultTexture,A=`${t}Dimensions`,s.hasOwnProperty(A)&&(d=s[A],d.x=h._width,d.y=h._height)),a)return;let f=o instanceof tn;if(!m(i._texturePaths[t])||f&&o.url!==i._texturePaths[t].url||!f&&o!==i._texturePaths[t]){if(typeof o=="string"||f){let E=f?o:tn.createIfNeeded(o),_;Pnt.test(E.url)?_=Ox(E.url):_=E.fetchImage(),Promise.resolve(_).then(function(R){i._loadedImages.push({id:t,image:R})}).catch(function(){m(h)&&h!==i._defaultTexture&&h.destroy(),i._textures[t]=i._defaultTexture})}else(o instanceof HTMLCanvasElement||o instanceof HTMLImageElement)&&i._loadedImages.push({id:t,image:o});i._texturePaths[t]=o}}}function jnt(t){return function(e,i){let n=e.uniforms[t];if(n instanceof LN){let o=e._textures[t];o!==e._defaultTexture&&o.destroy(),e._texturePaths[t]=void 0,e._textures[t]=n;return}if(m(e._textures[t])||(e._texturePaths[t]=void 0,e._textures[t]=i.defaultCubeMap),n===Qt.DefaultCubeMapId)return;let s=n.positiveX+n.negativeX+n.positiveY+n.negativeY+n.positiveZ+n.negativeZ;if(s!==e._texturePaths[t]){let o=[tn.createIfNeeded(n.positiveX).fetchImage(),tn.createIfNeeded(n.negativeX).fetchImage(),tn.createIfNeeded(n.positiveY).fetchImage(),tn.createIfNeeded(n.negativeY).fetchImage(),tn.createIfNeeded(n.positiveZ).fetchImage(),tn.createIfNeeded(n.negativeZ).fetchImage()];Promise.all(o).then(function(r){e._loadedCubeMaps.push({id:t,images:r})}),e._texturePaths[t]=s}}}function Hnt(t){let e=t._template.uniforms;for(let i in e)e.hasOwnProperty(i)&&IP(t,i)}function IP(t,e){let i=t._strict,n=t._template.uniforms,s=n[e],o=vnt(s);if(!m(o))throw new Y(`fabric: uniform '${e}' has invalid type.`);let r;if(o==="channels"){if(r=$E(t,e,s,!1),r===0&&i)throw new Y(`strict: shader source does not use channels '${e}'.`)}else{if(o==="sampler2D"){let A=`${e}Dimensions`;Knt(t,A)>0&&(n[A]={type:"ivec3",x:1,y:1},IP(t,A))}if(!new RegExp(`uniform\\s+${o}\\s+${e}\\s*;`).test(t.shaderSource)){let A=`uniform ${o} ${e};`;t.shaderSource=A+t.shaderSource}let h=`${e}_${t._count++}`;if(r=$E(t,e,h),r===1&&i)throw new Y(`strict: shader source does not use uniform '${e}'.`);if(t.uniforms[e]=s,o==="sampler2D")t._uniforms[h]=function(){return t._textures[e]},t._updateFunctions.push(Jnt(e));else if(o==="samplerCube")t._uniforms[h]=function(){return t._textures[e]},t._updateFunctions.push(jnt(e));else if(o.indexOf("mat")!==-1){let A=new ZP[o];t._uniforms[h]=function(){return ZP[o].fromColumnMajorArray(t.uniforms[e],A)}}else t._uniforms[h]=function(){return t.uniforms[e]}}}function vnt(t){let e=t.type;if(!m(e)){let i=typeof t;if(i==="number")e="float";else if(i==="boolean")e="bool";else if(i==="string"||t instanceof tn||t instanceof HTMLCanvasElement||t instanceof HTMLImageElement)/^([rgba]){1,4}$/i.test(t)?e="channels":t===Qt.DefaultCubeMapId?e="samplerCube":e="sampler2D";else if(i==="object")if(Array.isArray(t))(t.length===4||t.length===9||t.length===16)&&(e=`mat${Math.sqrt(t.length)}`);else{let n=0;for(let s in t)t.hasOwnProperty(s)&&(n+=1);n>=2&&n<=4?e=`vec${n}`:n===6&&(e="samplerCube")}}return e}function znt(t){let e=t._strict,i=t._template.materials;for(let n in i)if(i.hasOwnProperty(n)){let s=new Qt({strict:e,fabric:i[n],count:t._count});t._count=s._count,t._uniforms=es(t._uniforms,s._uniforms,!0),t.materials[n]=s,t._translucentFunctions=t._translucentFunctions.concat(s._translucentFunctions);let o="czm_getMaterial",r=`${o}_${t._count++}`;$E(s,o,r),t.shaderSource=s.shaderSource+t.shaderSource;let a=`${r}(materialInput)`;if($E(t,n,a)===0&&e)throw new Y(`strict: shader source does not use material '${n}'.`)}}function $E(t,e,i,n){n=Z(n,!0);let s=0,o="([\\w])?",r=`([\\w${n?".":""}])?`,a=new RegExp(r+e+o,"g");return t.shaderSource=t.shaderSource.replace(a,function(h,A,d){return A||d?h:(s+=1,i)}),s}function Knt(t,e,i){return $E(t,e,e,i)}var knt,Lnt,ZP,Pnt,wN,pP=S(()=>{Xe();aE();Qn();KA();ih();Ft();mt();Ws();Ot();Bx();dc();dn();bi();Ia();Wx();uI();Ux();Qx();Lx();wx();Px();jx();vx();Kx();qx();tP();iP();sP();rP();AP();cP();YE();dP();fP();NE();FE();_P();Qt._uniformList={};Qt.fromType=function(t,e){if(!m(Qt._materialCache.getMaterial(t)))throw new Y(`material with type '${t}' does not exist.`);let i=new Qt({fabric:{type:t}});if(m(e))for(let n in e)e.hasOwnProperty(n)&&(i.uniforms[n]=e[n]);return i};Qt.prototype.isTranslucent=function(){if(m(this.translucent))return typeof this.translucent=="function"?this.translucent():this.translucent;let t=!0,e=this._translucentFunctions,i=e.length;for(let n=0;n<i;++n){let s=e[n];if(typeof s=="function"?t=t&&s():t=t&&s,!t)break}return t};Qt.prototype.update=function(t){this._defaultTexture=t.defaultTexture;let e,i,n=this._loadedImages,s=n.length;for(e=0;e<s;++e){let h=n[e];i=h.id;let A=h.image,d;Array.isArray(A)&&(d=A.slice(1,A.length).map(function(I){return I.bufferView}),A=A[0]);let f=new ZA({minificationFilter:this._minificationFilter,magnificationFilter:this._magnificationFilter}),E;m(A.internalFormat)?E=new ba({context:t,pixelFormat:A.internalFormat,width:A.width,height:A.height,source:{arrayBufferView:A.bufferView,mipLevels:d},sampler:f}):E=new ba({context:t,source:A,sampler:f});let _=this._textures[i];m(_)&&_!==this._defaultTexture&&_.destroy(),this._textures[i]=E;let R=`${i}Dimensions`;if(this.uniforms.hasOwnProperty(R)){let I=this.uniforms[R];I.x=E._width,I.y=E._height}}n.length=0;let o=this._loadedCubeMaps;for(s=o.length,e=0;e<s;++e){let h=o[e];i=h.id;let A=h.images,d=new LN({context:t,source:{positiveX:A[0],negativeX:A[1],positiveY:A[2],negativeY:A[3],positiveZ:A[4],negativeZ:A[5]},sampler:new ZA({minificationFilter:this._minificationFilter,magnificationFilter:this._magnificationFilter})});this._textures[i]=d}o.length=0;let r=this._updateFunctions;for(s=r.length,e=0;e<s;++e)r[e](this,t);let a=this.materials;for(let h in a)a.hasOwnProperty(h)&&a[h].update(t)};Qt.prototype.isDestroyed=function(){return!1};Qt.prototype.destroy=function(){let t=this._textures;for(let i in t)if(t.hasOwnProperty(i)){let n=t[i];n!==this._defaultTexture&&n.destroy()}let e=this.materials;for(let i in e)e.hasOwnProperty(i)&&e[i].destroy();return li(this)};knt=["type","materials","uniforms","components","source"],Lnt=["diffuse","specular","shininess","normal","emission","alpha"];ZP={mat2:Hn,mat3:lt,mat4:at},Pnt=/\.ktx2$/i;Qt._materialCache={_materials:{},addMaterial:function(t,e){this._materials[t]=e},getMaterial:function(t){return this._materials[t]}};Qt.DefaultImageId="czm_defaultImage";Qt.DefaultCubeMapId="czm_defaultCubeMap";Qt.ColorType="Color";Qt._materialCache.addMaterial(Qt.ColorType,{fabric:{type:Qt.ColorType,uniforms:{color:new Zt(1,0,0,.5)},components:{diffuse:"color.rgb",alpha:"color.a"}},translucent:function(t){return t.uniforms.color.alpha<1}});Qt.ImageType="Image";Qt._materialCache.addMaterial(Qt.ImageType,{fabric:{type:Qt.ImageType,uniforms:{image:Qt.DefaultImageId,repeat:new nt(1,1),color:new Zt(1,1,1,1)},components:{diffuse:"texture(image, fract(repeat * materialInput.st)).rgb * color.rgb",alpha:"texture(image, fract(repeat * materialInput.st)).a * color.a"}},translucent:function(t){return t.uniforms.color.alpha<1}});Qt.DiffuseMapType="DiffuseMap";Qt._materialCache.addMaterial(Qt.DiffuseMapType,{fabric:{type:Qt.DiffuseMapType,uniforms:{image:Qt.DefaultImageId,channels:"rgb",repeat:new nt(1,1)},components:{diffuse:"texture(image, fract(repeat * materialInput.st)).channels"}},translucent:!1});Qt.AlphaMapType="AlphaMap";Qt._materialCache.addMaterial(Qt.AlphaMapType,{fabric:{type:Qt.AlphaMapType,uniforms:{image:Qt.DefaultImageId,channel:"a",repeat:new nt(1,1)},components:{alpha:"texture(image, fract(repeat * materialInput.st)).channel"}},translucent:!0});Qt.SpecularMapType="SpecularMap";Qt._materialCache.addMaterial(Qt.SpecularMapType,{fabric:{type:Qt.SpecularMapType,uniforms:{image:Qt.DefaultImageId,channel:"r",repeat:new nt(1,1)},components:{specular:"texture(image, fract(repeat * materialInput.st)).channel"}},translucent:!1});Qt.EmissionMapType="EmissionMap";Qt._materialCache.addMaterial(Qt.EmissionMapType,{fabric:{type:Qt.EmissionMapType,uniforms:{image:Qt.DefaultImageId,channels:"rgb",repeat:new nt(1,1)},components:{emission:"texture(image, fract(repeat * materialInput.st)).channels"}},translucent:!1});Qt.BumpMapType="BumpMap";Qt._materialCache.addMaterial(Qt.BumpMapType,{fabric:{type:Qt.BumpMapType,uniforms:{image:Qt.DefaultImageId,channel:"r",strength:.8,repeat:new nt(1,1)},source:Mx},translucent:!1});Qt.NormalMapType="NormalMap";Qt._materialCache.addMaterial(Qt.NormalMapType,{fabric:{type:Qt.NormalMapType,uniforms:{image:Qt.DefaultImageId,channels:"rgb",strength:.8,repeat:new nt(1,1)},source:$x},translucent:!1});Qt.GridType="Grid";Qt._materialCache.addMaterial(Qt.GridType,{fabric:{type:Qt.GridType,uniforms:{color:new Zt(0,1,0,1),cellAlpha:.1,lineCount:new nt(8,8),lineThickness:new nt(1,1),lineOffset:new nt(0,0)},source:Xx},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.cellAlpha<1}});Qt.StripeType="Stripe";Qt._materialCache.addMaterial(Qt.StripeType,{fabric:{type:Qt.StripeType,uniforms:{horizontal:!0,evenColor:new Zt(1,1,1,.5),oddColor:new Zt(0,0,1,.5),offset:0,repeat:5},source:mP},translucent:function(t){let e=t.uniforms;return e.evenColor.alpha<1||e.oddColor.alpha<1}});Qt.CheckerboardType="Checkerboard";Qt._materialCache.addMaterial(Qt.CheckerboardType,{fabric:{type:Qt.CheckerboardType,uniforms:{lightColor:new Zt(1,1,1,.5),darkColor:new Zt(0,0,0,.5),repeat:new nt(5,5)},source:kx},translucent:function(t){let e=t.uniforms;return e.lightColor.alpha<1||e.darkColor.alpha<1}});Qt.DotType="Dot";Qt._materialCache.addMaterial(Qt.DotType,{fabric:{type:Qt.DotType,uniforms:{lightColor:new Zt(1,1,0,.75),darkColor:new Zt(0,1,1,.75),repeat:new nt(5,5)},source:yx},translucent:function(t){let e=t.uniforms;return e.lightColor.alpha<1||e.darkColor.alpha<1}});Qt.WaterType="Water";Qt._materialCache.addMaterial(Qt.WaterType,{fabric:{type:Qt.WaterType,uniforms:{baseWaterColor:new Zt(.2,.3,.6,1),blendColor:new Zt(0,1,.699,1),specularMap:Qt.DefaultImageId,normalMap:Qt.DefaultImageId,frequency:10,animationSpeed:.01,amplitude:1,specularIntensity:.5,fadeFactor:1},source:EP},translucent:function(t){let e=t.uniforms;return e.baseWaterColor.alpha<1||e.blendColor.alpha<1}});Qt.RimLightingType="RimLighting";Qt._materialCache.addMaterial(Qt.RimLightingType,{fabric:{type:Qt.RimLightingType,uniforms:{color:new Zt(1,0,0,.7),rimColor:new Zt(1,1,1,.4),width:.3},source:hP},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.rimColor.alpha<1}});Qt.FadeType="Fade";Qt._materialCache.addMaterial(Qt.FadeType,{fabric:{type:Qt.FadeType,uniforms:{fadeInColor:new Zt(1,0,0,1),fadeOutColor:new Zt(0,0,0,0),maximumDistance:.5,repeat:!0,fadeDirection:{x:!0,y:!0},time:new nt(.5,.5)},source:zx},translucent:function(t){let e=t.uniforms;return e.fadeInColor.alpha<1||e.fadeOutColor.alpha<1}});Qt.PolylineArrowType="PolylineArrow";Qt._materialCache.addMaterial(Qt.PolylineArrowType,{fabric:{type:Qt.PolylineArrowType,uniforms:{color:new Zt(1,1,1,1)},source:eP},translucent:!0});Qt.PolylineDashType="PolylineDash";Qt._materialCache.addMaterial(Qt.PolylineDashType,{fabric:{type:Qt.PolylineDashType,uniforms:{color:new Zt(1,0,1,1),gapColor:new Zt(0,0,0,0),dashLength:16,dashPattern:255},source:nP},translucent:!0});Qt.PolylineGlowType="PolylineGlow";Qt._materialCache.addMaterial(Qt.PolylineGlowType,{fabric:{type:Qt.PolylineGlowType,uniforms:{color:new Zt(0,.5,1,1),glowPower:.25,taperPower:1},source:oP},translucent:!0});Qt.PolylineOutlineType="PolylineOutline";Qt._materialCache.addMaterial(Qt.PolylineOutlineType,{fabric:{type:Qt.PolylineOutlineType,uniforms:{color:new Zt(1,1,1,1),outlineColor:new Zt(1,0,0,1),outlineWidth:1},source:aP},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.outlineColor.alpha<1}});Qt.ElevationContourType="ElevationContour";Qt._materialCache.addMaterial(Qt.ElevationContourType,{fabric:{type:Qt.ElevationContourType,uniforms:{spacing:100,color:new Zt(1,0,0,1),width:1},source:Jx},translucent:!1});Qt.ElevationRampType="ElevationRamp";Qt._materialCache.addMaterial(Qt.ElevationRampType,{fabric:{type:Qt.ElevationRampType,uniforms:{image:Qt.DefaultImageId,minimumHeight:0,maximumHeight:1e4},source:Hx},translucent:!1});Qt.SlopeRampMaterialType="SlopeRamp";Qt._materialCache.addMaterial(Qt.SlopeRampMaterialType,{fabric:{type:Qt.SlopeRampMaterialType,uniforms:{image:Qt.DefaultImageId},source:lP},translucent:!1});Qt.AspectRampMaterialType="AspectRamp";Qt._materialCache.addMaterial(Qt.AspectRampMaterialType,{fabric:{type:Qt.AspectRampMaterialType,uniforms:{image:Qt.DefaultImageId},source:Dx},translucent:!1});Qt.ElevationBandType="ElevationBand";Qt._materialCache.addMaterial(Qt.ElevationBandType,{fabric:{type:Qt.ElevationBandType,uniforms:{heights:Qt.DefaultImageId,colors:Qt.DefaultImageId},source:xx},translucent:!0});wN=Qt});function Ll(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.translucent,!0),i=!1,n=Ll.VERTEX_FORMAT;this.material=m(t.material)?t.material:wN.fromType(wN.ColorType),this.translucent=e,this._vertexShaderSource=Z(t.vertexShaderSource,xN),this._fragmentShaderSource=Z(t.fragmentShaderSource,Xnt),this._renderState=Mo.getDefaultRenderState(e,i,t.renderState),this._closed=i,this._vertexFormat=n}var xN,Xnt,uP,CP=S(()=>{Ft();mt();Il();Ls();px();GN();Cx();LI();pP();xN=`${kI}
${Ix}`,Xnt=ux;_o.isInternetExplorer()||(xN=`#define CLIP_POLYLINE 
${xN}`);Object.defineProperties(Ll.prototype,{vertexShaderSource:{get:function(){let t=this._vertexShaderSource;return this.material.shaderSource.search(/in\s+float\s+v_polylineAngle;/g)!==-1&&(t=`#define POLYLINE_DASH
${t}`),t}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},vertexFormat:{get:function(){return this._vertexFormat}}});Ll.VERTEX_FORMAT=St.POSITION_AND_ST;Ll.prototype.getFragmentShaderSource=Mo.prototype.getFragmentShaderSource;Ll.prototype.isTranslucent=Mo.prototype.isTranslucent;Ll.prototype.getRenderState=Mo.prototype.getRenderState;uP=Ll});function qnt(t){t=Z(t,Z.EMPTY_OBJECT),this.position=t.position,this.normal=t.normal,this.st=t.st,this.bitangent=t.bitangent,this.tangent=t.tangent,this.color=t.color}var we,En=S(()=>{Ft();we=qnt});var $nt,Pe,go=S(()=>{$nt={NONE:0,TOP:1,ALL:2},Pe=Object.freeze($nt)});function tst(t,e){if(!m(t))throw new Y("array is required.");if(!m(e)||e<1)throw new Y("numberOfArrays must be greater than 0.");let i=[],n=t.length,s=0;for(;s<n;){let o=Math.ceil((n-s)/e--);i.push(t.slice(s,s+o)),s+=o}return i}var gP,TP=S(()=>{mt();Ot();gP=tst});function Rh(t,e,i){if(!m(t))throw new Y("context is required");if(!m(e))throw new Y("attributes is required");if(!m(i))throw new Y("numberOfInstances is required");if(this._attributes=e,this._numberOfInstances=i,e.length===0)return;let n=est(e),s=t.floatingPointTexture,o=n===ge.FLOAT&&!s,r=ist(e,o),a=nst(r,e,o),h=Math.floor(en.maximumTextureSize/a),A=Math.min(i,h),d=a*A,f=Math.ceil(i/A),E=1/d,_=E*.5,R=1/f,I=R*.5;this._textureDimensions=new nt(d,f),this._textureStep=new ie(E,_,R,I),this._pixelDatatype=o?ge.UNSIGNED_BYTE:n,this._packFloats=o,this._offsets=r,this._stride=a,this._texture=void 0;let C=4*d*f;this._batchValues=n===ge.FLOAT&&!o?new Float32Array(C):new Uint8Array(C),this._batchValuesDirty=!1}function est(t){let e=!1,i=t.length;for(let n=0;n<i;++n)if(t[n].componentDatatype!==At.UNSIGNED_BYTE){e=!0;break}return e?ge.FLOAT:ge.UNSIGNED_BYTE}function FP(t,e){let i=t[e].componentsPerAttribute;return i===2?nt:i===3?l:i===4?ie:Number}function ist(t,e){let i=new Array(t.length),n=0,s=t.length;for(let o=0;o<s;++o){let a=t[o].componentDatatype;i[o]=n,a!==At.UNSIGNED_BYTE&&e?n+=4:++n}return i}function nst(t,e,i){let n=t.length,s=t[n-1];return e[n-1].componentDatatype!==At.UNSIGNED_BYTE&&i?s+4:s+1}function sst(t,e,i){let n=ie.unpack(t,e,t_),s=ie.unpackFloat(n);n=ie.unpack(t,e+4,t_);let o=ie.unpackFloat(n);n=ie.unpack(t,e+8,t_);let r=ie.unpackFloat(n);n=ie.unpack(t,e+12,t_);let a=ie.unpackFloat(n);return ie.fromElements(s,o,r,a,i)}function ost(t,e,i){let n=ie.packFloat(t.x,t_);ie.pack(n,e,i),n=ie.packFloat(t.y,n),ie.pack(n,e,i+4),n=ie.packFloat(t.z,n),ie.pack(n,e,i+8),n=ie.packFloat(t.w,n),ie.pack(n,e,i+12)}function Ast(t,e){let i=t._textureDimensions;t._texture=new ba({context:e,pixelFormat:Ie.RGBA,pixelDatatype:t._pixelDatatype,width:i.x,height:i.y,sampler:ZA.NEAREST,flipY:!1})}function hst(t){let e=t._textureDimensions;t._texture.copyFrom({source:{width:e.x,height:e.y,arrayBufferView:t._batchValues}})}function cst(t){let e=t._stride;return t._textureDimensions.y===1?`uniform vec4 batchTextureStep; 
vec2 computeSt(float batchId) 
{ 
    float stepX = batchTextureStep.x; 
    float centerX = batchTextureStep.y; 
    float numberOfAttributes = float(${e}); 
    return vec2(centerX + (batchId * numberOfAttributes * stepX), 0.5); 
} 
`:`uniform vec4 batchTextureStep; 
uniform vec2 batchTextureDimensions; 
vec2 computeSt(float batchId) 
{ 
    float stepX = batchTextureStep.x; 
    float centerX = batchTextureStep.y; 
    float stepY = batchTextureStep.z; 
    float centerY = batchTextureStep.w; 
    float numberOfAttributes = float(${e}); 
    float xId = mod(batchId * numberOfAttributes, batchTextureDimensions.x); 
    float yId = floor(batchId * numberOfAttributes / batchTextureDimensions.x); 
    return vec2(centerX + (xId * stepX), centerY + (yId * stepY)); 
} 
`}function lst(t){return t===1?"float":`vec${t}`}function dst(t){return t===1?".x":t===2?".xy":t===3?".xyz":""}function mst(t,e){let n=t._attributes[e],s=n.componentsPerAttribute,o=n.functionName,r=lst(s),a=dst(s),h=t._offsets[e],A=`${r} ${o}(float batchId) 
{ 
    vec2 st = computeSt(batchId); 
    st.x += batchTextureStep.x * float(${h}); 
`;return t._packFloats&&n.componentDatatype!==ge.UNSIGNED_BYTE?A+=`vec4 textureValue; 
textureValue.x = czm_unpackFloat(texture(batchTexture, st)); 
textureValue.y = czm_unpackFloat(texture(batchTexture, st + vec2(batchTextureStep.x, 0.0))); 
textureValue.z = czm_unpackFloat(texture(batchTexture, st + vec2(batchTextureStep.x * 2.0, 0.0))); 
textureValue.w = czm_unpackFloat(texture(batchTexture, st + vec2(batchTextureStep.x * 3.0, 0.0))); 
`:A+=`    vec4 textureValue = texture(batchTexture, st); 
`,A+=`    ${r} value = textureValue${a}; 
`,t._pixelDatatype===ge.UNSIGNED_BYTE&&n.componentDatatype===At.UNSIGNED_BYTE&&!n.normalize?A+=`value *= 255.0; 
`:t._pixelDatatype===ge.FLOAT&&n.componentDatatype===At.UNSIGNED_BYTE&&n.normalize&&(A+=`value /= 255.0; 
`),A+=`    return value; 
} 
`,A}var t_,NP,rst,ast,bP,YP=S(()=>{Xe();Ht();Os();KA();oi();mt();Ws();Ot();_c();ga();Ec();YE();uI();Object.defineProperties(Rh.prototype,{attributes:{get:function(){return this._attributes}},numberOfInstances:{get:function(){return this._numberOfInstances}}});t_=new ie;NP=new ie;Rh.prototype.getBatchedAttribute=function(t,e,i){if(t<0||t>=this._numberOfInstances)throw new Y("instanceIndex is out of range.");if(e<0||e>=this._attributes.length)throw new Y("attributeIndex is out of range");let n=this._attributes,s=this._offsets[e],r=4*this._stride*t+4*s,a;this._packFloats&&n[e].componentDatatype!==ge.UNSIGNED_BYTE?a=sst(this._batchValues,r,NP):a=ie.unpack(this._batchValues,r,NP);let h=FP(n,e);return m(h.fromCartesian4)?h.fromCartesian4(a,i):m(h.clone)?h.clone(a,i):a.x};rst=[void 0,void 0,new nt,new l,new ie],ast=new ie;Rh.prototype.setBatchedAttribute=function(t,e,i){if(t<0||t>=this._numberOfInstances)throw new Y("instanceIndex is out of range.");if(e<0||e>=this._attributes.length)throw new Y("attributeIndex is out of range");if(!m(i))throw new Y("value is required.");let n=this._attributes,s=rst[n[e].componentsPerAttribute],o=this.getBatchedAttribute(t,e,s),r=FP(this._attributes,e);if(m(r.equals)?r.equals(o,i):o===i)return;let h=ast;h.x=m(i.x)?i.x:i,h.y=m(i.y)?i.y:0,h.z=m(i.z)?i.z:0,h.w=m(i.w)?i.w:0;let A=this._offsets[e],f=4*this._stride*t+4*A;this._packFloats&&n[e].componentDatatype!==ge.UNSIGNED_BYTE?ost(h,this._batchValues,f):ie.pack(h,this._batchValues,f),this._batchValuesDirty=!0};Rh.prototype.update=function(t){m(this._texture)&&!this._batchValuesDirty||this._attributes.length===0||(this._batchValuesDirty=!1,m(this._texture)||Ast(this,t.context),hst(this))};Rh.prototype.getUniformMapCallback=function(){let t=this;return function(e){return t._attributes.length===0?e:es(e,{batchTexture:function(){return t._texture},batchTextureDimensions:function(){return t._textureDimensions},batchTextureStep:function(){return t._textureStep}})}};Rh.prototype.getVertexShaderCallback=function(){let t=this._attributes;if(t.length===0)return function(n){return n};let e=`uniform highp sampler2D batchTexture; 
`;e+=`${cst(this)}
`;let i=t.length;for(let n=0;n<i;++n)e+=mst(this,n);return function(n){let s=n.indexOf("void main"),o=n.substring(0,s),r=n.substring(s);return`${o}
${e}
${r}`}};Rh.prototype.isDestroyed=function(){return!1};Rh.prototype.destroy=function(){return this._texture=this._texture&&this._texture.destroy(),li(this)};bP=Rh});var fst,wI,PN=S(()=>{ss();fst={NEVER:it.NEVER,LESS:it.LESS,EQUAL:it.EQUAL,LESS_OR_EQUAL:it.LEQUAL,GREATER:it.GREATER,NOT_EQUAL:it.NOTEQUAL,GREATER_OR_EQUAL:it.GEQUAL,ALWAYS:it.ALWAYS},wI=Object.freeze(fst)});function Est(t,e,i,n,s){p.defined("point",t),p.defined("p0",e),p.defined("p1",i),p.defined("p2",n),m(s)||(s=new l);let o,r,a,h,A,d,f,E;if(m(e.z)){if(l.equalsEpsilon(t,e,L.EPSILON14))return l.clone(l.UNIT_X,s);if(l.equalsEpsilon(t,i,L.EPSILON14))return l.clone(l.UNIT_Y,s);if(l.equalsEpsilon(t,n,L.EPSILON14))return l.clone(l.UNIT_Z,s);o=l.subtract(i,e,VP),r=l.subtract(n,e,SP),a=l.subtract(t,e,OP),h=l.dot(o,o),A=l.dot(o,r),d=l.dot(o,a),f=l.dot(r,r),E=l.dot(r,a)}else{if(nt.equalsEpsilon(t,e,L.EPSILON14))return l.clone(l.UNIT_X,s);if(nt.equalsEpsilon(t,i,L.EPSILON14))return l.clone(l.UNIT_Y,s);if(nt.equalsEpsilon(t,n,L.EPSILON14))return l.clone(l.UNIT_Z,s);o=nt.subtract(i,e,VP),r=nt.subtract(n,e,SP),a=nt.subtract(t,e,OP),h=nt.dot(o,o),A=nt.dot(o,r),d=nt.dot(o,a),f=nt.dot(r,r),E=nt.dot(r,a)}s.y=f*d-A*E,s.z=h*E-A*d;let _=h*f-A*A;if(_!==0)return s.y/=_,s.z/=_,s.x=1-s.y-s.z,s}var VP,SP,OP,BP,GP=S(()=>{Xe();Ht();ae();mt();_e();VP=new l,SP=new l,OP=new l;BP=Est});var JN,WP,DP=S(()=>{Ft();mt();Ot();JN={};JN.calculateACMR=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.indices,i=t.maximumIndex,n=Z(t.cacheSize,24);if(!m(e))throw new Y("indices is required.");let s=e.length;if(s<3||s%3!==0)throw new Y("indices length must be a multiple of three.");if(i<=0)throw new Y("maximumIndex must be greater than zero.");if(n<3)throw new Y("cacheSize must be greater than two.");if(!m(i)){i=0;let a=0,h=e[a];for(;a<s;)h>i&&(i=h),++a,h=e[a]}let o=[];for(let a=0;a<i+1;a++)o[a]=0;let r=n+1;for(let a=0;a<s;++a)r-o[e[a]]>n&&(o[e[a]]=r,++r);return(r-n+1)/(s/3)};JN.tipsify=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.indices,i=t.maximumIndex,n=Z(t.cacheSize,24),s;function o(c,g,O,D){for(;g.length>=1;){let w=g[g.length-1];if(g.splice(g.length-1,1),c[w].numLiveTriangles>0)return w}for(;s<D;){if(c[s].numLiveTriangles>0)return++s,s-1;++s}return-1}function r(c,g,O,D,w,x,H){let j=-1,X,tt=-1,G=0;for(;G<O.length;){let It=O[G];D[It].numLiveTriangles&&(X=0,w-D[It].timeStamp+2*D[It].numLiveTriangles<=g&&(X=w-D[It].timeStamp),(X>tt||tt===-1)&&(tt=X,j=It)),++G}return j===-1?o(D,x,c,H):j}if(!m(e))throw new Y("indices is required.");let a=e.length;if(a<3||a%3!==0)throw new Y("indices length must be a multiple of three.");if(i<=0)throw new Y("maximumIndex must be greater than zero.");if(n<3)throw new Y("cacheSize must be greater than two.");let h=0,A=0,d=e[A],f=a;if(m(i))h=i+1;else{for(;A<f;)d>h&&(h=d),++A,d=e[A];if(h===-1)return 0;++h}let E=[],_;for(_=0;_<h;_++)E[_]={numLiveTriangles:0,timeStamp:0,vertexTriangles:[]};A=0;let R=0;for(;A<f;)E[e[A]].vertexTriangles.push(R),++E[e[A]].numLiveTriangles,E[e[A+1]].vertexTriangles.push(R),++E[e[A+1]].numLiveTriangles,E[e[A+2]].vertexTriangles.push(R),++E[e[A+2]].numLiveTriangles,++R,A+=3;let I=0,C=n+1;s=1;let N=[],T=[],b,F,B=0,U=[],Q=a/3,M=[];for(_=0;_<Q;_++)M[_]=!1;let k,y;for(;I!==-1;){N=[],F=E[I],y=F.vertexTriangles.length;for(let c=0;c<y;++c)if(R=F.vertexTriangles[c],!M[R]){M[R]=!0,A=R+R+R;for(let g=0;g<3;++g)k=e[A],N.push(k),T.push(k),U[B]=k,++B,b=E[k],--b.numLiveTriangles,C-b.timeStamp>n&&(b.timeStamp=C,++C),++A}I=r(e,n,N,E,C,T,h)}return U};WP=JN});function zI(t,e,i,n,s){t[e++]=i,t[e++]=n,t[e++]=n,t[e++]=s,t[e++]=s,t[e]=i}function _st(t){let e=t.length,i=e/3*6,n=te.createTypedArray(e,i),s=0;for(let o=0;o<e;o+=3,s+=6)zI(n,s,t[o],t[o+1],t[o+2]);return n}function Rst(t){let e=t.length;if(e>=3){let i=(e-2)*6,n=te.createTypedArray(e,i);zI(n,0,t[0],t[1],t[2]);let s=6;for(let o=3;o<e;++o,s+=6)zI(n,s,t[o-1],t[o],t[o-2]);return n}return new Uint16Array}function Zst(t){if(t.length>0){let e=t.length-1,i=(e-1)*6,n=te.createTypedArray(e,i),s=t[0],o=0;for(let r=1;r<e;++r,o+=6)zI(n,o,s,t[r],t[r+1]);return n}return new Uint16Array}function UP(t){let e={};for(let i in t)if(t.hasOwnProperty(i)&&m(t[i])&&m(t[i].values)){let n=t[i];e[i]=new Tt({componentDatatype:n.componentDatatype,componentsPerAttribute:n.componentsPerAttribute,normalize:n.normalize,values:[]})}return e}function Ist(t,e,i){for(let n in e)if(e.hasOwnProperty(n)&&m(e[n])&&m(e[n].values)){let s=e[n];for(let o=0;o<s.componentsPerAttribute;++o)t[n].values.push(s.values[i*s.componentsPerAttribute+o])}}function HN(t,e){if(m(e)){let i=e.values,n=i.length;for(let s=0;s<n;s+=3)l.unpack(i,s,Ga),at.multiplyByPoint(t,Ga,Ga),l.pack(Ga,i,s)}}function vN(t,e){if(m(e)){let i=e.values,n=i.length;for(let s=0;s<n;s+=3)l.unpack(i,s,Ga),lt.multiplyByVector(t,Ga,Ga),Ga=l.normalize(Ga,Ga),l.pack(Ga,i,s)}}function ust(t,e){let i=t.length,n={},s=t[0][e].attributes,o;for(o in s)if(s.hasOwnProperty(o)&&m(s[o])&&m(s[o].values)){let r=s[o],a=r.values.length,h=!0;for(let A=1;A<i;++A){let d=t[A][e].attributes[o];if(!m(d)||r.componentDatatype!==d.componentDatatype||r.componentsPerAttribute!==d.componentsPerAttribute||r.normalize!==d.normalize){h=!1;break}a+=d.values.length}h&&(n[o]=new Tt({componentDatatype:r.componentDatatype,componentsPerAttribute:r.componentsPerAttribute,normalize:r.normalize,values:At.createTypedArray(r.componentDatatype,a)}))}return n}function zN(t,e){let i=t.length,n,s,o,r,a=t[0].modelMatrix,h=m(t[0][e].indices),A=t[0][e].primitiveType;for(s=1;s<i;++s){if(!at.equals(t[s].modelMatrix,a))throw new Y("All instances must have the same modelMatrix.");if(m(t[s][e].indices)!==h)throw new Y("All instance geometries must have an indices or not have one.");if(t[s][e].primitiveType!==A)throw new Y("All instance geometries must have the same primitiveType.")}let d=ust(t,e),f,E,_;for(n in d)if(d.hasOwnProperty(n))for(f=d[n].values,r=0,s=0;s<i;++s)for(E=t[s][e].attributes[n].values,_=E.length,o=0;o<_;++o)f[r++]=E[o];let R;if(h){let T=0;for(s=0;s<i;++s)T+=t[s][e].indices.length;let b=se.computeNumberOfVertices(new se({attributes:d,primitiveType:ne.POINTS})),F=te.createTypedArray(b,T),B=0,U=0;for(s=0;s<i;++s){let Q=t[s][e].indices,M=Q.length;for(r=0;r<M;++r)F[B++]=U+Q[r];U+=se.computeNumberOfVertices(t[s][e])}R=F}let I=new l,C=0,N;for(s=0;s<i;++s){if(N=t[s][e].boundingSphere,!m(N)){I=void 0;break}l.add(N.center,I,I)}if(m(I))for(l.divideByScalar(I,i,I),s=0;s<i;++s){N=t[s][e].boundingSphere;let T=l.magnitude(l.subtract(N.center,I,Cst))+N.radius;T>C&&(C=T)}return new se({attributes:d,indices:R,primitiveType:A,boundingSphere:m(I)?new Nt(I,C):void 0})}function Nst(t){if(m(t.indices))return t;let e=se.computeNumberOfVertices(t);if(e<3)throw new Y("The number of vertices must be at least three.");if(e%3!==0)throw new Y("The number of vertices must be a multiple of three.");let i=te.createTypedArray(e,e);for(let n=0;n<e;++n)i[n]=n;return t.indices=i,t}function Fst(t){let e=se.computeNumberOfVertices(t);if(e<3)throw new Y("The number of vertices must be at least three.");let i=te.createTypedArray(e,(e-2)*3);i[0]=1,i[1]=0,i[2]=2;let n=3;for(let s=3;s<e;++s)i[n++]=s-1,i[n++]=0,i[n++]=s;return t.indices=i,t.primitiveType=ne.TRIANGLES,t}function bst(t){let e=se.computeNumberOfVertices(t);if(e<3)throw new Y("The number of vertices must be at least 3.");let i=te.createTypedArray(e,(e-2)*3);i[0]=0,i[1]=1,i[2]=2,e>3&&(i[3]=0,i[4]=2,i[5]=3);let n=6;for(let s=3;s<e-1;s+=2)i[n++]=s,i[n++]=s-1,i[n++]=s+1,s+2<e&&(i[n++]=s,i[n++]=s+1,i[n++]=s+2);return t.indices=i,t.primitiveType=ne.TRIANGLES,t}function Yst(t){if(m(t.indices))return t;let e=se.computeNumberOfVertices(t);if(e<2)throw new Y("The number of vertices must be at least two.");if(e%2!==0)throw new Y("The number of vertices must be a multiple of 2.");let i=te.createTypedArray(e,e);for(let n=0;n<e;++n)i[n]=n;return t.indices=i,t}function Vst(t){let e=se.computeNumberOfVertices(t);if(e<2)throw new Y("The number of vertices must be at least two.");let i=te.createTypedArray(e,(e-1)*2);i[0]=0,i[1]=1;let n=2;for(let s=2;s<e;++s)i[n++]=s-1,i[n++]=s;return t.indices=i,t.primitiveType=ne.LINES,t}function Sst(t){let e=se.computeNumberOfVertices(t);if(e<2)throw new Y("The number of vertices must be at least two.");let i=te.createTypedArray(e,e*2);i[0]=0,i[1]=1;let n=2;for(let s=2;s<e;++s)i[n++]=s-1,i[n++]=s;return i[n++]=e-1,i[n]=0,t.indices=i,t.primitiveType=ne.LINES,t}function Ost(t){switch(t.primitiveType){case ne.TRIANGLE_FAN:return Fst(t);case ne.TRIANGLE_STRIP:return bst(t);case ne.TRIANGLES:return Nst(t);case ne.LINE_STRIP:return Vst(t);case ne.LINE_LOOP:return Sst(t);case ne.LINES:return Yst(t)}return t}function Cc(t,e){Math.abs(t.y)<L.EPSILON6&&(e?t.y=-L.EPSILON6:t.y=L.EPSILON6)}function Bst(t,e,i){if(t.y!==0&&e.y!==0&&i.y!==0){Cc(t,t.y<0),Cc(e,e.y<0),Cc(i,i.y<0);return}let n=Math.abs(t.y),s=Math.abs(e.y),o=Math.abs(i.y),r;n>s?n>o?r=L.sign(t.y):r=L.sign(i.y):s>o?r=L.sign(e.y):r=L.sign(i.y);let a=r<0;Cc(t,a),Cc(e,a),Cc(i,a)}function Hr(t,e,i,n){l.add(t,l.multiplyByScalar(l.subtract(e,t,yP),t.y/(t.y-e.y),yP),i),l.clone(i,n),Cc(i,!0),Cc(n,!1)}function Gst(t,e,i){if(t.x>=0||e.x>=0||i.x>=0)return;Bst(t,e,i);let n=t.y<0,s=e.y<0,o=i.y<0,r=0;r+=n?1:0,r+=s?1:0,r+=o?1:0;let a=KN.indices;r===1?(a[1]=3,a[2]=4,a[5]=6,a[7]=6,a[8]=5,n?(Hr(t,e,yl,xl),Hr(t,i,wl,Pl),a[0]=0,a[3]=1,a[4]=2,a[6]=1):s?(Hr(e,i,yl,xl),Hr(e,t,wl,Pl),a[0]=1,a[3]=2,a[4]=0,a[6]=2):o&&(Hr(i,t,yl,xl),Hr(i,e,wl,Pl),a[0]=2,a[3]=0,a[4]=1,a[6]=0)):r===2&&(a[2]=4,a[4]=4,a[5]=3,a[7]=5,a[8]=6,n?s?o||(Hr(i,t,yl,xl),Hr(i,e,wl,Pl),a[0]=0,a[1]=1,a[3]=0,a[6]=2):(Hr(e,i,yl,xl),Hr(e,t,wl,Pl),a[0]=2,a[1]=0,a[3]=2,a[6]=1):(Hr(t,e,yl,xl),Hr(t,i,wl,Pl),a[0]=1,a[1]=2,a[3]=1,a[6]=0));let h=KN.positions;return h[0]=t,h[1]=e,h[2]=i,h.length=3,(r===1||r===2)&&(h[3]=yl,h[4]=wl,h[5]=xl,h[6]=Pl,h.length=7),KN}function wP(t,e){let i=t.attributes;if(i.position.values.length===0)return;for(let s in i)if(i.hasOwnProperty(s)&&m(i[s])&&m(i[s].values)){let o=i[s];o.values=At.createTypedArray(o.componentDatatype,o.values)}let n=se.computeNumberOfVertices(t);return t.indices=te.createTypedArray(n,t.indices),e&&(t.boundingSphere=Nt.fromVertices(i.position.values)),t}function Km(t){let e=t.attributes,i={};for(let n in e)if(e.hasOwnProperty(n)&&m(e[n])&&m(e[n].values)){let s=e[n];i[n]=new Tt({componentDatatype:s.componentDatatype,componentsPerAttribute:s.componentsPerAttribute,normalize:s.normalize,values:[]})}return new se({attributes:i,indices:[],primitiveType:t.primitiveType})}function tF(t,e,i){let n=m(t.geometry.boundingSphere);e=wP(e,n),i=wP(i,n),m(i)&&!m(e)?t.geometry=i:!m(i)&&m(e)?t.geometry=e:(t.westHemisphereGeometry=e,t.eastHemisphereGeometry=i,t.geometry=void 0)}function eF(t,e){let i=new t,n=new t,s=new t;return function(o,r,a,h,A,d,f,E){let _=t.fromArray(A,o*e,i),R=t.fromArray(A,r*e,n),I=t.fromArray(A,a*e,s);t.multiplyByScalar(_,h.x,_),t.multiplyByScalar(R,h.y,R),t.multiplyByScalar(I,h.z,I);let C=t.add(_,R,_);if(t.add(C,I,C),E)try{t.normalize(C,C)}catch(N){throw new Y(N)}t.pack(C,d,f*e)}}function jI(t,e,i,n,s,o,r,a,h,A,d,f,E,_,R,I){if(!m(o)&&!m(r)&&!m(a)&&!m(h)&&!m(A)&&_===0)return;let C=l.fromArray(s,t*3,n_),N=l.fromArray(s,e*3,XN),T=l.fromArray(s,i*3,qN),b=BP(n,C,N,T,Ust);if(m(b)){if(m(o)&&vI(t,e,i,b,o,f.normal.values,I,!0),m(A)){let F=l.fromArray(A,t*3,n_),B=l.fromArray(A,e*3,XN),U=l.fromArray(A,i*3,qN);l.multiplyByScalar(F,b.x,F),l.multiplyByScalar(B,b.y,B),l.multiplyByScalar(U,b.z,U);let Q;!l.equals(F,l.ZERO)||!l.equals(B,l.ZERO)||!l.equals(U,l.ZERO)?(Q=l.add(F,B,F),l.add(Q,U,Q),l.normalize(Q,Q)):(Q=n_,Q.x=0,Q.y=0,Q.z=0),l.pack(Q,f.extrudeDirection.values,I*3)}if(m(d)&&Dst(t,e,i,b,d,f.applyOffset.values,I),m(r)&&vI(t,e,i,b,r,f.tangent.values,I,!0),m(a)&&vI(t,e,i,b,a,f.bitangent.values,I,!0),m(h)&&vP(t,e,i,b,h,f.st.values,I),_>0)for(let F=0;F<_;F++){let B=E[F];Mst(t,e,i,b,I,R[B],f[B])}}}function Mst(t,e,i,n,s,o,r){let a=o.componentsPerAttribute,h=o.values,A=r.values;switch(a){case 4:Wst(t,e,i,n,h,A,s,!1);break;case 3:vI(t,e,i,n,h,A,s,!1);break;case 2:vP(t,e,i,n,h,A,s,!1);break;default:A[s]=h[t]*n.x+h[e]*n.y+h[i]*n.z}}function CA(t,e,i,n,s,o){let r=t.position.values.length/3;if(s!==-1){let a=n[s],h=i[a];return h===-1?(i[a]=r,t.position.values.push(o.x,o.y,o.z),e.push(r),r):(e.push(h),h)}return t.position.values.push(o.x,o.y,o.z),e.push(r),r}function xP(t){let e=t.geometry,i=e.attributes,n=i.position.values,s=m(i.normal)?i.normal.values:void 0,o=m(i.bitangent)?i.bitangent.values:void 0,r=m(i.tangent)?i.tangent.values:void 0,a=m(i.st)?i.st.values:void 0,h=m(i.extrudeDirection)?i.extrudeDirection.values:void 0,A=m(i.applyOffset)?i.applyOffset.values:void 0,d=e.indices,f=[];for(let Q in i)i.hasOwnProperty(Q)&&!Qst[Q]&&m(i[Q])&&f.push(Q);let E=f.length,_=Km(e),R=Km(e),I,C,N,T,b,F=[];F.length=n.length/3;let B=[];for(B.length=n.length/3,b=0;b<F.length;++b)F[b]=-1,B[b]=-1;let U=d.length;for(b=0;b<U;b+=3){let Q=d[b],M=d[b+1],k=d[b+2],y=l.fromArray(n,Q*3),c=l.fromArray(n,M*3),g=l.fromArray(n,k*3),O=Gst(y,c,g);if(m(O)&&O.positions.length>3){let D=O.positions,w=O.indices,x=w.length;for(let H=0;H<x;++H){let j=w[H],X=D[j];X.y<0?(I=R.attributes,C=R.indices,N=F):(I=_.attributes,C=_.indices,N=B),T=CA(I,C,N,d,j<3?b+j:-1,X),jI(Q,M,k,X,n,s,r,o,a,h,A,I,f,E,i,T)}}else m(O)&&(y=O.positions[0],c=O.positions[1],g=O.positions[2]),y.y<0?(I=R.attributes,C=R.indices,N=F):(I=_.attributes,C=_.indices,N=B),T=CA(I,C,N,d,b,y),jI(Q,M,k,y,n,s,r,o,a,h,A,I,f,E,i,T),T=CA(I,C,N,d,b+1,c),jI(Q,M,k,c,n,s,r,o,a,h,A,I,f,E,i,T),T=CA(I,C,N,d,b+2,g),jI(Q,M,k,g,n,s,r,o,a,h,A,I,f,E,i,T)}tF(t,R,_)}function zm(t,e,i,n,s,o,r){if(!m(r))return;let a=l.fromArray(n,t*3,n_);l.equalsEpsilon(a,i,L.EPSILON10)?o.applyOffset.values[s]=r[t]:o.applyOffset.values[s]=r[e]}function PP(t){let e=t.geometry,i=e.attributes,n=i.position.values,s=m(i.applyOffset)?i.applyOffset.values:void 0,o=e.indices,r=Km(e),a=Km(e),h,A=o.length,d=[];d.length=n.length/3;let f=[];for(f.length=n.length/3,h=0;h<d.length;++h)d[h]=-1,f[h]=-1;for(h=0;h<A;h+=2){let E=o[h],_=o[h+1],R=l.fromArray(n,E*3,n_),I=l.fromArray(n,_*3,XN),C;Math.abs(R.y)<L.EPSILON6&&(R.y<0?R.y=-L.EPSILON6:R.y=L.EPSILON6),Math.abs(I.y)<L.EPSILON6&&(I.y<0?I.y=-L.EPSILON6:I.y=L.EPSILON6);let N=r.attributes,T=r.indices,b=f,F=a.attributes,B=a.indices,U=d,Q=no.lineSegmentPlane(R,I,zP,qN);if(m(Q)){let M=l.multiplyByScalar(l.UNIT_Y,5*L.EPSILON9,kst);R.y<0&&(l.negate(M,M),N=a.attributes,T=a.indices,b=d,F=r.attributes,B=r.indices,U=f);let k=l.add(Q,M,Lst);C=CA(N,T,b,o,h,R),zm(E,_,R,n,C,N,s),C=CA(N,T,b,o,-1,k),zm(E,_,k,n,C,N,s),l.negate(M,M),l.add(Q,M,k),C=CA(F,B,U,o,-1,k),zm(E,_,k,n,C,F,s),C=CA(F,B,U,o,h+1,I),zm(E,_,I,n,C,F,s)}else{let M,k,y;R.y<0?(M=a.attributes,k=a.indices,y=d):(M=r.attributes,k=r.indices,y=f),C=CA(M,k,y,o,h,R),zm(E,_,R,n,C,M,s),C=CA(M,k,y,o,h+1,I),zm(E,_,I,n,C,M,s)}}tF(t,a,r)}function HP(t){let e=t.attributes,i=e.position.values,n=e.prevPosition.values,s=e.nextPosition.values,o=i.length;for(let r=0;r<o;r+=3){let a=l.unpack(i,r,KP);if(a.x>0)continue;let h=l.unpack(n,r,XP);(a.y<0&&h.y>0||a.y>0&&h.y<0)&&(r-3>0?(n[r]=i[r-3],n[r+1]=i[r-2],n[r+2]=i[r-1]):l.pack(a,n,r));let A=l.unpack(s,r,$N);(a.y<0&&A.y>0||a.y>0&&A.y<0)&&(r+3<o?(s[r]=i[r+3],s[r+1]=i[r+4],s[r+2]=i[r+5]):l.pack(a,s,r))}}function jst(t){let e=t.geometry,i=e.attributes,n=i.position.values,s=i.prevPosition.values,o=i.nextPosition.values,r=i.expandAndWidth.values,a=m(i.st)?i.st.values:void 0,h=m(i.color)?i.color.values:void 0,A=Km(e),d=Km(e),f,E,_,R=!1,I=n.length/3;for(f=0;f<I;f+=4){let C=f,N=f+2,T=l.fromArray(n,C*3,KP),b=l.fromArray(n,N*3,XP);if(Math.abs(T.y)<HI)for(T.y=HI*(b.y<0?-1:1),n[f*3+1]=T.y,n[(f+1)*3+1]=T.y,E=C*3;E<C*3+4*3;E+=3)s[E]=n[f*3],s[E+1]=n[f*3+1],s[E+2]=n[f*3+2];if(Math.abs(b.y)<HI)for(b.y=HI*(T.y<0?-1:1),n[(f+2)*3+1]=b.y,n[(f+3)*3+1]=b.y,E=C*3;E<C*3+4*3;E+=3)o[E]=n[(f+2)*3],o[E+1]=n[(f+2)*3+1],o[E+2]=n[(f+2)*3+2];let F=A.attributes,B=A.indices,U=d.attributes,Q=d.indices,M=no.lineSegmentPlane(T,b,zP,wst);if(m(M)){R=!0;let k=l.multiplyByScalar(l.UNIT_Y,Jst,xst);T.y<0&&(l.negate(k,k),F=d.attributes,B=d.indices,U=A.attributes,Q=A.indices);let y=l.add(M,k,Pst);F.position.values.push(T.x,T.y,T.z,T.x,T.y,T.z),F.position.values.push(y.x,y.y,y.z),F.position.values.push(y.x,y.y,y.z),F.prevPosition.values.push(s[C*3],s[C*3+1],s[C*3+2]),F.prevPosition.values.push(s[C*3+3],s[C*3+4],s[C*3+5]),F.prevPosition.values.push(T.x,T.y,T.z,T.x,T.y,T.z),F.nextPosition.values.push(y.x,y.y,y.z),F.nextPosition.values.push(y.x,y.y,y.z),F.nextPosition.values.push(y.x,y.y,y.z),F.nextPosition.values.push(y.x,y.y,y.z),l.negate(k,k),l.add(M,k,y),U.position.values.push(y.x,y.y,y.z),U.position.values.push(y.x,y.y,y.z),U.position.values.push(b.x,b.y,b.z,b.x,b.y,b.z),U.prevPosition.values.push(y.x,y.y,y.z),U.prevPosition.values.push(y.x,y.y,y.z),U.prevPosition.values.push(y.x,y.y,y.z),U.prevPosition.values.push(y.x,y.y,y.z),U.nextPosition.values.push(b.x,b.y,b.z,b.x,b.y,b.z),U.nextPosition.values.push(o[N*3],o[N*3+1],o[N*3+2]),U.nextPosition.values.push(o[N*3+3],o[N*3+4],o[N*3+5]);let c=nt.fromArray(r,C*2,JP),g=Math.abs(c.y);F.expandAndWidth.values.push(-1,g,1,g),F.expandAndWidth.values.push(-1,-g,1,-g),U.expandAndWidth.values.push(-1,g,1,g),U.expandAndWidth.values.push(-1,-g,1,-g);let O=l.magnitudeSquared(l.subtract(M,T,$N));if(O/=l.magnitudeSquared(l.subtract(b,T,$N)),m(h)){let D=ie.fromArray(h,C*4,jP),w=ie.fromArray(h,N*4,jP),x=L.lerp(D.x,w.x,O),H=L.lerp(D.y,w.y,O),j=L.lerp(D.z,w.z,O),X=L.lerp(D.w,w.w,O);for(E=C*4;E<C*4+2*4;++E)F.color.values.push(h[E]);for(F.color.values.push(x,H,j,X),F.color.values.push(x,H,j,X),U.color.values.push(x,H,j,X),U.color.values.push(x,H,j,X),E=N*4;E<N*4+2*4;++E)U.color.values.push(h[E])}if(m(a)){let D=nt.fromArray(a,C*2,JP),w=nt.fromArray(a,(f+3)*2,yst),x=L.lerp(D.x,w.x,O);for(E=C*2;E<C*2+2*2;++E)F.st.values.push(a[E]);for(F.st.values.push(x,D.y),F.st.values.push(x,w.y),U.st.values.push(x,D.y),U.st.values.push(x,w.y),E=N*2;E<N*2+2*2;++E)U.st.values.push(a[E])}_=F.position.values.length/3-4,B.push(_,_+2,_+1),B.push(_+1,_+2,_+3),_=U.position.values.length/3-4,Q.push(_,_+2,_+1),Q.push(_+1,_+2,_+3)}else{let k,y;for(T.y<0?(k=d.attributes,y=d.indices):(k=A.attributes,y=A.indices),k.position.values.push(T.x,T.y,T.z),k.position.values.push(T.x,T.y,T.z),k.position.values.push(b.x,b.y,b.z),k.position.values.push(b.x,b.y,b.z),E=f*3;E<f*3+4*3;++E)k.prevPosition.values.push(s[E]),k.nextPosition.values.push(o[E]);for(E=f*2;E<f*2+4*2;++E)k.expandAndWidth.values.push(r[E]),m(a)&&k.st.values.push(a[E]);if(m(h))for(E=f*4;E<f*4+4*4;++E)k.color.values.push(h[E]);_=k.position.values.length/3-4,y.push(_,_+2,_+1),y.push(_+1,_+2,_+3)}}R&&(HP(d),HP(A)),tF(t,d,A)}var Qo,MP,pst,jN,Ga,xI,PI,Cst,jr,e_,Hm,vm,gst,QP,Tst,i_,Ba,kP,LP,JI,yP,yl,wl,xl,Pl,KN,Wst,vI,vP,Dst,n_,XN,qN,Ust,Qst,zP,kst,Lst,JP,yst,KP,XP,$N,wst,xst,Pst,jP,Jst,HI,wi,gA=S(()=>{oh();GP();_i();Xe();Ht();Os();ri();oi();Ft();mt();Ot();Tl();zA();yi();ji();dI();Di();nc();Ul();_e();dn();bi();nh();Xi();DP();Qo={};Qo.toWireframe=function(t){if(!m(t))throw new Y("geometry is required.");let e=t.indices;if(m(e)){switch(t.primitiveType){case ne.TRIANGLES:t.indices=_st(e);break;case ne.TRIANGLE_STRIP:t.indices=Rst(e);break;case ne.TRIANGLE_FAN:t.indices=Zst(e);break;default:throw new Y("geometry.primitiveType must be TRIANGLES, TRIANGLE_STRIP, or TRIANGLE_FAN.")}t.primitiveType=ne.LINES}return t};Qo.createLineSegmentsForVectors=function(t,e,i){if(e=Z(e,"normal"),!m(t))throw new Y("geometry is required.");if(!m(t.attributes.position))throw new Y("geometry.attributes.position is required.");if(!m(t.attributes[e]))throw new Y(`geometry.attributes must have an attribute with the same name as the attributeName parameter, ${e}.`);i=Z(i,1e4);let n=t.attributes.position.values,s=t.attributes[e].values,o=n.length,r=new Float64Array(2*o),a=0;for(let d=0;d<o;d+=3)r[a++]=n[d],r[a++]=n[d+1],r[a++]=n[d+2],r[a++]=n[d]+s[d]*i,r[a++]=n[d+1]+s[d+1]*i,r[a++]=n[d+2]+s[d+2]*i;let h,A=t.boundingSphere;return m(A)&&(h=new Nt(A.center,A.radius+i)),new se({attributes:{position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:r})},primitiveType:ne.LINES,boundingSphere:h})};Qo.createAttributeLocations=function(t){if(!m(t))throw new Y("geometry is required.");let e=["position","positionHigh","positionLow","position3DHigh","position3DLow","position2DHigh","position2DLow","pickColor","normal","st","tangent","bitangent","extrudeDirection","compressedAttributes"],i=t.attributes,n={},s=0,o,r=e.length;for(o=0;o<r;++o){let a=e[o];m(i[a])&&(n[a]=s++)}for(let a in i)i.hasOwnProperty(a)&&!m(n[a])&&(n[a]=s++);return n};Qo.reorderForPreVertexCache=function(t){if(!m(t))throw new Y("geometry is required.");let e=se.computeNumberOfVertices(t),i=t.indices;if(m(i)){let n=new Int32Array(e);for(let E=0;E<e;E++)n[E]=-1;let s=i,o=s.length,r=te.createTypedArray(e,o),a=0,h=0,A=0,d;for(;a<o;)d=n[s[a]],d!==-1?r[h]=d:(d=s[a],n[d]=A,r[h]=A,++A),++a,++h;t.indices=r;let f=t.attributes;for(let E in f)if(f.hasOwnProperty(E)&&m(f[E])&&m(f[E].values)){let _=f[E],R=_.values,I=0,C=_.componentsPerAttribute,N=At.createTypedArray(_.componentDatatype,A*C);for(;I<e;){let T=n[I];if(T!==-1)for(let b=0;b<C;b++)N[C*T+b]=R[C*I+b];++I}_.values=N}}return t};Qo.reorderForPostVertexCache=function(t,e){if(!m(t))throw new Y("geometry is required.");let i=t.indices;if(t.primitiveType===ne.TRIANGLES&&m(i)){let n=i.length,s=0;for(let o=0;o<n;o++)i[o]>s&&(s=i[o]);t.indices=WP.tipsify({indices:i,maximumIndex:s,cacheSize:e})}return t};Qo.fitToUnsignedShortIndices=function(t){if(!m(t))throw new Y("geometry is required.");if(m(t.indices)&&t.primitiveType!==ne.TRIANGLES&&t.primitiveType!==ne.LINES&&t.primitiveType!==ne.POINTS)throw new Y("geometry.primitiveType must equal to PrimitiveType.TRIANGLES, PrimitiveType.LINES, or PrimitiveType.POINTS.");let e=[],i=se.computeNumberOfVertices(t);if(m(t.indices)&&i>=L.SIXTY_FOUR_KILOBYTES){let n=[],s=[],o=0,r=UP(t.attributes),a=t.indices,h=a.length,A;t.primitiveType===ne.TRIANGLES?A=3:t.primitiveType===ne.LINES?A=2:t.primitiveType===ne.POINTS&&(A=1);for(let d=0;d<h;d+=A){for(let f=0;f<A;++f){let E=a[d+f],_=n[E];m(_)||(_=o++,n[E]=_,Ist(r,t.attributes,E)),s.push(_)}o+A>=L.SIXTY_FOUR_KILOBYTES&&(e.push(new se({attributes:r,indices:s,primitiveType:t.primitiveType,boundingSphere:t.boundingSphere,boundingSphereCV:t.boundingSphereCV})),n=[],s=[],o=0,r=UP(t.attributes))}s.length!==0&&e.push(new se({attributes:r,indices:s,primitiveType:t.primitiveType,boundingSphere:t.boundingSphere,boundingSphereCV:t.boundingSphereCV}))}else e.push(t);return e};MP=new l,pst=new ut;Qo.projectTo2D=function(t,e,i,n,s){if(!m(t))throw new Y("geometry is required.");if(!m(e))throw new Y("attributeName is required.");if(!m(i))throw new Y("attributeName3D is required.");if(!m(n))throw new Y("attributeName2D is required.");if(!m(t.attributes[e]))throw new Y(`geometry must have attribute matching the attributeName argument: ${e}.`);if(t.attributes[e].componentDatatype!==At.DOUBLE)throw new Y("The attribute componentDatatype must be ComponentDatatype.DOUBLE.");let o=t.attributes[e];s=m(s)?s:new Ss;let r=s.ellipsoid,a=o.values,h=new Float64Array(a.length),A=0;for(let d=0;d<a.length;d+=3){let f=l.fromArray(a,d,MP),E=r.cartesianToCartographic(f,pst);if(!m(E)){if(f.x&&f.y&&f.z)throw new Y(`Could not project point (${f.x}, ${f.y}, ${f.z}) to 2D.`);continue}let _=s.project(E,MP);h[A++]=_.x,h[A++]=_.y,h[A++]=_.z}return t.attributes[i]=o,t.attributes[n]=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:h}),delete t.attributes[e],t};jN={high:0,low:0};Qo.encodeAttribute=function(t,e,i,n){if(!m(t))throw new Y("geometry is required.");if(!m(e))throw new Y("attributeName is required.");if(!m(i))throw new Y("attributeHighName is required.");if(!m(n))throw new Y("attributeLowName is required.");if(!m(t.attributes[e]))throw new Y(`geometry must have attribute matching the attributeName argument: ${e}.`);if(t.attributes[e].componentDatatype!==At.DOUBLE)throw new Y("The attribute componentDatatype must be ComponentDatatype.DOUBLE.");let s=t.attributes[e],o=s.values,r=o.length,a=new Float32Array(r),h=new Float32Array(r);for(let d=0;d<r;++d)Gn.encode(o[d],jN),a[d]=jN.high,h[d]=jN.low;let A=s.componentsPerAttribute;return t.attributes[i]=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:A,values:a}),t.attributes[n]=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:A,values:h}),delete t.attributes[e],t};Ga=new l;xI=new at,PI=new lt;Qo.transformToWorldCoordinates=function(t){if(!m(t))throw new Y("instance is required.");let e=t.modelMatrix;if(at.equals(e,at.IDENTITY))return t;let i=t.geometry.attributes;HN(e,i.position),HN(e,i.prevPosition),HN(e,i.nextPosition),(m(i.normal)||m(i.tangent)||m(i.bitangent))&&(at.inverse(e,xI),at.transpose(xI,xI),at.getMatrix3(xI,PI),vN(PI,i.normal),vN(PI,i.tangent),vN(PI,i.bitangent));let n=t.geometry.boundingSphere;return m(n)&&(t.geometry.boundingSphere=Nt.transform(n,e,n)),t.modelMatrix=at.clone(at.IDENTITY),t};Cst=new l;Qo.combineInstances=function(t){if(!m(t)||t.length<1)throw new Y("instances is required and must have length greater than zero.");let e=[],i=[],n=t.length;for(let o=0;o<n;++o){let r=t[o];m(r.geometry)?e.push(r):m(r.westHemisphereGeometry)&&m(r.eastHemisphereGeometry)&&i.push(r)}let s=[];return e.length>0&&s.push(zN(e,"geometry")),i.length>0&&(s.push(zN(i,"westHemisphereGeometry")),s.push(zN(i,"eastHemisphereGeometry"))),s};jr=new l,e_=new l,Hm=new l,vm=new l;Qo.computeNormal=function(t){if(!m(t))throw new Y("geometry is required.");if(!m(t.attributes.position)||!m(t.attributes.position.values))throw new Y("geometry.attributes.position.values is required.");if(!m(t.indices))throw new Y("geometry.indices is required.");if(t.indices.length<2||t.indices.length%3!==0)throw new Y("geometry.indices length must be greater than 0 and be a multiple of 3.");if(t.primitiveType!==ne.TRIANGLES)throw new Y("geometry.primitiveType must be PrimitiveType.TRIANGLES.");let e=t.indices,i=t.attributes,n=i.position.values,s=i.position.values.length/3,o=e.length,r=new Array(s),a=new Array(o/3),h=new Array(o),A;for(A=0;A<s;A++)r[A]={indexOffset:0,count:0,currentCount:0};let d=0;for(A=0;A<o;A+=3){let R=e[A],I=e[A+1],C=e[A+2],N=R*3,T=I*3,b=C*3;e_.x=n[N],e_.y=n[N+1],e_.z=n[N+2],Hm.x=n[T],Hm.y=n[T+1],Hm.z=n[T+2],vm.x=n[b],vm.y=n[b+1],vm.z=n[b+2],r[R].count++,r[I].count++,r[C].count++,l.subtract(Hm,e_,Hm),l.subtract(vm,e_,vm),a[d]=l.cross(Hm,vm,new l),d++}let f=0;for(A=0;A<s;A++)r[A].indexOffset+=f,f+=r[A].count;d=0;let E;for(A=0;A<o;A+=3){E=r[e[A]];let R=E.indexOffset+E.currentCount;h[R]=d,E.currentCount++,E=r[e[A+1]],R=E.indexOffset+E.currentCount,h[R]=d,E.currentCount++,E=r[e[A+2]],R=E.indexOffset+E.currentCount,h[R]=d,E.currentCount++,d++}let _=new Float32Array(s*3);for(A=0;A<s;A++){let R=A*3;if(E=r[A],l.clone(l.ZERO,jr),E.count>0){for(d=0;d<E.count;d++)l.add(jr,a[h[E.indexOffset+d]],jr);l.equalsEpsilon(l.ZERO,jr,L.EPSILON10)&&l.clone(a[h[E.indexOffset]],jr)}l.equalsEpsilon(l.ZERO,jr,L.EPSILON10)&&(jr.z=1),l.normalize(jr,jr),_[R]=jr.x,_[R+1]=jr.y,_[R+2]=jr.z}return t.attributes.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_}),t};gst=new l,QP=new l,Tst=new l;Qo.computeTangentAndBitangent=function(t){if(!m(t))throw new Y("geometry is required.");let e=t.attributes,i=t.indices;if(!m(e.position)||!m(e.position.values))throw new Y("geometry.attributes.position.values is required.");if(!m(e.normal)||!m(e.normal.values))throw new Y("geometry.attributes.normal.values is required.");if(!m(e.st)||!m(e.st.values))throw new Y("geometry.attributes.st.values is required.");if(!m(i))throw new Y("geometry.indices is required.");if(i.length<2||i.length%3!==0)throw new Y("geometry.indices length must be greater than 0 and be a multiple of 3.");if(t.primitiveType!==ne.TRIANGLES)throw new Y("geometry.primitiveType must be PrimitiveType.TRIANGLES.");let n=t.attributes.position.values,s=t.attributes.normal.values,o=t.attributes.st.values,r=t.attributes.position.values.length/3,a=i.length,h=new Array(r*3),A;for(A=0;A<h.length;A++)h[A]=0;let d,f,E;for(A=0;A<a;A+=3){let I=i[A],C=i[A+1],N=i[A+2];d=I*3,f=C*3,E=N*3;let T=I*2,b=C*2,F=N*2,B=n[d],U=n[d+1],Q=n[d+2],M=o[T],k=o[T+1],y=o[b+1]-k,c=o[F+1]-k,g=1/((o[b]-M)*c-(o[F]-M)*y),O=(c*(n[f]-B)-y*(n[E]-B))*g,D=(c*(n[f+1]-U)-y*(n[E+1]-U))*g,w=(c*(n[f+2]-Q)-y*(n[E+2]-Q))*g;h[d]+=O,h[d+1]+=D,h[d+2]+=w,h[f]+=O,h[f+1]+=D,h[f+2]+=w,h[E]+=O,h[E+1]+=D,h[E+2]+=w}let _=new Float32Array(r*3),R=new Float32Array(r*3);for(A=0;A<r;A++){d=A*3,f=d+1,E=d+2;let I=l.fromArray(s,d,gst),C=l.fromArray(h,d,Tst),N=l.dot(I,C);l.multiplyByScalar(I,N,QP),l.normalize(l.subtract(C,QP,C),C),_[d]=C.x,_[f]=C.y,_[E]=C.z,l.normalize(l.cross(I,C,C),C),R[d]=C.x,R[f]=C.y,R[E]=C.z}return t.attributes.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_}),t.attributes.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:R}),t};i_=new nt,Ba=new l,kP=new l,LP=new l,JI=new nt;Qo.compressVertices=function(t){if(!m(t))throw new Y("geometry is required.");let e=t.attributes.extrudeDirection,i,n;if(m(e)){let U=e.values;n=U.length/3;let Q=new Float32Array(n*2),M=0;for(i=0;i<n;++i){if(l.fromArray(U,i*3,Ba),l.equals(Ba,l.ZERO)){M+=2;continue}JI=Yi.octEncodeInRange(Ba,65535,JI),Q[M++]=JI.x,Q[M++]=JI.y}return t.attributes.compressedAttributes=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:Q}),delete t.attributes.extrudeDirection,t}let s=t.attributes.normal,o=t.attributes.st,r=m(s),a=m(o);if(!r&&!a)return t;let h=t.attributes.tangent,A=t.attributes.bitangent,d=m(h),f=m(A),E,_,R,I;r&&(E=s.values),a&&(_=o.values),d&&(R=h.values),f&&(I=A.values),n=(r?E.length:_.length)/(r?3:2);let T=n,b=a&&r?2:1;b+=d||f?1:0,T*=b;let F=new Float32Array(T),B=0;for(i=0;i<n;++i){a&&(nt.fromArray(_,i*2,i_),F[B++]=Yi.compressTextureCoordinates(i_));let U=i*3;r&&m(R)&&m(I)?(l.fromArray(E,U,Ba),l.fromArray(R,U,kP),l.fromArray(I,U,LP),Yi.octPack(Ba,kP,LP,i_),F[B++]=i_.x,F[B++]=i_.y):(r&&(l.fromArray(E,U,Ba),F[B++]=Yi.octEncodeFloat(Ba)),d&&(l.fromArray(R,U,Ba),F[B++]=Yi.octEncodeFloat(Ba)),f&&(l.fromArray(I,U,Ba),F[B++]=Yi.octEncodeFloat(Ba)))}return t.attributes.compressedAttributes=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:b,values:F}),r&&delete t.attributes.normal,a&&delete t.attributes.st,f&&delete t.attributes.bitangent,d&&delete t.attributes.tangent,t};yP=new l;yl=new l,wl=new l,xl=new l,Pl=new l,KN={positions:new Array(7),indices:new Array(3*3)};Wst=eF(ie,4),vI=eF(l,3),vP=eF(nt,2),Dst=function(t,e,i,n,s,o,r){let a=s[t]*n.x,h=s[e]*n.y,A=s[i]*n.z;o[r]=a+h+A>L.EPSILON6?1:0},n_=new l,XN=new l,qN=new l,Ust=new l;Qst={position:!0,normal:!0,bitangent:!0,tangent:!0,st:!0,extrudeDirection:!0,applyOffset:!0};zP=Ki.fromPointNormal(l.ZERO,l.UNIT_Y),kst=new l,Lst=new l;JP=new nt,yst=new nt,KP=new l,XP=new l,$N=new l,wst=new l,xst=new l,Pst=new l,jP=new ie;Jst=5*L.EPSILON9,HI=L.EPSILON6;Qo.splitLongitude=function(t){if(!m(t))throw new Y("instance is required.");let e=t.geometry,i=e.boundingSphere;if(m(i)&&(i.center.x-i.radius>0||Nt.intersectPlane(i,Ki.ORIGIN_ZX_PLANE)!==Nn.INTERSECTING))return t;if(e.geometryType!==Ah.NONE)switch(e.geometryType){case Ah.POLYLINES:jst(t);break;case Ah.TRIANGLES:xP(t);break;case Ah.LINES:PP(t);break}else Ost(e),e.primitiveType===ne.TRIANGLES?xP(t):e.primitiveType===ne.LINES&&PP(t);return t};wi=Qo});function s_(t,e,i){t=Z(t,0),e=Z(e,0),i=Z(i,0),this.value=new Float32Array([t,e,i])}var qP,$P=S(()=>{ae();oi();Ft();mt();Object.defineProperties(s_.prototype,{componentDatatype:{get:function(){return At.FLOAT}},componentsPerAttribute:{get:function(){return 3}},normalize:{get:function(){return!1}}});s_.fromCartesian3=function(t){return p.defined("offset",t),new s_(t.x,t.y,t.z)};s_.toValue=function(t,e){return p.defined("offset",t),m(e)||(e=new Float32Array([t.x,t.y,t.z])),e[0]=t.x,e[1]=t.y,e[2]=t.z,e};qP=s_});function Hst(t,e,i){let n=!i,s=t.length,o;if(!n&&s>1){let r=t[0].modelMatrix;for(o=1;o<s;++o)if(!at.equals(r,t[o].modelMatrix)){n=!0;break}}if(n)for(o=0;o<s;++o)m(t[o].geometry)&&wi.transformToWorldCoordinates(t[o]);else at.multiplyTransformation(e,t[0].modelMatrix,e)}function iF(t,e){let i=t.attributes,n=i.position,s=n.values.length/n.componentsPerAttribute;i.batchId=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:1,values:new Float32Array(s)});let o=i.batchId.values;for(let r=0;r<s;++r)o[r]=e}function vst(t){let e=t.length;for(let i=0;i<e;++i){let n=t[i];m(n.geometry)?iF(n.geometry,i):m(n.westHemisphereGeometry)&&m(n.eastHemisphereGeometry)&&(iF(n.westHemisphereGeometry,i),iF(n.eastHemisphereGeometry,i))}}function zst(t){let e=t.instances,i=t.projection,n=t.elementIndexUintSupported,s=t.scene3DOnly,o=t.vertexCacheOptimize,r=t.compressVertices,a=t.modelMatrix,h,A,d,f=e.length;for(h=0;h<f;++h)if(m(e[h].geometry)){d=e[h].geometry.primitiveType;break}for(h=1;h<f;++h)if(m(e[h].geometry)&&e[h].geometry.primitiveType!==d)throw new Y("All instance geometries must have the same primitiveType.");if(Hst(e,a,s),!s)for(h=0;h<f;++h)m(e[h].geometry)&&wi.splitLongitude(e[h]);if(vst(e),o)for(h=0;h<f;++h){let _=e[h];m(_.geometry)?(wi.reorderForPostVertexCache(_.geometry),wi.reorderForPreVertexCache(_.geometry)):m(_.westHemisphereGeometry)&&m(_.eastHemisphereGeometry)&&(wi.reorderForPostVertexCache(_.westHemisphereGeometry),wi.reorderForPreVertexCache(_.westHemisphereGeometry),wi.reorderForPostVertexCache(_.eastHemisphereGeometry),wi.reorderForPreVertexCache(_.eastHemisphereGeometry))}let E=wi.combineInstances(e);for(f=E.length,h=0;h<f;++h){A=E[h];let _=A.attributes;if(s)for(let R in _)_.hasOwnProperty(R)&&_[R].componentDatatype===At.DOUBLE&&wi.encodeAttribute(A,R,`${R}3DHigh`,`${R}3DLow`);else for(let R in _)if(_.hasOwnProperty(R)&&_[R].componentDatatype===At.DOUBLE){let I=`${R}3D`,C=`${R}2D`;wi.projectTo2D(A,R,I,C,i),m(A.boundingSphere)&&R==="position"&&(A.boundingSphereCV=Nt.fromVertices(A.attributes.position2D.values)),wi.encodeAttribute(A,I,`${I}High`,`${I}Low`),wi.encodeAttribute(A,C,`${C}High`,`${C}Low`)}r&&wi.compressVertices(A)}if(!n){let _=[];for(f=E.length,h=0;h<f;++h)A=E[h],_=_.concat(wi.fitToUnsignedShortIndices(A));E=_}return E}function nF(t,e,i,n){let s,o,r,a=n.length-1;if(a>=0){let A=n[a];s=A.offset+A.count,r=A.index,o=i[r].indices.length}else s=0,r=0,o=i[r].indices.length;let h=t.length;for(let A=0;A<h;++A){let f=t[A][e];if(!m(f))continue;let E=f.indices.length;s+E>o&&(s=0,o=i[++r].indices.length),n.push({index:r,offset:s,count:E}),s+=E}}function Kst(t,e){let i=[];return nF(t,"geometry",e,i),nF(t,"westHemisphereGeometry",e,i),nF(t,"eastHemisphereGeometry",e,i),i}function Xst(t,e){let i=t.attributes;for(let n in i)if(i.hasOwnProperty(n)){let s=i[n];m(s)&&m(s.values)&&e.push(s.values.buffer)}m(t.indices)&&e.push(t.indices.buffer)}function qst(t,e){let i=t.length;for(let n=0;n<i;++n)Xst(t[n],e)}function $st(t){let e=1,i=t.length;for(let n=0;n<i;n++){let s=t[n];if(++e,!m(s))continue;let o=s.attributes;e+=7+2*Nt.packedLength+(m(s.indices)?s.indices.length:0);for(let r in o)if(o.hasOwnProperty(r)&&m(o[r])){let a=o[r];e+=5+a.values.length}}return e}function tot(t,e){let i=t.length,n=new Float64Array(1+i*19),s=0;n[s++]=i;for(let o=0;o<i;o++){let r=t[o];if(at.pack(r.modelMatrix,n,s),s+=at.packedLength,m(r.attributes)&&m(r.attributes.offset)){let a=r.attributes.offset.value;n[s]=a[0],n[s+1]=a[1],n[s+2]=a[2]}s+=3}return e.push(n.buffer),n}function eot(t){let e=t,i=new Array(e[0]),n=0,s=1;for(;s<e.length;){let o=at.unpack(e,s),r;s+=at.packedLength,m(e[s])&&(r={offset:new qP(e[s],e[s+1],e[s+2])}),s+=3,i[n++]={modelMatrix:o,attributes:r}}return i}function tJ(t){let e=t.length,i=1+(Nt.packedLength+1)*e,n=new Float32Array(i),s=0;n[s++]=e;for(let o=0;o<e;++o){let r=t[o];m(r)?(n[s++]=1,Nt.pack(t[o],n,s)):n[s++]=0,s+=Nt.packedLength}return n}function eJ(t){let e=new Array(t[0]),i=0,n=1;for(;n<t.length;)t[n++]===1&&(e[i]=Nt.unpack(t,n)),++i,n+=Nt.packedLength;return e}var Zh,TA,KI=S(()=>{_i();oi();Ft();mt();Ot();Oe();zA();yi();ji();En();gA();Di();bi();$P();Ml();Zh={};Zh.combineGeometry=function(t){let e,i,n=t.instances,s=n.length,o,r,a=!1;s>0&&(e=zst(t),e.length>0&&(i=wi.createAttributeLocations(e[0]),t.createPickOffsets&&(o=Kst(n,e))),m(n[0].attributes)&&m(n[0].attributes.offset)&&(r=new Array(s),a=!0));let h=new Array(s),A=new Array(s);for(let d=0;d<s;++d){let f=n[d],E=f.geometry;m(E)&&(h[d]=E.boundingSphere,A[d]=E.boundingSphereCV,a&&(r[d]=f.geometry.offsetAttribute));let _=f.eastHemisphereGeometry,R=f.westHemisphereGeometry;m(_)&&m(R)&&(m(_.boundingSphere)&&m(R.boundingSphere)&&(h[d]=Nt.union(_.boundingSphere,R.boundingSphere)),m(_.boundingSphereCV)&&m(R.boundingSphereCV)&&(A[d]=Nt.union(_.boundingSphereCV,R.boundingSphereCV)))}return{geometries:e,modelMatrix:t.modelMatrix,attributeLocations:i,pickOffsets:o,offsetInstanceExtend:r,boundingSpheres:h,boundingSpheresCV:A}};Zh.packCreateGeometryResults=function(t,e){let i=new Float64Array($st(t)),n=[],s={},o=t.length,r=0;i[r++]=o;for(let a=0;a<o;a++){let h=t[a],A=m(h);if(i[r++]=A?1:0,!A)continue;i[r++]=h.primitiveType,i[r++]=h.geometryType,i[r++]=Z(h.offsetAttribute,-1);let d=m(h.boundingSphere)?1:0;i[r++]=d,d&&Nt.pack(h.boundingSphere,i,r),r+=Nt.packedLength;let f=m(h.boundingSphereCV)?1:0;i[r++]=f,f&&Nt.pack(h.boundingSphereCV,i,r),r+=Nt.packedLength;let E=h.attributes,_=[];for(let I in E)E.hasOwnProperty(I)&&m(E[I])&&(_.push(I),m(s[I])||(s[I]=n.length,n.push(I)));i[r++]=_.length;for(let I=0;I<_.length;I++){let C=_[I],N=E[C];i[r++]=s[C],i[r++]=N.componentDatatype,i[r++]=N.componentsPerAttribute,i[r++]=N.normalize?1:0,i[r++]=N.values.length,i.set(N.values,r),r+=N.values.length}let R=m(h.indices)?h.indices.length:0;i[r++]=R,R>0&&(i.set(h.indices,r),r+=R)}return e.push(i.buffer),{stringTable:n,packedData:i}};Zh.unpackCreateGeometryResults=function(t){let e=t.stringTable,i=t.packedData,n,s=new Array(i[0]),o=0,r=1;for(;r<i.length;){if(!(i[r++]===1)){s[o++]=void 0;continue}let h=i[r++],A=i[r++],d=i[r++];d===-1&&(d=void 0);let f,E;i[r++]===1&&(f=Nt.unpack(i,r)),r+=Nt.packedLength,i[r++]===1&&(E=Nt.unpack(i,r)),r+=Nt.packedLength;let I,C,N,T=new we,b=i[r++];for(n=0;n<b;n++){let B=e[i[r++]],U=i[r++];N=i[r++];let Q=i[r++]!==0;I=i[r++],C=At.createTypedArray(U,I);for(let M=0;M<I;M++)C[M]=i[r++];T[B]=new Tt({componentDatatype:U,componentsPerAttribute:N,normalize:Q,values:C})}let F;if(I=i[r++],I>0){let B=C.length/N;for(F=te.createTypedArray(B,I),n=0;n<I;n++)F[n]=i[r++]}s[o++]=new se({primitiveType:h,geometryType:A,boundingSphere:f,boundingSphereCV:E,indices:F,attributes:T,offsetAttribute:d})}return s};Zh.packCombineGeometryParameters=function(t,e){let i=t.createGeometryResults,n=i.length;for(let s=0;s<n;s++)e.push(i[s].packedData.buffer);return{createGeometryResults:t.createGeometryResults,packedInstances:tot(t.instances,e),ellipsoid:t.ellipsoid,isGeographic:t.projection instanceof Ss,elementIndexUintSupported:t.elementIndexUintSupported,scene3DOnly:t.scene3DOnly,vertexCacheOptimize:t.vertexCacheOptimize,compressVertices:t.compressVertices,modelMatrix:t.modelMatrix,createPickOffsets:t.createPickOffsets}};Zh.unpackCombineGeometryParameters=function(t){let e=eot(t.packedInstances),i=t.createGeometryResults,n=i.length,s=0;for(let a=0;a<n;a++){let h=Zh.unpackCreateGeometryResults(i[a]),A=h.length;for(let d=0;d<A;d++){let f=h[d],E=e[s];E.geometry=f,++s}}let o=ot.clone(t.ellipsoid),r=t.isGeographic?new Ss(o):new ks(o);return{instances:e,ellipsoid:o,projection:r,elementIndexUintSupported:t.elementIndexUintSupported,scene3DOnly:t.scene3DOnly,vertexCacheOptimize:t.vertexCacheOptimize,compressVertices:t.compressVertices,modelMatrix:at.clone(t.modelMatrix),createPickOffsets:t.createPickOffsets}};Zh.packCombineGeometryResults=function(t,e){m(t.geometries)&&qst(t.geometries,e);let i=tJ(t.boundingSpheres),n=tJ(t.boundingSpheresCV);return e.push(i.buffer,n.buffer),{geometries:t.geometries,attributeLocations:t.attributeLocations,modelMatrix:t.modelMatrix,pickOffsets:t.pickOffsets,offsetInstanceExtend:t.offsetInstanceExtend,boundingSpheres:i,boundingSpheresCV:n}};Zh.unpackCombineGeometryResults=function(t){return{geometries:t.geometries,attributeLocations:t.attributeLocations,modelMatrix:t.modelMatrix,pickOffsets:t.pickOffsets,offsetInstanceExtend:t.offsetInstanceExtend,boundingSpheres:eJ(t.boundingSpheres),boundingSpheresCV:eJ(t.boundingSpheresCV)}};TA=Zh});var iot,Is,iJ=S(()=>{iot={READY:0,CREATING:1,CREATED:2,COMBINING:3,COMBINED:4,COMPLETE:5,FAILED:6},Is=Object.freeze(iot)});var Ir,XI,nJ=S(()=>{Ir={DISABLED:0,ENABLED:1,CAST_ONLY:2,RECEIVE_ONLY:3};Ir.NUMBER_OF_SHADOW_MODES=4;Ir.castShadows=function(t){return t===Ir.ENABLED||t===Ir.CAST_ONLY};Ir.receiveShadows=function(t){return t===Ir.ENABLED||t===Ir.RECEIVE_ONLY};Ir.fromCastReceive=function(t,e){return t&&e?Ir.ENABLED:t?Ir.CAST_ONLY:e?Ir.RECEIVE_ONLY:Ir.DISABLED};XI=Object.freeze(Ir)});function qn(t){if(t=Z(t,Z.EMPTY_OBJECT),this.geometryInstances=t.geometryInstances,this.appearance=t.appearance,this._appearance=void 0,this._material=void 0,this.depthFailAppearance=t.depthFailAppearance,this._depthFailAppearance=void 0,this._depthFailMaterial=void 0,this.modelMatrix=at.clone(Z(t.modelMatrix,at.IDENTITY)),this._modelMatrix=new at,this.show=Z(t.show,!0),this._vertexCacheOptimize=Z(t.vertexCacheOptimize,!1),this._interleave=Z(t.interleave,!1),this._releaseGeometryInstances=Z(t.releaseGeometryInstances,!0),this._allowPicking=Z(t.allowPicking,!0),this._asynchronous=Z(t.asynchronous,!0),this._compressVertices=Z(t.compressVertices,!0),this.cull=Z(t.cull,!0),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.rtcCenter=t.rtcCenter,m(this.rtcCenter)&&(!m(this.geometryInstances)||Array.isArray(this.geometryInstances)&&this.geometryInstances.length!==1))throw new Y("Relative-to-center rendering only supports one geometry instance.");this.shadows=Z(t.shadows,XI.DISABLED),this._translucent=void 0,this._state=Is.READY,this._geometries=[],this._error=void 0,this._numberOfInstances=0,this._boundingSpheres=[],this._boundingSphereWC=[],this._boundingSphereCV=[],this._boundingSphere2D=[],this._boundingSphereMorph=[],this._perInstanceAttributeCache=new Map,this._instanceIds=[],this._lastPerInstanceAttributeIndex=0,this._va=[],this._attributeLocations=void 0,this._primitiveType=void 0,this._frontFaceRS=void 0,this._backFaceRS=void 0,this._sp=void 0,this._depthFailAppearance=void 0,this._spDepthFail=void 0,this._frontFaceDepthFailRS=void 0,this._backFaceDepthFailRS=void 0,this._pickIds=[],this._colorCommands=[],this._pickCommands=[],this._createBoundingVolumeFunction=t._createBoundingVolumeFunction,this._createRenderStatesFunction=t._createRenderStatesFunction,this._createShaderProgramFunction=t._createShaderProgramFunction,this._createCommandsFunction=t._createCommandsFunction,this._updateAndQueueCommandsFunction=t._updateAndQueueCommandsFunction,this._createPickOffsets=t._createPickOffsets,this._pickOffsets=void 0,this._createGeometryResults=void 0,this._ready=!1,this._batchTable=void 0,this._batchTableAttributeIndices=void 0,this._offsetInstanceExtend=void 0,this._batchTableOffsetAttribute2DIndex=void 0,this._batchTableOffsetsUpdated=!1,this._instanceBoundingSpheres=void 0,this._instanceBoundingSpheresCV=void 0,this._tempBoundingSpheres=void 0,this._recomputeBoundingSpheres=!1,this._batchTableBoundingSpheresUpdated=!1,this._batchTableBoundingSphereAttributeIndices=void 0}function not(t){let e=t.length,i=[],n=t[0].attributes,s;for(s in n)if(n.hasOwnProperty(s)&&m(n[s])){let o=n[s],r=!0;for(let a=1;a<e;++a){let h=t[a].attributes[s];if(!m(h)||o.componentDatatype!==h.componentDatatype||o.componentsPerAttribute!==h.componentsPerAttribute||o.normalize!==h.normalize){r=!1;break}}r&&i.push(s)}return i}function mJ(t){let e=t.length;if(e===1)return t[0];if(e===2)return nt.unpack(t,0,sot);if(e===3)return l.unpack(t,0,oot);if(e===4)return ie.unpack(t,0,dJ)}function rot(t,e){let i=t.geometryInstances,n=Array.isArray(i)?i:[i],s=n.length;if(s===0)return;let o=not(n),r=o.length,a=[],h={},A={},d,E=n[0].attributes,_,R,I;for(_=0;_<r;++_)R=o[_],I=E[R],h[R]=_,a.push({functionName:`czm_batchTable_${R}`,componentDatatype:I.componentDatatype,componentsPerAttribute:I.componentsPerAttribute,normalize:I.normalize});o.indexOf("distanceDisplayCondition")!==-1&&(a.push({functionName:"czm_batchTable_boundingSphereCenter3DHigh",componentDatatype:At.FLOAT,componentsPerAttribute:3},{functionName:"czm_batchTable_boundingSphereCenter3DLow",componentDatatype:At.FLOAT,componentsPerAttribute:3},{functionName:"czm_batchTable_boundingSphereCenter2DHigh",componentDatatype:At.FLOAT,componentsPerAttribute:3},{functionName:"czm_batchTable_boundingSphereCenter2DLow",componentDatatype:At.FLOAT,componentsPerAttribute:3},{functionName:"czm_batchTable_boundingSphereRadius",componentDatatype:At.FLOAT,componentsPerAttribute:1}),A.center3DHigh=a.length-5,A.center3DLow=a.length-4,A.center2DHigh=a.length-3,A.center2DLow=a.length-2,A.radius=a.length-1),o.indexOf("offset")!==-1&&(a.push({functionName:"czm_batchTable_offset2D",componentDatatype:At.FLOAT,componentsPerAttribute:3}),d=a.length-1),a.push({functionName:"czm_batchTable_pickColor",componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:4,normalize:!0});let C=a.length,N=new bP(e,a,s);for(_=0;_<s;++_){let T=n[_];E=T.attributes;for(let Q=0;Q<r;++Q){R=o[Q],I=E[R];let M=mJ(I.value),k=h[R];N.setBatchedAttribute(_,k,M)}let b={primitive:Z(T.pickPrimitive,t)};m(T.id)&&(b.id=T.id);let F=e.createPickId(b);t._pickIds.push(F);let B=F.color,U=dJ;U.x=Zt.floatToByte(B.red),U.y=Zt.floatToByte(B.green),U.z=Zt.floatToByte(B.blue),U.w=Zt.floatToByte(B.alpha),N.setBatchedAttribute(_,C-1,U)}t._batchTable=N,t._batchTableAttributeIndices=h,t._batchTableBoundingSphereAttributeIndices=A,t._batchTableOffsetAttribute2DIndex=d}function aot(t){let e;return Array.isArray(t.values)?e=t.values.slice(0):e=new t.values.constructor(t.values),new Tt({componentDatatype:t.componentDatatype,componentsPerAttribute:t.componentsPerAttribute,normalize:t.normalize,values:e})}function Aot(t){let e=t.attributes,i=new we;for(let s in e)e.hasOwnProperty(s)&&m(e[s])&&(i[s]=aot(e[s]));let n;if(m(t.indices)){let s=t.indices;Array.isArray(s)?n=s.slice(0):n=new s.constructor(s)}return new se({attributes:i,indices:n,primitiveType:t.primitiveType,boundingSphere:Nt.clone(t.boundingSphere)})}function hot(t,e){return{geometry:e,attributes:t.attributes,modelMatrix:at.clone(t.modelMatrix),pickPrimitive:t.pickPrimitive,id:t.id}}function sJ(t){return`${Ui.replaceMain(t,"czm_non_pick_main")}
out vec4 v_pickColor; 
void main() 
{ 
    czm_non_pick_main(); 
    v_pickColor = czm_batchTable_pickColor(batchId); 
}`}function oJ(t){return`in vec4 v_pickColor;
${t}`}function rJ(t,e){if(!t.compressVertices)return e;let i=e.search(/in\s+vec3\s+normal;/g)!==-1,n=e.search(/in\s+vec2\s+st;/g)!==-1;if(!i&&!n)return e;let s=e.search(/in\s+vec3\s+tangent;/g)!==-1,o=e.search(/in\s+vec3\s+bitangent;/g)!==-1,r=n&&i?2:1;r+=s||o?1:0;let a=r>1?`vec${r}`:"float",h="compressedAttributes",A=`in ${a} ${h};`,d="",f="";if(n){d+=`vec2 st;
`;let R=r>1?`${h}.x`:h;f+=`    st = czm_decompressTextureCoordinates(${R});
`}i&&s&&o?(d+=`vec3 normal;
vec3 tangent;
vec3 bitangent;
`,f+=`    czm_octDecode(${h}.${n?"yz":"xy"}, normal, tangent, bitangent);
`):(i&&(d+=`vec3 normal;
`,f+=`    normal = czm_octDecode(${h}${r>1?`.${n?"y":"x"}`:""});
`),s&&(d+=`vec3 tangent;
`,f+=`    tangent = czm_octDecode(${h}.${n&&i?"z":"y"});
`),o&&(d+=`vec3 bitangent;
`,f+=`    bitangent = czm_octDecode(${h}.${n&&i?"z":"y"});
`));let E=e;E=E.replace(/in\s+vec3\s+normal;/g,""),E=E.replace(/in\s+vec2\s+st;/g,""),E=E.replace(/in\s+vec3\s+tangent;/g,""),E=E.replace(/in\s+vec3\s+bitangent;/g,""),E=Ui.replaceMain(E,"czm_non_compressed_main");let _=`void main() 
{ 
${f}    czm_non_compressed_main(); 
}`;return[A,d,E,_].join(`
`)}function lot(t){let e=Ui.replaceMain(t,"czm_non_depth_clamp_main");return e+=`void main() {
    czm_non_depth_clamp_main();
    gl_Position = czm_depthClamp(gl_Position);}
`,e}function dot(t){let e=Ui.replaceMain(t,"czm_non_depth_clamp_main");return e+=`void main() {
    czm_non_depth_clamp_main();
    #if defined(LOG_DEPTH)
        czm_writeLogDepth();
    #else
        czm_writeDepthClamp();
    #endif
}
`,e}function aJ(t,e){let i=t.vertexAttributes;for(let n in i)if(i.hasOwnProperty(n)&&!m(e[n]))throw new Y(`Appearance/Geometry mismatch.  The appearance requires vertex shader attribute input '${n}', which was not computed as part of the Geometry.  Use the appearance's vertexFormat property when constructing the geometry.`)}function mot(t,e){return function(){return t[e]}}function Eot(t,e){let i,n,s,o,r=t._instanceIds;if(t._state===Is.READY){i=Array.isArray(t.geometryInstances)?t.geometryInstances:[t.geometryInstances];let a=t._numberOfInstances=i.length,h=[],A=[];for(s=0;s<a;++s){if(n=i[s].geometry,r.push(i[s].id),m(n._workerName)&&m(n._workerPath)||!m(n._workerName)&&!m(n._workerPath))throw new Y("Must define either _workerName or _workerPath for asynchronous geometry.");A.push({moduleName:n._workerName,modulePath:n._workerPath,geometry:n})}if(!m(qI))for(qI=new Array(sF),s=0;s<sF;s++)qI[s]=new XE("createGeometry");let d;for(A=gP(A,sF),s=0;s<A.length;s++){let f=0,E=A[s],_=E.length;for(o=0;o<_;++o)d=E[o],n=d.geometry,m(n.constructor.pack)&&(d.offset=f,f+=Z(n.constructor.packedLength,n.packedLength));let R;if(f>0){let I=new Float64Array(f);for(R=[I.buffer],o=0;o<_;++o)d=E[o],n=d.geometry,m(n.constructor.pack)&&(n.constructor.pack(n,I,d.offset),d.geometry=I)}h.push(qI[s].scheduleTask({subTasks:A[s]},R))}t._state=Is.CREATING,Promise.all(h).then(function(f){t._createGeometryResults=f,t._state=Is.CREATED}).catch(function(f){r_(t,e,Is.FAILED,f)})}else if(t._state===Is.CREATED){let a=[];i=Array.isArray(t.geometryInstances)?t.geometryInstances:[t.geometryInstances];let h=e.scene3DOnly,A=e.mapProjection,d=fot.scheduleTask(TA.packCombineGeometryParameters({createGeometryResults:t._createGeometryResults,instances:i,ellipsoid:A.ellipsoid,projection:A,elementIndexUintSupported:e.context.elementIndexUint,scene3DOnly:h,vertexCacheOptimize:t.vertexCacheOptimize,compressVertices:t.compressVertices,modelMatrix:t.modelMatrix,createPickOffsets:t._createPickOffsets},a),a);t._createGeometryResults=void 0,t._state=Is.COMBINING,Promise.resolve(d).then(function(f){let E=TA.unpackCombineGeometryResults(f);t._geometries=E.geometries,t._attributeLocations=E.attributeLocations,t.modelMatrix=at.clone(E.modelMatrix,t.modelMatrix),t._pickOffsets=E.pickOffsets,t._offsetInstanceExtend=E.offsetInstanceExtend,t._instanceBoundingSpheres=E.boundingSpheres,t._instanceBoundingSpheresCV=E.boundingSpheresCV,m(t._geometries)&&t._geometries.length>0?(t._recomputeBoundingSpheres=!0,t._state=Is.COMBINED):r_(t,e,Is.FAILED,void 0)}).catch(function(f){r_(t,e,Is.FAILED,f)})}}function _ot(t,e){let i=Array.isArray(t.geometryInstances)?t.geometryInstances:[t.geometryInstances],n=t._numberOfInstances=i.length,s=new Array(n),o=t._instanceIds,r,a,h=0;for(a=0;a<n;a++){r=i[a];let E=r.geometry,_;m(E.attributes)&&m(E.primitiveType)?_=Aot(E):_=E.constructor.createGeometry(E),s[h++]=hot(r,_),o.push(r.id)}s.length=h;let A=e.scene3DOnly,d=e.mapProjection,f=TA.combineGeometry({instances:s,ellipsoid:d.ellipsoid,projection:d,elementIndexUintSupported:e.context.elementIndexUint,scene3DOnly:A,vertexCacheOptimize:t.vertexCacheOptimize,compressVertices:t.compressVertices,modelMatrix:t.modelMatrix,createPickOffsets:t._createPickOffsets});t._geometries=f.geometries,t._attributeLocations=f.attributeLocations,t.modelMatrix=at.clone(f.modelMatrix,t.modelMatrix),t._pickOffsets=f.pickOffsets,t._offsetInstanceExtend=f.offsetInstanceExtend,t._instanceBoundingSpheres=f.boundingSpheres,t._instanceBoundingSpheresCV=f.boundingSpheresCV,m(t._geometries)&&t._geometries.length>0?(t._recomputeBoundingSpheres=!0,t._state=Is.COMBINED):r_(t,e,Is.FAILED,void 0)}function Rot(t,e){let i=t._batchTableAttributeIndices.offset;if(!t._recomputeBoundingSpheres||!m(i)){t._recomputeBoundingSpheres=!1;return}let n,s=t._offsetInstanceExtend,o=t._instanceBoundingSpheres,r=o.length,a=t._tempBoundingSpheres;if(!m(a)){for(a=new Array(r),n=0;n<r;n++)a[n]=new Nt;t._tempBoundingSpheres=a}for(n=0;n<r;++n){let I=a[n],C=t._batchTable.getBatchedAttribute(n,i,new l);I=o[n].clone(I),RJ(I,C,s[n])}let h=[],A=[],d=[];for(n=0;n<r;++n){let I=a[n];I.center.x-I.radius>0||Nt.intersectPlane(I,Ki.ORIGIN_ZX_PLANE)!==Nn.INTERSECTING?h.push(I):(A.push(I),d.push(I))}let f=h[0],E=d[0],_=A[0];for(n=1;n<h.length;n++)f=Nt.union(f,h[n]);for(n=1;n<d.length;n++)E=Nt.union(E,d[n]);for(n=1;n<A.length;n++)_=Nt.union(_,A[n]);let R=[];for(m(f)&&R.push(f),m(E)&&R.push(E),m(_)&&R.push(_),n=0;n<R.length;n++){let I=R[n].clone(t._boundingSpheres[n]);t._boundingSpheres[n]=I,t._boundingSphereCV[n]=Nt.projectTo2D(I,e.mapProjection,t._boundingSphereCV[n])}qn._updateBoundingVolumes(t,e,t.modelMatrix,!0),t._recomputeBoundingSpheres=!1}function Zot(t,e){if(!m(t._batchTableAttributeIndices.distanceDisplayCondition)||t._batchTableBoundingSpheresUpdated)return;let n=t._batchTableBoundingSphereAttributeIndices,s=n.center3DHigh,o=n.center3DLow,r=n.center2DHigh,a=n.center2DLow,h=n.radius,A=e.mapProjection,d=A.ellipsoid,f=t._batchTable,E=t._instanceBoundingSpheres,_=E.length;for(let R=0;R<_;++R){let I=E[R];if(!m(I))continue;let C=t.modelMatrix;m(C)&&(I=Nt.transform(I,C,_J));let N=I.center,T=I.radius,b=Gn.fromCartesian(N,AJ);if(f.setBatchedAttribute(R,s,b.high),f.setBatchedAttribute(R,o,b.low),!e.scene3DOnly){let F=d.cartesianToCartographic(N,fJ),B=A.project(F,EJ);b=Gn.fromCartesian(B,AJ),f.setBatchedAttribute(R,r,b.high),f.setBatchedAttribute(R,a,b.low)}f.setBatchedAttribute(R,h,T)}t._batchTableBoundingSpheresUpdated=!0}function hJ(t,e){if(!m(t._batchTableAttributeIndices.offset)||t._batchTableOffsetsUpdated||e.scene3DOnly)return;let n=t._batchTableOffsetAttribute2DIndex,s=e.mapProjection,o=s.ellipsoid,r=t._batchTable,a=t._instanceBoundingSpheres,h=a.length;for(let A=0;A<h;++A){let d=a[A];if(!m(d))continue;let f=r.getBatchedAttribute(A,t._batchTableAttributeIndices.offset);if(l.equals(f,l.ZERO)){r.setBatchedAttribute(A,n,l.ZERO);continue}let E=t.modelMatrix;m(E)&&(d=Nt.transform(d,E,_J));let _=d.center;_=o.scaleToGeodeticSurface(_,Iot);let R=o.cartesianToCartographic(_,fJ),I=s.project(R,EJ),C=l.add(f,_,oF);R=o.cartesianToCartographic(C,R);let N=s.project(R,oF),T=l.subtract(N,I,oF),b=T.x;T.x=T.z,T.z=T.y,T.y=b,r.setBatchedAttribute(A,n,T)}t._batchTableOffsetsUpdated=!0}function pot(t,e){let i=t._attributeLocations,n=t._geometries,s=e.scene3DOnly,o=e.context,r=[],a=n.length;for(let h=0;h<a;++h){let A=n[h];if(r.push(mI.fromGeometry({context:o,geometry:A,attributeLocations:i,bufferUsage:ai.STATIC_DRAW,interleave:t._interleave})),m(t._createBoundingVolumeFunction))t._createBoundingVolumeFunction(e,A);else if(t._boundingSpheres.push(Nt.clone(A.boundingSphere)),t._boundingSphereWC.push(new Nt),!s){let d=A.boundingSphereCV.center,f=d.x,E=d.y,_=d.z;d.x=_,d.y=f,d.z=E,t._boundingSphereCV.push(Nt.clone(A.boundingSphereCV)),t._boundingSphere2D.push(new Nt),t._boundingSphereMorph.push(new Nt)}}t._va=r,t._primitiveType=n[0].primitiveType,t.releaseGeometryInstances&&(t.geometryInstances=void 0),t._geometries=void 0,r_(t,e,Is.COMPLETE,void 0)}function uot(t,e,i,n){let s=i.getRenderState(),o;n?(o=qs(s,!1),o.cull={enabled:!0,face:Eh.BACK},t._frontFaceRS=Yn.fromCache(o),o.cull.face=Eh.FRONT,t._backFaceRS=Yn.fromCache(o)):(t._frontFaceRS=Yn.fromCache(s),t._backFaceRS=t._frontFaceRS),o=qs(s,!1),m(t._depthFailAppearance)&&(o.depthTest.enabled=!1),m(t._depthFailAppearance)&&(s=t._depthFailAppearance.getRenderState(),o=qs(s,!1),o.depthTest.func=wI.GREATER,n?(o.cull={enabled:!0,face:Eh.BACK},t._frontFaceDepthFailRS=Yn.fromCache(o),o.cull.face=Eh.FRONT,t._backFaceDepthFailRS=Yn.fromCache(o)):(t._frontFaceDepthFailRS=Yn.fromCache(o),t._backFaceDepthFailRS=t._frontFaceRS))}function Cot(t,e,i){let n=e.context,s=t._attributeLocations,o=t._batchTable.getVertexShaderCallback()(i.vertexShaderSource);o=qn._appendOffsetToShader(t,o),o=qn._appendShowToShader(t,o),o=qn._appendDistanceDisplayConditionToShader(t,o,e.scene3DOnly),o=sJ(o),o=qn._updateColorAttribute(t,o,!1),o=rJ(t,o),o=qn._modifyShaderPosition(t,o,e.scene3DOnly);let r=i.getFragmentShaderSource();r=oJ(r),t._sp=Es.replaceCache({context:n,shaderProgram:t._sp,vertexShaderSource:o,fragmentShaderSource:r,attributeLocations:s}),aJ(t._sp,s),m(t._depthFailAppearance)&&(o=t._batchTable.getVertexShaderCallback()(t._depthFailAppearance.vertexShaderSource),o=qn._appendShowToShader(t,o),o=qn._appendDistanceDisplayConditionToShader(t,o,e.scene3DOnly),o=sJ(o),o=qn._updateColorAttribute(t,o,!0),o=rJ(t,o),o=qn._modifyShaderPosition(t,o,e.scene3DOnly),o=lot(o),r=t._depthFailAppearance.getFragmentShaderSource(),r=oJ(r),r=dot(r),t._spDepthFail=Es.replaceCache({context:n,shaderProgram:t._spDepthFail,vertexShaderSource:o,fragmentShaderSource:r,attributeLocations:s}),aJ(t._spDepthFail,s))}function lJ(t,e,i,n){let s=m(i)?i._uniforms:void 0,o={},r=e.uniforms;if(m(r)){for(let h in r)if(r.hasOwnProperty(h)){if(m(s)&&m(s[h]))throw new Y(`Appearance and material have a uniform with the same name: ${h}`);o[h]=mot(r,h)}}let a=es(o,s);return a=t._batchTable.getUniformMapCallback()(a),m(t.rtcCenter)&&(a.u_modifiedModelView=function(){let h=n.context.uniformState.view;return at.multiply(h,t._modelMatrix,o_),at.multiplyByPoint(o_,t.rtcCenter,cJ),at.setTranslation(o_,cJ,o_),o_}),a}function got(t,e,i,n,s,o,r,a){let h=lJ(t,e,i,a),A;m(t._depthFailAppearance)&&(A=lJ(t,t._depthFailAppearance,t._depthFailAppearance.material,a));let d=n?os.TRANSLUCENT:os.OPAQUE,f=s?2:1;f*=m(t._depthFailAppearance)?2:1,o.length=t._va.length*f;let E=o.length,_=0;for(let R=0;R<E;++R){let I;s&&(I=o[R],m(I)||(I=o[R]=new fn({owner:t,primitiveType:t._primitiveType})),I.vertexArray=t._va[_],I.renderState=t._backFaceRS,I.shaderProgram=t._sp,I.uniformMap=h,I.pass=d,++R),I=o[R],m(I)||(I=o[R]=new fn({owner:t,primitiveType:t._primitiveType})),I.vertexArray=t._va[_],I.renderState=t._frontFaceRS,I.shaderProgram=t._sp,I.uniformMap=h,I.pass=d,m(t._depthFailAppearance)&&(s&&(++R,I=o[R],m(I)||(I=o[R]=new fn({owner:t,primitiveType:t._primitiveType})),I.vertexArray=t._va[_],I.renderState=t._backFaceDepthFailRS,I.shaderProgram=t._spDepthFail,I.uniformMap=A,I.pass=d),++R,I=o[R],m(I)||(I=o[R]=new fn({owner:t,primitiveType:t._primitiveType})),I.vertexArray=t._va[_],I.renderState=t._frontFaceDepthFailRS,I.shaderProgram=t._spDepthFail,I.uniformMap=A,I.pass=d),++_}}function Tot(t,e,i,n,s,o,r,a){if(e.mode!==ye.SCENE3D&&!at.equals(s,at.IDENTITY))throw new Y("Primitive.modelMatrix is only supported in 3D mode.");qn._updateBoundingVolumes(t,e,s);let h;e.mode===ye.SCENE3D?h=t._boundingSphereWC:e.mode===ye.COLUMBUS_VIEW?h=t._boundingSphereCV:e.mode===ye.SCENE2D&&m(t._boundingSphere2D)?h=t._boundingSphere2D:m(t._boundingSphereMorph)&&(h=t._boundingSphereMorph);let A=e.commandList,d=e.passes;if(d.render||d.pick){let f=t.allowPicking,E=XI.castShadows(t.shadows),_=XI.receiveShadows(t.shadows),R=i.length,I=a?2:1;I*=m(t._depthFailAppearance)?2:1;for(let C=0;C<R;++C){let N=Math.floor(C/I),T=i[C];T.modelMatrix=s,T.boundingVolume=h[N],T.cull=o,T.debugShowBoundingVolume=r,T.castShadows=E,T.receiveShadows=_,f?T.pickId="v_pickColor":T.pickId=void 0,A.push(T)}}}function RJ(t,e,i){if(i===Pe.TOP){let n=Nt.clone(t,Not),s=Nt.clone(t,Fot);s.center=l.add(s.center,e,s.center),t=Nt.union(n,s,t)}else i===Pe.ALL&&(t.center=l.add(t.center,e,t.center));return t}function bot(t,e,i){return function(){let n=t.getBatchedAttribute(e,i),s=t.attributes[i],o=s.componentsPerAttribute,r=At.createTypedArray(s.componentDatatype,o);return m(n.constructor.pack)?n.constructor.pack(n,r,0):r[0]=n,r}}function Yot(t,e,i,n,s){return function(o){if(!m(o)||!m(o.length)||o.length<1||o.length>4)throw new Y("value must be and array with length between 1 and 4.");let r=mJ(o);t.setBatchedAttribute(e,i,r),s==="offset"&&(n._recomputeBoundingSpheres=!0,n._batchTableOffsetsUpdated=!1)}}function Sot(t,e,i){e.boundingSphere={get:function(){let n=t._instanceBoundingSpheres[i];if(m(n)){n=n.clone();let s=t.modelMatrix,o=e.offset;m(o)&&RJ(n,l.fromArray(o.get(),0,Vot),t._offsetInstanceExtend[i]),m(s)&&(n=Nt.transform(n,s))}return n}},e.boundingSphereCV={get:function(){return t._instanceBoundingSpheresCV[i]}}}function Oot(t,e,i){e.pickId={get:function(){return t._pickIds[i]}}}function r_(t,e,i,n){t._error=n,t._state=i,e.afterRender.push(function(){t._ready=t._state===Is.COMPLETE||t._state===Is.FAILED})}var sot,oot,dJ,cot,sF,qI,fot,AJ,fJ,EJ,_J,oF,Iot,o_,cJ,Not,Fot,Vot,vs,rF=S(()=>{_i();Xe();Ht();Os();ri();aE();Qn();KA();oi();Ft();mt();Ws();Ot();Tl();Il();yi();ji();En();go();nc();bi();nh();Ps();TP();kN();Nl();ga();Gm();Wm();Um();Qm();bl();OT();YP();MI();PN();KI();iJ();ua();nJ();Object.defineProperties(qn.prototype,{vertexCacheOptimize:{get:function(){return this._vertexCacheOptimize}},interleave:{get:function(){return this._interleave}},releaseGeometryInstances:{get:function(){return this._releaseGeometryInstances}},allowPicking:{get:function(){return this._allowPicking}},asynchronous:{get:function(){return this._asynchronous}},compressVertices:{get:function(){return this._compressVertices}},ready:{get:function(){return this._ready}}});sot=new nt,oot=new l,dJ=new ie;cot=/in\s+vec(?:3|4)\s+(.*)3DHigh;/g;qn._modifyShaderPosition=function(t,e,i){let n,s="",o="",r="";for(;(n=cot.exec(e))!==null;){let a=n[1],h=`vec4 czm_compute${a[0].toUpperCase()}${a.substr(1)}()`;h!=="vec4 czm_computePosition()"&&(s+=`${h};
`),m(t.rtcCenter)?(e=e.replace(/in\s+vec(?:3|4)\s+position3DHigh;/g,""),e=e.replace(/in\s+vec(?:3|4)\s+position3DLow;/g,""),s+=`uniform mat4 u_modifiedModelView;
`,o+=`in vec4 position;
`,r+=`${h}
{
    return u_modifiedModelView * position;
}

`,e=e.replace(/czm_modelViewRelativeToEye\s+\*\s+/g,""),e=e.replace(/czm_modelViewProjectionRelativeToEye/g,"czm_projection")):i?r+=`${h}
{
    return czm_translateRelativeToEye(${a}3DHigh, ${a}3DLow);
}

`:(o+=`in vec3 ${a}2DHigh;
in vec3 ${a}2DLow;
`,r+=`${h}
{
    vec4 p;
    if (czm_morphTime == 1.0)
    {
        p = czm_translateRelativeToEye(${a}3DHigh, ${a}3DLow);
    }
    else if (czm_morphTime == 0.0)
    {
        p = czm_translateRelativeToEye(${a}2DHigh.zxy, ${a}2DLow.zxy);
    }
    else
    {
        p = czm_columbusViewMorph(
                czm_translateRelativeToEye(${a}2DHigh.zxy, ${a}2DLow.zxy),
                czm_translateRelativeToEye(${a}3DHigh, ${a}3DLow),
                czm_morphTime);
    }
    return p;
}

`)}return[s,o,e,r].join(`
`)};qn._appendShowToShader=function(t,e){return m(t._batchTableAttributeIndices.show)?`${Ui.replaceMain(e,"czm_non_show_main")}
void main() 
{ 
    czm_non_show_main(); 
    gl_Position *= czm_batchTable_show(batchId); 
}`:e};qn._updateColorAttribute=function(t,e,i){if(!m(t._batchTableAttributeIndices.color)&&!m(t._batchTableAttributeIndices.depthFailColor)||e.search(/in\s+vec4\s+color;/g)===-1)return e;if(i&&!m(t._batchTableAttributeIndices.depthFailColor))throw new Y("A depthFailColor per-instance attribute is required when using a depth fail appearance that uses a color attribute.");let n=e;return n=n.replace(/in\s+vec4\s+color;/g,""),i?n=n.replace(/(\b)color(\b)/g,"$1czm_batchTable_depthFailColor(batchId)$2"):n=n.replace(/(\b)color(\b)/g,"$1czm_batchTable_color(batchId)$2"),n};qn._updatePickColorAttribute=function(t){let e=t.replace(/in\s+vec4\s+pickColor;/g,"");return e=e.replace(/(\b)pickColor(\b)/g,"$1czm_batchTable_pickColor(batchId)$2"),e};qn._appendOffsetToShader=function(t,e){if(!m(t._batchTableAttributeIndices.offset))return e;let i=`in float batchId;
`;i+="in float applyOffset;";let n=e.replace(/in\s+float\s+batchId;/g,i),s=`vec4 $1 = czm_computePosition();
`;return s+=`    if (czm_sceneMode == czm_sceneMode3D)
`,s+=`    {
`,s+="        $1 = $1 + vec4(czm_batchTable_offset(batchId) * applyOffset, 0.0);",s+=`    }
`,s+=`    else
`,s+=`    {
`,s+="        $1 = $1 + vec4(czm_batchTable_offset2D(batchId) * applyOffset, 0.0);",s+=`    }
`,n=n.replace(/vec4\s+([A-Za-z0-9_]+)\s+=\s+czm_computePosition\(\);/g,s),n};qn._appendDistanceDisplayConditionToShader=function(t,e,i){if(!m(t._batchTableAttributeIndices.distanceDisplayCondition))return e;let n=Ui.replaceMain(e,"czm_non_distanceDisplayCondition_main"),s=`void main() 
{ 
    czm_non_distanceDisplayCondition_main(); 
    vec2 distanceDisplayCondition = czm_batchTable_distanceDisplayCondition(batchId);
    vec3 boundingSphereCenter3DHigh = czm_batchTable_boundingSphereCenter3DHigh(batchId);
    vec3 boundingSphereCenter3DLow = czm_batchTable_boundingSphereCenter3DLow(batchId);
    float boundingSphereRadius = czm_batchTable_boundingSphereRadius(batchId);
`;return i?s+=`    vec4 centerRTE = czm_translateRelativeToEye(boundingSphereCenter3DHigh, boundingSphereCenter3DLow);
`:s+=`    vec3 boundingSphereCenter2DHigh = czm_batchTable_boundingSphereCenter2DHigh(batchId);
    vec3 boundingSphereCenter2DLow = czm_batchTable_boundingSphereCenter2DLow(batchId);
    vec4 centerRTE;
    if (czm_morphTime == 1.0)
    {
        centerRTE = czm_translateRelativeToEye(boundingSphereCenter3DHigh, boundingSphereCenter3DLow);
    }
    else if (czm_morphTime == 0.0)
    {
        centerRTE = czm_translateRelativeToEye(boundingSphereCenter2DHigh.zxy, boundingSphereCenter2DLow.zxy);
    }
    else
    {
        centerRTE = czm_columbusViewMorph(
                czm_translateRelativeToEye(boundingSphereCenter2DHigh.zxy, boundingSphereCenter2DLow.zxy),
                czm_translateRelativeToEye(boundingSphereCenter3DHigh, boundingSphereCenter3DLow),
                czm_morphTime);
    }
`,s+=`    float radiusSq = boundingSphereRadius * boundingSphereRadius; 
    float distanceSq; 
    if (czm_sceneMode == czm_sceneMode2D) 
    { 
        distanceSq = czm_eyeHeight2D.y - radiusSq; 
    } 
    else 
    { 
        distanceSq = dot(centerRTE.xyz, centerRTE.xyz) - radiusSq; 
    } 
    distanceSq = max(distanceSq, 0.0); 
    float nearSq = distanceDisplayCondition.x * distanceDisplayCondition.x; 
    float farSq = distanceDisplayCondition.y * distanceDisplayCondition.y; 
    float show = (distanceSq >= nearSq && distanceSq <= farSq) ? 1.0 : 0.0; 
    gl_Position *= show; 
}`,`${n}
${s}`};sF=Math.max(_o.hardwareConcurrency-1,1),fot=new XE("combineGeometry");AJ=new Gn,fJ=new ut,EJ=new l,_J=new Nt;oF=new l,Iot=new l;o_=new at,cJ=new l;qn._updateBoundingVolumes=function(t,e,i,n){let s,o,r;if(n||!at.equals(i,t._modelMatrix))for(at.clone(i,t._modelMatrix),o=t._boundingSpheres.length,s=0;s<o;++s)r=t._boundingSpheres[s],m(r)&&(t._boundingSphereWC[s]=Nt.transform(r,i,t._boundingSphereWC[s]),e.scene3DOnly||(t._boundingSphere2D[s]=Nt.clone(t._boundingSphereCV[s],t._boundingSphere2D[s]),t._boundingSphere2D[s].center.x=0,t._boundingSphereMorph[s]=Nt.union(t._boundingSphereWC[s],t._boundingSphereCV[s])));let a=t.appearance.pixelSize;if(m(a))for(o=t._boundingSpheres.length,s=0;s<o;++s){r=t._boundingSpheres[s];let h=t._boundingSphereWC[s],d=e.camera.getPixelSize(r,e.context.drawingBufferWidth,e.context.drawingBufferHeight)*a;h.radius=r.radius+d}};qn.prototype.update=function(t){if(!m(this.geometryInstances)&&this._va.length===0||m(this.geometryInstances)&&Array.isArray(this.geometryInstances)&&this.geometryInstances.length===0||!m(this.appearance)||t.mode!==ye.SCENE3D&&t.scene3DOnly||!t.passes.render&&!t.passes.pick)return;if(m(this._error))throw this._error;if(m(this.rtcCenter)&&!t.scene3DOnly)throw new Y("RTC rendering is only available for 3D only scenes.");if(this._state===Is.FAILED)return;let e=t.context;if(m(this._batchTable)||rot(this,e),this._batchTable.attributes.length>0){if(en.maximumVertexTextureImageUnits===0)throw new ke("Vertex texture fetch support is required to render primitives with per-instance attributes. The maximum number of vertex texture image units must be greater than zero.");this._batchTable.update(t)}if(this._state!==Is.COMPLETE&&this._state!==Is.COMBINED&&(this.asynchronous?Eot(this,t):_ot(this,t)),this._state===Is.COMBINED&&(Zot(this,t),hJ(this,t),pot(this,t)),!this.show||this._state!==Is.COMPLETE)return;this._batchTableOffsetsUpdated||hJ(this,t),this._recomputeBoundingSpheres&&Rot(this,t);let i=this.appearance,n=i.material,s=!1,o=!1;this._appearance!==i?(this._appearance=i,this._material=n,s=!0,o=!0):this._material!==n&&(this._material=n,o=!0);let r=this.depthFailAppearance,a=m(r)?r.material:void 0;this._depthFailAppearance!==r?(this._depthFailAppearance=r,this._depthFailMaterial=a,s=!0,o=!0):this._depthFailMaterial!==a&&(this._depthFailMaterial=a,o=!0);let h=this._appearance.isTranslucent();this._translucent!==h&&(this._translucent=h,s=!0),m(this._material)&&this._material.update(e);let A=i.closed&&h;s&&Z(this._createRenderStatesFunction,uot)(this,e,i,A),o&&Z(this._createShaderProgramFunction,Cot)(this,t,i),(s||o)&&Z(this._createCommandsFunction,got)(this,i,n,h,A,this._colorCommands,this._pickCommands,t),Z(this._updateAndQueueCommandsFunction,Tot)(this,t,this._colorCommands,this._pickCommands,this.modelMatrix,this.cull,this.debugShowBoundingVolume,A)};Not=new Nt,Fot=new Nt;Vot=new l;qn.prototype.getGeometryInstanceAttributes=function(t){if(!m(t))throw new Y("id is required");if(!m(this._batchTable))throw new Y("must call update before calling getGeometryInstanceAttributes");let e=this._perInstanceAttributeCache.get(t);if(m(e))return e;let i=-1,n=this._lastPerInstanceAttributeIndex,s=this._instanceIds,o=s.length;for(let A=0;A<o;++A){let d=(n+A)%o;if(t===s[d]){i=d;break}}if(i===-1)return;let r=this._batchTable,a=this._batchTableAttributeIndices;e={};let h={};for(let A in a)if(a.hasOwnProperty(A)){let d=a[A];h[A]={get:bot(r,i,d),set:Yot(r,i,d,this,A)}}return Sot(this,h,i),Oot(this,h,i),Object.defineProperties(e,h),this._lastPerInstanceAttributeIndex=i,this._perInstanceAttributeCache.set(t,e),e};qn.prototype.isDestroyed=function(){return!1};qn.prototype.destroy=function(){let t,e;this._sp=this._sp&&this._sp.destroy(),this._spDepthFail=this._spDepthFail&&this._spDepthFail.destroy();let i=this._va;for(t=i.length,e=0;e<t;++e)i[e].destroy();this._va=void 0;let n=this._pickIds;for(t=n.length,e=0;e<t;++e)n[e].destroy();return this._pickIds=void 0,this._batchTable=this._batchTable&&this._batchTable.destroy(),this._instanceIds=void 0,this._perInstanceAttributeCache=void 0,this._attributeLocations=void 0,li(this)};vs=qn});var Bot,pr,$I=S(()=>{ss();Bot={NEVER:it.NEVER,LESS:it.LESS,EQUAL:it.EQUAL,LESS_OR_EQUAL:it.LEQUAL,GREATER:it.GREATER,NOT_EQUAL:it.NOTEQUAL,GREATER_OR_EQUAL:it.GEQUAL,ALWAYS:it.ALWAYS},pr=Object.freeze(Bot)});var Got,Hi,tp=S(()=>{ss();Got={ZERO:it.ZERO,KEEP:it.KEEP,REPLACE:it.REPLACE,INCREMENT:it.INCR,DECREMENT:it.DECR,INVERT:it.INVERT,INCREMENT_WRAP:it.INCR_WRAP,DECREMENT_WRAP:it.DECR_WRAP},Hi=Object.freeze(Got)});var ep,Wa,aF=S(()=>{$I();tp();ep={CESIUM_3D_TILE_MASK:128,SKIP_LOD_MASK:112,SKIP_LOD_BIT_SHIFT:4,CLASSIFICATION_MASK:15};ep.setCesium3DTileBit=function(){return{enabled:!0,frontFunction:pr.ALWAYS,frontOperation:{fail:Hi.KEEP,zFail:Hi.KEEP,zPass:Hi.REPLACE},backFunction:pr.ALWAYS,backOperation:{fail:Hi.KEEP,zFail:Hi.KEEP,zPass:Hi.REPLACE},reference:ep.CESIUM_3D_TILE_MASK,mask:ep.CESIUM_3D_TILE_MASK}};Wa=Object.freeze(ep)});function Ih(t){t=Z(t,Z.EMPTY_OBJECT),this.geometryInstances=t.geometryInstances,this._hasPerInstanceColors=!0;let e=t.appearance;m(e)||(e=new uP),this.appearance=e,this.show=Z(t.show,!0),this.classificationType=Z(t.classificationType,Jr.BOTH),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this._debugShowShadowVolume=Z(t.debugShowShadowVolume,!1),this._primitiveOptions={geometryInstances:void 0,appearance:void 0,vertexCacheOptimize:!1,interleave:Z(t.interleave,!1),releaseGeometryInstances:Z(t.releaseGeometryInstances,!0),allowPicking:Z(t.allowPicking,!0),asynchronous:Z(t.asynchronous,!0),compressVertices:!1,_createShaderProgramFunction:void 0,_createCommandsFunction:void 0,_updateAndQueueCommandsFunction:void 0},this._zIndex=void 0,this._ready=!1,this._primitive=void 0,this._sp=void 0,this._sp2D=void 0,this._spMorph=void 0,this._renderState=ZJ(!1),this._renderState3DTiles=ZJ(!0),this._renderStateMorph=Yn.fromCache({cull:{enabled:!0,face:Eh.FRONT},depthTest:{enabled:!0},blending:Mr.PRE_MULTIPLIED_ALPHA_BLEND,depthMask:!1})}function Wot(t,e,i){let n=e.context,s=t._primitive,o=s._attributeLocations,r=s._batchTable.getVertexShaderCallback()(mx);r=vs._appendShowToShader(s,r),r=vs._appendDistanceDisplayConditionToShader(s,r),r=vs._modifyShaderPosition(t,r,e.scene3DOnly);let a=s._batchTable.getVertexShaderCallback()(lx);a=vs._appendShowToShader(s,a),a=vs._appendDistanceDisplayConditionToShader(s,a),a=vs._modifyShaderPosition(t,a,e.scene3DOnly);let h=s._batchTable.getVertexShaderCallback()(ax),A=[`GLOBE_MINIMUM_ALTITUDE ${e.mapProjection.ellipsoid.minimumRadius.toFixed(1)}`],d="",f="";m(i.material)?(f=m(i.material)?i.material.shaderSource:"",f.search(/in\s+float\s+v_polylineAngle;/g)!==-1&&A.push("ANGLE_VARYING"),f.search(/in\s+float\s+v_width;/g)!==-1&&A.push("WIDTH_VARYING")):d="PER_INSTANCE_COLOR",A.push(d);let E=t.debugShowShadowVolume?["DEBUG_SHOW_VOLUME",d]:[d],_=new Ui({defines:A,sources:[r]}),R=new Ui({defines:E,sources:[f,h]});t._sp=Es.replaceCache({context:n,shaderProgram:s._sp,vertexShaderSource:_,fragmentShaderSource:R,attributeLocations:o});let I=n.shaderCache.getDerivedShaderProgram(t._sp,"2dColor");if(!m(I)){let N=new Ui({defines:A.concat(["COLUMBUS_VIEW_2D"]),sources:[r]});I=n.shaderCache.createDerivedShaderProgram(t._sp,"2dColor",{context:n,shaderProgram:t._sp2D,vertexShaderSource:N,fragmentShaderSource:R,attributeLocations:o})}t._sp2D=I;let C=n.shaderCache.getDerivedShaderProgram(t._sp,"MorphColor");if(!m(C)){let N=new Ui({defines:A.concat([`MAX_TERRAIN_HEIGHT ${Do._defaultMaxTerrainHeight.toFixed(1)}`]),sources:[a]});h=s._batchTable.getVertexShaderCallback()(hx);let T=new Ui({defines:E,sources:[f,h]});C=n.shaderCache.createDerivedShaderProgram(t._sp,"MorphColor",{context:n,shaderProgram:t._spMorph,vertexShaderSource:N,fragmentShaderSource:T,attributeLocations:o})}t._spMorph=C}function ZJ(t){return Yn.fromCache({cull:{enabled:!0},blending:Mr.PRE_MULTIPLIED_ALPHA_BLEND,depthMask:!1,stencilTest:{enabled:t,frontFunction:pr.EQUAL,frontOperation:{fail:Hi.KEEP,zFail:Hi.KEEP,zPass:Hi.KEEP},backFunction:pr.EQUAL,backOperation:{fail:Hi.KEEP,zFail:Hi.KEEP,zPass:Hi.KEEP},reference:Wa.CESIUM_3D_TILE_MASK,mask:Wa.CESIUM_3D_TILE_MASK}})}function Dot(t,e,i,n,s,o){let r=t._primitive,a=r._va.length;s.length=a,o.length=a;let A=e instanceof DN?{}:i._uniforms,d=r._batchTable.getUniformMapCallback()(A);for(let f=0;f<a;f++){let E=r._va[f],_=s[f];m(_)||(_=s[f]=new fn({owner:t,primitiveType:r._primitiveType})),_.vertexArray=E,_.renderState=t._renderState,_.shaderProgram=t._sp,_.uniformMap=d,_.pass=os.TERRAIN_CLASSIFICATION,_.pickId="czm_batchTable_pickColor(v_endPlaneNormalEcAndBatchId.w)";let R=fn.shallowClone(_,_.derivedCommands.tileset);R.renderState=t._renderState3DTiles,R.pass=os.CESIUM_3D_TILE_CLASSIFICATION,_.derivedCommands.tileset=R;let I=fn.shallowClone(_,_.derivedCommands.color2D);I.shaderProgram=t._sp2D,_.derivedCommands.color2D=I;let C=fn.shallowClone(R,R.derivedCommands.color2D);C.shaderProgram=t._sp2D,R.derivedCommands.color2D=C;let N=fn.shallowClone(_,_.derivedCommands.colorMorph);N.renderState=t._renderStateMorph,N.shaderProgram=t._spMorph,N.pickId="czm_batchTable_pickColor(v_batchId)",_.derivedCommands.colorMorph=N}}function IJ(t,e,i,n,s,o,r){i.mode===ye.MORPHING?e=e.derivedCommands.colorMorph:i.mode!==ye.SCENE3D&&(e=e.derivedCommands.color2D),e.modelMatrix=n,e.boundingVolume=o,e.cull=s,e.debugShowBoundingVolume=r,i.commandList.push(e)}function Uot(t,e,i,n,s,o,r){let a=t._primitive;vs._updateBoundingVolumes(a,e,s);let h;e.mode===ye.SCENE3D?h=a._boundingSphereWC:e.mode===ye.COLUMBUS_VIEW?h=a._boundingSphereCV:e.mode===ye.SCENE2D&&m(a._boundingSphere2D)?h=a._boundingSphere2D:m(a._boundingSphereMorph)&&(h=a._boundingSphereMorph);let A=e.mode===ye.MORPHING,d=t.classificationType,f=d!==Jr.CESIUM_3D_TILE,E=d!==Jr.TERRAIN&&!A,_,R=e.passes;if(R.render||R.pick&&a.allowPicking){let I=i.length;for(let C=0;C<I;++C){let N=h[C];f&&(_=i[C],IJ(t,_,e,s,o,N,r)),E&&(_=i[C].derivedCommands.tileset,IJ(t,_,e,s,o,N,r))}}}var pJ,uJ=S(()=>{JE();oi();Ft();mt();Ws();Ot();uA();mN();ON();Gm();Wm();Um();Qm();bl();Ax();cx();dx();fx();km();UI();MI();Zx();CP();rF();ua();aF();$I();tp();Object.defineProperties(Ih.prototype,{interleave:{get:function(){return this._primitiveOptions.interleave}},releaseGeometryInstances:{get:function(){return this._primitiveOptions.releaseGeometryInstances}},allowPicking:{get:function(){return this._primitiveOptions.allowPicking}},asynchronous:{get:function(){return this._primitiveOptions.asynchronous}},ready:{get:function(){return this._ready}},debugShowShadowVolume:{get:function(){return this._debugShowShadowVolume}}});Ih.initializeTerrainHeights=function(){return Do.initialize()};Ih.prototype.update=function(t){if(!m(this._primitive)&&!m(this.geometryInstances))return;if(!Do.initialized){if(!this.asynchronous)throw new Y("For synchronous GroundPolylinePrimitives, you must call GroundPolylinePrimitives.initializeTerrainHeights() and wait for the returned promise to resolve.");Ih.initializeTerrainHeights();return}let e,i=this,n=this._primitiveOptions;if(!m(this._primitive)){let s=Array.isArray(this.geometryInstances)?this.geometryInstances:[this.geometryInstances],o=s.length,r=new Array(o),a;for(e=0;e<o;++e)if(a=s[e].attributes,!m(a)||!m(a.color)){this._hasPerInstanceColors=!1;break}for(e=0;e<o;++e){let h=s[e];a={};let A=h.attributes;for(let d in A)A.hasOwnProperty(d)&&(a[d]=A[d]);m(a.width)||(a.width=new Zr({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,value:[h.geometry.width]})),h.geometry._scene3DOnly=t.scene3DOnly,KE.setProjectionAndEllipsoid(h.geometry,t.mapProjection),r[e]=new Ln({geometry:h.geometry,attributes:a,id:h.id,pickPrimitive:i})}n.geometryInstances=r,n.appearance=this.appearance,n._createShaderProgramFunction=function(h,A,d){Wot(i,A,d)},n._createCommandsFunction=function(h,A,d,f,E,_,R){Dot(i,A,d,f,_,R)},n._updateAndQueueCommandsFunction=function(h,A,d,f,E,_,R,I){Uot(i,A,d,f,E,_,R)},this._primitive=new vs(n)}if(this.appearance instanceof DN&&!this._hasPerInstanceColors)throw new Y("All GeometryInstances must have color attributes to use PolylineColorAppearance with GroundPolylinePrimitive.");this._primitive.appearance=this.appearance,this._primitive.show=this.show,this._primitive.debugShowBoundingVolume=this.debugShowBoundingVolume,this._primitive.update(t),t.afterRender.push(()=>{!this._ready&&m(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};Ih.prototype.getGeometryInstanceAttributes=function(t){if(!m(this._primitive))throw new Y("must call update before calling getGeometryInstanceAttributes");return this._primitive.getGeometryInstanceAttributes(t)};Ih.isSupported=function(t){return t.frameState.context.depthTexture};Ih.prototype.isDestroyed=function(){return!1};Ih.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),this._sp=this._sp&&this._sp.destroy(),this._sp2D=void 0,this._spMorph=void 0,li(this)};pJ=Ih});function ko(t,e,i){this.minimum=l.clone(Z(t,l.ZERO)),this.maximum=l.clone(Z(e,l.ZERO)),m(i)?i=l.clone(i):i=l.midpoint(this.minimum,this.maximum,new l),this.center=i}var ip,ph,a_=S(()=>{Ht();ae();Ft();mt();nc();ko.fromCorners=function(t,e,i){return p.defined("minimum",t),p.defined("maximum",e),m(i)||(i=new ko),i.minimum=l.clone(t,i.minimum),i.maximum=l.clone(e,i.maximum),i.center=l.midpoint(t,e,i.center),i};ko.fromPoints=function(t,e){if(m(e)||(e=new ko),!m(t)||t.length===0)return e.minimum=l.clone(l.ZERO,e.minimum),e.maximum=l.clone(l.ZERO,e.maximum),e.center=l.clone(l.ZERO,e.center),e;let i=t[0].x,n=t[0].y,s=t[0].z,o=t[0].x,r=t[0].y,a=t[0].z,h=t.length;for(let f=1;f<h;f++){let E=t[f],_=E.x,R=E.y,I=E.z;i=Math.min(_,i),o=Math.max(_,o),n=Math.min(R,n),r=Math.max(R,r),s=Math.min(I,s),a=Math.max(I,a)}let A=e.minimum;A.x=i,A.y=n,A.z=s;let d=e.maximum;return d.x=o,d.y=r,d.z=a,e.center=l.midpoint(A,d,e.center),e};ko.clone=function(t,e){if(m(t))return m(e)?(e.minimum=l.clone(t.minimum,e.minimum),e.maximum=l.clone(t.maximum,e.maximum),e.center=l.clone(t.center,e.center),e):new ko(t.minimum,t.maximum,t.center)};ko.equals=function(t,e){return t===e||m(t)&&m(e)&&l.equals(t.center,e.center)&&l.equals(t.minimum,e.minimum)&&l.equals(t.maximum,e.maximum)};ip=new l;ko.intersectPlane=function(t,e){p.defined("box",t),p.defined("plane",e),ip=l.subtract(t.maximum,t.minimum,ip);let i=l.multiplyByScalar(ip,.5,ip),n=e.normal,s=i.x*Math.abs(n.x)+i.y*Math.abs(n.y)+i.z*Math.abs(n.z),o=l.dot(t.center,n)+e.distance;return o-s>0?Nn.INSIDE:o+s<0?Nn.OUTSIDE:Nn.INTERSECTING};ko.prototype.clone=function(t){return ko.clone(this,t)};ko.prototype.intersectPlane=function(t){return ko.intersectPlane(this,t)};ko.prototype.equals=function(t){return ko.equals(this,t)};ph=ko});function NA(t,e){if(p.defined("origin",t),e=Z(e,ot.WGS84),t=e.scaleToGeodeticSurface(t),!m(t))throw new Y("origin must not be at the center of the ellipsoid.");let i=In.eastNorthUpToFixedFrame(t,e);this._ellipsoid=e,this._origin=t,this._xAxis=l.fromCartesian4(at.getColumn(i,0,AF)),this._yAxis=l.fromCartesian4(at.getColumn(i,1,AF));let n=l.fromCartesian4(at.getColumn(i,2,AF));this._plane=Ki.fromPointNormal(t,n)}var AF,Mot,CJ,np,Qot,oo,Xm=S(()=>{a_();Xe();Ht();Os();ae();Ft();mt();Ot();Oe();Ul();bi();nh();SI();fr();AF=new ie;Object.defineProperties(NA.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},origin:{get:function(){return this._origin}},plane:{get:function(){return this._plane}},xAxis:{get:function(){return this._xAxis}},yAxis:{get:function(){return this._yAxis}},zAxis:{get:function(){return this._plane.normal}}});Mot=new ph;NA.fromPoints=function(t,e){p.defined("cartesians",t);let i=ph.fromPoints(t,Mot);return new NA(i.center,e)};CJ=new Wl,np=new l;NA.prototype.projectPointOntoPlane=function(t,e){p.defined("cartesian",t);let i=CJ;i.origin=t,l.normalize(t,i.direction);let n=no.rayPlane(i,this._plane,np);if(m(n)||(l.negate(i.direction,i.direction),n=no.rayPlane(i,this._plane,np)),m(n)){let s=l.subtract(n,this._origin,n),o=l.dot(this._xAxis,s),r=l.dot(this._yAxis,s);return m(e)?(e.x=o,e.y=r,e):new nt(o,r)}};NA.prototype.projectPointsOntoPlane=function(t,e){p.defined("cartesians",t),m(e)||(e=[]);let i=0,n=t.length;for(let s=0;s<n;s++){let o=this.projectPointOntoPlane(t[s],e[i]);m(o)&&(e[i]=o,i++)}return e.length=i,e};NA.prototype.projectPointToNearestOnPlane=function(t,e){p.defined("cartesian",t),m(e)||(e=new nt);let i=CJ;i.origin=t,l.clone(this._plane.normal,i.direction);let n=no.rayPlane(i,this._plane,np);m(n)||(l.negate(i.direction,i.direction),n=no.rayPlane(i,this._plane,np));let s=l.subtract(n,this._origin,n),o=l.dot(this._xAxis,s),r=l.dot(this._yAxis,s);return e.x=o,e.y=r,e};NA.prototype.projectPointsToNearestOnPlane=function(t,e){p.defined("cartesians",t),m(e)||(e=[]);let i=t.length;e.length=i;for(let n=0;n<i;n++)e[n]=this.projectPointToNearestOnPlane(t[n],e[n]);return e};Qot=new l;NA.prototype.projectPointOntoEllipsoid=function(t,e){p.defined("cartesian",t),m(e)||(e=new l);let i=this._ellipsoid,n=this._origin,s=this._xAxis,o=this._yAxis,r=Qot;return l.multiplyByScalar(s,t.x,r),e=l.add(n,r,e),l.multiplyByScalar(o,t.y,r),l.add(e,r,e),i.scaleToGeocentricSurface(e,e),e};NA.prototype.projectPointsOntoEllipsoid=function(t,e){p.defined("cartesians",t);let i=t.length;m(e)?e.length=i:e=new Array(i);for(let n=0;n<i;++n)e[n]=this.projectPointOntoEllipsoid(t[n],e[n]);return e};oo=NA});function Bi(t,e){this.center=l.clone(Z(t,l.ZERO)),this.halfAxes=lt.clone(Z(e,lt.ZERO))}function gJ(t,e,i,n,s,o,r,a,h,A,d){if(!m(s)||!m(o)||!m(r)||!m(a)||!m(h)||!m(A))throw new Y("all extents (minimum/maximum X/Y/Z) are required.");m(d)||(d=new Bi);let f=d.halfAxes;lt.setColumn(f,0,e,f),lt.setColumn(f,1,i,f),lt.setColumn(f,2,n,f);let E=YJ;E.x=(s+o)/2,E.y=(r+a)/2,E.z=(h+A)/2;let _=Hot;_.x=(o-s)/2,_.y=(a-r)/2,_.z=(A-h)/2;let R=d.center;return E=lt.multiplyByVector(f,E,E),l.add(t,E,R),lt.multiplyByScale(f,_,f),d}var kot,Lot,yot,wot,xot,Pot,Jot,jot,YJ,Hot,TJ,vot,zot,Kot,Xot,qot,$ot,trt,NJ,ert,FJ,irt,nrt,srt,ort,rrt,art,Art,hrt,crt,lrt,drt,mrt,frt,Ert,_rt,VJ,SJ,OJ,Rrt,bJ,Zrt,Irt,prt,urt,Crt,grt,Trt,Nrt,zs,Jl=S(()=>{_i();Xe();Ht();ri();ae();Ft();mt();Ot();Oe();Xm();nc();HZ();_e();dn();bi();nh();pn();Bi.packedLength=l.packedLength+lt.packedLength;Bi.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),l.pack(t.center,e,i),lt.pack(t.halfAxes,e,i+l.packedLength),e};Bi.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Bi),l.unpack(t,e,i.center),lt.unpack(t,e+l.packedLength,i.halfAxes),i};kot=new l,Lot=new l,yot=new l,wot=new l,xot=new l,Pot=new l,Jot=new lt,jot={unitary:new lt,diagonal:new lt};Bi.fromPoints=function(t,e){if(m(e)||(e=new Bi),!m(t)||t.length===0)return e.halfAxes=lt.ZERO,e.center=l.ZERO,e;let i,n=t.length,s=l.clone(t[0],kot);for(i=1;i<n;i++)l.add(s,t[i],s);let o=1/n;l.multiplyByScalar(s,o,s);let r=0,a=0,h=0,A=0,d=0,f=0,E;for(i=0;i<n;i++)E=l.subtract(t[i],s,Lot),r+=E.x*E.x,a+=E.x*E.y,h+=E.x*E.z,A+=E.y*E.y,d+=E.y*E.z,f+=E.z*E.z;r*=o,a*=o,h*=o,A*=o,d*=o,f*=o;let _=Jot;_[0]=r,_[1]=a,_[2]=h,_[3]=a,_[4]=A,_[5]=d,_[6]=h,_[7]=d,_[8]=f;let R=lt.computeEigenDecomposition(_,jot),I=lt.clone(R.unitary,e.halfAxes),C=lt.getColumn(I,0,wot),N=lt.getColumn(I,1,xot),T=lt.getColumn(I,2,Pot),b=-Number.MAX_VALUE,F=-Number.MAX_VALUE,B=-Number.MAX_VALUE,U=Number.MAX_VALUE,Q=Number.MAX_VALUE,M=Number.MAX_VALUE;for(i=0;i<n;i++)E=t[i],b=Math.max(l.dot(C,E),b),F=Math.max(l.dot(N,E),F),B=Math.max(l.dot(T,E),B),U=Math.min(l.dot(C,E),U),Q=Math.min(l.dot(N,E),Q),M=Math.min(l.dot(T,E),M);C=l.multiplyByScalar(C,.5*(U+b),C),N=l.multiplyByScalar(N,.5*(Q+F),N),T=l.multiplyByScalar(T,.5*(M+B),T);let k=l.add(C,N,e.center);l.add(k,T,k);let y=yot;return y.x=b-U,y.y=F-Q,y.z=B-M,l.multiplyByScalar(y,.5,y),lt.multiplyByScale(e.halfAxes,y,e.halfAxes),e};YJ=new l,Hot=new l;TJ=new ut,vot=new l,zot=new ut,Kot=new ut,Xot=new ut,qot=new ut,$ot=new ut,trt=new l,NJ=new l,ert=new l,FJ=new l,irt=new l,nrt=new nt,srt=new nt,ort=new nt,rrt=new nt,art=new nt,Art=new l,hrt=new l,crt=new l,lrt=new l,drt=new nt,mrt=new l,frt=new l,Ert=new l,_rt=new Ki(l.UNIT_X,0);Bi.fromRectangle=function(t,e,i,n,s){if(!m(t))throw new Y("rectangle is required");if(t.width<0||t.width>L.TWO_PI)throw new Y("Rectangle width must be between 0 and 2 * pi");if(t.height<0||t.height>L.PI)throw new Y("Rectangle height must be between 0 and pi");if(m(n)&&!L.equalsEpsilon(n.radii.x,n.radii.y,L.EPSILON15))throw new Y("Ellipsoid must be an ellipsoid of revolution (radii.x == radii.y)");e=Z(e,0),i=Z(i,0),n=Z(n,ot.WGS84);let o,r,a,h,A,d,f;if(t.width<=L.PI){let Q=Xt.center(t,TJ),M=n.cartographicToCartesian(Q,vot),k=new oo(M,n);f=k.plane;let y=Q.longitude,c=t.south<0&&t.north>0?0:Q.latitude,g=ut.fromRadians(y,t.north,i,zot),O=ut.fromRadians(t.west,t.north,i,Kot),D=ut.fromRadians(t.west,c,i,Xot),w=ut.fromRadians(t.west,t.south,i,qot),x=ut.fromRadians(y,t.south,i,$ot),H=n.cartographicToCartesian(g,trt),j=n.cartographicToCartesian(O,NJ),X=n.cartographicToCartesian(D,ert),tt=n.cartographicToCartesian(w,FJ),G=n.cartographicToCartesian(x,irt),It=k.projectPointToNearestOnPlane(H,nrt),gt=k.projectPointToNearestOnPlane(j,srt),Yt=k.projectPointToNearestOnPlane(X,ort),Ut=k.projectPointToNearestOnPlane(tt,rrt),Ct=k.projectPointToNearestOnPlane(G,art);return o=Math.min(gt.x,Yt.x,Ut.x),r=-o,h=Math.max(gt.y,It.y),a=Math.min(Ut.y,Ct.y),O.height=w.height=e,j=n.cartographicToCartesian(O,NJ),tt=n.cartographicToCartesian(w,FJ),A=Math.min(Ki.getPointDistance(f,j),Ki.getPointDistance(f,tt)),d=i,gJ(k.origin,k.xAxis,k.yAxis,k.zAxis,o,r,a,h,A,d,s)}let E=t.south>0,_=t.north<0,R=E?t.south:_?t.north:0,I=Xt.center(t,TJ).longitude,C=l.fromRadians(I,R,i,n,Art);C.z=0;let T=Math.abs(C.x)<L.EPSILON10&&Math.abs(C.y)<L.EPSILON10?l.UNIT_X:l.normalize(C,hrt),b=l.UNIT_Z,F=l.cross(T,b,crt);f=Ki.fromPointNormal(C,T,_rt);let B=l.fromRadians(I+L.PI_OVER_TWO,R,i,n,lrt);r=l.dot(Ki.projectPointOntoPlane(f,B,drt),F),o=-r,h=l.fromRadians(0,t.north,_?e:i,n,mrt).z,a=l.fromRadians(0,t.south,E?e:i,n,frt).z;let U=l.fromRadians(t.east,R,i,n,Ert);return A=Ki.getPointDistance(f,U),d=0,gJ(C,F,b,T,o,r,a,h,A,d,s)};Bi.fromTransformation=function(t,e){return p.typeOf.object("transformation",t),m(e)||(e=new Bi),e.center=at.getTranslation(t,e.center),e.halfAxes=at.getMatrix3(t,e.halfAxes),e.halfAxes=lt.multiplyByScalar(e.halfAxes,.5,e.halfAxes),e};Bi.clone=function(t,e){if(m(t))return m(e)?(l.clone(t.center,e.center),lt.clone(t.halfAxes,e.halfAxes),e):new Bi(t.center,t.halfAxes)};Bi.intersectPlane=function(t,e){if(!m(t))throw new Y("box is required.");if(!m(e))throw new Y("plane is required.");let i=t.center,n=e.normal,s=t.halfAxes,o=n.x,r=n.y,a=n.z,h=Math.abs(o*s[lt.COLUMN0ROW0]+r*s[lt.COLUMN0ROW1]+a*s[lt.COLUMN0ROW2])+Math.abs(o*s[lt.COLUMN1ROW0]+r*s[lt.COLUMN1ROW1]+a*s[lt.COLUMN1ROW2])+Math.abs(o*s[lt.COLUMN2ROW0]+r*s[lt.COLUMN2ROW1]+a*s[lt.COLUMN2ROW2]),A=l.dot(n,i)+e.distance;return A<=-h?Nn.OUTSIDE:A>=h?Nn.INSIDE:Nn.INTERSECTING};VJ=new l,SJ=new l,OJ=new l,Rrt=new l,bJ=new l,Zrt=new l;Bi.distanceSquaredTo=function(t,e){if(!m(t))throw new Y("box is required.");if(!m(e))throw new Y("cartesian is required.");let i=l.subtract(e,t.center,YJ),n=t.halfAxes,s=lt.getColumn(n,0,VJ),o=lt.getColumn(n,1,SJ),r=lt.getColumn(n,2,OJ),a=l.magnitude(s),h=l.magnitude(o),A=l.magnitude(r),d=!0,f=!0,E=!0;a>0?l.divideByScalar(s,a,s):d=!1,h>0?l.divideByScalar(o,h,o):f=!1,A>0?l.divideByScalar(r,A,r):E=!1;let _=!d+!f+!E,R,I,C;if(_===1){let F=s;R=o,I=r,f?E||(F=r,I=s):(F=o,R=s),C=l.cross(R,I,bJ),F===s?s=C:F===o?o=C:F===r&&(r=C)}else if(_===2){R=s,f?R=o:E&&(R=r);let F=l.UNIT_Y;F.equalsEpsilon(R,L.EPSILON3)&&(F=l.UNIT_X),I=l.cross(R,F,Rrt),l.normalize(I,I),C=l.cross(R,I,bJ),l.normalize(C,C),R===s?(o=I,r=C):R===o?(r=I,s=C):R===r&&(s=I,o=C)}else _===3&&(s=l.UNIT_X,o=l.UNIT_Y,r=l.UNIT_Z);let N=Zrt;N.x=l.dot(i,s),N.y=l.dot(i,o),N.z=l.dot(i,r);let T=0,b;return N.x<-a?(b=N.x+a,T+=b*b):N.x>a&&(b=N.x-a,T+=b*b),N.y<-h?(b=N.y+h,T+=b*b):N.y>h&&(b=N.y-h,T+=b*b),N.z<-A?(b=N.z+A,T+=b*b):N.z>A&&(b=N.z-A,T+=b*b),T};Irt=new l,prt=new l;Bi.computePlaneDistances=function(t,e,i,n){if(!m(t))throw new Y("box is required.");if(!m(e))throw new Y("position is required.");if(!m(i))throw new Y("direction is required.");m(n)||(n=new cA);let s=Number.POSITIVE_INFINITY,o=Number.NEGATIVE_INFINITY,r=t.center,a=t.halfAxes,h=lt.getColumn(a,0,VJ),A=lt.getColumn(a,1,SJ),d=lt.getColumn(a,2,OJ),f=l.add(h,A,Irt);l.add(f,d,f),l.add(f,r,f);let E=l.subtract(f,e,prt),_=l.dot(i,E);return s=Math.min(_,s),o=Math.max(_,o),l.add(r,h,f),l.add(f,A,f),l.subtract(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.add(r,h,f),l.subtract(f,A,f),l.add(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.add(r,h,f),l.subtract(f,A,f),l.subtract(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.subtract(r,h,f),l.add(f,A,f),l.add(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.subtract(r,h,f),l.add(f,A,f),l.subtract(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.subtract(r,h,f),l.subtract(f,A,f),l.add(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),l.subtract(r,h,f),l.subtract(f,A,f),l.subtract(f,d,f),l.subtract(f,e,E),_=l.dot(i,E),s=Math.min(_,s),o=Math.max(_,o),n.start=s,n.stop=o,n};urt=new l,Crt=new l,grt=new l;Bi.computeCorners=function(t,e){p.typeOf.object("box",t),m(e)||(e=[new l,new l,new l,new l,new l,new l,new l,new l]);let i=t.center,n=t.halfAxes,s=lt.getColumn(n,0,urt),o=lt.getColumn(n,1,Crt),r=lt.getColumn(n,2,grt);return l.clone(i,e[0]),l.subtract(e[0],s,e[0]),l.subtract(e[0],o,e[0]),l.subtract(e[0],r,e[0]),l.clone(i,e[1]),l.subtract(e[1],s,e[1]),l.subtract(e[1],o,e[1]),l.add(e[1],r,e[1]),l.clone(i,e[2]),l.subtract(e[2],s,e[2]),l.add(e[2],o,e[2]),l.subtract(e[2],r,e[2]),l.clone(i,e[3]),l.subtract(e[3],s,e[3]),l.add(e[3],o,e[3]),l.add(e[3],r,e[3]),l.clone(i,e[4]),l.add(e[4],s,e[4]),l.subtract(e[4],o,e[4]),l.subtract(e[4],r,e[4]),l.clone(i,e[5]),l.add(e[5],s,e[5]),l.subtract(e[5],o,e[5]),l.add(e[5],r,e[5]),l.clone(i,e[6]),l.add(e[6],s,e[6]),l.add(e[6],o,e[6]),l.subtract(e[6],r,e[6]),l.clone(i,e[7]),l.add(e[7],s,e[7]),l.add(e[7],o,e[7]),l.add(e[7],r,e[7]),e};Trt=new lt;Bi.computeTransformation=function(t,e){p.typeOf.object("box",t),m(e)||(e=new at);let i=t.center,n=lt.multiplyByUniformScale(t.halfAxes,2,Trt);return at.fromRotationTranslation(n,i,e)};Nrt=new Nt;Bi.isOccluded=function(t,e){if(!m(t))throw new Y("box is required.");if(!m(e))throw new Y("occluder is required.");let i=Nt.fromOrientedBoundingBox(t,Nrt);return!e.isBoundingSphereVisible(i)};Bi.prototype.intersectPlane=function(t){return Bi.intersectPlane(this,t)};Bi.prototype.distanceSquaredTo=function(t){return Bi.distanceSquaredTo(this,t)};Bi.prototype.computePlaneDistances=function(t,e,i){return Bi.computePlaneDistances(this,t,e,i)};Bi.prototype.computeCorners=function(t){return Bi.computeCorners(this,t)};Bi.prototype.computeTransformation=function(t){return Bi.computeTransformation(this,t)};Bi.prototype.isOccluded=function(t){return Bi.isOccluded(this,t)};Bi.equals=function(t,e){return t===e||m(t)&&m(e)&&l.equals(t.center,e.center)&&lt.equals(t.halfAxes,e.halfAxes)};Bi.prototype.clone=function(t){return Bi.clone(this,t)};Bi.prototype.equals=function(t){return Bi.equals(this,t)};zs=Bi});var sp,Frt,A_,hF=S(()=>{Ht();ri();Ot();mt();sp={};sp.getHeight=function(t,e,i){if(!Number.isFinite(e))throw new Y("scale must be a finite number.");if(!Number.isFinite(i))throw new Y("relativeHeight must be a finite number.");return(t-i)*e+i};Frt=new ut;sp.getPosition=function(t,e,i,n,s){let o=e.cartesianToCartographic(t,Frt);if(!m(o))return l.clone(t,s);let r=sp.getHeight(o.height,i,n);return l.fromRadians(o.longitude,o.latitude,r,e,s)};A_=sp});function qm(t,e,i,n){t=Z(t,1),e=Z(e,1),i=Z(i,1),n=Z(n,1),this.value=new Uint8Array([Zt.floatToByte(t),Zt.floatToByte(e),Zt.floatToByte(i),Zt.floatToByte(n)])}var BJ,GJ=S(()=>{Qn();oi();Ft();mt();Ot();Object.defineProperties(qm.prototype,{componentDatatype:{get:function(){return At.UNSIGNED_BYTE}},componentsPerAttribute:{get:function(){return 4}},normalize:{get:function(){return!0}}});qm.fromColor=function(t){if(!m(t))throw new Y("color is required.");return new qm(t.red,t.green,t.blue,t.alpha)};qm.toValue=function(t,e){if(!m(t))throw new Y("color is required.");return m(e)?t.toBytes(e):new Uint8Array(t.toBytes())};qm.equals=function(t,e){return t===e||m(t)&&m(e)&&t.value[0]===e.value[0]&&t.value[1]===e.value[1]&&t.value[2]===e.value[2]&&t.value[3]===e.value[3]};BJ=qm});var WJ,DJ=S(()=>{WJ=`in vec3 position3DHigh;
in vec3 position3DLow;
in float batchId;

#ifdef EXTRUDED_GEOMETRY
in vec3 extrudeDirection;

uniform float u_globeMinimumAltitude;
#endif // EXTRUDED_GEOMETRY

#ifdef PER_INSTANCE_COLOR
out vec4 v_color;
#endif // PER_INSTANCE_COLOR

#ifdef TEXTURE_COORDINATES
#ifdef SPHERICAL
out vec4 v_sphericalExtents;
#else // SPHERICAL
out vec2 v_inversePlaneExtents;
out vec4 v_westPlane;
out vec4 v_southPlane;
#endif // SPHERICAL
out vec3 v_uvMinAndSphericalLongitudeRotation;
out vec3 v_uMaxAndInverseDistance;
out vec3 v_vMaxAndInverseDistance;
#endif // TEXTURE_COORDINATES

void main()
{
    vec4 position = czm_computePosition();

#ifdef EXTRUDED_GEOMETRY
    float delta = min(u_globeMinimumAltitude, czm_geometricToleranceOverMeter * length(position.xyz));
    delta *= czm_sceneMode == czm_sceneMode3D ? 1.0 : 0.0;

    //extrudeDirection is zero for the top layer
    position = position + vec4(extrudeDirection * delta, 0.0);
#endif

#ifdef TEXTURE_COORDINATES
#ifdef SPHERICAL
    v_sphericalExtents = czm_batchTable_sphericalExtents(batchId);
    v_uvMinAndSphericalLongitudeRotation.z = czm_batchTable_longitudeRotation(batchId);
#else // SPHERICAL
#ifdef COLUMBUS_VIEW_2D
    vec4 planes2D_high = czm_batchTable_planes2D_HIGH(batchId);
    vec4 planes2D_low = czm_batchTable_planes2D_LOW(batchId);

    // If the primitive is split across the IDL (planes2D_high.x > planes2D_high.w):
    // - If this vertex is on the east side of the IDL (position3DLow.y > 0.0, comparison with position3DHigh may produce artifacts)
    // - existing "east" is on the wrong side of the world, far away (planes2D_high/low.w)
    // - so set "east" as beyond the eastmost extent of the projection (idlSplitNewPlaneHiLow)
    vec2 idlSplitNewPlaneHiLow = vec2(EAST_MOST_X_HIGH - (WEST_MOST_X_HIGH - planes2D_high.w), EAST_MOST_X_LOW - (WEST_MOST_X_LOW - planes2D_low.w));
    bool idlSplit = planes2D_high.x > planes2D_high.w && position3DLow.y > 0.0;
    planes2D_high.w = czm_branchFreeTernary(idlSplit, idlSplitNewPlaneHiLow.x, planes2D_high.w);
    planes2D_low.w = czm_branchFreeTernary(idlSplit, idlSplitNewPlaneHiLow.y, planes2D_low.w);

    // - else, if this vertex is on the west side of the IDL (position3DLow.y < 0.0)
    // - existing "west" is on the wrong side of the world, far away (planes2D_high/low.x)
    // - so set "west" as beyond the westmost extent of the projection (idlSplitNewPlaneHiLow)
    idlSplit = planes2D_high.x > planes2D_high.w && position3DLow.y < 0.0;
    idlSplitNewPlaneHiLow = vec2(WEST_MOST_X_HIGH - (EAST_MOST_X_HIGH - planes2D_high.x), WEST_MOST_X_LOW - (EAST_MOST_X_LOW - planes2D_low.x));
    planes2D_high.x = czm_branchFreeTernary(idlSplit, idlSplitNewPlaneHiLow.x, planes2D_high.x);
    planes2D_low.x = czm_branchFreeTernary(idlSplit, idlSplitNewPlaneHiLow.y, planes2D_low.x);

    vec3 southWestCorner = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(vec3(0.0, planes2D_high.xy), vec3(0.0, planes2D_low.xy))).xyz;
    vec3 northWestCorner = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(vec3(0.0, planes2D_high.x, planes2D_high.z), vec3(0.0, planes2D_low.x, planes2D_low.z))).xyz;
    vec3 southEastCorner = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(vec3(0.0, planes2D_high.w, planes2D_high.y), vec3(0.0, planes2D_low.w, planes2D_low.y))).xyz;
#else // COLUMBUS_VIEW_2D
    // 3D case has smaller "plane extents," so planes encoded as a 64 bit position and 2 vec3s for distances/direction
    vec3 southWestCorner = (czm_modelViewRelativeToEye * czm_translateRelativeToEye(czm_batchTable_southWest_HIGH(batchId), czm_batchTable_southWest_LOW(batchId))).xyz;
    vec3 northWestCorner = czm_normal * czm_batchTable_northward(batchId) + southWestCorner;
    vec3 southEastCorner = czm_normal * czm_batchTable_eastward(batchId) + southWestCorner;
#endif // COLUMBUS_VIEW_2D

    vec3 eastWard = southEastCorner - southWestCorner;
    float eastExtent = length(eastWard);
    eastWard /= eastExtent;

    vec3 northWard = northWestCorner - southWestCorner;
    float northExtent = length(northWard);
    northWard /= northExtent;

    v_westPlane = vec4(eastWard, -dot(eastWard, southWestCorner));
    v_southPlane = vec4(northWard, -dot(northWard, southWestCorner));
    v_inversePlaneExtents = vec2(1.0 / eastExtent, 1.0 / northExtent);
#endif // SPHERICAL
    vec4 uvMinAndExtents = czm_batchTable_uvMinAndExtents(batchId);
    vec4 uMaxVmax = czm_batchTable_uMaxVmax(batchId);

    v_uMaxAndInverseDistance = vec3(uMaxVmax.xy, uvMinAndExtents.z);
    v_vMaxAndInverseDistance = vec3(uMaxVmax.zw, uvMinAndExtents.w);
    v_uvMinAndSphericalLongitudeRotation.xy = uvMinAndExtents.xy;
#endif // TEXTURE_COORDINATES

#ifdef PER_INSTANCE_COLOR
    v_color = czm_batchTable_color(batchId);
#endif

    gl_Position = czm_depthClamp(czm_modelViewProjectionRelativeToEye * position);
}
`});var UJ,MJ=S(()=>{UJ=`#ifdef VECTOR_TILE
uniform vec4 u_highlightColor;
#endif

void main(void)
{
#ifdef VECTOR_TILE
    out_FragColor = czm_gammaCorrect(u_highlightColor);
#else
    out_FragColor = vec4(1.0);
#endif
    czm_writeDepthClamp();
}
`});var QJ,kJ=S(()=>{QJ=`in vec3 v_positionEC;
in vec3 v_normalEC;
in vec4 v_color;

void main()
{
    vec3 positionToEyeEC = -v_positionEC;

    vec3 normalEC = normalize(v_normalEC);
#ifdef FACE_FORWARD
    normalEC = faceforward(normalEC, vec3(0.0, 0.0, 1.0), -normalEC);
#endif

    vec4 color = czm_gammaCorrect(v_color);

    czm_materialInput materialInput;
    materialInput.normalEC = normalEC;
    materialInput.positionToEyeEC = positionToEyeEC;
    czm_material material = czm_getDefaultMaterial(materialInput);
    material.diffuse = color.rgb;
    material.alpha = color.a;

    out_FragColor = czm_phong(normalize(positionToEyeEC), material, czm_lightDirectionEC);
}
`});var LJ,yJ=S(()=>{LJ=`in vec3 position3DHigh;
in vec3 position3DLow;
in vec3 normal;
in vec4 color;
in float batchId;

out vec3 v_positionEC;
out vec3 v_normalEC;
out vec4 v_color;

void main()
{
    vec4 p = czm_computePosition();

    v_positionEC = (czm_modelViewRelativeToEye * p).xyz;      // position in eye coordinates
    v_normalEC = czm_normal * normal;                         // normal in eye coordinates
    v_color = color;

    gl_Position = czm_modelViewProjectionRelativeToEye * p;
}
`});var wJ,xJ=S(()=>{wJ=`in vec3 position3DHigh;
in vec3 position3DLow;
in vec4 color;
in float batchId;

out vec4 v_color;

void main()
{
    vec4 p = czm_computePosition();

    v_color = color;

    gl_Position = czm_modelViewProjectionRelativeToEye * p;
}
`});function uh(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.translucent,!0),i=Z(t.closed,!1),n=Z(t.flat,!1),s=n?wJ:LJ,o=n?QI:QJ,r=n?uh.FLAT_VERTEX_FORMAT:uh.VERTEX_FORMAT;this.material=void 0,this.translucent=e,this._vertexShaderSource=Z(t.vertexShaderSource,s),this._fragmentShaderSource=Z(t.fragmentShaderSource,o),this._renderState=Mo.getDefaultRenderState(e,i,t.renderState),this._closed=i,this._vertexFormat=r,this._flat=n,this._faceForward=Z(t.faceForward,!i)}var Da,op=S(()=>{Ft();Ls();kJ();yJ();BN();xJ();LI();Object.defineProperties(uh.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},vertexFormat:{get:function(){return this._vertexFormat}},flat:{get:function(){return this._flat}},faceForward:{get:function(){return this._faceForward}}});uh.VERTEX_FORMAT=St.POSITION_AND_NORMAL;uh.FLAT_VERTEX_FORMAT=St.POSITION_ONLY;uh.prototype.getFragmentShaderSource=Mo.prototype.getFragmentShaderSource;uh.prototype.isTranslucent=Mo.prototype.isTranslucent;uh.prototype.getRenderState=Mo.prototype.getRenderState;Da=uh});var cF,PJ=S(()=>{cF=`#ifdef TEXTURE_COORDINATES
#ifdef SPHERICAL
in vec4 v_sphericalExtents;
#else // SPHERICAL
in vec2 v_inversePlaneExtents;
in vec4 v_westPlane;
in vec4 v_southPlane;
#endif // SPHERICAL
in vec3 v_uvMinAndSphericalLongitudeRotation;
in vec3 v_uMaxAndInverseDistance;
in vec3 v_vMaxAndInverseDistance;
#endif // TEXTURE_COORDINATES

#ifdef PER_INSTANCE_COLOR
in vec4 v_color;
#endif

#ifdef NORMAL_EC
vec3 getEyeCoordinate3FromWindowCoordinate(vec2 fragCoord, float logDepthOrDepth) {
    vec4 eyeCoordinate = czm_windowToEyeCoordinates(fragCoord, logDepthOrDepth);
    return eyeCoordinate.xyz / eyeCoordinate.w;
}

vec3 vectorFromOffset(vec4 eyeCoordinate, vec2 positiveOffset) {
    vec2 glFragCoordXY = gl_FragCoord.xy;
    // Sample depths at both offset and negative offset
    float upOrRightLogDepth = czm_unpackDepth(texture(czm_globeDepthTexture, (glFragCoordXY + positiveOffset) / czm_viewport.zw));
    float downOrLeftLogDepth = czm_unpackDepth(texture(czm_globeDepthTexture, (glFragCoordXY - positiveOffset) / czm_viewport.zw));
    // Explicitly evaluate both paths
    // Necessary for multifrustum and for edges of the screen
    bvec2 upOrRightInBounds = lessThan(glFragCoordXY + positiveOffset, czm_viewport.zw);
    float useUpOrRight = float(upOrRightLogDepth > 0.0 && upOrRightInBounds.x && upOrRightInBounds.y);
    float useDownOrLeft = float(useUpOrRight == 0.0);
    vec3 upOrRightEC = getEyeCoordinate3FromWindowCoordinate(glFragCoordXY + positiveOffset, upOrRightLogDepth);
    vec3 downOrLeftEC = getEyeCoordinate3FromWindowCoordinate(glFragCoordXY - positiveOffset, downOrLeftLogDepth);
    return (upOrRightEC - (eyeCoordinate.xyz / eyeCoordinate.w)) * useUpOrRight + ((eyeCoordinate.xyz / eyeCoordinate.w) - downOrLeftEC) * useDownOrLeft;
}
#endif // NORMAL_EC

void main(void)
{
#ifdef REQUIRES_EC
    float logDepthOrDepth = czm_unpackDepth(texture(czm_globeDepthTexture, gl_FragCoord.xy / czm_viewport.zw));
    vec4 eyeCoordinate = czm_windowToEyeCoordinates(gl_FragCoord.xy, logDepthOrDepth);
#endif

#ifdef REQUIRES_WC
    vec4 worldCoordinate4 = czm_inverseView * eyeCoordinate;
    vec3 worldCoordinate = worldCoordinate4.xyz / worldCoordinate4.w;
#endif

#ifdef TEXTURE_COORDINATES
    vec2 uv;
#ifdef SPHERICAL
    // Treat world coords as a sphere normal for spherical coordinates
    vec2 sphericalLatLong = czm_approximateSphericalCoordinates(worldCoordinate);
    sphericalLatLong.y += v_uvMinAndSphericalLongitudeRotation.z;
    sphericalLatLong.y = czm_branchFreeTernary(sphericalLatLong.y < czm_pi, sphericalLatLong.y, sphericalLatLong.y - czm_twoPi);
    uv.x = (sphericalLatLong.y - v_sphericalExtents.y) * v_sphericalExtents.w;
    uv.y = (sphericalLatLong.x - v_sphericalExtents.x) * v_sphericalExtents.z;
#else // SPHERICAL
    // Unpack planes and transform to eye space
    uv.x = czm_planeDistance(v_westPlane, eyeCoordinate.xyz / eyeCoordinate.w) * v_inversePlaneExtents.x;
    uv.y = czm_planeDistance(v_southPlane, eyeCoordinate.xyz / eyeCoordinate.w) * v_inversePlaneExtents.y;
#endif // SPHERICAL
#endif // TEXTURE_COORDINATES

#ifdef PICK
#ifdef CULL_FRAGMENTS
    // When classifying translucent geometry, logDepthOrDepth == 0.0
    // indicates a region that should not be classified, possibly due to there
    // being opaque pixels there in another buffer.
    // Check for logDepthOrDepth != 0.0 to make sure this should be classified.
    if (0.0 <= uv.x && uv.x <= 1.0 && 0.0 <= uv.y && uv.y <= 1.0 || logDepthOrDepth != 0.0) {
        out_FragColor.a = 1.0; // 0.0 alpha leads to discard from ShaderSource.createPickFragmentShaderSource
        czm_writeDepthClamp();
    }
#else // CULL_FRAGMENTS
        out_FragColor.a = 1.0;
#endif // CULL_FRAGMENTS
#else // PICK

#ifdef CULL_FRAGMENTS
    // When classifying translucent geometry, logDepthOrDepth == 0.0
    // indicates a region that should not be classified, possibly due to there
    // being opaque pixels there in another buffer.
    if (uv.x <= 0.0 || 1.0 <= uv.x || uv.y <= 0.0 || 1.0 <= uv.y || logDepthOrDepth == 0.0) {
        discard;
    }
#endif

#ifdef NORMAL_EC
    // Compute normal by sampling adjacent pixels in 2x2 block in screen space
    vec3 downUp = vectorFromOffset(eyeCoordinate, vec2(0.0, 1.0));
    vec3 leftRight = vectorFromOffset(eyeCoordinate, vec2(1.0, 0.0));
    vec3 normalEC = normalize(cross(leftRight, downUp));
#endif


#ifdef PER_INSTANCE_COLOR

    vec4 color = czm_gammaCorrect(v_color);
#ifdef FLAT
    out_FragColor = color;
#else // FLAT
    czm_materialInput materialInput;
    materialInput.normalEC = normalEC;
    materialInput.positionToEyeEC = -eyeCoordinate.xyz;
    czm_material material = czm_getDefaultMaterial(materialInput);
    material.diffuse = color.rgb;
    material.alpha = color.a;

    out_FragColor = czm_phong(normalize(-eyeCoordinate.xyz), material, czm_lightDirectionEC);
#endif // FLAT

    // Premultiply alpha. Required for classification primitives on translucent globe.
    out_FragColor.rgb *= out_FragColor.a;

#else // PER_INSTANCE_COLOR

    // Material support.
    // USES_ is distinct from REQUIRES_, because some things are dependencies of each other or
    // dependencies for culling but might not actually be used by the material.

    czm_materialInput materialInput;

#ifdef USES_NORMAL_EC
    materialInput.normalEC = normalEC;
#endif

#ifdef USES_POSITION_TO_EYE_EC
    materialInput.positionToEyeEC = -eyeCoordinate.xyz;
#endif

#ifdef USES_TANGENT_TO_EYE
    materialInput.tangentToEyeMatrix = czm_eastNorthUpToEyeCoordinates(worldCoordinate, normalEC);
#endif

#ifdef USES_ST
    // Remap texture coordinates from computed (approximately aligned with cartographic space) to the desired
    // texture coordinate system, which typically forms a tight oriented bounding box around the geometry.
    // Shader is provided a set of reference points for remapping.
    materialInput.st.x = czm_lineDistance(v_uvMinAndSphericalLongitudeRotation.xy, v_uMaxAndInverseDistance.xy, uv) * v_uMaxAndInverseDistance.z;
    materialInput.st.y = czm_lineDistance(v_uvMinAndSphericalLongitudeRotation.xy, v_vMaxAndInverseDistance.xy, uv) * v_vMaxAndInverseDistance.z;
#endif

    czm_material material = czm_getMaterial(materialInput);

#ifdef FLAT
    out_FragColor = vec4(material.diffuse + material.emission, material.alpha);
#else // FLAT
    out_FragColor = czm_phong(normalize(-eyeCoordinate.xyz), material, czm_lightDirectionEC);
#endif // FLAT

    // Premultiply alpha. Required for classification primitives on translucent globe.
    out_FragColor.rgb *= out_FragColor.a;

#endif // PER_INSTANCE_COLOR
    czm_writeDepthClamp();
#endif // PICK
}
`});function vr(t,e,i){p.typeOf.bool("extentsCulling",t),p.typeOf.bool("planarExtents",e),p.typeOf.object("appearance",i),this._projectionExtentDefines={eastMostYhighDefine:"",eastMostYlowDefine:"",westMostYhighDefine:"",westMostYlowDefine:""};let n=new lF;n.requiresTextureCoordinates=t,n.requiresEC=!i.flat;let s=new lF;if(s.requiresTextureCoordinates=t,i instanceof Da)n.requiresNormalEC=!i.flat;else{let o=`${i.material.shaderSource}
${i.fragmentShaderSource}`;n.normalEC=o.indexOf("materialInput.normalEC")!==-1||o.indexOf("czm_getDefaultMaterial")!==-1,n.positionToEyeEC=o.indexOf("materialInput.positionToEyeEC")!==-1,n.tangentToEyeMatrix=o.indexOf("materialInput.tangentToEyeMatrix")!==-1,n.st=o.indexOf("materialInput.st")!==-1}this._colorShaderDependencies=n,this._pickShaderDependencies=s,this._appearance=i,this._extentsCulling=t,this._planarExtents=e}function qJ(t,e,i,n,s,o,r,a){let h=n.slice();if(a.eastMostYhighDefine===""){let A=jJ;A.longitude=L.PI,A.latitude=0,A.height=0;let d=r.project(A,JJ),f=Gn.encode(d.x,HJ);a.eastMostYhighDefine=`EAST_MOST_X_HIGH ${f.high.toFixed(`${f.high}`.length+1)}`,a.eastMostYlowDefine=`EAST_MOST_X_LOW ${f.low.toFixed(`${f.low}`.length+1)}`;let E=jJ;E.longitude=-L.PI,E.latitude=0,E.height=0;let _=r.project(E,JJ);f=Gn.encode(_.x,HJ),a.westMostYhighDefine=`WEST_MOST_X_HIGH ${f.high.toFixed(`${f.high}`.length+1)}`,a.westMostYlowDefine=`WEST_MOST_X_LOW ${f.low.toFixed(`${f.low}`.length+1)}`}return i&&(h.push(a.eastMostYhighDefine),h.push(a.eastMostYlowDefine),h.push(a.westMostYhighDefine),h.push(a.westMostYlowDefine)),m(o)&&o instanceof Da&&h.push("PER_INSTANCE_COLOR"),t.requiresTextureCoordinates&&(h.push("TEXTURE_COORDINATES"),e||i||h.push("SPHERICAL"),i&&h.push("COLUMBUS_VIEW_2D")),new Ui({defines:h,sources:[s]})}function lF(){this._requiresEC=!1,this._requiresWC=!1,this._requiresNormalEC=!1,this._requiresTextureCoordinates=!1,this._usesNormalEC=!1,this._usesPositionToEyeEC=!1,this._usesTangentToEyeMat=!1,this._usesSt=!1}function vJ(t,e,i){return Math.abs((e.y-t.y)*i.x-(e.x-t.x)*i.y+e.x*t.y-e.y*t.x)/nt.distance(e,t)}function $J(t,e){let i=brt,n=nt.unpack(e,0,i[0]),s=nt.unpack(e,2,i[1]),o=nt.unpack(e,4,i[2]);t.uMaxVmax=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,value:[s.x,s.y,o.x,o.y]});let r=1/vJ(n,s,o),a=1/vJ(n,o,s);t.uvMinAndExtents=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,value:[n.x,n.y,r,a]})}function ij(t,e,i){let n=tj;n.height=0,n.longitude=t.west,n.latitude=t.south;let s=e.project(n,ej);n.latitude=t.north;let o=e.project(n,Yrt);n.longitude=t.east,n.latitude=t.south;let r=e.project(n,Vrt),a=[0,0,0,0],h=[0,0,0,0],A=Gn.encode(s.x,rp);a[0]=A.high,h[0]=A.low,A=Gn.encode(s.y,rp),a[1]=A.high,h[1]=A.low,A=Gn.encode(o.y,rp),a[2]=A.high,h[2]=A.low,A=Gn.encode(r.x,rp),a[3]=A.high,h[3]=A.low,i.planes2D_HIGH=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,value:a}),i.planes2D_LOW=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,value:h})}function Wrt(t,e,i,n,s,o){let r=Xt.center(t,Brt);r.height=i;let a=ut.toCartesian(r,e,zJ),h=In.eastNorthUpToFixedFrame(a,e,Srt),A=at.inverse(h,Ort),d=t.west,f=t.east,E=t.north,_=t.south,R=Grt;R[0].latitude=_,R[0].longitude=d,R[1].latitude=E,R[1].longitude=d,R[2].latitude=E,R[2].longitude=f,R[3].latitude=_,R[3].longitude=f;let I=(d+f)*.5,C=(E+_)*.5;R[4].latitude=_,R[4].longitude=I,R[5].latitude=E,R[5].longitude=I,R[6].latitude=C,R[6].longitude=d,R[7].latitude=C,R[7].longitude=f;let N=Number.POSITIVE_INFINITY,T=Number.NEGATIVE_INFINITY,b=Number.POSITIVE_INFINITY,F=Number.NEGATIVE_INFINITY;for(let M=0;M<8;M++){R[M].height=i;let k=ut.toCartesian(R[M],e,zJ);at.multiplyByPoint(A,k,k),k.z=0,N=Math.min(N,k.x),T=Math.max(T,k.x),b=Math.min(b,k.y),F=Math.max(F,k.y)}let B=n;B.x=N,B.y=b,B.z=0,at.multiplyByPoint(h,B,B);let U=s;U.x=T,U.y=b,U.z=0,at.multiplyByPoint(h,U,U),l.subtract(U,B,s);let Q=o;Q.x=N,Q.y=F,Q.z=0,at.multiplyByPoint(h,Q,Q),l.subtract(Q,B,o)}function KJ(t,e,i,n){let s=tj;s.latitude=t,s.longitude=e,s.height=0;let o=ut.toCartesian(s,i,Qrt),r=Math.sqrt(o.x*o.x+o.y*o.y),a=L.fastApproximateAtan2(r,o.z),h=L.fastApproximateAtan2(o.x,o.y);return n.x=a,n.y=h,n}function krt(t){return Math.max(t.width,t.height)>vr.MAX_WIDTH_FOR_PLANAR_EXTENTS}var JJ,jJ,HJ,brt,tj,ej,Yrt,Vrt,rp,Srt,Ort,zJ,Brt,Grt,Drt,Urt,Mrt,Qrt,XJ,gc,dF=S(()=>{Xe();Ht();ri();ae();oi();Ft();mt();Tl();mN();_e();bi();pn();fr();bl();op();PJ();vr.prototype.createFragmentShader=function(t){p.typeOf.bool("columbusView2D",t);let e=this._appearance,i=this._colorShaderDependencies,n=[];!t&&!this._planarExtents&&n.push("SPHERICAL"),i.requiresEC&&n.push("REQUIRES_EC"),i.requiresWC&&n.push("REQUIRES_WC"),i.requiresTextureCoordinates&&n.push("TEXTURE_COORDINATES"),this._extentsCulling&&n.push("CULL_FRAGMENTS"),i.requiresNormalEC&&n.push("NORMAL_EC"),e instanceof Da&&n.push("PER_INSTANCE_COLOR"),i.normalEC&&n.push("USES_NORMAL_EC"),i.positionToEyeEC&&n.push("USES_POSITION_TO_EYE_EC"),i.tangentToEyeMatrix&&n.push("USES_TANGENT_TO_EYE"),i.st&&n.push("USES_ST"),e.flat&&n.push("FLAT");let s="";return e instanceof Da||(s=e.material.shaderSource),new Ui({defines:n,sources:[s,cF]})};vr.prototype.createPickFragmentShader=function(t){p.typeOf.bool("columbusView2D",t);let e=this._pickShaderDependencies,i=["PICK"];return!t&&!this._planarExtents&&i.push("SPHERICAL"),e.requiresEC&&i.push("REQUIRES_EC"),e.requiresWC&&i.push("REQUIRES_WC"),e.requiresTextureCoordinates&&i.push("TEXTURE_COORDINATES"),this._extentsCulling&&i.push("CULL_FRAGMENTS"),new Ui({defines:i,sources:[cF],pickColorQualifier:"in"})};vr.prototype.createVertexShader=function(t,e,i,n){return p.defined("defines",t),p.typeOf.string("vertexShaderSource",e),p.typeOf.bool("columbusView2D",i),p.defined("mapProjection",n),qJ(this._colorShaderDependencies,this._planarExtents,i,t,e,this._appearance,n,this._projectionExtentDefines)};vr.prototype.createPickVertexShader=function(t,e,i,n){return p.defined("defines",t),p.typeOf.string("vertexShaderSource",e),p.typeOf.bool("columbusView2D",i),p.defined("mapProjection",n),qJ(this._pickShaderDependencies,this._planarExtents,i,t,e,void 0,n,this._projectionExtentDefines)};JJ=new l,jJ=new ut,HJ={high:0,low:0};Object.defineProperties(lF.prototype,{requiresEC:{get:function(){return this._requiresEC},set:function(t){this._requiresEC=t||this._requiresEC}},requiresWC:{get:function(){return this._requiresWC},set:function(t){this._requiresWC=t||this._requiresWC,this.requiresEC=this._requiresWC}},requiresNormalEC:{get:function(){return this._requiresNormalEC},set:function(t){this._requiresNormalEC=t||this._requiresNormalEC,this.requiresEC=this._requiresNormalEC}},requiresTextureCoordinates:{get:function(){return this._requiresTextureCoordinates},set:function(t){this._requiresTextureCoordinates=t||this._requiresTextureCoordinates,this.requiresWC=this._requiresTextureCoordinates}},normalEC:{set:function(t){this.requiresNormalEC=t,this._usesNormalEC=t},get:function(){return this._usesNormalEC}},tangentToEyeMatrix:{set:function(t){this.requiresWC=t,this.requiresNormalEC=t,this._usesTangentToEyeMat=t},get:function(){return this._usesTangentToEyeMat}},positionToEyeEC:{set:function(t){this.requiresEC=t,this._usesPositionToEyeEC=t},get:function(){return this._usesPositionToEyeEC}},st:{set:function(t){this.requiresTextureCoordinates=t,this._usesSt=t},get:function(){return this._usesSt}}});brt=[new nt,new nt,new nt,new nt];tj=new ut,ej=new l,Yrt=new l,Vrt=new l,rp={high:0,low:0};Srt=new at,Ort=new at,zJ=new l,Brt=new ut,Grt=[new ut,new ut,new ut,new ut,new ut,new ut,new ut,new ut];Drt=new l,Urt=new l,Mrt=new Gn;vr.getPlanarTextureCoordinateAttributes=function(t,e,i,n,s){p.typeOf.object("boundingRectangle",t),p.defined("textureCoordinateRotationPoints",e),p.typeOf.object("ellipsoid",i),p.typeOf.object("projection",n);let o=ej,r=Drt,a=Urt;Wrt(t,i,Z(s,0),o,r,a);let h={};$J(h,e);let A=Gn.fromCartesian(o,Mrt);return h.southWest_HIGH=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:3,normalize:!1,value:l.pack(A.high,[0,0,0])}),h.southWest_LOW=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:3,normalize:!1,value:l.pack(A.low,[0,0,0])}),h.eastward=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:3,normalize:!1,value:l.pack(r,[0,0,0])}),h.northward=new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:3,normalize:!1,value:l.pack(a,[0,0,0])}),ij(t,n,h),h};Qrt=new l;XJ=new nt;vr.getSphericalExtentGeometryInstanceAttributes=function(t,e,i,n){p.typeOf.object("boundingRectangle",t),p.defined("textureCoordinateRotationPoints",e),p.typeOf.object("ellipsoid",i),p.typeOf.object("projection",n);let s=KJ(t.south,t.west,i,XJ),o=s.x,r=s.y,a=KJ(t.north,t.east,i,XJ),h=a.x,A=a.y,d=0;r>A&&(d=L.PI-r,r=-L.PI,A+=d),o-=L.EPSILON5,r-=L.EPSILON5,h+=L.EPSILON5,A+=L.EPSILON5;let f=1/(A-r),E=1/(h-o),_={sphericalExtents:new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:4,normalize:!1,value:[o,r,E,f]}),longitudeRotation:new Zr({componentDatatype:At.FLOAT,componentsPerAttribute:1,normalize:!1,value:[d]})};return $J(_,e),ij(t,n,_),_};vr.hasAttributesForTextureCoordinatePlanes=function(t){return m(t.southWest_HIGH)&&m(t.southWest_LOW)&&m(t.northward)&&m(t.eastward)&&m(t.planes2D_HIGH)&&m(t.planes2D_LOW)&&m(t.uMaxVmax)&&m(t.uvMinAndExtents)};vr.hasAttributesForSphericalExtents=function(t){return m(t.sphericalExtents)&&m(t.longitudeRotation)&&m(t.planes2D_HIGH)&&m(t.planes2D_LOW)&&m(t.uMaxVmax)&&m(t.uvMinAndExtents)};vr.shouldUseSphericalCoordinates=function(t){return p.typeOf.object("rectangle",t),krt(t)};vr.MAX_WIDTH_FOR_PLANAR_EXTENTS=L.toRadians(1);gc=vr});function jl(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.geometryInstances;this.geometryInstances=e,this.show=Z(t.show,!0),this.classificationType=Z(t.classificationType,Jr.BOTH),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.debugShowShadowVolume=Z(t.debugShowShadowVolume,!1),this._debugShowShadowVolume=!1,this._extruded=Z(t._extruded,!1),this._uniformMap=t._uniformMap,this._sp=void 0,this._spStencil=void 0,this._spPick=void 0,this._spColor=void 0,this._spPick2D=void 0,this._spColor2D=void 0,this._rsStencilDepthPass=void 0,this._rsStencilDepthPass3DTiles=void 0,this._rsColorPass=void 0,this._rsPickPass=void 0,this._commandsIgnoreShow=[],this._ready=!1,this._primitive=void 0,this._pickPrimitive=t._pickPrimitive,this._hasSphericalExtentsAttribute=!1,this._hasPlanarExtentsAttributes=!1,this._hasPerColorAttribute=!1,this.appearance=t.appearance,this._createBoundingVolumeFunction=t._createBoundingVolumeFunction,this._updateAndQueueCommandsFunction=t._updateAndQueueCommandsFunction,this._usePickOffsets=!1,this._primitiveOptions={geometryInstances:void 0,appearance:void 0,vertexCacheOptimize:Z(t.vertexCacheOptimize,!1),interleave:Z(t.interleave,!1),releaseGeometryInstances:Z(t.releaseGeometryInstances,!0),allowPicking:Z(t.allowPicking,!0),asynchronous:Z(t.asynchronous,!0),compressVertices:Z(t.compressVertices,!0),_createBoundingVolumeFunction:void 0,_createRenderStatesFunction:void 0,_createShaderProgramFunction:void 0,_createCommandsFunction:void 0,_updateAndQueueCommandsFunction:void 0,_createPickOffsets:!0}}function $m(t,e){let i=e?pr.EQUAL:pr.ALWAYS;return{colorMask:{red:!1,green:!1,blue:!1,alpha:!1},stencilTest:{enabled:t,frontFunction:i,frontOperation:{fail:Hi.KEEP,zFail:Hi.DECREMENT_WRAP,zPass:Hi.KEEP},backFunction:i,backOperation:{fail:Hi.KEEP,zFail:Hi.INCREMENT_WRAP,zPass:Hi.KEEP},reference:Wa.CESIUM_3D_TILE_MASK,mask:Wa.CESIUM_3D_TILE_MASK},stencilMask:Wa.CLASSIFICATION_MASK,depthTest:{enabled:!0,func:wI.LESS_OR_EQUAL},depthMask:!1}}function fF(t){return{stencilTest:{enabled:t,frontFunction:pr.NOT_EQUAL,frontOperation:{fail:Hi.ZERO,zFail:Hi.ZERO,zPass:Hi.ZERO},backFunction:pr.NOT_EQUAL,backOperation:{fail:Hi.ZERO,zFail:Hi.ZERO,zPass:Hi.ZERO},reference:0,mask:Wa.CLASSIFICATION_MASK},stencilMask:Wa.CLASSIFICATION_MASK,depthTest:{enabled:!1},depthMask:!1,blending:Mr.PRE_MULTIPLIED_ALPHA_BLEND}}function yrt(t,e,i,n){if(m(t._rsStencilDepthPass))return;let s=!t.debugShowShadowVolume;t._rsStencilDepthPass=Yn.fromCache($m(s,!1)),t._rsStencilDepthPass3DTiles=Yn.fromCache($m(s,!0)),t._rsColorPass=Yn.fromCache(fF(s,!1)),t._rsPickPass=Yn.fromCache(Lrt)}function wrt(t,e){if(!t.compressVertices)return e;if(e.search(/in\s+vec3\s+extrudeDirection;/g)!==-1){let i="compressedAttributes",n=`in vec2 ${i};`,s=`vec3 extrudeDirection;
`,o=`    extrudeDirection = czm_octDecode(${i}, 65535.0);
`,r=e;r=r.replace(/in\s+vec3\s+extrudeDirection;/g,""),r=Ui.replaceMain(r,"czm_non_compressed_main");let a=`void main() 
{ 
${o}    czm_non_compressed_main(); 
}`;return[n,s,r,a].join(`
`)}}function xrt(t,e){let i=e.context,n=t._primitive,s=WJ;s=t._primitive._batchTable.getVertexShaderCallback()(s),s=vs._appendDistanceDisplayConditionToShader(n,s),s=vs._modifyShaderPosition(t,s,e.scene3DOnly),s=vs._updateColorAttribute(n,s);let o=t._hasPlanarExtentsAttributes,r=o||t._hasSphericalExtentsAttribute;t._extruded&&(s=wrt(n,s));let a=t._extruded?"EXTRUDED_GEOMETRY":"",h=new Ui({defines:[a],sources:[s]}),A=new Ui({sources:[UJ]}),d=t._primitive._attributeLocations,f=new gc(r,o,t.appearance);if(t._spStencil=Es.replaceCache({context:i,shaderProgram:t._spStencil,vertexShaderSource:h,fragmentShaderSource:A,attributeLocations:d}),t._primitive.allowPicking){let R=Ui.createPickVertexShaderSource(s);R=vs._appendShowToShader(n,R),R=vs._updatePickColorAttribute(R);let I=f.createPickFragmentShader(!1),C=f.createPickVertexShader([a],R,!1,e.mapProjection);if(t._spPick=Es.replaceCache({context:i,shaderProgram:t._spPick,vertexShaderSource:C,fragmentShaderSource:I,attributeLocations:d}),r){let N=i.shaderCache.getDerivedShaderProgram(t._spPick,"2dPick");if(!m(N)){let T=f.createPickFragmentShader(!0),b=f.createPickVertexShader([a],R,!0,e.mapProjection);N=i.shaderCache.createDerivedShaderProgram(t._spPick,"2dPick",{vertexShaderSource:b,fragmentShaderSource:T,attributeLocations:d})}t._spPick2D=N}}else t._spPick=Es.fromCache({context:i,vertexShaderSource:h,fragmentShaderSource:A,attributeLocations:d});s=vs._appendShowToShader(n,s),h=new Ui({defines:[a],sources:[s]}),t._sp=Es.replaceCache({context:i,shaderProgram:t._sp,vertexShaderSource:h,fragmentShaderSource:A,attributeLocations:d});let E=f.createFragmentShader(!1),_=f.createVertexShader([a],s,!1,e.mapProjection);if(t._spColor=Es.replaceCache({context:i,shaderProgram:t._spColor,vertexShaderSource:_,fragmentShaderSource:E,attributeLocations:d}),r){let R=i.shaderCache.getDerivedShaderProgram(t._spColor,"2dColor");if(!m(R)){let I=f.createFragmentShader(!0),C=f.createVertexShader([a],s,!0,e.mapProjection);R=i.shaderCache.createDerivedShaderProgram(t._spColor,"2dColor",{vertexShaderSource:C,fragmentShaderSource:I,attributeLocations:d})}t._spColor2D=R}}function Prt(t,e){let i=t._primitive,n=i._va.length*2;e.length=n;let s,o,r,a=0,h=i._batchTable.getUniformMapCallback()(t._uniformMap),A=t._needs2DShader;for(s=0;s<n;s+=2){let _=i._va[a++];o=e[s],m(o)||(o=e[s]=new fn({owner:t,primitiveType:i._primitiveType})),o.vertexArray=_,o.renderState=t._rsStencilDepthPass,o.shaderProgram=t._sp,o.uniformMap=h,o.pass=os.TERRAIN_CLASSIFICATION,r=fn.shallowClone(o,o.derivedCommands.tileset),r.renderState=t._rsStencilDepthPass3DTiles,r.pass=os.CESIUM_3D_TILE_CLASSIFICATION,o.derivedCommands.tileset=r,o=e[s+1],m(o)||(o=e[s+1]=new fn({owner:t,primitiveType:i._primitiveType})),o.vertexArray=_,o.renderState=t._rsColorPass,o.shaderProgram=t._spColor,o.pass=os.TERRAIN_CLASSIFICATION;let I=t.appearance.material;if(m(I)&&(h=es(h,I._uniforms)),o.uniformMap=h,r=fn.shallowClone(o,o.derivedCommands.tileset),r.pass=os.CESIUM_3D_TILE_CLASSIFICATION,o.derivedCommands.tileset=r,A){let C=fn.shallowClone(o,o.derivedCommands.appearance2D);C.shaderProgram=t._spColor2D,o.derivedCommands.appearance2D=C,C=fn.shallowClone(r,r.derivedCommands.appearance2D),C.shaderProgram=t._spColor2D,r.derivedCommands.appearance2D=C}}let d=t._commandsIgnoreShow,f=t._spStencil,E=0;n=d.length=n/2;for(let _=0;_<n;++_){let R=d[_]=fn.shallowClone(e[E],d[_]);R.shaderProgram=f,R.pass=os.CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW,E+=2}}function Jrt(t,e){let i=t._usePickOffsets,n=t._primitive,s=n._va.length*2,o,r=0,a;i&&(o=n._pickOffsets,s=o.length*2),e.length=s;let h,A,d,f=0,E=n._batchTable.getUniformMapCallback()(t._uniformMap),_=t._needs2DShader;for(h=0;h<s;h+=2){let R=n._va[f++];if(i&&(a=o[r++],R=n._va[a.index]),A=e[h],m(A)||(A=e[h]=new fn({owner:t,primitiveType:n._primitiveType,pickOnly:!0})),A.vertexArray=R,A.renderState=t._rsStencilDepthPass,A.shaderProgram=t._sp,A.uniformMap=E,A.pass=os.TERRAIN_CLASSIFICATION,i&&(A.offset=a.offset,A.count=a.count),d=fn.shallowClone(A,A.derivedCommands.tileset),d.renderState=t._rsStencilDepthPass3DTiles,d.pass=os.CESIUM_3D_TILE_CLASSIFICATION,A.derivedCommands.tileset=d,A=e[h+1],m(A)||(A=e[h+1]=new fn({owner:t,primitiveType:n._primitiveType,pickOnly:!0})),A.vertexArray=R,A.renderState=t._rsPickPass,A.shaderProgram=t._spPick,A.uniformMap=E,A.pass=os.TERRAIN_CLASSIFICATION,i&&(A.offset=a.offset,A.count=a.count),d=fn.shallowClone(A,A.derivedCommands.tileset),d.pass=os.CESIUM_3D_TILE_CLASSIFICATION,A.derivedCommands.tileset=d,_){let I=fn.shallowClone(A,A.derivedCommands.pick2D);I.shaderProgram=t._spPick2D,A.derivedCommands.pick2D=I,I=fn.shallowClone(d,d.derivedCommands.pick2D),I.shaderProgram=t._spPick2D,d.derivedCommands.pick2D=I}}}function jrt(t,e,i,n,s,o,r){Prt(t,o),Jrt(t,r)}function nj(t,e){return Math.floor(t%e/2)}function mF(t,e,i,n,s,o){t.modelMatrix=i,t.boundingVolume=s,t.cull=n,t.debugShowBoundingVolume=o,e.commandList.push(t)}function sj(t,e,i,n,s){t.modelMatrix=i,t.boundingVolume=s,t.cull=n,e.commandList.push(t)}function Hrt(t,e,i,n,s,o,r,a){let h=t._primitive;vs._updateBoundingVolumes(h,e,s);let A;e.mode===ye.SCENE3D?A=h._boundingSphereWC:e.mode===ye.COLUMBUS_VIEW?A=h._boundingSphereCV:e.mode===ye.SCENE2D&&m(h._boundingSphere2D)?A=h._boundingSphere2D:m(h._boundingSphereMorph)&&(A=h._boundingSphereMorph);let d=t.classificationType,f=d!==Jr.CESIUM_3D_TILE,E=d!==Jr.TERRAIN,_=e.passes,R,I,C;if(_.render){let N=i.length;for(R=0;R<N;++R)I=A[nj(R,N)],f&&(C=i[R],mF(C,e,s,o,I,r)),E&&(C=i[R].derivedCommands.tileset,mF(C,e,s,o,I,r));if(e.invertClassification){let T=t._commandsIgnoreShow,b=T.length;for(R=0;R<b;++R)I=A[R],C=T[R],mF(C,e,s,o,I,r)}}if(_.pick){let N=n.length,T=h._pickOffsets;for(R=0;R<N;++R){let b=T[nj(R,N)];I=A[b.index],f&&(C=n[R],sj(C,e,s,o,I)),E&&(C=n[R].derivedCommands.tileset,sj(C,e,s,o,I))}}}var Lrt,EF,oj=S(()=>{GJ();KA();Ft();mt();Ws();Ot();uA();Gm();Wm();Um();Qm();bl();DJ();MJ();km();UI();PN();op();rF();ua();dF();aF();$I();tp();Object.defineProperties(jl.prototype,{vertexCacheOptimize:{get:function(){return this._primitiveOptions.vertexCacheOptimize}},interleave:{get:function(){return this._primitiveOptions.interleave}},releaseGeometryInstances:{get:function(){return this._primitiveOptions.releaseGeometryInstances}},allowPicking:{get:function(){return this._primitiveOptions.allowPicking}},asynchronous:{get:function(){return this._primitiveOptions.asynchronous}},compressVertices:{get:function(){return this._primitiveOptions.compressVertices}},ready:{get:function(){return this._ready}},_needs2DShader:{get:function(){return this._hasPlanarExtentsAttributes||this._hasSphericalExtentsAttribute}}});jl.isSupported=function(t){return t.context.stencilBuffer};Lrt={stencilTest:{enabled:!0,frontFunction:pr.NOT_EQUAL,frontOperation:{fail:Hi.ZERO,zFail:Hi.ZERO,zPass:Hi.ZERO},backFunction:pr.NOT_EQUAL,backOperation:{fail:Hi.ZERO,zFail:Hi.ZERO,zPass:Hi.ZERO},reference:0,mask:Wa.CLASSIFICATION_MASK},stencilMask:Wa.CLASSIFICATION_MASK,depthTest:{enabled:!1},depthMask:!1};jl.prototype.update=function(t){if(!m(this._primitive)&&!m(this.geometryInstances))return;let e=this.appearance;m(e)&&m(e.material)&&e.material.update(t.context);let i=this,n=this._primitiveOptions;if(!m(this._primitive)){let s=Array.isArray(this.geometryInstances)?this.geometryInstances:[this.geometryInstances],o=s.length,r,a,h,A=!1,d=!0,f,E=!1,_=!1;for(o>0&&(h=s[0].attributes,E=gc.hasAttributesForSphericalExtents(h),_=gc.hasAttributesForTextureCoordinatePlanes(h),f=h.color),r=0;r<o;r++){a=s[r];let I=a.attributes.color;if(m(I))A=!0;else if(A)throw new Y("All GeometryInstances must have color attributes to use per-instance color.");d=d&&m(I)&&BJ.equals(f,I)}if(!d&&!E&&!_)throw new Y("All GeometryInstances must have the same color attribute except via GroundPrimitives");if(A&&!m(e)&&(e=new Da({flat:!0}),this.appearance=e),!A&&e instanceof Da)throw new Y("PerInstanceColorAppearance requires color GeometryInstanceAttributes on all GeometryInstances");if(m(e.material)&&!E&&!_)throw new Y("Materials on ClassificationPrimitives are not supported except via GroundPrimitives");this._usePickOffsets=!E&&!_,this._hasSphericalExtentsAttribute=E,this._hasPlanarExtentsAttributes=_,this._hasPerColorAttribute=A;let R=new Array(o);for(r=0;r<o;++r)a=s[r],R[r]=new Ln({geometry:a.geometry,attributes:a.attributes,modelMatrix:a.modelMatrix,id:a.id,pickPrimitive:Z(this._pickPrimitive,i)});n.appearance=e,n.geometryInstances=R,m(this._createBoundingVolumeFunction)&&(n._createBoundingVolumeFunction=function(I,C){i._createBoundingVolumeFunction(I,C)}),n._createRenderStatesFunction=function(I,C,N,T){yrt(i,C)},n._createShaderProgramFunction=function(I,C,N){xrt(i,C)},n._createCommandsFunction=function(I,C,N,T,b,F,B){jrt(i,void 0,void 0,!0,!1,F,B)},m(this._updateAndQueueCommandsFunction)?n._updateAndQueueCommandsFunction=function(I,C,N,T,b,F,B,U){i._updateAndQueueCommandsFunction(I,C,N,T,b,F,B,U)}:n._updateAndQueueCommandsFunction=function(I,C,N,T,b,F,B,U){Hrt(i,C,N,T,b,F,B,U)},this._primitive=new vs(n)}if(this.debugShowShadowVolume&&!this._debugShowShadowVolume&&this._ready?(this._debugShowShadowVolume=!0,this._rsStencilDepthPass=Yn.fromCache($m(!1,!1)),this._rsStencilDepthPass3DTiles=Yn.fromCache($m(!1,!0)),this._rsColorPass=Yn.fromCache(fF(!1))):!this.debugShowShadowVolume&&this._debugShowShadowVolume&&(this._debugShowShadowVolume=!1,this._rsStencilDepthPass=Yn.fromCache($m(!0,!1)),this._rsStencilDepthPass3DTiles=Yn.fromCache($m(!0,!0)),this._rsColorPass=Yn.fromCache(fF(!0))),this._primitive.appearance!==e){if(!this._hasSphericalExtentsAttribute&&!this._hasPlanarExtentsAttributes&&m(e.material))throw new Y("Materials on ClassificationPrimitives are not supported except via GroundPrimitive");if(!this._hasPerColorAttribute&&e instanceof Da)throw new Y("PerInstanceColorAppearance requires color GeometryInstanceAttribute");this._primitive.appearance=e}this._primitive.show=this.show,this._primitive.debugShowBoundingVolume=this.debugShowBoundingVolume,this._primitive.update(t),t.afterRender.push(()=>{m(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};jl.prototype.getGeometryInstanceAttributes=function(t){if(!m(this._primitive))throw new Y("must call update before calling getGeometryInstanceAttributes");return this._primitive.getGeometryInstanceAttributes(t)};jl.prototype.isDestroyed=function(){return!1};jl.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),this._sp=this._sp&&this._sp.destroy(),this._spPick=this._spPick&&this._spPick.destroy(),this._spColor=this._spColor&&this._spColor.destroy(),this._spPick2D=void 0,this._spColor2D=void 0,li(this)};EF=jl});function nr(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.appearance,i=t.geometryInstances;if(!m(e)&&m(i)){let s=Array.isArray(i)?i:[i],o=s.length;for(let r=0;r<o;r++){let a=s[r].attributes;if(m(a)&&m(a.color)){e=new Da({flat:!0});break}}}this.appearance=e,this.geometryInstances=t.geometryInstances,this.show=Z(t.show,!0),this.classificationType=Z(t.classificationType,Jr.BOTH),this.debugShowBoundingVolume=Z(t.debugShowBoundingVolume,!1),this.debugShowShadowVolume=Z(t.debugShowShadowVolume,!1),this._boundingVolumes=[],this._boundingVolumes2D=[],this._ready=!1,this._primitive=void 0,this._maxHeight=void 0,this._minHeight=void 0,this._maxTerrainHeight=Do._defaultMaxTerrainHeight,this._minTerrainHeight=Do._defaultMinTerrainHeight,this._boundingSpheresKeys=[],this._boundingSpheres=[],this._useFragmentCulling=!1,this._zIndex=void 0;let n=this;this._classificationPrimitiveOptions={geometryInstances:void 0,appearance:void 0,vertexCacheOptimize:Z(t.vertexCacheOptimize,!1),interleave:Z(t.interleave,!1),releaseGeometryInstances:Z(t.releaseGeometryInstances,!0),allowPicking:Z(t.allowPicking,!0),asynchronous:Z(t.asynchronous,!0),compressVertices:Z(t.compressVertices,!0),_createBoundingVolumeFunction:void 0,_updateAndQueueCommandsFunction:void 0,_pickPrimitive:n,_extruded:!0,_uniformMap:vrt}}function rj(t){return function(e,i){let n=i.maximumRadius,s=n/Math.cos(e*.5)-n;return t._maxHeight+s}}function aj(t){return function(e,i){return t._minHeight}}function ap(t,e){let i=t.mapProjection.ellipsoid;if(!m(e.attributes)||!m(e.attributes.position3DHigh))return m(e.rectangle)?e.rectangle:void 0;let n=e.attributes.position3DHigh.values,s=e.attributes.position3DLow.values,o=n.length,r=Number.POSITIVE_INFINITY,a=Number.POSITIVE_INFINITY,h=Number.NEGATIVE_INFINITY,A=Number.NEGATIVE_INFINITY;for(let f=0;f<o;f+=3){let E=l.unpack(n,f,zrt),_=l.unpack(s,f,Krt),R=l.add(E,_,Xrt),I=i.cartesianToCartographic(R,qrt),C=I.latitude,N=I.longitude;r=Math.min(r,C),a=Math.min(a,N),h=Math.max(h,C),A=Math.max(A,N)}let d=$rt;return d.north=h,d.south=r,d.east=A,d.west=a,d}function tat(t,e,i){let n=Do.getMinimumMaximumHeights(e,i);t._minTerrainHeight=n.minimumTerrainHeight,t._maxTerrainHeight=n.maximumTerrainHeight}function eat(t,e,i){let n=e.mapProjection.ellipsoid,s=ap(e,i),o=zs.fromRectangle(s,t._minHeight,t._maxHeight,n);if(t._boundingVolumes.push(o),!e.scene3DOnly){let r=e.mapProjection,a=Nt.fromRectangleWithHeights2D(s,r,t._maxHeight,t._minHeight);l.fromElements(a.center.z,a.center.x,a.center.y,a.center),t._boundingVolumes2D.push(a)}}function _F(t,e){return Math.floor(t%e/2)}function RF(t,e,i,n,s,o,r){let a=t._primitive;i.mode!==ye.SCENE3D&&e.shaderProgram===a._spColor&&a._needs2DShader&&(e=e.derivedCommands.appearance2D),e.owner=t,e.modelMatrix=n,e.boundingVolume=o,e.cull=s,e.debugShowBoundingVolume=r,i.commandList.push(e)}function Aj(t,e,i,n,s,o){let r=t._primitive;i.mode!==ye.SCENE3D&&e.shaderProgram===r._spPick&&r._needs2DShader&&(e=e.derivedCommands.pick2D),e.owner=t,e.modelMatrix=n,e.boundingVolume=o,e.cull=s,i.commandList.push(e)}function iat(t,e,i,n,s,o,r,a){let h;e.mode===ye.SCENE3D?h=t._boundingVolumes:h=t._boundingVolumes2D;let A=t.classificationType,d=A!==Jr.CESIUM_3D_TILE,f=A!==Jr.TERRAIN,E=e.passes,_=t._primitive,R,I,C;if(E.render){let N=i.length;for(R=0;R<N;++R)I=h[_F(R,N)],d&&(C=i[R],RF(t,C,e,s,o,I,r)),f&&(C=i[R].derivedCommands.tileset,RF(t,C,e,s,o,I,r));if(e.invertClassification){let T=_._commandsIgnoreShow,b=T.length;for(R=0;R<b;++R)I=h[R],C=T[R],RF(t,C,e,s,o,I,r)}}if(E.pick){let N=n.length,T;for(t._useFragmentCulling||(T=_._primitive._pickOffsets),R=0;R<N;++R){if(I=h[_F(R,N)],!t._useFragmentCulling){let b=T[_F(R,N)];I=h[b.index]}d&&(C=n[R],Aj(t,C,e,s,o,I)),f&&(C=n[R].derivedCommands.tileset,Aj(t,C,e,s,o,I))}}}var vrt,zrt,Krt,Xrt,qrt,$rt,hj,cj=S(()=>{JE();_i();Ht();ri();ae();Ft();mt();Ws();Ot();uA();Jl();pn();hF();oj();UI();op();ua();dF();vrt={u_globeMinimumAltitude:function(){return 55e3}};Object.defineProperties(nr.prototype,{vertexCacheOptimize:{get:function(){return this._classificationPrimitiveOptions.vertexCacheOptimize}},interleave:{get:function(){return this._classificationPrimitiveOptions.interleave}},releaseGeometryInstances:{get:function(){return this._classificationPrimitiveOptions.releaseGeometryInstances}},allowPicking:{get:function(){return this._classificationPrimitiveOptions.allowPicking}},asynchronous:{get:function(){return this._classificationPrimitiveOptions.asynchronous}},compressVertices:{get:function(){return this._classificationPrimitiveOptions.compressVertices}},ready:{get:function(){return this._ready}}});nr.isSupported=EF.isSupported;zrt=new l,Krt=new l,Xrt=new l,qrt=new ut,$rt=new Xt;nr.initializeTerrainHeights=function(){return Do.initialize()};nr.prototype.update=function(t){if(!m(this._primitive)&&!m(this.geometryInstances))return;if(!Do.initialized){if(!this.asynchronous)throw new Y("For synchronous GroundPrimitives, you must call GroundPrimitive.initializeTerrainHeights() and wait for the returned promise to resolve.");nr.initializeTerrainHeights();return}let e=this,i=this._classificationPrimitiveOptions;if(!m(this._primitive)){let n=t.mapProjection.ellipsoid,s,o,r,a=Array.isArray(this.geometryInstances)?this.geometryInstances:[this.geometryInstances],h=a.length,A=new Array(h),d,f;for(d=0;d<h;++d){s=a[d],o=s.geometry;let I=ap(t,o);m(f)?m(I)&&Xt.union(f,I,f):f=Xt.clone(I);let C=s.id;if(m(C)&&m(I)){let N=Do.getBoundingSphere(I,n);this._boundingSpheresKeys.push(C),this._boundingSpheres.push(N)}if(r=o.constructor,!m(r)||!m(r.createShadowVolume))throw new Y("Not all of the geometry instances have GroundPrimitive support.")}tat(this,f,n);let E=t.verticalExaggeration,_=t.verticalExaggerationRelativeHeight;this._minHeight=A_.getHeight(this._minTerrainHeight,E,_),this._maxHeight=A_.getHeight(this._maxTerrainHeight,E,_);let R=nr._supportsMaterials(t.context);if(this._useFragmentCulling=R,R){let I,C=!0;for(d=0;d<h;++d)if(s=a[d],o=s.geometry,f=ap(t,o),gc.shouldUseSphericalCoordinates(f)){C=!1;break}for(d=0;d<h;++d){s=a[d],o=s.geometry,r=o.constructor;let N=ap(t,o),T=o.textureCoordinateRotationPoints;C?I=gc.getPlanarTextureCoordinateAttributes(N,T,n,t.mapProjection,this._maxHeight):I=gc.getSphericalExtentGeometryInstanceAttributes(N,T,n,t.mapProjection);let b=s.attributes;for(let F in b)b.hasOwnProperty(F)&&(I[F]=b[F]);A[d]=new Ln({geometry:r.createShadowVolume(o,aj(this),rj(this)),attributes:I,id:s.id})}}else for(d=0;d<h;++d)s=a[d],o=s.geometry,r=o.constructor,A[d]=new Ln({geometry:r.createShadowVolume(o,aj(this),rj(this)),attributes:s.attributes,id:s.id});i.geometryInstances=A,i.appearance=this.appearance,i._createBoundingVolumeFunction=function(I,C){eat(e,I,C)},i._updateAndQueueCommandsFunction=function(I,C,N,T,b,F,B,U){iat(e,C,N,T,b,F,B,U)},this._primitive=new EF(i)}this._primitive.appearance=this.appearance,this._primitive.show=this.show,this._primitive.debugShowShadowVolume=this.debugShowShadowVolume,this._primitive.debugShowBoundingVolume=this.debugShowBoundingVolume,this._primitive.update(t),t.afterRender.push(()=>{!this._ready&&m(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};nr.prototype.getBoundingSphere=function(t){let e=this._boundingSpheresKeys.indexOf(t);if(e!==-1)return this._boundingSpheres[e]};nr.prototype.getGeometryInstanceAttributes=function(t){if(!m(this._primitive))throw new Y("must call update before calling getGeometryInstanceAttributes");return this._primitive.getGeometryInstanceAttributes(t)};nr.prototype.isDestroyed=function(){return!1};nr.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),li(this)};nr._supportsMaterials=function(t){return t.depthTexture};nr.supportsMaterials=function(t){return p.typeOf.object("scene",t),nr._supportsMaterials(t.frameState.context)};hj=nr});function Tc(t){this._value=void 0,this._hasClone=!1,this._hasEquals=!1,this._definitionChanged=new We,this.setValue(t)}var Ch,h_=S(()=>{mt();xi();Object.defineProperties(Tc.prototype,{isConstant:{value:!0},definitionChanged:{get:function(){return this._definitionChanged}}});Tc.prototype.getValue=function(t,e){return this._hasClone?this._value.clone(e):this._value};Tc.prototype.setValue=function(t){let e=this._value;if(e!==t){let i=m(t),n=i&&typeof t.clone=="function",s=i&&typeof t.equals=="function";(!s||!t.equals(e))&&(this._hasClone=n,this._hasEquals=s,this._value=n?t.clone(this._value):t,this._definitionChanged.raiseEvent(this))}};Tc.prototype.equals=function(t){return this===t||t instanceof Tc&&(!this._hasEquals&&this._value===t._value||this._hasEquals&&this._value.equals(t._value))};Tc.prototype.valueOf=function(){return this._value};Tc.prototype.toString=function(){return String(this._value)};Ch=Tc});function nat(t,e,i,n,s){return{configurable:n,get:function(){return this[e]},set:function(o){let r=this[e],a=this[i];m(a)&&(a(),this[i]=void 0),o!==void 0&&(!m(o)||!m(o.getValue))&&m(s)&&(o=s(o)),r!==o&&(this[e]=o,this._definitionChanged.raiseEvent(this,t,o,r)),m(o)&&m(o.definitionChanged)&&(this[i]=o.definitionChanged.addEventListener(function(){this._definitionChanged.raiseEvent(this,t,o,o)},this))}}}function sat(t){return new Ch(t)}function oat(t,e,i){return nat(t,`_${t.toString()}`,`_${t.toString()}Subscription`,Z(e,!1),Z(i,sat))}var rt,yn=S(()=>{Ft();mt();h_();rt=oat});function c_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._image=void 0,this._imageSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this._pixelOffset=void 0,this._pixelOffsetSubscription=void 0,this._eyeOffset=void 0,this._eyeOffsetSubscription=void 0,this._horizontalOrigin=void 0,this._horizontalOriginSubscription=void 0,this._verticalOrigin=void 0,this._verticalOriginSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._color=void 0,this._colorSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._alignedAxis=void 0,this._alignedAxisSubscription=void 0,this._sizeInMeters=void 0,this._sizeInMetersSubscription=void 0,this._width=void 0,this._widthSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._scaleByDistance=void 0,this._scaleByDistanceSubscription=void 0,this._translucencyByDistance=void 0,this._translucencyByDistanceSubscription=void 0,this._pixelOffsetScaleByDistance=void 0,this._pixelOffsetScaleByDistanceSubscription=void 0,this._imageSubRegion=void 0,this._imageSubRegionSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._disableDepthTestDistance=void 0,this._disableDepthTestDistanceSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var lj,dj=S(()=>{Ft();mt();Ot();xi();yn();Object.defineProperties(c_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),image:rt("image"),scale:rt("scale"),pixelOffset:rt("pixelOffset"),eyeOffset:rt("eyeOffset"),horizontalOrigin:rt("horizontalOrigin"),verticalOrigin:rt("verticalOrigin"),heightReference:rt("heightReference"),color:rt("color"),rotation:rt("rotation"),alignedAxis:rt("alignedAxis"),sizeInMeters:rt("sizeInMeters"),width:rt("width"),height:rt("height"),scaleByDistance:rt("scaleByDistance"),translucencyByDistance:rt("translucencyByDistance"),pixelOffsetScaleByDistance:rt("pixelOffsetScaleByDistance"),imageSubRegion:rt("imageSubRegion"),distanceDisplayCondition:rt("distanceDisplayCondition"),disableDepthTestDistance:rt("disableDepthTestDistance")});c_.prototype.clone=function(t){return m(t)?(t.show=this._show,t.image=this._image,t.scale=this._scale,t.pixelOffset=this._pixelOffset,t.eyeOffset=this._eyeOffset,t.horizontalOrigin=this._horizontalOrigin,t.verticalOrigin=this._verticalOrigin,t.heightReference=this._heightReference,t.color=this._color,t.rotation=this._rotation,t.alignedAxis=this._alignedAxis,t.sizeInMeters=this._sizeInMeters,t.width=this._width,t.height=this._height,t.scaleByDistance=this._scaleByDistance,t.translucencyByDistance=this._translucencyByDistance,t.pixelOffsetScaleByDistance=this._pixelOffsetScaleByDistance,t.imageSubRegion=this._imageSubRegion,t.distanceDisplayCondition=this._distanceDisplayCondition,t.disableDepthTestDistance=this._disableDepthTestDistance,t):new c_(this)};c_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this._show,t.show),this.image=Z(this._image,t.image),this.scale=Z(this._scale,t.scale),this.pixelOffset=Z(this._pixelOffset,t.pixelOffset),this.eyeOffset=Z(this._eyeOffset,t.eyeOffset),this.horizontalOrigin=Z(this._horizontalOrigin,t.horizontalOrigin),this.verticalOrigin=Z(this._verticalOrigin,t.verticalOrigin),this.heightReference=Z(this._heightReference,t.heightReference),this.color=Z(this._color,t.color),this.rotation=Z(this._rotation,t.rotation),this.alignedAxis=Z(this._alignedAxis,t.alignedAxis),this.sizeInMeters=Z(this._sizeInMeters,t.sizeInMeters),this.width=Z(this._width,t.width),this.height=Z(this._height,t.height),this.scaleByDistance=Z(this._scaleByDistance,t.scaleByDistance),this.translucencyByDistance=Z(this._translucencyByDistance,t.translucencyByDistance),this.pixelOffsetScaleByDistance=Z(this._pixelOffsetScaleByDistance,t.pixelOffsetScaleByDistance),this.imageSubRegion=Z(this._imageSubRegion,t.imageSubRegion),this.distanceDisplayCondition=Z(this._distanceDisplayCondition,t.distanceDisplayCondition),this.disableDepthTestDistance=Z(this._disableDepthTestDistance,t.disableDepthTestDistance)};lj=c_});function Ua(){Y.throwInstantiationError()}var Si,Hl=S(()=>{Ft();mt();Ot();Object.defineProperties(Ua.prototype,{isConstant:{get:Y.throwInstantiationError},definitionChanged:{get:Y.throwInstantiationError}});Ua.prototype.getValue=Y.throwInstantiationError;Ua.prototype.equals=Y.throwInstantiationError;Ua.equals=function(t,e){return t===e||m(t)&&t.equals(e)};Ua.arrayEquals=function(t,e){if(t===e)return!0;if(!m(t)||!m(e)||t.length!==e.length)return!1;let i=t.length;for(let n=0;n<i;n++)if(!Ua.equals(t[n],e[n]))return!1;return!0};Ua.isConstant=function(t){return!m(t)||t.isConstant};Ua.getValueOrUndefined=function(t,e,i){return m(t)?t.getValue(e,i):void 0};Ua.getValueOrDefault=function(t,e,i,n){return m(t)?Z(t.getValue(e,n),i):i};Ua.getValueOrClonedDefault=function(t,e,i,n){let s;return m(t)&&(s=t.getValue(e,n)),m(s)||(s=i.clone(s)),s};Si=Ua});function tf(t){this._definitionChanged=new We,this._color=void 0,this._colorSubscription=void 0,this.color=t}var mj,fj=S(()=>{Qn();mt();xi();yn();Hl();Object.defineProperties(tf.prototype,{isConstant:{get:function(){return Si.isConstant(this._color)}},definitionChanged:{get:function(){return this._definitionChanged}},color:rt("color")});tf.prototype.getType=function(t){return"Color"};tf.prototype.getValue=function(t,e){return m(e)||(e={}),e.color=Si.getValueOrClonedDefault(this._color,t,Zt.WHITE,e.color),e};tf.prototype.equals=function(t){return this===t||t instanceof tf&&Si.equals(this._color,t._color)};mj=tf});function ef(t){t=Z(t,Z.EMPTY_OBJECT),this._definitionChanged=new We,this._image=void 0,this._imageSubscription=void 0,this._repeat=void 0,this._repeatSubscription=void 0,this._color=void 0,this._colorSubscription=void 0,this._transparent=void 0,this._transparentSubscription=void 0,this.image=t.image,this.repeat=t.repeat,this.color=t.color,this.transparent=t.transparent}var rat,aat,Aat,Ej,_j=S(()=>{Xe();Qn();Ft();mt();xi();yn();Hl();rat=new nt(1,1),aat=!1,Aat=Zt.WHITE;Object.defineProperties(ef.prototype,{isConstant:{get:function(){return Si.isConstant(this._image)&&Si.isConstant(this._repeat)}},definitionChanged:{get:function(){return this._definitionChanged}},image:rt("image"),repeat:rt("repeat"),color:rt("color"),transparent:rt("transparent")});ef.prototype.getType=function(t){return"Image"};ef.prototype.getValue=function(t,e){return m(e)||(e={}),e.image=Si.getValueOrUndefined(this._image,t),e.repeat=Si.getValueOrClonedDefault(this._repeat,t,rat,e.repeat),e.color=Si.getValueOrClonedDefault(this._color,t,Aat,e.color),Si.getValueOrDefault(this._transparent,t,aat)&&(e.color.alpha=Math.min(.99,e.color.alpha)),e};ef.prototype.equals=function(t){return this===t||t instanceof ef&&Si.equals(this._image,t._image)&&Si.equals(this._repeat,t._repeat)&&Si.equals(this._color,t._color)&&Si.equals(this._transparent,t._transparent)};Ej=ef});function hat(t){if(t instanceof Zt)return new mj(t);if(typeof t=="string"||t instanceof tn||t instanceof HTMLCanvasElement||t instanceof HTMLVideoElement){let e=new Ej;return e.image=t,e}throw new Y(`Unable to infer material type: ${t}`)}function cat(t,e){return rt(t,e,hat)}var wn,ur=S(()=>{Qn();Ot();Ia();fj();yn();_j();wn=cat});function l_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._dimensions=void 0,this._dimensionsSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Rj,Zj=S(()=>{Ft();mt();Ot();xi();ur();yn();Object.defineProperties(l_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),dimensions:rt("dimensions"),heightReference:rt("heightReference"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});l_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.dimensions=this.dimensions,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new l_(this)};l_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.dimensions=Z(this.dimensions,t.dimensions),this.heightReference=Z(this.heightReference,t.heightReference),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};Rj=l_});function nf(){Y.throwInstantiationError()}var ZF,Ap,IF=S(()=>{Ht();mt();Ot();dn();ic();fr();Object.defineProperties(nf.prototype,{isConstant:{get:Y.throwInstantiationError},definitionChanged:{get:Y.throwInstantiationError},referenceFrame:{get:Y.throwInstantiationError}});nf.prototype.getValue=Y.throwInstantiationError;nf.prototype.getValueInReferenceFrame=Y.throwInstantiationError;nf.prototype.equals=Y.throwInstantiationError;ZF=new lt;nf.convertToReferenceFrame=function(t,e,i,n,s){if(!m(e))return e;if(m(s)||(s=new l),i===n)return l.clone(e,s);let o=In.computeIcrfToFixedMatrix(t,ZF);if(m(o)||(o=In.computeTemeToPseudoFixedMatrix(t,ZF)),i===$i.INERTIAL)return lt.multiplyByVector(o,e,s);if(i===$i.FIXED)return lt.multiplyByVector(lt.transpose(o,ZF),e,s)};Ap=nf});function vl(t,e){this._definitionChanged=new We,this._value=l.clone(t),this._referenceFrame=Z(e,$i.FIXED)}var Ij,pj=S(()=>{Ht();Ft();mt();Ot();xi();ic();IF();Object.defineProperties(vl.prototype,{isConstant:{get:function(){return!m(this._value)||this._referenceFrame===$i.FIXED}},definitionChanged:{get:function(){return this._definitionChanged}},referenceFrame:{get:function(){return this._referenceFrame}}});vl.prototype.getValue=function(t,e){return this.getValueInReferenceFrame(t,$i.FIXED,e)};vl.prototype.setValue=function(t,e){let i=!1;l.equals(this._value,t)||(i=!0,this._value=l.clone(t)),m(e)&&this._referenceFrame!==e&&(i=!0,this._referenceFrame=e),i&&this._definitionChanged.raiseEvent(this)};vl.prototype.getValueInReferenceFrame=function(t,e,i){if(!m(t))throw new Y("time is required.");if(!m(e))throw new Y("referenceFrame is required.");return Ap.convertToReferenceFrame(t,this._value,this._referenceFrame,e,i)};vl.prototype.equals=function(t){return this===t||t instanceof vl&&l.equals(this._value,t._value)&&this._referenceFrame===t._referenceFrame};Ij=vl});function d_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._positions=void 0,this._positionsSubscription=void 0,this._width=void 0,this._widthSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._cornerType=void 0,this._cornerTypeSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var uj,Cj=S(()=>{Ft();mt();Ot();xi();ur();yn();Object.defineProperties(d_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),positions:rt("positions"),width:rt("width"),height:rt("height"),heightReference:rt("heightReference"),extrudedHeight:rt("extrudedHeight"),extrudedHeightReference:rt("extrudedHeightReference"),cornerType:rt("cornerType"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition"),classificationType:rt("classificationType"),zIndex:rt("zIndex")});d_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.positions=this.positions,t.width=this.width,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.cornerType=this.cornerType,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new d_(this)};d_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.positions=Z(this.positions,t.positions),this.width=Z(this.width,t.width),this.height=Z(this.height,t.height),this.heightReference=Z(this.heightReference,t.heightReference),this.extrudedHeight=Z(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=Z(this.extrudedHeightReference,t.extrudedHeightReference),this.cornerType=Z(this.cornerType,t.cornerType),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=Z(this.classificationType,t.classificationType),this.zIndex=Z(this.zIndex,t.zIndex)};uj=d_});function lat(t){return t}function dat(t,e){return rt(t,e,lat)}var hp,gj=S(()=>{yn();hp=dat});function m_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._length=void 0,this._lengthSubscription=void 0,this._topRadius=void 0,this._topRadiusSubscription=void 0,this._bottomRadius=void 0,this._bottomRadiusSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._numberOfVerticalLines=void 0,this._numberOfVerticalLinesSubscription=void 0,this._slices=void 0,this._slicesSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Tj,Nj=S(()=>{Ft();mt();Ot();xi();ur();yn();Object.defineProperties(m_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),length:rt("length"),topRadius:rt("topRadius"),bottomRadius:rt("bottomRadius"),heightReference:rt("heightReference"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),numberOfVerticalLines:rt("numberOfVerticalLines"),slices:rt("slices"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});m_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.length=this.length,t.topRadius=this.topRadius,t.bottomRadius=this.bottomRadius,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.numberOfVerticalLines=this.numberOfVerticalLines,t.slices=this.slices,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new m_(this)};m_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.length=Z(this.length,t.length),this.topRadius=Z(this.topRadius,t.topRadius),this.bottomRadius=Z(this.bottomRadius,t.bottomRadius),this.heightReference=Z(this.heightReference,t.heightReference),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.numberOfVerticalLines=Z(this.numberOfVerticalLines,t.numberOfVerticalLines),this.slices=Z(this.slices,t.slices),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};Tj=m_});function f_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._semiMajorAxis=void 0,this._semiMajorAxisSubscription=void 0,this._semiMinorAxis=void 0,this._semiMinorAxisSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._stRotation=void 0,this._stRotationSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._numberOfVerticalLines=void 0,this._numberOfVerticalLinesSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Fj,bj=S(()=>{Ft();mt();Ot();xi();ur();yn();Object.defineProperties(f_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),semiMajorAxis:rt("semiMajorAxis"),semiMinorAxis:rt("semiMinorAxis"),height:rt("height"),heightReference:rt("heightReference"),extrudedHeight:rt("extrudedHeight"),extrudedHeightReference:rt("extrudedHeightReference"),rotation:rt("rotation"),stRotation:rt("stRotation"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),numberOfVerticalLines:rt("numberOfVerticalLines"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition"),classificationType:rt("classificationType"),zIndex:rt("zIndex")});f_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.semiMajorAxis=this.semiMajorAxis,t.semiMinorAxis=this.semiMinorAxis,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.rotation=this.rotation,t.stRotation=this.stRotation,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.numberOfVerticalLines=this.numberOfVerticalLines,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new f_(this)};f_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.semiMajorAxis=Z(this.semiMajorAxis,t.semiMajorAxis),this.semiMinorAxis=Z(this.semiMinorAxis,t.semiMinorAxis),this.height=Z(this.height,t.height),this.heightReference=Z(this.heightReference,t.heightReference),this.extrudedHeight=Z(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=Z(this.extrudedHeightReference,t.extrudedHeightReference),this.rotation=Z(this.rotation,t.rotation),this.stRotation=Z(this.stRotation,t.stRotation),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.numberOfVerticalLines=Z(this.numberOfVerticalLines,t.numberOfVerticalLines),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=Z(this.classificationType,t.classificationType),this.zIndex=Z(this.zIndex,t.zIndex)};Fj=f_});function E_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._radii=void 0,this._radiiSubscription=void 0,this._innerRadii=void 0,this._innerRadiiSubscription=void 0,this._minimumClock=void 0,this._minimumClockSubscription=void 0,this._maximumClock=void 0,this._maximumClockSubscription=void 0,this._minimumCone=void 0,this._minimumConeSubscription=void 0,this._maximumCone=void 0,this._maximumConeSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._stackPartitions=void 0,this._stackPartitionsSubscription=void 0,this._slicePartitions=void 0,this._slicePartitionsSubscription=void 0,this._subdivisions=void 0,this._subdivisionsSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Yj,Vj=S(()=>{Ft();mt();Ot();xi();ur();yn();Object.defineProperties(E_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),radii:rt("radii"),innerRadii:rt("innerRadii"),minimumClock:rt("minimumClock"),maximumClock:rt("maximumClock"),minimumCone:rt("minimumCone"),maximumCone:rt("maximumCone"),heightReference:rt("heightReference"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),stackPartitions:rt("stackPartitions"),slicePartitions:rt("slicePartitions"),subdivisions:rt("subdivisions"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});E_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.radii=this.radii,t.innerRadii=this.innerRadii,t.minimumClock=this.minimumClock,t.maximumClock=this.maximumClock,t.minimumCone=this.minimumCone,t.maximumCone=this.maximumCone,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.stackPartitions=this.stackPartitions,t.slicePartitions=this.slicePartitions,t.subdivisions=this.subdivisions,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new E_(this)};E_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.radii=Z(this.radii,t.radii),this.innerRadii=Z(this.innerRadii,t.innerRadii),this.minimumClock=Z(this.minimumClock,t.minimumClock),this.maximumClock=Z(this.maximumClock,t.maximumClock),this.minimumCone=Z(this.minimumCone,t.minimumCone),this.maximumCone=Z(this.maximumCone,t.maximumCone),this.heightReference=Z(this.heightReference,t.heightReference),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.stackPartitions=Z(this.stackPartitions,t.stackPartitions),this.slicePartitions=Z(this.slicePartitions,t.slicePartitions),this.subdivisions=Z(this.subdivisions,t.subdivisions),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};Yj=E_});function __(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._text=void 0,this._textSubscription=void 0,this._font=void 0,this._fontSubscription=void 0,this._style=void 0,this._styleSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this._showBackground=void 0,this._showBackgroundSubscription=void 0,this._backgroundColor=void 0,this._backgroundColorSubscription=void 0,this._backgroundPadding=void 0,this._backgroundPaddingSubscription=void 0,this._pixelOffset=void 0,this._pixelOffsetSubscription=void 0,this._eyeOffset=void 0,this._eyeOffsetSubscription=void 0,this._horizontalOrigin=void 0,this._horizontalOriginSubscription=void 0,this._verticalOrigin=void 0,this._verticalOriginSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fillColor=void 0,this._fillColorSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._translucencyByDistance=void 0,this._translucencyByDistanceSubscription=void 0,this._pixelOffsetScaleByDistance=void 0,this._pixelOffsetScaleByDistanceSubscription=void 0,this._scaleByDistance=void 0,this._scaleByDistanceSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._disableDepthTestDistance=void 0,this._disableDepthTestDistanceSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Sj,Oj=S(()=>{Ft();mt();Ot();xi();yn();Object.defineProperties(__.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),text:rt("text"),font:rt("font"),style:rt("style"),scale:rt("scale"),showBackground:rt("showBackground"),backgroundColor:rt("backgroundColor"),backgroundPadding:rt("backgroundPadding"),pixelOffset:rt("pixelOffset"),eyeOffset:rt("eyeOffset"),horizontalOrigin:rt("horizontalOrigin"),verticalOrigin:rt("verticalOrigin"),heightReference:rt("heightReference"),fillColor:rt("fillColor"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),translucencyByDistance:rt("translucencyByDistance"),pixelOffsetScaleByDistance:rt("pixelOffsetScaleByDistance"),scaleByDistance:rt("scaleByDistance"),distanceDisplayCondition:rt("distanceDisplayCondition"),disableDepthTestDistance:rt("disableDepthTestDistance")});__.prototype.clone=function(t){return m(t)?(t.show=this.show,t.text=this.text,t.font=this.font,t.style=this.style,t.scale=this.scale,t.showBackground=this.showBackground,t.backgroundColor=this.backgroundColor,t.backgroundPadding=this.backgroundPadding,t.pixelOffset=this.pixelOffset,t.eyeOffset=this.eyeOffset,t.horizontalOrigin=this.horizontalOrigin,t.verticalOrigin=this.verticalOrigin,t.heightReference=this.heightReference,t.fillColor=this.fillColor,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.translucencyByDistance=this.translucencyByDistance,t.pixelOffsetScaleByDistance=this.pixelOffsetScaleByDistance,t.scaleByDistance=this.scaleByDistance,t.distanceDisplayCondition=this.distanceDisplayCondition,t.disableDepthTestDistance=this.disableDepthTestDistance,t):new __(this)};__.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.text=Z(this.text,t.text),this.font=Z(this.font,t.font),this.style=Z(this.style,t.style),this.scale=Z(this.scale,t.scale),this.showBackground=Z(this.showBackground,t.showBackground),this.backgroundColor=Z(this.backgroundColor,t.backgroundColor),this.backgroundPadding=Z(this.backgroundPadding,t.backgroundPadding),this.pixelOffset=Z(this.pixelOffset,t.pixelOffset),this.eyeOffset=Z(this.eyeOffset,t.eyeOffset),this.horizontalOrigin=Z(this.horizontalOrigin,t.horizontalOrigin),this.verticalOrigin=Z(this.verticalOrigin,t.verticalOrigin),this.heightReference=Z(this.heightReference,t.heightReference),this.fillColor=Z(this.fillColor,t.fillColor),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.translucencyByDistance=Z(this.translucencyByDistance,t.translucencyByDistance),this.pixelOffsetScaleByDistance=Z(this.pixelOffsetScaleByDistance,t.pixelOffsetScaleByDistance),this.scaleByDistance=Z(this.scaleByDistance,t.scaleByDistance),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.disableDepthTestDistance=Z(this.disableDepthTestDistance,t.disableDepthTestDistance)};Sj=__});function Bj(t,e,i){this.translation=l.clone(Z(t,fat)),this.rotation=Ae.clone(Z(e,Eat)),this.scale=l.clone(Z(i,mat))}var mat,fat,Eat,pF,Gj=S(()=>{Ht();Ft();mt();$s();mat=new l(1,1,1),fat=l.ZERO,Eat=Ae.IDENTITY;Bj.prototype.equals=function(t){return this===t||m(t)&&l.equals(this.translation,t.translation)&&Ae.equals(this.rotation,t.rotation)&&l.equals(this.scale,t.scale)};pF=Bj});function R_(t){t=Z(t,Z.EMPTY_OBJECT),this._definitionChanged=new We,this._translation=void 0,this._translationSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this.translation=t.translation,this.rotation=t.rotation,this.scale=t.scale}var uF,Wj,Dj=S(()=>{Ft();mt();xi();Gj();yn();Hl();uF=new pF;Object.defineProperties(R_.prototype,{isConstant:{get:function(){return Si.isConstant(this._translation)&&Si.isConstant(this._rotation)&&Si.isConstant(this._scale)}},definitionChanged:{get:function(){return this._definitionChanged}},translation:rt("translation"),rotation:rt("rotation"),scale:rt("scale")});R_.prototype.getValue=function(t,e){return m(e)||(e=new pF),e.translation=Si.getValueOrClonedDefault(this._translation,t,uF.translation,e.translation),e.rotation=Si.getValueOrClonedDefault(this._rotation,t,uF.rotation,e.rotation),e.scale=Si.getValueOrClonedDefault(this._scale,t,uF.scale,e.scale),e};R_.prototype.equals=function(t){return this===t||t instanceof R_&&Si.equals(this._translation,t._translation)&&Si.equals(this._rotation,t._rotation)&&Si.equals(this._scale,t._scale)};Wj=R_});function gh(t,e){this._propertyNames=[],this._definitionChanged=new We,m(t)&&this.merge(t,e)}function _at(t){return new Ch(t)}function Rat(t,e){let i=t._propertyNames,n=e._propertyNames,s=i.length;if(s!==n.length)return!1;for(let o=0;o<s;++o){let r=i[o];if(n.indexOf(r)===-1||!Si.equals(t[r],e[r]))return!1}return!0}var zl,CF=S(()=>{Ft();mt();Ot();xi();h_();yn();Hl();Object.defineProperties(gh.prototype,{propertyNames:{get:function(){return this._propertyNames}},isConstant:{get:function(){let t=this._propertyNames;for(let e=0,i=t.length;e<i;e++)if(!Si.isConstant(this[t[e]]))return!1;return!0}},definitionChanged:{get:function(){return this._definitionChanged}}});gh.prototype.hasProperty=function(t){return this._propertyNames.indexOf(t)!==-1};gh.prototype.addProperty=function(t,e,i){let n=this._propertyNames;if(!m(t))throw new Y("propertyName is required.");if(n.indexOf(t)!==-1)throw new Y(`${t} is already a registered property.`);n.push(t),Object.defineProperty(this,t,rt(t,!0,Z(i,_at))),m(e)&&(this[t]=e),this._definitionChanged.raiseEvent(this)};gh.prototype.removeProperty=function(t){let i=this._propertyNames.indexOf(t);if(!m(t))throw new Y("propertyName is required.");if(i===-1)throw new Y(`${t} is not a registered property.`);this._propertyNames.splice(i,1),delete this[t],this._definitionChanged.raiseEvent(this)};gh.prototype.getValue=function(t,e){if(!m(t))throw new Y("time is required.");m(e)||(e={});let i=this._propertyNames;for(let n=0,s=i.length;n<s;n++){let o=i[n];e[o]=Si.getValueOrUndefined(this[o],t,e[o])}return e};gh.prototype.merge=function(t,e){if(!m(t))throw new Y("source is required.");let i=this._propertyNames,n=m(t._propertyNames)?t._propertyNames:Object.keys(t);for(let s=0,o=n.length;s<o;s++){let r=n[s],a=this[r],h=t[r];a===void 0&&i.indexOf(r)===-1&&this.addProperty(r,void 0,e),h!==void 0&&(a!==void 0?m(a)&&m(a.merge)&&a.merge(h):m(h)&&m(h.merge)&&m(h.clone)?this[r]=h.clone():this[r]=h)}};gh.prototype.equals=function(t){return this===t||t instanceof gh&&Rat(this,t)};zl=gh});function Uj(t){return new Wj(t)}function Zat(t){return new zl(t,Uj)}function Iat(t){return new zl(t)}function Z_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._uri=void 0,this._uriSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this._minimumPixelSize=void 0,this._minimumPixelSizeSubscription=void 0,this._maximumScale=void 0,this._maximumScaleSubscription=void 0,this._incrementallyLoadTextures=void 0,this._incrementallyLoadTexturesSubscription=void 0,this._runAnimations=void 0,this._runAnimationsSubscription=void 0,this._clampAnimations=void 0,this._clampAnimationsSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._silhouetteColor=void 0,this._silhouetteColorSubscription=void 0,this._silhouetteSize=void 0,this._silhouetteSizeSubscription=void 0,this._color=void 0,this._colorSubscription=void 0,this._colorBlendMode=void 0,this._colorBlendModeSubscription=void 0,this._colorBlendAmount=void 0,this._colorBlendAmountSubscription=void 0,this._imageBasedLightingFactor=void 0,this._imageBasedLightingFactorSubscription=void 0,this._lightColor=void 0,this._lightColorSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._nodeTransformations=void 0,this._nodeTransformationsSubscription=void 0,this._articulations=void 0,this._articulationsSubscription=void 0,this._clippingPlanes=void 0,this._clippingPlanesSubscription=void 0,this._customShader=void 0,this._customShaderSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Mj,Qj=S(()=>{Ft();mt();Ot();xi();yn();Dj();CF();Object.defineProperties(Z_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),uri:rt("uri"),scale:rt("scale"),minimumPixelSize:rt("minimumPixelSize"),maximumScale:rt("maximumScale"),incrementallyLoadTextures:rt("incrementallyLoadTextures"),runAnimations:rt("runAnimations"),clampAnimations:rt("clampAnimations"),shadows:rt("shadows"),heightReference:rt("heightReference"),silhouetteColor:rt("silhouetteColor"),silhouetteSize:rt("silhouetteSize"),color:rt("color"),colorBlendMode:rt("colorBlendMode"),colorBlendAmount:rt("colorBlendAmount"),imageBasedLightingFactor:rt("imageBasedLightingFactor"),lightColor:rt("lightColor"),distanceDisplayCondition:rt("distanceDisplayCondition"),nodeTransformations:rt("nodeTransformations",void 0,Zat),articulations:rt("articulations",void 0,Iat),clippingPlanes:rt("clippingPlanes"),customShader:rt("customShader")});Z_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.uri=this.uri,t.scale=this.scale,t.minimumPixelSize=this.minimumPixelSize,t.maximumScale=this.maximumScale,t.incrementallyLoadTextures=this.incrementallyLoadTextures,t.runAnimations=this.runAnimations,t.clampAnimations=this.clampAnimations,t.heightReference=this._heightReference,t.silhouetteColor=this.silhouetteColor,t.silhouetteSize=this.silhouetteSize,t.color=this.color,t.colorBlendMode=this.colorBlendMode,t.colorBlendAmount=this.colorBlendAmount,t.imageBasedLightingFactor=this.imageBasedLightingFactor,t.lightColor=this.lightColor,t.distanceDisplayCondition=this.distanceDisplayCondition,t.nodeTransformations=this.nodeTransformations,t.articulations=this.articulations,t.clippingPlanes=this.clippingPlanes,t.customShader=this.customShader,t):new Z_(this)};Z_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.uri=Z(this.uri,t.uri),this.scale=Z(this.scale,t.scale),this.minimumPixelSize=Z(this.minimumPixelSize,t.minimumPixelSize),this.maximumScale=Z(this.maximumScale,t.maximumScale),this.incrementallyLoadTextures=Z(this.incrementallyLoadTextures,t.incrementallyLoadTextures),this.runAnimations=Z(this.runAnimations,t.runAnimations),this.clampAnimations=Z(this.clampAnimations,t.clampAnimations),this.shadows=Z(this.shadows,t.shadows),this.heightReference=Z(this.heightReference,t.heightReference),this.silhouetteColor=Z(this.silhouetteColor,t.silhouetteColor),this.silhouetteSize=Z(this.silhouetteSize,t.silhouetteSize),this.color=Z(this.color,t.color),this.colorBlendMode=Z(this.colorBlendMode,t.colorBlendMode),this.colorBlendAmount=Z(this.colorBlendAmount,t.colorBlendAmount),this.imageBasedLightingFactor=Z(this.imageBasedLightingFactor,t.imageBasedLightingFactor),this.lightColor=Z(this.lightColor,t.lightColor),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.clippingPlanes=Z(this.clippingPlanes,t.clippingPlanes),this.customShader=Z(this.customShader,t.customShader);let e=t.nodeTransformations;if(m(e)){let n=this.nodeTransformations;m(n)?n.merge(e):this.nodeTransformations=new zl(e,Uj)}let i=t.articulations;if(m(i)){let n=this.articulations;m(n)?n.merge(i):this.articulations=new zl(i)}};Mj=Z_});function I_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._uri=void 0,this._uriSubscription=void 0,this._maximumScreenSpaceError=void 0,this._maximumScreenSpaceErrorSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var kj,Lj=S(()=>{Ft();mt();Ot();xi();yn();Object.defineProperties(I_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),uri:rt("uri"),maximumScreenSpaceError:rt("maximumScreenSpaceError")});I_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.uri=this.uri,t.maximumScreenSpaceError=this.maximumScreenSpaceError,t):new I_(this)};I_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.uri=Z(this.uri,t.uri),this.maximumScreenSpaceError=Z(this.maximumScreenSpaceError,t.maximumScreenSpaceError)};kj=I_});function p_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._leadTime=void 0,this._leadTimeSubscription=void 0,this._trailTime=void 0,this._trailTimeSubscription=void 0,this._width=void 0,this._widthSubscription=void 0,this._resolution=void 0,this._resolutionSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var yj,wj=S(()=>{Ft();mt();Ot();xi();ur();yn();Object.defineProperties(p_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),leadTime:rt("leadTime"),trailTime:rt("trailTime"),width:rt("width"),resolution:rt("resolution"),material:wn("material"),distanceDisplayCondition:rt("distanceDisplayCondition")});p_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.leadTime=this.leadTime,t.trailTime=this.trailTime,t.width=this.width,t.resolution=this.resolution,t.material=this.material,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new p_(this)};p_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.leadTime=Z(this.leadTime,t.leadTime),this.trailTime=Z(this.trailTime,t.trailTime),this.width=Z(this.width,t.width),this.resolution=Z(this.resolution,t.resolution),this.material=Z(this.material,t.material),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};yj=p_});function u_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._plane=void 0,this._planeSubscription=void 0,this._dimensions=void 0,this._dimensionsSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var xj,Pj=S(()=>{Ft();mt();Ot();xi();ur();yn();Object.defineProperties(u_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),plane:rt("plane"),dimensions:rt("dimensions"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});u_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.plane=this.plane,t.dimensions=this.dimensions,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new u_(this)};u_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.plane=Z(this.plane,t.plane),this.dimensions=Z(this.dimensions,t.dimensions),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};xj=u_});function C_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._pixelSize=void 0,this._pixelSizeSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._color=void 0,this._colorSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._scaleByDistance=void 0,this._scaleByDistanceSubscription=void 0,this._translucencyByDistance=void 0,this._translucencyByDistanceSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._disableDepthTestDistance=void 0,this._disableDepthTestDistanceSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Jj,jj=S(()=>{Ft();mt();Ot();xi();yn();Object.defineProperties(C_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),pixelSize:rt("pixelSize"),heightReference:rt("heightReference"),color:rt("color"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),scaleByDistance:rt("scaleByDistance"),translucencyByDistance:rt("translucencyByDistance"),distanceDisplayCondition:rt("distanceDisplayCondition"),disableDepthTestDistance:rt("disableDepthTestDistance")});C_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.pixelSize=this.pixelSize,t.heightReference=this.heightReference,t.color=this.color,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.scaleByDistance=this.scaleByDistance,t.translucencyByDistance=this._translucencyByDistance,t.distanceDisplayCondition=this.distanceDisplayCondition,t.disableDepthTestDistance=this.disableDepthTestDistance,t):new C_(this)};C_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.pixelSize=Z(this.pixelSize,t.pixelSize),this.heightReference=Z(this.heightReference,t.heightReference),this.color=Z(this.color,t.color),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.scaleByDistance=Z(this.scaleByDistance,t.scaleByDistance),this.translucencyByDistance=Z(this._translucencyByDistance,t.translucencyByDistance),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.disableDepthTestDistance=Z(this.disableDepthTestDistance,t.disableDepthTestDistance)};Jj=C_});function pat(t,e){this.positions=m(t)?t:[],this.holes=m(e)?e:[]}var sf,cp=S(()=>{mt();sf=pat});function uat(t){return Array.isArray(t)&&(t=new sf(t)),new Ch(t)}function g_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._hierarchy=void 0,this._hierarchySubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._stRotation=void 0,this._stRotationSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._perPositionHeight=void 0,this._perPositionHeightSubscription=void 0,this._closeTop=void 0,this._closeTopSubscription=void 0,this._closeBottom=void 0,this._closeBottomSubscription=void 0,this._arcType=void 0,this._arcTypeSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this._textureCoordinates=void 0,this._textureCoordinatesSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Hj,vj=S(()=>{Ft();mt();Ot();xi();cp();h_();ur();yn();Object.defineProperties(g_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),hierarchy:rt("hierarchy",void 0,uat),height:rt("height"),heightReference:rt("heightReference"),extrudedHeight:rt("extrudedHeight"),extrudedHeightReference:rt("extrudedHeightReference"),stRotation:rt("stRotation"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),perPositionHeight:rt("perPositionHeight"),closeTop:rt("closeTop"),closeBottom:rt("closeBottom"),arcType:rt("arcType"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition"),classificationType:rt("classificationType"),zIndex:rt("zIndex"),textureCoordinates:rt("textureCoordinates")});g_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.hierarchy=this.hierarchy,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.stRotation=this.stRotation,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.perPositionHeight=this.perPositionHeight,t.closeTop=this.closeTop,t.closeBottom=this.closeBottom,t.arcType=this.arcType,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t.textureCoordinates=this.textureCoordinates,t):new g_(this)};g_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.hierarchy=Z(this.hierarchy,t.hierarchy),this.height=Z(this.height,t.height),this.heightReference=Z(this.heightReference,t.heightReference),this.extrudedHeight=Z(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=Z(this.extrudedHeightReference,t.extrudedHeightReference),this.stRotation=Z(this.stRotation,t.stRotation),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.perPositionHeight=Z(this.perPositionHeight,t.perPositionHeight),this.closeTop=Z(this.closeTop,t.closeTop),this.closeBottom=Z(this.closeBottom,t.closeBottom),this.arcType=Z(this.arcType,t.arcType),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=Z(this.classificationType,t.classificationType),this.zIndex=Z(this.zIndex,t.zIndex),this.textureCoordinates=Z(this.textureCoordinates,t.textureCoordinates)};Hj=g_});function T_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._positions=void 0,this._positionsSubscription=void 0,this._width=void 0,this._widthSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._depthFailMaterial=void 0,this._depthFailMaterialSubscription=void 0,this._arcType=void 0,this._arcTypeSubscription=void 0,this._clampToGround=void 0,this._clampToGroundSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var zj,Kj=S(()=>{Ft();mt();Ot();xi();ur();yn();Object.defineProperties(T_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),positions:rt("positions"),width:rt("width"),granularity:rt("granularity"),material:wn("material"),depthFailMaterial:wn("depthFailMaterial"),arcType:rt("arcType"),clampToGround:rt("clampToGround"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition"),classificationType:rt("classificationType"),zIndex:rt("zIndex")});T_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.positions=this.positions,t.width=this.width,t.granularity=this.granularity,t.material=this.material,t.depthFailMaterial=this.depthFailMaterial,t.arcType=this.arcType,t.clampToGround=this.clampToGround,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new T_(this)};T_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.positions=Z(this.positions,t.positions),this.width=Z(this.width,t.width),this.granularity=Z(this.granularity,t.granularity),this.material=Z(this.material,t.material),this.depthFailMaterial=Z(this.depthFailMaterial,t.depthFailMaterial),this.arcType=Z(this.arcType,t.arcType),this.clampToGround=Z(this.clampToGround,t.clampToGround),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=Z(this.classificationType,t.classificationType),this.zIndex=Z(this.zIndex,t.zIndex)};zj=T_});function N_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._positions=void 0,this._positionsSubscription=void 0,this._shape=void 0,this._shapeSubscription=void 0,this._cornerType=void 0,this._cornerTypeSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubsription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var Xj,qj=S(()=>{Ft();mt();Ot();xi();ur();yn();Object.defineProperties(N_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),positions:rt("positions"),shape:rt("shape"),cornerType:rt("cornerType"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});N_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.positions=this.positions,t.shape=this.shape,t.cornerType=this.cornerType,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new N_(this)};N_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.positions=Z(this.positions,t.positions),this.shape=Z(this.shape,t.shape),this.cornerType=Z(this.cornerType,t.cornerType),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};Xj=N_});function F_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._coordinates=void 0,this._coordinatesSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._stRotation=void 0,this._stRotationSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distancedisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var $j,t3=S(()=>{Ft();mt();Ot();xi();ur();yn();Object.defineProperties(F_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),coordinates:rt("coordinates"),height:rt("height"),heightReference:rt("heightReference"),extrudedHeight:rt("extrudedHeight"),extrudedHeightReference:rt("extrudedHeightReference"),rotation:rt("rotation"),stRotation:rt("stRotation"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition"),classificationType:rt("classificationType"),zIndex:rt("zIndex")});F_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.coordinates=this.coordinates,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.rotation=this.rotation,t.stRotation=this.stRotation,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new F_(this)};F_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.coordinates=Z(this.coordinates,t.coordinates),this.height=Z(this.height,t.height),this.heightReference=Z(this.heightReference,t.heightReference),this.extrudedHeight=Z(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=Z(this.extrudedHeightReference,t.extrudedHeightReference),this.rotation=Z(this.rotation,t.rotation),this.stRotation=Z(this.stRotation,t.stRotation),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=Z(this.classificationType,t.classificationType),this.zIndex=Z(this.zIndex,t.zIndex)};$j=F_});function b_(t){this._definitionChanged=new We,this._show=void 0,this._showSubscription=void 0,this._positions=void 0,this._positionsSubscription=void 0,this._minimumHeights=void 0,this._minimumHeightsSubscription=void 0,this._maximumHeights=void 0,this._maximumHeightsSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(Z(t,Z.EMPTY_OBJECT))}var e3,i3=S(()=>{Ft();mt();Ot();xi();ur();yn();Object.defineProperties(b_.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:rt("show"),positions:rt("positions"),minimumHeights:rt("minimumHeights"),maximumHeights:rt("maximumHeights"),granularity:rt("granularity"),fill:rt("fill"),material:wn("material"),outline:rt("outline"),outlineColor:rt("outlineColor"),outlineWidth:rt("outlineWidth"),shadows:rt("shadows"),distanceDisplayCondition:rt("distanceDisplayCondition")});b_.prototype.clone=function(t){return m(t)?(t.show=this.show,t.positions=this.positions,t.minimumHeights=this.minimumHeights,t.maximumHeights=this.maximumHeights,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new b_(this)};b_.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.show=Z(this.show,t.show),this.positions=Z(this.positions,t.positions),this.minimumHeights=Z(this.minimumHeights,t.minimumHeights),this.maximumHeights=Z(this.maximumHeights,t.maximumHeights),this.granularity=Z(this.granularity,t.granularity),this.fill=Z(this.fill,t.fill),this.material=Z(this.material,t.material),this.outline=Z(this.outline,t.outline),this.outlineColor=Z(this.outlineColor,t.outlineColor),this.outlineWidth=Z(this.outlineWidth,t.outlineWidth),this.shadows=Z(this.shadows,t.shadows),this.distanceDisplayCondition=Z(this.distanceDisplayCondition,t.distanceDisplayCondition)};e3=b_});var Cat,Kl,n3=S(()=>{Cat={NONE:0,HOLD:1,EXTRAPOLATE:2},Kl=Object.freeze(Cat)});var gF,s3,o3=S(()=>{mt();Ot();gF={type:"Linear"};gF.getRequiredDataPoints=function(t){return 2};gF.interpolateOrderZero=function(t,e,i,n,s){if(e.length!==2)throw new Y("The xTable provided to the linear interpolator must have exactly two elements.");if(n<=0)throw new Y("There must be at least 1 dependent variable for each independent variable.");m(s)||(s=new Array(n));let o,r,a,h=e[0],A=e[1];if(h===A)throw new Y("Divide by zero error: xTable[0] and xTable[1] are equal");for(o=0;o<n;o++)r=i[o],a=i[o+n],s[o]=((a-r)*t+A*r-h*a)/(A-h);return s};s3=gF});function a3(t,e,i){let n,s=t.length,o=i.length,r=s+o;if(t.length=r,s!==e){let a=s-1;for(n=r-1;n>=e;n--)t[n]=t[a--]}for(n=0;n<o;n++)t[e++]=i[n]}function A3(t,e){return t instanceof Ze?t:typeof t=="string"?Ze.fromIso8601(t):Ze.addSeconds(e,t,new Ze)}function lp(t,e,i,n,s){let o=0,r,a,h,A,d,f;for(;o<n.length;){d=A3(n[o],t),h=Go(e,d,Ze.compare);let E=0,_=0;if(h<0){for(h=~h,A=h*s,a=void 0,f=e[h];o<n.length&&(d=A3(n[o],t),!(m(a)&&Ze.compare(a,d)>=0||m(f)&&Ze.compare(d,f)>=0));){for(TF[E++]=d,o=o+1,r=0;r<s;r++)NF[_++]=n[o],o=o+1;a=d}E>0&&(NF.length=_,a3(i,A,NF),TF.length=E,a3(e,h,TF))}else{for(r=0;r<s;r++)o++,i[h*s+r]=n[o];o++}}}function Ma(t,e){p.defined("type",t);let i=t;i===Number&&(i=r3);let n=i.packedLength,s=Z(i.packedInterpolationLength,n),o=0,r;if(m(e)){let a=e.length;r=new Array(a);for(let h=0;h<a;h++){let A=e[h];A===Number&&(A=r3);let d=A.packedLength;n+=d,s+=Z(A.packedInterpolationLength,d),r[h]=A}o=a}this._type=t,this._innerType=i,this._interpolationDegree=1,this._interpolationAlgorithm=s3,this._numberOfPoints=0,this._times=[],this._values=[],this._xTable=[],this._yTable=[],this._packedLength=n,this._packedInterpolationLength=s,this._updateTableLength=!0,this._interpolationResult=new Array(s),this._definitionChanged=new We,this._derivativeTypes=e,this._innerDerivativeTypes=r,this._inputOrder=o,this._forwardExtrapolationType=Kl.NONE,this._forwardExtrapolationDuration=0,this._backwardExtrapolationType=Kl.NONE,this._backwardExtrapolationDuration=0}function h3(t,e,i){let n=t._packedLength;t._times.splice(e,i),t._values.splice(e*n,i*n),t._updateTableLength=!0,t._definitionChanged.raiseEvent(t)}var r3,TF,NF,dp,FF=S(()=>{sE();ae();Ft();mt();Ot();xi();n3();Or();o3();r3={packedLength:1,pack:function(t,e,i){i=Z(i,0),e[i]=t},unpack:function(t,e,i){return e=Z(e,0),t[e]}};TF=[],NF=[];Object.defineProperties(Ma.prototype,{isConstant:{get:function(){return this._values.length===0}},definitionChanged:{get:function(){return this._definitionChanged}},type:{get:function(){return this._type}},derivativeTypes:{get:function(){return this._derivativeTypes}},interpolationDegree:{get:function(){return this._interpolationDegree}},interpolationAlgorithm:{get:function(){return this._interpolationAlgorithm}},forwardExtrapolationType:{get:function(){return this._forwardExtrapolationType},set:function(t){this._forwardExtrapolationType!==t&&(this._forwardExtrapolationType=t,this._definitionChanged.raiseEvent(this))}},forwardExtrapolationDuration:{get:function(){return this._forwardExtrapolationDuration},set:function(t){this._forwardExtrapolationDuration!==t&&(this._forwardExtrapolationDuration=t,this._definitionChanged.raiseEvent(this))}},backwardExtrapolationType:{get:function(){return this._backwardExtrapolationType},set:function(t){this._backwardExtrapolationType!==t&&(this._backwardExtrapolationType=t,this._definitionChanged.raiseEvent(this))}},backwardExtrapolationDuration:{get:function(){return this._backwardExtrapolationDuration},set:function(t){this._backwardExtrapolationDuration!==t&&(this._backwardExtrapolationDuration=t,this._definitionChanged.raiseEvent(this))}}});Ma.prototype.getValue=function(t,e){p.defined("time",t);let i=this._times,n=i.length;if(n===0)return;let s,o=this._innerType,r=this._values,a=Go(i,t,Ze.compare);if(a<0){if(a=~a,a===0){let F=i[a];if(s=this._backwardExtrapolationDuration,this._backwardExtrapolationType===Kl.NONE||s!==0&&Ze.secondsDifference(F,t)>s)return;if(this._backwardExtrapolationType===Kl.HOLD)return o.unpack(r,0,e)}if(a>=n){a=n-1;let F=i[a];if(s=this._forwardExtrapolationDuration,this._forwardExtrapolationType===Kl.NONE||s!==0&&Ze.secondsDifference(t,F)>s)return;if(this._forwardExtrapolationType===Kl.HOLD)return a=n-1,o.unpack(r,a*o.packedLength,e)}let h=this._xTable,A=this._yTable,d=this._interpolationAlgorithm,f=this._packedInterpolationLength,E=this._inputOrder;if(this._updateTableLength){this._updateTableLength=!1;let F=Math.min(d.getRequiredDataPoints(this._interpolationDegree,E),n);F!==this._numberOfPoints&&(this._numberOfPoints=F,h.length=F,A.length=F*f)}let _=this._numberOfPoints-1;if(_<1)return;let R=0,I=n-1;if(I-R+1>=_+1){let F=a-(_/2|0)-1;F<R&&(F=R);let B=F+_;B>I&&(B=I,F=B-_,F<R&&(F=R)),R=F,I=B}let N=I-R+1;for(let F=0;F<N;++F)h[F]=Ze.secondsDifference(i[R+F],i[I]);if(m(o.convertPackedArrayForInterpolation))o.convertPackedArrayForInterpolation(r,R,I,A);else{let F=0,B=this._packedLength,U=R*B,Q=(I+1)*B;for(;U<Q;)A[F]=r[U],U++,F++}let T=Ze.secondsDifference(t,i[I]),b;if(E===0||!m(d.interpolate))b=d.interpolateOrderZero(T,h,A,f,this._interpolationResult);else{let F=Math.floor(f/(E+1));b=d.interpolate(T,h,A,F,E,E,this._interpolationResult)}return m(o.unpackInterpolationResult)?o.unpackInterpolationResult(b,r,R,I,e):o.unpack(b,0,e)}return o.unpack(r,a*this._packedLength,e)};Ma.prototype.setInterpolationOptions=function(t){if(!m(t))return;let e=!1,i=t.interpolationAlgorithm,n=t.interpolationDegree;m(i)&&this._interpolationAlgorithm!==i&&(this._interpolationAlgorithm=i,e=!0),m(n)&&this._interpolationDegree!==n&&(this._interpolationDegree=n,e=!0),e&&(this._updateTableLength=!0,this._definitionChanged.raiseEvent(this))};Ma.prototype.addSample=function(t,e,i){let n=this._innerDerivativeTypes,s=m(n);p.defined("time",t),p.defined("value",e),s&&p.defined("derivatives",i);let o=this._innerType,r=[];if(r.push(t),o.pack(e,r,r.length),s){let a=n.length;for(let h=0;h<a;h++)n[h].pack(i[h],r,r.length)}lp(void 0,this._times,this._values,r,this._packedLength),this._updateTableLength=!0,this._definitionChanged.raiseEvent(this)};Ma.prototype.addSamples=function(t,e,i){let n=this._innerDerivativeTypes,s=m(n);if(p.defined("times",t),p.defined("values",e),t.length!==e.length)throw new Y("times and values must be the same length.");if(s&&(!m(i)||i.length!==t.length))throw new Y("times and derivativeValues must be the same length.");let o=this._innerType,r=t.length,a=[];for(let h=0;h<r;h++)if(a.push(t[h]),o.pack(e[h],a,a.length),s){let A=i[h],d=n.length;for(let f=0;f<d;f++)n[f].pack(A[f],a,a.length)}lp(void 0,this._times,this._values,a,this._packedLength),this._updateTableLength=!0,this._definitionChanged.raiseEvent(this)};Ma.prototype.addSamplesPackedArray=function(t,e){p.defined("packedSamples",t),lp(e,this._times,this._values,t,this._packedLength),this._updateTableLength=!0,this._definitionChanged.raiseEvent(this)};Ma.prototype.removeSample=function(t){p.defined("time",t);let e=Go(this._times,t,Ze.compare);return e<0?!1:(h3(this,e,1),!0)};Ma.prototype.removeSamples=function(t){p.defined("timeInterval",t);let e=this._times,i=Go(e,t.start,Ze.compare);i<0?i=~i:t.isStartIncluded||++i;let n=Go(e,t.stop,Ze.compare);n<0?n=~n:t.isStopIncluded&&++n,h3(this,i,n-i)};Ma.prototype.equals=function(t){if(this===t)return!0;if(!m(t)||this._type!==t._type||this._interpolationDegree!==t._interpolationDegree||this._interpolationAlgorithm!==t._interpolationAlgorithm)return!1;let e=this._derivativeTypes,i=m(e),n=t._derivativeTypes,s=m(n);if(i!==s)return!1;let o,r;if(i){if(r=e.length,r!==n.length)return!1;for(o=0;o<r;o++)if(e[o]!==n[o])return!1}let a=this._times,h=t._times;if(r=a.length,r!==h.length)return!1;for(o=0;o<r;o++)if(!Ze.equals(a[o],h[o]))return!1;let A=this._values,d=t._values;for(r=A.length,o=0;o<r;o++)if(A[o]!==d[o])return!1;return!0};Ma._mergeNewSamples=lp;dp=Ma});function Fat(t){return new Ij(t)}function bat(t){return rt(t,void 0,Fat)}function ys(t,e){return rt(t,void 0,function(i){return i instanceof e?i:new e(i)})}function sr(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.id;m(e)||(e=Bs()),this._availability=void 0,this._id=e,this._definitionChanged=new We,this._name=t.name,this._show=Z(t.show,!0),this._parent=void 0,this._propertyNames=["billboard","box","corridor","cylinder","description","ellipse","ellipsoid","label","model","tileset","orientation","path","plane","point","polygon","polyline","polylineVolume","position","properties","rectangle","viewFrom","wall","referenceFrame","gltfZForwardYUp",...bF],this._billboard=void 0,this._billboardSubscription=void 0,this._box=void 0,this._boxSubscription=void 0,this._corridor=void 0,this._corridorSubscription=void 0,this._cylinder=void 0,this._cylinderSubscription=void 0,this._description=void 0,this._descriptionSubscription=void 0,this._ellipse=void 0,this._ellipseSubscription=void 0,this._ellipsoid=void 0,this._ellipsoidSubscription=void 0,this._label=void 0,this._labelSubscription=void 0,this._model=void 0,this._modelSubscription=void 0,this._tileset=void 0,this._tilesetSubscription=void 0,this._orientation=void 0,this._orientationSubscription=void 0,this._path=void 0,this._pathSubscription=void 0,this._plane=void 0,this._planeSubscription=void 0,this._point=void 0,this._pointSubscription=void 0,this._polygon=void 0,this._polygonSubscription=void 0,this._polyline=void 0,this._polylineSubscription=void 0,this._polylineVolume=void 0,this._polylineVolumeSubscription=void 0,this._position=void 0,this._positionSubscription=void 0,this._properties=void 0,this._propertiesSubscription=void 0,this._rectangle=void 0,this._rectangleSubscription=void 0,this._viewFrom=void 0,this._viewFromSubscription=void 0,this._wall=void 0,this._wallSubscription=void 0,this._children=[],this.entityCollection=void 0,this._referenceFrame=Z(t.referenceFrame,void 0),this._gltfZForwardYUp=Z(t.gltfZForwardYUp,!1),this.parent=t.parent,this.merge(t)}function YF(t,e,i){let n=e.length;for(let s=0;s<n;s++){let o=e[s],r=o._show;(!i&&r)!==(i&&r)&&YF(o,o._children,i)}t._definitionChanged.raiseEvent(t,"isShowing",i,!i)}var gat,Tat,Nat,bF,VF,c3,l3,of,rf,SF=S(()=>{Ht();ri();ae();ih();Ft();mt();Ot();xi();_e();dn();bi();$s();fr();uJ();cj();Sm();dj();Zj();pj();Cj();yn();gj();Nj();bj();Vj();Oj();Qj();Lj();wj();Pj();jj();vj();Kj();qj();Hl();CF();t3();i3();ic();FF();sE();Or();h_();({eastNorthUpToFixedFrame:gat,getTransformToFixedFrame:Tat}=In),Nat=new ut,bF=[];Object.defineProperties(sr.prototype,{availability:hp("availability"),id:{get:function(){return this._id}},definitionChanged:{get:function(){return this._definitionChanged}},name:hp("name"),show:{get:function(){return this._show},set:function(t){if(!m(t))throw new Y("value is required.");if(t===this._show)return;let e=this.isShowing;this._show=t;let i=this.isShowing;e!==i&&YF(this,this._children,i),this._definitionChanged.raiseEvent(this,"show",t,!t)}},isShowing:{get:function(){return this._show&&(!m(this.entityCollection)||this.entityCollection.show)&&(!m(this._parent)||this._parent.isShowing)}},parent:{get:function(){return this._parent},set:function(t){let e=this._parent;if(e===t)return;let i=this.isShowing;if(m(e)){let s=e._children.indexOf(this);e._children.splice(s,1)}this._parent=t,m(t)&&t._children.push(this);let n=this.isShowing;i!==n&&YF(this,this._children,n),this._definitionChanged.raiseEvent(this,"parent",t,e)}},propertyNames:{get:function(){return this._propertyNames}},billboard:ys("billboard",lj),box:ys("box",Rj),corridor:ys("corridor",uj),cylinder:ys("cylinder",Tj),description:rt("description"),ellipse:ys("ellipse",Fj),ellipsoid:ys("ellipsoid",Yj),label:ys("label",Sj),model:ys("model",Mj),tileset:ys("tileset",kj),orientation:rt("orientation"),path:ys("path",yj),plane:ys("plane",xj),point:ys("point",Jj),polygon:ys("polygon",Hj),polyline:ys("polyline",zj),polylineVolume:ys("polylineVolume",Xj),properties:ys("properties",zl),position:bat("position"),rectangle:ys("rectangle",$j),viewFrom:rt("viewFrom"),wall:ys("wall",e3)});sr.registerEntityType=function(t,e){Object.defineProperties(sr.prototype,{[t]:ys(t,e)}),bF.includes(t)||bF.push(t)};sr.prototype.isAvailable=function(t){if(!m(t))throw new Y("time is required.");let e=this._availability;return!m(e)||e.contains(t)};sr.prototype.addProperty=function(t){let e=this._propertyNames;if(!m(t))throw new Y("propertyName is required.");if(e.indexOf(t)!==-1)throw new Y(`${t} is already a registered property.`);if(t in this)throw new Y(`${t} is a reserved property name.`);e.push(t),Object.defineProperty(this,t,hp(t,!0))};sr.prototype.removeProperty=function(t){let i=this._propertyNames.indexOf(t);if(!m(t))throw new Y("propertyName is required.");if(i===-1)throw new Y(`${t} is not a registered property.`);this._propertyNames.splice(i,1),delete this[t]};sr.prototype.merge=function(t){if(!m(t))throw new Y("source is required.");this.name=Z(this.name,t.name),this.availability=Z(this.availability,t.availability);let e=this._propertyNames,i=m(t._propertyNames)?t._propertyNames:Object.keys(t),n=i.length;for(let s=0;s<n;s++){let o=i[s];if(o==="parent"||o==="name"||o==="availability"||o==="children")continue;let r=this[o],a=t[o];!m(r)&&e.indexOf(o)===-1&&this.addProperty(o),m(a)&&(m(r)?m(r.merge)&&r.merge(a):m(a.merge)&&m(a.clone)?this[o]=a.clone():this[o]=a)}};VF=new lt,c3=new l,l3=new Ae;Object.defineProperties(sr.prototype,{referenceFrame:{get:function(){return this._referenceFrame},set:function(t){Object.values($i).includes(t)&&(this._referenceFrame=t)}},gltfZForwardYUp:{get:function(){return this._gltfZForwardYUp},set:function(t){this._gltfZForwardYUp=t}}});sr.prototype.computeModelMatrix=function(t,e,i=!0,n=void 0){p.typeOf.object("time",t);let s=Si.getValueOrUndefined(this._position,t,c3);if(!m(s))return;let o=Si.getValueOrUndefined(this._orientation,t,l3);o&&~XG.indexOf(this.referenceFrame)&&(o=In.reverseHeadingQuaternion(o));let r=Tat(n||this.referenceFrame,t,this._position);return!m(o)||!i?e=r(s,void 0,e):m(this.referenceFrame)?(In.localToFixedFrameQuaternion(s,o,null,r,o),e=at.fromRotationTranslation(lt.fromQuaternion(o,VF),s,e)):e=at.fromRotationTranslation(lt.fromQuaternion(o,VF),s,e),e};sr.prototype.computeModelMatrixForHeightReference=function(t,e,i,n,s){p.typeOf.object("time",t);let o=Si.getValueOrDefault(e,t,Wr.NONE),r=Si.getValueOrUndefined(this._position,t,c3);if(o===Wr.NONE||!m(r)||l.equalsEpsilon(r,l.ZERO,L.EPSILON8))return this.computeModelMatrix(t,s);let a=n.cartesianToCartographic(r,Nat);gl(o)?a.height=i:a.height+=i,r=n.cartographicToCartesian(a,r);let h=Si.getValueOrUndefined(this._orientation,t,l3);return m(h)?s=at.fromRotationTranslation(lt.fromQuaternion(h,VF),r,s):s=gat(r,void 0,s),s};sr.supportsMaterialsforEntitiesOnTerrain=function(t){return hj.supportsMaterials(t)};sr.supportsPolylinesOnTerrain=function(t){return pJ.isSupported(t)};of=new Ae;sr.prototype.updateAdditiveOrientation=function(t,e){this.orientation||(this.orientation=new Ch(Ae.clone(Ae.IDENTITY)));let i=this.orientation,n=Ae.fromAxisAngle(l.UNIT_X,t.roll),s=Ae.fromAxisAngle(l.UNIT_Y,-t.pitch),o=Ae.fromAxisAngle(l.UNIT_Z,-t.heading),r=new Ae;if(Ae.multiply(s,o,r),Ae.multiply(n,r,r),i instanceof dp){let a=i._times,h=e?Go(a,e,Ze.compare):0;h<0&&(h=~h);let A=i._values[h];Ae.multiply(r,A,of),i._values[h]=Ae.clone(of)}else if(i instanceof Ch){let a=i.getValue();Ae.multiply(a,r,of),Ae.normalize(of,of),i.setValue(Ae.clone(of))}else throw new Y("Unsupported orientation property type.")};rf=sr});function Y_(t){if(t._firing){t._refire=!0;return}if(t._suspendCount===0){let e=t._addedEntities,i=t._removedEntities,n=t._changedEntities;if(n.length!==0||e.length!==0||i.length!==0){t._firing=!0;do{t._refire=!1;let s=e.values.slice(0),o=i.values.slice(0),r=n.values.slice(0);e.removeAll(),i.removeAll(),n.removeAll(),t._collectionChanged.raiseEvent(t,s,o,r)}while(t._refire);t._firing=!1}}}function To(t){this._owner=t,this._entities=new wE,this._addedEntities=new wE,this._removedEntities=new wE,this._changedEntities=new wE,this._suspendCount=0,this._collectionChanged=new We,this._id=Bs(),this._show=!0,this._firing=!1,this._refire=!1}var d3,m3,f3=S(()=>{rw();ih();mt();Ot();xi();hw();Or();lN();SF();d3={id:void 0};To.prototype.suspendEvents=function(){this._suspendCount++};To.prototype.resumeEvents=function(){if(this._suspendCount===0)throw new Y("resumeEvents can not be called before suspendEvents.");this._suspendCount--,Y_(this)};Object.defineProperties(To.prototype,{collectionChanged:{get:function(){return this._collectionChanged}},id:{get:function(){return this._id}},values:{get:function(){return this._entities.values}},show:{get:function(){return this._show},set:function(t){if(!m(t))throw new Y("value is required.");if(t===this._show)return;this.suspendEvents();let e,i=[],n=this._entities.values,s=n.length;for(e=0;e<s;e++)i.push(n[e].isShowing);for(this._show=t,e=0;e<s;e++){let o=i[e],r=n[e];o!==r.isShowing&&r.definitionChanged.raiseEvent(r,"isShowing",r.isShowing,o)}this.resumeEvents()}},owner:{get:function(){return this._owner}}});To.prototype.computeAvailability=function(){let t=dh.MAXIMUM_VALUE,e=dh.MINIMUM_VALUE,i=this._entities.values;for(let n=0,s=i.length;n<s;n++){let r=i[n].availability;if(m(r)){let a=r.start,h=r.stop;Ze.lessThan(a,t)&&!a.equals(dh.MINIMUM_VALUE)&&(t=a),Ze.greaterThan(h,e)&&!h.equals(dh.MAXIMUM_VALUE)&&(e=h)}}return dh.MAXIMUM_VALUE.equals(t)&&(t=dh.MINIMUM_VALUE),dh.MINIMUM_VALUE.equals(e)&&(e=dh.MAXIMUM_VALUE),new NI({start:t,stop:e})};To.prototype.add=function(t){if(!m(t))throw new Y("entity is required.");t instanceof rf||(t=new rf(t));let e=t.id,i=this._entities;if(i.contains(e))throw new Y(`An entity with id ${e} already exists in this collection.`);return t.entityCollection=this,i.set(e,t),this._removedEntities.remove(e)||this._addedEntities.set(e,t),t.definitionChanged.addEventListener(To.prototype._onEntityDefinitionChanged,this),Y_(this),t};To.prototype.remove=function(t){return m(t)?this.removeById(t.id):!1};To.prototype.contains=function(t){if(!m(t))throw new Y("entity is required");return this._entities.get(t.id)===t};To.prototype.removeById=function(t){if(!m(t))return!1;let i=this._entities.get(t);return this._entities.remove(t)?(this._addedEntities.remove(t)||(this._removedEntities.set(t,i),this._changedEntities.remove(t)),this._entities.remove(t),i.definitionChanged.removeEventListener(To.prototype._onEntityDefinitionChanged,this),Y_(this),!0):!1};To.prototype.removeAll=function(){let t=this._entities,e=t.length,i=t.values,n=this._addedEntities,s=this._removedEntities;for(let o=0;o<e;o++){let r=i[o],a=r.id,h=n.get(a);m(h)||(r.definitionChanged.removeEventListener(To.prototype._onEntityDefinitionChanged,this),s.set(a,r))}t.removeAll(),n.removeAll(),this._changedEntities.removeAll(),Y_(this)};To.prototype.getById=function(t){if(!m(t))throw new Y("id is required.");return this._entities.get(t)};To.prototype.getOrCreateEntity=function(t){if(!m(t))throw new Y("id is required.");let e=this._entities.get(t);return m(e)||(d3.id=t,e=new rf(d3),this.add(e)),e};To.prototype._onEntityDefinitionChanged=function(t){let e=t.id;this._addedEntities.contains(e)||this._changedEntities.set(e,t),Y_(this)};m3=To});function OF(t){this._name=t,this._clock=void 0,this._changed=new We,this._error=new We,this._isLoading=!1,this._loading=new We,this._entityCollection=new m3(this),this._entityCluster=new sw}var V_,BF=S(()=>{mt();Ot();xi();$G();ow();f3();Object.defineProperties(OF.prototype,{name:{get:function(){return this._name},set:function(t){this._name!==t&&(this._name=t,this._changed.raiseEvent(this))}},clock:{get:function(){return this._clock},set:function(t){this._clock!==t&&(this._clock=t,this._changed.raiseEvent(this))}},entities:{get:function(){return this._entityCollection}},isLoading:{get:function(){return this._isLoading},set:function(t){qG.setLoading(this,t)}},changedEvent:{get:function(){return this._changed}},errorEvent:{get:function(){return this._error}},loadingEvent:{get:function(){return this._loading}},show:{get:function(){return this._entityCollection.show},set:function(t){this._entityCollection.show=t}},clustering:{get:function(){return this._entityCluster},set:function(t){if(!m(t))throw new Y("value must be defined.");this._entityCluster=t}}});OF.prototype.update=function(t){return!0};V_=OF});function zr(t,e){e=Z(e,0);let i;if(e>0){i=new Array(e);for(let n=0;n<e;n++)i[n]=l}this._numberOfDerivatives=e,this._property=new dp(l,i),this._definitionChanged=new We,this._referenceFrame=Z(t,$i.FIXED),this._property._definitionChanged.addEventListener(function(){this._definitionChanged.raiseEvent(this)},this)}var E3,_3=S(()=>{Ht();ae();Ft();mt();Ot();xi();ic();IF();Hl();FF();Object.defineProperties(zr.prototype,{isConstant:{get:function(){return this._property.isConstant}},definitionChanged:{get:function(){return this._definitionChanged}},referenceFrame:{get:function(){return this._referenceFrame}},interpolationDegree:{get:function(){return this._property.interpolationDegree}},interpolationAlgorithm:{get:function(){return this._property.interpolationAlgorithm}},numberOfDerivatives:{get:function(){return this._numberOfDerivatives}},forwardExtrapolationType:{get:function(){return this._property.forwardExtrapolationType},set:function(t){this._property.forwardExtrapolationType=t}},forwardExtrapolationDuration:{get:function(){return this._property.forwardExtrapolationDuration},set:function(t){this._property.forwardExtrapolationDuration=t}},backwardExtrapolationType:{get:function(){return this._property.backwardExtrapolationType},set:function(t){this._property.backwardExtrapolationType=t}},backwardExtrapolationDuration:{get:function(){return this._property.backwardExtrapolationDuration},set:function(t){this._property.backwardExtrapolationDuration=t}}});zr.prototype.getValue=function(t,e){return this.getValueInReferenceFrame(t,$i.FIXED,e)};zr.prototype.getValueInReferenceFrame=function(t,e,i){if(p.defined("time",t),p.defined("referenceFrame",e),i=this._property.getValue(t,i),m(i))return Ap.convertToReferenceFrame(t,i,this._referenceFrame,e,i)};zr.prototype.setInterpolationOptions=function(t){this._property.setInterpolationOptions(t)};zr.prototype.addSample=function(t,e,i){let n=this._numberOfDerivatives;if(n>0&&(!m(i)||i.length!==n))throw new Y("derivatives length must be equal to the number of derivatives.");this._property.addSample(t,e,i)};zr.prototype.addSamples=function(t,e,i){this._property.addSamples(t,e,i)};zr.prototype.addSamplesPackedArray=function(t,e){this._property.addSamplesPackedArray(t,e)};zr.prototype.removeSample=function(t){return this._property.removeSample(t)};zr.prototype.removeSamples=function(t){this._property.removeSamples(t)};zr.prototype.equals=function(t){return this===t||t instanceof zr&&Si.equals(this._property,t._property)&&this._referenceFrame===t._referenceFrame};E3=zr});var af,or,Cr,ct,Xl=S(()=>{af=2,or=4,Cr=4,ct=4});var Qa,S_,O_,ql,GF=S(()=>{Qa=new Int32Array(2),S_=new Float32Array(Qa.buffer),O_=new Float64Array(Qa.buffer),ql=new Uint16Array(new Uint8Array([1,0]).buffer)[0]===1});var Af,WF=S(()=>{(function(t){t[t.UTF8_BYTES=1]="UTF8_BYTES",t[t.UTF16_STRING=2]="UTF16_STRING"})(Af||(Af={}))});var $l,DF=S(()=>{Xl();GF();WF();$l=class t{constructor(e){this.bytes_=e,this.position_=0,this.text_decoder_=new TextDecoder}static allocate(e){return new t(new Uint8Array(e))}clear(){this.position_=0}bytes(){return this.bytes_}position(){return this.position_}setPosition(e){this.position_=e}capacity(){return this.bytes_.length}readInt8(e){return this.readUint8(e)<<24>>24}readUint8(e){return this.bytes_[e]}readInt16(e){return this.readUint16(e)<<16>>16}readUint16(e){return this.bytes_[e]|this.bytes_[e+1]<<8}readInt32(e){return this.bytes_[e]|this.bytes_[e+1]<<8|this.bytes_[e+2]<<16|this.bytes_[e+3]<<24}readUint32(e){return this.readInt32(e)>>>0}readInt64(e){return BigInt.asIntN(64,BigInt(this.readUint32(e))+(BigInt(this.readUint32(e+4))<<BigInt(32)))}readUint64(e){return BigInt.asUintN(64,BigInt(this.readUint32(e))+(BigInt(this.readUint32(e+4))<<BigInt(32)))}readFloat32(e){return Qa[0]=this.readInt32(e),S_[0]}readFloat64(e){return Qa[ql?0:1]=this.readInt32(e),Qa[ql?1:0]=this.readInt32(e+4),O_[0]}writeInt8(e,i){this.bytes_[e]=i}writeUint8(e,i){this.bytes_[e]=i}writeInt16(e,i){this.bytes_[e]=i,this.bytes_[e+1]=i>>8}writeUint16(e,i){this.bytes_[e]=i,this.bytes_[e+1]=i>>8}writeInt32(e,i){this.bytes_[e]=i,this.bytes_[e+1]=i>>8,this.bytes_[e+2]=i>>16,this.bytes_[e+3]=i>>24}writeUint32(e,i){this.bytes_[e]=i,this.bytes_[e+1]=i>>8,this.bytes_[e+2]=i>>16,this.bytes_[e+3]=i>>24}writeInt64(e,i){this.writeInt32(e,Number(BigInt.asIntN(32,i))),this.writeInt32(e+4,Number(BigInt.asIntN(32,i>>BigInt(32))))}writeUint64(e,i){this.writeUint32(e,Number(BigInt.asUintN(32,i))),this.writeUint32(e+4,Number(BigInt.asUintN(32,i>>BigInt(32))))}writeFloat32(e,i){S_[0]=i,this.writeInt32(e,Qa[0])}writeFloat64(e,i){O_[0]=i,this.writeInt32(e,Qa[ql?0:1]),this.writeInt32(e+4,Qa[ql?1:0])}getBufferIdentifier(){if(this.bytes_.length<this.position_+4+4)throw new Error("FlatBuffers: ByteBuffer is too short to contain an identifier.");let e="";for(let i=0;i<4;i++)e+=String.fromCharCode(this.readInt8(this.position_+4+i));return e}__offset(e,i){let n=e-this.readInt32(e);return i<this.readInt16(n)?this.readInt16(n+i):0}__union(e,i){return e.bb_pos=i+this.readInt32(i),e.bb=this,e}__string(e,i){e+=this.readInt32(e);let n=this.readInt32(e);e+=4;let s=this.bytes_.subarray(e,e+n);return i===Af.UTF8_BYTES?s:this.text_decoder_.decode(s)}__union_with_string(e,i){return typeof e=="string"?this.__string(i):this.__union(e,i)}__indirect(e){return e+this.readInt32(e)}__vector(e){return e+this.readInt32(e)+4}__vector_len(e){return this.readInt32(e+this.readInt32(e))}__has_identifier(e){if(e.length!=4)throw new Error("FlatBuffers: file identifier must be length "+4);for(let i=0;i<4;i++)if(e.charCodeAt(i)!=this.readInt8(this.position()+4+i))return!1;return!0}createScalarList(e,i){let n=[];for(let s=0;s<i;++s){let o=e(s);o!==null&&n.push(o)}return n}createObjList(e,i){let n=[];for(let s=0;s<i;++s){let o=e(s);o!==null&&n.push(o.unpack())}return n}}});var mp,R3=S(()=>{DF();Xl();mp=class t{constructor(e){this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1,this.string_maps=null,this.text_encoder=new TextEncoder;let i;e?i=e:i=1024,this.bb=$l.allocate(i),this.space=i}clear(){this.bb.clear(),this.space=this.bb.capacity(),this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1,this.string_maps=null}forceDefaults(e){this.force_defaults=e}dataBuffer(){return this.bb}asUint8Array(){return this.bb.bytes().subarray(this.bb.position(),this.bb.position()+this.offset())}prep(e,i){e>this.minalign&&(this.minalign=e);let n=~(this.bb.capacity()-this.space+i)+1&e-1;for(;this.space<n+e+i;){let s=this.bb.capacity();this.bb=t.growByteBuffer(this.bb),this.space+=this.bb.capacity()-s}this.pad(n)}pad(e){for(let i=0;i<e;i++)this.bb.writeInt8(--this.space,0)}writeInt8(e){this.bb.writeInt8(this.space-=1,e)}writeInt16(e){this.bb.writeInt16(this.space-=2,e)}writeInt32(e){this.bb.writeInt32(this.space-=4,e)}writeInt64(e){this.bb.writeInt64(this.space-=8,e)}writeFloat32(e){this.bb.writeFloat32(this.space-=4,e)}writeFloat64(e){this.bb.writeFloat64(this.space-=8,e)}addInt8(e){this.prep(1,0),this.writeInt8(e)}addInt16(e){this.prep(2,0),this.writeInt16(e)}addInt32(e){this.prep(4,0),this.writeInt32(e)}addInt64(e){this.prep(8,0),this.writeInt64(e)}addFloat32(e){this.prep(4,0),this.writeFloat32(e)}addFloat64(e){this.prep(8,0),this.writeFloat64(e)}addFieldInt8(e,i,n){(this.force_defaults||i!=n)&&(this.addInt8(i),this.slot(e))}addFieldInt16(e,i,n){(this.force_defaults||i!=n)&&(this.addInt16(i),this.slot(e))}addFieldInt32(e,i,n){(this.force_defaults||i!=n)&&(this.addInt32(i),this.slot(e))}addFieldInt64(e,i,n){(this.force_defaults||i!==n)&&(this.addInt64(i),this.slot(e))}addFieldFloat32(e,i,n){(this.force_defaults||i!=n)&&(this.addFloat32(i),this.slot(e))}addFieldFloat64(e,i,n){(this.force_defaults||i!=n)&&(this.addFloat64(i),this.slot(e))}addFieldOffset(e,i,n){(this.force_defaults||i!=n)&&(this.addOffset(i),this.slot(e))}addFieldStruct(e,i,n){i!=n&&(this.nested(i),this.slot(e))}nested(e){if(e!=this.offset())throw new Error("FlatBuffers: struct must be serialized inline.")}notNested(){if(this.isNested)throw new Error("FlatBuffers: object serialization must not be nested.")}slot(e){this.vtable!==null&&(this.vtable[e]=this.offset())}offset(){return this.bb.capacity()-this.space}static growByteBuffer(e){let i=e.capacity();if(i&3221225472)throw new Error("FlatBuffers: cannot grow buffer beyond 2 gigabytes.");let n=i<<1,s=$l.allocate(n);return s.setPosition(n-i),s.bytes().set(e.bytes(),n-i),s}addOffset(e){this.prep(4,0),this.writeInt32(this.offset()-e+4)}startObject(e){this.notNested(),this.vtable==null&&(this.vtable=[]),this.vtable_in_use=e;for(let i=0;i<e;i++)this.vtable[i]=0;this.isNested=!0,this.object_start=this.offset()}endObject(){if(this.vtable==null||!this.isNested)throw new Error("FlatBuffers: endObject called without startObject");this.addInt32(0);let e=this.offset(),i=this.vtable_in_use-1;for(;i>=0&&this.vtable[i]==0;i--);let n=i+1;for(;i>=0;i--)this.addInt16(this.vtable[i]!=0?e-this.vtable[i]:0);let s=2;this.addInt16(e-this.object_start);let o=(n+s)*2;this.addInt16(o);let r=0,a=this.space;t:for(i=0;i<this.vtables.length;i++){let h=this.bb.capacity()-this.vtables[i];if(o==this.bb.readInt16(h)){for(let A=2;A<o;A+=2)if(this.bb.readInt16(a+A)!=this.bb.readInt16(h+A))continue t;r=this.vtables[i];break}}return r?(this.space=this.bb.capacity()-e,this.bb.writeInt32(this.space,r-e)):(this.vtables.push(this.offset()),this.bb.writeInt32(this.bb.capacity()-e,this.offset()-e)),this.isNested=!1,e}finish(e,i,n){let s=n?4:0;if(i){let o=i;if(this.prep(this.minalign,8+s),o.length!=4)throw new Error("FlatBuffers: file identifier must be length "+4);for(let r=3;r>=0;r--)this.writeInt8(o.charCodeAt(r))}this.prep(this.minalign,4+s),this.addOffset(e),s&&this.addInt32(this.bb.capacity()-this.space),this.bb.setPosition(this.space)}finishSizePrefixed(e,i){this.finish(e,i,!0)}requiredField(e,i){let n=this.bb.capacity()-e,s=n-this.bb.readInt32(n);if(!(i<this.bb.readInt16(s)&&this.bb.readInt16(s+i)!=0))throw new Error("FlatBuffers: field "+i+" must be set")}startVector(e,i,n){this.notNested(),this.vector_num_elems=i,this.prep(4,e*i),this.prep(n,e*i)}endVector(){return this.writeInt32(this.vector_num_elems),this.offset()}createSharedString(e){if(!e)return 0;if(this.string_maps||(this.string_maps=new Map),this.string_maps.has(e))return this.string_maps.get(e);let i=this.createString(e);return this.string_maps.set(e,i),i}createString(e){if(e==null)return 0;let i;e instanceof Uint8Array?i=e:i=this.text_encoder.encode(e),this.addInt8(0),this.startVector(1,i.length,1),this.bb.setPosition(this.space-=i.length);for(let n=0,s=this.space,o=this.bb.bytes();n<i.length;n++)o[s++]=i[n];return this.endVector()}createObjectOffset(e){return e===null?0:typeof e=="string"?this.createString(e):e.pack(this)}createObjectOffsetList(e){let i=[];for(let n=0;n<e.length;++n){let s=e[n];if(s!==null)i.push(this.createObjectOffset(s));else throw new Error("FlatBuffers: Argument for createObjectOffsetList cannot contain null.")}return i}createStructOffsetList(e,i){return i(this,e.length),this.createObjectOffsetList(e.slice().reverse()),this.endVector()}}});var Et={};He(Et,{Builder:()=>mp,ByteBuffer:()=>$l,Encoding:()=>Af,FILE_IDENTIFIER_LENGTH:()=>Cr,SIZEOF_INT:()=>or,SIZEOF_SHORT:()=>af,SIZE_PREFIX_LENGTH:()=>ct,float32:()=>S_,float64:()=>O_,int32:()=>Qa,isLittleEndian:()=>ql});var _t=S(()=>{Xl();Xl();Xl();Xl();GF();WF();R3();DF()});var Yat,UF,Z3=S(()=>{_t();({ByteBuffer:Yat}=Et),UF=(t,e,i)=>{t=new Uint8Array(t);let n=new i[`${e}COLLECTIONT`];return i[`${e}COLLECTION`][`getRootAs${e}COLLECTION`](new Yat(t)).unpackTo(n),n}});var MF=S(()=>{_t()});var I3=S(()=>{_t();MF()});var p3=S(()=>{MF();I3()});var ka,B_,fp=S(()=>{_t();ka=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsFrequencyRange(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsFrequencyRange(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}LOWER(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat64(this.bb_pos+e):0}static startFrequencyRange(e){e.startObject(2)}static addLower(e,i){e.addFieldFloat64(0,i,0)}static addUpper(e,i){e.addFieldFloat64(1,i,0)}static endFrequencyRange(e){return e.endObject()}static createFrequencyRange(e,i,n){return t.startFrequencyRange(e),t.addLower(e,i),t.addUpper(e,n),t.endFrequencyRange(e)}unpack(){return new B_(this.LOWER(),this.UPPER())}unpackTo(e){e.LOWER=this.LOWER(),e.UPPER=this.UPPER()}},B_=class{constructor(e=0,i=0){this.LOWER=e,this.UPPER=i}pack(e){return ka.createFrequencyRange(e,this.LOWER,this.UPPER)}}});var FA,G_,QF=S(()=>{_t();fp();FA=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsBand(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsBand(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}NAME(e){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__string(this.bb_pos+i,e):null}FREQUENCY_RANGE(e){let i=this.bb.__offset(this.bb_pos,6);return i?(e||new ka).__init(this.bb.__indirect(this.bb_pos+i),this.bb):null}static startBand(e){e.startObject(2)}static addName(e,i){e.addFieldOffset(0,i,0)}static addFrequencyRange(e,i){e.addFieldOffset(1,i,0)}static endBand(e){return e.endObject()}unpack(){return new G_(this.NAME(),this.FREQUENCY_RANGE()!==null?this.FREQUENCY_RANGE().unpack():null)}unpackTo(e){e.NAME=this.NAME(),e.FREQUENCY_RANGE=this.FREQUENCY_RANGE()!==null?this.FREQUENCY_RANGE().unpack():null}},G_=class{constructor(e=null,i=null){this.NAME=e,this.FREQUENCY_RANGE=i}pack(e){let i=this.NAME!==null?e.createString(this.NAME):0,n=this.FREQUENCY_RANGE!==null?this.FREQUENCY_RANGE.pack(e):0;return FA.startBand(e),FA.addName(e,i),FA.addFrequencyRange(e,n),FA.endBand(e)}}});var Nc,kF=S(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(Nc||(Nc={}))});var Fc,LF=S(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(Fc||(Fc={}))});var bc,yF=S(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(bc||(bc={}))});var Yc,wF=S(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(Yc||(Yc={}))});var td,W_,xF=S(()=>{_t();td=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsStokesParameters(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsStokesParameters(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}I(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}Q(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat64(this.bb_pos+e):0}U(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readFloat64(this.bb_pos+e):0}V(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readFloat64(this.bb_pos+e):0}static startStokesParameters(e){e.startObject(4)}static addI(e,i){e.addFieldFloat64(0,i,0)}static addQ(e,i){e.addFieldFloat64(1,i,0)}static addU(e,i){e.addFieldFloat64(2,i,0)}static addV(e,i){e.addFieldFloat64(3,i,0)}static endStokesParameters(e){return e.endObject()}static createStokesParameters(e,i,n,s,o){return t.startStokesParameters(e),t.addI(e,i),t.addQ(e,n),t.addU(e,s),t.addV(e,o),t.endStokesParameters(e)}unpack(){return new W_(this.I(),this.Q(),this.U(),this.V())}unpackTo(e){e.I=this.I(),e.Q=this.Q(),e.U=this.U(),e.V=this.V()}},W_=class{constructor(e=0,i=0,n=0,s=0){this.I=e,this.Q=i,this.U=n,this.V=s}pack(e){return td.createStokesParameters(e,this.I,this.Q,this.U,this.V)}}});var Zi,D_,Ep=S(()=>{_t();QF();kF();LF();fp();yF();wF();xF();Zi=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsIDM(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsIDM(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$IDM")}ID(e){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__string(this.bb_pos+i,e):null}NAME(e){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__string(this.bb_pos+i,e):null}DATA_MODE(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readInt8(this.bb_pos+e):Nc.REAL}UPLINK(e){let i=this.bb.__offset(this.bb_pos,10);return i?(e||new ka).__init(this.bb.__indirect(this.bb_pos+i),this.bb):null}DOWNLINK(e){let i=this.bb.__offset(this.bb_pos,12);return i?(e||new ka).__init(this.bb.__indirect(this.bb_pos+i),this.bb):null}BEACON(e){let i=this.bb.__offset(this.bb_pos,14);return i?(e||new ka).__init(this.bb.__indirect(this.bb_pos+i),this.bb):null}BAND(e,i){let n=this.bb.__offset(this.bb_pos,16);return n?(i||new FA).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}bandLength(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.__vector_len(this.bb_pos+e):0}POLARIZATION_TYPE(){let e=this.bb.__offset(this.bb_pos,18);return e?this.bb.readInt8(this.bb_pos+e):bc.linear}SIMPLE_POLARIZATION(){let e=this.bb.__offset(this.bb_pos,20);return e?this.bb.readInt8(this.bb_pos+e):Yc.vertical}STOKES_PARAMETERS(e){let i=this.bb.__offset(this.bb_pos,22);return i?(e||new td).__init(this.bb.__indirect(this.bb_pos+i),this.bb):null}POWER_REQUIRED(){let e=this.bb.__offset(this.bb_pos,24);return e?this.bb.readFloat64(this.bb_pos+e):0}POWER_TYPE(e){let i=this.bb.__offset(this.bb_pos,26);return i?this.bb.__string(this.bb_pos+i,e):null}TRANSMIT(){let e=this.bb.__offset(this.bb_pos,28);return e?!!this.bb.readInt8(this.bb_pos+e):!1}RECEIVE(){let e=this.bb.__offset(this.bb_pos,30);return e?!!this.bb.readInt8(this.bb_pos+e):!1}SENSOR_TYPE(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readInt8(this.bb_pos+e):Fc.UNKNOWN}SOURCE(e){let i=this.bb.__offset(this.bb_pos,34);return i?this.bb.__string(this.bb_pos+i,e):null}LAST_OB_TIME(e){let i=this.bb.__offset(this.bb_pos,36);return i?this.bb.__string(this.bb_pos+i,e):null}LOWER_LEFT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,38);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_LEFT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,40);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_RIGHT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_LEFT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_RIGHT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_RIGHT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_RIGHT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,50);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_LEFT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,52);return e?this.bb.readFloat64(this.bb_pos+e):0}RIGHT_GEO_BELT_LIMIT(){let e=this.bb.__offset(this.bb_pos,54);return e?this.bb.readFloat64(this.bb_pos+e):0}LEFT_GEO_BELT_LIMIT(){let e=this.bb.__offset(this.bb_pos,56);return e?this.bb.readFloat64(this.bb_pos+e):0}MAGNITUDE_LIMIT(){let e=this.bb.__offset(this.bb_pos,58);return e?this.bb.readFloat64(this.bb_pos+e):0}TASKABLE(){let e=this.bb.__offset(this.bb_pos,60);return e?!!this.bb.readInt8(this.bb_pos+e):!1}static startIDM(e){e.startObject(29)}static addId(e,i){e.addFieldOffset(0,i,0)}static addName(e,i){e.addFieldOffset(1,i,0)}static addDataMode(e,i){e.addFieldInt8(2,i,Nc.REAL)}static addUplink(e,i){e.addFieldOffset(3,i,0)}static addDownlink(e,i){e.addFieldOffset(4,i,0)}static addBeacon(e,i){e.addFieldOffset(5,i,0)}static addBand(e,i){e.addFieldOffset(6,i,0)}static createBandVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startBandVector(e,i){e.startVector(4,i,4)}static addPolarizationType(e,i){e.addFieldInt8(7,i,bc.linear)}static addSimplePolarization(e,i){e.addFieldInt8(8,i,Yc.vertical)}static addStokesParameters(e,i){e.addFieldOffset(9,i,0)}static addPowerRequired(e,i){e.addFieldFloat64(10,i,0)}static addPowerType(e,i){e.addFieldOffset(11,i,0)}static addTransmit(e,i){e.addFieldInt8(12,+i,0)}static addReceive(e,i){e.addFieldInt8(13,+i,0)}static addSensorType(e,i){e.addFieldInt8(14,i,Fc.UNKNOWN)}static addSource(e,i){e.addFieldOffset(15,i,0)}static addLastObTime(e,i){e.addFieldOffset(16,i,0)}static addLowerLeftElevationLimit(e,i){e.addFieldFloat64(17,i,0)}static addUpperLeftAzimuthLimit(e,i){e.addFieldFloat64(18,i,0)}static addLowerRightElevationLimit(e,i){e.addFieldFloat64(19,i,0)}static addLowerLeftAzimuthLimit(e,i){e.addFieldFloat64(20,i,0)}static addUpperRightElevationLimit(e,i){e.addFieldFloat64(21,i,0)}static addUpperRightAzimuthLimit(e,i){e.addFieldFloat64(22,i,0)}static addLowerRightAzimuthLimit(e,i){e.addFieldFloat64(23,i,0)}static addUpperLeftElevationLimit(e,i){e.addFieldFloat64(24,i,0)}static addRightGeoBeltLimit(e,i){e.addFieldFloat64(25,i,0)}static addLeftGeoBeltLimit(e,i){e.addFieldFloat64(26,i,0)}static addMagnitudeLimit(e,i){e.addFieldFloat64(27,i,0)}static addTaskable(e,i){e.addFieldInt8(28,+i,0)}static endIDM(e){return e.endObject()}static finishIDMBuffer(e,i){e.finish(i,"$IDM")}static finishSizePrefixedIDMBuffer(e,i){e.finish(i,"$IDM",!0)}unpack(){return new D_(this.ID(),this.NAME(),this.DATA_MODE(),this.UPLINK()!==null?this.UPLINK().unpack():null,this.DOWNLINK()!==null?this.DOWNLINK().unpack():null,this.BEACON()!==null?this.BEACON().unpack():null,this.bb.createObjList(this.BAND.bind(this),this.bandLength()),this.POLARIZATION_TYPE(),this.SIMPLE_POLARIZATION(),this.STOKES_PARAMETERS()!==null?this.STOKES_PARAMETERS().unpack():null,this.POWER_REQUIRED(),this.POWER_TYPE(),this.TRANSMIT(),this.RECEIVE(),this.SENSOR_TYPE(),this.SOURCE(),this.LAST_OB_TIME(),this.LOWER_LEFT_ELEVATION_LIMIT(),this.UPPER_LEFT_AZIMUTH_LIMIT(),this.LOWER_RIGHT_ELEVATION_LIMIT(),this.LOWER_LEFT_AZIMUTH_LIMIT(),this.UPPER_RIGHT_ELEVATION_LIMIT(),this.UPPER_RIGHT_AZIMUTH_LIMIT(),this.LOWER_RIGHT_AZIMUTH_LIMIT(),this.UPPER_LEFT_ELEVATION_LIMIT(),this.RIGHT_GEO_BELT_LIMIT(),this.LEFT_GEO_BELT_LIMIT(),this.MAGNITUDE_LIMIT(),this.TASKABLE())}unpackTo(e){e.ID=this.ID(),e.NAME=this.NAME(),e.DATA_MODE=this.DATA_MODE(),e.UPLINK=this.UPLINK()!==null?this.UPLINK().unpack():null,e.DOWNLINK=this.DOWNLINK()!==null?this.DOWNLINK().unpack():null,e.BEACON=this.BEACON()!==null?this.BEACON().unpack():null,e.BAND=this.bb.createObjList(this.BAND.bind(this),this.bandLength()),e.POLARIZATION_TYPE=this.POLARIZATION_TYPE(),e.SIMPLE_POLARIZATION=this.SIMPLE_POLARIZATION(),e.STOKES_PARAMETERS=this.STOKES_PARAMETERS()!==null?this.STOKES_PARAMETERS().unpack():null,e.POWER_REQUIRED=this.POWER_REQUIRED(),e.POWER_TYPE=this.POWER_TYPE(),e.TRANSMIT=this.TRANSMIT(),e.RECEIVE=this.RECEIVE(),e.SENSOR_TYPE=this.SENSOR_TYPE(),e.SOURCE=this.SOURCE(),e.LAST_OB_TIME=this.LAST_OB_TIME(),e.LOWER_LEFT_ELEVATION_LIMIT=this.LOWER_LEFT_ELEVATION_LIMIT(),e.UPPER_LEFT_AZIMUTH_LIMIT=this.UPPER_LEFT_AZIMUTH_LIMIT(),e.LOWER_RIGHT_ELEVATION_LIMIT=this.LOWER_RIGHT_ELEVATION_LIMIT(),e.LOWER_LEFT_AZIMUTH_LIMIT=this.LOWER_LEFT_AZIMUTH_LIMIT(),e.UPPER_RIGHT_ELEVATION_LIMIT=this.UPPER_RIGHT_ELEVATION_LIMIT(),e.UPPER_RIGHT_AZIMUTH_LIMIT=this.UPPER_RIGHT_AZIMUTH_LIMIT(),e.LOWER_RIGHT_AZIMUTH_LIMIT=this.LOWER_RIGHT_AZIMUTH_LIMIT(),e.UPPER_LEFT_ELEVATION_LIMIT=this.UPPER_LEFT_ELEVATION_LIMIT(),e.RIGHT_GEO_BELT_LIMIT=this.RIGHT_GEO_BELT_LIMIT(),e.LEFT_GEO_BELT_LIMIT=this.LEFT_GEO_BELT_LIMIT(),e.MAGNITUDE_LIMIT=this.MAGNITUDE_LIMIT(),e.TASKABLE=this.TASKABLE()}},D_=class{constructor(e=null,i=null,n=Nc.REAL,s=null,o=null,r=null,a=[],h=bc.linear,A=Yc.vertical,d=null,f=0,E=null,_=!1,R=!1,I=Fc.UNKNOWN,C=null,N=null,T=0,b=0,F=0,B=0,U=0,Q=0,M=0,k=0,y=0,c=0,g=0,O=!1){this.ID=e,this.NAME=i,this.DATA_MODE=n,this.UPLINK=s,this.DOWNLINK=o,this.BEACON=r,this.BAND=a,this.POLARIZATION_TYPE=h,this.SIMPLE_POLARIZATION=A,this.STOKES_PARAMETERS=d,this.POWER_REQUIRED=f,this.POWER_TYPE=E,this.TRANSMIT=_,this.RECEIVE=R,this.SENSOR_TYPE=I,this.SOURCE=C,this.LAST_OB_TIME=N,this.LOWER_LEFT_ELEVATION_LIMIT=T,this.UPPER_LEFT_AZIMUTH_LIMIT=b,this.LOWER_RIGHT_ELEVATION_LIMIT=F,this.LOWER_LEFT_AZIMUTH_LIMIT=B,this.UPPER_RIGHT_ELEVATION_LIMIT=U,this.UPPER_RIGHT_AZIMUTH_LIMIT=Q,this.LOWER_RIGHT_AZIMUTH_LIMIT=M,this.UPPER_LEFT_ELEVATION_LIMIT=k,this.RIGHT_GEO_BELT_LIMIT=y,this.LEFT_GEO_BELT_LIMIT=c,this.MAGNITUDE_LIMIT=g,this.TASKABLE=O}pack(e){let i=this.ID!==null?e.createString(this.ID):0,n=this.NAME!==null?e.createString(this.NAME):0,s=this.UPLINK!==null?this.UPLINK.pack(e):0,o=this.DOWNLINK!==null?this.DOWNLINK.pack(e):0,r=this.BEACON!==null?this.BEACON.pack(e):0,a=Zi.createBandVector(e,e.createObjectOffsetList(this.BAND)),h=this.STOKES_PARAMETERS!==null?this.STOKES_PARAMETERS.pack(e):0,A=this.POWER_TYPE!==null?e.createString(this.POWER_TYPE):0,d=this.SOURCE!==null?e.createString(this.SOURCE):0,f=this.LAST_OB_TIME!==null?e.createString(this.LAST_OB_TIME):0;return Zi.startIDM(e),Zi.addId(e,i),Zi.addName(e,n),Zi.addDataMode(e,this.DATA_MODE),Zi.addUplink(e,s),Zi.addDownlink(e,o),Zi.addBeacon(e,r),Zi.addBand(e,a),Zi.addPolarizationType(e,this.POLARIZATION_TYPE),Zi.addSimplePolarization(e,this.SIMPLE_POLARIZATION),Zi.addStokesParameters(e,h),Zi.addPowerRequired(e,this.POWER_REQUIRED),Zi.addPowerType(e,A),Zi.addTransmit(e,this.TRANSMIT),Zi.addReceive(e,this.RECEIVE),Zi.addSensorType(e,this.SENSOR_TYPE),Zi.addSource(e,d),Zi.addLastObTime(e,f),Zi.addLowerLeftElevationLimit(e,this.LOWER_LEFT_ELEVATION_LIMIT),Zi.addUpperLeftAzimuthLimit(e,this.UPPER_LEFT_AZIMUTH_LIMIT),Zi.addLowerRightElevationLimit(e,this.LOWER_RIGHT_ELEVATION_LIMIT),Zi.addLowerLeftAzimuthLimit(e,this.LOWER_LEFT_AZIMUTH_LIMIT),Zi.addUpperRightElevationLimit(e,this.UPPER_RIGHT_ELEVATION_LIMIT),Zi.addUpperRightAzimuthLimit(e,this.UPPER_RIGHT_AZIMUTH_LIMIT),Zi.addLowerRightAzimuthLimit(e,this.LOWER_RIGHT_AZIMUTH_LIMIT),Zi.addUpperLeftElevationLimit(e,this.UPPER_LEFT_ELEVATION_LIMIT),Zi.addRightGeoBeltLimit(e,this.RIGHT_GEO_BELT_LIMIT),Zi.addLeftGeoBeltLimit(e,this.LEFT_GEO_BELT_LIMIT),Zi.addMagnitudeLimit(e,this.MAGNITUDE_LIMIT),Zi.addTaskable(e,this.TASKABLE),Zi.endIDM(e)}}});var bA,U_,_p=S(()=>{_t();Ep();bA=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsPLD(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsPLD(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$PLD")}PAYLOAD_DURATION(e){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__string(this.bb_pos+i,e):null}MASS_AT_LAUNCH(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat32(this.bb_pos+e):0}DIMENSIONS(e){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__string(this.bb_pos+i,e):null}SOLAR_ARRAY_AREA(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readFloat32(this.bb_pos+e):0}SOLAR_ARRAY_DIMENSIONS(e){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.__string(this.bb_pos+i,e):null}NOMINAL_OPERATIONAL_LIFETIME(e){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.__string(this.bb_pos+i,e):null}INSTRUMENTS(e,i){let n=this.bb.__offset(this.bb_pos,16);return n?(i||new Zi).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}instrumentsLength(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.__vector_len(this.bb_pos+e):0}static startPLD(e){e.startObject(7)}static addPayloadDuration(e,i){e.addFieldOffset(0,i,0)}static addMassAtLaunch(e,i){e.addFieldFloat32(1,i,0)}static addDimensions(e,i){e.addFieldOffset(2,i,0)}static addSolarArrayArea(e,i){e.addFieldFloat32(3,i,0)}static addSolarArrayDimensions(e,i){e.addFieldOffset(4,i,0)}static addNominalOperationalLifetime(e,i){e.addFieldOffset(5,i,0)}static addInstruments(e,i){e.addFieldOffset(6,i,0)}static createInstrumentsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startInstrumentsVector(e,i){e.startVector(4,i,4)}static endPLD(e){return e.endObject()}static finishPLDBuffer(e,i){e.finish(i,"$PLD")}static finishSizePrefixedPLDBuffer(e,i){e.finish(i,"$PLD",!0)}static createPLD(e,i,n,s,o,r,a,h){return t.startPLD(e),t.addPayloadDuration(e,i),t.addMassAtLaunch(e,n),t.addDimensions(e,s),t.addSolarArrayArea(e,o),t.addSolarArrayDimensions(e,r),t.addNominalOperationalLifetime(e,a),t.addInstruments(e,h),t.endPLD(e)}unpack(){return new U_(this.PAYLOAD_DURATION(),this.MASS_AT_LAUNCH(),this.DIMENSIONS(),this.SOLAR_ARRAY_AREA(),this.SOLAR_ARRAY_DIMENSIONS(),this.NOMINAL_OPERATIONAL_LIFETIME(),this.bb.createObjList(this.INSTRUMENTS.bind(this),this.instrumentsLength()))}unpackTo(e){e.PAYLOAD_DURATION=this.PAYLOAD_DURATION(),e.MASS_AT_LAUNCH=this.MASS_AT_LAUNCH(),e.DIMENSIONS=this.DIMENSIONS(),e.SOLAR_ARRAY_AREA=this.SOLAR_ARRAY_AREA(),e.SOLAR_ARRAY_DIMENSIONS=this.SOLAR_ARRAY_DIMENSIONS(),e.NOMINAL_OPERATIONAL_LIFETIME=this.NOMINAL_OPERATIONAL_LIFETIME(),e.INSTRUMENTS=this.bb.createObjList(this.INSTRUMENTS.bind(this),this.instrumentsLength())}},U_=class{constructor(e=null,i=0,n=null,s=0,o=null,r=null,a=[]){this.PAYLOAD_DURATION=e,this.MASS_AT_LAUNCH=i,this.DIMENSIONS=n,this.SOLAR_ARRAY_AREA=s,this.SOLAR_ARRAY_DIMENSIONS=o,this.NOMINAL_OPERATIONAL_LIFETIME=r,this.INSTRUMENTS=a}pack(e){let i=this.PAYLOAD_DURATION!==null?e.createString(this.PAYLOAD_DURATION):0,n=this.DIMENSIONS!==null?e.createString(this.DIMENSIONS):0,s=this.SOLAR_ARRAY_DIMENSIONS!==null?e.createString(this.SOLAR_ARRAY_DIMENSIONS):0,o=this.NOMINAL_OPERATIONAL_LIFETIME!==null?e.createString(this.NOMINAL_OPERATIONAL_LIFETIME):0,r=bA.createInstrumentsVector(e,e.createObjectOffsetList(this.INSTRUMENTS));return bA.createPLD(e,i,this.MASS_AT_LAUNCH,n,this.SOLAR_ARRAY_AREA,s,o,r)}}});var Vc,PF=S(()=>{(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(Vc||(Vc={}))});var Sc,JF=S(()=>{(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(Sc||(Sc={}))});var Oc,jF=S(()=>{(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(Oc||(Oc={}))});var Bc,HF=S(()=>{(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(Bc||(Bc={}))});var Gc,vF=S(()=>{(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(Gc||(Gc={}))});var Wc,M_,zF=S(()=>{_t();_p();PF();JF();jF();HF();vF();Wc=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsCAT(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsCAT(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$CAT")}OBJECT_NAME(e){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__string(this.bb_pos+i,e):null}OBJECT_ID(e){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__string(this.bb_pos+i,e):null}NORAD_CAT_ID(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readUint32(this.bb_pos+e):0}OBJECT_TYPE(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readInt8(this.bb_pos+e):Oc.UNKNOWN}OPS_STATUS_CODE(){let e=this.bb.__offset(this.bb_pos,12);return e?this.bb.readInt8(this.bb_pos+e):Bc.UNKNOWN}OWNER(e){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.__string(this.bb_pos+i,e):null}LAUNCH_DATE(e){let i=this.bb.__offset(this.bb_pos,16);return i?this.bb.__string(this.bb_pos+i,e):null}LAUNCH_SITE(e){let i=this.bb.__offset(this.bb_pos,18);return i?this.bb.__string(this.bb_pos+i,e):null}DECAY_DATE(e){let i=this.bb.__offset(this.bb_pos,20);return i?this.bb.__string(this.bb_pos+i,e):null}PERIOD(){let e=this.bb.__offset(this.bb_pos,22);return e?this.bb.readFloat64(this.bb_pos+e):0}INCLINATION(){let e=this.bb.__offset(this.bb_pos,24);return e?this.bb.readFloat64(this.bb_pos+e):0}APOGEE(){let e=this.bb.__offset(this.bb_pos,26);return e?this.bb.readFloat64(this.bb_pos+e):0}PERIGEE(){let e=this.bb.__offset(this.bb_pos,28);return e?this.bb.readFloat64(this.bb_pos+e):0}RCS(){let e=this.bb.__offset(this.bb_pos,30);return e?this.bb.readFloat64(this.bb_pos+e):0}DATA_STATUS_CODE(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readInt8(this.bb_pos+e):Vc.NO_CURRENT_ELEMENTS}ORBIT_CENTER(e){let i=this.bb.__offset(this.bb_pos,34);return i?this.bb.__string(this.bb_pos+i,e):null}ORBIT_TYPE(){let e=this.bb.__offset(this.bb_pos,36);return e?this.bb.readInt8(this.bb_pos+e):Gc.ORBIT}DEPLOYMENT_DATE(e){let i=this.bb.__offset(this.bb_pos,38);return i?this.bb.__string(this.bb_pos+i,e):null}MANEUVERABLE(){let e=this.bb.__offset(this.bb_pos,40);return e?!!this.bb.readInt8(this.bb_pos+e):!1}SIZE(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS_TYPE(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readInt8(this.bb_pos+e):Sc.DRY}PAYLOADS(e,i){let n=this.bb.__offset(this.bb_pos,48);return n?(i||new bA).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}payloadsLength(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.__vector_len(this.bb_pos+e):0}static startCAT(e){e.startObject(23)}static addObjectName(e,i){e.addFieldOffset(0,i,0)}static addObjectId(e,i){e.addFieldOffset(1,i,0)}static addNoradCatId(e,i){e.addFieldInt32(2,i,0)}static addObjectType(e,i){e.addFieldInt8(3,i,Oc.UNKNOWN)}static addOpsStatusCode(e,i){e.addFieldInt8(4,i,Bc.UNKNOWN)}static addOwner(e,i){e.addFieldOffset(5,i,0)}static addLaunchDate(e,i){e.addFieldOffset(6,i,0)}static addLaunchSite(e,i){e.addFieldOffset(7,i,0)}static addDecayDate(e,i){e.addFieldOffset(8,i,0)}static addPeriod(e,i){e.addFieldFloat64(9,i,0)}static addInclination(e,i){e.addFieldFloat64(10,i,0)}static addApogee(e,i){e.addFieldFloat64(11,i,0)}static addPerigee(e,i){e.addFieldFloat64(12,i,0)}static addRcs(e,i){e.addFieldFloat64(13,i,0)}static addDataStatusCode(e,i){e.addFieldInt8(14,i,Vc.NO_CURRENT_ELEMENTS)}static addOrbitCenter(e,i){e.addFieldOffset(15,i,0)}static addOrbitType(e,i){e.addFieldInt8(16,i,Gc.ORBIT)}static addDeploymentDate(e,i){e.addFieldOffset(17,i,0)}static addManeuverable(e,i){e.addFieldInt8(18,+i,0)}static addSize(e,i){e.addFieldFloat64(19,i,0)}static addMass(e,i){e.addFieldFloat64(20,i,0)}static addMassType(e,i){e.addFieldInt8(21,i,Sc.DRY)}static addPayloads(e,i){e.addFieldOffset(22,i,0)}static createPayloadsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startPayloadsVector(e,i){e.startVector(4,i,4)}static endCAT(e){return e.endObject()}static finishCATBuffer(e,i){e.finish(i,"$CAT")}static finishSizePrefixedCATBuffer(e,i){e.finish(i,"$CAT",!0)}static createCAT(e,i,n,s,o,r,a,h,A,d,f,E,_,R,I,C,N,T,b,F,B,U,Q,M){return t.startCAT(e),t.addObjectName(e,i),t.addObjectId(e,n),t.addNoradCatId(e,s),t.addObjectType(e,o),t.addOpsStatusCode(e,r),t.addOwner(e,a),t.addLaunchDate(e,h),t.addLaunchSite(e,A),t.addDecayDate(e,d),t.addPeriod(e,f),t.addInclination(e,E),t.addApogee(e,_),t.addPerigee(e,R),t.addRcs(e,I),t.addDataStatusCode(e,C),t.addOrbitCenter(e,N),t.addOrbitType(e,T),t.addDeploymentDate(e,b),t.addManeuverable(e,F),t.addSize(e,B),t.addMass(e,U),t.addMassType(e,Q),t.addPayloads(e,M),t.endCAT(e)}unpack(){return new M_(this.OBJECT_NAME(),this.OBJECT_ID(),this.NORAD_CAT_ID(),this.OBJECT_TYPE(),this.OPS_STATUS_CODE(),this.OWNER(),this.LAUNCH_DATE(),this.LAUNCH_SITE(),this.DECAY_DATE(),this.PERIOD(),this.INCLINATION(),this.APOGEE(),this.PERIGEE(),this.RCS(),this.DATA_STATUS_CODE(),this.ORBIT_CENTER(),this.ORBIT_TYPE(),this.DEPLOYMENT_DATE(),this.MANEUVERABLE(),this.SIZE(),this.MASS(),this.MASS_TYPE(),this.bb.createObjList(this.PAYLOADS.bind(this),this.payloadsLength()))}unpackTo(e){e.OBJECT_NAME=this.OBJECT_NAME(),e.OBJECT_ID=this.OBJECT_ID(),e.NORAD_CAT_ID=this.NORAD_CAT_ID(),e.OBJECT_TYPE=this.OBJECT_TYPE(),e.OPS_STATUS_CODE=this.OPS_STATUS_CODE(),e.OWNER=this.OWNER(),e.LAUNCH_DATE=this.LAUNCH_DATE(),e.LAUNCH_SITE=this.LAUNCH_SITE(),e.DECAY_DATE=this.DECAY_DATE(),e.PERIOD=this.PERIOD(),e.INCLINATION=this.INCLINATION(),e.APOGEE=this.APOGEE(),e.PERIGEE=this.PERIGEE(),e.RCS=this.RCS(),e.DATA_STATUS_CODE=this.DATA_STATUS_CODE(),e.ORBIT_CENTER=this.ORBIT_CENTER(),e.ORBIT_TYPE=this.ORBIT_TYPE(),e.DEPLOYMENT_DATE=this.DEPLOYMENT_DATE(),e.MANEUVERABLE=this.MANEUVERABLE(),e.SIZE=this.SIZE(),e.MASS=this.MASS(),e.MASS_TYPE=this.MASS_TYPE(),e.PAYLOADS=this.bb.createObjList(this.PAYLOADS.bind(this),this.payloadsLength())}},M_=class{constructor(e=null,i=null,n=0,s=Oc.UNKNOWN,o=Bc.UNKNOWN,r=null,a=null,h=null,A=null,d=0,f=0,E=0,_=0,R=0,I=Vc.NO_CURRENT_ELEMENTS,C=null,N=Gc.ORBIT,T=null,b=!1,F=0,B=0,U=Sc.DRY,Q=[]){this.OBJECT_NAME=e,this.OBJECT_ID=i,this.NORAD_CAT_ID=n,this.OBJECT_TYPE=s,this.OPS_STATUS_CODE=o,this.OWNER=r,this.LAUNCH_DATE=a,this.LAUNCH_SITE=h,this.DECAY_DATE=A,this.PERIOD=d,this.INCLINATION=f,this.APOGEE=E,this.PERIGEE=_,this.RCS=R,this.DATA_STATUS_CODE=I,this.ORBIT_CENTER=C,this.ORBIT_TYPE=N,this.DEPLOYMENT_DATE=T,this.MANEUVERABLE=b,this.SIZE=F,this.MASS=B,this.MASS_TYPE=U,this.PAYLOADS=Q}pack(e){let i=this.OBJECT_NAME!==null?e.createString(this.OBJECT_NAME):0,n=this.OBJECT_ID!==null?e.createString(this.OBJECT_ID):0,s=this.OWNER!==null?e.createString(this.OWNER):0,o=this.LAUNCH_DATE!==null?e.createString(this.LAUNCH_DATE):0,r=this.LAUNCH_SITE!==null?e.createString(this.LAUNCH_SITE):0,a=this.DECAY_DATE!==null?e.createString(this.DECAY_DATE):0,h=this.ORBIT_CENTER!==null?e.createString(this.ORBIT_CENTER):0,A=this.DEPLOYMENT_DATE!==null?e.createString(this.DEPLOYMENT_DATE):0,d=Wc.createPayloadsVector(e,e.createObjectOffsetList(this.PAYLOADS));return Wc.createCAT(e,i,n,this.NORAD_CAT_ID,this.OBJECT_TYPE,this.OPS_STATUS_CODE,s,o,r,a,this.PERIOD,this.INCLINATION,this.APOGEE,this.PERIGEE,this.RCS,this.DATA_STATUS_CODE,h,this.ORBIT_TYPE,A,this.MANEUVERABLE,this.SIZE,this.MASS,this.MASS_TYPE,d)}}});var hf,Q_,u3=S(()=>{_t();zF();hf=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsCATCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsCATCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new Wc).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startCATCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endCATCOLLECTION(e){return e.endObject()}static createCATCOLLECTION(e,i){return t.startCATCOLLECTION(e),t.addRecords(e,i),t.endCATCOLLECTION(e)}unpack(){return new Q_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},Q_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=hf.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return hf.createCATCOLLECTION(e,i)}}});var cf,k_,C3=S(()=>{_t();Ep();cf=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsIDMCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsIDMCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new Zi).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startIDMCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endIDMCOLLECTION(e){return e.endObject()}static createIDMCOLLECTION(e,i){return t.startIDMCOLLECTION(e),t.addRecords(e,i),t.endIDMCOLLECTION(e)}unpack(){return new k_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},k_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=cf.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return cf.createIDMCOLLECTION(e,i)}}});var lf,L_,g3=S(()=>{_t();_p();lf=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsPLDCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsPLDCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new bA).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startPLDCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endPLDCOLLECTION(e){return e.endObject()}static createPLDCOLLECTION(e,i){return t.startPLDCOLLECTION(e),t.addRecords(e,i),t.endPLDCOLLECTION(e)}unpack(){return new L_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},L_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=lf.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return lf.createPLDCOLLECTION(e,i)}}});var ed={};He(ed,{Band:()=>FA,BandT:()=>G_,CAT:()=>Wc,CATCOLLECTION:()=>hf,CATCOLLECTIONT:()=>Q_,CATT:()=>M_,DataMode:()=>Nc,DeviceType:()=>Fc,FrequencyRange:()=>ka,FrequencyRangeT:()=>B_,IDM:()=>Zi,IDMCOLLECTION:()=>cf,IDMCOLLECTIONT:()=>k_,IDMT:()=>D_,PLD:()=>bA,PLDCOLLECTION:()=>lf,PLDCOLLECTIONT:()=>L_,PLDT:()=>U_,PolarizationType:()=>bc,SimplePolarization:()=>Yc,StokesParameters:()=>td,StokesParametersT:()=>W_,dataStatusCode:()=>Vc,massType:()=>Sc,objectType:()=>Oc,opsStatusCode:()=>Bc,orbitType:()=>Gc});var T3=S(()=>{QF();zF();u3();kF();LF();fp();Ep();C3();_p();g3();yF();wF();xF();PF();JF();jF();HF();vF()});var KF=S(()=>{_t()});var Rp=S(()=>{_t()});var XF=S(()=>{_t();Rp()});var Zp,qF=S(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(Zp||(Zp={}))});var Ip,$F=S(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(Ip||(Ip={}))});var pp,tb=S(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(pp||(pp={}))});var up,eb=S(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(up||(up={}))});var ib=S(()=>{_t()});var Cp=S(()=>{_t();XF();qF();$F();Rp();tb();eb();ib()});var gp=S(()=>{_t();Cp()});var Tp,nb=S(()=>{(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(Tp||(Tp={}))});var Np,sb=S(()=>{(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(Np||(Np={}))});var Fp,ob=S(()=>{(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(Fp||(Fp={}))});var bp,rb=S(()=>{(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(bp||(bp={}))});var Yp,ab=S(()=>{(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(Yp||(Yp={}))});var Vp=S(()=>{_t();gp();nb();sb();ob();rb();ab()});var V3=S(()=>{_t();Vp()});var Sp,Ab=S(()=>{(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(Sp||(Sp={}))});var hb=S(()=>{_t();Ab()});var Op=S(()=>{_t();KF();hb()});var Bp,cb=S(()=>{(function(t){t[t.CALCULATED=0]="CALCULATED",t[t.DEFAULT=1]="DEFAULT"})(Bp||(Bp={}))});var df,y_=S(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(df||(df={}))});var lb=S(()=>{_t();Vp();Op();cb();y_()});var Gp=S(()=>{_t()});var Wp,db=S(()=>{(function(t){t[t.ELLIPSOID=0]="ELLIPSOID",t[t.BOX=1]="BOX"})(Wp||(Wp={}))});var mb=S(()=>{_t();lb();Gp();y_();db()});var B3=S(()=>{_t();mb()});var G3=S(()=>{_t();Op()});var W3=S(()=>{_t();Cp()});var D3=S(()=>{_t();gp()});var U3=S(()=>{_t();Gp()});var fb=S(()=>{_t();y_()});var M3=S(()=>{_t();fb()});var Q3=S(()=>{KF();XF();Vp();V3();mb();B3();lb();hb();qF();$F();Op();G3();Rp();Cp();W3();Ab();gp();D3();Gp();U3();tb();fb();M3();eb();ib();cb();nb();sb();ob();rb();ab();y_();db()});var Eb=S(()=>{_t()});var k3=S(()=>{_t();Eb()});var L3=S(()=>{Eb();k3()});var Dp=S(()=>{_t()});var _b=S(()=>{_t();Dp()});var Up,Rb=S(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(Up||(Up={}))});var Mp,Zb=S(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(Mp||(Mp={}))});var Qp,Ib=S(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(Qp||(Qp={}))});var kp,pb=S(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(kp||(kp={}))});var ub=S(()=>{_t()});var Lp=S(()=>{_t();_b();Rb();Zb();Dp();Ib();pb();ub()});var yp=S(()=>{_t();Lp()});var wp,Cb=S(()=>{(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(wp||(wp={}))});var xp,gb=S(()=>{(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(xp||(xp={}))});var Pp,Tb=S(()=>{(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(Pp||(Pp={}))});var Jp,Nb=S(()=>{(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(Jp||(Jp={}))});var jp,Fb=S(()=>{(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(jp||(jp={}))});var Hp=S(()=>{_t();yp();Cb();gb();Tb();Nb();Fb()});var J3=S(()=>{_t();Hp()});var bb=S(()=>{_t();Hp()});var j3=S(()=>{_t();bb()});var H3=S(()=>{_t();Lp()});var v3=S(()=>{_t();yp()});var z3=S(()=>{_b();Hp();J3();bb();j3();Rb();Zb();Dp();Lp();H3();yp();v3();Ib();pb();ub();Cb();gb();Tb();Nb();Fb()});var Yb=S(()=>{_t()});var K3=S(()=>{_t();Yb()});var X3=S(()=>{Yb();K3()});var Vb=S(()=>{_t()});var q3=S(()=>{_t();Vb()});var $3=S(()=>{Vb();q3()});var w_,vp=S(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(w_||(w_={}))});var Sb=S(()=>{_t();vp()});var t4=S(()=>{_t();Sb()});var Ob=S(()=>{_t();vp()});var e4=S(()=>{_t();Ob()});var i4=S(()=>{Sb();t4();Ob();e4();vp()});var zp,Bb=S(()=>{(function(t){t[t.OBSERVED=0]="OBSERVED",t[t.PREDICTED=1]="PREDICTED"})(zp||(zp={}))});var Gb=S(()=>{_t();Bb()});var n4=S(()=>{_t();Gb()});var s4=S(()=>{Bb();Gb();n4()});var Wb=S(()=>{_t()});var Kp,Db=S(()=>{(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(Kp||(Kp={}))});var Ub=S(()=>{_t();Db()});var Mb=S(()=>{_t();Wb();Ub()});var o4=S(()=>{_t();Mb()});var r4=S(()=>{Wb();Ub();Mb();o4();Db()});var Xp,Qb=S(()=>{(function(t){t[t.OUTLIER=0]="OUTLIER"})(Xp||(Xp={}))});var kb=S(()=>{_t();Qb()});var Lb=S(()=>{_t();kb()});var a4=S(()=>{_t();Lb()});var A4=S(()=>{Lb();a4();kb();Qb()});var qp=S(()=>{_t()});var yb=S(()=>{_t();qp()});var $p,wb=S(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})($p||($p={}))});var tu,xb=S(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(tu||(tu={}))});var eu,Pb=S(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(eu||(eu={}))});var iu,Jb=S(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(iu||(iu={}))});var jb=S(()=>{_t()});var Hb=S(()=>{_t();yb();wb();xb();qp();Pb();Jb();jb()});var c4=S(()=>{_t();Hb()});var l4=S(()=>{yb();wb();xb();qp();Hb();c4();Pb();Jb();jb()});var vb=S(()=>{_t()});var nu=S(()=>{_t()});var m4=S(()=>{_t();nu()});var su=S(()=>{_t()});var zb=S(()=>{_t();su()});var ou,Kb=S(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(ou||(ou={}))});var ru,Xb=S(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(ru||(ru={}))});var au,qb=S(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(au||(au={}))});var Au,$b=S(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(Au||(Au={}))});var tY=S(()=>{_t()});var x_=S(()=>{_t();zb();Kb();Xb();su();qb();$b();tY()});var hu=S(()=>{_t();x_()});var cu,iY=S(()=>{(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(cu||(cu={}))});var lu,nY=S(()=>{(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(lu||(lu={}))});var du,sY=S(()=>{(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(du||(du={}))});var mu,oY=S(()=>{(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(mu||(mu={}))});var fu,rY=S(()=>{(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(fu||(fu={}))});var Eu=S(()=>{_t();hu();iY();nY();sY();oY();rY()});var R4=S(()=>{_t();Eu()});var _u,aY=S(()=>{(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(_u||(_u={}))});var AY=S(()=>{_t();aY()});var Ru,hY=S(()=>{(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(Ru||(Ru={}))});var cY=S(()=>{_t();hY()});var Zu=S(()=>{_t();vb();AY()});var I4=S(()=>{_t();Zu()});var lY=S(()=>{_t()});var p4=S(()=>{_t();x_()});var dY=S(()=>{_t();cY()});var mY=S(()=>{_t()});var Iu=S(()=>{_t();dY();mY()});var pu,fY=S(()=>{(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(pu||(pu={}))});var uu=S(()=>{_t();lY();x_();fY()});var EY=S(()=>{_t();nu();Eu();Zu();Iu();uu()});var g4=S(()=>{_t();EY()});var T4=S(()=>{_t();hu()});var N4=S(()=>{_t();Iu()});var F4=S(()=>{_t();uu()});var b4=S(()=>{vb();nu();m4();zb();Eu();R4();AY();Kb();Xb();cY();hY();Zu();I4();su();lY();x_();p4();aY();EY();g4();hu();T4();qb();Iu();N4();uu();F4();dY();mY();$b();fY();tY();iY();nY();sY();oY();rY()});var Cu,_Y=S(()=>{(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(Cu||(Cu={}))});var RY=S(()=>{_t();_Y()});var Y4=S(()=>{_t();RY()});var V4=S(()=>{RY();Y4();_Y()});var P_,gu=S(()=>{(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(P_||(P_={}))});var ZY=S(()=>{_t();gu()});var S4=S(()=>{_t();ZY()});var IY=S(()=>{_t();gu()});var O4=S(()=>{_t();IY()});var B4=S(()=>{ZY();S4();IY();O4();gu()});var mf,J_=S(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(mf||(mf={}))});var pY=S(()=>{_t();J_()});var uY=S(()=>{_t()});var j_,Tu=S(()=>{(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(j_||(j_={}))});var CY=S(()=>{_t();pY();uY();J_();Tu()});var gY=S(()=>{_t();CY()});var G4=S(()=>{_t();gY()});var TY=S(()=>{_t();J_()});var W4=S(()=>{_t();TY()});var NY=S(()=>{_t();Tu()});var D4=S(()=>{_t();NY()});var U4=S(()=>{gY();G4();TY();W4();NY();D4();pY();CY();uY();J_();Tu()});var Kr,Nu=S(()=>{(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(Kr||(Kr={}))});var id,H_,FY=S(()=>{_t();Nu();id=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsMET(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsMET(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$MET")}MEAN_ELEMENT_THEORY(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):Kr.SGP4}static startMET(e){e.startObject(1)}static addMeanElementTheory(e,i){e.addFieldInt8(0,i,Kr.SGP4)}static endMET(e){return e.endObject()}static finishMETBuffer(e,i){e.finish(i,"$MET")}static finishSizePrefixedMETBuffer(e,i){e.finish(i,"$MET",!0)}static createMET(e,i){return t.startMET(e),t.addMeanElementTheory(e,i),t.endMET(e)}unpack(){return new H_(this.MEAN_ELEMENT_THEORY())}unpackTo(e){e.MEAN_ELEMENT_THEORY=this.MEAN_ELEMENT_THEORY()}},H_=class{constructor(e=Kr.SGP4){this.MEAN_ELEMENT_THEORY=e}pack(e){return id.createMET(e,this.MEAN_ELEMENT_THEORY)}}});var ff,v_,M4=S(()=>{_t();FY();ff=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsMETCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsMETCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new id).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startMETCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endMETCOLLECTION(e){return e.endObject()}static createMETCOLLECTION(e,i){return t.startMETCOLLECTION(e),t.addRecords(e,i),t.endMETCOLLECTION(e)}unpack(){return new v_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},v_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=ff.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return ff.createMETCOLLECTION(e,i)}}});var Dc,bY=S(()=>{(function(t){t[t.SGP=0]="SGP",t[t.SGP4=1]="SGP4",t[t.SDP4=2]="SDP4",t[t.SGP8=3]="SGP8",t[t.SDP8=4]="SDP8"})(Dc||(Dc={}))});var Lo,Fu=S(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(Lo||(Lo={}))});var Xr,bu=S(()=>{(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(Xr||(Xr={}))});var nd,z_,YY=S(()=>{_t();bY();Nu();Fu();bu();nd=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsOMM(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsOMM(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$OMM")}CCSDS_OMM_VERS(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}CREATION_DATE(e){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__string(this.bb_pos+i,e):null}ORIGINATOR(e){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__string(this.bb_pos+i,e):null}OBJECT_NAME(e){let i=this.bb.__offset(this.bb_pos,10);return i?this.bb.__string(this.bb_pos+i,e):null}OBJECT_ID(e){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.__string(this.bb_pos+i,e):null}CENTER_NAME(e){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.__string(this.bb_pos+i,e):null}REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.readInt8(this.bb_pos+e):Lo.TEME}REFERENCE_FRAME_EPOCH(e){let i=this.bb.__offset(this.bb_pos,18);return i?this.bb.__string(this.bb_pos+i,e):null}TIME_SYSTEM(){let e=this.bb.__offset(this.bb_pos,20);return e?this.bb.readInt8(this.bb_pos+e):Xr.UTC}MEAN_ELEMENT_THEORY(){let e=this.bb.__offset(this.bb_pos,22);return e?this.bb.readInt8(this.bb_pos+e):Kr.SGP4}COMMENT(e){let i=this.bb.__offset(this.bb_pos,24);return i?this.bb.__string(this.bb_pos+i,e):null}EPOCH(e){let i=this.bb.__offset(this.bb_pos,26);return i?this.bb.__string(this.bb_pos+i,e):null}SEMI_MAJOR_AXIS(){let e=this.bb.__offset(this.bb_pos,28);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION(){let e=this.bb.__offset(this.bb_pos,30);return e?this.bb.readFloat64(this.bb_pos+e):0}ECCENTRICITY(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readFloat64(this.bb_pos+e):0}INCLINATION(){let e=this.bb.__offset(this.bb_pos,34);return e?this.bb.readFloat64(this.bb_pos+e):0}RA_OF_ASC_NODE(){let e=this.bb.__offset(this.bb_pos,36);return e?this.bb.readFloat64(this.bb_pos+e):0}ARG_OF_PERICENTER(){let e=this.bb.__offset(this.bb_pos,38);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_ANOMALY(){let e=this.bb.__offset(this.bb_pos,40);return e?this.bb.readFloat64(this.bb_pos+e):0}GM(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}SOLAR_RAD_AREA(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readFloat64(this.bb_pos+e):0}SOLAR_RAD_COEFF(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.readFloat64(this.bb_pos+e):0}DRAG_AREA(){let e=this.bb.__offset(this.bb_pos,50);return e?this.bb.readFloat64(this.bb_pos+e):0}DRAG_COEFF(){let e=this.bb.__offset(this.bb_pos,52);return e?this.bb.readFloat64(this.bb_pos+e):0}EPHEMERIS_TYPE(){let e=this.bb.__offset(this.bb_pos,54);return e?this.bb.readInt8(this.bb_pos+e):Dc.SGP4}CLASSIFICATION_TYPE(e){let i=this.bb.__offset(this.bb_pos,56);return i?this.bb.__string(this.bb_pos+i,e):null}NORAD_CAT_ID(){let e=this.bb.__offset(this.bb_pos,58);return e?this.bb.readUint32(this.bb_pos+e):0}ELEMENT_SET_NO(){let e=this.bb.__offset(this.bb_pos,60);return e?this.bb.readUint32(this.bb_pos+e):0}REV_AT_EPOCH(){let e=this.bb.__offset(this.bb_pos,62);return e?this.bb.readFloat64(this.bb_pos+e):0}BSTAR(){let e=this.bb.__offset(this.bb_pos,64);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION_DOT(){let e=this.bb.__offset(this.bb_pos,66);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION_DDOT(){let e=this.bb.__offset(this.bb_pos,68);return e?this.bb.readFloat64(this.bb_pos+e):0}COV_REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,70);return e?this.bb.readInt8(this.bb_pos+e):Lo.RSW}CX_X(){let e=this.bb.__offset(this.bb_pos,72);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_X(){let e=this.bb.__offset(this.bb_pos,74);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_Y(){let e=this.bb.__offset(this.bb_pos,76);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_X(){let e=this.bb.__offset(this.bb_pos,78);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_Y(){let e=this.bb.__offset(this.bb_pos,80);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_Z(){let e=this.bb.__offset(this.bb_pos,82);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_X(){let e=this.bb.__offset(this.bb_pos,84);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_Y(){let e=this.bb.__offset(this.bb_pos,86);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_Z(){let e=this.bb.__offset(this.bb_pos,88);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,90);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_X(){let e=this.bb.__offset(this.bb_pos,92);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Y(){let e=this.bb.__offset(this.bb_pos,94);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Z(){let e=this.bb.__offset(this.bb_pos,96);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,98);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Y_DOT(){let e=this.bb.__offset(this.bb_pos,100);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_X(){let e=this.bb.__offset(this.bb_pos,102);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Y(){let e=this.bb.__offset(this.bb_pos,104);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Z(){let e=this.bb.__offset(this.bb_pos,106);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,108);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Y_DOT(){let e=this.bb.__offset(this.bb_pos,110);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Z_DOT(){let e=this.bb.__offset(this.bb_pos,112);return e?this.bb.readFloat64(this.bb_pos+e):0}USER_DEFINED_BIP_0044_TYPE(){let e=this.bb.__offset(this.bb_pos,114);return e?this.bb.readUint32(this.bb_pos+e):0}USER_DEFINED_OBJECT_DESIGNATOR(e){let i=this.bb.__offset(this.bb_pos,116);return i?this.bb.__string(this.bb_pos+i,e):null}USER_DEFINED_EARTH_MODEL(e){let i=this.bb.__offset(this.bb_pos,118);return i?this.bb.__string(this.bb_pos+i,e):null}USER_DEFINED_EPOCH_TIMESTAMP(){let e=this.bb.__offset(this.bb_pos,120);return e?this.bb.readFloat64(this.bb_pos+e):0}USER_DEFINED_MICROSECONDS(){let e=this.bb.__offset(this.bb_pos,122);return e?this.bb.readFloat64(this.bb_pos+e):0}static startOMM(e){e.startObject(60)}static addCcsdsOmmVers(e,i){e.addFieldFloat64(0,i,0)}static addCreationDate(e,i){e.addFieldOffset(1,i,0)}static addOriginator(e,i){e.addFieldOffset(2,i,0)}static addObjectName(e,i){e.addFieldOffset(3,i,0)}static addObjectId(e,i){e.addFieldOffset(4,i,0)}static addCenterName(e,i){e.addFieldOffset(5,i,0)}static addReferenceFrame(e,i){e.addFieldInt8(6,i,Lo.TEME)}static addReferenceFrameEpoch(e,i){e.addFieldOffset(7,i,0)}static addTimeSystem(e,i){e.addFieldInt8(8,i,Xr.UTC)}static addMeanElementTheory(e,i){e.addFieldInt8(9,i,Kr.SGP4)}static addComment(e,i){e.addFieldOffset(10,i,0)}static addEpoch(e,i){e.addFieldOffset(11,i,0)}static addSemiMajorAxis(e,i){e.addFieldFloat64(12,i,0)}static addMeanMotion(e,i){e.addFieldFloat64(13,i,0)}static addEccentricity(e,i){e.addFieldFloat64(14,i,0)}static addInclination(e,i){e.addFieldFloat64(15,i,0)}static addRaOfAscNode(e,i){e.addFieldFloat64(16,i,0)}static addArgOfPericenter(e,i){e.addFieldFloat64(17,i,0)}static addMeanAnomaly(e,i){e.addFieldFloat64(18,i,0)}static addGm(e,i){e.addFieldFloat64(19,i,0)}static addMass(e,i){e.addFieldFloat64(20,i,0)}static addSolarRadArea(e,i){e.addFieldFloat64(21,i,0)}static addSolarRadCoeff(e,i){e.addFieldFloat64(22,i,0)}static addDragArea(e,i){e.addFieldFloat64(23,i,0)}static addDragCoeff(e,i){e.addFieldFloat64(24,i,0)}static addEphemerisType(e,i){e.addFieldInt8(25,i,Dc.SGP4)}static addClassificationType(e,i){e.addFieldOffset(26,i,0)}static addNoradCatId(e,i){e.addFieldInt32(27,i,0)}static addElementSetNo(e,i){e.addFieldInt32(28,i,0)}static addRevAtEpoch(e,i){e.addFieldFloat64(29,i,0)}static addBstar(e,i){e.addFieldFloat64(30,i,0)}static addMeanMotionDot(e,i){e.addFieldFloat64(31,i,0)}static addMeanMotionDdot(e,i){e.addFieldFloat64(32,i,0)}static addCovReferenceFrame(e,i){e.addFieldInt8(33,i,Lo.RSW)}static addCxX(e,i){e.addFieldFloat64(34,i,0)}static addCyX(e,i){e.addFieldFloat64(35,i,0)}static addCyY(e,i){e.addFieldFloat64(36,i,0)}static addCzX(e,i){e.addFieldFloat64(37,i,0)}static addCzY(e,i){e.addFieldFloat64(38,i,0)}static addCzZ(e,i){e.addFieldFloat64(39,i,0)}static addCxDotX(e,i){e.addFieldFloat64(40,i,0)}static addCxDotY(e,i){e.addFieldFloat64(41,i,0)}static addCxDotZ(e,i){e.addFieldFloat64(42,i,0)}static addCxDotXDot(e,i){e.addFieldFloat64(43,i,0)}static addCyDotX(e,i){e.addFieldFloat64(44,i,0)}static addCyDotY(e,i){e.addFieldFloat64(45,i,0)}static addCyDotZ(e,i){e.addFieldFloat64(46,i,0)}static addCyDotXDot(e,i){e.addFieldFloat64(47,i,0)}static addCyDotYDot(e,i){e.addFieldFloat64(48,i,0)}static addCzDotX(e,i){e.addFieldFloat64(49,i,0)}static addCzDotY(e,i){e.addFieldFloat64(50,i,0)}static addCzDotZ(e,i){e.addFieldFloat64(51,i,0)}static addCzDotXDot(e,i){e.addFieldFloat64(52,i,0)}static addCzDotYDot(e,i){e.addFieldFloat64(53,i,0)}static addCzDotZDot(e,i){e.addFieldFloat64(54,i,0)}static addUserDefinedBip0044Type(e,i){e.addFieldInt32(55,i,0)}static addUserDefinedObjectDesignator(e,i){e.addFieldOffset(56,i,0)}static addUserDefinedEarthModel(e,i){e.addFieldOffset(57,i,0)}static addUserDefinedEpochTimestamp(e,i){e.addFieldFloat64(58,i,0)}static addUserDefinedMicroseconds(e,i){e.addFieldFloat64(59,i,0)}static endOMM(e){return e.endObject()}static finishOMMBuffer(e,i){e.finish(i,"$OMM")}static finishSizePrefixedOMMBuffer(e,i){e.finish(i,"$OMM",!0)}static createOMM(e,i,n,s,o,r,a,h,A,d,f,E,_,R,I,C,N,T,b,F,B,U,Q,M,k,y,c,g,O,D,w,x,H,j,X,tt,G,It,gt,Yt,Ut,Ct,zt,kt,Jt,Wt,bt,ee,ce,je,Se,Ue,Me,Ce,Fe,ni,ze,Be,Mi,Ri,si){return t.startOMM(e),t.addCcsdsOmmVers(e,i),t.addCreationDate(e,n),t.addOriginator(e,s),t.addObjectName(e,o),t.addObjectId(e,r),t.addCenterName(e,a),t.addReferenceFrame(e,h),t.addReferenceFrameEpoch(e,A),t.addTimeSystem(e,d),t.addMeanElementTheory(e,f),t.addComment(e,E),t.addEpoch(e,_),t.addSemiMajorAxis(e,R),t.addMeanMotion(e,I),t.addEccentricity(e,C),t.addInclination(e,N),t.addRaOfAscNode(e,T),t.addArgOfPericenter(e,b),t.addMeanAnomaly(e,F),t.addGm(e,B),t.addMass(e,U),t.addSolarRadArea(e,Q),t.addSolarRadCoeff(e,M),t.addDragArea(e,k),t.addDragCoeff(e,y),t.addEphemerisType(e,c),t.addClassificationType(e,g),t.addNoradCatId(e,O),t.addElementSetNo(e,D),t.addRevAtEpoch(e,w),t.addBstar(e,x),t.addMeanMotionDot(e,H),t.addMeanMotionDdot(e,j),t.addCovReferenceFrame(e,X),t.addCxX(e,tt),t.addCyX(e,G),t.addCyY(e,It),t.addCzX(e,gt),t.addCzY(e,Yt),t.addCzZ(e,Ut),t.addCxDotX(e,Ct),t.addCxDotY(e,zt),t.addCxDotZ(e,kt),t.addCxDotXDot(e,Jt),t.addCyDotX(e,Wt),t.addCyDotY(e,bt),t.addCyDotZ(e,ee),t.addCyDotXDot(e,ce),t.addCyDotYDot(e,je),t.addCzDotX(e,Se),t.addCzDotY(e,Ue),t.addCzDotZ(e,Me),t.addCzDotXDot(e,Ce),t.addCzDotYDot(e,Fe),t.addCzDotZDot(e,ni),t.addUserDefinedBip0044Type(e,ze),t.addUserDefinedObjectDesignator(e,Be),t.addUserDefinedEarthModel(e,Mi),t.addUserDefinedEpochTimestamp(e,Ri),t.addUserDefinedMicroseconds(e,si),t.endOMM(e)}unpack(){return new z_(this.CCSDS_OMM_VERS(),this.CREATION_DATE(),this.ORIGINATOR(),this.OBJECT_NAME(),this.OBJECT_ID(),this.CENTER_NAME(),this.REFERENCE_FRAME(),this.REFERENCE_FRAME_EPOCH(),this.TIME_SYSTEM(),this.MEAN_ELEMENT_THEORY(),this.COMMENT(),this.EPOCH(),this.SEMI_MAJOR_AXIS(),this.MEAN_MOTION(),this.ECCENTRICITY(),this.INCLINATION(),this.RA_OF_ASC_NODE(),this.ARG_OF_PERICENTER(),this.MEAN_ANOMALY(),this.GM(),this.MASS(),this.SOLAR_RAD_AREA(),this.SOLAR_RAD_COEFF(),this.DRAG_AREA(),this.DRAG_COEFF(),this.EPHEMERIS_TYPE(),this.CLASSIFICATION_TYPE(),this.NORAD_CAT_ID(),this.ELEMENT_SET_NO(),this.REV_AT_EPOCH(),this.BSTAR(),this.MEAN_MOTION_DOT(),this.MEAN_MOTION_DDOT(),this.COV_REFERENCE_FRAME(),this.CX_X(),this.CY_X(),this.CY_Y(),this.CZ_X(),this.CZ_Y(),this.CZ_Z(),this.CX_DOT_X(),this.CX_DOT_Y(),this.CX_DOT_Z(),this.CX_DOT_X_DOT(),this.CY_DOT_X(),this.CY_DOT_Y(),this.CY_DOT_Z(),this.CY_DOT_X_DOT(),this.CY_DOT_Y_DOT(),this.CZ_DOT_X(),this.CZ_DOT_Y(),this.CZ_DOT_Z(),this.CZ_DOT_X_DOT(),this.CZ_DOT_Y_DOT(),this.CZ_DOT_Z_DOT(),this.USER_DEFINED_BIP_0044_TYPE(),this.USER_DEFINED_OBJECT_DESIGNATOR(),this.USER_DEFINED_EARTH_MODEL(),this.USER_DEFINED_EPOCH_TIMESTAMP(),this.USER_DEFINED_MICROSECONDS())}unpackTo(e){e.CCSDS_OMM_VERS=this.CCSDS_OMM_VERS(),e.CREATION_DATE=this.CREATION_DATE(),e.ORIGINATOR=this.ORIGINATOR(),e.OBJECT_NAME=this.OBJECT_NAME(),e.OBJECT_ID=this.OBJECT_ID(),e.CENTER_NAME=this.CENTER_NAME(),e.REFERENCE_FRAME=this.REFERENCE_FRAME(),e.REFERENCE_FRAME_EPOCH=this.REFERENCE_FRAME_EPOCH(),e.TIME_SYSTEM=this.TIME_SYSTEM(),e.MEAN_ELEMENT_THEORY=this.MEAN_ELEMENT_THEORY(),e.COMMENT=this.COMMENT(),e.EPOCH=this.EPOCH(),e.SEMI_MAJOR_AXIS=this.SEMI_MAJOR_AXIS(),e.MEAN_MOTION=this.MEAN_MOTION(),e.ECCENTRICITY=this.ECCENTRICITY(),e.INCLINATION=this.INCLINATION(),e.RA_OF_ASC_NODE=this.RA_OF_ASC_NODE(),e.ARG_OF_PERICENTER=this.ARG_OF_PERICENTER(),e.MEAN_ANOMALY=this.MEAN_ANOMALY(),e.GM=this.GM(),e.MASS=this.MASS(),e.SOLAR_RAD_AREA=this.SOLAR_RAD_AREA(),e.SOLAR_RAD_COEFF=this.SOLAR_RAD_COEFF(),e.DRAG_AREA=this.DRAG_AREA(),e.DRAG_COEFF=this.DRAG_COEFF(),e.EPHEMERIS_TYPE=this.EPHEMERIS_TYPE(),e.CLASSIFICATION_TYPE=this.CLASSIFICATION_TYPE(),e.NORAD_CAT_ID=this.NORAD_CAT_ID(),e.ELEMENT_SET_NO=this.ELEMENT_SET_NO(),e.REV_AT_EPOCH=this.REV_AT_EPOCH(),e.BSTAR=this.BSTAR(),e.MEAN_MOTION_DOT=this.MEAN_MOTION_DOT(),e.MEAN_MOTION_DDOT=this.MEAN_MOTION_DDOT(),e.COV_REFERENCE_FRAME=this.COV_REFERENCE_FRAME(),e.CX_X=this.CX_X(),e.CY_X=this.CY_X(),e.CY_Y=this.CY_Y(),e.CZ_X=this.CZ_X(),e.CZ_Y=this.CZ_Y(),e.CZ_Z=this.CZ_Z(),e.CX_DOT_X=this.CX_DOT_X(),e.CX_DOT_Y=this.CX_DOT_Y(),e.CX_DOT_Z=this.CX_DOT_Z(),e.CX_DOT_X_DOT=this.CX_DOT_X_DOT(),e.CY_DOT_X=this.CY_DOT_X(),e.CY_DOT_Y=this.CY_DOT_Y(),e.CY_DOT_Z=this.CY_DOT_Z(),e.CY_DOT_X_DOT=this.CY_DOT_X_DOT(),e.CY_DOT_Y_DOT=this.CY_DOT_Y_DOT(),e.CZ_DOT_X=this.CZ_DOT_X(),e.CZ_DOT_Y=this.CZ_DOT_Y(),e.CZ_DOT_Z=this.CZ_DOT_Z(),e.CZ_DOT_X_DOT=this.CZ_DOT_X_DOT(),e.CZ_DOT_Y_DOT=this.CZ_DOT_Y_DOT(),e.CZ_DOT_Z_DOT=this.CZ_DOT_Z_DOT(),e.USER_DEFINED_BIP_0044_TYPE=this.USER_DEFINED_BIP_0044_TYPE(),e.USER_DEFINED_OBJECT_DESIGNATOR=this.USER_DEFINED_OBJECT_DESIGNATOR(),e.USER_DEFINED_EARTH_MODEL=this.USER_DEFINED_EARTH_MODEL(),e.USER_DEFINED_EPOCH_TIMESTAMP=this.USER_DEFINED_EPOCH_TIMESTAMP(),e.USER_DEFINED_MICROSECONDS=this.USER_DEFINED_MICROSECONDS()}},z_=class{constructor(e=0,i=null,n=null,s=null,o=null,r=null,a=Lo.TEME,h=null,A=Xr.UTC,d=Kr.SGP4,f=null,E=null,_=0,R=0,I=0,C=0,N=0,T=0,b=0,F=0,B=0,U=0,Q=0,M=0,k=0,y=Dc.SGP4,c=null,g=0,O=0,D=0,w=0,x=0,H=0,j=Lo.RSW,X=0,tt=0,G=0,It=0,gt=0,Yt=0,Ut=0,Ct=0,zt=0,kt=0,Jt=0,Wt=0,bt=0,ee=0,ce=0,je=0,Se=0,Ue=0,Me=0,Ce=0,Fe=0,ni=0,ze=null,Be=null,Mi=0,Ri=0){this.CCSDS_OMM_VERS=e,this.CREATION_DATE=i,this.ORIGINATOR=n,this.OBJECT_NAME=s,this.OBJECT_ID=o,this.CENTER_NAME=r,this.REFERENCE_FRAME=a,this.REFERENCE_FRAME_EPOCH=h,this.TIME_SYSTEM=A,this.MEAN_ELEMENT_THEORY=d,this.COMMENT=f,this.EPOCH=E,this.SEMI_MAJOR_AXIS=_,this.MEAN_MOTION=R,this.ECCENTRICITY=I,this.INCLINATION=C,this.RA_OF_ASC_NODE=N,this.ARG_OF_PERICENTER=T,this.MEAN_ANOMALY=b,this.GM=F,this.MASS=B,this.SOLAR_RAD_AREA=U,this.SOLAR_RAD_COEFF=Q,this.DRAG_AREA=M,this.DRAG_COEFF=k,this.EPHEMERIS_TYPE=y,this.CLASSIFICATION_TYPE=c,this.NORAD_CAT_ID=g,this.ELEMENT_SET_NO=O,this.REV_AT_EPOCH=D,this.BSTAR=w,this.MEAN_MOTION_DOT=x,this.MEAN_MOTION_DDOT=H,this.COV_REFERENCE_FRAME=j,this.CX_X=X,this.CY_X=tt,this.CY_Y=G,this.CZ_X=It,this.CZ_Y=gt,this.CZ_Z=Yt,this.CX_DOT_X=Ut,this.CX_DOT_Y=Ct,this.CX_DOT_Z=zt,this.CX_DOT_X_DOT=kt,this.CY_DOT_X=Jt,this.CY_DOT_Y=Wt,this.CY_DOT_Z=bt,this.CY_DOT_X_DOT=ee,this.CY_DOT_Y_DOT=ce,this.CZ_DOT_X=je,this.CZ_DOT_Y=Se,this.CZ_DOT_Z=Ue,this.CZ_DOT_X_DOT=Me,this.CZ_DOT_Y_DOT=Ce,this.CZ_DOT_Z_DOT=Fe,this.USER_DEFINED_BIP_0044_TYPE=ni,this.USER_DEFINED_OBJECT_DESIGNATOR=ze,this.USER_DEFINED_EARTH_MODEL=Be,this.USER_DEFINED_EPOCH_TIMESTAMP=Mi,this.USER_DEFINED_MICROSECONDS=Ri}pack(e){let i=this.CREATION_DATE!==null?e.createString(this.CREATION_DATE):0,n=this.ORIGINATOR!==null?e.createString(this.ORIGINATOR):0,s=this.OBJECT_NAME!==null?e.createString(this.OBJECT_NAME):0,o=this.OBJECT_ID!==null?e.createString(this.OBJECT_ID):0,r=this.CENTER_NAME!==null?e.createString(this.CENTER_NAME):0,a=this.REFERENCE_FRAME_EPOCH!==null?e.createString(this.REFERENCE_FRAME_EPOCH):0,h=this.COMMENT!==null?e.createString(this.COMMENT):0,A=this.EPOCH!==null?e.createString(this.EPOCH):0,d=this.CLASSIFICATION_TYPE!==null?e.createString(this.CLASSIFICATION_TYPE):0,f=this.USER_DEFINED_OBJECT_DESIGNATOR!==null?e.createString(this.USER_DEFINED_OBJECT_DESIGNATOR):0,E=this.USER_DEFINED_EARTH_MODEL!==null?e.createString(this.USER_DEFINED_EARTH_MODEL):0;return nd.createOMM(e,this.CCSDS_OMM_VERS,i,n,s,o,r,this.REFERENCE_FRAME,a,this.TIME_SYSTEM,this.MEAN_ELEMENT_THEORY,h,A,this.SEMI_MAJOR_AXIS,this.MEAN_MOTION,this.ECCENTRICITY,this.INCLINATION,this.RA_OF_ASC_NODE,this.ARG_OF_PERICENTER,this.MEAN_ANOMALY,this.GM,this.MASS,this.SOLAR_RAD_AREA,this.SOLAR_RAD_COEFF,this.DRAG_AREA,this.DRAG_COEFF,this.EPHEMERIS_TYPE,d,this.NORAD_CAT_ID,this.ELEMENT_SET_NO,this.REV_AT_EPOCH,this.BSTAR,this.MEAN_MOTION_DOT,this.MEAN_MOTION_DDOT,this.COV_REFERENCE_FRAME,this.CX_X,this.CY_X,this.CY_Y,this.CZ_X,this.CZ_Y,this.CZ_Z,this.CX_DOT_X,this.CX_DOT_Y,this.CX_DOT_Z,this.CX_DOT_X_DOT,this.CY_DOT_X,this.CY_DOT_Y,this.CY_DOT_Z,this.CY_DOT_X_DOT,this.CY_DOT_Y_DOT,this.CZ_DOT_X,this.CZ_DOT_Y,this.CZ_DOT_Z,this.CZ_DOT_X_DOT,this.CZ_DOT_Y_DOT,this.CZ_DOT_Z_DOT,this.USER_DEFINED_BIP_0044_TYPE,f,E,this.USER_DEFINED_EPOCH_TIMESTAMP,this.USER_DEFINED_MICROSECONDS)}}});var Ef,K_,Q4=S(()=>{_t();YY();Ef=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsOMMCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsOMMCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new nd).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startOMMCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endOMMCOLLECTION(e){return e.endObject()}static createOMMCOLLECTION(e,i){return t.startOMMCOLLECTION(e),t.addRecords(e,i),t.endOMMCOLLECTION(e)}unpack(){return new K_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},K_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=Ef.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return Ef.createOMMCOLLECTION(e,i)}}});var sd,X_,VY=S(()=>{_t();Fu();sd=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsRFM(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsRFM(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$RFM")}REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):Lo.ECEF}static startRFM(e){e.startObject(1)}static addReferenceFrame(e,i){e.addFieldInt8(0,i,Lo.ECEF)}static endRFM(e){return e.endObject()}static finishRFMBuffer(e,i){e.finish(i,"$RFM")}static finishSizePrefixedRFMBuffer(e,i){e.finish(i,"$RFM",!0)}static createRFM(e,i){return t.startRFM(e),t.addReferenceFrame(e,i),t.endRFM(e)}unpack(){return new X_(this.REFERENCE_FRAME())}unpackTo(e){e.REFERENCE_FRAME=this.REFERENCE_FRAME()}},X_=class{constructor(e=Lo.ECEF){this.REFERENCE_FRAME=e}pack(e){return sd.createRFM(e,this.REFERENCE_FRAME)}}});var _f,q_,k4=S(()=>{_t();VY();_f=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsRFMCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsRFMCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new sd).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startRFMCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endRFMCOLLECTION(e){return e.endObject()}static createRFMCOLLECTION(e,i){return t.startRFMCOLLECTION(e),t.addRecords(e,i),t.endRFMCOLLECTION(e)}unpack(){return new q_(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},q_=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=_f.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return _f.createRFMCOLLECTION(e,i)}}});var od,$_,SY=S(()=>{_t();bu();od=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsTIM(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsTIM(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$TIM")}TIME_SYSTEM(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):Xr.GMST}static startTIM(e){e.startObject(1)}static addTimeSystem(e,i){e.addFieldInt8(0,i,Xr.GMST)}static endTIM(e){return e.endObject()}static finishTIMBuffer(e,i){e.finish(i,"$TIM")}static finishSizePrefixedTIMBuffer(e,i){e.finish(i,"$TIM",!0)}static createTIM(e,i){return t.startTIM(e),t.addTimeSystem(e,i),t.endTIM(e)}unpack(){return new $_(this.TIME_SYSTEM())}unpackTo(e){e.TIME_SYSTEM=this.TIME_SYSTEM()}},$_=class{constructor(e=Xr.GMST){this.TIME_SYSTEM=e}pack(e){return od.createTIM(e,this.TIME_SYSTEM)}}});var Rf,tR,L4=S(()=>{_t();SY();Rf=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,i){return this.bb_pos=e,this.bb=i,this}static getRootAsTIMCOLLECTION(e,i){return(i||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsTIMCOLLECTION(e,i){return e.setPosition(e.position()+4),(i||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,i){let n=this.bb.__offset(this.bb_pos,4);return n?(i||new od).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+n)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startTIMCOLLECTION(e){e.startObject(1)}static addRecords(e,i){e.addFieldOffset(0,i,0)}static createRecordsVector(e,i){e.startVector(4,i.length,4);for(let n=i.length-1;n>=0;n--)e.addOffset(i[n]);return e.endVector()}static startRecordsVector(e,i){e.startVector(4,i,4)}static endTIMCOLLECTION(e){return e.endObject()}static createTIMCOLLECTION(e,i){return t.startTIMCOLLECTION(e),t.addRecords(e,i),t.endTIMCOLLECTION(e)}unpack(){return new tR(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},tR=class{constructor(e=[]){this.RECORDS=e}pack(e){let i=Rf.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return Rf.createTIMCOLLECTION(e,i)}}});var rd={};He(rd,{MET:()=>id,METCOLLECTION:()=>ff,METCOLLECTIONT:()=>v_,METT:()=>H_,OMM:()=>nd,OMMCOLLECTION:()=>Ef,OMMCOLLECTIONT:()=>K_,OMMT:()=>z_,RFM:()=>sd,RFMCOLLECTION:()=>_f,RFMCOLLECTIONT:()=>q_,RFMT:()=>X_,TIM:()=>od,TIMCOLLECTION:()=>Rf,TIMCOLLECTIONT:()=>tR,TIMT:()=>$_,ephemerisType:()=>Dc,meanElementTheory:()=>Kr,refFrame:()=>Lo,timeSystem:()=>Xr});var y4=S(()=>{FY();M4();YY();Q4();VY();k4();SY();L4();bY();Nu();Fu();bu()});var OY=S(()=>{_t()});var w4=S(()=>{_t();OY()});var x4=S(()=>{OY();w4()});var Yu=S(()=>{_t()});var BY=S(()=>{_t();Yu()});var Vu,GY=S(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(Vu||(Vu={}))});var Su,WY=S(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(Su||(Su={}))});var Ou,DY=S(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(Ou||(Ou={}))});var Bu,UY=S(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(Bu||(Bu={}))});var MY=S(()=>{_t()});var Gu=S(()=>{_t();BY();GY();WY();Yu();DY();UY();MY()});var j4=S(()=>{_t();Gu()});var QY=S(()=>{_t();Gu()});var H4=S(()=>{_t();QY()});var v4=S(()=>{BY();GY();WY();Yu();Gu();j4();QY();H4();DY();UY();MY()});var kY=S(()=>{_t()});var z4=S(()=>{_t();kY()});var K4=S(()=>{kY();z4()});var LY=S(()=>{_t()});var yY=S(()=>{_t();LY()});var X4=S(()=>{_t();yY()});var q4=S(()=>{yY();X4();LY()});var wY=S(()=>{_t()});var eR=S(()=>{_t()});var $4=S(()=>{_t();eR()});var Wu=S(()=>{_t()});var PY=S(()=>{_t();Wu()});var Du,JY=S(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(Du||(Du={}))});var Uu,jY=S(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(Uu||(Uu={}))});var Mu,HY=S(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(Mu||(Mu={}))});var Qu,vY=S(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(Qu||(Qu={}))});var zY=S(()=>{_t()});var Zf=S(()=>{_t();PY();JY();jY();Wu();HY();vY();zY()});var iR=S(()=>{_t();Zf()});var Lu,KY=S(()=>{(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(Lu||(Lu={}))});var yu,XY=S(()=>{(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(yu||(yu={}))});var wu,qY=S(()=>{(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(wu||(wu={}))});var xu,$Y=S(()=>{(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(xu||(xu={}))});var Pu,tV=S(()=>{(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(Pu||(Pu={}))});var ad=S(()=>{_t();iR();KY();XY();qY();$Y();tV()});var eH=S(()=>{_t();ad()});var Ju,iV=S(()=>{(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(Ju||(Ju={}))});var nV=S(()=>{_t();iV()});var If=S(()=>{_t();wY();nV()});var ju,sV=S(()=>{(function(t){t[t.CALCULATED=0]="CALCULATED",t[t.DEFAULT=1]="DEFAULT"})(ju||(ju={}))});var La,YA=S(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(La||(La={}))});var oV=S(()=>{_t();ad();If();sV();YA()});var sR=S(()=>{_t()});var vu,rV=S(()=>{(function(t){t[t.ELLIPSOID=0]="ELLIPSOID",t[t.BOX=1]="BOX"})(vu||(vu={}))});var zu=S(()=>{_t();oV();sR();YA();rV()});var nH=S(()=>{_t();zu()});var Ku=S(()=>{_t()});var oH=S(()=>{_t();Ku()});var Xu=S(()=>{_t();ad()});var aH=S(()=>{_t();Xu()});var qu=S(()=>{_t()});var hH=S(()=>{_t();qu()});var $u,AV=S(()=>{(function(t){t[t.OBSERVED=0]="OBSERVED",t[t.PREDICTED=1]="PREDICTED"})($u||($u={}))});var tC=S(()=>{_t()});var lH=S(()=>{_t();tC()});var eC,hV=S(()=>{(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(eC||(eC={}))});var cV=S(()=>{_t();hV()});var iC=S(()=>{_t();YA()});var mH=S(()=>{_t();iC()});var nC=S(()=>{_t();AV()});var EH=S(()=>{_t();nC()});var _H=S(()=>{_t();If()});var lV=S(()=>{_t()});var sC,dV=S(()=>{(function(t){t[t.OUTLIER=0]="OUTLIER"})(sC||(sC={}))});var mV=S(()=>{_t();dV()});var oC=S(()=>{_t();mV()});var ZH=S(()=>{_t();oC()});var IH=S(()=>{_t();Zf()});var fV=S(()=>{_t();cV()});var EV=S(()=>{_t()});var oR=S(()=>{_t();fV();EV()});var rC,_V=S(()=>{(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(rC||(rC={}))});var rR=S(()=>{_t();lV();Zf();_V()});var aC=S(()=>{_t();eR();ad();If();oR();rR()});var uH=S(()=>{_t();aC()});var pf,aR=S(()=>{(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(pf||(pf={}))});var AC=S(()=>{_t();aR()});var gH=S(()=>{_t();AC()});var hC=S(()=>{_t();aR()});var NH=S(()=>{_t();hC()});var IV=S(()=>{_t();YA()});var pV=S(()=>{_t()});var uf,AR=S(()=>{(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(uf||(uf={}))});var uV=S(()=>{_t();IV();pV();YA();AR()});var cC=S(()=>{_t();uV()});var bH=S(()=>{_t();cC()});var lC,CV=S(()=>{(function(t){t[t.SGP=0]="SGP",t[t.SGP4=1]="SGP4",t[t.SDP4=2]="SDP4",t[t.SGP8=3]="SGP8",t[t.SDP8=4]="SDP8"})(lC||(lC={}))});var dC=S(()=>{_t();CV();aR();YA();AR()});var VH=S(()=>{_t();dC()});var mC=S(()=>{_t()});var OH=S(()=>{_t();mC()});var BH=S(()=>{_t();iR()});var GH=S(()=>{_t();sR()});var gV=S(()=>{_t()});var fC=S(()=>{_t();gV()});var DH=S(()=>{_t();fC()});var EC=S(()=>{_t();YA()});var TV=S(()=>{_t()});var _C=S(()=>{_t();TV()});var RC=S(()=>{_t();YA()});var ZC=S(()=>{_t();AR()});var IC,NV=S(()=>{eR();ad();zu();Ku();Xu();qu();tC();iC();nC();If();oC();Zf();aC();AC();hC();cC();dC();mC();iR();sR();fC();EC();oR();_C();rR();RC();ZC();(function(t){t[t.NONE=0]="NONE",t[t.MPE=1]="MPE",t[t.OMM=2]="OMM",t[t.PLD=3]="PLD",t[t.RFM=4]="RFM",t[t.CSM=5]="CSM",t[t.OSM=6]="OSM",t[t.CAT=7]="CAT",t[t.CRM=8]="CRM",t[t.SCM=9]="SCM",t[t.TDM=10]="TDM",t[t.IDM=11]="IDM",t[t.MET=12]="MET",t[t.ROC=13]="ROC",t[t.BOV=14]="BOV",t[t.EOP=15]="EOP",t[t.EOO=16]="EOO",t[t.EME=17]="EME",t[t.LDM=18]="LDM",t[t.PNM=19]="PNM",t[t.HYP=20]="HYP",t[t.CTR=21]="CTR",t[t.CDM=22]="CDM",t[t.SIT=23]="SIT",t[t.OEM=24]="OEM",t[t.TIM=25]="TIM",t[t.EPM=26]="EPM",t[t.PRG=27]="PRG"})(IC||(IC={}))});var FV=S(()=>{_t();NV()});var LH=S(()=>{_t();FV()});var yH=S(()=>{_t();EC()});var wH=S(()=>{_t();oR()});var xH=S(()=>{_t();_C()});var PH=S(()=>{_t();rR()});var JH=S(()=>{_t();RC()});var jH=S(()=>{_t();ZC()});var HH=S(()=>{wY();eR();$4();PY();ad();eH();zu();nH();oV();Ku();oH();Xu();aH();qu();hH();nV();JY();AV();jY();tC();lH();cV();hV();iC();mH();nC();EH();If();_H();Wu();lV();oC();ZH();Zf();IH();iV();aC();uH();AC();gH();hC();NH();cC();bH();dC();VH();mC();OH();iR();BH();sR();GH();fC();DH();HY();LH();EC();yH();oR();wH();FV();NV();TV();_C();xH();rR();PH();fV();EV();mV();dV();vY();_V();zY();RC();JH();ZC();jH();gV();IV();sV();KY();uV();pV();CV();XY();aR();qY();$Y();tV();YA();rV();AR()});var pC,bV=S(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(pC||(pC={}))});var YV=S(()=>{_t();bV()});var vH=S(()=>{_t();YV()});var zH=S(()=>{YV();vH();bV()});var uC,VV=S(()=>{(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(uC||(uC={}))});var SV=S(()=>{_t();VV()});var OV=S(()=>{_t();SV()});var BV=S(()=>{_t()});var GV=S(()=>{_t();OV();BV()});var KH=S(()=>{_t();GV()});var XH=S(()=>{SV();VV();GV();KH();OV();BV()});var WV=S(()=>{_t()});var DV=S(()=>{_t();WV()});var qH=S(()=>{_t();DV()});var $H=S(()=>{WV();DV();qH()});var CC=S(()=>{_t()});var UV=S(()=>{_t();CC()});var gC,MV=S(()=>{(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(gC||(gC={}))});var TC,QV=S(()=>{(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(TC||(TC={}))});var kV=S(()=>{_t()});var NC,LV=S(()=>{(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(NC||(NC={}))});var FC,yV=S(()=>{(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(FC||(FC={}))});var wV=S(()=>{_t()});var bC=S(()=>{_t();UV();MV();QV();CC();LV();yV();wV()});var iv=S(()=>{_t();bC()});var YC,xV=S(()=>{(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(YC||(YC={}))});var PV=S(()=>{_t();kV();bC();xV()});var nv=S(()=>{_t();PV()});var sv=S(()=>{UV();MV();QV();CC();kV();bC();iv();LV();PV();nv();yV();xV();wV()});var hR,VC=S(()=>{(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(hR||(hR={}))});var JV=S(()=>{_t();VC()});var ov=S(()=>{_t();JV()});var jV=S(()=>{_t();VC()});var rv=S(()=>{_t();jV()});var av=S(()=>{JV();ov();jV();rv();VC()});var SC,HV=S(()=>{(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(SC||(SC={}))});var vV=S(()=>{_t();HV()});var Av=S(()=>{_t();vV()});var hv=S(()=>{vV();Av();HV()});var zV=S(()=>{p3();T3();Q3();L3();z3();X3();$3();i4();s4();r4();A4();l4();b4();V4();B4();U4();y4();x4();v4();K4();q4();HH();zH();XH();$H();sv();av();hv()});var bht,Yfe,Yht,Vfe,OC,cv=S(()=>{SF();Or();mt();Ht();_3();ic();fr();dn();Qn();zV();({OMMT:bht,OMMCOLLECTIONT:Yfe}=rd),{CATT:Yht,CATCOLLECTIONT:Vfe}=ed;Number.prototype.map=function(t,e,i,n){return(this-t)*(n-i)/(e-t)+i};OC=class extends rf{constructor(e,i,n,s){super(e),this.constructor.prototype.wasmSchema={},this._position=new E3,this._spaceCatalog=n,this._wasmModule=i,this._velocity={getValue:(o,r)=>this._velocity.getValueInReferenceFrame(o,0,r),getValueInReferenceFrame:(o,r,a)=>{let h=new Float64Array(i.HEAP8.buffer,n.getVelocity(this.properties.wasmSpaceEntity,Ze.toDate(o).getTime(),r!==$i.TEME),3);if(m(a)||(a=new l),a=l.fromArray(h),r===$i.INERTIAL){let A=In.computeFixedToIcrfMatrix(o);if(m(A)){let d=new l;lt.multiplyByVector(A,a,d),a=d}}return a}},Object.defineProperty(this,"velocity",{get:()=>this._velocity,set:()=>{}}),Object.defineProperties(this._position,{isConstant:{get:()=>!1},_referenceFrame:{get:()=>this.entityCollection.referenceFrame},referenceFrame:{get:()=>this._referenceFrame}}),this._position.getValue=(o,r)=>this._position.getValueInReferenceFrame(o,0,r),this._position.getValueInReferenceFrame=(o,r,a)=>{let h=new Float64Array(i.HEAP8.buffer,n.getPositionInReferenceFrame(this.properties.wasmSpaceEntity,Ze.toDate(o).getTime(),r!==$i.TEME),3);if(m(a)||(a=new l),a=l.fromArray(h),r===$i.INERTIAL){let A=In.computeFixedToIcrfMatrix(o);if(m(A)){let d=new l;lt.multiplyByVector(A,a,d),a=d}}return a},this.children={add:o=>(o=this.entityCollection.add(o),this.entityCollection.allValues||(Object.defineProperty(this.entityCollection,"allValues",{get:function(){return this._entities.values}}),Object.defineProperty(this.entityCollection,"values",{get:function(){return this._entities.values.filter(r=>!r._isChild)}})),o._isChild=!0,o.parent=this,o.position=this.position,o),remove:o=>{this.entityCollection.remove(o);let r=this._children.indexOf(this);this._children.splice(r,1)},values:this._children},this.loadOMM(s)}loadOMM(e){let i=new this._wasmModule.PropagatedPositionProperty;i.addOMM(e),this.properties.wasmSpaceEntity=i,this.properties.CAT=this.properties._CAT||new Yht,this.properties._CAT._value.APOGEE=i.apogee,this.properties._CAT._value.PERIGEE=i.perigee,this.properties._CAT._value.PERIOD=i.period_sec,this.properties.OMM=this.properties._OMM||new bht,this.properties._OMM._value.ECCENTRICITY=i.ecco,this.properties._OMM._value.SEMI_MAJOR_AXIS=i.semi_major_axis/1e3,this.properties._OMM._value.SEMI_MINOR_AXIS=i.semi_minor_axis/1e3,this.array_index=this.properties.wasmSpaceEntity.array_index,this.samplesPerPeriod=180,this.extraEpochSamples=60,this.resolutionAtEpoch=5,this.autoEpochResolution=!0,this.epochBlockSize=.5,this.extraSamples=5,this.eccentricityThreshold=.2,this.targetIntervalCount=20,this._orbitShowing=!1,this._coverageShowing=!1,this.referenceFrame=$i.RIC,this._position._clearCache=!0}get orbitShowing(){return this._orbitShowing}get coverageShowing(){return this._coverageShowing}showCoverage(e={show:!1}){this._coverageShowing=e.show,e.show?this.entityCollection.owner._coverageGroup.push(this):this.entityCollection.owner._coverageGroup.remove({id:this.id})}showOrbit(e={show:!1}){if(this._orbitShowing=e.show,!e.show){this.path=null;return}e&&(e.color=e.material),e?.referenceEntity?this._localReferenceEntity=e.referenceEntity:this._localReferenceEntity=void 0,this.path=this.path||{};let{material:i,width:n,leadTime:s,trailTime:o,resolution:r}=this.path;this.path=Object.assign({},{material:i||Zt.WHITE,width:n||1.25,leadTime:s||5e3,trailTime:o||5e3,resolution:r||120,show:!0},e);let{ecco:a,period_sec:h}=this.properties.wasmSpaceEntity,A=a<this.eccentricityThreshold;A||(this.extraSamples=a.map(this.eccentricityThreshold,.9,10,50),this.samplesPerPeriod=a.map(this.eccentricityThreshold,.9,180,1440));let{samplesPerPeriod:d}=this,E=h/(A?1.8:2);this.path.leadTime=E,this.path.trailTime=E;let _={...this,period:h,resolution:h/d};this.path.resolution=A?{..._,method:"timeStep"}:{..._,method:"trueAnomaly",period:h,samplesPerPeriod:d}}}});var Sht,Vht,BC,lv=S(()=>{Sht={},Vht=(()=>{var t=Sht.url;return function(e={}){var i=e,n,s;i.ready=new Promise((u,V)=>{n=u,s=V}),["_getCoveragePositions","_inflateEllipsoid","_malloc","_free","_memory","_fflush","__embind_initialize_bindings","___indirect_function_table","___start_em_asm","___stop_em_asm","onRuntimeInitialized"].forEach(u=>{Object.getOwnPropertyDescriptor(i.ready,u)||Object.defineProperty(i.ready,u,{get:()=>Be("You are getting "+u+" on the Promise object, instead of the instance. Use .then() to get called back with the instance, see the MODULARIZE docs in src/settings.js"),set:()=>Be("You are setting "+u+" on the Promise object, instead of the instance. Use .then() to get called back with the instance, see the MODULARIZE docs in src/settings.js")})}),globalThis.__dirname=globalThis.__dirname||"";var o=Object.assign({},i),r=[],a="./this.program",h=(u,V)=>{throw V},A=!0,d=!1,f=!1,E=!1;if(i.ENVIRONMENT)throw new Error("Module.ENVIRONMENT has been deprecated. To force the environment, use the ENVIRONMENT compile-time option (for example, -sENVIRONMENT=web or -sENVIRONMENT=node)");var _="";function R(u){return i.locateFile?i.locateFile(u,_):_+u}var I,C,N,T;if(E){if(typeof process=="object"&&typeof Xo=="function"||typeof window=="object"||typeof importScripts=="function")throw new Error("not compiled for this environment (did you build to HTML and try to run it not on the web, or set ENVIRONMENT to something - like node - and run it someplace else - like on the web?)");typeof read<"u"&&(I=read),N=u=>{if(typeof readbuffer=="function")return new Uint8Array(readbuffer(u));let V=read(u,"binary");return c(typeof V=="object"),V},C=(u,V,W)=>{setTimeout(()=>V(N(u)))},typeof clearTimeout>"u"&&(globalThis.clearTimeout=u=>{}),typeof setTimeout>"u"&&(globalThis.setTimeout=u=>typeof u=="function"?u():Be()),typeof scriptArgs<"u"?r=scriptArgs:typeof arguments<"u"&&(r=arguments),typeof quit=="function"&&(h=(u,V)=>{throw setTimeout(()=>{if(!(V instanceof cs)){let W=V;V&&typeof V=="object"&&V.stack&&(W=[V,V.stack]),F(`exiting due to exception: ${W}`)}quit(u)}),V}),typeof print<"u"&&(typeof console>"u"&&(console={}),console.log=print,console.warn=console.error=typeof printErr<"u"?printErr:print)}else if(A||d){if(d?_=self.location.href:typeof document<"u"&&document.currentScript&&(_=document.currentScript.src),t&&(_=t),_.indexOf("blob:")!==0?_=_.substr(0,_.replace(/[?#].*/,"").lastIndexOf("/")+1):_="",!(typeof window=="object"||typeof importScripts=="function"))throw new Error("not compiled for this environment (did you build to HTML and try to run it not on the web, or set ENVIRONMENT to something - like node - and run it someplace else - like on the web?)");I=u=>{var V=new XMLHttpRequest;return V.open("GET",u,!1),V.send(null),V.responseText},d&&(N=u=>{var V=new XMLHttpRequest;return V.open("GET",u,!1),V.responseType="arraybuffer",V.send(null),new Uint8Array(V.response)}),C=(u,V,W)=>{var P=new XMLHttpRequest;P.open("GET",u,!0),P.responseType="arraybuffer",P.onload=()=>{if(P.status==200||P.status==0&&P.response){V(P.response);return}W()},P.onerror=W,P.send(null)},T=u=>document.title=u}else throw new Error("environment detection error");var b=i.print||console.log.bind(console),F=i.printErr||console.error.bind(console);Object.assign(i,o),o=null,lX(),i.arguments&&(r=i.arguments),_n("arguments","arguments_"),i.thisProgram&&(a=i.thisProgram),_n("thisProgram","thisProgram"),i.quit&&(h=i.quit),_n("quit","quit_"),c(typeof i.memoryInitializerPrefixURL>"u","Module.memoryInitializerPrefixURL option was removed, use Module.locateFile instead"),c(typeof i.pthreadMainPrefixURL>"u","Module.pthreadMainPrefixURL option was removed, use Module.locateFile instead"),c(typeof i.cdInitializerPrefixURL>"u","Module.cdInitializerPrefixURL option was removed, use Module.locateFile instead"),c(typeof i.filePackagePrefixURL>"u","Module.filePackagePrefixURL option was removed, use Module.locateFile instead"),c(typeof i.read>"u","Module.read option was removed (modify read_ in JS)"),c(typeof i.readAsync>"u","Module.readAsync option was removed (modify readAsync in JS)"),c(typeof i.readBinary>"u","Module.readBinary option was removed (modify readBinary in JS)"),c(typeof i.setWindowTitle>"u","Module.setWindowTitle option was removed (modify setWindowTitle in JS)"),c(typeof i.TOTAL_MEMORY>"u","Module.TOTAL_MEMORY has been renamed Module.INITIAL_MEMORY"),_n("asm","wasmExports"),_n("read","read_"),_n("readAsync","readAsync"),_n("readBinary","readBinary"),_n("setWindowTitle","setWindowTitle"),c(!d,"worker environment detected but not enabled at build time.  Add 'worker' to `-sENVIRONMENT` to enable."),c(!f,"node environment detected but not enabled at build time.  Add 'node' to `-sENVIRONMENT` to enable."),c(!E,"shell environment detected but not enabled at build time.  Add 'shell' to `-sENVIRONMENT` to enable.");var B;i.wasmBinary&&(B=i.wasmBinary),_n("wasmBinary","wasmBinary");var U=i.noExitRuntime||!0;_n("noExitRuntime","noExitRuntime"),typeof WebAssembly!="object"&&Be("no native wasm support detected");var Q,M,k=!1,y;function c(u,V){u||Be("Assertion failed"+(V?": "+V:""))}var g,O,D,w,x,H,j,X;function tt(){var u=Q.buffer;i.HEAP8=g=new Int8Array(u),i.HEAP16=D=new Int16Array(u),i.HEAP32=x=new Int32Array(u),i.HEAPU8=O=new Uint8Array(u),i.HEAPU16=w=new Uint16Array(u),i.HEAPU32=H=new Uint32Array(u),i.HEAPF32=j=new Float32Array(u),i.HEAPF64=X=new Float64Array(u)}c(!i.STACK_SIZE,"STACK_SIZE can no longer be set at runtime.  Use -sSTACK_SIZE at link time"),c(typeof Int32Array<"u"&&typeof Float64Array<"u"&&Int32Array.prototype.subarray!=null&&Int32Array.prototype.set!=null,"JS engine does not provide full typed array support"),c(!i.wasmMemory,"Use of `wasmMemory` detected.  Use -sIMPORTED_MEMORY to define wasmMemory externally"),c(!i.INITIAL_MEMORY,"Detected runtime INITIAL_MEMORY setting.  Use -sIMPORTED_MEMORY to define wasmMemory dynamically");var G;function It(){var u=$g();c((u&3)==0),u==0&&(u+=4),H[u>>2]=34821223,H[u+4>>2]=2310721022,H[0]=1668509029}function gt(){if(!k){var u=$g();u==0&&(u+=4);var V=H[u>>2],W=H[u+4>>2];(V!=34821223||W!=2310721022)&&Be(`Stack overflow! Stack cookie has been overwritten at ${Pn(u)}, expected hex dwords 0x89BACDFE and 0x2135467, but received ${Pn(W)} ${Pn(V)}`),H[0]!=1668509029&&Be("Runtime error: The application has corrupted its heap memory area (address zero)!")}}(function(){var u=new Int16Array(1),V=new Int8Array(u.buffer);if(u[0]=25459,V[0]!==115||V[1]!==99)throw"Runtime error: expected the system to be little-endian! (Run with -sSUPPORT_BIG_ENDIAN to bypass)"})();var Yt=[],Ut=[],Ct=[],zt=!1,kt=0;function Jt(){if(i.preRun)for(typeof i.preRun=="function"&&(i.preRun=[i.preRun]);i.preRun.length;)ee(i.preRun.shift());xn(Yt)}function Wt(){c(!zt),zt=!0,gt(),!i.noFSInit&&!K.init.initialized&&K.init(),K.ignorePermissions=!1,pi.init(),xn(Ut)}function bt(){if(gt(),i.postRun)for(typeof i.postRun=="function"&&(i.postRun=[i.postRun]);i.postRun.length;)je(i.postRun.shift());xn(Ct)}function ee(u){Yt.unshift(u)}function ce(u){Ut.unshift(u)}function je(u){Ct.unshift(u)}c(Math.imul,"This browser does not support Math.imul(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),c(Math.fround,"This browser does not support Math.fround(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),c(Math.clz32,"This browser does not support Math.clz32(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),c(Math.trunc,"This browser does not support Math.trunc(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill");var Se=0,Ue=null,Me=null,Ce={};function Fe(u){for(var V=u;;){if(!Ce[u])return u;u=V+Math.random()}}function ni(u){Se++,i.monitorRunDependencies&&i.monitorRunDependencies(Se),u?(c(!Ce[u]),Ce[u]=1,Ue===null&&typeof setInterval<"u"&&(Ue=setInterval(()=>{if(k){clearInterval(Ue),Ue=null;return}var V=!1;for(var W in Ce)V||(V=!0,F("still waiting on run dependencies:")),F("dependency: "+W);V&&F("(end of list)")},1e4))):F("warning: run dependency added without ID")}function ze(u){if(Se--,i.monitorRunDependencies&&i.monitorRunDependencies(Se),u?(c(Ce[u]),delete Ce[u]):F("warning: run dependency removed without ID"),Se==0&&(Ue!==null&&(clearInterval(Ue),Ue=null),Me)){var V=Me;Me=null,V()}}function Be(u){i.onAbort&&i.onAbort(u),u="Aborted("+u+")",F(u),k=!0,y=1;var V=new WebAssembly.RuntimeError(u);throw s(V),V}var Mi="data:application/octet-stream;base64,";function Ri(u){return u.startsWith(Mi)}function si(u){return u.startsWith("file://")}function qe(u){return function(){c(zt,`native function \`${u}\` called before runtime initialization`);var V=M[u];return c(V,`exported native function \`${u}\` not found`),V.apply(null,arguments)}}var Oi;Oi="data:application/octet-stream;base64,AGFzbQEAAAABtgRHYAF/AX9gAX8AYAJ/fwBgAn9/AX9gA39/fwF/YAZ/f39/f38Bf2AEf39/fwF/YAV/f39/fwF/YAN/f38AYAAAYAR/f39/AGAIf39/f39/f38Bf2AGf39/f39/AGAFf39/f38AYAABf2AHf39/f39/fwF/YAd/f39/f39/AGAFf35+fn4AYAF8AXxgBH98f38Bf2AFf39/f34Bf2ACfHwBfGADf35/AX5gC39/f39/f39/f39/AX9gCn9/f39/f39/f38AYAR/fn5/AGAFf39/f3wBf2ACf3wBf2AEf398fwF/YAZ/f39/fn4Bf2AHf39/f39+fgF/YAN/f38BfGACfH8BfGABfABgBX9/fH9/AGADfHx/AXxgBn98f39/fwF/YAV/f35/fwBgA39/fwF+YAR/f39/AX5gDH9/f39/f39/f39/fwF/YA9/f39/f39/f39/f39/f38AYAh/f39/f39/fwBgDX9/f39/f39/f39/f38AYAl/f39/f39/f38AYAABfGAEfn5+fgF/YAN+fn4Bf2ABfgF/YAJ+fgF8YAJ/fABgAn5+AX1gAn9/AXxgA39/fABgBH98f38AYAR/f3x8AGADf398AX9gAX4BfmAFf39/fH8Bf2AGf39/fH9/AGACfH8Bf2ACfn8Bf2ACf34AYAJ/fwF+YAN/f34AYAJ/fgF/YAR/f39+AX5gA39/fwF9YAl/f39/f39/f38Bf2AKf39/f39/f39/fwF/YAR/f35+AAKxCCUDZW52HGVtc2NyaXB0ZW5fcnVuX3NjcmlwdF9zdHJpbmcAAANlbnYLX19jeGFfdGhyb3cACANlbnYNX2VtdmFsX2RlY3JlZgABA2VudhZfZW1iaW5kX3JlZ2lzdGVyX2NsYXNzACsDZW52Il9lbWJpbmRfcmVnaXN0ZXJfY2xhc3NfY29uc3RydWN0b3IADANlbnYfX2VtYmluZF9yZWdpc3Rlcl9jbGFzc19mdW5jdGlvbgAsA2Vudh9fZW1iaW5kX3JlZ2lzdGVyX2NsYXNzX3Byb3BlcnR5ABgDZW52E19lbXZhbF9nZXRfcHJvcGVydHkAAwNlbnYSX2VtdmFsX25ld19jc3RyaW5nAAADZW52CV9lbXZhbF9hcwAfA2VudhZfZW12YWxfcnVuX2Rlc3RydWN0b3JzAAEDZW52GV9lbWJpbmRfcmVnaXN0ZXJfZnVuY3Rpb24AEANlbnYYZW1zY3JpcHRlbl9hc21fY29uc3RfaW50AAQDZW52FV9lbWJpbmRfcmVnaXN0ZXJfdm9pZAACA2VudhVfZW1iaW5kX3JlZ2lzdGVyX2Jvb2wADQNlbnYbX2VtYmluZF9yZWdpc3Rlcl9zdGRfc3RyaW5nAAIDZW52HF9lbWJpbmRfcmVnaXN0ZXJfc3RkX3dzdHJpbmcACANlbnYWX2VtYmluZF9yZWdpc3Rlcl9lbXZhbAACA2VudhhfZW1iaW5kX3JlZ2lzdGVyX2ludGVnZXIADQNlbnYWX2VtYmluZF9yZWdpc3Rlcl9mbG9hdAAIA2VudhxfZW1iaW5kX3JlZ2lzdGVyX21lbW9yeV92aWV3AAgDZW52E2Vtc2NyaXB0ZW5fZGF0ZV9ub3cALQNlbnYgX2Vtc2NyaXB0ZW5fZ2V0X25vd19pc19tb25vdG9uaWMADhZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxB2ZkX3JlYWQABhZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxCGZkX3dyaXRlAAYWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MQhmZF9jbG9zZQAAA2VudhVlbXNjcmlwdGVuX21lbWNweV9iaWcACANlbnYJX3R6c2V0X2pzAAgDZW52FmVtc2NyaXB0ZW5fcmVzaXplX2hlYXAAAANlbnYFYWJvcnQACRZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxEWVudmlyb25fc2l6ZXNfZ2V0AAMWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MQtlbnZpcm9uX2dldAADA2VudgpzdHJmdGltZV9sAAcDZW52F19lbWJpbmRfcmVnaXN0ZXJfYmlnaW50ABAWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MQdmZF9zZWVrAAcDZW52Cl9ta3RpbWVfanMAAANlbnYKX2dtdGltZV9qcwAIA84EzAQJDgABBAAEBAYJACARAAABAwIuLxkRGRERAAEJDg4ODgEAEREVMAQVMQIyAjMBAgAJAQkBAAACCQAAAQAOAwQ0NQMIAQQSEhU2AhMCIQMBATcDBQIBCQEDAAMICAABCQEOAwgbOAACAwgTOQIEBAEJDgMDAAIBAQICCQAAAgECGxw6HAABAAk7IgkSEhIhCQAJEgAEBBYACQQAFgMjPCAHDwgACj0NAwQkAggAAD4ABhEZCj9ABgQEAwlBAAABAAECBCUKBAQAAAMEBAoKAwABAAEAAQICAAMAAAAAAQABAAADAAEEBAAEAAEBAAMAAAACAgQCAggEAAMBCAIIAgIAAgAEAwIAAwADAgQDAgADAAMDAAMBBkIKBwoEBwoEAgAEBQAPAAABBQAIFwYKBA4mAgUnBQYmBQYFJwUNKEMFHwUKBQQDBQAPAAUDCBcEBQUFBQUNKAUFBQcAAAcKBwQQAhQHFBoEBhAdBwcABxAFBBQHFBoQHQcLAAUFBQwFDAUNBwsLBQUFDAUMBQ0HCw8MDwACAgIAAgIPFwIICAAAAwMPDQ8XAgIAAgADDw0eGCkEBR4YKQQFBAwMAgEIAg4ICAEBAAEAAAAAAgEAAQABAAEAAQIBAQAAAAABAAEAAQABAQIBAQEAAAACAgIBAAAAAgICCwsHBwALCwcBAAsECwcHAAAHAAsHBAYGBgMEAwQGBAcBAAMEAwQGBAcBAAEqKgMDAwMDAQkBCQQEBAMMCg0KCAoNCgQDDRAMDQwMAAAAAAEAIxUHEA9ERUYEBwFwAc4DzgMFBwEBgAyAgAIGFwR/AUGAuRgLfwFBAAt/AUEAC38BQQALB50EGwZtZW1vcnkCABFfX3dhc21fY2FsbF9jdG9ycwAlBm1hbGxvYwAzBGZyZWUANBBpbmZsYXRlRWxsaXBzb2lkALIBFGdldENvdmVyYWdlUG9zaXRpb25zAK0BBmZmbHVzaAC3AQ1fX2dldFR5cGVOYW1lALQBG19lbWJpbmRfaW5pdGlhbGl6ZV9iaW5kaW5ncwC1ARBfX2Vycm5vX2xvY2F0aW9uACYZX19pbmRpcmVjdF9mdW5jdGlvbl90YWJsZQEAC3NldFRlbXBSZXQwAD8VZW1zY3JpcHRlbl9zdGFja19pbml0AEAZZW1zY3JpcHRlbl9zdGFja19nZXRfZnJlZQBBGWVtc2NyaXB0ZW5fc3RhY2tfZ2V0X2Jhc2UAQhhlbXNjcmlwdGVuX3N0YWNrX2dldF9lbmQAQwlzdGFja1NhdmUARAxzdGFja1Jlc3RvcmUARQpzdGFja0FsbG9jAEYcZW1zY3JpcHRlbl9zdGFja19nZXRfY3VycmVudABEIl9fY3hhX2luY3JlbWVudF9leGNlcHRpb25fcmVmY291bnQAzQQVX19jeGFfaXNfcG9pbnRlcl90eXBlAOMEDGR5bkNhbGxfamlqaQDrBA5keW5DYWxsX3ZpaWppaQDsBA5keW5DYWxsX2lpaWlpagDtBA9keW5DYWxsX2lpaWlpamoA7gQQZHluQ2FsbF9paWlpaWlqagDvBAnrBgEAQQELzQNSWlxdXl5fYGFiY2RlZmd6XXt8fX5/gwFdhAFghQGGAYcBiAGJAYoBiwGMAY0BVpMBlAFde2CVAZYBXV5ee5cBmAGWAZkBmgGeAV1eXnt8nwGgAYwBoQGNAaIBowGkAYkBpQGmAaUBpwGoAYwBqwGsAa0BXrMB3AHNAc4B2wGeAjTLAij6A/kD9wPvA/ED8wP1A4kEiASGBP8DgQSDBIUEb44BXpsBnQGbAZwBqgGpAYEBggG7AbkBugG+Ab8BuAHjAeQB5QHmAecB6AG+Ab4B6QHrAewB7QHuAe0BhwKIAuUB5gHnAegBvgG+AYkC6wGLAu0BjALtAeQBsQKyArQCtQL1AfYB9wH4AeAB4gHhAeIB5AGuAqYCrwKwAoACgQKCAoMCiAKpAqoCrAKtAvUB9gH3AfgB4AHiAYgCpQKmAqcCqAKAAoECggKDAsIEwQTmA7kEuAS6BLsEvAS9BPIBvgS/BMAEoQSgBKIEpASmBKcEvgGpBKoEkgSRBJMElASVBJYElwSLBIoEjASNBI4EjwSQBF6bAZsBrQSuBK8EsASxBLIEswS0BPIBtQS2BLcEmwGrBKsEmgQnJ6wEJ5sBnQSeBJoEvgG+AZ8EnASbAZ0EngSaBL4BvgGfBJwEmwGYBJkEmgS+Ab4BmwScBJsBmASZBJoEvgG+AZsEnARemwG9Ar4CvwJemwHAAsECxQKbAcYCzALWAtgC2wLbAt0C3wLjAuUC5wKbAeoC7gLzAvQC9QL1AvYC9wL6AvsC/AKbAf0CgAOGA4cDiAOJA40DjgObAY8DkQOVA5YDlwOYA5oDmwNemwGdA54DnwOgA6IDpAOnA/sD/AP9A/4DgASCBIQEXpsBnQOpA6oDqwOtA68DsgPqA+sD7APtA/AD8gP0A+gD6QOzA+gD6QO1A5sBtgO2A7cDtwO3A7gDvgG5A7kDmwG2A7YDtwO3A7cDuAO+AbkDuQObAboDugO3A7cDtwO7A74BuQO5A5sBugO6A7cDtwO3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QZ3JAEHXoBIQKyIQQQA6ANegEiADQQA2AjggA0IANwMwA0AgBEEBcUUEQCADQTBqIAQgEGosAAAQkAELIARBAWoiBEHXoBJHDQALQQAhBEGwihQtAABFBEBBpIoUQdAAEFQiATYCAEGoihRCwICAgICKgICAfzcCACABQZrtEikAADcAOCABQZLtEikAADcAMCABQYrtEikAADcAKCABQYLtEikAADcAICABQfrsEikAADcAGCABQfLsEikAADcAECABQersEikAADcACCABQeLsEikAADcAACABQQA6AEBBsIoUQQE6AAALQYAIEFRB/wFBgAgQKSEKQaSKFEGkihQoAgBBr4oULAAAQQBOGyEAA0AgCiAAIARqLAAAQQJ0aiAENgIAIAogACAEQQFyIgFqLAAAQQJ0aiABNgIAIAogACAEQQJyIgFqLAAAQQJ0aiABNgIAIAogACAEQQNyIgFqLAAAQQJ0aiABNgIAIARBBGoiBEHAAEcNAAsCQCADKAI0IAMtADsiASABwEEASCIAGyIBRQRAQQAhBEEAIQEMAQsgAygCMCADQTBqIAAbIg4gAWohB0F4IQtBACEEQQAhAQNAIAogDi0AAEECdGooAgAiAEF/Rg0BIAAgCUEGdGohCQJ/IAtBBmoiACALQXpIDQAaIAkgAHUhCCAEIAZJBEAgBCAIOgAAIARBAWohBCALQQJrDAELIAQgAWsiDEEBaiIFQQBIDQRB/////wcgBiABayICQQF0IgAgBSAAIAVLGyACQf////8DTxsiDQR/IA0QVAVBAAsiDyAMaiICIAg6AAACfyACIAEgBEYNABogAUF/cyAEaiEIQQAhBiACIQUgDEEDcSIABEADQCAFQQFrIgUgBEEBayIELQAAOgAAIAZBAWoiBiAARw0ACwsgDyAIQQNJDQAaA0AgBUEBayAEQQFrLQAAOgAAIAVBAmsgBEECay0AADoAACAFQQNrIARBA2stAAA6AAAgBUEEayIFIARBBGsiBC0AADoAACABIARHDQALIA8LIQAgAQRAIAEQNAsgDSAPaiEGIAJBAWohBCAAIQEgC0ECawshCyAOQQFqIg4gB0cNAAsLIAoQNCADLAA7QQBIBEAgAygCMBA0CyAQEDQgBCABayICQfD///8HTw0CAkAgAkEKTQRAIAMgAjoAOyADQTBqIQUMAQsg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BEL///////////8AgyIJEDdBAEwEQCABIAogAyAJEDcEQCABIQQMAgsgBUHwAGogASACQgBCABA8IAUpA3ghAiAFKQNwIQQMAQsgBEIwiKdB//8BcSEGIAcEfiABBSAFQeAAaiABIApCAEKAgICAgIDAu8AAEDwgBSkDaCIKQjCIp0H4AGshByAFKQNgCyEEIAZFBEAgBUHQAGogAyAJQgBCgICAgICAwLvAABA8IAUpA1giCUIwiKdB+ABrIQYgBSkDUCEDCyAJQv///////z+DQoCAgICAgMAAhCELIApC////////P4NCgICAgICAwACEIQogBiAHSARAA0ACfiAKIAt9IAMgBFatfSIJQgBZBEAgCSAEIAN9IgSEUARAIAVBIGogASACQgBCABA8IAUpAyghAiAFKQMgIQQMBQsgCUIBhiAEQj+IhAwBCyAKQgGGIARCP4iECyEKIARCAYYhBCAHQQFrIgcgBkoNAAsgBiEHCwJAIAogC30gAyAEVq19IglCAFMEQCAKIQkMAQsgCSAEIAN9IgSEQgBSDQAgBUEwaiABIAJCAEIAEDwgBSkDOCECIAUpAzAhBAwBCyAJQv///////z9YBEADQCAEQj+IIQEgB0EBayEHIARCAYYhBCABIAlCAYaEIglCgICAgICAwABUDQALCyAIQYCAAnEhBiAHQQBMBEAgBUFAayAEIAlC////////P4MgB0H4AGogBnKtQjCGhEIAQoCAgICAgMDDPxA8IAUpA0ghAiAFKQNAIQQMAQsgCUL///////8/gyAGIAdyrUIwhoQhAgsgACAENwMAIAAgAjcDCCAFQYABaiQAC1IBAn9BuIIUKAIAIgEgAEEHakF4cSICaiEAAkAgAkEAIAAgAU0bDQAgAD8AQRB0SwRAIAAQHEUNAQtBuIIUIAA2AgAgAQ8LQbCGFEEwNgIAQX8LyCgBC38jAEEQayIKJAACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAIABB9AFNBEBBtIYUKAIAIgZBECAAQQtqQXhxIABBC0kbIgVBA3YiAHYiAUEDcQRAAkAgAUF/c0EBcSAAaiICQQN0IgFB3IYUaiIAIAFB5IYUaigCACIBKAIIIgRGBEBBtIYUIAZBfiACd3E2AgAMAQsgBCAANgIMIAAgBDYCCAsgAUEIaiEAIAEgAkED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ASAANgIMIAQgADYCCCAAQQA2AhggACAENgIMIAAgATYCCAsL2wECAX8CfkEBIQQCQCAAQgBSIAFC////////////AIMiBUKAgICAgIDA//8AViAFQoCAgICAgMD//wBRGw0AIAJCAFIgA0L///////////8AgyIGQoCAgICAgMD//wBWIAZCgICAgICAwP//AFEbDQAgACAChCAFIAaEhFAEQEEADwsgASADg0IAWQRAQX8hBCAAIAJUIAEgA1MgASADURsNASAAIAKFIAEgA4WEQgBSDwtBfyEEIAAgAlYgASADVSABIANRGw0AIAAgAoUgASADhYRCAFIhBAsgBAvAAQIBfwJ+QX8hAwJAIABCAFIgAUL///////////8AgyIEQoCAgICAgMD//wBWIARCgICAgICAwP//AFEbDQAgAkL///////////8AgyIFQoCAgICAgMD//wBWIAVCgICAgICAwP//AFJxDQAgACAEIAWEhFAEQEEADwsgASACg0IAWQRAIAEgAlIgASACU3ENASAAIAEgAoWEQgBSDwsgAEIAUiABIAJVIAEgAlEbDQAgACABIAKFhEIAUiEDCyADC1ABAX4CQCADQcAAcQRAIAEgA0FAaq2GIQJCACEBDAELIANFDQAgAiADrSIEhiABQcAAIANrrYiEIQIgASAEhiEBCyAAIAE3AwAgACACNwMIC6kPAgV/D34jAEHQAmsiBSQAIARC////////P4MhCyACQv///////z+DIQogAiAEhUKAgICAgICAgIB/gyENIARCMIinQf//AXEhCAJAAkAgAkIwiKdB//8BcSIJQf//AWtBgoB+TwRAIAhB//8Ba0GBgH5LDQELIAFQIAJC////////////AIMiDEKAgICAgIDA//8AVCAMQoCAgICAgMD//wBRG0UEQCACQoCAgICAgCCEIQ0MAgsgA1AgBEL///////////8AgyICQoCAgICAgMD//wBUIAJCgICAgICAwP//AFEbRQRAIARCgICAgICAIIQhDSADIQEMAgsgASAMQoCAgICAgMD//wCFhFAEQCADIAJCgICAgICAwP//AIWEUARAQgAhAUKAgICAgIDg//8AIQ0MAwsgDUKAgICAgIDA//8AhCENQgAhAQwCCyADIAJCgICAgICAwP//AIWEUARAQgAhAQwCCyABIAyE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IAFQIAJC////////////AIMiC0KAgICAgIDA//8AVCALQoCAgICAgMD//wBRG0UEQCACQoCAgICAgCCEIQoMAgsgA1AgBEL///////////8AgyICQoCAgICAgMD//wBUIAJCgICAgICAwP//AFEbRQRAIARCgICAgICAIIQhCiADIQEMAgsgASALQoCAgICAgMD//wCFhFAEQCACIAOEUARAQoCAgICAgOD//wAhCkIAIQEMAwsgCkKAgICAgIDA//8AhCEKQgAhAQwCCyADIAJCgICAgICAwP//AIWEUARAIAEgC4QhAkIAIQEgAlAEQEKAgICAgIDg//8AIQoMAwsgCkKAgICAgIDA//8AhCEKDAILIAEgC4RQBEBCACEBDAILIAIgA4RQBEBCACEBDAILIAtC////////P1gEQCAFQdAAaiABIA0gASANIA1QIgYbeSAGQQZ0rXynIgZBD2sQOUEQIAZrIQYgBSkDWCINQiCIIQ4gBSkDUCEBCyACQv///////z9WDQAgBUFAayADIAwgAyAMIAxQIggbeSAIQQZ0rXynIghBD2sQOSAGIAhrQRBqIQYgBSkDSCEMIAUpA0AhAwsgA0IPhiILQoCA/v8PgyICIAFCIIgiBH4iECALQiCIIhMgAUL/////D4MiAX58Ig9CIIYiESABIAJ+fCILIBFUrSACIA1C/////w+DIg1+IhUgBCATfnwiESAMQg+GIhIgA0IxiIRC/////w+DIgMgAX58IhQgDyAQVK1CIIYgD0IgiIR8Ig8gAiAOQoCABIQiDH4iFiANIBN+fCIOIBJCIIhCgICAgAiEIgIgAX58IhAgAyAEfnwiEkIghnwiF3whASAHIAlqIAZqQf//AGshBgJAIAIgBH4iGCAMIBN+fCIEIBhUrSAEIAQgAyANfnwiBFatfCACIAx+fCAEIAQgESAVVK0gESAUVq18fCIEVq18IAMgDH4iAyACIA1+fCICIANUrUIghiACQiCIhHwgBCACQiCGfCICIARUrXwgAiACIBAgElatIA4gFlStIA4gEFatfHxCIIYgEkIgiIR8IgJWrXwgAiACIA8gFFStIA8gF1atfHwiAlatfCIEQoCAgICAgMAAg0IAUgRAIAZBAWohBgwBCyALQj+IIQMgBEIBhiACQj+IhCEEIAJCAYYgAUI/iIQhAiALQgGGIQsgAyABQgGGhCEBCyAGQf//AU4EQCAKQoCAgICAgMD//wCEIQpCACEBDAELAn4gBkEATARAQQEgBmsiB0H/AE0EQCAFQTBqIAsgASAGQf8AaiIGEDkgBUEgaiACIAQgBhA5IAVBEGogCyABIAcQOyAFIAIgBCAHEDsgBSkDMCAFKQM4hEIAUq0gBSkDICAFKQMQhIQhCyAFKQMoIAUpAxiEIQEgBSkDACECIAUpAwgMAgtCACEBDAILIARC////////P4MgBq1CMIaECyAKhCEKIAtQIAFCAFkgAUKAgICAgICAgIB/URtFBEAgCiACQgF8IgFQrXwhCgwBCyALIAFCgICAgICAgICAf4WEQgBSBEAgAiEBDAELIAogAiACQgGDfCIBIAJUrXwhCgsgACABNwMAIAAgCjcDCCAFQeAAaiQAC3UBAX4gACABIAR+IAIgA358IANCIIgiAiABQiCIIgR+fCADQv////8PgyIDIAFC/////w+DIgF+IgVCIIggAyAEfnwiA0IgiHwgASACfiADQv////8Pg3wiAUIgiHw3AwggACAFQv////8PgyABQiCGhDcDAAumAQEBfwJ/AkAgACgCTCIBQQBOBEAgAUUNAUHEnxQoAgAgAUH/////e3FHDQELIAAoAgQiASAAKAIIRwRAIAAgAUEBajYCBCABLQAADAILIAAQ0QEMAQsgACAAKAJMIgFB/////wMgARs2AkwCfyAAKAIEIgEgACgCCEcEQCAAIAFBAWo2AgQgAS0AAAwBCyAAENEBCyEBIAAoAkwaIABBADYCTCABCwsGACAAJAELDgBBgLkYJANBgLkUJAILBwAjACMCawsEACMDCwQAIwILBAAjAAsGACAAJAALEAAjACAAa0FwcSIAJAAgAAvFCQIEfwV+IwBB8ABrIgYkACAEQv///////////wCDIQkCQAJAIAFQIgUgAkL///////////8AgyIKQoCAgICAgMD//wB9QoCAgICAgMCAgH9UIApQG0UEQCADQgBSIAlCgICAgICAwP//AH0iC0KAgICAgIDAgIB/ViALQoCAgICAgMCAgH9RGw0BCyAFIApCgICAgICAwP//AFQgCkKAgICAgIDA//8AURtFBEAgAkKAgICAgIAghCEEIAEhAwwCCyADUCAJQoCAgICAgMD//wBUIAlCgICAgICAwP//AFEbRQRAIARCgICAgICAIIQhBAwCCyABIApCgICAgICAwP//AIWEUARAQoCAgICAgOD//wAgAiABIAOFIAIgBIVCgICAgICAgICAf4WEUCIFGyEEQgAgASAFGyEDDAILIAMgCUKAgICAgIDA//8AhYRQDQEgASAKhFAEQCADIAmEQgBSDQIgASADgyEDIAIgBIMhBAwCCyADIAmEQgBSDQAgASEDIAIhBAwBCyADIAEgASADVCAJIApWIAkgClEbIggbIQogBCACIAgbIgtC////////P4MhCSACIAQgCBsiAkIwiKdB//8BcSEHIAtCMIinQf//AXEiBUUEQCAGQeAAaiAKIAkgCiAJIAlQIgUbeSAFQQZ0rXynIgVBD2sQOSAGKQNoIQkgBikDYCEKQRAgBWshBQsgASADIAgbIQMgAkL///////8/gyEEIAdFBEAgBkHQAGogAyAEIAMgBCAEUCIHG3kgB0EGdK18pyIHQQ9rEDlBECAHayEHIAYpA1ghBCAGKQNQIQMLIARCA4YgA0I9iIRCgICAgICAgASEIQEgCUIDhiAKQj2IhCEEIAIgC4UhDQJ+IANCA4YiAiAFIAdGDQAaIAUgB2siB0H/AEsEQEIAIQFCAQwBCyAGQUBrIAIgAUGAASAHaxA5IAZBMGogAiABIAcQOyAGKQM4IQEgBikDMCAGKQNAIAYpA0iEQgBSrYQLIQkgBEKAgICAgICABIQhDCAKQgOGIQoCQCANQgBTBEBCACEDQgAhBCAJIAqFIAEgDIWEUA0CIAogCX0hAiAMIAF9IAkgClatfSIEQv////////8DVg0BIAZBIGogAiAEIAIgBCAEUCIHG3kgB0EGdK18p0EMayIHEDkgBSAHayEFIAYpAyghBCAGKQMgIQIMAQsgCSAKfCICIAlUrSABIAx8fCIEQoCAgICAgIAIg1ANACAJQgGDIARCP4YgAkIBiISEIQIgBUEBaiEFIARCAYghBAsgC0KAgICAgICAgIB/gyEBIAVB//8BTgRAIAFCgICAgICAwP//AIQhBEIAIQMMAQtBACEHAkAgBUEASgRAIAUhBwwBCyAGQRBqIAIgBCAFQf8AahA5IAYgAiAEQQEgBWsQOyAGKQMAIAYpAxAgBikDGIRCAFKthCECIAYpAwghBAsgAqdBB3EiBUEES60gBEI9hiACQgOIhCICfCIDIAJUrSAEQgOIQv///////z+DIAetQjCGhCABhHwhBAJAIAVBBEYEQCAEIANCAYMiASADfCIDIAFUrXwhBAwBCyAFRQ0BCwsgACADNwMAIAAgBDcDCCAGQfAAaiQAC0QBAX8jAEEQayIFJAAgBSABIAIgAyAEQoCAgICAgICAgH+FEEcgBSkDACEBIAAgBSkDCDcDCCAAIAE3AwAgBUEQaiQAC4EMAwV8A34GfyMAQRBrIg0kAAJAAkAgAb0iCEI0iKciDEH/D3EiDkG+CGsiD0H/fksgAL0iB0I0iKciCkH/D2tBgnBPcQ0AIAhCAYZCgICAgICAgBB8QoGAgICAgIAQVARARAAAAAAAAPA/IQIgB0KAgICAgICA+D9RDQIgCEIBhiIJUA0CIAlCgYCAgICAgHBUIAdCAYYiB0KAgICAgICAcFhxRQRAIAAgAaAhAgwDCyAHQoCAgICAgIDw/wBRDQJEAAAAAAAAAAAgASABoiAHQv/////////v/wBWIAhCAFlzGyECDAILIAdCAYZCgICAgICAgBB8QoGAgICAgIAQVARAIAAgAKIhAiAHQgBTBEAgApogAiAIEEpBAUYbIQILIAhCAFkNAiMAQRBrIgpEAAAAAAAA8D8gAqM5AwggCisDCCECDAILIAdCAFMEQCAIEEoiC0UEQCAAIAChIgAgAKMhAgwDCyAKQf8PcSEKIAtBAUZBEnQhCyAHQv///////////wCDIQcLIA9B/35NBEBEAAAAAAAA8D8hAiAHQoCAgICAgID4P1ENAiAOQb0HTQRAIAEgAZogB0KAgICAgICA+D9WG0QAAAAAAADwP6AhAgwDCyAMQYAQSSAHQoGAgICAgID4P1RHBEAjAEEQayIKRAAAAAAAAABwOQMIIAorAwhEAAAAAAAAAHCiIQIMAwsjAEEQayIKRAAAAAAAAAAQOQMIIAorAwhEAAAAAAAAABCiIQIMAgsgCg0AIABEAAAAAAAAMEOivUL///////////8Ag0KAgICAgICAoAN9IQcLAnwgCEKAgIBAg78iBSANIAdCgICAgNCqpfM/fSIIQjSHp7ciA0H4GCsDAKIgCEItiKdB/wBxQQV0IgpB0BlqKwMAoCAHIAhCgICAgICAgHiDfSIHQoCAgIAIfEKAgICAcIO/IgAgCkG4GWorAwAiBKJEAAAAAAAA8L+gIgIgB78gAKEgBKIiBKAiACADQfAYKwMAoiAKQcgZaisDAKAiAyAAIAOgIgOhoKAgBCAAQYAZKwMAIgSiIgYgAiAEoiIEoKKgIAIgBKIiAiADIAMgAqAiAqGgoCAAIAAgBqIiA6IgAyADIABBsBkrAwCiQagZKwMAoKIgAEGgGSsDAKJBmBkrAwCgoKIgAEGQGSsDAKJBiBkrAwCgoKKgIgAgAiACIACgIgKhoDkDCCACvUKAgIBAg78iA6IhACABIAWhIAOiIA0rAwggAiADoaAgAaKgIQECQCAAvUI0iKdB/w9xIgpByQdrQT9JDQAgCkHJB0kEQCAARAAAAAAAAPA/oCIAmiAAIAsbDAILIApBiQhJIQxBACEKIAwNACAAvUIAUwRAIwBBEGsiCkQAAAAAAAAAkEQAAAAAAAAAECALGzkDCCAKKwMIRAAAAAAAAAAQogwCCyMAQRBrIgpEAAAAAAAAAPBEAAAAAAAAAHAgCxs5AwggCisDCEQAAAAAAAAAcKIMAQtBgAgrAwAgAKJBiAgrAwAiAqAiAyACoSICQZgIKwMAoiACQZAIKwMAoiAAoKAgAaAiACAAoiIBIAGiIABBuAgrAwCiQbAIKwMAoKIgASAAQagIKwMAokGgCCsDAKCiIAO9IginQQR0QfAPcSIMQfAIaisDACAAoKCgIQAgDEH4CGopAwAgCCALrXxCLYZ8IQcgCkUEQAJ8IAhCgICAgAiDUARAIAdCgICAgICAgIg/fb8iASAAoiABoEQAAAAAAAAAf6IMAQsgB0KAgICAgICA8D98Ige/IgEgAKIiAyABoCIAmUQAAAAAAADwP2MEfCMAQRBrIgogCkQAAAAAAAAQADkDCCAKKwMIRAAAAAAAABAAojkDCCAHQoCAgICAgICAgH+DvyAARAAAAAAAAPC/RAAAAAAAAPA/IABEAAAAAAAAAABjGyICoCIFIAMgASAAoaAgACACIAWhoKCgIAKhIgAgAEQAAAAAAAAAAGEbBSAAC0QAAAAAAAAQAKILDAELIAe/IgEgAKIgAaALIQILIA1BEGokACACC04CAX8BfgJ/QQAgAEI0iKdB/w9xIgFB/wdJDQAaQQIgAUGzCEsNABpBAEIBQbMIIAFrrYYiAkIBfSAAg0IAUg0AGkECQQEgACACg1AbCwvoAgECfwJAIAAgAUYNACABIAAgAmoiBGtBACACQQF0a00EQCAAIAEgAhArDwsgACABc0EDcSEDAkACQCAAIAFJBEAgAwRAIAAhAwwDCyAAQQNxRQRAIAAhAwwCCyAAIQMDQCACRQ0EIAMgAS0AADoAACABQQFqIQEgAkEBayECIANBAWoiA0EDcQ0ACwwBCwJAIAMNACAEQQNxBEADQCACRQ0FIAAgAkEBayICaiIDIAEgAmotAAA6AAAgA0EDcQ0ACwsgAkEDTQ0AA0AgACACQQRrIgJqIAEgAmooAgA2AgAgAkEDSw0ACwsgAkUNAgNAIAAgAkEBayICaiABIAJqLQAAOgAAIAINAAsMAgsgAkEDTQ0AA0AgAyABKAIANgIAIAFBBGohASADQQRqIQMgAkEEayICQQNLDQALCyACRQ0AA0AgAyABLQAAOgAAIANBAWohAyABQQFqIQEgAkEBayICDQALCyAAC5AEAgR+An8CQAJAIAG9IgRCAYYiA1ANACABvSECIAC9IgVCNIinQf8PcSIGQf8PRg0AIAJC////////////AINCgYCAgICAgPj/AFQNAQsgACABoiIAIACjDwsgAyAFQgGGIgJaBEAgAEQAAAAAAAAAAKIgACACIANRGw8LIARCNIinQf8PcSEHAn4gBkUEQEEAIQYgBUIMhiICQgBZBEADQCAGQQFrIQYgAkIBhiICQgBZDQALCyAFQQEgBmuthgwBCyAFQv////////8Hg0KAgICAgICACIQLIQICfiAHRQRAQQAhByAEQgyGIgNCAFkEQANAIAdBAWshByADQgGGIgNCAFkNAAsLIARBASAHa62GDAELIARC/////////weDQoCAgICAgIAIhAshBCAGIAdKBEADQAJAIAIgBH0iA0IAUw0AIAMiAkIAUg0AIABEAAAAAAAAAACiDwsgAkIBhiECIAZBAWsiBiAHSg0ACyAHIQYLAkAgAiAEfSIDQgBTDQAgAyICQgBSDQAgAEQAAAAAAAAAAKIPCwJAIAJC/////////wdWBEAgAiEDDAELA0AgBkEBayEGIAJCgICAgICAgARUIQcgAkIBhiIDIQIgBw0ACwsgBUKAgICAgICAgIB/gyECIAZBAEoEfiADQoCAgICAgIAIfSAGrUI0hoQFIANBASAGa62ICyAChL8L0QMCAn4CfyMAQSBrIgQkAAJAIAFC////////////AIMiA0KAgICAgIDAgDx9IANCgICAgICAwP/DAH1UBEAgAUIEhiAAQjyIhCEDIABC//////////8PgyIAQoGAgICAgICACFoEQCADQoGAgICAgICAwAB8IQIMAgsgA0KAgICAgICAgEB9IQIgAEKAgICAgICAgAhSDQEgAiADQgGDfCECDAELIABQIANCgICAgICAwP//AFQgA0KAgICAgIDA//8AURtFBEAgAUIEhiAAQjyIhEL/////////A4NCgICAgICAgPz/AIQhAgwBC0KAgICAgICA+P8AIQIgA0L///////+//8MAVg0AQgAhAiADQjCIpyIFQZH3AEkNACAEQRBqIAAgAUL///////8/g0KAgICAgIDAAIQiAiAFQYH3AGsQOSAEIAAgAkGB+AAgBWsQOyAEKQMIQgSGIAQpAwAiAEI8iIQhAiAEKQMQIAQpAxiEQgBSrSAAQv//////////D4OEIgBCgYCAgICAgIAIWgRAIAJCAXwhAgwBCyAAQoCAgICAgICACFINACACQgGDIAJ8IQILIARBIGokACACIAFCgICAgICAgICAf4OEvwt+AgJ/AX4jAEEQayIDJAAgAAJ+IAFFBEBCAAwBCyADIAEgAUEfdSICcyACayICrUIAIAJnIgJB0QBqEDkgAykDCEKAgICAgIDAAIVBnoABIAJrrUIwhnwgAUGAgICAeHGtQiCGhCEEIAMpAwALNwMAIAAgBDcDCCADQRBqJAAL+QECA34CfyMAQRBrIgUkAAJ+IAG9IgNC////////////AIMiAkKAgICAgICACH1C/////////+//AFgEQCACQjyGIQQgAkIEiEKAgICAgICAgDx8DAELIAJCgICAgICAgPj/AFoEQCADQjyGIQQgA0IEiEKAgICAgIDA//8AhAwBCyACUARAQgAMAQsgBSACQgAgA6dnQSBqIAJCIIinZyACQoCAgIAQVBsiBkExahA5IAUpAwAhBCAFKQMIQoCAgICAgMAAhUGM+AAgBmutQjCGhAshAiAAIAQ3AwAgACACIANCgICAgICAgICAf4OENwMIIAVBEGokAAtjAgF/AX4jAEEQayICJAAgAAJ+IAFFBEBCAAwBCyACIAGtQgAgAWciAUHRAGoQOSACKQMIQoCAgICAgMAAhUGegAEgAWutQjCGfCEDIAIpAwALNwMAIAAgAzcDCCACQRBqJAALtAMCA38BfiMAQSBrIgMkAAJAIAFC////////////AIMiBUKAgICAgIDAwD99IAVCgICAgICAwL/AAH1UBEAgAUIZiKchBCAAUCABQv///w+DIgVCgICACFQgBUKAgIAIURtFBEAgBEGBgICABGohAgwCCyAEQYCAgIAEaiECIAAgBUKAgIAIhYRCAFINASACIARBAXFqIQIMAQsgAFAgBUKAgICAgIDA//8AVCAFQoCAgICAgMD//wBRG0UEQCABQhmIp0H///8BcUGAgID+B3IhAgwBC0GAgID8ByECIAVC////////v7/AAFYNAEEAIQIgBUIwiKciBEGR/gBJDQAgA0EQaiAAIAFC////////P4NCgICAgICAwACEIgUgBEGB/gBrEDkgAyAAIAVBgf8AIARrEDsgAykDCCIAQhmIpyECIAMpAwAgAykDECADKQMYhEIAUq2EIgVQIABC////D4MiAEKAgIAIVCAAQoCAgAhRG0UEQCACQQFqIQIMAQsgBSAAQoCAgAiFhEIAUg0AIAJBAXEgAmohAgsgA0EgaiQAIAIgAUIgiKdBgICAgHhxcr4LGABBv4oULAAAQQBIBEBBtIoUKAIAEDQLC2oBA38gARAvIgJB8P///wdJBEACQCACQQpNBEAgACACOgALIAAhAwwBCyACQQ9yQQFqIgQQVCEDIAAgBEGAgICAeHI2AgggACADNgIAIAAgAjYCBAsgAyABIAIQSyACakEAOgAADwsQVQALNgEBf0EBIAAgAEEBTRshAAJAA0AgABAzIgENAUHwuBQoAgAiAQRAIAERCQAMAQsLEB0ACyABCwgAQag/EFgACxgAQa+KFCwAAEEASARAQaSKFCgCABA0CwsIAEG7PBBYAAthAQN/QQgQWSIBQayCFDYCACABQdiAFDYCACAAEC8iAkENahBUIgNBADYCCCADIAI2AgQgAyACNgIAIAEgA0EMaiAAIAJBAWoQKzYCBCABQYiBFDYCACABQaiBFEECEAEACw4AIABB0ABqEDNB0ABqCzIBAn8gAEHYgBQ2AgAgACgCBEEMayIBIAEoAghBAWsiAjYCCCACQQBIBEAgARA0CyAAC/QLAgV/BX4jAEEwayIFJAACQEHYABAzIgRFDQAgBEEEay0AAEEDcUUN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OQOIASAAQRhqIgQhAQJAAkAgACgCGCIDRQ0AA0AgAyIBKwMQIgsgKmQEQCABIgQoAgAiAw0BDAILIAsgKmNFDQIgASgCBCIDDQALIAFBBGohBAtB8AcQVCIDICo5AxAgA0EYakEAQdgHECkaIAMgATYCCCADQgA3AgAgBCADNgIAIAMhASAAKAIUKAIAIgUEQCAAIAU2AhQgBCgCACEBCyAAKAIYIAEQbiAAIAAoAhxBAWo2AhwLIANBGGogAkEYaiIBQdgHECsaIABBoAFqIAFB2AcQKxogAiwA+wdBAEgEQCACKALwBxA0CyACLACHCEEASARAIAIoAvwHEDQLIAIsAJMIQQBIBEAgAigCiAgQNAsgAkHwCGokAEEADwsQVQALXQECfyMAQRBrIgMkACABIAAoAgQiBEEBdWohASAAKAIAIQAgBEEBcQRAIAEoAgAgAGooAgAhAAsgAyACNgIMIAEgA0EMaiAAEQMAIQAgAygCDBACIANBEGokACAACw0AIAEgACgCAGorAwALDwAgASAAKAIAaiACOQMACw0AIAEgACgCAGooAgALDwAgASAAKAIAaiACNgIACxkAIAAEQCAAKAIAEGggACgCBBBoIAAQNAsLKAEBfyMAQRBrIgMkACADIAI2AgwgACABIAIQvQEhACADQRBqJAAgAAvHAQECfyMAQRBrIgEkAAJ8IAC9QiCIp0H/////B3EiAkH7w6T/A00EQEQAAAAAAADwPyACQZ7BmvIDSQ0BGiAARAAAAAAAAAAAEOoEDAELIAAgAKEgAkGAgMD/B08NABoCQAJAAkACQCAAIAEQwgFBA3EOAwABAgMLIAErAwAgASsDCBDqBAwDCyABKwMAIAErAwhBARDpBJoMAgsgASsDACABKwMIEOoEmgwBCyABKwMAIAErAwhBARDpBAshACABQRBqJAAgAAvLAQECfyMAQRBrIgEkAAJAIAC9QiCIp0H/////B3EiAkH7w6T/A00EQCACQYCAwPIDSQ0BIABEAAAAAAAAAABBABDpBCEADAELIAJBgIDA/wdPBEAgACAAoSEADAELAkACQAJAAkAgACABEMIBQQNxDgMAAQIDCyABKwMAIAErAwhBARDpBCEADAMLIAErAwAgASsDCBDqBCEADAILIAErAwAgASsDCEEBEOkEmiEADAELIAErAwAgASsD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QR8gAEEAQQAQBUEIEFQiAEEANgIEIABBIDYCAEEIEFQiAUEANgIEIAFBITYCAEHo9BJB6jpBwP0TQfjzEkEiIABBwP0TQZD0EkEjIAEQBgvAAQEDfyAABEAgAEGU8BI2AgACQEHoixQoAgAiAkHkixRGDQAgAiEBAkADQAJAIAEoAgQhAyABKAIIIABGDQAgAyIBQeSLFEcNAQwCCwsgASgCACICIAM2AgQgASgCBCACNgIAQeyLFEHsixQoAgBBAWs2AgAgARA0QeiLFCgCACECCyACQeSLFEYNAEEAIQEDQCACKAIIIAE2AhAgAUEBaiEBIAIoAgQiAkHkixRHDQALC0HwixRBAToAACAAEDQLC28BA39BFBBUIgFBAToABCABQZTwEjYCAEEMEFQiAEHkixQ2AgQgACABNgIIIABB5IsUKAIAIgI2AgAgAiAANgIEQeSLFCAANgIAQeyLFEHsixQoAgAiAEEBajYCACABIAA2AhBB8IsUQQE6AAAgAQsNACABIAAoAgBqLQAACw8AIAEgACgCAGogAjoAAAseACAAIAEgACgCCEEAIAAoAgAoAgAREwAaIAAoAggLNwEBfyABIAAoAgQiA0EBdWohASAAKAIAIQAgASACIANBAXEEfyABKAIAIABqKAIABSAACxEbAAsHACAAKAIQCwkAIAAgATYCEAs1AQF/IAEgACgCBCICQQF1aiEBIAAoAgAhACABIAJBAXEEfyABKAIAIABqKAIABSAACxEAAAs3AQF/IAEgACgCBCIDQQF1aiEBIAAoAgAhACABIAIgA0EBcQR/IAEoAgAgAGooAgAFIAALEQIACwQAQQALQwEDfyMAQSBrIgEkACABQQhqIgMgADcDACABQRhqIgIgAUEQaiADKQMAEN8BKQMANwMAIAIpAwAhACABQSBqJAAgAAuUAQECfwJAAkACQAJAIAAtAAsiA0GAAXFBB3YEQCAAKAIEIgMgACgCCEH/////B3FBAWsiAkYNAQwCC0EKIQIgA0H/AHEiA0EKRw0CCyAAIAJBASACIAIQxwMgAiEDCyAAKAIAIQIgACADQQFqNgIEDAELIAAgA0EBajoACyAAIQILIAIgA2oiACABOgAAIABBADoAAQvjAQECfyACQQBHIQMCQAJAAkAgAEEDcUUNACACRQ0AIAFB/wFxIQQDQCAALQAA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DCABRg0ADAELIAZC/////3dXBEAgAkEENgIADAMLIAZCgICAgAhZBEAgAkEENgIAQf////8HDAQLIAanDAMLCyACQQQ2AgBBAAwBC0GAgICAeAshACAEQRBqJAAgAAvaAQEDfyAAKAIEIAAtAAsiBEH/AHEgBEGAAXFBB3YbIQQCQCACIAFrQQVIDQAgBEUNACABIAIQ1QIgAkEEayEEIAAoAgQgAC0ACyICQf8AcSACQYABcUEHdhsgACgCACAAIAJBgAFxQQd2GyICaiEGAkADQAJAIAIsAAAiAEH/AGshBSABIARPDQAgBUH/AXFBggFPBEAgASgCACAARw0DCyABQQRqIQEgAiAGIAJrQQFKaiECDAELCyAFQf8BcUGCAUkNASAEKAIAQQFrIABJDQELIANBBDYCAAsLMgAgAkH/AXEhAgNAAkAgACABRwR/IAAtAAAgAkcNASAABSABCw8LIABBAWohAAwACwAL1AIBA39B3KoULQAABEBB2KoUKAIADwsjAEEgayIBJAACQAJAA0AgAUEIaiAAQQJ0aiAAQfjDAEH87RJBASAAdEH/////B3EbELgCIgI2AgAgAkF/Rg0BIABBAWoiAEEGRw0AC0Gc9hMhACABQQhqQZz2E0EYEJIBRQ0BQbT2EyEAIAFBCGpBtPYTQRgQkgFFDQFBACEAQfioFC0AAEUEQANAIABBAnRByKgUaiAAQfztEhC4AjYCACAAQQFqIgBBBkcNAAtB+KgUQQE6AABB4KgUQcioFCgCADYCAAtByKgUIQAgAUEIakHIqBRBGBCSAUUNAUHgqBQhACABQQhqQeCoFEEYEJIBRQ0BQRgQMyIARQ0AIAAgASkCCDcCACAAIAEpAhg3AhAgACABKQIQNwIIDAELQQAhAAsgAUEgaiQAQdyqFEEBOgAAQdiqFCAANgIAIAALFgAgACABIAJCgICAgICAgICAfxC7Ags/AQF/AkAgACABRg0AA0AgACABQQRrIgFPDQEgACgCACECIAAgASgCADYCACABIAI2AgAgAEEEaiEADAALAAsL5QQBAn8gAygCBCEAIAMoAhwhBiMAQeABayIDJAAgAyACNgLYASADIAE2AtwBIAAQzQIhByADQcgBaiAGIANB1wFqEM4CIANBvAFqIgJCADcCACACQQA2AgggAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCZAiADIAIoAgAgAiACLQALQYABcUEHdhsiBjYCuAEgAyADQRBqNgIMIANBADYCCANAAkAgA0HcAWogA0HYAWoQ/AENACADKAK4ASAGIAIoAgQgAi0ACyIAQf8AcSAAQYABcUEHdhsiAGpGBEAgAiAAQQF0EJkCIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQmQIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgYgAGo2ArgBCwJ/IAMoAtwBIgAoAgwiASAAKAIQRgRAIAAgACgCACgCJBEAAAwBCyABLQAAC8AgByAGIANBuAFqIANBCGogAywA1wEgAygCzAEgAy0A0wEgA0EQaiADQQxqQaDAExDPAg0AIANB3AFqEP4BGgwBCwsgAygCDCEAAkACQCADKALMASADLQDTASIBQf8AcSABQYABcUEHdhtFDQAgACADQRBqa0GfAUoNACADIABBBGoiATYCDCAAIAMoAgg2AgAMAQsgACEBCyAFIAYgAygCuAEgBCAHENcCNwMAIANByAFqIANBEGogASAEENECIANB3AFqIANB2AFqEPwBBEAgBCAEKAIAQQJyNgIACyADKALcASEAIAIQyQIaIANByAFqEMkCGiADQeABaiQAIAALrQECAn8BfiMAQRBrIgQkAAJAIAAgAUcEQEGwhhQoAgAhBUGwhhRBADYCABDTAhogACAEQQxqIAMQ1AIhBgJAQbCGFCgCACIABEAgBCgCDCABRw0BIABBxABHDQMgAkEENgIAQv///////////wBCgICAgICAgICAfyAGQgBVGyEGDAMLQbCGFCAFNgIAIAQoAgwgAUYNAgsLIAJBBDYCAEIAIQYLIARBEGokACAGC+UEAQJ/IAMoAgQhACADKAIcIQYjAEHgAWsiAyQAIAMgAjYC2AEgAyABNgLcASAAEM0CIQcgA0HIAWogBiADQdcBahDOAiADQbwBaiICQgA3AgAgAkEANgIIIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQmQIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgY2ArgBIAMgA0EQajYCDCADQQA2AggDQAJAIANB3AFqIANB2AFqEPwBDQAgAygCuAEgBiACKAIEIAItAAsiAEH/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KAL8ASEAIAIQyQIaIANBwAFqEMkCGiADQYACaiQAIAALtgECA38CfCMAQRBrIgMkAAJAAkACQCAAIAFHBEBBsIYUKAIAIQVBsIYUQQA2AgAQ0wIaIwBBEGsiBCQAIAQgACADQQxqQQEQvAIgBCkDACAEKQMIEE0hBiAEQRBqJABBsIYUKAIAIgBFDQEgAygCDCABRw0CIAYhByAAQcQARw0DDAILIAJBBDYCAAwCC0GwhhQgBTYCACADKAIMIAFGDQELIAJBBDYCACAHIQYLIANBEGokACAGC6MFAgN/AX4gAygCHCEAIwBBkAJrIgMkACADIAI2AogCIAMgATYCjAIgA0HQAWogACADQeABaiADQd8BaiADQd4BahDgAiADQcQBaiICQgA3AgAgAkEANgIIIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQmQIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgY2AsABIAMgA0EgajYCHCADQQA2AhggA0EBOgAXIANBxQA6ABYgAy0A3gHAIQEgAy0A3wHAIQcDQAJAIANBjAJqIANBiAJqEPwBDQAgAygCwAEgBiACKAIEIAItAAsiAEH/AHEgAEGAAXFBB3YbIgBqRgRAIAIgAEEBdBCZAiACIAItAAtBgAFxQQd2BH8gAigCCEH/////B3FBAWsFQQoLEJkCIAMgAigCACACIAItAAtBgAFxQQd2GyIGIABqNgLAAQsCfyADKAKMAiIAKAIMIgggACgCEEYEQCAAIAAoAgAoAiQRAAAMAQsgCC0AAAvAIANBF2ogA0EWaiAGIANBwAFqIAcgASADQdABaiADQSBqIANBHGogA0EYaiADQeABahDhAg0AIANBjAJqEP4BGgwBCwsgAygCHCEAAkACQCADKALUASADLQDbASIBQf8AcSABQYABcUEHdhtFDQAgAy0AF0UNACAAIANBIGprQZ8BSg0AIAMgAEEEaiIBNgIcIAAgAygCGDYCAAwBCyAAIQELIAMgBiADKALAASAEEOYCIAMpAwAhCSAFIAMpAwg3AwggBSAJNwMAIANB0AFqIANBIGogASAEENECIANBjAJqIANBiAJqEPwBBEAgBCAEKAIAQQJyNgIACyADKAKMAiEAIAIQyQIaIANB0AFqEMkCGiADQZACaiQAIAALsgICBH4F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ACADIAI2AvgCIAMgATYC/AIgA0HcAWogACADQfABaiADQewBaiADQegBahD4AiADQdABaiICQgA3AgAgAkEANgIIIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQmQIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgY2AswBIAMgA0EgajYCHCADQQA2AhggA0EBOgAXIANBxQA6ABYgAygC6AEhASADKALsASEHA0ACQCADQfwCaiADQfgCahCRAg0AIAMoAswBIAYgAigCBCACLQALIgBB/wBxIABBgAFxQQd2GyIAakYEQCACIABBAXQQmQIgAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCZAiADIAIoAgAgAiACLQALQYABcUEHdhsiBiAAajYCzAELAn8gAygC/AIiACgCDCIIIAAoAhBGBEAgACAAKAIAKAIkEQAADAELIAgoAgALIANBF2ogA0EWaiAGIANBzAFqIAcgASADQdwBaiADQSBqIANBHGogA0EYaiADQfABahD5Ag0AIANB/AJqEJMCGgwBCwsgAygCHCEAAkACQCADKALgASADLQDnASIBQf8AcSABQYABcUEHdhtFDQAgAy0AF0UNACAAIANBIGprQZ8BSg0AIAMgAEEEaiIBNgIcIAAgAygCGDYCAAwBCyAAIQELIAMgBiADKALMASAEEOYCIAMpAwAhCSAFIAMpAwg3AwggBSAJNwMAIANB3AFqIANBIGogASAEENECIANB/AJqIANB+AJqEJECBEAgBCAEKAIAQQJyNgIACyADKAL8AiEAIAIQyQIaIANB3AFqEMkCGiADQYADaiQAIAALiwUBAn8jAEHAAmsiACQAIAAgAjYCuAIgACABNgK8AiAAQcQBaiIHQgA3AgAgB0EANgIIIABBEGoiBiADKAIcIgE2AgAgASABKAIEQQFqNgIEIAAoAhAQkAIiAUGgwBNBusATIABB0AFqIAEoAgAoAjARBgAaIAAoAhAiASABKAIEQQFrIgI2AgQgAkF/RgRAIAEgASgCACgCCBEBAAsgAEG4AWoiAkIANwIAIAJBADYCCCACIAItAAtBgAFxQQd2BH8gAigCCEH/////B3FBAWsFQQoLEJkCIAAgAigCACACIAItAAtBgAFxQQd2GyIDNgK0ASAAIAY2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QZABaiIIIAQoAhwiATYCACABIAEoAgRBAWo2AgQgACgCkAEQ+wEhASAAQQA6AI8BAkAgAEGMAmogAiADIAggBCgCBCAFIABBjwFqIAEgByAAQZQBaiAAQYQCahC+A0UNACAAQdXqEigAADYAhwEgAEHO6hIpAAA3A4ABIAEgAEGAAWogAEGKAWogAEH2AGogASgCACgCIBEGABogAEHUADYCECAAQQhqIgNBADYCACADIABBEGoiBCgCADYCBAJAIAAoApQBIgEgBygCAGsiAkHjAE4EQCACQQJqEDMhBCADKAIAIQIgAyAENgIAIAIEQCACIAMoAgQRAQALIAMoAgAiBEUNAQsgAC0AjwEEQCAEQS06AAAgBEEBaiEECyAHKAIAIQIDQCABIAJNBEACQCAEQQA6AAAgACAGNgIAIABBEGpBgcAAIAAQaUEBRw0AIAMoAgAhASADQQA2AgAgAQRAIAEgAygCBBEBAAsMBAsFIAQgAEH2AGoiASABQQpqIAItAAAQ0gIgAGsgAGotAAo6AAAgBEEBaiEEIAJBAWohAiAAKAKUASEBDAELCxDeAQALEN4BAAsgAEGMAmogAEGIAmoQ/AEEQCAFIAUoAgBBAnI2AgALIAAoAowCIQIgACgCkAEiASABKAIEQQFrIgM2AgQgA0F/RgRAIAEgASgCACgCCBEBAAsgBygCACEBIAdBADYCACABBEAgASAHKAIEEQEACyAAQZACaiQAIAILhhgBD38jAEGQBGsiCyQAIAsgCjYCiAQgCyABNgKMBAJAIAAgC0GMBGoQ/AEEQCAFIAUoAgBBBHI2AgBBACEADAELIAtB1gA2AkwgC0HoAGoiASALQfAAajYCACABIAtBzABqIhEoAgA2AgQgCyABIhMoAgAiDjYCZCALIA5BkANqNgJgIBFCADcCACARQQA2AgggC0FAayIPQgA3AgAgD0EANgIIIAtBNGoiDEIANwIAIAxBADYCCCALQShqIg1CADcCACANQQA2AgggC0EcaiISQgA3AgAgEkEANgIIIAMoAgAhASMAQRBrIgMkACALAn8gAgRAIANBBGoiAiABEMIDIgEgASgCACgCLBECACALIAMoAgQ2AFwgAiABIAEoAgAoAiARAgAgDSACEJYCIAIQyQIaIAIgASABKAIAKAIcEQIAIAwgAhCWAiACEMkCGiAL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aiEMIABB0AJqIQgMAQsQ0wIhCiAAIAU3AwAgACAGNwMIIABBzAJqIApB+z8gABCLAyIKQX9GDQEgCygCACEHIAsgACgCzAIiCDYCACAHBEAgByALKAIEEQEACyAKEDMhDCAAKALQASEHIAAgDDYC0AEgBwRAIAcgACgC1AERAQALIAAoAtABIgxFDQELIAAgAygCHCIHNgLMASAHIAcoAgRBAWo2AgQgACgCzAEQ+wEiECIHIAggCCAKaiAMIAcoAgAoAiARBgAaIApBAEoEQCAILQAAQS1GIQ4LIABBuAFqIg1CADcCACANQQA2AgggAEGsAWoiCEIANwIAIAhBADYCCCAAQaABaiIHQgA3AgAgB0EANgIIIAIgDiAAKALMASAAQcgBaiAAQccBaiAAQcYBaiANIAggByAAQZwBahDTAyAAQdQANgIwIABBADYCKCAAIABBMGoiAigCADYCLAJ/IAAoApwBIg8gCkgEQCAKIA9rQQF0IAcoAgQgBy0ACyIJQf8AcSAJQYABcUEHdhtqIAgoAgQgCC0ACyIJQf8AcSAJQYABcUEHdhtqQQFqDAELIAcoAgQgBy0ACyIJQf8AcSAJQYABcUEHdhsgCCgCBCAILQALIglB/wBxIAlBgAFxQQd2G2pBAmoLIA9qIglB5QBPBEAgCRAzIQkgACgCKCECIAAgCTYCKCACBEAgAiAAKAIsEQEACyAAKAIoIgJFDQELIAIgAEEkaiAAQSBqIAMoAgQgDCAKIAxqIBAgDiAAQcgBaiAALADHASAALADGASANIAggByAPENQDIAEgAiAAKAIkIAAoAiAgAyAEEHchAiAAKAIoIQEgAEEANgIoIAEEQCABIAAoAiwRAQALIAcQyQIaIAgQyQIaIA0QyQIaIAAoAswBIgEgASgCBEEBayIDNgIEIANBf0YEQCABIAEoAgAoAggRAQALIAAoAtABIQEgAEEANgLQASABBEAgASAAKALUAREBAAsgCygCACEBIAtBADYCACABBEAgASALKAIEEQEACyAAQcADaiQAIAIPCxDeAQAL7wMBAX8jAEEQayIKJAAgCQJ/IAAEQCACEMIDIQACQCABBEAgCkEEaiIBIAAgACgCACgCLBECACADIAooAgQ2AAAgASAAIAAoAgAoAiARAgAMAQsgCkEEaiIBIAAgACgCACgCKBECACAD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eQBTYXR1cmRheQBTdW5kYXkATW9uZGF5AEZyaWRheQBNYXkAJW0vJWQvJXkAJTAxNmxseABhcnJheV9pbmRleABlcGhlbWVyaXNfc3RhcnRfaWR4AC0rICAgMFgweAAtMFgrMFggMFgtMHgrMHggMHgATm92AFRodQBBdWd1c3QAdW5zaWduZWQgc2hvcnQAZXBoZW1lcmlzX3N0YXJ0AHVuc2lnbmVkIGludABPY3QAZmxvYXQAU2F0AHVpbnQ2NF90AFN1YmNsYXNzAGdldENvdmVyYWdlUG9zaXRpb25zAHNlbWlfbWlub3JfYXhpcwBzZW1pX21ham9yX2F4aXMAQXByAHZlY3RvcgBnZXRWZWxvY2l0eVBvaW50ZXIAT2N0b2JlcgBOb3ZlbWJlcgBTZXB0ZW1iZXIARGVjZW1iZXIAdW5zaWduZWQgY2hhcgBNYXIAYWx0cABlcGhlbWVyaXNfc3RvcAB1bml4X3RpbWVzdGFtcABlcGhlbWVyaXNfc3RlcABTZXAAJUk6JU06JVMgJXAAaW5jbG8AZWNjbwBTdW4ASnVuAHN0ZDo6ZXhjZXB0aW9uAGdldFBvc2l0aW9uAEVudGl0eUNvbGxlY3Rpb24ATW9uAG5hbgBKYW4AUmVjZWl2ZWQ6ICVzXG4AcmFkaXVzZWFydGhrbQBKdWwAYm9vbAByZW1vdmVBbGwAQXByaWwAZW1zY3JpcHRlbjo6dmFsAEZyaQBiYWRfYXJyYXlfbmV3X2xlbmd0aABNYXJjaABBdWcAdW5zaWduZWQgbG9uZwB0ZXJtaW5hdGluZwBzdGQ6OndzdHJpbmcAYmFzaWNfc3RyaW5nAHN0ZDo6c3RyaW5nAHN0ZDo6dTE2c3RyaW5nAHN0ZDo6dTMyc3RyaW5nAGluZgAlNGQtJTJkLSUyZFQlMmQ6JTJkOiVsZgAlLjBMZgAlTGYAc2l6ZQB0cnVlAFR1ZQB1cGRhdGUAZmFsc2UAdGFrZUJhc2UASnVuZQBnZXRQb3NpdGlvbkluUmVmZXJlbmNlRnJhbWUAZ2V0TmFtZQBkb3VibGUAdmlzaWJsZQBhcG9nZWUAcGVyaWdlZQBwZXJpb2QAdm9pZABub3JhZF9jYXRfaWQAdGVybWluYXRlX2hhbmRsZXIgdW5leHBlY3RlZGx5IHJldHVybmVkAFdlZABzdGQ6OmJhZF9hbGxvYwBwZXJpb2Rfc2VjAERlYwBGZWIAYWx0YQBFQ0NFTlRSSUNJVFkATUVBTl9BTk9NQUxZACVhICViICVkICVIOiVNOiVTICVZAFBPU0lYAE1FQU5fTU9USU9OX0RPVABNRUFOX01PVElPTl9ERE9UAEdNVAAlSDolTTolUwBBUkdfT0ZfUEVSSUNFTlRFUgBCU1RBUgBFTEVNRU5UX1NFVF9OTwBNRUFOX01PVElPTgBJTkNMSU5BVElPTgBOQU4AUE0AYWRkT01NAEdNAEFNAExDX0FMTABSRVZfQVRfRVBPQ0gATEFORwBJTkYARVBIRU1FUklTX1RZUEUAQ0xBU1NJRklDQVRJT05fVFlQRQBSQV9PRl9BU0NfTk9ERQBPQkpFQ1RfSUQATk9SQURfQ0FUX0lEAEMAZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8c2hvcnQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIHNob3J0PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxpbnQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIGludD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8ZmxvYXQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVpbnQ4X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludDhfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dWludDE2X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludDE2X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVpbnQ2NF90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxpbnQ2NF90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzx1aW50MzJfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8aW50MzJfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8Y2hhcj4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgY2hhcj4Ac3RkOjpiYXNpY19zdHJpbmc8dW5zaWduZWQgY2hhcj4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8c2lnbmVkIGNoYXI+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGxvbmc+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIGxvbmc+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGRvdWJsZT4ARGVsY1lhWWVKZ3plcGcyZ05iaWJFY0ZiTmVVZzlmQ2NHY0Rkd2ZGYVhnamJrYUJlVWZtYjFjWWNBaHlna2ZqY0lnQ2ZoZ1NmTWN3aGdjeWFWZ2dhMGVMZkVmQWg5ZlVmQ2VDaGdneWJXZlRhWWNBYk1oaGNBaE1mRGN6Zk5hUWNOZlFoMGdYaE9kVGdZZlhjTWhrYTRhdGFFZDFjSWR3Z0FlRmFJYytnRWRnZmtmbGNMY0JjSmZmZVVhamRaZ0tiSGJ4ZmRiVWJPZXdiRWVsaEJjeWM4Yk1hSmhUYThhS2FVaGphQmdiZVhoQWN0Y1ljRWdEYlVib2FOZnplVWJ1aEFjQ2NaY1FiVWh3ZG9jMGJEZkZhRWRVZUJkVWQwZ3hnSGFBZE1kcGNJZXlmQWhvY1ViamJNZElmTWhsYllhTmRDZ3hlQWRQYlZoQWZnYW9oTWVsaGtoMmJBaERnSWJRaERjQWc4Z3phVWhEaFVkTmhGZHpka2QyYkZiemFKY09kTGZSaE5hU2NNY0FmQmVTZlBhaGRJaEphSmRTYndmU2FYZTFlSWgyaFNiaGM4YlhmVmVEYnNnQmZKZFFjY2h2Y0RjQ2ZVZS9jQ2hsYklmd2dXYjFid2FMYldkQmNBZzFlS2REZWNmMWFMaGdnQWVtZFVlRmNNZUtjTmZBYnhjUmVGZUFjVmJOYk1oUmV3Z0RoS2NTaE1lZ2VLZEZoSWN6ZENlRGhKZFdnRGZRZnNlUWFEYzFoUWhJZktoRGdKZFplTmFnYkFoeWJFaEFid2dQY01mMWFBYTFhRGNSYWNiNWhOaGhoY2N5YVRmaWQwZ1RjVWdqY0FlQWNVaGpkNGJTZUNiU2NVZnNjRWhsZjlhU2FOZmtib2JmaEZoMWZRaDdhQWRTYlVjSGFMZXdjd2hsZ1Bld2VwZlNiTWRGaHRnY2ZDZDFhZ2RRZk5jU2hnaDNjTmVTZTRlQWRKaGxoQmZUYUNiamFRYk1hVWdSZVFiRmhUZFRoRWJjaEFkeWJrZ2pnSWNDYmhnU2ZNZHdnZ2V5aFZkZ2cwY0xoRWFBYzlhVWRDZUNoZ2N5ZldhVGRZY0FlTWZoZEFlTWREZHpjTmdRZ05jUWQwY1hhT2hUaFlnWGZNYmtmNGR0YUVnMWhJYXdnQWJGaEljK2JFaGdha2ZsZExoQmVKZWZhVWNqYlpnS2VIYXhnZGJVaE9hd2NFZWxoQmR5YjhhTWdKY1RnOGNLYVVoamRCZmJnWGFBYXRoWWFFaERoVWVvZU5oemRVaHVkQWJDYVpkUWJVY3dob2YwY0RkRmFFZlVkQmdVZzBoeGVIaEFiTWhwZ0lkeWFBZm9jVWZqY01lSWJNZmxoWWZOZENkeGhBZlBjVmdBYmdhb2dNZmxoa2UyZ0FoRGJJZlFjRGVBZDhlemVVY0RmVWdOZ0ZmemRrYTJjRmh6ZUphT2FMZVJoTmJTZ01kQWVCZFNjUGZoZUllSmZKaFNmd2ZTYlhkMWZJZjJiU2VoYThjWGhWZ0Rmc2RCY0poUWRjZXZkRGdDY1VhL2FDYWxkSWN3YldnMWR3YUxiV2NCYkFmMWFLYURnY2cxYUxoZ2NBZ21oVWFGZE1iS2hOZkFheGFSZkZlQWZWZk5iTWFSY3dnRGhLZ1NlTWhnZ0tjRmdJaHpkQ2VEZUpoV2ZEaFFkc2FRZERnMWhRY0lkS2ZEYUphWmZOZWdlQWh5YkVoQWd3ZlBhTWIxaEFnMWZEZVJkY2Q1Y05oaGhjYnlhVGhpYjBkVGFVZmpkQWVBYVVmamQ0ZlNiQ2NTYlVoc2NFZmxkOWdTYk5ia2NvZmZnRmExZlFlN2hBYVNhVWVIYkxmd2J3Y2xlUGV3YnBjU2RNZkZldGZjZkNjMWVnZ1FlTmFTZGdjM2hOY1NiNGhBaEpibGdCY1RiQ2dqZVFmTWJVYVJlUWRGYlRjVGFFYWNiQWV5ZGtmamFJaENlaGNTZU1kd2JnZXloVmdnYzBlTGZFZUFnOWFVZENjQ2ZnaHliV2hUZVloQWJNZWhlQWJNYkRhemZOZVFoTmJRaDBkWGFPZVRmWWFYYk1ka2g0YXRoRWExZElkd2NBZ0ZnSWgrZ0VhZ2hrYWxhTGJCYkpmZmJVYmphWmdLY0hoeGFkYlVmT2F3ZUVnbGFCYnlhOGVNaEpjVGE4YktjVWVqZkJjYmdYZkFldGhZZkVhRGJVZW9iTmR6Z1VidWJBaENkWmZRYVVld2dvZDBnRGRGYkVnVWdCZVVhMGJ4YkhhQWVNZnBkSWd5Z0Fob2ZVYmpnTWZJZE1obGZZZ05kQ2F4ZUFjUGNWZkFiZ2VvZU1mbGFrYzJoQWZEYUlhUWJEYkFiOGZ6aFVkRGhVZU5hRmd6ZWtoMmZGYXpjSmJPYkxmUmZOZVNoTWRBZUJlU2FQZWhlSWNKZEpjU2Z3ZFNmWGMxY0liMmdTYmhmOGdYYVZhRGVzZUJjSmhRZmNndmJEYkNlVWMvaENkbGRJY3diV2QxYndnTGRXY0JhQWgxYktjRGRjYzFnTGhnYUFnbWNVYkZhTWJLZk5iQWN4ZFJkRmZBaFZjTmJNaFJod2JEZ0tlU2RNZmdiS2RGYUljemZDZERiSmdXaERmUWdzaFFlRGQxZVFiSWhLYURlSmdaZk5nZ2JBZnlmRWJBZ3doUGVNZjFnQWYxY0RmUmFjZjViTmRoZWNkeWZUYmloMGFUZVViamRBYkFhVWdqZzRiU2ZDZVNlVWdzYUVmbGE5ZlNoTmVrZ29hZmVGYTFiUWU3ZEFkU2ZVaEhiTGR3ZndlbGZQYndjcGJTYU1iRmJ0ZmNmQ2UxYmdkUWFOZ1NlZ2czZk5iU2Q0aEFoSmVsYUJiVGRDaGplUWNNZlVnUmFRY0ZlVGVUZ0VnY2RBaHlma2JqZUljQ2NoZ1NlTWZ3YWdieWJWYmdmMGdMaEVlQWg5Y1VlQ2RDZWdjeWJXYlRnWWNBaE1kaGhBaE1jRGJ6aE5kUWhOZVFiMGNYZk9iVGRZaFhnTWJrZjRjdGFFYzFiSWZ3aEFhRmdJZCtjRWVnZmtnbGVMZUJnSmRmYlVmamhaY0tlSGF4ZmRnVWdPZXdiRWJsaEJneWg4Z01mSmJUYzhmS2JVYWphQmdiaFhiQWF0YVliRWdEZFVhb2NOaHpiVWJ1YUFjQ2JaY1FnVWR3Y29jMGVEYkZmRWdVZEJnVWEwZHhoSGJBaE1mcGZJZXliQWhvZFVnamRNY0llTWZsaFlmTmZDZXhoQWdQY1ZjQWFnZW9jTWhsZGtmMmZBZURlSWhRYkRlQWE4Z3phVWdEYVViTmVGYnpha2EyZkZlemFKZU9lTGhSZ05mU2ZNZUFlQmhTYVBkaGdJYUpkSmhTY3dlU2dYZzFkSWYyZlNjaGU4Z1hoVmREYXNhQmFKZlFjY2d2Y0RjQ2RVaC9jQ2FsZElld2ZXZTFnd2VMZ1doQmhBZDFkS2VEZWNhMWJMZmdlQWVtZlVoRmFNaEtjTmdBZHhoUmJGYUFiVmROZ01jUmV3Y0RjS2ZTZE1iZ2NLZUZmSWV6ZENkRGRKZVdiRGNRYXNiUWVEZjFnUWVJYktjRGZKYlpmTmZnZEFoeWZFZUFmd2hQZk1lMWNBYjFnRGFSaGNkNWJOY2hjY2N5ZFRkaWEwY1RiVWVqZkFlQWJVZGpjNGFTaENhU2VVaHNiRWJsZjljU2dOZGthb2dmZkZhMWFRZjdkQWhTY1VkSGJMYndjd2RsZVBhd2FwYVNmTWRGZXRoY2JDZzFnZ2RRZU5nU2JnYjNkTmZTYjRlQWVKZWxiQmJUZUNiamFRZ01mVWFSYlFhRmZUZVRiRWRjZ0FjeWJrZ2piSWJDZWhmU2JNZXdjZ2Z5ZFZjZ2IwYkxoRWFBZDloVWJDZUNlZ2h5YVdjVGZZaEFjTWNoZEFjTWVEZ3pkTmVRYU5mUWEwZlhoT2FUZFlnWGJNZWtmNGZ0YkVlMWZJZXdoQWdGZklmK2dFZmdha2JsZUxmQmNKY2ZmVWNqYlpiS2hIaHhhZGZVZE9ld2JFaGxlQmF5ZzhiTWJKY1RlOGVLZlVhamhCZGJnWGVBZHRmWWVFY0RlVWVvYU5jemVVY3VhQWFDZFpkUWFVY3dlb2IwZ0RmRmRFZlVoQmhVZzBmeGNIYkFmTWZwZklheWJBZm9lVWhqZE1iSWZNYmxlWWhOYUNoeGVBZFBjVmdBZ2dkb2hNY2xoa2cyYkFnRGNJZVFkRGZBYjhiemZVYkRmVWROYUZlemFrZDJmRmV6aEphT2VMZFJmTmRTZ01nQWNCaFNoUGVoZklnSmJKYlNkd2NTYVhmMWdJYTJjU2ZoYjhjWGFWaERlc2NCZkpoUWVjYXZjRGNDZFVjL2JDZmxmSWR3Y1dhMWR3ZExoV2ZCY0FhMWdLY0RhY2IxZ0xjZ2ZBZG1nVWhGZk1hS2FOYUFieGRSYkZmQWVWY05lTWRSaHdjRGVLZlNlTWJnaEthRmFJY3pjQ2hEZ0piV2FEZFFkc2FRZ0RkMWJRZUlnS2VEZUpkWmFOYWdnQWV5aEVhQWN3Z1BoTWgxZUFlMWJEaFJjY2Q1aE5maGhjY3ljVGZpYTBhVGJVYWpjQWRBZVVmamU0Y1NkQ2hTYVVhc2hFYWxhOWVTZk5ha2hvZGZjRmExZlFmN2ZBZlNjVWdIY0xkd2Z3YmxiUGR3Y3BmU2FNY0ZkdGVjZUNoMWVnYVFhTmVTZmdmM2FOYVNmNGJBY0phbGZCZVRmQ2hqY1FkTWRVZlJkUWRGYVRnVGJFZ2NoQWh5ZGthamZJaENkaGhTZU1id2RnY3lnVmVnZTBlTGNFYkFnOWVVZ0NiQ2RnYXllV2FUYllkQWVNYmhjQWdNZURhemFOZFFkTmhRZTBhWGhPZ1RiWWdYZE1ja2Q0Z3RiRWQxYklod2VBZUZnSWYrYkVnZ2FrY2xnTGJCYUpoZmRVZmpmWmdLYUhheGVkYlViT2Z3ZkVlbGZCZnlnOGZNZ0poVGU4ZEtlVWZqYUJkYmVYZUFodGRZYkVnRGNVaG9jTmZ6ZlVndWVBYUNlWmVRZFVld2ZvaDBoRGVGYkVjVWNCZ1VhMGJ4ZkhlQWRNZHBmSWV5ZEFib2JVYmplTWNJZE1obGVZZ05iQ2Z4ZkFoUGdWZ0FhZ2ZvY01nbGNrZDJjQWVEY0lkUWdEYkFhOGJ6aFVjRGZVaE5jRmR6ZWtmMmJGY3poSmZPYUxkUmJOaFNlTWNBZUJoU2JQaGhiSWJKYkpiU2J3YlNiWGYxZElmMmZTZ2hoOGVYYVZjRGZzZkJlSmZRZGNkdmREZENmVWMvY0NhbGVJZHdhV2IxZ3dkTGVXZEJoQWExYktkRGZjZDFkTGFnZ0FnbWNVZEZnTWRLZU5nQWR4ZVJkRmZBYlZlTmRNY1Jmd2dEZEtjU2dNZGdmS2dGZElmemhDY0RkSmZXY0RiUWhzY1FiRGExZlFnSWZLZURmSmZaZE5lZ2FBYnljRWVBZHdmUGdNYzFjQWUxYURjUmhjZjVjTmZoZ2NoeWVUZWlnMGNUY1VnamRBZUFmVWNqYjRjU2ZDY1NkVWJzZ0VmbGM5YVNhTmNrZ29oZmJGZjFjUWM3aEFoU2NVYkhiTGd3ZndobGZQZ3dicGdTZ01lRmJ0ZWNoQ2IxY2doUWVOZlNnZ2QzZE5kU2Y0YUFjSmhsaEJhVGRDZGplUWdNYVVmUmNRYkZoVGZUZEVkY2VBYXlka2hqaEloQ2NoYlNkTWh3YWdkeWdWZ2dnMGNMZkVmQWc5ZFViQ2ZDYmdoeWFXYVRjWWhBYk1haGNBZU1mRGh6Yk5hUWNOZFFhMGdYYk9hVGRZY1hmTWRrZjRidGdFZTFlSWh3Z0FkRmRJYitkRWJnZWtibGdMYkJoSmJmZVVkamFaaEtjSGF4Z2RkVWhPZ3dlRWdsYUJheWE4aE1oSmFUZjhoS2VVaGpmQmNiYlhmQWR0Y1lnRWdEZVVib2FOZXphVWR1ZkFmQ2haZVFnVWV3YW9mMGREZ0ZkRWNVYkJiVWQwZnhlSGdBZ01mcGNJZ3ljQWhvY1VmamRNZ0ljTWhsYVlmTmJDYXhhQWJQZVZlQWFnZG9hTWhsYWtkMmdBZURnSWhRZURmQWc4YXpnVWdEZlVkTmVGZHpka2MyaEZlemZKZU9lTGZSZk5oU2FNZ0FjQmhTYlBjaGJJZ0pjSmFTZndjU2JYZDFjSWUyYVNlaGc4YlhkVmJEY3NnQmRKY1FhY2R2Z0RoQ2JVYy9nQ2JsZklid2ZXYzFld2VMYldkQmJBYzFjS2FEZWNiMWFMY2dmQWNtZVVjRmVNaEtmTmFBYnhlUmFGY0FkVmNOZU1mUmF3ZkRhS2VTZ01kZ2FLZkZhSWN6aENkRGNKYldmRGFRZ3NiUWNEYjFoUWhJYUtmRGFKZFpkTmVnaEFoeWJFYkFod2RQYU1hMWFBYjFiRGdSZ2NkNWdOZWhhY2h5ZVRoaWcwZ1RkVWZqZUFnQWhVZmplNGJTZkNoU2FVYXNkRWRsZzllU2ROY2tjb2hmZEZhMWZRYTdmQWFTY1VhSGFMZ3dod2dsYlBld2FwYVNnTWVGY3RmY2NDZTFnZ2NRYk5nU2JnYTNjTmNTZDRmQWJKYmxjQmhUYUNoamZRaE1lVWRSY1FkRmVUY1RhRWdjYkFieWVraGpoSWVDZmhjU2dNYndlZ2R5Z1ZlZ2MwY0xmRWFBZjliVWdDaENlZ2Z5ZFdhVGdZYUFiTWdoZUFiTWFEaHpiTmZRZU5jUWgwZVhoT2NUY1lhWGJNZGtiNGZ0aEVmMWZJZHdkQWZGZUlkK2RFZmdha2hsZUxmQmVKZWZiVWZqaFpnS2ZIYXhlZGJVZ09od2hFYmxiQmZ5ZDhoTWZKaFRmOGFLZVVmamNCZ2JmWGFBZXRhWWJFYkRlVWVvZ05jemNVY3VnQWZDY1pjUWVVYndob2cwYURiRmJFZFVmQmhVYzBleGRIZ0FoTWdwZEljeWhBZ29hVWVqaE1mSWJNZGxlWWJOZUNoeGVBYlBmVmRBZ2dib2VNZ2xna2gyZkFoRGdJZFFmRGVBYThjemJVaERlVWROYUZiemVrZzJnRmJ6Z0pjT2RMZ1JlTmJTYU1kQWNCaFNmUGhoaElhSmZKYlNkd2hTYlhhMWRJYjJhU2NoYjhoWGJWZURhc2ZCY0phUWhjZ3ZhRGhDYVVmL2ZDaGxhSWJ3Z1doMWR3YkxiV2NCZ0FiMWhLY0RnY2UxZ0xoZ2dBY21oVWRGYk1nS2JOYkFneGJSYUZjQWRWaE5jTWJSZHdmRGFLY1NhTWFnY0tiRmVJYXpoQ2VEZUpiV2ZEZVFhc2RRYkRoMWhRZ0llS2dEZ0plWmdOaGdiQWZ5aEVjQWJ3YlBhTWUxaEFjMWNEaFJiY2I1aE5naGZjYnlmVGJpYzBmVGdVYWpkQWVBZ1VjamQ0Z1NnQ2NTZVVjc2hFZmxjOWdTZE5oa2JvZGZhRmUxZlFhN2RBZVNhVWNIYUxid2h3aGxhUGZ3ZHBlU2FNY0ZndGZjYkNmMWRnZ1FkTmVTZmdjM2JOYVNhNGJBYkpkbGRCZlRjQ2ZqaFFnTWJVYlJmUWFGZVRoVGNFY2NnQWJ5Z2thamNJYkNoaGdTZk1ld2hnZHljVmRnYjBmTGNFaEFkOWJVZUNlQ2hnaHlmV2JUY1lmQWZNZGhjQWFNaERmemFOYlFhTmVRYTBmWGJPZlRlWWZYY01na2c0YnRjRWgxZUlid2FBZEZlSWgrYUVnZ2drY2xhTGFCaEpoZmdVZmpjWmFLZ0hheGdkYVViT2F3Z0VlbGZCY3lhOGZNZEpoVGc4ZEtlVWhqZEJlYmFYYUFjdGNZZ0VhRGdVZG9kTmF6Z1VodWJBZENhWmFRZVVhd2NvYjBlRGFGZUVmVWJCZlVhMGZ4Y0hkQWNNY3BoSWd5ZkFjb2VVZmpkTWZJaE1jbGVZYU5lQ2d4YkFlUGdWZkFiZ2dvZU1obGNrZTJhQWVEZklhUWhEZkFmOGR6Y1VhRGJVY05oRmh6ZmthMmZGaHpmSmVPZ0xiUmZOaFNiTWFBYUJiU2VQYWhkSWFKYkpiU2F3ZFNnWGExY0lkMmhTYmhiOGZYZVZmRGhzZkJlSmVRZmNkdmJEaENhVWIvYUNlbGFJaHdmV2UxY3dlTGVXaEJoQWQxZEtmRGdjYzFoTGhnZkFibWNVaEZjTWFLaE5iQWZ4aFJnRmFBYVZkTmNNYlJhd2VEYktoU2RNZmdmS2RGZElhemhDZURkSmNXaERnUWRzZlFnRGgxZ1FkSWhLZ0RmSmRaaE5oZ2dBaHlkRWJBYndnUGhNaDFoQWcxZ0RkUmFjYTViTmVoZWNleWVUYmlhMGFUZ1ViamhBZ0FhVWNqYjRmU2VDZFNnVWZzYkVkbGY5aFNjTmJrYW9oZmhGZTFlUWM3YkFmU2VVYUhhTGF3Z3djbGVQY3dncGNTZU1iRmZ0aGNkQ2QxZWdkUWZOZVNnZ2gzZU5kU2Y0Y0FmSmdsYUJnVGFDZWpjUWNNaFVkUmNRZkZmVGdUZ0VmY2hBY3lma2JqZklhQ2RoaFNjTWJ3Y2dleWVWZGdmMGNMZ0VmQWc5ZFVlQ2RDaGdheWFXaFRmWWdBZU1kaGRBZ01lRGZ6Z05jUWFOZVFjMGFYYU9kVGhZYlhkTWVrYzRmdGZFZjFmSWV3YUFnRmdJYStoRWRnYWtnbGZMYkJiSmFmZFVlamNaaEtiSGZ4ZmRiVWdPZndjRWdsaEJheWE4Z01jSmJUaDhjS2VVYWpkQmhiZFhmQWR0Y1lhRWVEYVVjb2JOaHpjVWN1Y0FmQ2VaY1FmVWJ3aG9lMGhEZEZnRWNVZ0JlVWgwZXhoSGJBZE1kcGZJY3loQWFvZVVkamdNY0lnTWhsZFloTmdDZHhkQWJQYVZoQWVnYW9kTWVsZ2thMmRBZ0RlSWhRZERmQWE4Z3pmVWdEY1VnTmJGZHpla2UyZUZkemRKaE9iTGFSZk5lU2FNYUFhQmdTYVBmaGJJY0phSmZTaHdmU2dYYTFmSWcyZFNiaGY4Z1hmVmhEYXNjQmhKYVFnY2J2Z0RjQ2RVYy9hQ2RsYklnd2RXaDFmd2VMZVdjQmRBYTFoS2NEZWNlMWJMZGdlQWJtZ1VlRmZNaEtkTmZBYnhmUmJGYkFhVmhOYk1oUmd3Y0RlS2hTaE1lZ2RLZkZoSWd6ZkNiRGFKZ1dnRGZRY3NhUWhEZDFiUWdJZktkRGFKZlpjTmZnZ0FoeWFFZkFod2dQYU1nMWJBYjFiRGFSYWNiNWJOZWhlY2h5YVRhaWQwZlRjVWZqYUFiQWRVZ2poNGNTZENlU2RVYXNmRWJsZjlhU2hOZWtib2RmYUZlMWdRYzdjQWZTZ1VnSGZMaHdjd2RsaFBhd2VwYlNjTWhGYXRjY2RDZjFnZ2VRYU5hU2dnYTNjTmFTYjRlQWhKYmxhQmZUaENiamNRY01mVWZSZVFiRmFUZ1RiRWJjYUFkeWJraGpiSWRDaGhjU2JNaHdlZ2R5Z1ZhZ2EwYUxoRWZBaDlnVWZDY0NjZ2V5ZldmVGhZYkFoTWNoYkFiTWJEZHpoTmNRZU5mUWYwYlhhT2dUZFlmWGFNYmtkNGh0Z0VlMWRJYXdjQWJGZkljK2hFYmdja2FsZkxiQmhKZGZkVWhqY1pnS2dIZHhnZGdVYU9hd2VFYmxkQmR5YzhlTWRKZFRhOGJLZVVjamRCYWJmWGZBZXRlWWFFaERkVWdvZE5nemdVZHVoQWJDZlpiUWNVYndjb2QwY0RmRmZFY1VlQmdVZTBoeGZIYkFkTWhwYklkeWhBY29hVWRqZk1kSWNNZmxiWWVOZUNieGNBZ1BhVmRBZWdjb2FNY2xia2IyZ0FiRGFJY1FoRGJBYThlemFVZURlVWROZkZiemdrZTJkRmV6ZUpkT2hMYVJmTmFTY01mQWJCY1NlUGJoZklhSmdKZ1Nod2JTZFhhMWdJYzJjU2ZoYzhiWGRWaERkc2FCaEplUWVjYnZiRGdDZ1VnL2FDZGxkSWR3Z1dkMWV3YUxkV2FCYkFnMWJLaERiY2MxZUxlZ2RBZ21jVWhGZk1nS2ZOYUFheGJSYkZkQWNWZE5oTWdSZ3djRGFLYlNoTWhnYktoRmhJaHpmQ2dEYUphV2ZEYlFic2FRYkRmMWRRZkljS2NEZ0plWmFOZWdjQWR5Z0VkQWF3Z1BhTWUxYUFlMWVEYVJoY2I1Yk5haGFjaHliVGFpYjBhVGVVZGpoQWdBZFVnamg0Y1NoQ2dTaFVmc2FFYWxiOWJTaE5ka2dvY2ZkRmUxY1FjN2ZBZlNnVWRIaExid2N3YWxhUGF3Z3BkU2JNZUZldGhjY0NmMWVnZVFnTmNTYWdlM2VOZ1NnNGFBZ0phbGFCYVRjQ2hqZFFiTWZVYlJlUWZGZlRoVGZFZWNjQWh5YWthamNJZkNiaGFTZU1hd2VnZnlhVmdnZzBlTGJFZkFkOWFVYUNjQ2dnY3lkV2dUZFlnQWJNZWhoQWRNY0RlemJOYVFkTmFRYjBjWGFPYVRkWWFYY01ma2c0aHRoRWUxZklld2hBY0ZiSWMrZ0VmZ2ZrZWxoTGdCYkpjZmVVZWpnWmRLZ0hmeGVkZVVjT2V3aEVlbGNCYnlmOGFNZkpiVGM4YUtoVWhqaEJjYmRYZUFjdGdZYkVmRGFVZm9kTmF6YlVndWFBZkNiWmRRY1Vid2ZvYzBhRGhGaEVnVWhCZ1VoMGV4YUhmQWhNZXBoSWR5aEFkb2JVY2phTWNJZk1jbGRZZU5iQ2N4ZkFkUGNWYkFjZ2FvZE1kbGJrZDJlQWVEaEloUWhEYkFjOGJ6ZFVoRGVVZk5nRmh6Z2tjMmRGYnplSmVPY0xmUmFOZlNlTWZBZEJjU2VQaGhiSWJKZkpkU2N3Y1NkWGcxYUljMmRTaGhlOGFYZlZiRGhzZUJnSmNRYWNodmNEZENnVWUvYkNmbGNJZndnV2IxYXdlTGhXZkJiQWExYktiRGdjYzFjTGNnYUFibWRVYUZkTWhLaE5hQWN4ZlJiRmhBZVZjTmZNY1Jld2JEYktjU2RNZ2doS2JGY0llemZDYURhSmZXZ0RlUWRzY1FmRGYxZFFkSWhLYkRhSmdaZ05mZ2JBY3lhRWRBZHdnUGRNZDFmQWYxZURmUmdjaDVkTmhoZ2NjeWRUY2ljMGhUY1VmamhBaEFkVWNqYjRoU2NDZlNnVWdzZ0VkbGc5Z1NiTmJrZm9jZmVGZTFnUWg3aEFmU2RVaEhiTGN3Z3dlbGRQZXdocGZTY01iRmJ0ZGNlQ2MxZWdjUWZOYVNoZ2QzZ05iU2I0ZkFmSmNsZ0JkVGNDZmpkUWRNZVVjUmRRYUZlVGZUY0ViY2JBZHlja2JqZEliQ2NoZFNnTWF3Y2dheWNWY2dkMGhMZkVhQWM5ZlVmQ2RDZ2dleWhXZVRmWWNBYk1maGhBZU1jRGd6Yk5kUWNOZVFoMGNYZ09nVGFZYVhkTWRrZzRjdGFFYzFlSWJ3Z0FlRmJJZCtmRWhnY2tkbGVMZEJhSmRmZVVhamVaY0toSGN4Y2RmVWJPZHdkRWFsYUJheWg4Z01kSmRUZjhoS2hVZmpoQmRiZFhnQWN0Z1ljRWVEZ1Vjb2JOYXpnVWd1Z0FlQ2RaZVFnVWZ3Y29kMGhEZkZkRWhVZ0JoVWcwaHhjSGFBZE1lcGZJZ3lnQWNvZFViamZNY0loTWZsaFllTmZDZHhjQWNQZVZlQWhnZW9jTWdsZmtoMmNBYkRlSWdRZURjQWg4Z3pkVWVEZVViTmhGZnpha2cyZkZjemhKZE9nTGNSYU5oU2ZNZkFoQmhTZVBoaGNJY0pkSmFTYXdlU2FYZzFoSWIyYlNlaGc4YVhhVmVEZnNjQmRKZVFiY2Z2YURoQ2NVZi9mQ2dsZklld2RXZTFod2hMaFdoQmRBZjFlS2dEaGNjMWJMYWdjQWRtYlVoRmNNZktlTmRBZ3hiUmZGaEFmVmdOaE1jUmF3ZkRlS2RTZk1kZ2hLY0ZkSWR6ZkNnRGJKZVdnRGFRZnNlUWZEZDFiUWdJZkthRGRKYlpkTmVnaEFoeWdFYUFhd2RQZU1oMWFBYjFiRGZSYWNhNWNOYWhhY2h5ZFRiaWYwZ1RmVWJqaEFoQWRVZmpiNGFTZ0NlU2FVZnNhRWVsaDliU2ZOZmtob2ZmYUZiMWVRYTdiQWhTY1VkSGRMZHdod2NsZ1Bkd2dwZ1NkTWNGZ3RnY2ZDaDFjZ2ZRZE5lU2NnYjNnTmNTZjRhQWJKZmxjQmdUYkNmamdRZ01lVWJSZlFiRmVUYlRnRWNjZ0FneWFrYWpnSWdDY2hkU2VNY3dhZ2R5Y1ZkZ2UwZ0xnRWJBYzllVWJDY0NnZ2h5ZVdmVGVZZkFkTWNoZEFiTWdEZnphTmNRZE5iUWYwZ1hoT2hUZFlhWGVNZGtmNGF0Z0VhMWJJZHdmQWhGZUliK2NFZ2dja2NsZExlQmVKY2ZlVWZqYVpkS2RIZnhkZGdVZU9id2FFaGxoQmV5aDhjTWVKYVRnOGNLYlVnamFCZmJnWGNBZnRmWWVFZERhVWNvZU5lemdVYnVjQWJDY1poUWhVY3dmb2UwaERiRmdFaFVmQmFVZDBheGZIZUFiTWNwaEloeWhBZ29oVWhqYk1oSWhNYmxlWWdOaENleGdBZVBmVmhBY2dlb2dNZGxla2YyY0FmRGNJYVFkRGhBZjhkemZVY0RhVWJOZkZmemFrZDJlRmJ6ZEpiT2hMZVJkTmZTZU1iQWJCYlNiUGVoaElnSmVKZlNkd2NTYVhhMWFJZzJnU2FoZDhnWGVWZkRkc2JCZEpkUWJjZ3ZiRGRDZVVnL2JDY2xjSWV3YldjMWZ3YkxmV2NCaEFoMWZLaERiY2cxYkxiZ2NBZW1kVWVGaE1hS2hOZkFoeGdSYkZiQWZWZk5hTWFSZ3dkRGFLZ1NmTWZnZEtmRmdJY3piQ2dEYkpoV2FEYlFhc2hRYURkMWZRZElkS2REY0plWmNOY2dkQWd5ZkVhQWd3ZlBjTWMxYkFkMWhEYlJlY2Q1YU5kaGVjZ3lnVGFpYTBlVGZVZGpjQWRBZ1VjamI0Y1NoQ2VTY1Vkc2JFZmxnOWNTYU5ha2hvYWZoRmIxZFFoN2VBYVNoVWVIaExid2h3aGxlUGJ3ZnBiU2NNaEZldGRjYkNlMWZnYVFiTmhTZGdjM2dOZ1NhNGhBZUpnbGFCYVRmQ2JqZ1FlTWNVZ1JoUWhGZ1RnVGVFZ2NhQWh5Z2tnamRJYUNkaGJTZ01md2dnZ3ljVmRnZDBiTGdFZEFoOWJVZUNjQ2ZnaHloV2hUZVllQWRNYmhlQWFNYURkemNOZVFkTmVRYzBlWGdPZFRhWWFYZE1ha2I0ZHRnRWgxaElid2ZBZUZkSWErZUVhZ2RraGxmTGhCZEplZmRVYWplWmRLYkhneGhkYlVhT2N3Z0VnbGhCZHlmOGhNY0pnVGY4YUtnVWJqZkJnYmFYYkFodGJZZUVlRGFVaG9jTmZ6ZVVkdWNBYkNlWmJRaFVid2JvYTBoRGJGZkVnVWRCZVVlMGR4aEhlQWhNYnBkSWd5ZUFhb2JVZ2pnTWhJZk1hbGRZaE5lQ2h4aEFkUGhWZUFhZ2hvZE1ibGRrYTJkQWdEaElnUWhEZEFnOGR6Z1VlRGNVZE5mRmR6YmthMmVGZXpkSmVPZkxiUmNOZ1NmTWNBYUJkU2hQY2hkSWZKZ0pmU2V3Y1NoWGQxZElnMmhTaGhjOGFYZVZhRGNzYUJmSmJRaGNodmFEY0NoVWYvZ0NlbGVJZXdmV2cxZ3dlTGNXZUJmQWQxZktlRGhjaDFkTGFnZEFobWhVYkZjTWFLZU5iQWZ4aFJmRmJBaFZnTmhNZ1Jld2REYUtoU2NNYmdkS2NGZklkemFDZERnSmNXZURhUWZzZVFnRGYxZFFoSWNLZ0RkSmZaZE5oZ2VBaHllRWFBYXdnUGdNZjFnQWQxZERmUmVjaDVnTmhoZmNoeWVUYmljMGVUZlVmamVBZEFkVWFqYjRoU2RDY1NiVWJzZEVlbGM5YVNhTmhrYm9iZmFGaDFiUWc3YUFiU2hVaEhlTGF3Z3dlbGNQZHdlcGdTZE1jRmJ0YmNiQ2YxZGdoUWROaFNjZ2gzYU5nU2Y0YUFkSmVsYUJkVGZDZmpoUWNNZFViUmZRZkZmVGVUZEVkY2FBZnlja2hqZkljQ2ZoY1NjTWF3aGdneWdWZ2diMGNMZUViQWg5ZlVmQ2ZDaGdieWNXZlRjWWhBZU1iaGJBZk1oRGR6Z05nUWJOYlFkMGZYYk9hVGZZZlhhTWdrYTRjdGNFZzFiSWZ3ZUFnRmhJZytkRWhnYWtnbGhMZEJiSmRmYlViamJaZUtoSGV4aGRhVWZPYXdnRWNsZkJieWY4ZU1iSmNUYjhiS2ZVZmphQmJiZVhlQWJ0aFloRWhEY1Vhb2ROZHpjVWR1Z0FiQ2FaZVFlVWV3Z29nMGFEZ0ZlRWFVZkJiVWgwZXhmSGFBYk1kcGNJYXliQWRvZ1VoamNNYUlmTWFsZ1liTmFDYXhhQWJQYlZhQWhnZW9nTWhsaGtmMmFBYURkSWVRZERoQWQ4ZnpkVWREZFVoTmJGaHpka2YyYUZmemdKY09nTGJSZ05hU2JNZkFoQmRTZlBoaGJJY0poSmFTZ3dmU2NYYTFkSWQyZ1NhaGU4ZFhnVmREZXNiQmdKaFFkY2F2YkRoQ2JVZi9nQ2JsY0lid2ZXZzFkd2ZMZFdnQmFBYzFhS2JEZ2NoMWZMZmdkQWdtZFVmRmZNZktmTmRBZnhhUmVGZkFnVmROY01nUmV3Y0RoS2FTY01lZ2dLZEZlSWh6YkNiRGhKZFdiRGZRY3NhUWVEZzFmUWhJYUtoRGhKZFpjTmFnZkFneWFFZ0Fnd2NQZ01kMWhBZTFlRGdSaGNnNWJOZmhjY2R5aFRoaWEwZFRlVWhqZUFnQWNVaGphNGZTZkNoU2RVYnNjRWFsYTloU2hOZ2thb2JmaEZoMWNRYTdhQWVTZlVoSGVMZHdhd2NsZ1Bhd2JwYVNlTWJGYXRkY2JDYzFkZ2hRZ05iU2RnZDNiTmhTYTRoQWhKZWxmQmRUZ0NjamNRZE1hVWFSZlFoRmFUYVRmRWdjZUFoeWRrZWpmSWRDZmhjU2VNYndiZ2F5ZVZhZ2gwaExmRWVBYjloVWJDZkNmZ2Z5aFdlVGVZY0FnTWZoaEFoTWREY3pnTmNRYk5nUWgwZlhoT2JUZVljWGhNYmthNGF0YUVnMWhJaHdhQWZGZ0liK2dFZmdla2RsZUxlQmNKZ2ZoVWdqZVplS2hIZnhhZGZVZE9md2dFaGxnQmZ5YThkTWhKYlRkOGNLYVVmamRCZ2JmWGZBZHRiWWZFaERnVWdvZU5hemRVZXVnQWRDYlpoUWdVZXdmb2cwZURoRmNFYlVlQmFVZDBheGRIY0FhTWVwY0lheWVBaG9jVWhqY01lSWJNZGxhWWJOYkNoeGJBYlBnVmZBZmdib2FNZ2xna2EyZUFnRGJJaFFoRGdBYzhiemRVZkRnVWROaEZiemhrYjJiRmJ6ZkpoT2ZMY1JhTmdTYk1mQWdCZlNmUGVoZUlnSmRKZlNjd2JTZ1hlMWZJZzJmU2VoYzhhWGdWYURoc2JCYUpoUWZjZHZiRGNDZVVlL2RDYmxhSWR3ZldjMWR3ZExoV2hCaEFjMWdLYURmY2IxZUxjZ2FBZG1lVWdGYk1mS2FOYUFkeGhSY0ZhQWNWZ05kTWFSY3doRGVLaFNnTWNnYktlRmNJYXpoQ2ZEZEpjV2ZEY1Foc2dRZERkMWVRaElhS2ZEZEplWmZOaGdkQWF5Y0VoQWR3ZlBhTWgxY0FmMWZEZ1JmY2E1YU5laGdjYXlnVGJpYzBlVGZVaGphQWJBZFVoamU0ZFNlQ2NTZVVkc2JFZWxkOWdTaE5ma2NvYmZkRmQxYVFnN2hBaFNoVWJIaExld2R3YmxjUGR3ZXBlU2RNZ0ZmdGdjZkNnMWdnZlFiTmNTZGdiM2NOYVNnNGVBZ0pnbGhCaFRkQ2VqY1FlTWRVaFJoUWdGZ1RiVGZFZ2NmQWR5Z2tlamZJY0NnaGdTaE1nd2ZnZHlmVmVnYzBhTGhFZkFkOWVVZENiQ2VnYnliV2FUYllhQWZNaGhhQWJNaERmemdOYlFjTmFRaDBjWGNPZlRnWWdYZ01oa2I0YXRlRWQxZklhd2RBZUZlSWIrZkVkZ2ZrY2xmTGNCYUpjZmRVZWpoWmJLYUhleGVkYlViT2F3ZEVhbGRCaHloOGNNZUpiVGU4YktlVWFqY0JiYmJYZUFhdGJZZUVhRGhVaG9jTmd6Z1VldWNBZkNlWmRRY1Vod2JvZTBiRGJGYUVnVWNCY1VkMGd4ZUhiQWRNY3BnSWd5Z0Fib2NVZWpnTWRJYU1ibGVZaE5hQ2Z4ZkFmUGNWYkFnZ2dvZ01hbGVrZDJjQWhEZ0llUWJEYkFmOGZ6ZVVjRGFVZE5hRmh6ZmtiMmhGZHphSmhPYkxoUmdOZlNmTWFBYkJiU2dQZWhoSWdKZ0poU2J3ZlNoWGExY0loMmdTZ2hnOGZYZVZjRGFzZEJiSmVRZWNhdmFEYUNhVWIvZ0NibGZJZHdoV2UxYXdjTGFXZ0JoQWExYUtjRGVjYzFiTGhnZEFjbWJVZEZnTWVLYU5lQWN4ZlJlRmdBYlZiTmJNZVJkd2NEZktmU2NNZGdmS2RGY0llemhDZkRnSmJXZkRnUWVzZlFnRGIxZVFmSWFLYURoSmFaYU5kZ2NBaHljRWhBZXdkUGZNaDFkQWMxZkRjUmVjaDVoTmRoZWNoeWFUYWlhMGVUZ1VjamNBZ0FlVWhqYzRkU2dDaFNiVWdzZEVjbGY5aFNhTmVrYm9iZmRGaDFiUWQ3Y0FiU2RVZkhmTGd3ZndlbGVQZXdjcGVTZU1oRmZ0ZWNkQ2ExZGdhUWdOaFNkZ2YzZk5jU2g0ZkFjSmRsaEJmVGVDZmpmUWFNYVVmUmJRZEZnVGFUYUVnY2RBZnlia2ZqaEljQ2hoZFNlTWZ3aGdjeWRWY2dkMGZMYUVlQWY5aFVlQ2FDZWdkeWVXY1RlWWJBaE1maGFBZE1iRGZ6Yk5jUWFOZ1FoMGFYZ09hVGNZZ1hoTWJrYzRhdGVFZTFmSWZ3ZUFmRmVJYitlRWVnYWtkbGdMZEJjSmhmYVVkamdaaEtkSGV4ZmRmVWNPZHdjRWNsZEJoeWU4ZE1iSmZUaDhjS2JVZmpmQmFiYVhiQWV0ZFloRWdEZVVib2dOYXpnVWR1aEFiQ2JaZFFiVWh3YW9lMGJEZUZiRWhVZkJhVWMwZXhiSGdBZE1hcGNJZXlhQWJvYlVmamdNZ0lmTWVsaFliTmVDZHhoQWNQaFZhQWdnaG9oTWJsaGtnMmFBYURoSWNRaERnQWY4aHpjVWJEZFVkTmRGZ3pia2YyZ0ZmemZKaE9kTGNSZU5oU2NNZkFkQmJTZlBiaGZJZEpkSmhTYXdmU2NYZTFiSWEyY1NnaGQ4Y1hnVmNEZXNhQmdKZlFmY2N2Y0RhQ2FVYS9kQ2NsZUlhd2VXZTFid2dMYVdoQmZBZzFkS2JEYmNkMWhMZWdhQWVtZ1VnRmJNZUtlTmNBYnhlUmVGZEFoVmFOY01lUmZ3YURiS2NTY01hZ2JLYUZmSWN6aENkRGZKYldnRGhRZHNoUWVEYjFnUWZJZUtlRGRKYlpmTmhnaEFmeWRFZkFld2dQZk1jMWRBZjFmRGZSZGNkNWVOaGhlY2d5ZlRmaWgwZFRoVWhqY0FhQWFVZ2pnNGZTZ0NiU2hVYnNlRWdsZTlkU2FOYWtmb2FmZkZlMWZRYjdmQWhTaFVnSGdMZHdmd2FsZlBkd2JwZlNnTWVGaHRmY2NDZTFkZ2hRZk5jU2RnYTNhTmVTZDRjQWFKY2xkQmNUZkNmamRRZk1iVWVSaFFnRmJUYVRiRWRjY0FjeWhrZ2pmSWVDY2hkU2VNYXdiZ2h5aFZiZ2IwZkxlRWJBZjlnVWRDZ0NkZ2R5ZldhVGRZZ0FhTWdoaEFjTWZEY3plTmdRZ05jUWMwZVhmT2hUY1liWGRNZWtmNGh0ZEViMWRJZndlQWFGY0loK2FFY2dha2VsZUxlQmFKYWZhVWNqZ1pjS2VIZ3hhZGZVZk9ld2RFY2xhQmF5YThlTWdKaFRkOGhLZlVhamdCZ2JhWGJBaHRjWWFFY0RmVWRvY05lemJVY3VhQWdDZVpkUWNVZHdhb2QwaERhRmVFaFVjQmJVYjBoeGZIZ0FoTWRwZUljeWRBZm9iVWJqZ01nSWhNYWxoWWVOYkNleGNBZFBkVmdBY2dib2RNYmxma2QyY0FhRGdJZFFoRGNBZDhnemdVYURnVWFOYkZmemFrYzJhRmZ6ZUplT2dMaFJlTmhTYU1jQWhCaFNiUGhoZElkSmdKYlNld2FTZVhkMWRJYjJiU2doZzhiWGVWYURlc2VCYUpjUWVjZ3ZmRGRDZVVkL2NDY2xiSWJ3ZVdjMWd3Z0xnV2VCZEFmMWJLYkRlY2MxYUxjZ2FBYW1oVWVGZU1jS2dOZ0FoeGhSZUZiQWZWY05iTWVSZ3djRGVLZlNkTWVnYUthRmZJZ3pmQ2VEY0piV2dEZlFic2FRYURiMWJRZEliS2REZkphWmdOZGdiQWZ5Y0ViQWd3Z1BiTWIxZEFmMWFEZFJlY2c1Zk5jaGVjZXloVGVpYTBhVGVVaGplQWhBaFVjamI0YVNnQ2ZTaFVlc2NFaGxjOWJTZE5ia2JvY2ZnRmUxYVFhN2RBaFNjVWdIZExid2h3aGxoUGJ3ZXBmU2ZNY0ZkdGdjZ0NnMWJnY1FoTmZTaGdoM2dOaFNiNGJBY0pmbGJCYlRkQ2ZqaFFkTWVVZFJjUWdGZlRkVGdFY2NiQWd5Z2toamFJYkNkaGJTZk1kd2VnZXlnVmJnZjBkTGRFaEFmOWdVY0NnQ2RnYnloV2FUZFljQWVNYWhnQWNNZ0RiemhOZlFkTmJRZjBnWGRPYlRhWWdYZ01oa2c0ZXRiRWgxaElmd2RBYUZoSWUrYkVmZ2ZrZmxmTGNCYUpjZmdVZWpiWmhLZUhneGNkYlVnT2R3ZUVjbGNCaHllOGNNZ0pjVGQ4ZEtlVWFqYkJlYmZYYUFjdGNZaEVhRGJVY29oTmN6ZVVhdWhBZ0NmWmNRZVVld2JvYTBnRGRGYUVnVWVCaFVlMGJ4ZkhiQWFNZXBoSWZ5aEFnb2RVYWpiTWhJZE1mbGZZYk5hQ2Z4ZkFkUGhWZUFlZ2VvZE1kbGZrYTJhQWREZEloUWhEYkFiOGh6YVVjRGVVYk5jRmd6Y2tnMmZGZHplSmVPZ0xmUmFOZVNnTWdBZEJoU2NQYWhjSWRKZEpjU2Z3ZFNmWGExYklnMmZTYWhoOGVYZFZoRGhzaEJiSmZRY2NndmZEZ0NnVWYvY0NlbGNJZ3dmV2IxYndiTGhXYkJlQWIxYUtmRGhjZDFhTGNnZkFmbWhVYUZiTWhLYk5lQWN4ZFJnRmJBZlZkTmFNYVJnd2ZEaEtkU2RNZWdnS2hGaEliemVDYURiSmRXYkRkUWNzZVFnRGExY1FkSWhLZkRkSmdaZE5nZ2NBZXlkRWVBZXdlUGFNYzFnQWgxZURkUmVjZjVlTmhoYmNmeWVUZ2lkMGZUZVVjamNBZEFoVWRqYTRoU2RDZ1NhVWRzZkVnbGQ5aFNjTmFrYm9lZmdGZzFkUWE3Z0FnU2dVYUhkTGV3Z3djbGFQZ3dkcGVTYU1hRmh0aGNhQ2IxYWdjUWhOY1NnZ2YzZU5oU2I0ZEFlSmJsY0JmVGNDZ2piUWFNY1VkUmRRY0ZnVGdUaEVnY2NBYXlja2RqZEllQ2ZoZVNjTWh3ZWdkeWVWZ2dmMGVMYUVhQWc5Y1VmQ2dDZ2dneWNXZ1RlWWFBaE1oaGRBZk1kRGZ6aE5hUWVOaFFlMGZYZU9nVGNZYVhjTWVrYTRjdGRFZDFhSWN3Z0FmRmhJYStjRWVnYmthbGJMaEJmSmJmaFVmamRaZUtmSGR4ZWRkVWVPYXdkRWZsYkJneWc4ZU1jSmJUZjhmS2hVaGpkQmFiZFhlQWZ0YVloRWNEZFVhb2ZOZHpkVWJ1ZUFlQ2VaYlFoVWF3Ym9hMGJEYUZoRWVVYUJlVWQwaHhjSGNBZ01mcGhJZHlnQWdvYVVnamhNY0lhTWdsYlliTmVDZnhmQWFQY1ZjQWNnZG9iTWNsY2thMmJBYURjSWFRYkRlQWU4Z3plVWNEYVVmTmZGYXpna2MyYUZmemRKY09kTGRSZ05hU2JNZkFjQmhTaFBiaGJJaEpmSmFTZndhU2JYZjFhSWIyaFNlaGE4Y1hnVmFEYnNoQmRKZ1FjY2Z2ZkRjQ2VVYS9jQ2RsZElid2ZXaDFkd2hMZldkQmFBZjFhS2VEZWNiMWVMY2dlQWNtY1VmRmdNaEthTmdBaHhhUmVGYUFkVmhOZk1kUmR3Y0RoS2dTZU1nZ2hLZ0ZlSWJ6aENmRGdKYVdjRGNRZ3NlUWVEZTFiUWNJZEtlRGJKZVpoTmFnZUFieWdFZEFnd2NQZk1jMWFBYTFiRGdSZWNjNWdOZ2hjY2V5YlRlaWQwZVRiVWZqYkFkQWFVYmpmNGJTZUNlU2RVZnNjRWdsZDlmU2hOZ2tib2VmZUZjMWJRYTdiQWNTaFVoSGNMY3dkd2dsYVBnd2JwZFNlTWdGZXRjY2JDZzFlZ2JRZ05mU2FnYjNiTmFTZzRoQWJKZGxjQmJUZkNjamFRaE1lVWVSZFFjRmFUYlRoRWhjZkFieWVraGpnSWdDZGhiU2hNY3doZ2d5YVZiZ2QwY0xjRWZBYzljVWhDZENiZ2h5YldkVGVZZ0FhTWFoaEFnTWJEZnpiTmNRYU5nUWUwZlhhT2NUZllnWGdNYmtmNGh0Y0VlMWZJYndmQWJGZ0liK2RFZWdoa2NsYUxoQmZKZGZkVWhqZFphS2NIYnhjZGdVZk9nd2dFZWxiQmR5ZDhhTWZKY1RhOGRLZ1VmamJCYWJiWGNBZHRmWWdFZkRiVWNvYU5kemdVaHVoQWRDZlpnUWRVZ3dkb2gwZkRkRmJFaFVoQmZVYTBleGRIZEFmTWVwZUlneWdBZm9lVWdqYk1mSWdNZmxkWWZOZkNleGhBYlBnVmhBaGdnb2VNaGxla2YyYUFkRGNJYVFoRGRBYThmemRVYURmVWhOYUZkemRrZzJoRmR6ZkphT2dMaFJkTmRTYU1hQWFCZ1NiUGFoYUloSmVKZ1Nld2hTZVhnMWdJZjJjU2RoYjhnWGFWZkRkc2VCaEplUWdjaHZoRGZDZlVhL2VDaGxoSWN3Y1dlMWN3ZExlV2RCYkFhMWNLYkRmY2YxYUxoZ2dBYW1jVWVGY01oS2dOZ0FjeGNSY0ZlQWNWZU5iTWNSZndkRGRLZlNnTWNnYkthRmVJZHphQ2hEZ0plV2FEZ1Fnc2ZRY0RoMWNRYUliS2NEYkpkWmROZWdhQWR5Y0VlQWN3ZFBjTWMxaEFmMWFEYVJoY2I1YU5kaGJjZnlhVGJpYzBhVGRVYmphQWdBYlVjamg0Z1NlQ2NTY1Vhc2ZFZmxnOWRTYk5oa2FvaGZmRmMxZVFmN2JBYlNmVWFIZkxod2N3Z2xlUGV3YnBoU2VNY0ZjdGdjYkNoMWJnZlFoTmFTZGdiM2hOZlNnNGdBYkpjbGZCaFRhQ2ZqYlFiTWRVYlJiUWdGY1RiVGZFY2NhQWF5ZmtoamZJYkNhaGNTaE1kd2FnZXlmVmRnaDBnTGdFY0FiOWJVZ0NhQ2ZnZ3lnV2JUY1lnQWFNZGhhQWNNYURoemhOY1FkTmhRZTBiWGFPZFRnWWZYZE1ma2U0Z3RlRWUxZklnd2NBZ0ZlSWIrZ0VkZ2FrZWxnTGNCYkplZmVVYWpoWmNLZkhneGVkaFVoT2J3Y0VlbGJCZnllOGFNZUpoVGM4YUthVWZqaEJlYmJYaEFldGZZZEVkRGZVYm9lTmd6ZlVldWdBYUNnWmVRaFVid2hvZTBoRGZGZ0VmVWJCY1VoMGZ4Z0hlQWNNaHBhSWV5Z0Fhb2hVYmpjTWFJZE1ibGJZY05nQ2h4ZUFoUGRWYkFiZ2FvZ01mbGhrZDJkQWJEYUloUWhEZEFnOGd6Y1VhRGFVZk5lRmJ6aGtkMmVGZXpkSmFPZ0xjUmNOaFNjTWZBZEJhU2FQZ2hlSWZKY0plU2N3Y1NhWGQxYUljMmJTZmhnOGdYZlZhRGNzaEJnSmhRZGNmdmJEZkNlVWYvY0NobGVJZXdjV2IxY3dhTGFXZEJlQWMxZEtoRGNjZDFmTGRnYUFobWdVYUZkTWdLYU5oQWZ4ZVJiRmNBaFZoTmVNYlJod2FEZktmU2ZNZGdnS2RGZ0loemVDZkRoSmFXaERjUWJzYVFhRGQxaFFlSWFLZkRnSmJaaE5kZ2JBY3lnRWRBZXdoUGNNZDFjQWcxY0RnUmVjZjViTmFoZ2NoeWhUZmlnMGJUZ1VhamhBYUFjVWhqYzRnU2ZDZ1NkVWVzaEVhbGY5Z1NhTmRrY29hZmVGZzFkUWc3ZUFhU2NVZ0hlTGV3ZXdobGJQZXdhcGhTY01nRmd0ZGNlQ2QxYmdhUWdOYlNlZ2UzYk5lU2M0YUFjSmVsZkJnVGJDZWpnUWFNZFViUmVRY0ZiVGVUaEVnY2FBZHlia2VqZUllQ2hoYlNkTWV3ZWdneWJWZ2dmMGZMZ0VkQWI5aFVlQ2hDYWdheWRXaFRmWWRBY01maGJBY01iRGJ6ZE5lUWNOYlFkMGVYZk9kVGFZZlhoTWRrYTRndGRFaDFnSWV3ZUFhRmNJZSthRWhnZ2tkbGRMaEJmSmZmaFVoamJaZUtnSGd4YWRnVWZPYndnRWhsZUJmeWQ4Zk1nSmFUYzhkS2NVYmpjQmRiZVhlQWV0Z1loRWREZlVnb2JOYnpnVWd1aEFjQ2daZFFnVWF3Ym9hMGNEaEZkRWVVYUJlVWIwZHhiSGhBZk1ocGZJaHllQWFvYVVoamdNY0lmTWRsZVlmTmdDZ3hoQWNQZlZoQWZnZm9kTWFsZGthMmhBYkRnSWFRaERhQWc4ZnplVWZEZVVmTmFGZ3pma2QyZUZmemVKZ09kTGNSaE5nU2NNZEFnQmNTYlBhaGZJY0piSmVTYndlU2JYYzFjSWMyY1NoaGM4Y1hiVmNEZ3NjQmhKY1FlY2Z2YURhQ2ZVZC9oQ2ZsY0ljd2JXZDFmd2ZMaFdmQmRBYTFmS2VEYmNoMWRMZGdnQWVtZlVlRmNNZEtoTmJBZnhhUmRGZEFiVmVOYU1kUmh3aERkS2hTZU1iZ2dLYUZnSWN6ZUNhRGdKZ1diRGNRZnNnUWdEZzFmUWJJY0tkRGdKZFpnTmRnaEFheWJFZEFhd2hQYU1lMWZBZjFoRGhSZmNhNWNOZGhiY2h5aFRnaWYwZlRhVWNqYkFmQWNVaGphNGNTZkNhU2VVZ3NnRWVsZjlkU2dOZWtjb2hmZUZnMWJRZTdlQWdTYlVhSGdMaHdjd2RsaFBhd2RwaFNoTWdGYXRnY2RDYTFlZ2ZRZk5jU2FnZjNnTmhTYTRlQWdKY2xmQmFUY0NnamhRY01nVWJSYlFiRmNUaFRjRWZjZkFneWVrZ2pnSWVDZWhmU2dNY3dmZ2d5Z1ZjZ2cwY0xmRWFBZTlnVWNDY0NjZ2h5Z1diVGFZZUFmTWFoaEFoTWREZ3plTmJRY05jUWgwaFhiT2JUZVlmWGRNZmtnNGV0ZEViMWJJYXdnQWJGYkllK2NFYWdoa2ZsZExiQmZKZ2ZnVWhqaFpiS2NIZnhkZGdVZ09od2dFZmxlQmN5YThlTWFKaFRmOGNLaFVkamZCY2JnWGNBZnRnWWhFY0RlVWVvYk5kemdVZ3VnQWRDY1pjUWVVYXdkb2gwY0RoRmZFaFViQmhVaDBleGdIZkFlTWRwYklkeWRBZW9iVWdqYk1iSWdNYmxhWWhOZUNheGVBYlBlVmVBYmdlb2RNYmxma2YyZUFjRGZJZ1FnRGdBZzhhemhVZURkVWNOZkZkemVrZzJnRmV6ZEpnT2NMYlJlTmZTYU1oQWRCZFNoUGRoZUliSmNKYlNid2VTYlhmMWRJYjJhU2FoYzhlWGJWZERmc2NCZUpiUWVjY3ZhRGNDY1VhL2NDYWxnSWJ3ZFdnMWJ3ZkxoV2NCZ0FkMWVLYkRoY2cxZExiZ2VBY21nVWJGZk1nS2VOZUFneGNSaEZnQWdWZU5kTWdSZXdoRGNLaFNjTWVnYktiRmNJYnphQ2hEYUpjV2ZEY1Flc2ZRaERiMWJRZEllS2dEZkphWmROYmdnQWF5Z0VkQWZ3ZFBlTWcxZ0FlMWVEZVJmY2g1Y05laGNjY3liVGdpZjBhVGNVZGpjQWNBYlVjamg0ZlNoQ2NTZlVnc2RFZmxiOWFTZE5ha2JvZ2ZmRmQxZFFhN2NBYlNiVWRIYkxid2d3YWxiUGJ3ZXBmU2hNYkZndGdjYUNlMWZnaFFhTmRTZmdiM2ROZlNoNGFBZUpmbGFCYlRhQ2FqYVFjTWFVYlJmUWNGYlRhVGRFY2NlQWh5Y2tmamRJYUNoaGVTYU1kd2FnYXlhVmdnZjBoTGdFZUFhOWZVYUNiQ2FnY3lmV2NUYVljQWNNaGhlQWFNZkRlemNOZFFoTmVRYjBlWGRPZVRhWWJYZ01ia2E0ZXRoRWMxaElkd2FBY0ZmSWMrZkVnZ2RrZmxiTGhCYUpnZmdVZGpmWmhLZ0hoeGdkZlVhT2R3ZEVmbGZCZ3lkOGNNY0poVGE4ZktiVWdqaEJoYmdYZEFkdGhZaEVnRGJVYm9kTmZ6Z1VidWVBYkNhWmdRYlVkd2ZvYzBiRGRGaEVmVWhCYVViMGN4ZUhiQWhNY3BoSWZ5YUFhb2RVZWpnTWNJZk1obGdZaE5mQ2F4aEFlUGNWZkFmZ2ZvaE1hbGRrZzJlQWdEY0loUWJEZ0FlOGJ6ZlViRGVVYk5nRmV6ZmtoMmRGY3poSmJPY0xkUmROY1NhTWhBaEJmU2FQZGhoSWZKY0phU2J3ZFNhWGMxYkloMmdTYmhjOGRYYlZnRGFzaEJlSmZRY2NjdmZEYkNiVWUvY0NibGhJZXdhV2gxYXdlTGRXZkJhQWQxZUtnRGVjZzFlTGZnZkFhbWdVZ0ZnTWRLZ05oQWN4YlJjRmNBaFZnTmJNYVJmd2NEYUtmU2RNaGdkS2JGZkllemFDZERlSmZXZURmUWVzZVFlRGgxZVFkSWdLaERlSmZaY05kZ2ZBYnllRWZBYXdkUGRNZDFkQWYxY0RkUmJjZzVlTmdoYmNieWFUYWllMGVUZVVmamNBY0FoVWdqYjRkU2JDYVNjVWhzZUVlbGE5ZVNjTmdrZG9kZmRGZjFnUWM3Z0FhU2NVaEhhTGV3ZHdjbGVQZ3docGdTYU1mRmR0ZWNnQ2cxZmdiUWdOYVNjZ2QzYU5nU2Y0ZkFiSmNsYUJoVGRDZmphUWNNaFVhUmdRaEZoVGdUY0VmY2FBYXloa2dqZ0ljQ2NoZFNkTWF3YWdkeWRWZWdnMGNMZEVoQWM5YlVnQ2hDZmdoeWNXZVRiWWVBZk1maGVBZU1lRGJ6Yk5jUWdOZlFnMGJYZE9mVGhZZFhiTWhrZzRodGNFaDFjSWR3ZkFlRmZJZCtlRWNnZGtkbGRMYUJjSmZmZFViamRaZktkSGV4Y2RiVWRPYXdoRWFsaEJieWU4ZE1mSmVUYjhjS2VVaGpiQmViaFhmQWZ0aFlkRWdEZlVob2ROYnplVWF1ZkFoQ2JaZ1FjVWZ3Z29iMGJEYkZlRWJVaEJiVWcwY3hoSGRBZk1mcGdJYXlnQWNvZ1VmamJNZ0liTWFsY1lkTmVDZ3hjQWRQaFZiQWdnZG9oTWRsZGtjMmdBY0RnSWFRYURoQWc4YnplVWVEZ1VhTmNGZnpoa2UyY0ZkemFKZU9kTGRSY05oU2dNZkFnQmJTYVBnaGFJZUpkSmhTZHdmU2JYZDFoSWMyYlNmaGY4ZFhiVmFEY3NlQmdKaFFmY2R2aERhQ2JVZS9oQ2FsZklhd2RXZTFhd2FMY1dlQmdBZzFkS2hEYWNmMWhMYWdnQWVtYVVmRmZNYktmTmVBY3hoUmRGaEFkVmJOYk1kUmd3ZURkS2JTaE1jZ2NLYkZoSWh6ZUNhRGNKZVdjRGJRYnNlUWREZDFmUWdJYktlRGFKaFpkTmNnYUFleWVFYkFid2ZQZU1lMWhBYTFnRGJSZ2NhNWNOZWhlY2R5YlRnaWEwZ1RhVWFqY0FiQWRVY2poNGhTYUNkU2RVYXNlRWhsYzlhU2FOZmtkb2dmZ0ZlMWhRYzdoQWNTY1VoSGRMYndnd2JsYVBld2VwZVNmTWZGZXRjY2FDYTFnZ2RRZ05hU2JnYTNiTmFTaDRnQWhKaGxkQmVUYkNhamNRZU1nVWZSYlFiRmFUYVRhRWdjYUFheWZrZGplSWZDYWhjU2JNYXdiZ2Z5Y1ZkZ2gwZExhRWRBYzljVWFDZ0NlZ2F5aFdlVGZZZEFjTWRoZ0FjTWFEYXpmTmhRaE5iUWMwZFhiT2RUZ1liWGNNaGtmNGh0YUVlMWJJYXdjQWNGY0lmK2hFZ2dla2RsaExhQmNKZmZmVWFqZFphS2dIZ3hoZGVVZ09jd2VFZGxlQmh5ZDhmTWJKZFRmOGVLaFVhamZCZGJjWGRBYnRjWWhFZ0RnVWZvZE5memJVZHVjQWJDZ1pjUWJVZXdib2UwaERjRmNFYlVlQmZVYjBheGNIZkFhTWdwZElkeWRBZG9nVWRqZk1lSWNNaGxhWWdOY0NjeGdBY1BmVmhBYWdjb2VNZWxia2QyZEFiRGhJZFFjRGhBZThiemdVZURhVWFOZUZoemNrYzJmRmN6Y0pjT2RMZlJlTmVTY01lQWVCYlNmUGZoaElnSmVKZFNjd2FTY1hmMWFJYzJiU2NoYzhhWGdWYkRnc2FCYkphUWNjZnZoRGFDZVVnL2hDZ2xnSWZ3ZldlMWd3ZkxkV2NCZ0FhMWJLZkRoY2ExZkxnZ2hBZm1iVWZGZU1kS2ROaEFneGdSZUZjQWdWZU5iTWdSZHdiRGZLaFNiTWVnYktnRmNJY3pkQ2NEZ0pkV2VEZ1Fkc2FRY0RhMWFRZklhS2hEYkpmWmFOZmdiQWJ5YkVhQWh3ZFBjTWQxZUFlMWhEZFJmY2E1YU5iaGNjY3liVGdpaDBkVGNVZWpoQWVBZlVkamQ0ZFNoQ2JTY1Vkc2VFZmxmOWdTZ05ka2VvZGZjRmgxZ1FiN2dBaFNlVWFIYUxjd2N3ZGxjUGF3Z3BiU2VNYUZkdGFjaENjMWhnZlFoTmZTaGdhM2hOY1NnNGRBZ0pmbGFCYVRmQ2ZqZ1FoTWdVZFJjUWdGZ1RmVGhFY2NkQWh5ZGtkamZJYkNkaGRTY01jd2dnZXlnVmJnYzBnTGNFZkFlOWVVZENmQ2dnYnloV2NUYlllQWJNZ2hkQWZNZURnemROZ1FnTmdRYjBkWGJPaFRnWWRYYk1ma2g0aHRnRWUxY0ljd2FBYUZjSWErZUViZ2VrYmxiTGRCaEpjZmhVZmpkWmhLZEhmeGZkYlVmT2R3ZEVlbGZCZ3lmOGRNYkpoVGY4YktiVWdqZkJjYmZYaEFndGFZaEVjRGRVY29nTmV6ZVVhdWhBYUNnWmNRaFVmd2RvZTBmRGZGZEVhVWdCaFViMGF4YkhlQWhNZ3BlSWJ5ZUFib2hVZmpmTWdJZk1hbGdZZU5jQ2N4YUFoUGVWZkFjZ2NvZk1kbGZrZTJlQWVEaElhUWREYUFmOGV6ZlVoRGZVaE5iRmd6ZWtlMmVGaHphSmJPZ0xhUmROY1NmTWZBYUJkU2FQaGhoSWFKY0piU2F3ZFNiWGQxZUliMmdTYmhjOGJYYlZnRGRzZ0JoSmRRaGNmdmNEYUNmVWEvY0NhbGVJaHdnV2cxZ3dmTGRXZkJkQWcxZUtiRGNjZDFkTGRnYkFnbWRVZEZnTWFLY05lQWh4ZFJlRmZBZlZiTmJNZFJod2hEZktiU2VNZWdjS2JGYkloemdDYURjSmJXZkRhUWRzZVFoRGIxY1FjSWVLZ0RnSmdaZE5mZ2NBZHliRWZBZHdmUGdNZjFiQWQxZURjUmVjZjVhTmJoaGNleWVUZ2ljMGVUZVVlamZBYkFhVWJqZDRkU2VDZFNmVWhzY0VobGI5ZFNiTmhrYW9jZmZGYzFjUWQ3Y0FlU2VVY0hiTGV3ZndmbGFQZXdlcGdTYk1lRmh0Y2NkQ2QxY2dlUWVOY1NiZ2gzY05lU2c0ZkFjSmRsZkJmVGZDYmpiUWVNaFVkUmdRZUZhVGdUaEVoY2RBZXlka2ZqY0lmQ2JoZ1NmTWV3aGdheWJWZGdlMGFMZkVoQWY5YlVnQ2ZDYWdmeWdXZlRkWWZBYU1iaGJBYU1nRGF6Z05jUWZOYVFlMGhYYk9oVGFZaFhmTWVrYzRkdGJFZTFiSWN3aEFhRmFJZitlRWRnaGtobGVMZUJoSmZmZVViamFaaEtnSGJ4aGRmVWFPZ3dlRWJsZEJleWY4ZU1kSmRUZDhnS2JVZWpmQmViaFhkQWZ0ZFlmRWNEYlVob2dOaHpjVWh1ZEFlQ2JaZFFmVWF3Ym9oMGZEZkZlRWVVYkJiVWYwZHhhSGdBYk1mcGVJYXljQWNvZlVjamdNYUliTWhsY1lhTmRDZHhlQWhQZFZnQWNnaG9mTWhsZ2tmMmVBZkRjSWRRZURkQWg4ZHplVWdEYVViTmRGY3pna2UyZ0ZjemVKZ09oTGZSZE5oU2RNZkFkQmJTZlBmaGNJY0pjSmFTYXdoU2FYaDFmSWgyaFNkaGY4ZVhiVmVEYXNhQmFKYlFjY2Z2Y0RjQ2dVYS9iQ2RsY0lkd2hXYzFkd2RMYVdnQmNBZjFmS2dEZ2NiMWhMYWdjQWRtYVViRmNNZEtlTmVBZnhhUmNGYUFjVmhOZU1iUmR3Y0RnS2hTYU1lZ2FLZkZhSWJ6ZENoRGJKaFdnRGFRYnNoUWNEZzFoUWhJZUthRGVKZFplTmhnZEFjeWNFZEFid2VQZU1kMWVBaDFlRGZSZmNmNWhOYWhmY2N5ZVRmaWQwZVRlVWJqYkFiQWVVZGplNGNTZUNhU2RVaHNhRWNsYTlkU2ROZmtjb2VmZkZiMWhRZTdnQWhTZlVlSGRMYXdkd2FsZ1Bkd2ZwYVNmTWhGZHRoY2NDZDFjZ2NRZ05lU2JnYzNlTmNTYTRkQWVKYWxhQmNUY0NlamdRZ01iVWZSY1FjRmNUZFRjRWdjZUFoeWRraGpkSWVDZWhiU2VNZHdnZ2R5ZlZkZ2gwY0xnRWRBZjlmVWJDaENoZ2F5ZVdoVGNZYUFiTWFoZEFhTWhEYnpnTmFRZU5mUWEwYlhnT2hUaFloWGRNZWtmNGh0ZUVnMWhJZ3dnQWNGYklkK2RFZ2dha2RsZ0xmQmZKZGZnVWRqZVplS2JIZXhmZGdVZE9od2JFYWxmQmV5aDhoTWhKYlRkOGhLZ1VjamVCYmJjWGRBZ3RlWWZFY0RlVWVvZk5hemhVZnVmQWhDYlpoUWNVYXdlb2YwZURoRmdFYlVmQmZVYjBneGdIZUFlTWNwZUlkeWFBYm9oVWhqYU1oSWdNZ2xiWWZOZUNieGVBZFBoVmhBY2dmb2JNZmxka2MyZEFiRGVJYVFhRGVBYzhmemRVZ0RhVWFOZ0ZmemJrYzJkRmd6YUpjT2hMYlJkTmhTYU1oQWFCZVNkUGdoZElmSmZKZVNnd2VTaFhnMWZJYjJnU2FoZzhoWGdWZURnc2RCaEphUWFjaHZmRGVDZlVjL2VDZGxiSWJ3ZVdjMWZ3Y0xjV2VCY0FiMWRLaERlY2IxYkxjZ2JBY21hVWVGYk1jS2hOaEFjeGZSZ0ZkQWZWZU5lTWNSYXdjRGJLYlNlTWJnYUtjRmNJaHpoQ2dEZ0plV2FEZFFnc2hRYURlMWVRaEljS2hEYUplWmROY2dmQWN5YUVnQWd3YlBnTWYxZkFmMWNEZlJkY2g1ZE5iaGNjY3llVGNpZzBlVGNVZ2plQWZBaFVnamU0Y1NkQ2NTY1Vic2dFZmxjOWhTY05na2ZvZmZmRmMxZ1FoN2JBZFNiVWRIaExkd2h3YWxlUGh3Y3BhU2FNaEZmdGFjZ0NjMWdnaFFkTmVTaGdoM2hOZlNjNGFBZ0pibGJCYVRjQ2NqYVFiTWdVYVJmUWVGYlRoVGRFY2NkQWN5ZGthamFJYkNiaGVTYU1nd2dnZnljVmNnaDBjTGFFYkFjOWFVZkNlQ2JnY3lhV2hUZ1loQWFNYmhkQWhNYkRlemJOZlFhTmFRZzBlWGVPZVRiWWNYZ01ja2g0ZnRmRWExY0lnd2RBZEZlSWYrYUVhZ2hrZmxlTGRCaEpkZmVVYmpmWmNLZUhheGdkZ1VjT2J3ZEVlbGNCaHliOGRNYkphVGE4ZEtjVWZqZ0JjYmNYZEFldGdZY0VmRGRVZG9kTmV6Y1VndWdBZkNlWmJRZVVid2NvYzBjRGJGYUVoVWFCaFVkMGN4Y0hnQWNNZnBiSWh5YkFhb2RVYWphTWNJZ01ibGhZY05nQ2d4ZUFlUGVWYkFhZ2NvZU1hbGZrZTJlQWVEZUloUWhEaEFoOGJ6ZlVlRGdVZU5iRmZ6Z2tlMmdGY3pmSmRPZUxkUmFOZFNmTWJBZkJhU2NQYmhnSWFKaEpjU2J3YlNnWGQxYUloMmJTZmhhOGFYZFZjRGZzZkJmSmZRZWNmdmZEYkNlVWMvZ0NhbGZJZndnV2QxYndiTGZXYkJhQWExYktjRGhjZzFnTGRnZkFjbWJVY0ZjTWRLYU5lQWh4ZFJnRmNBZVZhTmJNYlJjd2REYktmU2hNZWdjS2ZGZUlkemFDZkRoSmFXZ0RiUWJzZFFiRGQxY1FiSWNLZkRmSmdaZE5hZ2VBZHllRWdBaHdkUGZNaDFoQWcxZERoUmZjZTVjTmdoY2NheWRUZGlhMGdUYVVnamNBYkFjVWJqZjRkU2NDZ1NkVWZzYkVobGc5ZFNmTmRrYm9kZmNGaDFjUWU3ZkFnU2FVYUhlTGh3Y3dkbGJQYXdncGJTZ01lRmd0ZGNmQ2ExY2dnUWJOZFNnZ2QzZU5jU2I0YkFiSmdsZ0JoVGFDY2phUWZNZFVoUmNRaEZkVGhUZUViY2hBZHlha2dqZUljQ2FoZVNoTWZ3ZmdieWJWZmdnMGZMY0VnQWc5aFVnQ2JDZGdheWZXZ1RoWWZBZU1naGJBY01jRGJ6Yk5kUWVOZ1FoMGRYY09lVGdZZFhlTWdrYjRhdGRFYTFiSWZ3ZEFiRmhJZitjRWZnYWthbGJMYUJjSmRmYVVlamhaY0toSGZ4Z2RkVWZPaHdkRWRsYUJheWQ4Z01kSmRUZzhhS2hVZGpiQmNiZVhlQWZ0ZVllRWJEZVVlb2ROZ3phVWh1Z0FoQ2JaZ1FhVWN3aG9mMGZEYUZmRWNVZkJjVWUwZnhhSGNBZU1ncGFJZnlmQWVvYlVoamJNYklnTWRsaFlkTmZDZnhiQWJQZlZiQWJnZm9mTWRsYWtmMmVBY0RhSWVRZkRlQWE4Y3pkVWZEYlVnTmdGZHpka2cyYkZmemZKZE9hTGNSY05hU2VNZ0FlQmZTZVBmaGFJaEphSmdTY3doU2VYZjFjSWYyaFNkaGU4ZFhlVmNEaHNnQmNKZVFmY2Z2YkRlQ2dVaC9oQ2ZsY0lhd2dXYzFjd2dMYldoQmNBZTFhS2NEZ2NjMWZMYWdmQWVtaFVjRmZNZktmTmZBYnhjUmZGYUFlVmdOYk1iUmJ3ZkRiS2FTZU1mZ2FLYkZhSWV6ZUNhRGhKZFdiRGRRY3NoUWREZDFmUWVJYktnRGZKaFphTmdnY0FleWVFZ0Fnd2JQZE1lMWZBZzFnRGRSZmNjNWhOY2hiY2Z5ZlRoaWgwZVRnVWJqZ0FoQWFVYWphNGhTY0NiU2ZVYXNkRWZsZzliU2ROZ2tmb2NmZUZiMWVRZTdkQWZTZ1VmSGNMYXdmd2dsZVBod2ZwYlNnTWZGY3RjY2JDZzFoZ2dRY05kU2JnYzNoTmJTYTRnQWJKY2xhQmZUaENnamJRZk1hVWJSYVFhRmZUZlRnRWRjaEFkeWZrYmpmSWVDYmhoU2ZNZndoZ2d5ZFZiZ2gwZUxlRWFBYjlkVWhDY0NlZ2J5Z1dnVGNZYUFjTWhoZEFkTWVEZHpmTmdRaE5oUWYwY1hkT2JUYVlhWGdNZWtkNGV0ZEVjMWdJYndjQWRGYUlnK2JFZmdha2RsZUxhQmhKY2ZnVWVqY1phS2ZIaHhiZGRVZk9kd2RFaGxkQmV5ZDhjTWNKZlRoOGdLZ1VlamVCZ2JiWGZBZHRhWWhFZkRlVWVvaE5oemVVZXVhQWNDY1pjUWNVYXdob2gwZERjRmZFY1VjQmVVZjBheGFIY0FmTWVwZElleWFBZG9iVWFqZ01lSWhNZmxoWWZOaENieGdBZVBkVmNBaGdjb2VNZGxma2EyYUFhRGNJY1FmRGJBZjhiemNVZkRjVWdOaEZlemhrYTJoRmJ6aEpkT2hMY1JmTmJTZ01jQWJCZVNnUGFoYklnSmVKZVNnd2ZTYlhoMWdJZjJlU2hoZDhiWGFWZ0Rmc2FCZkpmUWVjZHZjRGZDZlVkL2JDZWxjSWZ3YVdkMWR3ZkxjV2JCZkFkMWhLZkRjY2IxaExkZ2FBYW1hVWdGZE1kS2ZOYUFneGRSYUZjQWhWY05lTWFSZndkRGNLZVNmTWZnYUthRmhJaHpiQ2hEZ0poV2JEZ1Fkc2VRaERlMWZRZkllS2ZEYUphWmdOYWdmQWd5Z0VkQWN3ZVBjTWIxYkFjMWZEZVJhY2Y1YU5naGRjYXliVGNpZjBiVGZVZGpkQWZBaFVmamc0Y1NjQ2RTZ1Vhc2hFZWxhOWFTZU5ja2FvZmZnRmQxYlFlN2NBYlNiVWVIZUxod2R3YmxhUGd3ZnBkU2hNZkZjdGNjYkNoMWNnZ1FhTmJTYWdkM2NOZlNkNGZBYkplbGhCZlRkQ2NqZ1FlTWZVZFJkUWdGZVRiVGRFY2NoQWd5ZmtjamhJaENjaGhTZ01nd2ZnY3lmVmhnYzBjTGZFY0FoOWZVZkNlQ2NnYXlmV2RUZFllQWFNZ2hmQWRNY0RiemVOYlFoTmNRYzBjWGhPaFRhWWVYZU1na2E0aHRlRWYxZ0lmd2NBZUZmSWgrZkVlZ2drZWxiTGVCYkphZmJVYWphWmRLY0hleGVkaFVkT2V3Y0VkbGRCaHllOGhNZkplVGY4ZEtjVWFqZUJlYmZYZkFjdGhZYUVkRGNVZG9iTmh6ZVVndWdBZkNjWmJRZFVld2JvZDBnRGZGZkVjVWZCZFVhMGh4aEhmQWdNYnBiSWN5ZUFlb2hVZmpiTWFJaE1ibGJZYU5nQ2F4Z0FhUGJWYUFnZ2FvY01kbGhrYjJnQWJEYklkUWZEZ0FmOGZ6aFVoRGJVYk5mRmN6ZWtoMmhGZHplSmNPaExkUmNOZ1NkTWZBZkJlU2dQZmhjSWRKZkpnU2J3ZFNnWGMxZklkMmJTYmhmOGFYaFZoRGRzaEJiSmdRY2NldmhEYUNmVWEvZENlbGFJZHdoV2IxaHdiTGFXZUJiQWIxZ0tnRGdjZDFiTGRnZUFkbWhVZUZjTWVLaE5oQWd4YlJhRmhBZ1ZiTmZNZlJod2ZEY0tlU2dNYmdnS2JGZ0liemVDZkRoSmZXZ0RjUWJzZ1FnRGQxZ1FlSWZLY0RhSmdaZE5nZ2JBZXljRWhBZ3dkUGZNYjFkQWIxZkRlUmFjaDVjTmZoY2NieWdUYWljMGZUZFVnamRBYUFjVWRqaDRkU2RDaFNmVWFzYUVobGU5Z1NnTmhrZW9hZmFGZDFlUWg3ZkFlU2NVZ0hkTGN3YndmbGZQZXdlcGJTYU1nRmN0YmNoQ2UxYWdhUWVOY1NjZ2MzYU5kU2M0Z0FiSmZsZUJhVGdDYmpnUWVNZFVoUmhRaEZjVGVUY0VhY2ZBZXlla2dqZElhQ2VoZVNiTWh3ZGdleWZWZWdjMGJMYUVoQWU5Z1ViQ2NDYmdoeWRXYVRiWWVBY01haGNBZ01jRGd6Yk5iUWVOYVFjMGhYZE9hVGhZYVhhTWVrYzRndGFFYzFiSWR3ZUFjRmhJZCtiRWFnYmtibGZMZkJhSmdmZ1VnamRaY0tlSGd4ZmRiVWdPZHdjRWZsZkJneWc4Yk1iSmVUZjhoS2FVYmpnQmZiY1hmQWd0YllnRWdEYVVnb2dOZXpkVWN1Z0FoQ2RaZVFiVWh3Y29hMGJEZUZkRWhVaEJjVWgwZ3hmSGRBZU1mcGJJYnlmQWVvZVVoamhNY0lnTWFsZ1lhTmFDZXhiQWVQZlZoQWhnZG9jTWFsYWtiMmVBZERmSWNRaERlQWc4aHpmVWJEY1VoTmJGY3pka2EyYkZnemdKYU9lTGFSZE5jU2dNZ0FkQmNTZFBkaGJJZEpiSmdTZ3dhU2FYZzFnSWEyY1NhaGE4YVhjVmZEYnNhQmVKYVFmY2Z2Y0RlQ2dVZS9jQ2hsYUlod2hXYjFjd2RMYVdkQmZBZzFlS2JEZ2NoMWVMaGdmQWNtaFVmRmVNZEtjTmNBZHhlUmFGZUFkVmROZU1hUmZ3ZERlS2dTYk1kZ2hLYUZiSWR6ZUNjRGRKY1djRGVRZ3NoUWNEYjFjUWNJZ0thRGZKZFpnTmdnYUFmeWhFZUFnd2VQY01kMWdBZjFkRGVSaGNoNWROZ2hiY2R5Z1RjaWMwaFRoVWhqZUFkQWJVZmpiNGVTZENkU2VVYnNkRWdsYTlhU2ROYWtnb2VmYkZnMWVRZDdjQWdTaFViSGhMZndmd2JsaFBid2dwaFNkTWdGZHRnY2dDZDFlZ2ZRZk5jU2FnZjNhTmdTYTRmQWdKYWxmQmdUYkNnamhRaE1nVWNSZlFiRmNUYlRjRWhjZEFheWVrZmpmSWdDYWhoU2ZNYndoZ2V5Z1ZjZ2gwZExlRWRBYjliVWhDYkNmZ2F5YldlVGJZZkFlTWVoZUFlTWNEYXpiTmJRZE5mUWEwYlhhT2hUaFlkWGJNZmtiNGh0Z0VoMWJJZXdhQWJGZEllK2VFYmdoa2JsZUxmQmhKY2ZkVWRqZVpoS2ZIZHhoZGJVZU9jd2RFYWxjQmN5aDhlTWFKYVRnOGJLZ1VnamJCYmJoWGNBYXRjWWNFZERjVWZvYk5hemFVZXVlQWJDYlpjUWFVZndhb2MwZURoRmJFZVVnQmJVYjBoeGhIaEFhTWJwZ0lmeWZBZG9hVWVqYU1mSWNNYmxiWWVOY0NkeGFBYlBnVmVBaGdkb2NNY2xja2UyYkFhRGFJY1FnRGZBZzhkemRVaERkVWdOZ0ZnemRrYTJnRmd6ZEpmT2dMZFJoTmVTZU1mQWZCaFNmUGFoZ0lkSmFKY1Nid2FTZVhhMWNJZzJoU2RoZDhkWGFWZ0Roc2JCZEphUWVjZnZoRGdDYVVnL2JDZWxlSWN3Z1doMWV3YkxjV2ZCZ0FmMWdLZ0RhY2MxYUxjZ2NBZG1hVWdGYU1mS2NOaEFieGNSYkZiQWVWY05iTWJSZHdiRGZLZ1NjTWZnZktkRmVJZnpmQ2VEYkpmV2hEaFFmc2dRYURhMWZRY0lmS2hEYkplWmZOZ2doQWR5Y0VkQWN3ZFBoTWIxYUFoMWdEZVJlY2I1Zk5haGFjYnljVGRpYTBjVGZVaGpiQWhBaFVmamE0Y1NnQ2dTZlVic2hFZGxlOWNTY05na2hvZmZhRmcxYlFmN2RBZVNlVWRIZUxnd2h3Z2xmUGR3YnBnU2dNYkZodGhjY0NkMWdnZ1FjTmZTYWdnM2FOZFNiNGRBZEpkbGVCZFRoQ2FqaFFnTWdVYVJnUWNGYVRlVGNFaGNhQWJ5aGtnamRJYkNhaGhTYk1ld2NnZnliVmhnZTBmTGRFYkFlOWFVY0NlQ2VnYnljV2ZUZlliQWVNZGhhQWZNZkRoemJOYVFhTmhRaDBnWGdPZVRiWWFYZ01la2M0Y3RoRWMxY0lmd2RBZkZiSWErZEVoZ2VrYWxlTGJCZEplZmVVYmpnWmVLYUhieGJkaFVjT2Z3Y0VkbGRCZXloOGhNZ0plVGQ4aEtmVWFqYUJhYmdYZ0FidGJZaEVmRGFVY29kTmd6ZVVndWJBZ0NhWmFRZFVnd2JvZzBkRGdGZEVhVWdCZFVjMGF4Z0hlQWdNZXBoSWV5YUFib2RVYmpkTWJJYU1mbGdZZU5mQ2V4Z0FlUGRWY0FoZ2JvaE1nbGFrZDJhQWNEZkllUWREY0FlOGJ6Y1VhRGZVYU5hRmh6ZWtmMmhGZ3poSmZPZkxiUmROYVNlTWFBY0JmU2RQYmhmSWRKZkpjU2J3YlNhWGYxYUloMmdTZ2hlOGZYZlZjRGdzYUJmSmVRZ2NkdmhEYUNlVWgvZkNkbGNJZndhV2cxYXdnTGJXZkJnQWgxZktkRGhjYzFhTGJnYUFmbWdVaEZoTWZLZk5mQWJ4Y1JiRmhBZFZlTmdNY1Jnd2JEYktlU2dNaGdhS2JGaEljemFDZERiSmdXYkRiUWJzaFFjRGMxYlFkSWZLY0RmSmRaZU5nZ2JBYnloRWdBYXdjUGhNYTFlQWUxaERnUmVjaDViTmVoZWNleWJUYWloMGFUZFVlamZBZ0FnVWFqZzRlU2NDY1NiVWZzZ0VnbGQ5aFNlTmdraG9oZmJGYTFnUWM3ZUFjU2NVZUhhTGV3ZXdhbGZQY3dlcGhTYk1kRmV0Y2NmQ2cxYWdlUWhOZVNlZ2gzZ05lU2M0YkFhSmNsZUJhVGJDZ2plUWFNZVViUmhRY0ZnVGdUaEVlY2dBZXlma2hqYUlhQ2NoYVNlTWZ3aGdheWhWYWdkMGVMYkVkQWQ5YVViQ2RDZmdieWFXZlRiWWRBY01jaGJBaE1mRGV6Yk5iUWZOZFFiMGVYZU9iVGNZY1hhTWNrYzRldGJFYzFmSWJ3Y0FkRmRJYythRWdnY2tlbGRMaEJoSmRmYlVlamdaZUtkSGN4ZmRlVWhPZHdoRWZsZ0JleWE4aE1nSmdUYjhkS2RVZ2piQmJiZ1hmQWh0YVlkRWdEaFVib2dOZ3poVWd1YUFlQ2haZFFmVWh3Y29mMGVEaEZoRWhVYkJjVWMwYXhmSGNBZE1hcGZJYXliQWhvY1VkamVNYklhTWVsY1lnTmhDYnhoQWRQY1ZnQWhnY29iTWNsYmtiMmhBaERkSWZRZ0RkQWY4ZHphVWNEZlVmTmVGY3pha2QyZkZhemdKZU9lTGdSZk5mU2dNY0FnQmFTZ1BjaGZJYUpoSmNTY3diU2FYYjFnSWQyZFNjaGE4ZFhjVmdEYXNnQmVKZ1FoY2N2aERhQ2hVZC9jQ2NsY0ljd2VXZTFid2RMY1djQmJBYzFmS2dEYmNkMWZMZGdhQWZtYlVlRmdNZUtjTmJBZXhnUmFGZEFjVmVOY01iUmV3YkRnS2VTYU1mZ2RLY0ZhSWV6Z0NmRGRKZ1dhRGZRYXNoUWNEZjFoUWdJZUtmRGJKZ1poTmdnYUFheWJFZUFkd2hQZ01oMWFBZTFnRGRSZ2NkNWFOZmhlY2d5Z1RnaWgwZVRkVWNqZkFoQWdVZWpkNGhTZ0NoU2dVZnNnRWdsYzlmU2ROZmtkb2JmYkZlMWVRZTdkQWdTZVVmSGZMZndod2NsYVBod2hwZVNmTWNGY3RnY2JDYTFhZ2NRYk5lU2dnYzNlTmRTaDRhQWhKZ2xiQmNUZENiamhRYk1hVWRSY1FhRmRUaFRnRWJjY0FneWZrY2piSWdDZGhjU2dNYXdmZ2F5Y1ZkZ2MwYkxkRWhBZjlmVWVDYkNoZ2V5YVdkVGJZZUFhTWJoYkFoTWFEYXpjTmNRZE5jUWYwZFhnT2VUZllmWGJNYWtmNGh0ZUVlMWVJZ3dhQWJGZUllK2ZFaGdja2VsYUxoQmVKYWZjVWdqYVpnS2RIZHhnZGFVZE9nd2VFYmxlQmN5YjhnTWZKY1RjOGFLZ1ViamZCZmJjWGJBaHRnWWdFZkRkVWJvZE5hemdVZ3VoQWJDZ1phUWRVYndib2UwZERmRmdFYlVmQmFVZzBheGdIY0FhTWNwY0lneWNBaG9kVWJqY01lSWRNaGxoWWROZ0NoeGNBZFBnVmJBZmdhb2FNYWxla2EyZ0FmRGdJaFFjRGFBZzhjemZVZERnVWVOZEZiemFrZTJiRmR6aEpmT2hMaFJhTmdTZ01nQWhCYlNlUGZoZkllSmJKYlNkd2JTZ1hkMWFJYzJoU2hoYzhjWGZWYkRoc2NCZ0pkUWdjZHZiRGNDYVVnL2ZDYWxnSWd3YVdoMWN3ZExoV2RCYUFkMWNLY0RjY2QxYkxnZ2RBY21oVWJGZE1lS2ZOaEFleGdSZEZiQWJWaE5mTWhSZ3doRGZLYVNiTWNnaEtmRmJJYXpjQ2VEZkpnV2dEZVFkc2VRZkRhMWZRZElnS2hEZkpoWmZOZ2dhQWN5YUVoQWV3ZlBlTWIxZEFkMWNEY1JiY2E1aE5kaGVjYXlkVGhpZTBiVGRVYWpjQWRBZFVhamE0YlNkQ2hTZlVoc2ZFZmxhOWJTYk5ma2hvZGZiRmcxZVFhN2FBZ1NmVWVIZExnd2J3Z2xkUGJ3YnBmU2JNZkZldGNjZ0NjMWFnY1FoTmhTY2dhM2hOZVNiNGZBaEphbGhCZlRoQ2RqZ1FnTWFVZVJmUWhGaFRoVGNFZmNjQWF5YWtnamRJaENmaGJTaE1md2ZnYnlmVmVnZjBnTGZFZUFjOWRVaENlQ2RnZ3liV2dUZ1lnQWZNZmhkQWNNZURkemVOZlFjTmFRaDBnWGZPYlRnWWFYaE1oa2M0YXRnRWMxZUlhd2dBZUZnSWcrYUViZ2drY2xjTGRCYUplZmRVY2phWmFLYkhjeGZkZlVkT2F3Y0VnbGdCYnlmOGhNYkpjVGM4Z0toVWVqYkJiYmRYZkFhdGFZZUVlRGNVZG9oTmN6aFVjdWZBZkNlWmFRZlVjd2dvYzBoRGJGZkViVWRCY1ViMGh4ZUhhQWdNZnBhSWd5ZEFhb2ZVZ2pjTWJJYU1kbGVZYU5oQ2Z4ZUFhUGRWZUFoZ2hvZk1jbGNrZTJjQWNEYUlkUWJEZEFiOGZ6aFVjRGVVZE5mRmJ6ZGtiMmZGZHpoSmZPYUxnUmZOZ1NoTWZBaEJnU2hQZ2hkSWdKZEpjU2Z3ZFNlWGExYklmMmdTYmhiOGRYYVZlRGVzYkJjSmFRY2NjdmdEaENiVWgvYUNobGFJYndkV2cxaHdjTGVXZ0JlQWMxZktnRGhjYzFmTGVnZUFmbWhVYkZmTWJLYk5nQWZ4ZFJhRmRBYlZoTmdNYVJjd2REZ0tjU2dNZGdmS2hGZkllemZDY0RjSmdXYkRhUWdzYlFlRGUxZFFkSWRLaERoSmNaYk5jZ2VBZnljRWhBY3dlUGNNYjFnQWExYURlUmNjYzVhTmJoZmNieWVUY2lmMGdUZlVmamhBaEFoVWFqZDRmU2VDYVNnVWhzYkVhbGY5Y1NoTmNrZ29lZmhGYjFoUWY3YUFnU2FVZUhiTGd3aHdjbGNQY3dlcGNTZ01mRmV0YWNlQ2UxY2diUWdOZFNmZ2YzZE5mU2M0aEFiSmhsZUJnVGVDYmpoUWRNZlViUmFRYkZkVGdUYkVkY2VBYnlna2ZqZ0lnQ2ZoZ1NoTWh3aGdheWRWZmdhMGFMZ0VhQWY5aFVhQ2dDYWdkeWhXZlRoWWdBZk1naGNBY01jRGF6Yk5mUWVOY1FlMGdYYU9lVGFZZlhoTWRrYzRhdGdFZTFmSWN3aEFjRmNJaCtiRWZnYWthbGhMZ0JoSmhmY1ViamNaYUtmSGJ4YWRkVWdPYndnRWNsZEJkeWM4Yk1mSmhUYjhjS2JVaGpmQmRiZVhiQWJ0Y1ljRWdEZ1Vob2ZOZ3phVWJ1Z0FhQ2RaaFFkVWh3ZG9oMGVEZkZlRWVVY0JoVWIwZXhmSGRBaE1kcGFJZ3liQWhvYVVkamJNYkllTWFsY1loTmVDZXhmQWhQZFZkQWZnaG9mTWdsaGtkMmhBYURlSWFRZ0RmQWM4aHpoVWJEZVVlTmNGaHpoa2IyZkZoemJKaE9hTGFSYk5iU2ZNZ0FmQmJTZFBmaGdJZUpjSmNTZndjU2ZYZDFhSWMyYlNmaGQ4Y1hlVmVEZHNjQmdKYVFmY2R2ZURiQ2JVYy9hQ2JsZElkd2NXZTFkd2RMaFdmQmhBYTFnS2ZEYWNkMWFMZWdiQWNtZlVhRmRNYUtkTmdBYnhnUmVGZ0FkVmNOZk1mUmN3ZkRnS2hTYk1nZ2JLZkZhSWh6ZkNjRGdKZFdiRGFRY3NhUWVEYzFnUWVJZ0tmRGdKZlpoTmRnY0FieWhFYkFmd2FQaE1kMWVBZjFhRGdSYWNkNWJOYmhmY2Z5YVRlaWEwZVRlVWJqYkFiQWdVaGpkNGhTY0NmU2JVaHNlRWZsYjlmU2ROY2tlb2hmZkZmMWJRaDdnQWZTZFVhSGJMZHdjd2dsaFBkd2dwZ1NhTWhGYnRiY2dDZTFiZ2hRZU5jU2hnYTNjTmVTYzRhQWNKZmxjQmZUY0NiamRRZk1nVWZSaFFjRmJUaFRnRWRjYUFjeWNrZWplSWhDZmhiU2JNZHdlZ2h5Y1ZhZ2gwZ0xhRWhBZDlhVWVDaENiZ2J5aFdhVGJZY0FlTWNoYkFjTWJEYnpiTmRRZ05nUWMwZlhiT2ZUZVlmWGJNZ2tjNGd0ZkVnMWNJZHdkQWNGZ0loK2ZFaGdla2dsYUxlQmdKZWZnVWFqZlpmS2dIaHhjZGRVYk9od2dFZmxlQmJ5ZzhiTWFKZFRnOGFLY1VhamVCYmJjWGRBYXRmWWZFZ0RkVWJvZ05lemVVYnVkQWNDZlpiUWNVYndjb2EwZ0RlRmRFZVVkQmZVaDBoeGNIZEFoTWdwZkljeWFBY29nVWVqZE1lSWJNYmxlWWJOZUNheGRBZVBkVmdBZmdmb2VNYmxna2YyZEFiRGJJZFFoRGZBaDhlemdVZURnVWROZEZjemVrYTJkRmV6aEpoT2hMZVJmTmdTZU1lQWNCZVNlUGhoY0lkSmZKYVNjd2RTaFhlMWFJYjJmU2NoYThjWGNWZkRlc2dCYUpjUWJjZnZjRGNDZlVlL2NDZ2xjSWV3ZFdlMWN3ZkxiV2hCYUFoMWdLYkRnY2cxZkxmZ2NBZm1kVWVGY01hS2VOZkFheGFSYUZmQWFWYU5iTWdSZXdoRGJLaFNiTWhnZUtjRmhJZHpnQ2hEZUpkV2dEZlFlc2JRYkRlMWhRZUlmS2hEZkpoWmNOY2dkQWJ5YUVmQWV3aFBoTWUxZEFlMWNEYVJmY2M1YU5naGZjaHllVGdpZDBoVGRVZmpmQWJBZ1Voamg0aFNjQ2hTYlVic2NFZGxjOWdTZU5la2dvZGZoRmIxYVFkN2hBaFNjVWRIZUxhd2J3aGxhUGJ3aHBjU2NNaEZjdGRjY0NkMWdnaFFhTmVTZ2dmM2NOY1NnNGVBaEpnbGFCaFRlQ2ZqaFFhTWFVY1JkUWRGYlRnVGJFY2NnQWd5YWtnamNJYkNkaGJTaE1od2JnYnllVmNnYjBnTGJFZEFhOWdVYkNnQ2VnYXlkV2ZUZlliQWhNaGhmQWFNaERmemVOYlFnTmJRYzBhWGNPZ1RoWWNYZ01la2I0ZnRhRWcxYklod2JBaEZiSWMrZUVmZ2NraGxoTGNCY0plZmRVZ2pjWmhLZ0hleGJkZ1VmT2V3ZkVjbGdCYXljOGhNZUphVGE4YktoVWNqZUJiYmhYYUFkdGVZaEVoRGZVaG9oTmZ6ZlVhdWFBZUNiWmVRYlVod2JvYTBhRGZGaEViVWFCY1VnMGh4ZkhoQWJNZHBiSWZ5Y0Fjb2VVY2piTWVJaE1ibGZZY05lQ2h4ZkFlUGhWZkFmZ2JvZU1mbGNrYzJnQWVEYUlmUWZEZEFhOGF6YVVkRGFVZk5kRmN6YmtiMmNGYnplSmZPZkxiUmVOZlNjTWNBZEJnU2hQaGhnSWFKYkplU2F3YlNoWGUxYkliMmNTY2hkOGRYZ1ZjRGRzY0JhSmdRZGNidmdEYkNiVWUvZUNmbGZJZ3dmV2YxZ3doTGVXYUJmQWExaEtlRGdjZTFkTGJnaEFhbWNVaEZoTWhLY05kQWJ4Y1JiRmJBaFZoTmNNZVJjd2REZEtjU2NNYWdlS2NGZUliemFDaERoSmRXaERhUWhzZVFkRGcxYlFoSWdLYkRjSmNaZ05hZ2RBZnloRWhBZHdlUGZNYjFnQWcxY0RmUmJjZTVjTmhoZ2NmeWJUY2loMGNUY1VjamVBYUFlVWVqYjRjU2FDY1NmVWhzZUVmbGI5Z1NhTmdrZG9nZmFGYjFmUWc3Y0FjU2NVZ0hoTGh3ZHdkbGdQaHdkcGhTaE1iRmh0Z2NhQ2gxaGdhUWFOZlNmZ2EzYk5nU2Y0aEFmSmNsZ0JkVGVDYmpkUWFNZlVnUmdRYUZmVGRUY0VkY2ZBZHloa2NqZklnQ2doaFNkTWV3YmdoeWNWZ2dmMGdMZkVnQWE5YlVlQ2hDaGdjeWdXaFRlWWNBYU1naGJBaE1mRGN6aE5hUWVOY1FjMGNYYU9jVGRZZlhlTWNrYTRmdGNFYjFiSWh3ZkFnRmhJZytlRWRnZWtjbGFMY0JlSmdmYlVlamJaZEtoSGV4ZGRiVWZPY3dmRWVsZUJheWg4ZU1lSmRUZzhoS2hVZmpkQmFiZVhiQWZ0aFljRWdEZVVkb2NOaHpjVWV1Z0FoQ2haZFFmVWN3Y29oMGREYUZhRWJVZkJmVWMwaHhiSGdBZ01icGRJZ3liQWZvaFVnamJNZElhTWNsZVlhTmNDZ3hmQWVQZlZkQWZnYm9kTWdsZWtoMmNBY0RlSWJRZkRiQWE4YnpnVWFEZVVlTmFGZnpoa2gyZ0ZjemVKYk9lTGNSY05nU2VNZEFiQmFTYlBiaGJJYkpmSmhTaHdmU2ZYZDFjSWQyYVNlaGU4YVhhVmhEaHNnQmVKZlFkY2Z2YURlQ2VVZy9jQ2RsZUlod2ZXYzFid2NMaFdoQmJBYjFhS2JEZGNjMWZMYmdiQWNtZFVoRmVNaEtmTmRBZHhiUmFGYkFlVmZOZ01jUmZ3ZERkS2NTYk1nZ2VLY0ZiSWJ6ZENiRGFKY1dhRGJRZ3NnUWNEZjFoUWZJYUtkRGRKYlpmTmJnYkFleWRFZkFnd2JQYU1iMWFBYjFjRGNSYmNiNWROaGhnY2V5ZlRnaWYwZVRhVWhqYUFjQWRVYmphNGJTZ0NhU2dVY3NoRWNsYTlhU2ZOY2tib2ZmZkZoMWNRYTdlQWhTZVVoSGJMZHdid2dsZFBod2VwY1NlTWVGZXRoY2RDaDFoZ2FRZU5iU2FnaDNmTmNTZTRmQWVKYWxmQmdUYkNkamZRY01jVWdSaFFmRmJUZlRmRWFjYUFkeWNrY2pjSWFDY2hhU2hNYndjZ2F5Z1ZjZ2QwaExmRWhBZjlkVWJDaENoZ2V5ZldnVGJZZUFmTWNoY0FjTWhEZ3poTmNRaE5oUWEwZVhoT2FUZlljWGJNZ2tnNGN0ZEVjMWdJZHdhQWFGaElhK2RFaGdja2JsZ0xoQmZKYWZlVWVqY1pnS2FIZHhmZGZVY09md2JFZGxnQmd5ZjhkTWRKYlRjOGhLZVVjamhCaGJnWGdBZ3RhWWVFZkRiVWRvYk5jemhVZ3VhQWhDaFpoUWRVZndib2gwZkRhRmNFaFVnQmJVYTBoeGhIaEFkTWhwY0lheWJBZW9hVWhqYk1nSWFNYWxhWWNOZENoeGZBY1BnVmZBY2djb2hNYmxia2gyZUFkRGVJZlFjRGFBZjhiemdVZERnVWVOYUZlemVrYTJjRmV6aEpiT2ZMaFJmTmdTZk1nQWJCZVNmUGdoZUllSmVKYVNod2ZTZ1hmMWVJZjJlU2NoZjhnWGNWZ0Rkc2NCZUpnUWJjYXZlRGNDZlVoL2FDaGxoSWh3Y1doMWJ3ZExiV2dCZ0FnMWVLZERlY2gxYUxhZ2hBYm1hVWNGYU1kS2ROZ0FmeGhSZEZmQWZWZ05nTWRSZHdmRGdLZFNiTWJnaEtlRmRJaHphQ2ZEYkplV2NEZlFjc2dRYkRlMWNRY0lnS2ZEYkpoWmZOZ2diQWJ5aEVnQWN3YlBmTWExaEFlMWZEaFJmY2Q1Z05laGdjaHloVGZpaDBhVGFVZ2pmQWRBZVVhamE0YVNjQ2RTZFVhc2dFY2xjOWJTYk5oa2JvZmZoRmMxZFFiN2ZBYlNhVWVIYUxod2R3YmxlUGZ3Z3BiU2dNZkZkdGRjY0NkMWFnaFFkTmJTYmdkM2JOaFNoNGhBZUpnbGJCYlRiQ2dqYVFjTWJVYVJkUWNGY1RiVGNFZ2NjQWF5aGtmamFJaENkaGhTZE1hd2RnZXljVmRnZDBoTGhFZ0FmOWdVZENnQ2RnZnlnV2JUZlliQWdNY2hoQWFNZ0RjemhOZ1FnTmZRZDBmWGhPZVRlWWhYYk1na2E0ZHRnRWcxYUlkd2dBZ0ZoSWQrY0VjZ2FrZWxhTGdCZkplZmNVYmpiWmJLaEhheGdkZ1VlT2J3aEVhbGdCZ3lhOGRNZUpjVGE4ZEtjVWNqYkJnYmRYZkFmdGZZZ0VmRGVVY29oTmV6Z1VmdWRBYUNoWmRRZ1Vid2FvYjBiRGNGYkVoVWVCZlVkMGh4ZkhjQWFNYnBmSWd5Y0Fnb2ZVZGpkTWNJYk1ibGNZYU5jQ2V4ZUFlUGFWZ0FnZ2RvZE1hbGNrYTJmQWZEYklhUWVEaEFnOGJ6ZFVmRGdVZU5kRmF6aGtiMmhGZnplSmNPZUxoUmZOZ1NkTWRBZEJhU2JQZGhiSWdKZUpkU2d3aFNlWGIxY0llMmFTY2hjOGdYYlZnRGNzZkJoSmZRZGNkdmREZkNoVWIvY0NkbGRJZHdlV2gxZ3dnTGFXYkJkQWMxZ0tnRGZjYjFkTGZnY0FobWRVZ0ZiTWVLZ05hQWN4Z1JkRmRBY1ZnTmFNY1Jhd2FEY0tlU2VNaGdkS2ZGY0llemRDZURjSmFXZkRnUWdzYlFnRGcxYlFnSWhLZURmSmVaYU5hZ2ZBZ3lhRWRBaHdnUGZNYzFhQWUxaERnUmhjZDVlTmJoYmNieWhUZ2lmMGdUZ1VmamNBaEFiVWNqYzRmU2dDZlNjVWRzZkVnbGg5Z1NlTmFrYm9oZmhGYzFkUWM3ZUFhU2ZVZ0hiTGJ3ZXdmbGNQZ3dlcGRTZ01kRmZ0Z2NhQ2MxZmdoUWJOYlNnZ2MzaE5jU2Q0YkFlSmhsZEJjVGdDZmpoUWFNYlVnUmZRaEZnVGhUZEVhY2JBZHlla2dqaElnQ2JoYlNiTWh3ZmdieWhWYWdoMGJMZkVmQWE5ZVVlQ2FDYWdoeWVXZVRoWWRBZ01oaGJBZU1nRGJ6Zk5lUWROZlFlMGFYY09mVGFZaFhlTWRrYzRhdGdFZTFiSWF3aEFmRmRJaCtlRWRnY2tlbGJMZEJnSmNmY1ViamFaZ0toSGh4Y2RlVWRPYXdlRWhsZ0JmeWQ4Yk1hSmdUYzhjS2VVYmphQmViYVhhQWd0YVllRWNEYVVmb2ROYnplVWV1aEFoQ2ZaZlFiVWd3Zm9oMGREYkZmRWJVYUJlVWEwZnhjSGVBZk1hcGhJZXliQWhvY1VjamhNZUlnTWFsZ1loTmZDZnhoQWFQYlZlQWJnaG9kTWVsZ2tmMmhBZkRlSWVRZURlQWY4aHpoVWZEY1VnTmNGaHpna2UyYUZmemRKZE9lTGFSZk5hU2JNY0FnQmRTZ1BlaGhJY0pjSmNTYXdlU2RYYTFoSWMyYVNkaGM4ZlhnVmNEaHNlQmRKZVFiY2Z2ZkRoQ2ZVZS9oQ2hsZElmd2JXZTFkd2dMY1diQmFBZjFiS2REZWNmMWhMaGdiQWVtYlVjRmRNZktnTmFBYXhhUmdGaEFiVmROZ01mUmR3YkRjS2ZTYk1kZ2VLaEZoSWN6YUNiRGRKY1dkRGZRZXNjUWdEZzFkUWdJZUtiRGNKY1plTmZnZEFheWZFY0Fhd2JQZk1kMWZBaDFiRGRSY2NoNWFOY2hmY2Z5YlRoaWYwZFRkVWZqY0FkQWFVZmphNGNTY0NiU2NVYXNkRWVsZDloU2ROZGtmb2JmZkZnMWJRaDdhQWdTaFVmSGJMY3dkd2JsYlBnd2VwYlNkTWRGZXRiY2hDZDFoZ2JRYU5nU2VnYzNlTmhTZjRiQWNKZmxmQmJUZENjamNRYU1lVWZSZ1FnRmFUZVRnRWdjYkFleWZrYWpmSWZDYWhmU2RNZHdnZ2d5aFZoZ2EwZkxkRWJBZTliVWhDYUNoZ2Z5ZVdnVGNZY0FlTWRoZ0FjTWFEaHpmTmhRZU5mUWQwZVhlT2dUY1lkWGZNYWtnNGR0Y0VmMWhJZndjQWRGaElkK2FFaGdja2NsZUxjQmFKaGZmVWdqZ1plS2dIZXhmZGRVaE9kd2NFY2xlQmh5YThjTWdKZ1RjOGhLZ1VkamVCZ2JnWGNBY3RkWWhFaERmVWhvZU5kemFVZ3VhQWFDZVphUWJVY3dob2QwY0RoRmJFY1VkQmhVZDBjeGRIY0FnTWRwYklieWdBYW9mVWRqYk1mSWJNaGxoWWhOZENieGJBZVBiVmVBZmdlb2ZNYWxja2IyZkFkRGVJaFFoRGZBZThnemJVZURoVWROZEZhemNrZjJoRmR6aEpiT2ZMYVJhTmhTY01kQWZCYlNlUGJoYklkSmhKY1Nid2RTZlhhMWhJYzJmU2NoZThhWGdWYURhc2NCaEplUWJjZXZhRGVDYlVnL2FDY2xoSWd3YVdnMWR3YkxmV2hCaEFkMWdLY0RmY2IxaExoZ2hBYm1hVWZGZU1lS2NOZUFoeGZSYkZjQWZWZ05iTWNSZndhRGdLaFNhTWJnZkthRmRJZnpkQ2JEZUpnV2JEYVFmc2ZRZERoMWRRZ0loS2ZEYkphWmFOZmdiQWN5YkViQWd3YVBlTWIxZkFiMWFEZFJmY2c1aE5laGFjZnljVGhpZTBiVGZVZGpjQWFBYlVoamc0YVNkQ2FTY1Vkc2ZFaGxkOWNTYk5la2RvY2ZkRmYxY1FiN2JBZVNoVWVIZkxid2N3ZmxhUGh3Y3BhU2JNZEZndGhjYUNoMWVnYlFoTmFTZWdlM2VOY1NjNGhBZEpobGRCZVRkQ2ZqY1FiTWZVYVJhUWhGZ1RhVGNFY2NmQWR5YmtlamhJZENiaGRTZk1od2RnaHljVmVnZDBiTGZFZEFhOWNVZ0NkQ2RnZHlnV2RUYVlhQWhNZGhhQWFNZ0RhemdOY1FlTmRRYjBmWGhPYlRjWWVYYU1oa2M0ZnRhRWgxZ0lhd2JBZEZkSWMrY0VoZ2hrZmxkTGdCZUphZmRVYWpmWmdLZ0hkeGZkY1VoT2Z3Z0VnbGNCZ3lnOGZNZ0pnVGE4ZEtnVWZqYkJkYmNYaEFidGFZZUVlRGRVYm9nTmJ6aFVidWhBYkNlWmZRZFVid2JvZjBlRGNGaEVjVWFCZ1VjMGZ4Z0hnQWhNZ3BlSWh5ZUFib2FVZWplTWVJZ01kbGNZaE5mQ2Z4aEFnUGhWZ0FkZ2FvYk1mbGFraDJmQWNEZklnUWZEZEFlOGZ6Z1ViRGZVYk5hRmR6ZmtjMmhGYnpiSmdPYUxmUmdOZFNkTWNBYUJoU2ZQYWhmSWdKaEpoU2V3Y1NnWGQxZElmMmRTZ2hiOGhYaFZoRGdzY0JmSmZRZmNldmVEYUNlVWQvZUNnbGRJZHdkV2cxYndmTGNXZkJmQWMxY0tkRGFjZzFlTGVnZkFobWFVZ0ZjTWVLZk5lQWJ4ZVJnRmhBZ1ZnTmNNYVJhd2JEZkthU2FNaGdhS2RGYklhemFDZURnSmdXZ0RmUWFzZVFmRGgxZlFlSWJLZ0RiSmdaYU5oZ2NBZnljRWFBZndnUGVNZTFhQWgxYURiUmVjaDViTmNoZGNneWJUZGljMGZUZVVoamJBYUFkVWdqZTRnU2VDZFNjVWdzZEVjbGY5YVNhTmRrY29iZmJGZzFmUWY3Y0FlU2NVZkhmTGF3Y3dibGNQZndhcGJTZk1nRmh0ZGNoQ2UxZWdiUWZOZFNkZ2IzZU5iU2c0YUFoSmhsY0JoVGJDY2pjUWVNZ1VnUmVRYUZlVGhUZEVnY2JBZHlha2FqYUlmQ2JoaFNiTWJ3ZWdneWJWZWdoMGRMZUVkQWY5YlVmQ2JDZmdkeWNXYVRmWWdBZE1maGdBaE1hRGN6Zk5iUWNOaFFmMGNYYk9mVGNZaFhhTWFrZjRhdGdFZTFhSWd3Z0FnRmhJZitkRWZnZ2tlbGZMZkJjSmRmZVVoamZaZktnSGV4aGRhVWhPaHdhRWZsZUJneWQ4Yk1mSmRUZjhiS2ZVZWpkQmFiYVhjQWd0YVlnRWdEY1Vhb2ROZnpmVWd1Z0FhQ2FaYVFiVWJ3aG9kMGNEY0ZoRWFVaEJiVWQwY3hlSGhBZE1kcGNJZXlkQWVvZlViamJNYUlnTWVsZllmTmFDaHhmQWdQZlZlQWNnZG9iTWhsZWtoMmFBZURkSWhRYkRjQWQ4YnpjVWJEY1ViTmdGaHpma2MyYUZnemhKY09jTGZSY05iU2ZNYUFjQmNTZ1BjaGdJYkpnSmhTYndnU2dYaDFiSWIyZVNhaGE4YlhkVmJEYnNjQmRKY1FhY2N2YURmQ2NVYy9mQ2hsZ0lmd2dXYzFhd2NMZ1dmQmhBZDFoS2ZEZGNlMWdMZ2dhQWhtYlVnRmdNaEthTmdBYnhhUmFGYkFmVmROaE1nUmF3ZkRlS2ZTZk1iZ2ZLY0ZmSWZ6YUNlRGFKYldmRGNRYnNiUWhEaDFjUWhJZktlRGJKZFphTmNnY0FjeWJFYkFid2VQYU1nMWVBaDFoRGdSZWNjNWdOZ2hlY2J5Z1RjaWYwZ1RkVWZqaEFiQWNVZWphNGVTZ0NlU2RVZ3NlRWNsZDlmU2hOZWtjb2dmZ0ZnMWhRZjdlQWNTZFVnSGRMZ3dmd2JsZlBod2JwZlNnTWdGZ3RmY2hDYTFlZ2hRYk5jU2dnaDNoTmFTZTRlQWVKZGxnQmZUYUNiamVRZE1mVWJSZ1FmRmZUZFRkRWdjZkFneWdrZWpkSWFDaGhoU2JNYndkZ2R5aFZmZ2EwY0xjRWZBYjliVWdDaENjZ2V5ZVdmVGhZYkFhTWdoYkFkTWFEY3pkTmdRY05mUWQwZVhkT2ZUaFlkWGdNYWtnNGd0YUVjMWFJY3diQWVGZUlmK2NFZ2dia2RsaExlQmhKYWZnVWRqYlpnS2dIY3hoZGJVaE9id2NFY2xjQmZ5YjhnTWJKY1RkOGhLaFVmamhCYmJmWGJBZXRkWWFFaERhVWRvZ05oemVVZHVnQWRDZVpnUWZVZndlb2UwYURlRmFFaFVoQmNVYjBoeGVIYUFoTWZwZElleWVBaG9hVWVqZk1hSWRNYWxlWWJOZENmeGJBZ1BkVmJBYmdkb2NNY2xka2EyZ0FiRGNJY1FjRGNBYThhemdVZURkVWVOYUZjemVraDJlRmZ6Y0pmT2ZMYlJmTmJTYU1oQWVCYlNiUGRoYklhSmZKYlNld2JTZ1hoMWFJZDJmU2RoZThkWGJWYkRmc2ZCYkplUWJjZHZiRGVDYVViL2VDYWxhSWZ3YVdkMWh3ZUxjV2hCZUFiMWFLZkRhY2MxY0xlZ2NBaG1nVWVGYk1mS2FOY0FjeGNSaEZkQWFWZU5hTWVSYndlRGVLYlNjTWVnYkthRmJJZnpoQ2NEZ0piV2FEYVFoc2RRZkRhMWRRZElkS2FEZkpoWmROY2dhQWF5ZUVnQWN3ZFBkTWYxaEFlMWdEZVJiY2U1ZE5kaGZjYnloVGdpaDBlVGJVY2poQWJBZFVhamU0ZVNoQ2dTZ1Vnc2NFZGxmOWJTZU5na2RvZGZoRmUxZFFmN2VBYVNiVWJIYUxod2V3ZmxnUGZ3Z3BjU2JNaEZkdGJjZ0NhMWhnaFFhTmNTZ2dnM2NOZlNlNGFBaEpmbGRCaFRoQ2dqZlFmTWhVYVJiUWNGZlRmVGNFaGNhQWJ5Y2tjamZJZUNmaGVTYk1md2ZnZnllVmZnZTBhTGVFY0FjOWdVYkNhQ2RnZ3lhV2VUZFlnQWNNYWhhQWVNZ0RoemNOYlFlTmRRYzBnWGdPaFRmWWRYZ01ma2I0ZnRjRWcxZElhd2NBYkZlSWYrZUVoZ2drZWxnTGJCZUpnZmRVZGpoWmhLZkhmeGRkaFVjT2N3ZUVkbGZCY3ljOGVNaEpjVGc4aEthVWNqYkJiYmFYZ0FidGRZZUVkRGhVZW9jTmh6YVVhdWZBZENmWmNRZ1Vod2NvZTBiRGRGYUVoVWdCZ1VnMGN4Z0hhQWVNZnBoSWN5ZEFmb2FVYmpiTWZJYU1nbGZZY05hQ2F4ZUFkUGhWZUFmZ2FvZ01jbGJrZTJkQWJEZUlkUWJEY0FnOGN6aFVoRGZVZE5kRmV6Z2toMmJGZnphSmRPaExmUmVOYlNoTWRBY0JkU2RQYmhjSWJKZUpoU2N3YlNnWGMxY0liMmdTZGhiOGRYYlZmRGVzaEJkSmNRZGNndmVEYkNjVWIvaENmbGNJYXdiV2YxaHdoTGNXYkJoQWQxaEtkRGhjYjFjTGdnYkFkbWhVZkZlTWFLZE5mQWR4ZVJiRmVBZlZhTmhNYVJid2dEYUtjU2RNYWdmS2ZGZklkemFDZURjSmFXZkRiUWJzYVFhRGExZVFoSWVLZkRhSmhaZk5nZ2JBZ3lkRWJBYndiUGFNZjFhQWIxZURnUmdjZjViTmRoZGNoeWNUaGlmMGRUY1VmamJBYkFhVWRqZDRjU2FDaFNmVWdzYkVkbGg5Y1NhTmJrZG9jZmNGZjFlUWg3YUFhU2ZVYkhiTGJ3Y3dlbGdQaHdmcGNTZE1nRmh0ZmNoQ2cxYWdhUWZOZ1NkZ2EzY05iU2U0YUFlSmRsZUJkVGVDZGpoUWRNYVViUmRRZEZlVGdUYUVhY2RBY3lma2FqYUliQ2hoYVNmTWR3ZmdheWVWZWdmMGJMYUVhQWM5ZVVoQ2RDZ2dheWRXZVRmWWFBY01laGdBZU1lRGZ6ZE5oUWJOYlFhMGdYZU9hVGNZYVhhTWVrZzRodGJFZjFmSWN3YUFmRmFJZitjRWdnZ2tjbGNMZkJlSmVmYlVjamZaYktmSGV4Y2RkVWVPZndhRWhsaEJieWI4YU1lSmdUZThhS2RVZWpoQmViYlhnQWV0YVljRWdEYVVib2ZOYXpiVWJ1ZEFmQ2ZaZ1FoVWd3Y29iMGNEZUZnRWVVYUJmVWcwZnhjSGZBZU1ncGdJZHllQWNvZFVjamVNYUlmTWNsaFlkTmJDaHhmQWVQZFZiQWFnY29lTWhsY2tnMmhBY0RoSWZRZ0RlQWI4YnplVWVEZFVhTmZGYnpma2UyaEZhemdKZ09kTGZSY05nU2RNaEFlQmNTZlBnaGFJZ0pmSmNTZXdiU2NYZjFkSWIyYVNmaGQ4Y1hiVmhEZXNjQmVKYlFnY2R2Z0RmQ2dVZS9mQ2FsZklhd2FXYTFmd2dMZVdoQmVBZDFhS2hEYWNoMWNMY2dkQWdtY1VkRmRNYUtiTmNBZ3hiUmFGY0FkVmdOZ01kUmd3ZERoS2ZTY01nZ2ZLaEZlSWJ6ZUNkRGJKZVdnRGZRZHNiUWZEYzFkUWVJY0tkRGVKZVpnTmFnaEFjeWNFYkFod2JQZU1jMWFBYTFlRGdSYmNiNWVOY2hnY2d5YlRnaWQwYVRlVWVqYUFlQWRVZWplNGVTYUNmU2hVY3NnRWJsYjlmU2VOYmtib2ZmZUZlMWJRZjdlQWdTZVVjSGFMY3dnd2FsYlBmd2FwaFNnTWZGZ3RjY2NDZDFoZ2JRYk5mU2JnYTNkTmRTaDRiQWZKZ2xkQmdUaENmamFRZE1jVWRSZlFjRmFUaFRmRWJjY0FmeWRrYmphSWRDZWhhU2VNZHdkZ2J5YlZkZ2YwZExhRWNBYjllVWNDY0NlZ2V5Y1dmVGVZYUFnTWFoZ0FoTWREZXpiTmNRZk5nUWQwZFhnT2JUY1lkWGhNYmtkNGZ0YUVmMWJJYXdlQWJGYklhK2VFYmdja2JsYkxnQmVKZGZnVWJqYlpnS2dIYnhhZGZVZU9hd2dFaGxiQmR5ZThoTWZKYlRjOGZLZ1VlamJCYWJjWGJBZ3RiWWRFZERkVWNvY05nemRVZHVlQWZDYVpiUWhVZHdob2UwZkRiRmRFYlViQmVVYTBoeGdIZkFhTWdwZUlmeWRBaG9lVWFqYk1hSWVNY2xnWWdOaENneGNBZFBiVmdBZGdmb2FNYWxoa2YyZkFhRGVJaFFhRGhBZzhlemhVaERjVWhOZEZiemNrZjJhRmh6YUpnT2FMYVJnTmNTYk1lQWhCaFNhUGZoZklhSmZKYlNnd2JTZ1hoMWJJYzJoU2VoYjhoWGVWZkRic2NCZEpjUWRjYnZjRGhDZVVjL2ZDZWxoSWd3YldkMWd3ZExiV2dCZEFnMWNLYkRlY2UxZ0xmZ2RBZG1nVWFGYk1jS2hOYUFoeGRSZEZjQWJWYU5nTWNSZHdlRGNLaFNiTWVnY0tkRmdJaHpiQ2hEYUpkV2ZEaFFic2RRYURhMWJRY0loS2VEY0pmWmFOaGdoQWV5aEVlQWd3ZlBhTWgxZkFkMWJEZlJlY2Q1YU5haGhjY3liVGFpZjBhVGNVYWpoQWFBYVVmamI0ZFNmQ2RTYlVmc2RFY2xoOWdTZ05la2VvaGZkRmYxaFFhN2FBZlNhVWhIZUxnd2d3ZmxlUGZ3ZHBlU2hNZUZhdGNjZkNiMWFnZFFoTmZTZGdoM2ZOZFNoNGFBYUpjbGFCY1RnQ2FqZVFiTWRVY1JkUWVGYlRmVGdFZ2NoQWV5ZWtoamZJZENiaGZTZ01od2FnZXlhVmFnYTBnTGVFZ0FkOWVVZENnQ2dnY3liV2VUZFlmQWFNYWhiQWZNY0RoemROYVFiTmRRZTBnWGNPYlRiWWRYZE1la2I0Z3RkRWExYUlld2NBYUZlSWIrY0VhZ2JrZGxiTGVCYUplZmRVYmpoWmZLY0hleGJkZVVoT2N3ZUVjbGVCYnlhOGRNZUpiVGQ4YktiVWJqZ0JiYmZYYkFodGJZaEVhRGhVaG9hTmN6Z1VjdWJBZUNlWmVRZFVld2NvZTBnRGRGZUViVWFCZVVjMGh4ZEhnQWhNYXBjSWR5ZEFnb2NVZGpiTWhJZU1obGJZZ05hQ2Z4Z0FjUGRWYUFkZ2NvYU1jbGdrZjJkQWNEZElhUWFEYUFmOGZ6ZFVhRGdVZU5oRmd6ZmtjMmJGaHphSmVPaExkUmROZlNlTWVBYkJhU2NQaGhoSWhKZUpoU2R3aFNmWGQxZElmMmNTZGhnOGVYaFZjRGVzZUJjSmZRYWNidmZEY0NoVWMvZkNhbGVJZndnV2cxYXdhTGNXY0JiQWYxZktmRGRjYzFnTGVnZEFobWNVaEZoTWdLZ05kQWF4ZVJoRmJBaFZhTmdNY1Jid2hEaEtmU2dNZGdmS2VGZUlhemVDZURoSmdXZURjUWZzZVFoRGExYlFoSWdLYkRiSmRaZU5iZ2RBZ3lmRWFBZXdkUGFNZDFlQWgxZ0RjUmNjYTVjTmRoaGNieWJUZWlnMGRUYlVkamFBZ0FiVWVqZDRhU2hDYVNiVWdzZkVkbGE5ZlNkTmVrY29hZmdGYTFiUWY3YkFiU2dVZ0hoTGN3YndlbGNQaHdncGNTZU1oRmh0ZGNmQ2gxZGdnUWNOZVNnZ2QzYk5iU2M0aEFlSmZsY0JjVGRDYWpnUWZNZ1VmUmFRZUZmVGVUYUVoY2VBZ3lna2RqZklmQ2RoZFNhTWF3ZWdjeWVWZmdkMGVMY0VlQWQ5aFVhQ2VDZGdkeWRXYVRmWWZBZ01oaGNBZk1hRGJ6ZU5hUWNOYVFlMGJYYU9lVGdZZlhkTWNrZDRodGJFYjFiSWd3ZUFhRmFJYStkRWdnaGtibGFMZUJkSmJmYlVkamdaZEtiSGd4Z2RnVWdPZXdjRWhsYUJleWg4aE1oSmNUZzhmS2JVZmpoQmViYVhhQWJ0aFllRWNEZlVlb2hOZXplVWd1Y0FkQ2ZaaFFhVWZ3YW9lMGhEZEZmRWFVZ0JhVWIwYXhiSGJBZ01kcGNJYXllQWhvZlVoamNNY0loTWZsY1lnTmZDZnhkQWRQZVZoQWNnYW9jTWFsZmtoMmdBZkRiSWRRZ0RkQWQ4YXplVWdEZFVlTmZGaHpia2QyZkZnemZKZ09iTGFSZE5hU2hNZ0FlQmhTaFBjaGFJZ0pmSmFTaHdoU2VYaDFoSWUyZVNhaGg4ZVhnVmNEaHNjQmZKYVFhY2h2Z0RnQ2FVYi9hQ2RsZ0lnd2hXYTFod2hMZFdjQmdBZzFiS2NEZmNlMWRMZmdnQWhtYlVlRmdNZEtoTmZBYXhoUmRGZ0FmVmZOZk1hUmJ3ZkRlS2FTaE1iZ2VLZEZlSWZ6aENkRGZKaFdoRGhRaHNlUWZEZjFmUWJJYktlRGRKY1phTmVnZEFneWdFYkFhd2ZQYU1nMWhBaDFkRGdSZWNmNWFOYmhlY2J5ZFRnaWMwZ1RmVWhqaEFjQWhVZ2pkNGdTY0NoU2VVZHNoRWhsYjllU2ROYmthb2RmYkZmMWVRYjdjQWFTZlVoSGFMY3dhd2VsZlBod2dwZFNkTWVGZHRmY2ZDYjFlZ2NRZU5oU2FnZDNlTmdTYTRlQWVKYWxlQmRUZ0NmamFRZk1oVWRSZVFlRmhUZ1RiRWJjY0FneWZrZ2piSWhDaGhnU2hNaHdkZ2V5Z1ZhZ2YwZExjRWJBZDlnVWZDZkNkZ2F5ZFdnVGZZY0FhTWhoZkFhTWdEZnphTmRRZE5oUWEwZVhnT2FUYllnWGZNZWtkNGh0Y0VmMWhJZ3dnQWhGZklmK2FFZmdja2hsZExmQmJKZ2ZjVWJqZlpkS2FIYXhjZGNVZ09jd2NFZGxjQmJ5YjhlTWhKZ1RnOGFLY1VhamdCYmJmWGZBZnRjWWNFZERlVWhvYk5hemFVaHVhQWVDZlpjUWZVZ3dob2MwZURkRmhFaFVjQmJVZzBneGdIYUFnTWZwY0ljeWZBYm9lVWdqYk1kSWZNZWxiWWdOZENkeGJBZVBkVmhBaGdmb2NNY2xja2gyZkFhRGJJaFFoRGFBaDhjemhVaERjVWhOYkZhemhraDJkRmF6Y0poT2dMZlJiTmNTZE1jQWVCaFNiUGJoZElkSmRKYlNkd2FTZ1hjMWZJZjJjU2NoaDhlWGRWYURhc2RCY0piUWZjYXZnRGZDaFVmL2ZDY2xmSWh3aFdmMWR3ZUxiV2FCaEFnMWJLZERkY2IxYUxnZ2VBaG1oVWdGYk1lS2hOZkFkeGJSZEZkQWFWZE5jTWVSY3doRGFLZlNjTWNnYUtlRmRJZXpiQ2dEaEpmV2FEYlFmc2JRZkRhMWNRaEllS2hEZUpoWmVOY2dhQWN5YUVmQWd3ZlBkTWExYkFlMWFEZVJnY2Y1ZU5naGVjZHljVGJpZDBkVGJVZGpoQWZBZVVoamU0ZVNiQ2dTYlVlc2hFZGxjOWVTZ05ja2dvYWZnRmUxZlFkN2RBYlNlVWVIZUxhd2J3aGxlUGJ3aHBnU2dNZEZmdGFjZ0NmMWVnZFFiTmVTaGdhM2FOZVNlNGFBYkpobGdCYVRiQ2JqZ1FoTWdVYVJjUWVGZ1RoVGJFaGNoQWV5YmtlamdJZUNoaGhTY01od2NnY3ljVmRnaDBhTGNFYkFhOWNVYkNoQ2FnYnljV2VUZlllQWNNZmhoQWRNaERhemdOY1FmTmZRZTBmWGFPZVRnWWVYYU1la2c0ZXRnRWgxY0lnd2hBZUZlSWIrZEVjZ2drYmxmTGdCY0phZmVVYmpkWmhLYUhheGZkZlVjT2N3Z0VobGNCZnlmOGhNZ0phVGg4ZEtkVWZqZkJhYmZYZ0FhdGFZYkVmRGJVZW9mTmV6Z1VndWFBYUNlWmhRY1Vid2JvYTBoRGFGaEVlVWhCY1VlMGN4aEhlQWJNZnBjSWN5Z0Fnb2JVYWpjTWhJYU1jbGJZZU5lQ2N4YkFiUGZWY0FoZ2NvZU1jbGZrZjJjQWJEZEloUWJEaEFoOGd6ZlVkRGZVY05mRmN6ZmtlMmdGaHpmSmFPYUxkUmVOZVNoTWdBZUJlU2FQZWhoSWZKaEpmU2R3Y1NkWGExYkljMmdTYWhnOGFYZFZmRGVzZ0JkSmJRaGNndmZEZUNkVWMvYUNlbGJJZ3dmV2MxaHdoTGJXZ0JmQWUxZEtoRGFjYzFhTGNnZUFjbWdVZEZjTWNLZE5jQWJ4Z1JiRmRBYVZoTmJNZFJod2VEZ0tjU2ZNZmdkS2ZGZ0lkemNDZkRjSmFXZURiUWVzZFFnRGUxZlFhSWRLYkRhSmZaYk5mZ2FBZXlmRWdBaHdiUGhNaDFkQWMxaERkUmFjZzVmTmFoYWNmeWdUZ2ljMGRUaFVhamdBZ0FiVWRqYjRlU2JDZVNmVWhzY0VjbGI5ZFNiTmhrZG9oZmRGaDFmUWY3aEFmU2RVZ0hiTGF3YXdmbGVQYXdmcGhTaE1mRmh0Y2NiQ2UxZ2diUWhOZVNjZ2UzZk5jU2Q0YkFlSmFsYkJiVGVDZ2pjUWRNaFVkUmZRZUZlVGVUZkVhY2NBZ3lia2NqZkllQ2VoZFNlTWV3aGdieWNWZmdlMGZMYkVjQWg5ZlViQ2RDZWdleWJXZFRjWWVBZU1naGNBZE1kRGN6YU5oUWVOaFFlMGhYZE9kVGJZYlhoTWNrZTRjdGdFZjFiSWJ3YkFoRmVJZythRWZnYWtmbGFMZ0JlSmhmZVVjamJaYUtoSGF4ZGRoVWhPZXdhRWJsaEJieWY4Yk1kSmRUZjhjS2RVZmphQmFiYVhkQWF0ZVlmRWNEZ1Vhb2FOaHphVWd1Z0FjQ2RaZFFmVWV3Ym9nMGVEYkZhRWJVaEJkVWgwYXhhSGNBaE1hcGJJZ3liQWhvZlVhamZNZ0liTWJsZFloTmNDYXhjQWFQZVZnQWFnZm9oTWVsZGtjMmhBaERkSWhRYkRhQWI4Z3pnVWdEZ1VmTmJGYXpha2cyYUZjemZKZ09iTGFSYk5hU2JNYUFlQmRTaFBlaGJJYkphSmhTZXdkU2RYaDFnSWcyZ1NmaGU4Y1hoVmREZXNjQmJKZVFlY2d2Y0RnQ2ZVYS9lQ2JsaElld2NXYzFld2dMaFdjQmhBYTFnS2ZEZWNhMWdMZ2diQWJtZVVkRmRNaEtiTmZBYnhnUmNGY0FjVmdOY01mUmV3YkRmS2NTZk1oZ2RLZkZhSWR6YkNkRGVKYldjRGNRaHNjUWJEYjFhUWJJZ0tkRGdKYVpkTmdnZkFleWVFY0Fod2hQZU1oMWZBYzFnRGdSZGNoNWNOZmhnY2Z5aFRiaWMwZVRkVWRqZkFnQWNVZ2plNGZTZkNmU2RVZ3NhRWJsZTlnU2JOaGtmb2ZmaEZkMWhRYjdiQWZTZVVoSGNMZHdld2NsYVBkd2ZwZVNkTWJGZXRmY2ZDZTFoZ2hRZk5oU2VnZzNnTmFTaDRoQWNKZWxnQmJUZkNiamRRaE1iVWFSZFFoRmJUZ1RkRWFjZUFkeWVrYmpmSWJDY2hoU2RNZXdjZ2J5ZVZnZ2MwZExhRWFBYjlkVWZDaENkZ2F5Y1dhVGRZZ0FlTWRoY0FjTWNEZHpnTmdRZU5lUWYwaFhjT2NUZFlkWGFNZ2tnNGJ0YUVlMWdJaHdkQWFGZUlhK2dFZ2dna2FsY0xmQmFKYmZiVWVqZ1pnS2ZIYXhjZGdVY09id2RFYmxkQmJ5ZDhoTWhKZ1RoOGhLYVVnamdCZGJnWGNBaHRjWWFFYURmVWRvZE5iemFVZXVlQWdDY1pjUWFVZHdjb2IwZERjRmNFYlVkQmZVaDBjeGJIZUFmTWZwZEloeWNBZG9nVWdqYU1iSWRNaGxjWWdOYUNmeGVBY1BnVmJBYWdib2dNYWxma2MyYUFmRGVJY1FjRGRBYThmemVVZkRlVWNOZkZnemVrZDJiRmZ6Z0piT2FMZVJhTmRTYU1mQWVCYlNoUGJoZUliSmJKYlNnd2RTZVhhMWhJaDJiU2RoYjhlWGNWZURlc2JCZ0phUWdjZ3ZhRGZDaFVoL2VDY2xlSWh3Z1dkMWJ3Z0xjV2JCZkFkMWdLYURjY2IxZExnZ2RBYm1kVWdGaE1jS2ZOaEFneGRSYkZlQWdWZU5kTWVSaHdnRGJLYlNlTWJnYkthRmhJYnpjQ2VEYkpkV2NEYlFlc2FRaERjMWNRY0lnS2ZEZkpoWmROY2diQWN5ZUVmQWJ3Z1BlTWQxZUFoMWZEZFJnY2I1Yk5iaGRjYnliVGRpZzBnVGZVZWphQWdBY1VjamQ0ZlNlQ2JTaFVkc2ZFY2xmOWVTY05ja2FvYWZnRmgxZ1FnN2FBaFNmVWVIYUxod2h3aGxoUGN3ZnBhU2hNYUZjdGNjZENhMWZnaFFmTmNTZGdjM2dOZlNlNGJBaEplbGNCaFRlQ2VqaFFhTWdVZlJnUWRGaFRkVGNFYmNnQWF5Z2tmamdJYUNlaGZTY01nd2VnYXlnVmVnYzBjTGhFYUFmOWFVZkNjQ2NnZ3llV2hUZVlhQWdNZ2hiQWJNYURmemdOZ1FhTmdRYzBhWGdPY1RjWWJYYk1na2g0ZXRhRWExaElkd2JBZEZnSWgrZEVjZ2FrYWxhTGRCYkpmZmJVZWpjWmZLY0hkeGFkZ1ViT2d3aEVnbGRCZXlkOGJNaEplVGg4YktoVWRqY0JmYmhYYUFhdGZZY0VoRGhVZG9mTmd6Z1VidWZBY0NkWmRRaFVhd2VvYTBoRGVGYUVlVWRCZlVlMGJ4Z0hhQWVNZXBjSWR5ZUFob2FVZmpkTWFJZk1mbGdZZU5hQ2Z4aEFhUGdWYkFnZ2VvZU1mbGVrZjJoQWJEYkliUWREZ0FlOGJ6Z1VkRGFVZU5kRmh6Y2tnMmVGY3pjSmZPZUxhUmZOYVNnTWFBZkJoU2hQY2hlSWFKZkplU2V3YlNlWGIxZklkMmRTZWhjOGZYaFZmRGJzZEJjSmVRZGNidmdEYUNoVWMvZkNmbGZJZHdhV2gxZHdmTGZXZEJiQWYxZUtnRGZjYTFmTGFnZUFobWFVY0ZoTWRLYU5jQWN4Z1JhRmZBZFZoTmdNY1Jnd2hEZ0toU2hNYmdoS2dGYUllemdDY0RmSmhXaERjUWJzZFFkRGIxYlFlSWdLZERmSmhaY05nZ2ZBZnljRWVBZXdiUGdNZzFjQWcxYURhUmVjZDVjTmZoZ2NkeWdUYmllMGhUZFViamdBY0FhVWVqZzRoU2dDaFNmVWVzYkVmbGE5ZVNoTmhrZ29hZmJGZDFhUWc3YUFlU2dVZEhlTGR3Z3dmbGdQY3dkcGdTZk1jRmh0ZGNoQ2UxY2dmUWFOZlNiZ2QzY05iU2Q0ZEFhSmNsaEJjVGVDYmpkUWFNZ1VhUmhRZUZjVGRUZUVnY2JBYXlna2dqZ0loQ2RoZ1NlTWN3ZmdleWNWYmdoMGFMZEVlQWI5YlVjQ2JDZGdneWFXY1RhWWVBYk1maGhBZE1iRGd6Y05lUWZOYVFmMGFYZ09kVGNZZlhnTWhrYzRjdGdFYzFnSWh3YUFlRmFJZCthRWNnZGtkbGdMY0JjSmVmaFVhamVaYktlSGh4Z2RnVWdPZ3dmRWJsYUJmeWI4Zk1iSmJUYThmS2hVZWpjQmZiZVhhQWV0ZlloRWVEYVVmb2FOYnpoVWJ1aEFmQ2haaFFjVWN3Y29jMGREY0ZnRWdVZUJhVWEwY3hkSGFBZ01ncGhJZnlkQWNvZFViamFNZElkTWdsZ1lmTmZDZHhiQWFQY1ZkQWdnYW9lTWJsaGtjMmRBZURiSWFRYURoQWU4aHpiVWdEaFVoTmZGY3pha2YyZ0ZjemJKZ09hTGNSZU5mU2VNZ0FlQmZTZlBlaGVJZUphSmVTZHdmU2FYZTFjSWgyYVNiaGI4Y1hhVmdEYnNnQmVKZ1FiY2N2aERlQ2RVaC9jQ2ZsZklmd2NXZTFid2NMY1dhQmVBZTFhS2JEYWNjMWdMYWdlQWNtZVVhRmRNYktmTmFBYnhoUmhGZkFnVmROYU1hUmR3ZURkS2dTZU1mZ2hLZkZjSWd6aENhRGhKY1dnRGZRaHNlUWJEaDFkUWNJYktnRGFKYlphTmRnZUFmeWZFaEFod2JQaE1nMWNBYTFhRGhSZmNkNWZOYWhkY2Z5ZlRkaWQwaFRiVWRqY0FkQWVVYWpnNGRTZENjU2ZVZ3NlRWVsYTlkU2NOZ2tmb2ZmYkZiMWNRaDdlQWNTZFVmSGVMY3dod2hsYVBkd2dwY1NoTWJGZHRnY2FDYTFoZ2JRYU5kU2FnYzNoTmFTYjRjQWhKZWxoQmdUZENnamZRZE1hVWdSZFFmRmNUYVRlRWFjZ0FieWFrYWpiSWVDYWhnU2dNZXdnZ2R5Z1ZjZ2cwZkxlRWhBZDlkVWFDZENmZ2d5ZFdiVGFZZEFiTWhoZUFjTWVEaHpnTmdRZU5jUWIwZ1hlT2ZUYllkWGFNZGtkNGh0aEVoMWhJYXdnQWFGZklhK2dFYmdma2ZsZkxnQmFKZmZnVWdqZFplS2VIZnhoZGFVZ09hd2VFaGxmQmh5YjhnTWdKaFRkOGhLZ1VmamRCZmJjWGNBYXRkWWFFZURlVWJvaE5jemZVYnVjQWdDZVpkUWJVY3dhb2EwZkRiRmdFZFVoQmZVZzBkeGRIZ0FnTWVwYklkeWhBZG9nVWhqZk1kSWdNYmxhWWROZkNjeGRBYVBjVmVBZWdlb2FNZWxna2cyYUFnRGFJaFFoRGVBZjhiemRVZERkVWdOZkZoemVrZjJmRmZ6Y0plT2ZMZ1JhTmdTZk1jQWZCZFNhUGNoYUllSmNKZlNjd2NTY1hlMWZJZTJhU2doZjhoWGFWZkRmc2VCZ0phUWNjZnZnRGZDaFViL2NDaGxhSWJ3YldmMWJ3ZExkV2RCaEFhMWJLY0RhY2gxZExmZ2VBZW1hVWJGZE1nS2dOaEFoeGhSZkZkQWRWYU5iTWNSZndjRGZLZFNmTWZnYktjRmNJZ3pmQ2dEYkpoV2ZEYlFmc2JRYkRiMWRRYkljS2hEZUpiWmNOaGdjQWR5ZkVkQWd3Y1BiTWcxZUFjMWREYlJjY2E1Yk5haGNjY3loVGVpZTBmVGZVYmpiQWRBYlViamg0Y1NlQ2RTZlVkc2FFZWxmOWJTY05ha2ZvYWZhRmUxYlFiN2VBZlNlVWFIZUxmd2h3aGxkUGd3ZXBiU2ZNZUZidGZjY0NjMWFnY1FkTmhTY2diM2hOY1NoNGFBYUpjbGJCZlRoQ2FqY1FoTWVVZVJkUWJGZ1RnVGNFYWNnQWR5YWthamJJaENoaGdTZE1nd2RnZXllVmhnYjBjTGVFYUFlOWhVZENhQ2dnYXliV2dUZllhQWRNZ2hnQWFNZkRmemNOZVFiTmhRYTBnWGdPZVRhWWdYYk1ia2c0ZHRkRWcxZklhd2hBY0ZoSWMrZkVhZ2hrZGxkTGZCZUpmZmRVZWpoWmRLYkhneGJkZVVhT2h3ZUVkbGdCZXlkOGZNZ0poVGI4aEtiVWVqZ0JhYmVYZEFndGNZaEViRGhVYW9oTmF6ZVVhdWFBZUNmWmRRaFVid2FvZTBiRGdGaEVhVWhCYVVnMGZ4Y0hiQWFNYnBmSWd5ZkFkb2NVZWpmTWhJZU1ibGdZYU5jQ2Z4Z0FoUGVWZ0FmZ2VvZ01mbGFrYzJhQWVEZ0lhUWNEYkFlOGN6YlVoRGFVYU5mRmN6Y2toMmNGZXpmSmZPZkxnUmNOYlNoTWdBZEJlU2FQYWhnSWRKaEpkU2J3aFNkWGQxaEljMmRTY2hoOGNYZ1ZjRGFzY0JhSmFRZWNhdmhEYUNhVWMvZ0NkbGFJZXdiV2ExZHdiTGFXZkJiQWgxZUtkRGVjYjFoTGZnZUFlbWhVYkZhTWVLZ05kQWd4ZFJoRmRBYlZiTmFNZFJod2ZEZktkU2NNZGdjS2JGYkllemVDZURnSmRXZ0RkUWdzYVFkRGcxZ1FoSWRLYkRlSmFaZE5lZ2VBYXloRWVBZHdiUGdNZDFiQWIxaERnUmdjYTVoTmNoYWNleWZUaGliMGRUYlVhamRBYkFmVWJqZjRnU2ZDY1NoVWdzYUVkbGY5Z1NmTmJrZW9lZmZGZjFiUWU3Y0FjU2RVY0hnTGR3aHdjbGJQY3dhcGFTaE1jRmZ0YmNoQ2cxZmdhUWZOZ1NoZ2IzZU5lU2M0ZEFoSmZsZUJoVGVDaGpnUWVNZVVmUmRRZ0ZhVGdUYUVlY2NBYnlha2NqZ0ljQ2hoZ1NnTWV3aGdjeWRWZGdkMGJMZ0VlQWU5YVVjQ2dDZ2doeWVXZlRiWWVBZk1laGVBZk1hRGF6ZU5nUWJOY1FkMGVYZk9hVGhZZ1hoTWZrZjRodGRFaDFlSWh3ZkFjRmFJaCtkRWFnZGthbGVMZEJoSmZmY1ViamRaZUtmSGF4ZGRmVWZPZ3dhRWFsZkJleWc4ZE1iSmNUZjhiS2ZVZWphQmNiY1hmQWF0Z1lnRWFEYlVlb2JOaHpiVWV1aEFkQ2daaFFnVWZ3aG9oMGdEZUZjRWVVZUJjVWgwZXhoSGdBZk1icGVJZ3llQWVvaFVnamNNZ0llTWVsZVliTmZDZ3hmQWNQZFZnQWRnZG9hTWhsZWtjMmNBaERnSWdRYkRjQWE4aHpkVWFEZVVjTmNGZ3pha2MyZ0ZkemFKYU9oTGVSZk5nU2dNZkFnQmhTZVBmaGJJaEpnSmNTaHdoU2hYZjFmSWEyY1NlaGI4YVhoVmREZnNoQmNKZlFnY2Z2ZURiQ2JVaC9jQ2JsZElkd2hXZTFod2VMZ1dmQmZBZDFmS2VEZ2NnMWhMYWdlQWdtZVVhRmFNaEtlTmZBZ3hoUmdGYkFjVmJOZE1oUmR3Y0RoS2RTZE1hZ2NLZkZjSWN6ZENiRGNKZVdhRGRRY3NiUWhEZDFlUWNJZ0toRGRKYVpnTmhnYkFheWJFYUFkd2hQYk1lMWZBZzFkRGRSY2NjNWNOZ2hjY2N5aFRjaWYwZ1RkVWFqZ0FlQWFVZmphNGZTY0NlU2JVZnNlRWdsZzllU2JOYmtmb2hmaEZiMWdRYTdnQWhTaFVjSGdMaHdnd2RsZFBid2FwZlNiTWVGZXRkY2hDaDFkZ2VRYk5iU2FnYjNmTmRTZjRkQWJKZ2xiQmVUY0NjamJRZk1kVWNSZ1FhRmhUY1RmRWZjZEFjeWhrZGpiSWdDZ2hlU2hNaHdnZ2Z5ZVZjZ2gwaExnRWdBZDlkVWFDZUNjZ2V5YVdjVGZZaEFmTWhoYkFiTWFEY3pnTmdRZk5mUWIwZ1hjT2dUZlljWGFNZGtmNGd0ZkVmMWFJZndkQWVGYkliK2VFZWdla2dsaExmQmVKZ2ZnVWRqaFpnS2VIZXhmZGhVZU9nd2hFYWxlQmZ5YThhTWZKYlRoOGFLaFVlamhCZ2JiWGFBZHRlWWJFZkRlVWZvaE5iemdVZXVnQWZDZ1pjUWFVYXdjb2YwaERnRmFFZFVnQmVVZTBheGVIZ0FlTWZwY0lheWRBYm9lVWVqZ01lSWdNZGxnWWdOZ0NleGhBaFBjVmZBZmdjb2ZNZmxma2UyY0FnRGRJY1FkRGNBaDhoemFVZERmVWVOZEZhemVrZzJlRmV6Y0pkT2FMZ1JkTmFTYU1mQWdCYVNjUGdoZEllSmRKZVNnd2NTZVhjMWJJaDJhU2JoYzhjWGZWZ0Rjc2ZCZUpkUWVjZ3ZnRGRDZVVlL2hDaGxjSWF3YldiMWJ3ZUxjV2JCY0FnMWVLZkRiY2gxZ0xkZ2FBYW1nVWNGYU1nS2JOZ0FneGFSZkZoQWVWYk5iTWRSYndmRGdLZVNkTWhnYktiRmJJYnpjQ2NEZ0phV2hEZ1Foc2RRZkRoMWJRYklhS2hEYkpmWmJOZ2dkQWN5ZUVnQWJ3aFBlTWMxYUFoMWREYVJmY2Y1Yk5kaGhjaHliVGZpYjBnVGFVZGplQWFBYlVmamE0Z1NoQ2RTZVVic2dFZ2xnOWNTY05oa2ZvZGZlRmUxYVFnN2NBYlNmVWZIYUxjd2V3Z2xlUGV3Z3BnU2ZNaEZodGVjZ0NhMWJnYlFnTmVTaGdoM2ZOZ1NiNGZBZkpkbGdCYlRjQ2FqY1FhTWNVaFJoUWVGYVRjVGNFZWNoQWZ5ZGtnamhJZkNjaGdTY01md2VnYXljVmRnZTBkTGdFZUFnOWNVZENhQ2JnZnljV2RUZ1ljQWVNZmhhQWVNY0RkemdOY1FjTmJRYzBhWGdPZFRoWWFYZ01ja2U0Y3RnRWgxZUlod2ZBY0ZkSWgrZUVmZ2RrZmxnTGJCY0pkZmRVZGpnWmFLaEhheGhkZlVnT2J3ZEVnbGRCZ3liOGhNYUpiVGI4YktmVWdqY0JoYmNYY0FjdGNZZ0VjRGhVZ29iTmJ6YVVldWdBYUNkWmhRYlVhd2ZvZTBoRGVGZkVmVWVCZFVmMGR4YUhmQWFNZXBlSWZ5ZkFob2NVYWpiTWRJZk1obGJZZU5oQ2J4YUFiUGZWY0FlZ2VvZE1ibGRrZDJoQWNEZ0lnUWZEY0FlOGJ6aFVnRGRVZU5lRmF6Z2thMmVGZXpjSmFPZExmUmhOZVNoTWRBZ0JjU2JQZWhjSWRKZEpnU2V3YVNoWGYxaEljMmVTZmhiOGFYZlZmRGZzZEJjSmVRaGNldmVEY0NjVWYvZkNhbGRJZndkV2YxaHdiTGRXaEJoQWYxYkthRGNjZTFnTGFnYkFhbWFVaEZhTWFLZ05kQWJ4ZFJmRmhBY1ZmTmVNZFJhd2VEaEtjU2RNYmdjS2JGaEljemdDZ0RmSmhXZkRnUWdzZFFhRGUxYVFnSWNLZERhSmhaZU5hZ2FBYXlhRWNBZHdiUGJNYTFiQWIxaERhUmZjZzVnTmJoZ2NneWVUZmlmMGhUZVVmamRBZUFoVWZqZjRiU2NDYVNlVWRzY0VhbGY5ZFNkTmFraG9iZmFGYTFoUWY3aEFmU2JVZ0hoTGV3YXdobGVQaHdmcGNTYU1iRmN0Z2NhQ2IxY2diUWhOYVNoZ2gzZE5kU2E0YUFmSmdsZUJoVGdDZGpoUWVNZ1VlUmRRZUZnVGJUZUVmY2VBZHlha2ZqZklkQ2FoZFNiTWZ3YmdieWhWY2diMGJMaEVmQWI5aFVmQ2FDZGdheWVXYlRiWWdBY01haGdBaE1nRGZ6YU5mUWhOZFFoMGZYZU9hVGVZZlhhTWdrZjRidGFFaDFnSWN3aEFmRmNJZStoRWFnYWtobGRMYUJiSmJmZ1VhamRaYUtmSGF4Z2RoVWZPaHdkRWRsZ0JjeWU4ZE1lSmFUYThnS2hVYWpiQmFiZ1hlQWZ0YlljRWVEYVVhb2FOZHplVWN1aEFmQ2JaYlFjVWJ3YW9oMGNEYkZoRWdVY0JoVWEwZHhhSGRBZ01jcGRJYnlmQWdvY1VkamZNZklkTWZsaFlnTmJDZnhmQWJQYVZiQWVnZ29mTWJsZGtoMmJBZ0RlSWhRZkRjQWI4Y3phVWdEYlVkTmZGYnpja2EyYkZjemFKY09hTGhSZE5lU2JNZEFhQmdTZlBlaGZJYkpnSmJTZXdnU2NYZjFoSWEyZlNjaGU4ZlhiVmVEaHNoQmNKYlFmY2J2Z0RhQ2NVZC9kQ2RsYklnd2NXYzFod2NMYVdiQmVBYTFnS2FEYmNiMWRMY2dmQWJtZlVhRmdNaEtkTmNBZHhhUmVGY0FiVmVOY01nUmJ3YkRiS2ZTYU1mZ2NLZ0ZiSWd6Y0NhRGVKZldoRGZRZ3NkUWNEZDFkUWFJZUtnRGdKZ1pkTmNnZkFmeWdFY0Fid2JQaE1kMWRBYzFlRGVSZmNjNWFOYWhnY2F5YlRhaWQwYVRkVWNqZEFnQWZVZWpmNGhTYkNmU2VVYXNiRWZsYzlnU2NOZmtmb2JmYUZjMWNRYjdmQWhTYVViSGRMaHdid2hsZFBid2VwYVNiTWVGZHRkY2NDZjFkZ2dRYU5hU2NnYTNmTmJTYzRkQWFKZGxhQmZUY0NkamdRZE1mVWZSZFFlRmNUZ1RoRWZjaEFoeWZrZGpmSWRDZGhlU2FNYndoZ2F5Y1ZiZ2YwaExmRWFBYTlnVWdDaENjZ2V5ZldlVGhZY0FkTWVoYUFoTWVEZnplTmVRZk5oUWUwZlhjT2JUY1lhWGdNY2tlNGJ0Z0ViMWdJY3dlQWZGaElnK2RFYmdja2FsZUxoQmNKZWZoVWFqY1pmS2dIZnhoZGFVZ09nd2JFZGxmQmR5aDhoTWVKYVRnOGhLZlVmamRCZGJoWGRBY3RoWWNFZ0RmVWFvYk5kemhVZHVnQWVDaFplUWJVZXdlb2MwY0RoRmNFZ1VkQmhVYjBieGNIYUFhTWFwZklneWdBaG9hVWFqZ01oSWRNY2xnWWhOY0NmeGFBZFBlVmhBZWdmb2NNZmxja2EyYUFkRGhJYVFkRGdBZDhmemZVY0RlVWNOaEZiemJrZTJnRmd6YUphT2FMYlJmTmJTYU1hQWRCaFNlUGVoZEllSmhKZVNid2dTZVhmMWdJYzJlU2doYzhiWGNWaERkc2FCY0pjUWJjY3ZkRGZDZ1VlL2FDZ2xkSWF3ZVdlMWV3YUxhV2hCYkFnMWFLZURiY2IxY0xkZ2hBZW1jVWRGaE1oS2JOZkFleGdSZEZiQWZWYk5hTWNSZHdiRGVLZlNjTWNnYUtkRmdJZ3phQ2ZEZ0phV2REZ1Fhc2JRZkRiMWRRYklhS2hEYkpkWmNOY2dmQWN5YUVmQWJ3YlBiTWIxYkFlMWJEZlJkY2Q1Z05naGhjaHlmVGJpYTBiVGRVZWpmQWNBaFViamc0ZlNmQ2JTaFVoc2VFY2xoOWdTZE5oa2NvaGZnRmExZVFoN2hBYlNlVWdIZExnd2R3YmxlUGd3ZHBlU2VNZUZkdGRjZENiMWVnZFFoTmhTZWdjM2NOZVNhNGVBYkpjbGdCaFRiQ2JqYVFlTWdVYlJhUWJGaFRmVGJFZ2NmQWF5aGtkamhJYUNjaGVTZ01id2dnY3loVmZnYzBnTGNFZ0FjOWVVZkNoQ2hnYnlmV2RUYVliQWhNYmhnQWdNaERiemdOYlFlTmFRYTBnWGJPYlRoWWFYZk1oa2I0ZnRiRWUxYklmd2NBYkZlSWMrZEVjZ2hrYWxhTGJCYUplZmRVZGpoWmFLaEhjeGFkY1VmT2N3Y0VlbGNCYXloOGVNYkpmVGU4ZkthVWJqYkJlYmVYY0FjdGVZZkVnRGVVZ29jTmF6YlVjdWRBYkNmWmdRYVVod2hvYjBoRGVGYkVjVWRCYlVhMGV4YkhjQWRNY3BiSWh5Z0Fnb2hVZmpnTWFJaE1lbGVZZk5nQ2V4ZkFiUGVWZUFkZ2dvYU1mbGFrYzJlQWdEYUliUWNEZ0FnOGN6Z1ViRGhVZ05kRmJ6ZWtmMmhGaHplSmVPYkxkUmROZFNkTWFBZEJmU2FQZmhhSWVKaEpkU2R3YVNhWGYxZElkMmJTYmhoOGVYZ1ZlRGNzZkJhSmNRYmNndmFEZ0NlVWEvaENnbGRJY3djV2gxYndhTGNXaEJiQWgxZ0tiRGNjYTFmTGJnY0FnbWhVYUZiTWJLZ05nQWZ4Y1JnRmFBZ1ZmTmdNYVJjd2VEZUtkU2NNZ2dkS2VGZUlmemVDYURlSmNXZERlUWNzZ1FnRGIxY1FmSWNLY0RlSmdaZE5kZ2VBaHllRWZBZXdlUGZNYzFiQWcxY0RmUmhjYjVnTmhoZmNoeWVUYmljMGFUYVVoamRBZ0FjVWNqZzRhU2FDZFNhVWVzY0VmbGM5Z1NoTmVraG9lZmhGaDFlUWI3ZkFkU2ZVYkhlTGF3YndjbGFQYndhcGZTYk1lRmR0ZWNjQ2gxZWdkUWhOYVNhZ2MzY05lU2Q0YkFoSmhsYUJnVGVDZ2pmUWNNYVVnUmFRZ0ZlVGRUZkVnY2hBZXlka2VqZklkQ2RoYVNkTWV3ZWdieWdWYWdlMGNMZ0VkQWI5YVVkQ2hDaGdieWhXaFRiWWFBaE1laGRBaE1iRGF6ZE5oUWROZlFkMGdYYk9hVGdZY1hnTWdrZTRodGRFYTFnSWN3Y0FnRmVJZitoRWdnYmtlbGNMY0JnSmZmZFVhamhaZ0tiSGV4Y2RoVWNPY3diRWhsY0JkeWM4Yk1oSmVUZzhoS2NVaGphQmZiZlhiQWZ0ZFloRWdEaFVjb2JOZ3pkVWJ1ZEFjQ2JaZFFlVWN3Zm9nMGdEYkZmRWFVZEJiVWcwZnhjSGVBYU1jcGRJYnllQWFvYlVnamRNZUlkTWJsaFljTmNDZXhoQWVQZFZiQWNnZm9hTWRsYmtlMmFBY0RmSWhRaERkQWM4ZXpkVWVEYVVlTmFGZXpoa2gyZUZlemFKZE9mTGRSZE5nU2RNZkFiQmVTYVBnaGFJZUpoSmZTY3dnU2VYYTFlSWUyZlNkaGM4ZlhmVmFEZnNiQmJKY1FkY2F2ZERhQ2dVaC9lQ2FsY0lmd2RXZDFmd2dMZldlQmVBaDFoS2ZEaGNnMWRMZ2dnQWNtYlVmRmFNYktlTmZBYXhlUmNGZkFiVmROZk1hUmF3Z0RiS2hTZE1oZ2dLZ0ZmSWZ6aENhRGhKZFdmRGVRZXNiUWdEZjFkUWdJZ0tlRGZKZ1plTmFnZ0FheWJFYUFkd2dQZ01jMWdBYjFiRGhSaGNiNWdOaGhlY2J5YlRnaWQwaFRiVWhqY0FnQWZVYmpoNGdTZENoU2JVY3NoRWdsZDlmU2dOZWthb2FmaEZjMWRRaDdoQWFTZVVoSGNMZXdhd2NsZ1Bkd2ZwYlNnTWFGYXRlY2RDYzFkZ2NRaE5jU2dnYTNmTmZTZzRmQWFKZmxlQmVUZ0NkamhRZU1iVWVSaFFlRmdUY1RoRWRjaEFjeWNraGpnSWZDZmhkU2JNY3dkZ2d5ZlZoZ2QwZ0xiRWRBZTloVWZDY0NiZ2J5Z1dkVGNZZ0FhTWVoZUFkTWZEZnpjTmVRZ05mUWYwZVhkT2FUZFllWGZNaGthNGh0ZUVkMWhJaHdiQWVGY0ljK2FFZmdoa2dsZ0xmQmhKZWZnVWFqYVpnS2hIZnhoZGFVaE9ld2NFZGxlQmZ5ZzhhTWZKaFRmOGVLYlVoamZCZ2JoWGJBYnRnWWdFYURkVWJvaE5nemFVZnVhQWFDY1piUWNVaHdib2gwZURlRmRFY1VjQmVVYjBkeGZIY0FoTWhwZ0lneWVBY29iVWRqYk1iSWZNZmxlWWJOZUNoeGVBZFBkVmdBZ2dob2hNZGxia2UyaEFnRGhJYVFnRGdBZjhiemhVZkRoVWZOZkZlemVrYTJhRmF6Z0pjT2FMZFJiTmdTZE1nQWdCZFNmUGdoZklnSmJKZVNmd2FTZlhoMWVJZjJiU2doYThhWGJWY0Rkc2JCY0pmUWJjYXZhRGNDYlVkL2RDaGxlSWN3ZVdoMWd3aExlV2FCZ0FnMWJLZ0RoY2QxZExiZ2hBY21iVWRGYk1hS2JOYkFjeGRSaEZhQWdWZE5mTWdSZ3doRGhLYVNiTWVnZktjRmdJZ3pkQ2ZEZUpjV2NEaFFjc2VRaERiMWZRY0liS2NEaEpoWmFOZGdhQWd5ZkVoQWR3Z1BjTWMxZEFkMWJEZlJiY2Q1Z05oaGNjZHlnVGJpYjBiVGhVYmpjQWJBZ1VnamY0ZlNjQ2JTZVVnc2dFZGxlOWRTY05na2JvZmZhRmQxZlFoN2dBZlNoVWVIYkxjd2N3ZWxjUGJ3ZXBkU2NNZEZldGZjZUNhMWVnY1FnTmVTaGdiM2ROYVNjNGZBZEplbGRCY1RiQ2ZqZVFjTWZVYlJoUWdGaFRkVGJFZmNjQWh5ZWthamVJYkNiaGRTZk1ld2JnZXlkVmJnaDBiTGNFYkFmOWNVaENlQ2RnZnlkV2VUZVlmQWNNZmhmQWFNZ0RlemhOZ1FjTmhRYjBoWGdPaFRnWWJYZ01ia2M0ZnRlRWExZ0lkd2JBYkZnSWQrYkVoZ2JrYWxmTGRCY0pkZmJVZmpjWmNLZ0hjeGFkaFViT2J3YkVibGRCZXloOGdNZEphVGE4aEtnVWhqZkJmYmNYaEFkdGdZZEVnRGJVZG9hTmV6ZlVmdWhBaENlWmFRZlVld2JvZTBhRGJGZUVlVWRCYlVmMGd4YUhjQWJNZXBmSWh5YkFib2dVY2pmTWdJZE1ibGVZYU5kQ2h4ZEFnUGhWYUFoZ2VvZk1nbGJrZDJiQWJEZUliUWFEZUFnOGd6ZVViRGJVY05jRmJ6Z2tkMmJGaHpjSmVPZExlUmZOZ1NkTWJBY0JoU2JQZWhlSWNKZEphU2R3Z1NlWGYxZ0ljMmdTZGhoOGhYZFZmRGJzZ0JoSmJRY2NjdmZEZ0NnVWcvZ0NkbGZJYXdkV2UxZXdlTGVXY0JlQWExY0thRGVjaDFkTGFnYkFjbWZVY0ZlTWVLZ05hQWF4aFJiRmVBYVZmTmdNZlJkd2REZ0thU2RNZmdoS2hGYklhemJDaERiSmhXZkRkUWhzYVFhRGIxaFFoSWJLZERlSmRaZU5nZ2FBZnliRWhBYXdnUGhNYjFnQWIxaERoUmdjYzVlTmNoYmNoeWJUZ2llMGJUZVVlamRBZEFiVWZqYTRmU2FDYVNoVWZzZUVmbGI5Z1NoTmVrZG9kZmZGZzFjUWE3ZEFjU2ZVZkhjTGd3ZndlbGFQZXdlcGVTaE1oRmZ0aGNlQ2gxZ2dmUWdOaFNnZ2IzZk5nU2M0ZEFnSmNsZUJoVGRDYmpnUWFNZ1VjUmRRYkZoVGJUaEVkY2JBYnlna2FqYkllQ2JoaFNlTWN3ZWdoeWNWaGdoMGdMZEVnQWQ5ZVVlQ2hDaGdjeWFXYlRmWWZBYk1kaGdBZk1jRGR6Zk5nUWhOZ1FnMGRYY09oVGdZZlhhTWhrYzRjdGJFYjFkSWR3ZEFmRmdJaCtnRWFnZ2tmbGVMaEJnSmNmZlVnamVaaEtnSGR4Y2RlVWhPaHdmRWNsZUJmeWU4Yk1nSmFUZThkS2FVY2pnQmNiaFhiQWF0aFliRWJEY1Vmb2hOYXpoVWV1ZkFkQ2haZlFkVWF3aG9kMGdEZ0ZoRWRVaEJjVWgwZXhlSGhBZk1jcGZJY3liQWNvYlVjamdNZ0lmTWZsZVliTmhDYXhjQWdQZVZjQWVnZG9kTWRsaGtoMmdBZ0RjSWRRZkRkQWc4Z3plVWJEZFVkTmZGZnpia2gyZUZkemZKY09lTGhSZE5oU2JNY0FmQmhTZ1BnaGVJZUphSmFTZXdiU2dYZDFnSWcyYVNoaGE4YVhlVmhEZ3NnQmhKY1FiY2V2ZkRkQ2hVYS9nQ2dsaElhd2ZXYjFnd2VMZVdkQmRBZTFoS2ZEYWNoMWdMZGdjQWVtZlVmRmRNaEthTmRBYXhoUmZGZUFkVmJOYk1jUmV3Z0RjS2JTZU1mZ2dLZUZjSWF6Z0NkRGFKYVdoRGZRYXNnUWVEZjFkUWVJZEthRGZKZlphTmZnY0FieWFFY0Fhd2FQZE1hMWNBYjFhRGhSZWNjNWJOZWhoY2F5ZVRkaWMwaFRjVWFqZ0FlQWdVYmpmNGZTYkNoU2FVYnNjRWVsaDlmU2dOaGtlb2NmYUZiMWdRaDdjQWJTZFVmSGdMYndnd2RsY1BiMGRrZlBhTmNsYkZoU2FEZjFhZ2FhZ0FkQ2hZYi9lSWdHaEVhNWFLZUVlWmNYY0FjamFBZ1lmRWdFYjlnRWhUYkRhd2VWYkFmQ2c0YXVmRWRpZEZoZGhJZVVlQWc4ZFFhQWdrYURnRmhCZXNkT2daZUNoNGU0aFZoemRJZEFmT2RDZFVhQ2hCYnlhWWhmYlBnQmZ3ZFVmTmZqY1VjRWhkYUJhSmdyZENiVWJsZHFjYmZEZWtkN2VIYkFhRWMzYlBlbGdOYU5kWGdCaDFnU2FQZ3hkZGFjZktkVWVkZTVnUWZTZDVjRmRiYW5jTmFoaEZoSGZzaGRnZGdBZ3NoWmJEaHplc2I3YWRiamZzZ3VhRWRDZ0loV2dWZVFmTWNoZEhobGJVZ2NiUmZGZDhjNGRFZ3hlRmJ2ZEpjQ2NjaDdlR2hIZUlkRmdQZFZjOGNiaFRlUWZVaGVkV2draDRnOWhQZkZkRWMrZUJlaWJkaExmWWhFZzVoL2JPZDNkTmRHaFVkV2NsZCtmVmJuZVJobWJiaEJmOGdVZ09oQWd0ZURmS2doZ1lnY2NOY3liOGJYY0ZoemVsZHdmQWdWYWxiRWRIYUhkcGRIaEVjd2NrZHZiSGNpaEVkdmNEaGtnWmh4Y1JiRmFJaFljU2MxZ1lja2dJY2pjY2M5YVBiRWJZY21iUmhGZ2RlQWhkZVFhTmVFZFZoUmJjYkxnUGFoYVVkV2diZ3pjVWFwZE9oMGhBZTZhVGhqZXBiRWVRZm1oZGhSZFFiemE5Yk9lWWIzZHRlWWFhZDJodGhlZlhma2ZVZkdhSWVVZlVlamVIZDBkdGgzYWZkeGNFaDlkV2J5ZE1jSGhWY25oOGRGYVhnRGJWY2NmSGh5YTBidmZBaFVndGZXZE1ld2RRYVRlQmZSaDhoaWdIZXlod2RBZlBmUWZKYk9lZWVFZk5iU2hKYkZoTmVlY0dhVmdBZlpkT2JtZzViK2JKZzJhTmhHZE5nUmQ4Z1NhRmMxZjlmS2FFZUFiWWNXYVhiamdWY3dnUWdtaDloaWFaZG5nWWhVZ2VlZ2drZC9oWGF3YzRhTWRIZFRhMWVkY0JhemRwaDZhVmR5YUFhRWZPYmhhUWFZaFFkQWhwZVRkSmZnZm9jWGhNY0dnTmdFYmRmQmNKYnJoQWVCaHhiNGhTZ0ZkdGF1Z1JmMGFaZE9jYWdsaE1oWmJFZTJjb2hMYVdkeGJCaEhkTmNBY1Fjd2ZDYkNiRWNFZ1pkbmRsaFdkQ2FYZ0ZiSmRSY0JoMWJjZUdnVGdKY3VlTWFqYllhcGhEaHlkbGNUZEVoa2dwZnpkU2RsaFFkWGVBZGtnSWIrZUhmMGV3aHVkTGZ5ZUpiRGdGZUhnSmVPZmNhd2Y5aE1mQ2RSZ1FlUGdYYkFlQWZzYmZlR2ZNYU5iVGRYYVFkRGdRaDJoUmgxZUVmWGFOY01oU2czY2hleWRHZlRnWmFGYUxmaGZGYkFoY2gwY1ljT2haZlZoTWdiYlBjVGRvZldoVmhsZlZjd2dUZ2dlRWdHaFhkU2ZnZlRjTmMyaHRldWVTZm1oUmg1ZVZkQmVSaDVkV2VFZlVjZGRWaGdlUWhnZVBmWGRnY0xiRmJ5YjVkbmNDaHhlSWNlZWZnVWVNZFpoZWdFYVFhTGZjZEZkcGRZZ2JnMmhvZHlkWmUyZ3dlS2hKaG5mTWZOZ1RlQmc5ZlpiUWRCZXhlVmhRZHlia2hSZmVmQmNVZThjR2dCYmxkQ2FkY1ZnY2NtZkFhaGJJZ3NhT2RSYWthNmZEZzJoTmdiZkZnQ2VwZnNmRWgzYmdiQmdDZWpmQWcvZEFiVmNjZ1RjZWhFaDBhTWdHY0ZmRWZ1YURjaWJzaFBkYmNrZUlod2JjY0VkdGZQZFdkeGIwY2RkVGFSZWtlUWVJZlNiQWUxYUpneWZZZkphS2NSZFplQWZSZERhQmJEZkVmQWNsaHVjQ2UzaEJlYWRRaG1iOWdpZkxoeWE4Y1VoZWRnYmNkSWZWaFRoRmRFZ1VhUmZ0aFFjR2ZqaHdhbWdWZW5oQWhJY0RoeGhRYjNoUWVEYkJnSmhJYndhTWFEaExjQ2FOZ05mWGhnYTlocmFVZWhhUmZ4YVJha2JVZTVjQWhVYjhhcmJhY2tnNGNaZ0diemJsaHdnSGFDYnNhU2NaYTBiY2IvZVFhU2NkYVFkWmVEYXhoSGJGY0RiMGhIYkhkVWN3ZElhV2NuZFFmcmdMY2loTWJnY0ZlRGVOZUZlQ2VFY3djdWVGYXhoQWVQaFRoUmhCYWFkV2ZrYkphdmFZZ21kWmJwaFJoamRjZmFmSmNrZElmQ2NUZ1FmVWJ5Z1VmRGdOYW5jTmcxZWtoOGVEZlhjd2FlZFJmQWRzZ3RjUWVUZ3diZWNCYVNkdGI4Y1ZoamNzY0RnYWN4ZTBhYWZOaEJhNWNEZE5md2VFaGJiTmcyZFpkVGZTYnhkcGY4Y0NiMWRFaFpoSGdEY1piSGhlaFViRmh2ZVdmbWQxYzFiU2MxaHRoL2ZXZEVkVWhkY1ZmZ2NRaGdmUGFXaDFhWmJiZjBhWmFuZUZia2Q5Zm1kZGJVY29nUWZVZ2hmSmZLZklnbGhvZExlYmYzYjlmbWhNZGtkbGNwZ1piSGRNYVFoVGFFYjBhRGJEaEVlRWJiaE9memVvY1lnZWJHaHRiMGZVYlVocGNPYmRhUmdGYzdoSGhsYThjMWdjZUVkdGUwZldhMmNKYmVhUGZuYUZhR2hFYjNhaGhUYVRlMmJ3ZTRkWGdWZW9jVGZiZFFlc2JRaFhkeGI1YlFiUmMyZ1JlQmZiZmthcGhraGNoUmRrZGFjTmdSYTBmQWFUZlZnOGZEYk9oaWcwZWlhT2dpZEFoSWNaZXhoNWhHYlFhSGNVZERmSGdGZklmQmZBYW5lQWdCYmFmR2c5ZGloWmJtaGtjVWVjZ2tiNWZ6aFFja2FJaENjV2RSYzBlWmFUZ2lhQmM5ZkdkQ2V3ZGRkWGNsYkZhS2FUYm5iVWFSYmNnMGh4ZFJiZWhIZ0FjNWVOY2thVWd1Y0VkVWFCYi9lQWVsZFloK2JHYWdkRWhoZ0djZ2ZGaFdkUWN6Z1ZkWmNEZ1FjOGRhZ0xia2J0ZmtlQ2hHYUpoS2FQaDFmTmVMY0ZnSGJFZ2RkSGNVYzBkWmRWY25kUmZ1ZGRhbmVNYXNiQ2JTYWxoUWRXYXdic2RnZUdiRmFFZVFoQ2FFZjVlcWJXY2tmTmIrY2Jja2N4Z3BnRmdIYkpmT2djZXhlQmRNZlRjVmZGaEplRmdVZzRhc2RPY2thMGI5ZkJmQ2ZZZVFhQ2FBY0lnd2dDZTNkTmhOY1FjWGFSaGFlVmVuZlFjUGZhYjFiSWhVZWNlVWRZZlRiZWJGZ05iUGhJaHliOGVIYkFieGRNZTFkQmMzZE5nV2NFYm5kcGVIZ1piRWhGYnVhU2ZtZlJiNWNGaGhoMWFxZk5ieGExYU5mR2VWY1plMGNiYWljdGQ2YVllMmN4ZG5iRmJoZkpkTWJkZVVjb2dZYkFlRWRwaEZlY2ZFZ2RjQ2ZLY1RoY2VvaEtma2ZBZDdjQWhUZjBhUWRSZUJibGJZYlNlVWM1YWthYWFYYlFlWWVjYkVnRmgwYlVmVWJvZ1loTmVFYU5jemhCZ1ZiRmRsY1dmbGVaYTBiRGEyYXRoU2VGZkhkRmVHY0VmM2hnZ0hmVGgyYkplc2RVYzBmMGFkZkRiM2ZRZWNlQmRYZjhiMWhBYnpmRWZOYktkMmNCZ2tkZWVVZ3NhVWRjZFJhMGVkZlRnUmNsZFdnZGZHZzVlcGZjYXlja2dUY0tiVmFWYUdlQmNUY29jRWNFYkZjcGNOaENkeWZ0ZndiUWNtZjljaWVaY21ka2VVY2Nia2c1ZHpkRWhFYnhkTmZVZ1Vha2RWZFRmamFzY3hiVGdDZlVnVGRPYWxoRWRlaE5iWGdkYVZoTmNnYW9mUWNMY1Rhd2RDZWRkbmdKZndlZWJCaFJleGFSaGhnTmM0YlVjMGg5Z2tnYWFsYU1oWmZFYjNoQWVMY0JnSGh3ZlNoZWdrZGRha2FRYVdkNWFLZlpjSGJsZkxoRmNIZEVlSGNIYVFhdGJNYkdmRGJjZTZlUGd6ZHdiaGRSaG1hOGJmZkVoaGhkZGZjU2RoYUJkU2dSYkFhdGR3Y1dia2JKY3ZjWWVtZlpicGhGYUhhSmRPY2NiMGdJYUpnR2ZRZ1FoYmhXZTBhNGM5aGJhemJKZndoUWVYYlJhUmVTZGtkNWMxaEVnWGhOZE1lVWFYZmhkd2RWYWlka2JVYVFiVmhJZ1VjY2FVZVlhVGFlY0ZmTmZQY05iaWg4YkhnVGRFYUVoK2dDYndjdGFZZVZnbmNJaE9kYWNFY0Znc2hDaDJmWmIxZlNhMWYxZTRoRWVSYTBmRWNBaG5meGcwaGJlbmJaZ3pmYmcwZFlhNmJIYnhiNWFtZWRiVWJvZ1FmVWRrYVFnTGVlZ0FiaGVNZkloR2hKYTdjYWhWZEllbmFBZ0RhQmZFZEJiUWZJYWZkU2VSZDBlYWJaZlhlUmJLY2VmVWVFaHZhZWYwZnBhT2hkaFJjRmJ6ZVRmRmNGZTRiSWFoYU1mZ2VXZ2poa2VjY0ZmQmQ0Y0VkV2FUZDBhUWdHYTJib2M2YkFnVmhaZEhiUGQxYzhmQWRCZmxlZGUwaERkeWhVaFNhQWZSZTBncWRDY1JnbGhiZUlkVmFoZFBhR2hVZUJiWWROaHliOGU2YlBiMmhjZlNoYWZ4YVplQWRSZldkNWZnZUVjRmhKZUVmQ2gzaEJkYWhIZjJhWmF1Y1RmR2ZrZVVkY2FraDVjemZFZkVoUWFmZlhneGFrZFZjVWUyYmxnMmNHYW5ibGROYlhibGNGYUtjVGVuYVVlUmJjZHhhNWZaZmNkQ2VKZFloSmR3aDlkMmRVaGdkWmc0YVRhemJsaDRmVWcwaDlma2FZZDBlZ2N6ZkVjM2hCYVdhVWNGYjVjcGZVZEViZGJrZ1FjV2E0Zk1kTWhUZWNkSWdRYURnaGRTY1ViMGIwY1JkQWduYWhndWhKZkhiOWV2ZkRkMmU0YVdhU2dXaFpmMWVTY2hiQmFTZ1JoQWh0YXlhRGJ4ZkVocWFZYWphVWM5YlJkamJzYU5mSmZ4YkphWGNaYzFnRmVKZkZhVWE1ZHBkZGhCaEFmMmVGZ0Rob2JTZEhlZ2FjYzZlWGIzYU5kRWdCZFhnRmN3ZURlVmg0YVBiYWMxaElnVWVjaFVhWWNUY2VlQmdVYWFjS2NpYWtjSGZVaEZnd2IrYUNjeGV4ZWVnR2UzYW9jY2hUZGthRmh1ZlNhbWZSaDViU2R4ZlJkeGdIZ1JmMGRaYlNld2E5aDBjTmdWZ3hiemhiYzBhWmFuZUZlaGRKaE1nZGFVaG9lUWFVZmtkUmVkZk1oUWhoZENiT2UyZUphN2dhZVZhb2QzZkdkWGVOZWxlQmRRY01hRmNVYVhkUWZjYU9lemZWYkJkZWJGZkJmOWNTY21jQmRPY2RkUmNGaHpnVGFGZ0ZjNGRjY0ZkWmMwZERjMmNzYkFhVWRTZ1VjVGJRZ1RlWmFUZlJhMGQ1aHFjVWh4ZWtkVGFjYUFidGRaYlZhaGFKZTZlUmYyZ1JiQmhiZ2thSWZ3ZWRhemVSZ3JhSWZVZzloU2VHaFZlWWVwYUNlMmg1ZXJoY2R6ZFJjc2RaY3hjWWdTY1RkSGZWZUtkRWJGZUpoRWZDZzNjQmNhZlFnbWc5ZGlnWmhoZ1pkcmFJYmhjd2g4YlJiQWJNZnlnTGVsaE1lVmJPYnloQWg2Z1RiR2FnZmdiSmNnZU1lTGRGYjNidGJCZUllUWNNaEZhTmN5Y1FiUGdKY0VkcGhuYmVjQmFSZHhiUmFoaE5iNGZVYzBoOWFrYmFnbGFNZVpkRWYzZkFlTGFXY1ZlWmhVZE5mUWJoZytoUWNTZmdoZmVLaGpob2FmZFhoVGM1ZFRkSGFVZ1VmUWRWY2lhOWFFY2RhbmZOaHZmUmNtY2NoV2FFY2toeGIxZ1NjaGRCZlNiUmVBZ3Rid2FXZ2thSmV2YU1jQ2FNZzlnUWJTZkFlQWJjYXdnUmdlZlZobmJ0YkpjRmFVZDVkcGdkZkJmaGJ3ZFFhWGVSZVJnU2RrZzVkMWFFY1hjTmNNY0RkSGhSZGFmVmNuZFFkUGZhYzFhSWZVZGNnVWFZYlRlZWFGYk5mUGVaY0dhb2dPZUVnQmc5Y2FiQ2cxYmxlV2dFY25ncGdIZVplRWFGaHViU2VtZ1JlNWVTZ3hjUmZsZkRheGcxZVFhQmRFZ3RiMGFPYm5mZ2UxYklnQWNsZHZkSGh4ZUpkS2RjZzJjQWVRZlVoa2FRYUxnY2VGaHBoQ2RiaDJlSmhtZGFiUmFSZnlhVGVuYU1kUWdUY2dhc2ZFYUJoMWFZZmFmSWNEY3RoV2JjZmthRmVwaFRiRWNvaGFjTGRFY0ViMmJBYXhiZGM0aEpmRmRnZm5iV2VpaGtiVGJSYWlkTWFIZ1NhbmVoZ1ZoU2RVaDVncWVVZHhla2FUYWNlQWV0YVphVmZoZkpoNmFSYTJkUmJCZmJja2ZwY2tnYWJVZnNhSmViYUFoQWRkaEdmUmZjZ0ZnSWZTZHdnM2ZJYlRjMGRIY1BjaGY0ZkRkUWZIaFZoYmdHZVZmd2FHYVVhaWdRZmZmTGdpZm9lc2dJZFRoMWJjaFdhRWc1Z3pjRWFFYnhmTmdVZlVia2NWYlRobWdsZDBmR2ZIY2xjYWRYZWxhRmdLYVRnbmVVYVJmY2IwaHhmUmNlZUhlQWFMYmRlRWh3ZHFhQmdsY2NlNWFSZGhkc2RxaFdha2Q4Zy9lUWdGYk1hWmFFaDNkQWVMYVdjVmZZYlNlZWNrZWRna2dRZVRjd2hQZE1kQ2F3ZVpnV2VuYkVhY2VEYkZlWWR6ZlZkbmVSYnVnZGNuaE5idmVSZW1nY2JXZUVnaGVGaGZkU2ZoZkJkU2hSZUFndGZ3Zldka2NJZnljU2RHYlphcGJGYkhiSmZPZmNheGJCZk1oQ2F3ZFFlSGRWYWhnb2dnZE9lMWZaYndjRGJuZHhiWWJTYmhkVmRmaEVjWGNOYU1oVWNYZmhid2NWZm5lUWZQYmFkd2RCZFJiSmhSaE5iQmdOY2xkTWFCY2FmaGY0ZXFnYWdYYVlmVWVkY0RmZ2drZVllQmJzYitkR2V6ZUljYmNPYWhoUWJXaE9oV2dCZnhlQWVoYTFkZmNDZUVhSmNqY2VkbWc1aGdkZWdWZ0pkd2hGYmdnaGFNZFphRmZvZUhhUWJWZ01kZmdZaFVlSmRRZmZoSGFsZE1jYWJSZVJieWVUYm5nTWZRaFRmRWEwZ01kWWh4ZFZoT2JhYlhnUWJZZ2NkRWdGZzBoRmN4ZThhQWJOZGtjVWM2Y0FjeGU5ZDRnT2NGZTRlZ2dBZzJoc2NBZ0hnWGFFZmRjT2ZYZWhkVGJUZjJmUmFxZFVheGRrY1RnY2RBZ3NmUWRFZkJhSmd5aENjR2d4YUloYmNsZFpka2ZLZTBoSWNVYUpjVmdWZFBhQWdrYTVkV2RPZGljc2VoYmNheGQwY0hiS2ZWZEZjWGNLZlNiY2RZY1hkd2RCYU1lQ2NSZGthVWVGYkNjNGV1YkxmeWQwZFVoSmJoYWNmamNWYlFoaGZOZEViQmR0ZEhjRGN6Y0JlMGJWYkRjVWNQY01nd2JVY0NkVGJIYndhS2NXZFVneGJSZWVnSGJCaFdiZGJBaDllcmZVaGhnUWhqaEFmMGJjZXRhQWRRY0Zia2FZZG5ha2JaZUVkM2RBYkxkV2dWZ1lnU2VlYWthZGJrZFFlV2c0YUVkYWNnZzBheWdaaEJjUmg1aFliaWJ4YXJoSmdCZFVhWGdDY1FhQWNhZU5iaGdkZjVkWWFEZWhlZmVTaGhnQmdTZlJkQWF0ZHdhV2hrZUpjdmRZZ21oWmZwY0ZjSGhKY1JoY2V4ZGhlRWVHYlZlRmJVZEZnUWdBYnNjSWZ4ZmdkRmhDaERnb2FGZFVoaWQ4Ym5iUWN6ZUlnVmZXZlNhcGE1ZVhmM2hnZ1BhWWN3YVlkYWZEZmpibGFEY0tlaGZ3YWJkS2R4ZlVhc2JHZVFhNWN3aFJoVmNjZEdlUWhEYVVnVGhLZHhiVWIzZ0dnaWRGZHdnUWFqZjVkeGFIZVJjMWZOZUdlVmVaZTBiYmFuZFpiemRiZzBoWmduZkZlZ2RoaE1jZmJRY1JjRmJIZGdmZ2VMZmJiVWVkZmZoYmZ6YVpjbWhiZXhmSmd5ZVJkaWhjYVFjVWVVZjBjZmFEYkVnSmVPYkpiM2J4Z0toZWRVY2hoNGZVaFVlSWNhYWVmMWgwYTJoQWVoZVloc2FPY0ZkWmVwYkRlemVsYWJhSGJYZzFkc2RFYjNlaGhUYVRoMmhSY3FkVWh4ZWtjVGFjZUFidGRaZEFoamNoZjZnUmcyZFJlQmRiYWthcGdrZmVnVWhzZlVlZWFBYVlmM2ZUYVJobGdXZGRjR2E1ZDJlY2gyZDhnYmZUYVJlWWVTZ1RiSGNWYktoRWVGZUpnRWhUZlNoVWZVaEFnVGZzZ3JoS2NTY2NnVWhQZkVnWWduZ0hnRWV3YWZlWGJVZ2xlY2dSaDJia2R2Y01ibmVCZ0JlZGRGZkZjS2hUaG5nVWNSZ2NmMGJ3ZFlmUGZuYkJiZWRkYVFnY2hsZlhoR2RBYUlmTmFuY1llY2JMZ0NjNGRXZUdnRGNKYWdhYmdBYU5oK2ZLYVNoWmI5aENhRGhOYmtlSGZUY0pnS2FNYkRhRWJDZVJiM2FGaFVjVWR4YzVnTmRGZXpjb2V0Z01kemN3ZXBmUmNpYWthZmNHZjJkWmcxYVNhaGRCZlNiUmZBYXRod2JXZGtjSmJ2Z1libWdZZjdnVWhTYVljYmRJYlZnNWRNY0FleGNRZmVlRmVRZ0JhaGdJY0JiUmN3YUVkM2VoYlJmQWcwZ2RjdWRPaDNmTmJNaFVmWGhoZXdhVmhuZlFmUGdhYTFhSmFkYk5jMGJZZmJhZWZoZDBoYWZLZlNnZ2VXZVNoeGVGZ3djRmFrYVJlV2NSYmlmTWVYaEllUWI0YW9kU2JqZEJld2RTYzBnOWZiYkhmUmMxZk5lR2NWY1phMGhiZ25oWmJ6Z2JlMGJaYm5iWGIxZVJiTWhmY1VmaGNEY0JoaGZaYkNmUGNoZTFlQWZiYzNnOWQ3Z2FiVWVBY3JnSGVqZVpiZmVDYmtnMGJEZVFkRGQ5YU9nYWFYaFFnWWhjaEVhRmYwYlVjVWJwZU9mZGNSYkZjemVUY0FmVWF3Z0lnaGJrZ2plRGV5YVVkWGNRYTNmRWJqZVFmU2FvY2NjSGhXaHhkQWNVaHhja2hUYWNnQWh0YVpoVmZoaEphNmRSaDJjUmVCZWJoa2hwZWtmZWJVZmxoOWhOYnhjMWNZY0FjMWhvY1pkTWRDaGNnNGNOZ0dmOGhQZk5oQmNaaEJmSGVEZ0FkSmhXZFJoUWVOZFRjamRSZWFhRmdpZ2NobmVLZ0djbGZBZk9nZ2J0ZHpnVmVnZlVoZmVBZWhjMGZWYkRmemJzaHpmVGVUZTBiRWdPY2dlVmRLaEFkeWJCZUNmSmUwY3dmVGFQY1hlQWVYZWRlRmN3YS9hQWVGaDBkL2NBZ1JhRmRTZlViMGU5aGtjYWFsZU1mWmFFZTNjQWhMY1djVmZZZlNnZWhraGRldGVXY2tlUmhLYlphSGZsaExkRmNIYUVlZGNIYlVoMGFaYlZobmdRYjhoTWN5Z2NoNmNGZENha2JXaFZnRWRRZ2hiQWVsYWtmQmdTZ0Flc2JrYVVlMWhsZkZkWWdtY1pmcGJGZkhjSmFPZ2NheGdCYk1oVGdRZXhjamNGYlVhNWZwaGRoQmZoZndnUWRYY1JoUmhTZWhhd2N3Z1JlU2RZY2VjSGEzZ2dmamVYZ2ljQmJIaElmZ2RFZllnY2JSY0lkZmhlYkFnRmJEZlpoQ2ROaGFjQWZqYWxhd2ZDYzFmbGZXYUVkbmJwZEhkWmZCYXhhRWJTZm1nUmc1ZlNkeGRSaHhoSGVSZDBmTGFUZkJlZ2EzaE9hamI4ZjhiSWFVYlloMGJIY2tmWmFBZ2RkUmVnZWNiVWJnZzBnSGRjYUJhOWVMaGJhemZsZE1iYWJSZVJleWZUZW5lTWFRZlRhRWcxZVJoU2FWZXdnSWRhZ1hid2VhYlBkaGJRYTVhRWN3YjhjY2dkZXhiRmJ1ZVVoVmVFZnNoS2NRY1lmeGhRY0NiMWZTYVJlbmhoZXNlRWUzYmhkVGRUZjJnUmdxZlVheGZrZ1RkY2hBZHRkWmNBZWxlb2dvZENmRGdOZUJiSWVBaDhmemJlZVRkOWVOYUliVmNoZDRkSGQwaHNkWmFKYm1mWmJ4ZGNlVGJrZEhiS2MwZE5nWGZUZW5iVWFMZFFiaGhVY1JjUmNqYVVoVWZGYm1hOGJ2YU1oemZwYkFlY2JnZ0FlOGNSaEVmd2RQYkZjRWNsYlVjVGVpZ2NnaGdWaFRoSWNFZkpobGRaYkRoVmRWZThoUmJjYjBjeGJSZ2VjSGVCZFdkZGFBZDlkcmhBZEZlRWdsZkVoMGhFYjJmVWYwYzBmeGFKYUJoZGdjYVZkVGZsY0ZnSGJCZklnUWJlY2tnWmg1aFFoVGZvYlRiTmdEZHdnRWZVYW5oRmE4Y1RkeGY5YVlnRGF4Y1ljN2NNYURiVWZxZkZhR2RjYlFjRmVFY3dobmZTY2xna2VjZEZjMWI4aHhlRmRBZEVicWJMY1NoQmJwaGRlU2dBZGNkTWhrZWtldWhHYUJoY2VQZlVjQmF4YURnZGFCZmhod2JRZlhiUmFSZVNna2Q1ZTFhRWhYYU5iTWVUZG5hZ2FnYlhoaWRBZ0RjYWN3aEFiWWdjY1FhOGRmZmVlQmdaYUdnVGRtaHBkVGdHZVJkTmJ3ZENmMWJsZVdmRWduZ3BnSGVaaEZodGd1YVNnRGJjZnRnR2dWYzBiL2RXZmhmOWVOY0JlRWd0YjBnT2hpaDhnamdLZ2dma2FoZUZha2NCY21kZGFVZ29jUWdVZGtmUWJMYmNiRmZwZENoYmUyZkpmbWJkYWhjUWIrZlJkaWVjY2NmVGhCZTljZGdTZVZleGdIaFFhM2ZRaFloY2dFZkZlMGhVY1VlcGVPZGRnUmZGZHplVGhFaHRlNGJQYlZlNGhnYkFjMmJzZ0FlSGZXZHBkc2NFZzNjaGdUZFRnMmVSZXFoVWF4ZGxiT2ZXaGdidGdaZ1ZiaGdKYTZnUmYyZFJiQmZLZEJkOGdxZE9haGM5Z2RjUGFsZU1oZGFEYUJmRWRDYmZmV2I0ZHRlV2NXZzljR2FaYXhjWWRTZ1RmSGdWaEtjRWNGZ0liTmVUZVhiQmVTZVFoQ2NFYzNiS2d5aHRkUmVJaEVmeGh6YkVoVmRGZU5jQmJSZUJjRmRDZHloWWJ5Z0dkQ2NSZ0liWGdsZUZlS2VUZW5lVWFSZWNhMGV4YVJhZWRIY0JiV2FkZUZlc2hqZUFiRmVzaG1kUmJsZzBjOWVCZkVoOGhRYU1kd2ZOZWNiZGdpZkpnWmVGY2doUWFhY2ZiVWVVYTNnQ2JEY1FnUGFaYm5ha2RLaFJhamFaZUlhVWFBYmhjWGhBZG5hUWZqZEljeWNBYTdkUmRpZFZjVGFFY2dhMWYxZkJkRWdVY2ZmQmVraDRhaWNYZFVodGEwYVNoR2ZaY3BiRmFIaEphT2JjZ3hnQmVNY1RkVmNFZEFoVWUwZjVmaGVaZUJoaGR1ZVFkU2dCZllnWWFFYzVnMWVFYlhoTmdNZ1VjWGdoY3dlVmJuYVFkUGRhY3dhWmhjYUljd2FsY0VmZWdCYjBjS2NNYjJhb2NoZldhRmgwYjNoVGRqZXdnRWJRY0RoVWRWYWJiRWZaY3NnR2NTYzBjamdEZ2hnWmF4YlhjRWU4aEtjVGJCZHNieGhJZUNlSmR6ZUloaGJNZTBlUWdoaEloQ2dPZ2hhNGJRYUVlQWNFY0xmUGVoaDhkRmVMY2phWWF2YlBkMWRGZDFlUmEyYmdhNmFUZ0VkMWFSY1NoUmhWZE9jYWhYY1JkRmRXYmtoRmQwZVVkVWFwYU9lZGRSYkZhemFDYmdmUWcyZU1nd2FJZzloUWZDaFZlU2JRY1hja2RTYUhlM2FnYUJjUWYyZlFnamhYYnhobGZXYWVmUWZzY0NoZmRCY0plNmNSZjJnUmFCaGJla2VwY2tmZWhVZXRhR2ROZUVjbGdJaEhiMWJkYldiZmNFZ1JoMmFjZDJjOWRHZVpleGdZY1NnVGdIZlZjS2dFYkZnSWhGZkFneWNKZlRlVGRrZFZmaWNaYm1ma2hVaGNma2Y1ZnpnRWdFZHhjTmVVY1Vka2ZGYlRkbmNkZnBjR2JDZkplcmFkYUZhRmNLZlRmbmRVZFJkY2YwZXhiUmNlZEhiQmhXYWRlQWU5YzBkVWNsZXhhNWdFYmhhOWY0YkFkVWFaZk9nYWVsZE1iWmVFZzNhQWFMZVdoVmRZZ1NnZWVrZmRoa2ZRZVdiNWRRZ1plQ2g4ZEVkWGJUYlViZGhEZ1VmMGVZZ1NjMmZsZnVkUGgxYmxmdmVSaG1mY2dXYkVia2d4ZDFkU2NoZEJmU2ZSY0FidGd3ZFdmbGMxYnZoWWJEZ1VoOWNSYmphc2VBYU5oQmFKYk1oVWJFZXhkSmRRYVJkY2I1Y01oVmJjZTJlUWZUZEZlN2VTYmtnNWUxYUVjWGZOZ01jVWJYZGhmd2hWYW5mUWNQZmFoMWJJY1VmY2RWYmtjVGFNaEZjc2ZiY2FiR2dvYkJoRWdCZzBmMmZRaGhmVWJhZ0dnamhOZUxnWmhBZ1JibmJZZEdoUmY1ZFNheGdSZ3hkSGdSZjFmTmJHaFZoWmEwZ2JjbmNaYnpoYmUwZlphOWVGZWxmcGJFZ0liVWNZZlFhQWVFYzBnRmJOZ2hnTWZPZ0lnMmZvYnZjWWREYTVleWRUZG5hTWNRZVRiRWYxZlJnU2ZSZ1ZlT2NhZFhnUWJZaGNlRmN0aDBhR2dVZkljYWFlZVJhRWRoY1JoWGR0YTRhY2hGZlplMGFEZTJkdGFTYUZmSGJGaEdoR2htZ05kNWVUaDJlUmFxZVVjeGFrY1RjY2NBYnNiRWJmYUJjSmg2aFJkMmRSY0JmYmNrYXBna2FQZXhlNWdhZk1ka2RsYVVoQWNsZGRoV2NNaG1mWWFpZGZhMmU4YlVkYmRoYVpkSmJaaG5jVmdLZUViRmhKZEVoQ2EzY0JkYWZRaG1jOGRyaEliR2FrYmNiZWZnZzlkN2VRZ2tlVmRCYlViVWRGZ0JkVGJuYVJmMGNVZkhmZ2RWZmVoRmNGY2FjVGRtZXNhUmZJaFVneGNPY2ViR2ZCYVdoYmZnYTliN2hVaGtiaGZ4aEhleGJzZnFlV2FraFpidGNaZGxjTWZZYlhoWGU1Zy9hSWFDZVpnM2hIaGpjZ2hGYU1heGJ3YnJlSGFRZllhNGdZZFFmRmd0ZWNjamc5YnRoWGgzZzFmRWZkYW5kTmN2Y1JhbWZjZ1dlRWJrZXhoMWRTZGhiQmZTZUFna2RRYWljV2NrZ29jNWJJZHplUmNwYlhmWGRKY1RmY2V3ZkJjWGNUZ1FlTmJKaENiMGY0Z2dmYmZ4ZmhkN2hTZmpmMWNZYVNoaGhvZ09kV2JBYzVnTWVUZkhnaGJnZlRmVmU0ZlBkYWUxYklmVWdjZlVoWWZUZ2VlRmROYVBjTmZpZDhnSGVUZkVlRWMrY0Nid2QxY05hT2ZIZ3BiSGNaYUVlRmN1Y1NibWJSYjVhRmFqYzVneGNIZ1JnMWhOYkdoVmdaZzBkYmZqZEFkbWdJYlFoVWJ6Z1hkMWYwZENmZGFRZ1liWWZCZWtkZ2FMaEllbGVaaENjSmNtYnRmbWNNZGpoNWV5ZlRmbmRNYlFiVGRFZDFlUmFTYVJoVmJPZkljRGRJZFlkZWFHZHRhMGhVaFVjcGJPZ2RjUmRGYXphVGRGYUZhNGdjZkZoWmc4YUJnMmJrZUJnUWJDYU1iUGJYYVRmOWhSY1RiMmNWYzNnVWUwaDFoS2dJY0VnNGRXZ0VhQmVJZXpjUmZ6ZmdnZGRiYmtjaGRtZ2VlVmRZaEphYmZCYzFjVWdSYUJkbGZRZWNibWE1ZytkT2ZtYjlhYmdaZ3hoUmRIZkdkRGdOZVNiRWNsZHRhSWFJaFhlQmhhaFFhbWc5YWllWmZtZWtmVWdjYmthNWd6aEVhRWYwYkRoWGJ3Y0JiR2VLY3lnY2IzZ1ZjemFRZElnT2hoZlpnQ2hCaDNjd2dZZ1dkVWd4Y1JhZWhIZEJlV2JkY0FhOWdyYVVjaGZSaDRlYmVCaE5kNGJVZzBoOWdrYmFhbGhNY1phRWMzaEFmTGVXYVFnSmFhZEtiQWVnZXplUWNTaEFnUGFNZjNla2cvYVRmU2hGYVllZWdCZTljTGhHZVNlWmZtZGNjWGVFY3FmQ2ZDYVJoWmVWYWdmVWE3Z0RhUmdKZlNoQ2RWaDRjamVEZWtnSWd0ZEphMmhZZm9nRmZDZFFlUGZQYjFha2dJZ1RiUWdJYWRmUmN3YWNobmFNZ3hnZ2gxY0RmemRjYWVoRGdnaGNhN2NWZ25jUmJGYVNmbGVKYXdiVmhuaFFkUGVhYzFmSWJVaGNmVWZZY1RmTGJoaEliZGZaaENmOWZUY0JhQmFOZGdiQ2J3YVZkV2ZWYm5iSWRWZGFlRWRFaG5hUWQzYjloVGdTZHhoUmR4YkhiUmMxZU5hR2NWZ1plMGZiYmlkSmR6Y2Nma2VZYXZoSGVrZlpoQWJkYVFoOGdaZVNlV2M0ZExiY2RGZXBkQ2ZiZzJiSmJtZ2FoUmhSZXliR2NEZUplQ2FUY0FjSmRSZVZhQmdVZmFlWmZ5Yk5iS2dPZ1JnVWJ4Y1doUmFoZ0NnZGhWaGhnNmVWYTNkdGU0ZmNkRmFaYjBjRGMyZXRjU2hGZUhiRmJHZlFiVGgwZ0hjR2RqZllja2JVZjFnWWhUaGNhUmZaZUVlVmdsZ2RlNmZRZ1dnSmZCY1pnaGQ1YWtkWmNFZ3RmQWVmZzBhNWZSZUJoRmVvZVRoZmFIZDVhNmFjZHlkQmFQZ2JmaGdvaFNiR2RHZDVlZ2NFZ0ZmSmZFYUNoM2RCYWFhUWVtZzhmL2VUaEdia2VVZmNma2E1ZXpiRWRFZXhnTmRGZnhjeGFiZ0RhVGYwZzljVmZ6YzVhQmVOaDFoa2FlaFFnbmVWaERoZWhrYndmS2JVZW5lQmZXaGRhQWU5YXJoVWhoZlJieGRSY2hkTWd1ZkVhaGIxZmtoSWUxZU1nRWVFY3liSWRGaEZjUmROYmNjUGdSYk1lc2dRYlhlSmJLY2RnSGNsZlVkRmdHZkVhZGVCaDBiMGJKZlZhaWNoZXVkTGUzYXNoOWhTZENjdGdUZlhlQWZzYmhjQWRoZGxmSmdiYWdodGh3Yldja2dKYXZjWWNtY1pmcGVGY0hmSWZhaGNmd2YxZU1iQmhWZ2tkZGRHYlVoNGJnY2ZnUWROZGFmUWZYZFJhUmFTZGtnNWIxZUVhWGFOZk1mVWdUYjRlL2VCYUhlUWJIZ1BlUmJOaEdkY2FRZ01hVGJaZlZiTmRmaGZhMmhvZ2FoR2dRZjFkd2hUZWtkSmRXZFZlM2dwaE1kZWRVaEZlL2RRZDJkUWd0YU1nRmhFZ01lSGVRaEJmTmhDYjBnTmRoYWJhbmdCYXpjUGJUYjBmaWZhZ3dnbGRtZ2RhVWFvZlFoVWFrZ1FlTGJjZEZlcGZDZmJkemZBZ2piUGZVZ0VhZ2dBZ0hkTmJFaFZkMmFkYlJnU2JSY1ZmT2dhY1hoUWFZaGNjQmd4YmVkVWZVZXBhT2ZkYlJmRmF6YVRkRmNFZCtoSmdSaGdlM2ZXZXlmSWNkZFdhbmhFZ1dmR2h5YXhmZmNUYXpkWmFtZ1VoMWdBYWZmY2NFYzVkUWRWZ2tmbGRRY1JoMmZSZEJkYmhrYXBha2JlZlVnc2NVZmNmVmdSaGJiVGRSZEZmZWJKYW1hQWYwZ0thamdzYURlQ2IxZk5kY2JDZnloRWJDZ0hnRmdKZlVkQ2MyYjVlYWJDZjJhOGIrY09obWJsZEdmZmNBaHdocWRSYkFla2NoaEZlQWFkZ1NhR2NpZkZkMGZCaEhlQWRJY2ZnVmRoYWdkVGJuZFVjUmhjYTBkeGdSaGVlSGJCYldjZGRBZjlkcmVCZ2xjd2FqZ0NlVWVSZTRkSGRRYm9oemVhYWlmRmRZZVhmVGZkY09jUGVBZ1JoQWNOZ1JiVmJzaFFnMmhrZUZhSWZqYThmWWRVZFNoVWdhZkhjUWVSYUtmVmhqZ3NnN2JJaG5hTWNnYkFiR2FkZ1VkWGFSZGthN2dEYmtlTmZRYVRiUmdCYWFiV2drYkpldmJZY21mWmFwZkZnSGFKYk9hY2IxZWtnS2JUaFZma2FiZUdod2N3YXdmSWhGYjBkY2NCZURlb2dXZkhnZ2NaYzFnRGZYYU1jRmdVZlhoTmV3Y1hoamRFZ1BmTmJ3YTRlVWhZZlVhOGRhZVVlbGJOYVBnWmdHY3BkVGFHZ1JoTmJ3aENnMWdsZFdoRWFpZjRnUGdOZGdmNGI1aFNlaWNvYjhmSGZCZ1FoRGVYZEZnTWZLZVhlRGdNZm1jUGREY2tmaGJaZTBlUmhnZVdnbGZjZUNkTWZoYjVhWWVWZVVnUmFDY0lmMWdvZk5iT2RqZFpobWVKZmxiSmh5YkRlRGh4YkZiQWhnZGtiQ2JTaHhkeGJWZ1FnM2ZRZVlnY2FFYUZiMGJVaFVkcGJPYmRhUmZFZ2hmQ2hRZ1VjdGZJZ2hnaGgwZkJhMGJGZ1NhRmdIaEZoR2JFZjNoaGJUZVRkMmNSZHFmVWZ4Z2tmYmZJZ2dkdGJFYmZlQmVKYTZoUmcyZ1JjQmFiZmtocGhrZ2ViVWdzYlVkY2JSZzBiZGFHYjFkWWJmZ01oR2Q1Z21jY2YzZUphYmZlZmhmWmViYlRnSGZOYk1mRWVBYVFkTGJRaGpkUmVhY1VobWU5Zy9mZWQzZ1FiVWFOYzJoUmR6Y0VoRWJ4ZE5oVWNVYWtiVmJUY21lbGMwZEdkSGZCZkJmZGdGYUZlS2JVYVhhVmdmZU5kaGF0Y1JmRGZUZmthWWVJZEJkY2NLaEFmRWRZZndnSGR4ZnNncWRXYm1iVmNrZGFmbGVNZlpoRWczYUFkTGFXYlZjWWNTYmVma2hkaGtkUWRXYTVmS2JmZ25ha2VkZFdjemZoaFpjSGNWZjBnWmZTZjJjbGF6ZWRhamVaYkZlUmNtZWNnV2ZFYmtkeGQxaFNlaGNCaFNkUmRBZnRhd2NXZmthSmN2ZFlibmhsZHBlV2dqYWNiWmdjYzJlVWFGZ0Fkd2dWZFJiZGJCZXdoN2JOZlVjRmU0Z0VhM2FoZlJlQWEwYmRlZmJFY1hmTmJNYVVlWGNoYXdmVmVuaFFlUGVhZTFmSWdVZWNkVWNZYVRkZWFFZWxlUGJLYmloOGZFY0dlV2RZZDVnUmdRaDFhT2JjZHloZ2dWZ0phUmhoYm1oR2RHYWhiNWRBaGhnaGN4aFdoQmNSYUVkRmZYZnhkMGJiZ25oWmZ6YmJhMGNaZ25mRmZoZ0pkTWdkZ1VicGNlYVhkRGFCYXlnQWZEaDhjbWVFYkFmTWNVZUdmM2RVaExoTWJRZUJhbGJQZERlMGMrZk9oMmdGZmtjYWFYZVFjWWhjaEVkRmYwZFVmVWJwYU9kZGhSY0ZmemhUZUZjRmZuZGNkRmM1ZjhlV2cyZHRiUGFGZENlTmdQaEhkM2hoZWJiR2EyZm9iVmFMZEVibGVCZlBjMWg4ZVdjS2JXaDFmNmZXZW1hUWZQYVliQmJvaDJoTmZoYjlmYmVKZ1VmUmVOY0NlQmdCaGZmWGFtZzVlMmRjZjJlOWNHZlpheGFZZ1NhVGdIaFZlS2hFZ0ZoSmVFZEVmWGhCZVNkRmVtaDliL2JaYWlnb2ZjaEpka2VKZHplUWRraFZhRWJYZ1dhTWFWYlRobWZsYzBnR2hIZUJjQmVkYUZiRmJLZVRjbmFWY0ZiV2hVaHhhUmJlZ0hnQmRXYWRiQWg5ZXJhVWdoYlJkNGdYYlRkbGE0ZVViMGY5Z2tnYWhsYU1oWmdFZHlkMGNoYVdlVmVZZFNoZWVrZmRna2dRYVdnNGVNZE1oVGZjZ0lmUWVEaGhkU2RVYjBhMWdVZVhlaWhCY2lmZGNpZkZjbWhSZ2pnd2Q4YUVna2h4ZjFjU2ZoZEJhU2FSZUFmdGV3Z1dnZ2dzZXBlWWNtYTRkbmFHZ2pnc2ZkY0VjVWNVYktjQ2N4aFFlYmZIYlJmeGhnZ2ZoUmJnZnJjYWczZlJnUmRTYWtlNWQxaEVlWGVOZU1iVWdYZGhjd2NWZWlnSmhPYU9hVmFKZmRoY2RWYnNoVGdhZ0ZhTWZUZVpmRGhOYmJnU2R4YTBhOGhUaGhmY2NSY1JmamRKZ09jZmUyZnRndWZTZG1nUmQ1Z1NoeGZSZXhnSGdSZzFlTmdHZlZlWWFtZ0theWhJZW1iUGRRYmhhbmFIYWtoWmZNYWFmRWJwaFlhV2doY0FjSGdjZkJoTmdMZ1pnbWU1Z21nZWhSYlJjdmNVaDJiNGVRYkdnRWVNZGRnRGhGZnNkSmhQZ1Rld2VZZmJnMGdFYmdjVWdWYkJiT2JmYVVjTmQ5YkRmeGY0ZG9mS2RWaDRmZ2JBZjJidGhDYUdkSGZGZldoSGMzY2dlYWhSY21jaGdxZkJkeGNBY0ljV2ZnY3RhWmdWZmhnSmI2aFJhMmNSYUJnYmFrYm9kNWFVaDBkc2hVZ2NlUmcwYWRhVGVSZGxjV2ZkY0doNGcvZU5jV2Q5Yk9iTmRSZThlU2dGYzFiOWVLZUVmRmFKZUViQ2EzZEJkYWhRZW1kOWJpYVphbWhsZ2RiTmJFYTVhN2NPaGtleGhOaFVnVWRrZlZoVGFtZGxjMGJHZkhkQmRCZWRiRmVGYktiUmVuaGRkRWhQaFFlZ2NVZlBlamhrY1ljTWNVZHRlcGhVZmhiVmZzZlJla2NjYmhkQWZ3Zm9hcmdMYUZnTmU0YVFjU2JKYUtoQWFEZFJkSGFQZkFiRWJoZ0VoMmI1ZU1mWWVsYk5iTGJGYkhhRWFkYkhoVWIwY1pkVmRuaFJidWJkYW5mTmF2Y1JibWVjZVdjUWZFaEllM2RIaDFlWWhVYkFnVmdsZXdlRWd3YXdnOGZOaGljY2JuZVZjemhjY0JkTmdSaEFndGhIZndoTWdJZFRoQ2V3YThoTWdsZDRmMWNFYzNoMWVSY0ZiaGhKZGZnRWNYZE5iTWZVYlhnaGh3YVZobmRRZlBlYWcxZ0lnVWJjZVVjWWVSZU5kQmNZZEJmSWR6ZTRnYmFHZHhkTWQ1aFJhVmhrZUVhT2JIZHBkSGJaaEVhRmJ1Z1NibWRSYzVhU2V4ZVJleGVIZ1JkUmVuYkdnVmJaZTBkYmZuaFpmemFiYjBnWmVuZEZnaGhKYk1oZGhVYXBnQ2ZGZnhjQmdlZEllaGFSYUNlYmhTZXdkemNKZ0ZkWWYzaEhhSGZFZVFmVGdWZ0JnUmVIaFVnd2NlZ0xoRGV0YmVmY2dCYk5iNmRIZlFhOGVBZE1ha2RVZjdlVGZBYTBoa2djYkRjMWU4Z1hmV2JVZmVkVWJUYThnQmNSYXpiQmZhZVphV2hSZXFnVWZ4YmtmVGZjZEFidGFaZFZmaGhKYzZoUmEyZFJiQmhiYmtlcGI3aGVmUWRNZmNlSmhSZkVhZGdYY1JoQmc4Z2RoR2U1YjJoY2cyYjljR2JaZXhjWWJTZFRjSGRWaEtjRWFGYkphRWNDZDJocGVhZ0FhV2hjZTJkYWVtYWxnR2NlYzFhVmNaZEVhRWF4Zk5hVWdVYmtiVmdUYm1lbGEwaEdhSGFCY0JnUGVSZWRlS2JSZW5jZGh6YUpmZ2hvZ1hnUGNTaEplVWdkaEJlSmEyZ1RneGdRY2plU2VFYmNjaGZBYndhcGNrZGJiRmNVY1pnRmMzYVFlRGJDZTFkaGZXYU9ieGNNZGxiU2VHY2RlS2JOYWpmd2ZmY1FlU2NOZlRhSGZRZzRmUmdBZ25kaGV1YkplSGgwY3JoQmd6aE5oWGNHZTFoZGhmZlNiaGJCZFNkUmZBZ3Rnd2VXZWtoSmJ2ZVljamN0ZERmRmFIYkpkT2NjZnhjQmJNZFRnVmZGZUpjRmJSYW9iaGJKaGxnY2huZ1FhVGVvZ1VmSGNVZzRlQmdTZENnTWRKYk5jQ2VvaGlnR2VTZFlhSGhRY1ZhSWJVY2NoVWVZY1RlZWVGY05iUGFaZ0dhcGVUZUdoUmZFYVdnUWZnZ3NjRmJSZ25kb2ZHYU5lZ2FZZDdkQmV5ZkVjM2NIY3hhUWY4ZVNjRWY0ZlpkR2hSZFFoeGNiYWpoZGh6ZVBnQmFJZzFnWGYxZndhTGhlZVVkcGh5ZkJmd2FKZU5nTmNRYmhlT2RiY3dlTWIwY09jMWNVYXJiTGhDZ1piV2FDY2diZ2REYlJmUmNVZHZlT2V5ZVpkWmFLZVVkMWIwZ0hjaGhoZU9iTmFFYk1kaGVEY1FoaGcxY1BhQmU4Zi9jU2RtZXNoZGhWY2phc2hEYVViQ2h4ZmRnVGJVZzVmcWJVZnhma2VUaGNlQWh0YVpnVmdoZ0poNmZUYW5nOWdyZmJia2FwZWtlZWJVZXNlVWhjZlJjMWdBZFpmeGRsY1doZGZHYjVnMmJjYjJoOWFHZkllVWVOYmNiRGV5Z0VjRGJYY3hmeGNFZlVobmFnYU9jU2UyZjhhNWRUZ0dna2VVZGNia2M1ZXpnRWdFY3hjTmNVZFVlbGRjYUNhR2dsYjhhVGNIYkJnZmFhYVZoRWFGZVJkbmJ3YVljV2ZVaHhlUmFlYkhjQmVXZWRoQWQ5YXJmVWRoYlJkeGJSaGtmY2Z3ZEFnUWZBZHpkYWJoZjFkY2JSaEhhQmY1YkdnQmVoaFZjUGR5Z0lkMmVFYnljRWZZZ2JjRmJOaExlRmRIY0VjZGFIY1VlMGFaYlZlbmdSZXVkZGNuYU5ndmhSZG1hVmczY1JoaGNnZHdnQmIwZkFkR2FSaEZoOGgvY1dnZ2VNYWphTGdpZWthcWNWZ1NoWWdMZGNhM2hJZVpmQ2h4YWNkTWNSZjBnNGNsZE5mVWJvZzNjQmJDZlpiUmJIaGdhWWMwZ1hhM2VNYkJhRWFDZUFnNWZHZXljRmJDZ2Fnd2FGZ2RhS2V3Zk1iSmZlZEVhTWFYYlpibWJwaFlnTWZ4Y05md2FDZzFkbGZXZEVibmVwaEhjWmZFZEZidWhTYW1iUmQ1YVNoeGRRZytoRmhSY1JoRGNUYlJoa2FIZE9oaWFRYjZhSWNRaEZldmZCYXdhUmdGZ2RhVWFFZDZlVWdrZVFoTGRjYkZocGFDZmJmMmNKZG1iYWVSY1JoeWFUYW5lTWJRaFRiRWc5aFJjQ2gwY3dkYWVMZkNhY2RhZ1dka2VGZDBnVWZVZXBhT2hkZVJkRmd6ZFRiRmhGZzRhY2NGZTlldmdKYldldGFTY0ZmSGVGZUdiRWIzZGhmVGdUZjJjUWI0YUZma2MxZUdkSWFrY1ZlWmNSY2hoSWhtYlJmemhCZ2FmUmdFYnBla2NlYlVoc2VVZmNmUmMwYWRjRWFEY05jV2hkZEdhNWcyY2NkMmI5YkdiWmUxZUJmSGJBYWplWWVlZVdhUmcwZEtlQ2V3aDlnU2JGYm1nWmhpZ1BoVWJNY1VoY2NrYTViemJFZUVheGFOZlVnVWVrZFZkSGNDZHdoZ2hUaFNhSWJQYmRjRmNvYmVoVGFuYlFlTWRjZ3hlaGdSZWZobmVaZldhZmZGZXRncmFUYXhhUmJoZVRjeGI5ZjRoSGRVY0VmbGZKZmhhOWJXaFVjSGJnY0FiRGRWYjhoSmZVYkVoZGdrYlFjV2c1YktlWmRIaGxhTGFTYlZnc2VkZUhnVWcwaFpkVmhuYlJjdWZkZmplVWI2aENoQ2JSaENkV2N3Z01jN2RTY2xhUmJhZUViQWdkZXdoQ2RFZ3RhdmVPZlVoeGRwaEZhSGZKY09jY2F4YkJmTWVUaFZoRmFKZ1hoQWZoYXBlZmNGZ1plK2FDZENiY2J6aEhjd2RnZXpoVmNDYUZkRWdCYVhnRmI1Y1ZoaWdaZUtiUGV3ZmRoR2VQYzBkWmhIYmRmaGc4ZUthS2ZpYTBhSGdVYVFoaGRhZENjMWFsZldlRWZuaHBkSGhaZEVjRmF1ZlNiaWcwZy9nU2h4ZnhmYmRIYVJmMWdOZ0dkVmRaYzBhYmhuZVpiemdiYzBiWmRuZkZkRWFjYkNnTWRRZjlkV2VHaHdjcGhPYU5mRmdoZ0NiYmRuYzlkbWdQZ1VoMGZpY0Nhemd4Y1dhVGhDaHdlRGJHZDFiUWFYY0NneWNGYmVmTmZnYVFjbWFVZVVkeGhJZlhoeGFGYnpiVGdGZEZkNGVjZUZnWmYwaERjMmF0ZFNmRmNIYU1nQWNSZ2phWWZRZ0dleWgwZWxnSGRSZnNoVGZiZVJnWmdaaEFia2RzZ3FiQWJpY3NjSGNiZmloc2QyZEtid2VwY05hRWgwZWhjYmhDZzFld2NFZ2VjaWFjaGxmQmJTYVljRGZNaEJnWWVVYVNobGg5aEtlRWJGaEpiRWFDZTNnQmFhYVFhbWI5Y2lmWmdtY2toY2NFY3hld2NoYVVmUmNVZ3ZlQmNBZTlhVGhDZnpmdGQ2Y1ViU2JNZDNlUGFSYVFoZGJSYmllRWZZZWNleGRBZ05oZWFDaFJiV2ZQZFViRWc0aEJmbGFVZy9nQmZWZlliM2FGYVVnOGFGYU9nQWZGZFlmU2FoYUpjZWVIY3hlQmJYZ0tiRWE1ZU9kUWdXaDViS2JaY0hibGFMZkZmSGFFYWRiSGRVZFFmemNWZm5jUmR1Y2RmbmhOYXZoUmRtZ2NjV2RFZGtoeGUxY0doRmZVZkdkRWdWYmthK2dXaGhjWmVoZkljRGQ4ZTloVWNSZTRkTGZQYlZoY2FZZ0JkVWdwY2piRmZVZjVocGRkY0JiaGZ3YVFoWGZSZ1JhU2JrZHdlbWFSZFNjRWdGY0hjemY5YXlnVmNuYlVkU2ZhZndhWmdOY0llUWZOY2NoUGFsY01lYmVaZUdkeGhWYUdlUmdzZmtkQ2YwZ1JkV2hFaEhlaGZIY2JlMGRFZzZhUWIzZjllVGNTZHhnUmh4ZEhoUmExZE5kR2FWZVpjMGdiZGlkQWh5Z1BiVWFZaHVhRmVnZzlhTWZJYVVmUmdjZ0Zjd2ZwZU1oSmNCYkpoWmNSZFdnSmVtYmFlUmJSZXlnVGFuZ01lUWhUaEViMGdZYURieGZWZUdiZWRYZ1FnRmNiaFZleGcwYkdkRWJOaE9mSmcxYlFnbmNHZlFkTWIyZWNiRWVaaHZnSmJXZ3RnU2RGZkhnRmZHYkVoM2VoZFRmVGIyY1Foc2dIZEVmc2hUZGVjRmIwZlljQmNCZklhL2FSZDNmbGdCYmJoMWN0Zi9iZWZWZUFjVWRlYURmY2VkZ1RkUmhsYldiZGNHYzVoMmFjYTJiOWhHaFpoeGJaZkJiR2Z6ZHdkZWhVZXhlcGRFaEFneWdKYVRlUWJqZFJnSWJaaG1ia2NVZmNha2g1ZHpnRWNFaHhlTmNVZFVma2dWaFRkbWVrYjNoV2hTZE1hRWNkY0ZiTWZMY0hhVGFaZFlkT2VrYjVlTGFVZG5oQmhXYWRoQWQ5Z3JlVWVoZ1JneGRSZGhkTmE0ZVViMGM5YmtmS2VSY0piS2dWaG5jQWhKZkZiUmhkYkdjTWF3YWxoMWNRaDNiUmFnZFpiSGFsYUxiRmNIZUVhZGVIZlVnMGdaY1ZhbmZSZnVkZGVuYU1hc2dCY3pmUmVUZkVoa2Q0YjNlQWgxZTRlVGJGaGxiSmh5YlFhR2VoZnZjWWFtZVpicGZGZkhmSmhPYmNheGZCZU1hVGFWaEZmSmdGZFVlNWNwZkpobGEwYWtmRmZDYVljZmFTZWdhZGR1ZU9mM2dOYk1oVWZYYWhld2ZWZ25iUWFQYWFoMWFJZVVoY2RVaFlmVGJPYXhhSWZjY0lnV2VwYlJhVGhFZWNmMmRFaDFndGJNY09mSGJwY0hnWmFFZkZkdWhTaG1hUmE1YlNleGRSYnhoSGVSZTFmTmhXaGhjY2ZuZ0thM2FaZXhoT2NoYUljaGhHZXdicGZPY2JlMmRBaFFlVWRrZVFjTGVjaEZncGRDZ2JiMmZKZG1hYWJSY1JjeWVUYWpnQmhSY0hod2RoaFJkSGgxaG9jSGdMaFhlUWNJZGFkbWd0YTBhVWFVZHBnT2FkaFJkRmJ6ZVRiRmNGZjRkY2hGYVpiMGNEZzJhdGdTZVJiamNRYlNhUmVpZm9oZGVUaHdieGFpYUJleGFBZWRlUGhFZDRmWGJFaFVmWWZ5YVhlRWE1ZkJhYmVrZXBia2NlZFVoc2hVYmNkUmMwZmRnVGFSYmxoV2JkYkNkMGYzZUllQ2ZwZ0dkWmZVZE5lUmFIaDJoZGZJYkNnbmdoaEViQ2UzZUJiYWFRZ21nOWZpYlpmbWJrZFVjY2RrYjVjemZFZ0FnOGVNZ0FjZ2V3Y1ZhVGdEZHdiM2hTYjNkMWJUZGRka2R0ZWdkVGFuYlVlUmRjYzBneGJSYmViSGhCZFdkZGFBZDlicmRVZmhiUWZ5Z0JnMGNBZzlnVWYwZjBjeGFQaGhkVWRJZkJkVGN4ZU9mV2QwZHdnNGVlZWtnZGhraFFlV2M1ZktjWmJIZWxjTGJGYUhlRWRkY0hkVWMxYWFoRmZ5aGNncmdkaG5nRWE2YUVmaWRFZGJoQWUxY29nNWhEZHhoSmdJZGJiZ2N0ZHdkV2hraEpndmFZZ21oWmZwZEZjSGdKZk9nY2J4ZkJkTWRUYVZlRWhiY1VnQmNvYjhmSmVsZFpld2JVZzNjUmZiZVNhZ2JkZXVjT2czY05mTWhVYVhkaGJ3aFZlbmVRZlBhYWQxaElmVWdjYlVkWWFUZU9keGRJZWNnSWVXZXBkUmZVY1ZjWWVvYUNlVWJOYThiRWNuZXBiSGNaZ0VmRmd1ZVNibWhSaDVlU2h4YlJjeGhIZlJkMWROY0dkUWZRZnhhT2ZpZk1kaGVJYVVjWWh1YkZlZ2R4Z1NlYWQwaG9nQmNTY1diNGZMYmNmRmhwZENkYmgyZkphbWRhZ1JoUmF5Z1RibmNNZVFiVGVBZTRlUWJHYWxhQmVPZ2FoemJaZFpkSWd3aFJhaWhSZ1VjaGFVZ1hieGJGaHpkVGNGZEZhNGhjYUZjWmcwaERiMmd0aFNoRmVIZUZlR2dFZjNjZ2FCY0NiamhBZC9jQWdWZWNiVGVDYmdjTWVOY1hoeGF3YTJlQWhpZ29iR2VPaGdiSmEvYlVhMGdzYVVhY2dSaDBiZGRUZ1JibGFXZmRoR2c1ZTJnY2cyZzlhR2JJZjFoTmdVZkRoU2JBYUdjUmZFZGhkdWFDZTNoQmZhYlFlbWM5ZmlhWmJtY2tlVWRjYmtkNWN6YUVmRWR4ZE5kVWFRZUJiVGJUY21hRWJ4aEVlWGJBaFRhTWVRZVViZmdIY0Roc2RSY0doMGFRZEZnY2FYaDRkYWRNY1VhRWVzZ0JlbGh4YnFmYmhCYk5kNGVVaDBmOWFrZ2FhbGJNaFpjRWUzZEFlTGdXZlZhWWNTYmVla2hkZHNkRWYyZjVjWGhaZEhnRmNKaEZkbmhFYVdmSGhSZjhiUWdXZkNkQWRoZkdlamR3YzRoQWh6aFZjMWRVY3hhOGZ3YVFmaGZsZGJjU2dBYnRoNGNIYzBmSmR5ZFlobWZkZjVmSGhXZWxka2JjY3hlQmVNZVRnVmhGaEpnRmdVZjVmcGNkaEJoaGh3ZUhhRmc1Y1JoU2RrYTVjMWNFZlhjTmdNYVVmU2VWZmFkVmhuYlFiUGhhaDFhSWNVY2NkVWJaZFZlTGNSYzBkTWVNZkNjTWNjY1ZieGdNYjNiQWF3YTFkYWNFYmlkaGVMYVpmQWFoZW5nU2JqZTlmVGhTY3hnUmd4aEhhUmgxZU5lR2FWaFpiMGdiY2lhQWd5ZlBmVWVZYmlnRmhnZjllTWJkaEZlc2VMZGVnRWFRaExnY2ZGZXBjQ2ViaDJoSmRtZmFiUmVRZTdhQ2VIYU1jWWFSZEVhVWZIY0JnbGV3aEtkYWZXZFFiWWFiY1ZleGVwZFVnUmdoYU9nS2hVYzFhemZYaEZnRmZtYWNmQWRSZzlmRGgyYjFnVWVGZEhma2FVZUViMmFWYlRiWGMyZjFlbWFVYjBoc2FUY2JlZ2NzY05mSGdsYnNicGdTY1NmZ2VFaEllQWIwZ3dlTWNVaElnZGRjZVViOWFZZkdkVWF3ZkVlT2JtYzVhMGVjaFhhUmFzZ1pieGhZYlNiVGhIZ1ZhS2dFYUZoSmZFY0NlemFrYWNlUWhtZmRocWZiZGpoOWhiZ09od2FwZXphQWJFYXhoUWRUY0ZkUWhWZUJjMmFraG9jUmFIaEFlSWJkYkVlOWJLZkdmamYxZ1ljSWdFZ0lmZGJQZFRjNGdSYklnRWNkZGlnVWFoaEpjM2FSZmhic2F4aFVoMWdKZGtoUGVoZHRnUWhRYkhnNWNIYUhoQmNoZ1ZhTGVnZDljdGFUYldiNWJhZ1pkR2NkZFdkRmJEYmdjVWhGZkdoY2VaZlZkbmVSZXVnZGVuYU5ldmRSZG1mY2FXYkVja2Z3YW5jRGcwZ1FhSGJGZmtkVmZ3Z1dhRWZCZzBlU2RHZ1pocGNGYkhnSmhPaGNieGhCZU1kVGVWY0VlQWNVYjBiNWJoZ2ZoQmRBYzVjUWJXaHBiUGhWZkZnTmYxY0FlWGFwZUFhVWNYZUFkaWFWZm1ob2JSZ2RhVWY4ZFVkWWNVZzhlZmRlY0FiRmRQZWVnbmdkYVRlVWNCYXBjNWVDZHdoc2ZUZ1JmaWg4YlZoS2NrYkZlc2RTZEhoOWRUZFNjeGZSZHhlSGJSZjFiTmRHYlZlWmMwZWJlamhBZjhmUGFVZlphdmhRY2hoSWZRZEtmVWdvY1lmQmZrZ1FhV2NjYkZhZ2VYYU9oeWZSYitjYWd4YzFhcGFUZm1lZ2RRaFJnV2FkaFJmU2JSYVZmT2dhaFhhUWVZaGNlRWRGZjBhVWJVZG9nZGVJZmxiZ2RuY0RleGJsYzRiZWFBZUphOWdEZnpoQmE0Z0ZlSGNGZUdmRWczZGhkVGhUYzJlUmVxZlVieGJrY1RhY2dBZHNkYWdGZzBmRWgvZlJmMmVZZUplS2V4Z0plbWFZaDJlRWJVYWNoUmEwYWRhVGdSZWxiV2RkZkdjNWcyYmNjMmY5Y0doWmN4ZFlmU2ZIYmpoQWFlZlJmUWdBZEthQ2V5Z3BnU2dGZmllY2ZyZk5nV2dVaFVjSWdFaEpoemdXZFVhVmFXZGVoMGFrYVZnVGJtZWxjMGhHaEhnQmVCZmRmRmZGZktnVGVuY1ViUmZNaEFoMGNDY1BhWGFCZFVjSWdWYXNhdGFTaGhlWmVyYmJhQmROZTRmVWcwZTlma2hhZWxmTWZaaEViM2NBYUxiV2VWaFlkU2dPaFFnWWczZ0JiR2c1ZUlnTWNTaDBkTmJHYldna2ZmY0JnMmZjY1poVmVuY1JodWRkaG5nTmR2Z1JjbWJjYldnRWJraHhiMWdTaGhoQmZTZUZoa2I0ZmthRGJ4Z0FhaGVZYWhoWmhoZVFjRGVvYUhhSWhCYnhhTWNIZTFmMWJKYlhnRWNkYnlmWGhoYmhkd2FRYVhjUmRSZFNja2Q1YTFkRWVYaE5nTWZVYlhmaGd3aEZoVGVWZWNlTGJsZUliV2RNYUJlVmVRYU1nUmVwZ05jZmRrZEJmVGdHY1JjTmh3Z0NnMWZsYldhRWJuZ3BjSGNaaEViRmh1Z1NkbWVSZTVjR2JWZUVmbGFTYUVoOGJEaEdjU2FWYzhjT2NqZDRiNmJQYUVjcGFuZlJiQmU1Y01kUGVFZk1lTGFlaEVhUWFMYWNhRmRwZENjYmMyY0plbWNhaFJiUmF5YVRibmNNZVFjRGV3YndmQ2dEZUJnVmZNYkpjVGVWZ01jT2hRYTlhbGFVaDFnQmdrZWRhUmdGYnpkVGRGYkZoNGZjZEZnWmEwYkRkMmR0ZFNoRmNIYUVhRmNVZmlhc2VXZFRkMmdZZW9oR2NsYmRoU2ZJYmxiSmhiZVRiRGhoYTZmUmQyYVJmQmRiZ2tmcGJrYWVjVWFzYVVlY2NSaDBnZGdUYlJkbGZXZkpiaWVzY2lmSmhqYzBnSWhaZzNmOGhhZEdnRGUwZ0RoUWMxZzVhRWVXZlhjeGZhZkNlMmFaYzVoVGJHaGtkVWFjaGtlNWV6Z0VkRWZ4Y05kVWVVYWthVmVUZW1ibGMwZFdlemJFZlNiTWZWY0ZoSWhEYkRiUmJDZU5obGNwZkZkZWZtYXBiOGNkaEFhOWZyY1VmaGFSYnhhUmJoZE5lNGRVZTBnOWhrZWFjbGJNZVpjRWJ5aEplT2REY1FmTmhBZU5oRWFjZVFkU2dUaG9hQ2dMYVNmcGFIZUZoQ2RNYlJoSGZRYVFoUWZUZ1ZjNWZ1YmRobmROZXZnUmJtZWNiV2JFZmtieGQxZVNjaGRCYVNiUmJFZWdoeGdDaFFnZGh2ZllkRGRNZHFmUmIyY0JnTWdhY1RncGZNYVRjVmVGYkpjRmhVYjVncGNkZUJiaGd3ZFFhWGdSZVJkU2hnYjBmMGhRYWpnWmJNZlVmeWIwY3poQmNYY2thZGFhYVVoZ2grZWNjVWJZYVRhZWVGZ05nUGRaaEdicGhUZ0dnUmNOZndoQ2UxaGtoVmNVYnlna2JDYlpkRWNNZDdlSGNpY0pkb2RYZVZjZ2cwZ0hod2VkZG5oR2RWZFpkMGdiaG5lWmR6ZWJkMGNaZW5kRmNoZ0pnTWRkZVVhcGhUY0VmeGFkZE9hY2JGYWdoWGVPZnlhUmRyZ2ViQWRJZStjQ2UzZEViS2RaZ2tjMWRSYlNoUmNWZk9mYWVYZFFjWWhjZ0ViRmQwZFVhVWdwZk9iZGVSY0VlaGJDaFFoVWh0YkliaGRoYjBlZGFtYU1nR2dYZURoZ2dWYUhoM2dnaEJnUWEyZlFmamhXaGdkSWg1Z2NnQWR0ZlphVmJoZUpiNmdSYTJjUmJCY2Jma2FwaGtiZWRVZnRiUWZOaEZmdGNjZkdkRmhVYkNnYmZrY1JmMmhjZjJlOWVHYVpneGVZY1NlVGdIaFZlS2ZFZkZiSmZFYkNjM2dCY2FiQ2J5ZWxnaWRiZGlnd2VkYWNhaGdvYTdlUWNnZ01lYWdVaFFjZGhRZEdmV2RrZ0FnUWdTZkFiRWNFaFFoTWNZYUFiU2ZjZVpoY2RUYmtlZmNNZnpkNGZaYUljMGNGaHJhRmQxZW9oeWJDZVZkY2Z4ZEhmUWVoYStjYWZsYUVjWmRHY0hjQmdmZVVjRWIwZzRhZWNrY2Rha2NRZVdkNWhLYVpnSGdsZExjRmRIY0VlZGhIY1ViMGVaY1Zibmh3ZzZoZGZtYjVidmFUZGplTWNXY0djVWZ4ZzNjU2NCZWxjY2hFZUVjUWRjaEZmUmZVYnFiTWVBZFVhb2RSYXpiZGFHZGVmaGZsYUFnVGNWYWtoTWZGZ1ZoTmdwaGRhUWdoYzVoV2FsYTViUmJTZ2tjNWYxYkVhWGROYU1nVWZYZ2hod2VWZG5oUmhTY1FhVmJJaFVhY2RVYVllVGRlYUZjTmdQZk9iVWdCZVRjR2FSZE5jd2RDZTFhbGJXaEVhamJ3ZFNhS2NnYkljNmdBaHlnc2QzYVNjMGFOZjVmU2RSYkZjTmJTaDFocGMwaEpmM2Q5ZnpjTmFHZ3hjbmhGZGhkSmJNZ2RkVWdvYVFjVWNrZVFmTGFKZWhmc2NRaGJleWZkYW1oZGVCY1FjbWhOY1NnRmR0aFZoMmJkZlJlU2FSZlZhT2dhZ1hkUWdZaGNhRWRGZjBhV2RSYTRkMWRKYzJieGJ6ZVVjVmZFaHNkQ2F4ZjhkSmFCaG1hZGhTY0hlQ2dVYzlkV2NnZlZnVGJVZG1kUWJ2ZldjZ2ZJZTVjY2FBYnRoWmJWZmhkSmY2YlJnMmFRYWNiUmJFZHBja2VlZ1Voc2NVaGNjUmgwaGRmQ2EwZXdhWWROYnpkb2MvZFBiQ2dGY0dlTWRSZjVkR2VRY0hnVWVZZkhjRmdJYU5hQmUzY0FiZmRUZW1jOGZ0ZWJhMmFsaFBmV2ZFZzVoemRFZkVmeGJOZVVmVWFrZVZnVGRtZWtoOWFYZm5nQmZKY1plRmJGZVhlVWYyYWdlUmFKaDBiSWZkaFBoVGQ0Z1JjSWRFZGRmaWNVZGtjWWEwZEVja2dZZ3FoSGNVYzllcGVlaDBiZ2J6ZkViM2ZBYUxlV2JWYlloU2RlYWtnZGZraFFnU2hjaE1kWmJIY0ZlaGNGZkhnRWFkZ0hhVWEwZlpmVmduZVJhdWJkYW5jTmd2YlRjbWdWZEZnUmhoYTRnOGdCZkZlZGJRY1JhQmVaZXRlV2ZoaFllMmNNaGljTWdtZVVhbmhJZEhoV2VSaEJmTWNUaFZhRmFKZkZlVWU1Z3BkZGJCYmhod2RRaFhiUmFSZFZlVWE1YjllR2NUY1phTWZUZEhlZ2U1aFhmM2VnaFBiWWV4ZHNmVWViYkVhWWNEZ2NkVmRwZWxlWmRHYnBoVGZHZlJoTmV3ZUNkMWRsY1dmRWJuZnBhSGdaZ0VoRmgwZ1NnaWMxYzVhVmVSYlJmamNEZkFjbGJhY0RiVWc1YW5kZWRHZkpja2ZSY1VhWmhuY0ZoaGNKYk1mZGJVYW9oUWFVZWtmUWRMY2NiRmJwaENmY2hHZUpmdWdJZUJhUmF2ZFRlbWhFZUJnV2NGaHBkRmVVZ1FnWmZZYmZiV2VNZFJhV2ZrZUZkMGZVY1VncGZPYWRnUmZGaHpiVGZGYkZmNGVjZEZjWmUwZ0ZkV2R0aGZiQmdtZ0JoU2NCaEdjeGVMaFhiSGRKZStnU2R4Y2toTmNjaEVjSmNaaFVjQmRSZTZmVGJ5YjFiQmRjYjBicGFwaGFkMWJvZEFnWmZnZ2tiRmNYZGdkOWhDY2JnR2ZkZjZnV2dXZTlnR2NaY3hkWWRTZFRlSGZWYUthRWNGZUpjRWRDaDNjZ2ZUaFFibmZKZGllYmdTZUFiZGFmZG1iUmF6aEVjRWJ4aE5nVWFVYmtnVmVUZW1nbGcwY0dmSGVBZElhSmJ6ZjhhTGFJYUhoMWFZZ2Vka2J4ZVhmZmhuYUJjZWRQYVFjOWgyZ1VmbGJ0YXhmV2hSZk5jb2VVZTFoVmRrZFBhbGYxY1ZiVmZqZjVjTWJEY1JjNGhTZWRmMGVkYTFoU2hHY0phZ2RaZ0hobGVMZEZlSGNFZGRjSGNVZjBkWmhWZW5kUmR1YVpmbmFOZXhjUmNpZjRlV2RGZEVocGIxY1FnbGFsZVNjV2NRZXNia2RWZEFnNGRxYUxiQ2hFZTllWGVIY0pkRmRjZTFibGJGYlFiWGV0Z0phRmJVZDVhcGdkYUJlaGd3Z1FkWGJSZlJlU2hraDRnOGRFYVdiMWVSY1VnU2F4ZCthR2RqaEZjQmFMZ0FkWmFjZGVmR2R3ZFRnZWVGaE5iUGNaY0djcGFUZUdiUmVOYXdoQWRsZGtnTmRPZ0hmcGVIZVpkRWdGZHViU2RtZFJjNWJTYXhjUmV4Z0hkVmZRZExjR2hWYTRkN2RaaDNlWWhoYktjaGNJYnlnUmRGZXhoTWRlY0Znc2JMaGVnRWVRYkxjY2FGY3BnQ2NiZjJoSmZtZmFjUmNSaHloVGZqaG9jUWRVZVViMGFGZFJlMWVrZExnSmJ6Z05lTWhPYUVjRmE1Z1VlVmR0YVZlWGR4ZEZkemdUZkZiRmU0ZWNmRmhaYzBhRGEyY3NoUGZGY0RjUWFLZlFjRGYxaFRhQmRpZUpkcWRXZ3dja2hUZmJhZ2FzZ1FlWGF4ZUljaGFiY1diUmZCaGJka2hwY2toZWFVZXNiVWdjZ1JjMGJkaFRkVmdBY1FjZGFHZ1poM2FQZ0dnWmZHaE5oVmVOZUdkR2JTYWNhRWhFZ0ZoOWNWY0VmRmNwZ2FlUWJtYjllaWRaY21oa2hVZWNja2I1aHpjRWhFYXdnRWJVZFZjUWhWZlhmbmFKYWVoR2RIYkJmQmRkYUZhRmVLY1RkbmNVZ1JnY2R4aEZkN2dlZEhiQmhXZ2RiQWY5Z3JiVWNoZVJieGFSZGxkb2craFVmMGJkZnNlYWdBZkJoTmFRZVRmbGhGY0hibGFRYlNiWmYxYXBia2dGZFRoY2FhY0lhVGJZZU5lRmZDZE1iZGZHZzBnc2JaZlhnaWRaZnVkYWgzZE1laGNTZUNhRmdFZ1hkUWRGZTlhR2FCaHhlU2NBZ1FlSmg1Y1Zka2FJZ2hoYmJDZjhiNmNkZ2lnY2NJYk5lVmFVaGVmUmFRY05lQWFIZ0VnZGhEZ2RnQmJoZHdkUWdYYVJjUmJTZmtoNWgxY0VhWGROYU1lQWh6ZzBma2RBYXlhWmdCZGFjMGNJZFVjYmVGYXNlT2FlZ0FjRmJCZUthQ2c4ZWRkWGdrZGNmNGVDZzBmWmNXZkhoMmR0YUhhZmFrZkVjUGhRYWpmQmcxYVNhMGVaYTljSGJWYVJiQmhHZVJnTmQ0aGJmamdsaDZhZGdHZHhhbmhGYWhnSmdNYmRkVWVvY1FiVWJrY1FoTGhPYlJmeGFDYlpiMmFBZm9oUGhGYWtmd2ZDYnljRWFTY1RnRmVCYk1jU2NVY0VhWGFPZFRnRmRYZU5ja2ZFYm1oV2NHYUJmT2ZkY1JmRmJ6Y1RoRmNGaDRnY2NGaFplMGZEZjJlc2JBY1VnU2VVZlRiUWRUZlplVGVSZTBkNWVxZVVjeGVrYVRnY2FBaHRkWmdWZmhnSmU2ZVJlMmZSY0JoYmFrZkliMmFlYVZoWWdVZ1lhd2JnaEliVGhSZzlnV2JKYW1jZGM2YVdmV2I5aEdlWmF4Z1liU2FUYkhnVmVLZEVhRmVKZkVjQ2IzZ0JoYWFEYkdlRWNXYkhneGhsY3hkRmZqZUVlU2VZZWpjNGRzaEthRGZaZm1jT2V4ZmtmRWFkYndlSWUxY2RoRmhkYU1hWmNIZlVmUmFjaDBieGFSY2VmSGNCY1dmZGFBZDlicmRVYmhjUmh4aFJkRmhVZXRhSGdRaHdkd2FJZHhjeGdYZ0ViWGVBYldnUmVGYlpiR2hJZnhoY2NoYkRmaWdoZ0tiRWdUZEFmRmRRZ0dibGI4Z1RieGI5Z1ljRGMzZm9lK2FKYkRld2g3ZUNjVGhOY1BiUWJnaGxlN2VBZDFnNGhXZkFkVmNNZGZjSGJHaGhndmFZZW1mWmNwZUZkSGdKZE9hY2J4ZkJiTWJUZVZhRmJKYkZiVWc1ZHBlYWF4Y2dmL2dhZDNkUmZSZVNja2g1YjFhRWRYYU5iTWRVZ1hkaGJ3YlZibmdRaFBlYWUxaEljVWdjZVZha2NUZkRmUmdvZ0JmTWFIaElieWVTZzBkRWR4aFVlbGdjZkdlUWZEY1VnVGNLZ3hkVWUzZ0dnaWdGZzNmQWRsYW9oMWhXYUVjVWdpZlhjMWhnZzNiTGN6ZG9nL2haZnhoSmFyYkZoa2VCZkFiZGVRYk1kWmZlZEViUWhMZGNlRmVwZUNjYmgyZUpkbWdhZlJoUmh5aFRmbmFNaFFnVGZFZjFoUmdTYlFkOWVPZkhnRGUxZldjSmFGYWtmVmRBZ3hjZ2dQYkxiQmY4Z2poSGZoYzRjc2NQYXdhSWV0ZlhleWg1ZmNlV2NEYkFmVmVSZHhjRWZkYUNmeWNFZ3lkUGZGYThkZGRNYzBlb2ZWZEdmaGdvaHVjU2gyZ1FhVGNZZ2thb2F0ZmNiR2VFZ1VhY2VSYzBhZGRUYVJibGhXYmRlR2Y1ZDJnY2IyYzljR2haaHhmWWRTZFZnbmdVZnJoR2ZBaFplSWZDaHdoc2FJZlBnMmdOYWljTGgyYVViVWZOYjBiSmN6YVhmMGRWZW5kVWFVZWtlVmZUYm1lbGQwY0dlSGVCYkJhZGNGZUZiS2dSZDJoNGM3YWNkMGJ4Y1JkZWdIZ0JoV2NkYUFmOWFyZ1Vha2dBYjVoRmVGZ3dodmJVZndiRWVoYlBmVmFOY3RkU2JpZUJoT2hQY0FiUmJBZE5jUmhWZ3NlUWd6ZmdmTGJLaEhia2FHZVFlU2hKaEpmSGZRZDlhY2RWZ2liY2Q2aEplRGRvZ2hiQWNXaHNmV2NYY0Jja2I0ZkNlRmJVZEFhUmRFZlFnaWJXYWlkQWg2Y0piQ2ZBaHNoUmVuZUJnSGNhY0RncGJNZVRhVmdGYkplRmVVZzVncGFkZkVkVmJhZVFhWGFSYlJlU2FrZTVmMWRFZFhnTWZLZEJiRGNZY3pjQWVqZzFjQWZKZVZnSmQxZWVkUmJJZWZnZWRBZ0ZnRGFaY0NoTmVmZUdiVmFaZzhoQ2R4YlpmZmFFZWlnRmd0YVpjRWNGYnVlU2ZtYVJhNWFTYXhlUmR4aEhoVmhzYllkVmR4aFVlZ2hKaHpla2Y5ZmJld2g1ZHZmUWJoZTVjTWVKZDBnTWJRYkNhV2M0ZkxiY2RGZ3BkQ2FiaDJnSmFtZ2FoUmhSZHlhVGNuaE5oQ2NDY1Jka2dFY0diMWN0YU9nZWFIZVFiRmViYVZjeGgwZEhjMGJwYlJkZGNVYlVoSWFIZ2lkeGg0ZGFhbGVZZWdnQWFUYmtlWGVWYlRiVWd6ZGVnamJZY0hkWGRuaElnSWFOaGhoRmZCY2NhQWJGZFpiR2RCaHRkaGViY1dkUmRCYWJna2hwYWtoZWNVZ3NmVWdjY1JlMWZBYlpkeGhsZ1djZGVHZjVkMmFjZTJiOWFHZ1pieGJaaEViRGVTZmRiS2VYY2xkSmhaZ0NoMmJGZldjYWRHZDliaWVaZm1ka2JVZWNla2M1Y3plRWVFYXhnTmJVZFJob2hWYlVmMmNrZ2dlRmRqZndmRWJPYmhmWWFlaEJlbmZrYzdlY2UwaHhlUmZlYUhnQmNXY2RlQWg5ZXJlVWFoY1JheGZCZXhiTmhsYVVjeGcxaHFjSmZoY1pnWGRWZUNmUmhEY1FkbmR3Y1NmZWVrZGRha2JRYldmNWVLaFpkSGVsYUxiWGZUYWNiZGhGZ1doY2haaFZjbmdSYnVhZGhuZE5jdmdSZm1nY2FXZUVoa2V3ZWpmQmRWY2toV2hSYUJidGN3YldnMWg5ZXlmWWhpYk5hcGZFZG5hUmRrZGNkeGFCYU1hVGVWYkZhSmNGZFVkNWNwY2RmQmhoaHdmU2NYYndiVWFTYWxjTmcxZFloaWJjYmVoR2VEZ1llM2JYYWpkRWJHaFpoUWFaZWJoSGVRZGxnRWNQYVFoRWhzZkplVGNrZldhRWJSZnBkNWVCZzNnTmhXYUVibmNwYUhjWmZFZ0ZodWFTZm1nUmY1aFNoeGVSZHplU2ZGZjRiZWNDaDFhUmYwZmNlMmh0Z3ViYmZ3Zk5kbmZTYmtnNWZtZmRlVWdvZVFnVWRraFFnTGRjZEZkcGNDZGJnMmFKZm1lYWdSZlJkd2hHYXpkQmREaFFkVmU5ZFRjU2VRaGhiVGJkZUhnUmNkZmNiQmEwYm9lZWUwYnBmT2RkZVJiRmZ6ZlRiRmVGZjRlY2dGZFpiMGREZzJhdGNTZkZmaWZRaFNjVmVXZ2xiRmdBZ3lmRmhvYlVld2ZRYk9iYmFRZ3NhY2RWYWthNGhtZGJlV2FSZUJlYmNrY3Bha2FlZVVjc2ZVZ2NoUmUwZGRoVGJSY2xhV2dkaGpoc2RpaE5lV2ZKaFhhY2NWZHBiWGNUaG5hVmZYZERmVWQ5ZUVhVGRuZWxod2VRZG1nOWdpZFpnbWRrZFViY2FrYzVhemJFZUVnVmJOZUNobWFNZFZiVGdtYWxhMGFHYUhjQmVCY2RmRmdGY0tnVGZuZlZiWWZOZlVjeGJaYkxkSGU0ZGFhTWNVZ0Vic2RCZGxheGZ4ZldlaGROaHFkVWR4aE1hNGhhYmdnRWRYZ1hkemRWZEZiSGVnZ0pkYWhlZGxldGNrZFVjMmRkYUtjTmFqYXdmZmhRZVNkTmZUY0hlVWJBY0liVGRWZjVhdWRkYm5jTmJ2YVJlbWhjYVdjRWVrZHhhMWNTZGhhQmZhZ0NmZ2J0YnRnV2RsY0JhbWViZ21nWmhoaFJkM2hKYUJiYmNoZUJmZWhSZUZoMWRKY0hkUWI5ZnBkZWR3Y1Zld2ZVYjNhMWNkZlNla2dZZjhjRWhYY3hjUmJVZFdncGU1Y1RhVmI0YVBoYWcxYkllVWVjaFVlWWRUZ2VhRmhOY1BmT2JVZkJiVGdHZFJjTmR3aENkMWVsY1diRWFuYnBmSGZNZGdmQWE4aFNkamVGYmllWWdSY1JheGRIZVJlMWROYUdlVmhaYzBoYmhuaFlmNmFLY1VjWmZ2Z1dnUmF0aE1jTGRtZkFiUWhVZGtmUWVMaGNmRmFwZUNnYmMyZUphbWFhZ1JlUWFrYkRjeWVFYVFoQ2RrZjFoTWFTZVJiaGhmZ2NkbGg0ZllhY2JFY0ZjMGVVaFVlcGVPaGRiUmJGY3pjVGFGYUVmK2NQZ3dlUmEwZUJkemg1aFNoQ2JYZ0ViUGNDaEhjZ2dBZFRnM2NwaHFmQmhnYkllVGJKZ1FiQmhTYVhkemZoYTZhUmMyaFJlQmhiaGtmcGRrZmVnVWFzaFVnY2NSYTBkZGFUZ1ZkQWRRYWRhR2ZZaCtlZWF6ZnRmS2VaZzBiTWJiY1RhR2FoZlhhRGNWZklmTWJBaHlkSmRXY1FkbWNKY3pmWmNuZ1FnSmJiYTBmNGcxZUVhRmFOZU5nUWZVZmtoUGJUZGpkeGIwYUZiWGZBaEhjZmRWZ2hnS2JGY1ZmOGdSaGNiMGR4YVJjZWRIYkJjV2NkZ0FnOWJyZFVjaGNSZ3hmUmFoZE5nNGNHYmdnbGJrYllibGdzYlVjQWhuZUFkV2VSY0Vic2JTY1BoRWZkYmliUmYyZjVkQ2FJZ25kbGFXaEZoQ2RRZVVlRWVVZTFjTWNWYm5mbGV1aE1jSGZOZmtkUmhuYllmV2FEYTFiRmhvYlNnbGJGZ2JnVGZRYnNjaWhIZ3hjWWU2aE1jQ2doaHBlVWVuZUpjRWNjZjFoNWZYZlpoMWVGZEpmRmhVYTVhcGdkZkJmaGN3Z1FhWGhSZ1JkU2FrZjVhMWVUY0hlTWRKaEhiU2NzZTFmVmduZGtiZWhhaDFhTWJKaGJjRWdaZlZjZWVGY1ZoSmZaYkdjSWVHYkdjUmU1ZnRlQ2h3ZnhiV2FIaDNlb2NCYmJlVWMxZ3VkUWdpYkpnNWFWaGhkUmY4ZURlQmNSZFdoTWcxYlphMGViY25mWmF6ZGJlMGFaZG5mRmVoaElkUmVkY1FiOWVjYUFhUWdFZWhlY2JGaHBnQ2ZiZTJnSmJtYWFoUmZSYXloVGZuY01nUWRDYWdhSWJEZlNmUmcwZ0hiYWdYZDhnWWJNZ1VhRmJxYVVjUmFsZk9kY2N4YWRmemRSYUJnaGI0aGJhVmZZZG5jRGQyYlpjU2FWZ1hjaGNLY0VoeWExaFRiVWZtYVFiamdTYkJobGVHY2NiQmVWYkViVmJnZkphaGFSaHpnRmFNYllmMGROYWtiSWZtZkVmVWdjYVJjMGVkZVRlUmJsZ1doZGRHZTVnMmNjZTJiOWdHY1phMWZCZmRlSGhuY1ZmQ2FSZGhkTWFXZENkemJ4Z2FoWGcyYzlhamdkZ21mVWNVaE1hVWU1Z3VoRWJGYnhlV2hVY1FmZ2FWYVVkR2hrYjNoQWUzYUFnQ2RmYTFicGZEZFpmSGFVZ1JiY2gwaHhnUmhlZ0hoQmFXYmRoQWE5YnJnVWZoYlJoeGZSZ2hlTWh4Z0ZnVWY5Y3NoSWVsZnRkTmNIZTNoQmdlZVdnVmUwZVNmT2RVZTVma2JRZkhoTmNYYVplRGRGY0RmUmFuYzBjZGFYZ2tkUWhRZFZjaWM5Y0ViZGhuYU5kdmZSZm1kY2NXaEVia2d4YzFiU2hoZ0JkU2JSYkFmdGN3ZVdia2dKZHZhTGVtaFpiMGhGZkhoTmdmZ2FoRGdwY01jVGNWYkZlSmhGY1VoNWVwZmRiQmRoYndjUWdYaFJiUmRTY2tkNWMxaEVjWGhNYU9mQWF6YTBieGZIYldoOGVsYWFmMWRJZlVoY2VVZFlmVGVlY0ZnTmdQY1pmR2ZwZ1RoR2RSZk5hd2FDYndmUmU4aEVlbmFwYkhmWmdFZ0ZidWNTZG1nUmI1ZVNmeGNSZnhnSGhSYTBjRWVYZzFnWmI4Z0llbmc5ZnplUGVRZE1hemRRZTBnQWFDYWRjUmM4aExjZWJFZlFjTGFjZUZicGZDZWJkMmNKZW1nYWVSZlJleWdUZ2ljNGQ2ZVRiRWIxZFJhU2ZSYlZoT2NhY1hkUWRZaGNmQmFNaHhmQmFSaDhkY2NPaHhlRmEraFhlVWhwaFNiY2dGYVpiMGNEYjJmdGZTY0ZmSGJFYWJnT2VYY2hmVGhUZDJiUmZxY1VkeGFrYVRiTmdsZDRlWGVGZlVlWWh6aENiQ2dwaEJlRGNVZ0lhd2JkYlVidGFHYWZmUmcxZ1ViUWFSaGtiVGFmYVdjNGN0Z1dnV2I5ZEdoWmR4aFlmU2ZUYkhjVmhLZ0VhRmJJYk5hQ2IyYzFoYWdMZERnb2R2YkpkQ2d4aEdhZWNnY2RnNmVFZ0JhQWhSZVVoVmNrZE9nWmZHZ2xhMGNHaEhnQmRCZmRhRmJGZUtmVGJuYVZoSGFNY2hoNWVSYU5kM2JCYUxiZGhGYnRibGFIZGxiRWEvaEFiVWRjZndnVWYwYUpja2FJYzBkZ2J6Z0VjM2ZBZUxnV2VWZlliU2JlZGtiZGFrYVFjU2V0ZUtmZWUzYWxjRGRIZkRmUWFkYUFjRWYxYzNnQWZ6Y2tnc2ZNZHljRmFuZUFoMmI0YmZlSGZrYndjd2JTZ2diNWhTaENld2Z0ZTJhWGFFaEplbmJKZTJkWmUwZ0ZnRGYxZkhlZWNoYkJjV2dUYVZma2dNaEZkVmVOYnBjT2F4aEZkcmFhYTNlUmhSYVNia2U1YjFiRWJYZU5oTWFVZFhmZ2NtZ0ZheWFZZ1BnSWExZUlkSmhjaFJlUWhkYk5nQmNZY0JhSWV6aDRlYmNBYWpibGV3YUNnMWhsZldlRWhuYnBmSGNaZEViRmR1aEFneWVKYzVoUWUxZHhoeGJHZ0JkMWFmZ0dlVmVkZ3BiY2gzZVpnamJaZ2tiWWV6Ylhma2NBYURkSWZrZHBiZWNGZ3hkTWRMYUJjQWFNYVNoS2RnaGNlMGZPYjFmc2NnY1JjbmhGYjVoQWFoYnNoUWZCaFZod2RLaGFmVGZ4Z2RjS2NFZkVmbmFCaFJlZ2dIY09nMWJaZ3hoUmVVYnBoU2FjaEZmWmcwZURoMmZ0ZlNlRmNIaEZkR2RFZ3pnMWZUZFVkV2RRZ2lnVWF4aFljVGJZZWdkdGRmZFViQmRKZnlkQWRtZVJmY2ZiYWdkSmVraGRia2ZzZUdnZWFBaFlkM2FUaFJmbGZXZ2RoR2g1ZzJiY2EyZDloR2daZjFnQmFkYkhkbmRWZUNhUmNoaE1jV2NDZXpjNWVhY1hnMmE5ZnllZmdXZ2xjUmZjYmxkQmh6YVhobGhkZk5kV2RrYUpjYmdSZjJha2F2Y01mbmRCZ0JnZGFGYUZiS2JUZG5jVWRSZ2NhMGJ4ZVJkZWNDY1ljWGZKZWdjOGM0YVVmZ2VsZXhiRmJsY0lmcWRBaEFkb2ZOYUpmQWhjZFJjUWFYZTVmWWdEZEJkUmNCaExjaGdWYnNiVWEyZTVlQWFaZ0RoZGFIY0ZnR2hNaFVoRWNVZzBoSWZRZEhkMWgxYlhnSGJOZXZnUmNtZmNhV2NFYWtieGExYlNkaGZCYVNlUmJFZUloMmFXZGtib2ZtY01lUWdnZG9mZWhuaG9nZGdlYWhlbGFNaEhmeGFRZGRoUWRCYndlbmNkZEZkWmVyaGFiM2NSY1JnU2JrZDVlMWZFYlhkTmJNZ1VnWGRoaHdoVmNpaEJnMGJJZWxlSWRmZmNlUWFoYnVkZWJFZzVnUGFOZDNnRmE1ZUdmUmdOYndmQ2YxZmxiV2FFaG5kcGhIY1pjQmN4ZEViU2dtZVJiNWNTZ3hnUmd4ZkhnUmMxaE5nR2ZRZVFheGRPZmlkTWFoZ0lhVWFZaHBoRGVUZ2hoTWJkY1Vlb2FRZ1Vna2ZRZ0xjY2FBY2Rmb2NiZjJjSmhtYmFlUmhSZnljVGZuY05hV2NHZlFnTWNTZEhjVmR3ZUJlSmUzZlJoYWJlZkJmVmE0ZFVhUmZoYkNhZGJWZWhlL2VUYUJlUmN4Y2NkQWcxZmVmRGYyZHRmU2NGYUhkRmNHY0VhM2FoYlRjVGF6ZFlhdmFCYTBieGRCZ1BnZ2VzaCtoWGJuZ3BmeWVGZldoaGZCZk9ka2ZRZG9nUGRBYVZjVGVKY1ZnVWRkY1FnQmhrY2ZjZmFXZUpoMmVKZTJmTmJHZ0xhaGRvYVNhQ2dYYnhiUmdPYmxmSmFFZENjM2VCYmFhUWRtZDllaWNPZjBoTWdVY2Nia2c1ZHphRWVFZnhoTmZVZlFkOWZBYkFiQ2ZvZ2doVWNUaDhlUGNkZkRlUmZDYkdibmJrZlJiSWhVZUJmUmRNY1hmeGNXYU1hUWRaYXJkQ2VUYjVneGZSYWhoTmc0aFVjMGc5ZWtnYWZsYU1nWmRRY1RmVmhmY0RmQWJSZGNmZWJpZUJoc2hOYjJmWWNZZmJmWGhWZ0xkUWNIYzBnZGNWaEVnRWRaZ0VkM2UxZTFmWGZIaE5mdmNSY21hY2VXaEVla2R4ZjFhRmh6aHBoU2JSYUFndGV3aFdoa2RKZ3ZlWWhpZEFmOGdXaGpmRWFhaE9nbGE4ZENnVGNTY05oQmhRZVVjSmFwYkpmaGhSaHdmQ2VIYmhnUmhEYzBhZGcxaFNobGdsaE1jVWVYZ2hid2VWY25iUWdQZmFlMWdJY1VjSWd3aE5oSGFMYVFmRWdCYlplQWc5YWJjVGRSYTlhd2VXY1ZlVmJXY1dmM2ZaZkhiSWJVZ2hiMWhZZkdoUmg1ZVNkeGdSYXhhSGRSYjFlTmRSZ0hieGIwY2JibmNaZHphYmIwZ1plbmdGZ2xoUWJaY09od2dsY0VkR2N3Y3RnRmJjZ0FjSmJLYU9hMmg1YW1lT2h4ZmhjeWZCZDNoOGZRYkNhVWVSZFJnRWFqYTliT2FhY1hhUWNZYWNhRWZGYjBoVWdVZXBiT2FKYzFnUWNuaEdiUWFNZjJlY2VEYUZjOGJkZFdlTWNBaEhhWGYxaEdkUmUzYlJjVGZCaG1maGFxZkZoaGVBZUllV2RnaHRiWmJWaGhiSmg2ZlJkMmRSYUJiTWgyZ0Jka2RlY1Vmc2hVZGNjUmgwYWRhVGdWYjhoRGVPaGliMGZpZk9maWZBaElmWmIzZ1FlYWZHY0hjbGhLYVFkbGY1YUVlUWZuZnhnYWJCZzJlWmNpaFBlVWJNZlVjY2RrZTVlemVFZUVneGdOY1VkVWNrZFZiSGhDZ3dhZ2ZUYVNmSWFQZ2RiRGNaaENjSmJIZzFkRGNmZjBld2NGZGRoamh3Z1RnT2RrZmdlL2FHaGhiUmM4Z1JnbGdwYnhkWGcwZDhmd2haYWxlTmJRYkhhM2JCZU9oVWRFYjBkNGFlZGtjZGFrZFFlV2Y1YktnWmVIY2tlV2RQY25mRWhkZkhiVWEwaFpkVmRuYVJldWhNaENlWWZoZUJmVGJOaGZjWGFRZkpjMWVQZGhmZ2FHYlNmQWVzY2lnVmRraElhbWhhYTJnWWN5Z1BlbmFKaE9hY2R4ZUJmTWFUY1ZnRmhKYkZnVWE0YzdkTWhVYXdobGZFZnpmcGNSZk9oMGhBYnpmUWV6ZndhQmJNYnllRWdraEVieGVWZ2RoT2FSaE5oTmFlY1ZmWWVUZ1piVWE1ZFNnWmFEZ2hoVGFIZnhjVmR3ZFFmbGZsZExkRGEyZWRjSGdNZEVkOGJpZkRleWRvaCtmSGgxZ3hjeGdBZWhjMGJaYUdiVWZ4ZzBoT2huZ2dnZ2ZJZ3dhOGZrY1VheGFvZ2VkZWFVaHBkWmFXZDBjMGNRZldkbGdwY0NhYmQyYUphbWRhYlJjUmd5ZkVmMWJrZ1FmVGFFZzFnUmJTZVJnVmNPZ2FlVGFKZE5mUGFnYUlnZ2VHZ0FmVWdBaGRiV2dGYTdkR2FGYzFoNGZJaGxlcGUwZ1JkbWdKZVNnVGQxZ3RkR2VFZjNlaGhUaFRlMmFSZnFnVWN4ZmtnVGFPY1FhdGZFaFZibmc4ZzdhRWJ5Y3hlUGdJaHdiTWVxZ2NmUmM4aGFiUGRWYmhoVGVDYWtnMGVlZWVmR2c0ZC9lZWNuY1Jlc2FaaHhlWWdTYVRmSGNWZktjRWVGYkpmRWVDYnplWWNWYkVmR2g5ZnFiTWhDY2hjR2djaGdidGZ6YkRmVWN3aDJkTGJFYlViVmhBZldibGNwYkdjQ2hKaGFlZGVCZGhnS2dVYkhkVmRlYmFhRWR4ZVloZWNDZXRjOGRkY0FhOWhyZlVkaGNSaHhhUmhoYk5nNGFVYjBlOWVrYlBlQmhKY0xjRWR6ZmdhTGhSY0ZlWmdHYUFnUWZnaFpkVGdVZVJjS2JaYkhibGRMaEZjSGFFZGRlSGVVZDBjWmhWY25iUmd1ZmRhamcxZHZkV2QyYmRjWWZSY3dhQWE1YVJhamNwZlNjUmVBZHRod2FXZWtiSmh2ZVlmbWRaZ3BoRmJIZUpoT2ZjYjBhTmJNZlVnRmVFZEJjRmhWYUJjcGhaY2didGNwZVFnV2d0ZlJkWGVrYTVhdmdFZ1RjdGVNYlRoM2JoZ2lnUmRHYmNlUGdkY0ZkSWdIYWNnVmh3YlRjTWFGYU5iUmdaZ0hhdGdLZ0NhQmhOZnZlQ2UwZXRjV2hDZ0hocGZXYWZoMmR0aHVlU2ZtYlJkNWZTZnhiUmR4ZkhjUmIxZU5hR2dWZFlhOWVLZ0hoWmg3ZUpka2daYTVlQ2R4YkljRGVkYVVlRWNRYkFmVWQwYUxiS2czaEJoQ2NiZTJkSmNtZWFmUmJSZXlkVGduZE1mUWhUZUVoMWNSZFNkVWZNYlBnT2MzZFJlWmFmYkVjRWVoZ1hnVWJvYUloZWdSZ0VhL2VWYjNidGE0aGNnRmdaYzBnRGUyaHRhU2RGZUhmRmVHY0VnM2ZoZVRlVGd6YWNjOWZHZ2thMWZRYk9iQWZ0YlJjQmdSZnRiNmFIZEVoNWRCZ2Jma2dwYmtlZWNVaHNnVWJjYVJmMGZkZVRlUmVsY1djZGFHYzVoMmNNY0NiNGdWY0loaGRZYkRiVmNsYjlhS2NFZUZhSmdFZENmM2FCZGFhUWFtYjlhaWZaaG1ia2dVZ2Noa2M1Y3pnRWRFZHhlY2dRZzFmRWZWZVVlR2ZrZjhlR2JIYlpmSGFkZUZia2ZFZFRnbWdnYVJjT2EwYVZlS2ZVYW5jQmNXYmRoQWY5aHJjVWVoZlJneGNSZGhkTmY0ZFVlMGg5ZWtmYWhsY01mWmVFZXpjSmFaaEhnQmVkaFpnWWdXYTFla2hRZldjNWhLZFpoSGNsZExoRmdIZUVhZGhIaFVlMGRaaFZmbmNSY3VmTmdUYUloOGhBZDJmY2FFZUNhR2ZaYzFiU2FoZkJhU2FSYkFldGZ3ZVdma2JKZnZlWWJtZFpncGFGZEhoSmJPZGNmeGFCaEViRGdGYUZnVWJGZ1Jmb2NTZ09ieGVoYjdoUWJXZVVlc2dRZTBhSmhmYkVhWGdOY01kVWNYY2hod2VWaG5oUWJQaGFoMWNJZFViY2dVZ1ljVGZlY0ZlTmhQaFpnR2VwZkNlQ2R3YXRid2FGZWtiUmZMY0VkbmNKaFdlZmZWZk5jdWZUYkdhUWg0Y1FmaGFSYjNmR2h6YmRkTmJHZFZhWmEwYmJjbmRaaHpkYmMwYVpjbmNGZ2hiSmNNY2RmVWdvYlFlVWVrZlFnTGdjaEZocGJDZVplMmhvYnFiYWZRYWxheWFSZm5jc2NEaFhlVWcxZVhjU2RWZDFlSGZhaFdmZ2NFZGNlRmZkYjlkVWhSZFpoT2NmYVFkZGZnZ1RjRmFkZTRlTWNWZTlkOWdBZjJic2RlaEZmR2Q5Z0dlQWVtZHBkRWFUYTJmSmNzYVVheGNGZWRkY2dCZFpiWmRHZ2hmdGd6Z1hmRWQ1Z0JmYmJrZXBna2FlYVVjc2ZVZGNjUmcwY2RoVGhSZWxkV2FkZEdhNWgyZGNlMmE4Z0VnTmhWY05hVGNCZzJlNWFnYkVjRmZKaEVmQ2EzZ0JnYWFRY21nOWNpZlpibWVrZ1VjY2hrYzViemVFZEFnOGJNZEFmZ2h3YlZnWGNYYU5hZWNHYUhhQmJCZWRjRmhGZktiVGJuYlVmUmFjYjBieGdSZmVlSGZCY1doZGJBYTlmcmFXZ2xlVmR4Z1dleGFNYXNoS2RBaEJma2VZY1ZoTWZJZWJobmhrZUhhY2cxZFllU2VlZ2tjZGRrZVFnV2M1YUtjWmJIYWxnTGdGaEhnRWVkZUhiVWgwZlpoVmduZVJldWVmYWliWmF2YldoMmhkY0NjYWdRZU5nMWhRZlJlQmFBYU9jUWdKYThiY2RFYkpmdmhZZG1nWmJwYUZjSGNKaE9oY2J4ZEJiTWFUY1ZhRmdKZkZiVWM1Y3BhZGhCY2hhd2JVYkdjWmFKZFNhbGJOYW9hRGRIaE5oRWdRZEdiRmRpYlZjbmhJZVBmS2RsYnNiVWZkZzBmQWM1YWVoRmROZFBjWmFHZXBkVGdHZ1JlTmh3YUNnMWRsY1dlRWJuZnBkSGhaYUVkRmF1ZVNhbWdSZDVlU2h3YVZoamhCZVJlMWVRZkJhRWJ0aDBlWmdtZmRkcWZmZ1VjWmRoZUZka2FkZEZjZGRVY3dhV2JlZEVjUWRMZGNhRmFwZUNjYmEyYkpnbWFhaFJmUmN5Z1RjbmRNYlFlVGZFYzFjUmRTYVJhVmZPZmFoWGFRZVFiZWJBZTFjMGZUYUVmcGJHY2ZoUWZCZG1mVGNGYmRoNGVPZEZoOWQwZEVnM2JkaFNiQmRXY05hUGNFZHlmUmRUY1JlMmh4YThmUWhCZ2tjVmRjZUVncGRRZlZlZ2c1Z21nUmQzZkpiSWFiZWhhWmRraGNmVmIwY0hlY2NSZXNlZGdHZkJmQmZmaGVlRWRSZTJmY2YyYzljR2daYnhjWWFTZlRmSGNWYktkRWZGZEpnRWRDYzNmQmJhZ1FlbWg5Z2lnWmFtY2thVWRQaGthNWd0YUVnRmU1aGRnUmFWaDRiVmVTZ0diOWMwZEViR2hWYlVnWmVrZWhjY2hUY21jc2FSZ1BkMGJ3ZE5jSmRIY0FoYWZkZ0JmRmhyZFJkd2JOYmlhVWFnaEJieGZVZTBkbGVpZmFjbGV0aFhnRWcyZjBoTGVGY1ZjOGZiZFljV2gxYWtiUWJXYTVlS2ZaaEhjbGdMYkZnSGFFZ2RhSGdVYjBoWmNWZm5oUmF1YmRibmZNaHRjRmhDYUpoWGJXYVZmZGdmY1NhaGdCYlNkUmFBZXRjd2ZXZ2tiSmd2ZVlibWNaYnBkRmVIaEpnT2NjZzFnTWZOZEhoaGVSZUpiQWdWZVJmRGdkZUJnaGR3Y1FoWGFSaFJnU2drZjVlMWJFaFhkTmJNZ1VjWGJoZ3dhVmNuYVFmUGFZYXhkTWhVZWJjRWhaaEhiQWh4ZnhmUGZiZjJkcGFDYVpkQmNwZDhiSWFWZ2xoV2JFYm5ocGFIZFpjRWdGZHVnU2VtZFJmNWJTY3hhUmF4Z0hiUmExYU5oR2JWZlpkMGJaYWllTmV6ZmNma2FZY3poYmRWZzFjTWNmZWtob2FDYkxiMGIwYkhlV2RsYXBlQ2ViYTJhSmJtY2FmUmJSaHliVGRuaE1oUWNUZ0VoMWhSY1NlUmdWZU9hYWZYZVFjWWNlZ0FmZGUwY1RmRWhvZmFiRGhsYzVlemRSZjFlRmdyZkRkVmI5YTRoSmhXZnRkU2FGaEhiRmZHYUVjM2JoZFRlVGcyZVJkcWRVZ3hla2hUZGNmQWF0ZVplVmFoY0plNmdWZ25mWmdaZWJobGFkZzVhWmJFYnNlY2RZY0FnUWVQZlRlUmE5Y1diTmhXYWRkMmNkaFdibGdzZVpjeGNZaFNnVGdIZ1ZoS2VFZ0ZiSmRFZENnM2JCYWFhUWNtYjljaWJaZ21ia2VVZGNna2c1ZXpnRWNGZjFlZmZTZVVha2RJZVViM2VSZzBnRWdHY0ZhWWRaZmxkRmVNYVRlaWVBZ1liY2EwaHBiWGVVYW5lQmZXZmRoQWg5Z3JjVWJoZlJneGVSZWhlTmI0YlVmMGg5Y2toYWRsZk1oWmhFaDNmQWRMZFdoVmVZYURiYWZGYjlha2NYYUhmTmRYZ1poSGNGY2FnRGNXZE1lZGRHaDBhMWRmYlhiM2NSaG9iY2VGZGxhdmFSYW1nY2JXZkVna2d4YzFmU2hoZUJoU2NSZkFkdGh3ZVdoa2FKYXZoWWVtY1picGRGYUhkSmZPaGVmeGZnY0FlVGNVZHhkamhGZFVmNWFwYmRkQmZoYndmUWNYZlJlUmdTYWtnNWcxYkViWGNOZ01lVWNYYWhld2hWZ25oUWZQZmFjMWNJZFVmZWdVYjRhQ2NiYVZoTmVKZlpjQ2ZKYWFkR2RRYjloc2JDYzBhaGNPY0dnM2FvYWJiVGRrZkZkdWVTaG1hUmY1YVNjeGVSYnhnSGZSZjFiTmZHZ1ZoWmYwZ2JkbmhaYXplYmcwaFplbmRGaGhnSmZNZGRoVWRJY1ljUmNGZWNkTGNkYmxhb2hEZlpnbWdKZzZhZGRSZlJlamNYZkhhb2NRZUVoR2VkZFJhU2JSZ1ZkT2NhY1hiUWhZZ2NhRWNGYzBlVWdVZHBiT2ZkaFJkRmV6ZFRhRmZGaDRhY2JGZVpiMGhEaDJmdGVhZkhiR2RkZ1ZmRWczZDVoVGNHZ21lMWFxZ1Rjd2NVZVRkWmFnYkpoWmhDYmpkaGM2Z1JjMmZSZkJhYmFrZnBna2ZlYVVlc2ZVZ2NiUmYwYmRjVGZSY2xmV2FkaEdoNWcyZ2NlMmY5ZkdjWmR4Y1lnYWVXY21nWmRLaEZobGRJZ0NiQWJuZGxoV2NhYkdhOWVpZlpobWFrYlVmY2FrZjViemRFaEVjeGZOZFVkVWVraFZkVGdtZ2xjMGVHZkhoQmRCYWRiRmNFaEdlVGdtZnNhUmVaZVZnbGNFYmFkMmdWZFdlY2VnZWxjcmRRYXdmVmFnZlVlZ2ZKYXBiUWRVZDloNmhhZGhlOGVaaEZnWGdZYkxkVWZSZGdmU2VaYTBhY2hvZlNkR2VkZlJoVGJuZmxhTGdGY0hnRWFkZkhlVWEwZFphVmRuYVJmdWVkZm5iTmJ2YkdoMGcwZFdhRWRrZ3hjMWVTZ2hoQmRTZlJlQWF0YndhV2RrZklleWVTZUdhWmdwYUZjSGNKZE9lY2h4YkJjTWZUZlZlRmRKZUZhUWRBYzhhT2RGZ1Jhd2RYZkdibGFNZFNlZ2ZCYmZmRWRYZE5mTWdVYVhoaGZ3ZVZmbmRRZlBlYWYxYUlmVWJjY1VnWWFNZ2VnRmZ0ZkhiS2ZtYXBlT2JHZFFjVmZsYkhma2RwYkZiR2czYlpoSGZiZUJnSmd1aFZnMmdSZG9hUWNoZjFoYmhIZVJkMWhOYUdiVmJaZjBmYmRuZFphemZiYjBlWmVuZ0ZiaGVKYVdoZGdRYVFoUWdUZ0VlUWFkYVpmVWU5Z1JkZWNtY0pkZ2RiZnpjNWR5YlRobmRNZVFlVGdFYTFnUmJTYVJkVmJPZGFoWGNRZFlhY2JFaEZhMGJXZVVlSWhBZmRjUmF4ZXVmVGhFYWRodGNaYlViVmdpZkJjbWdkZzRlRmhIY0ZiR2JFaDNiaGFUY1RkMmRSZ3FnVWN4YmtoVGdjZEFjdGZaZ1ZjbGNkYjBhRmF6Z0ViU2FKY2tlSmFzYmNnUWhVZFVhYmZ3YU1mRGFUZlFlaGhHZWZhV2Q1aHdhY2EzZDVhV2FkZlFlVWhiY1RiQ2ZsaEtmQmJVZ2RjV2RFYm1iWmZUZVRla2hWZGllWmdtaGtiVWRjYmthNWd6aEVoRWh4Zk5kVWZVaGtmVmhUZ21obGYwYUVnRGI1Y0JoYWNWY0ZhZmdXYkdjWWJEZVllMGd3Zk5iZWdIYmhiSGJaZkJjMWQ0aFVmaGdKZ3hhQ2hCZnBoeGJXZWtmTmhPZmFmbGJNZlphRWgzYUFoTGdXY1ZhWWRTYWVka2hkY2tlUWFXZTRlUGdhYWlna2ZlY1JoemFraFZjVWMwZlFiVmFmZkhkUmR1YmRjbmROYXZmUmhtY2NiV2RFYWtheGIxYlNjaGdCY1NjVGVFZFJld2hVYlZmOWh2YU1nV2c5ZXliUGFuZEpmT2VjYnhlQmNNZFRmVmRGY0pnRmJVYzRkMGVYZmhnaGR3ZFFkWGdSYlJkU2FrZTVhMWJFYVhoTWZlY0ZhQ2F3YmxhQmZEZm9nUGRIYmxncGZSZ2VlRmgwZjVlZWhGZE5jUGZaZkdncGdUYkdjUmFNYnRhSWdWYmxoV2ZFYm5ocGdIYlpiRWJGZHVnRGREZ0VjM2RDYkVkQWU0YVVmbGdOY05lYmFGaDRhZ2JaZDNoWWVvYlJiVWVaaG5kRmVoZkplTWRkZVVkb2hRZlVka2RSYmRmTWhRYmhoQ2hQYVdmSmI3Y2FnVWJCYzhkQWFqZVplZWdDZnhna2NaZFVlamE5Yk9hYWFYaFFkWWdjZ0ViRmEwY1VhVWFwaE9iUGZGYWRmemFSZ0FkVWRzYWNlRWJoZHBhRGh6Y2xkYmhGY0NkTWJEYVJieWgwZ0JnQWVXaFFhWmZCZzBidGJhYlBja2J4aFhjRWNFZ0FoMWJDaGdhY2FKZExleGZnZUhiTmZnZTliUmZmZDFneGJOYkhiVmRVZVBjZmNCZDBoaWRJZ1NlWWNJaEliQmdvZlNoR2hIZHhnUmVPaGxkSmNFYkNiM2NCZ2FlUWJtZjlmaWFaaG1jbGZTZVBnUmZ4Y3pnR2ZCY29jTWZBaDBhbGNjZFRlbmdSZzBiR2FuZEpnTmJkZ0JkUmJLZVViM2ZVZkJiYWdFYXdnRGNlZkdnNWhXZU1iUmFSYXJjV2F6ZTVneGFSZWhjTmE0Z1VjMGM5Y2tlYWNsaE1nWmZFZzNoQmdDZldiVmEwaFBhZWdqZFFld2NFZnliY2NFZkllM2djZE5iUmRqZzVnUWRmYWdmVmFZY0JoQmJjZGhhTWVqYVpjaGZCY3pjZGFHYlhjaGZWaDloT2FVY1FjQWhEaFVlVWQzZFZja2RJZzdiYmhEZVVnbGNYYlRnRWdMZmVoMWVWYUFmVGZWY2tjTWdGZVVlVmUwZ2RlRWJ3Y2tiU2RIZDFhWWNVaFdoUmQxZ0VkWGVOYk1kVWFYZWhid2VWZm5iUWdQYk9jUmFkY0FhSmJCYlJmZGNlYkJmcGdVZFRhbWRwYVRjR2ZSZE5id2RDYzFnbGNXaFRoMWVCY0hoWmJFZEZndWNTYm1lUmc1ZFNmMWVJZmtiVWExYTRmWmhVZ0Jja2Y2ZmJiZ2dWYzdiT2IwZnBibmRSaEJiNWRNaFBjRWNNZFFhQ2VXYTRiTGhjZUZncGFDZ2JjMmVKZG1hYWhSYlJheWVHYURjSmFDYlRkQWRoZVJnVmFCZ1ZoTWdhZjJkOGZ5ZmNiRWhGYzBnVWVVYXBnT2NkZFJkRmJ6ZVRoQmRoZDRhYmdWYVlnWmJUYmpoOGdhZ0doamZ3ZVBkWGVYYUFlSGhRY1NkZ2V2YkhkVmg1YUhhT2ZBZGRhWmRIZ3hmdGNoZGJlV2NSYUJnYmFrY3Bla2ZlYlVmc2RVYmNjUmIxZGJlQWdraHRlV2NmYURiZ2UzYUlnV2Q4Y0poWmF3Z3NlU2hIZ21oNWdLZVdjVmJKZGFhQ2R6YTlkQmZRZ21kUmVwYUthV2ZBaFVoTmgwYzVoNGFEZlVld2YrYUJkUmR0ZGNjQWVDaDVoNmVYYWlnSWdPZU9kVGdJZkNmRGN5Y2RieWFQZkFlZ2JVaGNiR2VGY0VnWWh3YTlmdGJVZGtkQWhLZ0NoV2Y1YnhnU2RHZVZna2ZhZmxjTWdaaEVkM2RBZUxhV2VWZVliU2RLY0FjSWR3YkZkRGd3ZUVlWmdEY3hjUWNQY25mRWRkZEhnVWgwZVpnVmJuZVJjdWJLaDFlbGV2ZFJlbWdjZ1dmRWZrZnhmMWVTZGxmWWVIYUNka2ZnYWtlRWJ3aDBoaGFZYWdhOWVoZFFhSGE1Zk9hSWNSYXhoTWdCZkZiaGJKY1RibWhSYXBlZGFCZmhld2NRZ1hlUmRSZlNoa2U1ZDFjUmN6ZElkZWVVZFRnMWF3YlNhM2FRZU5nYWNVaGtjK2RjZFViWWdUaGVoRmVOaFBiWmNHaHBkVGNHZVZhcGJ3ZUZlbGJrZjdoVWd5YjRjUGFhZWdhd2JuZ0JiR2R3ZHRnUmNWYWdmMGZVZTFib2ZaaFVoVmdwYjBjSmQzZDljb2NSaFVjWmFuZEZmaGVKYk1kZGRVZm9lUWhVYmtiUmdOY1Bid2NoaENhWmJ6ZFFjbmVPZnhhUWc5YVRmbWQ0aFFiSGRsZlpoUmJBYkJkVmJRZmFoVGVzY0RmY2NFZXBhL2NIaGtlTmVPYk1nQmFGZzRlVWdWZ0ViTGhKZUFoUWI5ZFFkU2Z4ZGNkVWVpZ01kSmJYYWhhc2NiaERnamhZZ0pjSGRGaDFiV2hlZUZoOGZpYUdmV2U5YnpnWGVFZDVhQmhiZGtlcGZrYWVkVWZzZlViY2ZSYTBhZGJIYzFnd2dDZUlkVGh3YzRoY2J5ZnBkZGVUZVJkWWFTZ1RoSGRWZUthRWVGZEpkRWVWZmxkcGVhY1FobWg5Y2lkWmhtZGtiVWJjYWdnZ2VtY1hhZ2U4Y1pkR2FBaFpmYmhUZGpiTmY4aFRnSGV4YkJnSmdsZTFoS2hCaDNod2NSYktlR2NaZVJoZWJIYUJjV2JkZUFoOWJyZFVoaGZSY3hnRWZGYklocWFVZHdncGFrZmRoMWVOY05oSGNUYXhnT2dGYXhoRmhHYk1mbGV4Zk9lUWNXYTVnS2FaZUhkbGJMY0ZkSGNFZmRlSGJVYlVhWWNCY0hhUWd5YUtnbmFOYi9oUmFuZWtkV2RRYUVnVmUxZVRoQmVaZlNoVGZGYWxhd2VSZjBjSmEvYmFiMmRwZnBoSGZIZk1lSGFjZDBjd2RRZFRkVWRGYUpjQ2MwYTRmZ2NkZ0VmUWVzaFFoVGcxYVJoVmRFZzRld2FHYUhhTmRLZlZkM2hoYTRlSGYzZ1FlU2dhYXhlY2hkZGFhbWF3ZVRjZWZGaE5oUGNaZ0dicGhUZ0dmUmVOY3dmVGJSYVljRWNFY25iSWZSZ0poUmROZXVhQmhXYVJia2ZTYnhmWmV6ZEVoUmgwYUZnR2hVY3RiMGZQYUdnMWZ6aEpma2VaZjVoRmJsY3BmWGVkYVVlRWNiY0dia2MwYkxlUGgxZ3BoSmJjY21kSWdlYVlnVWVBZ0plQmNnZjRjWmNWYzJoZGhSZlNjUmRWY09hYWZYYlFkWWdjZkVoRmgwZUFmd2g4ZGFmSWZFY01kOWFUZUJiNWFqY1djbGhaZTBkRGgyY3RjU2ZGY0hhRmJHZFRkbGRKYVRlVGcyaFJkcWhVZnhia2VUY2NoRWYwZ01hR2FGZkVodWVEZWlmc2VQYmJoamFOYnNoTGZVZmNkVWNJZHhhRWhkYUJhQmZCZ1diTGUwY1JmMmZjZDJjOWhHZ1pheGRZZlNjVGRIZlZlS2RWY2hoMGhXZ0NmM2hnY01nQWN6ZjFkaWhJYTJia2VKYWNlaGJwYzljUWJ3ZEFjRWRFaGdnd2RkZEhoR2dWYjBmVWhYZ2xnTmVkYkJiNWVLZFVoM2NVYVRnY2VVZkJmUmFNZkhhQmFMYWRlQmE5ZXdlVWVsYnhjeGdXZ2hkTWY5aFhiUWVNZGhkSmZCYlJjTmFXZjJnc2ZMZkVlVmZZZ1phWmMwaGRiMmZTY0VnUmhLZVpoSGhsYUxmRmFIaEVnZGRIZFVlMGhaZ1ZibmNRZWhmZGVuZGhleWNSYmhnUmRDZ1FhQWJVaDdoRGZSaDRoVWRGYWthUWI5Yk9kUWRvaHVoTWdBZVVlbWdVYkRkZGFHZ05jbWZzZ0VnTWVGZkZoQ2NGYVZleGY4aFlhaGJoYTZjUWJUZEVjcWdBZ2tkNWMrYUVkV2NJYXhjV2FHY05nYWFWZG5iUWVQZ2FhMWJJZlVhY2VVZFlhVGRlZkFnRWVLYU1hRGE4ZkJhVmF4ZU1hL2dFZkhhTmVXZEVkbmVwaEhlWmhFYUZkdWJTZ2pkbGFUZlNjeGNSaHhkSGdSZzFjTmdHZlZlWWh5ZU9memFnZ3dlT2N3YThnb2NXZ0JlSWhoaGZkUmM0YmNhVWZoZVliSGhjYUJmTmFMYWJiemRsZ01oYWFSZlJjeWJUZW5iTWdRZ1RiRWMxYlJiU2ZWYXdnSWFhZlhleGVNZGNlRWRSaDBlUWNFZ3BoUGNhZ0FkeGZ6ZVhhRmZFZWtiTGZGaFpia2REYTNhVmhTY1FjSGZoaEdkUmd6Z0FnQmdBZ0RkTmFxYUhhVmV4ZUVoY2VIY2tnWWJHYkZhVWUvY0loamFZZVRmSWFSYmhic2dlaHdmUmRTZE5jMGE1ZlljR2FSZmtnZmFKaDJkNGg0ZFBiRGV0Y0djTWRsYzlhY2hHYkhnZGdEZENmM2hoZ0VjQ2QzZEJmYWJRaG1iOWNpYlplbWhrZlVmT2d3aGhkemRHZ0JjaGJOYVdna2JsZUhhVGJuaGRlMGVVYVhibGJyYmRoRmJGY0tiVGRuY1VmUmZjZDBmeGJSY2VlSGNCYVdhSWhFZmNjNWFIZFVkTmR4Z0NiRmFZaHZiVWZ6aDBnbGhKYUJnUmNjYmRiaWdKY1pkRmJnZlFoYWdlaERnTWEyZUdmQ2ZjYUVoSWEzZmtmZmRXYTNmRmZjaFhiZ2c1ZmNhQmJTZ2RndWJOZURjWWcyZkNnU2JsYVNlRWVnYjRmZ2dEYkZhWWZYZUZoZ2hzYThnSGV3aHdkb2dOZGlkNWNyZkhkV2FsZGtmY2d4YkJkTWNUaFZjRmZKZkZkVWg0ZTBjWGhoaGhjd2ZRZFhoUmJSYlNja2Q1ZzFjVmV5Z1ljQ2dFaGlkd2U1Y0diVGRvaFBjQmIxZHBjQWJmaFVmWmZCZGRhRmRNZ0dhYWVHYW9nV2FGZFJnTWMvZkJoMWhrY2VjR2EzZm9kY2hUaGtjRmN1ZVNibWFSZjVhU2J4ZVJkeGJIZFJoMGdFaFhoMWNaYzhhYmR6ZWhoOWdKYWhmVWdGZVFmMWZRZEtoTWRCY2dnWWdCaGtmMGdDYldmbGZwYkNnYmIyaEpkbWZhY1JnUmN5ZlRibmdNZlFnVGdCZGtmWmZHYzFmb2haY2FlVGZwZ2RoSmIwYUVmQWRDZUJnb2ZMY0ViRWdNZmhhQWJ3YU5ld2VkZDFmUWQyZVdlaWMwZVVkVWJTYk5oRWhFaHpha2ZCYUNkRGNFYm5lRmRsZWRoSGZjZ0VhWWdNaEJiVWdaYzZmQmhTY0ZlQmFMZDBmb2FHY0xhQWcxY1NmTmJFZjhiZGdCYkZhY2dGaElhQ2g4YTRlTWNDZHBhQmJiYmdiMGQ0Z1RhSGZWZktkRWFGYUpjRWdDYzNjQmRhZFFhaWdZYWtkWmVtY0ZlR2RjY2xoQmd6Y1hnMGJ3ZFJjRGNVY2xlZGZUZW5kZGUwY1NobmFsZHJkZGNGZkZlS2JUY25lVWFSYmNlMGd4aFJhZWhIZ0JiV2ZJaEVkY2E1YkhiVWFOZHhkQ2VGZFlodmVVZ3poMGZsYkpkQmVSYmNkZGRpZEpjWmVGYmdmUWFhZ2ZlVWFVYXlhQWFDZkliZmFJZ1hkdGdMZFZjU2ZOaGFnU2VBZUJnY2ZHZ0NhQmF1YVBheWNCY3ZhQ2NUZEpiQ2ZFYWdlTWF6Z1NhbGJJYmRkRWRVZVVmMGJDYVVmVmZtY2VkVWZ4YnBjRmhIY0phT2NjYnhkQmRNY1RoVmFGZEpoWGhBZWhhcGNmZEZlRmJ3Z1NmbmhRZVVoU2RsZUJoMWRSZlhlMGVBaEZlRGRZZDNiQWVqZHdoR2hhYXdmWmhjZElkd2NsZ0VjZWJCaDBoS2dNYTJlb2RoZldiRmgwYzNmVGZqZHdoRWFRZURoVWRWYmJjRWdNYkhoQmRDYUFlOGJFZXhlUWcrYVNhRWVsaE5mVmRoYkJkMGVQY0RnY2Y5YUtlQWROYWxhSGh3ZGxjbWZkYlVmb2RRYVVla2RRaExkY2JGZm9nZmFSZldmSmNtY2FoUmZSYnllVGhuYk1hUWRDaGhlZ2NmZUNma2FFZEhmSmFqZW9hWWRIYzBja2JnZ1hlVWZvZmNlZWFSYUVoNmZRZ0ZlRWg5ZmVnVmRZYXZkSmhXZXRnU2JGZ0hmRmNHZ0ViM2FoZFRkVGgyaFJoNmVVZ3doY2RUZklkZ2F0ZWZiVWhCZEpoeWRGZVdjUmhjYWJkbGR4YXhnYmhGZWdkQmdjZFJlWWhkYkhheGVsZGRiZGRIaDloL2hhZkVkVmZHYlpkeGNZY1NnVGhIZ1ZjS2ZFYkZjSmJFY1RnVGM4ZklmUWZtZ2NlMGRKYXphc2FVY1BkVWg1ZHVhRWVGZ3hiQmNVZFFjRWVWZVVmMmNrY1poV2RTZlFnSmVlYmhhd2dEaEFkSGQxZ0ZoZmNRYUFiVWdOZGpoY2dDZlBlQWU5Y21lVWJsZTFhOWFSZ2diRmJ4YVNmRWg4ZHNnYWZrYjBiWmFYYkdhc2JMYVVkbGExYmRhY2QyZjFha2RRYVdmNWJLY1pnSGZsaExmRmZIZ0VjZGFIYlVnMWhOZ0xhVGExaHVkZmVYYk1mZ2hPZjJiY2NMYU9oRWZ4ZjFnU2doZEJnU2hSYUFkdGJ3YVdla2RKZ3ZlWWZtZlpocGVIZkNkQmhPZWRoUmVCZUVjWGYwYVJmY2VGZ1ZiSmQxY2RhQmVCZG9jUWZYYzVkUmdRZGdhdGYxYURibmNNZkRoVWhXYUpnd2dSZDNlUWZDZ2FjeGEwZGRiZWNFZDhjYWhlZEVlMWJSY2VjbWFwYmJjQWNSZ05oNmJDZjFlRWRUY0VnbWRWZkhkS2cwYkZnMGJTZm5nVmY1ZFJmaGVRZStmRmNCYlJiV2hNaDFhWmgwYWJhbmdaZXpmYmgwZ1phbmJTZnpoaGdNYWRlVWRvYVFiVWRrZFFjTGVjaEJid2hYZklhU2NFZnljSWhGYXNnOGJUZWhiMGhZZ0dmRWVGZlJnR2F4YmxjT2NJZ0hlZ2ZZaE5mVWZoZzBkQ2ZtZkJjT2FkY1JiRmh6aFRnRmhGZTRlY2FGZVpmMGdIYzJhdGRNZEZlQ2dOZEdoRmFYZDVnVGVSYXpkWmZxYVRkaGVrZkhiWWVoYkpoTmdUaHdkUmh0aFZmWGExaFVmYmFrY0Zla2VLaDBhc2VmZGNlUWd3Y1VkVmRqZk5iV2RkaEdlNWMyaGNnMmY5aEdkWmd4aFloU2RDYmpmb2JZZEVjRmJvYlNnU2JpZ0pmYWZEYldhOWIvZFpmbmZrZVllY2NnZlphemZEZlVhd2VnYkVoQmcxZ2RmUWNDYlFoOWZWaG5kZ2VWZWVoaGYwaFBmQWdEZEplRmhPZjBleGhjaGVnRGJsaGFhZGhCZ3RhaWFTYVJoUWc1Z1JoZ2UxaDRlSGRGaFJna2ZZaFZjaGdXYUdnbGFvZ0xmV2VWYlllU2hlY2tiZGRrZFFkV2I1YUtiWmZIZmthZmZiZXpmZ2JkZUZka2cxY1dhS2QzZlJjemRkZ25ic2c5YlJjbmVrZElhRGhFZHhkOWFVY2hhQmJZY1JlQWRNYzFkV2JsZzFkdmVMaFdkWmV6YUZjR2VGZE9mZmhoYUFlRGZSZkZlaGZBY0ZiVWhoZ3BiWmJnZTFibGFXYmxoNWhSYVNka2g1ZTFoRWJYZE5kTWFVZFNmVmdhaFZobmZRZ1BhYWgxZkljVWNjZ1ViWmRWaExjUmEwYk1oTWNDaE1jY2NWaHhmTWZVYkFjd2UxZmFmRWZpZ2hjTGRaZUFiaGdpaFNjaWNGZXdnU2EwYzllYmRIYVJkMWhOYUdiVmVaYjBjYmJuaFpiemNiYXdnOGNoZUZnaGZvYkZmZGhVYkVoUWJGYTBnUWZWZWNkQWc1ZU1hSWN5ZGNob2ZMY2tiQWE2YlJiM2VOZUVjQmFCZjhmZWVIY2hlVWZBZkxhQ2JNZVliQWVnZ0FjNmhGZmdjOGdyZUpmMGdNZjhmSGVsZWxiNmJHZ1JjZ2F3Z1NiamFOYlNnV2N5ZVFkU2JFZHplY2dWY1RjemRZY3JkSGNWZzVmV2NjYWdlSmhDaGZnQmFKYjZnUmYyY1JhQmViZWtocGFraGVnVWV0aGRoTmZ4ZjBlVmhYZVJmbGNJZmRjQ2RkaC9mY2F6aHNjT2ROZFZhbGJGZFRiRGZzZlBjUmMxZklmMmFTZmpoNGdkZkJkd2ZvZXdnTmZDaFpoR2ZlZ2tld2VhYlhkZ2ZnYklnQ2dVYWxlYWZHZHpoMWYwYVZjemNaYUJiSmFoZ0FiRWRDY1RnQWVUaGVkbGVkZzdnZWZIZUJiV2FkZEFoOWJyY1VjaGNRZnNjYmRCZ05nNGZVaDBiOWZrYWFlbGNNZFpkVmdTY1ZiRmZHY2djSmNiaE5kUWRsY2tmQ2VtYlljZWhhaEhka2RaZEdhSGZGYVVjRWVVZzFnY2RXZ25oUWZoZmZiM2dNYjBhYmRHZ2NiV2JFYmtjeGIxY1NoaGJCZVNkUmNBaHNhaWFIaHhhWWU2Yk1oQ2NoZnBmSGhGYWhoT2RjZ3hnQmZNYVRnVmJGY0pmRmRVYTVlcGhkZ0JmZ2UvYlFoU2VnZU5hU2JpYnBjOWhSaFhjOWJNYUFmM2ZSYndoSGMzZ2dhUGFmYzFlNGdVYVlka2ZnaEhlYWdFZkZoWGJkYW5jbGJIZ0Rjd2dWaGplRWYwZXhmRWFDZG1iSmdSZUlhVmhKZjJhUmNtZVJiMGFXZEJmcGJsYkRkUWg5aFZjQ2QwZ1ZmZ2FlYUdiQmRnZmRnMWVOZjFoRGZnY3BjYWVNZ0Zoa2dJZldmMGNnZ2hjY2VGYnBmQ2NiYjJjSmRtY2FkUmZSYXliVGJuY01jUWRPYTBiTWJHZkdhMWV3Y2FmTGZIZHhjTWdmaEVmRWVtZVhnVWRvYUhnZWRSY0ViMmdRYUZiRmhxZVloMWZwZzBkR2QyaEpnZWdQYW5hRmVHY0VjM2VoYVRiVGIyZlJhcWVVYXhja2ZUaGNiRWhKaFpmWGhSZUpidWdiZVdlUmdCaGJia2ZwY2tjZWdVYnNlVWdjYlJjMGNVaFZiamNOZ1dlZGhHYTVlMmVjYjJmOWdHYVpmMGZzYjRoVGZIY1ZoS2RFZkZlSmFFYUNkM2NBYmNnRmh5aEVoaGJNZWlhQmViZlBiRWQ0aDVmR2NCYmhhQmJVYlJoc2RaZFRmaWVCZzRjR2NEZFZoTmRkYUJkNWFEYlRiaWg0ZDdoY2IwaHhnUmhlYUhnQmhXZmRoQWc5ZHJoVWVrZFlkMGZFY2tnWWdxZEhoVWI5YnNoUWhGZk1mWmNFYTNoQWZMYldmVmJZZVNjZWZrZGRka2ZRYlNiRmFLaE9iQ2NWZkxlY2JIYmxiSmVFZ1VhMWFMZFdhbmJRZG5jZWFuZU5hM2dTYm1jY2NIZEhjRmN0YXNjWGNRYlphTGVWY3hkcGFqYVRhbGRwZDVhY2VIYlZlNGVBZFdmVWRMZFliQWFCZFVjUWhWYkZkRWNCZEVoQmYrYWJnUWQ5ZW1oV2dHZmRoQWZXYVZjcGN0YkJjMmdGZGZoUWRHZDFlbmdFYjJmY2ZmYmNhMWRzZlljV2IwZ1liVGJlZ0ZoTmJQYlpiR2JwZlRoR2ZSZU5od2JDZHlkNWRZYVJlU2FnYk9mTWhBZVJobWdIZ21oaGI1ZkdnUmJoYXhoVmNCY0ZoTmNYZkZmcGIwY2VnMmFSYy9nYmQxYTVidWNHZ2pkaGNNYmRmVWZvYlFjVWJrYlFoTGVjaEZlcGhDYmJoMmRJZ3ZnYWhSYjloeWdWaGxia2hRZFRmRWMxY1JnU2RSZlZlT2JhYVhiUWFZZmVlVmVwZWViVWFVZHBhT2FkZVJmRmd6YlRoRmhFaGxiV2hsYVpoMGJEZzJndGZTZ0ZmSGVGZ0doVmNTZDBmZGNEZ0RjQWRqaEhnRmZjYlRhRmRnaE1lTmVYZXhiSWdoaGJjV2FSZEJmYmVrZ3Bla2RlZlVic2NVYmNkUmcxaFVnQ2Z4Y2xiZWJmZkdkWWZpZmNoM2ZKaEdkTmZoYzVkR2dSaFhjc2dZZlZkUWJJYkllU2JqZ01oZmVTaGplMGcyZmFhbWFrZ1dnY2JFYWRkNmhIZUVhd2daZVhkd2dWYlFmQWJDZzRmZ2VVYkhjQmZkZmRhRWFOYURiUmgzY1ZoRGhOZ2hlZ2RFYktkamg1YVdnZGVnYjFmd2ZlZkJkUmJ4YVJiaGROZDRjVWUwZDlha2VhZmxkTmFmZ1hhQ2NJYkxmVWJVaDBoU2RMZmtja2ZvZkJnQ2RBYk5iTWNEaEZhTGFFYlhoRWhKY0hoVWd3YkVoU2YzZlJmK2NiaFhhTmNtYlJmamRNYldoR2VWZUZmMWNTY0FjMWNRY1hheWZGaHdoV2FrZEpidmFZY21lWmdwZ0ZiSGVKZ09mSWJWY1VhWWZHY0FlTWZIY0ZiUmFwY3lmWGNoYmhhd2hRYlhmUmJSZVNka2c1YjFoVGVGY2xhTWZVYlhiaGF3YVZkbmFRZ1BnYWN4ZlJkQmZQY3dmVmdIYk1mUmR3YkJhWmFEYnRmYmNUZVJlcGJ3ZVVkSGZOZldiRWRuZnBkSGdaZ0VkRmh1ZVNmbWZSYTVhR2hWZ0VibGRTZUVoOGVEYkdmUWRKZjZkT2JpZlFlNmFJYmtnWmY0aEZja2daZUNkSWJSZmhnWmRIYzBnd2RDZGNiRWRCZkNnT2MyaHdkMGhMYUViUWQrZERhemhCZFZkUmRFZElldmNOY1VkWmdGYU5nUWJoYkxnZWMwYlZkd2dYZmdiMWhDY2RlUmNOZHhoUmhVZHBiU2RjYUZmWmYwZURnMmJ0YlNmRmZIZEVlYmdPZlhoaGZUYlRnMmVSZ3FjVWd4Z2toVGNOZmxnNGdYY0ZhVWZZZXpnQ2JDZHBmQmdGZWtoSWd3ZmNmRWN0YlBmV2Z4ZTBmZGNUYlJmbGhXYWRiR2M1ZTJkY2IyYjhjVWNJY2thSmVIaEhiamd0Y0tnQWdVYVJmRWRGaFhoQWFPZFFhbmRCZWloWmJIZGtjV2ZjaGtlVmh6Z1JoRWZJaFpkSGVqYXBjQmdIYkNjQWY2ZVhnM2VoZlFlWWNsYWhjS2JWZEhhVmdGZGZhUmJnY2VlQ2J5Z1FnRWdQZ1VnRWRzZVdmZ2ZWYW5hVGR3ZWhnU2dVZDBjOWdrYWFmbGNNYlpoRWMzZkJkV2FjZDFlWWNTZGVla2NkY2tmUWNXZzVlS2VJYmlmd2ZGY1ZoeWJWZFVoVWdnZU1nWmZQZW5md2g2Z2VlbmRNaDliVGEyaGRiTmVPZ0VkeGUxYVNhaGFCaFNiUmdBYXRid2NXZmtnSWE5Yllobmh0YnBlUmNuZ0liU2dMZ3hlQmhkYVRnVmQ1YkphQmFWYlZmRGNkYkJjaGZ3Z1FmWGhSZ1JhU2NrZDVjMWFFaFRnVWNEYUFjM2FoZDRjQWVEZ1ZjZGFhY3hmc2VZZ2NhUWNNYVRjWmZWZU1kYmZhaGliWWNXYlZjMWhRZ2thUWUxYlZlV2dYYVhlcGJhZlphQWE4YTdkQmVpY2hkMWNTZTFjeGF4YUFoQmQwZjJjWmVGZ3BjMGZJZUhnWmd1Z2JjMWFaaDhkRmNsZGRmTWNhYjBlcGZlZVNnVWdRZ0FiZWd4YVJhTGdiYXplbGZNaGFmUmdSaHlnVGZuY01lUWNUYkVkMWFSZFNlUmJWZ09lSWNEaEllWWVlYkVlbGI4ZkdoRWRwZlRjZGNVYlZnOWVEY3hja2I1YUlhamFVZzdkU2V5ZjRhemhRaEhja2dJZ0dibmNGY2ZlVGN5YTFmcWdUZlJja2ZHaFpiUmRsZUFmUWh4Z0pnOGVRYldnUmFVaGViVmdsZHdkYmhVaHNoS2hjZFZjUWZVZVJnQmRrZU5oWGJtYzVkMmFjYjJoOWRHZ1pkeGNZZFNhVGJIZ1ZhS2ZFaEZiSmRFZFFhamRaZmFoU2JtZDRndGdiZzJobGZQY1dhRWE1Z3pjRWVFZXhiTmFVZFVoa2FWYVRhbWRsYjBnR2FIZkJoQmdkaEZjRWdEYkNlSGFVZFpnT2hrZHhlUGhlY0dmVmdBYVpleGM1ZHllV2V4Y1FmcWRiZEJlTmc0aFVoMGI5ZWtmYWdsYU1kWmRFZzNkQWJMZldiVmFZZlNiZWRrZWRma2JRZldiWWRZZVpiSGVSYldjRmVHYUlkVWdIZ1ZoTWFaZldkMmdWZHVmY2VIY1ZidmFEZW1hbGVHZVJkeGg4YTlmUWhnYkpiQmdYZFFmZGd3YlNoMWN0ZithYmFtY1poNGFEZ0didGRIaGFnRGRwYk1nVGdWZEZnSmVGaFVlNWZwY2RkQmVoYXdoUWdYZlJmUmdTaGtlNWcxZ0VkWGJNZFBmSGZqZVlla2FIYXphcGVhZ0xha2RrZStlY2ZVYllkVGdlZEZlTmRQaFpkR2JwaFRjR2ZSZE5hd2JDYzFibGZXaEVkaWRkZ3RkWmRFYUZodWRTZW1lUmY1ZVNmeGNSY3hoSGVSYjFlTmJHYlZmWmcwZWJoamU4YzFkYmcwYzRlcGNGYWhmbGRNZ1pmRWVvZE5jVGQxYmtnTGdOZlZmTmFDZk5kRWhoZ21jYWhSZVJkeWJUZW5iTWZRYVRiRWExZVJoU2hSY1ZlT2ZhZVhkUWdZZmNmRWNGYzhjQWYwZHBhRGFhYkJhRmNnYlJlVmVGZW1lY2NGaHRjbGhEZTJoMWJVZkZhRGdsaEliUWh5YzBmQWJCYjJkeGQ0ZlFmQWdBZGZhY2hCZXBoQWVSYXhlNWc2aFZmbmd4Z1lnWmQxYUZnT2ZlYVVnc2dVaGNlUmUwaGRjVGRSZWxmV2ZkYUdmNWcyaGNlMmE5aEdiWmF4aFljU2NEYnpob2ZFZlJlQmNzZEtiWGNqZ1ZjQmVhaEdjOWJpZFpibWZrYVVhY2ZrZDVmemZFY0VmeGdOYlVjVWhrZVZiVGNtZGthcGdNZm5hQmNCY2RkRmhGaEtoVGFuaFVkUmFjZzBmeGNSYWVoSGVCZVdnZGRBYzhka2dVZmdkbGV4ZERkd2ZoYlNlVWgwYzlna2ZhaGxlTWFaYUVmM2FBZ0xiV2NWZVloU2dlZWtkZGRrZ1FjU2MwZUZoS2JpZzBiQ2NXYmlnUmVZZEJobWNjaFpjVmNuaFJidWNkZW5oTmV2aFJhbWZjZVdlRWZrZnhoMWZTY2thMWY0ZlJjQWJ0Z3diV2RrZ0pjdmZZYW1oWmJwZEZhSGRKYk9kY2J4Z0FmRmdDZTFjRmhCY0FlRmRoZDZlWmhnYmhid2hYZTNmUWhZZlFkMGg0YXVnT2czZk5oTWNVYlhlaGN3YlZlbmJRaFBmYWIxZ0liVWZjYVVnWWNUZ2VlRmVOaEhjTmNtY3BmZWJCaEJmTmFqZ0FlbGdsY0lkRWduY2RiV2ZaZkVjZGZvaFNiaWF4YjNhR2YwY0VlaWdWaFJoVmJmY0Nma2E5YzRmYmRtYmRicWJmZWticGVuZUJld2NwY1ZmZmNFZllkUWhXZ2dlc2RMZmJlVmNvYkxiWmNuZGxjTWVhYlJjUmN5ZFRnbmVNZFFmVGFFYzFjUmdTaFJoVmJPY2FkWGZRZVllY2hBZ0ljN2NIZHhkNGhIZk9nMGNRZTJoVmMzY3RnNGFjZ0ZhWmYwY0RjMmJ0Z1NiRmdIYkZlR2RFZTNmaGFUaFRoemdsYUFiVWV4ZWtjVGZjY0FkdGJaZVZiaGJKZzZjUmQyZ1JmQmFiZWtlb2F0aGVhVmNZYVVoZWVSZFVlVmJBYmhnbGJiZWRmSGJ0ZWplWWNYYVphUWViZmhhWWRPaFVjSGhWZmJiQWJGZnRjRWNWaDNiQmZTYkNiMmU5Z3ZmWmNuYXdkQ2dZZVZneGRqZkdlVWRWZE5mV2VrZWtoRGJXYzNleGduY0RjbWd0aHJoZGZGZEZnS2RUZG5kVWFSZmNlMGR4YVJiZWNIY0JhV2ZLYVFoOGd1ZUhha2NjZzBlUmJsY3hhNGFWZVVibGdrZFliZ2ZFaFpnSGhtaDBjTGdTYmxhOGRTYVpmRWNkaHBmVWZHZzVmTWVZZG5ka2hEZ0djaWhGYUliVGFnYlVjUmZSZUdhZGgzYmVkbmZOYStjWGIzYllmYWFFY2xnMWd0YlVieGhsaEpkYmNnZHRid2hXY2tnSmZ2ZVlkbWdaYXBjRmJIZUpoT2NjZDFja2VLZ1RiVmNsZkJhSGJRZEZncGJhZVJmZ2MrZkZiRGdnYWRkUWgwaEpmMWVBZ0djRmFVZ1VmV2FaZndhSGQzZzBhR2JhaHdja2UrZmNhVWhZYlRmZWFGZE5nUGhaZEdocGhUY0diUmFOZndiQ2YxZWtkZmZWZ0hhcGdQYWJiQmhOYXVmUmUzYmxiNWRXZmhmMWd4aEFlUmQxZmRmRWVGZ1lhMmZQZERjTWN5ZUpoRmQxaE5nRmNoZ0plTWNkYVVhb2dRZ1Vja2FRZUxjY2NGZHBoQ2NiYTJlSWh1ZlpkMGVRYW5jSGNUY3NjWWZCYVVkUmRLY1lneGhWYU9kYWZYZ1FkWWRjaEVhRmMwZlVmVWhwZk9mZGhVZXhlemVDZVJnMGFyYU5lVmhZZzliU2VXZHRkYWFCYm1hRmhTYUNkM2doaE5nVGR5ZDFnamZVZzBjSWg1aGNjQWZ0Z1poVmRoZ0poNmNSYzJkUmVCZ2Joa2VwY2tmZWdVZ3RnZGJOYXhhMGFWZlJjVWN0ZVdoZWJYY05lMmdZY1dmWmFHaGVmeGVZY0NiUmZYYlVlSWZRYWhmY2JGZlFnR2Z0ZXdjUWVtZDloaWFaZ21la2JVZmNna2U1Y3piRWNFYXhhTmRVYlVmbGhkYVFiRGZrY2hiU2F6ZGhiSmVmYkJiaGFLYVVnR2NzZlJjWmJVYVZoUmNKZEhlQmFIZmJiUmMxZ25mVWFoYnhkbmNWaFJiTmcrZVVmd2VaZXRkYWFnZThjWmJBYm1mSWJUY1VlRWUwZjRmZWFrZmRha2FRaFdoNWFLZlpoSGFsYkxhRmVIYUVoZGRRZ0VhMWRjZkdhaWhjYnJmZGNqZm9ncGZSY21hOGRBZUJlMWFsY21mWGJCY0JlTWJSZEVkSmI1ZldjaGRsY0ZiWWVtZFpkcGRGZkhjSmZPZGNmeGJCY01mVGZWYUZiSmhGY1VnNGhnZE1jaGRoaDRlU2hTaFpmUmFSYjFhTmcxaEFjbmVwZE1hVGdYZGhiZ2NYZTNlUmVOZE9jUmJkY1ZoT2hsZjBkNWRlYkZoTmhQZFpkR2RwZVRnR2dSZ05md2ZDYTFjbGZXaEVobmVvYVBiYWRoZEVlN2FHaFNneGV4YVFiMWQxZnhhQWd3YU5kTmZDZkViUmI5ZWJjaWVwZ3phZmZWYlJmemdHZmhnSmNFYmZiUWVNZlFoVGhGZm9lTGFaYmxmTmhDY2FlV2VKZXdnZWFoaDFheWhFaG5iTWJCZVhmbGNWaGRoU2hSZzFoWWRlaG5kUWhlaGNjQWhoZTllVWhSZFpoT2NaZkFlTmRyYVJnVWZwZ1NnY2VGaFpnMGREYjJhdGFTZ0ZjSGFGZUdnRWgzYmhnVGFFYm1kUWR2YkhjMGFwZVdmY2JGZ0JhemVWZGhnSmU2ZVJnMmFSZEJjYmdrY3Bla2hlaFVlc2VVaGNnUmUxaFVjQ2N4aGxjZWhkYldlWmZuYVlkbmI1aFNhZGJnY2NoQWVUY0didGJLZldnVmZ0Y05mQ2J5Y1FkU2FFZUNhQWIxY1pmaWJkZlJiSmhVYzRkV2JRZmhkNGRDYUFkMGNFZ1hhSmh5YWNmaWVXZVRkd2JJZk1lRmdFZkpkQWJUY0ZlVWRjZ3hod2FlaE1nVGU0aENnZGhnYlpmd2VlY0JjUmd4aFJhaGFOZDRoVWMwZDlla2NhaGxmTWJaZ0VoM2FBaExlRWFCY0FhU2ZjZ2tnOGQyYlFiV2VOYlhjWmNHYTFmQ2dGZ0dkMGdkYkRkVWRRZFpoRmZDZlllcmZOZ3plaGYwYmJlR2FjZldhRWZraHhjMWFTYmhlQmVTZ1JhQWF0YndhV2VrYkpodmFLYW1jZ2Y1Y1FhU2VFYUdnZWd6aHBlTWFUZFZiRmVKZ0ZkVWY1Y3BlZGZCYmhod2FRaFhmUmNSY1Noa2U1YTFjR2hUYnBmTWhUaDJiWmN3Y1JjMmJ3Z0dlYWR3YzRnVWZZZzFkSWZEY2RmSGJsY1BhWmJHZXBiVGJHYVJoTmJ3YkNmMWFsaFdoRWhuaHBmSGhaZkVjRmV1Y1FlbWd3ZndiU2R3ZXBldmdIaFFheGVmYkViRmVaYnliYmhtZUJoZ2NaZGthWWM3YUZnZ2hOZGViYmVVZ1lmNmhVZmtmUWNMY2NhRmJwY0NhYmgyZkpnbWhhZ1JjUmh5ZlRnbmVNY1FkVGJFYVZkWmRBZkJnVmVRYmRmM2FRZ09nZWVVYkZleWVVYVZheGJkZGZjQmFFZXZhVGZFZEJicWJhYkZocGJlYkRnMmh0YVNoRmhIY0ZmR2JFYTNlaGVUaFRnMmNSZnFlVWJ4YmthVGZjZ0FhTmhQYlJlUmVKZThjUmN5ZDFlSWViZWhnWmNrZGFkRmNrZk1kV2d4YzBnZGZUZ1JkbGNXZGRmR2E1aDJnY2EyZDloR2FaZnhhWWRTY1JjV2c1Y2dmRWVGYkplRWRDYTNlQmdhZFFkbWU5ZmlnWmNtZ2tnVWJMYjJmUmJ6YUVlRWJ4Z05jVWhVYWtkVmVUZ21ibGcwZFJkVmJwYUJoZGdGYUZjS2FUZm5jVWhSZmNmMGd4ZlJnS2NqYVViQ2ZJZVZnMGJsZ1VlbGJ4ZXFiYmRCaE5kNGJVZzBhOWdrYWFmbGVNZlpiVGNsZ29nTGdXZVZjWWhTZmVna2hkYWtmUWhTZmdoZmdLaGpob2FmYlhjVGU1aFRoSGFUZnNiUmJBZm5nMWZ1ZkxmVmdsaHZiUmhtaGNiV2NFaGtjeGYxZ1NnaGZCaFNnQWdrZ1FhaWZXYmtmb2I1YkliemRSZnBoUmNuY0poVGRjZTJkc2h4aFFhVmNFZUFiRmhWaE5ncGRaY0FnTmd3YUNjSGhSZk5mU2doZnBhN2hYYVRkWWVDaEZiaWh3ZTRoVGVYY1FnRWJZZUJlc2dkZldkMGZZaFRkZWdGZU5jUGdaYUdicGNUZEdnUmdOYndnQ2d3ZnRhWWJRZGliOGVVZkxlRWVsaDhiWGEzY0ZmNWZUZVJjUWRsYkVlMWY0Z0ZnV2JBYlFnWGJJaFRiSWMyYkRjaGJKYnZoWGR4ZnRkRmNiZG1nQWFRYlVna2FRZkxhY2dGZXBjQ2ViZzJhSmJtZU9kMWJFY21nR2J5ZkZnZWVUYUJnOWRLY1lkeGVWY09kYWZYYlFlWWJjY0VkRmQwZURoR2FCYk9iZGhSZEZoemhUY0ZoRmE0YWNlQmJBZ2hiUWNTY2dmR2ZYZ1RkNGhJYkVkeGZKYmJlR2YyYWhjcWdBZlJmQWJUYUtjeWNGaFphVmVoZEpiNmRSYTJoUmFCZGJia2JwYmtjUGN3aFJkR2hjZVJhVmhMZURiRWV0ZldlUGVXZUpjMmZOaG1kTmNHZEtiQmNvYlNnQmJIZFZkWGFFYkNia2M1Z0JiM2FBZ1VnUWJuYUpkaWVkYm5jSWJVZ1BmRWg1aHZiRWZCZWhnRGhIaFFheGViY0NnVGQwYzhkR2ZIZ1plSGJkZUZiQmJDZFJhaWFjZlJlZmVsYUZjUmRhY25jbGZXaGFlQWg5YTdhV2F3YjlleGhUYVJiZ2gyZFdjbWJWZWtjYWJsZU1iWmRFZzNiQWZMZldlVmVZZlNiZWFrY2Roc2JDZkdnNWNYYlpkQ2MxYUZnVmh6ZWxoY2hUYXllNWRXY0VjamJFZ1BoSWduZ3NoaGRUZTJiNGdhaE9iRWd4ZjFlU2RoZUJoU2ZSY0FodGZ3Z1dja2RKY3ZlWWFtZlpkcGZIaERmZGZPYmJmaGRBY0ZhVGZVYzlkWGZGYlZhWmhnZ2VlRGhKYXdmUWhYZlJhUmRTYWtlNWgxZEVhWGVOYU1oVWdYZGhod2FWZW5leGVBZWFhMGE4YVVmT2VFYVlmV2dlYUViRmZhZWNkbWdOaGZhTWJ4YU5kd2RDZDFobGVXZEVlbmNwYUhjWmdFYkZidWZTYW1hUmY1ZkFleGVvZWhkU2JFZTRmRmFFZVJhbGY5ZlljbGF4ZXplYmEwaFpobmJGYWhnSmVNYWRlVWVvZFFnVWRrZ1FhTGFjZUJnSmdNYVBjemNjZTFnSWVSY3djM2RSZTJnZ2Q2ZVRmRWgxZFJkU2RSZFZlT2hhZlhnUWhZZWNhQmVNYXhoQmNSZzhoY2NPZ3hkRWU3YVZiM2Z0aDRmY2dGYlpoMGFEYTJidGNTYUZoQ2Z4Z3NjRWUzY2hmVGRUZzJoUmNxZVVjeGRsY1ZoSmhVaFVmYWRBY2xjc2ExY0NiV2RRYzdnWmNoYzVndGNlZFJoQWgrZmNnUmUwaGRoVGdSYmxjV2VkZ0djNWIyZmNmemIwZ0RmTWYwYk5iQWNBZm5mVWY3YkhmZ2FZaExlYWRTZmtkT2FCZndhNGZ3Y05hQ2NoZ05oZWZpZmhkN2hSYUVlVmhFYVNjbWRNYlZoVGhtY2xmMGNHZUhoQmdCaGRiQWN4ZGdkVGduYVVkUmdjYTBmeGFSZ2VkSGJBY1FiSWdVZkVkb2NCZ2xlMGMraENoQmdNZWZkV2R4YXRib2FhZWdlRWhWYUVjemNrZ0hhV2FSaE1mYmZlYmhleGhPZVFkV2g1ZkthWmVIaGxoTGVGZ0hoRWVkYkhnUWR0ZFdnQmJIZVJhbWRJaERhSWc5Z1JnaWdnZ1dnRGgwaHhmbGhVZFJjQWJYaFJnQmRWaHdlRmdVZEphcGNaZ0dmWmZvZ0hjRGgxZk9lZWhCZEFjRmRUZVVlOWRVZkZlUmN4Z25mT2VGYTBjK2JCZGlkQWNaZVNlaGhJYnBlRWNUaHhjTWhUYzJnVmN3ZUFkbmNwZURjTGdoYXhkVGZKZVFjNGFhZFlkMWFOaEVnYmR5YlZiYWVNZXhjTmF3Y0NjMWVsZFdmRWduYXBjSGFaZUVkRmR1YlNnamRZYkNlQmFCYlJjNmdIZ1ZnUWJ3aEdhVWR0YjBhT2hnaDBiOGFFZWxjMWJOY0ZnaGVKZk1mZGdVZm9kUWdVZGtjUWJMZWNlQWdnYkhkT2N6ZWNlMGNKZnhhUWU5YlZoVmVrYVFhVGJFZjFoUmFTZVJmVmNPZGFjU2FrZnliY2hFZEZnMGFVaFVocGNPZ2RiUmhFYjFjR2hSZDhkN2hKYUJoOGQ3ZFFhV2hzYzVkSGhDZFZhUGhFYXlhTmQ1ZVRjMmFSZnFiVWJ4Y2tkVGRjYkFhdGRaYVZoa2hBZi9nRWR6ZkVlVGhJYkVkb2d3Z2VjVWhvZ0piYmZCZDFkSmVWZGpiTmRXaGRnR2E1YjJjY2IyaDlkR2daZTBhc2U0Z1RhSGFWY0tnRWNGY0piRWRDaDNkQWNNY0FiemMxZGljRmUyZWtoSmdjZGdjZGc3ZUJkVWZWZEJiZWYwZGtlVmNUYm1jbGgwaEdhSGVCYkJoZGNGZEVjOWNUZm1jZ2NSZE9ma2dSZEhhY2FYY3hoOGZkYUFoOWFyZlViaGRSZXhhUmhoZE5oNGZVZTBodGNnaGFia2c0ZFpmV2RuZ2dkY2FVY0VjMGY0YWVja2VkZmtlUWJXZDVoS2daZUhjbGFEZFJkbmQ5Yi9iU2NBYnRoZmRFaHliWmZ1aGFiM2RNYWhiVGYyZXNhOGJFZmtmeGExYlNmaGhCY1NnUmFBZXRld2hXZ2thb2c5ZWJjQmNVZWxoV2F5ZlVnc2hKYmxnWWZLZUNmQWNOZUpjQ2FFaDRmV2hmaFJiUmdhZlFhWGFSZFJiU2VrZjVjMWZFZFhiTmRNaFVkWGJBZ2lmV2FCYTFhaGJHaENjSmR4aEVhamVKaHNmRmJUZ0lmM2JHZHdhZ2NxY2JjWGRZZkRlQ2QwZlJoV2RCZTJjcGJPYWFmR2F0ZHVlU2FtZ1JmNWhTYnhjUmJ4ZUhlUmQxY05lRWZSaGhlNmRHYWdoOGVEZkNiaWZJY1lkZGIyaEFiK2FGZURjTmN2aEllVGRGZzdkQWhEYVVkd2FHYjJlSmI3ZVFheGVSZ3lmVGJuZU1lUWhUZEVlMWhSZ1NnUmFWZk9oYWhTZEpmWGNPYVFmVmgwZ1FjVWFwY1BiYWNBZ3hnemVHZkZiOGVNZENnU2VZaFJlYWN4ZFFnemhaZ2dkTWZuZmFkZ2VjZ2dlT2RoZ1FkYWdQZ0dmdGhuYmNiQmVSZlpmQWdoZndiT2hQYWhoUWdrYUNlamVVYUZoQ2h6ZGxjMWhDYkdmSmN1aE9hR2drY21nR2V4YXdiQ2VjZjNiVmRHY0lhaGU0YWJkUmZYZWxnZ2dFZkZlSmhFZkNlM2RCZmFlUWFtYTllaWhaYW1nRmhHZmZnQWZVZWVkVWhSY1FiaGRGYUFjZGRTZUdmaWVGZTBnQmZYZkFnT2ZmY0ZnaGhEZVFkbGQ4Z1JmY2UwZnhiUmhlZ0hkQmFXY2RlQWE5YXJnV2FsYXBlL2VGZWxid2czaEhlemF3ZHRmTWZCZllmWmREYm5lQWNUY1NnRWY4aEFoY2UwZnRlT2JRY1dlNWRLZFplSGZsZUxkRmhIZkVoZGVIZlVhVmRYZVdoQWJzY3ZlSWV6YlFhaWVBZnlibGdDYUVkbGhGYTFkRGZFYVVhY2FCZTFoOGM1ZkZhUWV4YnZjYWdqYUpoZ2VGZ0NobGFrZWNleGVCYk1lVGJWZEZkSmhGZ1VjNWVwZGRhQmVoYndhRWN6Z0VjRmFIaHhjd2U3ZkVnWGdzZ1lmWGN3ZmNnUGRCYWllWmFBYVBkeGIxZnJmRGVrY1lmT2FlZ0JjMWVCZk5oRGdnZGNmVGNWYXdja2hVZ2doa2VUYUdlM2daZ0hhTWVGY3BoRWJTYm1nUmI1ZFNjeGRSYXhkSGFSYjFlTmRHYlFhdGI5YllobGd4aHpiYmEwZVpobmRGZWhkSmJNaGRhVWFvZlFnV2ZnY29kRmVOZGdhZ2NOYUlkbWJKYTdnYWJWY0libmVBY0RlQmRFYkJiUWdJY2ZlU2JSZTBoYWNaZ1hkUmdLZ2ZkRWFFZTloV2RFZG9jVmVYZXhkRmV6ZFRiRmRGZDRoY2FGYVpmMGZEYjJldGFTYkZnQ2VNaERiUmF5ZDBnQmdBaFdmUWY1Y1dkMWVkZUdlUGJFY2RmVmVWaGtiWmcyaFJlemhaZk5kYmJnYk5hdGVZZW1iRWJVZ2NiUmIwZWRlVGFSZ2xlV2FkYkdlNWcyZ0xmbWJaZktmVGZSZllhU2NUZEhhVmhLZkViRmFKZEVoQ2IzYUFlVWFUaEJoc2diZEZnZ2h4YndiRGZTZDhnQmRZY2lkMGMwZ0xiamZwaGdlUGVoYWthYmZhZWdjUmJCZWNhbGVkY2dmVGNuaFViUmhjYjBheGNSYmVhSGNCZVdoZGdBYzljcmRXZmhhd2EvaFNiRWRNZXFiSGhCY3NicmRQZ2dlcGNKZFZmbmY1YjBiSmhnZ1pjQWhOZlJjTWhyZVBkaGZGZEtiZWVYZmtjK2FYZFRmOWFKaEJhU2Z4YkxhQmREY1VlM2hlYkNnTWY5ZENlVGdOZlpiUmFoY1VjbGREZHhjbGJlZ2JnZ2F0Z3dmV2ZrZ0pmdmJZZm1nWmJwYkZoSGVKZE9oY2Z4Z2doQ2ZRY3lhNGEyZ1JiUmR3Z21hSWFGaGNoUGhQYm5mUmFNYlNjamdzZThjWGJ5Z2RjVWJNZ0Njb2JpYUZneWQwYUdmWmgzZmdoVWhjZFVnWWRUZGVjRmNOZ1BjWmVHaHBmVGVHZVJoTmd5ZlhoaGZjZ1NoVmR6Z3doT2hLaGdhUWdxY1NkR2hSYjRkVmFoZFFhbGFSYUVkMGNJZlZlaGJCZDBkSGFTYzhjK2dMaFFia2FyaEZlaGVSZktkWGIwZW9jUWFVZ2tiUWJMY2NkRmJwZkNoYmUyZ0pobWFhaFJjUmJ5YVBhU2VwaGRjRGVnZUloZGRSYjBiWWFlZExoRGVkZ1JiTmFSYUphMGNWYTBheGhrZ2RmUmFGYnpnVGVGYUZhNGhjZEZnWmgwYURmMmV0Y1NoRmFIZ0VoSWVhZkFhc2dLZUFkaWZZY2xnSGh4ZGRkQWZJZkVkNGNhZUhnMWdjZHBlT2RtaFJlY2RjZjFmZGZrYk5mMGJzY1NnZGN6ZGNkZGhUYlJnbGdXYmRlR2M1YzJmY2QyZzloR2VaZnhiWWFTZ1RhQmZvZEloV2NoZWNkSGNYZDNkNGNlYkJieWJraHJjS2FDYnhna2FJZUFnRWhqZVZlUmI0Y1poQ2VFY0ZoYmdRZ21la2VIZFFhVGMwYURiT2J4YjFhRWVIZFNjVmZVYU1jQWdVYlViS2gzZXhoV2dMYnloVmFyZFVnaGJSZnhiUmFoZk5lNGFVZDBjOWdrZ2FnbGRNaFpkRWgzZUFmTGJEYXhjZGZlZ0xjd2NKYitjUWJTY0FjZmNLZ0RmVmFIY1BjbmdFaGRjSGRVYzBjWmhWZ25mUmd1aGRibmVOZHZhUmhtZ2NnV2dFY2tid2IyZUJmVmg0Y1VkRGhVaHdmbGFDZ0FmTWd0ZkxoaWROaHpoRmNIZU5lZWhmYXphcGZNZFRiVmFGYkphRmFVZDVhcGZkaEJmaGR3ZlFiWGNSaFJnU2FoZ05jOGFHYkhoOWZtZlVmWGVoZ3dnVmRuZ1FhUGJhZzFiSWFVZ2NkVWQ1Y2RkZGdoY0ljRGhLaENkVWRRZ0dkUWg1ZXdlVGRRZndkWWdVZVNmNGdPZEtmd2g5Y3VlUWFqaEJlMWJTZDBiWmM5ZUhnVmRSZ0VkR2VRZjFoZWFiZ25oWmJ6ZmJoMGRaZ25kRmVoZEpoTWVkY1Vmb2NRZUFiQWFGZ2ZmSmFRZ2diTWdiZHpoZGJ1Z0plMGJFYStlQWduZThoUWVHY0VhRmhSZ0dmeGRsZU9iSWNIaDBmRGNXYmtnRmcwYVVmVWJwaE9hZGZSYUZlemdUY0ZjRWVsYmVnVmdwZGVmRGEyYnRoU2JGaEhlRmJHZ0ViM2ZoZVRhVGIyZndla2JYZVZlaGhmYVBhRWFRYWFhSWcxZXdhcGVCaGloSWJFY2JobGVkY2thUGd4ZjViYWVNYWtkbGhVZkFnbGZkaFdiZmVEZnBiL2hjZnpjUmZzZlpmeGdZYlNhVGVIYVZlS2dFZUZnSmhFZkNjM2ZCYWFoRWNDaG9jMmhNY3podGVhaGNlZ2NoYzdiWGdoZWtjQmVIZ1VnVWNWZkdobWFCZHZmTWduZUJlQmNkaEZnRmZLZFRobmRVYVJiY2UwZHdjTWNjaFhjeGU4Z2RlQWI5YnJiVWFoZlJieGFSZ2hkTmM0aFVmMGRjYnFnWmhCZ0pnVmhYYXplOWhJY0xkQmhoaEJhT2R3ZUVjaGNNZmlkSWdGZ01hM2NsZFdoRmVEaGRnSWJVZXdoNWZOYkhiemZzZGdiZGZuZ3NmN2JUZTJlZGdOaE9hRWZ4ZjFjU2FoYUJmU2NSZUFhdGh3Z1dja2hKZXZhWWFqZ1Flc2ZRYkNmY2VjY1BoUmNBZ0toUmRSZDhnY2dXZlFhSmVsYmRhRWJ4ZTVkV2JsZDVjUmJTYmtlNWgxYUVoWGNOZk1lVWhYZGhjd2VDZTNjMGNEZ1FkVmRJYlVnY2VVYlllVGVlYUZoTmJQYlpkR2VwZ2JiVmN4YjBkNWVXZkRnc2JEaFZoRGd3YkNkTmZrYUZiemdTZmliSWNzZkJjVmdjZ2xiVmdGZklkRGdHZ1ZmNGJnYVpoM2FZY29nUmhVYVpmbmhGZ2hoSmdNZmRjVWRvaFFmVWdrZVFlTGZjaEFlZ2FIZU9kemZjaDBjSmZ4ZlJjemRSYmpmMWNGaEFnQWRGZVJiVmZBaGhnT2hQaFhjUmJFZkxjRWJGZjFiQmVVZVFneGhQYUVlSWZSZkdlUmRjZytjTmRRYlJjOWRGYUVjRmRTZEZjSGdGY0djRWczZGhhVGJUYTJnUmdxZERmaGVBYmZjV2VnYXRhWmRWZGhnSmQ2ZVJjMmhSYUJnYmdrZnBoc2hOZDBoVmVYZ1BkbGRCZ05jRGJFZXNoVGJkYkhnTmUyYk5nVGFvZ0lkSmdFZ0poYmJBZ3pmdGVLZ0dnQWNaYUlnQ2R5ZkpjVGFRZ2pjUmFJYVphbWVrYVVjY2JrYTVoemVFYUVkeGhOaFVoVWRrZlZnQmZ5ZzlnMGhFYUhkRWRQZmVlaGdnZVpmTGdDYkJnWGdOZVFka2REZmNmQ2NSZmZmZGNGZE1kM2VVY2hhVWYvYlNnRmFvZHJkTWZSZm9naWZMZEJlWmVMaEdheWZJZENmVWRIZndoU2NlYmthZGFrYVFiV2M1YktjWmJIZmxnTGVGZEhiRWFkZ0hlUmJsaFJiQmZEZ3NiNWZkZGphMGRxZUVhV2hkZ2ljU2d4ZXdod2JMYzBhSWRBZUNnMWJsYjRlV2NDY01kOWFKZlRjTWhraFVlVGd3Z2FmSWNCYkFjQmhHY0FhSWNkY0ZmUWd3YXNhZGZIYW9nbGJCYXpnSWNVYkdnQmIxYTNkR2dHZWhlbWRVZFhnaGd3ZVZmbmJRYlBlYWgxZ0llVWNjZFViWWJUZ01kUmVWZVBnYmdEZjViVGNCY0FkNWN0ZUNid2J0YWZhRWNpZmdmQ2NNZ0JoUWY4ZUJkR2ZSZnBnVWFEYzVoeGRIaFJnMWhOZkdkVmdaYTBlYmFuYlphemZiZDBjWWJoaFdiVWRCaE1kZmZXZUFiUWFVY2tiUWNMZ2NmRmZwYUNhYmIyYkpnbWVhYVJmUmF5ZlRiaWNWZ1JiSGFrYzBhWWZTZVFhaGFPY1BoWGVwYVVnTmRRaDhhemJCYVFmSmZDaGRmVmZSZHpnVWdWYkVncWdmZ2hjb2N4ZFFiU2h3Y0diWGZIZzFiR2hYY0hoaGhPYVRlM2dSaG1kVWQxZEVmVGZiZVFkc2MwZ0ZmMGFZZ3lhU2dTaGtlSWVJZ0ViSWN0Z2RmVWR0ZVJnZWdBY1lmM2RUaFJmbGJXaGRoR2U1ZDJhY2cyYTljR2ZaYXhhWWVTZlRjSGFVZUNjRWNFY3hlRWVSY0didGF3Y1FhbWY5ZGloWmFtaGtlVWdjZmthNWh6YkVkRWh4Z05lVWNVYmtiZWRSZ1NhWmFlYUdnSGJCZkJiZGZGZEZlS2VUaG5iVWZSZ2NkMGR4ZFJmY2VWZnBoV2dkZ0FoOWJyZlVlaGRSYnhoUmFoZE5iNGdVaDBiOWFrY2FiaGJwaGZnRWIzZ2hnZmVJZ2hobGd2aGVoa2FaZzVkWGVHZDRoWWVIZHpkWWUyY0hnWGdGYkdiTmUwYjBlWmJWZG5mUmZ1ZmRmbmJOYnZhUmVtYWNkV2hFYmtieGgxZlNjaGdCYmFkRGFRaHRjdGNXYWhhWWZVZ0xmUmV0YmdjR2dIY0plR2VOYWhiQmVSZVRmUWNNYXlkV2JqZU5kZ2diZ3pnSmd3ZlFmWGNSY1JmU2ZrYzVmMWRFZVhoTmRNZFVjWGhoY3dlVmZuZVFjUGRLYVFjQmdSZU1oQWMwZkljVWVsZU5lUGNaZUdlcGhUZkdoUmNOYXdiQ2UxY2xmV2hFZW5icGJIaE9iV2Z0ZHVmU2ZtaFJoNWJTaHhmUmF4YUhlUmYxZU5lR2ZWYllibWZLY3loSWJtaFBoUWVoZm5nVWd4ZkpiU2NkYVFmTWZRY1RoVWZRYUdmWWhWZHBkWWhiZHlkdGhtYmRneGZRZTNjVGRtYXdoUWRYZ1VjMWZMY1NjUWZWZVZjUWIzZFFkWWJjaEVjRmIwZlVmVWZwYk9iZGRSZkVhdWZSZlZoMWhTYWNkRmRaZzBjRGEyZXRoU2ZGZEhhRmNHaEVoM2hBYWRhUWJTZDBlNWJOaGxkZGFRZVBoMGc4ZFFmR2NGZFZoNmZXY21oUWVIZ09kd2JRZm5oTGVRaEpnYmhQYnhlMGdWaEdnUmNCaFdkTGgwYVJnMmhjaDJhOWFHZ1pjeGVZZ1NjVGRIZVZnS2hFYkZkSWhYZVhkRGNrZU9jQWFTZmRmaWRiZGhkcGdBZ0lhQWFjZTlkVmQwYVFiWmRXY0ViZGZCZ0FlUWVVZjdnVGh6YlVmVGhGY3hjQWFaZkNkM2IwZFlkZWFrZndiS2ZVZG5hQmZXZ2RoQWM5YnJkVWJoYVJleGFSZWhlTmg0aFVjMGU5YWtmS2hSZ0pnS2hWYW5kQWVKYUVlUmJOaEtjZWhGYTFnT2JRYldlNWZLYVpmSGdsZkxiRmZIYkVhZGJIY1VhMGhaYlZmbmNRY3RmTmF5Y0FjcWFSZW1kVmNEYlJiZ2ZwZ3RlU2VBZHBiNGhSaEFhdGF3Z1dia2JKZXZiWWZtYlpicGVGYkhmSmhPZWNmeGdBYVBmRGNBZ0lhTWRGYVVmd2U4YkloRmE1ZjllV2JYY1poTGZZZEVoNWUxZkVjWGNOaE1oVWNYZWhjd2RWZm5kUWFQYWFjMWRJZlVnTWdnZGRjQWdQZ1ZhTmROaEpmVGFrZFFoVWJGY3BkeWNFY1hkTmRXZkVnbmdwZ0hmWmdFaEZkdWdTYm1kUmU1YVNmeGVSaHhmSGNWYjRjTWdTZ2hiTmEwZ2JkRGZvZHlkT2R3ZjhmcGhCYXhhQmVXZFhkMGNvYVFmVWVrY1FiTGdjY0ZjcGNDYWJnMmZKYm1jYWVSZlJjeWJEZ1RjSmREYkNoVWExZVRkQ2QxZHdoQWJLaENhWmFCaGNlbGZ0Z2VjVWRVZnBjT2NkZlJkRmF6ZlRmRmRGZzRkY2FGY1pkMGREZDJjc2JSYVZoU2RJY0RkRWYzZ29kUmFEZ2pjY2h2aFJlUWEwYVJlYWNpZUZmWmVWZWhhSmg2YlJnMmZSY0JoYmFrY3Bla2FlaFVjc2FVZGNjVmc1ZWNmSGNsZnhhV2dkZGpnc2QxYUlnSGIxaEVkZmVUZndiU2FUZEhlVmRLY0VkRmJKYUVkQ2gzY0JoYWZRYm1lOWhpYVplaWdwZFZmSWZRZHRoemdFYWhoa2dPYUFla2NRZkhiVGNIYU5nZWVHZEhiQmhCYWRiRmNGZ0tnVGhuZlVoUmNjYjBneGNSZGVoSGVBaFZmTmFWY3djdWRVZWhhWWhrYkVnbGdWZ3BiUmVRaE1kaGVhZkVoa2V6ZEVoM2FBYUxlV2RWZVllU2ZlYWtlZGVrYlFlV2Q1ZUtjWmJIYmtnSWNWZ1NnSmFZaEhkVWU5Z01jQWdqYkpjamVaZTJmVWVqZEFlMmFVaE1iT2hFaHhoMWdTYWhkQmdTZ1JhQWh0ZXdnV2RrZ0pldmNZZm1oWmZwY0ZjSGNJZmNmTmVrZVFiWmNIaHhkOWFKY0ZmRmU1ZnlnWGNoYmhhd2ZRY1hhUmhSZ1Nka2c1ZzFjRWdYZU5lTWNVaFhkaGF3YkVjamdGZUpnS2FnYWRoWWdKZ1Zhd2c1aGVmRmdOY1BhWmFHYXBjVGhHZVJkTmN3YUNjMWZsZldoRWNuYnBlSGVaaEJiTWRyZUhnamVFZ3JiQmVSYVJid2JEZ0FkWmduZkdoVmdaZTBnYmFuZ1plemRiaDBkWmZuZ0ZhaGdKZk1mS2VHZUFoUWRVZWtmUWhMY2NnRmNwY0NlYmQyY0phbWdOYkJkMWgrZ1pnSGNNYVFiVGJFZDFjUmRTY1JjVmZPYmFiWGdRZ1FiUGFrYzhlM2ZIY2dkUWROY05mRWZWYXpoVWJWZEVmK2FKY1JiZ2QzZVdleWZJZ2RiV2FuYkZlT2dSYzNmUmdUYUhkV2QxY3FhQ2VEY01iVGZjY0FldGNaZ1ZmaGdKaDZmUmEyZFJkQmNiaGtlb2V0YVBlMGRzZWNoY2JCZGthWmRSY1VjMWZmZ2ZlVWVSZTJnY2EyZTlnR2daY3hoWWJTYVRhSGdWZUtjRWNGZUpiRWRDZ3llUWFTZ0VoQ2dBYTFlWmhpaGRjUmFKaFVlNGhIZVNnUmR3YkllTmhCZHRiSGZBY1RldGM4aE1ibmJCaEJoZGFGaEZiS2dUZG5iVWhSaGNkMGV4Y1JlZWVIY0JoV2RkZ0FkOWdzZlVnRmVnYjRmRmRVaGRiNmFVZHdlNGYyaExnUWhaYlViVmRqYzVlZmJXYlJidGdIZ0thUmROaGtnQWF5YXRiS2JKYlRiZGFMZ2RmU2ROZVBmWGFCZlFiWmFHZFRhSmN1ZkZkQ2JZZHBnQWFDYUpoRWdRZ1VkdGNmZVNkaGJCZlNmUmVBZHRld2hXYWtlSmR2Z1libWdaZXBoRmFIZUplSGNhZURicGJNY1RiVmZGZkpkRmhVZTVncGRkaEJkaGN3YlFnWGNRYlljRGFFZDVlOWdBYVhlTmZSYlRlR2JWZXdmQWZuYXBlRGRMZmhoeGdUZEpmUWI0YWFjZWhBZEVlS2NNZERhOGdCaFZneGJNZytnQmVSYWdoYWRYYWpkVWFFZ2JmRmVGaG5kVWhVZjViNWhTY3hjUmd4aEhnUmIxYU5mR2VWaFpkMGdiZG5iWWNsYUxkaGdSY25mWGF3Y2xkbWdkZVVnb2VRYlVia2ZRYkxmY2NGYnBlQ2JiZjJiSmJtZUlmRmNKZ3lkUmRpYVZkZmVCYVFhbGNSYldoUmZWY1RhZGRHYWtoWWVJaGthaGFlY1VoVWZwZE9hZGhSZEZoemVUY0ZhRmg0aGNnRmVaYzBmRGYyYnNnVWFXaHljTmhHaEdneWFwZFRjVWVtY1JnNmdYY3hjbGhhYmNiQmZaYlplUmRnY2xoNmJEaG1jUmVkYmJkaGg1Y3FoTmRRZTVhYWdOY2tobGFWZVZnaGVsZWRoZmN5Y2RkL2djYnpnMWNHYmJmQWJzY1NjR2hBaDRhRGFiaFZkd2NJZlRmamY0aGRjRmVpYmRjNWVUYUdma2JVYmNoa2Y1ZHpjRWRFZHhoTmJVaFVha2VWZ1RnamQ4aDFiU2JuaEFoRWRkYkVjeGNLaEFiSGJ0Z1FlUGV3YkFjZWZPZ3dnVWFZZkpiMGY0aHRhRmh4YndiamRUZnhlOWdTZlVjMGE5YWtlYWdsZE1kWmNFYjNnQWdMZldmVmZZZlNjZWdrY2NjcmhRZFhlTmhLY2RhR2NKaGhoRmVIZEVlZGdIYlViMGdaZFZibmJSZ3ViZGZuYk5odmJBZENnaGVFZkVna2FRYzhnU2hnYTFjU2ZWZ0JmQmR3ZkViMGRKZHphWWJqZ0phbmVXaERkY2VBY05kRWFRZUVlVmJsZ0ZlQ2FIZmdhZGFnaGRiRWJOZGFhUWNYZVJnUmVTYmtiNWcxYUVjWGROYk1mVWhYZGhnd2RWZ25oUmhaZEtlZ2NBYVVhT2NVZ1ljT2NlZ0FhY2MwZExhUmVkYkljTWZ4Y05kd2RDZDFlbGJXYkVlbmVwZEhhWmNFYUZjdWFTZ21oUmY1ZEFibGVKY3hkRmdSY3diRGZGaHhkOGJuZURiQ2JNYTFiS2FRZE1mMWRIZ2xmcGFGZ2ZnR2NBZFFiVWJraFFhTGFjYUZicGNDYmJkMmNKYm1lYWFSZVJjeWJUYW5mTWNRaEdiQWFVaERhQmhrYUpkT2ZKYnplRmJQYmNiRGNVZ3RkQWJRZThjcmhKYzBkTWM4Y0hlbGhsY1NjY2dGaFpoMGREZzJhdGRTaEZoSGdGZEdiRWgzZGhoVGRUYjJlUmdxZlVmeGZrY1RoZGZ3Z2tlVmZIaDBiRWV1YVJlV2ZRYkFmUGRBYzBoeGJOYUFiNWVhZ0plUmcxZ1FoR2dFZ29mQ2NkYkNld2Z6ZWNkeWc0ZUloWmYzaGRnQWJIZ2pnUWVUY0VnQmQwaENmQ2F4YUlmUGVCZkNna2VuZU5hRGNvYVRkV2NFZDVoemVFaEVkeGhOZlVjVWNrZlZkVGRtY2xmMGJHYUhkQmhCZmRhRmRGZkRiVmRWYzhiUmVjZjBheGVSZ2VjSGZCZFdjZGdBZjljcmJVZmhiUmV4ZVJjbGh0aDJnRWZBZEFhMGNNZzFkdGFjZEhkM2JCYkVoVWFGZ29hU2VjYmdnaGFrZVNmbmFOZ0toTGNIZ2NiSGhVY1RoOWNhYlNlUWRVZ1FmVGVWZTVodWNkZG5lTmd2ZVJjbWJjZ1dlRWRrZXhmMWFTZWhjQWdQY2JiZ2V0YndnV2FrYkpldmJZaG1iWmhwaEZhSGFKYU9oY2EwZ0lnSmZHZFFiUWhiZVdmMGc0ZXNoYmJ6ZEpid2NRZlhjUmVSYlNha2Y1YTFiRWNYYk5lTWhEZ0hmRmY4aGZkSGdRaFBiYWIxZkloVWdjZlVnWWNUZmVoRmdOY0hlS2RtZlFjUmVRYkVlY2ExZlpmeGJ3ZFlmVmFTZTRmUGZaYUZoeGR1YURibWgxZzFnWWFSYlJleGVIYVJmMWhOZEdlVmZaZzBiYmhuZ1pmN2RJYVVhZ2gzY1JkRmQwY1lnT2ZoaDVjSmZBYWdkRWJGaERleGdNZlJoRGNUZ2NiZ2NMYTFlRWNnZVRhbWg0ZlFoVGJWYzFjWWZSZFRhOWRPaGFiWGZRZVlnY2JFZ0ZjMGJVYlVlcGFPZ2ZjVmI5ZjlkSGRBZE1mM2hKZUJoa2dnZFZjamZzY1hiR2JpaElhUmRVZ2lkaGhDaFdjV2NSaDNnVWcxZjlhR2FQYWtjZ2hOZkhnMWIwZjBhUmUyYXhkSWJiaGhoRmNPZ2VlVWdzZVVnY2VSZzBnZGJUZ1JjbGVXZGRlR2g1YTJkSmRTaDRkVWJaYzBoSWJTZlVhWGRVZmVhV2ZCYXNiWGZCZVRld2JmaERkQ2JnYjJjTGhuaEloK2FjZGtlNWd6YUVkRWF4Y05jVWFVYmtmVmVUYW1mbGgwY1VmVGhaZEJnZmJBZlZmS2NTZDNkVWJEZGNiMGcxZk1jWmNYY0JlR2FmZlNmVmdyZFVlaGFSZnhhUmdoaE5jNGRVYTBoOWdrZmFlbGZNYVpjRWN5ZFJhRGhDZXhnbGZGYmVhZ2FrYmhoRmZtZDRkNGFKZlRnY2RNZVVmUmhSaFBmVGJ3Z0pkTGJYYW5hWWVNZUlkemFVZnBkQWd6Z1VmV2ZRYlFiVWJ2ZkRieGJBY2ZhRWRWZ2dja2dXaGdiQWRxZFljaWZkZXBmV2JTaGNoQ2RKaDFha2NjZEFjUmVSZ0pnV2NnY2hhcGRaYlFhNWU5YUFlemEwZkZjR2JVZ3hhOGhDZWxjbGNNZVVmWGdoYXdkVmFuY1FlUGRhZDFoSWRVZGNiVWhaYlZiTmR3ZEZmUGZiYURjd2JTZ1NmeGhNZmloQ2cwZ1JmV2hBYm1hRmRIZU1hRWdGZHdjU2ZqYlpmaWNTYzBmWmN4ZUZnZ2ZCZk5jQ2QxZjlkMGJPYVhhNGduY0pid2M4YTBmR2VoY0llZWVlaFVocGJDYlVha2U4YUxjWWZWYU5hWmZSZFdoSmRtZmFlUmNSZHllVGRuYU1iUWZUY0VkMWVSYlNlVWZjZUxhUGZTYUZiS2VQYmtoRWZnZkdkUWZNZ2RoYmVqYnRlemJUaEZkRmE0ZWNhRmdaYjBoRGYyZXRlU2NTZ1hnaGFLZk9jWGZoY1RkVGcyZlJkcWZVZnhna2dUY2NhQWN0ZlJnR2RCaHdmcWhGaFNkc2JWYUlhUmE0ZzlmS2VRYjRkYWZJY2tkcGRjYkhkUWdwYkVhZGNIY05kMmJOaFRlb2RJY0pnRWZKZGJnQWV6ZXRhS2NHZ0ZodGNFZFVjRmRwaGFoUWFtZDliaWVaZm1ia2VVZGNla2c1aHpnRWVFZHdkYmRFaEJoc2ZWaEdkbWdsYXBkR2RDZFFiSmNQZ1FlSmJFZkFhamhCaGZoTmhCY2dlWmZZZTFicGRXZGRkQWY5ZXJlVWdoYlJkeGZSZ2hlTmM0Y1VlMGg4YnRnTGJGZ01lUmRSZzNlQWZPYldmVWFJZFNhZWIxY3BlNWRRYVhlNWJEYVRmbmFsY0xiRmdIZUVjZGVIY1VjMGhaYVZhbmVSY3ViZGNuZE5ndmdFaGlkOWJFZlhmUmR0ZTFkQmVGZVViRmNSYUhha2R4YkZmQWFVaHFiQmN6ZVFnN2ZXZnljQmVHZWNoWGZJYlpmQ2N4ZmNlTWJSZDBkNGQ2YlBjVWdJYzFnUWRUZWtlRWFHYVJjcGcxZ1VoemhaZ01iRWJIY2djOWJBZXpnaGJiZElmZ2VKY1loTmhFZ1poY2ZQaGxkTmFjZWRnbWJjZlJhVWRFYmNmamdDZlZmQmJOZU9nSGRwZUhlWmNFY0ZjdWZTYW1nUmU1ZVNmeGhSZXhlSGFWZnNiQ2hTYTFkWmM4Y09mRGJjaGhiYmR4Z1JjbmhDZXhkSmhjZWJoa2dwZkVoVWFsZ29nTGFJZ2tlRmRDaFBhV2NKZXRmZGJCaFJlbWFSaDFia2RRaFRlRWYxZ1JkU2JSZlZhT2VhZ1hhUWdZZ2NiRWZGZzBhVWVSYTFiR2FJaFZja2Q2ZEhmMWQxYjRkSWNsYXBnMGJYZVdldGRaYkZiR2ZKZFBiSGUzZmdkRWRSZ3pnQWJpaEdma2hvYWZnY2dGZGxoWmVYaFJjSmNyaFNoMmhRYVRlYmNrZEZoa2VhYjBmSWhQZ1dkeGEwY2RlVGFSZmxiV2VkY0doNWcyZGNhMmc5aEdkWmMwZlJmWGJHZUNmQWNZZ1hnbGRJYVFoUWd6YWtiSmNXZFVmVmFpZ1plbWJraFVkY2JraDVoemdFYUVkeGVOZURhRWhBaFpjWmRHaGxnMGJHZEhnQmJCaGRnRmVGZEtmVGduY1VhWmdQYlViSWJCZEtnamM4ZUNoT2IxZ3NkeWNBZmxoRmUvZUZjVWNRYTVnQWExY2xhd2FhZ2tmNGVaY1ZlU2FWZEZnR2ZnZEpjYmFOZVFlbGhrY1NiV2FkZktjUGUxYk5hTGFGaEhhRWdkYUhmVWgwY1phVmVuZlJmdWNkY25nTWQ1ZkJlemFVYldjUmJrZ3hjb2VTZ2tjUWFhY0RhVmRoZStiRmNnY2NkaGhKYVRlSWNoaERmMWdoYk9jY2J4ZUJiTWFUaFZhRmVKaEZjVWU1aHBkZGRCZ2doNWdCYzNkUmRaYkhna2Q1ZXdiRWdXYXRmTWZVaEdnVmh0Y1ZibWRRY0dkUWhWY0llVWhjZFVkWWdUZWVhRmVOZFBmWmNHZXBhVGRHYVJiTmF3ZlhneGNFZUVnWGFTYzFnSGhLZWdiUWU1ZVNkaGFZZzRiQmVWYk1hMGZlYUVhOGNmaFZnZ2FSZDhiYmJCYlFkbWhLY1FoQWZpaFJlQmVJZmZmUGJCZ0JkVmVVYmdnbGFlZElmd2E1ZkNnTGJTZWRkbWVLZ0JhUWIvYUdmemI5ZEViQmZSYzBmZGVEZkJhVWNCaExoM2NRaE9mWmdFaHdlMmZHY0JnNGNkYmRmeGFoYm9iWmJsY0ZnNGVjZkZmWmQwaERmMmF0Z1NkRmRIaEZhR2RFY3pnNGRjaEhiV2JSYmlnQmNWZWhnQmRjZkZlbGRaZ1NieGRKY3FhWGFHYVFoVmNiY2xnUmFrYUtnMWFBY1VkSWh4aDBmV2JVaEJkbGRPYmZnVWhSZTJkY2MyZTlnR2JaZHhhWWNTYVRnSGZWZUtkRWJGZUpjRWJDZXlkZGNTYkZoaWNjY3JnTmRXZ1VkVWJJY0VkSmZ6Z1Foa2F4ZEdoVWdWZDRhY2FRZGthTmcwZEdmSGVCZkJoZGdGZkZnS2VUaG5kVWJSYWNiMGZ4ZFJnZWZIYkJlV2VJZHdkY2YvaEdlbGIwY2llU2NoYU1mcWRVYzBnUmZrZGVmMWg4Z1pnUWRYZkFhQWJXYlVnQWZiZWRjbWIxYWtkUWhXZjVkS2NaaEhibGdMZEZjSGNFaGRjSGZVaDBnWmRWYW5hUmV1ZklnWGVzYjdoRGFpZDViRmRIZGtkd2VuZVNoaGR0YlNoVmNnZ2Rjd2RDY0VnSmhrZ1ljbmVOZGdmR2JGZ2hlT2djZnhoQmhNYVRlVmFGZUpjRmNVZTVjcGFkZUJnaGN3ZlFmWGZSZ1JjSGRVZVlmaGFXZFRkb2NmYVhkWGRnYmllVmJuYThnUGFlYkZhNGhVZUlhMGFZZFllZWdFZGRnR2hmZjBoQmdUZ0dkUmVOY3dmQ2MxaGxjV2VFZW5ocGJIYlpoRWZFaDhkRGN6YkFoc2NHYlZkcGF4aFNhVmVVZkVhU2JrZDFnZWRiaG5mWmd6ZWJhMGJaY25iRmRoZEphTWdkYVJnY2RaZVhkbWQ0ZkxiY2RGZXBmQ2ZiZjJkSmRtYmFhUmJSZXljUmhqYTBnZWhIZkJoOGdlZEhjVmNvZWFjTWNDZlJhZGdmYmhiVWM3aElnaGI0ZmNlUGFGZDhjMGFUYUVleGI0ZE5iZ2RNZzZnVGFEaDhnYmhXZ3pkOWdHZUdjM2JGZ1RhRmJFZDVocWNVaHhma2JUYWNmQWh0ZVphVmRoYUplNmJSZTJjUWdYZExheGdoYWtiTGJVZXNoSmJjZVFjMGNkYUVmUmRrY0NhUGNDaGNlbGJmZ1NjTWNEY0tiVmNGYUdkQmhHYjVlZ2RFYUZnSmZFaENiM2JCYWFiUWZtaDlkaWVaaG1ka2JVZUljQWFzZ25mUmRSZTRmRGRVYlZla2hWYlVnM2ZSZXBiR2NDZlJncmhkY0ZjRmdLY1RnbmFVZ1JiY2YwaHhnUmdlZkhkQmZXaGRnQWg5aDBkVWVoZ1pmemdiZUJjTmQ0aFViMGQ5Y2toYWFsYk1nWmNFaDNmQWhMZ1dkVmFZZVNkWWdFZ2RlMGhRYVhkTmhYYmVmWGJrZ0thUmZqaFpoSWNVZUFmaGRYaEFhaWdkZ2dkT2JqY1loaGhBaFRnTmVlZU9jRWV4ZDFiU2RoZkJjU2VSZ0FidGR3ZVdna2RKY3ZhWWFtYlpkcGFDYjNhSWUrZWVlMGVRZEVoQmJBZ0poRmFGYlZmNWhsZWRjRWd4YjVjYWIzZ1JoUmJTYmtnNWcxZEVmWGFOaE1hVWVYZ2hmd2FWZW5mUWNQY2NoVmJKZlRoZmJ3Z2RjRGNLZUJlOGdXZGJjRGQ0YmJkVWJFaEJoOGJDZHhlZ2FFZ1ZlU2Y4aEtjSWZRYzhiNmRHYldmMWhpZllnUmdSZXhjSGdSYjFnTmZHYVZhWmYwZGJjbmNZYnVmWmJrZ3BhTmRGZ2hiSmFNZmRoVWVvYlFlVWZrZlFnTGFjYUZhSWFNZVljVGFJZjBoSmZrY0FjOWFHZWlkcGdBZ0NkVWVNZ1VjR2RFZEFiUGFKZlNhY2FZY2JmVWFFYXlhQmZBYlFiTmhJZlZlZ2U4ZkFlbGhGZndkSmFGZDljMGJWYUVnRmVTZkZhSGdGaEdjRWQzYWhnVGNUYzJiUmhxaFVjeGJsZmFiTmRnYnRjUmdWZzFneGUwZURkamVjaGpmT2N3Z3dnaWRQZUJja2ZjYUpiUmRRaFVoWmR4ZWxkV2dkYkdmNWEyaGNiMmY5YUdnWmV4Y1loU2RUZEhoVmhLZFJhQmVvaFdhUmVDZGRiYWNEaENob2UxaFpkaGYxYU5kSWJnYnNlV2VRYWhmNGhDYkFnMGNFZ1hnTGR6ZHNkemdUYVRhMGRFYk9oZ2dWZUtnQWJ5YkJiQ2hKaDBkd2FUYVBjWGFBZ1hiZGRHYzBiK2RGZkZmSWMwZkZjQmVGZ3hjU2dHZVZja2hhZWxmTWRaYUVjM2FBZ0xhV2NWZlllU2FlY2tmY2MyYUJlRGZvZGZiTmNqZ2RnTGRRZURhbGZVY1Rja2UwYkVnU2EyZmxndWhJYm5hTmV3Y1JobWNZYUdoRWVsZlpiMWJXZmhoQmdQaFdmUmNaaHdlRmRFYndkc2VMZ1Nic2g1Z1ZkU2ZBZExjZWYwZlFlRWFCYkFhSmFGYUZnUmhwZmdnYmN6Zkpmd2NRYlhjUmhSY1Nla2c1YzFhRWJYZE5iTWdEaEhoRmE4YWZjSGdRaFBnYWQxY0ljVWRjZFVmWWNUZ2VjRmdOY0hiS2dtZ1FiRGZTZDFhd2drY1JkQWYwZVBnUWVqZjlnSmRMZVFhOGc5ZkdnaWVFZzZjSGd4YVJoc2FIYlZic2FZaFZkeGNVaGdnSmF6ZGthOWZiZDBhNWh1YUZna2NsYm1jZGFVZG9nUWVVY2tlUWFMYWNmRmNwZkNlYmYyY0pkbWVQaDFkVWFnYVRoaWVjaFFhVWdVYjFlVGJTYnhmbGNrY2FlWGVRZllhY2JFYUZkMGNVYlVmcGdPaGRlUmFGZ3pjVGZGYUVmeGFjZUVndGQwYlhlV2NVYTdlZWJnZUliMmFkZWhnc2duYk1hQWdrZkxmS2cyZFpmeGZDZFhlOGM4Y0pnUWhsZ1FlUmYyZ1JnQmdiZGtkcGJrZ2VmVWhzZVVjY2JSYTBjZGZIaDFid2hDZkliVGN3ZTRkY2gyYmRhc2ZaY3hhWWJTZ1RoSGdWZ0tjRWRGYUpiRWZDZTNkQmNhZVFlbWQ4YTJlTGJpZkJiSGRmY0FmSWMyZlhlZ2VzZlpiR2JVZmtkTGJUZW5hbGIwYUhjbmNaZHJjZGhGZEZjS2FUZW5mVWZSaGNmMGJ4Z1JnZWVIaEJmV2RkYUFnOWZyZlVoaGZ4ZTVhRWFoYU5obGhVY3hic2JzZ0lid2ZBaFhjUmJ6ZTllNGREaFFlUmhiZk5iQWJCYnNjUWN5YVliUGhQYUhjdGRIZ0ZiR2dFZVJjSGNRZ1FlUWRXZURka2h2aElmamhBZm5oVGNtY2doWWJTY1ZiNGdvY1JjVmhkZWJiU2drY0VhL2NFZHdleGFuZ1lnR2RaZHJhSGhYYXRmQ2dXZ1JjQmJNY1RhVmhGZ0pjRmdVZTVmcGZkZ0JlaGZ3YlFmWGRSY1JiU2NrYzRkaGdXY1Rmb2ZmZVhiemdRZDFoR2ZEZk5nYmdJZTFoSWNLYmNiUWE4YVRhZmVsY1ZjUGhiZERnNWFUZkViZ2g1Y3dhQ2hWZWxoWWZIZUhkUmZIY1pka2doZW5iUmRrZjVhNWZTaHhjUmV4ZUhnUmExYk5kR2FWYVplMGZiaG5hWmV6aGJmMGVSYTdnZGhFZmNkS2JNZXdjOWRDZ1Via2NZY0xnZWIxZ29hV2RiZzJlbGZtZmFjd2RwZndnWmdIZU1nUWdUZEVkMWhSYVNkUmJWZk9nYWRYZ1FlWWZjYkVkaGF2YWVmMGNwYU9kZGJSYkZlemJUZ0ZoRmU0aGNkRmZZY3BlQmJtYWRhNGdGaEhjRmZHYkVmM2NoZ1RmVGUyZlJhcWZVY3hmRmZkZGZnbGZzYUxlR2dVZFlnMWJFYnpnMGRSY0tkMGdRZm5jTmVnY1phRWJNYkVmOWNZY1RoUWhSZldlTWFqZHNoNGRNYURlc2JQY0tkRmdnZFNnUmRDYUZlR2hFaEFhQmFJY0NjemhsaFdhUWFpY3BidWVaYWloWWNkZWNnaGRWZFpoRWZFZXhlTmVVYVVia2RWZ1RjbWRsYzBiR2RIYkJiQmRQYVJjZGFLYlJkbmJSYmZkZmFRY1VkQ2RHZGlkVWRRY01na2hvYjViV2VrY0JoNGZUZ3plbGU0Y1VoMGg5ZmtlYWJsZk1hWmRFYjNoQWZMZldhVmZZYlNjZWFoYk1hc2JFZHljRWFkZVplRGJjYU9lUWEzaEZicGZSY0JjMWhjZE1heWhZaDhkT2RTZEZmbmZSaEFmWmZFY1ZjUmNraDRjRGcxZjRnR2RSZUVjWWJsaENjUmdaZ3ZnSWZDYU5lcGFWY1hnSWZzaEpibGJZYktmQ2dBZU5kTGdIZ0ZiVmREZ2RoQmRoYndoUWNYY1JhUmZTZmtnNWIxYkVhWGdOY01kR2VEYzVkd2hYZmxoNGhQZGFkMWdJZFVkY2FVYlllVGNlaEZkTmRQaFpkR2FwZVRkR2JSZnNibWRSZ0JjQWdTZkVhbWVwZUhjZWFWY3hhemRTY2pjWmU1aFRjUmNKYXhmRmRVYTlnTmNCYkZiWmRrYVplM2NwY1piYmQwZVpmbmFGY2hjSmRNYmRjVWdvaFFiVWhrY1FlTGRjZkZnb2FVaEllQ2ZzYmliYWNRZlJheWVVYjJkNGdOaFRoQWNSZlJjVGN4ZE5jT2JZYVRkMGVZaGJkVWJFZWdlVWdWYVZnT2dJZFJmOGEvZUNnUmM4Zy9iSmZCZjVhMGVGZFdidGZDZkhiWGgxZXNhRWczaGhmVGhUZjJlUmdxZVVoeGJrZVRjY2VBZ3RkWmNWY2hlSWJzZUNlQ2IwZkZjYmVsaHBka2daZ0ZnWWFKZGNmVmZnYmRmU2h4aDljV2NmaENidGMyZmJhbWc5ZldoYmdoZW9kNGdUY0hnVmJLZEVjRmVKZkVoQ2UzaEJjYWhRZG1kOWZpY1pibWFsZENhUGNRZGNjM2JFaEZheGROZFRhRmdRYkloVGdpZVphMGVIaG5oWmFCaGZnQmI1Y0tnVWQzZVZkRmJPZHdhVWFDYWRkamF3Y1RhT2VrZWdoL2VHY2hhMWc5aGJoQmZOZDRlVWcwYTlja2hhYWxkTWdaY0VoM2FBZUxnV2ZWYlliU2dhZWtlZGE2YlFnVGF4aEtjT2RDZ1ZoTGRYYVhhRWREY0hoUmhraFhhR2ZqZUVlZ2VNZVNiY2NuZlJiamV0YktkRWRsZHhhMWRWYUJnQWZYYlJlRmFjYXNjV2RnZDFkdmRmZ0dkWWI5Y1hhRGVzYWRnZmZWZHdhSmdBZnhmWWJkZlhkVWNkZERkZGRCY2hld2dRZVhnUmFSY1Nja2M1ZjFjRWNYY05lTWNXZ0ZoSmV3aFZlbmNRZlBjYWYxYklhVWhjZ1VjWWhUYmViRmhOZFBlWmNEZjRhYmhTZDFnd2huZUNleGFjZ1RiUmhYYW9jMWVKYlFkOGFwY0Rhd2FFZHJjR2JWZ3NmamRGZ1JhOGJDY1RmQWFKYzBmSWVUYkJmemJQZ1FnY2ZwZ1VlVmhkZE1iUGZBZlJiVWZGZXhnd2hKZmVmVWRGZ29nYmIyYUpnbWVhZ1JoUmZ5YlRibmZNZVFjVGZFYjFnUmFBaEZmTmFPZVljVGVFZ1lhYmVsZ3hlMGRIZWtmcGJJaGNkeGZFYmhnVGdFYTllbGVjYUJhOWU5ZkRmemJrZVhkUWRDaFFlVWNYZlhoaGJEZFZlRWM1ZXFjVWN4YWtlVGVjZUFodGVaaFZlaGRKZzZnUmgyZFFnSWdLZUVjcGFzZlBoRWNzY0thYmVCYjFnU2ZSYUJma2RFaE1iVGdvZGpjSWZTZkZkR2hhZ2dhY2ZKZVpmbmFWYUtjRWVGZkpoRWJDYjNjQmJhZVFjbWQ5Z2loWmhpaEJoU2hjZWtjWWJoZ0VkRmRKZlFkVWRRZkFkY2VUZGpkc2d4YlRnQ2ZVZFRjT2NsZEZnYmNWZVZmOGhSZmNhMGN4YVJkZWFIZEJiV2dkZ0FlOWFyaFVhaGNRYzRlQWVCZE5kd2NXZjBnY2MyZmFla2QwZ0hnRGdXZDBnTGFTaFZkOGVlYWVja2g4YnRhUWdYYUJoVWRlaG1oUmVMZkJmSGJnZ1JmSGZVZVZhY2VWY21kcGZ3YWFiR2U1Y3ZoVmNtZjRlYWNFYmtiUWU2Y1NlZ2E1YU1nV2FoY1pld2RTZ2tjdGRqaFliamZJYWhkWGdTYUZnT2hiZGdmMWFSZ1RlUWVWaEFmSGdHZVJjcGRkZ0JnaGJ3Z1FnWGRSZVJkU2JrYzVhMWdFZ1hmTmhNYlVmU2RvZjFhQWZpZkZiZGNKY1ZoSWZFYmFhbWF3ZlRnZWNGYk5lUGNaYUdhcGJUZkdhUmFOaHdjQ2gxY2tlUWVYZVNlaGVIYWJlR2F0ZXVnU2htZ1JiNWRTZXhjUmR4ZEhjUmcxZU5iR2ZWZlpoMGdiZ2ljQWh5Y1BlVWdZaHZhRmVnaDlnTWZPYWthb2dkYlVmZ2dFYUhhV2RsYnBiQ2RiZjJlSmJtZWFnUmFSaHloVGVuZU1iUWhUZkVoMWFSZlNjUmNVZmRnYWRXYmthWWVPYVVnRmU1aFVmUmdoZkNhWGV4Y0ZhemVUZ0ZhRmE0ZWNnRmZaYjBhRGEyYnRhU2VGZEhoRmRHaEVmM2ZnZVNjVGMzZWxocWhQZWxnaGNIZE9mQWVVYlVjSGQxZHhjeWVEYTJoaGFCY1BiVWFOZG9mVWEwaHNjVWNjZVJiMGFkZlRiUmJsaFdhZGNHZzVkMmFjYjJlOWNHZVpmeGdaaEhjVGRHaGhiS2ZSZ0Jlb2VOY1djSGQ0YUpmRGRpZFloaGVJZzJmRmVSaGZma2g0YjhnR2JVY0JmbmhVY1Vja2RWZVRobWFsZDBlR2ZIZUJjQmdkYkZlRmVLZlRibmhVZFJhY2J3Y3BnUmJaZlhlQWRDY2VibGN3aG5oR2gxY2NhMGVUZ2tlRmgwYlVnd2JaaHRmWmduZGtmWmZFaDNmQWJMZVdiVmRZZ1NmZWRrY2Rma2JRZ1dkNWdLZVpkSGdsY0xkV2VIYkVhQWNIYVZkMGRDYmZiSGFSYnVjZGVuZU5ldmRSYW1nY2JXYUVka2R4YzFjU2RoZEJiU2dCY1FidGJ1ZFdkZ2Q1YjBlU2ZHY1pmcGhGZEhlSmdPaGNieGJCYk1kVGVWZkZmSmRGZVVkNWVwZWZheGhNZjhnYWczaFJoUmFTaGthNWUxZEVlWGVOYU1kVWJYYWhjd2NWZm5lMGNsZ2FjMWVJZlVhY2NVYVlnVGRlZ0ZmTmNQaFphR2RwYVRmR2NSYU1nNWZUYVZmbGZlZ1Jld2NFYUxnR2JVYUZndmdWZzNkbGI1ZURoV2g4YTljWWNCZ1JoTmJRZm5leGgwZWJlbmNaZXphYmQwYVpmbmdGZWhiSmJNZ2RjVWRvZ1FhVWRrZVFkTGRlZEJmSmNDZWNmbWFJYXplRWVsZGdkUGFSYTNjOGdRY1JjQmQ1Z1JhVmRCYVVoSWhFaGpmaGJsZmVkVmNwZGVhVWVVZnBhT2FkaFJlRmh6Y1RkRmJGZzRoY2VGZlphMGNEZjJidGFTZkZoRGZNZVVkVmZqZWtnWWNWY0VnNWhxYlVjeGRrZlRiY2ZBY3RiWmdWY2hnSmU2ZFJnMmNSYUJkYmdoZ2RnT2dlZVVmc2dVZWNlUmIwY2RhVGRSZmxiV2dkaEdiNWgyYUlnU2hvZlNoTWVrYlJoY2NUY0NkWmJLaERnbGRJZU1oQ2UyZDljYWNUYzNnNWVpZ2ZnR2JsZ2NkY2VsZUJjemdRYTBoeGZTZlVkVmJnZVZhVmFHZmxka2VBZjFncGVCYmRkRmJGaEtoVGhuYlVhUmFjYzBieGRSZkplWGVsZGFoWGNnZjllcmZVYmhiUmN4YlJoaGZOYzRhVWUwZzloc2JKZEZoMWNKaFFlVGQ5aGZkRmNnZUpjTGVLZWdjSmZxZkNnQ2ZBYUphS2JDZXdkUGZVYlNnSWRkY0FmRWUxZ2ZoQWd6ZG9odGhJaGplb2FnYkNoR2djZ2VnUmZrZ0JmMWdHZ0JmeGJTZURkUWNKZHdnQWNXY2hidmNZZW1nWmNwZEZkSGFKZ09mY2V4aEJnTWdUZlZnRWRiZVVkQmJvZThnSmdsaFpod2VUZ0diVmVSZlNoMWJOZ29hRWRTYWNnRWVHY0NidGIrZEhkemZwYUxjTGVnZXBhN2ROZDBjNWRIY2RoRmhNZ2RjYWVHZm9oYWZFZUFjaGJhZ0NkMWZsaFdkRWhuY3BlSGdaaEVhRmF1YVNnamRsZndmUmF6YzVheGhIYVJlMWhOY0dhVmNaYTBmYmFuY1pnemZaYXdoaGVwY1Jja2JBaERkSWhRZ1ZnRWNDY3hkUmVPZWZkaGNNYk1kS2R5ZGNmK2NCZWxiSmR5YlVmM2VOYldhR2FRYk1jU2JIYVZmd2RCZUpnM2RRZVFjSmhFZTFnMGJBYTBnWmRPZFBiQmVoZHpmRmQzZHRoNGdjZEZnWmUwZ0RjMmF0ZFNlRmNIaEZjR2JFZjNoZ2RCZUNhamVBaC9jQWNWZmNlVGVKY2dkTWFOYUhlbGJzZ3BnU2YyZlFoVmJZZmtnb2cyZGRjVWR0ZmRmZmNSZzBoY2FYZFJoQmJOYlhlbWY1ZjJhY2YyYzlnR2VaY3hiWWZTaFRjSGRVY1hlR2RWZDVndWFDYTNoQmVhaFFjbWM5ZGljWmhtZGtlVWJjZWthWWE5ZUhoaGF3aGZkSGZoaDFjYWRHZGpnQWRrZlhkWGg0Yk5jTmVRY0lkZWZKZ3pkdGVWaE5laGRRaCtkUGJuaEJlTGdkYUVoa2crYUhnRmJjZGxiRGIxZHdhMmRVZjBkY2h3ZVpmbGFOYUxnSGgzYkJoQ2NVZUZkWmdKZlVmRWRkYmthUWZXZDVnS2FaY0hobGRMYkZhSGNFY2RjSGVSYjllY2VBZmlkRWM4ZE9hSGJNYTVoVGFqZU5oZWhXYXhhOWM1ZVNka2VSZGVlUmNGZGxnOGRXYmdidGRqZVlkbWdkYTRiSGZXYWxma2VjZHhmQmJNZVRiVmhGaEpnRmNVYzVncGFkZ0VoVmc1ZFRlVmM1aFJhU2drZzVnMWFFYlhmTmFNYVViWGRoZ3dkWGNqY29nQmJPaHdlQmViYUphUWVsYUhlSWdRaE1nS2dhZmpjMGFCZ1ViRWFjYjFiQ2EwZFJjV2NWYUNoOGNKaEpmeGRVZm5nQmRTZXBjNWJRZjBmQmI5YkhnVWM5aEJnR2FSZDloNGhiY2plTmQ2ZGJleGQxYk5mRmhoYUpkTWNkZlVlb2JRZlVka2FRYUxkY2ZGaHBiQ2ZKZmlkUmVtYVlmVWZJYTlnQmN6Y2NjUWVYYkVkMWZNaFZmQWRoY09oT2IzYzBoWWZlYkFiUmYwZlRjRWhwaE1nSWJFaFVmMWVWYUZnTmZ4Y2ZhRmRaZzhhUmNtZ3RnUGJGaENiVWNPYldhaWV0ZGRoQWR5YkVla2JGZUViMWFiYWVhUWFkYVpkWGJrYUJhNmFXZ21hUmNSZFplMWFGY09jZWVVY3NjVWhjZFJkMGhkYVRiUmVsZFdkZGdHZDVhMmJOYWlkTWVWZUllaGRaZmJnQ2NuaFZiQ2RSYWhjMGNOZFRnM2VCZUtnUWNuZUpoL2NlYzJhbGFkY2Nla2hoZDFhRWhFZDRmZWhCYVJmdGNjZkFiQ2c1aDJmR2hHaDFnY2dkZUFkVWJUYUhnamFCaGVlTmZVYndiRGNjZ1ZlcGRXZWRmQWI5ZHJiVWZoZlJieGRSY2hoTmI0ZlViMGY5aGthYWhsY3RjY2hFZjJhMGFMYUNmMWU4YWVlZWhrYzhmdGVRZVhhTmhLYk1nRGhFZENnUmIzYTllUmNXYkFkTmNlZkFlamR4Ym5oZWhuYk5lbmVGZUdmY2RMZ0VnbGd4ZDhnVWVUY3BmU2NSZkFmdGN3ZFdna2NKZ3ZiWWRtY1pkcGFGZEhoSWRMZ1BiMGZNZEphVGdRZXBlamJGZFVkNWZwY2RnQmhoaHdmUWhYZVJlUmVTY2toNWMxZkVlWGFNY0ZnRmczYWhiNGdWaHpnMWRjZkRmUmF0ZmFlT2FCZ0phV2RjaEFiRmdHZGJmVWZCYVRlR2hSZ05md2hDYjFjbGRXYkVobmdwYUhoWmJFZ0ZmdWdTZG1kUmU1ZEhhMWN3YmplVWFrZnBlTmVWZHhoTWZqZGJnaGhNY2hnUGRRY2tiMWdIaGpkaGNNaGRjVWdvaFFhVWFrZ1FhTGNjYkZhcGZDYmJhMmZKYW1mYWNSZ1JjeWRUZW5mTWJTYkxlaGdnY1hnRGgxZ0FlY2ZaYnllTmdLZU9lUmNVZ3hoV2hSZmtlYWNKYzFiZ2E5YUNoMWgxYzRnTmFSZ2doM2ZRaENiOGViZldoamVaZEtmRWd6Z2NkVmNDYVRoY2V2ZEJmMmdJZGZoY2VFY2NnY2hHZkZkVWR1ZkRieGVsZklhYmFnYU1oM2RlYVFkVmZiZmNjVmRGZlNhQWIxYzRoVGhKYm1iNGRsaEpjamI4ZVdhS2NFZFJmR2JDZVRlRmRJZE9obGdKZUVkQ2EzY0JmYWNRZG1mOWJpZVpmbWdrZFVhY2ZrZjVkemRFZEVieGRFY1NkbWJNZFZnVGZtYmxnMGdHZUhiQmVCZWRnRmVGYUtiVGRuaFVnUmNjYTBkUWREYmVjR2UxZFdmWmJBZThoM2FVZGtlWmQ0Y1NmamdsZjRiVWEwYjlia2hhY2xhTWZaZ0VnM2VBZ0xhV2RWZFlmU2FlZWthZGZrZUNoRGEwZHNkTGFUZWNkQ2JRZERjUWRWZ1ZmRWJRZnpiVmVuZVJkdWRkZm5oTmN2YlJobWZjaFdjRWRrZ3hlMWRTZGhiQmJTZVJoQWh0Z3djUmhVYkpkbmRhYWlkOWZwZUNhWGVKZmVoY2UwZ3hhTWVCYUZiaGVGZ0ZmUmFnYm1mUGdWYXhid2dVZFhkUmhNYVZoMWJOZDFlVmZIaE5hS2VWYTNkaGQ0ZEVhM2ZRYlNnYWcxZEJlQmZKZlFlQWRMZGVkbGRwZkdkVGVtY3BkVGVHYVJhTmZ3Z0NjMWFsZldlRWVuYnBkSGhaYUVnRmZ1YlNkbWJSZzVhU2V3ZjVheGZGaFJhVWVJZkdnVWd0aDBjSmEzYzlkL2JiZjBoNGJ1ZUZiZ2U5Zk1lSWd3ZlZiWmdGZ2tmUWFiYWVnVmZOZlpmUmNXYUplbWFhZFJjUmZ5YVRkbmNNZFFoVGNFYzFmUmFTaFVoaGRrZ2FoWGZRYVlnY2FFY0ZjMGZVYVVicGNPYWRlUmFGYXpnR2NoZkFmcWRjZEJnbGIwZUVhbWNzaEdmWGVEYmdiVmZIZVRkUWFXZkFnU2NNYytkR2R4Y2tmZWFjZUZhbGJDaGZiQmVKYzZlUmYyZFJhQmZiYmthcGVrZ2ViVWdzZ1VmY2dWY1JhYmZUY1JmRmE4ZGRkR2Y1YTJoY2cyZzlmR2RaZnhnWWdTZlRnSGRWZUtmRWJGZUpoTWdBZ3lnWWRWYkNmeWh0Y2lhZGFtZWtjSmRiYTFmTmd6aFdiVWV3YlJkRGFVY2xnY2JUY25lZGYwZlZiM2ZsZUJnY2FsZWRkS2ZSYmpld2JSaGJka2V3YmVmY2VYYXhjOGJkYkFnOWFyaFVoaGZSZnhhUmZoZ05nNGNVZjBkOWVraGFhbGZNYVJkUmMzZTVoSGJIZUJoaGdWZkxiZ2E5ZmtoWGEyYjVnYWFaZ0hiOWdOZkZnSGZrZU5nSGFWaE1oWmJIYzNmUWh5ZEtjbmFOZS9iUmZuZWtmV2ZRZEVjVmE4Y1Nna2Z3Yk9mUmRGZGxkd2dSYkVjSWU3ZEtoaWM4YTZnR2FqYjRiTGNQY1ZkY2FZZkJhVmNoZGphRmFVZTVicGVkZEJmaGJ3ZFFjWGVSYVJlU2ZrZTVoMWVHYkZnbGdNYVVmWGFoaHdmVmJuYVFiUGZhZjFkSWJVY2NiVWNZYlRhZWVBYmNhSGNOYmlnVWVFY0dmVmEwYzFkWGdGaGtoa2FVZnphUWRBZkllU2hRYzhmR2RDYXNmcmdRYnhmWWJRYVNiVWZraEllVmJBYVlkZ2RiYWlhSWM4YmJieGFFZTFiWGgwZFlhSmhkZFFiVmRGYkJiaGNkZENkTmNCZTliQ2JMaFRhY2FnZUxhMWhFaGdmVGVqYkZmZmVHYlFkTWZWY0dnaGJkZkhkY2dsZzRmWWJjYkVoRmEwaFVjVWVwY09hZGJSYkZmemNUYUZmRWY5ZGNhQWVvYm9nRGMyY01hWGJGYkdheGNHYkVjU2cwYkhkQ2FYZ3hmb2dXY2diSWg1YWNnQWV0aFpjVmJoY0pjNmdSYzJlUmVCYmJna2ZwYmtjUGR3Y1JmR2djaFJlVmNMaERoRWF0YldnUGNHYzVicmRjZDJkNWFYYWZkQmVZZUpnVGJIYXhhZ2NFZEZlSmVFYkNhM2dCY2FlUWRtZTlmaWVaZm1la2RVaGNna2E0Z2diUmh3ZlViWmJFZmdjRWJWZVJmaWd4ZTlhR2FDZXRncmRkZ0ZmRmhLYlRlbmVVZFJjY2EwZHhlUmhlYkhjQmhXY2RjQWM5YXJhVWVsYmNhd2FGZVZkWmQ0YVVhUWRjYmhhTWRsYUVoRGNPYlhiQWFMaFdmVmVZYVNmZWVrZ2Roa2RRYldmNWhLZFpnSGhsYUxiRmRIZEVlZGFIZFJjOWdjZUFlaWhFYjhoT2dIYk1jTWFUYWphTmhlaFdoeGc5YTVlU2NrYlJmZWJSYUZlbGY4aFdhZ2N0aG1oZWZVZnhkcGZGYUhnSmdPZWNleGZCZU1lVGJWaEZkSmdGY1VoNWJwZGRoQmFoY3diQWFqZlVkQ2FEZjBoNWgzY1JmQ2ZjY0tjU2RYZ3BocWdmZkhhUWJQYmFiMWVJaFVjY2FVZVlkVGZlZkZnTmJQZFpiR2FwZFRiR2RSZk1jemdTaGdkb2dUZ0VobmhnZFNkTWVBaGRkamdVY21jWmRqYVljUmVSY3hjSGNSZzFkTmJHZVZoWmMwZ2JnbmFaY3piYmgwZFphbmRGY2hmSmZNY2RoUmRoYlZmQmJoZEZlWmNQYWxob2FBYVpoemVZZnViSWJFaGRlK2hUaGllY2RjZlRoQmE5Z2RmU2dWY3hhSGNjZGxhNGRZZWNlRWdGaDBjVWZVZXBjT2dkYlJoRmh6ZlRhRmJGYzRnY2ZGYlpmMGZUZkNob2dCZ1VhWGJGZkViVWFpZnNlUWhCaGllMWNvZ1NoVGRNaFRkY2JBYXRkWmNWZ2hkSmM2YVJjMmRSYUJjYmNrYnBia2RlYVVjc2hVZGNnUmExYVBhQ2ZFZjBlRGJKZ2liQmUyaEZjbWRjZFNlTGUxYzlkQmNRZkhmVWFlYkhhRmZJaFdhQmQzZ0FjVGZTYTNlUmhJZFplbWZrZlVnY2hrZTVlemhFY0VieGFOZFVoVWFraFZiVGdtY2xlMGVHY0RhTWNBZUpieGFSZktkVGJEaGxnUWZKY3djVWJmYmFkWGhKZ01lWGFnYjlhcmhVZmhnUmh4ZlJoaGdOZTRlVWYwYjlma2RhZmxmTWdaZ0VhM2ZCZUlmR2hBZlZjWGNlYWtnVWVtZ0NlQ2hBZUxiTmZpZUJoSmVEZGxoc2dkZUhnVWgwZlphVmhuZ1JhdWRkYW5hTmF2ZVJhbWVjZldiRWZrZXhhMWdTZWhmQWVBZUFiVmY4ZGxkQ2RBY3hmdmFFaEdhNGg5ZFhlRGZzaGRiZmd4Y0FmWWdRY1ZmRWViaEdjVWQ0ZGdkZmFRZk5lYWFRaFhnUmZSYVNka2g1YTFmRWdYY05hTWdVZVhnaGJ3Y1ZmbmFRYlBjYWh4Y0ZlVmVJZWdoTWFUZWVhaGZFZk9mTmJ5ZzlhRmFEYVJiRmJxZ0lmVmFsaFdjRWVuaHBlSGdaZ0VkRmV1Z1NhbWRSaDVnU2R4aFJleGdIaFJiMWFOYkdlUWVRZnhkT2ZpYk1iaGVJYVVnWWYvYUhia2JZaEVjUGdCaGtiY2RVY2hlQWZIYmNoQWNoZk9mYmV5Z3RldmRjYWpoNWJ5ZlRjbmNNYlFiVGRFZDFmUmJTYlJkVmZPZWFiWGRRYlliY2hFZkZiMGNFaGdlc2VkZk1iQmNGZnhiR2ZSYklmcmJZZGxlUmZ1Z0piV2Z0YVNjRmRIZ0ZnR2hFZzNiaGhUYlRoMmdSY3FjVWh4YWtiVGhjYkFjc2NhZUZnMGNFZi9hUmUyYVlnVWRMYVJnbGJwZWFnMGZrZU9jV2d4YjBjZGJUZlJmbGRXZmRkR2c1ZzJjY2MyZTljR2RaaHhlWWFTZ1RiSGNVZ0phVWdRZEVnQmdDYTNhSWJQZ0ZnaWhsZnpoY2FDYlZoUmVjZ0ZjUmhaY0VlRWd4ZU5oVWJVaGtlVmZUYm1hbGgwaEdnSGZCZUJoZGRGZEZiS2FUZmpjWmhRaElkQWNsZlJiZWZpaFVnQ2dNaGdmSmM2ZlJjRmNnZzBjUmhBYWxmU2FVaDBkOWVrYmFjbGNNZVpoRWczZkFhTGJXZFZoWWZTZWVma2FkY2tiUWNXZTViS2ZOZmpkd2dmY1FnU2FOZVRiSGhTZThlUmVBaGpnd2huYUplWGM5YnZlRWdtZXNjV2RRY0VhQmIxZkFoeGNsZUpjYmhnZHRld2FXZGtmSmV2Z1lnbWNaY3BoRmNIaEpkT2RjZnhkQmFNZFRjVmZFYk5jVWdBZWdlb2VJYlZoUWJrZ1diMWE1ZFJjU2drYzVmMWRFY1hiTmVNZlVjWGRoYXdhVmNuaFFiUGNhZjFiSWdVZmNmVWVaZmFmUGRsYU5lSGFMZ0djTmJUYlRhVmdzaGlkUmhBZDVoV2VYaERhOGJRYlpjRGJVYTNjR2JpYUVjY2VHYVVoWWQrYVRkeGhWYVBlYmJCZWdoL2RJYURma2NrYUlnVWRZZWlmV2hGZUVlRGhNZlFiTmdlY0ZiVmM0ZkxiY2NsZnBmSmNiZXlhZGd2ZWNlamM1ZnlhVGduZE1hUWZUYkViMWJSYlNnUmhWY09mYWFYZVFkWWhjZEVmRmUwZFVmVWRwYUdlTWdCZUZndWJUZEZjbGE2ZGNmbGhaYi9iRGZ5ZTVoYmRHZWliVWVKYWZkemJjYUVoQ2dqZFllSmJFZWticGRXZ2ViQWVKZ1FhV2VoaEpleWFEaDJnUmdjY2Jha2J0YjBoY2hGZUFmK2RjY1JnMGZkaFRnUmdsY1dnZGNHZzVmMmVjZjJmOWJHaFpkeGZaY1BjWmNuYVZiS2NFYkZjSmFFaENjM2FCYWFhUWdtYjhoL2ZiZzJlVWErZmNoa2Y1ZXpkRWNFYXhiTmhVYVVla2ZWaFRnbWRFYzZiRmZpaEFlVGhPY3djVWFGaEdkaWR4YkJhTmRrY0lhRmhOZXhib2FsZ0dhMmNGZ3JiVGJ4YlFjM2JFYTFjMGM3Z0Jod2hZZXJjSmVGaE1oUmNHZW5mQmFRZWNhMWhZYVNkZWhrY2Rma2NRYVdjNWdLY1pjSGNsaExjRmFDZE5iWWRTYlJjaGRMaEdmSGVRZjFnWGJIZE5kdmZSYm1mY2hXYUVla2V4ZTFmU2NoZEJhU2NSZEFldGF3aERjaGVzYi9lSmczZnhmcGdGZGhkQWdiYU5iVmJZYUpnSGYxZE5jRmNQYzBhNWdwYWRkQmhoaHdnUWRYaFJjUmFTYWtmNWUxZkViWGJOZU1oRmRUY2tma2FGYjJlNGdQY0NnZ2NCaEdjTWVCYzhoZGhLYUFkRWFBZE1iQ2NVYkhjUWJFZk1hMWJCY1Fkb2NhYVdmemJrY0NnYWdnYklndmZCZGljaGZ4Y0hmMWd3ZzRjVGRoYU1ieWdXaEFhUWZtYmJnaWRvYnZkYmh4ZkljdmNYYzBiRmRBY2RkVmRvaFpjWGhtYjRmTGVjY0ZjcGJDZWJiMmZKZG1jYWhSZlJkeWRUZG5mTmVOZ1ZnMmNkZlJoU2ZSZVZjT2hhYVhmUWNZZ2NoRWdGZTBoRGRFZE5nVmZYZXhiRmN6YlRnRmhGZjRkY2RGZFplMGhXYlNhb2VBaEZmQ2hVZ1NoRWQyY1ZlVGZXZzNiUmd6YlJhUWJJZjVhY2VBY3RmWmVWZGhmSmg2Z1JmMmFSYUpjSWFFZlFmMGhLZXdnUmFBZVBma2JsYkViSGhWaHhoWWJKY3lmSWYvaE1hQ2NwYkdhZWdoYVplVWNHZFRic2RKZFJkQmFzZkxhUmJYZEJkU2NGaG1jTmFpYU5iR2FBZFVoS2ZXZ1JlemRFZkVoeGROYlVlVWdrZ1ZhVGFtYmxmMGdUZ2poRWZUZWRlQmZoZEtmVWQzY1ZoRmRPaHdjVWFDY2RjamJ3Z1RlT2NrZ2dhL2ZHZmdkOWdiaFJmaGJOZzRoVWgwYTloa2dhYmxnTWhaZUVoM2hoZmZoV2dVZnNmU2JKZ0Jna2F3ZVNiR2JKaGdjWmFIaGxlTGhGY0hkRWZkZEhmVWcwZVphVmduZ1JidWhmYmloRmZ2YVdmMmhkYUFnWGFRY1VoeGFTZ2dnQmZTYldjUmdaZXRiV2ZoZUJldmZmZFdhWWFnaEZiR2hoZ09mTGNVYjRmZWVSYUZoMWJqZ0ZnVWc1YnBlZGZCZWhod2FRYlhoUmRSY1Nia2M1YzFnQWhYZk5hU2hVYlNmeGR3aFNoWGhRYkhnWWR3Z1ljVWhlY2xoc2ZUZE1kVmZwZkRhWmhIaHBnVGdCYXhhTWNrZ0NjMWQ5ZlFhRWRuYkllVGNaZkZkeGJ1Y1dkbWcxZ3dkU2Z3YjVneGhTZlJlMWhUaEdlUmM5ZTBlYWJIYkJhemdaYnhlSmZuY0NjeGhJZ0ZhZmZFZ1llNmRVaGtjUWFMYWNkRmNwZENkYmgyYUphbWhhZVJnUmJ5Z1hjbmFNYk9nVGNCZDlmUmJWYmhnVmFHYlliU2dZZVlmZWExZnhiMGNHYUVnTmJDYWRnUWNGZnpiVWdsZ0VmcWhjYUZkQmh5YURmMmhNZ0FmRmRHZHhjR2VBZzNhRmRhZ1RmM2g1Z3FmQWdSZGtkTmRjZEVhSmVaZlVmQmJSYzZoVGF6ZlpiQmhjZTBob2Z0YmNnRWZjYytmY2NSZzBjZGdUZ1JhbGNXZmRoR2U1ZjJnY2UyZjlmR2RNaHhnWWNNYVRnQ2RkZ0tiRmJsY1JhRWVBZHloSmRhZFhjMmI4aDJoYmgzYkljK2djZ2tmNWJ6aEVnRWh4Zk5oVWZVYmtnVmVUYmplOGQxZFNjbmNBYkViYmEzZHRhS2dUYm5hVWVSZWNnMGV4YVJnZWFIYkJiV2dQZlVkbGFyY1dobGFwYS9hTWVtZG9jSWROZ2lnc2ZiaENneWNGZXJoY2RnZGxjMGVLaGllTmJpZkNmaWZnZFdoTmRXZGRlZ2FaZ0hibGVMYUZkSGZFZGRiSGdVZTBhWmVWZ25lUmF1Z2ZoamhaYXZhV2YyZGRhQ2JXYWdiVWNtYlJkRWdNZEhnQmRrZ29oaWVDY0FoTWMyY2FlamJKYWxkRmVDYUJnSGRlY2hjeGNNYlJoUmNSZ0hnYWFqZ0VhNWhKY2xiY2hrYkRlZ2ZzZXVhU2RsZ05mMWVYZDNjMGJjY0FnemVjZGtmR2FTZ0JhV2dPY3hmY2VkZ2FjbWd3Y1RkZWhGYU5oUGVaZkdkcGNUZUdhUmNOZndiVGVoaFVkRmdWZTNlb2JjY1Rka2ZGaHVmU2NtZVJkNWdTZnhjUmh4Z0hoUmgxZE5lR2RRZUFmMWJQZEhiWWg4Z2JlMWR0Ym5jUmJCZ0poQmZkY1JkNGZMZGVhRWdRZkxiY2RGYXBmQ2diYzJkSmhtZWFlUmRSZXlnVGZqZVljUWZVZlVkMGNmZURlRWZKY09iSmMzYnhlWGdmaEVkRWJpZ0hjZ2JNYktoZGZRYkZhNmFWZDNjdGU0ZGNjRmFaZzBnRGQyYnRoU2FGZUhoRmNHZEVjM2RnYVZnQWhEZVpicWRXZTBmOWJTYkliZ2ZzZ1JiVmZnZjlnNmJWYzNiOWhCYUlnVWFwYTZmZWNRYU1lUGhjZVJmWWNXYkJhUmJCZ1dkTWVSZ1ViK2ZEZW1nOWFiZFphMGhKZ2FjQmVTYVlmeGFXZEZjSmVQaENjeWdRYm5iV2JVZ1ZjaWVaZG1ma2FVZmNna2I1ZXpoRWdFZHhjTmdEZ0dkTWZWaFRibWdsZjBiR2hIY0JmQmZkZ0ZjRmNLY0hlRGRCY0ZhSmVoaDRhZmNlZURlVmNOZFhkZ2U5aHJmVWdoZFJmeGVSZWhjTmc0ZURia2haZW9nUWRGYU1hWmhFaDNmQWZMZ1dhVmFZY1NnZWZrY2Rnc2NEaDJiQWJhZU5mamZZZ2ZjV2h5ZFZmRWFUaFFhZ2VYZ0JnRGJFZXZkTWJnZlloR2ZDYURjTmE2ZWRhMGF4ZW9mU2JsZ1liSGdDZ2thZ2ZrZ0Vod2UwZWhmWWRtZDRmOWRHZEhoSWNjaGZleGdBZEZlUmNGZ0VhU2JQYzBhNWZwZGRlQmNoaHdlUWFYZ1JmUmFTZGtoNWIxY0VoWGVzaFlhVWRXYlZhd2ZSZm5jUmFUZGFnd2hZZWRkZmFVaFliYmdLYWxiTmhTYlpiSGVwZlRkUmNSY01laWFBZ2xkVmJXY1diM2RvYmJnT2ZFYUVkRGJRYmphQmQxZVNnMGNaYjloSGJVY2thRmVVZ0FiVmI2ZUljamVNYjliS2hCZUlldmNIY3dibGZtZmRlVWZvZVFmVWJrYlFnTGRjYkZkcGFDaGJnMmVKZW1oTGUxYnNhZ2NUaG5ndGZHZURjUmY5ZlJmRGdCZ1ZiVGNhZ1NlQmhRZE9hUmdJYVBlQmZUZmRhQ2NkZ1ZkNWd6Z1VjVmRGaHBmZmRGaFloOGZEYjNkWmRTZUJhR2hwZ0dmR2NIZ01mYmZUYzNoaGVxYUFhUmRrZFZiZGFnY3RkUmZHYVJhSmF3ZldobWdSZlRiZWIxZXhhdGFZYWtkc2FkZ1djeGYwZmRjVGJSYmxkV2dkZEdoNWEyZGNjMmQ5YkdoWmF4ZFloU2FDY1hlVmRCYkRnVmdJZVFmUWV6aGtoSmFPZVRjdGVpY2JoV2NsYmNiRGMwZDVlNWdFYUFnTmVXaGVmMGFrZlZjVGJtYmxjMGhHYkhnQmhCZmRlRmZGY0tkVGFpZ2RlVWFKY3hka2JEZU5hbmdBYlRiYmN5ZlZhcmdVZ2hhUmZ4YVJlaGFOYjRjVWYwZTlla2ROZjFkb2NWZ09mWGZBY0xiV2dWZ1liU2RlZGtjZGJrYlFnV2c1ZUNlS2RuZWNhYmhSZmpmNWVKaFVoaGNsZ0FjQmdqYUZmZ2JKaERiWWZ1ZkFjaGNKZy9iWGFCZGdkWGRMaHhoQmVQYlJkRWIwZ2xkRmhBYkVoN2NLZXlla2RuZ0ZmSGVvZWFjZmV4Y0FkZWNRZ1ZiRWNBY0hjRWI0ZXljWGFoZmhod2ZRZlhiUmJSZVNka2c1ZjFlRWJYYU5mTWJVY1hoQWZraFZmbWZrZ1BiZWgxYUpnSWFjYlJkSWNhY2RlRmhOZ0hiTmdtYXBhT2ZHYlFhTmV3Y1ZoMWhrZ0ViR2YzZ1pmSGhMZ1VjRWh5ZUZjbWZRaFVmUWQwYkJlOWJIZlVnOWdCaEdoUWhJZDhiSmJ5ZlZjOWZJY3djTWRwZlVmVWJZZ0VoZmRGYUViNmFVY2tnUWZMZ2NoRmVwZENhYmYyYUpkbWVhZVJlUmJ5aENnRGR4ZENoVGhFYVVmSGNDZEVnZGhPYkxoSGhRaEZmY2ZCZFVlOGVHaEJna2IxZUliUmhGZDRiVGJGZnhnMWNJaGljdGE0aERkeWJSYlNlQ2JYZEZoWGRDZkhlZ2VCaFRnM2hwZXFoUWF4ZWtoVmNkZ2dmdGVSZ0dhUmRKZ3djV2JtZVJlVGZlZzFleGd0ZVlka2VzY2RlV2J4ZjBkZGNUYlJnbGhXYmRlR2U1ZDJjY2YyYTlnR2daZnhhWWhTZUNmWGhWaEJjRGFWaElnUWRRY3pna2NKYk9nVGV0Y2ljYmhXZGtoWmhmYnhid2VPZEVkRWFaYU5hSGRsZUlnL2FUZm1jbGUwZUdiSGVCaEJlZGVGZUZmS2JUYW5nVWdSaElhUWNrYUZlTGdTaEliWWJkaEVhcGd3ZWVnQmZSY3hmUmdoYk5oNGNVZDBlOWFrZGFhbGNOZUVjR2NuaHdkaGNXZFZlWWNTZ2Vma2hkZWtoUWJXZDVoS2VaZ0hjRWVGYkdnaWNGZlBoVWNoY2xiV2FBY2llMGIraE1hM2gwZjlnQWJ5Z1piU2ZaYnljVWc3ZkhjZ2ZoYVNnV2FRZHNnMmFEZndjd2hzYU5kaWQ4Zm1lV2FuZUpmR2VKZ3hheGhNZUhjMWhoYkpiVGNtYVJncGhkZUJmaGd3Z1FoWGhSZFJlU2JrZjVoMWdFZ1hnTWJlZ0ZoQ2d3YWxoQmFEZG9kUGJPY1ZlSmJJYUxiVWZaYytmY2FBZWRmRGJaYkhhdGVmZUdmVWdjZDRmUWhnYnBlWWZYYmpkOGVKYUlheGNVYm1mUWMyaGhmNWJIaDFnd2U0ZVRnbWJZYVpkWmJFZzFoZWViaG5hWmh6YWJiMGhaYW5kRmRoYUpjTWNkZ1JmY2VaZVhnbWE0YkxoY2hGZnBnQ2JiZzJnSmFtZ2FkUmVSZnllUmVqZTBmZWNIZUJmOGVlYUhlVmZvZmFjTWJDZVJmZGVmZmhiTWJ4YkVjQWQ0ZzdmSGJGZzhhbmhYYlVnY2dVZkZlVmVaaHBkRGd5ZDBhSGVXZmphSWJTZFdoamhjZWRmVGIyZHdjK2NYZHhobGVCZWVjUWZzYkNnZmZCZkpjNmJSZzJmUmdCZmJla2FwZ2thZWRVaHNlVWJjZ1VoOWJZZUdmVWV3YkVoT2htZTRka2NjZXplTWNhYVpjM2RzYWFoR2JIZGxjS2dBY2xlNWhFZVhjemdnZlRoRWZXZEVldWZJY3loZGJUYUpoZ2ZaYzZiSGFFYndiWmhHYVFlQmJHYU5iVGcwYkpoR2NDZnhjQmZmZ0FkVWhDaEJieWVaZ3FhSmQwZXhjYWVlZEdkRWJyY2RiQmROYTNmVWVnZHhkNGNYYlRjbGU0YlVhMGY5ZWtnYWVsZE1hWmRFZDNoQWZMZ0JjRmI4ZGVnVWRFZmRna2ZRYldhNWZLYVpiSGVsZExhRmVIaEViVmJVYzBjTmdKZ0JnRGhzZzZjT2hTZGNkMmFGZWlmSWJZZ1FkQWFrYjBoRGdtaFViN2RDZWxjOWJoZFRkQ2FBYUtmWWRuZ3RjcGdVZWlnY2hBYk1oRWRRYkZmQWZoZTliSmNIaFJlcGdsYWRoRWRwZDViUWZTZDloN2ZTZWtiNWgxZkVhWGdOaE1jVWVYZWhld2JWZG5iUWRQYU9oUmdkZkFoSmNCZlJoZGJlZUFmRmZQZE9kRGNaZVRiZGVCYXNoa2ZCZTFmbGFFY0hjbmVvaFRiTGZBYWdhOWNSYkNnZ2c4Y0JmVmNNYmxmVmhSZlJmQmZHZFZmNGdnYkpkamg4ZGdmRmNCZ0ljYWdGaGdjNWNRZWRnVmZJZVpiVWdoaGdiTGRKZEJoSWFMZVBnQmRrZnlmYWJSZjlieWRYZndmNGFMY1pia2ExZ1JmU2dSaFZkT2FhZlhlUWRZaGNkRWJFZXBnV2ZFYVpha2VkaFJkRmN6aFRhRmhGaDRkY2ZGZ1pmMGREaDJlTWRjaEdjaWVFYVVmWGNDaHdnY2hHZ3pjMGI2Z0ZhaGdkY0JlTmVVYW9mZGJJYjNic2UwZ0VjM2dkZVRnQWdpZjlia2JaZUVodGJTaEphRmFOYWVhR2ZWZkFiWmVPaG1iNWUrYUpmMmNOYUdmTmRSYzhhU2VGZTFiOWZLZEVnRmJKYkVhQ2EzZkJmYWRRY21jOWNpYVphbWJsZEdlTmh4ZW9nbWZRZWdlSmdOZ1dhV2RNY1ZkVGdtaGxlMGRHZEhoQmFCY2RmRmZGZktjVGVuYlViUmNjZHhjNWZSYkpoQ2F4aFdlR2VRZ2NkL2hYaGhoUmhsYVNkaGRNaHNkR2R3Y1ljM2RaYUJiOWZjY1hiVGNkYWZjRWJWYThmZWRVZEVlZGNrZ1FlV2U1Y0tiWmNIZGxiTGRGZkhlRWJkaEhoVWIwY1pkWGVpZ0FkbWJQYXlmQWdVZ0VlaGZvYVdiVGFrY3hkOWZIYWxoZ2diYkZjM2JBZmthV2JrY2xldmRjZ3hodGFwZ0NjR2I1Zk9hYWF4ZmxmTWZFY1ZjRmZCY1FoUWJZaGdoSmcyZU1ka2FRZ1hkOWhSY1doRGROYjFjRGhXYzllTWJRZEdmNWQ1Y1hjM2FRYUVmUWZWZElnVWVjYVVlWWhUZ2VoRmFOaFBoWmJHYXBlVGJHYVJlTmd3Z0NjMWFsY0hnQmJHYzFjUWZjZjFhTmMvZ1hnR2ZSZXpjU2gwZUFnNWNWYUVnNGYyY1RiVmZaYi9mYmZtYVVlT2JSZ1ViWmFuYkZlaGZKYk1hZGZVY29hUWFVYmtjUWRMYWNnRmJOZFphUmZXZEpkbWFhYlJlUmd5YVRmbmVNYVFkVGhFYTBjTWdRYkJkbGdrY2FnWGhRZllhY2hFZ0ZiMGNVYVVjcGFPYmRjUmZraDlnUWVnYUVncWZQZ3diSWQ3YVdmemJJZUNjVWNYZDhlVWFWY2pha2JYZE9jZ2EwZmtjQmZ3Zm9oQmhFZm1hNWZaYVNkeGhJZDhoRWhpZG9mQ2VPZGdkTWRyZk5kMGhzYWNoSmRSYkViZGVIZ3hlQmZXZExjMGVSYjJkY2gyYTloR2VaZXhkWWdTZ1RoSGFWY0toRWRGY0lmV2JUY2lkUWhQZ0VhQ2ZGaGlnYmdraE1jVWZjYmtmNWV6YUVlRWd4Z05mVWFVZ2tjVmFUYW1mbGcwaEdmQ2VKYUJiS2VBZzFlS2ZJYjNjMWRGZ2ZlMGd4YkZhZGhIYUFjQ2NQZkVnWWU0ZVhhRmRnZzBmQ2dGYVFhc2ZHZjBiWmNvZVFoRmJNaFplRWIzZEFnTGZXaFZoWWZTZ2Vka2JkZWtiUWFXZjVnS2VkZ1diOWNjY0FjMmVZZ1BjRGRGY3NiWmJYZUhjUWY2Z1BoamhvaDhjUGFUZ05kcmNFYWthZGVmZ1NmaGFCaFNjUmFBZnRid2NXZWtkSmh2ZVllbWFaY3BiRmVIaEplT2hjaHhiaGJFZUdjUmZrZEFmUmRqYlVnOWFkY0JlTmF3Y1VkQWVsZFJoVmhsYkpmMWZBZUdoVmdGY1ViU2hSYndkWGNpYUJoSGVJZ2doRmZ2Y0poVWhZZllmZWRFYkVmeWJaaEhmWmNQY0djUWZ0aDVmQ2J3YVZjV2hSYmplSWVPZk5jemJvaDZoU2VtaDlmNWhXZ0dlbGQ0aE5meGExZU5mR2RWZlpmMGdiZm5jWmJ6ZmJlMGdaY25lRmhoZXRiWGJYYTBlb2RRYlVia2NRYkxoY2ZGaHBlQ2ZiYjJlSWg3ZFlhQmNoZ1loVGVuZk1hUWZUZ0VmMWNSYlNiUmhWYk9hYWNYY3hlV2NmZmhiRWdtYkhjaGE0YUJhSWNVYmdjamNDZVZlOGFxYk5lUmFjZ3dnWmNpZlVkR2NlZ0JnUmZHY0RkbmhnaFZlR2JpZW9ocGhCZTFmQmdjZVBlZ2R0Z1JoQWZoYzVkNmdGZldlaGRCZEpmMGROYmtmSWJtaEVlVWhjZlJkMGNkZlRkUmVsYVdmZGFHZjVlMmJjZzJkOWdPZU1ieGRZYlBnVGNHYlZmS2RUaEZnSWhRZUFlbmF4ZmFiU2JqZTFhaWFlYzJla2FFYWNmaGJKZ3piUWRraFZkQmJVYVFmQWZWYUVmamdWYTBnZGRYY2dkVmVlZ0ZiRWFZaFFmbmVWZEZlT2N3Z1ViQ2ZkZmpjd2hUYk9oa2dnZC9hR2ZoZjFkcWZiZkJhTmY0Y1VjMGI5ZGtjYWFsZU1hWmNFYjNkQWJMYldlUmFCYWRnS2ZFZ2Rjc2NGaHllOGVZY1poRGJ4YUxmQ2RYYUZhSmdWZlFlUmFLZExhU2RBYVRlZWJuZE1mZ2FSZW5ob2dXZUFkMGRCYTFhQWFoZ0JhUGdSZEJhdGNyZFdna2RsZWtmS2dtYVpkMWFGZUNjQmhPY2RkUmdaZE1nUmZSZzVmSmVIZTFhTmRwZlpjZ2MxYW1oU2JHYjlhUmRRZzJnUmcxZUViWGROZk1kVWRYZWhhd2JWaG5oUWJQZGFnMWdJZlVhY2dRaE1hVGdjYzBiNWdQYU1jQ2VJZGFnU2ZtZWdna2VDYTFoSmRXYldiZ2hkZEhjYmZraEViaGdVZlVnNWQ1ZVNheGFSZXhmSGZSYTFlTmdHY1ZlWmMwZmJlbmhZYWhmS2ZoaElneWNSYUZheGhNZ2ZkUWdVZFFjV2hGZmtiTGdZZlViaGFhZ1pobWI1YW1mTGJCZFJnc2FVZTNkTmNmYVRjRWR0ZFhhU2VSaDBoTGVhYlhna2JGYWNlQ2N3ZDFmQmFRY0poQWFKY1ZoNGJrZlJlRWFOZjBmY2VFYzVnMGhCZ1dmc2JBZEhkWGFoZktiRWR6YzFjSWJaZldlUmNxYVVmeGJrYVRlY2ZBZXRnWmdWZGhiSWhuaFRjbWVoZnJoYmhrZXBla2JlZFVlc2FVaGNhUmMwYmRkVGdSZUVoWWRlZWphNGRraFBkRGNzZEpjTWEwYjloQ2JDZlhic2dZZFZhUmZNZEFoWWJqZjRnT2dJZUFicGdpZ2VhMmJsYVNkSmJ3ZEFld2FSYUFiVWZDaEhlMGFrYWRmR2NtYVZlMGhTZW5keGVCZFBhVmNoYkthRmJWaDhlUmhjYzBoeGZSZ2VjSGRCYldoZGVBYjlmcmhVZmhhUmQ1YkVkaGZOZWxiVWExZjlma2JOaGxmTmROZkdkbmF3YkxhVWZRaFFlU2ZaZDBjZGcwaFFoVGNKZkthTmduaEJhSGRGY0RoZ2VkZVFhUmdFY1plT2QzYndnNmdlYW5iTWM5Z1NibWVkYkNkV2VnZlVobWVSYUZjd2JYYkNka2F3Y2tmRWdrZXRmMGVTY0dnWmNwY0ZmSGdKYk9lY2J4YUJjTWdUZVZlRmFKY0ZlUWRnaG1hSmhoZWhiNGdGYXphVWJEaFNiZ2N0ZjFnRGFIY01jZWNYZFhoZ2MvZFZmbWhrZlBkZWFsZjRnVWRPYVVlWWFPY2VkQWdjYUhnTGhUZGtkb2RUZVJmTmc3ZUNoMWNSZmJoVmh3Z2RmY2RaZEFkUmh1ZFZiR2JSYXBjU2R4Y0piM2hIZlJhVWZDZkdnVmV4aHBkYmFtYVJibWRlZlVkOWc4Z0ZnaGd0ZW1lZGVVYm9jUWhVZWtiUWVMYWNnRmRwYUNmYmUyYkplbWhhaFJmUWg2Y1RlbmNnYk5jVGFCaGtmWmZBaEVlWWYxZlBjWGNRYVRmY2NFYXhmNWdGY0RkZGVPZmZheGVFZjhoVmczZnRiNGhjY0ZhWmIwaERnMmR0ZlNiRmFIZ0ZmR2JFZjNhZ2RCYUNiamRBYS9nQWdWZ2NiVGdlZkVhUmdaYVhjQWc5YjZoVmJuZ1poWmdaZzBnWmZrYk1hVWNzZ0tnYmJCZzFjU2ZUZFJjOWdRYWRjR2RZYythY2MyZkphYmdaZTNodGZUYkdhRGQxZ0VjUWJCZzBlVGdBZTJiSmZXZlFkbmVkZmloYmFHZGxhR2ZlYjBjZGMvZUVhQWZSZFdoZWMwZWtoVmFUZ21hbGQwZUdhSGRCZ0JiZGVGYUVkWGZSYjNha2E3ZmNjMGd4Z1JkZWNIZkJiV2RkZUFjOWhyY1VmaGd3Yi9lU2FFZE1hcWZIZEJoc2VyYVBkZ2FwZUpiVmRuZzVkWmFIY0JiZGNXZ0Vid2FrZndkV2VXaDVjWGNaZERiOGdlYldlamNKYUpnVmVBY0poWGZWZG5ld2M2aGVmbmFNZTlnVGQyZ2RiTmFPZEVjeGYxZlNmaGJCZ1NnUmVBY3Rkd2hXaGthSmh2aFliamRRZnNnUWNDZGNkY2VQYVJjQmJFYlplMWRGYUpjRmFVZjVlcGRkaEJnaGF3ZFFnWGNSZlJlU2VrYTVhMWFRZjNnTWVRYkRjWGhnZ2RlWGdpaEFkRGhhZjBoTWVZZ2NoUmRKY2JlTWNRY0JjQmJLZUNjOGVkZlhja2djYjRmQWJsZlZoOGRFZm5ncGRIYVpnRWNGZHVkU2NtYlJnNWZTZnhhUmR4YkhjUmYxZmNoQ2YwZzVlMGVhZUhmWWRuYUpjd2E4ZTBkYmFVaFlkeGVkZlZkVWdRZlhjMWNVZ0xjZWZsYnBlS2RmYVhmZGZ6Y2FlUmNsYXljR2VqYXRoWmNIZ3pmWWNGZ05lQmFWY0ZmYWJXYlVmUmNjYUZidGUwZkJjUWdJaEhnSmNtYW9ibmJNZ1hidGY0ZGNhRmFaZzBkRGgyZHRhU2dGYkhhRmVHaEVjM2doYmFnVmNFZjVmcWZVYXhna2JUZGNoQWh0YlpjVmJoZkpkNmdHZm1kMWhOYlJiRWVwZ2tmZWdVZXNoVWRjZ1JhMGFkZFRlUmRsaGVmT2htZkFlbWFJZ1NoQWVTaEtlRWdKZkxiSGFEY0JoRWNRaGhmY2dGYVRneGVrZ1VlRmFuYzVlMGdDZmdld2VVZmJoMGQ0YTFoUmVRZkllT2RCY1FlQmJhYkFhR2VsYThhVGhIaHhhQmVKaGxoaGNLZkZhVmI4ZFJlY2cwZXhjUmVlZEhnQmFXZWRoQWQ5YnJhVWFoZ1FmamJSYmtnOGJrYlVheWhKZHNjUGhsZjhiWmdBYVhkd2hMaERlUmY1ZWJnS2NVZGthb2dCZkNiQWVOYk1kRGdGYUNkRGMxYnNlZGdIZlVkMGVaYlZibmdSZXVoZGFuZ05ndmFSY21iZGhBYlVneGY1ZzFnQWF4YUJnUGZSaEZkOGM0Y0VoeGJFZVVoTmNoZHRlcGFTY0hkSmJHY0pkMWhnZEZhSGRpaG9kZGhGZlVkVmJwZVpnV2NWZXdjWGZXaGhkUmdVZ2toZGN1Z09mM2ROZU1mVWRYZGhnd2FWZW5oUWVQYWFoMWVJZVVjY2NSYVJiV2RMZEFnWWVkY0tibWNwYUFoQ2Z3YlJnbWNFZjFjbGNRZ0VmamhOZ0hmZWUwY0ZnNmFXZUhmMWh0Y1VoZ2ZSYWdoQ2VnY3RjZGJHZlFocGMwYUphM2RaZ3BmYmd3YzljOGhQZUJhSmhNZWRkVWRvY1FhVWhrZFFmTGZjY0Zjb2dmZlpmbWc1aE1lYWJSYVJheWVUYm5mTWhRZlRoRWgxYVJnU2dSZzBiQWRaY3ljUmZLZFBieGFVYzdmQmhSZE1iZWVNYkJmOGRoZ0NjUmJBYThmR2VSZWdoZ2JIYm5kMGJ3YWNjWGRGaGJoRWF6YjRkR2ZBZFNmY2MrZ0dobGZaYmRjY2dBY01iTmVXZWhoSWZvYlRmbWJRZ2FlUmFFY3Boa2RlYlVmc2NVaGNjUmcwZWRiVGhSZGxnV2dkaERjeGQyZExjemROZ0dnQ2NoZzVnR2hRZkhmVmFZYkhjRmFJYlFoUWR6ZWtkSmRUaENmTWFuYktjQ2U1Y0FnT2RrZWRob2FPYWtkeGVOZVVoVWRrYVZiVGdtZWxnMGZHZEhnQmdCZ2RhQWJjY0xlSGZIaFZmWWFjZTFnRmVSZUxiRGJnYmZoSmczaFFjL2dVYWhoOWJ4YlZlMmQ1ZjRjRGUwYTlnc2ZQY2hldGZRaFFhQWV0ZmZmSmVGYVlhT2ZaY2tmZGc4ZVNlSGNWYmdlWmdIZGxkTGVGZkhmRWNkY0hhVWEwZVphVmNuYlJodWhKY0RlWWU3Y0VnemdWYVlkRWJsZzlmbmZYY1FlWmZLZ1JmQWMxaHdoRWYwZkpmd2RZZm5iSmg3Y0RjV2FaZFhiWWV3Y0ZiYmdXZTBlRmRKZFNkVWM0ZWdoZGZBYkpmd2ZDY0diOWc3YlNla2c1YzFhRWZYY05kTWhVaFhjaGh3Z1ZiaWVrZ0djWmEzZ2dkVWhjZ1VnWWFUYWVnRmZOZlBjWmRHZ3BlVGdFYVZlMWgrZVdnd2JzZFphUmZqY1VlVGFQY1JoRWZyYlJnRGRZZzhhQ2FsYkFnWWhVZzBibGJlYUNhemJvZVJiYmZtY3RjemVLY1JiTWdwYlZiVWJZYUZoT2NnZlFnUWNXYWhkQWVIZmNjQWZoYUxkYmF6aGxkTWRhZ1JlUmZ5ZlRlbmJNY1FiVGJFZjFmUmdTZ1JiVmFPY09nemVGZE1iSmNSYU1hNmNVYlViSmZraGRoUmhGZnplVGRGYUZlNGFjaEZoWmUwZERkMmZ0ZVNoRmNIY0VkVWZFYXljUWdQY1Rnd2JsZWliQmJ4YVViVGRaYkFjZGFaZkFnbGJvYXpiRmdHYW9jTmhLZndiUWJqYUxjUWNNY2RiZmhUZ2NiZGFUaFJobGdXYmRoR2E1YjJnY2IyYzlkR2NaYXhlWWRTaFRiQ2ZFZ0NoV2JRYkViL2RYZ3doMWNhZ0hma2NWZGlkWmRtYWtmVWFjYWtkNWd6ZkVjRWF4Yk5nVWhVZWthVmhUZ21lbGUwZEVhQ2NRYUpnUGRRZ0lheGNHZG5kVWJhZ2NhMWIwY3NjZWVHYnhmS2ZkZ0JnZGRpZFVma2NoaGJnUmdoaE5oNGhVaDBkOWJrZmFjbGhNZVpmRWIzZUFoTGdXY1ZlWWRTaGVna2E4YndmQ2JTYmNoWmRIZXloMWJMZkhjM2hFYlBkWWdFYjBjRmNTaG5jUmUvZFljSGVwaHZkR2ZrZDBnV2hFYmtmeGExZ1NlaGJCY1NnUmRBZHRjd2hXZWtjSmd2ZVlnbWdaZXBoSGVDZ1lkR2FPZmtiTWUzZUdmVmRGZkNhRmZWZTBnVWNkaEFoUmFzaFFoV2VaY0ZoUWcyY1JnMWFFaFhhTmZNZlVoWGRoZndlVmRuYlFjUGNhYzFlSWFkZGFjbWN3ZFRjZWZGaE5jUGRaaEdhcGFUY0dnUmNOY3diVmRsZ0JhYWNPYUhhcGRIYlpmRWNGZHVhU2FtZFJlNWZTYnhkUmI1YlVheGRNZmRoU2h4ZmtkZ2hJYVNnSWRxZ1Bhd2FOY3BmUmZGZmNiTmVNY1NjTmdlYkJnbGNjZ1poRWNqaDliQ2VjZW1kSWJnZlBnRmVvZXhnR2hqZ3BjZmNBZGtkMWNaYkhkUmNsaE9nT2QzZDBmWWJLaDJldGgwaFVoVWhwZ09mZGJSYkZoemJUYUZoRmg0Z2NhRmJZYm1kU2JqYThhSGJSY2phOWFHZ0doMWdKZFRoVGgyZFJlcWFVaHhla2NUZ2NiQWJ0aFpmVmdoYUpkNmZSY3pkWmRCaE1iaGdaY2thRmdFY05nQWJmZlJoMGdKYVFiUmhrZUNkUGhDZWNibGhmZlNkTWVEYktjVmRGZkdmQmFIZXhmR2JPaGxmSmJFZkNnM2ZCYmFmUWRtYTliaWJaZ21ia2VVYWNha2M1Z3pkR2VCaGdoRmJHZkJhcGV1Z0dhaGhSZzBoQmRHZ3hnQmVaZmtoVmNEZlRjaWZrYjdnY2UwY3hjUmRlYkhmQmZXZmRhQWM5ZHJnVWFoZlJoeGVSZ2hhTmY0YlVnMGhjYndnSWRoaHBnS2ZhZ0NkUWVMZlVkbGRZZURkQmMwZ2RjNGFYZ1doNWdiZ2NjbmNCZkxjU2VGZXNhZGZIZVVjMGJaY1ZnbmVSY3VnZGduYk5ldmFSZW1kY2ZXZkVka2V4ZzFnUWhrYVFoYWdEZ1ZhZ2hMaERja2NKZ2tjWWhuZlFiVWhGYUdkNWVTYmNid2RoZkZmVGVRaDFhamFGZ1VnNWhwZ2RlQmZoYndhUWJYZVJhUmFTYWtnNWgxYkVjWGROZk1nVWNTZ3diNGdIaHlkZGIwY1BiMWRJZ2ZoY2dWZVZkdWZVZ2xoTmFQZ1piR2ZwY1RjR2RSYU5kd2dDYTFobGFXYkVibmJOZ2NhVGZrZUZhdWZTY21oUmc1ZlNjeGhSY3hhSGRSZjBjUWhFYkZjcGNlYmJibmVaZHpiYmEwaFpkbmZGZGhnSmhNYWRmVWVKZ2ViWGVCaFJnWmdQY3djNGdOYk9memJzYTJjTGJCZW9jZ2VDZ3piSmVVYUtmZ2dFYWVhQ2VFZ0VjaWNEYkhoUWVGZWNiQWhjZWhlSGR3ZWtlYWFQZ0ZhNGI5YlRlRmhrZ3NlZmZGaFlmbWJCZG1hc2FKZFBlbmJGZ0dnRWczYWhlVGVUYzJiUmJxYlVoeGRrZ1RiY2ZGZmtkY2JBY2thY2NvYkNkV2FRY1RhYmRoYVloNGRlZVNmWWhjZkpkUmZFZWRiV2VSZ1ZlV2JJaENjWWUvY0llR2FFY0tnSWhsaGhoVmdHZURhMWVEZUhmRmRJZnpkQmFTZ0lmZmJBZ3lndGRxZU1naWFGYmRmSWFVZ0plemRSYUVkQmhOYlVlRmZrZFpiVGRuYnRkbmRGYkhjQmFWZ2ZkVWhwZWdoVGhuZlVkUmJjZTBjeGNSYmVoSGRCZVdkZGRGZ0pjaWFYY2pnNWZ4YVJhaGJOYTRlVWgwYjlma2dhZWxiTWRaZUdkemI0ZEZkQ2hRYVJmZGhMaGdiZ2F3Y0dkRGM0ZVBiYWRpaHNlT2dWYVRoVmc3YlVhUWJKZVloQWdoZ1ljTGZkaG1jNWd2Z0FjRGVKZFlnVWNSZWdlOGVCaFZnNWFTZ1RoRmY5YThhV2FoYkJobWdZYmphMWJEaEZjSGFKaE9mY2Z4ZEJoTWZUZ1ZlRmZKYUZoVWU1YXBjSmdsZzBha2dGY0NoWWdmYlNoaGJ4YzFhVGhTZTlmTWVQYUhhQWZrZVdhbmdRZ2JjWmgxY0poQWNPYlFiOWZBZGRnaGc4ZUtjS2RpZjBoSGRVYlJkcGc4Y0NheWE1Y1liUWREaDhhR2JJZ0Vha2g2YUFnaWMwYnFhUmV4ZFFnbGhFY1JlMWNNYUNnRmRwaDBhZmdHYlZiL2JiZzFhSmN1Y0RmVGFoYk1mZGhVYW9lUWRVYWtiUWJMYWNjRmFwZkNnTWdtZXRkcWFRYnhmUmN5aFRlbmVNZFFkVGZFZTFjUmhTYVJiVmdHZ0pjM2RwZEloSWJnZTRlZ2NIZmhnNGFYZkpiVmNSZDljSGVoaFFjNWhOYURlSWg3YldmaWhrY2VnVWFSZzBjamZFZzJoVmRUaENoVGFFZ2tjRWhFaDFiYWNQYTBnVmFaYVhoa2FaZzJiUmJ6Y1pjSWRiaGhhRmVPZmVhVWFzZFVkY2NSaDBnZGdUaFJnbGFXYmRmR2g1YzJmSWdTZW9oU2hNZGtnUmVjZFRoQ2VkY0tmVGZBYzVoRWNaYm5lZ2dPZlRjbWY5YzZlYWhtZmxiQWVPY2dlY2dnZEhmZ2VBZUlkSGF3YTVoQmhCYW1jQmY0ZUdiQWNkZ1BnSmZoZVFlTGhDZm5mMWRGZk9kd2FVZ0NnZGdIYUFiQ2NlZkFoOWRxZlFnaGJoaHhkVWZ3Z0ZoMGJVYTFiZGZ0ZGNiWGJrY1pkRWgzZUFnTGVXZFZjWWZTZWVja2ZkZWtmSGdHZmRkR2ZUZm5lbGNMaEZnSGJFYmRoSGdVZDBjWmRWYW5nUmdtZE9iSGgwYS9jRmVDYmhnQ2FYZVJmZ2RzYkdmbGFWYmNnRmZrYjRleGZIZ2liWWhnZ05heWRRaGxjVWRSYUFocmNjYndkMWZNaENid2FRYUhhVmNoZW9mZ2dPYzFkWmN3ZVNoU2RCZGRkU2FoZHhkOGRFZ1NkaGVtYVVlWGNoZXdjVmhuYlFjUGJhYjFlSWRVZ2NjVWFZZ1RlS2doaFlmYmdNZFRoZ2FkYUdoVWJGY3djVmF3ZVZmV2NmYjNnSWFUY2FhRWdGZDJjUmNtZVFldGFBYzFkMGRpYkViMWRFYUliVmR4ZkViZ2FKZ25hOWMvZ2JhemdGZ3BhUmhGZ2NmTmNNY1VhSmhFZUdhZ2gxYVlmZmhGaG9jV2VZYzJhSmJuaGVmQmVoYXlnV2UyaEVhY2NUZEZiVmdZaFViamM5aE9kYWhYZVFhWWhjYkVmRmIwY1VlVWVwY09lS2ZCYmhiL2daZmxjRmM0Z2NnRmFaZDBnRGMyZXRmU2RGYkhlRmdPZVhkWGNZaERmSGJTY3NmK2hIZ0VmMWVLYklmRWY1ZlhmQWVVY0FhemRFYnljRWgwaEJkd2FRY3dlRmNTYjRnVWViYUJmMWNiZEdmRmRjZVZhSWNDZmNkNWFQZFdmOWNPaE1meGNvYVNiSGRuZmxhS2RXaFZkNWNFaFRobmFsaGFmR2RVZFZkaWFaY21ma2ZVZmNma2I1ZHpjRWhFZXhnTmdVZFVibGFjYUNjR2VsYzhkRWRIaGdjVmFkZUVjeGVLZ1JiU2NFYlllZmUwYnhlWmRLZm5nQmVMYmRnQmQ5YnJlRGZoYlFkamJUZnhjOWI0ZFdnd2haYWtiZGQxZE1mSmhFZnlhd2ZMYUVkRmI4ZWVhZWVrZ1lkaGFTZ0diZGZLaFBoMWhOZExiRmhIZ0VlZGVIZVVmMGJaZFZjbmVSYXVlZGZuZ05kdmZSZmplRmRYaFFoRWh3ZjZhU2FnZzFlU2dLZVVnb2hrYUVoa2h3aC9lTGRUY0ZmaGhCZG5jNWhPYmFleGNCZkdmVGZSZmhmQWhGYlVmTmNwaFpjUWJOZ2FmUWVYZFJoUmJTZmtnNWgxZEVkWGZOZU1nVWJYY2hhd2RWZW5oUmJqaFljd2ZaZWNlT2FCZ1VoZmFlZkFkZGJEZ1poRGhoZWZhR2VWYnBkOGhDYXhlWmJhZEVmbWRwZ09jZmcyZHRodWVTaG1mUmc1aFNieGVSZ3hhSGNSYTFjTmFHZlZoWWZwY1JoSGhaZ3pmYmIwZlpnbmRGYmhlSmFNZWRlVWJvYVFkVWJoYkpkS2JJZ2xhb2RLZWJoM2U5Y21hZWVCZmhhWWFUYW5oTWhRYVRlRWIxYlJoU2RSY1ZhT2hhZlhjUWFZZmNlRWhFZzZnVWZWYmRhT2ZaZ1FhcGZaYVRkRmFGZjRkY2dGZlplMGZEZzJndGNTY0ZkSGJGY0dlVmFUaGNmQmVUYjJld2QrZ0dlMWVCYkFmQ2ExY2tia2dWY2dmOWI2ZVZoWGJGY1ViYmhraHhja2dMY1ZoQWFVYmVhaGhaYlRhVGVRZFZnV2JQZFdjNWd3Z2RnV2U5Z09jTGd4Y1lhWWZVaFhjVmdZZEJmVWNSYk5iRWFIZEJjVGZhZkdkOWdpaFpjbWZrYlVjY2RrZjVmemhFaEVheGJOZ1VjVWhrZVZlR2RpYUVmOWRTZndic2hUY2RiRmFwZEtjQWRBZWdoUmViYWtkeGNaZExjSGhCZFplZGVFYWRkaWFVYWhoSmh4Z1ZoQWFaZnRjU2dHZ1Zna2NhYWxiTWNaaEViM2RBYUxhV2hWZVlnU2NlZWtlY2gyZUJiRGZvZmZiTmFqYmRkTGdSZG5lRWFXYkhmUWdRZENhZmRIYlJldWdkYm5jTmN2YlJmbWJjZ1dhRWRrYndnb2FRYnhneGQ0ZlJlQWZ0YXdlV2VrZ0pmdmFZZW1jWmRwZkZiSGVvaEFkZmNVaEFmZWhBYWdiVWFHYlFjUmdjZzVmTWZSZ1libmVFaHplMGFGZURjemJzaGNoWGF5YmNidWNOZUhlaGJ0ZVZmamhKZmFhSmdSZkZjQWRPaEFnbGhkaGVmRmRzZWJjYWVHYm9jQmNGZVJnTWU1ZEJhMWNrY1RnR2gzZ29hY2FUYWtnRmN1ZFNobWZSZTVlU2J4aFJoeGJIaFJiMWVOYUdkUmE4Y3llYmduaDVnN2ZaYnhnSmFuZUNieGdKaEhmSWZVZE1hY2NVZ2tneGRaYWNiRWJkY0NmZmIyaEloNmNhZ1VjWmU3aFFkbmRNZFloQmNVYTFlTWNTZlFkVmNPY05nWGJSY1JhZWNVYzFjMGdVY0FkOWNIY2ZlQmhFZG9oWmdsZ0ZlNGVjZUZjWmgwY0RjMmN0ZlNmRmhIaEZnR2ZFZTNnaGRUZEdmU2VVZTRjVWUxY1liVGViZlFic2QwaEZnMGVZYXljU2NUZ1FmT2dPZlVhSmEyZWRkVWJzYU1iY2VSaGNoZGNCZEJiQmFXZWVhV2Y1Y25hYWJFYlZkR2daZnhmWWNTZVRmSGhWYUtnRWNGZEpnRWZDaDNkQmNhYlFnZ2FOaHFiTWNpZEZoZGhJZ1VmSmN6YlJiRWhCYk5jQWQwY1VlVmFCZzJkVmQwZ1ZoM2d4YUJhWmZGYmhkUmdaZkhkVWJSZWNmMGF4aFJiZWFIZUJmV2FkY0FnOWhyZlVka2hsZGJmUmNoZ05hNGZVYzBhOWJrYmFlbGhNY1pmRWEzZUFjTGJEaHhnZGhBYmVlZ2M5ZGthWGZHZjRmRGVaZUhoUmRMaEJkWGIwYTNlSGdVYTBnWmVWYm5kUmd1Z2RjbmJOZHZlUmVtaGNkV2dFYmtod2I3Y1NkZ2ExYlNjVmRSaEJhYWFXZ2tkSmF2YllmbWZaaHBiRmFIZUplT2hjZnhlQmZNZENheGc0aGJkRmdVZFlmOWJQYUZjRWFqYk9laWhaaFJiUWZVZzRkOWFiZ0hjTmFSZFViV2dwYWxjUWUzYVFlSmdhYndjWWhQZGNmVWVzZWVmTWNGaE5lUmFlZldjcGNEY0dmUmFWZzJhQ2IxY0VnWWFFY25iQmFhYlpmRmFOZjdiWGZHZDFnaWRTZXhoMWFiZ0hnUmcxZk5iR2ZWZVpiMGJiZW5mWmF6YmJiMGFaZ25nRmdoZElmWWJQZlFmTmJEZ0toUmdZZ0xjZWYxZW9jS2FFZG1nSmQ3Z2FjUmZ3Ym1kVGVuaHdnUWhBZmthUmRSZ1RieGhWZ2NmZmRHZkVoRGVXZmtnRmYwY1VnVWZwYU9hZGJSZkZkemJUYkZjRmg0ZGNkQWhRYnhmV2J6YjRlQWJXYW5jRWFVZkVlM2NOYlRnQmFuaDljQWhVYnhoa2RUZGNkQWJ0ZVpiVmhoaEpoNmVSaHphbGNJY1lnbWdCZWtjZWRVZnNjVWFjZlJkMGNkZ1RlUmhsZ1dmZmhDZ0JoNGFJZnpiMGhKYU1nMWRsY0djRmdTZFVlUGVIYmdoVWFXZ1FoaWhRY2ZjTmN3aFljc2hNZW5nRWRVY2JhMGE0ZTFnUmVRYUlnT2dCZFFnQmVhZUFkR2ZsYjhkVGdIYXhnQmNKYWxnMWZLYkJmM2h3ZVJnS2ZHZlplUmVlZEhkQmVXYWRjQWE5aHJmVWVoYlJneGZSYWhjTWZxYUZiaGJzYnhoT2JCZjBkWmVHYzFnb2dMYldoVmZZZVNiZWZrY2Rha2JRZVdnNWVLZlpjSGZsYUxlRmNIYWxmSmVIaFZjQWZaZ1hoU2NCZG5nZWhsZ2xmdmhSaG1kY2VXZEVia2Z4ZTFjU2NoYkJmU2ZSY0FjdGh3Y1dna2FvYjlhWWFuZnRkcGRCY0hlSWVTZGNoMGVKYkZoUWRYYXRiSmhGZlVkNWJwaGRlQmJoZ3dhUWVYYVJmUmNTZGtlNWExaEVjVGdwZk1nRGFTZ1Jkd2RPYm5ieGhiYkloeGZ0YUhjZmFVYlpoSGFkZUZlTWVkZGFnR2ZwZkNmRmJSZE5iaWhIZGtoeGNhY0VhbWVwZk9iYWFHY3RmdWRTY21oUmQ1Y1NjeGFSZXhnSGdSYzFhTmFHZ1ZoWmMwYmJkamFoZTljR2d6ZDhlWGFjYjNmWWV6YkZhRGFoZ2lmTWV6YzFoMGhBYXllOGR5Ykhld2QwYVVkSGZSY1FldWFFYW5hTWdZZkdiRWIxaE1kU2dYaGdnUGZQaFRhd2JXYk5hZ2EwaDdiSGdoZ2hjR2dJYVJnaGY2Y1FjSGV0ZzRkY2JGYVpnMGhEZTJldGdTYkZjSGhGZ0dnRWYzZGhoVGhUZDJmd2IrYkdjMWZCYkFkQ2UxYWtma2JWZmdhOWc2YlZiWGZGaFVlYmdrZHhja2FMYlVhSWdZYVdmeGMwZ2RmVGNSaGxlV2VkYkdiNWgyZ2NiMmg5YkdiWmN4aFljU2NIZW5hVmZCZUVjRWFOZ3VlQ2YzZ0JkYWFRYm1nOWdpZ1pmbWhrZVVoY2drYTVnemJHZlZjZGNuaFVoVWdrZFZhVGhtYWxkMGVHYkhoQmNCZWRiQWZ4Z0RjUWVsZzhnUmJjaDBheGdSZGViSGZCZVdoZGdBYzllcmJXZ2xlcGgvY0Zia2VFZTNnQmF3ZEFld2JNZ3dhTmFjZEhhU2RkY1pnRWRBZ0pnWGhEY3llNGdxaEZkWGg5YmNjQ2VCZXhnTGNDZVhmRmdiaFNmQWROaGFoQWFqZDBjaGFPZUhjTmduaEVnbWVzYldmUWVFZEJiMWNBZHhnbGZTZUhneWFGY3dnV2NrY0pkdmhZYW1hWmZwZkZoSGNKaE9lY2F4YkFiZWRDZ0FiVWhjZ1Jld2VCaHBjZmVEY0pod2dRYVhmUmdSYVNna2Y1YTFmRWRYaE5hTWVVZ1hnaGN3YVZnbmh4ZGJmYWUwYzhjVWRlZWhkSWJhZWRhSGJsY1BlWmdHYnBjVGFHZ1JkTmV3Z0NmMWRsY1doRWRuZ3BhSGdaZkVma2Y4ZFNjbmdsYTViV2V4ZVFhdGJIYlViOWRFYUZjWGd4ZzBoYmVuZVpiemRiaDBhWmRuZkZkaGNKY01kZGdVaG9hUWVVYWdiMGVMZExmQWRaaENmQWQyZm9neWNJZlZmMGJoZ1FkbmFOZUVlUWJFZzBiRGZSaFJnVmJjYlpkWGFRYU9hWmZWY1JlbmJSZUVhWmFPYVpiUmNoZi9nWmNsaEZnNGZjZ0ZhWmUwZkRkMmh0Z1NmRmRIZkZjR2dFYzNiaGZUY0FhV2ZvZ2ViS2FtYmxlMmVGZUhiUWg0aEpoR2JBYmJnUGdoZHNmeWdHYXpnb2VVZ0ZoamFsaGdmV2N4YjBnZGRUZlJhbGFXZGRiR2M1aDJiY2cyZTlhR2FaYXhoWWhTZVRlSGNWZ1ZmRWZGYnBjTWdYYnpiZ2JUZUVnUmVRZXdnR2IyYWtiSmdjZ2xoeGhtYUJoVWV4YkxjVWNSYTBnY2ZRZm1nbGI4YlRmRGhnYkliSmN5Ym9oWWZUYm5jNGZSYllnamNGZ1JhWmZYYUFmQ2VkZUJoRmIxYVRoQmVSYXBnVGh4ZHBiU2RVZjBlOWJrYWFjbGFNZlpnRWEzYUFiTGJXZVZhWWRTZGVna2ZkaGtlUWNYZ1JkS2RDZTNkRWJmZlhnRGZoY09lRWNVYTFnTmFXY25oUWE4aGVkbmhOY3VlVmNtZzRiYWhPZEVieGUxZlNoaGhCY1NmUmZBYnRod2dXZGthSmd2Z1ljbWZaaHBiUmRuYkpmRmNjY3dkSmFtZ1RnVmZGaEpiRmNVYzVocGNkZ0JoaGh3Z1FiWGhSYVJmUWIxZ1ZnZmRFYVhnTmFNZVVnWGNoYndlVmduY1FjUGJhZ3diOGRkZmZlV2F3aFRkZWdGZk5jUGhaZEdncGhUY0doUmVOZndkQWZ4Z2RoWWJRYmljZ2NJaE1hQWQ0ZzZoRWR6YVFlOGhSaFVoTWNqZVZkRWVrYkljYmREYjhnNmdPYW1lZGNsZ0RkU2FOYW5lQ2R4YUlhS2NJY0FlUmFUZUJmZ2UxZUViUGRsYnBmS2hPYTJiNWRtZE9jeGhoZ3ljQmUzYm9jUWRGZDJjZGhSZ1NkUmJWZU9iYWZYZFFnWWNjZkVoRmgwYVVhVWJvZ2NlTWZFZFVmbWdIYmhhOWI0ZmVnSGN4aDBkRGEyY3RhU2hGZUhhRmNHZUVhM2ZoYVRoVGMyZlJjcWhVYnhoRmhIZmNnQmJaZ1pjWGJVZFpjemdTZTBmNWdCZ2Jha2RwaGtjZWRVYXNoVWdjZ1JkMGRkYVRmUmFsZVdnZGZHaFloa2JjYzNlSmNHYmRleGhaZE9kVGNDZGRiRGFIaEhnaGdFaENoM2hCaGFoUWVtZzlmaWdaZW1ma2hVaGNma2Y1aHpkRWFBZFZmTmREYVJnVWdWZUlnbWVFZWdlVWNEY2toU2JlZUZlRWZlZFFibmRWZ0RiZmEwaHhoRGFkY0hmQmJBYlloUmFwZzRiUmJ4Y2hkeGdWYmhlcGQwY2VjVWg5ZmtmYWVsZk1kWmFFZzNnQWhMZFdjVmhZZVNhZWhrZWRia2dEaDJhQWIrZ0hmUWZrZXVoY2JBYzVhOGhiZnpnOWE0Ykxmd2hzYWRnQWV3Yk1mZmJLZFJkVmRpZE9nRWJ4YzFiU2hoZ0JkU2dSYUFndGV3Zldma2JKZnZlWWFtZlpmcGdGZUhiSmNSZmNheGVoaEVoR2NSY2toQWJSZGpjVWM3ZUNmUmJoZ3RlUWZTY0JiUmJWZ0ZoQmhyaEVhV2h0Z0ZhWGFYaGhnNGVBY2poeGNHYU9iQ2RsaEdkY2RVYjBiVGdhZlNkNWJQaGVhV2ZwYUJlRGVBZFpld2VEZVZna2ZDZkdjM2hOY3RhWmRFZUZldWRTZG1iUmE1YVNjeGdSYnhlSGFSZTFmTmdHZlZjWmgwYWJhbWN4ZnpoQWRFZzRkemFYZ2xlc2RmZmVkVWZwYkVnWGdrY1JmWmJmZUZjcGFEZWZlbWZ0YXFiUWh4ZVJjeWZUYW5hTWVRYVRoRWExZVJlU2NSZVZhT2VhY1hoUWVZY0lka2hGYS9nVWVWY2hna2RkY1JnRmF6ZVRnRmJGYzRjY2JGZVpjMGFEYTJhdGJTYkhhV2VwZ3NjRWgzZmhmVGdUZTJlUmFxZFVoeGZrZ1RoY2VGZVplUWNXZWpjaGI2ZlJmMmZSYUJiYmNrY3Bma2hlZVVkc2JVZWVlVmVNYlRjSGZVZXNnWmNJZ0NnRWNpY0tkamI4YkRiYWdVZkZjQWNCYVNmRWNQYlplVGJzYktnWGMyZk5nSWFMYmdmcGNpZGVkMmdsZ1NhSmJ3ZUFld2dSZUFmVWNDYUhlMGFrZmRjR2VtZlZnMGVTaG5leGZCY1BnVmRoYUtkRmdWYzhiUmVjZDBkeGFSZ2VoSGZCZldhZGVBYjllcmFVYWhnUWFqZUFoMGRjZXRiQWRRZkZia2dZaG5oa2JaY0VhM2FBaExmV2ZWYlllU2VlY2thZGJrYlFhV2M1ZEtoWmVIZEVjZmFGY0did2VkZUZjaGVrZVFhV2VsZDVjdWdkZ25hTmZ2ZVJlbWNjaFdjRWJrZXhmMWhTZWhiQmZTYlJjQWdNZmljV2JsZzlkdmZjYW1kWWExYkZkQ2FCYkhnZmZ6ZnBmTWVUZVZmRmVKYkZjVWY1ZnBoZGhCYmhkd2hRZlhkUmJSYlNiZ2ZkZDFhVGhTYjlnTWRQY1hkQWJrZ0hnamMxZmNoWmMxYUpmQWJmZlVhWmFCZGRoRmJOYmJhYWZHZXBlSGZDY3dncGFrZUVja2Q5Y0JnQWVHYU5hU2JhZ0ViRmcrZlFnMmFoYVRnU2N4YVJheGhIZlJnMWJOZ0dhVmNaYTBjYmJuZlpiemdiYjBnWWVwZ0doR2FZaDFlQmVTYTljMGJMaFNiVmU1aEFiamNzZjdmRWRCY0VnVGVHZVdjUWJkaFBlQWVjaDZiVGVFYzFmUmVTaFJjVmZPZ2FjWGFRZ1liY2JFY0ZlMGdVZFVhcGJPYmRjUWQ1Z3pmUmdGaGtoc2dPZUJmOGJuZGRhRGFsYVNmSGQzaEZjVmhiYm5oaGZPYlRoemZCYnFiVGFRZWNnTmRjY0JnbGdOaFhieGQ1ZVFiUmMyZVJiQmNiZWtocGdrZmVoVWJzaFVmY2FSZTBhZGNUYVJkbGVXZGRmR2M1YzJlZWd6ZHNmT2RMZGtmVmRwZ0hibmRWYUJiRWVFZ0FmNWJDZjJiMWdhaEZnbWU5ZzhlZWJIZ2NhVWhZYjFiaGY2ZkhiR2JaYU5hVWVVYmtmVmRUZG1kbGMwZ0dlSGhCY0JoZGhGZUZiS2dUZm5jVWNSZGNiMGR4YVpjTGJEZWdoZmhKaDNoUWY1YlViaGU5aHhmVmMyZDVnNGVUZGtjOGV3Y2Fka2MwYkhjRGFYYkFmVGJVYkZjb2U0Z2Vja2NkYWtlUWJXZDVhS2RaY0hjbGNMYkZjSGFFYmRoSGFVZDBlWmhWZW5kUmV1ZGZlaWVjZG5iRGh6ZVJjdGhRZkRkRmYxYVZjeGFCY0FjVWVSYzVkd2FYZkVmSWI3YWFhMmE5ZERmRmhIYkpnT2NjZXhkQmRNZlRjVmJGYUpmRmZVYzVjcGdkYUJnaGV3Y1FnV2I1Z1JmSmZFaFlhaGZXYlRnb2ZmY1hkWGNnZmtmV2duZ1JkZGFaZDFjSWRWZ1lhVWM4Z2ZhVWJsY05lUGVaY0docGdUaEdmUmhOZ3djQ2gxZGxnV2RFYW5jcGdIY05ka2VGZ2xlU2FuZUJkVGJTaHhiUmV4aEhmUmIxZ05kR2VWZVpoMGNiZm5hWmJ6Y1pnbGIxZ05hRmhoZUplTWNkZFVob2NRaFVka2ZRY0xlY2RBYmRmTGRZZTBhaGRtZGFnUmhSZ3lmVGVuYU1hUWhUaEVoMWdSZFFoVmF0ZEFhT2FTZ1pnWGJKZkFhNGhnY0NlQmJvZ0xlZWcwZVlkaGhCZ1FkVWI5ZkJlVGM4ZzZhV2gzY2hnQWdkZGhoUmFHZURmbmJnY1ZjR2hpYm9lcGFCZjFlQmZjZlBoZ2h0YVJiQWRoZTVoNmRGZldmaGRCZkpmMGZOZWtlSWhtaEVjVWVjYlJlMGZkY1RkUmJsaFdmZGNHZDVkMmJjYjJkOGZVaElna2JKYkhnSGJqZXRoS2FHYkhnaGFFYUNhM2FCaGFjUWdtZzlnaWdaaG1ma2NVaGNha2c1ZXpiRWhFY1FiWmhVY1ZkUWdWYlJlVGgxZDlhRmFGaHBmQmRkYkZmRmNLYlRlbmVVZVJmY2UwZHhmUmdlZ0hnQmVXYWRiQWFjYzVhVWZnZGxneGRWZ2hiTWZrYlVoeGMxZXRhWmNuZGtlWmdFZDNlQWRMYldlVmhZYVNmZWFrYmRja2VRYVdnNWdLZ1pmRGZCY0xlU2NDZzBoZGJjYlVjVmVOZUhhamUwYTliZWZuZE1lN2RTYm1kZGNFYkhma2Z4ZWhlUmNoYkJjR2NWYWhjSmRrZlFmMWhSZTRiY2ZIYzllOGdHZEhmSmZlZmVnaGR4YW1iVGZWZkZlSmVGZFVlNWhwZ2RiQmZoYndkUWdYZlJkUmRTYWtiNGc3aEhod2ZjZTFjSWNSZjBlVWZLaFJmVmM5YkdkVGdOZHRmRGhqZ1ZhbWFDZ0NmTWRnaEZlaGE1YTVnR2hSZ05id2dDZzFkbGdXZ0VlbmhwZEhiWmhFYkZjdWZTZW1hUmQ1ZVNjd2J0YnhhRmhSZVVmWmJVZFJhOGJuaEZlU2dRZE9nYmUxZ3RmbmJRaGhlSmFTZ2FkMWVRYlFoUWVGY0FnQ2RmZ0hhQmhDYmJhMmdKYW1mYWVSZ1JoeWNUYm5hTWhRZVRiRWgxZ1JiU2hSYlZoT2ZhaFhjUWZRZEpoQWFrYTlmQWhqZ0VjY2hkY1JlcGZ6YVhkU2h4YjRhYmFWZFlnZ2REZjNoVmdNY0NnbmNGaFhnQmNYaEZkZmFaZ1doUmJxYlVmeGhrZVRiY2ZBZnRjWmRWZGhkSmE2ZFJlMmZSYUJhYmZrZXBja2hlYlVnTmFBYk9oVmVSYk9iTmJraHRiV2dmZzJmNWdrY0RibWI5aGJhWmQwZ0lkU2RVZG1odGVVZEVjRWRwZE5mQmYxaHBlYWNRZ21mOWRpYVplbWRrZ1ViY2ZrZzViemhFaEVkeGZOZVVhVWRraFZoVGJtZ2xhOGRUZ0RmZ2JJY0pjeWZvZllhVGJuYjRiUmJZYkRnRmZSY1poWGZCaEVhWWdSYnBkcmhWZEJmUWVsZFRmeGdwYVNkVWYwYzlla2ZhYmxhTWdaZEVjM2dBaExiV2RWYVlhU2RlZ2thZGhrZ1FoWGFSZkthQ2huY0VkZmNYZURmaGVPZEVhVWgxZU5oV2JuZVFoOGFlZ25jTmd1YVZhMmE0aGFhT2ZFYnhkMWdTYWhnQmNTaFJmQWZ0aHdoV2VrZUpodmRZYm1hWmRwYVJnbmNKZkZhY2V3Z1JlbWVUaFZmRmRKYUZmVWQ1YXBiZGZCZ2hjd2RRZ1hmUmRSaFFiMWhWYmZjRWNYZE5jTWNVZVhnaGR3Y1ZibmhRaFBmYWJ3YzhmZGdmaFdjd2NUY2VoRmhOZVBkWmVHYXBmVGhHYVJjTmd3YUFieGJkZ1lkUWVpZWdhSWNNZUFiNGc2ZUVjemVRZDhoUmFVZk1iamZWZEVla2hJZmNlQmJnaGdmQWRoZU5jemJjYmtjWWFoYlFhMWR3ZlBjSWVRZE5kZmFIZUVkUWREYUplRmhaZENhUGVXZjVibWJJaEJiaGF5ZENnM2dvZlFjRmMyY2RoUmNTYVJlVmJPZWFkWGZRZFlhY2dFZ0ZoMGdVaFVhb2NIZ01jeGhGZjdkUmNGY2toc2ZjZkVidGQwYkJnRGU5ZmJmR2ZIZ0ZhT2dRZ1hlaGdPYVRjM2hSYXFiRGR4YWxkQmZlY1FkZGdaZVZiMWJkZXplVGFtYVFiYWhSY0VkcGFrZGVoVWJzZ1ViY2ZSaDBoZGhUZlJhbGRXZWRnR2U1YTJhSmJTZzRmVWFaZjFna2JTZFViWGFVZG5hVWZRZllnTWNCYVNhQWNWaEZiV2hkZ3doYWVtaGtiTWhjZWthUmZ6ZldhVWN4ZUFiVWhWaGdmY2ZWYVVhTmMwZUdoSGFCaEJmZGdGZkZiS2FUZm5mVWdSZ2NnMGR4YVJhZWdCaHhoZWhJZUVhY2NpYkFjUmNoY3hiRWRoZjljNGFBYlVhTmNrZEloMWE4ZVpkWGZIYkFhR2ZXZlVmY2JlaGVoa2hvZnJhU2JIYlZhZ2JaYUhhbGdMaEZkSGNFaGRnSGVVYTBhWmFWZW5kUmN1Y0tlMWFsYnZmUmJtaGNmV2FFYmtneGIxYVNhaGFCY1NhUmdBZHNibWhHY3hiQmh2ZUtmbWNaZDBiRmNHZUpoQ2FXZVJmQmNNZ1RjVmZGZEpnRmhVYzVicGJkZ0JhaGF3ZFFjWGNSaFJkQmZFYTVkb2FFYVdnSmFBZ2VhM2VoYndjVmVuZFFoUGJhYjFnSWhVYmNkVWdZYVRnZWhGZU5jUGROaDJmcGVPaEdjUWhOYXJiSWFWZGxiV2FFY25jcGFIZFpkRWJGYnVoU2JtZ1JjNWhTYzFnSWcrZlRieGMxY0ZnVGdSYzRjOWZQZ1FkMGNoY0Vka2daaDZlRmVnaEJjWmVZZkVib2VXZlVlaGNBZ1FiY2VGZEZhSmFKYzJlSmQ2Z2FnVmIxZ3lhU2NIY1VjUWVSZkFjTmFSYlFid2hoYU9nZWcyZkVnT2VlZ1ZkcGUwYldkR2FCZk9hZGJSaEZhemNUZ0ZoRmE0YmNhRmJaZzBkRGQyY3RjU2RGZUdnRmJHaERlWGFnZUhnVGUyZEpoc2hVY3dka2ZUYWJoUmdaYUVnVmJrYUZiNmhRY1djSmVCYmZia2hwYWxlWmdGZllkVWNKZ1ZoVmJVZUhkbWVJZUVkZGJHYVZmMmJPZTJkOWFMZlpid2FkY3ZjVGRIaE5jTWdFZUZkb2dYZ0NmMmIxaGFnVWcyYlpmdWVUY0dia2dVaGNha2I1YXplRWhFZ3hoTmVVY1Vja2RWYlRobWNsZjBjR2JIZ0JjSmJJZEJka2VEaEhoUWI1Z0RiY2cwZmRmUmFNZEFoMWhXYmFlUWE5ZGphV2doZHdmbGdSZ2hkeGc0YkhnVWNaZmtlZGNFYTBnWmNBZTNma2NMYVZkRmFaZ0JlY2UwYmRhaWhRZFhmeGNmYmNnWGRCYlFlUGZuZEVnZGNIaFVnMGFaaFZkbmZSZ3VhZGhuYk5mdmVSZ2pmVmVUYlJkaGZrZm5jQmRCZ0FnQWZSZUFkQmh3ZUViMWJsYkZkWWZtaFpocGdGY0hnSmNPZWNleGJCY01mVGFRYnhhQWZHZldiUmdwZWRhQmFoaHdnUWVYZ1JkUmhTZGthNWMxYkdlVGExZ0NjQWdTZW9mL2hBY2podGFiZ01hZ2JKZ1JkZmd4Y0ZlQmZNYVFmY2FLZ0RlU2JRZkhhZWIzZFpjd2JGZmxha2hRaFJjemVRZUViTWVBYmdoaGJCZEdlUmN4YUhieGhoaHhnVGV4ZkZhTmNVZkZicGUwYktoM2E5Y3plTmhHZ3hhbmRGZmhmSmZNYmRhVWhvaFFoVWFrY1FjTGFjY0Zmb2hMZEtlV2RKaHVnWWJSYXdkbWFUY21nNGRRZVJjeGdsZVloUmJSaFZmR2hPaDNlUWFGY2NkRmJGYTBlRGdVaG9hY2hmYUJkMWh6ZlRjUmJSZHhiZWJWZFlmdmJKYldmdGVTZEZoSGVGaEdhRWYzZGhjVGRUYzJiUmZxZFVneGVrZFRoSmdrZ29lTGRWYWxjMWI2ZFdkbWZRZ3NhTGN4ZDRjc2hkZnhldGdiaEpnaGZVZlBhUWFSYmxlT2dkZ0dhUmQyZk9ibWg5ZExjWmV3ZGNiYmVWZjFhOWdLYUVnRmNKY0VhQ2gzZkJlYWJRYW1lOWdpYlplbWdraFVnY2hpZUpjN2dSZEFhUWNFZ0Fla2VVZVZoR2htYlZmMGRTZG5jeGZCZ1BoVmExZUtjQWZYZlVjY2VjZTFnMWdkaGVkSGEwYlpiZmdSYlJhQmFVZGhkUmV4ZFJmaGVOZDRnVWIwYjlla2JhYmxiTWZaZlRnbGNvY0xkV2ZWZlljU2dlaGtiZGJrZ1FjV2g1Y0tjWmZIYWtoZGRWYlNiTWdkZFZkVWMwZUVjVmRqZjFndWNlZjNnTmQrZVNha2IwYldhRWhrYnhjMWdTZmhoQmJTYlJjQWZ0aHdhV2drZEpmdmNZZ2lmaGJwZkNnWGVKZWZmZmF6ZHBnTWhUZVZlRmhKZkZlVWc1YnBoZGVCZmhod2dRZVhkUmVSZ1NhaGMxZDFmRGFIZk5nY2hTaGxnSmZ3Z1ZkbmRRZ1BiYWQxYkljVWFjZFVlWWZUYmVnRmNNY0plS2V6ZmhiVGJFYlVhY2c0ZFFoZ2NvZXRlUWdIaHBiTWRaZEFna2NUZFNlbmFsaDVoV2dRaEZma2FIYlJldGROZVRiVWYxYzBmWWQzZXNlN2FiZTFiaGU2YUZkZ2ZKYU1lY2YwaHdkUWNXZGdmb2ZMZ2Voa2RkZENhZmhYZ2Rid2FZYUFoOWR5ZVJnMWNrZlFiVGVFYzFlUmRTZ1JhVmFPZGFlWGFRZ1lkY2ZFZkZhMGJVZVZhcGJPZWFieGVFaG5kVGhGZWRnK2VjaEVkWmYwYkVlbmhaZFBhRmZDaEpnR2ZGaFhoNWVUZlhhMmhSY3JkVGRnZVFlVGJKYkViTWRRZEJoV2hrYW9lUmIyZTlnQmhKZmthcGd2Z2VlVmFwYnBjY2NSY3NoYmhUZlJmRWNGY2RlSGZOYTJnWWhtZ1pkS2FUaFJkWWFTZFRkSGFWZktoRWRGZEpiRWZDYTNkQmNhZVFnbWQ5YmljWmFtZ2tiY2FKaGdjWWc2ZVFnemdjY2ZnVWRVZEliVmVCYWhlUmUwYUJnWGhCZ0pnZmJGZWtnZWNUY25kb2JSZFBlVWRWYlJoWmFtZTViV2RaYkFiWmRyaFhmeGVRZmllVGh4aE5kK2ZVaDFmMWh4YWZlMWVvZkNkT2NYZEFiTGVXY1ZhWWZTaGVha2NkZ2tmUWZXYzVhS2haYUNnc2VPY1FnQ2FSZVBoVWMwZTFkTGJWZ25lOWV1ZVBhMmhoZ0ZmUmNtaGNlV2ZFZ2toeGExZlNnaGJCY1NmUmFGZ1plNWJWaG1maGR2aFlhbWdaZHBmRmhIZkpnT2FjZnhmQmRNZ1JnUmU5Z0hjUmJSaHdnbWdJZkZmY2drZkdoQ2ZRZVVkUmJCY2tmbmRXYUNnY2FKaE9mRGZZYmtlVGZuaFFkU2JhYXhkUmVCYVBhd2ZWY0hkTWJSZ3dlQmZaaEdlSWVIZ0ZjUmFNZ2lhQmIxZGtkZmZHYzNkb2RjYlRka2NGaHVoU2FtZVJnNWJTZnhkUmd4YUhhUmMxYk5iR2VRaFFieGRPY2lkTWdoaEliVWNaY3ZmUGNCYkphTWhkZFVkb2RRY1Vka2VRYkxnY2VGZXBjQ2hiZjJnSmJtYlllVWhCZXloVWMzZE1lYmFHZUVnUmVkaFljeGZWZU9kYWZYYVFoWWVjYUVjRmcwYVVjVWZwZU9mZGNSZkZoemFSaEFnTmg0Y2JkVmVaYWtiRGV6Z2RjU2ZSZW5naGRLYk9oWGFoZFRiVGgyaFJicWhVYnhia2NUZWNnQWd0Z1pnVmFoYkpnNmVEZG1iUWJkZk1ia2JvaElmY2hSYTlhY2dPZkVmNGNSYlRmVWIxZmFhZGdEZXhlNmJjZDNkNWhLZFpjd2VjYkFoV2czZmxnS2hIaFVhTmNXZUVnM2JsYldhYWFHZjliaWdaZ21ka2NVYWNia2U1YnpjRWdFZHhmTmRVY1Vla2ZWZ0FhR2ZjYkFoWWVRY0Fka2FFaENmNGVyaFBnQWdkZ3dlQ2hqaE1haWREYlFoQWJtYUdmM2cwZ2ZiVWVrYWdldGNSZWhlc2dzZVVjMWZKYWtmQmJ4aEpmTmVXZTNkNWNOYkZiUmFsZWRhS2ZFYjhid2RTZ0dkZGJHZlRlbmJsY0xkRmNIZEVnZGhIaFVoMGZaZVZmbmVSZ3ViZGduZE5hdmdWYW1lY2dJZ0VmaGdoYzFkVGhCY1pnU2hUZkZoOWV3Y1JlMGVKZjlmZGUzaE5ocGFIaDNjSWVhZWNieGh0ZU1iWGNGZGhiRmZQZDBlNWdwZmRiQmdoZ3diUWJYZVJiUmdTZWtkNWgxZ0VhWGZOZ01jV2RTaHdlNGJIYnlhZGcwYU9hU2g4YVVoYmVFZ1llQmNiZVVlWmdQaFlobWhvYUhhRWFCZjlkYWhDZTFlbGVXYUVobmRwYUhiWmVFYkZidWFTZm1lUmQ1Z1NieGdRY2piSGdSYlpjTmRDZ0hieGIwZGJlbmJaY3pnYmcwY1pjbmNGY2hjSmhNZGRoVWJvYlpoU2VXYjRlTGNjZEZlcGFDZWJmMmJKZm1jYWRSY1JneWRFYzNkb2ZjYlpia2MxaFJmU2JSZlZkT2JhZVhjUWFZaGNnRWhGYjhlSGcwZVFiZWdKZzFnNGFuZUFkd2NVYmhnSWVCYU5oNmRXZURoa2JiaFFnRGRRZXZiWGVTYnhhQ2FXZlFkZ2NQYVVid2RRZFRkTmJsZTRmWGJGZVVjWWV6Z0NiQ2VwZ0JjWmdoZTVnb2dlZVJma2NZYmNlVmRRZlVoVGNVYkpoOGRkYUdnNWMyZmNkMmg5YkdmWmF4Z1lhU2FUaEhjVmNLZFFnaGdjY1FlWGRpZkllVWFRZG1iZGNJZ1pjbWNrYVVmY2JrZjViemVFYUVieGhOYlVmVWZrY1ZkVGFtYWxkOGZUYkhnQmhjZWRjRmVvZmVoUmMzZGtlN2ZjaDBieGFSZGVhSGNCYVdmZGNBZzlicmRVZmhoUmd4Y1JmaGNOY3doQWJVZTljNWVhYmthTWhaY1RhM2NCZlpjVWhGZG9mNGhlaGtnZGNrZ1FjV2E1Z0tjWmNIYmxlTGhGY0hkRWJkZ0hjVWExZ1FmVmZpaGdieWRkYmhhOWRuYkVmaWU5ZWZmUWFVaEJmMWdIZWhkeGVTYUZhZ2hkYXdkU2dFZDVkdmVjZlhnUmErZUFnbWNWYUNoY2Z4aDFoZmZYZzBjWmRmZkRmVWVkZWxnWGNoZGhjd2ZRYlhkUmRSYVNma2c1ZjFhRWVYYk5oTWNVZFhjaGJ3Y0djSGJwYTdmRWRpYkpkeGJGYVRjbGh5Y0NhaWZFZ3ViSGFSZFVjZ2ViYUdkTWNBZ1pmQ2RzZmliT2VIY3BoSGJaY0VmRmR1Y1NmbWdSZTVnU2d4ZFJkeGFIaFJhMWNOZkdhVmhaZXJoYmJuZzViN2RPYXdjNGV1YlJiV2NrZmVjQ2NFZ29kTmZVZ2xnWWFlYVpkVmNwYkVjYmJ6YVphdmVaaFJiUmU2aEdnamh0ZlpnSGh6YVllRGhTaFJlNWFPYWViQWNrYVlnYmNVaEViZ2JVZlZiUmVRY2FieGNGZHJhUmZWZWhkU2hjY0ZkWmMwYURhMmJ0Z1NhRmVIaEZmR2VFYzNlaGZUZlRoMmhSZHFlVWR3Y01oVGZIYXdkTWZOY0hibGdzYXBoU2QyYVFjVmVZYmtib2IyY2RlVWFzY1ZjWWhSZVFiUmhaYXhjbGVXZGRkR2c1YzJlY2cyYTllR2RaZ3hlWWNTZFRoSGVWY0toUWZsYkpoUGdDYzJlSmJ3ZVFnbWY5ZGljWmVtZmtkVWRjZGtkNWF6ZEViRWZ4Zk5kV2FGZUlhL2FUZW1lbGQwZUdjSGRCZUJkZGNGZUZiS2FUZWlhZ2RZaGZlMmFaZFJhZWZIYUJmV2VkY0FiOWdyY1ViaGhSY3hhVGFsYjFoMmRBZXhlMGhyaFBoaGh4Y05mU2hpYkJkT2ZWaHdjRmFBaE1neGRNYmhiS2NDYkFoZWFkaFdoOGZwZWNhWGFFZkFkSGhRYnRnTWFHaERnY2Q2YVBkemV3Y2hjUmVtaDlkQ2ZIYWtnd2ZuZVJiaGVBZGJnVGJRZnNkcmNjY0VlSmR2YllmbWVaZ3BlRmFIYkpiT2VjYXhkQmdNZVRkUWdNZU1lUWJSY3NhN2NPZmhiaGc0ZGFnM2FSZ1JiU2NrZTVjMWFFY1hlTmVNYlVlWGVoZndkVmduZ1FoUGRZaHdoWWRVYWJmRWFZaFlkTGVGZXBmRGdUZW1icGZUZUdjUmFOaHdmQ2QxZ2xiV2hFZ25icGdIYVplRWRGaHVkUWhqZVpmNWRWZ2hoUmdoZUhiVWhGZk5oU2UxYjljNGFSYUhjWmd6aGJmMGZaYm5oRmJoYkpmTWRkZ1Vob2JRZlVka2hRYkxnT2dWZm9oZWJNZzJkSWJLZ1lhVWhBZzZlQmF5YkFnY2hUaEJjbGVkaFNhVWZkZkNhYWZXYVlhVWFjZUZiSmRtZFJlbGN4Y1pnZWhSaEZlK2FYZjBmTmR2Zlpka2M1ZTliQWQwZkZjU2FGZ0hiRmdHYUVnM2JoYlRiVGQyZFJncWFVZ3hna2dUZWNnRWhWZlhlSWRtZ3NoS2ZJZ2dmQWYraERnemhnY1dnR2ZEY0pocmVBZ21laGV0ZVBjWGdZZmtoQWFFaFJmMmFjZDJhOWZHZlpieGVZaFNlVGJIYVZhS2RFY0ZhSmFFY0NkM2VCZ2FhWGFXZzlmcWRiYWpnMWdjY09ieGEwaEliUWdqZEZnTmJUZ0VhbGhCY1RmbmhkZnFnQmZuY0JlWmNmZFZhMWZLYlJmaWNGZFpiT2ZoYzhmcWFLZG5nQmZkZmRhQmU0Z1doVWdnZWxleGZWYkFnWmF0Y1VhMGVsYmtiUGNsY29lUWRPZFhnQWhMZ1djVmdZZ1NnZWhrYWRna2NRaFdoNWhLZ1pnSGZsZkxkRmFIZEVhSGFIaFNmSWdSZ0FjamZ3Y25mSmRYYzlmdmRFZG1jc2dXYlFmRWZCZjFoU2V3YUZlYmVTZUNkRmJ3ZVdja2FKaHZlWWNtaFpocGdGZEhnSmZPZ2NmeGRCZE1oVGFRaE5kSmRIZGtjNWc3YlhjaGNoZndkUWJYYlJnUmRTY2tiNWcxZkVhWGROY01oVWJYZEZicmhmY0hiUWNQYmFlMWNJY1VnY2dVZFloVGVlYUZnTWhTYmJlV2daZzViR2RSY05ld2NDYTFjbGRXY0VnbmhwZkhiWmFFZWtlZ2JSYkRnUWJyY0JhRWdBZytkU2NVZlFhZGJYYkZjZ2ZqZlBmRGM4aG5oS2FpZThocGFRZmdoRmJlZkdjU2E4YVFjVGYwYVJmTmRKZVJiUWJCYk9neWVzZnBjSmR4Z1JnNmdHYW5hOGFRZkhka2dGYlJoQWZCYnhhT2ZNY2xiNGhZZWNlRWhGZzBhVWNVZXBkT2FkYVJjRmh6YlRmRmNFZHFnTmFRaEllaGFYYlNkVmFTYkhhRmN0YUdjRWUzYWhoVGZUYjJnUmNxYlVoeGFrZVRjY2NBYXRnWmZWZWhkb2N1aFJjM2ZsYkJlWmdSYjVkdGdkZldlRWZVZ2NoUmQwZWRjVGNSaGxmV2ZkYkdlNWcyYWNhMmI5Y0dkWmV4YTViQWVUY0djaGZLZkFjRmVJYVloQ2h5Y0poVGRUZGtlVmdpYVpibWdrYlVmY2RraDVkemNFZEVkeGhOZVVnVWhrYlZlVGNpY0JjMGRSZUNkeGNCZUdkRmNrZWVnQmdqZ3hjQ2ZmZDBod2JGaGRkSGhBZEVnZWhBZjloL2RYaGhlUmZqY1Zhd2ZkZXZoUmMxYWRjM2NmaEVkY2hPY0hhM2NBZUdoU2IwaGNoR2ViYVZkTmI4ZlVhbmZoYmVmZmZIZUJmSGRQZG5nRWdkZEhhVWYwZlpjVmNuZVJldWhkaG5nTmF2YVJkbWRjZVdmWGdFZUliQmJNYTJnQWQzaEloSGVRaFJlS2REZkFiT2ZHYXhna2ZhYlllUWdJZCthSGFHYkliNGJaYTFlRmFKaEZjVWQ1ZHBnZGRCZ2hld2FRZVhiUmNSZ1Nia2c1ZDFlRWRYZU5lVGNVZFhkQmQ0Z0FlamR4YUdkT2NDZ2xnR2hEZkVkWWVPYWVlRWdGY2FjY2RXZHBoVmZHZVVhZGc1ZkJhM2JOZldmRWJuZHBjSGVaZkVjRmd1YlNjbWNSZzVlU2d4YlJmeGNIYlJlMWNOYUdhVmhaZzhmT2dqYzRlNmVQaERmMGMxYkZmaGFsZ01nWmdEaGNnUWdUYjBkUmNmaGNkRWdSZGNlY2NXZUphK2RZY0JjaGdZY1RmbmVNZVFlVGZFaDFjUmFTY1JnVmRPZGFkWGFRYlliY2ZFZkZmMGdVYlVmcGFPZWZmVWhVYTdjQmZRZElhRGFJZGxoWmQvYURlM2VrY3ZnRmFHZHhnR2NSaDNiaGVOYlVkWGhwZHFiUWhnYzhjYWVmY0NiRmVaZVZnaGZKZzZiUmgyY1JnQmdiZGtlcGNraGVjVWRzaFVhY2VSZDBkZGJUZ1JlbGJlYkliQ2NZZS9mSWNCZlFoVWJaYXhoMGRTY1hjd2JoZEtlRGJWZklhUWNDZTJoNWZFZlhoR2M5ZHdkY2htY0FhZGhXZUVhNWh6ZEVmRWd4ZU5jVWVVaGtmVmhUZG1obGQwY0diSGJCZUJmZGFGY0ZhUWhUZGhmc2NaaEpmd2VRZlljS2YzY3hiV2VJZkFoTmdyZEFlQmZoZHhjUmh3ZU5oeGJYYTJnVmZrY2FhbGdNZ1pkRWUzaEFnTGdXYlZkWWFTZ2Vla2ZkZmtjUWVUYXhiS2RiYTNibGFmY1BjbmZFZGRiSGJVZzBjWmJWYm5kUmd1YmRhbmFOY3ZmUmJtYzRnTmRPZUVkeGUxZFNkaGRCZFNnUmFBZnRnd2JXY2tlSWd5ZmFnMmZwZURkRmZIZEpnT2VjZ3hhQmVNaFRnVmdGZEpmRmNVY1libmNlYmthZ2JpYURnaWZBaGVnSGFoZGNnbGZWYkhhMGFiY0FjemJFY2tiRWZ4aDFlQmZQYzBhRWRHaEVheWFNYlRiWmZWZE1kSmFNYVNmUWFRYlRnVmVvYS9jUmdWZWxoZWdSZ25kWmZIZ05la2YxY3VjQWIyYTFkNWZFZ0RlNWV4YkhiUmMxZk5jR2NWYVpnMGNiZm5kWmh6ZmJjMGJZYjFhVWQwaFljWmFKZndnUWhRZ1dibWU0ZUxhY2RGZHBnQ2RiYjJnSmFtZWFmUmZSY3lkVGNuZk1mUWNUZUVnVWJGZFNhUWFoYk9kWWZpZEFhUmJmaEdldGIwY1VnVWRwYU9nZGFSZ0ZnemRUZUZiRmY0ZmNoRmRaZjBhRGQyZk1kQWhGYUdoeGRHZkFoM2VnZlBkVGR6YVpjamZYYnpkTWhUaGNkQWF0ZVplVmdoZkpiNmFSYjJnUmVCYmJla2dwaGtjZWFRZUlkVWVMZlVkRWdkYklkUmhFYUNmUGNDZ2NkbGVmYTJoOGdTZ2FheGhaYUFjUWdIZVZhZWFIZ0ZnSmFXYkdkbWRSYk5oVmhuYWRkeGFjZ0hnMGhEZGZja2E1YytlQWRsaDFnWmFSZGxnMGhOZlhoWGE5YmdhQWRIaGxoTmdYZ2xkRmRLZVRobmJVZ1JnY2IwZHhjUmVlYUhoQmRXZWRmQWg5YnJhUWJoYlJodmJSZ2tlZGY0YlZoVWFsaGtkWWdnZ2NjWmJEY25nQWJmYVNiMGg4Y0djWWQxYUZkemRVYTNmZGRmZlphSGNKYUxiUWhIZkVnV2hIYlZid2dRZVdibGM1Y3VlZGFuZ05mdmVSYW1jY2JXY0Vna2J4YjFhU2VoaEJmU2hSYUVoVmQrY0xhamJzZmZlQmV3ZklhV2hkY1FmQWI4ZkVhbWVraHphUGJpYVFkNWFaYVNmRWJiZkFiRGZKZ3diUWhYYVJjUmJTYmtkNWgxZEVmWGVOZk1kVWRYZWhmd2RWZm5lUWRQZ2RjRmJJYWNkZWdSZUpmYmVNZFFiQWgwaE5iaGJkZFRmQmhCYk1ka2JDZjBiZGVJYkRiSGNwZFZmY2ZFZGhmaWFZZkdhUmQ1Y1NmeGdSZ3hnSGJSZTFmTmNHYlZoWmEwZ2JhbmZaaHphYmUwaFpobmdGaGhlb2JZZVBnUWJOZERkS2NSYlliTGFlZDFncGdUY0VibWFKYzdoYWFVaEJkeWdVYUdlMGJPZFRlRmV4aEhjUWVCYWxoa2dhaFhmUWVZZWNjRWJGYjBoVWFVaHBnT2hkaFJmRmN6YlRiRmFGZTRjY2NGYVpoMGJCaHpoOGNhZlhkU2ZJZjlmUWhYaGhiWWhUZTNkWWRYYVVod2ZRY1RlSmRBZHRjSGhTZUFleGc2YVhhMmIxaE5nUmJFYXBna2dlaFVkc2NVY2NjUmMwYWRnVGNSZWxiV2RkZUdoNWUyYWNjMmc5ZEdlWmR4aDVhR2NCZERod2VaZGFld2FCZEVlQWNIYkJmSmZQZzJiOWUvZFpjbmRzZ0JiWmgwZzVnMWZFZ0JmaGRFZVdkR2RNZlZhVGVtZGxoMGdHYkhnQmZCY2RmRmRGZ0tlVGRuZVVlUmVjZzBheGhSYllibmhBaDRlZmVGZXNmamFHZDBhZGc5Y1Jha2dkZDBnVWJ4YjFib2dhaGxkSWdJYUdnbmN3Y2hhV2FWaFlhU2NlY2thZGZrZFFlV2Y1YktmWmFIZGxoTGRGY0hiRmNQZ0hiVWZZY1pjUWRsZDVjdWFkYW5iTmJ2ZFJjbWdjZ1djRWFrZ3hkMWFTaGhiQmJiZFhneWVGZXdiV2FrZ0pidmNZYW1iWmFwYkZhSGFKZE9nTGZoYWxjQWVaZzFmRmhKZEZmVWE1YXBoZGZCY2hod2FRaFhkUmNaYkJjRWJBYWxjUWh6Y3diWWhIaGlhd2JwZkJnamJFZUJiUGdBY0JkZGNKZ1FiTmYxZU5nQmh3Y09nTWVBZllkMmFHY1FmNWV3Z1RnUWZ3ZFliVWhTZDRmT2FLY3dmOWN1Z1FnamVCYzFoU2MwaFpjOWdIZVZhUmhFZUdkUWcxYmVjYmZuY1pkemdiYjBoWmhuZ0ZoaGNKZU1jZGNVZ29mUWNBaEFoRmNmaEpnUWVnZ01jYmJ5Y2xidWRQY1Zhd2E3ZUhjWGE4Z1FnR2NFaEZjUmVHZXhlbGdPaGFnR2dRZlVhY2NBYmhkOWVTaG1iQmJPaGRiUmRGaHplVGZGZEZnNGJjZEZnWmgwZlVnbWVKY2VmUGFuYUZnR2hFZDNiaGJUZVRnMmRSZ3FnVWN4ZWtjYmZQZGdmVWJKZUJhRmcwYXViQ2NEZkFhWWdQaGdiOWRxZkxkaGRsZmRmSmZWZWhjN2hBZ1ZhWWJYYUlhQWR3Y1RnY2IzZEpnR2VJZ1VhTmVjYkRoeWZFaERmWGR4ZXhnRWdBZ3lhUmJXYlFmamYxY3VmWmZpZUFiZGZjYmhlVmFaY0VhRWh4YU5iVWhVYmthVmFUaG1hbGIwaEdiSGRCaEJkSmNoZlFmZWNHaHljZGZmY2Nod2FkYlpkTGhEaGdkZmVKaHdoTmdyaEJnaGVoZnhhRmJCZjlmNGFVYmxnNWdvY2FjaGVvYVFkQ2ZGZW9mTGRXYlZlWWhTZ2Vja2VkZmtmUWFXYzVoS2hPZVhjQmZIZFBmbmVFZmRhSGVVZTBnWmNWZG5nUmV1ZmRibmhOZ25iQ2hHaGxnR2VRZkFoTWdoY0JkVWhRY0xiRmFFYzVhK2NEZFJlQWZtYk5haWJNZE5hV2Z5Y2NiTWRQZzFnVWdnZEtkRmRGZlVlRmRRY2dkOGVPYWxnc2ZrYkNjRGJzZmZnU2VrZ1lnaGNIaFhmTWVlYVhiWGFnYzVkWGczYlJhVWJRZFZnSWhVYWNkVWNZaFRhZWRGY05nUGRaYUdmcGdUYkdnVWJFZjFoWGh3aHdmRWVYaEhkb2JOYWJoQmhVYW1oQWJ6ZmRmMWhTYTBmQmI5Y0hjVWg5ZEJnR2JWZWRia2RZaG5oWWE2ZFpibGcxZU5jRmJoZkphTWhkZFVib2FRZlVha2VRZ0xmY2VBZWRoTGdZZjBlaGhtYWFiUmZSZ3lkVGNuZE1oUWNUZUVhMWZSZFFnVmV0YkFmT2ZTZFpnWGVKZ0FmNGVnaENkQmFvZUxlZWcwZ1lnaGhCZFFoVWI5Y0ZkQmNrYmhlVGZTZmNmWGRkY2hlUmZHZERhbmNnZlZhR2RpZ29ncGVCYzFnQmZjZlBkZ2N0aFJkQWdoZDViNmFGYVdnaGFCZEpkMGROZGtiSWNtZ0VhVWNjYVJhMGFkZ1RoUmZsY1diZGRHZjVoMmRjZDJmOGZVZUlja2dKZkhoSGFqZ3RnS2FXZGxmb2FRYlFmemdrZEpnVGRtZDhhMmJhY21lbGNHaGZha2g1aHlkQWhVaEJoTmNHYUVjQWZPZFpoR2dsYzBiR2NIaEJiQmNkYkZnRmFLYlRnbmFWZE1mZWFraEJjN2RlaEhnQmFXZmRhQWM5Z3JjVWhoZVJheGhSZ2hjc2MyZVhnUmQ4aDJlSmZRZ2RmV2JSYnljbGZiZEhkRmhoY1JnTmJSZGNoOWhRY1hnTmhLYklmaWR3ZEZkVmF5aFZmVWRVYWdmTWhaaFhnaWZCZmlhZGJpYUZjamRSYmliNGZhYUVoZ2VsYjhmU2hrZnRoNGVSZUFldGF3YVdka2RKZHZkWWNtYlphcGFGZEhlSmNPZ09hbGVaZ01kUmhYYnRoSmFGYVVjNWJwZWRiQmdoY3dmUWNYYlJjUmZTZWtnNWMxaEVoWGNzYUZjVWRTZlFjc2JWZm5jeGZHYmFjMGE4YlViWWJVZThjZmZVZGxjTmFQYlpnR2VwY1RkR2NSYU5od2JDZTFjbGdXZ0VhbmVwYUhlSWNVY0VleWFGaG1hUmNwZVNid2FsaHNlQWVCZjBoSWZHY1Fnb2VvZWJjbmU0YjJhYmYxaHRhbmVRZGxhb2FGYkpna2hSYWNmRmZ3ZXBjTWNKZkJlSmhMYllnMGhoYW1iYWJSZlJoeWZUY25mTWRRZFRjRWIxZlJmU2dSYVZhT2FhZFNoWWVZZWJhbGZ4aDBnQmhVYlFiQ2ZNZEZmOGYwZkdjQmVsZzRjZGVsZEJkMGhCZHpobGZTY0NnWGRFYVNjSGRUaFFjV2RBZ1NlTWErYkdkeGhBYWZlV2ZnZ3RnWmNWY2hkSmI2ZlJmMmNSZEJnYmhraHBma2FlZVVhc2JVYUlieGIxZEJkRWdSZGxnZWVKYm1hNWNyYWNoM2Y5ZlBmYWR6Y3doU2VUY0hkVmNLZkVjRmZKaEViQ2EzaEJkYWdRZm1jOWNpaFplaWZ3Y1VkYmRFaDVoamdFZkVicGJMZ1VjUWJBaFZjVWNHZ2toeGRHYUhkWmdIYmRiRmhrZFBnVGhtaGdjUmJPYmtmVmJkZlVjbmVCYldkZGdBaDlocmRVZGhkUmN4YlJnaGVOaDRkVWcwYjlja2hMYzFkTWJFZURkbWMwYkxhRWFGZzhhNGJlYWtiZGFrZFFkV2I1ZEthWmhIaGxlTGdGYkhjRWhkZkZlR2djYVpjVmJuY1JodWJkZG5jTmZ2ZVJnbWRjZ1dnRWhrZHhlMWZTZWtlSWVYY0VnRmc0Y2ljRmdFYUpiL2NlZ1VleGhwY0ZoSGNKaE9jY2J4ZkJhTWZUYlZkRmRKY0ZoVWQ0Y2dkTWVoaGhnNGhVYVhnUmFNZlZoMWVOZDFjUmJYYTBjQWJGYURmWWEzZUFoamh3aFBlTmR3ZTRmVWZZYVVoWWVPZlpoVWI1ZFBoTWhDY0lnYWdTY2hhMGU4ZFRiaGJjZFJlUmhqYUpkT2haZUJjTWJyaEhkamhFZnJjQmFSZlJlaGRCYWplZGdOZ0dlVmhaYzBhYmRuZlpmemFiYTBnWmduZ0ZmaGdJYkZlTWEwaG9jWWFRYmtkUWdWZ2NnQWRoZkxjYmd6YllidWZPZTFmc2NsZlRiamIxZVZoR2MwYzBhamFDY0Zmc2RKYUxoQmNGYUtiSWVnYjRobWRXYVVhZ2JhZU5mRWZNZDBkQ2JRZlVhTGdKaEJiY2FtZ1djMmhzYWRmUWNTYVZmR2dYY0RmNWhUY0RnU2JzZS9lSGNWYTFnQWVjYmdnSmRDY2ZhQmFKaDZlUmgyZ1JlQmdiZ2tocGZrZmVhVWFzZ1VmY2VWYVJjYmRUYlJhRmhHYmRmSGZCaDJhT2ZtZDhnYWhPYnhjWmViaFRnR2Z0ZVhkRWJBZ1liTWVRZWloTmNVYkRnaWhvZHNnSWVUYzFjY2RlYTJjUmN6Z0VkRWF4Y05kVWRVY2toVmZUY21kbGgwYUdkSGVCZEJnZGZBaFVhQ2dIZ0RjcGdHZ2Nmd2FJZ1VnTGEzaEFka2JOZFViRWZzaEZhM2JFYWpmRmJGZXdhcWJXYzBhMGMzZEphUWJaZkxhVWNEYlZnNGZEZFJhZGdBZExka2djZHJoRmJEZ3BnS2JLZXpnOWNMYVZjamU1ZklnVWJ3YmxhS2JWYUhhMWUxZlhoSGROZ3ZhUmdtYmNnV2hFZWtneGQxZFNiaGJCaFNoUmFFZ0lkMmFXZGtncGIvYlllbmNoY3BlVWNYYnRkT2dKZDFoZ2RlZEFjZ2RaaEpkV2V3ZHNmK2hkaEdmb2d4ZERjemZNY1VoTGV4ZHdibmRYYmloRmRFYVVleWdzZS9kQWN5ZVpmTWFMZGpmZGZhZE5mVWhaYWNhTGZRZGRoUGFLY3ljeGRUYVdoMWZ3Y2xlUmhSYTBhRmhFZEhoTmVjZ1Rja2JGYXVmU2RtYlJnNWdTZXhhUmF4ZkhkUmExZ05iR2ZSZE5kMGZjZkhhWWhuY0pmd2c4ZzBmR2JGZDRjSmVPZndhMWZFZ0dia2NRZU5kZGVsZ3BiS2JLY21mSmQ3ZmFlVWJBZTZoQmR5Y0FjZWFBZEFkZ2dmZERoa2JFZEdoWWVIZ2djeWdjaEVmRmgwZVVjVWdwYk9nZGhSZEZlemFUZEZhRmI0Y2NjRmJZaGdiQWZTZGNlWGVXY2poWWJTY1dhM2VoaGVmVGV6ZFpmcWRUY3hnbGhXZWNmQWFaYVplSGh4Z0pmOGdRZ1dkUmNKY0tnMGhwYzVlZWVSYjhmYWdQYVZiaGJUZENka2QwYmVoZGRHYU5hMmRJZVdnOWVOaFpjMWU4ZmJnVmgxaDlmS2NFZUZoSmZFYkNmM2FCaGFjUWJtZTlkaWVaYm1hbGVDY01keGV4YnpkWGcwaEJhbmJVY1Vja2VWZ1RhbWNsYzBlR2hIY0JkQmZkZ0ZkRmhLaFRobmhWYVpiY2QxaEZoUmRQZ1hmQmhiYWRkRWFaYXdiZWRCY1JleGZSY2hmTmI0ZVViMGQ5YmtkYWhsaE1oWmdFZHpibGZOYldhVmU1YkdnTWdnZDRiM2NRYlhjTmdYYmVoWGFrZWZnRmhIZmNoYmRIaFJlOGNaaFNhSGZRaG5nZGNuZ1ZncGNSaGllSWZXYURnRWh3Zm5hUWV6Z3BiU2hSYkFidGJ3ZFdoa2RKZHZoWWFtaFplcGNGZEhkSmJPYWNoMWdZY0RhSGIxZUZnQmJXY2tmNWQwYWRnRmhCY3dlVGFIZlJlQWJVZ1VkNGQ2Y0VlV2IxZlJmVWdXZ2hicmNWaG5ka2hDZUpkRmFzZlVhSmZUZDFjY2NlZEZiaGdQaE5oaGNkZ1RiQmRCY01na2dRZXhlQWRGZGFkVGZWZEhkYmMwYUVibmROZDNkOWFUYVNoeGdSY3hmSGJSZzFoTmdHZ1ZlWmcwaGJhbmhaZHpoS2JnY29mMGNVY3hjSWVGaE1lMGNvZ1lnUWh3Y0VoWWNjZkVoUmhDZ0plMmJJZzZkTmhSZVJjemdBaEhiMWVraE5hVGcwZDBnTGVXYW9mdmFHY3dhWmM1YUNkVGc0aEhiSmVEZW9iK2hHZG1iTWFIZlJlWGZ0ZDRmY2NGaFphMGhEZjJmdGhTYkZnSGNGYkdiRWUzYWhnVGRUYnloSWdsYkFkUmNrYmJmUGV3YnRnRWFWYWdoSmhoY1JneWN4YkJlY2VFaG9jcmRZY2thc2hmZGVkbGVJZ1VlVGJVaDBjdGFPYzJoNWY5aGNlemcwYjdoWmV3YnNmU2hHY0RjMGFEZlFleWVrYkxlQ2YzY3RoYWNDZHhoSmg1ZVRkR2hrZ1VhY2ZrYTVoemZFZkVjeGROY1VoVWdrY1ZlVGZpYndmNGVTZHphVmNCY0FiUmZnaEVjR2htZDFhd2hJYVJjNGVRZklnWGg0ZEdhSmJrZ0FjL2ZIYlVoQWZvaEZkbGhaYzJhQWFBZ29id2NaZkJmQmFZY1hnemF3ZkRkRGNWZG9hU2RMY2dkOGF0Y0VkbWVBZFpnTWJUZnNhS2JSZGliTmdjY1JiRWZWZlFnV2VuYlFlbmhkZW5laGN2Y0RmbWQ0ZmFkRWZoZDViOGhVaFRicGZTYVJhQWd0Z3dhV2drYUpodmZZYm1oWmJwZEZnSGJJYWNkTmVrYVFoWmZIYXhnOWdKYVhlVmZWaERmZGhCY2hjd2ZRZlhlUmZSZ1Noa2E1ZTFmRWNTYTVoRmRYZ1ZkSmJ3Y1ZibmNRZVBiYWMxYklnVWJjYlVhWWVUYmNiQmcxY0JiTmJEZ2dnY2FUaFZkd2JraFVnZ2VraFRmSGNEZHdoT2hLZEFkMWJ1Z1ZiMmdRZC9jSGdsYm9heWhTZlZmUWZDYlZmMWdaYzhhT2JuZ3BmemZQZ1VmcGJuaFhjeGM1ZE1jTWJFYk1oUWVDZldkNGJMYmNnRmZwZENlYmYyZ0pibWhhZVJlUmh5Z1RmbmVOZlpkQ2VrZDFjWmRTYjBiWWVhYU9hemExZVdnTmUwZE5hMGRUZUZiZGJPY0lnVWdnZWpmQ2FSYTRjK2JjY0FiSmQ5ZkRhemRCaDRnRmVIZEZiR2RFZDNoaGhUaFRmMmdSZ3FmVWh4Y2tiVGNjYkFic2ZRZ0VjQmVKYnljYmdXaFJjQmNiaGthcGJrZGVlVWZzZVVjY2FSZzBnZGZUZ1JhbGhXYmRoR2Q1ZCtiY2ZUYndhU2ZOYVZnOWJjZENhM2JkaEtmRGNVaDlnRWhYYnlja2dLZEJieWFBZGtkWmdqZXNkK2NjY2thNWV6YUVjRWR4Zk5mVWhVaGtkVmVUZW1ibGEwYUdnSGhCaEJnZGZGZkZhS2ZVZVhoVWJaZWVld2NsZFJmWmVYZkFjRWdmYlFlTmJyY1dma2RaYXhnV2F4Yk5lb2VXZGtoTmhrYVlmaGVvZVpiRGFuY0JnZmVFaFJjOWVCaGRlQWhzYWhjRGZ5Z2tnZWNMZUhkQmJDZFBibmZFYmRlSGFVYTBkWmdWY25nUmF1ZGRkbmhOYXZkUmZtZ2NkV2FFZWtneGExY1NkZ2NwY1NlUmFsZmdma2hDZ0Fkc2FoZkpkV2NSY3BjQ2FXYTlkT2NKZzBia2djYUNkQmE0YVBiRmJRZWRlcGRjZWhjNWV3Y1NnWGN3Z1VmU2JsZk5iMWZXaEhkcGJBYlVkWGFBYzVoVmdtY2tiUGRQY3hmcGdkYUlja2RoZmZjUGhSZzBmSWhNYkNhSmdhaEVoQmI5ZWFhQ2QxZmxkV2ZFYm5ocGhIZVplRWVGZ3VkU2VtZ1JiNWhTZ3hjUmN4ZEhkUWd4Z05oQmRFYXRhcGdiZ2lhSmQ5ZUlmd2dNZnBjVWZVZlliRWRmZ0dhQWJRZVVna2JRYUxlY2RGZ3BmQ2FiYTJkSmNtY2FkUmFSZnllVGZuZW9nUWhGZzJkZGFSYVNhUmJWYk9hYWdYZlFmWWRjZEVlRmEwZVViVWNwaE9nZGhSZEZkemJHZmhiQWRxaGNnQmNsZDBmRWJtZ3NnR2dHZGpmSWdPZFVlaWdvZndhQWRDYkFidmVNY2thMGNiZFliQWJKZUNhZmRCZ0pjNmFSZDJiUmNCYWJna2NwZmtmZWRVZnNnVWZjY1JkMGJkZVRiUmNsYUVkWWhYZmhlMmJiZFdhOGNKaFpmeGJBZVVjVGZIYTBiZWRFZUVoOWNFZ1JiSGVsZEJlYWZHZjloaWdaZW1ha2RVYWNha2c1ZHpkRWNFYXhjTmdVZ1Via2NWaEVkMGVOZjBnR2ZIYUJkQmJkYkZmRmhLZFRmbmZVZlJnY2MwZnhlUmVlZkRna2VRYmRhQWhjZTlhSGZWYTBnMWJSYWdoTmM0ZVVibGJKaDVkYWVoZlllWmFGYlhhWWFMaFdkd2RWYUdoS2dBZDRicWZCZ21neGRLYlplV2FSZ0xjUWhDaGhjTmhXYkFjSmFmZVZjamhGZm5hWGFIZU5kdmRSYW1jY2hXY0Vja2d4YTFoU2ZoY0JlU2RSaEFhdGd3aFdka2FJZjdnS2dqYlFkbWFRYTNlSWhBZE5ja2dkZU1nT2NRZWdkWmJVYkNic2g3ZkphbGJjZ2lhU2NYY1lkVWdCYUFnMGQ2ZlZoVGdvYUNkRmhuYWdnOWhBY3lkZGFiZGFleGNCZFJkY2ZRZWNlVGRLYndlY2NkaExmU2hRZlVmR2d4Z3BlcmhJZVZibGRXYkVkbmVwYUhkWmVFZ0ZidWFTZG1nUmU1ZVNieGhSZ3hhVmFGY3RkTmNFZ1ZjUWhuZU9kaWNRYjZnSWFRZkZhbGhGZ2diOWFSYmRjUmI1Z0phQWRnYUZhRWJOYmxlb2RIYmJlMmZSYWdlYWJSYVVmOGdRaERhcGdEZktjUWVNZlNjQmJsY0VnSGdKY3pmTWdRaE5hVWdoZzljZWUwYXBoT2NkZ1JoRmd6YlRlRmZGaDRkY2dGYVplMGVEZDJidGJTZEZkSGdFZ1NmV2d5YW9kY2dHaEdkUWNrZ0Zla2g0YlRjQmVGZUljSmVFZDNkY2ZvYkZhU2VzaFRjWmZrZ2dlUmJOYndnQmZhZFBka2FwZFRhVGVWZHdhWWdOZnljRWV5Z09iaWhFYUJmZmNSZFloUWZUZEhmNWRLZFZmVmh0aGZnSWVYYkJmYWJRaG1kOWhpaFpnbWNrZlVjY2hrYTViemdFZkJjRmZOZ0ZoQWVWYkdlQ2IyZGxhMmdWZGloVWFNYk5naGJRZFloVGdIYVVmTWRiYWtnd2ZGYUljU2FBZFRnT2UwZ2xocmRCZmhiUmgzZFFoQmNOaHdlQmUwZzlhNWhhZmthRWhNZkJobmJBYk5oV2FRYUliYmVZZFdhMWZrYlFhV2Q1Z0tnWmFIZ2xnTGVGYUhoRWRkYUhmVWcxY1FlRWVIZFJobWJaYW5hTmN4YVJhamRVZldjVGZoaEJkMWVIYWxjZ2NiYUZhd2dVZThoSGV3Y3dib2VOZGliNWFwY0NoSGRJYWNoY2MwZndnUWdUZlFhVWVCZVhnQmQxZm5lT2VGYTBmK2ZCYWliQWJaY1NhbGdKaDFlV2hIY3BibWZVYlhkaGd3Z1ZnbmVRaFBnYWExYkliVWFjZFVhWWhUZWVlRmFNZGJoTGdEY2dhY2JUY2hoTWQraFRlZ2I1Y1dmWWJEZHNmSmZJZ3doUWZMZkdoRGhZaDJiR2hSZnhnemJjZ2tjZ2ZaYUdiUmhrZ3lmYmhpaFFleWhJaFFmRWhpaEZobGNzZUNmTWhRZjloSWZVZ0VjMGFRZFdlbGZwY0NiYmEyaEpnbWZhYVJmUmZ5aFRobmdNZlFoVGVBZlFkWGVTZ1JiMGJjYmFiV2ZvaEZkY2FBY2hjOWZVZVJnZ2RMZUlnVWJRYWhmQWVsZ0Vic2ZPaEJmOGFuZEZlRWdGZ1NiRmVIZ0ZjR2dFaDNoaGFUYlRiMmVSYXFhVWF4ZGtkYmhJZGdndGVIaFNkQWd4ZW5jUmYzYlJjSWZZaG1nQmhrZGVnVWdzYVVlY2hSZzBmZGNUaFJhbGFXYWRhR2g1ZDJoY2gyZWNiUGNaaHdmc2RTZEdnamFvY0RlVmhGaEpmVWFDYjJnMWVIZVhlMmY4Y3JnWmRuYVlnVWJKaGdnWWQ2Z1FoMGVJZEJmRmhBaGRkU2RHYmloRmIwaEFjbmhBYkloZGFFYzljVWdVZUhiVWJCZ2Vka2hCYTdoZWFIaEJoV2RkaEFjOWdyZFVlaGNSZ3hoUmNoYU5nNGZVZDBhOGV3Y2FmZ2Q5Z0ZiRWczY2hhZmFXaFVlc2hTZmFla2Y1Yi9oYWYyZTViS2NaZkhlbGZMZEZlSGhFYWRmSGRVYzBhWmNWYWlhSWZ2YUpiSGRNYW5kWGhVYTBjV2dFZmtoeGIxY1NlaGdCYlNhUmNBZ3Rod2JXZ2tkSWdtZkpjR2NaYWhiRmZqYndiYmNQaGxnSWNKZ0hmMWJOYkpnQ2JGYk5lcGJJZUViRWVnZEJlRGNzYVhmU2RoY3BlOGNFY1RkVWFEY0FjM2doZTRoSGJuY1FkU2ZhZndkQWNQYmNnUWc4YlRiWmdsZU1iSGJmYzJjcGFZZUVmbGV0ZzVjQ2N3YTBnZWNXaHlja2Y4ZExjRGJ4ZHVhVmMyY1FidGdVY0RkNWF4YUhmUmcxZU5kR2FWY1pkMGJiY25lWmF6ZmJoMGVZYmllV2VrY0ViSmRkYlJhRWM2aFVma2dRaExhY2hGaHBhQ2RiaDJhSmJtYmFmUmVSZ3lnVGZuZ05iR2hEYVJkOWhSZ0dlaGRWZlRmYWhUYm9kV2NPZVJoSWZXZ0JiQWZ3ZElkTWdFYk5iN2ZHY0ZhaGc0ZGJnMWJZZGdoRGYzY0ZoU2RmY0hna2JJZFZoaWM5YlRoQWhXaHdiK2RYZXhibGFXZmVlUWVVZ05iR2hXYkVjdWJGaFNoMGNQZ0tmVWdKY3RjY2JFZmNjK2hjY1JjMGRkZlRmUmJsZ1diZGZHaDVjMmhjZTJjOWFHZFpleGdZYVNiVGdEY1JnS2hEYVZmSWRYYUJkVGN3Z2ZmRGhDYmdoMmJMY25kSWYraGNma2U1ZHpoRWZFZHhjTmNVZlVha2JWZlRkbWZsZDBnR2ZIYUFiSGVPYndjTmFLZVJmamEwZlJoYmRrYnhjQmNZZjNkQWJmZ2RnQWdKZnJoQWdCZlJidmRSZGxndGVqYVVmMGdSZXZjSWVsZG9oWmRSaHpmaGVDZUNnaWMxZGFhZWZrZnhia2dFZXhhTmJLY2ViWGhrZ1liYmZ6ZGtmZGZHYkVkMWVZZUtoMmQ5Z0VhZGVuZU5mdmhSZ21nY2ZXYkVja2V4aDFiU2RoZEJmU2FHZVNlRmR3Y1dka2JKYnZjWWZtaFplcGZGaEhiSmZPY2NneGRBaGVmQ2dBZVVjY2hSYXdoQmZwY0loRmZBZzVnRWFtZTlkN2JTZmtkNWQxZUViWGJOY01oVWVYZ2hld2dWZmlka2NHZmNjSGRnZlVkY2ZVYlljVGJlYkZmTmJQYlplRGJ3YVNiU2V4Z01naWFYZzFlbGNMZUVibmZVYjhhR2drY29jU2RSaFhoUmYwY1VhbmNWYThhWmIxZHhjQWFRaDFnc2hMaEVhM2NrZjBoZGJHYnhibmFGYWhnSmVNZ2RnVWZwY05nWGNBYmRmS2dQYkJhWmdLZVBiV2E1Ym1kSWVCZHhobWRSYTNmb2daYlZjMmNkZFJmU2ZSZ1ZmT2ROYkhnZ2R5YmNjRWZGZTBiVWRRZ3doYmRPaDFmSWduZ0JjUmY0ZzJhY2NGYTRmZ2FBYTJmc2hBZ0dnSGFFY1BiR2ZuYmdmSWZaZ1diUmNxYlVjeGNrY1RhY2RBY01oTGNXZkdkY2dUY0thUmRCYlNnZmhFZnBjNWZlZFFoSWZjZWFoUmRRZVViUWVSaGxlZWZKYW1iQWhEYUdkZ2NFZnlkY2RRZEloU2NVZVhkVWREaEdkRWJ0ZU5kQWRtZnRkd2hRZW1iOWNpYVpkamNRZFllV2hFZTVhemFFYUVid2hMYkJjQWJkZ1dmR2ZpZkFlN2RWYm5mQmhKZElnRmgxZEtkSGNIYmtiUmZPZ2tlVmVSaEliMWdwY1dhZGRBYjlhcmVVZ2hlUWhsZFNiRmVZZGdlQWN3YUFhMmFQaGdiQWVaZ0RjbmJCY1FnV2ZSaDRoQmNhYUZjMWdrZkNoR2daZ1plYmJYY1ZkTGhYY0djY2FKZ0JiMGIxYlFjWGRtY1ZlK2RmZTNnTWV5ZlhkVWIwZldoRWhrZ3hlMWdGYXhjeGQ0Z1JhQWd0ZXdoV2dnYlFhNmNMYkNmVWI5ZVhjVGUwYUFmY2h4aGdlWWRRZlZiRWFiZ0dkVWg0Z2djZmdSaGdmcmhhZTNkUmVSaFNha2c1ZzFnRWhYZ3NiS2NCZkRlWWR6YUFjamcxYUFhSmFWY0lhY2NJYjBhOGNUYUlnM2JsZ1BnWmZHZHBoVGNHZ1JmTmV3YUNjeGY4Y0RoWGJEYmtiVGJMZ1FnNGRnZVNjaWZGaHhjSGZ4YjFjeGhSaGpmZGJOZEdkVmRaZjBmYmNuY1pjemhiaDBmWmJuZ1VhRmUwaGVoZGdVY0pmR2hFYXhjWWdMaElhbGZwYWZiYmF4YmtlYmFaZVJkUWM3ZlRobWI0YVFoWGZFYkZnUmdEZUJmVmFUZWFiU2hBYVdhUGRBZ1FkNmdGZ2hhNGJHY2JiaGdFYzJmVGNFZDljNGhPZVViMWYwaFJkbWJCZ1plSGhYY0VhZGNPZ1hoaGRUY1RjMmVSYnFnVWR4Y2tnVGJjZUFmdGJaY1Zna2NRYjdlRmZXYVFnT2NiYmxhZGhrZExjVWVWZFhlT2RWYnhiUGRMZ2xiWWNTYk1kUWM4ZGlhZWV5Z1pnUGVmZkRmd2hTZVRkSGVWZUtiRWVGYkpiRWJDZDNmQmZhYVFlbWQ5YXpnZGNIaEVoVWNiZEViNGY4Yk9ja2F4aE5kVWdVZmtoVmNUY21kbGIwZUdjSGRCYUJlZGFGYUZlS2dVZlhkVmJEaGZiUmh3YUVhS2Z6Z2hhZWVPZ3dhWmhCY1VlaGRSZ3hiUmJoaE5hNGFVZjBkOWJrYWFlbGRNYlpnRWgzY0FiUmhXaFViUWZDZWJnbGI5ZmthWGUyZTRiRmdUZG5hbGVMaEZhSGVFZWRmSGFVZzBlWmFWaG5oUmR1ZWRmbmNOZ3ZoV2JXZWRmRWNIZkJnd2RnaEdkVmNoYmFnVmJSaEpnaWJXZmhhNWR2ZmFnaWZsYXBlQ2FtZ3hhT2daYlJhbGFBZVRjVWFCaGJkRGdVaDRhMWRkaEJjQmNtaFVhbmdSYlhnU2FnZ0ZhOGNHZUZlbGdNY1VjWGdoYndkVmVuY1FjUGVhYjFkSWVVZWNoVWZZZVRnZWZFYWxjUGhjZlhhOWNCaEFjQWNWYndmRmNWZmtkWmdFaGloWWdiY1poQWY1ZXVkVmZIZWxoNWJYZGdoTmJpYkNjUWNsY25mR2FWY1piMGhiZW5iWmF6aGJlMGVaZm5hRmVoYUpmTWJkY1Vnb2hQZFViaGhZZkZnSWNBZzhoUmNKYzJkcGUwZ2Vkd2JCZXliRWduZk1kWWJBZDBlMWNQYVZleGhWYWZlZWUzYTBoVWJjYkZmQmVtYlNlVWZvYVNnZGhSYmxiN2VBZzFoRmdtZWJibGVaZWlnQmVtaHRhVWNGZkdkZGZWZEdjbmVSYVRnWGJuZFpneWRVZjBkVWFUY2VjQmUxY0toVmVoYVJoNmFDY0doMWJJY1JjRWVwYmtjZWdVY3NjVWNjYlJhMGhkZVRiUmJsY1doZGhHYzVjMmZhZldnOWNPZUxkaGYwZVpoUWVGZzllS2FFY0ZnSmNFZ0NjM2ZCZGFjUWVtZjlnaWRaY21ja2NVY2Nka2Q1ZXpkR2dBZk5hTmRUZUVka2REZldhM2F4ZW5iRGRuYUJjS2FkZkZibGVDZlJnbWdRZUJjWWZWZjlhUmhmYW5oQWNaY2ZjUWE5aDNnVGNoZVJiZ2ZWY2hocGQ0aERhMGM5Y3NlZWcwZk1oTGJBYUhlQWJOY1dnUWJJZGNiT2FRYjhkbGhFZHdoMGhGaElkRGF3Z3FlUWZIZmxoVWNGY0VnUWFRZVhiM2hoYUVmZGJuaE5mdmVSYW1jY2RXY0Vka2V4YjFmU2FoYUJnU2RSY0FmdGZ3ZVdhaGZCaGhlTWVqYU1nNmVYZ0hlcGJraGNneGJCYk1lVGNWYkZmSmFGZFVjNWNwZmRlQmhoY3dmUWRYaFJjUmZTZGtnNWQxYkFkMmVkZGNlVWJTZVJmd2FYZWpic2ZQY2RjVWV3aFVlWWZGYjRnYWZkZ0hmbGJQY1pnR2hwYVRlR2NSY05od2ZDYTFhbGZXaEVmbmdwZ0hlWmNFYUZidWhTYm1mUmJvaFdkUWN4ZnhjUWZSZjFiRmNFZFJjbGMwZGNoR2JoaHpoZmRsY1JldWNGY2hnUmZNZ1loMWRrYVpkWGFtZTRjTGFjY0ZmcGNDaGJmMmNKaG1hYWdSYlJoeWhUYW5hTWFRZFRkRWIxZlJkU2VSYlZjZmNlYjJjd2JZYUxiRWdGYThoV2NRZ1ZoT2hhYndlOWd6aFdnbGJoZDRiZGdsZVpmaWdIYkdjSmhlZlBhbmdGY0diRWYzZGhnVGhUZDJiUmRxYlVieGJrZFRoY2dBZnRjWmRWZmhnSmc2YVJjM2VWZFRiZGhrZG9mNGVlaFVoTWNDZ1lmaGMwY2JhVGFWZFpkZmdYZW1jNWEyY2NjMmY5YUdhWmF4aFllU2RUZEhkVmFLYUViRmZKYkVmQ2EzY0JjVGdTaDNkUmdJY1pkbWVrY1VjY2VrYTVlemFFYkVmeGhOaFVmUmJRZy9mVGVtZ2xoMGRHZkhlQmFCZGRkRmZGZ0tlVGVpaGRlVWVKZHhoa2VEY05nbmRBY1llTWFWZWhncmNKYTFmMGIvYkVlZ2hzY1phQWRSZzBnbGZNZDFjdGNMZUdmbWNzZGhiV2hWaFlnU2dlY2tkZGFrYlFmV2g0ZFhhVGhuZGxiTGZGYkhmRWNkZkhhVWgwY1plRWdDaEVjZ2ROZVNlY2NtZUNoU2NrZ1dkWGRVYlJhOGdTYmtkdGI0aFJiQWd0ZXdiV2draEpmdmZZYm1lWmRwZUZoQ2RBZExlSmUwZVVlZWZBZzFkRmFiZUZnVmNOZzBkZGZGaGthaWVCYWllRWZjYkRjd2ZBYmhoUWduYzBiQWNGZURmWWgzYkFlamZ3aGxhYWMxZklhVWNjY1ViWWNUZGVmRmNOaFBlWmFHYXBhVGNCY2hoTWMrZlRkZ2g1ZldoWGFYaElhR2hOZmdhWWg3aEJjeWJFYzNiSGcwY2NnS2hEY0dhQmVFYUZmd2FNYmtnS2RqaGNlbmVLYWtjNGFtYVJhRmdVZlplT2dBYTljZWNCYmhkZGd3ZVloQ2FkYUxoWWdTZVlodmZMY2xlRWhoZEdobmdzYVpiWmdrYjFjUmNTYlJhVmVPZWFjWGNRYVlkY2hFYkZoMGVVZFZiQmdPZkljVmFraDZlSGExYUVmeGNQYmdjVWRnY1RiaWhVZVJhVWZUZDRkQWRFZ3plZGc1Y1RnMmZSYnFkVWN4aGtnVGNjYUFmdGdaYlZoaGVKZTZkV2JHZVFlWGFJYlFhTWVnYWVnUWZNZ2FkTWNsZHhmUmNBZVJoRWZDaFBlQ2JjYmxnZmQyZThoSGdOYlZjRmJIaEFiVGJBY0VoUmdBY0VkL2NHZndoMWVUZmFkR2Y5Y2lkWmRtZWtjVWFjYWtoNWV6ZEVoRWR4ZU5kVWFWZE1nVmRBZkNkd2dqZUdoRGg5YUplTmVRZU1iTmVHY3poaGZVZlBoUmVnY0NkQWcyYkFocmVmZVJoUmJCYVVkaGNSZ3hjUmZoaE5lNGNVYzBkOGE1ZlFlRmRNZlphRWczZUFhTGFXZlZnWWFTY1BlQmdJZ3FjQWJqZG9hRGhLaHpmZGdMZlhhSGJsZUpiRmRFYTFoQ2dmZkhjUmF1Y2RhbmJOZHZlUmNtZGNjV2dFZmtmd2FuZ0RjMGZRYUhoRmRrYVZid2hVZm1naGh2aFlobWhaYXBjRmFIYUphT2JjZXhkQmNNZ1RlVmNGZUJhUWFRYlljZ2dKZnhkWWdqZkJkRGRFZlZoU2RsYU5kMWFSaFhoTWJGYkhmeWFzY2tnRmN6YnBlTWRMYWhlMWVTZGNoUWNnZlRoWmUxaE1lYmRhYmlha2RmYVZjbGcwZDFnQWcxZkJlV2NDYUhmb2hKZ2JmQmhWZW5nUWIyY2hjVGVTYXhiUmh4ZkhhUmExY05nR2RWZ1phMGdiYm5mWmV6Z1pleGRJYXZhWGMwZUZlQ2dJYTFkc2RRZlRmMGNSZGZkT2dCZ01mUmVZZ1RlRWRqYkxmRmFCYThlRGdUZjllZmZBaGdhaGdaY1FkQmVzZFBkTGNUaEFmUWRJYjBiaGE2aEVjQWE0ZEtiZmVWZUJkNmRSY1ZiMWdTZ2NnRmRaYzBoRGUyYnRoU2dGZEhmRmFHYUVmM2doZVRlUmV6Y0FmaWJHYmtnb2dkZUphaGVsZlpkU2h4YklmdWREYXliMGVTZFloQmNrZWhhUGJBYThmYWNNZmxhRmNTZkFjMWh4ZWVmZmFXZ0FiM2ROY3lodGhPaEphaGc4YmJnUWhGYjljS2hFZEZmSmJFZkNhM2RCY2FiUWNtaDlhaWhaZW1na2djYUphZ2JZZjZoUWYwY0ljYmdRZmtoa2NJZVRhamEwZzhhVWJTYU5lUGFKY3hlUWNQZ0NobmJ0YVNjUGF3ZE1oZmJQZlhiaGRmZmZiUWdOZ0JiVWJoY1JjeGdSYmhjTmU0YlVkMGI5Y2tlYWRsZU1iWmVHZ3llUmVEZEVnQWFVYWNmTGJGZ05ia2RYZEdnNGhlYkxkRGZBZlljR2JpZUpoWWZXZkFoa2FYZkZlVGVnYmhoT2REYVpibmVUaDJnbGNGaFJkd2U0Z2hiR2VGZ0VhUmRFZkFmTWVqZVVjMGR0ZmpiU2hHZFphcGJGaEhhSmVPZWNjeGVCZk1oVGRWZUZnSmJGYlVkWWY5ZlBkRmhFZ2pjVGd5ZkFkZWRIaGdkOGc1ZWJjamQ4ZEplSGUzaGhldGhWY21mUWVHZVplM2hnZlVjY2JVYllmVGFlZ0ZlTmdQYVpkR2JwZFRkR2ZSY05lNGVYY3hkRWdmYlFjWGdRZktnSWNRZ3dkOWJBaHpnNGM4YVNnd2NsZ3hnRGRSY1JjQmFNZTFlWmIwaGJkbmJaYnpnYmMwZ1pjbmhGZGhoSmZNYmRmVWFKYkVjR2hnYzFiWWZmZWhmY2VIYUllaWMwZTBhTWNCZlJjdmZUYmpmMWVGZ0FhQWRGZlloUmNUYzlhT2FhZVhlUWVZZmNhRWhGZTBoVWVVY3BnT2VkZ1JkRWJuY0JkQmZnY3JmV2NsZ1plMGZEZTJndGdTaEZkSGFGZEdoRWYzZmhlYWZWZ0VmNWFxZVVkeGVrY1RoY2dBY3RhWmVWYmtkOWZRYlJnMmZSZEJkYmZrYXBla2hlZFVjdGZDZE1nRWQ4YmRoQWJ4ZGxoTGRkZkNoZGMrY1lhbWZaZ0lnRWVuYTliOGFPZ0dnWmhZZkNlM2NoZ0ViQ2IzYUJjYWJRYm1oOWZpZ1plaWdjYWFlSWdoZ3doOGhSYUFhTWNaZUNlQmRsY1FoUWJEZ0Vnc2VVYUFkOGNVZUplQmJVYkxkR2FqZ0FlUmFiY2tid2RYZ0xhVGE0ZVZjSWFFZFlia2NIZUJhUmE1ZUVlaGU5YzRhQWZVZVpka2dNZ1hma2VaY0VlM2dBaExlV2FWYVlkU2RlY2thZGZrZUZkeWI4ZVllWmNEZ0JkSGZQZG5jRWhkZ0hkVWYwaFphVmhuaFJidWVkZ25lTmR2Y1JlaWNJYmFiT2RFYnhmMWJTZGhlQmdTY1JmQWZ0Y3dmV2drZ0pjdmNZZGlobGdwZkNkWGJJZFBmZmFXZThlQWdBYWdhWmFGY1BkMGU1aHBoZGVCY2hmd2FRaFhkUmVSaFNla2I1ZzFnRWdUYXRiTWFUaEhoZ2V4ZldnQWh0ZEhnSWVoYVZkY2FhYW1jd2JUZWVnRmVOZFBiWmNHaHBhVGFHYlJiTmh3ZkFneGZ4ZFdhRGYzYm9iVGNaZEVidGd1Y0JiV2MxaDFiU2J4Y3dnNGhIYlFnQmdOZVhoRmZaYXFmY2RHZGhmemFmZ2xjQmh1ZUdkaGJKZUVlUGZFYW9mYmRUYzBiUmFaZWNmRmNCYUNmSWJHZXRncWZhYVJmd2g3ZVRhbmhVYU5jVGNGY3RoRWJYZkFiWmdiZllmSGVnZ1ljZWVBY2hjMGNXYmxmZGJPZUljUmdGZjVmVGhCYWxieGRhYjNneGUwYkRoMmJ0ZVNkRmVIY0ZjR2JFaDNmaGZUYkdnU2VVZzRkVWgxaGNhVGViaFFlc2JOZ0hlbGhzYnBiU2dSZnNnTmZJYlJoMWdraGNna2dzY2NjWmF3ZmdmSWFYYmdieGhXY2NibWM0ZnpnZWNtZ05lc2VaYnhnWWJTY1RlSGhWZEtoRWZGZUpoRWhDYjNmQmFhZEZkMmE5YS9oWmVpZmNoVWRiYkZlQmZ0ZEVhRmIxZGJoU2ZtZk1hVmZUZG1ibGQwZ0dkSGVCYkJjZGhGZkZoS2VHZjNhVWJhZ2Jja2Z3YUZkTWREY2tkRmVlYm5nQWJqZUdhMWVNZDVhUmZoYWhiNGdXZjFibGZ4Z2ZkMGNBZk1mRWQzZllmTGdFZ0ZhOGFKZ1VjRWhkYmtiUWdXZTVnS2ZaYkhlbGZMZkZoSGhGZ0xkWGJCZzhlWmhFY0hoUmd6ZmRmbmZzZzZnUmFuaHNlS2FFZWxkMWdqZlFleGRBYU9lUmVBY05ibWVUYjFhZGg4ZGRjMmVaY3ZhRmhEZnhnSGFhZERkcGFNZVRnVmFGY0plRmNVYTVjcGdkY0JmaGh3ZlNhVGNKYVJiVmUwZDVjOWdWYjNoTmZRZlRlWGhoYWhkUmZYaDBoUGZOYjFlSWhjYk5iMGdZZk5mWmFrZjFjUGJkYVhiTmJhY0ViQmg5Z2FkQ2gxZ2xoV2NFY25kcGNIZVpmRWZGaHVlU2dtY1JlNWZRZzFjcGN4ZUFlQmgxZmJoRGhFYk5kbmhlZDNmWmUxaGJod2FCZ3VjR2VqZ2hhTWZkYVVhb2dRZFVka2RRZ0xiY2RGZnBiQ2ZiZTJoSmh1Y1BiQmNSZ3ZjVGhqZFVjUWFVZ2xhTmVQZVNoUWFSaFlnWWdIY2dneWZjYUVkRmQwZFVkVWFwYU9kZGRSZkZmemVUZ0ZjRmI0Y2VlQmdsYjBmRWJtZHNoQmVHaGdjNGJLZlhiQ2g5ZmFjUWEwaDVocWRVY3hia2ZUY2NjQWd0ZFpjVmJoY0phNmRSZTJoUmhKZUpia2RwZjVnZWJSY2diYWFEYWxoVmVVZENjbGhGZmZlZWRFZFJjMmNjZTJhOWdHYlpneGZZY1NkVGhIaFZjS2RFZUZjSmZNZ1RibmJCYkhkUWVpaEZmaWViY0dkbGdiZWVhMGJKYVpnRWhFY3hoTmZVZlVka2RWZ1RhbWNsZjBkR2RIZkJiQmJmYkJiaGRLY1VnM2RWZFVoY2YxZEpoUGJaY25hQmRIY1llZ2JaYm5mZWRCZlJjeGVSYWhjTmc0YlVmMGg5ZmtkYWdsYk1hWmdFZzNhaGZDZVdnVmEwZlBjZWZoY0pha2RTZTJnNGhGZWJkWGNWZ2hnRmdIYUVnZGJIZVVlMGZaaFZjbmdSY3VkZGhuZk5idmZUYmlmNGZXY0ZlRmhGZjFjWGhBYVZhSGJWYXhiNWU1Y1ZlbWdoZHZiWWdtZVpmcGZGZUhoSmJPZ2NieGFCZk1hVGdWZUZiQmJYYkVnNWRpZWFoUmVnZCtjUWFYYTVjUmFBZ2toZGg1Z09nM2VOYU1oVWRYYWhkd2RWZG5lUWVQYWFjMWRJZFVhY2VVZTVnSGJNZUJjb2hjZmFkaGhVaGZlVmJrYlJid2dGZWxmbGhBZEJmMmc5YVVoY2ZVYkZib2FTYmlmRmJ3YVJiemQ1YnhlSGFSYjFhTmJHYVZnWmEwaGJkbmZaZnpoYmUwYVpkdmFRZGxkb2ZGZEpla2dSZnZkR2hnZTFnTWdPYUZjcGJmZGJhM2JSaHpkZmNBYWRnbmJUZm5hVWZRZ0JkVWdSYUtmWWN4ZFZnT2VhZVhkUWNZY2NhRWRGZDBmRGRGYUZka2VkY1JhRmh6Z1RmRmNGYzRnY2NGZFlnaWRUZ2pmbGJTZ1JhM2VGY2JjRWJ6Z1pnYmFUZFhnWmE4Y1JkZ2IwYkhnWWh4ZzVnT2dRYUFiTmI0ZFRmbWJoZnJhYmFrYnBoa2JlZ1Vhc2dVaGNiUmYwZ2RlVGVWY2hoV2ZhZVdjNGY0ZGVhMmYxYVVjZGZRZklhRWdWaEdkZGFZY0JoVWROYmRlQ2hYZmxiV2VhYUdlOWRpZVpjbWdrZ1VlY2NrZDViemVFZ0Vld2JZZlVhVmNRYVZiQWRHYkZmMmNDZDJhSmJYY1lna2VWZFNnVmEyZ3dhQWZaY0ViNWhZZWRlRmJwYldiZGZBYTlmcmJVZWhjUmZ4ZlJmaGROYzRkRmVVYjliNWhhYWhiMGhSY0VmV2VZYWRoUWNVY1FlRWFiaDFoVmZ5YlVlbWF4aERnYWZGZU5oTGJGZ0hoRWJkYUhiVWQwYVpoVmVuY1JodWVPZm5kTmR5YVJjaWFrZmVkRWZGZzlnaWRYaGdnZGRFZVZlUmRoY3BhU2NVaEJkbWFlZVVleGNwY0ZjSGFKYk9kY2R4aEJoTWVUZVZma2hHZ0dkeGg0ZTdnT2EwZXdhL2hGZlNhMGhCZURjMGhBaDhlWGV6ZW9kWWhVaFdnVmd3ZUhibmIwaERoUWdWZUllVWFjYlVhWWZUYmVhRmVOZVBjWmZHZnBiYmZWZ2hiMGVnYVdoUmJZZENkWGFTYzRkZWROZ0FmUmFnZkhlemhRZzliQ2JrZkFiMGNIZFFjQmhOYVhkd2JNYjZkTGFTYkliNmNJZEFiaGRuY0hja2ZaZUZkZGFSYUVkNmFVZWtjUWZMY2NjRmZwY0NnYmYyZEpobWdhZVJkUmJ5ZUdoRGdKYkNmVGNBYlJmZGJZZXhkVmNPZGFnWGJRZ1llY2VFZEZnMGFVYVVlcGRPZ2RkUmNGYXpnQWIxZkZobGNjZkZmUWFuYVdnemdraGJlV2NqYlpjRWdFZDJlVmZPaFRlemNBZXpoQWYxYXhhY2dOZWdic2JOY1RhVGRoZjZkUmIyZ1JiQmdiZWtkcGJrZGVmVWhzYVVkY2hSZDFoU2FUZ1JjOWRRZ2RnR2FaYytmSmMyZzloYmRaYzFhTWRhZ0diSGh4YkRkSGhGaEpiTWhSZkhlQmdIY1FnbWY1ZnplYmQyaFVoVWVlYWdoZGN6Y0RiVWh4YU1iUWZVZEFjY2hRYWtkTmMwZUdjSGFCaEJkZGVGY0ZmS2FUY25hVWJSZWNkMGR4YlJlZWVIZ0liRGhPYWtlc2V1YkZnRmQwZS9kQWcxZWRiNmhVZDBhNWQ1YWFlZ2hkY0FhUWh6Y1ZnRWVIZzFkWmd6aEtoQmVVaGxjR2FBaHdkZmJJaGpiOGRPZFJobmNFY2JnR2MyY2NmWmRWYm5mUmV1ZGRobmZOYnZoUmdtYWNmV2dFZGtoeGIxZFNlaGNCZ1NmRWNBYnNnNWJGZkJhRWY3YUloeWhnY3FkVWJUZTBhSWhjYzNhRWJlYUhneGFBYlFkZGN4Y3NidmJNYWxhMGVpYVFmWGNKYlhlWWZFZTVnMWVFYVhnTmdNY1VjWGhoaHdlVmhuZlFoUGVhZzFnSWFVZWNhVWNZY2JhY2NCY3BjUGJlYVdhcGFTZkNmUmNwaDhhQ2UxYkVlQ2NFZm1mZGVIZ0tiZ2NRZjVhU2RoZUVnd2ZCY1VlQmZwYWZiRWM4Y2ZlV2dBZDliOGNPZW5nOWc2ZVpjbGMxY05hRmZoZEpiTWdkYVVib2VRZFVha2hRZExjY2FGYnBnQ2VPZ1NlTWQwaGFmVmd4ZnlnVWczYk1lQWRRaEdlZGhSYVNiUmFWZE9mYWdYYVFnWWVjYUViRmQwZVVmVWNwZk9iZGFWYTliemZVZlZlRWRzaGZiaGRvZ3hoUWFTZHdjR2hYZkhmMWZzZ0VlM2VoaFRoVGgyaFJlcWRVaHhha2NUYWNlQWN0YlplVmhoYklmcGhSZDNobGRCYUpla2JwZ3ZnZWNRY1VjUGdXYnhnMGNkYVRkUmZsaFdkZGFHZzVoMmFjZjJmOWZHY1piMWE5YlVmVGNIZDFlYWdFZEViOWNaaENmemQ1YlRmUWJqYzBhbmhNYmpleGZHZFBlRWc0Y25iV2RBaFVjZWNTZ21nTWdWZ1RobWRsZTBhR2hIZkJhQmJkY0ZnRmhLZlRkbmFWZ1lhTmhVZHhoWmNVY25nQmdXaGRlQWg5Y3JiVWVoZlJoeGdSZWhnTmU0YVVoMGQ5ZGtlWWJsZ3RiTmFXZnpnbGNZZ1Zld2ZKYmRkTGZnZllmb2FQZWlhSWNQZUthbmRsYkFhQ2FYZEZlVGdGZ0VjRWZ6ZVZnbmZSYXViZGduZU5idmhSYW1nY2hXZ0Vja2d4ZTFjU2ZoZUJoQ2FSaEJoWmh0ZVdjaGJZZm5jS2V6Y1ZlbmRXYVRjY2FEZUlnRmhrYldlQ2FGYkZjUGJFaDJoUmJwY2RiQmJoaHdnUWdYZFJjUmJTaGtkNWUxYkVmWGdOZ01kVWhYYmhod2JYYmljQmFIYkllZ2dFYWFhUGJBZk5jZWZOZXdiRWdXYVphSGNkZ1RkVmZoY05ndmdDYjFodGhVZkVkbWVCZ0hjTGRVZ0ZheGRTY2lnb2Q4YkhkQmhRZEViVmdGYk1jWmdBZFRjY2NtY1BmRGNjYXFiWmIxY2RkeGRIZXhlSmRXZmRmUWhSYlZoQmhVYlJkWmFlaEVkdGZVZVpmbWR0Z3FoUWR4ZVJieWVUYm5oTWNRZ1RhRWcxYlJiU2FSY1ZjT2VhZ1hnUWhZZ0phQWFraDliQWhrZVFoRGVNZkZmd2hnZkJlUWZzYTlnY2NGYzFhMGRRYVdjdGZPZEZlR2VCZ1FjR2FsZEpjVGhUaDJlUmFxZFVneGRrZlRnY2RBZ3RjWmRWaGhnSmN6ZWJiV2hSZUJnYmNraHBja2VlYVVnc2NVZ2NkUmcwZWRkVGNSZGxmV2ZKZGlkc2NpY0pnamcwYklkWmN4YjRiNGhUZEhjVmdLY0VmRmdKYUVhQ2QzY0JhYWFRZ21nOWRpYVplbWFrZ1VhY2JnYUZjWmdFY0VoeGNOZlVlVWdrZlZjVGJtZWxiMGVHZkhnQmNCaGRlRmJGYUtkVGFuYlVhUmRiZEVjeGRaYUxhRGVnYmZkSmh3YUVibWhGZzFha2QrZkZoRWRwZzRkV2dGY0pla2dQaGxkb2V6ZkVjM2NBY0xjV2RWZVlkU2hlY2thZGJrZlFhV2U1Z0tnWmZIaGxoTGRGZ0hiRWNkZ0JiMGMxZFFiZmNIZ1JidWhkYm5hTmR2YVJibWZjZFdoRWVraHhjMWRTYmhjQmJTaFJhQWd0ZHdmV2NsYzFndmFOZGlhNGRnYlJjM2Z3YkRmTmNsYzBhRGJIYndoaGJIaFJnZ2JzZzlmZmJFZ3hnK2hFY2llRWVUY0NjeGF3aG5oVWVDYXBkRWZRZ1hiUmd3YkdlSGcwYkRoYWR3YlplY2ZPZEJkVWhkY05lUmNZZkNhTmJ5ZU1kSmhYYUJmcGNhZUNjMWdsaFdlRWJuaHBkSGRaYUVnRmd1YVNkbWFSYzVnU2d4ZVJleGFIY1JjMWROYkFjMWVZYmdnWWNEZlVkOGdQY3hmOWZ2YlFhbGJvZkZhSmhrZ1JoZGFGZ3dibGVFY0llZ2ZOZk9iYmZ6ZVlhdWhJZEVoZGE4ZkFhemhaZmRoSGd3Z1FmTGdEY0JjbGhPZGVoWGRnZFllUGVraGhhNGJlaDBlcGFPZWRnUmFGY3piVGFGZkZhNGdjZEZlWmYwZERhMmV0ZlNlRmVIZUZkT2ZSYnphQWJhZkhnR2hvYm5nRmJsY1JkQWFPY1ZhRWNjZlZnaGZsYW5oUmV5YnBhSWhZZW1kQmVrYmVjVWVzZ1VlY2NSYjBmZGhUZ1JobGRXZGRlR2Y1YzJlY2IyYjljR2NNYTFiNWFiaEhhMWU5ZktoRWhGZUpmRWdDaDNlQmhhZ1FnbWI5ZGlnWmRtZGthVWRjZWtjZGJvZ09ha2J4ZU5kVWFVYWtoVmVUZm1jbGMwZkdkSGdCZEJoZGhCZmdjTWdUaG5mMWFGZ09jd2ZVZENoZGFqYzBiVGZPZVZid2RpY0NiRmJGZXhhV2ZCZk5ib2NXYWtjOGYvZlFlRmFNZlpkRWYzZEFiTGFXZFZkWWdTZ2Vma2VkZ2tkUWZXYTVlS2FLZjFnTmRMY0ZhSGRFZmRoSGJVYTBhWmhWZW5iUmV1ZmRibmVOZ3ZoUmdtYmNlV2VEYlVieGc5Y0hibGdnZ2JnRmF3aFVlOWRIZXdnOGFnYk1jRGU5ZXBkSGMyYzlmT2ZKZnhlNGRmZkFnUmFnZUtlVWhFaFplNWRlaEJiaGNoZVZmM2RSYWNhU2NoYW9kOWNXaENhQmhDZUhmRGMwYTlnQmJUZDFhVmFMYWxnc2VkZVdkMGJZZlRmZWFGYU5kUGFaZEdmcGZUZEdoUmJOZXdhQ2MxZGxiV2ZFYm5icGFkYlplQWdoZUVkU2dtY1JjNWdTZnhkUmF4YkhlUmIxaE5oR2VWYVpjMGhiY25nWmZ6Z2JjMWFsY25jUWdsZW9kRmFKYmtiUmFkaEZkd2FsZ0VmSWVnY05jTWFQZUNjY2J5YllnVGQ1ZnlmVGFuZE1jUWdUYUVjMWhSZVNoUmZWaE9jYWVYZVFnWWhjaEVnRmUwYVVhVWRwYk9hZGhVY1ZkOWdIY3doUWU2YU1iUWJRZ21oVGFqZ0phYWhCZUhnMWJHY0FkbWI1Y1RnUWhtZVFmK2hHYzFlQmRBaGZia2VZY2NhR2EwZ0VhemVIaFNmRmdJYVlobWdCZWthZWhVYXNkVWVjaFJiMGFkZ1RlUmRsZVdnZGRHYzViMmdjYjJmOWRHYlpmeGdZZFNnVGhDZkVoQ2hXYlFkRmVLZ1JiamJVY1hkRWFTZ1lkNGFJaDBjTWhVaGNia2U1YnpkRWFFZnhnTmRVYVVka2FWYVRkbWRsYTBmR2NIZkJnQmVkYUZhRmdEY1plSGhVZFJkY2UwY3hkUmhlY0hhQmJXYmRlQWg5ZXJhVWJoYlJheGhSYWhmTmFpYlVmeGh0Y3FnS2VSYXhmSmFTaG5jaGNmaEVmUmQ5Z0JhZGJBZW9haGhEZENlRWNZY1BlWGNWaExjUWVEYWxlVWFUZWthTmZVYkVnemRrZjlkUGN5aGtjcWRTZW1hY2NHZkhia2N4ZGtkWGRCYUJoZmdSY0ZmOGI0YUVheGRGYmhoTGV5Zk1na2FSaHplc2VVZU5oaGFsZVhmWmExZ0ZkSmZGaFViNWJwZmRoQmFoZ3diUWVYY1JkUmJTYWtoNWUxYlJjemhJYWVjVWdUZGxmd2FTZjNjUWhmZmNmSGdnaFVmY2ZVZlliVGRlYUZmTmZQZ1poR2NwYVRnR2ZSZ05kd2NDYnhnWmc4YkVnbmZwZ0hnWmZFaEZidWNTYm1kUmY1Y1NieGJSZnhkSGNSYjFkTmVHYVVkbGUwZlpmaWdJZjdiSmVoYlZlcGhRYkFhTmJDZExjUmZKZ1liTGJSZEZiYmdOYUJic2ZXYUtnbWNwY01lYWFSZlJneWVUYW5mTWRRYVRnRWUxZVJjU2hSYlZjT2hhYlhlUWJZZGNiRWNGYTBlVWdVZXBjR2VJYVZla2I2YUhoMWE4aDFiTmFSaHNlN2JYZlRmSmJjZVZkemdraEhlUWRSYnNkY2JDaHlhRWNMaEJmeGRGYlNhY2VBZkJmWmRSZ3hldGg2ZFdnM2JoYUJhZGVrZk5ma2VKZVdhRWhVY2NhUmgwYmRmVGJSYmxmV2hkZEdhNWgyaGNoMmc5ZkdiWmV4Z1lnU2ZUYkhmVmNLZkVkRmRKZEVhWGJ6ZWdhVGRFZVdkRWJ2aElkeWdSaGJoSWJCZWRkOWhVZXdjUWNNZEFneWZwZGFkQ2dpZXdiVmJUZkhkZ2NBYWZlVmUxZWdmVGVuY1VlUmNjaDBkeGhSY2VnSGdCZldiZGZBZzlncmFVZ2hnUmh4ZVJnaGhOYTRkVWMwZTllc2ZQYmhodGdRYlFmSGE1ZkdiSGFCYnRiZGRLZUJoNWRxZEFhaWZZZUxiTmRoYm9iRWVVYkRlUmI4Z1NiVWZWZVljVmZuZDlidWZaaFhicGN2aFdjbmRzaFdkQ2VraFZjMWZGaGpncGJTZlJhQWh0ZndkV2RrZkpidmZZYW1kWmFwYUZhSGRKZE9lY2d4ZkJiTWVUaFZjRmZKZUZhVWE1aHBnSWNGZkFlNWRFZ25hb2ZjZURnd2ZNZjZhUWZ5Z3BoQ2VFY2pkQWV4Y0JnQmhkZUFjTGN4ZWRiMWhKaFVnNWhTZmVlRmVoY1BlZGFtZE5mNWZHYlJkTmZ3YkNjMWRsY1djRWZuYXBoSGJaY0VjRmR1Y1NjbWRSZjVoU2V4YlJleGZGZkJiRmVuaEdnVmRaYTBnYmRuYVpjemNiYzBmWmZuZUZoaGZKZ01kZGFVYm9mUWJVZ2tnUWJMZ2VjQmd0ZUNjWmdIYjlnbWRmaFJhMWErYVpkSGFNYVFiVGdFZDFmUmNTZlJoVmJPYmFoWGFRYVllY2FFY0ZoMGVVZ1VjcGVPaGRlVWRVZDdmQmFRYkpnMmdKY2tiUmE2YVZjemNNY2FkYWJ5ZVFiV2ZWYnpja2RIZkNibWR4Y0FjVWh4YWthVGRjaEFjdGJaYVZoaGFKYTZlUmMyYlJoQmhiZGtkcGdrZGVoVWFzZFVkY2dSZzBlVmVHZVZlRWZmaEpjMmRBZDdjTmNpYUliSmVOaFVjOGZjZ0RhemIwYUxjUWFqZ0VnTGFUZ3pjVWU3YUZmbWFjY2pmWmVtZUlkVWNZZDBoZGd6aERiRmVCZU5mU2dVYUFlVmVFY2toTmMwZEdiSGhCZUJhZGRGZUZlS2VUaG5iVWNSZmNlMGZ4YVJhZWNIZkJmV2FkZ0FnOWNyYVVlaGNSZ3hnRWNsYXNjeGhBaEVnRWZwZ0xjeGE1YldhUWJTZWtmRmFHZmhmNWRUYktkQ2RRZnJmQmdTY3NhcmhNaEhlRWZLZkhoWGQwYTNnSGNVZzBmWmdWYm5iUmJ1YmRobmhOZXZmUmZtZGNkV2JFYWtoeGQxZVNhaGNCZ1NoUmJBZ3RjNGZEYmdjb2RtYk1nV2RnZGtiVWJUYThlQmRJZ1VibGdDZURmaGFrZUlhUmF5ZzBobWNNaEZlMGhSYkZlWGN3YVFkU2VrZlZjMWNBYm5ncGRNZ1RmV2RSY3dlVGZuZTBiUGFOaDNnZ2hVYmNoVWNZaFRnZWJGZ05iUGRaZEdicGZUZUdoUmdOaHdmQ2ExYWxlV2VFZG5kcGhIYVpjRWZGYXVkSGJpYXdod2FHZUJjb2Q4ZVdoRmhBaENnU2R3YTlhNmdMY1RiNGN5aFBoU2dVYm9hVWVsYWNidGhJZVVoSmFSYlVka2Y4ZkxmWWJsZ05kb2diZzJoSmNtYWFkUmNSYXllVGRuZU1lUWdUYUVoMWRSYlNlUmJWY09hYWJYYVFoWWRlZ1VhMWhlZlVhVWhwY09jZGRSYUZiemZUaEZiRmc0ZWNiRmdaYjBlRGQyZ3RnU2hGZ0hlRmZHZEdkemFsY1RmUmRIZmxlcWhSZXhoQWZmZ1diZ2d0ZFpmVmNoaEpmNmFSYzJkUmNCYWJna2JwZ2toZWdVZnNiVWVjYlJnMGJkY1RhVWEwYWVoUGhUZzFiNGZKZVhheGZJaFBnMGY1ZWFoTWh5ZkFlYWFWaEJmTWNRZlRobmhoYndlUWFtZzllaWZaZG1na2VVZ2Nla2I1YXphRWhFZ3hjTmJVZ1Vha2dWYVRibWRsZTBlR2JIYUJmSmZJY0Joa2NEYkhnWGF0ZGNoTmJnZUVlZWVLaGlobGFZY05nMGFjYnFkQWNIYWNoK2hBYmxjWWhaZ0JkMGFjY2xiYWVsZ2diWmdBY25ma2ZMZlJhVWNvZ1NnWWNrZTVla2hIZFVoUmJLaFplSGFsZExnRmRIY0VjZGJIaFVlMGJaYVZkbmNSZHVoZGduZE5jdmRSYm1lY2VXYkVia2Z4YzFnSGFsZGdiYmhGYXdoVWU5YUhod2Y4Z2djTWZEYjlnbmNWZHpib2RQY0lkWGdNYkRmQ2FSYVFhb2NRYVVoWWVvZGZiUmhSaGFlUWRYZVJiUmFTY2tkNWIxZ0VmWGVOZk1nVWJYYWhld2FWZW5kUWZQYWFlMWVJYVVjY2ZVYllkYmNMaEJnc2JHYU5mMmFRZGVkWGZGZDRnL2VXYlFlQmhZZVVnVGdJY0dmTmhpYklkaGdEYmlkRWNZZkhneGN3ZndmSGdSYlplTmFDYWxjOWMwZWNjbWNwZXpoZGYwYTlmbmdTZmpjaGRNYWRnVWFvZ1FhVWNrYVFoTGRjZUZjcGZDZGJmMmNKZW1kYWNSaFJheWRUZG5lTWhRY1RhRWUxZVJlSGRWZDBhSGdPZG5icGVWZE5iUWF3ZzdmQWZ4Y05hQWJOYWxma2N5ZkhmamVJZzNlTmJCZE1oVmRXYTJmTWJUaEZiSGZwYkdnQWNYZUZkNWZUZTJjUmJxZlVleGFrY1RnY2JBZnRjWmVWZWhjSmc2Z1JoMmZSZ0JkYmdrZHBha2FjYkVhY2graGNkUmYwZ2RiVGVSZWxlV2NkaEdnNWUyZGNlMmg5Z0dnWmR4ZlliU2RUZEhoVmhLZUdhQmZOZkViQWRHZzFiYWJWZm1lWmh1YlRmR2FrZFVlY2NrYjVoemNFZEVheGhOY1VjVWNrZVZmVGJtZGxlMGRHZEhmQmFCZmRmQWdVaENjQmd5ZFlkZmhKZVZjaGZmZ0lkQ2RnY2VjQ2QxY29oN2JGZ2xmVWFsaEFneGd0Z1NlVWMwaDlja2ZhYWxmTWZaYkVlM2hBZExiV2FWY1llU2ZlZWtjZGRrZFFmV2E1ZktoWmFIY2xjRGNRZERhbGNVZ1Ria2FOZ1ViRWN6YWthaGVKYUNlcGRoZUJhU2U5ZlhiUWZDaDhiNmJEZmxkVWZ6YUViQWFNYXhlV2FrZ2xjdmFjZzJjOWRwZENmR2g1Yk9nYWF4Z2xnTWNFZVhldGRKY0ZlVWc1Y3BnZGNCaGhnd2VRZlhlUmJSZFNma2Y1ZjFkRWZYYk5iTWhVY1hoaGR3ZFZlbmNRZVBmUGh4ZXBhZGVJY2tiaGZlY1BiUmc0Z0FhTmVqYU5hZGNXY2xoc2N4YVdlVGhvZFpjVmNqYzhnbWFNY0Vha2V2YVFhMmFoZFRnU2d4ZVJneGJIZVJiMWZOY0dmVmhaZzBoYmFuZVpmemZiYzBlWmduZ0ZhaGVKYk1hZGRVZ29nWWNCZmdkeGNDYUlnMWhRZVBhS2FpZjhhcGRPZzBkMWI4ZkRhVGF0Y1JjSGNpYjRlZWVEYVZhQWh2Z1BlWGR4YlpkY2NFY3BlMGZRYmtkTmFPZmFiUWUxY3pmVmJGZGhkNGNMYUhleGYwZ0RnMmh0Y1NkRmZIYUZiR2RFYTNlaGZUY1RhMmNSZXFkVWV4ZWtlVGRjZkFodGhaZlZhaGhKYTZoRWd5Z3doSWRQY1VoUWRwY1BjQWVaZWJoSWgwYlFlVGFEZGxjRWRYZkpkZ2YwZjVmTmd5YW9jbmRNZHhjNWFUZlRiSGQ1Y0tiQWJsZXRndWdDYzNoQmVhaFFmbWQ5ZmlhWmVtZWtkVWVjYWthNWV6Y0VmRWV4ZU5kVWZVY2tlVmhSZDJkQmZlZUdoSGJCZEJhZGNGZkZoS2ZUYW5hVWFSY2NhMGh4Y1JiZWJIaEJjV2hkaEJhVmZyYldma2VBYjVkRGQwaEJiMmNCZlZmNWVxZU1kZ2h0Z1JhYmZDZ1ZhYmVIaFJmZGFHZ1BnMGU5Yk9iUWFXZjVkS2ZaZEhlbGRMYUZoSGhFZ2RjSGNVZTBmWmRWYW5hUmh1ZGRkbmdOZHZoUmFtZ2NhZWVSYmdoUWU4ZkdhUmc0Y2ZhQWNVYllkL2hDaEJlc2ZVYUlkMmVaZmloRmVHZk1jemJjYXdmeGJRZVRjVWVsaEFkRmJSYkplcGVJYkZmQWQ1YkVkbmdvZmNkRGN3Z01jNmdRZXlib2QzZEVoQWJWZjhhZmJIZlFjUGVhZjFiSWRVZmNjVWhZYlRkZWhGY05lUGhaY0dlcGdUaEdoUmdOaHdkQ2UxYWxmV2ZHZWlhNGdQZExmUmhKZmdnQmF5ZUVoMGVCZEViWWhvY1pobGJ4Y05kRWFsaFpmbmhFYTNiWmd2ZWNoMGZaZC9kSGh4Y0lmUWdkaFJkNWZZY0dkeGVjaEZhUGdSZzhiUGJJZ0RmQWcvZUVhbGRWZ3lhUmZYY01lQ2dNaFdlZGdSZFNlUmZWYk9lYWdYYVFlWWZjaEVjRmIwZFViVWZwY09oZGJSaEZoemJUZ0ZoRmJ4Y2ZiSGV4aDBlRGUyaHRlU2NGY0hnRmFHZkVhM2NoY1RkVGgyY1JjcWdVYnhja2dUYmNlQWF0YlJoRmh4YUpoeGNXZm1jUmhWZFpmMGNaZk9hZWZVY3NjVWZjZFJlMGhkZ1RjUmdsZFdlZGVHYjVkMmFjYjJnOWZHZVpieGNZYlNjR2FEZTBoRGZRYTFid2FTY0dmWGg0ZENhR2VpY2NiZGhNaHplbGRRZ01heGFvZTJkR2dHZ1plTmJVYVVma2FWZFRibWVsZTBkR2ZIYUJoQmJkZUZkRmFLZ1RmbmJVZlJhY2YwY3hlUmhlZ0hhZ2hDYVBoRWdZZjRiWGhGZmtkMGRDZDFhd2RxY0NoamdRZmxjYWhsZ2doWmhBYmdiMGdMZ1JmVWVvYVNlWWdrZzVoa2NIZVdoNGdlZ0xhRGNBZ1lmR2hqY3hjWWNVZEFoSmhMY0Rid2c4Y3ZnQ2czYzlkRmhSZW1kY2dXZUVja2d4ZjFnU2FoZUJmU2ZSZkFjdGd3Z1dma2hKYXZoWWZtY1pkcGJGY0hmSmhHY0poMWNnZEZmSGdsYzhhRWJVZkFiTWJtZkpma2dFZUxnQWJIZ1JmYWZTYWxhMGZJYUVmV2c5Y1FiVWRXZUJiNWJWYmlkZ2VQZlBneGZwZGRjSWJraGhoZWhQZlJlNGRBY05hamRNY29jV2dCZU5iN2JDZjBnc2dyYk9mSGJwZUhiWmFFZUZjdWhTaG1lUmc1YlNneGRSZ3hiSGJSZTFmTmVHZFZnWmUwY2Jjbmc5Zi9kUmFVZFpnbmFGY2hnSmhNY2RlVWZvZVFiVWVrZ1FkTGVjZUZlcGNDZmJiMmNKZm1nYWhSY3diemNUZ25iZ2VOY1RlRmNsY1lkUmNUZjllT2ZhYVhjUWhZZmNkRWFGZjBmVWdVZnBlT2FkZFJjRmJ6aFRkRmhGZDRhY2NGY1lnZ2JSZHllSWdCZ0dlaWNkZlZiSGNTZUFkTGhCZnhoc2EvZEFkMWcxZlNiSmFFYTVkUmVmZEJnSmM2aFJoMmJSYUJiYmdrYnBoa2hlY1Vlc2NVYWNjUmQwZWRkVGRSY2xiV2FkZ0dmNWgyZ2VjemNzZk9jTGhrYlVhY2RBYVRmQWVIZVhod2RBYmRjY2ZEY0ZjYWFTaFdjOWh6YUdoMmFrZUlkYmRrZTVlcmVHYVVjd2FSZFVlUmcxZWRnQmZ6Z3BoNmdWZ1RnVWNNYk9nd2hNZVRlTmNUZFJlc2ZmYTJiWmFSaGViSGVCZVdmZGdBYTllcmZVYWhkUmV4ZlJlaGFOYzRnVWQwYzlja2dhZWxjTWdaYkVlM2doZGZoRWRSZzlhQmVkYkFib2ZoZ0RmQ2ZFYVlmUGFRZklhS2NGZkhlb2NkZERiamhBYlphU2VtZ2hndWZiaG5lcGd2YkdnbWVkY0NkV2RnYVVjbWJSYkZlMGNYZkNmVWRRYmlnQWZ6ZGthdWhZY21mMWZwZ0JkZ2I5aGtlY2h4ZEJiTWdUZVZjRmNKY0ZmVWY1ZnBkZGVCYWhnd2NRYlhjUmNSZ1Nla2g1aDFlR2hIaDlibWNVZlhoaGR3aFZnbmNRYlBiYWQxY0lhVWdjYlVmWWNUZGVhRmNOaFBoWmNHZ3BnVGdFY1ZnSmF3YUFnRWRSYldnQmZuYU5hTGhUZmtoRmN1Y1NibWZSZjVhU2d4Z1JneGVIZFJnMWhOZEdlVmdaZTBmYmJuYVphemViZnhkSWd2aFhhMGRGZENlSWYxYzRlZWJDZGhoeGhEaERod2Y4Y1NjS2R5ZU1keWVMY0JoeGRZZ1RobmdNZ1FoVGdFYzFhUmNTaFJmVmJPZWFjWGhRaFlkY2hFaEZiMGRVYlVocGhPYmRiUmFGZTdmR2RCZ2toeGFJZTFjZ2Q1Z1NjaWZZYmRiUmFpZWdoOWRVZW5iaGZZYlRkM2FVZFhoVWd3Z1ViUGRjYUJiTmVRZVZoa2U1ZjZhRWV5YndmSWVQY1VkUWJwZlBiQWRaZGJjSWgwYlJlbWFEYkdiUmNhZ1hnbWU1ZDJhY2gyZTllR2haZXhiWWJTZFRmSGZWZktkRWJGZ0pjRWhDYTNhQmhhaFFmbWY5ZmlnYmFqZzFhY2VPZXhjMWY5Z1hhUWdrZUFkSGNoZXRhTWVOY1NjaGcwYkVmM2JCZFNkQ2RWYkZnV2RVZG5hVWRKZGVma2Z3ZU5hZWhDYlFkZWhQZlZjeGhsZUhlMWFFZDhlQ2dVYUVkaGVLZEFiNWdrY1llVmRNaExhYmdsZW9mTGNXZVZjWWZTY2Voa2RkYWtjUWVXZjVjS2NaaEhnbGhMYkZmSGFFYmRnSGVVZDBlUWJYZTNiaGRFZGRibmVOY3ZnUmhtYmNmV2ZFZWtleGMxZlNkaGhCZlNnUmVBYnRhd2JXZmthb2huZVlhbWQxaDBlRmJHYk5hWWZjY3hiMWRNZUdiUmRrZ0FmUmZrZEFia2RNY1ZlVWVqY0NjQ2I0ZlViUWYwZEpkZmdFYVhlTmNNZVVjWGJoZHdjVmduZFFhUGJhZzFjSWdVZmNlVWJZZVRhZWdGZnNhYmRMZENjTWRBaEZnMWY0ZjFmUmZnY29oZmhTY0RiOWNIY2VnVWNGYitlUWQyZmhmVGRTY3hiUmd4ZkhnUmMxaE5hR2ZWZFpkMGFiZm5hWmd6ZWJoMGhaYW5lRmNsZDFhTWJjYTBkd2VRYldlaGRCaERoT2VRZ2xkTWNJZmllY2dyZUpha2VZaHJnVGhtZDRiUWdUZmtiOWFZYVVjamc5Yk9hYWZYZVFjWWdjZUVoRmgwYlVkVWZwZk9nZGZSZkVmdWRaZWxiRmY0ZmNjRmhaZjBkRGgyY3RmU2hGYUhmRmNHaEVhemhFYVZkVGgyYXdkNWRVZXhnUWJUZ1loUmQxZlpjU2FBZDlmNmZEYzJmMWhCYU5jV2dCZWthZWRVZnNjVWJjZFJmMGdkaFRnUmFsZVdnZGNHZjVlMmFjaHpoa2ZIYk5oUmhaYUhnVGhHYWhmS2JRZjFoSmNKYUNmMmdGZ01iV2VVZlZjaWJaZ21la2hVZmNma2M1ZHpmRWNFYnhhTmNVZVVoa2VWZVRlaWgwaDdjTWJuYkJiQmFkZ0ZjRmRLYlRkbmJVYlJjY2UwZnhoUmJlaEhhQmJXZGRiQWU4aGthZWdCaFJneGdSZWhmTmM0aFVjMGI5ZWtiYWZsYU1lWmRFYTNjQWVMZFdjVmVZZFNiZWVsZ2hja2VTZlRob2VDZUxhU2JwZkZiUWVtZEFnVGhSZlJlVmNSZUtiU2VFYytkTWRqYklnN2JBaDJoOGU4Y0Vma2Z4ZzFjU2RoYUJkU2FSaEFhdGR3YVdka2VKY3ZiWWhtZlplcGZGYkhkSmhPZmNoeGVCaE1lVGNWZWtiZGZHZ3dnMGRoYU5jVWJvZlRlRGRqZ0FhVWRLZXhncGc5aFdlWGFOYUhhVWJXaGxlNWNWYm1lZ2NUaGFkMGRvYWRlY2JSZW9jVGJMZEZiMGhNYkxoQ2ZzYUJkZWRsZHdkMGJUYWphZ2NDYkdmamRKZU9iYWRHY3RldWVTYW1nUmM1Y1NjeGZSYnhjSGNSZzFlTmFHZVZlWmMwaGJmbmFaZXpjYmgwYVpmbmdGY2hjSmZNYWZhUmg0ZWVlRWFRaHhmS2JJZWpja2ROZEtieWRjYkhoUGJSaHdnNmdUaG5hZ2VRYlhnMGdSYlJoVmRRYWxjT2FjaFhiMGFZZ0xjRWRFYWdmWGd3Z2tlR2dOY0VnTWJRaEFleGFVYjlhRWZRZEpmOGNSYzJodGVaaEZlR2hOYlBkT2dYY2hmVGVUYzJjUmdxYlVmeGdrZlRmY2VBZXRiWmhWZmhhSmc2ZVJlMmJSZEJlYmNrZHBoa2NjYUVnY2crYWNnUmYwY2RkVGFSZWxnV2dkZkdiNWEyZGNjMmI5Z0dmWmF4YlliU2hUZkhkVmVLYUVlRmVKZk1oUWMzZkJkUmRYZTJhOWQyYWJoMmNVYythY2ZrZTVhemZFYUVjeGZOZFVmVWNrYVZlVGZtaGxhMGFHYkhhQmRCZGRiRmhGY0toVGNuZVZlRmVPZndnVWNDZWRnaWZaYkVlZWRsZ2NjemdHZm1kc2drYUZobGZjYjVhQmZ3ZHBjc2FRYUZoTWZaZUVhM2dBZ0xhV2JWaFloU2RlYmtoZGVrYlFmV2E1YUtjWmdIYWxnTGFGZkhoRWNkYUhmVWgwZVJhQWNuYm9ldGdQZWphSWg5Z0poU2JoZFNmVmF5YjBnaGFRZWxnaGhTYVRid2F0YWhiVWIwZkpmemVmZW1iWmV4Y0hjWGFJZlNkY2gwY1JhQ2NEZWhoa2VJZFJheWQwY21iTWVGYTBnUmFGZFhjd2VaZFFjMGZKYWZkRWZYY05iTWFVZlhlaGV3YVZhbmJRYlBkYWgxY0loVWJjYlVlWWhUYmVlRmdOaFBhWmNHaHBoVGVHZFJnc2hrY0JhUmZvZ2ViVWd5aGdha2RLZ3dmVWhyZktjemVCZHhhQWV4YlJmNmVIZFFnNWNFZkdhVWVwZW9lYmdtZzVkNmhiZ3hmcGFuZFFhaGN3Y1BnUGJRY3RoQ2FNZVFndGFQaE5mVGJzZ1dlWmZ5YnBobWNZZGhiUmFnZVJjMWhrYlFlVGJFaDFkUmJTZFJhVmZPY2FhWGVRYVlhY2NFZkZiMGFVY1VncGhPZmRiUmRGZ3plVGdGZ2hlMGRXYmxoWmUwYkRjMmF0Y1NnRmRIZUZjR2VFZzNnaGZUYVRjMmZSZHFoVWZ4Y2tkVGNjYkFidGdaZ1hobGhwZjZoVGFIZmxiQmdlaGtmTmhvYlVmMGhzZ1VoY2JSZzBmZGZUYlJhbGVXZGRnR2Y1aDJiY2IyYzliR2VaaHhmWWhTZ1RoSGJWZ0tlUmJCZ29kTmNXZUhoNGJNY1ViV2JFZTZmUGVpZ0ZicmRKZHhkNGEzZ1VoUmZnZUlnV2RXZE1jVmhUYm1kbGcwZEdkSGNCYUJhZGZGZEZhS2RUY25lVWJSYWNiMGN4YVJoZWhIY0JjV2ZkYUFoOWNyZ1dja2NCYS9jQmdWZXNmNWNBZVNld2JyYUxoaGhaZjRmUmgzYmhoRGNXYVZiMGdTYWFjMGM1Z2tiWGRYY0piS2JmZkhkQmRMZVNiSGNGZUplRWZ3YTViUmJGZ3lmWWJOZk9kVGNjZnFkSmR6Yk1iZWRXZWtkVmg1Y1lmQmFCZVNkUmVBZXRld2dXY2tiSmh2Y1lobWFaYnBnRmFIYkpmT2NjZ3hjQmVNZ1RjVmJGY0pmRmNVYzVnaGdJY0JlWWd6YkNhVGJVZkRiS2ZRYkVjeGRWZEJlSWJZZ1dkVGFCYndmWGdYYlFiY2JZZ2xhSWJJZGJiVWRZZExiY2VWZ01kVGVaZERiNWhkZFdobGhzZXhkV2ZUYm9jWmhWZmpnOGNtY01lRWVrYm1nU2dtaDllNWhXZlJiMWViZEhjUmcxY05hR2RWYVpiMGJiYW5oWmV6ZWJnMGNaZm5kRmNoZkpnTWNkZVVnb2FRZVVha2JRZ0NoZmRIYUJhQ2ZiZjJlSmNtY2FlUmZSZ3lkVGRuY01iUWhUaEVnMWZSY1NlUmJWZ09hYWZYaFFkWWZjY0Vha2E4Z1ViVWFGZ1RmZGVRYlZoNmhRYkhidGI0YmNkRmZaZDBjRGIyZ3RoU2hGZUhmRmdHZ0ViM2FoZlRmVGUyYlJncWFVZ3hia2ZUZmNiRmU4YlJoSGYwYkZlMGNFZFhlQmdQaE5oaGRJZnNiQmRoZTVjRWFOZlZleGhKY0NoQmNGZDhiZGZHaDVhMmNjaDJhOWFHYVpjeGVZYlNlVGVIYVZnS2RFYkZlSmRFYUNoM2RCZ2FmUWZtZTloaWhaZm1kRmdBYWZoQWMwYzdiVWRSYjRldWVIYmdlMWNRYUxlemIxYjhjVWNIZ0JiS2NkZUVjQmNEYlRjbWRrZU5kY2QxZ1JoWWZlY0NmeGdXZklhQWRFZW9mR2NsY1VmamNKZ1Zmd2U4Z0ZhaWU0Z3djWWRoZ3NkUWJIYzFjb2dMY1dkVmRZZFNlZWJraGRha2JRaFdjNWZLZFphSGdsYUxiRmRIYkVhZGNIZFVjMGhaZFZibmRSZHVmZmNpYmRkaGRCY1NjOWJYZVFnQ2c4YTZkRGRsaFVkemFFZUFhTWc0aFdka2NsYXZoY2NXYjljcGNDZEdmNWNPYWFieGFsYk1hRWNWZEVkZGVHaHdoMGRoY05jVWFvZFRiRGhqZEFlVWZLYXhmcGM5ZFdiWGJOYkhkVWZXY3BoNWhmYkhkUWVQZ2FmMWJJZlVhY2ZVY1lhVGhlYkZiTmdQYlpkR2dwZ1RkR2dSZ05od2dDYjFhbGhXYUdiM2dOZXRiWmJFYUZjdWNTYm1lUmc1YlNieGJSY3hoSGhSYzFnTmVHaFZhWmYwZGJhbmNaYXpnZGZVYlpjdmFRZGxib2hGYUpla2NSYUdmUWQwaHBhVGRLYkJmSWg5ZU9mamhJYmliS2JFaEFoM2VSZmxma2JRaFRiRWExaFJkU2ZSYVZoT2RhZ1hoUWRZYmNhRWFGZTBnVWVVYnBkT2VkZlJhRmJ6YlRnRmVGYTRmZWNBZklmUGNSZTJjdGVaaEZkR2VBZzdkRWcyZ1JlUGRUaDNleGJqZFVhMGJVZlRiSmJIZUFjUmZLZXhjNWNRY1JkMmFSZUJhYmFrZXBla2NlZ1Vnc2ZVZGNhUmQwYmRoVGhSZWxiV2FkZUdkNWQyZGNhMmc5YkdiWmF4ZjViR2ZOY3poMWVLZ0dmMWRKaFhnZGFuYUJjR2RYaG1iOWg2ZmJjMmFsYUllY2JoYW9oSWJXZUVleGdHZFVmVmR0YW9jWmhHYWxlMGFHY0hlQmNCY2RmRmZGZ0tlVGhuYVVhUmFjZzBneGJSZmVnSGJCZldhZGRBZTlicmJXYnhnaGZiaFJhaGROZTRnVWMwYjlla2JhaGxoTWFaaEVjM2RBaExmV2RWaFlkU2VlYWtmZGVrZlFjV2U1YkNhTGFIZmxnQWdDYlhnRWNKaEZhRWRFYXpnVmduZlJhdWhkZW5kTmF2Z1JnbWNjYldnRWdrYXhjMWRTY2hjQmFTaFJhQWh0YXdkV2FrZUlkN2ZLZWlnOGM2ZkdmaWdSZmNjZmFVY2dnVWhCZFNnNGdjaFJlUWZvYW9lSWRGYzFoNGNhYTNnUmdSY1Nia2g1ZTFnRWZYZ05lTWJVYVhnaGR3Y1ZlbmNRZVBjYWMxZ0lhVWhjZVVhWWRUZGVhRmFOZUhjTWFCZEVlYmJHYVJjaGR3YkdjaWdSZVdjRGZtY1poSGVmZEVjaGN1YUZlbWhRZnRkTWZGZ3dmTWNFZlRhZGFOY0dkVmdaYjBkYmFuYlplemZiYzBkWmduZUZhaGVKZU1jZGdVaG9oUWJVZWtlUWRMYWNnRmRwZkNmWmZ6ZlloZGdJZlJnUmg1Y1RibWZCZXRhVGZGZUZmTmhTZFFjMWVIY2FkU2ZnZ1lhSmVEY29jOGZVZ1VmRmdPY1piMmh4YVpoVGdGZ0ZlNGdjZ0ZnWmIwYkRjMmN0YVNjRmZIZkZkR2FFZzNjaGVUYlRkMmVSYXFnVWN4aGtiYWRmYUNoRmZaZ1ZlaGJKYTZlUmQyYVJjQmRiaGtmcGFrYWViVWRzZFVkY2ZSYzBhZGVUYlJlbGNXZ2RoR2JZaCtiY2EyaFJmYmdaYndoSWhiZVFlRmE5ZEtnRWdGZkpkRWNDaDNoQmZhYVFhbWU5YWljWmNtYWtnVWRjZ2tjNWV6YUVnRWJ4ZE5oVWdSZTFhZGRCZXpicGU2ZVRnbWFOZFBiTGJBYWtmQ2RNZ1NiQmdCZE5id2EwaEZnUGVYZmhmOGdkYUFhOWVyZlVkaGFSYnhnUmJoaE5kNGFVZTBoOWhrZ2FjbGJNZVphRWczY0FnTGZXYVZmWWVTY2Voa2Y4YXdjT2hpY1pmS2FiYTNlbGFhaGFoWGdFY0JiQWZVYzBoQmVYZzNoUWh5ZWRkaWJjYVVlRGJoZm9kYWNPZEVneGYxYVNlaGRCYVNoUmhBYXRkd2hXYmtlSmd2ZVlobWZaZHBoRmVIZkpiT2JjYXhkQmhNZVRiVmdGZUJkUWZUZlVmaGJkZEJkTmF3ZFVlZ2JsYVJoVmVsZkphMWhDZVhkcGhNZkRiWGZnaGtiTGNUY3diUGFZZ0ZmSWdHYURmR2F3YlRjZWhGY05mUGNaaEdocGVUY0doUmJOaHdhQ2cxaGxhV2VFYm5jcGFIYlpiRWNGZ3VoU2NtZTFhMWJZZ1JmUmZ4YkhjUmQxYk5kR2NWZVpnMGRiZG5nWmd6ZWJlMGNaZ25lRmJoYkpkTWFkZFVjb2dRYVdnZ2R3YUxoZWYwZWRnQ2hlYzJldGNxY1FleGRSZXljVGJuZU1kUWdUZ0VlMWZSZVNnUmJWZk9oYWhYYVFhWWdjaEVkRmEwZVVhVWhwZE9lSWNWZ2tkNmRIZTFmOGh1Z1plRmdnaHNnVmh5YU1ldGhRZFNjRWFDaFVlaWZ3ZldoUmIwZjVlcWNVZXhja2VUZWNmQWZ0Z1pkVmVoaEpiNmJSYTJlUmZCYmJha2NwaGtkZWhVZnNoVWRjYVJjMGNkY1JoVWcwYXRmUGNHZzVkOWFjZjNjNGc3ZFpkd2JvZk9kVGNHZzFoRGRFYUFlNWRFZVhmd2dzY1NiUGUyaE5lSWJaZm1ha2hVZGNoa2I1Z3pkRWJFY3hoTmNVYlVna2hWZVRkbWdsZjBjR2JIY0JlQmFkY0ZhRmFLYVRmbmExaEZkQ2hBZVJhUmNjYjNmQmZGZENlUWU5ZTNkVGRoZVJicGJUZHhoTWJrZVVjeGNzZ2ZmSWRsZ01iU2ZFZTJoSmMyYWNkMWhZYVNkZWdrYWRha2ZRZ1dlNWVLZ1pkSGFsZExiRmFIYUViZGFIY1VkMGRaYlZnbmhSZHVjZmUzYnBjamJiYkdoY2hXZ0Vha2h4ZTFmU2hoZUJlU2VSZkFndGd3ZFdka2FKY3ZiWWdtZlpicGFGYkhlb2RHY2NjeGd0YVJiVGZVYVZkQWREZG1jUmZwYmRnQmFoY3djUWFYZlJoUmVTaGtlNWcxYUVjWGhOZ01jVWVTZjhlNGVIYnpjaGVLZ2FkMWhwZUJkY2NWaGdoT2JlZUJidGZHZ2ZoMGZCZFRjR2JSaE5hd2VDZDFjbGJXZUVmbmZwZEhoWmdFYkVjemVZYkdnUmg1YlNoeGhSZ3hiSGhSZDFnTmNHZ1ZmWmMwZWJnaWNRYzJnT2h4aE1kMWZXYkJhSmFFaFhkMGFvYVFiVWNraFFnTGVjZEZicGhDY2JhMmhKYW1mYWJSYlJleWRIZFhlTWFPYVRnQWJWaFJhVGh4YU5oa2RhYVhoUWVZZmNmRWVGZjBoVWhVZHBmT2dkZFJoRmZ6YlRiRmVGZzRiY2FGYjRlN2RKZ1dldGFTaEZoSGhGY0dmRWEzZ2hnVGFUYzJjUmVxY1VleGdrZ1RiY2ZBY3RlWmdWYWdmMWI2Z1RlemJBZ0phSmV4ZGxicWJOZkFoNWJaZVBja2c5ZUVkVGNSaEpoTGdkaERkcGg0ZElhQ2FNYlBiSmJGY01kYWNCaEhneGVEZE9lbGJKZ0ViQ2MzZEJiYWVRZm1nOWFpZVphbWVrZFVmY2FrZTVmemJFZEVleGVOZFViVmVNZlZjQmUwY05kMGNHYkhiQmVCYmRhRmFGZUtiVGFuZlVkUmJjYzBoeGhSY2VlSGdCYVdkZGRBZTlkMGhVZWtoQWc1Z0RmMGNCZTJnSGZnZm9icGFKZ1FoRmZBY0hkU2FOY09mRGVWYzVlR2ZkYkJmUWF4Y0FoeWU4YlliTmJqZGdlU2ZIZ0Rha2JSY0hjUmI0ZVFhV2duYVFiNmFQZWphb2E4Z1NiQ2RwZlRlWGh4ZzhnOGRFaEZjVmJiY2JoZ2Z0YXdnV2JrZEpodmZZY21hWmJwZEZiSGdKY09nY2J4YUJlTWZUZlZoRmZKaEZiVmRSZXBkSWRCaFlkemZEaGlhUWRJZlFkaGRvZjlnV2JDZkJlQ2JIZ0RiMGg5ZUdjU2JaaFdhWmIxY0plQWJPY1FiOWZBY2RhaGY0ZEtkS2NUZmtiYWRRYTFhWmI4ZENmeGRGZ2FlRWVpZWxjT2VhZEdhdGd1Z1NnbWJSYjVnU2J4ZlJjeGRIYlJkMWNOZUdkVmNaYTBnYmNuZ1pmemhaYXhnSWN2ZlhoMGJGZkNmT2RBZDliZGVBZlFkMWRSZU5mVmZwZ2ZkYmJ6ZUZmbWZaYUJhUWg2ZVJhM2ZvZGNlWmJraDFkUmdTZ1JlVmdPZmFnWGJRZVlkY2VFYUZiMGVVZ1VicGNPZElnVmJraDZoSGQzZ3RnNGhjY0ZmWmcwaERlMmF0Z1NlRmJIZUZoR2ZFZjNkaGhhY1ZkRWI1aHFnVWZ4ZWtlVGVjY0FmdGZaZFZkaGFKaDZiR2htZDFlTmNSZUVocGZrZWVoVWFzZFVhY2JSZDBiZGhUaFJkbGVlYU9lMmVBYm1oSWNTaEFkU2RLZ0ViSmZMY0hmRGRCZEVoVmhCYnNhRGNUZGloTWhPZVFnbmNKYWlmSWZEZnhkYWVNZlJib2I2Ylhod2ZKZ05oV2FVZ0FiVmZGYVVhTmIwZkdiSGFCYkJhZGhGYkZjS2VUaG5lVWVSY2NlMGN3ZUhnT2dTYkpnV2JJaEFlTmFCYVViaGNSaHhoUmhoaE5mNGFVZDBmOWFrZWFkbGhNZFpoRWUzZkJnWmVWZlhod2FTYWVia2RkZmtoUWJXZDVoS2NaZEhobGNMYkZhSGJFYWRkSGdRZVFmWmZTZTNiUWY2Z1BlamJvZDhlU2FDYXBnVGdYYndlTWduZ0VjeGh4YzRkUmNBZ3Rjd2dXZWtkSmJ2aFlkbWNaZnBoRmZIY0phT2VjZnhnQWNKZFRnVWZ4Y0piRmF4YjBjOWZKaGxlRWgrYkJkbmNaY1JjVmQxYU5kMWZSZFNib2djZUZmRGJjZjJlVmZqZzBjRGFRYlZjSWhVZmNnVWdZZVRmZWdGZE5jUGZaY0dlcGNUaEdhUmJOYndhUmdGY2xoTGVFZW1hcGNMYlRha2RGYXVjU2RtZVJnNWRTaHhiUmF4Y0hlUmExYU5kR2FWaFplMGdKY25oWmN1YWJieGhJZXZiWGgwY0ZoQ2JPZkFnOWJkZUFkUWMxZlJoTmJWZlpmb2ZiZTJlSmJtYmFlUmRSZHllVGFuaE1nUWJUZ0VjMWNSY1NhUmRVYU5kYWhXZWtlWWNQY2djUWVqZFVlUWJSZkdiZmdBY3BjWmRUYUZmRmQ0Z2NnRmRaZDBjRGYyaHRmU2dGZkhiRmhHY1ZjVGVjZ0JhVGUyYnhlQWdVZ3hma2NUZWNhQWN0YlpnVmRoYUpmNmRSaDJjUmhCZmJka2hvZ3dmZWJWZ1lkK2FjaFJiMGZkYVRjUmFsZVdiZGhHZDVoMmdjYzJoOWFHZVpieGNZZVNjVGhDZkVmQ2ZXaFFiRmRLZVhjemg4Zk9mQWd5Z01mZGhLYmlmeGFhYmNmbGJCZHVhRWFGZDFiYmFlaDBla2RWZlRobWdsYzBiR2hIZUJjQmVkZUZiRmRLZFRibmJVZlJnY2UwaHhoUmFlZkdlOWdXY0liRWRjY2lmQWFSZm9jbmRWaHphbGE0ZFVjMGc5ZGtiYWdsZE1lWmdFZTNkQWNMaFdoVmVZZ1NlZWZrY2Rja2FRZ1djNWVLYVpmSGNsZkxoR2NpYU5hU2hTZVFmRWFSYlJlM2QxZUVlZGRuaE5idmhSZG1lY2RXY0Voa2F4ZDFkU2FoaEJlU2hSZkFidGZ3Yldla2VKZXZnWWZtY1pocGdGY0hjd2RQZk5nMWRSaEViWmQxYUZnSmZGYVVhNWRwZWRoQmhoZ3djUWVYZVJlUmNTZmtkNWQxYUVhWGVOZk1iVWRYYmhnd2JWaG5nUWRQZ2Fjd2ZaZ2NlT2ZCYVVoZGhMZ2toRmNsYlpmR2hwYVRjR2ZSZU5od2FDYzFkbGFXZEVjbmRwZEhmWmhFY0ZldWhTaG1lUmE1aFNheGdSZHhnSGZSaDFoTmVHZVZkWmQ2ZVBkRGZraG5mSWEwZTVhd2VIY3pmaGFNYmRlVWVvaFFiVWZrZVFnTGdjZ0ZicGdDZWJoMmFKYm1mYWFSZlJneWJUZG5nTWhRZFRmRWYxZFJlU2NSZVZmT2VhYlhmcGFaZE5oQWZWaDhiQmhRZkljSGdKZWhoOGdsZFhkMWM4Y3FmUGh3ZUlkNGZCYTNocGFBaEhjWGg4YkhnVmZ6Z3hmYmdHZXlld2VqZUFiQmVkYUZoWmdBZ1VkTGVHZVViWWMyaFRkM2ZWZlplWmYwYk5ldGJVaDBkc2dVZmNiUmcwaGRkVGNSZ2xlV2dkZUdhNWUyaGNkMmU5Y0dhWmh4Y1lmU2NUaEhlVmdLY0VkRmdKaE5jSWZYY0JjYWJRZ21iOWVpY1pnbWZrZFVoY2ZrYjVoemhFYUVkeGFOZVVnVWRrZlZjVGNuY05jMGdUYURmZ2JJZUpnMWY4aFpnQ2d6aEJnVmhmZVFoOGVkZE5hemE0aFRoZmJBZlpmbGdFYzFmQWYxYVRobGg5ZHhnWGQyZFZoa2RhaGxhTWFaaEVnM2hBYkxlV2RWYVlnU2NlYWtiZGNrZ1FjV2g1ZEtoTWJIaGNiS2JVYURkVWFWZVhma2NOZmZnQmJEZXNkamFHYUNlWWNpaEJiQ2hKZUVlR2NoYWdiOWNBZzBhTmFjZ0VoRWJRaGtnR2h3ZDRnUWZMZGliTWVuZkhiWGJ0YVZkV2VSYUJhTWdUaFZoRmdKZEZjVWg1Z3BkZGFCZGhkd2dRaFhkUmNSZEFka2E1ZDRkRWdXZ2RoTWhUZDJjVmh3ZkdoV2c4ZGxoUWJWZEliVWRjY1VkWWdUZmVoRmNOYVBjWmhHYXBiVGVHZVJjcGJhZ0NmMWNsYldlRWduZXBmSGFaYUVjRmh1YlNnbWRSZjVlU2R4aFFkMGhOYXhoMWNOaEdlVmRaZjBiYmFuY1phemFiZDBlWmNuZ0ZmaGhKYk1kZGJVY29kUGNVZGdkY2ZGZU5lZ2dnZk5nSWNnYUFldmVQZlViZGQ2Y1pmSGZNYVFiVGZFZDFmUmZTZFJkVmZPZmFjWGZRZlliY2ZFY0ZjMGdVY1VkcGVPZWRiUmhGaHphUmhCZGhiMmhNZHhlNGMxZ1hlUWdnYmRlVWJEYlFlbmVSZzNjQWNjYVRnMmQ5ZnFkUWVoZkFoVGhiZkJlZGhaY1RlaGJ0YzZhR2YyYlFoSWJZZkFla2JzZk9oQmFsZjNmUGNsZGxjWWdMZEVoMWNlZE9nMmJkYTZhV2ZXYjliR2VaZ3hnWWhTZVRoSGdWZ0tjRWZGZkpoRWZDZjNnQmFhY1FkbWY5ZmliWmFtYmtmVWVlaGdnZGU5aFVmd2VRY01oQWd5aHBhYWNDY2lkd2hWaFRhSGRnZE9jZGRGZ3BoS2dYYlhjd2ZSZmJoMWhCYlJnWWhIYWxjV2VLZUFjOGJpZ1hmRmZjYzVmQmYwZEVkYmhIYUFlc2NoYkNod2hjYlJmWGZIYkFlQWNXYVVkUWZiZFVoRWdkYWtlUWNXYjViS2RaaEhobGJMZUZmSGVFYWRkSGVVYTBhWmdWZW5hUmN1Z2RkbmZwZEZhUmZtY2NoV2FFY2toeGgxZFNkaGdCZ1NhUmFBYXRkd2RXYmtlSmN2YVlmbmh4Z3BjVmYzYXdjSWNJYlZoOGJCYkxneGhnY2RnUmNrYlpiRGFkYkJjaGV3Y1FlWGVSY1JlU2RrYjVlMWJFYlhkTmRNYVVoWGNoZHdlVmFuZ1FnUGFhZjFnSWRjZE9jRGgxYmNjZWhGZGhnUGNkY1JkZGdUZkJmUWY5aHdkRWIxaEJlV2VUZW5jb2ZPZkhmd2M0ZFRjUmRrZDVjNWVTZHhmUmh4ZUhmUmQxYk5jR2ZWZFphMGRiZm5oWmR6ZWJiMGVaYm5hRmJoZkpoTWVkZVVoSmJaZUtnUWRzZkxmZWExZXBhUmZFZW1nSmE2ZWRjUmZSYXFmUmgzZk5lTWRUZEFnUWdxZkJjaGhWYUZhYWFXZlpkbGJXZmtlRmYwYlViVWRwZk9lZGJSY0ZkemRUZEZiRmc0aGNnRmhaZTBnRGYyYnRmU2RGY0hnaGZLYk9mWGNoZFRoVGcyZFJjcWhVYXhoa2RUYmNkQWR0ZlplVmJoZEpkNmZSZzJlUWNWaFlnQWZzZWdlUGhVZ05hWGZmZDFoQmhJaEFnVWIwaGZlSmVDZElhdmRlYnpocGdQZmJoaGNoaEFlQWd5YkVlR2dHZUVhTmhUY0FhbmE0Z1hlRmJ5ZU1iMmNMY3plbGhZZ0tlMGFZZTFhR2NVZEJobmVVZ1Vja2VWaFRobWZsYzBnR2dIZUJjQmZkYkZmRmdLYlRobmNVYVJlY2YwY1FmZWFlZEhndGRMZWRnQmV0Y2llU2dUZzVjeGZSZWhhTmU0aFVoMGc5ZWtmYWRsYk1iWmFFYTNlQmZOZEZhZ2NRZVNiY2dsYXhja2NDZ1dmNWNVYlpiRGJaZ1FkRmJIY2dnM2RIZ1VhMGhaZFZhbmRSY3VkZGFuaE5mdmVSaG1mY2hXZ0Vla2d3YzJnUmZGYlloQWhDZTBnWWJTYkVieGRZZzhnYWZpYU5ocGdDYTNhSWRIaGZmVmdNZEVhRGdBZE1ocWRXaGdob2ZzY0ZhVWd4aDRoRGhuYzlmYWJRZTBnNWV2Z0VmVGRvZjNkSGZuZU5iN2FLZTNnZ2NQZWViMWNzaFlkV2gwYVllVGdlZUZkTmNQZlpjR2dwZFRjR2VSY05kd2RDaDFnbGZXZUVkbmVvYVRiYWRnY0FocWdEZW1jd2U2ZlJjVmhrYWtoVWJVaGtnRWJTYlJmb2V0ZFpkamRwYzZnWmFrYmdoMWJXYlVmWWVBYWZlVmhzYkJhV2EwaHBhR2NKZFJnWWJXZEplamZJZnFlTWhCY3djaGRSYjJoZ2g2YVRkRWUxYlJiU2NSZlZmT2JhZlhhUWRZZ2NnRWdGZTBkQWF3aDhhYWhJYkVnTWY5YVRmRmhsZlNoY2RGZ1pmMGFEaDJidGJTY0ZhSGFGYUdiRWUzaGhkVGVUZjJmUmhpZkFjUmRrZU9lY2JGZjljWGhGZ1ZjNGMxY0NjU2FGYUpnWmUwZlFiM2dNZlFiSmRTZ0pkV2U5Z1VnQ2ZsY0VoQ2JmYkhiOWdqZ2VhbWJaZEtiVGZSZFlmU2dUZ0hoVmhLYUVhRmRKY0VoQ2gzZEJmYWJRZm1nOWJpYk1hbWdkZ01lUGVSZnhiN2FRYmthVmVEZEhnQmh4ZlplR2JpY0Fia2VWYkNkbGFKZk5nVmJoYUdnWmNIZVVmUmZjZDBneGdSYWVoSGRCZVdmZGRBaDlicmZVZmhoUmF4YVRla2hGZTRjVGFrZThld2NaZUJmQmRWZlhhRGY1YU9kVWhWZThhY2NLYVFnOGJ0ZUJhemhvYzRkTGRUZzRkRGJRZ0hha2VNZkRia2NRY1FoV2dsYzVldWVkZG5iTmN2ZVJibWdjaFdnRWFrZnhkMWVTYmhmQmVTZVJnRmU5aCtlQWVnZTBnOWRhY2poUmNnYkdiamY4ZmJnUGgwZFFiRmVIYVJkMGFRaEhkUmd0YmdoZWVEZEpid2RRZVhlUmdSYVNla2U1ZTFhRWRYYk5lTWdVYVhjaGd3ZVZlbmd4Y2RnYWEwYThoVWRKZVVnaGRRZk5nQmh3Z0JjSWRXZ0pkYWRGYjBoQWU0ZVFkaGc4ZkNhWWVEaE1iQWZMY0JlVmJtZ1diM2VKZndlUWhoYWhlYmVIZVJkMWhOZEdkVmhaZzBlYmhuZVpkemViZzBhWmVuZ0ZjaGJJZllmZWZ4YkphZmFBZUVheGVaZ2VhVmZaY29oYmgyYUplbWJhYlJkUmN5ZFRlbmhNZlFhVGhFYjFnUmJTZ1JjVWVhY0ljVGMxZ0xmZmdnZmdoNmFHY0JiNWhHZkliVmJrYzZjSGYxYjhkcmJOYVJhTWR3YUJmbWJkZjRkRmdIZEZnR2NFZjNkaGNUZlRnMmRSaHFlVWZ4Y2tlVGRjYUFnc2hOYmZmQmVKYzZnUmMyaFJlQmhiY2ticGhrYWVoVWZzZVVhY2JSaFFhR2JaZXhkbGdXaGRiR2c1YzJlY2EyZTlnR2haZHhjWmVQZVJhWGZsZWdkRWhGZkplRWFDYzNiQmVhZlFjbWY5aGlhWmVtZEZkQWhmZEFjc2NyYlFnQWdNY2ZiQmRSZG9mVmdVYzJka2M3YkVjV2h0YXJiZGZGZEZoS2VUZ25nVWZSY0xla2VJY1NnT2FUZXdoYWFmYUZjMWJuZVVhbGQxYjVmVmNoZnBoMmFNYVJhb2dpYkxlQmhaZUxoR2NuY2tiUWVjYjFjWWhTZmVha2NjaDVkVGFVZFJjS2ZaYkhmbGRMaFViaWZSZFRkWGdoZmxhUWJHZ1RncGh1Y2ZhaWNkZ21mUmJqYXdkOGNFYWtheGYxZVNkaGJCZVNhRWFrYW9naWdXY2hoQmgwZlNlR2FaZnBoRmZIZEpiT2JjYjBhSmFNZlVjRmJGZ0JhVWh4Y3NnbmZOYzBnd2Q1ZERhamJwZ1JmUWJrYmRjMWdTY2xmbGNNaFVkWGNoY3djVmFuYlFoUGFhZ3dnQmFSZkphUmJOZUJmTmJsY01nYmZMZ0NjTWVBYUFjamhsZndnQ2UxYWxkV2NFZ25jb2RhYmJiVWJsZ25kVWJVZzViNWNTY3hoUmF4ZEhjUmUwYlpiU2J3ZzlhMGZOZFZleGV6ZmJoMGNaZ25iRmdoZUpiTWJkaFJkZ2NRZFRkMGFSYlpoY2dBZVljZWRiYndoUWN6Z0phMWhjZ21oQmV6aHhjZWNSYUVmOGdEZ0RhRWhFZ2JjT2F6ZG9kWWRKYUFia2c5Z0Fia2JoY0hnZmRSY2hkemFFaEFnMWc0ZmVmRWFkYTRoRGh5YzRjRWZWZ1RhMWZQZUdnM2RvYUhkQmR5ZDBhNWRVY1JjQWRJY1dkZ2F0Y1pkVmZoZ0pnNmVSaHpibGhCZkxhUWdzZ3doT2hnaE1hVWZlYVZhUWZVZ1RkVWVKYThlZGdHaDVlMmNjYjJlOWFHYlpneGhZaFFoQWd6ZWNkQWFWZlJhRWRRZUNkWGVCZ0hiWGEyZThkMmhQYnplbGRSZFBhUWNoYXpjUmF3YlVhRGRGZlFoWmZDaFRmbWQ5Y3lnR2RIZGdiVGVkZ0VmeGVLYkdiVGd4YWZkTmZ3ZE1mR2VjZldodGc4Z2RoQWE5ZHJiVWVoYVJoeGJHYXpjbGg0YlVkMGY5aGtmYWJsYk5hTmJIZlRmVmhUYUNoUmVsZEFnTGhoY1Jna2JYZEdlNGRZYmZkMWNOZ0xmRmhIYkVjZGNRaEVoRWd6ZlZibmZSaHVlZGdqZ1ViNmVDYkNjUmNDZVdkd2hNZzdoU2JoZ2dkR2NTZUFnc2RpYlVnMGRJaDBkU2FHZVphcGJGY0hiSmVPYmNoeGNJZ1pkSGZoY1JiSmVSY2hib2c3Z1BoVmFzZWtjUWQyZTlhN2JTaGthNWUxZEVlWGdOZ01lRmN5ZzBlK2RGZVNmQmZHZ0pnQmJ3YlVjT2RFYTVmSGNjZlZhTWVVZFRnbWhwZ1RhR2ZSZE5ld2hDZzFmbGhXZVJiRGhzZVZkWmVCY05idWdWZTJnUWZ0YlJjVmVnZTBmVWcxZW9kWmdVZFVmMWdlYWJkbmFaYXpiYmEwZlpjbmVGZ2hiSWhGZ01jMGdvYVlkQWFFZlFoT2FjZkVjNWRDYWNiV2FKaDJkWWJEZzVmeWRUZW5iTWdRY1RnRWIxYVJhU2ZSaFZoT2RQY1RneGZLZlBleGVaZjBkSGF3aDhjWmVkZVhlUWJoY0hlaGg0aHFiZWNGaFFmZGhRZFRoMGZUaFdhRGNnZkNmRWJ5YnNmSGJIZlNiMGFrYUZnQmNjYlRoSGRFZTRhWGdFaFVnWWh5ZlJheWVrYVVkUGRSZDVka2ZPZ3dmNGNVZE1nQmQxZFFoR2FGY1VoQ2VQYVRmNGY2Z05lbWI4ZkpoSWVSY1lhR2dUYW5jeGRSYU9hbGNKZEVlQ2MzYUJnYWRRaG1nOWNpZU5iQ2N4YkFhSmN4aHdhOWVFYkVkNWNRYlVlMGZraEloVWYzYVJkMGRUZkFmc2JUYmRjRmV4Z0tiWGRBYmdiUmdiZ0VieGVEYmVlR2VwZldiZGZoY0pocGVVZ2dobGNzZVdleGFNY3NmS2dCZzFka2haYjFhTWNJZ2JobmdBZFVnV2dVYmNoU2JZZ0VlZGUwYldia2NSZktnWmZIaGxoTGZGZUhiRmdBYk5kMGYwZlpjVmRuZlJodWdkZGplVWg2YUNkQ2RSZ0NmV2N3ZE1oN2RTZmxnVmRhZUViQWRKZHdiQWJXYWhkdmVZZW1nWmZwZkZhSGFKYU9kY2gwYUliSmdHZVFhUWdiY1dhMGY1ZGhkWmd4YmhlNmZRaFNjQmRmaEJoZ2FzYzdjVmhpZmNjRWhXZEhmaGIvaFZkbWNBY1BkWmZsZEpoZGhlY1JkSWRhaFlkM2hsZlBjWmRHZXBoVGRHZVJkTWJ0Z0ljVmFsZldkRWRuZ3BoSGZaZ0FiY2Q3ZUJjQ2ZjY3RiQWVsaHNmL2ZIZVZmSmJGZVRiVmY5ZDBkTmJWaHhmemdiaDBmWmFuaEZlaGdKZE1oZGdSZ3hnUmFBZUVnUmdaYWZlSGhCYUNoYmEyZkpmbWRhY1JmUmd5aFRkbmRNYlFiQ2ZVZ0ZjN2JTZlJnVmNPaGFmWGRRYVlmY2hFYkZjMGZVYVFnVmRDZlhjeGVGYXpoVGNGZEZmNGhjZEZmWmcwYkRoMmhzZ2FnR2VGY3RlR2JFYTNjaGdUZlRkMmRSZXFlVWF4aGtnVGVQZmdiZGV6Y1ZhaGVKaDZjUmgyY1JkQmJiZ2tkcGRrZWVkUmFnYVVjYmNCZjFiSmJRYTFmVWNUZk9oaWdrY2lnT2czZFJnc2haYnhoWWdTZFRiSGVWaEtjRWdGZEpoTWRRYjNkQmNIaFFiaWdaaHFjTWZtYkFhZGNmZWtkNWg3YVhia2V4ZVFiVWhRZ2RmUWdHZ1dla2V5ZEVhSGFoZ1NhZGJGZnRlS2VIZVhod2JSZGZkRWV4YUZhZWhIaDFjV2FQZEFlWmNpZlhmaGNSZzVnQWN4Zk5hbGJVZndjZGRrZ2RiRmhNYkpjRWEyaDhkTGhDY2xjWWRmZ2VlbGJOYWtiV2IyZjRiWmJiZldmSmFoZ0ZnSGZFYmRjSGJVYzBmWmhWYm5lUWc0ZE5meWFGYXZlQmEyYmNjTGRFZmxheGZ1ZFljQmRCY1NhUmhBY3Rod2JXY2toSmh2YkpnQ2hrYjdoRmVIZ29kY2ZjY3dlMWRNYVhjVWRwYUpoVWZFYTVnM2VkZkVocGNyYVFiU2FaZ1JkUWFWYk5hMWdCYVhmcGZtY1VmWGZoZXdhVmFuY1FmUGdhZzFiSWRVYmNjVWc1aGNlZWNFYzVmbGNaY0dkcGdUaEdmUmhOaHdkQ2YxY2xjV2NFZm5jcGZIY2JjQmJRY1ZhSGJtY29oNmFBZTFjVWZqZGZjbGFJZEpoWGREZ2NkZ2JaYmlmUmQ2ZkVja2haZDdnQ2FoYUpnZGViYlVhTWdRY0RobWY0Y0xjY2VGZnBjQ2FiZTJnSmZtZWFmUmFSYXlkVGZuZE1oWWNHYlRhWWNGZVJnMWRZZkdkS2hDZlpoN2ZQY3diVWR4ZE1hQmg1YUdoSmR4YkZkNGFUYUVmQmJ4ZERhVmZaZW9jRWQyZHRoRGhCYm5jaGdHYlRlMWZKZFRkVGEyZVJocWZVYnhoa2dUYmNjQWF0ZVpiVmJoaEpneWVFZmhjOGVWZ1lnQWdraHNjT2hCYmxlM2RQYWxmbGZZZExhRWQxYmVkSmZtYTVhOWRjYzNmMWdQY0diaGJZZU9kVWZIYlZnY2dHYVZkSWNZaElhWGZCaGFiUWZtYjlkaWNaYm1ia2VVZmNka2U1aHpiRWhCZmtmMmhCYlVkZGdXZkJiaWFnZW1nZWJ6ZjhhRmRNZVRmQWJlZVJhaWNjYlJlZWVFZHhiQ2FjZFFhMWNmYWVoQ2FWYnJjVWdoY1JmeGVSZWhjTmQ0YVVnMGY5YmthYWFsZk1oUmFYZlFjdGJLY1VibGcxYnZmZWFsaHBna2JTYVNiRmZLYWVhbWJkZkxmQmVXaGNhVWhIZVVlc2daZFJiR2JGYzdmZmMzZDliRmNSZG1kY2NXZ0Vja2J4YTFnU2NoZUJkU2ZSZkFidGN3ZVVhZ2R3ZlVkSWUyZDFhaWVhYVhkSmFUZmNkeGRnZ0RiVGJVYzljWGVGZFZmWmdnZWRmQmE1ZXdhVWUyZUZoRWFRZjBiSmhmZEVkWGJOZk1kVWNYYWhod2JWYW5hUWZQYWFkMWRJZ1VkZWZRZ2hnb2FPaFZiaGRFZ0dhV2RwY09oR2VRYUZibGJIaGxhbGRRZ0VjamhWZU9hZmMyaHRldWZTY21jUmM1Z1NmeGJSZ3hjSGJVYThoSWZUZlFiTWhtZ0llSGZaZTdjUmdVZVphbmRGYmhlSmRNaGRoVWZvZFFnVWJrYlFjWmNjYkVhZGdmYWNhbWZJZXVjUWJ4ZFJkeWNUZW5kTWdRYVRlRWgxZ1JmU2FSYlZiT2RhZVdjc2hZZGVmRWdraDdhVWNWaGRhT2dmaFViUWNJaEdnRmE4aDdmT2FCaGNjbWViYUNjUWZXZVVhUmZBYVNoR2R5ZXBoYWZNYm1oUmUyZlRjeGhraEJhZWZRZXNhRmJWZWhib2h2Y1BlRGJCZ1BnTGJRYUlibGFLaHloaGFiaE5mVmRoYjhmR2VSaEVjRWNkYUdiVmMyYllkbWRZYjdmWmN3ZWdiTWJUaEdlRmhEZEdkVmg1YnVmQ2UzaEJkYWRRZm1hOWZpZFpibWVraFViY2hrZzVjemNFZEVkeGVGaEhkemFKY1VmUmdXYkliSmVHZEdiMWZCaFpla2FSZWZhVGVuY01kUmdQZEViVmFZZVVkbmZCaFdlZGFBYjllcmVVZmhlUmV4ZFJiaGJOZTRkVWYxZlZka2VlYTFoTWdFZkRibWEwZkxiRWJWaFljVWRmZ0diMWFrZFFmV2Y1Y0tnWmZIZ2xmTGVGaEhkRWhkZUhmVWIwYVpkVmVuaHhnbWNPY1hkTmR5aGJoR2NjZFdmRWhrYnhmMWJTY2hlQmVTZFJiQWJ0YndoV2FraEpldmdZYW1mWmJoY1FlUWFrZ2FhZmhWZU1kRWZEZ0FiTWVxZVdoZ2FvaHNjRmVVZ3hoNGRFZzNnMGRzaFNibGZKZXBhRWZXZ0pnY2ZXZUhkZ2dzYWZlSGJRY1BnYWExaElmVWJjYVVnWWVUaGVkRmFOZFBhWmFHZ3BjVGdHZFJiTmc0ZlhlaWhJYkNmSGREYmtmUGZKYlJoTWhOaEJnU2VBZjhiS2JrYUJkNWNUZHhlMWRHZkdoVWZkYzllRWgzZFpidmRjZzBnWmN6Y0hieGdJaFFiWGUwYW9hUWdVZGtmUWVMZGNhRmdwZUNlYmYyYkpkbWRhZlJmUmN5Z1RhbmVNYVlhR2RUZllmRmFSZTFmWWRHY0tnQ2haZzdmUGF3YlVmeGVNZUJoNWZHZUpkeGRGZTRmVGVFZk5neGVEYVZnWmVxZEVkV2R0Y0FkSGJYY2hmS2JPZFhjaGdUaFRmMmVSZnFkVWN4Y2tmVGFjaEFldGZaYVZoaGVKYTZlVGh5Y29mNmhMaDBhRmV2ZkJnRWNzaEpnY2ZSYlZmU2RUZlFjZGZJYmRjSGJaZi9iY2UyYmxhR2JkYVFoTWdIZFJnWGJsaGdhRWhGZkpiRWdDZjNnQmFhZFFjbWE5aGlkWmFtaGtmVWJjZ2tmNWQ3aFhmamVjZ01lV2FrYUpmb2dUZ25oUmQwYkNibWJWYlVoZGhGZGRjS2NBZ1hjd2ZZZGZiMmVaZFJkZWRIZUJkV2RkZUFlOWZyYlVnaGhSaHhkQ2hEZGxoNGRVYjBkOWZrYmFhbGhNYlpmRWczY2tjUWJjaDFoWWZTZ2Vha2dkZWtnUWJUYk5oZ2JaZUhnbGJMZUZnSGFFZGRiV2F4ZmhoWGVGYVNiQWJuYk9jVGUxZXZmRGhtZTlnQ2NHZzBod2d1YllhQmhCYVNiUmRBZ3Rnd2hXZGtkSmJ2ZE1jQ2FNaDlkUWFTZUFoQWFjaHhhaGRtYlRiVmNGZ0pkRmhVZjVicGVkYkJlaGJ3Y1FoVGhVZ3FkUWJoY3BkMWFEZTJlMWdNY1FkR2RCYTVoVmRuYklhUGJmYlVhRmhwaGNmVWMwZFRmT2RTZ2hiSGhNYUdocGhOaEJjeGFOZ2hoR2dWZEJjV2VGYkhkcGNSZmRkemZ4ZHVmUWZXZVFkNGdNY0Jld2RsZkhjUWVOZVRlR2FVYkJnOWZiZ25oQmN6Z2VnVmJVZGFnRmFoZGxiTWNOYURhRWNHYVFkVWNRY05iY2FBZDRmL2VSZFdoSmFtZWFoUmdSYnlkVGVuZE1kUWJSZ1ZlWmI3ZVNhUmNWYk9iYWNYYlFjWWdMZldldGYwZ1VjVWFwZU9lZGVSYUVmMWdHZFJnOGg3ZEphQmc4ZTdnUWFXYnNnY2FIZkNlVmRLY0VneWJwaGZlVGV5ZjFnamFVZjBkSWY1YmNmQWZ0ZlpkVmRoZEpoNmNSaDJoUWRIYUliUmFoYmtnY2dSaDFiVmVJY3hjMWFZaFFnUmNrY1pjZGJIZk5hMmZDZUJnSmNLZFpmMWVnZlNoVWdYZlVmWWFDZzFkSWNOZUNjMmY1ZGFmRGZIYlJhaWJLZUdha2dmZGJmMGM1ZmdmR2JXYlpoTmJVaFVha2hWZlRnbWdsZTBjR2RIaEJjQmVmZUJmUmVLYlVoM2VVZlpnSmd6YmNjZmNCYlhnQmVLZWFoQWU5ZTZkUmRCZDFmeGFUZFJjTmR3ZEJnemRRaHFjYWFsZGdlWmRBaGdnMGhMZ1JnVWhvZlNnWWJraDVla2dTYm1mNGFlY0hnemFkaExiSGIzZEVkUGhZY0VjUWVWZ1Znamh0ZGdhSmVpYVlhOGZEYW1kOWdlYUdmZ2hsZzhnUWh3ZHRnNGJSYUFidGd3Zldna2ZKZnZnWWdtaFlkN2ZVYVNhWWNiY0lhVmg1Y01kQWJsZDhjRGZXYmdoY2huZGZkQmRwZnlhU2dHZzllN2dTZ2tkNWUxZkVnWGVOaE1jRGZGYUphd2ZWZW5lUWNQZWFoMWVKZ1NoSmdBZ2hkUWdMZUJob2dBYUtobWRvY0FlRWNVY2RkNWJDaHdlSmY4Z0VobmhwYkhiWmhFZkZodWhTYW1iUWQvZUJnRWhaZHhoRmZUZmRhTmNHZFZlWmIwZGJlbmdaZnplYmEwZFphbmhRZEZjTWZlZmRiUmRnZWNjZWhFYVFkTGhjYkZocGNDZmJmMmJKYW1oYWFSYlJjeWFUZWplb2NRZVVjVWMwZ0ZiUmgxZmtoTGdKZnpiTmNNZk9kRWIxZ2VjVWdVaHBnT2JkY1JmRmV6Z1RnRmdGZDRnY2FGZVpjMGhTZW1ndGhQY0ZkRGRoZ0doRmVuYmhnQWZRaDBnNWFxaFVleGdrYVRmY2JBaHRhWmNWYWhiSmU2YVJlMmdRZU9hYmdsaGRla2JlYTBna2RZaFdheGQwY2RiVGhSY2xhV2RkaEdlNWgyZ2NiMmY5Z0dmWmYxYjRkU2VVYlhkVWV4aGJhVmM1YXVoQ2IzZ0JkYWZRYm1lOWVpZFpibWdrZlVlY2drYzVhemJRZjBneGRRZVViVmRnZkRhWGdYZEZjbmNGZUZjcGVCY2RlRmhGYktiVGhuZVVjUmFjYjBkeGRSZWVjSGRBY0RkZGNCY0pjcmNRYmhiaGNiYVJmaGZOZzRkVWQwZjlia2NhYWxhTWNaaEViM2dBZkxnSGUxZVlmUGhlY2dmNWVrYlRnR2g0Z1BlZmUxaE5kTGVGYUhhRWVkZEhjVWcwY1phVmRuaFJidWZNZEhoTmF4YlJkamJJYk5nT2NFYnhkMWNTZWhoQmJTY1JmQWZ0Z3dlV2VrZElhNmNZYW1oMWMwaEZnQ2FGYWtlY2J4YkJlTWZUYVZjRmRKYUZjVWQ1YmdiWGFoaGhkd2NRZlhiUmhSZVNka2I1ZjFnRWhYaE1jRWZYZHlkZ2NsaEJjVGF3aEhkSmdWZXBlQWFmZFVoWmhHZmRmRmZNZ2FlWmZHZkZjVGNTZWhiTmN1YUNjeGQ5ZVdkRGZYZW9mQmNaZUZjdGJ1aEhmMmJSYXlhU2UwaGRhNGVGaEFoWmNuYUdhVmJaYTBjYmNuYlpmemFiYTBlWWYxY1VkMGZZY1pkSmV3ZFFoUWZXYW1hNGVMZmNiRmhwZUNmYmUyaEpmbWVhZFJkUmF5ZVhkM2VNZ05hVWhWZEJhUmFEZERmOWZPZ2FkWGdRZlloY2JFZ0ZoMGZVZlVlcGhPYmRmUmFGYXNnVGVGY2xjd2FJZ2xnWmFwaERjemM4Y3BoWGVYZUZlTGFFZzJma2R1Y1JnbWVoYUFoVWV4YWtjVGVjY0FmdGFaYlZkaGdKYzZnUmQyYVJiQmZiZ2tocGFzYk5na2NzZ2ZiYmNCYTFmY2JOZmtndGJXZ2FnbmhCaDJjWWRSZ0plUGNhZ3pid2FTY1RlSGVWYktnRWVGZ0plRWFDaDNlQmdhYVFnbWI5ZmloWmhtZkZjYmNjZ2tnVmV1YUVoQWcwZDJiV2RSY3NnVmJVZW5mVmYwZURoSGdsZkJkY2dsYUZnY2NYY1FjZ2ZZYWZjMmhaZlJmZWRIZkJnV2dkZUFoOWRyYVVmaGFSYnhmUmhoYU5kNGhVZDBmY2FyYmFjbGVnZEVoRWUzY0liV2JSZUZjUWViaGNhMmcxYmtlUWVXZDViS2JaY0hhbGNMZkZhSGdFaGRmSGRVZjBlRGVWZG1oWmZ1Y2FjMmQ1ZXlnUmVpZkllV2VGZUVicGZmY1NlaGhCZFNiUmFBY3Rhd2ZXYWtiSmJ2aFlobWJaZ3BkRmVIYkpjR2NlYjBhSmVNYVVoRmVGYkJlUWVUZlVjZ2VkZUJiVmR3ZVVkd2FsYlJlVmVsZkpnMWVDYVhkcGFNYldhbmVnY2tiTGJUZDBiUGZaYWxlSWFGaERhRWE4YWZlVWJsYU5iUGRaZUdmcGRUYUdnUmVOZndhQ2ExZ2xjV2dFZG5mcGNIaGJnQWQ1aHVhUWdYZmxmNWRDZW1mOGFqYkhkUWdOY1RhR2ZVZ2Rla2VFZTNhOWUvZVJhVWJaZW5oRmNoYkpmTWdkYlVhb2hRaFVia2dRYkxiY2dGaHBiQ2RaYnljMWdtYVlmZ2RsaHlhRGh3Z2dmWWdIYWtkMWdQYlZieGJWZWFhWWFIYVFmZWdjZkZiZGVuaExoRWdOZUNjWGN4ZkZhemRUaEZkRmg0ZGNnRmRaZzBhRGcyYXRiU2ZGY0hiRmFHYUdkemRkY1RkUmVIY2xmcWNFaG1lSWNiaEloZ2Z0ZEZhU2FoaEplb2NUYm1mUmFIZWJlbGN4aDNhQmhFaEljWWNXZnhnMGJkY1RnUmhsZldoZGdHaDViMmVjZDJjOWNHZFpieGJZZVNlUmhEZHBlS2NHYzBhOWdFZ0NnV2ExZVllU2gyYVpidWVUYUdia2dVZGNma2E1Y3phRWVFZ3hnTmVVZlVibGJkYlFiRGFrYmhlU2d6Y2hiSmJPZTFoaGJHZlpoSGNVZVJnY2IwYnhiUmRlZkhjQmhXYWRjQWU4ZGpnWGNGZzRiK2dEYjFmMWF3YlVjVWMxZHRhUWhGZ01kWmRFaDNlQWdMZ1dkVmdZZlNmY2ExZHhnT2VRZFdjNWdLZVphSGRsZUxnU2RWZHNoZGJIZlVhMGJaZVZibmJSZ21jSmVIYzBkdGhIZXpkTmFUaGZkZ2ZrZzdkRGNVZlFjYWhSZUJoWmZ3Z0hkMGh0aGpmWWNtYjRmN2RHZWliWWdCYkVhVWRrYlllQ2JEYkFhYmZSZndmOGJ3ZmRoQWFWaHdmRGhuYjFiZGJTY2tlWWJuY0hlemFVZmVmSGNqZVVhU2VEZXllQmNLZENlZ2NCYUdnTWFCZDhhVGNaZFZlTWdjZmJiWGNGaDVhR2RSY05od2ZDZTFkbGhXZ1ZlRGdVYVZhWmhFYmxkRWJTZ21oUmc1ZlNoeGRSYXhmSGNSYzBhYmRXYUFhUmgwZExiM2RaZ3VkYmZ6ZDBjYWhHaGpjaGRNYWRmVWZvYlFnVWJrY1FlTGRjYkZhcGRDYU9nbWNKYzdhYWZXZDhlUGJRYmxha2FRYlRnRWExZVJlU2dSZFZiT2RhZ1hnUWNZZk5na2ZGY3BkVWRVY2dlYmZPZzFkVWIyYkNnaGhnYzJmTmJSYkplMmJEYzJocGRQZ0ZjQ2hVZmZiUWR6ZTBkY2JDYVdiUWVmZkdlbGRkYkhoYWFHZW9lTGFCaEZjTWhqYlJmM2d0ZkJnR2d3ZU1lcWZMZlZnTmQxaEllMGM5Y2NlRmdCZ2xjTWZkZUFkOGhraElkU2I0Z2ZiYWN6Y3doU2NUYkhkVmNLYkVjRmdKaEVoQ2QzZUJoYWREZ21kOWEvZ1RjR2hrZFVmY2JrYjVmemhFYUVoeGdOZ1ViVWZrZlZhVGFtY3NkVmZlY2hnTWhsZUVoVGRjY3RnSmhoZXhmN2NHZkNhQWM4YUZkaGI4aG1oQmhYZjBnWWJKaG1iRWRIaE1iV2ZzZ0JlS2FRZjRjbWFLYlJoZGZjZFZoVGJkZkRkRWVCYnhiWmhOZWdob2JxYURoamU0Y2JiTmJpZ29nZmVRZ1NnZGNLaFJlUmFSY0RiUmhtY1ZoOGZaaFdjZGg2YlVlSGhBY09jQ2gwYmRhNmFTY0JneGE0Z1JiQWd0Y3dlV2VrYkpodmJZZ21hWmhwYkZjRGNGZU9iYmFoZUJiY2NRZFhndGNKZEZjVWc1Y3BhZGZCYWhmd2dRYlhlUmJSYkdna2Y1ZG9kRWVUYTljQ2FIZ1RkMGUrYkVjU2ZCZkhjY2FIZ2dmVWFjZlVhWWhUZ2VjRmVOZlBkWmVEZHBiVGZCZ3hnTWh6aEVjSGVOZ1dmRWNuZnBmSGFaZkVnRmh1aFNobWI5YXlhQ2ZEZTVheGNIYVJiMWhOZ0dnVmRaaDllUmRIYlpmemhiZDBlWmZuZkZlaGJKZk1iZmFRYnRlcmZFaFRja2NMZWJhVmdvZ09oRmRDZkVkYmNZZkJjaGJ5aFJnaWZaZ3JhQWJFZU1jU2VBY1ZmUWNjZENiamd0Z2NkTmFTYkFkZ2ZXZVFlbGZIYkNmQmRGZHVoVGVCYUpmeGNhZTNjeGYwYkRmMmZ0Y1NjRmdIYUZlT2hSYmdmTmZSZlFobWdaaGtlRWVGYkZnU2NJY21jZ2NXY0VlbGdjYWJlRWIyYXhkUmVaZ3phZGZrZlphRWZzZENiWWV4ZFFmUmhUY1JhRWhEaERkMmh3YUpjY2RXZ0VkRmdMZzFnZGdBZExmemRvZ09mVmJUY01kUWFBZzJlQmJUZVBkMmE5Zy9hWmJuYThiSGVlZjFhVmhaYUVoRWZ4Y05lVWdSZVFkWmFaZEdkbGUwYUdhSGFBYkhiSWZSYjhmSmJHaGpoeGhlaFBoVWV4YlpjTGZIY3hnV2JKYWdjWmFyZUNkVGg1YnhmUmRoZk5mNGdVYTBlOWFzYU9kRmExZExlVmVqaEZkUGZXYlVlc2RTYVBkQmJJZ3FjQWVqaG9mRGZLZ3piZGhMZUhhQ2hVYVJoSGFSaDhlVmdWYmpmMWRpaGRiamNaYWplUmFpYWdhZmZFZWhhZGhmZlNkaGhCZVNjUmVBZXRjd2dXYmtlSWE1aEliemZSZ3BkWGRIYTVka2VjYnhhQmZNYlRjVmRGZ0pjRmNVaDVmcGdkZ0ZhWmc4YmFjM2FSY1JoU2RrZjVjMWdFZVhiTmRNaFVoWGRnY2pjVmhtaGtiUGZjZzFlSWZlZmNjUWRrZlRiZGJWZk1lS2NaZEdoZGZUZENhQmQ5Y2FmQ2IxZ2xiV2hFY25ocGJIZFpoRWRGZnVnU2RpZFZkNWNWZWhhUmU1aERnQmIxaFJkQmhWaFlobmNaYTNhWmUraGJiMWFkYXJkUGZCYkpjTWNkZlVkb2NRZVVma2dRY0xhY2RGaG9lWGZiaDNiOWJtZEtmQmZSY3NhVWVIZk1hQmNRZ0djZGRSY1NhUmRWYk9jYWFYZlFkWWRjaEVoRmQwYkZnMGdwZlRlZGJSZHhka2NRY0hodGE0ZWNmRmhaZjBkRGYyY3RiU2hGZEhoRmdHYVhkM2hoaE9oVGR5ZzFhcWVUY0JibGhjZmNiQWdaZFpmUmJ4Z0pnZ2hSZzNhUmdOZFJnRWNwYmtmZWJVY3NnVWdjY1JoMGRkZ1RjUmVrZFZkZGVIZ05kMmVPZG1iOWNaY1pjeGdzYkRjVGJHZjllS2ZBZFZjNWF1Y0NhM2dCZWFmUWJtaDliaWdaYm1ka2hVZ2NjaGE1YnplRGJVZHdhWmVLZWhmc2RWYVJlV2FrZjRnWmFXZHRocmhkY0ZmRmJLYlRnbmZVaFJlY2IwZ3dlWGhOZnlmSmVXYWZoQ2ZWY3JiVWhoY1JjeGhSY2hoTmY0Y1ViMGI5Z2tlSmdsZU1oU2VEYW5oQmJJZlZlVmdaZ2FoZWhsY3Bia2NFZ1dkNWJNZlpiSGdGZ0RhQmdYZUVnQmZBZVVjMGdVY0VkSGYxY3VjZWczZE5jK2hUYTJjc2NXaFFla2h4ZnJiVmdBYTFnU2RTZVVlMWY4ZVdjZ2FSZHZlYWdYYXRlcGZSZjJmbGJrZWNheGFCaE1kVGZWYkZmSmhGZVVkNWhwYWRnRmU1ZndmWGMzZ1JmQmFVZVdiUmIxYUVoWGNOYU1nVWRYaGhhd2hWZG5kUWNQY0llMWZJY0pmY2hWZFFjR2JiZGxnTmZGYVphQ2ZKZFRmRWhoYk1ia2FjZEFjdGdXZ0dkWGRvY0xhR2dVYzFldWVCZG1lUmN5ZVZmaGhRY3liRWVSZDBkTGhHZVZjdGJwaGJhbWU1YVpnYmYwZlphbmZGZmhoSmhNY2RhVWJvYlpnU2RXZzRiTGNjYkZncGdDYmJjMmdKZ21iYWRWY0ljOWRIY0hjTWFZZVpha2IxZFJnU2ZSYVZoT2JhZVhkUWhZZWNmRWZFaDZhVWRWYmRkT2hQYVJmRmIxYVRoRmhsZHdkWWZWaFpjb2RFZjJmdGZmYlVibmFoYkdjSGhuZmhnQ2hSZG1naGNxZUdheGJraE5oYmFoZlplWmZXYzFoUmQyZFJieWRKYkJiWmRWZmRia2dQZEZnQWgrZGNhUmIwZ2RjVGRSYWxlV2hkaEdlNWEyZGNoeWdsZ0doZWVSYVliQ2RWYTFjOWFLZkVmRmdKY0VmQ2EzZ0JnYWFRZ21iOWRpaEtnR2VrYkpmY2ZsaHhkbWNCYWtmeGhIZ1VoUWRjYlZjUmNXZWthZ2NZaHllSmZCZWZlMWhFYkdhTWIzZWtmUmJQaDBkeGdhYlpnWGhBZVZhZWJBZjhhdGVVY2hhbGVzZVJoZ2Z0aFNjVWMwaDlla2hhaGxnTWVaYUVmM2VBZkNnUWduYXdjU2ZlYWtjZGFrY1FhV2Q1YUtlWmJEYUFlTmJGYUhja2NOY0hjVmJBYUVmU2IzZ1FkbWFmYTNkTWNuZlJnbmNvaFdnQWYwZ3hhNGJTZmthVmNKZmJiZ2J0YXdjV2JrZEpndmJZZG1kWmZwY1VjVGY0ZmRnTmFoaEFmWGdaZDFnRmFKaEZlVWg1YXBhZGRCZ2hnd2VRZlhjUWZZZkRmRWY1aDliV2RYY05iUmVUZ0dnVmV3YUZoM2cwZ1BlT2ZSZ2RmQWRKZEJmUmZkZGVkQmgxZ1BnZWQyYnBhRGRHYlJneGZ3YUdhMWRsZk1lRWhuZklkWGJaZkZkNWV1ZVJjM2JWZzViVWZSaFJlZ2FGYkJjMWJIYUdjVmQ1YmxoYmZuZmxjemZmaDBkOWI4Z1BiQmVKZ01mZGhVZG9mUWNVZmtoUWhMZWNlRmNwYktlSWJXaEpldGhkY0JhUWhmZURieWVkZllnUWFoZTBmZWJIYmhoMWZjY1piWGVSYmRiZWVVZWhiNGFVY1VnSWNHZGRkUmd4ZHVjVGVBZlJjeGVhYjNoeGMwYkRjMmN0YVNkRmJIYkZoR2hFZ3lhVmQ1ZlRmMmhSZHFmVWd4ZGtlVGVjY0Flc2JMYkVmMGJZYXZjRmdTY3BnQmhaaGhncGdrZVpia2VzYlpmWWhCYTBkSGhUZFFnaGJmZ2RjR2JSZzJhUGJXYjliTWNaYTNjdGNUZkdnRGYxZ0VjUWZCYjBlVGJBaDJmSmNXYVFlaWRkZmlkYWUyaGxjUmNlaDFiVmVaY0VjRWZ4ZE5hVWFVY2tlVmVFZjJnQmI0YU1ibmRCY0JhZGFGY0ZjS2FUYm5jVWVSZ2VheGE1aGZmTGN5aElhZmZJYkVmcGRyYVRieGJRZjNoRWMxZDBjN2JCZndhWWZyZUpjRmZNY1JnUmEzY3dmTGZDYjFlb2ZTZE1kMGV0ZWtiQmhHZkpiS2NLZTNjVmJMY1hiSGVnZWRhUmdtZGNjWmdWYW5hUmR1YmRmbmJOYnZiUmVtZWNjV2JSY0FnMGduZFNobGQ1aGVoYmVnZ3Rjd2RXY2thSmh2ZFljbWhaZHBlRmhIZUplT2NjZDBhTmdBYlpoMWhGZUpiRmNVZTVhcGJkZEJnaGJ3Y1FkWGFSYVJiU2dnYzloNWJPZTNjTmVNYlVkWGdoYndkVmFuaFFjUGNhYTFhSWNVYmNnUmhNYlRjWmJWZk5nWGJaZkdkQmdUYVVoUmFOZTllQ2Z4aFpjV2FIZjNhcGhXaGFlR2Z0Y3VlU2NtZlJjNWFTaHhkUmJ4ZkhiUmcxZk5lR2RWYVlkeWRiY21hdGV6ZFpoMWJkZm5oQ2hnZzVjTWdJZUVjTWVRaFhmMGRRYmFjZmhIZ0JiQ2RiZjJiSmJtaGFiUmZSY3lmVGduZ01oUWdUZUVnMGRkZFNjUWJoZU9mTGQzaFFoR2hiZGtlRmVsY1hjV2RCYU9kZGVSYkZhemVUZUZlRmY0ZmNoRmRaYTBhRGcyZnNhUmJGZUdieGZHYkFkV2d0Z1RnVWFuZWxjM2FVZDFiWWhUYmJod2RzaDBnRmEwZllheWhTYVRkUWdPZE9mVWFKYjJjZGZVYnNoWmRZZHdoa2ZVZFRiUmVSaFdmR2NTYjhkaWRPYTJiRWZXY0tlRWhFZ2FlWGRuYWxhS2RIZVVhVmJUZUFnbmZCaEFkUWNuYTlidWZUaEdoa2hVZWNha2c1aHplRWhFZ3hoTmVVZFVma2hWZFRkamdsYzBnQmRYZEFkRWFkY0VnNWJLYlhhbmRVY0xmY2V3YVJlUmJkYVhlQmRIY2VoQ2ZWZXJkVWRoY1JjeGFSY2hnTmI0Y1VkMGM5YWtlYWdsZE5hVWJFYjJoMGNMaEhmRmNZaE5mZWZsZ1pla2ZXYjJhNWFIYWRoWGZWZGhiRmRIZUVmZGNIZFVjMGdaaFZnbmVSZnVnZGNuZE5jdmJIaDJjY2NMZEVnbGd4YTFnVmdCZ0FjQWhSZ0ZlY2RzZVdha2ZwZy9oWWduYXRiMGJDZlhiSWRjZ2NkeGZaY0tiVGZVZUZiSmRDZDBmNWg0ZGRmQmJkaHdnRWUzYjFhUmFWYlVoNWVrZ0ViV2JsYU1lUWhXZk5oYWVWY25kUWZQZWFmMWVJaFVlY2hVYVljVGZlYUJkVWRBYk5nbWdwY2JhTWF4Z05md2dDYzFlbGNXZkVibmNwYkhnWmFFYkZjdWhTY2pkWmM1YVZjaGVRZGNhWGFFZGtlRmFGYnhlY2QyaFBnWGM0Z2hiWmZrZ3BhTmhGY2hjSmdNY2RkVWVvZlFmVWFrZVFnTGNjZ0ZkcGNDZWJoMmZJY3ZlT2RuYW9oemZJZUhidGVDZ1JjVWYwYk5hRmJSZlVjY2JhYVdoa2FGZGJoVWZGZ2xoVWdVZVZmT2VaZFRmdGF6YlRmRmNGYjRhY2JGY1poMGFEYzJodGNTY0ZkSGRGYkdhRWUzYWhjVGFVaEdmUmhpYVdnMGJvZlRjYmZRaHNlUWJCZlhid2Q3ZEtjV2F3ZFRkWmMwY3BlN2FlYlZkb2hVYmFkeGQwZk5kUmVCZFZoV2FmZENoQmYyYmJnbWI4Z0FjYmhoYThkNGJUZEhkVmFLZkVmRmRKY0VlQ2gzZEJiYWhRaG1oOWJpZFpkbWJrZ1VmY2NsYVJmemNHZ0VoUWVEZlVnVmVRZFZjSWd5Y2djZ2FVY0hkNGNIY09kQmQ0Z0ZnSGdIYjFkOGdNYWhkZ2VaY2RiamJ3Y1pmTWJ3aGNlNWVXZ3hlUmcrZVJobmg0aDVkQmV3ZGRhcWRCYmpiMGJMZUdkbmFrY0hhY2YxaFlkU2ZlZ2tlZGFrYlFjV2Y1aEtjWmFIYmxoTGVGZ0hlRWhkZUhkVWcwYVphVmdpZlpidWhmaEhmTmRuY0JlMmdjZUxnRWdpZUVjMGRIY2xiaGJjYUZnRWZRY25jVWdsZUJhamVZYm1kc2duaEhjWGd0Z09kYmh4ZUJiZGFUYVZjZGFQZUZmVWNZZ25kZWNSZVZoOGZRZVhkd2VRY1Nma2JSYW9hRWdXZEZkRmNXZUhlUmdhaFZjbmNRZVBoYWgxYkljVWVjY1VjWWVUZWVnRmFOZVBnWmZHZnBoVGhHYVJkTmN3ZkFld2R0ZldjR2JXZmRkSGZLZGtoRmZsZlNjaWVoYzVhVmVRaGxoeGdEYUJiMWJTY0dlUmRWZTBiWWZYaFlheWJiYzFkeGhuaFZkUmRKaEdhZGNTaGRoUmNCaGdid2VGZUlhQmVVY1ZkWmYzY0JocWFhYlFoVmh5aFFoM2ZOaGNnUmVVZ1JkZGZZZ3hnVmNPaGFoWGhRZ1lnY2NFZEZmMGhVYlVjcGNPZWRjUmVGZHpiVGdGaEZoNGZjZEFhUmgwYUJjV2RzYVRiRmZHZDloYmVFZjJhcGRUaFNnV2VKZHFiV2MxZmNhWWdlZndkZGNaY1hnbGVOZDZnU2dIZGxiQmRmY0VkTmd0ZWRiV2hFZlVjY2JSZzBoZGdUZFJlbGFXYWRoR2U1YTJlY2MyZTljR2haY3hoWWdTZlRhSGRVaEVhRWdGaGxoRWVSZjNhQmdFYlhjMmc4ZWthVGJHZ2tlVWZjaGtoNWd6Z0VnRWh4Z05nVWhVY2tlVmJUY21jbGMwZEdiSGRCY0JjZGhGZUZhS2NVZFhoVWhaaGVkeGc5Z1JlWmJYZkJmR2ZmZ1FkTmhyZVdibGdwZ3hoV2J4YU1mK2FXYWthWmFPZ2FlbGFNZlpjRWUzZUFnTGVXZFZkWWRTZWVma2FkZ2toUWFXYzVlS2ZaY0hkbGFMaEZkSGZFZUhkSGZRYk1jWmNYYlhiUWJpaGRnbWQxZXlmUmFuZVliOGRFZmtjeGMxZ1NjaGVCaFNnUmFBZXRnd2VXYWthSmZ2ZVljbWdaYXBkRmNIYkpjT2RjZ3hjQmVUaFRiVmJsaEJlUmRrZjViMGJkZ0JjQWhpZ1FoWGE1ZFJnQ2MwZzVkNGZFaFdlSmZGYVViWGhKaHdoT2F6ZVZjYmFJYjFieGRFYlBkaGhFZ2JnYWFsYzlkUGRLZzJmTmJhZEZoUmdOYjRjUmJWYWxlZGREZTNlb2JMYWJlVWVoZ0VmU2VtYVJjNWJTaHhlUmN4Y0hnUmMxZk5lR2NWZVplMGZiYW5iWmN6YmJlMGZaZG5mRmRoYkpiV2FkYVVnSWJZZkFoVWZRYVdkY2hBZGhnQ2RaZVdnSWdMZUtlRWRBZDZlUWJDYU5oZmFHYjBiVmZEZVJlUmFVY0NkYWFYaGtnWWFZZVVmaGQwZVdoMGFvaGphTmhFZlVjN2ZRYWdmRWEzaEpmMWI1ZG1oQWgyZnNhZGFIZlhkaGRLY0VnM2NBaGRkVGIzY2xicWhRY3hjQWhhY2VhUmJCZ3pjVmFoYUpkNmhSZDJoUmdCZGJla2ZwZ2tjZWJVYXNiVWFQZmhnMGZEZVVkQmNsY09lYmEwY1JlMmNjZjJkOWJHZVpjeGZZY1NjVGZIZVZmS2NFYUZkSWRRZmNoRGVsYWFjU2dXYThleWJHZDJna2NKaGNjbGR4Ym1oQmZVZnhmTGJVZVJmb2ZaYlRkamRsYTBmRWYyZzFhQmVPY1ZnMWJLYUhjWGhVZWVhYmhrYXhjRGhiZldiWmRhY2RjRWNCY3JhWGR3YmxkeGFYYmpmbGY0Y1VkMGU5ZmtkYWdsZE1oWmhFZjNoQWhMaFVoRWgwYzRoZWhrZWRha2NRZVdiNWNLYlplSGdsZkxlRmhEaGRjU2hUYjBkMGJSZWZiSGVSZXViZGNuZk5idmdSYm1lY2hXZ0Vja2d4ZjFnU2JsYTVoU2NXY1FhdGg0Z0ZkRWVKZ3pnZmJtZVljbWFIZlhmSWhTaGNkMGhOYUFjVGJRY1JkSmZIZ2xiTmRwZ09kd2dOaGFlUWJYZlJmUmFTaGtmNWYxY0VlWGFOZk1lVWZYYWhjd2JBYTNoUWdSY2FlMGVJZlBmV2MwaFlnVGNlZEZmTmFQZVpnR2RwZFRhR2RSZE5kd2hDY3dlMGR0YldhM2RwZE1lWmVCYkVkVGhTZ25kbGE1ZldkUWZGZ2thSGVSZXRjTmJWZTFjcGUwYlBjbmVaaDRhY2JrY1locWZHYmhjSWZDY2RoVWFVZE5kVWZsaFllZWNaZmxkWmRDYk9hbWVKZHJlZGVCYVJlcWNaZUhmTWZRZFRmRWcxZ1JnU2ZSZFZnT2JhYVhmUWJSZGFhMmd0aDBnVWFVZnBkT2RkaFJmRmR6aFRiRmdGYTRkSmFDaDBhOWJEYzJlQmZTYlJlSGVGY0xiRWh6aFVmdWhUZnpnaGQzZ1Vod2ZnYUJmYWdBYXRjVGRWY2tndGdoZWJjV2VSY0JhYmZrY3Bka2NlY1Vlc2JVYkxiQmVRYkdiWmR4ZmxnV2VkaEdmNGNyZGZjMGhWZkdlWmF4ZllhU2FDZmlhQWZFY1Vkd2VZZE5oUmJEZDVkYWRTaGpkdGFyY1pnamdJYStnY2RraDVhemdFZ0VieGdOaEJld2ZoYkhiVGFqYXRlMGFCaFhmQWFhYUtjVmE4ZWVhQWFRZFpjRmJJY1FlVWJmZ1BkMmd0ZjhoZGFBZjllcmRVZWhoUmh4Y0VoaGMwYTliQ2Z4YjhhcmhPYkFmZGNLZ0VkMmYwZGhhV2ZWaFlhU2RlZ2thZGZrZFFiV2U0YnJmTmNpYXNiS2hUZVhjOWhVYVRjaWF4ZkxnQmREYlVhM2hkaGljOGR6ZWJmR2NjYVdnRWhrZ3hjMWRTYWhkQmJTZUFibGE0ZCtoR2hSaFljbWVMZFNnaGZwYkhlQ2NaZUhmY2YwYXRjbWRUaFZoRmJKZ0ZiVWQ1aHBlZGFCY2hod2hRZ1NkWWJVZkhjaGZzZW5oWGEzYU5hT2ZLY2plY2Z5YkhlRGhGZU1mUGQxZ0pkMWVJYXhiUmFTYklmU2E1Z05lWmdIYmRiT2NHYVVoRmQraFNhQmFnZWFkWGVuaElhVGZiZFZicGZFZFNobWJSaDVnU2Z4Z1JoeGFIZVJmMGdRZkFobmR4aDBoYmduYVpjemZNZGticGVOZ0ZmaGhKaE1lZGdRZHhlRmFIaEFoZGhmY09lUmRVZU1oYmcyZW9meWRaaFJoUWVnZlJjM2ROaExmWmNrYzFnUmZTZFJmVmhPYmFiU2FKZFplSWRrYkVlOWNYYVVnb2NMZmJiamN0ZnpkVGdGZ0ZkNGRjZEZjWmYxZkJjeWIwZ0hhV2JqaElmU2RXZWphY2NkaFRjMmZ3ZGxmV2doZ2xhSWZXYWdodGhaZlZmaGFKYTZoUmYyZVJnQmZLYkJjOGNxZ09maGg5ZWRmUGRsZE1nZGRCZFJnRWNDaGViR2c0Z2tiZWVtZDhjZGhUZ1JmWWhTaFRmSGdWZktjRWdGY0pmRWRDZTNnQWdJYUJnemRzZjNiTmRDYmNhVWFKYmdkWWY2ZlFhMGJ3ZkVkSGN4ZnBnQmhEYnliY2YzYlhhVGg4YkhhZGhCaGxoZ2FUZ25lVWFSZmNiMGN4Z1JmZWFIY0JoV2FkZEFmOWhyZVRhUmdSZTViVGhrY2Nid2hHZmhneGFxZEZjUmY5ZldlUmhIaEFiV2JXYlVmWWViY2RhbWMxZmthUWVXaDViS2daZ0hnbGRMYUZmSGZFZWRlSGFVZjBiWmdWaG5md2U2Z1BnamRvaDhmU2dCYWhjZWZXZXdhc2U5Z1NnZ2QxZVNkVmNBYkpjOGNjYkVjSmV2ZllobWRaZHBoRmhIaEpmT2hjZXhlQmdNZVRhVmZGY0poSGhSaG9naGhQZlVldGIrZkVnemNFY2NjQ2R3ZGNlN2VWZVRmWWNlaFViV2NWYXdlR2dDYkZoRGZKYzFoc2dZZFdiMGJZYlRlZWNGZE5iUGdaZ0dlcGdUY0djUmJOaHdlQ2ExY2xkV2dFYkNhOGFKaEloQWFRZW9oQWZ5Zm9nOGdEYXhmWmh4ZEFjQWhCYU5oVGFRYThha2NLYXpha2ExZ2JheGVSYU5iRmNoZEpiTWdkY1Vlb2FRZFVla2dRZkxmY2VGZ3BiQ2hiYTJkSmFtY2FoUWJ0aHlkSGdYaDFnVGFEYVFmRWFkY1FlVWVFY0dkSWFDZ2NjVWRjZkJmVmM5YWVoMGRwYU9hZGRSZUZmemRUZkZlRmQ0ZGNkRmNaYzBlRGUyYXRiU2ZGZkhlRmZjZEVkM2hvYkFhR2N6Z1liamVIZVZlNGdSZGNmQmZaZEViVmNrYllkamhGZHliRWRPZEtkRWhvaHdhVWcwaHNoVWJjaFJmMGRkaFRiUmdsYVdoZGFHYjVoMmJjYzJhOWRHZ1poeGRZY05kVGREY1JiRWhVYXhkTWZJY1JnM2ZnY09mQ2RpZVloeGJhYm1mbGVBZmZja2g0ZmhoR2hXZ1pjTmdVZFVia2JWYlRkbWRsYjBhR2ZIZEJkQmNkYkZlRmRLaFRkbmNVZVJnYWdVZndkSGJOZnpoa2FTZmRhRWhGZ2xjRWdWYlVhOWhDY2hnc2dzY0dod2dZYTNnWmVsYk5lTmdIYTNoQmFaY1VnRmY4YjRiZWZrZGRja2VRaFdkNWFLZlpkSGVsZkxhRmVIY0VhZGhCZzBkMWNYZEVleWZOZXVjUGVuaHNhN2dTZm1kZGNFYkdkMWVkZWZmU2hoZ0JlU2VSZ0FkdGN3Yldia2ZJZ3loU2RHYVpjcGNGY0hlSmJPYWNheGFCYU1hQ2R3ZVFiSGFWYmhjb2ZnZ09mMWVaZndoRGczYndhRmNSY2tjNGFuYUdoSGFNZVhiZWYzZmhjd2ZWZW5kUWVQZ2FmMWRJZlViY2JVZlpmQmhQZFFjY2hhaE5jaWdSYlRmRWVVYmNjNGRRY2dmcGNZYWJnVGFZYUloTWUwZ0ZlemVTaG5kUmQ1YkZkeGVRZWxjRmhCZkZkTmhFYlFmSWU4Z0pneWJWaDlhRWhBZjRmdWZVY1ZocGhNZ2FmRWZvaEFhVWZoZWdkTGhJYWxhTmZPZGJhemVZaHViSWNFZ2RmcGhaZEhjTWdRY1RmRWIxZVJoU2FSZlZjT2NOYUZoNGdZaGNhRWNGYzBmVWFVYXBhT2RkY1ZlY2VtYkFoaGRJYXNjT2ZSZ2tnNmhEZXpnaGFhZ1FhSGhoaEdoU2FGaEpkVGZUZDJjUmVxZ1VmeGJrZlRnY2dBY3RjWmRCY0ZmY2J1YUViamVZZlBoYmNrY0lnd2dNYVFoSmVIYmZmMmdKZ1JnQWZrZjVnV2dhaFdjNWVnZ1phbmVwZlZmY2NoaFlmVWdUZkNoRmVEaEhkRmFKZE1nWGZ6ZmdiVGJFZ1dkRWRkZExjaWhCYVRhT2FrYjVodWRFYUJmaGdOY1RkMWRjYkxhVGRuZ2hiaWdFYlhmeGVCYUloQmRrZURmSGZXZzRlN2JjaDBmeGJSYWVlSGZCYldhZGZBaDhkMmZlZ0JkUmJ4Y1JnaGZOZjRkVWQwZDloa2RMZEFoWmhYZ1ViQ2RSZUNhRmVoYmdiU2NPYzBoOGV3ZFRhV2M0YVljYmJYYWtmUWRQaG5kRWZkZUhoVWMwZFpiVmduYVJldWFkYm5kTWU1YkJjemRVY1djV2EwY3hhb2RTYmtnQWJUZ0ZlbGNnZzFkTWJ3aHdjN2FhZWphSmJsYUZoQ2NCZU9nTGEwZHhhTWRYY0VhRmZBZERnbWhSZnBnZGFCZGhhd2NRZlhoUmVSZ1Nma2g1aDFjUWN6Y1llWWVCY0Nhb2crYVZobmR4Z2JkSWF4aHRiSGVmZXpkbGhmZ05nd2NSZ1BnZWhXY3BlRmREZ0FoWmZqZUhhbGFsZVFoRWZqYU5hT2VhZkVjRmdtZUhiaWJ3YndiR2hCYW9jT2dWYVZkUWFLYVVjVmZaZHBmYmVqYjloemZjYlZnaGE1ZUZiZ2FOZWFiZmJFZVlnUWRCZGdheGRDaElmMGRGYm9mYmYyYkpmbWRhYlJoUmd5Z1RjbmhOY05kWmFrYzFmUmdTZVJoVmVPYmFmWGRRYlloZWVCZXBoZWNVYVVicGNPZGRnUmJGZXpoVGFGYUZkNGNjYkVlVmdpZ0ZjV2NzaGFjSGZCaHdoSGZSaHpoQmZkZEhkeWNzZTlmV2d3YW9lRmdmZEFhdGdNZFhkeGF0ZDJoYmFXaFJoQmViYWtjcGdraGVoVWRzaFVkY2dSYjBmTWFXZXdhTmJXZ1BlR2VZZ2JhTWFqZHNhT2ZhaFViWmhkZkdoM2MxY2JmQmdsZDVhRWRIYUhkbGZUZVRha2FWaGljWmJtYmtnVWJjYmtjNWR6ZEVkRWZ4Z05nUWVGYmthUGFUZWlmRmQ4aGRhVGRFYVZkUGZGZjhiYWJBZ1NjSWhaZ1libGR4ZWRjZWdHZ2xmZmRmZFFlTmZCZFVnaGNSZ3hjUmZoYU5iNGJVaDBhOWdrZ2Fja2RFYURoRWF6ZGdmRGJOZkJjZGVHZk1ha2RrYjBmRGNqaGxiQ2ZkZW5nVmRMZ0JlMmFFZlVhRmdFYUVhemNWZ25iUmN1YWRkbmhOZXZlUmFtZGRlTGJIaG1kWmcxZVNjaGFCZVNiUmJBY3Rnd2ZXYmthSmd2Y09nV2RaYTZoQWdtYmhmT2dPZHhmaGNmZldoMWVoZUZlRmNWaDloL2JiYWhlZ2M0ZVNlV2ZWaEhjUWQwZkplMWJBZEdiTmdXY1VlVGRCYzRiUmMyZVFoR2RaaDFjSWhHZGFhMGJaZWJnY2JFZ0ZmR2daYURoZGJhY0FiamJsYXdiQ2QxZ2xhV2RFZW5lcGJIYlphRWJrZm1iUmVEYVFocmRCZUViQWUrY1NoVWFRaGRkWGZGZGdmeWNQYURja2EraERoUWc4Y3pkUmhSZUpoUmhkZFFlUWNaaFhmbWU0ZExjY2VGZHBnQ2diZDJiSmZtYmFjUmZSZHljUmRqZ3NlZWRIYUJhOGVlZ0hiVmJvYmFhTWZDZVJoZGZmYWdmY2ZtZEhlZ2VjYmdoSWNGZ3dheGRDZVFlTmg0YWJjVmZZaG5jQmhtZmRkNGFGYUhnRmFHYUViM2VoZFRkVGcyZ1JhcWRVYnhkRmFiYmZmbGRzZ0xhR2FVZlliMWVFYnpjMGRSZktjMGNRZWljS2Z3ZlJnWmRBZ2tibGVQY0JoRmRjYVJoZGhIZ05iMmhNYW1kWmdLaFRjUmJZYVNoVGVIYlZlS2hFZEZhSmhFZENjM2NCZFNkQ2JtZEVieWdOZUNnWmhBY1BnUmZvZnFoUWZBZmxlRGJCY1FmWmc3ZUdheWhRZDJiWGJTYkplQmZhY1ZhRWhNaEdhemh0ZFNjSmR3aFVhZWFOZ25kQmVlY2ZmUWU4YXdkZWFCaFJleGJSYmhjTmc0ZlVjMGY5aGthYWJsYk1nWmRFYnlhSmFPZERmUWNOYUFlTmJFZ2RoeWNWYUhkdGRaZGNnbmRsZUJnRmhDYVZkVmVWZUJlNGRYYkthVGh3Y25nTWhUZ3RkdmhUZVdjZGdDZ1dkZ2NVaG1iUmhHZThhZWZDaDFmeGhyZmNkRWJKYXZhWWdtaFpjcGVGZkhhSmVPZGNjeGFBZVJkUmZGZTFiamJGZFVoNWJwYmRlQmFoYXdlUWFYZFJoUmhTZ2tnWWc5ZkhjeWFNYWVmSGJpZHdoL2FBYWliMWFmZExibGV4Y0FhUGVqZVZkSGFLYWhmb2JCYUlnMmNwY09kR2RWZlVmbGJSY1Jmb2hDZldjemFVaEpjWmdFZ2tkNmNRYjJlUWVpZ1lnUmZSYXhjSGhSYzFmTmhHZ1ZjWmIwZ2JhbmJaaHpkYmN4Z1FoaWNRZ2tmY2JlZU9hMGZwYUVlR2hnZjFiWWJmZmdkNGNOY0FkVGZjaHJhS2YxZ0VlZ2NSZ25mb2ZlZEdlQWVJaGljSGRVYmNiSGJKZHpnTWRRY0pmRWVFY29lRGVVZXBnZmZaZVJnaGdvaFpnbGZGYzRiY2dGYlpiMGFEZjJidGRTZEZlSGdFY2JhR2FuYVJhNWRUYTJkUmRxY1VkeGVrYlRiY2ZBZ3RhWmdWZWhib2V5Z1NnVGhRZlRkSWZSaDRjcmRMZlJlSmhFaE5mQmZOZ2NoQ2dWZzFjV2FhZldnNGJ3ZUpmaWRFY0ZjTWgxZjlhZGVBYW5iVmNDZVJlRmJ0YUVmVWJGZ3BlYWdRYW1mOWdpZVpmbWJraFVhY2FrZjVhemdFZkVnd2RiZ0VnQmRzaFZnSGdHZ2xlcGZHZ0NjUWFKYVBkUWRKZ0VjTWJUZmxiZWJKYUVoeGVhZmVmQ2JSZVljQ2gwYU1ia2dCZlJiaGhiaFJlaGNOYjRlVWEwZDlka2FhYWxiTWJaYkVlM2dBY0xjV2NWZlphYmNlZ2xncGdrYUVmMmQ1Y1ViZWRtYWRmTGFCYldiY2hHZU5oMGgwYVphVmJuZFJkdWNkZ25hTmJ2ZVJobWRjY1dnRWNoZTRhd2VIY2tmVWVBZkNoZ2N0ZDRkY2ZFaEpmdmJZZ21iWmFwYkZhSGJKZU9lY2h4Y0JlTWJUYVZkRmZKY0hmUWJkYnBiZmd3YlZkd2hGZFRid2hZZkdlVWhBZEtoV2FUZW9iTGNHYVhnaGI3YVZoaWVBZ0JiRmZCZ3BiZGNOYWdmNGVhYWRiSGZsYlBhWmJHZHBjVGdHZFJiTmR3Y0NmMWZsZldoRWZuY3BiSGhaZUVna2E2Y0FoaWgwYnFoUmZXZHNlOWdVYmtkcGJOZEJkRmdaZGlnZWIyaE5lZ2JlZGtlWmRoZUZha2JCYkZjZWJXZEFiUWhVZ2tiUWdMYWNjRmZwY0NnYmEyZUpjbWVhZFJiUmF5Y1RlbmF0ZEVnQmFBZlFkQ2ZSZjJjb2RHZEllRGJOaFFkY2VGYXhhMGVSZTFoOWZiZFpoZ2RSaHpjU2dsYkVkeGNlZlZicGVlZ0RlMmV0YlNjRmVIZEZkR2RFZTNmaGZUZlRiMmZSZHFhVWN4YWxkSGhPZEVmSWVLZGZlQmJKYzZlUmgyYVJoQmViYmtmcGRrY2ViVWVzY1VhY2hSZVFmR2VaZXhnbGZXZmRjR2M1ZTJnY2IyYzljR2haYXhhWmRQZVJmWGFsY2dmRWRGZEpjRWRDYjNmQmVhYlFhbWg5YmlkWmhtZkZiY2FmZkJhNGVoZFhoeGJnZENnQmZSZ0JjRmRDYjJmY2JuZ1RjVGFJZlZnSmFoZEFlSmRHZG5hVWRNZmNld2dvaEVlTmZqZk1kQ2ZQZVVnQWdsaFVoaGh3YWxkVGd4Yk1iamdlaFVkOWFraGFkbGZNZVphRWQzYkFoTGZXZVZjWWJTaGVlaGJVY2hiRmdUY3NnWWVLYW5ja2VmY1hoRGJoYk9lRWd3ZnhlZGJFZm5kd2M2YWVjRGNBYmpoQ2ZTZGxoVGhHZWtoVmU3ZUJoRmRVZFZiQmhWZDhmMWZVYmthdGVtYmVhVWV4YnBmRmFIZUphT2FjZXhoQmdNY1RlVmJGaEpnU2FFZWRlbGNYZGhkaGV3ZlFkWGJSYlJiU2drZjVnMWdFYlhmTmJFaEdnWGJZZmdjQmREZ3RnYmhKZEFmWmFOZ0ljUWVNZ2RnTmJRY1lmRGZNZ0NmTWJEZ1ZoVWZwY3dnRmZsYmtjUWZSYnpnUWVFZk1mQWNnZ2hoQmhHYVJheGFIY3hhMWF4ZlJjamhkYU5kR2JWZlpjMGNiZG5iWmZ6ZWJmMGdaZ25kRmRoYklnYWhOYUJkZ2VRYkFmRWNnZWhhY2hGZnBhQ2JiZzJmSmJtZmFoUmRSZXlhVGduZ01nUWdUZUVlMGdZYlJjVGU5aE9nYWNYZ1FiWWdjaEVnRmcwYlVjVWdwZ09nZGNSZEZoemVUZEJmUmY0aGJnVmFZYWdoUmV5Z0ljQmZHZmdhNGFPYVdmamc4Y2JlUWIwZzVncWZVZXhla2NUaGNmQWF0aFplVmRoZ0phNmZSZDJiUmNCYWJhZ2ZWZGtoWmdFZ3RmQWhPZ1ZiUmVPZVFnMmNZYmFoT2N6aGxlNmZXZldjOWZHYVpjeGdZYlNmVGJIY1ZkS2ZFZUZjSmFFaENnM2dCZmFmQ2VtZDlnL2JaYmpkMGhhZURkUWhZYjZhVmV3ZVJlQmRlYjBha2ZWZ1RkbWNsZjBhR2FIZEJoQmNkZUZmRmNLZlRnbmNVZlJnUGJVaHhmTWRlZUNoUmdZZUNkMGVNY2tkQmJRZDliYmhSYmhjTmU0Y1VnMGE5aGtjYWhsZk1jWmFFZDNlQWVMaENkeGdOY0dmTGN4YVVncWJRY1dkWmJnY1pnSGZsY0xoRmhIaEVhZGVIYVVkMGhaZFZjbmdSZXVmZGRuZk5lbmhEZjJmY2JMZkVjZ2dOaDFnUWJCZUFjY2RUY1FjZGhhZFdoa2RKY3ZiWWFtZVpicGZGaEhlSmdPY2NjeGNCZ01kVGNWaEZlQmdSYjBjNWIwZ2RiRmdGZHdhWGQyYnBoUGdTYmxhOWZqY0dkSGE5Ym1mVWdYZGhod2ZWY25lUWdQZmFiMWhJY1VmY2NVZFloVGFlZUZmTmVIYk5mbWRwYlloQmFCYk1iMWdDZDFlTmdXZFhmSGNOYUxiVGRraEZkdWhTZW1iUmU1Y1NieGhSZXhoSGJSZjFmTmJHZFZnWmIwZFplaWZSYnpkYWdWZXRibmJBYUFlZGNaZlphbGc4YlpiWGVtZzRiTGdjaEZjcGhDZWJjMmdKYm1kYWVSYlJjeWJUZ25hTWFRY1RmRWVVZkRmU2FSaDVlVGdhZVRjc2hZYWVla2FFYjhmV2FFYVpma2JkZlJoRmV6ZVRjRmhGZTRiY2FGY1poMGFEYjJidGFTYUZiSGdGZ09kUmd6aEFoYWVIY0dib2JWYUhmMWRaZEVmY2RCZFplWmdRZkFkZGJ2ZVZnSGVGY0JlYWVFYW9ldGVjY0VnY2ErZWNkUmQwZGRkVGFSYmxlV2JkaEdjNWUyZGNnMmQ5ZUdjWmJ4ZFlnYWhHZkRoMGFEZFFkMWN3ZzdkUWh6Z2thZGRDYm1mOWcvYlpmbmQ4YUJmWmUxZjFmbWFFZEVlcGVOZEFiMGJBZlplWmZHYmxlMGVHaEhnQmhCY2RhRmNGYUtnVGhuY1VlUmFjZzBjeGJSZExiRGRnYWZhSmF5Z1ZhcmZVZWhmUmV4ZlJkaGFOYTRoVWMwYzlla2VhZWxkTWZRYkNlRmJvZExlV2JWZVlkU2ZlZmthZGFrYVFiV2M1ZUtlT2FYZ0JiSGhQYm5nRWVkZEhoVWIwZFpoVmNuaFJodWhkaG5mTmNuaERibWRsY0diUWhBZE1maGJCZFVmUWRMZ0ZiRWM1YytlSGdnYXNmNWFZYm5kdGFwZ1VjaWZjZEFjTWJFZ1FlRmNBZGhoOWJKYkhmUmJwY2dlZGNFYU5hYWhRYlhhUmRSZFNma2E1aDFnRWFYaE5jTWdVZFhoaGd3Y0hiemJJY1BjWWYwZ0lkVWdiYkZhc2JUYUxkRmgwYndnS2NDZlVhRWJHYVJhVmEyYUNoMGJsaFdjRGcyZ2RiSGdNYUVlOGFSaEFlaWIwZythQWJ4ZzFmeGFTZVZmVWZmZVZiZ2NGZjBoQ2h5ZlFkaGhJYkJnUmJ2aEZmRmhZY0ZhSWF3Zk5oRGJHaHdhdGJGZ2NhQmVnZGJjYmN6Z2dhamdPZjFidGZ3Y1JlMmZnZjZnVGdFZDFjUmhTaFJlVmhPaGFmWGFRYVlhY2FFaEZlMGdHZ0FmeGJPZmZhUWRGYnpiVWJVZnhiNGVKaEZkZ2ZMZVJheWdJYlZnWGVIYUZlQWhGaFhlaGJDYVRmM2VsYTNmVWQwZzBkZGREZDBmY2hXZEFlUmZ0YVFjUmgyYlJlQmRiZmtocGRrY2VnVWVzY1VmY2JSaDBhZGNUYVJja2JFYk1jVGRvZGpoSWVTaEZhR2hiZTBlSmNhZ0JiU2JaZUVlUWJoY2NjSmFTY2pja2hVYkJhaWFvaHdnWmhuZVFoVWdQZkFlc2RrYkVnQWdSZ0ZlUWJVZUFlY2JRZm1ja2VnY1VhRGdrYlNmYmMzaHRoS2VUYW5kVWRSaGNnMGd4YVJnZWVIYkJnV2dkYUFmOGhpZkZkQmZSYzVjRWhoYzBhL2hCYTBkY2F3YUlmaGdwYktjR2ZuZ2tiaGhXZVZoWWRTZmVia2VkZ2tkUWdXZjVmS2haYkhmbGJMZUZlSGRGaFBnV2ZCaGxkTWRCZ0RncGJ1YmZkbGVsZHZkUmNtZmNnV2RFZmtoeGgxZlNnaGNCYVNkUmFBZHRkd2FXaGtkSmh2Y2FoamhJY2hoWGhTYkZjQWVJZlZnVWZCYkRhQmZnZkhiVWRRaHNhN2hkZEFjVmV3ZUZkVGR3YlliR2FVYkFjMmVYZFRid2ZDZ0ZmSGRCYzVjWGczYmdnbGVhYjFlSWZVZGNnVWdZaFRlZWVGY05hUGVaYkdhcGNUZ0djUmJOZ3dlQ2QxaEVjQ2ZXZmpkTWZVaGFiamI0YWlhQmJUZU5iNWNWYWhjUmRoZEZhQmRGaG5nR2JWYlplMGJiaG5hWmN6YmJnMGdaY25oRmZoYkpjTWhkZlVmb2dRZVVka2N4Y2ZnT2FCZU1mUmJZZlJhMGV1YUlkRmRNZjZhVGRtaDRhUWNYZ0VhUmNkZllkeGVWYU9hYWRYYVFmWWdjaEVnRmMwaFVkVWVwZU9lZGJSZEZnemZUYUZoRWNzZ09lQmM4Zm5iSmJXZ3RnU2hGaEhlRmJHZEVmM2ZoZVRjVGgyY1JjcWRVYnhma2VUZ2VlUmZCY3phVmFoZUpmNmRSYzJoUmFCZGJoa2ZwaGtjZWFVZ3NoVWJPYUZoc2FkZ1JnVWEwaGViUGJUZzFnNGNOY2pmNWNPYk1ieGg4YWJkWmVuZlZjS2dFZkZmSmNFY0NhM2ZCZGFkUWRtZjloaWhaZ21na2dVZEllQWZzYm5lUmNSZjRmRGJVYVVoRWMvZVRobWRsZzBjR2ZIZkJlQmZkZUZmRmFLYlRhbmJVZlJkY2QwZnhnUmRlaEhoZ2JDZlBjRWZZaDRoWGRFY1ljMGNDZTFoSWV4Y0hoUWdzYmhlT2JGaE1nRWFFZnplNWJPaERibGVaZmFkY2ZsaGRmdGZTZ0dlSmZnY1phSGJsY0xkRmFIZkVhZGJIZFVjMGVaZVZmbmVSZ3ViZGJuY05ldmVSYW1iOWZDYVdlZ2ZVYW1iUmdHZzhkZWdDZTFleGd3ZVJoMGhKZitjYWEyaHBmRGFGZkhiSmdPYWNheGdCaE1oVGhWZUZkSmFGY1VkNWhwYWRoQmFoZ3dhUWNYaHdoRmFBZ2dkY2ZtY0hod2Z3ZUVjR2NEZThiNGdWaG1ma2RQY2VhMWhzZFllV2EwZ1llVGNlaEZhTmdQZlpmR2NwZVRjR2RSaE5ld2NDYTFnbGVXZkVhbmhvZlRiTGdBZWdiOWRZZUdjUmE1YlNneGFSZXhnSGJSZTFhTmhHZFZlWmMwZWJlbmZaZnpkWmFsZTFnTmVGZmhoSmZNYmRhVWZvZ1FjVWVrZVFjTGZjZkZhcGdDaEtiU2gwaDBnYWdSYXdna2JEZnlnRWhRZUhoa2ExZU1hU2RVZUZjQWRLZ2pnaGZYY1BhZ2ZSZzhkV2NFY1pkT2FQZkJoRmF1ZFRiRmZ4Y3BnYWUxZlplMWJXZHljTWhiYlJiM2E4YktmUmUzY0FnQmFSYm5kOWhxZFdoamRNZFRnY2VBZHRlWmNWYmhnSmg2aFJjMmdSZEJoYmNrZXBia2NlZlJja2JhZElkbGZWZ1VoQ2EwZjBoNmRNZ1NhZ2JpaGVnM2I1YktiWmh4ZGNkQ2NSZ1hnbGhLYVdhVmNsZlBhRWVGZnBoYWFRY21jOWhpY1phbWNrYlVkY2RrYzVoemRFYUVmd2VMZ0hiaGVzYVZhUmhrZE5kMGFHZEhjQmZCYWRoRmVGYUtlVGZuYlVkUmdjZTBoeGZSZGVkQ2VRaGVkUGNWZnhmbGJBZkZlRWM4ZEJlMWVvYTJmRmh3ZW9kMmVhaGtmNGRaZVJhemhoZkNkQ2NsZWhnUmdOaGdkZ2FxZ0JnR2VaZkRkYWVIY2toZmVYYkRoaGRPZ0VmemRKY1ZiR2JTZ05kdWJhYTNkTmMvYlNhbWdkZENiV2FnYlVibWRSZUdmOGRhaERoVWd3ZTRlV2hsZTlldmVjaG5lMWREYUZjSGFKYU9oY2V4YkJjTWNUZlZiRmNKZkZhVWM1ZXBnZGZCZ2dnNWVRYldlcGVNZFNlbGY1ZHViT2YzZ05nTWVVZFhnaGJ3YlZnbmhRaFBlYWIxZkliVWNjY1VkWWhUY01hVmM1Y0NoVGZtYXBiVGFHaFJoTmN3Y0NnMWdsZ1dnRWFuZnBlSGhaZUVjaGRFYVNlbWRSZTVkU2J4YVJieGZIZ1JlMWdOY0doVmRaYzBhYmRuZllmaGNZZlJlVWV2ZVhkMWNRZ1lkQmh3Yk5lWGdHZWhmQWNEZFlmVmJOZk9oUmZXY0pkbWZhaFJhUmR5YlRnbmZNZFFlVGFFaDFlUmRTZFJmVmVPZ2FjWGFSZ01kT2ZBYWdlbmNYYnhmZ2FMY09kRmVBYjZiQWVoZlVkOWZJZmxnZ2I0YVdiMmhNaEFkSGFYZkVkYWZUaDFjSmVUYlRoMmJSZXFlVWV4ZmtlVGhjY0FndGRaY1ZoaGFKYjZnUmYyZlJkQmNiZmticGJzYUxiUWhOYmRkSWJoZU5hUGJDYkZjUWhYZVBkU2dBaHliTmRqZjFhSWhOZUVlTmdRZkdnQ2RjZUxiVWV3Z1piTWVXYlhibGNXZGFoR2I5ZWlkWmZtZ2tnVWJjZWtmNWR6Y0ViRWR4aE5jVWFVZmtmVmdUYm1lbGIwZUdmRGRsZEJoYWJrYXhkS2NYZDJkTWU3Y2NmMGN4ZVJjZWdIaEJhV2JkZEFoOWJyY1VkaGdSZ3hkUmdoaE5iNGNVZjBmOWZrZmFhbGJNYUdmRWUzaGhnZmVFZFJiOWVCaGRiRGFnZHNkQ2dDZWtkQ2ZaZUNhVmhXaEZmR2FBZmRoQWZWYkVoWmNYaGphMWR1ZWViM2ZOaCtiVWJHYTRkZmZPY0VkeGYxZFNlaGNCZ1NnUmdBYnRjd2hXaGtlSmN2YlljbWJaZHBoRmJIZEphT2VjZnhiQmZNZFZnMWVGaEJlUWZRZVljZ2JKYnhnWWdQYURjVGNzZ0dhU2hoZEpob2dFYldlSmJNaFRkV2ZSZndhSGEzYjBmR2JjYkhiZ2ZVZmNjVWNZYlRmZWNGY05mUGZaZUdkcGhUaEdnUmNNYmlkVGRnZDBnRGZRaERkUmdIZk1lQWJrYm5hR2VYZDlkVGJTZ3hnUmV4Y0hiUmcxZU5mR2RWZVphMGhiYWlodGU2Z1lkMmJ4Z25lRmdoZkpkTWhkZFVlb2RRZVVma2hRZkxnZWhCZEplTWRQZXpjQWhwYVBlVmNzY21mRmV5Y05lVmNRYmdoTWhVZkRnbGdRaGFkTGZIZVFkRmRjZEFlY2JoZkhld2RrY2FlUGZGYjRlOWRUYUZobGh4ZmNoQWgxY2VoRGIyZHRjU2dGY0hmRmhHYkViM2hoZ1RoVGEyYlJhcWNCYVZiaGRCZGNlRmc5Y1piU2J4aEpmeWJVZFhhRmJVYWZlVmQ5ZWtoZmQwaHRmS2RKYVZnVmJVZkhhaGZjZnBiT2hDaEViaGJlY21mOWhOZ1pkd2VjYUpnWmVuaFZkS2JFYkZiSmhFZUNjM2hCYWFnUWhtYTloaWFaaGphdGJSZkpjaGFzZ2hjWGVraHhiRmVlZjBla2FWY1RhbWVsYzBnR2ZIZEJjQmFkZUZoRmVLZVRmbmVVYlJjZWF4Z2dhWmdNZ1NmTmdZYkNjMGJNYmtlQmVSYlJoc2FSaGdmVmJ0aFJobGZ4aHhlYWNsYVVoWmZSZzNha2JIY2NkMWNZYVNjZWVrYWRka2dRYldjNWVLZ1pkSGZsaExlRmRIZUVkZGVGYVJobGFSaEhleWZkZ2dmQ2NUZHNnbWhBZ1NnOGNXaERjMGN4ZDlnRmNFZlFoYWFEZVZnaGgrZEpjUWhvZm1lSmNTZzVicGFIZTNkSmVHYkpneGZCaFNnVWEwYzllSmZCYkZlaGRnZ2ZmUmZoZTJnUWJXZkphRWFYYzFhMWFnYkdiSGY5aG1jVWhYZmhnd2ZWZ25lUWVQYmFiMWJJaFVoY2hVZVlkVGhlY0ZoTWZiYkxjQ2FNaEFkTWh4YU5ld2VDZDFibGRXaEVhbmdwZEhoWmRFZkZhdWVTZW1nMWRpZ1lhUmhSYnhiSGJSYTFmTmZHZVZkWmMwY2JmbmZZZnVlWmRrZ3BlTmRGYWhkSmNNZmRlVWdvZlFkVWhrZlFmTGZjaEZjSWhLZ1llVGNJZzBjSmdrYkFoOWFHYWljcGNBZkNhVWZNZVVmR2RFZEFoUGVKYlNoY2hZYWJnVWhFaDhnWGd4Y29oY2dPZWtlVWQ4ZEdlQWFnZW9jTmhWZ2dmeGRYZ21idGdQZkZlRGNjYlRjWGVUaHNhSGhCY2lnc2JrZFVheGZGZkhjZWRRY3NlQ2RmZUJmSmE2Y1JmMmRSY0JlYmJrZXBka2NlYlVkc2JVZGNjVWg5aFlhR2ZVZHdoRWJPZW1jNGNpZ09oeWJZaFZoYWFXZWxkZWVBaHlmSmJLZURiVWY5aEVhWGYzZzRkbGhEZWljQWgxZlpkbWE4Y1NlY2NoYm9oN2ZXZlJhOWFEZExoZ2hGZmNoQ2JTZkZjMGFCaFdiMWVCaElkRmc4YTFkQmVqYnhlV2ZPZDFjZGI3YWVnSGdCZVdmZGdBYTljcmJVZGhkUmh4Y1Jia2E1ZXhnWGgyZVZna2VhYmxnTWNaZ0VhM2hBZ0xkV2VWZFljU2VjZ2dlOWVxZUVjVGR3ZkZjTWVEaFliZmhUZFNlRmFZZEVhd2FwZ0xiRWR6Y1VkNmdNaHloRWRiY0RiaWNaZFliRWJsYkZiMWhBZmhkNGRDY0Zna2dRYmtlRmRSZVllMmFNYmlhTmJuYlVmeWJaZ09lYmVoYUFoS2NHaEJnOGdLYVFmUWJjY21nT2ZoY2hiNGhGZVhoMWdSZEVoV2VSYjFoRWdYYk5jTWdVZlhlaGJ3ZVZlbmFRaFBkYWMxYkplR2NOZEJkSmRHZ0tjaGMxZlBmTWhDY0lmYWVTZWhnMGJQaFFheGdBZlJhV2duZHBkWmJaZEJiVmFnZE5kU2d3YndhRGJGZ3hiYmFIY1JnMWZOaEdnVmVaZDBmYmFuY1pnemRiZjBiWmNuZ0ZoaGVKZVRmZGZVY3NmQWFlY0VjUWVMZGNjRmVwaENiYmQyZ0pnbWNhYlJmUmN5Z1RjbmdNZVFiVmVrYjBkRmRBYVZkd2ZkZ1pmd2Z0Y1FlT2VRZFlmOGhVZlZjWmZPZkljUmY4aE1kQmVCZWdmL2RPZUhjeGMwZkRnMmZ0ZlNoRmJIY0ZhR2hFaDNjaGJUZVRmMmdSYXFjVWZ3YVliVGJjYVJocGR6YVZjaGhKZjZkUmQyY1JmQmViZ2tkcGdrZGViVWhzY1VoY2NSYTBlSGVUZFVlMGNlZFBnVGQxZDRhRGZDZk1jSmZNY0JoWWhNZVRoQ2FGZEVhYmN4ZjRkTGNYYUdjdGF3YVFibWI5ZmloWmRtZWtmVWVjZWtiNWN6YkVjQmhGY0VlWGRXYk1nVmFUaG1kbGYwYkdmSGdCY0JjZGhGZEZnS2NSYWphMGNmYkljeGQ0YWVkTGdEYThhQ2RMZFZlOGV1YlhkRmdnYjBjRmhVaEFnTWJHZHdlNGVxaGFla2g0ZlphV2UzZzVhYmdDZXhjbGhHZE5lUmRNZDlhRWRTZHRmRWdLZENhMWRMZkNjWGZGYmJoU2VBZE5iYWhBZ2pkMGdoZk9hSGROZW5nRWFtZDRjV2hTZFdlWmExYVNiaGRCZ1NnUmRBZnRnd2FXYmtkSmV2ZllnbWVZYjdmVWFTY1ljYmhJZVZiNWRNZkdkUmRrZkFjUmVrZEFmV2FQYUZoRWgzYkNkWGFSY05jU2VoY3BlN2hiYWpic2JGZkZmamdCZ2FjVmNuYVFhUGhhYzFnSWhVZWNkVWJZY1RnZWNGYU5hUGZaaEdocGNNY0diUmVKZ2dkSWdWZGxhV2RFZG5jcGZIZlpnRWNGZnVnU2NtZVJiNWRTYnhjUmZ4aEJmeGYwY1pnVWVSZzhkbmVZZEFja2g3ZUplZ2hFaHZoRmVnY3hiTWdJYVVjUmN2ZkdjZ2cxYk1kT2VIZ0JhQ2FiaDJiSmZtYWFoUmdSZXlnVGVuZ01hUWRUZEVlMWFSZVNlUWJwY09lYWdHYVVmeWdjZEViRmMwaFVkVWJwaE9nZGNSZkZnemhUYUZhRmI0ZWNiRmRaYnViRGR6YjhnYWJYY1NkSmVJYWJoRGNRZmNnR2NHZFJoMmVVYTBnMGNkZERmMGdjYldiQWFRZmxjUWVSYzJhUmNCYWJla2NwZWthZWZVZXNlVWRjY1VkQWdVYVFmVGFOZFdiZGhHYzVjMmNjZjJhOWdHY1pheGJZZFNkUmJEZzFjRWZRYkFoQWNMZ1hkemE4aE9jR2d6YzhjbmFhZUNiWmVHZWNmbGZOZHpmVmhoZ2tjRGVFZ2hnMWZjZkFnU2JkZzBmRWRDYVJkSWVkYkFkcGdnZFRkbmNVZ1JnY2IwYnhlUmdlYUhmQmRXYWRoQWc5YXJnQWJGaEVibGFFYzBnRWIyZ1VjMGNjZXdlSWdoY3BkS2ZIYVFkOWJIZkZhZ2NFYVNhSmNsYXBna2hGZ1doQWgxZUthRGFZYWNmSGFYYTBkZGhGZlJkbGRSY0hieWFkZmdnQ2dUYXNlbWVBZ1NjOGVXZ1RibGJGZDFnSGJoaDRkdGhEY0VlSWEzYkVka2d0Y2phWWRqZ0lhaGFYZFNmRmNWZFdmUmRCZk1kVGdWYUZnSmhGZ1VnNWhwZGRjQmhnaHRiU2dIZ2hhN2hTYmtiNWIxYUVmWGZOYk1nVWNYZ2hid2FWZ25ieGZIY1pjUWZKZEdnUGNoZEpnY2JMZ0Fob2FmY0llV2JRaFNoVmQxYmRid2JGYWxla2hRZFJmemZRY0VoTWJBYmdhaGJCZEdnUmN4ZEhjeGgxZnhmUmFqY2RmTmRHZVZoWmYwZmJmbmVaZHpmYmgwaFpnbmNGY2hoSWJlaE1mQmY1YkZnQWZBZ29hTGRlZkFjNGNLZEpnamhGaG9mRmRsZ2dnOWRHZ1hhTWZXZVVmVWUwZUZiUmYyZG9mQ2NKZWlnTWZSYWZoRWNGZjhjQmNRaElmSGFKZWhlOGFNZ0JoQmdnYS9hT2VGZFpmeWFFY21hc2ZHaEdhZ2I0Zk9oV2JqZDhnYmhSZW1haGhxYkJnMWVGZmFoSWh4ZUJnemVWYWhmSmQ2aFJjMmFSZkJhYmNrZHBka2hlYVJjWWVkY2ZkVGVjZWRjVGFSaGxkV2NkZ0dmNWUyYmNnMmM5ZUdkYmcxYTRhY2hIZ0NhY2JGYlJjQmcwZlFlVWVpaEFiZmRUZ0NhRWJ0ZE1nbWRrZ0phY2VnY2dnbWJYYmdlOGJaZUdkQWNaZGJmVGRtaEZoOWZHZ0NodGNyY2RkRmVGY0tjVGduZFVnUmZjZDBjeGFSYWVnSGdCZ1dmSmdraG9mL2VCYjBoWWEvY1JhaGd0Z1NjVWcwaDloa2ZhYWxoTWdaZUVoM2JBZExkV2RWZ1lnU2JlZGtmZGFzY0ZmU2dZZURkTmQzZWNiMGRXaERhNWZLY0hoVmRBY1pmUWZHYUZhN2daZVdjWmR2ZlFnR2RkZkljUmNnZ1FiOGdHZ1JiNGR0ZENjRWRRZW5jVWgwZTVoRmNZZ21hWmRwY0ZjSGVKZk9nY2V4YUJjTWRUZFZjRmFKYkZoVWI1ZmhhSWhGYUFlNWVFZ25hb2Z1ZUFiZ2ZjZXljV2dYYk5jUmJVZldjNWVsaFFiMmVjY2FlYWYxZVFlVWhMY3hjSmRiYk1mUWhCZ0JhR2h5ZElmYWRYaGxodGM1Z0JlM2JOY1dnRWVuZXBhSGdaY0VmRmZ1ZVNobWJSYzVjU2F4ZVJieGVIZVVja2ZGZlViQWVWYmVoYmJuZ1poemdiaDBhWmhuZEZjaGhKZ01hZGJVY29hUWdXZDFmOGhoY2NmRmJwZ0NoYmcyYUpibWVhZlJnUmR5aFRnaWU0aFphUWhHY2RmUmFTYVJiVmNPY2FoWGZRZFlmY2VFYUZhMGhXYlFjSmJBaEpnVWZNaDhoR2NCZDRnc2hLaFFoWWR4YUFmVGJNZWRnUmVuZ0ZiYmhFYXpoNGZHZkFjU2ZjaCtmR2ZsaFphZGNjaEFmTWdOZ1hkeGZJYmhiYmNXYlJoQmJiY2tncGJrZGVkVWFzZ1VmY2RSZjBlZGFUYVVlc2ZUZklmRGZzZGthUGVXYzllT2VNZTFkNWJiZkhlM2NzZTFnWGhCZTBiVGJDZXdjNWFIYlFhamd0ZnNmR2VTYVZkYmFKZVVlZGUvZUVoRWhRZ1poR2dRY0JhR2NRYUJlWWg4YlVjVGJjZkpkZGZDZzliWGFUYWlhRWhmaERoQWNRYlloUGd6Z2hhZmZlZUFjOGMvYUdjbGcwZ2ljWGdUaGxhNGJVZDBhOWVrZ2FjbGFNYlpnRWYzYUFmTGZCZ0ZlOGNlZFVmRWNkZmthUWVXZDVnS2VaYUhmbGFMYkZhSGhFZFZnVmRVZk5jSmNCY0Rkc2I2aE9hU2VjZDJiRmdpaElhWWRRZFFlUWM4YkRmRWNRY2dmRGJVZXdiNGVEY2tjSmJ5Y1lkaWg1ZG5nUmdDZ0FiQmZKZjFhOGdZYUZlQWdFZ01nR2h4ZTBhaGFQY1ZnNGFrZEVmM2ZSZU1oU2FnYWdiZ2dYaHpoQWVZYUdkRGVjYStnVmFuZXhnYmRZaGxlSmZQZFdoMGVZZ1RmZWFGY05mUGJaYkdkcGNUaEdlUmVOaHdiQ2d3ZXNhVGRSZGljOGZWaEtma2dGZm1hWWJHZ1JkNWRTZHhlUmZ4ZkhhUmcxYU5oR2VWYVphMGJiY25jWmF6ZE9kMGdaaDVlRmFnYU5jYWdYZTBob2FRZVVha2dRZUxjY2dGY3BkQ2JiYjJkSmRtYmFjUmZSZHlmVGFuZk1kUGhUZEVnVmJaZEhjVmIwZ0hoT2ZuaHBnbmZQZUFoNGdqZ1VnVmVkZE9lSWhWZGthNmJIYzFiOGVIYk9mQmQ4ZXpjUmYyY3RkTWRDYm5oRmFPYVJlM2doYWVkVGYzZlZnOGNXZWhjQWhmZGNiQWdNY05nSGZsYXNicGZTZlJjc2hKZkpmd2cwZHNkZWNWY1ljVWRZYVJoUWVVaFpieGNsZ1dmZGZHYzVjMmNjZzJhOWFHZFpjeGdZZVNoVGFIaFZmS2JFZUZnSmFlaENiMmNGYU1nUWVuY0pkL2FaZGpoMGQraGNia2M1ZnpiRWZFYnhmTmFVYlVma2JWZlRlbWRsZjBlR2hIY0JnQmJkZkVjNWZLaFJjbmUxZkZiT2J3Y1ViQ2NkaGdkOGFhZk9mMWZoYnJhVGN4Z1FobGhEYmxmb2ZyaFhkVGNBZnNnSWF4ZlJiUmhHY25kd2NMYVVkUWJKZWFlTWV4Z1JkcWRQZWliWWVEY0llemZGYkxhQ2FYZEVmTmhGYkVoUWR6ZFZkbmJSZ3VkZGVuaE5kdmFSY21lY2RXaEVla2F4ZTFnU2RoZkJoU2hSZEJjRmF3Y1Voa2hvZzdiS2JpaDhiNmVHZ2dlMGhDaFBiRWNkYk1oVWdIaHRhSmRGZ1VoNWJwZGRiQmNoYXdjUWFYY1JmUmhTaGtiNWMxZkVjWGNOYU1nVWJYYmhmd2dWZW5jeGFiaElieGJ0Y0hhZmd6YmxjZmJOZXdlUmhQZWVlbmNSYlRjVGRSY3Bod2ZWYTFhbGZlYkdoaWE0aFBkTGhSZEpnZ2NOZFNnd2J3ZkRoRmZ4Y3hiQWVRZEZoTmVFY1VkZGZpYmJibmd0Z3plT2EwZzlmdWFGZmhhUmdNZVlmMWE4YkZjUWRWaEVjQ2dlYlZhWmRvZWJiMmdKY21kYWJSY1JjeWRUaG5kTWVRY1RhRWExY1JkU2JSYVZiT2NhZFhkUWVZYWVoQmFVYjhjR2VCYWxkQWRDZ2xla2M2YkNleGJsYzRnYmRraGhlcGdEZHphOWNiaEhoWGYxYXNhRWgzY2hjVGFUZTJjUmRxaFVheGNrZVRhY2JBaHRoWmZWZmhmSWd1aERmeWEwZVNjUmdFZ3Boa2RlYlVnc2hVZmNjUmUwZmRkVGdSYmxjV2JkYkdkZGZ0ZVdiV2g5ZUdnWmF4Z1lhU2NUYUhlVmFLYkVhRmZJaFpmQWZuYXhod2RRZ21nOWZpZVpnbWhraFVoY2ZrYTVoemZFZUVkUWFGYlhmeGVsYUhoQWZUYTBmN2hUY0Nla2RSZ01mVmc4YVpkQmFqaHhoWGdKZnlkQWZVaFBiaWJSYVdmYWVRZjhnamNYYUVnUWdqYUNmVWZjYTNnQmh4ZFlmMGNMZzFmMWFLZldkemJsZE5jRGdSZ29lU2JaZjBhY2hpZ0ZiQ2ZBZ0piTWVEZEFhRWJXZ25oRWRWY1NhVWFFZlpjQmVIZTFkdWJMY1ZobGh2ZVJobWNjZVdhRWJrZHhoMWhTZGhjQmRTZlJkQWhzZ2ljSGJ4Z1ljNmZNY0NiaGNwZ0hmRmhoZU9oY2J4Z0JoTWNUZFZlRmFKZEZlVWE1Z3BkZGdCYWhld2VRY1NmQmFSZFZhRWc1ZGtkQmMxaGxiTWZVZFhnaGF3ZFZnbmZRYlBhYWYxZEloVWVjZ1VnWWdUY2ViRmVOZ1BhZWgyZ3BoYmRFYlVjY2g0ZVFnZ2ZwY1ljYmRUaEljT2FJZ3dlbGR1YVZlMmJRZnRoQWcxYTBhaWRFZTJhSWNCZlZkZ2ZGYjBlY2htZXBnemdaYnhnSmhuZ0djeGZKZ2RjWWUwYU1hWmJYYW1mNGVMY2NjRmZwYkNmYmYyZEphbWNhZFJoUmV5Z1RobmJNZVFmVGFFYTFjUmdTZFJlVmZHaFBjVGF4ZlJjSWIwYThiTGdIYVFlVWNaYmRiUWN4ZHplWGJGYWhlMGJXYmxoWmMwZURkMmF0YlNnRmFIZUZlR2RFYjNhaGVUY1RkMmRSZXFjVWd4Z2toVGFjZ0ZjbGNaY0Nja2c1aDZjVGR6ZkFlSmhKZXhobGdxZkJoZ2NOZGRjTmZsY1VkZGFTYndnUmVXZFlobmR0YWphWWFIY3BlUGJiZWpld2FTYVRoSGZWZ0tjRWVGY0pmRWZDZTNiQmdhaFFlbWU5ZmlmWmFtY2tkVWZhZ0ViNWhpYUJka2R4ZlFjVGZFYWxnQmZaZUdlbGMwZUdnSGVCZkJnZGNGYUZiS2hUZW5kVWNSZmNnMGF4ZFJlZWNIZUJnSmFkZEFmZGNqZkJjbGZ3YzRlRmdSZTBlSGRHZ3dhWWhqYklhbGVNaEVjRWJ5Z1JoRGVFZkFiVWdjZkJmUWVzZnJhRmZtZmRkR2VaZ0hiRWNmZlhlRGZoYk9oRWZ6YkphVmhHZlNkTmN1Z2FoM2VOZy9iVGEyZzRlOGRFaGtkeGMxYVNoaGFCaFNiUmNBZXRid2RXYmtlSmZ2Y1lhbWFaY3BlRmVHY2hjT2FlZHhmZ2JZZkJkUmhnYWFmR2h6ZEVoaGJQY1ZoOGM0aFFjV2hsZVJhUWNoZm9mOWJXY0NiQmdDZUxnamNBZTViRWNUaHdjUGhkZzBmNGhVYUpjVWM4aFRiSmVGYk5mSGhNZkNnSWNhYVNiaGYwYlBmUmF4ZlljQmRFYm1nUmRaZlpoRWFsZC9iWGFHZ1JkMGNTYjBmQmc0YkZjQmhSZ0JmTWIxZlphMGFiY25jWmV6ZmJoMGZaY25mRmhoZkpmTWJkZ1Vnb2RRYVVja2JRZ0xmY2FGYUljV2NKaHlnc2QxZ1plMmdzZitlQWJTYVFhUWdVZ1ViMWJaZkhjVmYwaEhlT2duZHBmbmJQYkFmNGRqYVVkVmFaZFNkZGJVaFZhNmVUaEZoZGM0Z1poa2ZOaGhlSGVIYjVmYmZHZkZidGRHY0VjM2JoZVRkVGcyaFJhcWFVY3hna2ZUZmNoQWR0ZFpiVmVoY0pmNmZSaDJmUWVUZmJkaGRZYjRkZWZVYk5nQWNPYlZhUmVPaFFkMmRZY2ViUGRTaGtiK2hjaDJkbGRiaFpod2RBZkhnV2ZXZVpkZmhHYlZmdGNJYklmWGZCZmFjUWVtYTlmaWdaYW1ja2JVYWNja2Q1Y3pkRWhFaHhhTmNCY1FmRmZjYUhoVWVOYTBoR2FIYkJlQmJkZEZiRmdLZlRmbmhVZVJoY2cwYnhhWWNZZzFlcGhXYmRkQWI5aHJiVWFoYlJmeGhSZGhjTmg0Z0Rja2FaYm9kUWdGZU1kWmJFZDNhQWFMZldiVmZZZlNnZWhraGRjc2dDYVdlQWRhZU5oamZZaGZlV2d5ZFZjRWVUYVFkZ2NYYkJkRGNzaDZkTmd5ZWNjcWdLYmliSmRRYlJha2J4Y29lU2NsZmhmY2ZGaEZoa2EvaERkZ2cwaDdlT2F6YVlnc2NHYWljQWRCYkpnMWJ4Yk1hVWdGZEVhUGRRZUFiQWdxZUljRmZFZy9nRGgzYlJmWmZIY2tmZGMxYVNnbGRsZ01mVWNYY2hod2FWYW5nUWhQYmFhMWFJYlVnY2JVZlplRmNPZ1FhRmdQZk5ibWNwaE9mR2VSaHNoa2RRZ3hjQWhGZ0hnQWNVZ1BjTGhRZFlhbWRTZ25kaGZsZlNhd2JWZm5jRmJCYzBjUmZHY1FiSWM4ZUpieWRWZDloRWJBZm9lb2FRYVFibGVtYWRnVWZvZVFhVWVrY1FnTGFjZkZncGZDaGJlMmVKZ21oT2cxYkVnbWNHZXlkRmJlY1RnRWFWYTdoU2FSYlZlT2dhZFhhUWNZYmNjRWNGZzBoVWVVaHBlT2NkZVJoRmM3Z0hmbGdGZGxlY2RGZzRjbWFEYjNlZGFPZkZhQ2NWZFBjRWZ5ZlJnVGhSZXpoWmFxZlRiUWhjY05iY2hBYU5jS2FSZEJlSmUzYVJnemFCaEljWmMwZ05ib2VVaDBlc2NVZGNmUmEwaGRjVGJSZGxkV2hkZUdkNWMyZGNoMmc5ZkdlYmMwZ0plYWRCZlNjWmJFYWJoeGM0Y0xkWGdIYUJmSGhRZ25nbGEzaGNoM2dvZkJnY2JrZ2hnemhRYWtkVmdCYWVnMGZrZlZlVGZtYmxlMGJHZkhjQmdCYWRiRmZGY0thVGZuYVVoUmdlaHhnZ2VaZU1nU2ROYVlkQ2YwYWNhaWdGYVZleGV4aFdmeGFNaHFlVWMxZkZiNmdkZ0ZkTWNJZkJlWGJrZEhlY2gxYllhU2dlaGtoZGhraFFnV2c1Y0tkWmVIYWxnTGVGZkhnRWZkYlNhUWFWZVFkQmdWYTVndWZkZ25oTmF2YlJobWFjYVdnRWRrYnhhMWFTYWhhQmFiZFhjeWJGaHdnV2hrZEpndmFZZG1kWmFwY0ZoSGFKZ09lTGNoYmxmQWJaYjFoRmNKZEZoVWE1YnBiZGVCYWhkd2FRZVhnUmJaY0Fia2ZBYWxhUWV6Y3dlWWVIY2lhd2ZwZ0JmamRFY0JmT2RSZzFoQWZNY0JmSmhXYUNmaGhvZEljTGNEZzVkVGVCYkJmTWI0Y0JiUWJrZEVlWGFTYTRmSWNNZ0JhZ2craERlMmJvaHJoQmNFYkFnamdIZFFkQmdOYlhhd2NNYjZnTGZTY0lhNmhJZ0FjaGRuYUhma2FaYUZlZGdSYUViNmdVYWtjUWdMaGNjRmNwY0NoYmYyYkpkbWFhZFJoUmh5Y0dkRGNKYkNoVGRCZjliUmhWZkJjVmNHaFBlVGN4ZlJjSWMwZzhkTGNHY1FiTWVKYlBkUmZGZ3ZnVWNGZUZlcGRaZWxoOWQwZlVmMmZzaEdiWGFEaGdlVmdIYVFnY2FmY0FoRGZOZXhmZWZSaGtkVGRjYUFkdGVaYlZiaGhKZzZmUmEyZFJhQmdiZWhjZ2doYkxmUmM1aEdkUGZ4ZzBiVmdaaHhlbGZXZGRmR2I1YzJjY2gyYjloR2NaYnhnWWdTYlRmSGhWYktjR2ZBaEJhRWVGZm5hQmNTaEViR2c5aDhhZWFIZWNiVWJKaGtoZGN6ZlRoRWN4YUZoQWcwZWtjSmJVaG1ibGU4ZENhMmNKZEJhZWJWY0VlZWFSZDNhd2FZY2ZnMmdaZ1JmZWdIZkJjV2VkZEFjOWZyZVViaGRSZnhiUmdoZk5jNGZVZTBkY2F3Z0liaGhwZktoSGNRZDloSGZGYWdmRWdTY1pnMGZkYnllVmNIZnRiWmdjZlhkbGFOaEZiQ2ZNY1VlRWJXZmNlWmNWYm5kUmN1Z2RkbmNOZ3ZmUmNtaGNkV2ZFZGtheGUxZ1NoaGNnZEdiRGVFZ0llamdWY0RlMGduY0tmeWNFZ2hkRmNHYTljT2dJY1JiQmJTZFVmMGI5Y0piQmhGZ2hlZ2hlYURnSmJ3aFFlWGVSZ1JhU2NrZjVhMWNFYlhnTmFNZVViWGNoYXdiVmVpaEJmSGRJaGdlRWUrZ2NlVWZZZ1RjZWRGYU5lUGFaZUdncGVUZEdkUmdOYXdnQWhrY0plOGJFaG5mcGdIYlphRWNGYXVjU2RtY1JiNWhTZzBibGQ0YUVnVGdkaE5hR2hWZFpmMGRiZ25hWmR6Z2JnMGRaZ25nSGFsaHBiQ2JKZVJkaGFmYkJmZ2h0ZGZlS2dRZ29oSGRZZFNiRWVxZkpnbGdvaDNkVGVtYTRiUWNDZmhlZ2hmaENna2FFZkhoSmNqZm9mWWZlZUViaGcwZ0NhbWJCZU9lZGZSY0ZhemdUYkZiRmc0YmNhRmFaZzBjRGUyY3NlQWFVZVNjVWZUZVFiVGFaZFRnQWFTaEVhOWVVZzFjRWJiZUpmRWFNaFFmQmFSYXdlRmFDZnllc2hXaFlna2JvYXdmTWFRZkphSGdmYjJlSmJWYkJmRmU0aGVlZmdYYVZmY2ZjZDJhOWdHZ1pmeGZZZlNlVGNIaFZkS2JFYkFhOWdOY0JoMWRwZGFmUWZtZDlhaWhaYW1na2NVZWNla2E1YnpjR2hBZVZhTmJUZkVnbGF1Zk1kMmJCZDRhTWRuYkJoQmNkZUZoRmNLY1RhbmFVaFJlY2MwY3hkWmRQY1hkQmNMaGRjRWRrYStnSGZGZWNmbGdEZTFnd2EyZVVhMGJkYXRnYWhnY2djemhFYjNmQWFMZFdlVmhZaFNhZWNrYWRja2hRaFdhNWVLZE5lamV3aGZhUWJTZk5mVGJIYVFiVWhDY2ZjSGZSYnVnZGhuY05odmJSYW1iY2JXZUVma2J3ZG9oUmVGY0VjQ2RGZUVnY2RwYVVnaGRCYmphWWNpZzljZ2VIYVhjNWZrZWNieGdCZE1oVGVWZUZmSmRGYlVjNWZwZ2RnQmJsYTRnRmh6ZXNmWWNEY2tnNWFsZ0VmWGRKYVJiVGNIY2dkMWNWZG5iSWRKZWFmMWRwYkFnZmh3Yk5jTGZLZUJkd2ZkZE1iRGVsZVRkQmNCZ01kMWNBaGxkQmJOaE9oSGdwY0hhWmhFZUZhdWJTZmplbGF3Z1FhMGFBZzVlVmJFYjVoRWVBYm5neGIwaGJobmZaZHpjTWRrZnBhTmFGYWhjSmNNZ2RjUWR4aEZmSGNBYWRmZmJPZVJhVWFNZmJjMmVvYXloWmZSZ1FiZ2hSZzNhTmRMZ1pla2cxZlJmU2dSYVZnT2JhYlNkSmRaaElia2NFZjliWGdVY29jTGViY2pmdGV6YVRjRmZGZDRkY2ZGZlpiMWdCZnliMGFIZ1dkamVJZFNjV2NqZ2NmZGNUYzJhd2dsZFdhaGhsaElhV2NnZHRlWmVWZ2hiSmI2Y1JjMmVSZUJhS2hCaDhicWdPZGhhOWZkZFBmbGFNZGRkQmdSZkViQ2hlZ0dkNGRrZ2ZmMmE4Z1BjYWF4ZlpkWGJSYVhhVWZSZ09hbGRKZ0VkQ2czY0JoYWdRZm1mOWRpZVpkbWVsYUdiTmV4YW9nbWVRZ2doSmhOaEJkUWhGZGNjSGNXYWtlOWFWYWlmTWVWaE5oUmM4Y0pjQ2J6Y3BoWGhjZHdkUmY3YWVnSGFCZFdjZGJBZDlncmVVZ2hmUmN4YlJhaGNOZDRhVGJFYzlhc2NZZGdmZGNSZFdkaWFNZ0ZhQ2F4YU5jZmVPaHdnNGVxZkJlU2hzaFljWmZHY1JmTGRXZmllUmhSYVVnVWFRZFZmZmdIZVJmdWhkY25oTmd2YlJjbWVjZ1diRWJrYnhkMWhTaGhnQmJTY1JnbGFnZmthQ2JBYXNlaGFKYldoUmhwY0NnV2I5Yk9hSmcwZ2tnY2ZDaEJhNGFQZ0ZoUmRwaERmZGRCaGhmd2JRY1hlUmhSZVNoa2I1ZTFoRWhYZ05jTWNVYVhkaGh3Y1ZlbWdzZ1BhS2ZsaHhnWGhNZUFmcGNmY2NhQWJjZkhkTGFUYmxmZmhHZVVkZGY4Z0Njd2R0ZmZjT2hIYnBlSGZaZ0VmRmF1Y1NhbWNSYzVoU2V4YVJjeGNIZVJoMWZOYkdlVmhaYXVoYmFuZVFlbWZJZFFmSWdpY1VjRmNzZkNhTWJBZDRlU2FVaGxma2VXZmNiQWI0YmJhUGd5YWNhcGFMYnhmUWJnZ1pnSGhNZFFiVGNFYjFiUmJTZVJhVmFPYWFnWGZRZFlmY2FFY0ZjMGFVY1VicGVSaGRhVWVKYjlhRGJ4ZUFiMGVQY0ZlNGJnZlJneWRJYkJkR2NIY0VnU2JHZGxmSmZUYlRkMmNSZXFoVWR4ZmtmVGJjY0FldGdaZ1ZjaGJKZjZlUmUyZ1JhQmFkZkVib2R5ZE5lZ2JKYVFkY2dWZk1nVGdEZ0Vna2hHZk9iRGZkZytmSmN5Y2NhUGFOaEJjb2FTZ0RhU2RjaE5jUmJSaDhoQmRSZlNjUWdKZVNnMmdaY0lmWmdtY2tnVWVjZGtmNWR6Y0VhRWF4YU5oVWFVZ2thVmZWZ0dka2U2aFhoU2JkYkJoUGFGZmtnZWhRZG5iVmFEY2ZoMGd3aFliZGVIYUFiVGZmZlJlUmdCZFVlaGhSZHhoUmJoZ05kNGJVZTBlOGg1ZlFlRmNNZ1piRWQzYkFhTGdXZVZlWWJTZlBkQmZJYXFhQWFqaG9lRGVLYnpoZGRMY1dobmFsZ0pnRWVVYjFmTGhXY25iUWNuaGVibmJNZnFiVGcyZ2RiTmNPaEVjeGUxY1NnaGFCZVNnUmNBYXRhd2FXaGtjSWU5ZkpoemhJZDhnUmRqYnhoT2NjaFVjVWNDZkNhUmNRaFBkWGJBYkFlc2RNYkJlcGN3ZlhmR2NsaFJhSGVoYWNjbGFWZURjd2FLaFVnVGNGZWFkVmduZlFmUGJhZTFhSWFVYmNkVWNZYVRjZWRGY05nUGdlZDJocGFiYUVnVWhjaDRoUWNnaHBkWWFiY1RndGVYZmRkRWNGaHpoU2JuZ0pic2dYY2doZGRrZkhmUmR0Y05jVGNWYzloNGRSYUhnWmF6Y2JiMGNaYW5iRmdoaEpiTWRkZ1Vnb2NRZFVma2RRZUxoZWVBYTRoS2FKYmpkRmFvZUZobGhWaGpjV2JIZE1lTmNUZkJkbGNSYVZod2d0Y1FnYWhXY1VlT2NlZlVhMWhlZVVmVWdwY09hZGRSZEZnemRUZ0ZnRmU0Y2NmRmJaYzBhRGUyYnRiYWZRZ0Rka2FQY1FiSGVZZXNhRGZuYmRlNGhVYXdkUWRUZVphaGg1Yk1lUmVRYmRiNmNRaFdkUWZUaFpiMGZaZU9oZWVVZ3NiVWFjZVJkMGFkZ1RiUmNsY1dnZGRHZzVnMmZjZDJiOWhPYU1lMWQ1YmJoSGQzYXNkMWZVYVVjWmJjYkNhMmgxaGFhRWhHZjlhOGJlZEhmY2JVY1loMWNoZzZlSGdHZVplTmRVZFVla2JWYVRibWZsZDBoR2VIZEJiQmFkZUZlRmVLZlRlaWhGZFpoT2ZoaDlhWWNVYm5mQmFXY2RkQWM5ZXJiVWVoY1JneGJSY2hhTmc0ZVVjMWRWZmtiWWRsYXRnTmJXYnpkbGFZYVZneWNsaFRmYWFsYmRia2JYZkdlNWJhZ1plQ2FWY0xjUWRIZWdmUmVOYjBhMGJaYVZibmRSaHVjZGNuZE5ndmVSYW1hY2NXZUVoa2Z4ZjFmUWNrYVFiYWhEZ1ZmaGYrZEpnUWROZCtoZGhHZlphMGRGZEdmSmJPaExheGNBYmVjUmRGYTFlamJGZlViNWJwY2RkQmNoYndmUWVYaFJlUmVTZGtoNWUxaEVlWGZOZ0VhQmdUY0FhNWFCY1hlcGN3Yktka2JFZEdhY2ZWZXNjVGFhY0ZhTWFUYVpoQ2hOZGFjRmFUY2xmd2ZDaDFnbGVXZEVlbmZwYkhoWmhFYkZhdWFTZG1lUmQ1YlNheGN3YmxkVmRWYVFlZWhGZ3lka2MxY2VnbWE1ZHplY2JrYlplM2RGaGtmNWVNZ01lRWhNYWNmZWZFaFFjTGJjZUZkcGVDY2JkMmFKZG1lYWJSY1JneWFUZW5kTWRRZUdhQWJVZ1ljR2hoYnhiVmJRYjNkUWZZZmNmRWRGYzBkVWFVYnBkT2FLZERhdGV6Y1RiRmVGZzRoY2ZGYlpiMGJEYnliMGhIZVdkamhJZVNjV2hqYWNlZGdUZnpiZGRpZkJjeGZBYVRiS2Z5Y0ZoWmNWZGhkSmE2ZlJmMmNSZUJkYmNrZHBna2VLY3dkNWRBZkpnRWQ5YVRlVGdSZ0ZlOGNkZUdiNWYyZGNhMmc5YkdiWmN4ZVlnU2ZUZUhlVmRLZ0djQWNZYU1lUWRpYk5jVWJQY1NoNWF5YWRhbWRrZEphY2dsZmhmbWVCY1ZiOWdZYlVnVWI4ZVZhR2dtZUJhNGFNZm5hQmFCaGRhRmZGZUtjVGNuYlVmUmNjZzBneGZSaGVjSGRnZ0NkUGJFY1lmNGRYZEdic2J3aFZmd2NWYjRnVGRrZThhd2NhY2tnMGZIZ0RkWGNBaGFjVGExYjhoZWVVYUVoZGZrY1FnV2E1YUtkWmFIZ2xhTGhGZkhiRWhkZkhhVWFWY05mSGRqaDBmOWFlZ0Fid2F1YlZoWGNVYVdiRGIwYXhobGJRZXhmeGM0ZFJhQWV0Z3dnV2ZrZEpodmJZaG1oWmhwY0ZmSGhKY09hZWMwY1FjRWdCY0FnSmJIaGFmZ2I5YzllYmVCYWhndGJRY1dnUmdZYVJhbWJSYTFhRWFYZE5hTWVVYlhkaGZ3YVZhbmZRZlBoYWgxZkpjQWdPZVFlOWRBYVVhbGFOZlBnWmNHYXBlVGFHYlJiTmJ3ZENmMWdsZ2ZmQ2hWYkJoSGZaZkVjRmJ1YVNlbWNSZzVlU2YwY2xhYmdIZVJmMWJOY0dnVmhaYTBiYmhuaFlnMWdPaGdoZ2NrYlFkbGVzZkRkT2YwaHBhUmJXYmhlQWNIZGNmQWFoaExlYmR6Y2xhTWVhYVJkUmJ5ZFRnbmdNZ1FhVGhFZDFkUmZTY1JnMGFjYmFoV2JrZ1liSWdrZUVob2VEY1VlcGFmYVpkUmdoZy9iWmVsYUZoNGVjZUZmWmgwYkRjMmR0aFNhRmVIYUZkR2NFYjNiQWdIZ0JieWQwZzViWGdXY1pjU2NZZEJkdGRaZVNkeGVKZXFnVGdtZmhjcmRiZmtkcGRrZ2VlVWJzYlVnY2VSaDBmZGJUZFJhbGhXY2ZmRGdvYytjT2ZqY3hhSWVHZkZmY2FEYVdobmhWYlhnRWJFZEpmTmVCZDFjcGJhYVFjbWU5Z2loWmFtZGtmVWVjZGtnNWR6ZUVkRWR4Y0ZiQmJRY0ZoY2hIaFdmY2RMZVdjV2dOZ1RiZGRFZ3hiS2ZYZm5kd2VkY1dlVWJ4Y1JlZWFIY0JhV2RkYkFiOWJyZFVlaGVSaHhmUmZoZHNnc2dHYndiWWIzZVpmQ2V4ZVloQmMyZWdhTGhSYUZiWWdDYmNnMWR4Yk9jUWVXZjVoS2NaYkhhbGZMYkZlSGNFZGRiSGhRaHRoV2JCZUhoUmZtaFhmSGVOZ3ZjUmRtZWNjV2NFZ2tmeGIxZVNlaGZCZFNjUmJGZzBleGJDaEVhSWVtZVlnbmN0ZHBoUWNRZ2toY2NEZGhoQWhRZUVmVmdFZ0hmVWJCYmxlcGNQZkJjQWJkYkFnQ2VBYlplUmZCZjRlNmNSYm5oc2dlYlhmWGdoZWxlWGczZDBoRGdhZHhkY2JVZ2JiRWdZYkRhZGZGYU1hQWhaZ0hnZGFUaFRlUmUwZjhjVGJoZ2NoUmNSYmpoSmZjZFRoa2VGY3VlU2htYlJjNWhTZHhkUmV4aEhhUmUxZU5oR2hSYWxhMGhjYkhlWWEyZGRmR2N4aG5hRmZoZEpmTWNkYlVob2RRZ1Vja2hRZkxhY2dGYW9oSGhiYzJlbGE3aGFhUWJGZVlhVGNuYk1iUWhUZUVkMWVSYVNoUmJWYk9mYWRYYTBhWWdLZjJkdGMwZFViVWVwaE9kZGhSYUZkemVUZUZnRmQ0YmNlRmNZZGlmVGJqaGxlU2NXZ25mRmFiYkVkeGJVZ1NlR2h5aHhna2RIYmxnQmZkaGVhQmY1Y1ZoVmhsaDFiNmJTZG1jUWJFYlpnMGZaZE9jZWFVYnNhVWVjYVJnMGZkZ1RhUmRsYldhZGVHaDViMmhjZjJlOGdWZFpod2VzZVNiSGhEYlFiWWZRZHhhY2V0ZVJjU2hSYlNnRmhtZ0VneGRLYmllQmJYYk5nMGFZaDJlSGdFY3diSWhVaFVjSWVWZkFnR2RCYjRjR2hDZEpjSWNiZTNkdGZLYlRlbmRVYVJiY2gwZXhjUmJlZkhnQmZXZWRiQWY4aC9jR2ZsYzBoaWJTYkZiNGZ0YUhleGVzYXRmT2VoZzllQWdHZzJiVWVMY1JmMWdaZ2NnZWZsY2hoa2JEY3lic2VkZVpkRGFGZURlZWdUYUJhSmdWZlVhTmNKYUdmU2hOZm1nSmdIYjljdmJDYkdlNGFmY0VibGNaZzFlQWF4ZGxnY2FCYVViOGcwYlVmZ2V3aHFoTmJXZFljaGhIZ0NlRmJIZmVjZ2Z0Y21hVGdWZ0ZnSmhGYVVhNWZwY2RoQmFoY3dkUWJTYmxlN2RTYmtkNWYxZkVhWGJOYk1nVWhYY2hld2FWY2lmWmFLZFBkd2ZkY0dlUGgwZ1pjSGJNZEJib2djZGZiMGhCZ1RiR2FSZ05hd2dDZDFjbGZXZ0VmaWFkYXRmWmJFYUZidWRTZm1oUmQ1Z1NieGRRZG5oWGFFaDllTmNUZkZkWmVwZmJkaWQxZFphYmgwYlpmbmhGZGhjSmNNZGRkVWJvZFFlVWZrYlFkTGRZZlVneGNZYmJkeWZwaHViQmJGYlVibWZCaG5hMWdBYkFieGVwZFpnV2dBZ05mQ2FhZVdkRWdSYWVnVWIxYWViVWVVYXBmT2JkYlJhRmR6ZFRmRmNGZDRmY2ZGZ1pmMGdIYW5jdGZJZEZkRGJsZU9oZmRqaGtlSGNCZTJhb2E2ZkhmRWc0ZGJhWWVSYnRnVmNWY2dlZGR6YlRobWZoYXJoYmdrZHBka2hlYVVmc2RVZ2NhUmEwY2RnVGZSZWxiV2NaZW5jUmYyaE9lMmVjZnJiSmVrZUpoYWdRY2llVWZGYlJmMWJwYVdjQmQzaEJmUGhTZTJnWmd1Y1RkR2drYVVnY2RrYTVoemVFYkVkeGROYVVmVWNsaEllUWNrZU5hMGdHZ0hmQmdCZ2RiRmVGZUtnVGhuY1VoUmJOZFVheGhNYmVjQ2h0YVdkWmFSY2xheGhVZ2xneGE1YlZjd2ZWZXhiWGcwaDlhMWRlZGtma2daZldhM2FnYmFmU2FWYThmZWhlZWxlVmUrYVFkU2ZaZ0NjZGRuY0JnTGhTZldhb2gzZkhlVWYwZFpiVmduY1JkdWdkZG5jTmduZERkbWNsaEdmUWJBZU1naGJCYlVnUWVMZUZlRWc1aCtlSGNCZUFnZ2ZMZHdmUWRnZFFmQ2FGYk9kYmdoYkFlQ2ZSYkZmMWJqZEZmVWU1ZXBlZGNCZWhod2NRZ1hmUmhSZlNka2ZZYzlhSGV5YU1oZWhIYWlid2IvaEFoaWMxZWZmTGhsZHhoU2dJYndjbGNlZEZlZ2NZYUNoSmZpYzhiQmVHZFFhNWJ3Y1dnRmFCY2FiT2JIYXBnSGhaYUVnRmR1Y1NhbWJSaDVoU2N4ZVJjNWhWaFJiTWJkZFNleGNrZWdnSWhTYUlocWZQYXdlTmJwZ1ViRWNBZ0RnT2REZmxhRWRBY0FlMWdGaE5mMWhwZmZoYmN5Y05jdmVaZlRnNWd5ZVRobmhNYVFnVGFFaDFoUmVTZlJlVmFPaFlkVGZ3aFdiSWJCYU1iN2ZCZ1FhVWNhZ0xkRWRFYTJiUWdnZ1VjM2VIYWdlTWQ1aFRnU2Q0ZEFkRmhHZXhoR2NWYVNoMGRkZ0RkRGRBZ2pjSGhGY2NoVGZlZkFhSmNaZERiVGVoaDZoUmIyY1JnQmRiZ2tkcGJrZWVmVWhzY1VmY2NSZzFjUGJDZEVlMGNEYUpoaWdCYTJlWmRYZnBjVGhkZUFkQWNTZVJnbmZVaGVoV2NCZnNkWGZCYlFnOGViaFVlM2VsZ2loYmhXaGxlQWRPYmdiY2JnYUhnamNNaE1lUWRWY2tkT2VaZEdobGIwZkdhSGRCYkJkZGFGY0ZlS2VUZ25mVmVNZWVha2FCYTdhZWJIZEJlV2VkYUFkOWhyaFVlaGdSYnhkUmVoYnNld2ZYYVJlOGIyYUphUWNkZVdjUmd5Z2xoYmNIZUZjaGZHZk5nVGJRaHdiRWN5ZWNkRWNJZzNmbGNXY0ZmRGhkZ0lnVWF3YjVlTmJIZHphc2ZnZ2RobmFzZjdjVGMyZWRoTmFPYUVieGcxZ1NoaGNCYVNhUmFBZHRmd2hXY2tmSmR2ZlliamVKaHBmQ2NYaEllYWhjYzBjd2VRY1RnVWJCY1pkRGJtYlJicGhkY0JiaGZ3YlFhWGdSaFJkU2FrYTVjMWNFZVhnTWZhYUVmQ2FwZXdjQmFIY1FmU2JhZnhnUmN2YUpiVGRzYVRoSmZBZzllUGJLZWlkOGRFY0dkVmN0ZTRlWGcxY0JlTmZPZUhlcGRIZFpnRWVGYnVlU2JtZFJhNWdTYXhkUmR4ZUhjVmFRaExiR2ZWaDVhMWhPY2pkNGU2Y1BnRWVnZ2dnUWRoZW9oZWRmaEVoTWNRaEFhQWhGZGZhSmJRZGdmTWJiZnphWWd1ZUlnRWNkYjhkR2NqYXhlK2JHaFFiQWdUYURoRWNkZEdjWWdIY3BhTWFQZnpjSWNnZ0Fod2RNYkFnTWVoZWtlbmRSZ1VncGNTZmNkRmZaYjBoRGcyYnRiU2JGYUhiRmNHZEVoM2doaFRmQ2NTZnNnNGFVaHhmRWQ1Z2NhQWF0ZlpjVmdoYkphNmhSYzJlUmNCZGJka2JwZWtkZWZVYXRoQ2ZNZkVoOGZkZEJkQmJsYUxmZGhEaG9lK2RPZ2pkeGJJaEpjRmVwYmRmQWdqZUJkQ2RHY1ZhNWVFY1RkbmNCY0hhUWZpZkVlbmJNYldjbGIxZUlnQmd3aHljU2dVY1JjYmhSYlVlQWRaZlRlaWNaZjBoQmFYZEJkWGdaYTBjcGhnZVRlbmFVZVJnY2cwZ3hoUmZlY0hiQmdXZ2RnQWc5Y3JiVWJoZVFmK2JSYWdnMWRsZVVoMWE5YmtnYmFGY1VjemJFZjNoQWFMZldiVmRZYVNoZWJraGRka2RRZldhNWVLYVphSGZsaERlWGFYYTloWmdWZ0Jlc2JSY0JjSGQxYWloZGhuZ3NhcWNQYlNnaGNyY0VnbGRGZzFmQWR4YjRjQWZBZlVlWWV4YkVkd2J3YnJlSmR6Z1JkbmJRaERkMGZnZUpjbGIwZ09lQ2FBZE5jQmZIZkVnQWM5ZU9jMmhzZGtmRWZ6YzBlZmZEZVVjWWdoZkdoSGdwZ0FmVWRUZkZhK2RFYVNjQWNIaE9hVmNzYWRmYWRtZ3dkVGJlYUZnTmRQYVpkR2VwY1RnR2hSZ05jd2FDZDFnbGFXYkVnamRWZEtoYWFXYXRmdWhTY21oUmg1YVNheGFSY3hhSGNSZTFjTmRHZlZnWmg5Y2RhVmF4ZnpoYmQwZlpmbmFGZ2hiSmRNZGRiVWhvZVFjVWVrYlJmWmVOZFFmNGNYZ1BiU2N4YW1kWWNWZkVnSmNBZFhjTWFkY1RkRmR3YXNlU2VRYWhkT2JJYkhkcGdNYVBheWQ4ZWhmSGRBY2djTGZKY3hnbGI2ZVFlZ2RVZjNnQWd3ZUllbWFSY2lmVWdWZkhkQ2JWYlBiR2FuYlJjVGdDZm1nb2ZnYkhoRmNCZmRmZWhBZ2xkYmNYZndhbGJRaFJjMmJSYkJnYmRrZXBka2JlYVVnc2VVZ2NnVWhBaFVmUWFUYU5lV2hkZ0dnNWMyZGNlMmM5ZUdmWmh4YVllU2RSZ0RmMWZFY1FkQWJBYkxkWGF6ZzhjT2VHZnpiOGhuZ2FlQ2NoZVFoTmNrYTVkdWNFY0Fob2FZYUhhd2FwZ0JhQmR5YVliNmdHY0hnZ2FWYmZmVmJFZFJiWmVIY1VmUmdjYjBoeGRSZmVkSGRCZ1diZGFBYjllcmdVZmtlSWR3Y0ZhQmRNZHFlVWIxZ0poa2NQZ2hhdGZRZVFoSGc1ZTBnR2dFZ1loQ2hlZ2tkeGRrZ0ZkV2hBaDFmSmhXZmxjYmZHZkZic2NkZEhiVWcwZ1plVmFuYlJidWVkaG5kTmV2aFJkbWdjZVdhRWVnYVZjMWJWZXhhQWdBZlJkQmFWaHVjUmVFY0pnK2VkZUhoMWVEY0ZjSGhKZU9mY2V4aEJlTWZUZ1ZnRmNKZ0ZoVWg1ZXBkUGFSYmhjN2VYZ0hjUWFGZ0FoZ2JjYm1jSGR3ZndlTmVRaEdoNWh3ZVhoWGJSZWJmWmJTZTFhVmhZZkZiQWZJZFVmbGFOZVBoWmNHZHBhVGVHZFJlTmd3Z0NnMWZsYVdlRWJpZHdkR2dOZGtjRWRyYVNibmZsYzVkQWRoZlJodmhBZ3dhTmhOY0NlRWNCZHZmUmFIZ1pmemRiYzBjWmVuZEZiaGJKYk1mZGVVYm9lUWNVaGdnRWZMZ2VhMGFkYkNjT2V5ZW9kdmVPYmhob2ROaERkMmVBZkNoVGVFZVpiUmdIZ1Jkc2d4Y0tnR2JjYktjYWIyaHRkMGhVY1VlcGNPYWRoUmZGZHpiVGhGZkZnNGNjaEZoWWZpZFRmamJsYlNkV2EzY0ZmYmRFZHpnMWNUY1VmWGJwYTBlVWZ3Z2dhRmJhYnliRmRaZ1ZkaGRKZTZnUmcyZFJkQmJiYmthcGJraGVmVWd0YUdiTmNFZWxiSWNIYzFmZGFXYWZkRWVSZjJoY2EyZDloR2FaaHhoWWFTZlRiSGJWZEtlRWJGZkpkRWFDaDNlZ2hWZVFkbWNSZi9iWmRqZzFmY2FPZHhjMWY5aGJjd2gxYlplU2ZVY2tkZWRUZ2plMWU2ZVpkemNGYVZmYmRGZ2hmR2FaYUhiVWhSY2NmMGV4Z1JiZWRIYUJlV2VkZkFmOWFyYlVkaGdSZ3hlVGFrZ2Nnd2RHZGhjeGhxYUZkUmRJZkpjQWMzY0FkV2RXZVVjQWhIZ2JoMWFSZXhhUWVXYWhjS2dOYW5lQmZIaFBhbmNFY2RkSGRVYTBnWmRWZG5iUmR1aGRobmZOZnZkUmJtY2NjV2JHYWhlZ2Y5ZUFmMGROaGNiT2gwYXBoaGNUZkVmSmh5YllibmRCZjhmQWRXYUZiYmdjaHhjWmhNY0JiRmhoZEZkUGQwaDVlcGhkZUJmaGJ3YVFoWGJSZlJmU2JrZjVjMWFFZVhnTmJNYldnU2Z3ZTRmSGh5aGNlQmVGaEJlTWNIZFljMGRZZU9hZWFFYVZnYWNjYVhhbGJHZEdnUmJWYndhVGFsaEJjYWZPZkhicGRIYlpoRWhGZXVmU2ZtY1JoNWFTZHhmUmR4YkhhUmIxYU5jRWJRYklkOGJKZnljVmI5Y0VmQWhkYnpoRGJoZ0pjUmVkZFZmd2VGYVJkMWhjaGVnY2RGaHhkQ2FJZkdndGFxZ1FneGFSZ3loVGduZE1mUWhUY0VmMWhSZ1NoUmNWYU9mYWFYYlFiWWZKZUFla2U5Z0FibWFCaE9lZGNSaEZkemNUYUZiRmI0ZWNlRmdaYzBiRGQyYXRlYmNEaDFkdGRHYkVkM2FoYVRjVGUyYVJmcWdVZnhla2ZUaExnUWFKY1ZmZmFCaEphNmRSYjJoUmJCZ2Joa2NwZmtnZWRVY3NnY2FPZVJoTmJOYUhlMWhZYUNoT2R6Y29odmJJZnllcGJJZk5lRWVOZFFlR2ZDZmNkTGNVY3djWmZFZ0ZhbmZBYWNkRmN5YkVhaGNNY2liQmViZFBoRWY1aDdlUmJFZ1ZkTmRDZG1jTWJWZ1RmbWZsaDBmR2ZIY0JjQmVkZUZoRmFLYVRmbmFWY0RmTmZoY2dlRWNLZ2phNWdXYUliRWFjZWljQWJSZm9od2ZBZGxoZGF3YkJmMGZFZm5lSmFoYXhmWGVWZm5iZ2JDY1ZkeGhoZlhiUGdRYVlmd2RCYUdhWmNEY2JmV2dKY2hlRmFIZUVoZGNIZFVhMGJaYlZibmRSZXViZGJpZDVobWRTZWtkMGRXZ0Vja2Z4YzFnU2VoaEJmU2NSYUFldGR3ZlVjZ2RwaGhkTWhqaFFkbWhRZ0RnMGZhYUtia2NBaEpjUWF4YndjY2JXY1Jlb2FnZUpkRmZRZXBhUWNXZGxlUmREYkJkc2U3Z1VjaWVjZkZoSGRqZ1pod2FYZGlnQWVHZWFod2NrZithY2dVYVlkVGRlY0ZkTmFQZVpnR2FwZlRhR2FSY05kd2NYZVJkZ2hFZkVnaWVoYUhoZWdVZEVoNmhBZWliMGFxaFJhV2VzZ3diRGJRZTFoQmVNaDFjWmgwZWJlbmZaYnpjYmYwaFpjbmVGZmhmSmRNZWRhVWRvYVFhR2gwZ1FmV2NjaEFjNGZLZkpoamRGY29nRmVsZlZoamVXZEhmOGY2Y1RnRWMxZ1JhU2NSYlZmT2RhZVhlUWRZaGNjRWhGZTBoVWZVZG9lTGJkZVFoeGd6YUdlQmRrZnhlSWExZWdiTGNUYW5oaGFBZkdmRmJ0YkdmRWEzYWhoVGdUYjJnUmRxY1VheGdrYlRhY2NBY3RhWmVWYmxhMWg2Z1dnbWJRY1ZoSmZnYk1iM2JkZXpjUmZWY1pjUWZVYVJnWmJ4ZWxlV2VkY0dnNWMyZGNlMmg5Z0doWmR4Z1lnU2NUYkhmVmRLZldjRmZKZFpoQ2R5YlJlVWJQY1NiNWd5Z2RjbWdVaCtnY2RrZDVjemFFaEVneGdOYVVmVWhrY1ZjVGFtYWxjMGVHZkhiQWZQaGRiRWJ4YUtlR2VuZHRldWRNYWxnMWFIaGRhRmVwZ1doZGhBZTlhcmRVZWhkUmR4ZlJiaGNOZjRmVWUwaDloa2FhYWdoQWJaaERibmJCZ2ZlVmN5ZWxlVGdhaFZoVmZvZWFnMmQ1ZUtmWmNIZmxoTGVGZkhjRWRkZkhiVWMwYVpjVmZuaFJndWFOZTNjTmR5YlJlamNNYVlmYmVRYzFjaGVVYWhheGM0YlJnQWd0aHdkV2RrZEpndmJZZ21nWmZwYUZnSGdKYU9hY2N4ZkFjWmRUYlVkeGVKY1JoMGc1YmpjZGFGaEJoOGVhZjNmUmJSYVNoa2Y1YTFhRWhYZ05kTWdVaFhoaGF3ZFZlbmZRYVBnTGhWaElkSmZjZVJjTWJUaFpoa2MxZFJhWmFIZHRhRmhBYWpkbGh3Z0NjMWFsZ1diRWZuY3BoSGNaaEVmRmF1Y1NhbWdRYi9jU2d4ZTlic2NIZVVjOWJOZ0VlMWJZZDZlZGNWZ3hnemNiYjBlWmFuZUZhaGRKZE1hZGVVZW9hUWFVYmtnUmZkZ01kUWRoYkNhSWgyaEpnN2JhaFZoSmZ5aFViR2cwY09mVGJGZnhmSGRVY2plOWJPYWFlWGFRaFloY2hFYUZoMGFVZVVhcGdPaGRkUmZGYTdnQ2dsYUZlK2RiZFZkWmNpZkdjbmM1ZkJlQWZYY2hoS2NFYzNiQWRWYVRoMmg5YjNlVWMxaEFiVGFlY2dmc2NSYlhneGM1ZDZhVGN5Z2hjQmdaYVZkZGZrYlBoMGJzZktmYmd3YU1oZGNYaEFlOWZmYmVhR2c1ZStnUGQyZzliTmZlZGhiWmdBZFRlSGI5YUtlUWgxZ3RmZmdJaFhhQmVhZFFjbWc5aGljWmZtYmtoVWNjZ2tnNWh6Y0VkQmNvZU1lQWgwZGxhV2VUYW5nUmYwZ1ZlSGhCZWZoYWNrZjliS2FYYTJmTWRLYldoVWZ4aFJhZWhIaEJlV2JkaEFiOWFyZVVhaGNSZnhiUmNrYkVlOWFCZ3hlb2cyZ0plRmRNaFJkT2hYYkFkTGNXZFZhWWNTZ2Via2JkZWthUWFXZTVoS2RaYkhhbGJMYUhoRGgwZWRiR2UxYkFkWmJRZUdiRmc3ZVpiV2haYm1oU2RrZDBoV2hFZ2tmeGQxZVNnaGJCYVNjUmdBZHRld2JXZ2tmSmF2aFlkbWQ0YWxjRmdIZ2xmVGZjZjFjbGFNY1JnMWhFYkhlSGdFYkpmRGFkZEJhaGh3aFFhWGhSYlJjU2NrZzVkMWZFY1hoTmVNZ1VoWGVoYjRjRmdYZ1FnRWRkY2xjSmNZY2NnVmhnYU5iWmdsZ05iZWNjaG1lTmdmYU1neGhOZndmQ2QxZmxiV2ZFYm5icGdIYlpnRWRGZnVjU2htYlJiNWJRYjFnaGJ4Z0did2ZCYU5lRGgwYk5iaGJmY1dhTmc2ZVljMmF4aG5iRmFoZ0pnTWVkYVVhb2NRYlVia2FRZExnY2JGZHBlQ2diZDJkb2RxY2FmUmg5aHZkVGFqYllmUWJSYmtmMGhaZVFjQmNsYWthYWdYYVFiWWNjY0VhRmUwZlVhVWVwZE9iZGZSY0ZiemJUZ0ZoRmJ3aE1oMWZaZy9nRWZtYnNkZWZGYUdkOWhZYURiWGdoYUNhV2JXaDFibWdlYVJha2dUZmNnQWF0ZFpkVmZoaEpjNmRSZjJlUmRCZWJma2VwaGtoY2hRY2dkVWZlZGdiQWdkYkhneGRsZGNjZGRDaDlnL2RmYzBkVmhHZVpjeGZZZ1NnVGFIZlZlS2ZFZkZnSmVFZ0NnM2NCYmFlUWFtYWNjaGdaZW1mOGhKY2NjbGhoZm1iQmVWaDllWWdXZ0VmVWEvY1RjbWNsZjBoR2hIY0JhQmNkYUZkRmZLY1RnbmZVZ1JnY2cwZHhoWmJPYjNjQmZkZGFhUWI4Z2llVWNoZzVleGJGaFJncGMwZmVnVWU5YmthYWVsZ01oWmNFZzNlQWFMZVdoVmVZZVNhZWRrZGRma2hTY1NlMWVLYVlkbWdSZExnQWdtY1FnSWZEY2xnZ2hRZVdmbGI1aHVoZGJuYk5kdmRSZG1jY2hXZEVna2V4YzFkU2doY0JoU2JSaEFmTWZ6ZFdia2NsY3ljWWRpYU5ocGJIY25iSWVBZ2VjaGF4Zm1kVGNWaEZnSmRGZVVoNWRwZGRnQmVoZHdnUWRYZVJnUmJTZmtnNWI5ZVVobmROZEtiVGdIZGhjbWhRZDJmRWdjYWZnbGFzaFlkV2IwZlljVGdlZUZhTmhQZVpjR2JwZVRnR2JSZ05md2RDaDFjbGJXZ0doamFsYkhoYmIxYXhjdWJCY1djUmV6aFNlMWN4ZDRnRWZUY2RiTmhHYlZhWmEwY2JjbmRaZHpnYmEwZFpobmRGY2hoSmFNZWRjVWRKZ0VlR2FnZTFjWWZmYWlnVWdEZGZhM2NKYm1nZGRCZlJla2RXZjJlWWdEZFdiVWMxZFhhU2FVZUJmSGVaYlZjNGhZYWNjRWVGaDBiVWVVaHBkT2VkZVJiRmF6Z1RlRmdGZTRoY2dGYjRkZ2JSZHlkSWVCZkdmZ2U0ZEhmQWJtYjVkVGRVZm1mUmM4YVJjZ2h3ZkFhWmNRZXRjZmZWZ2xjUmF6ZVNjMGg1ZkJkYmRrYnBja2hlZlVlc2VVZmNoUmUwZWRkVGFSZWxkV2dkaEdnWWNpZU9ieWVZZVZnYWhXZmxoVGdYZjJhZGhLYURkVmFKaFNjSGNtYVZmSmdWZjJlOWZrZlpkaWFVZWRiZmhtYlJoemNFZkVieGFOZVViVWVrZFZjVGZtZ2xjMGVHZEhkQmRCZmRiRmFrZGVmQmFqZHhmQ2JmZ1RkTWZRZ2JlR2VoZFdhYWJRZTlkOWNSZXdlRmdpZFVheGFOYSthVWh3YnhhdGhaaG5ha2FaZUViM2dBZkxiV2dWZ1lkU2ZlZmtiZGJrZlFnV2Q1ZUtnWmRDZjBlRGJYaFNnSWMzaEhhVWYwYlpiVmJuZlJkdWdkaG5kTmR2YlJlbWJjZVdhR2QxZ2RiZmRTZ2hjQmVTZ1JiQWR0Y3djV2hrZUphdmVZYmpidGRnYUdmRmJoaE9hY2Z4YUJkTWVUZ1ZhRmNKYUZkVWI1ZXBhZmJGZ0JiK2hFZlNiWWVlaEhnZ2FFaGhhU2dDZ01iSmVYYnpnd2E1Y0FkSGVRaFNnYWh4ZlJkQmJQZHdkVmVIY01lUmN3YkJiWmhHZUlnSGNFZ0JhTWNyY0llVmZsY1doRWVuZHBhSGZaZUVhRmJ1YlNkbWJSYTViU2gxYjBlM2dIZFJiVmRkYUdhVWN0YnBoYmFpYkphOWVFZkFiZGIyZ0FoQmdKZktkY2gwYW9mQWZVZ2xha2hXZWNkQWE1ZU1lRWJDZU5lMWVlZHhlUmIwZFNnSGhNYUFkVGVGZUJlTWVTZ1VmRmNBZEZoamZVYk1hYWVFaGhoMGhDZG1kQmhPZmRiUmNGY3poVGRGY0ZjNGNjZUZlWmYwZkRjMmV0Z1NkRmZEZmdoQWhFaDNiQmdEYlRlM2JsZTNkVWMwYTBhZGZEYTBlcGFKYlJkaGJ0YTZoRWZ5YndlVGdJY1JjMWNrZEhiQmdsYkdnUGdrZjhlVmFUZTFlMGVmaEloaWNjY2xmT2ZpYUFoSWJaZjFmUmZMaFRhQ2U4ZVBkUWZoYjFhR2hBZW1ldGF3ZFFhbWQ5YmlhWmRtY2tkVWZjYWtiNWF6Z0VnRWF4ZE5lVWFVZmxhY2RDYkdjbGI4YkNnWGVCaGNmYWJWYUViZWZRZEFkcGVRZVlnMWF4YVljZWhDYUlhVGJJYUZnb2E1Y0hjQmZSZTViRWVsZ3NneGZBaEVmRWYyZExleGc1aFlnV2ZqYzVnUGJIZUFlUWZTY1pnMGRjaHFmQmJEZGxiS2NMZEhkRmNiaEhkWGZnY1JmSGNSZGxjUmNIZHlmZGMxYVhmSGVOZHZlUmNtY2NkV2NFaGtoeGQxZlNjaGRCY1NmUmhGZ1pjYWhXZ2tiSmZ2aFlnbWNaY3BnRmJIYUpoT2JjZHhlQmJNZUJkQmZkY0piSGNSY3BnbmNNZzBjeGE0YUZkVGJ3Y1lhR2FVZmRmOGdPZjNjTmZNY1VjWGVoYndhVmNuYVFlUGFhZjFkSWhVZWNmVWNZYlRoS2VoZFliYmhNZ1RjZ2VkZ0dmUmJ0Y2FiQ2ExZWxlV2hFYm5kcGFIZFpiRWZGZnVnU2FtaFJnNWJTZ3hnUmV4YkhnUmdVY1plVWhSZDhibmhZaENoUWEyY0lnZ2hjYXVoV2RGZ1ljSmhKZTBob2ROaFVoaGZCZURkT2VRZ2xiTWRMZ0NnNGRwZEpnMWRGZzZhUmczZW9nY2ZaY2thMWNSZVNjUmVWaE9mYWhYZFFoWWhjYkViRmEwZVVkVWFwYk9jZGVSZkZiN2ZHZkJia2Z4Y0ljMWdnZExiVGRuYXRkQ2JGY0dneGFHaEFhM2dGaGZhWmdXY1JncWhVZ3hja2ZUYWNoQWJ0Z1pjVmNoZEpjNmVSZzJoUmFCaGJha2dwaHNiTGdRZE5nZGdJYWhjTmVpY0RlQWNoZ0FmZGZIZ05jMmJZaDJkWmhLYVRmUmRZZ1NjVGFIYVZjS2hFZUZjSmFFaENiM2FCZ2FkUWNtYzlnaWJaZ21ha2VjY0pjZ2ZZYzZnUWQwY0lneWZFYkZnb2NIZ1RkbmNSZjBkQ2VIZWxhTmNYYWxhRmNLZFRnbmFVZFJnY2YwaHhoUmFlYUhiQmdXY2RlQWQ5Y3JoVWFoYVJiNWVFZWxic2J4ZUFlRWJFZ2JkS2YwYWNiQmZFZzJnMGdMZlNiVmc4YmVhVWFFYmRia2RRZ1dkNWZLY1poSGFsY0xoRmJIZkVmZGJIaFVlMGdaZlZhbmNRYjZiUGZqZW9lOGNiZ0dhY2NXZ0Via2J4YjFnU2RoZEJjU2VSZUFmdGJ3Y1dka2JKZHZkYWQzYzFlRGZGYkhkSmRPZ2NleGNCZE1oVGdWYkZmSmNGZFVlNWVwYVBhVmc1ZXdhU2VTYkFkWmNBZnhmMWE3ZFZkQ2NKZkVnQmNYZkZoNWJmZ0hjUWJQZGFiMWJJYlVhY2dVZ1liVGZlZkZiTmJQZlpkR2FwZVRnU2MxYVlna2JYaGdkc2RZZkVibmVKYXRhWmNFZ0ZhdWJTY21mUmY1ZlNjeGdSY3hjSGVSZjFoTmZHY1ZmWmQwYmJobmI0Z25oSmd3aDhjMGVHaEVhQWZKZU9nQWR0ZVpnSGJBYUJiT2FJaGxncGJmY2JneWR3aGpoUGZoYVFlNmhSYm1mTWFaZlJnVWFGYzdkU2NSYlZjT2dhYVhkUWVZZmNlRWVGYzBkVWZVZHBmT2JkZVJmRmd6ZVRiRmNrZHNnT2JCZThnbmFBZFJnUWJUYUJkR2hGaEdjRGduZGhkQ2ZSZ21naGRBZFVjeGRrZVRkY2dBZXRhWmVWZWhnSmQ2Y1JlMmhSZEJkYmVrY3Boa2VlYVVjTmhBaE9nVmNSYU9lUWcyY1lnWGRaZVhkaGIyYmJibWg5ZVdiYmJoYW9hNGFUYUhiVmRLZUVhRmJKaEVhQ2gzY0JhYWdRY21jOWhpaFplbWNrYlVhY2NraFlobmVXaEFhVWJlZVhjemZaZlViWGdYYnRnMGNCYlhnQmVSZ2ZiVmIxYWdmVGduZ1VmUmNjZTBkeGhSZWVkSGhCYldhZGhBYjljcmFVYmhmUmd4ZFJkaGNzZnNjR2Z3YVlnM2RaaENoeGdZYUJmMmZnaExmUmdGY1loQ2FjYTBmdGhPYlFnV2I1aEtiWmhIZmxmTGRGY0hoRWhkZUhlVWIwaFphVmJuaFJndWhkZmlkY2VuYURnemZRYzhhRWZrZHhoMWZTYWhmQmZTZlJoQWF0ZHdiV2ZrYkpkdmJZZG1oWmZnZERlMWVoZ09kY2d4YUJjTWRUY1ZkRmRKaEZnVWQ1ZnBiZGhCZGdhMmFEZWlmWmNSYlFmaGNnZjBlUWQzY01kZWNVY1dlVmN3Y0FmbmNwYU1mSmF4YzFoYWZOZUVlNGVhaGRiRmFNYUdhWmZIYmRhVGVGZEFhSmNyYkNkMWFnZkNjV2JqY01jVWNhZGdjMGE2ZFFmamFaYndjVWVCZFJlNGROZ3hlMWhOYkdmVmVaZjBnYmduaFphemhiYjBnWmJuZ0ZnaGRKZE1kSmgwZFJlRGFHZWdlMWZOYkphRGNZYkhlS2VUZ1pndWVlZEJlaGF5YVRhMmJNY1piUWRFZDBnWWZRZWhlNWNWZlFiM2RRZVlmY2NFZ0ZmMGVVYVVhcGRPZmRkUmNGYnpnVGNCY2NoM2hJZ2xmWmY4YUpmV2d0aFNlRmVIY0ZjR2VFYzNlaGZUZFRjMmJSZHFmVWJ4ZWtkVGZKZEVmTWJRY0JnUmh3Z29jQWRpZ2tlQWVKZHdmUWFnZFBmQmhrY1VnYmNCYTFnSmVCYlZjQWRGZGVhaWEwYTZoUGNDaEViRGJiYXhoOGJlZFpnbmFWZUtkRWZGY0piRWVDZDNhQmJhYVFlbWg5aGllWmhtZmthVWRjYmthNGRuZVdoQWNVYmVjWGN6YVpiVWhYYW5kbGEwZUJmWGZCZVJnZWZIaHRnS2dUYW5oVWhSY2NoMGV4Z1JmZWVIYkJjV2FkY0FlOWJyZlVlaGNSaHhiRWJsYnNleGVBYkViRWhiYUtoMGdJZlBlRWcyYjBhTGNTYlZob2c0ZWVha2ZkZWthUWZXaDVhS2RaZUhlbGdMZkZnSGdFY2RhSGJVZDBjWmJWZWlnQWdtY1BkeWhCYWhjT2FTZVlhRmJBaEVmeGZvZ1NnZ2RCZWVlYmdnZXRjd2FXYmtkSmV2ZFllbWFaZ3BoRmZIYkphT2NjYXhiQmRNYlRlVmZFaGRmWGFRZmNoNmRlaG1iY2V4YVZiV2R4Z1JlVmUwZzVkbGdDYWxjbGFNZ1VmWGhoY3djVmFuZVFhUGFhZTFmSWdVZGNhVWdZZVRhZWZCZ3BmUGdlZm5oZGVUZkNnUWNoY2FmQ2MxZWxmV2FFZ25mcGVIaFpiRWZGZXVnU2VtZVJhNWJTZHhmUWI0YkVhQmVCY25iR2RWZlpoMGFiZm5oWmd6ZmJhMGJaaG5kRmhoZUpkTWhmaEdoQWFRZlVia2FRaExkY2dGZHBjQ2ZiYjJjSmFtZmFjUmFSY3lkVGFpZkVhZWZIZ3doVWRZZkRhMGdFZzhhSWJEZU5mUWVKZ0VibGdsYVdmRWZaZ2tnZGRSYkZjemNUY0ZoRmY0Z2NoRmNaZTBnRGcyZnRnU2RGZkhiRmdHY0VmeWZ3ZGJjQmNqYmRka2hBaFZoeGZlZE1lVWhJZVhlRWVsYWNkb2FTY1NmZ2NWZVpnaGdoY3RhZWNSYmRkSWZXZXhmMGdkY1RoUmJsYVdhZGdHaDVlMmVjZTJkOWVHaFpheGFZYlNoVGdIZVZmS2dFY0Znb2ZRZlFlemNrZ0pnVGREYzBhbmNLZ3lkaGRkYlBnQWFvaDJhUWRraElnZWZCY0FidGhCYkhnQ2RnZDNlVGNIZ2dnVGdmZlZoMWZnYlRmbmJVZVJjY2MwYnhoUmRlZEhkQmRXYWRkQWM5aHJkVWJoaFJkeGdSaGhlTmY0Y0dha2c5ZzZoZGQxYU1lTmVDaDFob2JMYVdiVmdZYVNoZWdrYmRma2dRaFdhNWNLYVpjSGFsZ0xlRmNIZkVjZGdIZlVlMGdaYlZlbWJ0ZXVmZmhpaGNmbmNEZ3pkUWZZZWJjUWcxYWhhVWhoYUFiT2dXaFFldGFoYldjbGM1aHplWWFtZTRmZ2hGaEhnOWhPaFpld2FoZUZmUmZIZHRjSmFGZ1VoNWdwZGRlQmhoYXdkUWVYZ1JlUmZTY2tlNWcxY0VjWGFOZ01kVWRYY2hkd2NWY21nNGdQY0llbGhJZEthYmRFaFloQWhhaG5obGhQZFpmR2JwYVRoR2RSZE5jd2ZDZjFkbGNXZEVnbmhwYUhhWmhFYUZjdWdTYW1hUmY1ZFNhd2F0Y3hkRmhVZWtoRmRVZ0FnVmg2aEVlVGFkZ2djZmZVZVlkN2VDZHhnSmdkZWRkVmZZaE1mVWZrY3hjQ2hjYUZlZGJDYmZoSGNCY3ZmWWVEZzVmeWFUY25kTWFRZ1RoRWgxY1JhU2hSZFZmT2NhYlhlUWZZYmNnRWVGYjBmVWNVZXBkT2ZkZFFndGh6YkJkVmVGZm1nYmNWZFphbGZHaFVmRmJTY0ZnSGFGaEdiRWIzZWhhVGNUZTJmUmNxYVVleGJrZVRkY2dBZ3RiWmNWYmhkSmg2YVJhM2h0ZEJnWmFoZzRmc2hNZ0JoZ2FhYURnbGN3Y01iV2V4ZGtnS2dhZFdoNWNuaGNhM2NOZ2FiWmR4ZzVmYmFUZ0hiaGJLYUFmVWVSZk5nQWhsZXBoYWJRYm1kOWdpaFpjbWZrZlVnY2hrZDVkemFFaEVoeGROZlVjVWhrYVZkVGJtZmxjMGdHZUdmcGJCZWZiQWVVZENjQmJ5ZVlhZmdEZUFlMWZCZWFnSGFBaEtmYWRRYTloNmFVYWdhaGJ0YVJjbGJwaHhjV2VsZlJhT2JhYWxhTWZaaEVlM2FBYkxhV2FWZ1lnU2RlY2tlZGdraEVleWVzZGViTWNTZXNjRmJGYkNoVmFWZVZhQmI0Y0NhZmNIZFJidWFkaG5oTmJ2aFJjbWZjaFdmRWNrY3dhb2FRY3hmeGc0ZFJmQWd0Z3dhV2drY0pldmRZaG1kWmNwYUZiSGJvY0dhZmJVZ0FmZWZBZGdnVWZHZVFkUmVjaDVmTWZSZFliK2RCZ0RoTWRRYkhnZ2d0YzFoRGNIaE1jS2VCY0RjWWF6aEFiamUxYUFnSmNWZElmY2JlZkVnWmZJZ1VmbGdOZFBkWmNHYnBiVGNHZVJmTmZ3YkNkMWhsaFdjRWhpYXdnR2ROYmtiRWU2ZFNjbmJsZzVkUWd3Y0pia2dDZkFmNWFZZUdhVmdCaDBkTWZDaEllN2NKYWhkVmdwYWFnVmROZmNnWmRVY01mUWVXZlVnUWVhZmFlM2JCY0NjYmQyZUpobWRhaFJlUmR5aFRhbmRNZFFoVGJFZjBmRGNEZ0ViRWJiZ09iemZvZFliZWFHZ3RhMGhVYVVncGFPZmRiUmVGYnphVGVGZkZnNGJjZ0ZmWmQwYkRjMmhNZUdlWGZEYmdhVmZIY1FoY2JTZlhmM2FSZHFjVGRoaGtkRmJaZ1JoNWJLZFFkeGdKZDhoUmJ6aEJjSWZZYm1hQmZrZ2VkVWVzaFVjY2NSYTBhZGdUY1JmbGJXY2RoR2Q1ZzJiY2IyaGNoU2daYndnc2ZTZlJlR2FOZ2ZnQmFVY0ZkUmRDYjNhWmJhY0hjRGVzZHFmTGR6ZW9iYWVEYlFoOWhpZUJha2JWZk5jV2FraGtnZGRHaG1mbGhxY0JjbWg1ZUJkWmVVZ2RhRGRSaDNha2Q3aGNlMGN4ZVJjZWdIYkJiV2FkZ0FjOWRyYlVoaGVSZ3hoUmVoYk5nd2VCZXdlY2V0ZE9kVmgxZG1iVWNtZkVhZGFXZFVnc2hTZGJiRmRKZ3hjVWNuZXRlS2RZZG5ia2RmYUhkWGMwZjNiSGZVZzBnWmRWZG5lUmd1YmRmbmhOYnZoUmFtZmNmV2ZFZGtneGU5Z0hmaGdCaFBoUmZBZU5jbWRUZDFmZGE4YmRnMmNaY3ZmRmRDY3dmYWRPYjFha2NmaFFkeWM0ZklnQmdsY3hmZ2JkaEJiTmR3Y1NhU2VCZVJiVmdGZ0JjcmZFYVdnSmFhZVdoSGNGZzhiZmRIZFFjUGhhYTFnSWZVaGNkVWhZZVRjZWFGZE5kUGdaZUdmcGNUYkViVWVjaDRnUWFnYXBkWWhiaFRldGNVZWRma2hGZHpiU2FuZkpoc2FYYWdiZGZraEhhUmh0Z05oVGhWaDllNGZSY0hlWmF6ZmJkMGdaZ25iRmNoZkpoTWRkYVVib2ZRZVVja2NRYUxjZWVBYjRhS2hKYWpnRmVvZ0ZkbGhWYm1oVmZuZk1oTmdUZEVhVWNQZUhmVmYwZUhoT2RuYXBhbmNNZ1ZnVmJzYVVhVWFGZ09iZmJVYVZjemFVZ2tnOWJtYmNjRWRkY2ljQmhtZkpnU2NFZ25iRmVRZ0JhbWQxZUFkV2ZtYTFnbWJlZVJna2ZUYmNnQWR0ZlpmVmNoZEpiNmhSYTJlUmVCaGJna2dwYmthTGJRaE5lZGFJaGphY2dkZlRnUmhsZldmZGFHYjVmMmhjaDJkOWFHZ1pkeGNZYWJoVmcxaDlmS2hFZkZiSmNFZkNlM2VCY2FiUWNtZzlnaWhPYjJkQWNZZVdnRWQ1ZHplRWJFYXhnTmhVYlVha2VWZ1RjbWJsZjhhVWNIZTRoUmdKZGhoNGhlYUFoU2NGaEljSWF3Y2xkZmFQYVNmRWREYU5mVWhNYTRjVWVnYmxmeGZEYmhhMGZvaEFkUWhBYXdmSmJRY2RiQWFRZHplVWJGYUhjQWZjaFNkWmYwZGNmaWNGZUNjQWhKZk1iRGdBYkVoV2JuZUVoVmVTZ1VlUWVaY0RmVmc1aHVlZGVuZE5ldmJSZm1nY2RXY0Vma2J4ZzFiU2RoZkFkQWhBZFZnOGdsYkNoQWV4ZHZiYWhrZ3hkcGVGZ0hmSmhPZ2NmeGNCZk1lVGJWYUZmSmRGaFVjNWRwZ2RlRWZ3ZDRnQ2JDZGRjZmZOYVFmOWNoZ0NhWGhOYlJlVGJIZmdia2RXZUFjdGZPYmZkMGVvY1ViZGIwZUFiNWFlZ0ZiTmZQZ1poR2ZwZ1RiR2RSZk5ld2hDYjFjbGNXZUVjbmNvZFRhTGVBZGdlOWJSZEJoc2g0ZVdod2dSY3hhQWJBZkJjTmVUYVZiZ2hMYkxlMmJaaGphYmQwZ0JiaGVQZ0JkSmFNZmRkVWRvY1FiVWFrZVFnTGRjYkZkcGhDZGJiMmdKZW1kUGJWY3djN2RIY1hnMWV2ZkRlVmI1YkRoU2ZRZmhmVGRhZFNjQWFXY0Rmd2JCY25lUWIwZHBkSWRjaHpidGd6ZVRkRmFGZzRiY2hGZFplMGNEZTJidGFTZkZmSGdGY0diRWR5ZHdjYmVCZmpiZGRrYkxoRmNnZENnWmNnaHRjRWZTZ3hoSWR1Y1NhUmRzY0FlZmgxZHhnT2FlZVVic2VVZ2NkUmMwZmRjVGRSZmxlV2FkYkdhNWgyZWVlbmJSZXNoWmF4ZFljU2ZUYUhkVmJLZEVnRmFKYkVmQ2h5YTFmVGJUZGtnVmZpYlphbWRrZFVhY2NraDVhemdFZ0VleGdOZ1diUWZFZGJjSGdqYXNoN2dUZ0RiOGVWY0xhUWZFY1BmUWJEZUphRGZOYWdoMGNGZFBnU2hJZmloUGFFYzRibGRVYWdlbGV4ZkRmaGcwYm9kQWhRZ0Fod2FKY1FoZGVBZ1FlemdVY0ZmSGRnZElhU2haYzBhY2VpZEZkQ2NBYUplTWFEZEFmRWRXZG5mRWdWZFNiVWNRaFpkRGJWZDVldWJkZ25iTmZ2YVJobWhjaFdlRWRrZnhkMWhTZ2hmQWJBY0FmVmM4Y2xoQ2hBZXhmdmJOZWloNGhnY1JiM2N3aHhhTWNnaFJjVWZUZFVkOWFKY1FkVWNBZ1dnTmJRYnhjb2RhZTNoUmVSZVNha2g1ZDFnRWhYaE5iTWhVYlhjaGV3YlZnbmJRZFBiZGRGYkloVmFZZFdod2FUY2ViRmNOYlBlWmdHZHBnVGhHY1JjTmh3ZUNjMWZsZldmRWhtY0JiSGhNY0Fna2FuZkdiV2hvZ0dmQ2RnY0JocGJIZFFhRmJOY1RoVmFnZkxhTGUyaEplcmhSZFVmWmRuYUZhaGJKYU1iZGRVZm9nUWJVZWtlUWNMZmNiRmZwZENiY2VHZUplbmZlYkRiNWV5ZlRlbmhNZlFmVGdFYzFkUmZTYVJoVmFPYWFlWGFRZ1lnY2VGZnRhMGNCZ1FoSWJIZkphaGM4ZE1kRGRVZUplcWJjYkVjaGUwZVdmMmFVZnRjVmVXYkpkVWNPYlhhaGRUZVRmMmVSY3FnVWd4YWtmVGNjYUFidGRaZFZmaGZKYzZlV2FHYlJhQWFmZW1oQmhrZmVoVWVzYVVmY2VSYzBiZGZUY1JhbGdXZWRlR2E1ZDJhY2QzYlZkR2RNYTFkNWRiZkhhM2FzaDFkVWRVZUZiV2VDYzJheGdhZ0ZjbWhFZmRjSmQzZG9oR2dXZUVkNWV6Y0VmRWR4Yk5lVWZVZ2tiVmVUZm1jbGIwaEdiSGFCYUJjYWUxZkZiTGZYZDFlOGZSY2NnMGR4aFJkZWdIZkJnV2hkZUFlOWJyZVVhaGRSZHhhUmJnZWxkNGFCaHdjY2N0ZE9hVmIxZG1lVWZtaEVkZGZXYlVkZ2NTY0xka2NrZmJlQWhIYzllY2NUaG5mbGZMYUZiSGJFZmRhSGNVZjBkWmZWZm5mUmR1ZmRmbmFOYnZjV2VXZmNoWGdBaG1jWmExZFNjaGRCZVNkUmhBZXRid2JXY2tkSmR2ZVlnbWNaYXBnRmJHZ2hiT2FKZzFkZ2ZGZEhhbGE4YzJhVmFGaDliL2NkZUFoUmJ3YkZhWGNvZHVkQ2IxYzliamRPaDNnTmRNZVVhWGhoYXdmVmFuY1FjUGVhZTFlSWFVYmNmVWVZZ1RjWmUxaE5oT2NkaFVmQmJUZ0dnUmJOZXdkQ2IxZmxjV2ZFZm5ncGRIYlpjRWdGaHViU2JuYzVkNWRIZTFmd2I0Z1RlaGdNZHlmV2RFZVpia2FiY21maGR6Z09iMGJnaFlkVmd3aEpoY2hiZm1mQWRRYVVha2FRZUxkY2FGaHBnQ2FiYTJnSmdtYk5lQmIxZCthWmdIYU1kUWNUZ0VjMWRSYVNjUmdWYU9kYWhYZFFjUWhPZEVlOGVrY0Fhd2ZVZGFmT2FrZFVkcWdIZEJiUmUyY1BkQmFNaG5mWGhCYThlYWFWZVRoOWdHZURmbmdnZGJoUWRUZFFkNGFIZUVhMWhjY0poRmZJY0pjRWR4Y3doMmFFYjJnUmhjYWJhZ2R3YXhhTmZ3aGhlQWJPYUZmSmFUY1RmUmZFZENlZmZXYzRndGhXZFdoOWFHZFpheGVZZlNjVGFIZlZnS2hFZkZoSmhFZENkeWNJYWZhRmJqY29kd2RLaEdnbGRBYk9lZ2djYmdkSGJqY01oTWhSZlZiRWVWaFVkbWZrZmdhRmFnZjhlQWRZYkVkbGdnYlRmbmdVaFJmY2QwZHhhUmRlY0hoQmJXZWRmQWQ5Y3JjVWJoZ1JndWZSaGhhSmRvZGVjVWI5YWthYWJsZU1kWmFFaDNkQWFMYVdjVmRZaFNmZWdrYmRna2hXZTJjNGNlaExjRGJBZ1llR2JnZTVjY2dDYlZkVWFaZ1NkSGJRYTZiZWVBaHdndWdVYm5hOGE4ZkVha2F4aDFmU2ZoZ0JmU2VSZEFldGZ3ZFdma2FKY3ZiWWJtZ1pmMmNGY0hoTmVmaFdjUmFCYU1mVGdWYkZiSmNGaFVkNWFwZWRiQmdoaHdkUWVYZ1JlUmZVYkVlNGNoZVdmVGVvYmZnWGF3ZmNjeGRSZFdmWWhQY2RlMWVKZ0FjZmh6aGxoU2dhaDBjRmFsZVpjR2RwY1RkR2VSYk5ld2JDYTFibGVXYUVhbmNwZkhjWmhFZEZjeGdTZ21mVmVwY1llUmVSY3hiSGVSaDFnTmFHZFZjWmgwZGJjbmdaZ3pmYmEwYVpnbmJEYUJhSWFZZlBkUWZOaERkWGJEY3RiS2NZZjBmaGZDaGNhV2NJZnllWmYyZHNkemJYZVdhRWc2Y1RjRWIxYVJlU2VSaFZoT2FhYVhoUWFZY2NnRWNGaDBhVWhVZHBkUmFkZlJoQmNpaFphbGJGaDRnY2hGYVphMGFEZzJidGZTaEZnSGhGZ0diRWgzZWhlVGFWZVdiUWIrZUdlMWNCYUFnZmduZVFlWWNSY3doUmE2aFdkMmhRY1ZjWWFEZFVhbGZhZ0ZmMGMrYmNoUmIwYmRiVGZSZ2xhV2JkZkdjNWcyYWNlMmQ5YUdnWmN4Y1lkTmJUaEhmUmNhZ09jbGZKYUVjQ2EzYUJnYWZRYW1nOWRpaFplbWRrYVVnY2VrZjVmemJDYWthd2NaY0djUWhCZ0dnUWFCYVliMWhDY1djWmFCZGFnbGhFZGVlUWFBZnBnUWJZZmxlcGY3YmVlSGdCZVdiZGJBZDlicmFVY2hnUmZ4Z1JlaGJOZDRhVWUwZDlkN2JhZGxnSWVJZU9hWGhBYUxiV2JWZFllU2NlZmtmZGdrYlFlV2Q1YUthWmRIZGxoTGdEZG5kRmFKYVZkUWZSZEtnV2RBZXNhdmZaZG1lTmR2Z1dobWFkZ0NnSGREYU1jMGNXaGdjQmNKaGJiZ2Z0ZndiV2JrYkphdmRZZm1iWmVwZEZiSGRJY1RhZWFoY3hobWRUY1ZlRmVKZEZoVWg1Z3BmZGdCYWhkd2RRZlhnd2daZ1JoQmc0ZG5kWGdpZWNmRGdCYVNkRWJnaEViM2RwZUFkT2NWaElnSmFjZVFkQmdHaE5haGVBZWJmTGNTZFVjZGJHZ1Joc2hraEFobGhrYU5lT2FIZXBoSGRaYUVlRmZ1ZlNibWVSaDVlU2h4ZFJheGRIZlVoOGRJaFRoUWRNYW1lSWZIYlpkN2RSYVVmWmNuYkZhaGFKYU1mZGdVZm9kUWRVYmtjUWhMZGNoRmdwZ0NiWmh6YllndWNJZkVjZGQ4aE1kVGNJYkFjWGZFYTBmTmNWaEJhVWZhaFpnd2h0Y1pkWWRGY0ZjOWNYZFdlQmdPZ2RiUmhGZ3pjVGNGZ0ZlNGRjZUZjWmgwZ0RmMmd0YVNiRmVIYWtoU2hXZHpmRWZBZ1FiUmRzY3JjUWJnZjhkVGdMaEJjWmJaYkFkaGF3YkZlQmduZFZnWGhaZTBkWmNPYmViVWZzaFViY2ZSZzBhZGFUZ1JmbGFXZmRjR2E1ZjJnY2EyZDlmT2FNYjFjNWFiY0hiM2VzZzFjVWRVYkZjV2JDZ3ljeGZIYlFhamZ0ZXNnR2JTY2dkSGNZZEVmZGMvZE9ja2h4Z05kVWdVYmthVmNUYm1hbGEwYkdkSGNCZkJkZGJGZUZkS2ZSaGlhRmJaYk9oaGQ5ZmZmQmV6Y0ZnQ2ZiYUFlOGYzZlRneGVRY2xoU2dHZ3dlNWFSZTFiZGR0Y1pibmVrYlpjRWgzY0FhTGRXYVZiWWVTZmVoa2VkZmtnUWJXYjVlS2NaZUNmMGZEYlhmU2hJZDNoSGRVZTBkWmNWaG5jUmJ1Z2RlbmROY3ZkUmhtY2NnV2VHZDFhZGZmYVNhaGNCaFNoUmNBY3Rkd2VXaGtiSmd2ZFljamV0YmdoR2hGZGhmT2djY3hmQmVNYlRoVmNGaEpnRmVVYzVkcGVmY0ZmQmcrZkViU2ZZZmVmSGFnaEVlaGZTZENhTWZKaFhhemRrYythRWVuZ1FlU2JhYnhjUmNCZlBid2dWZUhoTWNSZndhQmRaZEdkSWhIYkVoQmRNZHJnSWFWY2xoV2FFYW5jcGJIZlpiRWdGZXVlU2NtZlJlNWRTZjBhWWcwZFNlVWJnZmZnVmIxZlpiOGZSZEhoWmR6aGJmMGhaZG5kRmhoZkpjTWhkZVVhb2NRYVVja2hRYkxmZWZBZzRoS2ZKZWpoRmFvZEZobGhWYmljWGRuZE1hV2hVaFVoMGJGZ1JjMmVvY1BoZWRXZVFnUmRmaEdmdGQwZlVnVWJwYU9iZGhSZkZiemRUY0ZlRmI0YWNlRmJaYjBhRGUyZk1mR2hYY0RmZ2JWaEhmUWVjZlNiWGZuY0phcWhWYVFnUWFUZ0phQWRVYm1jRmJ3aE5ic2ZUYW1iaGFyZGJoa2hwZGtkZWRVZ3NlVWZjZlJiMGVkZFRmUmdsY1dkZGZHZDVlK2dKaHljY2dQYk5jQmhoZHRkRGRXYVpkWWFFZUZjUmNaYUNkeWRSZVVlUGdTZTVieGNkZ0doQWVZZldjRWE1YXpkRWNFYXhjTmFVY1Via2hWYlRjbWVsYjBoR2ZIYUJjQmRmZ0FoVWZDYkJkeWNZZ2ZoRGFBZTFiRmhZaEhkQmdRYmFoUWQ4ZS9kWGhHZ3Njd2hVYmdmdGh4Y1hmMmdWZmthYWZsaE1kWmNFZDNlQWVMZVdoVmNZZFNoZWhrY2Rja2VRZFRnb2VDY0xjU2FwZmhnRmhIYUVlZGRIZlVmMGFaY1ZibmVSZnVkZGZuaE5kdmNUYTNmd2U4YkVja2J4YjFiU2hoaEJiU2VSaEFkdGh3Y1dlaGM5ZW1jYmVrYXhlcGZGZUhhSmRPY2NneGRCZk1kVGJWZkZkSmJIYlFjWmVuYUpoRWZvZS9jRmFUZnNiRmNFZHhhNGN3YkhneWZzYkRhQWYzYmhodGdWY2phSmZhZUpnUmhGY0FnT2JBZGxmZGVlaEZic2RiZGJoV2ZvYkloTWh4Yk5od2FDZzFjbGhXYUVmbmJwYkhmWmNFY0ZjdWdTZGphWWM4YUhjMGVFZ2pjVWJ4ZTFjRmdNYjFiWmQwZWJjbmhaZ3plYmcwYlphbmFGZmhjSmFNaGRmVWRvY1FhV2RoY0JlRGJPYlFlbGNNZEVlQ2ZOaDJhZWVSZVFnTWFVYzNkTmVFYVFkamFJZVFhV2NRZFZiSGZaY1ZnNGRZZ2NiRWFGYzBjVWZVZnBhT2JkYlJhRmN6YlRoRmJGYzRnY2FGZDRmZ2hSZHlmSWNCZ0dnZ2Q0YkhmQWdtZjVmVGdNYlhhbGNxYkJoeGVkaHNnTWZSaHBnUGJYYXhnNWZRZVJnMmhSYUJnYmhraHBna2ZlZFVnc2JVYmNkUmQwYmRlVGVSaGxhZWNJZ0NnWWQvZ0lkR2RFZzViSmdnZVVnQWZUaEFhdGhYYUVnQWFaYktlZGVEZkZoSmJVZkdkWmJ1ZVRhR2FrY1VhY2NrZDVmemFFZkVoeGFOY1VjVWFrZFZmVGhtZmxlMGJFYkNhUWFKYlBiUWJKaEVhTWdUZlFhRmRhYjBkd2Z2aFpoWGdBZ0NnZWduZkFjcWJSY2dleGE0ZFNnamFsYzRjVWQwZDlja2ZhZWxhTWNaY0VnM2NBYkxkV2FWaFlhU2dlZWhnTWVzZENiRGExYWdnWmNIZGxiTGVGYkhmRWJkY0hkVWIwZ1phVmRuY1JidWVmYjJnaGNGZ1JibWRjZ1dhRWFrYXhlMWNTZGhkQmJTZVJkRmJaYzVjVmFtaGhjdmZZYW1jWmJwZkZjSGRKZ09nY2V4Z0JlTWZSZ1JlbGRIZlJlUmV3Y21jSWhGZ2Nja2dHZENlUWhVZ1JmQWVBZDZhUmFYaE5lUmVVaFRhNGhsZ0doRGdkZ2JmSWNoYzFkYWNjaFVlNGhhZmVoQWFoZGxkWmJHaHBlVGNHYlJlTmh3YkNjMWZsYldmRWhuZHBhSGdOaGdjUWY2ZkhoemNZZTNjU2N4ZnhlYmhIaFJkMWVOaEdjVmVaYjBiYmFuY1poemhiYjBmWmRuZkZhaGJKZUVhSWFRZ0pkWmRBYlVjcGUwZE1lVWFwZlNhYmczYTlobWRmaHdoRmVuZ1hlV2hZZ1FhU2RrZzBhUGVIZlZmMGZIZE9obmZwZ25mTWhWZkZka2FXZEViWmVrZmRkUmNGYXplVGFGYkZoNGJjYkZlWmYwY0RhMmV0ZFNjRmJIY0ZnT2ZSY3pjQWNhZEhkR2dvZ1ZoRWhnYWdnRmJjYkJlWmdaZ1FoQWNkZXZnVmZIYUZjQmVhZ0Vob2U2ZUxmUWFOY2RmSWhoYk5kaWREYkFkaGVBYmZlV2RKZmNoY2cyZzlnR2RaaHhjWWFTYVRhSGFWaEtlRWhGaEpkRWdDZjNhQmJTYUZnaWdjYnJmTmVXZWRicmRNZzFhMWdoZEVkRmRGYk5mUmExZXdmQWdYZ1hoeGQwY0hmbmVBYmZmSWhCY2tiRGFIYVhjdGN1YU1ibGE5YkRoY2hYZ3hkOGJkY0FiOWJyZVVoaGRSZnhmUmNoY05nNGFVYjBiOWVrZ2FibGJNZ1JmUmR6ZmhkQ2JDZGxnaGV0YU9iMWdOZThoUWVYZE5jS2FjYm1heGhlZkJnMmFRaGRiR2IwYjFoSGJBaGpid2JuY0phWGEwZ1FkQmgzaE1oT2ZHYzBkQmVmaFNiaGFCZ1NlUmRBZ3Rid2ZXaGtoSmd2YllobWNaZnBmRmJIZEljYWFPYTFma2JmZVpjMWFGZkpoRmJVYTVocGhkZ0JlaGF3YlFlWGRSZlJnU2JrZWRldWRPZjNlTmJNYlVnWGhoYndmVmJuY1FiUGZhZjFhSmhKYmVoRWNvZTVjZWdGYk5lUGhaZEdlcGRUYUdkUmhOZXdhQ2UxYkVkZWVIaENlb2VWZEtneGhVYWhlSGNqaDBocGdEaGhjb2RpY1ZjVmJRZ0xoVGFTYVFkOWZLY1RoNGJuZ2JoMWZ0ZW5kWGNoZ3djY2dKZXdiVmNFYkhiUmJCZ1NnSWZCYTlmTWZQZUNib2V2Y0xiMGdBZWdnVGRtYTRmUWhDZ2hjZ2FmY0Nha2RFaEhlSmVqaG9kWWhlYUJhVmg5ZlVkUmNGYmtkZGhSYUZmemhUZkZhRmY0ZWNmRmRaZjBhRGEyZHRoU2VSZWpkUWRTZlJkaWdvaGRoVGUyZnhjQWhVZnhma2RUZ2NhQWZ0aFphVmdoZUphNmNSZjJmUmNCaGJoa2hwZXNiTGNVY3NjUmFiZUJhMGNMZ1dnUmRCZmFhWGJtYjVnMmNjaDJlOWVHYlpieGdZY1NlVGFIZVZmS2hFY0ZkSmhFY1hnM2JCaEVoWGcyZTlkMmVmZWtmTWFVZ2Noa2g1Y3piRWVFY3hmTmNVZVVja2FWZFRibWZsZDBlR2VIaEJoQmZhZzFkRmJDZFJlaWdGYlpjT2hoZDloZmhCZXpjRmVHY1plQWE5ZTJiVWFraEFiNWREZDBnQmMyZExnQWU1YndmY2JsZk1oSGFEY1hnQWZEZkRjVmRZaGZlZWhsYU5kOGNTZEdiZGhHZFRibmRsZkxlRmdIY0VnZGNIZ1VmMGdaZ1ZhbmdSZ3VnZGhuY05mdmZSYW1iY2FXZ0Vna2dRZmhnQWdsYWthQmZTZ25nUWh4ZVNkMWNSaHZjZmYyY1poNWNIZ1hlNWhrZWNoeGZCZU1nVGFWZkZhSmdGZlVmNWZwY2RoQmFoZXdjUWVYZVJlUmJTZWtiNWgxZ0dhU2hjZkVjR2JDYXRmK2FLYlRiVWFjYmVkVmdJY0pkY2dWZ1liYWFkZEhjbGJQZVpoR2NwYVRiR2ZSY05od2ZDZDFhbGhXZ0VlbmNwZ0hmWmFFZEZmdWRTZ21hUmV4ZUhhMWh3ZzRjVGhoZk1heWZXYUVhSmVzYWJobWF0YXplZmQwZTlidWdQZEJnSmhNYWRlVWZvaFFkVWVrZFFoTGdjYUZocGFDZ2JiMmdKZW1nYWRSZVJnb2RUZGlnY2JRY1VobGRCYVJhV2NnZWRha2FhZFhhUWNZY2NhRWNGZDBlVWdVZHBnT2FkZVJoRmd6YVRmRmJGYzRlY2NFZ2xoMGVCYjJkTWVHZEZnSGV4Y2JiRWEyaHRjQmdSY21haGFBY1VieGhrYlRjY2VBaHRmWmJWY2hiSmY2ZFJmMmZSYUJnYmdrZHBna2JlZVVmc2FVZGVkVWVsYVZiQmRFaHBjWWhDaHlhOWZtZFlkMmc5Z2JnVGJSZllhU2RUY0hnVmdLYUVkRmhKY0ViQ2MzZkJjYWRRaG1kOWhpZFpibWhrZFVlY2hrYTVkemRCYWxkbGNZZ1FmbGZ3ZVZjU2RHYmxlOGZFZENlUWFKZlBkUWRKaEVkTWdUZ1FmQ2ZZY1VkeGNQZ1pibmVBYUNnZmJRZThmM2JVZWhjd2hsZkRmbGFvZnJhWGJUaEFjbGFmY2tnc2daaERoMmZ3YUxmVWFVZWNjRWNlaGtjcGNrZ0ZiV2ZkZkRjYmZYaEJoSGRQY25jRWJkZEhkVWgwZVphVmZuZ1JkdWhkYm5mTmh2Z1JkbWJjaFdhRWZrZXhoMWhTZGhiZ2RHZURiRWJJZGplVmZEYjBkdWZjZjNjQmJwZUNoWGVKZkdhSmUxaGdiRmVIaGxmOGMyZVZlRmZwYnhjZGZBZVpmdWhRaFNiQmJZZVNoa2RoaDFoQmIyZlpnWmJRZG1hMWc1YldhbGI0aFBmYWcxZkljVWRjaFVnWWRUZmVnRmFOY1BmWmNHZXBnVGdHY1JhTmJ3ZENoMWFsY2VhUmdqZEliT2NOZTBnOGJSZ0NjM2RkYnJmU2R3ZWxheGFEaFJjUmZCZE1jMWZaZTBkYmFuYVpjemZiZzBhWmduaEZmaGZKaE1mZGhVZG9lUWNVZ2tkUWVMZWNiRmhJYldnSmJ5ZXNhMWRaYjJmc2Z6aFdnbWhzYVFlVWRVZTFmQmZRZEJneGJrYmFoWGhRYllmY2hFZEZoMGRVZ1VkcGZPZmRjUmZGZXpkVGZGZEZlNGFjZEVoeGgwaFdlMmV0Y01mQ2JYYkZoWGVCYVZoSmVUY1RnMmJSZXFhVWF4Z2thVGRjYkFkdGRaZVZnaGNKYTZmUmcyaFJkQmJjYlVicGVzZGNoUmc4Y1VoZmFBY0FhZGNYZkFmOWNmaGVmRWVSYjJlY2MyYzljR2JaYnhhWWVTZFRmSGNWZUtmRWRGZEpmRWFDYTNjQmhhZFFobWI5ZnFjTWRpYkZhZGJJZVVhQWFNZ1VnVmd4YWRoVWJWZVFjL2JUZm1lbGQwYkdmSGFCYUJhZGRGYkZmS2NUYm5hVWFSYmNiMGF4aFJmZWdIYUJlV2hkZUFiOWg5YlJnd2FGZ2loVWV4Yk5lK2hVYTBhZGVzZVBiaGJ0ZFFnUWFIZTVoMGFHZ0VmY2dFaGVlbGJsYTZnUWFUZXBlRGNaYkNnVmNMZkhkQ2FWY1ZmVmJCZTRhWGFLY1RmVmY5YVphSGJOZnpoV2htaGNmZWdBYjFncGExYlJneGZBZUdnVGJRaEpjNWhVZDBhNWRGZllibWRaYXBmRmNIaEpkT2hjZHhmQmhNaFRlVmJGZUpmRmZVaDVjcGRkYkJhaGV3ZlNlU2hBYlpmQWd4ZzFjN2NiZGphSmJkZ1JkM2NoaHRhZmNIaFFoUGFhZjFoSWRVaGNoVWhZZlRkZWVGYU5kUGJaZkdncGNUZUdoUmNOZndjQ2IxYmxkV2VCZEdhOWJTYmRlMWJSYnVlVGFHYVJieGRRYjBlQWE1ZFZiRWM1YURiWmhoaGRnbmNmZEhhWmR0ZGNoVWFZZXpnSGN4ZEloUWRkZlVnSmJFZ0dkZ2YxZVljZmFpZ1VkRGdlYjNhcGZtZWRkUWRoaHljUmNtYklhR2ZUYUVmQmRSYUhoUmN4Y0hnWWhIZjBhVWNXYWthRmIwaFViVWZwYk9jZGhSYUZjemNUaEZhRmc0ZWNhRmNaaDBnRGQyZHRjU2FGZkhka2RTYldoemNFYUFhUWFSY3NocmZRY0Fic2dUZWJlUWZ0ZVJkQWFsZG9oemVGZkdkb2QrZ0xjMWc1ZzhoZWVWZFViS2JjYlVia2NVZFRlUmM5ZFdmWWFuYnRjamhZYkhlcGhQZmFhemZ3aFNjVGdIYlZlS2FFZ0ZiSmJFY0NmM2RCZWFjUWFtZTlmaWhaZW1ma2dVY2Nka2Y1YTdkUmNBZFFkRWhBYmtlZGFxZURhM2ExYXNiR2NHZDFoQmhaZEZkaGVEZlpiSGFVYVJmY2MwY3hiUmdlZ0hjQmdXZ2RnQWI5YnJhVWVoZFJoeGVSZmhnTmJpYVViMGhkY3NoUGZoYnRiUWNRZUhiNWIwZUdnRWhZY0NnZWhsZnBnT2FRZFdmNWJLY1piSGhsZExmRmRIaEVlZGNIYVViMGFaaFZnbmJSY3VlZGVuZE5kdmRSZ21nY2dBZ0JlMWNsYW1mWGd4ZUJjVWVSZ0FjTmQ0YkRiZ2NvZ21lTWFXY2diV2JWZFdoSmFlZmNid2I1aFNhVGJRZlZlQWdGaFJoSmhwaGZoRWF3aDRnQ2VDZWRiZmdOaFFiOWRrYkJiM2VOaFFkVGNYZWhiNGRSaDJkSWhQZFphbGFKaEFkZWdFYThjYWhjYVZhOWhsYlpoR2RwYVRoR2dSZU5hd2VDYzFkbGZXZkVnbmFwYUhiWmFFY0ZodWJTaG1iUmM1ZFFkMGhBZTVlVmFFZzViRGhaZGhkZGZsZmViSGhaZHVkUmJVY1plbmFGYmhiSmZNZ2RmVWhvY1FkVWVrYVFjTGJjY0ZicGNDY2JkMmRKaG1mYWFSYlJmeWJXZEdjWWNGaFhkMWRoZlJoVGh4aFZiR2JZZ1NhQmRRY09mUmVKYTZnTGdnYXRjZmJZY3hkRmh0Y1VhbGVFaHNnZWVWYllkb2JEZzJlTWFHYVhiRGFnYVZnSGJRZmNiU2dYZ0hkWmFxYlRod2hVZFRhZWVCZnBmUGFWY2hoOWY2YUVnMmExYkloWmMwZ05kb2RVZDBoc2JVY2NnUmcwYmRmVGFSaGxmV2dkYUdjNWYyYmNkMmY5ZEdjWmJ4Z1ljU2FUZEhnMGFlZ1dhQmFzZFhiQmVRYThhYmhVY1hlMWJpZGVoMGZNYVVlY2NrZjVhemRFY0VjeGNOZlVhVWVrY1ZhVGRtZWxmMGdHZ0hoQmVCZGRoRmhGYktlVGdtZ01oRWhaZGxjOWVFaGVlSGFaYVdiZmdBYWNiL2VHY2xhMGVpZ1NlR2R3ZjVkUWVGZjFla2NkZ0VnMGNaZlJjM2JrYkxlQmRWZFlmYWVMY2doOGZ0Y0VibWZBZTFmSmdXYTFkVGdGYkdlMGdCaEhmVWhVZkljUWZIaFJoamdkYmlmZGZtYlRhMmI0Z2ZoSGFtY1phMWhTY2hoQmhTZlJjQWJ0ZndjV2VrZkpodmVZZG1jWmhwZ0ZoSGFKZU9lY2V4Z0JnRWFHZlJja2VBZVJoa2ZBZVdmTmhRaHhib2FRY1dhbGVSaFFjaGZvZzljV2hDYkJiQ2hMZWpjbGhrZFRibmNRZlJjZGJWZkpiQWhlYUVmWWRWZ2ViRWVWZGFmY2dYZmxkR2dFYUJocGI4Y0lkVmFsYldjRWVuZnBnSGVaZ0VkRmd1YVNmbWdSYzVnU2h4ZFJheGhTYVZlVWRFaFNnbmZ4YzBoYmJuYVpjemhiZDBmWmNuYUZlaGNKZ01lZGhVZ29hWmhTZVdiNGVMZWNlRmdwYUNiYmMyZUpibWNhYVJkUmN5ZUVhM2dvZWNiWmJrYjFlUmdTYVJiVmRPY2FnWGhRaFljY2RFZEZmOGdHZ1VoUWRlZUpiMWE0ZG5oQWJ3ZVVhaGVJYUJmTmE2YVhoQ2ZNaGJhVWdpYVVmcWdWZGpiNGZIZFRjM2VsY3FnR2V4Y2RkRGNJZ2tiUWdOZEdnVWhZY2pjRmZ5ZUZnUGJQYVFjSWJ0YVBjeGU5YlllY2dRZUFmZGRDZDBod2ZZYk5nemRvYy9jUGNDZ0ZhR2diYTBmSWNlYlRhQ2hkZkRlRWRBYmxhdWFDZTNoQmhhZVFjbWc5aGliWmhtaGtnVWJjaGtkNWV6ZFFmZ2JrZlpmQmNCZHRnYmRUZm1lRmZlaEdoSGhCZkJlZGFGZUZiS2VUZm5hVWdSZmNhMGF4ZlJiZWhIY0JnZWhJZUFnOWZ1Y1RmeGFSZ25oVWRoZ3BnMGVlZVVnOWdrZGFlbGdNZVpkRWMzZEFmTGNXZ1ZjWWZTYWVla2JkY2tmRmNXYTVoVWJlZ1hjbGhmYURkRmVzYWRlSGFVZjBhWmhWaG5nUmV1aGRlbmZOZnZjUmRtYmNlV2dFaGtjeGQxY1ZmUmJCZGFmVGFGZDhjNGdFaHhkRmVoY0hhU2dkYzliRGJIaEplVGhjYzBoUWJFZEJmQWJKZUhoYWFnYjliNWdaZUJlaGhzZFhiWGFSZlpiSGJrZjVhNGFFYVdiZGVVYVdkSGVGZThkZmdIYVFoUGhhZzFoSWJVZmNjVWJZZFRiZWNGYU5hUGFaYUdlcGVUZEdhUmhOY3dnQ2gxYkVjQ2VXaGpmTWhVYmFlamY0YnZlV2RYYVpkNWdWZGhmUmJoZkZhQmFGZG5hR2dWYVplMGJiaG5jWmF6ZGJkMGRaYm5lRmFoYUplTWhkYlVob2FRY1Vla2NRZ0xmZWNBYjRlS2hKYWpiRmNvZUZjbGhWY2pkV2hIZU1iTmNUZkZjMWhZZlJiVGE5aE9mYWZYZlFjWWJjYkVmRmcwYVVmVWVwZ09lZGJSZ0ZkemFUY0ZkRmU0YWNoRmRaZThkV2N5Z01iYmZSZDNmOGI1YlVlbWJoYkRjVGYzZWxkcWRRZ3hnQWdhZ1dnZ2h0Z1pkVmNoZUpkNmdSZDJlUmhCYmJja2VwY2tmZWJVY3NjVWVjYlJnMGNIZlRhVWgxY1dhYWhuYk5hMmVZZ0hlMWFzYlpneGdZaFNjVGNIZ1ZnS2VFYkZmSmVFYkNjM2dCZmFiUWFtZzloaWRaZG5mWWJVYmVna2RZaG5oRWRFYkZkUWRVZ1Zkb2ZIZVJkMmdWY2VoR2JIaEJjQmhkaEZlRmdLZVRibmVVZFJmY2cwZnhjUmhlY0hjQmVXY2RnQWI5Y3JhV2hrZEFjNWFEZDBlQmEyaExlQWc1aHdiY2RsYU1jRWFFZDNoaGVmYUViUmQ5ZkJiZGNEZ2dkbGhVYkhhaGFLYmVmR2RWYUxkUWVIZGdkZGNRYlVkMGhSZUFiamJ3aG5mSmdYZzBjUWZCYjNjY2NHZkVjbGZKY3JlU2JoZGhmRGFVZmdkdGc5aFdjaGJaZG1oYWMyYTljbGNQZ25kSmhPYmNleGFCZU1kVGFWZ0ZkSmNGZ1VoNWRwZmRlQmNoYndmUWdYZVJnUmhTZ2tmWWhoaFdoVGZvY2ZoWGV3ZmNleGVSZVdmWWFQYmRlbGNJYWNkSmRRYjVnYWZLZTFnMGR3ZEpoWGhwY0RoR2hRaDlic2JDY3doMWZmZEVobmF4aEhmY2FsZlJmN2hXY1hiRmR3YVJnemY1Y3hoSGdSZTFiTmVHYlZhWmMwY2JhbmhaZnpkYmUwaFpjbmdGZ2hhSmJNZmRoVWJvZ1llQmFnYnhnQ2JJYzFhUWE5ZUxhbmROYndiYWVRZWxheWVYZm5kb2hjaFpha2IxYVJiU2RSY1ZiT2NhZFhjUWVZZ2NmRWJGZDBkVWVVYXBlT2dkaFJjRmd6ZlRhRmhrZXNoT2RCYjhmbmFBZ1JjUWFUY0JnR2JGaEdhRGVuY2hjRGVSYm1jMWdBYVVneGJrZ1RhY2VBZHRiWmRWY2hkSmQ2Y1JlMmRSZ0JjYmdrZXBha2hlYlZjRWNVZ0pnUmMwZERnVWJCZ2xoSGJZZmtoUmMyZWNoMmg5ZEdjWmR4ZFlhU2VUZEhmVmZLY0VmRmFKY0VkQ2gzYUJhYWZYY1djOWRxYmJlamYwYlVjZmMxYk5kemVBaFZocGVFZ1hlV2VNYVZoVGdtYWxnMGhHYkhjQmZCZ2RmRmJGY0toVGVuZFViUmdjYzBneGVSZWVkSGFCZWVmSWVFZmNnaWZBZlJib2VPZkJkd2dkZWdnVWIxYkpka2dZZGdiZGhSZldnaWJNZkZlSmdoaGNlQmRhYkVmZGc0ZlhnV2Y0ZGVoYmhYYmtkWGhGY0hhbGdKaFZmUWFSZEtiV2RBZ3NodmFaZjJhVmd2Y1diSGdrZFdiR2VsYjFhamFTZGhiMWFTYUVkQWNKZTVmVWYwZDVmRmNZZm1kWmZwaEZiSGhKZE9oY2F4YUJmTWVUYVZnRmRKY0ZiVWE1ZnBkZGNCZGhld2JTZ1NhQWJaZkFleGQxZTdkYmNqZ0pkZmRRZDNkaGh0aGZlSGRRY1BiYWQxZUlmVWFjZFVjWWJUZmVoRmROYlBmWmZHY3BjVGZHZFJiTmh3ZkNjMWJsYldiQmZHZzliU2VkYzFkUmd1Y1RkR2VSZ3hjUWcwZ0FmNWhWY0VlNWVEYlpmaGhkaGxiZWZIZ1pidmVjZDBoWWZ6YUhoeGNJYVFhZGFVZkplRWFHY2dkMWVZY2ZoaWZVYURlZmQzY0pmbWVkYndhcGF5Y1JobWJJZkdiVGZFZUJnUmJIZlJleGVIaFliSGUwY1VhV2hrZkZiMGRVaFVlcGVPZGRhUmdGZHpnVGJGZ0ZiNGRjZ0ZkWmIwaERkMmd0Y1NmRmRIZ2tlU2JXZnpoRWNBaFFiUmJzaHJlUWVnYzhlVGJiZVFmdGJSZkFobGNvaHphRmFHZG9mK2RMZDFmcGEwYmVhVmRjYUlnY2dVZmthVWhUYlJhOWFXZVlhbmJ0YmplWWJIYXBhUGJhYnpjd2RTYlRnSGVWZUtmRWZGZEphRWNDYjNjQmVhZ1FibWI5Y2llWmVtZGthVWJjZmtmNWE3Y1JnQWZRZ0VlQWFrZmRocWdEYzNobGdraEdoR2YxZUJhWmJGZmhhRGhaYUhmVWdSaGNiMGF4YVJmZWhIY0JkV2JkZkFoOWZyZlVoaGdSZXhhUmVoYU5haWFVZzBkZGFzY1BnaGh0Y1FkUWFIYTViMGJHYkVhSWJLZmVjbGJwaGtjU2ZUZm9lQ2ZMZlNjcGhGYWFhemNBZkplQmhVZTBjRmJTY25iUWE2aGZoM2hNZHpkUmNtYjlmQ2FXZmdiVWdtZVJkR2E4YlRjVmJ4ZGxod2NSaEZleGJ2Y2FobmVkYS9nRmNIYzljT2JKZ3hnbGhGZlJhRmYxY2piRmJVZTVhcGFkYkJnaGF3Y1FiWGdSYVJnU2FrZzVjMWNFZlhnTmNNZVVkWGRoZndmWGhpYkJmSGJJZWdjRWNhZ0RlZ2hjYkFoYWRsZk5jU2ZUZG1lcGJUaEdoUmhOaHdmQ2IxaGxnV2FFY25jcGNIZVphRWFGZXVmU2RtZlJlNWRTZnhoUmN4Z0Nid2NoZVllQ2drZU5kMGZhZEhiWmE3Z1poeGRJYnZkWGYwY0ZhQ2hDZWdic2JEZVFoRWVRaFhnYmVGaG9hV2NaaG1kSWQ2ZWFjUmJ3Y21nQmZqaHBlRGNRZ2poSWVRZ1dkQWFOZk9nZGIyZG9kWWVlZEZhQmZpaFVkVWNkY09mSWJSY2hiNmhSZ1ZlaGMwZ1dibGVaZzBiRGYyZXRiU2dGaEhmRmhHZEVhM2FoZVRoVGIyYlJocWJVaHhha2dUYWNmQWJNZk5lSGdsZnNjcGZTZFJhc2dBYmZlMWd4YmthWmNHYUVhVWdjaFJiMGNkZVRmUmFsYVdjZGNHYTViMmJjYTJjOWZHaFpleGJZZVNiVGNIYlZiS2RFZEVmUmJSZEhnbWdOYVBiUWFtZmxhaWFiZm1mRmJBYk9oZ2hjZ2doSGJqZ01oTWJRZUZiOGNWZVVnbmNWZDBhVGNIYWxhQmhLYUZmRmVDZ0dkamgxZFlkSWhFZklmdWZPZldkQmNHaGRlQmVGZDFlVWZoaHhiZ2VVYkJkTmQxaFVmeGJ0aHRoWWcxZ29nUWZIYjFkb2NMZVdoVmRZZVNhZWRrZ2Rha2VRYVdiNWFLY1piSGNsaExmRmRIZ0VhZGRIYlVnMGZSZkFjamN3YW5oSmZYaDBjUWhCYzNoY2FHZEVobGVGYjFnUWJraFFiYWJEaFZoaGQraEpoUWhOYS9iY2htaFplMWRDZUhhSWZhYmVmaGhCZktnVGNVZ2RkY2NBZkZkMWY4ZmZhUmZGZThjYWgzZVJoUmVTYmtkNWMxYkVoWGNOY01mVWRYYmhjd2RWaG5nUWNQZk9oVmdKaEllTGFVYllkYmZMaEJhc2FHZk5nMmVRZHNoV2dBaGRob2JDYjFoOWJMYkVnbWN4aFNlY2FWaEpiN2VRZDJhaGJUaFNheGFSaHhiSGFSaDFmTmFHZlZmWmQwY2JnbmNaYXpoYmMwYllmemNYYWxkc2dmY1hkMGVvYlFhVWFrYVFnTGhjZUZicGVDaGJjMmZKaG1iYWhSZTFjcGdaYkhhTWNRaFRiRWMxZlJhU2VSZ1ZoT2hhYVhkUmhGaGVjVWcxZGVoVWNVaHBjT2RkZVJlRmN6YlRkRmZGaDRjY2dGZDRhOGFBYVRkc2RBZldleWdVZEphUmh5ZEViRGFDYm1ib2M0YUhlRWUxYlNoSmhFZjRlMWJFYzFiUWN1Z1JoM2ZsY0JjSmZrZ1FiMGdLZHdjUmVBZlBoa2NsaEVnSGNWY3hoWWFKZGljRWRpZFBnMmg5Z2JnWmcxZ0JmSGVBZmpkWWRlY1djUmMwaEtlQ2QzYmdhT2VTZzJkOGI1YlRiR2FrZFVhY2NrYjVkemhFY0VheGROYlVhVWZraFZhVGhpY0FieWJHYUhjaGJKZmZmQWNWYktnU2YyY2dhUmhaYVZjaGNZYWRmSGhCZkdlZGZCYUphMmZVaGtjQmU0aFRjeGVNYnFmRmVoZHNneGNPY0JlMGRaZFJnemFoaENiQ2VrYzBhNGhlYmtnZGdrY1FlV2E1YUtnWmFIY2xnTGdGYUhhRWRkYlZnQWVzY1plWGhpZUJndWJhZ0dmNWd2YlZkWGJVZWZjRWNoZ2RmZmNTZ2hnQmhTZVJnQWV0ZXdmV2FrZUpndmhZZm1jWmdwYkZmSGJJZFlkTWVrYUpkTWdIZjFlRmVVaEZoUmVvZWhhUGdVYXRnK2NQY2pjVmFCZFdobGVWZGZmRWZYaE5jTWZVYVhkaGN3Z1ZnbmhRZ1BlYWIxYkliVWVjYVVnWmVhaFBmbGVOYUhlVGVtaHBlVGdHYlJnTmN3ZkNjMWJsZldnRWduY3BlSGhaZUVmRmJ1Y1NkbWdSZHhnUWIwZUFiNWVWY0VhNWdEZ1piaGVkYWtoZmRuaFpjdWZiZnhlSWN2YlhnMGFGZkNiQ2ZnY3NiRGNRYkVkMGRIZVdjbGZwZENnYmIyYkplbWZhY1JlUmF5ZFRjbmRNZ1FmVGRFZDFoUmhTZFJmVmdHYlBlVGF4YVJiSWgwaDhmTGFFZEZnbGhjZWRnUWR4YXpiSGRsY2hkMGdXaGxlWmEwYURmMmd0Y1NnRmFIZEZnR2hFYjNkaGZUZ1RhMmJSZHFlVWN4aGtlYmZJZGdodGFFY1Zna2ZZZXloRGVqY2RjUGNFZVFndGh3Z1lhVWNJYVljV2V4ZTBmZGJUZlJnbGFXZmRhR2Q1aDJjY2EyZDllR2daYnhhWWZTY1RmSGNWaENiUmhCZ29kTmdXY0hjNGVsZkFhM2F0ZjZjWmZuZlFnVWZKYmdhWWE2YVFmMGNJaHlmRWZGZWdiRGJSYjJjVmZlY0dnSGVCY0JoZGhGZUZhS2hUYW5mVWZSZmNiMGV4ZFJlZWZIY0JjV2VkZEFkY2UvZEdmbGUwaGlkU2ZHYndmNWZRZWxmbGRrZWRhMWZOZExmR2ZuZndhaGVXYlZmWWhTZmVla2dkYWthUWZXYjVkS2FaZUhibGhMYkZlSGVFYmRkSGNWYjRhTGNWaG1kbGh6YmRlaWNkZG1hYmVHZGNlV2FFZmtoeGgxZ1NmaGNCZ1NjUmJBaHRod2FXYmthSmJ2YWFlMGJ4Y3BlRmRIYkpiT2FjZHhkQmRNaFRkVmJGaEpoRmZVZDVhcGZkZEJjaGF3Y0VmemNFZ0ZoSGJ4Y3dlN2RFYlNkY2RFZkdhQ2Z0ZXJoZmdIZlFjUGVhYzFkSWdVY2NhVWhZY1RnZWZGYk5mUGZaZkdlcGZUaFRnUmZOYzllRmNsZ2xkRmFBZ0dmRmN0Y1poRWZGYXVhU2htZVJhNWJTYnhhUmh4Y0hnUmgxZk5oUmJIaHhjMGViYW5jWmd6YWJjMGdaY25iRmFoYUpkTWJkZ1VhcGhHZkVmeGhZZExmT2JWaHBjZmFiZDJnb2J5YUljVmIwaGhiUWhBY3hnUmhXYUZlVmdSZ1ZkUWNsY09jZWdHZElmUmhjYUJlMWIwaEJoUWNJaEhhSmVoZzhjTWNEZVVkSmVxYWZoSGh4ZzBiRGUyZHRkU2JGZkhkRmZHYkVkM2ZoZ1RjVGcyYlJicWhVaDFhd2VUZmJhUWd0ZFJhQWVsYW9hemNGZUdmb2YrZ0xmMWF0aHljZWFWYWNiSWNjZVFjd2RMY1JkQmJrYktiZGFEZW9jK2dPZWpjeGhJZUdjRmdjaENiWGZIZWxiZ2hFaEZiSmhFZ0NiM2RCYmFjUWJtYzlmaWJaYm1ia2hVYWNla2c0ZDhmRWFGaEZmTmNXaFFnQWRWYlVjbmJWZjBlVGVIZWxhQmZLY0ZoRmFDYkNkM2VVZlBmYmFWZkpoUmRjZkdmTmJFYWRkQWFKaHJmQmVoZjFoNGRTYWpkbGY0Y1VlMGU5ZGtiYWZsYk1jWmNFZDNkQWJMZldoVmdZYVNjZWFnZTlla2ZYYUdiNWVDYUliWGZsYVhjQ2FIY0ZhSmdGZ0VjMWhGZVZlbmZ3Zm5nZGJtZTFoeGNXZUdlY2FlZkFlVmY1ZjFnUmR4Y0FnR2JUYVFkSmRyZGNoRWdKYXZoWWNtaFpocGJGZEhjSmdPYmNieGJCZk1jVGJRY01hTWRRaFJhc2Y3Zk9kaGhoZDRhYWUzaFJmUmdTZGtiNWgxZ0VoWGJOZE1nVWRYaGhid2hWY25kUWNQZllld2JaYWNoT2JCYlVjZGFCZXhhSmZmaGRiR2RwY09jR2FRaFZnbGZIZ2thcGZEZkVjbmF4ZEhlTGVFYmhnaWVZZEdkUmU1ZVNkeGdSaHhiSGVSYTFnTmFHaFZkWmUwYmJmbmNaZXpnWmZ4YUlidmNYYzBnRmNDYkNlZ2NzaEJoUmNFZVFiV2hjZUJoSmNDZGNjWGV4YzRnYWFRZVZka2dSZDNmOGU2YlRkRWExY1JmU2RSaFZoT2VhYVhlUWVZZGNhRWdGZzBmVWJVYnBmR2FJZFZha2M2aEhnMWQ4Y0hoTWFVYVZhbWhEZDNjWmdTZEFmbWRSZVRoQWhHZzFnVGZTZFdnUWdsZldmaGJVYjVjY2FBY3RhWmJWaGhnSmU2aFJoMmJSZ0JiYmVrZnBoa2hlZVVlc2hjZUpmVmdWaFVoSGRoY2NmcGNOZVhmcGh1Y2NiM2FKYkdlS2hCZVliTWRVZ21idGZLZUFnVWhSaE5nQmgxYXBmYWhRZG1kOWJpZVpibWhrZlVmY2ZrZDVoemdFZEVieGJOZFVjUmUxYmRmQmd6ZXBhZWRHY0hkQmZCZWRiRmNGY0tiVGduYVVkUmVjYzBheGRSYmNoV2d0aDhhZGNBYzlkcmdVZ2hjUmF4Z1JoaGdOYzRkVWJ4YkpjdGhaZ25na2FaYkVjM2ZBYkxjV2hWY1llU2NlaGtjZGRrZFNnU2NaYkVkTmRDZ3NiRWRRZERoNWVKZlJjQmIxaGNlV2NDaFlnaGNJYWpnSWg3ZUFleGZWYWZiVmhRZlFnaGNTZWdkMWJTY0RnQWNVZ2dnQ2RBZzBoN2NMY1RnSWh3ZVJmRGZkZkFoSWJWaDhiWWVIYTFhRmVVZEZlUWRnZDhiT2VsZ3Nha2FDYURic2VmaFNna2ZZYmhkR2dIYk1lWGZlYTNkaGF3YVZlbmdRaFBmYWMxYUlnVWFjYlVnWWdUZWVkQmNvZkpiWmVHY0pjYmdFaFVjZGR3YURna2hSYldhQmFHZTVjT2JhZ0VhRmYrZ1NkbmhsZ2tmU2gwZ0JiNGRGZkJiMGdmZ1hmQWNJZ2hkUGFEYmhhemNPZXdhNGJ1Y1JjUWVsZ21lZGRVZ29hUWZVZ2tjUWdMZmNmRmdwYUNlYmYyZEpjbWNJY0ZnSmF5Z1JkaWhjZFFjVWZsYkJoUmdXYWdmZGVIaGFkU2U4Y3llY2RFZUZjMGZVYlVhcGhPZmRmUmdGZ3pkVGNGaEZnNGJjaEZmWWNpZFRoamRsYVNjUmRuZUZmYmRFZnlhd2NiYkJoamFkYmtkTGdGZ2dmRGFZZkJlQmR6ZVZnaGRKYjZiUmgyaFJmQmRiYWtocGhrZmVhVWNzY1VjY2VSZzFhVWZDZHhnbGVlYVhibWQ1YTJnY2YyZDlkR2ZaaHhhWWdTZlRhSGFWYUtkRWRGY0pjRWNDZjNnQmRTYVNmamJzaHFjTGd6YW9oYWFEZVFkOWVqZEFoRWN4ZlFnVWNSZzFoZGFCYnpkcGQ2YVpjemhGZVNoWmFsYmhkR2NaYUhmVWFSZmNoMGd4ZFJkZWdIY0JmV2JkYUFmOWVyaFVnaGZSZXhmUmVoZU5od2RCYXdjY2R0Yk9iVmUxYW1oVWFtZ01oWmhXYlVjc2ZTaEtjRWc1Ym9nYWYyYzVnS2daZkhhbGFMaEZoSGFFY2RmSGRVYTBkWmRWYW5mUmZ1aGRobmZOYW5kRmhHZmNkTGFFZmhiZ2I5ZEFnMGhOYWNjT2MwZXBla2ZRZmthdGdqYlNkR2JaY3BnRmZIZ0pkT2djaHhmQmRNYlRmVmNGZkpnRmhVYjVjcGNkZ0JnaGQ0YkZoVGF3ZFljR2hVZUFjS2FVZEdoZGhVZVVoV2hWaHdkQWRqY3hkR2RPZUZheGJyZU1lRmFjZ0ZiY2JWYzllbGZaaEdlcGdUZUdhUmJOYXdnQ2IxZ2xmV2NFaG5jcGJIZlpnRWNGZHVnU2ZtYndhdGNBYTFmMGhpaEViMmFJYU1hQ2JFZkJmMGdjZDNoWWVoaFpna2JwZk5kRmJoaEpjTWVkYVVob2NRZVVma2JRaExjY2hGZ3BhQ2NiYTJnSmNtaGFiUWFkY2dlVGVtZTRoTmhUZ0JhbGZZZVlieGNWYk9nYWZYZVFlWWJjY0VjRmcwYVVkVWRwYk9oZGFSYUZnemhSZ1hodGQ0Y2NiRmhaYjBiRGUyZHRnU2NGZ0hoRmZHY0VmM2hoYlRlVGQyYlJmcWZBaFZneGRIZ0piVmZrZVhnVmdrY1ljeWJEZ2pjZGVhZ1JlRWZwZ2tmZWNVYnNjVWhjZFJjMGFkZFRhUmNsZldmZGdHaDVjMmhKZzJiOWhMY2ViaGFZY0JhWGhtZDVjZ2dFaEZnSmVFZENoM2VCaGFjUWFtYjlhaWFaaG1oa2NVYkxkMmZSaHpjRWZFZnhoTmFVZlVma2FWZVRlbWZsYzBmR2ZIZEFoWGVOY1FkTmFLYUJmM2RVY01hY2YwaFFhRmdNaERoa2FGZWVobmRBaHFjUmdnZ3hmeGFXY2dhOWU0Y1FmbGNsZHRoYWZnZDhiWmRSZ3pmaGZDZENhbGhoYXRhT2QxZlJlMmZUZFVkUmJLZlpmSGhsY0xkRmNIZ0ViZGJIYVVjMGhaYVZnbmNSY3VnZGhqZlpkdmJXYjJnY2hlaFJlZ2VRaDhjR2FSYTRodGhCZFJocGRtY1dkbGI1ZXplWWVuY2RjL2dIZVhiSWJTYWNiMGRRZkVjQmVBYUpiSGFhYWdlOWQ1Y1pkQmdSZmFnUWZYaFJoUmFTYWtmNWExaEVhWGZOY01hVWFYZ2hmd2JWZG5oUmFBZmFhMGQ4ZVVjZWVRZThoVGhaYmtoMWVSZVpjRGU1ZGFjR2RVYjlnd2RBYnhheGJXZERnbWdaZEhhYmVGaEpiOGJTaG1jbGU1ZUhleGUxZjRlRWdUYmRjTmJHYlZnWmYwZ2JobmNaZXpmYmcwYVpibmVGZ2hmSmFNYmRkUWVJYVFnVGYwZFFkRGhOaFZjcGRjYmNiWGh4ZG1lUGJSYjFheWZFZ25jTWRZYkJjVWQxY05oVmZSY1ZmR2FlZW1nWWhZZGZiVWJFYWdhV2VFY05mVmdYZ3hlRmF6YlRmRmZGZTRlY2hGZFpmMGJEYjJodGZTZUZoQ2ZNZURlUmN5YTBjQmZBZldnUmhpYmVkUmNrZFRoY2FBZ3RlWmNWZWhlSmM2aFJkMmVSaEJiYmNrZ3Bka2JjYVJnOWJjYk9nRWQ0Y1RjTWNsZGhnR2VaZEdoNWdyZmNmM2dsZVRjY2hnaFVoSGdUZkhlTmFLY1diRmJ0ZUljSWNYZ0JiYWVRZW1mOWZpZlplbWNrYVVhY2draDViemNFaEVjeGJOaFdjUmgxZmRoQmZ6Z3BlNmFaYnpjRmZRZVlibGJGZVhlVGhqYzBjUmJiZFZmSmhQY2VoR2dGZkFmZmNRYU5mQmVVZWhiUmR4YVJmaGROYzRjVWMwYzlka2ZhZ2xkTWVaZkVlM2JBY0RkRGZSZzVhYmRLYVVja2ViY0FlSGQxZFlmWmJHaFJnTGdBZ21oUWdJZkRibGFnaFpoVWFIaFFkaGRmZjNiOWdGZ1JmbWVjaFdnRWhrZHhnMWJTYWhiQmRTY1JlQWR0ZndhV2VrZEpibmNOYmljNGhnZFJiM2J3ZnhnTWJnZ1JhVWhUZVVkeGhKYldma2U1YzNiYWFnY1pid2JVaEdkSmVZYVJhbWhSZTFiRWNYYk5iTWZVZFhoaGJ3ZlZmbmFRYVBlYWYxYkllVWVjYVJiSmdiZU1oUWVCZGxoWmRHZXBhVGZHZlJnTmV3Y0NiMWhsaFdnRWFuaHBnSGhiaFZncGJFaFNibWdSZzVkU2Z4YlJkeGZIZFJnMWFOaEdnUWV0YjloWWFsYXhlemhiYzBmWmVuaEZmaGJKZE1nZGJVYm9kUWFXY2dmd2RGaElmQWFnZE5nT2N5ZjBkeWVNYUVoUWczZFFoRGJCY2NmQWN3Y01kVWFTYlFjaGFPYkxkeWJGZVdkTWZ4aFVoOWhIZWdnUmNPZWZlUmJoYnpiRmQzZ3RhNGRjaEZhWmUwY0RhMmh0ZlNmRmRIaEZnR2NFZjNhZ2JCZENoamVBaC9oQWNWZGNhVGVQY2thNGNPZ1ZhbGZwZXlkRWd5YndoSWhQaFVlUWJiZE9hRmJzYUVkZmZSZzFhSmhCZ1ZlQWFGYmVkaGdFZzNlWWNuY2xkS2NaYTBkSmNhYUJoU2RaZkVkYmh4Zk5nWGJHYVhkeGJhZkZmaWFjaHJhTmdXY2RkcmNNaDFicGNyYkdiVmRkY25lVWdVaGtnVmdUaG1jbGIwZEdmSGFCZEJhZGNBYnhmRGFRZGxhOGVSZGNmMGh4ZVJoZWVIZkJkV2VkZkFkOWRyZldmbGIxZHhnV2J4Yk1kRGRMZ2tlWmhvZlFoRmZNZVpnRWMzZEFjTGhXYVZiWWVTYWVla2FkZXNoQmdHZDVkWGJaZkRoOGdlaFdlamhKZUpoVmdBYUpmWGdWZW5neGhuZGRmaWRoZkZiUmVtZWNlV2JFZmtjeGgxZVNmaGJCZlNmUmVBZnRkd2NDZEFnY2g3Y05nemhRaG5oRmhEYnBiVmVXZVJhQmhNYVRnVmRGZEphRmJVYjVicGhkYkJhZ2N0aFRmemZVZUJlR2RnZUlnc2RHYlNkRmJBZ1VnVGdGZzVlWGgzYmdlbGJhZjFjSWhVZmNhVWdZZVRjZWRGZk5jUGFaYkdndGhiZVRjMWZ3aDVmVGgxaGxiR2RFYm5hdGdhZmViVWdFYnJmU2ZtZUpkL2JTZ3hid2FsaEVhMWVnYVZmU2FSaGtobWRPYmlhVmR6aGNia2NZYmlmSGR4aHRmWGNYaDBjb2RRYlVna2ZRZkxoY2hBZWRkTGhaY3pkWWV1Z0llRWRkYjdoVmFWY2tiUWNUaEViMWdSY0ZhQmFsZmtiYWhYZlFlWWhjZUFiY2JoaEhkd2ZrY2FiUGVGaDRhOWRUZkZja2dzYWZnRmJZaG1jQWcyZ3NkYmRIYVhjRWVkZk9mWGFoYVRlVGMyYVJlcWZVZnhiRmVWaEphVWVVZGFnQWNsYXNhMWVDY1dlUmFKZVBnRWNOZGtkSWFtaEVmVWVjYlJjMGRkZVRiUmJsYldiZGJDZWdhamZQYlNld2FTZExnbGdsY2NkVGZEY0JlQ2dSYUZldGZFZVVnRmZwZ2FjUWdtZjllaWVaZm1la2FVY2Nha2M1aHpmVmRnZk1kZmVVY1ViRmREY0RhemF0ZDBkU2NuaEJiY2FkZUNjb2QzY1FjbmdWYllhY2QxZ0ZlUmFhaEhleGVXZU1kUWI5YzJoVWRrYkJjL2VDZmxlWWIyaEZkQmNzZ3NmY2hWZk5oY2FFYTJnNGVMZkVnRWMwaFNmTWQwZXhjdmFTZ0dlNGRSZFRjbmZsZ0xoRmhIZkVoZGJIZFVoMGZaaFZnbmNSZHVhZGJpY1VndWZGYkdkZGdaY0VibGVGaDFkSGNoZTRhUmhEYUVkb2FpY09hUWEwZ3JjSmR3YWNmOWJIZERjdGdIYWFoRGJwZ01iVGRWY0ZkSmZGYVVjNWFwZWRkQmRoaHdmUWFYY1JkQWRXY0ZhWmIxZkRjM2RNYkRhZWIzY2hhd2hWZm5lUWNQZ2FiMWJJY1VnY2VVY1liVGNlZkZnTmFQZWVjMmhvZUJlRmcwZE1kbGhXYkJoRmNlZlhmWGFOaHRmWmRFY0ZhdWNTZW1lUmQ1aFNneGdSZnhiSGRSZDFmTmJHaFZhWmJ1ZGJhbWNSY2plZWExYzVibmFDZEJmSWZEZVhmMGFvY1FoVWZrZ1FiTGhjaEZncGJDYWJmMmZKaG1hYWRSZFJieWRVY1hkTmhDYVFiaGUwZUVnR2NsZzFlR2JlaEdkMGVLaGNkQmUxYTBmV2RRZlZoT2VhaHdjOWd6aFdlbGJoZDBkY2VFYWRkbWhGYTJmc2VPZ0ZoSGJsZlFiQWNIZGhkVmNUZXljdGNqZFdlamZNZlRoY2RBZXRiWmJWZGhnSmg2ZlJjMmRSZkJmYmJrZXBka2hlaFZmRWNVaFpiQWVnaFBoVmJBYjllV2ZhaG1mNGg1YmNoemVNZWFlWmQxYWthU2JVZW1jaGNLYUJlVWZWYlhnSGIyY1Jmd2NRZm1iOWNpZFpmbWdrZVVlY2RrZDVkemFFY0VkeGhOYlVhVWZrY0thVGhqY3RjNmJTYkNiVWVTY1BkRmFsY1lnWGhHYkVmUmZMYzBoeGhaYU5nM2NCY0liYWdnZTliNmVRYUJnMWQ5ZFJjZ2RKZHFlU2QwZzhkNGNhZ2xkc2ZSZlhlSGZBYlZmUmIxZVlkRWFjZDBmZGRpYlFnWGNoYVpmYmdYZlZoTGJCaFdoTWNGaEhjUmRFYVpmWGJtYkphOWJkZG5lVmV2Z0NlV2g0Y2ZoT2ZFZ3hjMWVTZ2hjQmJTZ1JkQWd0YXdjV2VrZUpmdmNZY21iWmdwYkRmbmNKZ0dnT2VoZHRjSGRRY1hidGVKZEZlVWY1ZnBnZGRCZmhjd2hRYVhiUmFSY1Nla2E1YzFoRWNYYU5iTWRXaFRlZGJ3YVNjM2VRZVpjZmhraGNkSGhaYjBnWWZZY2VhRmJ0Y0hiYmdIZHRmRGVDY3djQmJ3ZERmVmdrYVphR2gzZnBnYmdlZEVmRmIvaFdhbWUxYzVkRmV4Z1JoNWNEYkFiMWRmYkNmbGRaY3liYmJpY0piOWVMZUFnNGdtYVJhSGNFZkRiTWVRZDlleGVCZWtheGVDYWVhVmVOZUxoWmFtaDVmTWVhYlJjUmZ5Y1RjbmNNZFFiVGJFZTFnUmFTZVJmVmRPYmFjWGZRZFlnY2VCYk5oNmNBZlJlOGVkaFBkUmJsZVphVGdGYUZmNGJjZ0ZjWmcwY0RlMmV0aFNiRmZIZ0ZjR2dFYTNlaGdUYlRiMmdSYnFlUWhRZTBoRGhjYkZkZGhaZ1hmbGgxZDZjV2FYZ3BkQmNmYzFiSmV0Y2RiV2NFYlVhY2ZSaDBoZGNUZlJjbGdXaGRjR2Y1YTJoY2YyZDlhR2daZnhkWWFTZFRhSGRWZWJlQWdrZnBjRWhWYTNoQmJTYlNiaWVCZWljZWJIYWNnVWdZZDFjeGQ2YUVkRWVwYk5hUmcxZW9hY2VRZWtlTmUwZkdoSGFCYkJkZGVGY0ZmS2ZUZ25oVWhSY2NlMGh4Z1JhZWhIZ0JlV2VkZUFiOWI2Y1FjQWZ4ZnhkR2VoZE5od2NXYndhQmFrZGRiRWgwYlpoQmNYaGtiTGJYZjFkWWFFZWFoVWc1Zm9nYWgyaDVnS2haYUhobGZMZEZhSGRFZmRiSGhVZzBkWmJWaG5oUmJ1Z2RnbmdOaHZlUmVuY1ljRWFDZGtid2ZwZ1NhaGJoZ0VhVmJ3ZXRhMmVXYmdnMWZtYlNmR2JaY3BiRmhIZkpjT2VjY3hoQmJNYlRjVmZGZ0pnRmhVZDVjcGhkZEJlaGY1ZlNnR2M5ZzdnU2FraDVnMWJFZlhoTmhNZ1VmWGFoaHdnVmJpYWtjbGZhZDFoSWZVaGNlVWdZZlRjZWRGZ05nUGZaZkRjZ2ZXZFRiVWdZZGljUmdWZmtjWWhWZ3liMWVIZUVlUWJnZWdoSGNuZXdiWWVHaFVnWWZ3YVJmQmNVZGZoRWhFZzFoZWhiZ25mWmR6YmJkMGNaYW5mRmFoZ0lkUmVYZDBkb2RRYVVma2JRZ0xoY2hGZnBlQ2FLaFRnY2dvYktia2ZBYTdmQWNUYTBhUWdBZDBlVmNZY1NkVWI1ZmtlYWJYYVFiWWdjYkViRmcwZVVmVWNwaE9lZGZVZk1iMmZHZUFiUWJxZlBkbGRaZG1lRGEzY1pmUGhGZURlQWRVZVZoQ2gwYmViQ2ZpZW9nK2hBZUJlZGRmZk5lVWFVZWVmQWZsaHBhUWZSYzJmUmFCZWJoa2NwYWtkZWJVaHNlVWFjZVJlMGJkY1ViaGhrZFllTWZUYWxkMmRQaEdmY2RIYk5lVmdGZEhmQWJUYUFnRWZSaEFhRWcvYUdjZ2cxYlRkVGNEZW9meWhJZWlhaGRBZE5kMGVZZnlmUWJnZXNhWWhIYkFkeGViZUdlamVvZlBlQ2hBYzFlSWRlZWhiVWREZUNlVGVCYUNkSmUwZ1JjWWZVZW5lQmJXZ2RmQWU5aHJoVWRoYVJleGhSaGhkTmQ0ZFVlMWVWZ2tjUGhoY3RiUWhRZ0hjQmFDZEZid2RWZUdkT2F3aGtmbmRCZUNjRWZNZVpkRGdaZWhoRmJIZEVlZGZIYlVkMGhaZFZnbmZSZnViZGRuZ05jdmJXZVdhZGhBZlhoUWdVYnhiU2RsZ2hoY2RCZDBnb2U4aEZha2FvYTdnS2hpYjhmNmFHZEhnSWhQaEllVmhjY1plQWhCZFFkSGdRZVJhMGhTZlpmR2FWZzVhYWEzZVJiUmRTY2tnNWcxZEViWGVOY01iVWJYY2hld2hWZW1kNGhQZkpnUmhkYkRlY2VRYWtmYmNPaFFmRWVJYk1jU2VjY1diVmMwaGNlamVjYkVha2dyYUdoMmFGZ3RiWmhFZEZmdWJTZW1mUmI1YVNmeGJRZXNlTmd4YzFnTmFHZlZoWmgwZ2JjbmJaaHpiS2FSaE1kcGFWZ1VlWWdGZE9lZ2ZRaFFjR2drZnhoZmRlYlZlb2NaZFJmV2dKaG1iYWRSZ1JkeWhUZ25nTWFRZ1RlRWcwYkRkRGFFZUVhYmFPZ3phb2ZZYmVhR2N0ZjBkVWJVZ3BmT2hkZFJnRmZ6Z1RnRmVGYTRlY2FGYlpnOGVXYXloTWRiZFJkM2U4YlZoVmdqaDBhWGhUYTNhbGNxZkJmeGVsZWFkUGNsZGdmTmhGZTFkd2g1YUFnaWhzYkhjYmJnZVJia2RaZmtldGZBY2ZjMWg1ZVJjQWhsZGNlVGJmYUdkZGQyYmFoV2Q4ZUlmYmUwZUlmYmRSaFhlbGFnZ0VhRmdKYUVmQ2QzZ0JjYWVRY21mOWJpZ1pjbWJrYlVhZWFoYW9nN2ZXZ1JjOWhEYUJnMWdnY1ZkVWUyYWtoZ2dVZERha2hTYmVmZ2hJYlBlQ2V6aEVkZmRNZUFkQWhlZ05iamVWaGVhZmVRZUVjcWhGZWxoQmY1ZUZkUmRwYTJjRWZnZ3NoZ2FZZWhmSWFRYUdibmN3Y2hiV2FWZFlkU2hlZWtjZGZraFFhV2g1Y0thWmZIaGxjTGRIZENkVmNWZVZkQmM0Z1hjQWhHZVpkdWRhZzNmTWU3ZURjaWg1YkZnSGhCZThld2ZEYTFiUmZjZkJlMGJjZi9jRmFBaGRmbmJhZDJjZ2hvZFVoRGZaYkdiTWFoZWxoRmZRYlhldGJKZkZlVWE1ZHBjZGhCYWhnd2ZRYlhiUmNSZlNla2g1YjliUmZUYnNhRmdBYW5iWWJtYVJmWGZRZlNlYWJ3ZVpmY2FPZ0JlVWZkZktheGhZaEtoSWVHaFFkUWdWY1Znd2ErZlRlbGZGYWZnR2MzZFpmdGNaaEVjRmZ1ZlNhbWNSZTVoU2h4ZFJleGFIZVJkMWNOZkVnUWNJZDhkSmN5YVZiOWRPaFZkSmNuZENheGJJZFlhUGFRZk5oRGNYZ0JlZGdPZk5mUmI1YU1iTGhDYTRjcGFKZzFiRmg2Z1JjM2UxaERkR2RRYThmRmdHZDFhUWZOYVBlWGZ4Z0xiZWVVYmhoNGJlaDBkcGFPZmRjUmdGZnpkVGVGaEZjNGhjY0ZiWmEwZkRjMmJNYUdmWGJEY2diVmRIY1Nod2djYUdjeWFVaG1jTGdGYVZhV2ZQZ2dldGNFY1ZlZ2hKZXpiU2cwZzVoQmJiYmthcGZrYmVlVWVzYlVjY2JSZjBhZGJUZlJnbGhlaEllQ2hZYi9oSWdHY0ViTGZJZ2xkdGRCYkJiU2Q4Z1BkRWNFYjlmRWJHZzNobGJXZmFhR2Q5ZmlhWmdtaGtmVWFjYWthNWF6ZkVnRWV4ZE5mVWJVZkZlQmNCZ2loQWRuY0ZjamgwZUVnT2dSZzRkWWVGZjNkVWFNZWNld2ZJZkVmTmVEZ3hmZmhlZ0NlVmRyZlVjaGVSZHhhUmRoY05jNGFVZjBlOWdrZGFlbGJOYk5jV2V6ZGxjWWVjaDFlWWhTZmVha2hkaGtiUWNXZTVmS2FaZUhlbGdDZ0RjMWZzYmRiSGVVYzBnWmVWY25hUmN1YmRnaWI1Y0ZlUmhtZ2NkV2FFZmtjeGYxZVNjaGNBZUVhQmZWYmxld2RGZkVoSmN5ZVlkaWM5ZWhnQmRYYnRjQWVCY25ka2NpZk9hVWhkaGRjR2RXZFJocGZkZEJkaGF3ZVFoWGVSZ1JlU2RrYjVmMWRRaG5iTmJSaFVlVGNaZjRlVmhHZ1VjZWNmZzBnSWZFaFpibGNjaEhhYmcwZ3RkYWhkYUhmMWhIZ0Rjd2FwYWtmSGJFZkJjSGRFYUhlTmVMZFRka2JGY3VkU2VtYVJhNWFTY3hhUmF4ZUhiUmYwZk1oR2NVZXRoMGdJZEhjNWN4YmZhbGVKZDNnQmRBYnRjWWNZZjFkMGhEaFJoRmFJZVRmYWJVZDFjU2hmY25hdGF4ZmVod2VOYndlUmgzZzhoNmRUYUVoMWVSZ1NoUmNWZ09jYWJYaFFoWWNjYkJoUmMwZlRmRWVvYUFiZmRSY05iaWZXYmtjRmdoYlplVWg1aGpoRmRuZGxlTGNCYjJnaGdVZ0NjMmN0ZkthWGhuZ0pkN2VVZ1JoQWRmZldjZ2d0Y1pnVmFoYUplNmhSZzJkUmFCYWJka2ZvYmliZWJWZ1llVWZQY3hnVWRmYlZlQWI5YURoWmdIZzVia2RhYm5iMWFTZGRjUWNRZ0toV2YyZDFiWWRDYUVlZGhUZ0VhbmdKYVRhVGJrYlZlaWVaZG1ia2JVYmNja2Y1YnplRWNFZXhnTmVIZlVia2hJaFRnaWFkZzhoR2RtZUpmWmZZaDBiRmNiaFdnV2JJaEZnWmJsZnhhQmdhZldlSmZBZVpiQmM5YTVmUmNBZVZnemJUYXdnaGRTaFVhMGQ5Y2tiYWdsZ01jWmZFZTNhQWJEYkZlbGNoZENnS2FBaGdjd2dEYWpkb2NUY05iRGF4ZkZkWGNUZjlkVWdTZ1VjMGRFZVZmamN4Zm5mZWdsYWxjdmFSYW1oY2JXZEVla2F4ZTFmU2NoaEJnU2JUY0VhUmYrZENkaGJBY2diTmZpZ2tlOWZUZ1NmSWdMaGZmVWdVZ2NnQ2JSZ0FkZGJVaEVnNWEwZGRnRmg0aGxkRGV6Z2NkRmJBZndiRWI3ZUVoWGJzY1llV2ZIaGdocmRmYUhoUWZQY2FjMWNJZVVmY2dVaFlnVGhlYUZlTmJQYlpiRGR3YVNoU2R4aE1kNWNCYTNlTmZXYUVmbmFwZ0hlWmZFZEZmdWJTaG1lUmY1YVNieGZSYXhnSGJWYUpjTmRCZkZnWmQyaFBjU2hJYWhlSmRnZWdkZ2ZGY0JlSmRSY2FjRWNwZ0VlQ2d4Z1JhT2dQYnhheGJDZk9hM2ZsYk1lYWNSZ1JheWZUYm5kTWVRY1RnRWgxZ1JlU2ZSYVZnT2ZKZ25jUWFlZWRna2RGZzhkV2VSYzViT2FhaEJoRWIyZ1JnQWVWZ3hoZWhWZnBiMGRCZ3lnUmdTZUNmWGJGYkhhQWFuZkZjZmFUYTJhd2RqZlVld2NRYlRhY2VSaHRnUWdYZXhmNWRRZlJlMmFSZUJmYmVrZ3Bna2ZlZVVlc2FVYmNiUmEwaGRmVGVSZ2xoVWNJZ1NjQWR5Z05jaWJrYlBlS2dWZU5hV2dUZm5oVmJMaERmVmZJYlFoVWNpY0FlZmdEY1NkbGVpZEJiemh0Y0dlTWF4aGNkUmJSaFFkb2FMZ0ZhQmZzYVZiU2VHaDljZWZHZ0hmQmdCaGRiRmdGYUtjVGJuY1ViUmNjaDBkeGVSYmVlSGNCZ1dnZGZGZXRlcmVHZTFkb2ZpYUVmbGNJYjJiRWVBYm9lcmJMZ0ZlTmU0Y1FkU2RKYUtiQWdEZlJjSGhQY0FjRWRoZ0VmMmU1YU1kWWVsZE5jTGRGY0hkRWdkZkhhVWYwZFpjVmRuZ1JidWhkaG5mTmJ2ZFJibWVjaFdnR2RrZFFoOGVTaGdiMWZTYlJkUmd0aDVnVmhrYUplbmFOY21nWmIwYUZjRGh3Y0xmSmZCZ0FkNWNCYUJjOGNkZERmU2U4ZDdmSmdsZmtmcGNTZVNhQmhZYVFjMGJkZnVlT2UzaE5hTWRVY1hoaGN3Y1ZhbmRRZ1BlYWMxZklnVWRjY1JkQmFTZUtnbGRNYkhiWmFIZmRjVGdDZlJnOWJhZENmMWNsaFdkRWhuZnBhSGRaZkViRmd1ZFNmbWNSZDVjU2R4YlFha2ZIYVFlQmZOZVRoVmRnYTRoS2V6ZWdkMGVPYndjNWNyYVBiQmhKZE1hZGRVYW9jUWFVY2tlUWFMYWNnRmNwZkNhYmgyYkpnbWZMZnhhUmZ2ZlRkamFzZFFlUmcwYjBkRWJVZWpmOWVPZ2FlWGZRaFloY2dFZEZjMGVVaFVncGdPYWRiUmdFYTZmQ2RsYkZld2NZY0ZoWmRwY0VobWJzYkhiSGZYZUVoVWRWaGlld2ZHZ0hoU2NwZHFlQmgxZEZkYWhJZnhkQmd6ZVZhaGdKZzZmUmgyZVJjQmdiZmtjcGdrYWVnVWZzZVViT2VGYnNoZGhSZFRkTmFXYWRhR2I1ZDJiY2EyYTlhR2FaZnhlWWRTY1RmSGhWYUtiRWhGYXBmTWNYaHpkZ2dUY0VhV2FFYzJlS2RUZjFmVmVQZGplRWUvZ1ZlUWRKZ05kV2RsZFFjVmJHYjJnQmU0Y01jbmVCYkJjZGRGYUZkS2hUaG5jVWZSYmNnMGR4YlJoZWdIY0JhV2NaYUFlOWcyZVRoeGJRZWxjRGdsZm9icmRYYVFnSWNoZUpld2dCaFFmU2RUZ1VjTGZYZjFiQWc0ZWVha2NkaGtkUWZXZDVhS2NaZEhibGZMY0ZjSGRFYWRjSGJVYzBnWmRWYW5ld2Q2YVBnamZvaDhmU2JDZXBoVGJYZndhTWduZ0VoeGFCZVBjUmZFYlJod2FSZFVmSmN0ZVlmR2ZaZ3pmRmhEZHRkT2ViaEJkQWVDZENoQWdaaEphWWRBaGNjbmNJZEFkQWVSYUVneWNZZFFhRWgwZ1pibWNBYTNkcGJNaFNoM2FnYytnRWR5ZU1mUGNPZFZjb2ZIY1lhMGE4Z2FmZGRIZ2xoUGVaZUdlcGVUZEdhUmhOZ3doQ2IxYmxnV2JFY25jcGJIZ1pkQmJVZ21nQWF6ZWRoM2JCaGxlRWc4Y1RhbGRRYlhiWGZGZFpoL2NiYmliTmN6YWNlMGVaZDBmQmRCZXRobWhkZ1Vmb2FRZlVha2RRZUxnY2JGZ3BmQ2FiZjJkSmdtaFljRGM1YXljVGJuaE1jUWhUYUViMWZSYlNoUmJWY09iYWJYYlFlWWhjaEJoTWd4Z0JmUmE4ZGNoT2Z4YkZhN2FaZWxjRmc0ZmNjRmhaYTBhRGQyZ3RiU2NGZEhlRmJHZ0VnM2ZoYVRkVGYyYVFkbGZlYlJna2ZUZWNoQWN0aFpnVmRoZ0poNmNSYzJjUmJCZGJoa2ZwY2tmZWJVYXNoVWhjZVFnSWVkYVJmVWUwaGViUGVUZzFiNGhQYmlib2JMYktmRWJSYkxhVGhIaDVlWGhFZUFlWmhOYUlmWGJCY2FoUWJtZDlkaWNaaG1ha2ZVaGNia2Y1YnphRWdFZHhjTmdVYlVna2hWZVRlbmdOYTBnVWZWZHBmQmhkZEZjRmNLZVRibmVVYVJiY2YwZ3hnUmhlZkhlQmdXYWRnQWU5Y3JiVWhoZlJndWdSZGtlY2F3ZUdkaGd4aHFkSmZ4YlpiVWNYYUNkSmJTYVZld2NWZlhmTGFrZDhod2RUYXphMGVmZEpiamRnZVpmUmdqYUJnRWJGZFZkMGZWYVZlaWRGYm5hZWZuYU1oN2FEaGllNWRGY0hlQWdFZndmQmQwZk1iYmdIZ2tmNWQ1ZGNiRWdKZXZmWWZtZVpjcGhGZEhhSmdPZGNkeGFCZ01kVGhWZUZnSmZGZlVnNWdwYmRhQWJKYXdoRmFYYm9nU2dCZFJkNGFzZkdhU2VjaEVlR2FDYnRnK2ZHY3piRmFDY0pkQWRCYk5kZmdVZlpiSGZNaEJob2NjZmFjaWNjZldlVmFFZUFnNWdVYlJoeGVhZEVobWNwYkxnWmhCZ1JjbmFSY2tkNWQ1YlNmeGhSYXhoSGFSaDFmTmRHYVZnWmYwY2JobmRaZnphYmEwZFpobmdIZWtlWWZFaFBoQmJrZmViSGh3ZEZlR2ZJaHhnTWVZY0tkbWZKaHRkZGZCYlFmbmJSYzNhOGg2YlRiRWcxZ1JiU2VSYlZmT2ZhZFhlUWhZZGNiRWFGZjBlVWhVY3BjT2VkYlVlVWE3YUJhUWFKYVNlY2FGaFpiMGJEZTJldGNTYUZiSGNGaEdjRWgzY2hlVGNUZDJlUmVqaFNnRGRNZlRjY2ZBZXRmWmFWYmhlSmE2ZFJhMmdSaEJkYmVrZm9ndGNQZzBoc2djZ0poVmZWZ1VnSGhoY2NnYmZNYlNmTWNsY09oamNVY0RkWmJ3YWdnU2ZYYUhheGRLZVNoM2FoYkVoQ2MzZEJlYWJRaG1mOWVpZFpobWVrZFVhY2JrZzViemFFZUFiTmFuZlViVWVraFZiVGFtZWxhMGFHYUhmQmFCZmRkRmdGYUtlVGVuZ1VoUmNjZTFkTmJSYWNoQ2ZRYmVjUGZWYXhnbGNIYTFhRWY4YkNoVWVFY2hkVWYwZ1JlNWhhYmdjY2JYZlFiRGR4ZkNlR2JoaE1oYWZhZWtodGdrZ1Vibmd4ZEtoYWJYYWtoZmRYZkRhaGFPYkVod2ZCZmNjR2Z5YWNlbmFMYURkWmhtZ1RiMGEwaFdmRWNrYXhiMWdTYWhoQmZTZVJhQWh0YndiV2drYkphdmVZZ21iWmJwaERnbmFJYkhoV2NSZEJhTWNUY1ZjRmRKZkZlVWQ1ZXBlZGJCZWhld2ZRaFhoUmdSYlNha2Y1aHFkRWVTaGNoRWZHYkNldGMrZkdlemVGY0NiSmFBYkJkTmNmaHhhVmVXZ0xoRmJ0ZWxhWmFHaHBmVGVHY1JoTmN3Y0NlMWdsZFdoRWhuYXBiSGdaYUVnRmZ1ZlNmbWdSZzVlU2F4ZVFjbGFFYzBnNGRZZldleGRjYm1lUGFEZGNhcWJaZjFnWmJyZkZmZ2JGZGVhZGdVZmNjUWVCZGdleGdDY0lhMWVRZFBhS2JpaDhlMWdJZEVkNGczZVJkM2E4ZDZiVGdFYzFkUmhTZVJkVmhPaGFhWGJRY1lmY2dFYkZhMGhVYVVicGhPYWRjUmdGY3pjVGdGZEVlc2VPZUJkOGFuZkFkU2FZY1hkV2RTY0lmUGFTaFRlMWQ1Z1RmMmVSYnFkVWZ4aGtnVGFjZkFodGRaZFZlaGRKZzZnUmQyY1JiQmJiaGtlcGRrYWNiR2hFZFVnY2dSZjBlZGJUYlJibGhXY2RhR2U1ZzJoY2EyaDliR2NaYXhiWWdTY1ZibmhVZ2VkSGZoZkViTGhXZnllbGFTYkZlaWFjZHJoTmZXaGRoWmVOY3djTWg4aFFmaGZWY0JhVWFSZzFmZGVCZnpicGI2YVZhVGZVaE1lSmV4ZGdkUWFDaDNka2VSZlliMGZCZFJkYWUyZUpkV2FlYlFoOGUvY0djbGIwZ2llU2JGZzRoOWRIZWhid2V0aE1oQmdZZVFkQ2FGZm9lTGhXYVZkWWJTaGVha2hkY2toUWNXYTVjS2haZEhmbGhMY0ZkQ2RkYWNoVGEwZzFlVmJWaG1jbGV1ZFphbWJoZ0ZnUmNtYmNjV2NFZmtmeGgxZ1NhaGdCZFNiUmJBZ3Rkd2ZXZmtnSWhtZkplR2VaYmhnV2YzY3RnT2JLY0RmcGZNZVRkVmhGZEpkRmJVaDVlcGRkYUJhaGV3YVFhWGZSYVJiU2RrYzVkMWdSZXphSWRlZlVkVGh0ZHJhZmZIaFFkUGdhYTFnSWNVZGNkVWNZY1RkZWNGaE5kUGRaZEdmcGVUYUdmUmFOaDRnU2NGZ2xiTGdFYWpiUmdQZ1Rha2hGZnVnU2VtZ1JiNWhTZXhnUmR4ZkhhUmMxZE5lR2RWaFpoMGJiZG5jWmZ6ZGJkMGc0Z3pjWGhsZXNmZmhlYndlZGVWYkhld2V0aFpkS2NWZVFhQmFKZXloTWUwZENnbGZzZzJiQ2d4YkplRWZSaEFjRmVSZFFjaGFWaGZoWWJIZ1FjRWFiZ0VmRmVzY1diRWVvZlNnWGh4aEZjemhUZ0ZiRmc0ZmNnRmNaZDBiRGEyZXRoU2NGaEhhRmRHZ0VmM2JoY1RoVGUyYVJocWFCYzFjRmhhYUljd2VVZVVhRWYxaDhmMWRGZVRkMWhQYUxhUWdJZ2xiS2N5YmhjYmdOZVZmaGI4ZkdkUmhFZ2FkZmhXZUpkY2RjYzJlOWdHZVpmeGdZaFNmVGFIYlZlS2dFYUZkSmFFYkNnM2FCY2FiUWFtYjllaWViZmpoMWdjaE9ieGExYzllWGZRZGtkQWNIaGhkdGVNZ1FjQ2ZvYzhnV2FTZklhaWhPaHhhVWhQZUxneWRFZ1pmUGEwZXhoYWdlY0dlTmJmZGRhQmdOZzNiVWNnaHhjNGNSZWtoOWRTZVVoMGY5Z2tkYWNsZE1hWmhFZjNjQWNMYVdoVmRZaFNmZWhrYmRla2ZRY1dnNWRLZlpoSGZrYWZmWGJEZmhmT2NFY3doQmFjZUdnemRzZjhhTGIzYzBic2hEZWlnWmFFZWNiUWhNY3hjRGIzaEVmR2dUZEVkZGd3Y1VhVWZKYTljYWEyaHBjRGRGYkhhSmRPY2NkeGhCZE1jVGdWYUZmSmRGYlVmNWhwaGRnQmVoZXdiUWFYZVJlUmZRY2hkb2E5ZVdhQ2NCYkNoSGNEYTBjOWFHY1NjWmFXaFphUmhGaGNkTWVCZlJod2ZOYnhjY2dLYUJhVGI1ZWJmVmZSYU5iN2FDZDBkeGVmZ0VkbWdaZGJnWmRGYWxhbmZTZGpmaGVUYlNoeGJSZnhjSGhSZjFoTmFHY1ZiWmYwZ2JobmNaZHphYmgwaFplbmFGY2hoSmdNYmRmVWZwYUVnR2NnZjFlWWJmY2hiY2NIZklkaWgwZDBlTWVCYm9leGRCZWpoSmZDZ0xod2RJaFZmRGFIY1FkYWRZZlRnZ2JZY2VnMGNGY2diV2ZFYVpoa2JkZVJlRmV6ZVRlRmRGZTRoY2FGaFplMGhEZjJjdGVTYkZkSGJGY0dmRWIzZGhjVGVSaHplQWVpaEdha2RvZ2RiUGhVYTRoVWdHZVVoQWNqZVNiU2ZjZUpjTGd4ZWdlSGVOZmdjOWFSZEViRWVrZVZjQWVSZ2xhZGVkZUhjbGYvYmNoM2ZOZ2FoWmd3ZzRoYmNUZ0NjbGZnZ0VmRmFKZEVkQ2czZEJhYWdRYW1jOWhpYlplbWZrY1VoY2ZrZTVmemdFZEVieGROYlVnVWhsYkJlQmZpYUFobmJGZWplMGFFZU9oUmM0ZlloRmQzaHRoU2hPaHdjMGZEZ0dnemE4YlNhTWRXZTRlL2hXZmxnaGZ4ZFRhUmROZHVhV2RtZFZia2NhZmxiTWhaYkVhM2JBY0xhV2dWZllkU2dlY2tiZGRrYlFnV2c1ZktlYmVYYkJnSGhQZm5kRWhkYkhiVWMwaFpmVmJuZFJidWFkZm5hTmF2ZlJobWhjZFdoRWhrZHhjMWVTaGtnUWNhaERjVmRoYitjRGFGaE5haGZJZXljSWR0Y0hnRGdGZEFnUGdrYlVhQWJHYlJnZ2FaYldlUmhkY2hoTmNSY0ZiNWZUYnljWWhlYkhhZ2VKYzloQWFtZkpnRmZYY3pkVWdsYkdmaWNCaEdmT2J4YTVoTmVlZ1JoVWRhZGRoSGZsYVBkWmRHZHBkVGdHZVJjTmN3YkNnMWRsaFdoRWFuZnBoSGNaY0VjRmZ1ZlNhbWNSYnhjQmN4Y1JhNmFBZEJkMWVWYkVoRmZwZWVnYmRuYlpkemRiaDBmWmFuYUZiaGVKZk1hZGZVZm9mUWRVaGtiUWdMYWNmRmRwZ0NjWmV5ZEZkbWNkZUJnUWg4YVJobGNrY1FjVGRFZjFkUmhTYVJkVmNPZWFhWGZRZ1lkY2FFZkZlMGhVaFVocGJPY2RmUmNGZHplVGFGY2tlc2NPZ0JoOGFuZEFnU2JZZFhjV2ZUYjRiVWdTZ25kWWZRZUJneWFVZjRjTWZGZFpoWGVOY1dnb2ROZlhibGU1ZjZoVGNHYVJoUWRaZjBocGc0aFphVWFzZU1oZWhCYTFhQmJaY3hkbGRXZ2RoR2E1aDJiY2EyYjlhR2NaZHhlWWhTZVRjSGhWZ0tlRWVGZ0plRWhDZDNkQmhhZVFibWI4ZTJnTGNpY0JiSGVmaEFkTWQyYVhmUWVNZWZnQ2NFZWRjV2dCaGloZ2NtZWVhemE4Y0ZoTWJUZUFhZWZSY2pma2FZYWZkMmFaZFJmZWJIaEJjV2RkZUFlOWdyZ1VlaGJSZHhoUmRoZE5jNGFVYjBjOWJrZWFmbGhNYlphRWQzZ2hmZmFFZlJlOWVCZGRoQWVvY2hhRGdDZkVjWWVQYVhoY2FJY1hlRGdCZlBlZmdnZEphZGVFZnhjVWU2ZWZkamI5ZXZjVGJXaGNoRmJHaDBheGVwYVZlaGFCYUtnVGNRYnNkc2FjZUVjSmh2YVlibWFaYnBkRmhIaEpkT2VjY3hhQmhNZVRiVmZGZUpiRmJVZTVjcGJkZkJkaGZ3ZlFkWGNRaEZjQWRnZGNlbWFIY3pjNGFKZUhjRGFjaGlnRGMzZ3BlTWhJZnhmTmVHZEVoZ2FsY1hjUGVUaElhYmFiY0NiWmNUaEVhaGNOZGllQWVsYVZmOGFFYm5jcGZIYVpnRWJGZHVoU2dtY1JoNWVTZ3hkUmd4ZEhkUmcxZk5oR2ZWaFpnMGZiYW5oWmU3Z09jd2U0YnVkUmNSYXdiQmhNZEFnZGFmaEFhQmEwZ0ZjTWZ4Y0lkRGhQZlFnRWFwZUxlVmZFaFRnR2RuZ3RjY2NUYkVjWmJSZ1hlQmd4YU9hZGhXZ2diWWhhYUVnaGMwZkRkV2ZCZ09lZGdSZEZiemJUZEZlRmc0aGNiRmhaZzBiRGQyaHRmU2VGZEhhRmNHZ0VjM2JoZlRnVGYyYlJicWdCZTFmRmZhYUlmd2JVZ1VnRWIxZjhhMWJGY1RmMWFQYkxoUWJJZGxiS2d5ZWhjYmFOZFZnaGg4ZkdjUmhFaGFmZGFHaFZlMmVaZDJlWmdLYlRhUmZZYlNoVGRIZ1ZiS2VFZ0ZjSmhFYUNhM2hCY2FiUWZtZTlkaWZaZG1na2JVYmNma2I1ZXpkR2FCZGdhRmFHYkJhb2hiY0FkeWh3ZDVnVmJ5Y0llWWdlYmhjSWNDZURneWFkZnllUGNBYmdlVWRHaFNhUmZlYU9lQWc5ZWdmVWhnZE5kNGFSY2dmOWZrYlVoMWZkZXRjYWNnZzhoemZFZzNjQWNMZFdhVmRZZ1NhZWJrYWRia2RRZ1dlNWdLZFpmSGdsaExkRmVIZEVoZGFIaFVlMGZaZ1ZiaWFBY21hUGh5ZEJmaGZDZXlmSmViZ1hiUmM0aHNlUmVGYU1jYWFCY1Zka2ZUYkZmUWZZaHFkQWJ6aEplaGNXZEhlSmJGZWNmd2JaaEZnWmgxZkZkSmJGZ1VoNWZwZWRlQmRoZHdnUWFYZ1JiUmJTZ2tmNWcxZkVkWGJOZE1oVWVYZkZhNWFXZ2xiNGdQZmFnMWdJZFViY2dVZ1lkVGhlY0ZhTmRQZlpmR2RwZlRiR2dSZk5od2VDZjFoa2FDZldjamJNYVVnYWVoZGRiOGRSYUNkVWE5aERmeGN3ZHlnRWUxY0FkWWFWZ1FmSWQ5ZlBlamNvYXFlWmd3ZGRldWRIYXhmd2RlZ09iaGg1ZGNoV2VsZ2NiYWFlY1ZhUWJQZ09laWc0ZXllSWFFZlFjK2JGZTNmdGJEYVJiVWVGZTdoU2NSYlZhT2hhZFhhUWNZZGNlRWVGYjBmVWFVaHBoT2JkZFJhRmJ6Y1RoRmhGYzRiZWNCZ3BiMGZCY0hhWmJTYURkSGRoY0tnT2NYaGhiVGZUYzJjUmdxaFVheGJrZFRoY2ZBZHRiWmhWZWhlSmg2aFJiMmVSZkJmYmdrYUlibmJlY1ZiWWVVZlBkeGNVZTNiVGZSZmxnV2NkYUdkNWIyZGNnMmg5Z0dlWmR4Y1lnU2FUYUhjVmhLZkViRmdKZEVoQ2QzYUJhU2ZGZmllY2dyZk5iV2NkY1pkTmh3Y01lOGFRY2hoVmZEYkVlZ2VGZ1VhSGRBYm9iN2dYZURiVWNnZkllRmZrZkdhVGFuZzRoUmhZZ2tmVmRSY1phR2V4ZFdoYmhBY1pmcmZEZWphNWd4Y1JnaGFOZjRoVWgwYjlja2NhZGxkTWJaaEVhM2FBY0xkV2JWYlloU2FlYWtjZGFraFFlV2Y1aEtoTWNEZUVhQ2FSaDNnOWdRZFdhQWJCaFdnQmFDYTFmZ2dOYlRlc2J1YkZmQWRSZVpjVmZnZmtmVWJIZ2hhZ2dlaFRhUWVkYmFmV2NrY0pndmZZZ21mWmVwYUZhSGJKaE9kY2d4ZEJmTWFUYVZmRmVKZUZoVWE1ZXBiZGFCaGhnNGhGYVRmd2dZZkdoVWJBZzRhVmZEYjRnRGFBYnllRmcraEZiVGd4aE9kT2JUZUZnYmJOYVFlTmF5ZkxiRmJzZkRoWmNHYUZiVGRDYWhmcGF3ZEZoMGhWZFdnQ2VuaE5oSGZPZUdhdGZ1Z1NlbWFSZzViU2d4YlJoeGZIZVJlMWdOYkdoVmdaZDBhYmNuZVpoemZiYjBiWmZuZEZhaGRKZk1jSWRRaEpjWmFBY1VocGNHZ05nUmVjZ05nUGVUZHRjb2VLZGxnd2h6Y0hmQmdCZ2ZmQ2VBZGdhd2VIZVJmMGZDYmFmWGc4Z1lhWWFrZGhnNGJlYjBicGdPZGRiUmRGaHpkVGFGZEZoNGJjaEZoWmgwZERlMmZ0YlNoRmdIZUZjR2dFZjNkaGNUYlJlemRBY2liR2drZ29mZGNQaFVmNGVVYUdlVWJBYmpkU2RTYmNlSmhMYXhiZ2ZIZE5jZ2g5Z1JoRWdFZ2tlVmNBaFJnbGVkZ2RnSGV0Zy9hY2UzYk5oYWNaYXdiNGViaFRkQ2FsYWdjRWhGYkpmRWJDYjNoQmFhYlFibWU5Z2lnWmdtY2toVWdjYWtiNWV6Z0VlRWZ4Zk5jVWNVZmtiVmNUZ2poMGY4YVVlU2NOZlBlT2ZSZVFlSGZBZFNkZGZJZGZkUWQ4Z1pkT2ZTZ0llMWdPZTBmc2J1Yk1kMGJCYzViQ2JoY05lemFVYzFndGh0ZlpobmhrY1pkRWYzZ0FnTGFXZFZhWWdTZmVla2NkYmtiUWhXZTVnS2JaZ0hmbGNMZEZmSGVFY2RoSGNVZFZjTmVIYmpmMGM5aGVmRGQ0ZnFmQ2Z5YmhnRWVTZjBjSWUyZkFkbGNFZUFhSmMwYlFkMGNIYnloTWI3aGFmaWFwYXBlSGYzY0pkWmNlZ2hjQmhRaFVoVmdGZVJiSGhFZjRmMWRYZGhiaGh3Z1FmWGZSYVJjU2ZrZzVhMWFFZlhoTmVNZFVjWGRoYndiVmduYlFjUGJhYzFlSWhVY2NmVWhaZUhhTWdCZ29mY2hhYWllY2ZXZ1ZoRmh3aGllVWJsZ2NhVmJXYWphc2FWYUJhd2M0ZnFnRGR3YVVodGZRZzFmaGR4ZUZoaGQxYWJhRWJIZXhlMGViZm5oWmh6Y2JhMGdaZW5oRmdoZEpkTWJkY1Vjb2JRZVVia2hRY0xkY2ZGZ3BnTGFaaG1nNWZNZ2FkUmVSZXliVGFuZ01nUWdUZ0VjMWFSYVNnUmJWZU9nYWdYYlFlWWdjZkVmRmUwY0JoUWRJZkhlSmhoZDhhbGhYYzFoOGU1YU5oQmhKZThhVGZHZFViZmRRYVRnMGhTY1dhaWhnZWZlRmFtY3dhcmJXZWhmQWVkYklla2JRZU5jR2doYnBicGhWZG1mMWNQYUlieGU4YW9kTGdRYkpiRWZQYlViUWFWaEhmaGZCZmFiWGVtZTVoMmhjaDJmOWdHYlpleGVZZVNnVGRIaFZmS2hFZEZiSmRFZ0NmM2dCaGFiUWFtZ2NndWJaY21mSWNKZmNmbGZaYjZmSGZHYVpjTmVVY1Vla2VWZVRobWFsZjBhR2JIY0JjQmRkaEZhRmZLZVRlbmNVaFJmY2gwYnhlWmZPYTNlQmZMZmRiRWdGZGpiZWNCZ1JleGhSY2hiTmY0Y1VlMGg5ZmthYWVsYk1kWmdFZDNkQWdMZldnVmVZZ1NjZWNrYmRia2NTZFRlb2NDZUxkU2RwYUZkV2FUZ1JjUWRVYWhlOWFBZFdnRGdjZW1hTmh5ZkVnTWVDY1NoTmNUaGNieGVoYTlkQmFoYUJjWmJSaEJkcGE1Y1dobGg1Y3pmWWJuZTVoZ2NGZUNjNWVrZGNneGZCZE1hVGJWZkZlSmFGZVVnNWhwZWRoQmZoZ3dmUWRYYlJmUmFTZmtiNWIxZUVhWGVOZU1jVWhTZXdoNGRIZnlmY2JCZUplaGhkYVphUGNoZVJkS2dkZ2hnQWdIZUpiVGVnY3dlVmdsaGNkMWVhaGdhMWZlY1hobmVOYkxnVGZrZ0ZjdWdTZm1iUmc1Y1NkeGdSZ3hhSGNSYTFoTmFHZlZiWmUwZWJlbmRaZXpiYmEwYVphbmJIYmtnWWJFY1BlQmhrY2VoSGR3ZEZiR2dQZXdoZ2ViYllnU2NFZXVnS2dFaFlnUmZBYlRnZGRWZkxhUmJsYVpkQmdSZlZiRmVhaFdiY2RSY2NiRmUxY29oVWFWYkpjSGFkZVViMWNaZlRhRmRGaDRhY2VGY1pmMGVEYzJodGVTZEZoSGdGZEdoRWEzaGhiVGJUaDJkUmJxY1VoeGhrYVRoY2FGZjhjUmZIZzBlRmUwZENnaWdFY01lSWJSZWdjOWJkZ3dnaGhjYk1kRWE5ZStoQWdsZDBoVGZGY1RlcGgrZFBkMmc5Yk5iWmF3ZlFiYmRRY0ZjOWRLZEVkRmRKZ0VlQ2czY0JjYWhRZ21lOWNpZlpjbWhrZFViY2hrYTVhemNFYkVmeGNOZlVnVWJGZUJoQmNpYkFobmFGZGpmMGNFYk9hUmM0aFllRmQzYnRjU2FPZ3dhMGZEY0doemQ4ZFNmTWRXaDRnL2ZXYWxhaGZ4YlRnUmROZ3RoV2NrZTlmNGdkYWxnTWFCZkdobmNCYlhjY2IxaFllU2FlZWtjZGNrZFFnV2Y1aEtiWmVIYmxjTGFGZEhiRWVkZkhnVWUwZVpnVmhuZVJkdWhkZ25kTWc3ZURhaWM1YUZiSGhBaEVld2ZCaDFlOGFBY0hlUWNVY3pjRWJnZE1nOWZBZVNoa2J0ZFVlUmdNZmFjZWcxZHhjTWRSZmxkRmVkY0hlRWRKZkRhZGVCZWhld2RRaFhlUmhSZlNja2Q1ZzFhRWZYZE5iTWFVY1hkaGR3aFZibmVRZVBnYWUxYklmY2ZKYVFoNWJhZktiMWQwYUNlSWZTZWNnY2NTYjBicGIrZ1NjQmdFaFhjUWVCY2toSWRJYUFlUWdQaEhibWN3YzFlU2N4aDloeGJDZmhnUmdOZUJjVWdwZjBhZGVuZzlkemNNaDJoeGhuZUZoaGNKY01iZGZVYm9lUWhVYWtiUWhMZmNiRmJwZ0NkYmIyYUpjbWJhZlJlUmV5aFRnbmVNY1FhR2FBYVVoWWVHaGhkc2dEZ0xlRGFsYlhkSWRoY2hlNmZFYmdmSWRQYUpoM2ZJZDhoQ2hCaFFjWmRKY0ZiNGI0Y0RiMmdCZFNoQWRuYmhic2NFaDNmaGVUaFRnMmNSYnFnVWZ4ZGtiVGhjZkFjdGRaY1ZkaGRKZTZoUmYyYlJkQmNaZTBlTmRvZ1VkMGFzYlVlY2ZSYjBlZGdUY1JnbGVXZ2RmR2c1ZTJlY2cyZzlmR2ZaZHhoWWdTYVRlQ2FFZkNhV2dRY0ZjS2dYZFdhUmdVY0FheWNzZG1oYmhpaG9mYWFQYnhmc2IvYlJoQWZVaGRnSGFSYkFoZGJEYzJoQmU5ZUZkaWhJZ09oSWhCZDFmQ2RYY1djUWRZaGZnUWVFZEVmTmFDZlFnZmFKZEVhTWJ5Y1dka2RkYzRjWGdUZWxlNGVVZTBhOWJrY2FhbGZNY1pnRWYzZ0FnTGFXZVZnWWZTYmVmaGdwY2toQmhDZ0lnWmdJZVhia2VRZ1BjbmdFYmRiSGRVZDBhWmZWaG5iUmZ1Z2RmbmFOZnZjUmFtYWNnV2ZFZWtmd2NqZENmMGhKYVNkQmN4YUJkYWVXZmtjSmZ2ZVlmbWNaZ3BnRmRIZEplT2FjYXhlQmJNYlRoVmJGZUphRmRVZllkcWVkZkFiVmd3Y0RjM2d4ZjdlU2RrZjVjMWNFYVhkTmFNaFVjWGRoY3dkVmVuZ1FoUGNhaDFoSWdVZWNiVWFZYVRiY2VBYWNhSGVMY1RnbGhkZVZhRmdZYTliUmdBY3NnUGhhZVRhWmVIYWJnMGdGZC9nTmcyZFJibGRWYnhkUmhwYkZiQmEwZVJiR2NRZklnOGdKYnloVmQ5YklhZ2NNZ3FkV2hVaEFoVmFEY2dhWmJ0ZVhhbWc0Y0xoY2hGZHBiQ2diZDJkSmRtZmFhUmRSZHljVGVuZ01iUWVUZEVmMWFSZFNmUmhWZkdhUGVUZHhoUmVJZDBnOGQ1YUZkQWZjZ0JiSmgwZ2dmSWJBaEZoRmV6ZGNlRWFVY0pmRGEzZmRiT2ZGaEdmbGRQZ0VheWhSZFRjR2V5YXdkamZBZ0JhZGFlZk5kVWVZZFdkQmhFZ3NmQmdDZTJoUmRLZWJkbGdnZVpkZGVXY0VhVWFjZlJjMGRkY1RiUmdsYldiZGNHYTVhMmNjZTJkOWNHZlpleGNZZlNkVGhIZFZoQ2RSYkJob2dOYVdnSGY0ZVhhQmh5aElmdGdOaERhQmh2ZlBka2Q1ZDRjRWdGYmtld2VVaFZlVWNKZ1RlbmRGZDliR2ZDaHhhQmZJYUJha2NEZUhjWGJ0Z2NjTmVnY0VkZWFLaGlja2V0Yk9mQWI5Z2dhVWhnZ0FnTWZTZWpmbGU0ZVVlMGY5ZmtlYWdsaE1jWmFFYjNjQWdMZldmVmFZYlNoZWJrZmRha2VRZFdnNWhDY01jRGRFZkNkUmczZzllUWZXZUFjQmVXZUJnQ2EwY1ZiT2ZuZ05ka2NSaG5oQmVyY0VjbGZCYnBoU2JnYmhmYmFSY0ZlZGd3Y0RhZ2NvZW1jTWNXZWdla2JVaFRhOGVCY0lhVWNrZTNiQWZWaEZjQ2NGaFZkZ2JVaFhkaGJoaHdjUWdYY1JoUmJTYWtlNWMxaEVlWGhOZk1mVWZYZ2hid2FWZG5lUWhHYVllbGc0YitmY2NVaFljVGhlY0ZoTmJQZFphR2RwaFRoR2VSYk5kd2dDYzFobGJXZkVhbmZwYUhkTWVBZWthbmJHaFdib2F2YVdiaGZvZndoV2dWYWxiRmZXaGxmZ2U1Zk9nemVvYW5oSmRoaFlmcmJUZnhob2dOYWZoRWFNYWVkQWNBY3RkZmhQY0ZkSmZSYmZlbWJ0YW9nSmFFYUVnK2dHY2plcGhBZEFjQmhSZlpmR2JoZXhlQ2VRYjNkUWhZZWNkRWRGYTBjVWdVZHBhT2ZkaFJkRmF6ZVRmRmdGZTRnY2ZGZlpoMGZEZTJkTWZlZ0ZjSGhwYWJiRWgyYUJmYWRRZTBkNWdxaFVneGVrYlRkY2ZBYnRnWmNWYmhkSmI2YlJlMmZSZkJkYmVrYnBoa2hlZVVoc2ZjZU1jaGgwZEFnVGJWY2RmZWhYZG1iNWMyYmNjMmU5YUdjWmh4Y1loU2NUY0hiVmJLYkVnRmFKaEVlQ2UzZEJnYWNRYm1iOWRpZ2JiamYxZmNmT2J4aDFkOWJYZFFna2NBYUhnaGV0ZE1lTmVTY1ZlMGdFZzNkQmVRY0NkVmdGYldlVWZuZFVhSmFlZmtod2hOY2ViQ2NRZGVhUGhWZXhobGJIYjFlRWc4YkNkVWNFZWhnS2JBZ01nWmRaY25oa2JaY0VoM2NBZ0xhV2JWaFlmU2NlZGthZGNrYVFkV2I1YktoWmZIZ2xlTGRGZ0hmRWFkZEhhVWZWY05nSGhqZzBoOWhlZkRlNGdxZENoeWVoZkVjU2F6YmNjNWhTaGhndGVTY1ZkM2ZaaHdnUmVsYjVidmdlZG1nOWdwZ1NmSGRJZmFoT2gxYmtnZmhRZ3hod2JNZVdhQWdFZTdkTGRXY01oOGFRaFhjOWNSZFdkRGNOZzViT2gzZ05mTWRVZVhkaGV3aFZjbmJRZ1BnYWExaEliVWFjZlVlWWZUZGVjRmROZ1BlWmZHYXBjVGdFZ1VlY2I0ZFFnZ2dwY1lkWGF6ZjhkS2NLYnhiTWYzZk1mU2JoYjVjUWNCZ1Jha2dZZkJnMWNSYUJiVmZaaHNjWmUzZ1lkdmdiY3hkSWd2ZlhiMGJGY0NkT2hBZTlkZGRIaFJnWmVTZkNjeGFaaENiWmFHZ0pneWRGZUJmaGNZZVRkbmdNZFFnVGZFZzFmUmVTY1JoVmdPYmFlWGJRZVliY2FFZkZjMGdVYVVlcGFPYWRmUmhGZTdnR2FCZWtieGZJYzFoZ2Y1ZFNhaWVZYmRlUmhpZmdoOWFYYzNhaGdZZFRkM2RNZVhkVWN3YlVkUGFjZ0JkTmNRZlZoa2E1ZDZjRWZ5aHdmSWJQaFVjUWhwaFBkQWhaZGJoSWgwaFJibWFBZFJkbGNkYmRiSGdnY0xkV2VXZjlhR2haZHhlWWhTZlRjSGRWY0tkRWZGY0phRWRDYTNhQmNhZlFmbWE5ZWllWmVtZUFjZGFmYm1hUmZ6YkVmRWF4Z05kVWFVZ2tkVmdUaG1obGIwYkdoSGZCZ0JkZGJGZUZmS2dUZ25lVmdGZE9hd2VVZENoZGRpZ1pjRWZlaGtoNGh2ZUZjaGN3ZHliU2hGZzRjdGJIZHhlc2d0YU9maGY5Z0FoR2F6YkVkQ2NVZ0ZoaGJBZ05mUmZNZm9nU2FYYjFnYmFiaFhhY2JHZVFjVGUxY0phVmJCZzFoVmZEZDNkd2c5aGZkM2c5YkZoUmJtYWNiV2dFaGtjeGgxZ1NoaGRCZlNmUmJBYnRjd2VXaGtkSmV2YllhbWZaZnBkSGhEZDVjT2JlZUFmMWJNZFZnVmFoZEZiUGUwaDVncGVkZEJjaGd3YVFkWGVSaFJmU2RrZTVnMWFFaFhiTmhNY1ViWGNoZ3dhVmduaHhhTWFhYTBnOGhVZ1BmMGY0YzVlZWNGZk5mUGRaYUdicGhUYkdmUmZOZ3dkQ2IxZmxjV2NFZ25jcGdIYlpkRWFGY3VkU2dtaFJheGRIZjFld2Q0ZlRmaGRNYUFiWGFCYXNhN2NQaENhOGdJZEllMGJaYnNiRmhnZ01ieGhkY1ZlWWRNYVVhbGZ3YkNkY2JBYlphQ2VPZHlmb2N2ZE9laGFvZi9lQ2h6ZzVkZmZIYmhoUWZxYUJhV2JoZkNoUWczYVFoWWhjZEVoRmQwZVVoVWJwZk9nZGdSZUZmemFUYkZmRmE0Y2NmRmZaZTBhRGgyY3RjU2hIY0NlVWdPYVdjaWF0Z2RhQWVpZEVobmJIZkVhdGJLYkNnMGNkZlpmWGRSaEpmcGNPY21hUmhkY2Nma2ZwYzhnY2dFZ3RhSWZjZ1VkbGhWZUJiRWJwZlloT2VTZnNiN2JQYURnMGdmZkhlRmVvZlNmUmQzYlZlWWNiZ1ZmNWd1YkNmM2RCZ2FiUWdtYTlhaWdaZ21ka2NVZ2Noa2Q1ZXplRWRFZHhiTmhVaFVna2JWZ1RibWVsZjhjVGdEZGdkSWdKaDFlOGFIZENlemdoY2VoSWRSZlVhcWVOYkhmQmFkYmRmQmJvZFdjVWdnZWhkdGZSZ2dhdGZ4ZlVheGhOYWtnUGhoYnRoUWNRYkhhNWhHYUhmQmh0aGRlS2dCZDRoZmZEZVdnNWhCZFplR2IwYjJhR2JGY3NmZGJIYlVjMGhaZ1ZibmZSZ3VoZGZuZU5hdmNSYm1nY2VXY0Vka2Z4YjFmU2RoZEJlU2ZSY0FoTWdrZkViZ2hzYThmYmdDZXNjc2ZXZ1RjMGNjY0tjbWdzaEFoVGdWYnBoSmdBZGpjTmRwY2FiQWNSY3dhV2dYZDFiUmVGYWtjNGNoY1dhVGhvYWZhWGh6aFVkMWhHZ3pjdGNkZk1kaWJsaFljY2FVYzBoVGdiZGlmNWhsYlpoR2FwZVRiR2VSZE5jd2JDZzFlbGdXZ0VibmhwZEhjWmZFY0ZjdWdTZW1oUmg1ZVFlaGgxZDlhTmh4ZjFjTmVHY1ZmWmUwZmJibmJaYnpkYmYwY1plbmFGaGhhSmVNZ2RjVWNvY1FnVWFoYkJoRGNPaFFobGZNZk9nWGVGYm9mS2JGZEFlMmVSYmpnQWNlYkFhUmFnaGRoSGJWZHdoZWFKZlNjMGhRZ01nVWhoZjlkWGN4YWdlQmRJZ1ZnMWc3YlhoMGRCaHhjZmRoY3NnaGRRY3pnOGdiZlJmRGIwZ2ZiR2V5YnRjYWhRYzBnNWZxZVVkeGFrYVRnY2JBYnRnWmVWZmhhSmE2YlJkMmhSZkJiYmRrYnBla2JlZ1Vnc2NjYVBmUmUwZ1doVWdCZWxjT2JmZ1dhSmVjZWNiMmU5YUdhWmN4ZVlkU2RUZUhlVmJLZEVlRmVKYkVkQ2UzZkJjYWhRZW1hOWRpZ2JmaWJvaFVkYmgwZTRkOWRHZUdhWmNOZ1VhVWVrYlZmVGVtZGxlMGFHY0hlQmdCZ2RmRmZGZEtiVGFuZlVlUmFjZTBheGRSZWVkSGdnZUNoUGRFZVlhNGVYYUZia2YwZkNhMWR3aHFoQ2VqZlFkb2dhZGxmZ2VaZ0FjZ2EwYUxmUmdVZG9jU2ZZZ2tjNWNrZ0hhV2Y0YWVjTGZEZUFlWWdHZWpoeGNZaFVhQWhKYkxlRGJ3YjhjaWhDZDNkOWZGY1JibWdjZldjRWNrY3hmMWZTYmhmQmZTY1JlQWd0ZXdnV2NraEphdmJZY21jWmFwZEZmSGJKYUdlSmgxZmdoRmhIZmxlOGFFZFViQWVNY21jSmdrZUViTGNEYVhhUmhhZlNlbGgwZkloRWNXZTlhUWhVZldkQmE1ZlZnaWZnZVBkUGV4aHBhZGJJaGtoaGhlZlBhUmc0YkFmTmFqZ01lb2hWaFJiTmY3YUNjMGRzZ3JlSGdsYUJoSGZaYkViRmF1ZlNobWNSYzVmU2R4ZlJheGRIY1JlMWZOZ0dkVmZaYTBkYmhuZ1pjemViYzBhNGd6YlhnbGNzYWZhZWF3YmRoVmdIYXdmdGhaaEtlU2VFY09jYmUyY2xibWJmaEdobGd5Y1VnbWc4ZFFnVmZFaFJoUmFGY1JjVWVhYUlhVGUxY0xmZmVnZXdmeGFIZUFmVWRjY0xoR2JvYy9jVGJGaHBhNGZaaENhdGU0YUpjV2h0Y1NkRmZIZUZjR2dFYzNkaGFUY1RkMmRSZnFnVWF4YmtnVGdjZ0FjdGJaZFZmaGhKZzZjVGR6Z0FlSmZKZXhnbGdxZU5hQWI1Y1pkUGNrZjllRWhOZmxnVmhXY2ZhMmE1ZmhnRGFtZzlkYWhlaHhlWWdLZ1JoWGRVZVdiRWNBZ1lkTWNRaGloTmZVZERjeWFvZHZoS2hUYnRiTmhDZFFmSmN6aEdlMGV4ZmJhTGFHZ01hVmRUY21jbGUwZUdiSGdCZUJmZGZGYkZkS2dUZm5iVWhSYmNiMGF4Y1JhZWRIZ0JlZmZmZ1FhTmFCZlVhaGNSZHhjUmhoYk5iNGNVZjBmOWJrY2FnbGRNZ1pnRWEzZUFlTGVXZFZiWWVTY0xkZ2c4YnRjRWJtYUFhY2RjZ0hlY2RLaFVhRGJVZFZkWGVrY05jVWFBY3pjZ2I2ZFBneWVNY2pmSGgyZDloWGdHZzBmVmY3ZEdlRmM4ZUdhQ2hBZE5iamRTYzBidGJoZ0xiemZNZ2xmUWZEYnNnZWFQZzBnbGhFZEhkbGRoY1NjUGUwZTVjcGdkZkJmaGZ3ZVFlWGJSYlJiU2hrZDVlMWRFY1hoTmdNZ0RnRmNKYXdnVmJuZ1FoUGRhZzFkSWRVZWNiVWhZZlRlZWdGY05iUGJaZEdiSWRiZEdmUmFoZnRjQ2cwYnBlRWZFYW5oZGNIaE1jQWZrZ25oR2JXZ29mMGFEaGxna2ZpYlZnRWdjZklhRWRGZnBmZWNiZW5oWmR6ZGJmMGFaY25nRmNoZUphTWJkY1Vob2ZRZ1Vha2RRZExiY2VGYUlhV2VKYnllc2YxZFpiMWdraDNlQWJ5Y0JnWmFGZmdlaGJSY1ZiQmZWYWViWWZIZmdoeWVjYUVhRmIwYlVjVWRwZ09jZGJSYkZkemFUYkZjRmE0ZmNoRmhaYjBhRGR5aFJhU2RFZG5jZGhHY0dmeWJ3Z2JkQmdqZ2Rha2RIYWxjeGVlZlBiMWVrZEFoVmFnZzljNmRSZldiWmRJYmRkV2dCZGthZWhVYnNkVWJjaFJjMGRkZVRnUmZsZVdlZGJHZjRhcmRXYldlOWNHZlpkeGRZZVNoVGFIZVZlS2hFZ0ZlSmZFaENmemFraGNmUWVtZmNka2NaaG1hUWVVaFlkVmJ4YnpnRGVsYkZjTmNHZFViQWNWZEZiVWhOZjBnR2VIZ0JkQmhkZ0ZkRmdLZVRhbmRVY1JnY2MwYXhlUmhlZENhWWVYaEplZ2c4ZzdhVWdnZGxkeGdBZEJlTmExYVVmMWV4YjJiY2FYZWtoWmdFYzNiQWNMZldiVmNZY1NkZWVrYWRoa2dRaFdnNWVLY1phRGYwZUVlRmRDYW9lM2FIZVVmMGZaYlZlbmhSZnVkZGJuZE5odmhSZG1iY2VXZUVna2Z4ZjFoU2hsZWtmVWhSZEFhTWYvaFVnMGJJZDBmU2NHZlpkcGVGZUhhSmNPaGNkeGJCYk1hVGNWY0ZhSmdGZFVhNWhwZmRoQmZoYXdmUWZTZEljUWJHaEVjNGgyZ0NkbGJsY01oVWVYY2hmd2hWaG5hUWVQZmFiMWZJZ1VnY2VVZFlmVGZlZEZlTmNQZ1pnR2dwZGJkV2hoYU5ldGdDZHhoZGVlaE9kSGJwZkhoWmNFYUZjdWhTY21lUmc1YVNheGJSYXhoSGVSYzFjTmZHYlZiWmcwYmJhbmNaYXpoWmN4Z0pmcGdWZlZhb2ZOYkpleWVsZmZmRmdnY0ZncWRKYUZhSWRLZWJjMmdsZm1mZWhCZDFleWJVZ21jOGNRYlZhRWRSZlJnRmFSZVViYWNaZ3pjZGhRZ01oUmFNZ1hiSGVnYjRkTGJGYkVnVmM3ZEJiRmJoZDBoV2JsYlphMGNEZTJjdGNTYUZlSGhGaEdiRWczaGhnVGJUZDJhUmRxaFVleGdrZ1RjY2JBZ3RiWmJYZmtjWmcwZkJkQ2J3YUFkUGdDZWtncmdQZVFjNWExY0phUmFWYVZmVGJSYUphV2ZaZzJlZGEyZWJiM2FOZUdjZmN4ZThkU2dFYkhlVWFlYUhmaGhFZE1iU2dpaEllNWhEZVNjc2NuZEJnemcwZWNlT2JrYTVoNGdFaEZjNWVFZFhoV2hNZlZoVGVtYWxnMGJHYUhoQmNCZWRiRmdGZktiVGhuZ1VkUmJjaDBoeGNSZ2VjSGVCYVdkZGVBaGNhL2ZYaEZnY2c1Z0JiMGJFaGJoSGVBZXNhaGdDYndnY2ZSYVdkM2ZBYUFmV2ZVZk1lYmJlY2xhdGU0ZlFmWGNaYkRnWmNDY1ZiTGVRZEhhOWJlYlZmUWR4Y0xlTmdUYXNkcWNNZHhmSWc3YlRkaWU4Y1dkR2VVZXhmaGRRZXhleGE0Y1JhQWZ0ZXdkV2RrYUpldmJZZm1nWmNwZ0ZkSGZKZU9mY2F4ZkJlTWhUZFZhRmhKYUZlVWQ1ZWhnSWdCYVloemJDY1RnVWhEZUtkUWJFYXhmVmVCZUliWWFXaFRoQmZ3ZVhhWGVRY1lmWWZsZ0lkSWFiaFVnWWhMY2NhVmFNaFRhWmVEZDVoZGVXY2xic2V4YVdoVGNvZFpkVmRqZDhibWVNZkVka2dtZlNhbWY5ZzVmWGJSZDFkYmJIZ1JoMWNOY0dhVmdaYjBhYmVuZlpjemFiZTBoWmhuZEZhaGhKY01hZGdVYW9nUWJXZjBhMGZIY1dhbGFwaENiYmEyZ0phbWdhZlJjUmJ5aFRlbmFNZlFiVGZFYjFhUmJTY1JkVmVPZWFmWGRRZVlhSmVBYmtnOWRBZ2tmUWdZZlpnQmE4YXlhQ2hCY1Zmd2VNZjFnZ2E1aFdiaWRjZEdoWGJTYkVoS2RTYm5oQWFTZlJobWMxYmtiQWRWYVpkSGdQZ0FkTmFLZ1JleGZ0YTBnQ2FqYkVjTmFPZ2diTWMwZ05nUmZJZ2NnSWVoZVFoUmRaY3hnbGJXZWRjR2Q1ZTJkY2IyZDllR2FaZnhoWWRTYlRoSGdWZEtmRWZGY0pjRWZDZzNoQmhhZVNmaWNkZ2ljYmdYZlFoVWhhYmtkZGcvZ09ja2N4Y05hVWhVZmtoVmdUY21ibGIwZUdkSGRCYUJiZGdGYUZlS2VUZm5nVWFSZWNoMGh4ZlJjY2FEY05iV2hhaFFjOGFsY1dhamI1ZnhnUmdoYU5mNGZVZzBnOWFrZGFnbGNNY1pkRWgzZEFmTGFXZlZnWWZTZGVoa2ZkaGtoUWJXZDVjS2ViY0NmMWZGZFZoemdsZWNmVGN5YzVlV2JFY2pkRWdQYklmbmNzZG5mUmhtYndjV2VBZjBlVmYxYVZhZ2R4YVNoWGNBZUpmd2NCZGtkSWg3ZWJlQ2VVYmhnVmFTYUFhdGNQYUZoUWNKZUxhQWFWaEJkWGhVaGRibGRYZ2hmaGd3YlFmWGFSY1JoU2hrYjVjMWJFZlhlTmhNZFVoWGVoYXdkVmNuaFFkUGFhYzFlSWNVY2NkVWdZZmJlTGhGYjBmTWhMZUNjc2NCYWVlbGh3aDBmVGZqaGdmQ2VHZWpjSmhIZ2JhMGhGZDlnUWMyZlJhbGRWZ3hlUmNwYUZjQmcwZFJkR2ZRYkpjNmdMZ1RiNGR5ZVBhU2FVZm9mVWRsY2NmdGRJZVVhSmNZYlVma2M4ZUxkWWhsZk5mT2hSZVdmSmdtY2FiUmhSZHlhVGFuZU1iUWhUaEVhMWZSYVNhUmRWZE9mYWVYZlFiWWdjZEViRmcwZFVhVWVwY0dnSWJSaDhmd2ZCYUJiQWdxZEVleGNrY3dmU2FnY29iR2ZIZkRmbGJHZEdiSGRoY0diUmRtYlJmMmhUZ3hha2NMY2VmUWdzaEZmVmRrZ1poMGRCYUNod2RBYVBlQ2drYnJjUGdRaDVoMWJKZVJlVmJWZlRoUmFKZFdjWWRHZ2RoNmdXZldoOWZHYlpheGNZZlNlVGZIZFZlS2NFY0ZiSmRFZ0NjM2ZCZ2FmUWFtYzloaWFaZm1na2VVZWNia2g1YzdhUmFFZkljT2VHaFFjaGdIY0xjU2JZY3dhWGhSY0VoVmJmY0JmbGdLZVJoWGhVZEdmZWJrZXhoTmJaZkhlQmdPY2ZoUWg4ZTNhVWNrZkJiL2RCZVZjc2E1Y0FhU2d3YXJmTGVoY1piNGdSaDNiaGJEYldmVmMwY1NhYmdFZDVjT2RRY1dnNWRLZ1piSGRsZkxnRmRIZ0VoZGFIZ1VnMGRaZlZibmNSZXVkZGduZ05idmZSZG1hY2ZmZUdjMGhCYmZiU2hoYUJoU2VSYUFkdGh3Y1dka2FKYnZnWWhtZVplcGdGZUhhSmFPZmNheGFCY01lVGFWZkVjZGJYZFFiY2g2YmVha2I1YmlmVGh6aFVnVmZEaGtlWWMyYUhhemQ0YlpnSGJTZHdnNWFCYmpnaGVXZ1lneGhNZWRlZWJFYmhoQmhOZHdnY2VEZmJiSGdsZkNoRWRCZDBjOWRYYmhmVWVDZldieWJvZkxlUGNVZWtlOWdRZjJiaGdUaFNheGFSZHhiSGhSYzFmTmNHaFZhWmEwYmJibmFaYnplYmUwZlplbmJGYmhlSmJNZWRkVWZvZVllR2FrZ1FjQWFiZFZlcGVhYVpibWc1ZE1hYWFSYVJleWJUYW5lTWZRY1RkRWcxZlJlU2ZSY1ZmT2dhZFhnUWJZYWNjRWNGaDBhVWVVYXBmR2ROZGhmRmd1ZlRiQmM5ZXdlV2VsZVplMGREZjJjdGZTaEZjSGJGaEdkRWEzZmhlVGNUZzJhUmZxZFVjeGRrZVRiY2JBZHRnWmdWZ2hkSmV5YkVoMmVvYUNlSmVnZnNoMmVHY2diUmVRZk5jSGF4ZkplUmFWYkZiV2NmZTJhNWJuZGVlbWQ5YmFoZWR4aFloS2dSaFhoVWRXZEVkQWNaZUtlU2NEY2diYmdFZkFnd2h0aEloaWF4YzFiSmRrZlliN2JHZ1VkQmVuZVVoVWNraFZjVGVtZGxoMGdHZUhlQmFCZWRkRmNGZUthVGVuYVViUmRjZzBkeGRSZWVnSGhCYVdnZGdBZGNiL2dYZUZmY2E1ZkJhMGNFaGJhSGFBZXNoaGJDYXdjY2JSZldmM2hBY0FkV2dVZFVlYmRlZWxodGg0Y1FmWGVaZURkWmJDY1ZlTGVRZ0hjOWhlYlZmUWV4YUxhTmZUYXNlcWFNYXhlSWY3ZVRiaWM4YldjR2dVZnhobmRRYnhheGU0aFJkQWF0YndmV2NrZkpkdmhZZm1nWmVwZkZoSGFKYU9lY2F4ZUJkTWVUYlZiRmZKYkZiVWE1YnBiZGhCYUFka2ZUY3poY2FaaENleGd3Z1diWGNqZ2NhSmRNaENheGI0ZkhlbmFRZUVlYWcwZmNoZGNjY1Zib2hQY2VkRWh0YUdhWmREYlpiVGRUZVJoMGR6ZlFkeGFnZkVjY2RUZFVkRGdJYlNhQWM2ZVFiaWd4ZDVhUWZCYlJibGVGaEJiRmRuYUdmVmhaZjBnYmVuZFpiemFiZzBoWmFuZ0ZjaGFKaE1jZGJVY29nUWJVZWthUWRMZmNlRmhwY0NiYmYyY29meWFaZDFkY2g2ZURmeWhGY3pnQWF3Z2toVWFLaEVoRmNHaElkWGNRY1RmY2NGYlplOWFVZVZiWmNTZmRnUWRsYjZnVGVBYTFmNGVKaEZkZ2UzZlJieWJvZUFmZGV6YjRhQ2JWYmhma2RIZ1JneWN4aHFkV2NCZmtoRmFlY1NiRmRaYVZlaGhKYzZjUmQyY1JiQmJiZWtmcGFrZmVlVWZzaFVnY2JSaDBoZGhUY1JmbGJXaGRlR2VkZy9jZmUwYVZiR2haZnhmWWhTY1RmSGdWaEtiRWRGYUpkRWNDZjNjQmdhYlFhbWQ5YWlkWmRtZGtjVWJjY2hib2I3YVdnUmE5ZkRmQmMxYm9kYmZEZHloMGF3Y0VmRGFOY1BiT2dRYlFlR2dHZmpjeGNCYlBoeGFWZ1pmT2VYZmxlZmFlZ2xoMGZrZEJjbGdoYTVnVmNRZEpoeGNYZFFhSWd4ZUphZ2dkZFFiUWN6ZXhmU2FVY1FjVWhiZmRkbWUxY2tlUWZXZjVjS2JaZEhlbGhMZUZlSGFFZWRhSGhVZDBoWmhWYW5oUmR1ZWRibmJOYnZkUmNtZDlhZWdFYmtlZGRvZ1NhZ2VoZWJnU2ZDZEZod2FXaGtkSmZ2ZFlmbWRaY3BoRmRIZUpkT2ZjYXhnQmRNYlRnVmJGZ0pjRmZVaDVicGRkYkJjQWZ6ZlFmV2VsYVJnQmhFYVplZmZFaFhjTmNNZVVmWGRoYXdmVmZuZVFmUGdhZDFnSWdVZWNhVWZZZVRnZWdGZ05kUGNaZUdlcGFUYUdhUmZzaGtiQmRSZm9nZWFVY3loZ2ZrYktkd2NVZ3JmS2F6ZkJheGdBZ3hnUmU2Y0hiUWN4ZEVnR2RVZHBjb2JiYW1iNWM2ZGJmeGRwZm5lUWVoZXdhUGVQZFFjdGJDY01lUWh0YVBoTmNUY3NiV2NaZHlkcGR2ZlplVGM1aHllVGFuaE1hUWVUYkVjMWFSZVNjUmZWZU9lYWdYZ1FjWWVjY0VlRmcwaFVhVWNwZk9oZGdSaEZoemVSaEFlVmIyZk1jeGU0aDFmWGJRaGdjZGFVY0RlUWRuYVJmM2FBY2JnVGcyZzlhcWdRZEJmQWJUYWJmQmJkaFpkVGVoYXRmNmRHYjJhUWhWZlliQWhrZnNkT2RCYmxiM2ZQYmxkbGNZZExhRWIxZGVnUGFHZDVoOWVjZzNhMWRQZWFoemd3YVNkVGNIaFZnS2ZFZ0ZjSmJFZkNhM2ZCYmFkUWZtZTloaWRaZG1la2ZVYWNna2I1YnpmRWZFZXhmTmRXYlJoMGJiY0RmU2FFYzFoU2RoY01jT2hNYkJlUWRyYkdjbmgxYlphY2UwY2RnUmdiaFhjbGNXYWFiQmVOY3JmU2NoZjFmeGNHYWhkTWZzZlhlUWF3aHNlS2V3YkZkNmJYYURkUmZPZE9mQWhJZmFjTWZrZmRhdmRRYVhmcGdEYmFlRmVOYkxnRmFIZUVoZGhIYVVmMGVaY1ZibmJSZXVoZGRuYk5ndmZSZm1mY2NXZkVka2Z4ZDFnU2FoZ0JjU2FUZUZjOWIrYUdnUWNvaHVkTWNBYlVjbWZVaERjY2h2ZUpkeGVnYkVkVGhWaHBiSmZBZ2tkZGVwZ2FkQWJSYndiV2dYZjFjUmhGY2tnNGhoZ0hlemZBaEVnRWVDZG9kVGRHYlRkQmZLZUNhZ2FZZmNjT2hVYllkWWFlY0VoVmVHZ1RkbWRwY1RhR2dSZE5hd2JDZDFnbGZXYUVmbmZwZEhoWmdFZUZhdWZTaG1lUmI1YlNoeGdSY3hlRmNCZ1JkQmRNYTFmWmQwYmJmbmdaYnpnYmYwZlpkbmJGaGhhSmdNYWRjVWNvZ1FiVWJrY1FiTGZjZEZncGZDaE9jeWZvZXZnT2JoZ29ma2ZXZm5oMWFSZkNhQWJsZlpkQ2doZXNhRGdQZkRlaGRNZU9iUmJFYzRoQ2ZFYkloUGFmY0JnaGE5ZkhoaGQ0ZnNhUGhGZzVkbmRIZW1mSmRjZFdkU2VRZEtnUmZ6ZEVjRGFBZHpjMWRpZ0FjQmhBZElkV2FnZHRjWmRWZWhlSmI2ZVJiMmZSaEJiYmNrZ3Bma2ZlY1Vlc2dVY2NkUmYxYUFkVGhWYXdhYWdKZHlodGYyYUtnRWJWZkdiWmZ4Z1lmU2hUZ0hiVmZLaEVlRmdKZEVnQ2UzZEJiYWVRZm1oOWZpZFpmbWRsZUNoTWJ4Y3hiemZVYzFiZGhuY1VkVWJrZlZlVGVtaGxkMGNHZEhhQmZCaGRlRmJGZ0tlVGFuaFVlUmZjZDBkeGRSZWNiRGhOaFdhYWdRaDhobGRXYWpiNWd4Y1JmaGZOZzRjVWYwZjlna2hhZGxkTWhaZEVjM2RBaExoV2NWYllmU2dlZWtjZGdrZ1FnV2JZZmVhSGJ6Z0ZnTGFIYTNoRWdNZ1lkRWIwZ0ZjU2ZuZVJnMmdmZDNkTWV6Z1JjamROaHRjV2NqY0ZoNWNZYkJkQmZTZVJnQWh0aHdmV2hrY0pkdmdZaG1mWmZwZkZjSGRKZk9mY2d4ZEJmTWZUZlZhRmJKYUhkUmZvZ1NnUGJCaGhoN2FRZldlY2RzZ1NjbGRKZHBjRWRXYXRjRmFVY1NnUmF3YkFnZ2c5ZEhnYWgxYWtkVWZZYXpoc2hmZ1VkbGFOZFBlWmdHaHBoVGFHZ1JjTmN3Y0NlMWJsaFdhRWFuZHBjSGVaYUVmRmR1ZVNmbWNSaDViUWUwYkFjS2ZWZFJnMWdHYkdiVWNNZEpnYmVtY3BkdmdiZTFmNWV1YUZka2E1ZU1mSWVUYUZjWWVVY2tiOGNMZ1phQ2hkZk9lUmJXZEpibWJhZ1JoUmd5ZlRlbmhNYVFjVGZFZzFhUmRTZ1JlVmJPYmFjWGNRZFlkY2FFZkZiMGJXZlJlNGQxaFBhUmZGZDRhVGFFaFlnRmJjZUVmcGVvY0RkM2dOZWJhRmhDYTFjR2FSZndlTWZiZlRlMmU5YXFmUmRXZ1FnNWJjYUFmdGhaZ1ZiaGNKZzZiUmYyZ1JiQmhiYWtlcGdrZmViVWdzZVVkY2JSYjBjZGdSaEJoQmVhZVhlbWM1aDJkY2MyZjljR2VaZXhlWWFTYVRoSGNWZ0tmRWNGZ0poRWVDZjNhQmNhYlFhbWQ5YWlnTWdpYUZjZGhJZ1VhQWZsYkFhVWZJZU1lRmFRZTBhZGVEZVdhY2g1ZVRjVGV3ZVZmUGFRY0VlR2ZGZzNhMWVRY2Vja2RWZGZhS2ZqZzhlQ2ZPYkFhZGM0aFFjeGcxZC9kQ2QwYVlmMGFCZXdjWWgwYUpnZ2dvZlJiUWhIZGtlSGFjZzFlWWFTYmVma2FkYWtkUWhXZDVhS2VaYUhkbGNMYUZiSGdFZWRhSGRVYzBoWmJWZG5iUmh1YWZhamh0Z3ZmVGdYZG9jV2FDZmthVmQ1YVloQmFCZVNkUmVBZnRod2RXY2tjSmR2YllkbWhaZXBnRmRIZ0plT2VjZXhlQmRNYVRiVmFGaEpiSGVRZDFncGdhYlJkZ2crZVNhVmE1Y1JlU2hrZTVnMWFFaFhoTmNNYVVoWGFoaHdlVmZuYlFiUGZhZzFiSWFVZWNnVWFZZVRoZWhGYk5jUGFiY0RoNGNvaFVlUmZOYTdlQ2YwYWdjcmRFaG1kWmRiYVplRmdsY25iU2dqZ2hoNWRIYjJhOGg1YVlkQmJGZG5nR2VWY1pkMGNiaG5iWmF6Z2JmMGZaZW5lRmZoZUpiTWRkY1Vnb2RRZlVna2ZRYkxiY2FGaHBnQ2hiZjJlb2F5Y0VjbGZ4Z3lkUmFYZk1iRGhNaFVhMWdOYlZlUmJWaFdlWWRIYVJkRWVjZEJkVWZQZEdkVWJwZkZhZGJRZU1iT2NRZUhndGQ0YmNmRmZaZDBhRGcyaHRjU2FGZkhoRmJHZUVhM2JoZVRiVGUyZ1JicWdVYXhia2ZUZGNkQWR0ZFplWGVrYVlhQmdEYTJnUmNLYWJkbGI4Y1pmZWFWY2NmSWNjZlFnVWdVZlRhVWFWY1diSWZCZFVlK2ZjYjJoUmJHYmNlMmRzaGVoWmRuYVZkS2hFY0ZjSmFFYkNnM2hCaGFoUWZtZDljaWNaZm1ja2FVZmNna2I1aHpmRWVFZnhiTmFVaFVoa2ZkZkdiaGZJYzhjR2RIY3RlQmhZaHlkeGJLYlVlbWdrZFJnYWMwZVZmUmdKaEhkQWNDYURiMGNkZ3JkV2ZSaFJnbmRPZXphbGU0ZVVhMGg5aGtnYWRsYU1iWmdFZTNnQWZMZFdlVmVZZFNnZWZrYWRka2FRYVdlNWNLZFpkSGJCZUNiR2ZGYXNlZGhIZFVhMGVaYVZhbmRSY3VjZGZuY05jdmRSaG1mY2NXYkVoa2Z4ZjFnU2ZoZEJhU2FSYkZiOGM0YUVmeGRGZGhlTmRIZVJjbmdWY1RnWWFLZWVjMWFOYUNiQWJBaFFoRmhRY1FnY2Q1Y09mRWRGaDRlQWFIZjFjWWZSZkJkd2Y2Z1JlVGQ5YUVnUWFtYmxjNWdXYURjbGFhZ0pkd2RaaGRkSWZRZHBiS2NjY0FhQmdHYmFlRWZCZlRiR2NSZU5od2JDaDFlbGRXYUVmbmdwY0hkWmRFYUZidWNTYW1nUmI1ZFNjeGRSZXhnSGFSZVVlRmRHY1ZiMWVwYWJjbWM1YTZkWWQyZ3hhbmVGYmhoSmNNaGRjVWdvZVFkVWNrYVFnTGRjZkZkcGZDZ2JlMmRKaG1lYWFSYlJieWFUZ25ldGVUYlRlRmVCZVJhQmR4ZjFja2VhZFhmUWdZY2NkRWVGYjBjVWRVY3BhT2FkZ1JhRmV6ZVRnRmdGZTRlY2FGaFpiMGNEYzJjdGZTYUZlSGRrYVNmYWFEY0JkVGVSZkdhUmU3Z0xkaGJrY1BkYmJBYXRlQmRYYnhnSWFtZFJmemRBaDZiSmJqZWRnb2VVaDBic2NVYmNoUmgwZ2RnVGJSaGxkV2ZkZEdkNWUyZ2NkMmg5Z0dnWmh4Y1liU2hUY0hoVmdLZ0VmRmVKYU1oWGN3ZHNkU2NRZm1mUmdpYWRlUmFRZlVnYmZsY0pkemhDYUVkVmNOZkRoVWRsZUJmTmNTaEZhMGNFZzNlQmRUY0NmVmQxYWdhVGhuaFVkUmdjYzBleGJSZWVnSGRCYVdoZGZBaDllcmFVZmhmUmV4Z1JmaGZOaDRjVWQwYzlna2JhZGxidGVOY2FkRGZnaExoVWFsY1ljSGZCYTBjZGQ0ZlhjV2U1Y1NoYmVYY2tlWGJGYkNnVmRtZ1ZjVWQwZlNoVmNtZ0FkVGNlYmxobGZ2YVJkbWNjYVdmRWJrZXhkMWhTZWhlQmhTZlJoQWJ0Z3dlV2NraEpidmdZYW1nWmRwYkZlSGVKYU9oZWMwZ1FoM2VCZVZhRmZDY0ZnVmRrYlVkZGVBYVJkc2hRaFdkeGFZaFNiaGFKZDFjUmZRY2dmRWdVZlhjTmZ3YVFhQWhrZGxoYWIxY0lmVWJjZ1ViWWhUYmVjRmdOYVBhWmNHZHBoVGJHZVJmTmV3ZUNjMWdsZldlRWZuY3BlT2FiZ1VoMWJFZ1NmbWNSYTViU2F4YVJkeGdIaFJjMWdOZEdjVmNaZjBlYmFuZ1plemFiYjBnWmhuYUZiaGhJZFlhUGVRZU5oRGdYZUJoSWdZYmZlaGJzZEdhS2IyZG9jbGJaZzFla2ZuaEFoaWNkYVpoSGZBaEVhSWdRZlZiUmRIZ1lnSGJwZktoUGh4Y1VhNGdXZVZobGZmZGZnQmc4ZitiR2NSYzBkc2VPY1FjWWE0Y1ZnbWRNYUJhSGNYYTFmc2VFZzNnaGdUYlRnMmhSZ3FhVWV4ZWtnVGNjZEFndGFaaFZkaGRKaDZlUmIyaFJjQmRiYmthcGRzZ01hVWVzZ2ZlYmhCZDBjRmRSZUJmVmM4aGRoR2M1ZzJmY2IyZjllR2RaZ3hhWWJTY1RlSGNWYUtoRWNGYkphRWZDZjNiQmNhaFFjbWQ5ZHFmSmFXaGthSmFjaGdoQmQ3aE9oa2F4Zk5hVWJVZWtnVmRUZG1hbGcwZUdoSGdCY0JoZGVGYkZiS2ZUZ25mVWZSYmNlMGJ4ZVJkZWhIY0JmZWhJZEhhUWJqaFVkaGM5YXhnVmIyYjVjNGVUZDFnTmVrZGNmbGRvZlpnVGMzYUJoZmdJZmhoNWh2ZmRobWcxYmtnUWRXZDViS2NaZUhhbGJMZ0ZlSGdFZmRkSGRVZjBlWmFWaG5kUmN1Y2RkbmVOZHZkUmhtY2NjV2RHY2hmZ2dPaEFlaGRCZlpoUmZCaGdnTmNXZ2xkNWR6Yllnbmg1ZmdhRmJDaDVoT2FKZTJjc2ZFY1RoVmNwYkpnQmd6aE5lbGJYY2hkaGh3Y1FiWGRSYVJlU2FrZzVhMWRFYVhiTmdNYlVjWGVoZndhVmZuY1FhUGFhaDFmSWZVZWNoVWJZaGJiTGdDZmdhSGFaYUdjRmdUY0RjR2c1ZHdoRmIwZlZlV2RDY25lTmZIYk9hRWdFYjZiTWRTYXhlNWFRZEJmUmFsZVloQmVGZG5mR2ZWYVpmMGRiY25nWmV6ZWJjMGJaZ25mRmZoZUpmTWJkY1Vob2hRYVVka2NRY0xjY2RGaHBhQ2ZiYjJlb2F5ZEVjbGF4ZHllUmVYY01mSGJNYlVoMWFOZlZoUmVWaFdjWWJIY1JhRWhjZEJhVWdQYkdoVWNwZkZiZGNRZmNjT2JaZGxjRmQ0YmNiRmdaYTBjRGUyZHRkU2FGYkhiRmdHaEVlM2FoYlRmVGMyZFJocWdVaHhma2RUYmVjUWJKY1ZiZmNCYUpoNmdSYzJkUmRCY2Joa2JwZGtkZWZVYnNiVWNjZ1JhMGFkZ1RlUmFsZVdhZGdHYTVlMmhKYXloY2NQYk5nQmdoZEVoV2FIZnNjTGNWYUJmWmVNaFNnSGM0aFhoRmh5Y01mMmhMZnpobGhZaEtiMGJZZ3liR2JVZlZnRGZBaHdhWmdCYkFobWJGYW5mQ2VYY2xoUGFPZ1FnUWNHZ0doamV4ZEJhUGh4ZVZkWmJLaDNkbGNOZVhjZ2Y5Y3JlVWNoZVJjeGhSY2hnTmQ0ZFVjMGI5YWtoYWNsYk1jWmRFYzNoQmFXY2NkMWdZYlNmZWZrYWRka2FRaFdlNWRLaFpjSGdsY0xkRmFIZEVhZGNIZVVmMWRSZ1ZnbmQ5Y3pkZGNtZHRnMGdiYkdnY2FXYUVla2J4YzFmU2VoZ0JjU2hSZkFkdGF3Yldma2VKY3ZnUGUyZ1liK2ZYZERkc2JDY05oaGFCYkVjSGZWZEZlWGhDZUVmNGZoY2ZlUWFOYmFhUWJYYVJiUmdTZGtnNWExaEVnWGFOZk1iVWRYY2hjd2VDYjFnNGFQaGFnMWNJZVVlY2NVZFliVGNlZEZlTmdQaFpnR2dvYkJmWGdFZWNlbGRXY1JhZGFXZEdlbGdCZ0hnWmhFYUZkdWRTZ21nUmc1YlNoeGVSZHhiSGFSYjFkTmFHZVJlQmEwZGNiSGNZaDdhYmgwY0JhaGFQZ0JkSmhNY2RiVWhvYlFlVWFrZFFiTGdjaEZmcGNDYWJnMmJKZ21iYWFSYVJjNmNBZFZma2dRY1RlRWIxZ1JoU2FSZlZnT2FhZlhjUWZZZ2NiRWZGaDBlVWZVZHBmT2RkZFJnRmhzaFRhRmVrZ3NlT2dCZThkbmdBZlNoWWFYZ1dlVGU0ZlVnU2VuaGhlWWhVZW1oUWQrZVhoVWNwZmZkT2dVZ2dlY2VYZ2xncGZ6YVRja2I1ZUJlYmNrZXBla2JlaFVic2RVZmNlUmcwZmRkVGNSZ2xiV2JkZkdoNWcyY2NoMmE5ZmNnWmIxaDhjNGZUYkhiVmZLYUVmRmZKZ0VkQ2gzY0JmYWNRZW1kOWRpYlpjbWVrYlVkY2drYTViemdEYTBhd2JaZkdlUWhCZUdoUWJDZlFoeGJWZlRjOGhUZ0xhVmY4Y1pnQ2F5ZUVoWmJKaDBiSWZDY0xlVGRJYlhiSmdsYjBkcWdDaHhkd2g1aFNjaGRNZitlV2VraE5ha2RQY2hodGJRZFFjSGg1Z0doSGVCZ3RhQmRNZnhoMGFoYlNiRWZSZUtnWmJIYmxhTGZGZUhoRWdkZEhmVWUwZFpkVmVuY1JndWRkZm5jTmd2YVJlbWhjYk1oRWVoYmhmN2hDaFZkOGZDY0hoUWZNZWthRWhnYXNkOGNiaENmc2RzYldkVGMwY2NmS2doZ3hhTWVHY1Jja2FBYVJna2dBZWthTWNWYVVmamhDYUNoNGVVZVJja2Q0ZDlhSGZYZU1hS2RXZkhhUmRhYVZhbmFRZVBkYWMxY0lhVWRjYVViWWFUZWViRmJOZFBnWmRHZnBoVGRHZVJhc2drZlFieGhBaEZkSGNEZmNhQ2RLZlJkSWJuYUVoQ2dGYTVoVmJoZVFoM2VIZFJnQmROY1VnVmE5ZzlmWWdsY3hhemhiYjBiWmduZ0ZkaGhKYk1iZGFVY29lUWRVYWtiUWNMZ2NmQWY0ZktkSmRqZ0ZoTWhhZ1JkUmd5Z1RibmJNZ1FkVGdFZzFnUmdTZlJjVmNPYVljR2I4aHljY2NFaEZoMGdVYVVicGNPZGRhUmRGYnpjVGhBYXhleGVmZUhieGYwaERiMmR0Z1NnRmRIYUZmR2VFYjNmaGFUYVJieWF0ZWtjQWEwYXRjY2NKZUVnUWZOYURiMGhJYS9jU2RTZEFjSWRLY1FkOGgzYkxjVWRzaEpnY2JWaHRmSWFBYzFjb2hDZFBlU2hFZDRmY2MyZGRlUGRaZzBlMGc0Z1RiSGJWaEtoRWZGZEpoRWNDaDNiQmdhYVFlbWI5YmljTWRDYmhhR2FjZ2hicGIvZE9ia2V4aE5mVWFVZ2tlVmZUZG1obGUwZEdkSGVCZUJiZGdGZEZmS2JIZEhia2Q3YmNmMGF4YVJiZWVIYkJlV2FkaEFoOWNyYVVkaGNSZ3hiUmhoYU1heGFVZjFjSmdrZVBiaGR0YVFlUWZIZDViR2FIZEJjdGJkaEthQmI1Ym9iYWMyaDVlS2NaYUhjbGRMZUZlSGJFZ2RhSGJVZDBjWmJWYW5nUmV1YU1oM2hOZ3lhUmZtYlZiRmVSYmhjNGU4Y0JmRmJkZ1FkUmRCZFpodGZXY2hjWWYyZE1oaWdNZm1kVWFuZkloSGVmaHpicGZNY1RhVmNGZkpjRmhVaDVkcGNkZ0JiaGd3ZlFjWGNSaFJoU2hnaEZlMWJEY0hjTmJjZVhhVmZKZHdiVmduZ1FlUGJhZzFiSWRVZ2NmVWRZZlRoZWdGZ05hUGVaY0NjSmZUYUJjQmRNaGtoUWN4aEFiRmNIaERkY2RDZktoUmVJYm5jRWNDZEZnMWJZZVJlUmd4Y0hhUmUxZ05mR2VWZlpiMGJiYW5mWmF6YWJlMGhaZG5kVmFSYkpiUmRkZ1FmUmdWY0JjVWZSZkZlZWVGZU5oWmNSYldiSmJtZGFoUmJSY3lkVGRuZU1hUWVUZ0ViMWhSY1NiVmdNYkJjT2czY1FmUWNXYWtkRmQwYlVoVWFwaE9mZGRSZEZoemNUZ0ZlRmM0Z2NnRmJaZTBoV2N5aE1mYmNSZTNmOGVTY1hnQ2R3ZFNkQWN4aHNmbWZGYmxjY2NUaGJmaGJaaFpmUmVRY0JjUWdSYjJoUmdCZmJka2dwZ2tkZWRVZXNiVWdjZ1JjMGhkYlRiUmVsZFdnZGFIZEZiMmFlZDJlY2hTaFpjd2NzY1NiR2hEaDBnRGRRYzFnd2hTZEdhbmU0ZVpnRGdpZkFnc2hJZjJiRWJkYmZmQmd3ZThiUmZBZ0JiRmRRYkViQWRjYlFia2NOYjBhR2JIZ0JmQmFkZEZhRmFLYVRhbmVVZlJhY2IwZXhiUmNlYUhlQmZXaGRmQWE4Yy9jWGhGY1VkMWdBZ2hkc2NzY0dhd2NZYzNhWmhBYlVmTGRIYVRiTmVIZEZiaGVoaFhjY2ZraDVocWFFaHllRWhlZUtlSGdGY2NjSGVYaGdnUmJOZDBkMGRaY1ZibmNSZXVoZGZuZU5ldmhSZG1mY2NXZEVla2Z4ZDFoU2RoYkJkU2RSY0ZmOWIraEdod2NZZ3JhYWFqYUllaGFYZlNjRmFBZUpiUWJOZkNkRGNoYTBiR2NXYndjdGJoZWZjUmNZaGliRGhpYkFiZGVRZ2xiOWJuY0dkSGhwZ0FhZWgzZWhid2hWZG5iUWRQZ2FkMWNJaFVnY2ZVYVliVGZlYkZhTmJQZlpoR2FwaFRnR2hVZ2RoK2dTaGhoMGZTYkdlaWg0aFBkTGJSZ0phZ2dIZEhkQmIzY0NmRmFnYSthVWgxYWhoRmVFYkZjZ2htY0llU2FJYy9kWmcxZGRlL2NIaHhmdGFBYVhlMGhvZVFnVWNraFFhTGhjZkZlcGhDYWJhMmVKZW1mYWNSY1JieWZUY25iTWVRYVRjQmNsY2ZlRWFWZG9nY2VZZ1NkQmdRZE9oUmVKZzZlQmYxZ3RlQWZPaEVoUWUvYUdhQmdnYm9kUGZBaDlnOGJUZm1jSmJjY1JkamM0ZlNkWGgzZkJjQWdYZG1nMWVrZEhia2J4YWZjSmNFZkliSmhHZGtkdGF5ZkZjR2cxYUlmWWJtY0Jia2ZlaFVoc2RVaGNlUmMwZWRlVGhSZWxhV2hkZUdoNWUyaGNkMmE5Y0diWmN4YVpnR2dRZWplZ2ZmaFhmQWVZY05nV2d6Z3dnRGZTZWpieGJyZmFmQ2ZoYVFhTmhrZVlkMWRHZ1VlQmFuZlVlVWRrZlZiVGJtZGxnMGZHZUhoQmNCYmRlRmFGY0tnVGZuZlVmUmZjaDBneGVSZUxnSGY0Z09hT2IxYzFmamVCaGxid2Y0ZkZkUmEwaHVhUWNVZEVicGhQZnhjOWdOZFdlaWZCaEhjQWJGaDVhVGRjZjBna2cyZERiamNvZEdmYmNHYnBkYWJIYVhhOWRRZ1NoQWhGZk5mSGJ5ZlFjaWVMZDNkc2I4YlRnMmc0YmFhT2dFYnhmMWdTaGhkQmFTYVJkQWV0Z3dkV2drZEpldmdZZm1jWmZwZkZjSGRKZU9jY2UwZFJjQ2hBYkFnUWVGZ1FnUWdjZDVkT2hFY0ZlNGRFYm5mMWVmZ0Nld2JvY3hoR2NUZ1ZiRmhYZlZmSmR3aFZlbmNRaFBlYWExZUljVWRjaFVhWWVUYWVkRmNOY1BjWmVHaHBoVGNHZlJjTWRrY0JhUWVFY1pmUWJIYUloVGhMYkFhZ2c5YlJiRGZKaHFkUmJWaGtna2JVZFVna2JFYlNlUmJvZXRlWmVqZ2RnNmhZYVJnUWJvYlFmbGU1ZEVkWmJsYXNkWmhYZEFnbGFlZVBhQWg0ZExmUGd5aDRjL2VZZ1VmZGc3Z1JhM2I4ZjZnVGdFaDFjUmdTY1JjVmRPY2FjWGRRYVljY2JFYkZkMGZVZVVjcGVPZWRhUmhGZHplR2RGYThhMWZKZVJkb2ZnZlJnamJzYWVoVGZYaGthVmhHYm5nWWRTZENieWNCZWloRmFSZkFnZmhXYmdhdGJaaFZkaGFKZzZiUmUyZ1JjQmRiY2tlcGJrZWVjVWJzY1VnY2VSZjBjZGJUZ1VoMWNZZkxiQ2dFZmtnZWZ6Y3NnT2hMY2thVWFjYUdlbWJGZEVkWGhRZ2NkSWZYZ3pna2dLZkRkamVaaHFlSmgyYkFjYWRJYkFhRWFuZlhmRWVSZWVoUWhFYUFlYmhBYXpkd2U0aFRmRGJrZ1JnT2NBaGhnQ2ZIY1hhd2JZZ2ZhMmRaZ1JiZWNIaEJoV2dkZEFkOWNyYlVmaGhSYXhhUmdoZU5iNGdVYzBkOWVrYWFmbGhOaE5mSGJUZzFhZWRGYlFhSmRiaEtoZ2NzYTliU2JUZDFhRGVhZmphZ2dQaFVhSGFsY2JnRmZFYlFnemhWY25iUmN1YmRkbmFOZnZnUmRtYWNoV2hFaGtkeGgxaFNkaGVCZ1NjUmNCYUZmd2RVZmhoWmd2ZGZhMmJZZjlnWGZEYnNkZGNmZFVmTWdKYkNlQmFWZUhjVmNnY0ljbWZPZGxkMWM0YlNhSGZvZVFnRGdnZ3BhOWRYYVhocGZGYlhoVmRKZ3dlVmZuYlFnUGJhaDFlSWhVZGNlVWNZZlRjZWFGZ05oUGdaZUdncGdUZlRkUmIwYXhnVGh4ZTFnZWhVY1hnUWVCZ05hZ2c0ZGplSmNEYUVkMGNDZVZjRWJqZUZkVWZrZ0ZlVWRBYVZmNmdPZmpia2ZuZkxmZ2ZvYVllV2VsY2NkQ2hmYUVoTWVMYmVjRWhRZ0xoY2RGaHBoQ2JiYjJjSmJtZ2FoUmRSY3loVGRuYU1lUWNCZkVoMWdjZ1NjUWExZ09iZGQyZmtiWWVQZTFocGZlYmVoMGhwZ09oZGVSZ0ZjemNUZkZkRmY0Y2NoRmhaZjBkRGgyY0pmNGVGYUhmRmFHaEVnM2JoZFRkVGUyZFJicWJVZHhha2RUZ2NhQWNzZ2NnZmFCZkpoNmNSZDJjUmFCYmJha2NwZWtkZWZVYnNlVWZjY1JlMGhkaFRiUmZsZUpoZGdDZzFkNGVOY1RhMGhKZEtjbmNSaGJnR2hDYlpiQ2RPaGxmSmRFZkNhM2NCYWFhUWRtZzliaWVaZ21ma2JVZGNia2E1YXpjRWZFZnhoTmZVZ1Via2hWZ1JiaWNCYTZkV2N6YmdkQWhKZGphSWFGY0NkamhCZXdmSmUwZFFmZWZlZEhkdGFXZVpoUWRaZHJmVGNnYWhieGJYZWhjcGY0Y0RlMGg4ZnRmWmVCZUJkUmNVYWlmSmRvaEZkaGVKY1hoR2N4Zk5lc2ZEZm1lZGZHYlRobmRsY0xoRmhIZ0VnZGZIZFVnMGJaZVZhbmVSZHVoZGFuaE5idmVSYm1kY2JXZ0Vka2Z4ZTFoUWJsaGxhY2ZCYTBkTWh4ZENlQ2ZFY2dkSmVpYk1hSWhRaEhib2dCYWNoeGJ0aE1mWGVsY2hlSmZDZVZhSmdwZWJhQmJGY3dhSGRYaFFkWWFSYkFiMGU5ZFVkQ2hFYnZmSGFqZXdnMWNOZnljQWFIZEplRmNJZmZhY2ZWZlFiYWVkYkhobGRQaFplR2NwZFRiR2ZSY05md2hDZTFkbGRXY0VlbmRwYUhoWmJFYkZkdWVTaG1hUmE1YlNieGR3ZTRlRWQxZTRiRmVXZkFkUWRYZElmVGZJYTJnRGRoaEpmdmJXY1JjSmhIZmRoVmM4ZVpiVWdsZmdjWGFjYUVoSmVMYmJmemg1Z21mSWZCZW9jeGFCYWpnSmFDYkxmd2ZJY1ZkRGhIaFFhYWJZYlRoc2ZZYmViMGFGYmdiV2ZFZlpna2hkZFJmRmZ6ZFRjRmZGZjRoY2RGaFphMGJEZzJldGJTYkZoSGJGZUdhRWIzY2hlVGNUYjJhUmFpZUdiaGFkZlFnT2hFY29oTGZOY1ZhMGErY0FlZ2dVZlZoWmZnYlZka2JjZWtoc2JEY2VkQmEwYkJoVWNSY2xnT2ZmaFdnNGhxY2NieWVaZkloSmZGYTVoVGJIYmhjWWJGZ1ZjQmFjaGxjWGMzZWdlVmhRZ21nUmVpaGNlR2RBYytjY2RrYTViemFFZ0VleGZOZVVlVWNrY1ZoVGdtZmxkMGJHYUhjQmZCYWRiRmFGZEtkUmQxYThnUmNjYTBieGNSaGVoSGZCaFdiZGdBZTlicmdVY2hnUmJ4ZVJkaGFOYzRlU2RVZThmbmZaZEJiVmNMYVhiRGYxZ3BiRWhBZEpiQmdjaG1iMWVrZlFoV2U1Y0tmWmRIZWxjTGNGZUhhRWhkZ0hkVWYwYVplVmFuaFJndWNkZW5kTmF2ZFJobWM5Z2ZiYWZRYU5hMWFRYlJoQmdEYU9oUWh0Z3NjUmNrZkpoM2hhZTJjWWExYUZhRGRzaDFmUGNHYjFoQWJaZTFmRmNKZUZmVWg1Z3BnZGZCYWhhd2FRZlhnUmVSYVNia2g1YzFlRWJYYk5nTWhVZ1hiaGN3YVhoamIxYzBjSmhGYklmZmRjZ1ZlVmF1ZGVhRWM5YVRnWmNIZUpiYWZHZVVmOWd3aFFnaWVJY1pkRWFuYkZnSGJkZWpkeGdpZ1llR2RSYjVkU2V4Y1JieGJIZFJkMWNOZEdiVmdaYjBiYmJuZVpjemJiZDBnWmVuaEZiaGhKaE1jZmJRYU5ocmZIZlViUWZBYmNiRWQ4aC9nYmUzZzVhNmdhZVFkeGE3YVRjaWU4Z1FkQmFUZ1loZWdTZlJkNWdPY2ZhUWdrYlViV2JrYUZjMGZVZlVhcGZPYmRlUmZGZnpiVGNGY0ZlNGNjZkZoWmgwY0RoMmN0YlNhRmFIZ0ZiR2dHZ3pjRWRvZUFjR2ZSY2hlVWF3aDVkdWJjYkJkZGJGY1ZoZ2NwaHpjUmF6YmhlQmZKY3pnRWJyaGVjVWhBYlVkWmIyY0FiM2FUY1JmbGNXZWRiR2I1YTJhY2QyZDlnR2RaYXhlWWVTYVRnSGVWZktiRWhGYUpjRWhBaG5leGZ3Z1FlbWg5aGllWmVtZWtnVWZjaGtlNWN6YUViRWF4Yk5jVWNVYmtnVmRUaGllcGI2ZFZlU2RVYU5nSWVCZ2diYWRBaGlid2ZaZE1ha2ZWZGZoS2VqZzhlQ2NPZ0FiZGM0ZlFheGQxaC9oQ2UwYllnMGZCYXdiWWIwZkpkZ2FvYVJnUWZIaGtoSGZjaDFoWWNTaGVia2hkZWtiUWVXYjVnS2RaYkhobGhMZUZlSGhFYmRlSGdVZTFiTmhXZENhd2RoYkpnSGhzYnNiVGQyZmxlRWdYaFJmZ2Q1ZFFoZ2VKYkZiVGNRY1VlOWFEZ3dlNGc3YktkemRZZWxmVGVYY29iZGNlZmhhNGNOY0NmUmZWYkJmVWIwY2RkbGNYZmhmaGJ3Z1FoWGFSYlJhU2NrZDVoMWFFZlhlTmJNY1VnWGZoaHdoVmRuZFFhSGJKYkZmSWFmZmJkRWJZZ0xiY2JVZ2hjbGJaZUdmcGVUZ0dkUmVOZXdoQ2cxY2xnV2FFZ25mcGdIaEloZ2c0YThnU2FtZnhmVGNTZXhhUmV4YkhnUmMxZU5hR2VWZFphMGhiZm5lWmN6ZmJkMGdZZ3ZhRmJnYXhnUmZkZFFnVWNRY1dkVWdRZmZjY2VGZnhoRWFSYldnSmdtaGFhUmFSYXlhVGhuZU1hUWhUZkVmMWFSZ1NiUmFWZE9kWWdUZEVoeWdjZEViRmMwZVVlVWJwaE9mZGdSZEZkemhUYkZlRmg0ZGNlRmhaZzBkRGQzaFJnU2VWYjNmOGZBYVFkVGRjZWVnTGJTYjBjK2NBZkJnRWE1aGNiQWd0ZFpoVmhoY0phNmNSZDJkUmVCY2Jka2hwaGtkZWZVZ3NmVWZjY1JlMGRkZVRjUmVsYmVoUGZXZEFmMWJPZXlmNGFVaEJoRmZsZ1dkQ2dSZ1FjZWhHaEJlMWZFaEFhSGNCYkxkU2QyZzlhK2NlaG1oa2ZNaGVlMGU0aHZmRWRBZVZoRGZFaGdiRmVVY0hkQWNvZDdoWGJEZlVnZ2VJY0Zha2VGZlJjM2FraDdmY2gwZ3hhUmZlZ0hhQmRXYWRjQWQ5aHJjVWhoZVJheGRSZGhkTmU0ZFVoMGM5Y2tmYWRsaE1lUmhXZ25hNWFJZkVjUmZkYkFoR2RRY2diZ2VCZ0FkOGVlZ2JkRGhaZkxkSGYzZ0VlT2FGYkVhMGVGZVNibmJSaDJhZmIzYU1kemJSZ2lhNGFZYlVoUWRRZjBlR2dIZk1mZGRBZkVkNGNSZERia2hvZmdnWWVtYjFicGVCY25ndGhDZFdoUmNCZE1kVGhWY0ZoSmhGaFVkNWFwaGRmQmdoZ3djUWJYYlJoUmVTZmtlNWQxZEViWGVOYU1lUWJYZ1JjYWJWYm5iUWhQYWFhMWRJYlVlY2FVZVlmVGRlYUZoTmJQZlpiR2VwZFRoR2RSY05od2VDZjFkbGRHYk9hSGVwZEhoWmhFY0ZjdWdTZW1nUmE1YVNheGFSZHhkSGZSZDFoTmRHZFZiWmMwY2JobmM5Z1pnYmcwY1plbmNGZWhnSmhNZWRmVWdvYlFhVWVrZFFhTGdjYUZlcGhDaGJoM2doY21kS2VoZG9hMGhIaERoeGdkZ0xiZ2RRYkZkR2NoYjFia2dhZlhmUWFZZGNhRWVGZDBjVWRVZXBmT2hkZlJmRmV6aFRoRmFGYjRhY2FGYVpnMGFEaDJldGNhaFhoUWJvYUphRWgzaE5jVGJYZGhhbGdxZFRmd2FVYlRiYWdBYUpjWmdDaGhiSWJ6ZlBiQ2hzYzhlWWJtZUJja2hlZlVoc2NVYWNlUmUwZmRkVGJSaGxjV2dkZUdlNWIyYmNjMmM5YUdoWmd4ZFliU2NUYUhlMGZEZWFieGcxZEViQWJIYkJmSmVQYzJlOWYrZWVlbWZrZU1nZWYwYjRldmFFY0FmVWMyZ0hoa2ZraGVnVGRuY3NlSmhGZEZlcGdCZ2RnRmJGY0thVGNuYVViUmdjZzBkeGFSZWVnSGdCZ1dhZGFBYjljcmRVY2hlUmR4ZFJkZ2FOZzBkZWVVZzlja2FhZ2xkTWRaZ0VmM2NBaExoV2hWZllkU2hlZWtnZGVrZVFnV2Y1ZUtjWmRIaGxjTGdCZkZic2hkZ0hoVWUwZVpoVmhuYlJjdWFkZG5lTmZ2aFJmbWRjZldoRWJrYXhkMWhTYmhhQmhiY1NnQ2NGZHdnV2JraEpndmdZYW1hWmdwYkZkSGJKYk9lY2N4Y0JoTWhUZ1FkVmRIZFRjUWNFYzdmZmRGZ3RnK2REaENiRWRkZEhiZ2FjZmxoWGdTZXBkRWNBZG5hRmQ1ZVdiQ2JaZEFiUGd4aDRkY2hZYTFnVWVhY2RmaGM0ZmFiS2NEYjRkYWNTaFZhOGZwY0FmeGRoZmZiSGhEY3NmRGZJYUVha2c3ZFFjMmRoZVRhU2h4YlJoeGhIYlJnMWdOYUdmVmFaZjBiYmNuY1pmemViZzBjWmJ2aFdkUmVKaEhnYWZFZ29nRWRXYzBhMGVRZldnbGZwZENjYmEyZkpibWhhZVJkUmd5YlRlbmFNYlFiVGZFZzFkUmFBZlJkVmZRZGFoVGVzYkRlV2NtZXRnMGdVZlVocGFPZGRnUmJGZ3pnVGFGYUZnNGRjZkZnWmM5ZUpiV2F0ZVNoRmVIYkZlR2ZFaDNiaGhUYlRoMmVSZ3FoVWN4aGtnVGJNYndlVWVmaEJlRmUwYzNnSmNTaDBmVmRQZFVoSWhoZWVnVmdRZVViT2hCZU5hZWdCZ1ZlZ2JFYkZjeWVFZnllTmRnZDRoU2ViaDFoa2daZVJnM2h4ZEtlQ2ZsZkljTmVjZ0RhOWdSZlNjUmZKZ3VhWmJuZWtkWWVjZ2xmNWUvaEVhRmF4aEVhWGVXZU1mVmVUZG1obGEwYkdiSGhCZUJoZGZGZUZjS2FUZW5mVWVSY2NhMGV4aFJmTGhIYjRiT2JPYTFnMWNqZUVnUmVvaDhnRWgxYzhkc2FHY2hmOGZvaE1kMWV0YlZjR2FuYmtnRmdDZHhibGNHYk5la2U5YTFmVWRHZGRmRWNLaFNnd2NIZVFkRGdoYk5iVWVSY1FkUmhCZlhlMWIxZlhjSGJOYXZiUmJtYmNiV2dFaGtmeGgxZ1NnaGNCZlNkUmFGZGtkMWdEaGhlY2M5YkxjR2haY2hkUGVuY0pmT2FjY3hiQmRNYVRhVmNGY0poRmZVYTVncGVkYUJlaGJ3YlNnU2JaYlJjVmQwZzRnaGRIZnpjQWZBY0hnamFZYzFjWGRuYzBhQmZPZUJhcGhkZE5meGRKaGhlTWFSZlFoSGRNZUdjSmNBZ0NkaGhwYTVlQmYzZ05hV2RFY25jcGRIZVpmRWNGZXVnU2FtZFJlNWZTYXhhUmh4Y0hjVWFsZ0RmUWZSZmthbWRaZmlnUmQ2Z1loUWZzZ3liV2VrY1liRmRKYVFiWmhKYldmZ2hVY0NnZmdIYUJkQ2NiZTJlSmVtYmFlUmRSY3lhVGRuZk1hUWhUY0VkMWZSZVNjUmIwYmNhYWFXYWtkWWhKZkVlOGEzYkhoUWhVZUFlTWZCYWxnNmJRZmdoSWd3YU9iUmdBaGdoZmRTaElmVmVYYUNjVmRPYkFlV2FGYWFoUmNtYWhlQWNVYXhna2dUZGNnQWN0YVpmVmFoaEpkNmFSYjJoUmRCYWJna2dvZXdjZGh4ZE5kYmdJaHhhVmZQZFJmQmNjZmJmSWFTYklnaWRPYWpkOGVLaFBjaGg1ZEhkUmZYYWxlZ2hFYUZnSmdFY0NhM2VCaGFmUWJtZzloaWdaYm1ia2JVZGNma2Q1aDdmUWJrZXhlUWNVaFJhMGRiZERhU2NVZzdlVmJqYlZlSmRmYVZjOGdaZkJoamZ4ZVhkSmF6ZDRnWWVQYnphZ2NDZWZiQmR4ZTViV2N4aDFmOWdiZkJnTmY0ZlVnMGM5ZmtnYWFsZk1nWmFFaDNoQWZMaFdnVmFZZ1NlTGFrZWtjOGhEZ2pleGNDY05ibmNCaEhlUGJuYkVoZGdIZ1VhMGZaYlZhbmVSYXVnZGZuaE5odmNSY21lY2NXYlJhZ2hRaDhoR2dSYjRoYmFDZmtlSWdrZlVmaGJZZm5lS2Z6ZlZlbmFSZXpkY2VMZ05leGJsYUFoWmgxYkZhSmVGYVVnNWNwYmRiQmJoYndlUWRYZlJiUmNTaGtnNWMxaFJiVmVsZk1lVWFYYWhjd2JWZm5kUWhQYmFmMWFJY1VhY2ZVaFlkYWVZYjNibGRQYlphR2RwY1RkR2NSZ05hd2hDZzFhbGhXaFRlM2hOaExlVGNraEZndWJTY21hUmM1YVNneGdSYXhjSGZSYzFiRmJUZlZlZ2N4Zk5iaWhZZDhnUGFSYklnMGRGY2dhOWNNZ09ja2ZNYkxkZWZFY1FlTGZjZ0ZicGhDaGJmemM5Zm9mS2VsaFVhK2VBaG5idGdDZFFjRWIwZllhUWRRZFZlSGVaZnhmWmVOaE5iZ2FjZ3hhQWgwYU5hSGViY2pmdGh6YVRmRmFGYzRmTGFWZ3BnZWZEZTJkc2h2ZEhjV2JwY3NlVGNuZUZjSWRaZVVmNGVtYkZla2cwaFRiT2JFZFFkS2dBY2xmd2E3ZUNnaWRGYkJoY2IwYXBjamhmZGxlQWQrZE9iRmJzZGRkUmJVZzBlUGNKY0Nhc2Y1Zk5oV2g4Z1JmTGNsYmhoV2hBZHllSmVLYkRoVWM5YVpjQ2IzYmNhUGZEY0Nmc2RuZ0liQ2hCYmFjTmR3Z3BlMGVFZUJnQWFSaFVlUmRkYlphQWFTZ29iMWdUY0Ria2RPaE9lbGY4ZkNnSGhEZ0JmWGdmY1FhVWJmY1BhRGVVZ09iR2cwY2xoamVVZkZiWWY5Z0NjVmhGZmlhVWdVZVpidGFhZ2doZ2V6ZkVoM2ZCZERlRmNnZVZhR2JOYkFlWWVwYUJmR2M1ZFhoWmFIZ3NnY2RXYXlkTmVXZ1dkQmc4ZGJnVGNWZzRnemNkZWpnWWJqYkZkU2ZJaFdnU2JXYVpnMWVTYmtoUWNBZ0hmUWFzYnJkY2JFaEpkdmdZaG1oWWFoZFdheWJFY2FlUGVWZEVoQmZDaEZjRmdVZkZjVWdZaG5hTWZVZDlkd2ZOYkFhWWI5YlFoZ2JJZjZmVWdqZkliWWJHZURoY2MrZldjRGZ4Z2RmTGJoYlFkZGdlYkVkaGRiZk5nd2RBZWJlS2hpYXNiZWhYaEJnTWFzZFZnMWdsZFVlVWhEZ3NlRGdaZmxicGJFYVNmbWRRZ2tlU2IxaGNjd2ZTaFZnNGhGaEdkVmQ0aHhnWmUzYlljb2dSZVVkWmhuZUZkaGRJYkVkT2RoYWxlRWZIYkFhVmFHZE5lVmhwYmZlYmYyY0FoeGdKY2tmWWM1YkNheWRFZVNhVmQyY2RmUmZTZFVnaGJraE5nRmU0aHloUGJBYVFkZ2FVZVFmOGdLZkljSGNVYjhhQWZSYkFmeGVQaGxmWmhwYURkeWhNYmRiUmR5ZlViSWZVY2piVWNXZ1FhU2FFaGtiRmcwYXBma2JPZ1ZnOGJSZVhjaGRWaDBnQWVpZ0FkVWFhYVVnTmQvaFVkMmNGZ1lnTmdFZGtnZGVHYVViMWZOZFhka2dSZDVoZmNHZzhobmZOZkVkVmRiY0NkemN0ZUtkUmNBYlpoRWFYZURia2RPZ0NkbWE4YzJnTGVpYndlVWNJZVJob2doZVdnUWZJYUthVWVVZjRiYmdDY3lnMGRoYkhiM2FBZkljTWdsZEVhZWdCaGpnQWdSZU5nd2ZNYmNkT2RUYmthWWNkZEVnb2RsZEZha2JkZnhoRWFWZG9jc2dHZzBjOWhqaFpiQmRaZWRhUmJuY2NlSGVXZ1JhbGdHZ01mZ2FJaDJlRmVpYmNlWmhJaFhha2ZOYldlemIxYVJiVWdoYm9lWmVHYlNkWWZuZk1oVGdvZGhoQmJ5YXNjV2RYYWdiTWV5YUFlMWJOYTRjRGJVZjFld2ZVYWdjY2ZyYU5md2NJY21lV2NUYk1jSGhQZFJnbGdNZ0Zlbmh0ZkpjRmFSYW9lOWdkZEFkVmh3ZlJjbmRvaFVnRGNoYXRneWJDaGxja2dSYlVoVGEwZjhiQmZUYkVhUGhNYkhmZ2ZVZWNoUmhKYUhoZWZFZzVkUGhaYldoc2NVZ1ZmVmJ3Y3liU2doZlVnaWJXY2pjTWRVYWFiZ2NRZjRnQ2J5ZWdjQ2RPZUVoQWVqYVZiRmJNYUtkRmJ4YkFjbWVJYlRlc2FRZkloQWFJaGlnWmNsZzBmRmFPZnhoNGVZZ1NhbGJVZFNjWmVWZU1mL2diZTNoMWJtZ0xmbGZnZTliRGREZ0piY2dPZ0FmVWZZZ0diaGFzYWhkR2d4YVplb2ZBZ2ljNGVMYU9kaWM4ZTNmZGNVaDBidmdUYkJka2MzYklnd2VJZzZiVGNpZllnWGdGZkdmdGFHaEdnemI4aGZiQWRDZVlicmNIZDJiMWhiZE9jVmNoYVhiT2RXY0FjWWJOZHhhWWJ1ZUVoU2FFYkJjQWFFZ3RhSWhMZFJjMWJWZ0Fha2JvYUNjT2dpYThjN2hOZG1oWmNHY2JlQmJZYlFkVGVIY2RiUmVPY2djOWF1YUlmVGRNYlZkRGVEZndlMmRaYWliOWVTaGNkbGdOZ3pnVmh3YUFiQ2VFYndkaGRaZk9naWdFYTlmU2gzYTRmT2NKY0JmUWdFYUNleWVjZGZkRGdBYzRhRWdQaGplWWVlYVpoeGUxZmpoUWNoYjFoL2dFYTBmTWI4YUVoaGRzaGhmWWVnYmRkTmdHYm5oNWZQYkVoQmdGYVhiS2VSaE5ic2FTZkdiQWJlYktnd2JvZGZnUmJqZWhkVGJXYWtnVWdJZ1FkSGUxaGdiSmhqZklncmZOY1RnTmZYZ1FkQmZoZjloV2V3YlphZWZSY0JhdGQ1YVZiQmVZZ2djRGRpZmtjK2dVYVNnQWJ0Z01oa2ZNY0pnUmdWY2hiU2dQYXdma2JsZE9lMWVvZHhmRGVRYUFoWmFBYXhmMWQ3Z1hnaWFNZUpnSGZ6ZDBmaWdWYW1ha2NQYUxnQmM1YmJkTWR3Z2RjZmJEYkJic2VHY05nMmJRZnNhVmNraE1mMWNSZFJnd2FFZkNnVmhBZ0RmSWhRYjBocmJIY2liRmU1aERhRmNnZitkWGQxYXdkQmViZlJkNGc5Y1BjWGJnZTJlT2NRZmNjcmNiYldjRWVZZEpjd2dOZ2ViRmNVZXBlTmdJZWhkVWRQZkRnQ2MwYmljTGhHZ1FlOWFCY3phMWZFZ1JiRmNWYUFiVWVBYUJjSGVGZUdoOGN5ZWVjQWhjZWhnSGZ3ZmtmYWRQaEZhNGg5YVJkQ2I1ZW9nS2RFY1JmamdIYkNmZ2JUaEFmSGcxYkdhYmZHaGdnTGRYZUhmMWgrZFFibGR0ZldlZWdRYXNjQ2FWZWtmUWQ3aEZhV2ZRYStjZmZoY0pkMmdQYXdla2hBZWFoVmNnaGRoVWVCaGtjcGNaaERlWmJuY1lnSGQxY2VhYWF4YVpodGJYZENjMWRlZ1VhaGNjZUFkVGUyZlZiYWRYaDJjOGVkZWRoamdFYUdjWmZWZzBkd2hVY1ZlaGFGYVdhRmhJZFZkR2FTYkVkOWNWZERoVmhCYmZnRmJCY0xiTmRRZ2dlWWVjaHhkZGJSZkxiQ2RJZ1BoZGhGZlJocmdCYkZiVWZqZVJibWR4aG9lQ2IxZXBnMmNmY2tlSWhQZEFmSGVBZldlV2VRYlpmVGhLZkJmUWJoZUtkQ2ZBY2VoYmVBZlpiYmNUaEdmTmNiY1hiMWFrYkJnRWYzZ3hoK2VMZG1jSmg4ZlZjR2M0Y2ZlRWRrZk5mMWRXZmtmaGVEZ1JoQWFGZXdmVWdoY0lndWRNaERmVWdzZmZoVGF3ZmFjZWcyYjllY2RGZFVkTWJQZ1ZmMWJwYnhoTWZSY0JnZ2RHYldlVmhEZUNiVWJkYzhhRWNYZXhoTWZRaFNiQmdpZlhnM2JRaEVoYWF3Z0plVmNJZXhhVmVXZkVmUmMwaGJnYmhCZ1ZiRGJRYlFkRWQyY1NkVWIxZU9kVmEzaEpkWGJQZUZlQmQ5YVhhMmUxZHdnU2J4YnRleGREZ1VhVmdlY0doVmd4YzBiWmZuZHNoamdMZ2hjUWYwZlVnM2VzY0NlSWFVYkpldmdRaGhkd2FaY05naGFoZFdoZGF5ZmRmdWJlY1VieGZqYlhkV2hjYlpmUmFVYzFhZWRTY1FhVWJXY2ZjWGYwY1lhZWQwaEVma2RFYUJkZ2JkZ01oSGdnZzlkR2JGYWtnSGhZYkFmNWRtZlNkU2NsYkdkRGdEYlJoT2hBZ3llQmNDYlhkU2FaY2pmV2JoZGtjY2VjYUJic2FCaFFoeGdKYXdnUmcyY3djUmNMZXhiZ2IzYVBoQ2FKZmFlSmVSZlZlaWNYZlVjRmNFZU1maWJ4ZWlnYWF5Y3BkT2hkZDBmNGNEZFhnMmVKaERkR2VWYUpmTGJDaDJiQWZDZlZnR2haZ2lhYmVXZGtjWmNJY2djOGRoY1Fnd2RraGtoSGZ4ZDBiZGFNZFhla2ZzZUNjamFZYURoWWdFY2toUGNSYW1mVmRKZVllbGg0YlVoY2NYY2xkV2NlY3dnOWM3YUNiZ2FOaHhjVGRSZ05kMWdBaHdmNGQyaE9iUmNaZXdiWGVTZVFoRGNKaGtiWmdLZmFnQWFFaG1jVmZYYVloUGdiZUdla2FUZUJkV2VJaE9mRmJFZ1FnWmJXZFhhUmMrY0xnbWF0YXZmVGNXYWRjR2dVZXhjNGdtYURkM2hrYmNlRWJBZE1jUGVTaGhkcGc5Z0phQ2FSYzloRGhEYWRmR2hZYjBkaGJkYlhjeGVWZEFmSGJFZDVkbWNkYUFlZ2JvYldkSGFSYWJoU2hrZVpjNGNRYlRjSWVlZEFnamYwZlphR2RDaEFjSGhGZEVoSmFNZFlmd2VCYlJoYmdFYXNiS2JiaEhnb2JMYkNlQWVFZjJkQWhsZ0JmV2NIaFhlcGJYZ1BhQWZCZm5iU2NtZzlhNWFHaDFkVWVqZVRnbGhnYWtlVmR3ZkpkOGFFZVdoWWhyZWZjUWRBZ2xlQWZnZm9lSmNmZVZocGhJYVFnMWVjYWFkZWRWYU5iQ2VZZkdjSmgyZE1jVmVaYnBjVGVqYnBmV2FUaEVoVWF1Y1diVWQxZ2JjZWUyZUFiSmZaaGxoSmYwZVRhRmJkY1RlZGhXYzVjamJGY0VjSmdoY1pnRWJjZzJnU2htZUphU2dWY2lhTWJEaFVlamROaElmVGN5aEVhbWRBaEZld2VUZURneGRzZUJiUWNsYUFoL2dBZ3loQmRVZkZnVWEwZTBjTGdCZWhnY2ZkZW1lQWdWY01kZ2RrYU9jWWRDZ3djemZOYnlkdGhUZEhjQmFGZEJjQmJEZndlTWdSZ0ZkVWE1ZkFiM2dsaFRlV2VXZjhjL2NaY2locGJWZUpiZ2MwYjdjRWVFYlFmeWJRZ1JoRWRHY1diWGhzYndoV2FUY05oSWRkZ0FjcGJLY01iV2NWYUpmWmJ3aDRlVWJQaERkUmdEZURhd2RnZjdnQmMwYWNiNWNRY1djNWJ3ZkxoRmI4ZDhlZmhoZ0ZnY2RWZnpnUWVlZEllbGdGZkJmTWhnZTRkaWhGYVdja2EzZWJjSGVCZkNmRGgzZEZoQWRIZFJhQWZaY0NoM2R3Z1JiWmNpaHRhNmJCaEhmWWFQYkhha2R4YmxhRWZnZ0lkVGJBYUJjeGFrYVVmMGN0YjBoWWNpaEFkOGVXaGphRWVhZ09kbGE4ZUNnVGRRZ2tmUmhUZlJkd2FvZ0pmMWZ3YTJoRGQyZmRmWmZRZDBoNGV1ZEVmU2g1ZE1kRmZ5ZzBjK2NGaFNiQmRHY0pnQmR3YVVjRGFsZlpjTGdiY1JiRmRlY2ZnV2ZKZGFjR2FVZ2hjd2FYYVJlZ2FFZkViZ2ZWY1hhUGJBYVZkOGREYm5nSmJwZldjUmJSZHNkSGJXZlpnS2RDZTBiSmN0Y2VoV2FkYnJiZWZ6Z3djVmFmZFdic2MvZk1hVWEwYmNlVWJrZE1lWWZhYlVkeGdhZkFiaWQ0Zk5nS2RGYUlhTGFTZ1hiOGhRYlNjMWY5ZkdkV2hsZndkMGhPY3hlTmJvaFBka2NaZDRlVWJVZzBibWZNZ0ZnMGgvZEFoeWMwZmdjWWVrYlliRGZRaERha2hlZ1VnSGFCZEJnSGQzZGhlVWFYaEhiVmN5ZE1mRmhwZVpmTmFYaGdicGFVYVJhNWI2aFFlSGdaYlVnZmRsZ3hkMGNIZmhnMWZrYkVkMGI1Z2FoU2hoZFZlV2VjaDNlOWRrYVlnSGJrZUZoRWdtZFZlQ2dPYnhkbGVOYUhoRmRKYURnSGMyZFJmTWFXaDNnc2ZIZ0xmamJwZG1lTmJDZHBnMGhIaEVoeGZLZVFoMWRrYUhhVmFuYkZhbWVEZEJhb2dJZEJkQmM4YmRkSGZIZUloZGRjaDBodGhEZWJlbWJBYXNoUGZuZHNiOWdLYUhhWmEyY1NhaGJOaC9mSGN3YkFkamhiZVZhOGRaYUZnR2FjZ1NhVGhFaEloTGhhaDFlTWdyYk9oUWZZYXViQmN5YkJkTWZHZ0hoRWFhZERnRmU1YXFmUGdqYUFkTWZIY3hiOWdvZ09lM2Z3Z1dmYmZWY3dmdGNYYjFjSmNEYlhkUWh0ZHRkV2VnaFFiNmdMY0NjVWU5ZVhiVGgwY0FlZWh4ZmxlTWFGY2xhRWhiYVVlQmdvZDhnSmVsZFpnd2NQYW1lUWZKYkRibGV3aHhlQmcyZk5iZWZTZG5jZ2V0ZFRoWGNSYmRkTGdnZFpmQmhJaHdnZ2NUZkJjMGJNZ1hiY2ZTZ2hkQ2dBYUJldGc1ZEVhRmVraExmRWRqZndkU2NLaGdiSWM2Y0FjeWZzZzNjU2QyYnRoaGZSY1FleGdlY0NiMGY1ZDhmRWNXZFlhcmFmZUZhVmF3ZURhd2FjYVBkZWdVZ3BndmFRYmhnd2ZlY05hRWIwY0hlZmhuaEpkdmFhZFVlOWh5ZEdiRGZKZENoVGVEZUpmQmhFZlFjQWRNZmVmR2gxYmNlTmZrZkZlcGVVY1RkVmFlaExiUWhRZXhnWGVVZ2hid2JlaFViMWcwZ1hoU2g0YUdoUWVTYk1mSWJFZndhZGdEaEZoM2VWaDVhUWNRY0VlVGhiYVFnc2hmZkFjMWd3aDVkRWN5ZjBiT2RJYkVlSWdiZ2FiUmRNYkZhWWhnaDhkRmZWYVFkbGRhaGRkQmdGYm1lS2czZ3BiWGJjYzFhSmhVZ1diSGh4aEtnU2UxZ0lkN2NHZXlhaGJMY1VoWGMxZzZhZmduZGtnVWJiaDBmNGVNZ0FhQmNSZGNlUWZsaHNlTmRWZ25ibGgwZUZiWGhCZ1JhTGhFZEJhWWZEaEdkNGRSYUpnUWgwYURhZWhBZTlkR2hMaEJjMWh6YUZkQWNKYWthVWVoY05mbGFVZXpnQmIwZ01ka2RaZmJnQWNtZ2xiUGhIYXlhMWN0YmFmaGI5ZDFlVWZuZ3hnU2VmY0doa2YyZ0RoM2JGYlBiV2hCZGxlTWRCY0RkcGV1YkNkV2FNaDNkVmZIYjlmUWVCaEZjbGVoYlVnUmJBZVBkU2ZBYnNlUGZTY2hhcGcrZmNhWGFSYnhiSGhBYzFoZWFLZndjTmNmaFdna2ZoaGNjVmJrZUpjcGRDZXdnZ2dvYlZnRGJCZUdkRGUxZDllbGJHZUdlaGNNY0RjSGdnZW9nRGFpYXhkZGRLYmdiRmdRYk5od2FnY0FnY2NGZnBiVWFUZ2toQWNkZVhjRWhSY3dhYWFnYXNhRWNVZnllTmhQZ2NibGhWZW5hUmRDYzRiMmRBZ2xmcGc1ZldhMWR0Y0VnQWdsZVpjMGJZZlhkbGR6aEdod2c0YnViUmFSZEljYmFQY0FjWmhjZ1VnZ2VaZE9mY2dBaDRiS2FLYm1mSWF3YUtoRmRnZG5jQ2czY05oQ2FDaFJla2VFYUdkMWJzYkxkTGNYZlJhYWZLY1VoRWF4aEJhd2NzaENhWGN3ZD1hPQBtOXZUTlZTT2ZHNjJsVWowcmQrUHpiT0JGSTRSblMwbG1xaTVuSVQ4UGFUcWpuVTFTbHFYUHZUL0tyNFFmM1hzb0RKczkzUCt5djJaZ0RhTmpEWWs0UT09ADAxMjM0NTY3ODkAQy5VVEYtOABmNmNhZTE2ZDY3MTRhZTg3OTdkY2M2OTQyNDU4MGMyZDE3M2IzMjliZmNmMDQ2MmY0NDEwN2I5ZjMwZDQwOGU2MWNhMjA2MTIwY2Y2NWMyNWFhNThkYjViMzViYTRkNGE1NzMxOWJkZDI4MzhjODQ4ZGE2NDBkMjE3MmRjNzk0NTQ4N2E0N2FmYjM3MzhlMTNiNTFjYzljYzc1OTg0ZGMxODY3YjJmODA1NzUyMTYzOTUxMzg4YTU5MDVhYjYwYTY5OWZjZmUzMTk0MWEyNmY3MDA4NjFmMzU5OWRjYTQ1Mzg2YzA5NzIwY2VhMjY1MWU1ZTU3ZTAwM2YwOGY1YzczAEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaYWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXowMTIzNDU2Nzg5Ky8ALgAobnVsbCkAUHVyZSB2aXJ0dWFsIGZ1bmN0aW9uIGNhbGxlZCEAZmluZFNhdHJlY0luZGV4OiAAZm9yOiAAbGliYysrYWJpOiAAU0FUUkVDIEJTVEFSOiAAAAAAAAAAACy3BABlAAAAMjZQcm9wYWdhdGVkUG9zaXRpb25Qcm9wZXJ0eQAAAAD8AAUADLcEAGi6BABQMjZQcm9wYWdhdGVkUG9zaXRpb25Qcm9wZXJ0eQAAAMT/BAA4twQAAAAAACy3BABQSzI2UHJvcGFnYXRlZFBvc2l0aW9uUHJvcGVydHkAAMT/BABotwQAAQAAACy3BABYtwQAwP4EAFi3BAA0vAQAaWlpaQBkaWkAdmlpZABQMTZFbnRpdHlDb2xsZWN0aW9uAAAAxP8EALa3BAAAAAAAeLkEAFBLMTZFbnRpdHlDb2xsZWN0aW9uAAAAAMT/BADctwQAAQAAAHi5BADMtwQA8LoEAAAAAABougQAZgAAADE2UG9zaXRpb25Qcm9wZXJ0eQBQSzE2UG9zaXRpb25Qcm9wZXJ0eQDE/wQAK7gEAAEAAABougQAcLoEAPT+BABwugQAJP8EADRCYXNlAAAAvAAFAGC4BABQNEJhc2UAAMT/BABwuAQAAAAAAGi4BABQSzRCYXNlAMT/BACIuAQAAQAAAGi4BAB2AAAAeLgEAAAAAABouAQAZwAAAGgAAABpAAAA8LoEAJC4BAA4U3ViY2xhc3MAAAD8AAUAxLgEAGi4BABQOFN1YmNsYXNzAADE/wQA3LgEAAAAAADQuAQAUEs4U3ViY2xhc3MAxP8EAPi4BAABAAAA0LgEAOi4BADA/gQAAAAAANC4BABnAAAAagAAAGsAAADwugQABLkEAGD+BABouAQAAAAAAIC5BABsAAAAbQAAAGkAMTZQb3NpdGlvblJlZ2lzdHJ5ADE2RW50aXR5Q29sbGVjdGlvbgC8AAUAZbkEAPwABQBSuQQAeLkEAAAAAAB4uQQAbgAAAG8AAABQMTZQb3NpdGlvblJlZ2lzdHJ5AMT/BACcuQQAAAAAAIC5BABQSzE2UG9zaXRpb25SZWdpc3RyeQAAAADE/wQAwLkEAAEAAACAuQQAaWkAdmkAAACwuQQA8LoEAGlpaQD0/gQA2LkEAGD+BACwuQQA4P4EAHZpaWkAAAAAYP4EALC5BAB2aWkA9P4EALC5BAAk/wQAaWlpZABBwPQSC4MI9P4EALC5BABwugQAJP8EAHj+BABQMTZQb3NpdGlvblByb3BlcnR5ALwABQAYuAQAxP8EAFS6BAAAAAAAaLoEAGlpaWlkaQAA9P4EALC5BABg/gQAwP4EAMD+BAAk/wQAwP4EAMD+BAB2aWlpZGlpAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0ljTlNfMTFjaGFyX3RyYWl0c0ljRUVOU185YWxsb2NhdG9ySWNFRUVFAAC8AAUAsLoEAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0loTlNfMTFjaGFyX3RyYWl0c0loRUVOU185YWxsb2NhdG9ySWhFRUVFAAC8AAUA+LoEAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0l3TlNfMTFjaGFyX3RyYWl0c0l3RUVOU185YWxsb2NhdG9ySXdFRUVFAAC8AAUAQLsEAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0lEc05TXzExY2hhcl90cmFpdHNJRHNFRU5TXzlhbGxvY2F0b3JJRHNFRUVFAAAAvAAFAIi7BABOU3QzX18yMTJiYXNpY19zdHJpbmdJRGlOU18xMWNoYXJfdHJhaXRzSURpRUVOU185YWxsb2NhdG9ySURpRUVFRQAAALwABQDUuwQATjEwZW1zY3JpcHRlbjN2YWxFAAC8AAUAILwEAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SWNFRQAAvAAFADy8BABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0lhRUUAALwABQBkvAQATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJaEVFAAC8AAUAjLwEAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SXNFRQAAvAAFALS8BABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0l0RUUAALwABQDcvAQATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJaUVFAAC8AAUABL0EAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SWpFRQAAvAAFACy9BABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0lsRUUAALwABQBUvQQATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJbUVFAAC8AAUAfL0EAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SXhFRQAAvAAFAKS9BABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0l5RUUAALwABQDMvQQATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJZkVFAAC8AAUA9L0EAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SWRFRQAAvAAFABy+BABB0PwSC2BPu2EFZ6zdPxgtRFT7Iek/m/aB0gtz7z8YLURU+yH5P+JlLyJ/K3o8B1wUMyamgTy9y/B6iAdwPAdcFDMmppE8GC1EVPsh6T8YLURU+yHpv9IhM3982QJA0iEzf3zZAsAAQb/9EgvoFYAYLURU+yEJQBgtRFT7IQnAAwAAAAQAAAAEAAAABgAAAIP5ogBETm4A/CkVANFXJwDdNPUAYtvAADyZlQBBkEMAY1H+ALveqwC3YcUAOm4kANJNQgBJBuAACeouAByS0QDrHf4AKbEcAOg+pwD1NYIARLsuAJzphAC0JnAAQX5fANaROQBTgzkAnPQ5AItfhAAo+b0A+B87AN7/lwAPmAUAES/vAApaiwBtH20Az342AAnLJwBGT7cAnmY/AC3qXwC6J3UA5evHAD178QD3OQcAklKKAPtr6gAfsV8ACF2NADADVgB7/EYA8KtrACC8zwA29JoA46kdAF5hkQAIG+YAhZllAKAUXwCNQGgAgNj/ACdzTQAGBjEAylYVAMmocwB74mAAa4zAABnERwDNZ8MACejcAFmDKgCLdsQAphyWAESv3QAZV9EApT4FAAUH/wAzfj8AwjLoAJhP3gC7fTIAJj3DAB5r7wCf+F4ANR86AH/yygDxhx0AfJAhAGokfADVbvoAMC13ABU7QwC1FMYAwxmdAK3EwgAsTUEADABdAIZ9RgDjcS0Am8aaADNiAAC00nwAtKeXADdV1QDXPvYAoxAYAE12/ABknSoAcNerAGN8+AB6sFcAFxXnAMBJVgA71tkAp4Q4ACQjywDWincAWlQjAAAfuQDxChsAGc7fAJ8x/wBmHmoAmVdhAKz7RwB+f9gAImW3ADLoiQDmv2AA78TNAGw2CQBdP9QAFt7XAFg73gDem5IA0iIoACiG6ADiWE0AxsoyAAjjFgDgfcsAF8BQAPMdpwAY4FsALhM0AIMSYgCDSAEA9Y5bAK2wfwAe6fIASEpDABBn0wCq3dgArl9CAGphzgAKKKQA05m0AAam8gBcd38Ao8KDAGE8iACKc3gAr4xaAG/XvQAtpmMA9L/LAI2B7wAmwWcAVcpFAMrZNgAoqNIAwmGNABLJdwAEJhQAEkabAMRZxADIxUQATbKRAAAX8wDUQ60AKUnlAP3VEAAAvvwAHpTMAHDO7gATPvUA7PGAALPnwwDH+CgAkwWUAMFxPgAuCbMAC0XzAIgSnACrIHsALrWfAEeSwgB7Mi8ADFVtAHKnkABr5x8AMcuWAHkWSgBBeeIA9N+JAOiUlwDi5oQAmTGXAIjtawBfXzYAu/0OAEiatABnpGwAcXJCAI1dMgCfFbgAvOUJAI0xJQD3dDkAMAUcAA0MAQBLCGgALO5YAEeqkAB05wIAvdYkAPd9pgBuSHIAnxbvAI6UpgC0kfYA0VNRAM8K8gAgmDMA9Ut+ALJjaADdPl8AQF0DAIWJfwBVUikAN2TAAG3YEAAySDIAW0x1AE5x1ABFVG4ACwnBACr1aQAUZtUAJwedAF0EUAC0O9sA6nbFAIf5FwBJa30AHSe6AJZpKQDGzKwArRRUAJDiagCI2YkALHJQAASkvgB3B5QA8zBwAAD8JwDqcagAZsJJAGTgPQCX3YMAoz+XAEOU/QANhowAMUHeAJI5nQDdcIwAF7fnAAjfOwAVNysAXICgAFqAkwAQEZIAD+jYAGyArwDb/0sAOJAPAFkYdgBipRUAYcu7AMeJuQAQQL0A0vIEAEl1JwDrtvYA2yK7AAoUqgCJJi8AZIN2AAk7MwAOlBoAUTqqAB2jwgCv7a4AXCYSAG3CTQAtepwAwFaXAAM/gwAJ8PYAK0CMAG0xmQA5tAcADCAVANjDWwD1ksQAxq1LAE7KpQCnN80A5qk2AKuSlADdQmgAGWPeAHaM7wBoi1IA/Ns3AK6hqwDfFTEAAK6hAAz72gBkTWYA7QW3ACllMABXVr8AR/86AGr5uQB1vvMAKJPfAKuAMABmjPYABMsVAPoiBgDZ5B0APbOkAFcbjwA2zQkATkLpABO+pAAzI7UA8KoaAE9lqADSwaUACz8PAFt4zQAj+XYAe4sEAIkXcgDGplMAb27iAO/rAACbSlgAxNq3AKpmugB2z88A0QIdALHxLQCMmcEAw613AIZI2gD3XaAAxoD0AKzwLwDd7JoAP1y8ANDebQCQxx8AKtu2AKMlOgAAr5oArVOTALZXBAApLbQAS4B+ANoHpwB2qg4Ae1mhABYSKgDcty0A+uX9AInb/gCJvv0A5HZsAAap/AA+gHAAhW4VAP2H/wAoPgcAYWczACoYhgBNveoAs+evAI9tbgCVZzkAMb9bAITXSAAw3xYAxy1DACVhNQDJcM4AMMu4AL9s/QCkAKIABWzkAFrdoAAhb0cAYhLSALlchABwYUkAa1bgAJlSAQBQVTcAHtW3ADPxxAATbl8AXTDkAIUuqQAdssMAoTI2AAi3pADqsdQAFvchAI9p5AAn/3cADAOAAI1ALQBPzaAAIKWZALOi0wAvXQoAtPlCABHaywB9vtAAm9vBAKsXvQDKooEACGpcAC5VFwAnAFUAfxTwAOEHhgAUC2QAlkGNAIe+3gDa/SoAayW2AHuJNAAF8/4Aub+eAGhqTwBKKqgAT8RaAC34vADXWpgA9MeVAA1NjQAgOqYApFdfABQ/sQCAOJUAzCABAHHdhgDJ3rYAv2D1AE1lEQABB2sAjLCsALLA0ABRVUgAHvsOAJVywwCjBjsAwEA1AAbcewDgRcwATin6ANbKyADo80EAfGTeAJtk2ADZvjEApJfDAHdY1ABp48UA8NoTALo6PABGGEYAVXVfANK99QBuksYArC5dAA5E7QAcPkIAYcSHACn96QDn1vMAInzKAG+RNQAI4MUA/9eNAG5q4gCw/cYAkwjBAHxddABrrbIAzW6dAD5yewDGEWoA98+pAClz3wC1yboAtwBRAOKyDQB0uiQA5X1gAHTYigANFSwAgRgMAH5mlAABKRYAn3p2AP39vgBWRe8A2X42AOzZEwCLurkAxJf8ADGoJwDxbsMAlMU2ANioVgC0qLUAz8wOABKJLQBvVzQALFaJAJnO4wDWILkAa16qAD4qnAARX8wA/QtKAOH0+wCOO20A4oYsAOnUhAD8tKkA7+7RAC41yQAvOWEAOCFEABvZyACB/AoA+0pqAC8c2ABTtIQATpmMAFQizAAqVdwAwMbWAAsZlgAacLgAaZVkACZaYAA/Uu4AfxEPAPS1EQD8y/UANLwtADS87gDoXcwA3V5gAGeOmwCSM+8AyRe4AGFYmwDhV7wAUYPGANg+EADdcUgALRzdAK8YoQAhLEYAWfPXANl6mACeVMAAT4b6AFYG/ADlea4AiSI2ADitIgBnk9wAVeiqAIImOADK55sAUQ2kAJkzsQCp1w4AaQVIAGWy8AB/iKcAiEyXAPnRNgAhkrMAe4JKAJjPIQBAn9wA3EdVAOF0OgBn60IA/p3fAF7UXwB7Z6QAuqx6AFX2ogAriCMAQbpVAFluCAAhKoYAOUeDAInj5gDlntQASftAAP9W6QAcD8oAxVmKAJT6KwDTwcUAD8XPANtargBHxYYAhUNiACGGOwAseZQAEGGHACpMewCALBoAQ78SAIgmkAB4PIkAqMTkAOXbewDEOsIAJvTqAPdnigANkr8AZaMrAD2TsQC9fAsApFHcACfdYwBp4d0AmpQZAKgplQBozigACe20AESfIABOmMoAcIJjAH58IwAPuTIAp/WOABRW5wAh8QgAtZ0qAG9+TQClGVEAtfmrAILf1gCW3WEAFjYCAMQ6nwCDoqEAcu1tADmNegCCuKkAazJcAEYnWwAANO0A0gB3APz0VQABWU0A4HGAAEGzkxMLfkD7Ifk/AAAAAC1EdD4AAACAmEb4PAAAAGBRzHg7AAAAgIMb8DkAAABAICV6OAAAAIAiguM2AAAAAB3zaTUZAAoAGRkZAAAAAAUAAAAAAAAJAAAAAAsAAAAAAAAAABkAEQoZGRkDCgcAAQAJCxgAAAkGCwAACwAGGQAAABkZGQBBwZQTCyEOAAAAAAAAAAAZAAoNGRkZAA0AAAIACQ4AAAAJAA4AAA4AQfuUEwsBDABBh5UTCxUTAAAAABMAAAAACQwAAAAAAAwAAAwAQbWVEwsBEABBwZUTCxUPAAAABA8AAAAACRAAAAAAABAAABAAQe+VEwsBEgBB+5UTCx4RAAAAABEAAAAACRIAAAAAABIAABIAABoAAAAaGhoAQbKWEwsOGgAAABoaGgAAAAAAAAkAQeOWEwsBFABB75YTCxUXAAAAABcAAAAACRQAAAAAABQAABQAQZ2XEwsBFgBBqZcTC/8CFQAAAAAVAAAAAAkWAAAAAAAWAAAWAAAwMTIzNDU2Nzg5QUJDREVG/////////////////////////////////////////////////////////////////wABAgMEBQYHCAn/////////CgsMDQ4PEBESExQVFhcYGRobHB0eHyAhIiP///////8KCwwNDg8QERITFBUWFxgZGhscHR4fICEiI///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////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",Ri(Oi)||(Oi=R(Oi));function gn(u){if(u==Oi&&B)return new Uint8Array(B);var V=CX(u);if(V)return V;if(N)return N(u);throw"both async and sync fetching of the wasm failed"}function De(u){return Promise.resolve().then(()=>gn(u))}function Ye(u,V,W){return De(u).then(P=>WebAssembly.instantiate(P,V)).then(P=>P).then(W,P=>{F("failed to asynchronously prepare wasm: "+P),si(Oi)&&F("warning: Loading from a file URI ("+Oi+") is not supported in most browsers. See https://emscripten.org/docs/getting_started/FAQ.html#how-do-i-run-a-local-webserver-for-testing-why-does-my-program-stall-in-downloading-or-preparing"),Be(P)})}function Gi(u,V,W,P){return Ye(V,W,P)}function An(){var u={env:wG,wasi_snapshot_preview1:wG};function V($,ht){var dt=$.exports;return M=dt,Q=M.memory,c(Q,"memory not found in wasm exports"),tt(),G=M.__indirect_function_table,c(G,"table not found in wasm exports"),ce(M.__wasm_call_ctors),ze("wasm-instantiate"),dt}ni("wasm-instantiate");var W=i;function P($){c(i===W,"the Module object should not be replaced during async compilation - perhaps the order of HTML elements is wrong?"),W=null,V($.instance)}if(i.instantiateWasm)try{return i.instantiateWasm(u,V)}catch($){F("Module.instantiateWasm callback failed with error: "+$),s($)}return Gi(B,Oi,u,P).catch(s),{}}var Ne,ei;function _n(u,V,W=!0){Object.getOwnPropertyDescriptor(i,u)||Object.defineProperty(i,u,{configurable:!0,get(){let P=W?" (the initial value can be provided on Module, but after startup the value is only looked for on a local variable of that name)":"";Be(`\`Module.${u}\` has been replaced by \`${V}\``+P)}})}function hs(u){Object.getOwnPropertyDescriptor(i,u)&&Be(`\`Module.${u}\` was supplied but \`${u}\` not included in INCOMING_MODULE_JS_API`)}function Qi(u){return u==="FS_createPath"||u==="FS_createDataFile"||u==="FS_createPreloadedFile"||u==="FS_unlink"||u==="addRunDependency"||u==="FS_createLazyFile"||u==="FS_createDevice"||u==="removeRunDependency"}function nn(u,V){typeof globalThis<"u"&&Object.defineProperty(globalThis,u,{configurable:!0,get(){Ai("`"+u+"` is not longer defined by emscripten. "+V)}})}nn("buffer","Please use HEAP8.buffer or wasmMemory.buffer");function ki(u){typeof globalThis<"u"&&!Object.getOwnPropertyDescriptor(globalThis,u)&&Object.defineProperty(globalThis,u,{configurable:!0,get(){var V="`"+u+"` is a library symbol and not included by default; add it to your library.js __deps or to DEFAULT_LIBRARY_FUNCS_TO_INCLUDE on the command line",W=u;W.startsWith("_")||(W="$"+u),V+=" (e.g. -sDEFAULT_LIBRARY_FUNCS_TO_INCLUDE='"+W+"')",Qi(u)&&(V+=". Alternatively, forcing filesystem support (-sFORCE_FILESYSTEM) can export this for you"),Ai(V)}}),sn(u)}function sn(u){Object.getOwnPropertyDescriptor(i,u)||Object.defineProperty(i,u,{configurable:!0,get(){var V="'"+u+"' was not exported. add it to EXPORTED_RUNTIME_METHODS (see the Emscripten FAQ)";Qi(u)&&(V+=". Alternatively, forcing filesystem support (-sFORCE_FILESYSTEM) can export this for you"),Be(V)}})}var Cs={328460:()=>{console.log("no show")}};function cs(u){this.name="ExitStatus",this.message=`Program terminated with exit(${u})`,this.status=u}var xn=u=>{for(;u.length>0;)u.shift()(i)},Pn=u=>(c(typeof u=="number"),u>>>=0,"0x"+u.toString(16).padStart(8,"0")),Ai=u=>{Ai.shown||(Ai.shown={}),Ai.shown[u]||(Ai.shown[u]=1,F(u))};function Ci(u){this.excPtr=u,this.ptr=u-24,this.set_type=function(V){H[this.ptr+4>>2]=V},this.get_type=function(){return H[this.ptr+4>>2]},this.set_destructor=function(V){H[this.ptr+8>>2]=V},this.get_destructor=function(){return H[this.ptr+8>>2]},this.set_caught=function(V){V=V?1:0,g[this.ptr+12>>0]=V},this.get_caught=function(){return g[this.ptr+12>>0]!=0},this.set_rethrown=function(V){V=V?1:0,g[this.ptr+13>>0]=V},this.get_rethrown=function(){return g[this.ptr+13>>0]!=0},this.init=function(V,W){this.set_adjusted_ptr(0),this.set_type(V),this.set_destructor(W)},this.set_adjusted_ptr=function(V){H[this.ptr+16>>2]=V},this.get_adjusted_ptr=function(){return H[this.ptr+16>>2]},this.get_exception_ptr=function(){var V=pX(this.get_type());if(V)return H[this.excPtr>>2];var W=this.get_adjusted_ptr();return W!==0?W:this.excPtr}}var Jn=0,ls=0;function ao(u,V,W){var P=new Ci(u);P.init(V,W),Jn=u,ls++,c(!1,"Exception thrown, but exception catching is not enabled. Compile with -sNO_DISABLE_EXCEPTION_CATCHING or -sEXCEPTION_CATCHING_ALLOWED=[..] to catch.")}function qi(u,V,W,P,$){}function hn(u){switch(u){case 1:return 0;case 2:return 1;case 4:return 2;case 8:return 3;default:throw new TypeError(`Unknown type size: ${u}`)}}function jo(){for(var u=new Array(256),V=0;V<256;++V)u[V]=String.fromCharCode(V);ds=u}var ds=void 0;function on(u){for(var V="",W=u;O[W];)V+=ds[O[W++]];return V}var ws={},Vo={},br={},So=void 0;function $e(u){throw new So(u)}var aa=void 0;function Yr(u){throw new aa(u)}function xs(u,V,W){u.forEach(function(ft){br[ft]=V});function P(ft){var Gt=W(ft);Gt.length!==u.length&&Yr("Mismatched type converter count");for(var Lt=0;Lt<u.length;++Lt)Tn(u[Lt],Gt[Lt])}var $=new Array(V.length),ht=[],dt=0;V.forEach((ft,Gt)=>{Vo.hasOwnProperty(ft)?$[Gt]=Vo[ft]:(ht.push(ft),ws.hasOwnProperty(ft)||(ws[ft]=[]),ws[ft].push(()=>{$[Gt]=Vo[ft],++dt,dt===ht.length&&P($)}))}),ht.length===0&&P($)}function gs(u,V,W={}){var P=V.name;if(u||$e(`type "${P}" must have a positive integer typeid pointer`),Vo.hasOwnProperty(u)){if(W.ignoreDuplicateRegistrations)return;$e(`Cannot register type '${P}' twice`)}if(Vo[u]=V,delete br[u],ws.hasOwnProperty(u)){var $=ws[u];delete ws[u],$.forEach(ht=>ht())}}function Tn(u,V,W={}){if(!("argPackAdvance"in V))throw new TypeError("registerType registeredInstance requires argPackAdvance");return gs(u,V,W)}function hr(u,V,W,P,$){var ht=hn(W);V=on(V),Tn(u,{name:V,fromWireType:function(dt){return!!dt},toWireType:function(dt,ft){return ft?P:$},argPackAdvance:8,readValueFromPointer:function(dt){var ft;if(W===1)ft=g;else if(W===2)ft=D;else if(W===4)ft=x;else throw new TypeError("Unknown boolean type size: "+V);return this.fromWireType(ft[dt>>ht])},destructorFunction:null})}function Uh(u){if(!(this instanceof mr)||!(u instanceof mr))return!1;for(var V=this.$$.ptrType.registeredClass,W=this.$$.ptr,P=u.$$.ptrType.registeredClass,$=u.$$.ptr;V.baseClass;)W=V.upcast(W),V=V.baseClass;for(;P.baseClass;)$=P.upcast($),P=P.baseClass;return V===P&&W===$}function Mh(u){return{count:u.count,deleteScheduled:u.deleteScheduled,preservePointerOnDelete:u.preservePointerOnDelete,ptr:u.ptr,ptrType:u.ptrType,smartPtr:u.smartPtr,smartPtrType:u.smartPtrType}}function On(u){function V(W){return W.$$.ptrType.registeredClass.name}$e(V(u)+" instance already deleted")}var cr=!1;function Ii(u){}function Oo(u){u.smartPtr?u.smartPtrType.rawDestructor(u.smartPtr):u.ptrType.registeredClass.rawDestructor(u.ptr)}function Kc(u){u.count.value-=1;var V=u.count.value===0;V&&Oo(u)}function Xc(u,V,W){if(V===W)return u;if(W.baseClass===void 0)return null;var P=Xc(u,V,W.baseClass);return P===null?null:W.downcast(P)}var qc={};function Qh(){return Object.keys(Xa).length}function kh(){var u=[];for(var V in Xa)Xa.hasOwnProperty(V)&&u.push(Xa[V]);return u}var Aa=[];function Lh(){for(;Aa.length;){var u=Aa.pop();u.$$.deleteScheduled=!1,u.delete()}}var ha=void 0;function Ka(u){ha=u,Aa.length&&ha&&ha(Lh)}function Vd(){i.getInheritedInstanceCount=Qh,i.getLiveInheritedInstances=kh,i.flushPendingDeletes=Lh,i.setDelayFunction=Ka}var Xa={};function Sd(u,V){for(V===void 0&&$e("ptr should not be undefined");u.baseClass;)V=u.upcast(V),u=u.baseClass;return V}function qa(u,V){return V=Sd(u,V),Xa[V]}function lr(u,V){(!V.ptrType||!V.ptr)&&Yr("makeClassHandle requires ptr and ptrType");var W=!!V.smartPtrType,P=!!V.smartPtr;return W!==P&&Yr("Both smartPtrType and smartPtr must be specified"),V.count={value:1},$a(Object.create(u,{$$:{value:V}}))}function kA(u){var V=this.getPointee(u);if(!V)return this.destructor(u),null;var W=qa(this.registeredClass,V);if(W!==void 0){if(W.$$.count.value===0)return W.$$.ptr=V,W.$$.smartPtr=u,W.clone();var P=W.clone();return this.destructor(u),P}function $(){return this.isSmartPointer?lr(this.registeredClass.instancePrototype,{ptrType:this.pointeeType,ptr:V,smartPtrType:this,smartPtr:u}):lr(this.registeredClass.instancePrototype,{ptrType:this,ptr:u})}var ht=this.registeredClass.getActualType(V),dt=qc[ht];if(!dt)return $.call(this);var ft;this.isConst?ft=dt.constPointerType:ft=dt.pointerType;var Gt=Xc(V,this.registeredClass,ft.registeredClass);return Gt===null?$.call(this):this.isSmartPointer?lr(ft.registeredClass.instancePrototype,{ptrType:ft,ptr:Gt,smartPtrType:this,smartPtr:u}):lr(ft.registeredClass.instancePrototype,{ptrType:ft,ptr:Gt})}var $a=function(u){return typeof FinalizationRegistry>"u"?($a=V=>V,u):(cr=new FinalizationRegistry(V=>{console.warn(V.leakWarning.stack.replace(/^Error: /,"")),Kc(V.$$)}),$a=V=>{var W=V.$$,P=!!W.smartPtr;if(P){var $={$$:W},ht=W.ptrType.registeredClass;$.leakWarning=new Error(`Embind found a leaked C++ instance ${ht.name} <${Pn(W.ptr)}>.
We'll free it automatically in this case, but this functionality is not reliable across various environments.
Make sure to invoke .delete() manually once you're done with the instance instead.
Originally allocated`),"captureStackTrace"in Error&&Error.captureStackTrace($.leakWarning,kA),cr.register(V,$,V)}return V},Ii=V=>cr.unregister(V),$a(u))};function Od(){if(this.$$.ptr||On(this),this.$$.preservePointerOnDelete)return this.$$.count.value+=1,this;var u=$a(Object.create(Object.getPrototypeOf(this),{$$:{value:Mh(this.$$)}}));return u.$$.count.value+=1,u.$$.deleteScheduled=!1,u}function dr(){this.$$.ptr||On(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&$e("Object already scheduled for deletion"),Ii(this),Kc(this.$$),this.$$.preservePointerOnDelete||(this.$$.smartPtr=void 0,this.$$.ptr=void 0)}function $c(){return!this.$$.ptr}function tl(){return this.$$.ptr||On(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&$e("Object already scheduled for deletion"),Aa.push(this),Aa.length===1&&ha&&ha(Lh),this.$$.deleteScheduled=!0,this}function yh(){mr.prototype.isAliasOf=Uh,mr.prototype.clone=Od,mr.prototype.delete=dr,mr.prototype.isDeleted=$c,mr.prototype.deleteLater=tl}function mr(){}var wh=48,Bd=57;function xh(u){if(u===void 0)return"_unknown";u=u.replace(/[^a-zA-Z0-9_]/g,"$");var V=u.charCodeAt(0);return V>=wh&&V<=Bd?`_${u}`:u}function Ph(u,V){return u=xh(u),{[u]:function(){return V.apply(this,arguments)}}[u]}function el(u,V,W){if(u[V].overloadTable===void 0){var P=u[V];u[V]=function(){return u[V].overloadTable.hasOwnProperty(arguments.length)||$e(`Function '${W}' called with an invalid number of arguments (${arguments.length}) - expects one of (${u[V].overloadTable})!`),u[V].overloadTable[arguments.length].apply(this,arguments)},u[V].overloadTable=[],u[V].overloadTable[P.argCount]=P}}function il(u,V,W){i.hasOwnProperty(u)?((W===void 0||i[u].overloadTable!==void 0&&i[u].overloadTable[W]!==void 0)&&$e(`Cannot register public name '${u}' twice`),el(i,u,u),i.hasOwnProperty(W)&&$e(`Cannot register multiple overloads of a function with the same number of arguments (${W})!`),i[u].overloadTable[W]=V):(i[u]=V,W!==void 0&&(i[u].numArguments=W))}function Gd(u,V,W,P,$,ht,dt,ft){this.name=u,this.constructor=V,this.instancePrototype=W,this.rawDestructor=P,this.baseClass=$,this.getActualType=ht,this.upcast=dt,this.downcast=ft,this.pureVirtualFunctions=[]}function tA(u,V,W){for(;V!==W;)V.upcast||$e(`Expected null or instance of ${W.name}, got an instance of ${V.name}`),u=V.upcast(u),V=V.baseClass;return u}function Wd(u,V){if(V===null)return this.isReference&&$e(`null is not a valid ${this.name}`),0;V.$$||$e(`Cannot pass "${la(V)}" as a ${this.name}`),V.$$.ptr||$e(`Cannot pass deleted object as a pointer of type ${this.name}`);var W=V.$$.ptrType.registeredClass,P=tA(V.$$.ptr,W,this.registeredClass);return P}function Dd(u,V){var W;if(V===null)return this.isReference&&$e(`null is not a valid ${this.name}`),this.isSmartPointer?(W=this.rawConstructor(),u!==null&&u.push(this.rawDestructor,W),W):0;V.$$||$e(`Cannot pass "${la(V)}" as a ${this.name}`),V.$$.ptr||$e(`Cannot pass deleted object as a pointer of type ${this.name}`),!this.isConst&&V.$$.ptrType.isConst&&$e(`Cannot convert argument of type ${V.$$.smartPtrType?V.$$.smartPtrType.name:V.$$.ptrType.name} to parameter type ${this.name}`);var P=V.$$.ptrType.registeredClass;if(W=tA(V.$$.ptr,P,this.registeredClass),this.isSmartPointer)switch(V.$$.smartPtr===void 0&&$e("Passing raw pointer to smart pointer is illegal"),this.sharingPolicy){case 0:V.$$.smartPtrType===this?W=V.$$.smartPtr:$e(`Cannot convert argument of type ${V.$$.smartPtrType?V.$$.smartPtrType.name:V.$$.ptrType.name} to parameter type ${this.name}`);break;case 1:W=V.$$.smartPtr;break;case 2:if(V.$$.smartPtrType===this)W=V.$$.smartPtr;else{var $=V.clone();W=this.rawShare(W,Bo.toHandle(function(){$.delete()})),u!==null&&u.push(this.rawDestructor,W)}break;default:$e("Unsupporting sharing policy")}return W}function Ud(u,V){if(V===null)return this.isReference&&$e(`null is not a valid ${this.name}`),0;V.$$||$e(`Cannot pass "${la(V)}" as a ${this.name}`),V.$$.ptr||$e(`Cannot pass deleted object as a pointer of type ${this.name}`),V.$$.ptrType.isConst&&$e(`Cannot convert argument of type ${V.$$.ptrType.name} to parameter type ${this.name}`);var W=V.$$.ptrType.registeredClass,P=tA(V.$$.ptr,W,this.registeredClass);return P}function LA(u){return this.fromWireType(x[u>>2])}function eA(u){return this.rawGetPointee&&(u=this.rawGetPointee(u)),u}function Md(u){this.rawDestructor&&this.rawDestructor(u)}function Qd(u){u!==null&&u.delete()}function yA(){Ho.prototype.getPointee=eA,Ho.prototype.destructor=Md,Ho.prototype.argPackAdvance=8,Ho.prototype.readValueFromPointer=LA,Ho.prototype.deleteObject=Qd,Ho.prototype.fromWireType=kA}function Ho(u,V,W,P,$,ht,dt,ft,Gt,Lt,re){this.name=u,this.registeredClass=V,this.isReference=W,this.isConst=P,this.isSmartPointer=$,this.pointeeType=ht,this.sharingPolicy=dt,this.rawGetPointee=ft,this.rawConstructor=Gt,this.rawShare=Lt,this.rawDestructor=re,!$&&V.baseClass===void 0?P?(this.toWireType=Wd,this.destructorFunction=null):(this.toWireType=Ud,this.destructorFunction=null):this.toWireType=Dd}function nl(u,V,W){i.hasOwnProperty(u)||Yr("Replacing nonexistant public symbol"),i[u].overloadTable!==void 0&&W!==void 0?i[u].overloadTable[W]=V:(i[u]=V,i[u].argCount=W)}var vo=(u,V,W)=>{c("dynCall_"+u in i,`bad function pointer type - dynCall function not found for sig '${u}'`),W&&W.length?c(W.length===u.substring(1).replace(/j/g,"--").length):c(u.length==1);var P=i["dynCall_"+u];return W&&W.length?P.apply(null,[V].concat(W)):P.call(null,V)},iA=[],Jh=u=>{var V=iA[u];return V||(u>=iA.length&&(iA.length=u+1),iA[u]=V=G.get(u)),c(G.get(u)==V,"JavaScript-side Wasm function table mirror is out of date!"),V},kd=(u,V,W)=>{if(u.includes("j"))return vo(u,V,W);c(Jh(V),`missing table entry in dynCall: ${V}`);var P=Jh(V).apply(null,W);return P},Ld=(u,V)=>{c(u.includes("j")||u.includes("p"),"getDynCaller should only be called with i64 sigs");var W=[];return function(){return W.length=0,Object.assign(W,arguments),kd(u,V,W)}};function jn(u,V){u=on(u);function W(){return u.includes("j")?Ld(u,V):Jh(V)}var P=W();return typeof P!="function"&&$e(`unknown function pointer with signature ${u}: ${V}`),P}function sl(u,V){var W=Ph(V,function(P){this.name=V,this.message=P;var $=new Error(P).stack;$!==void 0&&(this.stack=this.toString()+`
`+$.replace(/^Error(:[^\n]*)?\n/,""))});return W.prototype=Object.create(u.prototype),W.prototype.constructor=W,W.prototype.toString=function(){return this.message===void 0?this.name:`${this.name}: ${this.message}`},W}var jh=void 0;function nA(u){var V=mX(u),W=on(V);return HA(V),W}function ca(u,V){var W=[],P={};function $(ht){if(!P[ht]&&!Vo[ht]){if(br[ht]){br[ht].forEach($);return}W.push(ht),P[ht]=!0}}throw V.forEach($),new jh(`${u}: `+W.map(nA).join([", "]))}function Hh(u,V,W,P,$,ht,dt,ft,Gt,Lt,re,ue,fe){re=on(re),ht=jn($,ht),ft&&(ft=jn(dt,ft)),Lt&&(Lt=jn(Gt,Lt)),fe=jn(ue,fe);var Ee=xh(re);il(Ee,function(){ca(`Cannot construct ${re} due to unbound types`,[P])}),xs([u,V,W],P?[P]:[],function(Ve){Ve=Ve[0];var di,ln;P?(di=Ve.registeredClass,ln=di.instancePrototype):ln=mr.prototype;var Rn=Ph(Ee,function(){if(Object.getPrototypeOf(this)!==qt)throw new So("Use 'new' to construct "+re);if(be.constructor_body===void 0)throw new So(re+" has no accessible constructor");var ms=be.constructor_body[arguments.length];if(ms===void 0)throw new So(`Tried to invoke ctor of ${re} with invalid number of parameters (${arguments.length}) - expected (${Object.keys(be.constructor_body).toString()}) parameters instead!`);return ms.apply(this,arguments)}),qt=Object.create(ln,{constructor:{value:Rn}});Rn.prototype=qt;var be=new Gd(re,Rn,qt,fe,di,ht,ft,Lt);be.baseClass&&(be.baseClass.__derivedClasses===void 0&&(be.baseClass.__derivedClasses=[]),be.baseClass.__derivedClasses.push(be));var Ts=new Ho(re,be,!0,!1,!1),Zn=new Ho(re+"*",be,!1,!1,!1),Ko=new Ho(re+" const*",be,!1,!0,!1);return qc[u]={pointerType:Zn,constPointerType:Ko},nl(Ee,Rn),[Ts,Zn,Ko]})}function vh(u,V){for(var W=[],P=0;P<u;P++)W.push(H[V+P*4>>2]);return W}function wA(u){for(;u.length;){var V=u.pop(),W=u.pop();W(V)}}function ol(u,V){if(!(u instanceof Function))throw new TypeError(`new_ called with constructor type ${typeof u} which is not a function`);var W=Ph(u.name||"unknownFunctionName",function(){});W.prototype=u.prototype;var P=new W,$=u.apply(P,V);return $ instanceof Object?$:P}function zh(u,V,W,P,$,ht){var dt=V.length;dt<2&&$e("argTypes array size mismatch! Must at least get return value and 'this' types!"),c(!ht,"Async bindings are only supported with JSPI.");for(var ft=V[1]!==null&&W!==null,Gt=!1,Lt=1;Lt<V.length;++Lt)if(V[Lt]!==null&&V[Lt].destructorFunction===void 0){Gt=!0;break}for(var re=V[0].name!=="void",ue="",fe="",Lt=0;Lt<dt-2;++Lt)ue+=(Lt!==0?", ":"")+"arg"+Lt,fe+=(Lt!==0?", ":"")+"arg"+Lt+"Wired";var Ee=`
        return function ${xh(u)}(${ue}) {
        if (arguments.length !== ${dt-2}) {
          throwBindingError('function ${u} called with ${arguments.length} arguments, expected ${dt-2} args!');
        }`;Gt&&(Ee+=`var destructors = [];
`);var Ve=Gt?"destructors":"null",di=["throwBindingError","invoker","fn","runDestructors","retType","classParam"],ln=[$e,P,$,wA,V[0],V[1]];ft&&(Ee+="var thisWired = classParam.toWireType("+Ve+`, this);
`);for(var Lt=0;Lt<dt-2;++Lt)Ee+="var arg"+Lt+"Wired = argType"+Lt+".toWireType("+Ve+", arg"+Lt+"); // "+V[Lt+2].name+`
`,di.push("argType"+Lt),ln.push(V[Lt+2]);if(ft&&(fe="thisWired"+(fe.length>0?", ":"")+fe),Ee+=(re||ht?"var rv = ":"")+"invoker(fn"+(fe.length>0?", ":"")+fe+`);
`,Gt)Ee+=`runDestructors(destructors);
`;else for(var Lt=ft?1:2;Lt<V.length;++Lt){var Rn=Lt===1?"thisWired":"arg"+(Lt-2)+"Wired";V[Lt].destructorFunction!==null&&(Ee+=Rn+"_dtor("+Rn+"); // "+V[Lt].name+`
`,di.push(Rn+"_dtor"),ln.push(V[Lt].destructorFunction))}return re&&(Ee+=`var ret = retType.fromWireType(rv);
return ret;
`),Ee+=`}
`,di.push(Ee),ol(Function,di).apply(null,ln)}function yd(u,V,W,P,$,ht){c(V>0);var dt=vh(V,W);$=jn(P,$),xs([],[u],function(ft){ft=ft[0];var Gt=`constructor ${ft.name}`;if(ft.registeredClass.constructor_body===void 0&&(ft.registeredClass.constructor_body=[]),ft.registeredClass.constructor_body[V-1]!==void 0)throw new So(`Cannot register multiple constructors with identical number of parameters (${V-1}) for class '${ft.name}'! Overload resolution is currently only performed using the parameter count, not actual type info!`);return ft.registeredClass.constructor_body[V-1]=()=>{ca(`Cannot construct ${ft.name} due to unbound types`,dt)},xs([],dt,function(Lt){return Lt.splice(1,0,null),ft.registeredClass.constructor_body[V-1]=zh(Gt,Lt,null,$,ht),[]}),[]})}function Kh(u,V,W,P,$,ht,dt,ft,Gt){var Lt=vh(W,P);V=on(V),ht=jn($,ht),xs([],[u],function(re){re=re[0];var ue=`${re.name}.${V}`;V.startsWith("@@")&&(V=Symbol[V.substring(2)]),ft&&re.registeredClass.pureVirtualFunctions.push(V);function fe(){ca(`Cannot call ${ue} due to unbound types`,Lt)}var Ee=re.registeredClass.instancePrototype,Ve=Ee[V];return Ve===void 0||Ve.overloadTable===void 0&&Ve.className!==re.name&&Ve.argCount===W-2?(fe.argCount=W-2,fe.className=re.name,Ee[V]=fe):(el(Ee,V,ue),Ee[V].overloadTable[W-2]=fe),xs([],Lt,function(di){var ln=zh(ue,di,re,ht,dt,Gt);return Ee[V].overloadTable===void 0?(ln.argCount=W-2,Ee[V]=ln):Ee[V].overloadTable[W-2]=ln,[]}),[]})}function Vs(u,V,W){return u instanceof Object||$e(`${W} with invalid "this": ${u}`),u instanceof V.registeredClass.constructor||$e(`${W} incompatible with "this" of type ${u.constructor.name}`),u.$$.ptr||$e(`cannot call emscripten binding method ${W} on deleted object`),tA(u.$$.ptr,u.$$.ptrType.registeredClass,V.registeredClass)}function Xh(u,V,W,P,$,ht,dt,ft,Gt,Lt){V=on(V),$=jn(P,$),xs([],[u],function(re){re=re[0];var ue=`${re.name}.${V}`,fe={get(){ca(`Cannot access ${ue} due to unbound types`,[W,dt])},enumerable:!0,configurable:!0};return Gt?fe.set=()=>{ca(`Cannot access ${ue} due to unbound types`,[W,dt])}:fe.set=Ee=>{$e(ue+" is a read-only property")},Object.defineProperty(re.registeredClass.instancePrototype,V,fe),xs([],Gt?[W,dt]:[W],function(Ee){var Ve=Ee[0],di={get(){var Rn=Vs(this,re,ue+" getter");return Ve.fromWireType($(ht,Rn))},enumerable:!0};if(Gt){Gt=jn(ft,Gt);var ln=Ee[1];di.set=function(Rn){var qt=Vs(this,re,ue+" setter"),be=[];Gt(Lt,qt,ln.toWireType(be,Rn)),wA(be)}}return Object.defineProperty(re.registeredClass.instancePrototype,V,di),[]}),[]})}function wd(){Object.assign(rl.prototype,{get(u){return c(this.allocated[u]!==void 0,`invalid handle: ${u}`),this.allocated[u]},has(u){return this.allocated[u]!==void 0},allocate(u){var V=this.freelist.pop()||this.allocated.length;return this.allocated[V]=u,V},free(u){c(this.allocated[u]!==void 0),this.allocated[u]=void 0,this.freelist.push(u)}})}function rl(){this.allocated=[void 0],this.freelist=[]}var Ao=new rl;function ho(u){u>=Ao.reserved&&--Ao.get(u).refcount===0&&Ao.free(u)}function xd(){for(var u=0,V=Ao.reserved;V<Ao.allocated.length;++V)Ao.allocated[V]!==void 0&&++u;return u}function Pd(){Ao.allocated.push({value:void 0},{value:null},{value:!0},{value:!1}),Ao.reserved=Ao.allocated.length,i.count_emval_handles=xd}var Bo={toValue:u=>(u||$e("Cannot use deleted val. handle = "+u),Ao.get(u).value),toHandle:u=>{switch(u){case void 0:return 1;case null:return 2;case!0:return 3;case!1:return 4;default:return Ao.allocate({refcount:1,value:u})}}};function xA(u,V){V=on(V),Tn(u,{name:V,fromWireType:function(W){var P=Bo.toValue(W);return ho(W),P},toWireType:function(W,P){return Bo.toHandle(P)},argPackAdvance:8,readValueFromPointer:LA,destructorFunction:null})}function la(u){if(u===null)return"null";var V=typeof u;return V==="object"||V==="array"||V==="function"?u.toString():""+u}function da(u,V){switch(V){case 2:return function(W){return this.fromWireType(j[W>>2])};case 3:return function(W){return this.fromWireType(X[W>>3])};default:throw new TypeError("Unknown float type: "+u)}}function Jd(u,V,W){var P=hn(W);V=on(V),Tn(u,{name:V,fromWireType:function($){return $},toWireType:function($,ht){if(typeof ht!="number"&&typeof ht!="boolean")throw new TypeError(`Cannot convert ${la(ht)} to ${this.name}`);return ht},argPackAdvance:8,readValueFromPointer:da(V,P),destructorFunction:null})}function jd(u,V,W,P,$,ht,dt){var ft=vh(V,W);u=on(u),$=jn(P,$),il(u,function(){ca(`Cannot call ${u} due to unbound types`,ft)},V-1),xs([],ft,function(Gt){var Lt=[Gt[0],null].concat(Gt.slice(1));return nl(u,zh(u,Lt,null,$,ht,dt),V-1),[]})}function Hd(u,V,W){switch(V){case 0:return W?function($){return g[$]}:function($){return O[$]};case 1:return W?function($){return D[$>>1]}:function($){return w[$>>1]};case 2:return W?function($){return x[$>>2]}:function($){return H[$>>2]};default:throw new TypeError("Unknown integer type: "+u)}}function vd(u,V,W,P,$){V=on(V),$===-1&&($=4294967295);var ht=hn(W),dt=ue=>ue;if(P===0){var ft=32-8*W;dt=ue=>ue<<ft>>>ft}var Gt=V.includes("unsigned"),Lt=(ue,fe)=>{if(typeof ue!="number"&&typeof ue!="boolean")throw new TypeError(`Cannot convert "${la(ue)}" to ${fe}`);if(ue<P||ue>$)throw new TypeError(`Passing a number "${la(ue)}" from JS side to C/C++ side to an argument of type "${V}", which is outside the valid range [${P}, ${$}]!`)},re;Gt?re=function(ue,fe){return Lt(fe,this.name),fe>>>0}:re=function(ue,fe){return Lt(fe,this.name),fe},Tn(u,{name:V,fromWireType:dt,toWireType:re,argPackAdvance:8,readValueFromPointer:Hd(V,ht,P!==0),destructorFunction:null})}function zd(u,V,W){var P=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],$=P[V];function ht(dt){dt=dt>>2;var ft=H,Gt=ft[dt],Lt=ft[dt+1];return new $(ft.buffer,Lt,Gt)}W=on(W),Tn(u,{name:W,fromWireType:ht,argPackAdvance:8,readValueFromPointer:ht},{ignoreDuplicateRegistrations:!0})}var qh=(u,V,W,P)=>{if(c(typeof u=="string"),!(P>0))return 0;for(var $=W,ht=W+P-1,dt=0;dt<u.length;++dt){var ft=u.charCodeAt(dt);if(ft>=55296&&ft<=57343){var Gt=u.charCodeAt(++dt);ft=65536+((ft&1023)<<10)|Gt&1023}if(ft<=127){if(W>=ht)break;V[W++]=ft}else if(ft<=2047){if(W+1>=ht)break;V[W++]=192|ft>>6,V[W++]=128|ft&63}else if(ft<=65535){if(W+2>=ht)break;V[W++]=224|ft>>12,V[W++]=128|ft>>6&63,V[W++]=128|ft&63}else{if(W+3>=ht)break;ft>1114111&&Ai("Invalid Unicode code point "+Pn(ft)+" encountered when serializing a JS string to a UTF-8 string in wasm memory! (Valid unicode code points should be in range 0-0x10FFFF)."),V[W++]=240|ft>>18,V[W++]=128|ft>>12&63,V[W++]=128|ft>>6&63,V[W++]=128|ft&63}}return V[W]=0,W-$},PA=(u,V,W)=>(c(typeof W=="number","stringToUTF8(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),qh(u,O,V,W)),ma=u=>{for(var V=0,W=0;W<u.length;++W){var P=u.charCodeAt(W);P<=127?V++:P<=2047?V+=2:P>=55296&&P<=57343?(V+=4,++W):V+=3}return V},al=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,fa=(u,V,W)=>{for(var P=V+W,$=V;u[$]&&!($>=P);)++$;if($-V>16&&u.buffer&&al)return al.decode(u.subarray(V,$));for(var ht="";V<$;){var dt=u[V++];if(!(dt&128)){ht+=String.fromCharCode(dt);continue}var ft=u[V++]&63;if((dt&224)==192){ht+=String.fromCharCode((dt&31)<<6|ft);continue}var Gt=u[V++]&63;if((dt&240)==224?dt=(dt&15)<<12|ft<<6|Gt:((dt&248)!=240&&Ai("Invalid UTF-8 leading byte "+Pn(dt)+" encountered when deserializing a UTF-8 string in wasm memory to a JS string!"),dt=(dt&7)<<18|ft<<12|Gt<<6|u[V++]&63),dt<65536)ht+=String.fromCharCode(dt);else{var Lt=dt-65536;ht+=String.fromCharCode(55296|Lt>>10,56320|Lt&1023)}}return ht},Ea=(u,V)=>(c(typeof u=="number"),u?fa(O,u,V):"");function sA(u,V){V=on(V);var W=V==="std::string";Tn(u,{name:V,fromWireType:function(P){var $=H[P>>2],ht=P+4,dt;if(W)for(var ft=ht,Gt=0;Gt<=$;++Gt){var Lt=ht+Gt;if(Gt==$||O[Lt]==0){var re=Lt-ft,ue=Ea(ft,re);dt===void 0?dt=ue:(dt+="\0",dt+=ue),ft=Lt+1}}else{for(var fe=new Array($),Gt=0;Gt<$;++Gt)fe[Gt]=String.fromCharCode(O[ht+Gt]);dt=fe.join("")}return HA(P),dt},toWireType:function(P,$){$ instanceof ArrayBuffer&&($=new Uint8Array($));var ht,dt=typeof $=="string";dt||$ instanceof Uint8Array||$ instanceof Uint8ClampedArray||$ instanceof Int8Array||$e("Cannot pass non-string to std::string"),W&&dt?ht=ma($):ht=$.length;var ft=KR(4+ht+1),Gt=ft+4;if(H[ft>>2]=ht,W&&dt)PA($,Gt,ht+1);else if(dt)for(var Lt=0;Lt<ht;++Lt){var re=$.charCodeAt(Lt);re>255&&(HA(Gt),$e("String has UTF-16 code units that do not fit in 8 bits")),O[Gt+Lt]=re}else for(var Lt=0;Lt<ht;++Lt)O[Gt+Lt]=$[Lt];return P!==null&&P.push(HA,ft),ft},argPackAdvance:8,readValueFromPointer:LA,destructorFunction:function(P){HA(P)}})}var Al=typeof TextDecoder<"u"?new TextDecoder("utf-16le"):void 0,Kd=(u,V)=>{c(u%2==0,"Pointer passed to UTF16ToString must be aligned to two bytes!");for(var W=u,P=W>>1,$=P+V/2;!(P>=$)&&w[P];)++P;if(W=P<<1,W-u>32&&Al)return Al.decode(O.subarray(u,W));for(var ht="",dt=0;!(dt>=V/2);++dt){var ft=D[u+dt*2>>1];if(ft==0)break;ht+=String.fromCharCode(ft)}return ht},JA=(u,V,W)=>{if(c(V%2==0,"Pointer passed to stringToUTF16 must be aligned to two bytes!"),c(typeof W=="number","stringToUTF16(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),W===void 0&&(W=2147483647),W<2)return 0;W-=2;for(var P=V,$=W<u.length*2?W/2:u.length,ht=0;ht<$;++ht){var dt=u.charCodeAt(ht);D[V>>1]=dt,V+=2}return D[V>>1]=0,V-P},$h=u=>u.length*2,Xd=(u,V)=>{c(u%4==0,"Pointer passed to UTF32ToString must be aligned to four bytes!");for(var W=0,P="";!(W>=V/4);){var $=x[u+W*4>>2];if($==0)break;if(++W,$>=65536){var ht=$-65536;P+=String.fromCharCode(55296|ht>>10,56320|ht&1023)}else P+=String.fromCharCode($)}return P},hl=(u,V,W)=>{if(c(V%4==0,"Pointer passed to stringToUTF32 must be aligned to four bytes!"),c(typeof W=="number","stringToUTF32(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),W===void 0&&(W=2147483647),W<4)return 0;for(var P=V,$=P+W-4,ht=0;ht<u.length;++ht){var dt=u.charCodeAt(ht);if(dt>=55296&&dt<=57343){var ft=u.charCodeAt(++ht);dt=65536+((dt&1023)<<10)|ft&1023}if(x[V>>2]=dt,V+=4,V+4>$)break}return x[V>>2]=0,V-P},qd=u=>{for(var V=0,W=0;W<u.length;++W){var P=u.charCodeAt(W);P>=55296&&P<=57343&&++W,V+=4}return V},$d=function(u,V,W){W=on(W);var P,$,ht,dt,ft;V===2?(P=Kd,$=JA,dt=$h,ht=()=>w,ft=1):V===4&&(P=Xd,$=hl,dt=qd,ht=()=>H,ft=2),Tn(u,{name:W,fromWireType:function(Gt){for(var Lt=H[Gt>>2],re=ht(),ue,fe=Gt+4,Ee=0;Ee<=Lt;++Ee){var Ve=Gt+4+Ee*V;if(Ee==Lt||re[Ve>>ft]==0){var di=Ve-fe,ln=P(fe,di);ue===void 0?ue=ln:(ue+="\0",ue+=ln),fe=Ve+V}}return HA(Gt),ue},toWireType:function(Gt,Lt){typeof Lt!="string"&&$e(`Cannot pass non-string to C++ string type ${W}`);var re=dt(Lt),ue=KR(4+re+V);return H[ue>>2]=re>>ft,$(Lt,ue+4,re+V),Gt!==null&&Gt.push(HA,ue),ue},argPackAdvance:8,readValueFromPointer:LA,destructorFunction:function(Gt){HA(Gt)}})};function tm(u,V){V=on(V),Tn(u,{isVoid:!0,name:V,argPackAdvance:0,fromWireType:function(){},toWireType:function(W,P){}})}var em=!0,im=()=>em;function nm(u,V){var W=Vo[u];return W===void 0&&$e(V+" has unknown type "+nA(u)),W}function sm(u,V,W){u=Bo.toValue(u),V=nm(V,"emval::as");var P=[],$=Bo.toHandle(P);return H[W>>2]=$,V.toWireType(P,u)}function om(u,V){return u=Bo.toValue(u),V=Bo.toValue(V),Bo.toHandle(u[V])}var cl={};function rm(u){var V=cl[u];return V===void 0?on(u):V}function am(u){return Bo.toHandle(rm(u))}function Am(u){var V=Bo.toValue(u);wA(V),ho(u)}function ll(u,V){return c(u==u>>>0||u==(u|0)),c(V===(V|0)),V+2097152>>>0<4194305-!!u?(u>>>0)+V*4294967296:NaN}function hm(u,V,W){var P=ll(u,V),$=new Date(P*1e3);x[W>>2]=$.getUTCSeconds(),x[W+4>>2]=$.getUTCMinutes(),x[W+8>>2]=$.getUTCHours(),x[W+12>>2]=$.getUTCDate(),x[W+16>>2]=$.getUTCMonth(),x[W+20>>2]=$.getUTCFullYear()-1900,x[W+24>>2]=$.getUTCDay();var ht=Date.UTC($.getUTCFullYear(),0,1,0,0,0,0),dt=($.getTime()-ht)/(1e3*60*60*24)|0;x[W+28>>2]=dt}var oA=u=>u%4===0&&(u%100!==0||u%400===0),cm=[0,31,60,91,121,152,182,213,244,274,305,335],jA=[0,31,59,90,120,151,181,212,243,273,304,334],lm=u=>{var V=oA(u.getFullYear()),W=V?cm:jA,P=W[u.getMonth()]+u.getDate()-1;return P},dm=function(u){var V=(()=>{var W=new Date(x[u+20>>2]+1900,x[u+16>>2],x[u+12>>2],x[u+8>>2],x[u+4>>2],x[u>>2],0),P=x[u+32>>2],$=W.getTimezoneOffset(),ht=new Date(W.getFullYear(),0,1),dt=new Date(W.getFullYear(),6,1).getTimezoneOffset(),ft=ht.getTimezoneOffset(),Gt=Math.min(ft,dt);if(P<0)x[u+32>>2]=+(dt!=ft&&Gt==$);else if(P>0!=(Gt==$)){var Lt=Math.max(ft,dt),re=P>0?Gt:Lt;W.setTime(W.getTime()+(re-$)*6e4)}x[u+24>>2]=W.getDay();var ue=lm(W)|0;return x[u+28>>2]=ue,x[u>>2]=W.getSeconds(),x[u+4>>2]=W.getMinutes(),x[u+8>>2]=W.getHours(),x[u+12>>2]=W.getDate(),x[u+16>>2]=W.getMonth(),x[u+20>>2]=W.getYear(),W.getTime()/1e3})();return fX((Ne=V,+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)),V>>>0},dl=u=>{var V=ma(u)+1,W=KR(V);return W&&PA(u,W,V),W},mm=(u,V,W)=>{var P=new Date().getFullYear(),$=new Date(P,0,1),ht=new Date(P,6,1),dt=$.getTimezoneOffset(),ft=ht.getTimezoneOffset(),Gt=Math.max(dt,ft);H[u>>2]=Gt*60,x[V>>2]=+(dt!=ft);function Lt(Ve){var di=Ve.toTimeString().match(/\(([A-Za-z ]+)\)$/);return di?di[1]:"GMT"}var re=Lt($),ue=Lt(ht),fe=dl(re),Ee=dl(ue);ft<dt?(H[W>>2]=fe,H[W+4>>2]=Ee):(H[W>>2]=Ee,H[W+4>>2]=fe)},fm=()=>{Be("native code called abort()")},rA=[],fi=(u,V)=>{c(Array.isArray(rA)),c(V%16==0),rA.length=0;var W;for(V>>=2;W=O[u++];){var P=String.fromCharCode(W),$=["d","f","i"];c($.includes(P),`Invalid character ${W}("${P}") in readEmAsmArgs! Use only [${$}], and do not specify "v" for void return argument.`),V+=W!=105&V,rA.push(W==105?x[V]:X[V++>>1]),++V}return rA},z=(u,V,W)=>{var P=fi(V,W);return Cs.hasOwnProperty(u)||Be(`No EM_ASM constant found at address ${u}`),Cs[u].apply(null,P)},et=(u,V,W)=>z(u,V,W);function pt(){return Date.now()}var $t;$t=()=>performance.now();var ve=(u,V,W)=>O.copyWithin(u,V,V+W),hi=()=>2147483648,_a=u=>{var V=Q.buffer,W=u-V.byteLength+65535>>>16;try{return Q.grow(W),tt(),1}catch(P){F(`growMemory: Attempted to grow heap from ${V.byteLength} bytes to ${u} bytes, but got error: ${P}`)}},tc=u=>{var V=O.length;u>>>=0,c(u>V);var W=hi();if(u>W)return F(`Cannot enlarge memory, asked to go up to ${u} bytes, but the limit is ${W} bytes!`),!1;for(var P=(Gt,Lt)=>Gt+(Lt-Gt%Lt)%Lt,$=1;$<=4;$*=2){var ht=V*(1+.2/$);ht=Math.min(ht,u+100663296);var dt=Math.min(W,P(Math.max(u,ht),65536)),ft=_a(dt);if(ft)return!0}return F(`Failed to grow the heap from ${V} bytes to ${dt} bytes, not enough memory!`),!1},J=u=>{var V=(globalThis.eval["\u2003"]=globalThis.eval)(Ea(u));if(V==null)return 0;V+="";var W=J,P=ma(V);return(!W.bufferSize||W.bufferSize<P+1)&&(W.bufferSize&&HA(W.buffer),W.bufferSize=P+1,W.buffer=KR(W.bufferSize)),PA(V,W.buffer,W.bufferSize),W.buffer},v={},st=()=>a||"./this.program",Rt=()=>{if(!Rt.strings){var u=(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",V={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:u,_:st()};for(var W in v)v[W]===void 0?delete V[W]:V[W]=v[W];var P=[];for(var W in V)P.push(`${W}=${V[W]}`);Rt.strings=P}return Rt.strings},Vt=(u,V)=>{for(var W=0;W<u.length;++W)c(u.charCodeAt(W)===(u.charCodeAt(W)&255)),g[V++>>0]=u.charCodeAt(W);g[V>>0]=0},Bt={isAbs:u=>u.charAt(0)==="/",splitPath:u=>{var V=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;return V.exec(u).slice(1)},normalizeArray:(u,V)=>{for(var W=0,P=u.length-1;P>=0;P--){var $=u[P];$==="."?u.splice(P,1):$===".."?(u.splice(P,1),W++):W&&(u.splice(P,1),W--)}if(V)for(;W;W--)u.unshift("..");return u},normalize:u=>{var V=Bt.isAbs(u),W=u.substr(-1)==="/";return u=Bt.normalizeArray(u.split("/").filter(P=>!!P),!V).join("/"),!u&&!V&&(u="."),u&&W&&(u+="/"),(V?"/":"")+u},dirname:u=>{var V=Bt.splitPath(u),W=V[0],P=V[1];return!W&&!P?".":(P&&(P=P.substr(0,P.length-1)),W+P)},basename:u=>{if(u==="/")return"/";u=Bt.normalize(u),u=u.replace(/\/$/,"");var V=u.lastIndexOf("/");return V===-1?u:u.substr(V+1)},join:function(){var u=Array.prototype.slice.call(arguments);return Bt.normalize(u.join("/"))},join2:(u,V)=>Bt.normalize(u+"/"+V)},jt=()=>{if(typeof crypto=="object"&&typeof crypto.getRandomValues=="function")return u=>crypto.getRandomValues(u);Be("no cryptographic support found for randomDevice. consider polyfilling it if you want to use something insecure like Math.random(), e.g. put this in a --pre-js: var crypto = { getRandomValues: (array) => { for (var i = 0; i < array.length; i++) array[i] = (Math.random()*256)|0 } };")},Mt=u=>(Mt=jt())(u),Dt={resolve:function(){for(var u="",V=!1,W=arguments.length-1;W>=-1&&!V;W--){var P=W>=0?arguments[W]:K.cwd();if(typeof P!="string")throw new TypeError("Arguments to path.resolve must be strings");if(!P)return"";u=P+"/"+u,V=Bt.isAbs(P)}return u=Bt.normalizeArray(u.split("/").filter($=>!!$),!V).join("/"),(V?"/":"")+u||"."},relative:(u,V)=>{u=Dt.resolve(u).substr(1),V=Dt.resolve(V).substr(1);function W(Lt){for(var re=0;re<Lt.length&&Lt[re]==="";re++);for(var ue=Lt.length-1;ue>=0&&Lt[ue]==="";ue--);return re>ue?[]:Lt.slice(re,ue-re+1)}for(var P=W(u.split("/")),$=W(V.split("/")),ht=Math.min(P.length,$.length),dt=ht,ft=0;ft<ht;ft++)if(P[ft]!==$[ft]){dt=ft;break}for(var Gt=[],ft=dt;ft<P.length;ft++)Gt.push("..");return Gt=Gt.concat($.slice(dt)),Gt.join("/")}},pe=[];function Ge(u,V,W){var P=W>0?W:ma(u)+1,$=new Array(P),ht=qh(u,$,0,$.length);return V&&($.length=ht),$}var ci=()=>{if(!pe.length){var u=null;if(typeof window<"u"&&typeof window.prompt=="function"?(u=window.prompt("Input: "),u!==null&&(u+=`
`)):typeof readline=="function"&&(u=readline(),u!==null&&(u+=`
`)),!u)return null;pe=Ge(u,!0)}return pe.shift()},pi={ttys:[],init:function(){},shutdown:function(){},register:function(u,V){pi.ttys[u]={input:[],output:[],ops:V},K.registerDevice(u,pi.stream_ops)},stream_ops:{open:function(u){var V=pi.ttys[u.node.rdev];if(!V)throw new K.ErrnoError(43);u.tty=V,u.seekable=!1},close:function(u){u.tty.ops.fsync(u.tty)},fsync:function(u){u.tty.ops.fsync(u.tty)},read:function(u,V,W,P,$){if(!u.tty||!u.tty.ops.get_char)throw new K.ErrnoError(60);for(var ht=0,dt=0;dt<P;dt++){var ft;try{ft=u.tty.ops.get_char(u.tty)}catch{throw new K.ErrnoError(29)}if(ft===void 0&&ht===0)throw new K.ErrnoError(6);if(ft==null)break;ht++,V[W+dt]=ft}return ht&&(u.node.timestamp=Date.now()),ht},write:function(u,V,W,P,$){if(!u.tty||!u.tty.ops.put_char)throw new K.ErrnoError(60);try{for(var ht=0;ht<P;ht++)u.tty.ops.put_char(u.tty,V[W+ht])}catch{throw new K.ErrnoError(29)}return P&&(u.node.timestamp=Date.now()),ht}},default_tty_ops:{get_char:function(u){return ci()},put_char:function(u,V){V===null||V===10?(b(fa(u.output,0)),u.output=[]):V!=0&&u.output.push(V)},fsync:function(u){u.output&&u.output.length>0&&(b(fa(u.output,0)),u.output=[])},ioctl_tcgets:function(u){return{c_iflag:25856,c_oflag:5,c_cflag:191,c_lflag:35387,c_cc:[3,28,127,21,4,0,1,0,17,19,26,0,18,15,23,22,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]}},ioctl_tcsets:function(u,V,W){return 0},ioctl_tiocgwinsz:function(u){return[24,80]}},default_tty1_ops:{put_char:function(u,V){V===null||V===10?(F(fa(u.output,0)),u.output=[]):V!=0&&u.output.push(V)},fsync:function(u){u.output&&u.output.length>0&&(F(fa(u.output,0)),u.output=[])}}},cn=u=>{Be("internal error: mmapAlloc called but `emscripten_builtin_memalign` native symbol not exported")},Qe={ops_table:null,mount(u){return Qe.createNode(null,"/",16895,0)},createNode(u,V,W,P){if(K.isBlkdev(W)||K.isFIFO(W))throw new K.ErrnoError(63);Qe.ops_table||(Qe.ops_table={dir:{node:{getattr:Qe.node_ops.getattr,setattr:Qe.node_ops.setattr,lookup:Qe.node_ops.lookup,mknod:Qe.node_ops.mknod,rename:Qe.node_ops.rename,unlink:Qe.node_ops.unlink,rmdir:Qe.node_ops.rmdir,readdir:Qe.node_ops.readdir,symlink:Qe.node_ops.symlink},stream:{llseek:Qe.stream_ops.llseek}},file:{node:{getattr:Qe.node_ops.getattr,setattr:Qe.node_ops.setattr},stream:{llseek:Qe.stream_ops.llseek,read:Qe.stream_ops.read,write:Qe.stream_ops.write,allocate:Qe.stream_ops.allocate,mmap:Qe.stream_ops.mmap,msync:Qe.stream_ops.msync}},link:{node:{getattr:Qe.node_ops.getattr,setattr:Qe.node_ops.setattr,readlink:Qe.node_ops.readlink},stream:{}},chrdev:{node:{getattr:Qe.node_ops.getattr,setattr:Qe.node_ops.setattr},stream:K.chrdev_stream_ops}});var $=K.createNode(u,V,W,P);return K.isDir($.mode)?($.node_ops=Qe.ops_table.dir.node,$.stream_ops=Qe.ops_table.dir.stream,$.contents={}):K.isFile($.mode)?($.node_ops=Qe.ops_table.file.node,$.stream_ops=Qe.ops_table.file.stream,$.usedBytes=0,$.contents=null):K.isLink($.mode)?($.node_ops=Qe.ops_table.link.node,$.stream_ops=Qe.ops_table.link.stream):K.isChrdev($.mode)&&($.node_ops=Qe.ops_table.chrdev.node,$.stream_ops=Qe.ops_table.chrdev.stream),$.timestamp=Date.now(),u&&(u.contents[V]=$,u.timestamp=$.timestamp),$},getFileDataAsTypedArray(u){return u.contents?u.contents.subarray?u.contents.subarray(0,u.usedBytes):new Uint8Array(u.contents):new Uint8Array(0)},expandFileStorage(u,V){var W=u.contents?u.contents.length:0;if(!(W>=V)){var P=1024*1024;V=Math.max(V,W*(W<P?2:1.125)>>>0),W!=0&&(V=Math.max(V,256));var $=u.contents;u.contents=new Uint8Array(V),u.usedBytes>0&&u.contents.set($.subarray(0,u.usedBytes),0)}},resizeFileStorage(u,V){if(u.usedBytes!=V)if(V==0)u.contents=null,u.usedBytes=0;else{var W=u.contents;u.contents=new Uint8Array(V),W&&u.contents.set(W.subarray(0,Math.min(V,u.usedBytes))),u.usedBytes=V}},node_ops:{getattr(u){var V={};return V.dev=K.isChrdev(u.mode)?u.id:1,V.ino=u.id,V.mode=u.mode,V.nlink=1,V.uid=0,V.gid=0,V.rdev=u.rdev,K.isDir(u.mode)?V.size=4096:K.isFile(u.mode)?V.size=u.usedBytes:K.isLink(u.mode)?V.size=u.link.length:V.size=0,V.atime=new Date(u.timestamp),V.mtime=new Date(u.timestamp),V.ctime=new Date(u.timestamp),V.blksize=4096,V.blocks=Math.ceil(V.size/V.blksize),V},setattr(u,V){V.mode!==void 0&&(u.mode=V.mode),V.timestamp!==void 0&&(u.timestamp=V.timestamp),V.size!==void 0&&Qe.resizeFileStorage(u,V.size)},lookup(u,V){throw K.genericErrors[44]},mknod(u,V,W,P){return Qe.createNode(u,V,W,P)},rename(u,V,W){if(K.isDir(u.mode)){var P;try{P=K.lookupNode(V,W)}catch{}if(P)for(var $ in P.contents)throw new K.ErrnoError(55)}delete u.parent.contents[u.name],u.parent.timestamp=Date.now(),u.name=W,V.contents[W]=u,V.timestamp=u.parent.timestamp,u.parent=V},unlink(u,V){delete u.contents[V],u.timestamp=Date.now()},rmdir(u,V){var W=K.lookupNode(u,V);for(var P in W.contents)throw new K.ErrnoError(55);delete u.contents[V],u.timestamp=Date.now()},readdir(u){var V=[".",".."];for(var W in u.contents)u.contents.hasOwnProperty(W)&&V.push(W);return V},symlink(u,V,W){var P=Qe.createNode(u,V,41471,0);return P.link=W,P},readlink(u){if(!K.isLink(u.mode))throw new K.ErrnoError(28);return u.link}},stream_ops:{read(u,V,W,P,$){var ht=u.node.contents;if($>=u.node.usedBytes)return 0;var dt=Math.min(u.node.usedBytes-$,P);if(c(dt>=0),dt>8&&ht.subarray)V.set(ht.subarray($,$+dt),W);else for(var ft=0;ft<dt;ft++)V[W+ft]=ht[$+ft];return dt},write(u,V,W,P,$,ht){if(c(!(V instanceof ArrayBuffer)),V.buffer===g.buffer&&(ht=!1),!P)return 0;var dt=u.node;if(dt.timestamp=Date.now(),V.subarray&&(!dt.contents||dt.contents.subarray)){if(ht)return c($===0,"canOwn must imply no weird position inside the file"),dt.contents=V.subarray(W,W+P),dt.usedBytes=P,P;if(dt.usedBytes===0&&$===0)return dt.contents=V.slice(W,W+P),dt.usedBytes=P,P;if($+P<=dt.usedBytes)return dt.contents.set(V.subarray(W,W+P),$),P}if(Qe.expandFileStorage(dt,$+P),dt.contents.subarray&&V.subarray)dt.contents.set(V.subarray(W,W+P),$);else for(var ft=0;ft<P;ft++)dt.contents[$+ft]=V[W+ft];return dt.usedBytes=Math.max(dt.usedBytes,$+P),P},llseek(u,V,W){var P=V;if(W===1?P+=u.position:W===2&&K.isFile(u.node.mode)&&(P+=u.node.usedBytes),P<0)throw new K.ErrnoError(28);return P},allocate(u,V,W){Qe.expandFileStorage(u.node,V+W),u.node.usedBytes=Math.max(u.node.usedBytes,V+W)},mmap(u,V,W,P,$){if(!K.isFile(u.node.mode))throw new K.ErrnoError(43);var ht,dt,ft=u.node.contents;if(!($&2)&&ft.buffer===g.buffer)dt=!1,ht=ft.byteOffset;else{if((W>0||W+V<ft.length)&&(ft.subarray?ft=ft.subarray(W,W+V):ft=Array.prototype.slice.call(ft,W,W+V)),dt=!0,ht=cn(V),!ht)throw new K.ErrnoError(48);g.set(ft,ht)}return{ptr:ht,allocated:dt}},msync(u,V,W,P,$){return Qe.stream_ops.write(u,V,0,P,W,!1),0}}},Xs=(u,V,W,P)=>{var $=P?"":Fe(`al ${u}`);C(u,ht=>{c(ht,`Loading data file "${u}" failed (no arrayBuffer).`),V(new Uint8Array(ht)),$&&ze($)},ht=>{if(W)W();else throw`Loading data file "${u}" failed.`}),$&&ni($)},zo=i.preloadPlugins||[];function Vr(u,V,W,P){typeof Browser<"u"&&Browser.init();var $=!1;return zo.forEach(function(ht){$||ht.canHandle(V)&&(ht.handle(u,V,W,P),$=!0)}),$}function ml(u,V,W,P,$,ht,dt,ft,Gt,Lt){var re=V?Dt.resolve(Bt.join2(u,V)):u,ue=Fe(`cp ${re}`);function fe(Ee){function Ve(di){Lt&&Lt(),ft||K.createDataFile(u,V,di,P,$,Gt),ht&&ht(),ze(ue)}Vr(Ee,re,Ve,()=>{dt&&dt(),ze(ue)})||Ve(Ee)}ni(ue),typeof W=="string"?Xs(W,Ee=>fe(Ee),dt):fe(W)}function Ra(u){var V={r:0,"r+":2,w:577,"w+":578,a:1089,"a+":1090},W=V[u];if(typeof W>"u")throw new Error(`Unknown file open mode: ${u}`);return W}function iE(u,V){var W=0;return u&&(W|=365),V&&(W|=146),W}var jR={0:"Success",1:"Arg list too long",2:"Permission denied",3:"Address already in use",4:"Address not available",5:"Address family not supported by protocol family",6:"No more processes",7:"Socket already connected",8:"Bad file number",9:"Trying to read unreadable message",10:"Mount device busy",11:"Operation canceled",12:"No children",13:"Connection aborted",14:"Connection refused",15:"Connection reset by peer",16:"File locking deadlock error",17:"Destination address required",18:"Math arg out of domain of func",19:"Quota exceeded",20:"File exists",21:"Bad address",22:"File too large",23:"Host is unreachable",24:"Identifier removed",25:"Illegal byte sequence",26:"Connection already in progress",27:"Interrupted system call",28:"Invalid argument",29:"I/O error",30:"Socket is already connected",31:"Is a directory",32:"Too many symbolic links",33:"Too many open files",34:"Too many links",35:"Message too long",36:"Multihop attempted",37:"File or path name too long",38:"Network interface is not configured",39:"Connection reset by network",40:"Network is unreachable",41:"Too many open files in system",42:"No buffer space available",43:"No such device",44:"No such file or directory",45:"Exec format error",46:"No record locks available",47:"The link has been severed",48:"Not enough core",49:"No message of desired type",50:"Protocol not available",51:"No space left on device",52:"Function not implemented",53:"Socket is not connected",54:"Not a directory",55:"Directory not empty",56:"State not recoverable",57:"Socket operation on non-socket",59:"Not a typewriter",60:"No such device or address",61:"Value too large for defined data type",62:"Previous owner died",63:"Not super-user",64:"Broken pipe",65:"Protocol error",66:"Unknown protocol",67:"Protocol wrong type for socket",68:"Math result not representable",69:"Read only file system",70:"Illegal seek",71:"No such process",72:"Stale file handle",73:"Connection timed out",74:"Text file busy",75:"Cross-device link",100:"Device not a stream",101:"Bad font file fmt",102:"Invalid slot",103:"Invalid request code",104:"No anode",105:"Block device required",106:"Channel number out of range",107:"Level 3 halted",108:"Level 3 reset",109:"Link number out of range",110:"Protocol driver not attached",111:"No CSI structure available",112:"Level 2 halted",113:"Invalid exchange",114:"Invalid request descriptor",115:"Exchange full",116:"No data (for no delay io)",117:"Timer expired",118:"Out of streams resources",119:"Machine is not on the network",120:"Package not installed",121:"The object is remote",122:"Advertise error",123:"Srmount error",124:"Communication error on send",125:"Cross mount point (not really error)",126:"Given log. name not unique",127:"f.d. invalid for this operation",128:"Remote address changed",129:"Can   access a needed shared lib",130:"Accessing a corrupted shared lib",131:".lib section in a.out corrupted",132:"Attempting to link in too many libs",133:"Attempting to exec a shared library",135:"Streams pipe error",136:"Too many users",137:"Socket type not supported",138:"Not supported",139:"Protocol family not supported",140:"Can't send after socket shutdown",141:"Too many references",142:"Host is down",148:"No medium (in tape drive)",156:"Level 2 not synchronized"},Em={};function HR(u){return Ai("warning: build with -sDEMANGLE_SUPPORT to link in libcxxabi demangling"),u}function z8(u){var V=/\b_Z[\w\d_]+/g;return u.replace(V,function(W){var P=HR(W);return W===P?W:P+" ["+W+"]"})}var K={root:null,mounts:[],devices:{},streams:[],nextInode:1,nameTable:null,currentPath:"/",initialized:!1,ignorePermissions:!0,ErrnoError:null,genericErrors:{},filesystems:null,syncFSRequests:0,lookupPath:(u,V={})=>{if(u=Dt.resolve(u),!u)return{path:"",node:null};var W={follow_mount:!0,recurse_count:0};if(V=Object.assign(W,V),V.recurse_count>8)throw new K.ErrnoError(32);for(var P=u.split("/").filter(ue=>!!ue),$=K.root,ht="/",dt=0;dt<P.length;dt++){var ft=dt===P.length-1;if(ft&&V.parent)break;if($=K.lookupNode($,P[dt]),ht=Bt.join2(ht,P[dt]),K.isMountpoint($)&&(!ft||ft&&V.follow_mount)&&($=$.mounted.root),!ft||V.follow)for(var Gt=0;K.isLink($.mode);){var Lt=K.readlink(ht);ht=Dt.resolve(Bt.dirname(ht),Lt);var re=K.lookupPath(ht,{recurse_count:V.recurse_count+1});if($=re.node,Gt++>40)throw new K.ErrnoError(32)}}return{path:ht,node:$}},getPath:u=>{for(var V;;){if(K.isRoot(u)){var W=u.mount.mountpoint;return V?W[W.length-1]!=="/"?`${W}/${V}`:W+V:W}V=V?`${u.name}/${V}`:u.name,u=u.parent}},hashName:(u,V)=>{for(var W=0,P=0;P<V.length;P++)W=(W<<5)-W+V.charCodeAt(P)|0;return(u+W>>>0)%K.nameTable.length},hashAddNode:u=>{var V=K.hashName(u.parent.id,u.name);u.name_next=K.nameTable[V],K.nameTable[V]=u},hashRemoveNode:u=>{var V=K.hashName(u.parent.id,u.name);if(K.nameTable[V]===u)K.nameTable[V]=u.name_next;else for(var W=K.nameTable[V];W;){if(W.name_next===u){W.name_next=u.name_next;break}W=W.name_next}},lookupNode:(u,V)=>{var W=K.mayLookup(u);if(W)throw new K.ErrnoError(W,u);for(var P=K.hashName(u.id,V),$=K.nameTable[P];$;$=$.name_next){var ht=$.name;if($.parent.id===u.id&&ht===V)return $}return K.lookup(u,V)},createNode:(u,V,W,P)=>{c(typeof u=="object");var $=new K.FSNode(u,V,W,P);return K.hashAddNode($),$},destroyNode:u=>{K.hashRemoveNode(u)},isRoot:u=>u===u.parent,isMountpoint:u=>!!u.mounted,isFile:u=>(u&61440)===32768,isDir:u=>(u&61440)===16384,isLink:u=>(u&61440)===40960,isChrdev:u=>(u&61440)===8192,isBlkdev:u=>(u&61440)===24576,isFIFO:u=>(u&61440)===4096,isSocket:u=>(u&49152)===49152,flagsToPermissionString:u=>{var V=["r","w","rw"][u&3];return u&512&&(V+="w"),V},nodePermissions:(u,V)=>K.ignorePermissions?0:V.includes("r")&&!(u.mode&292)||V.includes("w")&&!(u.mode&146)||V.includes("x")&&!(u.mode&73)?2:0,mayLookup:u=>{var V=K.nodePermissions(u,"x");return V||(u.node_ops.lookup?0:2)},mayCreate:(u,V)=>{try{var W=K.lookupNode(u,V);return 20}catch{}return K.nodePermissions(u,"wx")},mayDelete:(u,V,W)=>{var P;try{P=K.lookupNode(u,V)}catch(ht){return ht.errno}var $=K.nodePermissions(u,"wx");if($)return $;if(W){if(!K.isDir(P.mode))return 54;if(K.isRoot(P)||K.getPath(P)===K.cwd())return 10}else if(K.isDir(P.mode))return 31;return 0},mayOpen:(u,V)=>u?K.isLink(u.mode)?32:K.isDir(u.mode)&&(K.flagsToPermissionString(V)!=="r"||V&512)?31:K.nodePermissions(u,K.flagsToPermissionString(V)):44,MAX_OPEN_FDS:4096,nextfd:()=>{for(var u=0;u<=K.MAX_OPEN_FDS;u++)if(!K.streams[u])return u;throw new K.ErrnoError(33)},getStreamChecked:u=>{var V=K.getStream(u);if(!V)throw new K.ErrnoError(8);return V},getStream:u=>K.streams[u],createStream:(u,V=-1)=>(K.FSStream||(K.FSStream=function(){this.shared={}},K.FSStream.prototype={},Object.defineProperties(K.FSStream.prototype,{object:{get(){return this.node},set(W){this.node=W}},isRead:{get(){return(this.flags&2097155)!==1}},isWrite:{get(){return(this.flags&2097155)!==0}},isAppend:{get(){return this.flags&1024}},flags:{get(){return this.shared.flags},set(W){this.shared.flags=W}},position:{get(){return this.shared.position},set(W){this.shared.position=W}}})),u=Object.assign(new K.FSStream,u),V==-1&&(V=K.nextfd()),u.fd=V,K.streams[V]=u,u),closeStream:u=>{K.streams[u]=null},chrdev_stream_ops:{open:u=>{var V=K.getDevice(u.node.rdev);u.stream_ops=V.stream_ops,u.stream_ops.open&&u.stream_ops.open(u)},llseek:()=>{throw new K.ErrnoError(70)}},major:u=>u>>8,minor:u=>u&255,makedev:(u,V)=>u<<8|V,registerDevice:(u,V)=>{K.devices[u]={stream_ops:V}},getDevice:u=>K.devices[u],getMounts:u=>{for(var V=[],W=[u];W.length;){var P=W.pop();V.push(P),W.push.apply(W,P.mounts)}return V},syncfs:(u,V)=>{typeof u=="function"&&(V=u,u=!1),K.syncFSRequests++,K.syncFSRequests>1&&F(`warning: ${K.syncFSRequests} FS.syncfs operations in flight at once, probably just doing extra work`);var W=K.getMounts(K.root.mount),P=0;function $(dt){return c(K.syncFSRequests>0),K.syncFSRequests--,V(dt)}function ht(dt){if(dt)return ht.errored?void 0:(ht.errored=!0,$(dt));++P>=W.length&&$(null)}W.forEach(dt=>{if(!dt.type.syncfs)return ht(null);dt.type.syncfs(dt,u,ht)})},mount:(u,V,W)=>{if(typeof u=="string")throw u;var P=W==="/",$=!W,ht;if(P&&K.root)throw new K.ErrnoError(10);if(!P&&!$){var dt=K.lookupPath(W,{follow_mount:!1});if(W=dt.path,ht=dt.node,K.isMountpoint(ht))throw new K.ErrnoError(10);if(!K.isDir(ht.mode))throw new K.ErrnoError(54)}var ft={type:u,opts:V,mountpoint:W,mounts:[]},Gt=u.mount(ft);return Gt.mount=ft,ft.root=Gt,P?K.root=Gt:ht&&(ht.mounted=ft,ht.mount&&ht.mount.mounts.push(ft)),Gt},unmount:u=>{var V=K.lookupPath(u,{follow_mount:!1});if(!K.isMountpoint(V.node))throw new K.ErrnoError(28);var W=V.node,P=W.mounted,$=K.getMounts(P);Object.keys(K.nameTable).forEach(dt=>{for(var ft=K.nameTable[dt];ft;){var Gt=ft.name_next;$.includes(ft.mount)&&K.destroyNode(ft),ft=Gt}}),W.mounted=null;var ht=W.mount.mounts.indexOf(P);c(ht!==-1),W.mount.mounts.splice(ht,1)},lookup:(u,V)=>u.node_ops.lookup(u,V),mknod:(u,V,W)=>{var P=K.lookupPath(u,{parent:!0}),$=P.node,ht=Bt.basename(u);if(!ht||ht==="."||ht==="..")throw new K.ErrnoError(28);var dt=K.mayCreate($,ht);if(dt)throw new K.ErrnoError(dt);if(!$.node_ops.mknod)throw new K.ErrnoError(63);return $.node_ops.mknod($,ht,V,W)},create:(u,V)=>(V=V!==void 0?V:438,V&=4095,V|=32768,K.mknod(u,V,0)),mkdir:(u,V)=>(V=V!==void 0?V:511,V&=1023,V|=16384,K.mknod(u,V,0)),mkdirTree:(u,V)=>{for(var W=u.split("/"),P="",$=0;$<W.length;++$)if(W[$]){P+="/"+W[$];try{K.mkdir(P,V)}catch(ht){if(ht.errno!=20)throw ht}}},mkdev:(u,V,W)=>(typeof W>"u"&&(W=V,V=438),V|=8192,K.mknod(u,V,W)),symlink:(u,V)=>{if(!Dt.resolve(u))throw new K.ErrnoError(44);var W=K.lookupPath(V,{parent:!0}),P=W.node;if(!P)throw new K.ErrnoError(44);var $=Bt.basename(V),ht=K.mayCreate(P,$);if(ht)throw new K.ErrnoError(ht);if(!P.node_ops.symlink)throw new K.ErrnoError(63);return P.node_ops.symlink(P,$,u)},rename:(u,V)=>{var W=Bt.dirname(u),P=Bt.dirname(V),$=Bt.basename(u),ht=Bt.basename(V),dt,ft,Gt;if(dt=K.lookupPath(u,{parent:!0}),ft=dt.node,dt=K.lookupPath(V,{parent:!0}),Gt=dt.node,!ft||!Gt)throw new K.ErrnoError(44);if(ft.mount!==Gt.mount)throw new K.ErrnoError(75);var Lt=K.lookupNode(ft,$),re=Dt.relative(u,P);if(re.charAt(0)!==".")throw new K.ErrnoError(28);if(re=Dt.relative(V,W),re.charAt(0)!==".")throw new K.ErrnoError(55);var ue;try{ue=K.lookupNode(Gt,ht)}catch{}if(Lt!==ue){var fe=K.isDir(Lt.mode),Ee=K.mayDelete(ft,$,fe);if(Ee)throw new K.ErrnoError(Ee);if(Ee=ue?K.mayDelete(Gt,ht,fe):K.mayCreate(Gt,ht),Ee)throw new K.ErrnoError(Ee);if(!ft.node_ops.rename)throw new K.ErrnoError(63);if(K.isMountpoint(Lt)||ue&&K.isMountpoint(ue))throw new K.ErrnoError(10);if(Gt!==ft&&(Ee=K.nodePermissions(ft,"w"),Ee))throw new K.ErrnoError(Ee);K.hashRemoveNode(Lt);try{ft.node_ops.rename(Lt,Gt,ht)}catch(Ve){throw Ve}finally{K.hashAddNode(Lt)}}},rmdir:u=>{var V=K.lookupPath(u,{parent:!0}),W=V.node,P=Bt.basename(u),$=K.lookupNode(W,P),ht=K.mayDelete(W,P,!0);if(ht)throw new K.ErrnoError(ht);if(!W.node_ops.rmdir)throw new K.ErrnoError(63);if(K.isMountpoint($))throw new K.ErrnoError(10);W.node_ops.rmdir(W,P),K.destroyNode($)},readdir:u=>{var V=K.lookupPath(u,{follow:!0}),W=V.node;if(!W.node_ops.readdir)throw new K.ErrnoError(54);return W.node_ops.readdir(W)},unlink:u=>{var V=K.lookupPath(u,{parent:!0}),W=V.node;if(!W)throw new K.ErrnoError(44);var P=Bt.basename(u),$=K.lookupNode(W,P),ht=K.mayDelete(W,P,!1);if(ht)throw new K.ErrnoError(ht);if(!W.node_ops.unlink)throw new K.ErrnoError(63);if(K.isMountpoint($))throw new K.ErrnoError(10);W.node_ops.unlink(W,P),K.destroyNode($)},readlink:u=>{var V=K.lookupPath(u),W=V.node;if(!W)throw new K.ErrnoError(44);if(!W.node_ops.readlink)throw new K.ErrnoError(28);return Dt.resolve(K.getPath(W.parent),W.node_ops.readlink(W))},stat:(u,V)=>{var W=K.lookupPath(u,{follow:!V}),P=W.node;if(!P)throw new K.ErrnoError(44);if(!P.node_ops.getattr)throw new K.ErrnoError(63);return P.node_ops.getattr(P)},lstat:u=>K.stat(u,!0),chmod:(u,V,W)=>{var P;if(typeof u=="string"){var $=K.lookupPath(u,{follow:!W});P=$.node}else P=u;if(!P.node_ops.setattr)throw new K.ErrnoError(63);P.node_ops.setattr(P,{mode:V&4095|P.mode&-4096,timestamp:Date.now()})},lchmod:(u,V)=>{K.chmod(u,V,!0)},fchmod:(u,V)=>{var W=K.getStreamChecked(u);K.chmod(W.node,V)},chown:(u,V,W,P)=>{var $;if(typeof u=="string"){var ht=K.lookupPath(u,{follow:!P});$=ht.node}else $=u;if(!$.node_ops.setattr)throw new K.ErrnoError(63);$.node_ops.setattr($,{timestamp:Date.now()})},lchown:(u,V,W)=>{K.chown(u,V,W,!0)},fchown:(u,V,W)=>{var P=K.getStreamChecked(u);K.chown(P.node,V,W)},truncate:(u,V)=>{if(V<0)throw new K.ErrnoError(28);var W;if(typeof u=="string"){var P=K.lookupPath(u,{follow:!0});W=P.node}else W=u;if(!W.node_ops.setattr)throw new K.ErrnoError(63);if(K.isDir(W.mode))throw new K.ErrnoError(31);if(!K.isFile(W.mode))throw new K.ErrnoError(28);var $=K.nodePermissions(W,"w");if($)throw new K.ErrnoError($);W.node_ops.setattr(W,{size:V,timestamp:Date.now()})},ftruncate:(u,V)=>{var W=K.getStreamChecked(u);if(!(W.flags&2097155))throw new K.ErrnoError(28);K.truncate(W.node,V)},utime:(u,V,W)=>{var P=K.lookupPath(u,{follow:!0}),$=P.node;$.node_ops.setattr($,{timestamp:Math.max(V,W)})},open:(u,V,W)=>{if(u==="")throw new K.ErrnoError(44);V=typeof V=="string"?Ra(V):V,W=typeof W>"u"?438:W,V&64?W=W&4095|32768:W=0;var P;if(typeof u=="object")P=u;else{u=Bt.normalize(u);try{var $=K.lookupPath(u,{follow:!(V&131072)});P=$.node}catch{}}var ht=!1;if(V&64)if(P){if(V&128)throw new K.ErrnoError(20)}else P=K.mknod(u,W,0),ht=!0;if(!P)throw new K.ErrnoError(44);if(K.isChrdev(P.mode)&&(V&=-513),V&65536&&!K.isDir(P.mode))throw new K.ErrnoError(54);if(!ht){var dt=K.mayOpen(P,V);if(dt)throw new K.ErrnoError(dt)}V&512&&!ht&&K.truncate(P,0),V&=-131713;var ft=K.createStream({node:P,path:K.getPath(P),flags:V,seekable:!0,position:0,stream_ops:P.stream_ops,ungotten:[],error:!1});return ft.stream_ops.open&&ft.stream_ops.open(ft),i.logReadFiles&&!(V&1)&&(K.readFiles||(K.readFiles={}),u in K.readFiles||(K.readFiles[u]=1)),ft},close:u=>{if(K.isClosed(u))throw new K.ErrnoError(8);u.getdents&&(u.getdents=null);try{u.stream_ops.close&&u.stream_ops.close(u)}catch(V){throw V}finally{K.closeStream(u.fd)}u.fd=null},isClosed:u=>u.fd===null,llseek:(u,V,W)=>{if(K.isClosed(u))throw new K.ErrnoError(8);if(!u.seekable||!u.stream_ops.llseek)throw new K.ErrnoError(70);if(W!=0&&W!=1&&W!=2)throw new K.ErrnoError(28);return u.position=u.stream_ops.llseek(u,V,W),u.ungotten=[],u.position},read:(u,V,W,P,$)=>{if(c(W>=0),P<0||$<0)throw new K.ErrnoError(28);if(K.isClosed(u))throw new K.ErrnoError(8);if((u.flags&2097155)===1)throw new K.ErrnoError(8);if(K.isDir(u.node.mode))throw new K.ErrnoError(31);if(!u.stream_ops.read)throw new K.ErrnoError(28);var ht=typeof $<"u";if(!ht)$=u.position;else if(!u.seekable)throw new K.ErrnoError(70);var dt=u.stream_ops.read(u,V,W,P,$);return ht||(u.position+=dt),dt},write:(u,V,W,P,$,ht)=>{if(c(W>=0),P<0||$<0)throw new K.ErrnoError(28);if(K.isClosed(u))throw new K.ErrnoError(8);if(!(u.flags&2097155))throw new K.ErrnoError(8);if(K.isDir(u.node.mode))throw new K.ErrnoError(31);if(!u.stream_ops.write)throw new K.ErrnoError(28);u.seekable&&u.flags&1024&&K.llseek(u,0,2);var dt=typeof $<"u";if(!dt)$=u.position;else if(!u.seekable)throw new K.ErrnoError(70);var ft=u.stream_ops.write(u,V,W,P,$,ht);return dt||(u.position+=ft),ft},allocate:(u,V,W)=>{if(K.isClosed(u))throw new K.ErrnoError(8);if(V<0||W<=0)throw new K.ErrnoError(28);if(!(u.flags&2097155))throw new K.ErrnoError(8);if(!K.isFile(u.node.mode)&&!K.isDir(u.node.mode))throw new K.ErrnoError(43);if(!u.stream_ops.allocate)throw new K.ErrnoError(138);u.stream_ops.allocate(u,V,W)},mmap:(u,V,W,P,$)=>{if(P&2&&!($&2)&&(u.flags&2097155)!==2)throw new K.ErrnoError(2);if((u.flags&2097155)===1)throw new K.ErrnoError(2);if(!u.stream_ops.mmap)throw new K.ErrnoError(43);return u.stream_ops.mmap(u,V,W,P,$)},msync:(u,V,W,P,$)=>(c(W>=0),u.stream_ops.msync?u.stream_ops.msync(u,V,W,P,$):0),munmap:u=>0,ioctl:(u,V,W)=>{if(!u.stream_ops.ioctl)throw new K.ErrnoError(59);return u.stream_ops.ioctl(u,V,W)},readFile:(u,V={})=>{if(V.flags=V.flags||0,V.encoding=V.encoding||"binary",V.encoding!=="utf8"&&V.encoding!=="binary")throw new Error(`Invalid encoding type "${V.encoding}"`);var W,P=K.open(u,V.flags),$=K.stat(u),ht=$.size,dt=new Uint8Array(ht);return K.read(P,dt,0,ht,0),V.encoding==="utf8"?W=fa(dt,0):V.encoding==="binary"&&(W=dt),K.close(P),W},writeFile:(u,V,W={})=>{W.flags=W.flags||577;var P=K.open(u,W.flags,W.mode);if(typeof V=="string"){var $=new Uint8Array(ma(V)+1),ht=qh(V,$,0,$.length);K.write(P,$,0,ht,void 0,W.canOwn)}else if(ArrayBuffer.isView(V))K.write(P,V,0,V.byteLength,void 0,W.canOwn);else throw new Error("Unsupported data type");K.close(P)},cwd:()=>K.currentPath,chdir:u=>{var V=K.lookupPath(u,{follow:!0});if(V.node===null)throw new K.ErrnoError(44);if(!K.isDir(V.node.mode))throw new K.ErrnoError(54);var W=K.nodePermissions(V.node,"x");if(W)throw new K.ErrnoError(W);K.currentPath=V.path},createDefaultDirectories:()=>{K.mkdir("/tmp"),K.mkdir("/home"),K.mkdir("/home/web_user")},createDefaultDevices:()=>{K.mkdir("/dev"),K.registerDevice(K.makedev(1,3),{read:()=>0,write:(P,$,ht,dt,ft)=>dt}),K.mkdev("/dev/null",K.makedev(1,3)),pi.register(K.makedev(5,0),pi.default_tty_ops),pi.register(K.makedev(6,0),pi.default_tty1_ops),K.mkdev("/dev/tty",K.makedev(5,0)),K.mkdev("/dev/tty1",K.makedev(6,0));var u=new Uint8Array(1024),V=0,W=()=>(V===0&&(V=Mt(u).byteLength),u[--V]);K.createDevice("/dev","random",W),K.createDevice("/dev","urandom",W),K.mkdir("/dev/shm"),K.mkdir("/dev/shm/tmp")},createSpecialDirectories:()=>{K.mkdir("/proc");var u=K.mkdir("/proc/self");K.mkdir("/proc/self/fd"),K.mount({mount:()=>{var V=K.createNode(u,"fd",16895,73);return V.node_ops={lookup:(W,P)=>{var $=+P,ht=K.getStreamChecked($),dt={parent:null,mount:{mountpoint:"fake"},node_ops:{readlink:()=>ht.path}};return dt.parent=dt,dt}},V}},{},"/proc/self/fd")},createStandardStreams:()=>{i.stdin?K.createDevice("/dev","stdin",i.stdin):K.symlink("/dev/tty","/dev/stdin"),i.stdout?K.createDevice("/dev","stdout",null,i.stdout):K.symlink("/dev/tty","/dev/stdout"),i.stderr?K.createDevice("/dev","stderr",null,i.stderr):K.symlink("/dev/tty1","/dev/stderr");var u=K.open("/dev/stdin",0),V=K.open("/dev/stdout",1),W=K.open("/dev/stderr",1);c(u.fd===0,`invalid handle for stdin (${u.fd})`),c(V.fd===1,`invalid handle for stdout (${V.fd})`),c(W.fd===2,`invalid handle for stderr (${W.fd})`)},ensureErrnoError:()=>{K.ErrnoError||(K.ErrnoError=function(V,W){this.name="ErrnoError",this.node=W,this.setErrno=function(P){this.errno=P;for(var $ in Em)if(Em[$]===P){this.code=$;break}},this.setErrno(V),this.message=jR[V],this.stack&&(Object.defineProperty(this,"stack",{value:new Error().stack,writable:!0}),this.stack=z8(this.stack))},K.ErrnoError.prototype=new Error,K.ErrnoError.prototype.constructor=K.ErrnoError,[44].forEach(u=>{K.genericErrors[u]=new K.ErrnoError(u),K.genericErrors[u].stack="<generic error, no stack>"}))},staticInit:()=>{K.ensureErrnoError(),K.nameTable=new Array(4096),K.mount(Qe,{},"/"),K.createDefaultDirectories(),K.createDefaultDevices(),K.createSpecialDirectories(),K.filesystems={MEMFS:Qe}},init:(u,V,W)=>{c(!K.init.initialized,"FS.init was previously called. If you want to initialize later with custom parameters, remove any earlier calls (note that one is automatically added to the generated code)"),K.init.initialized=!0,K.ensureErrnoError(),i.stdin=u||i.stdin,i.stdout=V||i.stdout,i.stderr=W||i.stderr,K.createStandardStreams()},quit:()=>{K.init.initialized=!1,dX(0);for(var u=0;u<K.streams.length;u++){var V=K.streams[u];V&&K.close(V)}},findObject:(u,V)=>{var W=K.analyzePath(u,V);return W.exists?W.object:null},analyzePath:(u,V)=>{try{var W=K.lookupPath(u,{follow:!V});u=W.path}catch{}var P={isRoot:!1,exists:!1,error:0,name:null,path:null,object:null,parentExists:!1,parentPath:null,parentObject:null};try{var W=K.lookupPath(u,{parent:!0});P.parentExists=!0,P.parentPath=W.path,P.parentObject=W.node,P.name=Bt.basename(u),W=K.lookupPath(u,{follow:!V}),P.exists=!0,P.path=W.path,P.object=W.node,P.name=W.node.name,P.isRoot=W.path==="/"}catch($){P.error=$.errno}return P},createPath:(u,V,W,P)=>{u=typeof u=="string"?u:K.getPath(u);for(var $=V.split("/").reverse();$.length;){var ht=$.pop();if(ht){var dt=Bt.join2(u,ht);try{K.mkdir(dt)}catch{}u=dt}}return dt},createFile:(u,V,W,P,$)=>{var ht=Bt.join2(typeof u=="string"?u:K.getPath(u),V),dt=iE(P,$);return K.create(ht,dt)},createDataFile:(u,V,W,P,$,ht)=>{var dt=V;u&&(u=typeof u=="string"?u:K.getPath(u),dt=V?Bt.join2(u,V):u);var ft=iE(P,$),Gt=K.create(dt,ft);if(W){if(typeof W=="string"){for(var Lt=new Array(W.length),re=0,ue=W.length;re<ue;++re)Lt[re]=W.charCodeAt(re);W=Lt}K.chmod(Gt,ft|146);var fe=K.open(Gt,577);K.write(fe,W,0,W.length,0,ht),K.close(fe),K.chmod(Gt,ft)}return Gt},createDevice:(u,V,W,P)=>{var $=Bt.join2(typeof u=="string"?u:K.getPath(u),V),ht=iE(!!W,!!P);K.createDevice.major||(K.createDevice.major=64);var dt=K.makedev(K.createDevice.major++,0);return K.registerDevice(dt,{open:ft=>{ft.seekable=!1},close:ft=>{P&&P.buffer&&P.buffer.length&&P(10)},read:(ft,Gt,Lt,re,ue)=>{for(var fe=0,Ee=0;Ee<re;Ee++){var Ve;try{Ve=W()}catch{throw new K.ErrnoError(29)}if(Ve===void 0&&fe===0)throw new K.ErrnoError(6);if(Ve==null)break;fe++,Gt[Lt+Ee]=Ve}return fe&&(ft.node.timestamp=Date.now()),fe},write:(ft,Gt,Lt,re,ue)=>{for(var fe=0;fe<re;fe++)try{P(Gt[Lt+fe])}catch{throw new K.ErrnoError(29)}return re&&(ft.node.timestamp=Date.now()),fe}}),K.mkdev($,ht,dt)},forceLoadFile:u=>{if(u.isDevice||u.isFolder||u.link||u.contents)return!0;if(typeof XMLHttpRequest<"u")throw new Error("Lazy loading should have been performed (contents set) in createLazyFile, but it was not. Lazy loading only works in web workers. Use --embed-file or --preload-file in emcc on the main thread.");if(I)try{u.contents=Ge(I(u.url),!0),u.usedBytes=u.contents.length}catch{throw new K.ErrnoError(29)}else throw new Error("Cannot load without read() or XMLHttpRequest.")},createLazyFile:(u,V,W,P,$)=>{function ht(){this.lengthKnown=!1,this.chunks=[]}if(ht.prototype.get=function(Ee){if(!(Ee>this.length-1||Ee<0)){var Ve=Ee%this.chunkSize,di=Ee/this.chunkSize|0;return this.getter(di)[Ve]}},ht.prototype.setDataGetter=function(Ee){this.getter=Ee},ht.prototype.cacheLength=function(){var Ee=new XMLHttpRequest;if(Ee.open("HEAD",W,!1),Ee.send(null),!(Ee.status>=200&&Ee.status<300||Ee.status===304))throw new Error("Couldn't load "+W+". Status: "+Ee.status);var Ve=Number(Ee.getResponseHeader("Content-length")),di,ln=(di=Ee.getResponseHeader("Accept-Ranges"))&&di==="bytes",Rn=(di=Ee.getResponseHeader("Content-Encoding"))&&di==="gzip",qt=1024*1024;ln||(qt=Ve);var be=(Zn,Ko)=>{if(Zn>Ko)throw new Error("invalid range ("+Zn+", "+Ko+") or no bytes requested!");if(Ko>Ve-1)throw new Error("only "+Ve+" bytes available! programmer error!");var ms=new XMLHttpRequest;if(ms.open("GET",W,!1),Ve!==qt&&ms.setRequestHeader("Range","bytes="+Zn+"-"+Ko),ms.responseType="arraybuffer",ms.overrideMimeType&&ms.overrideMimeType("text/plain; charset=x-user-defined"),ms.send(null),!(ms.status>=200&&ms.status<300||ms.status===304))throw new Error("Couldn't load "+W+". Status: "+ms.status);return ms.response!==void 0?new Uint8Array(ms.response||[]):Ge(ms.responseText||"",!0)},Ts=this;Ts.setDataGetter(Zn=>{var Ko=Zn*qt,ms=(Zn+1)*qt-1;if(ms=Math.min(ms,Ve-1),typeof Ts.chunks[Zn]>"u"&&(Ts.chunks[Zn]=be(Ko,ms)),typeof Ts.chunks[Zn]>"u")throw new Error("doXHR failed!");return Ts.chunks[Zn]}),(Rn||!Ve)&&(qt=Ve=1,Ve=this.getter(0).length,qt=Ve,b("LazyFiles on gzip forces download of the whole file when length is accessed")),this._length=Ve,this._chunkSize=qt,this.lengthKnown=!0},typeof XMLHttpRequest<"u"){if(!d)throw"Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";var dt=new ht;Object.defineProperties(dt,{length:{get:function(){return this.lengthKnown||this.cacheLength(),this._length}},chunkSize:{get:function(){return this.lengthKnown||this.cacheLength(),this._chunkSize}}});var ft={isDevice:!1,contents:dt}}else var ft={isDevice:!1,url:W};var Gt=K.createFile(u,V,ft,P,$);ft.contents?Gt.contents=ft.contents:ft.url&&(Gt.contents=null,Gt.url=ft.url),Object.defineProperties(Gt,{usedBytes:{get:function(){return this.contents.length}}});var Lt={},re=Object.keys(Gt.stream_ops);re.forEach(fe=>{var Ee=Gt.stream_ops[fe];Lt[fe]=function(){return K.forceLoadFile(Gt),Ee.apply(null,arguments)}});function ue(fe,Ee,Ve,di,ln){var Rn=fe.node.contents;if(ln>=Rn.length)return 0;var qt=Math.min(Rn.length-ln,di);if(c(qt>=0),Rn.slice)for(var be=0;be<qt;be++)Ee[Ve+be]=Rn[ln+be];else for(var be=0;be<qt;be++)Ee[Ve+be]=Rn.get(ln+be);return qt}return Lt.read=(fe,Ee,Ve,di,ln)=>(K.forceLoadFile(Gt),ue(fe,Ee,Ve,di,ln)),Lt.mmap=(fe,Ee,Ve,di,ln)=>{K.forceLoadFile(Gt);var Rn=cn(Ee);if(!Rn)throw new K.ErrnoError(48);return ue(fe,g,Rn,Ee,Ve),{ptr:Rn,allocated:!0}},Gt.stream_ops=Lt,Gt},absolutePath:()=>{Be("FS.absolutePath has been removed; use PATH_FS.resolve instead")},createFolder:()=>{Be("FS.createFolder has been removed; use FS.mkdir instead")},createLink:()=>{Be("FS.createLink has been removed; use FS.symlink instead")},joinPath:()=>{Be("FS.joinPath has been removed; use PATH.join instead")},mmapAlloc:()=>{Be("FS.mmapAlloc has been replaced by the top level function mmapAlloc")},standardizePath:()=>{Be("FS.standardizePath has been removed; use PATH.normalize instead")}},ec={DEFAULT_POLLMASK:5,calculateAt:function(u,V,W){if(Bt.isAbs(V))return V;var P;if(u===-100)P=K.cwd();else{var $=ec.getStreamFromFD(u);P=$.path}if(V.length==0){if(!W)throw new K.ErrnoError(44);return P}return Bt.join2(P,V)},doStat:function(u,V,W){try{var P=u(V)}catch(ft){if(ft&&ft.node&&Bt.normalize(V)!==Bt.normalize(K.getPath(ft.node)))return-54;throw ft}x[W>>2]=P.dev,x[W+4>>2]=P.mode,H[W+8>>2]=P.nlink,x[W+12>>2]=P.uid,x[W+16>>2]=P.gid,x[W+20>>2]=P.rdev,ei=[P.size>>>0,(Ne=P.size,+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[W+24>>2]=ei[0],x[W+28>>2]=ei[1],x[W+32>>2]=4096,x[W+36>>2]=P.blocks;var $=P.atime.getTime(),ht=P.mtime.getTime(),dt=P.ctime.getTime();return ei=[Math.floor($/1e3)>>>0,(Ne=Math.floor($/1e3),+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[W+40>>2]=ei[0],x[W+44>>2]=ei[1],H[W+48>>2]=$%1e3*1e3,ei=[Math.floor(ht/1e3)>>>0,(Ne=Math.floor(ht/1e3),+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[W+56>>2]=ei[0],x[W+60>>2]=ei[1],H[W+64>>2]=ht%1e3*1e3,ei=[Math.floor(dt/1e3)>>>0,(Ne=Math.floor(dt/1e3),+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[W+72>>2]=ei[0],x[W+76>>2]=ei[1],H[W+80>>2]=dt%1e3*1e3,ei=[P.ino>>>0,(Ne=P.ino,+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[W+88>>2]=ei[0],x[W+92>>2]=ei[1],0},doMsync:function(u,V,W,P,$){if(!K.isFile(V.node.mode))throw new K.ErrnoError(43);if(P&2)return 0;var ht=O.slice(u,u+W);K.msync(V,ht,$,W,P)},varargs:void 0,get(){c(ec.varargs!=null),ec.varargs+=4;var u=x[ec.varargs-4>>2];return u},getStr(u){var V=Ea(u);return V},getStreamFromFD:function(u){var V=K.getStreamChecked(u);return V}},K8=(u,V)=>{var W=0;return Rt().forEach(function(P,$){var ht=V+W;H[u+$*4>>2]=ht,Vt(P,ht),W+=P.length+1}),0},X8=(u,V)=>{var W=Rt();H[u>>2]=W.length;var P=0;return W.forEach(function($){P+=$.length+1}),H[V>>2]=P,0};function q8(u){try{var V=ec.getStreamFromFD(u);return K.close(V),0}catch(W){if(typeof K>"u"||W.name!=="ErrnoError")throw W;return W.errno}}var $8=(u,V,W,P)=>{for(var $=0,ht=0;ht<W;ht++){var dt=H[V>>2],ft=H[V+4>>2];V+=8;var Gt=K.read(u,g,dt,ft,P);if(Gt<0)return-1;if($+=Gt,Gt<ft)break;typeof P<"u"&&(P+=Gt)}return $};function tX(u,V,W,P){try{var $=ec.getStreamFromFD(u),ht=$8($,V,W);return H[P>>2]=ht,0}catch(dt){if(typeof K>"u"||dt.name!=="ErrnoError")throw dt;return dt.errno}}function eX(u,V,W,P,$){var ht=ll(V,W);try{if(isNaN(ht))return 61;var dt=ec.getStreamFromFD(u);return K.llseek(dt,ht,P),ei=[dt.position>>>0,(Ne=dt.position,+Math.abs(Ne)>=1?Ne>0?+Math.floor(Ne/4294967296)>>>0:~~+Math.ceil((Ne-+(~~Ne>>>0))/4294967296)>>>0:0)],x[$>>2]=ei[0],x[$+4>>2]=ei[1],dt.getdents&&ht===0&&P===0&&(dt.getdents=null),0}catch(ft){if(typeof K>"u"||ft.name!=="ErrnoError")throw ft;return ft.errno}}var iX=(u,V,W,P)=>{for(var $=0,ht=0;ht<W;ht++){var dt=H[V>>2],ft=H[V+4>>2];V+=8;var Gt=K.write(u,g,dt,ft,P);if(Gt<0)return-1;$+=Gt,typeof P<"u"&&(P+=Gt)}return $};function nX(u,V,W,P){try{var $=ec.getStreamFromFD(u),ht=iX($,V,W);return H[P>>2]=ht,0}catch(dt){if(typeof K>"u"||dt.name!=="ErrnoError")throw dt;return dt.errno}}var sX=(u,V)=>{for(var W=0,P=0;P<=V;W+=u[P++]);return W},MG=[31,29,31,30,31,30,31,31,30,31,30,31],QG=[31,28,31,30,31,30,31,31,30,31,30,31],oX=(u,V)=>{for(var W=new Date(u.getTime());V>0;){var P=oA(W.getFullYear()),$=W.getMonth(),ht=(P?MG:QG)[$];if(V>ht-W.getDate())V-=ht-W.getDate()+1,W.setDate(1),$<11?W.setMonth($+1):(W.setMonth(0),W.setFullYear(W.getFullYear()+1));else return W.setDate(W.getDate()+V),W}return W},kG=(u,V)=>{c(u.length>=0,"writeArrayToMemory array must have a length (should be an array or typed array)"),g.set(u,V)},rX=(u,V,W,P)=>{var $=x[P+40>>2],ht={tm_sec:x[P>>2],tm_min:x[P+4>>2],tm_hour:x[P+8>>2],tm_mday:x[P+12>>2],tm_mon:x[P+16>>2],tm_year:x[P+20>>2],tm_wday:x[P+24>>2],tm_yday:x[P+28>>2],tm_isdst:x[P+32>>2],tm_gmtoff:x[P+36>>2],tm_zone:$?Ea($):""},dt=Ea(W),ft={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var Gt in ft)dt=dt.replace(new RegExp(Gt,"g"),ft[Gt]);var Lt=["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],re=["January","February","March","April","May","June","July","August","September","October","November","December"];function ue(qt,be,Ts){for(var Zn=typeof qt=="number"?qt.toString():qt||"";Zn.length<be;)Zn=Ts[0]+Zn;return Zn}function fe(qt,be){return ue(qt,be,"0")}function Ee(qt,be){function Ts(Ko){return Ko<0?-1:Ko>0?1:0}var Zn;return(Zn=Ts(qt.getFullYear()-be.getFullYear()))===0&&(Zn=Ts(qt.getMonth()-be.getMonth()))===0&&(Zn=Ts(qt.getDate()-be.getDate())),Zn}function Ve(qt){switch(qt.getDay()){case 0:return new Date(qt.getFullYear()-1,11,29);case 1:return qt;case 2:return new Date(qt.getFullYear(),0,3);case 3:return new Date(qt.getFullYear(),0,2);case 4:return new Date(qt.getFullYear(),0,1);case 5:return new Date(qt.getFullYear()-1,11,31);case 6:return new Date(qt.getFullYear()-1,11,30)}}function di(qt){var be=oX(new Date(qt.tm_year+1900,0,1),qt.tm_yday),Ts=new Date(be.getFullYear(),0,4),Zn=new Date(be.getFullYear()+1,0,4),Ko=Ve(Ts),ms=Ve(Zn);return Ee(Ko,be)<=0?Ee(ms,be)<=0?be.getFullYear()+1:be.getFullYear():be.getFullYear()-1}var ln={"%a":qt=>Lt[qt.tm_wday].substring(0,3),"%A":qt=>Lt[qt.tm_wday],"%b":qt=>re[qt.tm_mon].substring(0,3),"%B":qt=>re[qt.tm_mon],"%C":qt=>{var be=qt.tm_year+1900;return fe(be/100|0,2)},"%d":qt=>fe(qt.tm_mday,2),"%e":qt=>ue(qt.tm_mday,2," "),"%g":qt=>di(qt).toString().substring(2),"%G":qt=>di(qt),"%H":qt=>fe(qt.tm_hour,2),"%I":qt=>{var be=qt.tm_hour;return be==0?be=12:be>12&&(be-=12),fe(be,2)},"%j":qt=>fe(qt.tm_mday+sX(oA(qt.tm_year+1900)?MG:QG,qt.tm_mon-1),3),"%m":qt=>fe(qt.tm_mon+1,2),"%M":qt=>fe(qt.tm_min,2),"%n":()=>`
`,"%p":qt=>qt.tm_hour>=0&&qt.tm_hour<12?"AM":"PM","%S":qt=>fe(qt.tm_sec,2),"%t":()=>"	","%u":qt=>qt.tm_wday||7,"%U":qt=>{var be=qt.tm_yday+7-qt.tm_wday;return fe(Math.floor(be/7),2)},"%V":qt=>{var be=Math.floor((qt.tm_yday+7-(qt.tm_wday+6)%7)/7);if((qt.tm_wday+371-qt.tm_yday-2)%7<=2&&be++,be){if(be==53){var Zn=(qt.tm_wday+371-qt.tm_yday)%7;Zn!=4&&(Zn!=3||!oA(qt.tm_year))&&(be=1)}}else{be=52;var Ts=(qt.tm_wday+7-qt.tm_yday-1)%7;(Ts==4||Ts==5&&oA(qt.tm_year%400-1))&&be++}return fe(be,2)},"%w":qt=>qt.tm_wday,"%W":qt=>{var be=qt.tm_yday+7-(qt.tm_wday+6)%7;return fe(Math.floor(be/7),2)},"%y":qt=>(qt.tm_year+1900).toString().substring(2),"%Y":qt=>qt.tm_year+1900,"%z":qt=>{var be=qt.tm_gmtoff,Ts=be>=0;return be=Math.abs(be)/60,be=be/60*100+be%60,(Ts?"+":"-")+("0000"+be).slice(-4)},"%Z":qt=>qt.tm_zone,"%%":()=>"%"};dt=dt.replace(/%%/g,"\0\0");for(var Gt in ln)dt.includes(Gt)&&(dt=dt.replace(new RegExp(Gt,"g"),ln[Gt](ht)));dt=dt.replace(/\0\0/g,"%");var Rn=Ge(dt,!1);return Rn.length>V?0:(kG(Rn,u),Rn.length-1)},aX=(u,V,W,P,$)=>rX(u,V,W,P);function AX(u){var V=i["_"+u];return c(V,"Cannot call unknown function "+u+", make sure it is exported"),V}var hX=u=>{var V=ma(u)+1,W=PG(V);return PA(u,W,V),W},LG=function(u,V,W,P,$){var ht={string:Ve=>{var di=0;return Ve!=null&&Ve!==0&&(di=hX(Ve)),di},array:Ve=>{var di=PG(Ve.length);return kG(Ve,di),di}};function dt(Ve){return V==="string"?Ea(Ve):V==="boolean"?!!Ve:Ve}var ft=AX(u),Gt=[],Lt=0;if(c(V!=="array",'Return type should not be "array".'),P)for(var re=0;re<P.length;re++){var ue=ht[W[re]];ue?(Lt===0&&(Lt=RX()),Gt[re]=ue(P[re])):Gt[re]=P[re]}var fe=ft.apply(null,Gt);function Ee(Ve){return Lt!==0&&ZX(Lt),dt(Ve)}return fe=Ee(fe),fe};function cX(u,V,W,P){return function(){return LG(u,V,W,arguments,P)}}jo(),So=i.BindingError=class extends Error{constructor(V){super(V),this.name="BindingError"}},aa=i.InternalError=class extends Error{constructor(V){super(V),this.name="InternalError"}},yh(),Vd(),yA(),jh=i.UnboundTypeError=sl(Error,"UnboundTypeError"),wd(),Pd();var yG=function(u,V,W,P){u||(u=this),this.parent=u,this.mount=u.mount,this.mounted=null,this.id=K.nextInode++,this.name=V,this.mode=W,this.node_ops={},this.stream_ops={},this.rdev=P},vR=365,zR=146;Object.defineProperties(yG.prototype,{read:{get:function(){return(this.mode&vR)===vR},set:function(u){u?this.mode|=vR:this.mode&=~vR}},write:{get:function(){return(this.mode&zR)===zR},set:function(u){u?this.mode|=zR:this.mode&=~zR}},isFolder:{get:function(){return K.isDir(this.mode)}},isDevice:{get:function(){return K.isChrdev(this.mode)}}}),K.FSNode=yG,K.createPreloadedFile=ml,K.staticInit(),Em={EPERM:63,ENOENT:44,ESRCH:71,EINTR:27,EIO:29,ENXIO:60,E2BIG:1,ENOEXEC:45,EBADF:8,ECHILD:12,EAGAIN:6,EWOULDBLOCK:6,ENOMEM:48,EACCES:2,EFAULT:21,ENOTBLK:105,EBUSY:10,EEXIST:20,EXDEV:75,ENODEV:43,ENOTDIR:54,EISDIR:31,EINVAL:28,ENFILE:41,EMFILE:33,ENOTTY:59,ETXTBSY:74,EFBIG:22,ENOSPC:51,ESPIPE:70,EROFS:69,EMLINK:34,EPIPE:64,EDOM:18,ERANGE:68,ENOMSG:49,EIDRM:24,ECHRNG:106,EL2NSYNC:156,EL3HLT:107,EL3RST:108,ELNRNG:109,EUNATCH:110,ENOCSI:111,EL2HLT:112,EDEADLK:16,ENOLCK:46,EBADE:113,EBADR:114,EXFULL:115,ENOANO:104,EBADRQC:103,EBADSLT:102,EDEADLOCK:16,EBFONT:101,ENOSTR:100,ENODATA:116,ETIME:117,ENOSR:118,ENONET:119,ENOPKG:120,EREMOTE:121,ENOLINK:47,EADV:122,ESRMNT:123,ECOMM:124,EPROTO:65,EMULTIHOP:36,EDOTDOT:125,EBADMSG:9,ENOTUNIQ:126,EBADFD:127,EREMCHG:128,ELIBACC:129,ELIBBAD:130,ELIBSCN:131,ELIBMAX:132,ELIBEXEC:133,ENOSYS:52,ENOTEMPTY:55,ENAMETOOLONG:37,ELOOP:32,EOPNOTSUPP:138,EPFNOSUPPORT:139,ECONNRESET:15,ENOBUFS:42,EAFNOSUPPORT:5,EPROTOTYPE:67,ENOTSOCK:57,ENOPROTOOPT:50,ESHUTDOWN:140,ECONNREFUSED:14,EADDRINUSE:3,ECONNABORTED:13,ENETUNREACH:40,ENETDOWN:38,ETIMEDOUT:73,EHOSTDOWN:142,EHOSTUNREACH:23,EINPROGRESS:26,EALREADY:7,EDESTADDRREQ:17,EMSGSIZE:35,EPROTONOSUPPORT:66,ESOCKTNOSUPPORT:137,EADDRNOTAVAIL:4,ENETRESET:39,EISCONN:30,ENOTCONN:53,ETOOMANYREFS:141,EUSERS:136,EDQUOT:19,ESTALE:72,ENOTSUP:138,ENOMEDIUM:148,EILSEQ:25,EOVERFLOW:61,ECANCELED:11,ENOTRECOVERABLE:56,EOWNERDEAD:62,ESTRPIPE:135};function lX(){hs("fetchSettings")}var wG={__cxa_throw:ao,_embind_register_bigint:qi,_embind_register_bool:hr,_embind_register_class:Hh,_embind_register_class_constructor:yd,_embind_register_class_function:Kh,_embind_register_class_property:Xh,_embind_register_emval:xA,_embind_register_float:Jd,_embind_register_function:jd,_embind_register_integer:vd,_embind_register_memory_view:zd,_embind_register_std_string:sA,_embind_register_std_wstring:$d,_embind_register_void:tm,_emscripten_get_now_is_monotonic:im,_emval_as:sm,_emval_decref:ho,_emval_get_property:om,_emval_new_cstring:am,_emval_run_destructors:Am,_gmtime_js:hm,_mktime_js:dm,_tzset_js:mm,abort:fm,emscripten_asm_const_int:et,emscripten_date_now:pt,emscripten_get_now:$t,emscripten_memcpy_big:ve,emscripten_resize_heap:tc,emscripten_run_script_string:J,environ_get:K8,environ_sizes_get:X8,fd_close:q8,fd_read:tX,fd_seek:eX,fd_write:nX,strftime_l:aX},LIt=An(),yIt=qe("__wasm_call_ctors"),KR=i._malloc=qe("malloc"),HA=i._free=qe("free"),wIt=i._inflateEllipsoid=qe("inflateEllipsoid"),xIt=i._getCoveragePositions=qe("getCoveragePositions"),dX=i._fflush=qe("fflush"),mX=qe("__getTypeName"),PIt=i.__embind_initialize_bindings=qe("_embind_initialize_bindings"),JIt=qe("__errno_location"),fX=qe("setTempRet0"),xG=()=>(xG=M.emscripten_stack_init)(),EX=()=>(EX=M.emscripten_stack_get_free)(),_X=()=>(_X=M.emscripten_stack_get_base)(),$g=()=>($g=M.emscripten_stack_get_end)(),RX=qe("stackSave"),ZX=qe("stackRestore"),PG=qe("stackAlloc"),IX=()=>(IX=M.emscripten_stack_get_current)(),jIt=qe("__cxa_increment_exception_refcount"),pX=qe("__cxa_is_pointer_type"),HIt=i.dynCall_jiji=qe("dynCall_jiji"),vIt=i.dynCall_viijii=qe("dynCall_viijii"),zIt=i.dynCall_iiiiij=qe("dynCall_iiiiij"),KIt=i.dynCall_iiiiijj=qe("dynCall_iiiiijj"),XIt=i.dynCall_iiiiiijj=qe("dynCall_iiiiiijj");function uX(u){try{for(var V=atob(u),W=new Uint8Array(V.length),P=0;P<V.length;++P)W[P]=V.charCodeAt(P);return W}catch{throw new Error("Converting base64 string to bytes failed.")}}function CX(u){if(Ri(u))return uX(u.slice(Mi.length))}i.ccall=LG,i.cwrap=cX;var gX=["writeI53ToI64","writeI53ToI64Clamped","writeI53ToI64Signaling","writeI53ToU64Clamped","writeI53ToU64Signaling","readI53FromI64","readI53FromU64","convertI32PairToI53","convertU32PairToI53","exitJS","setErrNo","inetPton4","inetNtop4","inetPton6","inetNtop6","readSockaddr","writeSockaddr","getHostByName","getCallstack","emscriptenLog","convertPCtoSourceLocation","runMainThreadEmAsm","jstoi_q","jstoi_s","listenOnce","autoResumeAudioContext","handleException","runtimeKeepalivePush","runtimeKeepalivePop","callUserCallback","maybeExit","safeSetTimeout","asmjsMangle","getNativeTypeSize","STACK_SIZE","STACK_ALIGN","POINTER_SIZE","ASSERTIONS","uleb128Encode","sigToWasmTypes","generateFuncType","convertJsFunctionToWasm","getEmptyTableSlot","updateTableMap","getFunctionAddress","addFunction","removeFunction","reallyNegative","unSign","strLen","reSign","formatString","intArrayToString","AsciiToString","registerKeyEventCallback","maybeCStringToJsString","findEventTarget","findCanvasEventTarget","getBoundingClientRect","fillMouseEventData","registerMouseEventCallback","registerWheelEventCallback","registerUiEventCallback","registerFocusEventCallback","fillDeviceOrientationEventData","registerDeviceOrientationEventCallback","fillDeviceMotionEventData","registerDeviceMotionEventCallback","screenOrientation","fillOrientationChangeEventData","registerOrientationChangeEventCallback","fillFullscreenChangeEventData","registerFullscreenChangeEventCallback","JSEvents_requestFullscreen","JSEvents_resizeCanvasForFullscreen","registerRestoreOldStyle","hideEverythingExceptGivenElement","restoreHiddenElements","setLetterbox","softFullscreenResizeWebGLRenderTarget","doRequestFullscreen","fillPointerlockChangeEventData","registerPointerlockChangeEventCallback","registerPointerlockErrorEventCallback","requestPointerLock","fillVisibilityChangeEventData","registerVisibilityChangeEventCallback","registerTouchEventCallback","fillGamepadEventData","registerGamepadEventCallback","registerBeforeUnloadEventCallback","fillBatteryEventData","battery","registerBatteryEventCallback","setCanvasElementSize","getCanvasElementSize","jsStackTrace","stackTrace","checkWasiClock","wasiRightsToMuslOFlags","wasiOFlagsToMuslOFlags","createDyncallWrapper","setImmediateWrapped","clearImmediateWrapped","polyfillSetImmediate","getPromise","makePromise","idsToPromises","makePromiseCallback","findMatchingCatch","setMainLoop","getSocketFromFD","getSocketAddress","_setNetworkCallback","heapObjectForWebGLType","heapAccessShiftForWebGLHeap","webgl_enable_ANGLE_instanced_arrays","webgl_enable_OES_vertex_array_object","webgl_enable_WEBGL_draw_buffers","webgl_enable_WEBGL_multi_draw","emscriptenWebGLGet","computeUnpackAlignedImageSize","colorChannelsInGlTextureFormat","emscriptenWebGLGetTexPixelData","__glGenObject","emscriptenWebGLGetUniform","webglGetUniformLocation","webglPrepareUniformLocationsBeforeFirstUse","webglGetLeftBracePos","emscriptenWebGLGetVertexAttrib","__glGetActiveAttribOrUniform","writeGLArray","registerWebGlEventCallback","runAndAbortIfError","SDL_unicode","SDL_ttfContext","SDL_audio","GLFW_Window","ALLOC_NORMAL","ALLOC_STACK","allocate","writeStringToMemory","writeAsciiToMemory","registerInheritedInstance","unregisterInheritedInstance","enumReadValueFromPointer","craftEmvalAllocator","emval_get_global","emval_lookupTypes","emval_allocateDestructors","emval_addMethodCaller"];gX.forEach(ki);var TX=["run","addOnPreRun","addOnInit","addOnPreMain","addOnExit","addOnPostRun","addRunDependency","removeRunDependency","FS_createFolder","FS_createPath","FS_createDataFile","FS_createLazyFile","FS_createLink","FS_createDevice","FS_unlink","out","err","callMain","abort","keepRuntimeAlive","wasmMemory","wasmTable","wasmExports","stackAlloc","stackSave","stackRestore","getTempRet0","setTempRet0","writeStackCookie","checkStackCookie","intArrayFromBase64","tryParseAsDataURI","convertI32PairToI53Checked","ptrToString","zeroMemory","getHeapMax","growMemory","ENV","MONTH_DAYS_REGULAR","MONTH_DAYS_LEAP","MONTH_DAYS_REGULAR_CUMULATIVE","MONTH_DAYS_LEAP_CUMULATIVE","isLeapYear","ydayFromDate","arraySum","addDays","ERRNO_CODES","ERRNO_MESSAGES","DNS","Protocols","Sockets","initRandomFill","randomFill","timers","warnOnce","UNWIND_CACHE","readEmAsmArgsArray","readEmAsmArgs","runEmAsmFunction","getExecutableName","dynCallLegacy","getDynCaller","dynCall","asyncLoad","alignMemory","mmapAlloc","handleAllocatorInit","HandleAllocator","getCFunc","freeTableIndexes","functionsInTableMap","setValue","getValue","PATH","PATH_FS","UTF8Decoder","UTF8ArrayToString","UTF8ToString","stringToUTF8Array","stringToUTF8","lengthBytesUTF8","intArrayFromString","stringToAscii","UTF16Decoder","UTF16ToString","stringToUTF16","lengthBytesUTF16","UTF32ToString","stringToUTF32","lengthBytesUTF32","stringToNewUTF8","stringToUTF8OnStack","writeArrayToMemory","JSEvents","specialHTMLTargets","currentFullscreenStrategy","restoreOldWindowedStyle","demangle","demangleAll","ExitStatus","getEnvStrings","doReadv","doWritev","promiseMap","uncaughtExceptionCount","exceptionLast","exceptionCaught","ExceptionInfo","Browser","wget","SYSCALLS","preloadPlugins","FS_createPreloadedFile","FS_modeStringToFlags","FS_getMode","FS_stdin_getChar_buffer","FS_stdin_getChar","FS","MEMFS","TTY","PIPEFS","SOCKFS","tempFixedLengthArray","miniTempWebGLFloatBuffers","miniTempWebGLIntBuffers","GL","emscripten_webgl_power_preferences","AL","GLUT","EGL","GLEW","IDBStore","SDL","SDL_gfx","GLFW","allocateUTF8","allocateUTF8OnStack","InternalError","BindingError","throwInternalError","throwBindingError","registeredTypes","awaitingDependencies","typeDependencies","tupleRegistrations","structRegistrations","sharedRegisterType","whenDependentTypesAreResolved","embind_charCodes","embind_init_charCodes","readLatin1String","getTypeName","heap32VectorToArray","requireRegisteredType","UnboundTypeError","PureVirtualError","init_embind","throwUnboundTypeError","ensureOverloadTable","exposePublicSymbol","replacePublicSymbol","extendError","createNamedFunction","embindRepr","registeredInstances","getBasestPointer","getInheritedInstance","getInheritedInstanceCount","getLiveInheritedInstances","registeredPointers","registerType","getShiftFromSize","integerReadValueFromPointer","floatReadValueFromPointer","simpleReadValueFromPointer","runDestructors","newFunc","craftInvokerFunction","embind__requireFunction","genericPointerToWireType","constNoSmartPtrRawPointerToWireType","nonConstNoSmartPtrRawPointerToWireType","init_RegisteredPointer","RegisteredPointer","RegisteredPointer_getPointee","RegisteredPointer_destructor","RegisteredPointer_deleteObject","RegisteredPointer_fromWireType","runDestructor","releaseClassHandle","finalizationRegistry","detachFinalizer_deps","detachFinalizer","attachFinalizer","makeClassHandle","init_ClassHandle","ClassHandle","ClassHandle_isAliasOf","throwInstanceAlreadyDeleted","ClassHandle_clone","ClassHandle_delete","deletionQueue","ClassHandle_isDeleted","ClassHandle_deleteLater","flushPendingDeletes","delayFunction","setDelayFunction","RegisteredClass","shallowCopyInternalPointer","downcastPointer","upcastPointer","validateThis","char_0","char_9","makeLegalFunctionName","emval_handles","emval_symbols","init_emval","count_emval_handles","getStringOrSymbol","Emval","emval_newers","emval_methodCallers","emval_registeredMethods"];TX.forEach(sn);var XR;Me=function u(){XR||JG(),XR||(Me=u)};function NX(){xG(),It()}function JG(){if(Se>0||(NX(),Jt(),Se>0))return;function u(){XR||(XR=!0,i.calledRun=!0,!k&&(Wt(),n(i),i.onRuntimeInitialized&&i.onRuntimeInitialized(),c(!i._main,'compiled without a main, but one is present. if you added it from JS, use Module["onRuntimeInitialized"]'),bt()))}i.setStatus?(i.setStatus("Running..."),setTimeout(function(){setTimeout(function(){i.setStatus("")},1),u()},1)):u(),gt()}if(i.preInit)for(typeof i.preInit=="function"&&(i.preInit=[i.preInit]);i.preInit.length>0;)i.preInit.pop()();return JG(),e.ready}})(),BC=Vht});var dv,mv=S(()=>{lv();globalThis.Buffer=globalThis.Buffer||{};dv=(BC.hasOwnProperty("then")?BC:Promise.resolve(BC())).then(t=>{let e={find_nearby_indices:{rval:"boolean",params:["number","number"]},getCoveragePositions:{rval:null,params:["number","number","number","number","number"]},inflateEllipsoid:{rval:null,params:["number"]}},i={wasm:t};return Object.keys(e).forEach(n=>{i[n]=e[n].params?t.cwrap(n,e[n].rval,e[n].params):t.cwrap(n,e[n].rval)}),i})});var Oht,KV,fv,Lfe,Ev=S(()=>{mv();Ot();Or();({FinalizationRegistry:Oht}=globalThis),KV={_previousLoad:!1,_instance:void 0,_wasmModule:void 0,_positionPointer:-1,_precisionMode:75,async initInstance(){let t="default";if(!this._previousLoad)try{this._wasmModule=(await dv).wasm,this._previousLoad=!0}catch(e){throw new Y(`Failed to load the WASM module: ${e.message}`)}if(!this._instance){let{PositionRegistry:e}=this._wasmModule;this._instance=new e(t)}return{instance:this._instance,wasmModule:this._wasmModule}},get instance(){return this._instance},get wasmModule(){return this._wasmModule},get positionPointer(){return this._positionPointer},update(t){if(!this._instance)return 0;let e=Math.round(t/this._precisionMode)*this._precisionMode;return this._lastUpdate!==e&&(this._lastUpdate=e,this._positionPointer=this._instance.update(e)),this._positionPointer||0},updateJulianDate(t){if(!this._instance)return 0;if(!(t instanceof Ze))throw new TypeError("Expected julianDate to be an instance of JulianDate");let e=Ze.toDate(t).getTime();return this.update(e)},get precisionMode(){return this._precisionMode},set precisionMode(t){if(typeof t!="number"||t<=0)throw new TypeError("Precision mode must be a positive number.");this._precisionMode=t}},fv={},Lfe=new Oht(t=>{let e=fv[t];e&&(KV._wasmModule.wasm.removePosition(e),delete fv[t],console.log(`Entity with ID ${t} has been garbage collected, pointer ${e}`))})});function _v(t){let e=[],i=t.properties.CAT.getValue(),n=t.properties.OMM.getValue(),s=n.SEMI_MAJOR_AXIS;if(i.PERIOD<128*60&&n.ECCENTRICITY<.25&&e.push(Ni.LEO),s>36e3){let o=Ze.now(),r=Ze.addMinutes(o,1440,new Ze),a=10,h=1/0,A=-1/0;for(let d=o;Ze.lessThan(d,r);d=Ze.addMinutes(d,a,new Ze)){let f=t.position.getValue(d),{latitude:E}=ut.fromCartesian(f,ot.WGS84)||{latitude:0},_=L.toDegrees(E);h=Math.min(h,_),A=Math.max(A,_)}i.PERIOD>XV-60&&i.PERIOD<XV+60&&(n.INCLINATION<1?e.push(Ni.GEO):e.push(Ni.GEOSYNC)),n.INCLINATION>=25&&n.INCLINATION<=180&&s>=37948&&s<=46380&&n.ECCENTRICITY<=.25&&e.push(Ni.IGO),n.INCLINATION>=0&&n.INCLINATION<=25&&s>=37948&&s<=46380&&n.ECCENTRICITY<=.25&&e.push(Ni.EGO),h>=-15&&A<=15&&i.PERIGEE>=35586&&i.PERIGEE<=35986&&e.push(Ni.GEOIADC)}return i.PERIGEE>=2e3&&i.PERIGEE<35700?e.push(Ni.MEO):i.PERIGEE>35786&&e.push(Ni.HEO),n.INCLINATION>97&&n.INCLINATION<99&&e.push(Ni.SUNSYNC),Math.abs(i.PERIOD-.5*XV)<1&&e.push(Ni.SEMISYNC),n.INCLINATION>=80&&n.INCLINATION<=100&&e.push(Ni.POLAR),e.length===0&&e.push(Ni.UNKNOWN),e}var Ni,XV,Rv=S(()=>{Or();_e();ri();Oe();Ni={LEO:"Low Earth Orbit",MEO:"Medium Earth Orbit",HEO:"Highly Elliptical Orbit",GEO:"Geostationary Orbit",IGO:"Inclined Geosynchronous Orbit",EGO:"Extended Geostationary Orbit",GEOIADC:"IADC GEO Protected Region",GEOSYNC:"Geosynchronous Orbit",SUNSYNC:"Sun Synchronous Orbit",SEMISYNC:"Semi Synchronous Orbit",POLAR:"POLAR Orbit",UNKNOWN:"UNKNOWN"},XV=86164.0905});function Cf(t,e){this._callback=void 0,this._isConstant=void 0,this._definitionChanged=new We,this.setCallback(t,e)}var Zv,Iv=S(()=>{mt();Ot();xi();Object.defineProperties(Cf.prototype,{isConstant:{get:function(){return this._isConstant}},definitionChanged:{get:function(){return this._definitionChanged}}});Cf.prototype.getValue=function(t,e){return this._callback(t,e)};Cf.prototype.setCallback=function(t,e){if(!m(t))throw new Y("callback is required.");if(!m(e))throw new Y("isConstant is required.");let i=this._callback!==t||this._isConstant!==e;this._callback=t,this._isConstant=e,i&&this._definitionChanged.raiseEvent(this)};Cf.prototype.equals=function(t){return this===t||t instanceof Cf&&this._callback===t._callback&&this._isConstant===t._isConstant};Zv=Cf});var qV,pv,uv=S(()=>{Qn();cp();Ht();Ot();BF();Iv();qV=class extends V_{constructor(e){if(!(e.sdc instanceof V_)||!e.sdc._wasmModule)throw new Y("Invalid SpaceCatalogDataSource");super(`${e.sdc.name}_coverageGroup`),this.objectList=[],this.sdc=e.sdc,this.sdc.entities.collectionChanged.addEventListener((i,n,s,o)=>{for(let r=0;r<s.length;r++)~this.objectList.indexOf(s[r])&&this.remove(s[r]);for(let r=0;r<n.length;r++)!~this.objectList.indexOf(n[r])&&n[r]._coverageShowing&&this.push(n[r])}),this.coverageType=e.coverageType||0,this.color=e.color||Zt.fromRandom({alpha:.3}),this.groundCoverageOnly=e.groundCoverageOnly||!1,this.angle=e.angle,this.lastIntersectionTime=null,this.cachedPositions=[],this.wasmModule=this.sdc._wasmModule,this.samples=e.samples||10,this.ecefPointer=this.wasmModule._malloc(24),this.ecefPoints=new Float64Array(this.wasmModule.HEAP8.buffer,this.ecefPointer,3),this.positions=new Float64Array(this.wasmModule.HEAP8.buffer,this.posArrayPointer,this._size),this.result=new l,this.ph=new sf,this.c3array=[]}get viewer(){return this._viewer}get samples(){return this._samples}set samples(e){this._samples=e,this._size=6*this._samples,this._bytesSize=this._size*8,this.posArrayPointer&&this.wasmModule._free(this.posArrayPointer),this.posArrayPointer=this.wasmModule._malloc(this._bytesSize),this.positions=new Float64Array(this.wasmModule.HEAP8.buffer,this.posArrayPointer,this._size)}createGeometry(){let e="noclick:CoverageEntity";if(this.ph.satpos=[],!this.entities.getById(e)){let i=this.entities.add({id:e,polygon:{hierarchy:new Zv(n=>{this.ph.positionsArray=[],this.ph.positions=[];for(let s=0;s<this.objectList.length;++s)if(this.objectList[s].show){if(this.c3array=[],this.result=this.objectList[s].position.getValue(n,this.result,!1),this.modelMatrix=this.objectList[s].computeModelMatrix(n),l.pack(this.result,this.ecefPoints),this.wasmModule.getCoveragePositions(this.ecefPointer,this.coverageType,this.angle,this.samples,this.posArrayPointer),this.positions.length%3===0){let o=l.unpackArray(this.positions,this.c3array);this.ph.positionsArray[s]=o}else continue;this.groundCoverageOnly||(this.ph.satpos[s]=l.clone(this.result))}return this.ph},!1),perPositionHeight:!0,material:this.color},properties:{unselectable:!0}});Object.defineProperties(i,{show:{get:()=>!0,set:()=>{}}})}}getById(e){return this.objectList.filter(i=>i.id===e)}push(e){this.objectList.filter(i=>i.id===e.id).length||(this.objectList.push(e),this.createGeometry())}remove(e){this.objectList=this.objectList.filter(i=>i.id!==e.id),Object.defineProperties(e,{show:{configurable:!0,get:()=>e._show,set:i=>{e._show=i}}}),this.createGeometry()}},pv=qV});var ZEe,IEe,pEe,Bht,GC,Cv=S(()=>{ic();BF();cv();Qn();Ht();IE();Om();Ev();Rv();uv();ih();Ot();Z3();zV();({OMMT:ZEe,OMMCOLLECTIONT:IEe}=rd),{CATT:pEe,CATCOLLECTIONT:Bht}=ed,GC=class extends V_{constructor(e={name=Bs(),referenceFrame=$i.FIXED,calcVelocity=!1,entityDefault={}}={}){super(e.name),this._viewer=void 0,this.OMM=null,this.CATRAW=null,this.CAT=null,this.COMBINEDOMMCAT=[],this.lastLoaded=null,this.options=e,this._wasmModule=null,this._registered=!1,this._entityCollection.referenceFrame=$i.FIXED,this._entityCollection.calcVelocity=e.calcVelocity||!1;let i=(n,s,o,r)=>{o.filter(a=>a.properties?.pointer).forEach(a=>{this._wasmModule.removeEntity(a.properties.pointer)}),this._entityCollection.referenceFrame=this._viewer?.scene.referenceFrame||this._entityCollection.referenceFrame};this._entityCollection.collectionChanged.addEventListener(i,this),this._orbits={[Ni.LEO]:[],[Ni.MEO]:[],[Ni.HEO]:[],[Ni.GEO]:[],[Ni.IGO]:[],[Ni.EGO]:[],[Ni.GEOIADC]:[],[Ni.GEOSYNC]:[],[Ni.SUNSYNC]:[],[Ni.SEMISYNC]:[],[Ni.POLAR]:[],[Ni.UNKNOWN]:[]}}onAdd(e){~e.getByName(this._coverageGroup.name).length&&e.add(this._coverageGroup)}onRemove(e){e.getByName(this._coverageGroup.name).length&&e.remove(this._coverageGroup)}async load(e){return await this.loadOMM(e,"tle")}loadOMM(e,i,n=!1){if(!e)throw new Y('The parameter "omm" is required.');if(!i)throw new Y('The parameter "satcat" is required.');return new Promise(async s=>{let o=await KV.initInstance();if(this._wasmModule=o.wasmModule,this._coverageGroup=this._coverageGroup||new pv({samples:72,sdc:this,coverageType:1,angle:90,groundCoverageOnly:!1,color:Zt.LIMEGREEN.withAlpha(.5)}),this.entities.suspendEvents(),this._wasmSatelliteCatalog=this._wasmSatelliteCatalog||o.instance,(e instanceof ArrayBuffer||e instanceof Uint8Array)&&(e instanceof ArrayBuffer&&(e=new Uint8Array(e)),this.OMM=UF(e,"OMM",rd)),(e.RECORDS||Array.isArray(e))&&(this.OMM={RECORDS:e?.RECORDS||e}),!this.OMM)throw Error("OMMCOLLECTIONT invalid");let r=[];this.CAT=new Bht,(i instanceof ArrayBuffer||e instanceof Uint8Array)&&(i instanceof ArrayBuffer&&(i=new Uint8Array(i)),this.CATRAW=UF(i,"CAT",ed)),(i.RECORDS||Array.isArray(i))&&(this.CATRAW={RECORDS:i?.RECORDS||i});for(let a=0;a<this.CATRAW.RECORDS.length;a++)r[this.CATRAW.RECORDS[a].NORAD_CAT_ID]=a;for(let a=0;a<this.OMM.RECORDS.length;a++){let h=this.OMM.RECORDS[a];this.CAT.RECORDS[a]=this.CATRAW.RECORDS[r[h.NORAD_CAT_ID]],this.COMBINEDOMMCAT[a]={};for(let f in h)h.hasOwnProperty(f)&&(this.COMBINEDOMMCAT[a][f]=h[f]);for(let f in this.CAT.RECORDS[a])this.CAT.RECORDS[a].hasOwnProperty(f)&&(this.COMBINEDOMMCAT[a][f]=this.CAT.RECORDS[a][f]);let A,d=h.NORAD_CAT_ID;if(A=this.entities.getById(d))A.loadOMM(h);else{let f={id:d,name:this.CAT.RECORDS[a]?.OBJECT_NAME||d,properties:{INDEX:a,CAT:this.CAT.RECORDS[a],OMM:h},point:{pixelSize:1,scaleByDistance:null},label:{show:!1,text:`${h.OBJECT_ID.toString().padStart(5,0)}`,font:"1rem Helvetica",showBackground:!0,horizontalOrigin:to.LEFT,backgroundColor:new Zt(.1,.1,.1,.9),pixelOffset:new l(10,0),scaleByDistance:new gi(150,1.5,13e7,0),pixelOffsetScaleByDistance:new gi(150,3,15e6,.5)}};for(let E in this.options.entityDefault)this.options.entityDefault[E]&&(f[E]=Object.assign({},f[E]||{},this.options.entityDefault[E]));if(f&&this._wasmModule&&h)try{let E=new OC(f,this._wasmModule,this._wasmSatelliteCatalog,h);A=this.entities.add(E,a);let{APOGEE:_,PERIGEE:R}=E.properties.CAT.getValue(),{SEMI_MAJOR_AXIS:I,SEMI_MINOR_AXIS:C}=E.properties.OMM.getValue(),{ECCENTRICITY:N}=E.properties.OMM.getValue();_/=1e3,R/=1e3,this.CAT.RECORDS[a]&&(this.CAT.RECORDS[a].APOGEE=_,this.CAT.RECORDS[a].PERIGEE=R),this.OMM.RECORDS[a]&&(this.OMM.RECORDS[a].SEMI_MAJOR_AXIS=I,this.OMM.RECORDS[a].SEMI_MINOR_AXIS=C,this.OMM.RECORDS[a].ECCENTRICITY=N),this.COMBINEDOMMCAT[a]={...this.COMBINEDOMMCAT[a],APOGEE:_,PERIGEE:R,SEMI_MAJOR_AXIS:I,SEMI_MINOR_AXIS:C,ECCENTRICITY:N}}catch(E){globalThis.error||(console.log(E),globalThis.error=E)}}}this.entities._suspendCount&&this.entities.resumeEvents(),this.entities.referenceFrame=this._viewer?.scene.referenceFrame,s(this)})}getEntitiesByOrbitType(e){return this._orbits[e]}categorizeSatellites(){for(let e in Ni)this._orbits[e]&&(this._orbits[e]=[]);for(let e=0;e<this.entities.values.length;e++){let i=this.entities.values[e],n=_v(i);for(let s in n)if(n[s]){let o=n[s];o===Ni.LEO?this.LEO.push(i):o===Ni.MEO?this.MEO.push(i):o===Ni.HEO?this.HEO.push(i):o===Ni.GEO?this.GEO.push(i):o===Ni.IGO?this.IGO.push(i):o===Ni.EGO?this.EGO.push(i):o===Ni.GEOIADC?this.GEOIADC.push(i):o===Ni.GEOSYNC?this.GEOSYNC.push(i):o===Ni.SUNSYNC?this.SUNSYNC.push(i):o===Ni.SEMISYNC?this.SEMISYNC.push(i):o===Ni.POLAR?this.POLAR.push(i):o===Ni.UNKNOWN&&this.UNKNOWN.push(i)}}}}});var $V={};He($V,{default:()=>Wht});async function Ght(t){let{transferEntities:e,screeningObjectIds:i}=t,n=[],{OMM:s,CAT:o}=e,r=new GC({name:"workerCatalog"});await r.loadOMM(s,o);let a=r._wasmSatelliteCatalog.conjunctionAssessment(t.start,t.stop,t.step,t.radius,i);for(let h=0;h<a.size();h++){let A=a.get(h);n.push({primary:A.primary.catalogNumber,secondary:A.secondary.catalogNumber,TCA:A.TCA,distance:A.distance})}return n}var Wht,tS=S(()=>{Ns();Cv();Wht=Wi(Ght)});var eS={};He(eS,{default:()=>Uht});function Dht(t,e){let i=TA.unpackCombineGeometryParameters(t),n=TA.combineGeometry(i);return TA.packCombineGeometryResults(n,e)}var Uht,iS=S(()=>{KI();Ns();Uht=Wi(Dht)});function gr(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.minimum,i=t.maximum;if(p.typeOf.object("min",e),p.typeOf.object("max",i),m(t.offsetAttribute)&&t.offsetAttribute===Pe.TOP)throw new Y("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");let n=Z(t.vertexFormat,St.DEFAULT);this._minimum=l.clone(e),this._maximum=l.clone(i),this._vertexFormat=n,this._offsetAttribute=t.offsetAttribute,this._workerName="createBoxGeometry"}var Mht,Tv,Nv,Fv,gv,nS,cR,sS=S(()=>{_i();Ht();ae();oi();Ft();mt();Ot();yi();ji();En();go();Xi();Ls();Mht=new l;gr.fromDimensions=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.dimensions;p.typeOf.object("dimensions",e),p.typeOf.number.greaterThanOrEquals("dimensions.x",e.x,0),p.typeOf.number.greaterThanOrEquals("dimensions.y",e.y,0),p.typeOf.number.greaterThanOrEquals("dimensions.z",e.z,0);let i=l.multiplyByScalar(e,.5,new l);return new gr({minimum:l.negate(i,new l),maximum:i,vertexFormat:t.vertexFormat,offsetAttribute:t.offsetAttribute})};gr.fromAxisAlignedBoundingBox=function(t){return p.typeOf.object("boundingBox",t),new gr({minimum:t.minimum,maximum:t.maximum})};gr.packedLength=2*l.packedLength+St.packedLength+1;gr.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),l.pack(t._minimum,e,i),l.pack(t._maximum,e,i+l.packedLength),St.pack(t._vertexFormat,e,i+2*l.packedLength),e[i+2*l.packedLength+St.packedLength]=Z(t._offsetAttribute,-1),e};Tv=new l,Nv=new l,Fv=new St,gv={minimum:Tv,maximum:Nv,vertexFormat:Fv,offsetAttribute:void 0};gr.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=l.unpack(t,e,Tv),s=l.unpack(t,e+l.packedLength,Nv),o=St.unpack(t,e+2*l.packedLength,Fv),r=t[e+2*l.packedLength+St.packedLength];return m(i)?(i._minimum=l.clone(n,i._minimum),i._maximum=l.clone(s,i._maximum),i._vertexFormat=St.clone(o,i._vertexFormat),i._offsetAttribute=r===-1?void 0:r,i):(gv.offsetAttribute=r===-1?void 0:r,new gr(gv))};gr.createGeometry=function(t){let e=t._minimum,i=t._maximum,n=t._vertexFormat;if(l.equals(e,i))return;let s=new we,o,r;if(n.position&&(n.st||n.normal||n.tangent||n.bitangent)){if(n.position&&(r=new Float64Array(6*4*3),r[0]=e.x,r[1]=e.y,r[2]=i.z,r[3]=i.x,r[4]=e.y,r[5]=i.z,r[6]=i.x,r[7]=i.y,r[8]=i.z,r[9]=e.x,r[10]=i.y,r[11]=i.z,r[12]=e.x,r[13]=e.y,r[14]=e.z,r[15]=i.x,r[16]=e.y,r[17]=e.z,r[18]=i.x,r[19]=i.y,r[20]=e.z,r[21]=e.x,r[22]=i.y,r[23]=e.z,r[24]=i.x,r[25]=e.y,r[26]=e.z,r[27]=i.x,r[28]=i.y,r[29]=e.z,r[30]=i.x,r[31]=i.y,r[32]=i.z,r[33]=i.x,r[34]=e.y,r[35]=i.z,r[36]=e.x,r[37]=e.y,r[38]=e.z,r[39]=e.x,r[40]=i.y,r[41]=e.z,r[42]=e.x,r[43]=i.y,r[44]=i.z,r[45]=e.x,r[46]=e.y,r[47]=i.z,r[48]=e.x,r[49]=i.y,r[50]=e.z,r[51]=i.x,r[52]=i.y,r[53]=e.z,r[54]=i.x,r[55]=i.y,r[56]=i.z,r[57]=e.x,r[58]=i.y,r[59]=i.z,r[60]=e.x,r[61]=e.y,r[62]=e.z,r[63]=i.x,r[64]=e.y,r[65]=e.z,r[66]=i.x,r[67]=e.y,r[68]=i.z,r[69]=e.x,r[70]=e.y,r[71]=i.z,s.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:r})),n.normal){let A=new Float32Array(72);A[0]=0,A[1]=0,A[2]=1,A[3]=0,A[4]=0,A[5]=1,A[6]=0,A[7]=0,A[8]=1,A[9]=0,A[10]=0,A[11]=1,A[12]=0,A[13]=0,A[14]=-1,A[15]=0,A[16]=0,A[17]=-1,A[18]=0,A[19]=0,A[20]=-1,A[21]=0,A[22]=0,A[23]=-1,A[24]=1,A[25]=0,A[26]=0,A[27]=1,A[28]=0,A[29]=0,A[30]=1,A[31]=0,A[32]=0,A[33]=1,A[34]=0,A[35]=0,A[36]=-1,A[37]=0,A[38]=0,A[39]=-1,A[40]=0,A[41]=0,A[42]=-1,A[43]=0,A[44]=0,A[45]=-1,A[46]=0,A[47]=0,A[48]=0,A[49]=1,A[50]=0,A[51]=0,A[52]=1,A[53]=0,A[54]=0,A[55]=1,A[56]=0,A[57]=0,A[58]=1,A[59]=0,A[60]=0,A[61]=-1,A[62]=0,A[63]=0,A[64]=-1,A[65]=0,A[66]=0,A[67]=-1,A[68]=0,A[69]=0,A[70]=-1,A[71]=0,s.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:A})}if(n.st){let A=new Float32Array(48);A[0]=0,A[1]=0,A[2]=1,A[3]=0,A[4]=1,A[5]=1,A[6]=0,A[7]=1,A[8]=1,A[9]=0,A[10]=0,A[11]=0,A[12]=0,A[13]=1,A[14]=1,A[15]=1,A[16]=0,A[17]=0,A[18]=1,A[19]=0,A[20]=1,A[21]=1,A[22]=0,A[23]=1,A[24]=1,A[25]=0,A[26]=0,A[27]=0,A[28]=0,A[29]=1,A[30]=1,A[31]=1,A[32]=1,A[33]=0,A[34]=0,A[35]=0,A[36]=0,A[37]=1,A[38]=1,A[39]=1,A[40]=0,A[41]=0,A[42]=1,A[43]=0,A[44]=1,A[45]=1,A[46]=0,A[47]=1,s.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:A})}if(n.tangent){let A=new Float32Array(72);A[0]=1,A[1]=0,A[2]=0,A[3]=1,A[4]=0,A[5]=0,A[6]=1,A[7]=0,A[8]=0,A[9]=1,A[10]=0,A[11]=0,A[12]=-1,A[13]=0,A[14]=0,A[15]=-1,A[16]=0,A[17]=0,A[18]=-1,A[19]=0,A[20]=0,A[21]=-1,A[22]=0,A[23]=0,A[24]=0,A[25]=1,A[26]=0,A[27]=0,A[28]=1,A[29]=0,A[30]=0,A[31]=1,A[32]=0,A[33]=0,A[34]=1,A[35]=0,A[36]=0,A[37]=-1,A[38]=0,A[39]=0,A[40]=-1,A[41]=0,A[42]=0,A[43]=-1,A[44]=0,A[45]=0,A[46]=-1,A[47]=0,A[48]=-1,A[49]=0,A[50]=0,A[51]=-1,A[52]=0,A[53]=0,A[54]=-1,A[55]=0,A[56]=0,A[57]=-1,A[58]=0,A[59]=0,A[60]=1,A[61]=0,A[62]=0,A[63]=1,A[64]=0,A[65]=0,A[66]=1,A[67]=0,A[68]=0,A[69]=1,A[70]=0,A[71]=0,s.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:A})}if(n.bitangent){let A=new Float32Array(72);A[0]=0,A[1]=1,A[2]=0,A[3]=0,A[4]=1,A[5]=0,A[6]=0,A[7]=1,A[8]=0,A[9]=0,A[10]=1,A[11]=0,A[12]=0,A[13]=1,A[14]=0,A[15]=0,A[16]=1,A[17]=0,A[18]=0,A[19]=1,A[20]=0,A[21]=0,A[22]=1,A[23]=0,A[24]=0,A[25]=0,A[26]=1,A[27]=0,A[28]=0,A[29]=1,A[30]=0,A[31]=0,A[32]=1,A[33]=0,A[34]=0,A[35]=1,A[36]=0,A[37]=0,A[38]=1,A[39]=0,A[40]=0,A[41]=1,A[42]=0,A[43]=0,A[44]=1,A[45]=0,A[46]=0,A[47]=1,A[48]=0,A[49]=0,A[50]=1,A[51]=0,A[52]=0,A[53]=1,A[54]=0,A[55]=0,A[56]=1,A[57]=0,A[58]=0,A[59]=1,A[60]=0,A[61]=0,A[62]=1,A[63]=0,A[64]=0,A[65]=1,A[66]=0,A[67]=0,A[68]=1,A[69]=0,A[70]=0,A[71]=1,s.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:A})}o=new Uint16Array(6*2*3),o[0]=0,o[1]=1,o[2]=2,o[3]=0,o[4]=2,o[5]=3,o[6]=6,o[7]=5,o[8]=4,o[9]=7,o[10]=6,o[11]=4,o[12]=8,o[13]=9,o[14]=10,o[15]=8,o[16]=10,o[17]=11,o[18]=14,o[19]=13,o[20]=12,o[21]=15,o[22]=14,o[23]=12,o[24]=18,o[25]=17,o[26]=16,o[27]=19,o[28]=18,o[29]=16,o[30]=20,o[31]=21,o[32]=22,o[33]=20,o[34]=22,o[35]=23}else r=new Float64Array(8*3),r[0]=e.x,r[1]=e.y,r[2]=e.z,r[3]=i.x,r[4]=e.y,r[5]=e.z,r[6]=i.x,r[7]=i.y,r[8]=e.z,r[9]=e.x,r[10]=i.y,r[11]=e.z,r[12]=e.x,r[13]=e.y,r[14]=i.z,r[15]=i.x,r[16]=e.y,r[17]=i.z,r[18]=i.x,r[19]=i.y,r[20]=i.z,r[21]=e.x,r[22]=i.y,r[23]=i.z,s.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:r}),o=new Uint16Array(6*2*3),o[0]=4,o[1]=5,o[2]=6,o[3]=4,o[4]=6,o[5]=7,o[6]=1,o[7]=0,o[8]=3,o[9]=1,o[10]=3,o[11]=2,o[12]=1,o[13]=6,o[14]=5,o[15]=1,o[16]=2,o[17]=6,o[18]=2,o[19]=3,o[20]=7,o[21]=2,o[22]=7,o[23]=6,o[24]=3,o[25]=0,o[26]=4,o[27]=3,o[28]=4,o[29]=7,o[30]=0,o[31]=1,o[32]=5,o[33]=0,o[34]=5,o[35]=4;let a=l.subtract(i,e,Mht),h=l.magnitude(a)*.5;if(m(t._offsetAttribute)){let A=r.length,d=t._offsetAttribute===Pe.NONE?0:1,f=new Uint8Array(A/3).fill(d);s.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:f})}return new se({attributes:s,indices:o,primitiveType:ne.TRIANGLES,boundingSphere:new Nt(l.ZERO,h),offsetAttribute:t._offsetAttribute})};gr.getUnitBox=function(){return m(nS)||(nS=gr.createGeometry(gr.fromDimensions({dimensions:new l(1,1,1),vertexFormat:St.POSITION_ONLY}))),nS};cR=gr});var oS={};He(oS,{default:()=>kht});function Qht(t,e){return m(e)&&(t=cR.unpack(t,e)),cR.createGeometry(t)}var kht,rS=S(()=>{sS();mt();kht=Qht});function VA(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.minimum,i=t.maximum;if(p.typeOf.object("min",e),p.typeOf.object("max",i),m(t.offsetAttribute)&&t.offsetAttribute===Pe.TOP)throw new Y("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");this._min=l.clone(e),this._max=l.clone(i),this._offsetAttribute=t.offsetAttribute,this._workerName="createBoxOutlineGeometry"}var Lht,Yv,Vv,bv,aS,Sv=S(()=>{_i();Ht();ae();oi();Ft();mt();Ot();yi();ji();En();go();Xi();Lht=new l;VA.fromDimensions=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.dimensions;p.typeOf.object("dimensions",e),p.typeOf.number.greaterThanOrEquals("dimensions.x",e.x,0),p.typeOf.number.greaterThanOrEquals("dimensions.y",e.y,0),p.typeOf.number.greaterThanOrEquals("dimensions.z",e.z,0);let i=l.multiplyByScalar(e,.5,new l);return new VA({minimum:l.negate(i,new l),maximum:i,offsetAttribute:t.offsetAttribute})};VA.fromAxisAlignedBoundingBox=function(t){return p.typeOf.object("boundindBox",t),new VA({minimum:t.minimum,maximum:t.maximum})};VA.packedLength=2*l.packedLength+1;VA.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),l.pack(t._min,e,i),l.pack(t._max,e,i+l.packedLength),e[i+l.packedLength*2]=Z(t._offsetAttribute,-1),e};Yv=new l,Vv=new l,bv={minimum:Yv,maximum:Vv,offsetAttribute:void 0};VA.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=l.unpack(t,e,Yv),s=l.unpack(t,e+l.packedLength,Vv),o=t[e+l.packedLength*2];return m(i)?(i._min=l.clone(n,i._min),i._max=l.clone(s,i._max),i._offsetAttribute=o===-1?void 0:o,i):(bv.offsetAttribute=o===-1?void 0:o,new VA(bv))};VA.createGeometry=function(t){let e=t._min,i=t._max;if(l.equals(e,i))return;let n=new we,s=new Uint16Array(12*2),o=new Float64Array(8*3);o[0]=e.x,o[1]=e.y,o[2]=e.z,o[3]=i.x,o[4]=e.y,o[5]=e.z,o[6]=i.x,o[7]=i.y,o[8]=e.z,o[9]=e.x,o[10]=i.y,o[11]=e.z,o[12]=e.x,o[13]=e.y,o[14]=i.z,o[15]=i.x,o[16]=e.y,o[17]=i.z,o[18]=i.x,o[19]=i.y,o[20]=i.z,o[21]=e.x,o[22]=i.y,o[23]=i.z,n.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:o}),s[0]=4,s[1]=5,s[2]=5,s[3]=6,s[4]=6,s[5]=7,s[6]=7,s[7]=4,s[8]=0,s[9]=1,s[10]=1,s[11]=2,s[12]=2,s[13]=3,s[14]=3,s[15]=0,s[16]=0,s[17]=4,s[18]=1,s[19]=5,s[20]=2,s[21]=6,s[22]=3,s[23]=7;let r=l.subtract(i,e,Lht),a=l.magnitude(r)*.5;if(m(t._offsetAttribute)){let h=o.length,A=t._offsetAttribute===Pe.NONE?0:1,d=new Uint8Array(h/3).fill(A);n.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:d})}return new se({attributes:n,indices:s,primitiveType:ne.LINES,boundingSphere:new Nt(l.ZERO,a),offsetAttribute:t._offsetAttribute})};aS=VA});var AS={};He(AS,{default:()=>wht});function yht(t,e){return m(e)&&(t=aS.unpack(t,e)),aS.createGeometry(t)}var wht,hS=S(()=>{Sv();mt();wht=yht});function gf(t,e,i,n,s,o,r,a,h,A){let d=t+e;l.multiplyByScalar(n,Math.cos(d),WC),l.multiplyByScalar(i,Math.sin(d),Ov),l.add(WC,Ov,WC);let f=Math.cos(t);f=f*f;let E=Math.sin(t);E=E*E;let R=o/Math.sqrt(r*f+s*E)/a;return Ae.fromAxisAngle(WC,R,Bv),lt.fromQuaternion(Bv,Gv),lt.multiplyByVector(Gv,h,A),l.normalize(A,A),l.multiplyByScalar(A,a,A),A}var lS,WC,Ov,Bv,Gv,Wv,Dv,cS,xht,Pht,Jht,jht,ya,dS=S(()=>{Ht();_e();dn();$s();lS={},WC=new l,Ov=new l,Bv=new Ae,Gv=new lt;Wv=new l,Dv=new l,cS=new l,xht=new l;lS.raisePositionsToHeight=function(t,e,i){let n=e.ellipsoid,s=e.height,o=e.extrudedHeight,r=i?t.length/3*2:t.length/3,a=new Float64Array(r*3),h=t.length,A=i?h:0;for(let d=0;d<h;d+=3){let f=d+1,E=d+2,_=l.fromArray(t,d,Wv);n.scaleToGeodeticSurface(_,_);let R=l.clone(_,Dv),I=n.geodeticSurfaceNormal(_,xht),C=l.multiplyByScalar(I,s,cS);l.add(_,C,_),i&&(l.multiplyByScalar(I,o,C),l.add(R,C,R),a[d+A]=R.x,a[f+A]=R.y,a[E+A]=R.z),a[d]=_.x,a[f]=_.y,a[E]=_.z}return a};Pht=new l,Jht=new l,jht=new l;lS.computeEllipsePositions=function(t,e,i){let n=t.semiMinorAxis,s=t.semiMajorAxis,o=t.rotation,r=t.center,a=t.granularity*8,h=n*n,A=s*s,d=s*n,f=l.magnitude(r),E=l.normalize(r,Pht),_=l.cross(l.UNIT_Z,r,Jht);_=l.normalize(_,_);let R=l.cross(E,_,jht),I=1+Math.ceil(L.PI_OVER_TWO/a),C=L.PI_OVER_TWO/(I-1),N=L.PI_OVER_TWO-I*C;N<0&&(I-=Math.ceil(Math.abs(N)/C));let T=2*(I*(I+2)),b=e?new Array(T*3):void 0,F=0,B=Wv,U=Dv,Q=I*4*3,M=Q-1,k=0,y=i?new Array(Q):void 0,c,g,O,D,w;for(N=L.PI_OVER_TWO,B=gf(N,o,R,_,h,d,A,f,E,B),e&&(b[F++]=B.x,b[F++]=B.y,b[F++]=B.z),i&&(y[M--]=B.z,y[M--]=B.y,y[M--]=B.x),N=L.PI_OVER_TWO-C,c=1;c<I+1;++c){if(B=gf(N,o,R,_,h,d,A,f,E,B),U=gf(Math.PI-N,o,R,_,h,d,A,f,E,U),e){for(b[F++]=B.x,b[F++]=B.y,b[F++]=B.z,O=2*c+2,g=1;g<O-1;++g)D=g/(O-1),w=l.lerp(B,U,D,cS),b[F++]=w.x,b[F++]=w.y,b[F++]=w.z;b[F++]=U.x,b[F++]=U.y,b[F++]=U.z}i&&(y[M--]=B.z,y[M--]=B.y,y[M--]=B.x,y[k++]=U.x,y[k++]=U.y,y[k++]=U.z),N=L.PI_OVER_TWO-(c+1)*C}for(c=I;c>1;--c){if(N=L.PI_OVER_TWO-(c-1)*C,B=gf(-N,o,R,_,h,d,A,f,E,B),U=gf(N+Math.PI,o,R,_,h,d,A,f,E,U),e){for(b[F++]=B.x,b[F++]=B.y,b[F++]=B.z,O=2*(c-1)+2,g=1;g<O-1;++g)D=g/(O-1),w=l.lerp(B,U,D,cS),b[F++]=w.x,b[F++]=w.y,b[F++]=w.z;b[F++]=U.x,b[F++]=U.y,b[F++]=U.z}i&&(y[M--]=B.z,y[M--]=B.y,y[M--]=B.x,y[k++]=U.x,y[k++]=U.y,y[k++]=U.z)}N=L.PI_OVER_TWO,B=gf(-N,o,R,_,h,d,A,f,E,B);let x={};return e&&(b[F++]=B.x,b[F++]=B.y,b[F++]=B.z,x.positions=b,x.numPts=I),i&&(y[M--]=B.z,y[M--]=B.y,y[M--]=B.x,x.outerPositions=y),x};ya=lS});function Pv(t,e,i){let n=e.vertexFormat,s=e.center,o=e.semiMajorAxis,r=e.semiMinorAxis,a=e.ellipsoid,h=e.stRotation,A=i?t.length/3*2:t.length/3,d=e.shadowVolume,f=n.st?new Float32Array(A*2):void 0,E=n.normal?new Float32Array(A*3):void 0,_=n.tangent?new Float32Array(A*3):void 0,R=n.bitangent?new Float32Array(A*3):void 0,I=d?new Float32Array(A*3):void 0,C=0,N=Qv,T=kv,b=Lv,F=new Ss(a),B=F.project(a.cartesianToCartographic(s,MC),yv),U=a.scaleToGeodeticSurface(s,Tf);a.geodeticSurfaceNormal(U,U);let Q=Mv,M=Hht;if(h!==0){let w=Ae.fromAxisAngle(U,h,ES);Q=lt.fromQuaternion(w,Q),w=Ae.fromAxisAngle(U,-h,ES),M=lt.fromQuaternion(w,M)}else Q=lt.clone(lt.IDENTITY,Q),M=lt.clone(lt.IDENTITY,M);let k=nt.fromElements(Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY,wv),y=nt.fromElements(Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY,xv),c=t.length,g=i?c:0,O=g/3*2;for(let w=0;w<c;w+=3){let x=w+1,H=w+2,j=l.fromArray(t,w,Tf);if(n.st){let X=lt.multiplyByVector(Q,j,mS),tt=F.project(a.cartesianToCartographic(X,MC),fS);l.subtract(tt,B,tt),bs.x=(tt.x+o)/(2*o),bs.y=(tt.y+r)/(2*r),k.x=Math.min(bs.x,k.x),k.y=Math.min(bs.y,k.y),y.x=Math.max(bs.x,y.x),y.y=Math.max(bs.y,y.y),i&&(f[C+O]=bs.x,f[C+1+O]=bs.y),f[C++]=bs.x,f[C++]=bs.y}(n.normal||n.tangent||n.bitangent||d)&&(N=a.geodeticSurfaceNormal(j,N),d&&(I[w+g]=-N.x,I[x+g]=-N.y,I[H+g]=-N.z),(n.normal||n.tangent||n.bitangent)&&((n.tangent||n.bitangent)&&(T=l.normalize(l.cross(l.UNIT_Z,N,T),T),lt.multiplyByVector(M,T,T)),n.normal&&(E[w]=N.x,E[x]=N.y,E[H]=N.z,i&&(E[w+g]=-N.x,E[x+g]=-N.y,E[H+g]=-N.z)),n.tangent&&(_[w]=T.x,_[x]=T.y,_[H]=T.z,i&&(_[w+g]=-T.x,_[x+g]=-T.y,_[H+g]=-T.z)),n.bitangent&&(b=l.normalize(l.cross(N,T,b),b),R[w]=b.x,R[x]=b.y,R[H]=b.z,i&&(R[w+g]=b.x,R[x+g]=b.y,R[H+g]=b.z))))}if(n.st){c=f.length;for(let w=0;w<c;w+=2)f[w]=(f[w]-k.x)/(y.x-k.x),f[w+1]=(f[w+1]-k.y)/(y.y-k.y)}let D=new we;if(n.position){let w=ya.raisePositionsToHeight(t,e,i);D.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:w})}if(n.st&&(D.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:f})),n.normal&&(D.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:E})),n.tangent&&(D.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_})),n.bitangent&&(D.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:R})),d&&(D.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:I})),i&&m(e.offsetAttribute)){let w=new Uint8Array(A);if(e.offsetAttribute===Pe.TOP)w=w.fill(1,0,A/2);else{let x=e.offsetAttribute===Pe.NONE?0:1;w=w.fill(x)}D.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:w})}return D}function Jv(t){let e=new Array(12*(t*(t+1))-6),i=0,n,s,o,r,a;for(n=0,o=1,r=0;r<3;r++)e[i++]=o++,e[i++]=n,e[i++]=o;for(r=2;r<t+1;++r){for(o=r*(r+1)-1,n=(r-1)*r-1,e[i++]=o++,e[i++]=n,e[i++]=o,s=2*r,a=0;a<s-1;++a)e[i++]=o,e[i++]=n++,e[i++]=n,e[i++]=o++,e[i++]=n,e[i++]=o;e[i++]=o++,e[i++]=n,e[i++]=o}for(s=t*2,++o,++n,r=0;r<s-1;++r)e[i++]=o,e[i++]=n++,e[i++]=n,e[i++]=o++,e[i++]=n,e[i++]=o;for(e[i++]=o,e[i++]=n++,e[i++]=n,e[i++]=o++,e[i++]=n++,e[i++]=n,++n,r=t-1;r>1;--r){for(e[i++]=n++,e[i++]=n,e[i++]=o,s=2*r,a=0;a<s-1;++a)e[i++]=o,e[i++]=n++,e[i++]=n,e[i++]=o++,e[i++]=n,e[i++]=o;e[i++]=n++,e[i++]=n++,e[i++]=o++}for(r=0;r<3;r++)e[i++]=n++,e[i++]=n,e[i++]=o;return e}function vht(t){let e=t.center;Ad=l.multiplyByScalar(t.ellipsoid.geodeticSurfaceNormal(e,Ad),t.height,Ad),Ad=l.add(e,Ad,Ad);let i=new Nt(Ad,t.semiMajorAxis),n=ya.computeEllipsePositions(t,!0,!1),s=n.positions,o=n.numPts,r=Pv(s,t,!1),a=Jv(o);return a=te.createTypedArray(s.length/3,a),{boundingSphere:i,attributes:r,indices:a}}function zht(t,e){let i=e.vertexFormat,n=e.center,s=e.semiMajorAxis,o=e.semiMinorAxis,r=e.ellipsoid,a=e.height,h=e.extrudedHeight,A=e.stRotation,d=t.length/3*2,f=new Float64Array(d*3),E=i.st?new Float32Array(d*2):void 0,_=i.normal?new Float32Array(d*3):void 0,R=i.tangent?new Float32Array(d*3):void 0,I=i.bitangent?new Float32Array(d*3):void 0,C=e.shadowVolume,N=C?new Float32Array(d*3):void 0,T=0,b=Qv,F=kv,B=Lv,U=new Ss(r),Q=U.project(r.cartesianToCartographic(n,MC),yv),M=r.scaleToGeodeticSurface(n,Tf);r.geodeticSurfaceNormal(M,M);let k=Ae.fromAxisAngle(M,A,ES),y=lt.fromQuaternion(k,Mv),c=nt.fromElements(Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY,wv),g=nt.fromElements(Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY,xv),O=t.length,D=O/3*2;for(let x=0;x<O;x+=3){let H=x+1,j=x+2,X=l.fromArray(t,x,Tf),tt;if(i.st){let It=lt.multiplyByVector(y,X,mS),gt=U.project(r.cartesianToCartographic(It,MC),fS);l.subtract(gt,Q,gt),bs.x=(gt.x+s)/(2*s),bs.y=(gt.y+o)/(2*o),c.x=Math.min(bs.x,c.x),c.y=Math.min(bs.y,c.y),g.x=Math.max(bs.x,g.x),g.y=Math.max(bs.y,g.y),E[T+D]=bs.x,E[T+1+D]=bs.y,E[T++]=bs.x,E[T++]=bs.y}X=r.scaleToGeodeticSurface(X,X),tt=l.clone(X,mS),b=r.geodeticSurfaceNormal(X,b),C&&(N[x+O]=-b.x,N[H+O]=-b.y,N[j+O]=-b.z);let G=l.multiplyByScalar(b,a,Uv);if(X=l.add(X,G,X),G=l.multiplyByScalar(b,h,G),tt=l.add(tt,G,tt),i.position&&(f[x+O]=tt.x,f[H+O]=tt.y,f[j+O]=tt.z,f[x]=X.x,f[H]=X.y,f[j]=X.z),i.normal||i.tangent||i.bitangent){B=l.clone(b,B);let It=l.fromArray(t,(x+3)%O,Uv);l.subtract(It,X,It);let gt=l.subtract(tt,X,fS);b=l.normalize(l.cross(gt,It,b),b),i.normal&&(_[x]=b.x,_[H]=b.y,_[j]=b.z,_[x+O]=b.x,_[H+O]=b.y,_[j+O]=b.z),i.tangent&&(F=l.normalize(l.cross(B,b,F),F),R[x]=F.x,R[H]=F.y,R[j]=F.z,R[x+O]=F.x,R[x+1+O]=F.y,R[x+2+O]=F.z),i.bitangent&&(I[x]=B.x,I[H]=B.y,I[j]=B.z,I[x+O]=B.x,I[H+O]=B.y,I[j+O]=B.z)}}if(i.st){O=E.length;for(let x=0;x<O;x+=2)E[x]=(E[x]-c.x)/(g.x-c.x),E[x+1]=(E[x+1]-c.y)/(g.y-c.y)}let w=new we;if(i.position&&(w.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:f})),i.st&&(w.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:E})),i.normal&&(w.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_})),i.tangent&&(w.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:R})),i.bitangent&&(w.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:I})),C&&(w.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:N})),m(e.offsetAttribute)){let x=new Uint8Array(d);if(e.offsetAttribute===Pe.TOP)x=x.fill(1,0,d/2);else{let H=e.offsetAttribute===Pe.NONE?0:1;x=x.fill(H)}w.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:x})}return w}function Kht(t){let e=t.length/3,i=te.createTypedArray(e,e*6),n=0;for(let s=0;s<e;s++){let o=s,r=s+e,a=(o+1)%e,h=a+e;i[n++]=o,i[n++]=r,i[n++]=a,i[n++]=a,i[n++]=r,i[n++]=h}return i}function Xht(t){let e=t.center,i=t.ellipsoid,n=t.semiMajorAxis,s=l.multiplyByScalar(i.geodeticSurfaceNormal(e,Tf),t.height,Tf);DC.center=l.add(e,s,DC.center),DC.radius=n,s=l.multiplyByScalar(i.geodeticSurfaceNormal(e,s),t.extrudedHeight,s),UC.center=l.add(e,s,UC.center),UC.radius=n;let o=ya.computeEllipsePositions(t,!0,!0),r=o.positions,a=o.numPts,h=o.outerPositions,A=Nt.union(DC,UC),d=Pv(r,t,!0),f=Jv(a),E=f.length;f.length=E*2;let _=r.length/3;for(let F=0;F<E;F+=3)f[F+E]=f[F+2]+_,f[F+1+E]=f[F+1]+_,f[F+2+E]=f[F]+_;let R=te.createTypedArray(_*2/3,f),I=new se({attributes:d,indices:R,primitiveType:ne.TRIANGLES}),C=zht(h,t);f=Kht(h);let N=te.createTypedArray(h.length*2/3,f),T=new se({attributes:C,indices:N,primitiveType:ne.TRIANGLES}),b=wi.combineInstances([new Ln({geometry:I}),new Ln({geometry:T})]);return{boundingSphere:A,attributes:b[0].attributes,indices:b[0].indices}}function jv(t,e,i,n,s,o,r){let h=ya.computeEllipsePositions({center:t,semiMajorAxis:e,semiMinorAxis:i,rotation:n,granularity:s},!1,!0).outerPositions,A=h.length/3,d=new Array(A);for(let E=0;E<A;++E)d[E]=l.fromArray(h,E*3);let f=Xt.fromCartesianArray(d,o,r);return f.width>L.PI&&(f.north=f.north>0?L.PI_OVER_TWO-L.EPSILON7:f.north,f.south=f.south<0?L.EPSILON7-L.PI_OVER_TWO:f.south,f.east=L.PI,f.west=-L.PI),f}function OA(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.center,i=Z(t.ellipsoid,ot.WGS84),n=t.semiMajorAxis,s=t.semiMinorAxis,o=Z(t.granularity,L.RADIANS_PER_DEGREE),r=Z(t.vertexFormat,St.DEFAULT);if(p.defined("options.center",e),p.typeOf.number("options.semiMajorAxis",n),p.typeOf.number("options.semiMinorAxis",s),n<s)throw new Y("semiMajorAxis must be greater than or equal to the semiMinorAxis.");if(o<=0)throw new Y("granularity must be greater than zero.");let a=Z(t.height,0),h=Z(t.extrudedHeight,a);this._center=l.clone(e),this._semiMajorAxis=n,this._semiMinorAxis=s,this._ellipsoid=ot.clone(i),this._rotation=Z(t.rotation,0),this._stRotation=Z(t.stRotation,0),this._height=Math.max(h,a),this._granularity=o,this._vertexFormat=St.clone(r),this._extrudedHeight=Math.min(h,a),this._shadowVolume=Z(t.shadowVolume,!1),this._workerName="createEllipseGeometry",this._offsetAttribute=t.offsetAttribute,this._rectangle=void 0,this._textureCoordinateRotationPoints=void 0}function qht(t){let e=-t._stRotation;if(e===0)return[0,0,0,1,1,0];let n=ya.computeEllipsePositions({center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,rotation:t._rotation,granularity:t._granularity},!1,!0).outerPositions,s=n.length/3,o=new Array(s);for(let h=0;h<s;++h)o[h]=l.fromArray(n,h*3);let r=t._ellipsoid,a=t.rectangle;return se._textureCoordinateRotationPoints(o,e,r,a)}var Tf,mS,fS,Uv,bs,Mv,Hht,ES,Qv,kv,Lv,MC,yv,wv,xv,Ad,DC,UC,Hv,vv,zv,SA,wa,_S=S(()=>{_i();Xe();Ht();ri();ae();oi();Ft();mt();Ot();dS();Oe();zA();yi();ji();En();uA();go();gA();Di();_e();dn();Xi();$s();pn();Ls();Tf=new l,mS=new l,fS=new l,Uv=new l,bs=new nt,Mv=new lt,Hht=new lt,ES=new Ae,Qv=new l,kv=new l,Lv=new l,MC=new ut,yv=new l,wv=new nt,xv=new nt;Ad=new l;DC=new Nt,UC=new Nt;OA.packedLength=l.packedLength+ot.packedLength+St.packedLength+9;OA.pack=function(t,e,i){return p.defined("value",t),p.defined("array",e),i=Z(i,0),l.pack(t._center,e,i),i+=l.packedLength,ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,St.pack(t._vertexFormat,e,i),i+=St.packedLength,e[i++]=t._semiMajorAxis,e[i++]=t._semiMinorAxis,e[i++]=t._rotation,e[i++]=t._stRotation,e[i++]=t._height,e[i++]=t._granularity,e[i++]=t._extrudedHeight,e[i++]=t._shadowVolume?1:0,e[i]=Z(t._offsetAttribute,-1),e};Hv=new l,vv=new ot,zv=new St,SA={center:Hv,ellipsoid:vv,vertexFormat:zv,semiMajorAxis:void 0,semiMinorAxis:void 0,rotation:void 0,stRotation:void 0,height:void 0,granularity:void 0,extrudedHeight:void 0,shadowVolume:void 0,offsetAttribute:void 0};OA.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=l.unpack(t,e,Hv);e+=l.packedLength;let s=ot.unpack(t,e,vv);e+=ot.packedLength;let o=St.unpack(t,e,zv);e+=St.packedLength;let r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++],E=t[e++],_=t[e++]===1,R=t[e];return m(i)?(i._center=l.clone(n,i._center),i._ellipsoid=ot.clone(s,i._ellipsoid),i._vertexFormat=St.clone(o,i._vertexFormat),i._semiMajorAxis=r,i._semiMinorAxis=a,i._rotation=h,i._stRotation=A,i._height=d,i._granularity=f,i._extrudedHeight=E,i._shadowVolume=_,i._offsetAttribute=R===-1?void 0:R,i):(SA.height=d,SA.extrudedHeight=E,SA.granularity=f,SA.stRotation=A,SA.rotation=h,SA.semiMajorAxis=r,SA.semiMinorAxis=a,SA.shadowVolume=_,SA.offsetAttribute=R===-1?void 0:R,new OA(SA))};OA.computeRectangle=function(t,e){t=Z(t,Z.EMPTY_OBJECT);let i=t.center,n=Z(t.ellipsoid,ot.WGS84),s=t.semiMajorAxis,o=t.semiMinorAxis,r=Z(t.granularity,L.RADIANS_PER_DEGREE),a=Z(t.rotation,0);if(p.defined("options.center",i),p.typeOf.number("options.semiMajorAxis",s),p.typeOf.number("options.semiMinorAxis",o),s<o)throw new Y("semiMajorAxis must be greater than or equal to the semiMinorAxis.");if(r<=0)throw new Y("granularity must be greater than zero.");return jv(i,s,o,a,r,n,e)};OA.createGeometry=function(t){if(t._semiMajorAxis<=0||t._semiMinorAxis<=0)return;let e=t._height,i=t._extrudedHeight,n=!L.equalsEpsilon(e,i,0,L.EPSILON2);t._center=t._ellipsoid.scaleToGeodeticSurface(t._center,t._center);let s={center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,ellipsoid:t._ellipsoid,rotation:t._rotation,height:e,granularity:t._granularity,vertexFormat:t._vertexFormat,stRotation:t._stRotation},o;if(n)s.extrudedHeight=i,s.shadowVolume=t._shadowVolume,s.offsetAttribute=t._offsetAttribute,o=Xht(s);else if(o=vht(s),m(t._offsetAttribute)){let r=o.attributes.position.values.length,a=t._offsetAttribute===Pe.NONE?0:1,h=new Uint8Array(r/3).fill(a);o.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:h})}return new se({attributes:o.attributes,indices:o.indices,primitiveType:ne.TRIANGLES,boundingSphere:o.boundingSphere,offsetAttribute:t._offsetAttribute})};OA.createShadowVolume=function(t,e,i){let n=t._granularity,s=t._ellipsoid,o=e(n,s),r=i(n,s);return new OA({center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,ellipsoid:s,rotation:t._rotation,stRotation:t._stRotation,granularity:n,extrudedHeight:o,height:r,vertexFormat:St.POSITION_ONLY,shadowVolume:!0})};Object.defineProperties(OA.prototype,{rectangle:{get:function(){return m(this._rectangle)||(this._rectangle=jv(this._center,this._semiMajorAxis,this._semiMinorAxis,this._rotation,this._granularity,this._ellipsoid)),this._rectangle}},textureCoordinateRotationPoints:{get:function(){return m(this._textureCoordinateRotationPoints)||(this._textureCoordinateRotationPoints=qht(this)),this._textureCoordinateRotationPoints}}});wa=OA});function Th(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.radius;p.typeOf.number("radius",e);let i={center:t.center,semiMajorAxis:e,semiMinorAxis:e,ellipsoid:t.ellipsoid,height:t.height,extrudedHeight:t.extrudedHeight,granularity:t.granularity,vertexFormat:t.vertexFormat,stRotation:t.stRotation,shadowVolume:t.shadowVolume};this._ellipseGeometry=new wa(i),this._workerName="createCircleGeometry"}var $ht,No,RS,Kv=S(()=>{Ht();ae();Ft();mt();_S();Oe();Ls();Th.packedLength=wa.packedLength;Th.pack=function(t,e,i){return p.typeOf.object("value",t),wa.pack(t._ellipseGeometry,e,i)};$ht=new wa({center:new l,semiMajorAxis:1,semiMinorAxis:1}),No={center:new l,radius:void 0,ellipsoid:ot.clone(ot.UNIT_SPHERE),height:void 0,extrudedHeight:void 0,granularity:void 0,vertexFormat:new St,stRotation:void 0,semiMajorAxis:void 0,semiMinorAxis:void 0,shadowVolume:void 0};Th.unpack=function(t,e,i){let n=wa.unpack(t,e,$ht);return No.center=l.clone(n._center,No.center),No.ellipsoid=ot.clone(n._ellipsoid,No.ellipsoid),No.height=n._height,No.extrudedHeight=n._extrudedHeight,No.granularity=n._granularity,No.vertexFormat=St.clone(n._vertexFormat,No.vertexFormat),No.stRotation=n._stRotation,No.shadowVolume=n._shadowVolume,m(i)?(No.semiMajorAxis=n._semiMajorAxis,No.semiMinorAxis=n._semiMinorAxis,i._ellipseGeometry=new wa(No),i):(No.radius=n._semiMajorAxis,new Th(No))};Th.createGeometry=function(t){return wa.createGeometry(t._ellipseGeometry)};Th.createShadowVolume=function(t,e,i){let n=t._ellipseGeometry._granularity,s=t._ellipseGeometry._ellipsoid,o=e(n,s),r=i(n,s);return new Th({center:t._ellipseGeometry._center,radius:t._ellipseGeometry._semiMajorAxis,ellipsoid:s,stRotation:t._ellipseGeometry._stRotation,granularity:n,extrudedHeight:o,height:r,vertexFormat:St.POSITION_ONLY,shadowVolume:!0})};Object.defineProperties(Th.prototype,{rectangle:{get:function(){return this._ellipseGeometry.rectangle}},textureCoordinateRotationPoints:{get:function(){return this._ellipseGeometry.textureCoordinateRotationPoints}}});RS=Th});var ZS={};He(ZS,{default:()=>ect});function tct(t,e){return m(e)&&(t=RS.unpack(t,e)),t._ellipseGeometry._center=l.clone(t._ellipseGeometry._center),t._ellipseGeometry._ellipsoid=ot.clone(t._ellipseGeometry._ellipsoid),RS.createGeometry(t)}var ect,IS=S(()=>{Ht();Kv();mt();Oe();ect=tct});function ict(t){let e=t.center;hd=l.multiplyByScalar(t.ellipsoid.geodeticSurfaceNormal(e,hd),t.height,hd),hd=l.add(e,hd,hd);let i=new Nt(hd,t.semiMajorAxis),n=ya.computeEllipsePositions(t,!1,!0).outerPositions,s=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:ya.raisePositionsToHeight(n,t,!1)})}),o=n.length/3,r=te.createTypedArray(o,o*2),a=0;for(let h=0;h<o;++h)r[a++]=h,r[a++]=(h+1)%o;return{boundingSphere:i,attributes:s,indices:r}}function nct(t){let e=t.center,i=t.ellipsoid,n=t.semiMajorAxis,s=l.multiplyByScalar(i.geodeticSurfaceNormal(e,Xv),t.height,Xv);QC.center=l.add(e,s,QC.center),QC.radius=n,s=l.multiplyByScalar(i.geodeticSurfaceNormal(e,s),t.extrudedHeight,s),kC.center=l.add(e,s,kC.center),kC.radius=n;let o=ya.computeEllipsePositions(t,!1,!0).outerPositions,r=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:ya.raisePositionsToHeight(o,t,!0)})});o=r.position.values;let a=Nt.union(QC,kC),h=o.length/3;if(m(t.offsetAttribute)){let R=new Uint8Array(h);if(t.offsetAttribute===Pe.TOP)R=R.fill(1,0,h/2);else{let I=t.offsetAttribute===Pe.NONE?0:1;R=R.fill(I)}r.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:R})}let A=Z(t.numberOfVerticalLines,16);A=L.clamp(A,0,h/2);let d=te.createTypedArray(h,h*2+A*2);h/=2;let f=0,E;for(E=0;E<h;++E)d[f++]=E,d[f++]=(E+1)%h,d[f++]=E+h,d[f++]=(E+1)%h+h;let _;if(A>0){let R=Math.min(A,h);_=Math.round(h/R);let I=Math.min(_*A,h);for(E=0;E<I;E+=_)d[f++]=E,d[f++]=E+h}return{boundingSphere:a,attributes:r,indices:d}}function Nf(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.center,i=Z(t.ellipsoid,ot.WGS84),n=t.semiMajorAxis,s=t.semiMinorAxis,o=Z(t.granularity,L.RADIANS_PER_DEGREE);if(!m(e))throw new Y("center is required.");if(!m(n))throw new Y("semiMajorAxis is required.");if(!m(s))throw new Y("semiMinorAxis is required.");if(n<s)throw new Y("semiMajorAxis must be greater than or equal to the semiMinorAxis.");if(o<=0)throw new Y("granularity must be greater than zero.");let r=Z(t.height,0),a=Z(t.extrudedHeight,r);this._center=l.clone(e),this._semiMajorAxis=n,this._semiMinorAxis=s,this._ellipsoid=ot.clone(i),this._rotation=Z(t.rotation,0),this._height=Math.max(a,r),this._granularity=o,this._extrudedHeight=Math.min(a,r),this._numberOfVerticalLines=Math.max(Z(t.numberOfVerticalLines,16),0),this._offsetAttribute=t.offsetAttribute,this._workerName="createEllipseOutlineGeometry"}var Xv,hd,QC,kC,qv,$v,Nh,xa,pS=S(()=>{_i();Ht();oi();Ft();mt();Ot();dS();Oe();yi();ji();En();go();Di();_e();Xi();Xv=new l,hd=new l;QC=new Nt,kC=new Nt;Nf.packedLength=l.packedLength+ot.packedLength+8;Nf.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),l.pack(t._center,e,i),i+=l.packedLength,ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._semiMajorAxis,e[i++]=t._semiMinorAxis,e[i++]=t._rotation,e[i++]=t._height,e[i++]=t._granularity,e[i++]=t._extrudedHeight,e[i++]=t._numberOfVerticalLines,e[i]=Z(t._offsetAttribute,-1),e};qv=new l,$v=new ot,Nh={center:qv,ellipsoid:$v,semiMajorAxis:void 0,semiMinorAxis:void 0,rotation:void 0,height:void 0,granularity:void 0,extrudedHeight:void 0,numberOfVerticalLines:void 0,offsetAttribute:void 0};Nf.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n=l.unpack(t,e,qv);e+=l.packedLength;let s=ot.unpack(t,e,$v);e+=ot.packedLength;let o=t[e++],r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++],E=t[e];return m(i)?(i._center=l.clone(n,i._center),i._ellipsoid=ot.clone(s,i._ellipsoid),i._semiMajorAxis=o,i._semiMinorAxis=r,i._rotation=a,i._height=h,i._granularity=A,i._extrudedHeight=d,i._numberOfVerticalLines=f,i._offsetAttribute=E===-1?void 0:E,i):(Nh.height=h,Nh.extrudedHeight=d,Nh.granularity=A,Nh.rotation=a,Nh.semiMajorAxis=o,Nh.semiMinorAxis=r,Nh.numberOfVerticalLines=f,Nh.offsetAttribute=E===-1?void 0:E,new Nf(Nh))};Nf.createGeometry=function(t){if(t._semiMajorAxis<=0||t._semiMinorAxis<=0)return;let e=t._height,i=t._extrudedHeight,n=!L.equalsEpsilon(e,i,0,L.EPSILON2);t._center=t._ellipsoid.scaleToGeodeticSurface(t._center,t._center);let s={center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,ellipsoid:t._ellipsoid,rotation:t._rotation,height:e,granularity:t._granularity,numberOfVerticalLines:t._numberOfVerticalLines},o;if(n)s.extrudedHeight=i,s.offsetAttribute=t._offsetAttribute,o=nct(s);else if(o=ict(s),m(t._offsetAttribute)){let r=o.attributes.position.values.length,a=t._offsetAttribute===Pe.NONE?0:1,h=new Uint8Array(r/3).fill(a);o.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:h})}return new se({attributes:o.attributes,indices:o.indices,primitiveType:ne.LINES,boundingSphere:o.boundingSphere,offsetAttribute:t._offsetAttribute})};xa=Nf});function Ff(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.radius;p.typeOf.number("radius",e);let i={center:t.center,semiMajorAxis:e,semiMinorAxis:e,ellipsoid:t.ellipsoid,height:t.height,extrudedHeight:t.extrudedHeight,granularity:t.granularity,numberOfVerticalLines:t.numberOfVerticalLines};this._ellipseGeometry=new xa(i),this._workerName="createCircleOutlineGeometry"}var sct,Tr,uS,tz=S(()=>{Ht();ae();Ft();mt();pS();Oe();Ff.packedLength=xa.packedLength;Ff.pack=function(t,e,i){return p.typeOf.object("value",t),xa.pack(t._ellipseGeometry,e,i)};sct=new xa({center:new l,semiMajorAxis:1,semiMinorAxis:1}),Tr={center:new l,radius:void 0,ellipsoid:ot.clone(ot.UNIT_SPHERE),height:void 0,extrudedHeight:void 0,granularity:void 0,numberOfVerticalLines:void 0,semiMajorAxis:void 0,semiMinorAxis:void 0};Ff.unpack=function(t,e,i){let n=xa.unpack(t,e,sct);return Tr.center=l.clone(n._center,Tr.center),Tr.ellipsoid=ot.clone(n._ellipsoid,Tr.ellipsoid),Tr.height=n._height,Tr.extrudedHeight=n._extrudedHeight,Tr.granularity=n._granularity,Tr.numberOfVerticalLines=n._numberOfVerticalLines,m(i)?(Tr.semiMajorAxis=n._semiMajorAxis,Tr.semiMinorAxis=n._semiMinorAxis,i._ellipseGeometry=new xa(Tr),i):(Tr.radius=n._semiMajorAxis,new Ff(Tr))};Ff.createGeometry=function(t){return xa.createGeometry(t._ellipseGeometry)};uS=Ff});var CS={};He(CS,{default:()=>rct});function oct(t,e){return m(e)&&(t=uS.unpack(t,e)),t._ellipseGeometry._center=l.clone(t._ellipseGeometry._center),t._ellipseGeometry._ellipsoid=ot.clone(t._ellipseGeometry._ellipsoid),uS.createGeometry(t)}var rct,gS=S(()=>{Ht();tz();mt();Oe();rct=oct});function oz(t,e,i,n,s){let o=l.subtract(t,e,act),r=l.dot(i,o),a=l.dot(n,o);return nt.fromElements(r,a,s)}var lR,act,ez,iz,nz,sz,bf,TS=S(()=>{Xe();Ht();ae();dn();Jl();lR={},act=new l,ez=new l,iz=new l,nz=new l,sz=new zs;lR.validOutline=function(t){p.defined("positions",t);let i=zs.fromPoints(t,sz).halfAxes,n=lt.getColumn(i,0,ez),s=lt.getColumn(i,1,iz),o=lt.getColumn(i,2,nz),r=l.magnitude(n),a=l.magnitude(s),h=l.magnitude(o);return!(r===0&&(a===0||h===0)||a===0&&h===0)};lR.computeProjectTo2DArguments=function(t,e,i,n){p.defined("positions",t),p.defined("centerResult",e),p.defined("planeAxis1Result",i),p.defined("planeAxis2Result",n);let s=zs.fromPoints(t,sz),o=s.halfAxes,r=lt.getColumn(o,0,ez),a=lt.getColumn(o,1,iz),h=lt.getColumn(o,2,nz),A=l.magnitude(r),d=l.magnitude(a),f=l.magnitude(h),E=Math.min(A,d,f);if(A===0&&(d===0||f===0)||d===0&&f===0)return!1;let _,R;return(E===d||E===f)&&(_=r),E===A?_=a:E===f&&(R=a),(E===A||E===d)&&(R=h),l.normalize(_,i),l.normalize(R,n),l.clone(s.center,e),!0};lR.createProjectPointsTo2DFunction=function(t,e,i){return function(n){let s=new Array(n.length);for(let o=0;o<n.length;o++)s[o]=oz(n[o],t,e,i);return s}};lR.createProjectPointTo2DFunction=function(t,e,i){return function(n,s){return oz(n,t,e,i,s)}};bf=lR});var cz=ts((NRe,YS)=>{"use strict";YS.exports=wC;YS.exports.default=wC;function wC(t,e,i){i=i||2;var n=e&&e.length,s=n?e[0]*i:t.length,o=az(t,0,s,i,!0),r=[];if(!o||o.next===o.prev)return r;var a,h,A,d,f,E,_;if(n&&(o=dct(t,e,o,i)),t.length>80*i){a=A=t[0],h=d=t[1];for(var R=i;R<s;R+=i)f=t[R],E=t[R+1],f<a&&(a=f),E<h&&(h=E),f>A&&(A=f),E>d&&(d=E);_=Math.max(A-a,d-h),_=_!==0?32767/_:0}return dR(o,r,i,a,h,_,0),r}function az(t,e,i,n,s){var o,r;if(s===bS(t,e,i,n)>0)for(o=e;o<i;o+=n)r=rz(o,t[o],t[o+1],r);else for(o=i-n;o>=e;o-=n)r=rz(o,t[o],t[o+1],r);return r&&xC(r,r.next)&&(fR(r),r=r.next),r}function cd(t,e){if(!t)return t;e||(e=t);var i=t,n;do if(n=!1,!i.steiner&&(xC(i,i.next)||as(i.prev,i,i.next)===0)){if(fR(i),i=e=i.prev,i===i.next)break;n=!0}else i=i.next;while(n||i!==e);return e}function dR(t,e,i,n,s,o,r){if(t){!r&&o&&Rct(t,n,s,o);for(var a=t,h,A;t.prev!==t.next;){if(h=t.prev,A=t.next,o?hct(t,n,s,o):Act(t)){e.push(h.i/i|0),e.push(t.i/i|0),e.push(A.i/i|0),fR(t),t=A.next,a=A.next;continue}if(t=A,t===a){r?r===1?(t=cct(cd(t),e,i),dR(t,e,i,n,s,o,2)):r===2&&lct(t,e,i,n,s,o):dR(cd(t),e,i,n,s,o,1);break}}}}function Act(t){var e=t.prev,i=t,n=t.next;if(as(e,i,n)>=0)return!1;for(var s=e.x,o=i.x,r=n.x,a=e.y,h=i.y,A=n.y,d=s<o?s<r?s:r:o<r?o:r,f=a<h?a<A?a:A:h<A?h:A,E=s>o?s>r?s:r:o>r?o:r,_=a>h?a>A?a:A:h>A?h:A,R=n.next;R!==e;){if(R.x>=d&&R.x<=E&&R.y>=f&&R.y<=_&&Yf(s,a,o,h,r,A,R.x,R.y)&&as(R.prev,R,R.next)>=0)return!1;R=R.next}return!0}function hct(t,e,i,n){var s=t.prev,o=t,r=t.next;if(as(s,o,r)>=0)return!1;for(var a=s.x,h=o.x,A=r.x,d=s.y,f=o.y,E=r.y,_=a<h?a<A?a:A:h<A?h:A,R=d<f?d<E?d:E:f<E?f:E,I=a>h?a>A?a:A:h>A?h:A,C=d>f?d>E?d:E:f>E?f:E,N=NS(_,R,e,i,n),T=NS(I,C,e,i,n),b=t.prevZ,F=t.nextZ;b&&b.z>=N&&F&&F.z<=T;){if(b.x>=_&&b.x<=I&&b.y>=R&&b.y<=C&&b!==s&&b!==r&&Yf(a,d,h,f,A,E,b.x,b.y)&&as(b.prev,b,b.next)>=0||(b=b.prevZ,F.x>=_&&F.x<=I&&F.y>=R&&F.y<=C&&F!==s&&F!==r&&Yf(a,d,h,f,A,E,F.x,F.y)&&as(F.prev,F,F.next)>=0))return!1;F=F.nextZ}for(;b&&b.z>=N;){if(b.x>=_&&b.x<=I&&b.y>=R&&b.y<=C&&b!==s&&b!==r&&Yf(a,d,h,f,A,E,b.x,b.y)&&as(b.prev,b,b.next)>=0)return!1;b=b.prevZ}for(;F&&F.z<=T;){if(F.x>=_&&F.x<=I&&F.y>=R&&F.y<=C&&F!==s&&F!==r&&Yf(a,d,h,f,A,E,F.x,F.y)&&as(F.prev,F,F.next)>=0)return!1;F=F.nextZ}return!0}function cct(t,e,i){var n=t;do{var s=n.prev,o=n.next.next;!xC(s,o)&&Az(s,n,n.next,o)&&mR(s,o)&&mR(o,s)&&(e.push(s.i/i|0),e.push(n.i/i|0),e.push(o.i/i|0),fR(n),fR(n.next),n=t=o),n=n.next}while(n!==t);return cd(n)}function lct(t,e,i,n,s,o){var r=t;do{for(var a=r.next.next;a!==r.prev;){if(r.i!==a.i&&pct(r,a)){var h=hz(r,a);r=cd(r,r.next),h=cd(h,h.next),dR(r,e,i,n,s,o,0),dR(h,e,i,n,s,o,0);return}a=a.next}r=r.next}while(r!==t)}function dct(t,e,i,n){var s=[],o,r,a,h,A;for(o=0,r=e.length;o<r;o++)a=e[o]*n,h=o<r-1?e[o+1]*n:t.length,A=az(t,a,h,n,!1),A===A.next&&(A.steiner=!0),s.push(Ict(A));for(s.sort(mct),o=0;o<s.length;o++)i=fct(s[o],i);return i}function mct(t,e){return t.x-e.x}function fct(t,e){var i=Ect(t,e);if(!i)return e;var n=hz(i,t);return cd(n,n.next),cd(i,i.next)}function Ect(t,e){var i=e,n=t.x,s=t.y,o=-1/0,r;do{if(s<=i.y&&s>=i.next.y&&i.next.y!==i.y){var a=i.x+(s-i.y)*(i.next.x-i.x)/(i.next.y-i.y);if(a<=n&&a>o&&(o=a,r=i.x<i.next.x?i:i.next,a===n))return r}i=i.next}while(i!==e);if(!r)return null;var h=r,A=r.x,d=r.y,f=1/0,E;i=r;do n>=i.x&&i.x>=A&&n!==i.x&&Yf(s<d?n:o,s,A,d,s<d?o:n,s,i.x,i.y)&&(E=Math.abs(s-i.y)/(n-i.x),mR(i,t)&&(E<f||E===f&&(i.x>r.x||i.x===r.x&&_ct(r,i)))&&(r=i,f=E)),i=i.next;while(i!==h);return r}function _ct(t,e){return as(t.prev,t,e.prev)<0&&as(e.next,t,t.next)<0}function Rct(t,e,i,n){var s=t;do s.z===0&&(s.z=NS(s.x,s.y,e,i,n)),s.prevZ=s.prev,s.nextZ=s.next,s=s.next;while(s!==t);s.prevZ.nextZ=null,s.prevZ=null,Zct(s)}function Zct(t){var e,i,n,s,o,r,a,h,A=1;do{for(i=t,t=null,o=null,r=0;i;){for(r++,n=i,a=0,e=0;e<A&&(a++,n=n.nextZ,!!n);e++);for(h=A;a>0||h>0&&n;)a!==0&&(h===0||!n||i.z<=n.z)?(s=i,i=i.nextZ,a--):(s=n,n=n.nextZ,h--),o?o.nextZ=s:t=s,s.prevZ=o,o=s;i=n}o.nextZ=null,A*=2}while(r>1);return t}function NS(t,e,i,n,s){return t=(t-i)*s|0,e=(e-n)*s|0,t=(t|t<<8)&16711935,t=(t|t<<4)&252645135,t=(t|t<<2)&858993459,t=(t|t<<1)&1431655765,e=(e|e<<8)&16711935,e=(e|e<<4)&252645135,e=(e|e<<2)&858993459,e=(e|e<<1)&1431655765,t|e<<1}function Ict(t){var e=t,i=t;do(e.x<i.x||e.x===i.x&&e.y<i.y)&&(i=e),e=e.next;while(e!==t);return i}function Yf(t,e,i,n,s,o,r,a){return(s-r)*(e-a)>=(t-r)*(o-a)&&(t-r)*(n-a)>=(i-r)*(e-a)&&(i-r)*(o-a)>=(s-r)*(n-a)}function pct(t,e){return t.next.i!==e.i&&t.prev.i!==e.i&&!uct(t,e)&&(mR(t,e)&&mR(e,t)&&Cct(t,e)&&(as(t.prev,t,e.prev)||as(t,e.prev,e))||xC(t,e)&&as(t.prev,t,t.next)>0&&as(e.prev,e,e.next)>0)}function as(t,e,i){return(e.y-t.y)*(i.x-e.x)-(e.x-t.x)*(i.y-e.y)}function xC(t,e){return t.x===e.x&&t.y===e.y}function Az(t,e,i,n){var s=yC(as(t,e,i)),o=yC(as(t,e,n)),r=yC(as(i,n,t)),a=yC(as(i,n,e));return!!(s!==o&&r!==a||s===0&&LC(t,i,e)||o===0&&LC(t,n,e)||r===0&&LC(i,t,n)||a===0&&LC(i,e,n))}function LC(t,e,i){return e.x<=Math.max(t.x,i.x)&&e.x>=Math.min(t.x,i.x)&&e.y<=Math.max(t.y,i.y)&&e.y>=Math.min(t.y,i.y)}function yC(t){return t>0?1:t<0?-1:0}function uct(t,e){var i=t;do{if(i.i!==t.i&&i.next.i!==t.i&&i.i!==e.i&&i.next.i!==e.i&&Az(i,i.next,t,e))return!0;i=i.next}while(i!==t);return!1}function mR(t,e){return as(t.prev,t,t.next)<0?as(t,e,t.next)>=0&&as(t,t.prev,e)>=0:as(t,e,t.prev)<0||as(t,t.next,e)<0}function Cct(t,e){var i=t,n=!1,s=(t.x+e.x)/2,o=(t.y+e.y)/2;do i.y>o!=i.next.y>o&&i.next.y!==i.y&&s<(i.next.x-i.x)*(o-i.y)/(i.next.y-i.y)+i.x&&(n=!n),i=i.next;while(i!==t);return n}function hz(t,e){var i=new FS(t.i,t.x,t.y),n=new FS(e.i,e.x,e.y),s=t.next,o=e.prev;return t.next=e,e.prev=t,i.next=s,s.prev=i,n.next=i,i.prev=n,o.next=n,n.prev=o,n}function rz(t,e,i,n){var s=new FS(t,e,i);return n?(s.next=n.next,s.prev=n,n.next.prev=s,n.next=s):(s.prev=s,s.next=s),s}function fR(t){t.next.prev=t.prev,t.prev.next=t.next,t.prevZ&&(t.prevZ.nextZ=t.nextZ),t.nextZ&&(t.nextZ.prevZ=t.prevZ)}function FS(t,e,i){this.i=t,this.x=e,this.y=i,this.prev=null,this.next=null,this.z=0,this.prevZ=null,this.nextZ=null,this.steiner=!1}wC.deviation=function(t,e,i,n){var s=e&&e.length,o=s?e[0]*i:t.length,r=Math.abs(bS(t,0,o,i));if(s)for(var a=0,h=e.length;a<h;a++){var A=e[a]*i,d=a<h-1?e[a+1]*i:t.length;r-=Math.abs(bS(t,A,d,i))}var f=0;for(a=0;a<n.length;a+=3){var E=n[a]*i,_=n[a+1]*i,R=n[a+2]*i;f+=Math.abs((t[E]-t[R])*(t[_+1]-t[E+1])-(t[E]-t[_])*(t[R+1]-t[E+1]))}return r===0&&f===0?0:Math.abs((f-r)/r)};function bS(t,e,i,n){for(var s=0,o=e,r=i-n;o<i;o+=n)s+=(t[r]-t[o])*(t[o+1]+t[r+1]),r=o;return s}wC.flatten=function(t){for(var e=t[0][0].length,i={vertices:[],holes:[],dimensions:e},n=0,s=0;s<t.length;s++){for(var o=0;o<t[s].length;o++)for(var r=0;r<e;r++)i.vertices.push(t[s][o][r]);s>0&&(n+=t[s-1].length,i.holes.push(n))}return i}});var fz,gct,Tct,Uc,Ez,_z,Rz,lz,dz,mz,Fh,Zz,Iz,pz,Vf,Nct,Fct,bct,VS,ui,Pa=S(()=>{fz=co(cz(),1);Xe();Ht();ri();ae();oi();Ft();mt();Oe();HE();yi();ji();_e();Xi();fc();gct=new l,Tct=new l,Uc={};Uc.computeArea2D=function(t){p.defined("positions",t),p.typeOf.number.greaterThanOrEquals("positions.length",t.length,3);let e=t.length,i=0;for(let n=e-1,s=0;s<e;n=s++){let o=t[n],r=t[s];i+=o.x*r.y-r.x*o.y}return i*.5};Uc.computeWindingOrder2D=function(t){return Uc.computeArea2D(t)>0?Us.COUNTER_CLOCKWISE:Us.CLOCKWISE};Uc.triangulate=function(t,e){p.defined("positions",t);let i=nt.packArray(t);return(0,fz.default)(i,e,2)};Ez=new l,_z=new l,Rz=new l,lz=new l,dz=new l,mz=new l,Fh=new l,Zz=new nt,Iz=new nt,pz=new nt,Vf=new nt;Uc.computeSubdivision=function(t,e,i,n,s){s=Z(s,L.RADIANS_PER_DEGREE);let o=m(n);p.typeOf.object("ellipsoid",t),p.defined("positions",e),p.defined("indices",i),p.typeOf.number.greaterThanOrEquals("indices.length",i.length,3),p.typeOf.number.equals("indices.length % 3","0",i.length%3,0),p.typeOf.number.greaterThan("granularity",s,0);let r=i.slice(0),a,h=e.length,A=new Array(h*3),d=new Array(h*2),f=0,E=0;for(a=0;a<h;a++){let b=e[a];if(A[f++]=b.x,A[f++]=b.y,A[f++]=b.z,o){let F=n[a];d[E++]=F.x,d[E++]=F.y}}let _=[],R={},I=t.maximumRadius,C=L.chordLength(s,I),N=C*C;for(;r.length>0;){let b=r.pop(),F=r.pop(),B=r.pop(),U=l.fromArray(A,B*3,Ez),Q=l.fromArray(A,F*3,_z),M=l.fromArray(A,b*3,Rz),k,y,c;o&&(k=nt.fromArray(d,B*2,Zz),y=nt.fromArray(d,F*2,Iz),c=nt.fromArray(d,b*2,pz));let g=l.multiplyByScalar(l.normalize(U,lz),I,lz),O=l.multiplyByScalar(l.normalize(Q,dz),I,dz),D=l.multiplyByScalar(l.normalize(M,mz),I,mz),w=l.magnitudeSquared(l.subtract(g,O,Fh)),x=l.magnitudeSquared(l.subtract(O,D,Fh)),H=l.magnitudeSquared(l.subtract(D,g,Fh)),j=Math.max(w,x,H),X,tt,G;j>N?w===j?(X=`${Math.min(B,F)} ${Math.max(B,F)}`,a=R[X],m(a)||(tt=l.add(U,Q,Fh),l.multiplyByScalar(tt,.5,tt),A.push(tt.x,tt.y,tt.z),a=A.length/3-1,R[X]=a,o&&(G=nt.add(k,y,Vf),nt.multiplyByScalar(G,.5,G),d.push(G.x,G.y))),r.push(B,a,b),r.push(a,F,b)):x===j?(X=`${Math.min(F,b)} ${Math.max(F,b)}`,a=R[X],m(a)||(tt=l.add(Q,M,Fh),l.multiplyByScalar(tt,.5,tt),A.push(tt.x,tt.y,tt.z),a=A.length/3-1,R[X]=a,o&&(G=nt.add(y,c,Vf),nt.multiplyByScalar(G,.5,G),d.push(G.x,G.y))),r.push(F,a,B),r.push(a,b,B)):H===j&&(X=`${Math.min(b,B)} ${Math.max(b,B)}`,a=R[X],m(a)||(tt=l.add(M,U,Fh),l.multiplyByScalar(tt,.5,tt),A.push(tt.x,tt.y,tt.z),a=A.length/3-1,R[X]=a,o&&(G=nt.add(c,k,Vf),nt.multiplyByScalar(G,.5,G),d.push(G.x,G.y))),r.push(b,a,F),r.push(a,B,F)):(_.push(B),_.push(F),_.push(b))}let T={attributes:{position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:A})},indices:_,primitiveType:ne.TRIANGLES};return o&&(T.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:d})),new se(T)};Nct=new ut,Fct=new ut,bct=new ut,VS=new ut;Uc.computeRhumbLineSubdivision=function(t,e,i,n,s){s=Z(s,L.RADIANS_PER_DEGREE);let o=m(n);p.typeOf.object("ellipsoid",t),p.defined("positions",e),p.defined("indices",i),p.typeOf.number.greaterThanOrEquals("indices.length",i.length,3),p.typeOf.number.equals("indices.length % 3","0",i.length%3,0),p.typeOf.number.greaterThan("granularity",s,0);let r=i.slice(0),a,h=e.length,A=new Array(h*3),d=new Array(h*2),f=0,E=0;for(a=0;a<h;a++){let B=e[a];if(A[f++]=B.x,A[f++]=B.y,A[f++]=B.z,o){let U=n[a];d[E++]=U.x,d[E++]=U.y}}let _=[],R={},I=t.maximumRadius,C=L.chordLength(s,I),N=new er(void 0,void 0,t),T=new er(void 0,void 0,t),b=new er(void 0,void 0,t);for(;r.length>0;){let B=r.pop(),U=r.pop(),Q=r.pop(),M=l.fromArray(A,Q*3,Ez),k=l.fromArray(A,U*3,_z),y=l.fromArray(A,B*3,Rz),c,g,O;o&&(c=nt.fromArray(d,Q*2,Zz),g=nt.fromArray(d,U*2,Iz),O=nt.fromArray(d,B*2,pz));let D=t.cartesianToCartographic(M,Nct),w=t.cartesianToCartographic(k,Fct),x=t.cartesianToCartographic(y,bct);N.setEndPoints(D,w);let H=N.surfaceDistance;T.setEndPoints(w,x);let j=T.surfaceDistance;b.setEndPoints(x,D);let X=b.surfaceDistance,tt=Math.max(H,j,X),G,It,gt,Yt,Ut;tt>C?H===tt?(G=`${Math.min(Q,U)} ${Math.max(Q,U)}`,a=R[G],m(a)||(It=N.interpolateUsingFraction(.5,VS),gt=(D.height+w.height)*.5,Yt=l.fromRadians(It.longitude,It.latitude,gt,t,Fh),A.push(Yt.x,Yt.y,Yt.z),a=A.length/3-1,R[G]=a,o&&(Ut=nt.add(c,g,Vf),nt.multiplyByScalar(Ut,.5,Ut),d.push(Ut.x,Ut.y))),r.push(Q,a,B),r.push(a,U,B)):j===tt?(G=`${Math.min(U,B)} ${Math.max(U,B)}`,a=R[G],m(a)||(It=T.interpolateUsingFraction(.5,VS),gt=(w.height+x.height)*.5,Yt=l.fromRadians(It.longitude,It.latitude,gt,t,Fh),A.push(Yt.x,Yt.y,Yt.z),a=A.length/3-1,R[G]=a,o&&(Ut=nt.add(g,O,Vf),nt.multiplyByScalar(Ut,.5,Ut),d.push(Ut.x,Ut.y))),r.push(U,a,Q),r.push(a,B,Q)):X===tt&&(G=`${Math.min(B,Q)} ${Math.max(B,Q)}`,a=R[G],m(a)||(It=b.interpolateUsingFraction(.5,VS),gt=(x.height+D.height)*.5,Yt=l.fromRadians(It.longitude,It.latitude,gt,t,Fh),A.push(Yt.x,Yt.y,Yt.z),a=A.length/3-1,R[G]=a,o&&(Ut=nt.add(O,c,Vf),nt.multiplyByScalar(Ut,.5,Ut),d.push(Ut.x,Ut.y))),r.push(B,a,U),r.push(a,Q,U)):(_.push(Q),_.push(U),_.push(B))}let F={attributes:{position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:A})},indices:_,primitiveType:ne.TRIANGLES};return o&&(F.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:d})),new se(F)};Uc.scaleToGeodeticHeight=function(t,e,i,n){i=Z(i,ot.WGS84);let s=gct,o=Tct;if(e=Z(e,0),n=Z(n,!0),m(t)){let r=t.length;for(let a=0;a<r;a+=3)l.fromArray(t,a,o),n&&(o=i.scaleToGeodeticSurface(o,o)),e!==0&&(s=i.geodeticSurfaceNormal(o,s),l.multiplyByScalar(s,e,s),l.add(o,s,o)),t[a]=o.x,t[a+1]=o.y,t[a+2]=o.z}return t};ui=Uc});function Mc(){this._array=[],this._offset=0,this._length=0}var SS,uz=S(()=>{Object.defineProperties(Mc.prototype,{length:{get:function(){return this._length}}});Mc.prototype.enqueue=function(t){this._array.push(t),this._length++};Mc.prototype.dequeue=function(){if(this._length===0)return;let t=this._array,e=this._offset,i=t[e];return t[e]=void 0,e++,e>10&&e*2>t.length&&(this._array=t.slice(e),e=0),this._offset=e,this._length--,i};Mc.prototype.peek=function(){if(this._length!==0)return this._array[this._offset]};Mc.prototype.contains=function(t){return this._array.indexOf(t)!==-1};Mc.prototype.clear=function(){this._array.length=this._offset=this._length=0};Mc.prototype.sort=function(t){this._offset>0&&(this._array=this._array.slice(this._offset),this._offset=0),this._array.sort(t)};SS=Mc});function Tz(t,e,i,n){return nt.subtract(e,t,ld),nt.multiplyByScalar(ld,i/n,ld),nt.add(t,ld,ld),[ld.x,ld.y]}function Yct(t,e,i,n){return l.subtract(e,t,Qc),l.multiplyByScalar(Qc,i/n,Qc),l.add(t,Qc,Qc),[Qc.x,Qc.y,Qc.z]}function Uct(t,e,i){let n=i.cartesianToCartographic(t,JC),s=i.cartesianToCartographic(e,jC);if(Math.sign(n.latitude)===Math.sign(s.latitude))return;PC.setEndPoints(n,s);let o=PC.findIntersectionWithLatitude(0,Dct);if(!m(o))return;let r=Math.min(n.longitude,s.longitude),a=Math.max(n.longitude,s.longitude);if(Math.abs(a-r)>L.PI){let h=r;r=a,a=h}if(!(o.longitude<r||o.longitude>a))return i.cartographicToCartesian(o)}function Mct(t,e,i,n){if(n===ti.RHUMB)return Uct(t,e,i);let s=no.lineSegmentPlane(t,e,Ki.ORIGIN_XY_PLANE);if(m(s))return i.scaleToGeodeticSurface(s,s)}function kct(t,e,i){let n=[],s,o,r,a,h,A=0;for(;A<t.length;){s=t[A],o=t[(A+1)%t.length],r=L.sign(s.z),a=L.sign(o.z);let d=f=>e.cartesianToCartographic(f,Qct).longitude;if(r===0)n.push({position:A,type:r,visited:!1,next:a,theta:d(s)});else if(a!==0){if(h=Mct(s,o,e,i),++A,!m(h))continue;t.splice(A,0,h),n.push({position:A,type:r,visited:!1,next:a,theta:d(h)})}++A}return n}function Nz(t,e,i,n,s,o,r){let a=[],h=o,A=f=>E=>E.position===f,d=[];do{let f=i[h];a.push(f);let E=n.findIndex(A(h)),_=n[E];if(!m(_)){++h;continue}let{visited:R,type:I,next:C}=_;if(_.visited=!0,I===0){if(C===0){let F=n[E-(r?1:-1)];if(F?.position===h+1)F.visited=!0;else{++h;continue}}if(!R&&r&&C>0||o===h&&!r&&C<0){++h;continue}}if(!(r?I>=0:I<=0)){++h;continue}R||d.push(h);let T=E+(r?1:-1),b=n[T];if(!m(b)){++h;continue}h=b.position}while(h<i.length&&h>=0&&h!==o&&a.length<i.length);t.splice(e,s,a);for(let f of d)e=Nz(t,++e,i,n,0,f,!r);return e}var Un,ld,Qc,JC,jC,Vct,Sct,PC,Oct,Bct,Gct,Wct,Dct,Qct,Lct,yct,wct,xct,Cz,gz,Pct,Jct,ii,ER=S(()=>{Gl();Sa();Xe();Ht();ri();oi();Ft();mt();Oe();HE();yi();ji();En();gA();Di();Ul();_e();dn();nh();cp();Pa();Xi();$s();uz();fc();Un={};Un.computeHierarchyPackedLength=function(t,e){let i=0,n=[t];for(;n.length>0;){let s=n.pop();if(!m(s))continue;i+=2;let o=s.positions,r=s.holes;if(m(o)&&o.length>0&&(i+=o.length*e.packedLength),m(r)){let a=r.length;for(let h=0;h<a;++h)n.push(r[h])}}return i};Un.packPolygonHierarchy=function(t,e,i,n){let s=[t];for(;s.length>0;){let o=s.pop();if(!m(o))continue;let r=o.positions,a=o.holes;if(e[i++]=m(r)?r.length:0,e[i++]=m(a)?a.length:0,m(r)){let h=r.length;for(let A=0;A<h;++A,i+=n.packedLength)n.pack(r[A],e,i)}if(m(a)){let h=a.length;for(let A=0;A<h;++A)s.push(a[A])}}return i};Un.unpackPolygonHierarchy=function(t,e,i){let n=t[e++],s=t[e++],o=new Array(n),r=s>0?new Array(s):void 0;for(let a=0;a<n;++a,e+=i.packedLength)o[a]=i.unpack(t,e);for(let a=0;a<s;++a)r[a]=Un.unpackPolygonHierarchy(t,e,i),e=r[a].startingIndex,delete r[a].startingIndex;return{positions:o,holes:r,startingIndex:e}};ld=new nt;Qc=new l;Un.subdivideLineCount=function(t,e,i){let s=l.distance(t,e)/i,o=Math.max(0,Math.ceil(L.log2(s)));return Math.pow(2,o)};JC=new ut,jC=new ut,Vct=new ut,Sct=new l,PC=new er;Un.subdivideRhumbLineCount=function(t,e,i,n){let s=t.cartesianToCartographic(e,JC),o=t.cartesianToCartographic(i,jC),a=new er(s,o,t).surfaceDistance/n,h=Math.max(0,Math.ceil(L.log2(a)));return Math.pow(2,h)};Un.subdivideTexcoordLine=function(t,e,i,n,s,o){let r=Un.subdivideLineCount(i,n,s),a=nt.distance(t,e),h=a/r,A=o;A.length=r*2;let d=0;for(let f=0;f<r;f++){let E=Tz(t,e,f*h,a);A[d++]=E[0],A[d++]=E[1]}return A};Un.subdivideLine=function(t,e,i,n){let s=Un.subdivideLineCount(t,e,i),o=l.distance(t,e),r=o/s;m(n)||(n=[]);let a=n;a.length=s*3;let h=0;for(let A=0;A<s;A++){let d=Yct(t,e,A*r,o);a[h++]=d[0],a[h++]=d[1],a[h++]=d[2]}return a};Un.subdivideTexcoordRhumbLine=function(t,e,i,n,s,o,r){let a=i.cartesianToCartographic(n,JC),h=i.cartesianToCartographic(s,jC);PC.setEndPoints(a,h);let A=PC.surfaceDistance/o,d=Math.max(0,Math.ceil(L.log2(A))),f=Math.pow(2,d),E=nt.distance(t,e),_=E/f,R=r;R.length=f*2;let I=0;for(let C=0;C<f;C++){let N=Tz(t,e,C*_,E);R[I++]=N[0],R[I++]=N[1]}return R};Un.subdivideRhumbLine=function(t,e,i,n,s){let o=t.cartesianToCartographic(e,JC),r=t.cartesianToCartographic(i,jC),a=new er(o,r,t),h=a.surfaceDistance/n,A=Math.max(0,Math.ceil(L.log2(h))),d=Math.pow(2,A),f=a.surfaceDistance/d;m(s)||(s=[]);let E=s;E.length=d*3;let _=0;for(let R=0;R<d;R++){let I=a.interpolateUsingSurfaceDistance(R*f,Vct),C=t.cartographicToCartesian(I,Sct);E[_++]=C.x,E[_++]=C.y,E[_++]=C.z}return E};Oct=new l,Bct=new l,Gct=new l,Wct=new l;Un.scaleToGeodeticHeightExtruded=function(t,e,i,n,s){n=Z(n,ot.WGS84);let o=Oct,r=Bct,a=Gct,h=Wct;if(m(t)&&m(t.attributes)&&m(t.attributes.position)){let A=t.attributes.position.values,d=A.length/2;for(let f=0;f<d;f+=3)l.fromArray(A,f,a),n.geodeticSurfaceNormal(a,o),h=n.scaleToGeodeticSurface(a,h),r=l.multiplyByScalar(o,i,r),r=l.add(h,r,r),A[f+d]=r.x,A[f+1+d]=r.y,A[f+2+d]=r.z,s&&(h=l.clone(a,h)),r=l.multiplyByScalar(o,e,r),r=l.add(h,r,r),A[f]=r.x,A[f+1]=r.y,A[f+2]=r.z}return t};Un.polygonOutlinesFromHierarchy=function(t,e,i){let n=[],s=new SS;s.enqueue(t);let o,r,a;for(;s.length!==0;){let h=s.dequeue(),A=h.positions;if(e)for(a=A.length,o=0;o<a;o++)i.scaleToGeodeticSurface(A[o],A[o]);if(A=Xn(A,l.equalsEpsilon,!0),A.length<3)continue;let d=h.holes?h.holes.length:0;for(o=0;o<d;o++){let f=h.holes[o],E=f.positions;if(e)for(a=E.length,r=0;r<a;++r)i.scaleToGeodeticSurface(E[r],E[r]);if(E=Xn(E,l.equalsEpsilon,!0),E.length<3)continue;n.push(E);let _=0;for(m(f.holes)&&(_=f.holes.length),r=0;r<_;r++)s.enqueue(f.holes[r])}n.push(A)}return n};Dct=new ut;Qct=new ut;Un.splitPolygonsOnEquator=function(t,e,i,n){m(n)||(n=[]),n.splice(0,0,...t),n.length=t.length;let s=0;for(;s<n.length;){let o=n[s],r=o.slice();if(o.length<3){n[s]=r,++s;continue}let a=kct(r,e,i);if(r.length===o.length||a.length<=1){n[s]=r,++s;continue}a.sort((A,d)=>A.theta-d.theta);let h=r[0].z>=0;s=Nz(n,s,r,a,1,0,h)}return n};Un.polygonsFromHierarchy=function(t,e,i,n,s,o){let r=[],a=[],h=new SS;h.enqueue(t);let A=m(o);for(;h.length!==0;){let d=h.dequeue(),f=d.positions,E=d.holes,_,R;if(n)for(R=f.length,_=0;_<R;_++)s.scaleToGeodeticSurface(f[_],f[_]);if(e||(f=Xn(f,l.equalsEpsilon,!0)),f.length<3)continue;let I=i(f);if(!m(I))continue;let C=[],N=ui.computeWindingOrder2D(I);if(N===Us.CLOCKWISE&&(I.reverse(),f=f.slice().reverse()),A){A=!1;let U=[f];if(U=o(U,U),U.length>1){for(let Q of U)h.enqueue(new sf(Q,E));continue}}let T=f.slice(),b=m(E)?E.length:0,F=[],B;for(_=0;_<b;_++){let U=E[_],Q=U.positions;if(n)for(R=Q.length,B=0;B<R;++B)s.scaleToGeodeticSurface(Q[B],Q[B]);if(e||(Q=Xn(Q,l.equalsEpsilon,!0)),Q.length<3)continue;let M=i(Q);if(!m(M))continue;N=ui.computeWindingOrder2D(M),N===Us.CLOCKWISE&&(M.reverse(),Q=Q.slice().reverse()),F.push(Q),C.push(T.length),T=T.concat(Q),I=I.concat(M);let k=0;for(m(U.holes)&&(k=U.holes.length),B=0;B<k;B++)h.enqueue(U.holes[B])}r.push({outerRing:f,holes:F}),a.push({positions:T,positions2D:I,holes:C})}return{hierarchy:r,polygons:a}};Lct=new nt,yct=new l,wct=new Ae,xct=new lt;Un.computeBoundingRectangle=function(t,e,i,n,s){let o=Ae.fromAxisAngle(t,n,wct),r=lt.fromQuaternion(o,xct),a=Number.POSITIVE_INFINITY,h=Number.NEGATIVE_INFINITY,A=Number.POSITIVE_INFINITY,d=Number.NEGATIVE_INFINITY,f=i.length;for(let E=0;E<f;++E){let _=l.clone(i[E],yct);lt.multiplyByVector(r,_,_);let R=e(_,Lct);m(R)&&(a=Math.min(a,R.x),h=Math.max(h,R.x),A=Math.min(A,R.y),d=Math.max(d,R.y))}return s.x=a,s.y=A,s.width=h-a,s.height=d-A,s};Un.createGeometryFromPositions=function(t,e,i,n,s,o,r){let a=ui.triangulate(e.positions2D,e.holes);a.length<3&&(a=[0,1,2]);let h=e.positions,A=m(i),d=A?i.positions:void 0;if(s){let f=h.length,E=new Array(f*3),_=0;for(let C=0;C<f;C++){let N=h[C];E[_++]=N.x,E[_++]=N.y,E[_++]=N.z}let R={attributes:{position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:E})},indices:a,primitiveType:ne.TRIANGLES};A&&(R.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:nt.packArray(d)}));let I=new se(R);return o.normal?wi.computeNormal(I):I}if(r===ti.GEODESIC)return ui.computeSubdivision(t,h,a,d,n);if(r===ti.RHUMB)return ui.computeRhumbLineSubdivision(t,h,a,d,n)};Cz=[],gz=[],Pct=new l,Jct=new l;Un.computeWallGeometry=function(t,e,i,n,s,o){let r,a,h,A,d,f,E,_,R,I=t.length,C=0,N=0,T=m(e),b=T?e.positions:void 0;if(s)for(a=I*3*2,r=new Array(a*2),T&&(R=I*2*2,_=new Array(R*2)),h=0;h<I;h++)A=t[h],d=t[(h+1)%I],r[C]=r[C+a]=A.x,++C,r[C]=r[C+a]=A.y,++C,r[C]=r[C+a]=A.z,++C,r[C]=r[C+a]=d.x,++C,r[C]=r[C+a]=d.y,++C,r[C]=r[C+a]=d.z,++C,T&&(f=b[h],E=b[(h+1)%I],_[N]=_[N+R]=f.x,++N,_[N]=_[N+R]=f.y,++N,_[N]=_[N+R]=E.x,++N,_[N]=_[N+R]=E.y,++N);else{let M=L.chordLength(n,i.maximumRadius),k=0;if(o===ti.GEODESIC)for(h=0;h<I;h++)k+=Un.subdivideLineCount(t[h],t[(h+1)%I],M);else if(o===ti.RHUMB)for(h=0;h<I;h++)k+=Un.subdivideRhumbLineCount(i,t[h],t[(h+1)%I],M);for(a=(k+I)*3,r=new Array(a*2),T&&(R=(k+I)*2,_=new Array(R*2)),h=0;h<I;h++){A=t[h],d=t[(h+1)%I];let y,c;T&&(f=b[h],E=b[(h+1)%I]),o===ti.GEODESIC?(y=Un.subdivideLine(A,d,M,gz),T&&(c=Un.subdivideTexcoordLine(f,E,A,d,M,Cz))):o===ti.RHUMB&&(y=Un.subdivideRhumbLine(i,A,d,M,gz),T&&(c=Un.subdivideTexcoordRhumbLine(f,E,i,A,d,M,Cz)));let g=y.length;for(let O=0;O<g;++O,++C)r[C]=y[O],r[C+a]=y[O];if(r[C]=d.x,r[C+a]=d.x,++C,r[C]=d.y,r[C+a]=d.y,++C,r[C]=d.z,r[C+a]=d.z,++C,T){let O=c.length;for(let D=0;D<O;++D,++N)_[N]=c[D],_[N+R]=c[D];_[N]=E.x,_[N+R]=E.x,++N,_[N]=E.y,_[N+R]=E.y,++N}}}I=r.length;let F=te.createTypedArray(I/3,I-t.length*6),B=0;for(I/=6,h=0;h<I;h++){let M=h,k=M+1,y=M+I,c=y+1;A=l.fromArray(r,M*3,Pct),d=l.fromArray(r,k*3,Jct),!l.equalsEpsilon(A,d,L.EPSILON10,L.EPSILON10)&&(F[B++]=M,F[B++]=y,F[B++]=k,F[B++]=k,F[B++]=y,F[B++]=c)}let U={attributes:new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:r})}),indices:F,primitiveType:ne.TRIANGLES};return T&&(U.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:_})),new se(U)};ii=Un});function slt(t,e,i,n,s,o,r,a,h){let A=t.positions,d=ui.triangulate(t.positions2D,t.holes);d.length<3&&(d=[0,1,2]);let f=te.createTypedArray(A.length,d.length);f.set(d);let E=elt;if(n!==0){let c=Ae.fromAxisAngle(r,n,Fz);if(E=lt.fromQuaternion(c,E),e.tangent||e.bitangent){c=Ae.fromAxisAngle(r,-n,Fz);let g=lt.fromQuaternion(c,ilt);a=l.normalize(lt.multiplyByVector(g,a,a),a),e.bitangent&&(h=l.normalize(l.cross(r,a,h),h))}}else E=lt.clone(lt.IDENTITY,E);let _=zct;e.st&&(_.x=i.x,_.y=i.y);let R=A.length,I=R*3,C=new Float64Array(I),N=e.normal?new Float32Array(I):void 0,T=e.tangent?new Float32Array(I):void 0,b=e.bitangent?new Float32Array(I):void 0,F=e.st?new Float32Array(R*2):void 0,B=0,U=0,Q=0,M=0,k=0;for(let c=0;c<R;c++){let g=A[c];if(C[B++]=g.x,C[B++]=g.y,C[B++]=g.z,e.st)if(m(s)&&s.positions.length===R)F[k++]=s.positions[c].x,F[k++]=s.positions[c].y;else{let O=lt.multiplyByVector(E,g,jct),D=o(O,vct);nt.subtract(D,_,D);let w=L.clamp(D.x/i.width,0,1),x=L.clamp(D.y/i.height,0,1);F[k++]=w,F[k++]=x}e.normal&&(N[U++]=r.x,N[U++]=r.y,N[U++]=r.z),e.tangent&&(T[M++]=a.x,T[M++]=a.y,T[M++]=a.z),e.bitangent&&(b[Q++]=h.x,b[Q++]=h.y,b[Q++]=h.z)}let y=new we;return e.position&&(y.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:C})),e.normal&&(y.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:N})),e.tangent&&(y.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:T})),e.bitangent&&(y.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:b})),e.st&&(y.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:F})),new se({attributes:y,indices:f,primitiveType:ne.TRIANGLES})}function dd(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.polygonHierarchy,i=t.textureCoordinates;p.defined("options.polygonHierarchy",e);let n=Z(t.vertexFormat,St.DEFAULT);this._vertexFormat=St.clone(n),this._polygonHierarchy=e,this._stRotation=Z(t.stRotation,0),this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._workerName="createCoplanarPolygonGeometry",this._textureCoordinates=i,this.packedLength=ii.computeHierarchyPackedLength(e,l)+St.packedLength+ot.packedLength+(m(i)?ii.computeHierarchyPackedLength(i,nt):1)+2}var jct,Hct,vct,zct,Kct,Xct,qct,_R,$ct,tlt,Fz,elt,ilt,nlt,olt,rlt,alt,OS,bz=S(()=>{Sa();Er();_i();Xe();Ht();ae();oi();TS();Ft();mt();Oe();yi();ji();En();uA();gA();Di();_e();dn();ER();Pa();Xi();$s();Ls();jct=new l,Hct=new mi,vct=new nt,zct=new nt,Kct=new l,Xct=new l,qct=new l,_R=new l,$ct=new l,tlt=new l,Fz=new Ae,elt=new lt,ilt=new lt,nlt=new l;dd.fromPositions=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.positions",t.positions);let e={polygonHierarchy:{positions:t.positions},vertexFormat:t.vertexFormat,stRotation:t.stRotation,ellipsoid:t.ellipsoid,textureCoordinates:t.textureCoordinates};return new dd(e)};dd.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),i=ii.packPolygonHierarchy(t._polygonHierarchy,e,i,l),ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,St.pack(t._vertexFormat,e,i),i+=St.packedLength,e[i++]=t._stRotation,m(t._textureCoordinates)?i=ii.packPolygonHierarchy(t._textureCoordinates,e,i,nt):e[i++]=-1,e[i++]=t.packedLength,e};olt=ot.clone(ot.UNIT_SPHERE),rlt=new St,alt={polygonHierarchy:{}};dd.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=ii.unpackPolygonHierarchy(t,e,l);e=n.startingIndex,delete n.startingIndex;let s=ot.unpack(t,e,olt);e+=ot.packedLength;let o=St.unpack(t,e,rlt);e+=St.packedLength;let r=t[e++],a=t[e]===-1?void 0:ii.unpackPolygonHierarchy(t,e,nt);m(a)?(e=a.startingIndex,delete a.startingIndex):e++;let h=t[e++];return m(i)||(i=new dd(alt)),i._polygonHierarchy=n,i._ellipsoid=ot.clone(s,i._ellipsoid),i._vertexFormat=St.clone(o,i._vertexFormat),i._stRotation=r,i._textureCoordinates=a,i.packedLength=h,i};dd.createGeometry=function(t){let e=t._vertexFormat,i=t._polygonHierarchy,n=t._stRotation,s=t._textureCoordinates,o=m(s),r=i.positions;if(r=Xn(r,l.equalsEpsilon,!0),r.length<3)return;let a=Kct,h=Xct,A=qct,d=$ct,f=tlt;if(!bf.computeProjectTo2DArguments(r,_R,d,f))return;if(a=l.cross(d,f,a),a=l.normalize(a,a),!l.equalsEpsilon(_R,l.ZERO,L.EPSILON6)){let k=t._ellipsoid.geodeticSurfaceNormal(_R,nlt);l.dot(a,k)<0&&(a=l.negate(a,a),d=l.negate(d,d))}let _=bf.createProjectPointsTo2DFunction(_R,d,f),R=bf.createProjectPointTo2DFunction(_R,d,f);e.tangent&&(h=l.clone(d,h)),e.bitangent&&(A=l.clone(f,A));let I=ii.polygonsFromHierarchy(i,o,_,!1),C=I.hierarchy,N=I.polygons,T=function(k){return k},b=o?ii.polygonsFromHierarchy(s,!0,T,!1).polygons:void 0;if(C.length===0)return;r=C[0].outerRing;let F=Nt.fromPoints(r),B=ii.computeBoundingRectangle(a,R,r,n,Hct),U=[];for(let k=0;k<N.length;k++){let y=new Ln({geometry:slt(N[k],e,B,n,o?b[k]:void 0,R,a,h,A)});U.push(y)}let Q=wi.combineInstances(U)[0];Q.attributes.position.values=new Float64Array(Q.attributes.position.values),Q.indices=te.createTypedArray(Q.attributes.position.values.length/3,Q.indices);let M=Q.attributes;return e.position||delete M.position,new se({attributes:M,indices:Q.indices,primitiveType:Q.primitiveType,boundingSphere:F})};OS=dd});var BS={};He(BS,{default:()=>hlt});function Alt(t,e){return m(e)&&(t=OS.unpack(t,e)),OS.createGeometry(t)}var hlt,GS=S(()=>{bz();mt();hlt=Alt});function clt(t){let e=t.length,i=new Float64Array(e*3),n=te.createTypedArray(e,e*2),s=0,o=0;for(let a=0;a<e;a++){let h=t[a];i[s++]=h.x,i[s++]=h.y,i[s++]=h.z,n[o++]=a,n[o++]=(a+1)%e}let r=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:i})});return new se({attributes:r,indices:n,primitiveType:ne.LINES})}function md(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.polygonHierarchy;p.defined("options.polygonHierarchy",e),this._polygonHierarchy=e,this._workerName="createCoplanarPolygonOutlineGeometry",this.packedLength=ii.computeHierarchyPackedLength(e,l)+1}var llt,WS,Yz=S(()=>{Sa();_i();Ht();ae();oi();TS();Ft();mt();yi();ji();En();uA();gA();Di();ER();Xi();md.fromPositions=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.positions",t.positions);let e={polygonHierarchy:{positions:t.positions}};return new md(e)};md.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),i=ii.packPolygonHierarchy(t._polygonHierarchy,e,i,l),e[i]=t.packedLength,e};llt={polygonHierarchy:{}};md.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=ii.unpackPolygonHierarchy(t,e,l);e=n.startingIndex,delete n.startingIndex;let s=t[e];return m(i)||(i=new md(llt)),i._polygonHierarchy=n,i.packedLength=s,i};md.createGeometry=function(t){let e=t._polygonHierarchy,i=e.positions;if(i=Xn(i,l.equalsEpsilon,!0),i.length<3||!bf.validOutline(i))return;let s=ii.polygonOutlinesFromHierarchy(e,!1);if(s.length===0)return;let o=[];for(let h=0;h<s.length;h++){let A=new Ln({geometry:clt(s[h])});o.push(A)}let r=wi.combineInstances(o)[0],a=Nt.fromPoints(e.positions);return new se({attributes:r.attributes,indices:r.indices,primitiveType:r.primitiveType,boundingSphere:a})};WS=md});var DS={};He(DS,{default:()=>mlt});function dlt(t,e){return m(e)&&(t=WS.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),WS.createGeometry(t)}var mlt,US=S(()=>{Yz();mt();Oe();mlt=dlt});var flt,Cn,fd=S(()=>{flt={ROUNDED:0,MITERED:1,BEVELED:2},Cn=Object.freeze(flt)});function Bz(t,e,i){let n=QS;n.length=t;let s;if(e===i){for(s=0;s<t;s++)n[s]=e;return n}let r=(i-e)/t;for(s=0;s<t;s++){let a=e+s*r;n[s]=a}return n}function glt(t,e,i,n,s,o,r,a){let h=n.scaleToGeodeticSurface(t,kS),A=n.scaleToGeodeticSurface(e,Clt),d=yo.numberOfPoints(t,e,i),f=n.cartesianToCartographic(h,vC),E=n.cartesianToCartographic(A,HC),_=Bz(d,s,o);MS.setEndPoints(f,E);let R=MS.surfaceDistance/d,I=a;f.height=s;let C=n.cartographicToCartesian(f,kc);l.pack(C,r,I),I+=3;for(let N=1;N<d;N++){let T=MS.interpolateUsingSurfaceDistance(N*R,HC);T.height=_[N],C=n.cartographicToCartesian(T,kc),l.pack(C,r,I),I+=3}return I}function Tlt(t,e,i,n,s,o,r,a){let h=n.cartesianToCartographic(t,vC),A=n.cartesianToCartographic(e,HC),d=yo.numberOfPointsRhumbLine(h,A,i);h.height=0,A.height=0;let f=Bz(d,s,o);RR.ellipsoid.equals(n)||(RR=new er(void 0,void 0,n)),RR.setEndPoints(h,A);let E=RR.surfaceDistance/d,_=a;h.height=s;let R=n.cartographicToCartesian(h,kc);l.pack(R,r,_),_+=3;for(let I=1;I<d;I++){let C=RR.interpolateUsingSurfaceDistance(I*E,HC);C.height=f[I],R=n.cartographicToCartesian(C,kc),l.pack(R,r,_),_+=3}return _}var yo,Elt,_lt,Rlt,Vz,Zlt,Sz,Ilt,plt,ult,QS,vC,HC,kc,kS,Clt,MS,RR,Oz,Nlt,Sn,Sf=S(()=>{Ht();ri();Ft();mt();Ot();Oe();EN();HE();Ul();_e();bi();nh();yo={};yo.numberOfPoints=function(t,e,i){let n=l.distance(t,e);return Math.ceil(n/i)};yo.numberOfPointsRhumbLine=function(t,e,i){let n=Math.pow(t.longitude-e.longitude,2)+Math.pow(t.latitude-e.latitude,2);return Math.max(1,Math.ceil(Math.sqrt(n/(i*i))))};Elt=new ut;yo.extractHeights=function(t,e){let i=t.length,n=new Array(i);for(let s=0;s<i;s++){let o=t[s];n[s]=e.cartesianToCartographic(o,Elt).height}return n};_lt=new at,Rlt=new l,Vz=new l,Zlt=new Ki(l.UNIT_X,0),Sz=new l,Ilt=new Ki(l.UNIT_X,0),plt=new l,ult=new l,QS=[];vC=new ut,HC=new ut,kc=new l,kS=new l,Clt=new l,MS=new FI,RR=new er;yo.wrapLongitude=function(t,e){let i=[],n=[];if(m(t)&&t.length>0){e=Z(e,at.IDENTITY);let s=at.inverseTransformation(e,_lt),o=at.multiplyByPoint(s,l.ZERO,Rlt),r=l.normalize(at.multiplyByPointAsVector(s,l.UNIT_Y,Vz),Vz),a=Ki.fromPointNormal(o,r,Zlt),h=l.normalize(at.multiplyByPointAsVector(s,l.UNIT_X,Sz),Sz),A=Ki.fromPointNormal(o,h,Ilt),d=1;i.push(l.clone(t[0]));let f=i[0],E=t.length;for(let _=1;_<E;++_){let R=t[_];if(Ki.getPointDistance(A,f)<0||Ki.getPointDistance(A,R)<0){let I=no.lineSegmentPlane(f,R,a,plt);if(m(I)){let C=l.multiplyByScalar(r,5e-9,ult);Ki.getPointDistance(a,f)<0&&l.negate(C,C),i.push(l.add(I,C,new l)),n.push(d+1),l.negate(C,C),i.push(l.add(I,C,new l)),d=1}}i.push(l.clone(t[_])),d++,f=R}n.push(d)}return{positions:i,lengths:n}};yo.generateArc=function(t){m(t)||(t={});let e=t.positions;if(!m(e))throw new Y("options.positions is required.");let i=e.length,n=Z(t.ellipsoid,ot.WGS84),s=Z(t.height,0),o=Array.isArray(s);if(i<1)return[];if(i===1){let I=n.scaleToGeodeticSurface(e[0],kS);if(s=o?s[0]:s,s!==0){let C=n.geodeticSurfaceNormal(I,kc);l.multiplyByScalar(C,s,C),l.add(I,C,I)}return[I.x,I.y,I.z]}let r=t.minDistance;if(!m(r)){let I=Z(t.granularity,L.RADIANS_PER_DEGREE);r=L.chordLength(I,n.maximumRadius)}let a=0,h;for(h=0;h<i-1;h++)a+=yo.numberOfPoints(e[h],e[h+1],r);let A=(a+1)*3,d=new Array(A),f=0;for(h=0;h<i-1;h++){let I=e[h],C=e[h+1],N=o?s[h]:s,T=o?s[h+1]:s;f=glt(I,C,r,n,N,T,d,f)}QS.length=0;let E=e[i-1],_=n.cartesianToCartographic(E,vC);_.height=o?s[i-1]:s;let R=n.cartographicToCartesian(_,kc);return l.pack(R,d,A-3),d};Oz=new ut,Nlt=new ut;yo.generateRhumbArc=function(t){m(t)||(t={});let e=t.positions;if(!m(e))throw new Y("options.positions is required.");let i=e.length,n=Z(t.ellipsoid,ot.WGS84),s=Z(t.height,0),o=Array.isArray(s);if(i<1)return[];if(i===1){let N=n.scaleToGeodeticSurface(e[0],kS);if(s=o?s[0]:s,s!==0){let T=n.geodeticSurfaceNormal(N,kc);l.multiplyByScalar(T,s,T),l.add(N,T,N)}return[N.x,N.y,N.z]}let r=Z(t.granularity,L.RADIANS_PER_DEGREE),a=0,h,A=n.cartesianToCartographic(e[0],Oz),d;for(h=0;h<i-1;h++)d=n.cartesianToCartographic(e[h+1],Nlt),a+=yo.numberOfPointsRhumbLine(A,d,r),A=ut.clone(d,Oz);let f=(a+1)*3,E=new Array(f),_=0;for(h=0;h<i-1;h++){let N=e[h],T=e[h+1],b=o?s[h]:s,F=o?s[h+1]:s;_=Tlt(N,T,r,n,b,F,E,_)}QS.length=0;let R=e[i-1],I=n.cartesianToCartographic(R,vC);I.height=o?s[i-1]:s;let C=n.cartographicToCartesian(I,kc);return l.pack(C,E,f-3),E};yo.generateCartesianArc=function(t){let e=yo.generateArc(t),i=e.length/3,n=new Array(i);for(let s=0;s<i;s++)n[s]=l.unpack(e,s*3);return n};yo.generateCartesianRhumbArc=function(t){let e=yo.generateRhumbArc(t),i=e.length/3,n=new Array(i);for(let s=0;s<i;s++)n[s]=l.unpack(e,s*3);return n};Sn=yo});function ZR(t,e){if(!m(t))throw new Y("identifier is required.");m(Gz[t])||(Gz[t]=!0,console.warn(Z(e,t)))}var Gz,zC,LS=S(()=>{Ft();mt();Ot();Gz={};ZR.geometryOutlines="Entity geometry outlines are unsupported on terrain. Outlines will be disabled. To enable outlines, disable geometry terrain clamping by explicitly setting height to 0.";ZR.geometryZIndex="Entity geometry with zIndex are unsupported when height or extrudedHeight are defined.  zIndex will be ignored";ZR.geometryHeightReference="Entity corridor, ellipse, polygon or rectangle with heightReference must also have a defined height.  heightReference will be ignored";ZR.geometryExtrudedHeightReference="Entity corridor, ellipse, polygon or rectangle with extrudedHeightReference must also have a defined extrudedHeight.  extrudedHeightReference will be ignored";zC=ZR});function Dlt(t,e){let i=new Array(t.length);for(let n=0;n<t.length;n++){let s=t[n];yS=e.cartesianToCartographic(s,yS),i[n]=yS.height,t[n]=e.scaleToGeodeticSurface(s,s)}return i}function wS(t,e,i,n){let s=t[0],o=t[1],r=l.angleBetween(s,o),a=Math.ceil(r/n),h=new Array(a),A;if(e===i){for(A=0;A<a;A++)h[A]=e;return h.push(i),h}let f=(i-e)/a;for(A=1;A<a;A++){let E=e+A*f;h[A]=E}return h[0]=e,h.push(i),h}function Ult(t,e,i,n){let s=new oo(i,n),o=s.projectPointOntoPlane(l.add(i,t,XC),XC),r=s.projectPointOntoPlane(l.add(i,e,qC),qC),a=nt.angleBetween(o,r);return r.x*o.y-r.y*o.x>=0?-a:a}function bh(t,e,i,n,s,o,r,a){let h=Llt,A=ylt;Ed=In.eastNorthUpToFixedFrame(t,s,Ed),h=at.multiplyByPointAsVector(Ed,Mlt,h),h=l.normalize(h,h);let d=Ult(h,e,t,s);xS=lt.fromRotationZ(d,xS),Wz.z=o,Ed=at.multiplyTransformation(Ed,at.fromRotationTranslation(xS,Wz,Qlt),Ed);let f=klt;f[0]=r;for(let E=0;E<a;E++)for(let _=0;_<i.length;_+=3)A=l.fromArray(i,_,A),A=lt.multiplyByVector(f,A,A),A=at.multiplyByPoint(Ed,A,A),n.push(A.x,A.y,A.z);return n}function PS(t,e,i,n,s,o,r){for(let a=0;a<t.length;a+=3){let h=l.fromArray(t,a,wlt);n=bh(h,e,i,n,s,o[a/3],r,1)}return n}function xlt(t,e){let i=t.length,n=new Array(i*6),s=0,o=e.x+e.width/2,r=e.y+e.height/2,a=t[0];n[s++]=a.x-o,n[s++]=0,n[s++]=a.y-r;for(let h=1;h<i;h++){a=t[h];let A=a.x-o,d=a.y-r;n[s++]=A,n[s++]=0,n[s++]=d,n[s++]=A,n[s++]=0,n[s++]=d}return a=t[0],n[s++]=a.x-o,n[s++]=0,n[s++]=a.y-r,n}function Dz(t,e){let i=t.length,n=new Array(i*3),s=0,o=e.x+e.width/2,r=e.y+e.height/2;for(let a=0;a<i;a++)n[s++]=t[a].x-o,n[s++]=0,n[s++]=t[a].y-r;return n}function kz(t,e,i,n,s,o,r,a,h,A){let d=l.angleBetween(l.subtract(e,t,Of),l.subtract(i,t,KC)),f=n===Cn.BEVELED?0:Math.ceil(d/L.toRadians(5)),E;s?E=lt.fromQuaternion(Ae.fromAxisAngle(l.negate(t,Of),d/(f+1),Uz),Qz):E=lt.fromQuaternion(Ae.fromAxisAngle(t,d/(f+1),Uz),Qz);let _,R;if(e=l.clone(e,Mz),f>0){let I=A?2:1;for(let C=0;C<f;C++)e=lt.multiplyByVector(E,e,e),_=l.subtract(e,t,Of),_=l.normalize(_,_),s||(_=l.negate(_,_)),R=o.scaleToGeodeticSurface(e,KC),r=bh(R,_,a,r,o,h,1,I)}else _=l.subtract(e,t,Of),_=l.normalize(_,_),s||(_=l.negate(_,_)),R=o.scaleToGeodeticSurface(e,KC),r=bh(R,_,a,r,o,h,1,1),i=l.clone(i,Mz),_=l.subtract(i,t,Of),_=l.normalize(_,_),s||(_=l.negate(_,_)),R=o.scaleToGeodeticSurface(i,KC),r=bh(R,_,a,r,o,h,1,1);return r}var Ks,Flt,blt,Ylt,Vlt,Slt,Olt,Blt,Glt,Wlt,Of,KC,IR,yS,XC,qC,Mlt,Ed,Qlt,xS,klt,Llt,ylt,Wz,wlt,Uz,Mz,Qz,Plt,Jlt,Lc,$C=S(()=>{Xe();Ht();Os();ri();fd();Xm();_e();dn();bi();Sf();$s();fr();LS();Ks=[new l,new l],Flt=new l,blt=new l,Ylt=new l,Vlt=new l,Slt=new l,Olt=new l,Blt=new l,Glt=new l,Wlt=new l,Of=new l,KC=new l,IR={},yS=new ut;XC=new l,qC=new l;Mlt=new l(-1,0,0),Ed=new at,Qlt=new at,xS=new lt,klt=lt.IDENTITY.clone(),Llt=new l,ylt=new ie,Wz=new l;wlt=new l;Uz=new Ae,Mz=new l,Qz=new lt;IR.removeDuplicatesFromShape=function(t){let e=t.length,i=[];for(let n=e-1,s=0;s<e;n=s++){let o=t[n],r=t[s];nt.equals(o,r)||i.push(r)}return i};IR.angleIsGreaterThanPi=function(t,e,i,n){let s=new oo(i,n),o=s.projectPointOntoPlane(l.add(i,t,XC),XC),r=s.projectPointOntoPlane(l.add(i,e,qC),qC);return r.x*o.y-r.y*o.x>=0};Plt=new l,Jlt=new l;IR.computePositions=function(t,e,i,n,s){let o=n._ellipsoid,r=Dlt(t,o),a=n._granularity,h=n._cornerType,A=s?xlt(e,i):Dz(e,i),d=s?Dz(e,i):void 0,f=i.height/2,E=i.width/2,_=t.length,R=[],I=s?[]:void 0,C=Flt,N=blt,T=Ylt,b=Vlt,F=Slt,B=Olt,U=Blt,Q=Glt,M=Wlt,k=t[0],y=t[1];b=o.geodeticSurfaceNormal(k,b),C=l.subtract(y,k,C),C=l.normalize(C,C),Q=l.cross(b,C,Q),Q=l.normalize(Q,Q);let c=r[0],g=r[1];s&&(I=bh(k,Q,d,I,o,c+f,1,1)),M=l.clone(k,M),k=y,N=l.negate(C,N);let O,D;for(let H=1;H<_-1;H++){let j=s?2:1;if(y=t[H+1],k.equals(y)){zC("Positions are too close and are considered equivalent with rounding error.");continue}C=l.subtract(y,k,C),C=l.normalize(C,C),T=l.add(C,N,T),T=l.normalize(T,T),b=o.geodeticSurfaceNormal(k,b);let X=l.multiplyByScalar(b,l.dot(C,b),Plt);l.subtract(C,X,X),l.normalize(X,X);let tt=l.multiplyByScalar(b,l.dot(N,b),Jlt);if(l.subtract(N,tt,tt),l.normalize(tt,tt),!L.equalsEpsilon(Math.abs(l.dot(X,tt)),1,L.EPSILON7)){T=l.cross(T,b,T),T=l.cross(b,T,T),T=l.normalize(T,T);let It=1/Math.max(.25,l.magnitude(l.cross(T,N,Of))),gt=IR.angleIsGreaterThanPi(C,N,k,o);gt?(F=l.add(k,l.multiplyByScalar(T,It*E,T),F),B=l.add(F,l.multiplyByScalar(Q,E,B),B),Ks[0]=l.clone(M,Ks[0]),Ks[1]=l.clone(B,Ks[1]),O=wS(Ks,c+f,g+f,a),D=Sn.generateArc({positions:Ks,granularity:a,ellipsoid:o}),R=PS(D,Q,A,R,o,O,1),Q=l.cross(b,C,Q),Q=l.normalize(Q,Q),U=l.add(F,l.multiplyByScalar(Q,E,U),U),h===Cn.ROUNDED||h===Cn.BEVELED?kz(F,B,U,h,gt,o,R,A,g+f,s):(T=l.negate(T,T),R=bh(k,T,A,R,o,g+f,It,j)),M=l.clone(U,M)):(F=l.add(k,l.multiplyByScalar(T,It*E,T),F),B=l.add(F,l.multiplyByScalar(Q,-E,B),B),Ks[0]=l.clone(M,Ks[0]),Ks[1]=l.clone(B,Ks[1]),O=wS(Ks,c+f,g+f,a),D=Sn.generateArc({positions:Ks,granularity:a,ellipsoid:o}),R=PS(D,Q,A,R,o,O,1),Q=l.cross(b,C,Q),Q=l.normalize(Q,Q),U=l.add(F,l.multiplyByScalar(Q,-E,U),U),h===Cn.ROUNDED||h===Cn.BEVELED?kz(F,B,U,h,gt,o,R,A,g+f,s):R=bh(k,T,A,R,o,g+f,It,j),M=l.clone(U,M)),N=l.negate(C,N)}else R=bh(M,Q,A,R,o,c+f,1,1),M=k;c=g,g=r[H+1],k=y}Ks[0]=l.clone(M,Ks[0]),Ks[1]=l.clone(k,Ks[1]),O=wS(Ks,c+f,g+f,a),D=Sn.generateArc({positions:Ks,granularity:a,ellipsoid:o}),R=PS(D,Q,A,R,o,O,1),s&&(I=bh(k,Q,d,I,o,g+f,1,1)),_=R.length;let w=s?_+I.length:_,x=new Float64Array(w);return x.set(R),s&&x.set(I,_),x};Lc=IR});function tg(t,e,i,n,s){let o=l.angleBetween(l.subtract(e,t,Bf),l.subtract(i,t,Pz)),r=n===Cn.BEVELED?1:Math.ceil(o/L.toRadians(5))+1,a=r*3,h=new Array(a);h[a-3]=i.x,h[a-2]=i.y,h[a-1]=i.z;let A;s?A=lt.fromQuaternion(Ae.fromAxisAngle(l.negate(t,Bf),o/r,yz),wz):A=lt.fromQuaternion(Ae.fromAxisAngle(t,o/r,yz),wz);let d=0;e=l.clone(e,Bf);for(let f=0;f<r;f++)e=lt.multiplyByVector(A,e,e),h[d++]=e.x,h[d++]=e.y,h[d++]=e.z;return h}function tdt(t){let e=Jz,i=jz,n=Hz,s=t[1];i=l.fromArray(t[1],s.length-3,i),n=l.fromArray(t[0],0,n),e=l.midpoint(i,n,e);let o=tg(e,i,n,Cn.ROUNDED,!1),r=t.length-1,a=t[r-1];s=t[r],i=l.fromArray(a,a.length-3,i),n=l.fromArray(s,0,n),e=l.midpoint(i,n,e);let h=tg(e,i,n,Cn.ROUNDED,!1);return[o,h]}function xz(t,e,i,n){let s=Bf;return n?s=l.add(t,e,s):(e=l.negate(e,e),s=l.add(t,e,s)),[s.x,s.y,s.z,i.x,i.y,i.z]}function JS(t,e,i,n){let s=new Array(t.length),o=new Array(t.length),r=l.multiplyByScalar(e,i,Bf),a=l.negate(r,Pz),h=0,A=t.length-1;for(let d=0;d<t.length;d+=3){let f=l.fromArray(t,d,jlt),E=l.add(f,a,Lz);s[h++]=E.x,s[h++]=E.y,s[h++]=E.z;let _=l.add(f,r,Lz);o[A--]=_.z,o[A--]=_.y,o[A--]=_.x}return n.push(s,o),n}var jS,Bf,Pz,jlt,Lz,wo,Jz,jz,Hz,Hlt,vlt,zlt,Klt,Xlt,qlt,$lt,yz,wz,edt,idt,vi,HS=S(()=>{Ht();fd();mt();_e();dn();Sf();$C();$s();jS={},Bf=new l,Pz=new l,jlt=new l,Lz=new l,wo=[new l,new l],Jz=new l,jz=new l,Hz=new l,Hlt=new l,vlt=new l,zlt=new l,Klt=new l,Xlt=new l,qlt=new l,$lt=new l,yz=new Ae,wz=new lt;jS.addAttribute=function(t,e,i,n){let s=e.x,o=e.y,r=e.z;m(i)&&(t[i]=s,t[i+1]=o,t[i+2]=r),m(n)&&(t[n]=r,t[n-1]=o,t[n-2]=s)};edt=new l,idt=new l;jS.computePositions=function(t){let e=t.granularity,i=t.positions,n=t.ellipsoid,s=t.width/2,o=t.cornerType,r=t.saveAttributes,a=Jz,h=jz,A=Hz,d=Hlt,f=vlt,E=zlt,_=Klt,R=Xlt,I=qlt,C=$lt,N=[],T=r?[]:void 0,b=r?[]:void 0,F=i[0],B=i[1];h=l.normalize(l.subtract(B,F,h),h),a=n.geodeticSurfaceNormal(F,a),d=l.normalize(l.cross(a,h,d),d),r&&(T.push(d.x,d.y,d.z),b.push(a.x,a.y,a.z)),_=l.clone(F,_),F=B,A=l.negate(h,A);let U,Q=[],M,k=i.length;for(M=1;M<k-1;M++){a=n.geodeticSurfaceNormal(F,a),B=i[M+1],h=l.normalize(l.subtract(B,F,h),h),f=l.normalize(l.add(h,A,f),f);let c=l.multiplyByScalar(a,l.dot(h,a),edt);l.subtract(h,c,c),l.normalize(c,c);let g=l.multiplyByScalar(a,l.dot(A,a),idt);if(l.subtract(A,g,g),l.normalize(g,g),!L.equalsEpsilon(Math.abs(l.dot(c,g)),1,L.EPSILON7)){f=l.cross(f,a,f),f=l.cross(a,f,f),f=l.normalize(f,f);let D=s/Math.max(.25,l.magnitude(l.cross(f,A,Bf))),w=Lc.angleIsGreaterThanPi(h,A,F,n);f=l.multiplyByScalar(f,D,f),w?(R=l.add(F,f,R),C=l.add(R,l.multiplyByScalar(d,s,C),C),I=l.add(R,l.multiplyByScalar(d,s*2,I),I),wo[0]=l.clone(_,wo[0]),wo[1]=l.clone(C,wo[1]),U=Sn.generateArc({positions:wo,granularity:e,ellipsoid:n}),N=JS(U,d,s,N),r&&(T.push(d.x,d.y,d.z),b.push(a.x,a.y,a.z)),E=l.clone(I,E),d=l.normalize(l.cross(a,h,d),d),I=l.add(R,l.multiplyByScalar(d,s*2,I),I),_=l.add(R,l.multiplyByScalar(d,s,_),_),o===Cn.ROUNDED||o===Cn.BEVELED?Q.push({leftPositions:tg(R,E,I,o,w)}):Q.push({leftPositions:xz(F,l.negate(f,f),I,w)})):(I=l.add(F,f,I),C=l.add(I,l.negate(l.multiplyByScalar(d,s,C),C),C),R=l.add(I,l.negate(l.multiplyByScalar(d,s*2,R),R),R),wo[0]=l.clone(_,wo[0]),wo[1]=l.clone(C,wo[1]),U=Sn.generateArc({positions:wo,granularity:e,ellipsoid:n}),N=JS(U,d,s,N),r&&(T.push(d.x,d.y,d.z),b.push(a.x,a.y,a.z)),E=l.clone(R,E),d=l.normalize(l.cross(a,h,d),d),R=l.add(I,l.negate(l.multiplyByScalar(d,s*2,R),R),R),_=l.add(I,l.negate(l.multiplyByScalar(d,s,_),_),_),o===Cn.ROUNDED||o===Cn.BEVELED?Q.push({rightPositions:tg(I,E,R,o,w)}):Q.push({rightPositions:xz(F,f,R,w)})),A=l.negate(h,A)}F=B}a=n.geodeticSurfaceNormal(F,a),wo[0]=l.clone(_,wo[0]),wo[1]=l.clone(F,wo[1]),U=Sn.generateArc({positions:wo,granularity:e,ellipsoid:n}),N=JS(U,d,s,N),r&&(T.push(d.x,d.y,d.z),b.push(a.x,a.y,a.z));let y;return o===Cn.ROUNDED&&(y=tdt(N)),{positions:N,corners:Q,lefts:T,normals:b,endPositions:y}};vi=jS});function $z(t,e){for(let i=0;i<t.length;i++)t[i]=e.scaleToGeodeticSurface(t[i],t[i]);return t}function Ja(t,e,i,n,s,o){let r=t.normals,a=t.tangents,h=t.bitangents,A=l.normalize(l.cross(i,e,yc),yc);o.normal&&vi.addAttribute(r,e,n,s),o.tangent&&vi.addAttribute(a,A,n,s),o.bitangent&&vi.addAttribute(h,i,n,s)}function t5(t,e,i){let n=t.positions,s=t.corners,o=t.endPositions,r=t.lefts,a=t.normals,h=new we,A,d=0,f=0,E,_=0,R;for(E=0;E<n.length;E+=2)R=n[E].length-3,d+=R,_+=R*2,f+=n[E+1].length-3;for(d+=3,f+=3,E=0;E<s.length;E++){A=s[E];let Ct=s[E].leftPositions;m(Ct)?(R=Ct.length,d+=R,_+=R):(R=s[E].rightPositions.length,f+=R,_+=R)}let I=m(o),C;I&&(C=o[0].length-3,d+=C,f+=C,C/=3,_+=C*6);let N=d+f,T=new Float64Array(N),b=e.normal?new Float32Array(N):void 0,F=e.tangent?new Float32Array(N):void 0,B=e.bitangent?new Float32Array(N):void 0,U={normals:b,tangents:F,bitangents:B},Q=0,M=N-1,k,y,c,g,O=Kz,D=Xz,w,x,H=C/2,j=te.createTypedArray(N/3,_),X=0;if(I){x=eg,w=ig;let Ct=o[0];for(O=l.fromArray(a,0,O),D=l.fromArray(r,0,D),E=0;E<H;E++)x=l.fromArray(Ct,(H-1-E)*3,x),w=l.fromArray(Ct,(H+E)*3,w),vi.addAttribute(T,w,Q),vi.addAttribute(T,x,void 0,M),Ja(U,O,D,Q,M,e),y=Q/3,g=y+1,k=(M-2)/3,c=k-1,j[X++]=k,j[X++]=y,j[X++]=c,j[X++]=c,j[X++]=y,j[X++]=g,Q+=3,M-=3}let tt=0,G=0,It=n[tt++],gt=n[tt++];T.set(It,Q),T.set(gt,M-gt.length+1),D=l.fromArray(r,G,D);let Yt,Ut;for(R=gt.length-3,E=0;E<R;E+=3)Yt=i.geodeticSurfaceNormal(l.fromArray(It,E,yc),yc),Ut=i.geodeticSurfaceNormal(l.fromArray(gt,R-E,Gf),Gf),O=l.normalize(l.add(Yt,Ut,O),O),Ja(U,O,D,Q,M,e),y=Q/3,g=y+1,k=(M-2)/3,c=k-1,j[X++]=k,j[X++]=y,j[X++]=c,j[X++]=c,j[X++]=y,j[X++]=g,Q+=3,M-=3;for(Yt=i.geodeticSurfaceNormal(l.fromArray(It,R,yc),yc),Ut=i.geodeticSurfaceNormal(l.fromArray(gt,R,Gf),Gf),O=l.normalize(l.add(Yt,Ut,O),O),G+=3,E=0;E<s.length;E++){let Ct;A=s[E];let zt=A.leftPositions,kt=A.rightPositions,Jt,Wt,bt=qz,ee=eg,ce=ig;if(O=l.fromArray(a,G,O),m(zt)){for(Ja(U,O,D,void 0,M,e),M-=3,Jt=g,Wt=c,Ct=0;Ct<zt.length/3;Ct++)bt=l.fromArray(zt,Ct*3,bt),j[X++]=Jt,j[X++]=Wt-Ct-1,j[X++]=Wt-Ct,vi.addAttribute(T,bt,void 0,M),ee=l.fromArray(T,(Wt-Ct-1)*3,ee),ce=l.fromArray(T,Jt*3,ce),D=l.normalize(l.subtract(ee,ce,D),D),Ja(U,O,D,void 0,M,e),M-=3;bt=l.fromArray(T,Jt*3,bt),ee=l.subtract(l.fromArray(T,Wt*3,ee),bt,ee),ce=l.subtract(l.fromArray(T,(Wt-Ct)*3,ce),bt,ce),D=l.normalize(l.add(ee,ce,D),D),Ja(U,O,D,Q,void 0,e),Q+=3}else{for(Ja(U,O,D,Q,void 0,e),Q+=3,Jt=c,Wt=g,Ct=0;Ct<kt.length/3;Ct++)bt=l.fromArray(kt,Ct*3,bt),j[X++]=Jt,j[X++]=Wt+Ct,j[X++]=Wt+Ct+1,vi.addAttribute(T,bt,Q),ee=l.fromArray(T,Jt*3,ee),ce=l.fromArray(T,(Wt+Ct)*3,ce),D=l.normalize(l.subtract(ee,ce,D),D),Ja(U,O,D,Q,void 0,e),Q+=3;bt=l.fromArray(T,Jt*3,bt),ee=l.subtract(l.fromArray(T,(Wt+Ct)*3,ee),bt,ee),ce=l.subtract(l.fromArray(T,Wt*3,ce),bt,ce),D=l.normalize(l.negate(l.add(ce,ee,D),D),D),Ja(U,O,D,void 0,M,e),M-=3}for(It=n[tt++],gt=n[tt++],It.splice(0,3),gt.splice(gt.length-3,3),T.set(It,Q),T.set(gt,M-gt.length+1),R=gt.length-3,G+=3,D=l.fromArray(r,G,D),Ct=0;Ct<gt.length;Ct+=3)Yt=i.geodeticSurfaceNormal(l.fromArray(It,Ct,yc),yc),Ut=i.geodeticSurfaceNormal(l.fromArray(gt,R-Ct,Gf),Gf),O=l.normalize(l.add(Yt,Ut,O),O),Ja(U,O,D,Q,M,e),g=Q/3,y=g-1,c=(M-2)/3,k=c+1,j[X++]=k,j[X++]=y,j[X++]=c,j[X++]=c,j[X++]=y,j[X++]=g,Q+=3,M-=3;Q-=3,M+=3}if(O=l.fromArray(a,a.length-3,O),Ja(U,O,D,Q,M,e),I){Q+=3,M-=3,x=eg,w=ig;let Ct=o[1];for(E=0;E<H;E++)x=l.fromArray(Ct,(C-E-1)*3,x),w=l.fromArray(Ct,E*3,w),vi.addAttribute(T,x,void 0,M),vi.addAttribute(T,w,Q),Ja(U,O,D,Q,M,e),g=Q/3,y=g-1,c=(M-2)/3,k=c+1,j[X++]=k,j[X++]=y,j[X++]=c,j[X++]=c,j[X++]=y,j[X++]=g,Q+=3,M-=3}if(h.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:T}),e.st){let Ct=new Float32Array(N/3*2),zt,kt,Jt=0;if(I){d/=3,f/=3;let Wt=Math.PI/(C+1);kt=1/(d-C+1),zt=1/(f-C+1);let bt,ee=C/2;for(E=ee+1;E<C+1;E++)bt=L.PI_OVER_TWO+Wt*E,Ct[Jt++]=zt*(1+Math.cos(bt)),Ct[Jt++]=.5*(1+Math.sin(bt));for(E=1;E<f-C+1;E++)Ct[Jt++]=E*zt,Ct[Jt++]=0;for(E=C;E>ee;E--)bt=L.PI_OVER_TWO-E*Wt,Ct[Jt++]=1-zt*(1+Math.cos(bt)),Ct[Jt++]=.5*(1+Math.sin(bt));for(E=ee;E>0;E--)bt=L.PI_OVER_TWO-Wt*E,Ct[Jt++]=1-kt*(1+Math.cos(bt)),Ct[Jt++]=.5*(1+Math.sin(bt));for(E=d-C;E>0;E--)Ct[Jt++]=E*kt,Ct[Jt++]=1;for(E=1;E<ee+1;E++)bt=L.PI_OVER_TWO+Wt*E,Ct[Jt++]=kt*(1+Math.cos(bt)),Ct[Jt++]=.5*(1+Math.sin(bt))}else{for(d/=3,f/=3,kt=1/(d-1),zt=1/(f-1),E=0;E<f;E++)Ct[Jt++]=E*zt,Ct[Jt++]=0;for(E=d;E>0;E--)Ct[Jt++]=(E-1)*kt,Ct[Jt++]=1}h.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:Ct})}return e.normal&&(h.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:U.normals})),e.tangent&&(h.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:U.tangents})),e.bitangent&&(h.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:U.bitangents})),{attributes:h,indices:j}}function sdt(t,e){if(!e.normal&&!e.tangent&&!e.bitangent&&!e.st)return t;let i=t.position.values,n,s;(e.normal||e.bitangent)&&(n=t.normal.values,s=t.bitangent.values);let o=t.position.values.length/18,r=o*3,a=o*2,h=r*2,A;if(e.normal||e.bitangent||e.tangent){let d=e.normal?new Float32Array(r*6):void 0,f=e.tangent?new Float32Array(r*6):void 0,E=e.bitangent?new Float32Array(r*6):void 0,_=Kz,R=Xz,I=eg,C=ig,N=ndt,T=qz,b=h;for(A=0;A<r;A+=3){let F=b+h;_=l.fromArray(i,A,_),R=l.fromArray(i,A+r,R),I=l.fromArray(i,(A+3)%r,I),R=l.subtract(R,_,R),I=l.subtract(I,_,I),C=l.normalize(l.cross(R,I,C),C),e.normal&&(vi.addAttribute(d,C,F),vi.addAttribute(d,C,F+3),vi.addAttribute(d,C,b),vi.addAttribute(d,C,b+3)),(e.tangent||e.bitangent)&&(T=l.fromArray(n,A,T),e.bitangent&&(vi.addAttribute(E,T,F),vi.addAttribute(E,T,F+3),vi.addAttribute(E,T,b),vi.addAttribute(E,T,b+3)),e.tangent&&(N=l.normalize(l.cross(T,C,N),N),vi.addAttribute(f,N,F),vi.addAttribute(f,N,F+3),vi.addAttribute(f,N,b),vi.addAttribute(f,N,b+3))),b+=6}if(e.normal){for(d.set(n),A=0;A<r;A+=3)d[A+r]=-n[A],d[A+r+1]=-n[A+1],d[A+r+2]=-n[A+2];t.normal.values=d}else t.normal=void 0;if(e.bitangent?(E.set(s),E.set(s,r),t.bitangent.values=E):t.bitangent=void 0,e.tangent){let F=t.tangent.values;f.set(F),f.set(F,r),t.tangent.values=f}}if(e.st){let d=t.st.values,f=new Float32Array(a*6);f.set(d),f.set(d,a);let E=a*2;for(let _=0;_<2;_++){for(f[E++]=d[0],f[E++]=d[1],A=2;A<a;A+=2){let R=d[A],I=d[A+1];f[E++]=R,f[E++]=I,f[E++]=R,f[E++]=I}f[E++]=d[0],f[E++]=d[1]}t.st.values=f}return t}function vS(t,e,i){i[e++]=t[0],i[e++]=t[1],i[e++]=t[2];for(let n=3;n<t.length;n+=3){let s=t[n],o=t[n+1],r=t[n+2];i[e++]=s,i[e++]=o,i[e++]=r,i[e++]=s,i[e++]=o,i[e++]=r}return i[e++]=t[0],i[e++]=t[1],i[e++]=t[2],i}function odt(t,e){let i=new St({position:e.position,normal:e.normal||e.bitangent||t.shadowVolume,tangent:e.tangent,bitangent:e.normal||e.bitangent,st:e.st}),n=t.ellipsoid,s=vi.computePositions(t),o=t5(s,i,n),r=t.height,a=t.extrudedHeight,h=o.attributes,A=o.indices,d=h.position.values,f=d.length,E=new Float64Array(f*6),_=new Float64Array(f);_.set(d);let R=new Float64Array(f*4);d=ui.scaleToGeodeticHeight(d,r,n),R=vS(d,0,R),_=ui.scaleToGeodeticHeight(_,a,n),R=vS(_,f*2,R),E.set(d),E.set(_,f),E.set(R,f*2),h.position.values=E,h=sdt(h,e);let I,C=f/3;if(t.shadowVolume){let k=h.normal.values;f=k.length;let y=new Float32Array(f*6);for(I=0;I<f;I++)k[I]=-k[I];y.set(k,f),y=vS(k,f*4,y),h.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:y}),e.normal||(h.normal=void 0)}if(m(t.offsetAttribute)){let k=new Uint8Array(C*6);if(t.offsetAttribute===Pe.TOP)k=k.fill(1,0,C).fill(1,C*2,C*4);else{let y=t.offsetAttribute===Pe.NONE?0:1;k=k.fill(y)}h.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:k})}let N=A.length,T=C+C,b=te.createTypedArray(E.length/3,N*2+T*3);b.set(A);let F=N;for(I=0;I<N;I+=3){let k=A[I],y=A[I+1],c=A[I+2];b[F++]=c+C,b[F++]=y+C,b[F++]=k+C}let B,U,Q,M;for(I=0;I<T;I+=2)B=I+T,U=B+T,Q=B+1,M=U+1,b[F++]=B,b[F++]=U,b[F++]=Q,b[F++]=Q,b[F++]=U,b[F++]=M;return{attributes:h,indices:b}}function zz(t,e,i,n,s,o){let r=l.subtract(e,t,vz);l.normalize(r,r);let a=i.geodeticSurfaceNormal(t,pR),h=l.cross(r,a,vz);l.multiplyByScalar(h,n,h);let A=s.latitude,d=s.longitude,f=o.latitude,E=o.longitude;l.add(t,h,pR),i.cartesianToCartographic(pR,$r);let _=$r.latitude,R=$r.longitude;A=Math.min(A,_),d=Math.min(d,R),f=Math.max(f,_),E=Math.max(E,R),l.subtract(t,h,pR),i.cartesianToCartographic(pR,$r),_=$r.latitude,R=$r.longitude,A=Math.min(A,_),d=Math.min(d,R),f=Math.max(f,_),E=Math.max(E,R),s.latitude=A,s.longitude=d,o.latitude=f,o.longitude=E}function e5(t,e,i,n,s){t=$z(t,e);let o=Xn(t,l.equalsEpsilon),r=o.length;if(r<2||i<=0)return new Xt;let a=i*.5;rr.latitude=Number.POSITIVE_INFINITY,rr.longitude=Number.POSITIVE_INFINITY,ar.latitude=Number.NEGATIVE_INFINITY,ar.longitude=Number.NEGATIVE_INFINITY;let h,A;if(n===Cn.ROUNDED){let E=o[0];l.subtract(E,o[1],qr),l.normalize(qr,qr),l.multiplyByScalar(qr,a,qr),l.add(E,qr,uR),e.cartesianToCartographic(uR,$r),h=$r.latitude,A=$r.longitude,rr.latitude=Math.min(rr.latitude,h),rr.longitude=Math.min(rr.longitude,A),ar.latitude=Math.max(ar.latitude,h),ar.longitude=Math.max(ar.longitude,A)}for(let E=0;E<r-1;++E)zz(o[E],o[E+1],e,a,rr,ar);let d=o[r-1];l.subtract(d,o[r-2],qr),l.normalize(qr,qr),l.multiplyByScalar(qr,a,qr),l.add(d,qr,uR),zz(d,uR,e,a,rr,ar),n===Cn.ROUNDED&&(e.cartesianToCartographic(uR,$r),h=$r.latitude,A=$r.longitude,rr.latitude=Math.min(rr.latitude,h),rr.longitude=Math.min(rr.longitude,A),ar.latitude=Math.max(ar.latitude,h),ar.longitude=Math.max(ar.longitude,A));let f=m(s)?s:new Xt;return f.north=ar.latitude,f.south=rr.latitude,f.east=ar.longitude,f.west=rr.longitude,f}function Vh(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.width;p.defined("options.positions",e),p.defined("options.width",i);let n=Z(t.height,0),s=Z(t.extrudedHeight,n);this._positions=e,this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._vertexFormat=St.clone(Z(t.vertexFormat,St.DEFAULT)),this._width=i,this._height=Math.max(n,s),this._extrudedHeight=Math.min(n,s),this._cornerType=Z(t.cornerType,Cn.ROUNDED),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._shadowVolume=Z(t.shadowVolume,!1),this._workerName="createCorridorGeometry",this._offsetAttribute=t.offsetAttribute,this._rectangle=void 0,this.packedLength=1+e.length*l.packedLength+ot.packedLength+St.packedLength+7}var Kz,Xz,eg,ig,ndt,qz,yc,Gf,vz,pR,$r,qr,uR,rr,ar,i5,n5,Yh,zS,s5=S(()=>{Sa();_i();Ht();ri();ae();oi();fd();HS();Ft();mt();Oe();yi();ji();En();go();Di();_e();Pa();Xi();pn();Ls();Kz=new l,Xz=new l,eg=new l,ig=new l,ndt=new l,qz=new l,yc=new l,Gf=new l;vz=new l,pR=new l,$r=new ut;qr=new l,uR=new l,rr=new ut,ar=new ut;Vh.pack=function(t,e,i){p.defined("value",t),p.defined("array",e),i=Z(i,0);let n=t._positions,s=n.length;e[i++]=s;for(let o=0;o<s;++o,i+=l.packedLength)l.pack(n[o],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,St.pack(t._vertexFormat,e,i),i+=St.packedLength,e[i++]=t._width,e[i++]=t._height,e[i++]=t._extrudedHeight,e[i++]=t._cornerType,e[i++]=t._granularity,e[i++]=t._shadowVolume?1:0,e[i]=Z(t._offsetAttribute,-1),e};i5=ot.clone(ot.UNIT_SPHERE),n5=new St,Yh={positions:void 0,ellipsoid:i5,vertexFormat:n5,width:void 0,height:void 0,extrudedHeight:void 0,cornerType:void 0,granularity:void 0,shadowVolume:void 0,offsetAttribute:void 0};Vh.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=t[e++],s=new Array(n);for(let R=0;R<n;++R,e+=l.packedLength)s[R]=l.unpack(t,e);let o=ot.unpack(t,e,i5);e+=ot.packedLength;let r=St.unpack(t,e,n5);e+=St.packedLength;let a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++],E=t[e++]===1,_=t[e];return m(i)?(i._positions=s,i._ellipsoid=ot.clone(o,i._ellipsoid),i._vertexFormat=St.clone(r,i._vertexFormat),i._width=a,i._height=h,i._extrudedHeight=A,i._cornerType=d,i._granularity=f,i._shadowVolume=E,i._offsetAttribute=_===-1?void 0:_,i):(Yh.positions=s,Yh.width=a,Yh.height=h,Yh.extrudedHeight=A,Yh.cornerType=d,Yh.granularity=f,Yh.shadowVolume=E,Yh.offsetAttribute=_===-1?void 0:_,new Vh(Yh))};Vh.computeRectangle=function(t,e){t=Z(t,Z.EMPTY_OBJECT);let i=t.positions,n=t.width;p.defined("options.positions",i),p.defined("options.width",n);let s=Z(t.ellipsoid,ot.WGS84),o=Z(t.cornerType,Cn.ROUNDED);return e5(i,s,n,o,e)};Vh.createGeometry=function(t){let e=t._positions,i=t._width,n=t._ellipsoid;e=$z(e,n);let s=Xn(e,l.equalsEpsilon);if(s.length<2||i<=0)return;let o=t._height,r=t._extrudedHeight,a=!L.equalsEpsilon(o,r,0,L.EPSILON2),h=t._vertexFormat,A={ellipsoid:n,positions:s,width:i,cornerType:t._cornerType,granularity:t._granularity,saveAttributes:!0},d;if(a)A.height=o,A.extrudedHeight=r,A.shadowVolume=t._shadowVolume,A.offsetAttribute=t._offsetAttribute,d=odt(A,h);else{let _=vi.computePositions(A);if(d=t5(_,h,n),d.attributes.position.values=ui.scaleToGeodeticHeight(d.attributes.position.values,o,n),m(t._offsetAttribute)){let R=t._offsetAttribute===Pe.NONE?0:1,I=d.attributes.position.values.length,C=new Uint8Array(I/3).fill(R);d.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:C})}}let f=d.attributes,E=Nt.fromVertices(f.position.values,void 0,3);return h.position||(d.attributes.position.values=void 0),new se({attributes:f,indices:d.indices,primitiveType:ne.TRIANGLES,boundingSphere:E,offsetAttribute:t._offsetAttribute})};Vh.createShadowVolume=function(t,e,i){let n=t._granularity,s=t._ellipsoid,o=e(n,s),r=i(n,s);return new Vh({positions:t._positions,width:t._width,cornerType:t._cornerType,ellipsoid:s,granularity:n,extrudedHeight:o,height:r,vertexFormat:St.POSITION_ONLY,shadowVolume:!0})};Object.defineProperties(Vh.prototype,{rectangle:{get:function(){return m(this._rectangle)||(this._rectangle=e5(this._positions,this._ellipsoid,this._width,this._cornerType)),this._rectangle}},textureCoordinateRotationPoints:{get:function(){return[0,0,0,1,1,0]}}});zS=Vh});var KS={};He(KS,{default:()=>adt});function rdt(t,e){return m(e)&&(t=zS.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),zS.createGeometry(t)}var adt,XS=S(()=>{s5();mt();Oe();adt=rdt});function hdt(t,e){for(let i=0;i<t.length;i++)t[i]=e.scaleToGeodeticSurface(t[i],t[i]);return t}function a5(t,e){let i=[],n=t.positions,s=t.corners,o=t.endPositions,r=new we,a,h=0,A=0,d,f=0,E;for(d=0;d<n.length;d+=2)E=n[d].length-3,h+=E,f+=E/3*4,A+=n[d+1].length-3;for(h+=3,A+=3,d=0;d<s.length;d++){a=s[d];let w=s[d].leftPositions;m(w)?(E=w.length,h+=E,f+=E/3*2):(E=s[d].rightPositions.length,A+=E,f+=E/3*2)}let _=m(o),R;_&&(R=o[0].length-3,h+=R,A+=R,R/=3,f+=R*4);let I=h+A,C=new Float64Array(I),N=0,T=I-1,b,F,B,U,Q,M,k=R/2,y=te.createTypedArray(I/3,f+4),c=0;if(y[c++]=N/3,y[c++]=(T-2)/3,_){i.push(N/3),M=o5,Q=r5;let w=o[0];for(d=0;d<k;d++)M=l.fromArray(w,(k-1-d)*3,M),Q=l.fromArray(w,(k+d)*3,Q),vi.addAttribute(C,Q,N),vi.addAttribute(C,M,void 0,T),F=N/3,U=F+1,b=(T-2)/3,B=b-1,y[c++]=b,y[c++]=B,y[c++]=F,y[c++]=U,N+=3,T-=3}let g=0,O=n[g++],D=n[g++];for(C.set(O,N),C.set(D,T-D.length+1),E=D.length-3,i.push(N/3,(T-2)/3),d=0;d<E;d+=3)F=N/3,U=F+1,b=(T-2)/3,B=b-1,y[c++]=b,y[c++]=B,y[c++]=F,y[c++]=U,N+=3,T-=3;for(d=0;d<s.length;d++){let w;a=s[d];let x=a.leftPositions,H=a.rightPositions,j,X=Adt;if(m(x)){for(T-=3,j=B,i.push(U),w=0;w<x.length/3;w++)X=l.fromArray(x,w*3,X),y[c++]=j-w-1,y[c++]=j-w,vi.addAttribute(C,X,void 0,T),T-=3;i.push(j-Math.floor(x.length/6)),e===Cn.BEVELED&&i.push((T-2)/3+1),N+=3}else{for(N+=3,j=U,i.push(B),w=0;w<H.length/3;w++)X=l.fromArray(H,w*3,X),y[c++]=j+w,y[c++]=j+w+1,vi.addAttribute(C,X,N),N+=3;i.push(j+Math.floor(H.length/6)),e===Cn.BEVELED&&i.push(N/3-1),T-=3}for(O=n[g++],D=n[g++],O.splice(0,3),D.splice(D.length-3,3),C.set(O,N),C.set(D,T-D.length+1),E=D.length-3,w=0;w<D.length;w+=3)U=N/3,F=U-1,B=(T-2)/3,b=B+1,y[c++]=b,y[c++]=B,y[c++]=F,y[c++]=U,N+=3,T-=3;N-=3,T+=3,i.push(N/3,(T-2)/3)}if(_){N+=3,T-=3,M=o5,Q=r5;let w=o[1];for(d=0;d<k;d++)M=l.fromArray(w,(R-d-1)*3,M),Q=l.fromArray(w,d*3,Q),vi.addAttribute(C,M,void 0,T),vi.addAttribute(C,Q,N),U=N/3,F=U-1,B=(T-2)/3,b=B+1,y[c++]=b,y[c++]=B,y[c++]=F,y[c++]=U,N+=3,T-=3;i.push(N/3)}else i.push(N/3,(T-2)/3);return y[c++]=N/3,y[c++]=(T-2)/3,r.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:C}),{attributes:r,indices:y,wallIndices:i}}function cdt(t){let e=t.ellipsoid,i=vi.computePositions(t),n=a5(i,t.cornerType),s=n.wallIndices,o=t.height,r=t.extrudedHeight,a=n.attributes,h=n.indices,A=a.position.values,d=A.length,f=new Float64Array(d);f.set(A);let E=new Float64Array(d*2);if(A=ui.scaleToGeodeticHeight(A,o,e),f=ui.scaleToGeodeticHeight(f,r,e),E.set(A),E.set(f,d),a.position.values=E,d/=3,m(t.offsetAttribute)){let b=new Uint8Array(d*2);if(t.offsetAttribute===Pe.TOP)b=b.fill(1,0,d);else{let F=t.offsetAttribute===Pe.NONE?0:1;b=b.fill(F)}a.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:b})}let _,R=h.length,I=te.createTypedArray(E.length/3,(R+s.length)*2);I.set(h);let C=R;for(_=0;_<R;_+=2){let b=h[_],F=h[_+1];I[C++]=b+d,I[C++]=F+d}let N,T;for(_=0;_<s.length;_++)N=s[_],T=N+d,I[C++]=N,I[C++]=T;return{attributes:a,indices:I}}function CR(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.width;p.typeOf.object("options.positions",e),p.typeOf.number("options.width",i);let n=Z(t.height,0),s=Z(t.extrudedHeight,n);this._positions=e,this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._width=i,this._height=Math.max(n,s),this._extrudedHeight=Math.min(n,s),this._cornerType=Z(t.cornerType,Cn.ROUNDED),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._offsetAttribute=t.offsetAttribute,this._workerName="createCorridorOutlineGeometry",this.packedLength=1+e.length*l.packedLength+ot.packedLength+6}var o5,r5,Adt,A5,wc,qS,h5=S(()=>{Sa();_i();Ht();ae();oi();fd();HS();Ft();mt();Oe();yi();ji();En();go();Di();_e();Pa();Xi();o5=new l,r5=new l,Adt=new l;CR.pack=function(t,e,i){p.typeOf.object("value",t),p.typeOf.object("array",e),i=Z(i,0);let n=t._positions,s=n.length;e[i++]=s;for(let o=0;o<s;++o,i+=l.packedLength)l.pack(n[o],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._width,e[i++]=t._height,e[i++]=t._extrudedHeight,e[i++]=t._cornerType,e[i++]=t._granularity,e[i]=Z(t._offsetAttribute,-1),e};A5=ot.clone(ot.UNIT_SPHERE),wc={positions:void 0,ellipsoid:A5,width:void 0,height:void 0,extrudedHeight:void 0,cornerType:void 0,granularity:void 0,offsetAttribute:void 0};CR.unpack=function(t,e,i){p.typeOf.object("array",t),e=Z(e,0);let n=t[e++],s=new Array(n);for(let E=0;E<n;++E,e+=l.packedLength)s[E]=l.unpack(t,e);let o=ot.unpack(t,e,A5);e+=ot.packedLength;let r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e];return m(i)?(i._positions=s,i._ellipsoid=ot.clone(o,i._ellipsoid),i._width=r,i._height=a,i._extrudedHeight=h,i._cornerType=A,i._granularity=d,i._offsetAttribute=f===-1?void 0:f,i):(wc.positions=s,wc.width=r,wc.height=a,wc.extrudedHeight=h,wc.cornerType=A,wc.granularity=d,wc.offsetAttribute=f===-1?void 0:f,new CR(wc))};CR.createGeometry=function(t){let e=t._positions,i=t._width,n=t._ellipsoid;e=hdt(e,n);let s=Xn(e,l.equalsEpsilon);if(s.length<2||i<=0)return;let o=t._height,r=t._extrudedHeight,a=!L.equalsEpsilon(o,r,0,L.EPSILON2),h={ellipsoid:n,positions:s,width:i,cornerType:t._cornerType,granularity:t._granularity,saveAttributes:!1},A;if(a)h.height=o,h.extrudedHeight=r,h.offsetAttribute=t._offsetAttribute,A=cdt(h);else{let E=vi.computePositions(h);if(A=a5(E,h.cornerType),A.attributes.position.values=ui.scaleToGeodeticHeight(A.attributes.position.values,o,n),m(t._offsetAttribute)){let _=A.attributes.position.values.length,R=t._offsetAttribute===Pe.NONE?0:1,I=new Uint8Array(_/3).fill(R);A.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:I})}}let d=A.attributes,f=Nt.fromVertices(d.position.values,void 0,3);return new se({attributes:d,indices:A.indices,primitiveType:ne.LINES,boundingSphere:f,offsetAttribute:t._offsetAttribute})};qS=CR});var $S={};He($S,{default:()=>ddt});function ldt(t,e){return m(e)&&(t=qS.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),qS.createGeometry(t)}var ddt,tO=S(()=>{h5();mt();Oe();ddt=ldt});var c5,ng,eO=S(()=>{_e();c5={};c5.computePositions=function(t,e,i,n,s){let o=t*.5,r=-o,a=n+n,h=s?2*a:a,A=new Float64Array(h*3),d,f=0,E=0,_=s?a*3:0,R=s?(a+n)*3:n*3;for(d=0;d<n;d++){let I=d/n*L.TWO_PI,C=Math.cos(I),N=Math.sin(I),T=C*i,b=N*i,F=C*e,B=N*e;A[E+_]=T,A[E+_+1]=b,A[E+_+2]=r,A[E+R]=F,A[E+R+1]=B,A[E+R+2]=o,E+=3,s&&(A[f++]=T,A[f++]=b,A[f++]=r,A[f++]=F,A[f++]=B,A[f++]=o)}return A};ng=c5});function Sh(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.length,i=t.topRadius,n=t.bottomRadius,s=Z(t.vertexFormat,St.DEFAULT),o=Z(t.slices,128);if(!m(e))throw new Y("options.length must be defined.");if(!m(i))throw new Y("options.topRadius must be defined.");if(!m(n))throw new Y("options.bottomRadius must be defined.");if(o<3)throw new Y("options.slices must be greater than or equal to 3.");if(m(t.offsetAttribute)&&t.offsetAttribute===Pe.TOP)throw new Y("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");this._length=e,this._topRadius=i,this._bottomRadius=n,this._vertexFormat=St.clone(s),this._slices=o,this._offsetAttribute=t.offsetAttribute,this._workerName="createCylinderGeometry"}var iO,mdt,fdt,Edt,_dt,l5,Wf,nO,gR,sO=S(()=>{_i();Xe();Ht();oi();eO();Ft();mt();Ot();yi();ji();En();go();Di();_e();Xi();Ls();iO=new nt,mdt=new l,fdt=new l,Edt=new l,_dt=new l;Sh.packedLength=St.packedLength+5;Sh.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),St.pack(t._vertexFormat,e,i),i+=St.packedLength,e[i++]=t._length,e[i++]=t._topRadius,e[i++]=t._bottomRadius,e[i++]=t._slices,e[i]=Z(t._offsetAttribute,-1),e};l5=new St,Wf={vertexFormat:l5,length:void 0,topRadius:void 0,bottomRadius:void 0,slices:void 0,offsetAttribute:void 0};Sh.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n=St.unpack(t,e,l5);e+=St.packedLength;let s=t[e++],o=t[e++],r=t[e++],a=t[e++],h=t[e];return m(i)?(i._vertexFormat=St.clone(n,i._vertexFormat),i._length=s,i._topRadius=o,i._bottomRadius=r,i._slices=a,i._offsetAttribute=h===-1?void 0:h,i):(Wf.length=s,Wf.topRadius=o,Wf.bottomRadius=r,Wf.slices=a,Wf.offsetAttribute=h===-1?void 0:h,new Sh(Wf))};Sh.createGeometry=function(t){let e=t._length,i=t._topRadius,n=t._bottomRadius,s=t._vertexFormat,o=t._slices;if(e<=0||i<0||n<0||i===0&&n===0)return;let r=o+o,a=o+r,h=r+r,A=ng.computePositions(e,i,n,o,!0),d=s.st?new Float32Array(h*2):void 0,f=s.normal?new Float32Array(h*3):void 0,E=s.tangent?new Float32Array(h*3):void 0,_=s.bitangent?new Float32Array(h*3):void 0,R,I=s.normal||s.tangent||s.bitangent;if(I){let Q=s.tangent||s.bitangent,M=0,k=0,y=0,c=Math.atan2(n-i,e),g=mdt;g.z=Math.sin(c);let O=Math.cos(c),D=Edt,w=fdt;for(R=0;R<o;R++){let x=R/o*L.TWO_PI,H=O*Math.cos(x),j=O*Math.sin(x);I&&(g.x=H,g.y=j,Q&&(D=l.normalize(l.cross(l.UNIT_Z,g,D),D)),s.normal&&(f[M++]=g.x,f[M++]=g.y,f[M++]=g.z,f[M++]=g.x,f[M++]=g.y,f[M++]=g.z),s.tangent&&(E[k++]=D.x,E[k++]=D.y,E[k++]=D.z,E[k++]=D.x,E[k++]=D.y,E[k++]=D.z),s.bitangent&&(w=l.normalize(l.cross(g,D,w),w),_[y++]=w.x,_[y++]=w.y,_[y++]=w.z,_[y++]=w.x,_[y++]=w.y,_[y++]=w.z))}for(R=0;R<o;R++)s.normal&&(f[M++]=0,f[M++]=0,f[M++]=-1),s.tangent&&(E[k++]=1,E[k++]=0,E[k++]=0),s.bitangent&&(_[y++]=0,_[y++]=-1,_[y++]=0);for(R=0;R<o;R++)s.normal&&(f[M++]=0,f[M++]=0,f[M++]=1),s.tangent&&(E[k++]=1,E[k++]=0,E[k++]=0),s.bitangent&&(_[y++]=0,_[y++]=1,_[y++]=0)}let C=12*o-12,N=te.createTypedArray(h,C),T=0,b=0;for(R=0;R<o-1;R++)N[T++]=b,N[T++]=b+2,N[T++]=b+3,N[T++]=b,N[T++]=b+3,N[T++]=b+1,b+=2;for(N[T++]=r-2,N[T++]=0,N[T++]=1,N[T++]=r-2,N[T++]=1,N[T++]=r-1,R=1;R<o-1;R++)N[T++]=r+R+1,N[T++]=r+R,N[T++]=r;for(R=1;R<o-1;R++)N[T++]=a,N[T++]=a+R,N[T++]=a+R+1;let F=0;if(s.st){let Q=Math.max(i,n);for(R=0;R<h;R++){let M=l.fromArray(A,R*3,_dt);d[F++]=(M.x+Q)/(2*Q),d[F++]=(M.y+Q)/(2*Q)}}let B=new we;s.position&&(B.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:A})),s.normal&&(B.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:f})),s.tangent&&(B.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:E})),s.bitangent&&(B.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_})),s.st&&(B.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:d})),iO.x=e*.5,iO.y=Math.max(n,i);let U=new Nt(l.ZERO,nt.magnitude(iO));if(m(t._offsetAttribute)){e=A.length;let Q=t._offsetAttribute===Pe.NONE?0:1,M=new Uint8Array(e/3).fill(Q);B.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:M})}return new se({attributes:B,indices:N,primitiveType:ne.TRIANGLES,boundingSphere:U,offsetAttribute:t._offsetAttribute})};Sh.getUnitCylinder=function(){return m(nO)||(nO=Sh.createGeometry(new Sh({topRadius:1,bottomRadius:1,length:1,vertexFormat:St.POSITION_ONLY}))),nO};gR=Sh});var oO={};He(oO,{default:()=>Zdt});function Rdt(t,e){return m(e)&&(t=gR.unpack(t,e)),gR.createGeometry(t)}var Zdt,rO=S(()=>{sO();mt();Zdt=Rdt});function Df(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.length,i=t.topRadius,n=t.bottomRadius,s=Z(t.slices,128),o=Math.max(Z(t.numberOfVerticalLines,16),0);if(p.typeOf.number("options.positions",e),p.typeOf.number("options.topRadius",i),p.typeOf.number("options.bottomRadius",n),p.typeOf.number.greaterThanOrEquals("options.slices",s,3),m(t.offsetAttribute)&&t.offsetAttribute===Pe.TOP)throw new Y("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");this._length=e,this._topRadius=i,this._bottomRadius=n,this._slices=s,this._numberOfVerticalLines=o,this._offsetAttribute=t.offsetAttribute,this._workerName="createCylinderOutlineGeometry"}var aO,_d,AO,d5=S(()=>{_i();Xe();Ht();ae();oi();eO();Ft();mt();Ot();yi();ji();En();go();Di();Xi();aO=new nt;Df.packedLength=6;Df.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t._length,e[i++]=t._topRadius,e[i++]=t._bottomRadius,e[i++]=t._slices,e[i++]=t._numberOfVerticalLines,e[i]=Z(t._offsetAttribute,-1),e};_d={length:void 0,topRadius:void 0,bottomRadius:void 0,slices:void 0,numberOfVerticalLines:void 0,offsetAttribute:void 0};Df.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=t[e++],s=t[e++],o=t[e++],r=t[e++],a=t[e++],h=t[e];return m(i)?(i._length=n,i._topRadius=s,i._bottomRadius=o,i._slices=r,i._numberOfVerticalLines=a,i._offsetAttribute=h===-1?void 0:h,i):(_d.length=n,_d.topRadius=s,_d.bottomRadius=o,_d.slices=r,_d.numberOfVerticalLines=a,_d.offsetAttribute=h===-1?void 0:h,new Df(_d))};Df.createGeometry=function(t){let e=t._length,i=t._topRadius,n=t._bottomRadius,s=t._slices,o=t._numberOfVerticalLines;if(e<=0||i<0||n<0||i===0&&n===0)return;let r=s*2,a=ng.computePositions(e,i,n,s,!1),h=s*2,A;if(o>0){let I=Math.min(o,s);A=Math.round(s/I),h+=I}let d=te.createTypedArray(r,h*2),f=0,E;for(E=0;E<s-1;E++)d[f++]=E,d[f++]=E+1,d[f++]=E+s,d[f++]=E+1+s;if(d[f++]=s-1,d[f++]=0,d[f++]=s+s-1,d[f++]=s,o>0)for(E=0;E<s;E+=A)d[f++]=E,d[f++]=E+s;let _=new we;_.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:a}),aO.x=e*.5,aO.y=Math.max(n,i);let R=new Nt(l.ZERO,nt.magnitude(aO));if(m(t._offsetAttribute)){e=a.length;let I=t._offsetAttribute===Pe.NONE?0:1,C=new Uint8Array(e/3).fill(I);_.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:C})}return new se({attributes:_,indices:d,primitiveType:ne.LINES,boundingSphere:R,offsetAttribute:t._offsetAttribute})};AO=Df});var hO={};He(hO,{default:()=>pdt});function Idt(t,e){return m(e)&&(t=AO.unpack(t,e)),AO.createGeometry(t)}var pdt,cO=S(()=>{d5();mt();pdt=Idt});var lO={};He(lO,{default:()=>Cdt});function udt(t,e){return m(e)&&(t=wa.unpack(t,e)),t._center=l.clone(t._center),t._ellipsoid=ot.clone(t._ellipsoid),wa.createGeometry(t)}var Cdt,dO=S(()=>{Ht();mt();_S();Oe();Cdt=udt});var mO={};He(mO,{default:()=>Tdt});function gdt(t,e){return m(e)&&(t=xa.unpack(t,e)),t._center=l.clone(t._center),t._ellipsoid=ot.clone(t._ellipsoid),xa.createGeometry(t)}var Tdt,fO=S(()=>{Ht();mt();pS();Oe();Tdt=gdt});function Oh(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.radii,Sdt),i=Z(t.innerRadii,e),n=Z(t.minimumClock,0),s=Z(t.maximumClock,L.TWO_PI),o=Z(t.minimumCone,0),r=Z(t.maximumCone,L.PI),a=Math.round(Z(t.stackPartitions,64)),h=Math.round(Z(t.slicePartitions,64)),A=Z(t.vertexFormat,St.DEFAULT);if(h<3)throw new Y("options.slicePartitions cannot be less than three.");if(a<3)throw new Y("options.stackPartitions cannot be less than three.");this._radii=l.clone(e),this._innerRadii=l.clone(i),this._minimumClock=n,this._maximumClock=s,this._minimumCone=o,this._maximumCone=r,this._stackPartitions=a,this._slicePartitions=h,this._vertexFormat=St.clone(A),this._offsetAttribute=t.offsetAttribute,this._workerName="createEllipsoidGeometry"}var Ndt,Fdt,bdt,Ydt,Vdt,Sdt,m5,f5,E5,_5,R5,xc,EO,Nr,sg=S(()=>{_i();Xe();Ht();oi();Ft();mt();Ot();Oe();yi();ji();En();go();Di();_e();Xi();Ls();Ndt=new l,Fdt=new l,bdt=new l,Ydt=new l,Vdt=new l,Sdt=new l(1,1,1),m5=Math.cos,f5=Math.sin;Oh.packedLength=2*l.packedLength+St.packedLength+7;Oh.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),l.pack(t._radii,e,i),i+=l.packedLength,l.pack(t._innerRadii,e,i),i+=l.packedLength,St.pack(t._vertexFormat,e,i),i+=St.packedLength,e[i++]=t._minimumClock,e[i++]=t._maximumClock,e[i++]=t._minimumCone,e[i++]=t._maximumCone,e[i++]=t._stackPartitions,e[i++]=t._slicePartitions,e[i]=Z(t._offsetAttribute,-1),e};E5=new l,_5=new l,R5=new St,xc={radii:E5,innerRadii:_5,vertexFormat:R5,minimumClock:void 0,maximumClock:void 0,minimumCone:void 0,maximumCone:void 0,stackPartitions:void 0,slicePartitions:void 0,offsetAttribute:void 0};Oh.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n=l.unpack(t,e,E5);e+=l.packedLength;let s=l.unpack(t,e,_5);e+=l.packedLength;let o=St.unpack(t,e,R5);e+=St.packedLength;let r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++],E=t[e];return m(i)?(i._radii=l.clone(n,i._radii),i._innerRadii=l.clone(s,i._innerRadii),i._vertexFormat=St.clone(o,i._vertexFormat),i._minimumClock=r,i._maximumClock=a,i._minimumCone=h,i._maximumCone=A,i._stackPartitions=d,i._slicePartitions=f,i._offsetAttribute=E===-1?void 0:E,i):(xc.minimumClock=r,xc.maximumClock=a,xc.minimumCone=h,xc.maximumCone=A,xc.stackPartitions=d,xc.slicePartitions=f,xc.offsetAttribute=E===-1?void 0:E,new Oh(xc))};Oh.createGeometry=function(t){let e=t._radii;if(e.x<=0||e.y<=0||e.z<=0)return;let i=t._innerRadii;if(i.x<=0||i.y<=0||i.z<=0)return;let n=t._minimumClock,s=t._maximumClock,o=t._minimumCone,r=t._maximumCone,a=t._vertexFormat,h=t._slicePartitions+1,A=t._stackPartitions+1;h=Math.round(h*Math.abs(s-n)/L.TWO_PI),A=Math.round(A*Math.abs(r-o)/L.PI),h<2&&(h=2),A<2&&(A=2);let d,f,E=0,_=[o],R=[n];for(d=0;d<A;d++)_.push(o+d*(r-o)/(A-1));for(_.push(r),f=0;f<h;f++)R.push(n+f*(s-n)/(h-1));R.push(s);let I=_.length,C=R.length,N=0,T=1,b=i.x!==e.x||i.y!==e.y||i.z!==e.z,F=!1,B=!1,U=!1;b&&(T=2,o>0&&(F=!0,N+=h-1),r<Math.PI&&(B=!0,N+=h-1),(s-n)%L.TWO_PI?(U=!0,N+=(A-1)*2+1):N+=1);let Q=C*I*T,M=new Float64Array(Q*3),k=new Array(Q).fill(!1),y=new Array(Q).fill(!1),c=h*A*T,g=6*(c+N+1-(h+A)*T),O=te.createTypedArray(c,g),D=a.normal?new Float32Array(Q*3):void 0,w=a.tangent?new Float32Array(Q*3):void 0,x=a.bitangent?new Float32Array(Q*3):void 0,H=a.st?new Float32Array(Q*2):void 0,j=new Array(I),X=new Array(I);for(d=0;d<I;d++)j[d]=f5(_[d]),X[d]=m5(_[d]);let tt=new Array(C),G=new Array(C);for(f=0;f<C;f++)G[f]=m5(R[f]),tt[f]=f5(R[f]);for(d=0;d<I;d++)for(f=0;f<C;f++)M[E++]=e.x*j[d]*G[f],M[E++]=e.y*j[d]*tt[f],M[E++]=e.z*X[d];let It=Q/2;if(b)for(d=0;d<I;d++)for(f=0;f<C;f++)M[E++]=i.x*j[d]*G[f],M[E++]=i.y*j[d]*tt[f],M[E++]=i.z*X[d],k[It]=!0,d>0&&d!==I-1&&f!==0&&f!==C-1&&(y[It]=!0),It++;E=0;let gt,Yt;for(d=1;d<I-2;d++)for(gt=d*C,Yt=(d+1)*C,f=1;f<C-2;f++)O[E++]=Yt+f,O[E++]=Yt+f+1,O[E++]=gt+f+1,O[E++]=Yt+f,O[E++]=gt+f+1,O[E++]=gt+f;if(b){let Ue=I*C;for(d=1;d<I-2;d++)for(gt=Ue+d*C,Yt=Ue+(d+1)*C,f=1;f<C-2;f++)O[E++]=Yt+f,O[E++]=gt+f,O[E++]=gt+f+1,O[E++]=Yt+f,O[E++]=gt+f+1,O[E++]=Yt+f+1}let Ut,Ct;if(b){if(F)for(Ct=I*C,d=1;d<C-2;d++)O[E++]=d,O[E++]=d+1,O[E++]=Ct+d+1,O[E++]=d,O[E++]=Ct+d+1,O[E++]=Ct+d;if(B)for(Ut=I*C-C,Ct=I*C*T-C,d=1;d<C-2;d++)O[E++]=Ut+d+1,O[E++]=Ut+d,O[E++]=Ct+d,O[E++]=Ut+d+1,O[E++]=Ct+d,O[E++]=Ct+d+1}if(U){for(d=1;d<I-2;d++)Ct=C*I+C*d,Ut=C*d,O[E++]=Ct,O[E++]=Ut+C,O[E++]=Ut,O[E++]=Ct,O[E++]=Ct+C,O[E++]=Ut+C;for(d=1;d<I-2;d++)Ct=C*I+C*(d+1)-1,Ut=C*(d+1)-1,O[E++]=Ut+C,O[E++]=Ct,O[E++]=Ut,O[E++]=Ut+C,O[E++]=Ct+C,O[E++]=Ct}let zt=new we;a.position&&(zt.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:M}));let kt=0,Jt=0,Wt=0,bt=0,ee=Q/2,ce,je=ot.fromCartesian3(e),Se=ot.fromCartesian3(i);if(a.st||a.normal||a.tangent||a.bitangent){for(d=0;d<Q;d++){ce=k[d]?Se:je;let Ue=l.fromArray(M,d*3,Ndt),Me=ce.geodeticSurfaceNormal(Ue,Fdt);if(y[d]&&l.negate(Me,Me),a.st){let Ce=nt.negate(Me,Vdt);H[kt++]=Math.atan2(Ce.y,Ce.x)/L.TWO_PI+.5,H[kt++]=Math.asin(Me.z)/Math.PI+.5}if(a.normal&&(D[Jt++]=Me.x,D[Jt++]=Me.y,D[Jt++]=Me.z),a.tangent||a.bitangent){let Ce=bdt,Fe=0,ni;if(k[d]&&(Fe=ee),!F&&d>=Fe&&d<Fe+C*2?ni=l.UNIT_X:ni=l.UNIT_Z,l.cross(ni,Me,Ce),l.normalize(Ce,Ce),a.tangent&&(w[Wt++]=Ce.x,w[Wt++]=Ce.y,w[Wt++]=Ce.z),a.bitangent){let ze=l.cross(Me,Ce,Ydt);l.normalize(ze,ze),x[bt++]=ze.x,x[bt++]=ze.y,x[bt++]=ze.z}}}a.st&&(zt.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:H})),a.normal&&(zt.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:D})),a.tangent&&(zt.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:w})),a.bitangent&&(zt.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:x}))}if(m(t._offsetAttribute)){let Ue=M.length,Me=t._offsetAttribute===Pe.NONE?0:1,Ce=new Uint8Array(Ue/3).fill(Me);zt.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:Ce})}return new se({attributes:zt,indices:O,primitiveType:ne.TRIANGLES,boundingSphere:Nt.fromEllipsoid(je),offsetAttribute:t._offsetAttribute})};Oh.getUnitEllipsoid=function(){return m(EO)||(EO=Oh.createGeometry(new Oh({radii:new l(1,1,1),vertexFormat:St.POSITION_ONLY}))),EO};Nr=Oh});var _O={};He(_O,{default:()=>Bdt});function Odt(t,e){return m(e)&&(t=Nr.unpack(t,e)),Nr.createGeometry(t)}var Bdt,RO=S(()=>{mt();sg();Bdt=Odt});function Uf(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.radii,Gdt),i=Z(t.innerRadii,e),n=Z(t.minimumClock,0),s=Z(t.maximumClock,L.TWO_PI),o=Z(t.minimumCone,0),r=Z(t.maximumCone,L.PI),a=Math.round(Z(t.stackPartitions,10)),h=Math.round(Z(t.slicePartitions,8)),A=Math.round(Z(t.subdivisions,128));if(a<1)throw new Y("options.stackPartitions cannot be less than 1");if(h<0)throw new Y("options.slicePartitions cannot be less than 0");if(A<0)throw new Y("options.subdivisions must be greater than or equal to zero.");if(m(t.offsetAttribute)&&t.offsetAttribute===Pe.TOP)throw new Y("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");this._radii=l.clone(e),this._innerRadii=l.clone(i),this._minimumClock=n,this._maximumClock=s,this._minimumCone=o,this._maximumCone=r,this._stackPartitions=a,this._slicePartitions=h,this._subdivisions=A,this._offsetAttribute=t.offsetAttribute,this._workerName="createEllipsoidOutlineGeometry"}var Gdt,og,rg,Z5,I5,Bh,ja,ZO=S(()=>{_i();Ht();oi();Ft();mt();Ot();Oe();yi();ji();En();go();Di();_e();Xi();Gdt=new l(1,1,1),og=Math.cos,rg=Math.sin;Uf.packedLength=2*l.packedLength+8;Uf.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),l.pack(t._radii,e,i),i+=l.packedLength,l.pack(t._innerRadii,e,i),i+=l.packedLength,e[i++]=t._minimumClock,e[i++]=t._maximumClock,e[i++]=t._minimumCone,e[i++]=t._maximumCone,e[i++]=t._stackPartitions,e[i++]=t._slicePartitions,e[i++]=t._subdivisions,e[i]=Z(t._offsetAttribute,-1),e};Z5=new l,I5=new l,Bh={radii:Z5,innerRadii:I5,minimumClock:void 0,maximumClock:void 0,minimumCone:void 0,maximumCone:void 0,stackPartitions:void 0,slicePartitions:void 0,subdivisions:void 0,offsetAttribute:void 0};Uf.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n=l.unpack(t,e,Z5);e+=l.packedLength;let s=l.unpack(t,e,I5);e+=l.packedLength;let o=t[e++],r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++],E=t[e];return m(i)?(i._radii=l.clone(n,i._radii),i._innerRadii=l.clone(s,i._innerRadii),i._minimumClock=o,i._maximumClock=r,i._minimumCone=a,i._maximumCone=h,i._stackPartitions=A,i._slicePartitions=d,i._subdivisions=f,i._offsetAttribute=E===-1?void 0:E,i):(Bh.minimumClock=o,Bh.maximumClock=r,Bh.minimumCone=a,Bh.maximumCone=h,Bh.stackPartitions=A,Bh.slicePartitions=d,Bh.subdivisions=f,Bh.offsetAttribute=E===-1?void 0:E,new Uf(Bh))};Uf.createGeometry=function(t){let e=t._radii;if(e.x<=0||e.y<=0||e.z<=0)return;let i=t._innerRadii;if(i.x<=0||i.y<=0||i.z<=0)return;let n=t._minimumClock,s=t._maximumClock,o=t._minimumCone,r=t._maximumCone,a=t._subdivisions,h=ot.fromCartesian3(e),A=t._slicePartitions+1,d=t._stackPartitions+1;A=Math.round(A*Math.abs(s-n)/L.TWO_PI),d=Math.round(d*Math.abs(r-o)/L.PI),A<2&&(A=2),d<2&&(d=2);let f=0,E=1,_=i.x!==e.x||i.y!==e.y||i.z!==e.z,R=!1,I=!1;_&&(E=2,o>0&&(R=!0,f+=A),r<Math.PI&&(I=!0,f+=A));let C=a*E*(d+A),N=new Float64Array(C*3),T=2*(C+f-(A+d)*E),b=te.createTypedArray(C,T),F,B,U,Q,M=0,k=new Array(d),y=new Array(d);for(F=0;F<d;F++)Q=o+F*(r-o)/(d-1),k[F]=rg(Q),y[F]=og(Q);let c=new Array(a),g=new Array(a);for(F=0;F<a;F++)U=n+F*(s-n)/(a-1),c[F]=rg(U),g[F]=og(U);for(F=0;F<d;F++)for(B=0;B<a;B++)N[M++]=e.x*k[F]*g[B],N[M++]=e.y*k[F]*c[B],N[M++]=e.z*y[F];if(_)for(F=0;F<d;F++)for(B=0;B<a;B++)N[M++]=i.x*k[F]*g[B],N[M++]=i.y*k[F]*c[B],N[M++]=i.z*y[F];for(k.length=a,y.length=a,F=0;F<a;F++)Q=o+F*(r-o)/(a-1),k[F]=rg(Q),y[F]=og(Q);for(c.length=A,g.length=A,F=0;F<A;F++)U=n+F*(s-n)/(A-1),c[F]=rg(U),g[F]=og(U);for(F=0;F<a;F++)for(B=0;B<A;B++)N[M++]=e.x*k[F]*g[B],N[M++]=e.y*k[F]*c[B],N[M++]=e.z*y[F];if(_)for(F=0;F<a;F++)for(B=0;B<A;B++)N[M++]=i.x*k[F]*g[B],N[M++]=i.y*k[F]*c[B],N[M++]=i.z*y[F];for(M=0,F=0;F<d*E;F++){let w=F*a;for(B=0;B<a-1;B++)b[M++]=w+B,b[M++]=w+B+1}let O=d*a*E;for(F=0;F<A;F++)for(B=0;B<a-1;B++)b[M++]=O+F+B*A,b[M++]=O+F+(B+1)*A;if(_)for(O=d*a*E+A*a,F=0;F<A;F++)for(B=0;B<a-1;B++)b[M++]=O+F+B*A,b[M++]=O+F+(B+1)*A;if(_){let w=d*a*E,x=w+a*A;if(R)for(F=0;F<A;F++)b[M++]=w+F,b[M++]=x+F;if(I)for(w+=a*A-A,x+=a*A-A,F=0;F<A;F++)b[M++]=w+F,b[M++]=x+F}let D=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:N})});if(m(t._offsetAttribute)){let w=N.length,x=t._offsetAttribute===Pe.NONE?0:1,H=new Uint8Array(w/3).fill(x);D.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:H})}return new se({attributes:D,indices:b,primitiveType:ne.LINES,boundingSphere:Nt.fromEllipsoid(h),offsetAttribute:t._offsetAttribute})};ja=Uf});var IO={};He(IO,{default:()=>Ddt});function Wdt(t,e){return m(t.buffer,e)&&(t=ja.unpack(t,e)),ja.createGeometry(t)}var Ddt,pO=S(()=>{mt();ZO();Ddt=Wdt});function BA(t){t=Z(t,Z.EMPTY_OBJECT),this.left=t.left,this._left=void 0,this.right=t.right,this._right=void 0,this.top=t.top,this._top=void 0,this.bottom=t.bottom,this._bottom=void 0,this.near=Z(t.near,1),this._near=this.near,this.far=Z(t.far,5e8),this._far=this.far,this._cullingVolume=new XZ,this._perspectiveMatrix=new at,this._infinitePerspective=new at}function uO(t){if(!m(t.right)||!m(t.left)||!m(t.top)||!m(t.bottom)||!m(t.near)||!m(t.far))throw new Y("right, left, top, bottom, near, or far parameters are not set.");let e=t.top,i=t.bottom,n=t.right,s=t.left,o=t.near,r=t.far;if(e!==t._top||i!==t._bottom||s!==t._left||n!==t._right||o!==t._near||r!==t._far){if(t.near<=0||t.near>t.far)throw new Y("near must be greater than zero and less than far.");t._left=s,t._right=n,t._top=e,t._bottom=i,t._near=o,t._far=r,t._perspectiveMatrix=at.computePerspectiveOffCenter(s,n,i,e,o,r,t._perspectiveMatrix),t._infinitePerspective=at.computeInfinitePerspectiveOffCenter(s,n,i,e,o,t._infinitePerspective)}}var Udt,Mdt,Qdt,kdt,p5,u5=S(()=>{Ht();Os();ZT();Ft();mt();Ot();_e();bi();Object.defineProperties(BA.prototype,{projectionMatrix:{get:function(){return uO(this),this._perspectiveMatrix}},infiniteProjectionMatrix:{get:function(){return uO(this),this._infinitePerspective}}});Udt=new l,Mdt=new l,Qdt=new l,kdt=new l;BA.prototype.computeCullingVolume=function(t,e,i){if(!m(t))throw new Y("position is required.");if(!m(e))throw new Y("direction is required.");if(!m(i))throw new Y("up is required.");let n=this._cullingVolume.planes,s=this.top,o=this.bottom,r=this.right,a=this.left,h=this.near,A=this.far,d=l.cross(e,i,Udt),f=Mdt;l.multiplyByScalar(e,h,f),l.add(t,f,f);let E=Qdt;l.multiplyByScalar(e,A,E),l.add(t,E,E);let _=kdt;l.multiplyByScalar(d,a,_),l.add(f,_,_),l.subtract(_,t,_),l.normalize(_,_),l.cross(_,i,_),l.normalize(_,_);let R=n[0];return m(R)||(R=n[0]=new ie),R.x=_.x,R.y=_.y,R.z=_.z,R.w=-l.dot(_,t),l.multiplyByScalar(d,r,_),l.add(f,_,_),l.subtract(_,t,_),l.cross(i,_,_),l.normalize(_,_),R=n[1],m(R)||(R=n[1]=new ie),R.x=_.x,R.y=_.y,R.z=_.z,R.w=-l.dot(_,t),l.multiplyByScalar(i,o,_),l.add(f,_,_),l.subtract(_,t,_),l.cross(d,_,_),l.normalize(_,_),R=n[2],m(R)||(R=n[2]=new ie),R.x=_.x,R.y=_.y,R.z=_.z,R.w=-l.dot(_,t),l.multiplyByScalar(i,s,_),l.add(f,_,_),l.subtract(_,t,_),l.cross(_,d,_),l.normalize(_,_),R=n[3],m(R)||(R=n[3]=new ie),R.x=_.x,R.y=_.y,R.z=_.z,R.w=-l.dot(_,t),R=n[4],m(R)||(R=n[4]=new ie),R.x=e.x,R.y=e.y,R.z=e.z,R.w=-l.dot(e,f),l.negate(e,_),R=n[5],m(R)||(R=n[5]=new ie),R.x=_.x,R.y=_.y,R.z=_.z,R.w=-l.dot(_,E),this._cullingVolume};BA.prototype.getPixelDimensions=function(t,e,i,n,s){if(uO(this),!m(t)||!m(e))throw new Y("Both drawingBufferWidth and drawingBufferHeight are required.");if(t<=0)throw new Y("drawingBufferWidth must be greater than zero.");if(e<=0)throw new Y("drawingBufferHeight must be greater than zero.");if(!m(i))throw new Y("distance is required.");if(!m(n))throw new Y("pixelRatio is required");if(n<=0)throw new Y("pixelRatio must be greater than zero.");if(!m(s))throw new Y("A result object is required.");let o=1/this.near,r=this.top*o,a=2*n*i*r/e;r=this.right*o;let h=2*n*i*r/t;return s.x=h,s.y=a,s};BA.prototype.clone=function(t){return m(t)||(t=new BA),t.right=this.right,t.left=this.left,t.top=this.top,t.bottom=this.bottom,t.near=this.near,t.far=this.far,t._left=void 0,t._right=void 0,t._top=void 0,t._bottom=void 0,t._near=void 0,t._far=void 0,t};BA.prototype.equals=function(t){return m(t)&&t instanceof BA&&this.right===t.right&&this.left===t.left&&this.top===t.top&&this.bottom===t.bottom&&this.near===t.near&&this.far===t.far};BA.prototype.equalsEpsilon=function(t,e,i){return t===this||m(t)&&t instanceof BA&&L.equalsEpsilon(this.right,t.right,e,i)&&L.equalsEpsilon(this.left,t.left,e,i)&&L.equalsEpsilon(this.top,t.top,e,i)&&L.equalsEpsilon(this.bottom,t.bottom,e,i)&&L.equalsEpsilon(this.near,t.near,e,i)&&L.equalsEpsilon(this.far,t.far,e,i)};p5=BA});function Ar(t){t=Z(t,Z.EMPTY_OBJECT),this._offCenterFrustum=new p5,this.fov=t.fov,this._fov=void 0,this._fovy=void 0,this._sseDenominator=void 0,this.aspectRatio=t.aspectRatio,this._aspectRatio=void 0,this.near=Z(t.near,1),this._near=this.near,this.far=Z(t.far,5e8),this._far=this.far,this.xOffset=Z(t.xOffset,0),this._xOffset=this.xOffset,this.yOffset=Z(t.yOffset,0),this._yOffset=this.yOffset}function Ha(t){if(!m(t.fov)||!m(t.aspectRatio)||!m(t.near)||!m(t.far))throw new Y("fov, aspectRatio, near, or far parameters are not set.");let e=t._offCenterFrustum;if(t.fov!==t._fov||t.aspectRatio!==t._aspectRatio||t.near!==t._near||t.far!==t._far||t.xOffset!==t._xOffset||t.yOffset!==t._yOffset){if(t.fov<0||t.fov>=Math.PI)throw new Y("fov must be in the range [0, PI).");if(t.aspectRatio<0)throw new Y("aspectRatio must be positive.");if(t.near<0||t.near>t.far)throw new Y("near must be greater than zero and less than far.");t._aspectRatio=t.aspectRatio,t._fov=t.fov,t._fovy=t.aspectRatio<=1?t.fov:Math.atan(Math.tan(t.fov*.5)/t.aspectRatio)*2,t._near=t.near,t._far=t.far,t._sseDenominator=2*Math.tan(.5*t._fovy),t._xOffset=t.xOffset,t._yOffset=t.yOffset,e.top=t.near*Math.tan(.5*t._fovy),e.bottom=-e.top,e.right=t.aspectRatio*e.top,e.left=-e.right,e.near=t.near,e.far=t.far,e.right+=t.xOffset,e.left+=t.xOffset,e.top+=t.yOffset,e.bottom+=t.yOffset}}var Fo,CO=S(()=>{ae();Ft();mt();Ot();_e();u5();Ar.packedLength=6;Ar.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),e[i++]=t.fov,e[i++]=t.aspectRatio,e[i++]=t.near,e[i++]=t.far,e[i++]=t.xOffset,e[i]=t.yOffset,e};Ar.unpack=function(t,e,i){return p.defined("array",t),e=Z(e,0),m(i)||(i=new Ar),i.fov=t[e++],i.aspectRatio=t[e++],i.near=t[e++],i.far=t[e++],i.xOffset=t[e++],i.yOffset=t[e],i};Object.defineProperties(Ar.prototype,{projectionMatrix:{get:function(){return Ha(this),this._offCenterFrustum.projectionMatrix}},infiniteProjectionMatrix:{get:function(){return Ha(this),this._offCenterFrustum.infiniteProjectionMatrix}},fovy:{get:function(){return Ha(this),this._fovy}},sseDenominator:{get:function(){return Ha(this),this._sseDenominator}},offCenterFrustum:{get:function(){return Ha(this),this._offCenterFrustum}}});Ar.prototype.computeCullingVolume=function(t,e,i){return Ha(this),this._offCenterFrustum.computeCullingVolume(t,e,i)};Ar.prototype.getPixelDimensions=function(t,e,i,n,s){return Ha(this),this._offCenterFrustum.getPixelDimensions(t,e,i,n,s)};Ar.prototype.clone=function(t){return m(t)||(t=new Ar),t.aspectRatio=this.aspectRatio,t.fov=this.fov,t.near=this.near,t.far=this.far,t._aspectRatio=void 0,t._fov=void 0,t._near=void 0,t._far=void 0,this._offCenterFrustum.clone(t._offCenterFrustum),t};Ar.prototype.equals=function(t){return!m(t)||!(t instanceof Ar)?!1:(Ha(this),Ha(t),this.fov===t.fov&&this.aspectRatio===t.aspectRatio&&this._offCenterFrustum.equals(t._offCenterFrustum))};Ar.prototype.equalsEpsilon=function(t,e,i){return!m(t)||!(t instanceof Ar)?!1:(Ha(this),Ha(t),L.equalsEpsilon(this.fov,t.fov,e,i)&&L.equalsEpsilon(this.aspectRatio,t.aspectRatio,e,i)&&this._offCenterFrustum.equalsEpsilon(t._offCenterFrustum,e,i))};Fo=Ar});function Rd(t){p.typeOf.object("options",t),p.typeOf.object("options.frustum",t.frustum),p.typeOf.object("options.origin",t.origin),p.typeOf.object("options.orientation",t.orientation);let e=t.frustum,i=t.orientation,n=t.origin,s=Z(t.vertexFormat,St.DEFAULT),o=Z(t._drawNearPlane,!0),r,a;e instanceof Fo?(r=ag,a=Fo.packedLength):e instanceof js&&(r=Ldt,a=js.packedLength),this._frustumType=r,this._frustum=e.clone(),this._origin=l.clone(n),this._orientation=Ae.clone(i),this._drawNearPlane=o,this._vertexFormat=s,this._workerName="createFrustumGeometry",this.packedLength=2+a+l.packedLength+Ae.packedLength+St.packedLength}function Mf(t,e,i,n,s,o,r,a){let h=t/3*2;for(let A=0;A<4;++A)m(e)&&(e[t]=o.x,e[t+1]=o.y,e[t+2]=o.z),m(i)&&(i[t]=r.x,i[t+1]=r.y,i[t+2]=r.z),m(n)&&(n[t]=a.x,n[t+1]=a.y,n[t+2]=a.z),t+=3;s[h]=0,s[h+1]=0,s[h+2]=1,s[h+3]=0,s[h+4]=1,s[h+5]=1,s[h+6]=0,s[h+7]=1}var ag,Ldt,ydt,wdt,xdt,Pdt,Jdt,jdt,Hdt,gO,C5,g5,T5,vdt,zdt,Kdt,Pc,TR,N5,NR,TO=S(()=>{_i();Ht();Os();ae();oi();Ft();mt();yi();ji();En();dn();bi();$Z();CO();Xi();$s();Ls();ag=0,Ldt=1;Rd.pack=function(t,e,i){p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0);let n=t._frustumType,s=t._frustum;return e[i++]=n,n===ag?(Fo.pack(s,e,i),i+=Fo.packedLength):(js.pack(s,e,i),i+=js.packedLength),l.pack(t._origin,e,i),i+=l.packedLength,Ae.pack(t._orientation,e,i),i+=Ae.packedLength,St.pack(t._vertexFormat,e,i),i+=St.packedLength,e[i]=t._drawNearPlane?1:0,e};ydt=new Fo,wdt=new js,xdt=new Ae,Pdt=new l,Jdt=new St;Rd.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=t[e++],s;n===ag?(s=Fo.unpack(t,e,ydt),e+=Fo.packedLength):(s=js.unpack(t,e,wdt),e+=js.packedLength);let o=l.unpack(t,e,Pdt);e+=l.packedLength;let r=Ae.unpack(t,e,xdt);e+=Ae.packedLength;let a=St.unpack(t,e,Jdt);e+=St.packedLength;let h=t[e]===1;if(!m(i))return new Rd({frustum:s,origin:o,orientation:r,vertexFormat:a,_drawNearPlane:h});let A=n===i._frustumType?i._frustum:void 0;return i._frustum=s.clone(A),i._frustumType=n,i._origin=l.clone(o,i._origin),i._orientation=Ae.clone(r,i._orientation),i._vertexFormat=St.clone(a,i._vertexFormat),i._drawNearPlane=h,i};jdt=new lt,Hdt=new at,gO=new at,C5=new l,g5=new l,T5=new l,vdt=new l,zdt=new l,Kdt=new l,Pc=new Array(3),TR=new Array(4);TR[0]=new ie(-1,-1,1,1);TR[1]=new ie(1,-1,1,1);TR[2]=new ie(1,1,1,1);TR[3]=new ie(-1,1,1,1);N5=new Array(4);for(let t=0;t<4;++t)N5[t]=new ie;Rd._computeNearFarPlanes=function(t,e,i,n,s,o,r,a){let h=lt.fromQuaternion(e,jdt),A=Z(o,C5),d=Z(r,g5),f=Z(a,T5);A=lt.getColumn(h,0,A),d=lt.getColumn(h,1,d),f=lt.getColumn(h,2,f),l.normalize(A,A),l.normalize(d,d),l.normalize(f,f),l.negate(A,A);let E=at.computeView(t,f,d,A,Hdt),_,R,I=n.projectionMatrix;if(i===ag){let C=at.multiply(I,E,gO);R=at.inverse(C,gO)}else _=at.inverseTransformation(E,gO);m(R)?(Pc[0]=n.near,Pc[1]=n.far):(Pc[0]=0,Pc[1]=n.near,Pc[2]=n.far);for(let C=0;C<2;++C)for(let N=0;N<4;++N){let T=ie.clone(TR[N],N5[N]);if(m(R)){T=at.multiplyByVector(R,T,T);let b=1/T.w;l.multiplyByScalar(T,b,T),l.subtract(T,t,T),l.normalize(T,T);let F=l.dot(f,T);l.multiplyByScalar(T,Pc[C]/F,T),l.add(T,t,T)}else{let b=n.offCenterFrustum;m(b)&&(n=b);let F=Pc[C],B=Pc[C+1];T.x=(T.x*(n.right-n.left)+n.left+n.right)*.5,T.y=(T.y*(n.top-n.bottom)+n.bottom+n.top)*.5,T.z=(T.z*(F-B)-F-B)*.5,T.w=1,at.multiplyByVector(_,T,T)}s[12*C+N*3]=T.x,s[12*C+N*3+1]=T.y,s[12*C+N*3+2]=T.z}};Rd.createGeometry=function(t){let e=t._frustumType,i=t._frustum,n=t._origin,s=t._orientation,o=t._drawNearPlane,r=t._vertexFormat,a=o?6:5,h=new Float64Array(3*4*6);Rd._computeNearFarPlanes(n,s,e,i,h);let A=3*4*2;h[A]=h[3*4],h[A+1]=h[3*4+1],h[A+2]=h[3*4+2],h[A+3]=h[0],h[A+4]=h[1],h[A+5]=h[2],h[A+6]=h[3*3],h[A+7]=h[3*3+1],h[A+8]=h[3*3+2],h[A+9]=h[3*7],h[A+10]=h[3*7+1],h[A+11]=h[3*7+2],A+=3*4,h[A]=h[3*5],h[A+1]=h[3*5+1],h[A+2]=h[3*5+2],h[A+3]=h[3],h[A+4]=h[4],h[A+5]=h[5],h[A+6]=h[0],h[A+7]=h[1],h[A+8]=h[2],h[A+9]=h[3*4],h[A+10]=h[3*4+1],h[A+11]=h[3*4+2],A+=3*4,h[A]=h[3],h[A+1]=h[4],h[A+2]=h[5],h[A+3]=h[3*5],h[A+4]=h[3*5+1],h[A+5]=h[3*5+2],h[A+6]=h[3*6],h[A+7]=h[3*6+1],h[A+8]=h[3*6+2],h[A+9]=h[3*2],h[A+10]=h[3*2+1],h[A+11]=h[3*2+2],A+=3*4,h[A]=h[3*2],h[A+1]=h[3*2+1],h[A+2]=h[3*2+2],h[A+3]=h[3*6],h[A+4]=h[3*6+1],h[A+5]=h[3*6+2],h[A+6]=h[3*7],h[A+7]=h[3*7+1],h[A+8]=h[3*7+2],h[A+9]=h[3*3],h[A+10]=h[3*3+1],h[A+11]=h[3*3+2],o||(h=h.subarray(3*4));let d=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:h})});if(m(r.normal)||m(r.tangent)||m(r.bitangent)||m(r.st)){let E=m(r.normal)?new Float32Array(12*a):void 0,_=m(r.tangent)?new Float32Array(3*4*a):void 0,R=m(r.bitangent)?new Float32Array(3*4*a):void 0,I=m(r.st)?new Float32Array(2*4*a):void 0,C=C5,N=g5,T=T5,b=l.negate(C,vdt),F=l.negate(N,zdt),B=l.negate(T,Kdt);A=0,o&&(Mf(A,E,_,R,I,B,C,N),A+=3*4),Mf(A,E,_,R,I,T,b,N),A+=3*4,Mf(A,E,_,R,I,b,B,N),A+=3*4,Mf(A,E,_,R,I,F,B,b),A+=3*4,Mf(A,E,_,R,I,C,T,N),A+=3*4,Mf(A,E,_,R,I,N,T,b),m(E)&&(d.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:E})),m(_)&&(d.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:_})),m(R)&&(d.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:R})),m(I)&&(d.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:I}))}let f=new Uint16Array(6*a);for(let E=0;E<a;++E){let _=E*6,R=E*4;f[_]=R,f[_+1]=R+1,f[_+2]=R+2,f[_+3]=R,f[_+4]=R+2,f[_+5]=R+3}return new se({attributes:d,indices:f,primitiveType:ne.TRIANGLES,boundingSphere:Nt.fromVertices(h)})};NR=Rd});var NO={};He(NO,{default:()=>qdt});function Xdt(t,e){return m(e)&&(t=NR.unpack(t,e)),NR.createGeometry(t)}var qdt,FO=S(()=>{mt();TO();qdt=Xdt});function FR(t){p.typeOf.object("options",t),p.typeOf.object("options.frustum",t.frustum),p.typeOf.object("options.origin",t.origin),p.typeOf.object("options.orientation",t.orientation);let e=t.frustum,i=t.orientation,n=t.origin,s=Z(t._drawNearPlane,!0),o,r;e instanceof Fo?(o=bO,r=Fo.packedLength):e instanceof js&&(o=$dt,r=js.packedLength),this._frustumType=o,this._frustum=e.clone(),this._origin=l.clone(n),this._orientation=Ae.clone(i),this._drawNearPlane=s,this._workerName="createFrustumOutlineGeometry",this.packedLength=2+r+l.packedLength+Ae.packedLength}var bO,$dt,tmt,emt,imt,nmt,YO,F5=S(()=>{_i();Ht();ae();oi();Ft();mt();TO();yi();ji();En();$Z();CO();Xi();$s();bO=0,$dt=1;FR.pack=function(t,e,i){p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0);let n=t._frustumType,s=t._frustum;return e[i++]=n,n===bO?(Fo.pack(s,e,i),i+=Fo.packedLength):(js.pack(s,e,i),i+=js.packedLength),l.pack(t._origin,e,i),i+=l.packedLength,Ae.pack(t._orientation,e,i),i+=Ae.packedLength,e[i]=t._drawNearPlane?1:0,e};tmt=new Fo,emt=new js,imt=new Ae,nmt=new l;FR.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=t[e++],s;n===bO?(s=Fo.unpack(t,e,tmt),e+=Fo.packedLength):(s=js.unpack(t,e,emt),e+=js.packedLength);let o=l.unpack(t,e,nmt);e+=l.packedLength;let r=Ae.unpack(t,e,imt);e+=Ae.packedLength;let a=t[e]===1;if(!m(i))return new FR({frustum:s,origin:o,orientation:r,_drawNearPlane:a});let h=n===i._frustumType?i._frustum:void 0;return i._frustum=s.clone(h),i._frustumType=n,i._origin=l.clone(o,i._origin),i._orientation=Ae.clone(r,i._orientation),i._drawNearPlane=a,i};FR.createGeometry=function(t){let e=t._frustumType,i=t._frustum,n=t._origin,s=t._orientation,o=t._drawNearPlane,r=new Float64Array(3*4*2);NR._computeNearFarPlanes(n,s,e,i,r);let a=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:r})}),h,A,d=o?2:1,f=new Uint16Array(8*(d+1)),E=o?0:1;for(;E<2;++E)h=o?E*8:0,A=E*4,f[h]=A,f[h+1]=A+1,f[h+2]=A+1,f[h+3]=A+2,f[h+4]=A+2,f[h+5]=A+3,f[h+6]=A+3,f[h+7]=A;for(E=0;E<2;++E)h=(d+E)*8,A=E*4,f[h]=A,f[h+1]=A+4,f[h+2]=A+1,f[h+3]=A+5,f[h+4]=A+2,f[h+5]=A+6,f[h+6]=A+3,f[h+7]=A+7;return new se({attributes:a,indices:f,primitiveType:ne.LINES,boundingSphere:Nt.fromVertices(r)})};YO=FR});var VO={};He(VO,{default:()=>omt});function smt(t,e){return m(e)&&(t=YO.unpack(t,e)),YO.createGeometry(t)}var omt,SO=S(()=>{mt();F5();omt=smt});var OO={};He(OO,{default:()=>amt});function rmt(t,e){return Do.initialize().then(function(){return m(e)&&(t=KE.unpack(t,e)),KE.createGeometry(t)})}var amt,BO=S(()=>{JE();mt();ON();amt=rmt});function Qf(t){t=Z(t,Z.EMPTY_OBJECT);let e=Z(t.vertexFormat,St.DEFAULT);this._vertexFormat=e,this._workerName="createPlaneGeometry"}var b5,Amt,Ag,hg,GO,Y5=S(()=>{_i();Ht();ae();oi();Ft();mt();yi();ji();En();Xi();Ls();Qf.packedLength=St.packedLength;Qf.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),St.pack(t._vertexFormat,e,i),e};b5=new St,Amt={vertexFormat:b5};Qf.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=St.unpack(t,e,b5);return m(i)?(i._vertexFormat=St.clone(n,i._vertexFormat),i):new Qf(Amt)};Ag=new l(-.5,-.5,0),hg=new l(.5,.5,0);Qf.createGeometry=function(t){let e=t._vertexFormat,i=new we,n,s;if(e.position){if(s=new Float64Array(4*3),s[0]=Ag.x,s[1]=Ag.y,s[2]=0,s[3]=hg.x,s[4]=Ag.y,s[5]=0,s[6]=hg.x,s[7]=hg.y,s[8]=0,s[9]=Ag.x,s[10]=hg.y,s[11]=0,i.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:s}),e.normal){let o=new Float32Array(12);o[0]=0,o[1]=0,o[2]=1,o[3]=0,o[4]=0,o[5]=1,o[6]=0,o[7]=0,o[8]=1,o[9]=0,o[10]=0,o[11]=1,i.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:o})}if(e.st){let o=new Float32Array(8);o[0]=0,o[1]=0,o[2]=1,o[3]=0,o[4]=1,o[5]=1,o[6]=0,o[7]=1,i.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:o})}if(e.tangent){let o=new Float32Array(12);o[0]=1,o[1]=0,o[2]=0,o[3]=1,o[4]=0,o[5]=0,o[6]=1,o[7]=0,o[8]=0,o[9]=1,o[10]=0,o[11]=0,i.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:o})}if(e.bitangent){let o=new Float32Array(12);o[0]=0,o[1]=1,o[2]=0,o[3]=0,o[4]=1,o[5]=0,o[6]=0,o[7]=1,o[8]=0,o[9]=0,o[10]=1,o[11]=0,i.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:o})}n=new Uint16Array(2*3),n[0]=0,n[1]=1,n[2]=2,n[3]=0,n[4]=2,n[5]=3}return new se({attributes:i,indices:n,primitiveType:ne.TRIANGLES,boundingSphere:new Nt(l.ZERO,Math.sqrt(2))})};GO=Qf});var WO={};He(WO,{default:()=>cmt});function hmt(t,e){return m(e)&&(t=GO.unpack(t,e)),GO.createGeometry(t)}var cmt,DO=S(()=>{mt();Y5();cmt=hmt});function kf(){this._workerName="createPlaneOutlineGeometry"}var Jc,cg,UO,V5=S(()=>{_i();Ht();ae();oi();mt();yi();ji();En();Xi();kf.packedLength=0;kf.pack=function(t,e){return p.defined("value",t),p.defined("array",e),e};kf.unpack=function(t,e,i){return p.defined("array",t),m(i)?i:new kf};Jc=new l(-.5,-.5,0),cg=new l(.5,.5,0);kf.createGeometry=function(){let t=new we,e=new Uint16Array(4*2),i=new Float64Array(4*3);return i[0]=Jc.x,i[1]=Jc.y,i[2]=Jc.z,i[3]=cg.x,i[4]=Jc.y,i[5]=Jc.z,i[6]=cg.x,i[7]=cg.y,i[8]=Jc.z,i[9]=Jc.x,i[10]=cg.y,i[11]=Jc.z,t.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:i}),e[0]=0,e[1]=1,e[2]=1,e[3]=2,e[4]=2,e[5]=3,e[6]=3,e[7]=0,new se({attributes:t,indices:e,primitiveType:ne.LINES,boundingSphere:new Nt(l.ZERO,Math.sqrt(2))})};UO=kf});var MO={};He(MO,{default:()=>dmt});function lmt(t,e){return m(e)&&(t=UO.unpack(t,e)),UO.createGeometry(t)}var dmt,QO=S(()=>{mt();V5();dmt=lmt});function As(t,e){this.position=t,m(this.position)||(this.position=new nt),this.tangentPlane=e,m(this.tangentPlane)||(this.tangentPlane=As.NORTH_POLE_TANGENT_PLANE)}var Lf,mmt,fmt,Emt,_mt,Fr,S5=S(()=>{Xe();Ht();ri();ae();mt();Oe();Xm();Ul();_e();SI();Object.defineProperties(As.prototype,{ellipsoid:{get:function(){return this.tangentPlane.ellipsoid}},x:{get:function(){return this.position.x}},y:{get:function(){return this.position.y}},conformalLatitude:{get:function(){let t=nt.magnitude(this.position),e=2*this.ellipsoid.maximumRadius;return this.tangentPlane.plane.normal.z*(L.PI_OVER_TWO-2*Math.atan2(t,e))}},longitude:{get:function(){let t=L.PI_OVER_TWO+Math.atan2(this.y,this.x);return t>Math.PI&&(t-=L.TWO_PI),t}}});Lf=new ut,mmt=new l;As.prototype.getLatitude=function(t){m(t)||(t=ot.WGS84),Lf.latitude=this.conformalLatitude,Lf.longitude=this.longitude,Lf.height=0;let e=this.ellipsoid.cartographicToCartesian(Lf,mmt);return t.cartesianToCartographic(e,Lf),Lf.latitude};fmt=new Wl,Emt=new l,_mt=new l;As.fromCartesian=function(t,e){p.defined("cartesian",t);let i=L.signNotZero(t.z),n=As.NORTH_POLE_TANGENT_PLANE,s=As.SOUTH_POLE;i<0&&(n=As.SOUTH_POLE_TANGENT_PLANE,s=As.NORTH_POLE);let o=fmt;o.origin=n.ellipsoid.scaleToGeocentricSurface(t,o.origin),o.direction=l.subtract(o.origin,s,Emt),l.normalize(o.direction,o.direction);let r=no.rayPlane(o,n.plane,_mt),a=l.subtract(r,s,r),h=l.dot(n.xAxis,a),A=i*l.dot(n.yAxis,a);return m(e)?(e.position=new nt(h,A),e.tangentPlane=n,e):new As(new nt(h,A),n)};As.fromCartesianArray=function(t,e){p.defined("cartesians",t);let i=t.length;m(e)?e.length=i:e=new Array(i);for(let n=0;n<i;n++)e[n]=As.fromCartesian(t[n],e[n]);return e};As.clone=function(t,e){if(m(t))return m(e)?(e.position=t.position,e.tangentPlane=t.tangentPlane,e):new As(t.position,t.tangentPlane)};As.HALF_UNIT_SPHERE=Object.freeze(new ot(.5,.5,.5));As.NORTH_POLE=Object.freeze(new l(0,0,.5));As.SOUTH_POLE=Object.freeze(new l(0,0,-.5));As.NORTH_POLE_TANGENT_PLANE=Object.freeze(new oo(As.NORTH_POLE,As.HALF_UNIT_SPHERE));As.SOUTH_POLE_TANGENT_PLANE=Object.freeze(new oo(As.SOUTH_POLE,As.HALF_UNIT_SPHERE));Fr=As});function Zmt(t,e,i,n){let o=n.cartesianToCartographic(t,Rmt).height,r=n.cartesianToCartographic(e,O5);r.height=o,n.cartographicToCartesian(r,e);let a=n.cartesianToCartographic(i,O5);a.height=o-100,n.cartographicToCartesian(a,i)}function kO(t){let e=t.vertexFormat,i=t.geometry,n=t.shadowVolume,s=i.attributes.position.values,o=m(i.attributes.st)?i.attributes.st.values:void 0,r=s.length,a=t.wall,h=t.top||a,A=t.bottom||a;if(e.st||e.normal||e.tangent||e.bitangent||n){let d=t.boundingRectangle,f=t.rotationAxis,E=t.projectTo2d,_=t.ellipsoid,R=t.stRotation,I=t.perPositionHeight,C=Nmt;C.x=d.x,C.y=d.y;let N=e.st?new Float32Array(2*(r/3)):void 0,T;e.normal&&(I&&h&&!a?T=i.attributes.normal.values:T=new Float32Array(r));let b=e.tangent?new Float32Array(r):void 0,F=e.bitangent?new Float32Array(r):void 0,B=n?new Float32Array(r):void 0,U=0,Q=0,M=pmt,k=umt,y=Cmt,c=!0,g=Ymt,O=Vmt;if(R!==0){let x=Ae.fromAxisAngle(f,R,G5);g=lt.fromQuaternion(x,g),x=Ae.fromAxisAngle(f,-R,G5),O=lt.fromQuaternion(x,O)}else g=lt.clone(lt.IDENTITY,g),O=lt.clone(lt.IDENTITY,O);let D=0,w=0;h&&A&&(D=r/2,w=r/3,r/=2);for(let x=0;x<r;x+=3){let H=l.fromArray(s,x,bmt);if(e.st&&!m(o)){let j=lt.multiplyByVector(g,H,Imt);j=_.scaleToGeodeticSurface(j,j);let X=E([j],Fmt)[0];nt.subtract(X,C,X);let tt=L.clamp(X.x/d.width,0,1),G=L.clamp(X.y/d.height,0,1);A&&(N[U+w]=tt,N[U+1+w]=G),h&&(N[U]=tt,N[U+1]=G),U+=2}if(e.normal||e.tangent||e.bitangent||n){let j=Q+1,X=Q+2;if(a){if(x+3<r){let tt=l.fromArray(s,x+3,gmt);if(c){let G=l.fromArray(s,x+r,Tmt);I&&Zmt(H,tt,G,_),l.subtract(tt,H,tt),l.subtract(G,H,G),M=l.normalize(l.cross(G,tt,M),M),c=!1}l.equalsEpsilon(tt,H,L.EPSILON10)&&(c=!0)}(e.tangent||e.bitangent)&&(y=_.geodeticSurfaceNormal(H,y),e.tangent&&(k=l.normalize(l.cross(y,M,k),k)))}else M=_.geodeticSurfaceNormal(H,M),(e.tangent||e.bitangent)&&(I&&(lg=l.fromArray(T,Q,lg),GA=l.cross(l.UNIT_Z,lg,GA),GA=l.normalize(lt.multiplyByVector(O,GA,GA),GA),e.bitangent&&(yf=l.normalize(l.cross(lg,GA,yf),yf))),k=l.cross(l.UNIT_Z,M,k),k=l.normalize(lt.multiplyByVector(O,k,k),k),e.bitangent&&(y=l.normalize(l.cross(M,k,y),y)));e.normal&&(t.wall?(T[Q+D]=M.x,T[j+D]=M.y,T[X+D]=M.z):A&&(T[Q+D]=-M.x,T[j+D]=-M.y,T[X+D]=-M.z),(h&&!I||a)&&(T[Q]=M.x,T[j]=M.y,T[X]=M.z)),n&&(a&&(M=_.geodeticSurfaceNormal(H,M)),B[Q+D]=-M.x,B[j+D]=-M.y,B[X+D]=-M.z),e.tangent&&(t.wall?(b[Q+D]=k.x,b[j+D]=k.y,b[X+D]=k.z):A&&(b[Q+D]=-k.x,b[j+D]=-k.y,b[X+D]=-k.z),h&&(I?(b[Q]=GA.x,b[j]=GA.y,b[X]=GA.z):(b[Q]=k.x,b[j]=k.y,b[X]=k.z))),e.bitangent&&(A&&(F[Q+D]=y.x,F[j+D]=y.y,F[X+D]=y.z),h&&(I?(F[Q]=yf.x,F[j]=yf.y,F[X]=yf.z):(F[Q]=y.x,F[j]=y.y,F[X]=y.z))),Q+=3}}e.st&&!m(o)&&(i.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:N})),e.normal&&(i.attributes.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:T})),e.tangent&&(i.attributes.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:b})),e.bitangent&&(i.attributes.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:F})),n&&(i.attributes.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:B}))}if(t.extrude&&m(t.offsetAttribute)){let d=s.length/3,f=new Uint8Array(d);if(t.offsetAttribute===Pe.TOP)h&&A||a?f=f.fill(1,0,d/2):h&&(f=f.fill(1));else{let E=t.offsetAttribute===Pe.NONE?0:1;f=f.fill(E)}i.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:f})}return i}function Smt(t,e,i,n,s,o,r,a,h,A){let d={walls:[]},f;if(r||a){let T=ii.createGeometryFromPositions(t,e,i,n,o,h,A),b=T.attributes.position.values,F=T.indices,B,U;if(r&&a){let Q=b.concat(b);B=Q.length/3,U=te.createTypedArray(B,F.length*2),U.set(F);let M=F.length,k=B/2;for(f=0;f<M;f+=3){let y=U[f]+k,c=U[f+1]+k,g=U[f+2]+k;U[f+M]=g,U[f+1+M]=c,U[f+2+M]=y}if(T.attributes.position.values=Q,o&&h.normal){let y=T.attributes.normal.values;T.attributes.normal.values=new Float32Array(Q.length),T.attributes.normal.values.set(y)}if(h.st&&m(i)){let y=T.attributes.st.values;T.attributes.st.values=new Float32Array(B*2),T.attributes.st.values=y.concat(y)}T.indices=U}else if(a){for(B=b.length/3,U=te.createTypedArray(B,F.length),f=0;f<F.length;f+=3)U[f]=F[f+2],U[f+1]=F[f+1],U[f+2]=F[f];T.indices=U}d.topAndBottom=new Ln({geometry:T})}let E=s.outerRing,_=oo.fromPoints(E,t),R=_.projectPointsOntoPlane(E,W5),I=ui.computeWindingOrder2D(R);I===Us.CLOCKWISE&&(E=E.slice().reverse());let C=ii.computeWallGeometry(E,i,t,n,o,A);d.walls.push(new Ln({geometry:C}));let N=s.holes;for(f=0;f<N.length;f++){let T=N[f];R=_.projectPointsOntoPlane(T,W5),I=ui.computeWindingOrder2D(R),I===Us.COUNTER_CLOCKWISE&&(T=T.slice().reverse()),C=ii.computeWallGeometry(T,i,t,n,o,A),d.walls.push(new Ln({geometry:C}))}return d}function ea(t){if(p.typeOf.object("options",t),p.typeOf.object("options.polygonHierarchy",t.polygonHierarchy),m(t.perPositionHeight)&&t.perPositionHeight&&m(t.height))throw new Y("Cannot use both options.perPositionHeight and options.height");if(m(t.arcType)&&t.arcType!==ti.GEODESIC&&t.arcType!==ti.RHUMB)throw new Y("Invalid arcType. Valid options are ArcType.GEODESIC and ArcType.RHUMB.");let e=t.polygonHierarchy,i=Z(t.vertexFormat,St.DEFAULT),n=Z(t.ellipsoid,ot.WGS84),s=Z(t.granularity,L.RADIANS_PER_DEGREE),o=Z(t.stRotation,0),r=t.textureCoordinates,a=Z(t.perPositionHeight,!1),h=a&&m(t.extrudedHeight),A=Z(t.height,0),d=Z(t.extrudedHeight,A);if(!h){let f=Math.max(A,d);d=Math.min(A,d),A=f}this._vertexFormat=St.clone(i),this._ellipsoid=ot.clone(n),this._granularity=s,this._stRotation=o,this._height=A,this._extrudedHeight=d,this._closeTop=Z(t.closeTop,!0),this._closeBottom=Z(t.closeBottom,!0),this._polygonHierarchy=e,this._perPositionHeight=a,this._perPositionHeightExtrude=h,this._shadowVolume=Z(t.shadowVolume,!1),this._workerName="createPolygonGeometry",this._offsetAttribute=t.offsetAttribute,this._arcType=Z(t.arcType,ti.GEODESIC),this._rectangle=void 0,this._textureCoordinateRotationPoints=void 0,this._textureCoordinates=r,this.packedLength=ii.computeHierarchyPackedLength(e,l)+ot.packedLength+St.packedLength+(r?ii.computeHierarchyPackedLength(r,nt):1)+12}function D5(t,e,i,n,s,o){let r=t.longitude,a=r>=0?r:r+L.TWO_PI;s.westOverIdl=Math.min(s.westOverIdl,a),s.eastOverIdl=Math.max(s.eastOverIdl,a),o.west=Math.min(o.west,r),o.east=Math.max(o.east,r);let h=t.getLatitude(i),A=h;if(o.south=Math.min(o.south,h),o.north=Math.max(o.north,h),n!==ti.RHUMB){let E=nt.subtract(e.position,t.position,Wmt),_=nt.dot(e.position,E)/nt.dot(E,E);if(_>0&&_<1){let R=nt.add(e.position,nt.multiplyByScalar(E,-_,E),Dmt),I=Fr.clone(e,Umt);I.position=R;let C=I.getLatitude(i);o.south=Math.min(o.south,C),o.north=Math.max(o.north,C),Math.abs(h)>Math.abs(C)&&(A=C)}}let d=e.x*t.y-t.x*e.y,f=Math.sign(d);f!==0&&(f*=nt.angleBetween(e.position,t.position)),A>=0&&(s.northAngle+=f),A<=0&&(s.southAngle+=f)}function kmt(t,e,i){return t.height>=L.PI||t.width>=L.PI?Fr.fromCartesian(e[0],Qmt).tangentPlane:oo.fromPoints(e,i)}function Lmt(t,e,i){return(n,s)=>{if(t.height>=L.PI||t.width>=L.PI){if(t.south<0&&t.north>0){m(s)||(s=[]);for(let r=0;r<n.length;++r){let a=i.cartesianToCartographic(n[r],M5);s[r]=new nt(a.longitude/L.PI,a.latitude/L.PI_OVER_TWO)}return s.length=n.length,s}return Fr.fromCartesianArray(n,s)}return oo.fromPoints(e,i).projectPointsOntoPlane(n,s)}}function ymt(t,e,i){if(t.height>=L.PI||t.width>=L.PI)return(s,o)=>{if(t.south<0&&t.north>0){let r=i.cartesianToCartographic(s,M5);return m(o)||(o=new nt),o.x=r.longitude/L.PI,o.y=r.latitude/L.PI_OVER_TWO,o}return Fr.fromCartesian(s,o)};let n=oo.fromPoints(e,i);return(s,o)=>n.projectPointsOntoPlane(s,o)}function wmt(t,e,i,n){return(s,o)=>!n&&(t.height>=L.PI_OVER_TWO||t.width>=2*L.PI_OVER_THREE)?ii.splitPolygonsOnEquator(s,e,i,o):s}function xmt(t,e,i,n){if(e.height>=L.PI||e.width>=L.PI)return mi.fromRectangle(e,void 0,B5);let s=t,o=oo.fromPoints(s,i);return ii.computeBoundingRectangle(o.plane.normal,o.projectPointOntoPlane.bind(o),s,n,B5)}function Pmt(t){let e=-t._stRotation;if(e===0)return[0,0,0,1,1,0];let i=t._ellipsoid,n=t._polygonHierarchy.positions,s=t.rectangle;return se._textureCoordinateRotationPoints(n,e,i,s)}var Rmt,O5,B5,Imt,pmt,umt,Cmt,gmt,Tmt,lg,GA,yf,Nmt,Fmt,bmt,G5,Ymt,Vmt,W5,Omt,Bmt,Gmt,Wmt,Dmt,Umt,U5,Mmt,ta,Qmt,M5,LO,Q5=S(()=>{Gl();Er();_i();Xe();Ht();ri();ae();oi();Ft();mt();Ot();Oe();Xm();yi();ji();uA();go();gA();Di();_e();dn();ER();Pa();$s();pn();S5();Ls();fc();Rmt=new ut,O5=new ut;B5=new mi,Imt=new l,pmt=new l,umt=new l,Cmt=new l,gmt=new l,Tmt=new l,lg=new l,GA=new l,yf=new l,Nmt=new nt,Fmt=new nt,bmt=new l,G5=new Ae,Ymt=new lt,Vmt=new lt;W5=[];ea.fromPositions=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.positions",t.positions);let e={polygonHierarchy:{positions:t.positions},height:t.height,extrudedHeight:t.extrudedHeight,vertexFormat:t.vertexFormat,stRotation:t.stRotation,ellipsoid:t.ellipsoid,granularity:t.granularity,perPositionHeight:t.perPositionHeight,closeTop:t.closeTop,closeBottom:t.closeBottom,offsetAttribute:t.offsetAttribute,arcType:t.arcType,textureCoordinates:t.textureCoordinates};return new ea(e)};ea.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),i=ii.packPolygonHierarchy(t._polygonHierarchy,e,i,l),ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,St.pack(t._vertexFormat,e,i),i+=St.packedLength,e[i++]=t._height,e[i++]=t._extrudedHeight,e[i++]=t._granularity,e[i++]=t._stRotation,e[i++]=t._perPositionHeightExtrude?1:0,e[i++]=t._perPositionHeight?1:0,e[i++]=t._closeTop?1:0,e[i++]=t._closeBottom?1:0,e[i++]=t._shadowVolume?1:0,e[i++]=Z(t._offsetAttribute,-1),e[i++]=t._arcType,m(t._textureCoordinates)?i=ii.packPolygonHierarchy(t._textureCoordinates,e,i,nt):e[i++]=-1,e[i++]=t.packedLength,e};Omt=ot.clone(ot.UNIT_SPHERE),Bmt=new St,Gmt={polygonHierarchy:{}};ea.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=ii.unpackPolygonHierarchy(t,e,l);e=n.startingIndex,delete n.startingIndex;let s=ot.unpack(t,e,Omt);e+=ot.packedLength;let o=St.unpack(t,e,Bmt);e+=St.packedLength;let r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++]===1,f=t[e++]===1,E=t[e++]===1,_=t[e++]===1,R=t[e++]===1,I=t[e++],C=t[e++],N=t[e]===-1?void 0:ii.unpackPolygonHierarchy(t,e,nt);m(N)?(e=N.startingIndex,delete N.startingIndex):e++;let T=t[e++];return m(i)||(i=new ea(Gmt)),i._polygonHierarchy=n,i._ellipsoid=ot.clone(s,i._ellipsoid),i._vertexFormat=St.clone(o,i._vertexFormat),i._height=r,i._extrudedHeight=a,i._granularity=h,i._stRotation=A,i._perPositionHeightExtrude=d,i._perPositionHeight=f,i._closeTop=E,i._closeBottom=_,i._shadowVolume=R,i._offsetAttribute=I===-1?void 0:I,i._arcType=C,i._textureCoordinates=N,i.packedLength=T,i};Wmt=new nt,Dmt=new nt,Umt=new Fr;U5=new Fr,Mmt=new Fr,ta={northAngle:0,southAngle:0,westOverIdl:0,eastOverIdl:0};ea.computeRectangleFromPositions=function(t,e,i,n){if(p.defined("positions",t),m(n)||(n=new Xt),t.length<3)return n;n.west=Number.POSITIVE_INFINITY,n.east=Number.NEGATIVE_INFINITY,n.south=Number.POSITIVE_INFINITY,n.north=Number.NEGATIVE_INFINITY,ta.northAngle=0,ta.southAngle=0,ta.westOverIdl=Number.POSITIVE_INFINITY,ta.eastOverIdl=Number.NEGATIVE_INFINITY;let s=t.length,o=Fr.fromCartesian(t[0],Mmt);for(let r=1;r<s;r++){let a=Fr.fromCartesian(t[r],U5);D5(a,o,e,i,ta,n),o=Fr.clone(a,o)}return D5(Fr.fromCartesian(t[0],U5),o,e,i,ta,n),n.east-n.west>ta.eastOverIdl-ta.westOverIdl&&(n.west=ta.westOverIdl,n.east=ta.eastOverIdl,n.east>L.PI&&(n.east=n.east-L.TWO_PI),n.west>L.PI&&(n.west=n.west-L.TWO_PI)),L.equalsEpsilon(Math.abs(ta.northAngle),L.TWO_PI,L.EPSILON10)&&(n.north=L.PI_OVER_TWO,n.east=L.PI,n.west=-L.PI),L.equalsEpsilon(Math.abs(ta.southAngle),L.TWO_PI,L.EPSILON10)&&(n.south=-L.PI_OVER_TWO,n.east=L.PI,n.west=-L.PI),n};Qmt=new Fr;M5=new ut;ea.createGeometry=function(t){let e=t._vertexFormat,i=t._ellipsoid,n=t._granularity,s=t._stRotation,o=t._polygonHierarchy,r=t._perPositionHeight,a=t._closeTop,h=t._closeBottom,A=t._arcType,d=t._textureCoordinates,f=m(d),E=o.positions;if(E.length<3)return;let _=t.rectangle,R=ii.polygonsFromHierarchy(o,f,Lmt(_,E,i),!r,i,wmt(_,i,A,r)),I=R.hierarchy,C=R.polygons,N=function(D){return D},T=f?ii.polygonsFromHierarchy(d,!0,N,!1,i).polygons:void 0;if(I.length===0)return;let b=I[0].outerRing,F=xmt(b,_,i,s),B=[],U=t._height,Q=t._extrudedHeight,M=t._perPositionHeightExtrude||!L.equalsEpsilon(U,Q,0,L.EPSILON2),k={perPositionHeight:r,vertexFormat:e,geometry:void 0,rotationAxis:kmt(_,b,i).plane.normal,projectTo2d:ymt(_,b,i),boundingRectangle:F,ellipsoid:i,stRotation:s,textureCoordinates:void 0,bottom:!1,top:!0,wall:!1,extrude:!1,arcType:A},y;if(M)for(k.extrude=!0,k.top=a,k.bottom=h,k.shadowVolume=t._shadowVolume,k.offsetAttribute=t._offsetAttribute,y=0;y<C.length;y++){let D=Smt(i,C[y],f?T[y]:void 0,n,I[y],r,a,h,e,A),w;a&&h?(w=D.topAndBottom,k.geometry=ii.scaleToGeodeticHeightExtruded(w.geometry,U,Q,i,r)):a?(w=D.topAndBottom,w.geometry.attributes.position.values=ui.scaleToGeodeticHeight(w.geometry.attributes.position.values,U,i,!r),k.geometry=w.geometry):h&&(w=D.topAndBottom,w.geometry.attributes.position.values=ui.scaleToGeodeticHeight(w.geometry.attributes.position.values,Q,i,!0),k.geometry=w.geometry),(a||h)&&(k.wall=!1,w.geometry=kO(k),B.push(w));let x=D.walls;k.wall=!0;for(let H=0;H<x.length;H++){let j=x[H];k.geometry=ii.scaleToGeodeticHeightExtruded(j.geometry,U,Q,i,r),j.geometry=kO(k),B.push(j)}}else for(y=0;y<C.length;y++){let D=new Ln({geometry:ii.createGeometryFromPositions(i,C[y],f?T[y]:void 0,n,r,e,A)});if(D.geometry.attributes.position.values=ui.scaleToGeodeticHeight(D.geometry.attributes.position.values,U,i,!r),k.geometry=D.geometry,D.geometry=kO(k),m(t._offsetAttribute)){let w=D.geometry.attributes.position.values.length,x=t._offsetAttribute===Pe.NONE?0:1,H=new Uint8Array(w/3).fill(x);D.geometry.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:H})}B.push(D)}let c=wi.combineInstances(B)[0];c.attributes.position.values=new Float64Array(c.attributes.position.values),c.indices=te.createTypedArray(c.attributes.position.values.length/3,c.indices);let g=c.attributes,O=Nt.fromVertices(g.position.values);return e.position||delete g.position,new se({attributes:g,indices:c.indices,primitiveType:c.primitiveType,boundingSphere:O,offsetAttribute:t._offsetAttribute})};ea.createShadowVolume=function(t,e,i){let n=t._granularity,s=t._ellipsoid,o=e(n,s),r=i(n,s);return new ea({polygonHierarchy:t._polygonHierarchy,ellipsoid:s,stRotation:t._stRotation,granularity:n,perPositionHeight:!1,extrudedHeight:o,height:r,vertexFormat:St.POSITION_ONLY,shadowVolume:!0,arcType:t._arcType})};Object.defineProperties(ea.prototype,{rectangle:{get:function(){if(!m(this._rectangle)){let t=this._polygonHierarchy.positions;this._rectangle=ea.computeRectangleFromPositions(t,this._ellipsoid,this._arcType)}return this._rectangle}},textureCoordinateRotationPoints:{get:function(){return m(this._textureCoordinateRotationPoints)||(this._textureCoordinateRotationPoints=Pmt(this)),this._textureCoordinateRotationPoints}}});LO=ea});var yO={};He(yO,{default:()=>jmt});function Jmt(t,e){return m(e)&&(t=LO.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),LO.createGeometry(t)}var jmt,wO=S(()=>{mt();Oe();Q5();jmt=Jmt});function Hmt(t,e,i,n,s){let r=oo.fromPoints(e,t).projectPointsOntoPlane(e,k5);ui.computeWindingOrder2D(r)===Us.CLOCKWISE&&(r.reverse(),e=e.slice().reverse());let h,A,d=e.length,f=0;if(n)for(h=new Float64Array(d*2*3),A=0;A<d;A++){let R=e[A],I=e[(A+1)%d];h[f++]=R.x,h[f++]=R.y,h[f++]=R.z,h[f++]=I.x,h[f++]=I.y,h[f++]=I.z}else{let R=0;if(s===ti.GEODESIC)for(A=0;A<d;A++)R+=ii.subdivideLineCount(e[A],e[(A+1)%d],i);else if(s===ti.RHUMB)for(A=0;A<d;A++)R+=ii.subdivideRhumbLineCount(t,e[A],e[(A+1)%d],i);for(h=new Float64Array(R*3),A=0;A<d;A++){let I;s===ti.GEODESIC?I=ii.subdivideLine(e[A],e[(A+1)%d],i,dg):s===ti.RHUMB&&(I=ii.subdivideRhumbLine(t,e[A],e[(A+1)%d],i,dg));let C=I.length;for(let N=0;N<C;++N)h[f++]=I[N]}}d=h.length/3;let E=d*2,_=te.createTypedArray(d,E);for(f=0,A=0;A<d-1;A++)_[f++]=A,_[f++]=A+1;return _[f++]=d-1,_[f++]=0,new Ln({geometry:new se({attributes:new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:h})}),indices:_,primitiveType:ne.LINES})})}function vmt(t,e,i,n,s){let r=oo.fromPoints(e,t).projectPointsOntoPlane(e,k5);ui.computeWindingOrder2D(r)===Us.CLOCKWISE&&(r.reverse(),e=e.slice().reverse());let h,A,d=e.length,f=new Array(d),E=0;if(n)for(h=new Float64Array(d*2*3*2),A=0;A<d;++A){f[A]=E/3;let C=e[A],N=e[(A+1)%d];h[E++]=C.x,h[E++]=C.y,h[E++]=C.z,h[E++]=N.x,h[E++]=N.y,h[E++]=N.z}else{let C=0;if(s===ti.GEODESIC)for(A=0;A<d;A++)C+=ii.subdivideLineCount(e[A],e[(A+1)%d],i);else if(s===ti.RHUMB)for(A=0;A<d;A++)C+=ii.subdivideRhumbLineCount(t,e[A],e[(A+1)%d],i);for(h=new Float64Array(C*3*2),A=0;A<d;++A){f[A]=E/3;let N;s===ti.GEODESIC?N=ii.subdivideLine(e[A],e[(A+1)%d],i,dg):s===ti.RHUMB&&(N=ii.subdivideRhumbLine(t,e[A],e[(A+1)%d],i,dg));let T=N.length;for(let b=0;b<T;++b)h[E++]=N[b]}}d=h.length/(3*2);let _=f.length,R=(d*2+_)*2,I=te.createTypedArray(d+_,R);for(E=0,A=0;A<d;++A)I[E++]=A,I[E++]=(A+1)%d,I[E++]=A+d,I[E++]=(A+1)%d+d;for(A=0;A<_;A++){let C=f[A];I[E++]=C,I[E++]=C+d}return new Ln({geometry:new se({attributes:new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:h})}),indices:I,primitiveType:ne.LINES})})}function Zd(t){if(p.typeOf.object("options",t),p.typeOf.object("options.polygonHierarchy",t.polygonHierarchy),t.perPositionHeight&&m(t.height))throw new Y("Cannot use both options.perPositionHeight and options.height");if(m(t.arcType)&&t.arcType!==ti.GEODESIC&&t.arcType!==ti.RHUMB)throw new Y("Invalid arcType. Valid options are ArcType.GEODESIC and ArcType.RHUMB.");let e=t.polygonHierarchy,i=Z(t.ellipsoid,ot.WGS84),n=Z(t.granularity,L.RADIANS_PER_DEGREE),s=Z(t.perPositionHeight,!1),o=s&&m(t.extrudedHeight),r=Z(t.arcType,ti.GEODESIC),a=Z(t.height,0),h=Z(t.extrudedHeight,a);if(!o){let A=Math.max(a,h);h=Math.min(a,h),a=A}this._ellipsoid=ot.clone(i),this._granularity=n,this._height=a,this._extrudedHeight=h,this._arcType=r,this._polygonHierarchy=e,this._perPositionHeight=s,this._perPositionHeightExtrude=o,this._offsetAttribute=t.offsetAttribute,this._workerName="createPolygonOutlineGeometry",this.packedLength=ii.computeHierarchyPackedLength(e,l)+ot.packedLength+8}var k5,dg,zmt,Kmt,xO,L5=S(()=>{Gl();_i();Ht();ae();oi();Ft();mt();Ot();Oe();Xm();yi();ji();En();uA();go();gA();Di();_e();ER();Pa();Xi();fc();k5=[],dg=[];Zd.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),i=ii.packPolygonHierarchy(t._polygonHierarchy,e,i,l),ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._height,e[i++]=t._extrudedHeight,e[i++]=t._granularity,e[i++]=t._perPositionHeightExtrude?1:0,e[i++]=t._perPositionHeight?1:0,e[i++]=t._arcType,e[i++]=Z(t._offsetAttribute,-1),e[i]=t.packedLength,e};zmt=ot.clone(ot.UNIT_SPHERE),Kmt={polygonHierarchy:{}};Zd.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=ii.unpackPolygonHierarchy(t,e,l);e=n.startingIndex,delete n.startingIndex;let s=ot.unpack(t,e,zmt);e+=ot.packedLength;let o=t[e++],r=t[e++],a=t[e++],h=t[e++]===1,A=t[e++]===1,d=t[e++],f=t[e++],E=t[e];return m(i)||(i=new Zd(Kmt)),i._polygonHierarchy=n,i._ellipsoid=ot.clone(s,i._ellipsoid),i._height=o,i._extrudedHeight=r,i._granularity=a,i._perPositionHeight=A,i._perPositionHeightExtrude=h,i._arcType=d,i._offsetAttribute=f===-1?void 0:f,i.packedLength=E,i};Zd.fromPositions=function(t){t=Z(t,Z.EMPTY_OBJECT),p.defined("options.positions",t.positions);let e={polygonHierarchy:{positions:t.positions},height:t.height,extrudedHeight:t.extrudedHeight,ellipsoid:t.ellipsoid,granularity:t.granularity,perPositionHeight:t.perPositionHeight,arcType:t.arcType,offsetAttribute:t.offsetAttribute};return new Zd(e)};Zd.createGeometry=function(t){let e=t._ellipsoid,i=t._granularity,n=t._polygonHierarchy,s=t._perPositionHeight,o=t._arcType,r=ii.polygonOutlinesFromHierarchy(n,!s,e);if(r.length===0)return;let a,h=[],A=L.chordLength(i,e.maximumRadius),d=t._height,f=t._extrudedHeight,E=t._perPositionHeightExtrude||!L.equalsEpsilon(d,f,0,L.EPSILON2),_,R;if(E)for(R=0;R<r.length;R++){if(a=vmt(e,r[R],A,s,o),a.geometry=ii.scaleToGeodeticHeightExtruded(a.geometry,d,f,e,s),m(t._offsetAttribute)){let N=a.geometry.attributes.position.values.length/3,T=new Uint8Array(N);t._offsetAttribute===Pe.TOP?T=T.fill(1,0,N/2):(_=t._offsetAttribute===Pe.NONE?0:1,T=T.fill(_)),a.geometry.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:T})}h.push(a)}else for(R=0;R<r.length;R++){if(a=Hmt(e,r[R],A,s,o),a.geometry.attributes.position.values=ui.scaleToGeodeticHeight(a.geometry.attributes.position.values,d,e,!s),m(t._offsetAttribute)){let N=a.geometry.attributes.position.values.length;_=t._offsetAttribute===Pe.NONE?0:1;let T=new Uint8Array(N/3).fill(_);a.geometry.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:T})}h.push(a)}let I=wi.combineInstances(h)[0],C=Nt.fromVertices(I.attributes.position.values);return new se({attributes:I.attributes,indices:I.indices,primitiveType:I.primitiveType,boundingSphere:C,offsetAttribute:t._offsetAttribute})};xO=Zd});var PO={};He(PO,{default:()=>qmt});function Xmt(t,e){return m(e)&&(t=xO.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),xO.createGeometry(t)}var qmt,JO=S(()=>{mt();Oe();L5();qmt=Xmt});function $mt(t,e,i,n,s){let o=J5;o.length=s;let r,a=i.red,h=i.green,A=i.blue,d=i.alpha,f=n.red,E=n.green,_=n.blue,R=n.alpha;if(Zt.equals(i,n)){for(r=0;r<s;r++)o[r]=Zt.clone(i);return o}let I=(f-a)/s,C=(E-h)/s,N=(_-A)/s,T=(R-d)/s;for(r=0;r<s;r++)o[r]=new Zt(a+r*I,h+r*C,A+r*N,d+r*T);return o}function bR(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.colors,n=Z(t.width,1),s=Z(t.colorsPerVertex,!1);if(!m(e)||e.length<2)throw new Y("At least two positions are required.");if(typeof n!="number")throw new Y("width must be a number");if(m(i)&&(s&&i.length<e.length||!s&&i.length<e.length-1))throw new Y("colors has an invalid length.");this._positions=e,this._colors=i,this._width=n,this._colorsPerVertex=s,this._vertexFormat=St.clone(Z(t.vertexFormat,St.DEFAULT)),this._arcType=Z(t.arcType,ti.GEODESIC),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._workerName="createPolylineGeometry";let o=1+e.length*l.packedLength;o+=m(i)?1+i.length*Zt.packedLength:1,this.packedLength=o+ot.packedLength+St.packedLength+4}var J5,j5,H5,Id,y5,w5,x5,P5,jO,v5=S(()=>{Gl();Sa();_i();Ht();Qn();oi();Ft();mt();Ot();Oe();yi();ji();En();dI();Di();_e();Sf();Xi();Ls();J5=[];bR.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._colors;for(o=m(r)?r.length:0,e[i++]=o,n=0;n<o;++n,i+=Zt.packedLength)Zt.pack(r[n],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,St.pack(t._vertexFormat,e,i),i+=St.packedLength,e[i++]=t._width,e[i++]=t._colorsPerVertex?1:0,e[i++]=t._arcType,e[i]=t._granularity,e};j5=ot.clone(ot.UNIT_SPHERE),H5=new St,Id={positions:void 0,colors:void 0,ellipsoid:j5,vertexFormat:H5,width:void 0,colorsPerVertex:void 0,arcType:void 0,granularity:void 0};bR.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r=s>0?new Array(s):void 0;for(n=0;n<s;++n,e+=Zt.packedLength)r[n]=Zt.unpack(t,e);let a=ot.unpack(t,e,j5);e+=ot.packedLength;let h=St.unpack(t,e,H5);e+=St.packedLength;let A=t[e++],d=t[e++]===1,f=t[e++],E=t[e];return m(i)?(i._positions=o,i._colors=r,i._ellipsoid=ot.clone(a,i._ellipsoid),i._vertexFormat=St.clone(h,i._vertexFormat),i._width=A,i._colorsPerVertex=d,i._arcType=f,i._granularity=E,i):(Id.positions=o,Id.colors=r,Id.width=A,Id.colorsPerVertex=d,Id.arcType=f,Id.granularity=E,new bR(Id))};y5=new l,w5=new l,x5=new l,P5=new l;bR.createGeometry=function(t){let e=t._width,i=t._vertexFormat,n=t._colors,s=t._colorsPerVertex,o=t._arcType,r=t._granularity,a=t._ellipsoid,h,A,d,f=[],E=Xn(t._positions,l.equalsEpsilon,!1,f);if(m(n)&&f.length>0){let w=0,x=f[0];n=n.filter(function(H,j){let X=!1;return s?X=j===x||j===0&&x===1:X=j+1===x,X?(w++,x=f[w],!1):!0})}let _=E.length;if(_<2||e<=0)return;if(o===ti.GEODESIC||o===ti.RHUMB){let w,x;o===ti.GEODESIC?(w=L.chordLength(r,a.maximumRadius),x=Sn.numberOfPoints):(w=r,x=Sn.numberOfPointsRhumbLine);let H=Sn.extractHeights(E,a);if(m(n)){let j=1;for(h=0;h<_-1;++h)j+=x(E[h],E[h+1],w);let X=new Array(j),tt=0;for(h=0;h<_-1;++h){let G=E[h],It=E[h+1],gt=n[h],Yt=x(G,It,w);if(s&&h<j){let Ut=n[h+1],Ct=$mt(G,It,gt,Ut,Yt),zt=Ct.length;for(A=0;A<zt;++A)X[tt++]=Ct[A]}else for(A=0;A<Yt;++A)X[tt++]=Zt.clone(gt)}X[tt]=Zt.clone(n[n.length-1]),n=X,J5.length=0}o===ti.GEODESIC?E=Sn.generateCartesianArc({positions:E,minDistance:w,ellipsoid:a,height:H}):E=Sn.generateCartesianRhumbArc({positions:E,granularity:w,ellipsoid:a,height:H})}_=E.length;let R=_*4-4,I=new Float64Array(R*3),C=new Float64Array(R*3),N=new Float64Array(R*3),T=new Float32Array(R*2),b=i.st?new Float32Array(R*2):void 0,F=m(n)?new Uint8Array(R*4):void 0,B=0,U=0,Q=0,M=0,k;for(A=0;A<_;++A){A===0?(k=y5,l.subtract(E[0],E[1],k),l.add(E[0],k,k)):k=E[A-1],l.clone(k,x5),l.clone(E[A],w5),A===_-1?(k=y5,l.subtract(E[_-1],E[_-2],k),l.add(E[_-1],k,k)):k=E[A+1],l.clone(k,P5);let w,x;m(F)&&(A!==0&&!s?w=n[A-1]:w=n[A],A!==_-1&&(x=n[A]));let H=A===0?2:0,j=A===_-1?2:4;for(d=H;d<j;++d){l.pack(w5,I,B),l.pack(x5,C,B),l.pack(P5,N,B),B+=3;let X=d-2<0?-1:1;if(T[U++]=2*(d%2)-1,T[U++]=X*e,i.st&&(b[Q++]=A/(_-1),b[Q++]=Math.max(T[U-2],0)),m(F)){let tt=d<2?w:x;F[M++]=Zt.floatToByte(tt.red),F[M++]=Zt.floatToByte(tt.green),F[M++]=Zt.floatToByte(tt.blue),F[M++]=Zt.floatToByte(tt.alpha)}}}let y=new we;y.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:I}),y.prevPosition=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:C}),y.nextPosition=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:N}),y.expandAndWidth=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:T}),i.st&&(y.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:b})),m(F)&&(y.color=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:4,values:F,normalize:!0}));let c=te.createTypedArray(R,_*6-6),g=0,O=0,D=_-1;for(A=0;A<D;++A)c[O++]=g,c[O++]=g+2,c[O++]=g+1,c[O++]=g+1,c[O++]=g+2,c[O++]=g+3,g+=4;return new se({attributes:y,indices:c,primitiveType:ne.TRIANGLES,boundingSphere:Nt.fromPoints(E),geometryType:Ah.POLYLINES})};jO=bR});var HO={};He(HO,{default:()=>eft});function tft(t,e){return m(e)&&(t=jO.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),jO.createGeometry(t)}var eft,vO=S(()=>{mt();Oe();v5();eft=tft});function ift(t,e,i,n){let s=new we;n.position&&(s.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:t}));let o=e.length,r=t.length/3,a=(r-o*2)/(o*2),h=ui.triangulate(e),A=(a-1)*o*6+h.length*2,d=te.createTypedArray(r,A),f,E,_,R,I,C,N=o*2,T=0;for(f=0;f<a-1;f++){for(E=0;E<o-1;E++)_=E*2+f*o*2,C=_+N,R=_+1,I=R+N,d[T++]=R,d[T++]=_,d[T++]=I,d[T++]=I,d[T++]=_,d[T++]=C;_=o*2-2+f*o*2,R=_+1,I=R+N,C=_+N,d[T++]=R,d[T++]=_,d[T++]=I,d[T++]=I,d[T++]=_,d[T++]=C}if(n.st||n.tangent||n.bitangent){let B=new Float32Array(r*2),U=1/(a-1),Q=1/i.height,M=i.height/2,k,y,c=0;for(f=0;f<a;f++){for(k=f*U,y=Q*(e[0].y+M),B[c++]=k,B[c++]=y,E=1;E<o;E++)y=Q*(e[E].y+M),B[c++]=k,B[c++]=y,B[c++]=k,B[c++]=y;y=Q*(e[0].y+M),B[c++]=k,B[c++]=y}for(E=0;E<o;E++)k=0,y=Q*(e[E].y+M),B[c++]=k,B[c++]=y;for(E=0;E<o;E++)k=(a-1)*U,y=Q*(e[E].y+M),B[c++]=k,B[c++]=y;s.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:new Float32Array(B)})}let b=r-o*2;for(f=0;f<h.length;f+=3){let B=h[f]+b,U=h[f+1]+b,Q=h[f+2]+b;d[T++]=B,d[T++]=U,d[T++]=Q,d[T++]=Q+o,d[T++]=U+o,d[T++]=B+o}let F=new se({attributes:s,indices:d,boundingSphere:Nt.fromVertices(t),primitiveType:ne.TRIANGLES});if(n.normal&&(F=wi.computeNormal(F)),n.tangent||n.bitangent){try{F=wi.computeTangentAndBitangent(F)}catch{zC("polyline-volume-tangent-bitangent","Unable to compute tangents and bitangents for polyline volume geometry")}n.tangent||(F.attributes.tangent=void 0),n.bitangent||(F.attributes.bitangent=void 0),n.st||(F.attributes.st=void 0)}return F}function VR(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.polylinePositions,i=t.shapePositions;if(!m(e))throw new Y("options.polylinePositions is required.");if(!m(i))throw new Y("options.shapePositions is required.");this._positions=e,this._shape=i,this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._cornerType=Z(t.cornerType,Cn.ROUNDED),this._vertexFormat=St.clone(Z(t.vertexFormat,St.DEFAULT)),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._workerName="createPolylineVolumeGeometry";let n=1+e.length*l.packedLength;n+=1+i.length*nt.packedLength,this.packedLength=n+ot.packedLength+St.packedLength+2}var z5,K5,YR,nft,zO,X5=S(()=>{Sa();Er();_i();Xe();Ht();oi();fd();Ft();mt();Ot();Oe();yi();ji();En();gA();Di();_e();LS();Pa();$C();Xi();Ls();fc();VR.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._shape;for(o=r.length,e[i++]=o,n=0;n<o;++n,i+=nt.packedLength)nt.pack(r[n],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,St.pack(t._vertexFormat,e,i),i+=St.packedLength,e[i++]=t._cornerType,e[i]=t._granularity,e};z5=ot.clone(ot.UNIT_SPHERE),K5=new St,YR={polylinePositions:void 0,shapePositions:void 0,ellipsoid:z5,vertexFormat:K5,cornerType:void 0,granularity:void 0};VR.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r=new Array(s);for(n=0;n<s;++n,e+=nt.packedLength)r[n]=nt.unpack(t,e);let a=ot.unpack(t,e,z5);e+=ot.packedLength;let h=St.unpack(t,e,K5);e+=St.packedLength;let A=t[e++],d=t[e];return m(i)?(i._positions=o,i._shape=r,i._ellipsoid=ot.clone(a,i._ellipsoid),i._vertexFormat=St.clone(h,i._vertexFormat),i._cornerType=A,i._granularity=d,i):(YR.polylinePositions=o,YR.shapePositions=r,YR.cornerType=A,YR.granularity=d,new VR(YR))};nft=new mi;VR.createGeometry=function(t){let e=t._positions,i=Xn(e,l.equalsEpsilon),n=t._shape;if(n=Lc.removeDuplicatesFromShape(n),i.length<2||n.length<3)return;ui.computeWindingOrder2D(n)===Us.CLOCKWISE&&n.reverse();let s=mi.fromPoints(n,nft),o=Lc.computePositions(i,n,s,t,!0);return ift(o,n,s,t._vertexFormat)};zO=VR});var KO={};He(KO,{default:()=>oft});function sft(t,e){return m(e)&&(t=zO.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),zO.createGeometry(t)}var oft,XO=S(()=>{mt();Oe();X5();oft=sft});function rft(t,e){let i=new we;i.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:t});let n=e.length,s=i.position.values.length/3,r=t.length/3/n,a=te.createTypedArray(s,2*n*(r+1)),h,A,d=0;h=0;let f=h*n;for(A=0;A<n-1;A++)a[d++]=A+f,a[d++]=A+f+1;for(a[d++]=n-1+f,a[d++]=f,h=r-1,f=h*n,A=0;A<n-1;A++)a[d++]=A+f,a[d++]=A+f+1;for(a[d++]=n-1+f,a[d++]=f,h=0;h<r-1;h++){let _=n*h,R=_+n;for(A=0;A<n;A++)a[d++]=A+_,a[d++]=A+R}return new se({attributes:i,indices:te.createTypedArray(s,a),boundingSphere:Nt.fromVertices(t),primitiveType:ne.LINES})}function OR(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.polylinePositions,i=t.shapePositions;if(!m(e))throw new Y("options.polylinePositions is required.");if(!m(i))throw new Y("options.shapePositions is required.");this._positions=e,this._shape=i,this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._cornerType=Z(t.cornerType,Cn.ROUNDED),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._workerName="createPolylineVolumeOutlineGeometry";let n=1+e.length*l.packedLength;n+=1+i.length*nt.packedLength,this.packedLength=n+ot.packedLength+2}var q5,SR,aft,qO,$5=S(()=>{Sa();Er();_i();Xe();Ht();oi();fd();Ft();mt();Ot();Oe();yi();ji();En();Di();_e();Pa();$C();Xi();fc();OR.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._shape;for(o=r.length,e[i++]=o,n=0;n<o;++n,i+=nt.packedLength)nt.pack(r[n],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._cornerType,e[i]=t._granularity,e};q5=ot.clone(ot.UNIT_SPHERE),SR={polylinePositions:void 0,shapePositions:void 0,ellipsoid:q5,height:void 0,cornerType:void 0,granularity:void 0};OR.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r=new Array(s);for(n=0;n<s;++n,e+=nt.packedLength)r[n]=nt.unpack(t,e);let a=ot.unpack(t,e,q5);e+=ot.packedLength;let h=t[e++],A=t[e];return m(i)?(i._positions=o,i._shape=r,i._ellipsoid=ot.clone(a,i._ellipsoid),i._cornerType=h,i._granularity=A,i):(SR.polylinePositions=o,SR.shapePositions=r,SR.cornerType=h,SR.granularity=A,new OR(SR))};aft=new mi;OR.createGeometry=function(t){let e=t._positions,i=Xn(e,l.equalsEpsilon),n=t._shape;if(n=Lc.removeDuplicatesFromShape(n),i.length<2||n.length<3)return;ui.computeWindingOrder2D(n)===Us.CLOCKWISE&&n.reverse();let s=mi.fromPoints(n,aft),o=Lc.computePositions(i,n,s,t,!1);return rft(o,n)};qO=OR});var $O={};He($O,{default:()=>hft});function Aft(t,e){return m(e)&&(t=qO.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),qO.createGeometry(t)}var hft,tB=S(()=>{mt();Oe();$5();hft=Aft});function i6(t,e,i,n,s,o,r){let a=Math.cos(e),h=n*a,A=i*a,d=Math.sin(e),f=n*d,E=i*d;ia=eB.project(t,ia),ia=l.subtract(ia,mg,ia);let _=Hn.fromRotation(e,lft);ia=Hn.multiplyByVector(_,ia,ia),ia=l.add(ia,mg,ia),t=eB.unproject(ia,t),o-=1,r-=1;let R=t.latitude,I=R+o*E,C=R-h*r,N=R-h*r+o*E,T=Math.max(R,I,C,N),b=Math.min(R,I,C,N),F=t.longitude,B=F+o*A,U=F+r*f,Q=F+r*f+o*A,M=Math.max(F,B,U,Q),k=Math.min(F,B,U,Q);return{north:T,south:b,east:M,west:k,granYCos:h,granYSin:f,granXCos:A,granXSin:E,nwCorner:t}}var t6,e6,cft,iB,lft,ia,dft,mg,eB,ro,nB=S(()=>{Ht();ri();mt();Ot();zA();_e();dc();pn();t6=Math.cos,e6=Math.sin,cft=Math.sqrt,iB={};iB.computePosition=function(t,e,i,n,s,o,r){let a=e.radiiSquared,h=t.nwCorner,A=t.boundingRectangle,d=h.latitude-t.granYCos*n+s*t.granXSin,f=t6(d),E=e6(d),_=a.z*E,R=h.longitude+n*t.granYSin+s*t.granXCos,I=f*t6(R),C=f*e6(R),N=a.x*I,T=a.y*C,b=cft(N*I+T*C+_*E);if(o.x=N/b,o.y=T/b,o.z=_/b,i){let F=t.stNwCorner;m(F)?(d=F.latitude-t.stGranYCos*n+s*t.stGranXSin,R=F.longitude+n*t.stGranYSin+s*t.stGranXCos,r.x=(R-t.stWest)*t.lonScalar,r.y=(d-t.stSouth)*t.latScalar):(r.x=(R-A.west)*t.lonScalar,r.y=(d-A.south)*t.latScalar)}};lft=new Hn,ia=new l,dft=new ut,mg=new l,eB=new Ss;iB.computeOptions=function(t,e,i,n,s,o,r){let a=t.east,h=t.west,A=t.north,d=t.south,f=!1,E=!1;A===L.PI_OVER_TWO&&(f=!0),d===-L.PI_OVER_TWO&&(E=!0);let _,R=A-d;h>a?_=L.TWO_PI-h+a:_=a-h;let I=Math.ceil(_/e)+1,C=Math.ceil(R/e)+1,N=_/(I-1),T=R/(C-1),b=Xt.northwest(t,o),F=Xt.center(t,dft);(i!==0||n!==0)&&(F.longitude<b.longitude&&(F.longitude+=L.TWO_PI),mg=eB.project(F,mg));let B=T,U=N,Q=0,M=0,k=Xt.clone(t,s),y={granYCos:B,granYSin:Q,granXCos:U,granXSin:M,nwCorner:b,boundingRectangle:k,width:I,height:C,northCap:f,southCap:E};if(i!==0){let c=i6(b,i,N,T,F,I,C);if(A=c.north,d=c.south,a=c.east,h=c.west,A<-L.PI_OVER_TWO||A>L.PI_OVER_TWO||d<-L.PI_OVER_TWO||d>L.PI_OVER_TWO)throw new Y("Rotated rectangle is invalid.  It crosses over either the north or south pole.");y.granYCos=c.granYCos,y.granYSin=c.granYSin,y.granXCos=c.granXCos,y.granXSin=c.granXSin,k.north=A,k.south=d,k.east=a,k.west=h}if(n!==0){i=i-n;let c=Xt.northwest(k,r),g=i6(c,i,N,T,F,I,C);y.stGranYCos=g.granYCos,y.stGranXCos=g.granXCos,y.stGranYSin=g.granYSin,y.stGranXSin=g.granXSin,y.stNwCorner=c,y.stWest=g.west,y.stSouth=g.south}return y};ro=iB});function h6(t,e){let i=new se({attributes:new we,primitiveType:ne.TRIANGLES});return i.attributes.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:e.positions}),t.normal&&(i.attributes.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:e.normals})),t.tangent&&(i.attributes.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:e.tangents})),t.bitangent&&(i.attributes.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:e.bitangents})),i}function _ft(t,e,i,n){let s=t.length,o=e.normal?new Float32Array(s):void 0,r=e.tangent?new Float32Array(s):void 0,a=e.bitangent?new Float32Array(s):void 0,h=0,A=a6,d=r6,f=o6;if(e.normal||e.tangent||e.bitangent)for(let E=0;E<s;E+=3){let _=l.fromArray(t,E,sB),R=h+1,I=h+2;f=i.geodeticSurfaceNormal(_,f),(e.tangent||e.bitangent)&&(l.cross(l.UNIT_Z,f,d),lt.multiplyByVector(n,d,d),l.normalize(d,d),e.bitangent&&l.normalize(l.cross(f,d,A),A)),e.normal&&(o[h]=f.x,o[R]=f.y,o[I]=f.z),e.tangent&&(r[h]=d.x,r[R]=d.y,r[I]=d.z),e.bitangent&&(a[h]=A.x,a[R]=A.y,a[I]=A.z),h+=3}return h6(e,{positions:t,normals:o,tangents:r,bitangents:a})}function Rft(t,e,i){let n=t.length,s=e.normal?new Float32Array(n):void 0,o=e.tangent?new Float32Array(n):void 0,r=e.bitangent?new Float32Array(n):void 0,a=0,h=0,A=0,d=!0,f=a6,E=r6,_=o6;if(e.normal||e.tangent||e.bitangent)for(let R=0;R<n;R+=6){let I=l.fromArray(t,R,sB),C=l.fromArray(t,(R+6)%n,oB);if(d){let N=l.fromArray(t,(R+3)%n,c6);l.subtract(C,I,C),l.subtract(N,I,N),_=l.normalize(l.cross(N,C,_),_),d=!1}l.equalsEpsilon(C,I,L.EPSILON10)&&(d=!0),(e.tangent||e.bitangent)&&(f=i.geodeticSurfaceNormal(I,f),e.tangent&&(E=l.normalize(l.cross(f,_,E),E))),e.normal&&(s[a++]=_.x,s[a++]=_.y,s[a++]=_.z,s[a++]=_.x,s[a++]=_.y,s[a++]=_.z),e.tangent&&(o[h++]=E.x,o[h++]=E.y,o[h++]=E.z,o[h++]=E.x,o[h++]=E.y,o[h++]=E.z),e.bitangent&&(r[A++]=f.x,r[A++]=f.y,r[A++]=f.z,r[A++]=f.x,r[A++]=f.y,r[A++]=f.z)}return h6(e,{positions:t,normals:s,tangents:o,bitangents:r})}function l6(t,e){let i=t._vertexFormat,n=t._ellipsoid,s=e.height,o=e.width,r=e.northCap,a=e.southCap,h=0,A=s,d=s,f=0;r&&(h=1,d-=1,f+=1),a&&(A-=1,d-=1,f+=1),f+=o*d;let E=i.position?new Float64Array(f*3):void 0,_=i.st?new Float32Array(f*2):void 0,R=0,I=0,C=sB,N=mft,T=Number.MAX_VALUE,b=Number.MAX_VALUE,F=-Number.MAX_VALUE,B=-Number.MAX_VALUE;for(let g=h;g<A;++g)for(let O=0;O<o;++O)ro.computePosition(e,n,i.st,g,O,C,N),E[R++]=C.x,E[R++]=C.y,E[R++]=C.z,i.st&&(_[I++]=N.x,_[I++]=N.y,T=Math.min(T,N.x),b=Math.min(b,N.y),F=Math.max(F,N.x),B=Math.max(B,N.y));if(r&&(ro.computePosition(e,n,i.st,0,0,C,N),E[R++]=C.x,E[R++]=C.y,E[R++]=C.z,i.st&&(_[I++]=N.x,_[I++]=N.y,T=N.x,b=N.y,F=N.x,B=N.y)),a&&(ro.computePosition(e,n,i.st,s-1,0,C,N),E[R++]=C.x,E[R++]=C.y,E[R]=C.z,i.st&&(_[I++]=N.x,_[I]=N.y,T=Math.min(T,N.x),b=Math.min(b,N.y),F=Math.max(F,N.x),B=Math.max(B,N.y))),i.st&&(T<0||b<0||F>1||B>1))for(let g=0;g<_.length;g+=2)_[g]=(_[g]-T)/(F-T),_[g+1]=(_[g+1]-b)/(B-b);let U=_ft(E,i,n,e.tangentRotationMatrix),Q=6*(o-1)*(d-1);r&&(Q+=3*(o-1)),a&&(Q+=3*(o-1));let M=te.createTypedArray(f,Q),k=0,y=0,c;for(c=0;c<d-1;++c){for(let g=0;g<o-1;++g){let O=k,D=O+o,w=D+1,x=O+1;M[y++]=O,M[y++]=D,M[y++]=x,M[y++]=x,M[y++]=D,M[y++]=w,++k}++k}if(r||a){let g=f-1,O=f-1;r&&a&&(g=f-2);let D,w;if(k=0,r)for(c=0;c<o-1;c++)D=k,w=D+1,M[y++]=g,M[y++]=D,M[y++]=w,++k;if(a)for(k=(d-1)*o,c=0;c<o-1;c++)D=k,w=D+1,M[y++]=D,M[y++]=O,M[y++]=w,++k}return U.indices=M,i.st&&(U.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:_})),U}function wf(t,e,i,n,s){return t[e++]=n[i],t[e++]=n[i+1],t[e++]=n[i+2],t[e++]=s[i],t[e++]=s[i+1],t[e]=s[i+2],t}function xf(t,e,i,n){return t[e++]=n[i],t[e++]=n[i+1],t[e++]=n[i],t[e]=n[i+1],t}function Zft(t,e){let i=t._shadowVolume,n=t._offsetAttribute,s=t._vertexFormat,o=t._extrudedHeight,r=t._surfaceHeight,a=t._ellipsoid,h=e.height,A=e.width,d;if(i){let Fe=St.clone(s,rB);Fe.normal=!0,t._vertexFormat=Fe}let f=l6(t,e);i&&(t._vertexFormat=s);let E=ui.scaleToGeodeticHeight(f.attributes.position.values,r,a,!1);E=new Float64Array(E);let _=E.length,R=_*2,I=new Float64Array(R);I.set(E);let C=ui.scaleToGeodeticHeight(f.attributes.position.values,o,a);I.set(C,_),f.attributes.position.values=I;let N=s.normal?new Float32Array(R):void 0,T=s.tangent?new Float32Array(R):void 0,b=s.bitangent?new Float32Array(R):void 0,F=s.st?new Float32Array(R/3*2):void 0,B,U;if(s.normal){for(U=f.attributes.normal.values,N.set(U),d=0;d<_;d++)U[d]=-U[d];N.set(U,_),f.attributes.normal.values=N}if(i){U=f.attributes.normal.values,s.normal||(f.attributes.normal=void 0);let Fe=new Float32Array(R);for(d=0;d<_;d++)U[d]=-U[d];Fe.set(U,_),f.attributes.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:Fe})}let Q,M=m(n);if(M){let Fe=_/3*2,ni=new Uint8Array(Fe);n===Pe.TOP?ni=ni.fill(1,0,Fe/2):(Q=n===Pe.NONE?0:1,ni=ni.fill(Q)),f.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:ni})}if(s.tangent){let Fe=f.attributes.tangent.values;for(T.set(Fe),d=0;d<_;d++)Fe[d]=-Fe[d];T.set(Fe,_),f.attributes.tangent.values=T}if(s.bitangent){let Fe=f.attributes.bitangent.values;b.set(Fe),b.set(Fe,_),f.attributes.bitangent.values=b}s.st&&(B=f.attributes.st.values,F.set(B),F.set(B,_/3*2),f.attributes.st.values=F);let k=f.indices,y=k.length,c=_/3,g=te.createTypedArray(R/3,y*2);for(g.set(k),d=0;d<y;d+=3)g[d+y]=k[d+2]+c,g[d+1+y]=k[d+1]+c,g[d+2+y]=k[d]+c;f.indices=g;let O=e.northCap,D=e.southCap,w=h,x=2,H=0,j=4,X=4;O&&(x-=1,w-=1,H+=1,j-=2,X-=1),D&&(x-=1,w-=1,H+=1,j-=2,X-=1),H+=x*A+2*w-j;let tt=(H+X)*2,G=new Float64Array(tt*3),It=i?new Float32Array(tt*3):void 0,gt=M?new Uint8Array(tt):void 0,Yt=s.st?new Float32Array(tt*2):void 0,Ut=n===Pe.TOP;M&&!Ut&&(Q=n===Pe.ALL?1:0,gt=gt.fill(Q));let Ct=0,zt=0,kt=0,Jt=0,Wt=A*w,bt;for(d=0;d<Wt;d+=A)bt=d*3,G=wf(G,Ct,bt,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,d*2,B),zt+=4),i&&(kt+=3,It[kt++]=U[bt],It[kt++]=U[bt+1],It[kt++]=U[bt+2]),Ut&&(gt[Jt++]=1,Jt+=1);if(D){let Fe=O?Wt+1:Wt;for(bt=Fe*3,d=0;d<2;d++)G=wf(G,Ct,bt,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,Fe*2,B),zt+=4),i&&(kt+=3,It[kt++]=U[bt],It[kt++]=U[bt+1],It[kt++]=U[bt+2]),Ut&&(gt[Jt++]=1,Jt+=1)}else for(d=Wt-A;d<Wt;d++)bt=d*3,G=wf(G,Ct,bt,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,d*2,B),zt+=4),i&&(kt+=3,It[kt++]=U[bt],It[kt++]=U[bt+1],It[kt++]=U[bt+2]),Ut&&(gt[Jt++]=1,Jt+=1);for(d=Wt-1;d>0;d-=A)bt=d*3,G=wf(G,Ct,bt,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,d*2,B),zt+=4),i&&(kt+=3,It[kt++]=U[bt],It[kt++]=U[bt+1],It[kt++]=U[bt+2]),Ut&&(gt[Jt++]=1,Jt+=1);if(O){let Fe=Wt;for(bt=Fe*3,d=0;d<2;d++)G=wf(G,Ct,bt,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,Fe*2,B),zt+=4),i&&(kt+=3,It[kt++]=U[bt],It[kt++]=U[bt+1],It[kt++]=U[bt+2]),Ut&&(gt[Jt++]=1,Jt+=1)}else for(d=A-1;d>=0;d--)bt=d*3,G=wf(G,Ct,bt,E,C),Ct+=6,s.st&&(Yt=xf(Yt,zt,d*2,B),zt+=4),i&&(kt+=3,It[kt++]=U[bt],It[kt++]=U[bt+1],It[kt++]=U[bt+2]),Ut&&(gt[Jt++]=1,Jt+=1);let ee=Rft(G,s,a);s.st&&(ee.attributes.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:Yt})),i&&(ee.attributes.extrudeDirection=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:It})),M&&(ee.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:gt}));let ce=te.createTypedArray(tt,H*6),je,Se,Ue,Me;_=G.length/3;let Ce=0;for(d=0;d<_-1;d+=2){je=d,Me=(je+2)%_;let Fe=l.fromArray(G,je*3,oB),ni=l.fromArray(G,Me*3,c6);l.equalsEpsilon(Fe,ni,L.EPSILON10)||(Se=(je+1)%_,Ue=(Se+2)%_,ce[Ce++]=je,ce[Ce++]=Se,ce[Ce++]=Me,ce[Ce++]=Me,ce[Ce++]=Se,ce[Ce++]=Ue)}return ee.indices=ce,ee=wi.combineInstances([new Ln({geometry:f}),new Ln({geometry:ee})]),ee[0]}function aB(t,e,i,n,s){if(i===0)return Xt.clone(t,s);let o=ro.computeOptions(t,e,i,0,A6,d6),r=o.height,a=o.width,h=Ift;return ro.computePosition(o,n,!1,0,0,h[0]),ro.computePosition(o,n,!1,0,a-1,h[1]),ro.computePosition(o,n,!1,r-1,0,h[2]),ro.computePosition(o,n,!1,r-1,a-1,h[3]),Xt.fromCartesianArray(h,n,s)}function WA(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.rectangle;if(p.typeOf.object("rectangle",e),Xt.validate(e),e.north<e.south)throw new Y("options.rectangle.north must be greater than or equal to options.rectangle.south");let i=Z(t.height,0),n=Z(t.extrudedHeight,i);this._rectangle=Xt.clone(e),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._ellipsoid=ot.clone(Z(t.ellipsoid,ot.WGS84)),this._surfaceHeight=Math.max(i,n),this._rotation=Z(t.rotation,0),this._stRotation=Z(t.stRotation,0),this._vertexFormat=St.clone(Z(t.vertexFormat,St.DEFAULT)),this._extrudedHeight=Math.min(i,n),this._shadowVolume=Z(t.shadowVolume,!1),this._workerName="createRectangleGeometry",this._offsetAttribute=t.offsetAttribute,this._rotatedRectangle=void 0,this._textureCoordinateRotationPoints=void 0}function Fft(t){if(t._stRotation===0)return[0,0,0,1,1,0];let e=Xt.clone(t._rectangle,s6),i=t._granularity,n=t._ellipsoid,s=t._rotation-t._stRotation,o=aB(e,i,s,n,s6),r=gft;r[0].x=o.west,r[0].y=o.south,r[1].x=o.west,r[1].y=o.north,r[2].x=o.east,r[2].y=o.south;let a=t.rectangle,h=Hn.fromRotation(t._stRotation,Tft),A=Xt.center(a,Nft);for(let R=0;R<3;++R){let I=r[R];I.x-=A.longitude,I.y-=A.latitude,Hn.multiplyByVector(h,I,I),I.x+=A.longitude,I.y+=A.latitude,I.x=(I.x-a.west)/a.width,I.y=(I.y-a.south)/a.height}let d=r[0],f=r[1],E=r[2],_=new Array(6);return nt.pack(d,_),nt.pack(f,_,2),nt.pack(E,_,4),_}var sB,o6,r6,a6,A6,mft,fft,Eft,oB,c6,rB,Ift,d6,pft,m6,f6,jc,uft,n6,Cft,s6,gft,Tft,Nft,AB,E6=S(()=>{_i();Xe();Ht();ri();ae();oi();Ft();mt();Ot();Oe();yi();ji();En();uA();go();gA();Di();_e();dc();dn();Pa();Xi();$s();pn();nB();Ls();sB=new l,o6=new l,r6=new l,a6=new l,A6=new Xt,mft=new nt,fft=new Nt,Eft=new Nt;oB=new l,c6=new l;rB=new St;Ift=[new l,new l,new l,new l],d6=new ut,pft=new ut;WA.packedLength=Xt.packedLength+ot.packedLength+St.packedLength+7;WA.pack=function(t,e,i){return p.typeOf.object("value",t),p.defined("array",e),i=Z(i,0),Xt.pack(t._rectangle,e,i),i+=Xt.packedLength,ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,St.pack(t._vertexFormat,e,i),i+=St.packedLength,e[i++]=t._granularity,e[i++]=t._surfaceHeight,e[i++]=t._rotation,e[i++]=t._stRotation,e[i++]=t._extrudedHeight,e[i++]=t._shadowVolume?1:0,e[i]=Z(t._offsetAttribute,-1),e};m6=new Xt,f6=ot.clone(ot.UNIT_SPHERE),jc={rectangle:m6,ellipsoid:f6,vertexFormat:rB,granularity:void 0,height:void 0,rotation:void 0,stRotation:void 0,extrudedHeight:void 0,shadowVolume:void 0,offsetAttribute:void 0};WA.unpack=function(t,e,i){p.defined("array",t),e=Z(e,0);let n=Xt.unpack(t,e,m6);e+=Xt.packedLength;let s=ot.unpack(t,e,f6);e+=ot.packedLength;let o=St.unpack(t,e,rB);e+=St.packedLength;let r=t[e++],a=t[e++],h=t[e++],A=t[e++],d=t[e++],f=t[e++]===1,E=t[e];return m(i)?(i._rectangle=Xt.clone(n,i._rectangle),i._ellipsoid=ot.clone(s,i._ellipsoid),i._vertexFormat=St.clone(o,i._vertexFormat),i._granularity=r,i._surfaceHeight=a,i._rotation=h,i._stRotation=A,i._extrudedHeight=d,i._shadowVolume=f,i._offsetAttribute=E===-1?void 0:E,i):(jc.granularity=r,jc.height=a,jc.rotation=h,jc.stRotation=A,jc.extrudedHeight=d,jc.shadowVolume=f,jc.offsetAttribute=E===-1?void 0:E,new WA(jc))};WA.computeRectangle=function(t,e){t=Z(t,Z.EMPTY_OBJECT);let i=t.rectangle;if(p.typeOf.object("rectangle",i),Xt.validate(i),i.north<i.south)throw new Y("options.rectangle.north must be greater than or equal to options.rectangle.south");let n=Z(t.granularity,L.RADIANS_PER_DEGREE),s=Z(t.ellipsoid,ot.WGS84),o=Z(t.rotation,0);return aB(i,n,o,s,e)};uft=new lt,n6=new Ae,Cft=new ut;WA.createGeometry=function(t){if(L.equalsEpsilon(t._rectangle.north,t._rectangle.south,L.EPSILON10)||L.equalsEpsilon(t._rectangle.east,t._rectangle.west,L.EPSILON10))return;let e=t._rectangle,i=t._ellipsoid,n=t._rotation,s=t._stRotation,o=t._vertexFormat,r=ro.computeOptions(e,t._granularity,n,s,A6,d6,pft),a=uft;if(s!==0||n!==0){let _=Xt.center(e,Cft),R=i.geodeticSurfaceNormalCartographic(_,oB);Ae.fromAxisAngle(R,-s,n6),lt.fromQuaternion(n6,a)}else lt.clone(lt.IDENTITY,a);let h=t._surfaceHeight,A=t._extrudedHeight,d=!L.equalsEpsilon(h,A,0,L.EPSILON2);r.lonScalar=1/t._rectangle.width,r.latScalar=1/t._rectangle.height,r.tangentRotationMatrix=a;let f,E;if(e=t._rectangle,d){f=Zft(t,r);let _=Nt.fromRectangle3D(e,i,h,Eft),R=Nt.fromRectangle3D(e,i,A,fft);E=Nt.union(_,R)}else{if(f=l6(t,r),f.attributes.position.values=ui.scaleToGeodeticHeight(f.attributes.position.values,h,i,!1),m(t._offsetAttribute)){let _=f.attributes.position.values.length,R=t._offsetAttribute===Pe.NONE?0:1,I=new Uint8Array(_/3).fill(R);f.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:I})}E=Nt.fromRectangle3D(e,i,h)}return o.position||delete f.attributes.position,new se({attributes:f.attributes,indices:f.indices,primitiveType:f.primitiveType,boundingSphere:E,offsetAttribute:t._offsetAttribute})};WA.createShadowVolume=function(t,e,i){let n=t._granularity,s=t._ellipsoid,o=e(n,s),r=i(n,s);return new WA({rectangle:t._rectangle,rotation:t._rotation,ellipsoid:s,stRotation:t._stRotation,granularity:n,extrudedHeight:r,height:o,vertexFormat:St.POSITION_ONLY,shadowVolume:!0})};s6=new Xt,gft=[new nt,new nt,new nt],Tft=new Hn,Nft=new ut;Object.defineProperties(WA.prototype,{rectangle:{get:function(){return m(this._rotatedRectangle)||(this._rotatedRectangle=aB(this._rectangle,this._granularity,this._rotation,this._ellipsoid)),this._rotatedRectangle}},textureCoordinateRotationPoints:{get:function(){return m(this._textureCoordinateRotationPoints)||(this._textureCoordinateRotationPoints=Fft(this)),this._textureCoordinateRotationPoints}}});AB=WA});var hB={};He(hB,{default:()=>Yft});function bft(t,e){return m(e)&&(t=AB.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),t._rectangle=Xt.clone(t._rectangle),AB.createGeometry(t)}var Yft,cB=S(()=>{mt();Oe();pn();E6();Yft=bft});function _6(t,e){let i=t._ellipsoid,n=e.height,s=e.width,o=e.northCap,r=e.southCap,a=n,h=2,A=0,d=4;o&&(h-=1,a-=1,A+=1,d-=2),r&&(h-=1,a-=1,A+=1,d-=2),A+=h*s+2*a-d;let f=new Float64Array(A*3),E=0,_=0,R,I=Oft;if(o)ro.computePosition(e,i,!1,_,0,I),f[E++]=I.x,f[E++]=I.y,f[E++]=I.z;else for(R=0;R<s;R++)ro.computePosition(e,i,!1,_,R,I),f[E++]=I.x,f[E++]=I.y,f[E++]=I.z;for(R=s-1,_=1;_<n;_++)ro.computePosition(e,i,!1,_,R,I),f[E++]=I.x,f[E++]=I.y,f[E++]=I.z;if(_=n-1,!r)for(R=s-2;R>=0;R--)ro.computePosition(e,i,!1,_,R,I),f[E++]=I.x,f[E++]=I.y,f[E++]=I.z;for(R=0,_=n-2;_>0;_--)ro.computePosition(e,i,!1,_,R,I),f[E++]=I.x,f[E++]=I.y,f[E++]=I.z;let C=f.length/3*2,N=te.createTypedArray(f.length/3,C),T=0;for(let F=0;F<f.length/3-1;F++)N[T++]=F,N[T++]=F+1;N[T++]=f.length/3-1,N[T++]=0;let b=new se({attributes:new we,primitiveType:ne.LINES});return b.attributes.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:f}),b.indices=N,b}function Gft(t,e){let i=t._surfaceHeight,n=t._extrudedHeight,s=t._ellipsoid,o=_6(t,e),r=e.height,a=e.width,h=ui.scaleToGeodeticHeight(o.attributes.position.values,i,s,!1),A=h.length,d=new Float64Array(A*2);d.set(h);let f=ui.scaleToGeodeticHeight(o.attributes.position.values,n,s);d.set(f,A),o.attributes.position.values=d;let E=e.northCap,_=e.southCap,R=4;E&&(R-=1),_&&(R-=1);let I=(d.length/3+R)*2,C=te.createTypedArray(d.length/3,I);A=d.length/6;let N=0;for(let b=0;b<A-1;b++)C[N++]=b,C[N++]=b+1,C[N++]=b+A,C[N++]=b+A+1;C[N++]=A-1,C[N++]=0,C[N++]=A+A-1,C[N++]=A,C[N++]=0,C[N++]=A;let T;if(E)T=r-1;else{let b=a-1;C[N++]=b,C[N++]=b+A,T=a+r-2}if(C[N++]=T,C[N++]=T+A,!_){let b=a+T-1;C[N++]=b,C[N]=b+A}return o.indices=C,o}function Jf(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.rectangle,i=Z(t.granularity,L.RADIANS_PER_DEGREE),n=Z(t.ellipsoid,ot.WGS84),s=Z(t.rotation,0);if(!m(e))throw new Y("rectangle is required.");if(Xt.validate(e),e.north<e.south)throw new Y("options.rectangle.north must be greater than options.rectangle.south");let o=Z(t.height,0),r=Z(t.extrudedHeight,o);this._rectangle=Xt.clone(e),this._granularity=i,this._ellipsoid=n,this._surfaceHeight=Math.max(o,r),this._rotation=s,this._extrudedHeight=Math.min(o,r),this._offsetAttribute=t.offsetAttribute,this._workerName="createRectangleOutlineGeometry"}var Vft,Sft,Oft,Bft,R6,Z6,Pf,Wft,lB,I6=S(()=>{_i();Ht();ri();oi();Ft();mt();Ot();Oe();yi();ji();En();go();Di();_e();Pa();Xi();pn();nB();Vft=new Nt,Sft=new Nt,Oft=new l,Bft=new Xt;Jf.packedLength=Xt.packedLength+ot.packedLength+5;Jf.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");return i=Z(i,0),Xt.pack(t._rectangle,e,i),i+=Xt.packedLength,ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._granularity,e[i++]=t._surfaceHeight,e[i++]=t._rotation,e[i++]=t._extrudedHeight,e[i]=Z(t._offsetAttribute,-1),e};R6=new Xt,Z6=ot.clone(ot.UNIT_SPHERE),Pf={rectangle:R6,ellipsoid:Z6,granularity:void 0,height:void 0,rotation:void 0,extrudedHeight:void 0,offsetAttribute:void 0};Jf.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n=Xt.unpack(t,e,R6);e+=Xt.packedLength;let s=ot.unpack(t,e,Z6);e+=ot.packedLength;let o=t[e++],r=t[e++],a=t[e++],h=t[e++],A=t[e];return m(i)?(i._rectangle=Xt.clone(n,i._rectangle),i._ellipsoid=ot.clone(s,i._ellipsoid),i._surfaceHeight=r,i._rotation=a,i._extrudedHeight=h,i._offsetAttribute=A===-1?void 0:A,i):(Pf.granularity=o,Pf.height=r,Pf.rotation=a,Pf.extrudedHeight=h,Pf.offsetAttribute=A===-1?void 0:A,new Jf(Pf))};Wft=new ut;Jf.createGeometry=function(t){let e=t._rectangle,i=t._ellipsoid,n=ro.computeOptions(e,t._granularity,t._rotation,0,Bft,Wft),s,o;if(L.equalsEpsilon(e.north,e.south,L.EPSILON10)||L.equalsEpsilon(e.east,e.west,L.EPSILON10))return;let r=t._surfaceHeight,a=t._extrudedHeight,h=!L.equalsEpsilon(r,a,0,L.EPSILON2),A;if(h){if(s=Gft(t,n),m(t._offsetAttribute)){let E=s.attributes.position.values.length/3,_=new Uint8Array(E);t._offsetAttribute===Pe.TOP?_=_.fill(1,0,E/2):(A=t._offsetAttribute===Pe.NONE?0:1,_=_.fill(A)),s.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:_})}let d=Nt.fromRectangle3D(e,i,r,Sft),f=Nt.fromRectangle3D(e,i,a,Vft);o=Nt.union(d,f)}else{if(s=_6(t,n),s.attributes.position.values=ui.scaleToGeodeticHeight(s.attributes.position.values,r,i,!1),m(t._offsetAttribute)){let d=s.attributes.position.values.length;A=t._offsetAttribute===Pe.NONE?0:1;let f=new Uint8Array(d/3).fill(A);s.attributes.applyOffset=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:1,values:f})}o=Nt.fromRectangle3D(e,i,r)}return new se({attributes:s.attributes,indices:s.indices,primitiveType:ne.LINES,boundingSphere:o,offsetAttribute:t._offsetAttribute})};lB=Jf});var dB={};He(dB,{default:()=>Uft});function Dft(t,e){return m(e)&&(t=lB.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),t._rectangle=Xt.clone(t._rectangle),lB.createGeometry(t)}var Uft,mB=S(()=>{mt();Oe();pn();I6();Uft=Dft});function Mft(t,e,i,n,s,o,r){let a=Sn.numberOfPoints(t,e,s),h,A=i.red,d=i.green,f=i.blue,E=i.alpha,_=n.red,R=n.green,I=n.blue,C=n.alpha;if(Zt.equals(i,n)){for(h=0;h<a;h++)o[r++]=Zt.floatToByte(A),o[r++]=Zt.floatToByte(d),o[r++]=Zt.floatToByte(f),o[r++]=Zt.floatToByte(E);return r}let N=(_-A)/a,T=(R-d)/a,b=(I-f)/a,F=(C-E)/a,B=r;for(h=0;h<a;h++)o[B++]=Zt.floatToByte(A+h*N),o[B++]=Zt.floatToByte(d+h*T),o[B++]=Zt.floatToByte(f+h*b),o[B++]=Zt.floatToByte(E+h*F);return B}function BR(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.colors,n=Z(t.colorsPerVertex,!1);if(!m(e)||e.length<2)throw new Y("At least two positions are required.");if(m(i)&&(n&&i.length<e.length||!n&&i.length<e.length-1))throw new Y("colors has an invalid length.");this._positions=e,this._colors=i,this._colorsPerVertex=n,this._arcType=Z(t.arcType,ti.GEODESIC),this._granularity=Z(t.granularity,L.RADIANS_PER_DEGREE),this._ellipsoid=Z(t.ellipsoid,ot.WGS84),this._workerName="createSimplePolylineGeometry";let s=1+e.length*l.packedLength;s+=m(i)?1+i.length*Zt.packedLength:1,this.packedLength=s+ot.packedLength+3}var fg,Eg,Qft,fB,p6=S(()=>{Gl();_i();Ht();Qn();oi();Ft();mt();Ot();Oe();yi();ji();En();Di();_e();Sf();Xi();BR.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._colors;for(o=m(r)?r.length:0,e[i++]=o,n=0;n<o;++n,i+=Zt.packedLength)Zt.pack(r[n],e,i);return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i++]=t._colorsPerVertex?1:0,e[i++]=t._arcType,e[i]=t._granularity,e};BR.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r=s>0?new Array(s):void 0;for(n=0;n<s;++n,e+=Zt.packedLength)r[n]=Zt.unpack(t,e);let a=ot.unpack(t,e);e+=ot.packedLength;let h=t[e++]===1,A=t[e++],d=t[e];return m(i)?(i._positions=o,i._colors=r,i._ellipsoid=a,i._colorsPerVertex=h,i._arcType=A,i._granularity=d,i):new BR({positions:o,colors:r,ellipsoid:a,colorsPerVertex:h,arcType:A,granularity:d})};fg=new Array(2),Eg=new Array(2),Qft={positions:fg,height:Eg,ellipsoid:void 0,minDistance:void 0,granularity:void 0};BR.createGeometry=function(t){let e=t._positions,i=t._colors,n=t._colorsPerVertex,s=t._arcType,o=t._granularity,r=t._ellipsoid,a=L.chordLength(o,r.maximumRadius),h=m(i)&&!n,A,d=e.length,f,E,_,R,I=0;if(s===ti.GEODESIC||s===ti.RHUMB){let F,B,U;s===ti.GEODESIC?(F=L.chordLength(o,r.maximumRadius),B=Sn.numberOfPoints,U=Sn.generateArc):(F=o,B=Sn.numberOfPointsRhumbLine,U=Sn.generateRhumbArc);let Q=Sn.extractHeights(e,r),M=Qft;if(s===ti.GEODESIC?M.minDistance=a:M.granularity=o,M.ellipsoid=r,h){let k=0;for(A=0;A<d-1;A++)k+=B(e[A],e[A+1],F)+1;f=new Float64Array(k*3),_=new Uint8Array(k*4),M.positions=fg,M.height=Eg;let y=0;for(A=0;A<d-1;++A){fg[0]=e[A],fg[1]=e[A+1],Eg[0]=Q[A],Eg[1]=Q[A+1];let c=U(M);if(m(i)){let g=c.length/3;R=i[A];for(let O=0;O<g;++O)_[y++]=Zt.floatToByte(R.red),_[y++]=Zt.floatToByte(R.green),_[y++]=Zt.floatToByte(R.blue),_[y++]=Zt.floatToByte(R.alpha)}f.set(c,I),I+=c.length}}else if(M.positions=e,M.height=Q,f=new Float64Array(U(M)),m(i)){for(_=new Uint8Array(f.length/3*4),A=0;A<d-1;++A){let y=e[A],c=e[A+1],g=i[A],O=i[A+1];I=Mft(y,c,g,O,a,_,I)}let k=i[d-1];_[I++]=Zt.floatToByte(k.red),_[I++]=Zt.floatToByte(k.green),_[I++]=Zt.floatToByte(k.blue),_[I++]=Zt.floatToByte(k.alpha)}}else{E=h?d*2-2:d,f=new Float64Array(E*3),_=m(i)?new Uint8Array(E*4):void 0;let F=0,B=0;for(A=0;A<d;++A){let U=e[A];if(h&&A>0&&(l.pack(U,f,F),F+=3,R=i[A-1],_[B++]=Zt.floatToByte(R.red),_[B++]=Zt.floatToByte(R.green),_[B++]=Zt.floatToByte(R.blue),_[B++]=Zt.floatToByte(R.alpha)),h&&A===d-1)break;l.pack(U,f,F),F+=3,m(i)&&(R=i[A],_[B++]=Zt.floatToByte(R.red),_[B++]=Zt.floatToByte(R.green),_[B++]=Zt.floatToByte(R.blue),_[B++]=Zt.floatToByte(R.alpha))}}let C=new we;C.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:f}),m(i)&&(C.color=new Tt({componentDatatype:At.UNSIGNED_BYTE,componentsPerAttribute:4,values:_,normalize:!0})),E=f.length/3;let N=(E-1)*2,T=te.createTypedArray(E,N),b=0;for(A=0;A<E-1;++A)T[b++]=A,T[b++]=A+1;return new se({attributes:C,indices:T,primitiveType:ne.LINES,boundingSphere:Nt.fromPoints(e)})};fB=BR});var EB={};He(EB,{default:()=>Lft});function kft(t,e){return m(e)&&(t=fB.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),fB.createGeometry(t)}var Lft,_B=S(()=>{mt();Oe();p6();Lft=kft});function jf(t){let e=Z(t.radius,1),n={radii:new l(e,e,e),stackPartitions:t.stackPartitions,slicePartitions:t.slicePartitions,vertexFormat:t.vertexFormat};this._ellipsoidGeometry=new Nr(n),this._workerName="createSphereGeometry"}var yft,Hc,RB,u6=S(()=>{Ht();ae();Ft();mt();sg();Ls();jf.packedLength=Nr.packedLength;jf.pack=function(t,e,i){return p.typeOf.object("value",t),Nr.pack(t._ellipsoidGeometry,e,i)};yft=new Nr,Hc={radius:void 0,radii:new l,vertexFormat:new St,stackPartitions:void 0,slicePartitions:void 0};jf.unpack=function(t,e,i){let n=Nr.unpack(t,e,yft);return Hc.vertexFormat=St.clone(n._vertexFormat,Hc.vertexFormat),Hc.stackPartitions=n._stackPartitions,Hc.slicePartitions=n._slicePartitions,m(i)?(l.clone(n._radii,Hc.radii),i._ellipsoidGeometry=new Nr(Hc),i):(Hc.radius=n._radii.x,new jf(Hc))};jf.createGeometry=function(t){return Nr.createGeometry(t._ellipsoidGeometry)};RB=jf});var ZB={};He(ZB,{default:()=>xft});function wft(t,e){return m(e)&&(t=RB.unpack(t,e)),RB.createGeometry(t)}var xft,IB=S(()=>{mt();u6();xft=wft});function Hf(t){let e=Z(t.radius,1),n={radii:new l(e,e,e),stackPartitions:t.stackPartitions,slicePartitions:t.slicePartitions,subdivisions:t.subdivisions};this._ellipsoidGeometry=new ja(n),this._workerName="createSphereOutlineGeometry"}var Pft,pd,pB,C6=S(()=>{Ht();ae();Ft();mt();ZO();Hf.packedLength=ja.packedLength;Hf.pack=function(t,e,i){return p.typeOf.object("value",t),ja.pack(t._ellipsoidGeometry,e,i)};Pft=new ja,pd={radius:void 0,radii:new l,stackPartitions:void 0,slicePartitions:void 0,subdivisions:void 0};Hf.unpack=function(t,e,i){let n=ja.unpack(t,e,Pft);return pd.stackPartitions=n._stackPartitions,pd.slicePartitions=n._slicePartitions,pd.subdivisions=n._subdivisions,m(i)?(l.clone(n._radii,pd.radii),i._ellipsoidGeometry=new ja(pd),i):(pd.radius=n._radii.x,new Hf(pd))};Hf.createGeometry=function(t){return ja.createGeometry(t._ellipsoidGeometry)};pB=Hf});var uB={};He(uB,{default:()=>jft});function Jft(t,e){return m(e)&&(t=pB.unpack(t,e)),pB.createGeometry(t)}var jft,CB=S(()=>{mt();C6();jft=Jft});var gB={};He(gB,{default:()=>dEt});function Kft(t,e,i,n,s,o,r){let a=t.length,h=new Float64Array(a*3);for(let A=0;A<a;++A){let d=t[A],f=e[A],E=i[A],_=L.lerp(n.west,n.east,d/GR),R=L.lerp(n.south,n.north,f/GR),I=L.lerp(s,o,E/GR),C=ut.fromRadians(_,R,I,vft),N=r.cartographicToCartesian(C,zft);l.pack(N,h,A*3)}return h}function Xft(t){let e=t.length,i=new Uint32Array(e+1),n=0;for(let s=0;s<e;++s)i[s]=n,n+=t[s];return i[e]=n,i}function tEt(t,e,i,n){let s=n.length,o=t.length,r=new Uint8Array(o),a=qft,h=$ft,A=0;for(let f=0;f<s;f++){let E=n[f],_=E;for(let R=1;R<E;R++){let I=A+R,C=I-1;h.longitude=t[I],h.latitude=e[I],a.longitude=t[C],a.latitude=e[C],ut.equals(h,a)&&(_--,r[C]=1)}n[f]=_,A+=E}let d=0;for(let f=0;f<o;f++)r[f]!==1&&(t[d]=t[f],e[d]=e[f],i[d]=i[f],d++)}function b6(t){let e=t*8,i=e*3,n=e*4;this.startEllipsoidNormals=new Float32Array(i),this.endEllipsoidNormals=new Float32Array(i),this.startPositionAndHeights=new Float32Array(n),this.startFaceNormalAndVertexCornerIds=new Float32Array(n),this.endPositionAndHeights=new Float32Array(n),this.endFaceNormalAndHalfWidths=new Float32Array(n),this.vertexBatchIds=new Uint16Array(e),this.indices=te.createTypedArray(e,36*t),this.vec3Offset=0,this.vec4Offset=0,this.batchIdOffset=0,this.indexOffset=0,this.volumeStartIndex=0}function T6(t,e,i,n,s){let o=l.subtract(i,e,eEt),r=l.subtract(e,t,g6);return l.normalize(o,o),l.normalize(r,r),l.dot(o,r)<Hft&&(r=l.multiplyByScalar(r,-1,g6)),l.add(o,r,s),l.equals(s,l.ZERO)&&(s=l.subtract(t,e)),l.cross(s,n,s),l.cross(n,s,s),l.normalize(s,s),s}function lEt(t,e){let i=new Uint16Array(t.positions),n=new Uint16Array(t.widths),s=new Uint32Array(t.counts),o=new Uint16Array(t.batchIds),r=rEt,a=aEt,h=AEt,A=new Float64Array(t.packedBuffer),d=0,f=A[d++],E=A[d++];Xt.unpack(A,d,r),d+=Xt.packedLength,ot.unpack(A,d,a),d+=ot.packedLength,l.unpack(A,d,h);let _,R=i.length/3,I=i.subarray(0,R),C=i.subarray(R,2*R),N=i.subarray(2*R,3*R);Yi.zigZagDeltaDecode(I,C,N),tEt(I,C,N,s);let T=s.length,b=0;for(_=0;_<T;_++){let c=s[_];b+=c-1}let F=new b6(b),B=Kft(I,C,N,r,f,E,a,h);R=I.length;let U=new Float32Array(R*3);for(_=0;_<R;++_)U[_*3]=B[_*3]-h.x,U[_*3+1]=B[_*3+1]-h.y,U[_*3+2]=B[_*3+2]-h.z;let Q=0,M=0;for(_=0;_<T;_++){let c=s[_]-1,g=n[_]*.5,O=o[_],D=Q;for(let w=0;w<c;w++){let x=l.unpack(U,Q,hEt),H=l.unpack(U,Q+3,cEt),j=N[M],X=N[M+1];j=L.lerp(f,E,j/GR),X=L.lerp(f,E,X/GR),M++;let tt=_g,G=Rg;if(w===0){let It=D+c*3,gt=l.unpack(U,It,_g);if(l.equals(gt,x))l.unpack(U,It-3,tt);else{let Yt=l.subtract(x,H,_g);tt=l.add(Yt,x,_g)}}else l.unpack(U,Q-3,tt);if(w===c-1){let It=l.unpack(U,D,Rg);if(l.equals(It,H))l.unpack(U,D+3,G);else{let gt=l.subtract(H,x,Rg);G=l.add(gt,H,Rg)}}else l.unpack(U,Q+6,G);F.addVolume(tt,x,H,G,j,X,g,O,h,a),Q+=3}Q+=3,M++}let k=F.indices;e.push(F.startEllipsoidNormals.buffer),e.push(F.endEllipsoidNormals.buffer),e.push(F.startPositionAndHeights.buffer),e.push(F.startFaceNormalAndVertexCornerIds.buffer),e.push(F.endPositionAndHeights.buffer),e.push(F.endFaceNormalAndHalfWidths.buffer),e.push(F.vertexBatchIds.buffer),e.push(k.buffer);let y={indexDatatype:k.BYTES_PER_ELEMENT===2?te.UNSIGNED_SHORT:te.UNSIGNED_INT,startEllipsoidNormals:F.startEllipsoidNormals.buffer,endEllipsoidNormals:F.endEllipsoidNormals.buffer,startPositionAndHeights:F.startPositionAndHeights.buffer,startFaceNormalAndVertexCornerIds:F.startFaceNormalAndVertexCornerIds.buffer,endPositionAndHeights:F.endPositionAndHeights.buffer,endFaceNormalAndHalfWidths:F.endFaceNormalAndHalfWidths.buffer,vertexBatchIds:F.vertexBatchIds.buffer,indices:k.buffer};if(t.keepDecodedPositions){let c=Xft(s);e.push(B.buffer,c.buffer),y=es(y,{decodedPositions:B.buffer,decodedPositionOffsets:c.buffer})}return y}var GR,Hft,vft,zft,qft,$ft,g6,eEt,Y6,N6,F6,iEt,nEt,sEt,oEt,rEt,aEt,AEt,_g,hEt,cEt,Rg,dEt,TB=S(()=>{oh();Ht();ri();KA();Oe();Di();_e();pn();Ns();GR=32767,Hft=Math.cos(L.toRadians(150)),vft=new ut,zft=new l;qft=new ut,$ft=new ut;g6=new l,eEt=new l;Y6=[0,2,6,0,6,4,0,1,3,0,3,2,0,4,5,0,5,1,5,3,1,5,7,3,7,5,4,7,4,6,7,6,2,7,2,3],N6=Y6.length,F6=new l,iEt=new l,nEt=new l,sEt=new l,oEt=new l;b6.prototype.addVolume=function(t,e,i,n,s,o,r,a,h,A){let d=l.add(e,h,F6),f=A.geodeticSurfaceNormal(d,iEt);d=l.add(i,h,F6);let E=A.geodeticSurfaceNormal(d,sEt),_=T6(t,e,i,f,nEt),R=T6(n,i,e,E,oEt),I=this.startEllipsoidNormals,C=this.endEllipsoidNormals,N=this.startPositionAndHeights,T=this.startFaceNormalAndVertexCornerIds,b=this.endPositionAndHeights,F=this.endFaceNormalAndHalfWidths,B=this.vertexBatchIds,U=this.batchIdOffset,Q=this.vec3Offset,M=this.vec4Offset,k;for(k=0;k<8;k++)l.pack(f,I,Q),l.pack(E,C,Q),l.pack(e,N,M),N[M+3]=s,l.pack(i,b,M),b[M+3]=o,l.pack(_,T,M),T[M+3]=k,l.pack(R,F,M),F[M+3]=r,B[U++]=a,Q+=3,M+=4;this.batchIdOffset=U,this.vec3Offset=Q,this.vec4Offset=M;let y=this.indices,c=this.volumeStartIndex,g=this.indexOffset;for(k=0;k<N6;k++)y[g+k]=Y6[k]+c;this.volumeStartIndex+=8,this.indexOffset+=N6};rEt=new Xt,aEt=new ot,AEt=new l,_g=new l,hEt=new l,cEt=new l,Rg=new l;dEt=Wi(lEt)});function mEt(t){this.offset=t.offset,this.count=t.count,this.color=t.color,this.batchIds=t.batchIds}var V6,S6=S(()=>{V6=mEt});var NB={};He(NB,{default:()=>bEt});function ZEt(t,e){let i=e*fEt,n=l.unpack(t,i,Ig);i+=l.packedLength;let s=at.unpack(t,i,na.modelMatrix);at.multiplyByScale(s,n,s);let o=na.boundingVolume;return l.clone(l.ZERO,o.center),o.radius=Math.sqrt(3),na}function IEt(t,e){let i=e*EEt,n=t[i++],s=t[i++],o=l.fromElements(n,n,s,Ig),r=at.unpack(t,i,na.modelMatrix);at.multiplyByScale(r,o,r);let a=na.boundingVolume;return l.clone(l.ZERO,a.center),a.radius=Math.sqrt(2),na}function pEt(t,e){let i=e*_Et,n=l.unpack(t,i,Ig);i+=l.packedLength;let s=at.unpack(t,i,na.modelMatrix);at.multiplyByScale(s,n,s);let o=na.boundingVolume;return l.clone(l.ZERO,o.center),o.radius=1,na}function uEt(t,e){let i=e*REt,n=t[i++],s=l.unpack(t,i,Ig),o=at.fromTranslation(s,na.modelMatrix);at.multiplyByUniformScale(o,n,o);let r=na.boundingVolume;return l.clone(l.ZERO,r.center),r.radius=1,na}function Zg(t,e,i,n,s){if(!m(e))return;let o=i.length,r=n.attributes.position.values,a=n.indices,h=t.positions,A=t.vertexBatchIds,d=t.indices,f=t.batchIds,E=t.batchTableColors,_=t.batchedIndices,R=t.indexOffsets,I=t.indexCounts,C=t.boundingVolumes,N=t.modelMatrix,T=t.center,b=t.positionOffset,F=t.batchIdIndex,B=t.indexOffset,U=t.batchedIndicesOffset;for(let Q=0;Q<o;++Q){let M=s(e,Q),k=M.modelMatrix;at.multiply(N,k,k);let y=i[Q],c=r.length;for(let D=0;D<c;D+=3){let w=l.unpack(r,D,CEt);at.multiplyByPoint(k,w,w),l.subtract(w,T,w),l.pack(w,h,b*3+D),A[F++]=y}let g=a.length;for(let D=0;D<g;++D)d[B+D]=a[D]+b;let O=Q+U;_[O]=new V6({offset:B,count:g,color:Zt.fromRgba(E[y]),batchIds:[y]}),f[O]=y,R[O]=B,I[O]=g,C[O]=Nt.transform(M.boundingVolume,k),b+=c/3,B+=g}t.positionOffset=b,t.batchIdIndex=F,t.indexOffset=B,t.batchedIndicesOffset+=o}function gEt(t){let e=new Float64Array(t),i=0;l.unpack(e,i,O6),i+=l.packedLength,at.unpack(e,i,B6)}function TEt(t){let e=t.length,i=0;for(let n=0;n<e;++n)i+=Zt.packedLength+3+t[n].batchIds.length;return i}function NEt(t,e,i){let n=i.length,s=2+n*Nt.packedLength+1+TEt(e),o=new Float64Array(s),r=0;o[r++]=t,o[r++]=n;for(let h=0;h<n;++h)Nt.pack(i[h],o,r),r+=Nt.packedLength;let a=e.length;o[r++]=a;for(let h=0;h<a;++h){let A=e[h];Zt.pack(A.color,o,r),r+=Zt.packedLength,o[r++]=A.offset,o[r++]=A.count;let d=A.batchIds,f=d.length;o[r++]=f;for(let E=0;E<f;++E)o[r++]=d[E]}return o}function FEt(t,e){let i=m(t.boxes)?new Float32Array(t.boxes):void 0,n=m(t.boxBatchIds)?new Uint16Array(t.boxBatchIds):void 0,s=m(t.cylinders)?new Float32Array(t.cylinders):void 0,o=m(t.cylinderBatchIds)?new Uint16Array(t.cylinderBatchIds):void 0,r=m(t.ellipsoids)?new Float32Array(t.ellipsoids):void 0,a=m(t.ellipsoidBatchIds)?new Uint16Array(t.ellipsoidBatchIds):void 0,h=m(t.spheres)?new Float32Array(t.spheres):void 0,A=m(t.sphereBatchIds)?new Uint16Array(t.sphereBatchIds):void 0,d=m(i)?n.length:0,f=m(s)?o.length:0,E=m(r)?a.length:0,_=m(h)?A.length:0,R=cR.getUnitBox(),I=gR.getUnitCylinder(),C=Nr.getUnitEllipsoid(),N=R.attributes.position.values,T=I.attributes.position.values,b=C.attributes.position.values,F=N.length*d;F+=T.length*f,F+=b.length*(E+_);let B=R.indices,U=I.indices,Q=C.indices,M=B.length*d;M+=U.length*f,M+=Q.length*(E+_);let k=new Float32Array(F),y=new Uint16Array(F/3),c=te.createTypedArray(F/3,M),g=d+f+E+_,O=new Uint16Array(g),D=new Array(g),w=new Uint32Array(g),x=new Uint32Array(g),H=new Array(g);gEt(t.packedBuffer);let j={batchTableColors:new Uint32Array(t.batchTableColors),positions:k,vertexBatchIds:y,indices:c,batchIds:O,batchedIndices:D,indexOffsets:w,indexCounts:x,boundingVolumes:H,positionOffset:0,batchIdIndex:0,indexOffset:0,batchedIndicesOffset:0,modelMatrix:B6,center:O6};Zg(j,i,n,R,ZEt),Zg(j,s,o,I,IEt),Zg(j,r,a,C,pEt),Zg(j,h,A,C,uEt);let X=NEt(c.BYTES_PER_ELEMENT,D,H);return e.push(k.buffer,y.buffer,c.buffer),e.push(O.buffer,w.buffer,x.buffer),e.push(X.buffer),{positions:k.buffer,vertexBatchIds:y.buffer,indices:c.buffer,indexOffsets:w.buffer,indexCounts:x.buffer,batchIds:O.buffer,packedBuffer:X.buffer}}var Ig,fEt,EEt,_Et,REt,na,CEt,O6,B6,bEt,FB=S(()=>{_i();sS();Ht();Qn();sO();mt();sg();Di();bi();S6();Ns();Ig=new l,fEt=at.packedLength+l.packedLength,EEt=at.packedLength+2,_Et=at.packedLength+l.packedLength,REt=l.packedLength+1,na={modelMatrix:new at,boundingVolume:new Nt};CEt=new l;O6=new l,B6=new at;bEt=Wi(FEt)});var YB={};He(YB,{default:()=>BEt});function SEt(t){t=new Float64Array(t);let e=0;pg.min=t[e++],pg.max=t[e++],Xt.unpack(t,e,G6),e+=Xt.packedLength,ot.unpack(t,e,W6)}function OEt(t,e){let i=new Uint16Array(t.positions);SEt(t.packedBuffer);let n=G6,s=W6,o=pg.min,r=pg.max,a=i.length/3,h=i.subarray(0,a),A=i.subarray(a,2*a),d=i.subarray(2*a,3*a);Yi.zigZagDeltaDecode(h,A,d);let f=new Float64Array(i.length);for(let E=0;E<a;++E){let _=h[E],R=A[E],I=d[E],C=L.lerp(n.west,n.east,_/bB),N=L.lerp(n.south,n.north,R/bB),T=L.lerp(o,r,I/bB),b=ut.fromRadians(C,N,T,YEt),F=s.cartographicToCartesian(b,VEt);l.pack(F,f,E*3)}return e.push(f.buffer),{positions:f.buffer}}var bB,YEt,VEt,G6,W6,pg,BEt,VB=S(()=>{oh();Ht();ri();Oe();_e();pn();Ns();bB=32767,YEt=new ut,VEt=new l,G6=new Xt,W6=new ot,pg={min:void 0,max:void 0};BEt=Wi(OEt)});var SB={};He(SB,{default:()=>wEt});function GEt(t){let e=new Float64Array(t),i=0;vf.indexBytesPerElement=e[i++],vf.min=e[i++],vf.max=e[i++],l.unpack(e,i,Q6),i+=l.packedLength,ot.unpack(e,i,k6),i+=ot.packedLength,Xt.unpack(e,i,L6)}function WEt(t){let e=t.length,i=0;for(let n=0;n<e;++n)i+=Zt.packedLength+3+t[n].batchIds.length;return i}function DEt(t,e,i){let n=e.length,s=2+n*zs.packedLength+1+WEt(i),o=new Float64Array(s),r=0;o[r++]=t,o[r++]=n;for(let h=0;h<n;++h)zs.pack(e[h],o,r),r+=zs.packedLength;let a=i.length;o[r++]=a;for(let h=0;h<a;++h){let A=i[h];Zt.pack(A.color,o,r),r+=Zt.packedLength,o[r++]=A.offset,o[r++]=A.count;let d=A.batchIds,f=d.length;o[r++]=f;for(let E=0;E<f;++E)o[r++]=d[E]}return o}function yEt(t,e){GEt(t.packedBuffer);let i;vf.indexBytesPerElement===2?i=new Uint16Array(t.indices):i=new Uint32Array(t.indices);let s=new Uint16Array(t.positions),o=new Uint32Array(t.counts),r=new Uint32Array(t.indexCounts),a=new Uint32Array(t.batchIds),h=new Uint32Array(t.batchTableColors),A=new Array(o.length),d=Q6,f=k6,E=L6,_=vf.min,R=vf.max,I=t.minimumHeights,C=t.maximumHeights;m(I)&&m(C)&&(I=new Float32Array(I),C=new Float32Array(C));let N,T,b,F=s.length/2,B=s.subarray(0,F),U=s.subarray(F,2*F);Yi.zigZagDeltaDecode(B,U);let Q=new Float64Array(F*3);for(N=0;N<F;++N){let Ct=B[N],zt=U[N],kt=L.lerp(E.west,E.east,Ct/D6),Jt=L.lerp(E.south,E.north,zt/D6),Wt=ut.fromRadians(kt,Jt,0,M6),bt=f.cartographicToCartesian(Wt,U6);l.pack(bt,Q,N*3)}let M=o.length,k=new Array(M),y=new Array(M),c=0,g=0;for(N=0;N<M;++N)k[N]=c,y[N]=g,c+=o[N],g+=r[N];let O=new Float32Array(F*3*2),D=new Uint16Array(F*2),w=new Uint32Array(y.length),x=new Uint32Array(r.length),H=[],j={};for(N=0;N<M;++N)b=h[N],m(j[b])?(j[b].positionLength+=o[N],j[b].indexLength+=r[N],j[b].batchIds.push(N)):j[b]={positionLength:o[N],indexLength:r[N],offset:0,indexOffset:0,batchIds:[N]};let X,tt=0,G=0;for(b in j)if(j.hasOwnProperty(b)){X=j[b],X.offset=tt,X.indexOffset=G;let Ct=X.positionLength*2,zt=X.indexLength*2+X.positionLength*6;tt+=Ct,G+=zt,X.indexLength=zt}let It=[];for(b in j)j.hasOwnProperty(b)&&(X=j[b],It.push({color:Zt.fromRgba(parseInt(b)),offset:X.indexOffset,count:X.indexLength,batchIds:X.batchIds}));for(N=0;N<M;++N){b=h[N],X=j[b];let Ct=X.offset,zt=Ct*3,kt=Ct,Jt=k[N],Wt=o[N],bt=a[N],ee=_,ce=R;m(I)&&m(C)&&(ee=I[N],ce=C[N]);let je=Number.POSITIVE_INFINITY,Se=Number.NEGATIVE_INFINITY,Ue=Number.POSITIVE_INFINITY,Me=Number.NEGATIVE_INFINITY;for(T=0;T<Wt;++T){let ze=l.unpack(Q,Jt*3+T*3,U6);f.scaleToGeodeticSurface(ze,ze);let Be=f.cartesianToCartographic(ze,M6),Mi=Be.latitude,Ri=Be.longitude;je=Math.min(Mi,je),Se=Math.max(Mi,Se),Ue=Math.min(Ri,Ue),Me=Math.max(Ri,Me);let si=f.geodeticSurfaceNormal(ze,UEt),qe=l.multiplyByScalar(si,ee,MEt),Oi=l.add(ze,qe,QEt);qe=l.multiplyByScalar(si,ce,qe);let gn=l.add(ze,qe,kEt);l.subtract(gn,d,gn),l.subtract(Oi,d,Oi),l.pack(gn,O,zt),l.pack(Oi,O,zt+3),D[kt]=bt,D[kt+1]=bt,zt+=6,kt+=2}E=LEt,E.west=Ue,E.east=Me,E.south=je,E.north=Se,A[N]=zs.fromRectangle(E,_,R,f);let Ce=X.indexOffset,Fe=y[N],ni=r[N];for(w[N]=Ce,T=0;T<ni;T+=3){let ze=i[Fe+T]-Jt,Be=i[Fe+T+1]-Jt,Mi=i[Fe+T+2]-Jt;H[Ce++]=ze*2+Ct,H[Ce++]=Be*2+Ct,H[Ce++]=Mi*2+Ct,H[Ce++]=Mi*2+1+Ct,H[Ce++]=Be*2+1+Ct,H[Ce++]=ze*2+1+Ct}for(T=0;T<Wt;++T){let ze=T,Be=(T+1)%Wt;H[Ce++]=ze*2+1+Ct,H[Ce++]=Be*2+Ct,H[Ce++]=ze*2+Ct,H[Ce++]=ze*2+1+Ct,H[Ce++]=Be*2+1+Ct,H[Ce++]=Be*2+Ct}X.offset+=Wt*2,X.indexOffset=Ce,x[N]=Ce-w[N]}H=te.createTypedArray(O.length/3,H);let gt=It.length;for(let Ct=0;Ct<gt;++Ct){let zt=It[Ct].batchIds,kt=0,Jt=zt.length;for(let Wt=0;Wt<Jt;++Wt)kt+=x[zt[Wt]];It[Ct].count=kt}let Yt=H.BYTES_PER_ELEMENT===2?te.UNSIGNED_SHORT:te.UNSIGNED_INT,Ut=DEt(Yt,A,It);return e.push(O.buffer,H.buffer,w.buffer,x.buffer,D.buffer,Ut.buffer),{positions:O.buffer,indices:H.buffer,indexOffsets:w.buffer,indexCounts:x.buffer,batchIds:D.buffer,packedBuffer:Ut.buffer}}var Q6,k6,L6,vf,D6,U6,UEt,MEt,QEt,kEt,M6,LEt,wEt,OB=S(()=>{oh();Ht();ri();Qn();mt();Oe();Di();_e();Jl();pn();Ns();Q6=new l,k6=new ot,L6=new Xt,vf={min:void 0,max:void 0,indexBytesPerElement:void 0};D6=32767,U6=new l,UEt=new l,MEt=new l,QEt=new l,kEt=new l,M6=new ut,LEt=new Xt;wEt=Wi(yEt)});function JEt(t,e,i,n,s){let o=t.length/3,r=t.subarray(0,o),a=t.subarray(o,2*o),h=t.subarray(2*o,3*o);Yi.zigZagDeltaDecode(r,a,h);let A=new Float64Array(t.length);for(let d=0;d<o;++d){let f=r[d],E=a[d],_=h[d],R=L.lerp(e.west,e.east,f/BB),I=L.lerp(e.south,e.north,E/BB),C=L.lerp(i,n,_/BB),N=ut.fromRadians(R,I,C,xEt),T=s.cartographicToCartesian(N,PEt);l.pack(T,A,d*3)}return A}var BB,xEt,PEt,y6,w6=S(()=>{oh();Ht();ri();_e();BB=32767,xEt=new ut,PEt=new l;y6=JEt});var GB={};He(GB,{default:()=>KEt});function jEt(t){t=new Float64Array(t);let e=0;ug.min=t[e++],ug.max=t[e++],Xt.unpack(t,e,H6),e+=Xt.packedLength,ot.unpack(t,e,v6),e+=ot.packedLength,l.unpack(t,e,z6)}function HEt(t){let e=t.length,i=new Uint32Array(e+1),n=0;for(let s=0;s<e;++s)i[s]=n,n+=t[s];return i[e]=n,i}function zEt(t,e){let i=new Uint16Array(t.positions),n=new Uint16Array(t.widths),s=new Uint32Array(t.counts),o=new Uint16Array(t.batchIds);jEt(t.packedBuffer);let r=H6,a=v6,h=z6,A=ug.min,d=ug.max,f=y6(i,r,A,d,a),E=f.length/3,_=E*4-4,R=new Float32Array(_*3),I=new Float32Array(_*3),C=new Float32Array(_*3),N=new Float32Array(_*2),T=new Uint16Array(_),b=0,F=0,B=0,U,Q=0,M=s.length;for(U=0;U<M;++U){let O=s[U],D=n[U],w=o[U];for(let x=0;x<O;++x){let H;if(x===0){let It=l.unpack(f,Q*3,x6),gt=l.unpack(f,(Q+1)*3,P6);H=l.subtract(It,gt,J6),l.add(It,H,H)}else H=l.unpack(f,(Q+x-1)*3,J6);let j=l.unpack(f,(Q+x)*3,vEt),X;if(x===O-1){let It=l.unpack(f,(Q+O-1)*3,x6),gt=l.unpack(f,(Q+O-2)*3,P6);X=l.subtract(It,gt,j6),l.add(It,X,X)}else X=l.unpack(f,(Q+x+1)*3,j6);l.subtract(H,h,H),l.subtract(j,h,j),l.subtract(X,h,X);let tt=x===0?2:0,G=x===O-1?2:4;for(let It=tt;It<G;++It){l.pack(j,R,b),l.pack(H,I,b),l.pack(X,C,b),b+=3;let gt=It-2<0?-1:1;N[F++]=2*(It%2)-1,N[F++]=gt*D,T[B++]=w}}Q+=O}let k=te.createTypedArray(_,E*6-6),y=0,c=0;for(M=E-1,U=0;U<M;++U)k[c++]=y,k[c++]=y+2,k[c++]=y+1,k[c++]=y+1,k[c++]=y+2,k[c++]=y+3,y+=4;e.push(R.buffer,I.buffer,C.buffer),e.push(N.buffer,T.buffer,k.buffer);let g={indexDatatype:k.BYTES_PER_ELEMENT===2?te.UNSIGNED_SHORT:te.UNSIGNED_INT,currentPositions:R.buffer,previousPositions:I.buffer,nextPositions:C.buffer,expandAndWidth:N.buffer,batchIds:T.buffer,indices:k.buffer};if(t.keepDecodedPositions){let O=HEt(s);e.push(f.buffer,O.buffer),g=es(g,{decodedPositions:f.buffer,decodedPositionOffsets:O.buffer})}return g}var H6,v6,z6,ug,x6,P6,J6,vEt,j6,KEt,WB=S(()=>{Ht();KA();w6();Oe();Di();pn();Ns();H6=new Xt,v6=new ot,z6=new l,ug={min:void 0,max:void 0};x6=new l,P6=new l,J6=new l,vEt=new l,j6=new l;KEt=Wi(zEt)});var XEt,sa,K6=S(()=>{XEt={NONE:0,BITS12:1},sa=Object.freeze(XEt)});function bo(t,e,i,n,s,o,r,a,h,A){let d=sa.NONE,f,E;if(m(e)&&m(i)&&m(n)&&m(s)){let _=e.minimum,R=e.maximum,I=l.subtract(R,_,qEt),C=n-i;Math.max(l.maximumComponent(I),C)<t_t-1?d=sa.BITS12:d=sa.NONE,f=at.inverseTransformation(s,new at);let T=l.negate(_,ud);at.multiply(at.fromTranslation(T,Cg),f,f);let b=ud;b.x=1/I.x,b.y=1/I.y,b.z=1/I.z,at.multiply(at.fromScale(b,Cg),f,f),E=at.clone(s),at.setTranslation(E,l.ZERO,E),s=at.clone(s,new at);let F=at.fromTranslation(_,Cg),B=at.fromScale(I,$Et),U=at.multiply(F,B,Cg);at.multiply(s,U,s),at.multiply(E,U,E)}this.quantization=d,this.minimumHeight=i,this.maximumHeight=n,this.center=l.clone(t),this.toScaledENU=f,this.fromScaledENU=s,this.matrix=E,this.hasVertexNormals=o,this.hasWebMercatorT=Z(r,!1),this.hasGeodeticSurfaceNormals=Z(a,!1),this.exaggeration=Z(h,1),this.exaggerationRelativeHeight=Z(A,0),this.stride=0,this._offsetGeodeticSurfaceNormal=0,this._offsetVertexNormal=0,this._calculateStrideAndOffsets()}var ud,qEt,oa,Cg,$Et,t_t,e_t,X6,gg,Tg,vc,WR=S(()=>{oh();Xe();Ht();oi();Ft();mt();_e();bi();hF();K6();ud=new l,qEt=new l,oa=new nt,Cg=new at,$Et=new at,t_t=Math.pow(2,12);bo.prototype.encode=function(t,e,i,n,s,o,r,a){let h=n.x,A=n.y;if(this.quantization===sa.BITS12){i=at.multiplyByPoint(this.toScaledENU,i,ud),i.x=L.clamp(i.x,0,1),i.y=L.clamp(i.y,0,1),i.z=L.clamp(i.z,0,1);let d=this.maximumHeight-this.minimumHeight,f=L.clamp((s-this.minimumHeight)/d,0,1);nt.fromElements(i.x,i.y,oa);let E=Yi.compressTextureCoordinates(oa);nt.fromElements(i.z,f,oa);let _=Yi.compressTextureCoordinates(oa);nt.fromElements(h,A,oa);let R=Yi.compressTextureCoordinates(oa);if(t[e++]=E,t[e++]=_,t[e++]=R,this.hasWebMercatorT){nt.fromElements(r,0,oa);let I=Yi.compressTextureCoordinates(oa);t[e++]=I}}else l.subtract(i,this.center,ud),t[e++]=ud.x,t[e++]=ud.y,t[e++]=ud.z,t[e++]=s,t[e++]=h,t[e++]=A,this.hasWebMercatorT&&(t[e++]=r);return this.hasVertexNormals&&(t[e++]=Yi.octPackFloat(o)),this.hasGeodeticSurfaceNormals&&(t[e++]=a.x,t[e++]=a.y,t[e++]=a.z),e};e_t=new l,X6=new l;bo.prototype.addGeodeticSurfaceNormals=function(t,e,i){if(this.hasGeodeticSurfaceNormals)return;let n=this.stride,s=t.length/n;this.hasGeodeticSurfaceNormals=!0,this._calculateStrideAndOffsets();let o=this.stride;for(let r=0;r<s;r++){for(let d=0;d<n;d++){let f=r*n+d,E=r*o+d;e[E]=t[f]}let a=this.decodePosition(e,r,e_t),h=i.geodeticSurfaceNormal(a,X6),A=r*o+this._offsetGeodeticSurfaceNormal;e[A]=h.x,e[A+1]=h.y,e[A+2]=h.z}};bo.prototype.removeGeodeticSurfaceNormals=function(t,e){if(!this.hasGeodeticSurfaceNormals)return;let i=this.stride,n=t.length/i;this.hasGeodeticSurfaceNormals=!1,this._calculateStrideAndOffsets();let s=this.stride;for(let o=0;o<n;o++)for(let r=0;r<s;r++){let a=o*i+r,h=o*s+r;e[h]=t[a]}};bo.prototype.decodePosition=function(t,e,i){if(m(i)||(i=new l),e*=this.stride,this.quantization===sa.BITS12){let n=Yi.decompressTextureCoordinates(t[e],oa);i.x=n.x,i.y=n.y;let s=Yi.decompressTextureCoordinates(t[e+1],oa);return i.z=s.x,at.multiplyByPoint(this.fromScaledENU,i,i)}return i.x=t[e],i.y=t[e+1],i.z=t[e+2],l.add(i,this.center,i)};bo.prototype.getExaggeratedPosition=function(t,e,i){i=this.decodePosition(t,e,i);let n=this.exaggeration,s=this.exaggerationRelativeHeight;if(n!==1&&this.hasGeodeticSurfaceNormals){let r=this.decodeGeodeticSurfaceNormal(t,e,X6),a=this.decodeHeight(t,e),h=A_.getHeight(a,n,s)-a;i.x+=r.x*h,i.y+=r.y*h,i.z+=r.z*h}return i};bo.prototype.decodeTextureCoordinates=function(t,e,i){return m(i)||(i=new nt),e*=this.stride,this.quantization===sa.BITS12?Yi.decompressTextureCoordinates(t[e+2],i):nt.fromElements(t[e+4],t[e+5],i)};bo.prototype.decodeHeight=function(t,e){return e*=this.stride,this.quantization===sa.BITS12?Yi.decompressTextureCoordinates(t[e+1],oa).y*(this.maximumHeight-this.minimumHeight)+this.minimumHeight:t[e+3]};bo.prototype.decodeWebMercatorT=function(t,e){return e*=this.stride,this.quantization===sa.BITS12?Yi.decompressTextureCoordinates(t[e+3],oa).x:t[e+6]};bo.prototype.getOctEncodedNormal=function(t,e,i){e=e*this.stride+this._offsetVertexNormal;let n=t[e]/256,s=Math.floor(n),o=(n-s)*256;return nt.fromElements(s,o,i)};bo.prototype.decodeGeodeticSurfaceNormal=function(t,e,i){return e=e*this.stride+this._offsetGeodeticSurfaceNormal,i.x=t[e],i.y=t[e+1],i.z=t[e+2],i};bo.prototype._calculateStrideAndOffsets=function(){let t=0;switch(this.quantization){case sa.BITS12:t+=3;break;default:t+=6}this.hasWebMercatorT&&(t+=1),this.hasVertexNormals&&(this._offsetVertexNormal=t,t+=1),this.hasGeodeticSurfaceNormals&&(this._offsetGeodeticSurfaceNormal=t,t+=3),this.stride=t};gg={position3DAndHeight:0,textureCoordAndEncodedNormals:1,geodeticSurfaceNormal:2},Tg={compressed0:0,compressed1:1,geodeticSurfaceNormal:2};bo.prototype.getAttributes=function(t){let e=At.FLOAT,i=At.getSizeInBytes(e),n=this.stride*i,s=0,o=[];function r(a,h){o.push({index:a,vertexBuffer:t,componentDatatype:e,componentsPerAttribute:h,offsetInBytes:s,strideInBytes:n}),s+=h*i}if(this.quantization===sa.NONE){r(gg.position3DAndHeight,4);let a=2;a+=this.hasWebMercatorT?1:0,a+=this.hasVertexNormals?1:0,r(gg.textureCoordAndEncodedNormals,a),this.hasGeodeticSurfaceNormals&&r(gg.geodeticSurfaceNormal,3)}else{let a=this.hasWebMercatorT||this.hasVertexNormals,h=this.hasWebMercatorT&&this.hasVertexNormals;r(Tg.compressed0,a?4:3),h&&r(Tg.compressed1,1),this.hasGeodeticSurfaceNormals&&r(Tg.geodeticSurfaceNormal,3)}return o};bo.prototype.getAttributeLocations=function(){return this.quantization===sa.NONE?gg:Tg};bo.clone=function(t,e){if(m(t))return m(e)||(e=new bo),e.quantization=t.quantization,e.minimumHeight=t.minimumHeight,e.maximumHeight=t.maximumHeight,e.center=l.clone(t.center),e.toScaledENU=at.clone(t.toScaledENU),e.fromScaledENU=at.clone(t.fromScaledENU),e.matrix=at.clone(t.matrix),e.hasVertexNormals=t.hasVertexNormals,e.hasWebMercatorT=t.hasWebMercatorT,e.hasGeodeticSurfaceNormals=t.hasGeodeticSurfaceNormals,e.exaggeration=t.exaggeration,e.exaggerationRelativeHeight=t.exaggerationRelativeHeight,e._calculateStrideAndOffsets(),e};vc=bo});var UB={};He(UB,{default:()=>h_t});function DR(t,e,i){i=Z(i,L);let n=t.length;for(let s=0;s<n;++s)if(i.equalsEpsilon(t[s],e,L.EPSILON12))return s;return-1}function s_t(t,e){t.ellipsoid=ot.clone(t.ellipsoid),t.rectangle=Xt.clone(t.rectangle);let i=A_t(t.buffer,t.relativeToCenter,t.ellipsoid,t.rectangle,t.nativeRectangle,t.exaggeration,t.exaggerationRelativeHeight,t.skirtHeight,t.includeWebMercatorT,t.negativeAltitudeExponentBias,t.negativeElevationThreshold),n=i.vertices;e.push(n.buffer);let s=i.indices;return e.push(s.buffer),{vertices:n.buffer,indices:s.buffer,numberOfAttributes:i.encoding.stride,minimumHeight:i.minimumHeight,maximumHeight:i.maximumHeight,boundingSphere3D:i.boundingSphere3D,orientedBoundingBox:i.orientedBoundingBox,occludeePointInScaledSpace:i.occludeePointInScaledSpace,encoding:i.encoding,vertexCountWithoutSkirts:i.vertexCountWithoutSkirts,indexCountWithoutSkirts:i.indexCountWithoutSkirts,westIndicesSouthToNorth:i.westIndicesSouthToNorth,southIndicesEastToWest:i.southIndicesEastToWest,eastIndicesNorthToSouth:i.eastIndicesNorthToSouth,northIndicesWestToEast:i.northIndicesWestToEast}}function A_t(t,e,i,n,s,o,r,a,h,A,d){let f,E,_,R,I,C;m(n)?(f=n.west,E=n.south,_=n.east,R=n.north,I=n.width,C=n.height):(f=L.toRadians(s.west),E=L.toRadians(s.south),_=L.toRadians(s.east),R=L.toRadians(s.north),I=L.toRadians(n.width),C=L.toRadians(n.height));let N=[E,R],T=[f,_],b=In.eastNorthUpToFixedFrame(e,i),F=at.inverseTransformation(b,a_t),B,U;h&&(B=ks.geodeticLatitudeToMercatorAngle(E),U=1/(ks.geodeticLatitudeToMercatorAngle(R)-B));let M=o!==1,k=new DataView(t),y=Number.POSITIVE_INFINITY,c=Number.NEGATIVE_INFINITY,g=o_t;g.x=Number.POSITIVE_INFINITY,g.y=Number.POSITIVE_INFINITY,g.z=Number.POSITIVE_INFINITY;let O=r_t;O.x=Number.NEGATIVE_INFINITY,O.y=Number.NEGATIVE_INFINITY,O.z=Number.NEGATIVE_INFINITY;let D=0,w=0,x=0,H,j;for(j=0;j<4;++j){let De=D;H=k.getUint32(De,!0),De+=DB;let Ye=L.toRadians(k.getFloat64(De,!0)*180);De+=Cd,DR(T,Ye)===-1&&T.push(Ye);let Gi=L.toRadians(k.getFloat64(De,!0)*180);De+=Cd,DR(N,Gi)===-1&&N.push(Gi),De+=2*Cd;let An=k.getInt32(De,!0);De+=Ng,w+=An,An=k.getInt32(De,!0),x+=An*3,D+=H+DB}let X=[],tt=[],G=new Array(w),It=new Array(w),gt=new Array(w),Yt=h?new Array(w):[],Ut=M?new Array(w):[],Ct=new Array(x),zt=[],kt=[],Jt=[],Wt=[],bt=0,ee=0;for(D=0,j=0;j<4;++j){H=k.getUint32(D,!0),D+=DB;let De=D,Ye=L.toRadians(k.getFloat64(D,!0)*180);D+=Cd;let Gi=L.toRadians(k.getFloat64(D,!0)*180);D+=Cd;let An=L.toRadians(k.getFloat64(D,!0)*180),Ne=An*.5;D+=Cd;let ei=L.toRadians(k.getFloat64(D,!0)*180),_n=ei*.5;D+=Cd;let hs=k.getInt32(D,!0);D+=Ng;let Qi=k.getInt32(D,!0);D+=Ng,D+=Ng;let nn=new Array(hs);for(let sn=0;sn<hs;++sn){let Cs=Ye+k.getUint8(D++)*An;Yo.longitude=Cs;let cs=Gi+k.getUint8(D++)*ei;Yo.latitude=cs;let xn=k.getFloat32(D,!0);if(D+=n_t,xn!==0&&xn<d&&(xn*=-Math.pow(2,A)),xn*=6371010,Yo.height=xn,DR(T,Cs)!==-1||DR(N,cs)!==-1){let Jn=DR(X,Yo,ut);if(Jn===-1)X.push(ut.clone(Yo)),tt.push(bt);else{nn[sn]=tt[Jn];continue}}nn[sn]=bt,Math.abs(Cs-f)<Ne?zt.push({index:bt,cartographic:ut.clone(Yo)}):Math.abs(Cs-_)<Ne?Jt.push({index:bt,cartographic:ut.clone(Yo)}):Math.abs(cs-E)<_n?kt.push({index:bt,cartographic:ut.clone(Yo)}):Math.abs(cs-R)<_n&&Wt.push({index:bt,cartographic:ut.clone(Yo)}),y=Math.min(xn,y),c=Math.max(xn,c),gt[bt]=xn;let Pn=i.cartographicToCartesian(Yo);if(G[bt]=Pn,h&&(Yt[bt]=(ks.geodeticLatitudeToMercatorAngle(cs)-B)*U),M){let Jn=i.geodeticSurfaceNormal(Pn);Ut[bt]=Jn}at.multiplyByPoint(F,Pn,zf),l.minimumByComponent(zf,g,g),l.maximumByComponent(zf,O,O);let Ai=(Cs-f)/(_-f);Ai=L.clamp(Ai,0,1);let Ci=(cs-E)/(R-E);Ci=L.clamp(Ci,0,1),It[bt]=new nt(Ai,Ci),++bt}let ki=Qi*3;for(let sn=0;sn<ki;++sn,++ee)Ct[ee]=nn[k.getUint16(D,!0)],D+=i_t;if(H!==D-De)throw new ke("Invalid terrain tile.")}G.length=bt,It.length=bt,gt.length=bt,h&&(Yt.length=bt),M&&(Ut.length=bt);let ce=bt,je=ee,Se={hMin:y,lastBorderPoint:void 0,skirtHeight:a,toENU:F,ellipsoid:i,minimum:g,maximum:O};zt.sort(function(De,Ye){return Ye.cartographic.latitude-De.cartographic.latitude}),kt.sort(function(De,Ye){return De.cartographic.longitude-Ye.cartographic.longitude}),Jt.sort(function(De,Ye){return De.cartographic.latitude-Ye.cartographic.latitude}),Wt.sort(function(De,Ye){return Ye.cartographic.longitude-De.cartographic.longitude});let Ue=1e-5;if(Fg(G,gt,It,Yt,Ut,Ct,Se,zt,-Ue*I,!0,-Ue*C),Fg(G,gt,It,Yt,Ut,Ct,Se,kt,-Ue*C,!1),Fg(G,gt,It,Yt,Ut,Ct,Se,Jt,Ue*I,!0,Ue*C),Fg(G,gt,It,Yt,Ut,Ct,Se,Wt,Ue*C,!1),zt.length>0&&Wt.length>0){let De=zt[0].index,Ye=ce,Gi=Wt[Wt.length-1].index,An=G.length-1;Ct.push(Gi,An,Ye,Ye,De,Gi)}w=G.length;let Me=Nt.fromPoints(G),Ce;m(n)&&(Ce=zs.fromRectangle(n,y,c,i));let ni=new dA(i).computeHorizonCullingPointPossiblyUnderEllipsoid(e,G,y),ze=new ph(g,O,e),Be=new vc(e,ze,Se.hMin,c,b,!1,h,M,o,r),Mi=new Float32Array(w*Be.stride),Ri=0;for(let De=0;De<w;++De)Ri=Be.encode(Mi,Ri,G[De],It[De],gt[De],void 0,Yt[De],Ut[De]);let si=zt.map(function(De){return De.index}).reverse(),qe=kt.map(function(De){return De.index}).reverse(),Oi=Jt.map(function(De){return De.index}).reverse(),gn=Wt.map(function(De){return De.index}).reverse();return qe.unshift(Oi[Oi.length-1]),qe.push(si[0]),gn.unshift(si[si.length-1]),gn.push(Oi[0]),{vertices:Mi,indices:new Uint16Array(Ct),maximumHeight:c,minimumHeight:y,encoding:Be,boundingSphere3D:Me,orientedBoundingBox:Ce,occludeePointInScaledSpace:ni,vertexCountWithoutSkirts:ce,indexCountWithoutSkirts:je,westIndicesSouthToNorth:si,southIndicesEastToWest:qe,eastIndicesNorthToSouth:Oi,northIndicesWestToEast:gn}}function Fg(t,e,i,n,s,o,r,a,h,A,d){let f=a.length;for(let E=0;E<f;++E){let _=a[E],R=_.cartographic,I=_.index,C=t.length,N=R.longitude,T=R.latitude;T=L.clamp(T,-L.PI_OVER_TWO,L.PI_OVER_TWO);let b=R.height-r.skirtHeight;r.hMin=Math.min(r.hMin,b),ut.fromRadians(N,T,b,Yo),A&&(Yo.longitude+=h),A?E===f-1?Yo.latitude+=d:E===0&&(Yo.latitude-=d):Yo.latitude+=h;let F=r.ellipsoid.cartographicToCartesian(Yo);t.push(F),e.push(b),i.push(nt.clone(i[I])),n.length>0&&n.push(n[I]),s.length>0&&s.push(s[I]),at.multiplyByPoint(r.toENU,F,zf);let B=r.minimum,U=r.maximum;l.minimumByComponent(zf,B,B),l.maximumByComponent(zf,U,U);let Q=r.lastBorderPoint;if(m(Q)){let M=Q.index;o.push(M,C-1,C,C,I,M)}r.lastBorderPoint=_}}var i_t,Ng,DB,n_t,Cd,Yo,zf,o_t,r_t,a_t,h_t,MB=S(()=>{a_();_i();Xe();Ht();ri();Ft();mt();Oe();Vm();_e();bi();Jl();pn();Ps();WR();fr();Ml();Ns();i_t=Uint16Array.BYTES_PER_ELEMENT,Ng=Int32Array.BYTES_PER_ELEMENT,DB=Uint32Array.BYTES_PER_ELEMENT,n_t=Float32Array.BYTES_PER_ELEMENT,Cd=Float64Array.BYTES_PER_ELEMENT;Yo=new ut,zf=new l,o_t=new l,r_t=new l,a_t=new at;h_t=Wi(s_t)});var c_t,q6,$6=S(()=>{c_t={NONE:0,LERC:1},q6=Object.freeze(c_t)});var DA,QB,l_t,d_t,m_t,tK,eK=S(()=>{a_();_i();Xe();Ht();Ft();mt();Ot();Oe();Vm();_e();bi();Jl();pn();WR();fr();Ml();DA={};DA.DEFAULT_STRUCTURE=Object.freeze({heightScale:1,heightOffset:0,elementsPerHeight:1,stride:1,elementMultiplier:256,isBigEndian:!1});QB=new l,l_t=new at,d_t=new l,m_t=new l;DA.computeVertices=function(t){if(!m(t)||!m(t.heightmap))throw new Y("options.heightmap is required.");if(!m(t.width)||!m(t.height))throw new Y("options.width and options.height are required.");if(!m(t.nativeRectangle))throw new Y("options.nativeRectangle is required.");if(!m(t.skirtHeight))throw new Y("options.skirtHeight is required.");let e=Math.cos,i=Math.sin,n=Math.sqrt,s=Math.atan,o=Math.exp,r=L.PI_OVER_TWO,a=L.toRadians,h=t.heightmap,A=t.width,d=t.height,f=t.skirtHeight,E=f>0,_=Z(t.isGeographic,!0),R=Z(t.ellipsoid,ot.WGS84),I=1/R.maximumRadius,C=Xt.clone(t.nativeRectangle),N=Xt.clone(t.rectangle),T,b,F,B;m(N)?(T=N.west,b=N.south,F=N.east,B=N.north):_?(T=a(C.west),b=a(C.south),F=a(C.east),B=a(C.north)):(T=C.west*I,b=r-2*s(o(-C.south*I)),F=C.east*I,B=r-2*s(o(-C.north*I)));let U=t.relativeToCenter,Q=m(U);U=Q?U:l.ZERO;let M=Z(t.includeWebMercatorT,!1),k=Z(t.exaggeration,1),y=Z(t.exaggerationRelativeHeight,0),g=k!==1,O=Z(t.structure,DA.DEFAULT_STRUCTURE),D=Z(O.heightScale,DA.DEFAULT_STRUCTURE.heightScale),w=Z(O.heightOffset,DA.DEFAULT_STRUCTURE.heightOffset),x=Z(O.elementsPerHeight,DA.DEFAULT_STRUCTURE.elementsPerHeight),H=Z(O.stride,DA.DEFAULT_STRUCTURE.stride),j=Z(O.elementMultiplier,DA.DEFAULT_STRUCTURE.elementMultiplier),X=Z(O.isBigEndian,DA.DEFAULT_STRUCTURE.isBigEndian),tt=Xt.computeWidth(C),G=Xt.computeHeight(C),It=tt/(A-1),gt=G/(d-1);_||(tt*=I,G*=I);let Yt=R.radiiSquared,Ut=Yt.x,Ct=Yt.y,zt=Yt.z,kt=65536,Jt=-65536,Wt=In.eastNorthUpToFixedFrame(U,R),bt=at.inverseTransformation(Wt,l_t),ee,ce;M&&(ee=ks.geodeticLatitudeToMercatorAngle(b),ce=1/(ks.geodeticLatitudeToMercatorAngle(B)-ee));let je=d_t;je.x=Number.POSITIVE_INFINITY,je.y=Number.POSITIVE_INFINITY,je.z=Number.POSITIVE_INFINITY;let Se=m_t;Se.x=Number.NEGATIVE_INFINITY,Se.y=Number.NEGATIVE_INFINITY,Se.z=Number.NEGATIVE_INFINITY;let Ue=Number.POSITIVE_INFINITY,Me=A*d,Ce=f>0?A*2+d*2:0,Fe=Me+Ce,ni=new Array(Fe),ze=new Array(Fe),Be=new Array(Fe),Mi=M?new Array(Fe):[],Ri=g?new Array(Fe):[],si=0,qe=d,Oi=0,gn=A;E&&(--si,++qe,--Oi,++gn);let De=1e-5;for(let Qi=si;Qi<qe;++Qi){let nn=Qi;nn<0&&(nn=0),nn>=d&&(nn=d-1);let ki=C.north-gt*nn;_?ki=a(ki):ki=r-2*s(o(-ki*I));let sn=(ki-b)/(B-b);sn=L.clamp(sn,0,1);let Cs=Qi===si,cs=Qi===qe-1;f>0&&(Cs?ki+=De*G:cs&&(ki-=De*G));let xn=e(ki),Pn=i(ki),Ai=zt*Pn,Ci;M&&(Ci=(ks.geodeticLatitudeToMercatorAngle(ki)-ee)*ce);for(let Jn=Oi;Jn<gn;++Jn){let ls=Jn;ls<0&&(ls=0),ls>=A&&(ls=A-1);let ao=nn*(A*H)+ls*H,qi;if(x===1)qi=h[ao];else{qi=0;let Tn;if(X)for(Tn=0;Tn<x;++Tn)qi=qi*j+h[ao+Tn];else for(Tn=x-1;Tn>=0;--Tn)qi=qi*j+h[ao+Tn]}qi=qi*D+w,Jt=Math.max(Jt,qi),kt=Math.min(kt,qi);let hn=C.west+It*ls;_?hn=a(hn):hn=hn*I;let jo=(hn-T)/(F-T);jo=L.clamp(jo,0,1);let ds=nn*A+ls;if(f>0){let Tn=Jn===Oi,hr=Jn===gn-1,Uh=Cs||cs||Tn||hr;if((Cs||cs)&&(Tn||hr))continue;Uh&&(qi-=f,Tn?(ds=Me+(d-nn-1),hn-=De*tt):cs?ds=Me+d+(A-ls-1):hr?(ds=Me+d+A+nn,hn+=De*tt):Cs&&(ds=Me+d+A+d+ls))}let on=xn*e(hn),ws=xn*i(hn),Vo=Ut*on,br=Ct*ws,$e=1/n(Vo*on+br*ws+Ai*Pn),aa=Vo*$e,Yr=br*$e,xs=Ai*$e,gs=new l;gs.x=aa+on*qi,gs.y=Yr+ws*qi,gs.z=xs+Pn*qi,at.multiplyByPoint(bt,gs,QB),l.minimumByComponent(QB,je,je),l.maximumByComponent(QB,Se,Se),Ue=Math.min(Ue,qi),ni[ds]=gs,Be[ds]=new nt(jo,sn),ze[ds]=qi,M&&(Mi[ds]=Ci),g&&(Ri[ds]=R.geodeticSurfaceNormal(gs))}}let Ye=Nt.fromPoints(ni),Gi;m(N)&&(Gi=zs.fromRectangle(N,kt,Jt,R));let An;Q&&(An=new dA(R).computeHorizonCullingPointPossiblyUnderEllipsoid(U,ni,kt));let Ne=new ph(je,Se,U),ei=new vc(U,Ne,Ue,Jt,Wt,!1,M,g,k,y),_n=new Float32Array(Fe*ei.stride),hs=0;for(let Qi=0;Qi<Fe;++Qi)hs=ei.encode(_n,hs,ni[Qi],Be[Qi],ze[Qi],void 0,Mi[Qi],Ri[Qi]);return{vertices:_n,maximumHeight:Jt,minimumHeight:kt,encoding:ei,boundingSphere3D:Ye,orientedBoundingBox:Gi,occludeePointInScaledSpace:An}};tK=DA});var iK=ts((AVe,bg)=>{/* Copyright 2015-2018 Esri. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 @preserve */(function(){var t=function(){var s={};s.defaultNoDataValue=-34027999387901484e22,s.decode=function(d,f){f=f||{};var E=f.encodedMaskData||f.encodedMaskData===null,_=h(d,f.inputOffset||0,E),R=f.noDataValue!==null?f.noDataValue:s.defaultNoDataValue,I=o(_,f.pixelType||Float32Array,f.encodedMaskData,R,f.returnMask),C={width:_.width,height:_.height,pixelData:I.resultPixels,minValue:I.minValue,maxValue:_.pixels.maxValue,noDataValue:R};return I.resultMask&&(C.maskData=I.resultMask),f.returnEncodedMask&&_.mask&&(C.encodedMaskData=_.mask.bitset?_.mask.bitset:null),f.returnFileInfo&&(C.fileInfo=r(_),f.computeUsedBitDepths&&(C.fileInfo.bitDepths=a(_))),C};var o=function(d,f,E,_,R){var I=0,C=d.pixels.numBlocksX,N=d.pixels.numBlocksY,T=Math.floor(d.width/C),b=Math.floor(d.height/N),F=2*d.maxZError,B=Number.MAX_VALUE,U;E=E||(d.mask?d.mask.bitset:null);var Q,M;Q=new f(d.width*d.height),R&&E&&(M=new Uint8Array(d.width*d.height));for(var k=new Float32Array(T*b),y,c,g=0;g<=N;g++){var O=g!==N?b:d.height%N;if(O!==0)for(var D=0;D<=C;D++){var w=D!==C?T:d.width%C;if(w!==0){var x=g*d.width*b+D*T,H=d.width-w,j=d.pixels.blocks[I],X,tt,G;j.encoding<2?(j.encoding===0?X=j.rawData:(A(j.stuffedData,j.bitsPerPixel,j.numValidPixels,j.offset,F,k,d.pixels.maxValue),X=k),tt=0):j.encoding===2?G=0:G=j.offset;var It;if(E)for(c=0;c<O;c++){for(x&7&&(It=E[x>>3],It<<=x&7),y=0;y<w;y++)x&7||(It=E[x>>3]),It&128?(M&&(M[x]=1),U=j.encoding<2?X[tt++]:G,B=B>U?U:B,Q[x++]=U):(M&&(M[x]=0),Q[x++]=_),It<<=1;x+=H}else if(j.encoding<2)for(c=0;c<O;c++){for(y=0;y<w;y++)U=X[tt++],B=B>U?U:B,Q[x++]=U;x+=H}else for(B=B>G?G:B,c=0;c<O;c++){for(y=0;y<w;y++)Q[x++]=G;x+=H}if(j.encoding===1&&tt!==j.numValidPixels)throw"Block and Mask do not match";I++}}}return{resultPixels:Q,resultMask:M,minValue:B}},r=function(d){return{fileIdentifierString:d.fileIdentifierString,fileVersion:d.fileVersion,imageType:d.imageType,height:d.height,width:d.width,maxZError:d.maxZError,eofOffset:d.eofOffset,mask:d.mask?{numBlocksX:d.mask.numBlocksX,numBlocksY:d.mask.numBlocksY,numBytes:d.mask.numBytes,maxValue:d.mask.maxValue}:null,pixels:{numBlocksX:d.pixels.numBlocksX,numBlocksY:d.pixels.numBlocksY,numBytes:d.pixels.numBytes,maxValue:d.pixels.maxValue,noDataValue:d.noDataValue}}},a=function(d){for(var f=d.pixels.numBlocksX*d.pixels.numBlocksY,E={},_=0;_<f;_++){var R=d.pixels.blocks[_];R.encoding===0?E.float32=!0:R.encoding===1?E[R.bitsPerPixel]=!0:E[0]=!0}return Object.keys(E)},h=function(d,f,E){var _={},R=new Uint8Array(d,f,10);if(_.fileIdentifierString=String.fromCharCode.apply(null,R),_.fileIdentifierString.trim()!=="CntZImage")throw"Unexpected file identifier string: "+_.fileIdentifierString;f+=10;var I=new DataView(d,f,24);if(_.fileVersion=I.getInt32(0,!0),_.imageType=I.getInt32(4,!0),_.height=I.getUint32(8,!0),_.width=I.getUint32(12,!0),_.maxZError=I.getFloat64(16,!0),f+=24,!E)if(I=new DataView(d,f,16),_.mask={},_.mask.numBlocksY=I.getUint32(0,!0),_.mask.numBlocksX=I.getUint32(4,!0),_.mask.numBytes=I.getUint32(8,!0),_.mask.maxValue=I.getFloat32(12,!0),f+=16,_.mask.numBytes>0){var C=new Uint8Array(Math.ceil(_.width*_.height/8));I=new DataView(d,f,_.mask.numBytes);var N=I.getInt16(0,!0),T=2,b=0;do{if(N>0)for(;N--;)C[b++]=I.getUint8(T++);else{var F=I.getUint8(T++);for(N=-N;N--;)C[b++]=F}N=I.getInt16(T,!0),T+=2}while(T<_.mask.numBytes);if(N!==-32768||b<C.length)throw"Unexpected end of mask RLE encoding";_.mask.bitset=C,f+=_.mask.numBytes}else _.mask.numBytes|_.mask.numBlocksY|_.mask.maxValue||(_.mask.bitset=new Uint8Array(Math.ceil(_.width*_.height/8)));I=new DataView(d,f,16),_.pixels={},_.pixels.numBlocksY=I.getUint32(0,!0),_.pixels.numBlocksX=I.getUint32(4,!0),_.pixels.numBytes=I.getUint32(8,!0),_.pixels.maxValue=I.getFloat32(12,!0),f+=16;var B=_.pixels.numBlocksX,U=_.pixels.numBlocksY,Q=B+(_.width%B>0?1:0),M=U+(_.height%U>0?1:0);_.pixels.blocks=new Array(Q*M);for(var k=0,y=0;y<M;y++)for(var c=0;c<Q;c++){var g=0,O=d.byteLength-f;I=new DataView(d,f,Math.min(10,O));var D={};_.pixels.blocks[k++]=D;var w=I.getUint8(0);if(g++,D.encoding=w&63,D.encoding>3)throw"Invalid block encoding ("+D.encoding+")";if(D.encoding===2){f++;continue}if(w!==0&&w!==2){if(w>>=6,D.offsetType=w,w===2)D.offset=I.getInt8(1),g++;else if(w===1)D.offset=I.getInt16(1,!0),g+=2;else if(w===0)D.offset=I.getFloat32(1,!0),g+=4;else throw"Invalid block offset type";if(D.encoding===1)if(w=I.getUint8(g),g++,D.bitsPerPixel=w&63,w>>=6,D.numValidPixelsType=w,w===2)D.numValidPixels=I.getUint8(g),g++;else if(w===1)D.numValidPixels=I.getUint16(g,!0),g+=2;else if(w===0)D.numValidPixels=I.getUint32(g,!0),g+=4;else throw"Invalid valid pixel count type"}if(f+=g,D.encoding!==3){var x,H;if(D.encoding===0){var j=(_.pixels.numBytes-1)/4;if(j!==Math.floor(j))throw"uncompressed block has invalid length";x=new ArrayBuffer(j*4),H=new Uint8Array(x),H.set(new Uint8Array(d,f,j*4));var X=new Float32Array(x);D.rawData=X,f+=j*4}else if(D.encoding===1){var tt=Math.ceil(D.numValidPixels*D.bitsPerPixel/8),G=Math.ceil(tt/4);x=new ArrayBuffer(G*4),H=new Uint8Array(x),H.set(new Uint8Array(d,f,tt)),D.stuffedData=new Uint32Array(x),f+=tt}}}return _.eofOffset=f,_},A=function(d,f,E,_,R,I,C){var N=(1<<f)-1,T=0,b,F=0,B,U,Q=Math.ceil((C-_)/R),M=d.length*4-Math.ceil(f*E/8);for(d[d.length-1]<<=8*M,b=0;b<E;b++){if(F===0&&(U=d[T++],F=32),F>=f)B=U>>>F-f&N,F-=f;else{var k=f-F;B=(U&N)<<k&N,U=d[T++],F=32-k,B+=U>>>F}I[b]=B<Q?_+B*R:C}return I};return s}(),e=function(){"use strict";var s={unstuff:function(h,A,d,f,E,_,R,I){var C=(1<<d)-1,N=0,T,b=0,F,B,U,Q,M=h.length*4-Math.ceil(d*f/8);if(h[h.length-1]<<=8*M,E)for(T=0;T<f;T++)b===0&&(B=h[N++],b=32),b>=d?(F=B>>>b-d&C,b-=d):(U=d-b,F=(B&C)<<U&C,B=h[N++],b=32-U,F+=B>>>b),A[T]=E[F];else for(Q=Math.ceil((I-_)/R),T=0;T<f;T++)b===0&&(B=h[N++],b=32),b>=d?(F=B>>>b-d&C,b-=d):(U=d-b,F=(B&C)<<U&C,B=h[N++],b=32-U,F+=B>>>b),A[T]=F<Q?_+F*R:I},unstuffLUT:function(h,A,d,f,E,_){var R=(1<<A)-1,I=0,C=0,N=0,T=0,b=0,F,B=[],U=h.length*4-Math.ceil(A*d/8);h[h.length-1]<<=8*U;var Q=Math.ceil((_-f)/E);for(C=0;C<d;C++)T===0&&(F=h[I++],T=32),T>=A?(b=F>>>T-A&R,T-=A):(N=A-T,b=(F&R)<<N&R,F=h[I++],T=32-N,b+=F>>>T),B[C]=b<Q?f+b*E:_;return B.unshift(f),B},unstuff2:function(h,A,d,f,E,_,R,I){var C=(1<<d)-1,N=0,T,b=0,F=0,B,U,Q;if(E)for(T=0;T<f;T++)b===0&&(U=h[N++],b=32,F=0),b>=d?(B=U>>>F&C,b-=d,F+=d):(Q=d-b,B=U>>>F&C,U=h[N++],b=32-Q,B|=(U&(1<<Q)-1)<<d-Q,F=Q),A[T]=E[B];else{var M=Math.ceil((I-_)/R);for(T=0;T<f;T++)b===0&&(U=h[N++],b=32,F=0),b>=d?(B=U>>>F&C,b-=d,F+=d):(Q=d-b,B=U>>>F&C,U=h[N++],b=32-Q,B|=(U&(1<<Q)-1)<<d-Q,F=Q),A[T]=B<M?_+B*R:I}return A},unstuffLUT2:function(h,A,d,f,E,_){var R=(1<<A)-1,I=0,C=0,N=0,T=0,b=0,F=0,B,U=[],Q=Math.ceil((_-f)/E);for(C=0;C<d;C++)T===0&&(B=h[I++],T=32,F=0),T>=A?(b=B>>>F&R,T-=A,F+=A):(N=A-T,b=B>>>F&R,B=h[I++],T=32-N,b|=(B&(1<<N)-1)<<A-N,F=N),U[C]=b<Q?f+b*E:_;return U.unshift(f),U},originalUnstuff:function(h,A,d,f){var E=(1<<d)-1,_=0,R,I=0,C,N,T,b=h.length*4-Math.ceil(d*f/8);for(h[h.length-1]<<=8*b,R=0;R<f;R++)I===0&&(N=h[_++],I=32),I>=d?(C=N>>>I-d&E,I-=d):(T=d-I,C=(N&E)<<T&E,N=h[_++],I=32-T,C+=N>>>I),A[R]=C;return A},originalUnstuff2:function(h,A,d,f){var E=(1<<d)-1,_=0,R,I=0,C=0,N,T,b;for(R=0;R<f;R++)I===0&&(T=h[_++],I=32,C=0),I>=d?(N=T>>>C&E,I-=d,C+=d):(b=d-I,N=T>>>C&E,T=h[_++],I=32-b,N|=(T&(1<<b)-1)<<d-b,C=b),A[R]=N;return A}},o={HUFFMAN_LUT_BITS_MAX:12,computeChecksumFletcher32:function(h){for(var A=65535,d=65535,f=h.length,E=Math.floor(f/2),_=0;E;){var R=E>=359?359:E;E-=R;do A+=h[_++]<<8,d+=A+=h[_++];while(--R);A=(A&65535)+(A>>>16),d=(d&65535)+(d>>>16)}return f&1&&(d+=A+=h[_]<<8),A=(A&65535)+(A>>>16),d=(d&65535)+(d>>>16),(d<<16|A)>>>0},readHeaderInfo:function(h,A){var d=A.ptr,f=new Uint8Array(h,d,6),E={};if(E.fileIdentifierString=String.fromCharCode.apply(null,f),E.fileIdentifierString.lastIndexOf("Lerc2",0)!==0)throw"Unexpected file identifier string (expect Lerc2 ): "+E.fileIdentifierString;d+=6;var _=new DataView(h,d,8),R=_.getInt32(0,!0);E.fileVersion=R,d+=4,R>=3&&(E.checksum=_.getUint32(4,!0),d+=4),_=new DataView(h,d,12),E.height=_.getUint32(0,!0),E.width=_.getUint32(4,!0),d+=8,R>=4?(E.numDims=_.getUint32(8,!0),d+=4):E.numDims=1,_=new DataView(h,d,40),E.numValidPixel=_.getUint32(0,!0),E.microBlockSize=_.getInt32(4,!0),E.blobSize=_.getInt32(8,!0),E.imageType=_.getInt32(12,!0),E.maxZError=_.getFloat64(16,!0),E.zMin=_.getFloat64(24,!0),E.zMax=_.getFloat64(32,!0),d+=40,A.headerInfo=E,A.ptr=d;var I,C;if(R>=3&&(C=R>=4?52:48,I=this.computeChecksumFletcher32(new Uint8Array(h,d-C,E.blobSize-14)),I!==E.checksum))throw"Checksum failed.";return!0},checkMinMaxRanges:function(h,A){var d=A.headerInfo,f=this.getDataTypeArray(d.imageType),E=d.numDims*this.getDataTypeSize(d.imageType),_=this.readSubArray(h,A.ptr,f,E),R=this.readSubArray(h,A.ptr+E,f,E);A.ptr+=2*E;var I,C=!0;for(I=0;I<d.numDims;I++)if(_[I]!==R[I]){C=!1;break}return d.minValues=_,d.maxValues=R,C},readSubArray:function(h,A,d,f){var E;if(d===Uint8Array)E=new Uint8Array(h,A,f);else{var _=new ArrayBuffer(f),R=new Uint8Array(_);R.set(new Uint8Array(h,A,f)),E=new d(_)}return E},readMask:function(h,A){var d=A.ptr,f=A.headerInfo,E=f.width*f.height,_=f.numValidPixel,R=new DataView(h,d,4),I={};if(I.numBytes=R.getUint32(0,!0),d+=4,(_===0||E===_)&&I.numBytes!==0)throw"invalid mask";var C,N;if(_===0)C=new Uint8Array(Math.ceil(E/8)),I.bitset=C,N=new Uint8Array(E),A.pixels.resultMask=N,d+=I.numBytes;else if(I.numBytes>0){C=new Uint8Array(Math.ceil(E/8)),R=new DataView(h,d,I.numBytes);var T=R.getInt16(0,!0),b=2,F=0,B=0;do{if(T>0)for(;T--;)C[F++]=R.getUint8(b++);else for(B=R.getUint8(b++),T=-T;T--;)C[F++]=B;T=R.getInt16(b,!0),b+=2}while(b<I.numBytes);if(T!==-32768||F<C.length)throw"Unexpected end of mask RLE encoding";N=new Uint8Array(E);var U=0,Q=0;for(Q=0;Q<E;Q++)Q&7?(U=C[Q>>3],U<<=Q&7):U=C[Q>>3],U&128&&(N[Q]=1);A.pixels.resultMask=N,I.bitset=C,d+=I.numBytes}return A.ptr=d,A.mask=I,!0},readDataOneSweep:function(h,A,d){var f=A.ptr,E=A.headerInfo,_=E.numDims,R=E.width*E.height,I=E.imageType,C=E.numValidPixel*o.getDataTypeSize(I)*_,N,T=A.pixels.resultMask;if(d===Uint8Array)N=new Uint8Array(h,f,C);else{var b=new ArrayBuffer(C),F=new Uint8Array(b);F.set(new Uint8Array(h,f,C)),N=new d(b)}if(N.length===R*_)A.pixels.resultPixels=N;else{A.pixels.resultPixels=new d(R*_);var B=0,U=0,Q=0,M=0;if(_>1)for(Q=0;Q<_;Q++)for(M=Q*R,U=0;U<R;U++)T[U]&&(A.pixels.resultPixels[M+U]=N[B++]);else for(U=0;U<R;U++)T[U]&&(A.pixels.resultPixels[U]=N[B++])}return f+=C,A.ptr=f,!0},readHuffmanTree:function(h,A){var d=this.HUFFMAN_LUT_BITS_MAX,f=new DataView(h,A.ptr,16);A.ptr+=16;var E=f.getInt32(0,!0);if(E<2)throw"unsupported Huffman version";var _=f.getInt32(4,!0),R=f.getInt32(8,!0),I=f.getInt32(12,!0);if(R>=I)return!1;var C=new Uint32Array(I-R);o.decodeBits(h,A,C);var N=[],T,b,F,B;for(T=R;T<I;T++)b=T-(T<_?0:_),N[b]={first:C[T-R],second:null};var U=h.byteLength-A.ptr,Q=Math.ceil(U/4),M=new ArrayBuffer(Q*4),k=new Uint8Array(M);k.set(new Uint8Array(h,A.ptr,U));var y=new Uint32Array(M),c=0,g,O=0;for(g=y[0],T=R;T<I;T++)b=T-(T<_?0:_),B=N[b].first,B>0&&(N[b].second=g<<c>>>32-B,32-c>=B?(c+=B,c===32&&(c=0,O++,g=y[O])):(c+=B-32,O++,g=y[O],N[b].second|=g>>>32-c));var D=0,w=0,x=new r;for(T=0;T<N.length;T++)N[T]!==void 0&&(D=Math.max(D,N[T].first));D>=d?w=d:w=D,D>=30&&console.log("WARning, large NUM LUT BITS IS "+D);var H=[],j,X,tt,G,It,gt;for(T=R;T<I;T++)if(b=T-(T<_?0:_),B=N[b].first,B>0)if(j=[B,b],B<=w)for(X=N[b].second<<w-B,tt=1<<w-B,F=0;F<tt;F++)H[X|F]=j;else for(X=N[b].second,gt=x,G=B-1;G>=0;G--)It=X>>>G&1,It?(gt.right||(gt.right=new r),gt=gt.right):(gt.left||(gt.left=new r),gt=gt.left),G===0&&!gt.val&&(gt.val=j[1]);return{decodeLut:H,numBitsLUTQick:w,numBitsLUT:D,tree:x,stuffedData:y,srcPtr:O,bitPos:c}},readHuffman:function(h,A,d){var f=A.headerInfo,E=f.numDims,_=A.headerInfo.height,R=A.headerInfo.width,I=R*_,C=this.readHuffmanTree(h,A),N=C.decodeLut,T=C.tree,b=C.stuffedData,F=C.srcPtr,B=C.bitPos,U=C.numBitsLUTQick,Q=C.numBitsLUT,M=A.headerInfo.imageType===0?128:0,k,y,c,g=A.pixels.resultMask,O,D,w,x,H,j,X,tt=0;B>0&&(F++,B=0);var G=b[F],It=A.encodeMode===1,gt=new d(I*E),Yt=gt,Ut;for(Ut=0;Ut<f.numDims;Ut++){if(E>1&&(Yt=new d(gt.buffer,I*Ut,I),tt=0),A.headerInfo.numValidPixel===R*_)for(j=0,x=0;x<_;x++)for(H=0;H<R;H++,j++){if(y=0,O=G<<B>>>32-U,D=O,32-B<U&&(O|=b[F+1]>>>64-B-U,D=O),N[D])y=N[D][1],B+=N[D][0];else for(O=G<<B>>>32-Q,D=O,32-B<Q&&(O|=b[F+1]>>>64-B-Q,D=O),k=T,X=0;X<Q;X++)if(w=O>>>Q-X-1&1,k=w?k.right:k.left,!(k.left||k.right)){y=k.val,B=B+X+1;break}B>=32&&(B-=32,F++,G=b[F]),c=y-M,It?(H>0?c+=tt:x>0?c+=Yt[j-R]:c+=tt,c&=255,Yt[j]=c,tt=c):Yt[j]=c}else for(j=0,x=0;x<_;x++)for(H=0;H<R;H++,j++)if(g[j]){if(y=0,O=G<<B>>>32-U,D=O,32-B<U&&(O|=b[F+1]>>>64-B-U,D=O),N[D])y=N[D][1],B+=N[D][0];else for(O=G<<B>>>32-Q,D=O,32-B<Q&&(O|=b[F+1]>>>64-B-Q,D=O),k=T,X=0;X<Q;X++)if(w=O>>>Q-X-1&1,k=w?k.right:k.left,!(k.left||k.right)){y=k.val,B=B+X+1;break}B>=32&&(B-=32,F++,G=b[F]),c=y-M,It?(H>0&&g[j-1]?c+=tt:x>0&&g[j-R]?c+=Yt[j-R]:c+=tt,c&=255,Yt[j]=c,tt=c):Yt[j]=c}A.ptr=A.ptr+(F+1)*4+(B>0?4:0)}A.pixels.resultPixels=gt},decodeBits:function(h,A,d,f,E){{var _=A.headerInfo,R=_.fileVersion,I=0,C=new DataView(h,A.ptr,5),N=C.getUint8(0);I++;var T=N>>6,b=T===0?4:3-T,F=(N&32)>0,B=N&31,U=0;if(b===1)U=C.getUint8(I),I++;else if(b===2)U=C.getUint16(I,!0),I+=2;else if(b===4)U=C.getUint32(I,!0),I+=4;else throw"Invalid valid pixel count type";var Q=2*_.maxZError,M,k,y,c,g,O,D,w,x,H,j=_.numDims>1?_.maxValues[E]:_.zMax;if(F){for(A.counter.lut++,w=C.getUint8(I),x=B,I++,c=Math.ceil((w-1)*B/8),g=Math.ceil(c/4),k=new ArrayBuffer(g*4),y=new Uint8Array(k),A.ptr+=I,y.set(new Uint8Array(h,A.ptr,c)),D=new Uint32Array(k),A.ptr+=c,H=0;w-1>>>H;)H++;c=Math.ceil(U*H/8),g=Math.ceil(c/4),k=new ArrayBuffer(g*4),y=new Uint8Array(k),y.set(new Uint8Array(h,A.ptr,c)),M=new Uint32Array(k),A.ptr+=c,R>=3?O=s.unstuffLUT2(D,B,w-1,f,Q,j):O=s.unstuffLUT(D,B,w-1,f,Q,j),R>=3?s.unstuff2(M,d,H,U,O):s.unstuff(M,d,H,U,O)}else A.counter.bitstuffer++,H=B,A.ptr+=I,H>0&&(c=Math.ceil(U*H/8),g=Math.ceil(c/4),k=new ArrayBuffer(g*4),y=new Uint8Array(k),y.set(new Uint8Array(h,A.ptr,c)),M=new Uint32Array(k),A.ptr+=c,R>=3?f==null?s.originalUnstuff2(M,d,H,U):s.unstuff2(M,d,H,U,!1,f,Q,j):f==null?s.originalUnstuff(M,d,H,U):s.unstuff(M,d,H,U,!1,f,Q,j))}},readTiles:function(h,A,d){var f=A.headerInfo,E=f.width,_=f.height,R=f.microBlockSize,I=f.imageType,C=o.getDataTypeSize(I),N=Math.ceil(E/R),T=Math.ceil(_/R);A.pixels.numBlocksY=T,A.pixels.numBlocksX=N,A.pixels.ptr=0;var b=0,F=0,B=0,U=0,Q=0,M=0,k=0,y=0,c=0,g=0,O=0,D=0,w=0,x=0,H=0,j=0,X,tt,G,It,gt,Yt,Ut=new d(R*R),Ct=_%R||R,zt=E%R||R,kt,Jt,Wt=f.numDims,bt,ee=A.pixels.resultMask,ce=A.pixels.resultPixels;for(B=0;B<T;B++)for(Q=B!==T-1?R:Ct,U=0;U<N;U++)for(M=U!==N-1?R:zt,O=B*E*R+U*R,D=E-M,bt=0;bt<Wt;bt++){if(Wt>1&&(ce=new d(A.pixels.resultPixels.buffer,E*_*bt*C,E*_)),k=h.byteLength-A.ptr,X=new DataView(h,A.ptr,Math.min(10,k)),tt={},j=0,y=X.getUint8(0),j++,c=y>>6&255,g=y>>2&15,g!==(U*R>>3&15))throw"integrity issue";if(Yt=y&3,Yt>3)throw A.ptr+=j,"Invalid block encoding ("+Yt+")";if(Yt===2){A.counter.constant++,A.ptr+=j;continue}else if(Yt===0){if(A.counter.uncompressed++,A.ptr+=j,w=Q*M*C,x=h.byteLength-A.ptr,w=w<x?w:x,G=new ArrayBuffer(w%C===0?w:w+C-w%C),It=new Uint8Array(G),It.set(new Uint8Array(h,A.ptr,w)),gt=new d(G),H=0,ee)for(b=0;b<Q;b++){for(F=0;F<M;F++)ee[O]&&(ce[O]=gt[H++]),O++;O+=D}else for(b=0;b<Q;b++){for(F=0;F<M;F++)ce[O++]=gt[H++];O+=D}A.ptr+=H*C}else if(kt=o.getDataTypeUsed(I,c),Jt=o.getOnePixel(tt,j,kt,X),j+=o.getDataTypeSize(kt),Yt===3)if(A.ptr+=j,A.counter.constantoffset++,ee)for(b=0;b<Q;b++){for(F=0;F<M;F++)ee[O]&&(ce[O]=Jt),O++;O+=D}else for(b=0;b<Q;b++){for(F=0;F<M;F++)ce[O++]=Jt;O+=D}else if(A.ptr+=j,o.decodeBits(h,A,Ut,Jt,bt),j=0,ee)for(b=0;b<Q;b++){for(F=0;F<M;F++)ee[O]&&(ce[O]=Ut[j++]),O++;O+=D}else for(b=0;b<Q;b++){for(F=0;F<M;F++)ce[O++]=Ut[j++];O+=D}}},formatFileInfo:function(h){return{fileIdentifierString:h.headerInfo.fileIdentifierString,fileVersion:h.headerInfo.fileVersion,imageType:h.headerInfo.imageType,height:h.headerInfo.height,width:h.headerInfo.width,numValidPixel:h.headerInfo.numValidPixel,microBlockSize:h.headerInfo.microBlockSize,blobSize:h.headerInfo.blobSize,maxZError:h.headerInfo.maxZError,pixelType:o.getPixelType(h.headerInfo.imageType),eofOffset:h.eofOffset,mask:h.mask?{numBytes:h.mask.numBytes}:null,pixels:{numBlocksX:h.pixels.numBlocksX,numBlocksY:h.pixels.numBlocksY,maxValue:h.headerInfo.zMax,minValue:h.headerInfo.zMin,noDataValue:h.noDataValue}}},constructConstantSurface:function(h){var A=h.headerInfo.zMax,d=h.headerInfo.numDims,f=h.headerInfo.height*h.headerInfo.width,E=f*d,_=0,R=0,I=0,C=h.pixels.resultMask;if(C)if(d>1)for(_=0;_<d;_++)for(I=_*f,R=0;R<f;R++)C[R]&&(h.pixels.resultPixels[I+R]=A);else for(R=0;R<f;R++)C[R]&&(h.pixels.resultPixels[R]=A);else if(h.pixels.resultPixels.fill)h.pixels.resultPixels.fill(A);else for(R=0;R<E;R++)h.pixels.resultPixels[R]=A},getDataTypeArray:function(h){var A;switch(h){case 0:A=Int8Array;break;case 1:A=Uint8Array;break;case 2:A=Int16Array;break;case 3:A=Uint16Array;break;case 4:A=Int32Array;break;case 5:A=Uint32Array;break;case 6:A=Float32Array;break;case 7:A=Float64Array;break;default:A=Float32Array}return A},getPixelType:function(h){var A;switch(h){case 0:A="S8";break;case 1:A="U8";break;case 2:A="S16";break;case 3:A="U16";break;case 4:A="S32";break;case 5:A="U32";break;case 6:A="F32";break;case 7:A="F64";break;default:A="F32"}return A},isValidPixelValue:function(h,A){if(A==null)return!1;var d;switch(h){case 0:d=A>=-128&&A<=127;break;case 1:d=A>=0&&A<=255;break;case 2:d=A>=-32768&&A<=32767;break;case 3:d=A>=0&&A<=65536;break;case 4:d=A>=-2147483648&&A<=2147483647;break;case 5:d=A>=0&&A<=4294967296;break;case 6:d=A>=-34027999387901484e22&&A<=34027999387901484e22;break;case 7:d=A>=5e-324&&A<=17976931348623157e292;break;default:d=!1}return d},getDataTypeSize:function(h){var A=0;switch(h){case 0:case 1:A=1;break;case 2:case 3:A=2;break;case 4:case 5:case 6:A=4;break;case 7:A=8;break;default:A=h}return A},getDataTypeUsed:function(h,A){var d=h;switch(h){case 2:case 4:d=h-A;break;case 3:case 5:d=h-2*A;break;case 6:A===0?d=h:A===1?d=2:d=1;break;case 7:A===0?d=h:d=h-2*A+1;break;default:d=h;break}return d},getOnePixel:function(h,A,d,f){var E=0;switch(d){case 0:E=f.getInt8(A);break;case 1:E=f.getUint8(A);break;case 2:E=f.getInt16(A,!0);break;case 3:E=f.getUint16(A,!0);break;case 4:E=f.getInt32(A,!0);break;case 5:E=f.getUInt32(A,!0);break;case 6:E=f.getFloat32(A,!0);break;case 7:E=f.getFloat64(A,!0);break;default:throw"the decoder does not understand this pixel type"}return E}},r=function(h,A,d){this.val=h,this.left=A,this.right=d},a={decode:function(h,A){A=A||{};var d=A.noDataValue,f=0,E={};if(E.ptr=A.inputOffset||0,E.pixels={},!!o.readHeaderInfo(h,E)){var _=E.headerInfo,R=_.fileVersion,I=o.getDataTypeArray(_.imageType);o.readMask(h,E),_.numValidPixel!==_.width*_.height&&!E.pixels.resultMask&&(E.pixels.resultMask=A.maskData);var C=_.width*_.height;if(E.pixels.resultPixels=new I(C*_.numDims),E.counter={onesweep:0,uncompressed:0,lut:0,bitstuffer:0,constant:0,constantoffset:0},_.numValidPixel!==0)if(_.zMax===_.zMin)o.constructConstantSurface(E);else if(R>=4&&o.checkMinMaxRanges(h,E))o.constructConstantSurface(E);else{var N=new DataView(h,E.ptr,2),T=N.getUint8(0);if(E.ptr++,T)o.readDataOneSweep(h,E,I);else if(R>1&&_.imageType<=1&&Math.abs(_.maxZError-.5)<1e-5){var b=N.getUint8(1);if(E.ptr++,E.encodeMode=b,b>2||R<4&&b>1)throw"Invalid Huffman flag "+b;b?o.readHuffman(h,E,I):o.readTiles(h,E,I)}else o.readTiles(h,E,I)}E.eofOffset=E.ptr;var F;A.inputOffset?(F=E.headerInfo.blobSize+A.inputOffset-E.ptr,Math.abs(F)>=1&&(E.eofOffset=A.inputOffset+E.headerInfo.blobSize)):(F=E.headerInfo.blobSize-E.ptr,Math.abs(F)>=1&&(E.eofOffset=E.headerInfo.blobSize));var B={width:_.width,height:_.height,pixelData:E.pixels.resultPixels,minValue:_.zMin,maxValue:_.zMax,validPixelCount:_.numValidPixel,dimCount:_.numDims,dimStats:{minValues:_.minValues,maxValues:_.maxValues},maskData:E.pixels.resultMask};if(E.pixels.resultMask&&o.isValidPixelValue(_.imageType,d)){var U=E.pixels.resultMask;for(f=0;f<C;f++)U[f]||(B.pixelData[f]=d);B.noDataValue=d}return E.noDataValue=d,A.returnFileInfo&&(B.fileInfo=o.formatFileInfo(E)),B}},getBandCount:function(h){var A=0,d=0,f={};for(f.ptr=0,f.pixels={};d<h.byteLength-58;)o.readHeaderInfo(h,f),d+=f.headerInfo.blobSize,A++,f.ptr=d;return A}};return a}(),i=function(){var s=new ArrayBuffer(4),o=new Uint8Array(s),r=new Uint32Array(s);return r[0]=1,o[0]===1}(),n={decode:function(s,o){if(!i)throw"Big endian system is not supported.";o=o||{};var r=o.inputOffset||0,a=new Uint8Array(s,r,10),h=String.fromCharCode.apply(null,a),A,d;if(h.trim()==="CntZImage")A=t,d=1;else if(h.substring(0,5)==="Lerc2")A=e,d=2;else throw"Unexpected file identifier string: "+h;for(var f=0,E=s.byteLength-10,_,R=[],I,C,N={width:0,height:0,pixels:[],pixelType:o.pixelType,mask:null,statistics:[]};r<E;){var T=A.decode(s,{inputOffset:r,encodedMaskData:_,maskData:C,returnMask:f===0,returnEncodedMask:f===0,returnFileInfo:!0,pixelType:o.pixelType||null,noDataValue:o.noDataValue||null});r=T.fileInfo.eofOffset,f===0&&(_=T.encodedMaskData,C=T.maskData,N.width=T.width,N.height=T.height,N.dimCount=T.dimCount||1,N.pixelType=T.pixelType||T.fileInfo.pixelType,N.mask=T.maskData),d>1&&T.fileInfo.mask&&T.fileInfo.mask.numBytes>0&&R.push(T.maskData),f++,N.pixels.push(T.pixelData),N.statistics.push({minValue:T.minValue,maxValue:T.maxValue,noDataValue:T.noDataValue,dimStats:T.dimStats})}var b,F,B;if(d>1&&R.length>1){for(B=N.width*N.height,N.bandMasks=R,C=new Uint8Array(B),C.set(R[0]),b=1;b<R.length;b++)for(I=R[b],F=0;F<B;F++)C[F]=C[F]&I[F];N.maskData=C}return N}};typeof define=="function"&&define.amd?define([],function(){return n}):typeof bg<"u"&&bg.exports?bg.exports=n:this.Lerc=n})()});var kB={};He(kB,{default:()=>E_t});function f_t(t,e){if(t.encoding===q6.LERC){let s;try{s=nK.default.decode(t.heightmap)}catch(r){throw new ke(r)}if(s.statistics[0].minValue===Number.MAX_VALUE)throw new ke("Invalid tile data");t.heightmap=s.pixels[0],t.width=s.width,t.height=s.height}t.ellipsoid=ot.clone(t.ellipsoid),t.rectangle=Xt.clone(t.rectangle);let i=tK.computeVertices(t),n=i.vertices;return e.push(n.buffer),{vertices:n.buffer,numberOfAttributes:i.encoding.stride,minimumHeight:i.minimumHeight,maximumHeight:i.maximumHeight,gridWidth:t.width,gridHeight:t.height,boundingSphere3D:i.boundingSphere3D,orientedBoundingBox:i.orientedBoundingBox,occludeePointInScaledSpace:i.occludeePointInScaledSpace,encoding:i.encoding,westIndicesSouthToNorth:i.westIndicesSouthToNorth,southIndicesEastToWest:i.southIndicesEastToWest,eastIndicesNorthToSouth:i.eastIndicesNorthToSouth,northIndicesWestToEast:i.northIndicesWestToEast}}var nK,E_t,LB=S(()=>{Oe();$6();eK();pn();Ps();nK=co(iK(),1);Ns();E_t=Wi(f_t)});function xo(){Y.throwInstantiationError()}function aK(t,e){let i=new Array(e),n=new Array(t),s=new Array(e),o=new Array(t),r;for(r=0;r<t;++r)o[r]=r,n[r]=t*e-1-r;for(r=0;r<e;++r)s[r]=(r+1)*t-1,i[r]=(e-r-1)*t;return{westIndicesSouthToNorth:i,southIndicesEastToWest:n,eastIndicesNorthToSouth:s,northIndicesWestToEast:o}}function AK(t,e,i,n){let s=0;for(let o=0;o<e-1;++o){for(let r=0;r<t-1;++r){let a=s,h=a+t,A=h+1,d=a+1;i[n++]=a,i[n++]=h,i[n++]=d,i[n++]=d,i[n++]=h,i[n++]=A,++s}++s}}function Yg(t,e,i,n){let s=t[0],o=t.length;for(let r=1;r<o;++r){let a=t[r];i[n++]=s,i[n++]=a,i[n++]=e,i[n++]=e,i[n++]=a,i[n++]=e+1,s=a,++e}return n}var sK,oK,rK,hK,cK=S(()=>{mt();Ot();Di();_e();Object.defineProperties(xo.prototype,{errorEvent:{get:Y.throwInstantiationError},credit:{get:Y.throwInstantiationError},tilingScheme:{get:Y.throwInstantiationError},hasWaterMask:{get:Y.throwInstantiationError},hasVertexNormals:{get:Y.throwInstantiationError},availability:{get:Y.throwInstantiationError}});sK=[];xo.getRegularGridIndices=function(t,e){if(t*e>=L.FOUR_GIGABYTES)throw new Y("The total number of vertices (width * height) must be less than 4,294,967,296.");let i=sK[t];m(i)||(sK[t]=i=[]);let n=i[e];return m(n)||(t*e<L.SIXTY_FOUR_KILOBYTES?n=i[e]=new Uint16Array((t-1)*(e-1)*6):n=i[e]=new Uint32Array((t-1)*(e-1)*6),AK(t,e,n,0)),n};oK=[];xo.getRegularGridIndicesAndEdgeIndices=function(t,e){if(t*e>=L.FOUR_GIGABYTES)throw new Y("The total number of vertices (width * height) must be less than 4,294,967,296.");let i=oK[t];m(i)||(oK[t]=i=[]);let n=i[e];if(!m(n)){let s=xo.getRegularGridIndices(t,e),o=aK(t,e),r=o.westIndicesSouthToNorth,a=o.southIndicesEastToWest,h=o.eastIndicesNorthToSouth,A=o.northIndicesWestToEast;n=i[e]={indices:s,westIndicesSouthToNorth:r,southIndicesEastToWest:a,eastIndicesNorthToSouth:h,northIndicesWestToEast:A}}return n};rK=[];xo.getRegularGridAndSkirtIndicesAndEdgeIndices=function(t,e){if(t*e>=L.FOUR_GIGABYTES)throw new Y("The total number of vertices (width * height) must be less than 4,294,967,296.");let i=rK[t];m(i)||(rK[t]=i=[]);let n=i[e];if(!m(n)){let s=t*e,o=(t-1)*(e-1)*6,r=t*2+e*2,a=Math.max(0,r-4)*6,h=s+r,A=o+a,d=aK(t,e),f=d.westIndicesSouthToNorth,E=d.southIndicesEastToWest,_=d.eastIndicesNorthToSouth,R=d.northIndicesWestToEast,I=te.createTypedArray(h,A);AK(t,e,I,0),xo.addSkirtIndices(f,E,_,R,s,I,o),n=i[e]={indices:I,westIndicesSouthToNorth:f,southIndicesEastToWest:E,eastIndicesNorthToSouth:_,northIndicesWestToEast:R,indexCountWithoutSkirts:o}}return n};xo.addSkirtIndices=function(t,e,i,n,s,o,r){let a=s;r=Yg(t,a,o,r),a+=t.length,r=Yg(e,a,o,r),a+=e.length,r=Yg(i,a,o,r),a+=i.length,Yg(n,a,o,r)};xo.heightmapTerrainQuality=.25;xo.getEstimatedLevelZeroGeometricErrorForAHeightmap=function(t,e,i){return t.maximumRadius*2*Math.PI*xo.heightmapTerrainQuality/(e*i)};xo.prototype.requestTileGeometry=Y.throwInstantiationError;xo.prototype.getLevelMaximumGeometricError=Y.throwInstantiationError;xo.prototype.getTileDataAvailable=Y.throwInstantiationError;xo.prototype.loadTileDataAvailability=Y.throwInstantiationError;hK=xo});var wB={};He(wB,{default:()=>I_t});function Z_t(t,e){let i=t.quantizedVertices,n=i.length/3,s=t.octEncodedNormals,o=t.westIndices.length+t.eastIndices.length+t.southIndices.length+t.northIndices.length,r=t.includeWebMercatorT,a=t.exaggeration,h=t.exaggerationRelativeHeight,d=a!==1,f=Xt.clone(t.rectangle),E=f.west,_=f.south,R=f.east,I=f.north,C=ot.clone(t.ellipsoid),N=t.minimumHeight,T=t.maximumHeight,b=t.relativeToCenter,F=In.eastNorthUpToFixedFrame(b,C),B=at.inverseTransformation(F,new at),U,Q;r&&(U=ks.geodeticLatitudeToMercatorAngle(_),Q=1/(ks.geodeticLatitudeToMercatorAngle(I)-U));let M=i.subarray(0,n),k=i.subarray(n,2*n),y=i.subarray(n*2,3*n),c=m(s),g=new Array(n),O=new Array(n),D=new Array(n),w=r?new Array(n):[],x=d?new Array(n):[],H=__t;H.x=Number.POSITIVE_INFINITY,H.y=Number.POSITIVE_INFINITY,H.z=Number.POSITIVE_INFINITY;let j=R_t;j.x=Number.NEGATIVE_INFINITY,j.y=Number.NEGATIVE_INFINITY,j.z=Number.NEGATIVE_INFINITY;let X=Number.POSITIVE_INFINITY,tt=Number.NEGATIVE_INFINITY,G=Number.POSITIVE_INFINITY,It=Number.NEGATIVE_INFINITY;for(let Ye=0;Ye<n;++Ye){let Gi=M[Ye],An=k[Ye],Ne=Gi/yB,ei=An/yB,_n=L.lerp(N,T,y[Ye]/yB);Ys.longitude=L.lerp(E,R,Ne),Ys.latitude=L.lerp(_,I,ei),Ys.height=_n,X=Math.min(Ys.longitude,X),tt=Math.max(Ys.longitude,tt),G=Math.min(Ys.latitude,G),It=Math.max(Ys.latitude,It);let hs=C.cartographicToCartesian(Ys);g[Ye]=new nt(Ne,ei),O[Ye]=_n,D[Ye]=hs,r&&(w[Ye]=(ks.geodeticLatitudeToMercatorAngle(Ys.latitude)-U)*Q),d&&(x[Ye]=C.geodeticSurfaceNormal(hs)),at.multiplyByPoint(B,hs,UR),l.minimumByComponent(UR,H,H),l.maximumByComponent(UR,j,j)}let gt=Og(t.westIndices,function(Ye,Gi){return g[Ye].y-g[Gi].y}),Yt=Og(t.eastIndices,function(Ye,Gi){return g[Gi].y-g[Ye].y}),Ut=Og(t.southIndices,function(Ye,Gi){return g[Gi].x-g[Ye].x}),Ct=Og(t.northIndices,function(Ye,Gi){return g[Ye].x-g[Gi].x}),zt;N<0&&(zt=new dA(C).computeHorizonCullingPointPossiblyUnderEllipsoid(b,D,N));let kt=N;kt=Math.min(kt,Vg(t.westIndices,t.westSkirtHeight,O,g,f,C,B,H,j)),kt=Math.min(kt,Vg(t.southIndices,t.southSkirtHeight,O,g,f,C,B,H,j)),kt=Math.min(kt,Vg(t.eastIndices,t.eastSkirtHeight,O,g,f,C,B,H,j)),kt=Math.min(kt,Vg(t.northIndices,t.northSkirtHeight,O,g,f,C,B,H,j));let Jt=new ph(H,j,b),Wt=new vc(b,Jt,kt,T,F,c,r,d,a,h),bt=Wt.stride,ee=n*bt+o*bt,ce=new Float32Array(ee),je=0;for(let Ye=0;Ye<n;++Ye){if(c){let Gi=Ye*2;Kf.x=s[Gi],Kf.y=s[Gi+1]}je=Wt.encode(ce,je,D[Ye],g[Ye],O[Ye],Kf,w[Ye],x[Ye])}let Se=Math.max(0,(o-4)*2),Ue=t.indices.length+Se*3,Me=te.createTypedArray(n+o,Ue);Me.set(t.indices,0);let Ce=1e-4,Fe=(tt-X)*Ce,ni=(It-G)*Ce,ze=-Fe,Be=0,Mi=Fe,Ri=0,si=0,qe=ni,Oi=0,gn=-ni,De=n*bt;return Sg(ce,De,gt,Wt,O,g,s,C,f,t.westSkirtHeight,U,Q,ze,Be),De+=t.westIndices.length*bt,Sg(ce,De,Ut,Wt,O,g,s,C,f,t.southSkirtHeight,U,Q,Oi,gn),De+=t.southIndices.length*bt,Sg(ce,De,Yt,Wt,O,g,s,C,f,t.eastSkirtHeight,U,Q,Mi,Ri),De+=t.eastIndices.length*bt,Sg(ce,De,Ct,Wt,O,g,s,C,f,t.northSkirtHeight,U,Q,si,qe),hK.addSkirtIndices(gt,Ut,Yt,Ct,n,Me,t.indices.length),e.push(ce.buffer,Me.buffer),{vertices:ce.buffer,indices:Me.buffer,westIndicesSouthToNorth:gt,southIndicesEastToWest:Ut,eastIndicesNorthToSouth:Yt,northIndicesWestToEast:Ct,vertexStride:bt,center:b,minimumHeight:N,maximumHeight:T,occludeePointInScaledSpace:zt,encoding:Wt,indexCountWithoutSkirts:t.indices.length}}function Vg(t,e,i,n,s,o,r,a,h){let A=Number.POSITIVE_INFINITY,d=s.north,f=s.south,E=s.east,_=s.west;E<_&&(E+=L.TWO_PI);let R=t.length;for(let I=0;I<R;++I){let C=t[I],N=i[C],T=n[C];Ys.longitude=L.lerp(_,E,T.x),Ys.latitude=L.lerp(f,d,T.y),Ys.height=N-e;let b=o.cartographicToCartesian(Ys,UR);at.multiplyByPoint(r,b,b),l.minimumByComponent(b,a,a),l.maximumByComponent(b,h,h),A=Math.min(A,Ys.height)}return A}function Sg(t,e,i,n,s,o,r,a,h,A,d,f,E,_){let R=m(r),I=h.north,C=h.south,N=h.east,T=h.west;N<T&&(N+=L.TWO_PI);let b=i.length;for(let F=0;F<b;++F){let B=i[F],U=s[B],Q=o[B];Ys.longitude=L.lerp(T,N,Q.x)+E,Ys.latitude=L.lerp(C,I,Q.y)+_,Ys.height=U-A;let M=a.cartographicToCartesian(Ys,UR);if(R){let c=B*2;Kf.x=r[c],Kf.y=r[c+1]}let k;n.hasWebMercatorT&&(k=(ks.geodeticLatitudeToMercatorAngle(Ys.latitude)-d)*f);let y;n.hasGeodeticSurfaceNormals&&(y=a.geodeticSurfaceNormal(M)),e=n.encode(t,e,M,Q,Ys.height,Kf,k,y)}}function Og(t,e){let i;return typeof t.slice=="function"&&(i=t.slice(),typeof i.sort!="function"&&(i=void 0)),m(i)||(i=Array.prototype.slice.call(t)),i.sort(e),i}var yB,UR,__t,R_t,Ys,Kf,I_t,xB=S(()=>{a_();Xe();Ht();ri();mt();Oe();Vm();Di();_e();bi();pn();WR();cK();fr();Ml();Ns();yB=32767,UR=new l,__t=new l,R_t=new l,Ys=new ut,Kf=new nt;I_t=Wi(Z_t)});function p_t(t,e){return L.equalsEpsilon(t.latitude,e.latitude,L.EPSILON10)&&L.equalsEpsilon(t.longitude,e.longitude,L.EPSILON10)}function g_t(t,e,i,n){e=Xn(e,l.equalsEpsilon);let s=e.length;if(s<2)return;let o=m(n),r=m(i),a=new Array(s),h=new Array(s),A=new Array(s),d=e[0];a[0]=d;let f=t.cartesianToCartographic(d,u_t);r&&(f.height=i[0]),h[0]=f.height,o?A[0]=n[0]:A[0]=0;let E=h[0],_=A[0],R=E===_,I=1;for(let C=1;C<s;++C){let N=e[C],T=t.cartesianToCartographic(N,C_t);r&&(T.height=i[C]),R=R&&T.height===0,p_t(f,T)?f.height<T.height&&(h[I-1]=T.height):(a[I]=N,h[I]=T.height,o?A[I]=n[C]:A[I]=0,R=R&&h[I]===A[I],ut.clone(T,f),++I)}if(!(R||I<2))return a.length=I,h.length=I,A.length=I,{positions:a,topHeights:h,bottomHeights:A}}var lK,u_t,C_t,T_t,N_t,F_t,Bg,PB=S(()=>{Sa();Ht();ri();mt();_e();Sf();lK={};u_t=new ut,C_t=new ut;T_t=new Array(2),N_t=new Array(2),F_t={positions:void 0,height:void 0,granularity:void 0,ellipsoid:void 0};lK.computePositions=function(t,e,i,n,s,o){let r=g_t(t,e,i,n);if(!m(r))return;e=r.positions,i=r.topHeights,n=r.bottomHeights;let a=e.length,h=a-2,A,d,f=L.chordLength(s,t.maximumRadius),E=F_t;if(E.minDistance=f,E.ellipsoid=t,o){let _=0,R;for(R=0;R<a-1;R++)_+=Sn.numberOfPoints(e[R],e[R+1],f)+1;A=new Float64Array(_*3),d=new Float64Array(_*3);let I=T_t,C=N_t;E.positions=I,E.height=C;let N=0;for(R=0;R<a-1;R++){I[0]=e[R],I[1]=e[R+1],C[0]=i[R],C[1]=i[R+1];let T=Sn.generateArc(E);A.set(T,N),C[0]=n[R],C[1]=n[R+1],d.set(Sn.generateArc(E),N),N+=T.length}}else E.positions=e,E.height=i,A=new Float64Array(Sn.generateArc(E)),E.height=n,d=new Float64Array(Sn.generateArc(E));return{bottomPositions:d,topPositions:A,numCorners:h}};Bg=lK});function gd(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.maximumHeights,n=t.minimumHeights;if(!m(e))throw new Y("options.positions is required.");if(m(i)&&i.length!==e.length)throw new Y("options.positions and options.maximumHeights must have the same length.");if(m(n)&&n.length!==e.length)throw new Y("options.positions and options.minimumHeights must have the same length.");let s=Z(t.vertexFormat,St.DEFAULT),o=Z(t.granularity,L.RADIANS_PER_DEGREE),r=Z(t.ellipsoid,ot.WGS84);this._positions=e,this._minimumHeights=n,this._maximumHeights=i,this._vertexFormat=St.clone(s),this._granularity=o,this._ellipsoid=ot.clone(r),this._workerName="createWallGeometry";let a=1+e.length*l.packedLength+2;m(n)&&(a+=n.length),m(i)&&(a+=i.length),this.packedLength=a+ot.packedLength+St.packedLength+1}var JB,Gg,b_t,dK,Y_t,V_t,S_t,mK,fK,MR,jB,EK=S(()=>{_i();Ht();oi();Ft();mt();Ot();Oe();yi();ji();En();Di();_e();Xi();Ls();PB();JB=new l,Gg=new l,b_t=new l,dK=new l,Y_t=new l,V_t=new l,S_t=new l;gd.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._minimumHeights;if(o=m(r)?r.length:0,e[i++]=o,m(r))for(n=0;n<o;++n)e[i++]=r[n];let a=t._maximumHeights;if(o=m(a)?a.length:0,e[i++]=o,m(a))for(n=0;n<o;++n)e[i++]=a[n];return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,St.pack(t._vertexFormat,e,i),i+=St.packedLength,e[i]=t._granularity,e};mK=ot.clone(ot.UNIT_SPHERE),fK=new St,MR={positions:void 0,minimumHeights:void 0,maximumHeights:void 0,ellipsoid:mK,vertexFormat:fK,granularity:void 0};gd.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r;if(s>0)for(r=new Array(s),n=0;n<s;++n)r[n]=t[e++];s=t[e++];let a;if(s>0)for(a=new Array(s),n=0;n<s;++n)a[n]=t[e++];let h=ot.unpack(t,e,mK);e+=ot.packedLength;let A=St.unpack(t,e,fK);e+=St.packedLength;let d=t[e];return m(i)?(i._positions=o,i._minimumHeights=r,i._maximumHeights=a,i._ellipsoid=ot.clone(h,i._ellipsoid),i._vertexFormat=St.clone(A,i._vertexFormat),i._granularity=d,i):(MR.positions=o,MR.minimumHeights=r,MR.maximumHeights=a,MR.granularity=d,new gd(MR))};gd.fromConstantHeights=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions;if(!m(e))throw new Y("options.positions is required.");let i,n,s=t.minimumHeight,o=t.maximumHeight,r=m(s),a=m(o);if(r||a){let A=e.length;i=r?new Array(A):void 0,n=a?new Array(A):void 0;for(let d=0;d<A;++d)r&&(i[d]=s),a&&(n[d]=o)}let h={positions:e,maximumHeights:n,minimumHeights:i,ellipsoid:t.ellipsoid,vertexFormat:t.vertexFormat};return new gd(h)};gd.createGeometry=function(t){let e=t._positions,i=t._minimumHeights,n=t._maximumHeights,s=t._vertexFormat,o=t._granularity,r=t._ellipsoid,a=Bg.computePositions(r,e,n,i,o,!0);if(!m(a))return;let h=a.bottomPositions,A=a.topPositions,d=a.numCorners,f=A.length,E=f*2,_=s.position?new Float64Array(E):void 0,R=s.normal?new Float32Array(E):void 0,I=s.tangent?new Float32Array(E):void 0,C=s.bitangent?new Float32Array(E):void 0,N=s.st?new Float32Array(E/3*2):void 0,T=0,b=0,F=0,B=0,U=0,Q=S_t,M=V_t,k=Y_t,y=!0;f/=3;let c,g=0,O=1/(f-d-1);for(c=0;c<f;++c){let j=c*3,X=l.fromArray(A,j,JB),tt=l.fromArray(h,j,Gg);if(s.position&&(_[T++]=tt.x,_[T++]=tt.y,_[T++]=tt.z,_[T++]=X.x,_[T++]=X.y,_[T++]=X.z),s.st&&(N[U++]=g,N[U++]=0,N[U++]=g,N[U++]=1),s.normal||s.tangent||s.bitangent){let G=l.clone(l.ZERO,dK),It=l.subtract(X,r.geodeticSurfaceNormal(X,Gg),Gg);if(c+1<f&&(G=l.fromArray(A,j+3,dK)),y){let gt=l.subtract(G,X,b_t),Yt=l.subtract(It,X,JB);Q=l.normalize(l.cross(Yt,gt,Q),Q),y=!1}l.equalsEpsilon(X,G,L.EPSILON10)?y=!0:(g+=O,s.tangent&&(M=l.normalize(l.subtract(G,X,M),M)),s.bitangent&&(k=l.normalize(l.cross(Q,M,k),k))),s.normal&&(R[b++]=Q.x,R[b++]=Q.y,R[b++]=Q.z,R[b++]=Q.x,R[b++]=Q.y,R[b++]=Q.z),s.tangent&&(I[B++]=M.x,I[B++]=M.y,I[B++]=M.z,I[B++]=M.x,I[B++]=M.y,I[B++]=M.z),s.bitangent&&(C[F++]=k.x,C[F++]=k.y,C[F++]=k.z,C[F++]=k.x,C[F++]=k.y,C[F++]=k.z)}}let D=new we;s.position&&(D.position=new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:_})),s.normal&&(D.normal=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:R})),s.tangent&&(D.tangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:I})),s.bitangent&&(D.bitangent=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:3,values:C})),s.st&&(D.st=new Tt({componentDatatype:At.FLOAT,componentsPerAttribute:2,values:N}));let w=E/3;E-=6*(d+1);let x=te.createTypedArray(w,E),H=0;for(c=0;c<w-2;c+=2){let j=c,X=c+2,tt=l.fromArray(_,j*3,JB),G=l.fromArray(_,X*3,Gg);if(l.equalsEpsilon(tt,G,L.EPSILON10))continue;let It=c+1,gt=c+3;x[H++]=It,x[H++]=j,x[H++]=gt,x[H++]=gt,x[H++]=j,x[H++]=X}return new se({attributes:D,indices:x,primitiveType:ne.TRIANGLES,boundingSphere:new Nt.fromVertices(_)})};jB=gd});var HB={};He(HB,{default:()=>B_t});function O_t(t,e){return m(e)&&(t=jB.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),jB.createGeometry(t)}var B_t,vB=S(()=>{mt();Oe();EK();B_t=O_t});function Td(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions,i=t.maximumHeights,n=t.minimumHeights;if(!m(e))throw new Y("options.positions is required.");if(m(i)&&i.length!==e.length)throw new Y("options.positions and options.maximumHeights must have the same length.");if(m(n)&&n.length!==e.length)throw new Y("options.positions and options.minimumHeights must have the same length.");let s=Z(t.granularity,L.RADIANS_PER_DEGREE),o=Z(t.ellipsoid,ot.WGS84);this._positions=e,this._minimumHeights=n,this._maximumHeights=i,this._granularity=s,this._ellipsoid=ot.clone(o),this._workerName="createWallOutlineGeometry";let r=1+e.length*l.packedLength+2;m(n)&&(r+=n.length),m(i)&&(r+=i.length),this.packedLength=r+ot.packedLength+1}var _K,RK,ZK,QR,zB,IK=S(()=>{_i();Ht();oi();Ft();mt();Ot();Oe();yi();ji();En();Di();_e();Xi();PB();_K=new l,RK=new l;Td.pack=function(t,e,i){if(!m(t))throw new Y("value is required");if(!m(e))throw new Y("array is required");i=Z(i,0);let n,s=t._positions,o=s.length;for(e[i++]=o,n=0;n<o;++n,i+=l.packedLength)l.pack(s[n],e,i);let r=t._minimumHeights;if(o=m(r)?r.length:0,e[i++]=o,m(r))for(n=0;n<o;++n)e[i++]=r[n];let a=t._maximumHeights;if(o=m(a)?a.length:0,e[i++]=o,m(a))for(n=0;n<o;++n)e[i++]=a[n];return ot.pack(t._ellipsoid,e,i),i+=ot.packedLength,e[i]=t._granularity,e};ZK=ot.clone(ot.UNIT_SPHERE),QR={positions:void 0,minimumHeights:void 0,maximumHeights:void 0,ellipsoid:ZK,granularity:void 0};Td.unpack=function(t,e,i){if(!m(t))throw new Y("array is required");e=Z(e,0);let n,s=t[e++],o=new Array(s);for(n=0;n<s;++n,e+=l.packedLength)o[n]=l.unpack(t,e);s=t[e++];let r;if(s>0)for(r=new Array(s),n=0;n<s;++n)r[n]=t[e++];s=t[e++];let a;if(s>0)for(a=new Array(s),n=0;n<s;++n)a[n]=t[e++];let h=ot.unpack(t,e,ZK);e+=ot.packedLength;let A=t[e];return m(i)?(i._positions=o,i._minimumHeights=r,i._maximumHeights=a,i._ellipsoid=ot.clone(h,i._ellipsoid),i._granularity=A,i):(QR.positions=o,QR.minimumHeights=r,QR.maximumHeights=a,QR.granularity=A,new Td(QR))};Td.fromConstantHeights=function(t){t=Z(t,Z.EMPTY_OBJECT);let e=t.positions;if(!m(e))throw new Y("options.positions is required.");let i,n,s=t.minimumHeight,o=t.maximumHeight,r=m(s),a=m(o);if(r||a){let A=e.length;i=r?new Array(A):void 0,n=a?new Array(A):void 0;for(let d=0;d<A;++d)r&&(i[d]=s),a&&(n[d]=o)}let h={positions:e,maximumHeights:n,minimumHeights:i,ellipsoid:t.ellipsoid};return new Td(h)};Td.createGeometry=function(t){let e=t._positions,i=t._minimumHeights,n=t._maximumHeights,s=t._granularity,o=t._ellipsoid,r=Bg.computePositions(o,e,n,i,s,!1);if(!m(r))return;let a=r.bottomPositions,h=r.topPositions,A=h.length,d=A*2,f=new Float64Array(d),E=0;A/=3;let _;for(_=0;_<A;++_){let T=_*3,b=l.fromArray(h,T,_K),F=l.fromArray(a,T,RK);f[E++]=F.x,f[E++]=F.y,f[E++]=F.z,f[E++]=b.x,f[E++]=b.y,f[E++]=b.z}let R=new we({position:new Tt({componentDatatype:At.DOUBLE,componentsPerAttribute:3,values:f})}),I=d/3;d=2*I-4+I;let C=te.createTypedArray(I,d),N=0;for(_=0;_<I-2;_+=2){let T=_,b=_+2,F=l.fromArray(f,T*3,_K),B=l.fromArray(f,b*3,RK);if(l.equalsEpsilon(F,B,L.EPSILON10))continue;let U=_+1,Q=_+3;C[N++]=U,C[N++]=T,C[N++]=U,C[N++]=Q,C[N++]=T,C[N++]=b}return C[N++]=I-2,C[N++]=I-1,new se({attributes:R,indices:C,primitiveType:ne.LINES,boundingSphere:new Nt.fromVertices(f)})};zB=Td});var KB={};He(KB,{default:()=>W_t});function G_t(t,e){return m(e)&&(t=zB.unpack(t,e)),t._ellipsoid=ot.clone(t._ellipsoid),zB.createGeometry(t)}var W_t,XB=S(()=>{mt();Oe();IK();W_t=G_t});var tG=ts((kR,$B)=>{var he=he||{};he.scope={};he.arrayIteratorImpl=function(t){var e=0;return function(){return e<t.length?{done:!1,value:t[e++]}:{done:!0}}};he.arrayIterator=function(t){return{next:he.arrayIteratorImpl(t)}};he.makeIterator=function(t){var e=typeof Symbol<"u"&&Symbol.iterator&&t[Symbol.iterator];return e?e.call(t):he.arrayIterator(t)};he.ASSUME_ES5=!1;he.ASSUME_NO_NATIVE_MAP=!1;he.ASSUME_NO_NATIVE_SET=!1;he.SIMPLE_FROUND_POLYFILL=!1;he.ISOLATE_POLYFILLS=!1;he.FORCE_POLYFILL_PROMISE=!1;he.FORCE_POLYFILL_PROMISE_WHEN_NO_UNHANDLED_REJECTION=!1;he.getGlobal=function(t){t=[typeof globalThis=="object"&&globalThis,t,typeof window=="object"&&window,typeof self=="object"&&self,typeof global=="object"&&global];for(var e=0;e<t.length;++e){var i=t[e];if(i&&i.Math==Math)return i}throw Error("Cannot find global object")};he.global=he.getGlobal(kR);he.defineProperty=he.ASSUME_ES5||typeof Object.defineProperties=="function"?Object.defineProperty:function(t,e,i){return t==Array.prototype||t==Object.prototype||(t[e]=i.value),t};he.IS_SYMBOL_NATIVE=typeof Symbol=="function"&&typeof Symbol("x")=="symbol";he.TRUST_ES6_POLYFILLS=!he.ISOLATE_POLYFILLS||he.IS_SYMBOL_NATIVE;he.polyfills={};he.propertyToPolyfillSymbol={};he.POLYFILL_PREFIX="$jscp$";he.polyfill=function(t,e,i,n){e&&(he.ISOLATE_POLYFILLS?he.polyfillIsolated(t,e,i,n):he.polyfillUnisolated(t,e,i,n))};he.polyfillUnisolated=function(t,e,i,n){for(i=he.global,t=t.split("."),n=0;n<t.length-1;n++){var s=t[n];if(!(s in i))return;i=i[s]}t=t[t.length-1],n=i[t],e=e(n),e!=n&&e!=null&&he.defineProperty(i,t,{configurable:!0,writable:!0,value:e})};he.polyfillIsolated=function(t,e,i,n){var s=t.split(".");t=s.length===1,n=s[0],n=!t&&n in he.polyfills?he.polyfills:he.global;for(var o=0;o<s.length-1;o++){var r=s[o];if(!(r in n))return;n=n[r]}s=s[s.length-1],i=he.IS_SYMBOL_NATIVE&&i==="es6"?n[s]:null,e=e(i),e!=null&&(t?he.defineProperty(he.polyfills,s,{configurable:!0,writable:!0,value:e}):e!==i&&(he.propertyToPolyfillSymbol[s]===void 0&&(i=1e9*Math.random()>>>0,he.propertyToPolyfillSymbol[s]=he.IS_SYMBOL_NATIVE?he.global.Symbol(s):he.POLYFILL_PREFIX+i+"$"+s),he.defineProperty(n,he.propertyToPolyfillSymbol[s],{configurable:!0,writable:!0,value:e})))};he.polyfill("Promise",function(t){function e(){this.batch_=null}function i(r){return r instanceof s?r:new s(function(a,h){a(r)})}if(t&&(!(he.FORCE_POLYFILL_PROMISE||he.FORCE_POLYFILL_PROMISE_WHEN_NO_UNHANDLED_REJECTION&&typeof he.global.PromiseRejectionEvent>"u")||!he.global.Promise||he.global.Promise.toString().indexOf("[native code]")===-1))return t;e.prototype.asyncExecute=function(r){if(this.batch_==null){this.batch_=[];var a=this;this.asyncExecuteFunction(function(){a.executeBatch_()})}this.batch_.push(r)};var n=he.global.setTimeout;e.prototype.asyncExecuteFunction=function(r){n(r,0)},e.prototype.executeBatch_=function(){for(;this.batch_&&this.batch_.length;){var r=this.batch_;this.batch_=[];for(var a=0;a<r.length;++a){var h=r[a];r[a]=null;try{h()}catch(A){this.asyncThrow_(A)}}}this.batch_=null},e.prototype.asyncThrow_=function(r){this.asyncExecuteFunction(function(){throw r})};var s=function(r){this.state_=0,this.result_=void 0,this.onSettledCallbacks_=[],this.isRejectionHandled_=!1;var a=this.createResolveAndReject_();try{r(a.resolve,a.reject)}catch(h){a.reject(h)}};s.prototype.createResolveAndReject_=function(){function r(A){return function(d){h||(h=!0,A.call(a,d))}}var a=this,h=!1;return{resolve:r(this.resolveTo_),reject:r(this.reject_)}},s.prototype.resolveTo_=function(r){if(r===this)this.reject_(new TypeError("A Promise cannot resolve to itself"));else if(r instanceof s)this.settleSameAsPromise_(r);else{t:switch(typeof r){case"object":var a=r!=null;break t;case"function":a=!0;break t;default:a=!1}a?this.resolveToNonPromiseObj_(r):this.fulfill_(r)}},s.prototype.resolveToNonPromiseObj_=function(r){var a=void 0;try{a=r.then}catch(h){this.reject_(h);return}typeof a=="function"?this.settleSameAsThenable_(a,r):this.fulfill_(r)},s.prototype.reject_=function(r){this.settle_(2,r)},s.prototype.fulfill_=function(r){this.settle_(1,r)},s.prototype.settle_=function(r,a){if(this.state_!=0)throw Error("Cannot settle("+r+", "+a+"): Promise already settled in state"+this.state_);this.state_=r,this.result_=a,this.state_===2&&this.scheduleUnhandledRejectionCheck_(),this.executeOnSettledCallbacks_()},s.prototype.scheduleUnhandledRejectionCheck_=function(){var r=this;n(function(){if(r.notifyUnhandledRejection_()){var a=he.global.console;typeof a<"u"&&a.error(r.result_)}},1)},s.prototype.notifyUnhandledRejection_=function(){if(this.isRejectionHandled_)return!1;var r=he.global.CustomEvent,a=he.global.Event,h=he.global.dispatchEvent;return typeof h>"u"?!0:(typeof r=="function"?r=new r("unhandledrejection",{cancelable:!0}):typeof a=="function"?r=new a("unhandledrejection",{cancelable:!0}):(r=he.global.document.createEvent("CustomEvent"),r.initCustomEvent("unhandledrejection",!1,!0,r)),r.promise=this,r.reason=this.result_,h(r))},s.prototype.executeOnSettledCallbacks_=function(){if(this.onSettledCallbacks_!=null){for(var r=0;r<this.onSettledCallbacks_.length;++r)o.asyncExecute(this.onSettledCallbacks_[r]);this.onSettledCallbacks_=null}};var o=new e;return s.prototype.settleSameAsPromise_=function(r){var a=this.createResolveAndReject_();r.callWhenSettled_(a.resolve,a.reject)},s.prototype.settleSameAsThenable_=function(r,a){var h=this.createResolveAndReject_();try{r.call(a,h.resolve,h.reject)}catch(A){h.reject(A)}},s.prototype.then=function(r,a){function h(E,_){return typeof E=="function"?function(R){try{A(E(R))}catch(I){d(I)}}:_}var A,d,f=new s(function(E,_){A=E,d=_});return this.callWhenSettled_(h(r,A),h(a,d)),f},s.prototype.catch=function(r){return this.then(void 0,r)},s.prototype.callWhenSettled_=function(r,a){function h(){switch(A.state_){case 1:r(A.result_);break;case 2:a(A.result_);break;default:throw Error("Unexpected state: "+A.state_)}}var A=this;this.onSettledCallbacks_==null?o.asyncExecute(h):this.onSettledCallbacks_.push(h),this.isRejectionHandled_=!0},s.resolve=i,s.reject=function(r){return new s(function(a,h){h(r)})},s.race=function(r){return new s(function(a,h){for(var A=he.makeIterator(r),d=A.next();!d.done;d=A.next())i(d.value).callWhenSettled_(a,h)})},s.all=function(r){var a=he.makeIterator(r),h=a.next();return h.done?i([]):new s(function(A,d){function f(R){return function(I){E[R]=I,_--,_==0&&A(E)}}var E=[],_=0;do E.push(void 0),_++,i(h.value).callWhenSettled_(f(E.length-1),d),h=a.next();while(!h.done)})},s},"es6","es3");he.owns=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)};he.assign=he.TRUST_ES6_POLYFILLS&&typeof Object.assign=="function"?Object.assign:function(t,e){for(var i=1;i<arguments.length;i++){var n=arguments[i];if(n)for(var s in n)he.owns(n,s)&&(t[s]=n[s])}return t};he.polyfill("Object.assign",function(t){return t||he.assign},"es6","es3");he.checkStringArgs=function(t,e,i){if(t==null)throw new TypeError("The 'this' value for String.prototype."+i+" must not be null or undefined");if(e instanceof RegExp)throw new TypeError("First argument to String.prototype."+i+" must not be a regular expression");return t+""};he.polyfill("String.prototype.startsWith",function(t){return t||function(e,i){var n=he.checkStringArgs(this,e,"startsWith");e+="";var s=n.length,o=e.length;i=Math.max(0,Math.min(i|0,n.length));for(var r=0;r<o&&i<s;)if(n[i++]!=e[r++])return!1;return r>=o}},"es6","es3");he.polyfill("Array.prototype.copyWithin",function(t){function e(i){return i=Number(i),i===1/0||i===-1/0?i:i|0}return t||function(i,n,s){var o=this.length;if(i=e(i),n=e(n),s=s===void 0?o:e(s),i=0>i?Math.max(o+i,0):Math.min(i,o),n=0>n?Math.max(o+n,0):Math.min(n,o),s=0>s?Math.max(o+s,0):Math.min(s,o),i<n)for(;n<s;)n in this?this[i++]=this[n++]:(delete this[i++],n++);else for(s=Math.min(s,o+n-i),i+=s-n;s>n;)--s in this?this[--i]=this[s]:delete this[--i];return this}},"es6","es3");he.typedArrayCopyWithin=function(t){return t||Array.prototype.copyWithin};he.polyfill("Int8Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Uint8Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Uint8ClampedArray.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Int16Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Uint16Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Int32Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Uint32Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Float32Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");he.polyfill("Float64Array.prototype.copyWithin",he.typedArrayCopyWithin,"es6","es5");var qB=function(){var t=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename<"u"&&(t=t||__filename),function(e){function i(z){return G.locateFile?G.locateFile(z,Wt):Wt+z}function n(z,et,pt){var $t=et+pt;for(pt=et;z[pt]&&!(pt>=$t);)++pt;if(16<pt-et&&z.buffer&&ze)return ze.decode(z.subarray(et,pt));for($t="";et<pt;){var ve=z[et++];if(ve&128){var hi=z[et++]&63;if((ve&224)==192)$t+=String.fromCharCode((ve&31)<<6|hi);else{var _a=z[et++]&63;ve=(ve&240)==224?(ve&15)<<12|hi<<6|_a:(ve&7)<<18|hi<<12|_a<<6|z[et++]&63,65536>ve?$t+=String.fromCharCode(ve):(ve-=65536,$t+=String.fromCharCode(55296|ve>>10,56320|ve&1023))}}else $t+=String.fromCharCode(ve)}return $t}function s(z,et){return z?n(Mi,z,et):""}function o(){var z=Fe.buffer;G.HEAP8=Be=new Int8Array(z),G.HEAP16=new Int16Array(z),G.HEAP32=Ri=new Int32Array(z),G.HEAPU8=Mi=new Uint8Array(z),G.HEAPU16=new Uint16Array(z),G.HEAPU32=si=new Uint32Array(z),G.HEAPF32=new Float32Array(z),G.HEAPF64=new Float64Array(z)}function r(z){throw G.onAbort&&G.onAbort(z),z="Aborted("+z+")",Me(z),ni=!0,z=new WebAssembly.RuntimeError(z+". Build with -sASSERTIONS for more info."),gt(z),z}function a(z){try{if(z==Ne&&Ce)return new Uint8Array(Ce);if(je)return je(z);throw"both async and sync fetching of the wasm failed"}catch(et){r(et)}}function h(){if(!Ce&&(zt||kt)){if(typeof fetch=="function"&&!Ne.startsWith("file://"))return fetch(Ne,{credentials:"same-origin"}).then(function(z){if(!z.ok)throw"failed to load wasm binary file at '"+Ne+"'";return z.arrayBuffer()}).catch(function(){return a(Ne)});if(Se)return new Promise(function(z,et){Se(Ne,function(pt){z(new Uint8Array(pt))},et)})}return Promise.resolve().then(function(){return a(Ne)})}function A(z){for(;0<z.length;)z.shift()(G)}function d(z){this.excPtr=z,this.ptr=z-24,this.set_type=function(et){si[this.ptr+4>>2]=et},this.get_type=function(){return si[this.ptr+4>>2]},this.set_destructor=function(et){si[this.ptr+8>>2]=et},this.get_destructor=function(){return si[this.ptr+8>>2]},this.set_refcount=function(et){Ri[this.ptr>>2]=et},this.set_caught=function(et){Be[this.ptr+12>>0]=et?1:0},this.get_caught=function(){return Be[this.ptr+12>>0]!=0},this.set_rethrown=function(et){Be[this.ptr+13>>0]=et?1:0},this.get_rethrown=function(){return Be[this.ptr+13>>0]!=0},this.init=function(et,pt){this.set_adjusted_ptr(0),this.set_type(et),this.set_destructor(pt),this.set_refcount(0),this.set_caught(!1),this.set_rethrown(!1)},this.add_ref=function(){Ri[this.ptr>>2]+=1},this.release_ref=function(){var et=Ri[this.ptr>>2];return Ri[this.ptr>>2]=et-1,et===1},this.set_adjusted_ptr=function(et){si[this.ptr+16>>2]=et},this.get_adjusted_ptr=function(){return si[this.ptr+16>>2]},this.get_exception_ptr=function(){if(fm(this.get_type()))return si[this.excPtr>>2];var et=this.get_adjusted_ptr();return et!==0?et:this.excPtr}}function f(){function z(){if(!rA&&(rA=!0,G.calledRun=!0,!ni)){if(De=!0,A(Oi),It(G),G.onRuntimeInitialized&&G.onRuntimeInitialized(),G.postRun)for(typeof G.postRun=="function"&&(G.postRun=[G.postRun]);G.postRun.length;)gn.unshift(G.postRun.shift());A(gn)}}if(!(0<Ye)){if(G.preRun)for(typeof G.preRun=="function"&&(G.preRun=[G.preRun]);G.preRun.length;)qe.unshift(G.preRun.shift());A(qe),0<Ye||(G.setStatus?(G.setStatus("Running..."),setTimeout(function(){setTimeout(function(){G.setStatus("")},1),z()},1)):z())}}function E(){}function _(z){return(z||E).__cache__}function R(z,et){var pt=_(et),$t=pt[z];return $t||($t=Object.create((et||E).prototype),$t.ptr=z,pt[z]=$t)}function I(z){if(typeof z=="string"){for(var et=0,pt=0;pt<z.length;++pt){var $t=z.charCodeAt(pt);127>=$t?et++:2047>=$t?et+=2:55296<=$t&&57343>=$t?(et+=4,++pt):et+=3}if(et=Array(et+1),pt=0,$t=et.length,0<$t){$t=pt+$t-1;for(var ve=0;ve<z.length;++ve){var hi=z.charCodeAt(ve);if(55296<=hi&&57343>=hi){var _a=z.charCodeAt(++ve);hi=65536+((hi&1023)<<10)|_a&1023}if(127>=hi){if(pt>=$t)break;et[pt++]=hi}else{if(2047>=hi){if(pt+1>=$t)break;et[pt++]=192|hi>>6}else{if(65535>=hi){if(pt+2>=$t)break;et[pt++]=224|hi>>12}else{if(pt+3>=$t)break;et[pt++]=240|hi>>18,et[pt++]=128|hi>>12&63}et[pt++]=128|hi>>6&63}et[pt++]=128|hi&63}}et[pt]=0}return z=fi.alloc(et,Be),fi.copy(et,Be,z),z}return z}function C(z){if(typeof z=="object"){var et=fi.alloc(z,Be);return fi.copy(z,Be,et),et}return z}function N(){throw"cannot construct a VoidPtr, no constructor in IDL"}function T(){this.ptr=nn(),_(T)[this.ptr]=this}function b(){this.ptr=Cs(),_(b)[this.ptr]=this}function F(){this.ptr=Pn(),_(F)[this.ptr]=this}function B(){this.ptr=Ci(),_(B)[this.ptr]=this}function U(){this.ptr=br(),_(U)[this.ptr]=this}function Q(){this.ptr=gs(),_(Q)[this.ptr]=this}function M(){this.ptr=Mh(),_(M)[this.ptr]=this}function k(){this.ptr=Oo(),_(k)[this.ptr]=this}function y(){this.ptr=kh(),_(y)[this.ptr]=this}function c(){throw"cannot construct a Status, no constructor in IDL"}function g(){this.ptr=Xa(),_(g)[this.ptr]=this}function O(){this.ptr=kA(),_(O)[this.ptr]=this}function D(){this.ptr=$c(),_(D)[this.ptr]=this}function w(){this.ptr=wh(),_(w)[this.ptr]=this}function x(){this.ptr=el(),_(x)[this.ptr]=this}function H(){this.ptr=Wd(),_(H)[this.ptr]=this}function j(){this.ptr=eA(),_(j)[this.ptr]=this}function X(){this.ptr=Ho(),_(X)[this.ptr]=this}function tt(){this.ptr=jh(),_(tt)[this.ptr]=this}e=e===void 0?{}:e;var G=typeof e<"u"?e:{},It,gt;G.ready=new Promise(function(z,et){It=z,gt=et});var Yt=!1,Ut=!1;G.onRuntimeInitialized=function(){Yt=!0,Ut&&typeof G.onModuleLoaded=="function"&&G.onModuleLoaded(G)},G.onModuleParsed=function(){Ut=!0,Yt&&typeof G.onModuleLoaded=="function"&&G.onModuleLoaded(G)},G.isVersionSupported=function(z){return typeof z!="string"?!1:(z=z.split("."),2>z.length||3<z.length?!1:z[0]==1&&0<=z[1]&&5>=z[1]?!0:!(z[0]!=0||10<z[1]))};var Ct=Object.assign({},G),zt=typeof window=="object",kt=typeof importScripts=="function",Jt=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",Wt="";if(Jt){var bt=Xo("fs"),ee=Xo("path");Wt=kt?ee.dirname(Wt)+"/":__dirname+"/";var ce=function(z,et){return z=z.startsWith("file://")?new URL(z):ee.normalize(z),bt.readFileSync(z,et?void 0:"utf8")},je=function(z){return z=ce(z,!0),z.buffer||(z=new Uint8Array(z)),z},Se=function(z,et,pt){z=z.startsWith("file://")?new URL(z):ee.normalize(z),bt.readFile(z,function($t,ve){$t?pt($t):et(ve.buffer)})};1<process.argv.length&&process.argv[1].replace(/\\/g,"/"),process.argv.slice(2),G.inspect=function(){return"[Emscripten Module object]"}}else(zt||kt)&&(kt?Wt=self.location.href:typeof document<"u"&&document.currentScript&&(Wt=document.currentScript.src),t&&(Wt=t),Wt=Wt.indexOf("blob:")!==0?Wt.substr(0,Wt.replace(/[?#].*/,"").lastIndexOf("/")+1):"",ce=function(z){var et=new XMLHttpRequest;return et.open("GET",z,!1),et.send(null),et.responseText},kt&&(je=function(z){var et=new XMLHttpRequest;return et.open("GET",z,!1),et.responseType="arraybuffer",et.send(null),new Uint8Array(et.response)}),Se=function(z,et,pt){var $t=new XMLHttpRequest;$t.open("GET",z,!0),$t.responseType="arraybuffer",$t.onload=function(){$t.status==200||$t.status==0&&$t.response?et($t.response):pt()},$t.onerror=pt,$t.send(null)});var Ue=G.print||console.log.bind(console),Me=G.printErr||console.warn.bind(console);Object.assign(G,Ct),Ct=null;var Ce;G.wasmBinary&&(Ce=G.wasmBinary),typeof WebAssembly!="object"&&r("no native wasm support detected");var Fe,ni=!1,ze=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,Be,Mi,Ri,si,qe=[],Oi=[],gn=[],De=!1,Ye=0,Gi=null,An=null,Ne="draco_decoder.wasm";Ne.startsWith("data:application/octet-stream;base64,")||(Ne=i(Ne));var ei=0,_n=[null,[],[]],hs={b:function(z,et,pt){throw new d(z).init(et,pt),ei++,z},a:function(){r("")},g:function(z,et,pt){Mi.copyWithin(z,et,et+pt)},e:function(z){var et=Mi.length;if(z>>>=0,2147483648<z)return!1;for(var pt=1;4>=pt;pt*=2){var $t=et*(1+.2/pt);$t=Math.min($t,z+100663296);var ve=Math;$t=Math.max(z,$t),ve=ve.min.call(ve,2147483648,$t+(65536-$t%65536)%65536);t:{$t=Fe.buffer;try{Fe.grow(ve-$t.byteLength+65535>>>16),o();var hi=1;break t}catch{}hi=void 0}if(hi)return!0}return!1},f:function(z){return 52},d:function(z,et,pt,$t,ve){return 70},c:function(z,et,pt,$t){for(var ve=0,hi=0;hi<pt;hi++){var _a=si[et>>2],tc=si[et+4>>2];et+=8;for(var J=0;J<tc;J++){var v=Mi[_a+J],st=_n[z];v===0||v===10?((z===1?Ue:Me)(n(st,0)),st.length=0):st.push(v)}ve+=tc}return si[$t>>2]=ve,0}};(function(){function z(ve,hi){G.asm=ve.exports,Fe=G.asm.h,o(),Oi.unshift(G.asm.i),Ye--,G.monitorRunDependencies&&G.monitorRunDependencies(Ye),Ye==0&&(Gi!==null&&(clearInterval(Gi),Gi=null),An&&(ve=An,An=null,ve()))}function et(ve){z(ve.instance)}function pt(ve){return h().then(function(hi){return WebAssembly.instantiate(hi,$t)}).then(function(hi){return hi}).then(ve,function(hi){Me("failed to asynchronously prepare wasm: "+hi),r(hi)})}var $t={a:hs};if(Ye++,G.monitorRunDependencies&&G.monitorRunDependencies(Ye),G.instantiateWasm)try{return G.instantiateWasm($t,z)}catch(ve){Me("Module.instantiateWasm callback failed with error: "+ve),gt(ve)}return function(){return Ce||typeof WebAssembly.instantiateStreaming!="function"||Ne.startsWith("data:application/octet-stream;base64,")||Ne.startsWith("file://")||Jt||typeof fetch!="function"?pt(et):fetch(Ne,{credentials:"same-origin"}).then(function(ve){return WebAssembly.instantiateStreaming(ve,$t).then(et,function(hi){return Me("wasm streaming compile failed: "+hi),Me("falling back to ArrayBuffer instantiation"),pt(et)})})}().catch(gt),{}})();var Qi=G._emscripten_bind_VoidPtr___destroy___0=function(){return(Qi=G._emscripten_bind_VoidPtr___destroy___0=G.asm.k).apply(null,arguments)},nn=G._emscripten_bind_DecoderBuffer_DecoderBuffer_0=function(){return(nn=G._emscripten_bind_DecoderBuffer_DecoderBuffer_0=G.asm.l).apply(null,arguments)},ki=G._emscripten_bind_DecoderBuffer_Init_2=function(){return(ki=G._emscripten_bind_DecoderBuffer_Init_2=G.asm.m).apply(null,arguments)},sn=G._emscripten_bind_DecoderBuffer___destroy___0=function(){return(sn=G._emscripten_bind_DecoderBuffer___destroy___0=G.asm.n).apply(null,arguments)},Cs=G._emscripten_bind_AttributeTransformData_AttributeTransformData_0=function(){return(Cs=G._emscripten_bind_AttributeTransformData_AttributeTransformData_0=G.asm.o).apply(null,arguments)},cs=G._emscripten_bind_AttributeTransformData_transform_type_0=function(){return(cs=G._emscripten_bind_AttributeTransformData_transform_type_0=G.asm.p).apply(null,arguments)},xn=G._emscripten_bind_AttributeTransformData___destroy___0=function(){return(xn=G._emscripten_bind_AttributeTransformData___destroy___0=G.asm.q).apply(null,arguments)},Pn=G._emscripten_bind_GeometryAttribute_GeometryAttribute_0=function(){return(Pn=G._emscripten_bind_GeometryAttribute_GeometryAttribute_0=G.asm.r).apply(null,arguments)},Ai=G._emscripten_bind_GeometryAttribute___destroy___0=function(){return(Ai=G._emscripten_bind_GeometryAttribute___destroy___0=G.asm.s).apply(null,arguments)},Ci=G._emscripten_bind_PointAttribute_PointAttribute_0=function(){return(Ci=G._emscripten_bind_PointAttribute_PointAttribute_0=G.asm.t).apply(null,arguments)},Jn=G._emscripten_bind_PointAttribute_size_0=function(){return(Jn=G._emscripten_bind_PointAttribute_size_0=G.asm.u).apply(null,arguments)},ls=G._emscripten_bind_PointAttribute_GetAttributeTransformData_0=function(){return(ls=G._emscripten_bind_PointAttribute_GetAttributeTransformData_0=G.asm.v).apply(null,arguments)},ao=G._emscripten_bind_PointAttribute_attribute_type_0=function(){return(ao=G._emscripten_bind_PointAttribute_attribute_type_0=G.asm.w).apply(null,arguments)},qi=G._emscripten_bind_PointAttribute_data_type_0=function(){return(qi=G._emscripten_bind_PointAttribute_data_type_0=G.asm.x).apply(null,arguments)},hn=G._emscripten_bind_PointAttribute_num_components_0=function(){return(hn=G._emscripten_bind_PointAttribute_num_components_0=G.asm.y).apply(null,arguments)},jo=G._emscripten_bind_PointAttribute_normalized_0=function(){return(jo=G._emscripten_bind_PointAttribute_normalized_0=G.asm.z).apply(null,arguments)},ds=G._emscripten_bind_PointAttribute_byte_stride_0=function(){return(ds=G._emscripten_bind_PointAttribute_byte_stride_0=G.asm.A).apply(null,arguments)},on=G._emscripten_bind_PointAttribute_byte_offset_0=function(){return(on=G._emscripten_bind_PointAttribute_byte_offset_0=G.asm.B).apply(null,arguments)},ws=G._emscripten_bind_PointAttribute_unique_id_0=function(){return(ws=G._emscripten_bind_PointAttribute_unique_id_0=G.asm.C).apply(null,arguments)},Vo=G._emscripten_bind_PointAttribute___destroy___0=function(){return(Vo=G._emscripten_bind_PointAttribute___destroy___0=G.asm.D).apply(null,arguments)},br=G._emscripten_bind_AttributeQuantizationTransform_AttributeQuantizationTransform_0=function(){return(br=G._emscripten_bind_AttributeQuantizationTransform_AttributeQuantizationTransform_0=G.asm.E).apply(null,arguments)},So=G._emscripten_bind_AttributeQuantizationTransform_InitFromAttribute_1=function(){return(So=G._emscripten_bind_AttributeQuantizationTransform_InitFromAttribute_1=G.asm.F).apply(null,arguments)},$e=G._emscripten_bind_AttributeQuantizationTransform_quantization_bits_0=function(){return($e=G._emscripten_bind_AttributeQuantizationTransform_quantization_bits_0=G.asm.G).apply(null,arguments)},aa=G._emscripten_bind_AttributeQuantizationTransform_min_value_1=function(){return(aa=G._emscripten_bind_AttributeQuantizationTransform_min_value_1=G.asm.H).apply(null,arguments)},Yr=G._emscripten_bind_AttributeQuantizationTransform_range_0=function(){return(Yr=G._emscripten_bind_AttributeQuantizationTransform_range_0=G.asm.I).apply(null,arguments)},xs=G._emscripten_bind_AttributeQuantizationTransform___destroy___0=function(){return(xs=G._emscripten_bind_AttributeQuantizationTransform___destroy___0=G.asm.J).apply(null,arguments)},gs=G._emscripten_bind_AttributeOctahedronTransform_AttributeOctahedronTransform_0=function(){return(gs=G._emscripten_bind_AttributeOctahedronTransform_AttributeOctahedronTransform_0=G.asm.K).apply(null,arguments)},Tn=G._emscripten_bind_AttributeOctahedronTransform_InitFromAttribute_1=function(){return(Tn=G._emscripten_bind_AttributeOctahedronTransform_InitFromAttribute_1=G.asm.L).apply(null,arguments)},hr=G._emscripten_bind_AttributeOctahedronTransform_quantization_bits_0=function(){return(hr=G._emscripten_bind_AttributeOctahedronTransform_quantization_bits_0=G.asm.M).apply(null,arguments)},Uh=G._emscripten_bind_AttributeOctahedronTransform___destroy___0=function(){return(Uh=G._emscripten_bind_AttributeOctahedronTransform___destroy___0=G.asm.N).apply(null,arguments)},Mh=G._emscripten_bind_PointCloud_PointCloud_0=function(){return(Mh=G._emscripten_bind_PointCloud_PointCloud_0=G.asm.O).apply(null,arguments)},On=G._emscripten_bind_PointCloud_num_attributes_0=function(){return(On=G._emscripten_bind_PointCloud_num_attributes_0=G.asm.P).apply(null,arguments)},cr=G._emscripten_bind_PointCloud_num_points_0=function(){return(cr=G._emscripten_bind_PointCloud_num_points_0=G.asm.Q).apply(null,arguments)},Ii=G._emscripten_bind_PointCloud___destroy___0=function(){return(Ii=G._emscripten_bind_PointCloud___destroy___0=G.asm.R).apply(null,arguments)},Oo=G._emscripten_bind_Mesh_Mesh_0=function(){return(Oo=G._emscripten_bind_Mesh_Mesh_0=G.asm.S).apply(null,arguments)},Kc=G._emscripten_bind_Mesh_num_faces_0=function(){return(Kc=G._emscripten_bind_Mesh_num_faces_0=G.asm.T).apply(null,arguments)},Xc=G._emscripten_bind_Mesh_num_attributes_0=function(){return(Xc=G._emscripten_bind_Mesh_num_attributes_0=G.asm.U).apply(null,arguments)},qc=G._emscripten_bind_Mesh_num_points_0=function(){return(qc=G._emscripten_bind_Mesh_num_points_0=G.asm.V).apply(null,arguments)},Qh=G._emscripten_bind_Mesh___destroy___0=function(){return(Qh=G._emscripten_bind_Mesh___destroy___0=G.asm.W).apply(null,arguments)},kh=G._emscripten_bind_Metadata_Metadata_0=function(){return(kh=G._emscripten_bind_Metadata_Metadata_0=G.asm.X).apply(null,arguments)},Aa=G._emscripten_bind_Metadata___destroy___0=function(){return(Aa=G._emscripten_bind_Metadata___destroy___0=G.asm.Y).apply(null,arguments)},Lh=G._emscripten_bind_Status_code_0=function(){return(Lh=G._emscripten_bind_Status_code_0=G.asm.Z).apply(null,arguments)},ha=G._emscripten_bind_Status_ok_0=function(){return(ha=G._emscripten_bind_Status_ok_0=G.asm._).apply(null,arguments)},Ka=G._emscripten_bind_Status_error_msg_0=function(){return(Ka=G._emscripten_bind_Status_error_msg_0=G.asm.$).apply(null,arguments)},Vd=G._emscripten_bind_Status___destroy___0=function(){return(Vd=G._emscripten_bind_Status___destroy___0=G.asm.aa).apply(null,arguments)},Xa=G._emscripten_bind_DracoFloat32Array_DracoFloat32Array_0=function(){return(Xa=G._emscripten_bind_DracoFloat32Array_DracoFloat32Array_0=G.asm.ba).apply(null,arguments)},Sd=G._emscripten_bind_DracoFloat32Array_GetValue_1=function(){return(Sd=G._emscripten_bind_DracoFloat32Array_GetValue_1=G.asm.ca).apply(null,arguments)},qa=G._emscripten_bind_DracoFloat32Array_size_0=function(){return(qa=G._emscripten_bind_DracoFloat32Array_size_0=G.asm.da).apply(null,arguments)},lr=G._emscripten_bind_DracoFloat32Array___destroy___0=function(){return(lr=G._emscripten_bind_DracoFloat32Array___destroy___0=G.asm.ea).apply(null,arguments)},kA=G._emscripten_bind_DracoInt8Array_DracoInt8Array_0=function(){return(kA=G._emscripten_bind_DracoInt8Array_DracoInt8Array_0=G.asm.fa).apply(null,arguments)},$a=G._emscripten_bind_DracoInt8Array_GetValue_1=function(){return($a=G._emscripten_bind_DracoInt8Array_GetValue_1=G.asm.ga).apply(null,arguments)},Od=G._emscripten_bind_DracoInt8Array_size_0=function(){return(Od=G._emscripten_bind_DracoInt8Array_size_0=G.asm.ha).apply(null,arguments)},dr=G._emscripten_bind_DracoInt8Array___destroy___0=function(){return(dr=G._emscripten_bind_DracoInt8Array___destroy___0=G.asm.ia).apply(null,arguments)},$c=G._emscripten_bind_DracoUInt8Array_DracoUInt8Array_0=function(){return($c=G._emscripten_bind_DracoUInt8Array_DracoUInt8Array_0=G.asm.ja).apply(null,arguments)},tl=G._emscripten_bind_DracoUInt8Array_GetValue_1=function(){return(tl=G._emscripten_bind_DracoUInt8Array_GetValue_1=G.asm.ka).apply(null,arguments)},yh=G._emscripten_bind_DracoUInt8Array_size_0=function(){return(yh=G._emscripten_bind_DracoUInt8Array_size_0=G.asm.la).apply(null,arguments)},mr=G._emscripten_bind_DracoUInt8Array___destroy___0=function(){return(mr=G._emscripten_bind_DracoUInt8Array___destroy___0=G.asm.ma).apply(null,arguments)},wh=G._emscripten_bind_DracoInt16Array_DracoInt16Array_0=function(){return(wh=G._emscripten_bind_DracoInt16Array_DracoInt16Array_0=G.asm.na).apply(null,arguments)},Bd=G._emscripten_bind_DracoInt16Array_GetValue_1=function(){return(Bd=G._emscripten_bind_DracoInt16Array_GetValue_1=G.asm.oa).apply(null,arguments)},xh=G._emscripten_bind_DracoInt16Array_size_0=function(){return(xh=G._emscripten_bind_DracoInt16Array_size_0=G.asm.pa).apply(null,arguments)},Ph=G._emscripten_bind_DracoInt16Array___destroy___0=function(){return(Ph=G._emscripten_bind_DracoInt16Array___destroy___0=G.asm.qa).apply(null,arguments)},el=G._emscripten_bind_DracoUInt16Array_DracoUInt16Array_0=function(){return(el=G._emscripten_bind_DracoUInt16Array_DracoUInt16Array_0=G.asm.ra).apply(null,arguments)},il=G._emscripten_bind_DracoUInt16Array_GetValue_1=function(){return(il=G._emscripten_bind_DracoUInt16Array_GetValue_1=G.asm.sa).apply(null,arguments)},Gd=G._emscripten_bind_DracoUInt16Array_size_0=function(){return(Gd=G._emscripten_bind_DracoUInt16Array_size_0=G.asm.ta).apply(null,arguments)},tA=G._emscripten_bind_DracoUInt16Array___destroy___0=function(){return(tA=G._emscripten_bind_DracoUInt16Array___destroy___0=G.asm.ua).apply(null,arguments)},Wd=G._emscripten_bind_DracoInt32Array_DracoInt32Array_0=function(){return(Wd=G._emscripten_bind_DracoInt32Array_DracoInt32Array_0=G.asm.va).apply(null,arguments)},Dd=G._emscripten_bind_DracoInt32Array_GetValue_1=function(){return(Dd=G._emscripten_bind_DracoInt32Array_GetValue_1=G.asm.wa).apply(null,arguments)},Ud=G._emscripten_bind_DracoInt32Array_size_0=function(){return(Ud=G._emscripten_bind_DracoInt32Array_size_0=G.asm.xa).apply(null,arguments)},LA=G._emscripten_bind_DracoInt32Array___destroy___0=function(){return(LA=G._emscripten_bind_DracoInt32Array___destroy___0=G.asm.ya).apply(null,arguments)},eA=G._emscripten_bind_DracoUInt32Array_DracoUInt32Array_0=function(){return(eA=G._emscripten_bind_DracoUInt32Array_DracoUInt32Array_0=G.asm.za).apply(null,arguments)},Md=G._emscripten_bind_DracoUInt32Array_GetValue_1=function(){return(Md=G._emscripten_bind_DracoUInt32Array_GetValue_1=G.asm.Aa).apply(null,arguments)},Qd=G._emscripten_bind_DracoUInt32Array_size_0=function(){return(Qd=G._emscripten_bind_DracoUInt32Array_size_0=G.asm.Ba).apply(null,arguments)},yA=G._emscripten_bind_DracoUInt32Array___destroy___0=function(){return(yA=G._emscripten_bind_DracoUInt32Array___destroy___0=G.asm.Ca).apply(null,arguments)},Ho=G._emscripten_bind_MetadataQuerier_MetadataQuerier_0=function(){return(Ho=G._emscripten_bind_MetadataQuerier_MetadataQuerier_0=G.asm.Da).apply(null,arguments)},nl=G._emscripten_bind_MetadataQuerier_HasEntry_2=function(){return(nl=G._emscripten_bind_MetadataQuerier_HasEntry_2=G.asm.Ea).apply(null,arguments)},vo=G._emscripten_bind_MetadataQuerier_GetIntEntry_2=function(){return(vo=G._emscripten_bind_MetadataQuerier_GetIntEntry_2=G.asm.Fa).apply(null,arguments)},iA=G._emscripten_bind_MetadataQuerier_GetIntEntryArray_3=function(){return(iA=G._emscripten_bind_MetadataQuerier_GetIntEntryArray_3=G.asm.Ga).apply(null,arguments)},Jh=G._emscripten_bind_MetadataQuerier_GetDoubleEntry_2=function(){return(Jh=G._emscripten_bind_MetadataQuerier_GetDoubleEntry_2=G.asm.Ha).apply(null,arguments)},kd=G._emscripten_bind_MetadataQuerier_GetStringEntry_2=function(){return(kd=G._emscripten_bind_MetadataQuerier_GetStringEntry_2=G.asm.Ia).apply(null,arguments)},Ld=G._emscripten_bind_MetadataQuerier_NumEntries_1=function(){return(Ld=G._emscripten_bind_MetadataQuerier_NumEntries_1=G.asm.Ja).apply(null,arguments)},jn=G._emscripten_bind_MetadataQuerier_GetEntryName_2=function(){return(jn=G._emscripten_bind_MetadataQuerier_GetEntryName_2=G.asm.Ka).apply(null,arguments)},sl=G._emscripten_bind_MetadataQuerier___destroy___0=function(){return(sl=G._emscripten_bind_MetadataQuerier___destroy___0=G.asm.La).apply(null,arguments)},jh=G._emscripten_bind_Decoder_Decoder_0=function(){return(jh=G._emscripten_bind_Decoder_Decoder_0=G.asm.Ma).apply(null,arguments)},nA=G._emscripten_bind_Decoder_DecodeArrayToPointCloud_3=function(){return(nA=G._emscripten_bind_Decoder_DecodeArrayToPointCloud_3=G.asm.Na).apply(null,arguments)},ca=G._emscripten_bind_Decoder_DecodeArrayToMesh_3=function(){return(ca=G._emscripten_bind_Decoder_DecodeArrayToMesh_3=G.asm.Oa).apply(null,arguments)},Hh=G._emscripten_bind_Decoder_GetAttributeId_2=function(){return(Hh=G._emscripten_bind_Decoder_GetAttributeId_2=G.asm.Pa).apply(null,arguments)},vh=G._emscripten_bind_Decoder_GetAttributeIdByName_2=function(){return(vh=G._emscripten_bind_Decoder_GetAttributeIdByName_2=G.asm.Qa).apply(null,arguments)},wA=G._emscripten_bind_Decoder_GetAttributeIdByMetadataEntry_3=function(){return(wA=G._emscripten_bind_Decoder_GetAttributeIdByMetadataEntry_3=G.asm.Ra).apply(null,arguments)},ol=G._emscripten_bind_Decoder_GetAttribute_2=function(){return(ol=G._emscripten_bind_Decoder_GetAttribute_2=G.asm.Sa).apply(null,arguments)},zh=G._emscripten_bind_Decoder_GetAttributeByUniqueId_2=function(){return(zh=G._emscripten_bind_Decoder_GetAttributeByUniqueId_2=G.asm.Ta).apply(null,arguments)},yd=G._emscripten_bind_Decoder_GetMetadata_1=function(){return(yd=G._emscripten_bind_Decoder_GetMetadata_1=G.asm.Ua).apply(null,arguments)},Kh=G._emscripten_bind_Decoder_GetAttributeMetadata_2=function(){return(Kh=G._emscripten_bind_Decoder_GetAttributeMetadata_2=G.asm.Va).apply(null,arguments)},Vs=G._emscripten_bind_Decoder_GetFaceFromMesh_3=function(){return(Vs=G._emscripten_bind_Decoder_GetFaceFromMesh_3=G.asm.Wa).apply(null,arguments)},Xh=G._emscripten_bind_Decoder_GetTriangleStripsFromMesh_2=function(){return(Xh=G._emscripten_bind_Decoder_GetTriangleStripsFromMesh_2=G.asm.Xa).apply(null,arguments)},wd=G._emscripten_bind_Decoder_GetTrianglesUInt16Array_3=function(){return(wd=G._emscripten_bind_Decoder_GetTrianglesUInt16Array_3=G.asm.Ya).apply(null,arguments)},rl=G._emscripten_bind_Decoder_GetTrianglesUInt32Array_3=function(){return(rl=G._emscripten_bind_Decoder_GetTrianglesUInt32Array_3=G.asm.Za).apply(null,arguments)},Ao=G._emscripten_bind_Decoder_GetAttributeFloat_3=function(){return(Ao=G._emscripten_bind_Decoder_GetAttributeFloat_3=G.asm._a).apply(null,arguments)},ho=G._emscripten_bind_Decoder_GetAttributeFloatForAllPoints_3=function(){return(ho=G._emscripten_bind_Decoder_GetAttributeFloatForAllPoints_3=G.asm.$a).apply(null,arguments)},xd=G._emscripten_bind_Decoder_GetAttributeIntForAllPoints_3=function(){return(xd=G._emscripten_bind_Decoder_GetAttributeIntForAllPoints_3=G.asm.ab).apply(null,arguments)},Pd=G._emscripten_bind_Decoder_GetAttributeInt8ForAllPoints_3=function(){return(Pd=G._emscripten_bind_Decoder_GetAttributeInt8ForAllPoints_3=G.asm.bb).apply(null,arguments)},Bo=G._emscripten_bind_Decoder_GetAttributeUInt8ForAllPoints_3=function(){return(Bo=G._emscripten_bind_Decoder_GetAttributeUInt8ForAllPoints_3=G.asm.cb).apply(null,arguments)},xA=G._emscripten_bind_Decoder_GetAttributeInt16ForAllPoints_3=function(){return(xA=G._emscripten_bind_Decoder_GetAttributeInt16ForAllPoints_3=G.asm.db).apply(null,arguments)},la=G._emscripten_bind_Decoder_GetAttributeUInt16ForAllPoints_3=function(){return(la=G._emscripten_bind_Decoder_GetAttributeUInt16ForAllPoints_3=G.asm.eb).apply(null,arguments)},da=G._emscripten_bind_Decoder_GetAttributeInt32ForAllPoints_3=function(){return(da=G._emscripten_bind_Decoder_GetAttributeInt32ForAllPoints_3=G.asm.fb).apply(null,arguments)},Jd=G._emscripten_bind_Decoder_GetAttributeUInt32ForAllPoints_3=function(){return(Jd=G._emscripten_bind_Decoder_GetAttributeUInt32ForAllPoints_3=G.asm.gb).apply(null,arguments)},jd=G._emscripten_bind_Decoder_GetAttributeDataArrayForAllPoints_5=function(){return(jd=G._emscripten_bind_Decoder_GetAttributeDataArrayForAllPoints_5=G.asm.hb).apply(null,arguments)},Hd=G._emscripten_bind_Decoder_SkipAttributeTransform_1=function(){return(Hd=G._emscripten_bind_Decoder_SkipAttributeTransform_1=G.asm.ib).apply(null,arguments)},vd=G._emscripten_bind_Decoder_GetEncodedGeometryType_Deprecated_1=function(){return(vd=G._emscripten_bind_Decoder_GetEncodedGeometryType_Deprecated_1=G.asm.jb).apply(null,arguments)},zd=G._emscripten_bind_Decoder_DecodeBufferToPointCloud_2=function(){return(zd=G._emscripten_bind_Decoder_DecodeBufferToPointCloud_2=G.asm.kb).apply(null,arguments)},qh=G._emscripten_bind_Decoder_DecodeBufferToMesh_2=function(){return(qh=G._emscripten_bind_Decoder_DecodeBufferToMesh_2=G.asm.lb).apply(null,arguments)},PA=G._emscripten_bind_Decoder___destroy___0=function(){return(PA=G._emscripten_bind_Decoder___destroy___0=G.asm.mb).apply(null,arguments)},ma=G._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_INVALID_TRANSFORM=function(){return(ma=G._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_INVALID_TRANSFORM=G.asm.nb).apply(null,arguments)},al=G._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_NO_TRANSFORM=function(){return(al=G._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_NO_TRANSFORM=G.asm.ob).apply(null,arguments)},fa=G._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_QUANTIZATION_TRANSFORM=function(){return(fa=G._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_QUANTIZATION_TRANSFORM=G.asm.pb).apply(null,arguments)},Ea=G._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_OCTAHEDRON_TRANSFORM=function(){return(Ea=G._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_OCTAHEDRON_TRANSFORM=G.asm.qb).apply(null,arguments)},sA=G._emscripten_enum_draco_GeometryAttribute_Type_INVALID=function(){return(sA=G._emscripten_enum_draco_GeometryAttribute_Type_INVALID=G.asm.rb).apply(null,arguments)},Al=G._emscripten_enum_draco_GeometryAttribute_Type_POSITION=function(){return(Al=G._emscripten_enum_draco_GeometryAttribute_Type_POSITION=G.asm.sb).apply(null,arguments)},Kd=G._emscripten_enum_draco_GeometryAttribute_Type_NORMAL=function(){return(Kd=G._emscripten_enum_draco_GeometryAttribute_Type_NORMAL=G.asm.tb).apply(null,arguments)},JA=G._emscripten_enum_draco_GeometryAttribute_Type_COLOR=function(){return(JA=G._emscripten_enum_draco_GeometryAttribute_Type_COLOR=G.asm.ub).apply(null,arguments)},$h=G._emscripten_enum_draco_GeometryAttribute_Type_TEX_COORD=function(){return($h=G._emscripten_enum_draco_GeometryAttribute_Type_TEX_COORD=G.asm.vb).apply(null,arguments)},Xd=G._emscripten_enum_draco_GeometryAttribute_Type_GENERIC=function(){return(Xd=G._emscripten_enum_draco_GeometryAttribute_Type_GENERIC=G.asm.wb).apply(null,arguments)},hl=G._emscripten_enum_draco_EncodedGeometryType_INVALID_GEOMETRY_TYPE=function(){return(hl=G._emscripten_enum_draco_EncodedGeometryType_INVALID_GEOMETRY_TYPE=G.asm.xb).apply(null,arguments)},qd=G._emscripten_enum_draco_EncodedGeometryType_POINT_CLOUD=function(){return(qd=G._emscripten_enum_draco_EncodedGeometryType_POINT_CLOUD=G.asm.yb).apply(null,arguments)},$d=G._emscripten_enum_draco_EncodedGeometryType_TRIANGULAR_MESH=function(){return($d=G._emscripten_enum_draco_EncodedGeometryType_TRIANGULAR_MESH=G.asm.zb).apply(null,arguments)},tm=G._emscripten_enum_draco_DataType_DT_INVALID=function(){return(tm=G._emscripten_enum_draco_DataType_DT_INVALID=G.asm.Ab).apply(null,arguments)},em=G._emscripten_enum_draco_DataType_DT_INT8=function(){return(em=G._emscripten_enum_draco_DataType_DT_INT8=G.asm.Bb).apply(null,arguments)},im=G._emscripten_enum_draco_DataType_DT_UINT8=function(){return(im=G._emscripten_enum_draco_DataType_DT_UINT8=G.asm.Cb).apply(null,arguments)},nm=G._emscripten_enum_draco_DataType_DT_INT16=function(){return(nm=G._emscripten_enum_draco_DataType_DT_INT16=G.asm.Db).apply(null,arguments)},sm=G._emscripten_enum_draco_DataType_DT_UINT16=function(){return(sm=G._emscripten_enum_draco_DataType_DT_UINT16=G.asm.Eb).apply(null,arguments)},om=G._emscripten_enum_draco_DataType_DT_INT32=function(){return(om=G._emscripten_enum_draco_DataType_DT_INT32=G.asm.Fb).apply(null,arguments)},cl=G._emscripten_enum_draco_DataType_DT_UINT32=function(){return(cl=G._emscripten_enum_draco_DataType_DT_UINT32=G.asm.Gb).apply(null,arguments)},rm=G._emscripten_enum_draco_DataType_DT_INT64=function(){return(rm=G._emscripten_enum_draco_DataType_DT_INT64=G.asm.Hb).apply(null,arguments)},am=G._emscripten_enum_draco_DataType_DT_UINT64=function(){return(am=G._emscripten_enum_draco_DataType_DT_UINT64=G.asm.Ib).apply(null,arguments)},Am=G._emscripten_enum_draco_DataType_DT_FLOAT32=function(){return(Am=G._emscripten_enum_draco_DataType_DT_FLOAT32=G.asm.Jb).apply(null,arguments)},ll=G._emscripten_enum_draco_DataType_DT_FLOAT64=function(){return(ll=G._emscripten_enum_draco_DataType_DT_FLOAT64=G.asm.Kb).apply(null,arguments)},hm=G._emscripten_enum_draco_DataType_DT_BOOL=function(){return(hm=G._emscripten_enum_draco_DataType_DT_BOOL=G.asm.Lb).apply(null,arguments)},oA=G._emscripten_enum_draco_DataType_DT_TYPES_COUNT=function(){return(oA=G._emscripten_enum_draco_DataType_DT_TYPES_COUNT=G.asm.Mb).apply(null,arguments)},cm=G._emscripten_enum_draco_StatusCode_OK=function(){return(cm=G._emscripten_enum_draco_StatusCode_OK=G.asm.Nb).apply(null,arguments)},jA=G._emscripten_enum_draco_StatusCode_DRACO_ERROR=function(){return(jA=G._emscripten_enum_draco_StatusCode_DRACO_ERROR=G.asm.Ob).apply(null,arguments)},lm=G._emscripten_enum_draco_StatusCode_IO_ERROR=function(){return(lm=G._emscripten_enum_draco_StatusCode_IO_ERROR=G.asm.Pb).apply(null,arguments)},dm=G._emscripten_enum_draco_StatusCode_INVALID_PARAMETER=function(){return(dm=G._emscripten_enum_draco_StatusCode_INVALID_PARAMETER=G.asm.Qb).apply(null,arguments)},dl=G._emscripten_enum_draco_StatusCode_UNSUPPORTED_VERSION=function(){return(dl=G._emscripten_enum_draco_StatusCode_UNSUPPORTED_VERSION=G.asm.Rb).apply(null,arguments)},mm=G._emscripten_enum_draco_StatusCode_UNKNOWN_VERSION=function(){return(mm=G._emscripten_enum_draco_StatusCode_UNKNOWN_VERSION=G.asm.Sb).apply(null,arguments)};G._malloc=function(){return(G._malloc=G.asm.Tb).apply(null,arguments)},G._free=function(){return(G._free=G.asm.Ub).apply(null,arguments)};var fm=function(){return(fm=G.asm.Vb).apply(null,arguments)};G.___start_em_js=15856,G.___stop_em_js=15954;var rA;if(An=function z(){rA||f(),rA||(An=z)},G.preInit)for(typeof G.preInit=="function"&&(G.preInit=[G.preInit]);0<G.preInit.length;)G.preInit.pop()();f(),E.prototype=Object.create(E.prototype),E.prototype.constructor=E,E.prototype.__class__=E,E.__cache__={},G.WrapperObject=E,G.getCache=_,G.wrapPointer=R,G.castObject=function(z,et){return R(z.ptr,et)},G.NULL=R(0),G.destroy=function(z){if(!z.__destroy__)throw"Error: Cannot destroy object. (Did you create it yourself?)";z.__destroy__(),delete _(z.__class__)[z.ptr]},G.compare=function(z,et){return z.ptr===et.ptr},G.getPointer=function(z){return z.ptr},G.getClass=function(z){return z.__class__};var fi={buffer:0,size:0,pos:0,temps:[],needed:0,prepare:function(){if(fi.needed){for(var z=0;z<fi.temps.length;z++)G._free(fi.temps[z]);fi.temps.length=0,G._free(fi.buffer),fi.buffer=0,fi.size+=fi.needed,fi.needed=0}fi.buffer||(fi.size+=128,fi.buffer=G._malloc(fi.size),fi.buffer||r(void 0)),fi.pos=0},alloc:function(z,et){return fi.buffer||r(void 0),z=z.length*et.BYTES_PER_ELEMENT,z=z+7&-8,fi.pos+z>=fi.size?(0<z||r(void 0),fi.needed+=z,et=G._malloc(z),fi.temps.push(et)):(et=fi.buffer+fi.pos,fi.pos+=z),et},copy:function(z,et,pt){switch(pt>>>=0,et.BYTES_PER_ELEMENT){case 2:pt>>>=1;break;case 4:pt>>>=2;break;case 8:pt>>>=3}for(var $t=0;$t<z.length;$t++)et[pt+$t]=z[$t]}};return N.prototype=Object.create(E.prototype),N.prototype.constructor=N,N.prototype.__class__=N,N.__cache__={},G.VoidPtr=N,N.prototype.__destroy__=N.prototype.__destroy__=function(){Qi(this.ptr)},T.prototype=Object.create(E.prototype),T.prototype.constructor=T,T.prototype.__class__=T,T.__cache__={},G.DecoderBuffer=T,T.prototype.Init=T.prototype.Init=function(z,et){var pt=this.ptr;fi.prepare(),typeof z=="object"&&(z=C(z)),et&&typeof et=="object"&&(et=et.ptr),ki(pt,z,et)},T.prototype.__destroy__=T.prototype.__destroy__=function(){sn(this.ptr)},b.prototype=Object.create(E.prototype),b.prototype.constructor=b,b.prototype.__class__=b,b.__cache__={},G.AttributeTransformData=b,b.prototype.transform_type=b.prototype.transform_type=function(){return cs(this.ptr)},b.prototype.__destroy__=b.prototype.__destroy__=function(){xn(this.ptr)},F.prototype=Object.create(E.prototype),F.prototype.constructor=F,F.prototype.__class__=F,F.__cache__={},G.GeometryAttribute=F,F.prototype.__destroy__=F.prototype.__destroy__=function(){Ai(this.ptr)},B.prototype=Object.create(E.prototype),B.prototype.constructor=B,B.prototype.__class__=B,B.__cache__={},G.PointAttribute=B,B.prototype.size=B.prototype.size=function(){return Jn(this.ptr)},B.prototype.GetAttributeTransformData=B.prototype.GetAttributeTransformData=function(){return R(ls(this.ptr),b)},B.prototype.attribute_type=B.prototype.attribute_type=function(){return ao(this.ptr)},B.prototype.data_type=B.prototype.data_type=function(){return qi(this.ptr)},B.prototype.num_components=B.prototype.num_components=function(){return hn(this.ptr)},B.prototype.normalized=B.prototype.normalized=function(){return!!jo(this.ptr)},B.prototype.byte_stride=B.prototype.byte_stride=function(){return ds(this.ptr)},B.prototype.byte_offset=B.prototype.byte_offset=function(){return on(this.ptr)},B.prototype.unique_id=B.prototype.unique_id=function(){return ws(this.ptr)},B.prototype.__destroy__=B.prototype.__destroy__=function(){Vo(this.ptr)},U.prototype=Object.create(E.prototype),U.prototype.constructor=U,U.prototype.__class__=U,U.__cache__={},G.AttributeQuantizationTransform=U,U.prototype.InitFromAttribute=U.prototype.InitFromAttribute=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),!!So(et,z)},U.prototype.quantization_bits=U.prototype.quantization_bits=function(){return $e(this.ptr)},U.prototype.min_value=U.prototype.min_value=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),aa(et,z)},U.prototype.range=U.prototype.range=function(){return Yr(this.ptr)},U.prototype.__destroy__=U.prototype.__destroy__=function(){xs(this.ptr)},Q.prototype=Object.create(E.prototype),Q.prototype.constructor=Q,Q.prototype.__class__=Q,Q.__cache__={},G.AttributeOctahedronTransform=Q,Q.prototype.InitFromAttribute=Q.prototype.InitFromAttribute=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),!!Tn(et,z)},Q.prototype.quantization_bits=Q.prototype.quantization_bits=function(){return hr(this.ptr)},Q.prototype.__destroy__=Q.prototype.__destroy__=function(){Uh(this.ptr)},M.prototype=Object.create(E.prototype),M.prototype.constructor=M,M.prototype.__class__=M,M.__cache__={},G.PointCloud=M,M.prototype.num_attributes=M.prototype.num_attributes=function(){return On(this.ptr)},M.prototype.num_points=M.prototype.num_points=function(){return cr(this.ptr)},M.prototype.__destroy__=M.prototype.__destroy__=function(){Ii(this.ptr)},k.prototype=Object.create(E.prototype),k.prototype.constructor=k,k.prototype.__class__=k,k.__cache__={},G.Mesh=k,k.prototype.num_faces=k.prototype.num_faces=function(){return Kc(this.ptr)},k.prototype.num_attributes=k.prototype.num_attributes=function(){return Xc(this.ptr)},k.prototype.num_points=k.prototype.num_points=function(){return qc(this.ptr)},k.prototype.__destroy__=k.prototype.__destroy__=function(){Qh(this.ptr)},y.prototype=Object.create(E.prototype),y.prototype.constructor=y,y.prototype.__class__=y,y.__cache__={},G.Metadata=y,y.prototype.__destroy__=y.prototype.__destroy__=function(){Aa(this.ptr)},c.prototype=Object.create(E.prototype),c.prototype.constructor=c,c.prototype.__class__=c,c.__cache__={},G.Status=c,c.prototype.code=c.prototype.code=function(){return Lh(this.ptr)},c.prototype.ok=c.prototype.ok=function(){return!!ha(this.ptr)},c.prototype.error_msg=c.prototype.error_msg=function(){return s(Ka(this.ptr))},c.prototype.__destroy__=c.prototype.__destroy__=function(){Vd(this.ptr)},g.prototype=Object.create(E.prototype),g.prototype.constructor=g,g.prototype.__class__=g,g.__cache__={},G.DracoFloat32Array=g,g.prototype.GetValue=g.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),Sd(et,z)},g.prototype.size=g.prototype.size=function(){return qa(this.ptr)},g.prototype.__destroy__=g.prototype.__destroy__=function(){lr(this.ptr)},O.prototype=Object.create(E.prototype),O.prototype.constructor=O,O.prototype.__class__=O,O.__cache__={},G.DracoInt8Array=O,O.prototype.GetValue=O.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),$a(et,z)},O.prototype.size=O.prototype.size=function(){return Od(this.ptr)},O.prototype.__destroy__=O.prototype.__destroy__=function(){dr(this.ptr)},D.prototype=Object.create(E.prototype),D.prototype.constructor=D,D.prototype.__class__=D,D.__cache__={},G.DracoUInt8Array=D,D.prototype.GetValue=D.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),tl(et,z)},D.prototype.size=D.prototype.size=function(){return yh(this.ptr)},D.prototype.__destroy__=D.prototype.__destroy__=function(){mr(this.ptr)},w.prototype=Object.create(E.prototype),w.prototype.constructor=w,w.prototype.__class__=w,w.__cache__={},G.DracoInt16Array=w,w.prototype.GetValue=w.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),Bd(et,z)},w.prototype.size=w.prototype.size=function(){return xh(this.ptr)},w.prototype.__destroy__=w.prototype.__destroy__=function(){Ph(this.ptr)},x.prototype=Object.create(E.prototype),x.prototype.constructor=x,x.prototype.__class__=x,x.__cache__={},G.DracoUInt16Array=x,x.prototype.GetValue=x.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),il(et,z)},x.prototype.size=x.prototype.size=function(){return Gd(this.ptr)},x.prototype.__destroy__=x.prototype.__destroy__=function(){tA(this.ptr)},H.prototype=Object.create(E.prototype),H.prototype.constructor=H,H.prototype.__class__=H,H.__cache__={},G.DracoInt32Array=H,H.prototype.GetValue=H.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),Dd(et,z)},H.prototype.size=H.prototype.size=function(){return Ud(this.ptr)},H.prototype.__destroy__=H.prototype.__destroy__=function(){LA(this.ptr)},j.prototype=Object.create(E.prototype),j.prototype.constructor=j,j.prototype.__class__=j,j.__cache__={},G.DracoUInt32Array=j,j.prototype.GetValue=j.prototype.GetValue=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),Md(et,z)},j.prototype.size=j.prototype.size=function(){return Qd(this.ptr)},j.prototype.__destroy__=j.prototype.__destroy__=function(){yA(this.ptr)},X.prototype=Object.create(E.prototype),X.prototype.constructor=X,X.prototype.__class__=X,X.__cache__={},G.MetadataQuerier=X,X.prototype.HasEntry=X.prototype.HasEntry=function(z,et){var pt=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),!!nl(pt,z,et)},X.prototype.GetIntEntry=X.prototype.GetIntEntry=function(z,et){var pt=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),vo(pt,z,et)},X.prototype.GetIntEntryArray=X.prototype.GetIntEntryArray=function(z,et,pt){var $t=this.ptr;fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),pt&&typeof pt=="object"&&(pt=pt.ptr),iA($t,z,et,pt)},X.prototype.GetDoubleEntry=X.prototype.GetDoubleEntry=function(z,et){var pt=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),Jh(pt,z,et)},X.prototype.GetStringEntry=X.prototype.GetStringEntry=function(z,et){var pt=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),s(kd(pt,z,et))},X.prototype.NumEntries=X.prototype.NumEntries=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),Ld(et,z)},X.prototype.GetEntryName=X.prototype.GetEntryName=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),s(jn(pt,z,et))},X.prototype.__destroy__=X.prototype.__destroy__=function(){sl(this.ptr)},tt.prototype=Object.create(E.prototype),tt.prototype.constructor=tt,tt.prototype.__class__=tt,tt.__cache__={},G.Decoder=tt,tt.prototype.DecodeArrayToPointCloud=tt.prototype.DecodeArrayToPointCloud=function(z,et,pt){var $t=this.ptr;return fi.prepare(),typeof z=="object"&&(z=C(z)),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),R(nA($t,z,et,pt),c)},tt.prototype.DecodeArrayToMesh=tt.prototype.DecodeArrayToMesh=function(z,et,pt){var $t=this.ptr;return fi.prepare(),typeof z=="object"&&(z=C(z)),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),R(ca($t,z,et,pt),c)},tt.prototype.GetAttributeId=tt.prototype.GetAttributeId=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),Hh(pt,z,et)},tt.prototype.GetAttributeIdByName=tt.prototype.GetAttributeIdByName=function(z,et){var pt=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),vh(pt,z,et)},tt.prototype.GetAttributeIdByMetadataEntry=tt.prototype.GetAttributeIdByMetadataEntry=function(z,et,pt){var $t=this.ptr;return fi.prepare(),z&&typeof z=="object"&&(z=z.ptr),et=et&&typeof et=="object"?et.ptr:I(et),pt=pt&&typeof pt=="object"?pt.ptr:I(pt),wA($t,z,et,pt)},tt.prototype.GetAttribute=tt.prototype.GetAttribute=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),R(ol(pt,z,et),B)},tt.prototype.GetAttributeByUniqueId=tt.prototype.GetAttributeByUniqueId=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),R(zh(pt,z,et),B)},tt.prototype.GetMetadata=tt.prototype.GetMetadata=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),R(yd(et,z),y)},tt.prototype.GetAttributeMetadata=tt.prototype.GetAttributeMetadata=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),R(Kh(pt,z,et),y)},tt.prototype.GetFaceFromMesh=tt.prototype.GetFaceFromMesh=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!Vs($t,z,et,pt)},tt.prototype.GetTriangleStripsFromMesh=tt.prototype.GetTriangleStripsFromMesh=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),Xh(pt,z,et)},tt.prototype.GetTrianglesUInt16Array=tt.prototype.GetTrianglesUInt16Array=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!wd($t,z,et,pt)},tt.prototype.GetTrianglesUInt32Array=tt.prototype.GetTrianglesUInt32Array=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!rl($t,z,et,pt)},tt.prototype.GetAttributeFloat=tt.prototype.GetAttributeFloat=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!Ao($t,z,et,pt)},tt.prototype.GetAttributeFloatForAllPoints=tt.prototype.GetAttributeFloatForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!ho($t,z,et,pt)},tt.prototype.GetAttributeIntForAllPoints=tt.prototype.GetAttributeIntForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!xd($t,z,et,pt)},tt.prototype.GetAttributeInt8ForAllPoints=tt.prototype.GetAttributeInt8ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!Pd($t,z,et,pt)},tt.prototype.GetAttributeUInt8ForAllPoints=tt.prototype.GetAttributeUInt8ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!Bo($t,z,et,pt)},tt.prototype.GetAttributeInt16ForAllPoints=tt.prototype.GetAttributeInt16ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!xA($t,z,et,pt)},tt.prototype.GetAttributeUInt16ForAllPoints=tt.prototype.GetAttributeUInt16ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!la($t,z,et,pt)},tt.prototype.GetAttributeInt32ForAllPoints=tt.prototype.GetAttributeInt32ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!da($t,z,et,pt)},tt.prototype.GetAttributeUInt32ForAllPoints=tt.prototype.GetAttributeUInt32ForAllPoints=function(z,et,pt){var $t=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),!!Jd($t,z,et,pt)},tt.prototype.GetAttributeDataArrayForAllPoints=tt.prototype.GetAttributeDataArrayForAllPoints=function(z,et,pt,$t,ve){var hi=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),pt&&typeof pt=="object"&&(pt=pt.ptr),$t&&typeof $t=="object"&&($t=$t.ptr),ve&&typeof ve=="object"&&(ve=ve.ptr),!!jd(hi,z,et,pt,$t,ve)},tt.prototype.SkipAttributeTransform=tt.prototype.SkipAttributeTransform=function(z){var et=this.ptr;z&&typeof z=="object"&&(z=z.ptr),Hd(et,z)},tt.prototype.GetEncodedGeometryType_Deprecated=tt.prototype.GetEncodedGeometryType_Deprecated=function(z){var et=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),vd(et,z)},tt.prototype.DecodeBufferToPointCloud=tt.prototype.DecodeBufferToPointCloud=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),R(zd(pt,z,et),c)},tt.prototype.DecodeBufferToMesh=tt.prototype.DecodeBufferToMesh=function(z,et){var pt=this.ptr;return z&&typeof z=="object"&&(z=z.ptr),et&&typeof et=="object"&&(et=et.ptr),R(qh(pt,z,et),c)},tt.prototype.__destroy__=tt.prototype.__destroy__=function(){PA(this.ptr)},function(){function z(){G.ATTRIBUTE_INVALID_TRANSFORM=ma(),G.ATTRIBUTE_NO_TRANSFORM=al(),G.ATTRIBUTE_QUANTIZATION_TRANSFORM=fa(),G.ATTRIBUTE_OCTAHEDRON_TRANSFORM=Ea(),G.INVALID=sA(),G.POSITION=Al(),G.NORMAL=Kd(),G.COLOR=JA(),G.TEX_COORD=$h(),G.GENERIC=Xd(),G.INVALID_GEOMETRY_TYPE=hl(),G.POINT_CLOUD=qd(),G.TRIANGULAR_MESH=$d(),G.DT_INVALID=tm(),G.DT_INT8=em(),G.DT_UINT8=im(),G.DT_INT16=nm(),G.DT_UINT16=sm(),G.DT_INT32=om(),G.DT_UINT32=cl(),G.DT_INT64=rm(),G.DT_UINT64=am(),G.DT_FLOAT32=Am(),G.DT_FLOAT64=ll(),G.DT_BOOL=hm(),G.DT_TYPES_COUNT=oA(),G.OK=cm(),G.DRACO_ERROR=jA(),G.IO_ERROR=lm(),G.INVALID_PARAMETER=dm(),G.UNSUPPORTED_VERSION=dl(),G.UNKNOWN_VERSION=mm()}De?z():Oi.unshift(z)}(),typeof G.onModuleParsed=="function"&&G.onModuleParsed(),G.Decoder.prototype.GetEncodedGeometryType=function(z){if(z.__class__&&z.__class__===G.DecoderBuffer)return G.Decoder.prototype.GetEncodedGeometryType_Deprecated(z);if(8>z.byteLength)return G.INVALID_GEOMETRY_TYPE;switch(z[7]){case 0:return G.POINT_CLOUD;case 1:return G.TRIANGULAR_MESH;default:return G.INVALID_GEOMETRY_TYPE}},e.ready}}();typeof kR=="object"&&typeof $B=="object"?$B.exports=qB:typeof define=="function"&&define.amd?define([],function(){return qB}):typeof kR=="object"&&(kR.DracoDecoderModule=qB)});var iG={};He(iG,{default:()=>x_t});function D_t(t,e){let i=t.num_points(),n=t.num_faces(),s=new Fi.DracoInt32Array,o=n*3,r=te.createTypedArray(i,o),a=0;for(let h=0;h<n;++h)e.GetFaceFromMesh(t,h,s),r[a+0]=s.GetValue(0),r[a+1]=s.GetValue(1),r[a+2]=s.GetValue(2),a+=3;return Fi.destroy(s),{typedArray:r,numberOfIndices:o}}function U_t(t,e,i,n,s){let o,r;n.quantizationBits<=8?(r=new Fi.DracoUInt8Array,o=new Uint8Array(s),e.GetAttributeUInt8ForAllPoints(t,i,r)):n.quantizationBits<=16?(r=new Fi.DracoUInt16Array,o=new Uint16Array(s),e.GetAttributeUInt16ForAllPoints(t,i,r)):(r=new Fi.DracoFloat32Array,o=new Float32Array(s),e.GetAttributeFloatForAllPoints(t,i,r));for(let a=0;a<s;++a)o[a]=r.GetValue(a);return Fi.destroy(r),o}function M_t(t,e,i,n){let s,o;switch(i.data_type()){case 1:case 11:o=new Fi.DracoInt8Array,s=new Int8Array(n),e.GetAttributeInt8ForAllPoints(t,i,o);break;case 2:o=new Fi.DracoUInt8Array,s=new Uint8Array(n),e.GetAttributeUInt8ForAllPoints(t,i,o);break;case 3:o=new Fi.DracoInt16Array,s=new Int16Array(n),e.GetAttributeInt16ForAllPoints(t,i,o);break;case 4:o=new Fi.DracoUInt16Array,s=new Uint16Array(n),e.GetAttributeUInt16ForAllPoints(t,i,o);break;case 5:case 7:o=new Fi.DracoInt32Array,s=new Int32Array(n),e.GetAttributeInt32ForAllPoints(t,i,o);break;case 6:case 8:o=new Fi.DracoUInt32Array,s=new Uint32Array(n),e.GetAttributeUInt32ForAllPoints(t,i,o);break;case 9:case 10:o=new Fi.DracoFloat32Array,s=new Float32Array(n),e.GetAttributeFloatForAllPoints(t,i,o);break}for(let r=0;r<n;++r)s[r]=o.GetValue(r);return Fi.destroy(o),s}function pK(t,e,i){let n=t.num_points(),s=i.num_components(),o,r=new Fi.AttributeQuantizationTransform;if(r.InitFromAttribute(i)){let d=new Array(s);for(let f=0;f<s;++f)d[f]=r.min_value(f);o={quantizationBits:r.quantization_bits(),minValues:d,range:r.range(),octEncoded:!1}}Fi.destroy(r),r=new Fi.AttributeOctahedronTransform,r.InitFromAttribute(i)&&(o={quantizationBits:r.quantization_bits(),octEncoded:!0}),Fi.destroy(r);let a=n*s,h;m(o)?h=U_t(t,e,i,o,a):h=M_t(t,e,i,a);let A=At.fromTypedArray(h);return{array:h,data:{componentsPerAttribute:s,componentDatatype:A,byteOffset:i.byte_offset(),byteStride:At.getSizeInBytes(A)*s,normalized:i.normalized(),quantization:o}}}function Q_t(t){let e=new Fi.Decoder;t.dequantizeInShader&&(e.SkipAttributeTransform(Fi.POSITION),e.SkipAttributeTransform(Fi.NORMAL));let i=new Fi.DecoderBuffer;if(i.Init(t.buffer,t.buffer.length),e.GetEncodedGeometryType(i)!==Fi.POINT_CLOUD)throw new ke("Draco geometry type must be POINT_CLOUD.");let s=new Fi.PointCloud,o=e.DecodeBufferToPointCloud(i,s);if(!o.ok()||s.ptr===0)throw new ke(`Error decoding draco point cloud: ${o.error_msg()}`);Fi.destroy(i);let r={},a=t.properties;for(let h in a)if(a.hasOwnProperty(h)){let A;if(h==="POSITION"||h==="NORMAL"){let d=e.GetAttributeId(s,Fi[h]);A=e.GetAttribute(s,d)}else{let d=a[h];A=e.GetAttributeByUniqueId(s,d)}r[h]=pK(s,e,A)}return Fi.destroy(s),Fi.destroy(e),r}function k_t(t){let e=new Fi.Decoder,i=["POSITION","NORMAL","COLOR","TEX_COORD"];if(t.dequantizeInShader)for(let f=0;f<i.length;++f)e.SkipAttributeTransform(Fi[i[f]]);let n=t.bufferView,s=new Fi.DecoderBuffer;if(s.Init(t.array,n.byteLength),e.GetEncodedGeometryType(s)!==Fi.TRIANGULAR_MESH)throw new ke("Unsupported draco mesh geometry type.");let r=new Fi.Mesh,a=e.DecodeBufferToMesh(s,r);if(!a.ok()||r.ptr===0)throw new ke(`Error decoding draco mesh geometry: ${a.error_msg()}`);Fi.destroy(s);let h={},A=t.compressedAttributes;for(let f in A)if(A.hasOwnProperty(f)){let E=A[f],_=e.GetAttributeByUniqueId(r,E);h[f]=pK(r,e,_)}let d={indexArray:D_t(r,e),attributeData:h};return Fi.destroy(r),Fi.destroy(e),d}async function L_t(t,e){return m(t.bufferView)?k_t(t):Q_t(t)}async function y_t(t,e){let i=t.webAssemblyConfig;return m(i)&&m(i.wasmBinaryFile)?Fi=await(0,eG.default)(i):Fi=await(0,eG.default)(),!0}async function w_t(t,e){let i=t.webAssemblyConfig;return m(i)?y_t(t,e):L_t(t,e)}var eG,Fi,x_t,nG=S(()=>{oi();mt();Di();Ps();Ns();eG=co(tG(),1);x_t=Wi(w_t)});function sG(t,e){if(sG.passThroughDataForTesting)return e;p.typeOf.object("key",t),p.typeOf.object("data",e);let i=t.byteLength;if(i===0||i%4!==0)throw new ke("The length of key must be greater than 0 and a multiple of 4.");let n=new DataView(e),s=n.getUint32(0,!0);if(s===P_t||s===J_t)return e;let o=new DataView(t),r=0,a=e.byteLength,h=a-a%8,A=i,d,f=8;for(;r<h;)for(f=(f+8)%24,d=f;r<h&&d<A;)n.setUint32(r,n.getUint32(r,!0)^o.getUint32(d,!0),!0),n.setUint32(r+4,n.getUint32(r+4,!0)^o.getUint32(d+4,!0),!0),r+=8,d+=24;if(r<a)for(d>=A&&(f=(f+8)%24,d=f);r<a;)n.setUint8(r,n.getUint8(r)^o.getUint8(d)),r++,d++}var P_t,J_t,uK,CK=S(()=>{ae();Ps();P_t=1953029805,J_t=2917034100;sG.passThroughDataForTesting=!1;uK=sG});function j_t(t,e){return(t&e)!==0}var Xf,gK=S(()=>{Xf=j_t});function UA(t,e,i,n,s,o){this._bits=t,this.cnodeVersion=e,this.imageryVersion=i,this.terrainVersion=n,this.imageryProvider=s,this.terrainProvider=o,this.ancestorHasTerrain=!1,this.terrainState=void 0}var H_t,TK,v_t,z_t,K_t,NK,FK=S(()=>{mt();gK();H_t=[1,2,4,8],TK=15,v_t=16,z_t=64,K_t=128;UA.clone=function(t,e){return m(e)?(e._bits=t._bits,e.cnodeVersion=t.cnodeVersion,e.imageryVersion=t.imageryVersion,e.terrainVersion=t.terrainVersion,e.imageryProvider=t.imageryProvider,e.terrainProvider=t.terrainProvider):e=new UA(t._bits,t.cnodeVersion,t.imageryVersion,t.terrainVersion,t.imageryProvider,t.terrainProvider),e.ancestorHasTerrain=t.ancestorHasTerrain,e.terrainState=t.terrainState,e};UA.prototype.setParent=function(t){this.ancestorHasTerrain=t.ancestorHasTerrain||this.hasTerrain()};UA.prototype.hasSubtree=function(){return Xf(this._bits,v_t)};UA.prototype.hasImagery=function(){return Xf(this._bits,z_t)};UA.prototype.hasTerrain=function(){return Xf(this._bits,K_t)};UA.prototype.hasChildren=function(){return Xf(this._bits,TK)};UA.prototype.hasChild=function(t){return Xf(this._bits,H_t[t])};UA.prototype.getChildBitmask=function(){return this._bits&TK};NK=UA});var YK=ts((QSe,bK)=>{"use strict";var X_t=(t,e,i,n)=>{let s=t&65535|0,o=t>>>16&65535|0,r=0;for(;i!==0;){r=i>2e3?2e3:i,i-=r;do s=s+e[n++]|0,o=o+s|0;while(--r);s%=65521,o%=65521}return s|o<<16|0};bK.exports=X_t});var SK=ts((kSe,VK)=>{"use strict";var q_t=()=>{let t,e=[];for(var i=0;i<256;i++){t=i;for(var n=0;n<8;n++)t=t&1?3988292384^t>>>1:t>>>1;e[i]=t}return e},$_t=new Uint32Array(q_t()),tRt=(t,e,i,n)=>{let s=$_t,o=n+i;t^=-1;for(let r=n;r<o;r++)t=t>>>8^s[(t^e[r])&255];return t^-1};VK.exports=tRt});var BK=ts((LSe,OK)=>{"use strict";OK.exports=function(e,i){let n,s,o,r,a,h,A,d,f,E,_,R,I,C,N,T,b,F,B,U,Q,M,k,y,c=e.state;n=e.next_in,k=e.input,s=n+(e.avail_in-5),o=e.next_out,y=e.output,r=o-(i-e.avail_out),a=o+(e.avail_out-257),h=c.dmax,A=c.wsize,d=c.whave,f=c.wnext,E=c.window,_=c.hold,R=c.bits,I=c.lencode,C=c.distcode,N=(1<<c.lenbits)-1,T=(1<<c.distbits)-1;t:do{R<15&&(_+=k[n++]<<R,R+=8,_+=k[n++]<<R,R+=8),b=I[_&N];e:for(;;){if(F=b>>>24,_>>>=F,R-=F,F=b>>>16&255,F===0)y[o++]=b&65535;else if(F&16){B=b&65535,F&=15,F&&(R<F&&(_+=k[n++]<<R,R+=8),B+=_&(1<<F)-1,_>>>=F,R-=F),R<15&&(_+=k[n++]<<R,R+=8,_+=k[n++]<<R,R+=8),b=C[_&T];i:for(;;){if(F=b>>>24,_>>>=F,R-=F,F=b>>>16&255,F&16){if(U=b&65535,F&=15,R<F&&(_+=k[n++]<<R,R+=8,R<F&&(_+=k[n++]<<R,R+=8)),U+=_&(1<<F)-1,U>h){e.msg="invalid distance too far back",c.mode=16209;break t}if(_>>>=F,R-=F,F=o-r,U>F){if(F=U-F,F>d&&c.sane){e.msg="invalid distance too far back",c.mode=16209;break t}if(Q=0,M=E,f===0){if(Q+=A-F,F<B){B-=F;do y[o++]=E[Q++];while(--F);Q=o-U,M=y}}else if(f<F){if(Q+=A+f-F,F-=f,F<B){B-=F;do y[o++]=E[Q++];while(--F);if(Q=0,f<B){F=f,B-=F;do y[o++]=E[Q++];while(--F);Q=o-U,M=y}}}else if(Q+=f-F,F<B){B-=F;do y[o++]=E[Q++];while(--F);Q=o-U,M=y}for(;B>2;)y[o++]=M[Q++],y[o++]=M[Q++],y[o++]=M[Q++],B-=3;B&&(y[o++]=M[Q++],B>1&&(y[o++]=M[Q++]))}else{Q=o-U;do y[o++]=y[Q++],y[o++]=y[Q++],y[o++]=y[Q++],B-=3;while(B>2);B&&(y[o++]=y[Q++],B>1&&(y[o++]=y[Q++]))}}else if(F&64){e.msg="invalid distance code",c.mode=16209;break t}else{b=C[(b&65535)+(_&(1<<F)-1)];continue i}break}}else if(F&64)if(F&32){c.mode=16191;break t}else{e.msg="invalid literal/length code",c.mode=16209;break t}else{b=I[(b&65535)+(_&(1<<F)-1)];continue e}break}}while(n<s&&o<a);B=R>>3,n-=B,R-=B<<3,_&=(1<<R)-1,e.next_in=n,e.next_out=o,e.avail_in=n<s?5+(s-n):5-(n-s),e.avail_out=o<a?257+(a-o):257-(o-a),c.hold=_,c.bits=R}});var WK=ts((ySe,GK)=>{"use strict";var eRt=new Uint16Array([3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258,0,0]),iRt=new Uint8Array([16,16,16,16,16,16,16,16,17,17,17,17,18,18,18,18,19,19,19,19,20,20,20,20,21,21,21,21,16,72,78]),nRt=new Uint16Array([1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577,0,0]),sRt=new Uint8Array([16,16,16,16,17,17,18,18,19,19,20,20,21,21,22,22,23,23,24,24,25,25,26,26,27,27,28,28,29,29,64,64]),oRt=(t,e,i,n,s,o,r,a)=>{let h=a.bits,A=0,d=0,f=0,E=0,_=0,R=0,I=0,C=0,N=0,T=0,b,F,B,U,Q,M=null,k,y=new Uint16Array(16),c=new Uint16Array(16),g=null,O,D,w;for(A=0;A<=15;A++)y[A]=0;for(d=0;d<n;d++)y[e[i+d]]++;for(_=h,E=15;E>=1&&y[E]===0;E--);if(_>E&&(_=E),E===0)return s[o++]=1<<24|64<<16|0,s[o++]=1<<24|64<<16|0,a.bits=1,0;for(f=1;f<E&&y[f]===0;f++);for(_<f&&(_=f),C=1,A=1;A<=15;A++)if(C<<=1,C-=y[A],C<0)return-1;if(C>0&&(t===0||E!==1))return-1;for(c[1]=0,A=1;A<15;A++)c[A+1]=c[A]+y[A];for(d=0;d<n;d++)e[i+d]!==0&&(r[c[e[i+d]]++]=d);if(t===0?(M=g=r,k=20):t===1?(M=eRt,g=iRt,k=257):(M=nRt,g=sRt,k=0),T=0,d=0,A=f,Q=o,R=_,I=0,B=-1,N=1<<_,U=N-1,t===1&&N>852||t===2&&N>592)return 1;for(;;){O=A-I,r[d]+1<k?(D=0,w=r[d]):r[d]>=k?(D=g[r[d]-k],w=M[r[d]-k]):(D=96,w=0),b=1<<A-I,F=1<<R,f=F;do F-=b,s[Q+(T>>I)+F]=O<<24|D<<16|w|0;while(F!==0);for(b=1<<A-1;T&b;)b>>=1;if(b!==0?(T&=b-1,T+=b):T=0,d++,--y[A]===0){if(A===E)break;A=e[i+r[d]]}if(A>_&&(T&U)!==B){for(I===0&&(I=_),Q+=f,R=A-I,C=1<<R;R+I<E&&(C-=y[R+I],!(C<=0));)R++,C<<=1;if(N+=1<<R,t===1&&N>852||t===2&&N>592)return 1;B=T&U,s[B]=_<<24|R<<16|Q-o|0}}return T!==0&&(s[Q+T]=A-I<<24|64<<16|0),a.bits=_,0};GK.exports=oRt});var Wg=ts((wSe,DK)=>{"use strict";DK.exports={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_TREES:6,Z_OK:0,Z_STREAM_END:1,Z_NEED_DICT:2,Z_ERRNO:-1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_MEM_ERROR:-4,Z_BUF_ERROR:-5,Z_NO_COMPRESSION:0,Z_BEST_SPEED:1,Z_BEST_COMPRESSION:9,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8}});var _8=ts((xSe,va)=>{"use strict";var cG=YK(),MA=SK(),rRt=BK(),LR=WK(),aRt=0,a8=1,A8=2,{Z_FINISH:UK,Z_BLOCK:ARt,Z_TREES:Dg,Z_OK:Nd,Z_STREAM_END:hRt,Z_NEED_DICT:cRt,Z_STREAM_ERROR:ra,Z_DATA_ERROR:h8,Z_MEM_ERROR:lG,Z_BUF_ERROR:lRt,Z_DEFLATED:MK}=Wg(),kg=16180,QK=16181,kK=16182,LK=16183,yK=16184,wK=16185,xK=16186,PK=16187,JK=16188,jK=16189,Qg=16190,Gh=16191,oG=16192,HK=16193,rG=16194,vK=16195,zK=16196,KK=16197,XK=16198,Ug=16199,Mg=16200,qK=16201,$K=16202,t8=16203,e8=16204,i8=16205,aG=16206,n8=16207,s8=16208,$n=16209,dG=16210,c8=16211,dRt=852,mRt=592,fRt=15,ERt=fRt,o8=t=>(t>>>24&255)+(t>>>8&65280)+((t&65280)<<8)+((t&255)<<24);function _Rt(){this.strm=null,this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,this.flags=0,this.dmax=0,this.check=0,this.total=0,this.head=null,this.wbits=0,this.wsize=0,this.whave=0,this.wnext=0,this.window=null,this.hold=0,this.bits=0,this.length=0,this.offset=0,this.extra=0,this.lencode=null,this.distcode=null,this.lenbits=0,this.distbits=0,this.ncode=0,this.nlen=0,this.ndist=0,this.have=0,this.next=null,this.lens=new Uint16Array(320),this.work=new Uint16Array(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}var Fd=t=>{if(!t)return 1;let e=t.state;return!e||e.strm!==t||e.mode<kg||e.mode>c8?1:0},l8=t=>{if(Fd(t))return ra;let e=t.state;return t.total_in=t.total_out=e.total=0,t.msg="",e.wrap&&(t.adler=e.wrap&1),e.mode=kg,e.last=0,e.havedict=0,e.flags=-1,e.dmax=32768,e.head=null,e.hold=0,e.bits=0,e.lencode=e.lendyn=new Int32Array(dRt),e.distcode=e.distdyn=new Int32Array(mRt),e.sane=1,e.back=-1,Nd},d8=t=>{if(Fd(t))return ra;let e=t.state;return e.wsize=0,e.whave=0,e.wnext=0,l8(t)},m8=(t,e)=>{let i;if(Fd(t))return ra;let n=t.state;return e<0?(i=0,e=-e):(i=(e>>4)+5,e<48&&(e&=15)),e&&(e<8||e>15)?ra:(n.window!==null&&n.wbits!==e&&(n.window=null),n.wrap=i,n.wbits=e,d8(t))},f8=(t,e)=>{if(!t)return ra;let i=new _Rt;t.state=i,i.strm=t,i.window=null,i.mode=kg;let n=m8(t,e);return n!==Nd&&(t.state=null),n},RRt=t=>f8(t,ERt),r8=!0,AG,hG,ZRt=t=>{if(r8){AG=new Int32Array(512),hG=new Int32Array(32);let e=0;for(;e<144;)t.lens[e++]=8;for(;e<256;)t.lens[e++]=9;for(;e<280;)t.lens[e++]=7;for(;e<288;)t.lens[e++]=8;for(LR(a8,t.lens,0,288,AG,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;LR(A8,t.lens,0,32,hG,0,t.work,{bits:5}),r8=!1}t.lencode=AG,t.lenbits=9,t.distcode=hG,t.distbits=5},E8=(t,e,i,n)=>{let s,o=t.state;return o.window===null&&(o.wsize=1<<o.wbits,o.wnext=0,o.whave=0,o.window=new Uint8Array(o.wsize)),n>=o.wsize?(o.window.set(e.subarray(i-o.wsize,i),0),o.wnext=0,o.whave=o.wsize):(s=o.wsize-o.wnext,s>n&&(s=n),o.window.set(e.subarray(i-n,i-n+s),o.wnext),n-=s,n?(o.window.set(e.subarray(i-n,i),0),o.wnext=n,o.whave=o.wsize):(o.wnext+=s,o.wnext===o.wsize&&(o.wnext=0),o.whave<o.wsize&&(o.whave+=s))),0},IRt=(t,e)=>{let i,n,s,o,r,a,h,A,d,f,E,_,R,I,C=0,N,T,b,F,B,U,Q,M,k=new Uint8Array(4),y,c,g=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(Fd(t)||!t.output||!t.input&&t.avail_in!==0)return ra;i=t.state,i.mode===Gh&&(i.mode=oG),r=t.next_out,s=t.output,h=t.avail_out,o=t.next_in,n=t.input,a=t.avail_in,A=i.hold,d=i.bits,f=a,E=h,M=Nd;t:for(;;)switch(i.mode){case kg:if(i.wrap===0){i.mode=oG;break}for(;d<16;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(i.wrap&2&&A===35615){i.wbits===0&&(i.wbits=15),i.check=0,k[0]=A&255,k[1]=A>>>8&255,i.check=MA(i.check,k,2,0),A=0,d=0,i.mode=QK;break}if(i.head&&(i.head.done=!1),!(i.wrap&1)||(((A&255)<<8)+(A>>8))%31){t.msg="incorrect header check",i.mode=$n;break}if((A&15)!==MK){t.msg="unknown compression method",i.mode=$n;break}if(A>>>=4,d-=4,Q=(A&15)+8,i.wbits===0&&(i.wbits=Q),Q>15||Q>i.wbits){t.msg="invalid window size",i.mode=$n;break}i.dmax=1<<i.wbits,i.flags=0,t.adler=i.check=1,i.mode=A&512?jK:Gh,A=0,d=0;break;case QK:for(;d<16;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(i.flags=A,(i.flags&255)!==MK){t.msg="unknown compression method",i.mode=$n;break}if(i.flags&57344){t.msg="unknown header flags set",i.mode=$n;break}i.head&&(i.head.text=A>>8&1),i.flags&512&&i.wrap&4&&(k[0]=A&255,k[1]=A>>>8&255,i.check=MA(i.check,k,2,0)),A=0,d=0,i.mode=kK;case kK:for(;d<32;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.head&&(i.head.time=A),i.flags&512&&i.wrap&4&&(k[0]=A&255,k[1]=A>>>8&255,k[2]=A>>>16&255,k[3]=A>>>24&255,i.check=MA(i.check,k,4,0)),A=0,d=0,i.mode=LK;case LK:for(;d<16;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.head&&(i.head.xflags=A&255,i.head.os=A>>8),i.flags&512&&i.wrap&4&&(k[0]=A&255,k[1]=A>>>8&255,i.check=MA(i.check,k,2,0)),A=0,d=0,i.mode=yK;case yK:if(i.flags&1024){for(;d<16;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.length=A,i.head&&(i.head.extra_len=A),i.flags&512&&i.wrap&4&&(k[0]=A&255,k[1]=A>>>8&255,i.check=MA(i.check,k,2,0)),A=0,d=0}else i.head&&(i.head.extra=null);i.mode=wK;case wK:if(i.flags&1024&&(_=i.length,_>a&&(_=a),_&&(i.head&&(Q=i.head.extra_len-i.length,i.head.extra||(i.head.extra=new Uint8Array(i.head.extra_len)),i.head.extra.set(n.subarray(o,o+_),Q)),i.flags&512&&i.wrap&4&&(i.check=MA(i.check,n,_,o)),a-=_,o+=_,i.length-=_),i.length))break t;i.length=0,i.mode=xK;case xK:if(i.flags&2048){if(a===0)break t;_=0;do Q=n[o+_++],i.head&&Q&&i.length<65536&&(i.head.name+=String.fromCharCode(Q));while(Q&&_<a);if(i.flags&512&&i.wrap&4&&(i.check=MA(i.check,n,_,o)),a-=_,o+=_,Q)break t}else i.head&&(i.head.name=null);i.length=0,i.mode=PK;case PK:if(i.flags&4096){if(a===0)break t;_=0;do Q=n[o+_++],i.head&&Q&&i.length<65536&&(i.head.comment+=String.fromCharCode(Q));while(Q&&_<a);if(i.flags&512&&i.wrap&4&&(i.check=MA(i.check,n,_,o)),a-=_,o+=_,Q)break t}else i.head&&(i.head.comment=null);i.mode=JK;case JK:if(i.flags&512){for(;d<16;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(i.wrap&4&&A!==(i.check&65535)){t.msg="header crc mismatch",i.mode=$n;break}A=0,d=0}i.head&&(i.head.hcrc=i.flags>>9&1,i.head.done=!0),t.adler=i.check=0,i.mode=Gh;break;case jK:for(;d<32;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}t.adler=i.check=o8(A),A=0,d=0,i.mode=Qg;case Qg:if(i.havedict===0)return t.next_out=r,t.avail_out=h,t.next_in=o,t.avail_in=a,i.hold=A,i.bits=d,cRt;t.adler=i.check=1,i.mode=Gh;case Gh:if(e===ARt||e===Dg)break t;case oG:if(i.last){A>>>=d&7,d-=d&7,i.mode=aG;break}for(;d<3;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}switch(i.last=A&1,A>>>=1,d-=1,A&3){case 0:i.mode=HK;break;case 1:if(ZRt(i),i.mode=Ug,e===Dg){A>>>=2,d-=2;break t}break;case 2:i.mode=zK;break;case 3:t.msg="invalid block type",i.mode=$n}A>>>=2,d-=2;break;case HK:for(A>>>=d&7,d-=d&7;d<32;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if((A&65535)!==(A>>>16^65535)){t.msg="invalid stored block lengths",i.mode=$n;break}if(i.length=A&65535,A=0,d=0,i.mode=rG,e===Dg)break t;case rG:i.mode=vK;case vK:if(_=i.length,_){if(_>a&&(_=a),_>h&&(_=h),_===0)break t;s.set(n.subarray(o,o+_),r),a-=_,o+=_,h-=_,r+=_,i.length-=_;break}i.mode=Gh;break;case zK:for(;d<14;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(i.nlen=(A&31)+257,A>>>=5,d-=5,i.ndist=(A&31)+1,A>>>=5,d-=5,i.ncode=(A&15)+4,A>>>=4,d-=4,i.nlen>286||i.ndist>30){t.msg="too many length or distance symbols",i.mode=$n;break}i.have=0,i.mode=KK;case KK:for(;i.have<i.ncode;){for(;d<3;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.lens[g[i.have++]]=A&7,A>>>=3,d-=3}for(;i.have<19;)i.lens[g[i.have++]]=0;if(i.lencode=i.lendyn,i.lenbits=7,y={bits:i.lenbits},M=LR(aRt,i.lens,0,19,i.lencode,0,i.work,y),i.lenbits=y.bits,M){t.msg="invalid code lengths set",i.mode=$n;break}i.have=0,i.mode=XK;case XK:for(;i.have<i.nlen+i.ndist;){for(;C=i.lencode[A&(1<<i.lenbits)-1],N=C>>>24,T=C>>>16&255,b=C&65535,!(N<=d);){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(b<16)A>>>=N,d-=N,i.lens[i.have++]=b;else{if(b===16){for(c=N+2;d<c;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(A>>>=N,d-=N,i.have===0){t.msg="invalid bit length repeat",i.mode=$n;break}Q=i.lens[i.have-1],_=3+(A&3),A>>>=2,d-=2}else if(b===17){for(c=N+3;d<c;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}A>>>=N,d-=N,Q=0,_=3+(A&7),A>>>=3,d-=3}else{for(c=N+7;d<c;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}A>>>=N,d-=N,Q=0,_=11+(A&127),A>>>=7,d-=7}if(i.have+_>i.nlen+i.ndist){t.msg="invalid bit length repeat",i.mode=$n;break}for(;_--;)i.lens[i.have++]=Q}}if(i.mode===$n)break;if(i.lens[256]===0){t.msg="invalid code -- missing end-of-block",i.mode=$n;break}if(i.lenbits=9,y={bits:i.lenbits},M=LR(a8,i.lens,0,i.nlen,i.lencode,0,i.work,y),i.lenbits=y.bits,M){t.msg="invalid literal/lengths set",i.mode=$n;break}if(i.distbits=6,i.distcode=i.distdyn,y={bits:i.distbits},M=LR(A8,i.lens,i.nlen,i.ndist,i.distcode,0,i.work,y),i.distbits=y.bits,M){t.msg="invalid distances set",i.mode=$n;break}if(i.mode=Ug,e===Dg)break t;case Ug:i.mode=Mg;case Mg:if(a>=6&&h>=258){t.next_out=r,t.avail_out=h,t.next_in=o,t.avail_in=a,i.hold=A,i.bits=d,rRt(t,E),r=t.next_out,s=t.output,h=t.avail_out,o=t.next_in,n=t.input,a=t.avail_in,A=i.hold,d=i.bits,i.mode===Gh&&(i.back=-1);break}for(i.back=0;C=i.lencode[A&(1<<i.lenbits)-1],N=C>>>24,T=C>>>16&255,b=C&65535,!(N<=d);){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(T&&!(T&240)){for(F=N,B=T,U=b;C=i.lencode[U+((A&(1<<F+B)-1)>>F)],N=C>>>24,T=C>>>16&255,b=C&65535,!(F+N<=d);){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}A>>>=F,d-=F,i.back+=F}if(A>>>=N,d-=N,i.back+=N,i.length=b,T===0){i.mode=i8;break}if(T&32){i.back=-1,i.mode=Gh;break}if(T&64){t.msg="invalid literal/length code",i.mode=$n;break}i.extra=T&15,i.mode=qK;case qK:if(i.extra){for(c=i.extra;d<c;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.length+=A&(1<<i.extra)-1,A>>>=i.extra,d-=i.extra,i.back+=i.extra}i.was=i.length,i.mode=$K;case $K:for(;C=i.distcode[A&(1<<i.distbits)-1],N=C>>>24,T=C>>>16&255,b=C&65535,!(N<=d);){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(!(T&240)){for(F=N,B=T,U=b;C=i.distcode[U+((A&(1<<F+B)-1)>>F)],N=C>>>24,T=C>>>16&255,b=C&65535,!(F+N<=d);){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}A>>>=F,d-=F,i.back+=F}if(A>>>=N,d-=N,i.back+=N,T&64){t.msg="invalid distance code",i.mode=$n;break}i.offset=b,i.extra=T&15,i.mode=t8;case t8:if(i.extra){for(c=i.extra;d<c;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}i.offset+=A&(1<<i.extra)-1,A>>>=i.extra,d-=i.extra,i.back+=i.extra}if(i.offset>i.dmax){t.msg="invalid distance too far back",i.mode=$n;break}i.mode=e8;case e8:if(h===0)break t;if(_=E-h,i.offset>_){if(_=i.offset-_,_>i.whave&&i.sane){t.msg="invalid distance too far back",i.mode=$n;break}_>i.wnext?(_-=i.wnext,R=i.wsize-_):R=i.wnext-_,_>i.length&&(_=i.length),I=i.window}else I=s,R=r-i.offset,_=i.length;_>h&&(_=h),h-=_,i.length-=_;do s[r++]=I[R++];while(--_);i.length===0&&(i.mode=Mg);break;case i8:if(h===0)break t;s[r++]=i.length,h--,i.mode=Mg;break;case aG:if(i.wrap){for(;d<32;){if(a===0)break t;a--,A|=n[o++]<<d,d+=8}if(E-=h,t.total_out+=E,i.total+=E,i.wrap&4&&E&&(t.adler=i.check=i.flags?MA(i.check,s,E,r-E):cG(i.check,s,E,r-E)),E=h,i.wrap&4&&(i.flags?A:o8(A))!==i.check){t.msg="incorrect data check",i.mode=$n;break}A=0,d=0}i.mode=n8;case n8:if(i.wrap&&i.flags){for(;d<32;){if(a===0)break t;a--,A+=n[o++]<<d,d+=8}if(i.wrap&4&&A!==(i.total&4294967295)){t.msg="incorrect length check",i.mode=$n;break}A=0,d=0}i.mode=s8;case s8:M=hRt;break t;case $n:M=h8;break t;case dG:return lG;case c8:default:return ra}return t.next_out=r,t.avail_out=h,t.next_in=o,t.avail_in=a,i.hold=A,i.bits=d,(i.wsize||E!==t.avail_out&&i.mode<$n&&(i.mode<aG||e!==UK))&&E8(t,t.output,t.next_out,E-t.avail_out)?(i.mode=dG,lG):(f-=t.avail_in,E-=t.avail_out,t.total_in+=f,t.total_out+=E,i.total+=E,i.wrap&4&&E&&(t.adler=i.check=i.flags?MA(i.check,s,E,t.next_out-E):cG(i.check,s,E,t.next_out-E)),t.data_type=i.bits+(i.last?64:0)+(i.mode===Gh?128:0)+(i.mode===Ug||i.mode===rG?256:0),(f===0&&E===0||e===UK)&&M===Nd&&(M=lRt),M)},pRt=t=>{if(Fd(t))return ra;let e=t.state;return e.window&&(e.window=null),t.state=null,Nd},uRt=(t,e)=>{if(Fd(t))return ra;let i=t.state;return i.wrap&2?(i.head=e,e.done=!1,Nd):ra},CRt=(t,e)=>{let i=e.length,n,s,o;return Fd(t)||(n=t.state,n.wrap!==0&&n.mode!==Qg)?ra:n.mode===Qg&&(s=1,s=cG(s,e,i,0),s!==n.check)?h8:(o=E8(t,e,i,i),o?(n.mode=dG,lG):(n.havedict=1,Nd))};va.exports.inflateReset=d8;va.exports.inflateReset2=m8;va.exports.inflateResetKeep=l8;va.exports.inflateInit=RRt;va.exports.inflateInit2=f8;va.exports.inflate=IRt;va.exports.inflateEnd=pRt;va.exports.inflateGetHeader=uRt;va.exports.inflateSetDictionary=CRt;va.exports.inflateInfo="pako inflate (from Nodeca project)"});var R8=ts((PSe,mG)=>{"use strict";var gRt=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);mG.exports.assign=function(t){let e=Array.prototype.slice.call(arguments,1);for(;e.length;){let i=e.shift();if(i){if(typeof i!="object")throw new TypeError(i+"must be non-object");for(let n in i)gRt(i,n)&&(t[n]=i[n])}}return t};mG.exports.flattenChunks=t=>{let e=0;for(let n=0,s=t.length;n<s;n++)e+=t[n].length;let i=new Uint8Array(e);for(let n=0,s=0,o=t.length;n<o;n++){let r=t[n];i.set(r,s),s+=r.length}return i}});var I8=ts((JSe,Lg)=>{"use strict";var Z8=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch{Z8=!1}var yR=new Uint8Array(256);for(let t=0;t<256;t++)yR[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;yR[254]=yR[254]=1;Lg.exports.string2buf=t=>{if(typeof TextEncoder=="function"&&TextEncoder.prototype.encode)return new TextEncoder().encode(t);let e,i,n,s,o,r=t.length,a=0;for(s=0;s<r;s++)i=t.charCodeAt(s),(i&64512)===55296&&s+1<r&&(n=t.charCodeAt(s+1),(n&64512)===56320&&(i=65536+(i-55296<<10)+(n-56320),s++)),a+=i<128?1:i<2048?2:i<65536?3:4;for(e=new Uint8Array(a),o=0,s=0;o<a;s++)i=t.charCodeAt(s),(i&64512)===55296&&s+1<r&&(n=t.charCodeAt(s+1),(n&64512)===56320&&(i=65536+(i-55296<<10)+(n-56320),s++)),i<128?e[o++]=i:i<2048?(e[o++]=192|i>>>6,e[o++]=128|i&63):i<65536?(e[o++]=224|i>>>12,e[o++]=128|i>>>6&63,e[o++]=128|i&63):(e[o++]=240|i>>>18,e[o++]=128|i>>>12&63,e[o++]=128|i>>>6&63,e[o++]=128|i&63);return e};var TRt=(t,e)=>{if(e<65534&&t.subarray&&Z8)return String.fromCharCode.apply(null,t.length===e?t:t.subarray(0,e));let i="";for(let n=0;n<e;n++)i+=String.fromCharCode(t[n]);return i};Lg.exports.buf2string=(t,e)=>{let i=e||t.length;if(typeof TextDecoder=="function"&&TextDecoder.prototype.decode)return new TextDecoder().decode(t.subarray(0,e));let n,s,o=new Array(i*2);for(s=0,n=0;n<i;){let r=t[n++];if(r<128){o[s++]=r;continue}let a=yR[r];if(a>4){o[s++]=65533,n+=a-1;continue}for(r&=a===2?31:a===3?15:7;a>1&&n<i;)r=r<<6|t[n++]&63,a--;if(a>1){o[s++]=65533;continue}r<65536?o[s++]=r:(r-=65536,o[s++]=55296|r>>10&1023,o[s++]=56320|r&1023)}return TRt(o,s)};Lg.exports.utf8border=(t,e)=>{e=e||t.length,e>t.length&&(e=t.length);let i=e-1;for(;i>=0&&(t[i]&192)===128;)i--;return i<0||i===0?e:i+yR[t[i]]>e?i:e}});var u8=ts((jSe,p8)=>{"use strict";p8.exports={2:"need dictionary",1:"stream end",0:"","-1":"file error","-2":"stream error","-3":"data error","-4":"insufficient memory","-5":"buffer error","-6":"incompatible version"}});var g8=ts((HSe,C8)=>{"use strict";function NRt(){this.input=null,this.next_in=0,this.avail_in=0,this.total_in=0,this.output=null,this.next_out=0,this.avail_out=0,this.total_out=0,this.msg="",this.state=null,this.data_type=2,this.adler=0}C8.exports=NRt});var N8=ts((vSe,T8)=>{"use strict";function FRt(){this.text=0,this.time=0,this.xflags=0,this.os=0,this.extra=null,this.extra_len=0,this.name="",this.comment="",this.hcrc=0,this.done=!1}T8.exports=FRt});var V8=ts((zSe,qf)=>{"use strict";var Wh=_8(),b8=R8(),_G=I8(),RG=u8(),bRt=g8(),YRt=N8(),Y8=Object.prototype.toString,{Z_NO_FLUSH:VRt,Z_FINISH:SRt,Z_OK:wR,Z_STREAM_END:fG,Z_NEED_DICT:EG,Z_STREAM_ERROR:ORt,Z_DATA_ERROR:F8,Z_MEM_ERROR:BRt}=Wg();function xR(t){this.options=b8.assign({chunkSize:1024*64,windowBits:15,to:""},t||{});let e=this.options;e.raw&&e.windowBits>=0&&e.windowBits<16&&(e.windowBits=-e.windowBits,e.windowBits===0&&(e.windowBits=-15)),e.windowBits>=0&&e.windowBits<16&&!(t&&t.windowBits)&&(e.windowBits+=32),e.windowBits>15&&e.windowBits<48&&(e.windowBits&15||(e.windowBits|=15)),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new bRt,this.strm.avail_out=0;let i=Wh.inflateInit2(this.strm,e.windowBits);if(i!==wR)throw new Error(RG[i]);if(this.header=new YRt,Wh.inflateGetHeader(this.strm,this.header),e.dictionary&&(typeof e.dictionary=="string"?e.dictionary=_G.string2buf(e.dictionary):Y8.call(e.dictionary)==="[object ArrayBuffer]"&&(e.dictionary=new Uint8Array(e.dictionary)),e.raw&&(i=Wh.inflateSetDictionary(this.strm,e.dictionary),i!==wR)))throw new Error(RG[i])}xR.prototype.push=function(t,e){let i=this.strm,n=this.options.chunkSize,s=this.options.dictionary,o,r,a;if(this.ended)return!1;for(e===~~e?r=e:r=e===!0?SRt:VRt,Y8.call(t)==="[object ArrayBuffer]"?i.input=new Uint8Array(t):i.input=t,i.next_in=0,i.avail_in=i.input.length;;){for(i.avail_out===0&&(i.output=new Uint8Array(n),i.next_out=0,i.avail_out=n),o=Wh.inflate(i,r),o===EG&&s&&(o=Wh.inflateSetDictionary(i,s),o===wR?o=Wh.inflate(i,r):o===F8&&(o=EG));i.avail_in>0&&o===fG&&i.state.wrap>0&&t[i.next_in]!==0;)Wh.inflateReset(i),o=Wh.inflate(i,r);switch(o){case ORt:case F8:case EG:case BRt:return this.onEnd(o),this.ended=!0,!1}if(a=i.avail_out,i.next_out&&(i.avail_out===0||o===fG))if(this.options.to==="string"){let h=_G.utf8border(i.output,i.next_out),A=i.next_out-h,d=_G.buf2string(i.output,h);i.next_out=A,i.avail_out=n-A,A&&i.output.set(i.output.subarray(h,h+A),0),this.onData(d)}else this.onData(i.output.length===i.next_out?i.output:i.output.subarray(0,i.next_out));if(!(o===wR&&a===0)){if(o===fG)return o=Wh.inflateEnd(this.strm),this.onEnd(o),this.ended=!0,!0;if(i.avail_in===0)break}}return!0};xR.prototype.onData=function(t){this.chunks.push(t)};xR.prototype.onEnd=function(t){t===wR&&(this.options.to==="string"?this.result=this.chunks.join(""):this.result=b8.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};function ZG(t,e){let i=new xR(e);if(i.push(t),i.err)throw i.msg||RG[i.err];return i.result}function GRt(t,e){return e=e||{},e.raw=!0,ZG(t,e)}qf.exports.Inflate=xR;qf.exports.inflate=ZG;qf.exports.inflateRaw=GRt;qf.exports.ungzip=ZG;qf.exports.constants=Wg()});var IG={};He(IG,{default:()=>wRt});function WRt(t,e){let i=zc.fromString(t.type),n=t.buffer;uK(t.key,n);let s=yRt(n);n=s.buffer;let o=s.length;switch(i){case zc.METADATA:return URt(n,o,t.quadKey);case zc.TERRAIN:return kRt(n,o,e);case zc.DBROOT:return e.push(n),{buffer:n}}}function URt(t,e,i){let n=new DataView(t),s=0,o=n.getUint32(s,!0);if(s+=tE,o!==DRt)throw new ke("Invalid magic");let r=n.getUint32(s,!0);if(s+=tE,r!==1)throw new ke("Invalid data type. Must be 1 for QuadTreePacket");let a=n.getUint32(s,!0);if(s+=tE,a!==2)throw new ke("Invalid QuadTreePacket version. Only version 2 is supported.");let h=n.getInt32(s,!0);s+=bd;let A=n.getInt32(s,!0);if(s+=bd,A!==32)throw new ke("Invalid instance size.");let d=n.getInt32(s,!0);s+=bd;let f=n.getInt32(s,!0);s+=bd;let E=n.getInt32(s,!0);if(s+=bd,d!==h*A+s)throw new ke("Invalid dataBufferOffset");if(d+f+E!==e)throw new ke("Invalid packet offsets");let _=[];for(let b=0;b<h;++b){let F=n.getUint8(s);++s,++s;let B=n.getUint16(s,!0);s+=$f;let U=n.getUint16(s,!0);s+=$f;let Q=n.getUint16(s,!0);s+=$f,s+=$f,s+=$f,s+=bd,s+=bd,s+=8;let M=n.getUint8(s++),k=n.getUint8(s++);s+=$f,_.push(new NK(F,B,U,Q,M,k))}let R=[],I=0;function C(b,F,B){let U=!1;if(B===4){if(F.hasSubtree())return;U=!0}for(let Q=0;Q<4;++Q){let M=b+Q.toString();if(U)R[M]=null;else if(B<4)if(!F.hasChild(Q))R[M]=null;else{if(I===h){console.log("Incorrect number of instances");return}let k=_[I++];R[M]=k,C(M,k,B+1)}}}let N=0,T=_[I++];return i===""?++N:R[i]=T,C(i,T,N),R}function kRt(t,e,i){let n=new DataView(t),s=function(a){for(let h=0;h<QRt;++h){let A=n.getUint32(a,!0);if(a+=tE,a+=A,a>e)throw new ke("Malformed terrain packet found.")}return a},o=0,r=[];for(;r.length<MRt;){let a=o;o=s(o);let h=t.slice(a,o);i.push(h),r.push(h)}return r}function yRt(t){let e=new DataView(t),i=0,n=e.getUint32(i,!0);if(i+=tE,n!==S8&&n!==LRt)throw new ke("Invalid magic");let s=e.getUint32(i,n===S8);i+=tE;let o=new Uint8Array(t,i),r=O8.default.inflate(o);if(r.length!==s)throw new ke("Size of packet doesn't match header");return r}var O8,$f,bd,tE,zc,DRt,MRt,QRt,S8,LRt,wRt,pG=S(()=>{CK();FK();Ps();O8=co(V8(),1);Ns();$f=Uint16Array.BYTES_PER_ELEMENT,bd=Int32Array.BYTES_PER_ELEMENT,tE=Uint32Array.BYTES_PER_ELEMENT,zc={METADATA:0,TERRAIN:1,DBROOT:2};zc.fromString=function(t){if(t==="Metadata")return zc.METADATA;if(t==="Terrain")return zc.TERRAIN;if(t==="DbRoot")return zc.DBROOT};DRt=32301;MRt=5,QRt=4;S8=1953029805,LRt=2917034100;wRt=Wi(WRt)});function xRt(t){return p.defined("value",t),t<=.04045?t*.07739938080495357:Math.pow((t+.055)*.9478672985781991,2.4)}var yg,B8=S(()=>{ae();yg=xRt});var TG={};He(TG,{default:()=>EZt});function PRt(t,e,i,n,s,o){let r=i*(1-t)+n*t,a=s*(1-t)+o*t;return r*(1-e)+a*e}function wg(t,e,i,n){let s=t+e*i;return n[s]}function JRt(t,e,i){let n=i.nativeExtent,s=(t-n.west)/(n.east-n.west)*(i.width-1),o=(e-n.south)/(n.north-n.south)*(i.height-1),r=Math.floor(s),a=Math.floor(o);s-=r,o-=a;let h=r<i.width?r+1:r,A=a<i.height?a+1:a;a=i.height-1-a,A=i.height-1-A;let d=wg(r,a,i.width,i.buffer),f=wg(h,a,i.width,i.buffer),E=wg(r,A,i.width,i.buffer),_=wg(h,A,i.width,i.buffer),R=PRt(s,o,d,f,E,_);return R=R*i.scale+i.offset,R}function G8(t,e,i){for(let n=0;n<i.length;n++){let s=i[n].nativeExtent,o=new l;if(i[n].projectionType==="WebMercator"){let r=i[n].projection._ellipsoid._radii;o=new ks(new ot(r.x,r.y,r.z)).project(new ut(t,e,0))}else o.x=t,o.y=e;if(o.x>s.west&&o.x<s.east&&o.y>s.south&&o.y<s.north)return JRt(o.x,o.y,i[n])}return 0}function jRt(t,e,i,n,s,o,r){if(r)return;let a=G8(s.longitude,s.latitude,o);for(let h=0;h<t;++h){let A=G8(s.longitude+L.toRadians(i*e[h*3]),s.latitude+L.toRadians(n*e[h*3+1]),o);e[h*3+2]+=A-a}}function HRt(t,e,i,n,s,o,r,a,h){if(t===0||!m(e)||e.length===0)return;let A=new ot(Math.sqrt(r.x),Math.sqrt(r.y),Math.sqrt(r.z));for(let d=0;d<t;++d){let f=d*3,E=f+1,_=f+2,R=new ut;R.longitude=n.longitude+L.toRadians(a*e[f]),R.latitude=n.latitude+L.toRadians(h*e[E]),R.height=n.height+e[_];let I={};A.cartographicToCartesian(R,I),I.x-=s.x,I.y-=s.y,I.z-=s.z;let C={};if(lt.multiplyByVector(o,I,C),e[f]=C.x,e[E]=C.y,e[_]=C.z,m(i)){let N=new l(i[f],i[E],i[_]),T={};lt.multiplyByVector(o,N,T),i[f]=T.x,i[E]=T.y,i[_]=T.z}}}function vRt(t,e,i){for(let n=0;n<t;++n){let s=i[n*4]/65535,o=i[n*4+1]/65535,r=(i[n*4+2]-i[n*4])/65535,a=(i[n*4+3]-i[n*4+1])/65535;e[n*2]*=r,e[n*2]+=s,e[n*2+1]*=a,e[n*2+1]+=o}}function zRt(t,e,i,n){let s=new Uint32Array(t),o=m(e)?a=>e[a]:a=>a,r=0;if(n&&m(i)){let a=h=>i[o(h)*4+3]<255;for(let h=0;h<t;h+=3)!a(h)&&!a(h+1)&&!a(h+2)&&(s[r++]=o(h),s[r++]=o(h+1),s[r++]=o(h+2));if(r>0){let h=r;for(let A=0;A<t;A+=3)(a(A)||a(A+1)||a(A+2))&&(s[h++]=o(A),s[h++]=o(A+1),s[h++]=o(A+2))}else for(let h=0;h<t;++h)s[h]=o(h)}else{r=t;for(let a=0;a<t;++a)s[a]=o(a)}return{indexArray:s,transparentVertexOffset:r}}function KRt(t,e,i){let n=e[i];if(m(n))return n;let s=e[i]={positions:{},indices:{},edges:{}},o=Z(t[i],t.default);return s.hasOutline=m(o?.edges),s}function XRt(t,e,i,n){if(!m(t[i])){let s=i*3,o=e;for(let r=0;r<3;r++){let a=n[s+r];m(o[a])||(o[a]={}),o=o[a]}m(o.index)||(o.index=i),t[i]=o.index}}function qRt(t,e,i,n,s,o){let r,a;n<s?(r=n,a=s):(r=s,a=n);let h=t[r];m(h)||(h=t[r]={});let A=h[a];m(A)||(A=h[a]={normalsIndex:[],outlines:[]}),A.normalsIndex.push(o),(A.outlines.length===0||e!==n||i!==s)&&A.outlines.push(e,i)}function $Rt(t,e,i,n){let s=[];for(let o=0;o<i.length;o+=3){let r=m(e)?e[i[o]]:"default",a=KRt(t,s,r);if(!a.hasOutline)continue;let h=a.indices,A=a.positions;for(let f=0;f<3;f++){let E=i[o+f];XRt(h,A,E,n)}let d=a.edges;for(let f=0;f<3;f++){let E=i[o+f],_=i[o+(f+1)%3],R=h[E],I=h[_];qRt(d,E,_,R,I,o)}}return s}function W8(t,e,i,n){let s=i[e]*3,o=i[e+1]*3,r=i[e+2]*3;l.fromArray(n,s,QA),l.fromArray(n,o,xg),l.fromArray(n,r,Pg),l.subtract(xg,QA,xg),l.subtract(Pg,QA,Pg),l.cross(xg,Pg,QA);let a=l.magnitude(QA);a!==0&&l.divideByScalar(QA,a,QA);let h=e*3,A=(e+1)*3,d=(e+2)*3;l.pack(QA,t,h),l.pack(QA,t,A),l.pack(QA,t,d)}function tZt(t,e,i){l.fromArray(t,e,Jg),l.fromArray(t,i,uG);let n=l.dot(Jg,uG),s=l.magnitude(l.cross(Jg,uG,Jg));return Math.atan2(s,n)<.25}function eZt(t,e,i,n,s){if(e.normalsIndex.length>1){let o=n.length===s.length;for(let r=0;r<e.normalsIndex.length;r++){let a=e.normalsIndex[r];if(m(s[a*3])||W8(s,a,i,n),r!==0)for(let h=0;h<r;h++){let A=e.normalsIndex[h],d=o?i[a]*3:a*3,f=o?i[A]*3:A*3;if(tZt(s,d,f))return}}}t.push(...e.outlines)}function iZt(t,e,i,n,s){let o=Object.keys(e);for(let r=0;r<o.length;r++){let a=e[o[r]],h=Object.keys(a);for(let A=0;A<h.length;A++){let d=a[h[A]];eZt(t,d,i,n,s)}}}function nZt(t,e,i,n){let s=[],o=Object.keys(t);for(let r=0;r<o.length;r++){let a=t[o[r]].edges;iZt(s,a,e,i,n)}return s}function sZt(t,e,i,n,s){if(!m(t)||Object.keys(t).length===0)return;let o=$Rt(t,e,i,n);(!m(s)||i.length*3!==s.length)&&(s=[]);let r=nZt(o,i,n,s);return r.length>0?new Uint32Array(r):void 0}function oZt(t){let e=new Float32Array(t.length);for(let i=0;i<t.length;i+=4)e[i]=yg(Zt.byteToFloat(t[i])),e[i+1]=yg(Zt.byteToFloat(t[i+1])),e[i+2]=yg(Zt.byteToFloat(t[i+2])),e[i+3]=Zt.byteToFloat(t[i+3]);return e}function rZt(t,e,i,n,s,o,r){let a={normals:void 0,positions:void 0,uv0s:void 0,colors:void 0,featureIndex:void 0,vertexCount:void 0};if(t===0||!m(i)||i.length===0||m(n))return a;if(m(e)){a.vertexCount=e.length,a.positions=new Float32Array(e.length*3),a.uv0s=m(s)?new Float32Array(e.length*2):void 0,a.colors=m(o)?new Uint8Array(e.length*4):void 0,a.featureIndex=m(r)?new Array(e.length):void 0;for(let h=0;h<e.length;h++){let A=e[h];a.positions[h*3]=i[A*3],a.positions[h*3+1]=i[A*3+1],a.positions[h*3+2]=i[A*3+2],m(a.uv0s)&&(a.uv0s[h*2]=s[A*2],a.uv0s[h*2+1]=s[A*2+1]),m(a.colors)&&(a.colors[h*4]=o[A*4],a.colors[h*4+1]=o[A*4+1],a.colors[h*4+2]=o[A*4+2],a.colors[h*4+3]=o[A*4+3]),m(a.featureIndex)&&(a.featureIndex[h]=r[A])}t=e.length,i=a.positions}e=new Array(t);for(let h=0;h<t;h++)e[h]=h;a.normals=new Float32Array(e.length*3);for(let h=0;h<e.length;h+=3)W8(a.normals,h,e,i);return a}function aZt(t,e,i,n,s,o,r,a){if(t===0||!m(i)||i.length===0)return{buffers:[],bufferViews:[],accessors:[],meshes:[],nodes:[],nodesInScene:[]};let h=[],A=[],d=[],f=[],E=[],_=[],R={},I=[];m(e)&&(t=e.length);let{indexArray:C,transparentVertexOffset:N}=zRt(t,e,o,a.splitGeometryByColorTransparency),T=new Blob([C],{type:"application/binary"}),b=URL.createObjectURL(T),F=t,B=a.enableFeatures&&m(r)?new Float32Array(r.length):void 0,U=0;if(m(B))for(let bt=0;bt<r.length;++bt){B[bt]=r[bt];let ee=r[bt]+1;U<ee&&(U=ee)}let Q,M=sZt(a.symbologyData,r,C,i,n);if(m(M)){let bt=new Blob([M],{type:"application/binary"});Q=URL.createObjectURL(bt)}let k=i.subarray(0,F*3),y=new Blob([k],{type:"application/binary"}),c=URL.createObjectURL(y),g=Number.POSITIVE_INFINITY,O=Number.NEGATIVE_INFINITY,D=Number.POSITIVE_INFINITY,w=Number.NEGATIVE_INFINITY,x=Number.POSITIVE_INFINITY,H=Number.NEGATIVE_INFINITY;for(let bt=0;bt<k.length/3;bt++)g=Math.min(g,k[bt*3+0]),O=Math.max(O,k[bt*3+0]),D=Math.min(D,k[bt*3+1]),w=Math.max(w,k[bt*3+1]),x=Math.min(x,k[bt*3+2]),H=Math.max(H,k[bt*3+2]);let j=n?n.subarray(0,F*3):void 0,X;if(m(j)){let bt=new Blob([j],{type:"application/binary"});X=URL.createObjectURL(bt)}let tt=s?s.subarray(0,F*2):void 0,G;if(m(tt)){let bt=new Blob([tt],{type:"application/binary"});G=URL.createObjectURL(bt)}let It=m(o)?oZt(o.subarray(0,F*4)):void 0,gt;if(m(It)){let bt=new Blob([It],{type:"application/binary"});gt=URL.createObjectURL(bt)}let Yt=m(B)?B.subarray(0,F):void 0,Ut;if(m(Yt)){let bt=new Blob([Yt],{type:"application/binary"});Ut=URL.createObjectURL(bt)}let Ct=m(B)?new Float32Array(U):void 0,zt;if(m(Ct)){for(let ee=0;ee<Ct.length;++ee)Ct[ee]=ee;let bt=new Blob([Ct],{type:"application/binary"});zt=URL.createObjectURL(bt)}let kt={},Jt={};kt.POSITION=d.length,h.push({uri:c,byteLength:k.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:k.byteLength,target:34962}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5126,count:k.length/3,type:"VEC3",max:[g,D,x],min:[O,w,H]}),m(X)&&(kt.NORMAL=d.length,h.push({uri:X,byteLength:j.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:j.byteLength,target:34962}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5126,count:j.length/3,type:"VEC3"})),m(G)&&(kt.TEXCOORD_0=d.length,h.push({uri:G,byteLength:tt.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:tt.byteLength,target:34962}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5126,count:tt.length/2,type:"VEC2"})),m(gt)&&(kt.COLOR_0=d.length,h.push({uri:gt,byteLength:It.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:It.byteLength,target:34962}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5126,count:It.length/4,type:"VEC4"})),m(Ut)&&(kt._FEATURE_ID_0=d.length,h.push({uri:Ut,byteLength:Yt.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:Yt.byteLength,target:34963}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5126,count:Yt.length,type:"SCALAR"}),Jt.EXT_mesh_features={featureIds:[{attribute:0,propertyTable:0,featureCount:U}]},I.push("EXT_mesh_features")),m(zt)&&(h.push({uri:zt,byteLength:Ct.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:Ct.byteLength,target:34963}),R.EXT_structural_metadata={schema:{id:"i3s-metadata-schema-001",name:"I3S metadata schema 001",description:"The schema for I3S metadata",version:"1.0",classes:{feature:{name:"feature",description:"Feature metadata",properties:{index:{description:"The feature index",type:"SCALAR",componentType:"FLOAT32",required:!0}}}}},propertyTables:[{name:"feature-indices-mapping",class:"feature",count:U,properties:{index:{values:A.length-1}}}]},I.push("EXT_structural_metadata")),m(Q)&&(h.push({uri:Q,byteLength:M.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:M.byteLength,target:34963}),d.push({bufferView:A.length-1,byteOffset:0,componentType:5125,count:M.length,type:"SCALAR"}),Jt.CESIUM_primitive_outline={indices:d.length-1},I.push("CESIUM_primitive_outline")),h.push({uri:b,byteLength:C.byteLength}),A.push({buffer:h.length-1,byteOffset:0,byteLength:C.byteLength,target:34963});let Wt=[];return N>0&&(d.push({bufferView:A.length-1,byteOffset:0,componentType:5125,count:N,type:"SCALAR"}),Wt.push({attributes:kt,indices:d.length-1,material:Wt.length,extensions:Jt})),N<t&&(d.push({bufferView:A.length-1,byteOffset:4*N,componentType:5125,count:t-N,type:"SCALAR"}),Wt.push({attributes:kt,indices:d.length-1,material:Wt.length,extensions:Jt,extra:{isTransparent:!0}})),f.push({primitives:Wt}),_.push(0),E.push({mesh:0}),{buffers:h,bufferViews:A,accessors:d,meshes:f,nodes:E,nodesInScene:_,rootExtensions:R,extensionsUsed:I}}function AZt(t,e,i,n){let s=new Uint8Array(t,0,5);return s[0]===68&&s[1]===82&&s[2]===65&&s[3]===67&&s[4]===79?hZt(t,i):lZt(t,e,i,n)}function hZt(t){let e=gG,i=new e.DecoderBuffer,n=new Uint8Array(t);i.Init(n,n.length);let s=new e.Decoder,o=s.GetEncodedGeometryType(i),r=new e.MetadataQuerier,a,h;o===e.TRIANGULAR_MESH&&(a=new e.Mesh,h=s.DecodeBufferToMesh(i,a));let A={vertexCount:[0],featureCount:0};if(m(h)&&h.ok()&&a.ptr!==0){let d=a.num_faces(),f=a.num_attributes(),E=a.num_points();A.indices=new Uint32Array(d*3);let _=A.indices;A.vertexCount[0]=E,A.scale_x=1,A.scale_y=1;let R=new e.DracoInt32Array(3);for(let I=0;I<d;++I)s.GetFaceFromMesh(a,I,R),_[I*3]=R.GetValue(0),_[I*3+1]=R.GetValue(1),_[I*3+2]=R.GetValue(2);e.destroy(R);for(let I=0;I<f;++I){let C=s.GetAttribute(a,I),N=cZt(e,s,a,C,E),T=C.attribute_type(),b="unknown";T===e.POSITION?b="positions":T===e.NORMAL?b="normals":T===e.COLOR?b="colors":T===e.TEX_COORD&&(b="uv0s");let F=s.GetAttributeMetadata(a,I);if(F.ptr!==0){let B=r.NumEntries(F);for(let U=0;U<B;++U){let Q=r.GetEntryName(F,U);Q==="i3s-scale_x"?A.scale_x=r.GetDoubleEntry(F,"i3s-scale_x"):Q==="i3s-scale_y"?A.scale_y=r.GetDoubleEntry(F,"i3s-scale_y"):Q==="i3s-attribute-type"&&(b=r.GetStringEntry(F,"i3s-attribute-type"))}}m(A[b])&&console.log("Attribute already exists",b),A[b]=N,b==="feature-index"&&A.featureCount++}e.destroy(a)}return e.destroy(r),e.destroy(s),A}function cZt(t,e,i,n,s){let o=n.num_components()*s,r,h=[function(){},function(){r=new t.DracoInt8Array(o),e.GetAttributeInt8ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Int8Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){r=new t.DracoInt8Array(o),e.GetAttributeUInt8ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Uint8Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){r=new t.DracoInt16Array(o),e.GetAttributeInt16ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Int16Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){r=new t.DracoInt16Array(o),e.GetAttributeUInt16ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Uint16Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){r=new t.DracoInt32Array(o),e.GetAttributeInt32ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Int32Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){r=new t.DracoInt32Array(o),e.GetAttributeUInt32ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Uint32Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){},function(){},function(){r=new t.DracoFloat32Array(o),e.GetAttributeFloatForAllPoints(i,n,r)||console.error("Bad stream");let d=new Float32Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d},function(){},function(){r=new t.DracoUInt8Array(o),e.GetAttributeUInt8ForAllPoints(i,n,r)||console.error("Bad stream");let d=new Uint8Array(o);for(let f=0;f<o;++f)d[f]=r.GetValue(f);return d}][n.data_type()]();return m(r)&&t.destroy(r),h}function lZt(t,e,i,n){let s={vertexCount:0},o=new DataView(t);try{let r=0;if(s.vertexCount=o.getUint32(r,1),r+=4,s.featureCount=o.getUint32(r,1),r+=4,m(i))for(let a=0;a<i.attributes.length;a++)m(jg[i.attributes[a]])?r=jg[i.attributes[a]](s,t,r):console.error("Unknown decoder for",i.attributes[a]);else{let a=e.ordering,h=e.featureAttributeOrder;m(n)&&m(n.geometryData)&&m(n.geometryData[0])&&m(n.geometryData[0].params)&&(a=Object.keys(n.geometryData[0].params.vertexAttributes),h=Object.keys(n.geometryData[0].params.featureAttributes));for(let A=0;A<a.length;A++){let d=jg[a[A]];r=d(s,t,r)}for(let A=0;A<h.length;A++){let d=jg[h[A]];r=d(s,t,r)}}}catch(r){console.error(r)}return s.scale_x=1,s.scale_y=1,s}function dZt(t){let e=AZt(t.binaryData,t.schema,t.bufferInfo,t.featureData);m(t.geoidDataList)&&t.geoidDataList.length>0&&jRt(e.vertexCount,e.positions,e.scale_x,e.scale_y,t.cartographicCenter,t.geoidDataList,!1),HRt(e.vertexCount,e.positions,e.normals,t.cartographicCenter,t.cartesianCenter,t.parentRotation,t.ellipsoidRadiiSquare,e.scale_x,e.scale_y),m(e.uv0s)&&m(e["uv-region"])&&vRt(e.vertexCount,e.uv0s,e["uv-region"]);let i;if(m(e["feature-index"]))i=e["feature-index"];else if(m(e.faceRange)){i=new Array(e.vertexCount);for(let r=0;r<e.faceRange.length-1;r+=2){let a=r/2,h=e.faceRange[r],A=e.faceRange[r+1];for(let d=h;d<=A;d++)i[d*3]=a,i[d*3+1]=a,i[d*3+2]=a}}if(t.calculateNormals){let r=rZt(e.vertexCount,e.indices,e.positions,e.normals,e.uv0s,e.colors,i);m(r.normals)&&(e.normals=r.normals,m(r.vertexCount)&&(e.vertexCount=r.vertexCount,e.indices=r.indices,e.positions=r.positions,e.uv0s=r.uv0s,e.colors=r.colors,i=r.featureIndex))}let n=aZt(e.vertexCount,e.indices,e.positions,e.normals,e.uv0s,e.colors,i,t),s={positions:e.positions,indices:e.indices,featureIndex:i,sourceURL:t.url,cartesianCenter:t.cartesianCenter,parentRotation:t.parentRotation};return n._customAttributes=s,{meshData:n}}async function mZt(t,e){let i=t.webAssemblyConfig;return m(i)&&m(i.wasmBinaryFile)?gG=await(0,CG.default)(i):gG=await(0,CG.default)(),!0}function fZt(t,e){let i=t.webAssemblyConfig;return m(i)?mZt(t,e):dZt(t,e)}var CG,gG,QA,xg,Pg,Jg,uG,jg,EZt,NG=S(()=>{Ns();Ft();mt();Ml();Oe();ri();Ht();Qn();dn();_e();CG=co(tG(),1);B8();QA=new l,xg=new l,Pg=new l;Jg=new l,uG=new l;jg={position:function(t,e,i){let n=t.vertexCount*3;return t.positions=new Float32Array(e,i,n),i+=n*4,i},normal:function(t,e,i){let n=t.vertexCount*3;return t.normals=new Float32Array(e,i,n),i+=n*4,i},uv0:function(t,e,i){let n=t.vertexCount*2;return t.uv0s=new Float32Array(e,i,n),i+=n*4,i},color:function(t,e,i){let n=t.vertexCount*4;return t.colors=new Uint8Array(e,i,n),i+=n,i},featureId:function(t,e,i){let n=t.featureCount;return i+=n*8,i},id:function(t,e,i){let n=t.featureCount;return i+=n*8,i},faceRange:function(t,e,i){let n=t.featureCount*2;return t.faceRange=new Uint32Array(e,i,n),i+=n*4,i},uvRegion:function(t,e,i){let n=t.vertexCount*4;return t["uv-region"]=new Uint16Array(e,i,n),i+=n*2,i},region:function(t,e,i){let n=t.vertexCount*4;return t["uv-region"]=new Uint16Array(e,i,n),i+=n*2,i}};EZt=Wi(fZt)});var _Zt,PR,D8=S(()=>{_Zt={VK_FORMAT_UNDEFINED:0,VK_FORMAT_R4G4_UNORM_PACK8:1,VK_FORMAT_R4G4B4A4_UNORM_PACK16:2,VK_FORMAT_B4G4R4A4_UNORM_PACK16:3,VK_FORMAT_R5G6B5_UNORM_PACK16:4,VK_FORMAT_B5G6R5_UNORM_PACK16:5,VK_FORMAT_R5G5B5A1_UNORM_PACK16:6,VK_FORMAT_B5G5R5A1_UNORM_PACK16:7,VK_FORMAT_A1R5G5B5_UNORM_PACK16:8,VK_FORMAT_R8_UNORM:9,VK_FORMAT_R8_SNORM:10,VK_FORMAT_R8_USCALED:11,VK_FORMAT_R8_SSCALED:12,VK_FORMAT_R8_UINT:13,VK_FORMAT_R8_SINT:14,VK_FORMAT_R8_SRGB:15,VK_FORMAT_R8G8_UNORM:16,VK_FORMAT_R8G8_SNORM:17,VK_FORMAT_R8G8_USCALED:18,VK_FORMAT_R8G8_SSCALED:19,VK_FORMAT_R8G8_UINT:20,VK_FORMAT_R8G8_SINT:21,VK_FORMAT_R8G8_SRGB:22,VK_FORMAT_R8G8B8_UNORM:23,VK_FORMAT_R8G8B8_SNORM:24,VK_FORMAT_R8G8B8_USCALED:25,VK_FORMAT_R8G8B8_SSCALED:26,VK_FORMAT_R8G8B8_UINT:27,VK_FORMAT_R8G8B8_SINT:28,VK_FORMAT_R8G8B8_SRGB:29,VK_FORMAT_B8G8R8_UNORM:30,VK_FORMAT_B8G8R8_SNORM:31,VK_FORMAT_B8G8R8_USCALED:32,VK_FORMAT_B8G8R8_SSCALED:33,VK_FORMAT_B8G8R8_UINT:34,VK_FORMAT_B8G8R8_SINT:35,VK_FORMAT_B8G8R8_SRGB:36,VK_FORMAT_R8G8B8A8_UNORM:37,VK_FORMAT_R8G8B8A8_SNORM:38,VK_FORMAT_R8G8B8A8_USCALED:39,VK_FORMAT_R8G8B8A8_SSCALED:40,VK_FORMAT_R8G8B8A8_UINT:41,VK_FORMAT_R8G8B8A8_SINT:42,VK_FORMAT_R8G8B8A8_SRGB:43,VK_FORMAT_B8G8R8A8_UNORM:44,VK_FORMAT_B8G8R8A8_SNORM:45,VK_FORMAT_B8G8R8A8_USCALED:46,VK_FORMAT_B8G8R8A8_SSCALED:47,VK_FORMAT_B8G8R8A8_UINT:48,VK_FORMAT_B8G8R8A8_SINT:49,VK_FORMAT_B8G8R8A8_SRGB:50,VK_FORMAT_A8B8G8R8_UNORM_PACK32:51,VK_FORMAT_A8B8G8R8_SNORM_PACK32:52,VK_FORMAT_A8B8G8R8_USCALED_PACK32:53,VK_FORMAT_A8B8G8R8_SSCALED_PACK32:54,VK_FORMAT_A8B8G8R8_UINT_PACK32:55,VK_FORMAT_A8B8G8R8_SINT_PACK32:56,VK_FORMAT_A8B8G8R8_SRGB_PACK32:57,VK_FORMAT_A2R10G10B10_UNORM_PACK32:58,VK_FORMAT_A2R10G10B10_SNORM_PACK32:59,VK_FORMAT_A2R10G10B10_USCALED_PACK32:60,VK_FORMAT_A2R10G10B10_SSCALED_PACK32:61,VK_FORMAT_A2R10G10B10_UINT_PACK32:62,VK_FORMAT_A2R10G10B10_SINT_PACK32:63,VK_FORMAT_A2B10G10R10_UNORM_PACK32:64,VK_FORMAT_A2B10G10R10_SNORM_PACK32:65,VK_FORMAT_A2B10G10R10_USCALED_PACK32:66,VK_FORMAT_A2B10G10R10_SSCALED_PACK32:67,VK_FORMAT_A2B10G10R10_UINT_PACK32:68,VK_FORMAT_A2B10G10R10_SINT_PACK32:69,VK_FORMAT_R16_UNORM:70,VK_FORMAT_R16_SNORM:71,VK_FORMAT_R16_USCALED:72,VK_FORMAT_R16_SSCALED:73,VK_FORMAT_R16_UINT:74,VK_FORMAT_R16_SINT:75,VK_FORMAT_R16_SFLOAT:76,VK_FORMAT_R16G16_UNORM:77,VK_FORMAT_R16G16_SNORM:78,VK_FORMAT_R16G16_USCALED:79,VK_FORMAT_R16G16_SSCALED:80,VK_FORMAT_R16G16_UINT:81,VK_FORMAT_R16G16_SINT:82,VK_FORMAT_R16G16_SFLOAT:83,VK_FORMAT_R16G16B16_UNORM:84,VK_FORMAT_R16G16B16_SNORM:85,VK_FORMAT_R16G16B16_USCALED:86,VK_FORMAT_R16G16B16_SSCALED:87,VK_FORMAT_R16G16B16_UINT:88,VK_FORMAT_R16G16B16_SINT:89,VK_FORMAT_R16G16B16_SFLOAT:90,VK_FORMAT_R16G16B16A16_UNORM:91,VK_FORMAT_R16G16B16A16_SNORM:92,VK_FORMAT_R16G16B16A16_USCALED:93,VK_FORMAT_R16G16B16A16_SSCALED:94,VK_FORMAT_R16G16B16A16_UINT:95,VK_FORMAT_R16G16B16A16_SINT:96,VK_FORMAT_R16G16B16A16_SFLOAT:97,VK_FORMAT_R32_UINT:98,VK_FORMAT_R32_SINT:99,VK_FORMAT_R32_SFLOAT:100,VK_FORMAT_R32G32_UINT:101,VK_FORMAT_R32G32_SINT:102,VK_FORMAT_R32G32_SFLOAT:103,VK_FORMAT_R32G32B32_UINT:104,VK_FORMAT_R32G32B32_SINT:105,VK_FORMAT_R32G32B32_SFLOAT:106,VK_FORMAT_R32G32B32A32_UINT:107,VK_FORMAT_R32G32B32A32_SINT:108,VK_FORMAT_R32G32B32A32_SFLOAT:109,VK_FORMAT_R64_UINT:110,VK_FORMAT_R64_SINT:111,VK_FORMAT_R64_SFLOAT:112,VK_FORMAT_R64G64_UINT:113,VK_FORMAT_R64G64_SINT:114,VK_FORMAT_R64G64_SFLOAT:115,VK_FORMAT_R64G64B64_UINT:116,VK_FORMAT_R64G64B64_SINT:117,VK_FORMAT_R64G64B64_SFLOAT:118,VK_FORMAT_R64G64B64A64_UINT:119,VK_FORMAT_R64G64B64A64_SINT:120,VK_FORMAT_R64G64B64A64_SFLOAT:121,VK_FORMAT_B10G11R11_UFLOAT_PACK32:122,VK_FORMAT_E5B9G9R9_UFLOAT_PACK32:123,VK_FORMAT_D16_UNORM:124,VK_FORMAT_X8_D24_UNORM_PACK32:125,VK_FORMAT_D32_SFLOAT:126,VK_FORMAT_S8_UINT:127,VK_FORMAT_D16_UNORM_S8_UINT:128,VK_FORMAT_D24_UNORM_S8_UINT:129,VK_FORMAT_D32_SFLOAT_S8_UINT:130,VK_FORMAT_BC1_RGB_UNORM_BLOCK:131,VK_FORMAT_BC1_RGB_SRGB_BLOCK:132,VK_FORMAT_BC1_RGBA_UNORM_BLOCK:133,VK_FORMAT_BC1_RGBA_SRGB_BLOCK:134,VK_FORMAT_BC2_UNORM_BLOCK:135,VK_FORMAT_BC2_SRGB_BLOCK:136,VK_FORMAT_BC3_UNORM_BLOCK:137,VK_FORMAT_BC3_SRGB_BLOCK:138,VK_FORMAT_BC4_UNORM_BLOCK:139,VK_FORMAT_BC4_SNORM_BLOCK:140,VK_FORMAT_BC5_UNORM_BLOCK:141,VK_FORMAT_BC5_SNORM_BLOCK:142,VK_FORMAT_BC6H_UFLOAT_BLOCK:143,VK_FORMAT_BC6H_SFLOAT_BLOCK:144,VK_FORMAT_BC7_UNORM_BLOCK:145,VK_FORMAT_BC7_SRGB_BLOCK:146,VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK:147,VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK:148,VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK:149,VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK:150,VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK:151,VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK:152,VK_FORMAT_EAC_R11_UNORM_BLOCK:153,VK_FORMAT_EAC_R11_SNORM_BLOCK:154,VK_FORMAT_EAC_R11G11_UNORM_BLOCK:155,VK_FORMAT_EAC_R11G11_SNORM_BLOCK:156,VK_FORMAT_ASTC_4x4_UNORM_BLOCK:157,VK_FORMAT_ASTC_4x4_SRGB_BLOCK:158,VK_FORMAT_ASTC_5x4_UNORM_BLOCK:159,VK_FORMAT_ASTC_5x4_SRGB_BLOCK:160,VK_FORMAT_ASTC_5x5_UNORM_BLOCK:161,VK_FORMAT_ASTC_5x5_SRGB_BLOCK:162,VK_FORMAT_ASTC_6x5_UNORM_BLOCK:163,VK_FORMAT_ASTC_6x5_SRGB_BLOCK:164,VK_FORMAT_ASTC_6x6_UNORM_BLOCK:165,VK_FORMAT_ASTC_6x6_SRGB_BLOCK:166,VK_FORMAT_ASTC_8x5_UNORM_BLOCK:167,VK_FORMAT_ASTC_8x5_SRGB_BLOCK:168,VK_FORMAT_ASTC_8x6_UNORM_BLOCK:169,VK_FORMAT_ASTC_8x6_SRGB_BLOCK:170,VK_FORMAT_ASTC_8x8_UNORM_BLOCK:171,VK_FORMAT_ASTC_8x8_SRGB_BLOCK:172,VK_FORMAT_ASTC_10x5_UNORM_BLOCK:173,VK_FORMAT_ASTC_10x5_SRGB_BLOCK:174,VK_FORMAT_ASTC_10x6_UNORM_BLOCK:175,VK_FORMAT_ASTC_10x6_SRGB_BLOCK:176,VK_FORMAT_ASTC_10x8_UNORM_BLOCK:177,VK_FORMAT_ASTC_10x8_SRGB_BLOCK:178,VK_FORMAT_ASTC_10x10_UNORM_BLOCK:179,VK_FORMAT_ASTC_10x10_SRGB_BLOCK:180,VK_FORMAT_ASTC_12x10_UNORM_BLOCK:181,VK_FORMAT_ASTC_12x10_SRGB_BLOCK:182,VK_FORMAT_ASTC_12x12_UNORM_BLOCK:183,VK_FORMAT_ASTC_12x12_SRGB_BLOCK:184,VK_FORMAT_G8B8G8R8_422_UNORM:1000156e3,VK_FORMAT_B8G8R8G8_422_UNORM:1000156001,VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM:1000156002,VK_FORMAT_G8_B8R8_2PLANE_420_UNORM:1000156003,VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM:1000156004,VK_FORMAT_G8_B8R8_2PLANE_422_UNORM:1000156005,VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM:1000156006,VK_FORMAT_R10X6_UNORM_PACK16:1000156007,VK_FORMAT_R10X6G10X6_UNORM_2PACK16:1000156008,VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16:1000156009,VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16:1000156010,VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16:1000156011,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16:1000156012,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16:1000156013,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16:1000156014,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16:1000156015,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16:1000156016,VK_FORMAT_R12X4_UNORM_PACK16:1000156017,VK_FORMAT_R12X4G12X4_UNORM_2PACK16:1000156018,VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16:1000156019,VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16:1000156020,VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16:1000156021,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16:1000156022,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16:1000156023,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16:1000156024,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16:1000156025,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16:1000156026,VK_FORMAT_G16B16G16R16_422_UNORM:1000156027,VK_FORMAT_B16G16R16G16_422_UNORM:1000156028,VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM:1000156029,VK_FORMAT_G16_B16R16_2PLANE_420_UNORM:1000156030,VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM:1000156031,VK_FORMAT_G16_B16R16_2PLANE_422_UNORM:1000156032,VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM:1000156033,VK_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG:1000054e3,VK_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG:1000054001,VK_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG:1000054002,VK_FORMAT_PVRTC2_4BPP_UNORM_BLOCK_IMG:1000054003,VK_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG:1000054004,VK_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG:1000054005,VK_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG:1000054006,VK_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG:1000054007,VK_FORMAT_ASTC_4x4_SFLOAT_BLOCK_EXT:1000066e3,VK_FORMAT_ASTC_5x4_SFLOAT_BLOCK_EXT:1000066001,VK_FORMAT_ASTC_5x5_SFLOAT_BLOCK_EXT:1000066002,VK_FORMAT_ASTC_6x5_SFLOAT_BLOCK_EXT:1000066003,VK_FORMAT_ASTC_6x6_SFLOAT_BLOCK_EXT:1000066004,VK_FORMAT_ASTC_8x5_SFLOAT_BLOCK_EXT:1000066005,VK_FORMAT_ASTC_8x6_SFLOAT_BLOCK_EXT:1000066006,VK_FORMAT_ASTC_8x8_SFLOAT_BLOCK_EXT:1000066007,VK_FORMAT_ASTC_10x5_SFLOAT_BLOCK_EXT:1000066008,VK_FORMAT_ASTC_10x6_SFLOAT_BLOCK_EXT:1000066009,VK_FORMAT_ASTC_10x8_SFLOAT_BLOCK_EXT:1000066010,VK_FORMAT_ASTC_10x10_SFLOAT_BLOCK_EXT:1000066011,VK_FORMAT_ASTC_12x10_SFLOAT_BLOCK_EXT:1000066012,VK_FORMAT_ASTC_12x12_SFLOAT_BLOCK_EXT:1000066013,VK_FORMAT_G8B8G8R8_422_UNORM_KHR:1000156e3,VK_FORMAT_B8G8R8G8_422_UNORM_KHR:1000156001,VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM_KHR:1000156002,VK_FORMAT_G8_B8R8_2PLANE_420_UNORM_KHR:1000156003,VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM_KHR:1000156004,VK_FORMAT_G8_B8R8_2PLANE_422_UNORM_KHR:1000156005,VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM_KHR:1000156006,VK_FORMAT_R10X6_UNORM_PACK16_KHR:1000156007,VK_FORMAT_R10X6G10X6_UNORM_2PACK16_KHR:1000156008,VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16_KHR:1000156009,VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16_KHR:1000156010,VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16_KHR:1000156011,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16_KHR:1000156012,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16_KHR:1000156013,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16_KHR:1000156014,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16_KHR:1000156015,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16_KHR:1000156016,VK_FORMAT_R12X4_UNORM_PACK16_KHR:1000156017,VK_FORMAT_R12X4G12X4_UNORM_2PACK16_KHR:1000156018,VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16_KHR:1000156019,VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16_KHR:1000156020,VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16_KHR:1000156021,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16_KHR:1000156022,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16_KHR:1000156023,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16_KHR:1000156024,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16_KHR:1000156025,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16_KHR:1000156026,VK_FORMAT_G16B16G16R16_422_UNORM_KHR:1000156027,VK_FORMAT_B16G16R16G16_422_UNORM_KHR:1000156028,VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM_KHR:1000156029,VK_FORMAT_G16_B16R16_2PLANE_420_UNORM_KHR:1000156030,VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM_KHR:1000156031,VK_FORMAT_G16_B16R16_2PLANE_422_UNORM_KHR:1000156032,VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM_KHR:1000156033},PR=Object.freeze(_Zt)});function U8(t){return typeof TextDecoder<"u"?new TextDecoder().decode(t):Buffer.from(t).toString("utf8")}function M8(t){let e=new Uint8Array(t.buffer,t.byteOffset,Po.length);if(e[0]!==Po[0]||e[1]!==Po[1]||e[2]!==Po[2]||e[3]!==Po[3]||e[4]!==Po[4]||e[5]!==Po[5]||e[6]!==Po[6]||e[7]!==Po[7]||e[8]!==Po[8]||e[9]!==Po[9]||e[10]!==Po[10]||e[11]!==Po[11])throw new Error("Missing KTX 2.0 identifier.");let i=new FG,n=17*Uint32Array.BYTES_PER_ELEMENT,s=new Yd(t,Po.length,n,!0);i.vkFormat=s._nextUint32(),i.typeSize=s._nextUint32(),i.pixelWidth=s._nextUint32(),i.pixelHeight=s._nextUint32(),i.pixelDepth=s._nextUint32(),i.layerCount=s._nextUint32(),i.faceCount=s._nextUint32();let o=s._nextUint32();i.supercompressionScheme=s._nextUint32();let r=s._nextUint32(),a=s._nextUint32(),h=s._nextUint32(),A=s._nextUint32(),d=s._nextUint64(),f=s._nextUint64(),E=o*3*8,_=new Yd(t,Po.length+n,E,!0);for(let tt=0;tt<o;tt++)i.levels.push({levelData:new Uint8Array(t.buffer,t.byteOffset+_._nextUint64(),_._nextUint64()),uncompressedByteLength:_._nextUint64()});let R=new Yd(t,r,a,!0),I={vendorId:R._skip(4)._nextUint16(),descriptorType:R._nextUint16(),versionNumber:R._nextUint16(),descriptorBlockSize:R._nextUint16(),colorModel:R._nextUint8(),colorPrimaries:R._nextUint8(),transferFunction:R._nextUint8(),flags:R._nextUint8(),texelBlockDimension:[R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8()],bytesPlane:[R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8()],samples:[]},T=(I.descriptorBlockSize/4-6)/4;for(let tt=0;tt<T;tt++){let G={bitOffset:R._nextUint16(),bitLength:R._nextUint8(),channelType:R._nextUint8(),samplePosition:[R._nextUint8(),R._nextUint8(),R._nextUint8(),R._nextUint8()],sampleLower:-1/0,sampleUpper:1/0};G.channelType&64?(G.sampleLower=R._nextInt32(),G.sampleUpper=R._nextInt32()):(G.sampleLower=R._nextUint32(),G.sampleUpper=R._nextUint32()),I.samples[tt]=G}i.dataFormatDescriptor.length=0,i.dataFormatDescriptor.push(I);let b=new Yd(t,h,A,!0);for(;b._offset<A;){let tt=b._nextUint32(),G=b._scan(tt),It=U8(G);if(i.keyValue[It]=b._nextUint8Array(tt-G.byteLength-1),It.match(/^ktx/i)){let Yt=U8(i.keyValue[It]);i.keyValue[It]=Yt.substring(0,Yt.lastIndexOf("\0"))}let gt=tt%4?4-tt%4:0;b._skip(gt)}if(f<=0)return i;let F=new Yd(t,d,f,!0),B=F._nextUint16(),U=F._nextUint16(),Q=F._nextUint32(),M=F._nextUint32(),k=F._nextUint32(),y=F._nextUint32(),c=[];for(let tt=0;tt<o;tt++)c.push({imageFlags:F._nextUint32(),rgbSliceByteOffset:F._nextUint32(),rgbSliceByteLength:F._nextUint32(),alphaSliceByteOffset:F._nextUint32(),alphaSliceByteLength:F._nextUint32()});let g=d+F._offset,O=g+Q,D=O+M,w=D+k,x=new Uint8Array(t.buffer,t.byteOffset+g,Q),H=new Uint8Array(t.buffer,t.byteOffset+O,M),j=new Uint8Array(t.buffer,t.byteOffset+D,k),X=new Uint8Array(t.buffer,t.byteOffset+w,y);return i.globalData={endpointCount:B,selectorCount:U,imageDescs:c,endpointsData:x,selectorsData:H,tablesData:j,extendedData:X},i}var FG,Yd,fOe,Po,Q8=S(()=>{FG=class{constructor(){this.vkFormat=0,this.typeSize=1,this.pixelWidth=0,this.pixelHeight=0,this.pixelDepth=0,this.layerCount=0,this.faceCount=1,this.supercompressionScheme=0,this.levels=[],this.dataFormatDescriptor=[{vendorId:0,descriptorType:0,descriptorBlockSize:0,versionNumber:2,colorModel:0,colorPrimaries:1,transferFunction:2,flags:0,texelBlockDimension:[0,0,0,0],bytesPlane:[0,0,0,0,0,0,0,0],samples:[]}],this.keyValue={},this.globalData=null}},Yd=class{constructor(e,i,n,s){this._dataView=void 0,this._littleEndian=void 0,this._offset=void 0,this._dataView=new DataView(e.buffer,e.byteOffset+i,n),this._littleEndian=s,this._offset=0}_nextUint8(){let e=this._dataView.getUint8(this._offset);return this._offset+=1,e}_nextUint16(){let e=this._dataView.getUint16(this._offset,this._littleEndian);return this._offset+=2,e}_nextUint32(){let e=this._dataView.getUint32(this._offset,this._littleEndian);return this._offset+=4,e}_nextUint64(){let e=this._dataView.getUint32(this._offset,this._littleEndian),i=this._dataView.getUint32(this._offset+4,this._littleEndian),n=e+2**32*i;return this._offset+=8,n}_nextInt32(){let e=this._dataView.getInt32(this._offset,this._littleEndian);return this._offset+=4,e}_nextUint8Array(e){let i=new Uint8Array(this._dataView.buffer,this._dataView.byteOffset+this._offset,e);return this._offset+=e,i}_skip(e){return this._offset+=e,this}_scan(e,i=0){let n=this._offset,s=0;for(;this._dataView.getUint8(this._offset)!==i&&s<e;)s++,this._offset++;return s<e&&this._offset++,new Uint8Array(this._dataView.buffer,this._dataView.byteOffset+n,s)}},fOe=new Uint8Array([0]),Po=[171,75,84,88,32,50,48,187,13,10,26,10]});var k8=ts((Hg,YG)=>{var bG=function(){var t=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename<"u"&&(t=t||__filename),function(e){e=e||{};var i=typeof e<"u"?e:{},n,s;i.ready=new Promise(function(J,v){n=J,s=v});var o={},r;for(r in i)i.hasOwnProperty(r)&&(o[r]=i[r]);var a=[],h="./this.program",A=function(J,v){throw v},d=!1,f=!1,E=!1,_=!1;d=typeof window=="object",f=typeof importScripts=="function",E=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",_=!d&&!E&&!f;var R="";function I(J){return i.locateFile?i.locateFile(J,R):R+J}var C,N,T,b,F,B;E?(f?R=Xo("path").dirname(R)+"/":R=__dirname+"/",C=function(v,st){return F||(F=Xo("fs")),B||(B=Xo("path")),v=B.normalize(v),F.readFileSync(v,st?null:"utf8")},T=function(v){var st=C(v,!0);return st.buffer||(st=new Uint8Array(st)),w(st.buffer),st},process.argv.length>1&&(h=process.argv[1].replace(/\\/g,"/")),a=process.argv.slice(2),process.on("uncaughtException",function(J){if(!(J instanceof _a))throw J}),process.on("unhandledRejection",ki),A=function(J){process.exit(J)},i.inspect=function(){return"[Emscripten Module object]"}):_?(typeof read<"u"&&(C=function(v){return read(v)}),T=function(v){var st;return typeof readbuffer=="function"?new Uint8Array(readbuffer(v)):(st=read(v,"binary"),w(typeof st=="object"),st)},typeof scriptArgs<"u"?a=scriptArgs:typeof arguments<"u"&&(a=arguments),typeof quit=="function"&&(A=function(J){quit(J)}),typeof print<"u"&&(typeof console>"u"&&(console={}),console.log=print,console.warn=console.error=typeof printErr<"u"?printErr:print)):(d||f)&&(f?R=self.location.href:typeof document<"u"&&document.currentScript&&(R=document.currentScript.src),t&&(R=t),R.indexOf("blob:")!==0?R=R.substr(0,R.lastIndexOf("/")+1):R="",C=function(J){var v=new XMLHttpRequest;return v.open("GET",J,!1),v.send(null),v.responseText},f&&(T=function(J){var v=new XMLHttpRequest;return v.open("GET",J,!1),v.responseType="arraybuffer",v.send(null),new Uint8Array(v.response)}),N=function(J,v,st){var Rt=new XMLHttpRequest;Rt.open("GET",J,!0),Rt.responseType="arraybuffer",Rt.onload=function(){if(Rt.status==200||Rt.status==0&&Rt.response){v(Rt.response);return}st()},Rt.onerror=st,Rt.send(null)},b=function(J){document.title=J});var U=i.print||console.log.bind(console),Q=i.printErr||console.warn.bind(console);for(r in o)o.hasOwnProperty(r)&&(i[r]=o[r]);o=null,i.arguments&&(a=i.arguments),i.thisProgram&&(h=i.thisProgram),i.quit&&(A=i.quit);var M=0,k=function(J){M=J},y;i.wasmBinary&&(y=i.wasmBinary);var c=i.noExitRuntime||!0;typeof WebAssembly!="object"&&ki("no native wasm support detected");var g,O=!1,D;function w(J,v){J||ki("Assertion failed: "+v)}var x=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0;function H(J,v,st){for(var Rt=v+st,Vt=v;J[Vt]&&!(Vt>=Rt);)++Vt;if(Vt-v>16&&J.subarray&&x)return x.decode(J.subarray(v,Vt));for(var Bt="";v<Vt;){var jt=J[v++];if(!(jt&128)){Bt+=String.fromCharCode(jt);continue}var Mt=J[v++]&63;if((jt&224)==192){Bt+=String.fromCharCode((jt&31)<<6|Mt);continue}var Dt=J[v++]&63;if((jt&240)==224?jt=(jt&15)<<12|Mt<<6|Dt:jt=(jt&7)<<18|Mt<<12|Dt<<6|J[v++]&63,jt<65536)Bt+=String.fromCharCode(jt);else{var pe=jt-65536;Bt+=String.fromCharCode(55296|pe>>10,56320|pe&1023)}}return Bt}function j(J,v){return J?H(ee,J,v):""}function X(J,v,st,Rt){if(!(Rt>0))return 0;for(var Vt=st,Bt=st+Rt-1,jt=0;jt<J.length;++jt){var Mt=J.charCodeAt(jt);if(Mt>=55296&&Mt<=57343){var Dt=J.charCodeAt(++jt);Mt=65536+((Mt&1023)<<10)|Dt&1023}if(Mt<=127){if(st>=Bt)break;v[st++]=Mt}else if(Mt<=2047){if(st+1>=Bt)break;v[st++]=192|Mt>>6,v[st++]=128|Mt&63}else if(Mt<=65535){if(st+2>=Bt)break;v[st++]=224|Mt>>12,v[st++]=128|Mt>>6&63,v[st++]=128|Mt&63}else{if(st+3>=Bt)break;v[st++]=240|Mt>>18,v[st++]=128|Mt>>12&63,v[st++]=128|Mt>>6&63,v[st++]=128|Mt&63}}return v[st]=0,st-Vt}function tt(J,v,st){return X(J,ee,v,st)}function G(J){for(var v=0,st=0;st<J.length;++st){var Rt=J.charCodeAt(st);Rt>=55296&&Rt<=57343&&(Rt=65536+((Rt&1023)<<10)|J.charCodeAt(++st)&1023),Rt<=127?++v:Rt<=2047?v+=2:Rt<=65535?v+=3:v+=4}return v}var It=typeof TextDecoder<"u"?new TextDecoder("utf-16le"):void 0;function gt(J,v){for(var st=J,Rt=st>>1,Vt=Rt+v/2;!(Rt>=Vt)&&je[Rt];)++Rt;if(st=Rt<<1,st-J>32&&It)return It.decode(ee.subarray(J,st));for(var Bt="",jt=0;!(jt>=v/2);++jt){var Mt=ce[J+jt*2>>1];if(Mt==0)break;Bt+=String.fromCharCode(Mt)}return Bt}function Yt(J,v,st){if(st===void 0&&(st=2147483647),st<2)return 0;st-=2;for(var Rt=v,Vt=st<J.length*2?st/2:J.length,Bt=0;Bt<Vt;++Bt){var jt=J.charCodeAt(Bt);ce[v>>1]=jt,v+=2}return ce[v>>1]=0,v-Rt}function Ut(J){return J.length*2}function Ct(J,v){for(var st=0,Rt="";!(st>=v/4);){var Vt=Se[J+st*4>>2];if(Vt==0)break;if(++st,Vt>=65536){var Bt=Vt-65536;Rt+=String.fromCharCode(55296|Bt>>10,56320|Bt&1023)}else Rt+=String.fromCharCode(Vt)}return Rt}function zt(J,v,st){if(st===void 0&&(st=2147483647),st<4)return 0;for(var Rt=v,Vt=Rt+st-4,Bt=0;Bt<J.length;++Bt){var jt=J.charCodeAt(Bt);if(jt>=55296&&jt<=57343){var Mt=J.charCodeAt(++Bt);jt=65536+((jt&1023)<<10)|Mt&1023}if(Se[v>>2]=jt,v+=4,v+4>Vt)break}return Se[v>>2]=0,v-Rt}function kt(J){for(var v=0,st=0;st<J.length;++st){var Rt=J.charCodeAt(st);Rt>=55296&&Rt<=57343&&++st,v+=4}return v}function Jt(J,v){return J%v>0&&(J+=v-J%v),J}var Wt,bt,ee,ce,je,Se,Ue,Me,Ce;function Fe(J){Wt=J,i.HEAP8=bt=new Int8Array(J),i.HEAP16=ce=new Int16Array(J),i.HEAP32=Se=new Int32Array(J),i.HEAPU8=ee=new Uint8Array(J),i.HEAPU16=je=new Uint16Array(J),i.HEAPU32=Ue=new Uint32Array(J),i.HEAPF32=Me=new Float32Array(J),i.HEAPF64=Ce=new Float64Array(J)}var ni=i.INITIAL_MEMORY||16777216,ze,Be=[],Mi=[],Ri=[],si=[],qe=!1;function Oi(){if(i.preRun)for(typeof i.preRun=="function"&&(i.preRun=[i.preRun]);i.preRun.length;)Gi(i.preRun.shift());ao(Be)}function gn(){qe=!0,ao(Mi)}function De(){ao(Ri)}function Ye(){if(i.postRun)for(typeof i.postRun=="function"&&(i.postRun=[i.postRun]);i.postRun.length;)Ne(i.postRun.shift());ao(si)}function Gi(J){Be.unshift(J)}function An(J){Mi.unshift(J)}function Ne(J){si.unshift(J)}var ei=0,_n=null,hs=null;function Qi(J){ei++,i.monitorRunDependencies&&i.monitorRunDependencies(ei)}function nn(J){if(ei--,i.monitorRunDependencies&&i.monitorRunDependencies(ei),ei==0&&(_n!==null&&(clearInterval(_n),_n=null),hs)){var v=hs;hs=null,v()}}i.preloadedImages={},i.preloadedAudios={};function ki(J){i.onAbort&&i.onAbort(J),J+="",Q(J),O=!0,D=1,J="abort("+J+"). Build with -s ASSERTIONS=1 for more info.";var v=new WebAssembly.RuntimeError(J);throw s(v),v}function sn(J,v){return String.prototype.startsWith?J.startsWith(v):J.indexOf(v)===0}var Cs="data:application/octet-stream;base64,";function cs(J){return sn(J,Cs)}var xn="file://";function Pn(J){return sn(J,xn)}var Ai="basis_transcoder.wasm";cs(Ai)||(Ai=I(Ai));function Ci(J){try{if(J==Ai&&y)return new Uint8Array(y);if(T)return T(J);throw"both async and sync fetching of the wasm failed"}catch(v){ki(v)}}function Jn(){if(!y&&(d||f)){if(typeof fetch=="function"&&!Pn(Ai))return fetch(Ai,{credentials:"same-origin"}).then(function(J){if(!J.ok)throw"failed to load wasm binary file at '"+Ai+"'";return J.arrayBuffer()}).catch(function(){return Ci(Ai)});if(N)return new Promise(function(J,v){N(Ai,function(st){J(new Uint8Array(st))},v)})}return Promise.resolve().then(function(){return Ci(Ai)})}function ls(){var J={a:fm};function v(jt,Mt){var Dt=jt.exports;i.asm=Dt,g=i.asm.K,Fe(g.buffer),ze=i.asm.O,An(i.asm.L),nn("wasm-instantiate")}Qi("wasm-instantiate");function st(jt){v(jt.instance)}function Rt(jt){return Jn().then(function(Mt){var Dt=WebAssembly.instantiate(Mt,J);return Dt}).then(jt,function(Mt){Q("failed to asynchronously prepare wasm: "+Mt),ki(Mt)})}function Vt(){return!y&&typeof WebAssembly.instantiateStreaming=="function"&&!cs(Ai)&&!Pn(Ai)&&typeof fetch=="function"?fetch(Ai,{credentials:"same-origin"}).then(function(jt){var Mt=WebAssembly.instantiateStreaming(jt,J);return Mt.then(st,function(Dt){return Q("wasm streaming compile failed: "+Dt),Q("falling back to ArrayBuffer instantiation"),Rt(st)})}):Rt(st)}if(i.instantiateWasm)try{var Bt=i.instantiateWasm(J,v);return Bt}catch(jt){return Q("Module.instantiateWasm callback failed with error: "+jt),!1}return Vt().catch(s),{}}function ao(J){for(;J.length>0;){var v=J.shift();if(typeof v=="function"){v(i);continue}var st=v.func;typeof st=="number"?v.arg===void 0?ze.get(st)():ze.get(st)(v.arg):st(v.arg===void 0?null:v.arg)}}var qi={};function hn(J){for(;J.length;){var v=J.pop(),st=J.pop();st(v)}}function jo(J){return this.fromWireType(Ue[J>>2])}var ds={},on={},ws={},Vo=48,br=57;function So(J){if(J===void 0)return"_unknown";J=J.replace(/[^a-zA-Z0-9_]/g,"$");var v=J.charCodeAt(0);return v>=Vo&&v<=br?"_"+J:J}function $e(J,v){return J=So(J),new Function("body","return function "+J+`() {
    "use strict";    return body.apply(this, arguments);
};
`)(v)}function aa(J,v){var st=$e(v,function(Rt){this.name=v,this.message=Rt;var Vt=new Error(Rt).stack;Vt!==void 0&&(this.stack=this.toString()+`
`+Vt.replace(/^Error(:[^\n]*)?\n/,""))});return st.prototype=Object.create(J.prototype),st.prototype.constructor=st,st.prototype.toString=function(){return this.message===void 0?this.name:this.name+": "+this.message},st}var Yr=void 0;function xs(J){throw new Yr(J)}function gs(J,v,st){J.forEach(function(Mt){ws[Mt]=v});function Rt(Mt){var Dt=st(Mt);Dt.length!==J.length&&xs("Mismatched type converter count");for(var pe=0;pe<J.length;++pe)Oo(J[pe],Dt[pe])}var Vt=new Array(v.length),Bt=[],jt=0;v.forEach(function(Mt,Dt){on.hasOwnProperty(Mt)?Vt[Dt]=on[Mt]:(Bt.push(Mt),ds.hasOwnProperty(Mt)||(ds[Mt]=[]),ds[Mt].push(function(){Vt[Dt]=on[Mt],++jt,jt===Bt.length&&Rt(Vt)}))}),Bt.length===0&&Rt(Vt)}function Tn(J){var v=qi[J];delete qi[J];var st=v.rawConstructor,Rt=v.rawDestructor,Vt=v.fields,Bt=Vt.map(function(jt){return jt.getterReturnType}).concat(Vt.map(function(jt){return jt.setterArgumentType}));gs([J],Bt,function(jt){var Mt={};return Vt.forEach(function(Dt,pe){var Ge=Dt.fieldName,ci=jt[pe],pi=Dt.getter,cn=Dt.getterContext,Qe=jt[pe+Vt.length],Xs=Dt.setter,zo=Dt.setterContext;Mt[Ge]={read:function(Vr){return ci.fromWireType(pi(cn,Vr))},write:function(Vr,ml){var Ra=[];Xs(zo,Vr,Qe.toWireType(Ra,ml)),hn(Ra)}}}),[{name:v.name,fromWireType:function(Dt){var pe={};for(var Ge in Mt)pe[Ge]=Mt[Ge].read(Dt);return Rt(Dt),pe},toWireType:function(Dt,pe){for(var Ge in Mt)if(!(Ge in pe))throw new TypeError('Missing field:  "'+Ge+'"');var ci=st();for(Ge in Mt)Mt[Ge].write(ci,pe[Ge]);return Dt!==null&&Dt.push(Rt,ci),ci},argPackAdvance:8,readValueFromPointer:jo,destructorFunction:Rt}]})}function hr(J){switch(J){case 1:return 0;case 2:return 1;case 4:return 2;case 8:return 3;default:throw new TypeError("Unknown type size: "+J)}}function Uh(){for(var J=new Array(256),v=0;v<256;++v)J[v]=String.fromCharCode(v);Mh=J}var Mh=void 0;function On(J){for(var v="",st=J;ee[st];)v+=Mh[ee[st++]];return v}var cr=void 0;function Ii(J){throw new cr(J)}function Oo(J,v,st){if(st=st||{},!("argPackAdvance"in v))throw new TypeError("registerType registeredInstance requires argPackAdvance");var Rt=v.name;if(J||Ii('type "'+Rt+'" must have a positive integer typeid pointer'),on.hasOwnProperty(J)){if(st.ignoreDuplicateRegistrations)return;Ii("Cannot register type '"+Rt+"' twice")}if(on[J]=v,delete ws[J],ds.hasOwnProperty(J)){var Vt=ds[J];delete ds[J],Vt.forEach(function(Bt){Bt()})}}function Kc(J,v,st,Rt,Vt){var Bt=hr(st);v=On(v),Oo(J,{name:v,fromWireType:function(jt){return!!jt},toWireType:function(jt,Mt){return Mt?Rt:Vt},argPackAdvance:8,readValueFromPointer:function(jt){var Mt;if(st===1)Mt=bt;else if(st===2)Mt=ce;else if(st===4)Mt=Se;else throw new TypeError("Unknown boolean type size: "+v);return this.fromWireType(Mt[jt>>Bt])},destructorFunction:null})}function Xc(J){if(!(this instanceof dr)||!(J instanceof dr))return!1;for(var v=this.$$.ptrType.registeredClass,st=this.$$.ptr,Rt=J.$$.ptrType.registeredClass,Vt=J.$$.ptr;v.baseClass;)st=v.upcast(st),v=v.baseClass;for(;Rt.baseClass;)Vt=Rt.upcast(Vt),Rt=Rt.baseClass;return v===Rt&&st===Vt}function qc(J){return{count:J.count,deleteScheduled:J.deleteScheduled,preservePointerOnDelete:J.preservePointerOnDelete,ptr:J.ptr,ptrType:J.ptrType,smartPtr:J.smartPtr,smartPtrType:J.smartPtrType}}function Qh(J){function v(st){return st.$$.ptrType.registeredClass.name}Ii(v(J)+" instance already deleted")}var kh=!1;function Aa(J){}function Lh(J){J.smartPtr?J.smartPtrType.rawDestructor(J.smartPtr):J.ptrType.registeredClass.rawDestructor(J.ptr)}function ha(J){J.count.value-=1;var v=J.count.value===0;v&&Lh(J)}function Ka(J){return typeof FinalizationGroup>"u"?(Ka=function(v){return v},J):(kh=new FinalizationGroup(function(v){for(var st=v.next();!st.done;st=v.next()){var Rt=st.value;Rt.ptr?ha(Rt):console.warn("object already deleted: "+Rt.ptr)}}),Ka=function(v){return kh.register(v,v.$$,v.$$),v},Aa=function(v){kh.unregister(v.$$)},Ka(J))}function Vd(){if(this.$$.ptr||Qh(this),this.$$.preservePointerOnDelete)return this.$$.count.value+=1,this;var J=Ka(Object.create(Object.getPrototypeOf(this),{$$:{value:qc(this.$$)}}));return J.$$.count.value+=1,J.$$.deleteScheduled=!1,J}function Xa(){this.$$.ptr||Qh(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&Ii("Object already scheduled for deletion"),Aa(this),ha(this.$$),this.$$.preservePointerOnDelete||(this.$$.smartPtr=void 0,this.$$.ptr=void 0)}function Sd(){return!this.$$.ptr}var qa=void 0,lr=[];function kA(){for(;lr.length;){var J=lr.pop();J.$$.deleteScheduled=!1,J.delete()}}function $a(){return this.$$.ptr||Qh(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&Ii("Object already scheduled for deletion"),lr.push(this),lr.length===1&&qa&&qa(kA),this.$$.deleteScheduled=!0,this}function Od(){dr.prototype.isAliasOf=Xc,dr.prototype.clone=Vd,dr.prototype.delete=Xa,dr.prototype.isDeleted=Sd,dr.prototype.deleteLater=$a}function dr(){}var $c={};function tl(J,v,st){if(J[v].overloadTable===void 0){var Rt=J[v];J[v]=function(){return J[v].overloadTable.hasOwnProperty(arguments.length)||Ii("Function '"+st+"' called with an invalid number of arguments ("+arguments.length+") - expects one of ("+J[v].overloadTable+")!"),J[v].overloadTable[arguments.length].apply(this,arguments)},J[v].overloadTable=[],J[v].overloadTable[Rt.argCount]=Rt}}function yh(J,v,st){i.hasOwnProperty(J)?((st===void 0||i[J].overloadTable!==void 0&&i[J].overloadTable[st]!==void 0)&&Ii("Cannot register public name '"+J+"' twice"),tl(i,J,J),i.hasOwnProperty(st)&&Ii("Cannot register multiple overloads of a function with the same number of arguments ("+st+")!"),i[J].overloadTable[st]=v):(i[J]=v,st!==void 0&&(i[J].numArguments=st))}function mr(J,v,st,Rt,Vt,Bt,jt,Mt){this.name=J,this.constructor=v,this.instancePrototype=st,this.rawDestructor=Rt,this.baseClass=Vt,this.getActualType=Bt,this.upcast=jt,this.downcast=Mt,this.pureVirtualFunctions=[]}function wh(J,v,st){for(;v!==st;)v.upcast||Ii("Expected null or instance of "+st.name+", got an instance of "+v.name),J=v.upcast(J),v=v.baseClass;return J}function Bd(J,v){if(v===null)return this.isReference&&Ii("null is not a valid "+this.name),0;v.$$||Ii('Cannot pass "'+da(v)+'" as a '+this.name),v.$$.ptr||Ii("Cannot pass deleted object as a pointer of type "+this.name);var st=v.$$.ptrType.registeredClass,Rt=wh(v.$$.ptr,st,this.registeredClass);return Rt}function xh(J,v){var st;if(v===null)return this.isReference&&Ii("null is not a valid "+this.name),this.isSmartPointer?(st=this.rawConstructor(),J!==null&&J.push(this.rawDestructor,st),st):0;v.$$||Ii('Cannot pass "'+da(v)+'" as a '+this.name),v.$$.ptr||Ii("Cannot pass deleted object as a pointer of type "+this.name),!this.isConst&&v.$$.ptrType.isConst&&Ii("Cannot convert argument of type "+(v.$$.smartPtrType?v.$$.smartPtrType.name:v.$$.ptrType.name)+" to parameter type "+this.name);var Rt=v.$$.ptrType.registeredClass;if(st=wh(v.$$.ptr,Rt,this.registeredClass),this.isSmartPointer)switch(v.$$.smartPtr===void 0&&Ii("Passing raw pointer to smart pointer is illegal"),this.sharingPolicy){case 0:v.$$.smartPtrType===this?st=v.$$.smartPtr:Ii("Cannot convert argument of type "+(v.$$.smartPtrType?v.$$.smartPtrType.name:v.$$.ptrType.name)+" to parameter type "+this.name);break;case 1:st=v.$$.smartPtr;break;case 2:if(v.$$.smartPtrType===this)st=v.$$.smartPtr;else{var Vt=v.clone();st=this.rawShare(st,ho(function(){Vt.delete()})),J!==null&&J.push(this.rawDestructor,st)}break;default:Ii("Unsupporting sharing policy")}return st}function Ph(J,v){if(v===null)return this.isReference&&Ii("null is not a valid "+this.name),0;v.$$||Ii('Cannot pass "'+da(v)+'" as a '+this.name),v.$$.ptr||Ii("Cannot pass deleted object as a pointer of type "+this.name),v.$$.ptrType.isConst&&Ii("Cannot convert argument of type "+v.$$.ptrType.name+" to parameter type "+this.name);var st=v.$$.ptrType.registeredClass,Rt=wh(v.$$.ptr,st,this.registeredClass);return Rt}function el(J){return this.rawGetPointee&&(J=this.rawGetPointee(J)),J}function il(J){this.rawDestructor&&this.rawDestructor(J)}function Gd(J){J!==null&&J.delete()}function tA(J,v,st){if(v===st)return J;if(st.baseClass===void 0)return null;var Rt=tA(J,v,st.baseClass);return Rt===null?null:st.downcast(Rt)}function Wd(){return Object.keys(eA).length}function Dd(){var J=[];for(var v in eA)eA.hasOwnProperty(v)&&J.push(eA[v]);return J}function Ud(J){qa=J,lr.length&&qa&&qa(kA)}function LA(){i.getInheritedInstanceCount=Wd,i.getLiveInheritedInstances=Dd,i.flushPendingDeletes=kA,i.setDelayFunction=Ud}var eA={};function Md(J,v){for(v===void 0&&Ii("ptr should not be undefined");J.baseClass;)v=J.upcast(v),J=J.baseClass;return v}function Qd(J,v){return v=Md(J,v),eA[v]}function yA(J,v){(!v.ptrType||!v.ptr)&&xs("makeClassHandle requires ptr and ptrType");var st=!!v.smartPtrType,Rt=!!v.smartPtr;return st!==Rt&&xs("Both smartPtrType and smartPtr must be specified"),v.count={value:1},Ka(Object.create(J,{$$:{value:v}}))}function Ho(J){var v=this.getPointee(J);if(!v)return this.destructor(J),null;var st=Qd(this.registeredClass,v);if(st!==void 0){if(st.$$.count.value===0)return st.$$.ptr=v,st.$$.smartPtr=J,st.clone();var Rt=st.clone();return this.destructor(J),Rt}function Vt(){return this.isSmartPointer?yA(this.registeredClass.instancePrototype,{ptrType:this.pointeeType,ptr:v,smartPtrType:this,smartPtr:J}):yA(this.registeredClass.instancePrototype,{ptrType:this,ptr:J})}var Bt=this.registeredClass.getActualType(v),jt=$c[Bt];if(!jt)return Vt.call(this);var Mt;this.isConst?Mt=jt.constPointerType:Mt=jt.pointerType;var Dt=tA(v,this.registeredClass,Mt.registeredClass);return Dt===null?Vt.call(this):this.isSmartPointer?yA(Mt.registeredClass.instancePrototype,{ptrType:Mt,ptr:Dt,smartPtrType:this,smartPtr:J}):yA(Mt.registeredClass.instancePrototype,{ptrType:Mt,ptr:Dt})}function nl(){vo.prototype.getPointee=el,vo.prototype.destructor=il,vo.prototype.argPackAdvance=8,vo.prototype.readValueFromPointer=jo,vo.prototype.deleteObject=Gd,vo.prototype.fromWireType=Ho}function vo(J,v,st,Rt,Vt,Bt,jt,Mt,Dt,pe,Ge){this.name=J,this.registeredClass=v,this.isReference=st,this.isConst=Rt,this.isSmartPointer=Vt,this.pointeeType=Bt,this.sharingPolicy=jt,this.rawGetPointee=Mt,this.rawConstructor=Dt,this.rawShare=pe,this.rawDestructor=Ge,!Vt&&v.baseClass===void 0?Rt?(this.toWireType=Bd,this.destructorFunction=null):(this.toWireType=Ph,this.destructorFunction=null):this.toWireType=xh}function iA(J,v,st){i.hasOwnProperty(J)||xs("Replacing nonexistant public symbol"),i[J].overloadTable!==void 0&&st!==void 0?i[J].overloadTable[st]=v:(i[J]=v,i[J].argCount=st)}function Jh(J,v,st){var Rt=i["dynCall_"+J];return st&&st.length?Rt.apply(null,[v].concat(st)):Rt.call(null,v)}function kd(J,v,st){return J.indexOf("j")!=-1?Jh(J,v,st):ze.get(v).apply(null,st)}function Ld(J,v){var st=[];return function(){st.length=arguments.length;for(var Rt=0;Rt<arguments.length;Rt++)st[Rt]=arguments[Rt];return kd(J,v,st)}}function jn(J,v){J=On(J);function st(){return J.indexOf("j")!=-1?Ld(J,v):ze.get(v)}var Rt=st();return typeof Rt!="function"&&Ii("unknown function pointer with signature "+J+": "+v),Rt}var sl=void 0;function jh(J){var v=pt(J),st=On(v);return et(v),st}function nA(J,v){var st=[],Rt={};function Vt(Bt){if(!Rt[Bt]&&!on[Bt]){if(ws[Bt]){ws[Bt].forEach(Vt);return}st.push(Bt),Rt[Bt]=!0}}throw v.forEach(Vt),new sl(J+": "+st.map(jh).join([", "]))}function ca(J,v,st,Rt,Vt,Bt,jt,Mt,Dt,pe,Ge,ci,pi){Ge=On(Ge),Bt=jn(Vt,Bt),Mt&&(Mt=jn(jt,Mt)),pe&&(pe=jn(Dt,pe)),pi=jn(ci,pi);var cn=So(Ge);yh(cn,function(){nA("Cannot construct "+Ge+" due to unbound types",[Rt])}),gs([J,v,st],Rt?[Rt]:[],function(Qe){Qe=Qe[0];var Xs,zo;Rt?(Xs=Qe.registeredClass,zo=Xs.instancePrototype):zo=dr.prototype;var Vr=$e(cn,function(){if(Object.getPrototypeOf(this)!==ml)throw new cr("Use 'new' to construct "+Ge);if(Ra.constructor_body===void 0)throw new cr(Ge+" has no accessible constructor");var HR=Ra.constructor_body[arguments.length];if(HR===void 0)throw new cr("Tried to invoke ctor of "+Ge+" with invalid number of parameters ("+arguments.length+") - expected ("+Object.keys(Ra.constructor_body).toString()+") parameters instead!");return HR.apply(this,arguments)}),ml=Object.create(zo,{constructor:{value:Vr}});Vr.prototype=ml;var Ra=new mr(Ge,Vr,ml,pi,Xs,Bt,Mt,pe),iE=new vo(Ge,Ra,!0,!1,!1),jR=new vo(Ge+"*",Ra,!1,!1,!1),Em=new vo(Ge+" const*",Ra,!1,!0,!1);return $c[J]={pointerType:jR,constPointerType:Em},iA(cn,Vr),[iE,jR,Em]})}function Hh(J,v){for(var st=[],Rt=0;Rt<J;Rt++)st.push(Se[(v>>2)+Rt]);return st}function vh(J,v,st,Rt,Vt,Bt){w(v>0);var jt=Hh(v,st);Vt=jn(Rt,Vt);var Mt=[Bt],Dt=[];gs([],[J],function(pe){pe=pe[0];var Ge="constructor "+pe.name;if(pe.registeredClass.constructor_body===void 0&&(pe.registeredClass.constructor_body=[]),pe.registeredClass.constructor_body[v-1]!==void 0)throw new cr("Cannot register multiple constructors with identical number of parameters ("+(v-1)+") for class '"+pe.name+"'! Overload resolution is currently only performed using the parameter count, not actual type info!");return pe.registeredClass.constructor_body[v-1]=function(){nA("Cannot construct "+pe.name+" due to unbound types",jt)},gs([],jt,function(ci){return pe.registeredClass.constructor_body[v-1]=function(){arguments.length!==v-1&&Ii(Ge+" called with "+arguments.length+" arguments, expected "+(v-1)),Dt.length=0,Mt.length=v;for(var cn=1;cn<v;++cn)Mt[cn]=ci[cn].toWireType(Dt,arguments[cn-1]);var Qe=Vt.apply(null,Mt);return hn(Dt),ci[0].fromWireType(Qe)},[]}),[]})}function wA(J,v){if(!(J instanceof Function))throw new TypeError("new_ called with constructor type "+typeof J+" which is not a function");var st=$e(J.name||"unknownFunctionName",function(){});st.prototype=J.prototype;var Rt=new st,Vt=J.apply(Rt,v);return Vt instanceof Object?Vt:Rt}function ol(J,v,st,Rt,Vt){var Bt=v.length;Bt<2&&Ii("argTypes array size mismatch! Must at least get return value and 'this' types!");for(var jt=v[1]!==null&&st!==null,Mt=!1,Dt=1;Dt<v.length;++Dt)if(v[Dt]!==null&&v[Dt].destructorFunction===void 0){Mt=!0;break}for(var pe=v[0].name!=="void",Ge="",ci="",Dt=0;Dt<Bt-2;++Dt)Ge+=(Dt!==0?", ":"")+"arg"+Dt,ci+=(Dt!==0?", ":"")+"arg"+Dt+"Wired";var pi="return function "+So(J)+"("+Ge+`) {
if (arguments.length !== `+(Bt-2)+`) {
throwBindingError('function `+J+" called with ' + arguments.length + ' arguments, expected "+(Bt-2)+` args!');
}
`;Mt&&(pi+=`var destructors = [];
`);var cn=Mt?"destructors":"null",Qe=["throwBindingError","invoker","fn","runDestructors","retType","classParam"],Xs=[Ii,Rt,Vt,hn,v[0],v[1]];jt&&(pi+="var thisWired = classParam.toWireType("+cn+`, this);
`);for(var Dt=0;Dt<Bt-2;++Dt)pi+="var arg"+Dt+"Wired = argType"+Dt+".toWireType("+cn+", arg"+Dt+"); // "+v[Dt+2].name+`
`,Qe.push("argType"+Dt),Xs.push(v[Dt+2]);if(jt&&(ci="thisWired"+(ci.length>0?", ":"")+ci),pi+=(pe?"var rv = ":"")+"invoker(fn"+(ci.length>0?", ":"")+ci+`);
`,Mt)pi+=`runDestructors(destructors);
`;else for(var Dt=jt?1:2;Dt<v.length;++Dt){var zo=Dt===1?"thisWired":"arg"+(Dt-2)+"Wired";v[Dt].destructorFunction!==null&&(pi+=zo+"_dtor("+zo+"); // "+v[Dt].name+`
`,Qe.push(zo+"_dtor"),Xs.push(v[Dt].destructorFunction))}pe&&(pi+=`var ret = retType.fromWireType(rv);
return ret;
`),pi+=`}
`,Qe.push(pi);var Vr=wA(Function,Qe).apply(null,Xs);return Vr}function zh(J,v,st,Rt,Vt,Bt,jt,Mt){var Dt=Hh(st,Rt);v=On(v),Bt=jn(Vt,Bt),gs([],[J],function(pe){pe=pe[0];var Ge=pe.name+"."+v;Mt&&pe.registeredClass.pureVirtualFunctions.push(v);function ci(){nA("Cannot call "+Ge+" due to unbound types",Dt)}var pi=pe.registeredClass.instancePrototype,cn=pi[v];return cn===void 0||cn.overloadTable===void 0&&cn.className!==pe.name&&cn.argCount===st-2?(ci.argCount=st-2,ci.className=pe.name,pi[v]=ci):(tl(pi,v,Ge),pi[v].overloadTable[st-2]=ci),gs([],Dt,function(Qe){var Xs=ol(Ge,Qe,pe,Bt,jt);return pi[v].overloadTable===void 0?(Xs.argCount=st-2,pi[v]=Xs):pi[v].overloadTable[st-2]=Xs,[]}),[]})}function yd(J,v,st){J=On(J),gs([],[v],function(Rt){return Rt=Rt[0],i[J]=Rt.fromWireType(st),[]})}var Kh=[],Vs=[{},{value:void 0},{value:null},{value:!0},{value:!1}];function Xh(J){J>4&&--Vs[J].refcount===0&&(Vs[J]=void 0,Kh.push(J))}function wd(){for(var J=0,v=5;v<Vs.length;++v)Vs[v]!==void 0&&++J;return J}function rl(){for(var J=5;J<Vs.length;++J)if(Vs[J]!==void 0)return Vs[J];return null}function Ao(){i.count_emval_handles=wd,i.get_first_emval=rl}function ho(J){switch(J){case void 0:return 1;case null:return 2;case!0:return 3;case!1:return 4;default:{var v=Kh.length?Kh.pop():Vs.length;return Vs[v]={refcount:1,value:J},v}}}function xd(J,v){v=On(v),Oo(J,{name:v,fromWireType:function(st){var Rt=Vs[st].value;return Xh(st),Rt},toWireType:function(st,Rt){return ho(Rt)},argPackAdvance:8,readValueFromPointer:jo,destructorFunction:null})}function Pd(J,v,st){switch(v){case 0:return function(Rt){var Vt=st?bt:ee;return this.fromWireType(Vt[Rt])};case 1:return function(Rt){var Vt=st?ce:je;return this.fromWireType(Vt[Rt>>1])};case 2:return function(Rt){var Vt=st?Se:Ue;return this.fromWireType(Vt[Rt>>2])};default:throw new TypeError("Unknown integer type: "+J)}}function Bo(J,v,st,Rt){var Vt=hr(st);v=On(v);function Bt(){}Bt.values={},Oo(J,{name:v,constructor:Bt,fromWireType:function(jt){return this.constructor.values[jt]},toWireType:function(jt,Mt){return Mt.value},argPackAdvance:8,readValueFromPointer:Pd(v,Vt,Rt),destructorFunction:null}),yh(v,Bt)}function xA(J,v){var st=on[J];return st===void 0&&Ii(v+" has unknown type "+jh(J)),st}function la(J,v,st){var Rt=xA(J,"enum");v=On(v);var Vt=Rt.constructor,Bt=Object.create(Rt.constructor.prototype,{value:{value:st},constructor:{value:$e(Rt.name+"_"+v,function(){})}});Vt.values[st]=Bt,Vt[v]=Bt}function da(J){if(J===null)return"null";var v=typeof J;return v==="object"||v==="array"||v==="function"?J.toString():""+J}function Jd(J,v){switch(v){case 2:return function(st){return this.fromWireType(Me[st>>2])};case 3:return function(st){return this.fromWireType(Ce[st>>3])};default:throw new TypeError("Unknown float type: "+J)}}function jd(J,v,st){var Rt=hr(st);v=On(v),Oo(J,{name:v,fromWireType:function(Vt){return Vt},toWireType:function(Vt,Bt){if(typeof Bt!="number"&&typeof Bt!="boolean")throw new TypeError('Cannot convert "'+da(Bt)+'" to '+this.name);return Bt},argPackAdvance:8,readValueFromPointer:Jd(v,Rt),destructorFunction:null})}function Hd(J,v,st,Rt,Vt,Bt){var jt=Hh(v,st);J=On(J),Vt=jn(Rt,Vt),yh(J,function(){nA("Cannot call "+J+" due to unbound types",jt)},v-1),gs([],jt,function(Mt){var Dt=[Mt[0],null].concat(Mt.slice(1));return iA(J,ol(J,Dt,null,Vt,Bt),v-1),[]})}function vd(J,v,st){switch(v){case 0:return st?function(Vt){return bt[Vt]}:function(Vt){return ee[Vt]};case 1:return st?function(Vt){return ce[Vt>>1]}:function(Vt){return je[Vt>>1]};case 2:return st?function(Vt){return Se[Vt>>2]}:function(Vt){return Ue[Vt>>2]};default:throw new TypeError("Unknown integer type: "+J)}}function zd(J,v,st,Rt,Vt){v=On(v),Vt===-1&&(Vt=4294967295);var Bt=hr(st),jt=function(pe){return pe};if(Rt===0){var Mt=32-8*st;jt=function(pe){return pe<<Mt>>>Mt}}var Dt=v.indexOf("unsigned")!=-1;Oo(J,{name:v,fromWireType:jt,toWireType:function(pe,Ge){if(typeof Ge!="number"&&typeof Ge!="boolean")throw new TypeError('Cannot convert "'+da(Ge)+'" to '+this.name);if(Ge<Rt||Ge>Vt)throw new TypeError('Passing a number "'+da(Ge)+'" from JS side to C/C++ side to an argument of type "'+v+'", which is outside the valid range ['+Rt+", "+Vt+"]!");return Dt?Ge>>>0:Ge|0},argPackAdvance:8,readValueFromPointer:vd(v,Bt,Rt!==0),destructorFunction:null})}function qh(J,v,st){var Rt=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],Vt=Rt[v];function Bt(jt){jt=jt>>2;var Mt=Ue,Dt=Mt[jt],pe=Mt[jt+1];return new Vt(Wt,pe,Dt)}st=On(st),Oo(J,{name:st,fromWireType:Bt,argPackAdvance:8,readValueFromPointer:Bt},{ignoreDuplicateRegistrations:!0})}function PA(J,v){v=On(v);var st=v==="std::string";Oo(J,{name:v,fromWireType:function(Rt){var Vt=Ue[Rt>>2],Bt;if(st)for(var jt=Rt+4,Mt=0;Mt<=Vt;++Mt){var Dt=Rt+4+Mt;if(Mt==Vt||ee[Dt]==0){var pe=Dt-jt,Ge=j(jt,pe);Bt===void 0?Bt=Ge:(Bt+="\0",Bt+=Ge),jt=Dt+1}}else{for(var ci=new Array(Vt),Mt=0;Mt<Vt;++Mt)ci[Mt]=String.fromCharCode(ee[Rt+4+Mt]);Bt=ci.join("")}return et(Rt),Bt},toWireType:function(Rt,Vt){Vt instanceof ArrayBuffer&&(Vt=new Uint8Array(Vt));var Bt,jt=typeof Vt=="string";jt||Vt instanceof Uint8Array||Vt instanceof Uint8ClampedArray||Vt instanceof Int8Array||Ii("Cannot pass non-string to std::string"),st&&jt?Bt=function(){return G(Vt)}:Bt=function(){return Vt.length};var Mt=Bt(),Dt=z(4+Mt+1);if(Ue[Dt>>2]=Mt,st&&jt)tt(Vt,Dt+4,Mt+1);else if(jt)for(var pe=0;pe<Mt;++pe){var Ge=Vt.charCodeAt(pe);Ge>255&&(et(Dt),Ii("String has UTF-16 code units that do not fit in 8 bits")),ee[Dt+4+pe]=Ge}else for(var pe=0;pe<Mt;++pe)ee[Dt+4+pe]=Vt[pe];return Rt!==null&&Rt.push(et,Dt),Dt},argPackAdvance:8,readValueFromPointer:jo,destructorFunction:function(Rt){et(Rt)}})}function ma(J,v,st){st=On(st);var Rt,Vt,Bt,jt,Mt;v===2?(Rt=gt,Vt=Yt,jt=Ut,Bt=function(){return je},Mt=1):v===4&&(Rt=Ct,Vt=zt,jt=kt,Bt=function(){return Ue},Mt=2),Oo(J,{name:st,fromWireType:function(Dt){for(var pe=Ue[Dt>>2],Ge=Bt(),ci,pi=Dt+4,cn=0;cn<=pe;++cn){var Qe=Dt+4+cn*v;if(cn==pe||Ge[Qe>>Mt]==0){var Xs=Qe-pi,zo=Rt(pi,Xs);ci===void 0?ci=zo:(ci+="\0",ci+=zo),pi=Qe+v}}return et(Dt),ci},toWireType:function(Dt,pe){typeof pe!="string"&&Ii("Cannot pass non-string to C++ string type "+st);var Ge=jt(pe),ci=z(4+Ge+v);return Ue[ci>>2]=Ge>>Mt,Vt(pe,ci+4,Ge+v),Dt!==null&&Dt.push(et,ci),ci},argPackAdvance:8,readValueFromPointer:jo,destructorFunction:function(Dt){et(Dt)}})}function al(J,v,st,Rt,Vt,Bt){qi[J]={name:On(v),rawConstructor:jn(st,Rt),rawDestructor:jn(Vt,Bt),fields:[]}}function fa(J,v,st,Rt,Vt,Bt,jt,Mt,Dt,pe){qi[J].fields.push({fieldName:On(v),getterReturnType:st,getter:jn(Rt,Vt),getterContext:Bt,setterArgumentType:jt,setter:jn(Mt,Dt),setterContext:pe})}function Ea(J,v){v=On(v),Oo(J,{isVoid:!0,name:v,argPackAdvance:0,fromWireType:function(){},toWireType:function(st,Rt){}})}function sA(J){return J||Ii("Cannot use deleted val. handle = "+J),Vs[J].value}function Al(J,v,st){J=sA(J),v=xA(v,"emval::as");var Rt=[],Vt=ho(Rt);return Se[st>>2]=Vt,v.toWireType(Rt,J)}var Kd={};function JA(J){var v=Kd[J];return v===void 0?On(J):v}var $h=[];function Xd(J,v,st,Rt){J=$h[J],v=sA(v),st=JA(st),J(v,st,null,Rt)}function hl(){return typeof globalThis=="object"?globalThis:function(){return Function}()("return this")()}function qd(J){return J===0?ho(hl()):(J=JA(J),ho(hl()[J]))}function $d(J){var v=$h.length;return $h.push(J),v}function tm(J,v){for(var st=new Array(J),Rt=0;Rt<J;++Rt)st[Rt]=xA(Se[(v>>2)+Rt],"parameter "+Rt);return st}function em(J,v){for(var st=tm(J,v),Rt=st[0],Vt=Rt.name+"_$"+st.slice(1).map(function(cn){return cn.name}).join("_")+"$",Bt=["retType"],jt=[Rt],Mt="",Dt=0;Dt<J-1;++Dt)Mt+=(Dt!==0?", ":"")+"arg"+Dt,Bt.push("argType"+Dt),jt.push(st[1+Dt]);for(var pe=So("methodCaller_"+Vt),Ge="return function "+pe+`(handle, name, destructors, args) {
`,ci=0,Dt=0;Dt<J-1;++Dt)Ge+="    var arg"+Dt+" = argType"+Dt+".readValueFromPointer(args"+(ci?"+"+ci:"")+`);
`,ci+=st[Dt+1].argPackAdvance;Ge+="    var rv = handle[name]("+Mt+`);
`;for(var Dt=0;Dt<J-1;++Dt)st[Dt+1].deleteObject&&(Ge+="    argType"+Dt+".deleteObject(arg"+Dt+`);
`);Rt.isVoid||(Ge+=`    return retType.toWireType(destructors, rv);
`),Ge+=`};
`,Bt.push(Ge);var pi=wA(Function,Bt).apply(null,jt);return $d(pi)}function im(J){return J=JA(J),ho(i[J])}function nm(J,v){return J=sA(J),v=sA(v),ho(J[v])}function sm(J){J>4&&(Vs[J].refcount+=1)}function om(J){for(var v="",st=0;st<J;++st)v+=(st!==0?", ":"")+"arg"+st;for(var Rt="return function emval_allocator_"+J+`(constructor, argTypes, args) {
`,st=0;st<J;++st)Rt+="var argType"+st+" = requireRegisteredType(Module['HEAP32'][(argTypes >>> 2) + "+st+'], "parameter '+st+`");
var arg`+st+" = argType"+st+`.readValueFromPointer(args);
args += argType`+st+`['argPackAdvance'];
`;return Rt+="var obj = new constructor("+v+`);
return __emval_register(obj);
}
`,new Function("requireRegisteredType","Module","__emval_register",Rt)(xA,i,ho)}var cl={};function rm(J,v,st,Rt){J=sA(J);var Vt=cl[v];return Vt||(Vt=om(v),cl[v]=Vt),Vt(J,st,Rt)}function am(J){return ho(JA(J))}function Am(J){var v=Vs[J].value;hn(v),Xh(J)}function ll(){ki()}function hm(J,v,st){ee.copyWithin(J,v,v+st)}function oA(J){try{return g.grow(J-Wt.byteLength+65535>>>16),Fe(g.buffer),1}catch{}}function cm(J){var v=ee.length;J=J>>>0;var st=2147483648;if(J>st)return!1;for(var Rt=1;Rt<=4;Rt*=2){var Vt=v*(1+.2/Rt);Vt=Math.min(Vt,J+100663296);var Bt=Math.min(st,Jt(Math.max(J,Vt),65536)),jt=oA(Bt);if(jt)return!0}return!1}var jA={mappings:{},buffers:[null,[],[]],printChar:function(J,v){var st=jA.buffers[J];v===0||v===10?((J===1?U:Q)(H(st,0)),st.length=0):st.push(v)},varargs:void 0,get:function(){jA.varargs+=4;var J=Se[jA.varargs-4>>2];return J},getStr:function(J){var v=j(J);return v},get64:function(J,v){return J}};function lm(J){return 0}function dm(J,v,st,Rt,Vt){}function dl(J,v,st,Rt){for(var Vt=0,Bt=0;Bt<st;Bt++){for(var jt=Se[v+Bt*8>>2],Mt=Se[v+(Bt*8+4)>>2],Dt=0;Dt<Mt;Dt++)jA.printChar(J,ee[jt+Dt]);Vt+=Mt}return Se[Rt>>2]=Vt,0}function mm(J){k(J|0)}Yr=i.InternalError=aa(Error,"InternalError"),Uh(),cr=i.BindingError=aa(Error,"BindingError"),Od(),nl(),LA(),sl=i.UnboundTypeError=aa(Error,"UnboundTypeError"),Ao();var fm={t:Tn,I:Kc,x:ca,w:vh,d:zh,k:yd,H:xd,n:Bo,a:la,A:jd,i:Hd,j:zd,h:qh,B:PA,v:ma,u:al,c:fa,J:Ea,m:Al,s:Xd,b:Xh,y:qd,p:em,r:im,e:nm,g:sm,q:rm,f:am,l:Am,o:ll,E:hm,F:cm,G:lm,C:dm,z:dl,D:mm},rA=ls(),fi=i.___wasm_call_ctors=function(){return(fi=i.___wasm_call_ctors=i.asm.L).apply(null,arguments)},z=i._malloc=function(){return(z=i._malloc=i.asm.M).apply(null,arguments)},et=i._free=function(){return(et=i._free=i.asm.N).apply(null,arguments)},pt=i.___getTypeName=function(){return(pt=i.___getTypeName=i.asm.P).apply(null,arguments)},$t=i.___embind_register_native_and_builtin_types=function(){return($t=i.___embind_register_native_and_builtin_types=i.asm.Q).apply(null,arguments)},ve=i.dynCall_jiji=function(){return(ve=i.dynCall_jiji=i.asm.R).apply(null,arguments)},hi;function _a(J){this.name="ExitStatus",this.message="Program terminated with exit("+J+")",this.status=J}hs=function J(){hi||tc(),hi||(hs=J)};function tc(J){if(J=J||a,ei>0||(Oi(),ei>0))return;function v(){hi||(hi=!0,i.calledRun=!0,!O&&(gn(),De(),n(i),i.onRuntimeInitialized&&i.onRuntimeInitialized(),Ye()))}i.setStatus?(i.setStatus("Running..."),setTimeout(function(){setTimeout(function(){i.setStatus("")},1),v()},1)):v()}if(i.run=tc,i.preInit)for(typeof i.preInit=="function"&&(i.preInit=[i.preInit]);i.preInit.length>0;)i.preInit.pop()();return tc(),e.ready}}();typeof Hg=="object"&&typeof YG=="object"?YG.exports=bG:typeof define=="function"&&define.amd?define([],function(){return bG}):typeof Hg=="object"&&(Hg.BASIS=bG)});var VG={};He(VG,{default:()=>CZt});function RZt(t,e){p.typeOf.object("transcoderModule",JR);let i=t.ktx2Buffer,n=t.supportedTargetFormats,s;try{s=M8(i)}catch{throw new ke("Invalid KTX2 file.")}if(s.layerCount!==0)throw new ke("KTX2 texture arrays are not supported.");if(s.pixelDepth!==0)throw new ke("KTX2 3D textures are unsupported.");let o=s.dataFormatDescriptor[0],r=new Array(s.levelCount);return s.vkFormat===0&&(o.colorModel===w8||o.colorModel===x8)?IZt(i,s,n,JR,e,r):(e.push(i.buffer),ZZt(s,r)),r}function ZZt(t,e){let i=t.vkFormat===PR.VK_FORMAT_R8G8B8_SRGB?Ie.RGB:Ie.RGBA,n;t.vkFormat===PR.VK_FORMAT_R8G8B8A8_UNORM?n=ge.UNSIGNED_BYTE:t.vkFormat===PR.VK_FORMAT_R16G16B16A16_SFLOAT?n=ge.HALF_FLOAT:t.vkFormat===PR.VK_FORMAT_R32G32B32A32_SFLOAT&&(n=ge.FLOAT);for(let s=0;s<t.levels.length;++s){let o={};e[s]=o;let r=t.levels[s].levelData,a=t.pixelWidth>>s,h=t.pixelHeight>>s,A=a*h*Ie.componentsLength(i);for(let d=0;d<t.faceCount;++d){let f=r.byteOffset+A*t.typeSize*d,E;!m(n)||ge.sizeInBytes(n)===1?E=new Uint8Array(r.buffer,f,A):ge.sizeInBytes(n)===2?E=new Uint16Array(r.buffer,f,A):E=new Float32Array(r.buffer,f,A),o[y8[d]]={internalFormat:i,datatype:n,width:a,height:h,levelBuffer:E}}}}function IZt(t,e,i,n,s,o){let r=new n.KTX2File(t),a=r.getWidth(),h=r.getHeight(),A=r.getLevels(),d=r.getHasAlpha();if(!(a>0)||!(h>0)||!(A>0))throw r.close(),r.delete(),new ke("Invalid KTX2 file");let f,E,_=e.dataFormatDescriptor[0],R=n.transcoder_texture_format;if(_.colorModel===w8)if(i.etc)f=d?Ie.RGBA8_ETC2_EAC:Ie.RGB8_ETC2,E=d?R.cTFETC2_RGBA:R.cTFETC1_RGB;else if(i.etc1&&!d)f=Ie.RGB_ETC1,E=R.cTFETC1_RGB;else if(i.s3tc)f=d?Ie.RGBA_DXT5:Ie.RGB_DXT1,E=d?R.cTFBC3_RGBA:R.cTFBC1_RGB;else if(i.pvrtc)f=d?Ie.RGBA_PVRTC_4BPPV1:Ie.RGB_PVRTC_4BPPV1,E=d?R.cTFPVRTC1_4_RGBA:R.cTFPVRTC1_4_RGB;else if(i.astc)f=Ie.RGBA_ASTC,E=R.cTFASTC_4x4_RGBA;else if(i.bc7)f=Ie.RGBA_BC7,E=R.cTFBC7_RGBA;else throw new ke("No transcoding format target available for ETC1S compressed ktx2.");else if(_.colorModel===x8)if(i.astc)f=Ie.RGBA_ASTC,E=R.cTFASTC_4x4_RGBA;else if(i.bc7)f=Ie.RGBA_BC7,E=R.cTFBC7_RGBA;else if(i.s3tc)f=d?Ie.RGBA_DXT5:Ie.RGB_DXT1,E=d?R.cTFBC3_RGBA:R.cTFBC1_RGB;else if(i.etc)f=d?Ie.RGBA8_ETC2_EAC:Ie.RGB8_ETC2,E=d?R.cTFETC2_RGBA:R.cTFETC1_RGB;else if(i.etc1&&!d)f=Ie.RGB_ETC1,E=R.cTFETC1_RGB;else if(i.pvrtc)f=d?Ie.RGBA_PVRTC_4BPPV1:Ie.RGB_PVRTC_4BPPV1,E=d?R.cTFPVRTC1_4_RGBA:R.cTFPVRTC1_4_RGB;else throw new ke("No transcoding format target available for UASTC compressed ktx2.");if(!r.startTranscoding())throw r.close(),r.delete(),new ke("startTranscoding() failed");for(let I=0;I<e.levels.length;++I){let C={};o[I]=C,a=e.pixelWidth>>I,h=e.pixelHeight>>I;let N=r.getImageTranscodedSizeInBytes(I,0,0,E.value),T=new Uint8Array(N),b=r.transcodeImage(T,I,0,0,E.value,0,-1,-1);if(!m(b))throw new ke("transcodeImage() failed.");s.push(T.buffer),C[y8[0]]={internalFormat:f,width:a,height:h,levelBuffer:T}}return r.close(),r.delete(),o}async function pZt(t,e){let i=t.webAssemblyConfig,n=Z(L8.default,self.BASIS);return m(i.wasmBinaryFile)?JR=await n(i):JR=await n(),JR.initializeBasis(),!0}function uZt(t,e){let i=t.webAssemblyConfig;return m(i)?pZt(t,e):RZt(t,e)}var L8,y8,w8,x8,JR,CZt,SG=S(()=>{Ft();mt();ae();_c();Ps();D8();Ec();Ns();Q8();L8=co(k8(),1),y8=["positiveX","negativeX","positiveY","negativeY","positiveZ","negativeZ"],w8=163,x8=166;CZt=Wi(uZt)});var P8={};var OG=S(()=>{self.onmessage=function(t){let e=t.data.array,i=self.webkitPostMessage||self.postMessage;try{i({array:e},[e.buffer])}catch{i({})}}});var vg,zg,J8=S(()=>{Xe();Ht();ae();mt();Ot();vg={};vg.clipTriangleAtAxisAlignedThreshold=function(t,e,i,n,s,o){if(!m(t))throw new Y("threshold is required.");if(!m(e))throw new Y("keepAbove is required.");if(!m(i))throw new Y("u0 is required.");if(!m(n))throw new Y("u1 is required.");if(!m(s))throw new Y("u2 is required.");m(o)?o.length=0:o=[];let r,a,h;e?(r=i<t,a=n<t,h=s<t):(r=i>t,a=n>t,h=s>t);let A=r+a+h,d,f,E,_,R,I;return A===1?r?(d=(t-i)/(n-i),f=(t-i)/(s-i),o.push(1),o.push(2),f!==1&&(o.push(-1),o.push(0),o.push(2),o.push(f)),d!==1&&(o.push(-1),o.push(0),o.push(1),o.push(d))):a?(E=(t-n)/(s-n),_=(t-n)/(i-n),o.push(2),o.push(0),_!==1&&(o.push(-1),o.push(1),o.push(0),o.push(_)),E!==1&&(o.push(-1),o.push(1),o.push(2),o.push(E))):h&&(R=(t-s)/(i-s),I=(t-s)/(n-s),o.push(0),o.push(1),I!==1&&(o.push(-1),o.push(2),o.push(1),o.push(I)),R!==1&&(o.push(-1),o.push(2),o.push(0),o.push(R))):A===2?!r&&i!==t?(_=(t-n)/(i-n),R=(t-s)/(i-s),o.push(0),o.push(-1),o.push(1),o.push(0),o.push(_),o.push(-1),o.push(2),o.push(0),o.push(R)):!a&&n!==t?(I=(t-s)/(n-s),d=(t-i)/(n-i),o.push(1),o.push(-1),o.push(2),o.push(1),o.push(I),o.push(-1),o.push(0),o.push(1),o.push(d)):!h&&s!==t&&(f=(t-i)/(s-i),E=(t-n)/(s-n),o.push(2),o.push(-1),o.push(0),o.push(2),o.push(f),o.push(-1),o.push(1),o.push(2),o.push(E)):A!==3&&(o.push(0),o.push(1),o.push(2)),o};vg.computeBarycentricCoordinates=function(t,e,i,n,s,o,r,a,h){if(!m(t))throw new Y("x is required.");if(!m(e))throw new Y("y is required.");if(!m(i))throw new Y("x1 is required.");if(!m(n))throw new Y("y1 is required.");if(!m(s))throw new Y("x2 is required.");if(!m(o))throw new Y("y2 is required.");if(!m(r))throw new Y("x3 is required.");if(!m(a))throw new Y("y3 is required.");let A=i-r,d=r-s,f=o-a,E=n-a,_=1/(f*A+d*E),R=e-a,I=t-r,C=(f*I+d*R)*_,N=(-E*I+A*R)*_,T=1-C-N;return m(h)?(h.x=C,h.y=N,h.z=T,h):new l(C,N,T)};vg.computeLineSegmentLineSegmentIntersection=function(t,e,i,n,s,o,r,a,h){p.typeOf.number("x00",t),p.typeOf.number("y00",e),p.typeOf.number("x01",i),p.typeOf.number("y01",n),p.typeOf.number("x10",s),p.typeOf.number("y10",o),p.typeOf.number("x11",r),p.typeOf.number("y11",a);let A=(r-s)*(e-o)-(a-o)*(t-s),d=(i-t)*(e-o)-(n-e)*(t-s),f=(a-o)*(i-t)-(r-s)*(n-e);if(f===0)return;let E=A/f,_=d/f;if(E>=0&&E<=1&&_>=0&&_<=1)return m(h)||(h=new nt),h.x=t+E*(i-t),h.y=e+E*(n-e),h};zg=vg});var BG={};He(BG,{default:()=>QZt});function DZt(t,e){let i=t.isEastChild,n=t.isNorthChild,s=i?za:0,o=i?ps:za,r=n?za:0,a=n?ps:za,h=NZt,A=FZt,d=bZt,f=VZt;h.length=0,A.length=0,d.length=0,f.length=0;let E=YZt;E.length=0;let _={},R=t.vertices,I=t.indices;I=I.subarray(0,t.indexCountWithoutSkirts);let C=vc.clone(t.encoding),N=C.hasVertexNormals,T=0,b=t.vertexCountWithoutSkirts,F=t.minimumHeight,B=t.maximumHeight,U=new Array(b),Q=new Array(b),M=new Array(b),k=N?new Array(b*2):void 0,y=20,c,g,O,D,w;for(g=0,O=0;g<b;++g,O+=2){let Ri=C.decodeTextureCoordinates(R,g,GZt);if(c=C.decodeHeight(R,g),D=L.clamp(Ri.x*ps|0,0,ps),w=L.clamp(Ri.y*ps|0,0,ps),M[g]=L.clamp((c-F)/(B-F)*ps|0,0,ps),D<y&&(D=0),w<y&&(w=0),ps-D<y&&(D=ps),ps-w<y&&(w=ps),U[g]=D,Q[g]=w,N){let si=C.getOctEncodedNormal(R,g,WZt);k[O]=si.x,k[O+1]=si.y}(i&&D>=za||!i&&D<=za)&&(n&&w>=za||!n&&w<=za)&&(_[g]=T,h.push(D),A.push(w),d.push(M[g]),N&&(f.push(k[O]),f.push(k[O+1])),++T)}let x=[];x.push(new us),x.push(new us),x.push(new us);let H=[];H.push(new us),H.push(new us),H.push(new us);let j,X;for(g=0;g<I.length;g+=3){let Ri=I[g],si=I[g+1],qe=I[g+2],Oi=U[Ri],gn=U[si],De=U[qe];x[0].initializeIndexed(U,Q,M,k,Ri),x[1].initializeIndexed(U,Q,M,k,si),x[2].initializeIndexed(U,Q,M,k,qe);let Ye=zg.clipTriangleAtAxisAlignedThreshold(za,i,Oi,gn,De,gZt);j=0,!(j>=Ye.length)&&(j=H[0].initializeFromClipResult(Ye,j,x),!(j>=Ye.length)&&(j=H[1].initializeFromClipResult(Ye,j,x),!(j>=Ye.length)&&(j=H[2].initializeFromClipResult(Ye,j,x),X=zg.clipTriangleAtAxisAlignedThreshold(za,n,H[0].getV(),H[1].getV(),H[2].getV(),j8),H8(h,A,d,f,E,_,X,H,N),j<Ye.length&&(H[2].clone(H[1]),H[2].initializeFromClipResult(Ye,j,x),X=zg.clipTriangleAtAxisAlignedThreshold(za,n,H[0].getV(),H[1].getV(),H[2].getV(),j8),H8(h,A,d,f,E,_,X,H,N)))))}let tt=i?-ps:0,G=n?-ps:0,It=[],gt=[],Yt=[],Ut=[],Ct=Number.MAX_VALUE,zt=-Ct,kt=TZt;kt.length=0;let Jt=ot.clone(t.ellipsoid),Wt=Xt.clone(t.childRectangle),bt=Wt.north,ee=Wt.south,ce=Wt.east,je=Wt.west;for(ce<je&&(ce+=L.TWO_PI),g=0;g<h.length;++g)D=Math.round(h[g]),D<=s?(It.push(g),D=0):D>=o?(Yt.push(g),D=ps):D=D*2+tt,h[g]=D,w=Math.round(A[g]),w<=r?(gt.push(g),w=0):w>=a?(Ut.push(g),w=ps):w=w*2+G,A[g]=w,c=L.lerp(F,B,d[g]/ps),c<Ct&&(Ct=c),c>zt&&(zt=c),d[g]=c,Kg.longitude=L.lerp(je,ce,D/ps),Kg.latitude=L.lerp(ee,bt,w/ps),Kg.height=c,Jt.cartographicToCartesian(Kg,Dh),kt.push(Dh.x),kt.push(Dh.y),kt.push(Dh.z);let Se=Nt.fromVertices(kt,l.ZERO,3,OZt),Ue=zs.fromRectangle(Wt,Ct,zt,Jt,BZt),Ce=new dA(Jt).computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid(Se.center,kt,3,Se.center,Ct,SZt),Fe=zt-Ct,ni=new Uint16Array(h.length+A.length+d.length);for(g=0;g<h.length;++g)ni[g]=h[g];let ze=h.length;for(g=0;g<A.length;++g)ni[ze+g]=A[g];for(ze+=A.length,g=0;g<d.length;++g)ni[ze+g]=ps*(d[g]-Ct)/Fe;let Be=te.createTypedArray(h.length,E),Mi;if(N){let Ri=new Uint8Array(f);e.push(ni.buffer,Be.buffer,Ri.buffer),Mi=Ri.buffer}else e.push(ni.buffer,Be.buffer);return{vertices:ni.buffer,encodedNormals:Mi,indices:Be.buffer,minimumHeight:Ct,maximumHeight:zt,westIndices:It,southIndices:gt,eastIndices:Yt,northIndices:Ut,boundingSphere:Se,orientedBoundingBox:Ue,horizonOcclusionPoint:Ce}}function us(){this.vertexBuffer=void 0,this.index=void 0,this.first=void 0,this.second=void 0,this.ratio=void 0}function v8(t,e){++Xg;let i=UZt[Xg],n=MZt[Xg];return i=Yi.octDecode(t.first.getNormalX(),t.first.getNormalY(),i),n=Yi.octDecode(t.second.getNormalX(),t.second.getNormalY(),n),Dh=l.lerp(i,n,t.ratio,Dh),l.normalize(Dh,Dh),Yi.octEncode(Dh,e),--Xg,e}function H8(t,e,i,n,s,o,r,a,h){if(r.length===0)return;let A=0,d=0;for(;d<r.length;)d=Jo[A++].initializeFromClipResult(r,d,a);for(let f=0;f<A;++f){let E=Jo[f];if(E.isIndexed())E.newIndex=o[E.index],E.uBuffer=t,E.vBuffer=e,E.heightBuffer=i,h&&(E.normalBuffer=n);else{let _=E.getKey();if(m(o[_]))E.newIndex=o[_];else{let R=t.length;t.push(E.getU()),e.push(E.getV()),i.push(E.getH()),h&&(n.push(E.getNormalX()),n.push(E.getNormalY())),E.newIndex=R,o[_]=R}}}A===3?(s.push(Jo[0].newIndex),s.push(Jo[1].newIndex),s.push(Jo[2].newIndex)):A===4&&(s.push(Jo[0].newIndex),s.push(Jo[1].newIndex),s.push(Jo[2].newIndex),s.push(Jo[0].newIndex),s.push(Jo[2].newIndex),s.push(Jo[3].newIndex))}var ps,za,gZt,j8,TZt,Kg,Dh,NZt,FZt,bZt,YZt,VZt,SZt,OZt,BZt,GZt,WZt,eE,Xg,UZt,MZt,Jo,QZt,GG=S(()=>{oh();_i();Xe();Ht();ri();mt();Oe();Vm();Di();J8();_e();Jl();pn();WR();Ns();ps=32767,za=ps/2|0,gZt=[],j8=[],TZt=[],Kg=new ut,Dh=new l,NZt=[],FZt=[],bZt=[],YZt=[],VZt=[],SZt=new l,OZt=new Nt,BZt=new zs,GZt=new nt,WZt=new l;us.prototype.clone=function(t){return m(t)||(t=new us),t.uBuffer=this.uBuffer,t.vBuffer=this.vBuffer,t.heightBuffer=this.heightBuffer,t.normalBuffer=this.normalBuffer,t.index=this.index,t.first=this.first,t.second=this.second,t.ratio=this.ratio,t};us.prototype.initializeIndexed=function(t,e,i,n,s){this.uBuffer=t,this.vBuffer=e,this.heightBuffer=i,this.normalBuffer=n,this.index=s,this.first=void 0,this.second=void 0,this.ratio=void 0};us.prototype.initializeFromClipResult=function(t,e,i){let n=e+1;return t[e]!==-1?i[t[e]].clone(this):(this.vertexBuffer=void 0,this.index=void 0,this.first=i[t[n]],++n,this.second=i[t[n]],++n,this.ratio=t[n],++n),n};us.prototype.getKey=function(){return this.isIndexed()?this.index:JSON.stringify({first:this.first.getKey(),second:this.second.getKey(),ratio:this.ratio})};us.prototype.isIndexed=function(){return m(this.index)};us.prototype.getH=function(){return m(this.index)?this.heightBuffer[this.index]:L.lerp(this.first.getH(),this.second.getH(),this.ratio)};us.prototype.getU=function(){return m(this.index)?this.uBuffer[this.index]:L.lerp(this.first.getU(),this.second.getU(),this.ratio)};us.prototype.getV=function(){return m(this.index)?this.vBuffer[this.index]:L.lerp(this.first.getV(),this.second.getV(),this.ratio)};eE=new nt,Xg=-1,UZt=[new l,new l],MZt=[new l,new l];us.prototype.getNormalX=function(){return m(this.index)?this.normalBuffer[this.index*2]:(eE=v8(this,eE),eE.x)};us.prototype.getNormalY=function(){return m(this.index)?this.normalBuffer[this.index*2+1]:(eE=v8(this,eE),eE.y)};Jo=[];Jo.push(new us);Jo.push(new us);Jo.push(new us);Jo.push(new us);QZt=Wi(DZt)});var kZt,WG=S(()=>{kZt=jG({"./AnalysisWorker.js":()=>Promise.resolve().then(()=>(i0(),e0)),"./ConjunctionAssessment.js":()=>Promise.resolve().then(()=>(tS(),$V)),"./combineGeometry.js":()=>Promise.resolve().then(()=>(iS(),eS)),"./createBoxGeometry.js":()=>Promise.resolve().then(()=>(rS(),oS)),"./createBoxOutlineGeometry.js":()=>Promise.resolve().then(()=>(hS(),AS)),"./createCircleGeometry.js":()=>Promise.resolve().then(()=>(IS(),ZS)),"./createCircleOutlineGeometry.js":()=>Promise.resolve().then(()=>(gS(),CS)),"./createCoplanarPolygonGeometry.js":()=>Promise.resolve().then(()=>(GS(),BS)),"./createCoplanarPolygonOutlineGeometry.js":()=>Promise.resolve().then(()=>(US(),DS)),"./createCorridorGeometry.js":()=>Promise.resolve().then(()=>(XS(),KS)),"./createCorridorOutlineGeometry.js":()=>Promise.resolve().then(()=>(tO(),$S)),"./createCylinderGeometry.js":()=>Promise.resolve().then(()=>(rO(),oO)),"./createCylinderOutlineGeometry.js":()=>Promise.resolve().then(()=>(cO(),hO)),"./createEllipseGeometry.js":()=>Promise.resolve().then(()=>(dO(),lO)),"./createEllipseOutlineGeometry.js":()=>Promise.resolve().then(()=>(fO(),mO)),"./createEllipsoidGeometry.js":()=>Promise.resolve().then(()=>(RO(),_O)),"./createEllipsoidOutlineGeometry.js":()=>Promise.resolve().then(()=>(pO(),IO)),"./createFrustumGeometry.js":()=>Promise.resolve().then(()=>(FO(),NO)),"./createFrustumOutlineGeometry.js":()=>Promise.resolve().then(()=>(SO(),VO)),"./createGeometry.js":()=>Promise.resolve().then(()=>(UG(),DG)),"./createGroundPolylineGeometry.js":()=>Promise.resolve().then(()=>(BO(),OO)),"./createPlaneGeometry.js":()=>Promise.resolve().then(()=>(DO(),WO)),"./createPlaneOutlineGeometry.js":()=>Promise.resolve().then(()=>(QO(),MO)),"./createPolygonGeometry.js":()=>Promise.resolve().then(()=>(wO(),yO)),"./createPolygonOutlineGeometry.js":()=>Promise.resolve().then(()=>(JO(),PO)),"./createPolylineGeometry.js":()=>Promise.resolve().then(()=>(vO(),HO)),"./createPolylineVolumeGeometry.js":()=>Promise.resolve().then(()=>(XO(),KO)),"./createPolylineVolumeOutlineGeometry.js":()=>Promise.resolve().then(()=>(tB(),$O)),"./createRectangleGeometry.js":()=>Promise.resolve().then(()=>(cB(),hB)),"./createRectangleOutlineGeometry.js":()=>Promise.resolve().then(()=>(mB(),dB)),"./createSimplePolylineGeometry.js":()=>Promise.resolve().then(()=>(_B(),EB)),"./createSphereGeometry.js":()=>Promise.resolve().then(()=>(IB(),ZB)),"./createSphereOutlineGeometry.js":()=>Promise.resolve().then(()=>(CB(),uB)),"./createTaskProcessorWorker.js":()=>Promise.resolve().then(()=>(Ns(),t0)),"./createVectorTileClampedPolylines.js":()=>Promise.resolve().then(()=>(TB(),gB)),"./createVectorTileGeometries.js":()=>Promise.resolve().then(()=>(FB(),NB)),"./createVectorTilePoints.js":()=>Promise.resolve().then(()=>(VB(),YB)),"./createVectorTilePolygons.js":()=>Promise.resolve().then(()=>(OB(),SB)),"./createVectorTilePolylines.js":()=>Promise.resolve().then(()=>(WB(),GB)),"./createVerticesFromGoogleEarthEnterpriseBuffer.js":()=>Promise.resolve().then(()=>(MB(),UB)),"./createVerticesFromHeightmap.js":()=>Promise.resolve().then(()=>(LB(),kB)),"./createVerticesFromQuantizedTerrainMesh.js":()=>Promise.resolve().then(()=>(xB(),wB)),"./createWallGeometry.js":()=>Promise.resolve().then(()=>(vB(),HB)),"./createWallOutlineGeometry.js":()=>Promise.resolve().then(()=>(XB(),KB)),"./decodeDraco.js":()=>Promise.resolve().then(()=>(nG(),iG)),"./decodeGoogleEarthEnterprisePacket.js":()=>Promise.resolve().then(()=>(pG(),IG)),"./decodeI3S.js":()=>Promise.resolve().then(()=>(NG(),TG)),"./transcodeKTX2.js":()=>Promise.resolve().then(()=>(SG(),VG)),"./transferTypedArrayTest.js":()=>Promise.resolve().then(()=>(OG(),P8)),"./upsampleQuantizedTerrainMesh.js":()=>Promise.resolve().then(()=>(GG(),BG))})});var DG={};He(DG,{default:()=>wZt});async function LZt(t,e){let i=Z(qg[e],qg[t]);return m(i)?i:m(e)?(typeof exports=="object"?i=Xo(e):i=(await import(e)).default,qg[e]=i,i):(typeof exports=="object"?i=Xo(`Workers/${t}`):i=(m(e)?await import(e):await kZt(`./${t}.js`)).default,qg[t]=i,i)}async function yZt(t,e){let i=t.subTasks,n=i.length,s=new Array(n);for(let o=0;o<n;o++){let r=i[o],a=r.geometry,h=r.moduleName,A=r.modulePath;if(m(h)&&m(A))throw new Y("Must only set moduleName or modulePath");m(h)||m(A)?s[o]=LZt(h,A).then(d=>d(a,r.offset)):s[o]=a}return Promise.all(s).then(function(o){return TA.packCreateGeometryResults(o,e)})}var qg,wZt,UG=S(()=>{Ot();Ft();mt();KI();Ns();WG();qg={};wZt=Wi(yZt)});var kIt={};He(kIt,{AnalysisWorker:()=>xZt,ConjunctionAssessment:()=>PZt,combineGeometry:()=>JZt,createBoxGeometry:()=>jZt,createBoxOutlineGeometry:()=>HZt,createCircleGeometry:()=>vZt,createCircleOutlineGeometry:()=>zZt,createCoplanarPolygonGeometry:()=>KZt,createCoplanarPolygonOutlineGeometry:()=>XZt,createCorridorGeometry:()=>qZt,createCorridorOutlineGeometry:()=>$Zt,createCylinderGeometry:()=>tIt,createCylinderOutlineGeometry:()=>eIt,createEllipseGeometry:()=>iIt,createEllipseOutlineGeometry:()=>nIt,createEllipsoidGeometry:()=>sIt,createEllipsoidOutlineGeometry:()=>oIt,createFrustumGeometry:()=>rIt,createFrustumOutlineGeometry:()=>aIt,createGeometry:()=>AIt,createGroundPolylineGeometry:()=>hIt,createPlaneGeometry:()=>cIt,createPlaneOutlineGeometry:()=>lIt,createPolygonGeometry:()=>dIt,createPolygonOutlineGeometry:()=>mIt,createPolylineGeometry:()=>fIt,createPolylineVolumeGeometry:()=>EIt,createPolylineVolumeOutlineGeometry:()=>_It,createRectangleGeometry:()=>RIt,createRectangleOutlineGeometry:()=>ZIt,createSimplePolylineGeometry:()=>IIt,createSphereGeometry:()=>pIt,createSphereOutlineGeometry:()=>uIt,createTaskProcessorWorker:()=>CIt,createVectorTileClampedPolylines:()=>gIt,createVectorTileGeometries:()=>TIt,createVectorTilePoints:()=>NIt,createVectorTilePolygons:()=>FIt,createVectorTilePolylines:()=>bIt,createVerticesFromGoogleEarthEnterpriseBuffer:()=>YIt,createVerticesFromHeightmap:()=>VIt,createVerticesFromQuantizedTerrainMesh:()=>SIt,createWallGeometry:()=>OIt,createWallOutlineGeometry:()=>BIt,decodeDraco:()=>GIt,decodeGoogleEarthEnterprisePacket:()=>WIt,decodeI3S:()=>DIt,transcodeKTX2:()=>UIt,transferTypedArrayTest:()=>MIt,upsampleQuantizedTerrainMesh:()=>QIt});var xZt=()=>{Promise.resolve().then(()=>i0())},PZt=()=>{Promise.resolve().then(()=>tS())},JZt=()=>{Promise.resolve().then(()=>iS())},jZt=()=>{Promise.resolve().then(()=>rS())},HZt=()=>{Promise.resolve().then(()=>hS())},vZt=()=>{Promise.resolve().then(()=>IS())},zZt=()=>{Promise.resolve().then(()=>gS())},KZt=()=>{Promise.resolve().then(()=>GS())},XZt=()=>{Promise.resolve().then(()=>US())},qZt=()=>{Promise.resolve().then(()=>XS())},$Zt=()=>{Promise.resolve().then(()=>tO())},tIt=()=>{Promise.resolve().then(()=>rO())},eIt=()=>{Promise.resolve().then(()=>cO())},iIt=()=>{Promise.resolve().then(()=>dO())},nIt=()=>{Promise.resolve().then(()=>fO())},sIt=()=>{Promise.resolve().then(()=>RO())},oIt=()=>{Promise.resolve().then(()=>pO())},rIt=()=>{Promise.resolve().then(()=>FO())},aIt=()=>{Promise.resolve().then(()=>SO())},AIt=()=>{Promise.resolve().then(()=>UG())},hIt=()=>{Promise.resolve().then(()=>BO())},cIt=()=>{Promise.resolve().then(()=>DO())},lIt=()=>{Promise.resolve().then(()=>QO())},dIt=()=>{Promise.resolve().then(()=>wO())},mIt=()=>{Promise.resolve().then(()=>JO())},fIt=()=>{Promise.resolve().then(()=>vO())},EIt=()=>{Promise.resolve().then(()=>XO())},_It=()=>{Promise.resolve().then(()=>tB())},RIt=()=>{Promise.resolve().then(()=>cB())},ZIt=()=>{Promise.resolve().then(()=>mB())},IIt=()=>{Promise.resolve().then(()=>_B())},pIt=()=>{Promise.resolve().then(()=>IB())},uIt=()=>{Promise.resolve().then(()=>CB())},CIt=()=>{Promise.resolve().then(()=>Ns())},gIt=()=>{Promise.resolve().then(()=>TB())},TIt=()=>{Promise.resolve().then(()=>FB())},NIt=()=>{Promise.resolve().then(()=>VB())},FIt=()=>{Promise.resolve().then(()=>OB())},bIt=()=>{Promise.resolve().then(()=>WB())},YIt=()=>{Promise.resolve().then(()=>MB())},VIt=()=>{Promise.resolve().then(()=>LB())},SIt=()=>{Promise.resolve().then(()=>xB())},OIt=()=>{Promise.resolve().then(()=>vB())},BIt=()=>{Promise.resolve().then(()=>XB())},GIt=()=>{Promise.resolve().then(()=>nG())},WIt=()=>{Promise.resolve().then(()=>pG())},DIt=()=>{Promise.resolve().then(()=>NG())},UIt=()=>{Promise.resolve().then(()=>SG())},MIt=()=>{Promise.resolve().then(()=>OG())},QIt=()=>{Promise.resolve().then(()=>GG())};return OX(kIt);})();
")});var KO=Zo((tOe,wct)=>{var eOe=b(W()),Zb=function(t){t==null&&(t=new Date().getTime()),this.N=624,this.M=397,this.MATRIX_A=2567483615,this.UPPER_MASK=2147483648,this.LOWER_MASK=2147483647,this.mt=new Array(this.N),this.mti=this.N+1,t.constructor==Array?this.init_by_array(t,t.length):this.init_seed(t)};Zb.prototype.init_seed=function(t){for(this.mt[0]=t>>>0,this.mti=1;this.mti>>30;this.mt[this.mti]=(((t&4294901760)>>>16)*1812433253<<16)+(t&65535)*1812433253+this.mti,this.mt[this.mti]>>>=0}};Zb.prototype.init_by_array=function(t,e){var n,i,o;for(this.init_seed(19650218),n=1,i=0,o=this.N>e?this.N:e;o;o--){var a=this.mt[n-1]^this.mt[n-1]>>>30;this.mt[n]=(this.mt[n]^(((a&4294901760)>>>16)*1664525<<16)+(a&65535)*1664525)+t[i]+i,this.mt[n]>>>=0,n++,i++,n>=this.N&&(this.mt[0]=this.mt[this.N-1],n=1),i>=e&&(i=0)}for(o=this.N-1;o;o--){var a=this.mt[n-1]^this.mt[n-1]>>>30;this.mt[n]=(this.mt[n]^(((a&4294901760)>>>16)*1566083941<<16)+(a&65535)*1566083941)-n,this.mt[n]>>>=0,n++,n>=this.N&&(this.mt[0]=this.mt[this.N-1],n=1)}this.mt[0]=2147483648};Zb.prototype.random_int=function(){var t,e=new Array(0,this.MATRIX_A);if(this.mti>=this.N){var n;for(this.mti==this.N+1&&this.init_seed(5489),n=0;n>>1^e[t&1];for(;n>>1^e[t&1];t=this.mt[this.N-1]&this.UPPER_MASK|this.mt[0]&this.LOWER_MASK,this.mt[this.N-1]=this.mt[this.M-1]^t>>>1^e[t&1],this.mti=0}return t=this.mt[this.mti++],t^=t>>>11,t^=t<<7&2636928640,t^=t<<15&4022730752,t^=t>>>18,t>>>0};Zb.prototype.random_int31=function(){return this.random_int()>>>1};Zb.prototype.random_incl=function(){return this.random_int()*(1/4294967295)};Zb.prototype.random=function(){return this.random_int()*(1/4294967296)};Zb.prototype.random_excl=function(){return(this.random_int()+.5)*(1/4294967296)};Zb.prototype.random_long=function(){var t=this.random_int()>>>5,e=this.random_int()>>>6;return(t*67108864+e)*(1/9007199254740992)};wct.exports=Zb});var Rmt=Zo((jg,qg)=>{var Lwe=b(W());/*! https://mths.be/punycode v1.4.0 by @mathias */(function(t){var e=typeof jg=="object"&&jg&&!jg.nodeType&&jg,n=typeof qg=="object"&&qg&&!qg.nodeType&&qg,i=typeof global=="object"&&global;(i.global===i||i.window===i||i.self===i)&&(t=i);var o,a=2147483647,s=36,l=1,r=26,d=38,m=700,h=72,u=128,R="-",V=/^xn--/,F=/[^\x20-\x7E]/,U=/[\x2E\u3002\uFF0E\uFF61]/g,G={overflow:"Overflow: input needs wider integers to process","not-basic":"Illegal input >= 0x80 (not a basic code point)","invalid-input":"Invalid input"},A=s-l,S=Math.floor,g=String.fromCharCode,C;function y(w){throw new RangeError(G[w])}function Y(w,z){for(var H=w.length,nt=[];H--;)nt[H]=z(w[H]);return nt}function Q(w,z){var H=w.split("@"),nt="";H.length>1&&(nt=H[0]+"@",w=H[1]),w=w.replace(U,".");var $=w.split("."),dt=Y($,z).join(".");return nt+dt}function J(w){for(var z=[],H=0,nt=w.length,$,dt;H=55296&&$<=56319&&H65535&&(z-=65536,H+=g(z>>>10&1023|55296),z=56320|z&1023),H+=g(z),H}).join("")}function Z(w){return w-48<10?w-22:w-65<26?w-65:w-97<26?w-97:s}function E(w,z){return w+22+75*(w<26)-((z!=0)<<5)}function I(w,z,H){var nt=0;for(w=H?S(w/m):w>>1,w+=S(w/z);w>A*r>>1;nt+=s)w=S(w/A);return S(nt+(A+1)*w/(w+d))}function B(w){var z=[],H=w.length,nt,$=0,dt=u,q=h,at,st,Et,Qt,Wt,Nt,kt,Mt,qt;for(at=w.lastIndexOf(R),at<0&&(at=0),st=0;st=128&&y("not-basic"),z.push(w.charCodeAt(st));for(Et=at>0?at+1:0;Et=H&&y("invalid-input"),kt=Z(w.charCodeAt(Et++)),(kt>=s||kt>S((a-$)/Wt))&&y("overflow"),$+=kt*Wt,Mt=Nt<=q?l:Nt>=q+r?r:Nt-q,!(ktS(a/qt)&&y("overflow"),Wt*=qt;nt=z.length+1,q=I($-Qt,nt,Qt==0),S($/nt)>a-dt&&y("overflow"),dt+=S($/nt),$%=nt,z.splice($++,0,dt)}return M(z)}function X(w){var z,H,nt,$,dt,q,at,st,Et,Qt,Wt,Nt=[],kt,Mt,qt,ie;for(w=J(w),kt=w.length,z=u,H=0,dt=h,q=0;q=z&&WtS((a-H)/Mt)&&y("overflow"),H+=(at-z)*Mt,z=at,q=0;qa&&y("overflow"),Wt==z){for(st=H,Et=s;Qt=Et<=dt?l:Et>=dt+r?r:Et-dt,!(st{var Mwe=b(W());/*! * URI.js - Mutating URLs * IPv6 Support * @@ -35,7 +35,7 @@ var Cesium=(()=>{var pMt=Object.create;var PO=Object.defineProperty;var uMt=Obje * Licensed under * MIT License http://www.opensource.org/licenses/mit-license * - */(function(t,e){"use strict";typeof ZH=="object"&&ZH.exports?ZH.exports=e():typeof define=="function"&&define.amd?define(e):t.IPv6=e(t)})(Rmt,function(t){"use strict";var e=t&&t.IPv6;function n(o){var a=o.toLowerCase(),s=a.split(":"),l=s.length,r=8;s[0]===""&&s[1]===""&&s[2]===""?(s.shift(),s.shift()):s[0]===""&&s[1]===""?s.shift():s[l-1]===""&&s[l-2]===""&&s.pop(),l=s.length,s[l-1].indexOf(".")!==-1&&(r=7);var d;for(d=0;d1);Z++)m.splice(0,1);s[h]=m.join("")}var b=-1,u=0,F=0,U=-1,G=!1;for(h=0;hu&&(b=U,u=F)):s[h]==="0"&&(G=!0,U=h,F=1);F>u&&(b=U,u=F),u>1&&s.splice(b,u,""),l=s.length;var A="";for(s[0]===""&&(A=":"),h=0;h{var _we=R(W());/*! + */(function(t,e){"use strict";typeof uH=="object"&&uH.exports?uH.exports=e():typeof define=="function"&&define.amd?define(e):t.IPv6=e(t)})(bmt,function(t){"use strict";var e=t&&t.IPv6;function n(o){var a=o.toLowerCase(),s=a.split(":"),l=s.length,r=8;s[0]===""&&s[1]===""&&s[2]===""?(s.shift(),s.shift()):s[0]===""&&s[1]===""?s.shift():s[l-1]===""&&s[l-2]===""&&s.pop(),l=s.length,s[l-1].indexOf(".")!==-1&&(r=7);var d;for(d=0;d1);u++)m.splice(0,1);s[h]=m.join("")}var R=-1,V=0,F=0,U=-1,G=!1;for(h=0;hV&&(R=U,V=F)):s[h]==="0"&&(G=!0,U=h,F=1);F>V&&(R=U,V=F),V>1&&s.splice(R,V,""),l=s.length;var A="";for(s[0]===""&&(A=":"),h=0;h{var _we=b(W());/*! * URI.js - Mutating URLs * Second Level Domain (SLD) Support * @@ -47,7 +47,7 @@ var Cesium=(()=>{var pMt=Object.create;var PO=Object.defineProperty;var uMt=Obje * Licensed under * MIT License http://www.opensource.org/licenses/mit-license * - */(function(t,e){"use strict";typeof VH=="object"&&VH.exports?VH.exports=e():typeof define=="function"&&define.amd?define(e):t.SecondLevelDomains=e(t)})(fmt,function(t){"use strict";var e=t&&t.SecondLevelDomains,n={list:{ac:" com gov mil net org ",ae:" ac co gov mil name net org pro sch ",af:" com edu gov net org ",al:" com edu gov mil net org ",ao:" co ed gv it og pb ",ar:" com edu gob gov int mil net org tur ",at:" ac co gv or ",au:" asn com csiro edu gov id net org ",ba:" co com edu gov mil net org rs unbi unmo unsa untz unze ",bb:" biz co com edu gov info net org store tv ",bh:" biz cc com edu gov info net org ",bn:" com edu gov net org ",bo:" com edu gob gov int mil net org tv ",br:" adm adv agr am arq art ato b bio blog bmd cim cng cnt com coop ecn edu eng esp etc eti far flog fm fnd fot fst g12 ggf gov imb ind inf jor jus lel mat med mil mus net nom not ntr odo org ppg pro psc psi qsl rec slg srv tmp trd tur tv vet vlog wiki zlg ",bs:" com edu gov net org ",bz:" du et om ov rg ",ca:" ab bc mb nb nf nl ns nt nu on pe qc sk yk ",ck:" biz co edu gen gov info net org ",cn:" ac ah bj com cq edu fj gd gov gs gx gz ha hb he hi hl hn jl js jx ln mil net nm nx org qh sc sd sh sn sx tj tw xj xz yn zj ",co:" com edu gov mil net nom org ",cr:" ac c co ed fi go or sa ",cy:" ac biz com ekloges gov ltd name net org parliament press pro tm ",do:" art com edu gob gov mil net org sld web ",dz:" art asso com edu gov net org pol ",ec:" com edu fin gov info med mil net org pro ",eg:" com edu eun gov mil name net org sci ",er:" com edu gov ind mil net org rochest w ",es:" com edu gob nom org ",et:" biz com edu gov info name net org ",fj:" ac biz com info mil name net org pro ",fk:" ac co gov net nom org ",fr:" asso com f gouv nom prd presse tm ",gg:" co net org ",gh:" com edu gov mil org ",gn:" ac com gov net org ",gr:" com edu gov mil net org ",gt:" com edu gob ind mil net org ",gu:" com edu gov net org ",hk:" com edu gov idv net org ",hu:" 2000 agrar bolt casino city co erotica erotika film forum games hotel info ingatlan jogasz konyvelo lakas media news org priv reklam sex shop sport suli szex tm tozsde utazas video ",id:" ac co go mil net or sch web ",il:" ac co gov idf k12 muni net org ",in:" ac co edu ernet firm gen gov i ind mil net nic org res ",iq:" com edu gov i mil net org ",ir:" ac co dnssec gov i id net org sch ",it:" edu gov ",je:" co net org ",jo:" com edu gov mil name net org sch ",jp:" ac ad co ed go gr lg ne or ",ke:" ac co go info me mobi ne or sc ",kh:" com edu gov mil net org per ",ki:" biz com de edu gov info mob net org tel ",km:" asso com coop edu gouv k medecin mil nom notaires pharmaciens presse tm veterinaire ",kn:" edu gov net org ",kr:" ac busan chungbuk chungnam co daegu daejeon es gangwon go gwangju gyeongbuk gyeonggi gyeongnam hs incheon jeju jeonbuk jeonnam k kg mil ms ne or pe re sc seoul ulsan ",kw:" com edu gov net org ",ky:" com edu gov net org ",kz:" com edu gov mil net org ",lb:" com edu gov net org ",lk:" assn com edu gov grp hotel int ltd net ngo org sch soc web ",lr:" com edu gov net org ",lv:" asn com conf edu gov id mil net org ",ly:" com edu gov id med net org plc sch ",ma:" ac co gov m net org press ",mc:" asso tm ",me:" ac co edu gov its net org priv ",mg:" com edu gov mil nom org prd tm ",mk:" com edu gov inf name net org pro ",ml:" com edu gov net org presse ",mn:" edu gov org ",mo:" com edu gov net org ",mt:" com edu gov net org ",mv:" aero biz com coop edu gov info int mil museum name net org pro ",mw:" ac co com coop edu gov int museum net org ",mx:" com edu gob net org ",my:" com edu gov mil name net org sch ",nf:" arts com firm info net other per rec store web ",ng:" biz com edu gov mil mobi name net org sch ",ni:" ac co com edu gob mil net nom org ",np:" com edu gov mil net org ",nr:" biz com edu gov info net org ",om:" ac biz co com edu gov med mil museum net org pro sch ",pe:" com edu gob mil net nom org sld ",ph:" com edu gov i mil net ngo org ",pk:" biz com edu fam gob gok gon gop gos gov net org web ",pl:" art bialystok biz com edu gda gdansk gorzow gov info katowice krakow lodz lublin mil net ngo olsztyn org poznan pwr radom slupsk szczecin torun warszawa waw wroc wroclaw zgora ",pr:" ac biz com edu est gov info isla name net org pro prof ",ps:" com edu gov net org plo sec ",pw:" belau co ed go ne or ",ro:" arts com firm info nom nt org rec store tm www ",rs:" ac co edu gov in org ",sb:" com edu gov net org ",sc:" com edu gov net org ",sh:" co com edu gov net nom org ",sl:" com edu gov net org ",st:" co com consulado edu embaixada gov mil net org principe saotome store ",sv:" com edu gob org red ",sz:" ac co org ",tr:" av bbs bel biz com dr edu gen gov info k12 name net org pol tel tsk tv web ",tt:" aero biz cat co com coop edu gov info int jobs mil mobi museum name net org pro tel travel ",tw:" club com ebiz edu game gov idv mil net org ",mu:" ac co com gov net or org ",mz:" ac co edu gov org ",na:" co com ",nz:" ac co cri geek gen govt health iwi maori mil net org parliament school ",pa:" abo ac com edu gob ing med net nom org sld ",pt:" com edu gov int net nome org publ ",py:" com edu gov mil net org ",qa:" com edu gov mil net org ",re:" asso com nom ",ru:" ac adygeya altai amur arkhangelsk astrakhan bashkiria belgorod bir bryansk buryatia cbg chel chelyabinsk chita chukotka chuvashia com dagestan e-burg edu gov grozny int irkutsk ivanovo izhevsk jar joshkar-ola kalmykia kaluga kamchatka karelia kazan kchr kemerovo khabarovsk khakassia khv kirov koenig komi kostroma kranoyarsk kuban kurgan kursk lipetsk magadan mari mari-el marine mil mordovia mosreg msk murmansk nalchik net nnov nov novosibirsk nsk omsk orenburg org oryol penza perm pp pskov ptz rnd ryazan sakhalin samara saratov simbirsk smolensk spb stavropol stv surgut tambov tatarstan tom tomsk tsaritsyn tsk tula tuva tver tyumen udm udmurtia ulan-ude vladikavkaz vladimir vladivostok volgograd vologda voronezh vrn vyatka yakutia yamal yekaterinburg yuzhno-sakhalinsk ",rw:" ac co com edu gouv gov int mil net ",sa:" com edu gov med net org pub sch ",sd:" com edu gov info med net org tv ",se:" a ac b bd c d e f g h i k l m n o org p parti pp press r s t tm u w x y z ",sg:" com edu gov idn net org per ",sn:" art com edu gouv org perso univ ",sy:" com edu gov mil net news org ",th:" ac co go in mi net or ",tj:" ac biz co com edu go gov info int mil name net nic org test web ",tn:" agrinet com defense edunet ens fin gov ind info intl mincom nat net org perso rnrt rns rnu tourism ",tz:" ac co go ne or ",ua:" biz cherkassy chernigov chernovtsy ck cn co com crimea cv dn dnepropetrovsk donetsk dp edu gov if in ivano-frankivsk kh kharkov kherson khmelnitskiy kiev kirovograd km kr ks kv lg lugansk lutsk lviv me mk net nikolaev od odessa org pl poltava pp rovno rv sebastopol sumy te ternopil uzhgorod vinnica vn zaporizhzhe zhitomir zp zt ",ug:" ac co go ne or org sc ",uk:" ac bl british-library co cym gov govt icnet jet lea ltd me mil mod national-library-scotland nel net nhs nic nls org orgn parliament plc police sch scot soc ",us:" dni fed isa kids nsn ",uy:" com edu gub mil net org ",ve:" co com edu gob info mil net org web ",vi:" co com k12 net org ",vn:" ac biz com edu gov health info int name net org pro ",ye:" co com gov ltd me net org plc ",yu:" ac co edu gov org ",za:" ac agric alt bourse city co cybernet db edu gov grondar iaccess imt inca landesign law mil net ngo nis nom olivetti org pix school tm web ",zm:" ac co com edu gov net org sch ",com:"ar br cn de eu gb gr hu jpn kr no qc ru sa se uk us uy za ",net:"gb jp se uk ",org:"ae",de:"com "},has:function(i){var o=i.lastIndexOf(".");if(o<=0||o>=i.length-1)return!1;var a=i.lastIndexOf(".",o-1);if(a<=0||a>=o-1)return!1;var s=n.list[i.slice(o+1)];return s?s.indexOf(" "+i.slice(a+1,o)+" ")>=0:!1},is:function(i){var o=i.lastIndexOf(".");if(o<=0||o>=i.length-1)return!1;var a=i.lastIndexOf(".",o-1);if(a>=0)return!1;var s=n.list[i.slice(o+1)];return s?s.indexOf(" "+i.slice(0,o)+" ")>=0:!1},get:function(i){var o=i.lastIndexOf(".");if(o<=0||o>=i.length-1)return null;var a=i.lastIndexOf(".",o-1);if(a<=0||a>=o-1)return null;var s=n.list[i.slice(o+1)];return!s||s.indexOf(" "+i.slice(a+1,o)+" ")<0?null:i.slice(a+1)},noConflict:function(){return t.SecondLevelDomains===this&&(t.SecondLevelDomains=e),this}};return n})});var uh=Vo((Umt,bH)=>{var Dwe=R(W());/*! + */(function(t,e){"use strict";typeof ZH=="object"&&ZH.exports?ZH.exports=e():typeof define=="function"&&define.amd?define(e):t.SecondLevelDomains=e(t)})(fmt,function(t){"use strict";var e=t&&t.SecondLevelDomains,n={list:{ac:" com gov mil net org ",ae:" ac co gov mil name net org pro sch ",af:" com edu gov net org ",al:" com edu gov mil net org ",ao:" co ed gv it og pb ",ar:" com edu gob gov int mil net org tur ",at:" ac co gv or ",au:" asn com csiro edu gov id net org ",ba:" co com edu gov mil net org rs unbi unmo unsa untz unze ",bb:" biz co com edu gov info net org store tv ",bh:" biz cc com edu gov info net org ",bn:" com edu gov net org ",bo:" com edu gob gov int mil net org tv ",br:" adm adv agr am arq art ato b bio blog bmd cim cng cnt com coop ecn edu eng esp etc eti far flog fm fnd fot fst g12 ggf gov imb ind inf jor jus lel mat med mil mus net nom not ntr odo org ppg pro psc psi qsl rec slg srv tmp trd tur tv vet vlog wiki zlg ",bs:" com edu gov net org ",bz:" du et om ov rg ",ca:" ab bc mb nb nf nl ns nt nu on pe qc sk yk ",ck:" biz co edu gen gov info net org ",cn:" ac ah bj com cq edu fj gd gov gs gx gz ha hb he hi hl hn jl js jx ln mil net nm nx org qh sc sd sh sn sx tj tw xj xz yn zj ",co:" com edu gov mil net nom org ",cr:" ac c co ed fi go or sa ",cy:" ac biz com ekloges gov ltd name net org parliament press pro tm ",do:" art com edu gob gov mil net org sld web ",dz:" art asso com edu gov net org pol ",ec:" com edu fin gov info med mil net org pro ",eg:" com edu eun gov mil name net org sci ",er:" com edu gov ind mil net org rochest w ",es:" com edu gob nom org ",et:" biz com edu gov info name net org ",fj:" ac biz com info mil name net org pro ",fk:" ac co gov net nom org ",fr:" asso com f gouv nom prd presse tm ",gg:" co net org ",gh:" com edu gov mil org ",gn:" ac com gov net org ",gr:" com edu gov mil net org ",gt:" com edu gob ind mil net org ",gu:" com edu gov net org ",hk:" com edu gov idv net org ",hu:" 2000 agrar bolt casino city co erotica erotika film forum games hotel info ingatlan jogasz konyvelo lakas media news org priv reklam sex shop sport suli szex tm tozsde utazas video ",id:" ac co go mil net or sch web ",il:" ac co gov idf k12 muni net org ",in:" ac co edu ernet firm gen gov i ind mil net nic org res ",iq:" com edu gov i mil net org ",ir:" ac co dnssec gov i id net org sch ",it:" edu gov ",je:" co net org ",jo:" com edu gov mil name net org sch ",jp:" ac ad co ed go gr lg ne or ",ke:" ac co go info me mobi ne or sc ",kh:" com edu gov mil net org per ",ki:" biz com de edu gov info mob net org tel ",km:" asso com coop edu gouv k medecin mil nom notaires pharmaciens presse tm veterinaire ",kn:" edu gov net org ",kr:" ac busan chungbuk chungnam co daegu daejeon es gangwon go gwangju gyeongbuk gyeonggi gyeongnam hs incheon jeju jeonbuk jeonnam k kg mil ms ne or pe re sc seoul ulsan ",kw:" com edu gov net org ",ky:" com edu gov net org ",kz:" com edu gov mil net org ",lb:" com edu gov net org ",lk:" assn com edu gov grp hotel int ltd net ngo org sch soc web ",lr:" com edu gov net org ",lv:" asn com conf edu gov id mil net org ",ly:" com edu gov id med net org plc sch ",ma:" ac co gov m net org press ",mc:" asso tm ",me:" ac co edu gov its net org priv ",mg:" com edu gov mil nom org prd tm ",mk:" com edu gov inf name net org pro ",ml:" com edu gov net org presse ",mn:" edu gov org ",mo:" com edu gov net org ",mt:" com edu gov net org ",mv:" aero biz com coop edu gov info int mil museum name net org pro ",mw:" ac co com coop edu gov int museum net org ",mx:" com edu gob net org ",my:" com edu gov mil name net org sch ",nf:" arts com firm info net other per rec store web ",ng:" biz com edu gov mil mobi name net org sch ",ni:" ac co com edu gob mil net nom org ",np:" com edu gov mil net org ",nr:" biz com edu gov info net org ",om:" ac biz co com edu gov med mil museum net org pro sch ",pe:" com edu gob mil net nom org sld ",ph:" com edu gov i mil net ngo org ",pk:" biz com edu fam gob gok gon gop gos gov net org web ",pl:" art bialystok biz com edu gda gdansk gorzow gov info katowice krakow lodz lublin mil net ngo olsztyn org poznan pwr radom slupsk szczecin torun warszawa waw wroc wroclaw zgora ",pr:" ac biz com edu est gov info isla name net org pro prof ",ps:" com edu gov net org plo sec ",pw:" belau co ed go ne or ",ro:" arts com firm info nom nt org rec store tm www ",rs:" ac co edu gov in org ",sb:" com edu gov net org ",sc:" com edu gov net org ",sh:" co com edu gov net nom org ",sl:" com edu gov net org ",st:" co com consulado edu embaixada gov mil net org principe saotome store ",sv:" com edu gob org red ",sz:" ac co org ",tr:" av bbs bel biz com dr edu gen gov info k12 name net org pol tel tsk tv web ",tt:" aero biz cat co com coop edu gov info int jobs mil mobi museum name net org pro tel travel ",tw:" club com ebiz edu game gov idv mil net org ",mu:" ac co com gov net or org ",mz:" ac co edu gov org ",na:" co com ",nz:" ac co cri geek gen govt health iwi maori mil net org parliament school ",pa:" abo ac com edu gob ing med net nom org sld ",pt:" com edu gov int net nome org publ ",py:" com edu gov mil net org ",qa:" com edu gov mil net org ",re:" asso com nom ",ru:" ac adygeya altai amur arkhangelsk astrakhan bashkiria belgorod bir bryansk buryatia cbg chel chelyabinsk chita chukotka chuvashia com dagestan e-burg edu gov grozny int irkutsk ivanovo izhevsk jar joshkar-ola kalmykia kaluga kamchatka karelia kazan kchr kemerovo khabarovsk khakassia khv kirov koenig komi kostroma kranoyarsk kuban kurgan kursk lipetsk magadan mari mari-el marine mil mordovia mosreg msk murmansk nalchik net nnov nov novosibirsk nsk omsk orenburg org oryol penza perm pp pskov ptz rnd ryazan sakhalin samara saratov simbirsk smolensk spb stavropol stv surgut tambov tatarstan tom tomsk tsaritsyn tsk tula tuva tver tyumen udm udmurtia ulan-ude vladikavkaz vladimir vladivostok volgograd vologda voronezh vrn vyatka yakutia yamal yekaterinburg yuzhno-sakhalinsk ",rw:" ac co com edu gouv gov int mil net ",sa:" com edu gov med net org pub sch ",sd:" com edu gov info med net org tv ",se:" a ac b bd c d e f g h i k l m n o org p parti pp press r s t tm u w x y z ",sg:" com edu gov idn net org per ",sn:" art com edu gouv org perso univ ",sy:" com edu gov mil net news org ",th:" ac co go in mi net or ",tj:" ac biz co com edu go gov info int mil name net nic org test web ",tn:" agrinet com defense edunet ens fin gov ind info intl mincom nat net org perso rnrt rns rnu tourism ",tz:" ac co go ne or ",ua:" biz cherkassy chernigov chernovtsy ck cn co com crimea cv dn dnepropetrovsk donetsk dp edu gov if in ivano-frankivsk kh kharkov kherson khmelnitskiy kiev kirovograd km kr ks kv lg lugansk lutsk lviv me mk net nikolaev od odessa org pl poltava pp rovno rv sebastopol sumy te ternopil uzhgorod vinnica vn zaporizhzhe zhitomir zp zt ",ug:" ac co go ne or org sc ",uk:" ac bl british-library co cym gov govt icnet jet lea ltd me mil mod national-library-scotland nel net nhs nic nls org orgn parliament plc police sch scot soc ",us:" dni fed isa kids nsn ",uy:" com edu gub mil net org ",ve:" co com edu gob info mil net org web ",vi:" co com k12 net org ",vn:" ac biz com edu gov health info int name net org pro ",ye:" co com gov ltd me net org plc ",yu:" ac co edu gov org ",za:" ac agric alt bourse city co cybernet db edu gov grondar iaccess imt inca landesign law mil net ngo nis nom olivetti org pix school tm web ",zm:" ac co com edu gov net org sch ",com:"ar br cn de eu gb gr hu jpn kr no qc ru sa se uk us uy za ",net:"gb jp se uk ",org:"ae",de:"com "},has:function(i){var o=i.lastIndexOf(".");if(o<=0||o>=i.length-1)return!1;var a=i.lastIndexOf(".",o-1);if(a<=0||a>=o-1)return!1;var s=n.list[i.slice(o+1)];return s?s.indexOf(" "+i.slice(a+1,o)+" ")>=0:!1},is:function(i){var o=i.lastIndexOf(".");if(o<=0||o>=i.length-1)return!1;var a=i.lastIndexOf(".",o-1);if(a>=0)return!1;var s=n.list[i.slice(o+1)];return s?s.indexOf(" "+i.slice(0,o)+" ")>=0:!1},get:function(i){var o=i.lastIndexOf(".");if(o<=0||o>=i.length-1)return null;var a=i.lastIndexOf(".",o-1);if(a<=0||a>=o-1)return null;var s=n.list[i.slice(o+1)];return!s||s.indexOf(" "+i.slice(a+1,o)+" ")<0?null:i.slice(a+1)},noConflict:function(){return t.SecondLevelDomains===this&&(t.SecondLevelDomains=e),this}};return n})});var Vh=Zo((Umt,RH)=>{var Dwe=b(W());/*! * URI.js - Mutating URLs * * Version: 1.19.11 @@ -58,18 +58,18 @@ var Cesium=(()=>{var pMt=Object.create;var PO=Object.defineProperty;var uMt=Obje * Licensed under * MIT License http://www.opensource.org/licenses/mit-license * - */(function(t,e){"use strict";typeof bH=="object"&&bH.exports?bH.exports=e(bmt(),Wmt(),Fmt()):typeof define=="function"&&define.amd?define(["./punycode","./IPv6","./SecondLevelDomains"],e):t.URI=e(t.punycode,t.IPv6,t.SecondLevelDomains,t)})(Umt,function(t,e,n,i){"use strict";var o=i&&i.URI;function a(E,I){var B=arguments.length>=1,X=arguments.length>=2;if(!(this instanceof a))return B?X?new a(E,I):new a(E):new a;if(E===void 0){if(B)throw new TypeError("undefined is not a valid argument for URI");typeof location<"u"?E=location.href+"":E=""}if(E===null&&B)throw new TypeError("null is not a valid argument for URI");return this.href(E),I!==void 0?this.absoluteTo(I):this}function s(E){return/^[0-9]+$/.test(E)}a.version="1.19.11";var l=a.prototype,r=Object.prototype.hasOwnProperty;function d(E){return E.replace(/([.*+?^=!:${}()|[\]\/\\])/g,"\\$1")}function m(E){return E===void 0?"Undefined":String(Object.prototype.toString.call(E)).slice(8,-1)}function h(E){return m(E)==="Array"}function Z(E,I){var B={},X,_;if(m(I)==="RegExp")B=null;else if(h(I))for(X=0,_=I.length;X<_;X++)B[I[X]]=!0;else B[I]=!0;for(X=0,_=E.length;X<_;X++){var P=B&&B[E[X]]!==void 0||!B&&I.test(E[X]);P&&(E.splice(X,1),_--,X--)}return E}function b(E,I){var B,X;if(h(I)){for(B=0,X=I.length;B]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))/ig,a.findUri={start:/\b(?:([a-z][a-z0-9.+-]*:\/\/)|www\.)/gi,end:/[\s\r\n]|$/,trim:/[`!()\[\]{};:'".,<>?«»“”„‘’]+$/,parens:/(\([^\)]*\)|\[[^\]]*\]|\{[^}]*\}|<[^>]*>)/g},a.leading_whitespace_expression=/^[\x00-\x20\u00a0\u1680\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff]+/,a.ascii_tab_whitespace=/[\u0009\u000A\u000D]+/g,a.defaultPorts={http:"80",https:"443",ftp:"21",gopher:"70",ws:"80",wss:"443"},a.hostProtocols=["http","https"],a.invalid_hostname_characters=/[^a-zA-Z0-9\.\-:_]/,a.domAttributes={a:"href",blockquote:"cite",link:"href",base:"href",script:"src",form:"action",img:"src",area:"href",iframe:"src",embed:"src",source:"src",track:"src",input:"src",audio:"src",video:"src"},a.getDomAttribute=function(E){if(!(!E||!E.nodeName)){var I=E.nodeName.toLowerCase();if(!(I==="input"&&E.type!=="image"))return a.domAttributes[I]}};function U(E){return escape(E)}function G(E){return encodeURIComponent(E).replace(/[!'()*]/g,U).replace(/\*/g,"%2A")}a.encode=G,a.decode=decodeURIComponent,a.iso8859=function(){a.encode=escape,a.decode=unescape},a.unicode=function(){a.encode=G,a.decode=decodeURIComponent},a.characters={pathname:{encode:{expression:/%(24|26|2B|2C|3B|3D|3A|40)/ig,map:{"%24":"$","%26":"&","%2B":"+","%2C":",","%3B":";","%3D":"=","%3A":":","%40":"@"}},decode:{expression:/[\/\?#]/g,map:{"/":"%2F","?":"%3F","#":"%23"}}},reserved:{encode:{expression:/%(21|23|24|26|27|28|29|2A|2B|2C|2F|3A|3B|3D|3F|40|5B|5D)/ig,map:{"%3A":":","%2F":"/","%3F":"?","%23":"#","%5B":"[","%5D":"]","%40":"@","%21":"!","%24":"$","%26":"&","%27":"'","%28":"(","%29":")","%2A":"*","%2B":"+","%2C":",","%3B":";","%3D":"="}}},urnpath:{encode:{expression:/%(21|24|27|28|29|2A|2B|2C|3B|3D|40)/ig,map:{"%21":"!","%24":"$","%27":"'","%28":"(","%29":")","%2A":"*","%2B":"+","%2C":",","%3B":";","%3D":"=","%40":"@"}},decode:{expression:/[\/\?#:]/g,map:{"/":"%2F","?":"%3F","#":"%23",":":"%3A"}}}},a.encodeQuery=function(E,I){var B=a.encode(E+"");return I===void 0&&(I=a.escapeQuerySpace),I?B.replace(/%20/g,"+"):B},a.decodeQuery=function(E,I){E+="",I===void 0&&(I=a.escapeQuerySpace);try{return a.decode(I?E.replace(/\+/g,"%20"):E)}catch{return E}};var A={encode:"encode",decode:"decode"},T,g=function(E,I){return function(B){try{return a[I](B+"").replace(a.characters[E][I].expression,function(X){return a.characters[E][I].map[X]})}catch{return B}}};for(T in A)a[T+"PathSegment"]=g("pathname",A[T]),a[T+"UrnPathSegment"]=g("urnpath",A[T]);var C=function(E,I,B){return function(X){var _;B?_=function(H){return a[I](a[B](H))}:_=a[I];for(var P=(X+"").split(E),w=0,z=P.length;w-1&&(I.fragment=E.substring(B+1)||null,E=E.substring(0,B)),B=E.indexOf("?"),B>-1&&(I.query=E.substring(B+1)||null,E=E.substring(0,B)),E=E.replace(/^(https?|ftp|wss?)?:+[/\\]*/i,"$1://"),E=E.replace(/^[/\\]{2,}/i,"//"),E.substring(0,2)==="//"?(I.protocol=null,E=E.substring(2),E=a.parseAuthority(E,I)):(B=E.indexOf(":"),B>-1&&(I.protocol=E.substring(0,B)||null,I.protocol&&!I.protocol.match(a.protocol_expression)?I.protocol=void 0:E.substring(B+1,B+3).replace(/\\/g,"/")==="//"?(E=E.substring(B+3),E=a.parseAuthority(E,I)):(E=E.substring(B+1),I.urn=!0))),I.path=E,I},a.parseHost=function(E,I){E||(E=""),E=E.replace(/\\/g,"/");var B=E.indexOf("/"),X,_;if(B===-1&&(B=E.length),E.charAt(0)==="[")X=E.indexOf("]"),I.hostname=E.substring(1,X)||null,I.port=E.substring(X+2,B)||null,I.port==="/"&&(I.port=null);else{var P=E.indexOf(":"),w=E.indexOf("/"),z=E.indexOf(":",P+1);z!==-1&&(w===-1||z-1?_:E.length-1),w;return P>-1&&(_===-1||P<_)?(w=E.substring(0,P).split(":"),I.username=w[0]?a.decode(w[0]):null,w.shift(),I.password=w[0]?a.decode(w.join(":")):null,E=B.substring(P+1)):(I.username=null,I.password=null),E},a.parseQuery=function(E,I){if(!E)return{};if(E=E.replace(/&+/g,"&").replace(/^\?*&*|&+$/g,""),!E)return{};for(var B={},X=E.split("&"),_=X.length,P,w,z,H=0;H<_;H++)P=X[H].split("="),w=a.decodeQuery(P.shift(),I),z=P.length?a.decodeQuery(P.join("="),I):null,w!=="__proto__"&&(r.call(B,w)?((typeof B[w]=="string"||B[w]===null)&&(B[w]=[B[w]]),B[w].push(z)):B[w]=z);return B},a.build=function(E){var I="",B=!1;return E.protocol&&(I+=E.protocol+":"),!E.urn&&(I||E.hostname)&&(I+="//",B=!0),I+=a.buildAuthority(E)||"",typeof E.path=="string"&&(E.path.charAt(0)!=="/"&&B&&(I+="/"),I+=E.path),typeof E.query=="string"&&E.query&&(I+="?"+E.query),typeof E.fragment=="string"&&E.fragment&&(I+="#"+E.fragment),I},a.buildHost=function(E){var I="";if(E.hostname)a.ip6_expression.test(E.hostname)?I+="["+E.hostname+"]":I+=E.hostname;else return"";return E.port&&(I+=":"+E.port),I},a.buildAuthority=function(E){return a.buildUserinfo(E)+a.buildHost(E)},a.buildUserinfo=function(E){var I="";return E.username&&(I+=a.encode(E.username)),E.password&&(I+=":"+a.encode(E.password)),I&&(I+="@"),I},a.buildQuery=function(E,I,B){var X="",_,P,w,z;for(P in E)if(P!=="__proto__"&&r.call(E,P))if(h(E[P]))for(_={},w=0,z=E[P].length;w-1?q=q.slice(0,at)+q.slice(at).replace(P,""):q=q.replace(P,""),!(q.length<=H[0].length)&&!(B.ignore&&B.ignore.test(q))){dt=nt+q.length;var Qt=I(q,nt,dt,E);if(Qt===void 0){X.lastIndex=dt;continue}Qt=String(Qt),E=E.slice(0,nt)+Qt+E.slice(dt),X.lastIndex=nt+Qt.length}}return X.lastIndex=0,E},a.ensureValidHostname=function(E,I){var B=!!E,X=!!I,_=!1;if(X&&(_=b(a.hostProtocols,I)),_&&!B)throw new TypeError("Hostname cannot be empty, if protocol is "+I);if(E&&E.match(a.invalid_hostname_characters)){if(!t)throw new TypeError('Hostname "'+E+'" contains characters other than [A-Z0-9.-:_] and Punycode.js is not available');if(t.toASCII(E).match(a.invalid_hostname_characters))throw new TypeError('Hostname "'+E+'" contains characters other than [A-Z0-9.-:_]')}},a.ensureValidPort=function(E){if(E){var I=Number(E);if(!(s(I)&&I>0&&I<65536))throw new TypeError('Port "'+E+'" is not a valid port')}},a.noConflict=function(E){if(E){var I={URI:this.noConflict()};return i.URITemplate&&typeof i.URITemplate.noConflict=="function"&&(I.URITemplate=i.URITemplate.noConflict()),i.IPv6&&typeof i.IPv6.noConflict=="function"&&(I.IPv6=i.IPv6.noConflict()),i.SecondLevelDomains&&typeof i.SecondLevelDomains.noConflict=="function"&&(I.SecondLevelDomains=i.SecondLevelDomains.noConflict()),I}else i.URI===this&&(i.URI=o);return this},l.build=function(E){return E===!0?this._deferred_build=!0:(E===void 0||this._deferred_build)&&(this._string=a.build(this._parts),this._deferred_build=!1),this},l.clone=function(){return new a(this)},l.valueOf=l.toString=function(){return this.build(!1)._string};function y(E){return function(I,B){return I===void 0?this._parts[E]||"":(this._parts[E]=I||null,this.build(!B),this)}}function Y(E,I){return function(B,X){return B===void 0?this._parts[E]||"":(B!==null&&(B=B+"",B.charAt(0)===I&&(B=B.substring(1))),this._parts[E]=B,this.build(!X),this)}}l.protocol=y("protocol"),l.username=y("username"),l.password=y("password"),l.hostname=y("hostname"),l.port=y("port"),l.query=Y("query","?"),l.fragment=Y("fragment","#"),l.search=function(E,I){var B=this.query(E,I);return typeof B=="string"&&B.length?"?"+B:B},l.hash=function(E,I){var B=this.fragment(E,I);return typeof B=="string"&&B.length?"#"+B:B},l.pathname=function(E,I){if(E===void 0||E===!0){var B=this._parts.path||(this._parts.hostname?"/":"");return E?(this._parts.urn?a.decodeUrnPath:a.decodePath)(B):B}else return this._parts.urn?this._parts.path=E?a.recodeUrnPath(E):"":this._parts.path=E?a.recodePath(E):"/",this.build(!I),this},l.path=l.pathname,l.href=function(E,I){var B;if(E===void 0)return this.toString();this._string="",this._parts=a._parts();var X=E instanceof a,_=typeof E=="object"&&(E.hostname||E.path||E.pathname);if(E.nodeName){var P=a.getDomAttribute(E);E=E[P]||"",_=!1}if(!X&&_&&E.pathname!==void 0&&(E=E.toString()),typeof E=="string"||E instanceof String)this._parts=a.parse(String(E),this._parts);else if(X||_){var w=X?E._parts:E;for(B in w)B!=="query"&&r.call(this._parts,B)&&(this._parts[B]=w[B]);w.query&&this.query(w.query,!1)}else throw new TypeError("invalid input");return this.build(!I),this},l.is=function(E){var I=!1,B=!1,X=!1,_=!1,P=!1,w=!1,z=!1,H=!this._parts.urn;switch(this._parts.hostname&&(H=!1,B=a.ip4_expression.test(this._parts.hostname),X=a.ip6_expression.test(this._parts.hostname),I=B||X,_=!I,P=_&&n&&n.has(this._parts.hostname),w=_&&a.idn_expression.test(this._parts.hostname),z=_&&a.punycode_expression.test(this._parts.hostname)),E.toLowerCase()){case"relative":return H;case"absolute":return!H;case"domain":case"name":return _;case"sld":return P;case"ip":return I;case"ip4":case"ipv4":case"inet4":return B;case"ip6":case"ipv6":case"inet6":return X;case"idn":return w;case"url":return!this._parts.urn;case"urn":return!!this._parts.urn;case"punycode":return z}return null};var Q=l.protocol,J=l.port,M=l.hostname;l.protocol=function(E,I){if(E&&(E=E.replace(/:(\/\/)?$/,""),!E.match(a.protocol_expression)))throw new TypeError('Protocol "'+E+`" contains characters other than [A-Z0-9.+-] or doesn't start with [A-Z]`);return Q.call(this,E,I)},l.scheme=l.protocol,l.port=function(E,I){return this._parts.urn?E===void 0?"":this:(E!==void 0&&(E===0&&(E=null),E&&(E+="",E.charAt(0)===":"&&(E=E.substring(1)),a.ensureValidPort(E))),J.call(this,E,I))},l.hostname=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E!==void 0){var B={preventInvalidHostname:this._parts.preventInvalidHostname},X=a.parseHost(E,B);if(X!=="/")throw new TypeError('Hostname "'+E+'" contains characters other than [A-Z0-9.-]');E=B.hostname,this._parts.preventInvalidHostname&&a.ensureValidHostname(E,this._parts.protocol)}return M.call(this,E,I)},l.origin=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0){var B=this.protocol(),X=this.authority();return X?(B?B+"://":"")+this.authority():""}else{var _=a(E);return this.protocol(_.protocol()).authority(_.authority()).build(!I),this}},l.host=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0)return this._parts.hostname?a.buildHost(this._parts):"";var B=a.parseHost(E,this._parts);if(B!=="/")throw new TypeError('Hostname "'+E+'" contains characters other than [A-Z0-9.-]');return this.build(!I),this},l.authority=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0)return this._parts.hostname?a.buildAuthority(this._parts):"";var B=a.parseAuthority(E,this._parts);if(B!=="/")throw new TypeError('Hostname "'+E+'" contains characters other than [A-Z0-9.-]');return this.build(!I),this},l.userinfo=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0){var B=a.buildUserinfo(this._parts);return B&&B.substring(0,B.length-1)}else return E[E.length-1]!=="@"&&(E+="@"),a.parseUserinfo(E,this._parts),this.build(!I),this},l.resource=function(E,I){var B;return E===void 0?this.path()+this.search()+this.hash():(B=a.parse(E),this._parts.path=B.path,this._parts.query=B.query,this._parts.fragment=B.fragment,this.build(!I),this)},l.subdomain=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0){if(!this._parts.hostname||this.is("IP"))return"";var B=this._parts.hostname.length-this.domain().length-1;return this._parts.hostname.substring(0,B)||""}else{var X=this._parts.hostname.length-this.domain().length,_=this._parts.hostname.substring(0,X),P=new RegExp("^"+d(_));if(E&&E.charAt(E.length-1)!=="."&&(E+="."),E.indexOf(":")!==-1)throw new TypeError("Domains cannot contain colons");return E&&a.ensureValidHostname(E,this._parts.protocol),this._parts.hostname=this._parts.hostname.replace(P,E),this.build(!I),this}},l.domain=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(typeof E=="boolean"&&(I=E,E=void 0),E===void 0){if(!this._parts.hostname||this.is("IP"))return"";var B=this._parts.hostname.match(/\./g);if(B&&B.length<2)return this._parts.hostname;var X=this._parts.hostname.length-this.tld(I).length-1;return X=this._parts.hostname.lastIndexOf(".",X-1)+1,this._parts.hostname.substring(X)||""}else{if(!E)throw new TypeError("cannot set domain empty");if(E.indexOf(":")!==-1)throw new TypeError("Domains cannot contain colons");if(a.ensureValidHostname(E,this._parts.protocol),!this._parts.hostname||this.is("IP"))this._parts.hostname=E;else{var _=new RegExp(d(this.domain())+"$");this._parts.hostname=this._parts.hostname.replace(_,E)}return this.build(!I),this}},l.tld=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(typeof E=="boolean"&&(I=E,E=void 0),E===void 0){if(!this._parts.hostname||this.is("IP"))return"";var B=this._parts.hostname.lastIndexOf("."),X=this._parts.hostname.substring(B+1);return I!==!0&&n&&n.list[X.toLowerCase()]&&n.get(this._parts.hostname)||X}else{var _;if(E)if(E.match(/[^a-zA-Z0-9-]/))if(n&&n.is(E))_=new RegExp(d(this.tld())+"$"),this._parts.hostname=this._parts.hostname.replace(_,E);else throw new TypeError('TLD "'+E+'" contains characters other than [A-Z0-9]');else{if(!this._parts.hostname||this.is("IP"))throw new ReferenceError("cannot set TLD on non-domain host");_=new RegExp(d(this.tld())+"$"),this._parts.hostname=this._parts.hostname.replace(_,E)}else throw new TypeError("cannot set TLD empty");return this.build(!I),this}},l.directory=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0||E===!0){if(!this._parts.path&&!this._parts.hostname)return"";if(this._parts.path==="/")return"/";var B=this._parts.path.length-this.filename().length-1,X=this._parts.path.substring(0,B)||(this._parts.hostname?"/":"");return E?a.decodePath(X):X}else{var _=this._parts.path.length-this.filename().length,P=this._parts.path.substring(0,_),w=new RegExp("^"+d(P));return this.is("relative")||(E||(E="/"),E.charAt(0)!=="/"&&(E="/"+E)),E&&E.charAt(E.length-1)!=="/"&&(E+="/"),E=a.recodePath(E),this._parts.path=this._parts.path.replace(w,E),this.build(!I),this}},l.filename=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(typeof E!="string"){if(!this._parts.path||this._parts.path==="/")return"";var B=this._parts.path.lastIndexOf("/"),X=this._parts.path.substring(B+1);return E?a.decodePathSegment(X):X}else{var _=!1;E.charAt(0)==="/"&&(E=E.substring(1)),E.match(/\.?\//)&&(_=!0);var P=new RegExp(d(this.filename())+"$");return E=a.recodePath(E),this._parts.path=this._parts.path.replace(P,E),_?this.normalizePath(I):this.build(!I),this}},l.suffix=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0||E===!0){if(!this._parts.path||this._parts.path==="/")return"";var B=this.filename(),X=B.lastIndexOf("."),_,P;return X===-1?"":(_=B.substring(X+1),P=/^[a-z0-9%]+$/i.test(_)?_:"",E?a.decodePathSegment(P):P)}else{E.charAt(0)==="."&&(E=E.substring(1));var w=this.suffix(),z;if(w)E?z=new RegExp(d(w)+"$"):z=new RegExp(d("."+w)+"$");else{if(!E)return this;this._parts.path+="."+a.recodePath(E)}return z&&(E=a.recodePath(E),this._parts.path=this._parts.path.replace(z,E)),this.build(!I),this}},l.segment=function(E,I,B){var X=this._parts.urn?":":"/",_=this.path(),P=_.substring(0,1)==="/",w=_.split(X);if(E!==void 0&&typeof E!="number"&&(B=I,I=E,E=void 0),E!==void 0&&typeof E!="number")throw new Error('Bad segment "'+E+'", must be 0-based integer');if(P&&w.shift(),E<0&&(E=Math.max(w.length+E,0)),I===void 0)return E===void 0?w:w[E];if(E===null||w[E]===void 0)if(h(I)){w=[];for(var z=0,H=I.length;z{var uAn=R(W());/*! @license DOMPurify 3.1.2 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.1.2/LICENSE */(function(t,e){typeof Uq=="object"&&typeof Gq<"u"?Gq.exports=e():typeof define=="function"&&define.amd?define(e):(t=typeof globalThis<"u"?globalThis:t||self,t.DOMPurify=e())})(Uq,function(){"use strict";let{entries:t,setPrototypeOf:e,isFrozen:n,getPrototypeOf:i,getOwnPropertyDescriptor:o}=Object,{freeze:a,seal:s,create:l}=Object,{apply:r,construct:d}=typeof Reflect<"u"&&Reflect;a||(a=function(zt){return zt}),s||(s=function(zt){return zt}),r||(r=function(zt,ke,ue){return zt.apply(ke,ue)}),d||(d=function(zt,ke){return new zt(...ke)});let m=y(Array.prototype.forEach),h=y(Array.prototype.pop),Z=y(Array.prototype.push),b=y(String.prototype.toLowerCase),u=y(String.prototype.toString),F=y(String.prototype.match),U=y(String.prototype.replace),G=y(String.prototype.indexOf),A=y(String.prototype.trim),T=y(Object.prototype.hasOwnProperty),g=y(RegExp.prototype.test),C=Y(TypeError);function y(de){return function(zt){for(var ke=arguments.length,ue=new Array(ke>1?ke-1:0),We=1;We2&&arguments[2]!==void 0?arguments[2]:b;e&&e(de,null);let ue=zt.length;for(;ue--;){let We=zt[ue];if(typeof We=="string"){let un=ke(We);un!==We&&(n(zt)||(zt[ue]=un),We=un)}de[We]=!0}return de}function J(de){for(let zt=0;zt/gm),at=s(/\${[\w\W]*}/gm),st=s(/^data-[\-\w.\u00B7-\uFFFF]/),Et=s(/^aria-[\-\w]+$/),Qt=s(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|sms|cid|xmpp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i),Wt=s(/^(?:\w+script|data):/i),Nt=s(/[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g),kt=s(/^html$/i),Mt=s(/^[a-z][.\w]*(-[.\w]+)+$/i);var qt=Object.freeze({__proto__:null,MUSTACHE_EXPR:dt,ERB_EXPR:q,TMPLIT_EXPR:at,DATA_ATTR:st,ARIA_ATTR:Et,IS_ALLOWED_URI:Qt,IS_SCRIPT_OR_DATA:Wt,ATTR_WHITESPACE:Nt,DOCTYPE_NAME:kt,CUSTOM_ELEMENT:Mt});let ie=function(){return typeof window>"u"?null:window},oe=function(zt,ke){if(typeof zt!="object"||typeof zt.createPolicy!="function")return null;let ue=null,We="data-tt-policy-suffix";ke&&ke.hasAttribute(We)&&(ue=ke.getAttribute(We));let un="dompurify"+(ue?"#"+ue:"");try{return zt.createPolicy(un,{createHTML(Ct){return Ct},createScriptURL(Ct){return Ct}})}catch{return console.warn("TrustedTypes policy "+un+" could not be created."),null}};function He(){let de=arguments.length>0&&arguments[0]!==void 0?arguments[0]:ie(),zt=Zn=>He(Zn);if(zt.version="3.1.2",zt.removed=[],!de||!de.document||de.document.nodeType!==9)return zt.isSupported=!1,zt;let{document:ke}=de,ue=ke,We=ue.currentScript,{DocumentFragment:un,HTMLTemplateElement:Ct,Node:_t,Element:Je,NodeFilter:xe,NamedNodeMap:oo=de.NamedNodeMap||de.MozNamedAttrMap,HTMLFormElement:ea,DOMParser:gs,trustedTypes:is}=de,ja=Je.prototype,qn=V(ja,"cloneNode"),ae=V(ja,"nextSibling"),fe=V(ja,"childNodes"),ge=V(ja,"parentNode");if(typeof Ct=="function"){let Zn=ke.createElement("template");Zn.content&&Zn.content.ownerDocument&&(ke=Zn.content.ownerDocument)}let Ze,Ke="",{implementation:An,createNodeIterator:si,createDocumentFragment:da,getElementsByTagName:_a}=ke,{importNode:bl}=ue,na={};zt.isSupported=typeof t=="function"&&typeof ge=="function"&&An&&An.createHTMLDocument!==void 0;let{MUSTACHE_EXPR:Go,ERB_EXPR:Ao,TMPLIT_EXPR:Xs,DATA_ATTR:Es,ARIA_ATTR:wl,IS_SCRIPT_OR_DATA:ka,ATTR_WHITESPACE:Wa,CUSTOM_ELEMENT:Ju}=qt,{IS_ALLOWED_URI:yl}=qt,Bi=null,sd=Q({},[...E,...I,...B,..._,...w]),zi=null,js=Q({},[...z,...H,...nt,...$]),ca=Object.seal(l(null,{tagNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},attributeNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},allowCustomizedBuiltInElements:{writable:!0,configurable:!1,enumerable:!0,value:!1}})),$n=null,mr=null,hr=!0,pr=!0,hs=!1,ma=!0,Ed=!1,BW=!0,Rc=!1,$b=!1,Zp=!1,Lu=!1,QW=!1,tR=!1,kW=!0,YW=!1,pg="user-content-",MU=!0,lh=!1,Vp={},lm=null,_U=Q({},["annotation-xml","audio","colgroup","desc","foreignobject","head","iframe","math","mi","mn","mo","ms","mtext","noembed","noframes","noscript","plaintext","script","style","svg","template","thead","title","video","xmp"]),DU=null,Mu=Q({},["audio","video","img","source","image","track"]),eR=null,ug=Q({},["alt","class","for","id","label","name","pattern","placeholder","role","summary","title","value","style","xmlns"]),bp="http://www.w3.org/1998/Math/MathML",Rp="http://www.w3.org/2000/svg",kr="http://www.w3.org/1999/xhtml",fV=kr,xW=!1,XW=null,OU=Q({},[bp,Rp,kr],u),nR=null,rh=["application/xhtml+xml","text/html"],HU="text/html",Js=null,ld=null,iR=255,wU=ke.createElement("form"),PU=function(Kt){return Kt instanceof RegExp||Kt instanceof Function},JW=function(){let Kt=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};if(!(ld&&ld===Kt)){if((!Kt||typeof Kt!="object")&&(Kt={}),Kt=M(Kt),nR=rh.indexOf(Kt.PARSER_MEDIA_TYPE)===-1?HU:Kt.PARSER_MEDIA_TYPE,Js=nR==="application/xhtml+xml"?u:b,Bi=T(Kt,"ALLOWED_TAGS")?Q({},Kt.ALLOWED_TAGS,Js):sd,zi=T(Kt,"ALLOWED_ATTR")?Q({},Kt.ALLOWED_ATTR,Js):js,XW=T(Kt,"ALLOWED_NAMESPACES")?Q({},Kt.ALLOWED_NAMESPACES,u):OU,eR=T(Kt,"ADD_URI_SAFE_ATTR")?Q(M(ug),Kt.ADD_URI_SAFE_ATTR,Js):ug,DU=T(Kt,"ADD_DATA_URI_TAGS")?Q(M(Mu),Kt.ADD_DATA_URI_TAGS,Js):Mu,lm=T(Kt,"FORBID_CONTENTS")?Q({},Kt.FORBID_CONTENTS,Js):_U,$n=T(Kt,"FORBID_TAGS")?Q({},Kt.FORBID_TAGS,Js):{},mr=T(Kt,"FORBID_ATTR")?Q({},Kt.FORBID_ATTR,Js):{},Vp=T(Kt,"USE_PROFILES")?Kt.USE_PROFILES:!1,hr=Kt.ALLOW_ARIA_ATTR!==!1,pr=Kt.ALLOW_DATA_ATTR!==!1,hs=Kt.ALLOW_UNKNOWN_PROTOCOLS||!1,ma=Kt.ALLOW_SELF_CLOSE_IN_ATTR!==!1,Ed=Kt.SAFE_FOR_TEMPLATES||!1,BW=Kt.SAFE_FOR_XML!==!1,Rc=Kt.WHOLE_DOCUMENT||!1,Lu=Kt.RETURN_DOM||!1,QW=Kt.RETURN_DOM_FRAGMENT||!1,tR=Kt.RETURN_TRUSTED_TYPE||!1,Zp=Kt.FORCE_BODY||!1,kW=Kt.SANITIZE_DOM!==!1,YW=Kt.SANITIZE_NAMED_PROPS||!1,MU=Kt.KEEP_CONTENT!==!1,lh=Kt.IN_PLACE||!1,yl=Kt.ALLOWED_URI_REGEXP||Qt,fV=Kt.NAMESPACE||kr,ca=Kt.CUSTOM_ELEMENT_HANDLING||{},Kt.CUSTOM_ELEMENT_HANDLING&&PU(Kt.CUSTOM_ELEMENT_HANDLING.tagNameCheck)&&(ca.tagNameCheck=Kt.CUSTOM_ELEMENT_HANDLING.tagNameCheck),Kt.CUSTOM_ELEMENT_HANDLING&&PU(Kt.CUSTOM_ELEMENT_HANDLING.attributeNameCheck)&&(ca.attributeNameCheck=Kt.CUSTOM_ELEMENT_HANDLING.attributeNameCheck),Kt.CUSTOM_ELEMENT_HANDLING&&typeof Kt.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements=="boolean"&&(ca.allowCustomizedBuiltInElements=Kt.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements),Ed&&(pr=!1),QW&&(Lu=!0),Vp&&(Bi=Q({},w),zi=[],Vp.html===!0&&(Q(Bi,E),Q(zi,z)),Vp.svg===!0&&(Q(Bi,I),Q(zi,H),Q(zi,$)),Vp.svgFilters===!0&&(Q(Bi,B),Q(zi,H),Q(zi,$)),Vp.mathMl===!0&&(Q(Bi,_),Q(zi,nt),Q(zi,$))),Kt.ADD_TAGS&&(Bi===sd&&(Bi=M(Bi)),Q(Bi,Kt.ADD_TAGS,Js)),Kt.ADD_ATTR&&(zi===js&&(zi=M(zi)),Q(zi,Kt.ADD_ATTR,Js)),Kt.ADD_URI_SAFE_ATTR&&Q(eR,Kt.ADD_URI_SAFE_ATTR,Js),Kt.FORBID_CONTENTS&&(lm===_U&&(lm=M(lm)),Q(lm,Kt.FORBID_CONTENTS,Js)),MU&&(Bi["#text"]=!0),Rc&&Q(Bi,["html","head","body"]),Bi.table&&(Q(Bi,["tbody"]),delete $n.tbody),Kt.TRUSTED_TYPES_POLICY){if(typeof Kt.TRUSTED_TYPES_POLICY.createHTML!="function")throw C('TRUSTED_TYPES_POLICY configuration option must provide a "createHTML" hook.');if(typeof Kt.TRUSTED_TYPES_POLICY.createScriptURL!="function")throw C('TRUSTED_TYPES_POLICY configuration option must provide a "createScriptURL" hook.');Ze=Kt.TRUSTED_TYPES_POLICY,Ke=Ze.createHTML("")}else Ze===void 0&&(Ze=oe(is,We)),Ze!==null&&typeof Ke=="string"&&(Ke=Ze.createHTML(""));a&&a(Kt),ld=Kt}},FV=Q({},["mi","mo","mn","ms","mtext"]),vU=Q({},["foreignobject","annotation-xml"]),Zg=Q({},["title","style","font","a","script"]),Vg=Q({},[...I,...B,...X]),oR=Q({},[..._,...P]),SN=function(Kt){let De=ge(Kt);(!De||!De.tagName)&&(De={namespaceURI:fV,tagName:"template"});let ti=b(Kt.tagName),Hi=b(De.tagName);return XW[Kt.namespaceURI]?Kt.namespaceURI===Rp?De.namespaceURI===kr?ti==="svg":De.namespaceURI===bp?ti==="svg"&&(Hi==="annotation-xml"||FV[Hi]):!!Vg[ti]:Kt.namespaceURI===bp?De.namespaceURI===kr?ti==="math":De.namespaceURI===Rp?ti==="math"&&vU[Hi]:!!oR[ti]:Kt.namespaceURI===kr?De.namespaceURI===Rp&&!vU[Hi]||De.namespaceURI===bp&&!FV[Hi]?!1:!oR[ti]&&(Zg[ti]||!Vg[ti]):!!(nR==="application/xhtml+xml"&&XW[Kt.namespaceURI]):!1},Cd=function(Kt){Z(zt.removed,{element:Kt});try{Kt.parentNode.removeChild(Kt)}catch{Kt.remove()}},KU=function(Kt,De){try{Z(zt.removed,{attribute:De.getAttributeNode(Kt),from:De})}catch{Z(zt.removed,{attribute:null,from:De})}if(De.removeAttribute(Kt),Kt==="is"&&!zi[Kt])if(Lu||QW)try{Cd(De)}catch{}else try{De.setAttribute(Kt,"")}catch{}},bg=function(Kt){let De=null,ti=null;if(Zp)Kt=""+Kt;else{let Pl=F(Kt,/^[\r\n\t ]+/);ti=Pl&&Pl[0]}nR==="application/xhtml+xml"&&fV===kr&&(Kt=''+Kt+"");let Hi=Ze?Ze.createHTML(Kt):Kt;if(fV===kr)try{De=new gs().parseFromString(Hi,nR)}catch{}if(!De||!De.documentElement){De=An.createDocument(fV,"template",null);try{De.documentElement.innerHTML=xW?Ke:Hi}catch{}}let Rl=De.body||De.documentElement;return Kt&&ti&&Rl.insertBefore(ke.createTextNode(ti),Rl.childNodes[0]||null),fV===kr?_a.call(De,Rc?"html":"body")[0]:Rc?De.documentElement:Rl},rm=function(Kt){return si.call(Kt.ownerDocument||Kt,Kt,xe.SHOW_ELEMENT|xe.SHOW_COMMENT|xe.SHOW_TEXT|xe.SHOW_PROCESSING_INSTRUCTION|xe.SHOW_CDATA_SECTION,null)},Rg=function(Kt){return Kt instanceof ea&&(typeof Kt.__depth<"u"&&typeof Kt.__depth!="number"||typeof Kt.__removalCount<"u"&&typeof Kt.__removalCount!="number"||typeof Kt.nodeName!="string"||typeof Kt.textContent!="string"||typeof Kt.removeChild!="function"||!(Kt.attributes instanceof oo)||typeof Kt.removeAttribute!="function"||typeof Kt.setAttribute!="function"||typeof Kt.namespaceURI!="string"||typeof Kt.insertBefore!="function"||typeof Kt.hasChildNodes!="function")},LW=function(Kt){return typeof _t=="function"&&Kt instanceof _t},Id=function(Kt,De,ti){na[Kt]&&m(na[Kt],Hi=>{Hi.call(zt,De,ti,ld)})},MW=function(Kt){let De=null;if(Id("beforeSanitizeElements",Kt,null),Rg(Kt))return Cd(Kt),!0;let ti=Js(Kt.nodeName);if(Id("uponSanitizeElement",Kt,{tagName:ti,allowedTags:Bi}),Kt.hasChildNodes()&&!LW(Kt.firstElementChild)&&g(/<[/\w]/g,Kt.innerHTML)&&g(/<[/\w]/g,Kt.textContent)||Kt.nodeType===7||BW&&Kt.nodeType===8&&g(/<[/\w]/g,Kt.data))return Cd(Kt),!0;if(!Bi[ti]||$n[ti]){if(!$n[ti]&&fg(ti)&&(ca.tagNameCheck instanceof RegExp&&g(ca.tagNameCheck,ti)||ca.tagNameCheck instanceof Function&&ca.tagNameCheck(ti)))return!1;if(MU&&!lm[ti]){let Hi=ge(Kt)||Kt.parentNode,Rl=fe(Kt)||Kt.childNodes;if(Rl&&Hi){let Pl=Rl.length;for(let Bl=Pl-1;Bl>=0;--Bl){let Yr=qn(Rl[Bl],!0);Yr.__removalCount=(Kt.__removalCount||0)+1,Hi.insertBefore(Yr,ae(Kt))}}}return Cd(Kt),!0}return Kt instanceof Je&&!SN(Kt)||(ti==="noscript"||ti==="noembed"||ti==="noframes")&&g(/<\/no(script|embed|frames)/i,Kt.innerHTML)?(Cd(Kt),!0):(Ed&&Kt.nodeType===3&&(De=Kt.textContent,m([Go,Ao,Xs],Hi=>{De=U(De,Hi," ")}),Kt.textContent!==De&&(Z(zt.removed,{element:Kt.cloneNode()}),Kt.textContent=De)),Id("afterSanitizeElements",Kt,null),!1)},Wg=function(Kt,De,ti){if(kW&&(De==="id"||De==="name")&&(ti in ke||ti in wU))return!1;if(!(pr&&!mr[De]&&g(Es,De))){if(!(hr&&g(wl,De))){if(!zi[De]||mr[De]){if(!(fg(Kt)&&(ca.tagNameCheck instanceof RegExp&&g(ca.tagNameCheck,Kt)||ca.tagNameCheck instanceof Function&&ca.tagNameCheck(Kt))&&(ca.attributeNameCheck instanceof RegExp&&g(ca.attributeNameCheck,De)||ca.attributeNameCheck instanceof Function&&ca.attributeNameCheck(De))||De==="is"&&ca.allowCustomizedBuiltInElements&&(ca.tagNameCheck instanceof RegExp&&g(ca.tagNameCheck,ti)||ca.tagNameCheck instanceof Function&&ca.tagNameCheck(ti))))return!1}else if(!eR[De]){if(!g(yl,U(ti,Wa,""))){if(!((De==="src"||De==="xlink:href"||De==="href")&&Kt!=="script"&&G(ti,"data:")===0&&DU[Kt])){if(!(hs&&!g(ka,U(ti,Wa,"")))){if(ti)return!1}}}}}}return!0},fg=function(Kt){return Kt!=="annotation-xml"&&F(Kt,Ju)},dm=function(Kt){Id("beforeSanitizeAttributes",Kt,null);let{attributes:De}=Kt;if(!De)return;let ti={attrName:"",attrValue:"",keepAttr:!0,allowedAttributes:zi},Hi=De.length;for(;Hi--;){let Rl=De[Hi],{name:Pl,namespaceURI:Bl,value:Yr}=Rl,ps=Js(Pl),Ql=Pl==="value"?Yr:A(Yr);if(ti.attrName=ps,ti.attrValue=Ql,ti.keepAttr=!0,ti.forceKeepAttr=void 0,Id("uponSanitizeAttribute",Kt,ti),Ql=ti.attrValue,ti.forceKeepAttr||(KU(Pl,Kt),!ti.keepAttr))continue;if(!ma&&g(/\/>/i,Ql)){KU(Pl,Kt);continue}Ed&&m([Go,Ao,Xs],zU=>{Ql=U(Ql,zU," ")});let Wp=Js(Kt.nodeName);if(Wg(Wp,ps,Ql)){if(YW&&(ps==="id"||ps==="name")&&(KU(Pl,Kt),Ql=pg+Ql),Ze&&typeof is=="object"&&typeof is.getAttributeType=="function"&&!Bl)switch(is.getAttributeType(Wp,ps)){case"TrustedHTML":{Ql=Ze.createHTML(Ql);break}case"TrustedScriptURL":{Ql=Ze.createScriptURL(Ql);break}}try{Bl?Kt.setAttributeNS(Bl,Pl,Ql):Kt.setAttribute(Pl,Ql),h(zt.removed)}catch{}}}Id("afterSanitizeAttributes",Kt,null)},Da=function Zn(Kt){let De=null,ti=rm(Kt);for(Id("beforeSanitizeShadowDOM",Kt,null);De=ti.nextNode();){if(Id("uponSanitizeShadowNode",De,null),MW(De))continue;let Hi=ge(De);De.nodeType===1&&(Hi&&Hi.__depth?De.__depth=(De.__removalCount||0)+Hi.__depth+1:De.__depth=1),De.__depth>=iR&&Cd(De),De.content instanceof un&&(De.content.__depth=De.__depth,Zn(De.content)),dm(De)}Id("afterSanitizeShadowDOM",Kt,null)};return zt.sanitize=function(Zn){let Kt=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},De=null,ti=null,Hi=null,Rl=null;if(xW=!Zn,xW&&(Zn=""),typeof Zn!="string"&&!LW(Zn))if(typeof Zn.toString=="function"){if(Zn=Zn.toString(),typeof Zn!="string")throw C("dirty is not a string, aborting")}else throw C("toString is not a function");if(!zt.isSupported)return Zn;if($b||JW(Kt),zt.removed=[],typeof Zn=="string"&&(lh=!1),lh){if(Zn.nodeName){let Yr=Js(Zn.nodeName);if(!Bi[Yr]||$n[Yr])throw C("root node is forbidden and cannot be sanitized in-place")}}else if(Zn instanceof _t)De=bg(""),ti=De.ownerDocument.importNode(Zn,!0),ti.nodeType===1&&ti.nodeName==="BODY"||ti.nodeName==="HTML"?De=ti:De.appendChild(ti);else{if(!Lu&&!Ed&&!Rc&&Zn.indexOf("<")===-1)return Ze&&tR?Ze.createHTML(Zn):Zn;if(De=bg(Zn),!De)return Lu?null:tR?Ke:""}De&&Zp&&Cd(De.firstChild);let Pl=rm(lh?Zn:De);for(;Hi=Pl.nextNode();){if(MW(Hi))continue;let Yr=ge(Hi);Hi.nodeType===1&&(Yr&&Yr.__depth?Hi.__depth=(Hi.__removalCount||0)+Yr.__depth+1:Hi.__depth=1),Hi.__depth>=iR&&Cd(Hi),Hi.content instanceof un&&(Hi.content.__depth=Hi.__depth,Da(Hi.content)),dm(Hi)}if(lh)return Zn;if(Lu){if(QW)for(Rl=da.call(De.ownerDocument);De.firstChild;)Rl.appendChild(De.firstChild);else Rl=De;return(zi.shadowroot||zi.shadowrootmode)&&(Rl=bl.call(ue,Rl,!0)),Rl}let Bl=Rc?De.outerHTML:De.innerHTML;return Rc&&Bi["!doctype"]&&De.ownerDocument&&De.ownerDocument.doctype&&De.ownerDocument.doctype.name&&g(kt,De.ownerDocument.doctype.name)&&(Bl=" -`+Bl),Ed&&m([Go,Ao,Xs],Yr=>{Bl=U(Bl,Yr," ")}),Ze&&tR?Ze.createHTML(Bl):Bl},zt.setConfig=function(){let Zn=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};JW(Zn),$b=!0},zt.clearConfig=function(){ld=null,$b=!1},zt.isValidAttribute=function(Zn,Kt,De){ld||JW({});let ti=Js(Zn),Hi=Js(Kt);return Wg(ti,Hi,De)},zt.addHook=function(Zn,Kt){typeof Kt=="function"&&(na[Zn]=na[Zn]||[],Z(na[Zn],Kt))},zt.removeHook=function(Zn){if(na[Zn])return h(na[Zn])},zt.removeHooks=function(Zn){na[Zn]&&(na[Zn]=[])},zt.removeAllHooks=function(){na={}},zt}var rn=He();return rn})});var qbt=Vo((Gkn,r$)=>{"use strict";var Akn=R(W());r$.exports=Yw;r$.exports.default=Yw;function Yw(t,e,n){n=n||2;var i=e&&e.length,o=i?e[0]*n:t.length,a=Kbt(t,0,o,n,!0),s=[];if(!a||a.next===a.prev)return s;var l,r,d,m,h,Z,b;if(i&&(a=Jqt(t,e,a,n)),t.length>80*n){l=d=t[0],r=m=t[1];for(var u=n;ud&&(d=h),Z>m&&(m=Z);b=Math.max(d-l,m-r),b=b!==0?32767/b:0}return lY(a,s,n,l,r,b,0),s}function Kbt(t,e,n,i,o){var a,s;if(o===l$(t,e,n,i)>0)for(a=e;a=e;a-=i)s=vbt(a,t[a],t[a+1],s);return s&&xw(s,s.next)&&(dY(s),s=s.next),s}function SA(t,e){if(!t)return t;e||(e=t);var n=t,i;do if(i=!1,!n.steiner&&(xw(n,n.next)||ol(n.prev,n,n.next)===0)){if(dY(n),n=e=n.prev,n===n.next)break;i=!0}else n=n.next;while(i||n!==e);return e}function lY(t,e,n,i,o,a,s){if(t){!s&&a&&Oqt(t,i,o,a);for(var l=t,r,d;t.prev!==t.next;){if(r=t.prev,d=t.next,a?Yqt(t,i,o,a):kqt(t)){e.push(r.i/n|0),e.push(t.i/n|0),e.push(d.i/n|0),dY(t),t=d.next,l=d.next;continue}if(t=d,t===l){s?s===1?(t=xqt(SA(t),e,n),lY(t,e,n,i,o,a,2)):s===2&&Xqt(t,e,n,i,o,a):lY(SA(t),e,n,i,o,a,1);break}}}}function kqt(t){var e=t.prev,n=t,i=t.next;if(ol(e,n,i)>=0)return!1;for(var o=e.x,a=n.x,s=i.x,l=e.y,r=n.y,d=i.y,m=oa?o>s?o:s:a>s?a:s,b=l>r?l>d?l:d:r>d?r:d,u=i.next;u!==e;){if(u.x>=m&&u.x<=Z&&u.y>=h&&u.y<=b&&HE(o,l,a,r,s,d,u.x,u.y)&&ol(u.prev,u,u.next)>=0)return!1;u=u.next}return!0}function Yqt(t,e,n,i){var o=t.prev,a=t,s=t.next;if(ol(o,a,s)>=0)return!1;for(var l=o.x,r=a.x,d=s.x,m=o.y,h=a.y,Z=s.y,b=lr?l>d?l:d:r>d?r:d,U=m>h?m>Z?m:Z:h>Z?h:Z,G=a$(b,u,e,n,i),A=a$(F,U,e,n,i),T=t.prevZ,g=t.nextZ;T&&T.z>=G&&g&&g.z<=A;){if(T.x>=b&&T.x<=F&&T.y>=u&&T.y<=U&&T!==o&&T!==s&&HE(l,m,r,h,d,Z,T.x,T.y)&&ol(T.prev,T,T.next)>=0||(T=T.prevZ,g.x>=b&&g.x<=F&&g.y>=u&&g.y<=U&&g!==o&&g!==s&&HE(l,m,r,h,d,Z,g.x,g.y)&&ol(g.prev,g,g.next)>=0))return!1;g=g.nextZ}for(;T&&T.z>=G;){if(T.x>=b&&T.x<=F&&T.y>=u&&T.y<=U&&T!==o&&T!==s&&HE(l,m,r,h,d,Z,T.x,T.y)&&ol(T.prev,T,T.next)>=0)return!1;T=T.prevZ}for(;g&&g.z<=A;){if(g.x>=b&&g.x<=F&&g.y>=u&&g.y<=U&&g!==o&&g!==s&&HE(l,m,r,h,d,Z,g.x,g.y)&&ol(g.prev,g,g.next)>=0)return!1;g=g.nextZ}return!0}function xqt(t,e,n){var i=t;do{var o=i.prev,a=i.next.next;!xw(o,a)&&zbt(o,i,i.next,a)&&rY(o,a)&&rY(a,o)&&(e.push(o.i/n|0),e.push(i.i/n|0),e.push(a.i/n|0),dY(i),dY(i.next),i=t=a),i=i.next}while(i!==t);return SA(i)}function Xqt(t,e,n,i,o,a){var s=t;do{for(var l=s.next.next;l!==s.prev;){if(s.i!==l.i&&Pqt(s,l)){var r=jbt(s,l);s=SA(s,s.next),r=SA(r,r.next),lY(s,e,n,i,o,a,0),lY(r,e,n,i,o,a,0);return}l=l.next}s=s.next}while(s!==t)}function Jqt(t,e,n,i){var o=[],a,s,l,r,d;for(a=0,s=e.length;a=n.next.y&&n.next.y!==n.y){var l=n.x+(o-n.y)*(n.next.x-n.x)/(n.next.y-n.y);if(l<=i&&l>a&&(a=l,s=n.x=n.x&&n.x>=d&&i!==n.x&&HE(os.x||n.x===s.x&&Dqt(s,n)))&&(s=n,h=Z)),n=n.next;while(n!==r);return s}function Dqt(t,e){return ol(t.prev,t,e.prev)<0&&ol(e.next,t,t.next)<0}function Oqt(t,e,n,i){var o=t;do o.z===0&&(o.z=a$(o.x,o.y,e,n,i)),o.prevZ=o.prev,o.nextZ=o.next,o=o.next;while(o!==t);o.prevZ.nextZ=null,o.prevZ=null,Hqt(o)}function Hqt(t){var e,n,i,o,a,s,l,r,d=1;do{for(n=t,t=null,a=null,s=0;n;){for(s++,i=n,l=0,e=0;e0||r>0&&i;)l!==0&&(r===0||!i||n.z<=i.z)?(o=n,n=n.nextZ,l--):(o=i,i=i.nextZ,r--),a?a.nextZ=o:t=o,o.prevZ=a,a=o;n=i}a.nextZ=null,d*=2}while(s>1);return t}function a$(t,e,n,i,o){return t=(t-n)*o|0,e=(e-i)*o|0,t=(t|t<<8)&16711935,t=(t|t<<4)&252645135,t=(t|t<<2)&858993459,t=(t|t<<1)&1431655765,e=(e|e<<8)&16711935,e=(e|e<<4)&252645135,e=(e|e<<2)&858993459,e=(e|e<<1)&1431655765,t|e<<1}function wqt(t){var e=t,n=t;do(e.x=(t-s)*(a-l)&&(t-s)*(i-l)>=(n-s)*(e-l)&&(n-s)*(a-l)>=(o-s)*(i-l)}function Pqt(t,e){return t.next.i!==e.i&&t.prev.i!==e.i&&!vqt(t,e)&&(rY(t,e)&&rY(e,t)&&Kqt(t,e)&&(ol(t.prev,t,e.prev)||ol(t,e.prev,e))||xw(t,e)&&ol(t.prev,t,t.next)>0&&ol(e.prev,e,e.next)>0)}function ol(t,e,n){return(e.y-t.y)*(n.x-e.x)-(e.x-t.x)*(n.y-e.y)}function xw(t,e){return t.x===e.x&&t.y===e.y}function zbt(t,e,n,i){var o=kw(ol(t,e,n)),a=kw(ol(t,e,i)),s=kw(ol(n,i,t)),l=kw(ol(n,i,e));return!!(o!==a&&s!==l||o===0&&Qw(t,n,e)||a===0&&Qw(t,i,e)||s===0&&Qw(n,t,i)||l===0&&Qw(n,e,i))}function Qw(t,e,n){return e.x<=Math.max(t.x,n.x)&&e.x>=Math.min(t.x,n.x)&&e.y<=Math.max(t.y,n.y)&&e.y>=Math.min(t.y,n.y)}function kw(t){return t>0?1:t<0?-1:0}function vqt(t,e){var n=t;do{if(n.i!==t.i&&n.next.i!==t.i&&n.i!==e.i&&n.next.i!==e.i&&zbt(n,n.next,t,e))return!0;n=n.next}while(n!==t);return!1}function rY(t,e){return ol(t.prev,t,t.next)<0?ol(t,e,t.next)>=0&&ol(t,t.prev,e)>=0:ol(t,e,t.prev)<0||ol(t,t.next,e)<0}function Kqt(t,e){var n=t,i=!1,o=(t.x+e.x)/2,a=(t.y+e.y)/2;do n.y>a!=n.next.y>a&&n.next.y!==n.y&&o<(n.next.x-n.x)*(a-n.y)/(n.next.y-n.y)+n.x&&(i=!i),n=n.next;while(n!==t);return i}function jbt(t,e){var n=new s$(t.i,t.x,t.y),i=new s$(e.i,e.x,e.y),o=t.next,a=e.prev;return t.next=e,e.prev=t,n.next=o,o.prev=n,i.next=n,n.prev=i,a.next=i,i.prev=a,i}function vbt(t,e,n,i){var o=new s$(t,e,n);return i?(o.next=i.next,o.prev=i,i.next.prev=o,i.next=o):(o.prev=o,o.next=o),o}function dY(t){t.next.prev=t.prev,t.prev.next=t.next,t.prevZ&&(t.prevZ.nextZ=t.nextZ),t.nextZ&&(t.nextZ.prevZ=t.prevZ)}function s$(t,e,n){this.i=t,this.x=e,this.y=n,this.prev=null,this.next=null,this.z=0,this.prevZ=null,this.nextZ=null,this.steiner=!1}Yw.deviation=function(t,e,n,i){var o=e&&e.length,a=o?e[0]*n:t.length,s=Math.abs(l$(t,0,a,n));if(o)for(var l=0,r=e.length;l0&&(i+=t[o-1].length,n.holes.push(i))}return n}});var oft=Vo((i7n,ift)=>{"use strict";var o7n=R(W());ift.exports=ure;var FX=1e20;function ure(t,e){e||(e={});var n=e.cutoff==null?.25:e.cutoff,i=e.radius==null?8:e.radius,o=e.channel||0,a,s,l,r,d,m,h,Z,b,u,F;if(ArrayBuffer.isView(t)||Array.isArray(t)){if(!e.width||!e.height)throw Error("For raw data width and height should be provided by options");a=e.width,s=e.height,r=t,e.stride?m=e.stride:m=Math.floor(t.length/a/s)}else window.HTMLCanvasElement&&t instanceof window.HTMLCanvasElement?(Z=t,h=Z.getContext("2d"),a=Z.width,s=Z.height,b=h.getImageData(0,0,a,s),r=b.data,m=4):window.CanvasRenderingContext2D&&t instanceof window.CanvasRenderingContext2D?(Z=t.canvas,h=t,a=Z.width,s=Z.height,b=h.getImageData(0,0,a,s),r=b.data,m=4):window.ImageData&&t instanceof window.ImageData&&(b=t,a=t.width,s=t.height,r=b.data,m=4);if(l=Math.max(a,s),window.Uint8ClampedArray&&r instanceof window.Uint8ClampedArray||window.Uint8Array&&r instanceof window.Uint8Array)for(d=r,r=Array(a*s),u=0,F=Math.floor(d.length/m);u{var A7n=R(W());function Tre(){var t=0,e=1,n=2,i=3,o=4,a=5,s=6,l=7,r=8,d=9,m=10,h=11,Z=12,b=13,u=14,F=15,U=16,G=17,A=0,T=1,g=2,C=3,y=4;function Y(V,E){return 55296<=V.charCodeAt(E)&&V.charCodeAt(E)<=56319&&56320<=V.charCodeAt(E+1)&&V.charCodeAt(E+1)<=57343}function Q(V,E){E===void 0&&(E=0);var I=V.charCodeAt(E);if(55296<=I&&I<=56319&&E=1){var B=V.charCodeAt(E-1),X=I;return 55296<=B&&B<=56319?(B-55296)*1024+(X-56320)+65536:X}return I}function J(V,E,I){var B=[V].concat(E).concat([I]),X=B[B.length-2],_=I,P=B.lastIndexOf(u);if(P>1&&B.slice(1,P).every(function(H){return H==i})&&[i,b,G].indexOf(V)==-1)return g;var w=B.lastIndexOf(o);if(w>0&&B.slice(1,w).every(function(H){return H==o})&&[Z,o].indexOf(X)==-1)return B.filter(function(H){return H==o}).length%2==1?C:y;if(X==t&&_==e)return A;if(X==n||X==t||X==e)return _==u&&E.every(function(H){return H==i})?g:T;if(_==n||_==t||_==e)return T;if(X==s&&(_==s||_==l||_==d||_==m))return A;if((X==d||X==l)&&(_==l||_==r))return A;if((X==m||X==r)&&_==r)return A;if(_==i||_==F)return A;if(_==a)return A;if(X==Z)return A;var z=B.indexOf(i)!=-1?B.lastIndexOf(i)-1:B.length-2;return[b,G].indexOf(B[z])!=-1&&B.slice(z+1,-1).every(function(H){return H==i})&&_==u||X==F&&[U,G].indexOf(_)!=-1?A:E.indexOf(o)!=-1?g:X==o&&_==o?A:T}this.nextBreak=function(V,E){if(E===void 0&&(E=0),E<0)return 0;if(E>=V.length-1)return V.length;for(var I=M(Q(V,E)),B=[],X=E+1;X{var $gi=R(W());(function(t,e){typeof wet=="object"&&typeof Pet<"u"?Pet.exports=e():typeof define=="function"&&define.amd?define(e):(t=t||self).RBush=e()})(wet,function(){"use strict";function t(U,G,A,T,g){(function C(y,Y,Q,J,M){for(;J>Q;){if(J-Q>600){var V=J-Q+1,E=Y-Q+1,I=Math.log(V),B=.5*Math.exp(2*I/3),X=.5*Math.sqrt(I*B*(V-B)/V)*(E-V/2<0?-1:1),_=Math.max(Q,Math.floor(Y-E*B/V+X)),P=Math.min(J,Math.floor(Y+(V-E)*B/V+X));C(y,Y,_,P,M)}var w=y[Y],z=Q,H=J;for(e(y,Q,Y),M(y[J],w)>0&&e(y,Q,J);z0;)H--}M(y[Q],w)===0?e(y,Q,H):e(y,++H,J),H<=Y&&(Q=H+1),Y<=H&&(J=H-1)}})(U,G,A||0,T||U.length-1,g||n)}function e(U,G,A){var T=U[G];U[G]=U[A],U[A]=T}function n(U,G){return UG?1:0}var i=function(U){U===void 0&&(U=9),this._maxEntries=Math.max(4,U),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()};function o(U,G,A){if(!A)return G.indexOf(U);for(var T=0;T=U.minX&&G.maxY>=U.minY}function u(U){return{children:U,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function F(U,G,A,T,g){for(var C=[G,A];C.length;)if(!((A=C.pop())-(G=C.pop())<=T)){var y=G+Math.ceil((A-G)/T/2)*T;t(U,y,G,A,g),C.push(G,y,y,A)}}return i.prototype.all=function(){return this._all(this.data,[])},i.prototype.search=function(U){var G=this.data,A=[];if(!b(U,G))return A;for(var T=this.toBBox,g=[];G;){for(var C=0;C=0&&g[G].children.length>this._maxEntries;)this._split(g,G),G--;this._adjustParentBBoxes(T,g,G)},i.prototype._split=function(U,G){var A=U[G],T=A.children.length,g=this._minEntries;this._chooseSplitAxis(A,g,T);var C=this._chooseSplitIndex(A,g,T),y=u(A.children.splice(C,A.children.length-C));y.height=A.height,y.leaf=A.leaf,a(A,this.toBBox),a(y,this.toBBox),G?U[G-1].children.push(y):this._splitRoot(A,y)},i.prototype._splitRoot=function(U,G){this.data=u([U,G]),this.data.height=U.height+1,this.data.leaf=!1,a(this.data,this.toBBox)},i.prototype._chooseSplitIndex=function(U,G,A){for(var T,g,C,y,Y,Q,J,M=1/0,V=1/0,E=G;E<=A-G;E++){var I=s(U,0,E,this.toBBox),B=s(U,E,A,this.toBBox),X=(g=I,C=B,y=void 0,Y=void 0,Q=void 0,J=void 0,y=Math.max(g.minX,C.minX),Y=Math.max(g.minY,C.minY),Q=Math.min(g.maxX,C.maxX),J=Math.min(g.maxY,C.maxY),Math.max(0,Q-y)*Math.max(0,J-Y)),_=m(I)+m(B);X=G;M--){var V=U.children[M];l(y,U.leaf?g(V):V),Y+=h(y)}return Y},i.prototype._adjustParentBBoxes=function(U,G,A){for(var T=A;T>=0;T--)l(G[T],U)},i.prototype._condense=function(U){for(var G=U.length-1,A=void 0;G>=0;G--)U[G].children.length===0?G>0?(A=U[G-1].children).splice(A.indexOf(U[G]),1):this.clear():a(U[G],this.toBBox)},i})});var zEt=Vo((DI,oM)=>{var AJi=R(W());/** + */(function(t,e){"use strict";typeof RH=="object"&&RH.exports?RH.exports=e(Rmt(),Wmt(),Fmt()):typeof define=="function"&&define.amd?define(["./punycode","./IPv6","./SecondLevelDomains"],e):t.URI=e(t.punycode,t.IPv6,t.SecondLevelDomains,t)})(Umt,function(t,e,n,i){"use strict";var o=i&&i.URI;function a(E,I){var B=arguments.length>=1,X=arguments.length>=2;if(!(this instanceof a))return B?X?new a(E,I):new a(E):new a;if(E===void 0){if(B)throw new TypeError("undefined is not a valid argument for URI");typeof location<"u"?E=location.href+"":E=""}if(E===null&&B)throw new TypeError("null is not a valid argument for URI");return this.href(E),I!==void 0?this.absoluteTo(I):this}function s(E){return/^[0-9]+$/.test(E)}a.version="1.19.11";var l=a.prototype,r=Object.prototype.hasOwnProperty;function d(E){return E.replace(/([.*+?^=!:${}()|[\]\/\\])/g,"\\$1")}function m(E){return E===void 0?"Undefined":String(Object.prototype.toString.call(E)).slice(8,-1)}function h(E){return m(E)==="Array"}function u(E,I){var B={},X,_;if(m(I)==="RegExp")B=null;else if(h(I))for(X=0,_=I.length;X<_;X++)B[I[X]]=!0;else B[I]=!0;for(X=0,_=E.length;X<_;X++){var P=B&&B[E[X]]!==void 0||!B&&I.test(E[X]);P&&(E.splice(X,1),_--,X--)}return E}function R(E,I){var B,X;if(h(I)){for(B=0,X=I.length;B]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))/ig,a.findUri={start:/\b(?:([a-z][a-z0-9.+-]*:\/\/)|www\.)/gi,end:/[\s\r\n]|$/,trim:/[`!()\[\]{};:'".,<>?«»“”„‘’]+$/,parens:/(\([^\)]*\)|\[[^\]]*\]|\{[^}]*\}|<[^>]*>)/g},a.leading_whitespace_expression=/^[\x00-\x20\u00a0\u1680\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff]+/,a.ascii_tab_whitespace=/[\u0009\u000A\u000D]+/g,a.defaultPorts={http:"80",https:"443",ftp:"21",gopher:"70",ws:"80",wss:"443"},a.hostProtocols=["http","https"],a.invalid_hostname_characters=/[^a-zA-Z0-9\.\-:_]/,a.domAttributes={a:"href",blockquote:"cite",link:"href",base:"href",script:"src",form:"action",img:"src",area:"href",iframe:"src",embed:"src",source:"src",track:"src",input:"src",audio:"src",video:"src"},a.getDomAttribute=function(E){if(!(!E||!E.nodeName)){var I=E.nodeName.toLowerCase();if(!(I==="input"&&E.type!=="image"))return a.domAttributes[I]}};function U(E){return escape(E)}function G(E){return encodeURIComponent(E).replace(/[!'()*]/g,U).replace(/\*/g,"%2A")}a.encode=G,a.decode=decodeURIComponent,a.iso8859=function(){a.encode=escape,a.decode=unescape},a.unicode=function(){a.encode=G,a.decode=decodeURIComponent},a.characters={pathname:{encode:{expression:/%(24|26|2B|2C|3B|3D|3A|40)/ig,map:{"%24":"$","%26":"&","%2B":"+","%2C":",","%3B":";","%3D":"=","%3A":":","%40":"@"}},decode:{expression:/[\/\?#]/g,map:{"/":"%2F","?":"%3F","#":"%23"}}},reserved:{encode:{expression:/%(21|23|24|26|27|28|29|2A|2B|2C|2F|3A|3B|3D|3F|40|5B|5D)/ig,map:{"%3A":":","%2F":"/","%3F":"?","%23":"#","%5B":"[","%5D":"]","%40":"@","%21":"!","%24":"$","%26":"&","%27":"'","%28":"(","%29":")","%2A":"*","%2B":"+","%2C":",","%3B":";","%3D":"="}}},urnpath:{encode:{expression:/%(21|24|27|28|29|2A|2B|2C|3B|3D|40)/ig,map:{"%21":"!","%24":"$","%27":"'","%28":"(","%29":")","%2A":"*","%2B":"+","%2C":",","%3B":";","%3D":"=","%40":"@"}},decode:{expression:/[\/\?#:]/g,map:{"/":"%2F","?":"%3F","#":"%23",":":"%3A"}}}},a.encodeQuery=function(E,I){var B=a.encode(E+"");return I===void 0&&(I=a.escapeQuerySpace),I?B.replace(/%20/g,"+"):B},a.decodeQuery=function(E,I){E+="",I===void 0&&(I=a.escapeQuerySpace);try{return a.decode(I?E.replace(/\+/g,"%20"):E)}catch{return E}};var A={encode:"encode",decode:"decode"},S,g=function(E,I){return function(B){try{return a[I](B+"").replace(a.characters[E][I].expression,function(X){return a.characters[E][I].map[X]})}catch{return B}}};for(S in A)a[S+"PathSegment"]=g("pathname",A[S]),a[S+"UrnPathSegment"]=g("urnpath",A[S]);var C=function(E,I,B){return function(X){var _;B?_=function(H){return a[I](a[B](H))}:_=a[I];for(var P=(X+"").split(E),w=0,z=P.length;w-1&&(I.fragment=E.substring(B+1)||null,E=E.substring(0,B)),B=E.indexOf("?"),B>-1&&(I.query=E.substring(B+1)||null,E=E.substring(0,B)),E=E.replace(/^(https?|ftp|wss?)?:+[/\\]*/i,"$1://"),E=E.replace(/^[/\\]{2,}/i,"//"),E.substring(0,2)==="//"?(I.protocol=null,E=E.substring(2),E=a.parseAuthority(E,I)):(B=E.indexOf(":"),B>-1&&(I.protocol=E.substring(0,B)||null,I.protocol&&!I.protocol.match(a.protocol_expression)?I.protocol=void 0:E.substring(B+1,B+3).replace(/\\/g,"/")==="//"?(E=E.substring(B+3),E=a.parseAuthority(E,I)):(E=E.substring(B+1),I.urn=!0))),I.path=E,I},a.parseHost=function(E,I){E||(E=""),E=E.replace(/\\/g,"/");var B=E.indexOf("/"),X,_;if(B===-1&&(B=E.length),E.charAt(0)==="[")X=E.indexOf("]"),I.hostname=E.substring(1,X)||null,I.port=E.substring(X+2,B)||null,I.port==="/"&&(I.port=null);else{var P=E.indexOf(":"),w=E.indexOf("/"),z=E.indexOf(":",P+1);z!==-1&&(w===-1||z-1?_:E.length-1),w;return P>-1&&(_===-1||P<_)?(w=E.substring(0,P).split(":"),I.username=w[0]?a.decode(w[0]):null,w.shift(),I.password=w[0]?a.decode(w.join(":")):null,E=B.substring(P+1)):(I.username=null,I.password=null),E},a.parseQuery=function(E,I){if(!E)return{};if(E=E.replace(/&+/g,"&").replace(/^\?*&*|&+$/g,""),!E)return{};for(var B={},X=E.split("&"),_=X.length,P,w,z,H=0;H<_;H++)P=X[H].split("="),w=a.decodeQuery(P.shift(),I),z=P.length?a.decodeQuery(P.join("="),I):null,w!=="__proto__"&&(r.call(B,w)?((typeof B[w]=="string"||B[w]===null)&&(B[w]=[B[w]]),B[w].push(z)):B[w]=z);return B},a.build=function(E){var I="",B=!1;return E.protocol&&(I+=E.protocol+":"),!E.urn&&(I||E.hostname)&&(I+="//",B=!0),I+=a.buildAuthority(E)||"",typeof E.path=="string"&&(E.path.charAt(0)!=="/"&&B&&(I+="/"),I+=E.path),typeof E.query=="string"&&E.query&&(I+="?"+E.query),typeof E.fragment=="string"&&E.fragment&&(I+="#"+E.fragment),I},a.buildHost=function(E){var I="";if(E.hostname)a.ip6_expression.test(E.hostname)?I+="["+E.hostname+"]":I+=E.hostname;else return"";return E.port&&(I+=":"+E.port),I},a.buildAuthority=function(E){return a.buildUserinfo(E)+a.buildHost(E)},a.buildUserinfo=function(E){var I="";return E.username&&(I+=a.encode(E.username)),E.password&&(I+=":"+a.encode(E.password)),I&&(I+="@"),I},a.buildQuery=function(E,I,B){var X="",_,P,w,z;for(P in E)if(P!=="__proto__"&&r.call(E,P))if(h(E[P]))for(_={},w=0,z=E[P].length;w-1?q=q.slice(0,at)+q.slice(at).replace(P,""):q=q.replace(P,""),!(q.length<=H[0].length)&&!(B.ignore&&B.ignore.test(q))){dt=nt+q.length;var Qt=I(q,nt,dt,E);if(Qt===void 0){X.lastIndex=dt;continue}Qt=String(Qt),E=E.slice(0,nt)+Qt+E.slice(dt),X.lastIndex=nt+Qt.length}}return X.lastIndex=0,E},a.ensureValidHostname=function(E,I){var B=!!E,X=!!I,_=!1;if(X&&(_=R(a.hostProtocols,I)),_&&!B)throw new TypeError("Hostname cannot be empty, if protocol is "+I);if(E&&E.match(a.invalid_hostname_characters)){if(!t)throw new TypeError('Hostname "'+E+'" contains characters other than [A-Z0-9.-:_] and Punycode.js is not available');if(t.toASCII(E).match(a.invalid_hostname_characters))throw new TypeError('Hostname "'+E+'" contains characters other than [A-Z0-9.-:_]')}},a.ensureValidPort=function(E){if(E){var I=Number(E);if(!(s(I)&&I>0&&I<65536))throw new TypeError('Port "'+E+'" is not a valid port')}},a.noConflict=function(E){if(E){var I={URI:this.noConflict()};return i.URITemplate&&typeof i.URITemplate.noConflict=="function"&&(I.URITemplate=i.URITemplate.noConflict()),i.IPv6&&typeof i.IPv6.noConflict=="function"&&(I.IPv6=i.IPv6.noConflict()),i.SecondLevelDomains&&typeof i.SecondLevelDomains.noConflict=="function"&&(I.SecondLevelDomains=i.SecondLevelDomains.noConflict()),I}else i.URI===this&&(i.URI=o);return this},l.build=function(E){return E===!0?this._deferred_build=!0:(E===void 0||this._deferred_build)&&(this._string=a.build(this._parts),this._deferred_build=!1),this},l.clone=function(){return new a(this)},l.valueOf=l.toString=function(){return this.build(!1)._string};function y(E){return function(I,B){return I===void 0?this._parts[E]||"":(this._parts[E]=I||null,this.build(!B),this)}}function Y(E,I){return function(B,X){return B===void 0?this._parts[E]||"":(B!==null&&(B=B+"",B.charAt(0)===I&&(B=B.substring(1))),this._parts[E]=B,this.build(!X),this)}}l.protocol=y("protocol"),l.username=y("username"),l.password=y("password"),l.hostname=y("hostname"),l.port=y("port"),l.query=Y("query","?"),l.fragment=Y("fragment","#"),l.search=function(E,I){var B=this.query(E,I);return typeof B=="string"&&B.length?"?"+B:B},l.hash=function(E,I){var B=this.fragment(E,I);return typeof B=="string"&&B.length?"#"+B:B},l.pathname=function(E,I){if(E===void 0||E===!0){var B=this._parts.path||(this._parts.hostname?"/":"");return E?(this._parts.urn?a.decodeUrnPath:a.decodePath)(B):B}else return this._parts.urn?this._parts.path=E?a.recodeUrnPath(E):"":this._parts.path=E?a.recodePath(E):"/",this.build(!I),this},l.path=l.pathname,l.href=function(E,I){var B;if(E===void 0)return this.toString();this._string="",this._parts=a._parts();var X=E instanceof a,_=typeof E=="object"&&(E.hostname||E.path||E.pathname);if(E.nodeName){var P=a.getDomAttribute(E);E=E[P]||"",_=!1}if(!X&&_&&E.pathname!==void 0&&(E=E.toString()),typeof E=="string"||E instanceof String)this._parts=a.parse(String(E),this._parts);else if(X||_){var w=X?E._parts:E;for(B in w)B!=="query"&&r.call(this._parts,B)&&(this._parts[B]=w[B]);w.query&&this.query(w.query,!1)}else throw new TypeError("invalid input");return this.build(!I),this},l.is=function(E){var I=!1,B=!1,X=!1,_=!1,P=!1,w=!1,z=!1,H=!this._parts.urn;switch(this._parts.hostname&&(H=!1,B=a.ip4_expression.test(this._parts.hostname),X=a.ip6_expression.test(this._parts.hostname),I=B||X,_=!I,P=_&&n&&n.has(this._parts.hostname),w=_&&a.idn_expression.test(this._parts.hostname),z=_&&a.punycode_expression.test(this._parts.hostname)),E.toLowerCase()){case"relative":return H;case"absolute":return!H;case"domain":case"name":return _;case"sld":return P;case"ip":return I;case"ip4":case"ipv4":case"inet4":return B;case"ip6":case"ipv6":case"inet6":return X;case"idn":return w;case"url":return!this._parts.urn;case"urn":return!!this._parts.urn;case"punycode":return z}return null};var Q=l.protocol,J=l.port,M=l.hostname;l.protocol=function(E,I){if(E&&(E=E.replace(/:(\/\/)?$/,""),!E.match(a.protocol_expression)))throw new TypeError('Protocol "'+E+`" contains characters other than [A-Z0-9.+-] or doesn't start with [A-Z]`);return Q.call(this,E,I)},l.scheme=l.protocol,l.port=function(E,I){return this._parts.urn?E===void 0?"":this:(E!==void 0&&(E===0&&(E=null),E&&(E+="",E.charAt(0)===":"&&(E=E.substring(1)),a.ensureValidPort(E))),J.call(this,E,I))},l.hostname=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E!==void 0){var B={preventInvalidHostname:this._parts.preventInvalidHostname},X=a.parseHost(E,B);if(X!=="/")throw new TypeError('Hostname "'+E+'" contains characters other than [A-Z0-9.-]');E=B.hostname,this._parts.preventInvalidHostname&&a.ensureValidHostname(E,this._parts.protocol)}return M.call(this,E,I)},l.origin=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0){var B=this.protocol(),X=this.authority();return X?(B?B+"://":"")+this.authority():""}else{var _=a(E);return this.protocol(_.protocol()).authority(_.authority()).build(!I),this}},l.host=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0)return this._parts.hostname?a.buildHost(this._parts):"";var B=a.parseHost(E,this._parts);if(B!=="/")throw new TypeError('Hostname "'+E+'" contains characters other than [A-Z0-9.-]');return this.build(!I),this},l.authority=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0)return this._parts.hostname?a.buildAuthority(this._parts):"";var B=a.parseAuthority(E,this._parts);if(B!=="/")throw new TypeError('Hostname "'+E+'" contains characters other than [A-Z0-9.-]');return this.build(!I),this},l.userinfo=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0){var B=a.buildUserinfo(this._parts);return B&&B.substring(0,B.length-1)}else return E[E.length-1]!=="@"&&(E+="@"),a.parseUserinfo(E,this._parts),this.build(!I),this},l.resource=function(E,I){var B;return E===void 0?this.path()+this.search()+this.hash():(B=a.parse(E),this._parts.path=B.path,this._parts.query=B.query,this._parts.fragment=B.fragment,this.build(!I),this)},l.subdomain=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0){if(!this._parts.hostname||this.is("IP"))return"";var B=this._parts.hostname.length-this.domain().length-1;return this._parts.hostname.substring(0,B)||""}else{var X=this._parts.hostname.length-this.domain().length,_=this._parts.hostname.substring(0,X),P=new RegExp("^"+d(_));if(E&&E.charAt(E.length-1)!=="."&&(E+="."),E.indexOf(":")!==-1)throw new TypeError("Domains cannot contain colons");return E&&a.ensureValidHostname(E,this._parts.protocol),this._parts.hostname=this._parts.hostname.replace(P,E),this.build(!I),this}},l.domain=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(typeof E=="boolean"&&(I=E,E=void 0),E===void 0){if(!this._parts.hostname||this.is("IP"))return"";var B=this._parts.hostname.match(/\./g);if(B&&B.length<2)return this._parts.hostname;var X=this._parts.hostname.length-this.tld(I).length-1;return X=this._parts.hostname.lastIndexOf(".",X-1)+1,this._parts.hostname.substring(X)||""}else{if(!E)throw new TypeError("cannot set domain empty");if(E.indexOf(":")!==-1)throw new TypeError("Domains cannot contain colons");if(a.ensureValidHostname(E,this._parts.protocol),!this._parts.hostname||this.is("IP"))this._parts.hostname=E;else{var _=new RegExp(d(this.domain())+"$");this._parts.hostname=this._parts.hostname.replace(_,E)}return this.build(!I),this}},l.tld=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(typeof E=="boolean"&&(I=E,E=void 0),E===void 0){if(!this._parts.hostname||this.is("IP"))return"";var B=this._parts.hostname.lastIndexOf("."),X=this._parts.hostname.substring(B+1);return I!==!0&&n&&n.list[X.toLowerCase()]&&n.get(this._parts.hostname)||X}else{var _;if(E)if(E.match(/[^a-zA-Z0-9-]/))if(n&&n.is(E))_=new RegExp(d(this.tld())+"$"),this._parts.hostname=this._parts.hostname.replace(_,E);else throw new TypeError('TLD "'+E+'" contains characters other than [A-Z0-9]');else{if(!this._parts.hostname||this.is("IP"))throw new ReferenceError("cannot set TLD on non-domain host");_=new RegExp(d(this.tld())+"$"),this._parts.hostname=this._parts.hostname.replace(_,E)}else throw new TypeError("cannot set TLD empty");return this.build(!I),this}},l.directory=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0||E===!0){if(!this._parts.path&&!this._parts.hostname)return"";if(this._parts.path==="/")return"/";var B=this._parts.path.length-this.filename().length-1,X=this._parts.path.substring(0,B)||(this._parts.hostname?"/":"");return E?a.decodePath(X):X}else{var _=this._parts.path.length-this.filename().length,P=this._parts.path.substring(0,_),w=new RegExp("^"+d(P));return this.is("relative")||(E||(E="/"),E.charAt(0)!=="/"&&(E="/"+E)),E&&E.charAt(E.length-1)!=="/"&&(E+="/"),E=a.recodePath(E),this._parts.path=this._parts.path.replace(w,E),this.build(!I),this}},l.filename=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(typeof E!="string"){if(!this._parts.path||this._parts.path==="/")return"";var B=this._parts.path.lastIndexOf("/"),X=this._parts.path.substring(B+1);return E?a.decodePathSegment(X):X}else{var _=!1;E.charAt(0)==="/"&&(E=E.substring(1)),E.match(/\.?\//)&&(_=!0);var P=new RegExp(d(this.filename())+"$");return E=a.recodePath(E),this._parts.path=this._parts.path.replace(P,E),_?this.normalizePath(I):this.build(!I),this}},l.suffix=function(E,I){if(this._parts.urn)return E===void 0?"":this;if(E===void 0||E===!0){if(!this._parts.path||this._parts.path==="/")return"";var B=this.filename(),X=B.lastIndexOf("."),_,P;return X===-1?"":(_=B.substring(X+1),P=/^[a-z0-9%]+$/i.test(_)?_:"",E?a.decodePathSegment(P):P)}else{E.charAt(0)==="."&&(E=E.substring(1));var w=this.suffix(),z;if(w)E?z=new RegExp(d(w)+"$"):z=new RegExp(d("."+w)+"$");else{if(!E)return this;this._parts.path+="."+a.recodePath(E)}return z&&(E=a.recodePath(E),this._parts.path=this._parts.path.replace(z,E)),this.build(!I),this}},l.segment=function(E,I,B){var X=this._parts.urn?":":"/",_=this.path(),P=_.substring(0,1)==="/",w=_.split(X);if(E!==void 0&&typeof E!="number"&&(B=I,I=E,E=void 0),E!==void 0&&typeof E!="number")throw new Error('Bad segment "'+E+'", must be 0-based integer');if(P&&w.shift(),E<0&&(E=Math.max(w.length+E,0)),I===void 0)return E===void 0?w:w[E];if(E===null||w[E]===void 0)if(h(I)){w=[];for(var z=0,H=I.length;z{var VAn=b(W());/*! @license DOMPurify 3.1.2 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.1.2/LICENSE */(function(t,e){typeof Uq=="object"&&typeof Gq<"u"?Gq.exports=e():typeof define=="function"&&define.amd?define(e):(t=typeof globalThis<"u"?globalThis:t||self,t.DOMPurify=e())})(Uq,function(){"use strict";let{entries:t,setPrototypeOf:e,isFrozen:n,getPrototypeOf:i,getOwnPropertyDescriptor:o}=Object,{freeze:a,seal:s,create:l}=Object,{apply:r,construct:d}=typeof Reflect<"u"&&Reflect;a||(a=function(zt){return zt}),s||(s=function(zt){return zt}),r||(r=function(zt,ke,Ve){return zt.apply(ke,Ve)}),d||(d=function(zt,ke){return new zt(...ke)});let m=y(Array.prototype.forEach),h=y(Array.prototype.pop),u=y(Array.prototype.push),R=y(String.prototype.toLowerCase),V=y(String.prototype.toString),F=y(String.prototype.match),U=y(String.prototype.replace),G=y(String.prototype.indexOf),A=y(String.prototype.trim),S=y(Object.prototype.hasOwnProperty),g=y(RegExp.prototype.test),C=Y(TypeError);function y(de){return function(zt){for(var ke=arguments.length,Ve=new Array(ke>1?ke-1:0),We=1;We2&&arguments[2]!==void 0?arguments[2]:R;e&&e(de,null);let Ve=zt.length;for(;Ve--;){let We=zt[Ve];if(typeof We=="string"){let Vn=ke(We);Vn!==We&&(n(zt)||(zt[Ve]=Vn),We=Vn)}de[We]=!0}return de}function J(de){for(let zt=0;zt/gm),at=s(/\${[\w\W]*}/gm),st=s(/^data-[\-\w.\u00B7-\uFFFF]/),Et=s(/^aria-[\-\w]+$/),Qt=s(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|sms|cid|xmpp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i),Wt=s(/^(?:\w+script|data):/i),Nt=s(/[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g),kt=s(/^html$/i),Mt=s(/^[a-z][.\w]*(-[.\w]+)+$/i);var qt=Object.freeze({__proto__:null,MUSTACHE_EXPR:dt,ERB_EXPR:q,TMPLIT_EXPR:at,DATA_ATTR:st,ARIA_ATTR:Et,IS_ALLOWED_URI:Qt,IS_SCRIPT_OR_DATA:Wt,ATTR_WHITESPACE:Nt,DOCTYPE_NAME:kt,CUSTOM_ELEMENT:Mt});let ie=function(){return typeof window>"u"?null:window},oe=function(zt,ke){if(typeof zt!="object"||typeof zt.createPolicy!="function")return null;let Ve=null,We="data-tt-policy-suffix";ke&&ke.hasAttribute(We)&&(Ve=ke.getAttribute(We));let Vn="dompurify"+(Ve?"#"+Ve:"");try{return zt.createPolicy(Vn,{createHTML(Ct){return Ct},createScriptURL(Ct){return Ct}})}catch{return console.warn("TrustedTypes policy "+Vn+" could not be created."),null}};function He(){let de=arguments.length>0&&arguments[0]!==void 0?arguments[0]:ie(),zt=un=>He(un);if(zt.version="3.1.2",zt.removed=[],!de||!de.document||de.document.nodeType!==9)return zt.isSupported=!1,zt;let{document:ke}=de,Ve=ke,We=Ve.currentScript,{DocumentFragment:Vn,HTMLTemplateElement:Ct,Node:_t,Element:Je,NodeFilter:xe,NamedNodeMap:oo=de.NamedNodeMap||de.MozNamedAttrMap,HTMLFormElement:ea,DOMParser:gs,trustedTypes:is}=de,ja=Je.prototype,qn=Z(ja,"cloneNode"),ae=Z(ja,"nextSibling"),fe=Z(ja,"childNodes"),ge=Z(ja,"parentNode");if(typeof Ct=="function"){let un=ke.createElement("template");un.content&&un.content.ownerDocument&&(ke=un.content.ownerDocument)}let ue,Ke="",{implementation:An,createNodeIterator:si,createDocumentFragment:da,getElementsByTagName:_a}=ke,{importNode:Rl}=Ve,na={};zt.isSupported=typeof t=="function"&&typeof ge=="function"&&An&&An.createHTMLDocument!==void 0;let{MUSTACHE_EXPR:Go,ERB_EXPR:Ao,TMPLIT_EXPR:Xs,DATA_ATTR:Es,ARIA_ATTR:wl,IS_SCRIPT_OR_DATA:ka,ATTR_WHITESPACE:Wa,CUSTOM_ELEMENT:JV}=qt,{IS_ALLOWED_URI:yl}=qt,Bi=null,sd=Q({},[...E,...I,...B,..._,...w]),zi=null,js=Q({},[...z,...H,...nt,...$]),ca=Object.seal(l(null,{tagNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},attributeNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},allowCustomizedBuiltInElements:{writable:!0,configurable:!1,enumerable:!0,value:!1}})),$n=null,mr=null,hr=!0,pr=!0,hs=!1,ma=!0,Ed=!1,BW=!0,bc=!1,$R=!1,up=!1,LV=!1,QW=!1,tb=!1,kW=!0,YW=!1,pg="user-content-",MU=!0,lh=!1,Zp={},lm=null,_U=Q({},["annotation-xml","audio","colgroup","desc","foreignobject","head","iframe","math","mi","mn","mo","ms","mtext","noembed","noframes","noscript","plaintext","script","style","svg","template","thead","title","video","xmp"]),DU=null,MV=Q({},["audio","video","img","source","image","track"]),eb=null,Vg=Q({},["alt","class","for","id","label","name","pattern","placeholder","role","summary","title","value","style","xmlns"]),Rp="http://www.w3.org/1998/Math/MathML",bp="http://www.w3.org/2000/svg",kr="http://www.w3.org/1999/xhtml",fZ=kr,xW=!1,XW=null,OU=Q({},[Rp,bp,kr],V),nb=null,rh=["application/xhtml+xml","text/html"],HU="text/html",Js=null,ld=null,ib=255,wU=ke.createElement("form"),PU=function(Kt){return Kt instanceof RegExp||Kt instanceof Function},JW=function(){let Kt=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};if(!(ld&&ld===Kt)){if((!Kt||typeof Kt!="object")&&(Kt={}),Kt=M(Kt),nb=rh.indexOf(Kt.PARSER_MEDIA_TYPE)===-1?HU:Kt.PARSER_MEDIA_TYPE,Js=nb==="application/xhtml+xml"?V:R,Bi=S(Kt,"ALLOWED_TAGS")?Q({},Kt.ALLOWED_TAGS,Js):sd,zi=S(Kt,"ALLOWED_ATTR")?Q({},Kt.ALLOWED_ATTR,Js):js,XW=S(Kt,"ALLOWED_NAMESPACES")?Q({},Kt.ALLOWED_NAMESPACES,V):OU,eb=S(Kt,"ADD_URI_SAFE_ATTR")?Q(M(Vg),Kt.ADD_URI_SAFE_ATTR,Js):Vg,DU=S(Kt,"ADD_DATA_URI_TAGS")?Q(M(MV),Kt.ADD_DATA_URI_TAGS,Js):MV,lm=S(Kt,"FORBID_CONTENTS")?Q({},Kt.FORBID_CONTENTS,Js):_U,$n=S(Kt,"FORBID_TAGS")?Q({},Kt.FORBID_TAGS,Js):{},mr=S(Kt,"FORBID_ATTR")?Q({},Kt.FORBID_ATTR,Js):{},Zp=S(Kt,"USE_PROFILES")?Kt.USE_PROFILES:!1,hr=Kt.ALLOW_ARIA_ATTR!==!1,pr=Kt.ALLOW_DATA_ATTR!==!1,hs=Kt.ALLOW_UNKNOWN_PROTOCOLS||!1,ma=Kt.ALLOW_SELF_CLOSE_IN_ATTR!==!1,Ed=Kt.SAFE_FOR_TEMPLATES||!1,BW=Kt.SAFE_FOR_XML!==!1,bc=Kt.WHOLE_DOCUMENT||!1,LV=Kt.RETURN_DOM||!1,QW=Kt.RETURN_DOM_FRAGMENT||!1,tb=Kt.RETURN_TRUSTED_TYPE||!1,up=Kt.FORCE_BODY||!1,kW=Kt.SANITIZE_DOM!==!1,YW=Kt.SANITIZE_NAMED_PROPS||!1,MU=Kt.KEEP_CONTENT!==!1,lh=Kt.IN_PLACE||!1,yl=Kt.ALLOWED_URI_REGEXP||Qt,fZ=Kt.NAMESPACE||kr,ca=Kt.CUSTOM_ELEMENT_HANDLING||{},Kt.CUSTOM_ELEMENT_HANDLING&&PU(Kt.CUSTOM_ELEMENT_HANDLING.tagNameCheck)&&(ca.tagNameCheck=Kt.CUSTOM_ELEMENT_HANDLING.tagNameCheck),Kt.CUSTOM_ELEMENT_HANDLING&&PU(Kt.CUSTOM_ELEMENT_HANDLING.attributeNameCheck)&&(ca.attributeNameCheck=Kt.CUSTOM_ELEMENT_HANDLING.attributeNameCheck),Kt.CUSTOM_ELEMENT_HANDLING&&typeof Kt.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements=="boolean"&&(ca.allowCustomizedBuiltInElements=Kt.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements),Ed&&(pr=!1),QW&&(LV=!0),Zp&&(Bi=Q({},w),zi=[],Zp.html===!0&&(Q(Bi,E),Q(zi,z)),Zp.svg===!0&&(Q(Bi,I),Q(zi,H),Q(zi,$)),Zp.svgFilters===!0&&(Q(Bi,B),Q(zi,H),Q(zi,$)),Zp.mathMl===!0&&(Q(Bi,_),Q(zi,nt),Q(zi,$))),Kt.ADD_TAGS&&(Bi===sd&&(Bi=M(Bi)),Q(Bi,Kt.ADD_TAGS,Js)),Kt.ADD_ATTR&&(zi===js&&(zi=M(zi)),Q(zi,Kt.ADD_ATTR,Js)),Kt.ADD_URI_SAFE_ATTR&&Q(eb,Kt.ADD_URI_SAFE_ATTR,Js),Kt.FORBID_CONTENTS&&(lm===_U&&(lm=M(lm)),Q(lm,Kt.FORBID_CONTENTS,Js)),MU&&(Bi["#text"]=!0),bc&&Q(Bi,["html","head","body"]),Bi.table&&(Q(Bi,["tbody"]),delete $n.tbody),Kt.TRUSTED_TYPES_POLICY){if(typeof Kt.TRUSTED_TYPES_POLICY.createHTML!="function")throw C('TRUSTED_TYPES_POLICY configuration option must provide a "createHTML" hook.');if(typeof Kt.TRUSTED_TYPES_POLICY.createScriptURL!="function")throw C('TRUSTED_TYPES_POLICY configuration option must provide a "createScriptURL" hook.');ue=Kt.TRUSTED_TYPES_POLICY,Ke=ue.createHTML("")}else ue===void 0&&(ue=oe(is,We)),ue!==null&&typeof Ke=="string"&&(Ke=ue.createHTML(""));a&&a(Kt),ld=Kt}},FZ=Q({},["mi","mo","mn","ms","mtext"]),vU=Q({},["foreignobject","annotation-xml"]),ug=Q({},["title","style","font","a","script"]),Zg=Q({},[...I,...B,...X]),ob=Q({},[..._,...P]),TN=function(Kt){let De=ge(Kt);(!De||!De.tagName)&&(De={namespaceURI:fZ,tagName:"template"});let ti=R(Kt.tagName),Hi=R(De.tagName);return XW[Kt.namespaceURI]?Kt.namespaceURI===bp?De.namespaceURI===kr?ti==="svg":De.namespaceURI===Rp?ti==="svg"&&(Hi==="annotation-xml"||FZ[Hi]):!!Zg[ti]:Kt.namespaceURI===Rp?De.namespaceURI===kr?ti==="math":De.namespaceURI===bp?ti==="math"&&vU[Hi]:!!ob[ti]:Kt.namespaceURI===kr?De.namespaceURI===bp&&!vU[Hi]||De.namespaceURI===Rp&&!FZ[Hi]?!1:!ob[ti]&&(ug[ti]||!Zg[ti]):!!(nb==="application/xhtml+xml"&&XW[Kt.namespaceURI]):!1},Cd=function(Kt){u(zt.removed,{element:Kt});try{Kt.parentNode.removeChild(Kt)}catch{Kt.remove()}},KU=function(Kt,De){try{u(zt.removed,{attribute:De.getAttributeNode(Kt),from:De})}catch{u(zt.removed,{attribute:null,from:De})}if(De.removeAttribute(Kt),Kt==="is"&&!zi[Kt])if(LV||QW)try{Cd(De)}catch{}else try{De.setAttribute(Kt,"")}catch{}},Rg=function(Kt){let De=null,ti=null;if(up)Kt=""+Kt;else{let Pl=F(Kt,/^[\r\n\t ]+/);ti=Pl&&Pl[0]}nb==="application/xhtml+xml"&&fZ===kr&&(Kt=''+Kt+"");let Hi=ue?ue.createHTML(Kt):Kt;if(fZ===kr)try{De=new gs().parseFromString(Hi,nb)}catch{}if(!De||!De.documentElement){De=An.createDocument(fZ,"template",null);try{De.documentElement.innerHTML=xW?Ke:Hi}catch{}}let bl=De.body||De.documentElement;return Kt&&ti&&bl.insertBefore(ke.createTextNode(ti),bl.childNodes[0]||null),fZ===kr?_a.call(De,bc?"html":"body")[0]:bc?De.documentElement:bl},rm=function(Kt){return si.call(Kt.ownerDocument||Kt,Kt,xe.SHOW_ELEMENT|xe.SHOW_COMMENT|xe.SHOW_TEXT|xe.SHOW_PROCESSING_INSTRUCTION|xe.SHOW_CDATA_SECTION,null)},bg=function(Kt){return Kt instanceof ea&&(typeof Kt.__depth<"u"&&typeof Kt.__depth!="number"||typeof Kt.__removalCount<"u"&&typeof Kt.__removalCount!="number"||typeof Kt.nodeName!="string"||typeof Kt.textContent!="string"||typeof Kt.removeChild!="function"||!(Kt.attributes instanceof oo)||typeof Kt.removeAttribute!="function"||typeof Kt.setAttribute!="function"||typeof Kt.namespaceURI!="string"||typeof Kt.insertBefore!="function"||typeof Kt.hasChildNodes!="function")},LW=function(Kt){return typeof _t=="function"&&Kt instanceof _t},Id=function(Kt,De,ti){na[Kt]&&m(na[Kt],Hi=>{Hi.call(zt,De,ti,ld)})},MW=function(Kt){let De=null;if(Id("beforeSanitizeElements",Kt,null),bg(Kt))return Cd(Kt),!0;let ti=Js(Kt.nodeName);if(Id("uponSanitizeElement",Kt,{tagName:ti,allowedTags:Bi}),Kt.hasChildNodes()&&!LW(Kt.firstElementChild)&&g(/<[/\w]/g,Kt.innerHTML)&&g(/<[/\w]/g,Kt.textContent)||Kt.nodeType===7||BW&&Kt.nodeType===8&&g(/<[/\w]/g,Kt.data))return Cd(Kt),!0;if(!Bi[ti]||$n[ti]){if(!$n[ti]&&fg(ti)&&(ca.tagNameCheck instanceof RegExp&&g(ca.tagNameCheck,ti)||ca.tagNameCheck instanceof Function&&ca.tagNameCheck(ti)))return!1;if(MU&&!lm[ti]){let Hi=ge(Kt)||Kt.parentNode,bl=fe(Kt)||Kt.childNodes;if(bl&&Hi){let Pl=bl.length;for(let Bl=Pl-1;Bl>=0;--Bl){let Yr=qn(bl[Bl],!0);Yr.__removalCount=(Kt.__removalCount||0)+1,Hi.insertBefore(Yr,ae(Kt))}}}return Cd(Kt),!0}return Kt instanceof Je&&!TN(Kt)||(ti==="noscript"||ti==="noembed"||ti==="noframes")&&g(/<\/no(script|embed|frames)/i,Kt.innerHTML)?(Cd(Kt),!0):(Ed&&Kt.nodeType===3&&(De=Kt.textContent,m([Go,Ao,Xs],Hi=>{De=U(De,Hi," ")}),Kt.textContent!==De&&(u(zt.removed,{element:Kt.cloneNode()}),Kt.textContent=De)),Id("afterSanitizeElements",Kt,null),!1)},Wg=function(Kt,De,ti){if(kW&&(De==="id"||De==="name")&&(ti in ke||ti in wU))return!1;if(!(pr&&!mr[De]&&g(Es,De))){if(!(hr&&g(wl,De))){if(!zi[De]||mr[De]){if(!(fg(Kt)&&(ca.tagNameCheck instanceof RegExp&&g(ca.tagNameCheck,Kt)||ca.tagNameCheck instanceof Function&&ca.tagNameCheck(Kt))&&(ca.attributeNameCheck instanceof RegExp&&g(ca.attributeNameCheck,De)||ca.attributeNameCheck instanceof Function&&ca.attributeNameCheck(De))||De==="is"&&ca.allowCustomizedBuiltInElements&&(ca.tagNameCheck instanceof RegExp&&g(ca.tagNameCheck,ti)||ca.tagNameCheck instanceof Function&&ca.tagNameCheck(ti))))return!1}else if(!eb[De]){if(!g(yl,U(ti,Wa,""))){if(!((De==="src"||De==="xlink:href"||De==="href")&&Kt!=="script"&&G(ti,"data:")===0&&DU[Kt])){if(!(hs&&!g(ka,U(ti,Wa,"")))){if(ti)return!1}}}}}}return!0},fg=function(Kt){return Kt!=="annotation-xml"&&F(Kt,JV)},dm=function(Kt){Id("beforeSanitizeAttributes",Kt,null);let{attributes:De}=Kt;if(!De)return;let ti={attrName:"",attrValue:"",keepAttr:!0,allowedAttributes:zi},Hi=De.length;for(;Hi--;){let bl=De[Hi],{name:Pl,namespaceURI:Bl,value:Yr}=bl,ps=Js(Pl),Ql=Pl==="value"?Yr:A(Yr);if(ti.attrName=ps,ti.attrValue=Ql,ti.keepAttr=!0,ti.forceKeepAttr=void 0,Id("uponSanitizeAttribute",Kt,ti),Ql=ti.attrValue,ti.forceKeepAttr||(KU(Pl,Kt),!ti.keepAttr))continue;if(!ma&&g(/\/>/i,Ql)){KU(Pl,Kt);continue}Ed&&m([Go,Ao,Xs],zU=>{Ql=U(Ql,zU," ")});let Wp=Js(Kt.nodeName);if(Wg(Wp,ps,Ql)){if(YW&&(ps==="id"||ps==="name")&&(KU(Pl,Kt),Ql=pg+Ql),ue&&typeof is=="object"&&typeof is.getAttributeType=="function"&&!Bl)switch(is.getAttributeType(Wp,ps)){case"TrustedHTML":{Ql=ue.createHTML(Ql);break}case"TrustedScriptURL":{Ql=ue.createScriptURL(Ql);break}}try{Bl?Kt.setAttributeNS(Bl,Pl,Ql):Kt.setAttribute(Pl,Ql),h(zt.removed)}catch{}}}Id("afterSanitizeAttributes",Kt,null)},Da=function un(Kt){let De=null,ti=rm(Kt);for(Id("beforeSanitizeShadowDOM",Kt,null);De=ti.nextNode();){if(Id("uponSanitizeShadowNode",De,null),MW(De))continue;let Hi=ge(De);De.nodeType===1&&(Hi&&Hi.__depth?De.__depth=(De.__removalCount||0)+Hi.__depth+1:De.__depth=1),De.__depth>=ib&&Cd(De),De.content instanceof Vn&&(De.content.__depth=De.__depth,un(De.content)),dm(De)}Id("afterSanitizeShadowDOM",Kt,null)};return zt.sanitize=function(un){let Kt=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},De=null,ti=null,Hi=null,bl=null;if(xW=!un,xW&&(un=""),typeof un!="string"&&!LW(un))if(typeof un.toString=="function"){if(un=un.toString(),typeof un!="string")throw C("dirty is not a string, aborting")}else throw C("toString is not a function");if(!zt.isSupported)return un;if($R||JW(Kt),zt.removed=[],typeof un=="string"&&(lh=!1),lh){if(un.nodeName){let Yr=Js(un.nodeName);if(!Bi[Yr]||$n[Yr])throw C("root node is forbidden and cannot be sanitized in-place")}}else if(un instanceof _t)De=Rg(""),ti=De.ownerDocument.importNode(un,!0),ti.nodeType===1&&ti.nodeName==="BODY"||ti.nodeName==="HTML"?De=ti:De.appendChild(ti);else{if(!LV&&!Ed&&!bc&&un.indexOf("<")===-1)return ue&&tb?ue.createHTML(un):un;if(De=Rg(un),!De)return LV?null:tb?Ke:""}De&&up&&Cd(De.firstChild);let Pl=rm(lh?un:De);for(;Hi=Pl.nextNode();){if(MW(Hi))continue;let Yr=ge(Hi);Hi.nodeType===1&&(Yr&&Yr.__depth?Hi.__depth=(Hi.__removalCount||0)+Yr.__depth+1:Hi.__depth=1),Hi.__depth>=ib&&Cd(Hi),Hi.content instanceof Vn&&(Hi.content.__depth=Hi.__depth,Da(Hi.content)),dm(Hi)}if(lh)return un;if(LV){if(QW)for(bl=da.call(De.ownerDocument);De.firstChild;)bl.appendChild(De.firstChild);else bl=De;return(zi.shadowroot||zi.shadowrootmode)&&(bl=Rl.call(Ve,bl,!0)),bl}let Bl=bc?De.outerHTML:De.innerHTML;return bc&&Bi["!doctype"]&&De.ownerDocument&&De.ownerDocument.doctype&&De.ownerDocument.doctype.name&&g(kt,De.ownerDocument.doctype.name)&&(Bl=" +`+Bl),Ed&&m([Go,Ao,Xs],Yr=>{Bl=U(Bl,Yr," ")}),ue&&tb?ue.createHTML(Bl):Bl},zt.setConfig=function(){let un=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};JW(un),$R=!0},zt.clearConfig=function(){ld=null,$R=!1},zt.isValidAttribute=function(un,Kt,De){ld||JW({});let ti=Js(un),Hi=Js(Kt);return Wg(ti,Hi,De)},zt.addHook=function(un,Kt){typeof Kt=="function"&&(na[un]=na[un]||[],u(na[un],Kt))},zt.removeHook=function(un){if(na[un])return h(na[un])},zt.removeHooks=function(un){na[un]&&(na[un]=[])},zt.removeAllHooks=function(){na={}},zt}var rn=He();return rn})});var qRt=Zo((G2n,r$)=>{"use strict";var A2n=b(W());r$.exports=Yw;r$.exports.default=Yw;function Yw(t,e,n){n=n||2;var i=e&&e.length,o=i?e[0]*n:t.length,a=KRt(t,0,o,n,!0),s=[];if(!a||a.next===a.prev)return s;var l,r,d,m,h,u,R;if(i&&(a=Jqt(t,e,a,n)),t.length>80*n){l=d=t[0],r=m=t[1];for(var V=n;Vd&&(d=h),u>m&&(m=u);R=Math.max(d-l,m-r),R=R!==0?32767/R:0}return lY(a,s,n,l,r,R,0),s}function KRt(t,e,n,i,o){var a,s;if(o===l$(t,e,n,i)>0)for(a=e;a=e;a-=i)s=vRt(a,t[a],t[a+1],s);return s&&xw(s,s.next)&&(dY(s),s=s.next),s}function TA(t,e){if(!t)return t;e||(e=t);var n=t,i;do if(i=!1,!n.steiner&&(xw(n,n.next)||ol(n.prev,n,n.next)===0)){if(dY(n),n=e=n.prev,n===n.next)break;i=!0}else n=n.next;while(i||n!==e);return e}function lY(t,e,n,i,o,a,s){if(t){!s&&a&&Oqt(t,i,o,a);for(var l=t,r,d;t.prev!==t.next;){if(r=t.prev,d=t.next,a?Yqt(t,i,o,a):kqt(t)){e.push(r.i/n|0),e.push(t.i/n|0),e.push(d.i/n|0),dY(t),t=d.next,l=d.next;continue}if(t=d,t===l){s?s===1?(t=xqt(TA(t),e,n),lY(t,e,n,i,o,a,2)):s===2&&Xqt(t,e,n,i,o,a):lY(TA(t),e,n,i,o,a,1);break}}}}function kqt(t){var e=t.prev,n=t,i=t.next;if(ol(e,n,i)>=0)return!1;for(var o=e.x,a=n.x,s=i.x,l=e.y,r=n.y,d=i.y,m=oa?o>s?o:s:a>s?a:s,R=l>r?l>d?l:d:r>d?r:d,V=i.next;V!==e;){if(V.x>=m&&V.x<=u&&V.y>=h&&V.y<=R&&HE(o,l,a,r,s,d,V.x,V.y)&&ol(V.prev,V,V.next)>=0)return!1;V=V.next}return!0}function Yqt(t,e,n,i){var o=t.prev,a=t,s=t.next;if(ol(o,a,s)>=0)return!1;for(var l=o.x,r=a.x,d=s.x,m=o.y,h=a.y,u=s.y,R=lr?l>d?l:d:r>d?r:d,U=m>h?m>u?m:u:h>u?h:u,G=a$(R,V,e,n,i),A=a$(F,U,e,n,i),S=t.prevZ,g=t.nextZ;S&&S.z>=G&&g&&g.z<=A;){if(S.x>=R&&S.x<=F&&S.y>=V&&S.y<=U&&S!==o&&S!==s&&HE(l,m,r,h,d,u,S.x,S.y)&&ol(S.prev,S,S.next)>=0||(S=S.prevZ,g.x>=R&&g.x<=F&&g.y>=V&&g.y<=U&&g!==o&&g!==s&&HE(l,m,r,h,d,u,g.x,g.y)&&ol(g.prev,g,g.next)>=0))return!1;g=g.nextZ}for(;S&&S.z>=G;){if(S.x>=R&&S.x<=F&&S.y>=V&&S.y<=U&&S!==o&&S!==s&&HE(l,m,r,h,d,u,S.x,S.y)&&ol(S.prev,S,S.next)>=0)return!1;S=S.prevZ}for(;g&&g.z<=A;){if(g.x>=R&&g.x<=F&&g.y>=V&&g.y<=U&&g!==o&&g!==s&&HE(l,m,r,h,d,u,g.x,g.y)&&ol(g.prev,g,g.next)>=0)return!1;g=g.nextZ}return!0}function xqt(t,e,n){var i=t;do{var o=i.prev,a=i.next.next;!xw(o,a)&&zRt(o,i,i.next,a)&&rY(o,a)&&rY(a,o)&&(e.push(o.i/n|0),e.push(i.i/n|0),e.push(a.i/n|0),dY(i),dY(i.next),i=t=a),i=i.next}while(i!==t);return TA(i)}function Xqt(t,e,n,i,o,a){var s=t;do{for(var l=s.next.next;l!==s.prev;){if(s.i!==l.i&&Pqt(s,l)){var r=jRt(s,l);s=TA(s,s.next),r=TA(r,r.next),lY(s,e,n,i,o,a,0),lY(r,e,n,i,o,a,0);return}l=l.next}s=s.next}while(s!==t)}function Jqt(t,e,n,i){var o=[],a,s,l,r,d;for(a=0,s=e.length;a=n.next.y&&n.next.y!==n.y){var l=n.x+(o-n.y)*(n.next.x-n.x)/(n.next.y-n.y);if(l<=i&&l>a&&(a=l,s=n.x=n.x&&n.x>=d&&i!==n.x&&HE(os.x||n.x===s.x&&Dqt(s,n)))&&(s=n,h=u)),n=n.next;while(n!==r);return s}function Dqt(t,e){return ol(t.prev,t,e.prev)<0&&ol(e.next,t,t.next)<0}function Oqt(t,e,n,i){var o=t;do o.z===0&&(o.z=a$(o.x,o.y,e,n,i)),o.prevZ=o.prev,o.nextZ=o.next,o=o.next;while(o!==t);o.prevZ.nextZ=null,o.prevZ=null,Hqt(o)}function Hqt(t){var e,n,i,o,a,s,l,r,d=1;do{for(n=t,t=null,a=null,s=0;n;){for(s++,i=n,l=0,e=0;e0||r>0&&i;)l!==0&&(r===0||!i||n.z<=i.z)?(o=n,n=n.nextZ,l--):(o=i,i=i.nextZ,r--),a?a.nextZ=o:t=o,o.prevZ=a,a=o;n=i}a.nextZ=null,d*=2}while(s>1);return t}function a$(t,e,n,i,o){return t=(t-n)*o|0,e=(e-i)*o|0,t=(t|t<<8)&16711935,t=(t|t<<4)&252645135,t=(t|t<<2)&858993459,t=(t|t<<1)&1431655765,e=(e|e<<8)&16711935,e=(e|e<<4)&252645135,e=(e|e<<2)&858993459,e=(e|e<<1)&1431655765,t|e<<1}function wqt(t){var e=t,n=t;do(e.x=(t-s)*(a-l)&&(t-s)*(i-l)>=(n-s)*(e-l)&&(n-s)*(a-l)>=(o-s)*(i-l)}function Pqt(t,e){return t.next.i!==e.i&&t.prev.i!==e.i&&!vqt(t,e)&&(rY(t,e)&&rY(e,t)&&Kqt(t,e)&&(ol(t.prev,t,e.prev)||ol(t,e.prev,e))||xw(t,e)&&ol(t.prev,t,t.next)>0&&ol(e.prev,e,e.next)>0)}function ol(t,e,n){return(e.y-t.y)*(n.x-e.x)-(e.x-t.x)*(n.y-e.y)}function xw(t,e){return t.x===e.x&&t.y===e.y}function zRt(t,e,n,i){var o=kw(ol(t,e,n)),a=kw(ol(t,e,i)),s=kw(ol(n,i,t)),l=kw(ol(n,i,e));return!!(o!==a&&s!==l||o===0&&Qw(t,n,e)||a===0&&Qw(t,i,e)||s===0&&Qw(n,t,i)||l===0&&Qw(n,e,i))}function Qw(t,e,n){return e.x<=Math.max(t.x,n.x)&&e.x>=Math.min(t.x,n.x)&&e.y<=Math.max(t.y,n.y)&&e.y>=Math.min(t.y,n.y)}function kw(t){return t>0?1:t<0?-1:0}function vqt(t,e){var n=t;do{if(n.i!==t.i&&n.next.i!==t.i&&n.i!==e.i&&n.next.i!==e.i&&zRt(n,n.next,t,e))return!0;n=n.next}while(n!==t);return!1}function rY(t,e){return ol(t.prev,t,t.next)<0?ol(t,e,t.next)>=0&&ol(t,t.prev,e)>=0:ol(t,e,t.prev)<0||ol(t,t.next,e)<0}function Kqt(t,e){var n=t,i=!1,o=(t.x+e.x)/2,a=(t.y+e.y)/2;do n.y>a!=n.next.y>a&&n.next.y!==n.y&&o<(n.next.x-n.x)*(a-n.y)/(n.next.y-n.y)+n.x&&(i=!i),n=n.next;while(n!==t);return i}function jRt(t,e){var n=new s$(t.i,t.x,t.y),i=new s$(e.i,e.x,e.y),o=t.next,a=e.prev;return t.next=e,e.prev=t,n.next=o,o.prev=n,i.next=n,n.prev=i,a.next=i,i.prev=a,i}function vRt(t,e,n,i){var o=new s$(t,e,n);return i?(o.next=i.next,o.prev=i,i.next.prev=o,i.next=o):(o.prev=o,o.next=o),o}function dY(t){t.next.prev=t.prev,t.prev.next=t.next,t.prevZ&&(t.prevZ.nextZ=t.nextZ),t.nextZ&&(t.nextZ.prevZ=t.prevZ)}function s$(t,e,n){this.i=t,this.x=e,this.y=n,this.prev=null,this.next=null,this.z=0,this.prevZ=null,this.nextZ=null,this.steiner=!1}Yw.deviation=function(t,e,n,i){var o=e&&e.length,a=o?e[0]*n:t.length,s=Math.abs(l$(t,0,a,n));if(o)for(var l=0,r=e.length;l0&&(i+=t[o-1].length,n.holes.push(i))}return n}});var oft=Zo((i7n,ift)=>{"use strict";var o7n=b(W());ift.exports=Vre;var FX=1e20;function Vre(t,e){e||(e={});var n=e.cutoff==null?.25:e.cutoff,i=e.radius==null?8:e.radius,o=e.channel||0,a,s,l,r,d,m,h,u,R,V,F;if(ArrayBuffer.isView(t)||Array.isArray(t)){if(!e.width||!e.height)throw Error("For raw data width and height should be provided by options");a=e.width,s=e.height,r=t,e.stride?m=e.stride:m=Math.floor(t.length/a/s)}else window.HTMLCanvasElement&&t instanceof window.HTMLCanvasElement?(u=t,h=u.getContext("2d"),a=u.width,s=u.height,R=h.getImageData(0,0,a,s),r=R.data,m=4):window.CanvasRenderingContext2D&&t instanceof window.CanvasRenderingContext2D?(u=t.canvas,h=t,a=u.width,s=u.height,R=h.getImageData(0,0,a,s),r=R.data,m=4):window.ImageData&&t instanceof window.ImageData&&(R=t,a=t.width,s=t.height,r=R.data,m=4);if(l=Math.max(a,s),window.Uint8ClampedArray&&r instanceof window.Uint8ClampedArray||window.Uint8Array&&r instanceof window.Uint8Array)for(d=r,r=Array(a*s),V=0,F=Math.floor(d.length/m);V{var A7n=b(W());function Sre(){var t=0,e=1,n=2,i=3,o=4,a=5,s=6,l=7,r=8,d=9,m=10,h=11,u=12,R=13,V=14,F=15,U=16,G=17,A=0,S=1,g=2,C=3,y=4;function Y(Z,E){return 55296<=Z.charCodeAt(E)&&Z.charCodeAt(E)<=56319&&56320<=Z.charCodeAt(E+1)&&Z.charCodeAt(E+1)<=57343}function Q(Z,E){E===void 0&&(E=0);var I=Z.charCodeAt(E);if(55296<=I&&I<=56319&&E=1){var B=Z.charCodeAt(E-1),X=I;return 55296<=B&&B<=56319?(B-55296)*1024+(X-56320)+65536:X}return I}function J(Z,E,I){var B=[Z].concat(E).concat([I]),X=B[B.length-2],_=I,P=B.lastIndexOf(V);if(P>1&&B.slice(1,P).every(function(H){return H==i})&&[i,R,G].indexOf(Z)==-1)return g;var w=B.lastIndexOf(o);if(w>0&&B.slice(1,w).every(function(H){return H==o})&&[u,o].indexOf(X)==-1)return B.filter(function(H){return H==o}).length%2==1?C:y;if(X==t&&_==e)return A;if(X==n||X==t||X==e)return _==V&&E.every(function(H){return H==i})?g:S;if(_==n||_==t||_==e)return S;if(X==s&&(_==s||_==l||_==d||_==m))return A;if((X==d||X==l)&&(_==l||_==r))return A;if((X==m||X==r)&&_==r)return A;if(_==i||_==F)return A;if(_==a)return A;if(X==u)return A;var z=B.indexOf(i)!=-1?B.lastIndexOf(i)-1:B.length-2;return[R,G].indexOf(B[z])!=-1&&B.slice(z+1,-1).every(function(H){return H==i})&&_==V||X==F&&[U,G].indexOf(_)!=-1?A:E.indexOf(o)!=-1?g:X==o&&_==o?A:S}this.nextBreak=function(Z,E){if(E===void 0&&(E=0),E<0)return 0;if(E>=Z.length-1)return Z.length;for(var I=M(Q(Z,E)),B=[],X=E+1;X{var $gi=b(W());(function(t,e){typeof wet=="object"&&typeof Pet<"u"?Pet.exports=e():typeof define=="function"&&define.amd?define(e):(t=t||self).RBush=e()})(wet,function(){"use strict";function t(U,G,A,S,g){(function C(y,Y,Q,J,M){for(;J>Q;){if(J-Q>600){var Z=J-Q+1,E=Y-Q+1,I=Math.log(Z),B=.5*Math.exp(2*I/3),X=.5*Math.sqrt(I*B*(Z-B)/Z)*(E-Z/2<0?-1:1),_=Math.max(Q,Math.floor(Y-E*B/Z+X)),P=Math.min(J,Math.floor(Y+(Z-E)*B/Z+X));C(y,Y,_,P,M)}var w=y[Y],z=Q,H=J;for(e(y,Q,Y),M(y[J],w)>0&&e(y,Q,J);z0;)H--}M(y[Q],w)===0?e(y,Q,H):e(y,++H,J),H<=Y&&(Q=H+1),Y<=H&&(J=H-1)}})(U,G,A||0,S||U.length-1,g||n)}function e(U,G,A){var S=U[G];U[G]=U[A],U[A]=S}function n(U,G){return UG?1:0}var i=function(U){U===void 0&&(U=9),this._maxEntries=Math.max(4,U),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()};function o(U,G,A){if(!A)return G.indexOf(U);for(var S=0;S=U.minX&&G.maxY>=U.minY}function V(U){return{children:U,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function F(U,G,A,S,g){for(var C=[G,A];C.length;)if(!((A=C.pop())-(G=C.pop())<=S)){var y=G+Math.ceil((A-G)/S/2)*S;t(U,y,G,A,g),C.push(G,y,y,A)}}return i.prototype.all=function(){return this._all(this.data,[])},i.prototype.search=function(U){var G=this.data,A=[];if(!R(U,G))return A;for(var S=this.toBBox,g=[];G;){for(var C=0;C=0&&g[G].children.length>this._maxEntries;)this._split(g,G),G--;this._adjustParentBBoxes(S,g,G)},i.prototype._split=function(U,G){var A=U[G],S=A.children.length,g=this._minEntries;this._chooseSplitAxis(A,g,S);var C=this._chooseSplitIndex(A,g,S),y=V(A.children.splice(C,A.children.length-C));y.height=A.height,y.leaf=A.leaf,a(A,this.toBBox),a(y,this.toBBox),G?U[G-1].children.push(y):this._splitRoot(A,y)},i.prototype._splitRoot=function(U,G){this.data=V([U,G]),this.data.height=U.height+1,this.data.leaf=!1,a(this.data,this.toBBox)},i.prototype._chooseSplitIndex=function(U,G,A){for(var S,g,C,y,Y,Q,J,M=1/0,Z=1/0,E=G;E<=A-G;E++){var I=s(U,0,E,this.toBBox),B=s(U,E,A,this.toBBox),X=(g=I,C=B,y=void 0,Y=void 0,Q=void 0,J=void 0,y=Math.max(g.minX,C.minX),Y=Math.max(g.minY,C.minY),Q=Math.min(g.maxX,C.maxX),J=Math.min(g.maxY,C.maxY),Math.max(0,Q-y)*Math.max(0,J-Y)),_=m(I)+m(B);X=G;M--){var Z=U.children[M];l(y,U.leaf?g(Z):Z),Y+=h(y)}return Y},i.prototype._adjustParentBBoxes=function(U,G,A){for(var S=A;S>=0;S--)l(G[S],U)},i.prototype._condense=function(U){for(var G=U.length-1,A=void 0;G>=0;G--)U[G].children.length===0?G>0?(A=U[G-1].children).splice(A.indexOf(U[G]),1):this.clear():a(U[G],this.toBBox)},i})});var zEt=Zo((DI,oM)=>{var AJi=b(W());/** * @license * Lodash * Copyright OpenJS Foundation and other contributors * Released under MIT license * Based on Underscore.js 1.8.3 * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors - */(function(){var t,e="4.17.21",n=200,i="Unsupported core-js use. Try https://npms.io/search?q=ponyfill.",o="Expected a function",a="Invalid `variable` option passed into `_.template`",s="__lodash_hash_undefined__",l=500,r="__lodash_placeholder__",d=1,m=2,h=4,Z=1,b=2,u=1,F=2,U=4,G=8,A=16,T=32,g=64,C=128,y=256,Y=512,Q=30,J="...",M=800,V=16,E=1,I=2,B=3,X=1/0,_=9007199254740991,P=17976931348623157e292,w=NaN,z=4294967295,H=z-1,nt=z>>>1,$=[["ary",C],["bind",u],["bindKey",F],["curry",G],["curryRight",A],["flip",Y],["partial",T],["partialRight",g],["rearg",y]],dt="[object Arguments]",q="[object Array]",at="[object AsyncFunction]",st="[object Boolean]",Et="[object Date]",Qt="[object DOMException]",Wt="[object Error]",Nt="[object Function]",kt="[object GeneratorFunction]",Mt="[object Map]",qt="[object Number]",ie="[object Null]",oe="[object Object]",He="[object Promise]",rn="[object Proxy]",de="[object RegExp]",zt="[object Set]",ke="[object String]",ue="[object Symbol]",We="[object Undefined]",un="[object WeakMap]",Ct="[object WeakSet]",_t="[object ArrayBuffer]",Je="[object DataView]",xe="[object Float32Array]",oo="[object Float64Array]",ea="[object Int8Array]",gs="[object Int16Array]",is="[object Int32Array]",ja="[object Uint8Array]",qn="[object Uint8ClampedArray]",ae="[object Uint16Array]",fe="[object Uint32Array]",ge=/\b__p \+= '';/g,Ze=/\b(__p \+=) '' \+/g,Ke=/(__e\(.*?\)|\b__t\)) \+\n'';/g,An=/&(?:amp|lt|gt|quot|#39);/g,si=/[&<>"']/g,da=RegExp(An.source),_a=RegExp(si.source),bl=/<%-([\s\S]+?)%>/g,na=/<%([\s\S]+?)%>/g,Go=/<%=([\s\S]+?)%>/g,Ao=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Xs=/^\w*$/,Es=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,wl=/[\\^$.*+?()[\]{}|]/g,ka=RegExp(wl.source),Wa=/^\s+/,Ju=/\s/,yl=/\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/,Bi=/\{\n\/\* \[wrapped with (.+)\] \*/,sd=/,? & /,zi=/[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g,js=/[()=,{}\[\]\/\s]/,ca=/\\(\\)?/g,$n=/\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g,mr=/\w*$/,hr=/^[-+]0x[0-9a-f]+$/i,pr=/^0b[01]+$/i,hs=/^\[object .+?Constructor\]$/,ma=/^0o[0-7]+$/i,Ed=/^(?:0|[1-9]\d*)$/,BW=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g,Rc=/($^)/,$b=/['\n\r\u2028\u2029\\]/g,Zp="\\ud800-\\udfff",Lu="\\u0300-\\u036f",QW="\\ufe20-\\ufe2f",tR="\\u20d0-\\u20ff",kW=Lu+QW+tR,YW="\\u2700-\\u27bf",pg="a-z\\xdf-\\xf6\\xf8-\\xff",MU="\\xac\\xb1\\xd7\\xf7",lh="\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf",Vp="\\u2000-\\u206f",lm=" \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000",_U="A-Z\\xc0-\\xd6\\xd8-\\xde",DU="\\ufe0e\\ufe0f",Mu=MU+lh+Vp+lm,eR="['\u2019]",ug="["+Zp+"]",bp="["+Mu+"]",Rp="["+kW+"]",kr="\\d+",fV="["+YW+"]",xW="["+pg+"]",XW="[^"+Zp+Mu+kr+YW+pg+_U+"]",OU="\\ud83c[\\udffb-\\udfff]",nR="(?:"+Rp+"|"+OU+")",rh="[^"+Zp+"]",HU="(?:\\ud83c[\\udde6-\\uddff]){2}",Js="[\\ud800-\\udbff][\\udc00-\\udfff]",ld="["+_U+"]",iR="\\u200d",wU="(?:"+xW+"|"+XW+")",PU="(?:"+ld+"|"+XW+")",JW="(?:"+eR+"(?:d|ll|m|re|s|t|ve))?",FV="(?:"+eR+"(?:D|LL|M|RE|S|T|VE))?",vU=nR+"?",Zg="["+DU+"]?",Vg="(?:"+iR+"(?:"+[rh,HU,Js].join("|")+")"+Zg+vU+")*",oR="\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?=\\b|[A-Z_])",SN="\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?=\\b|[a-z_])",Cd=Zg+vU+Vg,KU="(?:"+[fV,HU,Js].join("|")+")"+Cd,bg="(?:"+[rh+Rp+"?",Rp,HU,Js,ug].join("|")+")",rm=RegExp(eR,"g"),Rg=RegExp(Rp,"g"),LW=RegExp(OU+"(?="+OU+")|"+bg+Cd,"g"),Id=RegExp([ld+"?"+xW+"+"+JW+"(?="+[bp,ld,"$"].join("|")+")",PU+"+"+FV+"(?="+[bp,ld+wU,"$"].join("|")+")",ld+"?"+wU+"+"+JW,ld+"+"+FV,SN,oR,kr,KU].join("|"),"g"),MW=RegExp("["+iR+Zp+kW+DU+"]"),Wg=/[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/,fg=["Array","Buffer","DataView","Date","Error","Float32Array","Float64Array","Function","Int8Array","Int16Array","Int32Array","Map","Math","Object","Promise","RegExp","Set","String","Symbol","TypeError","Uint8Array","Uint8ClampedArray","Uint16Array","Uint32Array","WeakMap","_","clearTimeout","isFinite","parseInt","setTimeout"],dm=-1,Da={};Da[xe]=Da[oo]=Da[ea]=Da[gs]=Da[is]=Da[ja]=Da[qn]=Da[ae]=Da[fe]=!0,Da[dt]=Da[q]=Da[_t]=Da[st]=Da[Je]=Da[Et]=Da[Wt]=Da[Nt]=Da[Mt]=Da[qt]=Da[oe]=Da[de]=Da[zt]=Da[ke]=Da[un]=!1;var Zn={};Zn[dt]=Zn[q]=Zn[_t]=Zn[Je]=Zn[st]=Zn[Et]=Zn[xe]=Zn[oo]=Zn[ea]=Zn[gs]=Zn[is]=Zn[Mt]=Zn[qt]=Zn[oe]=Zn[de]=Zn[zt]=Zn[ke]=Zn[ue]=Zn[ja]=Zn[qn]=Zn[ae]=Zn[fe]=!0,Zn[Wt]=Zn[Nt]=Zn[un]=!1;var Kt={\u00C0:"A",\u00C1:"A",\u00C2:"A",\u00C3:"A",\u00C4:"A",\u00C5:"A",\u00E0:"a",\u00E1:"a",\u00E2:"a",\u00E3:"a",\u00E4:"a",\u00E5:"a",\u00C7:"C",\u00E7:"c",\u00D0:"D",\u00F0:"d",\u00C8:"E",\u00C9:"E",\u00CA:"E",\u00CB:"E",\u00E8:"e",\u00E9:"e",\u00EA:"e",\u00EB:"e",\u00CC:"I",\u00CD:"I",\u00CE:"I",\u00CF:"I",\u00EC:"i",\u00ED:"i",\u00EE:"i",\u00EF:"i",\u00D1:"N",\u00F1:"n",\u00D2:"O",\u00D3:"O",\u00D4:"O",\u00D5:"O",\u00D6:"O",\u00D8:"O",\u00F2:"o",\u00F3:"o",\u00F4:"o",\u00F5:"o",\u00F6:"o",\u00F8:"o",\u00D9:"U",\u00DA:"U",\u00DB:"U",\u00DC:"U",\u00F9:"u",\u00FA:"u",\u00FB:"u",\u00FC:"u",\u00DD:"Y",\u00FD:"y",\u00FF:"y",\u00C6:"Ae",\u00E6:"ae",\u00DE:"Th",\u00FE:"th",\u00DF:"ss",\u0100:"A",\u0102:"A",\u0104:"A",\u0101:"a",\u0103:"a",\u0105:"a",\u0106:"C",\u0108:"C",\u010A:"C",\u010C:"C",\u0107:"c",\u0109:"c",\u010B:"c",\u010D:"c",\u010E:"D",\u0110:"D",\u010F:"d",\u0111:"d",\u0112:"E",\u0114:"E",\u0116:"E",\u0118:"E",\u011A:"E",\u0113:"e",\u0115:"e",\u0117:"e",\u0119:"e",\u011B:"e",\u011C:"G",\u011E:"G",\u0120:"G",\u0122:"G",\u011D:"g",\u011F:"g",\u0121:"g",\u0123:"g",\u0124:"H",\u0126:"H",\u0125:"h",\u0127:"h",\u0128:"I",\u012A:"I",\u012C:"I",\u012E:"I",\u0130:"I",\u0129:"i",\u012B:"i",\u012D:"i",\u012F:"i",\u0131:"i",\u0134:"J",\u0135:"j",\u0136:"K",\u0137:"k",\u0138:"k",\u0139:"L",\u013B:"L",\u013D:"L",\u013F:"L",\u0141:"L",\u013A:"l",\u013C:"l",\u013E:"l",\u0140:"l",\u0142:"l",\u0143:"N",\u0145:"N",\u0147:"N",\u014A:"N",\u0144:"n",\u0146:"n",\u0148:"n",\u014B:"n",\u014C:"O",\u014E:"O",\u0150:"O",\u014D:"o",\u014F:"o",\u0151:"o",\u0154:"R",\u0156:"R",\u0158:"R",\u0155:"r",\u0157:"r",\u0159:"r",\u015A:"S",\u015C:"S",\u015E:"S",\u0160:"S",\u015B:"s",\u015D:"s",\u015F:"s",\u0161:"s",\u0162:"T",\u0164:"T",\u0166:"T",\u0163:"t",\u0165:"t",\u0167:"t",\u0168:"U",\u016A:"U",\u016C:"U",\u016E:"U",\u0170:"U",\u0172:"U",\u0169:"u",\u016B:"u",\u016D:"u",\u016F:"u",\u0171:"u",\u0173:"u",\u0174:"W",\u0175:"w",\u0176:"Y",\u0177:"y",\u0178:"Y",\u0179:"Z",\u017B:"Z",\u017D:"Z",\u017A:"z",\u017C:"z",\u017E:"z",\u0132:"IJ",\u0133:"ij",\u0152:"Oe",\u0153:"oe",\u0149:"'n",\u017F:"s"},De={"&":"&","<":"<",">":">",'"':""","'":"'"},ti={"&":"&","<":"<",">":">",""":'"',"'":"'"},Hi={"\\":"\\","'":"'","\n":"n","\r":"r","\u2028":"u2028","\u2029":"u2029"},Rl=parseFloat,Pl=parseInt,Bl=typeof global=="object"&&global&&global.Object===Object&&global,Yr=typeof self=="object"&&self&&self.Object===Object&&self,ps=Bl||Yr||Function("return this")(),Ql=typeof DI=="object"&&DI&&!DI.nodeType&&DI,Wp=Ql&&typeof oM=="object"&&oM&&!oM.nodeType&&oM,zU=Wp&&Wp.exports===Ql,Fg=zU&&Bl.process,Ls=function(){try{var vt=Wp&&Wp.require&&Wp.require("util").types;return vt||Fg&&Fg.binding&&Fg.binding("util")}catch{}}(),Ug=Ls&&Ls.isArrayBuffer,lO=Ls&&Ls.isDate,rO=Ls&&Ls.isMap,dh=Ls&&Ls.isRegExp,dO=Ls&&Ls.isSet,aR=Ls&&Ls.isTypedArray;function Wc(vt,Te,me){switch(me.length){case 0:return vt.call(Te);case 1:return vt.call(Te,me[0]);case 2:return vt.call(Te,me[0],me[1]);case 3:return vt.call(Te,me[0],me[1],me[2])}return vt.apply(Te,me)}function y4(vt,Te,me,Jn){for(var Ai=-1,ia=vt==null?0:vt.length;++Ai-1}function DW(vt,Te,me){for(var Jn=-1,Ai=vt==null?0:vt.length;++Jn-1;);return me}function bO(vt,Te){for(var me=vt.length;me--&&HW(Te,vt[me],0)>-1;);return me}function J4(vt,Te){for(var me=vt.length,Jn=0;me--;)vt[me]===Te&&++Jn;return Jn}var L4=CN(Kt),M4=CN(De);function RO(vt){return"\\"+Hi[vt]}function _4(vt,Te){return vt==null?t:vt[Te]}function PW(vt){return MW.test(vt)}function Tg(vt){return Wg.test(vt)}function D4(vt){for(var Te,me=[];!(Te=vt.next()).done;)me.push(Te.value);return me}function yN(vt){var Te=-1,me=Array(vt.size);return vt.forEach(function(Jn,Ai){me[++Te]=[Ai,Jn]}),me}function WO(vt,Te){return function(me){return vt(Te(me))}}function AV(vt,Te){for(var me=-1,Jn=vt.length,Ai=0,ia=[];++me-1}function en(S,N){var O=this.__data__,tt=TO(O,S);return tt<0?(++this.size,O.push([S,N])):O[tt][1]=N,this}yt.prototype.clear=Yt,yt.prototype.delete=Dt,yt.prototype.get=pe,yt.prototype.has=Se,yt.prototype.set=en;function Vn(S){var N=-1,O=S==null?0:S.length;for(this.clear();++N=N?S:N)),S}function fp(S,N,O,tt,ct,Tt){var Jt,Ht=N&d,$t=N&m,ye=N&h;if(O&&(Jt=ct?O(S,tt,ct,Tt):O(S)),Jt!==t)return Jt;if(!qs(S))return S;var Be=ji(S);if(Be){if(Jt=_Yt(S),!Ht)return um(S,Jt)}else{var Oe=yd(S),Bn=Oe==Nt||Oe==kt;if(af(S))return kdt(S,Ht);if(Oe==oe||Oe==dt||Bn&&!ct){if(Jt=$t||Bn?{}:tct(S),!Ht)return $t?NYt(S,tYt(Jt,S)):IYt(S,mdt(Jt,S))}else{if(!Zn[Oe])return ct?S:{};Jt=DYt(S,Oe,Ht)}}Tt||(Tt=new fa);var li=Tt.get(S);if(li)return li;Tt.set(S,Jt),Cct(S)?S.forEach(function(ki){Jt.add(fp(ki,N,O,ki,S,Tt))}):gct(S)&&S.forEach(function(ki,No){Jt.set(No,fp(ki,N,O,No,S,Tt))});var Qi=ye?$t?N8:I8:$t?Vm:xr,Zo=Be?t:Qi(S);return cm(Zo||S,function(ki,No){Zo&&(No=ki,ki=S[No]),MN(Jt,No,fp(ki,N,O,No,S,Tt))}),Jt}function eYt(S){var N=xr(S);return function(O){return hdt(O,S,N)}}function hdt(S,N,O){var tt=O.length;if(S==null)return!tt;for(S=Oa(S);tt--;){var ct=O[tt],Tt=N[ct],Jt=S[ct];if(Jt===t&&!(ct in S)||!Tt(Jt))return!1}return!0}function pdt(S,N,O){if(typeof S!="function")throw new hm(o);return vN(function(){S.apply(t,O)},N)}function _N(S,N,O,tt){var ct=-1,Tt=_W,Jt=!0,Ht=S.length,$t=[],ye=N.length;if(!Ht)return $t;O&&(N=Ta(N,fc(O))),tt?(Tt=DW,Jt=!1):N.length>=n&&(Tt=jU,Jt=!1,N=new Oo(N));t:for(;++ctct?0:ct+O),tt=tt===t||tt>ct?ct:po(tt),tt<0&&(tt+=ct),tt=O>tt?0:Nct(tt);O0&&O(Ht)?N>1?rd(Ht,N-1,O,tt,ct):_u(ct,Ht):tt||(ct[ct.length]=Ht)}return ct}var h8=Mdt(),Vdt=Mdt(!0);function gV(S,N){return S&&h8(S,N,xr)}function p8(S,N){return S&&Vdt(S,N,xr)}function gO(S,N){return UV(N,function(O){return pR(S[O])})}function sG(S,N){N=nf(N,S);for(var O=0,tt=N.length;S!=null&&ON}function oYt(S,N){return S!=null&&ga.call(S,N)}function aYt(S,N){return S!=null&&N in Oa(S)}function sYt(S,N,O){return S>=us(N,O)&&S=120&&Be.length>=120)?new Oo(Jt&&Be):t}Be=S[0];var Oe=-1,Bn=Ht[0];t:for(;++Oe-1;)Ht!==S&&Bg.call(Ht,$t,1),Bg.call(S,$t,1);return S}function gdt(S,N){for(var O=S?N.length:0,tt=O-1;O--;){var ct=N[O];if(O==tt||ct!==Tt){var Tt=ct;hR(ct)?Bg.call(S,ct,1):G8(S,ct)}}return S}function f8(S,N){return S+lR(UO()*(N-S+1))}function WYt(S,N,O,tt){for(var ct=-1,Tt=Ms(eG((N-S)/(O||1)),0),Jt=me(Tt);Tt--;)Jt[tt?Tt:++ct]=S,S+=O;return Jt}function F8(S,N){var O="";if(!S||N<1||N>_)return O;do N%2&&(O+=S),N=lR(N/2),N&&(S+=S);while(N);return O}function Fo(S,N){return X8(ict(S,N,bm),S+"")}function fYt(S){return cdt(Dg(S))}function FYt(S,N){var O=Dg(S);return XO(O,aG(N,0,O.length))}function HN(S,N,O,tt){if(!qs(S))return S;N=nf(N,S);for(var ct=-1,Tt=N.length,Jt=Tt-1,Ht=S;Ht!=null&&++ctct?0:ct+N),O=O>ct?ct:O,O<0&&(O+=ct),ct=N>O?0:O-N>>>0,N>>>=0;for(var Tt=me(ct);++tt>>1,Jt=S[Tt];Jt!==null&&!mh(Jt)&&(O?Jt<=N:Jt=n){var ye=N?null:kYt(S);if(ye)return qU(ye);Jt=!1,ct=jU,$t=new Oo}else $t=N?[]:Ht;t:for(;++tt=tt?S:Fp(S,N,O)}var Qdt=t8||function(S){return ps.clearTimeout(S)};function kdt(S,N){if(N)return S.slice();var O=S.length,tt=fO?fO(O):new S.constructor(O);return S.copy(tt),tt}function g8(S){var N=new S.constructor(S.byteLength);return new Ng(N).set(new Ng(S)),N}function SYt(S,N){var O=N?g8(S.buffer):S.buffer;return new S.constructor(O,S.byteOffset,S.byteLength)}function gYt(S){var N=new S.constructor(S.source,mr.exec(S));return N.lastIndex=S.lastIndex,N}function EYt(S){return Yg?Oa(Yg.call(S)):{}}function Ydt(S,N){var O=N?g8(S.buffer):S.buffer;return new S.constructor(O,S.byteOffset,S.length)}function xdt(S,N){if(S!==N){var O=S!==t,tt=S===null,ct=S===S,Tt=mh(S),Jt=N!==t,Ht=N===null,$t=N===N,ye=mh(N);if(!Ht&&!ye&&!Tt&&S>N||Tt&&Jt&&$t&&!Ht&&!ye||tt&&Jt&&$t||!O&&$t||!ct)return 1;if(!tt&&!Tt&&!ye&&S=Ht)return $t;var ye=O[tt];return $t*(ye=="desc"?-1:1)}}return S.index-N.index}function Xdt(S,N,O,tt){for(var ct=-1,Tt=S.length,Jt=O.length,Ht=-1,$t=N.length,ye=Ms(Tt-Jt,0),Be=me($t+ye),Oe=!tt;++Ht<$t;)Be[Ht]=N[Ht];for(;++ct1?O[ct-1]:t,Jt=ct>2?O[2]:t;for(Tt=S.length>3&&typeof Tt=="function"?(ct--,Tt):t,Jt&&Uc(O[0],O[1],Jt)&&(Tt=ct<3?t:Tt,ct=1),N=Oa(N);++tt-1?ct[Tt?N[Jt]:Jt]:t}}function Odt(S){return mR(function(N){var O=N.length,tt=O,ct=pm.prototype.thru;for(S&&N.reverse();tt--;){var Tt=N[tt];if(typeof Tt!="function")throw new hm(o);if(ct&&!Jt&&YO(Tt)=="wrapper")var Jt=new pm([],!0)}for(tt=Jt?tt:O;++tt1&&Ko.reverse(),Be&&$tHt))return!1;var ye=Tt.get(S),Be=Tt.get(N);if(ye&&Be)return ye==N&&Be==S;var Oe=-1,Bn=!0,li=O&b?new Oo:t;for(Tt.set(S,N),Tt.set(N,S);++Oe1?"& ":"")+N[tt],N=N.join(O>2?", ":" "),S.replace(yl,`{ + */(function(){var t,e="4.17.21",n=200,i="Unsupported core-js use. Try https://npms.io/search?q=ponyfill.",o="Expected a function",a="Invalid `variable` option passed into `_.template`",s="__lodash_hash_undefined__",l=500,r="__lodash_placeholder__",d=1,m=2,h=4,u=1,R=2,V=1,F=2,U=4,G=8,A=16,S=32,g=64,C=128,y=256,Y=512,Q=30,J="...",M=800,Z=16,E=1,I=2,B=3,X=1/0,_=9007199254740991,P=17976931348623157e292,w=NaN,z=4294967295,H=z-1,nt=z>>>1,$=[["ary",C],["bind",V],["bindKey",F],["curry",G],["curryRight",A],["flip",Y],["partial",S],["partialRight",g],["rearg",y]],dt="[object Arguments]",q="[object Array]",at="[object AsyncFunction]",st="[object Boolean]",Et="[object Date]",Qt="[object DOMException]",Wt="[object Error]",Nt="[object Function]",kt="[object GeneratorFunction]",Mt="[object Map]",qt="[object Number]",ie="[object Null]",oe="[object Object]",He="[object Promise]",rn="[object Proxy]",de="[object RegExp]",zt="[object Set]",ke="[object String]",Ve="[object Symbol]",We="[object Undefined]",Vn="[object WeakMap]",Ct="[object WeakSet]",_t="[object ArrayBuffer]",Je="[object DataView]",xe="[object Float32Array]",oo="[object Float64Array]",ea="[object Int8Array]",gs="[object Int16Array]",is="[object Int32Array]",ja="[object Uint8Array]",qn="[object Uint8ClampedArray]",ae="[object Uint16Array]",fe="[object Uint32Array]",ge=/\b__p \+= '';/g,ue=/\b(__p \+=) '' \+/g,Ke=/(__e\(.*?\)|\b__t\)) \+\n'';/g,An=/&(?:amp|lt|gt|quot|#39);/g,si=/[&<>"']/g,da=RegExp(An.source),_a=RegExp(si.source),Rl=/<%-([\s\S]+?)%>/g,na=/<%([\s\S]+?)%>/g,Go=/<%=([\s\S]+?)%>/g,Ao=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Xs=/^\w*$/,Es=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,wl=/[\\^$.*+?()[\]{}|]/g,ka=RegExp(wl.source),Wa=/^\s+/,JV=/\s/,yl=/\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/,Bi=/\{\n\/\* \[wrapped with (.+)\] \*/,sd=/,? & /,zi=/[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g,js=/[()=,{}\[\]\/\s]/,ca=/\\(\\)?/g,$n=/\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g,mr=/\w*$/,hr=/^[-+]0x[0-9a-f]+$/i,pr=/^0b[01]+$/i,hs=/^\[object .+?Constructor\]$/,ma=/^0o[0-7]+$/i,Ed=/^(?:0|[1-9]\d*)$/,BW=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g,bc=/($^)/,$R=/['\n\r\u2028\u2029\\]/g,up="\\ud800-\\udfff",LV="\\u0300-\\u036f",QW="\\ufe20-\\ufe2f",tb="\\u20d0-\\u20ff",kW=LV+QW+tb,YW="\\u2700-\\u27bf",pg="a-z\\xdf-\\xf6\\xf8-\\xff",MU="\\xac\\xb1\\xd7\\xf7",lh="\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf",Zp="\\u2000-\\u206f",lm=" \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000",_U="A-Z\\xc0-\\xd6\\xd8-\\xde",DU="\\ufe0e\\ufe0f",MV=MU+lh+Zp+lm,eb="['\u2019]",Vg="["+up+"]",Rp="["+MV+"]",bp="["+kW+"]",kr="\\d+",fZ="["+YW+"]",xW="["+pg+"]",XW="[^"+up+MV+kr+YW+pg+_U+"]",OU="\\ud83c[\\udffb-\\udfff]",nb="(?:"+bp+"|"+OU+")",rh="[^"+up+"]",HU="(?:\\ud83c[\\udde6-\\uddff]){2}",Js="[\\ud800-\\udbff][\\udc00-\\udfff]",ld="["+_U+"]",ib="\\u200d",wU="(?:"+xW+"|"+XW+")",PU="(?:"+ld+"|"+XW+")",JW="(?:"+eb+"(?:d|ll|m|re|s|t|ve))?",FZ="(?:"+eb+"(?:D|LL|M|RE|S|T|VE))?",vU=nb+"?",ug="["+DU+"]?",Zg="(?:"+ib+"(?:"+[rh,HU,Js].join("|")+")"+ug+vU+")*",ob="\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?=\\b|[A-Z_])",TN="\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?=\\b|[a-z_])",Cd=ug+vU+Zg,KU="(?:"+[fZ,HU,Js].join("|")+")"+Cd,Rg="(?:"+[rh+bp+"?",bp,HU,Js,Vg].join("|")+")",rm=RegExp(eb,"g"),bg=RegExp(bp,"g"),LW=RegExp(OU+"(?="+OU+")|"+Rg+Cd,"g"),Id=RegExp([ld+"?"+xW+"+"+JW+"(?="+[Rp,ld,"$"].join("|")+")",PU+"+"+FZ+"(?="+[Rp,ld+wU,"$"].join("|")+")",ld+"?"+wU+"+"+JW,ld+"+"+FZ,TN,ob,kr,KU].join("|"),"g"),MW=RegExp("["+ib+up+kW+DU+"]"),Wg=/[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/,fg=["Array","Buffer","DataView","Date","Error","Float32Array","Float64Array","Function","Int8Array","Int16Array","Int32Array","Map","Math","Object","Promise","RegExp","Set","String","Symbol","TypeError","Uint8Array","Uint8ClampedArray","Uint16Array","Uint32Array","WeakMap","_","clearTimeout","isFinite","parseInt","setTimeout"],dm=-1,Da={};Da[xe]=Da[oo]=Da[ea]=Da[gs]=Da[is]=Da[ja]=Da[qn]=Da[ae]=Da[fe]=!0,Da[dt]=Da[q]=Da[_t]=Da[st]=Da[Je]=Da[Et]=Da[Wt]=Da[Nt]=Da[Mt]=Da[qt]=Da[oe]=Da[de]=Da[zt]=Da[ke]=Da[Vn]=!1;var un={};un[dt]=un[q]=un[_t]=un[Je]=un[st]=un[Et]=un[xe]=un[oo]=un[ea]=un[gs]=un[is]=un[Mt]=un[qt]=un[oe]=un[de]=un[zt]=un[ke]=un[Ve]=un[ja]=un[qn]=un[ae]=un[fe]=!0,un[Wt]=un[Nt]=un[Vn]=!1;var Kt={\u00C0:"A",\u00C1:"A",\u00C2:"A",\u00C3:"A",\u00C4:"A",\u00C5:"A",\u00E0:"a",\u00E1:"a",\u00E2:"a",\u00E3:"a",\u00E4:"a",\u00E5:"a",\u00C7:"C",\u00E7:"c",\u00D0:"D",\u00F0:"d",\u00C8:"E",\u00C9:"E",\u00CA:"E",\u00CB:"E",\u00E8:"e",\u00E9:"e",\u00EA:"e",\u00EB:"e",\u00CC:"I",\u00CD:"I",\u00CE:"I",\u00CF:"I",\u00EC:"i",\u00ED:"i",\u00EE:"i",\u00EF:"i",\u00D1:"N",\u00F1:"n",\u00D2:"O",\u00D3:"O",\u00D4:"O",\u00D5:"O",\u00D6:"O",\u00D8:"O",\u00F2:"o",\u00F3:"o",\u00F4:"o",\u00F5:"o",\u00F6:"o",\u00F8:"o",\u00D9:"U",\u00DA:"U",\u00DB:"U",\u00DC:"U",\u00F9:"u",\u00FA:"u",\u00FB:"u",\u00FC:"u",\u00DD:"Y",\u00FD:"y",\u00FF:"y",\u00C6:"Ae",\u00E6:"ae",\u00DE:"Th",\u00FE:"th",\u00DF:"ss",\u0100:"A",\u0102:"A",\u0104:"A",\u0101:"a",\u0103:"a",\u0105:"a",\u0106:"C",\u0108:"C",\u010A:"C",\u010C:"C",\u0107:"c",\u0109:"c",\u010B:"c",\u010D:"c",\u010E:"D",\u0110:"D",\u010F:"d",\u0111:"d",\u0112:"E",\u0114:"E",\u0116:"E",\u0118:"E",\u011A:"E",\u0113:"e",\u0115:"e",\u0117:"e",\u0119:"e",\u011B:"e",\u011C:"G",\u011E:"G",\u0120:"G",\u0122:"G",\u011D:"g",\u011F:"g",\u0121:"g",\u0123:"g",\u0124:"H",\u0126:"H",\u0125:"h",\u0127:"h",\u0128:"I",\u012A:"I",\u012C:"I",\u012E:"I",\u0130:"I",\u0129:"i",\u012B:"i",\u012D:"i",\u012F:"i",\u0131:"i",\u0134:"J",\u0135:"j",\u0136:"K",\u0137:"k",\u0138:"k",\u0139:"L",\u013B:"L",\u013D:"L",\u013F:"L",\u0141:"L",\u013A:"l",\u013C:"l",\u013E:"l",\u0140:"l",\u0142:"l",\u0143:"N",\u0145:"N",\u0147:"N",\u014A:"N",\u0144:"n",\u0146:"n",\u0148:"n",\u014B:"n",\u014C:"O",\u014E:"O",\u0150:"O",\u014D:"o",\u014F:"o",\u0151:"o",\u0154:"R",\u0156:"R",\u0158:"R",\u0155:"r",\u0157:"r",\u0159:"r",\u015A:"S",\u015C:"S",\u015E:"S",\u0160:"S",\u015B:"s",\u015D:"s",\u015F:"s",\u0161:"s",\u0162:"T",\u0164:"T",\u0166:"T",\u0163:"t",\u0165:"t",\u0167:"t",\u0168:"U",\u016A:"U",\u016C:"U",\u016E:"U",\u0170:"U",\u0172:"U",\u0169:"u",\u016B:"u",\u016D:"u",\u016F:"u",\u0171:"u",\u0173:"u",\u0174:"W",\u0175:"w",\u0176:"Y",\u0177:"y",\u0178:"Y",\u0179:"Z",\u017B:"Z",\u017D:"Z",\u017A:"z",\u017C:"z",\u017E:"z",\u0132:"IJ",\u0133:"ij",\u0152:"Oe",\u0153:"oe",\u0149:"'n",\u017F:"s"},De={"&":"&","<":"<",">":">",'"':""","'":"'"},ti={"&":"&","<":"<",">":">",""":'"',"'":"'"},Hi={"\\":"\\","'":"'","\n":"n","\r":"r","\u2028":"u2028","\u2029":"u2029"},bl=parseFloat,Pl=parseInt,Bl=typeof global=="object"&&global&&global.Object===Object&&global,Yr=typeof self=="object"&&self&&self.Object===Object&&self,ps=Bl||Yr||Function("return this")(),Ql=typeof DI=="object"&&DI&&!DI.nodeType&&DI,Wp=Ql&&typeof oM=="object"&&oM&&!oM.nodeType&&oM,zU=Wp&&Wp.exports===Ql,Fg=zU&&Bl.process,Ls=function(){try{var vt=Wp&&Wp.require&&Wp.require("util").types;return vt||Fg&&Fg.binding&&Fg.binding("util")}catch{}}(),Ug=Ls&&Ls.isArrayBuffer,lO=Ls&&Ls.isDate,rO=Ls&&Ls.isMap,dh=Ls&&Ls.isRegExp,dO=Ls&&Ls.isSet,ab=Ls&&Ls.isTypedArray;function Wc(vt,Se,me){switch(me.length){case 0:return vt.call(Se);case 1:return vt.call(Se,me[0]);case 2:return vt.call(Se,me[0],me[1]);case 3:return vt.call(Se,me[0],me[1],me[2])}return vt.apply(Se,me)}function y4(vt,Se,me,Jn){for(var Ai=-1,ia=vt==null?0:vt.length;++Ai-1}function DW(vt,Se,me){for(var Jn=-1,Ai=vt==null?0:vt.length;++Jn-1;);return me}function RO(vt,Se){for(var me=vt.length;me--&&HW(Se,vt[me],0)>-1;);return me}function J4(vt,Se){for(var me=vt.length,Jn=0;me--;)vt[me]===Se&&++Jn;return Jn}var L4=CN(Kt),M4=CN(De);function bO(vt){return"\\"+Hi[vt]}function _4(vt,Se){return vt==null?t:vt[Se]}function PW(vt){return MW.test(vt)}function Sg(vt){return Wg.test(vt)}function D4(vt){for(var Se,me=[];!(Se=vt.next()).done;)me.push(Se.value);return me}function yN(vt){var Se=-1,me=Array(vt.size);return vt.forEach(function(Jn,Ai){me[++Se]=[Ai,Jn]}),me}function WO(vt,Se){return function(me){return vt(Se(me))}}function AZ(vt,Se){for(var me=-1,Jn=vt.length,Ai=0,ia=[];++me-1}function en(T,N){var O=this.__data__,tt=SO(O,T);return tt<0?(++this.size,O.push([T,N])):O[tt][1]=N,this}yt.prototype.clear=Yt,yt.prototype.delete=Dt,yt.prototype.get=pe,yt.prototype.has=Te,yt.prototype.set=en;function Zn(T){var N=-1,O=T==null?0:T.length;for(this.clear();++N=N?T:N)),T}function fp(T,N,O,tt,ct,St){var Jt,Ht=N&d,$t=N&m,ye=N&h;if(O&&(Jt=ct?O(T,tt,ct,St):O(T)),Jt!==t)return Jt;if(!qs(T))return T;var Be=ji(T);if(Be){if(Jt=_Yt(T),!Ht)return Vm(T,Jt)}else{var Oe=yd(T),Bn=Oe==Nt||Oe==kt;if(af(T))return kdt(T,Ht);if(Oe==oe||Oe==dt||Bn&&!ct){if(Jt=$t||Bn?{}:tct(T),!Ht)return $t?NYt(T,tYt(Jt,T)):IYt(T,mdt(Jt,T))}else{if(!un[Oe])return ct?T:{};Jt=DYt(T,Oe,Ht)}}St||(St=new fa);var li=St.get(T);if(li)return li;St.set(T,Jt),Cct(T)?T.forEach(function(ki){Jt.add(fp(ki,N,O,ki,T,St))}):gct(T)&&T.forEach(function(ki,No){Jt.set(No,fp(ki,N,O,No,T,St))});var Qi=ye?$t?N8:I8:$t?Zm:xr,uo=Be?t:Qi(T);return cm(uo||T,function(ki,No){uo&&(No=ki,ki=T[No]),MN(Jt,No,fp(ki,N,O,No,T,St))}),Jt}function eYt(T){var N=xr(T);return function(O){return hdt(O,T,N)}}function hdt(T,N,O){var tt=O.length;if(T==null)return!tt;for(T=Oa(T);tt--;){var ct=O[tt],St=N[ct],Jt=T[ct];if(Jt===t&&!(ct in T)||!St(Jt))return!1}return!0}function pdt(T,N,O){if(typeof T!="function")throw new hm(o);return vN(function(){T.apply(t,O)},N)}function _N(T,N,O,tt){var ct=-1,St=_W,Jt=!0,Ht=T.length,$t=[],ye=N.length;if(!Ht)return $t;O&&(N=Sa(N,fc(O))),tt?(St=DW,Jt=!1):N.length>=n&&(St=jU,Jt=!1,N=new Oo(N));t:for(;++ctct?0:ct+O),tt=tt===t||tt>ct?ct:po(tt),tt<0&&(tt+=ct),tt=O>tt?0:Nct(tt);O0&&O(Ht)?N>1?rd(Ht,N-1,O,tt,ct):_V(ct,Ht):tt||(ct[ct.length]=Ht)}return ct}var h8=Mdt(),Zdt=Mdt(!0);function gZ(T,N){return T&&h8(T,N,xr)}function p8(T,N){return T&&Zdt(T,N,xr)}function gO(T,N){return UZ(N,function(O){return pb(T[O])})}function sG(T,N){N=nf(N,T);for(var O=0,tt=N.length;T!=null&&ON}function oYt(T,N){return T!=null&&ga.call(T,N)}function aYt(T,N){return T!=null&&N in Oa(T)}function sYt(T,N,O){return T>=Vs(N,O)&&T=120&&Be.length>=120)?new Oo(Jt&&Be):t}Be=T[0];var Oe=-1,Bn=Ht[0];t:for(;++Oe-1;)Ht!==T&&Bg.call(Ht,$t,1),Bg.call(T,$t,1);return T}function gdt(T,N){for(var O=T?N.length:0,tt=O-1;O--;){var ct=N[O];if(O==tt||ct!==St){var St=ct;hb(ct)?Bg.call(T,ct,1):G8(T,ct)}}return T}function f8(T,N){return T+lb(UO()*(N-T+1))}function WYt(T,N,O,tt){for(var ct=-1,St=Ms(eG((N-T)/(O||1)),0),Jt=me(St);St--;)Jt[tt?St:++ct]=T,T+=O;return Jt}function F8(T,N){var O="";if(!T||N<1||N>_)return O;do N%2&&(O+=T),N=lb(N/2),N&&(T+=T);while(N);return O}function Fo(T,N){return X8(ict(T,N,Rm),T+"")}function fYt(T){return cdt(Dg(T))}function FYt(T,N){var O=Dg(T);return XO(O,aG(N,0,O.length))}function HN(T,N,O,tt){if(!qs(T))return T;N=nf(N,T);for(var ct=-1,St=N.length,Jt=St-1,Ht=T;Ht!=null&&++ctct?0:ct+N),O=O>ct?ct:O,O<0&&(O+=ct),ct=N>O?0:O-N>>>0,N>>>=0;for(var St=me(ct);++tt>>1,Jt=T[St];Jt!==null&&!mh(Jt)&&(O?Jt<=N:Jt=n){var ye=N?null:kYt(T);if(ye)return qU(ye);Jt=!1,ct=jU,$t=new Oo}else $t=N?[]:Ht;t:for(;++tt=tt?T:Fp(T,N,O)}var Qdt=t8||function(T){return ps.clearTimeout(T)};function kdt(T,N){if(N)return T.slice();var O=T.length,tt=fO?fO(O):new T.constructor(O);return T.copy(tt),tt}function g8(T){var N=new T.constructor(T.byteLength);return new Ng(N).set(new Ng(T)),N}function TYt(T,N){var O=N?g8(T.buffer):T.buffer;return new T.constructor(O,T.byteOffset,T.byteLength)}function gYt(T){var N=new T.constructor(T.source,mr.exec(T));return N.lastIndex=T.lastIndex,N}function EYt(T){return Yg?Oa(Yg.call(T)):{}}function Ydt(T,N){var O=N?g8(T.buffer):T.buffer;return new T.constructor(O,T.byteOffset,T.length)}function xdt(T,N){if(T!==N){var O=T!==t,tt=T===null,ct=T===T,St=mh(T),Jt=N!==t,Ht=N===null,$t=N===N,ye=mh(N);if(!Ht&&!ye&&!St&&T>N||St&&Jt&&$t&&!Ht&&!ye||tt&&Jt&&$t||!O&&$t||!ct)return 1;if(!tt&&!St&&!ye&&T=Ht)return $t;var ye=O[tt];return $t*(ye=="desc"?-1:1)}}return T.index-N.index}function Xdt(T,N,O,tt){for(var ct=-1,St=T.length,Jt=O.length,Ht=-1,$t=N.length,ye=Ms(St-Jt,0),Be=me($t+ye),Oe=!tt;++Ht<$t;)Be[Ht]=N[Ht];for(;++ct1?O[ct-1]:t,Jt=ct>2?O[2]:t;for(St=T.length>3&&typeof St=="function"?(ct--,St):t,Jt&&Uc(O[0],O[1],Jt)&&(St=ct<3?t:St,ct=1),N=Oa(N);++tt-1?ct[St?N[Jt]:Jt]:t}}function Odt(T){return mb(function(N){var O=N.length,tt=O,ct=pm.prototype.thru;for(T&&N.reverse();tt--;){var St=N[tt];if(typeof St!="function")throw new hm(o);if(ct&&!Jt&&YO(St)=="wrapper")var Jt=new pm([],!0)}for(tt=Jt?tt:O;++tt1&&Ko.reverse(),Be&&$tHt))return!1;var ye=St.get(T),Be=St.get(N);if(ye&&Be)return ye==N&&Be==T;var Oe=-1,Bn=!0,li=O&R?new Oo:t;for(St.set(T,N),St.set(N,T);++Oe1?"& ":"")+N[tt],N=N.join(O>2?", ":" "),T.replace(yl,`{ /* [wrapped with `+N+`] */ -`)}function HYt(S){return ji(S)||dG(S)||!!(xN&&S&&S[xN])}function hR(S,N){var O=typeof S;return N=N??_,!!N&&(O=="number"||O!="symbol"&&Ed.test(S))&&S>-1&&S%1==0&&S0){if(++N>=M)return arguments[0]}else N=0;return S.apply(t,arguments)}}function XO(S,N){var O=-1,tt=S.length,ct=tt-1;for(N=N===t?tt:N;++O1?S[N-1]:t;return O=typeof O=="function"?(S.pop(),O):t,Zct(S,O)});function Vct(S){var N=bt(S);return N.__chain__=!0,N}function nXt(S,N){return N(S),S}function JO(S,N){return N(S)}var iXt=mR(function(S){var N=S.length,O=N?S[0]:0,tt=this.__wrapped__,ct=function(Tt){return m8(Tt,S)};return N>1||this.__actions__.length||!(tt instanceof To)||!hR(O)?this.thru(ct):(tt=tt.slice(O,+O+(N?1:0)),tt.__actions__.push({func:JO,args:[ct],thisArg:t}),new pm(tt,this.__chain__).thru(function(Tt){return N&&!Tt.length&&Tt.push(t),Tt}))});function oXt(){return Vct(this)}function aXt(){return new pm(this.value(),this.__chain__)}function sXt(){this.__values__===t&&(this.__values__=Ict(this.value()));var S=this.__index__>=this.__values__.length,N=S?t:this.__values__[this.__index__++];return{done:S,value:N}}function lXt(){return this}function rXt(S){for(var N,O=this;O instanceof xg;){var tt=dct(O);tt.__index__=0,tt.__values__=t,N?ct.__wrapped__=tt:N=tt;var ct=tt;O=O.__wrapped__}return ct.__wrapped__=S,N}function dXt(){var S=this.__wrapped__;if(S instanceof To){var N=S;return this.__actions__.length&&(N=new To(this)),N=N.reverse(),N.__actions__.push({func:JO,args:[J8],thisArg:t}),new pm(N,this.__chain__)}return this.thru(J8)}function cXt(){return ydt(this.__wrapped__,this.__actions__)}var mXt=NO(function(S,N,O){ga.call(S,O)?++S[O]:dR(S,O,1)});function hXt(S,N,O){var tt=ji(S)?cO:nYt;return O&&Uc(S,N,O)&&(N=t),tt(S,Ei(N,3))}function pXt(S,N){var O=ji(S)?UV:Zdt;return O(S,Ei(N,3))}var uXt=Ddt(cct),ZXt=Ddt(mct);function VXt(S,N){return rd(LO(S,N),1)}function bXt(S,N){return rd(LO(S,N),X)}function RXt(S,N,O){return O=O===t?1:po(O),rd(LO(S,N),O)}function bct(S,N){var O=ji(S)?cm:tf;return O(S,Ei(N,3))}function Rct(S,N){var O=ji(S)?B4:udt;return O(S,Ei(N,3))}var WXt=NO(function(S,N,O){ga.call(S,O)?S[O].push(N):dR(S,O,[N])});function fXt(S,N,O,tt){S=Zm(S)?S:Dg(S),O=O&&!tt?po(O):0;var ct=S.length;return O<0&&(O=Ms(ct+O,0)),HO(S)?O<=ct&&S.indexOf(N,O)>-1:!!ct&&HW(S,N,O)>-1}var FXt=Fo(function(S,N,O){var tt=-1,ct=typeof N=="function",Tt=Zm(S)?me(S.length):[];return tf(S,function(Jt){Tt[++tt]=ct?Wc(N,Jt,O):DN(Jt,N,O)}),Tt}),UXt=NO(function(S,N,O){dR(S,O,N)});function LO(S,N){var O=ji(S)?Ta:Fdt;return O(S,Ei(N,3))}function GXt(S,N,O,tt){return S==null?[]:(ji(N)||(N=N==null?[]:[N]),O=tt?t:O,ji(O)||(O=O==null?[]:[O]),Tdt(S,N,O))}var AXt=NO(function(S,N,O){S[O?0:1].push(N)},function(){return[[],[]]});function TXt(S,N,O){var tt=ji(S)?GV:ZO,ct=arguments.length<3;return tt(S,Ei(N,4),O,ct,tf)}function SXt(S,N,O){var tt=ji(S)?OW:ZO,ct=arguments.length<3;return tt(S,Ei(N,4),O,ct,udt)}function gXt(S,N){var O=ji(S)?UV:Zdt;return O(S,DO(Ei(N,3)))}function EXt(S){var N=ji(S)?cdt:fYt;return N(S)}function CXt(S,N,O){(O?Uc(S,N,O):N===t)?N=1:N=po(N);var tt=ji(S)?jkt:FYt;return tt(S,N)}function IXt(S){var N=ji(S)?qkt:GYt;return N(S)}function NXt(S){if(S==null)return 0;if(Zm(S))return HO(S)?vW(S):S.length;var N=yd(S);return N==Mt||N==zt?S.size:b8(S).length}function yXt(S,N,O){var tt=ji(S)?gN:AYt;return O&&Uc(S,N,O)&&(N=t),tt(S,Ei(N,3))}var BXt=Fo(function(S,N){if(S==null)return[];var O=N.length;return O>1&&Uc(S,N[0],N[1])?N=[]:O>2&&Uc(N[0],N[1],N[2])&&(N=[N[0]]),Tdt(S,rd(N,1),[])}),MO=FO||function(){return ps.Date.now()};function QXt(S,N){if(typeof N!="function")throw new hm(o);return S=po(S),function(){if(--S<1)return N.apply(this,arguments)}}function Wct(S,N,O){return N=O?t:N,N=S&&N==null?S.length:N,cR(S,C,t,t,t,t,N)}function fct(S,N){var O;if(typeof N!="function")throw new hm(o);return S=po(S),function(){return--S>0&&(O=N.apply(this,arguments)),S<=1&&(N=t),O}}var M8=Fo(function(S,N,O){var tt=u;if(O.length){var ct=AV(O,Mg(M8));tt|=T}return cR(S,tt,N,O,ct)}),Fct=Fo(function(S,N,O){var tt=u|F;if(O.length){var ct=AV(O,Mg(Fct));tt|=T}return cR(N,tt,S,O,ct)});function Uct(S,N,O){N=O?t:N;var tt=cR(S,G,t,t,t,t,t,N);return tt.placeholder=Uct.placeholder,tt}function Gct(S,N,O){N=O?t:N;var tt=cR(S,A,t,t,t,t,t,N);return tt.placeholder=Gct.placeholder,tt}function Act(S,N,O){var tt,ct,Tt,Jt,Ht,$t,ye=0,Be=!1,Oe=!1,Bn=!0;if(typeof S!="function")throw new hm(o);N=Gp(N)||0,qs(O)&&(Be=!!O.leading,Oe="maxWait"in O,Tt=Oe?Ms(Gp(O.maxWait)||0,N):Tt,Bn="trailing"in O?!!O.trailing:Bn);function li(Yl){var wu=tt,ZR=ct;return tt=ct=t,ye=Yl,Jt=S.apply(ZR,wu),Jt}function Qi(Yl){return ye=Yl,Ht=vN(No,N),Be?li(Yl):Jt}function Zo(Yl){var wu=Yl-$t,ZR=Yl-ye,Dct=N-wu;return Oe?us(Dct,Tt-ZR):Dct}function ki(Yl){var wu=Yl-$t,ZR=Yl-ye;return $t===t||wu>=N||wu<0||Oe&&ZR>=Tt}function No(){var Yl=MO();if(ki(Yl))return Ko(Yl);Ht=vN(No,Zo(Yl))}function Ko(Yl){return Ht=t,Bn&&tt?li(Yl):(tt=ct=t,Jt)}function hh(){Ht!==t&&Qdt(Ht),ye=0,tt=$t=ct=Ht=t}function Gc(){return Ht===t?Jt:Ko(MO())}function ph(){var Yl=MO(),wu=ki(Yl);if(tt=arguments,ct=this,$t=Yl,wu){if(Ht===t)return Qi($t);if(Oe)return Qdt(Ht),Ht=vN(No,N),li($t)}return Ht===t&&(Ht=vN(No,N)),Jt}return ph.cancel=hh,ph.flush=Gc,ph}var kXt=Fo(function(S,N){return pdt(S,1,N)}),YXt=Fo(function(S,N,O){return pdt(S,Gp(N)||0,O)});function xXt(S){return cR(S,Y)}function _O(S,N){if(typeof S!="function"||N!=null&&typeof N!="function")throw new hm(o);var O=function(){var tt=arguments,ct=N?N.apply(this,tt):tt[0],Tt=O.cache;if(Tt.has(ct))return Tt.get(ct);var Jt=S.apply(this,tt);return O.cache=Tt.set(ct,Jt)||Tt,Jt};return O.cache=new(_O.Cache||Vn),O}_O.Cache=Vn;function DO(S){if(typeof S!="function")throw new hm(o);return function(){var N=arguments;switch(N.length){case 0:return!S.call(this);case 1:return!S.call(this,N[0]);case 2:return!S.call(this,N[0],N[1]);case 3:return!S.call(this,N[0],N[1],N[2])}return!S.apply(this,N)}}function XXt(S){return fct(2,S)}var JXt=TYt(function(S,N){N=N.length==1&&ji(N[0])?Ta(N[0],fc(Ei())):Ta(rd(N,1),fc(Ei()));var O=N.length;return Fo(function(tt){for(var ct=-1,Tt=us(tt.length,O);++ct=N}),dG=Rdt(function(){return arguments}())?Rdt:function(S){return Wl(S)&&ga.call(S,"callee")&&!YN.call(S,"callee")},ji=me.isArray,tJt=Ug?fc(Ug):rYt;function Zm(S){return S!=null&&OO(S.length)&&!pR(S)}function kl(S){return Wl(S)&&Zm(S)}function eJt(S){return S===!0||S===!1||Wl(S)&&Fc(S)==st}var af=n8||$8,nJt=lO?fc(lO):dYt;function iJt(S){return Wl(S)&&S.nodeType===1&&!KN(S)}function oJt(S){if(S==null)return!0;if(Zm(S)&&(ji(S)||typeof S=="string"||typeof S.splice=="function"||af(S)||_g(S)||dG(S)))return!S.length;var N=yd(S);if(N==Mt||N==zt)return!S.size;if(PN(S))return!b8(S).length;for(var O in S)if(ga.call(S,O))return!1;return!0}function aJt(S,N){return ON(S,N)}function sJt(S,N,O){O=typeof O=="function"?O:t;var tt=O?O(S,N):t;return tt===t?ON(S,N,t,O):!!tt}function D8(S){if(!Wl(S))return!1;var N=Fc(S);return N==Wt||N==Qt||typeof S.message=="string"&&typeof S.name=="string"&&!KN(S)}function lJt(S){return typeof S=="number"&&XN(S)}function pR(S){if(!qs(S))return!1;var N=Fc(S);return N==Nt||N==kt||N==at||N==rn}function Sct(S){return typeof S=="number"&&S==po(S)}function OO(S){return typeof S=="number"&&S>-1&&S%1==0&&S<=_}function qs(S){var N=typeof S;return S!=null&&(N=="object"||N=="function")}function Wl(S){return S!=null&&typeof S=="object"}var gct=rO?fc(rO):mYt;function rJt(S,N){return S===N||V8(S,N,B8(N))}function dJt(S,N,O){return O=typeof O=="function"?O:t,V8(S,N,B8(N),O)}function cJt(S){return Ect(S)&&S!=+S}function mJt(S){if(vYt(S))throw new Ai(i);return Wdt(S)}function hJt(S){return S===null}function pJt(S){return S==null}function Ect(S){return typeof S=="number"||Wl(S)&&Fc(S)==qt}function KN(S){if(!Wl(S)||Fc(S)!=oe)return!1;var N=yg(S);if(N===null)return!0;var O=ga.call(N,"constructor")&&N.constructor;return typeof O=="function"&&O instanceof O&&Eg.call(O)==j4}var O8=dh?fc(dh):hYt;function uJt(S){return Sct(S)&&S>=-_&&S<=_}var Cct=dO?fc(dO):pYt;function HO(S){return typeof S=="string"||!ji(S)&&Wl(S)&&Fc(S)==ke}function mh(S){return typeof S=="symbol"||Wl(S)&&Fc(S)==ue}var _g=aR?fc(aR):uYt;function ZJt(S){return S===t}function VJt(S){return Wl(S)&&yd(S)==un}function bJt(S){return Wl(S)&&Fc(S)==Ct}var RJt=kO(R8),WJt=kO(function(S,N){return S<=N});function Ict(S){if(!S)return[];if(Zm(S))return HO(S)?mm(S):um(S);if(tG&&S[tG])return D4(S[tG]());var N=yd(S),O=N==Mt?yN:N==zt?qU:Dg;return O(S)}function uR(S){if(!S)return S===0?S:0;if(S=Gp(S),S===X||S===-X){var N=S<0?-1:1;return N*P}return S===S?S:0}function po(S){var N=uR(S),O=N%1;return N===N?O?N-O:N:0}function Nct(S){return S?aG(po(S),0,z):0}function Gp(S){if(typeof S=="number")return S;if(mh(S))return w;if(qs(S)){var N=typeof S.valueOf=="function"?S.valueOf():S;S=qs(N)?N+"":N}if(typeof S!="string")return S===0?S:+S;S=VO(S);var O=pr.test(S);return O||ma.test(S)?Pl(S.slice(2),O?2:8):hr.test(S)?w:+S}function yct(S){return EV(S,Vm(S))}function fJt(S){return S?aG(po(S),-_,_):S===0?S:0}function xa(S){return S==null?"":ch(S)}var FJt=Jg(function(S,N){if(PN(N)||Zm(N)){EV(N,xr(N),S);return}for(var O in N)ga.call(N,O)&&MN(S,O,N[O])}),Bct=Jg(function(S,N){EV(N,Vm(N),S)}),wO=Jg(function(S,N,O,tt){EV(N,Vm(N),S,tt)}),UJt=Jg(function(S,N,O,tt){EV(N,xr(N),S,tt)}),GJt=mR(m8);function AJt(S,N){var O=oG(S);return N==null?O:mdt(O,N)}var TJt=Fo(function(S,N){S=Oa(S);var O=-1,tt=N.length,ct=tt>2?N[2]:t;for(ct&&Uc(N[0],N[1],ct)&&(tt=1);++O1),Tt}),EV(S,N8(S),O),tt&&(O=fp(O,d|m|h,YYt));for(var ct=N.length;ct--;)G8(O,N[ct]);return O});function DJt(S,N){return kct(S,DO(Ei(N)))}var OJt=mR(function(S,N){return S==null?{}:bYt(S,N)});function kct(S,N){if(S==null)return{};var O=Ta(N8(S),function(tt){return[tt]});return N=Ei(N),Sdt(S,O,function(tt,ct){return N(tt,ct[0])})}function HJt(S,N,O){N=nf(N,S);var tt=-1,ct=N.length;for(ct||(ct=1,S=t);++ttN){var tt=S;S=N,N=tt}if(O||S%1||N%1){var ct=UO();return us(S+ct*(N-S+Rl("1e-"+((ct+"").length-1))),N)}return f8(S,N)}var nLt=Lg(function(S,N,O){return N=N.toLowerCase(),S+(O?Xct(N):N)});function Xct(S){return P8(xa(S).toLowerCase())}function Jct(S){return S=xa(S),S&&S.replace(BW,L4).replace(Rg,"")}function iLt(S,N,O){S=xa(S),N=ch(N);var tt=S.length;O=O===t?tt:aG(po(O),0,tt);var ct=O;return O-=N.length,O>=0&&S.slice(O,ct)==N}function oLt(S){return S=xa(S),S&&_a.test(S)?S.replace(si,M4):S}function aLt(S){return S=xa(S),S&&ka.test(S)?S.replace(wl,"\\$&"):S}var sLt=Lg(function(S,N,O){return S+(O?"-":"")+N.toLowerCase()}),lLt=Lg(function(S,N,O){return S+(O?" ":"")+N.toLowerCase()}),rLt=_dt("toLowerCase");function dLt(S,N,O){S=xa(S),N=po(N);var tt=N?vW(S):0;if(!N||tt>=N)return S;var ct=(N-tt)/2;return QO(lR(ct),O)+S+QO(eG(ct),O)}function cLt(S,N,O){S=xa(S),N=po(N);var tt=N?vW(S):0;return N&&tt>>0,O?(S=xa(S),S&&(typeof N=="string"||N!=null&&!O8(N))&&(N=ch(N),!N&&PW(S))?of(mm(S),0,O):S.split(N,O)):[]}var bLt=Lg(function(S,N,O){return S+(O?" ":"")+P8(N)});function RLt(S,N,O){return S=xa(S),O=O==null?0:aG(po(O),0,S.length),N=ch(N),S.slice(O,O+N.length)==N}function WLt(S,N,O){var tt=bt.templateSettings;O&&Uc(S,N,O)&&(N=t),S=xa(S),N=wO({},N,tt,Kdt);var ct=wO({},N.imports,tt.imports,Kdt),Tt=xr(ct),Jt=Ag(ct,Tt),Ht,$t,ye=0,Be=N.interpolate||Rc,Oe="__p += '",Bn=BN((N.escape||Rc).source+"|"+Be.source+"|"+(Be===Go?$n:Rc).source+"|"+(N.evaluate||Rc).source+"|$","g"),li="//# sourceURL="+(ga.call(N,"sourceURL")?(N.sourceURL+"").replace(/\s/g," "):"lodash.templateSources["+ ++dm+"]")+` -`;S.replace(Bn,function(ki,No,Ko,hh,Gc,ph){return Ko||(Ko=hh),Oe+=S.slice(ye,ph).replace($b,RO),No&&(Ht=!0,Oe+=`' + +`)}function HYt(T){return ji(T)||dG(T)||!!(xN&&T&&T[xN])}function hb(T,N){var O=typeof T;return N=N??_,!!N&&(O=="number"||O!="symbol"&&Ed.test(T))&&T>-1&&T%1==0&&T0){if(++N>=M)return arguments[0]}else N=0;return T.apply(t,arguments)}}function XO(T,N){var O=-1,tt=T.length,ct=tt-1;for(N=N===t?tt:N;++O1?T[N-1]:t;return O=typeof O=="function"?(T.pop(),O):t,uct(T,O)});function Zct(T){var N=Rt(T);return N.__chain__=!0,N}function nXt(T,N){return N(T),T}function JO(T,N){return N(T)}var iXt=mb(function(T){var N=T.length,O=N?T[0]:0,tt=this.__wrapped__,ct=function(St){return m8(St,T)};return N>1||this.__actions__.length||!(tt instanceof So)||!hb(O)?this.thru(ct):(tt=tt.slice(O,+O+(N?1:0)),tt.__actions__.push({func:JO,args:[ct],thisArg:t}),new pm(tt,this.__chain__).thru(function(St){return N&&!St.length&&St.push(t),St}))});function oXt(){return Zct(this)}function aXt(){return new pm(this.value(),this.__chain__)}function sXt(){this.__values__===t&&(this.__values__=Ict(this.value()));var T=this.__index__>=this.__values__.length,N=T?t:this.__values__[this.__index__++];return{done:T,value:N}}function lXt(){return this}function rXt(T){for(var N,O=this;O instanceof xg;){var tt=dct(O);tt.__index__=0,tt.__values__=t,N?ct.__wrapped__=tt:N=tt;var ct=tt;O=O.__wrapped__}return ct.__wrapped__=T,N}function dXt(){var T=this.__wrapped__;if(T instanceof So){var N=T;return this.__actions__.length&&(N=new So(this)),N=N.reverse(),N.__actions__.push({func:JO,args:[J8],thisArg:t}),new pm(N,this.__chain__)}return this.thru(J8)}function cXt(){return ydt(this.__wrapped__,this.__actions__)}var mXt=NO(function(T,N,O){ga.call(T,O)?++T[O]:db(T,O,1)});function hXt(T,N,O){var tt=ji(T)?cO:nYt;return O&&Uc(T,N,O)&&(N=t),tt(T,Ei(N,3))}function pXt(T,N){var O=ji(T)?UZ:udt;return O(T,Ei(N,3))}var VXt=Ddt(cct),uXt=Ddt(mct);function ZXt(T,N){return rd(LO(T,N),1)}function RXt(T,N){return rd(LO(T,N),X)}function bXt(T,N,O){return O=O===t?1:po(O),rd(LO(T,N),O)}function Rct(T,N){var O=ji(T)?cm:tf;return O(T,Ei(N,3))}function bct(T,N){var O=ji(T)?B4:Vdt;return O(T,Ei(N,3))}var WXt=NO(function(T,N,O){ga.call(T,O)?T[O].push(N):db(T,O,[N])});function fXt(T,N,O,tt){T=um(T)?T:Dg(T),O=O&&!tt?po(O):0;var ct=T.length;return O<0&&(O=Ms(ct+O,0)),HO(T)?O<=ct&&T.indexOf(N,O)>-1:!!ct&&HW(T,N,O)>-1}var FXt=Fo(function(T,N,O){var tt=-1,ct=typeof N=="function",St=um(T)?me(T.length):[];return tf(T,function(Jt){St[++tt]=ct?Wc(N,Jt,O):DN(Jt,N,O)}),St}),UXt=NO(function(T,N,O){db(T,O,N)});function LO(T,N){var O=ji(T)?Sa:Fdt;return O(T,Ei(N,3))}function GXt(T,N,O,tt){return T==null?[]:(ji(N)||(N=N==null?[]:[N]),O=tt?t:O,ji(O)||(O=O==null?[]:[O]),Sdt(T,N,O))}var AXt=NO(function(T,N,O){T[O?0:1].push(N)},function(){return[[],[]]});function SXt(T,N,O){var tt=ji(T)?GZ:uO,ct=arguments.length<3;return tt(T,Ei(N,4),O,ct,tf)}function TXt(T,N,O){var tt=ji(T)?OW:uO,ct=arguments.length<3;return tt(T,Ei(N,4),O,ct,Vdt)}function gXt(T,N){var O=ji(T)?UZ:udt;return O(T,DO(Ei(N,3)))}function EXt(T){var N=ji(T)?cdt:fYt;return N(T)}function CXt(T,N,O){(O?Uc(T,N,O):N===t)?N=1:N=po(N);var tt=ji(T)?j2t:FYt;return tt(T,N)}function IXt(T){var N=ji(T)?q2t:GYt;return N(T)}function NXt(T){if(T==null)return 0;if(um(T))return HO(T)?vW(T):T.length;var N=yd(T);return N==Mt||N==zt?T.size:R8(T).length}function yXt(T,N,O){var tt=ji(T)?gN:AYt;return O&&Uc(T,N,O)&&(N=t),tt(T,Ei(N,3))}var BXt=Fo(function(T,N){if(T==null)return[];var O=N.length;return O>1&&Uc(T,N[0],N[1])?N=[]:O>2&&Uc(N[0],N[1],N[2])&&(N=[N[0]]),Sdt(T,rd(N,1),[])}),MO=FO||function(){return ps.Date.now()};function QXt(T,N){if(typeof N!="function")throw new hm(o);return T=po(T),function(){if(--T<1)return N.apply(this,arguments)}}function Wct(T,N,O){return N=O?t:N,N=T&&N==null?T.length:N,cb(T,C,t,t,t,t,N)}function fct(T,N){var O;if(typeof N!="function")throw new hm(o);return T=po(T),function(){return--T>0&&(O=N.apply(this,arguments)),T<=1&&(N=t),O}}var M8=Fo(function(T,N,O){var tt=V;if(O.length){var ct=AZ(O,Mg(M8));tt|=S}return cb(T,tt,N,O,ct)}),Fct=Fo(function(T,N,O){var tt=V|F;if(O.length){var ct=AZ(O,Mg(Fct));tt|=S}return cb(N,tt,T,O,ct)});function Uct(T,N,O){N=O?t:N;var tt=cb(T,G,t,t,t,t,t,N);return tt.placeholder=Uct.placeholder,tt}function Gct(T,N,O){N=O?t:N;var tt=cb(T,A,t,t,t,t,t,N);return tt.placeholder=Gct.placeholder,tt}function Act(T,N,O){var tt,ct,St,Jt,Ht,$t,ye=0,Be=!1,Oe=!1,Bn=!0;if(typeof T!="function")throw new hm(o);N=Gp(N)||0,qs(O)&&(Be=!!O.leading,Oe="maxWait"in O,St=Oe?Ms(Gp(O.maxWait)||0,N):St,Bn="trailing"in O?!!O.trailing:Bn);function li(Yl){var wV=tt,ub=ct;return tt=ct=t,ye=Yl,Jt=T.apply(ub,wV),Jt}function Qi(Yl){return ye=Yl,Ht=vN(No,N),Be?li(Yl):Jt}function uo(Yl){var wV=Yl-$t,ub=Yl-ye,Dct=N-wV;return Oe?Vs(Dct,St-ub):Dct}function ki(Yl){var wV=Yl-$t,ub=Yl-ye;return $t===t||wV>=N||wV<0||Oe&&ub>=St}function No(){var Yl=MO();if(ki(Yl))return Ko(Yl);Ht=vN(No,uo(Yl))}function Ko(Yl){return Ht=t,Bn&&tt?li(Yl):(tt=ct=t,Jt)}function hh(){Ht!==t&&Qdt(Ht),ye=0,tt=$t=ct=Ht=t}function Gc(){return Ht===t?Jt:Ko(MO())}function ph(){var Yl=MO(),wV=ki(Yl);if(tt=arguments,ct=this,$t=Yl,wV){if(Ht===t)return Qi($t);if(Oe)return Qdt(Ht),Ht=vN(No,N),li($t)}return Ht===t&&(Ht=vN(No,N)),Jt}return ph.cancel=hh,ph.flush=Gc,ph}var kXt=Fo(function(T,N){return pdt(T,1,N)}),YXt=Fo(function(T,N,O){return pdt(T,Gp(N)||0,O)});function xXt(T){return cb(T,Y)}function _O(T,N){if(typeof T!="function"||N!=null&&typeof N!="function")throw new hm(o);var O=function(){var tt=arguments,ct=N?N.apply(this,tt):tt[0],St=O.cache;if(St.has(ct))return St.get(ct);var Jt=T.apply(this,tt);return O.cache=St.set(ct,Jt)||St,Jt};return O.cache=new(_O.Cache||Zn),O}_O.Cache=Zn;function DO(T){if(typeof T!="function")throw new hm(o);return function(){var N=arguments;switch(N.length){case 0:return!T.call(this);case 1:return!T.call(this,N[0]);case 2:return!T.call(this,N[0],N[1]);case 3:return!T.call(this,N[0],N[1],N[2])}return!T.apply(this,N)}}function XXt(T){return fct(2,T)}var JXt=SYt(function(T,N){N=N.length==1&&ji(N[0])?Sa(N[0],fc(Ei())):Sa(rd(N,1),fc(Ei()));var O=N.length;return Fo(function(tt){for(var ct=-1,St=Vs(tt.length,O);++ct=N}),dG=bdt(function(){return arguments}())?bdt:function(T){return Wl(T)&&ga.call(T,"callee")&&!YN.call(T,"callee")},ji=me.isArray,tJt=Ug?fc(Ug):rYt;function um(T){return T!=null&&OO(T.length)&&!pb(T)}function kl(T){return Wl(T)&&um(T)}function eJt(T){return T===!0||T===!1||Wl(T)&&Fc(T)==st}var af=n8||$8,nJt=lO?fc(lO):dYt;function iJt(T){return Wl(T)&&T.nodeType===1&&!KN(T)}function oJt(T){if(T==null)return!0;if(um(T)&&(ji(T)||typeof T=="string"||typeof T.splice=="function"||af(T)||_g(T)||dG(T)))return!T.length;var N=yd(T);if(N==Mt||N==zt)return!T.size;if(PN(T))return!R8(T).length;for(var O in T)if(ga.call(T,O))return!1;return!0}function aJt(T,N){return ON(T,N)}function sJt(T,N,O){O=typeof O=="function"?O:t;var tt=O?O(T,N):t;return tt===t?ON(T,N,t,O):!!tt}function D8(T){if(!Wl(T))return!1;var N=Fc(T);return N==Wt||N==Qt||typeof T.message=="string"&&typeof T.name=="string"&&!KN(T)}function lJt(T){return typeof T=="number"&&XN(T)}function pb(T){if(!qs(T))return!1;var N=Fc(T);return N==Nt||N==kt||N==at||N==rn}function Tct(T){return typeof T=="number"&&T==po(T)}function OO(T){return typeof T=="number"&&T>-1&&T%1==0&&T<=_}function qs(T){var N=typeof T;return T!=null&&(N=="object"||N=="function")}function Wl(T){return T!=null&&typeof T=="object"}var gct=rO?fc(rO):mYt;function rJt(T,N){return T===N||Z8(T,N,B8(N))}function dJt(T,N,O){return O=typeof O=="function"?O:t,Z8(T,N,B8(N),O)}function cJt(T){return Ect(T)&&T!=+T}function mJt(T){if(vYt(T))throw new Ai(i);return Wdt(T)}function hJt(T){return T===null}function pJt(T){return T==null}function Ect(T){return typeof T=="number"||Wl(T)&&Fc(T)==qt}function KN(T){if(!Wl(T)||Fc(T)!=oe)return!1;var N=yg(T);if(N===null)return!0;var O=ga.call(N,"constructor")&&N.constructor;return typeof O=="function"&&O instanceof O&&Eg.call(O)==j4}var O8=dh?fc(dh):hYt;function VJt(T){return Tct(T)&&T>=-_&&T<=_}var Cct=dO?fc(dO):pYt;function HO(T){return typeof T=="string"||!ji(T)&&Wl(T)&&Fc(T)==ke}function mh(T){return typeof T=="symbol"||Wl(T)&&Fc(T)==Ve}var _g=ab?fc(ab):VYt;function uJt(T){return T===t}function ZJt(T){return Wl(T)&&yd(T)==Vn}function RJt(T){return Wl(T)&&Fc(T)==Ct}var bJt=kO(b8),WJt=kO(function(T,N){return T<=N});function Ict(T){if(!T)return[];if(um(T))return HO(T)?mm(T):Vm(T);if(tG&&T[tG])return D4(T[tG]());var N=yd(T),O=N==Mt?yN:N==zt?qU:Dg;return O(T)}function Vb(T){if(!T)return T===0?T:0;if(T=Gp(T),T===X||T===-X){var N=T<0?-1:1;return N*P}return T===T?T:0}function po(T){var N=Vb(T),O=N%1;return N===N?O?N-O:N:0}function Nct(T){return T?aG(po(T),0,z):0}function Gp(T){if(typeof T=="number")return T;if(mh(T))return w;if(qs(T)){var N=typeof T.valueOf=="function"?T.valueOf():T;T=qs(N)?N+"":N}if(typeof T!="string")return T===0?T:+T;T=ZO(T);var O=pr.test(T);return O||ma.test(T)?Pl(T.slice(2),O?2:8):hr.test(T)?w:+T}function yct(T){return EZ(T,Zm(T))}function fJt(T){return T?aG(po(T),-_,_):T===0?T:0}function xa(T){return T==null?"":ch(T)}var FJt=Jg(function(T,N){if(PN(N)||um(N)){EZ(N,xr(N),T);return}for(var O in N)ga.call(N,O)&&MN(T,O,N[O])}),Bct=Jg(function(T,N){EZ(N,Zm(N),T)}),wO=Jg(function(T,N,O,tt){EZ(N,Zm(N),T,tt)}),UJt=Jg(function(T,N,O,tt){EZ(N,xr(N),T,tt)}),GJt=mb(m8);function AJt(T,N){var O=oG(T);return N==null?O:mdt(O,N)}var SJt=Fo(function(T,N){T=Oa(T);var O=-1,tt=N.length,ct=tt>2?N[2]:t;for(ct&&Uc(N[0],N[1],ct)&&(tt=1);++O1),St}),EZ(T,N8(T),O),tt&&(O=fp(O,d|m|h,YYt));for(var ct=N.length;ct--;)G8(O,N[ct]);return O});function DJt(T,N){return kct(T,DO(Ei(N)))}var OJt=mb(function(T,N){return T==null?{}:RYt(T,N)});function kct(T,N){if(T==null)return{};var O=Sa(N8(T),function(tt){return[tt]});return N=Ei(N),Tdt(T,O,function(tt,ct){return N(tt,ct[0])})}function HJt(T,N,O){N=nf(N,T);var tt=-1,ct=N.length;for(ct||(ct=1,T=t);++ttN){var tt=T;T=N,N=tt}if(O||T%1||N%1){var ct=UO();return Vs(T+ct*(N-T+bl("1e-"+((ct+"").length-1))),N)}return f8(T,N)}var nLt=Lg(function(T,N,O){return N=N.toLowerCase(),T+(O?Xct(N):N)});function Xct(T){return P8(xa(T).toLowerCase())}function Jct(T){return T=xa(T),T&&T.replace(BW,L4).replace(bg,"")}function iLt(T,N,O){T=xa(T),N=ch(N);var tt=T.length;O=O===t?tt:aG(po(O),0,tt);var ct=O;return O-=N.length,O>=0&&T.slice(O,ct)==N}function oLt(T){return T=xa(T),T&&_a.test(T)?T.replace(si,M4):T}function aLt(T){return T=xa(T),T&&ka.test(T)?T.replace(wl,"\\$&"):T}var sLt=Lg(function(T,N,O){return T+(O?"-":"")+N.toLowerCase()}),lLt=Lg(function(T,N,O){return T+(O?" ":"")+N.toLowerCase()}),rLt=_dt("toLowerCase");function dLt(T,N,O){T=xa(T),N=po(N);var tt=N?vW(T):0;if(!N||tt>=N)return T;var ct=(N-tt)/2;return QO(lb(ct),O)+T+QO(eG(ct),O)}function cLt(T,N,O){T=xa(T),N=po(N);var tt=N?vW(T):0;return N&&tt>>0,O?(T=xa(T),T&&(typeof N=="string"||N!=null&&!O8(N))&&(N=ch(N),!N&&PW(T))?of(mm(T),0,O):T.split(N,O)):[]}var RLt=Lg(function(T,N,O){return T+(O?" ":"")+P8(N)});function bLt(T,N,O){return T=xa(T),O=O==null?0:aG(po(O),0,T.length),N=ch(N),T.slice(O,O+N.length)==N}function WLt(T,N,O){var tt=Rt.templateSettings;O&&Uc(T,N,O)&&(N=t),T=xa(T),N=wO({},N,tt,Kdt);var ct=wO({},N.imports,tt.imports,Kdt),St=xr(ct),Jt=Ag(ct,St),Ht,$t,ye=0,Be=N.interpolate||bc,Oe="__p += '",Bn=BN((N.escape||bc).source+"|"+Be.source+"|"+(Be===Go?$n:bc).source+"|"+(N.evaluate||bc).source+"|$","g"),li="//# sourceURL="+(ga.call(N,"sourceURL")?(N.sourceURL+"").replace(/\s/g," "):"lodash.templateSources["+ ++dm+"]")+` +`;T.replace(Bn,function(ki,No,Ko,hh,Gc,ph){return Ko||(Ko=hh),Oe+=T.slice(ye,ph).replace($R,bO),No&&(Ht=!0,Oe+=`' + __e(`+No+`) + '`),Gc&&($t=!0,Oe+=`'; `+Gc+`; @@ -79,33 +79,33 @@ __p += '`),Ko&&(Oe+=`' + `;var Qi=ga.call(N,"variable")&&N.variable;if(!Qi)Oe=`with (obj) { `+Oe+` } -`;else if(js.test(Qi))throw new Ai(a);Oe=($t?Oe.replace(ge,""):Oe).replace(Ze,"$1").replace(Ke,"$1;"),Oe="function("+(Qi||"obj")+`) { +`;else if(js.test(Qi))throw new Ai(a);Oe=($t?Oe.replace(ge,""):Oe).replace(ue,"$1").replace(Ke,"$1;"),Oe="function("+(Qi||"obj")+`) { `+(Qi?"":`obj || (obj = {}); `)+"var __t, __p = ''"+(Ht?", __e = _.escape":"")+($t?`, __j = Array.prototype.join; function print() { __p += __j.call(arguments, '') } `:`; `)+Oe+`return __p -}`;var Zo=Mct(function(){return ia(Tt,li+"return "+Oe).apply(t,Jt)});if(Zo.source=Oe,D8(Zo))throw Zo;return Zo}function fLt(S){return xa(S).toLowerCase()}function FLt(S){return xa(S).toUpperCase()}function ULt(S,N,O){if(S=xa(S),S&&(O||N===t))return VO(S);if(!S||!(N=ch(N)))return S;var tt=mm(S),ct=mm(N),Tt=wW(tt,ct),Jt=bO(tt,ct)+1;return of(tt,Tt,Jt).join("")}function GLt(S,N,O){if(S=xa(S),S&&(O||N===t))return S.slice(0,Sg(S)+1);if(!S||!(N=ch(N)))return S;var tt=mm(S),ct=bO(tt,mm(N))+1;return of(tt,0,ct).join("")}function ALt(S,N,O){if(S=xa(S),S&&(O||N===t))return S.replace(Wa,"");if(!S||!(N=ch(N)))return S;var tt=mm(S),ct=wW(tt,mm(N));return of(tt,ct).join("")}function TLt(S,N){var O=Q,tt=J;if(qs(N)){var ct="separator"in N?N.separator:ct;O="length"in N?po(N.length):O,tt="omission"in N?ch(N.omission):tt}S=xa(S);var Tt=S.length;if(PW(S)){var Jt=mm(S);Tt=Jt.length}if(O>=Tt)return S;var Ht=O-vW(tt);if(Ht<1)return tt;var $t=Jt?of(Jt,0,Ht).join(""):S.slice(0,Ht);if(ct===t)return $t+tt;if(Jt&&(Ht+=$t.length-Ht),O8(ct)){if(S.slice(Ht).search(ct)){var ye,Be=$t;for(ct.global||(ct=BN(ct.source,xa(mr.exec(ct))+"g")),ct.lastIndex=0;ye=ct.exec(Be);)var Oe=ye.index;$t=$t.slice(0,Oe===t?Ht:Oe)}}else if(S.indexOf(ch(ct),Ht)!=Ht){var Bn=$t.lastIndexOf(ct);Bn>-1&&($t=$t.slice(0,Bn))}return $t+tt}function SLt(S){return S=xa(S),S&&da.test(S)?S.replace(An,P4):S}var gLt=Lg(function(S,N,O){return S+(O?" ":"")+N.toUpperCase()}),P8=_dt("toUpperCase");function Lct(S,N,O){return S=xa(S),N=O?t:N,N===t?Tg(S)?Sa(S):k4(S):S.match(N)||[]}var Mct=Fo(function(S,N){try{return Wc(S,t,N)}catch(O){return D8(O)?O:new Ai(O)}}),ELt=mR(function(S,N){return cm(N,function(O){O=CV(O),dR(S,O,M8(S[O],S))}),S});function CLt(S){var N=S==null?0:S.length,O=Ei();return S=N?Ta(S,function(tt){if(typeof tt[1]!="function")throw new hm(o);return[O(tt[0]),tt[1]]}):[],Fo(function(tt){for(var ct=-1;++ct_)return[];var O=z,tt=us(S,z);N=Ei(N),S-=z;for(var ct=NN(tt,N);++O0||N<0)?new To(O):(S<0?O=O.takeRight(-S):S&&(O=O.drop(S)),N!==t&&(N=po(N),O=N<0?O.dropRight(-N):O.take(N-S)),O)},To.prototype.takeRightWhile=function(S){return this.reverse().takeWhile(S).reverse()},To.prototype.toArray=function(){return this.take(z)},gV(To.prototype,function(S,N){var O=/^(?:filter|find|map|reject)|While$/.test(N),tt=/^(?:head|last)$/.test(N),ct=bt[tt?"take"+(N=="last"?"Right":""):N],Tt=tt||/^find/.test(N);ct&&(bt.prototype[N]=function(){var Jt=this.__wrapped__,Ht=tt?[1]:arguments,$t=Jt instanceof To,ye=Ht[0],Be=$t||ji(Jt),Oe=function(No){var Ko=ct.apply(bt,_u([No],Ht));return tt&&Bn?Ko[0]:Ko};Be&&O&&typeof ye=="function"&&ye.length!=1&&($t=Be=!1);var Bn=this.__chain__,li=!!this.__actions__.length,Qi=Tt&&!Bn,Zo=$t&&!li;if(!Tt&&Be){Jt=Zo?Jt:new To(this);var ki=S.apply(Jt,Ht);return ki.__actions__.push({func:JO,args:[Oe],thisArg:t}),new pm(ki,Bn)}return Qi&&Zo?S.apply(this,Ht):(ki=this.thru(Oe),Qi?tt?ki.value()[0]:ki.value():ki)})}),cm(["pop","push","shift","sort","splice","unshift"],function(S){var N=gg[S],O=/^(?:push|sort|unshift)$/.test(S)?"tap":"thru",tt=/^(?:pop|shift)$/.test(S);bt.prototype[S]=function(){var ct=arguments;if(tt&&!this.__chain__){var Tt=this.value();return N.apply(ji(Tt)?Tt:[],ct)}return this[O](function(Jt){return N.apply(ji(Jt)?Jt:[],ct)})}}),gV(To.prototype,function(S,N){var O=bt[N];if(O){var tt=O.name+"";ga.call($W,tt)||($W[tt]=[]),$W[tt].push({name:N,func:O})}}),$W[yO(t,F).name]=[{name:"wrapper",func:t}],To.prototype.clone=r8,To.prototype.reverse=Xg,To.prototype.value=d8,bt.prototype.at=iXt,bt.prototype.chain=oXt,bt.prototype.commit=aXt,bt.prototype.next=sXt,bt.prototype.plant=rXt,bt.prototype.reverse=dXt,bt.prototype.toJSON=bt.prototype.valueOf=bt.prototype.value=cXt,bt.prototype.first=bt.prototype.head,tG&&(bt.prototype[tG]=lXt),bt},Du=K4();typeof define=="function"&&typeof define.amd=="object"&&define.amd?(ps._=Du,define(function(){return Du})):Wp?((Wp.exports=Du)._=Du,Ql._=Du):ps._=Du}).call(DI)});var NK=Vo((D_i,aCt)=>{var O_i=R(W());aCt.exports=eGe;function eGe(t,e,n){return t[0]=e[0]-n[0],t[1]=e[1]-n[1],t[2]=e[2]-n[2],t}});var yK=Vo((H_i,sCt)=>{var w_i=R(W());sCt.exports=nGe;function nGe(t,e,n){var i=e[0],o=e[1],a=e[2],s=n[0],l=n[1],r=n[2];return t[0]=o*r-a*l,t[1]=a*s-i*r,t[2]=i*l-o*s,t}});var rCt=Vo((P_i,lCt)=>{var v_i=R(W());lCt.exports=iGe;function iGe(t){var e=t[0],n=t[1],i=t[2];return e*e+n*n+i*i}});var pCt=Vo((K_i,hCt)=>{var z_i=R(W()),dCt=NK(),oGe=yK(),cCt=rCt(),qit=[],mCt=[],aGe=[];hCt.exports=function(t,e,n){dCt(qit,n,e),dCt(mCt,t,e);var i=cCt(oGe(aGe,mCt,qit)),o=cCt(qit);if(o===0)throw Error("a and b are the same point");return i/o}});var ZCt=Vo((j_i,uCt)=>{"use strict";var q_i=R(W()),sGe=pCt();uCt.exports=function(t,e,n){return Math.sqrt(sGe(t,e,n))}});var $it=Vo(($_i,VCt)=>{var t9i=R(W());VCt.exports=lGe;function lGe(t,e){var n=e[0],i=e[1],o=e[2],a=n*n+i*i+o*o;return a>0&&(a=1/Math.sqrt(a),t[0]=e[0]*a,t[1]=e[1]*a,t[2]=e[2]*a),t}});var tot=Vo((e9i,WCt)=>{var n9i=R(W()),rGe=$it(),bCt=NK(),dGe=yK(),RCt=[0,0,0];WCt.exports=cGe;function cGe(t,e,n,i){return bCt(t,e,n),bCt(RCt,n,i),dGe(t,t,RCt),rGe(t,t)}});var eot=Vo((i9i,fCt)=>{var o9i=R(W());fCt.exports=mGe;function mGe(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]}});var UCt=Vo(BK=>{"use strict";var s9i=R(W());Object.defineProperty(BK,"__esModule",{value:!0});BK.default=void 0;function hGe(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function FCt(t,e){for(var n=0;n{"use strict";var r9i=R(W());Object.defineProperty(QK,"__esModule",{value:!0});QK.default=void 0;function GCt(t,e){for(var n=0;n{var c9i=R(W());TCt.exports=RGe;function RGe(t,e,n){return t[0]=e[0]+n[0],t[1]=e[1]+n[1],t[2]=e[2]+n[2],t}});var ECt=Vo((m9i,gCt)=>{var h9i=R(W());gCt.exports=WGe;function WGe(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}});var ICt=Vo((p9i,CCt)=>{var u9i=R(W());CCt.exports=fGe;function fGe(t){var e=t[0],n=t[1],i=t[2];return Math.sqrt(e*e+n*n+i*i)}});var yCt=Vo((Z9i,NCt)=>{var V9i=R(W());NCt.exports=FGe;function FGe(t,e,n){return t[0]=e[0]*n,t[1]=e[1]*n,t[2]=e[2]*n,t}});var QCt=Vo((b9i,BCt)=>{var R9i=R(W());BCt.exports=UGe;function UGe(t,e,n,i){return t[0]=e[0]+n[0]*i,t[1]=e[1]+n[1]*i,t[2]=e[2]+n[2]*i,t}});var YCt=Vo((W9i,kCt)=>{var f9i=R(W());kCt.exports=GGe;function GGe(t,e){var n=e[0]-t[0],i=e[1]-t[1],o=e[2]-t[2];return Math.sqrt(n*n+i*i+o*o)}});var XCt=Vo((F9i,xCt)=>{var U9i=R(W());xCt.exports=AGe;function AGe(t,e){var n=e[0]-t[0],i=e[1]-t[1],o=e[2]-t[2];return n*n+i*i+o*o}});var LCt=Vo((G9i,JCt)=>{var A9i=R(W()),t1=1e3,e1=t1*60,n1=e1*60,zT=n1*24,TGe=zT*7,SGe=zT*365.25;JCt.exports=function(t,e){e=e||{};var n=typeof t;if(n==="string"&&t.length>0)return gGe(t);if(n==="number"&&isFinite(t))return e.long?CGe(t):EGe(t);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(t))};function gGe(t){if(t=String(t),!(t.length>100)){var e=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(t);if(e){var n=parseFloat(e[1]),i=(e[2]||"ms").toLowerCase();switch(i){case"years":case"year":case"yrs":case"yr":case"y":return n*SGe;case"weeks":case"week":case"w":return n*TGe;case"days":case"day":case"d":return n*zT;case"hours":case"hour":case"hrs":case"hr":case"h":return n*n1;case"minutes":case"minute":case"mins":case"min":case"m":return n*e1;case"seconds":case"second":case"secs":case"sec":case"s":return n*t1;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return n;default:return}}}}function EGe(t){var e=Math.abs(t);return e>=zT?Math.round(t/zT)+"d":e>=n1?Math.round(t/n1)+"h":e>=e1?Math.round(t/e1)+"m":e>=t1?Math.round(t/t1)+"s":t+"ms"}function CGe(t){var e=Math.abs(t);return e>=zT?kK(t,e,zT,"day"):e>=n1?kK(t,e,n1,"hour"):e>=e1?kK(t,e,e1,"minute"):e>=t1?kK(t,e,t1,"second"):t+" ms"}function kK(t,e,n,i){var o=e>=n*1.5;return Math.round(t/n)+" "+i+(o?"s":"")}});var _Ct=Vo((T9i,MCt)=>{var S9i=R(W());function IGe(t){n.debug=n,n.default=n,n.coerce=r,n.disable=a,n.enable=o,n.enabled=s,n.humanize=LCt(),n.destroy=d,Object.keys(t).forEach(m=>{n[m]=t[m]}),n.names=[],n.skips=[],n.formatters={};function e(m){let h=0;for(let Z=0;Z{if(y==="%%")return"%";g++;let Q=n.formatters[Y];if(typeof Q=="function"){let J=U[g];y=Q.call(G,J),U.splice(g,1),g--}return y}),n.formatArgs.call(G,U),(G.log||n.log).apply(G,U)}return F.namespace=m,F.useColors=n.useColors(),F.color=n.selectColor(m),F.extend=i,F.destroy=n.destroy,Object.defineProperty(F,"enabled",{enumerable:!0,configurable:!1,get:()=>Z!==null?Z:(b!==n.namespaces&&(b=n.namespaces,u=n.enabled(m)),u),set:U=>{Z=U}}),typeof n.init=="function"&&n.init(F),F}function i(m,h){let Z=n(this.namespace+(typeof h>"u"?":":h)+m);return Z.log=this.log,Z}function o(m){n.save(m),n.namespaces=m,n.names=[],n.skips=[];let h,Z=(typeof m=="string"?m:"").split(/[\s,]+/),b=Z.length;for(h=0;h"-"+h)].join(",");return n.enable(""),m}function s(m){if(m[m.length-1]==="*")return!0;let h,Z;for(h=0,Z=n.skips.length;h{var g9i=R(W());qh.formatArgs=yGe;qh.save=BGe;qh.load=QGe;qh.useColors=NGe;qh.storage=kGe();qh.destroy=(()=>{let t=!1;return()=>{t||(t=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})();qh.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function NGe(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)?!1:typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function yGe(t){if(t[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+t[0]+(this.useColors?"%c ":" ")+"+"+YK.exports.humanize(this.diff),!this.useColors)return;let e="color: "+this.color;t.splice(1,0,e,"color: inherit");let n=0,i=0;t[0].replace(/%[a-zA-Z%]/g,o=>{o!=="%%"&&(n++,o==="%c"&&(i=n))}),t.splice(i,0,e)}qh.log=console.debug||console.log||(()=>{});function BGe(t){try{t?qh.storage.setItem("debug",t):qh.storage.removeItem("debug")}catch{}}function QGe(){let t;try{t=qh.storage.getItem("debug")}catch{}return!t&&typeof process<"u"&&"env"in process&&(t=process.env.DEBUG),t}function kGe(){try{return localStorage}catch{}}YK.exports=_Ct()(qh);var{formatters:YGe}=YK.exports;YGe.j=function(t){try{return JSON.stringify(t)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var wCt=Vo(XK=>{"use strict";var C9i=R(W());Object.defineProperty(XK,"__esModule",{value:!0});XK.default=void 0;var xGe=HCt(YCt()),XGe=HCt(XCt());function HCt(t){return t&&t.__esModule?t:{default:t}}function JGe(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function DCt(t,e){for(var n=0;n ").concat(i.head().index," between ").concat(i.face.collectIndices(),", ").concat(n.face.collectIndices())),this.opposite=n,n.opposite=this}}]),t}();XK.default=MGe});var jCt=Vo(Ib=>{"use strict";var N9i=R(W());Object.defineProperty(Ib,"__esModule",{value:!0});Ib.default=Ib.VISIBLE=Ib.NON_CONVEX=Ib.DELETED=void 0;var not=Nb(eot()),PCt=Nb(SCt()),iot=Nb(NK()),_Ge=Nb(yK()),DGe=Nb(ECt()),OGe=Nb(ICt()),oot=Nb(yCt()),HGe=Nb(QCt()),wGe=Nb($it()),aot=Nb(wCt());function Nb(t){return t&&t.__esModule?t:{default:t}}function PGe(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function vCt(t,e){for(var n=0;n0;)i=i.next,n-=1;for(;n<0;)i=i.prev,n+=1;return i}},{key:"computeNormal",value:function(){var n=this.edge,i=n.next,o=i.next,a=(0,iot.default)([],i.head().point,n.head().point),s=[],l=[];for(this.nVertices=2,this.normal=[0,0,0];o!==n;)(0,DGe.default)(l,a),(0,iot.default)(a,o.head().point,n.head().point),(0,PCt.default)(this.normal,this.normal,(0,_Ge.default)(s,l,a)),o=o.next,this.nVertices+=1;this.area=(0,OGe.default)(this.normal),this.normal=(0,oot.default)(this.normal,this.normal,1/this.area)}},{key:"computeNormalMinArea",value:function(n){if(this.computeNormal(),this.areao&&(i=a,o=s),a=a.next}while(a!==this.edge);var l=i.tail().point,r=i.head().point,d=(0,iot.default)([],r,l),m=Math.sqrt(o);(0,oot.default)(d,d,1/m);var h=(0,not.default)(this.normal,d);(0,HGe.default)(this.normal,this.normal,d,-h),(0,wGe.default)(this.normal,this.normal)}}},{key:"computeCentroid",value:function(){this.centroid=[0,0,0];var n=this.edge;do(0,PCt.default)(this.centroid,this.centroid,n.head().point),n=n.next;while(n!==this.edge);(0,oot.default)(this.centroid,this.centroid,1/this.nVertices)}},{key:"computeNormalAndCentroid",value:function(n){typeof n<"u"?this.computeNormalMinArea(n):this.computeNormal(),this.computeCentroid(),this.offset=(0,not.default)(this.normal,this.centroid)}},{key:"distanceToPlane",value:function(n){return(0,not.default)(this.normal,n)-this.offset}},{key:"connectHalfEdges",value:function(n,i){var o;if(n.opposite.face===i.opposite.face){var a=i.opposite.face,s;n===this.edge&&(this.edge=i),a.nVertices===3?(s=i.opposite.prev.opposite,a.mark=sot,o=a):(s=i.opposite.next,a.edge===s.prev&&(a.edge=s),s.prev=s.prev.prev,s.prev.next=s),i.prev=n.prev,i.prev.next=i,i.setOpposite(s),a.computeNormalAndCentroid()}else n.next=i,i.prev=n;return o}},{key:"mergeAdjacentFaces",value:function(n,i){var o=n.opposite,a=o.face;i.push(a),a.mark=sot;for(var s=n.prev,l=n.next,r=o.prev,d=o.next;s.opposite.face===a;)s=s.prev,d=d.next;for(;l.opposite.face===a;)l=l.next,r=r.prev;var m;for(m=d;m!==r.next;m=m.next)m.face=this;this.edge=l;var h;return h=this.connectHalfEdges(r,l),h&&i.push(h),h=this.connectHalfEdges(s,d),h&&i.push(h),this.computeNormalAndCentroid(),i}},{key:"collectIndices",value:function(){var n=[],i=this.edge;do n.push(i.head().index),i=i.next;while(i!==this.edge);return n}}],[{key:"createTriangle",value:function(n,i,o){var a=arguments.length>3&&arguments[3]!==void 0?arguments[3]:0,s=new t,l=new aot.default(n,s),r=new aot.default(i,s),d=new aot.default(o,s);return l.next=d.prev=r,r.next=l.prev=d,d.next=r.prev=l,s.edge=l,s.computeNormalAndCentroid(a),KCt.enabled&&KCt("face created %j",s.collectIndices()),s}}]),t}();Ib.default=zGe});var iIt=Vo(JK=>{"use strict";var B9i=R(W());function rot(t){"@babel/helpers - typeof";return rot=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(e){return typeof e}:function(e){return e&&typeof Symbol=="function"&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},rot(t)}Object.defineProperty(JK,"__esModule",{value:!0});JK.default=void 0;var jGe=sM(ZCt()),qGe=sM(tot()),lot=sM(eot()),qCt=sM(UCt()),$Ge=sM(ACt()),qr=tAe(jCt());function nIt(t){if(typeof WeakMap!="function")return null;var e=new WeakMap,n=new WeakMap;return(nIt=function(o){return o?n:e})(t)}function tAe(t,e){if(!e&&t&&t.__esModule)return t;if(t===null||rot(t)!=="object"&&typeof t!="function")return{default:t};var n=nIt(e);if(n&&n.has(t))return n.get(t);var i={},o=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var a in t)if(a!=="default"&&Object.prototype.hasOwnProperty.call(t,a)){var s=o?Object.getOwnPropertyDescriptor(t,a):null;s&&(s.get||s.set)?Object.defineProperty(i,a,s):i[a]=t[a]}return i.default=t,n&&n.set(t,i),i}function sM(t){return t&&t.__esModule?t:{default:t}}function eAe(t,e){return aAe(t)||oAe(t,e)||iAe(t,e)||nAe()}function nAe(){throw new TypeError(`Invalid attempt to destructure non-iterable instance. -In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function iAe(t,e){if(t){if(typeof t=="string")return $Ct(t,e);var n=Object.prototype.toString.call(t).slice(8,-1);if(n==="Object"&&t.constructor&&(n=t.constructor.name),n==="Map"||n==="Set")return Array.from(t);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return $Ct(t,e)}}function $Ct(t,e){(e==null||e>t.length)&&(e=t.length);for(var n=0,i=new Array(e);nthis.tolerance?this.addVertexToFace(s,i):this.unclaimed.add(s)}}},{key:"resolveUnclaimedPoints",value:function(n){for(var i=this.unclaimed.first(),o=i;o;o=i){i=o.next;for(var a=this.tolerance,s=void 0,l=0;la&&(a=d,s=r),a>1e3*this.tolerance)break}}s&&this.addVertexToFace(o,s)}}},{key:"computeExtremes",value:function(){var n=this,i=[],o=[],a=[],s=[],l,r;for(l=0;l<3;l+=1)a[l]=s[l]=this.vertices[0];for(l=0;l<3;l+=1)i[l]=o[l]=this.vertices[0].point[l];for(l=1;lo[r]&&(o[r]=m[r],s[r]=d)}return this.tolerance=3*Number.EPSILON*(Math.max(Math.abs(i[0]),Math.abs(o[0]))+Math.max(Math.abs(i[1]),Math.abs(o[1]))+Math.max(Math.abs(i[2]),Math.abs(o[2]))),zZ.enabled&&zZ("tolerance %d",n.tolerance),[a,s]}},{key:"createInitialSimplex",value:function(){var n=this.vertices,i=this.computeExtremes(),o=eAe(i,2),a=o[0],s=o[1],l,r,d=0,m=0;for(l=0;l<3;l+=1){var h=s[l].point[l]-a[l].point[l];h>d&&(d=h,m=l)}var Z=a[m],b=s[m],u,F;for(d=0,l=0;ld&&(d=G,u=U)}}var A=(0,qGe.default)([],Z.point,b.point,u.point),T=(0,lot.default)(Z.point,A);for(d=-1,l=0;ld&&(d=C,F=g)}}var y=[];if((0,lot.default)(F.point,A)-T<0)for(y.push(qr.default.createTriangle(Z,b,u),qr.default.createTriangle(F,b,Z),qr.default.createTriangle(F,u,b),qr.default.createTriangle(F,Z,u)),l=0;l<3;l+=1){var Y=(l+1)%3;y[l+1].getEdge(2).setOpposite(y[0].getEdge(Y)),y[l+1].getEdge(1).setOpposite(y[Y+1].getEdge(0))}else for(y.push(qr.default.createTriangle(Z,u,b),qr.default.createTriangle(F,Z,b),qr.default.createTriangle(F,b,u),qr.default.createTriangle(F,u,Z)),l=0;l<3;l+=1){var Q=(l+1)%3;y[l+1].getEdge(2).setOpposite(y[0].getEdge((3-l)%3)),y[l+1].getEdge(0).setOpposite(y[Q+1].getEdge(1))}for(l=0;l<4;l+=1)this.faces.push(y[l]);for(l=0;ld&&(d=V,M=y[r])}M&&this.addVertexToFace(J,M)}}}},{key:"reindexFaceAndVertices",value:function(){for(var n=[],i=0;io&&(o=s,n=i)}return n}}},{key:"computeHorizon",value:function(n,i,o,a){this.deleteFaceVertices(o),o.mark=qr.DELETED;var s;i?s=i.next:s=i=o.getEdge(0);do{var l=s.opposite,r=l.face;r.mark===qr.VISIBLE&&(r.distanceToPlane(n)>this.tolerance?this.computeHorizon(n,l,r,a):a.push(s)),s=s.next}while(s!==i)}},{key:"addAdjoiningFace",value:function(n,i){var o=qr.default.createTriangle(n,i.tail(),i.head());return this.faces.push(o),o.getEdge(-1).setOpposite(i.opposite),o.getEdge(0)}},{key:"addNewFaces",value:function(n,i){this.newFaces=[];for(var o,a,s=0;s=n.nVertices)throw Error("merge recursion limit exceeded");var l=o.opposite.face,r=!1;if(i===eIt?(this.oppositeFaceDistance(o)>-this.tolerance||this.oppositeFaceDistance(o.opposite)>-this.tolerance)&&(r=!0):n.area>l.area?this.oppositeFaceDistance(o)>-this.tolerance?r=!0:this.oppositeFaceDistance(o.opposite)>-this.tolerance&&(a=!1):this.oppositeFaceDistance(o.opposite)>-this.tolerance?r=!0:this.oppositeFaceDistance(o)>-this.tolerance&&(a=!1),r){zZ("face merge");for(var d=n.mergeAdjacentFaces(o,[]),m=0;m{"use strict";var k9i=R(W());Object.defineProperty(LK,"__esModule",{value:!0});LK.default=hAe;LK.isPointInsideHull=pAe;var cAe=oIt(iIt()),mAe=oIt(tot());function oIt(t){return t&&t.__esModule?t:{default:t}}function hAe(t){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},n=new cAe.default(t);return n.build(),n.collectFaces(e.skipTriangulation)}function pAe(t,e,n){for(var i=0;i0)return!1}return!0}});var wst=Vo((exports,module)=>{var gOo=R(W());/*! +}`;var uo=Mct(function(){return ia(St,li+"return "+Oe).apply(t,Jt)});if(uo.source=Oe,D8(uo))throw uo;return uo}function fLt(T){return xa(T).toLowerCase()}function FLt(T){return xa(T).toUpperCase()}function ULt(T,N,O){if(T=xa(T),T&&(O||N===t))return ZO(T);if(!T||!(N=ch(N)))return T;var tt=mm(T),ct=mm(N),St=wW(tt,ct),Jt=RO(tt,ct)+1;return of(tt,St,Jt).join("")}function GLt(T,N,O){if(T=xa(T),T&&(O||N===t))return T.slice(0,Tg(T)+1);if(!T||!(N=ch(N)))return T;var tt=mm(T),ct=RO(tt,mm(N))+1;return of(tt,0,ct).join("")}function ALt(T,N,O){if(T=xa(T),T&&(O||N===t))return T.replace(Wa,"");if(!T||!(N=ch(N)))return T;var tt=mm(T),ct=wW(tt,mm(N));return of(tt,ct).join("")}function SLt(T,N){var O=Q,tt=J;if(qs(N)){var ct="separator"in N?N.separator:ct;O="length"in N?po(N.length):O,tt="omission"in N?ch(N.omission):tt}T=xa(T);var St=T.length;if(PW(T)){var Jt=mm(T);St=Jt.length}if(O>=St)return T;var Ht=O-vW(tt);if(Ht<1)return tt;var $t=Jt?of(Jt,0,Ht).join(""):T.slice(0,Ht);if(ct===t)return $t+tt;if(Jt&&(Ht+=$t.length-Ht),O8(ct)){if(T.slice(Ht).search(ct)){var ye,Be=$t;for(ct.global||(ct=BN(ct.source,xa(mr.exec(ct))+"g")),ct.lastIndex=0;ye=ct.exec(Be);)var Oe=ye.index;$t=$t.slice(0,Oe===t?Ht:Oe)}}else if(T.indexOf(ch(ct),Ht)!=Ht){var Bn=$t.lastIndexOf(ct);Bn>-1&&($t=$t.slice(0,Bn))}return $t+tt}function TLt(T){return T=xa(T),T&&da.test(T)?T.replace(An,P4):T}var gLt=Lg(function(T,N,O){return T+(O?" ":"")+N.toUpperCase()}),P8=_dt("toUpperCase");function Lct(T,N,O){return T=xa(T),N=O?t:N,N===t?Sg(T)?Ta(T):k4(T):T.match(N)||[]}var Mct=Fo(function(T,N){try{return Wc(T,t,N)}catch(O){return D8(O)?O:new Ai(O)}}),ELt=mb(function(T,N){return cm(N,function(O){O=CZ(O),db(T,O,M8(T[O],T))}),T});function CLt(T){var N=T==null?0:T.length,O=Ei();return T=N?Sa(T,function(tt){if(typeof tt[1]!="function")throw new hm(o);return[O(tt[0]),tt[1]]}):[],Fo(function(tt){for(var ct=-1;++ct_)return[];var O=z,tt=Vs(T,z);N=Ei(N),T-=z;for(var ct=NN(tt,N);++O0||N<0)?new So(O):(T<0?O=O.takeRight(-T):T&&(O=O.drop(T)),N!==t&&(N=po(N),O=N<0?O.dropRight(-N):O.take(N-T)),O)},So.prototype.takeRightWhile=function(T){return this.reverse().takeWhile(T).reverse()},So.prototype.toArray=function(){return this.take(z)},gZ(So.prototype,function(T,N){var O=/^(?:filter|find|map|reject)|While$/.test(N),tt=/^(?:head|last)$/.test(N),ct=Rt[tt?"take"+(N=="last"?"Right":""):N],St=tt||/^find/.test(N);ct&&(Rt.prototype[N]=function(){var Jt=this.__wrapped__,Ht=tt?[1]:arguments,$t=Jt instanceof So,ye=Ht[0],Be=$t||ji(Jt),Oe=function(No){var Ko=ct.apply(Rt,_V([No],Ht));return tt&&Bn?Ko[0]:Ko};Be&&O&&typeof ye=="function"&&ye.length!=1&&($t=Be=!1);var Bn=this.__chain__,li=!!this.__actions__.length,Qi=St&&!Bn,uo=$t&&!li;if(!St&&Be){Jt=uo?Jt:new So(this);var ki=T.apply(Jt,Ht);return ki.__actions__.push({func:JO,args:[Oe],thisArg:t}),new pm(ki,Bn)}return Qi&&uo?T.apply(this,Ht):(ki=this.thru(Oe),Qi?tt?ki.value()[0]:ki.value():ki)})}),cm(["pop","push","shift","sort","splice","unshift"],function(T){var N=gg[T],O=/^(?:push|sort|unshift)$/.test(T)?"tap":"thru",tt=/^(?:pop|shift)$/.test(T);Rt.prototype[T]=function(){var ct=arguments;if(tt&&!this.__chain__){var St=this.value();return N.apply(ji(St)?St:[],ct)}return this[O](function(Jt){return N.apply(ji(Jt)?Jt:[],ct)})}}),gZ(So.prototype,function(T,N){var O=Rt[N];if(O){var tt=O.name+"";ga.call($W,tt)||($W[tt]=[]),$W[tt].push({name:N,func:O})}}),$W[yO(t,F).name]=[{name:"wrapper",func:t}],So.prototype.clone=r8,So.prototype.reverse=Xg,So.prototype.value=d8,Rt.prototype.at=iXt,Rt.prototype.chain=oXt,Rt.prototype.commit=aXt,Rt.prototype.next=sXt,Rt.prototype.plant=rXt,Rt.prototype.reverse=dXt,Rt.prototype.toJSON=Rt.prototype.valueOf=Rt.prototype.value=cXt,Rt.prototype.first=Rt.prototype.head,tG&&(Rt.prototype[tG]=lXt),Rt},DV=K4();typeof define=="function"&&typeof define.amd=="object"&&define.amd?(ps._=DV,define(function(){return DV})):Wp?((Wp.exports=DV)._=DV,Ql._=DV):ps._=DV}).call(DI)});var N3=Zo((D_i,aCt)=>{var O_i=b(W());aCt.exports=eGe;function eGe(t,e,n){return t[0]=e[0]-n[0],t[1]=e[1]-n[1],t[2]=e[2]-n[2],t}});var y3=Zo((H_i,sCt)=>{var w_i=b(W());sCt.exports=nGe;function nGe(t,e,n){var i=e[0],o=e[1],a=e[2],s=n[0],l=n[1],r=n[2];return t[0]=o*r-a*l,t[1]=a*s-i*r,t[2]=i*l-o*s,t}});var rCt=Zo((P_i,lCt)=>{var v_i=b(W());lCt.exports=iGe;function iGe(t){var e=t[0],n=t[1],i=t[2];return e*e+n*n+i*i}});var pCt=Zo((K_i,hCt)=>{var z_i=b(W()),dCt=N3(),oGe=y3(),cCt=rCt(),qit=[],mCt=[],aGe=[];hCt.exports=function(t,e,n){dCt(qit,n,e),dCt(mCt,t,e);var i=cCt(oGe(aGe,mCt,qit)),o=cCt(qit);if(o===0)throw Error("a and b are the same point");return i/o}});var uCt=Zo((j_i,VCt)=>{"use strict";var q_i=b(W()),sGe=pCt();VCt.exports=function(t,e,n){return Math.sqrt(sGe(t,e,n))}});var $it=Zo(($_i,ZCt)=>{var t9i=b(W());ZCt.exports=lGe;function lGe(t,e){var n=e[0],i=e[1],o=e[2],a=n*n+i*i+o*o;return a>0&&(a=1/Math.sqrt(a),t[0]=e[0]*a,t[1]=e[1]*a,t[2]=e[2]*a),t}});var tot=Zo((e9i,WCt)=>{var n9i=b(W()),rGe=$it(),RCt=N3(),dGe=y3(),bCt=[0,0,0];WCt.exports=cGe;function cGe(t,e,n,i){return RCt(t,e,n),RCt(bCt,n,i),dGe(t,t,bCt),rGe(t,t)}});var eot=Zo((i9i,fCt)=>{var o9i=b(W());fCt.exports=mGe;function mGe(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]}});var UCt=Zo(B3=>{"use strict";var s9i=b(W());Object.defineProperty(B3,"__esModule",{value:!0});B3.default=void 0;function hGe(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function FCt(t,e){for(var n=0;n{"use strict";var r9i=b(W());Object.defineProperty(Q3,"__esModule",{value:!0});Q3.default=void 0;function GCt(t,e){for(var n=0;n{var c9i=b(W());SCt.exports=bGe;function bGe(t,e,n){return t[0]=e[0]+n[0],t[1]=e[1]+n[1],t[2]=e[2]+n[2],t}});var ECt=Zo((m9i,gCt)=>{var h9i=b(W());gCt.exports=WGe;function WGe(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}});var ICt=Zo((p9i,CCt)=>{var V9i=b(W());CCt.exports=fGe;function fGe(t){var e=t[0],n=t[1],i=t[2];return Math.sqrt(e*e+n*n+i*i)}});var yCt=Zo((u9i,NCt)=>{var Z9i=b(W());NCt.exports=FGe;function FGe(t,e,n){return t[0]=e[0]*n,t[1]=e[1]*n,t[2]=e[2]*n,t}});var QCt=Zo((R9i,BCt)=>{var b9i=b(W());BCt.exports=UGe;function UGe(t,e,n,i){return t[0]=e[0]+n[0]*i,t[1]=e[1]+n[1]*i,t[2]=e[2]+n[2]*i,t}});var YCt=Zo((W9i,kCt)=>{var f9i=b(W());kCt.exports=GGe;function GGe(t,e){var n=e[0]-t[0],i=e[1]-t[1],o=e[2]-t[2];return Math.sqrt(n*n+i*i+o*o)}});var XCt=Zo((F9i,xCt)=>{var U9i=b(W());xCt.exports=AGe;function AGe(t,e){var n=e[0]-t[0],i=e[1]-t[1],o=e[2]-t[2];return n*n+i*i+o*o}});var LCt=Zo((G9i,JCt)=>{var A9i=b(W()),t1=1e3,e1=t1*60,n1=e1*60,zS=n1*24,SGe=zS*7,TGe=zS*365.25;JCt.exports=function(t,e){e=e||{};var n=typeof t;if(n==="string"&&t.length>0)return gGe(t);if(n==="number"&&isFinite(t))return e.long?CGe(t):EGe(t);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(t))};function gGe(t){if(t=String(t),!(t.length>100)){var e=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(t);if(e){var n=parseFloat(e[1]),i=(e[2]||"ms").toLowerCase();switch(i){case"years":case"year":case"yrs":case"yr":case"y":return n*TGe;case"weeks":case"week":case"w":return n*SGe;case"days":case"day":case"d":return n*zS;case"hours":case"hour":case"hrs":case"hr":case"h":return n*n1;case"minutes":case"minute":case"mins":case"min":case"m":return n*e1;case"seconds":case"second":case"secs":case"sec":case"s":return n*t1;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return n;default:return}}}}function EGe(t){var e=Math.abs(t);return e>=zS?Math.round(t/zS)+"d":e>=n1?Math.round(t/n1)+"h":e>=e1?Math.round(t/e1)+"m":e>=t1?Math.round(t/t1)+"s":t+"ms"}function CGe(t){var e=Math.abs(t);return e>=zS?k3(t,e,zS,"day"):e>=n1?k3(t,e,n1,"hour"):e>=e1?k3(t,e,e1,"minute"):e>=t1?k3(t,e,t1,"second"):t+" ms"}function k3(t,e,n,i){var o=e>=n*1.5;return Math.round(t/n)+" "+i+(o?"s":"")}});var _Ct=Zo((S9i,MCt)=>{var T9i=b(W());function IGe(t){n.debug=n,n.default=n,n.coerce=r,n.disable=a,n.enable=o,n.enabled=s,n.humanize=LCt(),n.destroy=d,Object.keys(t).forEach(m=>{n[m]=t[m]}),n.names=[],n.skips=[],n.formatters={};function e(m){let h=0;for(let u=0;u{if(y==="%%")return"%";g++;let Q=n.formatters[Y];if(typeof Q=="function"){let J=U[g];y=Q.call(G,J),U.splice(g,1),g--}return y}),n.formatArgs.call(G,U),(G.log||n.log).apply(G,U)}return F.namespace=m,F.useColors=n.useColors(),F.color=n.selectColor(m),F.extend=i,F.destroy=n.destroy,Object.defineProperty(F,"enabled",{enumerable:!0,configurable:!1,get:()=>u!==null?u:(R!==n.namespaces&&(R=n.namespaces,V=n.enabled(m)),V),set:U=>{u=U}}),typeof n.init=="function"&&n.init(F),F}function i(m,h){let u=n(this.namespace+(typeof h>"u"?":":h)+m);return u.log=this.log,u}function o(m){n.save(m),n.namespaces=m,n.names=[],n.skips=[];let h,u=(typeof m=="string"?m:"").split(/[\s,]+/),R=u.length;for(h=0;h"-"+h)].join(",");return n.enable(""),m}function s(m){if(m[m.length-1]==="*")return!0;let h,u;for(h=0,u=n.skips.length;h{var g9i=b(W());qh.formatArgs=yGe;qh.save=BGe;qh.load=QGe;qh.useColors=NGe;qh.storage=kGe();qh.destroy=(()=>{let t=!1;return()=>{t||(t=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})();qh.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function NGe(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)?!1:typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function yGe(t){if(t[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+t[0]+(this.useColors?"%c ":" ")+"+"+Y3.exports.humanize(this.diff),!this.useColors)return;let e="color: "+this.color;t.splice(1,0,e,"color: inherit");let n=0,i=0;t[0].replace(/%[a-zA-Z%]/g,o=>{o!=="%%"&&(n++,o==="%c"&&(i=n))}),t.splice(i,0,e)}qh.log=console.debug||console.log||(()=>{});function BGe(t){try{t?qh.storage.setItem("debug",t):qh.storage.removeItem("debug")}catch{}}function QGe(){let t;try{t=qh.storage.getItem("debug")}catch{}return!t&&typeof process<"u"&&"env"in process&&(t=process.env.DEBUG),t}function kGe(){try{return localStorage}catch{}}Y3.exports=_Ct()(qh);var{formatters:YGe}=Y3.exports;YGe.j=function(t){try{return JSON.stringify(t)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var wCt=Zo(X3=>{"use strict";var C9i=b(W());Object.defineProperty(X3,"__esModule",{value:!0});X3.default=void 0;var xGe=HCt(YCt()),XGe=HCt(XCt());function HCt(t){return t&&t.__esModule?t:{default:t}}function JGe(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function DCt(t,e){for(var n=0;n ").concat(i.head().index," between ").concat(i.face.collectIndices(),", ").concat(n.face.collectIndices())),this.opposite=n,n.opposite=this}}]),t}();X3.default=MGe});var jCt=Zo(IR=>{"use strict";var N9i=b(W());Object.defineProperty(IR,"__esModule",{value:!0});IR.default=IR.VISIBLE=IR.NON_CONVEX=IR.DELETED=void 0;var not=NR(eot()),PCt=NR(TCt()),iot=NR(N3()),_Ge=NR(y3()),DGe=NR(ECt()),OGe=NR(ICt()),oot=NR(yCt()),HGe=NR(QCt()),wGe=NR($it()),aot=NR(wCt());function NR(t){return t&&t.__esModule?t:{default:t}}function PGe(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function vCt(t,e){for(var n=0;n0;)i=i.next,n-=1;for(;n<0;)i=i.prev,n+=1;return i}},{key:"computeNormal",value:function(){var n=this.edge,i=n.next,o=i.next,a=(0,iot.default)([],i.head().point,n.head().point),s=[],l=[];for(this.nVertices=2,this.normal=[0,0,0];o!==n;)(0,DGe.default)(l,a),(0,iot.default)(a,o.head().point,n.head().point),(0,PCt.default)(this.normal,this.normal,(0,_Ge.default)(s,l,a)),o=o.next,this.nVertices+=1;this.area=(0,OGe.default)(this.normal),this.normal=(0,oot.default)(this.normal,this.normal,1/this.area)}},{key:"computeNormalMinArea",value:function(n){if(this.computeNormal(),this.areao&&(i=a,o=s),a=a.next}while(a!==this.edge);var l=i.tail().point,r=i.head().point,d=(0,iot.default)([],r,l),m=Math.sqrt(o);(0,oot.default)(d,d,1/m);var h=(0,not.default)(this.normal,d);(0,HGe.default)(this.normal,this.normal,d,-h),(0,wGe.default)(this.normal,this.normal)}}},{key:"computeCentroid",value:function(){this.centroid=[0,0,0];var n=this.edge;do(0,PCt.default)(this.centroid,this.centroid,n.head().point),n=n.next;while(n!==this.edge);(0,oot.default)(this.centroid,this.centroid,1/this.nVertices)}},{key:"computeNormalAndCentroid",value:function(n){typeof n<"u"?this.computeNormalMinArea(n):this.computeNormal(),this.computeCentroid(),this.offset=(0,not.default)(this.normal,this.centroid)}},{key:"distanceToPlane",value:function(n){return(0,not.default)(this.normal,n)-this.offset}},{key:"connectHalfEdges",value:function(n,i){var o;if(n.opposite.face===i.opposite.face){var a=i.opposite.face,s;n===this.edge&&(this.edge=i),a.nVertices===3?(s=i.opposite.prev.opposite,a.mark=sot,o=a):(s=i.opposite.next,a.edge===s.prev&&(a.edge=s),s.prev=s.prev.prev,s.prev.next=s),i.prev=n.prev,i.prev.next=i,i.setOpposite(s),a.computeNormalAndCentroid()}else n.next=i,i.prev=n;return o}},{key:"mergeAdjacentFaces",value:function(n,i){var o=n.opposite,a=o.face;i.push(a),a.mark=sot;for(var s=n.prev,l=n.next,r=o.prev,d=o.next;s.opposite.face===a;)s=s.prev,d=d.next;for(;l.opposite.face===a;)l=l.next,r=r.prev;var m;for(m=d;m!==r.next;m=m.next)m.face=this;this.edge=l;var h;return h=this.connectHalfEdges(r,l),h&&i.push(h),h=this.connectHalfEdges(s,d),h&&i.push(h),this.computeNormalAndCentroid(),i}},{key:"collectIndices",value:function(){var n=[],i=this.edge;do n.push(i.head().index),i=i.next;while(i!==this.edge);return n}}],[{key:"createTriangle",value:function(n,i,o){var a=arguments.length>3&&arguments[3]!==void 0?arguments[3]:0,s=new t,l=new aot.default(n,s),r=new aot.default(i,s),d=new aot.default(o,s);return l.next=d.prev=r,r.next=l.prev=d,d.next=r.prev=l,s.edge=l,s.computeNormalAndCentroid(a),KCt.enabled&&KCt("face created %j",s.collectIndices()),s}}]),t}();IR.default=zGe});var iIt=Zo(J3=>{"use strict";var B9i=b(W());function rot(t){"@babel/helpers - typeof";return rot=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(e){return typeof e}:function(e){return e&&typeof Symbol=="function"&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},rot(t)}Object.defineProperty(J3,"__esModule",{value:!0});J3.default=void 0;var jGe=sM(uCt()),qGe=sM(tot()),lot=sM(eot()),qCt=sM(UCt()),$Ge=sM(ACt()),qr=tAe(jCt());function nIt(t){if(typeof WeakMap!="function")return null;var e=new WeakMap,n=new WeakMap;return(nIt=function(o){return o?n:e})(t)}function tAe(t,e){if(!e&&t&&t.__esModule)return t;if(t===null||rot(t)!=="object"&&typeof t!="function")return{default:t};var n=nIt(e);if(n&&n.has(t))return n.get(t);var i={},o=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var a in t)if(a!=="default"&&Object.prototype.hasOwnProperty.call(t,a)){var s=o?Object.getOwnPropertyDescriptor(t,a):null;s&&(s.get||s.set)?Object.defineProperty(i,a,s):i[a]=t[a]}return i.default=t,n&&n.set(t,i),i}function sM(t){return t&&t.__esModule?t:{default:t}}function eAe(t,e){return aAe(t)||oAe(t,e)||iAe(t,e)||nAe()}function nAe(){throw new TypeError(`Invalid attempt to destructure non-iterable instance. +In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function iAe(t,e){if(t){if(typeof t=="string")return $Ct(t,e);var n=Object.prototype.toString.call(t).slice(8,-1);if(n==="Object"&&t.constructor&&(n=t.constructor.name),n==="Map"||n==="Set")return Array.from(t);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return $Ct(t,e)}}function $Ct(t,e){(e==null||e>t.length)&&(e=t.length);for(var n=0,i=new Array(e);nthis.tolerance?this.addVertexToFace(s,i):this.unclaimed.add(s)}}},{key:"resolveUnclaimedPoints",value:function(n){for(var i=this.unclaimed.first(),o=i;o;o=i){i=o.next;for(var a=this.tolerance,s=void 0,l=0;la&&(a=d,s=r),a>1e3*this.tolerance)break}}s&&this.addVertexToFace(o,s)}}},{key:"computeExtremes",value:function(){var n=this,i=[],o=[],a=[],s=[],l,r;for(l=0;l<3;l+=1)a[l]=s[l]=this.vertices[0];for(l=0;l<3;l+=1)i[l]=o[l]=this.vertices[0].point[l];for(l=1;lo[r]&&(o[r]=m[r],s[r]=d)}return this.tolerance=3*Number.EPSILON*(Math.max(Math.abs(i[0]),Math.abs(o[0]))+Math.max(Math.abs(i[1]),Math.abs(o[1]))+Math.max(Math.abs(i[2]),Math.abs(o[2]))),zu.enabled&&zu("tolerance %d",n.tolerance),[a,s]}},{key:"createInitialSimplex",value:function(){var n=this.vertices,i=this.computeExtremes(),o=eAe(i,2),a=o[0],s=o[1],l,r,d=0,m=0;for(l=0;l<3;l+=1){var h=s[l].point[l]-a[l].point[l];h>d&&(d=h,m=l)}var u=a[m],R=s[m],V,F;for(d=0,l=0;ld&&(d=G,V=U)}}var A=(0,qGe.default)([],u.point,R.point,V.point),S=(0,lot.default)(u.point,A);for(d=-1,l=0;ld&&(d=C,F=g)}}var y=[];if((0,lot.default)(F.point,A)-S<0)for(y.push(qr.default.createTriangle(u,R,V),qr.default.createTriangle(F,R,u),qr.default.createTriangle(F,V,R),qr.default.createTriangle(F,u,V)),l=0;l<3;l+=1){var Y=(l+1)%3;y[l+1].getEdge(2).setOpposite(y[0].getEdge(Y)),y[l+1].getEdge(1).setOpposite(y[Y+1].getEdge(0))}else for(y.push(qr.default.createTriangle(u,V,R),qr.default.createTriangle(F,u,R),qr.default.createTriangle(F,R,V),qr.default.createTriangle(F,V,u)),l=0;l<3;l+=1){var Q=(l+1)%3;y[l+1].getEdge(2).setOpposite(y[0].getEdge((3-l)%3)),y[l+1].getEdge(0).setOpposite(y[Q+1].getEdge(1))}for(l=0;l<4;l+=1)this.faces.push(y[l]);for(l=0;ld&&(d=Z,M=y[r])}M&&this.addVertexToFace(J,M)}}}},{key:"reindexFaceAndVertices",value:function(){for(var n=[],i=0;io&&(o=s,n=i)}return n}}},{key:"computeHorizon",value:function(n,i,o,a){this.deleteFaceVertices(o),o.mark=qr.DELETED;var s;i?s=i.next:s=i=o.getEdge(0);do{var l=s.opposite,r=l.face;r.mark===qr.VISIBLE&&(r.distanceToPlane(n)>this.tolerance?this.computeHorizon(n,l,r,a):a.push(s)),s=s.next}while(s!==i)}},{key:"addAdjoiningFace",value:function(n,i){var o=qr.default.createTriangle(n,i.tail(),i.head());return this.faces.push(o),o.getEdge(-1).setOpposite(i.opposite),o.getEdge(0)}},{key:"addNewFaces",value:function(n,i){this.newFaces=[];for(var o,a,s=0;s=n.nVertices)throw Error("merge recursion limit exceeded");var l=o.opposite.face,r=!1;if(i===eIt?(this.oppositeFaceDistance(o)>-this.tolerance||this.oppositeFaceDistance(o.opposite)>-this.tolerance)&&(r=!0):n.area>l.area?this.oppositeFaceDistance(o)>-this.tolerance?r=!0:this.oppositeFaceDistance(o.opposite)>-this.tolerance&&(a=!1):this.oppositeFaceDistance(o.opposite)>-this.tolerance?r=!0:this.oppositeFaceDistance(o)>-this.tolerance&&(a=!1),r){zu("face merge");for(var d=n.mergeAdjacentFaces(o,[]),m=0;m{"use strict";var k9i=b(W());Object.defineProperty(L3,"__esModule",{value:!0});L3.default=hAe;L3.isPointInsideHull=pAe;var cAe=oIt(iIt()),mAe=oIt(tot());function oIt(t){return t&&t.__esModule?t:{default:t}}function hAe(t){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},n=new cAe.default(t);return n.build(),n.collectFaces(e.skipTriangulation)}function pAe(t,e,n){for(var i=0;i0)return!1}return!0}});var wst=Zo((exports,module)=>{var gOo=b(W());/*! * protobuf.js v7.2.6 (c) 2016, daniel wirtz * compiled tue, 16 jan 2024 22:54:38 utc * licensed under the bsd-3-clause license * see: https://github.com/dcodeio/protobuf.js for details - */(function(undefined){"use strict";(function(e,n,i){function o(s){var l=n[s];return l||e[s][0].call(l=n[s]={exports:{}},o,l,l.exports),l.exports}var a=o(i[0]);a.util.global.protobuf=a,typeof define=="function"&&define.amd&&define(["long"],function(s){return s&&s.isLong&&(a.util.Long=s,a.configure()),a}),typeof module=="object"&&module&&module.exports&&(module.exports=a)})({1:[function(t,e,n){"use strict";e.exports=i;function i(o,a){for(var s=new Array(arguments.length-1),l=0,r=2,d=!0;r1&&d.charAt(m)==="=";)++h;return Math.ceil(d.length*3)/4-h};for(var o=new Array(64),a=new Array(123),s=0;s<64;)a[o[s]=s<26?s+65:s<52?s+71:s<62?s-4:s-59|43]=s++;i.encode=function(d,m,h){for(var Z=null,b=[],u=0,F=0,U;m>2],U=(G&3)<<4,F=1;break;case 1:b[u++]=o[U|G>>4],U=(G&15)<<2,F=2;break;case 2:b[u++]=o[U|G>>6],b[u++]=o[G&63],F=0;break}u>8191&&((Z||(Z=[])).push(String.fromCharCode.apply(String,b)),u=0)}return F&&(b[u++]=o[U],b[u++]=61,F===1&&(b[u++]=61)),Z?(u&&Z.push(String.fromCharCode.apply(String,b.slice(0,u))),Z.join("")):String.fromCharCode.apply(String,b.slice(0,u))};var l="invalid encoding";i.decode=function(d,m,h){for(var Z=h,b=0,u,F=0;F1)break;if((U=a[U])===undefined)throw Error(l);switch(b){case 0:u=U,b=1;break;case 1:m[h++]=u<<2|(U&48)>>4,u=U,b=2;break;case 2:m[h++]=(u&15)<<4|(U&60)>>2,u=U,b=3;break;case 3:m[h++]=(u&3)<<6|U,b=0;break}}if(b===1)throw Error(l);return h-Z},i.test=function(d){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(d)}},{}],3:[function(t,e,n){"use strict";e.exports=i;function i(){this._listeners={}}i.prototype.on=function(a,s,l){return(this._listeners[a]||(this._listeners[a]=[])).push({fn:s,ctx:l||this}),this},i.prototype.off=function(a,s){if(a===undefined)this._listeners={};else if(s===undefined)this._listeners[a]=[];else for(var l=this._listeners[a],r=0;r0?0:2147483648,b,u);else if(isNaN(Z))h(2143289344,b,u);else if(Z>34028234663852886e22)h((F<<31|2139095040)>>>0,b,u);else if(Z<11754943508222875e-54)h((F<<31|Math.round(Z/1401298464324817e-60))>>>0,b,u);else{var U=Math.floor(Math.log(Z)/Math.LN2),G=Math.round(Z*Math.pow(2,-U)*8388608)&8388607;h((F<<31|U+127<<23|G)>>>0,b,u)}}r.writeFloatLE=d.bind(null,o),r.writeFloatBE=d.bind(null,a);function m(h,Z,b){var u=h(Z,b),F=(u>>31)*2+1,U=u>>>23&255,G=u&8388607;return U===255?G?NaN:F*(1/0):U===0?F*1401298464324817e-60*G:F*Math.pow(2,U-150)*(G+8388608)}r.readFloatLE=m.bind(null,s),r.readFloatBE=m.bind(null,l)}(),typeof Float64Array<"u"?function(){var d=new Float64Array([-0]),m=new Uint8Array(d.buffer),h=m[7]===128;function Z(U,G,A){d[0]=U,G[A]=m[0],G[A+1]=m[1],G[A+2]=m[2],G[A+3]=m[3],G[A+4]=m[4],G[A+5]=m[5],G[A+6]=m[6],G[A+7]=m[7]}function b(U,G,A){d[0]=U,G[A]=m[7],G[A+1]=m[6],G[A+2]=m[5],G[A+3]=m[4],G[A+4]=m[3],G[A+5]=m[2],G[A+6]=m[1],G[A+7]=m[0]}r.writeDoubleLE=h?Z:b,r.writeDoubleBE=h?b:Z;function u(U,G){return m[0]=U[G],m[1]=U[G+1],m[2]=U[G+2],m[3]=U[G+3],m[4]=U[G+4],m[5]=U[G+5],m[6]=U[G+6],m[7]=U[G+7],d[0]}function F(U,G){return m[7]=U[G],m[6]=U[G+1],m[5]=U[G+2],m[4]=U[G+3],m[3]=U[G+4],m[2]=U[G+5],m[1]=U[G+6],m[0]=U[G+7],d[0]}r.readDoubleLE=h?u:F,r.readDoubleBE=h?F:u}():function(){function d(h,Z,b,u,F,U){var G=u<0?1:0;if(G&&(u=-u),u===0)h(0,F,U+Z),h(1/u>0?0:2147483648,F,U+b);else if(isNaN(u))h(0,F,U+Z),h(2146959360,F,U+b);else if(u>17976931348623157e292)h(0,F,U+Z),h((G<<31|2146435072)>>>0,F,U+b);else{var A;if(u<22250738585072014e-324)A=u/5e-324,h(A>>>0,F,U+Z),h((G<<31|A/4294967296)>>>0,F,U+b);else{var T=Math.floor(Math.log(u)/Math.LN2);T===1024&&(T=1023),A=u*Math.pow(2,-T),h(A*4503599627370496>>>0,F,U+Z),h((G<<31|T+1023<<20|A*1048576&1048575)>>>0,F,U+b)}}}r.writeDoubleLE=d.bind(null,o,0,4),r.writeDoubleBE=d.bind(null,a,4,0);function m(h,Z,b,u,F){var U=h(u,F+Z),G=h(u,F+b),A=(G>>31)*2+1,T=G>>>20&2047,g=4294967296*(G&1048575)+U;return T===2047?g?NaN:A*(1/0):T===0?A*5e-324*g:A*Math.pow(2,T-1075)*(g+4503599627370496)}r.readDoubleLE=m.bind(null,s,0,4),r.readDoubleBE=m.bind(null,l,4,0)}(),r}function o(r,d,m){d[m]=r&255,d[m+1]=r>>>8&255,d[m+2]=r>>>16&255,d[m+3]=r>>>24}function a(r,d,m){d[m]=r>>>24,d[m+1]=r>>>16&255,d[m+2]=r>>>8&255,d[m+3]=r&255}function s(r,d){return(r[d]|r[d+1]<<8|r[d+2]<<16|r[d+3]<<24)>>>0}function l(r,d){return(r[d]<<24|r[d+1]<<16|r[d+2]<<8|r[d+3])>>>0}},{}],5:[function(require,module,exports){"use strict";module.exports=inquire;function inquire(moduleName){try{var mod=eval("quire".replace(/^/,"re"))(moduleName);if(mod&&(mod.length||Object.keys(mod).length))return mod}catch(t){}return null}},{}],6:[function(t,e,n){"use strict";e.exports=i;function i(o,a,s){var l=s||8192,r=l>>>1,d=null,m=l;return function(Z){if(Z<1||Z>r)return o(Z);m+Z>l&&(d=o(l),m=0);var b=a.call(d,m,m+=Z);return m&7&&(m=(m|7)+1),b}}},{}],7:[function(t,e,n){"use strict";var i=n;i.length=function(a){for(var s=0,l=0,r=0;r191&&Z<224?m[h++]=(Z&31)<<6|a[s++]&63:Z>239&&Z<365?(Z=((Z&7)<<18|(a[s++]&63)<<12|(a[s++]&63)<<6|a[s++]&63)-65536,m[h++]=55296+(Z>>10),m[h++]=56320+(Z&1023)):m[h++]=(Z&15)<<12|(a[s++]&63)<<6|a[s++]&63,h>8191&&((d||(d=[])).push(String.fromCharCode.apply(String,m)),h=0);return d?(h&&d.push(String.fromCharCode.apply(String,m.slice(0,h))),d.join("")):String.fromCharCode.apply(String,m.slice(0,h))},i.write=function(a,s,l){for(var r=l,d,m,h=0;h>6|192,s[l++]=d&63|128):(d&64512)===55296&&((m=a.charCodeAt(h+1))&64512)===56320?(d=65536+((d&1023)<<10)+(m&1023),++h,s[l++]=d>>18|240,s[l++]=d>>12&63|128,s[l++]=d>>6&63|128,s[l++]=d&63|128):(s[l++]=d>>12|224,s[l++]=d>>6&63|128,s[l++]=d&63|128);return l-r}},{}],8:[function(t,e,n){"use strict";var i=n;i.build="minimal",i.Writer=t(16),i.BufferWriter=t(17),i.Reader=t(9),i.BufferReader=t(10),i.util=t(15),i.rpc=t(12),i.roots=t(11),i.configure=o;function o(){i.util._configure(),i.Writer._configure(i.BufferWriter),i.Reader._configure(i.BufferReader)}o()},{10:10,11:11,12:12,15:15,16:16,17:17,9:9}],9:[function(t,e,n){"use strict";e.exports=r;var i=t(15),o,a=i.LongBits,s=i.utf8;function l(u,F){return RangeError("index out of range: "+u.pos+" + "+(F||1)+" > "+u.len)}function r(u){this.buf=u,this.pos=0,this.len=u.length}var d=typeof Uint8Array<"u"?function(F){if(F instanceof Uint8Array||Array.isArray(F))return new r(F);throw Error("illegal buffer")}:function(F){if(Array.isArray(F))return new r(F);throw Error("illegal buffer")},m=function(){return i.Buffer?function(U){return(r.create=function(A){return i.Buffer.isBuffer(A)?new o(A):d(A)})(U)}:d};r.create=m(),r.prototype._slice=i.Array.prototype.subarray||i.Array.prototype.slice,r.prototype.uint32=function(){var F=4294967295;return function(){if(F=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(F=(F|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(F=(F|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(F=(F|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(F=(F|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return F;if((this.pos+=5)>this.len)throw this.pos=this.len,l(this,10);return F}}(),r.prototype.int32=function(){return this.uint32()|0},r.prototype.sint32=function(){var F=this.uint32();return F>>>1^-(F&1)|0};function h(){var u=new a(0,0),F=0;if(this.len-this.pos>4){for(;F<4;++F)if(u.lo=(u.lo|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return u;if(u.lo=(u.lo|(this.buf[this.pos]&127)<<28)>>>0,u.hi=(u.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return u;F=0}else{for(;F<3;++F){if(this.pos>=this.len)throw l(this);if(u.lo=(u.lo|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return u}return u.lo=(u.lo|(this.buf[this.pos++]&127)<>>0,u}if(this.len-this.pos>4){for(;F<5;++F)if(u.hi=(u.hi|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return u}else for(;F<5;++F){if(this.pos>=this.len)throw l(this);if(u.hi=(u.hi|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return u}throw Error("invalid varint encoding")}r.prototype.bool=function(){return this.uint32()!==0};function Z(u,F){return(u[F-4]|u[F-3]<<8|u[F-2]<<16|u[F-1]<<24)>>>0}r.prototype.fixed32=function(){if(this.pos+4>this.len)throw l(this,4);return Z(this.buf,this.pos+=4)},r.prototype.sfixed32=function(){if(this.pos+4>this.len)throw l(this,4);return Z(this.buf,this.pos+=4)|0};function b(){if(this.pos+8>this.len)throw l(this,8);return new a(Z(this.buf,this.pos+=4),Z(this.buf,this.pos+=4))}r.prototype.float=function(){if(this.pos+4>this.len)throw l(this,4);var F=i.float.readFloatLE(this.buf,this.pos);return this.pos+=4,F},r.prototype.double=function(){if(this.pos+8>this.len)throw l(this,4);var F=i.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,F},r.prototype.bytes=function(){var F=this.uint32(),U=this.pos,G=this.pos+F;if(G>this.len)throw l(this,F);if(this.pos+=F,Array.isArray(this.buf))return this.buf.slice(U,G);if(U===G){var A=i.Buffer;return A?A.alloc(0):new this.buf.constructor(0)}return this._slice.call(this.buf,U,G)},r.prototype.string=function(){var F=this.bytes();return s.read(F,0,F.length)},r.prototype.skip=function(F){if(typeof F=="number"){if(this.pos+F>this.len)throw l(this,F);this.pos+=F}else do if(this.pos>=this.len)throw l(this);while(this.buf[this.pos++]&128);return this},r.prototype.skipType=function(u){switch(u){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(u=this.uint32()&7)!==4;)this.skipType(u);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+u+" at offset "+this.pos)}return this},r._configure=function(u){o=u,r.create=m(),o._configure();var F=i.Long?"toLong":"toNumber";i.merge(r.prototype,{int64:function(){return h.call(this)[F](!1)},uint64:function(){return h.call(this)[F](!0)},sint64:function(){return h.call(this).zzDecode()[F](!1)},fixed64:function(){return b.call(this)[F](!0)},sfixed64:function(){return b.call(this)[F](!1)}})}},{15:15}],10:[function(t,e,n){"use strict";e.exports=a;var i=t(9);(a.prototype=Object.create(i.prototype)).constructor=a;var o=t(15);function a(s){i.call(this,s)}a._configure=function(){o.Buffer&&(a.prototype._slice=o.Buffer.prototype.slice)},a.prototype.string=function(){var l=this.uint32();return this.buf.utf8Slice?this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+l,this.len)):this.buf.toString("utf-8",this.pos,this.pos=Math.min(this.pos+l,this.len))},a._configure()},{15:15,9:9}],11:[function(t,e,n){"use strict";e.exports={}},{}],12:[function(t,e,n){"use strict";var i=n;i.Service=t(13)},{13:13}],13:[function(t,e,n){"use strict";e.exports=o;var i=t(15);(o.prototype=Object.create(i.EventEmitter.prototype)).constructor=o;function o(a,s,l){if(typeof a!="function")throw TypeError("rpcImpl must be a function");i.EventEmitter.call(this),this.rpcImpl=a,this.requestDelimited=!!s,this.responseDelimited=!!l}o.prototype.rpcCall=function a(s,l,r,d,m){if(!d)throw TypeError("request must be specified");var h=this;if(!m)return i.asPromise(a,h,s,l,r,d);if(!h.rpcImpl)return setTimeout(function(){m(Error("already ended"))},0),undefined;try{return h.rpcImpl(s,l[h.requestDelimited?"encodeDelimited":"encode"](d).finish(),function(b,u){if(b)return h.emit("error",b,s),m(b);if(u===null)return h.end(!0),undefined;if(!(u instanceof r))try{u=r[h.responseDelimited?"decodeDelimited":"decode"](u)}catch(F){return h.emit("error",F,s),m(F)}return h.emit("data",u,s),m(null,u)})}catch(Z){return h.emit("error",Z,s),setTimeout(function(){m(Z)},0),undefined}},o.prototype.end=function(s){return this.rpcImpl&&(s||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this}},{15:15}],14:[function(t,e,n){"use strict";e.exports=o;var i=t(15);function o(r,d){this.lo=r>>>0,this.hi=d>>>0}var a=o.zero=new o(0,0);a.toNumber=function(){return 0},a.zzEncode=a.zzDecode=function(){return this},a.length=function(){return 1};var s=o.zeroHash="\0\0\0\0\0\0\0\0";o.fromNumber=function(d){if(d===0)return a;var m=d<0;m&&(d=-d);var h=d>>>0,Z=(d-h)/4294967296>>>0;return m&&(Z=~Z>>>0,h=~h>>>0,++h>4294967295&&(h=0,++Z>4294967295&&(Z=0))),new o(h,Z)},o.from=function(d){if(typeof d=="number")return o.fromNumber(d);if(i.isString(d))if(i.Long)d=i.Long.fromString(d);else return o.fromNumber(parseInt(d,10));return d.low||d.high?new o(d.low>>>0,d.high>>>0):a},o.prototype.toNumber=function(d){if(!d&&this.hi>>>31){var m=~this.lo+1>>>0,h=~this.hi>>>0;return m||(h=h+1>>>0),-(m+h*4294967296)}return this.lo+this.hi*4294967296},o.prototype.toLong=function(d){return i.Long?new i.Long(this.lo|0,this.hi|0,!!d):{low:this.lo|0,high:this.hi|0,unsigned:!!d}};var l=String.prototype.charCodeAt;o.fromHash=function(d){return d===s?a:new o((l.call(d,0)|l.call(d,1)<<8|l.call(d,2)<<16|l.call(d,3)<<24)>>>0,(l.call(d,4)|l.call(d,5)<<8|l.call(d,6)<<16|l.call(d,7)<<24)>>>0)},o.prototype.toHash=function(){return String.fromCharCode(this.lo&255,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,this.hi&255,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},o.prototype.zzEncode=function(){var d=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^d)>>>0,this.lo=(this.lo<<1^d)>>>0,this},o.prototype.zzDecode=function(){var d=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^d)>>>0,this.hi=(this.hi>>>1^d)>>>0,this},o.prototype.length=function(){var d=this.lo,m=(this.lo>>>28|this.hi<<4)>>>0,h=this.hi>>>24;return h===0?m===0?d<16384?d<128?1:2:d<2097152?3:4:m<16384?m<128?5:6:m<2097152?7:8:h<128?9:10}},{15:15}],15:[function(t,e,n){"use strict";var i=n;i.asPromise=t(1),i.base64=t(2),i.EventEmitter=t(3),i.float=t(4),i.inquire=t(5),i.utf8=t(7),i.pool=t(6),i.LongBits=t(14),i.isNode=!!(typeof global<"u"&&global&&global.process&&global.process.versions&&global.process.versions.node),i.global=i.isNode&&global||typeof window<"u"&&window||typeof self<"u"&&self||this,i.emptyArray=Object.freeze?Object.freeze([]):[],i.emptyObject=Object.freeze?Object.freeze({}):{},i.isInteger=Number.isInteger||function(l){return typeof l=="number"&&isFinite(l)&&Math.floor(l)===l},i.isString=function(l){return typeof l=="string"||l instanceof String},i.isObject=function(l){return l&&typeof l=="object"},i.isset=i.isSet=function(l,r){var d=l[r];return d!=null&&l.hasOwnProperty(r)?typeof d!="object"||(Array.isArray(d)?d.length:Object.keys(d).length)>0:!1},i.Buffer=function(){try{var s=i.inquire("buffer").Buffer;return s.prototype.utf8Write?s:null}catch{return null}}(),i._Buffer_from=null,i._Buffer_allocUnsafe=null,i.newBuffer=function(l){return typeof l=="number"?i.Buffer?i._Buffer_allocUnsafe(l):new i.Array(l):i.Buffer?i._Buffer_from(l):typeof Uint8Array>"u"?l:new Uint8Array(l)},i.Array=typeof Uint8Array<"u"?Uint8Array:Array,i.Long=i.global.dcodeIO&&i.global.dcodeIO.Long||i.global.Long||i.inquire("long"),i.key2Re=/^true|false|0|1$/,i.key32Re=/^-?(?:0|[1-9][0-9]*)$/,i.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,i.longToHash=function(l){return l?i.LongBits.from(l).toHash():i.LongBits.zeroHash},i.longFromHash=function(l,r){var d=i.LongBits.fromHash(l);return i.Long?i.Long.fromBits(d.lo,d.hi,r):d.toNumber(!!r)};function o(s,l,r){for(var d=Object.keys(l),m=0;m-1;--h)if(r[m[h]]===1&&this[m[h]]!==undefined&&this[m[h]]!==null)return m[h]}},i.oneOfSetter=function(l){return function(r){for(var d=0;d127;)g[C++]=T&127|128,T>>>=7;g[C]=T}function F(T,g){this.len=T,this.next=undefined,this.val=g}F.prototype=Object.create(r.prototype),F.prototype.fn=u,h.prototype.uint32=function(g){return this.len+=(this.tail=this.tail.next=new F((g=g>>>0)<128?1:g<16384?2:g<2097152?3:g<268435456?4:5,g)).len,this},h.prototype.int32=function(g){return g<0?this._push(U,10,a.fromNumber(g)):this.uint32(g)},h.prototype.sint32=function(g){return this.uint32((g<<1^g>>31)>>>0)};function U(T,g,C){for(;T.hi;)g[C++]=T.lo&127|128,T.lo=(T.lo>>>7|T.hi<<25)>>>0,T.hi>>>=7;for(;T.lo>127;)g[C++]=T.lo&127|128,T.lo=T.lo>>>7;g[C++]=T.lo}h.prototype.uint64=function(g){var C=a.from(g);return this._push(U,C.length(),C)},h.prototype.int64=h.prototype.uint64,h.prototype.sint64=function(g){var C=a.from(g).zzEncode();return this._push(U,C.length(),C)},h.prototype.bool=function(g){return this._push(b,1,g?1:0)};function G(T,g,C){g[C]=T&255,g[C+1]=T>>>8&255,g[C+2]=T>>>16&255,g[C+3]=T>>>24}h.prototype.fixed32=function(g){return this._push(G,4,g>>>0)},h.prototype.sfixed32=h.prototype.fixed32,h.prototype.fixed64=function(g){var C=a.from(g);return this._push(G,4,C.lo)._push(G,4,C.hi)},h.prototype.sfixed64=h.prototype.fixed64,h.prototype.float=function(g){return this._push(i.float.writeFloatLE,4,g)},h.prototype.double=function(g){return this._push(i.float.writeDoubleLE,8,g)};var A=i.Array.prototype.set?function(g,C,y){C.set(g,y)}:function(g,C,y){for(var Y=0;Y>>0;if(!C)return this._push(b,1,0);if(i.isString(g)){var y=h.alloc(C=s.length(g));s.decode(g,y,0),g=y}return this.uint32(C)._push(A,C,g)},h.prototype.string=function(g){var C=l.length(g);return C?this.uint32(C)._push(l.write,C,g):this._push(b,1,0)},h.prototype.fork=function(){return this.states=new m(this),this.head=this.tail=new r(d,0,0),this.len=0,this},h.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new r(d,0,0),this.len=0),this},h.prototype.ldelim=function(){var g=this.head,C=this.tail,y=this.len;return this.reset().uint32(y),y&&(this.tail.next=g.next,this.tail=C,this.len+=y),this},h.prototype.finish=function(){for(var g=this.head.next,C=this.constructor.alloc(this.len),y=0;g;)g.fn(g.val,C,y),y+=g.len,g=g.next;return C},h._configure=function(T){o=T,h.create=Z(),o._configure()}},{15:15}],17:[function(t,e,n){"use strict";e.exports=a;var i=t(16);(a.prototype=Object.create(i.prototype)).constructor=a;var o=t(15);function a(){i.call(this)}a._configure=function(){a.alloc=o._Buffer_allocUnsafe,a.writeBytesBuffer=o.Buffer&&o.Buffer.prototype instanceof Uint8Array&&o.Buffer.prototype.set.name==="set"?function(r,d,m){d.set(r,m)}:function(r,d,m){if(r.copy)r.copy(d,m,0,r.length);else for(var h=0;h>>0;return this.uint32(d),d&&this._push(a.writeBytesBuffer,d,r),this};function s(l,r,d){l.length<40?o.utf8.write(l,r,d):r.utf8Write?r.utf8Write(l,d):r.write(l,d)}a.prototype.string=function(r){var d=o.Buffer.byteLength(r);return this.uint32(d),d&&this._push(s,d,r),this},a._configure()},{15:15,16:16}]},{},[8])})()});var X2t=Vo((Mjo,t4)=>{var _jo=R(W());/* Copyright 2015-2018 Esri. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 @preserve */(function(){var t=function(){var o={};o.defaultNoDataValue=-34027999387901484e22,o.decode=function(m,h){h=h||{};var Z=h.encodedMaskData||h.encodedMaskData===null,b=r(m,h.inputOffset||0,Z),u=h.noDataValue!==null?h.noDataValue:o.defaultNoDataValue,F=a(b,h.pixelType||Float32Array,h.encodedMaskData,u,h.returnMask),U={width:b.width,height:b.height,pixelData:F.resultPixels,minValue:F.minValue,maxValue:b.pixels.maxValue,noDataValue:u};return F.resultMask&&(U.maskData=F.resultMask),h.returnEncodedMask&&b.mask&&(U.encodedMaskData=b.mask.bitset?b.mask.bitset:null),h.returnFileInfo&&(U.fileInfo=s(b),h.computeUsedBitDepths&&(U.fileInfo.bitDepths=l(b))),U};var a=function(m,h,Z,b,u){var F=0,U=m.pixels.numBlocksX,G=m.pixels.numBlocksY,A=Math.floor(m.width/U),T=Math.floor(m.height/G),g=2*m.maxZError,C=Number.MAX_VALUE,y;Z=Z||(m.mask?m.mask.bitset:null);var Y,Q;Y=new h(m.width*m.height),u&&Z&&(Q=new Uint8Array(m.width*m.height));for(var J=new Float32Array(A*T),M,V,E=0;E<=G;E++){var I=E!==G?T:m.height%G;if(I!==0)for(var B=0;B<=U;B++){var X=B!==U?A:m.width%U;if(X!==0){var _=E*m.width*T+B*A,P=m.width-X,w=m.pixels.blocks[F],z,H,nt;w.encoding<2?(w.encoding===0?z=w.rawData:(d(w.stuffedData,w.bitsPerPixel,w.numValidPixels,w.offset,g,J,m.pixels.maxValue),z=J),H=0):w.encoding===2?nt=0:nt=w.offset;var $;if(Z)for(V=0;V>3],$<<=_&7),M=0;M>3]),$&128?(Q&&(Q[_]=1),y=w.encoding<2?z[H++]:nt,C=C>y?y:C,Y[_++]=y):(Q&&(Q[_]=0),Y[_++]=b),$<<=1;_+=P}else if(w.encoding<2)for(V=0;Vy?y:C,Y[_++]=y;_+=P}else for(C=C>nt?nt:C,V=0;V0){var U=new Uint8Array(Math.ceil(b.width*b.height/8));F=new DataView(m,h,b.mask.numBytes);var G=F.getInt16(0,!0),A=2,T=0;do{if(G>0)for(;G--;)U[T++]=F.getUint8(A++);else{var g=F.getUint8(A++);for(G=-G;G--;)U[T++]=g}G=F.getInt16(A,!0),A+=2}while(A0?1:0),Q=y+(b.height%y>0?1:0);b.pixels.blocks=new Array(Y*Q);for(var J=0,M=0;M3)throw"Invalid block encoding ("+B.encoding+")";if(B.encoding===2){h++;continue}if(X!==0&&X!==2){if(X>>=6,B.offsetType=X,X===2)B.offset=F.getInt8(1),E++;else if(X===1)B.offset=F.getInt16(1,!0),E+=2;else if(X===0)B.offset=F.getFloat32(1,!0),E+=4;else throw"Invalid block offset type";if(B.encoding===1)if(X=F.getUint8(E),E++,B.bitsPerPixel=X&63,X>>=6,B.numValidPixelsType=X,X===2)B.numValidPixels=F.getUint8(E),E++;else if(X===1)B.numValidPixels=F.getUint16(E,!0),E+=2;else if(X===0)B.numValidPixels=F.getUint32(E,!0),E+=4;else throw"Invalid valid pixel count type"}if(h+=E,B.encoding!==3){var _,P;if(B.encoding===0){var w=(b.pixels.numBytes-1)/4;if(w!==Math.floor(w))throw"uncompressed block has invalid length";_=new ArrayBuffer(w*4),P=new Uint8Array(_),P.set(new Uint8Array(m,h,w*4));var z=new Float32Array(_);B.rawData=z,h+=w*4}else if(B.encoding===1){var H=Math.ceil(B.numValidPixels*B.bitsPerPixel/8),nt=Math.ceil(H/4);_=new ArrayBuffer(nt*4),P=new Uint8Array(_),P.set(new Uint8Array(m,h,H)),B.stuffedData=new Uint32Array(_),h+=H}}}return b.eofOffset=h,b},d=function(m,h,Z,b,u,F,U){var G=(1<=h)C=y>>>g-h&G,g-=h;else{var J=h-g;C=(y&G)<>>g}F[T]=C=m?(g=C>>>T-m&U,T-=m):(y=m-T,g=(C&U)<>>T),d[A]=Z[g];else for(Y=Math.ceil((F-b)/u),A=0;A=m?(g=C>>>T-m&U,T-=m):(y=m-T,g=(C&U)<>>T),d[A]=g=d?(T=g>>>A-d&u,A-=d):(G=d-A,T=(g&u)<>>A),C[U]=T=m?(C=y>>>g&U,T-=m,g+=m):(Y=m-T,C=y>>>g&U,y=r[G++],T=32-Y,C|=(y&(1<=m?(C=y>>>g&U,T-=m,g+=m):(Y=m-T,C=y>>>g&U,y=r[G++],T=32-Y,C|=(y&(1<=d?(T=C>>>g&u,A-=d,g+=d):(G=d-A,T=C>>>g&u,C=r[F++],A=32-G,T|=(C&(1<=m?(U=G>>>F-m&Z,F-=m):(A=m-F,U=(G&Z)<>>F),d[u]=U;return d},originalUnstuff2:function(r,d,m,h){var Z=(1<=m?(G=A>>>U&Z,F-=m,U+=m):(T=m-F,G=A>>>U&Z,A=r[b++],F=32-T,G|=(A&(1<=359?359:Z;Z-=u;do d+=r[b++]<<8,m+=d+=r[b++];while(--u);d=(d&65535)+(d>>>16),m=(m&65535)+(m>>>16)}return h&1&&(m+=d+=r[b]<<8),d=(d&65535)+(d>>>16),m=(m&65535)+(m>>>16),(m<<16|d)>>>0},readHeaderInfo:function(r,d){var m=d.ptr,h=new Uint8Array(r,m,6),Z={};if(Z.fileIdentifierString=String.fromCharCode.apply(null,h),Z.fileIdentifierString.lastIndexOf("Lerc2",0)!==0)throw"Unexpected file identifier string (expect Lerc2 ): "+Z.fileIdentifierString;m+=6;var b=new DataView(r,m,8),u=b.getInt32(0,!0);Z.fileVersion=u,m+=4,u>=3&&(Z.checksum=b.getUint32(4,!0),m+=4),b=new DataView(r,m,12),Z.height=b.getUint32(0,!0),Z.width=b.getUint32(4,!0),m+=8,u>=4?(Z.numDims=b.getUint32(8,!0),m+=4):Z.numDims=1,b=new DataView(r,m,40),Z.numValidPixel=b.getUint32(0,!0),Z.microBlockSize=b.getInt32(4,!0),Z.blobSize=b.getInt32(8,!0),Z.imageType=b.getInt32(12,!0),Z.maxZError=b.getFloat64(16,!0),Z.zMin=b.getFloat64(24,!0),Z.zMax=b.getFloat64(32,!0),m+=40,d.headerInfo=Z,d.ptr=m;var F,U;if(u>=3&&(U=u>=4?52:48,F=this.computeChecksumFletcher32(new Uint8Array(r,m-U,Z.blobSize-14)),F!==Z.checksum))throw"Checksum failed.";return!0},checkMinMaxRanges:function(r,d){var m=d.headerInfo,h=this.getDataTypeArray(m.imageType),Z=m.numDims*this.getDataTypeSize(m.imageType),b=this.readSubArray(r,d.ptr,h,Z),u=this.readSubArray(r,d.ptr+Z,h,Z);d.ptr+=2*Z;var F,U=!0;for(F=0;F0){U=new Uint8Array(Math.ceil(Z/8)),u=new DataView(r,m,F.numBytes);var A=u.getInt16(0,!0),T=2,g=0,C=0;do{if(A>0)for(;A--;)U[g++]=u.getUint8(T++);else for(C=u.getUint8(T++),A=-A;A--;)U[g++]=C;A=u.getInt16(T,!0),T+=2}while(T>3],y<<=Y&7):y=U[Y>>3],y&128&&(G[Y]=1);d.pixels.resultMask=G,F.bitset=U,m+=F.numBytes}return d.ptr=m,d.mask=F,!0},readDataOneSweep:function(r,d,m){var h=d.ptr,Z=d.headerInfo,b=Z.numDims,u=Z.width*Z.height,F=Z.imageType,U=Z.numValidPixel*a.getDataTypeSize(F)*b,G,A=d.pixels.resultMask;if(m===Uint8Array)G=new Uint8Array(r,h,U);else{var T=new ArrayBuffer(U),g=new Uint8Array(T);g.set(new Uint8Array(r,h,U)),G=new m(T)}if(G.length===u*b)d.pixels.resultPixels=G;else{d.pixels.resultPixels=new m(u*b);var C=0,y=0,Y=0,Q=0;if(b>1)for(Y=0;Y=F)return!1;var U=new Uint32Array(F-u);a.decodeBits(r,d,U);var G=[],A,T,g,C;for(A=u;A0&&(G[T].second=E<>>32-C,32-V>=C?(V+=C,V===32&&(V=0,I++,E=M[I])):(V+=C-32,I++,E=M[I],G[T].second|=E>>>32-V));var B=0,X=0,_=new s;for(A=0;A=m?X=m:X=B,B>=30&&console.log("WARning, large NUM LUT BITS IS "+B);var P=[],w,z,H,nt,$,dt;for(A=u;A0)if(w=[C,T],C<=X)for(z=G[T].second<=0;nt--)$=z>>>nt&1,$?(dt.right||(dt.right=new s),dt=dt.right):(dt.left||(dt.left=new s),dt=dt.left),nt===0&&!dt.val&&(dt.val=w[1]);return{decodeLut:P,numBitsLUTQick:X,numBitsLUT:B,tree:_,stuffedData:M,srcPtr:I,bitPos:V}},readHuffman:function(r,d,m){var h=d.headerInfo,Z=h.numDims,b=d.headerInfo.height,u=d.headerInfo.width,F=u*b,U=this.readHuffmanTree(r,d),G=U.decodeLut,A=U.tree,T=U.stuffedData,g=U.srcPtr,C=U.bitPos,y=U.numBitsLUTQick,Y=U.numBitsLUT,Q=d.headerInfo.imageType===0?128:0,J,M,V,E=d.pixels.resultMask,I,B,X,_,P,w,z,H=0;C>0&&(g++,C=0);var nt=T[g],$=d.encodeMode===1,dt=new m(F*Z),q=dt,at;for(at=0;at1&&(q=new m(dt.buffer,F*at,F),H=0),d.headerInfo.numValidPixel===u*b)for(w=0,_=0;_>>32-y,B=I,32-C>>64-C-y,B=I),G[B])M=G[B][1],C+=G[B][0];else for(I=nt<>>32-Y,B=I,32-C>>64-C-Y,B=I),J=A,z=0;z>>Y-z-1&1,J=X?J.right:J.left,!(J.left||J.right)){M=J.val,C=C+z+1;break}C>=32&&(C-=32,g++,nt=T[g]),V=M-Q,$?(P>0?V+=H:_>0?V+=q[w-u]:V+=H,V&=255,q[w]=V,H=V):q[w]=V}else for(w=0,_=0;_>>32-y,B=I,32-C>>64-C-y,B=I),G[B])M=G[B][1],C+=G[B][0];else for(I=nt<>>32-Y,B=I,32-C>>64-C-Y,B=I),J=A,z=0;z>>Y-z-1&1,J=X?J.right:J.left,!(J.left||J.right)){M=J.val,C=C+z+1;break}C>=32&&(C-=32,g++,nt=T[g]),V=M-Q,$?(P>0&&E[w-1]?V+=H:_>0&&E[w-u]?V+=q[w-u]:V+=H,V&=255,q[w]=V,H=V):q[w]=V}d.ptr=d.ptr+(g+1)*4+(C>0?4:0)}d.pixels.resultPixels=dt},decodeBits:function(r,d,m,h,Z){{var b=d.headerInfo,u=b.fileVersion,F=0,U=new DataView(r,d.ptr,5),G=U.getUint8(0);F++;var A=G>>6,T=A===0?4:3-A,g=(G&32)>0,C=G&31,y=0;if(T===1)y=U.getUint8(F),F++;else if(T===2)y=U.getUint16(F,!0),F+=2;else if(T===4)y=U.getUint32(F,!0),F+=4;else throw"Invalid valid pixel count type";var Y=2*b.maxZError,Q,J,M,V,E,I,B,X,_,P,w=b.numDims>1?b.maxValues[Z]:b.zMax;if(g){for(d.counter.lut++,X=U.getUint8(F),_=C,F++,V=Math.ceil((X-1)*C/8),E=Math.ceil(V/4),J=new ArrayBuffer(E*4),M=new Uint8Array(J),d.ptr+=F,M.set(new Uint8Array(r,d.ptr,V)),B=new Uint32Array(J),d.ptr+=V,P=0;X-1>>>P;)P++;V=Math.ceil(y*P/8),E=Math.ceil(V/4),J=new ArrayBuffer(E*4),M=new Uint8Array(J),M.set(new Uint8Array(r,d.ptr,V)),Q=new Uint32Array(J),d.ptr+=V,u>=3?I=o.unstuffLUT2(B,C,X-1,h,Y,w):I=o.unstuffLUT(B,C,X-1,h,Y,w),u>=3?o.unstuff2(Q,m,P,y,I):o.unstuff(Q,m,P,y,I)}else d.counter.bitstuffer++,P=C,d.ptr+=F,P>0&&(V=Math.ceil(y*P/8),E=Math.ceil(V/4),J=new ArrayBuffer(E*4),M=new Uint8Array(J),M.set(new Uint8Array(r,d.ptr,V)),Q=new Uint32Array(J),d.ptr+=V,u>=3?h==null?o.originalUnstuff2(Q,m,P,y):o.unstuff2(Q,m,P,y,!1,h,Y,w):h==null?o.originalUnstuff(Q,m,P,y):o.unstuff(Q,m,P,y,!1,h,Y,w))}},readTiles:function(r,d,m){var h=d.headerInfo,Z=h.width,b=h.height,u=h.microBlockSize,F=h.imageType,U=a.getDataTypeSize(F),G=Math.ceil(Z/u),A=Math.ceil(b/u);d.pixels.numBlocksY=A,d.pixels.numBlocksX=G,d.pixels.ptr=0;var T=0,g=0,C=0,y=0,Y=0,Q=0,J=0,M=0,V=0,E=0,I=0,B=0,X=0,_=0,P=0,w=0,z,H,nt,$,dt,q,at=new m(u*u),st=b%u||u,Et=Z%u||u,Qt,Wt,Nt=h.numDims,kt,Mt=d.pixels.resultMask,qt=d.pixels.resultPixels;for(C=0;C1&&(qt=new m(d.pixels.resultPixels.buffer,Z*b*kt*U,Z*b)),J=r.byteLength-d.ptr,z=new DataView(r,d.ptr,Math.min(10,J)),H={},w=0,M=z.getUint8(0),w++,V=M>>6&255,E=M>>2&15,E!==(y*u>>3&15))throw"integrity issue";if(q=M&3,q>3)throw d.ptr+=w,"Invalid block encoding ("+q+")";if(q===2){d.counter.constant++,d.ptr+=w;continue}else if(q===0){if(d.counter.uncompressed++,d.ptr+=w,X=Y*Q*U,_=r.byteLength-d.ptr,X=X<_?X:_,nt=new ArrayBuffer(X%U===0?X:X+U-X%U),$=new Uint8Array(nt),$.set(new Uint8Array(r,d.ptr,X)),dt=new m(nt),P=0,Mt)for(T=0;T1)for(b=0;b=-128&&d<=127;break;case 1:m=d>=0&&d<=255;break;case 2:m=d>=-32768&&d<=32767;break;case 3:m=d>=0&&d<=65536;break;case 4:m=d>=-2147483648&&d<=2147483647;break;case 5:m=d>=0&&d<=4294967296;break;case 6:m=d>=-34027999387901484e22&&d<=34027999387901484e22;break;case 7:m=d>=5e-324&&d<=17976931348623157e292;break;default:m=!1}return m},getDataTypeSize:function(r){var d=0;switch(r){case 0:case 1:d=1;break;case 2:case 3:d=2;break;case 4:case 5:case 6:d=4;break;case 7:d=8;break;default:d=r}return d},getDataTypeUsed:function(r,d){var m=r;switch(r){case 2:case 4:m=r-d;break;case 3:case 5:m=r-2*d;break;case 6:d===0?m=r:d===1?m=2:m=1;break;case 7:d===0?m=r:m=r-2*d+1;break;default:m=r;break}return m},getOnePixel:function(r,d,m,h){var Z=0;switch(m){case 0:Z=h.getInt8(d);break;case 1:Z=h.getUint8(d);break;case 2:Z=h.getInt16(d,!0);break;case 3:Z=h.getUint16(d,!0);break;case 4:Z=h.getInt32(d,!0);break;case 5:Z=h.getUInt32(d,!0);break;case 6:Z=h.getFloat32(d,!0);break;case 7:Z=h.getFloat64(d,!0);break;default:throw"the decoder does not understand this pixel type"}return Z}},s=function(r,d,m){this.val=r,this.left=d,this.right=m},l={decode:function(r,d){d=d||{};var m=d.noDataValue,h=0,Z={};if(Z.ptr=d.inputOffset||0,Z.pixels={},!!a.readHeaderInfo(r,Z)){var b=Z.headerInfo,u=b.fileVersion,F=a.getDataTypeArray(b.imageType);a.readMask(r,Z),b.numValidPixel!==b.width*b.height&&!Z.pixels.resultMask&&(Z.pixels.resultMask=d.maskData);var U=b.width*b.height;if(Z.pixels.resultPixels=new F(U*b.numDims),Z.counter={onesweep:0,uncompressed:0,lut:0,bitstuffer:0,constant:0,constantoffset:0},b.numValidPixel!==0)if(b.zMax===b.zMin)a.constructConstantSurface(Z);else if(u>=4&&a.checkMinMaxRanges(r,Z))a.constructConstantSurface(Z);else{var G=new DataView(r,Z.ptr,2),A=G.getUint8(0);if(Z.ptr++,A)a.readDataOneSweep(r,Z,F);else if(u>1&&b.imageType<=1&&Math.abs(b.maxZError-.5)<1e-5){var T=G.getUint8(1);if(Z.ptr++,Z.encodeMode=T,T>2||u<4&&T>1)throw"Invalid Huffman flag "+T;T?a.readHuffman(r,Z,F):a.readTiles(r,Z,F)}else a.readTiles(r,Z,F)}Z.eofOffset=Z.ptr;var g;d.inputOffset?(g=Z.headerInfo.blobSize+d.inputOffset-Z.ptr,Math.abs(g)>=1&&(Z.eofOffset=d.inputOffset+Z.headerInfo.blobSize)):(g=Z.headerInfo.blobSize-Z.ptr,Math.abs(g)>=1&&(Z.eofOffset=Z.headerInfo.blobSize));var C={width:b.width,height:b.height,pixelData:Z.pixels.resultPixels,minValue:b.zMin,maxValue:b.zMax,validPixelCount:b.numValidPixel,dimCount:b.numDims,dimStats:{minValues:b.minValues,maxValues:b.maxValues},maskData:Z.pixels.resultMask};if(Z.pixels.resultMask&&a.isValidPixelValue(b.imageType,m)){var y=Z.pixels.resultMask;for(h=0;h1&&A.fileInfo.mask&&A.fileInfo.mask.numBytes>0&&u.push(A.maskData),h++,G.pixels.push(A.pixelData),G.statistics.push({minValue:A.minValue,maxValue:A.maxValue,noDataValue:A.noDataValue,dimStats:A.dimStats})}var T,g,C;if(m>1&&u.length>1){for(C=G.width*G.height,G.bandMasks=u,U=new Uint8Array(C),U.set(u[0]),T=1;T{var $Ga=R(W());kkt.exports={webm:"data:video/webm;base64,GkXfowEAAAAAAAAfQoaBAUL3gQFC8oEEQvOBCEKChHdlYm1Ch4EEQoWBAhhTgGcBAAAAAAAVkhFNm3RALE27i1OrhBVJqWZTrIHfTbuMU6uEFlSua1OsggEwTbuMU6uEHFO7a1OsghV17AEAAAAAAACkAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAVSalmAQAAAAAAAEUq17GDD0JATYCNTGF2ZjU1LjMzLjEwMFdBjUxhdmY1NS4zMy4xMDBzpJBlrrXf3DCDVB8KcgbMpcr+RImIQJBgAAAAAAAWVK5rAQAAAAAAD++uAQAAAAAAADLXgQFzxYEBnIEAIrWcg3VuZIaFVl9WUDiDgQEj44OEAmJaAOABAAAAAAAABrCBsLqBkK4BAAAAAAAPq9eBAnPFgQKcgQAitZyDdW5khohBX1ZPUkJJU4OBAuEBAAAAAAAAEZ+BArWIQOdwAAAAAABiZIEgY6JPbwIeVgF2b3JiaXMAAAAAAoC7AAAAAAAAgLUBAAAAAAC4AQN2b3JiaXMtAAAAWGlwaC5PcmcgbGliVm9yYmlzIEkgMjAxMDExMDEgKFNjaGF1ZmVudWdnZXQpAQAAABUAAABlbmNvZGVyPUxhdmM1NS41Mi4xMDIBBXZvcmJpcyVCQ1YBAEAAACRzGCpGpXMWhBAaQlAZ4xxCzmvsGUJMEYIcMkxbyyVzkCGkoEKIWyiB0JBVAABAAACHQXgUhIpBCCGEJT1YkoMnPQghhIg5eBSEaUEIIYQQQgghhBBCCCGERTlokoMnQQgdhOMwOAyD5Tj4HIRFOVgQgydB6CCED0K4moOsOQghhCQ1SFCDBjnoHITCLCiKgsQwuBaEBDUojILkMMjUgwtCiJqDSTX4GoRnQXgWhGlBCCGEJEFIkIMGQcgYhEZBWJKDBjm4FITLQagahCo5CB+EIDRkFQCQAACgoiiKoigKEBqyCgDIAAAQQFEUx3EcyZEcybEcCwgNWQUAAAEACAAAoEiKpEiO5EiSJFmSJVmSJVmS5omqLMuyLMuyLMsyEBqyCgBIAABQUQxFcRQHCA1ZBQBkAAAIoDiKpViKpWiK54iOCISGrAIAgAAABAAAEDRDUzxHlETPVFXXtm3btm3btm3btm3btm1blmUZCA1ZBQBAAAAQ0mlmqQaIMAMZBkJDVgEACAAAgBGKMMSA0JBVAABAAACAGEoOogmtOd+c46BZDppKsTkdnEi1eZKbirk555xzzsnmnDHOOeecopxZDJoJrTnnnMSgWQqaCa0555wnsXnQmiqtOeeccc7pYJwRxjnnnCateZCajbU555wFrWmOmkuxOeecSLl5UptLtTnnnHPOOeecc84555zqxekcnBPOOeecqL25lpvQxTnnnE/G6d6cEM4555xzzjnnnHPOOeecIDRkFQAABABAEIaNYdwpCNLnaCBGEWIaMulB9+gwCRqDnELq0ehopJQ6CCWVcVJKJwgNWQUAAAIAQAghhRRSSCGFFFJIIYUUYoghhhhyyimnoIJKKqmooowyyyyzzDLLLLPMOuyssw47DDHEEEMrrcRSU2011lhr7jnnmoO0VlprrbVSSimllFIKQkNWAQAgAAAEQgYZZJBRSCGFFGKIKaeccgoqqIDQkFUAACAAgAAAAABP8hzRER3RER3RER3RER3R8RzPESVREiVREi3TMjXTU0VVdWXXlnVZt31b2IVd933d933d+HVhWJZlWZZlWZZlWZZlWZZlWZYgNGQVAAACAAAghBBCSCGFFFJIKcYYc8w56CSUEAgNWQUAAAIACAAAAHAUR3EcyZEcSbIkS9IkzdIsT/M0TxM9URRF0zRV0RVdUTdtUTZl0zVdUzZdVVZtV5ZtW7Z125dl2/d93/d93/d93/d93/d9XQdCQ1YBABIAADqSIymSIimS4ziOJElAaMgqAEAGAEAAAIriKI7jOJIkSZIlaZJneZaomZrpmZ4qqkBoyCoAABAAQAAAAAAAAIqmeIqpeIqoeI7oiJJomZaoqZoryqbsuq7ruq7ruq7ruq7ruq7ruq7ruq7ruq7ruq7ruq7ruq7ruq4LhIasAgAkAAB0JEdyJEdSJEVSJEdygNCQVQCADACAAAAcwzEkRXIsy9I0T/M0TxM90RM901NFV3SB0JBVAAAgAIAAAAAAAAAMybAUy9EcTRIl1VItVVMt1VJF1VNVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVN0zRNEwgNWQkAkAEAkBBTLS3GmgmLJGLSaqugYwxS7KWxSCpntbfKMYUYtV4ah5RREHupJGOKQcwtpNApJq3WVEKFFKSYYyoVUg5SIDRkhQAQmgHgcBxAsixAsiwAAAAAAAAAkDQN0DwPsDQPAAAAAAAAACRNAyxPAzTPAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABA0jRA8zxA8zwAAAAAAAAA0DwP8DwR8EQRAAAAAAAAACzPAzTRAzxRBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABA0jRA8zxA8zwAAAAAAAAAsDwP8EQR0DwRAAAAAAAAACzPAzxRBDzRAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAEOAAABBgIRQasiIAiBMAcEgSJAmSBM0DSJYFTYOmwTQBkmVB06BpME0AAAAAAAAAAAAAJE2DpkHTIIoASdOgadA0iCIAAAAAAAAAAAAAkqZB06BpEEWApGnQNGgaRBEAAAAAAAAAAAAAzzQhihBFmCbAM02IIkQRpgkAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAAAGHAAAAgwoQwUGrIiAIgTAHA4imUBAIDjOJYFAACO41gWAABYliWKAABgWZooAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAYcAAACDChDBQashIAiAIAcCiKZQHHsSzgOJYFJMmyAJYF0DyApgFEEQAIAAAocAAACLBBU2JxgEJDVgIAUQAABsWxLE0TRZKkaZoniiRJ0zxPFGma53meacLzPM80IYqiaJoQRVE0TZimaaoqME1VFQAAUOAAABBgg6bE4gCFhqwEAEICAByKYlma5nmeJ4qmqZokSdM8TxRF0TRNU1VJkqZ5niiKommapqqyLE3zPFEURdNUVVWFpnmeKIqiaaqq6sLzPE8URdE0VdV14XmeJ4qiaJqq6roQRVE0TdNUTVV1XSCKpmmaqqqqrgtETxRNU1Vd13WB54miaaqqq7ouEE3TVFVVdV1ZBpimaaqq68oyQFVV1XVdV5YBqqqqruu6sgxQVdd1XVmWZQCu67qyLMsCAAAOHAAAAoygk4wqi7DRhAsPQKEhKwKAKAAAwBimFFPKMCYhpBAaxiSEFEImJaXSUqogpFJSKRWEVEoqJaOUUmopVRBSKamUCkIqJZVSAADYgQMA2IGFUGjISgAgDwCAMEYpxhhzTiKkFGPOOScRUoox55yTSjHmnHPOSSkZc8w556SUzjnnnHNSSuacc845KaVzzjnnnJRSSuecc05KKSWEzkEnpZTSOeecEwAAVOAAABBgo8jmBCNBhYasBABSAQAMjmNZmuZ5omialiRpmud5niiapiZJmuZ5nieKqsnzPE8URdE0VZXneZ4oiqJpqirXFUXTNE1VVV2yLIqmaZqq6rowTdNUVdd1XZimaaqq67oubFtVVdV1ZRm2raqq6rqyDFzXdWXZloEsu67s2rIAAPAEBwCgAhtWRzgpGgssNGQlAJABAEAYg5BCCCFlEEIKIYSUUggJAAAYcAAACDChDBQashIASAUAAIyx1lprrbXWQGettdZaa62AzFprrbXWWmuttdZaa6211lJrrbXWWmuttdZaa6211lprrbXWWmuttdZaa6211lprrbXWWmuttdZaa6211lprrbXWWmstpZRSSimllFJKKaWUUkoppZRSSgUA+lU4APg/2LA6wknRWGChISsBgHAAAMAYpRhzDEIppVQIMeacdFRai7FCiDHnJKTUWmzFc85BKCGV1mIsnnMOQikpxVZjUSmEUlJKLbZYi0qho5JSSq3VWIwxqaTWWoutxmKMSSm01FqLMRYjbE2ptdhqq7EYY2sqLbQYY4zFCF9kbC2m2moNxggjWywt1VprMMYY3VuLpbaaizE++NpSLDHWXAAAd4MDAESCjTOsJJ0VjgYXGrISAAgJACAQUooxxhhzzjnnpFKMOeaccw5CCKFUijHGnHMOQgghlIwx5pxzEEIIIYRSSsaccxBCCCGEkFLqnHMQQgghhBBKKZ1zDkIIIYQQQimlgxBCCCGEEEoopaQUQgghhBBCCKmklEIIIYRSQighlZRSCCGEEEIpJaSUUgohhFJCCKGElFJKKYUQQgillJJSSimlEkoJJYQSUikppRRKCCGUUkpKKaVUSgmhhBJKKSWllFJKIYQQSikFAAAcOAAABBhBJxlVFmGjCRcegEJDVgIAZAAAkKKUUiktRYIipRikGEtGFXNQWoqocgxSzalSziDmJJaIMYSUk1Qy5hRCDELqHHVMKQYtlRhCxhik2HJLoXMOAAAAQQCAgJAAAAMEBTMAwOAA4XMQdAIERxsAgCBEZohEw0JweFAJEBFTAUBigkIuAFRYXKRdXECXAS7o4q4DIQQhCEEsDqCABByccMMTb3jCDU7QKSp1IAAAAAAADADwAACQXAAREdHMYWRobHB0eHyAhIiMkAgAAAAAABcAfAAAJCVAREQ0cxgZGhscHR4fICEiIyQBAIAAAgAAAAAggAAEBAQAAAAAAAIAAAAEBB9DtnUBAAAAAAAEPueBAKOFggAAgACjzoEAA4BwBwCdASqwAJAAAEcIhYWIhYSIAgIABhwJ7kPfbJyHvtk5D32ych77ZOQ99snIe+2TkPfbJyHvtk5D32ych77ZOQ99YAD+/6tQgKOFggADgAqjhYIAD4AOo4WCACSADqOZgQArADECAAEQEAAYABhYL/QACIBDmAYAAKOFggA6gA6jhYIAT4AOo5mBAFMAMQIAARAQABgAGFgv9AAIgEOYBgAAo4WCAGSADqOFggB6gA6jmYEAewAxAgABEBAAGAAYWC/0AAiAQ5gGAACjhYIAj4AOo5mBAKMAMQIAARAQABgAGFgv9AAIgEOYBgAAo4WCAKSADqOFggC6gA6jmYEAywAxAgABEBAAGAAYWC/0AAiAQ5gGAACjhYIAz4AOo4WCAOSADqOZgQDzADECAAEQEAAYABhYL/QACIBDmAYAAKOFggD6gA6jhYIBD4AOo5iBARsAEQIAARAQFGAAYWC/0AAiAQ5gGACjhYIBJIAOo4WCATqADqOZgQFDADECAAEQEAAYABhYL/QACIBDmAYAAKOFggFPgA6jhYIBZIAOo5mBAWsAMQIAARAQABgAGFgv9AAIgEOYBgAAo4WCAXqADqOFggGPgA6jmYEBkwAxAgABEBAAGAAYWC/0AAiAQ5gGAACjhYIBpIAOo4WCAbqADqOZgQG7ADECAAEQEAAYABhYL/QACIBDmAYAAKOFggHPgA6jmYEB4wAxAgABEBAAGAAYWC/0AAiAQ5gGAACjhYIB5IAOo4WCAfqADqOZgQILADECAAEQEAAYABhYL/QACIBDmAYAAKOFggIPgA6jhYICJIAOo5mBAjMAMQIAARAQABgAGFgv9AAIgEOYBgAAo4WCAjqADqOFggJPgA6jmYECWwAxAgABEBAAGAAYWC/0AAiAQ5gGAACjhYICZIAOo4WCAnqADqOZgQKDADECAAEQEAAYABhYL/QACIBDmAYAAKOFggKPgA6jhYICpIAOo5mBAqsAMQIAARAQABgAGFgv9AAIgEOYBgAAo4WCArqADqOFggLPgA6jmIEC0wARAgABEBAUYABhYL/QACIBDmAYAKOFggLkgA6jhYIC+oAOo5mBAvsAMQIAARAQABgAGFgv9AAIgEOYBgAAo4WCAw+ADqOZgQMjADECAAEQEAAYABhYL/QACIBDmAYAAKOFggMkgA6jhYIDOoAOo5mBA0sAMQIAARAQABgAGFgv9AAIgEOYBgAAo4WCA0+ADqOFggNkgA6jmYEDcwAxAgABEBAAGAAYWC/0AAiAQ5gGAACjhYIDeoAOo4WCA4+ADqOZgQObADECAAEQEAAYABhYL/QACIBDmAYAAKOFggOkgA6jhYIDuoAOo5mBA8MAMQIAARAQABgAGFgv9AAIgEOYBgAAo4WCA8+ADqOFggPkgA6jhYID+oAOo4WCBA+ADhxTu2sBAAAAAAAAEbuPs4EDt4r3gQHxghEr8IEK",mp4:"data:video/mp4;base64,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"}});var Xkt=Vo((tAa,xkt)=>{var eAa=R(W()),{webm:lDe,mp4:rDe}=Ykt(),Drt=()=>typeof navigator<"u"&&parseFloat((""+(/CPU.*OS ([0-9_]{3,4})[0-9_]{0,1}|(CPU like).*AppleWebKit.*Mobile/i.exec(navigator.userAgent)||[0,""])[1]).replace("undefined","3_2").replace("_",".").replace("_",""))<10&&!window.MSStream,Ort=()=>"wakeLock"in navigator,Hrt=class{constructor(){if(this.enabled=!1,Ort()){this._wakeLock=null;let e=()=>{this._wakeLock!==null&&document.visibilityState==="visible"&&this.enable()};document.addEventListener("visibilitychange",e),document.addEventListener("fullscreenchange",e)}else Drt()?this.noSleepTimer=null:(this.noSleepVideo=document.createElement("video"),this.noSleepVideo.setAttribute("title","No Sleep"),this.noSleepVideo.setAttribute("playsinline",""),this._addSourceToVideo(this.noSleepVideo,"webm",lDe),this._addSourceToVideo(this.noSleepVideo,"mp4",rDe),this.noSleepVideo.addEventListener("loadedmetadata",()=>{this.noSleepVideo.duration<=1?this.noSleepVideo.setAttribute("loop",""):this.noSleepVideo.addEventListener("timeupdate",()=>{this.noSleepVideo.currentTime>.5&&(this.noSleepVideo.currentTime=Math.random())})}))}_addSourceToVideo(e,n,i){var o=document.createElement("source");o.src=i,o.type=`video/${n}`,e.appendChild(o)}get isEnabled(){return this.enabled}enable(){return Ort()?navigator.wakeLock.request("screen").then(e=>{this._wakeLock=e,this.enabled=!0,console.log("Wake Lock active."),this._wakeLock.addEventListener("release",()=>{console.log("Wake Lock released.")})}).catch(e=>{throw this.enabled=!1,console.error(`${e.name}, ${e.message}`),e}):Drt()?(this.disable(),console.warn(` + */(function(undefined){"use strict";(function(e,n,i){function o(s){var l=n[s];return l||e[s][0].call(l=n[s]={exports:{}},o,l,l.exports),l.exports}var a=o(i[0]);a.util.global.protobuf=a,typeof define=="function"&&define.amd&&define(["long"],function(s){return s&&s.isLong&&(a.util.Long=s,a.configure()),a}),typeof module=="object"&&module&&module.exports&&(module.exports=a)})({1:[function(t,e,n){"use strict";e.exports=i;function i(o,a){for(var s=new Array(arguments.length-1),l=0,r=2,d=!0;r1&&d.charAt(m)==="=";)++h;return Math.ceil(d.length*3)/4-h};for(var o=new Array(64),a=new Array(123),s=0;s<64;)a[o[s]=s<26?s+65:s<52?s+71:s<62?s-4:s-59|43]=s++;i.encode=function(d,m,h){for(var u=null,R=[],V=0,F=0,U;m>2],U=(G&3)<<4,F=1;break;case 1:R[V++]=o[U|G>>4],U=(G&15)<<2,F=2;break;case 2:R[V++]=o[U|G>>6],R[V++]=o[G&63],F=0;break}V>8191&&((u||(u=[])).push(String.fromCharCode.apply(String,R)),V=0)}return F&&(R[V++]=o[U],R[V++]=61,F===1&&(R[V++]=61)),u?(V&&u.push(String.fromCharCode.apply(String,R.slice(0,V))),u.join("")):String.fromCharCode.apply(String,R.slice(0,V))};var l="invalid encoding";i.decode=function(d,m,h){for(var u=h,R=0,V,F=0;F1)break;if((U=a[U])===undefined)throw Error(l);switch(R){case 0:V=U,R=1;break;case 1:m[h++]=V<<2|(U&48)>>4,V=U,R=2;break;case 2:m[h++]=(V&15)<<4|(U&60)>>2,V=U,R=3;break;case 3:m[h++]=(V&3)<<6|U,R=0;break}}if(R===1)throw Error(l);return h-u},i.test=function(d){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(d)}},{}],3:[function(t,e,n){"use strict";e.exports=i;function i(){this._listeners={}}i.prototype.on=function(a,s,l){return(this._listeners[a]||(this._listeners[a]=[])).push({fn:s,ctx:l||this}),this},i.prototype.off=function(a,s){if(a===undefined)this._listeners={};else if(s===undefined)this._listeners[a]=[];else for(var l=this._listeners[a],r=0;r0?0:2147483648,R,V);else if(isNaN(u))h(2143289344,R,V);else if(u>34028234663852886e22)h((F<<31|2139095040)>>>0,R,V);else if(u<11754943508222875e-54)h((F<<31|Math.round(u/1401298464324817e-60))>>>0,R,V);else{var U=Math.floor(Math.log(u)/Math.LN2),G=Math.round(u*Math.pow(2,-U)*8388608)&8388607;h((F<<31|U+127<<23|G)>>>0,R,V)}}r.writeFloatLE=d.bind(null,o),r.writeFloatBE=d.bind(null,a);function m(h,u,R){var V=h(u,R),F=(V>>31)*2+1,U=V>>>23&255,G=V&8388607;return U===255?G?NaN:F*(1/0):U===0?F*1401298464324817e-60*G:F*Math.pow(2,U-150)*(G+8388608)}r.readFloatLE=m.bind(null,s),r.readFloatBE=m.bind(null,l)}(),typeof Float64Array<"u"?function(){var d=new Float64Array([-0]),m=new Uint8Array(d.buffer),h=m[7]===128;function u(U,G,A){d[0]=U,G[A]=m[0],G[A+1]=m[1],G[A+2]=m[2],G[A+3]=m[3],G[A+4]=m[4],G[A+5]=m[5],G[A+6]=m[6],G[A+7]=m[7]}function R(U,G,A){d[0]=U,G[A]=m[7],G[A+1]=m[6],G[A+2]=m[5],G[A+3]=m[4],G[A+4]=m[3],G[A+5]=m[2],G[A+6]=m[1],G[A+7]=m[0]}r.writeDoubleLE=h?u:R,r.writeDoubleBE=h?R:u;function V(U,G){return m[0]=U[G],m[1]=U[G+1],m[2]=U[G+2],m[3]=U[G+3],m[4]=U[G+4],m[5]=U[G+5],m[6]=U[G+6],m[7]=U[G+7],d[0]}function F(U,G){return m[7]=U[G],m[6]=U[G+1],m[5]=U[G+2],m[4]=U[G+3],m[3]=U[G+4],m[2]=U[G+5],m[1]=U[G+6],m[0]=U[G+7],d[0]}r.readDoubleLE=h?V:F,r.readDoubleBE=h?F:V}():function(){function d(h,u,R,V,F,U){var G=V<0?1:0;if(G&&(V=-V),V===0)h(0,F,U+u),h(1/V>0?0:2147483648,F,U+R);else if(isNaN(V))h(0,F,U+u),h(2146959360,F,U+R);else if(V>17976931348623157e292)h(0,F,U+u),h((G<<31|2146435072)>>>0,F,U+R);else{var A;if(V<22250738585072014e-324)A=V/5e-324,h(A>>>0,F,U+u),h((G<<31|A/4294967296)>>>0,F,U+R);else{var S=Math.floor(Math.log(V)/Math.LN2);S===1024&&(S=1023),A=V*Math.pow(2,-S),h(A*4503599627370496>>>0,F,U+u),h((G<<31|S+1023<<20|A*1048576&1048575)>>>0,F,U+R)}}}r.writeDoubleLE=d.bind(null,o,0,4),r.writeDoubleBE=d.bind(null,a,4,0);function m(h,u,R,V,F){var U=h(V,F+u),G=h(V,F+R),A=(G>>31)*2+1,S=G>>>20&2047,g=4294967296*(G&1048575)+U;return S===2047?g?NaN:A*(1/0):S===0?A*5e-324*g:A*Math.pow(2,S-1075)*(g+4503599627370496)}r.readDoubleLE=m.bind(null,s,0,4),r.readDoubleBE=m.bind(null,l,4,0)}(),r}function o(r,d,m){d[m]=r&255,d[m+1]=r>>>8&255,d[m+2]=r>>>16&255,d[m+3]=r>>>24}function a(r,d,m){d[m]=r>>>24,d[m+1]=r>>>16&255,d[m+2]=r>>>8&255,d[m+3]=r&255}function s(r,d){return(r[d]|r[d+1]<<8|r[d+2]<<16|r[d+3]<<24)>>>0}function l(r,d){return(r[d]<<24|r[d+1]<<16|r[d+2]<<8|r[d+3])>>>0}},{}],5:[function(require,module,exports){"use strict";module.exports=inquire;function inquire(moduleName){try{var mod=eval("quire".replace(/^/,"re"))(moduleName);if(mod&&(mod.length||Object.keys(mod).length))return mod}catch(t){}return null}},{}],6:[function(t,e,n){"use strict";e.exports=i;function i(o,a,s){var l=s||8192,r=l>>>1,d=null,m=l;return function(u){if(u<1||u>r)return o(u);m+u>l&&(d=o(l),m=0);var R=a.call(d,m,m+=u);return m&7&&(m=(m|7)+1),R}}},{}],7:[function(t,e,n){"use strict";var i=n;i.length=function(a){for(var s=0,l=0,r=0;r191&&u<224?m[h++]=(u&31)<<6|a[s++]&63:u>239&&u<365?(u=((u&7)<<18|(a[s++]&63)<<12|(a[s++]&63)<<6|a[s++]&63)-65536,m[h++]=55296+(u>>10),m[h++]=56320+(u&1023)):m[h++]=(u&15)<<12|(a[s++]&63)<<6|a[s++]&63,h>8191&&((d||(d=[])).push(String.fromCharCode.apply(String,m)),h=0);return d?(h&&d.push(String.fromCharCode.apply(String,m.slice(0,h))),d.join("")):String.fromCharCode.apply(String,m.slice(0,h))},i.write=function(a,s,l){for(var r=l,d,m,h=0;h>6|192,s[l++]=d&63|128):(d&64512)===55296&&((m=a.charCodeAt(h+1))&64512)===56320?(d=65536+((d&1023)<<10)+(m&1023),++h,s[l++]=d>>18|240,s[l++]=d>>12&63|128,s[l++]=d>>6&63|128,s[l++]=d&63|128):(s[l++]=d>>12|224,s[l++]=d>>6&63|128,s[l++]=d&63|128);return l-r}},{}],8:[function(t,e,n){"use strict";var i=n;i.build="minimal",i.Writer=t(16),i.BufferWriter=t(17),i.Reader=t(9),i.BufferReader=t(10),i.util=t(15),i.rpc=t(12),i.roots=t(11),i.configure=o;function o(){i.util._configure(),i.Writer._configure(i.BufferWriter),i.Reader._configure(i.BufferReader)}o()},{10:10,11:11,12:12,15:15,16:16,17:17,9:9}],9:[function(t,e,n){"use strict";e.exports=r;var i=t(15),o,a=i.LongBits,s=i.utf8;function l(V,F){return RangeError("index out of range: "+V.pos+" + "+(F||1)+" > "+V.len)}function r(V){this.buf=V,this.pos=0,this.len=V.length}var d=typeof Uint8Array<"u"?function(F){if(F instanceof Uint8Array||Array.isArray(F))return new r(F);throw Error("illegal buffer")}:function(F){if(Array.isArray(F))return new r(F);throw Error("illegal buffer")},m=function(){return i.Buffer?function(U){return(r.create=function(A){return i.Buffer.isBuffer(A)?new o(A):d(A)})(U)}:d};r.create=m(),r.prototype._slice=i.Array.prototype.subarray||i.Array.prototype.slice,r.prototype.uint32=function(){var F=4294967295;return function(){if(F=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(F=(F|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(F=(F|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(F=(F|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(F=(F|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return F;if((this.pos+=5)>this.len)throw this.pos=this.len,l(this,10);return F}}(),r.prototype.int32=function(){return this.uint32()|0},r.prototype.sint32=function(){var F=this.uint32();return F>>>1^-(F&1)|0};function h(){var V=new a(0,0),F=0;if(this.len-this.pos>4){for(;F<4;++F)if(V.lo=(V.lo|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return V;if(V.lo=(V.lo|(this.buf[this.pos]&127)<<28)>>>0,V.hi=(V.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return V;F=0}else{for(;F<3;++F){if(this.pos>=this.len)throw l(this);if(V.lo=(V.lo|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return V}return V.lo=(V.lo|(this.buf[this.pos++]&127)<>>0,V}if(this.len-this.pos>4){for(;F<5;++F)if(V.hi=(V.hi|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return V}else for(;F<5;++F){if(this.pos>=this.len)throw l(this);if(V.hi=(V.hi|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return V}throw Error("invalid varint encoding")}r.prototype.bool=function(){return this.uint32()!==0};function u(V,F){return(V[F-4]|V[F-3]<<8|V[F-2]<<16|V[F-1]<<24)>>>0}r.prototype.fixed32=function(){if(this.pos+4>this.len)throw l(this,4);return u(this.buf,this.pos+=4)},r.prototype.sfixed32=function(){if(this.pos+4>this.len)throw l(this,4);return u(this.buf,this.pos+=4)|0};function R(){if(this.pos+8>this.len)throw l(this,8);return new a(u(this.buf,this.pos+=4),u(this.buf,this.pos+=4))}r.prototype.float=function(){if(this.pos+4>this.len)throw l(this,4);var F=i.float.readFloatLE(this.buf,this.pos);return this.pos+=4,F},r.prototype.double=function(){if(this.pos+8>this.len)throw l(this,4);var F=i.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,F},r.prototype.bytes=function(){var F=this.uint32(),U=this.pos,G=this.pos+F;if(G>this.len)throw l(this,F);if(this.pos+=F,Array.isArray(this.buf))return this.buf.slice(U,G);if(U===G){var A=i.Buffer;return A?A.alloc(0):new this.buf.constructor(0)}return this._slice.call(this.buf,U,G)},r.prototype.string=function(){var F=this.bytes();return s.read(F,0,F.length)},r.prototype.skip=function(F){if(typeof F=="number"){if(this.pos+F>this.len)throw l(this,F);this.pos+=F}else do if(this.pos>=this.len)throw l(this);while(this.buf[this.pos++]&128);return this},r.prototype.skipType=function(V){switch(V){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(V=this.uint32()&7)!==4;)this.skipType(V);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+V+" at offset "+this.pos)}return this},r._configure=function(V){o=V,r.create=m(),o._configure();var F=i.Long?"toLong":"toNumber";i.merge(r.prototype,{int64:function(){return h.call(this)[F](!1)},uint64:function(){return h.call(this)[F](!0)},sint64:function(){return h.call(this).zzDecode()[F](!1)},fixed64:function(){return R.call(this)[F](!0)},sfixed64:function(){return R.call(this)[F](!1)}})}},{15:15}],10:[function(t,e,n){"use strict";e.exports=a;var i=t(9);(a.prototype=Object.create(i.prototype)).constructor=a;var o=t(15);function a(s){i.call(this,s)}a._configure=function(){o.Buffer&&(a.prototype._slice=o.Buffer.prototype.slice)},a.prototype.string=function(){var l=this.uint32();return this.buf.utf8Slice?this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+l,this.len)):this.buf.toString("utf-8",this.pos,this.pos=Math.min(this.pos+l,this.len))},a._configure()},{15:15,9:9}],11:[function(t,e,n){"use strict";e.exports={}},{}],12:[function(t,e,n){"use strict";var i=n;i.Service=t(13)},{13:13}],13:[function(t,e,n){"use strict";e.exports=o;var i=t(15);(o.prototype=Object.create(i.EventEmitter.prototype)).constructor=o;function o(a,s,l){if(typeof a!="function")throw TypeError("rpcImpl must be a function");i.EventEmitter.call(this),this.rpcImpl=a,this.requestDelimited=!!s,this.responseDelimited=!!l}o.prototype.rpcCall=function a(s,l,r,d,m){if(!d)throw TypeError("request must be specified");var h=this;if(!m)return i.asPromise(a,h,s,l,r,d);if(!h.rpcImpl)return setTimeout(function(){m(Error("already ended"))},0),undefined;try{return h.rpcImpl(s,l[h.requestDelimited?"encodeDelimited":"encode"](d).finish(),function(R,V){if(R)return h.emit("error",R,s),m(R);if(V===null)return h.end(!0),undefined;if(!(V instanceof r))try{V=r[h.responseDelimited?"decodeDelimited":"decode"](V)}catch(F){return h.emit("error",F,s),m(F)}return h.emit("data",V,s),m(null,V)})}catch(u){return h.emit("error",u,s),setTimeout(function(){m(u)},0),undefined}},o.prototype.end=function(s){return this.rpcImpl&&(s||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this}},{15:15}],14:[function(t,e,n){"use strict";e.exports=o;var i=t(15);function o(r,d){this.lo=r>>>0,this.hi=d>>>0}var a=o.zero=new o(0,0);a.toNumber=function(){return 0},a.zzEncode=a.zzDecode=function(){return this},a.length=function(){return 1};var s=o.zeroHash="\0\0\0\0\0\0\0\0";o.fromNumber=function(d){if(d===0)return a;var m=d<0;m&&(d=-d);var h=d>>>0,u=(d-h)/4294967296>>>0;return m&&(u=~u>>>0,h=~h>>>0,++h>4294967295&&(h=0,++u>4294967295&&(u=0))),new o(h,u)},o.from=function(d){if(typeof d=="number")return o.fromNumber(d);if(i.isString(d))if(i.Long)d=i.Long.fromString(d);else return o.fromNumber(parseInt(d,10));return d.low||d.high?new o(d.low>>>0,d.high>>>0):a},o.prototype.toNumber=function(d){if(!d&&this.hi>>>31){var m=~this.lo+1>>>0,h=~this.hi>>>0;return m||(h=h+1>>>0),-(m+h*4294967296)}return this.lo+this.hi*4294967296},o.prototype.toLong=function(d){return i.Long?new i.Long(this.lo|0,this.hi|0,!!d):{low:this.lo|0,high:this.hi|0,unsigned:!!d}};var l=String.prototype.charCodeAt;o.fromHash=function(d){return d===s?a:new o((l.call(d,0)|l.call(d,1)<<8|l.call(d,2)<<16|l.call(d,3)<<24)>>>0,(l.call(d,4)|l.call(d,5)<<8|l.call(d,6)<<16|l.call(d,7)<<24)>>>0)},o.prototype.toHash=function(){return String.fromCharCode(this.lo&255,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,this.hi&255,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},o.prototype.zzEncode=function(){var d=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^d)>>>0,this.lo=(this.lo<<1^d)>>>0,this},o.prototype.zzDecode=function(){var d=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^d)>>>0,this.hi=(this.hi>>>1^d)>>>0,this},o.prototype.length=function(){var d=this.lo,m=(this.lo>>>28|this.hi<<4)>>>0,h=this.hi>>>24;return h===0?m===0?d<16384?d<128?1:2:d<2097152?3:4:m<16384?m<128?5:6:m<2097152?7:8:h<128?9:10}},{15:15}],15:[function(t,e,n){"use strict";var i=n;i.asPromise=t(1),i.base64=t(2),i.EventEmitter=t(3),i.float=t(4),i.inquire=t(5),i.utf8=t(7),i.pool=t(6),i.LongBits=t(14),i.isNode=!!(typeof global<"u"&&global&&global.process&&global.process.versions&&global.process.versions.node),i.global=i.isNode&&global||typeof window<"u"&&window||typeof self<"u"&&self||this,i.emptyArray=Object.freeze?Object.freeze([]):[],i.emptyObject=Object.freeze?Object.freeze({}):{},i.isInteger=Number.isInteger||function(l){return typeof l=="number"&&isFinite(l)&&Math.floor(l)===l},i.isString=function(l){return typeof l=="string"||l instanceof String},i.isObject=function(l){return l&&typeof l=="object"},i.isset=i.isSet=function(l,r){var d=l[r];return d!=null&&l.hasOwnProperty(r)?typeof d!="object"||(Array.isArray(d)?d.length:Object.keys(d).length)>0:!1},i.Buffer=function(){try{var s=i.inquire("buffer").Buffer;return s.prototype.utf8Write?s:null}catch{return null}}(),i._Buffer_from=null,i._Buffer_allocUnsafe=null,i.newBuffer=function(l){return typeof l=="number"?i.Buffer?i._Buffer_allocUnsafe(l):new i.Array(l):i.Buffer?i._Buffer_from(l):typeof Uint8Array>"u"?l:new Uint8Array(l)},i.Array=typeof Uint8Array<"u"?Uint8Array:Array,i.Long=i.global.dcodeIO&&i.global.dcodeIO.Long||i.global.Long||i.inquire("long"),i.key2Re=/^true|false|0|1$/,i.key32Re=/^-?(?:0|[1-9][0-9]*)$/,i.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,i.longToHash=function(l){return l?i.LongBits.from(l).toHash():i.LongBits.zeroHash},i.longFromHash=function(l,r){var d=i.LongBits.fromHash(l);return i.Long?i.Long.fromBits(d.lo,d.hi,r):d.toNumber(!!r)};function o(s,l,r){for(var d=Object.keys(l),m=0;m-1;--h)if(r[m[h]]===1&&this[m[h]]!==undefined&&this[m[h]]!==null)return m[h]}},i.oneOfSetter=function(l){return function(r){for(var d=0;d127;)g[C++]=S&127|128,S>>>=7;g[C]=S}function F(S,g){this.len=S,this.next=undefined,this.val=g}F.prototype=Object.create(r.prototype),F.prototype.fn=V,h.prototype.uint32=function(g){return this.len+=(this.tail=this.tail.next=new F((g=g>>>0)<128?1:g<16384?2:g<2097152?3:g<268435456?4:5,g)).len,this},h.prototype.int32=function(g){return g<0?this._push(U,10,a.fromNumber(g)):this.uint32(g)},h.prototype.sint32=function(g){return this.uint32((g<<1^g>>31)>>>0)};function U(S,g,C){for(;S.hi;)g[C++]=S.lo&127|128,S.lo=(S.lo>>>7|S.hi<<25)>>>0,S.hi>>>=7;for(;S.lo>127;)g[C++]=S.lo&127|128,S.lo=S.lo>>>7;g[C++]=S.lo}h.prototype.uint64=function(g){var C=a.from(g);return this._push(U,C.length(),C)},h.prototype.int64=h.prototype.uint64,h.prototype.sint64=function(g){var C=a.from(g).zzEncode();return this._push(U,C.length(),C)},h.prototype.bool=function(g){return this._push(R,1,g?1:0)};function G(S,g,C){g[C]=S&255,g[C+1]=S>>>8&255,g[C+2]=S>>>16&255,g[C+3]=S>>>24}h.prototype.fixed32=function(g){return this._push(G,4,g>>>0)},h.prototype.sfixed32=h.prototype.fixed32,h.prototype.fixed64=function(g){var C=a.from(g);return this._push(G,4,C.lo)._push(G,4,C.hi)},h.prototype.sfixed64=h.prototype.fixed64,h.prototype.float=function(g){return this._push(i.float.writeFloatLE,4,g)},h.prototype.double=function(g){return this._push(i.float.writeDoubleLE,8,g)};var A=i.Array.prototype.set?function(g,C,y){C.set(g,y)}:function(g,C,y){for(var Y=0;Y>>0;if(!C)return this._push(R,1,0);if(i.isString(g)){var y=h.alloc(C=s.length(g));s.decode(g,y,0),g=y}return this.uint32(C)._push(A,C,g)},h.prototype.string=function(g){var C=l.length(g);return C?this.uint32(C)._push(l.write,C,g):this._push(R,1,0)},h.prototype.fork=function(){return this.states=new m(this),this.head=this.tail=new r(d,0,0),this.len=0,this},h.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new r(d,0,0),this.len=0),this},h.prototype.ldelim=function(){var g=this.head,C=this.tail,y=this.len;return this.reset().uint32(y),y&&(this.tail.next=g.next,this.tail=C,this.len+=y),this},h.prototype.finish=function(){for(var g=this.head.next,C=this.constructor.alloc(this.len),y=0;g;)g.fn(g.val,C,y),y+=g.len,g=g.next;return C},h._configure=function(S){o=S,h.create=u(),o._configure()}},{15:15}],17:[function(t,e,n){"use strict";e.exports=a;var i=t(16);(a.prototype=Object.create(i.prototype)).constructor=a;var o=t(15);function a(){i.call(this)}a._configure=function(){a.alloc=o._Buffer_allocUnsafe,a.writeBytesBuffer=o.Buffer&&o.Buffer.prototype instanceof Uint8Array&&o.Buffer.prototype.set.name==="set"?function(r,d,m){d.set(r,m)}:function(r,d,m){if(r.copy)r.copy(d,m,0,r.length);else for(var h=0;h>>0;return this.uint32(d),d&&this._push(a.writeBytesBuffer,d,r),this};function s(l,r,d){l.length<40?o.utf8.write(l,r,d):r.utf8Write?r.utf8Write(l,d):r.write(l,d)}a.prototype.string=function(r){var d=o.Buffer.byteLength(r);return this.uint32(d),d&&this._push(s,d,r),this},a._configure()},{15:15,16:16}]},{},[8])})()});var Xkt=Zo((Mjo,t4)=>{var _jo=b(W());/* Copyright 2015-2018 Esri. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 @preserve */(function(){var t=function(){var o={};o.defaultNoDataValue=-34027999387901484e22,o.decode=function(m,h){h=h||{};var u=h.encodedMaskData||h.encodedMaskData===null,R=r(m,h.inputOffset||0,u),V=h.noDataValue!==null?h.noDataValue:o.defaultNoDataValue,F=a(R,h.pixelType||Float32Array,h.encodedMaskData,V,h.returnMask),U={width:R.width,height:R.height,pixelData:F.resultPixels,minValue:F.minValue,maxValue:R.pixels.maxValue,noDataValue:V};return F.resultMask&&(U.maskData=F.resultMask),h.returnEncodedMask&&R.mask&&(U.encodedMaskData=R.mask.bitset?R.mask.bitset:null),h.returnFileInfo&&(U.fileInfo=s(R),h.computeUsedBitDepths&&(U.fileInfo.bitDepths=l(R))),U};var a=function(m,h,u,R,V){var F=0,U=m.pixels.numBlocksX,G=m.pixels.numBlocksY,A=Math.floor(m.width/U),S=Math.floor(m.height/G),g=2*m.maxZError,C=Number.MAX_VALUE,y;u=u||(m.mask?m.mask.bitset:null);var Y,Q;Y=new h(m.width*m.height),V&&u&&(Q=new Uint8Array(m.width*m.height));for(var J=new Float32Array(A*S),M,Z,E=0;E<=G;E++){var I=E!==G?S:m.height%G;if(I!==0)for(var B=0;B<=U;B++){var X=B!==U?A:m.width%U;if(X!==0){var _=E*m.width*S+B*A,P=m.width-X,w=m.pixels.blocks[F],z,H,nt;w.encoding<2?(w.encoding===0?z=w.rawData:(d(w.stuffedData,w.bitsPerPixel,w.numValidPixels,w.offset,g,J,m.pixels.maxValue),z=J),H=0):w.encoding===2?nt=0:nt=w.offset;var $;if(u)for(Z=0;Z>3],$<<=_&7),M=0;M>3]),$&128?(Q&&(Q[_]=1),y=w.encoding<2?z[H++]:nt,C=C>y?y:C,Y[_++]=y):(Q&&(Q[_]=0),Y[_++]=R),$<<=1;_+=P}else if(w.encoding<2)for(Z=0;Zy?y:C,Y[_++]=y;_+=P}else for(C=C>nt?nt:C,Z=0;Z0){var U=new Uint8Array(Math.ceil(R.width*R.height/8));F=new DataView(m,h,R.mask.numBytes);var G=F.getInt16(0,!0),A=2,S=0;do{if(G>0)for(;G--;)U[S++]=F.getUint8(A++);else{var g=F.getUint8(A++);for(G=-G;G--;)U[S++]=g}G=F.getInt16(A,!0),A+=2}while(A0?1:0),Q=y+(R.height%y>0?1:0);R.pixels.blocks=new Array(Y*Q);for(var J=0,M=0;M3)throw"Invalid block encoding ("+B.encoding+")";if(B.encoding===2){h++;continue}if(X!==0&&X!==2){if(X>>=6,B.offsetType=X,X===2)B.offset=F.getInt8(1),E++;else if(X===1)B.offset=F.getInt16(1,!0),E+=2;else if(X===0)B.offset=F.getFloat32(1,!0),E+=4;else throw"Invalid block offset type";if(B.encoding===1)if(X=F.getUint8(E),E++,B.bitsPerPixel=X&63,X>>=6,B.numValidPixelsType=X,X===2)B.numValidPixels=F.getUint8(E),E++;else if(X===1)B.numValidPixels=F.getUint16(E,!0),E+=2;else if(X===0)B.numValidPixels=F.getUint32(E,!0),E+=4;else throw"Invalid valid pixel count type"}if(h+=E,B.encoding!==3){var _,P;if(B.encoding===0){var w=(R.pixels.numBytes-1)/4;if(w!==Math.floor(w))throw"uncompressed block has invalid length";_=new ArrayBuffer(w*4),P=new Uint8Array(_),P.set(new Uint8Array(m,h,w*4));var z=new Float32Array(_);B.rawData=z,h+=w*4}else if(B.encoding===1){var H=Math.ceil(B.numValidPixels*B.bitsPerPixel/8),nt=Math.ceil(H/4);_=new ArrayBuffer(nt*4),P=new Uint8Array(_),P.set(new Uint8Array(m,h,H)),B.stuffedData=new Uint32Array(_),h+=H}}}return R.eofOffset=h,R},d=function(m,h,u,R,V,F,U){var G=(1<=h)C=y>>>g-h&G,g-=h;else{var J=h-g;C=(y&G)<>>g}F[S]=C=m?(g=C>>>S-m&U,S-=m):(y=m-S,g=(C&U)<>>S),d[A]=u[g];else for(Y=Math.ceil((F-R)/V),A=0;A=m?(g=C>>>S-m&U,S-=m):(y=m-S,g=(C&U)<>>S),d[A]=g=d?(S=g>>>A-d&V,A-=d):(G=d-A,S=(g&V)<>>A),C[U]=S=m?(C=y>>>g&U,S-=m,g+=m):(Y=m-S,C=y>>>g&U,y=r[G++],S=32-Y,C|=(y&(1<=m?(C=y>>>g&U,S-=m,g+=m):(Y=m-S,C=y>>>g&U,y=r[G++],S=32-Y,C|=(y&(1<=d?(S=C>>>g&V,A-=d,g+=d):(G=d-A,S=C>>>g&V,C=r[F++],A=32-G,S|=(C&(1<=m?(U=G>>>F-m&u,F-=m):(A=m-F,U=(G&u)<>>F),d[V]=U;return d},originalUnstuff2:function(r,d,m,h){var u=(1<=m?(G=A>>>U&u,F-=m,U+=m):(S=m-F,G=A>>>U&u,A=r[R++],F=32-S,G|=(A&(1<=359?359:u;u-=V;do d+=r[R++]<<8,m+=d+=r[R++];while(--V);d=(d&65535)+(d>>>16),m=(m&65535)+(m>>>16)}return h&1&&(m+=d+=r[R]<<8),d=(d&65535)+(d>>>16),m=(m&65535)+(m>>>16),(m<<16|d)>>>0},readHeaderInfo:function(r,d){var m=d.ptr,h=new Uint8Array(r,m,6),u={};if(u.fileIdentifierString=String.fromCharCode.apply(null,h),u.fileIdentifierString.lastIndexOf("Lerc2",0)!==0)throw"Unexpected file identifier string (expect Lerc2 ): "+u.fileIdentifierString;m+=6;var R=new DataView(r,m,8),V=R.getInt32(0,!0);u.fileVersion=V,m+=4,V>=3&&(u.checksum=R.getUint32(4,!0),m+=4),R=new DataView(r,m,12),u.height=R.getUint32(0,!0),u.width=R.getUint32(4,!0),m+=8,V>=4?(u.numDims=R.getUint32(8,!0),m+=4):u.numDims=1,R=new DataView(r,m,40),u.numValidPixel=R.getUint32(0,!0),u.microBlockSize=R.getInt32(4,!0),u.blobSize=R.getInt32(8,!0),u.imageType=R.getInt32(12,!0),u.maxZError=R.getFloat64(16,!0),u.zMin=R.getFloat64(24,!0),u.zMax=R.getFloat64(32,!0),m+=40,d.headerInfo=u,d.ptr=m;var F,U;if(V>=3&&(U=V>=4?52:48,F=this.computeChecksumFletcher32(new Uint8Array(r,m-U,u.blobSize-14)),F!==u.checksum))throw"Checksum failed.";return!0},checkMinMaxRanges:function(r,d){var m=d.headerInfo,h=this.getDataTypeArray(m.imageType),u=m.numDims*this.getDataTypeSize(m.imageType),R=this.readSubArray(r,d.ptr,h,u),V=this.readSubArray(r,d.ptr+u,h,u);d.ptr+=2*u;var F,U=!0;for(F=0;F0){U=new Uint8Array(Math.ceil(u/8)),V=new DataView(r,m,F.numBytes);var A=V.getInt16(0,!0),S=2,g=0,C=0;do{if(A>0)for(;A--;)U[g++]=V.getUint8(S++);else for(C=V.getUint8(S++),A=-A;A--;)U[g++]=C;A=V.getInt16(S,!0),S+=2}while(S>3],y<<=Y&7):y=U[Y>>3],y&128&&(G[Y]=1);d.pixels.resultMask=G,F.bitset=U,m+=F.numBytes}return d.ptr=m,d.mask=F,!0},readDataOneSweep:function(r,d,m){var h=d.ptr,u=d.headerInfo,R=u.numDims,V=u.width*u.height,F=u.imageType,U=u.numValidPixel*a.getDataTypeSize(F)*R,G,A=d.pixels.resultMask;if(m===Uint8Array)G=new Uint8Array(r,h,U);else{var S=new ArrayBuffer(U),g=new Uint8Array(S);g.set(new Uint8Array(r,h,U)),G=new m(S)}if(G.length===V*R)d.pixels.resultPixels=G;else{d.pixels.resultPixels=new m(V*R);var C=0,y=0,Y=0,Q=0;if(R>1)for(Y=0;Y=F)return!1;var U=new Uint32Array(F-V);a.decodeBits(r,d,U);var G=[],A,S,g,C;for(A=V;A0&&(G[S].second=E<>>32-C,32-Z>=C?(Z+=C,Z===32&&(Z=0,I++,E=M[I])):(Z+=C-32,I++,E=M[I],G[S].second|=E>>>32-Z));var B=0,X=0,_=new s;for(A=0;A=m?X=m:X=B,B>=30&&console.log("WARning, large NUM LUT BITS IS "+B);var P=[],w,z,H,nt,$,dt;for(A=V;A0)if(w=[C,S],C<=X)for(z=G[S].second<=0;nt--)$=z>>>nt&1,$?(dt.right||(dt.right=new s),dt=dt.right):(dt.left||(dt.left=new s),dt=dt.left),nt===0&&!dt.val&&(dt.val=w[1]);return{decodeLut:P,numBitsLUTQick:X,numBitsLUT:B,tree:_,stuffedData:M,srcPtr:I,bitPos:Z}},readHuffman:function(r,d,m){var h=d.headerInfo,u=h.numDims,R=d.headerInfo.height,V=d.headerInfo.width,F=V*R,U=this.readHuffmanTree(r,d),G=U.decodeLut,A=U.tree,S=U.stuffedData,g=U.srcPtr,C=U.bitPos,y=U.numBitsLUTQick,Y=U.numBitsLUT,Q=d.headerInfo.imageType===0?128:0,J,M,Z,E=d.pixels.resultMask,I,B,X,_,P,w,z,H=0;C>0&&(g++,C=0);var nt=S[g],$=d.encodeMode===1,dt=new m(F*u),q=dt,at;for(at=0;at1&&(q=new m(dt.buffer,F*at,F),H=0),d.headerInfo.numValidPixel===V*R)for(w=0,_=0;_>>32-y,B=I,32-C>>64-C-y,B=I),G[B])M=G[B][1],C+=G[B][0];else for(I=nt<>>32-Y,B=I,32-C>>64-C-Y,B=I),J=A,z=0;z>>Y-z-1&1,J=X?J.right:J.left,!(J.left||J.right)){M=J.val,C=C+z+1;break}C>=32&&(C-=32,g++,nt=S[g]),Z=M-Q,$?(P>0?Z+=H:_>0?Z+=q[w-V]:Z+=H,Z&=255,q[w]=Z,H=Z):q[w]=Z}else for(w=0,_=0;_>>32-y,B=I,32-C>>64-C-y,B=I),G[B])M=G[B][1],C+=G[B][0];else for(I=nt<>>32-Y,B=I,32-C>>64-C-Y,B=I),J=A,z=0;z>>Y-z-1&1,J=X?J.right:J.left,!(J.left||J.right)){M=J.val,C=C+z+1;break}C>=32&&(C-=32,g++,nt=S[g]),Z=M-Q,$?(P>0&&E[w-1]?Z+=H:_>0&&E[w-V]?Z+=q[w-V]:Z+=H,Z&=255,q[w]=Z,H=Z):q[w]=Z}d.ptr=d.ptr+(g+1)*4+(C>0?4:0)}d.pixels.resultPixels=dt},decodeBits:function(r,d,m,h,u){{var R=d.headerInfo,V=R.fileVersion,F=0,U=new DataView(r,d.ptr,5),G=U.getUint8(0);F++;var A=G>>6,S=A===0?4:3-A,g=(G&32)>0,C=G&31,y=0;if(S===1)y=U.getUint8(F),F++;else if(S===2)y=U.getUint16(F,!0),F+=2;else if(S===4)y=U.getUint32(F,!0),F+=4;else throw"Invalid valid pixel count type";var Y=2*R.maxZError,Q,J,M,Z,E,I,B,X,_,P,w=R.numDims>1?R.maxValues[u]:R.zMax;if(g){for(d.counter.lut++,X=U.getUint8(F),_=C,F++,Z=Math.ceil((X-1)*C/8),E=Math.ceil(Z/4),J=new ArrayBuffer(E*4),M=new Uint8Array(J),d.ptr+=F,M.set(new Uint8Array(r,d.ptr,Z)),B=new Uint32Array(J),d.ptr+=Z,P=0;X-1>>>P;)P++;Z=Math.ceil(y*P/8),E=Math.ceil(Z/4),J=new ArrayBuffer(E*4),M=new Uint8Array(J),M.set(new Uint8Array(r,d.ptr,Z)),Q=new Uint32Array(J),d.ptr+=Z,V>=3?I=o.unstuffLUT2(B,C,X-1,h,Y,w):I=o.unstuffLUT(B,C,X-1,h,Y,w),V>=3?o.unstuff2(Q,m,P,y,I):o.unstuff(Q,m,P,y,I)}else d.counter.bitstuffer++,P=C,d.ptr+=F,P>0&&(Z=Math.ceil(y*P/8),E=Math.ceil(Z/4),J=new ArrayBuffer(E*4),M=new Uint8Array(J),M.set(new Uint8Array(r,d.ptr,Z)),Q=new Uint32Array(J),d.ptr+=Z,V>=3?h==null?o.originalUnstuff2(Q,m,P,y):o.unstuff2(Q,m,P,y,!1,h,Y,w):h==null?o.originalUnstuff(Q,m,P,y):o.unstuff(Q,m,P,y,!1,h,Y,w))}},readTiles:function(r,d,m){var h=d.headerInfo,u=h.width,R=h.height,V=h.microBlockSize,F=h.imageType,U=a.getDataTypeSize(F),G=Math.ceil(u/V),A=Math.ceil(R/V);d.pixels.numBlocksY=A,d.pixels.numBlocksX=G,d.pixels.ptr=0;var S=0,g=0,C=0,y=0,Y=0,Q=0,J=0,M=0,Z=0,E=0,I=0,B=0,X=0,_=0,P=0,w=0,z,H,nt,$,dt,q,at=new m(V*V),st=R%V||V,Et=u%V||V,Qt,Wt,Nt=h.numDims,kt,Mt=d.pixels.resultMask,qt=d.pixels.resultPixels;for(C=0;C1&&(qt=new m(d.pixels.resultPixels.buffer,u*R*kt*U,u*R)),J=r.byteLength-d.ptr,z=new DataView(r,d.ptr,Math.min(10,J)),H={},w=0,M=z.getUint8(0),w++,Z=M>>6&255,E=M>>2&15,E!==(y*V>>3&15))throw"integrity issue";if(q=M&3,q>3)throw d.ptr+=w,"Invalid block encoding ("+q+")";if(q===2){d.counter.constant++,d.ptr+=w;continue}else if(q===0){if(d.counter.uncompressed++,d.ptr+=w,X=Y*Q*U,_=r.byteLength-d.ptr,X=X<_?X:_,nt=new ArrayBuffer(X%U===0?X:X+U-X%U),$=new Uint8Array(nt),$.set(new Uint8Array(r,d.ptr,X)),dt=new m(nt),P=0,Mt)for(S=0;S1)for(R=0;R=-128&&d<=127;break;case 1:m=d>=0&&d<=255;break;case 2:m=d>=-32768&&d<=32767;break;case 3:m=d>=0&&d<=65536;break;case 4:m=d>=-2147483648&&d<=2147483647;break;case 5:m=d>=0&&d<=4294967296;break;case 6:m=d>=-34027999387901484e22&&d<=34027999387901484e22;break;case 7:m=d>=5e-324&&d<=17976931348623157e292;break;default:m=!1}return m},getDataTypeSize:function(r){var d=0;switch(r){case 0:case 1:d=1;break;case 2:case 3:d=2;break;case 4:case 5:case 6:d=4;break;case 7:d=8;break;default:d=r}return d},getDataTypeUsed:function(r,d){var m=r;switch(r){case 2:case 4:m=r-d;break;case 3:case 5:m=r-2*d;break;case 6:d===0?m=r:d===1?m=2:m=1;break;case 7:d===0?m=r:m=r-2*d+1;break;default:m=r;break}return m},getOnePixel:function(r,d,m,h){var u=0;switch(m){case 0:u=h.getInt8(d);break;case 1:u=h.getUint8(d);break;case 2:u=h.getInt16(d,!0);break;case 3:u=h.getUint16(d,!0);break;case 4:u=h.getInt32(d,!0);break;case 5:u=h.getUInt32(d,!0);break;case 6:u=h.getFloat32(d,!0);break;case 7:u=h.getFloat64(d,!0);break;default:throw"the decoder does not understand this pixel type"}return u}},s=function(r,d,m){this.val=r,this.left=d,this.right=m},l={decode:function(r,d){d=d||{};var m=d.noDataValue,h=0,u={};if(u.ptr=d.inputOffset||0,u.pixels={},!!a.readHeaderInfo(r,u)){var R=u.headerInfo,V=R.fileVersion,F=a.getDataTypeArray(R.imageType);a.readMask(r,u),R.numValidPixel!==R.width*R.height&&!u.pixels.resultMask&&(u.pixels.resultMask=d.maskData);var U=R.width*R.height;if(u.pixels.resultPixels=new F(U*R.numDims),u.counter={onesweep:0,uncompressed:0,lut:0,bitstuffer:0,constant:0,constantoffset:0},R.numValidPixel!==0)if(R.zMax===R.zMin)a.constructConstantSurface(u);else if(V>=4&&a.checkMinMaxRanges(r,u))a.constructConstantSurface(u);else{var G=new DataView(r,u.ptr,2),A=G.getUint8(0);if(u.ptr++,A)a.readDataOneSweep(r,u,F);else if(V>1&&R.imageType<=1&&Math.abs(R.maxZError-.5)<1e-5){var S=G.getUint8(1);if(u.ptr++,u.encodeMode=S,S>2||V<4&&S>1)throw"Invalid Huffman flag "+S;S?a.readHuffman(r,u,F):a.readTiles(r,u,F)}else a.readTiles(r,u,F)}u.eofOffset=u.ptr;var g;d.inputOffset?(g=u.headerInfo.blobSize+d.inputOffset-u.ptr,Math.abs(g)>=1&&(u.eofOffset=d.inputOffset+u.headerInfo.blobSize)):(g=u.headerInfo.blobSize-u.ptr,Math.abs(g)>=1&&(u.eofOffset=u.headerInfo.blobSize));var C={width:R.width,height:R.height,pixelData:u.pixels.resultPixels,minValue:R.zMin,maxValue:R.zMax,validPixelCount:R.numValidPixel,dimCount:R.numDims,dimStats:{minValues:R.minValues,maxValues:R.maxValues},maskData:u.pixels.resultMask};if(u.pixels.resultMask&&a.isValidPixelValue(R.imageType,m)){var y=u.pixels.resultMask;for(h=0;h1&&A.fileInfo.mask&&A.fileInfo.mask.numBytes>0&&V.push(A.maskData),h++,G.pixels.push(A.pixelData),G.statistics.push({minValue:A.minValue,maxValue:A.maxValue,noDataValue:A.noDataValue,dimStats:A.dimStats})}var S,g,C;if(m>1&&V.length>1){for(C=G.width*G.height,G.bandMasks=V,U=new Uint8Array(C),U.set(V[0]),S=1;S{var $Ga=b(W());k2t.exports={webm:"data:video/webm;base64,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",mp4:"data:video/mp4;base64,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"}});var X2t=Zo((tAa,x2t)=>{var eAa=b(W()),{webm:lDe,mp4:rDe}=Y2t(),Drt=()=>typeof navigator<"u"&&parseFloat((""+(/CPU.*OS ([0-9_]{3,4})[0-9_]{0,1}|(CPU like).*AppleWebKit.*Mobile/i.exec(navigator.userAgent)||[0,""])[1]).replace("undefined","3_2").replace("_",".").replace("_",""))<10&&!window.MSStream,Ort=()=>"wakeLock"in navigator,Hrt=class{constructor(){if(this.enabled=!1,Ort()){this._wakeLock=null;let e=()=>{this._wakeLock!==null&&document.visibilityState==="visible"&&this.enable()};document.addEventListener("visibilitychange",e),document.addEventListener("fullscreenchange",e)}else Drt()?this.noSleepTimer=null:(this.noSleepVideo=document.createElement("video"),this.noSleepVideo.setAttribute("title","No Sleep"),this.noSleepVideo.setAttribute("playsinline",""),this._addSourceToVideo(this.noSleepVideo,"webm",lDe),this._addSourceToVideo(this.noSleepVideo,"mp4",rDe),this.noSleepVideo.addEventListener("loadedmetadata",()=>{this.noSleepVideo.duration<=1?this.noSleepVideo.setAttribute("loop",""):this.noSleepVideo.addEventListener("timeupdate",()=>{this.noSleepVideo.currentTime>.5&&(this.noSleepVideo.currentTime=Math.random())})}))}_addSourceToVideo(e,n,i){var o=document.createElement("source");o.src=i,o.type=`video/${n}`,e.appendChild(o)}get isEnabled(){return this.enabled}enable(){return Ort()?navigator.wakeLock.request("screen").then(e=>{this._wakeLock=e,this.enabled=!0,console.log("Wake Lock active."),this._wakeLock.addEventListener("release",()=>{console.log("Wake Lock released.")})}).catch(e=>{throw this.enabled=!1,console.error(`${e.name}, ${e.message}`),e}):Drt()?(this.disable(),console.warn(` NoSleep enabled for older iOS devices. This can interrupt active or long-running network requests from completing successfully. See https://github.com/richtr/NoSleep.js/issues/15 for more details. `),this.noSleepTimer=window.setInterval(()=>{document.hidden||(window.location.href=window.location.href.split("#")[0],window.setTimeout(window.stop,0))},15e3),this.enabled=!0,Promise.resolve()):this.noSleepVideo.play().then(n=>(this.enabled=!0,n)).catch(n=>{throw this.enabled=!1,n})}disable(){Ort()?(this._wakeLock&&this._wakeLock.release(),this._wakeLock=null):Drt()?this.noSleepTimer&&(console.warn(` NoSleep now disabled for older iOS devices. - `),window.clearInterval(this.noSleepTimer),this.noSleepTimer=null):this.noSleepVideo.pause(),this.enabled=!1}};xkt.exports=Hrt});var JDe={};vO(JDe,{AlphaMode:()=>qV,AlphaPipelineStage:()=>ux,Analysis:()=>x1,Animation:()=>GD,AnimationViewModel:()=>AD,Appearance:()=>ua,ApproximateTerrainHeights:()=>uo,ArcGISTiledElevationTerrainProvider:()=>Sst,ArcGisBaseMapType:()=>oV,ArcGisMapServerImageryProvider:()=>cW,ArcGisMapService:()=>tp,ArcType:()=>Ln,ArticulationStageType:()=>zd,AssociativeArray:()=>qe,Atmosphere:()=>b_,AtmospherePipelineStage:()=>vY,AttributeCompression:()=>Ni,AttributeType:()=>_n,AutoExposure:()=>R9,AutomaticUniforms:()=>bR,Axis:()=>$a,AxisAlignedBoundingBox:()=>Ff,B3dmLoader:()=>SY,B3dmParser:()=>GY,BaseLayerPicker:()=>SD,BaseLayerPickerViewModel:()=>TD,BatchTable:()=>kG,BatchTableHierarchy:()=>lA,BatchTexture:()=>Yc,BatchTexturePipelineStage:()=>Zx,Billboard:()=>Na,BillboardCollection:()=>yh,BillboardGraphics:()=>Mr,BillboardVisualizer:()=>h2,BingMapsGeocoderService:()=>Est,BingMapsImageryProvider:()=>LM,BingMapsStyle:()=>U1,BlendEquation:()=>pd,BlendFunction:()=>Ha,BlendOption:()=>wa,BlendingState:()=>Pn,BoundingRectangle:()=>Fe,BoundingSphere:()=>Ft,BoundingSphereState:()=>ve,BoundingVolumeSemantics:()=>AA,BoxEmitter:()=>Ult,BoxGeometry:()=>Am,BoxGeometryUpdater:()=>Ck,BoxGraphics:()=>PG,BoxOutlineGeometry:()=>tZ,BrdfLutGenerator:()=>f_,Buffer:()=>we,BufferLoader:()=>pA,BufferUsage:()=>ce,CPUStylingPipelineStage:()=>Wx,CallbackProperty:()=>Th,Camera:()=>Aa,CameraEventAggregator:()=>S9,CameraEventType:()=>Mo,CameraFlightPath:()=>U_,Cartesian2:()=>K,Cartesian3:()=>p,Cartesian4:()=>Rt,Cartographic:()=>gt,CartographicGeocoderService:()=>Ist,CatmullRomSpline:()=>Nst,Cesium3DContentGroup:()=>sA,Cesium3DTile:()=>iu,Cesium3DTileBatchTable:()=>wR,Cesium3DTileColorBlendMode:()=>Nm,Cesium3DTileContent:()=>Glt,Cesium3DTileContentFactory:()=>DA,Cesium3DTileContentState:()=>rs,Cesium3DTileContentType:()=>nr,Cesium3DTileFeature:()=>Fr,Cesium3DTileFeatureTable:()=>FZ,Cesium3DTileOptimizationHint:()=>jp,Cesium3DTileOptimizations:()=>KX,Cesium3DTilePass:()=>ns,Cesium3DTilePassState:()=>Eu,Cesium3DTilePointFeature:()=>b0,Cesium3DTileRefine:()=>ss,Cesium3DTileStyle:()=>qS,Cesium3DTileStyleEngine:()=>eJ,Cesium3DTilesInspector:()=>fD,Cesium3DTilesInspectorViewModel:()=>WD,Cesium3DTilesVoxelProvider:()=>Alt,Cesium3DTileset:()=>Pr,Cesium3DTilesetBaseTraversal:()=>lJ,Cesium3DTilesetCache:()=>qX,Cesium3DTilesetGraphics:()=>tA,Cesium3DTilesetHeatmap:()=>$X,Cesium3DTilesetMetadata:()=>$A,Cesium3DTilesetMostDetailedTraversal:()=>oJ,Cesium3DTilesetSkipTraversal:()=>cJ,Cesium3DTilesetStatistics:()=>N0,Cesium3DTilesetTraversal:()=>Sr,Cesium3DTilesetVisualizer:()=>mJ,CesiumInspector:()=>ND,CesiumInspectorViewModel:()=>ID,CesiumTerrainProvider:()=>HS,CesiumWidget:()=>W5,Check:()=>Xa,CheckerboardMaterialProperty:()=>yC,CircleEmitter:()=>M5,CircleGeometry:()=>xst,CircleOutlineGeometry:()=>Xst,ClassificationModelDrawCommand:()=>_Y,ClassificationPipelineStage:()=>Vx,ClassificationPrimitive:()=>fE,ClassificationType:()=>Ji,ClassifyOrbit:()=>_tt,ClearCommand:()=>ao,ClippingPlane:()=>TA,ClippingPlaneCollection:()=>Ml,ClippingPolygon:()=>KE,ClippingPolygonCollection:()=>RZ,Clock:()=>kZ,ClockRange:()=>pl,ClockSpeedUp:()=>Jst,ClockStep:()=>ya,ClockViewModel:()=>ZD,CloudCollection:()=>Ilt,CloudType:()=>mN,Color:()=>v,ColorBlendMode:()=>Kd,ColorGeometryInstanceAttribute:()=>En,ColorMaterialProperty:()=>Cn,Command:()=>Crt,ComponentDatatype:()=>it,Composite3DTileContent:()=>Yk,CompositeEntityCollection:()=>Ott,CompositeMaterialProperty:()=>QC,CompositePositionProperty:()=>cl,CompositeProperty:()=>ec,CompressedTextureBuffer:()=>by,ComputeCommand:()=>Wm,ComputeEngine:()=>Zy,ConditionsExpression:()=>x5,ConeEmitter:()=>ylt,ConjunctionAssessmentTask:()=>Mst,ConstantPositionProperty:()=>jl,ConstantProperty:()=>Ii,ConstantSpline:()=>IY,ContentMetadata:()=>MX,Context:()=>a2,ContextLimits:()=>Sn,CoplanarPolygonGeometry:()=>HJ,CoplanarPolygonGeometryLibrary:()=>T0,CoplanarPolygonOutlineGeometry:()=>nu,CornerType:()=>Xo,CorridorGeometry:()=>aT,CorridorGeometryLibrary:()=>Po,CorridorGeometryUpdater:()=>fJ,CorridorGraphics:()=>KG,CorridorOutlineGeometry:()=>WJ,CoverageGroupDataSource:()=>SJ,CoveragePolygonGeometry:()=>PJ,CoveragePolygonGeometryLibrary:()=>hI,Credit:()=>on,CreditDisplay:()=>S_,CubeMap:()=>Ld,CubeMapFace:()=>XV,CubicRealPolynomial:()=>BG,CullFace:()=>so,CullingVolume:()=>Jl,CumulusCloud:()=>hp,CustomDataSource:()=>hb,CustomHeightmapTerrainProvider:()=>_st,CustomShader:()=>JS,CustomShaderMode:()=>Z0,CustomShaderPipelineStage:()=>Sx,CustomShaderTranslucencyMode:()=>iF,CylinderGeometry:()=>gJ,CylinderGeometryLibrary:()=>sT,CylinderGeometryUpdater:()=>CJ,CylinderGraphics:()=>zG,CylinderOutlineGeometry:()=>EJ,CzmlDataSource:()=>O0,DataSource:()=>ml,DataSourceClock:()=>YZ,DataSourceCollection:()=>YJ,DataSourceDisplay:()=>kF,DebugAppearance:()=>Blt,DebugCameraPrimitive:()=>Jb,DebugInspector:()=>Q9,DebugModelMatrixPrimitive:()=>D5,DefaultProxy:()=>Dst,DepthFunction:()=>_d,DepthPlane:()=>Q_,DequantizationPipelineStage:()=>Ex,DerivedCommand:()=>VW,DeveloperError:()=>Ut,DeviceOrientationCameraController:()=>Y_,DirectionalLight:()=>Qlt,DiscardEmptyTileImagePolicy:()=>G1,DiscardMissingTileImagePolicy:()=>XM,DistanceDisplayCondition:()=>Wn,DistanceDisplayConditionGeometryInstanceAttribute:()=>Xi,DoubleEndedPriorityQueue:()=>xS,DoublyLinkedList:()=>jX,DracoLoader:()=>$R,DrawCommand:()=>Ee,DynamicAtmosphereLightingType:()=>uS,DynamicGeometryBatch:()=>ZT,DynamicGeometryUpdater:()=>lo,EarthOrientationParameters:()=>ly,EarthOrientationParametersSample:()=>lf,EasingFunction:()=>Zl,EllipseGeometry:()=>Pc,EllipseGeometryLibrary:()=>Om,EllipseGeometryUpdater:()=>XJ,EllipseGraphics:()=>jG,EllipseOutlineGeometry:()=>Lh,Ellipsoid:()=>mt,EllipsoidGeodesic:()=>oZ,EllipsoidGeometry:()=>Cr,EllipsoidGeometryUpdater:()=>LJ,EllipsoidGraphics:()=>qG,EllipsoidOutlineGeometry:()=>Qh,EllipsoidPrimitive:()=>h_,EllipsoidRhumbLine:()=>ud,EllipsoidSurfaceAppearance:()=>klt,EllipsoidTangentPlane:()=>Fl,EllipsoidTerrainProvider:()=>Ru,EllipsoidalOccluder:()=>BZ,EmbeddedTileServiceImageryProvider:()=>Ylt,Empty3DTileContent:()=>WC,EncodedCartesian3:()=>Mi,Entity:()=>qa,EntityCluster:()=>Yh,EntityCollection:()=>gr,EntityView:()=>AL,Event:()=>It,EventHelper:()=>rl,Expression:()=>xp,ExpressionNodeType:()=>tn,ExternalData:()=>y6,ExtrapolationType:()=>Ah,FeatureDetection:()=>In,FeatureIdPipelineStage:()=>nF,FlatbufferUtilities:()=>a1,Fog:()=>x_,ForEach:()=>ne,FrameRateMonitor:()=>P5,FrameState:()=>X_,Framebuffer:()=>Lr,FramebufferManager:()=>Ro,FrustumCommands:()=>__,FrustumGeometry:()=>VS,FrustumOutlineGeometry:()=>C_,Fullscreen:()=>Ds,FullscreenButton:()=>BD,FullscreenButtonViewModel:()=>yD,GenerateAccessReport:()=>Ost,GeoJsonDataSource:()=>gL,GeoJsonLoader:()=>gY,GeocodeType:()=>IU,Geocoder:()=>kD,GeocoderService:()=>sN,GeocoderViewModel:()=>QD,GeographicProjection:()=>yo,GeographicTilingScheme:()=>Qo,Geometry:()=>_e,Geometry3DTileContent:()=>Xk,GeometryAttribute:()=>jt,GeometryAttributes:()=>ei,GeometryFactory:()=>Hst,GeometryInstance:()=>$e,GeometryInstanceAttribute:()=>Dd,GeometryOffsetAttribute:()=>zn,GeometryPipeline:()=>gi,GeometryPipelineStage:()=>yx,GeometryType:()=>gp,GeometryUpdater:()=>ro,GeometryUpdaterSet:()=>gT,GeometryVisualizer:()=>dL,GetFeatureInfoFormat:()=>cS,Globe:()=>r_,GlobeDepth:()=>D_,GlobeSurfaceShaderSet:()=>xM,GlobeSurfaceTile:()=>Tu,GlobeSurfaceTileProvider:()=>qM,GlobeTranslucency:()=>$M,GlobeTranslucencyFramebuffer:()=>O_,GlobeTranslucencyState:()=>J_,GltfBufferViewLoader:()=>QE,GltfDracoLoader:()=>kE,GltfImageLoader:()=>YE,GltfIndexBufferLoader:()=>xE,GltfJsonLoader:()=>JE,GltfLoader:()=>s0,GltfLoaderUtil:()=>km,GltfStructuralMetadataLoader:()=>WY,GltfTextureLoader:()=>LE,GltfVertexBufferLoader:()=>ME,GoogleEarthEnterpriseImageryProvider:()=>Xlt,GoogleEarthEnterpriseMapsProvider:()=>DM,GoogleEarthEnterpriseMetadata:()=>EW,GoogleEarthEnterpriseTerrainData:()=>lN,GoogleEarthEnterpriseTerrainProvider:()=>$st,GoogleEarthEnterpriseTileInformation:()=>E5,GoogleMaps:()=>PS,GpxDataSource:()=>NL,GregorianDate:()=>WR,GridImageryProvider:()=>Jlt,GridMaterialProperty:()=>OC,GroundGeometryUpdater:()=>_i,GroundPolylineGeometry:()=>kR,GroundPolylinePrimitive:()=>Gh,GroundPrimitive:()=>Nc,GroupMetadata:()=>CC,HeadingPitchRange:()=>Zu,HeadingPitchRoll:()=>Jr,Heap:()=>iy,HeightReference:()=>Ge,HeightmapEncoding:()=>Uu,HeightmapTerrainData:()=>Gd,HeightmapTessellator:()=>b1,HermitePolynomialApproximation:()=>rT,HermiteSpline:()=>$f,HilbertOrder:()=>IE,HomeButton:()=>xD,HomeButtonViewModel:()=>YD,HorizontalOrigin:()=>to,I3SBuildingSceneLayerExplorer:()=>Xrt,I3SBuildingSceneLayerExplorerViewModel:()=>XD,I3SDataProvider:()=>RV,I3SDecoder:()=>v5,I3SFeature:()=>K5,I3SField:()=>z5,I3SGeometry:()=>hN,I3SLayer:()=>ig,I3SNode:()=>pN,I3SStatistics:()=>$5,I3SSublayer:()=>eD,I3SSymbology:()=>q5,I3dmLoader:()=>CY,I3dmParser:()=>EY,Iau2000Orientation:()=>c_,Iau2006XysData:()=>cy,Iau2006XysSample:()=>UG,IauOrientationAxes:()=>m_,IauOrientationParameters:()=>d_,ImageBasedLighting:()=>aA,ImageBasedLightingPipelineStage:()=>zY,ImageMaterialProperty:()=>Sf,Imagery:()=>C1,ImageryLayer:()=>$r,ImageryLayerCollection:()=>t_,ImageryLayerFeatureInfo:()=>iV,ImageryProvider:()=>$c,ImageryState:()=>ho,Implicit3DTileContent:()=>DE,ImplicitAvailabilityBitstream:()=>yE,ImplicitMetadataView:()=>BE,ImplicitSubdivisionScheme:()=>Al,ImplicitSubtree:()=>UA,ImplicitSubtreeCache:()=>J5,ImplicitSubtreeMetadata:()=>Jk,ImplicitTileCoordinates:()=>nT,ImplicitTileset:()=>eT,IndexDatatype:()=>re,InfoBox:()=>LD,InfoBoxViewModel:()=>JD,InspectorShared:()=>gd,InstanceAttributeSemantic:()=>Sl,InstancingPipelineStage:()=>cx,InterpolationAlgorithm:()=>tlt,InterpolationType:()=>WZ,Intersect:()=>yn,IntersectionTests:()=>no,Intersections2D:()=>SW,Interval:()=>hd,InvertClassification:()=>M1,Ion:()=>cZ,IonGeocoderService:()=>N5,IonImageryProvider:()=>mW,IonResource:()=>gh,IonWorldImageryStyle:()=>hW,Iso8601:()=>Re,JobScheduler:()=>L_,JobType:()=>Vd,JsonMetadataTable:()=>o0,JulianDate:()=>rt,KTX2Transcoder:()=>Ry,KeyboardEventModifier:()=>id,KeyframeNode:()=>ra,KmlCamera:()=>yL,KmlDataSource:()=>iM,KmlLookAt:()=>zL,KmlTour:()=>jL,KmlTourFlyTo:()=>$L,KmlTourWait:()=>tM,Label:()=>cF,LabelCollection:()=>sb,LabelGraphics:()=>aZ,LabelStyle:()=>Pa,LabelVisualizer:()=>cL,LagrangePolynomialApproximation:()=>dT,LatLonGrid:()=>Pit,LeapSecond:()=>zo,Light:()=>Dlt,LightingModel:()=>nb,LightingPipelineStage:()=>Qx,LinearApproximation:()=>_R,LinearSpline:()=>qf,MakeBillboardLabel:()=>Olt,ManagedArray:()=>kc,MapMode2D:()=>eh,MapProjection:()=>ilt,MapboxImageryProvider:()=>OM,MapboxStyleImageryProvider:()=>Hlt,Material:()=>eo,MaterialAppearance:()=>Fa,MaterialPipelineStage:()=>Yx,MaterialProperty:()=>Ua,Math:()=>k,Matrix2:()=>pa,Matrix3:()=>ot,Matrix4:()=>L,Megatexture:()=>P1,MetadataClass:()=>uZ,MetadataClassProperty:()=>kf,MetadataComponentType:()=>vn,MetadataEntity:()=>Yi,MetadataEnum:()=>nY,MetadataEnumValue:()=>eY,MetadataPipelineStage:()=>_p,MetadataSchema:()=>ZZ,MetadataSchemaLoader:()=>_E,MetadataSemantic:()=>GA,MetadataTable:()=>Bm,MetadataTableProperty:()=>Mk,MetadataType:()=>Nn,MipmapHint:()=>JV,Model:()=>AZ,Model3DTileContent:()=>ib,ModelAlphaOptions:()=>tX,ModelAnimation:()=>QY,ModelAnimationChannel:()=>BY,ModelAnimationCollection:()=>kY,ModelAnimationLoop:()=>xm,ModelAnimationState:()=>UZ,ModelArticulation:()=>qY,ModelArticulationStage:()=>jY,ModelClippingPlanesPipelineStage:()=>ex,ModelClippingPolygonsPipelineStage:()=>ox,ModelColorPipelineStage:()=>eF,ModelComponents:()=>Tn,ModelDrawCommand:()=>DY,ModelFeature:()=>YY,ModelFeatureTable:()=>XY,ModelGraphics:()=>JR,ModelLightingOptions:()=>rX,ModelMatrixUpdateStage:()=>mx,ModelNode:()=>ax,ModelRenderResources:()=>eX,ModelRuntimeNode:()=>px,ModelRuntimePrimitive:()=>qx,ModelSceneGraph:()=>cX,ModelSilhouettePipelineStage:()=>oX,ModelSkin:()=>$x,ModelSplitterPipelineStage:()=>sX,ModelStatistics:()=>mX,ModelType:()=>Is,ModelUtility:()=>Mn,ModelVisualizer:()=>mL,Moon:()=>u_,MorphTargetsPipelineStage:()=>Xx,MorphWeightSpline:()=>olt,MortonOrder:()=>VF,Multiple3DTileContent:()=>OX,MultisampleFramebuffer:()=>s2,NavigationHelpButton:()=>_D,NavigationHelpButtonViewModel:()=>MD,NearFarScalar:()=>ln,NeverTileDiscardPolicy:()=>Plt,NodeRenderResources:()=>lX,NodeStatisticsPipelineStage:()=>hx,NodeTransformationProperty:()=>$G,OIT:()=>w_,Occluder:()=>Z_,OctahedralProjectedCubeMap:()=>dZ,OffsetGeometryInstanceAttribute:()=>aa,OpenCageGeocoderService:()=>slt,OpenStreetMapImageryProvider:()=>IW,OrderedGroundPrimitiveCollection:()=>xJ,OrientedBoundingBox:()=>ci,OrthographicFrustum:()=>wn,OrthographicOffCenterFrustum:()=>el,Packable:()=>llt,PackableForInterpolation:()=>rlt,Particle:()=>VN,ParticleBurst:()=>Klt,ParticleEmitter:()=>zlt,ParticleSystem:()=>jlt,Pass:()=>Pt,PassState:()=>Md,PathGraphics:()=>LR,PathVisualizer:()=>uL,PeliasGeocoderService:()=>I5,PerInstanceColorAppearance:()=>jn,PerformanceDisplay:()=>bW,PerformanceWatchdog:()=>OD,PerformanceWatchdogViewModel:()=>DD,PerspectiveFrustum:()=>Io,PerspectiveOffCenterFrustum:()=>em,PickDepth:()=>M_,PickDepthFramebuffer:()=>v_,PickFramebuffer:()=>z_,Picking:()=>$_,PickingPipelineStage:()=>Jx,PinBuilder:()=>q0,PixelDatatype:()=>Ue,PixelFormat:()=>Ye,Plane:()=>Kn,PlaneGeometry:()=>MJ,PlaneGeometryUpdater:()=>DJ,PlaneGraphics:()=>Uk,PlaneOutlineGeometry:()=>_J,PlanetImageryProvider:()=>qlt,PntsLoader:()=>pX,PntsParser:()=>xA,PointCloud:()=>aD,PointCloudEyeDomeLighting:()=>l0,PointCloudShading:()=>eb,PointCloudStylingPipelineStage:()=>Mx,PointGraphics:()=>eA,PointPrimitive:()=>Er,PointPrimitiveCollection:()=>JC,PointVisualizer:()=>VL,PolygonGeometry:()=>i0,PolygonGeometryLibrary:()=>Fi,PolygonGeometryUpdater:()=>vJ,PolygonGraphics:()=>sZ,PolygonHierarchy:()=>Wr,PolygonOutlineGeometry:()=>wJ,PolygonPipeline:()=>wi,Polyline:()=>vp,PolylineArrowMaterialProperty:()=>wC,PolylineCollection:()=>Mc,PolylineColorAppearance:()=>Ul,PolylineDashMaterialProperty:()=>vC,PolylineGeometry:()=>j0,PolylineGeometryUpdater:()=>WL,PolylineGlowMaterialProperty:()=>zC,PolylineGraphics:()=>Od,PolylineMaterialAppearance:()=>zl,PolylineOutlineMaterialProperty:()=>AF,PolylinePipeline:()=>xo,PolylineVisualizer:()=>FL,PolylineVolumeGeometry:()=>jJ,PolylineVolumeGeometryLibrary:()=>IZ,PolylineVolumeGeometryUpdater:()=>eL,PolylineVolumeGraphics:()=>nA,PolylineVolumeOutlineGeometry:()=>tL,PositionProperty:()=>xR,PositionPropertyArray:()=>L0,PostProcessStage:()=>Qa,PostProcessStageCollection:()=>U9,PostProcessStageComposite:()=>nm,PostProcessStageLibrary:()=>Iu,PostProcessStageSampleMode:()=>op,PostProcessStageTextureCache:()=>ES,Primitive:()=>Wi,PrimitiveCollection:()=>Dm,PrimitiveLoadPlan:()=>yA,PrimitiveOutlineGenerator:()=>NA,PrimitiveOutlinePipelineStage:()=>Ox,PrimitivePipeline:()=>MG,PrimitiveRenderResources:()=>dX,PrimitiveState:()=>vs,PrimitiveStatisticsPipelineStage:()=>Hx,PrimitiveType:()=>le,ProjectionPicker:()=>wD,ProjectionPickerViewModel:()=>HD,Property:()=>et,PropertyArray:()=>qC,PropertyAttribute:()=>IA,PropertyAttributeProperty:()=>ZY,PropertyBag:()=>Em,PropertyTable:()=>Xc,PropertyTexture:()=>CA,PropertyTextureProperty:()=>uY,ProviderViewModel:()=>Nl,Proxy:()=>dlt,QuadraticRealPolynomial:()=>Cc,QuadtreeOccluders:()=>e_,QuadtreePrimitive:()=>l_,QuadtreeTile:()=>n_,QuadtreeTileLoadState:()=>Br,QuadtreeTileProvider:()=>ort,QuantizedMeshTerrainData:()=>OS,QuarticRealPolynomial:()=>w2,Quaternion:()=>wt,QuaternionSpline:()=>yY,Queue:()=>$V,Ray:()=>di,Rectangle:()=>Gt,RectangleCollisionChecker:()=>CT,RectangleGeometry:()=>FT,RectangleGeometryLibrary:()=>ir,RectangleGeometryUpdater:()=>nL,RectangleGraphics:()=>lZ,RectangleOutlineGeometry:()=>wA,ReferenceFrame:()=>ri,ReferenceProperty:()=>M0,RenderState:()=>he,Renderbuffer:()=>bh,RenderbufferFormat:()=>Sc,Request:()=>Zs,RequestErrorEvent:()=>yV,RequestScheduler:()=>xd,RequestState:()=>qi,RequestType:()=>Xl,Resource:()=>te,ResourceCache:()=>jo,ResourceCacheKey:()=>Ym,ResourceCacheStatistics:()=>sY,ResourceLoader:()=>Va,ResourceLoaderState:()=>pn,Rotation:()=>ru,RuntimeError:()=>St,S2Cell:()=>KR,SDFSettings:()=>Ar,SampledPositionProperty:()=>Bs,SampledProperty:()=>ql,Sampler:()=>Hn,ScaledPositionProperty:()=>vc,Scene:()=>s5,SceneFramebuffer:()=>FS,SceneMode:()=>ut,SceneMode2DPipelineStage:()=>wx,SceneModePicker:()=>vD,SceneModePickerViewModel:()=>PD,SceneTransforms:()=>qo,SceneTransitioner:()=>T9,ScreenSpaceCameraController:()=>C9,ScreenSpaceEventHandler:()=>sp,ScreenSpaceEventType:()=>Zi,SelectedFeatureIdPipelineStage:()=>oF,SelectionIndicator:()=>jD,SelectionIndicatorViewModel:()=>zD,Sensor:()=>oW,SensorVolumePortionToDisplay:()=>nI,SensorVolumes:()=>dot,SerializePosition:()=>g5,ShaderBuilder:()=>EG,ShaderCache:()=>$Q,ShaderDestination:()=>Xt,ShaderFunction:()=>d2,ShaderProgram:()=>xn,ShaderSource:()=>Ve,ShaderStruct:()=>r2,ShadowMap:()=>fW,ShadowMapShader:()=>Db,ShadowMode:()=>ui,ShadowVolumeAppearance:()=>Fh,ShowGeometryInstanceAttribute:()=>pi,Simon1994PlanetaryPositions:()=>_V,SimplePolylineGeometry:()=>clt,SingleTileImageryProvider:()=>HM,SkinningPipelineStage:()=>vx,SkyAtmosphere:()=>d5,SkyBox:()=>h5,SpaceCatalogDataSource:()=>BM,SpaceEntity:()=>oS,SpatialNode:()=>e5,SphereEmitter:()=>srt,SphereGeometry:()=>mlt,SphereOutlineGeometry:()=>g0,Spherical:()=>Oc,Spline:()=>ba,SplitDirection:()=>Jc,Splitter:()=>RN,StaticGeometryColorBatch:()=>mu,StaticGeometryPerMaterialBatch:()=>hu,StaticGroundGeometryColorBatch:()=>UI,StaticGroundGeometryPerMaterialBatch:()=>rL,StaticGroundPolylinePerMaterialBatch:()=>fL,StaticOutlineGeometryBatch:()=>TI,StencilConstants:()=>gn,StencilFunction:()=>Li,StencilOperation:()=>je,SteppedSpline:()=>NY,Stereographic:()=>vd,StripeMaterialProperty:()=>tI,StripeOrientation:()=>xZ,StructuralMetadata:()=>bd,StyleCommandsNeeded:()=>GZ,StyleExpression:()=>lrt,Sun:()=>R5,SunLight:()=>gR,SunPostProcess:()=>y9,SupportedImageFormats:()=>fY,SvgPathBindingHandler:()=>pD,TaskProcessor:()=>$i,Terrain:()=>lD,TerrainData:()=>nV,TerrainEncoding:()=>lc,TerrainFillMesh:()=>B1,TerrainMesh:()=>Au,TerrainOffsetProperty:()=>iA,TerrainProvider:()=>El,TerrainQuantization:()=>yr,TerrainState:()=>Ga,Texture:()=>hn,TextureAtlas:()=>dF,TextureCache:()=>t2,TextureMagnificationFilter:()=>bo,TextureManager:()=>i5,TextureMinificationFilter:()=>On,TextureUniform:()=>Art,TextureWrap:()=>Vi,TileAvailability:()=>pV,TileBoundingRegion:()=>eu,TileBoundingS2Cell:()=>PX,TileBoundingSphere:()=>E0,TileBoundingVolume:()=>rrt,TileCoordinatesImageryProvider:()=>dD,TileDiscardPolicy:()=>crt,TileEdge:()=>mi,TileImagery:()=>I1,TileMapServiceImageryProvider:()=>hU,TileMetadata:()=>_X,TileOrientedBoundingBox:()=>kh,TileProviderError:()=>za,TileReplacementQueue:()=>i_,TileSelectionResult:()=>Pi,TileState:()=>mrt,Tileset3DTileContent:()=>VX,TilesetMetadata:()=>vX,TilesetPipelineStage:()=>HY,TilingScheme:()=>hlt,TimeConstants:()=>xi,TimeDynamicImagery:()=>mS,TimeDynamicPointCloud:()=>UN,TimeInterval:()=>ai,TimeIntervalCollection:()=>ys,TimeIntervalCollectionPositionProperty:()=>_0,TimeIntervalCollectionProperty:()=>_m,TimeStandard:()=>Di,Timeline:()=>tO,TimelineHighlightRange:()=>qD,TimelineTrack:()=>$D,Tipsify:()=>j2,ToggleButtonViewModel:()=>YU,Tonemapper:()=>FU,Transforms:()=>Pe,TranslationRotationScale:()=>gf,TranslucentTileClassification:()=>q_,TridiagonalSystemSolver:()=>nC,TrustedServers:()=>eE,TweenCollection:()=>yS,UniformState:()=>o2,UniformType:()=>K1,UrlTemplateImageryProvider:()=>Ad,VERSION:()=>XDe,VRButton:()=>nO,VRButtonViewModel:()=>eO,VRTheWorldTerrainProvider:()=>plt,VaryingType:()=>Trt,Vector3DTileBatch:()=>vV,Vector3DTileClampedPolylines:()=>XX,Vector3DTileContent:()=>LX,Vector3DTileGeometry:()=>vR,Vector3DTilePoints:()=>NX,Vector3DTilePolygons:()=>yX,Vector3DTilePolylines:()=>_A,Vector3DTilePrimitive:()=>cA,VelocityOrientationProperty:()=>NJ,VelocityVectorProperty:()=>pT,VertexArray:()=>Ki,VertexArrayFacade:()=>CR,VertexAttributeSemantic:()=>sn,VertexFormat:()=>ee,VerticalExaggeration:()=>Ps,VerticalExaggerationPipelineStage:()=>zx,VerticalOrigin:()=>hi,VideoSynchronizer:()=>ult,View:()=>AS,Viewer:()=>Prt,ViewportQuad:()=>urt,Visibility:()=>Ys,Visualizer:()=>Vot,VoxelBoxShape:()=>Pb,VoxelCell:()=>k9,VoxelContent:()=>L5,VoxelCylinderShape:()=>vb,VoxelEllipsoidShape:()=>YS,VoxelInspector:()=>sO,VoxelInspectorViewModel:()=>aO,VoxelPrimitive:()=>TU,VoxelProvider:()=>Vrt,VoxelRenderResources:()=>z9,VoxelShape:()=>brt,VoxelShapeType:()=>_o,VoxelTraversal:()=>v1,VulkanConstants:()=>Zlt,WallGeometry:()=>oL,WallGeometryLibrary:()=>UT,WallGeometryUpdater:()=>lL,WallGraphics:()=>MR,WallOutlineGeometry:()=>sL,WasmPositionManager:()=>K0,WebGLConstants:()=>pt,WebMapServiceImageryProvider:()=>PM,WebMapTileServiceImageryProvider:()=>hS,WebMercatorProjection:()=>Yo,WebMercatorTilingScheme:()=>Gs,WindingOrder:()=>ws,WireframeIndexGenerator:()=>hC,WireframePipelineStage:()=>jx,_shadersAcesTonemappingStage:()=>t9,_shadersAdditiveBlend:()=>I9,_shadersAdjustTranslucentFS:()=>_1,_shadersAllMaterialAppearanceFS:()=>Z2,_shadersAllMaterialAppearanceVS:()=>V2,_shadersAmbientOcclusionGenerate:()=>e9,_shadersAmbientOcclusionModulate:()=>n9,_shadersAspectRampMaterial:()=>F2,_shadersAtmosphereCommon:()=>rW,_shadersAtmosphereStageFS:()=>wY,_shadersAtmosphereStageVS:()=>PY,_shadersBasicMaterialAppearanceFS:()=>b2,_shadersBasicMaterialAppearanceVS:()=>R2,_shadersBillboardCollectionFS:()=>bX,_shadersBillboardCollectionVS:()=>RX,_shadersBlackAndWhite:()=>i9,_shadersBloomComposite:()=>o9,_shadersBrdfLutGeneratorFS:()=>R_,_shadersBrightPass:()=>N9,_shadersBrightness:()=>a9,_shadersBumpMapMaterial:()=>U2,_shadersCPUStylingStageFS:()=>Rx,_shadersCPUStylingStageVS:()=>bx,_shadersCheckerboardMaterial:()=>G2,_shadersCloudCollectionFS:()=>f5,_shadersCloudCollectionVS:()=>F5,_shadersCloudNoiseFS:()=>U5,_shadersCloudNoiseVS:()=>G5,_shadersCompareAndPackTranslucentDepth:()=>j_,_shadersCompositeOITFS:()=>H_,_shadersCompositeTranslucentClassification:()=>GS,_shadersContrastBias:()=>s9,_shadersCustomShaderStageFS:()=>Fx,_shadersCustomShaderStageVS:()=>fx,_shadersCzmBuiltins:()=>TG,_shadersDepthOfField:()=>l9,_shadersDepthPlaneFS:()=>I_,_shadersDepthPlaneVS:()=>N_,_shadersDepthView:()=>r9,_shadersDepthViewPacked:()=>Grt,_shadersDotMaterial:()=>A2,_shadersEdgeDetection:()=>d9,_shadersElevationBandMaterial:()=>T2,_shadersElevationContourMaterial:()=>S2,_shadersElevationRampMaterial:()=>g2,_shadersEllipsoidFS:()=>k1,_shadersEllipsoidSurfaceAppearanceFS:()=>O5,_shadersEllipsoidSurfaceAppearanceVS:()=>H5,_shadersEllipsoidVS:()=>Y1,_shadersFXAA:()=>m9,_shadersFXAA3_11:()=>b9,_shadersFadeMaterial:()=>E2,_shadersFeatureIdStageFS:()=>Ux,_shadersFeatureIdStageVS:()=>Gx,_shadersFilmicTonemapping:()=>c9,_shadersGaussianBlur1D:()=>fU,_shadersGeometryStageFS:()=>Cx,_shadersGeometryStageVS:()=>Ix,_shadersGlobeFS:()=>kM,_shadersGlobeVS:()=>YM,_shadersGridMaterial:()=>C2,_shadersGroundAtmosphere:()=>W1,_shadersHSBToRGB:()=>uB,_shadersHSLToRGB:()=>ZB,_shadersImageBasedLightingStageFS:()=>KY,_shadersInstancingStageCommon:()=>sx,_shadersInstancingStageVS:()=>lx,_shadersIntersectBox:()=>_9,_shadersIntersectClippingPlanes:()=>M9,_shadersIntersectCylinder:()=>D9,_shadersIntersectDepth:()=>L9,_shadersIntersectEllipsoid:()=>O9,_shadersIntersectLongitude:()=>w1,_shadersIntersection:()=>kS,_shadersIntersectionUtils:()=>J9,_shadersLegacyInstancingStageVS:()=>rx,_shadersLensFlare:()=>h9,_shadersLightingStageFS:()=>Bx,_shadersMaterialStageFS:()=>kx,_shadersMegatexture:()=>K9,_shadersMetadataStageFS:()=>Ax,_shadersMetadataStageVS:()=>Tx,_shadersModelClippingPlanesStageFS:()=>tx,_shadersModelClippingPolygonsStageFS:()=>ix,_shadersModelClippingPolygonsStageVS:()=>nx,_shadersModelColorStageFS:()=>$Y,_shadersModelFS:()=>JY,_shadersModelSilhouetteStageFS:()=>nX,_shadersModelSilhouetteStageVS:()=>iX,_shadersModelSplitterStageFS:()=>aX,_shadersModelVS:()=>LY,_shadersModifiedReinhardTonemapping:()=>p9,_shadersMorphTargetsStageVS:()=>xx,_shadersNightVision:()=>u9,_shadersNormalMapMaterial:()=>I2,_shadersOctahedralProjectionAtlasFS:()=>Ik,_shadersOctahedralProjectionFS:()=>Nk,_shadersOctahedralProjectionVS:()=>yk,_shadersOctree:()=>v9,_shadersPassThrough:()=>nh,_shadersPassThroughDepth:()=>bU,_shadersPerInstanceColorAppearanceFS:()=>L2,_shadersPerInstanceColorAppearanceVS:()=>M2,_shadersPerInstanceFlatColorAppearanceFS:()=>yG,_shadersPerInstanceFlatColorAppearanceVS:()=>_2,_shadersPointCloudEyeDomeLighting:()=>FY,_shadersPointCloudStylingStageVS:()=>Lx,_shadersPointPrimitiveCollectionFS:()=>GF,_shadersPointPrimitiveCollectionVS:()=>FJ,_shadersPolygonSignedDistanceFS:()=>cY,_shadersPolylineArrowMaterial:()=>N2,_shadersPolylineColorAppearanceVS:()=>dk,_shadersPolylineCommon:()=>Uh,_shadersPolylineDashMaterial:()=>y2,_shadersPolylineFS:()=>HG,_shadersPolylineGlowMaterial:()=>B2,_shadersPolylineMaterialAppearanceVS:()=>ck,_shadersPolylineOutlineMaterial:()=>Q2,_shadersPolylineShadowVolumeFS:()=>ak,_shadersPolylineShadowVolumeMorphFS:()=>sk,_shadersPolylineShadowVolumeMorphVS:()=>lk,_shadersPolylineShadowVolumeVS:()=>rk,_shadersPolylineVS:()=>TX,_shadersPrimitiveOutlineStageFS:()=>Dx,_shadersPrimitiveOutlineStageVS:()=>_x,_shadersRGBToHSB:()=>VB,_shadersRGBToHSL:()=>bB,_shadersRGBToXYZ:()=>RB,_shadersReinhardTonemapping:()=>Z9,_shadersReprojectWebMercatorFS:()=>KM,_shadersReprojectWebMercatorVS:()=>zM,_shadersRimLightingMaterial:()=>k2,_shadersSelectedFeatureIdStageCommon:()=>mC,_shadersShadowVolumeAppearanceFS:()=>RE,_shadersShadowVolumeAppearanceVS:()=>P2,_shadersShadowVolumeFS:()=>Uf,_shadersSilhouette:()=>V9,_shadersSkinningStageVS:()=>Px,_shadersSkyAtmosphereCommon:()=>j1,_shadersSkyAtmosphereFS:()=>l5,_shadersSkyAtmosphereVS:()=>r5,_shadersSkyBoxFS:()=>c5,_shadersSkyBoxVS:()=>m5,_shadersSlopeRampMaterial:()=>Y2,_shadersStripeMaterial:()=>x2,_shadersSunFS:()=>p5,_shadersSunTextureFS:()=>u5,_shadersSunVS:()=>Z5,_shadersTexturedMaterialAppearanceFS:()=>W2,_shadersTexturedMaterialAppearanceVS:()=>f2,_shadersVector3DTileClampedPolylinesFS:()=>YX,_shadersVector3DTileClampedPolylinesVS:()=>kX,_shadersVector3DTilePolylinesVS:()=>BX,_shadersVectorTileVS:()=>CE,_shadersVerticalExaggerationStageVS:()=>Kx,_shadersViewportQuadFS:()=>A5,_shadersViewportQuadVS:()=>GG,_shadersVoxelFS:()=>x9,_shadersVoxelUtils:()=>Y9,_shadersVoxelVS:()=>X9,_shadersWater:()=>X2,_shadersXYZToRGB:()=>WB,_shadersacesTonemapping:()=>fB,_shadersalphaWeight:()=>FB,_shadersantialias:()=>UB,_shadersapplyHSBShift:()=>GB,_shadersapproximateSphericalCoordinates:()=>AB,_shadersapproximateTanh:()=>TB,_shadersbackFacing:()=>SB,_shadersbranchFreeTernary:()=>gB,_shaderscascadeColor:()=>EB,_shaderscascadeDistance:()=>CB,_shaderscascadeMatrix:()=>IB,_shaderscascadeWeights:()=>NB,_shadersclipPolygons:()=>yB,_shaderscolumbusViewMorph:()=>BB,_shaderscomputeAtmosphereColor:()=>QB,_shaderscomputeGroundAtmosphereScattering:()=>kB,_shaderscomputePosition:()=>YB,_shaderscomputeScattering:()=>xB,_shadersconvertUvToBox:()=>H9,_shadersconvertUvToCylinder:()=>w9,_shadersconvertUvToEllipsoid:()=>P9,_shaderscosineAndSine:()=>XB,_shadersdecompressTextureCoordinates:()=>JB,_shadersdefaultPbrMaterial:()=>LB,_shadersdegreesPerRadian:()=>Fy,_shadersdepthClamp:()=>MB,_shadersdepthRange:()=>Uy,_shadersdepthRangeStruct:()=>aB,_shaderseastNorthUpToEyeCoordinates:()=>_B,_shadersellipsoidContainsPoint:()=>DB,_shadersellipsoidWgs84TextureCoordinates:()=>OB,_shadersepsilon1:()=>Gy,_shadersepsilon2:()=>Ay,_shadersepsilon3:()=>Ty,_shadersepsilon4:()=>Sy,_shadersepsilon5:()=>gy,_shadersepsilon6:()=>Ey,_shadersepsilon7:()=>Cy,_shadersequalsEpsilon:()=>HB,_shaderseyeOffset:()=>wB,_shaderseyeToWindowCoordinates:()=>PB,_shadersfastApproximateAtan:()=>vB,_shadersfog:()=>KB,_shadersgammaCorrect:()=>zB,_shadersgeodeticSurfaceNormal:()=>jB,_shadersgetDefaultMaterial:()=>qB,_shadersgetDynamicAtmosphereLightDirection:()=>$B,_shadersgetLambertDiffuse:()=>tQ,_shadersgetSpecular:()=>eQ,_shadersgetWaterNoise:()=>nQ,_shadershue:()=>iQ,_shadersinfinity:()=>Iy,_shadersinverseGamma:()=>oQ,_shadersisEmpty:()=>aQ,_shadersisFull:()=>sQ,_shaderslatitudeToWebMercatorFraction:()=>lQ,_shaderslineDistance:()=>rQ,_shaderslinearToSrgb:()=>dQ,_shadersluminance:()=>cQ,_shadersmaterial:()=>sB,_shadersmaterialInput:()=>lB,_shadersmetersPerPixel:()=>mQ,_shadersmodelMaterial:()=>rB,_shadersmodelToWindowCoordinates:()=>hQ,_shadersmodelVertexOutput:()=>dB,_shadersmultiplyWithColorBalance:()=>pQ,_shadersnearFarScalar:()=>uQ,_shadersoctDecode:()=>ZQ,_shadersoneOverPi:()=>Ny,_shadersoneOverTwoPi:()=>yy,_shaderspackDepth:()=>VQ,_shaderspassCesium3DTile:()=>By,_shaderspassCesium3DTileClassification:()=>Qy,_shaderspassCesium3DTileClassificationIgnoreShow:()=>ky,_shaderspassClassification:()=>Yy,_shaderspassCompute:()=>xy,_shaderspassEnvironment:()=>Xy,_shaderspassGlobe:()=>Jy,_shaderspassOpaque:()=>Ly,_shaderspassOverlay:()=>My,_shaderspassTerrainClassification:()=>_y,_shaderspassTranslucent:()=>Dy,_shaderspassVoxels:()=>Oy,_shaderspbrLighting:()=>bQ,_shaderspbrMetallicRoughnessMaterial:()=>RQ,_shaderspbrParameters:()=>cB,_shaderspbrSpecularGlossinessMaterial:()=>WQ,_shadersphong:()=>fQ,_shaderspi:()=>Hy,_shaderspiOverFour:()=>wy,_shaderspiOverSix:()=>Py,_shaderspiOverThree:()=>vy,_shaderspiOverTwo:()=>Ky,_shadersplaneDistance:()=>FQ,_shaderspointAlongRay:()=>UQ,_shadersradiansPerDegree:()=>zy,_shadersray:()=>mB,_shadersrayEllipsoidIntersectionInterval:()=>GQ,_shadersraySegment:()=>hB,_shadersraySphereIntersectionInterval:()=>AQ,_shadersreadDepth:()=>TQ,_shadersreadNonPerspective:()=>SQ,_shadersreverseLogDepth:()=>gQ,_shadersround:()=>EQ,_shaderssampleOctahedralProjection:()=>CQ,_shaderssaturation:()=>IQ,_shaderssceneMode2D:()=>jy,_shaderssceneMode3D:()=>qy,_shaderssceneModeColumbusView:()=>$y,_shaderssceneModeMorphing:()=>tB,_shadersshadowDepthCompare:()=>NQ,_shadersshadowParameters:()=>pB,_shadersshadowVisibility:()=>yQ,_shaderssignNotZero:()=>BQ,_shaderssolarRadius:()=>eB,_shaderssphericalHarmonics:()=>QQ,_shaderssrgbToLinear:()=>kQ,_shaderstangentToEyeSpaceMatrix:()=>YQ,_shaderstextureCube:()=>xQ,_shadersthreePiOver2:()=>nB,_shaderstransformPlane:()=>XQ,_shaderstranslateRelativeToEye:()=>JQ,_shaderstranslucentPhong:()=>LQ,_shaderstranspose:()=>MQ,_shaderstwoPi:()=>iB,_shadersunpackClippingExtents:()=>_Q,_shadersunpackDepth:()=>DQ,_shadersunpackFloat:()=>OQ,_shadersunpackUint:()=>HQ,_shadersvalueTransform:()=>wQ,_shadersvertexLogDepth:()=>PQ,_shaderswebMercatorMaxLatitude:()=>oB,_shaderswindowToEyeCoordinates:()=>vQ,_shaderswriteDepthClamp:()=>KQ,_shaderswriteLogDepth:()=>zQ,_shaderswriteNonPerspective:()=>jQ,addBuffer:()=>zk,addDefaults:()=>_k,addExtensionsRequired:()=>Pk,addExtensionsUsed:()=>Xp,addPipelineExtras:()=>Jf,addToArray:()=>$l,appendForwardSlash:()=>$N,arrayRemoveDuplicates:()=>sa,barycentricCoordinates:()=>YG,binarySearch:()=>Ja,buildDrawCommand:()=>OY,buildModuleUrl:()=>Dn,buildVoxelDrawCommands:()=>q9,cesiumWorkerBootstrapperPackedStringBase64:()=>bot,clone:()=>be,combine:()=>ze,computeFlyToLocationForRectangle:()=>rg,computePositions:()=>qF,conic_sensor_graphics:()=>XT,conic_sensor_visualizer:()=>LT,createBillboardPointCallback:()=>XA,createCommand:()=>bi,createDefaultImageryProviderViewModels:()=>gD,createDefaultTerrainProviderViewModels:()=>ED,createElevationBandMaterial:()=>Wrt,createGooglePhotorealistic3DTileset:()=>frt,createGuid:()=>Si,createMaterialPropertyDescriptor:()=>la,createOsmBuildingsAsync:()=>Frt,createPropertyDescriptor:()=>ft,createRawPropertyDescriptor:()=>gm,createTangentSpaceDebugPrimitive:()=>Urt,createTaskProcessorWorker:()=>Srt,createUniform:()=>hy,createUniformArray:()=>py,createWorldBathymetryAsync:()=>B5,createWorldImageryAsync:()=>pW,createWorldTerrainAsync:()=>KS,custom_pattern_sensor_graphics:()=>_T,custom_pattern_sensor_visualizer:()=>DT,custom_sensor_volume:()=>KZ,custom_sensor_volume_fs_glsl:()=>PI,custom_sensor_volume_vs_glsl:()=>vI,decodeGoogleEarthEnterpriseData:()=>Q5,decodeVectorPolylinePositions:()=>JX,defaultValue:()=>f,defer:()=>kd,defined:()=>c,demodernizeShader:()=>qQ,deprecationWarning:()=>Zr,destroyObject:()=>At,exportKml:()=>Uot,findAccessorMinMax:()=>RA,findContentMetadata:()=>OA,findGroupMetadata:()=>HA,findTileMetadata:()=>DX,forEachTextureInMaterial:()=>XE,formatError:()=>Qb,freezeRenderState:()=>w6,getAbsoluteUri:()=>IV,getAccessorByteStride:()=>Qm,getBaseUri:()=>ty,getBinaryAccessor:()=>Eh,getClipAndStyleCode:()=>iD,getClippingFunction:()=>dW,getComponentReader:()=>e0,getElement:()=>Ui,getExtensionFromUri:()=>pG,getFilenameFromUri:()=>X0,getImageFromTypedArray:()=>n5,getImagePixels:()=>vu,getJsonFromTypedArray:()=>ts,getMagic:()=>mZ,getStringFromTypedArray:()=>Im,getTimestamp:()=>Oi,hasExtension:()=>co,heightReferenceOnEntityPropertyChanged:()=>DR,initialize:()=>KT,isBitSet:()=>Vc,isBlobUri:()=>uG,isCrossOriginUrl:()=>ZG,isDataUri:()=>fR,isLeapYear:()=>Pu,isPointIn2D:()=>lM,isPointIn3D:()=>rM,knockout:()=>Lt,knockout_3_5_1:()=>dg,knockout_es5:()=>hD,loadAndExecuteScript:()=>VG,loadCubeMap:()=>c2,loadImageFromTypedArray:()=>ZA,loadKTX2:()=>Fm,mergeSort:()=>ZW,moveTechniqueRenderStates:()=>wk,moveTechniquesToExtension:()=>vk,numberOfComponentsForType:()=>Ih,objectToQuery:()=>bG,oneTimeWarning:()=>Gn,parseBatchTable:()=>c0,parseFeatureMetadataLegacy:()=>RY,parseGlb:()=>Ok,parseResponseHeaders:()=>ey,parseStructuralMetadata:()=>bY,pickModel:()=>uC,pointInsideTriangle:()=>blt,preprocess3DTileContent:()=>db,processVoxelProperties:()=>j9,queryToObject:()=>Tc,readAccessorPacked:()=>jk,rectangular_pyramid_sensor_volume:()=>PT,rectangular_sensor_graphics:()=>HT,rectangular_sensor_visualizer:()=>vT,removeExtension:()=>WA,removeExtensionsRequired:()=>Dk,removeExtensionsUsed:()=>bA,removePipelineExtras:()=>Hk,removeUnusedElements:()=>Kk,remove_primitive:()=>ac,resizeImageToNextPowerOfTwo:()=>_f,sampleTerrain:()=>k5,sampleTerrainMostDetailed:()=>zS,scaleToGeodeticSurface:()=>hG,sensor_state:()=>JT,sensor_volume_glsl:()=>wI,srgbToLinear:()=>jS,subdivideArray:()=>v2,subscribeAndEvaluate:()=>od,transferTypedArrayTestSrc:()=>Got,updateAccessorComponentTypes:()=>qk,updateVersion:()=>$k,usesExtension:()=>Cs,viewerCSSMixin:()=>vrt,viewerCameraMixin:()=>Krt,viewerCesium3DTilesInspectorMixin:()=>zrt,viewerCesiumInspectorMixin:()=>jrt,viewerDragDropMixin:()=>$rt,viewerPerformanceWatchdogMixin:()=>tdt,viewerReferenceFrameMixin:()=>edt,viewerStorageMixin:()=>ndt,viewerVoxelInspectorMixin:()=>idt,webGLConstantToGlslType:()=>flt,wrapFunction:()=>Y5,writeTextToCanvas:()=>LA});var NSa=R(W(),1);var Uqo=R(W(),1);var JOe=R(W(),1);var dOe=R(W(),1);var jDe=R(W(),1);var ODe=R(W(),1);function WMt(t){return t!=null}var c=WMt;var PDe=R(W(),1);function cG(t){this.name="DeveloperError",this.message=t;let e;try{throw new Error}catch(n){e=n.stack}this.stack=e}c(Object.create)&&(cG.prototype=Object.create(Error.prototype),cG.prototype.constructor=cG);cG.prototype.toString=function(){let t=`${this.name}: ${this.message}`;return c(this.stack)&&(t+=` -${this.stack.toString()}`),t};cG.throwInstantiationError=function(){throw new cG("This function defines an interface and should not be called directly.")};var Ut=cG;var vl={};vl.typeOf={};function fMt(t){return`${t} is required, actual value was undefined`}function Hg(t,e,n){return`Expected ${n} to be typeof ${e}, actual typeof was ${t}`}vl.defined=function(t,e){if(!c(e))throw new Ut(fMt(t))};vl.typeOf.func=function(t,e){if(typeof e!="function")throw new Ut(Hg(typeof e,"function",t))};vl.typeOf.string=function(t,e){if(typeof e!="string")throw new Ut(Hg(typeof e,"string",t))};vl.typeOf.number=function(t,e){if(typeof e!="number")throw new Ut(Hg(typeof e,"number",t))};vl.typeOf.number.lessThan=function(t,e,n){if(vl.typeOf.number(t,e),e>=n)throw new Ut(`Expected ${t} to be less than ${n}, actual value was ${e}`)};vl.typeOf.number.lessThanOrEquals=function(t,e,n){if(vl.typeOf.number(t,e),e>n)throw new Ut(`Expected ${t} to be less than or equal to ${n}, actual value was ${e}`)};vl.typeOf.number.greaterThan=function(t,e,n){if(vl.typeOf.number(t,e),e<=n)throw new Ut(`Expected ${t} to be greater than ${n}, actual value was ${e}`)};vl.typeOf.number.greaterThanOrEquals=function(t,e,n){if(vl.typeOf.number(t,e),e0?1:-1});Me.signNotZero=function(t){return t<0?-1:1};Me.toSNorm=function(t,e){return e=f(e,255),Math.round((Me.clamp(t,-1,1)*.5+.5)*e)};Me.fromSNorm=function(t,e){return e=f(e,255),Me.clamp(t,0,e)/e*2-1};Me.normalize=function(t,e,n){return n=Math.max(n-e,0),n===0?0:Me.clamp((t-e)/n,0,1)};Me.sinh=f(Math.sinh,function(e){return(Math.exp(e)-Math.exp(-e))/2});Me.cosh=f(Math.cosh,function(e){return(Math.exp(e)+Math.exp(-e))/2});Me.lerp=function(t,e,n){return(1-n)*t+n*e};Me.PI=Math.PI;Me.ONE_OVER_PI=1/Math.PI;Me.PI_OVER_TWO=Math.PI/2;Me.PI_OVER_THREE=Math.PI/3;Me.PI_OVER_FOUR=Math.PI/4;Me.PI_OVER_SIX=Math.PI/6;Me.THREE_PI_OVER_TWO=3*Math.PI/2;Me.TWO_PI=2*Math.PI;Me.ONE_OVER_TWO_PI=1/(2*Math.PI);Me.RADIANS_PER_DEGREE=Math.PI/180;Me.DEGREES_PER_RADIAN=180/Math.PI;Me.RADIANS_PER_ARCSECOND=Me.RADIANS_PER_DEGREE/3600;Me.toRadians=function(t){return t*Me.RADIANS_PER_DEGREE};Me.toDegrees=function(t){return t*Me.DEGREES_PER_RADIAN};Me.convertLongitudeRange=function(t){let e=Me.TWO_PI,n=t-Math.floor(t/e)*e;return n<-Math.PI?n+e:n>=Math.PI?n-e:n};Me.clampToLatitudeRange=function(t){return Me.clamp(t,-1*Me.PI_OVER_TWO,Me.PI_OVER_TWO)};Me.negativePiToPi=function(t){return t>=-Me.PI&&t<=Me.PI?t:Me.zeroToTwoPi(t+Me.PI)-Me.PI};Me.zeroToTwoPi=function(t){if(t>=0&&t<=Me.TWO_PI)return t;let e=Me.mod(t,Me.TWO_PI);return Math.abs(e)Me.EPSILON14?Me.TWO_PI:e};Me.mod=function(t,e){return Me.sign(t)===Me.sign(e)&&Math.abs(t)n};Me.greaterThanOrEquals=function(t,e,n){return t-e>-n};var zO=[1];Me.factorial=function(t){let e=zO.length;if(t>=e){let n=zO[e-1];for(let i=e;i<=t;i++){let o=n*i;zO.push(o),n=o}}return zO[t]};Me.incrementWrap=function(t,e,n){return n=f(n,0),++t,t>e&&(t=n),t};Me.isPowerOfTwo=function(t){return t!==0&&(t&t-1)===0};Me.nextPowerOfTwo=function(t){return--t,t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,++t,t};Me.previousPowerOfTwo=function(t){return t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,t|=t>>32,t=(t>>>0)-(t>>>1),t};Me.clamp=function(t,e,n){return tn?n:t};var Pct=new t6.default;Me.setRandomNumberSeed=function(t){Pct=new t6.default(t)};Me.nextRandomNumber=function(){return Pct.random()};Me.randomBetween=function(t,e){return Me.nextRandomNumber()*(e-t)+t};Me.acosClamped=function(t){return Math.acos(Me.clamp(t,-1,1))};Me.asinClamped=function(t){return Math.asin(Me.clamp(t,-1,1))};Me.chordLength=function(t,e){return 2*e*Math.sin(t*.5)};Me.logBase=function(t,e){return Math.log(t)/Math.log(e)};Me.cbrt=f(Math.cbrt,function(e){let n=Math.pow(Math.abs(e),.3333333333333333);return e<0?-n:n});Me.log2=f(Math.log2,function(e){return Math.log(e)*Math.LOG2E});Me.fog=function(t,e){let n=t*e;return 1-Math.exp(-(n*n))};Me.fastApproximateAtan=function(t){return t*(-.1784*Math.abs(t)-.0663*t*t+1.0301)};Me.fastApproximateAtan2=function(t,e){let n,i=Math.abs(t);n=Math.abs(e);let o=Math.max(i,n);n=Math.min(i,n);let a=n/o;return i=Me.fastApproximateAtan(a),i=Math.abs(e)>Math.abs(t)?Me.PI_OVER_TWO-i:i,i=t<0?Me.PI-i:i,i=e<0?-i:i,i};var k=Me;function Ie(t,e,n){this.x=f(t,0),this.y=f(e,0),this.z=f(n,0)}Ie.fromSpherical=function(t,e){c(e)||(e=new Ie);let n=t.clock,i=t.cone,o=f(t.magnitude,1),a=o*Math.sin(i);return e.x=a*Math.cos(n),e.y=a*Math.sin(n),e.z=o*Math.cos(i),e};Ie.fromElements=function(t,e,n,i){return c(i)?(i.x=t,i.y=e,i.z=n,i):new Ie(t,e,n)};Ie.clone=function(t,e){if(c(t))return c(e)?(e.x=t.x,e.y=t.y,e.z=t.z,e):new Ie(t.x,t.y,t.z)};Ie.fromCartesian4=Ie.clone;Ie.packedLength=3;Ie.pack=function(t,e,n){return n=f(n,0),e[n++]=t.x,e[n++]=t.y,e[n]=t.z,e};Ie.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Ie),n.x=t[e++],n.y=t[e++],n.z=t[e],n};Ie.packArray=function(t,e){let n=t.length,i=n*3;c(e)?!Array.isArray(e)&&e.length!==i||e.length!==i&&(e.length=i):e=new Array(i);for(let o=0;oi&&(o=d,i=m)}let a=1,s=0,l=o6[o],r=a6[o];if(Math.abs(t[Ne.getElementIndex(r,l)])>n){let d=t[Ne.getElementIndex(r,r)],m=t[Ne.getElementIndex(l,l)],h=t[Ne.getElementIndex(r,l)],Z=(d-m)/2/h,b;Z<0?b=-1/(-Z+Math.sqrt(1+Z*Z)):b=1/(Z+Math.sqrt(1+Z*Z)),a=1/Math.sqrt(1+b*b),s=b*a}return e=Ne.clone(Ne.IDENTITY,e),e[Ne.getElementIndex(l,l)]=e[Ne.getElementIndex(r,r)]=a,e[Ne.getElementIndex(r,l)]=s,e[Ne.getElementIndex(l,r)]=-s,e}var tH=new Ne,qct=new Ne;Ne.computeEigenDecomposition=function(t,e){let n=k.EPSILON20,i=10,o=0,a=0;c(e)||(e={});let s=e.unitary=Ne.clone(Ne.IDENTITY,e.unitary),l=e.diagonal=Ne.clone(t,e.diagonal),r=n*IMt(l);for(;ar;)yMt(l,tH),Ne.transpose(tH,qct),Ne.multiply(l,tH,l),Ne.multiply(qct,l,l),Ne.multiply(s,tH,s),++o>2&&(++a,o=0);return e};Ne.abs=function(t,e){return e[0]=Math.abs(t[0]),e[1]=Math.abs(t[1]),e[2]=Math.abs(t[2]),e[3]=Math.abs(t[3]),e[4]=Math.abs(t[4]),e[5]=Math.abs(t[5]),e[6]=Math.abs(t[6]),e[7]=Math.abs(t[7]),e[8]=Math.abs(t[8]),e};Ne.determinant=function(t){let e=t[0],n=t[3],i=t[6],o=t[1],a=t[4],s=t[7],l=t[2],r=t[5],d=t[8];return e*(a*d-r*s)+o*(r*i-n*d)+l*(n*s-a*i)};Ne.inverse=function(t,e){let n=t[0],i=t[1],o=t[2],a=t[3],s=t[4],l=t[5],r=t[6],d=t[7],m=t[8],h=Ne.determinant(t);e[0]=s*m-d*l,e[1]=d*o-i*m,e[2]=i*l-s*o,e[3]=r*l-a*m,e[4]=n*m-r*o,e[5]=a*o-n*l,e[6]=a*d-r*s,e[7]=r*i-n*d,e[8]=n*s-a*i;let Z=1/h;return Ne.multiplyByScalar(e,Z,e)};var BMt=new Ne;Ne.inverseTranspose=function(t,e){return Ne.inverse(Ne.transpose(t,BMt),e)};Ne.equals=function(t,e){return t===e||c(t)&&c(e)&&t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]&&t[4]===e[4]&&t[5]===e[5]&&t[6]===e[6]&&t[7]===e[7]&&t[8]===e[8]};Ne.equalsEpsilon=function(t,e,n){return n=f(n,0),t===e||c(t)&&c(e)&&Math.abs(t[0]-e[0])<=n&&Math.abs(t[1]-e[1])<=n&&Math.abs(t[2]-e[2])<=n&&Math.abs(t[3]-e[3])<=n&&Math.abs(t[4]-e[4])<=n&&Math.abs(t[5]-e[5])<=n&&Math.abs(t[6]-e[6])<=n&&Math.abs(t[7]-e[7])<=n&&Math.abs(t[8]-e[8])<=n};Ne.IDENTITY=Object.freeze(new Ne(1,0,0,0,1,0,0,0,1));Ne.ZERO=Object.freeze(new Ne(0,0,0,0,0,0,0,0,0));Ne.COLUMN0ROW0=0;Ne.COLUMN0ROW1=1;Ne.COLUMN0ROW2=2;Ne.COLUMN1ROW0=3;Ne.COLUMN1ROW1=4;Ne.COLUMN1ROW2=5;Ne.COLUMN2ROW0=6;Ne.COLUMN2ROW1=7;Ne.COLUMN2ROW2=8;Object.defineProperties(Ne.prototype,{length:{get:function(){return Ne.packedLength}}});Ne.prototype.clone=function(t){return Ne.clone(this,t)};Ne.prototype.equals=function(t){return Ne.equals(this,t)};Ne.equalsArray=function(t,e,n){return t[0]===e[n]&&t[1]===e[n+1]&&t[2]===e[n+2]&&t[3]===e[n+3]&&t[4]===e[n+4]&&t[5]===e[n+5]&&t[6]===e[n+6]&&t[7]===e[n+7]&&t[8]===e[n+8]};Ne.prototype.equalsEpsilon=function(t,e){return Ne.equalsEpsilon(this,t,e)};Ne.prototype.toString=function(){return`(${this[0]}, ${this[3]}, ${this[6]}) + `),window.clearInterval(this.noSleepTimer),this.noSleepTimer=null):this.noSleepVideo.pause(),this.enabled=!1}};x2t.exports=Hrt});var JDe={};vO(JDe,{AlphaMode:()=>qZ,AlphaPipelineStage:()=>Vx,Analysis:()=>x1,Animation:()=>GD,AnimationViewModel:()=>AD,Appearance:()=>Va,ApproximateTerrainHeights:()=>Vo,ArcGISTiledElevationTerrainProvider:()=>Tst,ArcGisBaseMapType:()=>oZ,ArcGisMapServerImageryProvider:()=>cW,ArcGisMapService:()=>tp,ArcType:()=>Ln,ArticulationStageType:()=>zd,AssociativeArray:()=>qe,Atmosphere:()=>R_,AtmospherePipelineStage:()=>vY,AttributeCompression:()=>Ni,AttributeType:()=>_n,AutoExposure:()=>b9,AutomaticUniforms:()=>Rb,Axis:()=>$a,AxisAlignedBoundingBox:()=>Ff,B3dmLoader:()=>TY,B3dmParser:()=>GY,BaseLayerPicker:()=>TD,BaseLayerPickerViewModel:()=>SD,BatchTable:()=>kG,BatchTableHierarchy:()=>lA,BatchTexture:()=>Yc,BatchTexturePipelineStage:()=>ux,Billboard:()=>Na,BillboardCollection:()=>yh,BillboardGraphics:()=>Mr,BillboardVisualizer:()=>hk,BingMapsGeocoderService:()=>Est,BingMapsImageryProvider:()=>LM,BingMapsStyle:()=>U1,BlendEquation:()=>pd,BlendFunction:()=>Ha,BlendOption:()=>wa,BlendingState:()=>Pn,BoundingRectangle:()=>Fe,BoundingSphere:()=>Ft,BoundingSphereState:()=>ve,BoundingVolumeSemantics:()=>AA,BoxEmitter:()=>Ult,BoxGeometry:()=>Am,BoxGeometryUpdater:()=>C2,BoxGraphics:()=>PG,BoxOutlineGeometry:()=>tu,BrdfLutGenerator:()=>f_,Buffer:()=>we,BufferLoader:()=>pA,BufferUsage:()=>ce,CPUStylingPipelineStage:()=>Wx,CallbackProperty:()=>Sh,Camera:()=>Aa,CameraEventAggregator:()=>T9,CameraEventType:()=>Mo,CameraFlightPath:()=>U_,Cartesian2:()=>K,Cartesian3:()=>p,Cartesian4:()=>bt,Cartographic:()=>gt,CartographicGeocoderService:()=>Ist,CatmullRomSpline:()=>Nst,Cesium3DContentGroup:()=>sA,Cesium3DTile:()=>iV,Cesium3DTileBatchTable:()=>wb,Cesium3DTileColorBlendMode:()=>Nm,Cesium3DTileContent:()=>Glt,Cesium3DTileContentFactory:()=>DA,Cesium3DTileContentState:()=>rs,Cesium3DTileContentType:()=>nr,Cesium3DTileFeature:()=>Fr,Cesium3DTileFeatureTable:()=>Fu,Cesium3DTileOptimizationHint:()=>jp,Cesium3DTileOptimizations:()=>KX,Cesium3DTilePass:()=>ns,Cesium3DTilePassState:()=>EV,Cesium3DTilePointFeature:()=>R0,Cesium3DTileRefine:()=>ss,Cesium3DTileStyle:()=>qT,Cesium3DTileStyleEngine:()=>eJ,Cesium3DTilesInspector:()=>fD,Cesium3DTilesInspectorViewModel:()=>WD,Cesium3DTilesVoxelProvider:()=>Alt,Cesium3DTileset:()=>Pr,Cesium3DTilesetBaseTraversal:()=>lJ,Cesium3DTilesetCache:()=>qX,Cesium3DTilesetGraphics:()=>tA,Cesium3DTilesetHeatmap:()=>$X,Cesium3DTilesetMetadata:()=>$A,Cesium3DTilesetMostDetailedTraversal:()=>oJ,Cesium3DTilesetSkipTraversal:()=>cJ,Cesium3DTilesetStatistics:()=>N0,Cesium3DTilesetTraversal:()=>Tr,Cesium3DTilesetVisualizer:()=>mJ,CesiumInspector:()=>ND,CesiumInspectorViewModel:()=>ID,CesiumTerrainProvider:()=>HT,CesiumWidget:()=>W5,Check:()=>Xa,CheckerboardMaterialProperty:()=>yC,CircleEmitter:()=>M5,CircleGeometry:()=>xst,CircleOutlineGeometry:()=>Xst,ClassificationModelDrawCommand:()=>_Y,ClassificationPipelineStage:()=>Zx,ClassificationPrimitive:()=>fE,ClassificationType:()=>Ji,ClassifyOrbit:()=>_tt,ClearCommand:()=>ao,ClippingPlane:()=>SA,ClippingPlaneCollection:()=>Ml,ClippingPolygon:()=>KE,ClippingPolygonCollection:()=>bu,Clock:()=>ku,ClockRange:()=>pl,ClockSpeedUp:()=>Jst,ClockStep:()=>ya,ClockViewModel:()=>uD,CloudCollection:()=>Ilt,CloudType:()=>mN,Color:()=>v,ColorBlendMode:()=>Kd,ColorGeometryInstanceAttribute:()=>En,ColorMaterialProperty:()=>Cn,Command:()=>Crt,ComponentDatatype:()=>it,Composite3DTileContent:()=>Y2,CompositeEntityCollection:()=>Ott,CompositeMaterialProperty:()=>QC,CompositePositionProperty:()=>cl,CompositeProperty:()=>ec,CompressedTextureBuffer:()=>Ry,ComputeCommand:()=>Wm,ComputeEngine:()=>uy,ConditionsExpression:()=>x5,ConeEmitter:()=>ylt,ConjunctionAssessmentTask:()=>Mst,ConstantPositionProperty:()=>jl,ConstantProperty:()=>Ii,ConstantSpline:()=>IY,ContentMetadata:()=>MX,Context:()=>ak,ContextLimits:()=>Tn,CoplanarPolygonGeometry:()=>HJ,CoplanarPolygonGeometryLibrary:()=>S0,CoplanarPolygonOutlineGeometry:()=>nV,CornerType:()=>Xo,CorridorGeometry:()=>aS,CorridorGeometryLibrary:()=>Po,CorridorGeometryUpdater:()=>fJ,CorridorGraphics:()=>KG,CorridorOutlineGeometry:()=>WJ,CoverageGroupDataSource:()=>TJ,CoveragePolygonGeometry:()=>PJ,CoveragePolygonGeometryLibrary:()=>hI,Credit:()=>on,CreditDisplay:()=>T_,CubeMap:()=>Ld,CubeMapFace:()=>XZ,CubicRealPolynomial:()=>BG,CullFace:()=>so,CullingVolume:()=>Jl,CumulusCloud:()=>hp,CustomDataSource:()=>hR,CustomHeightmapTerrainProvider:()=>_st,CustomShader:()=>JT,CustomShaderMode:()=>u0,CustomShaderPipelineStage:()=>Tx,CustomShaderTranslucencyMode:()=>iF,CylinderGeometry:()=>gJ,CylinderGeometryLibrary:()=>sS,CylinderGeometryUpdater:()=>CJ,CylinderGraphics:()=>zG,CylinderOutlineGeometry:()=>EJ,CzmlDataSource:()=>O0,DataSource:()=>ml,DataSourceClock:()=>Yu,DataSourceCollection:()=>YJ,DataSourceDisplay:()=>kF,DebugAppearance:()=>Blt,DebugCameraPrimitive:()=>JR,DebugInspector:()=>Q9,DebugModelMatrixPrimitive:()=>D5,DefaultProxy:()=>Dst,DepthFunction:()=>_d,DepthPlane:()=>Q_,DequantizationPipelineStage:()=>Ex,DerivedCommand:()=>ZW,DeveloperError:()=>Ut,DeviceOrientationCameraController:()=>Y_,DirectionalLight:()=>Qlt,DiscardEmptyTileImagePolicy:()=>G1,DiscardMissingTileImagePolicy:()=>XM,DistanceDisplayCondition:()=>Wn,DistanceDisplayConditionGeometryInstanceAttribute:()=>Xi,DoubleEndedPriorityQueue:()=>xT,DoublyLinkedList:()=>jX,DracoLoader:()=>$b,DrawCommand:()=>Ee,DynamicAtmosphereLightingType:()=>VT,DynamicGeometryBatch:()=>uS,DynamicGeometryUpdater:()=>lo,EarthOrientationParameters:()=>ly,EarthOrientationParametersSample:()=>lf,EasingFunction:()=>ul,EllipseGeometry:()=>Pc,EllipseGeometryLibrary:()=>Om,EllipseGeometryUpdater:()=>XJ,EllipseGraphics:()=>jG,EllipseOutlineGeometry:()=>Lh,Ellipsoid:()=>mt,EllipsoidGeodesic:()=>ou,EllipsoidGeometry:()=>Cr,EllipsoidGeometryUpdater:()=>LJ,EllipsoidGraphics:()=>qG,EllipsoidOutlineGeometry:()=>Qh,EllipsoidPrimitive:()=>h_,EllipsoidRhumbLine:()=>Vd,EllipsoidSurfaceAppearance:()=>klt,EllipsoidTangentPlane:()=>Fl,EllipsoidTerrainProvider:()=>bV,EllipsoidalOccluder:()=>Bu,EmbeddedTileServiceImageryProvider:()=>Ylt,Empty3DTileContent:()=>WC,EncodedCartesian3:()=>Mi,Entity:()=>qa,EntityCluster:()=>Yh,EntityCollection:()=>gr,EntityView:()=>AL,Event:()=>It,EventHelper:()=>rl,Expression:()=>xp,ExpressionNodeType:()=>tn,ExternalData:()=>y6,ExtrapolationType:()=>Ah,FeatureDetection:()=>In,FeatureIdPipelineStage:()=>nF,FlatbufferUtilities:()=>a1,Fog:()=>x_,ForEach:()=>ne,FrameRateMonitor:()=>P5,FrameState:()=>X_,Framebuffer:()=>Lr,FramebufferManager:()=>bo,FrustumCommands:()=>__,FrustumGeometry:()=>ZT,FrustumOutlineGeometry:()=>C_,Fullscreen:()=>Ds,FullscreenButton:()=>BD,FullscreenButtonViewModel:()=>yD,GenerateAccessReport:()=>Ost,GeoJsonDataSource:()=>gL,GeoJsonLoader:()=>gY,GeocodeType:()=>IU,Geocoder:()=>kD,GeocoderService:()=>sN,GeocoderViewModel:()=>QD,GeographicProjection:()=>yo,GeographicTilingScheme:()=>Qo,Geometry:()=>_e,Geometry3DTileContent:()=>X2,GeometryAttribute:()=>jt,GeometryAttributes:()=>ei,GeometryFactory:()=>Hst,GeometryInstance:()=>$e,GeometryInstanceAttribute:()=>Dd,GeometryOffsetAttribute:()=>zn,GeometryPipeline:()=>gi,GeometryPipelineStage:()=>yx,GeometryType:()=>gp,GeometryUpdater:()=>ro,GeometryUpdaterSet:()=>gS,GeometryVisualizer:()=>dL,GetFeatureInfoFormat:()=>cT,Globe:()=>r_,GlobeDepth:()=>D_,GlobeSurfaceShaderSet:()=>xM,GlobeSurfaceTile:()=>SV,GlobeSurfaceTileProvider:()=>qM,GlobeTranslucency:()=>$M,GlobeTranslucencyFramebuffer:()=>O_,GlobeTranslucencyState:()=>J_,GltfBufferViewLoader:()=>QE,GltfDracoLoader:()=>kE,GltfImageLoader:()=>YE,GltfIndexBufferLoader:()=>xE,GltfJsonLoader:()=>JE,GltfLoader:()=>s0,GltfLoaderUtil:()=>km,GltfStructuralMetadataLoader:()=>WY,GltfTextureLoader:()=>LE,GltfVertexBufferLoader:()=>ME,GoogleEarthEnterpriseImageryProvider:()=>Xlt,GoogleEarthEnterpriseMapsProvider:()=>DM,GoogleEarthEnterpriseMetadata:()=>EW,GoogleEarthEnterpriseTerrainData:()=>lN,GoogleEarthEnterpriseTerrainProvider:()=>$st,GoogleEarthEnterpriseTileInformation:()=>E5,GoogleMaps:()=>PT,GpxDataSource:()=>NL,GregorianDate:()=>Wb,GridImageryProvider:()=>Jlt,GridMaterialProperty:()=>OC,GroundGeometryUpdater:()=>_i,GroundPolylineGeometry:()=>kb,GroundPolylinePrimitive:()=>Gh,GroundPrimitive:()=>Nc,GroupMetadata:()=>CC,HeadingPitchRange:()=>uV,HeadingPitchRoll:()=>Jr,Heap:()=>iy,HeightReference:()=>Ge,HeightmapEncoding:()=>UV,HeightmapTerrainData:()=>Gd,HeightmapTessellator:()=>R1,HermitePolynomialApproximation:()=>rS,HermiteSpline:()=>$f,HilbertOrder:()=>IE,HomeButton:()=>xD,HomeButtonViewModel:()=>YD,HorizontalOrigin:()=>to,I3SBuildingSceneLayerExplorer:()=>Xrt,I3SBuildingSceneLayerExplorerViewModel:()=>XD,I3SDataProvider:()=>bZ,I3SDecoder:()=>v5,I3SFeature:()=>K5,I3SField:()=>z5,I3SGeometry:()=>hN,I3SLayer:()=>ig,I3SNode:()=>pN,I3SStatistics:()=>$5,I3SSublayer:()=>eD,I3SSymbology:()=>q5,I3dmLoader:()=>CY,I3dmParser:()=>EY,Iau2000Orientation:()=>c_,Iau2006XysData:()=>cy,Iau2006XysSample:()=>UG,IauOrientationAxes:()=>m_,IauOrientationParameters:()=>d_,ImageBasedLighting:()=>aA,ImageBasedLightingPipelineStage:()=>zY,ImageMaterialProperty:()=>Tf,Imagery:()=>C1,ImageryLayer:()=>$r,ImageryLayerCollection:()=>t_,ImageryLayerFeatureInfo:()=>iZ,ImageryProvider:()=>$c,ImageryState:()=>ho,Implicit3DTileContent:()=>DE,ImplicitAvailabilityBitstream:()=>yE,ImplicitMetadataView:()=>BE,ImplicitSubdivisionScheme:()=>Al,ImplicitSubtree:()=>UA,ImplicitSubtreeCache:()=>J5,ImplicitSubtreeMetadata:()=>J2,ImplicitTileCoordinates:()=>nS,ImplicitTileset:()=>eS,IndexDatatype:()=>re,InfoBox:()=>LD,InfoBoxViewModel:()=>JD,InspectorShared:()=>gd,InstanceAttributeSemantic:()=>Tl,InstancingPipelineStage:()=>cx,InterpolationAlgorithm:()=>tlt,InterpolationType:()=>Wu,Intersect:()=>yn,IntersectionTests:()=>no,Intersections2D:()=>TW,Interval:()=>hd,InvertClassification:()=>M1,Ion:()=>cu,IonGeocoderService:()=>N5,IonImageryProvider:()=>mW,IonResource:()=>gh,IonWorldImageryStyle:()=>hW,Iso8601:()=>be,JobScheduler:()=>L_,JobType:()=>Zd,JsonMetadataTable:()=>o0,JulianDate:()=>rt,KTX2Transcoder:()=>by,KeyboardEventModifier:()=>id,KeyframeNode:()=>ra,KmlCamera:()=>yL,KmlDataSource:()=>iM,KmlLookAt:()=>zL,KmlTour:()=>jL,KmlTourFlyTo:()=>$L,KmlTourWait:()=>tM,Label:()=>cF,LabelCollection:()=>sR,LabelGraphics:()=>au,LabelStyle:()=>Pa,LabelVisualizer:()=>cL,LagrangePolynomialApproximation:()=>dS,LatLonGrid:()=>Pit,LeapSecond:()=>zo,Light:()=>Dlt,LightingModel:()=>nR,LightingPipelineStage:()=>Qx,LinearApproximation:()=>_b,LinearSpline:()=>qf,MakeBillboardLabel:()=>Olt,ManagedArray:()=>kc,MapMode2D:()=>eh,MapProjection:()=>ilt,MapboxImageryProvider:()=>OM,MapboxStyleImageryProvider:()=>Hlt,Material:()=>eo,MaterialAppearance:()=>Fa,MaterialPipelineStage:()=>Yx,MaterialProperty:()=>Ua,Math:()=>k,Matrix2:()=>pa,Matrix3:()=>ot,Matrix4:()=>L,Megatexture:()=>P1,MetadataClass:()=>Vu,MetadataClassProperty:()=>kf,MetadataComponentType:()=>vn,MetadataEntity:()=>Yi,MetadataEnum:()=>nY,MetadataEnumValue:()=>eY,MetadataPipelineStage:()=>_p,MetadataSchema:()=>uu,MetadataSchemaLoader:()=>_E,MetadataSemantic:()=>GA,MetadataTable:()=>Bm,MetadataTableProperty:()=>M2,MetadataType:()=>Nn,MipmapHint:()=>JZ,Model:()=>Au,Model3DTileContent:()=>iR,ModelAlphaOptions:()=>tX,ModelAnimation:()=>QY,ModelAnimationChannel:()=>BY,ModelAnimationCollection:()=>kY,ModelAnimationLoop:()=>xm,ModelAnimationState:()=>Uu,ModelArticulation:()=>qY,ModelArticulationStage:()=>jY,ModelClippingPlanesPipelineStage:()=>ex,ModelClippingPolygonsPipelineStage:()=>ox,ModelColorPipelineStage:()=>eF,ModelComponents:()=>Sn,ModelDrawCommand:()=>DY,ModelFeature:()=>YY,ModelFeatureTable:()=>XY,ModelGraphics:()=>Jb,ModelLightingOptions:()=>rX,ModelMatrixUpdateStage:()=>mx,ModelNode:()=>ax,ModelRenderResources:()=>eX,ModelRuntimeNode:()=>px,ModelRuntimePrimitive:()=>qx,ModelSceneGraph:()=>cX,ModelSilhouettePipelineStage:()=>oX,ModelSkin:()=>$x,ModelSplitterPipelineStage:()=>sX,ModelStatistics:()=>mX,ModelType:()=>Is,ModelUtility:()=>Mn,ModelVisualizer:()=>mL,Moon:()=>V_,MorphTargetsPipelineStage:()=>Xx,MorphWeightSpline:()=>olt,MortonOrder:()=>ZF,Multiple3DTileContent:()=>OX,MultisampleFramebuffer:()=>sk,NavigationHelpButton:()=>_D,NavigationHelpButtonViewModel:()=>MD,NearFarScalar:()=>ln,NeverTileDiscardPolicy:()=>Plt,NodeRenderResources:()=>lX,NodeStatisticsPipelineStage:()=>hx,NodeTransformationProperty:()=>$G,OIT:()=>w_,Occluder:()=>u_,OctahedralProjectedCubeMap:()=>du,OffsetGeometryInstanceAttribute:()=>aa,OpenCageGeocoderService:()=>slt,OpenStreetMapImageryProvider:()=>IW,OrderedGroundPrimitiveCollection:()=>xJ,OrientedBoundingBox:()=>ci,OrthographicFrustum:()=>wn,OrthographicOffCenterFrustum:()=>el,Packable:()=>llt,PackableForInterpolation:()=>rlt,Particle:()=>ZN,ParticleBurst:()=>Klt,ParticleEmitter:()=>zlt,ParticleSystem:()=>jlt,Pass:()=>Pt,PassState:()=>Md,PathGraphics:()=>Lb,PathVisualizer:()=>VL,PeliasGeocoderService:()=>I5,PerInstanceColorAppearance:()=>jn,PerformanceDisplay:()=>RW,PerformanceWatchdog:()=>OD,PerformanceWatchdogViewModel:()=>DD,PerspectiveFrustum:()=>Io,PerspectiveOffCenterFrustum:()=>em,PickDepth:()=>M_,PickDepthFramebuffer:()=>v_,PickFramebuffer:()=>z_,Picking:()=>$_,PickingPipelineStage:()=>Jx,PinBuilder:()=>q0,PixelDatatype:()=>Ue,PixelFormat:()=>Ye,Plane:()=>Kn,PlaneGeometry:()=>MJ,PlaneGeometryUpdater:()=>DJ,PlaneGraphics:()=>U2,PlaneOutlineGeometry:()=>_J,PlanetImageryProvider:()=>qlt,PntsLoader:()=>pX,PntsParser:()=>xA,PointCloud:()=>aD,PointCloudEyeDomeLighting:()=>l0,PointCloudShading:()=>eR,PointCloudStylingPipelineStage:()=>Mx,PointGraphics:()=>eA,PointPrimitive:()=>Er,PointPrimitiveCollection:()=>JC,PointVisualizer:()=>ZL,PolygonGeometry:()=>i0,PolygonGeometryLibrary:()=>Fi,PolygonGeometryUpdater:()=>vJ,PolygonGraphics:()=>su,PolygonHierarchy:()=>Wr,PolygonOutlineGeometry:()=>wJ,PolygonPipeline:()=>wi,Polyline:()=>vp,PolylineArrowMaterialProperty:()=>wC,PolylineCollection:()=>Mc,PolylineColorAppearance:()=>Ul,PolylineDashMaterialProperty:()=>vC,PolylineGeometry:()=>j0,PolylineGeometryUpdater:()=>WL,PolylineGlowMaterialProperty:()=>zC,PolylineGraphics:()=>Od,PolylineMaterialAppearance:()=>zl,PolylineOutlineMaterialProperty:()=>AF,PolylinePipeline:()=>xo,PolylineVisualizer:()=>FL,PolylineVolumeGeometry:()=>jJ,PolylineVolumeGeometryLibrary:()=>Iu,PolylineVolumeGeometryUpdater:()=>eL,PolylineVolumeGraphics:()=>nA,PolylineVolumeOutlineGeometry:()=>tL,PositionProperty:()=>xb,PositionPropertyArray:()=>L0,PostProcessStage:()=>Qa,PostProcessStageCollection:()=>U9,PostProcessStageComposite:()=>nm,PostProcessStageLibrary:()=>IV,PostProcessStageSampleMode:()=>op,PostProcessStageTextureCache:()=>ET,Primitive:()=>Wi,PrimitiveCollection:()=>Dm,PrimitiveLoadPlan:()=>yA,PrimitiveOutlineGenerator:()=>NA,PrimitiveOutlinePipelineStage:()=>Ox,PrimitivePipeline:()=>MG,PrimitiveRenderResources:()=>dX,PrimitiveState:()=>vs,PrimitiveStatisticsPipelineStage:()=>Hx,PrimitiveType:()=>le,ProjectionPicker:()=>wD,ProjectionPickerViewModel:()=>HD,Property:()=>et,PropertyArray:()=>qC,PropertyAttribute:()=>IA,PropertyAttributeProperty:()=>uY,PropertyBag:()=>Em,PropertyTable:()=>Xc,PropertyTexture:()=>CA,PropertyTextureProperty:()=>VY,ProviderViewModel:()=>Nl,Proxy:()=>dlt,QuadraticRealPolynomial:()=>Cc,QuadtreeOccluders:()=>e_,QuadtreePrimitive:()=>l_,QuadtreeTile:()=>n_,QuadtreeTileLoadState:()=>Br,QuadtreeTileProvider:()=>ort,QuantizedMeshTerrainData:()=>OT,QuarticRealPolynomial:()=>wk,Quaternion:()=>wt,QuaternionSpline:()=>yY,Queue:()=>$Z,Ray:()=>di,Rectangle:()=>Gt,RectangleCollisionChecker:()=>CS,RectangleGeometry:()=>FS,RectangleGeometryLibrary:()=>ir,RectangleGeometryUpdater:()=>nL,RectangleGraphics:()=>lu,RectangleOutlineGeometry:()=>wA,ReferenceFrame:()=>ri,ReferenceProperty:()=>M0,RenderState:()=>he,Renderbuffer:()=>Rh,RenderbufferFormat:()=>Tc,Request:()=>us,RequestErrorEvent:()=>yZ,RequestScheduler:()=>xd,RequestState:()=>qi,RequestType:()=>Xl,Resource:()=>te,ResourceCache:()=>jo,ResourceCacheKey:()=>Ym,ResourceCacheStatistics:()=>sY,ResourceLoader:()=>Za,ResourceLoaderState:()=>pn,Rotation:()=>rV,RuntimeError:()=>Tt,S2Cell:()=>Kb,SDFSettings:()=>Ar,SampledPositionProperty:()=>Bs,SampledProperty:()=>ql,Sampler:()=>Hn,ScaledPositionProperty:()=>vc,Scene:()=>s5,SceneFramebuffer:()=>FT,SceneMode:()=>Vt,SceneMode2DPipelineStage:()=>wx,SceneModePicker:()=>vD,SceneModePickerViewModel:()=>PD,SceneTransforms:()=>qo,SceneTransitioner:()=>S9,ScreenSpaceCameraController:()=>C9,ScreenSpaceEventHandler:()=>sp,ScreenSpaceEventType:()=>ui,SelectedFeatureIdPipelineStage:()=>oF,SelectionIndicator:()=>jD,SelectionIndicatorViewModel:()=>zD,Sensor:()=>oW,SensorVolumePortionToDisplay:()=>nI,SensorVolumes:()=>dot,SerializePosition:()=>g5,ShaderBuilder:()=>EG,ShaderCache:()=>$Q,ShaderDestination:()=>Xt,ShaderFunction:()=>dk,ShaderProgram:()=>xn,ShaderSource:()=>Ze,ShaderStruct:()=>rk,ShadowMap:()=>fW,ShadowMapShader:()=>DR,ShadowMode:()=>Vi,ShadowVolumeAppearance:()=>Fh,ShowGeometryInstanceAttribute:()=>pi,Simon1994PlanetaryPositions:()=>_Z,SimplePolylineGeometry:()=>clt,SingleTileImageryProvider:()=>HM,SkinningPipelineStage:()=>vx,SkyAtmosphere:()=>d5,SkyBox:()=>h5,SpaceCatalogDataSource:()=>BM,SpaceEntity:()=>oT,SpatialNode:()=>e5,SphereEmitter:()=>srt,SphereGeometry:()=>mlt,SphereOutlineGeometry:()=>g0,Spherical:()=>Oc,Spline:()=>Ra,SplitDirection:()=>Jc,Splitter:()=>bN,StaticGeometryColorBatch:()=>mV,StaticGeometryPerMaterialBatch:()=>hV,StaticGroundGeometryColorBatch:()=>UI,StaticGroundGeometryPerMaterialBatch:()=>rL,StaticGroundPolylinePerMaterialBatch:()=>fL,StaticOutlineGeometryBatch:()=>SI,StencilConstants:()=>gn,StencilFunction:()=>Li,StencilOperation:()=>je,SteppedSpline:()=>NY,Stereographic:()=>vd,StripeMaterialProperty:()=>tI,StripeOrientation:()=>xu,StructuralMetadata:()=>Rd,StyleCommandsNeeded:()=>Gu,StyleExpression:()=>lrt,Sun:()=>b5,SunLight:()=>gb,SunPostProcess:()=>y9,SupportedImageFormats:()=>fY,SvgPathBindingHandler:()=>pD,TaskProcessor:()=>$i,Terrain:()=>lD,TerrainData:()=>nZ,TerrainEncoding:()=>lc,TerrainFillMesh:()=>B1,TerrainMesh:()=>AV,TerrainOffsetProperty:()=>iA,TerrainProvider:()=>El,TerrainQuantization:()=>yr,TerrainState:()=>Ga,Texture:()=>hn,TextureAtlas:()=>dF,TextureCache:()=>tk,TextureMagnificationFilter:()=>Ro,TextureManager:()=>i5,TextureMinificationFilter:()=>On,TextureUniform:()=>Art,TextureWrap:()=>Zi,TileAvailability:()=>pZ,TileBoundingRegion:()=>eV,TileBoundingS2Cell:()=>PX,TileBoundingSphere:()=>E0,TileBoundingVolume:()=>rrt,TileCoordinatesImageryProvider:()=>dD,TileDiscardPolicy:()=>crt,TileEdge:()=>mi,TileImagery:()=>I1,TileMapServiceImageryProvider:()=>hU,TileMetadata:()=>_X,TileOrientedBoundingBox:()=>kh,TileProviderError:()=>za,TileReplacementQueue:()=>i_,TileSelectionResult:()=>Pi,TileState:()=>mrt,Tileset3DTileContent:()=>ZX,TilesetMetadata:()=>vX,TilesetPipelineStage:()=>HY,TilingScheme:()=>hlt,TimeConstants:()=>xi,TimeDynamicImagery:()=>mT,TimeDynamicPointCloud:()=>UN,TimeInterval:()=>ai,TimeIntervalCollection:()=>ys,TimeIntervalCollectionPositionProperty:()=>_0,TimeIntervalCollectionProperty:()=>_m,TimeStandard:()=>Di,Timeline:()=>tO,TimelineHighlightRange:()=>qD,TimelineTrack:()=>$D,Tipsify:()=>jk,ToggleButtonViewModel:()=>YU,Tonemapper:()=>FU,Transforms:()=>Pe,TranslationRotationScale:()=>gf,TranslucentTileClassification:()=>q_,TridiagonalSystemSolver:()=>nC,TrustedServers:()=>eE,TweenCollection:()=>yT,UniformState:()=>ok,UniformType:()=>K1,UrlTemplateImageryProvider:()=>Ad,VERSION:()=>XDe,VRButton:()=>nO,VRButtonViewModel:()=>eO,VRTheWorldTerrainProvider:()=>plt,VaryingType:()=>Srt,Vector3DTileBatch:()=>vZ,Vector3DTileClampedPolylines:()=>XX,Vector3DTileContent:()=>LX,Vector3DTileGeometry:()=>vb,Vector3DTilePoints:()=>NX,Vector3DTilePolygons:()=>yX,Vector3DTilePolylines:()=>_A,Vector3DTilePrimitive:()=>cA,VelocityOrientationProperty:()=>NJ,VelocityVectorProperty:()=>pS,VertexArray:()=>Ki,VertexArrayFacade:()=>Cb,VertexAttributeSemantic:()=>sn,VertexFormat:()=>ee,VerticalExaggeration:()=>Ps,VerticalExaggerationPipelineStage:()=>zx,VerticalOrigin:()=>hi,VideoSynchronizer:()=>Vlt,View:()=>AT,Viewer:()=>Prt,ViewportQuad:()=>Vrt,Visibility:()=>Ys,Visualizer:()=>Zot,VoxelBoxShape:()=>PR,VoxelCell:()=>k9,VoxelContent:()=>L5,VoxelCylinderShape:()=>vR,VoxelEllipsoidShape:()=>YT,VoxelInspector:()=>sO,VoxelInspectorViewModel:()=>aO,VoxelPrimitive:()=>SU,VoxelProvider:()=>Zrt,VoxelRenderResources:()=>z9,VoxelShape:()=>Rrt,VoxelShapeType:()=>_o,VoxelTraversal:()=>v1,VulkanConstants:()=>ult,WallGeometry:()=>oL,WallGeometryLibrary:()=>US,WallGeometryUpdater:()=>lL,WallGraphics:()=>Mb,WallOutlineGeometry:()=>sL,WasmPositionManager:()=>K0,WebGLConstants:()=>pt,WebMapServiceImageryProvider:()=>PM,WebMapTileServiceImageryProvider:()=>hT,WebMercatorProjection:()=>Yo,WebMercatorTilingScheme:()=>Gs,WindingOrder:()=>ws,WireframeIndexGenerator:()=>hC,WireframePipelineStage:()=>jx,_shadersAcesTonemappingStage:()=>t9,_shadersAdditiveBlend:()=>I9,_shadersAdjustTranslucentFS:()=>_1,_shadersAllMaterialAppearanceFS:()=>uk,_shadersAllMaterialAppearanceVS:()=>Zk,_shadersAmbientOcclusionGenerate:()=>e9,_shadersAmbientOcclusionModulate:()=>n9,_shadersAspectRampMaterial:()=>Fk,_shadersAtmosphereCommon:()=>rW,_shadersAtmosphereStageFS:()=>wY,_shadersAtmosphereStageVS:()=>PY,_shadersBasicMaterialAppearanceFS:()=>Rk,_shadersBasicMaterialAppearanceVS:()=>bk,_shadersBillboardCollectionFS:()=>RX,_shadersBillboardCollectionVS:()=>bX,_shadersBlackAndWhite:()=>i9,_shadersBloomComposite:()=>o9,_shadersBrdfLutGeneratorFS:()=>b_,_shadersBrightPass:()=>N9,_shadersBrightness:()=>a9,_shadersBumpMapMaterial:()=>Uk,_shadersCPUStylingStageFS:()=>bx,_shadersCPUStylingStageVS:()=>Rx,_shadersCheckerboardMaterial:()=>Gk,_shadersCloudCollectionFS:()=>f5,_shadersCloudCollectionVS:()=>F5,_shadersCloudNoiseFS:()=>U5,_shadersCloudNoiseVS:()=>G5,_shadersCompareAndPackTranslucentDepth:()=>j_,_shadersCompositeOITFS:()=>H_,_shadersCompositeTranslucentClassification:()=>GT,_shadersContrastBias:()=>s9,_shadersCustomShaderStageFS:()=>Fx,_shadersCustomShaderStageVS:()=>fx,_shadersCzmBuiltins:()=>SG,_shadersDepthOfField:()=>l9,_shadersDepthPlaneFS:()=>I_,_shadersDepthPlaneVS:()=>N_,_shadersDepthView:()=>r9,_shadersDepthViewPacked:()=>Grt,_shadersDotMaterial:()=>Ak,_shadersEdgeDetection:()=>d9,_shadersElevationBandMaterial:()=>Sk,_shadersElevationContourMaterial:()=>Tk,_shadersElevationRampMaterial:()=>gk,_shadersEllipsoidFS:()=>k1,_shadersEllipsoidSurfaceAppearanceFS:()=>O5,_shadersEllipsoidSurfaceAppearanceVS:()=>H5,_shadersEllipsoidVS:()=>Y1,_shadersFXAA:()=>m9,_shadersFXAA3_11:()=>R9,_shadersFadeMaterial:()=>Ek,_shadersFeatureIdStageFS:()=>Ux,_shadersFeatureIdStageVS:()=>Gx,_shadersFilmicTonemapping:()=>c9,_shadersGaussianBlur1D:()=>fU,_shadersGeometryStageFS:()=>Cx,_shadersGeometryStageVS:()=>Ix,_shadersGlobeFS:()=>kM,_shadersGlobeVS:()=>YM,_shadersGridMaterial:()=>Ck,_shadersGroundAtmosphere:()=>W1,_shadersHSBToRGB:()=>VB,_shadersHSLToRGB:()=>uB,_shadersImageBasedLightingStageFS:()=>KY,_shadersInstancingStageCommon:()=>sx,_shadersInstancingStageVS:()=>lx,_shadersIntersectBox:()=>_9,_shadersIntersectClippingPlanes:()=>M9,_shadersIntersectCylinder:()=>D9,_shadersIntersectDepth:()=>L9,_shadersIntersectEllipsoid:()=>O9,_shadersIntersectLongitude:()=>w1,_shadersIntersection:()=>kT,_shadersIntersectionUtils:()=>J9,_shadersLegacyInstancingStageVS:()=>rx,_shadersLensFlare:()=>h9,_shadersLightingStageFS:()=>Bx,_shadersMaterialStageFS:()=>kx,_shadersMegatexture:()=>K9,_shadersMetadataStageFS:()=>Ax,_shadersMetadataStageVS:()=>Sx,_shadersModelClippingPlanesStageFS:()=>tx,_shadersModelClippingPolygonsStageFS:()=>ix,_shadersModelClippingPolygonsStageVS:()=>nx,_shadersModelColorStageFS:()=>$Y,_shadersModelFS:()=>JY,_shadersModelSilhouetteStageFS:()=>nX,_shadersModelSilhouetteStageVS:()=>iX,_shadersModelSplitterStageFS:()=>aX,_shadersModelVS:()=>LY,_shadersModifiedReinhardTonemapping:()=>p9,_shadersMorphTargetsStageVS:()=>xx,_shadersNightVision:()=>V9,_shadersNormalMapMaterial:()=>Ik,_shadersOctahedralProjectionAtlasFS:()=>I2,_shadersOctahedralProjectionFS:()=>N2,_shadersOctahedralProjectionVS:()=>y2,_shadersOctree:()=>v9,_shadersPassThrough:()=>nh,_shadersPassThroughDepth:()=>RU,_shadersPerInstanceColorAppearanceFS:()=>Lk,_shadersPerInstanceColorAppearanceVS:()=>Mk,_shadersPerInstanceFlatColorAppearanceFS:()=>yG,_shadersPerInstanceFlatColorAppearanceVS:()=>_k,_shadersPointCloudEyeDomeLighting:()=>FY,_shadersPointCloudStylingStageVS:()=>Lx,_shadersPointPrimitiveCollectionFS:()=>GF,_shadersPointPrimitiveCollectionVS:()=>FJ,_shadersPolygonSignedDistanceFS:()=>cY,_shadersPolylineArrowMaterial:()=>Nk,_shadersPolylineColorAppearanceVS:()=>d2,_shadersPolylineCommon:()=>Uh,_shadersPolylineDashMaterial:()=>yk,_shadersPolylineFS:()=>HG,_shadersPolylineGlowMaterial:()=>Bk,_shadersPolylineMaterialAppearanceVS:()=>c2,_shadersPolylineOutlineMaterial:()=>Qk,_shadersPolylineShadowVolumeFS:()=>a2,_shadersPolylineShadowVolumeMorphFS:()=>s2,_shadersPolylineShadowVolumeMorphVS:()=>l2,_shadersPolylineShadowVolumeVS:()=>r2,_shadersPolylineVS:()=>SX,_shadersPrimitiveOutlineStageFS:()=>Dx,_shadersPrimitiveOutlineStageVS:()=>_x,_shadersRGBToHSB:()=>ZB,_shadersRGBToHSL:()=>RB,_shadersRGBToXYZ:()=>bB,_shadersReinhardTonemapping:()=>u9,_shadersReprojectWebMercatorFS:()=>KM,_shadersReprojectWebMercatorVS:()=>zM,_shadersRimLightingMaterial:()=>kk,_shadersSelectedFeatureIdStageCommon:()=>mC,_shadersShadowVolumeAppearanceFS:()=>bE,_shadersShadowVolumeAppearanceVS:()=>Pk,_shadersShadowVolumeFS:()=>Uf,_shadersSilhouette:()=>Z9,_shadersSkinningStageVS:()=>Px,_shadersSkyAtmosphereCommon:()=>j1,_shadersSkyAtmosphereFS:()=>l5,_shadersSkyAtmosphereVS:()=>r5,_shadersSkyBoxFS:()=>c5,_shadersSkyBoxVS:()=>m5,_shadersSlopeRampMaterial:()=>Yk,_shadersStripeMaterial:()=>xk,_shadersSunFS:()=>p5,_shadersSunTextureFS:()=>V5,_shadersSunVS:()=>u5,_shadersTexturedMaterialAppearanceFS:()=>Wk,_shadersTexturedMaterialAppearanceVS:()=>fk,_shadersVector3DTileClampedPolylinesFS:()=>YX,_shadersVector3DTileClampedPolylinesVS:()=>kX,_shadersVector3DTilePolylinesVS:()=>BX,_shadersVectorTileVS:()=>CE,_shadersVerticalExaggerationStageVS:()=>Kx,_shadersViewportQuadFS:()=>A5,_shadersViewportQuadVS:()=>GG,_shadersVoxelFS:()=>x9,_shadersVoxelUtils:()=>Y9,_shadersVoxelVS:()=>X9,_shadersWater:()=>Xk,_shadersXYZToRGB:()=>WB,_shadersacesTonemapping:()=>fB,_shadersalphaWeight:()=>FB,_shadersantialias:()=>UB,_shadersapplyHSBShift:()=>GB,_shadersapproximateSphericalCoordinates:()=>AB,_shadersapproximateTanh:()=>SB,_shadersbackFacing:()=>TB,_shadersbranchFreeTernary:()=>gB,_shaderscascadeColor:()=>EB,_shaderscascadeDistance:()=>CB,_shaderscascadeMatrix:()=>IB,_shaderscascadeWeights:()=>NB,_shadersclipPolygons:()=>yB,_shaderscolumbusViewMorph:()=>BB,_shaderscomputeAtmosphereColor:()=>QB,_shaderscomputeGroundAtmosphereScattering:()=>kB,_shaderscomputePosition:()=>YB,_shaderscomputeScattering:()=>xB,_shadersconvertUvToBox:()=>H9,_shadersconvertUvToCylinder:()=>w9,_shadersconvertUvToEllipsoid:()=>P9,_shaderscosineAndSine:()=>XB,_shadersdecompressTextureCoordinates:()=>JB,_shadersdefaultPbrMaterial:()=>LB,_shadersdegreesPerRadian:()=>Fy,_shadersdepthClamp:()=>MB,_shadersdepthRange:()=>Uy,_shadersdepthRangeStruct:()=>aB,_shaderseastNorthUpToEyeCoordinates:()=>_B,_shadersellipsoidContainsPoint:()=>DB,_shadersellipsoidWgs84TextureCoordinates:()=>OB,_shadersepsilon1:()=>Gy,_shadersepsilon2:()=>Ay,_shadersepsilon3:()=>Sy,_shadersepsilon4:()=>Ty,_shadersepsilon5:()=>gy,_shadersepsilon6:()=>Ey,_shadersepsilon7:()=>Cy,_shadersequalsEpsilon:()=>HB,_shaderseyeOffset:()=>wB,_shaderseyeToWindowCoordinates:()=>PB,_shadersfastApproximateAtan:()=>vB,_shadersfog:()=>KB,_shadersgammaCorrect:()=>zB,_shadersgeodeticSurfaceNormal:()=>jB,_shadersgetDefaultMaterial:()=>qB,_shadersgetDynamicAtmosphereLightDirection:()=>$B,_shadersgetLambertDiffuse:()=>tQ,_shadersgetSpecular:()=>eQ,_shadersgetWaterNoise:()=>nQ,_shadershue:()=>iQ,_shadersinfinity:()=>Iy,_shadersinverseGamma:()=>oQ,_shadersisEmpty:()=>aQ,_shadersisFull:()=>sQ,_shaderslatitudeToWebMercatorFraction:()=>lQ,_shaderslineDistance:()=>rQ,_shaderslinearToSrgb:()=>dQ,_shadersluminance:()=>cQ,_shadersmaterial:()=>sB,_shadersmaterialInput:()=>lB,_shadersmetersPerPixel:()=>mQ,_shadersmodelMaterial:()=>rB,_shadersmodelToWindowCoordinates:()=>hQ,_shadersmodelVertexOutput:()=>dB,_shadersmultiplyWithColorBalance:()=>pQ,_shadersnearFarScalar:()=>VQ,_shadersoctDecode:()=>uQ,_shadersoneOverPi:()=>Ny,_shadersoneOverTwoPi:()=>yy,_shaderspackDepth:()=>ZQ,_shaderspassCesium3DTile:()=>By,_shaderspassCesium3DTileClassification:()=>Qy,_shaderspassCesium3DTileClassificationIgnoreShow:()=>ky,_shaderspassClassification:()=>Yy,_shaderspassCompute:()=>xy,_shaderspassEnvironment:()=>Xy,_shaderspassGlobe:()=>Jy,_shaderspassOpaque:()=>Ly,_shaderspassOverlay:()=>My,_shaderspassTerrainClassification:()=>_y,_shaderspassTranslucent:()=>Dy,_shaderspassVoxels:()=>Oy,_shaderspbrLighting:()=>RQ,_shaderspbrMetallicRoughnessMaterial:()=>bQ,_shaderspbrParameters:()=>cB,_shaderspbrSpecularGlossinessMaterial:()=>WQ,_shadersphong:()=>fQ,_shaderspi:()=>Hy,_shaderspiOverFour:()=>wy,_shaderspiOverSix:()=>Py,_shaderspiOverThree:()=>vy,_shaderspiOverTwo:()=>Ky,_shadersplaneDistance:()=>FQ,_shaderspointAlongRay:()=>UQ,_shadersradiansPerDegree:()=>zy,_shadersray:()=>mB,_shadersrayEllipsoidIntersectionInterval:()=>GQ,_shadersraySegment:()=>hB,_shadersraySphereIntersectionInterval:()=>AQ,_shadersreadDepth:()=>SQ,_shadersreadNonPerspective:()=>TQ,_shadersreverseLogDepth:()=>gQ,_shadersround:()=>EQ,_shaderssampleOctahedralProjection:()=>CQ,_shaderssaturation:()=>IQ,_shaderssceneMode2D:()=>jy,_shaderssceneMode3D:()=>qy,_shaderssceneModeColumbusView:()=>$y,_shaderssceneModeMorphing:()=>tB,_shadersshadowDepthCompare:()=>NQ,_shadersshadowParameters:()=>pB,_shadersshadowVisibility:()=>yQ,_shaderssignNotZero:()=>BQ,_shaderssolarRadius:()=>eB,_shaderssphericalHarmonics:()=>QQ,_shaderssrgbToLinear:()=>kQ,_shaderstangentToEyeSpaceMatrix:()=>YQ,_shaderstextureCube:()=>xQ,_shadersthreePiOver2:()=>nB,_shaderstransformPlane:()=>XQ,_shaderstranslateRelativeToEye:()=>JQ,_shaderstranslucentPhong:()=>LQ,_shaderstranspose:()=>MQ,_shaderstwoPi:()=>iB,_shadersunpackClippingExtents:()=>_Q,_shadersunpackDepth:()=>DQ,_shadersunpackFloat:()=>OQ,_shadersunpackUint:()=>HQ,_shadersvalueTransform:()=>wQ,_shadersvertexLogDepth:()=>PQ,_shaderswebMercatorMaxLatitude:()=>oB,_shaderswindowToEyeCoordinates:()=>vQ,_shaderswriteDepthClamp:()=>KQ,_shaderswriteLogDepth:()=>zQ,_shaderswriteNonPerspective:()=>jQ,addBuffer:()=>z2,addDefaults:()=>_2,addExtensionsRequired:()=>P2,addExtensionsUsed:()=>Xp,addPipelineExtras:()=>Jf,addToArray:()=>$l,appendForwardSlash:()=>$N,arrayRemoveDuplicates:()=>sa,barycentricCoordinates:()=>YG,binarySearch:()=>Ja,buildDrawCommand:()=>OY,buildModuleUrl:()=>Dn,buildVoxelDrawCommands:()=>q9,cesiumWorkerBootstrapperPackedStringBase64:()=>Rot,clone:()=>Re,combine:()=>ze,computeFlyToLocationForRectangle:()=>rg,computePositions:()=>qF,conic_sensor_graphics:()=>XS,conic_sensor_visualizer:()=>LS,createBillboardPointCallback:()=>XA,createCommand:()=>Ri,createDefaultImageryProviderViewModels:()=>gD,createDefaultTerrainProviderViewModels:()=>ED,createElevationBandMaterial:()=>Wrt,createGooglePhotorealistic3DTileset:()=>frt,createGuid:()=>Ti,createMaterialPropertyDescriptor:()=>la,createOsmBuildingsAsync:()=>Frt,createPropertyDescriptor:()=>ft,createRawPropertyDescriptor:()=>gm,createTangentSpaceDebugPrimitive:()=>Urt,createTaskProcessorWorker:()=>Trt,createUniform:()=>hy,createUniformArray:()=>py,createWorldBathymetryAsync:()=>B5,createWorldImageryAsync:()=>pW,createWorldTerrainAsync:()=>KT,custom_pattern_sensor_graphics:()=>_S,custom_pattern_sensor_visualizer:()=>DS,custom_sensor_volume:()=>Ku,custom_sensor_volume_fs_glsl:()=>PI,custom_sensor_volume_vs_glsl:()=>vI,decodeGoogleEarthEnterpriseData:()=>Q5,decodeVectorPolylinePositions:()=>JX,defaultValue:()=>f,defer:()=>kd,defined:()=>c,demodernizeShader:()=>qQ,deprecationWarning:()=>ur,destroyObject:()=>At,exportKml:()=>Uot,findAccessorMinMax:()=>bA,findContentMetadata:()=>OA,findGroupMetadata:()=>HA,findTileMetadata:()=>DX,forEachTextureInMaterial:()=>XE,formatError:()=>QR,freezeRenderState:()=>w6,getAbsoluteUri:()=>IZ,getAccessorByteStride:()=>Qm,getBaseUri:()=>ty,getBinaryAccessor:()=>Eh,getClipAndStyleCode:()=>iD,getClippingFunction:()=>dW,getComponentReader:()=>e0,getElement:()=>Ui,getExtensionFromUri:()=>pG,getFilenameFromUri:()=>X0,getImageFromTypedArray:()=>n5,getImagePixels:()=>vV,getJsonFromTypedArray:()=>ts,getMagic:()=>mu,getStringFromTypedArray:()=>Im,getTimestamp:()=>Oi,hasExtension:()=>co,heightReferenceOnEntityPropertyChanged:()=>Db,initialize:()=>KS,isBitSet:()=>Zc,isBlobUri:()=>VG,isCrossOriginUrl:()=>uG,isDataUri:()=>fb,isLeapYear:()=>PV,isPointIn2D:()=>lM,isPointIn3D:()=>rM,knockout:()=>Lt,knockout_3_5_1:()=>dg,knockout_es5:()=>hD,loadAndExecuteScript:()=>ZG,loadCubeMap:()=>ck,loadImageFromTypedArray:()=>uA,loadKTX2:()=>Fm,mergeSort:()=>uW,moveTechniqueRenderStates:()=>w2,moveTechniquesToExtension:()=>v2,numberOfComponentsForType:()=>Ih,objectToQuery:()=>RG,oneTimeWarning:()=>Gn,parseBatchTable:()=>c0,parseFeatureMetadataLegacy:()=>bY,parseGlb:()=>O2,parseResponseHeaders:()=>ey,parseStructuralMetadata:()=>RY,pickModel:()=>VC,pointInsideTriangle:()=>Rlt,preprocess3DTileContent:()=>dR,processVoxelProperties:()=>j9,queryToObject:()=>Sc,readAccessorPacked:()=>j2,rectangular_pyramid_sensor_volume:()=>PS,rectangular_sensor_graphics:()=>HS,rectangular_sensor_visualizer:()=>vS,removeExtension:()=>WA,removeExtensionsRequired:()=>D2,removeExtensionsUsed:()=>RA,removePipelineExtras:()=>H2,removeUnusedElements:()=>K2,remove_primitive:()=>ac,resizeImageToNextPowerOfTwo:()=>_f,sampleTerrain:()=>k5,sampleTerrainMostDetailed:()=>zT,scaleToGeodeticSurface:()=>hG,sensor_state:()=>JS,sensor_volume_glsl:()=>wI,srgbToLinear:()=>jT,subdivideArray:()=>vk,subscribeAndEvaluate:()=>od,transferTypedArrayTestSrc:()=>Got,updateAccessorComponentTypes:()=>q2,updateVersion:()=>$2,usesExtension:()=>Cs,viewerCSSMixin:()=>vrt,viewerCameraMixin:()=>Krt,viewerCesium3DTilesInspectorMixin:()=>zrt,viewerCesiumInspectorMixin:()=>jrt,viewerDragDropMixin:()=>$rt,viewerPerformanceWatchdogMixin:()=>tdt,viewerReferenceFrameMixin:()=>edt,viewerStorageMixin:()=>ndt,viewerVoxelInspectorMixin:()=>idt,webGLConstantToGlslType:()=>flt,wrapFunction:()=>Y5,writeTextToCanvas:()=>LA});var NTa=b(W(),1);var Uqo=b(W(),1);var JOe=b(W(),1);var dOe=b(W(),1);var jDe=b(W(),1);var ODe=b(W(),1);function WMt(t){return t!=null}var c=WMt;var PDe=b(W(),1);function cG(t){this.name="DeveloperError",this.message=t;let e;try{throw new Error}catch(n){e=n.stack}this.stack=e}c(Object.create)&&(cG.prototype=Object.create(Error.prototype),cG.prototype.constructor=cG);cG.prototype.toString=function(){let t=`${this.name}: ${this.message}`;return c(this.stack)&&(t+=` +${this.stack.toString()}`),t};cG.throwInstantiationError=function(){throw new cG("This function defines an interface and should not be called directly.")};var Ut=cG;var vl={};vl.typeOf={};function fMt(t){return`${t} is required, actual value was undefined`}function Hg(t,e,n){return`Expected ${n} to be typeof ${e}, actual typeof was ${t}`}vl.defined=function(t,e){if(!c(e))throw new Ut(fMt(t))};vl.typeOf.func=function(t,e){if(typeof e!="function")throw new Ut(Hg(typeof e,"function",t))};vl.typeOf.string=function(t,e){if(typeof e!="string")throw new Ut(Hg(typeof e,"string",t))};vl.typeOf.number=function(t,e){if(typeof e!="number")throw new Ut(Hg(typeof e,"number",t))};vl.typeOf.number.lessThan=function(t,e,n){if(vl.typeOf.number(t,e),e>=n)throw new Ut(`Expected ${t} to be less than ${n}, actual value was ${e}`)};vl.typeOf.number.lessThanOrEquals=function(t,e,n){if(vl.typeOf.number(t,e),e>n)throw new Ut(`Expected ${t} to be less than or equal to ${n}, actual value was ${e}`)};vl.typeOf.number.greaterThan=function(t,e,n){if(vl.typeOf.number(t,e),e<=n)throw new Ut(`Expected ${t} to be greater than ${n}, actual value was ${e}`)};vl.typeOf.number.greaterThanOrEquals=function(t,e,n){if(vl.typeOf.number(t,e),e0?1:-1});Me.signNotZero=function(t){return t<0?-1:1};Me.toSNorm=function(t,e){return e=f(e,255),Math.round((Me.clamp(t,-1,1)*.5+.5)*e)};Me.fromSNorm=function(t,e){return e=f(e,255),Me.clamp(t,0,e)/e*2-1};Me.normalize=function(t,e,n){return n=Math.max(n-e,0),n===0?0:Me.clamp((t-e)/n,0,1)};Me.sinh=f(Math.sinh,function(e){return(Math.exp(e)-Math.exp(-e))/2});Me.cosh=f(Math.cosh,function(e){return(Math.exp(e)+Math.exp(-e))/2});Me.lerp=function(t,e,n){return(1-n)*t+n*e};Me.PI=Math.PI;Me.ONE_OVER_PI=1/Math.PI;Me.PI_OVER_TWO=Math.PI/2;Me.PI_OVER_THREE=Math.PI/3;Me.PI_OVER_FOUR=Math.PI/4;Me.PI_OVER_SIX=Math.PI/6;Me.THREE_PI_OVER_TWO=3*Math.PI/2;Me.TWO_PI=2*Math.PI;Me.ONE_OVER_TWO_PI=1/(2*Math.PI);Me.RADIANS_PER_DEGREE=Math.PI/180;Me.DEGREES_PER_RADIAN=180/Math.PI;Me.RADIANS_PER_ARCSECOND=Me.RADIANS_PER_DEGREE/3600;Me.toRadians=function(t){return t*Me.RADIANS_PER_DEGREE};Me.toDegrees=function(t){return t*Me.DEGREES_PER_RADIAN};Me.convertLongitudeRange=function(t){let e=Me.TWO_PI,n=t-Math.floor(t/e)*e;return n<-Math.PI?n+e:n>=Math.PI?n-e:n};Me.clampToLatitudeRange=function(t){return Me.clamp(t,-1*Me.PI_OVER_TWO,Me.PI_OVER_TWO)};Me.negativePiToPi=function(t){return t>=-Me.PI&&t<=Me.PI?t:Me.zeroToTwoPi(t+Me.PI)-Me.PI};Me.zeroToTwoPi=function(t){if(t>=0&&t<=Me.TWO_PI)return t;let e=Me.mod(t,Me.TWO_PI);return Math.abs(e)Me.EPSILON14?Me.TWO_PI:e};Me.mod=function(t,e){return Me.sign(t)===Me.sign(e)&&Math.abs(t)n};Me.greaterThanOrEquals=function(t,e,n){return t-e>-n};var zO=[1];Me.factorial=function(t){let e=zO.length;if(t>=e){let n=zO[e-1];for(let i=e;i<=t;i++){let o=n*i;zO.push(o),n=o}}return zO[t]};Me.incrementWrap=function(t,e,n){return n=f(n,0),++t,t>e&&(t=n),t};Me.isPowerOfTwo=function(t){return t!==0&&(t&t-1)===0};Me.nextPowerOfTwo=function(t){return--t,t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,++t,t};Me.previousPowerOfTwo=function(t){return t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,t|=t>>32,t=(t>>>0)-(t>>>1),t};Me.clamp=function(t,e,n){return tn?n:t};var Pct=new t6.default;Me.setRandomNumberSeed=function(t){Pct=new t6.default(t)};Me.nextRandomNumber=function(){return Pct.random()};Me.randomBetween=function(t,e){return Me.nextRandomNumber()*(e-t)+t};Me.acosClamped=function(t){return Math.acos(Me.clamp(t,-1,1))};Me.asinClamped=function(t){return Math.asin(Me.clamp(t,-1,1))};Me.chordLength=function(t,e){return 2*e*Math.sin(t*.5)};Me.logBase=function(t,e){return Math.log(t)/Math.log(e)};Me.cbrt=f(Math.cbrt,function(e){let n=Math.pow(Math.abs(e),.3333333333333333);return e<0?-n:n});Me.log2=f(Math.log2,function(e){return Math.log(e)*Math.LOG2E});Me.fog=function(t,e){let n=t*e;return 1-Math.exp(-(n*n))};Me.fastApproximateAtan=function(t){return t*(-.1784*Math.abs(t)-.0663*t*t+1.0301)};Me.fastApproximateAtan2=function(t,e){let n,i=Math.abs(t);n=Math.abs(e);let o=Math.max(i,n);n=Math.min(i,n);let a=n/o;return i=Me.fastApproximateAtan(a),i=Math.abs(e)>Math.abs(t)?Me.PI_OVER_TWO-i:i,i=t<0?Me.PI-i:i,i=e<0?-i:i,i};var k=Me;function Ie(t,e,n){this.x=f(t,0),this.y=f(e,0),this.z=f(n,0)}Ie.fromSpherical=function(t,e){c(e)||(e=new Ie);let n=t.clock,i=t.cone,o=f(t.magnitude,1),a=o*Math.sin(i);return e.x=a*Math.cos(n),e.y=a*Math.sin(n),e.z=o*Math.cos(i),e};Ie.fromElements=function(t,e,n,i){return c(i)?(i.x=t,i.y=e,i.z=n,i):new Ie(t,e,n)};Ie.clone=function(t,e){if(c(t))return c(e)?(e.x=t.x,e.y=t.y,e.z=t.z,e):new Ie(t.x,t.y,t.z)};Ie.fromCartesian4=Ie.clone;Ie.packedLength=3;Ie.pack=function(t,e,n){return n=f(n,0),e[n++]=t.x,e[n++]=t.y,e[n]=t.z,e};Ie.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Ie),n.x=t[e++],n.y=t[e++],n.z=t[e],n};Ie.packArray=function(t,e){let n=t.length,i=n*3;c(e)?!Array.isArray(e)&&e.length!==i||e.length!==i&&(e.length=i):e=new Array(i);for(let o=0;oi&&(o=d,i=m)}let a=1,s=0,l=o6[o],r=a6[o];if(Math.abs(t[Ne.getElementIndex(r,l)])>n){let d=t[Ne.getElementIndex(r,r)],m=t[Ne.getElementIndex(l,l)],h=t[Ne.getElementIndex(r,l)],u=(d-m)/2/h,R;u<0?R=-1/(-u+Math.sqrt(1+u*u)):R=1/(u+Math.sqrt(1+u*u)),a=1/Math.sqrt(1+R*R),s=R*a}return e=Ne.clone(Ne.IDENTITY,e),e[Ne.getElementIndex(l,l)]=e[Ne.getElementIndex(r,r)]=a,e[Ne.getElementIndex(r,l)]=s,e[Ne.getElementIndex(l,r)]=-s,e}var tH=new Ne,qct=new Ne;Ne.computeEigenDecomposition=function(t,e){let n=k.EPSILON20,i=10,o=0,a=0;c(e)||(e={});let s=e.unitary=Ne.clone(Ne.IDENTITY,e.unitary),l=e.diagonal=Ne.clone(t,e.diagonal),r=n*IMt(l);for(;ar;)yMt(l,tH),Ne.transpose(tH,qct),Ne.multiply(l,tH,l),Ne.multiply(qct,l,l),Ne.multiply(s,tH,s),++o>2&&(++a,o=0);return e};Ne.abs=function(t,e){return e[0]=Math.abs(t[0]),e[1]=Math.abs(t[1]),e[2]=Math.abs(t[2]),e[3]=Math.abs(t[3]),e[4]=Math.abs(t[4]),e[5]=Math.abs(t[5]),e[6]=Math.abs(t[6]),e[7]=Math.abs(t[7]),e[8]=Math.abs(t[8]),e};Ne.determinant=function(t){let e=t[0],n=t[3],i=t[6],o=t[1],a=t[4],s=t[7],l=t[2],r=t[5],d=t[8];return e*(a*d-r*s)+o*(r*i-n*d)+l*(n*s-a*i)};Ne.inverse=function(t,e){let n=t[0],i=t[1],o=t[2],a=t[3],s=t[4],l=t[5],r=t[6],d=t[7],m=t[8],h=Ne.determinant(t);e[0]=s*m-d*l,e[1]=d*o-i*m,e[2]=i*l-s*o,e[3]=r*l-a*m,e[4]=n*m-r*o,e[5]=a*o-n*l,e[6]=a*d-r*s,e[7]=r*i-n*d,e[8]=n*s-a*i;let u=1/h;return Ne.multiplyByScalar(e,u,e)};var BMt=new Ne;Ne.inverseTranspose=function(t,e){return Ne.inverse(Ne.transpose(t,BMt),e)};Ne.equals=function(t,e){return t===e||c(t)&&c(e)&&t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]&&t[4]===e[4]&&t[5]===e[5]&&t[6]===e[6]&&t[7]===e[7]&&t[8]===e[8]};Ne.equalsEpsilon=function(t,e,n){return n=f(n,0),t===e||c(t)&&c(e)&&Math.abs(t[0]-e[0])<=n&&Math.abs(t[1]-e[1])<=n&&Math.abs(t[2]-e[2])<=n&&Math.abs(t[3]-e[3])<=n&&Math.abs(t[4]-e[4])<=n&&Math.abs(t[5]-e[5])<=n&&Math.abs(t[6]-e[6])<=n&&Math.abs(t[7]-e[7])<=n&&Math.abs(t[8]-e[8])<=n};Ne.IDENTITY=Object.freeze(new Ne(1,0,0,0,1,0,0,0,1));Ne.ZERO=Object.freeze(new Ne(0,0,0,0,0,0,0,0,0));Ne.COLUMN0ROW0=0;Ne.COLUMN0ROW1=1;Ne.COLUMN0ROW2=2;Ne.COLUMN1ROW0=3;Ne.COLUMN1ROW1=4;Ne.COLUMN1ROW2=5;Ne.COLUMN2ROW0=6;Ne.COLUMN2ROW1=7;Ne.COLUMN2ROW2=8;Object.defineProperties(Ne.prototype,{length:{get:function(){return Ne.packedLength}}});Ne.prototype.clone=function(t){return Ne.clone(this,t)};Ne.prototype.equals=function(t){return Ne.equals(this,t)};Ne.equalsArray=function(t,e,n){return t[0]===e[n]&&t[1]===e[n+1]&&t[2]===e[n+2]&&t[3]===e[n+3]&&t[4]===e[n+4]&&t[5]===e[n+5]&&t[6]===e[n+6]&&t[7]===e[n+7]&&t[8]===e[n+8]};Ne.prototype.equalsEpsilon=function(t,e){return Ne.equalsEpsilon(this,t,e)};Ne.prototype.toString=function(){return`(${this[0]}, ${this[3]}, ${this[6]}) (${this[1]}, ${this[4]}, ${this[7]}) -(${this[2]}, ${this[5]}, ${this[8]})`};var ot=Ne;var GOe=R(W(),1);function zN(t){this.name="RuntimeError",this.message=t;let e;try{throw new Error}catch(n){e=n.stack}this.stack=e}c(Object.create)&&(zN.prototype=Object.create(Error.prototype),zN.prototype.constructor=zN);zN.prototype.toString=function(){let t=`${this.name}: ${this.message}`;return c(this.stack)&&(t+=` -${this.stack.toString()}`),t};var St=zN;function Ce(t,e,n,i,o,a,s,l,r,d,m,h,Z,b,u,F){this[0]=f(t,0),this[1]=f(o,0),this[2]=f(r,0),this[3]=f(Z,0),this[4]=f(e,0),this[5]=f(a,0),this[6]=f(d,0),this[7]=f(b,0),this[8]=f(n,0),this[9]=f(s,0),this[10]=f(m,0),this[11]=f(u,0),this[12]=f(i,0),this[13]=f(l,0),this[14]=f(h,0),this[15]=f(F,0)}Ce.packedLength=16;Ce.pack=function(t,e,n){return n=f(n,0),e[n++]=t[0],e[n++]=t[1],e[n++]=t[2],e[n++]=t[3],e[n++]=t[4],e[n++]=t[5],e[n++]=t[6],e[n++]=t[7],e[n++]=t[8],e[n++]=t[9],e[n++]=t[10],e[n++]=t[11],e[n++]=t[12],e[n++]=t[13],e[n++]=t[14],e[n]=t[15],e};Ce.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Ce),n[0]=t[e++],n[1]=t[e++],n[2]=t[e++],n[3]=t[e++],n[4]=t[e++],n[5]=t[e++],n[6]=t[e++],n[7]=t[e++],n[8]=t[e++],n[9]=t[e++],n[10]=t[e++],n[11]=t[e++],n[12]=t[e++],n[13]=t[e++],n[14]=t[e++],n[15]=t[e],n};Ce.packArray=function(t,e){let n=t.length,i=n*16;c(e)?!Array.isArray(e)&&e.length!==i||e.length!==i&&(e.length=i):e=new Array(i);for(let o=0;o=k.SIXTY_FOUR_KILOBYTES?new Uint32Array(e):new Uint16Array(e)};ur.createTypedArrayFromArrayBuffer=function(t,e,n,i){return t>=k.SIXTY_FOUR_KILOBYTES?new Uint32Array(e,n,i):new Uint16Array(e,n,i)};ur.fromTypedArray=function(t){if(t instanceof Uint8Array)return ur.UNSIGNED_BYTE;if(t instanceof Uint16Array)return ur.UNSIGNED_SHORT;if(t instanceof Uint32Array)return ur.UNSIGNED_INT};var re=Object.freeze(ur);var qOe=R(W(),1);var eH={STREAM_DRAW:pt.STREAM_DRAW,STATIC_DRAW:pt.STATIC_DRAW,DYNAMIC_DRAW:pt.DYNAMIC_DRAW,validate:function(t){return t===eH.STREAM_DRAW||t===eH.STATIC_DRAW||t===eH.DYNAMIC_DRAW}},ce=Object.freeze(eH);function Tp(t){t=f(t,f.EMPTY_OBJECT);let e=t.context._gl,n=t.bufferTarget,i=t.typedArray,o=t.sizeInBytes,a=t.usage,s=c(i);s&&(o=i.byteLength);let l=e.createBuffer();e.bindBuffer(n,l),e.bufferData(n,s?i:o,a),e.bindBuffer(n,null),this._id=Si(),this._gl=e,this._webgl2=t.context._webgl2,this._bufferTarget=n,this._sizeInBytes=o,this._usage=a,this._buffer=l,this.vertexArrayDestroyable=!0}Tp.createVertexBuffer=function(t){return new Tp({context:t.context,bufferTarget:pt.ARRAY_BUFFER,typedArray:t.typedArray,sizeInBytes:t.sizeInBytes,usage:t.usage})};Tp.createIndexBuffer=function(t){let e=t.context,n=t.indexDatatype,i=re.getSizeInBytes(n),o=new Tp({context:e,bufferTarget:pt.ELEMENT_ARRAY_BUFFER,typedArray:t.typedArray,sizeInBytes:t.sizeInBytes,usage:t.usage}),a=o.sizeInBytes/i;return Object.defineProperties(o,{indexDatatype:{get:function(){return n}},bytesPerIndex:{get:function(){return i}},numberOfIndices:{get:function(){return a}}}),o};Object.defineProperties(Tp.prototype,{sizeInBytes:{get:function(){return this._sizeInBytes}},usage:{get:function(){return this._usage}}});Tp.prototype._getBuffer=function(){return this._buffer};Tp.prototype.copyFromArrayView=function(t,e){e=f(e,0);let n=this._gl,i=this._bufferTarget;n.bindBuffer(i,this._buffer),n.bufferSubData(i,e,t),n.bindBuffer(i,null)};Tp.prototype.copyFromBuffer=function(t,e,n,i){let o=pt.COPY_READ_BUFFER,a=pt.COPY_WRITE_BUFFER,s=this._gl;s.bindBuffer(a,this._buffer),s.bindBuffer(o,t._buffer),s.copyBufferSubData(o,a,e,n,i),s.bindBuffer(a,null),s.bindBuffer(o,null)};Tp.prototype.getBufferData=function(t,e,n,i){e=f(e,0),n=f(n,0);let o=this._gl,a=pt.COPY_READ_BUFFER;o.bindBuffer(a,this._buffer),o.getBufferSubData(a,e,t,n,i),o.bindBuffer(a,null)};Tp.prototype.isDestroyed=function(){return!1};Tp.prototype.destroy=function(){return this._gl.deleteBuffer(this._buffer),At(this)};var we=Tp;var AHe=R(W(),1);var fHe=R(W(),1);var uHe=R(W(),1);var dHe=R(W(),1);var sf,$s={requestFullscreen:void 0,exitFullscreen:void 0,fullscreenEnabled:void 0,fullscreenElement:void 0,fullscreenchange:void 0,fullscreenerror:void 0},Rm={};Object.defineProperties(Rm,{element:{get:function(){if(Rm.supportsFullscreen())return document[$s.fullscreenElement]}},changeEventName:{get:function(){if(Rm.supportsFullscreen())return $s.fullscreenchange}},errorEventName:{get:function(){if(Rm.supportsFullscreen())return $s.fullscreenerror}},enabled:{get:function(){if(Rm.supportsFullscreen())return document[$s.fullscreenEnabled]}},fullscreen:{get:function(){if(Rm.supportsFullscreen())return Rm.element!==null}}});Rm.supportsFullscreen=function(){if(c(sf))return sf;sf=!1;let t=document.body;if(typeof t.requestFullscreen=="function")return $s.requestFullscreen="requestFullscreen",$s.exitFullscreen="exitFullscreen",$s.fullscreenEnabled="fullscreenEnabled",$s.fullscreenElement="fullscreenElement",$s.fullscreenchange="fullscreenchange",$s.fullscreenerror="fullscreenerror",sf=!0,sf;let e=["webkit","moz","o","ms","khtml"],n;for(let i=0,o=e.length;i{let e=new Image;e.onload=function(){Ac._result=e.width>0&&e.height>0,t(Ac._result)},e.onerror=function(){Ac._result=!1,t(Ac._result)},e.src="data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA"})),Ac._promise};Object.defineProperties(Ac,{initialized:{get:function(){return c(Ac._result)}}});var Kg=[];typeof ArrayBuffer<"u"&&(Kg.push(Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array),typeof Uint8ClampedArray<"u"&&Kg.push(Uint8ClampedArray),typeof Uint8ClampedArray<"u"&&Kg.push(Uint8ClampedArray),typeof BigInt64Array<"u"&&Kg.push(BigInt64Array),typeof BigUint64Array<"u"&&Kg.push(BigUint64Array));var Sp={isChrome:h6,chromeVersion:KMt,isSafari:nmt,safariVersion:zMt,isWebkit:imt,webkitVersion:jMt,isInternetExplorer:omt,internetExplorerVersion:qMt,isEdge:rH,edgeVersion:$Mt,isFirefox:dH,firefoxVersion:n_t,isWindows:t_t,isIPadOrIOS:e_t,hardwareConcurrency:f(Qd.hardwareConcurrency,3),supportsPointerEvents:i_t,supportsImageRenderingPixelated:lmt,supportsWebP:Ac,imageRenderingValue:o_t,typedArrayTypes:Kg};Sp.supportsBasis=function(t){return Sp.supportsWebAssembly()&&t.context.supportsBasis};Sp.supportsFullscreen=function(){return Ds.supportsFullscreen()};Sp.supportsTypedArrays=function(){return typeof ArrayBuffer<"u"};Sp.supportsBigInt64Array=function(){return typeof BigInt64Array<"u"};Sp.supportsBigUint64Array=function(){return typeof BigUint64Array<"u"};Sp.supportsBigInt=function(){return typeof BigInt<"u"};Sp.supportsWebWorkers=function(){return typeof Worker<"u"};Sp.supportsWebAssembly=function(){return typeof WebAssembly<"u"};Sp.supportsWebgl2=function(t){return t.context.webgl2};Sp.supportsEsmWebWorkers=function(){return!dH()||parseInt(p6)>=114};var In=Sp;function u6(t,e,n){return n<0&&(n+=1),n>1&&(n-=1),n*6<1?t+(e-t)*6*n:n*2<1?e:n*3<2?t+(e-t)*(2/3-n)*6:t}function Vt(t,e,n,i){this.red=f(t,1),this.green=f(e,1),this.blue=f(n,1),this.alpha=f(i,1)}Vt.fromCartesian4=function(t,e){return c(e)?(e.red=t.x,e.green=t.y,e.blue=t.z,e.alpha=t.w,e):new Vt(t.x,t.y,t.z,t.w)};Vt.fromBytes=function(t,e,n,i,o){return t=Vt.byteToFloat(f(t,255)),e=Vt.byteToFloat(f(e,255)),n=Vt.byteToFloat(f(n,255)),i=Vt.byteToFloat(f(i,255)),c(o)?(o.red=t,o.green=e,o.blue=n,o.alpha=i,o):new Vt(t,e,n,i)};Vt.fromAlpha=function(t,e,n){return c(n)?(n.red=t.red,n.green=t.green,n.blue=t.blue,n.alpha=e,n):new Vt(t.red,t.green,t.blue,e)};var Z6,V6,RR;In.supportsTypedArrays()&&(Z6=new ArrayBuffer(4),V6=new Uint32Array(Z6),RR=new Uint8Array(Z6));Vt.fromRgba=function(t,e){return V6[0]=t,Vt.fromBytes(RR[0],RR[1],RR[2],RR[3],e)};Vt.fromHsl=function(t,e,n,i,o){t=f(t,0)%1,e=f(e,0),n=f(n,0),i=f(i,1);let a=n,s=n,l=n;if(e!==0){let r;n<.5?r=n*(1+e):r=n+e-n*e;let d=2*n-r;a=u6(d,r,t+1/3),s=u6(d,r,t),l=u6(d,r,t-1/3)}return c(o)?(o.red=a,o.green=s,o.blue=l,o.alpha=i,o):new Vt(a,s,l,i)};Vt.fromRandom=function(t,e){t=f(t,f.EMPTY_OBJECT);let n=t.red;if(!c(n)){let s=f(t.minimumRed,0),l=f(t.maximumRed,1);n=s+k.nextRandomNumber()*(l-s)}let i=t.green;if(!c(i)){let s=f(t.minimumGreen,0),l=f(t.maximumGreen,1);i=s+k.nextRandomNumber()*(l-s)}let o=t.blue;if(!c(o)){let s=f(t.minimumBlue,0),l=f(t.maximumBlue,1);o=s+k.nextRandomNumber()*(l-s)}let a=t.alpha;if(!c(a)){let s=f(t.minimumAlpha,0),l=f(t.maximumAlpha,1);a=s+k.nextRandomNumber()*(l-s)}return c(e)?(e.red=n,e.green=i,e.blue=o,e.alpha=a,e):new Vt(n,i,o,a)};var a_t=/^#([0-9a-f])([0-9a-f])([0-9a-f])([0-9a-f])?$/i,s_t=/^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})?$/i,l_t=/^rgba?\s*\(\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i,r_t=/^hsla?\s*\(\s*([0-9.]+)\s*[,\s]+\s*([0-9.]+%)\s*[,\s]+\s*([0-9.]+%)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i;Vt.fromCssColorString=function(t,e){c(e)||(e=new Vt),t=t.trim();let n=Vt[t.toUpperCase()];if(c(n))return Vt.clone(n,e),e;let i=a_t.exec(t);return i!==null?(e.red=parseInt(i[1],16)/15,e.green=parseInt(i[2],16)/15,e.blue=parseInt(i[3],16)/15,e.alpha=parseInt(f(i[4],"f"),16)/15,e):(i=s_t.exec(t),i!==null?(e.red=parseInt(i[1],16)/255,e.green=parseInt(i[2],16)/255,e.blue=parseInt(i[3],16)/255,e.alpha=parseInt(f(i[4],"ff"),16)/255,e):(i=l_t.exec(t),i!==null?(e.red=parseFloat(i[1])/(i[1].substr(-1)==="%"?100:255),e.green=parseFloat(i[2])/(i[2].substr(-1)==="%"?100:255),e.blue=parseFloat(i[3])/(i[3].substr(-1)==="%"?100:255),e.alpha=parseFloat(f(i[4],"1.0")),e):(i=r_t.exec(t),i!==null?Vt.fromHsl(parseFloat(i[1])/360,parseFloat(i[2])/100,parseFloat(i[3])/100,parseFloat(f(i[4],"1.0")),e):(e=void 0,e))))};Vt.packedLength=4;Vt.pack=function(t,e,n){return n=f(n,0),e[n++]=t.red,e[n++]=t.green,e[n++]=t.blue,e[n]=t.alpha,e};Vt.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Vt),n.red=t[e++],n.green=t[e++],n.blue=t[e++],n.alpha=t[e],n};Vt.byteToFloat=function(t){return t/255};Vt.floatToByte=function(t){return t===1?255:t*256|0};Vt.clone=function(t,e){if(c(t))return c(e)?(e.red=t.red,e.green=t.green,e.blue=t.blue,e.alpha=t.alpha,e):new Vt(t.red,t.green,t.blue,t.alpha)};Vt.equals=function(t,e){return t===e||c(t)&&c(e)&&t.red===e.red&&t.green===e.green&&t.blue===e.blue&&t.alpha===e.alpha};Vt.equalsArray=function(t,e,n){return t.red===e[n]&&t.green===e[n+1]&&t.blue===e[n+2]&&t.alpha===e[n+3]};Vt.prototype.clone=function(t){return Vt.clone(this,t)};Vt.prototype.equals=function(t){return Vt.equals(this,t)};Vt.prototype.equalsEpsilon=function(t,e){return this===t||c(t)&&Math.abs(this.red-t.red)<=e&&Math.abs(this.green-t.green)<=e&&Math.abs(this.blue-t.blue)<=e&&Math.abs(this.alpha-t.alpha)<=e};Vt.prototype.toString=function(){return`(${this.red}, ${this.green}, ${this.blue}, ${this.alpha})`};Vt.prototype.toCssColorString=function(){let t=Vt.floatToByte(this.red),e=Vt.floatToByte(this.green),n=Vt.floatToByte(this.blue);return this.alpha===1?`rgb(${t},${e},${n})`:`rgba(${t},${e},${n},${this.alpha})`};Vt.prototype.toCssHexString=function(){let t=Vt.floatToByte(this.red).toString(16);t.length<2&&(t=`0${t}`);let e=Vt.floatToByte(this.green).toString(16);e.length<2&&(e=`0${e}`);let n=Vt.floatToByte(this.blue).toString(16);if(n.length<2&&(n=`0${n}`),this.alpha<1){let i=Vt.floatToByte(this.alpha).toString(16);return i.length<2&&(i=`0${i}`),`#${t}${e}${n}${i}`}return`#${t}${e}${n}`};Vt.prototype.toBytes=function(t){let e=Vt.floatToByte(this.red),n=Vt.floatToByte(this.green),i=Vt.floatToByte(this.blue),o=Vt.floatToByte(this.alpha);return c(t)?(t[0]=e,t[1]=n,t[2]=i,t[3]=o,t):[e,n,i,o]};Vt.prototype.toRgba=function(){return RR[0]=Vt.floatToByte(this.red),RR[1]=Vt.floatToByte(this.green),RR[2]=Vt.floatToByte(this.blue),RR[3]=Vt.floatToByte(this.alpha),V6[0]};Vt.prototype.brighten=function(t,e){return t=1-t,e.red=1-(1-this.red)*t,e.green=1-(1-this.green)*t,e.blue=1-(1-this.blue)*t,e.alpha=this.alpha,e};Vt.prototype.darken=function(t,e){return t=1-t,e.red=this.red*t,e.green=this.green*t,e.blue=this.blue*t,e.alpha=this.alpha,e};Vt.prototype.withAlpha=function(t,e){return Vt.fromAlpha(this,t,e)};Vt.add=function(t,e,n){return n.red=t.red+e.red,n.green=t.green+e.green,n.blue=t.blue+e.blue,n.alpha=t.alpha+e.alpha,n};Vt.subtract=function(t,e,n){return n.red=t.red-e.red,n.green=t.green-e.green,n.blue=t.blue-e.blue,n.alpha=t.alpha-e.alpha,n};Vt.multiply=function(t,e,n){return n.red=t.red*e.red,n.green=t.green*e.green,n.blue=t.blue*e.blue,n.alpha=t.alpha*e.alpha,n};Vt.divide=function(t,e,n){return n.red=t.red/e.red,n.green=t.green/e.green,n.blue=t.blue/e.blue,n.alpha=t.alpha/e.alpha,n};Vt.mod=function(t,e,n){return n.red=t.red%e.red,n.green=t.green%e.green,n.blue=t.blue%e.blue,n.alpha=t.alpha%e.alpha,n};Vt.lerp=function(t,e,n,i){return i.red=k.lerp(t.red,e.red,n),i.green=k.lerp(t.green,e.green,n),i.blue=k.lerp(t.blue,e.blue,n),i.alpha=k.lerp(t.alpha,e.alpha,n),i};Vt.multiplyByScalar=function(t,e,n){return n.red=t.red*e,n.green=t.green*e,n.blue=t.blue*e,n.alpha=t.alpha*e,n};Vt.divideByScalar=function(t,e,n){return n.red=t.red/e,n.green=t.green/e,n.blue=t.blue/e,n.alpha=t.alpha/e,n};Vt.ALICEBLUE=Object.freeze(Vt.fromCssColorString("#F0F8FF"));Vt.ANTIQUEWHITE=Object.freeze(Vt.fromCssColorString("#FAEBD7"));Vt.AQUA=Object.freeze(Vt.fromCssColorString("#00FFFF"));Vt.AQUAMARINE=Object.freeze(Vt.fromCssColorString("#7FFFD4"));Vt.AZURE=Object.freeze(Vt.fromCssColorString("#F0FFFF"));Vt.BEIGE=Object.freeze(Vt.fromCssColorString("#F5F5DC"));Vt.BISQUE=Object.freeze(Vt.fromCssColorString("#FFE4C4"));Vt.BLACK=Object.freeze(Vt.fromCssColorString("#000000"));Vt.BLANCHEDALMOND=Object.freeze(Vt.fromCssColorString("#FFEBCD"));Vt.BLUE=Object.freeze(Vt.fromCssColorString("#0000FF"));Vt.BLUEVIOLET=Object.freeze(Vt.fromCssColorString("#8A2BE2"));Vt.BROWN=Object.freeze(Vt.fromCssColorString("#A52A2A"));Vt.BURLYWOOD=Object.freeze(Vt.fromCssColorString("#DEB887"));Vt.CADETBLUE=Object.freeze(Vt.fromCssColorString("#5F9EA0"));Vt.CHARTREUSE=Object.freeze(Vt.fromCssColorString("#7FFF00"));Vt.CHOCOLATE=Object.freeze(Vt.fromCssColorString("#D2691E"));Vt.CORAL=Object.freeze(Vt.fromCssColorString("#FF7F50"));Vt.CORNFLOWERBLUE=Object.freeze(Vt.fromCssColorString("#6495ED"));Vt.CORNSILK=Object.freeze(Vt.fromCssColorString("#FFF8DC"));Vt.CRIMSON=Object.freeze(Vt.fromCssColorString("#DC143C"));Vt.CYAN=Object.freeze(Vt.fromCssColorString("#00FFFF"));Vt.DARKBLUE=Object.freeze(Vt.fromCssColorString("#00008B"));Vt.DARKCYAN=Object.freeze(Vt.fromCssColorString("#008B8B"));Vt.DARKGOLDENROD=Object.freeze(Vt.fromCssColorString("#B8860B"));Vt.DARKGRAY=Object.freeze(Vt.fromCssColorString("#A9A9A9"));Vt.DARKGREEN=Object.freeze(Vt.fromCssColorString("#006400"));Vt.DARKGREY=Vt.DARKGRAY;Vt.DARKKHAKI=Object.freeze(Vt.fromCssColorString("#BDB76B"));Vt.DARKMAGENTA=Object.freeze(Vt.fromCssColorString("#8B008B"));Vt.DARKOLIVEGREEN=Object.freeze(Vt.fromCssColorString("#556B2F"));Vt.DARKORANGE=Object.freeze(Vt.fromCssColorString("#FF8C00"));Vt.DARKORCHID=Object.freeze(Vt.fromCssColorString("#9932CC"));Vt.DARKRED=Object.freeze(Vt.fromCssColorString("#8B0000"));Vt.DARKSALMON=Object.freeze(Vt.fromCssColorString("#E9967A"));Vt.DARKSEAGREEN=Object.freeze(Vt.fromCssColorString("#8FBC8F"));Vt.DARKSLATEBLUE=Object.freeze(Vt.fromCssColorString("#483D8B"));Vt.DARKSLATEGRAY=Object.freeze(Vt.fromCssColorString("#2F4F4F"));Vt.DARKSLATEGREY=Vt.DARKSLATEGRAY;Vt.DARKTURQUOISE=Object.freeze(Vt.fromCssColorString("#00CED1"));Vt.DARKVIOLET=Object.freeze(Vt.fromCssColorString("#9400D3"));Vt.DEEPPINK=Object.freeze(Vt.fromCssColorString("#FF1493"));Vt.DEEPSKYBLUE=Object.freeze(Vt.fromCssColorString("#00BFFF"));Vt.DIMGRAY=Object.freeze(Vt.fromCssColorString("#696969"));Vt.DIMGREY=Vt.DIMGRAY;Vt.DODGERBLUE=Object.freeze(Vt.fromCssColorString("#1E90FF"));Vt.FIREBRICK=Object.freeze(Vt.fromCssColorString("#B22222"));Vt.FLORALWHITE=Object.freeze(Vt.fromCssColorString("#FFFAF0"));Vt.FORESTGREEN=Object.freeze(Vt.fromCssColorString("#228B22"));Vt.FUCHSIA=Object.freeze(Vt.fromCssColorString("#FF00FF"));Vt.GAINSBORO=Object.freeze(Vt.fromCssColorString("#DCDCDC"));Vt.GHOSTWHITE=Object.freeze(Vt.fromCssColorString("#F8F8FF"));Vt.GOLD=Object.freeze(Vt.fromCssColorString("#FFD700"));Vt.GOLDENROD=Object.freeze(Vt.fromCssColorString("#DAA520"));Vt.GRAY=Object.freeze(Vt.fromCssColorString("#808080"));Vt.GREEN=Object.freeze(Vt.fromCssColorString("#008000"));Vt.GREENYELLOW=Object.freeze(Vt.fromCssColorString("#ADFF2F"));Vt.GREY=Vt.GRAY;Vt.HONEYDEW=Object.freeze(Vt.fromCssColorString("#F0FFF0"));Vt.HOTPINK=Object.freeze(Vt.fromCssColorString("#FF69B4"));Vt.INDIANRED=Object.freeze(Vt.fromCssColorString("#CD5C5C"));Vt.INDIGO=Object.freeze(Vt.fromCssColorString("#4B0082"));Vt.IVORY=Object.freeze(Vt.fromCssColorString("#FFFFF0"));Vt.KHAKI=Object.freeze(Vt.fromCssColorString("#F0E68C"));Vt.LAVENDER=Object.freeze(Vt.fromCssColorString("#E6E6FA"));Vt.LAVENDAR_BLUSH=Object.freeze(Vt.fromCssColorString("#FFF0F5"));Vt.LAWNGREEN=Object.freeze(Vt.fromCssColorString("#7CFC00"));Vt.LEMONCHIFFON=Object.freeze(Vt.fromCssColorString("#FFFACD"));Vt.LIGHTBLUE=Object.freeze(Vt.fromCssColorString("#ADD8E6"));Vt.LIGHTCORAL=Object.freeze(Vt.fromCssColorString("#F08080"));Vt.LIGHTCYAN=Object.freeze(Vt.fromCssColorString("#E0FFFF"));Vt.LIGHTGOLDENRODYELLOW=Object.freeze(Vt.fromCssColorString("#FAFAD2"));Vt.LIGHTGRAY=Object.freeze(Vt.fromCssColorString("#D3D3D3"));Vt.LIGHTGREEN=Object.freeze(Vt.fromCssColorString("#90EE90"));Vt.LIGHTGREY=Vt.LIGHTGRAY;Vt.LIGHTPINK=Object.freeze(Vt.fromCssColorString("#FFB6C1"));Vt.LIGHTSEAGREEN=Object.freeze(Vt.fromCssColorString("#20B2AA"));Vt.LIGHTSKYBLUE=Object.freeze(Vt.fromCssColorString("#87CEFA"));Vt.LIGHTSLATEGRAY=Object.freeze(Vt.fromCssColorString("#778899"));Vt.LIGHTSLATEGREY=Vt.LIGHTSLATEGRAY;Vt.LIGHTSTEELBLUE=Object.freeze(Vt.fromCssColorString("#B0C4DE"));Vt.LIGHTYELLOW=Object.freeze(Vt.fromCssColorString("#FFFFE0"));Vt.LIME=Object.freeze(Vt.fromCssColorString("#00FF00"));Vt.LIMEGREEN=Object.freeze(Vt.fromCssColorString("#32CD32"));Vt.LINEN=Object.freeze(Vt.fromCssColorString("#FAF0E6"));Vt.MAGENTA=Object.freeze(Vt.fromCssColorString("#FF00FF"));Vt.MAROON=Object.freeze(Vt.fromCssColorString("#800000"));Vt.MEDIUMAQUAMARINE=Object.freeze(Vt.fromCssColorString("#66CDAA"));Vt.MEDIUMBLUE=Object.freeze(Vt.fromCssColorString("#0000CD"));Vt.MEDIUMORCHID=Object.freeze(Vt.fromCssColorString("#BA55D3"));Vt.MEDIUMPURPLE=Object.freeze(Vt.fromCssColorString("#9370DB"));Vt.MEDIUMSEAGREEN=Object.freeze(Vt.fromCssColorString("#3CB371"));Vt.MEDIUMSLATEBLUE=Object.freeze(Vt.fromCssColorString("#7B68EE"));Vt.MEDIUMSPRINGGREEN=Object.freeze(Vt.fromCssColorString("#00FA9A"));Vt.MEDIUMTURQUOISE=Object.freeze(Vt.fromCssColorString("#48D1CC"));Vt.MEDIUMVIOLETRED=Object.freeze(Vt.fromCssColorString("#C71585"));Vt.MIDNIGHTBLUE=Object.freeze(Vt.fromCssColorString("#191970"));Vt.MINTCREAM=Object.freeze(Vt.fromCssColorString("#F5FFFA"));Vt.MISTYROSE=Object.freeze(Vt.fromCssColorString("#FFE4E1"));Vt.MOCCASIN=Object.freeze(Vt.fromCssColorString("#FFE4B5"));Vt.NAVAJOWHITE=Object.freeze(Vt.fromCssColorString("#FFDEAD"));Vt.NAVY=Object.freeze(Vt.fromCssColorString("#000080"));Vt.OLDLACE=Object.freeze(Vt.fromCssColorString("#FDF5E6"));Vt.OLIVE=Object.freeze(Vt.fromCssColorString("#808000"));Vt.OLIVEDRAB=Object.freeze(Vt.fromCssColorString("#6B8E23"));Vt.ORANGE=Object.freeze(Vt.fromCssColorString("#FFA500"));Vt.ORANGERED=Object.freeze(Vt.fromCssColorString("#FF4500"));Vt.ORCHID=Object.freeze(Vt.fromCssColorString("#DA70D6"));Vt.PALEGOLDENROD=Object.freeze(Vt.fromCssColorString("#EEE8AA"));Vt.PALEGREEN=Object.freeze(Vt.fromCssColorString("#98FB98"));Vt.PALETURQUOISE=Object.freeze(Vt.fromCssColorString("#AFEEEE"));Vt.PALEVIOLETRED=Object.freeze(Vt.fromCssColorString("#DB7093"));Vt.PAPAYAWHIP=Object.freeze(Vt.fromCssColorString("#FFEFD5"));Vt.PEACHPUFF=Object.freeze(Vt.fromCssColorString("#FFDAB9"));Vt.PERU=Object.freeze(Vt.fromCssColorString("#CD853F"));Vt.PINK=Object.freeze(Vt.fromCssColorString("#FFC0CB"));Vt.PLUM=Object.freeze(Vt.fromCssColorString("#DDA0DD"));Vt.POWDERBLUE=Object.freeze(Vt.fromCssColorString("#B0E0E6"));Vt.PURPLE=Object.freeze(Vt.fromCssColorString("#800080"));Vt.RED=Object.freeze(Vt.fromCssColorString("#FF0000"));Vt.ROSYBROWN=Object.freeze(Vt.fromCssColorString("#BC8F8F"));Vt.ROYALBLUE=Object.freeze(Vt.fromCssColorString("#4169E1"));Vt.SADDLEBROWN=Object.freeze(Vt.fromCssColorString("#8B4513"));Vt.SALMON=Object.freeze(Vt.fromCssColorString("#FA8072"));Vt.SANDYBROWN=Object.freeze(Vt.fromCssColorString("#F4A460"));Vt.SEAGREEN=Object.freeze(Vt.fromCssColorString("#2E8B57"));Vt.SEASHELL=Object.freeze(Vt.fromCssColorString("#FFF5EE"));Vt.SIENNA=Object.freeze(Vt.fromCssColorString("#A0522D"));Vt.SILVER=Object.freeze(Vt.fromCssColorString("#C0C0C0"));Vt.SKYBLUE=Object.freeze(Vt.fromCssColorString("#87CEEB"));Vt.SLATEBLUE=Object.freeze(Vt.fromCssColorString("#6A5ACD"));Vt.SLATEGRAY=Object.freeze(Vt.fromCssColorString("#708090"));Vt.SLATEGREY=Vt.SLATEGRAY;Vt.SNOW=Object.freeze(Vt.fromCssColorString("#FFFAFA"));Vt.SPRINGGREEN=Object.freeze(Vt.fromCssColorString("#00FF7F"));Vt.STEELBLUE=Object.freeze(Vt.fromCssColorString("#4682B4"));Vt.TAN=Object.freeze(Vt.fromCssColorString("#D2B48C"));Vt.TEAL=Object.freeze(Vt.fromCssColorString("#008080"));Vt.THISTLE=Object.freeze(Vt.fromCssColorString("#D8BFD8"));Vt.TOMATO=Object.freeze(Vt.fromCssColorString("#FF6347"));Vt.TURQUOISE=Object.freeze(Vt.fromCssColorString("#40E0D0"));Vt.VIOLET=Object.freeze(Vt.fromCssColorString("#EE82EE"));Vt.WHEAT=Object.freeze(Vt.fromCssColorString("#F5DEB3"));Vt.WHITE=Object.freeze(Vt.fromCssColorString("#FFFFFF"));Vt.WHITESMOKE=Object.freeze(Vt.fromCssColorString("#F5F5F5"));Vt.YELLOW=Object.freeze(Vt.fromCssColorString("#FFFF00"));Vt.YELLOWGREEN=Object.freeze(Vt.fromCssColorString("#9ACD32"));Vt.TRANSPARENT=Object.freeze(new Vt(0,0,0,0));var v=Vt;function cH(t){t=f(t,f.EMPTY_OBJECT),this.color=t.color,this.depth=t.depth,this.stencil=t.stencil,this.renderState=t.renderState,this.framebuffer=t.framebuffer,this.owner=t.owner,this.pass=t.pass}cH.ALL=Object.freeze(new cH({color:new v(0,0,0,0),depth:1,stencil:0}));cH.prototype.execute=function(t,e){t.clear(this,e)};var ao=cH;var IHe=R(W(),1);var SHe=R(W(),1),d_t={ENVIRONMENT:0,COMPUTE:1,GLOBE:2,TERRAIN_CLASSIFICATION:3,CESIUM_3D_TILE:4,CESIUM_3D_TILE_CLASSIFICATION:5,CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW:6,OPAQUE:7,TRANSLUCENT:8,VOXELS:9,OVERLAY:10,NUMBER_OF_PASSES:11},Pt=Object.freeze(d_t);function rmt(t){t=f(t,f.EMPTY_OBJECT),this.vertexArray=t.vertexArray,this.fragmentShaderSource=t.fragmentShaderSource,this.shaderProgram=t.shaderProgram,this.uniformMap=t.uniformMap,this.outputTexture=t.outputTexture,this.preExecute=t.preExecute,this.postExecute=t.postExecute,this.canceled=t.canceled,this.persists=f(t.persists,!1),this.pass=Pt.COMPUTE,this.owner=t.owner}rmt.prototype.execute=function(t){t.execute(this)};var Wm=rmt;var qze=R(W(),1);var R3e=R(W(),1);var kHe=R(W(),1);function Un(t,e){this.x=f(t,0),this.y=f(e,0)}Un.fromElements=function(t,e,n){return c(n)?(n.x=t,n.y=e,n):new Un(t,e)};Un.clone=function(t,e){if(c(t))return c(e)?(e.x=t.x,e.y=t.y,e):new Un(t.x,t.y)};Un.fromCartesian3=Un.clone;Un.fromCartesian4=Un.clone;Un.packedLength=2;Un.pack=function(t,e,n){return n=f(n,0),e[n++]=t.x,e[n]=t.y,e};Un.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Un),n.x=t[e++],n.y=t[e],n};Un.packArray=function(t,e){let n=t.length,i=n*2;c(e)?!Array.isArray(e)&&e.length!==i||e.length!==i&&(e.length=i):e=new Array(i);for(let o=0;ok.EPSILON12);return c(o)?(o.x=a*J,o.y=s*M,o.z=l*V,o):new p(a*J,s*M,l*V)}var hG=p_t;function xl(t,e,n){this.longitude=f(t,0),this.latitude=f(e,0),this.height=f(n,0)}xl.fromRadians=function(t,e,n,i){return n=f(n,0),c(i)?(i.longitude=t,i.latitude=e,i.height=n,i):new xl(t,e,n)};xl.fromDegrees=function(t,e,n,i){return t=k.toRadians(t),e=k.toRadians(e),xl.fromRadians(t,e,n,i)};var u_t=new p,Z_t=new p,V_t=new p,b_t=new p(1/6378137,1/6378137,1/6356752314245179e-9),R_t=new p(1/(6378137*6378137),1/(6378137*6378137),1/(6356752314245179e-9*6356752314245179e-9)),W_t=k.EPSILON1;xl.fromCartesian=function(t,e,n){let i=c(e)?e.oneOverRadii:b_t,o=c(e)?e.oneOverRadiiSquared:R_t,a=c(e)?e._centerToleranceSquared:W_t,s=hG(t,i,o,a,Z_t);if(!c(s))return;let l=p.multiplyComponents(s,o,u_t);l=p.normalize(l,l);let r=p.subtract(t,s,V_t),d=Math.atan2(l.y,l.x),m=Math.asin(l.z),h=k.sign(p.dot(r,t))*p.magnitude(r);return c(n)?(n.longitude=d,n.latitude=m,n.height=h,n):new xl(d,m,h)};xl.toCartesian=function(t,e,n){return p.fromRadians(t.longitude,t.latitude,t.height,e,n)};xl.clone=function(t,e){if(c(t))return c(e)?(e.longitude=t.longitude,e.latitude=t.latitude,e.height=t.height,e):new xl(t.longitude,t.latitude,t.height)};xl.equals=function(t,e){return t===e||c(t)&&c(e)&&t.longitude===e.longitude&&t.latitude===e.latitude&&t.height===e.height};xl.equalsEpsilon=function(t,e,n){return n=f(n,0),t===e||c(t)&&c(e)&&Math.abs(t.longitude-e.longitude)<=n&&Math.abs(t.latitude-e.latitude)<=n&&Math.abs(t.height-e.height)<=n};xl.ZERO=Object.freeze(new xl(0,0,0));xl.prototype.clone=function(t){return xl.clone(this,t)};xl.prototype.equals=function(t){return xl.equals(this,t)};xl.prototype.equalsEpsilon=function(t,e){return xl.equalsEpsilon(this,t,e)};xl.prototype.toString=function(){return`(${this.longitude}, ${this.latitude}, ${this.height})`};var gt=xl;var dwe=R(W(),1);var nwe=R(W(),1);function pmt(t,e,n,i){e=f(e,0),n=f(n,0),i=f(i,0),t._radii=new p(e,n,i),t._radiiSquared=new p(e*e,n*n,i*i),t._radiiToTheFourth=new p(e*e*e*e,n*n*n*n,i*i*i*i),t._oneOverRadii=new p(e===0?0:1/e,n===0?0:1/n,i===0?0:1/i),t._oneOverRadiiSquared=new p(e===0?0:1/(e*e),n===0?0:1/(n*n),i===0?0:1/(i*i)),t._minimumRadius=Math.min(e,n,i),t._maximumRadius=Math.max(e,n,i),t._centerToleranceSquared=k.EPSILON1,t._radiiSquared.z!==0&&(t._squaredXOverSquaredZ=t._radiiSquared.x/t._radiiSquared.z)}function oa(t,e,n){this._radii=void 0,this._radiiSquared=void 0,this._radiiToTheFourth=void 0,this._oneOverRadii=void 0,this._oneOverRadiiSquared=void 0,this._minimumRadius=void 0,this._maximumRadius=void 0,this._centerToleranceSquared=void 0,this._squaredXOverSquaredZ=void 0,pmt(this,t,e,n)}Object.defineProperties(oa.prototype,{radii:{get:function(){return this._radii}},radiiSquared:{get:function(){return this._radiiSquared}},radiiToTheFourth:{get:function(){return this._radiiToTheFourth}},oneOverRadii:{get:function(){return this._oneOverRadii}},oneOverRadiiSquared:{get:function(){return this._oneOverRadiiSquared}},minimumRadius:{get:function(){return this._minimumRadius}},maximumRadius:{get:function(){return this._maximumRadius}}});oa.clone=function(t,e){if(!c(t))return;let n=t._radii;return c(e)?(p.clone(n,e._radii),p.clone(t._radiiSquared,e._radiiSquared),p.clone(t._radiiToTheFourth,e._radiiToTheFourth),p.clone(t._oneOverRadii,e._oneOverRadii),p.clone(t._oneOverRadiiSquared,e._oneOverRadiiSquared),e._minimumRadius=t._minimumRadius,e._maximumRadius=t._maximumRadius,e._centerToleranceSquared=t._centerToleranceSquared,e):new oa(n.x,n.y,n.z)};oa.fromCartesian3=function(t,e){return c(e)||(e=new oa),c(t)&&pmt(e,t.x,t.y,t.z),e};oa.WGS84=Object.freeze(new oa(6378137,6378137,6356752314245179e-9));oa.UNIT_SPHERE=Object.freeze(new oa(1,1,1));oa.MOON=Object.freeze(new oa(k.LUNAR_RADIUS,k.LUNAR_RADIUS,k.LUNAR_RADIUS));oa.prototype.clone=function(t){return oa.clone(this,t)};oa.packedLength=p.packedLength;oa.pack=function(t,e,n){return n=f(n,0),p.pack(t._radii,e,n),e};oa.unpack=function(t,e,n){e=f(e,0);let i=p.unpack(t,e);return oa.fromCartesian3(i,n)};oa.prototype.geocentricSurfaceNormal=p.normalize;oa.prototype.geodeticSurfaceNormalCartographic=function(t,e){let n=t.longitude,i=t.latitude,o=Math.cos(i),a=o*Math.cos(n),s=o*Math.sin(n),l=Math.sin(i);return c(e)||(e=new p),e.x=a,e.y=s,e.z=l,p.normalize(e,e)};oa.prototype.geodeticSurfaceNormal=function(t,e){if(!p.equalsEpsilon(t,p.ZERO,k.EPSILON14))return c(e)||(e=new p),e=p.multiplyComponents(t,this._oneOverRadiiSquared,e),p.normalize(e,e)};var f_t=new p,F_t=new p;oa.prototype.cartographicToCartesian=function(t,e){let n=f_t,i=F_t;this.geodeticSurfaceNormalCartographic(t,n),p.multiplyComponents(this._radiiSquared,n,i);let o=Math.sqrt(p.dot(n,i));return p.divideByScalar(i,o,i),p.multiplyByScalar(n,t.height,n),c(e)||(e=new p),p.add(i,n,e)};oa.prototype.cartographicArrayToCartesianArray=function(t,e){let n=t.length;c(e)?e.length=n:e=new Array(n);for(let i=0;i=this._radii.z-e))return n};var T_t=new p;oa.prototype.getLocalCurvature=function(t,e){c(e)||(e=new K);let n=this.getSurfaceNormalIntersectionWithZAxis(t,0,T_t),i=p.distance(t,n),o=this.minimumRadius*i/this.maximumRadius**2,a=i*o**2;return K.fromElements(1/i,1/a,e)};var S_t=[.14887433898163,.43339539412925,.67940956829902,.86506336668898,.97390652851717,0],g_t=[.29552422471475,.26926671930999,.21908636251598,.14945134915058,.066671344308684,0];function hmt(t,e,n){let i=.5*(e+t),o=.5*(e-t),a=0;for(let s=0;s<5;s++){let l=o*S_t[s];a+=g_t[s]*(n(i+l)+n(i-l))}return a*=o,a}oa.prototype.surfaceArea=function(t){let e=t.west,n=t.east,i=t.south,o=t.north;for(;n0){o=a-1;continue}return a}return~(o+1)}var Ja=C_t;var Zwe=R(W(),1);function I_t(t,e,n,i,o){this.xPoleWander=t,this.yPoleWander=e,this.xPoleOffset=n,this.yPoleOffset=i,this.ut1MinusUtc=o}var lf=I_t;var Jwe=R(W(),1);var Gwe=R(W(),1);var bwe=R(W(),1);function N_t(t){return t%4===0&&t%100!==0||t%400===0}var Pu=N_t;var umt=[31,28,31,30,31,30,31,31,30,31,30,31];function y_t(t,e,n,i,o,a,s,l){t=f(t,1),e=f(e,1),n=f(n,1),i=f(i,0),o=f(o,0),a=f(a,0),s=f(s,0),l=f(l,!1),this.year=t,this.month=e,this.day=n,this.hour=i,this.minute=o,this.second=a,this.millisecond=s,this.isLeapSecond=l;function F(){Xa.typeOf.number.greaterThanOrEquals("Year",t,1),Xa.typeOf.number.lessThanOrEquals("Year",t,9999),Xa.typeOf.number.greaterThanOrEquals("Month",e,1),Xa.typeOf.number.lessThanOrEquals("Month",e,12),Xa.typeOf.number.greaterThanOrEquals("Day",n,1),Xa.typeOf.number.lessThanOrEquals("Day",n,31),Xa.typeOf.number.greaterThanOrEquals("Hour",i,0),Xa.typeOf.number.lessThanOrEquals("Hour",i,23),Xa.typeOf.number.greaterThanOrEquals("Minute",o,0),Xa.typeOf.number.lessThanOrEquals("Minute",o,59),Xa.typeOf.bool("IsLeapSecond",l),Xa.typeOf.number.greaterThanOrEquals("Second",a,0),Xa.typeOf.number.lessThanOrEquals("Second",a,l?60:59),Xa.typeOf.number.greaterThanOrEquals("Millisecond",s,0),Xa.typeOf.number.lessThan("Millisecond",s,1e3)}function U(){let G=e===2&&Pu(t)?umt[e-1]+1:umt[e-1];if(n>G)throw new Ut("Month and Day represents invalid date")}}var WR=y_t;var Twe=R(W(),1);function B_t(t,e){this.julianDate=t,this.offset=e}var zo=B_t;var gwe=R(W(),1),Q_t={SECONDS_PER_MILLISECOND:.001,SECONDS_PER_MINUTE:60,MINUTES_PER_HOUR:60,HOURS_PER_DAY:24,SECONDS_PER_HOUR:3600,MINUTES_PER_DAY:1440,SECONDS_PER_DAY:86400,DAYS_PER_JULIAN_CENTURY:36525,PICOSECOND:1e-9,MODIFIED_JULIAN_DATE_DIFFERENCE:24000005e-1},xi=Object.freeze(Q_t);var Cwe=R(W(),1),k_t={UTC:0,TAI:1},Di=Object.freeze(k_t);var Vmt=new WR,b6=[31,28,31,30,31,30,31,31,30,31,30,31],R6=29;function W6(t,e){return mn.compare(t.julianDate,e.julianDate)}var zg=new zo;function uH(t){zg.julianDate=t;let e=mn.leapSeconds,n=Ja(e,zg,W6);n<0&&(n=~n),n>=e.length&&(n=e.length-1);let i=e[n].offset;n>0&&mn.secondsDifference(e[n].julianDate,t)>i&&(n--,i=e[n].offset),mn.addSeconds(t,i,t)}function Zmt(t,e){zg.julianDate=t;let n=mn.leapSeconds,i=Ja(n,zg,W6);if(i<0&&(i=~i),i===0)return mn.addSeconds(t,-n[0].offset,e);if(i>=n.length)return mn.addSeconds(t,-n[i-1].offset,e);let o=mn.secondsDifference(n[i].julianDate,t);if(o===0)return mn.addSeconds(t,-n[i].offset,e);if(!(o<=1))return mn.addSeconds(t,-n[--i].offset,e)}function rf(t,e,n){let i=e/xi.SECONDS_PER_DAY|0;return t+=i,e-=xi.SECONDS_PER_DAY*i,e<0&&(t--,e+=xi.SECONDS_PER_DAY),n.dayNumber=t,n.secondsOfDay=e,n}function f6(t,e,n,i,o,a,s){let l=(e-14)/12|0,r=t+4800+l,d=(1461*r/4|0)+(367*(e-2-12*l)/12|0)-(3*((r+100)/100|0)/4|0)+n-32075;i=i-12,i<0&&(i+=24);let m=a+(i*xi.SECONDS_PER_HOUR+o*xi.SECONDS_PER_MINUTE+s*xi.SECONDS_PER_MILLISECOND);return m>=43200&&(d-=1),[d,m]}var Y_t=/^(\d{4})$/,x_t=/^(\d{4})-(\d{2})$/,X_t=/^(\d{4})-?(\d{3})$/,J_t=/^(\d{4})-?W(\d{2})-?(\d{1})?$/,L_t=/^(\d{4})-?(\d{2})-?(\d{2})$/,F6=/([Z+\-])?(\d{2})?:?(\d{2})?$/,M_t=/^(\d{2})(\.\d+)?/.source+F6.source,__t=/^(\d{2}):?(\d{2})(\.\d+)?/.source+F6.source,D_t=/^(\d{2}):?(\d{2}):?(\d{2})(\.\d+)?/.source+F6.source;function mn(t,e,n){this.dayNumber=void 0,this.secondsOfDay=void 0,t=f(t,0),e=f(e,0),n=f(n,Di.UTC);let i=t|0;e=e+(t-i)*xi.SECONDS_PER_DAY,rf(i,e,this),n===Di.UTC&&uH(this)}mn.fromGregorianDate=function(t,e){let n=f6(t.year,t.month,t.day,t.hour,t.minute,t.second,t.millisecond);return c(e)?(rf(n[0],n[1],e),uH(e),e):new mn(n[0],n[1],Di.UTC)};mn.fromDate=function(t,e){let n=f6(t.getUTCFullYear(),t.getUTCMonth()+1,t.getUTCDate(),t.getUTCHours(),t.getUTCMinutes(),t.getUTCSeconds(),t.getUTCMilliseconds());return c(e)?(rf(n[0],n[1],e),uH(e),e):new mn(n[0],n[1],Di.UTC)};mn.fromIso8601=function(t,e){t=t.replace(",",".");let n=t.split("T"),i,o=1,a=1,s=0,l=0,r=0,d=0,m=n[0],h=n[1],Z,b;if(n=m.match(L_t),n!==null)i=+n[1],o=+n[2],a=+n[3];else if(n=m.match(x_t),n!==null)i=+n[1],o=+n[2];else if(n=m.match(Y_t),n!==null)i=+n[1];else{let G;if(n=m.match(X_t),n!==null)i=+n[1],G=+n[2],b=Pu(i);else if(n=m.match(J_t),n!==null){i=+n[1];let A=+n[2],T=+n[3]||0,g=new Date(Date.UTC(i,0,4));G=A*7+T-g.getUTCDay()-3}Z=new Date(Date.UTC(i,0,1)),Z.setUTCDate(G),o=Z.getUTCMonth()+1,a=Z.getUTCDate()}b=Pu(i);let u;if(c(h)){n=h.match(D_t),n!==null?(s=+n[1],l=+n[2],r=+n[3],d=+(n[4]||0)*1e3,u=5):(n=h.match(__t),n!==null?(s=+n[1],l=+n[2],r=+(n[3]||0)*60,u=4):(n=h.match(M_t),n!==null&&(s=+n[1],l=+(n[2]||0)*60,u=3)));let G=n[u],A=+n[u+1],T=+(n[u+2]||0);switch(G){case"+":s=s-A,l=l-T;break;case"-":s=s+A,l=l+T;break;case"Z":break;default:l=l+new Date(Date.UTC(i,o-1,a,s,l)).getTimezoneOffset();break}}let F=r===60;for(F&&r--;l>=60;)l-=60,s++;for(;s>=24;)s-=24,a++;for(Z=b&&o===2?R6:b6[o-1];a>Z;)a-=Z,o++,o>12&&(o-=12,i++),Z=b&&o===2?R6:b6[o-1];for(;l<0;)l+=60,s--;for(;s<0;)s+=24,a--;for(;a<1;)o--,o<1&&(o+=12,i--),Z=b&&o===2?R6:b6[o-1],a+=Z;let U=f6(i,o,a,s,l,r,d);return c(e)?(rf(U[0],U[1],e),uH(e)):e=new mn(U[0],U[1],Di.UTC),F&&mn.addSeconds(e,1,e),e};mn.now=function(t){return mn.fromDate(new Date,t)};var pH=new mn(0,0,Di.TAI);mn.toGregorianDate=function(t,e){let n=!1,i=Zmt(t,pH);c(i)||(mn.addSeconds(t,-1,pH),i=Zmt(pH,pH),n=!0);let o=i.dayNumber,a=i.secondsOfDay;a>=43200&&(o+=1);let s=o+68569|0,l=4*s/146097|0;s=s-((146097*l+3)/4|0)|0;let r=4e3*(s+1)/1461001|0;s=s-(1461*r/4|0)+31|0;let d=80*s/2447|0,m=s-(2447*d/80|0)|0;s=d/11|0;let h=d+2-12*s|0,Z=100*(l-49)+r+s|0,b=a/xi.SECONDS_PER_HOUR|0,u=a-b*xi.SECONDS_PER_HOUR,F=u/xi.SECONDS_PER_MINUTE|0;u=u-F*xi.SECONDS_PER_MINUTE;let U=u|0,G=(u-U)/xi.SECONDS_PER_MILLISECOND;return b+=12,b>23&&(b-=24),n&&(U+=1),c(e)?(e.year=Z,e.month=h,e.day=m,e.hour=b,e.minute=F,e.second=U,e.millisecond=G,e.isLeapSecond=n,e):new WR(Z,h,m,b,F,U,G,n)};mn.toDate=function(t){let e=mn.toGregorianDate(t,Vmt),n=e.second;return e.isLeapSecond&&(n-=1),new Date(Date.UTC(e.year,e.month-1,e.day,e.hour,e.minute,n,e.millisecond))};mn.toIso8601=function(t,e){let n=mn.toGregorianDate(t,Vmt),i=n.year,o=n.month,a=n.day,s=n.hour,l=n.minute,r=n.second,d=n.millisecond;i===1e4&&o===1&&a===1&&s===0&&l===0&&r===0&&d===0&&(i=9999,o=12,a=31,s=24);let m;return!c(e)&&d!==0?(m=(d*.01).toString().replace(".",""),`${i.toString().padStart(4,"0")}-${o.toString().padStart(2,"0")}-${a.toString().padStart(2,"0")}T${s.toString().padStart(2,"0")}:${l.toString().padStart(2,"0")}:${r.toString().padStart(2,"0")}.${m}Z`):!c(e)||e===0?`${i.toString().padStart(4,"0")}-${o.toString().padStart(2,"0")}-${a.toString().padStart(2,"0")}T${s.toString().padStart(2,"0")}:${l.toString().padStart(2,"0")}:${r.toString().padStart(2,"0")}Z`:(m=(d*.01).toFixed(e).replace(".","").slice(0,e),`${i.toString().padStart(4,"0")}-${o.toString().padStart(2,"0")}-${a.toString().padStart(2,"0")}T${s.toString().padStart(2,"0")}:${l.toString().padStart(2,"0")}:${r.toString().padStart(2,"0")}.${m}Z`)};mn.clone=function(t,e){if(c(t))return c(e)?(e.dayNumber=t.dayNumber,e.secondsOfDay=t.secondsOfDay,e):new mn(t.dayNumber,t.secondsOfDay,Di.TAI)};mn.compare=function(t,e){let n=t.dayNumber-e.dayNumber;return n!==0?n:t.secondsOfDay-e.secondsOfDay};mn.equals=function(t,e){return t===e||c(t)&&c(e)&&t.dayNumber===e.dayNumber&&t.secondsOfDay===e.secondsOfDay};mn.equalsEpsilon=function(t,e,n){return n=f(n,0),t===e||c(t)&&c(e)&&Math.abs(mn.secondsDifference(t,e))<=n};mn.totalDays=function(t){return t.dayNumber+t.secondsOfDay/xi.SECONDS_PER_DAY};mn.secondsDifference=function(t,e){return(t.dayNumber-e.dayNumber)*xi.SECONDS_PER_DAY+(t.secondsOfDay-e.secondsOfDay)};mn.daysDifference=function(t,e){let n=t.dayNumber-e.dayNumber,i=(t.secondsOfDay-e.secondsOfDay)/xi.SECONDS_PER_DAY;return n+i};mn.computeTaiMinusUtc=function(t){zg.julianDate=t;let e=mn.leapSeconds,n=Ja(e,zg,W6);return n<0&&(n=~n,--n,n<0&&(n=0)),e[n].offset};mn.addSeconds=function(t,e,n){return rf(t.dayNumber,t.secondsOfDay+e,n)};mn.addMinutes=function(t,e,n){let i=t.secondsOfDay+e*xi.SECONDS_PER_MINUTE;return rf(t.dayNumber,i,n)};mn.addHours=function(t,e,n){let i=t.secondsOfDay+e*xi.SECONDS_PER_HOUR;return rf(t.dayNumber,i,n)};mn.addDays=function(t,e,n){let i=t.dayNumber+e;return rf(i,t.secondsOfDay,n)};mn.lessThan=function(t,e){return mn.compare(t,e)<0};mn.lessThanOrEquals=function(t,e){return mn.compare(t,e)<=0};mn.greaterThan=function(t,e){return mn.compare(t,e)>0};mn.greaterThanOrEquals=function(t,e){return mn.compare(t,e)>=0};mn.prototype.clone=function(t){return mn.clone(this,t)};mn.prototype.equals=function(t){return mn.equals(this,t)};mn.prototype.equalsEpsilon=function(t,e){return mn.equalsEpsilon(this,t,e)};mn.prototype.toString=function(){return mn.toIso8601(this)};mn.leapSeconds=[new zo(new mn(2441317,43210,Di.TAI),10),new zo(new mn(2441499,43211,Di.TAI),11),new zo(new mn(2441683,43212,Di.TAI),12),new zo(new mn(2442048,43213,Di.TAI),13),new zo(new mn(2442413,43214,Di.TAI),14),new zo(new mn(2442778,43215,Di.TAI),15),new zo(new mn(2443144,43216,Di.TAI),16),new zo(new mn(2443509,43217,Di.TAI),17),new zo(new mn(2443874,43218,Di.TAI),18),new zo(new mn(2444239,43219,Di.TAI),19),new zo(new mn(2444786,43220,Di.TAI),20),new zo(new mn(2445151,43221,Di.TAI),21),new zo(new mn(2445516,43222,Di.TAI),22),new zo(new mn(2446247,43223,Di.TAI),23),new zo(new mn(2447161,43224,Di.TAI),24),new zo(new mn(2447892,43225,Di.TAI),25),new zo(new mn(2448257,43226,Di.TAI),26),new zo(new mn(2448804,43227,Di.TAI),27),new zo(new mn(2449169,43228,Di.TAI),28),new zo(new mn(2449534,43229,Di.TAI),29),new zo(new mn(2450083,43230,Di.TAI),30),new zo(new mn(2450630,43231,Di.TAI),31),new zo(new mn(2451179,43232,Di.TAI),32),new zo(new mn(2453736,43233,Di.TAI),33),new zo(new mn(2454832,43234,Di.TAI),34),new zo(new mn(2456109,43235,Di.TAI),35),new zo(new mn(2457204,43236,Di.TAI),36),new zo(new mn(2457754,43237,Di.TAI),37)];var rt=mn;var Bve=R(W(),1),kmt=R(uh(),1);var Hwe=R(W(),1);function O_t(t){return(t.length===0||t[t.length-1]!=="/")&&(t=`${t}/`),t}var $N=O_t;var vwe=R(W(),1);function Gmt(t,e){if(t===null||typeof t!="object")return t;e=f(e,!1);let n=new t.constructor;for(let i in t)if(t.hasOwnProperty(i)){let o=t[i];e&&(o=Gmt(o,e)),n[i]=o}return n}var be=Gmt;var qwe=R(W(),1);function Amt(t,e,n){n=f(n,!1);let i={},o=c(t),a=c(e),s,l,r;if(o)for(s in t)t.hasOwnProperty(s)&&(l=t[s],a&&n&&typeof l=="object"&&e.hasOwnProperty(s)?(r=e[s],typeof r=="object"?i[s]=Amt(l,r,n):i[s]=l):i[s]=l);if(a)for(s in e)e.hasOwnProperty(s)&&!i.hasOwnProperty(s)&&(r=e[s],i[s]=r);return i}var ze=Amt;var tPe=R(W(),1);function H_t(){let t,e,n=new Promise(function(i,o){t=i,e=o});return{resolve:t,reject:e,promise:n}}var kd=H_t;var oPe=R(W(),1),Tmt=R(uh(),1);function U6(t,e){let n;return typeof document<"u"&&(n=document),U6._implementation(t,e,n)}U6._implementation=function(t,e,n){if(!c(e)){if(typeof n>"u")return t;e=f(n.baseURI,n.location.href)}let i=new Tmt.default(t);return i.scheme()!==""?i.toString():i.absoluteTo(e).toString()};var IV=U6;var sPe=R(W(),1),Smt=R(uh(),1);function w_t(t,e){let n="",i=t.lastIndexOf("/");return i!==-1&&(n=t.substring(0,i+1)),e&&(t=new Smt.default(t),t.query().length!==0&&(n+=`?${t.query()}`),t.fragment().length!==0&&(n+=`#${t.fragment()}`)),n}var ty=w_t;var rPe=R(W(),1),gmt=R(uh(),1);function P_t(t){let e=new gmt.default(t);e.normalize();let n=e.path(),i=n.lastIndexOf("/");return i!==-1&&(n=n.substr(i+1)),i=n.lastIndexOf("."),i===-1?n="":n=n.substr(i+1),n}var pG=P_t;var mPe=R(W(),1);var Emt={};function v_t(t,e,n){c(e)||(e=t.width),c(n)||(n=t.height);let i=Emt[e];c(i)||(i={},Emt[e]=i);let o=i[n];if(!c(o)){let a=document.createElement("canvas");a.width=e,a.height=n,o=a.getContext("2d",{willReadFrequently:!0}),o.globalCompositeOperation="copy",i[n]=o}return o.drawImage(t,0,0,e,n),o.getImageData(0,0,e,n).data}var vu=v_t;var pPe=R(W(),1);var K_t=/^blob:/i;function z_t(t){return K_t.test(t)}var uG=z_t;var VPe=R(W(),1);var NV;function j_t(t){c(NV)||(NV=document.createElement("a")),NV.href=window.location.href;let e=NV.host,n=NV.protocol;return NV.href=t,NV.href=NV.href,n!==NV.protocol||e!==NV.host}var ZG=j_t;var RPe=R(W(),1);var q_t=/^data:/i;function $_t(t){return q_t.test(t)}var fR=$_t;var fPe=R(W(),1);function t9t(t){let e=document.createElement("script");return e.async=!0,e.src=t,new Promise((n,i)=>{window.crossOriginIsolated&&e.setAttribute("crossorigin","anonymous");let o=document.getElementsByTagName("head")[0];e.onload=function(){e.onload=void 0,o.removeChild(e),n()},e.onerror=function(a){i(a)},o.appendChild(e)})}var VG=t9t;var UPe=R(W(),1);function e9t(t){let e="";for(let n in t)if(t.hasOwnProperty(n)){let i=t[n],o=`${encodeURIComponent(n)}=`;if(Array.isArray(i))for(let a=0,s=i.length;a0){let s=o.substring(0,a),l=o.substring(a+2);e[s]=l}}return e}var ey=a9t;function Cmt(t,e,n){this.statusCode=t,this.response=e,this.responseHeaders=n,typeof this.responseHeaders=="string"&&(this.responseHeaders=ey(this.responseHeaders))}Cmt.prototype.toString=function(){let t="Request has failed.";return c(this.statusCode)&&(t+=` Status Code: ${this.statusCode}`),t};var yV=Cmt;var ove=R(W(),1),WH=R(uh(),1);var OPe=R(W(),1);function ny(){this._listeners=[],this._scopes=[],this._toRemove=[],this._insideRaiseEvent=!1}Object.defineProperties(ny.prototype,{numberOfListeners:{get:function(){return this._listeners.length-this._toRemove.length}}});ny.prototype.addEventListener=function(t,e){this._listeners.push(t),this._scopes.push(e);let n=this;return function(){n.removeEventListener(t,e)}};ny.prototype.removeEventListener=function(t,e){let n=this._listeners,i=this._scopes,o=-1;for(let a=0;a0){for(o.sort(s9t),t=0;t=0;--e)this.heapify(e)};RG.prototype.insert=function(t){let e=this._array,n=this._comparator,i=this._maximumLength,o=this._length++;for(oi&&(a=e[i],this._length=i),a};RG.prototype.pop=function(t){if(t=f(t,0),this._length===0)return;let e=this._array,n=e[t];return G6(e,t,--this._length),this.heapify(t),e[this._length]=void 0,n};var iy=RG;function l9t(t,e){return t.priority-e.priority}var ha={numberOfAttemptedRequests:0,numberOfActiveRequests:0,numberOfCancelledRequests:0,numberOfCancelledActiveRequests:0,numberOfFailedRequests:0,numberOfActiveRequestsEver:0,lastNumberOfActiveRequests:0},$g=20,Yd=new iy({comparator:l9t});Yd.maximumLength=$g;Yd.reserve($g);var BV=[],FR={},r9t=typeof document<"u"?new WH.default(document.location.href):new WH.default,fH=new It;function Vs(){}Vs.maximumRequests=50;Vs.maximumRequestsPerServer=18;Vs.requestsByServer={};Vs.throttleRequests=!0;Vs.debugShowStatistics=!1;Vs.requestCompletedEvent=fH;Object.defineProperties(Vs,{statistics:{get:function(){return ha}},priorityHeapLength:{get:function(){return $g},set:function(t){if(t<$g)for(;Yd.length>t;){let e=Yd.pop();WG(e)}$g=t,Yd.maximumLength=t,Yd.reserve(t)}}});function Imt(t){c(t.priorityFunction)&&(t.priority=t.priorityFunction())}Vs.serverHasOpenSlots=function(t,e){e=f(e,1);let n=f(Vs.requestsByServer[t],Vs.maximumRequestsPerServer);return FR[t]+e<=n};Vs.heapHasOpenSlots=function(t){return Yd.length+t<=$g};function Nmt(t){return t.state===qi.UNISSUED&&(t.state=qi.ISSUED,t.deferred=kd()),t.deferred.promise}function d9t(t){return function(e){if(t.state===qi.CANCELLED)return;let n=t.deferred;--ha.numberOfActiveRequests,--FR[t.serverKey],fH.raiseEvent(),t.state=qi.RECEIVED,t.deferred=void 0,n.resolve(e)}}function c9t(t){return function(e){t.state!==qi.CANCELLED&&(++ha.numberOfFailedRequests,--ha.numberOfActiveRequests,--FR[t.serverKey],fH.raiseEvent(e),t.state=qi.FAILED,t.deferred.reject(e))}}function ymt(t){let e=Nmt(t);return t.state=qi.ACTIVE,BV.push(t),++ha.numberOfActiveRequests,++ha.numberOfActiveRequestsEver,++FR[t.serverKey],t.requestFunction().then(d9t(t)).catch(c9t(t)),e}function WG(t){let e=t.state===qi.ACTIVE;if(t.state=qi.CANCELLED,++ha.numberOfCancelledRequests,c(t.deferred)){let n=t.deferred;t.deferred=void 0,n.reject()}e&&(--ha.numberOfActiveRequests,--FR[t.serverKey],++ha.numberOfCancelledActiveRequests),c(t.cancelFunction)&&t.cancelFunction()}Vs.update=function(){let t,e,n=0,i=BV.length;for(t=0;t0&&(BV[t-n]=e)}BV.length-=n;let o=Yd.internalArray,a=Yd.length;for(t=0;t0;){if(e=Yd.pop(),e.cancelled){WG(e);continue}if(e.throttleByServer&&!Vs.serverHasOpenSlots(e.serverKey)){WG(e);continue}ymt(e),++l}m9t()};Vs.getServerKey=function(t){let e=new WH.default(t);e.scheme()===""&&(e=e.absoluteTo(r9t),e.normalize());let n=e.authority();/:/.test(n)||(n=`${n}:${e.scheme()==="https"?"443":"80"}`);let i=FR[n];return c(i)||(FR[n]=0),n};Vs.request=function(t){if(fR(t.url)||uG(t.url))return fH.raiseEvent(),t.state=qi.RECEIVED,t.requestFunction();if(++ha.numberOfAttemptedRequests,c(t.serverKey)||(t.serverKey=Vs.getServerKey(t.url)),Vs.throttleRequests&&t.throttleByServer&&!Vs.serverHasOpenSlots(t.serverKey))return;if(!Vs.throttleRequests||!t.throttle)return ymt(t);if(BV.length>=Vs.maximumRequests)return;Imt(t);let e=Yd.insert(t);if(c(e)){if(e===t)return;WG(e)}return Nmt(t)};function m9t(){Vs.debugShowStatistics&&(ha.numberOfActiveRequests===0&&ha.lastNumberOfActiveRequests>0&&(ha.numberOfAttemptedRequests>0&&(console.log(`Number of attempted requests: ${ha.numberOfAttemptedRequests}`),ha.numberOfAttemptedRequests=0),ha.numberOfCancelledRequests>0&&(console.log(`Number of cancelled requests: ${ha.numberOfCancelledRequests}`),ha.numberOfCancelledRequests=0),ha.numberOfCancelledActiveRequests>0&&(console.log(`Number of cancelled active requests: ${ha.numberOfCancelledActiveRequests}`),ha.numberOfCancelledActiveRequests=0),ha.numberOfFailedRequests>0&&(console.log(`Number of failed requests: ${ha.numberOfFailedRequests}`),ha.numberOfFailedRequests=0)),ha.lastNumberOfActiveRequests=ha.numberOfActiveRequests)}Vs.clearForSpecs=function(){for(;Yd.length>0;){let e=Yd.pop();WG(e)}let t=BV.length;for(let e=0;e0}},credits:{get:function(){return this._credits}}});cn.prototype.toString=function(){return this.getUrlComponent(!0,!0)};cn.prototype.parseUrl=function(t,e,n,i){let o=new kmt.default(t),a=p9t(o.query());this._queryParameters=e?UH(a,this.queryParameters,n):a,o.search(""),o.fragment(""),c(i)&&o.scheme()===""&&(o=o.absoluteTo(IV(i))),this._url=o.toString()};function p9t(t){return t.length===0?{}:t.indexOf("=")===-1?{[t]:void 0}:Tc(t)}function UH(t,e,n){if(!n)return ze(t,e);let i=be(t,!0);for(let o in e)if(e.hasOwnProperty(o)){let a=i[o],s=e[o];c(a)?(Array.isArray(a)||(a=i[o]=[a]),i[o]=a.concat(s)):i[o]=Array.isArray(s)?s.slice():s}return i}cn.prototype.getUrlComponent=function(t,e){if(this.isDataUri)return this._url;let n=this._url;t&&(n=`${n}${u9t(this.queryParameters)}`),n=n.replace(/%7B/g,"{").replace(/%7D/g,"}");let i=this._templateValues;return Object.keys(i).length>0&&(n=n.replace(/{(.*?)}/g,function(o,a){let s=i[a];return c(s)?encodeURIComponent(s):o})),e&&c(this.proxy)&&(n=this.proxy.getURL(n)),n};function u9t(t){let e=Object.keys(t);return e.length===0?"":e.length===1&&!c(t[e[0]])?`?${e[0]}`:`?${bG(t)}`}cn.prototype.setQueryParameters=function(t,e){e?this._queryParameters=UH(this._queryParameters,t,!1):this._queryParameters=UH(t,this._queryParameters,!1)};cn.prototype.appendQueryParameters=function(t){this._queryParameters=UH(t,this._queryParameters,!0)};cn.prototype.setTemplateValues=function(t,e){e?this._templateValues=ze(this._templateValues,t):this._templateValues=ze(t,this._templateValues)};cn.prototype.getDerivedResource=function(t){let e=this.clone();if(e._retryCount=0,c(t.url)){let n=f(t.preserveQueryParameters,!1);e.parseUrl(t.url,!0,n,this._url)}return c(t.queryParameters)&&(e._queryParameters=ze(t.queryParameters,e.queryParameters)),c(t.templateValues)&&(e._templateValues=ze(t.templateValues,e.templateValues)),c(t.headers)&&(e.headers=ze(t.headers,e.headers)),c(t.proxy)&&(e.proxy=t.proxy),c(t.request)&&(e.request=t.request),c(t.retryCallback)&&(e.retryCallback=t.retryCallback),c(t.retryAttempts)&&(e.retryAttempts=t.retryAttempts),e};cn.prototype.retryOnError=function(t){let e=this.retryCallback;if(typeof e!="function"||this._retryCount>=this.retryAttempts)return Promise.resolve(!1);let n=this;return Promise.resolve(e(this,t)).then(function(i){return++n._retryCount,i})};cn.prototype.clone=function(t){return c(t)?(t._url=this._url,t._queryParameters=be(this._queryParameters),t._templateValues=be(this._templateValues),t.headers=be(this.headers),t.proxy=this.proxy,t.retryCallback=this.retryCallback,t.retryAttempts=this.retryAttempts,t._retryCount=0,t.request=this.request.clone(),t):new cn({url:this._url,queryParameters:this.queryParameters,templateValues:this.templateValues,headers:this.headers,proxy:this.proxy,retryCallback:this.retryCallback,retryAttempts:this.retryAttempts,request:this.request.clone(),parseUrl:!1,credits:c(this.credits)?this.credits.slice():void 0})};cn.prototype.getBaseUri=function(t){return ty(this.getUrlComponent(t),t)};cn.prototype.appendForwardSlash=function(){this._url=$N(this._url)};cn.prototype.fetchArrayBuffer=function(){return this.fetch({responseType:"arraybuffer"})};cn.fetchArrayBuffer=function(t){return new cn(t).fetchArrayBuffer()};cn.prototype.fetchBlob=function(){return this.fetch({responseType:"blob"})};cn.fetchBlob=function(t){return new cn(t).fetchBlob()};cn.prototype.fetchImage=function(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.preferImageBitmap,!1),n=f(t.preferBlob,!1),i=f(t.flipY,!1),o=f(t.skipColorSpaceConversion,!1);if(T6(this.request),!Ymt||this.isDataUri||this.isBlobUri||!this.hasHeaders&&!n)return A6({resource:this,flipY:i,skipColorSpaceConversion:o,preferImageBitmap:e});let a=this.fetchBlob();if(!c(a))return;let s,l,r,d;return cn.supportsImageBitmapOptions().then(function(m){return s=m,l=s&&e,a}).then(function(m){if(!c(m))return;if(d=m,l)return cn.createImageBitmapFromBlob(m,{flipY:i,premultiplyAlpha:!1,skipColorSpaceConversion:o});let h=window.URL.createObjectURL(m);return r=new cn({url:h}),A6({resource:r,flipY:i,skipColorSpaceConversion:o,preferImageBitmap:!1})}).then(function(m){if(c(m))return m.blob=d,l||window.URL.revokeObjectURL(r.url),m}).catch(function(m){return c(r)&&window.URL.revokeObjectURL(r.url),m.blob=d,Promise.reject(m)})};function A6(t){let e=t.resource,n=t.flipY,i=t.skipColorSpaceConversion,o=t.preferImageBitmap,a=e.request;a.url=e.url,a.requestFunction=function(){let l=!1;!e.isDataUri&&!e.isBlobUri&&(l=e.isCrossOriginUrl);let r=kd();return cn._Implementations.createImage(a,l,r,n,i,o),r.promise};let s=xd.request(a);if(c(s))return s.catch(function(l){return a.state!==qi.FAILED?Promise.reject(l):e.retryOnError(l).then(function(r){return r?(a.state=qi.UNISSUED,a.deferred=void 0,A6({resource:e,flipY:n,skipColorSpaceConversion:i,preferImageBitmap:o})):Promise.reject(l)})})}cn.fetchImage=function(t){return new cn(t).fetchImage({flipY:t.flipY,skipColorSpaceConversion:t.skipColorSpaceConversion,preferBlob:t.preferBlob,preferImageBitmap:t.preferImageBitmap})};cn.prototype.fetchText=function(){return this.fetch({responseType:"text"})};cn.fetchText=function(t){return new cn(t).fetchText()};cn.prototype.fetchJson=function(){let t=this.fetch({responseType:"text",headers:{Accept:"application/json,*/*;q=0.01"}});if(c(t))return t.then(function(e){if(c(e))return JSON.parse(e)})};cn.fetchJson=function(t){return new cn(t).fetchJson()};cn.prototype.fetchXML=function(){return this.fetch({responseType:"document",overrideMimeType:"text/xml"})};cn.fetchXML=function(t){return new cn(t).fetchXML()};cn.prototype.fetchJsonp=function(t){t=f(t,"callback"),T6(this.request);let e;do e=`loadJsonp${k.nextRandomNumber().toString().substring(2,8)}`;while(c(window[e]));return xmt(this,t,e)};function xmt(t,e,n){let i={};i[e]=n,t.setQueryParameters(i);let o=t.request,a=t.url;o.url=a,o.requestFunction=function(){let l=kd();return window[n]=function(r){l.resolve(r);try{delete window[n]}catch{window[n]=void 0}},cn._Implementations.loadAndExecuteScript(a,n,l),l.promise};let s=xd.request(o);if(c(s))return s.catch(function(l){return o.state!==qi.FAILED?Promise.reject(l):t.retryOnError(l).then(function(r){return r?(o.state=qi.UNISSUED,o.deferred=void 0,xmt(t,e,n)):Promise.reject(l)})})}cn.fetchJsonp=function(t){return new cn(t).fetchJsonp(t.callbackParameterName)};cn.prototype._makeRequest=function(t){let e=this;T6(e.request);let n=e.request,i=e.url;n.url=i,n.requestFunction=function(){let a=t.responseType,s=ze(t.headers,e.headers),l=t.overrideMimeType,r=t.method,d=t.data,m=kd(),h=cn._Implementations.loadWithXhr(i,a,r,d,s,m,l);return c(h)&&c(h.abort)&&(n.cancelFunction=function(){h.abort()}),m.promise};let o=xd.request(n);if(c(o))return o.then(function(a){return n.cancelFunction=void 0,a}).catch(function(a){return n.cancelFunction=void 0,n.state!==qi.FAILED?Promise.reject(a):e.retryOnError(a).then(function(s){return s?(n.state=qi.UNISSUED,n.deferred=void 0,e.fetch(t)):Promise.reject(a)})})};function T6(t){if(t.state===qi.ISSUED||t.state===qi.ACTIVE)throw new St("The Resource is already being fetched.");t.state=qi.UNISSUED,t.deferred=void 0}var Z9t=/^data:(.*?)(;base64)?,(.*)$/;function FH(t,e){let n=decodeURIComponent(e);return t?atob(n):n}function Qmt(t,e){let n=FH(t,e),i=new ArrayBuffer(n.length),o=new Uint8Array(i);for(let a=0;a{if(!l.ok){let r={};l.headers.forEach((d,m)=>{r[m]=d}),a.reject(new yV(l.status,l,r));return}switch(e){case"text":a.resolve(l.text());break;case"json":a.resolve(l.json());break;default:a.resolve(new Uint8Array(await l.arrayBuffer()).buffer);break}}).catch(()=>{a.reject(new yV)})}var R9t=typeof XMLHttpRequest>"u";cn._Implementations.loadWithXhr=function(t,e,n,i,o,a,s){let l=Z9t.exec(t);if(l!==null){a.resolve(V9t(l,e));return}if(R9t){b9t(t,e,n,i,o,a,s);return}let r=new XMLHttpRequest;if(eE.contains(t)&&(r.withCredentials=!0),r.open(n,t,!0),c(s)&&c(r.overrideMimeType)&&r.overrideMimeType(s),c(o))for(let m in o)o.hasOwnProperty(m)&&r.setRequestHeader(m,o[m]);c(e)&&(r.responseType=e);let d=!1;return typeof t=="string"&&(d=t.indexOf("file://")===0||typeof window<"u"&&window.location.origin==="file://"),r.onload=function(){if((r.status<200||r.status>=300)&&!(d&&r.status===0)){a.reject(new yV(r.status,r.response,r.getAllResponseHeaders()));return}let m=r.response,h=r.responseType;if(n==="HEAD"||n==="OPTIONS"){let b=r.getAllResponseHeaders().trim().split(/[\r\n]+/),u={};b.forEach(function(F){let U=F.split(": "),G=U.shift();u[G]=U.join(": ")}),a.resolve(u);return}if(r.status===204)a.resolve(void 0);else if(c(m)&&(!c(e)||h===e))a.resolve(m);else if(e==="json"&&typeof m=="string")try{a.resolve(JSON.parse(m))}catch(Z){a.reject(Z)}else(h===""||h==="document")&&c(r.responseXML)&&r.responseXML.hasChildNodes()?a.resolve(r.responseXML):(h===""||h==="text")&&c(r.responseText)?a.resolve(r.responseText):a.reject(new St("Invalid XMLHttpRequest response type."))},r.onerror=function(m){a.reject(new yV)},r.send(i),r};cn._Implementations.loadAndExecuteScript=function(t,e,n){return VG(t,e).catch(function(i){n.reject(i)})};cn._DefaultImplementations={};cn._DefaultImplementations.createImage=cn._Implementations.createImage;cn._DefaultImplementations.loadWithXhr=cn._Implementations.loadWithXhr;cn._DefaultImplementations.loadAndExecuteScript=cn._Implementations.loadAndExecuteScript;cn.DEFAULT=Object.freeze(new cn({url:typeof document>"u"?"":document.location.href.split("?")[0]}));var te=cn;function sy(t){t=f(t,f.EMPTY_OBJECT),this._dates=void 0,this._samples=void 0,this._dateColumn=-1,this._xPoleWanderRadiansColumn=-1,this._yPoleWanderRadiansColumn=-1,this._ut1MinusUtcSecondsColumn=-1,this._xCelestialPoleOffsetRadiansColumn=-1,this._yCelestialPoleOffsetRadiansColumn=-1,this._taiMinusUtcSecondsColumn=-1,this._columnCount=0,this._lastIndex=-1,this._addNewLeapSeconds=f(t.addNewLeapSeconds,!0),c(t.data)?Xmt(this,t.data):Xmt(this,{columnNames:["dateIso8601","modifiedJulianDateUtc","xPoleWanderRadians","yPoleWanderRadians","ut1MinusUtcSeconds","lengthOfDayCorrectionSeconds","xCelestialPoleOffsetRadians","yCelestialPoleOffsetRadians","taiMinusUtcSeconds"],samples:[]})}sy.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=te.createIfNeeded(t),i;try{i=await n.fetchJson()}catch{throw new St(`An error occurred while retrieving the EOP data from the URL ${n.url}.`)}return new sy({addNewLeapSeconds:e.addNewLeapSeconds,data:i})};sy.NONE=Object.freeze({compute:function(t,e){return c(e)?(e.xPoleWander=0,e.yPoleWander=0,e.xPoleOffset=0,e.yPoleOffset=0,e.ut1MinusUtc=0):e=new lf(0,0,0,0,0),e}});sy.prototype.compute=function(t,e){if(!c(this._samples))return;if(c(e)||(e=new lf(0,0,0,0,0)),this._samples.length===0)return e.xPoleWander=0,e.yPoleWander=0,e.xPoleOffset=0,e.yPoleOffset=0,e.ut1MinusUtc=0,e;let n=this._dates,i=this._lastIndex,o=0,a=0;if(c(i)){let l=n[i],r=n[i+1],d=rt.lessThanOrEquals(l,t),m=!c(r),h=m||rt.greaterThanOrEquals(r,t);if(d&&h)return o=i,!m&&r.equals(t)&&++o,a=o+1,Lmt(this,n,this._samples,t,o,a,e),e}let s=Ja(n,t,rt.compare,this._dateColumn);return s>=0?(se.length-1)return s.xPoleWander=0,s.yPoleWander=0,s.xPoleOffset=0,s.yPoleOffset=0,s.ut1MinusUtc=0,s;let r=e[o],d=e[a];if(r.equals(d)||i.equals(r))return Jmt(t,n,o,l,s),s;if(i.equals(d))return Jmt(t,n,a,l,s),s;let m=rt.secondsDifference(i,r)/rt.secondsDifference(d,r),h=o*l,Z=a*l,b=n[h+t._ut1MinusUtcSecondsColumn],u=n[Z+t._ut1MinusUtcSecondsColumn],F=u-b;if(F>.5||F<-.5){let U=n[h+t._taiMinusUtcSecondsColumn],G=n[Z+t._taiMinusUtcSecondsColumn];U!==G&&(d.equals(i)?b=u:u-=G-U)}return s.xPoleWander=ay(m,n[h+t._xPoleWanderRadiansColumn],n[Z+t._xPoleWanderRadiansColumn]),s.yPoleWander=ay(m,n[h+t._yPoleWanderRadiansColumn],n[Z+t._yPoleWanderRadiansColumn]),s.xPoleOffset=ay(m,n[h+t._xCelestialPoleOffsetRadiansColumn],n[Z+t._xCelestialPoleOffsetRadiansColumn]),s.yPoleOffset=ay(m,n[h+t._yCelestialPoleOffsetRadiansColumn],n[Z+t._yCelestialPoleOffsetRadiansColumn]),s.ut1MinusUtc=ay(m,b,u),s}var ly=sy;var rKe=R(W(),1);var $ve=R(W(),1);function Qe(t,e,n,i){this.x=f(t,0),this.y=f(e,0),this.z=f(n,0),this.w=f(i,0)}var ry=new p;Qe.fromAxisAngle=function(t,e,n){let i=e/2,o=Math.sin(i);ry=p.normalize(t,ry);let a=ry.x*o,s=ry.y*o,l=ry.z*o,r=Math.cos(i);return c(n)?(n.x=a,n.y=s,n.z=l,n.w=r,n):new Qe(a,s,l,r)};var f9t=[1,2,0],F9t=new Array(3);Qe.fromRotationMatrix=function(t,e){let n,i,o,a,s,l=t[ot.COLUMN0ROW0],r=t[ot.COLUMN1ROW1],d=t[ot.COLUMN2ROW2],m=l+r+d;if(m>0)n=Math.sqrt(m+1),s=.5*n,n=.5/n,i=(t[ot.COLUMN1ROW2]-t[ot.COLUMN2ROW1])*n,o=(t[ot.COLUMN2ROW0]-t[ot.COLUMN0ROW2])*n,a=(t[ot.COLUMN0ROW1]-t[ot.COLUMN1ROW0])*n;else{let h=f9t,Z=0;r>l&&(Z=1),d>l&&d>r&&(Z=2);let b=h[Z],u=h[b];n=Math.sqrt(t[ot.getElementIndex(Z,Z)]-t[ot.getElementIndex(b,b)]-t[ot.getElementIndex(u,u)]+1);let F=F9t;F[Z]=.5*n,n=.5/n,s=(t[ot.getElementIndex(u,b)]-t[ot.getElementIndex(b,u)])*n,F[b]=(t[ot.getElementIndex(b,Z)]+t[ot.getElementIndex(Z,b)])*n,F[u]=(t[ot.getElementIndex(u,Z)]+t[ot.getElementIndex(Z,u)])*n,i=-F[0],o=-F[1],a=-F[2]}return c(e)?(e.x=i,e.y=o,e.z=a,e.w=s,e):new Qe(i,o,a,s)};var Mmt=new Qe,_mt=new Qe,S6=new Qe,Dmt=new Qe;Qe.fromHeadingPitchRoll=function(t,e){return Dmt=Qe.fromAxisAngle(p.UNIT_X,t.roll,Mmt),S6=Qe.fromAxisAngle(p.UNIT_Y,-t.pitch,e),e=Qe.multiply(S6,Dmt,S6),_mt=Qe.fromAxisAngle(p.UNIT_Z,-t.heading,Mmt),Qe.multiply(_mt,e,e)};var GH=new p,g6=new p,Ku=new Qe,Omt=new Qe,AH=new Qe;Qe.packedLength=4;Qe.pack=function(t,e,n){return n=f(n,0),e[n++]=t.x,e[n++]=t.y,e[n++]=t.z,e[n]=t.w,e};Qe.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Qe),n.x=t[e],n.y=t[e+1],n.z=t[e+2],n.w=t[e+3],n};Qe.packedInterpolationLength=3;Qe.convertPackedArrayForInterpolation=function(t,e,n,i){Qe.unpack(t,n*4,AH),Qe.conjugate(AH,AH);for(let o=0,a=n-e+1;o=0?a=1:(a=-1,o=-o);let s=o-1,l=1-n,r=n*n,d=l*l;for(let b=7;b>=0;--b)UR[b]=(TH[b]*r-SH[b])*s,GR[b]=(TH[b]*d-SH[b])*s;let m=a*n*(1+UR[0]*(1+UR[1]*(1+UR[2]*(1+UR[3]*(1+UR[4]*(1+UR[5]*(1+UR[6]*(1+UR[7])))))))),h=l*(1+GR[0]*(1+GR[1]*(1+GR[2]*(1+GR[3]*(1+GR[4]*(1+GR[5]*(1+GR[6]*(1+GR[7])))))))),Z=Qe.multiplyByScalar(t,h,A9t);return Qe.multiplyByScalar(e,m,i),Qe.add(Z,i,i)};Qe.fastSquad=function(t,e,n,i,o,a){let s=Qe.fastSlerp(t,e,o,dy),l=Qe.fastSlerp(n,i,o,iE);return Qe.fastSlerp(s,l,2*o*(1-o),a)};Qe.equals=function(t,e){return t===e||c(t)&&c(e)&&t.x===e.x&&t.y===e.y&&t.z===e.z&&t.w===e.w};Qe.equalsEpsilon=function(t,e,n){return n=f(n,0),t===e||c(t)&&c(e)&&Math.abs(t.x-e.x)<=n&&Math.abs(t.y-e.y)<=n&&Math.abs(t.z-e.z)<=n&&Math.abs(t.w-e.w)<=n};Qe.ZERO=Object.freeze(new Qe(0,0,0,0));Qe.IDENTITY=Object.freeze(new Qe(0,0,0,1));Qe.prototype.clone=function(t){return Qe.clone(this,t)};Qe.prototype.equals=function(t){return Qe.equals(this,t)};Qe.prototype.equalsEpsilon=function(t,e){return Qe.equalsEpsilon(this,t,e)};Qe.prototype.toString=function(){return`(${this.x}, ${this.y}, ${this.z}, ${this.w})`};var wt=Qe;function Xd(t,e,n){this.heading=f(t,0),this.pitch=f(e,0),this.roll=f(n,0)}Xd.fromQuaternion=function(t,e,n){c(e)||(e=new Xd);let i,o;if(c(n)){if(typeof n=="function")i=n();else if(n instanceof L)i=n;else throw new Ut("referenceFrame must be a Matrix4 or a function returning a Matrix4");let m=L.inverse(i,new L),h=L.getRotation(m,new ot),Z=wt.fromRotationMatrix(h,new wt);o=wt.multiply(Z,t,new wt)}else o=t;let a=2*(o.w*o.y-o.z*o.x),s=1-2*(o.x*o.x+o.y*o.y),l=2*(o.w*o.x+o.y*o.z),r=1-2*(o.y*o.y+o.z*o.z),d=2*(o.w*o.z+o.x*o.y);return e.heading=-Math.atan2(d,r),e.roll=Math.atan2(l,s),e.pitch=-k.asinClamped(a),e};Xd.fromDegrees=function(t,e,n,i){return c(i)||(i=new Xd),i.heading=t*k.RADIANS_PER_DEGREE,i.pitch=e*k.RADIANS_PER_DEGREE,i.roll=n*k.RADIANS_PER_DEGREE,i};Xd.clone=function(t,e){if(c(t))return c(e)?(e.heading=t.heading,e.pitch=t.pitch,e.roll=t.roll,e):new Xd(t.heading,t.pitch,t.roll)};Xd.equals=function(t,e){return t===e||c(t)&&c(e)&&t.heading===e.heading&&t.pitch===e.pitch&&t.roll===e.roll};Xd.equalsEpsilon=function(t,e,n,i){return t===e||c(t)&&c(e)&&k.equalsEpsilon(t.heading,e.heading,n,i)&&k.equalsEpsilon(t.pitch,e.pitch,n,i)&&k.equalsEpsilon(t.roll,e.roll,n,i)};Xd.prototype.clone=function(t){return Xd.clone(this,t)};Xd.prototype.equals=function(t){return Xd.equals(this,t)};Xd.prototype.equalsEpsilon=function(t,e,n){return Xd.equalsEpsilon(this,t,e,n)};Xd.prototype.toString=function(){return`(${this.heading}, ${this.pitch}, ${this.roll})`};var Jr=Xd;var CKe=R(W(),1);var VKe=R(W(),1);var cKe=R(W(),1),N6={},gH=[],Pmt={},EH={};var y6={};var vmt={};var Kmt=/((?:.*\/)|^)Cesium\.js(?:\?|\#|$)/;function T9t(){let t=document.getElementsByTagName("script");for(let e=0,n=t.length;e"u"?t:(c(CH)||(CH=document.createElement("a")),CH.href=t,CH.href)}var fG;function jmt(){if(c(fG))return fG;let t;return typeof CESIUM_BASE_URL<"u"?t=CESIUM_BASE_URL:c(vmt?.url)?t=IV(".",vmt.url):typeof define=="object"&&c(define.amd)&&!define.amd.toUrlUndefined&&c(Og.toUrl)?t=IV("..",FG("Core/buildModuleUrl.js")):t=T9t(),fG=new te({url:zmt(t)}),fG.appendForwardSlash(),fG}function S9t(t){return zmt(Og.toUrl(`../${t}`))}function qmt(t){return jmt().getDerivedResource({url:t}).url}var IH;function FG(t){return N6[t]?N6[t]:(c(IH)||(typeof define=="object"&&c(define.amd)&&!define.amd.toUrlUndefined&&c(Og.toUrl)?IH=S9t:IH=qmt),IH(t))}FG._cesiumScriptRegex=Kmt;FG._buildModuleUrlFromBaseUrl=qmt;FG._clearBaseResource=function(){fG=void 0};FG.setBaseUrl=function(t){fG=te.DEFAULT.getDerivedResource({url:t})};FG.getCesiumBaseUrl=jmt;var Dn=FG;var WKe=R(W(),1);function g9t(t,e,n){this.x=t,this.y=e,this.s=n}var UG=g9t;function k6(t){t=f(t,f.EMPTY_OBJECT),this._xysFileUrlTemplate=te.createIfNeeded(t.xysFileUrlTemplate),this._interpolationOrder=f(t.interpolationOrder,9),this._sampleZeroJulianEphemerisDate=f(t.sampleZeroJulianEphemerisDate,24423965e-1),this._sampleZeroDateTT=new rt(this._sampleZeroJulianEphemerisDate,0,Di.TAI),this._stepSizeDays=f(t.stepSizeDays,1),this._samplesPerXysFile=f(t.samplesPerXysFile,1e3),this._totalSamples=f(t.totalSamples,27426),this._samples=Pmt||new Array(this._totalSamples*3),this._chunkDownloadsInProgress=[];let e=this._interpolationOrder,n=this._denominators=new Array(e+1),i=this._xTable=new Array(e+1),o=Math.pow(this._stepSizeDays,e);for(let a=0;a<=e;++a){n[a]=o,i[a]=a*this._stepSizeDays;for(let s=0;s<=e;++s)s!==a&&(n[a]*=a-s);n[a]=1/n[a]}this._work=new Array(e+1),this._coef=new Array(e+1)}var E9t=new rt(0,0,Di.TAI);function B6(t,e,n){let i=E9t;return i.dayNumber=e,i.secondsOfDay=n,rt.daysDifference(i,t._sampleZeroDateTT)}k6.prototype.preload=function(t,e,n,i){let o=B6(this,t,e),a=B6(this,n,i),s=o/this._stepSizeDays-this._interpolationOrder/2|0;s<0&&(s=0);let l=a/this._stepSizeDays-this._interpolationOrder/2|0+this._interpolationOrder;l>=this._totalSamples&&(l=this._totalSamples-1);let r=s/this._samplesPerXysFile|0,d=l/this._samplesPerXysFile|0,m=[];for(let h=r;h<=d;++h)m.push(Q6(this,h));return Promise.all(m)};k6.prototype.computeXysRadians=function(t,e,n){let i=B6(this,t,e);if(i<0)return;let o=i/this._stepSizeDays|0;if(o>=this._totalSamples)return;let a=this._interpolationOrder,s=o-(a/2|0);s<0&&(s=0);let l=s+a;l>=this._totalSamples&&(l=this._totalSamples-1,s=l-a,s<0&&(s=0));let r=!1,d=this._samples;if(c(d[s*3])||(Q6(this,s/this._samplesPerXysFile|0),r=!0),c(d[l*3])||(Q6(this,l/this._samplesPerXysFile|0),r=!0),r)return;c(n)?(n.x=0,n.y=0,n.s=0):n=new UG(0,0,0);let m=i-s*this._stepSizeDays,h=this._work,Z=this._denominators,b=this._coef,u=this._xTable,F,U;for(F=0;F<=a;++F)h[F]=m-u[F];for(F=0;F<=a;++F){for(b[F]=1,U=0;U<=a;++U)U!==F&&(b[F]*=h[U]);b[F]*=Z[F];let G=(s+F)*3;n.x+=b[F]*d[G++],n.y+=b[F]*d[G++],n.s+=b[F]*d[G]}return n};function Q6(t,e){if(t._chunkDownloadsInProgress[e])return t._chunkDownloadsInProgress[e];let n,i=t._xysFileUrlTemplate;c(i)?n=i.getDerivedResource({templateValues:{0:e}}):n=new te({url:Dn(`Assets/IAU2006_XYS/IAU2006_XYS_${e}.json`)});let o=n.fetchJson().then(function(a){t._chunkDownloadsInProgress[e]=!1;let s=t._samples,l=a.samples,r=e*t._samplesPerXysFile*3;for(let d=0,m=l.length;d=43200?o=(a+.5)/xi.DAYS_PER_JULIAN_CENTURY:o=(a-.5)/xi.DAYS_PER_JULIAN_CENTURY;let l=(J9t+o*(L9t+o*(M9t+o*_9t)))*H9t%k.TWO_PI,r=O9t+D9t*(n-24515455e-1),d=(i+xi.SECONDS_PER_DAY*.5)%xi.SECONDS_PER_DAY,m=l+r*d,h=Math.cos(m),Z=Math.sin(m);return c(e)?(e[0]=h,e[1]=-Z,e[2]=0,e[3]=Z,e[4]=h,e[5]=0,e[6]=0,e[7]=0,e[8]=1,e):new ot(h,Z,0,-Z,h,0,0,0,1)};Ci.iau2006XysData=new cy;Ci.earthOrientationParameters=ly.NONE;var M6=32.184,w9t=2451545;Ci.preloadIcrfFixed=function(t){let e=t.start.dayNumber,n=t.start.secondsOfDay+M6,i=t.stop.dayNumber,o=t.stop.secondsOfDay+M6;return Ci.iau2006XysData.preload(e,n,i,o)};Ci.computeIcrfToFixedMatrix=function(t,e){c(e)||(e=new ot);let n=Ci.computeFixedToIcrfMatrix(t,e);if(c(n))return ot.transpose(n,e)};var P9t=new UG(0,0,0),v9t=new lf(0,0,0,0,0,0),X6=new ot,J6=new ot;Ci.computeFixedToIcrfMatrix=function(t,e){c(e)||(e=new ot);let n=Ci.earthOrientationParameters.compute(t,v9t);if(!c(n))return;let i=t.dayNumber,o=t.secondsOfDay+M6,a=Ci.iau2006XysData.computeXysRadians(i,o,P9t);if(!c(a))return;let s=a.x+n.xPoleOffset,l=a.y+n.yPoleOffset,r=1/(1+Math.sqrt(1-s*s-l*l)),d=X6;d[0]=1-r*s*s,d[3]=-r*s*l,d[6]=s,d[1]=-r*s*l,d[4]=1-r*l*l,d[7]=l,d[2]=-s,d[5]=-l,d[8]=1-r*(s*s+l*l);let m=ot.fromRotationZ(-a.s,J6),h=ot.multiply(d,m,X6),Z=t.dayNumber,b=t.secondsOfDay-rt.computeTaiMinusUtc(t)+n.ut1MinusUtc,u=Z-2451545,F=b/xi.SECONDS_PER_DAY,U=.779057273264+F+.00273781191135448*(u+F);U=U%1*k.TWO_PI;let G=ot.fromRotationZ(U,J6),A=ot.multiply(h,G,X6),T=Math.cos(n.xPoleWander),g=Math.cos(n.yPoleWander),C=Math.sin(n.xPoleWander),y=Math.sin(n.yPoleWander),Y=i-w9t+o/xi.SECONDS_PER_DAY;Y/=36525;let Q=-47e-6*Y*k.RADIANS_PER_DEGREE/3600,J=Math.cos(Q),M=Math.sin(Q),V=J6;return V[0]=T*J,V[1]=T*M,V[2]=C,V[3]=-g*M+y*C*J,V[4]=g*J+y*C*M,V[5]=-y*T,V[6]=-y*M-g*C*J,V[7]=y*J-g*C*M,V[8]=g*T,ot.multiply(A,V,e)};var K9t=new Rt;Ci.pointToWindowCoordinates=function(t,e,n,i){return i=Ci.pointToGLWindowCoordinates(t,e,n,i),i.y=2*e[5]-i.y,i};Ci.pointToGLWindowCoordinates=function(t,e,n,i){c(i)||(i=new K);let o=K9t;return L.multiplyByVector(t,Rt.fromElements(n.x,n.y,n.z,1,o),o),Rt.multiplyByScalar(o,1/o.w,o),L.multiplyByVector(e,o,o),K.fromCartesian4(o,i)};var z9t=new p,j9t=new p,q9t=new p;Ci.rotationMatrixFromPositionVelocity=function(t,e,n,i){let o=f(n,mt.WGS84).geodeticSurfaceNormal(t,z9t),a=p.cross(e,o,j9t);p.equalsEpsilon(a,p.ZERO,k.EPSILON6)&&(a=p.clone(p.UNIT_X,a));let s=p.cross(a,e,q9t);return p.normalize(s,s),p.cross(e,s,a),p.negate(a,a),p.normalize(a,a),c(i)||(i=new ot),i[0]=e.x,i[1]=e.y,i[2]=e.z,i[3]=a.x,i[4]=a.y,i[5]=a.z,i[6]=s.x,i[7]=s.y,i[8]=s.z,i};var nht=new L(0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1),iht=new gt,_6=new p,$9t=new p,t5t=new ot,D6=new L,oht=new L;Ci.basisTo2D=function(t,e,n){let i=L.getTranslation(e,$9t),o=t.ellipsoid,a;if(p.equals(i,p.ZERO))a=p.clone(p.ZERO,_6);else{let m=o.cartesianToCartographic(i,iht);a=t.project(m,_6),p.fromElements(a.z,a.x,a.y,a)}let s=Ci.eastNorthUpToFixedFrame(i,o,D6),l=L.inverseTransformation(s,oht),r=L.getMatrix3(e,t5t),d=L.multiplyByMatrix3(l,r,n);return L.multiply(nht,d,n),L.setTranslation(n,a,n),n};Ci.wgs84To2DModelMatrix=function(t,e,n){let i=t.ellipsoid,o=Ci.eastNorthUpToFixedFrame(e,i,D6),a=L.inverseTransformation(o,oht),s=i.cartesianToCartographic(e,iht),l=t.project(s,_6);p.fromElements(l.z,l.x,l.y,l);let r=L.fromTranslation(l,D6);return L.multiply(nht,a,n),L.multiply(r,n,n),n};var e5t=new p,n5t=new p,i5t=new p,o5t=new p,a5t=new p,s5t=new p,l5t=new p,r5t=new p,L6=new rt,d5t=new ot,c5t=new ot,m5t=new ot;Ci.vvlhToFixed=function(t,e,n){let i=t.getValue(e,e5t);rt.addSeconds(e,.01,L6);let o=t.getValue(L6,n5t),a=mt.WGS84,s=a.maximumRadius+1e5;if(c(n)||(n=new L),p.magnitude(i)<=s){let Z=p.subtract(o,i,new p),b;if(p.magnitude(Z)===0){let U=Ci.eastNorthUpToFixedFrame(i,a);b=new p(U[0],U[1],U[2])}else b=p.normalize(Z,new p);let u=a.geodeticSurfaceNormal(i,new p),F=p.cross(u,b,new p);return n[0]=b.x,n[1]=b.y,n[2]=b.z,n[3]=0,n[4]=F.x,n[5]=F.y,n[6]=F.z,n[7]=0,n[8]=u.x,n[9]=u.y,n[10]=u.z,n[11]=0,n[12]=i.x,n[13]=i.y,n[14]=i.z,n[15]=1,n}let l=Ci.computeFixedToIcrfMatrix(e,d5t);if(!l)return new L;let r=Ci.computeFixedToIcrfMatrix(L6,c5t),d=ot.transpose(l,m5t),m=ot.multiplyByVector(l,i,i5t),h=ot.multiplyByVector(r,o,o5t);if(!p.equalsEpsilon(m,h,k.EPSILON14)){let Z=p.subtract(h,m,a5t),b=s5t;try{p.negate(p.normalize(m,b),b)}catch{console.log(m,b)}let u=p.cross(Z,b,l5t);p.negate(u,u);let F=p.cross(u,b,r5t);try{ot.multiplyByVector(d,F,F),ot.multiplyByVector(d,u,u),ot.multiplyByVector(d,b,b),p.normalize(F,F),p.normalize(u,u),p.normalize(b,b),n[0]=F.x,n[1]=F.y,n[2]=F.z,n[3]=0,n[4]=u.x,n[5]=u.y,n[6]=u.z,n[7]=0,n[8]=b.x,n[9]=b.y,n[10]=b.z,n[11]=0,n[12]=i.x,n[13]=i.y,n[14]=i.z,n[15]=1}catch(U){return console.log(U,F,u,b,Z,i,o,t),new Array(16).fill(0)}}return L.multiply(n,new L(1,0,0,0,0,-1,0,0,0,0,-1,0,0,0,0,1),n),n};Ci.reverseHeadingQuaternion=function(t){if(!c(t))throw new Ut("orientation is required");let e=new Jr;Jr.fromQuaternion(t,e),e.heading=-e.heading,e.roll=-e.roll;let n=new wt;return wt.fromHeadingPitchRoll(e,n),n};var pf=new L(0,0,1,0,0,1,0,0,-1,0,0,0,0,0,0,1);Ci.getPositionInVVLH=function(t,e,n,i,o=ri.FIXED){let a=e.position.getValueInReferenceFrame(n,o.FIXED),s=t.position.getValueInReferenceFrame(i,o.FIXED),l;try{l=L.inverse(Ci.vvlhToFixed(t.position,n),new L)}catch{l=new L}let r=L.multiplyByPoint(l,a,new p),d=L.getRotation(Ci.vvlhToFixed(t.position,i),new ot),m=ot.multiplyByVector(d,r,new p),h=p.add(s,m,new p);if(o===ri.INERTIAL){let Z=Ci.computeFixedToIcrfMatrix(i);Z&&(h=ot.multiplyByVector(Z,h,new p))}return h};var eht=Ci.localFrameToFixedFrameGenerator("north","west");Ci.getTransformToFixedFrame=function(t,e,n){let i,o={[ri.FIXED]:()=>L.IDENTITY,[ri.INERTIAL]:()=>{if(!c(e))throw new Ut("Conversion from INERTIAL to FIXED requires a time.");return Ci.computeIcrfToFixedMatrix(e)},[ri.TEME]:()=>{throw new Ut("Conversion from TEME to FIXED is not implemented.")},[ri.VVLH]:()=>{if(!c(e)||!c(n))throw new Ut("Conversion from VVLH to FIXED requires both time and position.");let a=Ci.vvlhToFixed(n,e),s=L.fromScale(new p(1,-1,-1));return L.multiply(a,s,new L)},[ri.NED]:()=>{if(!c(e)||!c(n))throw new Ut("Conversion from NED to FIXED requires both time and position.");let a=eht(n.getValue(e)),s=L.fromScale(new p(1,-1,-1));return L.multiply(a,s,new L)},[ri.NEU]:()=>{if(!c(e)||!c(n))throw new Ut("Conversion from NEU to FIXED requires both time and position.");let a=eht(n.getValue(e)),s=L.fromScale(new p(1,-1,1));return L.multiply(a,s,new L)},[ri.RIC]:()=>{if(!c(e)||!c(n))throw new Ut("Conversion from RIC to FIXED requires both time and position.");let a=Ci.vvlhToFixed(n,e),s=L.fromArray([0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1]);return L.multiply(a,s,new L)}};return o.hasOwnProperty(t)?i=o[t]:i=Ci.eastNorthUpToFixedFrame,i};var Pe=Ci;function fi(t,e,n,i){this.west=f(t,0),this.south=f(e,0),this.east=f(n,0),this.north=f(i,0)}Object.defineProperties(fi.prototype,{width:{get:function(){return fi.computeWidth(this)}},height:{get:function(){return fi.computeHeight(this)}}});fi.packedLength=4;fi.pack=function(t,e,n){return n=f(n,0),e[n++]=t.west,e[n++]=t.south,e[n++]=t.east,e[n]=t.north,e};fi.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new fi),n.west=t[e++],n.south=t[e++],n.east=t[e++],n.north=t[e],n};fi.computeWidth=function(t){let e=t.east,n=t.west;return e=0?m.longitude:m.longitude+k.TWO_PI;o=Math.min(o,h),a=Math.max(a,h)}return i-n>a-o&&(n=o,i=a,i>k.PI&&(i=i-k.TWO_PI),n>k.PI&&(n=n-k.TWO_PI)),c(e)?(e.west=n,e.south=s,e.east=i,e.north=l,e):new fi(n,s,i,l)};fi.fromCartesianArray=function(t,e,n){e=f(e,mt.WGS84);let i=Number.MAX_VALUE,o=-Number.MAX_VALUE,a=Number.MAX_VALUE,s=-Number.MAX_VALUE,l=Number.MAX_VALUE,r=-Number.MAX_VALUE;for(let d=0,m=t.length;d=0?h.longitude:h.longitude+k.TWO_PI;a=Math.min(a,Z),s=Math.max(s,Z)}return o-i>s-a&&(i=a,o=s,o>k.PI&&(o=o-k.TWO_PI),i>k.PI&&(i=i-k.TWO_PI)),c(n)?(n.west=i,n.south=l,n.east=o,n.north=r,n):new fi(i,l,o,r)};var h5t=new p,p5t=new p,u5t=new p,Z5t=new p,V5t=new p,O6=new Array(5);for(let t=0;t0?i+=k.TWO_PI:a0&&(a+=k.TWO_PI),i=m))return c(n)?(n.west=l,n.south=d,n.east=r,n.north=m,n):new fi(l,d,r,m)};fi.simpleIntersection=function(t,e,n){let i=Math.max(t.west,e.west),o=Math.max(t.south,e.south),a=Math.min(t.east,e.east),s=Math.min(t.north,e.north);if(!(o>=s||i>=a))return c(n)?(n.west=i,n.south=o,n.east=a,n.north=s,n):new fi(i,o,a,s)};fi.union=function(t,e,n){c(n)||(n=new fi);let i=t.east,o=t.west,a=e.east,s=e.west;i0?i+=k.TWO_PI:a0&&(a+=k.TWO_PI),io||k.equalsEpsilon(n,o,k.EPSILON14))&&(n=t.south&&i<=t.north};var b5t=new gt;fi.subsample=function(t,e,n,i){e=f(e,mt.WGS84),n=f(n,0),c(i)||(i=[]);let o=0,a=t.north,s=t.south,l=t.east,r=t.west,d=b5t;d.height=n,d.longitude=r,d.latitude=a,i[o]=e.cartographicToCartesian(d,i[o]),o++,d.longitude=l,i[o]=e.cartographicToCartesian(d,i[o]),o++,d.latitude=s,i[o]=e.cartographicToCartesian(d,i[o]),o++,d.longitude=r,i[o]=e.cartographicToCartesian(d,i[o]),o++,a<0?d.latitude=a:s>0?d.latitude=s:d.latitude=0;for(let m=1;m<8;++m)d.longitude=-Math.PI+m*k.PI_OVER_TWO,fi.contains(t,d)&&(i[o]=e.cartographicToCartesian(d,i[o]),o++);return d.latitude===0&&(d.longitude=r,i[o]=e.cartographicToCartesian(d,i[o]),o++,d.longitude=l,i[o]=e.cartographicToCartesian(d,i[o]),o++),i.length=o,i};fi.subsection=function(t,e,n,i,o,a){if(c(a)||(a=new fi),t.west<=t.east){let l=t.east-t.west;a.west=t.west+e*l,a.east=t.west+i*l}else{let l=k.TWO_PI+t.east-t.west;a.west=k.negativePiToPi(t.west+e*l),a.east=k.negativePiToPi(t.west+i*l)}let s=t.north-t.south;return a.south=t.south+n*s,a.north=t.south+o*s,e===1&&(a.west=t.east),i===1&&(a.east=t.east),n===1&&(a.south=t.north),o===1&&(a.north=t.north),a};fi.MAX_VALUE=Object.freeze(new fi(-Math.PI,-k.PI_OVER_TWO,Math.PI,k.PI_OVER_TWO));var Gt=fi;function tl(t,e,n,i){this.x=f(t,0),this.y=f(e,0),this.width=f(n,0),this.height=f(i,0)}tl.packedLength=4;tl.pack=function(t,e,n){return n=f(n,0),e[n++]=t.x,e[n++]=t.y,e[n++]=t.width,e[n]=t.height,e};tl.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new tl),n.x=t[e++],n.y=t[e++],n.width=t[e++],n.height=t[e],n};tl.fromPoints=function(t,e){if(c(e)||(e=new tl),!c(t)||t.length===0)return e.x=0,e.y=0,e.width=0,e.height=0,e;let n=t.length,i=t[0].x,o=t[0].y,a=t[0].x,s=t[0].y;for(let l=1;ln.width?n.width=i:i<0&&(n.width-=i,n.x=e.x),o>n.height?n.height=o:o<0&&(n.height-=o,n.y=e.y),n};tl.intersect=function(t,e){let n=t.x,i=t.y,o=e.x,a=e.y;return n>o+e.width||n+t.widtha+e.height?yn.OUTSIDE:yn.INTERSECTING};tl.equals=function(t,e){return t===e||c(t)&&c(e)&&t.x===e.x&&t.y===e.y&&t.width===e.width&&t.height===e.height};tl.prototype.clone=function(t){return tl.clone(this,t)};tl.prototype.intersect=function(t){return tl.intersect(this,t)};tl.prototype.equals=function(t){return tl.equals(this,t)};var Fe=tl;var F3e=R(W(),1);var dd={POINTS:pt.POINTS,LINES:pt.LINES,LINE_LOOP:pt.LINE_LOOP,LINE_STRIP:pt.LINE_STRIP,TRIANGLES:pt.TRIANGLES,TRIANGLE_STRIP:pt.TRIANGLE_STRIP,TRIANGLE_FAN:pt.TRIANGLE_FAN};dd.isLines=function(t){return t===dd.LINES||t===dd.LINE_LOOP||t===dd.LINE_STRIP};dd.isTriangles=function(t){return t===dd.TRIANGLES||t===dd.TRIANGLE_STRIP||t===dd.TRIANGLE_FAN};dd.validate=function(t){return t===dd.POINTS||t===dd.LINES||t===dd.LINE_LOOP||t===dd.LINE_STRIP||t===dd.TRIANGLES||t===dd.TRIANGLE_STRIP||t===dd.TRIANGLE_FAN};var le=Object.freeze(dd);var G3e=R(W(),1),GG=`in vec4 position; +(${this[3]}, ${this[7]}, ${this[11]}, ${this[15]})`};var L=Ce;var QOe=b(W(),1),DMt={DEPTH_BUFFER_BIT:256,STENCIL_BUFFER_BIT:1024,COLOR_BUFFER_BIT:16384,POINTS:0,LINES:1,LINE_LOOP:2,LINE_STRIP:3,TRIANGLES:4,TRIANGLE_STRIP:5,TRIANGLE_FAN:6,ZERO:0,ONE:1,SRC_COLOR:768,ONE_MINUS_SRC_COLOR:769,SRC_ALPHA:770,ONE_MINUS_SRC_ALPHA:771,DST_ALPHA:772,ONE_MINUS_DST_ALPHA:773,DST_COLOR:774,ONE_MINUS_DST_COLOR:775,SRC_ALPHA_SATURATE:776,FUNC_ADD:32774,BLEND_EQUATION:32777,BLEND_EQUATION_RGB:32777,BLEND_EQUATION_ALPHA:34877,FUNC_SUBTRACT:32778,FUNC_REVERSE_SUBTRACT:32779,BLEND_DST_RGB:32968,BLEND_SRC_RGB:32969,BLEND_DST_ALPHA:32970,BLEND_SRC_ALPHA:32971,CONSTANT_COLOR:32769,ONE_MINUS_CONSTANT_COLOR:32770,CONSTANT_ALPHA:32771,ONE_MINUS_CONSTANT_ALPHA:32772,BLEND_COLOR:32773,ARRAY_BUFFER:34962,ELEMENT_ARRAY_BUFFER:34963,ARRAY_BUFFER_BINDING:34964,ELEMENT_ARRAY_BUFFER_BINDING:34965,STREAM_DRAW:35040,STATIC_DRAW:35044,DYNAMIC_DRAW:35048,BUFFER_SIZE:34660,BUFFER_USAGE:34661,CURRENT_VERTEX_ATTRIB:34342,FRONT:1028,BACK:1029,FRONT_AND_BACK:1032,CULL_FACE:2884,BLEND:3042,DITHER:3024,STENCIL_TEST:2960,DEPTH_TEST:2929,SCISSOR_TEST:3089,POLYGON_OFFSET_FILL:32823,SAMPLE_ALPHA_TO_COVERAGE:32926,SAMPLE_COVERAGE:32928,NO_ERROR:0,INVALID_ENUM:1280,INVALID_VALUE:1281,INVALID_OPERATION:1282,OUT_OF_MEMORY:1285,CW:2304,CCW:2305,LINE_WIDTH:2849,ALIASED_POINT_SIZE_RANGE:33901,ALIASED_LINE_WIDTH_RANGE:33902,CULL_FACE_MODE:2885,FRONT_FACE:2886,DEPTH_RANGE:2928,DEPTH_WRITEMASK:2930,DEPTH_CLEAR_VALUE:2931,DEPTH_FUNC:2932,STENCIL_CLEAR_VALUE:2961,STENCIL_FUNC:2962,STENCIL_FAIL:2964,STENCIL_PASS_DEPTH_FAIL:2965,STENCIL_PASS_DEPTH_PASS:2966,STENCIL_REF:2967,STENCIL_VALUE_MASK:2963,STENCIL_WRITEMASK:2968,STENCIL_BACK_FUNC:34816,STENCIL_BACK_FAIL:34817,STENCIL_BACK_PASS_DEPTH_FAIL:34818,STENCIL_BACK_PASS_DEPTH_PASS:34819,STENCIL_BACK_REF:36003,STENCIL_BACK_VALUE_MASK:36004,STENCIL_BACK_WRITEMASK:36005,VIEWPORT:2978,SCISSOR_BOX:3088,COLOR_CLEAR_VALUE:3106,COLOR_WRITEMASK:3107,UNPACK_ALIGNMENT:3317,PACK_ALIGNMENT:3333,MAX_TEXTURE_SIZE:3379,MAX_VIEWPORT_DIMS:3386,SUBPIXEL_BITS:3408,RED_BITS:3410,GREEN_BITS:3411,BLUE_BITS:3412,ALPHA_BITS:3413,DEPTH_BITS:3414,STENCIL_BITS:3415,POLYGON_OFFSET_UNITS:10752,POLYGON_OFFSET_FACTOR:32824,TEXTURE_BINDING_2D:32873,SAMPLE_BUFFERS:32936,SAMPLES:32937,SAMPLE_COVERAGE_VALUE:32938,SAMPLE_COVERAGE_INVERT:32939,COMPRESSED_TEXTURE_FORMATS:34467,DONT_CARE:4352,FASTEST:4353,NICEST:4354,GENERATE_MIPMAP_HINT:33170,BYTE:5120,UNSIGNED_BYTE:5121,SHORT:5122,UNSIGNED_SHORT:5123,INT:5124,UNSIGNED_INT:5125,FLOAT:5126,DEPTH_COMPONENT:6402,ALPHA:6406,RGB:6407,RGBA:6408,LUMINANCE:6409,LUMINANCE_ALPHA:6410,UNSIGNED_SHORT_4_4_4_4:32819,UNSIGNED_SHORT_5_5_5_1:32820,UNSIGNED_SHORT_5_6_5:33635,FRAGMENT_SHADER:35632,VERTEX_SHADER:35633,MAX_VERTEX_ATTRIBS:34921,MAX_VERTEX_UNIFORM_VECTORS:36347,MAX_VARYING_VECTORS:36348,MAX_COMBINED_TEXTURE_IMAGE_UNITS:35661,MAX_VERTEX_TEXTURE_IMAGE_UNITS:35660,MAX_TEXTURE_IMAGE_UNITS:34930,MAX_FRAGMENT_UNIFORM_VECTORS:36349,SHADER_TYPE:35663,DELETE_STATUS:35712,LINK_STATUS:35714,VALIDATE_STATUS:35715,ATTACHED_SHADERS:35717,ACTIVE_UNIFORMS:35718,ACTIVE_ATTRIBUTES:35721,SHADING_LANGUAGE_VERSION:35724,CURRENT_PROGRAM:35725,NEVER:512,LESS:513,EQUAL:514,LEQUAL:515,GREATER:516,NOTEQUAL:517,GEQUAL:518,ALWAYS:519,KEEP:7680,REPLACE:7681,INCR:7682,DECR:7683,INVERT:5386,INCR_WRAP:34055,DECR_WRAP:34056,VENDOR:7936,RENDERER:7937,VERSION:7938,NEAREST:9728,LINEAR:9729,NEAREST_MIPMAP_NEAREST:9984,LINEAR_MIPMAP_NEAREST:9985,NEAREST_MIPMAP_LINEAR:9986,LINEAR_MIPMAP_LINEAR:9987,TEXTURE_MAG_FILTER:10240,TEXTURE_MIN_FILTER:10241,TEXTURE_WRAP_S:10242,TEXTURE_WRAP_T:10243,TEXTURE_2D:3553,TEXTURE:5890,TEXTURE_CUBE_MAP:34067,TEXTURE_BINDING_CUBE_MAP:34068,TEXTURE_CUBE_MAP_POSITIVE_X:34069,TEXTURE_CUBE_MAP_NEGATIVE_X:34070,TEXTURE_CUBE_MAP_POSITIVE_Y:34071,TEXTURE_CUBE_MAP_NEGATIVE_Y:34072,TEXTURE_CUBE_MAP_POSITIVE_Z:34073,TEXTURE_CUBE_MAP_NEGATIVE_Z:34074,MAX_CUBE_MAP_TEXTURE_SIZE:34076,TEXTURE0:33984,TEXTURE1:33985,TEXTURE2:33986,TEXTURE3:33987,TEXTURE4:33988,TEXTURE5:33989,TEXTURE6:33990,TEXTURE7:33991,TEXTURE8:33992,TEXTURE9:33993,TEXTURE10:33994,TEXTURE11:33995,TEXTURE12:33996,TEXTURE13:33997,TEXTURE14:33998,TEXTURE15:33999,TEXTURE16:34e3,TEXTURE17:34001,TEXTURE18:34002,TEXTURE19:34003,TEXTURE20:34004,TEXTURE21:34005,TEXTURE22:34006,TEXTURE23:34007,TEXTURE24:34008,TEXTURE25:34009,TEXTURE26:34010,TEXTURE27:34011,TEXTURE28:34012,TEXTURE29:34013,TEXTURE30:34014,TEXTURE31:34015,ACTIVE_TEXTURE:34016,REPEAT:10497,CLAMP_TO_EDGE:33071,MIRRORED_REPEAT:33648,FLOAT_VEC2:35664,FLOAT_VEC3:35665,FLOAT_VEC4:35666,INT_VEC2:35667,INT_VEC3:35668,INT_VEC4:35669,BOOL:35670,BOOL_VEC2:35671,BOOL_VEC3:35672,BOOL_VEC4:35673,FLOAT_MAT2:35674,FLOAT_MAT3:35675,FLOAT_MAT4:35676,SAMPLER_2D:35678,SAMPLER_CUBE:35680,VERTEX_ATTRIB_ARRAY_ENABLED:34338,VERTEX_ATTRIB_ARRAY_SIZE:34339,VERTEX_ATTRIB_ARRAY_STRIDE:34340,VERTEX_ATTRIB_ARRAY_TYPE:34341,VERTEX_ATTRIB_ARRAY_NORMALIZED:34922,VERTEX_ATTRIB_ARRAY_POINTER:34373,VERTEX_ATTRIB_ARRAY_BUFFER_BINDING:34975,IMPLEMENTATION_COLOR_READ_TYPE:35738,IMPLEMENTATION_COLOR_READ_FORMAT:35739,COMPILE_STATUS:35713,LOW_FLOAT:36336,MEDIUM_FLOAT:36337,HIGH_FLOAT:36338,LOW_INT:36339,MEDIUM_INT:36340,HIGH_INT:36341,FRAMEBUFFER:36160,RENDERBUFFER:36161,RGBA4:32854,RGB5_A1:32855,RGB565:36194,DEPTH_COMPONENT16:33189,STENCIL_INDEX:6401,STENCIL_INDEX8:36168,DEPTH_STENCIL:34041,RENDERBUFFER_WIDTH:36162,RENDERBUFFER_HEIGHT:36163,RENDERBUFFER_INTERNAL_FORMAT:36164,RENDERBUFFER_RED_SIZE:36176,RENDERBUFFER_GREEN_SIZE:36177,RENDERBUFFER_BLUE_SIZE:36178,RENDERBUFFER_ALPHA_SIZE:36179,RENDERBUFFER_DEPTH_SIZE:36180,RENDERBUFFER_STENCIL_SIZE:36181,FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE:36048,FRAMEBUFFER_ATTACHMENT_OBJECT_NAME:36049,FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL:36050,FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE:36051,COLOR_ATTACHMENT0:36064,DEPTH_ATTACHMENT:36096,STENCIL_ATTACHMENT:36128,DEPTH_STENCIL_ATTACHMENT:33306,NONE:0,FRAMEBUFFER_COMPLETE:36053,FRAMEBUFFER_INCOMPLETE_ATTACHMENT:36054,FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:36055,FRAMEBUFFER_INCOMPLETE_DIMENSIONS:36057,FRAMEBUFFER_UNSUPPORTED:36061,FRAMEBUFFER_BINDING:36006,RENDERBUFFER_BINDING:36007,MAX_RENDERBUFFER_SIZE:34024,INVALID_FRAMEBUFFER_OPERATION:1286,UNPACK_FLIP_Y_WEBGL:37440,UNPACK_PREMULTIPLY_ALPHA_WEBGL:37441,CONTEXT_LOST_WEBGL:37442,UNPACK_COLORSPACE_CONVERSION_WEBGL:37443,BROWSER_DEFAULT_WEBGL:37444,COMPRESSED_RGB_S3TC_DXT1_EXT:33776,COMPRESSED_RGBA_S3TC_DXT1_EXT:33777,COMPRESSED_RGBA_S3TC_DXT3_EXT:33778,COMPRESSED_RGBA_S3TC_DXT5_EXT:33779,COMPRESSED_RGB_PVRTC_4BPPV1_IMG:35840,COMPRESSED_RGB_PVRTC_2BPPV1_IMG:35841,COMPRESSED_RGBA_PVRTC_4BPPV1_IMG:35842,COMPRESSED_RGBA_PVRTC_2BPPV1_IMG:35843,COMPRESSED_RGBA_ASTC_4x4_WEBGL:37808,COMPRESSED_RGB_ETC1_WEBGL:36196,COMPRESSED_RGBA_BPTC_UNORM:36492,HALF_FLOAT_OES:36193,DOUBLE:5130,READ_BUFFER:3074,UNPACK_ROW_LENGTH:3314,UNPACK_SKIP_ROWS:3315,UNPACK_SKIP_PIXELS:3316,PACK_ROW_LENGTH:3330,PACK_SKIP_ROWS:3331,PACK_SKIP_PIXELS:3332,COLOR:6144,DEPTH:6145,STENCIL:6146,RED:6403,RGB8:32849,RGBA8:32856,RGB10_A2:32857,TEXTURE_BINDING_3D:32874,UNPACK_SKIP_IMAGES:32877,UNPACK_IMAGE_HEIGHT:32878,TEXTURE_3D:32879,TEXTURE_WRAP_R:32882,MAX_3D_TEXTURE_SIZE:32883,UNSIGNED_INT_2_10_10_10_REV:33640,MAX_ELEMENTS_VERTICES:33e3,MAX_ELEMENTS_INDICES:33001,TEXTURE_MIN_LOD:33082,TEXTURE_MAX_LOD:33083,TEXTURE_BASE_LEVEL:33084,TEXTURE_MAX_LEVEL:33085,MIN:32775,MAX:32776,DEPTH_COMPONENT24:33190,MAX_TEXTURE_LOD_BIAS:34045,TEXTURE_COMPARE_MODE:34892,TEXTURE_COMPARE_FUNC:34893,CURRENT_QUERY:34917,QUERY_RESULT:34918,QUERY_RESULT_AVAILABLE:34919,STREAM_READ:35041,STREAM_COPY:35042,STATIC_READ:35045,STATIC_COPY:35046,DYNAMIC_READ:35049,DYNAMIC_COPY:35050,MAX_DRAW_BUFFERS:34852,DRAW_BUFFER0:34853,DRAW_BUFFER1:34854,DRAW_BUFFER2:34855,DRAW_BUFFER3:34856,DRAW_BUFFER4:34857,DRAW_BUFFER5:34858,DRAW_BUFFER6:34859,DRAW_BUFFER7:34860,DRAW_BUFFER8:34861,DRAW_BUFFER9:34862,DRAW_BUFFER10:34863,DRAW_BUFFER11:34864,DRAW_BUFFER12:34865,DRAW_BUFFER13:34866,DRAW_BUFFER14:34867,DRAW_BUFFER15:34868,MAX_FRAGMENT_UNIFORM_COMPONENTS:35657,MAX_VERTEX_UNIFORM_COMPONENTS:35658,SAMPLER_3D:35679,SAMPLER_2D_SHADOW:35682,FRAGMENT_SHADER_DERIVATIVE_HINT:35723,PIXEL_PACK_BUFFER:35051,PIXEL_UNPACK_BUFFER:35052,PIXEL_PACK_BUFFER_BINDING:35053,PIXEL_UNPACK_BUFFER_BINDING:35055,FLOAT_MAT2x3:35685,FLOAT_MAT2x4:35686,FLOAT_MAT3x2:35687,FLOAT_MAT3x4:35688,FLOAT_MAT4x2:35689,FLOAT_MAT4x3:35690,SRGB:35904,SRGB8:35905,SRGB8_ALPHA8:35907,COMPARE_REF_TO_TEXTURE:34894,RGBA32F:34836,RGB32F:34837,RGBA16F:34842,RGB16F:34843,VERTEX_ATTRIB_ARRAY_INTEGER:35069,MAX_ARRAY_TEXTURE_LAYERS:35071,MIN_PROGRAM_TEXEL_OFFSET:35076,MAX_PROGRAM_TEXEL_OFFSET:35077,MAX_VARYING_COMPONENTS:35659,TEXTURE_2D_ARRAY:35866,TEXTURE_BINDING_2D_ARRAY:35869,R11F_G11F_B10F:35898,UNSIGNED_INT_10F_11F_11F_REV:35899,RGB9_E5:35901,UNSIGNED_INT_5_9_9_9_REV:35902,TRANSFORM_FEEDBACK_BUFFER_MODE:35967,MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS:35968,TRANSFORM_FEEDBACK_VARYINGS:35971,TRANSFORM_FEEDBACK_BUFFER_START:35972,TRANSFORM_FEEDBACK_BUFFER_SIZE:35973,TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN:35976,RASTERIZER_DISCARD:35977,MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS:35978,MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS:35979,INTERLEAVED_ATTRIBS:35980,SEPARATE_ATTRIBS:35981,TRANSFORM_FEEDBACK_BUFFER:35982,TRANSFORM_FEEDBACK_BUFFER_BINDING:35983,RGBA32UI:36208,RGB32UI:36209,RGBA16UI:36214,RGB16UI:36215,RGBA8UI:36220,RGB8UI:36221,RGBA32I:36226,RGB32I:36227,RGBA16I:36232,RGB16I:36233,RGBA8I:36238,RGB8I:36239,RED_INTEGER:36244,RGB_INTEGER:36248,RGBA_INTEGER:36249,SAMPLER_2D_ARRAY:36289,SAMPLER_2D_ARRAY_SHADOW:36292,SAMPLER_CUBE_SHADOW:36293,UNSIGNED_INT_VEC2:36294,UNSIGNED_INT_VEC3:36295,UNSIGNED_INT_VEC4:36296,INT_SAMPLER_2D:36298,INT_SAMPLER_3D:36299,INT_SAMPLER_CUBE:36300,INT_SAMPLER_2D_ARRAY:36303,UNSIGNED_INT_SAMPLER_2D:36306,UNSIGNED_INT_SAMPLER_3D:36307,UNSIGNED_INT_SAMPLER_CUBE:36308,UNSIGNED_INT_SAMPLER_2D_ARRAY:36311,DEPTH_COMPONENT32F:36012,DEPTH32F_STENCIL8:36013,FLOAT_32_UNSIGNED_INT_24_8_REV:36269,FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING:33296,FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE:33297,FRAMEBUFFER_ATTACHMENT_RED_SIZE:33298,FRAMEBUFFER_ATTACHMENT_GREEN_SIZE:33299,FRAMEBUFFER_ATTACHMENT_BLUE_SIZE:33300,FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE:33301,FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE:33302,FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE:33303,FRAMEBUFFER_DEFAULT:33304,UNSIGNED_INT_24_8:34042,DEPTH24_STENCIL8:35056,UNSIGNED_NORMALIZED:35863,DRAW_FRAMEBUFFER_BINDING:36006,READ_FRAMEBUFFER:36008,DRAW_FRAMEBUFFER:36009,READ_FRAMEBUFFER_BINDING:36010,RENDERBUFFER_SAMPLES:36011,FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER:36052,MAX_COLOR_ATTACHMENTS:36063,COLOR_ATTACHMENT1:36065,COLOR_ATTACHMENT2:36066,COLOR_ATTACHMENT3:36067,COLOR_ATTACHMENT4:36068,COLOR_ATTACHMENT5:36069,COLOR_ATTACHMENT6:36070,COLOR_ATTACHMENT7:36071,COLOR_ATTACHMENT8:36072,COLOR_ATTACHMENT9:36073,COLOR_ATTACHMENT10:36074,COLOR_ATTACHMENT11:36075,COLOR_ATTACHMENT12:36076,COLOR_ATTACHMENT13:36077,COLOR_ATTACHMENT14:36078,COLOR_ATTACHMENT15:36079,FRAMEBUFFER_INCOMPLETE_MULTISAMPLE:36182,MAX_SAMPLES:36183,HALF_FLOAT:5131,RG:33319,RG_INTEGER:33320,R8:33321,RG8:33323,R16F:33325,R32F:33326,RG16F:33327,RG32F:33328,R8I:33329,R8UI:33330,R16I:33331,R16UI:33332,R32I:33333,R32UI:33334,RG8I:33335,RG8UI:33336,RG16I:33337,RG16UI:33338,RG32I:33339,RG32UI:33340,VERTEX_ARRAY_BINDING:34229,R8_SNORM:36756,RG8_SNORM:36757,RGB8_SNORM:36758,RGBA8_SNORM:36759,SIGNED_NORMALIZED:36764,COPY_READ_BUFFER:36662,COPY_WRITE_BUFFER:36663,COPY_READ_BUFFER_BINDING:36662,COPY_WRITE_BUFFER_BINDING:36663,UNIFORM_BUFFER:35345,UNIFORM_BUFFER_BINDING:35368,UNIFORM_BUFFER_START:35369,UNIFORM_BUFFER_SIZE:35370,MAX_VERTEX_UNIFORM_BLOCKS:35371,MAX_FRAGMENT_UNIFORM_BLOCKS:35373,MAX_COMBINED_UNIFORM_BLOCKS:35374,MAX_UNIFORM_BUFFER_BINDINGS:35375,MAX_UNIFORM_BLOCK_SIZE:35376,MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS:35377,MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS:35379,UNIFORM_BUFFER_OFFSET_ALIGNMENT:35380,ACTIVE_UNIFORM_BLOCKS:35382,UNIFORM_TYPE:35383,UNIFORM_SIZE:35384,UNIFORM_BLOCK_INDEX:35386,UNIFORM_OFFSET:35387,UNIFORM_ARRAY_STRIDE:35388,UNIFORM_MATRIX_STRIDE:35389,UNIFORM_IS_ROW_MAJOR:35390,UNIFORM_BLOCK_BINDING:35391,UNIFORM_BLOCK_DATA_SIZE:35392,UNIFORM_BLOCK_ACTIVE_UNIFORMS:35394,UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES:35395,UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER:35396,UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER:35398,INVALID_INDEX:4294967295,MAX_VERTEX_OUTPUT_COMPONENTS:37154,MAX_FRAGMENT_INPUT_COMPONENTS:37157,MAX_SERVER_WAIT_TIMEOUT:37137,OBJECT_TYPE:37138,SYNC_CONDITION:37139,SYNC_STATUS:37140,SYNC_FLAGS:37141,SYNC_FENCE:37142,SYNC_GPU_COMMANDS_COMPLETE:37143,UNSIGNALED:37144,SIGNALED:37145,ALREADY_SIGNALED:37146,TIMEOUT_EXPIRED:37147,CONDITION_SATISFIED:37148,WAIT_FAILED:37149,SYNC_FLUSH_COMMANDS_BIT:1,VERTEX_ATTRIB_ARRAY_DIVISOR:35070,ANY_SAMPLES_PASSED:35887,ANY_SAMPLES_PASSED_CONSERVATIVE:36202,SAMPLER_BINDING:35097,RGB10_A2UI:36975,INT_2_10_10_10_REV:36255,TRANSFORM_FEEDBACK:36386,TRANSFORM_FEEDBACK_PAUSED:36387,TRANSFORM_FEEDBACK_ACTIVE:36388,TRANSFORM_FEEDBACK_BINDING:36389,COMPRESSED_R11_EAC:37488,COMPRESSED_SIGNED_R11_EAC:37489,COMPRESSED_RG11_EAC:37490,COMPRESSED_SIGNED_RG11_EAC:37491,COMPRESSED_RGB8_ETC2:37492,COMPRESSED_SRGB8_ETC2:37493,COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2:37494,COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2:37495,COMPRESSED_RGBA8_ETC2_EAC:37496,COMPRESSED_SRGB8_ALPHA8_ETC2_EAC:37497,TEXTURE_IMMUTABLE_FORMAT:37167,MAX_ELEMENT_INDEX:36203,TEXTURE_IMMUTABLE_LEVELS:33503,MAX_TEXTURE_MAX_ANISOTROPY_EXT:34047},pt=Object.freeze(DMt);var OMt=new p;function dn(t){this._size=t.size,this._datatype=t.datatype,this.getValue=t.getValue}var Xr={};Xr[pt.FLOAT]="float";Xr[pt.FLOAT_VEC2]="vec2";Xr[pt.FLOAT_VEC3]="vec3";Xr[pt.FLOAT_VEC4]="vec4";Xr[pt.INT]="int";Xr[pt.INT_VEC2]="ivec2";Xr[pt.INT_VEC3]="ivec3";Xr[pt.INT_VEC4]="ivec4";Xr[pt.BOOL]="bool";Xr[pt.BOOL_VEC2]="bvec2";Xr[pt.BOOL_VEC3]="bvec3";Xr[pt.BOOL_VEC4]="bvec4";Xr[pt.FLOAT_MAT2]="mat2";Xr[pt.FLOAT_MAT3]="mat3";Xr[pt.FLOAT_MAT4]="mat4";Xr[pt.SAMPLER_2D]="sampler2D";Xr[pt.SAMPLER_CUBE]="samplerCube";dn.prototype.getDeclaration=function(t){let e=`uniform ${Xr[this._datatype]} ${t}`,n=this._size;return n===1?e+=";":e+=`[${n.toString()}];`,e};var HMt={czm_viewport:new dn({size:1,datatype:pt.FLOAT_VEC4,getValue:function(t){return t.viewportCartesian4}}),czm_viewportOrthographic:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.viewportOrthographic}}),czm_viewportTransformation:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.viewportTransformation}}),czm_globeDepthTexture:new dn({size:1,datatype:pt.SAMPLER_2D,getValue:function(t){return t.globeDepthTexture}}),czm_model:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.model}}),czm_inverseModel:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.inverseModel}}),czm_view:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.view}}),czm_view3D:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.view3D}}),czm_viewRotation:new dn({size:1,datatype:pt.FLOAT_MAT3,getValue:function(t){return t.viewRotation}}),czm_viewRotation3D:new dn({size:1,datatype:pt.FLOAT_MAT3,getValue:function(t){return t.viewRotation3D}}),czm_inverseView:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.inverseView}}),czm_inverseView3D:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.inverseView3D}}),czm_inverseViewRotation:new dn({size:1,datatype:pt.FLOAT_MAT3,getValue:function(t){return t.inverseViewRotation}}),czm_inverseViewRotation3D:new dn({size:1,datatype:pt.FLOAT_MAT3,getValue:function(t){return t.inverseViewRotation3D}}),czm_projection:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.projection}}),czm_inverseProjection:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.inverseProjection}}),czm_infiniteProjection:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.infiniteProjection}}),czm_modelView:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.modelView}}),czm_modelView3D:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.modelView3D}}),czm_modelViewRelativeToEye:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.modelViewRelativeToEye}}),czm_inverseModelView:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.inverseModelView}}),czm_inverseModelView3D:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.inverseModelView3D}}),czm_viewProjection:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.viewProjection}}),czm_inverseViewProjection:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.inverseViewProjection}}),czm_modelViewProjection:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.modelViewProjection}}),czm_inverseModelViewProjection:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.inverseModelViewProjection}}),czm_modelViewProjectionRelativeToEye:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.modelViewProjectionRelativeToEye}}),czm_modelViewInfiniteProjection:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.modelViewInfiniteProjection}}),czm_orthographicIn3D:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.orthographicIn3D?1:0}}),czm_normal:new dn({size:1,datatype:pt.FLOAT_MAT3,getValue:function(t){return t.normal}}),czm_normal3D:new dn({size:1,datatype:pt.FLOAT_MAT3,getValue:function(t){return t.normal3D}}),czm_inverseNormal:new dn({size:1,datatype:pt.FLOAT_MAT3,getValue:function(t){return t.inverseNormal}}),czm_inverseNormal3D:new dn({size:1,datatype:pt.FLOAT_MAT3,getValue:function(t){return t.inverseNormal3D}}),czm_eyeHeight:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.eyeHeight}}),czm_eyeHeight2D:new dn({size:1,datatype:pt.FLOAT_VEC2,getValue:function(t){return t.eyeHeight2D}}),czm_eyeEllipsoidNormalEC:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.eyeEllipsoidNormalEC}}),czm_eyeEllipsoidCurvature:new dn({size:1,datatype:pt.FLOAT_VEC2,getValue:function(t){return t.eyeEllipsoidCurvature}}),czm_modelToEnu:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.modelToEnu}}),czm_enuToModel:new dn({size:1,datatype:pt.FLOAT_MAT4,getValue:function(t){return t.enuToModel}}),czm_entireFrustum:new dn({size:1,datatype:pt.FLOAT_VEC2,getValue:function(t){return t.entireFrustum}}),czm_currentFrustum:new dn({size:1,datatype:pt.FLOAT_VEC2,getValue:function(t){return t.currentFrustum}}),czm_frustumPlanes:new dn({size:1,datatype:pt.FLOAT_VEC4,getValue:function(t){return t.frustumPlanes}}),czm_farDepthFromNearPlusOne:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.farDepthFromNearPlusOne}}),czm_log2FarDepthFromNearPlusOne:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.log2FarDepthFromNearPlusOne}}),czm_oneOverLog2FarDepthFromNearPlusOne:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.oneOverLog2FarDepthFromNearPlusOne}}),czm_sunPositionWC:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.sunPositionWC}}),czm_sunPositionColumbusView:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.sunPositionColumbusView}}),czm_sunDirectionEC:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.sunDirectionEC}}),czm_sunDirectionWC:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.sunDirectionWC}}),czm_moonDirectionEC:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.moonDirectionEC}}),czm_lightDirectionEC:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.lightDirectionEC}}),czm_lightDirectionWC:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.lightDirectionWC}}),czm_lightColor:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.lightColor}}),czm_lightColorHdr:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.lightColorHdr}}),czm_encodedCameraPositionMCHigh:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.encodedCameraPositionMCHigh}}),czm_encodedCameraPositionMCLow:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.encodedCameraPositionMCLow}}),czm_viewerPositionWC:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return L.getTranslation(t.inverseView,OMt)}}),czm_frameNumber:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.frameState.frameNumber}}),czm_morphTime:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.frameState.morphTime}}),czm_sceneMode:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.frameState.mode}}),czm_pass:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.pass}}),czm_backgroundColor:new dn({size:1,datatype:pt.FLOAT_VEC4,getValue:function(t){return t.backgroundColor}}),czm_brdfLut:new dn({size:1,datatype:pt.SAMPLER_2D,getValue:function(t){return t.brdfLut}}),czm_environmentMap:new dn({size:1,datatype:pt.SAMPLER_CUBE,getValue:function(t){return t.environmentMap}}),czm_specularEnvironmentMaps:new dn({size:1,datatype:pt.SAMPLER_2D,getValue:function(t){return t.specularEnvironmentMaps}}),czm_specularEnvironmentMapSize:new dn({size:1,datatype:pt.FLOAT_VEC2,getValue:function(t){return t.specularEnvironmentMapsDimensions}}),czm_specularEnvironmentMapsMaximumLOD:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.specularEnvironmentMapsMaximumLOD}}),czm_sphericalHarmonicCoefficients:new dn({size:9,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.sphericalHarmonicCoefficients}}),czm_temeToPseudoFixed:new dn({size:1,datatype:pt.FLOAT_MAT3,getValue:function(t){return t.temeToPseudoFixedMatrix}}),czm_pixelRatio:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.pixelRatio}}),czm_fogDensity:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.fogDensity}}),czm_fogMinimumBrightness:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.fogMinimumBrightness}}),czm_atmosphereHsbShift:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.atmosphereHsbShift}}),czm_atmosphereLightIntensity:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.atmosphereLightIntensity}}),czm_atmosphereRayleighCoefficient:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.atmosphereRayleighCoefficient}}),czm_atmosphereRayleighScaleHeight:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.atmosphereRayleighScaleHeight}}),czm_atmosphereMieCoefficient:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.atmosphereMieCoefficient}}),czm_atmosphereMieScaleHeight:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.atmosphereMieScaleHeight}}),czm_atmosphereMieAnisotropy:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.atmosphereMieAnisotropy}}),czm_atmosphereDynamicLighting:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.atmosphereDynamicLighting}}),czm_splitPosition:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.splitPosition}}),czm_geometricToleranceOverMeter:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.geometricToleranceOverMeter}}),czm_minimumDisableDepthTestDistance:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.minimumDisableDepthTestDistance}}),czm_invertClassificationColor:new dn({size:1,datatype:pt.FLOAT_VEC4,getValue:function(t){return t.invertClassificationColor}}),czm_gamma:new dn({size:1,datatype:pt.FLOAT,getValue:function(t){return t.gamma}}),czm_ellipsoidRadii:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.ellipsoid.radii}}),czm_ellipsoidInverseRadii:new dn({size:1,datatype:pt.FLOAT_VEC3,getValue:function(t){return t.ellipsoid.oneOverRadii}})},Rb=HMt;var sHe=b(W(),1);var MOe=b(W(),1);function wMt(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(t){let e=Math.random()*16|0;return(t==="x"?e:e&3|8).toString(16)})}var Ti=wMt;var OOe=b(W(),1);function PMt(){return!0}function vMt(t,e){e=f(e,"This object was destroyed, i.e., destroy() was called.");function n(){}for(let i in t)typeof t[i]=="function"&&(t[i]=n);t.isDestroyed=PMt}var At=vMt;var KOe=b(W(),1);var Vr={UNSIGNED_BYTE:pt.UNSIGNED_BYTE,UNSIGNED_SHORT:pt.UNSIGNED_SHORT,UNSIGNED_INT:pt.UNSIGNED_INT};Vr.getSizeInBytes=function(t){switch(t){case Vr.UNSIGNED_BYTE:return Uint8Array.BYTES_PER_ELEMENT;case Vr.UNSIGNED_SHORT:return Uint16Array.BYTES_PER_ELEMENT;case Vr.UNSIGNED_INT:return Uint32Array.BYTES_PER_ELEMENT}};Vr.fromSizeInBytes=function(t){switch(t){case 2:return Vr.UNSIGNED_SHORT;case 4:return Vr.UNSIGNED_INT;case 1:return Vr.UNSIGNED_BYTE}};Vr.validate=function(t){return c(t)&&(t===Vr.UNSIGNED_BYTE||t===Vr.UNSIGNED_SHORT||t===Vr.UNSIGNED_INT)};Vr.createTypedArray=function(t,e){return t>=k.SIXTY_FOUR_KILOBYTES?new Uint32Array(e):new Uint16Array(e)};Vr.createTypedArrayFromArrayBuffer=function(t,e,n,i){return t>=k.SIXTY_FOUR_KILOBYTES?new Uint32Array(e,n,i):new Uint16Array(e,n,i)};Vr.fromTypedArray=function(t){if(t instanceof Uint8Array)return Vr.UNSIGNED_BYTE;if(t instanceof Uint16Array)return Vr.UNSIGNED_SHORT;if(t instanceof Uint32Array)return Vr.UNSIGNED_INT};var re=Object.freeze(Vr);var qOe=b(W(),1);var eH={STREAM_DRAW:pt.STREAM_DRAW,STATIC_DRAW:pt.STATIC_DRAW,DYNAMIC_DRAW:pt.DYNAMIC_DRAW,validate:function(t){return t===eH.STREAM_DRAW||t===eH.STATIC_DRAW||t===eH.DYNAMIC_DRAW}},ce=Object.freeze(eH);function Sp(t){t=f(t,f.EMPTY_OBJECT);let e=t.context._gl,n=t.bufferTarget,i=t.typedArray,o=t.sizeInBytes,a=t.usage,s=c(i);s&&(o=i.byteLength);let l=e.createBuffer();e.bindBuffer(n,l),e.bufferData(n,s?i:o,a),e.bindBuffer(n,null),this._id=Ti(),this._gl=e,this._webgl2=t.context._webgl2,this._bufferTarget=n,this._sizeInBytes=o,this._usage=a,this._buffer=l,this.vertexArrayDestroyable=!0}Sp.createVertexBuffer=function(t){return new Sp({context:t.context,bufferTarget:pt.ARRAY_BUFFER,typedArray:t.typedArray,sizeInBytes:t.sizeInBytes,usage:t.usage})};Sp.createIndexBuffer=function(t){let e=t.context,n=t.indexDatatype,i=re.getSizeInBytes(n),o=new Sp({context:e,bufferTarget:pt.ELEMENT_ARRAY_BUFFER,typedArray:t.typedArray,sizeInBytes:t.sizeInBytes,usage:t.usage}),a=o.sizeInBytes/i;return Object.defineProperties(o,{indexDatatype:{get:function(){return n}},bytesPerIndex:{get:function(){return i}},numberOfIndices:{get:function(){return a}}}),o};Object.defineProperties(Sp.prototype,{sizeInBytes:{get:function(){return this._sizeInBytes}},usage:{get:function(){return this._usage}}});Sp.prototype._getBuffer=function(){return this._buffer};Sp.prototype.copyFromArrayView=function(t,e){e=f(e,0);let n=this._gl,i=this._bufferTarget;n.bindBuffer(i,this._buffer),n.bufferSubData(i,e,t),n.bindBuffer(i,null)};Sp.prototype.copyFromBuffer=function(t,e,n,i){let o=pt.COPY_READ_BUFFER,a=pt.COPY_WRITE_BUFFER,s=this._gl;s.bindBuffer(a,this._buffer),s.bindBuffer(o,t._buffer),s.copyBufferSubData(o,a,e,n,i),s.bindBuffer(a,null),s.bindBuffer(o,null)};Sp.prototype.getBufferData=function(t,e,n,i){e=f(e,0),n=f(n,0);let o=this._gl,a=pt.COPY_READ_BUFFER;o.bindBuffer(a,this._buffer),o.getBufferSubData(a,e,t,n,i),o.bindBuffer(a,null)};Sp.prototype.isDestroyed=function(){return!1};Sp.prototype.destroy=function(){return this._gl.deleteBuffer(this._buffer),At(this)};var we=Sp;var AHe=b(W(),1);var fHe=b(W(),1);var VHe=b(W(),1);var dHe=b(W(),1);var sf,$s={requestFullscreen:void 0,exitFullscreen:void 0,fullscreenEnabled:void 0,fullscreenElement:void 0,fullscreenchange:void 0,fullscreenerror:void 0},bm={};Object.defineProperties(bm,{element:{get:function(){if(bm.supportsFullscreen())return document[$s.fullscreenElement]}},changeEventName:{get:function(){if(bm.supportsFullscreen())return $s.fullscreenchange}},errorEventName:{get:function(){if(bm.supportsFullscreen())return $s.fullscreenerror}},enabled:{get:function(){if(bm.supportsFullscreen())return document[$s.fullscreenEnabled]}},fullscreen:{get:function(){if(bm.supportsFullscreen())return bm.element!==null}}});bm.supportsFullscreen=function(){if(c(sf))return sf;sf=!1;let t=document.body;if(typeof t.requestFullscreen=="function")return $s.requestFullscreen="requestFullscreen",$s.exitFullscreen="exitFullscreen",$s.fullscreenEnabled="fullscreenEnabled",$s.fullscreenElement="fullscreenElement",$s.fullscreenchange="fullscreenchange",$s.fullscreenerror="fullscreenerror",sf=!0,sf;let e=["webkit","moz","o","ms","khtml"],n;for(let i=0,o=e.length;i{let e=new Image;e.onload=function(){Ac._result=e.width>0&&e.height>0,t(Ac._result)},e.onerror=function(){Ac._result=!1,t(Ac._result)},e.src="data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA"})),Ac._promise};Object.defineProperties(Ac,{initialized:{get:function(){return c(Ac._result)}}});var Kg=[];typeof ArrayBuffer<"u"&&(Kg.push(Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array),typeof Uint8ClampedArray<"u"&&Kg.push(Uint8ClampedArray),typeof Uint8ClampedArray<"u"&&Kg.push(Uint8ClampedArray),typeof BigInt64Array<"u"&&Kg.push(BigInt64Array),typeof BigUint64Array<"u"&&Kg.push(BigUint64Array));var Tp={isChrome:h6,chromeVersion:KMt,isSafari:nmt,safariVersion:zMt,isWebkit:imt,webkitVersion:jMt,isInternetExplorer:omt,internetExplorerVersion:qMt,isEdge:rH,edgeVersion:$Mt,isFirefox:dH,firefoxVersion:n_t,isWindows:t_t,isIPadOrIOS:e_t,hardwareConcurrency:f(Qd.hardwareConcurrency,3),supportsPointerEvents:i_t,supportsImageRenderingPixelated:lmt,supportsWebP:Ac,imageRenderingValue:o_t,typedArrayTypes:Kg};Tp.supportsBasis=function(t){return Tp.supportsWebAssembly()&&t.context.supportsBasis};Tp.supportsFullscreen=function(){return Ds.supportsFullscreen()};Tp.supportsTypedArrays=function(){return typeof ArrayBuffer<"u"};Tp.supportsBigInt64Array=function(){return typeof BigInt64Array<"u"};Tp.supportsBigUint64Array=function(){return typeof BigUint64Array<"u"};Tp.supportsBigInt=function(){return typeof BigInt<"u"};Tp.supportsWebWorkers=function(){return typeof Worker<"u"};Tp.supportsWebAssembly=function(){return typeof WebAssembly<"u"};Tp.supportsWebgl2=function(t){return t.context.webgl2};Tp.supportsEsmWebWorkers=function(){return!dH()||parseInt(p6)>=114};var In=Tp;function V6(t,e,n){return n<0&&(n+=1),n>1&&(n-=1),n*6<1?t+(e-t)*6*n:n*2<1?e:n*3<2?t+(e-t)*(2/3-n)*6:t}function Zt(t,e,n,i){this.red=f(t,1),this.green=f(e,1),this.blue=f(n,1),this.alpha=f(i,1)}Zt.fromCartesian4=function(t,e){return c(e)?(e.red=t.x,e.green=t.y,e.blue=t.z,e.alpha=t.w,e):new Zt(t.x,t.y,t.z,t.w)};Zt.fromBytes=function(t,e,n,i,o){return t=Zt.byteToFloat(f(t,255)),e=Zt.byteToFloat(f(e,255)),n=Zt.byteToFloat(f(n,255)),i=Zt.byteToFloat(f(i,255)),c(o)?(o.red=t,o.green=e,o.blue=n,o.alpha=i,o):new Zt(t,e,n,i)};Zt.fromAlpha=function(t,e,n){return c(n)?(n.red=t.red,n.green=t.green,n.blue=t.blue,n.alpha=e,n):new Zt(t.red,t.green,t.blue,e)};var u6,Z6,bb;In.supportsTypedArrays()&&(u6=new ArrayBuffer(4),Z6=new Uint32Array(u6),bb=new Uint8Array(u6));Zt.fromRgba=function(t,e){return Z6[0]=t,Zt.fromBytes(bb[0],bb[1],bb[2],bb[3],e)};Zt.fromHsl=function(t,e,n,i,o){t=f(t,0)%1,e=f(e,0),n=f(n,0),i=f(i,1);let a=n,s=n,l=n;if(e!==0){let r;n<.5?r=n*(1+e):r=n+e-n*e;let d=2*n-r;a=V6(d,r,t+1/3),s=V6(d,r,t),l=V6(d,r,t-1/3)}return c(o)?(o.red=a,o.green=s,o.blue=l,o.alpha=i,o):new Zt(a,s,l,i)};Zt.fromRandom=function(t,e){t=f(t,f.EMPTY_OBJECT);let n=t.red;if(!c(n)){let s=f(t.minimumRed,0),l=f(t.maximumRed,1);n=s+k.nextRandomNumber()*(l-s)}let i=t.green;if(!c(i)){let s=f(t.minimumGreen,0),l=f(t.maximumGreen,1);i=s+k.nextRandomNumber()*(l-s)}let o=t.blue;if(!c(o)){let s=f(t.minimumBlue,0),l=f(t.maximumBlue,1);o=s+k.nextRandomNumber()*(l-s)}let a=t.alpha;if(!c(a)){let s=f(t.minimumAlpha,0),l=f(t.maximumAlpha,1);a=s+k.nextRandomNumber()*(l-s)}return c(e)?(e.red=n,e.green=i,e.blue=o,e.alpha=a,e):new Zt(n,i,o,a)};var a_t=/^#([0-9a-f])([0-9a-f])([0-9a-f])([0-9a-f])?$/i,s_t=/^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})?$/i,l_t=/^rgba?\s*\(\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i,r_t=/^hsla?\s*\(\s*([0-9.]+)\s*[,\s]+\s*([0-9.]+%)\s*[,\s]+\s*([0-9.]+%)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i;Zt.fromCssColorString=function(t,e){c(e)||(e=new Zt),t=t.trim();let n=Zt[t.toUpperCase()];if(c(n))return Zt.clone(n,e),e;let i=a_t.exec(t);return i!==null?(e.red=parseInt(i[1],16)/15,e.green=parseInt(i[2],16)/15,e.blue=parseInt(i[3],16)/15,e.alpha=parseInt(f(i[4],"f"),16)/15,e):(i=s_t.exec(t),i!==null?(e.red=parseInt(i[1],16)/255,e.green=parseInt(i[2],16)/255,e.blue=parseInt(i[3],16)/255,e.alpha=parseInt(f(i[4],"ff"),16)/255,e):(i=l_t.exec(t),i!==null?(e.red=parseFloat(i[1])/(i[1].substr(-1)==="%"?100:255),e.green=parseFloat(i[2])/(i[2].substr(-1)==="%"?100:255),e.blue=parseFloat(i[3])/(i[3].substr(-1)==="%"?100:255),e.alpha=parseFloat(f(i[4],"1.0")),e):(i=r_t.exec(t),i!==null?Zt.fromHsl(parseFloat(i[1])/360,parseFloat(i[2])/100,parseFloat(i[3])/100,parseFloat(f(i[4],"1.0")),e):(e=void 0,e))))};Zt.packedLength=4;Zt.pack=function(t,e,n){return n=f(n,0),e[n++]=t.red,e[n++]=t.green,e[n++]=t.blue,e[n]=t.alpha,e};Zt.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Zt),n.red=t[e++],n.green=t[e++],n.blue=t[e++],n.alpha=t[e],n};Zt.byteToFloat=function(t){return t/255};Zt.floatToByte=function(t){return t===1?255:t*256|0};Zt.clone=function(t,e){if(c(t))return c(e)?(e.red=t.red,e.green=t.green,e.blue=t.blue,e.alpha=t.alpha,e):new Zt(t.red,t.green,t.blue,t.alpha)};Zt.equals=function(t,e){return t===e||c(t)&&c(e)&&t.red===e.red&&t.green===e.green&&t.blue===e.blue&&t.alpha===e.alpha};Zt.equalsArray=function(t,e,n){return t.red===e[n]&&t.green===e[n+1]&&t.blue===e[n+2]&&t.alpha===e[n+3]};Zt.prototype.clone=function(t){return Zt.clone(this,t)};Zt.prototype.equals=function(t){return Zt.equals(this,t)};Zt.prototype.equalsEpsilon=function(t,e){return this===t||c(t)&&Math.abs(this.red-t.red)<=e&&Math.abs(this.green-t.green)<=e&&Math.abs(this.blue-t.blue)<=e&&Math.abs(this.alpha-t.alpha)<=e};Zt.prototype.toString=function(){return`(${this.red}, ${this.green}, ${this.blue}, ${this.alpha})`};Zt.prototype.toCssColorString=function(){let t=Zt.floatToByte(this.red),e=Zt.floatToByte(this.green),n=Zt.floatToByte(this.blue);return this.alpha===1?`rgb(${t},${e},${n})`:`rgba(${t},${e},${n},${this.alpha})`};Zt.prototype.toCssHexString=function(){let t=Zt.floatToByte(this.red).toString(16);t.length<2&&(t=`0${t}`);let e=Zt.floatToByte(this.green).toString(16);e.length<2&&(e=`0${e}`);let n=Zt.floatToByte(this.blue).toString(16);if(n.length<2&&(n=`0${n}`),this.alpha<1){let i=Zt.floatToByte(this.alpha).toString(16);return i.length<2&&(i=`0${i}`),`#${t}${e}${n}${i}`}return`#${t}${e}${n}`};Zt.prototype.toBytes=function(t){let e=Zt.floatToByte(this.red),n=Zt.floatToByte(this.green),i=Zt.floatToByte(this.blue),o=Zt.floatToByte(this.alpha);return c(t)?(t[0]=e,t[1]=n,t[2]=i,t[3]=o,t):[e,n,i,o]};Zt.prototype.toRgba=function(){return bb[0]=Zt.floatToByte(this.red),bb[1]=Zt.floatToByte(this.green),bb[2]=Zt.floatToByte(this.blue),bb[3]=Zt.floatToByte(this.alpha),Z6[0]};Zt.prototype.brighten=function(t,e){return t=1-t,e.red=1-(1-this.red)*t,e.green=1-(1-this.green)*t,e.blue=1-(1-this.blue)*t,e.alpha=this.alpha,e};Zt.prototype.darken=function(t,e){return t=1-t,e.red=this.red*t,e.green=this.green*t,e.blue=this.blue*t,e.alpha=this.alpha,e};Zt.prototype.withAlpha=function(t,e){return Zt.fromAlpha(this,t,e)};Zt.add=function(t,e,n){return n.red=t.red+e.red,n.green=t.green+e.green,n.blue=t.blue+e.blue,n.alpha=t.alpha+e.alpha,n};Zt.subtract=function(t,e,n){return n.red=t.red-e.red,n.green=t.green-e.green,n.blue=t.blue-e.blue,n.alpha=t.alpha-e.alpha,n};Zt.multiply=function(t,e,n){return n.red=t.red*e.red,n.green=t.green*e.green,n.blue=t.blue*e.blue,n.alpha=t.alpha*e.alpha,n};Zt.divide=function(t,e,n){return n.red=t.red/e.red,n.green=t.green/e.green,n.blue=t.blue/e.blue,n.alpha=t.alpha/e.alpha,n};Zt.mod=function(t,e,n){return n.red=t.red%e.red,n.green=t.green%e.green,n.blue=t.blue%e.blue,n.alpha=t.alpha%e.alpha,n};Zt.lerp=function(t,e,n,i){return i.red=k.lerp(t.red,e.red,n),i.green=k.lerp(t.green,e.green,n),i.blue=k.lerp(t.blue,e.blue,n),i.alpha=k.lerp(t.alpha,e.alpha,n),i};Zt.multiplyByScalar=function(t,e,n){return n.red=t.red*e,n.green=t.green*e,n.blue=t.blue*e,n.alpha=t.alpha*e,n};Zt.divideByScalar=function(t,e,n){return n.red=t.red/e,n.green=t.green/e,n.blue=t.blue/e,n.alpha=t.alpha/e,n};Zt.ALICEBLUE=Object.freeze(Zt.fromCssColorString("#F0F8FF"));Zt.ANTIQUEWHITE=Object.freeze(Zt.fromCssColorString("#FAEBD7"));Zt.AQUA=Object.freeze(Zt.fromCssColorString("#00FFFF"));Zt.AQUAMARINE=Object.freeze(Zt.fromCssColorString("#7FFFD4"));Zt.AZURE=Object.freeze(Zt.fromCssColorString("#F0FFFF"));Zt.BEIGE=Object.freeze(Zt.fromCssColorString("#F5F5DC"));Zt.BISQUE=Object.freeze(Zt.fromCssColorString("#FFE4C4"));Zt.BLACK=Object.freeze(Zt.fromCssColorString("#000000"));Zt.BLANCHEDALMOND=Object.freeze(Zt.fromCssColorString("#FFEBCD"));Zt.BLUE=Object.freeze(Zt.fromCssColorString("#0000FF"));Zt.BLUEVIOLET=Object.freeze(Zt.fromCssColorString("#8A2BE2"));Zt.BROWN=Object.freeze(Zt.fromCssColorString("#A52A2A"));Zt.BURLYWOOD=Object.freeze(Zt.fromCssColorString("#DEB887"));Zt.CADETBLUE=Object.freeze(Zt.fromCssColorString("#5F9EA0"));Zt.CHARTREUSE=Object.freeze(Zt.fromCssColorString("#7FFF00"));Zt.CHOCOLATE=Object.freeze(Zt.fromCssColorString("#D2691E"));Zt.CORAL=Object.freeze(Zt.fromCssColorString("#FF7F50"));Zt.CORNFLOWERBLUE=Object.freeze(Zt.fromCssColorString("#6495ED"));Zt.CORNSILK=Object.freeze(Zt.fromCssColorString("#FFF8DC"));Zt.CRIMSON=Object.freeze(Zt.fromCssColorString("#DC143C"));Zt.CYAN=Object.freeze(Zt.fromCssColorString("#00FFFF"));Zt.DARKBLUE=Object.freeze(Zt.fromCssColorString("#00008B"));Zt.DARKCYAN=Object.freeze(Zt.fromCssColorString("#008B8B"));Zt.DARKGOLDENROD=Object.freeze(Zt.fromCssColorString("#B8860B"));Zt.DARKGRAY=Object.freeze(Zt.fromCssColorString("#A9A9A9"));Zt.DARKGREEN=Object.freeze(Zt.fromCssColorString("#006400"));Zt.DARKGREY=Zt.DARKGRAY;Zt.DARKKHAKI=Object.freeze(Zt.fromCssColorString("#BDB76B"));Zt.DARKMAGENTA=Object.freeze(Zt.fromCssColorString("#8B008B"));Zt.DARKOLIVEGREEN=Object.freeze(Zt.fromCssColorString("#556B2F"));Zt.DARKORANGE=Object.freeze(Zt.fromCssColorString("#FF8C00"));Zt.DARKORCHID=Object.freeze(Zt.fromCssColorString("#9932CC"));Zt.DARKRED=Object.freeze(Zt.fromCssColorString("#8B0000"));Zt.DARKSALMON=Object.freeze(Zt.fromCssColorString("#E9967A"));Zt.DARKSEAGREEN=Object.freeze(Zt.fromCssColorString("#8FBC8F"));Zt.DARKSLATEBLUE=Object.freeze(Zt.fromCssColorString("#483D8B"));Zt.DARKSLATEGRAY=Object.freeze(Zt.fromCssColorString("#2F4F4F"));Zt.DARKSLATEGREY=Zt.DARKSLATEGRAY;Zt.DARKTURQUOISE=Object.freeze(Zt.fromCssColorString("#00CED1"));Zt.DARKVIOLET=Object.freeze(Zt.fromCssColorString("#9400D3"));Zt.DEEPPINK=Object.freeze(Zt.fromCssColorString("#FF1493"));Zt.DEEPSKYBLUE=Object.freeze(Zt.fromCssColorString("#00BFFF"));Zt.DIMGRAY=Object.freeze(Zt.fromCssColorString("#696969"));Zt.DIMGREY=Zt.DIMGRAY;Zt.DODGERBLUE=Object.freeze(Zt.fromCssColorString("#1E90FF"));Zt.FIREBRICK=Object.freeze(Zt.fromCssColorString("#B22222"));Zt.FLORALWHITE=Object.freeze(Zt.fromCssColorString("#FFFAF0"));Zt.FORESTGREEN=Object.freeze(Zt.fromCssColorString("#228B22"));Zt.FUCHSIA=Object.freeze(Zt.fromCssColorString("#FF00FF"));Zt.GAINSBORO=Object.freeze(Zt.fromCssColorString("#DCDCDC"));Zt.GHOSTWHITE=Object.freeze(Zt.fromCssColorString("#F8F8FF"));Zt.GOLD=Object.freeze(Zt.fromCssColorString("#FFD700"));Zt.GOLDENROD=Object.freeze(Zt.fromCssColorString("#DAA520"));Zt.GRAY=Object.freeze(Zt.fromCssColorString("#808080"));Zt.GREEN=Object.freeze(Zt.fromCssColorString("#008000"));Zt.GREENYELLOW=Object.freeze(Zt.fromCssColorString("#ADFF2F"));Zt.GREY=Zt.GRAY;Zt.HONEYDEW=Object.freeze(Zt.fromCssColorString("#F0FFF0"));Zt.HOTPINK=Object.freeze(Zt.fromCssColorString("#FF69B4"));Zt.INDIANRED=Object.freeze(Zt.fromCssColorString("#CD5C5C"));Zt.INDIGO=Object.freeze(Zt.fromCssColorString("#4B0082"));Zt.IVORY=Object.freeze(Zt.fromCssColorString("#FFFFF0"));Zt.KHAKI=Object.freeze(Zt.fromCssColorString("#F0E68C"));Zt.LAVENDER=Object.freeze(Zt.fromCssColorString("#E6E6FA"));Zt.LAVENDAR_BLUSH=Object.freeze(Zt.fromCssColorString("#FFF0F5"));Zt.LAWNGREEN=Object.freeze(Zt.fromCssColorString("#7CFC00"));Zt.LEMONCHIFFON=Object.freeze(Zt.fromCssColorString("#FFFACD"));Zt.LIGHTBLUE=Object.freeze(Zt.fromCssColorString("#ADD8E6"));Zt.LIGHTCORAL=Object.freeze(Zt.fromCssColorString("#F08080"));Zt.LIGHTCYAN=Object.freeze(Zt.fromCssColorString("#E0FFFF"));Zt.LIGHTGOLDENRODYELLOW=Object.freeze(Zt.fromCssColorString("#FAFAD2"));Zt.LIGHTGRAY=Object.freeze(Zt.fromCssColorString("#D3D3D3"));Zt.LIGHTGREEN=Object.freeze(Zt.fromCssColorString("#90EE90"));Zt.LIGHTGREY=Zt.LIGHTGRAY;Zt.LIGHTPINK=Object.freeze(Zt.fromCssColorString("#FFB6C1"));Zt.LIGHTSEAGREEN=Object.freeze(Zt.fromCssColorString("#20B2AA"));Zt.LIGHTSKYBLUE=Object.freeze(Zt.fromCssColorString("#87CEFA"));Zt.LIGHTSLATEGRAY=Object.freeze(Zt.fromCssColorString("#778899"));Zt.LIGHTSLATEGREY=Zt.LIGHTSLATEGRAY;Zt.LIGHTSTEELBLUE=Object.freeze(Zt.fromCssColorString("#B0C4DE"));Zt.LIGHTYELLOW=Object.freeze(Zt.fromCssColorString("#FFFFE0"));Zt.LIME=Object.freeze(Zt.fromCssColorString("#00FF00"));Zt.LIMEGREEN=Object.freeze(Zt.fromCssColorString("#32CD32"));Zt.LINEN=Object.freeze(Zt.fromCssColorString("#FAF0E6"));Zt.MAGENTA=Object.freeze(Zt.fromCssColorString("#FF00FF"));Zt.MAROON=Object.freeze(Zt.fromCssColorString("#800000"));Zt.MEDIUMAQUAMARINE=Object.freeze(Zt.fromCssColorString("#66CDAA"));Zt.MEDIUMBLUE=Object.freeze(Zt.fromCssColorString("#0000CD"));Zt.MEDIUMORCHID=Object.freeze(Zt.fromCssColorString("#BA55D3"));Zt.MEDIUMPURPLE=Object.freeze(Zt.fromCssColorString("#9370DB"));Zt.MEDIUMSEAGREEN=Object.freeze(Zt.fromCssColorString("#3CB371"));Zt.MEDIUMSLATEBLUE=Object.freeze(Zt.fromCssColorString("#7B68EE"));Zt.MEDIUMSPRINGGREEN=Object.freeze(Zt.fromCssColorString("#00FA9A"));Zt.MEDIUMTURQUOISE=Object.freeze(Zt.fromCssColorString("#48D1CC"));Zt.MEDIUMVIOLETRED=Object.freeze(Zt.fromCssColorString("#C71585"));Zt.MIDNIGHTBLUE=Object.freeze(Zt.fromCssColorString("#191970"));Zt.MINTCREAM=Object.freeze(Zt.fromCssColorString("#F5FFFA"));Zt.MISTYROSE=Object.freeze(Zt.fromCssColorString("#FFE4E1"));Zt.MOCCASIN=Object.freeze(Zt.fromCssColorString("#FFE4B5"));Zt.NAVAJOWHITE=Object.freeze(Zt.fromCssColorString("#FFDEAD"));Zt.NAVY=Object.freeze(Zt.fromCssColorString("#000080"));Zt.OLDLACE=Object.freeze(Zt.fromCssColorString("#FDF5E6"));Zt.OLIVE=Object.freeze(Zt.fromCssColorString("#808000"));Zt.OLIVEDRAB=Object.freeze(Zt.fromCssColorString("#6B8E23"));Zt.ORANGE=Object.freeze(Zt.fromCssColorString("#FFA500"));Zt.ORANGERED=Object.freeze(Zt.fromCssColorString("#FF4500"));Zt.ORCHID=Object.freeze(Zt.fromCssColorString("#DA70D6"));Zt.PALEGOLDENROD=Object.freeze(Zt.fromCssColorString("#EEE8AA"));Zt.PALEGREEN=Object.freeze(Zt.fromCssColorString("#98FB98"));Zt.PALETURQUOISE=Object.freeze(Zt.fromCssColorString("#AFEEEE"));Zt.PALEVIOLETRED=Object.freeze(Zt.fromCssColorString("#DB7093"));Zt.PAPAYAWHIP=Object.freeze(Zt.fromCssColorString("#FFEFD5"));Zt.PEACHPUFF=Object.freeze(Zt.fromCssColorString("#FFDAB9"));Zt.PERU=Object.freeze(Zt.fromCssColorString("#CD853F"));Zt.PINK=Object.freeze(Zt.fromCssColorString("#FFC0CB"));Zt.PLUM=Object.freeze(Zt.fromCssColorString("#DDA0DD"));Zt.POWDERBLUE=Object.freeze(Zt.fromCssColorString("#B0E0E6"));Zt.PURPLE=Object.freeze(Zt.fromCssColorString("#800080"));Zt.RED=Object.freeze(Zt.fromCssColorString("#FF0000"));Zt.ROSYBROWN=Object.freeze(Zt.fromCssColorString("#BC8F8F"));Zt.ROYALBLUE=Object.freeze(Zt.fromCssColorString("#4169E1"));Zt.SADDLEBROWN=Object.freeze(Zt.fromCssColorString("#8B4513"));Zt.SALMON=Object.freeze(Zt.fromCssColorString("#FA8072"));Zt.SANDYBROWN=Object.freeze(Zt.fromCssColorString("#F4A460"));Zt.SEAGREEN=Object.freeze(Zt.fromCssColorString("#2E8B57"));Zt.SEASHELL=Object.freeze(Zt.fromCssColorString("#FFF5EE"));Zt.SIENNA=Object.freeze(Zt.fromCssColorString("#A0522D"));Zt.SILVER=Object.freeze(Zt.fromCssColorString("#C0C0C0"));Zt.SKYBLUE=Object.freeze(Zt.fromCssColorString("#87CEEB"));Zt.SLATEBLUE=Object.freeze(Zt.fromCssColorString("#6A5ACD"));Zt.SLATEGRAY=Object.freeze(Zt.fromCssColorString("#708090"));Zt.SLATEGREY=Zt.SLATEGRAY;Zt.SNOW=Object.freeze(Zt.fromCssColorString("#FFFAFA"));Zt.SPRINGGREEN=Object.freeze(Zt.fromCssColorString("#00FF7F"));Zt.STEELBLUE=Object.freeze(Zt.fromCssColorString("#4682B4"));Zt.TAN=Object.freeze(Zt.fromCssColorString("#D2B48C"));Zt.TEAL=Object.freeze(Zt.fromCssColorString("#008080"));Zt.THISTLE=Object.freeze(Zt.fromCssColorString("#D8BFD8"));Zt.TOMATO=Object.freeze(Zt.fromCssColorString("#FF6347"));Zt.TURQUOISE=Object.freeze(Zt.fromCssColorString("#40E0D0"));Zt.VIOLET=Object.freeze(Zt.fromCssColorString("#EE82EE"));Zt.WHEAT=Object.freeze(Zt.fromCssColorString("#F5DEB3"));Zt.WHITE=Object.freeze(Zt.fromCssColorString("#FFFFFF"));Zt.WHITESMOKE=Object.freeze(Zt.fromCssColorString("#F5F5F5"));Zt.YELLOW=Object.freeze(Zt.fromCssColorString("#FFFF00"));Zt.YELLOWGREEN=Object.freeze(Zt.fromCssColorString("#9ACD32"));Zt.TRANSPARENT=Object.freeze(new Zt(0,0,0,0));var v=Zt;function cH(t){t=f(t,f.EMPTY_OBJECT),this.color=t.color,this.depth=t.depth,this.stencil=t.stencil,this.renderState=t.renderState,this.framebuffer=t.framebuffer,this.owner=t.owner,this.pass=t.pass}cH.ALL=Object.freeze(new cH({color:new v(0,0,0,0),depth:1,stencil:0}));cH.prototype.execute=function(t,e){t.clear(this,e)};var ao=cH;var IHe=b(W(),1);var THe=b(W(),1),d_t={ENVIRONMENT:0,COMPUTE:1,GLOBE:2,TERRAIN_CLASSIFICATION:3,CESIUM_3D_TILE:4,CESIUM_3D_TILE_CLASSIFICATION:5,CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW:6,OPAQUE:7,TRANSLUCENT:8,VOXELS:9,OVERLAY:10,NUMBER_OF_PASSES:11},Pt=Object.freeze(d_t);function rmt(t){t=f(t,f.EMPTY_OBJECT),this.vertexArray=t.vertexArray,this.fragmentShaderSource=t.fragmentShaderSource,this.shaderProgram=t.shaderProgram,this.uniformMap=t.uniformMap,this.outputTexture=t.outputTexture,this.preExecute=t.preExecute,this.postExecute=t.postExecute,this.canceled=t.canceled,this.persists=f(t.persists,!1),this.pass=Pt.COMPUTE,this.owner=t.owner}rmt.prototype.execute=function(t){t.execute(this)};var Wm=rmt;var qze=b(W(),1);var bKe=b(W(),1);var kHe=b(W(),1);function Un(t,e){this.x=f(t,0),this.y=f(e,0)}Un.fromElements=function(t,e,n){return c(n)?(n.x=t,n.y=e,n):new Un(t,e)};Un.clone=function(t,e){if(c(t))return c(e)?(e.x=t.x,e.y=t.y,e):new Un(t.x,t.y)};Un.fromCartesian3=Un.clone;Un.fromCartesian4=Un.clone;Un.packedLength=2;Un.pack=function(t,e,n){return n=f(n,0),e[n++]=t.x,e[n]=t.y,e};Un.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Un),n.x=t[e++],n.y=t[e],n};Un.packArray=function(t,e){let n=t.length,i=n*2;c(e)?!Array.isArray(e)&&e.length!==i||e.length!==i&&(e.length=i):e=new Array(i);for(let o=0;ok.EPSILON12);return c(o)?(o.x=a*J,o.y=s*M,o.z=l*Z,o):new p(a*J,s*M,l*Z)}var hG=p_t;function xl(t,e,n){this.longitude=f(t,0),this.latitude=f(e,0),this.height=f(n,0)}xl.fromRadians=function(t,e,n,i){return n=f(n,0),c(i)?(i.longitude=t,i.latitude=e,i.height=n,i):new xl(t,e,n)};xl.fromDegrees=function(t,e,n,i){return t=k.toRadians(t),e=k.toRadians(e),xl.fromRadians(t,e,n,i)};var V_t=new p,u_t=new p,Z_t=new p,R_t=new p(1/6378137,1/6378137,1/6356752314245179e-9),b_t=new p(1/(6378137*6378137),1/(6378137*6378137),1/(6356752314245179e-9*6356752314245179e-9)),W_t=k.EPSILON1;xl.fromCartesian=function(t,e,n){let i=c(e)?e.oneOverRadii:R_t,o=c(e)?e.oneOverRadiiSquared:b_t,a=c(e)?e._centerToleranceSquared:W_t,s=hG(t,i,o,a,u_t);if(!c(s))return;let l=p.multiplyComponents(s,o,V_t);l=p.normalize(l,l);let r=p.subtract(t,s,Z_t),d=Math.atan2(l.y,l.x),m=Math.asin(l.z),h=k.sign(p.dot(r,t))*p.magnitude(r);return c(n)?(n.longitude=d,n.latitude=m,n.height=h,n):new xl(d,m,h)};xl.toCartesian=function(t,e,n){return p.fromRadians(t.longitude,t.latitude,t.height,e,n)};xl.clone=function(t,e){if(c(t))return c(e)?(e.longitude=t.longitude,e.latitude=t.latitude,e.height=t.height,e):new xl(t.longitude,t.latitude,t.height)};xl.equals=function(t,e){return t===e||c(t)&&c(e)&&t.longitude===e.longitude&&t.latitude===e.latitude&&t.height===e.height};xl.equalsEpsilon=function(t,e,n){return n=f(n,0),t===e||c(t)&&c(e)&&Math.abs(t.longitude-e.longitude)<=n&&Math.abs(t.latitude-e.latitude)<=n&&Math.abs(t.height-e.height)<=n};xl.ZERO=Object.freeze(new xl(0,0,0));xl.prototype.clone=function(t){return xl.clone(this,t)};xl.prototype.equals=function(t){return xl.equals(this,t)};xl.prototype.equalsEpsilon=function(t,e){return xl.equalsEpsilon(this,t,e)};xl.prototype.toString=function(){return`(${this.longitude}, ${this.latitude}, ${this.height})`};var gt=xl;var dwe=b(W(),1);var nwe=b(W(),1);function pmt(t,e,n,i){e=f(e,0),n=f(n,0),i=f(i,0),t._radii=new p(e,n,i),t._radiiSquared=new p(e*e,n*n,i*i),t._radiiToTheFourth=new p(e*e*e*e,n*n*n*n,i*i*i*i),t._oneOverRadii=new p(e===0?0:1/e,n===0?0:1/n,i===0?0:1/i),t._oneOverRadiiSquared=new p(e===0?0:1/(e*e),n===0?0:1/(n*n),i===0?0:1/(i*i)),t._minimumRadius=Math.min(e,n,i),t._maximumRadius=Math.max(e,n,i),t._centerToleranceSquared=k.EPSILON1,t._radiiSquared.z!==0&&(t._squaredXOverSquaredZ=t._radiiSquared.x/t._radiiSquared.z)}function oa(t,e,n){this._radii=void 0,this._radiiSquared=void 0,this._radiiToTheFourth=void 0,this._oneOverRadii=void 0,this._oneOverRadiiSquared=void 0,this._minimumRadius=void 0,this._maximumRadius=void 0,this._centerToleranceSquared=void 0,this._squaredXOverSquaredZ=void 0,pmt(this,t,e,n)}Object.defineProperties(oa.prototype,{radii:{get:function(){return this._radii}},radiiSquared:{get:function(){return this._radiiSquared}},radiiToTheFourth:{get:function(){return this._radiiToTheFourth}},oneOverRadii:{get:function(){return this._oneOverRadii}},oneOverRadiiSquared:{get:function(){return this._oneOverRadiiSquared}},minimumRadius:{get:function(){return this._minimumRadius}},maximumRadius:{get:function(){return this._maximumRadius}}});oa.clone=function(t,e){if(!c(t))return;let n=t._radii;return c(e)?(p.clone(n,e._radii),p.clone(t._radiiSquared,e._radiiSquared),p.clone(t._radiiToTheFourth,e._radiiToTheFourth),p.clone(t._oneOverRadii,e._oneOverRadii),p.clone(t._oneOverRadiiSquared,e._oneOverRadiiSquared),e._minimumRadius=t._minimumRadius,e._maximumRadius=t._maximumRadius,e._centerToleranceSquared=t._centerToleranceSquared,e):new oa(n.x,n.y,n.z)};oa.fromCartesian3=function(t,e){return c(e)||(e=new oa),c(t)&&pmt(e,t.x,t.y,t.z),e};oa.WGS84=Object.freeze(new oa(6378137,6378137,6356752314245179e-9));oa.UNIT_SPHERE=Object.freeze(new oa(1,1,1));oa.MOON=Object.freeze(new oa(k.LUNAR_RADIUS,k.LUNAR_RADIUS,k.LUNAR_RADIUS));oa.prototype.clone=function(t){return oa.clone(this,t)};oa.packedLength=p.packedLength;oa.pack=function(t,e,n){return n=f(n,0),p.pack(t._radii,e,n),e};oa.unpack=function(t,e,n){e=f(e,0);let i=p.unpack(t,e);return oa.fromCartesian3(i,n)};oa.prototype.geocentricSurfaceNormal=p.normalize;oa.prototype.geodeticSurfaceNormalCartographic=function(t,e){let n=t.longitude,i=t.latitude,o=Math.cos(i),a=o*Math.cos(n),s=o*Math.sin(n),l=Math.sin(i);return c(e)||(e=new p),e.x=a,e.y=s,e.z=l,p.normalize(e,e)};oa.prototype.geodeticSurfaceNormal=function(t,e){if(!p.equalsEpsilon(t,p.ZERO,k.EPSILON14))return c(e)||(e=new p),e=p.multiplyComponents(t,this._oneOverRadiiSquared,e),p.normalize(e,e)};var f_t=new p,F_t=new p;oa.prototype.cartographicToCartesian=function(t,e){let n=f_t,i=F_t;this.geodeticSurfaceNormalCartographic(t,n),p.multiplyComponents(this._radiiSquared,n,i);let o=Math.sqrt(p.dot(n,i));return p.divideByScalar(i,o,i),p.multiplyByScalar(n,t.height,n),c(e)||(e=new p),p.add(i,n,e)};oa.prototype.cartographicArrayToCartesianArray=function(t,e){let n=t.length;c(e)?e.length=n:e=new Array(n);for(let i=0;i=this._radii.z-e))return n};var S_t=new p;oa.prototype.getLocalCurvature=function(t,e){c(e)||(e=new K);let n=this.getSurfaceNormalIntersectionWithZAxis(t,0,S_t),i=p.distance(t,n),o=this.minimumRadius*i/this.maximumRadius**2,a=i*o**2;return K.fromElements(1/i,1/a,e)};var T_t=[.14887433898163,.43339539412925,.67940956829902,.86506336668898,.97390652851717,0],g_t=[.29552422471475,.26926671930999,.21908636251598,.14945134915058,.066671344308684,0];function hmt(t,e,n){let i=.5*(e+t),o=.5*(e-t),a=0;for(let s=0;s<5;s++){let l=o*T_t[s];a+=g_t[s]*(n(i+l)+n(i-l))}return a*=o,a}oa.prototype.surfaceArea=function(t){let e=t.west,n=t.east,i=t.south,o=t.north;for(;n0){o=a-1;continue}return a}return~(o+1)}var Ja=C_t;var uwe=b(W(),1);function I_t(t,e,n,i,o){this.xPoleWander=t,this.yPoleWander=e,this.xPoleOffset=n,this.yPoleOffset=i,this.ut1MinusUtc=o}var lf=I_t;var Jwe=b(W(),1);var Gwe=b(W(),1);var Rwe=b(W(),1);function N_t(t){return t%4===0&&t%100!==0||t%400===0}var PV=N_t;var Vmt=[31,28,31,30,31,30,31,31,30,31,30,31];function y_t(t,e,n,i,o,a,s,l){t=f(t,1),e=f(e,1),n=f(n,1),i=f(i,0),o=f(o,0),a=f(a,0),s=f(s,0),l=f(l,!1),this.year=t,this.month=e,this.day=n,this.hour=i,this.minute=o,this.second=a,this.millisecond=s,this.isLeapSecond=l;function F(){Xa.typeOf.number.greaterThanOrEquals("Year",t,1),Xa.typeOf.number.lessThanOrEquals("Year",t,9999),Xa.typeOf.number.greaterThanOrEquals("Month",e,1),Xa.typeOf.number.lessThanOrEquals("Month",e,12),Xa.typeOf.number.greaterThanOrEquals("Day",n,1),Xa.typeOf.number.lessThanOrEquals("Day",n,31),Xa.typeOf.number.greaterThanOrEquals("Hour",i,0),Xa.typeOf.number.lessThanOrEquals("Hour",i,23),Xa.typeOf.number.greaterThanOrEquals("Minute",o,0),Xa.typeOf.number.lessThanOrEquals("Minute",o,59),Xa.typeOf.bool("IsLeapSecond",l),Xa.typeOf.number.greaterThanOrEquals("Second",a,0),Xa.typeOf.number.lessThanOrEquals("Second",a,l?60:59),Xa.typeOf.number.greaterThanOrEquals("Millisecond",s,0),Xa.typeOf.number.lessThan("Millisecond",s,1e3)}function U(){let G=e===2&&PV(t)?Vmt[e-1]+1:Vmt[e-1];if(n>G)throw new Ut("Month and Day represents invalid date")}}var Wb=y_t;var Swe=b(W(),1);function B_t(t,e){this.julianDate=t,this.offset=e}var zo=B_t;var gwe=b(W(),1),Q_t={SECONDS_PER_MILLISECOND:.001,SECONDS_PER_MINUTE:60,MINUTES_PER_HOUR:60,HOURS_PER_DAY:24,SECONDS_PER_HOUR:3600,MINUTES_PER_DAY:1440,SECONDS_PER_DAY:86400,DAYS_PER_JULIAN_CENTURY:36525,PICOSECOND:1e-9,MODIFIED_JULIAN_DATE_DIFFERENCE:24000005e-1},xi=Object.freeze(Q_t);var Cwe=b(W(),1),k_t={UTC:0,TAI:1},Di=Object.freeze(k_t);var Zmt=new Wb,R6=[31,28,31,30,31,30,31,31,30,31,30,31],b6=29;function W6(t,e){return mn.compare(t.julianDate,e.julianDate)}var zg=new zo;function VH(t){zg.julianDate=t;let e=mn.leapSeconds,n=Ja(e,zg,W6);n<0&&(n=~n),n>=e.length&&(n=e.length-1);let i=e[n].offset;n>0&&mn.secondsDifference(e[n].julianDate,t)>i&&(n--,i=e[n].offset),mn.addSeconds(t,i,t)}function umt(t,e){zg.julianDate=t;let n=mn.leapSeconds,i=Ja(n,zg,W6);if(i<0&&(i=~i),i===0)return mn.addSeconds(t,-n[0].offset,e);if(i>=n.length)return mn.addSeconds(t,-n[i-1].offset,e);let o=mn.secondsDifference(n[i].julianDate,t);if(o===0)return mn.addSeconds(t,-n[i].offset,e);if(!(o<=1))return mn.addSeconds(t,-n[--i].offset,e)}function rf(t,e,n){let i=e/xi.SECONDS_PER_DAY|0;return t+=i,e-=xi.SECONDS_PER_DAY*i,e<0&&(t--,e+=xi.SECONDS_PER_DAY),n.dayNumber=t,n.secondsOfDay=e,n}function f6(t,e,n,i,o,a,s){let l=(e-14)/12|0,r=t+4800+l,d=(1461*r/4|0)+(367*(e-2-12*l)/12|0)-(3*((r+100)/100|0)/4|0)+n-32075;i=i-12,i<0&&(i+=24);let m=a+(i*xi.SECONDS_PER_HOUR+o*xi.SECONDS_PER_MINUTE+s*xi.SECONDS_PER_MILLISECOND);return m>=43200&&(d-=1),[d,m]}var Y_t=/^(\d{4})$/,x_t=/^(\d{4})-(\d{2})$/,X_t=/^(\d{4})-?(\d{3})$/,J_t=/^(\d{4})-?W(\d{2})-?(\d{1})?$/,L_t=/^(\d{4})-?(\d{2})-?(\d{2})$/,F6=/([Z+\-])?(\d{2})?:?(\d{2})?$/,M_t=/^(\d{2})(\.\d+)?/.source+F6.source,__t=/^(\d{2}):?(\d{2})(\.\d+)?/.source+F6.source,D_t=/^(\d{2}):?(\d{2}):?(\d{2})(\.\d+)?/.source+F6.source;function mn(t,e,n){this.dayNumber=void 0,this.secondsOfDay=void 0,t=f(t,0),e=f(e,0),n=f(n,Di.UTC);let i=t|0;e=e+(t-i)*xi.SECONDS_PER_DAY,rf(i,e,this),n===Di.UTC&&VH(this)}mn.fromGregorianDate=function(t,e){let n=f6(t.year,t.month,t.day,t.hour,t.minute,t.second,t.millisecond);return c(e)?(rf(n[0],n[1],e),VH(e),e):new mn(n[0],n[1],Di.UTC)};mn.fromDate=function(t,e){let n=f6(t.getUTCFullYear(),t.getUTCMonth()+1,t.getUTCDate(),t.getUTCHours(),t.getUTCMinutes(),t.getUTCSeconds(),t.getUTCMilliseconds());return c(e)?(rf(n[0],n[1],e),VH(e),e):new mn(n[0],n[1],Di.UTC)};mn.fromIso8601=function(t,e){t=t.replace(",",".");let n=t.split("T"),i,o=1,a=1,s=0,l=0,r=0,d=0,m=n[0],h=n[1],u,R;if(n=m.match(L_t),n!==null)i=+n[1],o=+n[2],a=+n[3];else if(n=m.match(x_t),n!==null)i=+n[1],o=+n[2];else if(n=m.match(Y_t),n!==null)i=+n[1];else{let G;if(n=m.match(X_t),n!==null)i=+n[1],G=+n[2],R=PV(i);else if(n=m.match(J_t),n!==null){i=+n[1];let A=+n[2],S=+n[3]||0,g=new Date(Date.UTC(i,0,4));G=A*7+S-g.getUTCDay()-3}u=new Date(Date.UTC(i,0,1)),u.setUTCDate(G),o=u.getUTCMonth()+1,a=u.getUTCDate()}R=PV(i);let V;if(c(h)){n=h.match(D_t),n!==null?(s=+n[1],l=+n[2],r=+n[3],d=+(n[4]||0)*1e3,V=5):(n=h.match(__t),n!==null?(s=+n[1],l=+n[2],r=+(n[3]||0)*60,V=4):(n=h.match(M_t),n!==null&&(s=+n[1],l=+(n[2]||0)*60,V=3)));let G=n[V],A=+n[V+1],S=+(n[V+2]||0);switch(G){case"+":s=s-A,l=l-S;break;case"-":s=s+A,l=l+S;break;case"Z":break;default:l=l+new Date(Date.UTC(i,o-1,a,s,l)).getTimezoneOffset();break}}let F=r===60;for(F&&r--;l>=60;)l-=60,s++;for(;s>=24;)s-=24,a++;for(u=R&&o===2?b6:R6[o-1];a>u;)a-=u,o++,o>12&&(o-=12,i++),u=R&&o===2?b6:R6[o-1];for(;l<0;)l+=60,s--;for(;s<0;)s+=24,a--;for(;a<1;)o--,o<1&&(o+=12,i--),u=R&&o===2?b6:R6[o-1],a+=u;let U=f6(i,o,a,s,l,r,d);return c(e)?(rf(U[0],U[1],e),VH(e)):e=new mn(U[0],U[1],Di.UTC),F&&mn.addSeconds(e,1,e),e};mn.now=function(t){return mn.fromDate(new Date,t)};var pH=new mn(0,0,Di.TAI);mn.toGregorianDate=function(t,e){let n=!1,i=umt(t,pH);c(i)||(mn.addSeconds(t,-1,pH),i=umt(pH,pH),n=!0);let o=i.dayNumber,a=i.secondsOfDay;a>=43200&&(o+=1);let s=o+68569|0,l=4*s/146097|0;s=s-((146097*l+3)/4|0)|0;let r=4e3*(s+1)/1461001|0;s=s-(1461*r/4|0)+31|0;let d=80*s/2447|0,m=s-(2447*d/80|0)|0;s=d/11|0;let h=d+2-12*s|0,u=100*(l-49)+r+s|0,R=a/xi.SECONDS_PER_HOUR|0,V=a-R*xi.SECONDS_PER_HOUR,F=V/xi.SECONDS_PER_MINUTE|0;V=V-F*xi.SECONDS_PER_MINUTE;let U=V|0,G=(V-U)/xi.SECONDS_PER_MILLISECOND;return R+=12,R>23&&(R-=24),n&&(U+=1),c(e)?(e.year=u,e.month=h,e.day=m,e.hour=R,e.minute=F,e.second=U,e.millisecond=G,e.isLeapSecond=n,e):new Wb(u,h,m,R,F,U,G,n)};mn.toDate=function(t){let e=mn.toGregorianDate(t,Zmt),n=e.second;return e.isLeapSecond&&(n-=1),new Date(Date.UTC(e.year,e.month-1,e.day,e.hour,e.minute,n,e.millisecond))};mn.toIso8601=function(t,e){let n=mn.toGregorianDate(t,Zmt),i=n.year,o=n.month,a=n.day,s=n.hour,l=n.minute,r=n.second,d=n.millisecond;i===1e4&&o===1&&a===1&&s===0&&l===0&&r===0&&d===0&&(i=9999,o=12,a=31,s=24);let m;return!c(e)&&d!==0?(m=(d*.01).toString().replace(".",""),`${i.toString().padStart(4,"0")}-${o.toString().padStart(2,"0")}-${a.toString().padStart(2,"0")}T${s.toString().padStart(2,"0")}:${l.toString().padStart(2,"0")}:${r.toString().padStart(2,"0")}.${m}Z`):!c(e)||e===0?`${i.toString().padStart(4,"0")}-${o.toString().padStart(2,"0")}-${a.toString().padStart(2,"0")}T${s.toString().padStart(2,"0")}:${l.toString().padStart(2,"0")}:${r.toString().padStart(2,"0")}Z`:(m=(d*.01).toFixed(e).replace(".","").slice(0,e),`${i.toString().padStart(4,"0")}-${o.toString().padStart(2,"0")}-${a.toString().padStart(2,"0")}T${s.toString().padStart(2,"0")}:${l.toString().padStart(2,"0")}:${r.toString().padStart(2,"0")}.${m}Z`)};mn.clone=function(t,e){if(c(t))return c(e)?(e.dayNumber=t.dayNumber,e.secondsOfDay=t.secondsOfDay,e):new mn(t.dayNumber,t.secondsOfDay,Di.TAI)};mn.compare=function(t,e){let n=t.dayNumber-e.dayNumber;return n!==0?n:t.secondsOfDay-e.secondsOfDay};mn.equals=function(t,e){return t===e||c(t)&&c(e)&&t.dayNumber===e.dayNumber&&t.secondsOfDay===e.secondsOfDay};mn.equalsEpsilon=function(t,e,n){return n=f(n,0),t===e||c(t)&&c(e)&&Math.abs(mn.secondsDifference(t,e))<=n};mn.totalDays=function(t){return t.dayNumber+t.secondsOfDay/xi.SECONDS_PER_DAY};mn.secondsDifference=function(t,e){return(t.dayNumber-e.dayNumber)*xi.SECONDS_PER_DAY+(t.secondsOfDay-e.secondsOfDay)};mn.daysDifference=function(t,e){let n=t.dayNumber-e.dayNumber,i=(t.secondsOfDay-e.secondsOfDay)/xi.SECONDS_PER_DAY;return n+i};mn.computeTaiMinusUtc=function(t){zg.julianDate=t;let e=mn.leapSeconds,n=Ja(e,zg,W6);return n<0&&(n=~n,--n,n<0&&(n=0)),e[n].offset};mn.addSeconds=function(t,e,n){return rf(t.dayNumber,t.secondsOfDay+e,n)};mn.addMinutes=function(t,e,n){let i=t.secondsOfDay+e*xi.SECONDS_PER_MINUTE;return rf(t.dayNumber,i,n)};mn.addHours=function(t,e,n){let i=t.secondsOfDay+e*xi.SECONDS_PER_HOUR;return rf(t.dayNumber,i,n)};mn.addDays=function(t,e,n){let i=t.dayNumber+e;return rf(i,t.secondsOfDay,n)};mn.lessThan=function(t,e){return mn.compare(t,e)<0};mn.lessThanOrEquals=function(t,e){return mn.compare(t,e)<=0};mn.greaterThan=function(t,e){return mn.compare(t,e)>0};mn.greaterThanOrEquals=function(t,e){return mn.compare(t,e)>=0};mn.prototype.clone=function(t){return mn.clone(this,t)};mn.prototype.equals=function(t){return mn.equals(this,t)};mn.prototype.equalsEpsilon=function(t,e){return mn.equalsEpsilon(this,t,e)};mn.prototype.toString=function(){return mn.toIso8601(this)};mn.leapSeconds=[new zo(new mn(2441317,43210,Di.TAI),10),new zo(new mn(2441499,43211,Di.TAI),11),new zo(new mn(2441683,43212,Di.TAI),12),new zo(new mn(2442048,43213,Di.TAI),13),new zo(new mn(2442413,43214,Di.TAI),14),new zo(new mn(2442778,43215,Di.TAI),15),new zo(new mn(2443144,43216,Di.TAI),16),new zo(new mn(2443509,43217,Di.TAI),17),new zo(new mn(2443874,43218,Di.TAI),18),new zo(new mn(2444239,43219,Di.TAI),19),new zo(new mn(2444786,43220,Di.TAI),20),new zo(new mn(2445151,43221,Di.TAI),21),new zo(new mn(2445516,43222,Di.TAI),22),new zo(new mn(2446247,43223,Di.TAI),23),new zo(new mn(2447161,43224,Di.TAI),24),new zo(new mn(2447892,43225,Di.TAI),25),new zo(new mn(2448257,43226,Di.TAI),26),new zo(new mn(2448804,43227,Di.TAI),27),new zo(new mn(2449169,43228,Di.TAI),28),new zo(new mn(2449534,43229,Di.TAI),29),new zo(new mn(2450083,43230,Di.TAI),30),new zo(new mn(2450630,43231,Di.TAI),31),new zo(new mn(2451179,43232,Di.TAI),32),new zo(new mn(2453736,43233,Di.TAI),33),new zo(new mn(2454832,43234,Di.TAI),34),new zo(new mn(2456109,43235,Di.TAI),35),new zo(new mn(2457204,43236,Di.TAI),36),new zo(new mn(2457754,43237,Di.TAI),37)];var rt=mn;var Bve=b(W(),1),kmt=b(Vh(),1);var Hwe=b(W(),1);function O_t(t){return(t.length===0||t[t.length-1]!=="/")&&(t=`${t}/`),t}var $N=O_t;var vwe=b(W(),1);function Gmt(t,e){if(t===null||typeof t!="object")return t;e=f(e,!1);let n=new t.constructor;for(let i in t)if(t.hasOwnProperty(i)){let o=t[i];e&&(o=Gmt(o,e)),n[i]=o}return n}var Re=Gmt;var qwe=b(W(),1);function Amt(t,e,n){n=f(n,!1);let i={},o=c(t),a=c(e),s,l,r;if(o)for(s in t)t.hasOwnProperty(s)&&(l=t[s],a&&n&&typeof l=="object"&&e.hasOwnProperty(s)?(r=e[s],typeof r=="object"?i[s]=Amt(l,r,n):i[s]=l):i[s]=l);if(a)for(s in e)e.hasOwnProperty(s)&&!i.hasOwnProperty(s)&&(r=e[s],i[s]=r);return i}var ze=Amt;var tPe=b(W(),1);function H_t(){let t,e,n=new Promise(function(i,o){t=i,e=o});return{resolve:t,reject:e,promise:n}}var kd=H_t;var oPe=b(W(),1),Smt=b(Vh(),1);function U6(t,e){let n;return typeof document<"u"&&(n=document),U6._implementation(t,e,n)}U6._implementation=function(t,e,n){if(!c(e)){if(typeof n>"u")return t;e=f(n.baseURI,n.location.href)}let i=new Smt.default(t);return i.scheme()!==""?i.toString():i.absoluteTo(e).toString()};var IZ=U6;var sPe=b(W(),1),Tmt=b(Vh(),1);function w_t(t,e){let n="",i=t.lastIndexOf("/");return i!==-1&&(n=t.substring(0,i+1)),e&&(t=new Tmt.default(t),t.query().length!==0&&(n+=`?${t.query()}`),t.fragment().length!==0&&(n+=`#${t.fragment()}`)),n}var ty=w_t;var rPe=b(W(),1),gmt=b(Vh(),1);function P_t(t){let e=new gmt.default(t);e.normalize();let n=e.path(),i=n.lastIndexOf("/");return i!==-1&&(n=n.substr(i+1)),i=n.lastIndexOf("."),i===-1?n="":n=n.substr(i+1),n}var pG=P_t;var mPe=b(W(),1);var Emt={};function v_t(t,e,n){c(e)||(e=t.width),c(n)||(n=t.height);let i=Emt[e];c(i)||(i={},Emt[e]=i);let o=i[n];if(!c(o)){let a=document.createElement("canvas");a.width=e,a.height=n,o=a.getContext("2d",{willReadFrequently:!0}),o.globalCompositeOperation="copy",i[n]=o}return o.drawImage(t,0,0,e,n),o.getImageData(0,0,e,n).data}var vV=v_t;var pPe=b(W(),1);var K_t=/^blob:/i;function z_t(t){return K_t.test(t)}var VG=z_t;var ZPe=b(W(),1);var NZ;function j_t(t){c(NZ)||(NZ=document.createElement("a")),NZ.href=window.location.href;let e=NZ.host,n=NZ.protocol;return NZ.href=t,NZ.href=NZ.href,n!==NZ.protocol||e!==NZ.host}var uG=j_t;var bPe=b(W(),1);var q_t=/^data:/i;function $_t(t){return q_t.test(t)}var fb=$_t;var fPe=b(W(),1);function t9t(t){let e=document.createElement("script");return e.async=!0,e.src=t,new Promise((n,i)=>{window.crossOriginIsolated&&e.setAttribute("crossorigin","anonymous");let o=document.getElementsByTagName("head")[0];e.onload=function(){e.onload=void 0,o.removeChild(e),n()},e.onerror=function(a){i(a)},o.appendChild(e)})}var ZG=t9t;var UPe=b(W(),1);function e9t(t){let e="";for(let n in t)if(t.hasOwnProperty(n)){let i=t[n],o=`${encodeURIComponent(n)}=`;if(Array.isArray(i))for(let a=0,s=i.length;a0){let s=o.substring(0,a),l=o.substring(a+2);e[s]=l}}return e}var ey=a9t;function Cmt(t,e,n){this.statusCode=t,this.response=e,this.responseHeaders=n,typeof this.responseHeaders=="string"&&(this.responseHeaders=ey(this.responseHeaders))}Cmt.prototype.toString=function(){let t="Request has failed.";return c(this.statusCode)&&(t+=` Status Code: ${this.statusCode}`),t};var yZ=Cmt;var ove=b(W(),1),WH=b(Vh(),1);var OPe=b(W(),1);function ny(){this._listeners=[],this._scopes=[],this._toRemove=[],this._insideRaiseEvent=!1}Object.defineProperties(ny.prototype,{numberOfListeners:{get:function(){return this._listeners.length-this._toRemove.length}}});ny.prototype.addEventListener=function(t,e){this._listeners.push(t),this._scopes.push(e);let n=this;return function(){n.removeEventListener(t,e)}};ny.prototype.removeEventListener=function(t,e){let n=this._listeners,i=this._scopes,o=-1;for(let a=0;a0){for(o.sort(s9t),t=0;t=0;--e)this.heapify(e)};bG.prototype.insert=function(t){let e=this._array,n=this._comparator,i=this._maximumLength,o=this._length++;for(oi&&(a=e[i],this._length=i),a};bG.prototype.pop=function(t){if(t=f(t,0),this._length===0)return;let e=this._array,n=e[t];return G6(e,t,--this._length),this.heapify(t),e[this._length]=void 0,n};var iy=bG;function l9t(t,e){return t.priority-e.priority}var ha={numberOfAttemptedRequests:0,numberOfActiveRequests:0,numberOfCancelledRequests:0,numberOfCancelledActiveRequests:0,numberOfFailedRequests:0,numberOfActiveRequestsEver:0,lastNumberOfActiveRequests:0},$g=20,Yd=new iy({comparator:l9t});Yd.maximumLength=$g;Yd.reserve($g);var BZ=[],Fb={},r9t=typeof document<"u"?new WH.default(document.location.href):new WH.default,fH=new It;function Zs(){}Zs.maximumRequests=50;Zs.maximumRequestsPerServer=18;Zs.requestsByServer={};Zs.throttleRequests=!0;Zs.debugShowStatistics=!1;Zs.requestCompletedEvent=fH;Object.defineProperties(Zs,{statistics:{get:function(){return ha}},priorityHeapLength:{get:function(){return $g},set:function(t){if(t<$g)for(;Yd.length>t;){let e=Yd.pop();WG(e)}$g=t,Yd.maximumLength=t,Yd.reserve(t)}}});function Imt(t){c(t.priorityFunction)&&(t.priority=t.priorityFunction())}Zs.serverHasOpenSlots=function(t,e){e=f(e,1);let n=f(Zs.requestsByServer[t],Zs.maximumRequestsPerServer);return Fb[t]+e<=n};Zs.heapHasOpenSlots=function(t){return Yd.length+t<=$g};function Nmt(t){return t.state===qi.UNISSUED&&(t.state=qi.ISSUED,t.deferred=kd()),t.deferred.promise}function d9t(t){return function(e){if(t.state===qi.CANCELLED)return;let n=t.deferred;--ha.numberOfActiveRequests,--Fb[t.serverKey],fH.raiseEvent(),t.state=qi.RECEIVED,t.deferred=void 0,n.resolve(e)}}function c9t(t){return function(e){t.state!==qi.CANCELLED&&(++ha.numberOfFailedRequests,--ha.numberOfActiveRequests,--Fb[t.serverKey],fH.raiseEvent(e),t.state=qi.FAILED,t.deferred.reject(e))}}function ymt(t){let e=Nmt(t);return t.state=qi.ACTIVE,BZ.push(t),++ha.numberOfActiveRequests,++ha.numberOfActiveRequestsEver,++Fb[t.serverKey],t.requestFunction().then(d9t(t)).catch(c9t(t)),e}function WG(t){let e=t.state===qi.ACTIVE;if(t.state=qi.CANCELLED,++ha.numberOfCancelledRequests,c(t.deferred)){let n=t.deferred;t.deferred=void 0,n.reject()}e&&(--ha.numberOfActiveRequests,--Fb[t.serverKey],++ha.numberOfCancelledActiveRequests),c(t.cancelFunction)&&t.cancelFunction()}Zs.update=function(){let t,e,n=0,i=BZ.length;for(t=0;t0&&(BZ[t-n]=e)}BZ.length-=n;let o=Yd.internalArray,a=Yd.length;for(t=0;t0;){if(e=Yd.pop(),e.cancelled){WG(e);continue}if(e.throttleByServer&&!Zs.serverHasOpenSlots(e.serverKey)){WG(e);continue}ymt(e),++l}m9t()};Zs.getServerKey=function(t){let e=new WH.default(t);e.scheme()===""&&(e=e.absoluteTo(r9t),e.normalize());let n=e.authority();/:/.test(n)||(n=`${n}:${e.scheme()==="https"?"443":"80"}`);let i=Fb[n];return c(i)||(Fb[n]=0),n};Zs.request=function(t){if(fb(t.url)||VG(t.url))return fH.raiseEvent(),t.state=qi.RECEIVED,t.requestFunction();if(++ha.numberOfAttemptedRequests,c(t.serverKey)||(t.serverKey=Zs.getServerKey(t.url)),Zs.throttleRequests&&t.throttleByServer&&!Zs.serverHasOpenSlots(t.serverKey))return;if(!Zs.throttleRequests||!t.throttle)return ymt(t);if(BZ.length>=Zs.maximumRequests)return;Imt(t);let e=Yd.insert(t);if(c(e)){if(e===t)return;WG(e)}return Nmt(t)};function m9t(){Zs.debugShowStatistics&&(ha.numberOfActiveRequests===0&&ha.lastNumberOfActiveRequests>0&&(ha.numberOfAttemptedRequests>0&&(console.log(`Number of attempted requests: ${ha.numberOfAttemptedRequests}`),ha.numberOfAttemptedRequests=0),ha.numberOfCancelledRequests>0&&(console.log(`Number of cancelled requests: ${ha.numberOfCancelledRequests}`),ha.numberOfCancelledRequests=0),ha.numberOfCancelledActiveRequests>0&&(console.log(`Number of cancelled active requests: ${ha.numberOfCancelledActiveRequests}`),ha.numberOfCancelledActiveRequests=0),ha.numberOfFailedRequests>0&&(console.log(`Number of failed requests: ${ha.numberOfFailedRequests}`),ha.numberOfFailedRequests=0)),ha.lastNumberOfActiveRequests=ha.numberOfActiveRequests)}Zs.clearForSpecs=function(){for(;Yd.length>0;){let e=Yd.pop();WG(e)}let t=BZ.length;for(let e=0;e0}},credits:{get:function(){return this._credits}}});cn.prototype.toString=function(){return this.getUrlComponent(!0,!0)};cn.prototype.parseUrl=function(t,e,n,i){let o=new kmt.default(t),a=p9t(o.query());this._queryParameters=e?UH(a,this.queryParameters,n):a,o.search(""),o.fragment(""),c(i)&&o.scheme()===""&&(o=o.absoluteTo(IZ(i))),this._url=o.toString()};function p9t(t){return t.length===0?{}:t.indexOf("=")===-1?{[t]:void 0}:Sc(t)}function UH(t,e,n){if(!n)return ze(t,e);let i=Re(t,!0);for(let o in e)if(e.hasOwnProperty(o)){let a=i[o],s=e[o];c(a)?(Array.isArray(a)||(a=i[o]=[a]),i[o]=a.concat(s)):i[o]=Array.isArray(s)?s.slice():s}return i}cn.prototype.getUrlComponent=function(t,e){if(this.isDataUri)return this._url;let n=this._url;t&&(n=`${n}${V9t(this.queryParameters)}`),n=n.replace(/%7B/g,"{").replace(/%7D/g,"}");let i=this._templateValues;return Object.keys(i).length>0&&(n=n.replace(/{(.*?)}/g,function(o,a){let s=i[a];return c(s)?encodeURIComponent(s):o})),e&&c(this.proxy)&&(n=this.proxy.getURL(n)),n};function V9t(t){let e=Object.keys(t);return e.length===0?"":e.length===1&&!c(t[e[0]])?`?${e[0]}`:`?${RG(t)}`}cn.prototype.setQueryParameters=function(t,e){e?this._queryParameters=UH(this._queryParameters,t,!1):this._queryParameters=UH(t,this._queryParameters,!1)};cn.prototype.appendQueryParameters=function(t){this._queryParameters=UH(t,this._queryParameters,!0)};cn.prototype.setTemplateValues=function(t,e){e?this._templateValues=ze(this._templateValues,t):this._templateValues=ze(t,this._templateValues)};cn.prototype.getDerivedResource=function(t){let e=this.clone();if(e._retryCount=0,c(t.url)){let n=f(t.preserveQueryParameters,!1);e.parseUrl(t.url,!0,n,this._url)}return c(t.queryParameters)&&(e._queryParameters=ze(t.queryParameters,e.queryParameters)),c(t.templateValues)&&(e._templateValues=ze(t.templateValues,e.templateValues)),c(t.headers)&&(e.headers=ze(t.headers,e.headers)),c(t.proxy)&&(e.proxy=t.proxy),c(t.request)&&(e.request=t.request),c(t.retryCallback)&&(e.retryCallback=t.retryCallback),c(t.retryAttempts)&&(e.retryAttempts=t.retryAttempts),e};cn.prototype.retryOnError=function(t){let e=this.retryCallback;if(typeof e!="function"||this._retryCount>=this.retryAttempts)return Promise.resolve(!1);let n=this;return Promise.resolve(e(this,t)).then(function(i){return++n._retryCount,i})};cn.prototype.clone=function(t){return c(t)?(t._url=this._url,t._queryParameters=Re(this._queryParameters),t._templateValues=Re(this._templateValues),t.headers=Re(this.headers),t.proxy=this.proxy,t.retryCallback=this.retryCallback,t.retryAttempts=this.retryAttempts,t._retryCount=0,t.request=this.request.clone(),t):new cn({url:this._url,queryParameters:this.queryParameters,templateValues:this.templateValues,headers:this.headers,proxy:this.proxy,retryCallback:this.retryCallback,retryAttempts:this.retryAttempts,request:this.request.clone(),parseUrl:!1,credits:c(this.credits)?this.credits.slice():void 0})};cn.prototype.getBaseUri=function(t){return ty(this.getUrlComponent(t),t)};cn.prototype.appendForwardSlash=function(){this._url=$N(this._url)};cn.prototype.fetchArrayBuffer=function(){return this.fetch({responseType:"arraybuffer"})};cn.fetchArrayBuffer=function(t){return new cn(t).fetchArrayBuffer()};cn.prototype.fetchBlob=function(){return this.fetch({responseType:"blob"})};cn.fetchBlob=function(t){return new cn(t).fetchBlob()};cn.prototype.fetchImage=function(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.preferImageBitmap,!1),n=f(t.preferBlob,!1),i=f(t.flipY,!1),o=f(t.skipColorSpaceConversion,!1);if(S6(this.request),!Ymt||this.isDataUri||this.isBlobUri||!this.hasHeaders&&!n)return A6({resource:this,flipY:i,skipColorSpaceConversion:o,preferImageBitmap:e});let a=this.fetchBlob();if(!c(a))return;let s,l,r,d;return cn.supportsImageBitmapOptions().then(function(m){return s=m,l=s&&e,a}).then(function(m){if(!c(m))return;if(d=m,l)return cn.createImageBitmapFromBlob(m,{flipY:i,premultiplyAlpha:!1,skipColorSpaceConversion:o});let h=window.URL.createObjectURL(m);return r=new cn({url:h}),A6({resource:r,flipY:i,skipColorSpaceConversion:o,preferImageBitmap:!1})}).then(function(m){if(c(m))return m.blob=d,l||window.URL.revokeObjectURL(r.url),m}).catch(function(m){return c(r)&&window.URL.revokeObjectURL(r.url),m.blob=d,Promise.reject(m)})};function A6(t){let e=t.resource,n=t.flipY,i=t.skipColorSpaceConversion,o=t.preferImageBitmap,a=e.request;a.url=e.url,a.requestFunction=function(){let l=!1;!e.isDataUri&&!e.isBlobUri&&(l=e.isCrossOriginUrl);let r=kd();return cn._Implementations.createImage(a,l,r,n,i,o),r.promise};let s=xd.request(a);if(c(s))return s.catch(function(l){return a.state!==qi.FAILED?Promise.reject(l):e.retryOnError(l).then(function(r){return r?(a.state=qi.UNISSUED,a.deferred=void 0,A6({resource:e,flipY:n,skipColorSpaceConversion:i,preferImageBitmap:o})):Promise.reject(l)})})}cn.fetchImage=function(t){return new cn(t).fetchImage({flipY:t.flipY,skipColorSpaceConversion:t.skipColorSpaceConversion,preferBlob:t.preferBlob,preferImageBitmap:t.preferImageBitmap})};cn.prototype.fetchText=function(){return this.fetch({responseType:"text"})};cn.fetchText=function(t){return new cn(t).fetchText()};cn.prototype.fetchJson=function(){let t=this.fetch({responseType:"text",headers:{Accept:"application/json,*/*;q=0.01"}});if(c(t))return t.then(function(e){if(c(e))return JSON.parse(e)})};cn.fetchJson=function(t){return new cn(t).fetchJson()};cn.prototype.fetchXML=function(){return this.fetch({responseType:"document",overrideMimeType:"text/xml"})};cn.fetchXML=function(t){return new cn(t).fetchXML()};cn.prototype.fetchJsonp=function(t){t=f(t,"callback"),S6(this.request);let e;do e=`loadJsonp${k.nextRandomNumber().toString().substring(2,8)}`;while(c(window[e]));return xmt(this,t,e)};function xmt(t,e,n){let i={};i[e]=n,t.setQueryParameters(i);let o=t.request,a=t.url;o.url=a,o.requestFunction=function(){let l=kd();return window[n]=function(r){l.resolve(r);try{delete window[n]}catch{window[n]=void 0}},cn._Implementations.loadAndExecuteScript(a,n,l),l.promise};let s=xd.request(o);if(c(s))return s.catch(function(l){return o.state!==qi.FAILED?Promise.reject(l):t.retryOnError(l).then(function(r){return r?(o.state=qi.UNISSUED,o.deferred=void 0,xmt(t,e,n)):Promise.reject(l)})})}cn.fetchJsonp=function(t){return new cn(t).fetchJsonp(t.callbackParameterName)};cn.prototype._makeRequest=function(t){let e=this;S6(e.request);let n=e.request,i=e.url;n.url=i,n.requestFunction=function(){let a=t.responseType,s=ze(t.headers,e.headers),l=t.overrideMimeType,r=t.method,d=t.data,m=kd(),h=cn._Implementations.loadWithXhr(i,a,r,d,s,m,l);return c(h)&&c(h.abort)&&(n.cancelFunction=function(){h.abort()}),m.promise};let o=xd.request(n);if(c(o))return o.then(function(a){return n.cancelFunction=void 0,a}).catch(function(a){return n.cancelFunction=void 0,n.state!==qi.FAILED?Promise.reject(a):e.retryOnError(a).then(function(s){return s?(n.state=qi.UNISSUED,n.deferred=void 0,e.fetch(t)):Promise.reject(a)})})};function S6(t){if(t.state===qi.ISSUED||t.state===qi.ACTIVE)throw new Tt("The Resource is already being fetched.");t.state=qi.UNISSUED,t.deferred=void 0}var u9t=/^data:(.*?)(;base64)?,(.*)$/;function FH(t,e){let n=decodeURIComponent(e);return t?atob(n):n}function Qmt(t,e){let n=FH(t,e),i=new ArrayBuffer(n.length),o=new Uint8Array(i);for(let a=0;a{if(!l.ok){let r={};l.headers.forEach((d,m)=>{r[m]=d}),a.reject(new yZ(l.status,l,r));return}switch(e){case"text":a.resolve(l.text());break;case"json":a.resolve(l.json());break;default:a.resolve(new Uint8Array(await l.arrayBuffer()).buffer);break}}).catch(()=>{a.reject(new yZ)})}var b9t=typeof XMLHttpRequest>"u";cn._Implementations.loadWithXhr=function(t,e,n,i,o,a,s){let l=u9t.exec(t);if(l!==null){a.resolve(Z9t(l,e));return}if(b9t){R9t(t,e,n,i,o,a,s);return}let r=new XMLHttpRequest;if(eE.contains(t)&&(r.withCredentials=!0),r.open(n,t,!0),c(s)&&c(r.overrideMimeType)&&r.overrideMimeType(s),c(o))for(let m in o)o.hasOwnProperty(m)&&r.setRequestHeader(m,o[m]);c(e)&&(r.responseType=e);let d=!1;return typeof t=="string"&&(d=t.indexOf("file://")===0||typeof window<"u"&&window.location.origin==="file://"),r.onload=function(){if((r.status<200||r.status>=300)&&!(d&&r.status===0)){a.reject(new yZ(r.status,r.response,r.getAllResponseHeaders()));return}let m=r.response,h=r.responseType;if(n==="HEAD"||n==="OPTIONS"){let R=r.getAllResponseHeaders().trim().split(/[\r\n]+/),V={};R.forEach(function(F){let U=F.split(": "),G=U.shift();V[G]=U.join(": ")}),a.resolve(V);return}if(r.status===204)a.resolve(void 0);else if(c(m)&&(!c(e)||h===e))a.resolve(m);else if(e==="json"&&typeof m=="string")try{a.resolve(JSON.parse(m))}catch(u){a.reject(u)}else(h===""||h==="document")&&c(r.responseXML)&&r.responseXML.hasChildNodes()?a.resolve(r.responseXML):(h===""||h==="text")&&c(r.responseText)?a.resolve(r.responseText):a.reject(new Tt("Invalid XMLHttpRequest response type."))},r.onerror=function(m){a.reject(new yZ)},r.send(i),r};cn._Implementations.loadAndExecuteScript=function(t,e,n){return ZG(t,e).catch(function(i){n.reject(i)})};cn._DefaultImplementations={};cn._DefaultImplementations.createImage=cn._Implementations.createImage;cn._DefaultImplementations.loadWithXhr=cn._Implementations.loadWithXhr;cn._DefaultImplementations.loadAndExecuteScript=cn._Implementations.loadAndExecuteScript;cn.DEFAULT=Object.freeze(new cn({url:typeof document>"u"?"":document.location.href.split("?")[0]}));var te=cn;function sy(t){t=f(t,f.EMPTY_OBJECT),this._dates=void 0,this._samples=void 0,this._dateColumn=-1,this._xPoleWanderRadiansColumn=-1,this._yPoleWanderRadiansColumn=-1,this._ut1MinusUtcSecondsColumn=-1,this._xCelestialPoleOffsetRadiansColumn=-1,this._yCelestialPoleOffsetRadiansColumn=-1,this._taiMinusUtcSecondsColumn=-1,this._columnCount=0,this._lastIndex=-1,this._addNewLeapSeconds=f(t.addNewLeapSeconds,!0),c(t.data)?Xmt(this,t.data):Xmt(this,{columnNames:["dateIso8601","modifiedJulianDateUtc","xPoleWanderRadians","yPoleWanderRadians","ut1MinusUtcSeconds","lengthOfDayCorrectionSeconds","xCelestialPoleOffsetRadians","yCelestialPoleOffsetRadians","taiMinusUtcSeconds"],samples:[]})}sy.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=te.createIfNeeded(t),i;try{i=await n.fetchJson()}catch{throw new Tt(`An error occurred while retrieving the EOP data from the URL ${n.url}.`)}return new sy({addNewLeapSeconds:e.addNewLeapSeconds,data:i})};sy.NONE=Object.freeze({compute:function(t,e){return c(e)?(e.xPoleWander=0,e.yPoleWander=0,e.xPoleOffset=0,e.yPoleOffset=0,e.ut1MinusUtc=0):e=new lf(0,0,0,0,0),e}});sy.prototype.compute=function(t,e){if(!c(this._samples))return;if(c(e)||(e=new lf(0,0,0,0,0)),this._samples.length===0)return e.xPoleWander=0,e.yPoleWander=0,e.xPoleOffset=0,e.yPoleOffset=0,e.ut1MinusUtc=0,e;let n=this._dates,i=this._lastIndex,o=0,a=0;if(c(i)){let l=n[i],r=n[i+1],d=rt.lessThanOrEquals(l,t),m=!c(r),h=m||rt.greaterThanOrEquals(r,t);if(d&&h)return o=i,!m&&r.equals(t)&&++o,a=o+1,Lmt(this,n,this._samples,t,o,a,e),e}let s=Ja(n,t,rt.compare,this._dateColumn);return s>=0?(se.length-1)return s.xPoleWander=0,s.yPoleWander=0,s.xPoleOffset=0,s.yPoleOffset=0,s.ut1MinusUtc=0,s;let r=e[o],d=e[a];if(r.equals(d)||i.equals(r))return Jmt(t,n,o,l,s),s;if(i.equals(d))return Jmt(t,n,a,l,s),s;let m=rt.secondsDifference(i,r)/rt.secondsDifference(d,r),h=o*l,u=a*l,R=n[h+t._ut1MinusUtcSecondsColumn],V=n[u+t._ut1MinusUtcSecondsColumn],F=V-R;if(F>.5||F<-.5){let U=n[h+t._taiMinusUtcSecondsColumn],G=n[u+t._taiMinusUtcSecondsColumn];U!==G&&(d.equals(i)?R=V:V-=G-U)}return s.xPoleWander=ay(m,n[h+t._xPoleWanderRadiansColumn],n[u+t._xPoleWanderRadiansColumn]),s.yPoleWander=ay(m,n[h+t._yPoleWanderRadiansColumn],n[u+t._yPoleWanderRadiansColumn]),s.xPoleOffset=ay(m,n[h+t._xCelestialPoleOffsetRadiansColumn],n[u+t._xCelestialPoleOffsetRadiansColumn]),s.yPoleOffset=ay(m,n[h+t._yCelestialPoleOffsetRadiansColumn],n[u+t._yCelestialPoleOffsetRadiansColumn]),s.ut1MinusUtc=ay(m,R,V),s}var ly=sy;var r3e=b(W(),1);var $ve=b(W(),1);function Qe(t,e,n,i){this.x=f(t,0),this.y=f(e,0),this.z=f(n,0),this.w=f(i,0)}var ry=new p;Qe.fromAxisAngle=function(t,e,n){let i=e/2,o=Math.sin(i);ry=p.normalize(t,ry);let a=ry.x*o,s=ry.y*o,l=ry.z*o,r=Math.cos(i);return c(n)?(n.x=a,n.y=s,n.z=l,n.w=r,n):new Qe(a,s,l,r)};var f9t=[1,2,0],F9t=new Array(3);Qe.fromRotationMatrix=function(t,e){let n,i,o,a,s,l=t[ot.COLUMN0ROW0],r=t[ot.COLUMN1ROW1],d=t[ot.COLUMN2ROW2],m=l+r+d;if(m>0)n=Math.sqrt(m+1),s=.5*n,n=.5/n,i=(t[ot.COLUMN1ROW2]-t[ot.COLUMN2ROW1])*n,o=(t[ot.COLUMN2ROW0]-t[ot.COLUMN0ROW2])*n,a=(t[ot.COLUMN0ROW1]-t[ot.COLUMN1ROW0])*n;else{let h=f9t,u=0;r>l&&(u=1),d>l&&d>r&&(u=2);let R=h[u],V=h[R];n=Math.sqrt(t[ot.getElementIndex(u,u)]-t[ot.getElementIndex(R,R)]-t[ot.getElementIndex(V,V)]+1);let F=F9t;F[u]=.5*n,n=.5/n,s=(t[ot.getElementIndex(V,R)]-t[ot.getElementIndex(R,V)])*n,F[R]=(t[ot.getElementIndex(R,u)]+t[ot.getElementIndex(u,R)])*n,F[V]=(t[ot.getElementIndex(V,u)]+t[ot.getElementIndex(u,V)])*n,i=-F[0],o=-F[1],a=-F[2]}return c(e)?(e.x=i,e.y=o,e.z=a,e.w=s,e):new Qe(i,o,a,s)};var Mmt=new Qe,_mt=new Qe,T6=new Qe,Dmt=new Qe;Qe.fromHeadingPitchRoll=function(t,e){return Dmt=Qe.fromAxisAngle(p.UNIT_X,t.roll,Mmt),T6=Qe.fromAxisAngle(p.UNIT_Y,-t.pitch,e),e=Qe.multiply(T6,Dmt,T6),_mt=Qe.fromAxisAngle(p.UNIT_Z,-t.heading,Mmt),Qe.multiply(_mt,e,e)};var GH=new p,g6=new p,KV=new Qe,Omt=new Qe,AH=new Qe;Qe.packedLength=4;Qe.pack=function(t,e,n){return n=f(n,0),e[n++]=t.x,e[n++]=t.y,e[n++]=t.z,e[n]=t.w,e};Qe.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Qe),n.x=t[e],n.y=t[e+1],n.z=t[e+2],n.w=t[e+3],n};Qe.packedInterpolationLength=3;Qe.convertPackedArrayForInterpolation=function(t,e,n,i){Qe.unpack(t,n*4,AH),Qe.conjugate(AH,AH);for(let o=0,a=n-e+1;o=0?a=1:(a=-1,o=-o);let s=o-1,l=1-n,r=n*n,d=l*l;for(let R=7;R>=0;--R)Ub[R]=(SH[R]*r-TH[R])*s,Gb[R]=(SH[R]*d-TH[R])*s;let m=a*n*(1+Ub[0]*(1+Ub[1]*(1+Ub[2]*(1+Ub[3]*(1+Ub[4]*(1+Ub[5]*(1+Ub[6]*(1+Ub[7])))))))),h=l*(1+Gb[0]*(1+Gb[1]*(1+Gb[2]*(1+Gb[3]*(1+Gb[4]*(1+Gb[5]*(1+Gb[6]*(1+Gb[7])))))))),u=Qe.multiplyByScalar(t,h,A9t);return Qe.multiplyByScalar(e,m,i),Qe.add(u,i,i)};Qe.fastSquad=function(t,e,n,i,o,a){let s=Qe.fastSlerp(t,e,o,dy),l=Qe.fastSlerp(n,i,o,iE);return Qe.fastSlerp(s,l,2*o*(1-o),a)};Qe.equals=function(t,e){return t===e||c(t)&&c(e)&&t.x===e.x&&t.y===e.y&&t.z===e.z&&t.w===e.w};Qe.equalsEpsilon=function(t,e,n){return n=f(n,0),t===e||c(t)&&c(e)&&Math.abs(t.x-e.x)<=n&&Math.abs(t.y-e.y)<=n&&Math.abs(t.z-e.z)<=n&&Math.abs(t.w-e.w)<=n};Qe.ZERO=Object.freeze(new Qe(0,0,0,0));Qe.IDENTITY=Object.freeze(new Qe(0,0,0,1));Qe.prototype.clone=function(t){return Qe.clone(this,t)};Qe.prototype.equals=function(t){return Qe.equals(this,t)};Qe.prototype.equalsEpsilon=function(t,e){return Qe.equalsEpsilon(this,t,e)};Qe.prototype.toString=function(){return`(${this.x}, ${this.y}, ${this.z}, ${this.w})`};var wt=Qe;function Xd(t,e,n){this.heading=f(t,0),this.pitch=f(e,0),this.roll=f(n,0)}Xd.fromQuaternion=function(t,e,n){c(e)||(e=new Xd);let i,o;if(c(n)){if(typeof n=="function")i=n();else if(n instanceof L)i=n;else throw new Ut("referenceFrame must be a Matrix4 or a function returning a Matrix4");let m=L.inverse(i,new L),h=L.getRotation(m,new ot),u=wt.fromRotationMatrix(h,new wt);o=wt.multiply(u,t,new wt)}else o=t;let a=2*(o.w*o.y-o.z*o.x),s=1-2*(o.x*o.x+o.y*o.y),l=2*(o.w*o.x+o.y*o.z),r=1-2*(o.y*o.y+o.z*o.z),d=2*(o.w*o.z+o.x*o.y);return e.heading=-Math.atan2(d,r),e.roll=Math.atan2(l,s),e.pitch=-k.asinClamped(a),e};Xd.fromDegrees=function(t,e,n,i){return c(i)||(i=new Xd),i.heading=t*k.RADIANS_PER_DEGREE,i.pitch=e*k.RADIANS_PER_DEGREE,i.roll=n*k.RADIANS_PER_DEGREE,i};Xd.clone=function(t,e){if(c(t))return c(e)?(e.heading=t.heading,e.pitch=t.pitch,e.roll=t.roll,e):new Xd(t.heading,t.pitch,t.roll)};Xd.equals=function(t,e){return t===e||c(t)&&c(e)&&t.heading===e.heading&&t.pitch===e.pitch&&t.roll===e.roll};Xd.equalsEpsilon=function(t,e,n,i){return t===e||c(t)&&c(e)&&k.equalsEpsilon(t.heading,e.heading,n,i)&&k.equalsEpsilon(t.pitch,e.pitch,n,i)&&k.equalsEpsilon(t.roll,e.roll,n,i)};Xd.prototype.clone=function(t){return Xd.clone(this,t)};Xd.prototype.equals=function(t){return Xd.equals(this,t)};Xd.prototype.equalsEpsilon=function(t,e,n){return Xd.equalsEpsilon(this,t,e,n)};Xd.prototype.toString=function(){return`(${this.heading}, ${this.pitch}, ${this.roll})`};var Jr=Xd;var C3e=b(W(),1);var Z3e=b(W(),1);var c3e=b(W(),1),N6={},gH=[],Pmt={},EH={};var y6={};var vmt={};var Kmt=/((?:.*\/)|^)Cesium\.js(?:\?|\#|$)/;function S9t(){let t=document.getElementsByTagName("script");for(let e=0,n=t.length;e"u"?t:(c(CH)||(CH=document.createElement("a")),CH.href=t,CH.href)}var fG;function jmt(){if(c(fG))return fG;let t;return typeof CESIUM_BASE_URL<"u"?t=CESIUM_BASE_URL:c(vmt?.url)?t=IZ(".",vmt.url):typeof define=="object"&&c(define.amd)&&!define.amd.toUrlUndefined&&c(Og.toUrl)?t=IZ("..",FG("Core/buildModuleUrl.js")):t=S9t(),fG=new te({url:zmt(t)}),fG.appendForwardSlash(),fG}function T9t(t){return zmt(Og.toUrl(`../${t}`))}function qmt(t){return jmt().getDerivedResource({url:t}).url}var IH;function FG(t){return N6[t]?N6[t]:(c(IH)||(typeof define=="object"&&c(define.amd)&&!define.amd.toUrlUndefined&&c(Og.toUrl)?IH=T9t:IH=qmt),IH(t))}FG._cesiumScriptRegex=Kmt;FG._buildModuleUrlFromBaseUrl=qmt;FG._clearBaseResource=function(){fG=void 0};FG.setBaseUrl=function(t){fG=te.DEFAULT.getDerivedResource({url:t})};FG.getCesiumBaseUrl=jmt;var Dn=FG;var W3e=b(W(),1);function g9t(t,e,n){this.x=t,this.y=e,this.s=n}var UG=g9t;function k6(t){t=f(t,f.EMPTY_OBJECT),this._xysFileUrlTemplate=te.createIfNeeded(t.xysFileUrlTemplate),this._interpolationOrder=f(t.interpolationOrder,9),this._sampleZeroJulianEphemerisDate=f(t.sampleZeroJulianEphemerisDate,24423965e-1),this._sampleZeroDateTT=new rt(this._sampleZeroJulianEphemerisDate,0,Di.TAI),this._stepSizeDays=f(t.stepSizeDays,1),this._samplesPerXysFile=f(t.samplesPerXysFile,1e3),this._totalSamples=f(t.totalSamples,27426),this._samples=Pmt||new Array(this._totalSamples*3),this._chunkDownloadsInProgress=[];let e=this._interpolationOrder,n=this._denominators=new Array(e+1),i=this._xTable=new Array(e+1),o=Math.pow(this._stepSizeDays,e);for(let a=0;a<=e;++a){n[a]=o,i[a]=a*this._stepSizeDays;for(let s=0;s<=e;++s)s!==a&&(n[a]*=a-s);n[a]=1/n[a]}this._work=new Array(e+1),this._coef=new Array(e+1)}var E9t=new rt(0,0,Di.TAI);function B6(t,e,n){let i=E9t;return i.dayNumber=e,i.secondsOfDay=n,rt.daysDifference(i,t._sampleZeroDateTT)}k6.prototype.preload=function(t,e,n,i){let o=B6(this,t,e),a=B6(this,n,i),s=o/this._stepSizeDays-this._interpolationOrder/2|0;s<0&&(s=0);let l=a/this._stepSizeDays-this._interpolationOrder/2|0+this._interpolationOrder;l>=this._totalSamples&&(l=this._totalSamples-1);let r=s/this._samplesPerXysFile|0,d=l/this._samplesPerXysFile|0,m=[];for(let h=r;h<=d;++h)m.push(Q6(this,h));return Promise.all(m)};k6.prototype.computeXysRadians=function(t,e,n){let i=B6(this,t,e);if(i<0)return;let o=i/this._stepSizeDays|0;if(o>=this._totalSamples)return;let a=this._interpolationOrder,s=o-(a/2|0);s<0&&(s=0);let l=s+a;l>=this._totalSamples&&(l=this._totalSamples-1,s=l-a,s<0&&(s=0));let r=!1,d=this._samples;if(c(d[s*3])||(Q6(this,s/this._samplesPerXysFile|0),r=!0),c(d[l*3])||(Q6(this,l/this._samplesPerXysFile|0),r=!0),r)return;c(n)?(n.x=0,n.y=0,n.s=0):n=new UG(0,0,0);let m=i-s*this._stepSizeDays,h=this._work,u=this._denominators,R=this._coef,V=this._xTable,F,U;for(F=0;F<=a;++F)h[F]=m-V[F];for(F=0;F<=a;++F){for(R[F]=1,U=0;U<=a;++U)U!==F&&(R[F]*=h[U]);R[F]*=u[F];let G=(s+F)*3;n.x+=R[F]*d[G++],n.y+=R[F]*d[G++],n.s+=R[F]*d[G]}return n};function Q6(t,e){if(t._chunkDownloadsInProgress[e])return t._chunkDownloadsInProgress[e];let n,i=t._xysFileUrlTemplate;c(i)?n=i.getDerivedResource({templateValues:{0:e}}):n=new te({url:Dn(`Assets/IAU2006_XYS/IAU2006_XYS_${e}.json`)});let o=n.fetchJson().then(function(a){t._chunkDownloadsInProgress[e]=!1;let s=t._samples,l=a.samples,r=e*t._samplesPerXysFile*3;for(let d=0,m=l.length;d=43200?o=(a+.5)/xi.DAYS_PER_JULIAN_CENTURY:o=(a-.5)/xi.DAYS_PER_JULIAN_CENTURY;let l=(J9t+o*(L9t+o*(M9t+o*_9t)))*H9t%k.TWO_PI,r=O9t+D9t*(n-24515455e-1),d=(i+xi.SECONDS_PER_DAY*.5)%xi.SECONDS_PER_DAY,m=l+r*d,h=Math.cos(m),u=Math.sin(m);return c(e)?(e[0]=h,e[1]=-u,e[2]=0,e[3]=u,e[4]=h,e[5]=0,e[6]=0,e[7]=0,e[8]=1,e):new ot(h,u,0,-u,h,0,0,0,1)};Ci.iau2006XysData=new cy;Ci.earthOrientationParameters=ly.NONE;var M6=32.184,w9t=2451545;Ci.preloadIcrfFixed=function(t){let e=t.start.dayNumber,n=t.start.secondsOfDay+M6,i=t.stop.dayNumber,o=t.stop.secondsOfDay+M6;return Ci.iau2006XysData.preload(e,n,i,o)};Ci.computeIcrfToFixedMatrix=function(t,e){c(e)||(e=new ot);let n=Ci.computeFixedToIcrfMatrix(t,e);if(c(n))return ot.transpose(n,e)};var P9t=new UG(0,0,0),v9t=new lf(0,0,0,0,0,0),X6=new ot,J6=new ot;Ci.computeFixedToIcrfMatrix=function(t,e){c(e)||(e=new ot);let n=Ci.earthOrientationParameters.compute(t,v9t);if(!c(n))return;let i=t.dayNumber,o=t.secondsOfDay+M6,a=Ci.iau2006XysData.computeXysRadians(i,o,P9t);if(!c(a))return;let s=a.x+n.xPoleOffset,l=a.y+n.yPoleOffset,r=1/(1+Math.sqrt(1-s*s-l*l)),d=X6;d[0]=1-r*s*s,d[3]=-r*s*l,d[6]=s,d[1]=-r*s*l,d[4]=1-r*l*l,d[7]=l,d[2]=-s,d[5]=-l,d[8]=1-r*(s*s+l*l);let m=ot.fromRotationZ(-a.s,J6),h=ot.multiply(d,m,X6),u=t.dayNumber,R=t.secondsOfDay-rt.computeTaiMinusUtc(t)+n.ut1MinusUtc,V=u-2451545,F=R/xi.SECONDS_PER_DAY,U=.779057273264+F+.00273781191135448*(V+F);U=U%1*k.TWO_PI;let G=ot.fromRotationZ(U,J6),A=ot.multiply(h,G,X6),S=Math.cos(n.xPoleWander),g=Math.cos(n.yPoleWander),C=Math.sin(n.xPoleWander),y=Math.sin(n.yPoleWander),Y=i-w9t+o/xi.SECONDS_PER_DAY;Y/=36525;let Q=-47e-6*Y*k.RADIANS_PER_DEGREE/3600,J=Math.cos(Q),M=Math.sin(Q),Z=J6;return Z[0]=S*J,Z[1]=S*M,Z[2]=C,Z[3]=-g*M+y*C*J,Z[4]=g*J+y*C*M,Z[5]=-y*S,Z[6]=-y*M-g*C*J,Z[7]=y*J-g*C*M,Z[8]=g*S,ot.multiply(A,Z,e)};var K9t=new bt;Ci.pointToWindowCoordinates=function(t,e,n,i){return i=Ci.pointToGLWindowCoordinates(t,e,n,i),i.y=2*e[5]-i.y,i};Ci.pointToGLWindowCoordinates=function(t,e,n,i){c(i)||(i=new K);let o=K9t;return L.multiplyByVector(t,bt.fromElements(n.x,n.y,n.z,1,o),o),bt.multiplyByScalar(o,1/o.w,o),L.multiplyByVector(e,o,o),K.fromCartesian4(o,i)};var z9t=new p,j9t=new p,q9t=new p;Ci.rotationMatrixFromPositionVelocity=function(t,e,n,i){let o=f(n,mt.WGS84).geodeticSurfaceNormal(t,z9t),a=p.cross(e,o,j9t);p.equalsEpsilon(a,p.ZERO,k.EPSILON6)&&(a=p.clone(p.UNIT_X,a));let s=p.cross(a,e,q9t);return p.normalize(s,s),p.cross(e,s,a),p.negate(a,a),p.normalize(a,a),c(i)||(i=new ot),i[0]=e.x,i[1]=e.y,i[2]=e.z,i[3]=a.x,i[4]=a.y,i[5]=a.z,i[6]=s.x,i[7]=s.y,i[8]=s.z,i};var nht=new L(0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1),iht=new gt,_6=new p,$9t=new p,t5t=new ot,D6=new L,oht=new L;Ci.basisTo2D=function(t,e,n){let i=L.getTranslation(e,$9t),o=t.ellipsoid,a;if(p.equals(i,p.ZERO))a=p.clone(p.ZERO,_6);else{let m=o.cartesianToCartographic(i,iht);a=t.project(m,_6),p.fromElements(a.z,a.x,a.y,a)}let s=Ci.eastNorthUpToFixedFrame(i,o,D6),l=L.inverseTransformation(s,oht),r=L.getMatrix3(e,t5t),d=L.multiplyByMatrix3(l,r,n);return L.multiply(nht,d,n),L.setTranslation(n,a,n),n};Ci.wgs84To2DModelMatrix=function(t,e,n){let i=t.ellipsoid,o=Ci.eastNorthUpToFixedFrame(e,i,D6),a=L.inverseTransformation(o,oht),s=i.cartesianToCartographic(e,iht),l=t.project(s,_6);p.fromElements(l.z,l.x,l.y,l);let r=L.fromTranslation(l,D6);return L.multiply(nht,a,n),L.multiply(r,n,n),n};var e5t=new p,n5t=new p,i5t=new p,o5t=new p,a5t=new p,s5t=new p,l5t=new p,r5t=new p,L6=new rt,d5t=new ot,c5t=new ot,m5t=new ot;Ci.vvlhToFixed=function(t,e,n){let i=t.getValue(e,e5t);rt.addSeconds(e,.01,L6);let o=t.getValue(L6,n5t),a=mt.WGS84,s=a.maximumRadius+1e5;if(c(n)||(n=new L),p.magnitude(i)<=s){let u=p.subtract(o,i,new p),R;if(p.magnitude(u)===0){let U=Ci.eastNorthUpToFixedFrame(i,a);R=new p(U[0],U[1],U[2])}else R=p.normalize(u,new p);let V=a.geodeticSurfaceNormal(i,new p),F=p.cross(V,R,new p);return n[0]=R.x,n[1]=R.y,n[2]=R.z,n[3]=0,n[4]=F.x,n[5]=F.y,n[6]=F.z,n[7]=0,n[8]=V.x,n[9]=V.y,n[10]=V.z,n[11]=0,n[12]=i.x,n[13]=i.y,n[14]=i.z,n[15]=1,n}let l=Ci.computeFixedToIcrfMatrix(e,d5t);if(!l)return new L;let r=Ci.computeFixedToIcrfMatrix(L6,c5t),d=ot.transpose(l,m5t),m=ot.multiplyByVector(l,i,i5t),h=ot.multiplyByVector(r,o,o5t);if(!p.equalsEpsilon(m,h,k.EPSILON14)){let u=p.subtract(h,m,a5t),R=s5t;try{p.negate(p.normalize(m,R),R)}catch{console.log(m,R)}let V=p.cross(u,R,l5t);p.negate(V,V);let F=p.cross(V,R,r5t);try{ot.multiplyByVector(d,F,F),ot.multiplyByVector(d,V,V),ot.multiplyByVector(d,R,R),p.normalize(F,F),p.normalize(V,V),p.normalize(R,R),n[0]=F.x,n[1]=F.y,n[2]=F.z,n[3]=0,n[4]=V.x,n[5]=V.y,n[6]=V.z,n[7]=0,n[8]=R.x,n[9]=R.y,n[10]=R.z,n[11]=0,n[12]=i.x,n[13]=i.y,n[14]=i.z,n[15]=1}catch(U){return console.log(U,F,V,R,u,i,o,t),new Array(16).fill(0)}}return L.multiply(n,new L(1,0,0,0,0,-1,0,0,0,0,-1,0,0,0,0,1),n),n};Ci.reverseHeadingQuaternion=function(t){if(!c(t))throw new Ut("orientation is required");let e=new Jr;Jr.fromQuaternion(t,e),e.heading=-e.heading,e.roll=-e.roll;let n=new wt;return wt.fromHeadingPitchRoll(e,n),n};var pf=new L(0,0,1,0,0,1,0,0,-1,0,0,0,0,0,0,1);Ci.getPositionInVVLH=function(t,e,n,i,o=ri.FIXED){let a=e.position.getValueInReferenceFrame(n,o.FIXED),s=t.position.getValueInReferenceFrame(i,o.FIXED),l;try{l=L.inverse(Ci.vvlhToFixed(t.position,n),new L)}catch{l=new L}let r=L.multiplyByPoint(l,a,new p),d=L.getRotation(Ci.vvlhToFixed(t.position,i),new ot),m=ot.multiplyByVector(d,r,new p),h=p.add(s,m,new p);if(o===ri.INERTIAL){let u=Ci.computeFixedToIcrfMatrix(i);u&&(h=ot.multiplyByVector(u,h,new p))}return h};var eht=Ci.localFrameToFixedFrameGenerator("north","west");Ci.getTransformToFixedFrame=function(t,e,n){let i,o={[ri.FIXED]:()=>L.IDENTITY,[ri.INERTIAL]:()=>{if(!c(e))throw new Ut("Conversion from INERTIAL to FIXED requires a time.");return Ci.computeIcrfToFixedMatrix(e)},[ri.TEME]:()=>{throw new Ut("Conversion from TEME to FIXED is not implemented.")},[ri.VVLH]:()=>{if(!c(e)||!c(n))throw new Ut("Conversion from VVLH to FIXED requires both time and position.");let a=Ci.vvlhToFixed(n,e),s=L.fromScale(new p(1,-1,-1));return L.multiply(a,s,new L)},[ri.NED]:()=>{if(!c(e)||!c(n))throw new Ut("Conversion from NED to FIXED requires both time and position.");let a=eht(n.getValue(e)),s=L.fromScale(new p(1,-1,-1));return L.multiply(a,s,new L)},[ri.NEU]:()=>{if(!c(e)||!c(n))throw new Ut("Conversion from NEU to FIXED requires both time and position.");let a=eht(n.getValue(e)),s=L.fromScale(new p(1,-1,1));return L.multiply(a,s,new L)},[ri.RIC]:()=>{if(!c(e)||!c(n))throw new Ut("Conversion from RIC to FIXED requires both time and position.");let a=Ci.vvlhToFixed(n,e),s=L.fromArray([0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1]);return L.multiply(a,s,new L)}};return o.hasOwnProperty(t)?i=o[t]:i=Ci.eastNorthUpToFixedFrame,i};var Pe=Ci;function fi(t,e,n,i){this.west=f(t,0),this.south=f(e,0),this.east=f(n,0),this.north=f(i,0)}Object.defineProperties(fi.prototype,{width:{get:function(){return fi.computeWidth(this)}},height:{get:function(){return fi.computeHeight(this)}}});fi.packedLength=4;fi.pack=function(t,e,n){return n=f(n,0),e[n++]=t.west,e[n++]=t.south,e[n++]=t.east,e[n]=t.north,e};fi.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new fi),n.west=t[e++],n.south=t[e++],n.east=t[e++],n.north=t[e],n};fi.computeWidth=function(t){let e=t.east,n=t.west;return e=0?m.longitude:m.longitude+k.TWO_PI;o=Math.min(o,h),a=Math.max(a,h)}return i-n>a-o&&(n=o,i=a,i>k.PI&&(i=i-k.TWO_PI),n>k.PI&&(n=n-k.TWO_PI)),c(e)?(e.west=n,e.south=s,e.east=i,e.north=l,e):new fi(n,s,i,l)};fi.fromCartesianArray=function(t,e,n){e=f(e,mt.WGS84);let i=Number.MAX_VALUE,o=-Number.MAX_VALUE,a=Number.MAX_VALUE,s=-Number.MAX_VALUE,l=Number.MAX_VALUE,r=-Number.MAX_VALUE;for(let d=0,m=t.length;d=0?h.longitude:h.longitude+k.TWO_PI;a=Math.min(a,u),s=Math.max(s,u)}return o-i>s-a&&(i=a,o=s,o>k.PI&&(o=o-k.TWO_PI),i>k.PI&&(i=i-k.TWO_PI)),c(n)?(n.west=i,n.south=l,n.east=o,n.north=r,n):new fi(i,l,o,r)};var h5t=new p,p5t=new p,V5t=new p,u5t=new p,Z5t=new p,O6=new Array(5);for(let t=0;t0?i+=k.TWO_PI:a0&&(a+=k.TWO_PI),i=m))return c(n)?(n.west=l,n.south=d,n.east=r,n.north=m,n):new fi(l,d,r,m)};fi.simpleIntersection=function(t,e,n){let i=Math.max(t.west,e.west),o=Math.max(t.south,e.south),a=Math.min(t.east,e.east),s=Math.min(t.north,e.north);if(!(o>=s||i>=a))return c(n)?(n.west=i,n.south=o,n.east=a,n.north=s,n):new fi(i,o,a,s)};fi.union=function(t,e,n){c(n)||(n=new fi);let i=t.east,o=t.west,a=e.east,s=e.west;i0?i+=k.TWO_PI:a0&&(a+=k.TWO_PI),io||k.equalsEpsilon(n,o,k.EPSILON14))&&(n=t.south&&i<=t.north};var R5t=new gt;fi.subsample=function(t,e,n,i){e=f(e,mt.WGS84),n=f(n,0),c(i)||(i=[]);let o=0,a=t.north,s=t.south,l=t.east,r=t.west,d=R5t;d.height=n,d.longitude=r,d.latitude=a,i[o]=e.cartographicToCartesian(d,i[o]),o++,d.longitude=l,i[o]=e.cartographicToCartesian(d,i[o]),o++,d.latitude=s,i[o]=e.cartographicToCartesian(d,i[o]),o++,d.longitude=r,i[o]=e.cartographicToCartesian(d,i[o]),o++,a<0?d.latitude=a:s>0?d.latitude=s:d.latitude=0;for(let m=1;m<8;++m)d.longitude=-Math.PI+m*k.PI_OVER_TWO,fi.contains(t,d)&&(i[o]=e.cartographicToCartesian(d,i[o]),o++);return d.latitude===0&&(d.longitude=r,i[o]=e.cartographicToCartesian(d,i[o]),o++,d.longitude=l,i[o]=e.cartographicToCartesian(d,i[o]),o++),i.length=o,i};fi.subsection=function(t,e,n,i,o,a){if(c(a)||(a=new fi),t.west<=t.east){let l=t.east-t.west;a.west=t.west+e*l,a.east=t.west+i*l}else{let l=k.TWO_PI+t.east-t.west;a.west=k.negativePiToPi(t.west+e*l),a.east=k.negativePiToPi(t.west+i*l)}let s=t.north-t.south;return a.south=t.south+n*s,a.north=t.south+o*s,e===1&&(a.west=t.east),i===1&&(a.east=t.east),n===1&&(a.south=t.north),o===1&&(a.north=t.north),a};fi.MAX_VALUE=Object.freeze(new fi(-Math.PI,-k.PI_OVER_TWO,Math.PI,k.PI_OVER_TWO));var Gt=fi;function tl(t,e,n,i){this.x=f(t,0),this.y=f(e,0),this.width=f(n,0),this.height=f(i,0)}tl.packedLength=4;tl.pack=function(t,e,n){return n=f(n,0),e[n++]=t.x,e[n++]=t.y,e[n++]=t.width,e[n]=t.height,e};tl.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new tl),n.x=t[e++],n.y=t[e++],n.width=t[e++],n.height=t[e],n};tl.fromPoints=function(t,e){if(c(e)||(e=new tl),!c(t)||t.length===0)return e.x=0,e.y=0,e.width=0,e.height=0,e;let n=t.length,i=t[0].x,o=t[0].y,a=t[0].x,s=t[0].y;for(let l=1;ln.width?n.width=i:i<0&&(n.width-=i,n.x=e.x),o>n.height?n.height=o:o<0&&(n.height-=o,n.y=e.y),n};tl.intersect=function(t,e){let n=t.x,i=t.y,o=e.x,a=e.y;return n>o+e.width||n+t.widtha+e.height?yn.OUTSIDE:yn.INTERSECTING};tl.equals=function(t,e){return t===e||c(t)&&c(e)&&t.x===e.x&&t.y===e.y&&t.width===e.width&&t.height===e.height};tl.prototype.clone=function(t){return tl.clone(this,t)};tl.prototype.intersect=function(t){return tl.intersect(this,t)};tl.prototype.equals=function(t){return tl.equals(this,t)};var Fe=tl;var FKe=b(W(),1);var dd={POINTS:pt.POINTS,LINES:pt.LINES,LINE_LOOP:pt.LINE_LOOP,LINE_STRIP:pt.LINE_STRIP,TRIANGLES:pt.TRIANGLES,TRIANGLE_STRIP:pt.TRIANGLE_STRIP,TRIANGLE_FAN:pt.TRIANGLE_FAN};dd.isLines=function(t){return t===dd.LINES||t===dd.LINE_LOOP||t===dd.LINE_STRIP};dd.isTriangles=function(t){return t===dd.TRIANGLES||t===dd.TRIANGLE_STRIP||t===dd.TRIANGLE_FAN};dd.validate=function(t){return t===dd.POINTS||t===dd.LINES||t===dd.LINE_LOOP||t===dd.LINE_STRIP||t===dd.TRIANGLES||t===dd.TRIANGLE_STRIP||t===dd.TRIANGLE_FAN};var le=Object.freeze(dd);var GKe=b(W(),1),GG=`in vec4 position; in vec2 textureCoordinates; out vec2 v_textureCoordinates; @@ -115,14 +115,14 @@ void main() gl_Position = position; v_textureCoordinates = textureCoordinates; } -`;var E3e=R(W(),1);var Os={CULL:1,OCCLUDE:2,EXECUTE_IN_CLOSEST_FRUSTUM:4,DEBUG_SHOW_BOUNDING_VOLUME:8,CAST_SHADOWS:16,RECEIVE_SHADOWS:32,PICK_ONLY:64,DEPTH_FOR_TRANSLUCENT_CLASSIFICATION:128};function my(t){t=f(t,f.EMPTY_OBJECT),this._boundingVolume=t.boundingVolume,this._orientedBoundingBox=t.orientedBoundingBox,this._modelMatrix=t.modelMatrix,this._primitiveType=f(t.primitiveType,le.TRIANGLES),this._vertexArray=t.vertexArray,this._count=t.count,this._offset=f(t.offset,0),this._instanceCount=f(t.instanceCount,0),this._shaderProgram=t.shaderProgram,this._uniformMap=t.uniformMap,this._renderState=t.renderState,this._framebuffer=t.framebuffer,this._pass=t.pass,this._owner=t.owner,this._debugOverlappingFrustums=0,this._pickId=t.pickId,this._flags=0,this.cull=f(t.cull,!0),this.occlude=f(t.occlude,!0),this.executeInClosestFrustum=f(t.executeInClosestFrustum,!1),this.debugShowBoundingVolume=f(t.debugShowBoundingVolume,!1),this.castShadows=f(t.castShadows,!1),this.receiveShadows=f(t.receiveShadows,!1),this.pickOnly=f(t.pickOnly,!1),this.depthForTranslucentClassification=f(t.depthForTranslucentClassification,!1),this.dirty=!0,this.lastDirtyTime=0,this.derivedCommands={}}function Jd(t,e){return(t._flags&e)===e}function uf(t,e,n){n?t._flags|=e:t._flags&=~e}Object.defineProperties(my.prototype,{boundingVolume:{get:function(){return this._boundingVolume},set:function(t){this._boundingVolume!==t&&(this._boundingVolume=t,this.dirty=!0)}},orientedBoundingBox:{get:function(){return this._orientedBoundingBox},set:function(t){this._orientedBoundingBox!==t&&(this._orientedBoundingBox=t,this.dirty=!0)}},cull:{get:function(){return Jd(this,Os.CULL)},set:function(t){Jd(this,Os.CULL)!==t&&(uf(this,Os.CULL,t),this.dirty=!0)}},occlude:{get:function(){return Jd(this,Os.OCCLUDE)},set:function(t){Jd(this,Os.OCCLUDE)!==t&&(uf(this,Os.OCCLUDE,t),this.dirty=!0)}},modelMatrix:{get:function(){return this._modelMatrix},set:function(t){this._modelMatrix!==t&&(this._modelMatrix=t,this.dirty=!0)}},primitiveType:{get:function(){return this._primitiveType},set:function(t){this._primitiveType!==t&&(this._primitiveType=t,this.dirty=!0)}},vertexArray:{get:function(){return this._vertexArray},set:function(t){this._vertexArray!==t&&(this._vertexArray=t,this.dirty=!0)}},count:{get:function(){return this._count},set:function(t){this._count!==t&&(this._count=t,this.dirty=!0)}},offset:{get:function(){return this._offset},set:function(t){this._offset!==t&&(this._offset=t,this.dirty=!0)}},instanceCount:{get:function(){return this._instanceCount},set:function(t){this._instanceCount!==t&&(this._instanceCount=t,this.dirty=!0)}},shaderProgram:{get:function(){return this._shaderProgram},set:function(t){this._shaderProgram!==t&&(this._shaderProgram=t,this.dirty=!0)}},castShadows:{get:function(){return Jd(this,Os.CAST_SHADOWS)},set:function(t){Jd(this,Os.CAST_SHADOWS)!==t&&(uf(this,Os.CAST_SHADOWS,t),this.dirty=!0)}},receiveShadows:{get:function(){return Jd(this,Os.RECEIVE_SHADOWS)},set:function(t){Jd(this,Os.RECEIVE_SHADOWS)!==t&&(uf(this,Os.RECEIVE_SHADOWS,t),this.dirty=!0)}},uniformMap:{get:function(){return this._uniformMap},set:function(t){this._uniformMap!==t&&(this._uniformMap=t,this.dirty=!0)}},renderState:{get:function(){return this._renderState},set:function(t){this._renderState!==t&&(this._renderState=t,this.dirty=!0)}},framebuffer:{get:function(){return this._framebuffer},set:function(t){this._framebuffer!==t&&(this._framebuffer=t,this.dirty=!0)}},pass:{get:function(){return this._pass},set:function(t){this._pass!==t&&(this._pass=t,this.dirty=!0)}},executeInClosestFrustum:{get:function(){return Jd(this,Os.EXECUTE_IN_CLOSEST_FRUSTUM)},set:function(t){Jd(this,Os.EXECUTE_IN_CLOSEST_FRUSTUM)!==t&&(uf(this,Os.EXECUTE_IN_CLOSEST_FRUSTUM,t),this.dirty=!0)}},owner:{get:function(){return this._owner},set:function(t){this._owner!==t&&(this._owner=t,this.dirty=!0)}},debugShowBoundingVolume:{get:function(){return Jd(this,Os.DEBUG_SHOW_BOUNDING_VOLUME)},set:function(t){Jd(this,Os.DEBUG_SHOW_BOUNDING_VOLUME)!==t&&(uf(this,Os.DEBUG_SHOW_BOUNDING_VOLUME,t),this.dirty=!0)}},debugOverlappingFrustums:{get:function(){return this._debugOverlappingFrustums},set:function(t){this._debugOverlappingFrustums!==t&&(this._debugOverlappingFrustums=t,this.dirty=!0)}},pickId:{get:function(){return this._pickId},set:function(t){this._pickId!==t&&(this._pickId=t,this.dirty=!0)}},pickOnly:{get:function(){return Jd(this,Os.PICK_ONLY)},set:function(t){Jd(this,Os.PICK_ONLY)!==t&&(uf(this,Os.PICK_ONLY,t),this.dirty=!0)}},depthForTranslucentClassification:{get:function(){return Jd(this,Os.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION)},set:function(t){Jd(this,Os.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION)!==t&&(uf(this,Os.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION,t),this.dirty=!0)}}});my.shallowClone=function(t,e){if(c(t))return c(e)||(e=new my),e._boundingVolume=t._boundingVolume,e._orientedBoundingBox=t._orientedBoundingBox,e._modelMatrix=t._modelMatrix,e._primitiveType=t._primitiveType,e._vertexArray=t._vertexArray,e._count=t._count,e._offset=t._offset,e._instanceCount=t._instanceCount,e._shaderProgram=t._shaderProgram,e._uniformMap=t._uniformMap,e._renderState=t._renderState,e._framebuffer=t._framebuffer,e._pass=t._pass,e._owner=t._owner,e._debugOverlappingFrustums=t._debugOverlappingFrustums,e._pickId=t._pickId,e._flags=t._flags,e.dirty=!0,e.lastDirtyTime=0,e};my.prototype.execute=function(t,e){t.draw(this,e)};var Ee=my;var D3e=R(W(),1);var k3e=R(W(),1);var N3e=R(W(),1);var Bo={UNSIGNED_BYTE:pt.UNSIGNED_BYTE,UNSIGNED_SHORT:pt.UNSIGNED_SHORT,UNSIGNED_INT:pt.UNSIGNED_INT,FLOAT:pt.FLOAT,HALF_FLOAT:pt.HALF_FLOAT_OES,UNSIGNED_INT_24_8:pt.UNSIGNED_INT_24_8,UNSIGNED_SHORT_4_4_4_4:pt.UNSIGNED_SHORT_4_4_4_4,UNSIGNED_SHORT_5_5_5_1:pt.UNSIGNED_SHORT_5_5_5_1,UNSIGNED_SHORT_5_6_5:pt.UNSIGNED_SHORT_5_6_5};Bo.toWebGLConstant=function(t,e){switch(t){case Bo.UNSIGNED_BYTE:return pt.UNSIGNED_BYTE;case Bo.UNSIGNED_SHORT:return pt.UNSIGNED_SHORT;case Bo.UNSIGNED_INT:return pt.UNSIGNED_INT;case Bo.FLOAT:return pt.FLOAT;case Bo.HALF_FLOAT:return e.webgl2?pt.HALF_FLOAT:pt.HALF_FLOAT_OES;case Bo.UNSIGNED_INT_24_8:return pt.UNSIGNED_INT_24_8;case Bo.UNSIGNED_SHORT_4_4_4_4:return pt.UNSIGNED_SHORT_4_4_4_4;case Bo.UNSIGNED_SHORT_5_5_5_1:return pt.UNSIGNED_SHORT_5_5_5_1;case Bo.UNSIGNED_SHORT_5_6_5:return Bo.UNSIGNED_SHORT_5_6_5}};Bo.isPacked=function(t){return t===Bo.UNSIGNED_INT_24_8||t===Bo.UNSIGNED_SHORT_4_4_4_4||t===Bo.UNSIGNED_SHORT_5_5_5_1||t===Bo.UNSIGNED_SHORT_5_6_5};Bo.sizeInBytes=function(t){switch(t){case Bo.UNSIGNED_BYTE:return 1;case Bo.UNSIGNED_SHORT:case Bo.UNSIGNED_SHORT_4_4_4_4:case Bo.UNSIGNED_SHORT_5_5_5_1:case Bo.UNSIGNED_SHORT_5_6_5:case Bo.HALF_FLOAT:return 2;case Bo.UNSIGNED_INT:case Bo.FLOAT:case Bo.UNSIGNED_INT_24_8:return 4}};Bo.validate=function(t){return t===Bo.UNSIGNED_BYTE||t===Bo.UNSIGNED_SHORT||t===Bo.UNSIGNED_INT||t===Bo.FLOAT||t===Bo.HALF_FLOAT||t===Bo.UNSIGNED_INT_24_8||t===Bo.UNSIGNED_SHORT_4_4_4_4||t===Bo.UNSIGNED_SHORT_5_5_5_1||t===Bo.UNSIGNED_SHORT_5_6_5};var Ue=Object.freeze(Bo);var Xe={DEPTH_COMPONENT:pt.DEPTH_COMPONENT,DEPTH_STENCIL:pt.DEPTH_STENCIL,ALPHA:pt.ALPHA,RED:pt.RED,RG:pt.RG,RGB:pt.RGB,RGBA:pt.RGBA,LUMINANCE:pt.LUMINANCE,LUMINANCE_ALPHA:pt.LUMINANCE_ALPHA,RGB_DXT1:pt.COMPRESSED_RGB_S3TC_DXT1_EXT,RGBA_DXT1:pt.COMPRESSED_RGBA_S3TC_DXT1_EXT,RGBA_DXT3:pt.COMPRESSED_RGBA_S3TC_DXT3_EXT,RGBA_DXT5:pt.COMPRESSED_RGBA_S3TC_DXT5_EXT,RGB_PVRTC_4BPPV1:pt.COMPRESSED_RGB_PVRTC_4BPPV1_IMG,RGB_PVRTC_2BPPV1:pt.COMPRESSED_RGB_PVRTC_2BPPV1_IMG,RGBA_PVRTC_4BPPV1:pt.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG,RGBA_PVRTC_2BPPV1:pt.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG,RGBA_ASTC:pt.COMPRESSED_RGBA_ASTC_4x4_WEBGL,RGB_ETC1:pt.COMPRESSED_RGB_ETC1_WEBGL,RGB8_ETC2:pt.COMPRESSED_RGB8_ETC2,RGBA8_ETC2_EAC:pt.COMPRESSED_RGBA8_ETC2_EAC,RGBA_BC7:pt.COMPRESSED_RGBA_BPTC_UNORM};Xe.componentsLength=function(t){switch(t){case Xe.RGB:return 3;case Xe.RGBA:return 4;case Xe.LUMINANCE_ALPHA:case Xe.RG:return 2;case Xe.ALPHA:case Xe.RED:case Xe.LUMINANCE:return 1;default:return 1}};Xe.validate=function(t){return t===Xe.DEPTH_COMPONENT||t===Xe.DEPTH_STENCIL||t===Xe.ALPHA||t===Xe.RED||t===Xe.RG||t===Xe.RGB||t===Xe.RGBA||t===Xe.LUMINANCE||t===Xe.LUMINANCE_ALPHA||t===Xe.RGB_DXT1||t===Xe.RGBA_DXT1||t===Xe.RGBA_DXT3||t===Xe.RGBA_DXT5||t===Xe.RGB_PVRTC_4BPPV1||t===Xe.RGB_PVRTC_2BPPV1||t===Xe.RGBA_PVRTC_4BPPV1||t===Xe.RGBA_PVRTC_2BPPV1||t===Xe.RGBA_ASTC||t===Xe.RGB_ETC1||t===Xe.RGB8_ETC2||t===Xe.RGBA8_ETC2_EAC||t===Xe.RGBA_BC7};Xe.isColorFormat=function(t){return t===Xe.RED||t===Xe.ALPHA||t===Xe.RGB||t===Xe.RGBA||t===Xe.LUMINANCE||t===Xe.LUMINANCE_ALPHA};Xe.isDepthFormat=function(t){return t===Xe.DEPTH_COMPONENT||t===Xe.DEPTH_STENCIL};Xe.isCompressedFormat=function(t){return t===Xe.RGB_DXT1||t===Xe.RGBA_DXT1||t===Xe.RGBA_DXT3||t===Xe.RGBA_DXT5||t===Xe.RGB_PVRTC_4BPPV1||t===Xe.RGB_PVRTC_2BPPV1||t===Xe.RGBA_PVRTC_4BPPV1||t===Xe.RGBA_PVRTC_2BPPV1||t===Xe.RGBA_ASTC||t===Xe.RGB_ETC1||t===Xe.RGB8_ETC2||t===Xe.RGBA8_ETC2_EAC||t===Xe.RGBA_BC7};Xe.isDXTFormat=function(t){return t===Xe.RGB_DXT1||t===Xe.RGBA_DXT1||t===Xe.RGBA_DXT3||t===Xe.RGBA_DXT5};Xe.isPVRTCFormat=function(t){return t===Xe.RGB_PVRTC_4BPPV1||t===Xe.RGB_PVRTC_2BPPV1||t===Xe.RGBA_PVRTC_4BPPV1||t===Xe.RGBA_PVRTC_2BPPV1};Xe.isASTCFormat=function(t){return t===Xe.RGBA_ASTC};Xe.isETC1Format=function(t){return t===Xe.RGB_ETC1};Xe.isETC2Format=function(t){return t===Xe.RGB8_ETC2||t===Xe.RGBA8_ETC2_EAC};Xe.isBC7Format=function(t){return t===Xe.RGBA_BC7};Xe.compressedTextureSizeInBytes=function(t,e,n){switch(t){case Xe.RGB_DXT1:case Xe.RGBA_DXT1:case Xe.RGB_ETC1:case Xe.RGB8_ETC2:return Math.floor((e+3)/4)*Math.floor((n+3)/4)*8;case Xe.RGBA_DXT3:case Xe.RGBA_DXT5:case Xe.RGBA_ASTC:case Xe.RGBA8_ETC2_EAC:return Math.floor((e+3)/4)*Math.floor((n+3)/4)*16;case Xe.RGB_PVRTC_4BPPV1:case Xe.RGBA_PVRTC_4BPPV1:return Math.floor((Math.max(e,8)*Math.max(n,8)*4+7)/8);case Xe.RGB_PVRTC_2BPPV1:case Xe.RGBA_PVRTC_2BPPV1:return Math.floor((Math.max(e,16)*Math.max(n,8)*2+7)/8);case Xe.RGBA_BC7:return Math.ceil(e/4)*Math.ceil(n/4)*16;default:return 0}};Xe.textureSizeInBytes=function(t,e,n,i){let o=Xe.componentsLength(t);return Ue.isPacked(e)&&(o=1),o*Ue.sizeInBytes(e)*n*i};Xe.alignmentInBytes=function(t,e,n){let i=Xe.textureSizeInBytes(t,e,n,1)%4;return i===0?4:i===2?2:1};Xe.createTypedArray=function(t,e,n,i){let o,a=Ue.sizeInBytes(e);a===Uint8Array.BYTES_PER_ELEMENT?o=Uint8Array:a===Uint16Array.BYTES_PER_ELEMENT?o=Uint16Array:a===Float32Array.BYTES_PER_ELEMENT&&e===Ue.FLOAT?o=Float32Array:o=Uint32Array;let s=Xe.componentsLength(t)*n*i;return new o(s)};Xe.flipY=function(t,e,n,i,o){if(o===1)return t;let a=Xe.createTypedArray(e,n,i,o),s=Xe.componentsLength(e),l=i*s;for(let r=0;r0&&console.log(`${xV}Vertex shader compile log: ${r}`),r=t.getShaderInfoLog(a),c(r)&&r.length>0&&console.log(`${xV}Fragment shader compile log: ${r}`),r=t.getProgramInfoLog(s),c(r)&&r.length>0&&console.log(`${xV}Shader program link log: ${r}`)),t.deleteShader(o),t.deleteShader(a),s;let d,m=e._debugShaders;throw t.getShaderParameter(a,t.COMPILE_STATUS)?t.getShaderParameter(o,t.COMPILE_STATUS)?(r=t.getProgramInfoLog(s),console.error(`${xV}Shader program link log: ${r}`),h(o,"vertex"),h(a,"fragment"),d=`Program failed to link. Link log: ${r}`):(r=t.getShaderInfoLog(o),console.error(`${xV}Vertex shader compile log: ${r}`),console.error(`${xV} Vertex shader source: -${n}`),d=`Vertex shader failed to compile. Compile log: ${r}`):(r=t.getShaderInfoLog(a),console.error(`${xV}Fragment shader compile log: ${r}`),console.error(`${xV} Fragment shader source: -${i}`),d=`Fragment shader failed to compile. Compile log: ${r}`),t.deleteShader(o),t.deleteShader(a),t.deleteProgram(s),new St(d);function h(Z,b){if(!c(m))return;let u=m.getTranslatedShaderSource(Z);if(u===""){console.error(`${xV}${b} shader translation failed.`);return}console.error(`${xV}Translated ${b} shaderSource: -${u}`)}}function x5t(t,e,n){let i={};for(let o=0;o=0){if(m=n[d.slice(0,u)],!c(m))continue;h=m._locations,h.length<=1&&(Z=m.value,b=t.getUniformLocation(e,d),b!==null&&(h.push(b),Z.push(t.getUniform(e,b))))}else{h=[];for(let F=0;F{t.onmessage=function(o){let a=o.data.array,s=c(a)&&a[0]===e;i(s),t.terminate(),cd._canTransferArrayBuffer=s}})}return cd._canTransferArrayBuffer}var j6=new It;function z6(t){let e;try{e=new Blob([t],{type:"application/javascript"})}catch{let o=window.BlobBuilder||window.WebKitBlobBuilder||window.MozBlobBuilder||window.MSBlobBuilder,a=new o;a.append(t),e=a.getBlob("application/javascript")}return(window.URL||window.webkitURL).createObjectURL(e)}function q6(t){let e=new vht.default(t),n=e.scheme().length!==0&&e.fragment().length===0,i={},o;if(ZG(t)){let s=`importScripts("${t}");`;return o=z6(s),new Worker(o,i)}let a=t.replace(/\.js$/,"");if(!n&&typeof CESIUM_WORKERS<"u"){let s=` +`;var EKe=b(W(),1);var Os={CULL:1,OCCLUDE:2,EXECUTE_IN_CLOSEST_FRUSTUM:4,DEBUG_SHOW_BOUNDING_VOLUME:8,CAST_SHADOWS:16,RECEIVE_SHADOWS:32,PICK_ONLY:64,DEPTH_FOR_TRANSLUCENT_CLASSIFICATION:128};function my(t){t=f(t,f.EMPTY_OBJECT),this._boundingVolume=t.boundingVolume,this._orientedBoundingBox=t.orientedBoundingBox,this._modelMatrix=t.modelMatrix,this._primitiveType=f(t.primitiveType,le.TRIANGLES),this._vertexArray=t.vertexArray,this._count=t.count,this._offset=f(t.offset,0),this._instanceCount=f(t.instanceCount,0),this._shaderProgram=t.shaderProgram,this._uniformMap=t.uniformMap,this._renderState=t.renderState,this._framebuffer=t.framebuffer,this._pass=t.pass,this._owner=t.owner,this._debugOverlappingFrustums=0,this._pickId=t.pickId,this._flags=0,this.cull=f(t.cull,!0),this.occlude=f(t.occlude,!0),this.executeInClosestFrustum=f(t.executeInClosestFrustum,!1),this.debugShowBoundingVolume=f(t.debugShowBoundingVolume,!1),this.castShadows=f(t.castShadows,!1),this.receiveShadows=f(t.receiveShadows,!1),this.pickOnly=f(t.pickOnly,!1),this.depthForTranslucentClassification=f(t.depthForTranslucentClassification,!1),this.dirty=!0,this.lastDirtyTime=0,this.derivedCommands={}}function Jd(t,e){return(t._flags&e)===e}function Vf(t,e,n){n?t._flags|=e:t._flags&=~e}Object.defineProperties(my.prototype,{boundingVolume:{get:function(){return this._boundingVolume},set:function(t){this._boundingVolume!==t&&(this._boundingVolume=t,this.dirty=!0)}},orientedBoundingBox:{get:function(){return this._orientedBoundingBox},set:function(t){this._orientedBoundingBox!==t&&(this._orientedBoundingBox=t,this.dirty=!0)}},cull:{get:function(){return Jd(this,Os.CULL)},set:function(t){Jd(this,Os.CULL)!==t&&(Vf(this,Os.CULL,t),this.dirty=!0)}},occlude:{get:function(){return Jd(this,Os.OCCLUDE)},set:function(t){Jd(this,Os.OCCLUDE)!==t&&(Vf(this,Os.OCCLUDE,t),this.dirty=!0)}},modelMatrix:{get:function(){return this._modelMatrix},set:function(t){this._modelMatrix!==t&&(this._modelMatrix=t,this.dirty=!0)}},primitiveType:{get:function(){return this._primitiveType},set:function(t){this._primitiveType!==t&&(this._primitiveType=t,this.dirty=!0)}},vertexArray:{get:function(){return this._vertexArray},set:function(t){this._vertexArray!==t&&(this._vertexArray=t,this.dirty=!0)}},count:{get:function(){return this._count},set:function(t){this._count!==t&&(this._count=t,this.dirty=!0)}},offset:{get:function(){return this._offset},set:function(t){this._offset!==t&&(this._offset=t,this.dirty=!0)}},instanceCount:{get:function(){return this._instanceCount},set:function(t){this._instanceCount!==t&&(this._instanceCount=t,this.dirty=!0)}},shaderProgram:{get:function(){return this._shaderProgram},set:function(t){this._shaderProgram!==t&&(this._shaderProgram=t,this.dirty=!0)}},castShadows:{get:function(){return Jd(this,Os.CAST_SHADOWS)},set:function(t){Jd(this,Os.CAST_SHADOWS)!==t&&(Vf(this,Os.CAST_SHADOWS,t),this.dirty=!0)}},receiveShadows:{get:function(){return Jd(this,Os.RECEIVE_SHADOWS)},set:function(t){Jd(this,Os.RECEIVE_SHADOWS)!==t&&(Vf(this,Os.RECEIVE_SHADOWS,t),this.dirty=!0)}},uniformMap:{get:function(){return this._uniformMap},set:function(t){this._uniformMap!==t&&(this._uniformMap=t,this.dirty=!0)}},renderState:{get:function(){return this._renderState},set:function(t){this._renderState!==t&&(this._renderState=t,this.dirty=!0)}},framebuffer:{get:function(){return this._framebuffer},set:function(t){this._framebuffer!==t&&(this._framebuffer=t,this.dirty=!0)}},pass:{get:function(){return this._pass},set:function(t){this._pass!==t&&(this._pass=t,this.dirty=!0)}},executeInClosestFrustum:{get:function(){return Jd(this,Os.EXECUTE_IN_CLOSEST_FRUSTUM)},set:function(t){Jd(this,Os.EXECUTE_IN_CLOSEST_FRUSTUM)!==t&&(Vf(this,Os.EXECUTE_IN_CLOSEST_FRUSTUM,t),this.dirty=!0)}},owner:{get:function(){return this._owner},set:function(t){this._owner!==t&&(this._owner=t,this.dirty=!0)}},debugShowBoundingVolume:{get:function(){return Jd(this,Os.DEBUG_SHOW_BOUNDING_VOLUME)},set:function(t){Jd(this,Os.DEBUG_SHOW_BOUNDING_VOLUME)!==t&&(Vf(this,Os.DEBUG_SHOW_BOUNDING_VOLUME,t),this.dirty=!0)}},debugOverlappingFrustums:{get:function(){return this._debugOverlappingFrustums},set:function(t){this._debugOverlappingFrustums!==t&&(this._debugOverlappingFrustums=t,this.dirty=!0)}},pickId:{get:function(){return this._pickId},set:function(t){this._pickId!==t&&(this._pickId=t,this.dirty=!0)}},pickOnly:{get:function(){return Jd(this,Os.PICK_ONLY)},set:function(t){Jd(this,Os.PICK_ONLY)!==t&&(Vf(this,Os.PICK_ONLY,t),this.dirty=!0)}},depthForTranslucentClassification:{get:function(){return Jd(this,Os.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION)},set:function(t){Jd(this,Os.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION)!==t&&(Vf(this,Os.DEPTH_FOR_TRANSLUCENT_CLASSIFICATION,t),this.dirty=!0)}}});my.shallowClone=function(t,e){if(c(t))return c(e)||(e=new my),e._boundingVolume=t._boundingVolume,e._orientedBoundingBox=t._orientedBoundingBox,e._modelMatrix=t._modelMatrix,e._primitiveType=t._primitiveType,e._vertexArray=t._vertexArray,e._count=t._count,e._offset=t._offset,e._instanceCount=t._instanceCount,e._shaderProgram=t._shaderProgram,e._uniformMap=t._uniformMap,e._renderState=t._renderState,e._framebuffer=t._framebuffer,e._pass=t._pass,e._owner=t._owner,e._debugOverlappingFrustums=t._debugOverlappingFrustums,e._pickId=t._pickId,e._flags=t._flags,e.dirty=!0,e.lastDirtyTime=0,e};my.prototype.execute=function(t,e){t.draw(this,e)};var Ee=my;var DKe=b(W(),1);var kKe=b(W(),1);var NKe=b(W(),1);var Bo={UNSIGNED_BYTE:pt.UNSIGNED_BYTE,UNSIGNED_SHORT:pt.UNSIGNED_SHORT,UNSIGNED_INT:pt.UNSIGNED_INT,FLOAT:pt.FLOAT,HALF_FLOAT:pt.HALF_FLOAT_OES,UNSIGNED_INT_24_8:pt.UNSIGNED_INT_24_8,UNSIGNED_SHORT_4_4_4_4:pt.UNSIGNED_SHORT_4_4_4_4,UNSIGNED_SHORT_5_5_5_1:pt.UNSIGNED_SHORT_5_5_5_1,UNSIGNED_SHORT_5_6_5:pt.UNSIGNED_SHORT_5_6_5};Bo.toWebGLConstant=function(t,e){switch(t){case Bo.UNSIGNED_BYTE:return pt.UNSIGNED_BYTE;case Bo.UNSIGNED_SHORT:return pt.UNSIGNED_SHORT;case Bo.UNSIGNED_INT:return pt.UNSIGNED_INT;case Bo.FLOAT:return pt.FLOAT;case Bo.HALF_FLOAT:return e.webgl2?pt.HALF_FLOAT:pt.HALF_FLOAT_OES;case Bo.UNSIGNED_INT_24_8:return pt.UNSIGNED_INT_24_8;case Bo.UNSIGNED_SHORT_4_4_4_4:return pt.UNSIGNED_SHORT_4_4_4_4;case Bo.UNSIGNED_SHORT_5_5_5_1:return pt.UNSIGNED_SHORT_5_5_5_1;case Bo.UNSIGNED_SHORT_5_6_5:return Bo.UNSIGNED_SHORT_5_6_5}};Bo.isPacked=function(t){return t===Bo.UNSIGNED_INT_24_8||t===Bo.UNSIGNED_SHORT_4_4_4_4||t===Bo.UNSIGNED_SHORT_5_5_5_1||t===Bo.UNSIGNED_SHORT_5_6_5};Bo.sizeInBytes=function(t){switch(t){case Bo.UNSIGNED_BYTE:return 1;case Bo.UNSIGNED_SHORT:case Bo.UNSIGNED_SHORT_4_4_4_4:case Bo.UNSIGNED_SHORT_5_5_5_1:case Bo.UNSIGNED_SHORT_5_6_5:case Bo.HALF_FLOAT:return 2;case Bo.UNSIGNED_INT:case Bo.FLOAT:case Bo.UNSIGNED_INT_24_8:return 4}};Bo.validate=function(t){return t===Bo.UNSIGNED_BYTE||t===Bo.UNSIGNED_SHORT||t===Bo.UNSIGNED_INT||t===Bo.FLOAT||t===Bo.HALF_FLOAT||t===Bo.UNSIGNED_INT_24_8||t===Bo.UNSIGNED_SHORT_4_4_4_4||t===Bo.UNSIGNED_SHORT_5_5_5_1||t===Bo.UNSIGNED_SHORT_5_6_5};var Ue=Object.freeze(Bo);var Xe={DEPTH_COMPONENT:pt.DEPTH_COMPONENT,DEPTH_STENCIL:pt.DEPTH_STENCIL,ALPHA:pt.ALPHA,RED:pt.RED,RG:pt.RG,RGB:pt.RGB,RGBA:pt.RGBA,LUMINANCE:pt.LUMINANCE,LUMINANCE_ALPHA:pt.LUMINANCE_ALPHA,RGB_DXT1:pt.COMPRESSED_RGB_S3TC_DXT1_EXT,RGBA_DXT1:pt.COMPRESSED_RGBA_S3TC_DXT1_EXT,RGBA_DXT3:pt.COMPRESSED_RGBA_S3TC_DXT3_EXT,RGBA_DXT5:pt.COMPRESSED_RGBA_S3TC_DXT5_EXT,RGB_PVRTC_4BPPV1:pt.COMPRESSED_RGB_PVRTC_4BPPV1_IMG,RGB_PVRTC_2BPPV1:pt.COMPRESSED_RGB_PVRTC_2BPPV1_IMG,RGBA_PVRTC_4BPPV1:pt.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG,RGBA_PVRTC_2BPPV1:pt.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG,RGBA_ASTC:pt.COMPRESSED_RGBA_ASTC_4x4_WEBGL,RGB_ETC1:pt.COMPRESSED_RGB_ETC1_WEBGL,RGB8_ETC2:pt.COMPRESSED_RGB8_ETC2,RGBA8_ETC2_EAC:pt.COMPRESSED_RGBA8_ETC2_EAC,RGBA_BC7:pt.COMPRESSED_RGBA_BPTC_UNORM};Xe.componentsLength=function(t){switch(t){case Xe.RGB:return 3;case Xe.RGBA:return 4;case Xe.LUMINANCE_ALPHA:case Xe.RG:return 2;case Xe.ALPHA:case Xe.RED:case Xe.LUMINANCE:return 1;default:return 1}};Xe.validate=function(t){return t===Xe.DEPTH_COMPONENT||t===Xe.DEPTH_STENCIL||t===Xe.ALPHA||t===Xe.RED||t===Xe.RG||t===Xe.RGB||t===Xe.RGBA||t===Xe.LUMINANCE||t===Xe.LUMINANCE_ALPHA||t===Xe.RGB_DXT1||t===Xe.RGBA_DXT1||t===Xe.RGBA_DXT3||t===Xe.RGBA_DXT5||t===Xe.RGB_PVRTC_4BPPV1||t===Xe.RGB_PVRTC_2BPPV1||t===Xe.RGBA_PVRTC_4BPPV1||t===Xe.RGBA_PVRTC_2BPPV1||t===Xe.RGBA_ASTC||t===Xe.RGB_ETC1||t===Xe.RGB8_ETC2||t===Xe.RGBA8_ETC2_EAC||t===Xe.RGBA_BC7};Xe.isColorFormat=function(t){return t===Xe.RED||t===Xe.ALPHA||t===Xe.RGB||t===Xe.RGBA||t===Xe.LUMINANCE||t===Xe.LUMINANCE_ALPHA};Xe.isDepthFormat=function(t){return t===Xe.DEPTH_COMPONENT||t===Xe.DEPTH_STENCIL};Xe.isCompressedFormat=function(t){return t===Xe.RGB_DXT1||t===Xe.RGBA_DXT1||t===Xe.RGBA_DXT3||t===Xe.RGBA_DXT5||t===Xe.RGB_PVRTC_4BPPV1||t===Xe.RGB_PVRTC_2BPPV1||t===Xe.RGBA_PVRTC_4BPPV1||t===Xe.RGBA_PVRTC_2BPPV1||t===Xe.RGBA_ASTC||t===Xe.RGB_ETC1||t===Xe.RGB8_ETC2||t===Xe.RGBA8_ETC2_EAC||t===Xe.RGBA_BC7};Xe.isDXTFormat=function(t){return t===Xe.RGB_DXT1||t===Xe.RGBA_DXT1||t===Xe.RGBA_DXT3||t===Xe.RGBA_DXT5};Xe.isPVRTCFormat=function(t){return t===Xe.RGB_PVRTC_4BPPV1||t===Xe.RGB_PVRTC_2BPPV1||t===Xe.RGBA_PVRTC_4BPPV1||t===Xe.RGBA_PVRTC_2BPPV1};Xe.isASTCFormat=function(t){return t===Xe.RGBA_ASTC};Xe.isETC1Format=function(t){return t===Xe.RGB_ETC1};Xe.isETC2Format=function(t){return t===Xe.RGB8_ETC2||t===Xe.RGBA8_ETC2_EAC};Xe.isBC7Format=function(t){return t===Xe.RGBA_BC7};Xe.compressedTextureSizeInBytes=function(t,e,n){switch(t){case Xe.RGB_DXT1:case Xe.RGBA_DXT1:case Xe.RGB_ETC1:case Xe.RGB8_ETC2:return Math.floor((e+3)/4)*Math.floor((n+3)/4)*8;case Xe.RGBA_DXT3:case Xe.RGBA_DXT5:case Xe.RGBA_ASTC:case Xe.RGBA8_ETC2_EAC:return Math.floor((e+3)/4)*Math.floor((n+3)/4)*16;case Xe.RGB_PVRTC_4BPPV1:case Xe.RGBA_PVRTC_4BPPV1:return Math.floor((Math.max(e,8)*Math.max(n,8)*4+7)/8);case Xe.RGB_PVRTC_2BPPV1:case Xe.RGBA_PVRTC_2BPPV1:return Math.floor((Math.max(e,16)*Math.max(n,8)*2+7)/8);case Xe.RGBA_BC7:return Math.ceil(e/4)*Math.ceil(n/4)*16;default:return 0}};Xe.textureSizeInBytes=function(t,e,n,i){let o=Xe.componentsLength(t);return Ue.isPacked(e)&&(o=1),o*Ue.sizeInBytes(e)*n*i};Xe.alignmentInBytes=function(t,e,n){let i=Xe.textureSizeInBytes(t,e,n,1)%4;return i===0?4:i===2?2:1};Xe.createTypedArray=function(t,e,n,i){let o,a=Ue.sizeInBytes(e);a===Uint8Array.BYTES_PER_ELEMENT?o=Uint8Array:a===Uint16Array.BYTES_PER_ELEMENT?o=Uint16Array:a===Float32Array.BYTES_PER_ELEMENT&&e===Ue.FLOAT?o=Float32Array:o=Uint32Array;let s=Xe.componentsLength(t)*n*i;return new o(s)};Xe.flipY=function(t,e,n,i,o){if(o===1)return t;let a=Xe.createTypedArray(e,n,i,o),s=Xe.componentsLength(e),l=i*s;for(let r=0;r0&&console.log(`${xZ}Vertex shader compile log: ${r}`),r=t.getShaderInfoLog(a),c(r)&&r.length>0&&console.log(`${xZ}Fragment shader compile log: ${r}`),r=t.getProgramInfoLog(s),c(r)&&r.length>0&&console.log(`${xZ}Shader program link log: ${r}`)),t.deleteShader(o),t.deleteShader(a),s;let d,m=e._debugShaders;throw t.getShaderParameter(a,t.COMPILE_STATUS)?t.getShaderParameter(o,t.COMPILE_STATUS)?(r=t.getProgramInfoLog(s),console.error(`${xZ}Shader program link log: ${r}`),h(o,"vertex"),h(a,"fragment"),d=`Program failed to link. Link log: ${r}`):(r=t.getShaderInfoLog(o),console.error(`${xZ}Vertex shader compile log: ${r}`),console.error(`${xZ} Vertex shader source: +${n}`),d=`Vertex shader failed to compile. Compile log: ${r}`):(r=t.getShaderInfoLog(a),console.error(`${xZ}Fragment shader compile log: ${r}`),console.error(`${xZ} Fragment shader source: +${i}`),d=`Fragment shader failed to compile. Compile log: ${r}`),t.deleteShader(o),t.deleteShader(a),t.deleteProgram(s),new Tt(d);function h(u,R){if(!c(m))return;let V=m.getTranslatedShaderSource(u);if(V===""){console.error(`${xZ}${R} shader translation failed.`);return}console.error(`${xZ}Translated ${R} shaderSource: +${V}`)}}function x5t(t,e,n){let i={};for(let o=0;o=0){if(m=n[d.slice(0,V)],!c(m))continue;h=m._locations,h.length<=1&&(u=m.value,R=t.getUniformLocation(e,d),R!==null&&(h.push(R),u.push(t.getUniform(e,R))))}else{h=[];for(let F=0;F{t.onmessage=function(o){let a=o.data.array,s=c(a)&&a[0]===e;i(s),t.terminate(),cd._canTransferArrayBuffer=s}})}return cd._canTransferArrayBuffer}var j6=new It;function z6(t){let e;try{e=new Blob([t],{type:"application/javascript"})}catch{let o=window.BlobBuilder||window.WebKitBlobBuilder||window.MozBlobBuilder||window.MSBlobBuilder,a=new o;a.append(t),e=a.getBlob("application/javascript")}return(window.URL||window.webkitURL).createObjectURL(e)}function q6(t){let e=new vht.default(t),n=e.scheme().length!==0&&e.fragment().length===0,i={},o;if(uG(t)){let s=`importScripts("${t}");`;return o=z6(s),new Worker(o,i)}let a=t.replace(/\.js$/,"");if(!n&&typeof CESIUM_WORKERS<"u"){let s=` importScripts("${z6(CESIUM_WORKERS)}"); CesiumWorkers["${a}"](); - `;return o=z6(s),new Worker(o,i)}if(o=t,n||(o=Dn(`${cd._workerModulePrefix+a}.js`)),!In.supportsEsmWebWorkers())throw new St("This browser is not supported. Please update your browser to continue.");return i.type="module",new Worker(o,i)}async function oDt(t,e){let n={modulePath:void 0,wasmBinaryFile:void 0,wasmBinary:void 0};if(!In.supportsWebAssembly()){if(!c(e.fallbackModulePath))throw new St(`This browser does not support Web Assembly, and no backup module was provided for ${t._workerPath}`);return n.modulePath=Dn(e.fallbackModulePath),n}n.wasmBinaryFile=Dn(e.wasmBinaryFile);let i=await te.fetchArrayBuffer({url:n.wasmBinaryFile});return n.wasmBinary=i,n}function cd(t,e){this._workerPath=t,this._maximumActiveTasks=f(e,Number.POSITIVE_INFINITY),this._activeTasks=0,this._nextID=0,this._webAssemblyPromise=void 0}var aDt=(t,e,n,i)=>{let o=({data:a})=>{if(a.id===e){if(c(a.error)){let s=a.error;s.name==="RuntimeError"?(s=new St(a.error.message),s.stack=a.error.stack):s.name==="DeveloperError"?(s=new Ut(a.error.message),s.stack=a.error.stack):s.name==="Error"&&(s=new Error(a.error.message),s.stack=a.error.stack),j6.raiseEvent(s),i(s)}else j6.raiseEvent(),n(a.result);t.removeEventListener("message",o)}};return o},sDt=[];async function lDt(t,e,n){let i=await Promise.resolve(Kht());c(n)?i||(n.length=0):n=sDt;let o=t._nextID++,a=new Promise((s,l)=>{t._worker.addEventListener("message",aDt(t._worker,o,s,l))});return t._worker.postMessage({id:o,baseUrl:Dn.getCesiumBaseUrl().url,parameters:e,canTransferArrayBuffer:i},n),a}async function rDt(t,e,n){++t._activeTasks;try{let i=await lDt(t,e,n);return--t._activeTasks,i}catch(i){throw--t._activeTasks,i}}cd.prototype.scheduleTask=function(t,e){if(c(this._worker)||(this._worker=q6(this._workerPath)),!(this._activeTasks>=this._maximumActiveTasks))return rDt(this,t,e)};cd.prototype.initWebAssemblyModule=async function(t){if(c(this._webAssemblyPromise))return this._webAssemblyPromise;let e=async()=>{let n=this._worker=q6(this._workerPath),i=await oDt(this,t),o=await Promise.resolve(Kht()),a,s=i.wasmBinary;c(s)&&o&&(a=[s]);let l=new Promise((r,d)=>{n.onmessage=function({data:m}){c(m)?r(m.result):d(new St("Could not configure wasm module"))}});return n.postMessage({canTransferArrayBuffer:o,parameters:{webAssemblyConfig:i}},a),l};return this._webAssemblyPromise=e(),this._webAssemblyPromise};cd.prototype.isDestroyed=function(){return!1};cd.prototype.destroy=function(){return c(this._worker)&&this._worker.terminate(),At(this)};cd.taskCompletedEvent=j6;cd._defaultWorkerModulePrefix="Workers/";cd._workerModulePrefix=cd._defaultWorkerModulePrefix;cd._canTransferArrayBuffer=void 0;var $i=cd;function TR(){}TR._transcodeTaskProcessor=new $i("transcodeKTX2",Number.POSITIVE_INFINITY);TR._readyPromise=void 0;function dDt(){let t=TR._transcodeTaskProcessor.initWebAssemblyModule({wasmBinaryFile:"ThirdParty/basis_transcoder.wasm"}).then(function(e){if(e)return TR._transcodeTaskProcessor;throw new St("KTX2 transcoder could not be initialized.")});TR._readyPromise=t}TR.transcode=function(t,e){return c(TR._readyPromise)||dDt(),TR._readyPromise.then(function(n){let i;if(t instanceof ArrayBuffer){let o=new Uint8Array(t);return i={supportedTargetFormats:e,ktx2Buffer:o},n.scheduleTask(i,[t])}return i={supportedTargetFormats:e,ktx2Buffer:t},n.scheduleTask(i,[t.buffer])}).then(function(n){let i=n.length,o=Object.keys(n[0]),a=o.length,s;for(s=0;s{let o=({data:a})=>{if(a.id===e){if(c(a.error)){let s=a.error;s.name==="RuntimeError"?(s=new Tt(a.error.message),s.stack=a.error.stack):s.name==="DeveloperError"?(s=new Ut(a.error.message),s.stack=a.error.stack):s.name==="Error"&&(s=new Error(a.error.message),s.stack=a.error.stack),j6.raiseEvent(s),i(s)}else j6.raiseEvent(),n(a.result);t.removeEventListener("message",o)}};return o},sDt=[];async function lDt(t,e,n){let i=await Promise.resolve(Kht());c(n)?i||(n.length=0):n=sDt;let o=t._nextID++,a=new Promise((s,l)=>{t._worker.addEventListener("message",aDt(t._worker,o,s,l))});return t._worker.postMessage({id:o,baseUrl:Dn.getCesiumBaseUrl().url,parameters:e,canTransferArrayBuffer:i},n),a}async function rDt(t,e,n){++t._activeTasks;try{let i=await lDt(t,e,n);return--t._activeTasks,i}catch(i){throw--t._activeTasks,i}}cd.prototype.scheduleTask=function(t,e){if(c(this._worker)||(this._worker=q6(this._workerPath)),!(this._activeTasks>=this._maximumActiveTasks))return rDt(this,t,e)};cd.prototype.initWebAssemblyModule=async function(t){if(c(this._webAssemblyPromise))return this._webAssemblyPromise;let e=async()=>{let n=this._worker=q6(this._workerPath),i=await oDt(this,t),o=await Promise.resolve(Kht()),a,s=i.wasmBinary;c(s)&&o&&(a=[s]);let l=new Promise((r,d)=>{n.onmessage=function({data:m}){c(m)?r(m.result):d(new Tt("Could not configure wasm module"))}});return n.postMessage({canTransferArrayBuffer:o,parameters:{webAssemblyConfig:i}},a),l};return this._webAssemblyPromise=e(),this._webAssemblyPromise};cd.prototype.isDestroyed=function(){return!1};cd.prototype.destroy=function(){return c(this._worker)&&this._worker.terminate(),At(this)};cd.taskCompletedEvent=j6;cd._defaultWorkerModulePrefix="Workers/";cd._workerModulePrefix=cd._defaultWorkerModulePrefix;cd._canTransferArrayBuffer=void 0;var $i=cd;function Sb(){}Sb._transcodeTaskProcessor=new $i("transcodeKTX2",Number.POSITIVE_INFINITY);Sb._readyPromise=void 0;function dDt(){let t=Sb._transcodeTaskProcessor.initWebAssemblyModule({wasmBinaryFile:"ThirdParty/basis_transcoder.wasm"}).then(function(e){if(e)return Sb._transcodeTaskProcessor;throw new Tt("KTX2 transcoder could not be initialized.")});Sb._readyPromise=t}Sb.transcode=function(t,e){return c(Sb._readyPromise)||dDt(),Sb._readyPromise.then(function(n){let i;if(t instanceof ArrayBuffer){let o=new Uint8Array(t);return i={supportedTargetFormats:e,ktx2Buffer:o},n.scheduleTask(i,[t])}return i={supportedTargetFormats:e,ktx2Buffer:t},n.scheduleTask(i,[t.buffer])}).then(function(n){let i=n.length,o=Object.keys(n[0]),a=o.length,s;for(s=0;s1/pi. * * @alias czm_oneOverPi @@ -224,7 +224,7 @@ const float czm_infinity = 5906376272000.0; // Distance from the Sun to Pluto i * float pi = 1.0 / czm_oneOverPi; */ const float czm_oneOverPi = 0.3183098861837907; -`;var c8e=R(W(),1),yy=`/** +`;var c8e=b(W(),1),yy=`/** * A built-in GLSL floating-point constant for 1/2pi. * * @alias czm_oneOverTwoPi @@ -240,7 +240,7 @@ const float czm_oneOverPi = 0.3183098861837907; * float pi = 2.0 * czm_oneOverTwoPi; */ const float czm_oneOverTwoPi = 0.15915494309189535; -`;var h8e=R(W(),1),By=`/** +`;var h8e=b(W(),1),By=`/** * The automatic GLSL constant for {@link Pass#CESIUM_3D_TILE} * * @name czm_passCesium3DTile @@ -249,7 +249,7 @@ const float czm_oneOverTwoPi = 0.15915494309189535; * @see czm_pass */ const float czm_passCesium3DTile = 4.0; -`;var u8e=R(W(),1),Qy=`/** +`;var V8e=b(W(),1),Qy=`/** * The automatic GLSL constant for {@link Pass#CESIUM_3D_TILE_CLASSIFICATION} * * @name czm_passCesium3DTileClassification @@ -258,7 +258,7 @@ const float czm_passCesium3DTile = 4.0; * @see czm_pass */ const float czm_passCesium3DTileClassification = 5.0; -`;var V8e=R(W(),1),ky=`/** +`;var Z8e=b(W(),1),ky=`/** * The automatic GLSL constant for {@link Pass#CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW} * * @name czm_passCesium3DTileClassificationIgnoreShow @@ -267,7 +267,7 @@ const float czm_passCesium3DTileClassification = 5.0; * @see czm_pass */ const float czm_passCesium3DTileClassificationIgnoreShow = 6.0; -`;var R8e=R(W(),1),Yy=`/** +`;var b8e=b(W(),1),Yy=`/** * The automatic GLSL constant for {@link Pass#CLASSIFICATION} * * @name czm_passClassification @@ -276,7 +276,7 @@ const float czm_passCesium3DTileClassificationIgnoreShow = 6.0; * @see czm_pass */ const float czm_passClassification = 7.0; -`;var f8e=R(W(),1),xy=`/** +`;var f8e=b(W(),1),xy=`/** * The automatic GLSL constant for {@link Pass#COMPUTE} * * @name czm_passCompute @@ -285,7 +285,7 @@ const float czm_passClassification = 7.0; * @see czm_pass */ const float czm_passCompute = 1.0; -`;var U8e=R(W(),1),Xy=`/** +`;var U8e=b(W(),1),Xy=`/** * The automatic GLSL constant for {@link Pass#ENVIRONMENT} * * @name czm_passEnvironment @@ -294,7 +294,7 @@ const float czm_passCompute = 1.0; * @see czm_pass */ const float czm_passEnvironment = 0.0; -`;var A8e=R(W(),1),Jy=`/** +`;var A8e=b(W(),1),Jy=`/** * The automatic GLSL constant for {@link Pass#GLOBE} * * @name czm_passGlobe @@ -303,7 +303,7 @@ const float czm_passEnvironment = 0.0; * @see czm_pass */ const float czm_passGlobe = 2.0; -`;var S8e=R(W(),1),Ly=`/** +`;var T8e=b(W(),1),Ly=`/** * The automatic GLSL constant for {@link Pass#OPAQUE} * * @name czm_passOpaque @@ -312,7 +312,7 @@ const float czm_passGlobe = 2.0; * @see czm_pass */ const float czm_passOpaque = 7.0; -`;var E8e=R(W(),1),My=`/** +`;var E8e=b(W(),1),My=`/** * The automatic GLSL constant for {@link Pass#OVERLAY} * * @name czm_passOverlay @@ -321,7 +321,7 @@ const float czm_passOpaque = 7.0; * @see czm_pass */ const float czm_passOverlay = 10.0; -`;var I8e=R(W(),1),_y=`/** +`;var I8e=b(W(),1),_y=`/** * The automatic GLSL constant for {@link Pass#TERRAIN_CLASSIFICATION} * * @name czm_passTerrainClassification @@ -330,7 +330,7 @@ const float czm_passOverlay = 10.0; * @see czm_pass */ const float czm_passTerrainClassification = 3.0; -`;var y8e=R(W(),1),Dy=`/** +`;var y8e=b(W(),1),Dy=`/** * The automatic GLSL constant for {@link Pass#TRANSLUCENT} * * @name czm_passTranslucent @@ -339,7 +339,7 @@ const float czm_passTerrainClassification = 3.0; * @see czm_pass */ const float czm_passTranslucent = 8.0; -`;var Q8e=R(W(),1),Oy=`/** +`;var Q8e=b(W(),1),Oy=`/** * The automatic GLSL constant for {@link Pass#VOXELS} * * @name czm_passVoxels @@ -348,7 +348,7 @@ const float czm_passTranslucent = 8.0; * @see czm_pass */ const float czm_passVoxels = 9.0; -`;var Y8e=R(W(),1),Hy=`/** +`;var Y8e=b(W(),1),Hy=`/** * A built-in GLSL floating-point constant for Math.PI. * * @alias czm_pi @@ -364,7 +364,7 @@ const float czm_passVoxels = 9.0; * float twoPi = 2.0 * czm_pi; */ const float czm_pi = 3.141592653589793; -`;var X8e=R(W(),1),wy=`/** +`;var X8e=b(W(),1),wy=`/** * A built-in GLSL floating-point constant for pi/4. * * @alias czm_piOverFour @@ -380,7 +380,7 @@ const float czm_pi = 3.141592653589793; * float pi = 4.0 * czm_piOverFour; */ const float czm_piOverFour = 0.7853981633974483; -`;var L8e=R(W(),1),Py=`/** +`;var L8e=b(W(),1),Py=`/** * A built-in GLSL floating-point constant for pi/6. * * @alias czm_piOverSix @@ -396,7 +396,7 @@ const float czm_piOverFour = 0.7853981633974483; * float pi = 6.0 * czm_piOverSix; */ const float czm_piOverSix = 0.5235987755982988; -`;var _8e=R(W(),1),vy=`/** +`;var _8e=b(W(),1),vy=`/** * A built-in GLSL floating-point constant for pi/3. * * @alias czm_piOverThree @@ -412,7 +412,7 @@ const float czm_piOverSix = 0.5235987755982988; * float pi = 3.0 * czm_piOverThree; */ const float czm_piOverThree = 1.0471975511965976; -`;var O8e=R(W(),1),Ky=`/** +`;var O8e=b(W(),1),Ky=`/** * A built-in GLSL floating-point constant for pi/2. * * @alias czm_piOverTwo @@ -428,7 +428,7 @@ const float czm_piOverThree = 1.0471975511965976; * float pi = 2.0 * czm_piOverTwo; */ const float czm_piOverTwo = 1.5707963267948966; -`;var w8e=R(W(),1),zy=`/** +`;var w8e=b(W(),1),zy=`/** * A built-in GLSL floating-point constant for converting degrees to radians. * * @alias czm_radiansPerDegree @@ -444,7 +444,7 @@ const float czm_piOverTwo = 1.5707963267948966; * float rad = czm_radiansPerDegree * deg; */ const float czm_radiansPerDegree = 0.017453292519943295; -`;var v8e=R(W(),1),jy=`/** +`;var v8e=b(W(),1),jy=`/** * The constant identifier for the 2D {@link SceneMode} * * @name czm_sceneMode2D @@ -455,7 +455,7 @@ const float czm_radiansPerDegree = 0.017453292519943295; * @see czm_sceneModeMorphing */ const float czm_sceneMode2D = 2.0; -`;var z8e=R(W(),1),qy=`/** +`;var z8e=b(W(),1),qy=`/** * The constant identifier for the 3D {@link SceneMode} * * @name czm_sceneMode3D @@ -466,7 +466,7 @@ const float czm_sceneMode2D = 2.0; * @see czm_sceneModeMorphing */ const float czm_sceneMode3D = 3.0; -`;var q8e=R(W(),1),$y=`/** +`;var q8e=b(W(),1),$y=`/** * The constant identifier for the Columbus View {@link SceneMode} * * @name czm_sceneModeColumbusView @@ -477,7 +477,7 @@ const float czm_sceneMode3D = 3.0; * @see czm_sceneModeMorphing */ const float czm_sceneModeColumbusView = 1.0; -`;var t6e=R(W(),1),tB=`/** +`;var t6e=b(W(),1),tB=`/** * The constant identifier for the Morphing {@link SceneMode} * * @name czm_sceneModeMorphing @@ -488,7 +488,7 @@ const float czm_sceneModeColumbusView = 1.0; * @see czm_sceneMode3D */ const float czm_sceneModeMorphing = 0.0; -`;var n6e=R(W(),1),eB=`/** +`;var n6e=b(W(),1),eB=`/** * A built-in GLSL floating-point constant for one solar radius. * * @alias czm_solarRadius @@ -501,7 +501,7 @@ const float czm_sceneModeMorphing = 0.0; * const float czm_solarRadius = ...; */ const float czm_solarRadius = 695500000.0; -`;var o6e=R(W(),1),nB=`/** +`;var o6e=b(W(),1),nB=`/** * A built-in GLSL floating-point constant for 3pi/2. * * @alias czm_threePiOver2 @@ -517,7 +517,7 @@ const float czm_solarRadius = 695500000.0; * float pi = (2.0 / 3.0) * czm_threePiOver2; */ const float czm_threePiOver2 = 4.71238898038469; -`;var s6e=R(W(),1),iB=`/** +`;var s6e=b(W(),1),iB=`/** * A built-in GLSL floating-point constant for 2pi. * * @alias czm_twoPi @@ -533,7 +533,7 @@ const float czm_threePiOver2 = 4.71238898038469; * float pi = czm_twoPi / 2.0; */ const float czm_twoPi = 6.283185307179586; -`;var r6e=R(W(),1),oB=`/** +`;var r6e=b(W(),1),oB=`/** * The maximum latitude, in radians, both North and South, supported by a Web Mercator * (EPSG:3857) projection. Technically, the Mercator projection is defined * for any latitude up to (but not including) 90 degrees, but it makes sense @@ -549,7 +549,7 @@ const float czm_twoPi = 6.283185307179586; * @glslConstant */ const float czm_webMercatorMaxLatitude = 1.4844222297453324; -`;var c6e=R(W(),1),aB=`/** +`;var c6e=b(W(),1),aB=`/** * @name czm_depthRangeStruct * @glslStruct */ @@ -558,7 +558,7 @@ struct czm_depthRangeStruct float near; float far; }; -`;var h6e=R(W(),1),sB=`/** +`;var h6e=b(W(),1),sB=`/** * Holds material information that can be used for lighting. Returned by all czm_getMaterial functions. * * @name czm_material @@ -580,7 +580,7 @@ struct czm_material vec3 emission; float alpha; }; -`;var u6e=R(W(),1),lB=`/** +`;var V6e=b(W(),1),lB=`/** * Used as input to every material's czm_getMaterial function. * * @name czm_materialInput @@ -608,7 +608,7 @@ struct czm_materialInput float slope; float aspect; }; -`;var V6e=R(W(),1),rB=`/** +`;var Z6e=b(W(),1),rB=`/** * Struct for representing a material for a {@link Model}. The model * rendering pipeline will pass this struct between material, custom shaders, * and lighting stages. This is not to be confused with {@link czm_material} @@ -637,7 +637,7 @@ struct czm_modelMaterial { float occlusion; vec3 emissive; }; -`;var R6e=R(W(),1),dB=`/** +`;var b6e=b(W(),1),dB=`/** * Struct for representing the output of a custom vertex shader. * * @name czm_modelVertexOutput @@ -653,7 +653,7 @@ struct czm_modelVertexOutput { vec3 positionMC; float pointSize; }; -`;var f6e=R(W(),1),cB=`/** +`;var f6e=b(W(),1),cB=`/** * Parameters for {@link czm_pbrLighting} * * @name czm_material @@ -669,7 +669,7 @@ struct czm_pbrParameters float roughness; vec3 f0; }; -`;var U6e=R(W(),1),mB=`/** +`;var U6e=b(W(),1),mB=`/** * DOC_TBA * * @name czm_ray @@ -680,7 +680,7 @@ struct czm_ray vec3 origin; vec3 direction; }; -`;var A6e=R(W(),1),hB=`/** +`;var A6e=b(W(),1),hB=`/** * DOC_TBA * * @name czm_raySegment @@ -707,7 +707,7 @@ const czm_raySegment czm_emptyRaySegment = czm_raySegment(-czm_infinity, -czm_in * @glslConstant */ const czm_raySegment czm_fullRaySegment = czm_raySegment(0.0, czm_infinity); -`;var S6e=R(W(),1),pB=`struct czm_shadowParameters +`;var T6e=b(W(),1),pB=`struct czm_shadowParameters { #ifdef USE_CUBE_MAP_SHADOW vec3 texCoords; @@ -722,7 +722,7 @@ const czm_raySegment czm_fullRaySegment = czm_raySegment(0.0, czm_infinity); float normalShadingSmooth; float darkness; }; -`;var E6e=R(W(),1),uB=`/** +`;var E6e=b(W(),1),VB=`/** * Converts an HSB color (hue, saturation, brightness) to RGB * HSB <-> RGB conversion with minimal branching: {@link http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl} * @@ -746,7 +746,7 @@ vec3 czm_HSBToRGB(vec3 hsb) vec3 p = abs(fract(hsb.xxx + K_HSB2RGB.xyz) * 6.0 - K_HSB2RGB.www); return hsb.z * mix(K_HSB2RGB.xxx, clamp(p - K_HSB2RGB.xxx, 0.0, 1.0), hsb.y); } -`;var I6e=R(W(),1),ZB=`/** +`;var I6e=b(W(),1),uB=`/** * Converts an HSL color (hue, saturation, lightness) to RGB * HSL <-> RGB conversion: {@link http://www.chilliant.com/rgb2hsv.html} * @@ -777,7 +777,7 @@ vec3 czm_HSLToRGB(vec3 hsl) float c = (1.0 - abs(2.0 * hsl.z - 1.0)) * hsl.y; return (rgb - 0.5) * c + hsl.z; } -`;var y6e=R(W(),1),VB=`/** +`;var y6e=b(W(),1),ZB=`/** * Converts an RGB color to HSB (hue, saturation, brightness) * HSB <-> RGB conversion with minimal branching: {@link http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl} * @@ -804,7 +804,7 @@ vec3 czm_RGBToHSB(vec3 rgb) float d = q.x - min(q.w, q.y); return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + czm_epsilon7)), d / (q.x + czm_epsilon7), q.x); } -`;var Q6e=R(W(),1),bB=`/** +`;var Q6e=b(W(),1),RB=`/** * Converts an RGB color to HSL (hue, saturation, lightness) * HSL <-> RGB conversion: {@link http://www.chilliant.com/rgb2hsv.html} * @@ -838,7 +838,7 @@ vec3 czm_RGBToHSL(vec3 rgb) float s = hcv.y / (1.0 - abs(l * 2.0 - 1.0) + czm_epsilon7); return vec3(hcv.x, s, l); } -`;var Y6e=R(W(),1),RB=`/** +`;var Y6e=b(W(),1),bB=`/** * Converts an RGB color to CIE Yxy. *

The conversion is described in * {@link http://content.gpwiki.org/index.php/D3DBook:High-Dynamic_Range_Rendering#Luminance_Transform|Luminance Transform} @@ -868,7 +868,7 @@ vec3 czm_RGBToXYZ(vec3 rgb) Yxy.gb = xyz.rg / temp; return Yxy; } -`;var X6e=R(W(),1),WB=`/** +`;var X6e=b(W(),1),WB=`/** * Converts a CIE Yxy color to RGB. *

The conversion is described in * {@link http://content.gpwiki.org/index.php/D3DBook:High-Dynamic_Range_Rendering#Luminance_Transform|Luminance Transform} @@ -898,7 +898,7 @@ vec3 czm_XYZToRGB(vec3 Yxy) return XYZ2RGB * xyz; } -`;var L6e=R(W(),1),fB=`// See: +`;var L6e=b(W(),1),fB=`// See: // https://knarkowicz.wordpress.com/2016/01/06/aces-filmic-tone-mapping-curve/ vec3 czm_acesTonemapping(vec3 color) { @@ -914,7 +914,7 @@ vec3 czm_acesTonemapping(vec3 color) { return color; } -`;var _6e=R(W(),1),FB=`/** +`;var _6e=b(W(),1),FB=`/** * @private */ float czm_alphaWeight(float a) @@ -925,7 +925,7 @@ float czm_alphaWeight(float a) // http://jcgt.org/published/0002/02/09/ return pow(a + 0.01, 4.0) + max(1e-2, min(3.0 * 1e3, 0.003 / (1e-5 + pow(abs(z) / 200.0, 4.0)))); } -`;var O6e=R(W(),1),UB=`/** +`;var O6e=b(W(),1),UB=`/** * Procedural anti-aliasing by blurring two colors that meet at a sharp edge. * * @name czm_antialias @@ -964,7 +964,7 @@ vec4 czm_antialias(vec4 color1, vec4 color2, vec4 currentColor, float dist) { return czm_antialias(color1, color2, currentColor, dist, 0.1); } -`;var w6e=R(W(),1),GB=`/** +`;var w6e=b(W(),1),GB=`/** * Apply a HSB color shift to an RGB color. * * @param {vec3} rgb The color in RGB space. @@ -996,7 +996,7 @@ vec3 czm_applyHSBShift(vec3 rgb, vec3 hsbShift, bool ignoreBlackPixels) { // Convert shifted hsb back to rgb return czm_HSBToRGB(hsb); } -`;var v6e=R(W(),1),AB=`/** +`;var v6e=b(W(),1),AB=`/** * Approximately computes spherical coordinates given a normal. * Uses approximate inverse trigonometry for speed and consistency, * since inverse trigonometry can differ from vendor-to-vendor and when compared with the CPU. @@ -1014,7 +1014,7 @@ vec2 czm_approximateSphericalCoordinates(vec3 normal) { float longitudeApproximation = czm_fastApproximateAtan(normal.x, normal.y); return vec2(latitudeApproximation, longitudeApproximation); } -`;var z6e=R(W(),1),TB=`/** +`;var z6e=b(W(),1),SB=`/** * Compute a rational approximation to tanh(x) * * @param {float} x A real number input @@ -1024,7 +1024,7 @@ float czm_approximateTanh(float x) { float x2 = x * x; return max(-1.0, min(1.0, x * (27.0 + x2) / (27.0 + 9.0 * x2))); } -`;var q6e=R(W(),1),SB=`/** +`;var q6e=b(W(),1),TB=`/** * Determines if the fragment is back facing * * @name czm_backFacing @@ -1037,7 +1037,7 @@ bool czm_backFacing() // !gl_FrontFacing doesn't work as expected on Mac/Intel so use the more verbose form instead. See https://github.com/CesiumGS/cesium/pull/8494. return gl_FrontFacing == false; } -`;var t7e=R(W(),1),gB=`/** +`;var t7e=b(W(),1),gB=`/** * Branchless ternary operator to be used when it's inexpensive to explicitly * evaluate both possibilities for a float expression. * @@ -1108,7 +1108,7 @@ vec4 czm_branchFreeTernary(bool comparison, vec4 a, vec4 b) { float useA = float(comparison); return a * useA + b * (1.0 - useA); } -`;var n7e=R(W(),1),EB=` +`;var n7e=b(W(),1),EB=` vec4 czm_cascadeColor(vec4 weights) { return vec4(1.0, 0.0, 0.0, 1.0) * weights.x + @@ -1116,14 +1116,14 @@ vec4 czm_cascadeColor(vec4 weights) vec4(0.0, 0.0, 1.0, 1.0) * weights.z + vec4(1.0, 0.0, 1.0, 1.0) * weights.w; } -`;var o7e=R(W(),1),CB=` +`;var o7e=b(W(),1),CB=` uniform vec4 shadowMap_cascadeDistances; float czm_cascadeDistance(vec4 weights) { return dot(shadowMap_cascadeDistances, weights); } -`;var s7e=R(W(),1),IB=` +`;var s7e=b(W(),1),IB=` uniform mat4 shadowMap_cascadeMatrices[4]; mat4 czm_cascadeMatrix(vec4 weights) @@ -1133,7 +1133,7 @@ mat4 czm_cascadeMatrix(vec4 weights) shadowMap_cascadeMatrices[2] * weights.z + shadowMap_cascadeMatrices[3] * weights.w; } -`;var r7e=R(W(),1),NB=` +`;var r7e=b(W(),1),NB=` uniform vec4 shadowMap_cascadeSplits[2]; vec4 czm_cascadeWeights(float depthEye) @@ -1143,7 +1143,7 @@ vec4 czm_cascadeWeights(float depthEye) vec4 far = step(depthEye, shadowMap_cascadeSplits[1]); return near * far; } -`;var c7e=R(W(),1),yB=`float getSignedDistance(vec2 uv, highp sampler2D clippingDistance) { +`;var c7e=b(W(),1),yB=`float getSignedDistance(vec2 uv, highp sampler2D clippingDistance) { float signedDistance = texture(clippingDistance, uv).r; return (signedDistance - 0.5) * 2.0; } @@ -1180,7 +1180,7 @@ void czm_clipPolygons(highp sampler2D clippingDistance, int extentsLength, vec2 } #endif } -`;var h7e=R(W(),1),BB=`/** +`;var h7e=b(W(),1),BB=`/** * DOC_TBA * * @name czm_columbusViewMorph @@ -1192,7 +1192,7 @@ vec4 czm_columbusViewMorph(vec4 position2D, vec4 position3D, float time) vec3 p = mix(position2D.xyz, position3D.xyz, time); return vec4(p, 1.0); } -`;var u7e=R(W(),1),QB=`/** +`;var V7e=b(W(),1),QB=`/** * Compute the atmosphere color, applying Rayleigh and Mie scattering. This * builtin uses automatic uniforms so the atmophere settings are synced with the * state of the Scene, even in other contexts like Model. @@ -1236,7 +1236,7 @@ vec4 czm_computeAtmosphereColor( return vec4(color, opacity); } -`;var V7e=R(W(),1),kB=`/** +`;var Z7e=b(W(),1),kB=`/** * Compute atmosphere scattering for the ground atmosphere and fog. This method * uses automatic uniforms so it is always synced with the scene settings. * @@ -1266,7 +1266,7 @@ void czm_computeGroundAtmosphereScattering(vec3 positionWC, vec3 lightDirection, opacity ); } -`;var R7e=R(W(),1),YB=`/** +`;var b7e=b(W(),1),YB=`/** * Returns a position in model coordinates relative to eye taking into * account the current scene mode: 3D, 2D, or Columbus view. *

@@ -1288,7 +1288,7 @@ void czm_computeGroundAtmosphereScattering(vec3 positionWC, vec3 lightDirection, * @see czm_translateRelativeToEye */ vec4 czm_computePosition(); -`;var f7e=R(W(),1),xB=`/** +`;var f7e=b(W(),1),xB=`/** * This function computes the colors contributed by Rayliegh and Mie scattering on a given ray, as well as * the transmittance value for the ray. This function uses automatic uniforms * so the atmosphere settings are always synced with the current scene. @@ -1438,7 +1438,7 @@ void czm_computeScattering( // Compute the transmittance i.e. how much light is passing through the atmosphere. opacity = length(exp(-((czm_atmosphereMieCoefficient * opticalDepth.y) + (czm_atmosphereRayleighCoefficient * opticalDepth.x)))); } -`;var U7e=R(W(),1),XB=`/** +`;var U7e=b(W(),1),XB=`/** * @private */ vec2 cordic(float angle) @@ -1649,7 +1649,7 @@ vec2 czm_cosineAndSine(float angle) return cordic(angle); } } -`;var A7e=R(W(),1),JB=`/** +`;var A7e=b(W(),1),JB=`/** * Decompresses texture coordinates that were packed into a single float. * * @name czm_decompressTextureCoordinates @@ -1666,7 +1666,7 @@ vec2 czm_cosineAndSine(float angle) float sty = (encoded - xZeroTo4095 * 4096.0) / 4095.0; return vec2(stx, sty); } -`;var S7e=R(W(),1),LB=`/** +`;var T7e=b(W(),1),LB=`/** * Get default parameters for physically based rendering. These defaults * describe a rough dielectric (non-metal) surface (e.g. rough plastic). * @@ -1682,7 +1682,7 @@ czm_pbrParameters czm_defaultPbrMaterial() results.f0 = REFLECTANCE_DIELECTRIC; return results; } -`;var E7e=R(W(),1),MB=`// emulated noperspective +`;var E7e=b(W(),1),MB=`// emulated noperspective #if (__VERSION__ == 300 || defined(GL_EXT_frag_depth)) && !defined(LOG_DEPTH) out float v_WindowZ; #endif @@ -1729,7 +1729,7 @@ vec4 czm_depthClamp(vec4 coords) #endif return coords; } -`;var I7e=R(W(),1),_B=`/** +`;var I7e=b(W(),1),_B=`/** * Computes a 3x3 rotation matrix that transforms vectors from an ellipsoid's east-north-up coordinate system * to eye coordinates. In east-north-up coordinates, x points east, y points north, and z points along the * surface normal. East-north-up can be used as an ellipsoid's tangent space for operations such as bump mapping. @@ -1762,7 +1762,7 @@ mat3 czm_eastNorthUpToEyeCoordinates(vec3 positionMC, vec3 normalEC) bitangentEC.x, bitangentEC.y, bitangentEC.z, normalEC.x, normalEC.y, normalEC.z); } -`;var y7e=R(W(),1),DB=`/** +`;var y7e=b(W(),1),DB=`/** * DOC_TBA * * @name czm_ellipsoidContainsPoint @@ -1774,7 +1774,7 @@ bool czm_ellipsoidContainsPoint(vec3 ellipsoid_inverseRadii, vec3 point) vec3 scaled = ellipsoid_inverseRadii * (czm_inverseModelView * vec4(point, 1.0)).xyz; return (dot(scaled, scaled) <= 1.0); } -`;var Q7e=R(W(),1),OB=`/** +`;var Q7e=b(W(),1),OB=`/** * DOC_TBA * * @name czm_ellipsoidWgs84TextureCoordinates @@ -1784,7 +1784,7 @@ vec2 czm_ellipsoidWgs84TextureCoordinates(vec3 normal) { return vec2(atan(normal.y, normal.x) * czm_oneOverTwoPi + 0.5, asin(normal.z) * czm_oneOverPi + 0.5); } -`;var Y7e=R(W(),1),HB=`/** +`;var Y7e=b(W(),1),HB=`/** * Compares left and right componentwise. Returns true * if they are within epsilon and false otherwise. The inputs * left and right can be floats, vec2s, @@ -1820,7 +1820,7 @@ bool czm_equalsEpsilon(vec2 left, vec2 right, float epsilon) { bool czm_equalsEpsilon(float left, float right, float epsilon) { return (abs(left - right) <= epsilon); } -`;var X7e=R(W(),1),wB=`/** +`;var X7e=b(W(),1),wB=`/** * DOC_TBA * * @name czm_eyeOffset @@ -1840,7 +1840,7 @@ vec4 czm_eyeOffset(vec4 positionEC, vec3 eyeOffset) p.z += zEyeOffset.z; return p; } -`;var L7e=R(W(),1),PB=`/** +`;var L7e=b(W(),1),PB=`/** * Transforms a position from eye to window coordinates. The transformation * from eye to clip coordinates is done using {@link czm_projection}. * The transform from normalized device coordinates to window coordinates is @@ -1872,7 +1872,7 @@ vec4 czm_eyeToWindowCoordinates(vec4 positionEC) q.xyz = (czm_viewportTransformation * vec4(q.xyz, 1.0)).xyz; // window coordinates return q; } -`;var _7e=R(W(),1),vB=`/** +`;var _7e=b(W(),1),vB=`/** * Approxiamtes atan over the range [0, 1]. Safe to flip output for negative input. * * Based on Michal Drobot's approximation from ShaderFastLibs, which in turn is based on @@ -1927,7 +1927,7 @@ float czm_fastApproximateAtan(float x, float y) { t = czm_branchFreeTernary(y < 0.0, -t, t); return t; } -`;var O7e=R(W(),1),KB=`/** +`;var O7e=b(W(),1),KB=`/** * Gets the color with fog at a distance from the camera. * * @name czm_fog @@ -1965,7 +1965,7 @@ vec3 czm_fog(float distanceToCamera, vec3 color, vec3 fogColor, float fogModifie float fog = 1.0 - exp(-((fogModifierConstant * scalar + fogModifierConstant) * (scalar * (1.0 + fogModifierConstant)))); return mix(color, fogColor, fog); } -`;var w7e=R(W(),1),zB=`/** +`;var w7e=b(W(),1),zB=`/** * Converts a color from RGB space to linear space. * * @name czm_gammaCorrect @@ -1987,7 +1987,7 @@ vec4 czm_gammaCorrect(vec4 color) { #endif return color; } -`;var v7e=R(W(),1),jB=`/** +`;var v7e=b(W(),1),jB=`/** * DOC_TBA * * @name czm_geodeticSurfaceNormal @@ -2003,7 +2003,7 @@ vec3 czm_geodeticSurfaceNormal(vec3 positionOnEllipsoid, vec3 ellipsoidCenter, v { return normalize((positionOnEllipsoid - ellipsoidCenter) * oneOverEllipsoidRadiiSquared); } -`;var z7e=R(W(),1),qB=`/** +`;var z7e=b(W(),1),qB=`/** * An czm_material with default values. Every material's czm_getMaterial * should use this default material as a base for the material it returns. * The default normal value is given by materialInput.normalEC. @@ -2030,7 +2030,7 @@ czm_material czm_getDefaultMaterial(czm_materialInput materialInput) material.alpha = 1.0; return material; } -`;var q7e=R(W(),1),$B=`/** +`;var q7e=b(W(),1),$B=`/** * Select which direction vector to use for dynamic atmosphere lighting based on an enum value * * @name czm_getDynamicAtmosphereLightDirection @@ -2052,7 +2052,7 @@ vec3 czm_getDynamicAtmosphereLightDirection(vec3 positionWC, float lightEnum) { czm_sunDirectionWC * float(lightEnum == SUNLIGHT); return normalize(lightDirection); } -`;var tqe=R(W(),1),tQ=`/** +`;var tqe=b(W(),1),tQ=`/** * Calculates the intensity of diffusely reflected light. * * @name czm_getLambertDiffuse @@ -2074,7 +2074,7 @@ float czm_getLambertDiffuse(vec3 lightDirectionEC, vec3 normalEC) { return max(dot(lightDirectionEC, normalEC), 0.0); } -`;var nqe=R(W(),1),eQ=`/** +`;var nqe=b(W(),1),eQ=`/** * Calculates the specular intensity of reflected light. * * @name czm_getSpecular @@ -2103,7 +2103,7 @@ float czm_getSpecular(vec3 lightDirectionEC, vec3 toEyeEC, vec3 normalEC, float // Prevent this by making sure shininess is at least czm_epsilon2. return pow(specular, max(shininess, czm_epsilon2)); } -`;var oqe=R(W(),1),nQ=`/** +`;var oqe=b(W(),1),nQ=`/** * @private */ vec4 czm_getWaterNoise(sampler2D normalMap, vec2 uv, float time, float angleInRadians) @@ -2140,7 +2140,7 @@ vec4 czm_getWaterNoise(sampler2D normalMap, vec2 uv, float time, float angleInRa // average and scale to between -1 and 1 return ((noise / 4.0) - 0.5) * 2.0; } -`;var sqe=R(W(),1),iQ=`/** +`;var sqe=b(W(),1),iQ=`/** * Adjusts the hue of a color. * * @name czm_hue @@ -2170,7 +2170,7 @@ vec3 czm_hue(vec3 rgb, float adjustment) vec3 color = vec3(yiq.x, chroma * cos(hue), chroma * sin(hue)); return toRGB * color; } -`;var rqe=R(W(),1),oQ=`/** +`;var rqe=b(W(),1),oQ=`/** * Converts a color in linear space to RGB space. * * @name czm_inverseGamma @@ -2182,7 +2182,7 @@ vec3 czm_hue(vec3 rgb, float adjustment) vec3 czm_inverseGamma(vec3 color) { return pow(color, vec3(1.0 / czm_gamma)); } -`;var cqe=R(W(),1),aQ=`/** +`;var cqe=b(W(),1),aQ=`/** * Determines if a time interval is empty. * * @name czm_isEmpty @@ -2201,7 +2201,7 @@ bool czm_isEmpty(czm_raySegment interval) { return (interval.stop < 0.0); } -`;var hqe=R(W(),1),sQ=`/** +`;var hqe=b(W(),1),sQ=`/** * Determines if a time interval is empty. * * @name czm_isFull @@ -2220,7 +2220,7 @@ bool czm_isFull(czm_raySegment interval) { return (interval.start == 0.0 && interval.stop == czm_infinity); } -`;var uqe=R(W(),1),lQ=`/** +`;var Vqe=b(W(),1),lQ=`/** * Computes the fraction of a Web Wercator rectangle at which a given geodetic latitude is located. * * @name czm_latitudeToWebMercatorFraction @@ -2241,7 +2241,7 @@ float czm_latitudeToWebMercatorFraction(float latitude, float southMercatorY, fl return (mercatorY - southMercatorY) * oneOverMercatorHeight; } -`;var Vqe=R(W(),1),rQ=`/** +`;var Zqe=b(W(),1),rQ=`/** * Computes distance from an point in 2D to a line in 2D. * * @name czm_lineDistance @@ -2255,7 +2255,7 @@ float czm_latitudeToWebMercatorFraction(float latitude, float southMercatorY, fl float czm_lineDistance(vec2 point1, vec2 point2, vec2 point) { return abs((point2.y - point1.y) * point.x - (point2.x - point1.x) * point.y + point2.x * point1.y - point2.y * point1.x) / distance(point2, point1); } -`;var Rqe=R(W(),1),dQ=`/** +`;var bqe=b(W(),1),dQ=`/** * Converts a linear RGB color to an sRGB color. * * @param {vec3|vec4} linearIn The color in linear color space. @@ -2271,7 +2271,7 @@ vec4 czm_linearToSrgb(vec4 linearIn) vec3 srgbOut = pow(linearIn.rgb, vec3(1.0/2.2)); return vec4(srgbOut, linearIn.a); } -`;var fqe=R(W(),1),cQ=`/** +`;var fqe=b(W(),1),cQ=`/** * Computes the luminance of a color. * * @name czm_luminance @@ -2291,7 +2291,7 @@ float czm_luminance(vec3 rgb) const vec3 W = vec3(0.2125, 0.7154, 0.0721); return dot(rgb, W); } -`;var Uqe=R(W(),1),mQ=`/** +`;var Uqe=b(W(),1),mQ=`/** * Computes the size of a pixel in meters at a distance from the eye. *

* Use this version when passing in a custom pixel ratio. For example, passing in 1.0 will return meters per native device pixel. @@ -2352,7 +2352,7 @@ float czm_metersPerPixel(vec4 positionEC) { return czm_metersPerPixel(positionEC, czm_pixelRatio); } -`;var Aqe=R(W(),1),hQ=`/** +`;var Aqe=b(W(),1),hQ=`/** * Transforms a position from model to window coordinates. The transformation * from model to clip coordinates is done using {@link czm_modelViewProjection}. * The transform from normalized device coordinates to window coordinates is @@ -2389,7 +2389,7 @@ vec4 czm_modelToWindowCoordinates(vec4 position) q.xyz = (czm_viewportTransformation * vec4(q.xyz, 1.0)).xyz; // window coordinates return q; } -`;var Sqe=R(W(),1),pQ=`/** +`;var Tqe=b(W(),1),pQ=`/** * DOC_TBA * * @name czm_multiplyWithColorBalance @@ -2407,7 +2407,7 @@ vec3 czm_multiplyWithColorBalance(vec3 left, vec3 right) return ((leftLuminance + rightLuminance) / (2.0 * targetLuminance)) * target; } -`;var Eqe=R(W(),1),uQ=`/** +`;var Eqe=b(W(),1),VQ=`/** * Computes a value that scales with distance. The scaling is clamped at the near and * far distances, and does not extrapolate. This function works with the * {@link NearFarScalar} JavaScript class. @@ -2433,7 +2433,7 @@ float czm_nearFarScalar(vec4 nearFarScalar, float cameraDistSq) return mix(valueAtMin, valueAtMax, t); } -`;var Iqe=R(W(),1),ZQ=` /** +`;var Iqe=b(W(),1),uQ=` /** * Decodes a unit-length vector in 'oct' encoding to a normalized 3-component Cartesian vector. * The 'oct' encoding is described in "A Survey of Efficient Representations of Independent Unit Vectors", * Cigolle et al 2014: http://jcgt.org/published/0003/02/01/ @@ -2516,7 +2516,7 @@ float czm_nearFarScalar(vec4 nearFarScalar, float cameraDistSq) vector3 = czm_octDecode(vec2(x, y)); } -`;var yqe=R(W(),1),VQ=`/** +`;var yqe=b(W(),1),ZQ=`/** * Packs a depth value into a vec3 that can be represented by unsigned bytes. * * @name czm_packDepth @@ -2534,7 +2534,7 @@ vec4 czm_packDepth(float depth) enc -= enc.yzww * vec4(1.0 / 255.0, 1.0 / 255.0, 1.0 / 255.0, 0.0); return enc; } -`;var Qqe=R(W(),1),bQ=`vec3 lambertianDiffuse(vec3 diffuseColor) +`;var Qqe=b(W(),1),RQ=`vec3 lambertianDiffuse(vec3 diffuseColor) { return diffuseColor / czm_pi; } @@ -2633,7 +2633,7 @@ vec3 czm_pbrLighting( // Lo = (diffuse + specular) * Li * NdotL return (diffuseContribution + specularContribution) * NdotL * lightColorHdr; } -`;var Yqe=R(W(),1),RQ=`/** +`;var Yqe=b(W(),1),bQ=`/** * Compute parameters for physically based rendering using the * metallic/roughness workflow. All inputs are linear; sRGB texture values must * be decoded beforehand @@ -2670,7 +2670,7 @@ czm_pbrParameters czm_pbrMetallicRoughnessMaterial( return results; } -`;var Xqe=R(W(),1),WQ=`/** +`;var Xqe=b(W(),1),WQ=`/** * Compute parameters for physically based rendering using the * specular/glossy workflow. All inputs are linear; sRGB texture values must * be decoded beforehand @@ -2700,7 +2700,7 @@ czm_pbrParameters czm_pbrSpecularGlossinessMaterial( return results; } -`;var Lqe=R(W(),1),fQ=`float czm_private_getLambertDiffuseOfMaterial(vec3 lightDirectionEC, czm_material material) +`;var Lqe=b(W(),1),fQ=`float czm_private_getLambertDiffuseOfMaterial(vec3 lightDirectionEC, czm_material material) { return czm_getLambertDiffuse(lightDirectionEC, material.normal); } @@ -2763,7 +2763,7 @@ vec4 czm_private_phong(vec3 toEye, czm_material material, vec3 lightDirectionEC) return vec4(color, material.alpha); } -`;var _qe=R(W(),1),FQ=`/** +`;var _qe=b(W(),1),FQ=`/** * Computes distance from a point to a plane. * * @name czm_planeDistance @@ -2791,7 +2791,7 @@ float czm_planeDistance(vec4 plane, vec3 point) { float czm_planeDistance(vec3 planeNormal, float planeDistance, vec3 point) { return (dot(planeNormal, point) + planeDistance); } -`;var Oqe=R(W(),1),UQ=`/** +`;var Oqe=b(W(),1),UQ=`/** * Computes the point along a ray at the given time. time can be positive, negative, or zero. * * @name czm_pointAlongRay @@ -2810,7 +2810,7 @@ vec3 czm_pointAlongRay(czm_ray ray, float time) { return ray.origin + (time * ray.direction); } -`;var wqe=R(W(),1),GQ=`/** +`;var wqe=b(W(),1),GQ=`/** * DOC_TBA * * @name czm_rayEllipsoidIntersectionInterval @@ -2893,7 +2893,7 @@ czm_raySegment czm_rayEllipsoidIntersectionInterval(czm_ray ray, vec3 ellipsoid_ } } } -`;var vqe=R(W(),1),AQ=`/** +`;var vqe=b(W(),1),AQ=`/** * Compute the intersection interval of a ray with a sphere. * * @name czm_raySphereIntersectionInterval @@ -2929,11 +2929,11 @@ czm_raySegment czm_raySphereIntersectionInterval(czm_ray ray, vec3 center, float czm_raySegment result = czm_raySegment(t0, t1); return result; } -`;var zqe=R(W(),1),TQ=`float czm_readDepth(sampler2D depthTexture, vec2 texCoords) +`;var zqe=b(W(),1),SQ=`float czm_readDepth(sampler2D depthTexture, vec2 texCoords) { return czm_reverseLogDepth(texture(depthTexture, texCoords).r); } -`;var qqe=R(W(),1),SQ=`/** +`;var qqe=b(W(),1),TQ=`/** * Reads a value previously transformed with {@link czm_writeNonPerspective} * by dividing it by \`w\`, the value used in the perspective divide. * This function is intended to be called in a fragment shader to access a @@ -2964,7 +2964,7 @@ vec3 czm_readNonPerspective(vec3 value, float oneOverW) { vec4 czm_readNonPerspective(vec4 value, float oneOverW) { return value * oneOverW; } -`;var t$e=R(W(),1),gQ=`float czm_reverseLogDepth(float logZ) +`;var t$e=b(W(),1),gQ=`float czm_reverseLogDepth(float logZ) { #ifdef LOG_DEPTH float near = czm_currentFrustum.x; @@ -2975,7 +2975,7 @@ vec4 czm_readNonPerspective(vec4 value, float oneOverW) { #endif return logZ; } -`;var n$e=R(W(),1),EQ=`/** +`;var n$e=b(W(),1),EQ=`/** * Round a floating point value. This function exists because round() doesn't * exist in GLSL 1.00. * @@ -2997,7 +2997,7 @@ vec3 czm_round(vec3 value) { vec4 czm_round(vec4 value) { return floor(value + 0.5); } -`;var o$e=R(W(),1),CQ=`/** +`;var o$e=b(W(),1),CQ=`/** * Samples the 4 neighboring pixels and return the weighted average. * * @private @@ -3075,7 +3075,7 @@ vec3 czm_sampleOctahedralProjection(sampler2D projectedMap, vec2 textureSize, ve return mix(colorNextLod, colorCurrentLod, nextLod - lod); } -`;var s$e=R(W(),1),IQ=`/** +`;var s$e=b(W(),1),IQ=`/** * Adjusts the saturation of a color. * * @name czm_saturation @@ -3097,7 +3097,7 @@ vec3 czm_saturation(vec3 rgb, float adjustment) vec3 intensity = vec3(dot(rgb, W)); return mix(intensity, rgb, adjustment); } -`;var r$e=R(W(),1),NQ=` +`;var r$e=b(W(),1),NQ=` float czm_sampleShadowMap(highp samplerCube shadowMap, vec3 d) { return czm_unpackDepth(czm_textureCube(shadowMap, d)); @@ -3121,7 +3121,7 @@ float czm_shadowDepthCompare(sampler2D shadowMap, vec2 uv, float depth) { return step(depth, czm_sampleShadowMap(shadowMap, uv)); } -`;var c$e=R(W(),1),yQ=` +`;var c$e=b(W(),1),yQ=` float czm_private_shadowVisibility(float visibility, float nDotL, float normalShadingSmooth, float darkness) { #ifdef USE_NORMAL_SHADING @@ -3187,7 +3187,7 @@ float czm_shadowVisibility(sampler2D shadowMap, czm_shadowParameters shadowParam return czm_private_shadowVisibility(visibility, nDotL, normalShadingSmooth, darkness); } #endif -`;var h$e=R(W(),1),BQ=`/** +`;var h$e=b(W(),1),BQ=`/** * Returns 1.0 if the given value is positive or zero, and -1.0 if it is negative. This is similar to the GLSL * built-in function sign except that returns 1.0 instead of 0.0 when the input value is 0.0. * @@ -3216,7 +3216,7 @@ vec4 czm_signNotZero(vec4 value) { return vec4(czm_signNotZero(value.x), czm_signNotZero(value.y), czm_signNotZero(value.z), czm_signNotZero(value.w)); } -`;var u$e=R(W(),1),QQ=`/** +`;var V$e=b(W(),1),QQ=`/** * Computes a color from the third order spherical harmonic coefficients and a normalized direction vector. *

* The order of the coefficients is [L00, L1_1, L10, L11, L2_2, L2_1, L20, L21, L22]. @@ -3258,7 +3258,7 @@ vec3 czm_sphericalHarmonics(vec3 normal, vec3 coefficients[9]) + L21 * (z * x) + L22 * (x * x - y * y); } -`;var V$e=R(W(),1),kQ=`/** +`;var Z$e=b(W(),1),kQ=`/** * Converts an sRGB color to a linear RGB color. * * @param {vec3|vec4} srgbIn The color in sRGB space @@ -3274,7 +3274,7 @@ vec4 czm_srgbToLinear(vec4 srgbIn) vec3 linearOut = pow(srgbIn.rgb, vec3(2.2)); return vec4(linearOut, srgbIn.a); } -`;var R$e=R(W(),1),YQ=`/** +`;var b$e=b(W(),1),YQ=`/** * Creates a matrix that transforms vectors from tangent space to eye space. * * @name czm_tangentToEyeSpaceMatrix @@ -3299,7 +3299,7 @@ mat3 czm_tangentToEyeSpaceMatrix(vec3 normalEC, vec3 tangentEC, vec3 bitangentEC bitangent.x, bitangent.y, bitangent.z, normal.x , normal.y , normal.z); } -`;var f$e=R(W(),1),xQ=`/** +`;var f$e=b(W(),1),xQ=`/** * A wrapper around the texture (WebGL2) / textureCube (WebGL1) * function to allow for WebGL 1 support. * @@ -3315,7 +3315,7 @@ vec4 czm_textureCube(samplerCube sampler, vec3 p) { #else return textureCube(sampler, p); #endif -}`;var U$e=R(W(),1),XQ=`/** +}`;var U$e=b(W(),1),XQ=`/** * Transforms a plane. * * @name czm_transformPlane @@ -3330,7 +3330,7 @@ vec4 czm_transformPlane(vec4 plane, mat4 transform) { float normalMagnitude = length(transformedPlane.xyz); return transformedPlane / normalMagnitude; } -`;var A$e=R(W(),1),JQ=`/** +`;var A$e=b(W(),1),JQ=`/** * Translates a position (or any vec3) that was encoded with {@link EncodedCartesian3}, * and then provided to the shader as separate high and low bits to * be relative to the eye. As shown in the example, the position can then be transformed in eye @@ -3375,7 +3375,7 @@ vec4 czm_translateRelativeToEye(vec3 high, vec3 low) return vec4(highDifference + lowDifference, 1.0); } -`;var S$e=R(W(),1),LQ=`/** +`;var T$e=b(W(),1),LQ=`/** * @private */ vec4 czm_translucentPhong(vec3 toEye, czm_material material, vec3 lightDirectionEC) @@ -3402,7 +3402,7 @@ vec4 czm_translucentPhong(vec3 toEye, czm_material material, vec3 lightDirection return vec4(color, material.alpha); } -`;var E$e=R(W(),1),MQ=`/** +`;var E$e=b(W(),1),MQ=`/** * Returns the transpose of the matrix. The input matrix can be * a mat2, mat3, or mat4. * @@ -3447,7 +3447,7 @@ mat4 czm_transpose(mat4 matrix) matrix[0][2], matrix[1][2], matrix[2][2], matrix[3][2], matrix[0][3], matrix[1][3], matrix[2][3], matrix[3][3]); } -`;var I$e=R(W(),1),_Q=`vec2 getLookupUv(vec2 dimensions, int i) { +`;var I$e=b(W(),1),_Q=`vec2 getLookupUv(vec2 dimensions, int i) { int pixY = i / int(dimensions.x); int pixX = i - (pixY * int(dimensions.x)); float pixelWidth = 1.0 / dimensions.x; @@ -3460,7 +3460,7 @@ mat4 czm_transpose(mat4 matrix) vec4 czm_unpackClippingExtents(highp sampler2D extentsTexture, int index) { vec2 textureDimensions = vec2(textureSize(extentsTexture, 0)); return texture(extentsTexture, getLookupUv(textureDimensions, index)); -}`;var y$e=R(W(),1),DQ=`/** +}`;var y$e=b(W(),1),DQ=`/** * Unpacks a vec4 depth value to a float in [0, 1) range. * * @name czm_unpackDepth @@ -3476,7 +3476,7 @@ vec4 czm_unpackClippingExtents(highp sampler2D extentsTexture, int index) { // http://aras-p.info/blog/2009/07/30/encoding-floats-to-rgba-the-final/ return dot(packedDepth, vec4(1.0, 1.0 / 255.0, 1.0 / 65025.0, 1.0 / 16581375.0)); } -`;var Q$e=R(W(),1),OQ=`/** +`;var Q$e=b(W(),1),OQ=`/** * Unpack an IEEE 754 single-precision float that is packed as a little-endian unsigned normalized vec4. * * @name czm_unpackFloat @@ -3500,7 +3500,7 @@ float czm_unpackFloat(vec4 packedFloat) float result = sign * exp2(exponent - 23.0) * mantissa; return result; } -`;var Y$e=R(W(),1),HQ=`/** +`;var Y$e=b(W(),1),HQ=`/** * Unpack unsigned integers of 1-4 bytes. in WebGL 1, there is no uint type, * so the return value is an int. *

@@ -3531,7 +3531,7 @@ float czm_unpackFloat(vec4 packedFloat) vec4 rounded = czm_round(packedValue * 255.0); return int(dot(rounded, vec4(1.0, 256.0, 65536.0, 16777216.0))); } -`;var X$e=R(W(),1),wQ=`/** +`;var X$e=b(W(),1),wQ=`/** * Transform metadata values following the EXT_structural_metadata spec * by multiplying by scale and adding the offset. Operations are always * performed component-wise, even for matrices. @@ -3569,7 +3569,7 @@ mat3 czm_valueTransform(mat3 offset, mat3 scale, mat3 value) { mat4 czm_valueTransform(mat4 offset, mat4 scale, mat4 value) { return matrixCompMult(scale, value) + offset; } -`;var L$e=R(W(),1),PQ=`#ifdef LOG_DEPTH +`;var L$e=b(W(),1),PQ=`#ifdef LOG_DEPTH // 1.0 at the near plane, increasing linearly from there. out float v_depthFromNearPlusOne; #ifdef SHADOW_MAP @@ -3633,7 +3633,7 @@ void czm_vertexLogDepth(vec4 clipCoords) czm_updatePositionDepth(clipCoords); #endif } -`;var _$e=R(W(),1),vQ=`vec4 czm_screenToEyeCoordinates(vec4 screenCoordinate) +`;var _$e=b(W(),1),vQ=`vec4 czm_screenToEyeCoordinates(vec4 screenCoordinate) { // Reconstruct NDC coordinates float x = 2.0 * screenCoordinate.x - 1.0; @@ -3744,7 +3744,7 @@ vec4 czm_windowToEyeCoordinates(vec2 fragmentCoordinateXY, float depthOrLogDepth vec2 screenCoordXY = (fragmentCoordinateXY.xy - czm_viewport.xy) / czm_viewport.zw; return czm_screenToEyeCoordinates(screenCoordXY, depthOrLogDepth); } -`;var O$e=R(W(),1),KQ=`// emulated noperspective +`;var O$e=b(W(),1),KQ=`// emulated noperspective #if !defined(LOG_DEPTH) in float v_WindowZ; #endif @@ -3768,7 +3768,7 @@ void czm_writeDepthClamp() gl_FragDepth = clamp(v_WindowZ * gl_FragCoord.w, 0.0, 1.0); #endif } -`;var w$e=R(W(),1),zQ=`#ifdef LOG_DEPTH +`;var w$e=b(W(),1),zQ=`#ifdef LOG_DEPTH in float v_depthFromNearPlusOne; #ifdef POLYGON_OFFSET @@ -3847,7 +3847,7 @@ void czm_writeLogDepth() { czm_writeLogDepth(v_depthFromNearPlusOne); #endif } -`;var v$e=R(W(),1),jQ=`/** +`;var v$e=b(W(),1),jQ=`/** * Transforms a value for non-perspective interpolation by multiplying * it by w, the value used in the perspective divide. This function is * intended to be called in a vertex shader to compute the value of a @@ -3879,7 +3879,7 @@ vec3 czm_writeNonPerspective(vec3 value, float w) { vec4 czm_writeNonPerspective(vec4 value, float w) { return value * w; } -`;var TG={czm_degreesPerRadian:Fy,czm_depthRange:Uy,czm_epsilon1:Gy,czm_epsilon2:Ay,czm_epsilon3:Ty,czm_epsilon4:Sy,czm_epsilon5:gy,czm_epsilon6:Ey,czm_epsilon7:Cy,czm_infinity:Iy,czm_oneOverPi:Ny,czm_oneOverTwoPi:yy,czm_passCesium3DTile:By,czm_passCesium3DTileClassification:Qy,czm_passCesium3DTileClassificationIgnoreShow:ky,czm_passClassification:Yy,czm_passCompute:xy,czm_passEnvironment:Xy,czm_passGlobe:Jy,czm_passOpaque:Ly,czm_passOverlay:My,czm_passTerrainClassification:_y,czm_passTranslucent:Dy,czm_passVoxels:Oy,czm_pi:Hy,czm_piOverFour:wy,czm_piOverSix:Py,czm_piOverThree:vy,czm_piOverTwo:Ky,czm_radiansPerDegree:zy,czm_sceneMode2D:jy,czm_sceneMode3D:qy,czm_sceneModeColumbusView:$y,czm_sceneModeMorphing:tB,czm_solarRadius:eB,czm_threePiOver2:nB,czm_twoPi:iB,czm_webMercatorMaxLatitude:oB,czm_depthRangeStruct:aB,czm_material:sB,czm_materialInput:lB,czm_modelMaterial:rB,czm_modelVertexOutput:dB,czm_pbrParameters:cB,czm_ray:mB,czm_raySegment:hB,czm_shadowParameters:pB,czm_HSBToRGB:uB,czm_HSLToRGB:ZB,czm_RGBToHSB:VB,czm_RGBToHSL:bB,czm_RGBToXYZ:RB,czm_XYZToRGB:WB,czm_acesTonemapping:fB,czm_alphaWeight:FB,czm_antialias:UB,czm_applyHSBShift:GB,czm_approximateSphericalCoordinates:AB,czm_approximateTanh:TB,czm_backFacing:SB,czm_branchFreeTernary:gB,czm_cascadeColor:EB,czm_cascadeDistance:CB,czm_cascadeMatrix:IB,czm_cascadeWeights:NB,czm_clipPolygons:yB,czm_columbusViewMorph:BB,czm_computeAtmosphereColor:QB,czm_computeGroundAtmosphereScattering:kB,czm_computePosition:YB,czm_computeScattering:xB,czm_cosineAndSine:XB,czm_decompressTextureCoordinates:JB,czm_defaultPbrMaterial:LB,czm_depthClamp:MB,czm_eastNorthUpToEyeCoordinates:_B,czm_ellipsoidContainsPoint:DB,czm_ellipsoidWgs84TextureCoordinates:OB,czm_equalsEpsilon:HB,czm_eyeOffset:wB,czm_eyeToWindowCoordinates:PB,czm_fastApproximateAtan:vB,czm_fog:KB,czm_gammaCorrect:zB,czm_geodeticSurfaceNormal:jB,czm_getDefaultMaterial:qB,czm_getDynamicAtmosphereLightDirection:$B,czm_getLambertDiffuse:tQ,czm_getSpecular:eQ,czm_getWaterNoise:nQ,czm_hue:iQ,czm_inverseGamma:oQ,czm_isEmpty:aQ,czm_isFull:sQ,czm_latitudeToWebMercatorFraction:lQ,czm_lineDistance:rQ,czm_linearToSrgb:dQ,czm_luminance:cQ,czm_metersPerPixel:mQ,czm_modelToWindowCoordinates:hQ,czm_multiplyWithColorBalance:pQ,czm_nearFarScalar:uQ,czm_octDecode:ZQ,czm_packDepth:VQ,czm_pbrLighting:bQ,czm_pbrMetallicRoughnessMaterial:RQ,czm_pbrSpecularGlossinessMaterial:WQ,czm_phong:fQ,czm_planeDistance:FQ,czm_pointAlongRay:UQ,czm_rayEllipsoidIntersectionInterval:GQ,czm_raySphereIntersectionInterval:AQ,czm_readDepth:TQ,czm_readNonPerspective:SQ,czm_reverseLogDepth:gQ,czm_round:EQ,czm_sampleOctahedralProjection:CQ,czm_saturation:IQ,czm_shadowDepthCompare:NQ,czm_shadowVisibility:yQ,czm_signNotZero:BQ,czm_sphericalHarmonics:QQ,czm_srgbToLinear:kQ,czm_tangentToEyeSpaceMatrix:YQ,czm_textureCube:xQ,czm_transformPlane:XQ,czm_translateRelativeToEye:JQ,czm_translucentPhong:LQ,czm_transpose:MQ,czm_unpackClippingExtents:_Q,czm_unpackDepth:DQ,czm_unpackFloat:OQ,czm_unpackUint:HQ,czm_valueTransform:wQ,czm_vertexLogDepth:PQ,czm_windowToEyeCoordinates:vQ,czm_writeDepthClamp:KQ,czm_writeLogDepth:zQ,czm_writeNonPerspective:jQ};var Cnn=R(W(),1);function mDt(t,e){let n=t;return n=n.replaceAll("version 300 es",""),n=n.replaceAll(/(texture\()/g,"texture2D("),e?(n=n.replaceAll(/\n\s*(in)\s+(vec\d|mat\d|float)/g,` +`;var SG={czm_degreesPerRadian:Fy,czm_depthRange:Uy,czm_epsilon1:Gy,czm_epsilon2:Ay,czm_epsilon3:Sy,czm_epsilon4:Ty,czm_epsilon5:gy,czm_epsilon6:Ey,czm_epsilon7:Cy,czm_infinity:Iy,czm_oneOverPi:Ny,czm_oneOverTwoPi:yy,czm_passCesium3DTile:By,czm_passCesium3DTileClassification:Qy,czm_passCesium3DTileClassificationIgnoreShow:ky,czm_passClassification:Yy,czm_passCompute:xy,czm_passEnvironment:Xy,czm_passGlobe:Jy,czm_passOpaque:Ly,czm_passOverlay:My,czm_passTerrainClassification:_y,czm_passTranslucent:Dy,czm_passVoxels:Oy,czm_pi:Hy,czm_piOverFour:wy,czm_piOverSix:Py,czm_piOverThree:vy,czm_piOverTwo:Ky,czm_radiansPerDegree:zy,czm_sceneMode2D:jy,czm_sceneMode3D:qy,czm_sceneModeColumbusView:$y,czm_sceneModeMorphing:tB,czm_solarRadius:eB,czm_threePiOver2:nB,czm_twoPi:iB,czm_webMercatorMaxLatitude:oB,czm_depthRangeStruct:aB,czm_material:sB,czm_materialInput:lB,czm_modelMaterial:rB,czm_modelVertexOutput:dB,czm_pbrParameters:cB,czm_ray:mB,czm_raySegment:hB,czm_shadowParameters:pB,czm_HSBToRGB:VB,czm_HSLToRGB:uB,czm_RGBToHSB:ZB,czm_RGBToHSL:RB,czm_RGBToXYZ:bB,czm_XYZToRGB:WB,czm_acesTonemapping:fB,czm_alphaWeight:FB,czm_antialias:UB,czm_applyHSBShift:GB,czm_approximateSphericalCoordinates:AB,czm_approximateTanh:SB,czm_backFacing:TB,czm_branchFreeTernary:gB,czm_cascadeColor:EB,czm_cascadeDistance:CB,czm_cascadeMatrix:IB,czm_cascadeWeights:NB,czm_clipPolygons:yB,czm_columbusViewMorph:BB,czm_computeAtmosphereColor:QB,czm_computeGroundAtmosphereScattering:kB,czm_computePosition:YB,czm_computeScattering:xB,czm_cosineAndSine:XB,czm_decompressTextureCoordinates:JB,czm_defaultPbrMaterial:LB,czm_depthClamp:MB,czm_eastNorthUpToEyeCoordinates:_B,czm_ellipsoidContainsPoint:DB,czm_ellipsoidWgs84TextureCoordinates:OB,czm_equalsEpsilon:HB,czm_eyeOffset:wB,czm_eyeToWindowCoordinates:PB,czm_fastApproximateAtan:vB,czm_fog:KB,czm_gammaCorrect:zB,czm_geodeticSurfaceNormal:jB,czm_getDefaultMaterial:qB,czm_getDynamicAtmosphereLightDirection:$B,czm_getLambertDiffuse:tQ,czm_getSpecular:eQ,czm_getWaterNoise:nQ,czm_hue:iQ,czm_inverseGamma:oQ,czm_isEmpty:aQ,czm_isFull:sQ,czm_latitudeToWebMercatorFraction:lQ,czm_lineDistance:rQ,czm_linearToSrgb:dQ,czm_luminance:cQ,czm_metersPerPixel:mQ,czm_modelToWindowCoordinates:hQ,czm_multiplyWithColorBalance:pQ,czm_nearFarScalar:VQ,czm_octDecode:uQ,czm_packDepth:ZQ,czm_pbrLighting:RQ,czm_pbrMetallicRoughnessMaterial:bQ,czm_pbrSpecularGlossinessMaterial:WQ,czm_phong:fQ,czm_planeDistance:FQ,czm_pointAlongRay:UQ,czm_rayEllipsoidIntersectionInterval:GQ,czm_raySphereIntersectionInterval:AQ,czm_readDepth:SQ,czm_readNonPerspective:TQ,czm_reverseLogDepth:gQ,czm_round:EQ,czm_sampleOctahedralProjection:CQ,czm_saturation:IQ,czm_shadowDepthCompare:NQ,czm_shadowVisibility:yQ,czm_signNotZero:BQ,czm_sphericalHarmonics:QQ,czm_srgbToLinear:kQ,czm_tangentToEyeSpaceMatrix:YQ,czm_textureCube:xQ,czm_transformPlane:XQ,czm_translateRelativeToEye:JQ,czm_translucentPhong:LQ,czm_transpose:MQ,czm_unpackClippingExtents:_Q,czm_unpackDepth:DQ,czm_unpackFloat:OQ,czm_unpackUint:HQ,czm_valueTransform:wQ,czm_vertexLogDepth:PQ,czm_windowToEyeCoordinates:vQ,czm_writeDepthClamp:KQ,czm_writeLogDepth:zQ,czm_writeNonPerspective:jQ};var Cnn=b(W(),1);function mDt(t,e){let n=t;return n=n.replaceAll("version 300 es",""),n=n.replaceAll(/(texture\()/g,"texture2D("),e?(n=n.replaceAll(/\n\s*(in)\s+(vec\d|mat\d|float)/g,` varying $2`),/out_FragData_(\d+)/.test(n)&&(n=`#extension GL_EXT_draw_buffers : enable ${n}`,n=n.replaceAll(/layout\s+\(location\s*=\s*\d+\)\s*out\s+vec4\s+out_FragData_\d+;/g,""),n=n.replaceAll(/out_FragData_(\d+)/g,"gl_FragData[$1]")),n=n.replaceAll(/layout\s+\(location\s*=\s*0\)\s*out\s+vec4\s+out_FragColor;/g,""),n=n.replaceAll(/out_FragColor/g,"gl_FragColor"),n=n.replaceAll(/out_FragColor\[(\d+)\]/g,"gl_FragColor[$1]"),/gl_FragDepth/.test(n)&&(n=`#extension GL_EXT_frag_depth : enable ${n}`,n=n.replaceAll(/gl_FragDepth/g,"gl_FragDepthEXT")),n=`#ifdef GL_OES_standard_derivatives @@ -3887,12 +3887,12 @@ ${n}`,n=n.replaceAll(/gl_FragDepth/g,"gl_FragDepthEXT")),n=`#ifdef GL_OES_standa #endif ${n}`):(n=n.replaceAll(/(in)\s+(vec\d|mat\d|float)/g,"attribute $2"),n=n.replaceAll(/(out)\s+(vec\d|mat\d|float)\s+([\w]+);/g,"varying $2 $3;")),n=`#version 100 ${n}`,n}var qQ=mDt;function qht(t){return t=t.replace(/\/\/.*/g,""),t.replace(/\/\*\*[\s\S]*?\*\//gm,function(e){let n=e.match(/\n/gm).length,i="";for(let o=0;o0;){let o=t.pop();n.push(o),o.requiredBy.length===0&&e.push(o)}for(;e.length>0;){let o=e.shift();t.push(o);for(let a=0;a=0;--o)i=`${i+e[o].glslSource} +`;return i})}function $ht(t,e,n){let i;for(let o=0;o0;){let o=t.pop();n.push(o),o.requiredBy.length===0&&e.push(o)}for(;e.length>0;){let o=e.shift();t.push(o);for(let a=0;a=0;--o)i=`${i+e[o].glslSource} `;return i.replace(n.glslSource,"")}function ept(t,e,n){let i,o,a="",s=t.sources;if(c(s))for(i=0,o=s.length;i-1&&i.derivedKeywords.splice(s,1)}return this.createDerivedShaderProgram(t,e,n)};ju.prototype.getDerivedShaderProgram=function(t,e){let n=t._cachedShader,i=e+n.keyword,o=this._shaders[i];if(c(o))return o.shaderProgram};ju.prototype.createDerivedShaderProgram=function(t,e,n){let i=t._cachedShader,o=e+i.keyword,a=n.vertexShaderSource,s=n.fragmentShaderSource,l=n.attributeLocations;typeof a=="string"&&(a=new Ve({sources:[a]})),typeof s=="string"&&(s=new Ve({sources:[s]}));let r=this._context,d=a.createCombinedVertexShader(r),m=s.createCombinedFragmentShader(r),h=new xn({gl:r._gl,logShaderCompilation:r.logShaderCompilation,debugShaders:r.debugShaders,vertexShaderSource:a,vertexShaderText:d,fragmentShaderSource:s,fragmentShaderText:m,attributeLocations:l}),Z={cache:this,shaderProgram:h,keyword:o,derivedKeywords:[],count:0};return i.derivedKeywords.push(e),h._cachedShader=Z,this._shaders[o]=Z,h};function $6(t,e){let n=e.derivedKeywords,i=n.length;for(let o=0;o=0?(n=Math.floor(t/65536)*65536,e.high=n,e.low=t-n):(n=Math.floor(-t/65536)*65536,e.high=-n,e.low=t+n),e};var SR={high:0,low:0};LV.fromCartesian=function(t,e){c(e)||(e=new LV);let n=e.high,i=e.low;return LV.encode(t.x,SR),n.x=SR.high,i.x=SR.low,LV.encode(t.y,SR),n.y=SR.high,i.y=SR.low,LV.encode(t.z,SR),n.z=SR.high,i.z=SR.low,e};var t7=new LV;LV.writeElements=function(t,e,n){LV.fromCartesian(t,t7);let i=t7.high,o=t7.low;e[n]=i.x,e[n+1]=i.y,e[n+2]=i.z,e[n+3]=o.x,e[n+4]=o.y,e[n+5]=o.z};var Mi=LV;var Xin=R(W(),1);var yin=R(W(),1);var Gin=R(W(),1);var Zin=R(W(),1);function br(t,e){this.normal=p.clone(t),this.distance=e}br.fromPointNormal=function(t,e,n){let i=-p.dot(e,t);return c(n)?(p.clone(e,n.normal),n.distance=i,n):new br(e,i)};var RDt=new p;br.fromCartesian4=function(t,e){let n=p.fromCartesian4(t,RDt),i=t.w;return c(e)?(p.clone(n,e.normal),e.distance=i,e):new br(n,i)};br.getPointDistance=function(t,e){return p.dot(t.normal,e)+t.distance};var WDt=new p;br.projectPointOntoPlane=function(t,e,n){c(n)||(n=new p);let i=br.getPointDistance(t,e),o=p.multiplyByScalar(t.normal,i,WDt);return p.subtract(e,o,n)};var fDt=new L,FDt=new Rt,UDt=new p;br.transform=function(t,e,n){let i=t.normal,o=t.distance,a=L.inverseTranspose(e,fDt),s=Rt.fromElements(i.x,i.y,i.z,o,FDt);s=L.multiplyByVector(a,s,s);let l=p.fromCartesian4(s,UDt);return s=Rt.divideByScalar(s,p.magnitude(l),s),br.fromCartesian4(s,n)};br.clone=function(t,e){return c(e)?(p.clone(t.normal,e.normal),e.distance=t.distance,e):new br(t.normal,t.distance)};br.equals=function(t,e){return t.distance===e.distance&&p.equals(t.normal,e.normal)};br.ORIGIN_XY_PLANE=Object.freeze(new br(p.UNIT_Z,0));br.ORIGIN_YZ_PLANE=Object.freeze(new br(p.UNIT_X,0));br.ORIGIN_ZX_PLANE=Object.freeze(new br(p.UNIT_Y,0));var Kn=br;function Ep(t){this.planes=f(t,[])}var e2=[new p,new p,new p];p.clone(p.UNIT_X,e2[0]);p.clone(p.UNIT_Y,e2[1]);p.clone(p.UNIT_Z,e2[2]);var Vf=new p,GDt=new p,opt=new Kn(new p(1,0,0),0);Ep.fromBoundingSphere=function(t,e){c(e)||(e=new Ep);let n=e2.length,i=e.planes;i.length=2*n;let o=t.center,a=t.radius,s=0;for(let l=0;lQDt;++a){o=i;let s=o-e*Math.sin(o)-t,l=1-e*Math.cos(o);i=o-s/l}return o=i+n*k.TWO_PI,o}function YDt(t,e){let n=Math.floor(t/k.TWO_PI);t-=n*k.TWO_PI;let i=Math.cos(t)-e,o=Math.sin(t)*Math.sqrt(1-e*e),a=Math.atan2(o,i);return a=k.zeroToTwoPi(a),t<0&&(a-=k.TWO_PI),a+=n*k.TWO_PI,a}function xDt(t,e,n,i){let o=Math.cos(t),a=Math.sin(t),s=Math.cos(e),l=Math.sin(e),r=Math.cos(n),d=Math.sin(n);return c(i)?(i[0]=r*o-d*a*s,i[1]=d*o+r*a*s,i[2]=a*l,i[3]=-r*a-d*o*s,i[4]=-d*a+r*o*s,i[5]=o*l,i[6]=d*l,i[7]=-r*l,i[8]=s):i=new ot(r*o-d*a*s,-r*a-d*o*s,d*l,d*o+r*a*s,-d*a+r*o*s,-r*l,a*l,o*l,s),i}var XDt=1.0000010178*md,JDt=100.46645683*Cp,LDt=129597742283429e-5*Zh,lpt=16002,rpt=21863,dpt=32004,cpt=10931,mpt=14529,hpt=16368,ppt=15318,upt=32794,MDt=64*1e-7*md,_Dt=-152*1e-7*md,DDt=62*1e-7*md,ODt=-8*1e-7*md,HDt=32*1e-7*md,wDt=-41*1e-7*md,PDt=19*1e-7*md,vDt=-11*1e-7*md,KDt=-150*1e-7*md,zDt=-46*1e-7*md,jDt=68*1e-7*md,qDt=54*1e-7*md,$Dt=14*1e-7*md,tOt=24*1e-7*md,eOt=-28*1e-7*md,nOt=22*1e-7*md,Zpt=10,Vpt=16002,bpt=21863,Rpt=10931,Wpt=1473,fpt=32004,Fpt=4387,Upt=73,iOt=-325*1e-7,oOt=-322*1e-7,aOt=-79*1e-7,sOt=232*1e-7,lOt=-52*1e-7,rOt=97*1e-7,dOt=55*1e-7,cOt=-41*1e-7,mOt=-105*1e-7,hOt=-137*1e-7,pOt=258*1e-7,uOt=35*1e-7,ZOt=-116*1e-7,VOt=-88*1e-7,bOt=-112*1e-7,ROt=-80*1e-7,sE=new rt(0,0,Di.TAI);function WOt(t,e){Apt(t,sE);let i=(sE.dayNumber-LH.dayNumber+(sE.secondsOfDay-LH.secondsOfDay)/xi.SECONDS_PER_DAY)/(xi.DAYS_PER_JULIAN_CENTURY*10),o=.3595362*i,a=XDt+MDt*Math.cos(lpt*o)+KDt*Math.sin(lpt*o)+_Dt*Math.cos(rpt*o)+zDt*Math.sin(rpt*o)+DDt*Math.cos(dpt*o)+jDt*Math.sin(dpt*o)+ODt*Math.cos(cpt*o)+qDt*Math.sin(cpt*o)+HDt*Math.cos(mpt*o)+$Dt*Math.sin(mpt*o)+wDt*Math.cos(hpt*o)+tOt*Math.sin(hpt*o)+PDt*Math.cos(ppt*o)+eOt*Math.sin(ppt*o)+vDt*Math.cos(upt*o)+nOt*Math.sin(upt*o),s=JDt+LDt*i+iOt*Math.cos(Zpt*o)+mOt*Math.sin(Zpt*o)+oOt*Math.cos(Vpt*o)+hOt*Math.sin(Vpt*o)+aOt*Math.cos(bpt*o)+pOt*Math.sin(bpt*o)+sOt*Math.cos(Rpt*o)+uOt*Math.sin(Rpt*o)+lOt*Math.cos(Wpt*o)+ZOt*Math.sin(Wpt*o)+rOt*Math.cos(fpt*o)+VOt*Math.sin(fpt*o)+dOt*Math.cos(Fpt*o)+bOt*Math.sin(Fpt*o)+cOt*Math.cos(Upt*o)+ROt*Math.sin(Upt*o),l=.0167086342-.0004203654*i,r=102.93734808*Cp+11612.3529*Zh*i,d=469.97289*Zh*i,m=174.87317577*Cp-8679.27034*Zh*i;return Tpt(a,l,d,r,m,s,e)}function Spt(t,e){Apt(t,sE);let i=(sE.dayNumber-LH.dayNumber+(sE.secondsOfDay-LH.secondsOfDay)/xi.SECONDS_PER_DAY)/xi.DAYS_PER_JULIAN_CENTURY,o=i*i,a=o*i,s=a*i,l=383397.7725+.004*i,r=.055545526-16e-9*i,d=5.15668983*Cp,m=-8e-5*i+.02966*o-42e-6*a-13e-8*s,h=83.35324312*Cp,Z=146434202669e-4*i-38.2702*o-.045047*a+21301e-8*s,b=125.04455501*Cp,u=-69679193631e-4*i+6.3602*o+.007625*a-3586e-8*s,F=218.31664563*Cp,U=17325593434847e-4*i-6.391*o+.006588*a-3169e-8*s,G=297.85019547*Cp+Zh*(1602961601209e-3*i-6.3706*o+.006593*a-3169e-8*s),A=93.27209062*Cp+Zh*(17395272628478e-4*i-12.7512*o-.001037*a+417e-8*s),T=134.96340251*Cp+Zh*(17179159232178e-4*i+31.8792*o+.051635*a-2447e-7*s),g=357.52910918*Cp+Zh*(1295965810481e-4*i-.5532*o+136e-6*a-1149e-8*s),C=310.17137918*Cp-Zh*(6967051436e-3*i+6.2068*o+.007618*a-3219e-8*s),y=2*G,Y=4*G,Q=6*G,J=2*T,M=3*T,V=4*T,E=2*A;l+=3400.4*Math.cos(y)-635.6*Math.cos(y-T)-235.6*Math.cos(T)+218.1*Math.cos(y-g)+181*Math.cos(y+T),r+=.014216*Math.cos(y-T)+.008551*Math.cos(y-J)-.001383*Math.cos(T)+.001356*Math.cos(y+T)-.001147*Math.cos(Y-M)-914e-6*Math.cos(Y-J)+869e-6*Math.cos(y-g-T)-627e-6*Math.cos(y)-394e-6*Math.cos(Y-V)+282e-6*Math.cos(y-g-J)-279e-6*Math.cos(G-T)-236e-6*Math.cos(J)+231e-6*Math.cos(Y)+229e-6*Math.cos(Q-V)-201e-6*Math.cos(J-E),m+=486.26*Math.cos(y-E)-40.13*Math.cos(y)+37.51*Math.cos(E)+25.73*Math.cos(J-E)+19.97*Math.cos(y-g-E),Z+=-55609*Math.sin(y-T)-34711*Math.sin(y-J)-9792*Math.sin(T)+9385*Math.sin(Y-M)+7505*Math.sin(Y-J)+5318*Math.sin(y+T)+3484*Math.sin(Y-V)-3417*Math.sin(y-g-T)-2530*Math.sin(Q-V)-2376*Math.sin(y)-2075*Math.sin(y-M)-1883*Math.sin(J)-1736*Math.sin(Q-5*T)+1626*Math.sin(g)-1370*Math.sin(Q-M),u+=-5392*Math.sin(y-E)-540*Math.sin(g)-441*Math.sin(y)+423*Math.sin(E)-288*Math.sin(J-E),U+=-3332.9*Math.sin(y)+1197.4*Math.sin(y-T)-662.5*Math.sin(g)+396.3*Math.sin(T)-218*Math.sin(y-g);let I=2*C,B=3*C;m+=46.997*Math.cos(C)*i-.614*Math.cos(y-E+C)*i+.614*Math.cos(y-E-C)*i-.0297*Math.cos(I)*o-.0335*Math.cos(C)*o+.0012*Math.cos(y-E+I)*o-16e-5*Math.cos(C)*a+4e-5*Math.cos(B)*a+4e-5*Math.cos(I)*a;let X=2.116*Math.sin(C)*i-.111*Math.sin(y-E-C)*i-.0015*Math.sin(C)*o;Z+=X,U+=X,u+=-520.77*Math.sin(C)*i+13.66*Math.sin(y-E+C)*i+1.12*Math.sin(y-C)*i-1.06*Math.sin(E-C)*i+.66*Math.sin(I)*o+.371*Math.sin(C)*o-.035*Math.sin(y-E+I)*o-.015*Math.sin(y-E+C)*o+.0014*Math.sin(C)*a-.0011*Math.sin(B)*a-9e-4*Math.sin(I)*a,l*=IDt;let _=d+m*Zh,P=h+Z*Zh,w=F+U*Zh,z=b+u*Zh;return Tpt(l,r,_,P,z,w,e)}var Gpt=.012300034,fOt=Gpt/(Gpt+1)*-1;function FOt(t,e){return e=Spt(t,e),p.multiplyByScalar(e,fOt,e)}var gpt=new ot(1.0000000000000002,5619723173785822e-31,4690511510146299e-34,-5154129427414611e-31,.9174820620691819,-.39777715593191376,-223970096136568e-30,.39777715593191376,.9174820620691819),n2=new p;n7.computeSunPositionInEarthInertialFrame=function(t,e){return c(t)||(t=rt.now()),c(e)||(e=new p),n2=WOt(t,n2),e=p.negate(n2,e),FOt(t,n2),p.subtract(e,n2,e),ot.multiplyByVector(gpt,e,e),e};n7.computeMoonPositionInEarthInertialFrame=function(t,e){return c(t)||(t=rt.now()),e=Spt(t,e),ot.multiplyByVector(gpt,e,e),e};var _V=n7;var Kin=R(W(),1),MH={MORPHING:0,COLUMBUS_VIEW:1,SCENE2D:2,SCENE3D:3};MH.getMorphTime=function(t){return t===MH.SCENE3D?1:t===MH.MORPHING?void 0:0};var ut=Object.freeze(MH);var $in=R(W(),1);function UOt(t){t=f(t,f.EMPTY_OBJECT),this.color=v.clone(f(t.color,v.WHITE)),this.intensity=f(t.intensity,2)}var gR=UOt;function lE(){this.globeDepthTexture=void 0,this.gamma=void 0,this._viewport=new Fe,this._viewportCartesian4=new Rt,this._viewportDirty=!1,this._viewportOrthographicMatrix=L.clone(L.IDENTITY),this._viewportTransformation=L.clone(L.IDENTITY),this._model=L.clone(L.IDENTITY),this._view=L.clone(L.IDENTITY),this._inverseView=L.clone(L.IDENTITY),this._projection=L.clone(L.IDENTITY),this._infiniteProjection=L.clone(L.IDENTITY),this._entireFrustum=new K,this._currentFrustum=new K,this._frustumPlanes=new Rt,this._farDepthFromNearPlusOne=void 0,this._log2FarDepthFromNearPlusOne=void 0,this._oneOverLog2FarDepthFromNearPlusOne=void 0,this._frameState=void 0,this._temeToPseudoFixed=ot.clone(L.IDENTITY),this._view3DDirty=!0,this._view3D=new L,this._inverseView3DDirty=!0,this._inverseView3D=new L,this._inverseModelDirty=!0,this._inverseModel=new L,this._inverseTransposeModelDirty=!0,this._inverseTransposeModel=new ot,this._viewRotation=new ot,this._inverseViewRotation=new ot,this._viewRotation3D=new ot,this._inverseViewRotation3D=new ot,this._inverseProjectionDirty=!0,this._inverseProjection=new L,this._modelViewDirty=!0,this._modelView=new L,this._modelView3DDirty=!0,this._modelView3D=new L,this._modelViewRelativeToEyeDirty=!0,this._modelViewRelativeToEye=new L,this._inverseModelViewDirty=!0,this._inverseModelView=new L,this._inverseModelView3DDirty=!0,this._inverseModelView3D=new L,this._viewProjectionDirty=!0,this._viewProjection=new L,this._inverseViewProjectionDirty=!0,this._inverseViewProjection=new L,this._modelViewProjectionDirty=!0,this._modelViewProjection=new L,this._inverseModelViewProjectionDirty=!0,this._inverseModelViewProjection=new L,this._modelViewProjectionRelativeToEyeDirty=!0,this._modelViewProjectionRelativeToEye=new L,this._modelViewInfiniteProjectionDirty=!0,this._modelViewInfiniteProjection=new L,this._normalDirty=!0,this._normal=new ot,this._normal3DDirty=!0,this._normal3D=new ot,this._inverseNormalDirty=!0,this._inverseNormal=new ot,this._inverseNormal3DDirty=!0,this._inverseNormal3D=new ot,this._encodedCameraPositionMCDirty=!0,this._encodedCameraPositionMC=new Mi,this._cameraPosition=new p,this._sunPositionWC=new p,this._sunPositionColumbusView=new p,this._sunDirectionWC=new p,this._sunDirectionEC=new p,this._moonDirectionEC=new p,this._lightDirectionWC=new p,this._lightDirectionEC=new p,this._lightColor=new p,this._lightColorHdr=new p,this._pass=void 0,this._mode=void 0,this._mapProjection=void 0,this._ellipsoid=void 0,this._cameraDirection=new p,this._cameraRight=new p,this._cameraUp=new p,this._frustum2DWidth=0,this._eyeHeight=0,this._eyeHeight2D=new K,this._eyeEllipsoidNormalEC=new p,this._eyeEllipsoidCurvature=new K,this._modelToEnu=new L,this._enuToModel=new L,this._pixelRatio=1,this._orthographicIn3D=!1,this._backgroundColor=new v,this._brdfLut=void 0,this._environmentMap=void 0,this._sphericalHarmonicCoefficients=void 0,this._specularEnvironmentMaps=void 0,this._specularEnvironmentMapsDimensions=new K,this._specularEnvironmentMapsMaximumLOD=void 0,this._fogDensity=void 0,this._fogMinimumBrightness=void 0,this._atmosphereHsbShift=void 0,this._atmosphereLightIntensity=void 0,this._atmosphereRayleighCoefficient=new p,this._atmosphereRayleighScaleHeight=new p,this._atmosphereMieCoefficient=new p,this._atmosphereMieScaleHeight=void 0,this._atmosphereMieAnisotropy=void 0,this._atmosphereDynamicLighting=void 0,this._invertClassificationColor=void 0,this._splitPosition=0,this._pixelSizePerMeter=void 0,this._geometricToleranceOverMeter=void 0,this._minimumDisableDepthTestDistance=void 0}Object.defineProperties(lE.prototype,{frameState:{get:function(){return this._frameState}},viewport:{get:function(){return this._viewport},set:function(t){if(!Fe.equals(t,this._viewport)){Fe.clone(t,this._viewport);let e=this._viewport,n=this._viewportCartesian4;n.x=e.x,n.y=e.y,n.z=e.width,n.w=e.height,this._viewportDirty=!0}}},viewportCartesian4:{get:function(){return this._viewportCartesian4}},viewportOrthographic:{get:function(){return Cpt(this),this._viewportOrthographicMatrix}},viewportTransformation:{get:function(){return Cpt(this),this._viewportTransformation}},model:{get:function(){return this._model},set:function(t){L.clone(t,this._model),this._modelView3DDirty=!0,this._inverseModelView3DDirty=!0,this._inverseModelDirty=!0,this._inverseTransposeModelDirty=!0,this._modelViewDirty=!0,this._inverseModelViewDirty=!0,this._modelViewRelativeToEyeDirty=!0,this._inverseModelViewDirty=!0,this._modelViewProjectionDirty=!0,this._inverseModelViewProjectionDirty=!0,this._modelViewProjectionRelativeToEyeDirty=!0,this._modelViewInfiniteProjectionDirty=!0,this._normalDirty=!0,this._inverseNormalDirty=!0,this._normal3DDirty=!0,this._inverseNormal3DDirty=!0,this._encodedCameraPositionMCDirty=!0}},inverseModel:{get:function(){return this._inverseModelDirty&&(this._inverseModelDirty=!1,L.inverse(this._model,this._inverseModel)),this._inverseModel}},inverseTransposeModel:{get:function(){let t=this._inverseTransposeModel;return this._inverseTransposeModelDirty&&(this._inverseTransposeModelDirty=!1,L.getMatrix3(this.inverseModel,t),ot.transpose(t,t)),t}},view:{get:function(){return this._view}},view3D:{get:function(){return i7(this),this._view3D}},viewRotation:{get:function(){return i7(this),this._viewRotation}},viewRotation3D:{get:function(){return i7(this),this._viewRotation3D}},inverseView:{get:function(){return this._inverseView}},inverseView3D:{get:function(){return ypt(this),this._inverseView3D}},inverseViewRotation:{get:function(){return this._inverseViewRotation}},inverseViewRotation3D:{get:function(){return ypt(this),this._inverseViewRotation3D}},projection:{get:function(){return this._projection}},inverseProjection:{get:function(){return BOt(this),this._inverseProjection}},infiniteProjection:{get:function(){return this._infiniteProjection}},modelView:{get:function(){return QOt(this),this._modelView}},modelView3D:{get:function(){return kOt(this),this._modelView3D}},modelViewRelativeToEye:{get:function(){return MOt(this),this._modelViewRelativeToEye}},inverseModelView:{get:function(){return YOt(this),this._inverseModelView}},inverseModelView3D:{get:function(){return xOt(this),this._inverseModelView3D}},viewProjection:{get:function(){return XOt(this),this._viewProjection}},inverseViewProjection:{get:function(){return JOt(this),this._inverseViewProjection}},modelViewProjection:{get:function(){return LOt(this),this._modelViewProjection}},inverseModelViewProjection:{get:function(){return _Ot(this),this._inverseModelViewProjection}},modelViewProjectionRelativeToEye:{get:function(){return DOt(this),this._modelViewProjectionRelativeToEye}},modelViewInfiniteProjection:{get:function(){return OOt(this),this._modelViewInfiniteProjection}},normal:{get:function(){return HOt(this),this._normal}},normal3D:{get:function(){return wOt(this),this._normal3D}},inverseNormal:{get:function(){return POt(this),this._inverseNormal}},inverseNormal3D:{get:function(){return vOt(this),this._inverseNormal3D}},entireFrustum:{get:function(){return this._entireFrustum}},currentFrustum:{get:function(){return this._currentFrustum}},frustumPlanes:{get:function(){return this._frustumPlanes}},farDepthFromNearPlusOne:{get:function(){return this._farDepthFromNearPlusOne}},log2FarDepthFromNearPlusOne:{get:function(){return this._log2FarDepthFromNearPlusOne}},oneOverLog2FarDepthFromNearPlusOne:{get:function(){return this._oneOverLog2FarDepthFromNearPlusOne}},eyeHeight:{get:function(){return this._eyeHeight}},eyeHeight2D:{get:function(){return this._eyeHeight2D}},eyeEllipsoidNormalEC:{get:function(){return this._eyeEllipsoidNormalEC}},eyeEllipsoidCurvature:{get:function(){return this._eyeEllipsoidCurvature}},modelToEnu:{get:function(){return this._modelToEnu}},enuToModel:{get:function(){return this._enuToModel}},sunPositionWC:{get:function(){return this._sunPositionWC}},sunPositionColumbusView:{get:function(){return this._sunPositionColumbusView}},sunDirectionWC:{get:function(){return this._sunDirectionWC}},sunDirectionEC:{get:function(){return this._sunDirectionEC}},moonDirectionEC:{get:function(){return this._moonDirectionEC}},lightDirectionWC:{get:function(){return this._lightDirectionWC}},lightDirectionEC:{get:function(){return this._lightDirectionEC}},lightColor:{get:function(){return this._lightColor}},lightColorHdr:{get:function(){return this._lightColorHdr}},encodedCameraPositionMCHigh:{get:function(){return Npt(this),this._encodedCameraPositionMC.high}},encodedCameraPositionMCLow:{get:function(){return Npt(this),this._encodedCameraPositionMC.low}},temeToPseudoFixedMatrix:{get:function(){return this._temeToPseudoFixed}},pixelRatio:{get:function(){return this._pixelRatio}},fogDensity:{get:function(){return this._fogDensity}},fogMinimumBrightness:{get:function(){return this._fogMinimumBrightness}},atmosphereHsbShift:{get:function(){return this._atmosphereHsbShift}},atmosphereLightIntensity:{get:function(){return this._atmosphereLightIntensity}},atmosphereRayleighCoefficient:{get:function(){return this._atmosphereRayleighCoefficient}},atmosphereRayleighScaleHeight:{get:function(){return this._atmosphereRayleighScaleHeight}},atmosphereMieCoefficient:{get:function(){return this._atmosphereMieCoefficient}},atmosphereMieScaleHeight:{get:function(){return this._atmosphereMieScaleHeight}},atmosphereMieAnisotropy:{get:function(){return this._atmosphereMieAnisotropy}},atmosphereDynamicLighting:{get:function(){return this._atmosphereDynamicLighting}},geometricToleranceOverMeter:{get:function(){return this._geometricToleranceOverMeter}},pass:{get:function(){return this._pass}},backgroundColor:{get:function(){return this._backgroundColor}},brdfLut:{get:function(){return this._brdfLut}},environmentMap:{get:function(){return this._environmentMap}},sphericalHarmonicCoefficients:{get:function(){return this._sphericalHarmonicCoefficients}},specularEnvironmentMaps:{get:function(){return this._specularEnvironmentMaps}},specularEnvironmentMapsDimensions:{get:function(){return this._specularEnvironmentMapsDimensions}},specularEnvironmentMapsMaximumLOD:{get:function(){return this._specularEnvironmentMapsMaximumLOD}},splitPosition:{get:function(){return this._splitPosition}},minimumDisableDepthTestDistance:{get:function(){return this._minimumDisableDepthTestDistance}},invertClassificationColor:{get:function(){return this._invertClassificationColor}},orthographicIn3D:{get:function(){return this._orthographicIn3D}},ellipsoid:{get:function(){return f(this._ellipsoid,mt.WGS84)}}});function GOt(t,e){L.clone(e,t._view),L.getMatrix3(e,t._viewRotation),t._view3DDirty=!0,t._inverseView3DDirty=!0,t._modelViewDirty=!0,t._modelView3DDirty=!0,t._modelViewRelativeToEyeDirty=!0,t._inverseModelViewDirty=!0,t._inverseModelView3DDirty=!0,t._viewProjectionDirty=!0,t._inverseViewProjectionDirty=!0,t._modelViewProjectionDirty=!0,t._modelViewProjectionRelativeToEyeDirty=!0,t._modelViewInfiniteProjectionDirty=!0,t._normalDirty=!0,t._inverseNormalDirty=!0,t._normal3DDirty=!0,t._inverseNormal3DDirty=!0}function AOt(t,e){L.clone(e,t._inverseView),L.getMatrix3(e,t._inverseViewRotation)}function TOt(t,e){L.clone(e,t._projection),t._inverseProjectionDirty=!0,t._viewProjectionDirty=!0,t._inverseViewProjectionDirty=!0,t._modelViewProjectionDirty=!0,t._modelViewProjectionRelativeToEyeDirty=!0}function SOt(t,e){L.clone(e,t._infiniteProjection),t._modelViewInfiniteProjectionDirty=!0}var Ept=new p,gOt=new L;function EOt(t,e){p.clone(e.positionWC,t._cameraPosition),p.clone(e.directionWC,t._cameraDirection),p.clone(e.rightWC,t._cameraRight),p.clone(e.upWC,t._cameraUp);let n=t._ellipsoid,i,o=e.positionCartographic;if(c(o)?(t._eyeHeight=o.height,t._eyeEllipsoidNormalEC=n.geodeticSurfaceNormalCartographic(o,t._eyeEllipsoidNormalEC),i=p.fromRadians(o.longitude,o.latitude,0,n,Ept)):(t._eyeHeight=-n.maximumRadius,p.magnitude(e.positionWC)>0&&(t._eyeEllipsoidNormalEC=p.normalize(e.positionWC,t._eyeEllipsoidNormalEC)),i=n.scaleToGeodeticSurface(e.positionWC,Ept)),t._encodedCameraPositionMCDirty=!0,!c(i))return;t._eyeEllipsoidNormalEC=ot.multiplyByVector(t._viewRotation,t._eyeEllipsoidNormalEC,t._eyeEllipsoidNormalEC);let a=Pe.eastNorthUpToFixedFrame(i,n,gOt);t._enuToModel=L.multiplyTransformation(t.inverseModel,a,t._enuToModel),t._modelToEnu=L.inverseTransformation(t._enuToModel,t._modelToEnu),k.equalsEpsilon(n._radii.x,n._radii.y,k.EPSILON15)&&(t._eyeEllipsoidCurvature=n.getLocalCurvature(i,t._eyeEllipsoidCurvature))}var i2=new ot,COt=new gt;function IOt(t,e){c(Pe.computeIcrfToFixedMatrix(e.time,i2))||(i2=Pe.computeTemeToPseudoFixedMatrix(e.time,i2));let n=_V.computeSunPositionInEarthInertialFrame(e.time,t._sunPositionWC);ot.multiplyByVector(i2,n,n),p.normalize(n,t._sunDirectionWC),n=ot.multiplyByVector(t.viewRotation3D,n,t._sunDirectionEC),p.normalize(n,n),n=_V.computeMoonPositionInEarthInertialFrame(e.time,t._moonDirectionEC),ot.multiplyByVector(i2,n,n),ot.multiplyByVector(t.viewRotation3D,n,n),p.normalize(n,n);let i=e.mapProjection,a=i.ellipsoid.cartesianToCartographic(t._sunPositionWC,COt);i.project(a,t._sunPositionColumbusView)}lE.prototype.updateCamera=function(t){GOt(this,t.viewMatrix),AOt(this,t.inverseViewMatrix),EOt(this,t),this._entireFrustum.x=t.frustum.near,this._entireFrustum.y=t.frustum.far,this.updateFrustum(t.frustum),this._orthographicIn3D=this._mode!==ut.SCENE2D&&t.frustum instanceof wn};lE.prototype.updateFrustum=function(t){TOt(this,t.projectionMatrix),c(t.infiniteProjectionMatrix)&&SOt(this,t.infiniteProjectionMatrix),this._currentFrustum.x=t.near,this._currentFrustum.y=t.far,this._farDepthFromNearPlusOne=t.far-t.near+1,this._log2FarDepthFromNearPlusOne=k.log2(this._farDepthFromNearPlusOne),this._oneOverLog2FarDepthFromNearPlusOne=1/this._log2FarDepthFromNearPlusOne;let e=t.offCenterFrustum;c(e)&&(t=e),this._frustumPlanes.x=t.top,this._frustumPlanes.y=t.bottom,this._frustumPlanes.z=t.left,this._frustumPlanes.w=t.right};lE.prototype.updatePass=function(t){this._pass=t};var NOt=[],yOt=new gR;lE.prototype.update=function(t){this._mode=t.mode,this._mapProjection=t.mapProjection,this._ellipsoid=t.mapProjection.ellipsoid,this._pixelRatio=t.pixelRatio;let e=t.camera;this.updateCamera(e),t.mode===ut.SCENE2D?(this._frustum2DWidth=e.frustum.right-e.frustum.left,this._eyeHeight2D.x=this._frustum2DWidth*.5,this._eyeHeight2D.y=this._eyeHeight2D.x*this._eyeHeight2D.x):(this._frustum2DWidth=0,this._eyeHeight2D.x=0,this._eyeHeight2D.y=0),IOt(this,t);let n=f(t.light,yOt);n instanceof gR?(this._lightDirectionWC=p.clone(this._sunDirectionWC,this._lightDirectionWC),this._lightDirectionEC=p.clone(this._sunDirectionEC,this._lightDirectionEC)):(this._lightDirectionWC=p.normalize(p.negate(n.direction,this._lightDirectionWC),this._lightDirectionWC),this._lightDirectionEC=ot.multiplyByVector(this.viewRotation3D,this._lightDirectionWC,this._lightDirectionEC));let i=n.color,o=p.fromElements(i.red,i.green,i.blue,this._lightColorHdr);o=p.multiplyByScalar(o,n.intensity,o);let a=p.maximumComponent(o);a>1?p.divideByScalar(o,a,this._lightColor):p.clone(o,this._lightColor);let s=t.brdfLutGenerator,l=c(s)?s.colorTexture:void 0;this._brdfLut=l,this._environmentMap=f(t.environmentMap,t.context.defaultCubeMap),this._sphericalHarmonicCoefficients=f(t.sphericalHarmonicCoefficients,NOt),this._specularEnvironmentMaps=t.specularEnvironmentMaps,this._specularEnvironmentMapsMaximumLOD=t.specularEnvironmentMapsMaximumLOD,c(this._specularEnvironmentMaps)&&K.clone(this._specularEnvironmentMaps.dimensions,this._specularEnvironmentMapsDimensions),this._fogDensity=t.fog.density,this._fogMinimumBrightness=t.fog.minimumBrightness;let r=t.atmosphere;c(r)&&(this._atmosphereHsbShift=p.fromElements(r.hueShift,r.saturationShift,r.brightnessShift,this._atmosphereHsbShift),this._atmosphereLightIntensity=r.lightIntensity,this._atmosphereRayleighCoefficient=p.clone(r.rayleighCoefficient,this._atmosphereRayleighCoefficient),this._atmosphereRayleighScaleHeight=r.rayleighScaleHeight,this._atmosphereMieCoefficient=p.clone(r.mieCoefficient,this._atmosphereMieCoefficient),this._atmosphereMieScaleHeight=r.mieScaleHeight,this._atmosphereMieAnisotropy=r.mieAnisotropy,this._atmosphereDynamicLighting=r.dynamicLighting),this._invertClassificationColor=t.invertClassificationColor,this._frameState=t,this._temeToPseudoFixed=Pe.computeTemeToPseudoFixedMatrix(t.time,this._temeToPseudoFixed),this._splitPosition=t.splitPosition*t.context.drawingBufferWidth;let d=e.frustum.fov,m=this._viewport,h;c(d)?m.height>m.width?h=Math.tan(.5*d)*2/m.height:h=Math.tan(.5*d)*2/m.width:h=1/Math.max(m.width,m.height),this._geometricToleranceOverMeter=h*t.maximumScreenSpaceError,v.clone(t.backgroundColor,this._backgroundColor),this._minimumDisableDepthTestDistance=t.minimumDisableDepthTestDistance,this._minimumDisableDepthTestDistance*=this._minimumDisableDepthTestDistance,this._minimumDisableDepthTestDistance===Number.POSITIVE_INFINITY&&(this._minimumDisableDepthTestDistance=-1)};function Cpt(t){if(t._viewportDirty){let e=t._viewport;L.computeOrthographicOffCenter(e.x,e.x+e.width,e.y,e.y+e.height,0,1,t._viewportOrthographicMatrix),L.computeViewportTransformation(e,0,1,t._viewportTransformation),t._viewportDirty=!1}}function BOt(t){t._inverseProjectionDirty&&(t._inverseProjectionDirty=!1,t._mode!==ut.SCENE2D&&t._mode!==ut.MORPHING&&!t._orthographicIn3D?L.inverse(t._projection,t._inverseProjection):L.clone(L.ZERO,t._inverseProjection))}function QOt(t){t._modelViewDirty&&(t._modelViewDirty=!1,L.multiplyTransformation(t._view,t._model,t._modelView))}function kOt(t){t._modelView3DDirty&&(t._modelView3DDirty=!1,L.multiplyTransformation(t.view3D,t._model,t._modelView3D))}function YOt(t){t._inverseModelViewDirty&&(t._inverseModelViewDirty=!1,L.inverse(t.modelView,t._inverseModelView))}function xOt(t){t._inverseModelView3DDirty&&(t._inverseModelView3DDirty=!1,L.inverse(t.modelView3D,t._inverseModelView3D))}function XOt(t){t._viewProjectionDirty&&(t._viewProjectionDirty=!1,L.multiply(t._projection,t._view,t._viewProjection))}function JOt(t){t._inverseViewProjectionDirty&&(t._inverseViewProjectionDirty=!1,L.inverse(t.viewProjection,t._inverseViewProjection))}function LOt(t){t._modelViewProjectionDirty&&(t._modelViewProjectionDirty=!1,L.multiply(t._projection,t.modelView,t._modelViewProjection))}function MOt(t){if(t._modelViewRelativeToEyeDirty){t._modelViewRelativeToEyeDirty=!1;let e=t.modelView,n=t._modelViewRelativeToEye;n[0]=e[0],n[1]=e[1],n[2]=e[2],n[3]=e[3],n[4]=e[4],n[5]=e[5],n[6]=e[6],n[7]=e[7],n[8]=e[8],n[9]=e[9],n[10]=e[10],n[11]=e[11],n[12]=0,n[13]=0,n[14]=0,n[15]=e[15]}}function _Ot(t){t._inverseModelViewProjectionDirty&&(t._inverseModelViewProjectionDirty=!1,L.inverse(t.modelViewProjection,t._inverseModelViewProjection))}function DOt(t){t._modelViewProjectionRelativeToEyeDirty&&(t._modelViewProjectionRelativeToEyeDirty=!1,L.multiply(t._projection,t.modelViewRelativeToEye,t._modelViewProjectionRelativeToEye))}function OOt(t){t._modelViewInfiniteProjectionDirty&&(t._modelViewInfiniteProjectionDirty=!1,L.multiply(t._infiniteProjection,t.modelView,t._modelViewInfiniteProjection))}function HOt(t){if(t._normalDirty){t._normalDirty=!1;let e=t._normal;L.getMatrix3(t.inverseModelView,e),ot.transpose(e,e)}}function wOt(t){if(t._normal3DDirty){t._normal3DDirty=!1;let e=t._normal3D;L.getMatrix3(t.inverseModelView3D,e),ot.transpose(e,e)}}function POt(t){if(t._inverseNormalDirty){t._inverseNormalDirty=!1;let e=t._inverseNormal;L.getMatrix3(t.modelView,e),ot.transpose(e,e)}}function vOt(t){if(t._inverseNormal3DDirty){t._inverseNormal3DDirty=!1;let e=t._inverseNormal3D;L.getMatrix3(t.modelView3D,e),ot.transpose(e,e)}}var Ipt=new p;function Npt(t){t._encodedCameraPositionMCDirty&&(t._encodedCameraPositionMCDirty=!1,L.multiplyByPoint(t.inverseModel,t._cameraPosition,Ipt),Mi.fromCartesian(Ipt,t._encodedCameraPositionMC))}var KOt=new p,zOt=new p,jOt=new p,qOt=new p,$Ot=new gt,tHt=new p,eHt=new L;function nHt(t,e,n,i,o,a,s,l){let r=KOt;r.x=t.y,r.y=t.z,r.z=t.x;let d=zOt;d.x=n.y,d.y=n.z,d.z=n.x;let m=jOt;m.x=i.y,m.y=i.z,m.z=i.x;let h=qOt;h.x=e.y,h.y=e.z,h.z=e.x,a===ut.SCENE2D&&(r.z=o*.5);let Z=s.unproject(r,$Ot);Z.longitude=k.clamp(Z.longitude,-Math.PI,Math.PI),Z.latitude=k.clamp(Z.latitude,-k.PI_OVER_TWO,k.PI_OVER_TWO);let b=s.ellipsoid,u=b.cartographicToCartesian(Z,tHt),F=Pe.eastNorthUpToFixedFrame(u,b,eHt);return L.multiplyByPointAsVector(F,d,d),L.multiplyByPointAsVector(F,m,m),L.multiplyByPointAsVector(F,h,h),c(l)||(l=new L),l[0]=d.x,l[1]=m.x,l[2]=-h.x,l[3]=0,l[4]=d.y,l[5]=m.y,l[6]=-h.y,l[7]=0,l[8]=d.z,l[9]=m.z,l[10]=-h.z,l[11]=0,l[12]=-p.dot(d,u),l[13]=-p.dot(m,u),l[14]=p.dot(h,u),l[15]=1,l}function i7(t){t._view3DDirty&&(t._mode===ut.SCENE3D?L.clone(t._view,t._view3D):nHt(t._cameraPosition,t._cameraDirection,t._cameraRight,t._cameraUp,t._frustum2DWidth,t._mode,t._mapProjection,t._view3D),L.getMatrix3(t._view3D,t._viewRotation3D),t._view3DDirty=!1)}function ypt(t){t._inverseView3DDirty&&(L.inverseTransformation(t.view3D,t._inverseView3D),L.getMatrix3(t._inverseView3D,t._inverseViewRotation3D),t._inverseView3DDirty=!1)}var o2=lE;var yon=R(W(),1);function iHt(t,e,n,i){let o=c(e.vertexBuffer),a=c(e.value),s=e.value?e.value.length:e.componentsPerAttribute,l={index:f(e.index,n),enabled:f(e.enabled,!0),vertexBuffer:e.vertexBuffer,value:a?e.value.slice(0):void 0,componentsPerAttribute:s,componentDatatype:f(e.componentDatatype,it.FLOAT),normalize:f(e.normalize,!1),offsetInBytes:f(e.offsetInBytes,0),strideInBytes:f(e.strideInBytes,0),instanceDivisor:f(e.instanceDivisor,0)};if(o)l.vertexAttrib=function(r){let d=this.index;r.bindBuffer(r.ARRAY_BUFFER,this.vertexBuffer._getBuffer()),r.vertexAttribPointer(d,this.componentsPerAttribute,this.componentDatatype,this.normalize,this.strideInBytes,this.offsetInBytes),r.enableVertexAttribArray(d),this.instanceDivisor>0&&(i.glVertexAttribDivisor(d,this.instanceDivisor),i._vertexAttribDivisors[d]=this.instanceDivisor,i._previousDrawInstanced=!0)},l.disableVertexAttribArray=function(r){r.disableVertexAttribArray(this.index),this.instanceDivisor>0&&i.glVertexAttribDivisor(n,0)};else{switch(l.componentsPerAttribute){case 1:l.vertexAttrib=function(r){r.vertexAttrib1fv(this.index,this.value)};break;case 2:l.vertexAttrib=function(r){r.vertexAttrib2fv(this.index,this.value)};break;case 3:l.vertexAttrib=function(r){r.vertexAttrib3fv(this.index,this.value)};break;case 4:l.vertexAttrib=function(r){r.vertexAttrib4fv(this.index,this.value)};break}l.disableVertexAttribArray=function(r){}}t.push(l)}function Qpt(t,e,n){for(let i=0;i0&&(r=!0),c(s[a].value)&&(d=!0);let h;e.vertexArrayObject&&(h=e.glCreateVertexArray(),e.glBindVertexArray(h),Qpt(n,s,o),e.glBindVertexArray(null)),this._numberOfVertices=l,this._hasInstancedAttributes=r,this._hasConstantAttributes=d,this._context=e,this._gl=n,this._vao=h,this._attributes=s,this._indexBuffer=o}function Bpt(t){return t.values.length/t.componentsPerAttribute}function oHt(t){return it.getSizeInBytes(t.componentDatatype)*t.componentsPerAttribute}function aHt(t){let e,n,i,o=[];for(n in t)t.hasOwnProperty(n)&&c(t[n])&&c(t[n].values)&&(o.push(n),t[n].componentDatatype===it.DOUBLE&&(t[n].componentDatatype=it.FLOAT,t[n].values=it.createTypedArray(it.FLOAT,t[n].values)));let a,s=o.length;if(s>0)for(a=Bpt(t[o[0]]),e=1;e0){let d=it.getSizeInBytes(t[o[0]].componentDatatype),m=l%d;m!==0&&(l+=d-m);let h=a*l,Z=new ArrayBuffer(h),b={};for(e=0;e=k.SIXTY_FOUR_KILOBYTES&&e.elementIndexUint?Z=we.createIndexBuffer({context:e,typedArray:new Uint32Array(b),usage:i,indexDatatype:re.UNSIGNED_INT}):Z=we.createIndexBuffer({context:e,typedArray:new Uint16Array(b),usage:i,indexDatatype:re.UNSIGNED_SHORT})),new ER({context:e,attributes:m,indexBuffer:Z})};Object.defineProperties(ER.prototype,{numberOfAttributes:{get:function(){return this._attributes.length}},numberOfVertices:{get:function(){return this._numberOfVertices}},indexBuffer:{get:function(){return this._indexBuffer}}});ER.prototype.getAttribute=function(t){return this._attributes[t]};function sHt(t){let e=t._context,n=t._hasInstancedAttributes;if(!n&&!e._previousDrawInstanced)return;e._previousDrawInstanced=n;let i=e._vertexAttribDivisors,o=t._attributes,a=Sn.maximumVertexAttributes,s;if(n){let l=o.length;for(s=0;s0&&(e.glVertexAttribDivisor(s,0),i[s]=0)}function lHt(t,e){let n=t._attributes,i=n.length;for(let o=0;o"u")throw new St("The browser does not support WebGL. Visit http://get.webgl.org.");!n&&!(typeof WebGL2RenderingContext<"u")&&(n=!0);let o=n?"webgl":"webgl2",a=t.getContext(o,e);if(!c(a))throw new St("The browser supports WebGL, but initialization failed.");return a}function dHt(t,e){let n="WebGL Error: ";switch(e){case t.INVALID_ENUM:n+="INVALID_ENUM";break;case t.INVALID_VALUE:n+="INVALID_VALUE";break;case t.INVALID_OPERATION:n+="INVALID_OPERATION";break;case t.OUT_OF_MEMORY:n+="OUT_OF_MEMORY";break;case t.CONTEXT_LOST_WEBGL:n+="CONTEXT_LOST_WEBGL lost";break;default:n+=`Unknown (${e})`}return n}function cHt(t,e,n,i){let o=`${dHt(t,i)}: ${e.name}(`;for(let a=0;a=8}},antialias:{get:function(){return this._antialias}},msaa:{get:function(){return this._webgl2}},standardDerivatives:{get:function(){return this._standardDerivatives||this._webgl2}},floatBlend:{get:function(){return this._floatBlend}},blendMinmax:{get:function(){return this._blendMinmax||this._webgl2}},elementIndexUint:{get:function(){return this._elementIndexUint||this._webgl2}},depthTexture:{get:function(){return this._depthTexture||this._webgl2}},floatingPointTexture:{get:function(){return this._webgl2||this._textureFloat}},halfFloatingPointTexture:{get:function(){return this._webgl2||this._textureHalfFloat}},textureFloatLinear:{get:function(){return this._textureFloatLinear}},textureHalfFloatLinear:{get:function(){return this._webgl2&&this._textureFloatLinear||!this._webgl2&&this._textureHalfFloatLinear}},textureFilterAnisotropic:{get:function(){return!!this._textureFilterAnisotropic}},s3tc:{get:function(){return this._s3tc}},pvrtc:{get:function(){return this._pvrtc}},astc:{get:function(){return this._astc}},etc:{get:function(){return this._etc}},etc1:{get:function(){return this._etc1}},bc7:{get:function(){return this._bc7}},supportsBasis:{get:function(){return this._s3tc||this._pvrtc||this._astc||this._etc||this._etc1||this._bc7}},vertexArrayObject:{get:function(){return this._vertexArrayObject||this._webgl2}},fragmentDepth:{get:function(){return this._fragDepth||this._webgl2}},instancedArrays:{get:function(){return this._instancedArrays||this._webgl2}},colorBufferFloat:{get:function(){return this._colorBufferFloat}},colorBufferHalfFloat:{get:function(){return this._webgl2&&this._colorBufferFloat||!this._webgl2&&this._colorBufferHalfFloat}},drawBuffers:{get:function(){return this._drawBuffers||this._webgl2}},debugShaders:{get:function(){return this._debugShaders}},throwOnWebGLError:{get:function(){return this._throwOnWebGLError},set:function(t){this._throwOnWebGLError=t,this._gl=pHt(this._originalGLContext,t?mHt:void 0)}},defaultTexture:{get:function(){return this._defaultTexture===void 0&&(this._defaultTexture=new hn({context:this,source:{width:1,height:1,arrayBufferView:new Uint8Array([255,255,255,255])},flipY:!1})),this._defaultTexture}},defaultEmissiveTexture:{get:function(){return this._defaultEmissiveTexture===void 0&&(this._defaultEmissiveTexture=new hn({context:this,pixelFormat:Ye.RGB,source:{width:1,height:1,arrayBufferView:new Uint8Array([0,0,0])},flipY:!1})),this._defaultEmissiveTexture}},defaultNormalTexture:{get:function(){return this._defaultNormalTexture===void 0&&(this._defaultNormalTexture=new hn({context:this,pixelFormat:Ye.RGB,source:{width:1,height:1,arrayBufferView:new Uint8Array([128,128,255])},flipY:!1})),this._defaultNormalTexture}},defaultCubeMap:{get:function(){if(this._defaultCubeMap===void 0){let t={width:1,height:1,arrayBufferView:new Uint8Array([255,255,255,255])};this._defaultCubeMap=new Ld({context:this,source:{positiveX:t,negativeX:t,positiveY:t,negativeY:t,positiveZ:t,negativeZ:t},flipY:!1})}return this._defaultCubeMap}},drawingBufferHeight:{get:function(){return this._gl.drawingBufferHeight}},drawingBufferWidth:{get:function(){return this._gl.drawingBufferWidth}},defaultFramebuffer:{get:function(){return uHt}}});function kpt(t,e,n,i){let o=t._currentRenderState,a=t._currentPassState;t._currentRenderState=e,t._currentPassState=n,he.partialApply(t._gl,o,e,a,n,i)}var o7;typeof WebGLRenderingContext<"u"&&(o7=[pt.BACK]);function a7(t,e){if(e!==t._currentFramebuffer){t._currentFramebuffer=e;let n=o7;if(c(e))e._bind(),n=e._getActiveColorAttachments();else{let i=t._gl;i.bindFramebuffer(i.FRAMEBUFFER,null)}t.drawBuffers&&t.glDrawBuffers(n)}}var ZHt=new ao;Vh.prototype.clear=function(t,e){t=f(t,ZHt),e=f(e,this._defaultPassState);let n=this._gl,i=0,o=t.color,a=t.depth,s=t.stencil;c(o)&&(v.equals(this._clearColor,o)||(v.clone(o,this._clearColor),n.clearColor(o.red,o.green,o.blue,o.alpha)),i|=n.COLOR_BUFFER_BIT),c(a)&&(a!==this._clearDepth&&(this._clearDepth=a,n.clearDepth(a)),i|=n.DEPTH_BUFFER_BIT),c(s)&&(s!==this._clearStencil&&(this._clearStencil=s,n.clearStencil(s)),i|=n.STENCIL_BUFFER_BIT);let l=f(t.renderState,this._defaultRenderState);kpt(this,l,e,!0);let r=f(t.framebuffer,e.framebuffer);a7(this,r),n.clear(i)};function VHt(t,e,n,i,o){a7(t,e),kpt(t,o,n,!1),i._bind(),t._maxFrameTextureUnitIndex=Math.max(t._maxFrameTextureUnitIndex,i.maximumTextureUnitIndex)}function bHt(t,e,n,i){let o=e._primitiveType,a=e._vertexArray,s=e._offset,l=e._count,r=e.instanceCount;t._us.model=f(e._modelMatrix,L.IDENTITY),n._setUniforms(i,t._us,t.validateShaderProgram),a._bind();let d=a.indexBuffer;c(d)?(s=s*d.bytesPerIndex,c(l)?l=Math.min(l,d.numberOfIndices):l=d.numberOfIndices,r===0?t._gl.drawElements(o,l,d.indexDatatype,s):t.glDrawElementsInstanced(o,l,d.indexDatatype,s,r)):(c(l)?l=Math.min(l,a.numberOfVertices):l=a.numberOfVertices,r===0?t._gl.drawArrays(o,s,l):t.glDrawArraysInstanced(o,s,l,r)),a._unBind()}Vh.prototype.draw=function(t,e,n,i){e=f(e,this._defaultPassState);let o=f(t._framebuffer,e.framebuffer),a=f(t._renderState,this._defaultRenderState);n=f(n,t._shaderProgram),i=f(i,t._uniformMap),VHt(this,o,e,n,a),bHt(this,t,n,i)};Vh.prototype.endFrame=function(){let t=this._gl;t.useProgram(null),this._currentFramebuffer=void 0,t.bindFramebuffer(t.FRAMEBUFFER,null);let e=o7;this.drawBuffers&&this.glDrawBuffers(e);let n=this._maxFrameTextureUnitIndex;this._maxFrameTextureUnitIndex=0;for(let i=0;i0&&(l=s.getColorTexture(0).pixelDatatype);let r=Ye.createTypedArray(Ye.RGBA,l,o,a);return a7(this,s),e.readPixels(n,i,o,a,Ye.RGBA,Ue.toWebGLConstant(l,this),r),r};var Ypt={position:0,textureCoordinates:1};Vh.prototype.getViewportQuadVertexArray=function(){let t=this.cache.viewportQuad_vertexArray;if(!c(t)){let e=new _e({attributes:{position:new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:[-1,-1,1,-1,1,1,-1,1]}),textureCoordinates:new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:[0,0,1,0,1,1,0,1]})},indices:new Uint16Array([0,1,2,0,2,3]),primitiveType:le.TRIANGLES});t=Ki.fromGeometry({context:this,geometry:e,attributeLocations:Ypt,bufferUsage:ce.STATIC_DRAW,interleave:!0}),this.cache.viewportQuad_vertexArray=t}return t};Vh.prototype.createViewportQuadCommand=function(t,e){return e=f(e,f.EMPTY_OBJECT),new Ee({vertexArray:this.getViewportQuadVertexArray(),primitiveType:le.TRIANGLES,renderState:e.renderState,shaderProgram:xn.fromCache({context:this,vertexShaderSource:GG,fragmentShaderSource:t,attributeLocations:Ypt}),uniformMap:e.uniformMap,owner:e.owner,framebuffer:e.framebuffer,pass:e.pass})};Vh.prototype.getObjectByPickColor=function(t){return this._pickObjects[t.toRgba()]};function s7(t,e,n){this._pickObjects=t,this.key=e,this.color=n}Object.defineProperties(s7.prototype,{object:{get:function(){return this._pickObjects[this.key]},set:function(t){this._pickObjects[this.key]=t}}});s7.prototype.destroy=function(){delete this._pickObjects[this.key]};Vh.prototype.createPickId=function(t){++this._nextPickColor[0];let e=this._nextPickColor[0];if(e===0)throw new St("Out of unique Pick IDs.");return this._pickObjects[e]=t,new s7(this._pickObjects,e,v.fromRgba(e))};Vh.prototype.isDestroyed=function(){return!1};Vh.prototype.destroy=function(){let t=this.cache;for(let e in t)if(t.hasOwnProperty(e)){let n=t[e];c(n.destroy)&&n.destroy()}return this._shaderCache=this._shaderCache.destroy(),this._textureCache=this._textureCache.destroy(),this._defaultTexture=this._defaultTexture&&this._defaultTexture.destroy(),this._defaultEmissiveTexture=this._defaultEmissiveTexture&&this._defaultEmissiveTexture.destroy(),this._defaultNormalTexture=this._defaultNormalTexture&&this._defaultNormalTexture.destroy(),this._defaultCubeMap=this._defaultCubeMap&&this._defaultCubeMap.destroy(),At(this)};Vh._deprecationWarning=Zr;var a2=Vh;var Jan=R(W(),1);var ban=R(W(),1);function rE(t){t=f(t,f.EMPTY_OBJECT);let e=t.context,n=t.width,i=t.height;this._width=n,this._height=i;let o=t.colorRenderbuffers,a=t.colorTextures;if(c(o)!==c(a))throw new Ut("Both color renderbuffer and texture attachments must be provided.");let s=t.depthStencilRenderbuffer,l=t.depthStencilTexture;if(c(s)!==c(l))throw new Ut("Both depth-stencil renderbuffer and texture attachments must be provided.");this._renderFramebuffer=new Lr({context:e,colorRenderbuffers:o,depthStencilRenderbuffer:s,destroyAttachments:t.destroyAttachments}),this._colorFramebuffer=new Lr({context:e,colorTextures:a,depthStencilTexture:l,destroyAttachments:t.destroyAttachments})}rE.prototype.getRenderFramebuffer=function(){return this._renderFramebuffer};rE.prototype.getColorFramebuffer=function(){return this._colorFramebuffer};rE.prototype.blitFramebuffers=function(t,e){this._renderFramebuffer.bindRead(),this._colorFramebuffer.bindDraw();let n=t._gl,i=0;this._colorFramebuffer._colorTextures.length>0&&(i|=n.COLOR_BUFFER_BIT),c(this._colorFramebuffer.depthStencilTexture)&&(i|=n.DEPTH_BUFFER_BIT|(e?n.STENCIL_BUFFER_BIT:0)),n.blitFramebuffer(0,0,this._width,this._height,0,0,this._width,this._height,i,n.NEAREST),n.bindFramebuffer(n.READ_FRAMEBUFFER,null),n.bindFramebuffer(n.DRAW_FRAMEBUFFER,null)};rE.prototype.isDestroyed=function(){return!1};rE.prototype.destroy=function(){return this._renderFramebuffer.destroy(),this._colorFramebuffer.destroy(),At(this)};var s2=rE;var gan=R(W(),1);var fan=R(W(),1);var Gm={RGBA4:pt.RGBA4,RGBA8:pt.RGBA8,RGBA16F:pt.RGBA16F,RGBA32F:pt.RGBA32F,RGB5_A1:pt.RGB5_A1,RGB565:pt.RGB565,DEPTH_COMPONENT16:pt.DEPTH_COMPONENT16,STENCIL_INDEX8:pt.STENCIL_INDEX8,DEPTH_STENCIL:pt.DEPTH_STENCIL,DEPTH24_STENCIL8:pt.DEPTH24_STENCIL8,validate:function(t){return t===Gm.RGBA4||t===Gm.RGBA8||t===Gm.RGBA16F||t===Gm.RGBA32F||t===Gm.RGB5_A1||t===Gm.RGB565||t===Gm.DEPTH_COMPONENT16||t===Gm.STENCIL_INDEX8||t===Gm.DEPTH_STENCIL||t===Gm.DEPTH24_STENCIL8},getColorFormat:function(t){return t===pt.FLOAT?Gm.RGBA32F:t===pt.HALF_FLOAT_OES?Gm.RGBA16F:Gm.RGBA8}},Sc=Object.freeze(Gm);function l2(t){t=f(t,f.EMPTY_OBJECT);let n=t.context._gl,i=Sn.maximumRenderbufferSize,o=f(t.format,Sc.RGBA4),a=c(t.width)?t.width:n.drawingBufferWidth,s=c(t.height)?t.height:n.drawingBufferHeight,l=f(t.numSamples,1);this._gl=n,this._format=o,this._width=a,this._height=s,this._renderbuffer=this._gl.createRenderbuffer(),n.bindRenderbuffer(n.RENDERBUFFER,this._renderbuffer),l>1?n.renderbufferStorageMultisample(n.RENDERBUFFER,l,o,a,s):n.renderbufferStorage(n.RENDERBUFFER,o,a,s),n.bindRenderbuffer(n.RENDERBUFFER,null)}Object.defineProperties(l2.prototype,{format:{get:function(){return this._format}},width:{get:function(){return this._width}},height:{get:function(){return this._height}}});l2.prototype._getRenderbuffer=function(){return this._renderbuffer};l2.prototype.isDestroyed=function(){return!1};l2.prototype.destroy=function(){return this._gl.deleteRenderbuffer(this._renderbuffer),At(this)};var bh=l2;function Kl(t){t=f(t,f.EMPTY_OBJECT),this._numSamples=f(t.numSamples,1),this._colorAttachmentsLength=f(t.colorAttachmentsLength,1),this._color=f(t.color,!0),this._depth=f(t.depth,!1),this._depthStencil=f(t.depthStencil,!1),this._supportsDepthTexture=f(t.supportsDepthTexture,!1),this._createColorAttachments=f(t.createColorAttachments,!0),this._createDepthAttachments=f(t.createDepthAttachments,!0),this._pixelDatatype=t.pixelDatatype,this._pixelFormat=t.pixelFormat,this._width=void 0,this._height=void 0,this._framebuffer=void 0,this._multisampleFramebuffer=void 0,this._colorTextures=void 0,this._color&&(this._colorTextures=new Array(this._colorAttachmentsLength),this._colorRenderbuffers=new Array(this._colorAttachmentsLength)),this._colorRenderbuffer=void 0,this._depthStencilRenderbuffer=void 0,this._depthStencilTexture=void 0,this._depthRenderbuffer=void 0,this._depthTexture=void 0,this._attachmentsDirty=!1}Object.defineProperties(Kl.prototype,{framebuffer:{get:function(){return this._numSamples>1?this._multisampleFramebuffer.getRenderFramebuffer():this._framebuffer}},numSamples:{get:function(){return this._numSamples}},status:{get:function(){return this.framebuffer.status}}});Kl.prototype.isDirty=function(t,e,n,i,o){n=f(n,1);let a=this._width!==t||this._height!==e,s=this._numSamples!==n,l=c(i)&&this._pixelDatatype!==i||c(o)&&this._pixelFormat!==o,r=n===1?c(this._framebuffer):c(this._multisampleFramebuffer);return this._attachmentsDirty||a||s||l||!r||this._color&&!c(this._colorTextures[0])};Kl.prototype.update=function(t,e,n,i,o,a){if(i=t.msaa?f(i,1):1,o=f(o,this._color?f(this._pixelDatatype,Ue.UNSIGNED_BYTE):void 0),a=f(a,this._color?f(this._pixelFormat,Ye.RGBA):void 0),this.isDirty(e,n,i,o,a)){if(this.destroy(),this._width=e,this._height=n,this._numSamples=i,this._pixelDatatype=o,this._pixelFormat=a,this._attachmentsDirty=!1,this._color&&this._createColorAttachments){for(let s=0;s1){let l=Sc.getColorFormat(o);this._colorRenderbuffers[s]=new bh({context:t,width:e,height:n,format:l,numSamples:this._numSamples})}}this._depthStencil&&this._createDepthAttachments&&(this._supportsDepthTexture&&t.depthTexture?(this._depthStencilTexture=new hn({context:t,width:e,height:n,pixelFormat:Ye.DEPTH_STENCIL,pixelDatatype:Ue.UNSIGNED_INT_24_8,sampler:Hn.NEAREST}),this._numSamples>1&&(this._depthStencilRenderbuffer=new bh({context:t,width:e,height:n,format:Sc.DEPTH24_STENCIL8,numSamples:this._numSamples}))):this._depthStencilRenderbuffer=new bh({context:t,width:e,height:n,format:Sc.DEPTH_STENCIL})),this._depth&&this._createDepthAttachments&&(this._supportsDepthTexture&&t.depthTexture?this._depthTexture=new hn({context:t,width:e,height:n,pixelFormat:Ye.DEPTH_COMPONENT,pixelDatatype:Ue.UNSIGNED_INT,sampler:Hn.NEAREST}):this._depthRenderbuffer=new bh({context:t,width:e,height:n,format:Sc.DEPTH_COMPONENT16})),this._numSamples>1?this._multisampleFramebuffer=new s2({context:t,width:this._width,height:this._height,colorTextures:this._colorTextures,colorRenderbuffers:this._colorRenderbuffers,depthStencilTexture:this._depthStencilTexture,depthStencilRenderbuffer:this._depthStencilRenderbuffer,destroyAttachments:!1}):this._framebuffer=new Lr({context:t,colorTextures:this._colorTextures,depthTexture:this._depthTexture,depthRenderbuffer:this._depthRenderbuffer,depthStencilTexture:this._depthStencilTexture,depthStencilRenderbuffer:this._depthStencilRenderbuffer,destroyAttachments:!1})}};Kl.prototype.getColorTexture=function(t){return t=f(t,0),this._colorTextures[t]};Kl.prototype.setColorTexture=function(t,e){e=f(e,0),this._attachmentsDirty=t!==this._colorTextures[e],this._colorTextures[e]=t};Kl.prototype.getColorRenderbuffer=function(t){return t=f(t,0),this._colorRenderbuffers[t]};Kl.prototype.setColorRenderbuffer=function(t,e){e=f(e,0),this._attachmentsDirty=t!==this._colorRenderbuffers[e],this._colorRenderbuffers[e]=t};Kl.prototype.getDepthRenderbuffer=function(){return this._depthRenderbuffer};Kl.prototype.setDepthRenderbuffer=function(t){this._attachmentsDirty=t!==this._depthRenderbuffer,this._depthRenderbuffer=t};Kl.prototype.getDepthTexture=function(){return this._depthTexture};Kl.prototype.setDepthTexture=function(t){this._attachmentsDirty=t!==this._depthTexture,this._depthTexture=t};Kl.prototype.getDepthStencilRenderbuffer=function(){return this._depthStencilRenderbuffer};Kl.prototype.setDepthStencilRenderbuffer=function(t){this._attachmentsDirty=t!==this._depthStencilRenderbuffer,this._depthStencilRenderbuffer=t};Kl.prototype.getDepthStencilTexture=function(){return this._depthStencilTexture};Kl.prototype.setDepthStencilTexture=function(t){this._attachmentsDirty=t!==this._depthStencilTexture,this._depthStencilTexture=t};Kl.prototype.prepareTextures=function(t,e){this._numSamples>1&&this._multisampleFramebuffer.blitFramebuffers(t,e)};Kl.prototype.clear=function(t,e,n){let i=e.framebuffer;e.framebuffer=this.framebuffer,e.execute(t,n),e.framebuffer=i};Kl.prototype.destroyFramebuffer=function(){this._framebuffer=this._framebuffer&&this._framebuffer.destroy(),this._multisampleFramebuffer=this._multisampleFramebuffer&&this._multisampleFramebuffer.destroy()};Kl.prototype.destroy=function(){if(this._color){let t,e=this._colorTextures.length;for(t=0;t0?it.getSizeInBytes(t[0].componentDatatype):0,o=i>0?e%i:0,a=o===0?0:i-o;return e+=a,e};Rr._createArrayViews=function(t,e){let n=[],i=0,o=t.length;for(let a=0;a0){let n=new ArrayBuffer(e*t.vertexSizeInBytes);if(c(t.arrayBuffer)){let a=new Uint8Array(n),s=new Uint8Array(t.arrayBuffer),l=s.length;for(let r=0;r0){e.needsCommit=!1;let n=e.vertexBuffer,i=t._size*e.vertexSizeInBytes,o=c(n);if(!o||n.sizeInBytes0){let i=t.vertexSizeInBytes*e,o=t.vertexSizeInBytes*n;t.vertexBuffer.copyFromArrayView(new Uint8Array(t.arrayBuffer,i,o),i)}}Rr.prototype.endSubCommits=function(){let t=this._allBuffers;for(let e=0,n=t.length;e0&&(this._hash={},t.length=0)};var qe=CG;var xsn=R(W(),1);function Rh(t,e){t=f(t,0),this._near=t,e=f(e,Number.MAX_VALUE),this._far=e}Object.defineProperties(Rh.prototype,{near:{get:function(){return this._near},set:function(t){this._near=t}},far:{get:function(){return this._far},set:function(t){this._far=t}}});Rh.packedLength=2;Rh.pack=function(t,e,n){return n=f(n,0),e[n++]=t.near,e[n]=t.far,e};Rh.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Rh),n.near=t[e++],n.far=t[e],n};Rh.equals=function(t,e){return t===e||c(t)&&c(e)&&t.near===e.near&&t.far===e.far};Rh.clone=function(t,e){if(c(t))return c(e)||(e=new Rh),e.near=t.near,e.far=t.far,e};Rh.prototype.clone=function(t){return Rh.clone(this,t)};Rh.prototype.equals=function(t){return Rh.equals(this,t)};var Wn=Rh;var Msn=R(W(),1);function Ip(t,e,n,i){this.near=f(t,0),this.nearValue=f(e,0),this.far=f(n,1),this.farValue=f(i,0)}Ip.clone=function(t,e){if(c(t))return c(e)?(e.near=t.near,e.nearValue=t.nearValue,e.far=t.far,e.farValue=t.farValue,e):new Ip(t.near,t.nearValue,t.far,t.farValue)};Ip.packedLength=4;Ip.pack=function(t,e,n){return n=f(n,0),e[n++]=t.near,e[n++]=t.nearValue,e[n++]=t.far,e[n]=t.farValue,e};Ip.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Ip),n.near=t[e++],n.nearValue=t[e++],n.far=t[e++],n.farValue=t[e],n};Ip.equals=function(t,e){return t===e||c(t)&&c(e)&&t.near===e.near&&t.nearValue===e.nearValue&&t.far===e.far&&t.farValue===e.farValue};Ip.prototype.clone=function(t){return Ip.clone(this,t)};Ip.prototype.equals=function(t){return Ip.equals(this,t)};var ln=Ip;var Dsn=R(W(),1),IG={NONE:0,CLAMP_TO_GROUND:1,RELATIVE_TO_GROUND:2,CLAMP_TO_TERRAIN:3,RELATIVE_TO_TERRAIN:4,CLAMP_TO_3D_TILE:5,RELATIVE_TO_3D_TILE:6},Ge=Object.freeze(IG);function Np(t){return t===IG.CLAMP_TO_GROUND||t===IG.CLAMP_TO_3D_TILE||t===IG.CLAMP_TO_TERRAIN}function dE(t){return t===IG.RELATIVE_TO_GROUND||t===IG.RELATIVE_TO_3D_TILE||t===IG.RELATIVE_TO_TERRAIN}var Hsn=R(W(),1),EHt={CENTER:0,LEFT:1,RIGHT:-1},to=Object.freeze(EHt);var Psn=R(W(),1),CHt={CENTER:0,BOTTOM:1,BASELINE:2,TOP:-1},hi=Object.freeze(CHt);var Ksn=R(W(),1),IHt={DONE:0,PENDING:1,FAILED:2},ve=Object.freeze(IHt);var tln=R(W(),1);function $u(){Ut.throwInstantiationError()}Object.defineProperties($u.prototype,{isConstant:{get:Ut.throwInstantiationError},definitionChanged:{get:Ut.throwInstantiationError}});$u.prototype.getValue=Ut.throwInstantiationError;$u.prototype.equals=Ut.throwInstantiationError;$u.equals=function(t,e){return t===e||c(t)&&t.equals(e)};$u.arrayEquals=function(t,e){if(t===e)return!0;if(!c(t)||!c(e)||t.length!==e.length)return!1;let n=t.length;for(let i=0;i-1;o--)a=e[o],c(a._billboard)&&c(a._position)&&s.set(a.id,new xpt(a));for(o=i.length-1;o>-1;o--)a=i[o],c(a._billboard)&&c(a._position)?s.contains(a.id)||s.set(a.id,new xpt(a)):(c7(s.get(a.id),a,l),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],c7(s.get(a.id),a,l),s.remove(a.id)};function c7(t,e,n){c(t)&&(t.billboard=void 0,n.removeBillboard(e))}var h2=Wf;var pAn=R(W(),1);var ern=R(W(),1);var Bln=R(W(),1);var Wln=R(W(),1);function zHt(t,e){this.start=f(t,0),this.stop=f(e,0)}var hd=zHt;function oi(t,e){this.center=p.clone(f(t,p.ZERO)),this.radius=f(e,0)}var p7=new p,u7=new p,Z7=new p,V7=new p,b7=new p,R7=new p,W7=new p,_r=new p,f7=new p,F7=new p,U7=new p,G7=new p,jHt=4/3*k.PI;oi.fromPoints=function(t,e){if(c(e)||(e=new oi),!c(t)||t.length===0)return e.center=p.clone(p.ZERO,e.center),e.radius=0,e;let n=p.clone(t[0],W7),i=p.clone(n,p7),o=p.clone(n,u7),a=p.clone(n,Z7),s=p.clone(n,V7),l=p.clone(n,b7),r=p.clone(n,R7),d=t.length,m;for(m=1;ms.x&&p.clone(n,s),Jl.y&&p.clone(n,l),Mr.z&&p.clone(n,r)}let h=p.magnitudeSquared(p.subtract(s,i,_r)),Z=p.magnitudeSquared(p.subtract(l,o,_r)),b=p.magnitudeSquared(p.subtract(r,a,_r)),u=i,F=s,U=h;Z>U&&(U=Z,u=o,F=l),b>U&&(U=b,u=a,F=r);let G=f7;G.x=(u.x+F.x)*.5,G.y=(u.y+F.y)*.5,G.z=(u.z+F.z)*.5;let A=p.magnitudeSquared(p.subtract(F,G,_r)),T=Math.sqrt(A),g=F7;g.x=i.x,g.y=o.y,g.z=a.z;let C=U7;C.x=s.x,C.y=l.y,C.z=r.z;let y=p.midpoint(g,C,G7),Y=0;for(m=0;mY&&(Y=Q);let J=p.magnitudeSquared(p.subtract(n,G,_r));if(J>A){let M=Math.sqrt(J);T=(T+M)*.5,A=T*T;let V=M-T;G.x=(T*G.x+V*n.x)/M,G.y=(T*G.y+V*n.y)/M,G.z=(T*G.z+V*n.z)/M}}return Tr.x&&p.clone(o,r),Vd.y&&p.clone(o,d),Em.z&&p.clone(o,m)}let b=p.magnitudeSquared(p.subtract(r,a,_r)),u=p.magnitudeSquared(p.subtract(d,s,_r)),F=p.magnitudeSquared(p.subtract(m,l,_r)),U=a,G=r,A=b;u>A&&(A=u,U=s,G=d),F>A&&(A=F,U=l,G=m);let T=f7;T.x=(U.x+G.x)*.5,T.y=(U.y+G.y)*.5,T.z=(U.z+G.z)*.5;let g=p.magnitudeSquared(p.subtract(G,T,_r)),C=Math.sqrt(g),y=F7;y.x=a.x,y.y=s.y,y.z=l.z;let Y=U7;Y.x=r.x,Y.y=d.y,Y.z=m.z;let Q=p.midpoint(y,Y,G7),J=0;for(Z=0;ZJ&&(J=M);let V=p.magnitudeSquared(p.subtract(o,T,_r));if(V>g){let E=Math.sqrt(V);C=(C+E)*.5,g=C*C;let I=E-C;T.x=(C*T.x+I*o.x)/E,T.y=(C*T.y+I*o.y)/E,T.z=(C*T.z+I*o.z)/E}}return Cl.x&&p.clone(i,l),Mr.y&&p.clone(i,r),Vd.z&&p.clone(i,d)}let Z=p.magnitudeSquared(p.subtract(l,o,_r)),b=p.magnitudeSquared(p.subtract(r,a,_r)),u=p.magnitudeSquared(p.subtract(d,s,_r)),F=o,U=l,G=Z;b>G&&(G=b,F=a,U=r),u>G&&(G=u,F=s,U=d);let A=f7;A.x=(F.x+U.x)*.5,A.y=(F.y+U.y)*.5,A.z=(F.z+U.z)*.5;let T=p.magnitudeSquared(p.subtract(U,A,_r)),g=Math.sqrt(T),C=F7;C.x=o.x,C.y=a.y,C.z=s.z;let y=U7;y.x=l.x,y.y=r.y,y.z=d.z;let Y=p.midpoint(C,y,G7),Q=0;for(h=0;hQ&&(Q=J);let M=p.magnitudeSquared(p.subtract(i,A,_r));if(M>T){let V=Math.sqrt(M);g=(g+V)*.5,T=g*g;let E=V-g;A.x=(g*A.x+E*i.x)/V,A.y=(g*A.y+E*i.y)/V,A.z=(g*A.z+E*i.z)/V}}return g=r+s)return t.clone(n),n;if(s>=r+o)return e.clone(n),n;let d=(o+r+s)*.5,m=p.multiplyByScalar(l,(-o+d)/r,dwt);return p.add(m,i,m),p.clone(m,n.center),n.radius=d,n};var cwt=new p;oi.expand=function(t,e,n){n=oi.clone(t,n);let i=p.magnitude(p.subtract(e,n.center,cwt));return i>n.radius&&(n.radius=i),n};oi.intersectPlane=function(t,e){let n=t.center,i=t.radius,o=e.normal,a=p.dot(o,n)+e.distance;return a<-i?yn.OUTSIDE:a-1&&i.derivedKeywords.splice(s,1)}return this.createDerivedShaderProgram(t,e,n)};jV.prototype.getDerivedShaderProgram=function(t,e){let n=t._cachedShader,i=e+n.keyword,o=this._shaders[i];if(c(o))return o.shaderProgram};jV.prototype.createDerivedShaderProgram=function(t,e,n){let i=t._cachedShader,o=e+i.keyword,a=n.vertexShaderSource,s=n.fragmentShaderSource,l=n.attributeLocations;typeof a=="string"&&(a=new Ze({sources:[a]})),typeof s=="string"&&(s=new Ze({sources:[s]}));let r=this._context,d=a.createCombinedVertexShader(r),m=s.createCombinedFragmentShader(r),h=new xn({gl:r._gl,logShaderCompilation:r.logShaderCompilation,debugShaders:r.debugShaders,vertexShaderSource:a,vertexShaderText:d,fragmentShaderSource:s,fragmentShaderText:m,attributeLocations:l}),u={cache:this,shaderProgram:h,keyword:o,derivedKeywords:[],count:0};return i.derivedKeywords.push(e),h._cachedShader=u,this._shaders[o]=u,h};function $6(t,e){let n=e.derivedKeywords,i=n.length;for(let o=0;o=0?(n=Math.floor(t/65536)*65536,e.high=n,e.low=t-n):(n=Math.floor(-t/65536)*65536,e.high=-n,e.low=t+n),e};var Tb={high:0,low:0};LZ.fromCartesian=function(t,e){c(e)||(e=new LZ);let n=e.high,i=e.low;return LZ.encode(t.x,Tb),n.x=Tb.high,i.x=Tb.low,LZ.encode(t.y,Tb),n.y=Tb.high,i.y=Tb.low,LZ.encode(t.z,Tb),n.z=Tb.high,i.z=Tb.low,e};var t7=new LZ;LZ.writeElements=function(t,e,n){LZ.fromCartesian(t,t7);let i=t7.high,o=t7.low;e[n]=i.x,e[n+1]=i.y,e[n+2]=i.z,e[n+3]=o.x,e[n+4]=o.y,e[n+5]=o.z};var Mi=LZ;var Xin=b(W(),1);var yin=b(W(),1);var Gin=b(W(),1);var uin=b(W(),1);function Rr(t,e){this.normal=p.clone(t),this.distance=e}Rr.fromPointNormal=function(t,e,n){let i=-p.dot(e,t);return c(n)?(p.clone(e,n.normal),n.distance=i,n):new Rr(e,i)};var bDt=new p;Rr.fromCartesian4=function(t,e){let n=p.fromCartesian4(t,bDt),i=t.w;return c(e)?(p.clone(n,e.normal),e.distance=i,e):new Rr(n,i)};Rr.getPointDistance=function(t,e){return p.dot(t.normal,e)+t.distance};var WDt=new p;Rr.projectPointOntoPlane=function(t,e,n){c(n)||(n=new p);let i=Rr.getPointDistance(t,e),o=p.multiplyByScalar(t.normal,i,WDt);return p.subtract(e,o,n)};var fDt=new L,FDt=new bt,UDt=new p;Rr.transform=function(t,e,n){let i=t.normal,o=t.distance,a=L.inverseTranspose(e,fDt),s=bt.fromElements(i.x,i.y,i.z,o,FDt);s=L.multiplyByVector(a,s,s);let l=p.fromCartesian4(s,UDt);return s=bt.divideByScalar(s,p.magnitude(l),s),Rr.fromCartesian4(s,n)};Rr.clone=function(t,e){return c(e)?(p.clone(t.normal,e.normal),e.distance=t.distance,e):new Rr(t.normal,t.distance)};Rr.equals=function(t,e){return t.distance===e.distance&&p.equals(t.normal,e.normal)};Rr.ORIGIN_XY_PLANE=Object.freeze(new Rr(p.UNIT_Z,0));Rr.ORIGIN_YZ_PLANE=Object.freeze(new Rr(p.UNIT_X,0));Rr.ORIGIN_ZX_PLANE=Object.freeze(new Rr(p.UNIT_Y,0));var Kn=Rr;function Ep(t){this.planes=f(t,[])}var ek=[new p,new p,new p];p.clone(p.UNIT_X,ek[0]);p.clone(p.UNIT_Y,ek[1]);p.clone(p.UNIT_Z,ek[2]);var Zf=new p,GDt=new p,opt=new Kn(new p(1,0,0),0);Ep.fromBoundingSphere=function(t,e){c(e)||(e=new Ep);let n=ek.length,i=e.planes;i.length=2*n;let o=t.center,a=t.radius,s=0;for(let l=0;lQDt;++a){o=i;let s=o-e*Math.sin(o)-t,l=1-e*Math.cos(o);i=o-s/l}return o=i+n*k.TWO_PI,o}function YDt(t,e){let n=Math.floor(t/k.TWO_PI);t-=n*k.TWO_PI;let i=Math.cos(t)-e,o=Math.sin(t)*Math.sqrt(1-e*e),a=Math.atan2(o,i);return a=k.zeroToTwoPi(a),t<0&&(a-=k.TWO_PI),a+=n*k.TWO_PI,a}function xDt(t,e,n,i){let o=Math.cos(t),a=Math.sin(t),s=Math.cos(e),l=Math.sin(e),r=Math.cos(n),d=Math.sin(n);return c(i)?(i[0]=r*o-d*a*s,i[1]=d*o+r*a*s,i[2]=a*l,i[3]=-r*a-d*o*s,i[4]=-d*a+r*o*s,i[5]=o*l,i[6]=d*l,i[7]=-r*l,i[8]=s):i=new ot(r*o-d*a*s,-r*a-d*o*s,d*l,d*o+r*a*s,-d*a+r*o*s,-r*l,a*l,o*l,s),i}var XDt=1.0000010178*md,JDt=100.46645683*Cp,LDt=129597742283429e-5*uh,lpt=16002,rpt=21863,dpt=32004,cpt=10931,mpt=14529,hpt=16368,ppt=15318,Vpt=32794,MDt=64*1e-7*md,_Dt=-152*1e-7*md,DDt=62*1e-7*md,ODt=-8*1e-7*md,HDt=32*1e-7*md,wDt=-41*1e-7*md,PDt=19*1e-7*md,vDt=-11*1e-7*md,KDt=-150*1e-7*md,zDt=-46*1e-7*md,jDt=68*1e-7*md,qDt=54*1e-7*md,$Dt=14*1e-7*md,tOt=24*1e-7*md,eOt=-28*1e-7*md,nOt=22*1e-7*md,upt=10,Zpt=16002,Rpt=21863,bpt=10931,Wpt=1473,fpt=32004,Fpt=4387,Upt=73,iOt=-325*1e-7,oOt=-322*1e-7,aOt=-79*1e-7,sOt=232*1e-7,lOt=-52*1e-7,rOt=97*1e-7,dOt=55*1e-7,cOt=-41*1e-7,mOt=-105*1e-7,hOt=-137*1e-7,pOt=258*1e-7,VOt=35*1e-7,uOt=-116*1e-7,ZOt=-88*1e-7,ROt=-112*1e-7,bOt=-80*1e-7,sE=new rt(0,0,Di.TAI);function WOt(t,e){Apt(t,sE);let i=(sE.dayNumber-LH.dayNumber+(sE.secondsOfDay-LH.secondsOfDay)/xi.SECONDS_PER_DAY)/(xi.DAYS_PER_JULIAN_CENTURY*10),o=.3595362*i,a=XDt+MDt*Math.cos(lpt*o)+KDt*Math.sin(lpt*o)+_Dt*Math.cos(rpt*o)+zDt*Math.sin(rpt*o)+DDt*Math.cos(dpt*o)+jDt*Math.sin(dpt*o)+ODt*Math.cos(cpt*o)+qDt*Math.sin(cpt*o)+HDt*Math.cos(mpt*o)+$Dt*Math.sin(mpt*o)+wDt*Math.cos(hpt*o)+tOt*Math.sin(hpt*o)+PDt*Math.cos(ppt*o)+eOt*Math.sin(ppt*o)+vDt*Math.cos(Vpt*o)+nOt*Math.sin(Vpt*o),s=JDt+LDt*i+iOt*Math.cos(upt*o)+mOt*Math.sin(upt*o)+oOt*Math.cos(Zpt*o)+hOt*Math.sin(Zpt*o)+aOt*Math.cos(Rpt*o)+pOt*Math.sin(Rpt*o)+sOt*Math.cos(bpt*o)+VOt*Math.sin(bpt*o)+lOt*Math.cos(Wpt*o)+uOt*Math.sin(Wpt*o)+rOt*Math.cos(fpt*o)+ZOt*Math.sin(fpt*o)+dOt*Math.cos(Fpt*o)+ROt*Math.sin(Fpt*o)+cOt*Math.cos(Upt*o)+bOt*Math.sin(Upt*o),l=.0167086342-.0004203654*i,r=102.93734808*Cp+11612.3529*uh*i,d=469.97289*uh*i,m=174.87317577*Cp-8679.27034*uh*i;return Spt(a,l,d,r,m,s,e)}function Tpt(t,e){Apt(t,sE);let i=(sE.dayNumber-LH.dayNumber+(sE.secondsOfDay-LH.secondsOfDay)/xi.SECONDS_PER_DAY)/xi.DAYS_PER_JULIAN_CENTURY,o=i*i,a=o*i,s=a*i,l=383397.7725+.004*i,r=.055545526-16e-9*i,d=5.15668983*Cp,m=-8e-5*i+.02966*o-42e-6*a-13e-8*s,h=83.35324312*Cp,u=146434202669e-4*i-38.2702*o-.045047*a+21301e-8*s,R=125.04455501*Cp,V=-69679193631e-4*i+6.3602*o+.007625*a-3586e-8*s,F=218.31664563*Cp,U=17325593434847e-4*i-6.391*o+.006588*a-3169e-8*s,G=297.85019547*Cp+uh*(1602961601209e-3*i-6.3706*o+.006593*a-3169e-8*s),A=93.27209062*Cp+uh*(17395272628478e-4*i-12.7512*o-.001037*a+417e-8*s),S=134.96340251*Cp+uh*(17179159232178e-4*i+31.8792*o+.051635*a-2447e-7*s),g=357.52910918*Cp+uh*(1295965810481e-4*i-.5532*o+136e-6*a-1149e-8*s),C=310.17137918*Cp-uh*(6967051436e-3*i+6.2068*o+.007618*a-3219e-8*s),y=2*G,Y=4*G,Q=6*G,J=2*S,M=3*S,Z=4*S,E=2*A;l+=3400.4*Math.cos(y)-635.6*Math.cos(y-S)-235.6*Math.cos(S)+218.1*Math.cos(y-g)+181*Math.cos(y+S),r+=.014216*Math.cos(y-S)+.008551*Math.cos(y-J)-.001383*Math.cos(S)+.001356*Math.cos(y+S)-.001147*Math.cos(Y-M)-914e-6*Math.cos(Y-J)+869e-6*Math.cos(y-g-S)-627e-6*Math.cos(y)-394e-6*Math.cos(Y-Z)+282e-6*Math.cos(y-g-J)-279e-6*Math.cos(G-S)-236e-6*Math.cos(J)+231e-6*Math.cos(Y)+229e-6*Math.cos(Q-Z)-201e-6*Math.cos(J-E),m+=486.26*Math.cos(y-E)-40.13*Math.cos(y)+37.51*Math.cos(E)+25.73*Math.cos(J-E)+19.97*Math.cos(y-g-E),u+=-55609*Math.sin(y-S)-34711*Math.sin(y-J)-9792*Math.sin(S)+9385*Math.sin(Y-M)+7505*Math.sin(Y-J)+5318*Math.sin(y+S)+3484*Math.sin(Y-Z)-3417*Math.sin(y-g-S)-2530*Math.sin(Q-Z)-2376*Math.sin(y)-2075*Math.sin(y-M)-1883*Math.sin(J)-1736*Math.sin(Q-5*S)+1626*Math.sin(g)-1370*Math.sin(Q-M),V+=-5392*Math.sin(y-E)-540*Math.sin(g)-441*Math.sin(y)+423*Math.sin(E)-288*Math.sin(J-E),U+=-3332.9*Math.sin(y)+1197.4*Math.sin(y-S)-662.5*Math.sin(g)+396.3*Math.sin(S)-218*Math.sin(y-g);let I=2*C,B=3*C;m+=46.997*Math.cos(C)*i-.614*Math.cos(y-E+C)*i+.614*Math.cos(y-E-C)*i-.0297*Math.cos(I)*o-.0335*Math.cos(C)*o+.0012*Math.cos(y-E+I)*o-16e-5*Math.cos(C)*a+4e-5*Math.cos(B)*a+4e-5*Math.cos(I)*a;let X=2.116*Math.sin(C)*i-.111*Math.sin(y-E-C)*i-.0015*Math.sin(C)*o;u+=X,U+=X,V+=-520.77*Math.sin(C)*i+13.66*Math.sin(y-E+C)*i+1.12*Math.sin(y-C)*i-1.06*Math.sin(E-C)*i+.66*Math.sin(I)*o+.371*Math.sin(C)*o-.035*Math.sin(y-E+I)*o-.015*Math.sin(y-E+C)*o+.0014*Math.sin(C)*a-.0011*Math.sin(B)*a-9e-4*Math.sin(I)*a,l*=IDt;let _=d+m*uh,P=h+u*uh,w=F+U*uh,z=R+V*uh;return Spt(l,r,_,P,z,w,e)}var Gpt=.012300034,fOt=Gpt/(Gpt+1)*-1;function FOt(t,e){return e=Tpt(t,e),p.multiplyByScalar(e,fOt,e)}var gpt=new ot(1.0000000000000002,5619723173785822e-31,4690511510146299e-34,-5154129427414611e-31,.9174820620691819,-.39777715593191376,-223970096136568e-30,.39777715593191376,.9174820620691819),nk=new p;n7.computeSunPositionInEarthInertialFrame=function(t,e){return c(t)||(t=rt.now()),c(e)||(e=new p),nk=WOt(t,nk),e=p.negate(nk,e),FOt(t,nk),p.subtract(e,nk,e),ot.multiplyByVector(gpt,e,e),e};n7.computeMoonPositionInEarthInertialFrame=function(t,e){return c(t)||(t=rt.now()),e=Tpt(t,e),ot.multiplyByVector(gpt,e,e),e};var _Z=n7;var Kin=b(W(),1),MH={MORPHING:0,COLUMBUS_VIEW:1,SCENE2D:2,SCENE3D:3};MH.getMorphTime=function(t){return t===MH.SCENE3D?1:t===MH.MORPHING?void 0:0};var Vt=Object.freeze(MH);var $in=b(W(),1);function UOt(t){t=f(t,f.EMPTY_OBJECT),this.color=v.clone(f(t.color,v.WHITE)),this.intensity=f(t.intensity,2)}var gb=UOt;function lE(){this.globeDepthTexture=void 0,this.gamma=void 0,this._viewport=new Fe,this._viewportCartesian4=new bt,this._viewportDirty=!1,this._viewportOrthographicMatrix=L.clone(L.IDENTITY),this._viewportTransformation=L.clone(L.IDENTITY),this._model=L.clone(L.IDENTITY),this._view=L.clone(L.IDENTITY),this._inverseView=L.clone(L.IDENTITY),this._projection=L.clone(L.IDENTITY),this._infiniteProjection=L.clone(L.IDENTITY),this._entireFrustum=new K,this._currentFrustum=new K,this._frustumPlanes=new bt,this._farDepthFromNearPlusOne=void 0,this._log2FarDepthFromNearPlusOne=void 0,this._oneOverLog2FarDepthFromNearPlusOne=void 0,this._frameState=void 0,this._temeToPseudoFixed=ot.clone(L.IDENTITY),this._view3DDirty=!0,this._view3D=new L,this._inverseView3DDirty=!0,this._inverseView3D=new L,this._inverseModelDirty=!0,this._inverseModel=new L,this._inverseTransposeModelDirty=!0,this._inverseTransposeModel=new ot,this._viewRotation=new ot,this._inverseViewRotation=new ot,this._viewRotation3D=new ot,this._inverseViewRotation3D=new ot,this._inverseProjectionDirty=!0,this._inverseProjection=new L,this._modelViewDirty=!0,this._modelView=new L,this._modelView3DDirty=!0,this._modelView3D=new L,this._modelViewRelativeToEyeDirty=!0,this._modelViewRelativeToEye=new L,this._inverseModelViewDirty=!0,this._inverseModelView=new L,this._inverseModelView3DDirty=!0,this._inverseModelView3D=new L,this._viewProjectionDirty=!0,this._viewProjection=new L,this._inverseViewProjectionDirty=!0,this._inverseViewProjection=new L,this._modelViewProjectionDirty=!0,this._modelViewProjection=new L,this._inverseModelViewProjectionDirty=!0,this._inverseModelViewProjection=new L,this._modelViewProjectionRelativeToEyeDirty=!0,this._modelViewProjectionRelativeToEye=new L,this._modelViewInfiniteProjectionDirty=!0,this._modelViewInfiniteProjection=new L,this._normalDirty=!0,this._normal=new ot,this._normal3DDirty=!0,this._normal3D=new ot,this._inverseNormalDirty=!0,this._inverseNormal=new ot,this._inverseNormal3DDirty=!0,this._inverseNormal3D=new ot,this._encodedCameraPositionMCDirty=!0,this._encodedCameraPositionMC=new Mi,this._cameraPosition=new p,this._sunPositionWC=new p,this._sunPositionColumbusView=new p,this._sunDirectionWC=new p,this._sunDirectionEC=new p,this._moonDirectionEC=new p,this._lightDirectionWC=new p,this._lightDirectionEC=new p,this._lightColor=new p,this._lightColorHdr=new p,this._pass=void 0,this._mode=void 0,this._mapProjection=void 0,this._ellipsoid=void 0,this._cameraDirection=new p,this._cameraRight=new p,this._cameraUp=new p,this._frustum2DWidth=0,this._eyeHeight=0,this._eyeHeight2D=new K,this._eyeEllipsoidNormalEC=new p,this._eyeEllipsoidCurvature=new K,this._modelToEnu=new L,this._enuToModel=new L,this._pixelRatio=1,this._orthographicIn3D=!1,this._backgroundColor=new v,this._brdfLut=void 0,this._environmentMap=void 0,this._sphericalHarmonicCoefficients=void 0,this._specularEnvironmentMaps=void 0,this._specularEnvironmentMapsDimensions=new K,this._specularEnvironmentMapsMaximumLOD=void 0,this._fogDensity=void 0,this._fogMinimumBrightness=void 0,this._atmosphereHsbShift=void 0,this._atmosphereLightIntensity=void 0,this._atmosphereRayleighCoefficient=new p,this._atmosphereRayleighScaleHeight=new p,this._atmosphereMieCoefficient=new p,this._atmosphereMieScaleHeight=void 0,this._atmosphereMieAnisotropy=void 0,this._atmosphereDynamicLighting=void 0,this._invertClassificationColor=void 0,this._splitPosition=0,this._pixelSizePerMeter=void 0,this._geometricToleranceOverMeter=void 0,this._minimumDisableDepthTestDistance=void 0}Object.defineProperties(lE.prototype,{frameState:{get:function(){return this._frameState}},viewport:{get:function(){return this._viewport},set:function(t){if(!Fe.equals(t,this._viewport)){Fe.clone(t,this._viewport);let e=this._viewport,n=this._viewportCartesian4;n.x=e.x,n.y=e.y,n.z=e.width,n.w=e.height,this._viewportDirty=!0}}},viewportCartesian4:{get:function(){return this._viewportCartesian4}},viewportOrthographic:{get:function(){return Cpt(this),this._viewportOrthographicMatrix}},viewportTransformation:{get:function(){return Cpt(this),this._viewportTransformation}},model:{get:function(){return this._model},set:function(t){L.clone(t,this._model),this._modelView3DDirty=!0,this._inverseModelView3DDirty=!0,this._inverseModelDirty=!0,this._inverseTransposeModelDirty=!0,this._modelViewDirty=!0,this._inverseModelViewDirty=!0,this._modelViewRelativeToEyeDirty=!0,this._inverseModelViewDirty=!0,this._modelViewProjectionDirty=!0,this._inverseModelViewProjectionDirty=!0,this._modelViewProjectionRelativeToEyeDirty=!0,this._modelViewInfiniteProjectionDirty=!0,this._normalDirty=!0,this._inverseNormalDirty=!0,this._normal3DDirty=!0,this._inverseNormal3DDirty=!0,this._encodedCameraPositionMCDirty=!0}},inverseModel:{get:function(){return this._inverseModelDirty&&(this._inverseModelDirty=!1,L.inverse(this._model,this._inverseModel)),this._inverseModel}},inverseTransposeModel:{get:function(){let t=this._inverseTransposeModel;return this._inverseTransposeModelDirty&&(this._inverseTransposeModelDirty=!1,L.getMatrix3(this.inverseModel,t),ot.transpose(t,t)),t}},view:{get:function(){return this._view}},view3D:{get:function(){return i7(this),this._view3D}},viewRotation:{get:function(){return i7(this),this._viewRotation}},viewRotation3D:{get:function(){return i7(this),this._viewRotation3D}},inverseView:{get:function(){return this._inverseView}},inverseView3D:{get:function(){return ypt(this),this._inverseView3D}},inverseViewRotation:{get:function(){return this._inverseViewRotation}},inverseViewRotation3D:{get:function(){return ypt(this),this._inverseViewRotation3D}},projection:{get:function(){return this._projection}},inverseProjection:{get:function(){return BOt(this),this._inverseProjection}},infiniteProjection:{get:function(){return this._infiniteProjection}},modelView:{get:function(){return QOt(this),this._modelView}},modelView3D:{get:function(){return kOt(this),this._modelView3D}},modelViewRelativeToEye:{get:function(){return MOt(this),this._modelViewRelativeToEye}},inverseModelView:{get:function(){return YOt(this),this._inverseModelView}},inverseModelView3D:{get:function(){return xOt(this),this._inverseModelView3D}},viewProjection:{get:function(){return XOt(this),this._viewProjection}},inverseViewProjection:{get:function(){return JOt(this),this._inverseViewProjection}},modelViewProjection:{get:function(){return LOt(this),this._modelViewProjection}},inverseModelViewProjection:{get:function(){return _Ot(this),this._inverseModelViewProjection}},modelViewProjectionRelativeToEye:{get:function(){return DOt(this),this._modelViewProjectionRelativeToEye}},modelViewInfiniteProjection:{get:function(){return OOt(this),this._modelViewInfiniteProjection}},normal:{get:function(){return HOt(this),this._normal}},normal3D:{get:function(){return wOt(this),this._normal3D}},inverseNormal:{get:function(){return POt(this),this._inverseNormal}},inverseNormal3D:{get:function(){return vOt(this),this._inverseNormal3D}},entireFrustum:{get:function(){return this._entireFrustum}},currentFrustum:{get:function(){return this._currentFrustum}},frustumPlanes:{get:function(){return this._frustumPlanes}},farDepthFromNearPlusOne:{get:function(){return this._farDepthFromNearPlusOne}},log2FarDepthFromNearPlusOne:{get:function(){return this._log2FarDepthFromNearPlusOne}},oneOverLog2FarDepthFromNearPlusOne:{get:function(){return this._oneOverLog2FarDepthFromNearPlusOne}},eyeHeight:{get:function(){return this._eyeHeight}},eyeHeight2D:{get:function(){return this._eyeHeight2D}},eyeEllipsoidNormalEC:{get:function(){return this._eyeEllipsoidNormalEC}},eyeEllipsoidCurvature:{get:function(){return this._eyeEllipsoidCurvature}},modelToEnu:{get:function(){return this._modelToEnu}},enuToModel:{get:function(){return this._enuToModel}},sunPositionWC:{get:function(){return this._sunPositionWC}},sunPositionColumbusView:{get:function(){return this._sunPositionColumbusView}},sunDirectionWC:{get:function(){return this._sunDirectionWC}},sunDirectionEC:{get:function(){return this._sunDirectionEC}},moonDirectionEC:{get:function(){return this._moonDirectionEC}},lightDirectionWC:{get:function(){return this._lightDirectionWC}},lightDirectionEC:{get:function(){return this._lightDirectionEC}},lightColor:{get:function(){return this._lightColor}},lightColorHdr:{get:function(){return this._lightColorHdr}},encodedCameraPositionMCHigh:{get:function(){return Npt(this),this._encodedCameraPositionMC.high}},encodedCameraPositionMCLow:{get:function(){return Npt(this),this._encodedCameraPositionMC.low}},temeToPseudoFixedMatrix:{get:function(){return this._temeToPseudoFixed}},pixelRatio:{get:function(){return this._pixelRatio}},fogDensity:{get:function(){return this._fogDensity}},fogMinimumBrightness:{get:function(){return this._fogMinimumBrightness}},atmosphereHsbShift:{get:function(){return this._atmosphereHsbShift}},atmosphereLightIntensity:{get:function(){return this._atmosphereLightIntensity}},atmosphereRayleighCoefficient:{get:function(){return this._atmosphereRayleighCoefficient}},atmosphereRayleighScaleHeight:{get:function(){return this._atmosphereRayleighScaleHeight}},atmosphereMieCoefficient:{get:function(){return this._atmosphereMieCoefficient}},atmosphereMieScaleHeight:{get:function(){return this._atmosphereMieScaleHeight}},atmosphereMieAnisotropy:{get:function(){return this._atmosphereMieAnisotropy}},atmosphereDynamicLighting:{get:function(){return this._atmosphereDynamicLighting}},geometricToleranceOverMeter:{get:function(){return this._geometricToleranceOverMeter}},pass:{get:function(){return this._pass}},backgroundColor:{get:function(){return this._backgroundColor}},brdfLut:{get:function(){return this._brdfLut}},environmentMap:{get:function(){return this._environmentMap}},sphericalHarmonicCoefficients:{get:function(){return this._sphericalHarmonicCoefficients}},specularEnvironmentMaps:{get:function(){return this._specularEnvironmentMaps}},specularEnvironmentMapsDimensions:{get:function(){return this._specularEnvironmentMapsDimensions}},specularEnvironmentMapsMaximumLOD:{get:function(){return this._specularEnvironmentMapsMaximumLOD}},splitPosition:{get:function(){return this._splitPosition}},minimumDisableDepthTestDistance:{get:function(){return this._minimumDisableDepthTestDistance}},invertClassificationColor:{get:function(){return this._invertClassificationColor}},orthographicIn3D:{get:function(){return this._orthographicIn3D}},ellipsoid:{get:function(){return f(this._ellipsoid,mt.WGS84)}}});function GOt(t,e){L.clone(e,t._view),L.getMatrix3(e,t._viewRotation),t._view3DDirty=!0,t._inverseView3DDirty=!0,t._modelViewDirty=!0,t._modelView3DDirty=!0,t._modelViewRelativeToEyeDirty=!0,t._inverseModelViewDirty=!0,t._inverseModelView3DDirty=!0,t._viewProjectionDirty=!0,t._inverseViewProjectionDirty=!0,t._modelViewProjectionDirty=!0,t._modelViewProjectionRelativeToEyeDirty=!0,t._modelViewInfiniteProjectionDirty=!0,t._normalDirty=!0,t._inverseNormalDirty=!0,t._normal3DDirty=!0,t._inverseNormal3DDirty=!0}function AOt(t,e){L.clone(e,t._inverseView),L.getMatrix3(e,t._inverseViewRotation)}function SOt(t,e){L.clone(e,t._projection),t._inverseProjectionDirty=!0,t._viewProjectionDirty=!0,t._inverseViewProjectionDirty=!0,t._modelViewProjectionDirty=!0,t._modelViewProjectionRelativeToEyeDirty=!0}function TOt(t,e){L.clone(e,t._infiniteProjection),t._modelViewInfiniteProjectionDirty=!0}var Ept=new p,gOt=new L;function EOt(t,e){p.clone(e.positionWC,t._cameraPosition),p.clone(e.directionWC,t._cameraDirection),p.clone(e.rightWC,t._cameraRight),p.clone(e.upWC,t._cameraUp);let n=t._ellipsoid,i,o=e.positionCartographic;if(c(o)?(t._eyeHeight=o.height,t._eyeEllipsoidNormalEC=n.geodeticSurfaceNormalCartographic(o,t._eyeEllipsoidNormalEC),i=p.fromRadians(o.longitude,o.latitude,0,n,Ept)):(t._eyeHeight=-n.maximumRadius,p.magnitude(e.positionWC)>0&&(t._eyeEllipsoidNormalEC=p.normalize(e.positionWC,t._eyeEllipsoidNormalEC)),i=n.scaleToGeodeticSurface(e.positionWC,Ept)),t._encodedCameraPositionMCDirty=!0,!c(i))return;t._eyeEllipsoidNormalEC=ot.multiplyByVector(t._viewRotation,t._eyeEllipsoidNormalEC,t._eyeEllipsoidNormalEC);let a=Pe.eastNorthUpToFixedFrame(i,n,gOt);t._enuToModel=L.multiplyTransformation(t.inverseModel,a,t._enuToModel),t._modelToEnu=L.inverseTransformation(t._enuToModel,t._modelToEnu),k.equalsEpsilon(n._radii.x,n._radii.y,k.EPSILON15)&&(t._eyeEllipsoidCurvature=n.getLocalCurvature(i,t._eyeEllipsoidCurvature))}var ik=new ot,COt=new gt;function IOt(t,e){c(Pe.computeIcrfToFixedMatrix(e.time,ik))||(ik=Pe.computeTemeToPseudoFixedMatrix(e.time,ik));let n=_Z.computeSunPositionInEarthInertialFrame(e.time,t._sunPositionWC);ot.multiplyByVector(ik,n,n),p.normalize(n,t._sunDirectionWC),n=ot.multiplyByVector(t.viewRotation3D,n,t._sunDirectionEC),p.normalize(n,n),n=_Z.computeMoonPositionInEarthInertialFrame(e.time,t._moonDirectionEC),ot.multiplyByVector(ik,n,n),ot.multiplyByVector(t.viewRotation3D,n,n),p.normalize(n,n);let i=e.mapProjection,a=i.ellipsoid.cartesianToCartographic(t._sunPositionWC,COt);i.project(a,t._sunPositionColumbusView)}lE.prototype.updateCamera=function(t){GOt(this,t.viewMatrix),AOt(this,t.inverseViewMatrix),EOt(this,t),this._entireFrustum.x=t.frustum.near,this._entireFrustum.y=t.frustum.far,this.updateFrustum(t.frustum),this._orthographicIn3D=this._mode!==Vt.SCENE2D&&t.frustum instanceof wn};lE.prototype.updateFrustum=function(t){SOt(this,t.projectionMatrix),c(t.infiniteProjectionMatrix)&&TOt(this,t.infiniteProjectionMatrix),this._currentFrustum.x=t.near,this._currentFrustum.y=t.far,this._farDepthFromNearPlusOne=t.far-t.near+1,this._log2FarDepthFromNearPlusOne=k.log2(this._farDepthFromNearPlusOne),this._oneOverLog2FarDepthFromNearPlusOne=1/this._log2FarDepthFromNearPlusOne;let e=t.offCenterFrustum;c(e)&&(t=e),this._frustumPlanes.x=t.top,this._frustumPlanes.y=t.bottom,this._frustumPlanes.z=t.left,this._frustumPlanes.w=t.right};lE.prototype.updatePass=function(t){this._pass=t};var NOt=[],yOt=new gb;lE.prototype.update=function(t){this._mode=t.mode,this._mapProjection=t.mapProjection,this._ellipsoid=t.mapProjection.ellipsoid,this._pixelRatio=t.pixelRatio;let e=t.camera;this.updateCamera(e),t.mode===Vt.SCENE2D?(this._frustum2DWidth=e.frustum.right-e.frustum.left,this._eyeHeight2D.x=this._frustum2DWidth*.5,this._eyeHeight2D.y=this._eyeHeight2D.x*this._eyeHeight2D.x):(this._frustum2DWidth=0,this._eyeHeight2D.x=0,this._eyeHeight2D.y=0),IOt(this,t);let n=f(t.light,yOt);n instanceof gb?(this._lightDirectionWC=p.clone(this._sunDirectionWC,this._lightDirectionWC),this._lightDirectionEC=p.clone(this._sunDirectionEC,this._lightDirectionEC)):(this._lightDirectionWC=p.normalize(p.negate(n.direction,this._lightDirectionWC),this._lightDirectionWC),this._lightDirectionEC=ot.multiplyByVector(this.viewRotation3D,this._lightDirectionWC,this._lightDirectionEC));let i=n.color,o=p.fromElements(i.red,i.green,i.blue,this._lightColorHdr);o=p.multiplyByScalar(o,n.intensity,o);let a=p.maximumComponent(o);a>1?p.divideByScalar(o,a,this._lightColor):p.clone(o,this._lightColor);let s=t.brdfLutGenerator,l=c(s)?s.colorTexture:void 0;this._brdfLut=l,this._environmentMap=f(t.environmentMap,t.context.defaultCubeMap),this._sphericalHarmonicCoefficients=f(t.sphericalHarmonicCoefficients,NOt),this._specularEnvironmentMaps=t.specularEnvironmentMaps,this._specularEnvironmentMapsMaximumLOD=t.specularEnvironmentMapsMaximumLOD,c(this._specularEnvironmentMaps)&&K.clone(this._specularEnvironmentMaps.dimensions,this._specularEnvironmentMapsDimensions),this._fogDensity=t.fog.density,this._fogMinimumBrightness=t.fog.minimumBrightness;let r=t.atmosphere;c(r)&&(this._atmosphereHsbShift=p.fromElements(r.hueShift,r.saturationShift,r.brightnessShift,this._atmosphereHsbShift),this._atmosphereLightIntensity=r.lightIntensity,this._atmosphereRayleighCoefficient=p.clone(r.rayleighCoefficient,this._atmosphereRayleighCoefficient),this._atmosphereRayleighScaleHeight=r.rayleighScaleHeight,this._atmosphereMieCoefficient=p.clone(r.mieCoefficient,this._atmosphereMieCoefficient),this._atmosphereMieScaleHeight=r.mieScaleHeight,this._atmosphereMieAnisotropy=r.mieAnisotropy,this._atmosphereDynamicLighting=r.dynamicLighting),this._invertClassificationColor=t.invertClassificationColor,this._frameState=t,this._temeToPseudoFixed=Pe.computeTemeToPseudoFixedMatrix(t.time,this._temeToPseudoFixed),this._splitPosition=t.splitPosition*t.context.drawingBufferWidth;let d=e.frustum.fov,m=this._viewport,h;c(d)?m.height>m.width?h=Math.tan(.5*d)*2/m.height:h=Math.tan(.5*d)*2/m.width:h=1/Math.max(m.width,m.height),this._geometricToleranceOverMeter=h*t.maximumScreenSpaceError,v.clone(t.backgroundColor,this._backgroundColor),this._minimumDisableDepthTestDistance=t.minimumDisableDepthTestDistance,this._minimumDisableDepthTestDistance*=this._minimumDisableDepthTestDistance,this._minimumDisableDepthTestDistance===Number.POSITIVE_INFINITY&&(this._minimumDisableDepthTestDistance=-1)};function Cpt(t){if(t._viewportDirty){let e=t._viewport;L.computeOrthographicOffCenter(e.x,e.x+e.width,e.y,e.y+e.height,0,1,t._viewportOrthographicMatrix),L.computeViewportTransformation(e,0,1,t._viewportTransformation),t._viewportDirty=!1}}function BOt(t){t._inverseProjectionDirty&&(t._inverseProjectionDirty=!1,t._mode!==Vt.SCENE2D&&t._mode!==Vt.MORPHING&&!t._orthographicIn3D?L.inverse(t._projection,t._inverseProjection):L.clone(L.ZERO,t._inverseProjection))}function QOt(t){t._modelViewDirty&&(t._modelViewDirty=!1,L.multiplyTransformation(t._view,t._model,t._modelView))}function kOt(t){t._modelView3DDirty&&(t._modelView3DDirty=!1,L.multiplyTransformation(t.view3D,t._model,t._modelView3D))}function YOt(t){t._inverseModelViewDirty&&(t._inverseModelViewDirty=!1,L.inverse(t.modelView,t._inverseModelView))}function xOt(t){t._inverseModelView3DDirty&&(t._inverseModelView3DDirty=!1,L.inverse(t.modelView3D,t._inverseModelView3D))}function XOt(t){t._viewProjectionDirty&&(t._viewProjectionDirty=!1,L.multiply(t._projection,t._view,t._viewProjection))}function JOt(t){t._inverseViewProjectionDirty&&(t._inverseViewProjectionDirty=!1,L.inverse(t.viewProjection,t._inverseViewProjection))}function LOt(t){t._modelViewProjectionDirty&&(t._modelViewProjectionDirty=!1,L.multiply(t._projection,t.modelView,t._modelViewProjection))}function MOt(t){if(t._modelViewRelativeToEyeDirty){t._modelViewRelativeToEyeDirty=!1;let e=t.modelView,n=t._modelViewRelativeToEye;n[0]=e[0],n[1]=e[1],n[2]=e[2],n[3]=e[3],n[4]=e[4],n[5]=e[5],n[6]=e[6],n[7]=e[7],n[8]=e[8],n[9]=e[9],n[10]=e[10],n[11]=e[11],n[12]=0,n[13]=0,n[14]=0,n[15]=e[15]}}function _Ot(t){t._inverseModelViewProjectionDirty&&(t._inverseModelViewProjectionDirty=!1,L.inverse(t.modelViewProjection,t._inverseModelViewProjection))}function DOt(t){t._modelViewProjectionRelativeToEyeDirty&&(t._modelViewProjectionRelativeToEyeDirty=!1,L.multiply(t._projection,t.modelViewRelativeToEye,t._modelViewProjectionRelativeToEye))}function OOt(t){t._modelViewInfiniteProjectionDirty&&(t._modelViewInfiniteProjectionDirty=!1,L.multiply(t._infiniteProjection,t.modelView,t._modelViewInfiniteProjection))}function HOt(t){if(t._normalDirty){t._normalDirty=!1;let e=t._normal;L.getMatrix3(t.inverseModelView,e),ot.transpose(e,e)}}function wOt(t){if(t._normal3DDirty){t._normal3DDirty=!1;let e=t._normal3D;L.getMatrix3(t.inverseModelView3D,e),ot.transpose(e,e)}}function POt(t){if(t._inverseNormalDirty){t._inverseNormalDirty=!1;let e=t._inverseNormal;L.getMatrix3(t.modelView,e),ot.transpose(e,e)}}function vOt(t){if(t._inverseNormal3DDirty){t._inverseNormal3DDirty=!1;let e=t._inverseNormal3D;L.getMatrix3(t.modelView3D,e),ot.transpose(e,e)}}var Ipt=new p;function Npt(t){t._encodedCameraPositionMCDirty&&(t._encodedCameraPositionMCDirty=!1,L.multiplyByPoint(t.inverseModel,t._cameraPosition,Ipt),Mi.fromCartesian(Ipt,t._encodedCameraPositionMC))}var KOt=new p,zOt=new p,jOt=new p,qOt=new p,$Ot=new gt,tHt=new p,eHt=new L;function nHt(t,e,n,i,o,a,s,l){let r=KOt;r.x=t.y,r.y=t.z,r.z=t.x;let d=zOt;d.x=n.y,d.y=n.z,d.z=n.x;let m=jOt;m.x=i.y,m.y=i.z,m.z=i.x;let h=qOt;h.x=e.y,h.y=e.z,h.z=e.x,a===Vt.SCENE2D&&(r.z=o*.5);let u=s.unproject(r,$Ot);u.longitude=k.clamp(u.longitude,-Math.PI,Math.PI),u.latitude=k.clamp(u.latitude,-k.PI_OVER_TWO,k.PI_OVER_TWO);let R=s.ellipsoid,V=R.cartographicToCartesian(u,tHt),F=Pe.eastNorthUpToFixedFrame(V,R,eHt);return L.multiplyByPointAsVector(F,d,d),L.multiplyByPointAsVector(F,m,m),L.multiplyByPointAsVector(F,h,h),c(l)||(l=new L),l[0]=d.x,l[1]=m.x,l[2]=-h.x,l[3]=0,l[4]=d.y,l[5]=m.y,l[6]=-h.y,l[7]=0,l[8]=d.z,l[9]=m.z,l[10]=-h.z,l[11]=0,l[12]=-p.dot(d,V),l[13]=-p.dot(m,V),l[14]=p.dot(h,V),l[15]=1,l}function i7(t){t._view3DDirty&&(t._mode===Vt.SCENE3D?L.clone(t._view,t._view3D):nHt(t._cameraPosition,t._cameraDirection,t._cameraRight,t._cameraUp,t._frustum2DWidth,t._mode,t._mapProjection,t._view3D),L.getMatrix3(t._view3D,t._viewRotation3D),t._view3DDirty=!1)}function ypt(t){t._inverseView3DDirty&&(L.inverseTransformation(t.view3D,t._inverseView3D),L.getMatrix3(t._inverseView3D,t._inverseViewRotation3D),t._inverseView3DDirty=!1)}var ok=lE;var yon=b(W(),1);function iHt(t,e,n,i){let o=c(e.vertexBuffer),a=c(e.value),s=e.value?e.value.length:e.componentsPerAttribute,l={index:f(e.index,n),enabled:f(e.enabled,!0),vertexBuffer:e.vertexBuffer,value:a?e.value.slice(0):void 0,componentsPerAttribute:s,componentDatatype:f(e.componentDatatype,it.FLOAT),normalize:f(e.normalize,!1),offsetInBytes:f(e.offsetInBytes,0),strideInBytes:f(e.strideInBytes,0),instanceDivisor:f(e.instanceDivisor,0)};if(o)l.vertexAttrib=function(r){let d=this.index;r.bindBuffer(r.ARRAY_BUFFER,this.vertexBuffer._getBuffer()),r.vertexAttribPointer(d,this.componentsPerAttribute,this.componentDatatype,this.normalize,this.strideInBytes,this.offsetInBytes),r.enableVertexAttribArray(d),this.instanceDivisor>0&&(i.glVertexAttribDivisor(d,this.instanceDivisor),i._vertexAttribDivisors[d]=this.instanceDivisor,i._previousDrawInstanced=!0)},l.disableVertexAttribArray=function(r){r.disableVertexAttribArray(this.index),this.instanceDivisor>0&&i.glVertexAttribDivisor(n,0)};else{switch(l.componentsPerAttribute){case 1:l.vertexAttrib=function(r){r.vertexAttrib1fv(this.index,this.value)};break;case 2:l.vertexAttrib=function(r){r.vertexAttrib2fv(this.index,this.value)};break;case 3:l.vertexAttrib=function(r){r.vertexAttrib3fv(this.index,this.value)};break;case 4:l.vertexAttrib=function(r){r.vertexAttrib4fv(this.index,this.value)};break}l.disableVertexAttribArray=function(r){}}t.push(l)}function Qpt(t,e,n){for(let i=0;i0&&(r=!0),c(s[a].value)&&(d=!0);let h;e.vertexArrayObject&&(h=e.glCreateVertexArray(),e.glBindVertexArray(h),Qpt(n,s,o),e.glBindVertexArray(null)),this._numberOfVertices=l,this._hasInstancedAttributes=r,this._hasConstantAttributes=d,this._context=e,this._gl=n,this._vao=h,this._attributes=s,this._indexBuffer=o}function Bpt(t){return t.values.length/t.componentsPerAttribute}function oHt(t){return it.getSizeInBytes(t.componentDatatype)*t.componentsPerAttribute}function aHt(t){let e,n,i,o=[];for(n in t)t.hasOwnProperty(n)&&c(t[n])&&c(t[n].values)&&(o.push(n),t[n].componentDatatype===it.DOUBLE&&(t[n].componentDatatype=it.FLOAT,t[n].values=it.createTypedArray(it.FLOAT,t[n].values)));let a,s=o.length;if(s>0)for(a=Bpt(t[o[0]]),e=1;e0){let d=it.getSizeInBytes(t[o[0]].componentDatatype),m=l%d;m!==0&&(l+=d-m);let h=a*l,u=new ArrayBuffer(h),R={};for(e=0;e=k.SIXTY_FOUR_KILOBYTES&&e.elementIndexUint?u=we.createIndexBuffer({context:e,typedArray:new Uint32Array(R),usage:i,indexDatatype:re.UNSIGNED_INT}):u=we.createIndexBuffer({context:e,typedArray:new Uint16Array(R),usage:i,indexDatatype:re.UNSIGNED_SHORT})),new Eb({context:e,attributes:m,indexBuffer:u})};Object.defineProperties(Eb.prototype,{numberOfAttributes:{get:function(){return this._attributes.length}},numberOfVertices:{get:function(){return this._numberOfVertices}},indexBuffer:{get:function(){return this._indexBuffer}}});Eb.prototype.getAttribute=function(t){return this._attributes[t]};function sHt(t){let e=t._context,n=t._hasInstancedAttributes;if(!n&&!e._previousDrawInstanced)return;e._previousDrawInstanced=n;let i=e._vertexAttribDivisors,o=t._attributes,a=Tn.maximumVertexAttributes,s;if(n){let l=o.length;for(s=0;s0&&(e.glVertexAttribDivisor(s,0),i[s]=0)}function lHt(t,e){let n=t._attributes,i=n.length;for(let o=0;o"u")throw new Tt("The browser does not support WebGL. Visit http://get.webgl.org.");!n&&!(typeof WebGL2RenderingContext<"u")&&(n=!0);let o=n?"webgl":"webgl2",a=t.getContext(o,e);if(!c(a))throw new Tt("The browser supports WebGL, but initialization failed.");return a}function dHt(t,e){let n="WebGL Error: ";switch(e){case t.INVALID_ENUM:n+="INVALID_ENUM";break;case t.INVALID_VALUE:n+="INVALID_VALUE";break;case t.INVALID_OPERATION:n+="INVALID_OPERATION";break;case t.OUT_OF_MEMORY:n+="OUT_OF_MEMORY";break;case t.CONTEXT_LOST_WEBGL:n+="CONTEXT_LOST_WEBGL lost";break;default:n+=`Unknown (${e})`}return n}function cHt(t,e,n,i){let o=`${dHt(t,i)}: ${e.name}(`;for(let a=0;a=8}},antialias:{get:function(){return this._antialias}},msaa:{get:function(){return this._webgl2}},standardDerivatives:{get:function(){return this._standardDerivatives||this._webgl2}},floatBlend:{get:function(){return this._floatBlend}},blendMinmax:{get:function(){return this._blendMinmax||this._webgl2}},elementIndexUint:{get:function(){return this._elementIndexUint||this._webgl2}},depthTexture:{get:function(){return this._depthTexture||this._webgl2}},floatingPointTexture:{get:function(){return this._webgl2||this._textureFloat}},halfFloatingPointTexture:{get:function(){return this._webgl2||this._textureHalfFloat}},textureFloatLinear:{get:function(){return this._textureFloatLinear}},textureHalfFloatLinear:{get:function(){return this._webgl2&&this._textureFloatLinear||!this._webgl2&&this._textureHalfFloatLinear}},textureFilterAnisotropic:{get:function(){return!!this._textureFilterAnisotropic}},s3tc:{get:function(){return this._s3tc}},pvrtc:{get:function(){return this._pvrtc}},astc:{get:function(){return this._astc}},etc:{get:function(){return this._etc}},etc1:{get:function(){return this._etc1}},bc7:{get:function(){return this._bc7}},supportsBasis:{get:function(){return this._s3tc||this._pvrtc||this._astc||this._etc||this._etc1||this._bc7}},vertexArrayObject:{get:function(){return this._vertexArrayObject||this._webgl2}},fragmentDepth:{get:function(){return this._fragDepth||this._webgl2}},instancedArrays:{get:function(){return this._instancedArrays||this._webgl2}},colorBufferFloat:{get:function(){return this._colorBufferFloat}},colorBufferHalfFloat:{get:function(){return this._webgl2&&this._colorBufferFloat||!this._webgl2&&this._colorBufferHalfFloat}},drawBuffers:{get:function(){return this._drawBuffers||this._webgl2}},debugShaders:{get:function(){return this._debugShaders}},throwOnWebGLError:{get:function(){return this._throwOnWebGLError},set:function(t){this._throwOnWebGLError=t,this._gl=pHt(this._originalGLContext,t?mHt:void 0)}},defaultTexture:{get:function(){return this._defaultTexture===void 0&&(this._defaultTexture=new hn({context:this,source:{width:1,height:1,arrayBufferView:new Uint8Array([255,255,255,255])},flipY:!1})),this._defaultTexture}},defaultEmissiveTexture:{get:function(){return this._defaultEmissiveTexture===void 0&&(this._defaultEmissiveTexture=new hn({context:this,pixelFormat:Ye.RGB,source:{width:1,height:1,arrayBufferView:new Uint8Array([0,0,0])},flipY:!1})),this._defaultEmissiveTexture}},defaultNormalTexture:{get:function(){return this._defaultNormalTexture===void 0&&(this._defaultNormalTexture=new hn({context:this,pixelFormat:Ye.RGB,source:{width:1,height:1,arrayBufferView:new Uint8Array([128,128,255])},flipY:!1})),this._defaultNormalTexture}},defaultCubeMap:{get:function(){if(this._defaultCubeMap===void 0){let t={width:1,height:1,arrayBufferView:new Uint8Array([255,255,255,255])};this._defaultCubeMap=new Ld({context:this,source:{positiveX:t,negativeX:t,positiveY:t,negativeY:t,positiveZ:t,negativeZ:t},flipY:!1})}return this._defaultCubeMap}},drawingBufferHeight:{get:function(){return this._gl.drawingBufferHeight}},drawingBufferWidth:{get:function(){return this._gl.drawingBufferWidth}},defaultFramebuffer:{get:function(){return VHt}}});function kpt(t,e,n,i){let o=t._currentRenderState,a=t._currentPassState;t._currentRenderState=e,t._currentPassState=n,he.partialApply(t._gl,o,e,a,n,i)}var o7;typeof WebGLRenderingContext<"u"&&(o7=[pt.BACK]);function a7(t,e){if(e!==t._currentFramebuffer){t._currentFramebuffer=e;let n=o7;if(c(e))e._bind(),n=e._getActiveColorAttachments();else{let i=t._gl;i.bindFramebuffer(i.FRAMEBUFFER,null)}t.drawBuffers&&t.glDrawBuffers(n)}}var uHt=new ao;Zh.prototype.clear=function(t,e){t=f(t,uHt),e=f(e,this._defaultPassState);let n=this._gl,i=0,o=t.color,a=t.depth,s=t.stencil;c(o)&&(v.equals(this._clearColor,o)||(v.clone(o,this._clearColor),n.clearColor(o.red,o.green,o.blue,o.alpha)),i|=n.COLOR_BUFFER_BIT),c(a)&&(a!==this._clearDepth&&(this._clearDepth=a,n.clearDepth(a)),i|=n.DEPTH_BUFFER_BIT),c(s)&&(s!==this._clearStencil&&(this._clearStencil=s,n.clearStencil(s)),i|=n.STENCIL_BUFFER_BIT);let l=f(t.renderState,this._defaultRenderState);kpt(this,l,e,!0);let r=f(t.framebuffer,e.framebuffer);a7(this,r),n.clear(i)};function ZHt(t,e,n,i,o){a7(t,e),kpt(t,o,n,!1),i._bind(),t._maxFrameTextureUnitIndex=Math.max(t._maxFrameTextureUnitIndex,i.maximumTextureUnitIndex)}function RHt(t,e,n,i){let o=e._primitiveType,a=e._vertexArray,s=e._offset,l=e._count,r=e.instanceCount;t._us.model=f(e._modelMatrix,L.IDENTITY),n._setUniforms(i,t._us,t.validateShaderProgram),a._bind();let d=a.indexBuffer;c(d)?(s=s*d.bytesPerIndex,c(l)?l=Math.min(l,d.numberOfIndices):l=d.numberOfIndices,r===0?t._gl.drawElements(o,l,d.indexDatatype,s):t.glDrawElementsInstanced(o,l,d.indexDatatype,s,r)):(c(l)?l=Math.min(l,a.numberOfVertices):l=a.numberOfVertices,r===0?t._gl.drawArrays(o,s,l):t.glDrawArraysInstanced(o,s,l,r)),a._unBind()}Zh.prototype.draw=function(t,e,n,i){e=f(e,this._defaultPassState);let o=f(t._framebuffer,e.framebuffer),a=f(t._renderState,this._defaultRenderState);n=f(n,t._shaderProgram),i=f(i,t._uniformMap),ZHt(this,o,e,n,a),RHt(this,t,n,i)};Zh.prototype.endFrame=function(){let t=this._gl;t.useProgram(null),this._currentFramebuffer=void 0,t.bindFramebuffer(t.FRAMEBUFFER,null);let e=o7;this.drawBuffers&&this.glDrawBuffers(e);let n=this._maxFrameTextureUnitIndex;this._maxFrameTextureUnitIndex=0;for(let i=0;i0&&(l=s.getColorTexture(0).pixelDatatype);let r=Ye.createTypedArray(Ye.RGBA,l,o,a);return a7(this,s),e.readPixels(n,i,o,a,Ye.RGBA,Ue.toWebGLConstant(l,this),r),r};var Ypt={position:0,textureCoordinates:1};Zh.prototype.getViewportQuadVertexArray=function(){let t=this.cache.viewportQuad_vertexArray;if(!c(t)){let e=new _e({attributes:{position:new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:[-1,-1,1,-1,1,1,-1,1]}),textureCoordinates:new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:[0,0,1,0,1,1,0,1]})},indices:new Uint16Array([0,1,2,0,2,3]),primitiveType:le.TRIANGLES});t=Ki.fromGeometry({context:this,geometry:e,attributeLocations:Ypt,bufferUsage:ce.STATIC_DRAW,interleave:!0}),this.cache.viewportQuad_vertexArray=t}return t};Zh.prototype.createViewportQuadCommand=function(t,e){return e=f(e,f.EMPTY_OBJECT),new Ee({vertexArray:this.getViewportQuadVertexArray(),primitiveType:le.TRIANGLES,renderState:e.renderState,shaderProgram:xn.fromCache({context:this,vertexShaderSource:GG,fragmentShaderSource:t,attributeLocations:Ypt}),uniformMap:e.uniformMap,owner:e.owner,framebuffer:e.framebuffer,pass:e.pass})};Zh.prototype.getObjectByPickColor=function(t){return this._pickObjects[t.toRgba()]};function s7(t,e,n){this._pickObjects=t,this.key=e,this.color=n}Object.defineProperties(s7.prototype,{object:{get:function(){return this._pickObjects[this.key]},set:function(t){this._pickObjects[this.key]=t}}});s7.prototype.destroy=function(){delete this._pickObjects[this.key]};Zh.prototype.createPickId=function(t){++this._nextPickColor[0];let e=this._nextPickColor[0];if(e===0)throw new Tt("Out of unique Pick IDs.");return this._pickObjects[e]=t,new s7(this._pickObjects,e,v.fromRgba(e))};Zh.prototype.isDestroyed=function(){return!1};Zh.prototype.destroy=function(){let t=this.cache;for(let e in t)if(t.hasOwnProperty(e)){let n=t[e];c(n.destroy)&&n.destroy()}return this._shaderCache=this._shaderCache.destroy(),this._textureCache=this._textureCache.destroy(),this._defaultTexture=this._defaultTexture&&this._defaultTexture.destroy(),this._defaultEmissiveTexture=this._defaultEmissiveTexture&&this._defaultEmissiveTexture.destroy(),this._defaultNormalTexture=this._defaultNormalTexture&&this._defaultNormalTexture.destroy(),this._defaultCubeMap=this._defaultCubeMap&&this._defaultCubeMap.destroy(),At(this)};Zh._deprecationWarning=ur;var ak=Zh;var Jan=b(W(),1);var Ran=b(W(),1);function rE(t){t=f(t,f.EMPTY_OBJECT);let e=t.context,n=t.width,i=t.height;this._width=n,this._height=i;let o=t.colorRenderbuffers,a=t.colorTextures;if(c(o)!==c(a))throw new Ut("Both color renderbuffer and texture attachments must be provided.");let s=t.depthStencilRenderbuffer,l=t.depthStencilTexture;if(c(s)!==c(l))throw new Ut("Both depth-stencil renderbuffer and texture attachments must be provided.");this._renderFramebuffer=new Lr({context:e,colorRenderbuffers:o,depthStencilRenderbuffer:s,destroyAttachments:t.destroyAttachments}),this._colorFramebuffer=new Lr({context:e,colorTextures:a,depthStencilTexture:l,destroyAttachments:t.destroyAttachments})}rE.prototype.getRenderFramebuffer=function(){return this._renderFramebuffer};rE.prototype.getColorFramebuffer=function(){return this._colorFramebuffer};rE.prototype.blitFramebuffers=function(t,e){this._renderFramebuffer.bindRead(),this._colorFramebuffer.bindDraw();let n=t._gl,i=0;this._colorFramebuffer._colorTextures.length>0&&(i|=n.COLOR_BUFFER_BIT),c(this._colorFramebuffer.depthStencilTexture)&&(i|=n.DEPTH_BUFFER_BIT|(e?n.STENCIL_BUFFER_BIT:0)),n.blitFramebuffer(0,0,this._width,this._height,0,0,this._width,this._height,i,n.NEAREST),n.bindFramebuffer(n.READ_FRAMEBUFFER,null),n.bindFramebuffer(n.DRAW_FRAMEBUFFER,null)};rE.prototype.isDestroyed=function(){return!1};rE.prototype.destroy=function(){return this._renderFramebuffer.destroy(),this._colorFramebuffer.destroy(),At(this)};var sk=rE;var gan=b(W(),1);var fan=b(W(),1);var Gm={RGBA4:pt.RGBA4,RGBA8:pt.RGBA8,RGBA16F:pt.RGBA16F,RGBA32F:pt.RGBA32F,RGB5_A1:pt.RGB5_A1,RGB565:pt.RGB565,DEPTH_COMPONENT16:pt.DEPTH_COMPONENT16,STENCIL_INDEX8:pt.STENCIL_INDEX8,DEPTH_STENCIL:pt.DEPTH_STENCIL,DEPTH24_STENCIL8:pt.DEPTH24_STENCIL8,validate:function(t){return t===Gm.RGBA4||t===Gm.RGBA8||t===Gm.RGBA16F||t===Gm.RGBA32F||t===Gm.RGB5_A1||t===Gm.RGB565||t===Gm.DEPTH_COMPONENT16||t===Gm.STENCIL_INDEX8||t===Gm.DEPTH_STENCIL||t===Gm.DEPTH24_STENCIL8},getColorFormat:function(t){return t===pt.FLOAT?Gm.RGBA32F:t===pt.HALF_FLOAT_OES?Gm.RGBA16F:Gm.RGBA8}},Tc=Object.freeze(Gm);function lk(t){t=f(t,f.EMPTY_OBJECT);let n=t.context._gl,i=Tn.maximumRenderbufferSize,o=f(t.format,Tc.RGBA4),a=c(t.width)?t.width:n.drawingBufferWidth,s=c(t.height)?t.height:n.drawingBufferHeight,l=f(t.numSamples,1);this._gl=n,this._format=o,this._width=a,this._height=s,this._renderbuffer=this._gl.createRenderbuffer(),n.bindRenderbuffer(n.RENDERBUFFER,this._renderbuffer),l>1?n.renderbufferStorageMultisample(n.RENDERBUFFER,l,o,a,s):n.renderbufferStorage(n.RENDERBUFFER,o,a,s),n.bindRenderbuffer(n.RENDERBUFFER,null)}Object.defineProperties(lk.prototype,{format:{get:function(){return this._format}},width:{get:function(){return this._width}},height:{get:function(){return this._height}}});lk.prototype._getRenderbuffer=function(){return this._renderbuffer};lk.prototype.isDestroyed=function(){return!1};lk.prototype.destroy=function(){return this._gl.deleteRenderbuffer(this._renderbuffer),At(this)};var Rh=lk;function Kl(t){t=f(t,f.EMPTY_OBJECT),this._numSamples=f(t.numSamples,1),this._colorAttachmentsLength=f(t.colorAttachmentsLength,1),this._color=f(t.color,!0),this._depth=f(t.depth,!1),this._depthStencil=f(t.depthStencil,!1),this._supportsDepthTexture=f(t.supportsDepthTexture,!1),this._createColorAttachments=f(t.createColorAttachments,!0),this._createDepthAttachments=f(t.createDepthAttachments,!0),this._pixelDatatype=t.pixelDatatype,this._pixelFormat=t.pixelFormat,this._width=void 0,this._height=void 0,this._framebuffer=void 0,this._multisampleFramebuffer=void 0,this._colorTextures=void 0,this._color&&(this._colorTextures=new Array(this._colorAttachmentsLength),this._colorRenderbuffers=new Array(this._colorAttachmentsLength)),this._colorRenderbuffer=void 0,this._depthStencilRenderbuffer=void 0,this._depthStencilTexture=void 0,this._depthRenderbuffer=void 0,this._depthTexture=void 0,this._attachmentsDirty=!1}Object.defineProperties(Kl.prototype,{framebuffer:{get:function(){return this._numSamples>1?this._multisampleFramebuffer.getRenderFramebuffer():this._framebuffer}},numSamples:{get:function(){return this._numSamples}},status:{get:function(){return this.framebuffer.status}}});Kl.prototype.isDirty=function(t,e,n,i,o){n=f(n,1);let a=this._width!==t||this._height!==e,s=this._numSamples!==n,l=c(i)&&this._pixelDatatype!==i||c(o)&&this._pixelFormat!==o,r=n===1?c(this._framebuffer):c(this._multisampleFramebuffer);return this._attachmentsDirty||a||s||l||!r||this._color&&!c(this._colorTextures[0])};Kl.prototype.update=function(t,e,n,i,o,a){if(i=t.msaa?f(i,1):1,o=f(o,this._color?f(this._pixelDatatype,Ue.UNSIGNED_BYTE):void 0),a=f(a,this._color?f(this._pixelFormat,Ye.RGBA):void 0),this.isDirty(e,n,i,o,a)){if(this.destroy(),this._width=e,this._height=n,this._numSamples=i,this._pixelDatatype=o,this._pixelFormat=a,this._attachmentsDirty=!1,this._color&&this._createColorAttachments){for(let s=0;s1){let l=Tc.getColorFormat(o);this._colorRenderbuffers[s]=new Rh({context:t,width:e,height:n,format:l,numSamples:this._numSamples})}}this._depthStencil&&this._createDepthAttachments&&(this._supportsDepthTexture&&t.depthTexture?(this._depthStencilTexture=new hn({context:t,width:e,height:n,pixelFormat:Ye.DEPTH_STENCIL,pixelDatatype:Ue.UNSIGNED_INT_24_8,sampler:Hn.NEAREST}),this._numSamples>1&&(this._depthStencilRenderbuffer=new Rh({context:t,width:e,height:n,format:Tc.DEPTH24_STENCIL8,numSamples:this._numSamples}))):this._depthStencilRenderbuffer=new Rh({context:t,width:e,height:n,format:Tc.DEPTH_STENCIL})),this._depth&&this._createDepthAttachments&&(this._supportsDepthTexture&&t.depthTexture?this._depthTexture=new hn({context:t,width:e,height:n,pixelFormat:Ye.DEPTH_COMPONENT,pixelDatatype:Ue.UNSIGNED_INT,sampler:Hn.NEAREST}):this._depthRenderbuffer=new Rh({context:t,width:e,height:n,format:Tc.DEPTH_COMPONENT16})),this._numSamples>1?this._multisampleFramebuffer=new sk({context:t,width:this._width,height:this._height,colorTextures:this._colorTextures,colorRenderbuffers:this._colorRenderbuffers,depthStencilTexture:this._depthStencilTexture,depthStencilRenderbuffer:this._depthStencilRenderbuffer,destroyAttachments:!1}):this._framebuffer=new Lr({context:t,colorTextures:this._colorTextures,depthTexture:this._depthTexture,depthRenderbuffer:this._depthRenderbuffer,depthStencilTexture:this._depthStencilTexture,depthStencilRenderbuffer:this._depthStencilRenderbuffer,destroyAttachments:!1})}};Kl.prototype.getColorTexture=function(t){return t=f(t,0),this._colorTextures[t]};Kl.prototype.setColorTexture=function(t,e){e=f(e,0),this._attachmentsDirty=t!==this._colorTextures[e],this._colorTextures[e]=t};Kl.prototype.getColorRenderbuffer=function(t){return t=f(t,0),this._colorRenderbuffers[t]};Kl.prototype.setColorRenderbuffer=function(t,e){e=f(e,0),this._attachmentsDirty=t!==this._colorRenderbuffers[e],this._colorRenderbuffers[e]=t};Kl.prototype.getDepthRenderbuffer=function(){return this._depthRenderbuffer};Kl.prototype.setDepthRenderbuffer=function(t){this._attachmentsDirty=t!==this._depthRenderbuffer,this._depthRenderbuffer=t};Kl.prototype.getDepthTexture=function(){return this._depthTexture};Kl.prototype.setDepthTexture=function(t){this._attachmentsDirty=t!==this._depthTexture,this._depthTexture=t};Kl.prototype.getDepthStencilRenderbuffer=function(){return this._depthStencilRenderbuffer};Kl.prototype.setDepthStencilRenderbuffer=function(t){this._attachmentsDirty=t!==this._depthStencilRenderbuffer,this._depthStencilRenderbuffer=t};Kl.prototype.getDepthStencilTexture=function(){return this._depthStencilTexture};Kl.prototype.setDepthStencilTexture=function(t){this._attachmentsDirty=t!==this._depthStencilTexture,this._depthStencilTexture=t};Kl.prototype.prepareTextures=function(t,e){this._numSamples>1&&this._multisampleFramebuffer.blitFramebuffers(t,e)};Kl.prototype.clear=function(t,e,n){let i=e.framebuffer;e.framebuffer=this.framebuffer,e.execute(t,n),e.framebuffer=i};Kl.prototype.destroyFramebuffer=function(){this._framebuffer=this._framebuffer&&this._framebuffer.destroy(),this._multisampleFramebuffer=this._multisampleFramebuffer&&this._multisampleFramebuffer.destroy()};Kl.prototype.destroy=function(){if(this._color){let t,e=this._colorTextures.length;for(t=0;t0?it.getSizeInBytes(t[0].componentDatatype):0,o=i>0?e%i:0,a=o===0?0:i-o;return e+=a,e};br._createArrayViews=function(t,e){let n=[],i=0,o=t.length;for(let a=0;a0){let n=new ArrayBuffer(e*t.vertexSizeInBytes);if(c(t.arrayBuffer)){let a=new Uint8Array(n),s=new Uint8Array(t.arrayBuffer),l=s.length;for(let r=0;r0){e.needsCommit=!1;let n=e.vertexBuffer,i=t._size*e.vertexSizeInBytes,o=c(n);if(!o||n.sizeInBytes0){let i=t.vertexSizeInBytes*e,o=t.vertexSizeInBytes*n;t.vertexBuffer.copyFromArrayView(new Uint8Array(t.arrayBuffer,i,o),i)}}br.prototype.endSubCommits=function(){let t=this._allBuffers;for(let e=0,n=t.length;e0&&(this._hash={},t.length=0)};var qe=CG;var xsn=b(W(),1);function bh(t,e){t=f(t,0),this._near=t,e=f(e,Number.MAX_VALUE),this._far=e}Object.defineProperties(bh.prototype,{near:{get:function(){return this._near},set:function(t){this._near=t}},far:{get:function(){return this._far},set:function(t){this._far=t}}});bh.packedLength=2;bh.pack=function(t,e,n){return n=f(n,0),e[n++]=t.near,e[n]=t.far,e};bh.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new bh),n.near=t[e++],n.far=t[e],n};bh.equals=function(t,e){return t===e||c(t)&&c(e)&&t.near===e.near&&t.far===e.far};bh.clone=function(t,e){if(c(t))return c(e)||(e=new bh),e.near=t.near,e.far=t.far,e};bh.prototype.clone=function(t){return bh.clone(this,t)};bh.prototype.equals=function(t){return bh.equals(this,t)};var Wn=bh;var Msn=b(W(),1);function Ip(t,e,n,i){this.near=f(t,0),this.nearValue=f(e,0),this.far=f(n,1),this.farValue=f(i,0)}Ip.clone=function(t,e){if(c(t))return c(e)?(e.near=t.near,e.nearValue=t.nearValue,e.far=t.far,e.farValue=t.farValue,e):new Ip(t.near,t.nearValue,t.far,t.farValue)};Ip.packedLength=4;Ip.pack=function(t,e,n){return n=f(n,0),e[n++]=t.near,e[n++]=t.nearValue,e[n++]=t.far,e[n]=t.farValue,e};Ip.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new Ip),n.near=t[e++],n.nearValue=t[e++],n.far=t[e++],n.farValue=t[e],n};Ip.equals=function(t,e){return t===e||c(t)&&c(e)&&t.near===e.near&&t.nearValue===e.nearValue&&t.far===e.far&&t.farValue===e.farValue};Ip.prototype.clone=function(t){return Ip.clone(this,t)};Ip.prototype.equals=function(t){return Ip.equals(this,t)};var ln=Ip;var Dsn=b(W(),1),IG={NONE:0,CLAMP_TO_GROUND:1,RELATIVE_TO_GROUND:2,CLAMP_TO_TERRAIN:3,RELATIVE_TO_TERRAIN:4,CLAMP_TO_3D_TILE:5,RELATIVE_TO_3D_TILE:6},Ge=Object.freeze(IG);function Np(t){return t===IG.CLAMP_TO_GROUND||t===IG.CLAMP_TO_3D_TILE||t===IG.CLAMP_TO_TERRAIN}function dE(t){return t===IG.RELATIVE_TO_GROUND||t===IG.RELATIVE_TO_3D_TILE||t===IG.RELATIVE_TO_TERRAIN}var Hsn=b(W(),1),EHt={CENTER:0,LEFT:1,RIGHT:-1},to=Object.freeze(EHt);var Psn=b(W(),1),CHt={CENTER:0,BOTTOM:1,BASELINE:2,TOP:-1},hi=Object.freeze(CHt);var Ksn=b(W(),1),IHt={DONE:0,PENDING:1,FAILED:2},ve=Object.freeze(IHt);var tln=b(W(),1);function $V(){Ut.throwInstantiationError()}Object.defineProperties($V.prototype,{isConstant:{get:Ut.throwInstantiationError},definitionChanged:{get:Ut.throwInstantiationError}});$V.prototype.getValue=Ut.throwInstantiationError;$V.prototype.equals=Ut.throwInstantiationError;$V.equals=function(t,e){return t===e||c(t)&&t.equals(e)};$V.arrayEquals=function(t,e){if(t===e)return!0;if(!c(t)||!c(e)||t.length!==e.length)return!1;let n=t.length;for(let i=0;i-1;o--)a=e[o],c(a._billboard)&&c(a._position)&&s.set(a.id,new xpt(a));for(o=i.length-1;o>-1;o--)a=i[o],c(a._billboard)&&c(a._position)?s.contains(a.id)||s.set(a.id,new xpt(a)):(c7(s.get(a.id),a,l),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],c7(s.get(a.id),a,l),s.remove(a.id)};function c7(t,e,n){c(t)&&(t.billboard=void 0,n.removeBillboard(e))}var hk=Wf;var pAn=b(W(),1);var ern=b(W(),1);var Bln=b(W(),1);var Wln=b(W(),1);function zHt(t,e){this.start=f(t,0),this.stop=f(e,0)}var hd=zHt;function oi(t,e){this.center=p.clone(f(t,p.ZERO)),this.radius=f(e,0)}var p7=new p,V7=new p,u7=new p,Z7=new p,R7=new p,b7=new p,W7=new p,_r=new p,f7=new p,F7=new p,U7=new p,G7=new p,jHt=4/3*k.PI;oi.fromPoints=function(t,e){if(c(e)||(e=new oi),!c(t)||t.length===0)return e.center=p.clone(p.ZERO,e.center),e.radius=0,e;let n=p.clone(t[0],W7),i=p.clone(n,p7),o=p.clone(n,V7),a=p.clone(n,u7),s=p.clone(n,Z7),l=p.clone(n,R7),r=p.clone(n,b7),d=t.length,m;for(m=1;ms.x&&p.clone(n,s),Jl.y&&p.clone(n,l),Mr.z&&p.clone(n,r)}let h=p.magnitudeSquared(p.subtract(s,i,_r)),u=p.magnitudeSquared(p.subtract(l,o,_r)),R=p.magnitudeSquared(p.subtract(r,a,_r)),V=i,F=s,U=h;u>U&&(U=u,V=o,F=l),R>U&&(U=R,V=a,F=r);let G=f7;G.x=(V.x+F.x)*.5,G.y=(V.y+F.y)*.5,G.z=(V.z+F.z)*.5;let A=p.magnitudeSquared(p.subtract(F,G,_r)),S=Math.sqrt(A),g=F7;g.x=i.x,g.y=o.y,g.z=a.z;let C=U7;C.x=s.x,C.y=l.y,C.z=r.z;let y=p.midpoint(g,C,G7),Y=0;for(m=0;mY&&(Y=Q);let J=p.magnitudeSquared(p.subtract(n,G,_r));if(J>A){let M=Math.sqrt(J);S=(S+M)*.5,A=S*S;let Z=M-S;G.x=(S*G.x+Z*n.x)/M,G.y=(S*G.y+Z*n.y)/M,G.z=(S*G.z+Z*n.z)/M}}return Sr.x&&p.clone(o,r),Zd.y&&p.clone(o,d),Em.z&&p.clone(o,m)}let R=p.magnitudeSquared(p.subtract(r,a,_r)),V=p.magnitudeSquared(p.subtract(d,s,_r)),F=p.magnitudeSquared(p.subtract(m,l,_r)),U=a,G=r,A=R;V>A&&(A=V,U=s,G=d),F>A&&(A=F,U=l,G=m);let S=f7;S.x=(U.x+G.x)*.5,S.y=(U.y+G.y)*.5,S.z=(U.z+G.z)*.5;let g=p.magnitudeSquared(p.subtract(G,S,_r)),C=Math.sqrt(g),y=F7;y.x=a.x,y.y=s.y,y.z=l.z;let Y=U7;Y.x=r.x,Y.y=d.y,Y.z=m.z;let Q=p.midpoint(y,Y,G7),J=0;for(u=0;uJ&&(J=M);let Z=p.magnitudeSquared(p.subtract(o,S,_r));if(Z>g){let E=Math.sqrt(Z);C=(C+E)*.5,g=C*C;let I=E-C;S.x=(C*S.x+I*o.x)/E,S.y=(C*S.y+I*o.y)/E,S.z=(C*S.z+I*o.z)/E}}return Cl.x&&p.clone(i,l),Mr.y&&p.clone(i,r),Zd.z&&p.clone(i,d)}let u=p.magnitudeSquared(p.subtract(l,o,_r)),R=p.magnitudeSquared(p.subtract(r,a,_r)),V=p.magnitudeSquared(p.subtract(d,s,_r)),F=o,U=l,G=u;R>G&&(G=R,F=a,U=r),V>G&&(G=V,F=s,U=d);let A=f7;A.x=(F.x+U.x)*.5,A.y=(F.y+U.y)*.5,A.z=(F.z+U.z)*.5;let S=p.magnitudeSquared(p.subtract(U,A,_r)),g=Math.sqrt(S),C=F7;C.x=o.x,C.y=a.y,C.z=s.z;let y=U7;y.x=l.x,y.y=r.y,y.z=d.z;let Y=p.midpoint(C,y,G7),Q=0;for(h=0;hQ&&(Q=J);let M=p.magnitudeSquared(p.subtract(i,A,_r));if(M>S){let Z=Math.sqrt(M);g=(g+Z)*.5,S=g*g;let E=Z-g;A.x=(g*A.x+E*i.x)/Z,A.y=(g*A.y+E*i.y)/Z,A.z=(g*A.z+E*i.z)/Z}}return g=r+s)return t.clone(n),n;if(s>=r+o)return e.clone(n),n;let d=(o+r+s)*.5,m=p.multiplyByScalar(l,(-o+d)/r,dwt);return p.add(m,i,m),p.clone(m,n.center),n.radius=d,n};var cwt=new p;oi.expand=function(t,e,n){n=oi.clone(t,n);let i=p.magnitude(p.subtract(e,n.center,cwt));return i>n.radius&&(n.radius=i),n};oi.intersectPlane=function(t,e){let n=t.center,i=t.radius,o=e.normal,a=p.dot(o,n)+e.distance;return a<-i?yn.OUTSIDE:a-1)return!0;return!1}function Ywt(t){let e=t._template.components,n=t._template.source;if(c(n))t.shaderSource+=`${n} +`;function Ae(t){this.type=void 0,this.shaderSource=void 0,this.materials=void 0,this.uniforms=void 0,this._uniforms=void 0,this.translucent=void 0,this._minificationFilter=f(t.minificationFilter,On.LINEAR),this._magnificationFilter=f(t.magnificationFilter,Ro.LINEAR),this._strict=void 0,this._template=void 0,this._count=void 0,this._texturePaths={},this._loadedImages=[],this._loadedCubeMaps=[],this._textures={},this._updateFunctions=[],this._defaultTexture=void 0,Iwt(t,this),Object.defineProperties(this,{type:{value:this.type,writable:!1}}),c(Ae._uniformList[this.type])||(Ae._uniformList[this.type]=Object.keys(this._uniforms))}Ae._uniformList={};Ae.fromType=function(t,e){let n=new Ae({fabric:{type:t}});if(c(e))for(let i in e)e.hasOwnProperty(i)&&(n.uniforms[i]=e[i]);return n};Ae.prototype.isTranslucent=function(){if(c(this.translucent))return typeof this.translucent=="function"?this.translucent():this.translucent;let t=!0,e=this._translucentFunctions,n=e.length;for(let i=0;i-1)return!0;return!1}function Ywt(t){let e=t._template.components,n=t._template.source;if(c(n))t.shaderSource+=`${n} `;else{if(t.shaderSource+=`czm_material czm_getMaterial(czm_materialInput materialInput) { `,t.shaderSource+=`czm_material material = czm_getDefaultMaterial(materialInput); @@ -4664,7 +4664,7 @@ czm_material czm_getMaterial(czm_materialInput materialInput) `:t.shaderSource+=`material.${o} = ${e[o]}; `}t.shaderSource+=`return material; } -`}}var zpt={mat2:pa,mat3:ot,mat4:L},xwt=/\.ktx2$/i;function Xwt(t){let e;return function(n,i){let o=n.uniforms,a=o[t],s=e!==a,l=!c(a)||a===Ae.DefaultImageId;e=a;let r=n._textures[t],d,m;if(a instanceof HTMLVideoElement){if(a.readyState>=2){if(s&&c(r)&&(r!==i.defaultTexture&&r.destroy(),r=void 0),!c(r)||r===i.defaultTexture){let Z=new Hn({minificationFilter:n._minificationFilter,magnificationFilter:n._magnificationFilter});r=new hn({context:i,source:a,sampler:Z}),n._textures[t]=r;return}r.copyFrom({source:a})}else c(r)||(n._textures[t]=i.defaultTexture);return}if(a instanceof hn&&a!==r){n._texturePaths[t]=void 0;let Z=n._textures[t];c(Z)&&Z!==n._defaultTexture&&Z.destroy(),n._textures[t]=a,d=`${t}Dimensions`,o.hasOwnProperty(d)&&(m=o[d],m.x=a._width,m.y=a._height);return}if(s&&c(r)&&l&&(r!==n._defaultTexture&&r.destroy(),r=void 0),c(r)||(n._texturePaths[t]=void 0,r=n._textures[t]=n._defaultTexture,d=`${t}Dimensions`,o.hasOwnProperty(d)&&(m=o[d],m.x=r._width,m.y=r._height)),l)return;let h=a instanceof te;if(!c(n._texturePaths[t])||h&&a.url!==n._texturePaths[t].url||!h&&a!==n._texturePaths[t]){if(typeof a=="string"||h){let Z=h?a:te.createIfNeeded(a),b;xwt.test(Z.url)?b=Fm(Z.url):b=Z.fetchImage(),Promise.resolve(b).then(function(u){n._loadedImages.push({id:t,image:u})}).catch(function(){c(r)&&r!==n._defaultTexture&&r.destroy(),n._textures[t]=n._defaultTexture})}else(a instanceof HTMLCanvasElement||a instanceof HTMLImageElement)&&n._loadedImages.push({id:t,image:a});n._texturePaths[t]=a}}}function Jwt(t){return function(e,n){let i=e.uniforms[t];if(i instanceof Ld){let a=e._textures[t];a!==e._defaultTexture&&a.destroy(),e._texturePaths[t]=void 0,e._textures[t]=i;return}if(c(e._textures[t])||(e._texturePaths[t]=void 0,e._textures[t]=n.defaultCubeMap),i===Ae.DefaultCubeMapId)return;let o=i.positiveX+i.negativeX+i.positiveY+i.negativeY+i.positiveZ+i.negativeZ;if(o!==e._texturePaths[t]){let a=[te.createIfNeeded(i.positiveX).fetchImage(),te.createIfNeeded(i.negativeX).fetchImage(),te.createIfNeeded(i.positiveY).fetchImage(),te.createIfNeeded(i.negativeY).fetchImage(),te.createIfNeeded(i.positiveZ).fetchImage(),te.createIfNeeded(i.negativeZ).fetchImage()];Promise.all(a).then(function(s){e._loadedCubeMaps.push({id:t,images:s})}),e._texturePaths[t]=o}}}function Lwt(t){let e=t._template.uniforms;for(let n in e)e.hasOwnProperty(n)&&jpt(t,n)}function jpt(t,e){let n=t._strict,i=t._template.uniforms,o=i[e],a=Mwt(o),s;if(a==="channels")s=J2(t,e,o,!1);else{if(a==="sampler2D"){let d=`${e}Dimensions`;Dwt(t,d)>0&&(i[d]={type:"ivec3",x:1,y:1},jpt(t,d))}if(!new RegExp(`uniform\\s+${a}\\s+${e}\\s*;`).test(t.shaderSource)){let d=`uniform ${a} ${e};`;t.shaderSource=d+t.shaderSource}let r=`${e}_${t._count++}`;if(s=J2(t,e,r),t.uniforms[e]=o,a==="sampler2D")t._uniforms[r]=function(){return t._textures[e]},t._updateFunctions.push(Xwt(e));else if(a==="samplerCube")t._uniforms[r]=function(){return t._textures[e]},t._updateFunctions.push(Jwt(e));else if(a.indexOf("mat")!==-1){let d=new zpt[a];t._uniforms[r]=function(){return zpt[a].fromColumnMajorArray(t.uniforms[e],d)}}else t._uniforms[r]=function(){return t.uniforms[e]}}}function Mwt(t){let e=t.type;if(!c(e)){let n=typeof t;if(n==="number")e="float";else if(n==="boolean")e="bool";else if(n==="string"||t instanceof te||t instanceof HTMLCanvasElement||t instanceof HTMLImageElement)/^([rgba]){1,4}$/i.test(t)?e="channels":t===Ae.DefaultCubeMapId?e="samplerCube":e="sampler2D";else if(n==="object")if(Array.isArray(t))(t.length===4||t.length===9||t.length===16)&&(e=`mat${Math.sqrt(t.length)}`);else{let i=0;for(let o in t)t.hasOwnProperty(o)&&(i+=1);i>=2&&i<=4?e=`vec${i}`:i===6&&(e="samplerCube")}}return e}function _wt(t){let e=t._strict,n=t._template.materials;for(let i in n)if(n.hasOwnProperty(i)){let o=new Ae({strict:e,fabric:n[i],count:t._count});t._count=o._count,t._uniforms=ze(t._uniforms,o._uniforms,!0),t.materials[i]=o,t._translucentFunctions=t._translucentFunctions.concat(o._translucentFunctions);let a="czm_getMaterial",s=`${a}_${t._count++}`;J2(o,a,s),t.shaderSource=o.shaderSource+t.shaderSource;let l=`${s}(materialInput)`,r=J2(t,i,l)}}function J2(t,e,n,i){i=f(i,!0);let o=0,a="([\\w])?",s=`([\\w${i?".":""}])?`,l=new RegExp(s+e+a,"g");return t.shaderSource=t.shaderSource.replace(l,function(r,d,m){return d||m?r:(o+=1,n)}),o}function Dwt(t,e,n){return J2(t,e,e,n)}Ae._materialCache={_materials:{},addMaterial:function(t,e){this._materials[t]=e},getMaterial:function(t){return this._materials[t]}};Ae.DefaultImageId="czm_defaultImage";Ae.DefaultCubeMapId="czm_defaultCubeMap";Ae.ColorType="Color";Ae._materialCache.addMaterial(Ae.ColorType,{fabric:{type:Ae.ColorType,uniforms:{color:new v(1,0,0,.5)},components:{diffuse:"color.rgb",alpha:"color.a"}},translucent:function(t){return t.uniforms.color.alpha<1}});Ae.ImageType="Image";Ae._materialCache.addMaterial(Ae.ImageType,{fabric:{type:Ae.ImageType,uniforms:{image:Ae.DefaultImageId,repeat:new K(1,1),color:new v(1,1,1,1)},components:{diffuse:"texture(image, fract(repeat * materialInput.st)).rgb * color.rgb",alpha:"texture(image, fract(repeat * materialInput.st)).a * color.a"}},translucent:function(t){return t.uniforms.color.alpha<1}});Ae.DiffuseMapType="DiffuseMap";Ae._materialCache.addMaterial(Ae.DiffuseMapType,{fabric:{type:Ae.DiffuseMapType,uniforms:{image:Ae.DefaultImageId,channels:"rgb",repeat:new K(1,1)},components:{diffuse:"texture(image, fract(repeat * materialInput.st)).channels"}},translucent:!1});Ae.AlphaMapType="AlphaMap";Ae._materialCache.addMaterial(Ae.AlphaMapType,{fabric:{type:Ae.AlphaMapType,uniforms:{image:Ae.DefaultImageId,channel:"a",repeat:new K(1,1)},components:{alpha:"texture(image, fract(repeat * materialInput.st)).channel"}},translucent:!0});Ae.SpecularMapType="SpecularMap";Ae._materialCache.addMaterial(Ae.SpecularMapType,{fabric:{type:Ae.SpecularMapType,uniforms:{image:Ae.DefaultImageId,channel:"r",repeat:new K(1,1)},components:{specular:"texture(image, fract(repeat * materialInput.st)).channel"}},translucent:!1});Ae.EmissionMapType="EmissionMap";Ae._materialCache.addMaterial(Ae.EmissionMapType,{fabric:{type:Ae.EmissionMapType,uniforms:{image:Ae.DefaultImageId,channels:"rgb",repeat:new K(1,1)},components:{emission:"texture(image, fract(repeat * materialInput.st)).channels"}},translucent:!1});Ae.BumpMapType="BumpMap";Ae._materialCache.addMaterial(Ae.BumpMapType,{fabric:{type:Ae.BumpMapType,uniforms:{image:Ae.DefaultImageId,channel:"r",strength:.8,repeat:new K(1,1)},source:U2},translucent:!1});Ae.NormalMapType="NormalMap";Ae._materialCache.addMaterial(Ae.NormalMapType,{fabric:{type:Ae.NormalMapType,uniforms:{image:Ae.DefaultImageId,channels:"rgb",strength:.8,repeat:new K(1,1)},source:I2},translucent:!1});Ae.GridType="Grid";Ae._materialCache.addMaterial(Ae.GridType,{fabric:{type:Ae.GridType,uniforms:{color:new v(0,1,0,1),cellAlpha:.1,lineCount:new K(8,8),lineThickness:new K(1,1),lineOffset:new K(0,0)},source:C2},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.cellAlpha<1}});Ae.StripeType="Stripe";Ae._materialCache.addMaterial(Ae.StripeType,{fabric:{type:Ae.StripeType,uniforms:{horizontal:!0,evenColor:new v(1,1,1,.5),oddColor:new v(0,0,1,.5),offset:0,repeat:5},source:x2},translucent:function(t){let e=t.uniforms;return e.evenColor.alpha<1||e.oddColor.alpha<1}});Ae.CheckerboardType="Checkerboard";Ae._materialCache.addMaterial(Ae.CheckerboardType,{fabric:{type:Ae.CheckerboardType,uniforms:{lightColor:new v(1,1,1,.5),darkColor:new v(0,0,0,.5),repeat:new K(5,5)},source:G2},translucent:function(t){let e=t.uniforms;return e.lightColor.alpha<1||e.darkColor.alpha<1}});Ae.DotType="Dot";Ae._materialCache.addMaterial(Ae.DotType,{fabric:{type:Ae.DotType,uniforms:{lightColor:new v(1,1,0,.75),darkColor:new v(0,1,1,.75),repeat:new K(5,5)},source:A2},translucent:function(t){let e=t.uniforms;return e.lightColor.alpha<1||e.darkColor.alpha<1}});Ae.WaterType="Water";Ae._materialCache.addMaterial(Ae.WaterType,{fabric:{type:Ae.WaterType,uniforms:{baseWaterColor:new v(.2,.3,.6,1),blendColor:new v(0,1,.699,1),specularMap:Ae.DefaultImageId,normalMap:Ae.DefaultImageId,frequency:10,animationSpeed:.01,amplitude:1,specularIntensity:.5,fadeFactor:1},source:X2},translucent:function(t){let e=t.uniforms;return e.baseWaterColor.alpha<1||e.blendColor.alpha<1}});Ae.RimLightingType="RimLighting";Ae._materialCache.addMaterial(Ae.RimLightingType,{fabric:{type:Ae.RimLightingType,uniforms:{color:new v(1,0,0,.7),rimColor:new v(1,1,1,.4),width:.3},source:k2},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.rimColor.alpha<1}});Ae.FadeType="Fade";Ae._materialCache.addMaterial(Ae.FadeType,{fabric:{type:Ae.FadeType,uniforms:{fadeInColor:new v(1,0,0,1),fadeOutColor:new v(0,0,0,0),maximumDistance:.5,repeat:!0,fadeDirection:{x:!0,y:!0},time:new K(.5,.5)},source:E2},translucent:function(t){let e=t.uniforms;return e.fadeInColor.alpha<1||e.fadeOutColor.alpha<1}});Ae.PolylineArrowType="PolylineArrow";Ae._materialCache.addMaterial(Ae.PolylineArrowType,{fabric:{type:Ae.PolylineArrowType,uniforms:{color:new v(1,1,1,1)},source:N2},translucent:!0});Ae.PolylineDashType="PolylineDash";Ae._materialCache.addMaterial(Ae.PolylineDashType,{fabric:{type:Ae.PolylineDashType,uniforms:{color:new v(1,0,1,1),gapColor:new v(0,0,0,0),dashLength:16,dashPattern:255},source:y2},translucent:!0});Ae.PolylineGlowType="PolylineGlow";Ae._materialCache.addMaterial(Ae.PolylineGlowType,{fabric:{type:Ae.PolylineGlowType,uniforms:{color:new v(0,.5,1,1),glowPower:.25,taperPower:1},source:B2},translucent:!0});Ae.PolylineOutlineType="PolylineOutline";Ae._materialCache.addMaterial(Ae.PolylineOutlineType,{fabric:{type:Ae.PolylineOutlineType,uniforms:{color:new v(1,1,1,1),outlineColor:new v(1,0,0,1),outlineWidth:1},source:Q2},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.outlineColor.alpha<1}});Ae.ElevationContourType="ElevationContour";Ae._materialCache.addMaterial(Ae.ElevationContourType,{fabric:{type:Ae.ElevationContourType,uniforms:{spacing:100,color:new v(1,0,0,1),width:1},source:S2},translucent:!1});Ae.ElevationRampType="ElevationRamp";Ae._materialCache.addMaterial(Ae.ElevationRampType,{fabric:{type:Ae.ElevationRampType,uniforms:{image:Ae.DefaultImageId,minimumHeight:0,maximumHeight:1e4},source:g2},translucent:!1});Ae.SlopeRampMaterialType="SlopeRamp";Ae._materialCache.addMaterial(Ae.SlopeRampMaterialType,{fabric:{type:Ae.SlopeRampMaterialType,uniforms:{image:Ae.DefaultImageId},source:Y2},translucent:!1});Ae.AspectRampMaterialType="AspectRamp";Ae._materialCache.addMaterial(Ae.AspectRampMaterialType,{fabric:{type:Ae.AspectRampMaterialType,uniforms:{image:Ae.DefaultImageId},source:F2},translucent:!1});Ae.ElevationBandType="ElevationBand";Ae._materialCache.addMaterial(Ae.ElevationBandType,{fabric:{type:Ae.ElevationBandType,uniforms:{heights:Ae.DefaultImageId,colors:Ae.DefaultImageId},source:T2},translucent:!0});var eo=Ae;function NG(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.translucent,!0),n=f(t.closed,!1),i=f(t.materialSupport,NG.MaterialSupport.TEXTURED);this.material=c(t.material)?t.material:eo.fromType(eo.ColorType),this.translucent=e,this._vertexShaderSource=f(t.vertexShaderSource,i.vertexShaderSource),this._fragmentShaderSource=f(t.fragmentShaderSource,i.fragmentShaderSource),this._renderState=ua.getDefaultRenderState(e,n,t.renderState),this._closed=n,this._materialSupport=i,this._vertexFormat=i.vertexFormat,this._flat=f(t.flat,!1),this._faceForward=f(t.faceForward,!n)}Object.defineProperties(NG.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},materialSupport:{get:function(){return this._materialSupport}},vertexFormat:{get:function(){return this._vertexFormat}},flat:{get:function(){return this._flat}},faceForward:{get:function(){return this._faceForward}}});NG.prototype.getFragmentShaderSource=ua.prototype.getFragmentShaderSource;NG.prototype.isTranslucent=ua.prototype.isTranslucent;NG.prototype.getRenderState=ua.prototype.getRenderState;NG.MaterialSupport={BASIC:Object.freeze({vertexFormat:ee.POSITION_AND_NORMAL,vertexShaderSource:R2,fragmentShaderSource:b2}),TEXTURED:Object.freeze({vertexFormat:ee.POSITION_NORMAL_AND_ST,vertexShaderSource:f2,fragmentShaderSource:W2}),ALL:Object.freeze({vertexFormat:ee.ALL,vertexShaderSource:V2,fragmentShaderSource:Z2})};var Fa=NG;var Gmn=R(W(),1);var rmn=R(W(),1),L2=`in vec3 v_positionEC; +`}}var zpt={mat2:pa,mat3:ot,mat4:L},xwt=/\.ktx2$/i;function Xwt(t){let e;return function(n,i){let o=n.uniforms,a=o[t],s=e!==a,l=!c(a)||a===Ae.DefaultImageId;e=a;let r=n._textures[t],d,m;if(a instanceof HTMLVideoElement){if(a.readyState>=2){if(s&&c(r)&&(r!==i.defaultTexture&&r.destroy(),r=void 0),!c(r)||r===i.defaultTexture){let u=new Hn({minificationFilter:n._minificationFilter,magnificationFilter:n._magnificationFilter});r=new hn({context:i,source:a,sampler:u}),n._textures[t]=r;return}r.copyFrom({source:a})}else c(r)||(n._textures[t]=i.defaultTexture);return}if(a instanceof hn&&a!==r){n._texturePaths[t]=void 0;let u=n._textures[t];c(u)&&u!==n._defaultTexture&&u.destroy(),n._textures[t]=a,d=`${t}Dimensions`,o.hasOwnProperty(d)&&(m=o[d],m.x=a._width,m.y=a._height);return}if(s&&c(r)&&l&&(r!==n._defaultTexture&&r.destroy(),r=void 0),c(r)||(n._texturePaths[t]=void 0,r=n._textures[t]=n._defaultTexture,d=`${t}Dimensions`,o.hasOwnProperty(d)&&(m=o[d],m.x=r._width,m.y=r._height)),l)return;let h=a instanceof te;if(!c(n._texturePaths[t])||h&&a.url!==n._texturePaths[t].url||!h&&a!==n._texturePaths[t]){if(typeof a=="string"||h){let u=h?a:te.createIfNeeded(a),R;xwt.test(u.url)?R=Fm(u.url):R=u.fetchImage(),Promise.resolve(R).then(function(V){n._loadedImages.push({id:t,image:V})}).catch(function(){c(r)&&r!==n._defaultTexture&&r.destroy(),n._textures[t]=n._defaultTexture})}else(a instanceof HTMLCanvasElement||a instanceof HTMLImageElement)&&n._loadedImages.push({id:t,image:a});n._texturePaths[t]=a}}}function Jwt(t){return function(e,n){let i=e.uniforms[t];if(i instanceof Ld){let a=e._textures[t];a!==e._defaultTexture&&a.destroy(),e._texturePaths[t]=void 0,e._textures[t]=i;return}if(c(e._textures[t])||(e._texturePaths[t]=void 0,e._textures[t]=n.defaultCubeMap),i===Ae.DefaultCubeMapId)return;let o=i.positiveX+i.negativeX+i.positiveY+i.negativeY+i.positiveZ+i.negativeZ;if(o!==e._texturePaths[t]){let a=[te.createIfNeeded(i.positiveX).fetchImage(),te.createIfNeeded(i.negativeX).fetchImage(),te.createIfNeeded(i.positiveY).fetchImage(),te.createIfNeeded(i.negativeY).fetchImage(),te.createIfNeeded(i.positiveZ).fetchImage(),te.createIfNeeded(i.negativeZ).fetchImage()];Promise.all(a).then(function(s){e._loadedCubeMaps.push({id:t,images:s})}),e._texturePaths[t]=o}}}function Lwt(t){let e=t._template.uniforms;for(let n in e)e.hasOwnProperty(n)&&jpt(t,n)}function jpt(t,e){let n=t._strict,i=t._template.uniforms,o=i[e],a=Mwt(o),s;if(a==="channels")s=Jk(t,e,o,!1);else{if(a==="sampler2D"){let d=`${e}Dimensions`;Dwt(t,d)>0&&(i[d]={type:"ivec3",x:1,y:1},jpt(t,d))}if(!new RegExp(`uniform\\s+${a}\\s+${e}\\s*;`).test(t.shaderSource)){let d=`uniform ${a} ${e};`;t.shaderSource=d+t.shaderSource}let r=`${e}_${t._count++}`;if(s=Jk(t,e,r),t.uniforms[e]=o,a==="sampler2D")t._uniforms[r]=function(){return t._textures[e]},t._updateFunctions.push(Xwt(e));else if(a==="samplerCube")t._uniforms[r]=function(){return t._textures[e]},t._updateFunctions.push(Jwt(e));else if(a.indexOf("mat")!==-1){let d=new zpt[a];t._uniforms[r]=function(){return zpt[a].fromColumnMajorArray(t.uniforms[e],d)}}else t._uniforms[r]=function(){return t.uniforms[e]}}}function Mwt(t){let e=t.type;if(!c(e)){let n=typeof t;if(n==="number")e="float";else if(n==="boolean")e="bool";else if(n==="string"||t instanceof te||t instanceof HTMLCanvasElement||t instanceof HTMLImageElement)/^([rgba]){1,4}$/i.test(t)?e="channels":t===Ae.DefaultCubeMapId?e="samplerCube":e="sampler2D";else if(n==="object")if(Array.isArray(t))(t.length===4||t.length===9||t.length===16)&&(e=`mat${Math.sqrt(t.length)}`);else{let i=0;for(let o in t)t.hasOwnProperty(o)&&(i+=1);i>=2&&i<=4?e=`vec${i}`:i===6&&(e="samplerCube")}}return e}function _wt(t){let e=t._strict,n=t._template.materials;for(let i in n)if(n.hasOwnProperty(i)){let o=new Ae({strict:e,fabric:n[i],count:t._count});t._count=o._count,t._uniforms=ze(t._uniforms,o._uniforms,!0),t.materials[i]=o,t._translucentFunctions=t._translucentFunctions.concat(o._translucentFunctions);let a="czm_getMaterial",s=`${a}_${t._count++}`;Jk(o,a,s),t.shaderSource=o.shaderSource+t.shaderSource;let l=`${s}(materialInput)`,r=Jk(t,i,l)}}function Jk(t,e,n,i){i=f(i,!0);let o=0,a="([\\w])?",s=`([\\w${i?".":""}])?`,l=new RegExp(s+e+a,"g");return t.shaderSource=t.shaderSource.replace(l,function(r,d,m){return d||m?r:(o+=1,n)}),o}function Dwt(t,e,n){return Jk(t,e,e,n)}Ae._materialCache={_materials:{},addMaterial:function(t,e){this._materials[t]=e},getMaterial:function(t){return this._materials[t]}};Ae.DefaultImageId="czm_defaultImage";Ae.DefaultCubeMapId="czm_defaultCubeMap";Ae.ColorType="Color";Ae._materialCache.addMaterial(Ae.ColorType,{fabric:{type:Ae.ColorType,uniforms:{color:new v(1,0,0,.5)},components:{diffuse:"color.rgb",alpha:"color.a"}},translucent:function(t){return t.uniforms.color.alpha<1}});Ae.ImageType="Image";Ae._materialCache.addMaterial(Ae.ImageType,{fabric:{type:Ae.ImageType,uniforms:{image:Ae.DefaultImageId,repeat:new K(1,1),color:new v(1,1,1,1)},components:{diffuse:"texture(image, fract(repeat * materialInput.st)).rgb * color.rgb",alpha:"texture(image, fract(repeat * materialInput.st)).a * color.a"}},translucent:function(t){return t.uniforms.color.alpha<1}});Ae.DiffuseMapType="DiffuseMap";Ae._materialCache.addMaterial(Ae.DiffuseMapType,{fabric:{type:Ae.DiffuseMapType,uniforms:{image:Ae.DefaultImageId,channels:"rgb",repeat:new K(1,1)},components:{diffuse:"texture(image, fract(repeat * materialInput.st)).channels"}},translucent:!1});Ae.AlphaMapType="AlphaMap";Ae._materialCache.addMaterial(Ae.AlphaMapType,{fabric:{type:Ae.AlphaMapType,uniforms:{image:Ae.DefaultImageId,channel:"a",repeat:new K(1,1)},components:{alpha:"texture(image, fract(repeat * materialInput.st)).channel"}},translucent:!0});Ae.SpecularMapType="SpecularMap";Ae._materialCache.addMaterial(Ae.SpecularMapType,{fabric:{type:Ae.SpecularMapType,uniforms:{image:Ae.DefaultImageId,channel:"r",repeat:new K(1,1)},components:{specular:"texture(image, fract(repeat * materialInput.st)).channel"}},translucent:!1});Ae.EmissionMapType="EmissionMap";Ae._materialCache.addMaterial(Ae.EmissionMapType,{fabric:{type:Ae.EmissionMapType,uniforms:{image:Ae.DefaultImageId,channels:"rgb",repeat:new K(1,1)},components:{emission:"texture(image, fract(repeat * materialInput.st)).channels"}},translucent:!1});Ae.BumpMapType="BumpMap";Ae._materialCache.addMaterial(Ae.BumpMapType,{fabric:{type:Ae.BumpMapType,uniforms:{image:Ae.DefaultImageId,channel:"r",strength:.8,repeat:new K(1,1)},source:Uk},translucent:!1});Ae.NormalMapType="NormalMap";Ae._materialCache.addMaterial(Ae.NormalMapType,{fabric:{type:Ae.NormalMapType,uniforms:{image:Ae.DefaultImageId,channels:"rgb",strength:.8,repeat:new K(1,1)},source:Ik},translucent:!1});Ae.GridType="Grid";Ae._materialCache.addMaterial(Ae.GridType,{fabric:{type:Ae.GridType,uniforms:{color:new v(0,1,0,1),cellAlpha:.1,lineCount:new K(8,8),lineThickness:new K(1,1),lineOffset:new K(0,0)},source:Ck},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.cellAlpha<1}});Ae.StripeType="Stripe";Ae._materialCache.addMaterial(Ae.StripeType,{fabric:{type:Ae.StripeType,uniforms:{horizontal:!0,evenColor:new v(1,1,1,.5),oddColor:new v(0,0,1,.5),offset:0,repeat:5},source:xk},translucent:function(t){let e=t.uniforms;return e.evenColor.alpha<1||e.oddColor.alpha<1}});Ae.CheckerboardType="Checkerboard";Ae._materialCache.addMaterial(Ae.CheckerboardType,{fabric:{type:Ae.CheckerboardType,uniforms:{lightColor:new v(1,1,1,.5),darkColor:new v(0,0,0,.5),repeat:new K(5,5)},source:Gk},translucent:function(t){let e=t.uniforms;return e.lightColor.alpha<1||e.darkColor.alpha<1}});Ae.DotType="Dot";Ae._materialCache.addMaterial(Ae.DotType,{fabric:{type:Ae.DotType,uniforms:{lightColor:new v(1,1,0,.75),darkColor:new v(0,1,1,.75),repeat:new K(5,5)},source:Ak},translucent:function(t){let e=t.uniforms;return e.lightColor.alpha<1||e.darkColor.alpha<1}});Ae.WaterType="Water";Ae._materialCache.addMaterial(Ae.WaterType,{fabric:{type:Ae.WaterType,uniforms:{baseWaterColor:new v(.2,.3,.6,1),blendColor:new v(0,1,.699,1),specularMap:Ae.DefaultImageId,normalMap:Ae.DefaultImageId,frequency:10,animationSpeed:.01,amplitude:1,specularIntensity:.5,fadeFactor:1},source:Xk},translucent:function(t){let e=t.uniforms;return e.baseWaterColor.alpha<1||e.blendColor.alpha<1}});Ae.RimLightingType="RimLighting";Ae._materialCache.addMaterial(Ae.RimLightingType,{fabric:{type:Ae.RimLightingType,uniforms:{color:new v(1,0,0,.7),rimColor:new v(1,1,1,.4),width:.3},source:kk},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.rimColor.alpha<1}});Ae.FadeType="Fade";Ae._materialCache.addMaterial(Ae.FadeType,{fabric:{type:Ae.FadeType,uniforms:{fadeInColor:new v(1,0,0,1),fadeOutColor:new v(0,0,0,0),maximumDistance:.5,repeat:!0,fadeDirection:{x:!0,y:!0},time:new K(.5,.5)},source:Ek},translucent:function(t){let e=t.uniforms;return e.fadeInColor.alpha<1||e.fadeOutColor.alpha<1}});Ae.PolylineArrowType="PolylineArrow";Ae._materialCache.addMaterial(Ae.PolylineArrowType,{fabric:{type:Ae.PolylineArrowType,uniforms:{color:new v(1,1,1,1)},source:Nk},translucent:!0});Ae.PolylineDashType="PolylineDash";Ae._materialCache.addMaterial(Ae.PolylineDashType,{fabric:{type:Ae.PolylineDashType,uniforms:{color:new v(1,0,1,1),gapColor:new v(0,0,0,0),dashLength:16,dashPattern:255},source:yk},translucent:!0});Ae.PolylineGlowType="PolylineGlow";Ae._materialCache.addMaterial(Ae.PolylineGlowType,{fabric:{type:Ae.PolylineGlowType,uniforms:{color:new v(0,.5,1,1),glowPower:.25,taperPower:1},source:Bk},translucent:!0});Ae.PolylineOutlineType="PolylineOutline";Ae._materialCache.addMaterial(Ae.PolylineOutlineType,{fabric:{type:Ae.PolylineOutlineType,uniforms:{color:new v(1,1,1,1),outlineColor:new v(1,0,0,1),outlineWidth:1},source:Qk},translucent:function(t){let e=t.uniforms;return e.color.alpha<1||e.outlineColor.alpha<1}});Ae.ElevationContourType="ElevationContour";Ae._materialCache.addMaterial(Ae.ElevationContourType,{fabric:{type:Ae.ElevationContourType,uniforms:{spacing:100,color:new v(1,0,0,1),width:1},source:Tk},translucent:!1});Ae.ElevationRampType="ElevationRamp";Ae._materialCache.addMaterial(Ae.ElevationRampType,{fabric:{type:Ae.ElevationRampType,uniforms:{image:Ae.DefaultImageId,minimumHeight:0,maximumHeight:1e4},source:gk},translucent:!1});Ae.SlopeRampMaterialType="SlopeRamp";Ae._materialCache.addMaterial(Ae.SlopeRampMaterialType,{fabric:{type:Ae.SlopeRampMaterialType,uniforms:{image:Ae.DefaultImageId},source:Yk},translucent:!1});Ae.AspectRampMaterialType="AspectRamp";Ae._materialCache.addMaterial(Ae.AspectRampMaterialType,{fabric:{type:Ae.AspectRampMaterialType,uniforms:{image:Ae.DefaultImageId},source:Fk},translucent:!1});Ae.ElevationBandType="ElevationBand";Ae._materialCache.addMaterial(Ae.ElevationBandType,{fabric:{type:Ae.ElevationBandType,uniforms:{heights:Ae.DefaultImageId,colors:Ae.DefaultImageId},source:Sk},translucent:!0});var eo=Ae;function NG(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.translucent,!0),n=f(t.closed,!1),i=f(t.materialSupport,NG.MaterialSupport.TEXTURED);this.material=c(t.material)?t.material:eo.fromType(eo.ColorType),this.translucent=e,this._vertexShaderSource=f(t.vertexShaderSource,i.vertexShaderSource),this._fragmentShaderSource=f(t.fragmentShaderSource,i.fragmentShaderSource),this._renderState=Va.getDefaultRenderState(e,n,t.renderState),this._closed=n,this._materialSupport=i,this._vertexFormat=i.vertexFormat,this._flat=f(t.flat,!1),this._faceForward=f(t.faceForward,!n)}Object.defineProperties(NG.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},materialSupport:{get:function(){return this._materialSupport}},vertexFormat:{get:function(){return this._vertexFormat}},flat:{get:function(){return this._flat}},faceForward:{get:function(){return this._faceForward}}});NG.prototype.getFragmentShaderSource=Va.prototype.getFragmentShaderSource;NG.prototype.isTranslucent=Va.prototype.isTranslucent;NG.prototype.getRenderState=Va.prototype.getRenderState;NG.MaterialSupport={BASIC:Object.freeze({vertexFormat:ee.POSITION_AND_NORMAL,vertexShaderSource:bk,fragmentShaderSource:Rk}),TEXTURED:Object.freeze({vertexFormat:ee.POSITION_NORMAL_AND_ST,vertexShaderSource:fk,fragmentShaderSource:Wk}),ALL:Object.freeze({vertexFormat:ee.ALL,vertexShaderSource:Zk,fragmentShaderSource:uk})};var Fa=NG;var Gmn=b(W(),1);var rmn=b(W(),1),Lk=`in vec3 v_positionEC; in vec3 v_normalEC; in vec4 v_color; @@ -4688,7 +4688,7 @@ void main() out_FragColor = czm_phong(normalize(positionToEyeEC), material, czm_lightDirectionEC); } -`;var cmn=R(W(),1),M2=`in vec3 position3DHigh; +`;var cmn=b(W(),1),Mk=`in vec3 position3DHigh; in vec3 position3DLow; in vec3 normal; in vec4 color; @@ -4708,13 +4708,13 @@ void main() gl_Position = czm_modelViewProjectionRelativeToEye * p; } -`;var hmn=R(W(),1),yG=`in vec4 v_color; +`;var hmn=b(W(),1),yG=`in vec4 v_color; void main() { out_FragColor = czm_gammaCorrect(v_color); } -`;var umn=R(W(),1),_2=`in vec3 position3DHigh; +`;var Vmn=b(W(),1),_k=`in vec3 position3DHigh; in vec3 position3DLow; in vec4 color; in float batchId; @@ -4729,7 +4729,7 @@ void main() gl_Position = czm_modelViewProjectionRelativeToEye * p; } -`;function IR(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.translucent,!0),n=f(t.closed,!1),i=f(t.flat,!1),o=i?_2:M2,a=i?yG:L2,s=i?IR.FLAT_VERTEX_FORMAT:IR.VERTEX_FORMAT;this.material=void 0,this.translucent=e,this._vertexShaderSource=f(t.vertexShaderSource,o),this._fragmentShaderSource=f(t.fragmentShaderSource,a),this._renderState=ua.getDefaultRenderState(e,n,t.renderState),this._closed=n,this._vertexFormat=s,this._flat=i,this._faceForward=f(t.faceForward,!n)}Object.defineProperties(IR.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},vertexFormat:{get:function(){return this._vertexFormat}},flat:{get:function(){return this._flat}},faceForward:{get:function(){return this._faceForward}}});IR.VERTEX_FORMAT=ee.POSITION_AND_NORMAL;IR.FLAT_VERTEX_FORMAT=ee.POSITION_ONLY;IR.prototype.getFragmentShaderSource=ua.prototype.getFragmentShaderSource;IR.prototype.isTranslucent=ua.prototype.isTranslucent;IR.prototype.getRenderState=ua.prototype.getRenderState;var jn=IR;var Imn=R(W(),1);function pE(t){this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this.color=t}Object.defineProperties(pE.prototype,{isConstant:{get:function(){return et.isConstant(this._color)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color")});pE.prototype.getType=function(t){return"Color"};pE.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,v.WHITE,e.color),e};pE.prototype.equals=function(t){return this===t||t instanceof pE&&et.equals(this._color,t._color)};var Cn=pE;var _bn=R(W(),1);var Ubn=R(W(),1);var $mn=R(W(),1);var Jmn=R(W(),1);function ff(t){t=f(t,f.EMPTY_OBJECT),this._ellipsoid=f(t.ellipsoid,mt.WGS84),this._rectangle=f(t.rectangle,Gt.MAX_VALUE),this._projection=new yo(this._ellipsoid),this._numberOfLevelZeroTilesX=f(t.numberOfLevelZeroTilesX,2),this._numberOfLevelZeroTilesY=f(t.numberOfLevelZeroTilesY,1)}Object.defineProperties(ff.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},rectangle:{get:function(){return this._rectangle}},projection:{get:function(){return this._projection}}});ff.prototype.getNumberOfXTilesAtLevel=function(t){return this._numberOfLevelZeroTilesX<=o&&(d=o-1);let m=(i.north-t.latitude)/l|0;return m>=a&&(m=a-1),c(n)?(n.x=d,n.y=m,n):new K(d,m)};var Qo=ff;var qpt=new p,$pt=new p,tut=new gt,S7=new p,Owt=new p,eut=new Ft,Hwt=new Qo,D2=[new gt,new gt,new gt,new gt],O2=new K,fl={};fl.initialize=function(){let t=fl._initPromise;return c(t)||(t=te.fetchJson(Dn("Assets/approximateTerrainHeights.json")).then(function(e){fl._terrainHeights=e}),fl._initPromise=t),t};fl.getMinimumMaximumHeights=function(t,e){e=f(e,mt.WGS84);let n=nut(t),i=fl._defaultMinTerrainHeight,o=fl._defaultMaxTerrainHeight;if(c(n)){let a=`${n.level}-${n.x}-${n.y}`,s=fl._terrainHeights[a];c(s)&&(i=s[0],o=s[1]),e.cartographicToCartesian(Gt.northeast(t,tut),qpt),e.cartographicToCartesian(Gt.southwest(t,tut),$pt),p.midpoint($pt,qpt,S7);let l=e.scaleToGeodeticSurface(S7,Owt);if(c(l)){let r=p.distance(S7,l);i=Math.min(i,-r)}else i=fl._defaultMinTerrainHeight}return i=Math.max(fl._defaultMinTerrainHeight,i),{minimumTerrainHeight:i,maximumTerrainHeight:o}};fl.getBoundingSphere=function(t,e){e=f(e,mt.WGS84);let n=nut(t),i=fl._defaultMaxTerrainHeight;if(c(n)){let a=`${n.level}-${n.x}-${n.y}`,s=fl._terrainHeights[a];c(s)&&(i=s[1])}let o=Ft.fromRectangle3D(t,e,0);return Ft.fromRectangle3D(t,e,i,eut),Ft.union(o,eut,o)};function nut(t){gt.fromRadians(t.east,t.north,0,D2[0]),gt.fromRadians(t.west,t.north,0,D2[1]),gt.fromRadians(t.east,t.south,0,D2[2]),gt.fromRadians(t.west,t.south,0,D2[3]);let e=0,n=0,i=0,o=0,a=fl._terrainHeightsMaxLevel,s;for(s=0;s<=a;++s){let l=!1;for(let r=0;r<4;++r){let d=D2[r];if(Hwt.positionToTileXY(d,s,O2),r===0)i=O2.x,o=O2.y;else if(i!==O2.x||o!==O2.y){l=!0;break}}if(l)break;e=i,n=o}if(s!==0)return{x:e,y:n,level:s>a?a:s-1}}fl._terrainHeightsMaxLevel=6;fl._defaultMaxTerrainHeight=9e3;fl._defaultMinTerrainHeight=-1e5;fl._terrainHeights=gH?gH:void 0;fl._initPromise=gH?new Promise(function(t){t()}):void 0;Object.defineProperties(fl,{initialized:{get:function(){return c(fl._terrainHeights)}}});var uo=fl;var cpn=R(W(),1);var Phn=R(W(),1);var ahn=R(W(),1);function Ec(t,e,n){this.minimum=p.clone(f(t,p.ZERO)),this.maximum=p.clone(f(e,p.ZERO)),c(n)?n=p.clone(n):n=p.midpoint(this.minimum,this.maximum,new p),this.center=n}Ec.fromCorners=function(t,e,n){return c(n)||(n=new Ec),n.minimum=p.clone(t,n.minimum),n.maximum=p.clone(e,n.maximum),n.center=p.midpoint(t,e,n.center),n};Ec.fromPoints=function(t,e){if(c(e)||(e=new Ec),!c(t)||t.length===0)return e.minimum=p.clone(p.ZERO,e.minimum),e.maximum=p.clone(p.ZERO,e.maximum),e.center=p.clone(p.ZERO,e.center),e;let n=t[0].x,i=t[0].y,o=t[0].z,a=t[0].x,s=t[0].y,l=t[0].z,r=t.length;for(let h=1;h0?yn.INSIDE:a+o<0?yn.OUTSIDE:yn.INTERSECTING};Ec.prototype.clone=function(t){return Ec.clone(this,t)};Ec.prototype.intersectPlane=function(t){return Ec.intersectPlane(this,t)};Ec.prototype.equals=function(t){return Ec.equals(this,t)};var Ff=Ec;var Bhn=R(W(),1);var rhn=R(W(),1);var g7={};g7.computeDiscriminant=function(t,e,n){return e*e-4*t*n};function iut(t,e,n){let i=t+e;return k.sign(t)!==k.sign(e)&&Math.abs(i/Math.max(Math.abs(t),Math.abs(e)))d&&d/r0?[l/t,n/l]:[n/l,l/t]};var Cc=g7;var Vhn=R(W(),1);var mhn=R(W(),1);var C7={};C7.computeDiscriminant=function(t,e,n,i){let o=t*t,a=e*e,s=n*n,l=i*i;return 18*t*e*n*i+a*s-27*o*l-4*(t*s*n+a*e*i)};function E7(t,e,n,i){let o=t,a=e/3,s=n/3,l=i,r=o*s,d=a*l,m=a*a,h=s*s,Z=o*s-m,b=o*l-a*s,u=a*l-h,F=4*Z*u-b*b,U,G;if(F<0){let nt,$,dt;m*d>=r*h?(nt=o,$=Z,dt=-2*a*Z+o*b):(nt=l,$=u,dt=-l*b+2*s*u);let at=-(dt<0?-1:1)*Math.abs(nt)*Math.sqrt(-F);G=-dt+at;let st=G/2,Et=st<0?-Math.pow(-st,1/3):Math.pow(st,1/3),Qt=G===at?-Et:-$/Et;return U=$<=0?Et+Qt:-dt/(Et*Et+Qt*Qt+$),m*d>=r*h?[(U-a)/o]:[-l/(U+s)]}let A=Z,T=-2*a*Z+o*b,g=u,C=-l*b+2*s*u,y=Math.sqrt(F),Y=Math.sqrt(3)/2,Q=Math.abs(Math.atan2(o*y,-T)/3);U=2*Math.sqrt(-A);let J=Math.cos(Q);G=U*J;let M=U*(-J/2-Y*Math.sin(Q)),V=G+M>2*a?G-a:M-a,E=o,I=V/E;Q=Math.abs(Math.atan2(l*y,-C)/3),U=2*Math.sqrt(-g),J=Math.cos(Q),G=U*J,M=U*(-J/2-Y*Math.sin(Q));let B=-l,X=G+M<2*s?G+s:M+s,_=B/X,P=E*X,w=-V*X-E*B,z=V*B,H=(s*w-a*z)/(-a*w+s*P);return I<=H?I<=_?H<=_?[I,H,_]:[I,_,H]:[_,I,H]:I<=_?[H,I,_]:H<=_?[H,_,I]:[_,H,I]}C7.computeRealRoots=function(t,e,n,i){let o,a;if(t===0)return Cc.computeRealRoots(e,n,i);if(e===0){if(n===0){if(i===0)return[0,0,0];a=-i/t;let s=a<0?-Math.pow(-a,1/3):Math.pow(a,1/3);return[s,s,s]}else if(i===0)return o=Cc.computeRealRoots(t,0,n),o.Length===0?[0]:[o[0],0,o[1]];return E7(t,0,n,i)}else{if(n===0)return i===0?(a=-e/t,a<0?[a,0,0]:[0,0,a]):E7(t,e,0,i);if(i===0)return o=Cc.computeRealRoots(t,e,n),o.length===0?[0]:o[1]<=0?[o[0],o[1],0]:o[0]>=0?[0,o[0],o[1]]:[o[0],0,o[1]]}return E7(t,e,n,i)};var BG=C7;var I7={};I7.computeDiscriminant=function(t,e,n,i,o){let a=t*t,s=a*t,l=e*e,r=l*e,d=n*n,m=d*n,h=i*i,Z=h*i,b=o*o,u=b*o;return l*d*h-4*r*Z-4*t*m*h+18*t*e*n*Z-27*a*h*h+256*s*u+o*(18*r*n*i-4*l*m+16*t*d*d-80*t*e*d*i-6*t*l*h+144*a*n*h)+b*(144*t*l*n-27*l*l-128*a*d-192*a*e*i)};function eZ(t,e,n,i){let o=t*t,a=e-3*o/8,s=n-e*t/2+o*t/8,l=i-n*t/4+e*o/16-3*o*o/256,r=BG.computeRealRoots(1,2*a,a*a-4*l,-s*s);if(r.length>0){let d=-t/4,m=r[r.length-1];if(Math.abs(m)=0&&b>=0){let F=Math.sqrt(Z),U=Math.sqrt(b);return[d-U,d-F,d+F,d+U]}else{if(Z>=0&&b<0)return u=Math.sqrt(Z),[d-u,d+u];if(Z<0&&b>=0)return u=Math.sqrt(b),[d-u,d+u]}}return[]}else if(m>0){let h=Math.sqrt(m),Z=(a+m-s/h)/2,b=(a+m+s/h)/2,u=Cc.computeRealRoots(1,h,Z),F=Cc.computeRealRoots(1,-h,b);return u.length!==0?(u[0]+=d,u[1]+=d,F.length!==0?(F[0]+=d,F[1]+=d,u[1]<=F[0]?[u[0],u[1],F[0],F[1]]:F[1]<=u[0]?[F[0],F[1],u[0],u[1]]:u[0]>=F[0]&&u[1]<=F[1]?[F[0],u[0],u[1],F[1]]:F[0]>=u[0]&&F[1]<=u[1]?[u[0],F[0],F[1],u[1]]:u[0]>F[0]&&u[0]0){let h=m[0],Z=e-h,b=Z*Z,u=t/2,F=Z/2,U=b-4*i,G=b+4*Math.abs(i),A=s-4*h,T=s+4*Math.abs(h),g,C;if(h<0||U*T=V[0]&&M[1]<=V[1]?[V[0],M[0],M[1],V[1]]:V[0]>=M[0]&&V[1]<=M[1]?[M[0],V[0],V[1],M[1]]:M[0]>V[0]&&M[0]m)||(Z=p.cross(h,l,aut),u=p.dot(s,Z),u<0||b+u>m))return;F=p.dot(r,Z)/m}else{if(Math.abs(m)1||(Z=p.cross(h,l,aut),u=p.dot(s,Z)*U,u<0||b+u>1))return;F=p.dot(r,Z)*U}return F};os.rayTriangle=function(t,e,n,i,o,a){let s=os.rayTriangleParametric(t,e,n,i,o);if(!(!c(s)||s<0))return c(a)||(a=new p),p.multiplyByScalar(t.direction,s,a),p.add(t.origin,a,a)};var vwt=new di;os.lineSegmentTriangle=function(t,e,n,i,o,a,s){let l=vwt;p.clone(t,l.origin),p.subtract(e,t,l.direction),p.normalize(l.direction,l.direction);let r=os.rayTriangleParametric(l,n,i,o,a);if(!(!c(r)||r<0||r>p.distance(t,e)))return c(s)||(s=new p),p.multiplyByScalar(l.direction,r,s),p.add(l.origin,s,s)};function Kwt(t,e,n,i){let o=e*e-4*t*n;if(o<0)return;if(o>0){let s=1/(2*t),l=Math.sqrt(o),r=(-e+l)*s,d=(-e-l)*s;return rs))return i.start=Math.max(i.start,0),i.stop=Math.min(i.stop,s),i};var qwt=new p,$wt=new p;os.rayEllipsoid=function(t,e){let n=e.oneOverRadii,i=p.multiplyComponents(n,t.origin,qwt),o=p.multiplyComponents(n,t.direction,$wt),a=p.magnitudeSquared(i),s=p.dot(i,o),l,r,d,m,h;if(a>1){if(s>=0)return;let Z=s*s;if(l=a-1,r=p.magnitudeSquared(o),d=r*l,Zd){m=s*s-d,h=-s+Math.sqrt(m);let u=h/r,F=l/h;return u0?b.push(new p(i,o*J,o*-E)):E!==0?(b.push(new p(i,o*J,o*-E)),b.push(new p(i,o*J,o*E)),++Q):b.push(new p(i,o*J,o*E))}return b};var N7=new p,sut=new p,lut=new p,HH=new p,tPt=new p,ePt=new ot,nPt=new ot,iPt=new ot,oPt=new ot,aPt=new ot,rut=new ot,dut=new ot,cut=new p,sPt=new p,lPt=new gt;os.grazingAltitudeLocation=function(t,e){let n=t.origin,i=t.direction;if(!p.equals(n,p.ZERO)){let y=e.geodeticSurfaceNormal(n,N7);if(p.dot(i,y)>=0)return n}let o=c(this.rayEllipsoid(t,e)),a=e.transformPositionToScaledSpace(i,N7),s=p.normalize(a,a),l=p.mostOrthogonalAxis(a,HH),r=p.normalize(p.cross(l,s,sut),sut),d=p.normalize(p.cross(s,r,lut),lut),m=ePt;m[0]=s.x,m[1]=s.y,m[2]=s.z,m[3]=r.x,m[4]=r.y,m[5]=r.z,m[6]=d.x,m[7]=d.y,m[8]=d.z;let h=ot.transpose(m,nPt),Z=ot.fromScale(e.radii,iPt),b=ot.fromScale(e.oneOverRadii,oPt),u=aPt;u[0]=0,u[1]=-i.z,u[2]=i.y,u[3]=i.z,u[4]=0,u[5]=-i.x,u[6]=-i.y,u[7]=i.x,u[8]=0;let F=ot.multiply(ot.multiply(h,b,rut),u,rut),U=ot.multiply(ot.multiply(F,Z,dut),m,dut),G=ot.multiplyByVector(F,n,tPt),A=os.quadraticVectorExpression(U,p.negate(G,N7),0,0,1),T,g,C=A.length;if(C>0){let y=p.clone(p.ZERO,sPt),Y=Number.NEGATIVE_INFINITY;for(let J=0;JY&&(Y=V,y=p.clone(T,y))}let Q=e.cartesianToCartographic(y,lPt);return Y=k.clamp(Y,0,1),g=p.magnitude(p.subtract(y,n,HH))*Math.sqrt(1-Y*Y),g=o?-g:g,Q.height=g,e.cartographicToCartesian(Q,new p)}};var rPt=new p;os.lineSegmentPlane=function(t,e,n,i){c(i)||(i=new p);let o=p.subtract(e,t,rPt),a=n.normal,s=p.dot(a,o);if(Math.abs(s)1))return p.multiplyByScalar(o,r,i),p.add(t,i,i),i};os.trianglePlaneIntersection=function(t,e,n,i){let o=i.normal,a=i.distance,s=p.dot(o,t)+a<0,l=p.dot(o,e)+a<0,r=p.dot(o,n)+a<0,d=0;d+=s?1:0,d+=l?1:0,d+=r?1:0;let m,h;if((d===1||d===2)&&(m=new p,h=new p),d===1){if(s)return os.lineSegmentPlane(t,e,i,m),os.lineSegmentPlane(t,n,i,h),{positions:[t,e,n,m,h],indices:[0,3,4,1,2,4,1,4,3]};if(l)return os.lineSegmentPlane(e,n,i,m),os.lineSegmentPlane(e,t,i,h),{positions:[t,e,n,m,h],indices:[1,3,4,2,0,4,2,4,3]};if(r)return os.lineSegmentPlane(n,t,i,m),os.lineSegmentPlane(n,e,i,h),{positions:[t,e,n,m,h],indices:[2,3,4,0,1,4,0,4,3]}}else if(d===2)if(s)if(l){if(!r)return os.lineSegmentPlane(t,n,i,m),os.lineSegmentPlane(e,n,i,h),{positions:[t,e,n,m,h],indices:[0,1,4,0,4,3,2,3,4]}}else return os.lineSegmentPlane(n,e,i,m),os.lineSegmentPlane(t,e,i,h),{positions:[t,e,n,m,h],indices:[2,0,4,2,4,3,1,3,4]};else return os.lineSegmentPlane(e,t,i,m),os.lineSegmentPlane(n,t,i,h),{positions:[t,e,n,m,h],indices:[1,2,4,1,4,3,0,3,4]}};var no=os;var y7=new Rt;function OV(t,e){e=f(e,mt.WGS84),t=e.scaleToGeodeticSurface(t);let n=Pe.eastNorthUpToFixedFrame(t,e);this._ellipsoid=e,this._origin=t,this._xAxis=p.fromCartesian4(L.getColumn(n,0,y7)),this._yAxis=p.fromCartesian4(L.getColumn(n,1,y7));let i=p.fromCartesian4(L.getColumn(n,2,y7));this._plane=Kn.fromPointNormal(t,i)}Object.defineProperties(OV.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},origin:{get:function(){return this._origin}},plane:{get:function(){return this._plane}},xAxis:{get:function(){return this._xAxis}},yAxis:{get:function(){return this._yAxis}},zAxis:{get:function(){return this._plane.normal}}});var dPt=new Ff;OV.fromPoints=function(t,e){let n=Ff.fromPoints(t,dPt);return new OV(n.center,e)};var put=new di,wH=new p;OV.prototype.projectPointOntoPlane=function(t,e){let n=put;n.origin=t,p.normalize(t,n.direction);let i=no.rayPlane(n,this._plane,wH);if(c(i)||(p.negate(n.direction,n.direction),i=no.rayPlane(n,this._plane,wH)),c(i)){let o=p.subtract(i,this._origin,i),a=p.dot(this._xAxis,o),s=p.dot(this._yAxis,o);return c(e)?(e.x=a,e.y=s,e):new K(a,s)}};OV.prototype.projectPointsOntoPlane=function(t,e){c(e)||(e=[]);let n=0,i=t.length;for(let o=0;o0?0:Y.latitude,E=gt.fromRadians(M,t.north,n,FPt),I=gt.fromRadians(t.west,t.north,n,UPt),B=gt.fromRadians(t.west,V,n,GPt),X=gt.fromRadians(t.west,t.south,n,APt),_=gt.fromRadians(M,t.south,n,TPt),P=i.cartographicToCartesian(E,SPt),w=i.cartographicToCartesian(I,Vut),z=i.cartographicToCartesian(B,gPt),H=i.cartographicToCartesian(X,but),nt=i.cartographicToCartesian(_,EPt),$=J.projectPointToNearestOnPlane(P,CPt),dt=J.projectPointToNearestOnPlane(w,IPt),q=J.projectPointToNearestOnPlane(z,NPt),at=J.projectPointToNearestOnPlane(H,yPt),st=J.projectPointToNearestOnPlane(nt,BPt);return a=Math.min(dt.x,q.x,at.x),s=-a,r=Math.max(dt.y,$.y),l=Math.min(at.y,st.y),I.height=X.height=e,w=i.cartographicToCartesian(I,Vut),H=i.cartographicToCartesian(X,but),d=Math.min(Kn.getPointDistance(h,w),Kn.getPointDistance(h,H)),m=n,uut(J.origin,J.xAxis,J.yAxis,J.zAxis,a,s,l,r,d,m,o)}let Z=t.south>0,b=t.north<0,u=Z?t.south:b?t.north:0,F=Gt.center(t,Zut).longitude,U=p.fromRadians(F,u,n,i,QPt);U.z=0;let A=Math.abs(U.x)=r?yn.INSIDE:yn.INTERSECTING};var fut=new p,Fut=new p,Uut=new p,DPt=new p,Rut=new p,OPt=new p;Ho.distanceSquaredTo=function(t,e){let n=p.subtract(e,t.center,Wut),i=t.halfAxes,o=ot.getColumn(i,0,fut),a=ot.getColumn(i,1,Fut),s=ot.getColumn(i,2,Uut),l=p.magnitude(o),r=p.magnitude(a),d=p.magnitude(s),m=!0,h=!0,Z=!0;l>0?p.divideByScalar(o,l,o):m=!1,r>0?p.divideByScalar(a,r,a):h=!1,d>0?p.divideByScalar(s,d,s):Z=!1;let b=!m+!h+!Z,u,F,U;if(b===1){let g=o;u=a,F=s,h?Z||(g=s,F=o):(g=a,u=o),U=p.cross(u,F,Rut),g===o?o=U:g===a?a=U:g===s&&(s=U)}else if(b===2){u=o,h?u=a:Z&&(u=s);let g=p.UNIT_Y;g.equalsEpsilon(u,k.EPSILON3)&&(g=p.UNIT_X),F=p.cross(u,g,DPt),p.normalize(F,F),U=p.cross(u,F,Rut),p.normalize(U,U),u===o?(a=F,s=U):u===a?(s=F,o=U):u===s&&(o=F,a=U)}else b===3&&(o=p.UNIT_X,a=p.UNIT_Y,s=p.UNIT_Z);let G=OPt;G.x=p.dot(n,o),G.y=p.dot(n,a),G.z=p.dot(n,s);let A=0,T;return G.x<-l?(T=G.x+l,A+=T*T):G.x>l&&(T=G.x-l,A+=T*T),G.y<-r?(T=G.y+r,A+=T*T):G.y>r&&(T=G.y-r,A+=T*T),G.z<-d?(T=G.z+d,A+=T*T):G.z>d&&(T=G.z-d,A+=T*T),A};var HPt=new p,wPt=new p;Ho.computePlaneDistances=function(t,e,n,i){c(i)||(i=new hd);let o=Number.POSITIVE_INFINITY,a=Number.NEGATIVE_INFINITY,s=t.center,l=t.halfAxes,r=ot.getColumn(l,0,fut),d=ot.getColumn(l,1,Fut),m=ot.getColumn(l,2,Uut),h=p.add(r,d,HPt);p.add(h,m,h),p.add(h,s,h);let Z=p.subtract(h,e,wPt),b=p.dot(n,Z);return o=Math.min(b,o),a=Math.max(b,a),p.add(s,r,h),p.add(h,d,h),p.subtract(h,m,h),p.subtract(h,e,Z),b=p.dot(n,Z),o=Math.min(b,o),a=Math.max(b,a),p.add(s,r,h),p.subtract(h,d,h),p.add(h,m,h),p.subtract(h,e,Z),b=p.dot(n,Z),o=Math.min(b,o),a=Math.max(b,a),p.add(s,r,h),p.subtract(h,d,h),p.subtract(h,m,h),p.subtract(h,e,Z),b=p.dot(n,Z),o=Math.min(b,o),a=Math.max(b,a),p.subtract(s,r,h),p.add(h,d,h),p.add(h,m,h),p.subtract(h,e,Z),b=p.dot(n,Z),o=Math.min(b,o),a=Math.max(b,a),p.subtract(s,r,h),p.add(h,d,h),p.subtract(h,m,h),p.subtract(h,e,Z),b=p.dot(n,Z),o=Math.min(b,o),a=Math.max(b,a),p.subtract(s,r,h),p.subtract(h,d,h),p.add(h,m,h),p.subtract(h,e,Z),b=p.dot(n,Z),o=Math.min(b,o),a=Math.max(b,a),p.subtract(s,r,h),p.subtract(h,d,h),p.subtract(h,m,h),p.subtract(h,e,Z),b=p.dot(n,Z),o=Math.min(b,o),a=Math.max(b,a),i.start=o,i.stop=a,i};var PPt=new p,vPt=new p,KPt=new p;Ho.computeCorners=function(t,e){c(e)||(e=[new p,new p,new p,new p,new p,new p,new p,new p]);let n=t.center,i=t.halfAxes,o=ot.getColumn(i,0,PPt),a=ot.getColumn(i,1,vPt),s=ot.getColumn(i,2,KPt);return p.clone(n,e[0]),p.subtract(e[0],o,e[0]),p.subtract(e[0],a,e[0]),p.subtract(e[0],s,e[0]),p.clone(n,e[1]),p.subtract(e[1],o,e[1]),p.subtract(e[1],a,e[1]),p.add(e[1],s,e[1]),p.clone(n,e[2]),p.subtract(e[2],o,e[2]),p.add(e[2],a,e[2]),p.subtract(e[2],s,e[2]),p.clone(n,e[3]),p.subtract(e[3],o,e[3]),p.add(e[3],a,e[3]),p.add(e[3],s,e[3]),p.clone(n,e[4]),p.add(e[4],o,e[4]),p.subtract(e[4],a,e[4]),p.subtract(e[4],s,e[4]),p.clone(n,e[5]),p.add(e[5],o,e[5]),p.subtract(e[5],a,e[5]),p.add(e[5],s,e[5]),p.clone(n,e[6]),p.add(e[6],o,e[6]),p.add(e[6],a,e[6]),p.subtract(e[6],s,e[6]),p.clone(n,e[7]),p.add(e[7],o,e[7]),p.add(e[7],a,e[7]),p.add(e[7],s,e[7]),e};var zPt=new ot;Ho.computeTransformation=function(t,e){c(e)||(e=new L);let n=t.center,i=ot.multiplyByUniformScale(t.halfAxes,2,zPt);return L.fromRotationTranslation(i,n,e)};var jPt=new Ft;Ho.isOccluded=function(t,e){let n=Ft.fromOrientedBoundingBox(t,jPt);return!e.isBoundingSphereVisible(n)};Ho.prototype.intersectPlane=function(t){return Ho.intersectPlane(this,t)};Ho.prototype.distanceSquaredTo=function(t){return Ho.distanceSquaredTo(this,t)};Ho.prototype.computePlaneDistances=function(t,e,n){return Ho.computePlaneDistances(this,t,e,n)};Ho.prototype.computeCorners=function(t){return Ho.computeCorners(this,t)};Ho.prototype.computeTransformation=function(t){return Ho.computeTransformation(this,t)};Ho.prototype.isOccluded=function(t){return Ho.isOccluded(this,t)};Ho.equals=function(t,e){return t===e||c(t)&&c(e)&&p.equals(t.center,e.center)&&ot.equals(t.halfAxes,e.halfAxes)};Ho.prototype.clone=function(t){return Ho.clone(this,t)};Ho.prototype.equals=function(t){return Ho.equals(this,t)};var ci=Ho;var Zpn=R(W(),1);var PH={};PH.getHeight=function(t,e,n){return(t-n)*e+n};var qPt=new gt;PH.getPosition=function(t,e,n,i,o){let a=e.cartesianToCartographic(t,qPt);if(!c(a))return p.clone(t,o);let s=PH.getHeight(a.height,n,i);return p.fromRadians(a.longitude,a.latitude,s,e,o)};var Ps=PH;var obn=R(W(),1);var bpn=R(W(),1),P2=`in vec3 position3DHigh; +`;function Ib(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.translucent,!0),n=f(t.closed,!1),i=f(t.flat,!1),o=i?_k:Mk,a=i?yG:Lk,s=i?Ib.FLAT_VERTEX_FORMAT:Ib.VERTEX_FORMAT;this.material=void 0,this.translucent=e,this._vertexShaderSource=f(t.vertexShaderSource,o),this._fragmentShaderSource=f(t.fragmentShaderSource,a),this._renderState=Va.getDefaultRenderState(e,n,t.renderState),this._closed=n,this._vertexFormat=s,this._flat=i,this._faceForward=f(t.faceForward,!n)}Object.defineProperties(Ib.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},vertexFormat:{get:function(){return this._vertexFormat}},flat:{get:function(){return this._flat}},faceForward:{get:function(){return this._faceForward}}});Ib.VERTEX_FORMAT=ee.POSITION_AND_NORMAL;Ib.FLAT_VERTEX_FORMAT=ee.POSITION_ONLY;Ib.prototype.getFragmentShaderSource=Va.prototype.getFragmentShaderSource;Ib.prototype.isTranslucent=Va.prototype.isTranslucent;Ib.prototype.getRenderState=Va.prototype.getRenderState;var jn=Ib;var Imn=b(W(),1);function pE(t){this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this.color=t}Object.defineProperties(pE.prototype,{isConstant:{get:function(){return et.isConstant(this._color)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color")});pE.prototype.getType=function(t){return"Color"};pE.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,v.WHITE,e.color),e};pE.prototype.equals=function(t){return this===t||t instanceof pE&&et.equals(this._color,t._color)};var Cn=pE;var _Rn=b(W(),1);var URn=b(W(),1);var $mn=b(W(),1);var Jmn=b(W(),1);function ff(t){t=f(t,f.EMPTY_OBJECT),this._ellipsoid=f(t.ellipsoid,mt.WGS84),this._rectangle=f(t.rectangle,Gt.MAX_VALUE),this._projection=new yo(this._ellipsoid),this._numberOfLevelZeroTilesX=f(t.numberOfLevelZeroTilesX,2),this._numberOfLevelZeroTilesY=f(t.numberOfLevelZeroTilesY,1)}Object.defineProperties(ff.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},rectangle:{get:function(){return this._rectangle}},projection:{get:function(){return this._projection}}});ff.prototype.getNumberOfXTilesAtLevel=function(t){return this._numberOfLevelZeroTilesX<=o&&(d=o-1);let m=(i.north-t.latitude)/l|0;return m>=a&&(m=a-1),c(n)?(n.x=d,n.y=m,n):new K(d,m)};var Qo=ff;var qpt=new p,$pt=new p,tVt=new gt,T7=new p,Owt=new p,eVt=new Ft,Hwt=new Qo,Dk=[new gt,new gt,new gt,new gt],Ok=new K,fl={};fl.initialize=function(){let t=fl._initPromise;return c(t)||(t=te.fetchJson(Dn("Assets/approximateTerrainHeights.json")).then(function(e){fl._terrainHeights=e}),fl._initPromise=t),t};fl.getMinimumMaximumHeights=function(t,e){e=f(e,mt.WGS84);let n=nVt(t),i=fl._defaultMinTerrainHeight,o=fl._defaultMaxTerrainHeight;if(c(n)){let a=`${n.level}-${n.x}-${n.y}`,s=fl._terrainHeights[a];c(s)&&(i=s[0],o=s[1]),e.cartographicToCartesian(Gt.northeast(t,tVt),qpt),e.cartographicToCartesian(Gt.southwest(t,tVt),$pt),p.midpoint($pt,qpt,T7);let l=e.scaleToGeodeticSurface(T7,Owt);if(c(l)){let r=p.distance(T7,l);i=Math.min(i,-r)}else i=fl._defaultMinTerrainHeight}return i=Math.max(fl._defaultMinTerrainHeight,i),{minimumTerrainHeight:i,maximumTerrainHeight:o}};fl.getBoundingSphere=function(t,e){e=f(e,mt.WGS84);let n=nVt(t),i=fl._defaultMaxTerrainHeight;if(c(n)){let a=`${n.level}-${n.x}-${n.y}`,s=fl._terrainHeights[a];c(s)&&(i=s[1])}let o=Ft.fromRectangle3D(t,e,0);return Ft.fromRectangle3D(t,e,i,eVt),Ft.union(o,eVt,o)};function nVt(t){gt.fromRadians(t.east,t.north,0,Dk[0]),gt.fromRadians(t.west,t.north,0,Dk[1]),gt.fromRadians(t.east,t.south,0,Dk[2]),gt.fromRadians(t.west,t.south,0,Dk[3]);let e=0,n=0,i=0,o=0,a=fl._terrainHeightsMaxLevel,s;for(s=0;s<=a;++s){let l=!1;for(let r=0;r<4;++r){let d=Dk[r];if(Hwt.positionToTileXY(d,s,Ok),r===0)i=Ok.x,o=Ok.y;else if(i!==Ok.x||o!==Ok.y){l=!0;break}}if(l)break;e=i,n=o}if(s!==0)return{x:e,y:n,level:s>a?a:s-1}}fl._terrainHeightsMaxLevel=6;fl._defaultMaxTerrainHeight=9e3;fl._defaultMinTerrainHeight=-1e5;fl._terrainHeights=gH?gH:void 0;fl._initPromise=gH?new Promise(function(t){t()}):void 0;Object.defineProperties(fl,{initialized:{get:function(){return c(fl._terrainHeights)}}});var Vo=fl;var cpn=b(W(),1);var Phn=b(W(),1);var ahn=b(W(),1);function Ec(t,e,n){this.minimum=p.clone(f(t,p.ZERO)),this.maximum=p.clone(f(e,p.ZERO)),c(n)?n=p.clone(n):n=p.midpoint(this.minimum,this.maximum,new p),this.center=n}Ec.fromCorners=function(t,e,n){return c(n)||(n=new Ec),n.minimum=p.clone(t,n.minimum),n.maximum=p.clone(e,n.maximum),n.center=p.midpoint(t,e,n.center),n};Ec.fromPoints=function(t,e){if(c(e)||(e=new Ec),!c(t)||t.length===0)return e.minimum=p.clone(p.ZERO,e.minimum),e.maximum=p.clone(p.ZERO,e.maximum),e.center=p.clone(p.ZERO,e.center),e;let n=t[0].x,i=t[0].y,o=t[0].z,a=t[0].x,s=t[0].y,l=t[0].z,r=t.length;for(let h=1;h0?yn.INSIDE:a+o<0?yn.OUTSIDE:yn.INTERSECTING};Ec.prototype.clone=function(t){return Ec.clone(this,t)};Ec.prototype.intersectPlane=function(t){return Ec.intersectPlane(this,t)};Ec.prototype.equals=function(t){return Ec.equals(this,t)};var Ff=Ec;var Bhn=b(W(),1);var rhn=b(W(),1);var g7={};g7.computeDiscriminant=function(t,e,n){return e*e-4*t*n};function iVt(t,e,n){let i=t+e;return k.sign(t)!==k.sign(e)&&Math.abs(i/Math.max(Math.abs(t),Math.abs(e)))d&&d/r0?[l/t,n/l]:[n/l,l/t]};var Cc=g7;var Zhn=b(W(),1);var mhn=b(W(),1);var C7={};C7.computeDiscriminant=function(t,e,n,i){let o=t*t,a=e*e,s=n*n,l=i*i;return 18*t*e*n*i+a*s-27*o*l-4*(t*s*n+a*e*i)};function E7(t,e,n,i){let o=t,a=e/3,s=n/3,l=i,r=o*s,d=a*l,m=a*a,h=s*s,u=o*s-m,R=o*l-a*s,V=a*l-h,F=4*u*V-R*R,U,G;if(F<0){let nt,$,dt;m*d>=r*h?(nt=o,$=u,dt=-2*a*u+o*R):(nt=l,$=V,dt=-l*R+2*s*V);let at=-(dt<0?-1:1)*Math.abs(nt)*Math.sqrt(-F);G=-dt+at;let st=G/2,Et=st<0?-Math.pow(-st,1/3):Math.pow(st,1/3),Qt=G===at?-Et:-$/Et;return U=$<=0?Et+Qt:-dt/(Et*Et+Qt*Qt+$),m*d>=r*h?[(U-a)/o]:[-l/(U+s)]}let A=u,S=-2*a*u+o*R,g=V,C=-l*R+2*s*V,y=Math.sqrt(F),Y=Math.sqrt(3)/2,Q=Math.abs(Math.atan2(o*y,-S)/3);U=2*Math.sqrt(-A);let J=Math.cos(Q);G=U*J;let M=U*(-J/2-Y*Math.sin(Q)),Z=G+M>2*a?G-a:M-a,E=o,I=Z/E;Q=Math.abs(Math.atan2(l*y,-C)/3),U=2*Math.sqrt(-g),J=Math.cos(Q),G=U*J,M=U*(-J/2-Y*Math.sin(Q));let B=-l,X=G+M<2*s?G+s:M+s,_=B/X,P=E*X,w=-Z*X-E*B,z=Z*B,H=(s*w-a*z)/(-a*w+s*P);return I<=H?I<=_?H<=_?[I,H,_]:[I,_,H]:[_,I,H]:I<=_?[H,I,_]:H<=_?[H,_,I]:[_,H,I]}C7.computeRealRoots=function(t,e,n,i){let o,a;if(t===0)return Cc.computeRealRoots(e,n,i);if(e===0){if(n===0){if(i===0)return[0,0,0];a=-i/t;let s=a<0?-Math.pow(-a,1/3):Math.pow(a,1/3);return[s,s,s]}else if(i===0)return o=Cc.computeRealRoots(t,0,n),o.Length===0?[0]:[o[0],0,o[1]];return E7(t,0,n,i)}else{if(n===0)return i===0?(a=-e/t,a<0?[a,0,0]:[0,0,a]):E7(t,e,0,i);if(i===0)return o=Cc.computeRealRoots(t,e,n),o.length===0?[0]:o[1]<=0?[o[0],o[1],0]:o[0]>=0?[0,o[0],o[1]]:[o[0],0,o[1]]}return E7(t,e,n,i)};var BG=C7;var I7={};I7.computeDiscriminant=function(t,e,n,i,o){let a=t*t,s=a*t,l=e*e,r=l*e,d=n*n,m=d*n,h=i*i,u=h*i,R=o*o,V=R*o;return l*d*h-4*r*u-4*t*m*h+18*t*e*n*u-27*a*h*h+256*s*V+o*(18*r*n*i-4*l*m+16*t*d*d-80*t*e*d*i-6*t*l*h+144*a*n*h)+R*(144*t*l*n-27*l*l-128*a*d-192*a*e*i)};function eu(t,e,n,i){let o=t*t,a=e-3*o/8,s=n-e*t/2+o*t/8,l=i-n*t/4+e*o/16-3*o*o/256,r=BG.computeRealRoots(1,2*a,a*a-4*l,-s*s);if(r.length>0){let d=-t/4,m=r[r.length-1];if(Math.abs(m)=0&&R>=0){let F=Math.sqrt(u),U=Math.sqrt(R);return[d-U,d-F,d+F,d+U]}else{if(u>=0&&R<0)return V=Math.sqrt(u),[d-V,d+V];if(u<0&&R>=0)return V=Math.sqrt(R),[d-V,d+V]}}return[]}else if(m>0){let h=Math.sqrt(m),u=(a+m-s/h)/2,R=(a+m+s/h)/2,V=Cc.computeRealRoots(1,h,u),F=Cc.computeRealRoots(1,-h,R);return V.length!==0?(V[0]+=d,V[1]+=d,F.length!==0?(F[0]+=d,F[1]+=d,V[1]<=F[0]?[V[0],V[1],F[0],F[1]]:F[1]<=V[0]?[F[0],F[1],V[0],V[1]]:V[0]>=F[0]&&V[1]<=F[1]?[F[0],V[0],V[1],F[1]]:F[0]>=V[0]&&F[1]<=V[1]?[V[0],F[0],F[1],V[1]]:V[0]>F[0]&&V[0]0){let h=m[0],u=e-h,R=u*u,V=t/2,F=u/2,U=R-4*i,G=R+4*Math.abs(i),A=s-4*h,S=s+4*Math.abs(h),g,C;if(h<0||U*S=Z[0]&&M[1]<=Z[1]?[Z[0],M[0],M[1],Z[1]]:Z[0]>=M[0]&&Z[1]<=M[1]?[M[0],Z[0],Z[1],M[1]]:M[0]>Z[0]&&M[0]m)||(u=p.cross(h,l,aVt),V=p.dot(s,u),V<0||R+V>m))return;F=p.dot(r,u)/m}else{if(Math.abs(m)1||(u=p.cross(h,l,aVt),V=p.dot(s,u)*U,V<0||R+V>1))return;F=p.dot(r,u)*U}return F};os.rayTriangle=function(t,e,n,i,o,a){let s=os.rayTriangleParametric(t,e,n,i,o);if(!(!c(s)||s<0))return c(a)||(a=new p),p.multiplyByScalar(t.direction,s,a),p.add(t.origin,a,a)};var vwt=new di;os.lineSegmentTriangle=function(t,e,n,i,o,a,s){let l=vwt;p.clone(t,l.origin),p.subtract(e,t,l.direction),p.normalize(l.direction,l.direction);let r=os.rayTriangleParametric(l,n,i,o,a);if(!(!c(r)||r<0||r>p.distance(t,e)))return c(s)||(s=new p),p.multiplyByScalar(l.direction,r,s),p.add(l.origin,s,s)};function Kwt(t,e,n,i){let o=e*e-4*t*n;if(o<0)return;if(o>0){let s=1/(2*t),l=Math.sqrt(o),r=(-e+l)*s,d=(-e-l)*s;return rs))return i.start=Math.max(i.start,0),i.stop=Math.min(i.stop,s),i};var qwt=new p,$wt=new p;os.rayEllipsoid=function(t,e){let n=e.oneOverRadii,i=p.multiplyComponents(n,t.origin,qwt),o=p.multiplyComponents(n,t.direction,$wt),a=p.magnitudeSquared(i),s=p.dot(i,o),l,r,d,m,h;if(a>1){if(s>=0)return;let u=s*s;if(l=a-1,r=p.magnitudeSquared(o),d=r*l,ud){m=s*s-d,h=-s+Math.sqrt(m);let V=h/r,F=l/h;return V0?R.push(new p(i,o*J,o*-E)):E!==0?(R.push(new p(i,o*J,o*-E)),R.push(new p(i,o*J,o*E)),++Q):R.push(new p(i,o*J,o*E))}return R};var N7=new p,sVt=new p,lVt=new p,HH=new p,tPt=new p,ePt=new ot,nPt=new ot,iPt=new ot,oPt=new ot,aPt=new ot,rVt=new ot,dVt=new ot,cVt=new p,sPt=new p,lPt=new gt;os.grazingAltitudeLocation=function(t,e){let n=t.origin,i=t.direction;if(!p.equals(n,p.ZERO)){let y=e.geodeticSurfaceNormal(n,N7);if(p.dot(i,y)>=0)return n}let o=c(this.rayEllipsoid(t,e)),a=e.transformPositionToScaledSpace(i,N7),s=p.normalize(a,a),l=p.mostOrthogonalAxis(a,HH),r=p.normalize(p.cross(l,s,sVt),sVt),d=p.normalize(p.cross(s,r,lVt),lVt),m=ePt;m[0]=s.x,m[1]=s.y,m[2]=s.z,m[3]=r.x,m[4]=r.y,m[5]=r.z,m[6]=d.x,m[7]=d.y,m[8]=d.z;let h=ot.transpose(m,nPt),u=ot.fromScale(e.radii,iPt),R=ot.fromScale(e.oneOverRadii,oPt),V=aPt;V[0]=0,V[1]=-i.z,V[2]=i.y,V[3]=i.z,V[4]=0,V[5]=-i.x,V[6]=-i.y,V[7]=i.x,V[8]=0;let F=ot.multiply(ot.multiply(h,R,rVt),V,rVt),U=ot.multiply(ot.multiply(F,u,dVt),m,dVt),G=ot.multiplyByVector(F,n,tPt),A=os.quadraticVectorExpression(U,p.negate(G,N7),0,0,1),S,g,C=A.length;if(C>0){let y=p.clone(p.ZERO,sPt),Y=Number.NEGATIVE_INFINITY;for(let J=0;JY&&(Y=Z,y=p.clone(S,y))}let Q=e.cartesianToCartographic(y,lPt);return Y=k.clamp(Y,0,1),g=p.magnitude(p.subtract(y,n,HH))*Math.sqrt(1-Y*Y),g=o?-g:g,Q.height=g,e.cartographicToCartesian(Q,new p)}};var rPt=new p;os.lineSegmentPlane=function(t,e,n,i){c(i)||(i=new p);let o=p.subtract(e,t,rPt),a=n.normal,s=p.dot(a,o);if(Math.abs(s)1))return p.multiplyByScalar(o,r,i),p.add(t,i,i),i};os.trianglePlaneIntersection=function(t,e,n,i){let o=i.normal,a=i.distance,s=p.dot(o,t)+a<0,l=p.dot(o,e)+a<0,r=p.dot(o,n)+a<0,d=0;d+=s?1:0,d+=l?1:0,d+=r?1:0;let m,h;if((d===1||d===2)&&(m=new p,h=new p),d===1){if(s)return os.lineSegmentPlane(t,e,i,m),os.lineSegmentPlane(t,n,i,h),{positions:[t,e,n,m,h],indices:[0,3,4,1,2,4,1,4,3]};if(l)return os.lineSegmentPlane(e,n,i,m),os.lineSegmentPlane(e,t,i,h),{positions:[t,e,n,m,h],indices:[1,3,4,2,0,4,2,4,3]};if(r)return os.lineSegmentPlane(n,t,i,m),os.lineSegmentPlane(n,e,i,h),{positions:[t,e,n,m,h],indices:[2,3,4,0,1,4,0,4,3]}}else if(d===2)if(s)if(l){if(!r)return os.lineSegmentPlane(t,n,i,m),os.lineSegmentPlane(e,n,i,h),{positions:[t,e,n,m,h],indices:[0,1,4,0,4,3,2,3,4]}}else return os.lineSegmentPlane(n,e,i,m),os.lineSegmentPlane(t,e,i,h),{positions:[t,e,n,m,h],indices:[2,0,4,2,4,3,1,3,4]};else return os.lineSegmentPlane(e,t,i,m),os.lineSegmentPlane(n,t,i,h),{positions:[t,e,n,m,h],indices:[1,2,4,1,4,3,0,3,4]}};var no=os;var y7=new bt;function OZ(t,e){e=f(e,mt.WGS84),t=e.scaleToGeodeticSurface(t);let n=Pe.eastNorthUpToFixedFrame(t,e);this._ellipsoid=e,this._origin=t,this._xAxis=p.fromCartesian4(L.getColumn(n,0,y7)),this._yAxis=p.fromCartesian4(L.getColumn(n,1,y7));let i=p.fromCartesian4(L.getColumn(n,2,y7));this._plane=Kn.fromPointNormal(t,i)}Object.defineProperties(OZ.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},origin:{get:function(){return this._origin}},plane:{get:function(){return this._plane}},xAxis:{get:function(){return this._xAxis}},yAxis:{get:function(){return this._yAxis}},zAxis:{get:function(){return this._plane.normal}}});var dPt=new Ff;OZ.fromPoints=function(t,e){let n=Ff.fromPoints(t,dPt);return new OZ(n.center,e)};var pVt=new di,wH=new p;OZ.prototype.projectPointOntoPlane=function(t,e){let n=pVt;n.origin=t,p.normalize(t,n.direction);let i=no.rayPlane(n,this._plane,wH);if(c(i)||(p.negate(n.direction,n.direction),i=no.rayPlane(n,this._plane,wH)),c(i)){let o=p.subtract(i,this._origin,i),a=p.dot(this._xAxis,o),s=p.dot(this._yAxis,o);return c(e)?(e.x=a,e.y=s,e):new K(a,s)}};OZ.prototype.projectPointsOntoPlane=function(t,e){c(e)||(e=[]);let n=0,i=t.length;for(let o=0;o0?0:Y.latitude,E=gt.fromRadians(M,t.north,n,FPt),I=gt.fromRadians(t.west,t.north,n,UPt),B=gt.fromRadians(t.west,Z,n,GPt),X=gt.fromRadians(t.west,t.south,n,APt),_=gt.fromRadians(M,t.south,n,SPt),P=i.cartographicToCartesian(E,TPt),w=i.cartographicToCartesian(I,ZVt),z=i.cartographicToCartesian(B,gPt),H=i.cartographicToCartesian(X,RVt),nt=i.cartographicToCartesian(_,EPt),$=J.projectPointToNearestOnPlane(P,CPt),dt=J.projectPointToNearestOnPlane(w,IPt),q=J.projectPointToNearestOnPlane(z,NPt),at=J.projectPointToNearestOnPlane(H,yPt),st=J.projectPointToNearestOnPlane(nt,BPt);return a=Math.min(dt.x,q.x,at.x),s=-a,r=Math.max(dt.y,$.y),l=Math.min(at.y,st.y),I.height=X.height=e,w=i.cartographicToCartesian(I,ZVt),H=i.cartographicToCartesian(X,RVt),d=Math.min(Kn.getPointDistance(h,w),Kn.getPointDistance(h,H)),m=n,VVt(J.origin,J.xAxis,J.yAxis,J.zAxis,a,s,l,r,d,m,o)}let u=t.south>0,R=t.north<0,V=u?t.south:R?t.north:0,F=Gt.center(t,uVt).longitude,U=p.fromRadians(F,V,n,i,QPt);U.z=0;let A=Math.abs(U.x)=r?yn.INSIDE:yn.INTERSECTING};var fVt=new p,FVt=new p,UVt=new p,DPt=new p,bVt=new p,OPt=new p;Ho.distanceSquaredTo=function(t,e){let n=p.subtract(e,t.center,WVt),i=t.halfAxes,o=ot.getColumn(i,0,fVt),a=ot.getColumn(i,1,FVt),s=ot.getColumn(i,2,UVt),l=p.magnitude(o),r=p.magnitude(a),d=p.magnitude(s),m=!0,h=!0,u=!0;l>0?p.divideByScalar(o,l,o):m=!1,r>0?p.divideByScalar(a,r,a):h=!1,d>0?p.divideByScalar(s,d,s):u=!1;let R=!m+!h+!u,V,F,U;if(R===1){let g=o;V=a,F=s,h?u||(g=s,F=o):(g=a,V=o),U=p.cross(V,F,bVt),g===o?o=U:g===a?a=U:g===s&&(s=U)}else if(R===2){V=o,h?V=a:u&&(V=s);let g=p.UNIT_Y;g.equalsEpsilon(V,k.EPSILON3)&&(g=p.UNIT_X),F=p.cross(V,g,DPt),p.normalize(F,F),U=p.cross(V,F,bVt),p.normalize(U,U),V===o?(a=F,s=U):V===a?(s=F,o=U):V===s&&(o=F,a=U)}else R===3&&(o=p.UNIT_X,a=p.UNIT_Y,s=p.UNIT_Z);let G=OPt;G.x=p.dot(n,o),G.y=p.dot(n,a),G.z=p.dot(n,s);let A=0,S;return G.x<-l?(S=G.x+l,A+=S*S):G.x>l&&(S=G.x-l,A+=S*S),G.y<-r?(S=G.y+r,A+=S*S):G.y>r&&(S=G.y-r,A+=S*S),G.z<-d?(S=G.z+d,A+=S*S):G.z>d&&(S=G.z-d,A+=S*S),A};var HPt=new p,wPt=new p;Ho.computePlaneDistances=function(t,e,n,i){c(i)||(i=new hd);let o=Number.POSITIVE_INFINITY,a=Number.NEGATIVE_INFINITY,s=t.center,l=t.halfAxes,r=ot.getColumn(l,0,fVt),d=ot.getColumn(l,1,FVt),m=ot.getColumn(l,2,UVt),h=p.add(r,d,HPt);p.add(h,m,h),p.add(h,s,h);let u=p.subtract(h,e,wPt),R=p.dot(n,u);return o=Math.min(R,o),a=Math.max(R,a),p.add(s,r,h),p.add(h,d,h),p.subtract(h,m,h),p.subtract(h,e,u),R=p.dot(n,u),o=Math.min(R,o),a=Math.max(R,a),p.add(s,r,h),p.subtract(h,d,h),p.add(h,m,h),p.subtract(h,e,u),R=p.dot(n,u),o=Math.min(R,o),a=Math.max(R,a),p.add(s,r,h),p.subtract(h,d,h),p.subtract(h,m,h),p.subtract(h,e,u),R=p.dot(n,u),o=Math.min(R,o),a=Math.max(R,a),p.subtract(s,r,h),p.add(h,d,h),p.add(h,m,h),p.subtract(h,e,u),R=p.dot(n,u),o=Math.min(R,o),a=Math.max(R,a),p.subtract(s,r,h),p.add(h,d,h),p.subtract(h,m,h),p.subtract(h,e,u),R=p.dot(n,u),o=Math.min(R,o),a=Math.max(R,a),p.subtract(s,r,h),p.subtract(h,d,h),p.add(h,m,h),p.subtract(h,e,u),R=p.dot(n,u),o=Math.min(R,o),a=Math.max(R,a),p.subtract(s,r,h),p.subtract(h,d,h),p.subtract(h,m,h),p.subtract(h,e,u),R=p.dot(n,u),o=Math.min(R,o),a=Math.max(R,a),i.start=o,i.stop=a,i};var PPt=new p,vPt=new p,KPt=new p;Ho.computeCorners=function(t,e){c(e)||(e=[new p,new p,new p,new p,new p,new p,new p,new p]);let n=t.center,i=t.halfAxes,o=ot.getColumn(i,0,PPt),a=ot.getColumn(i,1,vPt),s=ot.getColumn(i,2,KPt);return p.clone(n,e[0]),p.subtract(e[0],o,e[0]),p.subtract(e[0],a,e[0]),p.subtract(e[0],s,e[0]),p.clone(n,e[1]),p.subtract(e[1],o,e[1]),p.subtract(e[1],a,e[1]),p.add(e[1],s,e[1]),p.clone(n,e[2]),p.subtract(e[2],o,e[2]),p.add(e[2],a,e[2]),p.subtract(e[2],s,e[2]),p.clone(n,e[3]),p.subtract(e[3],o,e[3]),p.add(e[3],a,e[3]),p.add(e[3],s,e[3]),p.clone(n,e[4]),p.add(e[4],o,e[4]),p.subtract(e[4],a,e[4]),p.subtract(e[4],s,e[4]),p.clone(n,e[5]),p.add(e[5],o,e[5]),p.subtract(e[5],a,e[5]),p.add(e[5],s,e[5]),p.clone(n,e[6]),p.add(e[6],o,e[6]),p.add(e[6],a,e[6]),p.subtract(e[6],s,e[6]),p.clone(n,e[7]),p.add(e[7],o,e[7]),p.add(e[7],a,e[7]),p.add(e[7],s,e[7]),e};var zPt=new ot;Ho.computeTransformation=function(t,e){c(e)||(e=new L);let n=t.center,i=ot.multiplyByUniformScale(t.halfAxes,2,zPt);return L.fromRotationTranslation(i,n,e)};var jPt=new Ft;Ho.isOccluded=function(t,e){let n=Ft.fromOrientedBoundingBox(t,jPt);return!e.isBoundingSphereVisible(n)};Ho.prototype.intersectPlane=function(t){return Ho.intersectPlane(this,t)};Ho.prototype.distanceSquaredTo=function(t){return Ho.distanceSquaredTo(this,t)};Ho.prototype.computePlaneDistances=function(t,e,n){return Ho.computePlaneDistances(this,t,e,n)};Ho.prototype.computeCorners=function(t){return Ho.computeCorners(this,t)};Ho.prototype.computeTransformation=function(t){return Ho.computeTransformation(this,t)};Ho.prototype.isOccluded=function(t){return Ho.isOccluded(this,t)};Ho.equals=function(t,e){return t===e||c(t)&&c(e)&&p.equals(t.center,e.center)&&ot.equals(t.halfAxes,e.halfAxes)};Ho.prototype.clone=function(t){return Ho.clone(this,t)};Ho.prototype.equals=function(t){return Ho.equals(this,t)};var ci=Ho;var upn=b(W(),1);var PH={};PH.getHeight=function(t,e,n){return(t-n)*e+n};var qPt=new gt;PH.getPosition=function(t,e,n,i,o){let a=e.cartesianToCartographic(t,qPt);if(!c(a))return p.clone(t,o);let s=PH.getHeight(a.height,n,i);return p.fromRadians(a.longitude,a.latitude,s,e,o)};var Ps=PH;var oRn=b(W(),1);var Rpn=b(W(),1),Pk=`in vec3 position3DHigh; in vec3 position3DLow; in float batchId; @@ -4830,7 +4830,7 @@ void main() gl_Position = czm_depthClamp(czm_modelViewProjectionRelativeToEye * position); } -`;var Wpn=R(W(),1),Uf=`#ifdef VECTOR_TILE +`;var Wpn=b(W(),1),Uf=`#ifdef VECTOR_TILE uniform vec4 u_highlightColor; #endif @@ -4843,7 +4843,7 @@ void main(void) #endif czm_writeDepthClamp(); } -`;var Fpn=R(W(),1),Gut={TERRAIN:0,CESIUM_3D_TILE:1,BOTH:2};Gut.NUMBER_OF_CLASSIFICATION_TYPES=3;var Ji=Object.freeze(Gut);var Apn=R(W(),1);var $Pt={NEVER:pt.NEVER,LESS:pt.LESS,EQUAL:pt.EQUAL,LESS_OR_EQUAL:pt.LEQUAL,GREATER:pt.GREATER,NOT_EQUAL:pt.NOTEQUAL,GREATER_OR_EQUAL:pt.GEQUAL,ALWAYS:pt.ALWAYS},_d=Object.freeze($Pt);var tVn=R(W(),1);var Spn=R(W(),1);function tvt(t,e){let n=[],i=t.length,o=0;for(;o>1^-(t&1)}La.zigZagDeltaDecode=function(t,e,n){let i=t.length,o=0,a=0,s=0;for(let l=0;l>11,m=r>>5&o,h=r&i,Z=3*l;e[Z]=d*a,e[Z+1]=m*s,e[Z+2]=h*a}return e};var Ni=La;var run=R(W(),1);var Cut=new p,Iut=new p,Nut=new p;function uvt(t,e,n,i,o){c(o)||(o=new p);let a,s,l,r,d,m,h,Z;if(c(e.z)){if(p.equalsEpsilon(t,e,k.EPSILON14))return p.clone(p.UNIT_X,o);if(p.equalsEpsilon(t,n,k.EPSILON14))return p.clone(p.UNIT_Y,o);if(p.equalsEpsilon(t,i,k.EPSILON14))return p.clone(p.UNIT_Z,o);a=p.subtract(n,e,Cut),s=p.subtract(i,e,Iut),l=p.subtract(t,e,Nut),r=p.dot(a,a),d=p.dot(a,s),m=p.dot(a,l),h=p.dot(s,s),Z=p.dot(s,l)}else{if(K.equalsEpsilon(t,e,k.EPSILON14))return p.clone(p.UNIT_X,o);if(K.equalsEpsilon(t,n,k.EPSILON14))return p.clone(p.UNIT_Y,o);if(K.equalsEpsilon(t,i,k.EPSILON14))return p.clone(p.UNIT_Z,o);a=K.subtract(n,e,Cut),s=K.subtract(i,e,Iut),l=K.subtract(t,e,Nut),r=K.dot(a,a),d=K.dot(a,s),m=K.dot(a,l),h=K.dot(s,s),Z=K.dot(s,l)}o.y=h*m-d*Z,o.z=r*Z-d*m;let b=r*h-d*d;if(b!==0)return o.y/=b,o.z/=b,o.x=1-o.y-o.z,o}var YG=uvt;var hun=R(W(),1);var k7={};k7.calculateACMR=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.indices,n=t.maximumIndex,i=f(t.cacheSize,24),o=e.length;if(!c(n)){n=0;let l=0,r=e[l];for(;ln&&(n=r),++l,r=e[l]}let a=[];for(let l=0;li&&(a[e[l]]=s,++s);return(s-i+1)/(o/3)};k7.tipsify=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.indices,n=t.maximumIndex,i=f(t.cacheSize,24),o;function a(V,E,I,B){for(;E.length>=1;){let X=E[E.length-1];if(E.splice(E.length-1,1),V[X].numLiveTriangles>0)return X}for(;o0)return++o,o-1;++o}return-1}function s(V,E,I,B,X,_,P){let w=-1,z,H=-1,nt=0;for(;ntH||H===-1)&&(H=z,w=$)),++nt}return w===-1?a(B,_,V,P):w}let l=e.length,r=0,d=0,m=e[d],h=l;if(c(n))r=n+1;else{for(;dr&&(r=m),++d,m=e[d];if(r===-1)return 0;++r}let Z=[],b;for(b=0;bi&&(T.timeStamp=U,++U),++d}F=s(e,i,G,Z,U,A,r)}return y};var j2=k7;var Ic={};function ew(t,e,n,i,o){t[e++]=n,t[e++]=i,t[e++]=i,t[e++]=o,t[e++]=o,t[e]=n}function Zvt(t){let e=t.length,n=e/3*6,i=re.createTypedArray(e,n),o=0;for(let a=0;a=3){let n=(e-2)*6,i=re.createTypedArray(e,n);ew(i,0,t[0],t[1],t[2]);let o=6;for(let a=3;a0){let e=t.length-1,n=(e-1)*6,i=re.createTypedArray(e,n),o=t[0],a=0;for(let s=1;so&&(o=n[a]);t.indices=j2.tipsify({indices:n,maximumIndex:o,cacheSize:e})}return t};function yut(t){let e={};for(let n in t)if(t.hasOwnProperty(n)&&c(t[n])&&c(t[n].values)){let i=t[n];e[n]=new jt({componentDatatype:i.componentDatatype,componentsPerAttribute:i.componentsPerAttribute,normalize:i.normalize,values:[]})}return e}function Rvt(t,e,n){for(let i in e)if(e.hasOwnProperty(i)&&c(e[i])&&c(e[i].values)){let o=e[i];for(let a=0;a=k.SIXTY_FOUR_KILOBYTES){let i=[],o=[],a=0,s=yut(t.attributes),l=t.indices,r=l.length,d;t.primitiveType===le.TRIANGLES?d=3:t.primitiveType===le.LINES?d=2:t.primitiveType===le.POINTS&&(d=1);for(let m=0;m=k.SIXTY_FOUR_KILOBYTES&&(e.push(new _e({attributes:s,indices:o,primitiveType:t.primitiveType,boundingSphere:t.boundingSphere,boundingSphereCV:t.boundingSphereCV})),i=[],o=[],a=0,s=yut(t.attributes))}o.length!==0&&e.push(new _e({attributes:s,indices:o,primitiveType:t.primitiveType,boundingSphere:t.boundingSphere,boundingSphereCV:t.boundingSphereCV}))}else e.push(t);return e};var But=new p,Wvt=new gt;Ic.projectTo2D=function(t,e,n,i,o){let a=t.attributes[e];o=c(o)?o:new yo;let s=o.ellipsoid,l=a.values,r=new Float64Array(l.length),d=0;for(let m=0;mU&&(U=A)}return new _e({attributes:m,indices:u,primitiveType:d,boundingSphere:c(F)?new Ft(F,U):void 0})}Ic.combineInstances=function(t){let e=[],n=[],i=t.length;for(let a=0;a0&&o.push(J7(e,"geometry")),n.length>0&&(o.push(J7(n,"westHemisphereGeometry")),o.push(J7(n,"eastHemisphereGeometry"))),o};var yp=new p,q2=new p,uE=new p,ZE=new p;Ic.computeNormal=function(t){let e=t.indices,n=t.attributes,i=n.position.values,o=n.position.values.length/3,a=e.length,s=new Array(o),l=new Array(a/3),r=new Array(a),d;for(d=0;d0){for(m=0;m3&&(n[3]=0,n[4]=2,n[5]=3);let i=6;for(let o=3;oo?i>a?s=k.sign(t.y):s=k.sign(n.y):o>a?s=k.sign(e.y):s=k.sign(n.y);let l=s<0;Gf(t,l),Gf(e,l),Gf(n,l)}var xut=new p;function Bp(t,e,n,i){p.add(t,p.multiplyByScalar(p.subtract(e,t,xut),t.y/(t.y-e.y),xut),n),p.clone(n,i),Gf(n,!0),Gf(i,!1)}var xG=new p,XG=new p,JG=new p,LG=new p,L7={positions:new Array(7),indices:new Array(3*3)};function yvt(t,e,n){if(t.x>=0||e.x>=0||n.x>=0)return;Nvt(t,e,n);let i=t.y<0,o=e.y<0,a=n.y<0,s=0;s+=i?1:0,s+=o?1:0,s+=a?1:0;let l=L7.indices;s===1?(l[1]=3,l[2]=4,l[5]=6,l[7]=6,l[8]=5,i?(Bp(t,e,xG,JG),Bp(t,n,XG,LG),l[0]=0,l[3]=1,l[4]=2,l[6]=1):o?(Bp(e,n,xG,JG),Bp(e,t,XG,LG),l[0]=1,l[3]=2,l[4]=0,l[6]=2):a&&(Bp(n,t,xG,JG),Bp(n,e,XG,LG),l[0]=2,l[3]=0,l[4]=1,l[6]=0)):s===2&&(l[2]=4,l[4]=4,l[5]=3,l[7]=5,l[8]=6,i?o?a||(Bp(n,t,xG,JG),Bp(n,e,XG,LG),l[0]=0,l[1]=1,l[3]=0,l[6]=2):(Bp(e,n,xG,JG),Bp(e,t,XG,LG),l[0]=2,l[1]=0,l[3]=2,l[6]=1):(Bp(t,e,xG,JG),Bp(t,n,XG,LG),l[0]=1,l[1]=2,l[3]=1,l[6]=0));let r=L7.positions;return r[0]=t,r[1]=e,r[2]=n,r.length=3,(s===1||s===2)&&(r[3]=xG,r[4]=XG,r[5]=JG,r[6]=LG,r.length=7),L7}function Xut(t,e){let n=t.attributes;if(n.position.values.length===0)return;for(let o in n)if(n.hasOwnProperty(o)&&c(n[o])&&c(n[o].values)){let a=n[o];a.values=it.createTypedArray(a.componentDatatype,a.values)}let i=_e.computeNumberOfVertices(t);return t.indices=re.createTypedArray(i,t.indices),e&&(t.boundingSphere=Ft.fromVertices(n.position.values)),t}function bE(t){let e=t.attributes,n={};for(let i in e)if(e.hasOwnProperty(i)&&c(e[i])&&c(e[i].values)){let o=e[i];n[i]=new jt({componentDatatype:o.componentDatatype,componentsPerAttribute:o.componentsPerAttribute,normalize:o.normalize,values:[]})}return new _e({attributes:n,indices:[],primitiveType:t.primitiveType})}function O7(t,e,n){let i=c(t.geometry.boundingSphere);e=Xut(e,i),n=Xut(n,i),c(n)&&!c(e)?t.geometry=n:!c(n)&&c(e)?t.geometry=e:(t.westHemisphereGeometry=e,t.eastHemisphereGeometry=n,t.geometry=void 0)}function H7(t,e){let n=new t,i=new t,o=new t;return function(a,s,l,r,d,m,h,Z){let b=t.fromArray(d,a*e,n),u=t.fromArray(d,s*e,i),F=t.fromArray(d,l*e,o);t.multiplyByScalar(b,r.x,b),t.multiplyByScalar(u,r.y,u),t.multiplyByScalar(F,r.z,F);let U=t.add(b,u,b);if(t.add(U,F,U),Z)try{t.normalize(U,U)}catch(G){throw new Ut(G)}t.pack(U,m,h*e)}}var Bvt=H7(Rt,4),tw=H7(p,3),Out=H7(K,2),Qvt=function(t,e,n,i,o,a,s){let l=o[t]*i.x,r=o[e]*i.y,d=o[n]*i.z;a[s]=l+r+d>k.EPSILON6?1:0},tk=new p,M7=new p,_7=new p,kvt=new p;function qH(t,e,n,i,o,a,s,l,r,d,m,h,Z,b,u,F){if(!c(a)&&!c(s)&&!c(l)&&!c(r)&&!c(d)&&b===0)return;let U=p.fromArray(o,t*3,tk),G=p.fromArray(o,e*3,M7),A=p.fromArray(o,n*3,_7),T=YG(i,U,G,A,kvt);if(c(T)){if(c(a)&&tw(t,e,n,T,a,h.normal.values,F,!0),c(d)){let g=p.fromArray(d,t*3,tk),C=p.fromArray(d,e*3,M7),y=p.fromArray(d,n*3,_7);p.multiplyByScalar(g,T.x,g),p.multiplyByScalar(C,T.y,C),p.multiplyByScalar(y,T.z,y);let Y;!p.equals(g,p.ZERO)||!p.equals(C,p.ZERO)||!p.equals(y,p.ZERO)?(Y=p.add(g,C,g),p.add(Y,y,Y),p.normalize(Y,Y)):(Y=tk,Y.x=0,Y.y=0,Y.z=0),p.pack(Y,h.extrudeDirection.values,F*3)}if(c(m)&&Qvt(t,e,n,T,m,h.applyOffset.values,F),c(s)&&tw(t,e,n,T,s,h.tangent.values,F,!0),c(l)&&tw(t,e,n,T,l,h.bitangent.values,F,!0),c(r)&&Out(t,e,n,T,r,h.st.values,F),b>0)for(let g=0;g3){let B=I.positions,X=I.indices,_=X.length;for(let P=0;P<_;++P){let w=X[P],z=B[w];z.y<0?(F=u.attributes,U=u.indices,G=g):(F=b.attributes,U=b.indices,G=C),A=HV(F,U,G,m,w<3?T+w:-1,z),qH(Y,Q,J,z,i,o,s,a,l,r,d,F,h,Z,n,A)}}else c(I)&&(M=I.positions[0],V=I.positions[1],E=I.positions[2]),M.y<0?(F=u.attributes,U=u.indices,G=g):(F=b.attributes,U=b.indices,G=C),A=HV(F,U,G,m,T,M),qH(Y,Q,J,M,i,o,s,a,l,r,d,F,h,Z,n,A),A=HV(F,U,G,m,T+1,V),qH(Y,Q,J,V,i,o,s,a,l,r,d,F,h,Z,n,A),A=HV(F,U,G,m,T+2,E),qH(Y,Q,J,E,i,o,s,a,l,r,d,F,h,Z,n,A)}O7(t,u,b)}var Hut=Kn.fromPointNormal(p.ZERO,p.UNIT_Y),Xvt=new p,Jvt=new p;function VE(t,e,n,i,o,a,s){if(!c(s))return;let l=p.fromArray(i,t*3,tk);p.equalsEpsilon(l,n,k.EPSILON10)?a.applyOffset.values[o]=s[t]:a.applyOffset.values[o]=s[e]}function Lut(t){let e=t.geometry,n=e.attributes,i=n.position.values,o=c(n.applyOffset)?n.applyOffset.values:void 0,a=e.indices,s=bE(e),l=bE(e),r,d=a.length,m=[];m.length=i.length/3;let h=[];for(h.length=i.length/3,r=0;r0)continue;let r=p.unpack(i,s,Put);(l.y<0&&r.y>0||l.y>0&&r.y<0)&&(s-3>0?(i[s]=n[s-3],i[s+1]=n[s-2],i[s+2]=n[s-1]):p.pack(l,i,s));let d=p.unpack(o,s,D7);(l.y<0&&d.y>0||l.y>0&&d.y<0)&&(s+30||Ft.intersectPlane(n,Kn.ORIGIN_ZX_PLANE)!==yn.INTERSECTING))return t;if(e.geometryType!==gp.NONE)switch(e.geometryType){case gp.POLYLINES:Hvt(t);break;case gp.TRIANGLES:Jut(t);break;case gp.LINES:Lut(t);break}else Ivt(e),e.primitiveType===le.TRIANGLES?Jut(t):e.primitiveType===le.LINES&&Lut(t);return t};var gi=Ic;var Pun=R(W(),1);function Tm(t){this._ellipsoid=f(t,mt.WGS84),this._semimajorAxis=this._ellipsoid.maximumRadius,this._oneOverSemimajorAxis=1/this._semimajorAxis}Object.defineProperties(Tm.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});Tm.mercatorAngleToGeodeticLatitude=function(t){return k.PI_OVER_TWO-2*Math.atan(Math.exp(-t))};Tm.geodeticLatitudeToMercatorAngle=function(t){t>Tm.MaximumLatitude?t=Tm.MaximumLatitude:t<-Tm.MaximumLatitude&&(t=-Tm.MaximumLatitude);let e=Math.sin(t);return .5*Math.log((1+e)/(1-e))};Tm.MaximumLatitude=Tm.mercatorAngleToGeodeticLatitude(Math.PI);Tm.prototype.project=function(t,e){let n=this._semimajorAxis,i=t.longitude*n,o=Tm.geodeticLatitudeToMercatorAngle(t.latitude)*n,a=t.height;return c(e)?(e.x=i,e.y=o,e.z=a,e):new p(i,o,a)};Tm.prototype.unproject=function(t,e){let n=this._oneOverSemimajorAxis,i=t.x*n,o=Tm.mercatorAngleToGeodeticLatitude(t.y*n),a=t.z;return c(e)?(e.longitude=i,e.latitude=o,e.height=a,e):new gt(i,o,a)};var Yo=Tm;function wvt(t,e,n){let i=!n,o=t.length,a;if(!i&&o>1){let s=t[0].modelMatrix;for(a=1;a=0){let d=i[l];o=d.offset+d.count,s=d.index,a=n[s].indices.length}else o=0,s=0,a=n[s].indices.length;let r=t.length;for(let d=0;da&&(o=0,a=n[++s].indices.length),i.push({index:s,offset:o,count:Z}),o+=Z}}function Kvt(t,e){let n=[];return P7(t,"geometry",e,n),P7(t,"westHemisphereGeometry",e,n),P7(t,"eastHemisphereGeometry",e,n),n}var yR={};yR.combineGeometry=function(t){let e,n,i=t.instances,o=i.length,a,s,l=!1;o>0&&(e=vvt(t),e.length>0&&(n=gi.createAttributeLocations(e[0]),t.createPickOffsets&&(a=Kvt(i,e))),c(i[0].attributes)&&c(i[0].attributes.offset)&&(s=new Array(o),l=!0));let r=new Array(o),d=new Array(o);for(let m=0;m0&&(n.set(r.indices,s),s+=u)}return e.push(n.buffer),{stringTable:i,packedData:n}};yR.unpackCreateGeometryResults=function(t){let e=t.stringTable,n=t.packedData,i,o=new Array(n[0]),a=0,s=1;for(;s0){let C=U.length/G;for(g=re.createTypedArray(C,F),i=0;i>1^-(t&1)}La.zigZagDeltaDecode=function(t,e,n){let i=t.length,o=0,a=0,s=0;for(let l=0;l>11,m=r>>5&o,h=r&i,u=3*l;e[u]=d*a,e[u+1]=m*s,e[u+2]=h*a}return e};var Ni=La;var rVn=b(W(),1);var CVt=new p,IVt=new p,NVt=new p;function Vvt(t,e,n,i,o){c(o)||(o=new p);let a,s,l,r,d,m,h,u;if(c(e.z)){if(p.equalsEpsilon(t,e,k.EPSILON14))return p.clone(p.UNIT_X,o);if(p.equalsEpsilon(t,n,k.EPSILON14))return p.clone(p.UNIT_Y,o);if(p.equalsEpsilon(t,i,k.EPSILON14))return p.clone(p.UNIT_Z,o);a=p.subtract(n,e,CVt),s=p.subtract(i,e,IVt),l=p.subtract(t,e,NVt),r=p.dot(a,a),d=p.dot(a,s),m=p.dot(a,l),h=p.dot(s,s),u=p.dot(s,l)}else{if(K.equalsEpsilon(t,e,k.EPSILON14))return p.clone(p.UNIT_X,o);if(K.equalsEpsilon(t,n,k.EPSILON14))return p.clone(p.UNIT_Y,o);if(K.equalsEpsilon(t,i,k.EPSILON14))return p.clone(p.UNIT_Z,o);a=K.subtract(n,e,CVt),s=K.subtract(i,e,IVt),l=K.subtract(t,e,NVt),r=K.dot(a,a),d=K.dot(a,s),m=K.dot(a,l),h=K.dot(s,s),u=K.dot(s,l)}o.y=h*m-d*u,o.z=r*u-d*m;let R=r*h-d*d;if(R!==0)return o.y/=R,o.z/=R,o.x=1-o.y-o.z,o}var YG=Vvt;var hVn=b(W(),1);var k7={};k7.calculateACMR=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.indices,n=t.maximumIndex,i=f(t.cacheSize,24),o=e.length;if(!c(n)){n=0;let l=0,r=e[l];for(;ln&&(n=r),++l,r=e[l]}let a=[];for(let l=0;li&&(a[e[l]]=s,++s);return(s-i+1)/(o/3)};k7.tipsify=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.indices,n=t.maximumIndex,i=f(t.cacheSize,24),o;function a(Z,E,I,B){for(;E.length>=1;){let X=E[E.length-1];if(E.splice(E.length-1,1),Z[X].numLiveTriangles>0)return X}for(;o0)return++o,o-1;++o}return-1}function s(Z,E,I,B,X,_,P){let w=-1,z,H=-1,nt=0;for(;ntH||H===-1)&&(H=z,w=$)),++nt}return w===-1?a(B,_,Z,P):w}let l=e.length,r=0,d=0,m=e[d],h=l;if(c(n))r=n+1;else{for(;dr&&(r=m),++d,m=e[d];if(r===-1)return 0;++r}let u=[],R;for(R=0;Ri&&(S.timeStamp=U,++U),++d}F=s(e,i,G,u,U,A,r)}return y};var jk=k7;var Ic={};function ew(t,e,n,i,o){t[e++]=n,t[e++]=i,t[e++]=i,t[e++]=o,t[e++]=o,t[e]=n}function uvt(t){let e=t.length,n=e/3*6,i=re.createTypedArray(e,n),o=0;for(let a=0;a=3){let n=(e-2)*6,i=re.createTypedArray(e,n);ew(i,0,t[0],t[1],t[2]);let o=6;for(let a=3;a0){let e=t.length-1,n=(e-1)*6,i=re.createTypedArray(e,n),o=t[0],a=0;for(let s=1;so&&(o=n[a]);t.indices=jk.tipsify({indices:n,maximumIndex:o,cacheSize:e})}return t};function yVt(t){let e={};for(let n in t)if(t.hasOwnProperty(n)&&c(t[n])&&c(t[n].values)){let i=t[n];e[n]=new jt({componentDatatype:i.componentDatatype,componentsPerAttribute:i.componentsPerAttribute,normalize:i.normalize,values:[]})}return e}function bvt(t,e,n){for(let i in e)if(e.hasOwnProperty(i)&&c(e[i])&&c(e[i].values)){let o=e[i];for(let a=0;a=k.SIXTY_FOUR_KILOBYTES){let i=[],o=[],a=0,s=yVt(t.attributes),l=t.indices,r=l.length,d;t.primitiveType===le.TRIANGLES?d=3:t.primitiveType===le.LINES?d=2:t.primitiveType===le.POINTS&&(d=1);for(let m=0;m=k.SIXTY_FOUR_KILOBYTES&&(e.push(new _e({attributes:s,indices:o,primitiveType:t.primitiveType,boundingSphere:t.boundingSphere,boundingSphereCV:t.boundingSphereCV})),i=[],o=[],a=0,s=yVt(t.attributes))}o.length!==0&&e.push(new _e({attributes:s,indices:o,primitiveType:t.primitiveType,boundingSphere:t.boundingSphere,boundingSphereCV:t.boundingSphereCV}))}else e.push(t);return e};var BVt=new p,Wvt=new gt;Ic.projectTo2D=function(t,e,n,i,o){let a=t.attributes[e];o=c(o)?o:new yo;let s=o.ellipsoid,l=a.values,r=new Float64Array(l.length),d=0;for(let m=0;mU&&(U=A)}return new _e({attributes:m,indices:V,primitiveType:d,boundingSphere:c(F)?new Ft(F,U):void 0})}Ic.combineInstances=function(t){let e=[],n=[],i=t.length;for(let a=0;a0&&o.push(J7(e,"geometry")),n.length>0&&(o.push(J7(n,"westHemisphereGeometry")),o.push(J7(n,"eastHemisphereGeometry"))),o};var yp=new p,qk=new p,VE=new p,uE=new p;Ic.computeNormal=function(t){let e=t.indices,n=t.attributes,i=n.position.values,o=n.position.values.length/3,a=e.length,s=new Array(o),l=new Array(a/3),r=new Array(a),d;for(d=0;d0){for(m=0;m3&&(n[3]=0,n[4]=2,n[5]=3);let i=6;for(let o=3;oo?i>a?s=k.sign(t.y):s=k.sign(n.y):o>a?s=k.sign(e.y):s=k.sign(n.y);let l=s<0;Gf(t,l),Gf(e,l),Gf(n,l)}var xVt=new p;function Bp(t,e,n,i){p.add(t,p.multiplyByScalar(p.subtract(e,t,xVt),t.y/(t.y-e.y),xVt),n),p.clone(n,i),Gf(n,!0),Gf(i,!1)}var xG=new p,XG=new p,JG=new p,LG=new p,L7={positions:new Array(7),indices:new Array(3*3)};function yvt(t,e,n){if(t.x>=0||e.x>=0||n.x>=0)return;Nvt(t,e,n);let i=t.y<0,o=e.y<0,a=n.y<0,s=0;s+=i?1:0,s+=o?1:0,s+=a?1:0;let l=L7.indices;s===1?(l[1]=3,l[2]=4,l[5]=6,l[7]=6,l[8]=5,i?(Bp(t,e,xG,JG),Bp(t,n,XG,LG),l[0]=0,l[3]=1,l[4]=2,l[6]=1):o?(Bp(e,n,xG,JG),Bp(e,t,XG,LG),l[0]=1,l[3]=2,l[4]=0,l[6]=2):a&&(Bp(n,t,xG,JG),Bp(n,e,XG,LG),l[0]=2,l[3]=0,l[4]=1,l[6]=0)):s===2&&(l[2]=4,l[4]=4,l[5]=3,l[7]=5,l[8]=6,i?o?a||(Bp(n,t,xG,JG),Bp(n,e,XG,LG),l[0]=0,l[1]=1,l[3]=0,l[6]=2):(Bp(e,n,xG,JG),Bp(e,t,XG,LG),l[0]=2,l[1]=0,l[3]=2,l[6]=1):(Bp(t,e,xG,JG),Bp(t,n,XG,LG),l[0]=1,l[1]=2,l[3]=1,l[6]=0));let r=L7.positions;return r[0]=t,r[1]=e,r[2]=n,r.length=3,(s===1||s===2)&&(r[3]=xG,r[4]=XG,r[5]=JG,r[6]=LG,r.length=7),L7}function XVt(t,e){let n=t.attributes;if(n.position.values.length===0)return;for(let o in n)if(n.hasOwnProperty(o)&&c(n[o])&&c(n[o].values)){let a=n[o];a.values=it.createTypedArray(a.componentDatatype,a.values)}let i=_e.computeNumberOfVertices(t);return t.indices=re.createTypedArray(i,t.indices),e&&(t.boundingSphere=Ft.fromVertices(n.position.values)),t}function RE(t){let e=t.attributes,n={};for(let i in e)if(e.hasOwnProperty(i)&&c(e[i])&&c(e[i].values)){let o=e[i];n[i]=new jt({componentDatatype:o.componentDatatype,componentsPerAttribute:o.componentsPerAttribute,normalize:o.normalize,values:[]})}return new _e({attributes:n,indices:[],primitiveType:t.primitiveType})}function O7(t,e,n){let i=c(t.geometry.boundingSphere);e=XVt(e,i),n=XVt(n,i),c(n)&&!c(e)?t.geometry=n:!c(n)&&c(e)?t.geometry=e:(t.westHemisphereGeometry=e,t.eastHemisphereGeometry=n,t.geometry=void 0)}function H7(t,e){let n=new t,i=new t,o=new t;return function(a,s,l,r,d,m,h,u){let R=t.fromArray(d,a*e,n),V=t.fromArray(d,s*e,i),F=t.fromArray(d,l*e,o);t.multiplyByScalar(R,r.x,R),t.multiplyByScalar(V,r.y,V),t.multiplyByScalar(F,r.z,F);let U=t.add(R,V,R);if(t.add(U,F,U),u)try{t.normalize(U,U)}catch(G){throw new Ut(G)}t.pack(U,m,h*e)}}var Bvt=H7(bt,4),tw=H7(p,3),OVt=H7(K,2),Qvt=function(t,e,n,i,o,a,s){let l=o[t]*i.x,r=o[e]*i.y,d=o[n]*i.z;a[s]=l+r+d>k.EPSILON6?1:0},t2=new p,M7=new p,_7=new p,kvt=new p;function qH(t,e,n,i,o,a,s,l,r,d,m,h,u,R,V,F){if(!c(a)&&!c(s)&&!c(l)&&!c(r)&&!c(d)&&R===0)return;let U=p.fromArray(o,t*3,t2),G=p.fromArray(o,e*3,M7),A=p.fromArray(o,n*3,_7),S=YG(i,U,G,A,kvt);if(c(S)){if(c(a)&&tw(t,e,n,S,a,h.normal.values,F,!0),c(d)){let g=p.fromArray(d,t*3,t2),C=p.fromArray(d,e*3,M7),y=p.fromArray(d,n*3,_7);p.multiplyByScalar(g,S.x,g),p.multiplyByScalar(C,S.y,C),p.multiplyByScalar(y,S.z,y);let Y;!p.equals(g,p.ZERO)||!p.equals(C,p.ZERO)||!p.equals(y,p.ZERO)?(Y=p.add(g,C,g),p.add(Y,y,Y),p.normalize(Y,Y)):(Y=t2,Y.x=0,Y.y=0,Y.z=0),p.pack(Y,h.extrudeDirection.values,F*3)}if(c(m)&&Qvt(t,e,n,S,m,h.applyOffset.values,F),c(s)&&tw(t,e,n,S,s,h.tangent.values,F,!0),c(l)&&tw(t,e,n,S,l,h.bitangent.values,F,!0),c(r)&&OVt(t,e,n,S,r,h.st.values,F),R>0)for(let g=0;g3){let B=I.positions,X=I.indices,_=X.length;for(let P=0;P<_;++P){let w=X[P],z=B[w];z.y<0?(F=V.attributes,U=V.indices,G=g):(F=R.attributes,U=R.indices,G=C),A=HZ(F,U,G,m,w<3?S+w:-1,z),qH(Y,Q,J,z,i,o,s,a,l,r,d,F,h,u,n,A)}}else c(I)&&(M=I.positions[0],Z=I.positions[1],E=I.positions[2]),M.y<0?(F=V.attributes,U=V.indices,G=g):(F=R.attributes,U=R.indices,G=C),A=HZ(F,U,G,m,S,M),qH(Y,Q,J,M,i,o,s,a,l,r,d,F,h,u,n,A),A=HZ(F,U,G,m,S+1,Z),qH(Y,Q,J,Z,i,o,s,a,l,r,d,F,h,u,n,A),A=HZ(F,U,G,m,S+2,E),qH(Y,Q,J,E,i,o,s,a,l,r,d,F,h,u,n,A)}O7(t,V,R)}var HVt=Kn.fromPointNormal(p.ZERO,p.UNIT_Y),Xvt=new p,Jvt=new p;function ZE(t,e,n,i,o,a,s){if(!c(s))return;let l=p.fromArray(i,t*3,t2);p.equalsEpsilon(l,n,k.EPSILON10)?a.applyOffset.values[o]=s[t]:a.applyOffset.values[o]=s[e]}function LVt(t){let e=t.geometry,n=e.attributes,i=n.position.values,o=c(n.applyOffset)?n.applyOffset.values:void 0,a=e.indices,s=RE(e),l=RE(e),r,d=a.length,m=[];m.length=i.length/3;let h=[];for(h.length=i.length/3,r=0;r0)continue;let r=p.unpack(i,s,PVt);(l.y<0&&r.y>0||l.y>0&&r.y<0)&&(s-3>0?(i[s]=n[s-3],i[s+1]=n[s-2],i[s+2]=n[s-1]):p.pack(l,i,s));let d=p.unpack(o,s,D7);(l.y<0&&d.y>0||l.y>0&&d.y<0)&&(s+30||Ft.intersectPlane(n,Kn.ORIGIN_ZX_PLANE)!==yn.INTERSECTING))return t;if(e.geometryType!==gp.NONE)switch(e.geometryType){case gp.POLYLINES:Hvt(t);break;case gp.TRIANGLES:JVt(t);break;case gp.LINES:LVt(t);break}else Ivt(e),e.primitiveType===le.TRIANGLES?JVt(t):e.primitiveType===le.LINES&&LVt(t);return t};var gi=Ic;var PVn=b(W(),1);function Sm(t){this._ellipsoid=f(t,mt.WGS84),this._semimajorAxis=this._ellipsoid.maximumRadius,this._oneOverSemimajorAxis=1/this._semimajorAxis}Object.defineProperties(Sm.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});Sm.mercatorAngleToGeodeticLatitude=function(t){return k.PI_OVER_TWO-2*Math.atan(Math.exp(-t))};Sm.geodeticLatitudeToMercatorAngle=function(t){t>Sm.MaximumLatitude?t=Sm.MaximumLatitude:t<-Sm.MaximumLatitude&&(t=-Sm.MaximumLatitude);let e=Math.sin(t);return .5*Math.log((1+e)/(1-e))};Sm.MaximumLatitude=Sm.mercatorAngleToGeodeticLatitude(Math.PI);Sm.prototype.project=function(t,e){let n=this._semimajorAxis,i=t.longitude*n,o=Sm.geodeticLatitudeToMercatorAngle(t.latitude)*n,a=t.height;return c(e)?(e.x=i,e.y=o,e.z=a,e):new p(i,o,a)};Sm.prototype.unproject=function(t,e){let n=this._oneOverSemimajorAxis,i=t.x*n,o=Sm.mercatorAngleToGeodeticLatitude(t.y*n),a=t.z;return c(e)?(e.longitude=i,e.latitude=o,e.height=a,e):new gt(i,o,a)};var Yo=Sm;function wvt(t,e,n){let i=!n,o=t.length,a;if(!i&&o>1){let s=t[0].modelMatrix;for(a=1;a=0){let d=i[l];o=d.offset+d.count,s=d.index,a=n[s].indices.length}else o=0,s=0,a=n[s].indices.length;let r=t.length;for(let d=0;da&&(o=0,a=n[++s].indices.length),i.push({index:s,offset:o,count:u}),o+=u}}function Kvt(t,e){let n=[];return P7(t,"geometry",e,n),P7(t,"westHemisphereGeometry",e,n),P7(t,"eastHemisphereGeometry",e,n),n}var yb={};yb.combineGeometry=function(t){let e,n,i=t.instances,o=i.length,a,s,l=!1;o>0&&(e=vvt(t),e.length>0&&(n=gi.createAttributeLocations(e[0]),t.createPickOffsets&&(a=Kvt(i,e))),c(i[0].attributes)&&c(i[0].attributes.offset)&&(s=new Array(o),l=!0));let r=new Array(o),d=new Array(o);for(let m=0;m0&&(n.set(r.indices,s),s+=V)}return e.push(n.buffer),{stringTable:i,packedData:n}};yb.unpackCreateGeometryResults=function(t){let e=t.stringTable,n=t.packedData,i,o=new Array(n[0]),a=0,s=1;for(;s0){let C=U.length/G;for(g=re.createTypedArray(C,F),i=0;i= nearSq && distanceSq <= farSq) ? 1.0 : 0.0; gl_Position *= show; }`,`${i} -${o}`};function qut(t,e){if(!t.compressVertices)return e;let n=e.search(/in\s+vec3\s+normal;/g)!==-1,i=e.search(/in\s+vec2\s+st;/g)!==-1;if(!n&&!i)return e;let o=e.search(/in\s+vec3\s+tangent;/g)!==-1,a=e.search(/in\s+vec3\s+bitangent;/g)!==-1,s=i&&n?2:1;s+=o||a?1:0;let l=s>1?`vec${s}`:"float",r="compressedAttributes",d=`in ${l} ${r};`,m="",h="";if(i){m+=`vec2 st; -`;let u=s>1?`${r}.x`:r;h+=` st = czm_decompressTextureCoordinates(${u}); +${o}`};function qVt(t,e){if(!t.compressVertices)return e;let n=e.search(/in\s+vec3\s+normal;/g)!==-1,i=e.search(/in\s+vec2\s+st;/g)!==-1;if(!n&&!i)return e;let o=e.search(/in\s+vec3\s+tangent;/g)!==-1,a=e.search(/in\s+vec3\s+bitangent;/g)!==-1,s=i&&n?2:1;s+=o||a?1:0;let l=s>1?`vec${s}`:"float",r="compressedAttributes",d=`in ${l} ${r};`,m="",h="";if(i){m+=`vec2 st; +`;let V=s>1?`${r}.x`:r;h+=` st = czm_decompressTextureCoordinates(${V}); `}n&&o&&a?(m+=`vec3 normal; vec3 tangent; vec3 bitangent; @@ -4994,14 +4994,14 @@ vec3 bitangent; `,h+=` tangent = czm_octDecode(${r}.${i&&n?"z":"y"}); `),a&&(m+=`vec3 bitangent; `,h+=` bitangent = czm_octDecode(${r}.${i&&n?"z":"y"}); -`));let Z=e;Z=Z.replace(/in\s+vec3\s+normal;/g,""),Z=Z.replace(/in\s+vec2\s+st;/g,""),Z=Z.replace(/in\s+vec3\s+tangent;/g,""),Z=Z.replace(/in\s+vec3\s+bitangent;/g,""),Z=Ve.replaceMain(Z,"czm_non_compressed_main");let b=`void main() +`));let u=e;u=u.replace(/in\s+vec3\s+normal;/g,""),u=u.replace(/in\s+vec2\s+st;/g,""),u=u.replace(/in\s+vec3\s+tangent;/g,""),u=u.replace(/in\s+vec3\s+bitangent;/g,""),u=Ze.replaceMain(u,"czm_non_compressed_main");let R=`void main() { ${h} czm_non_compressed_main(); -}`;return[d,m,Z,b].join(` -`)}function cKt(t){let e=Ve.replaceMain(t,"czm_non_depth_clamp_main");return e+=`void main() { +}`;return[d,m,u,R].join(` +`)}function c3t(t){let e=Ze.replaceMain(t,"czm_non_depth_clamp_main");return e+=`void main() { czm_non_depth_clamp_main(); gl_Position = czm_depthClamp(gl_Position);} -`,e}function mKt(t){let e=Ve.replaceMain(t,"czm_non_depth_clamp_main");return e+=`void main() { +`,e}function m3t(t){let e=Ze.replaceMain(t,"czm_non_depth_clamp_main");return e+=`void main() { czm_non_depth_clamp_main(); #if defined(LOG_DEPTH) czm_writeLogDepth(); @@ -5009,7 +5009,7 @@ ${h} czm_non_compressed_main(); czm_writeDepthClamp(); #endif } -`,e}function $ut(t,e){let n=t.vertexAttributes}function hKt(t,e){return function(){return t[e]}}var v7=Math.max(In.hardwareConcurrency-1,1),nw,pKt=new $i("combineGeometry");function uKt(t,e){let n,i,o,a,s=t._instanceIds;if(t._state===vs.READY){n=Array.isArray(t.geometryInstances)?t.geometryInstances:[t.geometryInstances];let l=t._numberOfInstances=n.length,r=[],d=[];for(o=0;o0){let F=new Float64Array(h);for(u=[F.buffer],a=0;a0?(t._recomputeBoundingSpheres=!0,t._state=vs.COMBINED):nk(t,e,vs.FAILED,void 0)}).catch(function(h){nk(t,e,vs.FAILED,h)})}}function ZKt(t,e){let n=Array.isArray(t.geometryInstances)?t.geometryInstances:[t.geometryInstances],i=t._numberOfInstances=n.length,o=new Array(i),a=t._instanceIds,s,l,r=0;for(l=0;l0?(t._recomputeBoundingSpheres=!0,t._state=vs.COMBINED):nk(t,e,vs.FAILED,void 0)}function VKt(t,e){let n=t._batchTableAttributeIndices.offset;if(!t._recomputeBoundingSpheres||!c(n)){t._recomputeBoundingSpheres=!1;return}let i,o=t._offsetInstanceExtend,a=t._instanceBoundingSpheres,s=a.length,l=t._tempBoundingSpheres;if(!c(l)){for(l=new Array(s),i=0;i0||Ft.intersectPlane(F,Kn.ORIGIN_ZX_PLANE)!==yn.INTERSECTING?r.push(F):(d.push(F),m.push(F))}let h=r[0],Z=m[0],b=d[0];for(i=1;i0){if(Sn.maximumVertexTextureImageUnits===0)throw new St("Vertex texture fetch support is required to render primitives with per-instance attributes. The maximum number of vertex texture image units must be greater than zero.");this._batchTable.update(t)}if(this._state!==vs.COMPLETE&&this._state!==vs.COMBINED&&(this.asynchronous?uKt(this,t):ZKt(this,t)),this._state===vs.COMBINED&&(bKt(this,t),eZt(this,t),WKt(this,t)),!this.show||this._state!==vs.COMPLETE)return;this._batchTableOffsetsUpdated||eZt(this,t),this._recomputeBoundingSpheres&&VKt(this,t);let n=this.appearance,i=n.material,o=!1,a=!1;this._appearance!==n?(this._appearance=n,this._material=i,o=!0,a=!0):this._material!==i&&(this._material=i,a=!0);let s=this.depthFailAppearance,l=c(s)?s.material:void 0;this._depthFailAppearance!==s?(this._depthFailAppearance=s,this._depthFailMaterial=l,o=!0,a=!0):this._depthFailMaterial!==l&&(this._depthFailMaterial=l,a=!0);let r=this._appearance.isTranslucent();this._translucent!==r&&(this._translucent=r,o=!0),c(this._material)&&this._material.update(e);let d=n.closed&&r;o&&f(this._createRenderStatesFunction,fKt)(this,e,n,d),a&&f(this._createShaderProgramFunction,FKt)(this,t,n),(o||a)&&f(this._createCommandsFunction,UKt)(this,n,i,r,d,this._colorCommands,this._pickCommands,t),f(this._updateAndQueueCommandsFunction,GKt)(this,t,this._colorCommands,this._pickCommands,this.modelMatrix,this.cull,this.debugShowBoundingVolume,d)};var AKt=new Ft,TKt=new Ft;function dZt(t,e,n){if(n===zn.TOP){let i=Ft.clone(t,AKt),o=Ft.clone(t,TKt);o.center=p.add(o.center,e,o.center),t=Ft.union(i,o,t)}else n===zn.ALL&&(t.center=p.add(t.center,e,t.center));return t}function SKt(t,e,n){return function(){let i=t.getBatchedAttribute(e,n),o=t.attributes[n],a=o.componentsPerAttribute,s=it.createTypedArray(o.componentDatatype,a);return c(i.constructor.pack)?i.constructor.pack(i,s,0):s[0]=i,s}}function gKt(t,e,n,i,o){return function(a){let s=aZt(a);t.setBatchedAttribute(e,n,s),o==="offset"&&(i._recomputeBoundingSpheres=!0,i._batchTableOffsetsUpdated=!1)}}var EKt=new p;function CKt(t,e,n){e.boundingSphere={get:function(){let i=t._instanceBoundingSpheres[n];if(c(i)){i=i.clone();let o=t.modelMatrix,a=e.offset;c(a)&&dZt(i,p.fromArray(a.get(),0,EKt),t._offsetInstanceExtend[n]),c(o)&&(i=Ft.transform(i,o))}return i}},e.boundingSphereCV={get:function(){return t._instanceBoundingSpheresCV[n]}}}function IKt(t,e,n){e.pickId={get:function(){return t._pickIds[n]}}}Ks.prototype.getGeometryInstanceAttributes=function(t){let e=this._perInstanceAttributeCache.get(t);if(c(e))return e;let n=-1,i=this._lastPerInstanceAttributeIndex,o=this._instanceIds,a=o.length;for(let d=0;d0){let F=new Float64Array(h);for(V=[F.buffer],a=0;a0?(t._recomputeBoundingSpheres=!0,t._state=vs.COMBINED):n2(t,e,vs.FAILED,void 0)}).catch(function(h){n2(t,e,vs.FAILED,h)})}}function u3t(t,e){let n=Array.isArray(t.geometryInstances)?t.geometryInstances:[t.geometryInstances],i=t._numberOfInstances=n.length,o=new Array(i),a=t._instanceIds,s,l,r=0;for(l=0;l0?(t._recomputeBoundingSpheres=!0,t._state=vs.COMBINED):n2(t,e,vs.FAILED,void 0)}function Z3t(t,e){let n=t._batchTableAttributeIndices.offset;if(!t._recomputeBoundingSpheres||!c(n)){t._recomputeBoundingSpheres=!1;return}let i,o=t._offsetInstanceExtend,a=t._instanceBoundingSpheres,s=a.length,l=t._tempBoundingSpheres;if(!c(l)){for(l=new Array(s),i=0;i0||Ft.intersectPlane(F,Kn.ORIGIN_ZX_PLANE)!==yn.INTERSECTING?r.push(F):(d.push(F),m.push(F))}let h=r[0],u=m[0],R=d[0];for(i=1;i0){if(Tn.maximumVertexTextureImageUnits===0)throw new Tt("Vertex texture fetch support is required to render primitives with per-instance attributes. The maximum number of vertex texture image units must be greater than zero.");this._batchTable.update(t)}if(this._state!==vs.COMPLETE&&this._state!==vs.COMBINED&&(this.asynchronous?V3t(this,t):u3t(this,t)),this._state===vs.COMBINED&&(R3t(this,t),eut(this,t),W3t(this,t)),!this.show||this._state!==vs.COMPLETE)return;this._batchTableOffsetsUpdated||eut(this,t),this._recomputeBoundingSpheres&&Z3t(this,t);let n=this.appearance,i=n.material,o=!1,a=!1;this._appearance!==n?(this._appearance=n,this._material=i,o=!0,a=!0):this._material!==i&&(this._material=i,a=!0);let s=this.depthFailAppearance,l=c(s)?s.material:void 0;this._depthFailAppearance!==s?(this._depthFailAppearance=s,this._depthFailMaterial=l,o=!0,a=!0):this._depthFailMaterial!==l&&(this._depthFailMaterial=l,a=!0);let r=this._appearance.isTranslucent();this._translucent!==r&&(this._translucent=r,o=!0),c(this._material)&&this._material.update(e);let d=n.closed&&r;o&&f(this._createRenderStatesFunction,f3t)(this,e,n,d),a&&f(this._createShaderProgramFunction,F3t)(this,t,n),(o||a)&&f(this._createCommandsFunction,U3t)(this,n,i,r,d,this._colorCommands,this._pickCommands,t),f(this._updateAndQueueCommandsFunction,G3t)(this,t,this._colorCommands,this._pickCommands,this.modelMatrix,this.cull,this.debugShowBoundingVolume,d)};var A3t=new Ft,S3t=new Ft;function dut(t,e,n){if(n===zn.TOP){let i=Ft.clone(t,A3t),o=Ft.clone(t,S3t);o.center=p.add(o.center,e,o.center),t=Ft.union(i,o,t)}else n===zn.ALL&&(t.center=p.add(t.center,e,t.center));return t}function T3t(t,e,n){return function(){let i=t.getBatchedAttribute(e,n),o=t.attributes[n],a=o.componentsPerAttribute,s=it.createTypedArray(o.componentDatatype,a);return c(i.constructor.pack)?i.constructor.pack(i,s,0):s[0]=i,s}}function g3t(t,e,n,i,o){return function(a){let s=aut(a);t.setBatchedAttribute(e,n,s),o==="offset"&&(i._recomputeBoundingSpheres=!0,i._batchTableOffsetsUpdated=!1)}}var E3t=new p;function C3t(t,e,n){e.boundingSphere={get:function(){let i=t._instanceBoundingSpheres[n];if(c(i)){i=i.clone();let o=t.modelMatrix,a=e.offset;c(a)&&dut(i,p.fromArray(a.get(),0,E3t),t._offsetInstanceExtend[n]),c(o)&&(i=Ft.transform(i,o))}return i}},e.boundingSphereCV={get:function(){return t._instanceBoundingSpheresCV[n]}}}function I3t(t,e,n){e.pickId={get:function(){return t._pickIds[n]}}}Ks.prototype.getGeometryInstanceAttributes=function(t){let e=this._perInstanceAttributeCache.get(t);if(c(e))return e;let n=-1,i=this._lastPerInstanceAttributeIndex,o=this._instanceIds,a=o.length;for(let d=0;dd&&(m=k.PI-s,s=-k.PI,d+=m),a-=k.EPSILON5,s-=k.EPSILON5,r+=k.EPSILON5,d+=k.EPSILON5;let h=1/(d-s),Z=1/(r-a),b={sphericalExtents:new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:4,normalize:!1,value:[a,s,Z,h]}),longitudeRotation:new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:1,normalize:!1,value:[m]})};return RZt(b,e),FZt(t,i,b),b};Qp.hasAttributesForTextureCoordinatePlanes=function(t){return c(t.southWest_HIGH)&&c(t.southWest_LOW)&&c(t.northward)&&c(t.eastward)&&c(t.planes2D_HIGH)&&c(t.planes2D_LOW)&&c(t.uMaxVmax)&&c(t.uvMinAndExtents)};Qp.hasAttributesForSphericalExtents=function(t){return c(t.sphericalExtents)&&c(t.longitudeRotation)&&c(t.planes2D_HIGH)&&c(t.planes2D_LOW)&&c(t.uMaxVmax)&&c(t.uvMinAndExtents)};function OKt(t){return Math.max(t.width,t.height)>Qp.MAX_WIDTH_FOR_PLANAR_EXTENTS}Qp.shouldUseSphericalCoordinates=function(t){return OKt(t)};Qp.MAX_WIDTH_FOR_PLANAR_EXTENTS=k.toRadians(1);var Fh=Qp;var yVn=R(W(),1);var TVn=R(W(),1);var HKt={NEVER:pt.NEVER,LESS:pt.LESS,EQUAL:pt.EQUAL,LESS_OR_EQUAL:pt.LEQUAL,GREATER:pt.GREATER,NOT_EQUAL:pt.NOTEQUAL,GREATER_OR_EQUAL:pt.GEQUAL,ALWAYS:pt.ALWAYS},Li=Object.freeze(HKt);var EVn=R(W(),1);var wKt={ZERO:pt.ZERO,KEEP:pt.KEEP,REPLACE:pt.REPLACE,INCREMENT:pt.INCR,DECREMENT:pt.DECR,INVERT:pt.INVERT,INCREMENT_WRAP:pt.INCR_WRAP,DECREMENT_WRAP:pt.DECR_WRAP},je=Object.freeze(wKt);var ow={CESIUM_3D_TILE_MASK:128,SKIP_LOD_MASK:112,SKIP_LOD_BIT_SHIFT:4,CLASSIFICATION_MASK:15};ow.setCesium3DTileBit=function(){return{enabled:!0,frontFunction:Li.ALWAYS,frontOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.REPLACE},backFunction:Li.ALWAYS,backOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.REPLACE},reference:ow.CESIUM_3D_TILE_MASK,mask:ow.CESIUM_3D_TILE_MASK}};var gn=Object.freeze(ow);function _G(t){t=f(t,f.EMPTY_OBJECT);let e=t.geometryInstances;this.geometryInstances=e,this.show=f(t.show,!0),this.classificationType=f(t.classificationType,Ji.BOTH),this.debugShowBoundingVolume=f(t.debugShowBoundingVolume,!1),this.debugShowShadowVolume=f(t.debugShowShadowVolume,!1),this._debugShowShadowVolume=!1,this._extruded=f(t._extruded,!1),this._uniformMap=t._uniformMap,this._sp=void 0,this._spStencil=void 0,this._spPick=void 0,this._spColor=void 0,this._spPick2D=void 0,this._spColor2D=void 0,this._rsStencilDepthPass=void 0,this._rsStencilDepthPass3DTiles=void 0,this._rsColorPass=void 0,this._rsPickPass=void 0,this._commandsIgnoreShow=[],this._ready=!1,this._primitive=void 0,this._pickPrimitive=t._pickPrimitive,this._hasSphericalExtentsAttribute=!1,this._hasPlanarExtentsAttributes=!1,this._hasPerColorAttribute=!1,this.appearance=t.appearance,this._createBoundingVolumeFunction=t._createBoundingVolumeFunction,this._updateAndQueueCommandsFunction=t._updateAndQueueCommandsFunction,this._usePickOffsets=!1,this._primitiveOptions={geometryInstances:void 0,appearance:void 0,vertexCacheOptimize:f(t.vertexCacheOptimize,!1),interleave:f(t.interleave,!1),releaseGeometryInstances:f(t.releaseGeometryInstances,!0),allowPicking:f(t.allowPicking,!0),asynchronous:f(t.asynchronous,!0),compressVertices:f(t.compressVertices,!0),_createBoundingVolumeFunction:void 0,_createRenderStatesFunction:void 0,_createShaderProgramFunction:void 0,_createCommandsFunction:void 0,_updateAndQueueCommandsFunction:void 0,_createPickOffsets:!0}}Object.defineProperties(_G.prototype,{vertexCacheOptimize:{get:function(){return this._primitiveOptions.vertexCacheOptimize}},interleave:{get:function(){return this._primitiveOptions.interleave}},releaseGeometryInstances:{get:function(){return this._primitiveOptions.releaseGeometryInstances}},allowPicking:{get:function(){return this._primitiveOptions.allowPicking}},asynchronous:{get:function(){return this._primitiveOptions.asynchronous}},compressVertices:{get:function(){return this._primitiveOptions.compressVertices}},ready:{get:function(){return this._ready}},_needs2DShader:{get:function(){return this._hasPlanarExtentsAttributes||this._hasSphericalExtentsAttribute}}});_G.isSupported=function(t){return t.context.stencilBuffer};function WE(t,e){let n=e?Li.EQUAL:Li.ALWAYS;return{colorMask:{red:!1,green:!1,blue:!1,alpha:!1},stencilTest:{enabled:t,frontFunction:n,frontOperation:{fail:je.KEEP,zFail:je.DECREMENT_WRAP,zPass:je.KEEP},backFunction:n,backOperation:{fail:je.KEEP,zFail:je.INCREMENT_WRAP,zPass:je.KEEP},reference:gn.CESIUM_3D_TILE_MASK,mask:gn.CESIUM_3D_TILE_MASK},stencilMask:gn.CLASSIFICATION_MASK,depthTest:{enabled:!0,func:_d.LESS_OR_EQUAL},depthMask:!1}}function q7(t){return{stencilTest:{enabled:t,frontFunction:Li.NOT_EQUAL,frontOperation:{fail:je.ZERO,zFail:je.ZERO,zPass:je.ZERO},backFunction:Li.NOT_EQUAL,backOperation:{fail:je.ZERO,zFail:je.ZERO,zPass:je.ZERO},reference:0,mask:gn.CLASSIFICATION_MASK},stencilMask:gn.CLASSIFICATION_MASK,depthTest:{enabled:!1},depthMask:!1,blending:Pn.PRE_MULTIPLIED_ALPHA_BLEND}}var PKt={stencilTest:{enabled:!0,frontFunction:Li.NOT_EQUAL,frontOperation:{fail:je.ZERO,zFail:je.ZERO,zPass:je.ZERO},backFunction:Li.NOT_EQUAL,backOperation:{fail:je.ZERO,zFail:je.ZERO,zPass:je.ZERO},reference:0,mask:gn.CLASSIFICATION_MASK},stencilMask:gn.CLASSIFICATION_MASK,depthTest:{enabled:!1},depthMask:!1};function vKt(t,e,n,i){if(c(t._rsStencilDepthPass))return;let o=!t.debugShowShadowVolume;t._rsStencilDepthPass=he.fromCache(WE(o,!1)),t._rsStencilDepthPass3DTiles=he.fromCache(WE(o,!0)),t._rsColorPass=he.fromCache(q7(o,!1)),t._rsPickPass=he.fromCache(PKt)}function KKt(t,e){if(!t.compressVertices)return e;if(e.search(/in\s+vec3\s+extrudeDirection;/g)!==-1){let n="compressedAttributes",i=`in vec2 ${n};`,o=`vec3 extrudeDirection; +${n.fragmentShaderSource}`;i.normalEC=a.indexOf("materialInput.normalEC")!==-1||a.indexOf("czm_getDefaultMaterial")!==-1,i.positionToEyeEC=a.indexOf("materialInput.positionToEyeEC")!==-1,i.tangentToEyeMatrix=a.indexOf("materialInput.tangentToEyeMatrix")!==-1,i.st=a.indexOf("materialInput.st")!==-1}this._colorShaderDependencies=i,this._pickShaderDependencies=o,this._appearance=n,this._extentsCulling=t,this._planarExtents=e}Qp.prototype.createFragmentShader=function(t){let e=this._appearance,n=this._colorShaderDependencies,i=[];!t&&!this._planarExtents&&i.push("SPHERICAL"),n.requiresEC&&i.push("REQUIRES_EC"),n.requiresWC&&i.push("REQUIRES_WC"),n.requiresTextureCoordinates&&i.push("TEXTURE_COORDINATES"),this._extentsCulling&&i.push("CULL_FRAGMENTS"),n.requiresNormalEC&&i.push("NORMAL_EC"),e instanceof jn&&i.push("PER_INSTANCE_COLOR"),n.normalEC&&i.push("USES_NORMAL_EC"),n.positionToEyeEC&&i.push("USES_POSITION_TO_EYE_EC"),n.tangentToEyeMatrix&&i.push("USES_TANGENT_TO_EYE"),n.st&&i.push("USES_ST"),e.flat&&i.push("FLAT");let o="";return e instanceof jn||(o=e.material.shaderSource),new Ze({defines:i,sources:[o,bE]})};Qp.prototype.createPickFragmentShader=function(t){let e=this._pickShaderDependencies,n=["PICK"];return!t&&!this._planarExtents&&n.push("SPHERICAL"),e.requiresEC&&n.push("REQUIRES_EC"),e.requiresWC&&n.push("REQUIRES_WC"),e.requiresTextureCoordinates&&n.push("TEXTURE_COORDINATES"),this._extentsCulling&&n.push("CULL_FRAGMENTS"),new Ze({defines:n,sources:[bE],pickColorQualifier:"in"})};Qp.prototype.createVertexShader=function(t,e,n,i){return Rut(this._colorShaderDependencies,this._planarExtents,n,t,e,this._appearance,i,this._projectionExtentDefines)};Qp.prototype.createPickVertexShader=function(t,e,n,i){return Rut(this._pickShaderDependencies,this._planarExtents,n,t,e,void 0,i,this._projectionExtentDefines)};var cut=new p,mut=new gt,hut={high:0,low:0};function Rut(t,e,n,i,o,a,s,l){let r=i.slice();if(l.eastMostYhighDefine===""){let d=mut;d.longitude=k.PI,d.latitude=0,d.height=0;let m=s.project(d,cut),h=Mi.encode(m.x,hut);l.eastMostYhighDefine=`EAST_MOST_X_HIGH ${h.high.toFixed(`${h.high}`.length+1)}`,l.eastMostYlowDefine=`EAST_MOST_X_LOW ${h.low.toFixed(`${h.low}`.length+1)}`;let u=mut;u.longitude=-k.PI,u.latitude=0,u.height=0;let R=s.project(u,cut);h=Mi.encode(R.x,hut),l.westMostYhighDefine=`WEST_MOST_X_HIGH ${h.high.toFixed(`${h.high}`.length+1)}`,l.westMostYlowDefine=`WEST_MOST_X_LOW ${h.low.toFixed(`${h.low}`.length+1)}`}return n&&(r.push(l.eastMostYhighDefine),r.push(l.eastMostYlowDefine),r.push(l.westMostYhighDefine),r.push(l.westMostYlowDefine)),c(a)&&a instanceof jn&&r.push("PER_INSTANCE_COLOR"),t.requiresTextureCoordinates&&(r.push("TEXTURE_COORDINATES"),e||n||r.push("SPHERICAL"),n&&r.push("COLUMBUS_VIEW_2D")),new Ze({defines:r,sources:[o]})}function z7(){this._requiresEC=!1,this._requiresWC=!1,this._requiresNormalEC=!1,this._requiresTextureCoordinates=!1,this._usesNormalEC=!1,this._usesPositionToEyeEC=!1,this._usesTangentToEyeMat=!1,this._usesSt=!1}Object.defineProperties(z7.prototype,{requiresEC:{get:function(){return this._requiresEC},set:function(t){this._requiresEC=t||this._requiresEC}},requiresWC:{get:function(){return this._requiresWC},set:function(t){this._requiresWC=t||this._requiresWC,this.requiresEC=this._requiresWC}},requiresNormalEC:{get:function(){return this._requiresNormalEC},set:function(t){this._requiresNormalEC=t||this._requiresNormalEC,this.requiresEC=this._requiresNormalEC}},requiresTextureCoordinates:{get:function(){return this._requiresTextureCoordinates},set:function(t){this._requiresTextureCoordinates=t||this._requiresTextureCoordinates,this.requiresWC=this._requiresTextureCoordinates}},normalEC:{set:function(t){this.requiresNormalEC=t,this._usesNormalEC=t},get:function(){return this._usesNormalEC}},tangentToEyeMatrix:{set:function(t){this.requiresWC=t,this.requiresNormalEC=t,this._usesTangentToEyeMat=t},get:function(){return this._usesTangentToEyeMat}},positionToEyeEC:{set:function(t){this.requiresEC=t,this._usesPositionToEyeEC=t},get:function(){return this._usesPositionToEyeEC}},st:{set:function(t){this.requiresTextureCoordinates=t,this._usesSt=t},get:function(){return this._usesSt}}});function put(t,e,n){return Math.abs((e.y-t.y)*n.x-(e.x-t.x)*n.y+e.x*t.y-e.y*t.x)/K.distance(e,t)}var y3t=[new K,new K,new K,new K];function but(t,e){let n=y3t,i=K.unpack(e,0,n[0]),o=K.unpack(e,2,n[1]),a=K.unpack(e,4,n[2]);t.uMaxVmax=new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:4,normalize:!1,value:[o.x,o.y,a.x,a.y]});let s=1/put(i,o,a),l=1/put(i,a,o);t.uvMinAndExtents=new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:4,normalize:!1,value:[i.x,i.y,s,l]})}var Wut=new gt,fut=new p,B3t=new p,Q3t=new p,iw={high:0,low:0};function Fut(t,e,n){let i=Wut;i.height=0,i.longitude=t.west,i.latitude=t.south;let o=e.project(i,fut);i.latitude=t.north;let a=e.project(i,B3t);i.longitude=t.east,i.latitude=t.south;let s=e.project(i,Q3t),l=[0,0,0,0],r=[0,0,0,0],d=Mi.encode(o.x,iw);l[0]=d.high,r[0]=d.low,d=Mi.encode(o.y,iw),l[1]=d.high,r[1]=d.low,d=Mi.encode(a.y,iw),l[2]=d.high,r[2]=d.low,d=Mi.encode(s.x,iw),l[3]=d.high,r[3]=d.low,n.planes2D_HIGH=new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:4,normalize:!1,value:l}),n.planes2D_LOW=new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:4,normalize:!1,value:r})}var k3t=new L,Y3t=new L,Vut=new p,x3t=new gt,X3t=[new gt,new gt,new gt,new gt,new gt,new gt,new gt,new gt];function J3t(t,e,n,i,o,a){let s=Gt.center(t,x3t);s.height=n;let l=gt.toCartesian(s,e,Vut),r=Pe.eastNorthUpToFixedFrame(l,e,k3t),d=L.inverse(r,Y3t),m=t.west,h=t.east,u=t.north,R=t.south,V=X3t;V[0].latitude=R,V[0].longitude=m,V[1].latitude=u,V[1].longitude=m,V[2].latitude=u,V[2].longitude=h,V[3].latitude=R,V[3].longitude=h;let F=(m+h)*.5,U=(u+R)*.5;V[4].latitude=R,V[4].longitude=F,V[5].latitude=u,V[5].longitude=F,V[6].latitude=U,V[6].longitude=m,V[7].latitude=U,V[7].longitude=h;let G=Number.POSITIVE_INFINITY,A=Number.NEGATIVE_INFINITY,S=Number.POSITIVE_INFINITY,g=Number.NEGATIVE_INFINITY;for(let Q=0;Q<8;Q++){V[Q].height=n;let J=gt.toCartesian(V[Q],e,Vut);L.multiplyByPoint(d,J,J),J.z=0,G=Math.min(G,J.x),A=Math.max(A,J.x),S=Math.min(S,J.y),g=Math.max(g,J.y)}let C=i;C.x=G,C.y=S,C.z=0,L.multiplyByPoint(r,C,C);let y=o;y.x=A,y.y=S,y.z=0,L.multiplyByPoint(r,y,y),p.subtract(y,C,o);let Y=a;Y.x=G,Y.y=g,Y.z=0,L.multiplyByPoint(r,Y,Y),p.subtract(Y,C,a)}var L3t=new p,M3t=new p,_3t=new Mi;Qp.getPlanarTextureCoordinateAttributes=function(t,e,n,i,o){let a=fut,s=L3t,l=M3t;J3t(t,n,f(o,0),a,s,l);let r={};but(r,e);let d=Mi.fromCartesian(a,_3t);return r.southWest_HIGH=new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:3,normalize:!1,value:p.pack(d.high,[0,0,0])}),r.southWest_LOW=new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:3,normalize:!1,value:p.pack(d.low,[0,0,0])}),r.eastward=new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:3,normalize:!1,value:p.pack(s,[0,0,0])}),r.northward=new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:3,normalize:!1,value:p.pack(l,[0,0,0])}),Fut(t,i,r),r};var D3t=new p;function uut(t,e,n,i){let o=Wut;o.latitude=t,o.longitude=e,o.height=0;let a=gt.toCartesian(o,n,D3t),s=Math.sqrt(a.x*a.x+a.y*a.y),l=k.fastApproximateAtan2(s,a.z),r=k.fastApproximateAtan2(a.x,a.y);return i.x=l,i.y=r,i}var Zut=new K;Qp.getSphericalExtentGeometryInstanceAttributes=function(t,e,n,i){let o=uut(t.south,t.west,n,Zut),a=o.x,s=o.y,l=uut(t.north,t.east,n,Zut),r=l.x,d=l.y,m=0;s>d&&(m=k.PI-s,s=-k.PI,d+=m),a-=k.EPSILON5,s-=k.EPSILON5,r+=k.EPSILON5,d+=k.EPSILON5;let h=1/(d-s),u=1/(r-a),R={sphericalExtents:new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:4,normalize:!1,value:[a,s,u,h]}),longitudeRotation:new Dd({componentDatatype:it.FLOAT,componentsPerAttribute:1,normalize:!1,value:[m]})};return but(R,e),Fut(t,i,R),R};Qp.hasAttributesForTextureCoordinatePlanes=function(t){return c(t.southWest_HIGH)&&c(t.southWest_LOW)&&c(t.northward)&&c(t.eastward)&&c(t.planes2D_HIGH)&&c(t.planes2D_LOW)&&c(t.uMaxVmax)&&c(t.uvMinAndExtents)};Qp.hasAttributesForSphericalExtents=function(t){return c(t.sphericalExtents)&&c(t.longitudeRotation)&&c(t.planes2D_HIGH)&&c(t.planes2D_LOW)&&c(t.uMaxVmax)&&c(t.uvMinAndExtents)};function O3t(t){return Math.max(t.width,t.height)>Qp.MAX_WIDTH_FOR_PLANAR_EXTENTS}Qp.shouldUseSphericalCoordinates=function(t){return O3t(t)};Qp.MAX_WIDTH_FOR_PLANAR_EXTENTS=k.toRadians(1);var Fh=Qp;var yZn=b(W(),1);var SZn=b(W(),1);var H3t={NEVER:pt.NEVER,LESS:pt.LESS,EQUAL:pt.EQUAL,LESS_OR_EQUAL:pt.LEQUAL,GREATER:pt.GREATER,NOT_EQUAL:pt.NOTEQUAL,GREATER_OR_EQUAL:pt.GEQUAL,ALWAYS:pt.ALWAYS},Li=Object.freeze(H3t);var EZn=b(W(),1);var w3t={ZERO:pt.ZERO,KEEP:pt.KEEP,REPLACE:pt.REPLACE,INCREMENT:pt.INCR,DECREMENT:pt.DECR,INVERT:pt.INVERT,INCREMENT_WRAP:pt.INCR_WRAP,DECREMENT_WRAP:pt.DECR_WRAP},je=Object.freeze(w3t);var ow={CESIUM_3D_TILE_MASK:128,SKIP_LOD_MASK:112,SKIP_LOD_BIT_SHIFT:4,CLASSIFICATION_MASK:15};ow.setCesium3DTileBit=function(){return{enabled:!0,frontFunction:Li.ALWAYS,frontOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.REPLACE},backFunction:Li.ALWAYS,backOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.REPLACE},reference:ow.CESIUM_3D_TILE_MASK,mask:ow.CESIUM_3D_TILE_MASK}};var gn=Object.freeze(ow);function _G(t){t=f(t,f.EMPTY_OBJECT);let e=t.geometryInstances;this.geometryInstances=e,this.show=f(t.show,!0),this.classificationType=f(t.classificationType,Ji.BOTH),this.debugShowBoundingVolume=f(t.debugShowBoundingVolume,!1),this.debugShowShadowVolume=f(t.debugShowShadowVolume,!1),this._debugShowShadowVolume=!1,this._extruded=f(t._extruded,!1),this._uniformMap=t._uniformMap,this._sp=void 0,this._spStencil=void 0,this._spPick=void 0,this._spColor=void 0,this._spPick2D=void 0,this._spColor2D=void 0,this._rsStencilDepthPass=void 0,this._rsStencilDepthPass3DTiles=void 0,this._rsColorPass=void 0,this._rsPickPass=void 0,this._commandsIgnoreShow=[],this._ready=!1,this._primitive=void 0,this._pickPrimitive=t._pickPrimitive,this._hasSphericalExtentsAttribute=!1,this._hasPlanarExtentsAttributes=!1,this._hasPerColorAttribute=!1,this.appearance=t.appearance,this._createBoundingVolumeFunction=t._createBoundingVolumeFunction,this._updateAndQueueCommandsFunction=t._updateAndQueueCommandsFunction,this._usePickOffsets=!1,this._primitiveOptions={geometryInstances:void 0,appearance:void 0,vertexCacheOptimize:f(t.vertexCacheOptimize,!1),interleave:f(t.interleave,!1),releaseGeometryInstances:f(t.releaseGeometryInstances,!0),allowPicking:f(t.allowPicking,!0),asynchronous:f(t.asynchronous,!0),compressVertices:f(t.compressVertices,!0),_createBoundingVolumeFunction:void 0,_createRenderStatesFunction:void 0,_createShaderProgramFunction:void 0,_createCommandsFunction:void 0,_updateAndQueueCommandsFunction:void 0,_createPickOffsets:!0}}Object.defineProperties(_G.prototype,{vertexCacheOptimize:{get:function(){return this._primitiveOptions.vertexCacheOptimize}},interleave:{get:function(){return this._primitiveOptions.interleave}},releaseGeometryInstances:{get:function(){return this._primitiveOptions.releaseGeometryInstances}},allowPicking:{get:function(){return this._primitiveOptions.allowPicking}},asynchronous:{get:function(){return this._primitiveOptions.asynchronous}},compressVertices:{get:function(){return this._primitiveOptions.compressVertices}},ready:{get:function(){return this._ready}},_needs2DShader:{get:function(){return this._hasPlanarExtentsAttributes||this._hasSphericalExtentsAttribute}}});_G.isSupported=function(t){return t.context.stencilBuffer};function WE(t,e){let n=e?Li.EQUAL:Li.ALWAYS;return{colorMask:{red:!1,green:!1,blue:!1,alpha:!1},stencilTest:{enabled:t,frontFunction:n,frontOperation:{fail:je.KEEP,zFail:je.DECREMENT_WRAP,zPass:je.KEEP},backFunction:n,backOperation:{fail:je.KEEP,zFail:je.INCREMENT_WRAP,zPass:je.KEEP},reference:gn.CESIUM_3D_TILE_MASK,mask:gn.CESIUM_3D_TILE_MASK},stencilMask:gn.CLASSIFICATION_MASK,depthTest:{enabled:!0,func:_d.LESS_OR_EQUAL},depthMask:!1}}function q7(t){return{stencilTest:{enabled:t,frontFunction:Li.NOT_EQUAL,frontOperation:{fail:je.ZERO,zFail:je.ZERO,zPass:je.ZERO},backFunction:Li.NOT_EQUAL,backOperation:{fail:je.ZERO,zFail:je.ZERO,zPass:je.ZERO},reference:0,mask:gn.CLASSIFICATION_MASK},stencilMask:gn.CLASSIFICATION_MASK,depthTest:{enabled:!1},depthMask:!1,blending:Pn.PRE_MULTIPLIED_ALPHA_BLEND}}var P3t={stencilTest:{enabled:!0,frontFunction:Li.NOT_EQUAL,frontOperation:{fail:je.ZERO,zFail:je.ZERO,zPass:je.ZERO},backFunction:Li.NOT_EQUAL,backOperation:{fail:je.ZERO,zFail:je.ZERO,zPass:je.ZERO},reference:0,mask:gn.CLASSIFICATION_MASK},stencilMask:gn.CLASSIFICATION_MASK,depthTest:{enabled:!1},depthMask:!1};function v3t(t,e,n,i){if(c(t._rsStencilDepthPass))return;let o=!t.debugShowShadowVolume;t._rsStencilDepthPass=he.fromCache(WE(o,!1)),t._rsStencilDepthPass3DTiles=he.fromCache(WE(o,!0)),t._rsColorPass=he.fromCache(q7(o,!1)),t._rsPickPass=he.fromCache(P3t)}function K3t(t,e){if(!t.compressVertices)return e;if(e.search(/in\s+vec3\s+extrudeDirection;/g)!==-1){let n="compressedAttributes",i=`in vec2 ${n};`,o=`vec3 extrudeDirection; `,a=` extrudeDirection = czm_octDecode(${n}, 65535.0); -`,s=e;s=s.replace(/in\s+vec3\s+extrudeDirection;/g,""),s=Ve.replaceMain(s,"czm_non_compressed_main");let l=`void main() +`,s=e;s=s.replace(/in\s+vec3\s+extrudeDirection;/g,""),s=Ze.replaceMain(s,"czm_non_compressed_main");let l=`void main() { ${a} czm_non_compressed_main(); }`;return[i,o,s,l].join(` -`)}}function zKt(t,e){let n=e.context,i=t._primitive,o=P2;o=t._primitive._batchTable.getVertexShaderCallback()(o),o=Wi._appendDistanceDisplayConditionToShader(i,o),o=Wi._modifyShaderPosition(t,o,e.scene3DOnly),o=Wi._updateColorAttribute(i,o);let a=t._hasPlanarExtentsAttributes,s=a||t._hasSphericalExtentsAttribute;t._extruded&&(o=KKt(i,o));let l=t._extruded?"EXTRUDED_GEOMETRY":"",r=new Ve({defines:[l],sources:[o]}),d=new Ve({sources:[Uf]}),m=t._primitive._attributeLocations,h=new Fh(s,a,t.appearance);if(t._spStencil=xn.replaceCache({context:n,shaderProgram:t._spStencil,vertexShaderSource:r,fragmentShaderSource:d,attributeLocations:m}),t._primitive.allowPicking){let u=Ve.createPickVertexShaderSource(o);u=Wi._appendShowToShader(i,u),u=Wi._updatePickColorAttribute(u);let F=h.createPickFragmentShader(!1),U=h.createPickVertexShader([l],u,!1,e.mapProjection);if(t._spPick=xn.replaceCache({context:n,shaderProgram:t._spPick,vertexShaderSource:U,fragmentShaderSource:F,attributeLocations:m}),s){let G=n.shaderCache.getDerivedShaderProgram(t._spPick,"2dPick");if(!c(G)){let A=h.createPickFragmentShader(!0),T=h.createPickVertexShader([l],u,!0,e.mapProjection);G=n.shaderCache.createDerivedShaderProgram(t._spPick,"2dPick",{vertexShaderSource:T,fragmentShaderSource:A,attributeLocations:m})}t._spPick2D=G}}else t._spPick=xn.fromCache({context:n,vertexShaderSource:r,fragmentShaderSource:d,attributeLocations:m});o=Wi._appendShowToShader(i,o),r=new Ve({defines:[l],sources:[o]}),t._sp=xn.replaceCache({context:n,shaderProgram:t._sp,vertexShaderSource:r,fragmentShaderSource:d,attributeLocations:m});let Z=h.createFragmentShader(!1),b=h.createVertexShader([l],o,!1,e.mapProjection);if(t._spColor=xn.replaceCache({context:n,shaderProgram:t._spColor,vertexShaderSource:b,fragmentShaderSource:Z,attributeLocations:m}),s){let u=n.shaderCache.getDerivedShaderProgram(t._spColor,"2dColor");if(!c(u)){let F=h.createFragmentShader(!0),U=h.createVertexShader([l],o,!0,e.mapProjection);u=n.shaderCache.createDerivedShaderProgram(t._spColor,"2dColor",{vertexShaderSource:U,fragmentShaderSource:F,attributeLocations:m})}t._spColor2D=u}}function jKt(t,e){let n=t._primitive,i=n._va.length*2;e.length=i;let o,a,s,l=0,r=n._batchTable.getUniformMapCallback()(t._uniformMap),d=t._needs2DShader;for(o=0;o0&&(r=o[0].attributes,Z=Fh.hasAttributesForSphericalExtents(r),b=Fh.hasAttributesForTextureCoordinatePlanes(r),h=r.color),s=0;s{c(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};_G.prototype.getGeometryInstanceAttributes=function(t){return this._primitive.getGeometryInstanceAttributes(t)};_G.prototype.isDestroyed=function(){return!1};_G.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),this._sp=this._sp&&this._sp.destroy(),this._spPick=this._spPick&&this._spPick.destroy(),this._spColor=this._spColor&&this._spColor.destroy(),this._spPick2D=void 0,this._spColor2D=void 0,At(this)};var fE=_G;var e3t={u_globeMinimumAltitude:function(){return 55e3}};function Sm(t){t=f(t,f.EMPTY_OBJECT);let e=t.appearance,n=t.geometryInstances;if(!c(e)&&c(n)){let o=Array.isArray(n)?n:[n],a=o.length;for(let s=0;s{!this._ready&&c(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};Sm.prototype.getBoundingSphere=function(t){let e=this._boundingSpheresKeys.indexOf(t);if(e!==-1)return this._boundingSpheres[e]};Sm.prototype.getGeometryInstanceAttributes=function(t){return this._primitive.getGeometryInstanceAttributes(t)};Sm.prototype.isDestroyed=function(){return!1};Sm.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),At(this)};Sm._supportsMaterials=function(t){return t.depthTexture};Sm.supportsMaterials=function(t){return Sm._supportsMaterials(t.frameState.context)};var Nc=Sm;var Ebn=R(W(),1);function FE(){Ut.throwInstantiationError()}Object.defineProperties(FE.prototype,{isConstant:{get:Ut.throwInstantiationError},definitionChanged:{get:Ut.throwInstantiationError}});FE.prototype.getType=Ut.throwInstantiationError;FE.prototype.getValue=Ut.throwInstantiationError;FE.prototype.equals=Ut.throwInstantiationError;FE.getValue=function(t,e,n){let i;return c(e)&&(i=e.getType(t),c(i))?((!c(n)||n.type!==i)&&(n=eo.fromType(i)),e.getValue(t,n.uniforms),n):((!c(n)||n.type!==eo.ColorType)&&(n=eo.fromType(eo.ColorType)),v.clone(v.WHITE,n.uniforms.color),n)};var Ua=FE;function DG(t,e,n){this._primitives=e,this._orderedGroundPrimitives=n,this._primitive=void 0,this._outlinePrimitive=void 0,this._geometryUpdater=t,this._options=t._options,this._entity=t._entity,this._material=void 0}DG.prototype._isHidden=function(t,e,n){return!t.isShowing||!t.isAvailable(n)||!et.getValueOrDefault(e.show,n,!0)};DG.prototype._setOptions=Ut.throwInstantiationError;DG.prototype.update=function(t){let e=this._geometryUpdater,n=e._onTerrain,i=this._primitives,o=this._orderedGroundPrimitives;n?o.remove(this._primitive):(i.removeAndDestroy(this._primitive),i.removeAndDestroy(this._outlinePrimitive),this._outlinePrimitive=void 0),this._primitive=void 0;let a=this._entity,s=a[this._geometryUpdater._geometryPropertyName];if(this._setOptions(a,s,t),this._isHidden(a,s,t))return;let l=this._geometryUpdater.shadowsProperty.getValue(t),r=this._options;if(!c(s.fill)||s.fill.getValue(t)){let d=e.fillMaterialProperty,m=d instanceof Cn,h,Z=e._getIsClosed(r);if(m)h=new jn({closed:Z,flat:n&&!e._supportsMaterialsforEntitiesOnTerrain});else{let b=Ua.getValue(t,d,this._material);this._material=b,h=new Fa({material:b,translucent:b.isTranslucent(),closed:Z})}if(n)r.vertexFormat=jn.VERTEX_FORMAT,this._primitive=o.add(new Nc({geometryInstances:this._geometryUpdater.createFillGeometryInstance(t),appearance:h,asynchronous:!1,shadows:l,classificationType:this._geometryUpdater.classificationTypeProperty.getValue(t)}),et.getValueOrUndefined(this._geometryUpdater.zIndex,t));else{r.vertexFormat=h.vertexFormat;let b=this._geometryUpdater.createFillGeometryInstance(t);m&&(h.translucent=b.attributes.color.value[3]!==255),a?.properties?.uniforms&&(h.uniforms=a.properties.uniforms.getValue()()),a?.properties?.vertexShaderSource&&(h._vertexShaderSource=a.properties.vertexShaderSource.getValue()()),a?.properties?.fragmentShaderSource&&(h._fragmentShaderSource=a.properties.fragmentShaderSource.getValue()()),this._primitive=i.add(new Wi({geometryInstances:b,appearance:h,asynchronous:!1,shadows:l}))}}if(!n&&c(s.outline)&&s.outline.getValue(t)){let d=this._geometryUpdater.createOutlineGeometryInstance(t),m=et.getValueOrDefault(s.outlineWidth,t,1);this._outlinePrimitive=i.add(new Wi({geometryInstances:d,appearance:new jn({flat:!0,translucent:d.attributes.color.value[3]!==255,renderState:{lineWidth:e._scene.clampLineWidth(m)}}),asynchronous:!1,shadows:l}))}};DG.prototype.getBoundingSphere=function(t){let e=this._entity,n=this._primitive,i=this._outlinePrimitive,o;return c(n)&&n.show&&n.ready&&(o=n.getGeometryInstanceAttributes(e),c(o)&&c(o.boundingSphere))?(Ft.clone(o.boundingSphere,t),ve.DONE):c(i)&&i.show&&i.ready&&(o=i.getGeometryInstanceAttributes(e),c(o)&&c(o.boundingSphere))?(Ft.clone(o.boundingSphere,t),ve.DONE):c(n)&&!n.ready||c(i)&&!i.ready?ve.PENDING:ve.FAILED};DG.prototype.isDestroyed=function(){return!1};DG.prototype.destroy=function(){let t=this._primitives,e=this._orderedGroundPrimitives;this._geometryUpdater._onTerrain?e.remove(this._primitive):t.removeAndDestroy(this._primitive),t.removeAndDestroy(this._outlinePrimitive),At(this)};var lo=DG;var TGn=R(W(),1);var rGn=R(W(),1);var v0n=R(W(),1);var YRn=R(W(),1);var Obn=R(W(),1),c3t={NONE:0,GEODESIC:1,RHUMB:2},Ln=Object.freeze(c3t);var Kbn=R(W(),1);var gZt=k.EPSILON10;function m3t(t,e,n,i){if(!c(t))return;n=f(n,!1);let o=c(i),a=t.length;if(a<2)return t;let s,l=t[0],r,d,m=0,h=-1;for(s=1;sk.EPSILON12);let E=M*(e*e-n*n)/(n*n),I=1+E*(4096+E*(E*(320-175*E)-768))/16384,B=E*(256+E*(E*(74-47*E)-128))/1024,X=V*V,_=B*J*(V+B*(Q*(2*X-1)-B*V*(4*J*J-3)*(4*X-3)/6)/4),P=n*I*(Y-_),w=Math.atan2(b*y,U-A*C),z=Math.atan2(h*y,U*C-A);t._distance=P,t._startHeading=w,t._endHeading=z,t._uSquared=E}var Z3t=new p,eq=new p;function CZt(t,e,n,i){let o=p.normalize(i.cartographicToCartesian(e,eq),Z3t),a=p.normalize(i.cartographicToCartesian(n,eq),eq);u3t(t,i.maximumRadius,i.minimumRadius,e.longitude,e.latitude,n.longitude,n.latitude),t._start=gt.clone(e,t._start),t._end=gt.clone(n,t._end),t._start.height=0,t._end.height=0,h3t(t)}function ik(t,e,n){let i=f(n,mt.WGS84);this._ellipsoid=i,this._start=new gt,this._end=new gt,this._constants={},this._startHeading=void 0,this._endHeading=void 0,this._distance=void 0,this._uSquared=void 0,c(t)&&c(e)&&CZt(this,t,e,i)}Object.defineProperties(ik.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},surfaceDistance:{get:function(){return this._distance}},start:{get:function(){return this._start}},end:{get:function(){return this._end}},startHeading:{get:function(){return this._startHeading}},endHeading:{get:function(){return this._endHeading}}});ik.prototype.setEndPoints=function(t,e){CZt(this,t,e,this._ellipsoid)};ik.prototype.interpolateUsingFraction=function(t,e){return this.interpolateUsingSurfaceDistance(this._distance*t,e)};ik.prototype.interpolateUsingSurfaceDistance=function(t,e){let n=this._constants,i=n.distanceRatio+t/n.b,o=Math.cos(2*i),a=Math.cos(4*i),s=Math.cos(6*i),l=Math.sin(2*i),r=Math.sin(4*i),d=Math.sin(6*i),m=Math.sin(8*i),h=i*i,Z=i*h,b=n.u8Over256,u=n.u2Over4,F=n.u6Over64,U=n.u4Over16,G=2*Z*b*o/3+i*(1-u+7*U/4-15*F/4+579*b/64-(U-15*F/4+187*b/16)*o-(5*F/4-115*b/16)*a-29*b*s/16)+(u/2-U+71*F/32-85*b/16)*l+(5*U/16-5*F/4+383*b/96)*r-h*((F-11*b/2)*l+5*b*r/2)+(29*F/96-29*b/16)*d+539*b*m/1536,A=Math.asin(Math.sin(G)*n.cosineAlpha),T=Math.atan(n.a/n.b*Math.tan(A));G=G-n.sigma;let g=Math.cos(2*n.sigma+G),C=Math.sin(G),y=Math.cos(G),Y=n.cosineU*y,Q=n.sineU*C,M=Math.atan2(C*n.sineHeading,Y-Q*n.cosineHeading)-EZt(n.f,n.sineAlpha,n.cosineSquaredAlpha,G,C,y,g);return c(e)?(e.longitude=this._start.longitude+M,e.latitude=T,e.height=0,e):new gt(this._start.longitude+M,T,0)};var oZ=ik;var mRn=R(W(),1);function iq(t,e,n){if(t===0)return e*n;let i=t*t,o=i*i,a=o*i,s=a*i,l=s*i,r=l*i,d=n,m=Math.sin(2*d),h=Math.sin(4*d),Z=Math.sin(6*d),b=Math.sin(8*d),u=Math.sin(10*d),F=Math.sin(12*d);return e*((1-i/4-3*o/64-5*a/256-175*s/16384-441*l/65536-4851*r/1048576)*d-(3*i/8+3*o/32+45*a/1024+105*s/4096+2205*l/131072+6237*r/524288)*m+(15*o/256+45*a/1024+525*s/16384+1575*l/65536+155925*r/8388608)*h-(35*a/3072+175*s/12288+3675*l/262144+13475*r/1048576)*Z+(315*s/131072+2205*l/524288+43659*r/8388608)*b-(693*l/1310720+6237*r/5242880)*u+1001*r/8388608*F)}function V3t(t,e,n){let i=t/n;if(e===0)return i;let o=i*i,a=o*i,s=a*i,l=e,r=l*l,d=r*r,m=d*r,h=m*r,Z=h*r,b=Z*r,u=Math.sin(2*i),F=Math.cos(2*i),U=Math.sin(4*i),G=Math.cos(4*i),A=Math.sin(6*i),T=Math.cos(6*i),g=Math.sin(8*i),C=Math.cos(8*i),y=Math.sin(10*i),Y=Math.cos(10*i),Q=Math.sin(12*i);return i+i*r/4+7*i*d/64+15*i*m/256+579*i*h/16384+1515*i*Z/65536+16837*i*b/1048576+(3*i*d/16+45*i*m/256-i*(32*o-561)*h/4096-i*(232*o-1677)*Z/16384+i*(399985-90560*o+512*s)*b/5242880)*F+(21*i*m/256+483*i*h/4096-i*(224*o-1969)*Z/16384-i*(33152*o-112599)*b/1048576)*G+(151*i*h/4096+4681*i*Z/65536+1479*i*b/16384-453*a*b/32768)*T+(1097*i*Z/65536+42783*i*b/1048576)*C+8011*i*b/1048576*Y+(3*r/8+3*d/16+213*m/2048-3*o*m/64+255*h/4096-33*o*h/512+20861*Z/524288-33*o*Z/512+s*Z/1024+28273*b/1048576-471*o*b/8192+9*s*b/4096)*u+(21*d/256+21*m/256+533*h/8192-21*o*h/512+197*Z/4096-315*o*Z/4096+584039*b/16777216-12517*o*b/131072+7*s*b/2048)*U+(151*m/6144+151*h/4096+5019*Z/131072-453*o*Z/16384+26965*b/786432-8607*o*b/131072)*A+(1097*h/131072+1097*Z/65536+225797*b/10485760-1097*o*b/65536)*g+(8011*Z/2621440+8011*b/1048576)*y+293393*b/251658240*Q}function UE(t,e){if(t===0)return Math.log(Math.tan(.5*(k.PI_OVER_TWO+e)));let n=t*Math.sin(e);return Math.log(Math.tan(.5*(k.PI_OVER_TWO+e)))-t/2*Math.log((1+n)/(1-n))}function b3t(t,e,n,i,o){let a=UE(t._ellipticity,n),s=UE(t._ellipticity,o);return Math.atan2(k.negativePiToPi(i-e),s-a)}function R3t(t,e,n,i,o,a,s){let l=t._heading,r=a-i,d=0;if(k.equalsEpsilon(Math.abs(l),k.PI_OVER_TWO,k.EPSILON8))if(e===n)d=e*Math.cos(o)*k.negativePiToPi(r);else{let m=Math.sin(o);d=e*Math.cos(o)*k.negativePiToPi(r)/Math.sqrt(1-t._ellipticitySquared*m*m)}else{let m=iq(t._ellipticity,e,o);d=(iq(t._ellipticity,e,s)-m)/Math.cos(l)}return Math.abs(d)}var W3t=new p,nq=new p;function IZt(t,e,n,i){let o=p.normalize(i.cartographicToCartesian(e,nq),W3t),a=p.normalize(i.cartographicToCartesian(n,nq),nq),s=i.maximumRadius,l=i.minimumRadius,r=s*s,d=l*l;t._ellipticitySquared=(r-d)/r,t._ellipticity=Math.sqrt(t._ellipticitySquared),t._start=gt.clone(e,t._start),t._start.height=0,t._end=gt.clone(n,t._end),t._end.height=0,t._heading=b3t(t,e.longitude,e.latitude,n.longitude,n.latitude),t._distance=R3t(t,i.maximumRadius,i.minimumRadius,e.longitude,e.latitude,n.longitude,n.latitude)}function NZt(t,e,n,i,o,a){if(n===0)return gt.clone(t,a);let s=o*o,l,r,d;if(Math.abs(k.PI_OVER_TWO-Math.abs(e))>k.EPSILON8){let m=iq(o,i,t.latitude),h=n*Math.cos(e),Z=m+h;if(r=V3t(Z,o,i),Math.abs(e)0?l=k.negativePiToPi(t.longitude+d):l=k.negativePiToPi(t.longitude-d)}return c(a)?(a.longitude=l,a.latitude=r,a.height=0,a):new gt(l,r,0)}function BR(t,e,n){let i=f(n,mt.WGS84);this._ellipsoid=i,this._start=new gt,this._end=new gt,this._heading=void 0,this._distance=void 0,this._ellipticity=void 0,this._ellipticitySquared=void 0,c(t)&&c(e)&&IZt(this,t,e,i)}Object.defineProperties(BR.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},surfaceDistance:{get:function(){return this._distance}},start:{get:function(){return this._start}},end:{get:function(){return this._end}},heading:{get:function(){return this._heading}}});BR.fromStartHeadingDistance=function(t,e,n,i,o){let a=f(i,mt.WGS84),s=a.maximumRadius,l=a.minimumRadius,r=s*s,d=l*l,m=Math.sqrt((r-d)/r);e=k.negativePiToPi(e);let h=NZt(t,e,n,a.maximumRadius,m);return!c(o)||c(i)&&!i.equals(o.ellipsoid)?new BR(t,h,a):(o.setEndPoints(t,h),o)};BR.prototype.setEndPoints=function(t,e){IZt(this,t,e,this._ellipsoid)};BR.prototype.interpolateUsingFraction=function(t,e){return this.interpolateUsingSurfaceDistance(t*this._distance,e)};BR.prototype.interpolateUsingSurfaceDistance=function(t,e){return NZt(this._start,this._heading,t,this._ellipsoid.maximumRadius,this._ellipticity,e)};BR.prototype.findIntersectionWithLongitude=function(t,e){let n=this._ellipticity,i=this._heading,o=Math.abs(i),a=this._start;if(t=k.negativePiToPi(t),k.equalsEpsilon(Math.abs(t),Math.PI,k.EPSILON14)&&(t=k.sign(a.longitude)*Math.PI),c(e)||(e=new gt),Math.abs(k.PI_OVER_TWO-o)<=k.EPSILON8)return e.longitude=t,e.latitude=a.latitude,e.height=0,e;if(k.equalsEpsilon(Math.abs(k.PI_OVER_TWO-o),k.PI_OVER_TWO,k.EPSILON8))return k.equalsEpsilon(t,a.longitude,k.EPSILON12)?void 0:(e.longitude=t,e.latitude=k.PI_OVER_TWO*k.sign(k.PI_OVER_TWO-i),e.height=0,e);let s=a.latitude,l=n*Math.sin(s),r=Math.tan(.5*(k.PI_OVER_TWO+s))*Math.exp((t-a.longitude)/Math.tan(i)),d=(1+l)/(1-l),m=a.latitude,h;do{h=m;let Z=n*Math.sin(h),b=(1+Z)/(1-Z);m=2*Math.atan(r*Math.pow(b/d,n/2))-k.PI_OVER_TWO}while(!k.equalsEpsilon(m,h,k.EPSILON12));return e.longitude=t,e.latitude=m,e.height=0,e};BR.prototype.findIntersectionWithLatitude=function(t,e){let n=this._ellipticity,i=this._heading,o=this._start;if(k.equalsEpsilon(Math.abs(i),k.PI_OVER_TWO,k.EPSILON8))return;let a=UE(n,o.latitude),s=UE(n,t),l=Math.tan(i)*(s-a),r=k.negativePiToPi(o.longitude+l);return c(e)?(e.longitude=r,e.latitude=t,e.height=0,e):new gt(r,t,0)};var ud=BR;var mq=[yo,Yo],f3t=mq.length,jZt=Math.cos(k.toRadians(30)),yZt=Math.cos(k.toRadians(150)),qZt=0,$Zt=1e3;function Tf(t){t=f(t,f.EMPTY_OBJECT);let e=t.positions;this.width=f(t.width,1),this._positions=e,this.granularity=f(t.granularity,9999),this.loop=f(t.loop,!1),this.arcType=f(t.arcType,Ln.GEODESIC),this._ellipsoid=mt.WGS84,this._projectionIndex=0,this._workerName="createGroundPolylineGeometry",this._scene3DOnly=!1}Object.defineProperties(Tf.prototype,{packedLength:{get:function(){return 1+this._positions.length*3+1+1+1+mt.packedLength+1+1}}});Tf.setProjectionAndEllipsoid=function(t,e){let n=0;for(let i=0;ijZt||ak.PI_OVER_TWO&&(l=!0,s=p.subtract(a,n,LZt),d=r.cartesianToCartographic(s,JZt)),d.height=0;let m=t.project(d,o);return o=p.subtract(m,i,o),o.z=0,o=p.normalize(o,o),l&&p.negate(o,o),o}var L3t=new p,MZt=new p;function _Zt(t,e,n,i,o,a){let s=p.subtract(e,t,L3t);p.normalize(s,s);let l=n-qZt,r=p.multiplyByScalar(s,l,MZt);p.add(t,r,o);let d=i-$Zt;r=p.multiplyByScalar(s,d,MZt),p.add(e,r,a)}var M3t=new p;function rw(t,e){let n=Kn.getPointDistance(dw,t),i=Kn.getPointDistance(dw,e),o=M3t;k.equalsEpsilon(n,0,k.EPSILON2)?(o=QR(e,t,o),p.multiplyByScalar(o,k.EPSILON2,o),p.add(t,o,t)):k.equalsEpsilon(i,0,k.EPSILON2)&&(o=QR(t,e,o),p.multiplyByScalar(o,k.EPSILON2,o),p.add(e,o,e))}function _3t(t,e){let n=Math.abs(t.longitude),i=Math.abs(e.longitude);if(k.equalsEpsilon(n,k.PI,k.EPSILON11)){let o=k.sign(e.longitude);return t.longitude=o*(n-k.EPSILON11),1}else if(k.equalsEpsilon(i,k.PI,k.EPSILON11)){let o=k.sign(t.longitude);return e.longitude=o*(i-k.EPSILON11),2}return 0}var eVt=new gt,nVt=new gt,DZt=new p,lq=new p,OZt=new p,HZt=new p,D3t=new p,wZt=new p,O3t=[eVt,nVt],H3t=new Gt,w3t=new p,P3t=new p,v3t=new p,K3t=new p,z3t=new p,j3t=new p,rq=new p,dq=new p,q3t=new p,$3t=new p,tzt=new p,PZt=new p,ezt=new p,nzt=new p,izt=new Mi,ozt=new Mi,vZt=new p,azt=new p,KZt=new p,szt=[new Ft,new Ft],iVt=[0,2,1,0,3,2,0,7,3,0,4,7,0,5,4,0,1,5,5,7,4,5,6,7,5,2,6,5,1,2,3,6,2,3,7,6],zZt=iVt.length;function lzt(t,e,n,i,o,a,s){let l,r,d=e._ellipsoid,m=n.length/3-1,h=m*8,Z=h*4,b=m*36,u=h>65535?new Uint32Array(b):new Uint16Array(b),F=new Float64Array(h*3),U=new Float32Array(Z),G=new Float32Array(Z),A=new Float32Array(Z),T=new Float32Array(Z),g=new Float32Array(Z),C,y,Y,Q;s&&(C=new Float32Array(Z),y=new Float32Array(Z),Y=new Float32Array(Z),Q=new Float32Array(h*2));let J=a.length/2,M=0,V=eVt;V.height=0;let E=nVt;E.height=0;let I=DZt,B=lq;if(s)for(r=0,l=1;ljZt?(de=ok(e,V,oe,He,rq),zt=ok(e,E,at,rn,dq)):Ao===1?(zt=ok(e,E,at,rn,dq),de.x=0,de.y=k.sign(V.longitude-Math.abs(E.longitude)),de.z=0):(de=ok(e,V,oe,He,rq),zt.x=0,zt.y=k.sign(V.longitude-E.longitude),zt.z=0)}let ke=p.distance(ie,q),ue=Mi.fromCartesian(qt,izt),We=p.subtract(dt,qt,q3t),un=p.normalize(We,PZt),Ct=p.subtract(ie,qt,$3t);Ct=p.normalize(Ct,Ct);let _t=p.cross(un,Ct,PZt);_t=p.normalize(_t,_t);let Je=p.cross(Ct,oe,ezt);Je=p.normalize(Je,Je);let xe=p.subtract(q,dt,tzt);xe=p.normalize(xe,xe);let oo=p.cross(at,xe,nzt);oo=p.normalize(oo,oo);let ea=ke/_,gs=st/_,is=0,ja,qn,ae,fe=0,ge=0;if(s){is=p.distance(He,rn),ja=Mi.fromCartesian(He,ozt),qn=p.subtract(rn,He,vZt),ae=p.normalize(qn,azt);let Ao=ae.x;ae.x=ae.y,ae.y=-Ao,fe=is/M,ge=Et/M}for(P=0;P<8;P++){let Ao=nt+P*4,Xs=z+P*2,Es=Ao+3,wl=P<4?1:-1,ka=P===2||P===3||P===6||P===7?1:-1;p.pack(ue.high,U,Ao),U[Es]=We.x,p.pack(ue.low,G,Ao),G[Es]=We.y,p.pack(Je,A,Ao),A[Es]=We.z,p.pack(oo,T,Ao),T[Es]=ea*wl,p.pack(_t,g,Ao);let Wa=gs*ka;Wa===0&&ka<0&&(Wa=9),g[Es]=Wa,s&&(C[Ao]=ja.high.x,C[Ao+1]=ja.high.y,C[Ao+2]=ja.low.x,C[Ao+3]=ja.low.y,Y[Ao]=-de.y,Y[Ao+1]=de.x,Y[Ao+2]=zt.y,Y[Ao+3]=-zt.x,y[Ao]=qn.x,y[Ao+1]=qn.y,y[Ao+2]=ae.x,y[Ao+3]=ae.y,Q[Xs]=fe*wl,Wa=ge*ka,Wa===0&&ka<0&&(Wa=9),Q[Xs+1]=Wa)}let Ze=v3t,Ke=K3t,An=w3t,si=P3t,da=Gt.fromCartographicArray(O3t,H3t),_a=uo.getMinimumMaximumHeights(da,d),bl=_a.minimumTerrainHeight,na=_a.maximumTerrainHeight;Qt+=Math.abs(bl),Qt+=Math.abs(na),_Zt(qt,ie,bl,na,Ze,An),_Zt(dt,q,bl,na,Ke,si);let Go=p.multiplyByScalar(_t,k.EPSILON5,KZt);p.add(Ze,Go,Ze),p.add(Ke,Go,Ke),p.add(An,Go,An),p.add(si,Go,si),rw(Ze,Ke),rw(An,si),p.pack(Ze,F,H),p.pack(Ke,F,H+3),p.pack(si,F,H+6),p.pack(An,F,H+9),Go=p.multiplyByScalar(_t,-2*k.EPSILON5,KZt),p.add(Ze,Go,Ze),p.add(Ke,Go,Ke),p.add(An,Go,An),p.add(si,Go,si),rw(Ze,Ke),rw(An,si),p.pack(Ze,F,H+12),p.pack(Ke,F,H+15),p.pack(si,F,H+18),p.pack(An,F,H+21),w+=2,r+=3,z+=16,H+=24,nt+=32,st+=ke,Et+=is}r=0;let Wt=0;for(l=0;l0&&(r=o[0].attributes,u=Fh.hasAttributesForSphericalExtents(r),R=Fh.hasAttributesForTextureCoordinatePlanes(r),h=r.color),s=0;s{c(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};_G.prototype.getGeometryInstanceAttributes=function(t){return this._primitive.getGeometryInstanceAttributes(t)};_G.prototype.isDestroyed=function(){return!1};_G.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),this._sp=this._sp&&this._sp.destroy(),this._spPick=this._spPick&&this._spPick.destroy(),this._spColor=this._spColor&&this._spColor.destroy(),this._spPick2D=void 0,this._spColor2D=void 0,At(this)};var fE=_G;var eKt={u_globeMinimumAltitude:function(){return 55e3}};function Tm(t){t=f(t,f.EMPTY_OBJECT);let e=t.appearance,n=t.geometryInstances;if(!c(e)&&c(n)){let o=Array.isArray(n)?n:[n],a=o.length;for(let s=0;s{!this._ready&&c(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};Tm.prototype.getBoundingSphere=function(t){let e=this._boundingSpheresKeys.indexOf(t);if(e!==-1)return this._boundingSpheres[e]};Tm.prototype.getGeometryInstanceAttributes=function(t){return this._primitive.getGeometryInstanceAttributes(t)};Tm.prototype.isDestroyed=function(){return!1};Tm.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),At(this)};Tm._supportsMaterials=function(t){return t.depthTexture};Tm.supportsMaterials=function(t){return Tm._supportsMaterials(t.frameState.context)};var Nc=Tm;var ERn=b(W(),1);function FE(){Ut.throwInstantiationError()}Object.defineProperties(FE.prototype,{isConstant:{get:Ut.throwInstantiationError},definitionChanged:{get:Ut.throwInstantiationError}});FE.prototype.getType=Ut.throwInstantiationError;FE.prototype.getValue=Ut.throwInstantiationError;FE.prototype.equals=Ut.throwInstantiationError;FE.getValue=function(t,e,n){let i;return c(e)&&(i=e.getType(t),c(i))?((!c(n)||n.type!==i)&&(n=eo.fromType(i)),e.getValue(t,n.uniforms),n):((!c(n)||n.type!==eo.ColorType)&&(n=eo.fromType(eo.ColorType)),v.clone(v.WHITE,n.uniforms.color),n)};var Ua=FE;function DG(t,e,n){this._primitives=e,this._orderedGroundPrimitives=n,this._primitive=void 0,this._outlinePrimitive=void 0,this._geometryUpdater=t,this._options=t._options,this._entity=t._entity,this._material=void 0}DG.prototype._isHidden=function(t,e,n){return!t.isShowing||!t.isAvailable(n)||!et.getValueOrDefault(e.show,n,!0)};DG.prototype._setOptions=Ut.throwInstantiationError;DG.prototype.update=function(t){let e=this._geometryUpdater,n=e._onTerrain,i=this._primitives,o=this._orderedGroundPrimitives;n?o.remove(this._primitive):(i.removeAndDestroy(this._primitive),i.removeAndDestroy(this._outlinePrimitive),this._outlinePrimitive=void 0),this._primitive=void 0;let a=this._entity,s=a[this._geometryUpdater._geometryPropertyName];if(this._setOptions(a,s,t),this._isHidden(a,s,t))return;let l=this._geometryUpdater.shadowsProperty.getValue(t),r=this._options;if(!c(s.fill)||s.fill.getValue(t)){let d=e.fillMaterialProperty,m=d instanceof Cn,h,u=e._getIsClosed(r);if(m)h=new jn({closed:u,flat:n&&!e._supportsMaterialsforEntitiesOnTerrain});else{let R=Ua.getValue(t,d,this._material);this._material=R,h=new Fa({material:R,translucent:R.isTranslucent(),closed:u})}if(n)r.vertexFormat=jn.VERTEX_FORMAT,this._primitive=o.add(new Nc({geometryInstances:this._geometryUpdater.createFillGeometryInstance(t),appearance:h,asynchronous:!1,shadows:l,classificationType:this._geometryUpdater.classificationTypeProperty.getValue(t)}),et.getValueOrUndefined(this._geometryUpdater.zIndex,t));else{r.vertexFormat=h.vertexFormat;let R=this._geometryUpdater.createFillGeometryInstance(t);m&&(h.translucent=R.attributes.color.value[3]!==255),a?.properties?.uniforms&&(h.uniforms=a.properties.uniforms.getValue()()),a?.properties?.vertexShaderSource&&(h._vertexShaderSource=a.properties.vertexShaderSource.getValue()()),a?.properties?.fragmentShaderSource&&(h._fragmentShaderSource=a.properties.fragmentShaderSource.getValue()()),this._primitive=i.add(new Wi({geometryInstances:R,appearance:h,asynchronous:!1,shadows:l}))}}if(!n&&c(s.outline)&&s.outline.getValue(t)){let d=this._geometryUpdater.createOutlineGeometryInstance(t),m=et.getValueOrDefault(s.outlineWidth,t,1);this._outlinePrimitive=i.add(new Wi({geometryInstances:d,appearance:new jn({flat:!0,translucent:d.attributes.color.value[3]!==255,renderState:{lineWidth:e._scene.clampLineWidth(m)}}),asynchronous:!1,shadows:l}))}};DG.prototype.getBoundingSphere=function(t){let e=this._entity,n=this._primitive,i=this._outlinePrimitive,o;return c(n)&&n.show&&n.ready&&(o=n.getGeometryInstanceAttributes(e),c(o)&&c(o.boundingSphere))?(Ft.clone(o.boundingSphere,t),ve.DONE):c(i)&&i.show&&i.ready&&(o=i.getGeometryInstanceAttributes(e),c(o)&&c(o.boundingSphere))?(Ft.clone(o.boundingSphere,t),ve.DONE):c(n)&&!n.ready||c(i)&&!i.ready?ve.PENDING:ve.FAILED};DG.prototype.isDestroyed=function(){return!1};DG.prototype.destroy=function(){let t=this._primitives,e=this._orderedGroundPrimitives;this._geometryUpdater._onTerrain?e.remove(this._primitive):t.removeAndDestroy(this._primitive),t.removeAndDestroy(this._outlinePrimitive),At(this)};var lo=DG;var SGn=b(W(),1);var rGn=b(W(),1);var v0n=b(W(),1);var Ybn=b(W(),1);var ORn=b(W(),1),cKt={NONE:0,GEODESIC:1,RHUMB:2},Ln=Object.freeze(cKt);var KRn=b(W(),1);var gut=k.EPSILON10;function mKt(t,e,n,i){if(!c(t))return;n=f(n,!1);let o=c(i),a=t.length;if(a<2)return t;let s,l=t[0],r,d,m=0,h=-1;for(s=1;sk.EPSILON12);let E=M*(e*e-n*n)/(n*n),I=1+E*(4096+E*(E*(320-175*E)-768))/16384,B=E*(256+E*(E*(74-47*E)-128))/1024,X=Z*Z,_=B*J*(Z+B*(Q*(2*X-1)-B*Z*(4*J*J-3)*(4*X-3)/6)/4),P=n*I*(Y-_),w=Math.atan2(R*y,U-A*C),z=Math.atan2(h*y,U*C-A);t._distance=P,t._startHeading=w,t._endHeading=z,t._uSquared=E}var uKt=new p,eq=new p;function Cut(t,e,n,i){let o=p.normalize(i.cartographicToCartesian(e,eq),uKt),a=p.normalize(i.cartographicToCartesian(n,eq),eq);VKt(t,i.maximumRadius,i.minimumRadius,e.longitude,e.latitude,n.longitude,n.latitude),t._start=gt.clone(e,t._start),t._end=gt.clone(n,t._end),t._start.height=0,t._end.height=0,hKt(t)}function i2(t,e,n){let i=f(n,mt.WGS84);this._ellipsoid=i,this._start=new gt,this._end=new gt,this._constants={},this._startHeading=void 0,this._endHeading=void 0,this._distance=void 0,this._uSquared=void 0,c(t)&&c(e)&&Cut(this,t,e,i)}Object.defineProperties(i2.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},surfaceDistance:{get:function(){return this._distance}},start:{get:function(){return this._start}},end:{get:function(){return this._end}},startHeading:{get:function(){return this._startHeading}},endHeading:{get:function(){return this._endHeading}}});i2.prototype.setEndPoints=function(t,e){Cut(this,t,e,this._ellipsoid)};i2.prototype.interpolateUsingFraction=function(t,e){return this.interpolateUsingSurfaceDistance(this._distance*t,e)};i2.prototype.interpolateUsingSurfaceDistance=function(t,e){let n=this._constants,i=n.distanceRatio+t/n.b,o=Math.cos(2*i),a=Math.cos(4*i),s=Math.cos(6*i),l=Math.sin(2*i),r=Math.sin(4*i),d=Math.sin(6*i),m=Math.sin(8*i),h=i*i,u=i*h,R=n.u8Over256,V=n.u2Over4,F=n.u6Over64,U=n.u4Over16,G=2*u*R*o/3+i*(1-V+7*U/4-15*F/4+579*R/64-(U-15*F/4+187*R/16)*o-(5*F/4-115*R/16)*a-29*R*s/16)+(V/2-U+71*F/32-85*R/16)*l+(5*U/16-5*F/4+383*R/96)*r-h*((F-11*R/2)*l+5*R*r/2)+(29*F/96-29*R/16)*d+539*R*m/1536,A=Math.asin(Math.sin(G)*n.cosineAlpha),S=Math.atan(n.a/n.b*Math.tan(A));G=G-n.sigma;let g=Math.cos(2*n.sigma+G),C=Math.sin(G),y=Math.cos(G),Y=n.cosineU*y,Q=n.sineU*C,M=Math.atan2(C*n.sineHeading,Y-Q*n.cosineHeading)-Eut(n.f,n.sineAlpha,n.cosineSquaredAlpha,G,C,y,g);return c(e)?(e.longitude=this._start.longitude+M,e.latitude=S,e.height=0,e):new gt(this._start.longitude+M,S,0)};var ou=i2;var mbn=b(W(),1);function iq(t,e,n){if(t===0)return e*n;let i=t*t,o=i*i,a=o*i,s=a*i,l=s*i,r=l*i,d=n,m=Math.sin(2*d),h=Math.sin(4*d),u=Math.sin(6*d),R=Math.sin(8*d),V=Math.sin(10*d),F=Math.sin(12*d);return e*((1-i/4-3*o/64-5*a/256-175*s/16384-441*l/65536-4851*r/1048576)*d-(3*i/8+3*o/32+45*a/1024+105*s/4096+2205*l/131072+6237*r/524288)*m+(15*o/256+45*a/1024+525*s/16384+1575*l/65536+155925*r/8388608)*h-(35*a/3072+175*s/12288+3675*l/262144+13475*r/1048576)*u+(315*s/131072+2205*l/524288+43659*r/8388608)*R-(693*l/1310720+6237*r/5242880)*V+1001*r/8388608*F)}function ZKt(t,e,n){let i=t/n;if(e===0)return i;let o=i*i,a=o*i,s=a*i,l=e,r=l*l,d=r*r,m=d*r,h=m*r,u=h*r,R=u*r,V=Math.sin(2*i),F=Math.cos(2*i),U=Math.sin(4*i),G=Math.cos(4*i),A=Math.sin(6*i),S=Math.cos(6*i),g=Math.sin(8*i),C=Math.cos(8*i),y=Math.sin(10*i),Y=Math.cos(10*i),Q=Math.sin(12*i);return i+i*r/4+7*i*d/64+15*i*m/256+579*i*h/16384+1515*i*u/65536+16837*i*R/1048576+(3*i*d/16+45*i*m/256-i*(32*o-561)*h/4096-i*(232*o-1677)*u/16384+i*(399985-90560*o+512*s)*R/5242880)*F+(21*i*m/256+483*i*h/4096-i*(224*o-1969)*u/16384-i*(33152*o-112599)*R/1048576)*G+(151*i*h/4096+4681*i*u/65536+1479*i*R/16384-453*a*R/32768)*S+(1097*i*u/65536+42783*i*R/1048576)*C+8011*i*R/1048576*Y+(3*r/8+3*d/16+213*m/2048-3*o*m/64+255*h/4096-33*o*h/512+20861*u/524288-33*o*u/512+s*u/1024+28273*R/1048576-471*o*R/8192+9*s*R/4096)*V+(21*d/256+21*m/256+533*h/8192-21*o*h/512+197*u/4096-315*o*u/4096+584039*R/16777216-12517*o*R/131072+7*s*R/2048)*U+(151*m/6144+151*h/4096+5019*u/131072-453*o*u/16384+26965*R/786432-8607*o*R/131072)*A+(1097*h/131072+1097*u/65536+225797*R/10485760-1097*o*R/65536)*g+(8011*u/2621440+8011*R/1048576)*y+293393*R/251658240*Q}function UE(t,e){if(t===0)return Math.log(Math.tan(.5*(k.PI_OVER_TWO+e)));let n=t*Math.sin(e);return Math.log(Math.tan(.5*(k.PI_OVER_TWO+e)))-t/2*Math.log((1+n)/(1-n))}function RKt(t,e,n,i,o){let a=UE(t._ellipticity,n),s=UE(t._ellipticity,o);return Math.atan2(k.negativePiToPi(i-e),s-a)}function bKt(t,e,n,i,o,a,s){let l=t._heading,r=a-i,d=0;if(k.equalsEpsilon(Math.abs(l),k.PI_OVER_TWO,k.EPSILON8))if(e===n)d=e*Math.cos(o)*k.negativePiToPi(r);else{let m=Math.sin(o);d=e*Math.cos(o)*k.negativePiToPi(r)/Math.sqrt(1-t._ellipticitySquared*m*m)}else{let m=iq(t._ellipticity,e,o);d=(iq(t._ellipticity,e,s)-m)/Math.cos(l)}return Math.abs(d)}var WKt=new p,nq=new p;function Iut(t,e,n,i){let o=p.normalize(i.cartographicToCartesian(e,nq),WKt),a=p.normalize(i.cartographicToCartesian(n,nq),nq),s=i.maximumRadius,l=i.minimumRadius,r=s*s,d=l*l;t._ellipticitySquared=(r-d)/r,t._ellipticity=Math.sqrt(t._ellipticitySquared),t._start=gt.clone(e,t._start),t._start.height=0,t._end=gt.clone(n,t._end),t._end.height=0,t._heading=RKt(t,e.longitude,e.latitude,n.longitude,n.latitude),t._distance=bKt(t,i.maximumRadius,i.minimumRadius,e.longitude,e.latitude,n.longitude,n.latitude)}function Nut(t,e,n,i,o,a){if(n===0)return gt.clone(t,a);let s=o*o,l,r,d;if(Math.abs(k.PI_OVER_TWO-Math.abs(e))>k.EPSILON8){let m=iq(o,i,t.latitude),h=n*Math.cos(e),u=m+h;if(r=ZKt(u,o,i),Math.abs(e)0?l=k.negativePiToPi(t.longitude+d):l=k.negativePiToPi(t.longitude-d)}return c(a)?(a.longitude=l,a.latitude=r,a.height=0,a):new gt(l,r,0)}function Bb(t,e,n){let i=f(n,mt.WGS84);this._ellipsoid=i,this._start=new gt,this._end=new gt,this._heading=void 0,this._distance=void 0,this._ellipticity=void 0,this._ellipticitySquared=void 0,c(t)&&c(e)&&Iut(this,t,e,i)}Object.defineProperties(Bb.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},surfaceDistance:{get:function(){return this._distance}},start:{get:function(){return this._start}},end:{get:function(){return this._end}},heading:{get:function(){return this._heading}}});Bb.fromStartHeadingDistance=function(t,e,n,i,o){let a=f(i,mt.WGS84),s=a.maximumRadius,l=a.minimumRadius,r=s*s,d=l*l,m=Math.sqrt((r-d)/r);e=k.negativePiToPi(e);let h=Nut(t,e,n,a.maximumRadius,m);return!c(o)||c(i)&&!i.equals(o.ellipsoid)?new Bb(t,h,a):(o.setEndPoints(t,h),o)};Bb.prototype.setEndPoints=function(t,e){Iut(this,t,e,this._ellipsoid)};Bb.prototype.interpolateUsingFraction=function(t,e){return this.interpolateUsingSurfaceDistance(t*this._distance,e)};Bb.prototype.interpolateUsingSurfaceDistance=function(t,e){return Nut(this._start,this._heading,t,this._ellipsoid.maximumRadius,this._ellipticity,e)};Bb.prototype.findIntersectionWithLongitude=function(t,e){let n=this._ellipticity,i=this._heading,o=Math.abs(i),a=this._start;if(t=k.negativePiToPi(t),k.equalsEpsilon(Math.abs(t),Math.PI,k.EPSILON14)&&(t=k.sign(a.longitude)*Math.PI),c(e)||(e=new gt),Math.abs(k.PI_OVER_TWO-o)<=k.EPSILON8)return e.longitude=t,e.latitude=a.latitude,e.height=0,e;if(k.equalsEpsilon(Math.abs(k.PI_OVER_TWO-o),k.PI_OVER_TWO,k.EPSILON8))return k.equalsEpsilon(t,a.longitude,k.EPSILON12)?void 0:(e.longitude=t,e.latitude=k.PI_OVER_TWO*k.sign(k.PI_OVER_TWO-i),e.height=0,e);let s=a.latitude,l=n*Math.sin(s),r=Math.tan(.5*(k.PI_OVER_TWO+s))*Math.exp((t-a.longitude)/Math.tan(i)),d=(1+l)/(1-l),m=a.latitude,h;do{h=m;let u=n*Math.sin(h),R=(1+u)/(1-u);m=2*Math.atan(r*Math.pow(R/d,n/2))-k.PI_OVER_TWO}while(!k.equalsEpsilon(m,h,k.EPSILON12));return e.longitude=t,e.latitude=m,e.height=0,e};Bb.prototype.findIntersectionWithLatitude=function(t,e){let n=this._ellipticity,i=this._heading,o=this._start;if(k.equalsEpsilon(Math.abs(i),k.PI_OVER_TWO,k.EPSILON8))return;let a=UE(n,o.latitude),s=UE(n,t),l=Math.tan(i)*(s-a),r=k.negativePiToPi(o.longitude+l);return c(e)?(e.longitude=r,e.latitude=t,e.height=0,e):new gt(r,t,0)};var Vd=Bb;var mq=[yo,Yo],fKt=mq.length,jut=Math.cos(k.toRadians(30)),yut=Math.cos(k.toRadians(150)),qut=0,$ut=1e3;function Sf(t){t=f(t,f.EMPTY_OBJECT);let e=t.positions;this.width=f(t.width,1),this._positions=e,this.granularity=f(t.granularity,9999),this.loop=f(t.loop,!1),this.arcType=f(t.arcType,Ln.GEODESIC),this._ellipsoid=mt.WGS84,this._projectionIndex=0,this._workerName="createGroundPolylineGeometry",this._scene3DOnly=!1}Object.defineProperties(Sf.prototype,{packedLength:{get:function(){return 1+this._positions.length*3+1+1+1+mt.packedLength+1+1}}});Sf.setProjectionAndEllipsoid=function(t,e){let n=0;for(let i=0;ijut||ak.PI_OVER_TWO&&(l=!0,s=p.subtract(a,n,Lut),d=r.cartesianToCartographic(s,Jut)),d.height=0;let m=t.project(d,o);return o=p.subtract(m,i,o),o.z=0,o=p.normalize(o,o),l&&p.negate(o,o),o}var LKt=new p,Mut=new p;function _ut(t,e,n,i,o,a){let s=p.subtract(e,t,LKt);p.normalize(s,s);let l=n-qut,r=p.multiplyByScalar(s,l,Mut);p.add(t,r,o);let d=i-$ut;r=p.multiplyByScalar(s,d,Mut),p.add(e,r,a)}var MKt=new p;function rw(t,e){let n=Kn.getPointDistance(dw,t),i=Kn.getPointDistance(dw,e),o=MKt;k.equalsEpsilon(n,0,k.EPSILON2)?(o=Qb(e,t,o),p.multiplyByScalar(o,k.EPSILON2,o),p.add(t,o,t)):k.equalsEpsilon(i,0,k.EPSILON2)&&(o=Qb(t,e,o),p.multiplyByScalar(o,k.EPSILON2,o),p.add(e,o,e))}function _Kt(t,e){let n=Math.abs(t.longitude),i=Math.abs(e.longitude);if(k.equalsEpsilon(n,k.PI,k.EPSILON11)){let o=k.sign(e.longitude);return t.longitude=o*(n-k.EPSILON11),1}else if(k.equalsEpsilon(i,k.PI,k.EPSILON11)){let o=k.sign(t.longitude);return e.longitude=o*(i-k.EPSILON11),2}return 0}var eZt=new gt,nZt=new gt,Dut=new p,lq=new p,Out=new p,Hut=new p,DKt=new p,wut=new p,OKt=[eZt,nZt],HKt=new Gt,wKt=new p,PKt=new p,vKt=new p,KKt=new p,zKt=new p,jKt=new p,rq=new p,dq=new p,qKt=new p,$Kt=new p,tzt=new p,Put=new p,ezt=new p,nzt=new p,izt=new Mi,ozt=new Mi,vut=new p,azt=new p,Kut=new p,szt=[new Ft,new Ft],iZt=[0,2,1,0,3,2,0,7,3,0,4,7,0,5,4,0,1,5,5,7,4,5,6,7,5,2,6,5,1,2,3,6,2,3,7,6],zut=iZt.length;function lzt(t,e,n,i,o,a,s){let l,r,d=e._ellipsoid,m=n.length/3-1,h=m*8,u=h*4,R=m*36,V=h>65535?new Uint32Array(R):new Uint16Array(R),F=new Float64Array(h*3),U=new Float32Array(u),G=new Float32Array(u),A=new Float32Array(u),S=new Float32Array(u),g=new Float32Array(u),C,y,Y,Q;s&&(C=new Float32Array(u),y=new Float32Array(u),Y=new Float32Array(u),Q=new Float32Array(h*2));let J=a.length/2,M=0,Z=eZt;Z.height=0;let E=nZt;E.height=0;let I=Dut,B=lq;if(s)for(r=0,l=1;ljut?(de=o2(e,Z,oe,He,rq),zt=o2(e,E,at,rn,dq)):Ao===1?(zt=o2(e,E,at,rn,dq),de.x=0,de.y=k.sign(Z.longitude-Math.abs(E.longitude)),de.z=0):(de=o2(e,Z,oe,He,rq),zt.x=0,zt.y=k.sign(Z.longitude-E.longitude),zt.z=0)}let ke=p.distance(ie,q),Ve=Mi.fromCartesian(qt,izt),We=p.subtract(dt,qt,qKt),Vn=p.normalize(We,Put),Ct=p.subtract(ie,qt,$Kt);Ct=p.normalize(Ct,Ct);let _t=p.cross(Vn,Ct,Put);_t=p.normalize(_t,_t);let Je=p.cross(Ct,oe,ezt);Je=p.normalize(Je,Je);let xe=p.subtract(q,dt,tzt);xe=p.normalize(xe,xe);let oo=p.cross(at,xe,nzt);oo=p.normalize(oo,oo);let ea=ke/_,gs=st/_,is=0,ja,qn,ae,fe=0,ge=0;if(s){is=p.distance(He,rn),ja=Mi.fromCartesian(He,ozt),qn=p.subtract(rn,He,vut),ae=p.normalize(qn,azt);let Ao=ae.x;ae.x=ae.y,ae.y=-Ao,fe=is/M,ge=Et/M}for(P=0;P<8;P++){let Ao=nt+P*4,Xs=z+P*2,Es=Ao+3,wl=P<4?1:-1,ka=P===2||P===3||P===6||P===7?1:-1;p.pack(Ve.high,U,Ao),U[Es]=We.x,p.pack(Ve.low,G,Ao),G[Es]=We.y,p.pack(Je,A,Ao),A[Es]=We.z,p.pack(oo,S,Ao),S[Es]=ea*wl,p.pack(_t,g,Ao);let Wa=gs*ka;Wa===0&&ka<0&&(Wa=9),g[Es]=Wa,s&&(C[Ao]=ja.high.x,C[Ao+1]=ja.high.y,C[Ao+2]=ja.low.x,C[Ao+3]=ja.low.y,Y[Ao]=-de.y,Y[Ao+1]=de.x,Y[Ao+2]=zt.y,Y[Ao+3]=-zt.x,y[Ao]=qn.x,y[Ao+1]=qn.y,y[Ao+2]=ae.x,y[Ao+3]=ae.y,Q[Xs]=fe*wl,Wa=ge*ka,Wa===0&&ka<0&&(Wa=9),Q[Xs+1]=Wa)}let ue=vKt,Ke=KKt,An=wKt,si=PKt,da=Gt.fromCartographicArray(OKt,HKt),_a=Vo.getMinimumMaximumHeights(da,d),Rl=_a.minimumTerrainHeight,na=_a.maximumTerrainHeight;Qt+=Math.abs(Rl),Qt+=Math.abs(na),_ut(qt,ie,Rl,na,ue,An),_ut(dt,q,Rl,na,Ke,si);let Go=p.multiplyByScalar(_t,k.EPSILON5,Kut);p.add(ue,Go,ue),p.add(Ke,Go,Ke),p.add(An,Go,An),p.add(si,Go,si),rw(ue,Ke),rw(An,si),p.pack(ue,F,H),p.pack(Ke,F,H+3),p.pack(si,F,H+6),p.pack(An,F,H+9),Go=p.multiplyByScalar(_t,-2*k.EPSILON5,Kut),p.add(ue,Go,ue),p.add(Ke,Go,Ke),p.add(An,Go,An),p.add(si,Go,si),rw(ue,Ke),rw(An,si),p.pack(ue,F,H+12),p.pack(Ke,F,H+15),p.pack(si,F,H+18),p.pack(An,F,H+21),w+=2,r+=3,z+=16,H+=24,nt+=32,st+=ke,Et+=is}r=0;let Wt=0;for(l=0;l{!this._ready&&c(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};YR.prototype.getGeometryInstanceAttributes=function(t){return this._primitive.getGeometryInstanceAttributes(t)};YR.isSupported=function(t){return t.frameState.context.depthTexture};YR.prototype.isDestroyed=function(){return!1};YR.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),this._sp=this._sp&&this._sp.destroy(),this._sp2D=void 0,this._spMorph=void 0,At(this)};var Gh=YR;var bWn=R(W(),1);var cWn=R(W(),1);var iWn=R(W(),1);var pzt=new K(1,1),uzt=!1,Zzt=v.WHITE;function GE(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._image=void 0,this._imageSubscription=void 0,this._repeat=void 0,this._repeatSubscription=void 0,this._color=void 0,this._colorSubscription=void 0,this._transparent=void 0,this._transparentSubscription=void 0,this.image=t.image,this.repeat=t.repeat,this.color=t.color,this.transparent=t.transparent}Object.defineProperties(GE.prototype,{isConstant:{get:function(){return et.isConstant(this._image)&&et.isConstant(this._repeat)}},definitionChanged:{get:function(){return this._definitionChanged}},image:ft("image"),repeat:ft("repeat"),color:ft("color"),transparent:ft("transparent")});GE.prototype.getType=function(t){return"Image"};GE.prototype.getValue=function(t,e){return c(e)||(e={}),e.image=et.getValueOrUndefined(this._image,t),e.repeat=et.getValueOrClonedDefault(this._repeat,t,pzt,e.repeat),e.color=et.getValueOrClonedDefault(this._color,t,Zzt,e.color),et.getValueOrDefault(this._transparent,t,uzt)&&(e.color.alpha=Math.min(.99,e.color.alpha)),e};GE.prototype.equals=function(t){return this===t||t instanceof GE&&et.equals(this._image,t._image)&&et.equals(this._repeat,t._repeat)&&et.equals(this._color,t._color)&&et.equals(this._transparent,t._transparent)};var Sf=GE;function Vzt(t){if(t instanceof v)return new Cn(t);if(typeof t=="string"||t instanceof te||t instanceof HTMLCanvasElement||t instanceof HTMLVideoElement){let e=new Sf;return e.image=t,e}}function bzt(t,e){return ft(t,e,Vzt)}var la=bzt;function mk(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._dimensions=void 0,this._dimensionsSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(mk.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),dimensions:ft("dimensions"),heightReference:ft("heightReference"),fill:ft("fill"),material:la("material"),outline:ft("outline"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),shadows:ft("shadows"),distanceDisplayCondition:ft("distanceDisplayCondition")});mk.prototype.clone=function(t){return c(t)?(t.show=this.show,t.dimensions=this.dimensions,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new mk(this)};mk.prototype.merge=function(t){this.show=f(this.show,t.show),this.dimensions=f(this.dimensions,t.dimensions),this.heightReference=f(this.heightReference,t.heightReference),this.fill=f(this.fill,t.fill),this.material=f(this.material,t.material),this.outline=f(this.outline,t.outline),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.shadows=f(this.shadows,t.shadows),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition)};var PG=mk;var BWn=R(W(),1);var TWn=R(W(),1);function AE(){Ut.throwInstantiationError()}Object.defineProperties(AE.prototype,{isConstant:{get:Ut.throwInstantiationError},definitionChanged:{get:Ut.throwInstantiationError},referenceFrame:{get:Ut.throwInstantiationError}});AE.prototype.getValue=Ut.throwInstantiationError;AE.prototype.getValueInReferenceFrame=Ut.throwInstantiationError;AE.prototype.equals=Ut.throwInstantiationError;var uq=new ot;AE.convertToReferenceFrame=function(t,e,n,i,o){if(!c(e))return e;if(c(o)||(o=new p),n===i)return p.clone(e,o);let a=Pe.computeIcrfToFixedMatrix(t,uq);if(c(a)||(a=Pe.computeTemeToPseudoFixedMatrix(t,uq)),n===ri.INERTIAL)return ot.multiplyByVector(a,e,o);if(n===ri.FIXED)return ot.multiplyByVector(ot.transpose(a,uq),e,o)};var xR=AE;function vG(t,e){this._definitionChanged=new It,this._value=p.clone(t),this._referenceFrame=f(e,ri.FIXED)}Object.defineProperties(vG.prototype,{isConstant:{get:function(){return!c(this._value)||this._referenceFrame===ri.FIXED}},definitionChanged:{get:function(){return this._definitionChanged}},referenceFrame:{get:function(){return this._referenceFrame}}});vG.prototype.getValue=function(t,e){return this.getValueInReferenceFrame(t,ri.FIXED,e)};vG.prototype.setValue=function(t,e){let n=!1;p.equals(this._value,t)||(n=!0,this._value=p.clone(t)),c(e)&&this._referenceFrame!==e&&(n=!0,this._referenceFrame=e),n&&this._definitionChanged.raiseEvent(this)};vG.prototype.getValueInReferenceFrame=function(t,e,n){return xR.convertToReferenceFrame(t,this._value,this._referenceFrame,e,n)};vG.prototype.equals=function(t){return this===t||t instanceof vG&&p.equals(this._value,t._value)&&this._referenceFrame===t._referenceFrame};var jl=vG;var LWn=R(W(),1);function hk(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._positions=void 0,this._positionsSubscription=void 0,this._width=void 0,this._widthSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._cornerType=void 0,this._cornerTypeSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(hk.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),positions:ft("positions"),width:ft("width"),height:ft("height"),heightReference:ft("heightReference"),extrudedHeight:ft("extrudedHeight"),extrudedHeightReference:ft("extrudedHeightReference"),cornerType:ft("cornerType"),granularity:ft("granularity"),fill:ft("fill"),material:la("material"),outline:ft("outline"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),shadows:ft("shadows"),distanceDisplayCondition:ft("distanceDisplayCondition"),classificationType:ft("classificationType"),zIndex:ft("zIndex")});hk.prototype.clone=function(t){return c(t)?(t.show=this.show,t.positions=this.positions,t.width=this.width,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.cornerType=this.cornerType,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new hk(this)};hk.prototype.merge=function(t){this.show=f(this.show,t.show),this.positions=f(this.positions,t.positions),this.width=f(this.width,t.width),this.height=f(this.height,t.height),this.heightReference=f(this.heightReference,t.heightReference),this.extrudedHeight=f(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=f(this.extrudedHeightReference,t.extrudedHeightReference),this.cornerType=f(this.cornerType,t.cornerType),this.granularity=f(this.granularity,t.granularity),this.fill=f(this.fill,t.fill),this.material=f(this.material,t.material),this.outline=f(this.outline,t.outline),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.shadows=f(this.shadows,t.shadows),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=f(this.classificationType,t.classificationType),this.zIndex=f(this.zIndex,t.zIndex)};var KG=hk;var DWn=R(W(),1);function Rzt(t){return t}function Wzt(t,e){return ft(t,e,Rzt)}var gm=Wzt;var zWn=R(W(),1);function pk(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._length=void 0,this._lengthSubscription=void 0,this._topRadius=void 0,this._topRadiusSubscription=void 0,this._bottomRadius=void 0,this._bottomRadiusSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._numberOfVerticalLines=void 0,this._numberOfVerticalLinesSubscription=void 0,this._slices=void 0,this._slicesSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(pk.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),length:ft("length"),topRadius:ft("topRadius"),bottomRadius:ft("bottomRadius"),heightReference:ft("heightReference"),fill:ft("fill"),material:la("material"),outline:ft("outline"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),numberOfVerticalLines:ft("numberOfVerticalLines"),slices:ft("slices"),shadows:ft("shadows"),distanceDisplayCondition:ft("distanceDisplayCondition")});pk.prototype.clone=function(t){return c(t)?(t.show=this.show,t.length=this.length,t.topRadius=this.topRadius,t.bottomRadius=this.bottomRadius,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.numberOfVerticalLines=this.numberOfVerticalLines,t.slices=this.slices,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new pk(this)};pk.prototype.merge=function(t){this.show=f(this.show,t.show),this.length=f(this.length,t.length),this.topRadius=f(this.topRadius,t.topRadius),this.bottomRadius=f(this.bottomRadius,t.bottomRadius),this.heightReference=f(this.heightReference,t.heightReference),this.fill=f(this.fill,t.fill),this.material=f(this.material,t.material),this.outline=f(this.outline,t.outline),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.numberOfVerticalLines=f(this.numberOfVerticalLines,t.numberOfVerticalLines),this.slices=f(this.slices,t.slices),this.shadows=f(this.shadows,t.shadows),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition)};var zG=pk;var ifn=R(W(),1);function uk(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._semiMajorAxis=void 0,this._semiMajorAxisSubscription=void 0,this._semiMinorAxis=void 0,this._semiMinorAxisSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._stRotation=void 0,this._stRotationSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._numberOfVerticalLines=void 0,this._numberOfVerticalLinesSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(uk.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),semiMajorAxis:ft("semiMajorAxis"),semiMinorAxis:ft("semiMinorAxis"),height:ft("height"),heightReference:ft("heightReference"),extrudedHeight:ft("extrudedHeight"),extrudedHeightReference:ft("extrudedHeightReference"),rotation:ft("rotation"),stRotation:ft("stRotation"),granularity:ft("granularity"),fill:ft("fill"),material:la("material"),outline:ft("outline"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),numberOfVerticalLines:ft("numberOfVerticalLines"),shadows:ft("shadows"),distanceDisplayCondition:ft("distanceDisplayCondition"),classificationType:ft("classificationType"),zIndex:ft("zIndex")});uk.prototype.clone=function(t){return c(t)?(t.show=this.show,t.semiMajorAxis=this.semiMajorAxis,t.semiMinorAxis=this.semiMinorAxis,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.rotation=this.rotation,t.stRotation=this.stRotation,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.numberOfVerticalLines=this.numberOfVerticalLines,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new uk(this)};uk.prototype.merge=function(t){this.show=f(this.show,t.show),this.semiMajorAxis=f(this.semiMajorAxis,t.semiMajorAxis),this.semiMinorAxis=f(this.semiMinorAxis,t.semiMinorAxis),this.height=f(this.height,t.height),this.heightReference=f(this.heightReference,t.heightReference),this.extrudedHeight=f(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=f(this.extrudedHeightReference,t.extrudedHeightReference),this.rotation=f(this.rotation,t.rotation),this.stRotation=f(this.stRotation,t.stRotation),this.granularity=f(this.granularity,t.granularity),this.fill=f(this.fill,t.fill),this.material=f(this.material,t.material),this.outline=f(this.outline,t.outline),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.numberOfVerticalLines=f(this.numberOfVerticalLines,t.numberOfVerticalLines),this.shadows=f(this.shadows,t.shadows),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=f(this.classificationType,t.classificationType),this.zIndex=f(this.zIndex,t.zIndex)};var jG=uk;var cfn=R(W(),1);function Zk(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._radii=void 0,this._radiiSubscription=void 0,this._innerRadii=void 0,this._innerRadiiSubscription=void 0,this._minimumClock=void 0,this._minimumClockSubscription=void 0,this._maximumClock=void 0,this._maximumClockSubscription=void 0,this._minimumCone=void 0,this._minimumConeSubscription=void 0,this._maximumCone=void 0,this._maximumConeSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._stackPartitions=void 0,this._stackPartitionsSubscription=void 0,this._slicePartitions=void 0,this._slicePartitionsSubscription=void 0,this._subdivisions=void 0,this._subdivisionsSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(Zk.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),radii:ft("radii"),innerRadii:ft("innerRadii"),minimumClock:ft("minimumClock"),maximumClock:ft("maximumClock"),minimumCone:ft("minimumCone"),maximumCone:ft("maximumCone"),heightReference:ft("heightReference"),fill:ft("fill"),material:la("material"),outline:ft("outline"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),stackPartitions:ft("stackPartitions"),slicePartitions:ft("slicePartitions"),subdivisions:ft("subdivisions"),shadows:ft("shadows"),distanceDisplayCondition:ft("distanceDisplayCondition")});Zk.prototype.clone=function(t){return c(t)?(t.show=this.show,t.radii=this.radii,t.innerRadii=this.innerRadii,t.minimumClock=this.minimumClock,t.maximumClock=this.maximumClock,t.minimumCone=this.minimumCone,t.maximumCone=this.maximumCone,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.stackPartitions=this.stackPartitions,t.slicePartitions=this.slicePartitions,t.subdivisions=this.subdivisions,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new Zk(this)};Zk.prototype.merge=function(t){this.show=f(this.show,t.show),this.radii=f(this.radii,t.radii),this.innerRadii=f(this.innerRadii,t.innerRadii),this.minimumClock=f(this.minimumClock,t.minimumClock),this.maximumClock=f(this.maximumClock,t.maximumClock),this.minimumCone=f(this.minimumCone,t.minimumCone),this.maximumCone=f(this.maximumCone,t.maximumCone),this.heightReference=f(this.heightReference,t.heightReference),this.fill=f(this.fill,t.fill),this.material=f(this.material,t.material),this.outline=f(this.outline,t.outline),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.stackPartitions=f(this.stackPartitions,t.stackPartitions),this.slicePartitions=f(this.slicePartitions,t.slicePartitions),this.subdivisions=f(this.subdivisions,t.subdivisions),this.shadows=f(this.shadows,t.shadows),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition)};var qG=Zk;var Vfn=R(W(),1);function Vk(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._text=void 0,this._textSubscription=void 0,this._font=void 0,this._fontSubscription=void 0,this._style=void 0,this._styleSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this._showBackground=void 0,this._showBackgroundSubscription=void 0,this._backgroundColor=void 0,this._backgroundColorSubscription=void 0,this._backgroundPadding=void 0,this._backgroundPaddingSubscription=void 0,this._pixelOffset=void 0,this._pixelOffsetSubscription=void 0,this._eyeOffset=void 0,this._eyeOffsetSubscription=void 0,this._horizontalOrigin=void 0,this._horizontalOriginSubscription=void 0,this._verticalOrigin=void 0,this._verticalOriginSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fillColor=void 0,this._fillColorSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._translucencyByDistance=void 0,this._translucencyByDistanceSubscription=void 0,this._pixelOffsetScaleByDistance=void 0,this._pixelOffsetScaleByDistanceSubscription=void 0,this._scaleByDistance=void 0,this._scaleByDistanceSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._disableDepthTestDistance=void 0,this._disableDepthTestDistanceSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(Vk.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),text:ft("text"),font:ft("font"),style:ft("style"),scale:ft("scale"),showBackground:ft("showBackground"),backgroundColor:ft("backgroundColor"),backgroundPadding:ft("backgroundPadding"),pixelOffset:ft("pixelOffset"),eyeOffset:ft("eyeOffset"),horizontalOrigin:ft("horizontalOrigin"),verticalOrigin:ft("verticalOrigin"),heightReference:ft("heightReference"),fillColor:ft("fillColor"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),translucencyByDistance:ft("translucencyByDistance"),pixelOffsetScaleByDistance:ft("pixelOffsetScaleByDistance"),scaleByDistance:ft("scaleByDistance"),distanceDisplayCondition:ft("distanceDisplayCondition"),disableDepthTestDistance:ft("disableDepthTestDistance")});Vk.prototype.clone=function(t){return c(t)?(t.show=this.show,t.text=this.text,t.font=this.font,t.style=this.style,t.scale=this.scale,t.showBackground=this.showBackground,t.backgroundColor=this.backgroundColor,t.backgroundPadding=this.backgroundPadding,t.pixelOffset=this.pixelOffset,t.eyeOffset=this.eyeOffset,t.horizontalOrigin=this.horizontalOrigin,t.verticalOrigin=this.verticalOrigin,t.heightReference=this.heightReference,t.fillColor=this.fillColor,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.translucencyByDistance=this.translucencyByDistance,t.pixelOffsetScaleByDistance=this.pixelOffsetScaleByDistance,t.scaleByDistance=this.scaleByDistance,t.distanceDisplayCondition=this.distanceDisplayCondition,t.disableDepthTestDistance=this.disableDepthTestDistance,t):new Vk(this)};Vk.prototype.merge=function(t){this.show=f(this.show,t.show),this.text=f(this.text,t.text),this.font=f(this.font,t.font),this.style=f(this.style,t.style),this.scale=f(this.scale,t.scale),this.showBackground=f(this.showBackground,t.showBackground),this.backgroundColor=f(this.backgroundColor,t.backgroundColor),this.backgroundPadding=f(this.backgroundPadding,t.backgroundPadding),this.pixelOffset=f(this.pixelOffset,t.pixelOffset),this.eyeOffset=f(this.eyeOffset,t.eyeOffset),this.horizontalOrigin=f(this.horizontalOrigin,t.horizontalOrigin),this.verticalOrigin=f(this.verticalOrigin,t.verticalOrigin),this.heightReference=f(this.heightReference,t.heightReference),this.fillColor=f(this.fillColor,t.fillColor),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.translucencyByDistance=f(this.translucencyByDistance,t.translucencyByDistance),this.pixelOffsetScaleByDistance=f(this.pixelOffsetScaleByDistance,t.pixelOffsetScaleByDistance),this.scaleByDistance=f(this.scaleByDistance,t.scaleByDistance),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition),this.disableDepthTestDistance=f(this.disableDepthTestDistance,t.disableDepthTestDistance)};var aZ=Vk;var wfn=R(W(),1);var Ifn=R(W(),1);var Ufn=R(W(),1);var fzt=new p(1,1,1),Fzt=p.ZERO,Uzt=wt.IDENTITY;function sVt(t,e,n){this.translation=p.clone(f(t,Fzt)),this.rotation=wt.clone(f(e,Uzt)),this.scale=p.clone(f(n,fzt))}sVt.prototype.equals=function(t){return this===t||c(t)&&p.equals(this.translation,t.translation)&&wt.equals(this.rotation,t.rotation)&&p.equals(this.scale,t.scale)};var gf=sVt;var Zq=new gf;function bk(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._translation=void 0,this._translationSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this.translation=t.translation,this.rotation=t.rotation,this.scale=t.scale}Object.defineProperties(bk.prototype,{isConstant:{get:function(){return et.isConstant(this._translation)&&et.isConstant(this._rotation)&&et.isConstant(this._scale)}},definitionChanged:{get:function(){return this._definitionChanged}},translation:ft("translation"),rotation:ft("rotation"),scale:ft("scale")});bk.prototype.getValue=function(t,e){return c(e)||(e=new gf),e.translation=et.getValueOrClonedDefault(this._translation,t,Zq.translation,e.translation),e.rotation=et.getValueOrClonedDefault(this._rotation,t,Zq.rotation,e.rotation),e.scale=et.getValueOrClonedDefault(this._scale,t,Zq.scale,e.scale),e};bk.prototype.equals=function(t){return this===t||t instanceof bk&&et.equals(this._translation,t._translation)&&et.equals(this._rotation,t._rotation)&&et.equals(this._scale,t._scale)};var $G=bk;var Xfn=R(W(),1);function XR(t,e){this._propertyNames=[],this._definitionChanged=new It,c(t)&&this.merge(t,e)}Object.defineProperties(XR.prototype,{propertyNames:{get:function(){return this._propertyNames}},isConstant:{get:function(){let t=this._propertyNames;for(let e=0,n=t.length;e=e;i--)t[i]=t[l--]}for(i=0;i=0||c(h)&&rt.compare(m,h)>=0));){for(bq[Z++]=m,a=a+1,s=0;s0&&(Rq.length=b,dVt(n,d,Rq),bq.length=Z,dVt(e,r,bq))}else{for(s=0;so)return;if(this._backwardExtrapolationType===Ah.HOLD)return a.unpack(s,0,e)}if(l>=i){l=i-1;let g=n[l];if(o=this._forwardExtrapolationDuration,this._forwardExtrapolationType===Ah.NONE||o!==0&&rt.secondsDifference(t,g)>o)return;if(this._forwardExtrapolationType===Ah.HOLD)return l=i-1,a.unpack(s,l*a.packedLength,e)}let r=this._xTable,d=this._yTable,m=this._interpolationAlgorithm,h=this._packedInterpolationLength,Z=this._inputOrder;if(this._updateTableLength){this._updateTableLength=!1;let g=Math.min(m.getRequiredDataPoints(this._interpolationDegree,Z),i);g!==this._numberOfPoints&&(this._numberOfPoints=g,r.length=g,d.length=g*h)}let b=this._numberOfPoints-1;if(b<1)return;let u=0,F=i-1;if(F-u+1>=b+1){let g=l-(b/2|0)-1;gF&&(C=F,g=C-b,g{this._terrainHeight=l.height,this.definitionChanged.raiseEvent()};this._removeCallbackFunc=t.updateHeight(o,s,this._heightReference)};gE.prototype.getValue=function(t,e){let n=et.getValueOrDefault(this._heightReference,t,Ge.NONE),i=et.getValueOrDefault(this._extrudedHeightReference,t,Ge.NONE);if(n===Ge.NONE&&!dE(i))return this._position=p.clone(p.ZERO,this._position),p.clone(p.ZERO,e);if(this._positionProperty.isConstant)return p.multiplyByScalar(this._normal,this._terrainHeight,e);let o=this._scene,a=this._positionProperty.getValue(t,uVt);if(!c(a)||p.equals(a,p.ZERO)||!c(o.globe))return p.clone(p.ZERO,e);if(p.equalsEpsilon(this._position,a,k.EPSILON10))return p.multiplyByScalar(this._normal,this._terrainHeight,e);this._position=p.clone(a,this._position),this._updateClamping();let s=o.globe.ellipsoid.geodeticSurfaceNormal(a,this._normal);return p.multiplyByScalar(s,this._terrainHeight,e)};gE.prototype.isDestroyed=function(){return!1};gE.prototype.destroy=function(){return c(this._removeEventListener)&&this._removeEventListener(),c(this._removeModeListener)&&this._removeModeListener(),c(this._removeCallbackFunc)&&this._removeCallbackFunc(),At(this)};var iA=gE;function Dzt(t,e,n,i){if(ro.prototype._onEntityPropertyChanged.call(this,t,e,n,i),this._observedPropertyNames.indexOf(e)===-1)return;let o=this._entity[this._geometryPropertyName];if(!c(o))return;c(this._terrainOffsetProperty)&&(this._terrainOffsetProperty.destroy(),this._terrainOffsetProperty=void 0);let a=o.heightReference;if(c(a)){let s=new Th(this._computeCenter.bind(this),!this._dynamic);this._terrainOffsetProperty=new iA(this._scene,s,a)}}var DR=Dzt;var ZVt=p.ZERO,VVt=new p,Ozt=new p,bVt=new v;function Hzt(t){this.id=t,this.vertexFormat=void 0,this.dimensions=void 0,this.offsetAttribute=void 0}function Sh(t,e){ro.call(this,{entity:t,scene:e,geometryOptions:new Hzt(t),geometryPropertyName:"box",observedPropertyNames:["availability","position","orientation","box"]}),this._onEntityPropertyChanged(t,"box",t.box,void 0)}c(Object.create)&&(Sh.prototype=Object.create(ro.prototype),Sh.prototype.constructor=Sh);Object.defineProperties(Sh.prototype,{terrainOffsetProperty:{get:function(){return this._terrainOffsetProperty}}});Sh.prototype.createFillGeometryInstance=function(t){let e=this._entity,n=e.isAvailable(t),i=new pi(n&&e.isShowing&&this._showProperty.getValue(t)&&this._fillProperty.getValue(t)),o=this._distanceDisplayConditionProperty.getValue(t),a=Xi.fromDistanceDisplayCondition(o),s={show:i,distanceDisplayCondition:a,color:void 0,offset:void 0};if(this._materialProperty instanceof Cn){let l;c(this._materialProperty.color)&&(this._materialProperty.color.isConstant||n)&&(l=this._materialProperty.color.getValue(t,bVt)),c(l)||(l=v.WHITE),s.color=En.fromColor(l)}return c(this._options.offsetAttribute)&&(s.offset=aa.fromCartesian3(et.getValueOrDefault(this._terrainOffsetProperty,t,ZVt,VVt))),new $e({id:e,geometry:Am.fromDimensions(this._options),modelMatrix:e.computeModelMatrixForHeightReference(t,e.box.heightReference,this._options.dimensions.z*.5,this._scene.mapProjection.ellipsoid),attributes:s})};Sh.prototype.createOutlineGeometryInstance=function(t){let e=this._entity,n=e.isAvailable(t),i=et.getValueOrDefault(this._outlineColorProperty,t,v.BLACK,bVt),o=this._distanceDisplayConditionProperty.getValue(t),a={show:new pi(n&&e.isShowing&&this._showProperty.getValue(t)&&this._showOutlineProperty.getValue(t)),color:En.fromColor(i),distanceDisplayCondition:Xi.fromDistanceDisplayCondition(o),offset:void 0};return c(this._options.offsetAttribute)&&(a.offset=aa.fromCartesian3(et.getValueOrDefault(this._terrainOffsetProperty,t,ZVt,VVt))),new $e({id:e,geometry:tZ.fromDimensions(this._options),modelMatrix:e.computeModelMatrixForHeightReference(t,e.box.heightReference,this._options.dimensions.z*.5,this._scene.mapProjection.ellipsoid),attributes:a})};Sh.prototype._computeCenter=function(t,e){return et.getValueOrUndefined(this._entity.position,t,e)};Sh.prototype._isHidden=function(t,e){return!c(e.dimensions)||!c(t.position)||ro.prototype._isHidden.call(this,t,e)};Sh.prototype._isDynamic=function(t,e){return!t.position.isConstant||!et.isConstant(t.orientation)||!e.dimensions.isConstant||!et.isConstant(e.outlineWidth)};Sh.prototype._setStaticOptions=function(t,e){let n=et.getValueOrDefault(e.heightReference,Re.MINIMUM_VALUE,Ge.NONE),i=this._options;i.vertexFormat=this._materialProperty instanceof Cn?jn.VERTEX_FORMAT:Fa.MaterialSupport.TEXTURED.vertexFormat,i.dimensions=e.dimensions.getValue(Re.MINIMUM_VALUE,i.dimensions),i.offsetAttribute=n!==Ge.NONE?zn.ALL:void 0};Sh.prototype._onEntityPropertyChanged=DR;Sh.DynamicGeometryUpdater=EE;function EE(t,e,n){lo.call(this,t,e,n)}c(Object.create)&&(EE.prototype=Object.create(lo.prototype),EE.prototype.constructor=EE);EE.prototype._isHidden=function(t,e,n){let i=et.getValueOrUndefined(t.position,n,Ozt),o=this._options.dimensions;return!c(i)||!c(o)||lo.prototype._isHidden.call(this,t,e,n)};EE.prototype._setOptions=function(t,e,n){let i=et.getValueOrDefault(e.heightReference,n,Ge.NONE),o=this._options;o.dimensions=et.getValueOrUndefined(e.dimensions,n,o.dimensions),o.offsetAttribute=i!==Ge.NONE?zn.ALL:void 0};var Ck=Sh;var jri=R(W(),1);var Lri=R(W(),1);var RAn=R(W(),1),WVt=R(RVt(),1);var wzt=0,Aq={};function wV(t,e){let n,i=t;c(Aq[i])?n=Aq[i]:(n=wzt++,Aq[i]=n),e=f(e,!1),this._id=n,this._html=t,this._showOnScreen=e,this._element=void 0}Object.defineProperties(wV.prototype,{html:{get:function(){return this._html}},id:{get:function(){return this._id}},showOnScreen:{get:function(){return this._showOnScreen},set:function(t){this._showOnScreen=t}},element:{get:function(){if(!c(this._element)){let t=WVt.default.sanitize(this._html),e=document.createElement("div");e._creditId=this._id,e.style.display="inline",e.innerHTML=t;let n=e.querySelectorAll("a");for(let i=0;i{!this._ready&&c(this._primitive)&&this._primitive.ready&&(this._ready=!0,this.releaseGeometryInstances&&(this.geometryInstances=void 0))})};Yb.prototype.getGeometryInstanceAttributes=function(t){return this._primitive.getGeometryInstanceAttributes(t)};Yb.isSupported=function(t){return t.frameState.context.depthTexture};Yb.prototype.isDestroyed=function(){return!1};Yb.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),this._sp=this._sp&&this._sp.destroy(),this._sp2D=void 0,this._spMorph=void 0,At(this)};var Gh=Yb;var RWn=b(W(),1);var cWn=b(W(),1);var iWn=b(W(),1);var pzt=new K(1,1),Vzt=!1,uzt=v.WHITE;function GE(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._image=void 0,this._imageSubscription=void 0,this._repeat=void 0,this._repeatSubscription=void 0,this._color=void 0,this._colorSubscription=void 0,this._transparent=void 0,this._transparentSubscription=void 0,this.image=t.image,this.repeat=t.repeat,this.color=t.color,this.transparent=t.transparent}Object.defineProperties(GE.prototype,{isConstant:{get:function(){return et.isConstant(this._image)&&et.isConstant(this._repeat)}},definitionChanged:{get:function(){return this._definitionChanged}},image:ft("image"),repeat:ft("repeat"),color:ft("color"),transparent:ft("transparent")});GE.prototype.getType=function(t){return"Image"};GE.prototype.getValue=function(t,e){return c(e)||(e={}),e.image=et.getValueOrUndefined(this._image,t),e.repeat=et.getValueOrClonedDefault(this._repeat,t,pzt,e.repeat),e.color=et.getValueOrClonedDefault(this._color,t,uzt,e.color),et.getValueOrDefault(this._transparent,t,Vzt)&&(e.color.alpha=Math.min(.99,e.color.alpha)),e};GE.prototype.equals=function(t){return this===t||t instanceof GE&&et.equals(this._image,t._image)&&et.equals(this._repeat,t._repeat)&&et.equals(this._color,t._color)&&et.equals(this._transparent,t._transparent)};var Tf=GE;function Zzt(t){if(t instanceof v)return new Cn(t);if(typeof t=="string"||t instanceof te||t instanceof HTMLCanvasElement||t instanceof HTMLVideoElement){let e=new Tf;return e.image=t,e}}function Rzt(t,e){return ft(t,e,Zzt)}var la=Rzt;function m2(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._dimensions=void 0,this._dimensionsSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(m2.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),dimensions:ft("dimensions"),heightReference:ft("heightReference"),fill:ft("fill"),material:la("material"),outline:ft("outline"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),shadows:ft("shadows"),distanceDisplayCondition:ft("distanceDisplayCondition")});m2.prototype.clone=function(t){return c(t)?(t.show=this.show,t.dimensions=this.dimensions,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new m2(this)};m2.prototype.merge=function(t){this.show=f(this.show,t.show),this.dimensions=f(this.dimensions,t.dimensions),this.heightReference=f(this.heightReference,t.heightReference),this.fill=f(this.fill,t.fill),this.material=f(this.material,t.material),this.outline=f(this.outline,t.outline),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.shadows=f(this.shadows,t.shadows),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition)};var PG=m2;var BWn=b(W(),1);var SWn=b(W(),1);function AE(){Ut.throwInstantiationError()}Object.defineProperties(AE.prototype,{isConstant:{get:Ut.throwInstantiationError},definitionChanged:{get:Ut.throwInstantiationError},referenceFrame:{get:Ut.throwInstantiationError}});AE.prototype.getValue=Ut.throwInstantiationError;AE.prototype.getValueInReferenceFrame=Ut.throwInstantiationError;AE.prototype.equals=Ut.throwInstantiationError;var Vq=new ot;AE.convertToReferenceFrame=function(t,e,n,i,o){if(!c(e))return e;if(c(o)||(o=new p),n===i)return p.clone(e,o);let a=Pe.computeIcrfToFixedMatrix(t,Vq);if(c(a)||(a=Pe.computeTemeToPseudoFixedMatrix(t,Vq)),n===ri.INERTIAL)return ot.multiplyByVector(a,e,o);if(n===ri.FIXED)return ot.multiplyByVector(ot.transpose(a,Vq),e,o)};var xb=AE;function vG(t,e){this._definitionChanged=new It,this._value=p.clone(t),this._referenceFrame=f(e,ri.FIXED)}Object.defineProperties(vG.prototype,{isConstant:{get:function(){return!c(this._value)||this._referenceFrame===ri.FIXED}},definitionChanged:{get:function(){return this._definitionChanged}},referenceFrame:{get:function(){return this._referenceFrame}}});vG.prototype.getValue=function(t,e){return this.getValueInReferenceFrame(t,ri.FIXED,e)};vG.prototype.setValue=function(t,e){let n=!1;p.equals(this._value,t)||(n=!0,this._value=p.clone(t)),c(e)&&this._referenceFrame!==e&&(n=!0,this._referenceFrame=e),n&&this._definitionChanged.raiseEvent(this)};vG.prototype.getValueInReferenceFrame=function(t,e,n){return xb.convertToReferenceFrame(t,this._value,this._referenceFrame,e,n)};vG.prototype.equals=function(t){return this===t||t instanceof vG&&p.equals(this._value,t._value)&&this._referenceFrame===t._referenceFrame};var jl=vG;var LWn=b(W(),1);function h2(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._positions=void 0,this._positionsSubscription=void 0,this._width=void 0,this._widthSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._cornerType=void 0,this._cornerTypeSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(h2.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),positions:ft("positions"),width:ft("width"),height:ft("height"),heightReference:ft("heightReference"),extrudedHeight:ft("extrudedHeight"),extrudedHeightReference:ft("extrudedHeightReference"),cornerType:ft("cornerType"),granularity:ft("granularity"),fill:ft("fill"),material:la("material"),outline:ft("outline"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),shadows:ft("shadows"),distanceDisplayCondition:ft("distanceDisplayCondition"),classificationType:ft("classificationType"),zIndex:ft("zIndex")});h2.prototype.clone=function(t){return c(t)?(t.show=this.show,t.positions=this.positions,t.width=this.width,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.cornerType=this.cornerType,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new h2(this)};h2.prototype.merge=function(t){this.show=f(this.show,t.show),this.positions=f(this.positions,t.positions),this.width=f(this.width,t.width),this.height=f(this.height,t.height),this.heightReference=f(this.heightReference,t.heightReference),this.extrudedHeight=f(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=f(this.extrudedHeightReference,t.extrudedHeightReference),this.cornerType=f(this.cornerType,t.cornerType),this.granularity=f(this.granularity,t.granularity),this.fill=f(this.fill,t.fill),this.material=f(this.material,t.material),this.outline=f(this.outline,t.outline),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.shadows=f(this.shadows,t.shadows),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=f(this.classificationType,t.classificationType),this.zIndex=f(this.zIndex,t.zIndex)};var KG=h2;var DWn=b(W(),1);function bzt(t){return t}function Wzt(t,e){return ft(t,e,bzt)}var gm=Wzt;var zWn=b(W(),1);function p2(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._length=void 0,this._lengthSubscription=void 0,this._topRadius=void 0,this._topRadiusSubscription=void 0,this._bottomRadius=void 0,this._bottomRadiusSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._numberOfVerticalLines=void 0,this._numberOfVerticalLinesSubscription=void 0,this._slices=void 0,this._slicesSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(p2.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),length:ft("length"),topRadius:ft("topRadius"),bottomRadius:ft("bottomRadius"),heightReference:ft("heightReference"),fill:ft("fill"),material:la("material"),outline:ft("outline"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),numberOfVerticalLines:ft("numberOfVerticalLines"),slices:ft("slices"),shadows:ft("shadows"),distanceDisplayCondition:ft("distanceDisplayCondition")});p2.prototype.clone=function(t){return c(t)?(t.show=this.show,t.length=this.length,t.topRadius=this.topRadius,t.bottomRadius=this.bottomRadius,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.numberOfVerticalLines=this.numberOfVerticalLines,t.slices=this.slices,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new p2(this)};p2.prototype.merge=function(t){this.show=f(this.show,t.show),this.length=f(this.length,t.length),this.topRadius=f(this.topRadius,t.topRadius),this.bottomRadius=f(this.bottomRadius,t.bottomRadius),this.heightReference=f(this.heightReference,t.heightReference),this.fill=f(this.fill,t.fill),this.material=f(this.material,t.material),this.outline=f(this.outline,t.outline),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.numberOfVerticalLines=f(this.numberOfVerticalLines,t.numberOfVerticalLines),this.slices=f(this.slices,t.slices),this.shadows=f(this.shadows,t.shadows),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition)};var zG=p2;var ifn=b(W(),1);function V2(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._semiMajorAxis=void 0,this._semiMajorAxisSubscription=void 0,this._semiMinorAxis=void 0,this._semiMinorAxisSubscription=void 0,this._height=void 0,this._heightSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._extrudedHeight=void 0,this._extrudedHeightSubscription=void 0,this._extrudedHeightReference=void 0,this._extrudedHeightReferenceSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._stRotation=void 0,this._stRotationSubscription=void 0,this._granularity=void 0,this._granularitySubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._numberOfVerticalLines=void 0,this._numberOfVerticalLinesSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._classificationType=void 0,this._classificationTypeSubscription=void 0,this._zIndex=void 0,this._zIndexSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(V2.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),semiMajorAxis:ft("semiMajorAxis"),semiMinorAxis:ft("semiMinorAxis"),height:ft("height"),heightReference:ft("heightReference"),extrudedHeight:ft("extrudedHeight"),extrudedHeightReference:ft("extrudedHeightReference"),rotation:ft("rotation"),stRotation:ft("stRotation"),granularity:ft("granularity"),fill:ft("fill"),material:la("material"),outline:ft("outline"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),numberOfVerticalLines:ft("numberOfVerticalLines"),shadows:ft("shadows"),distanceDisplayCondition:ft("distanceDisplayCondition"),classificationType:ft("classificationType"),zIndex:ft("zIndex")});V2.prototype.clone=function(t){return c(t)?(t.show=this.show,t.semiMajorAxis=this.semiMajorAxis,t.semiMinorAxis=this.semiMinorAxis,t.height=this.height,t.heightReference=this.heightReference,t.extrudedHeight=this.extrudedHeight,t.extrudedHeightReference=this.extrudedHeightReference,t.rotation=this.rotation,t.stRotation=this.stRotation,t.granularity=this.granularity,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.numberOfVerticalLines=this.numberOfVerticalLines,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t.classificationType=this.classificationType,t.zIndex=this.zIndex,t):new V2(this)};V2.prototype.merge=function(t){this.show=f(this.show,t.show),this.semiMajorAxis=f(this.semiMajorAxis,t.semiMajorAxis),this.semiMinorAxis=f(this.semiMinorAxis,t.semiMinorAxis),this.height=f(this.height,t.height),this.heightReference=f(this.heightReference,t.heightReference),this.extrudedHeight=f(this.extrudedHeight,t.extrudedHeight),this.extrudedHeightReference=f(this.extrudedHeightReference,t.extrudedHeightReference),this.rotation=f(this.rotation,t.rotation),this.stRotation=f(this.stRotation,t.stRotation),this.granularity=f(this.granularity,t.granularity),this.fill=f(this.fill,t.fill),this.material=f(this.material,t.material),this.outline=f(this.outline,t.outline),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.numberOfVerticalLines=f(this.numberOfVerticalLines,t.numberOfVerticalLines),this.shadows=f(this.shadows,t.shadows),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition),this.classificationType=f(this.classificationType,t.classificationType),this.zIndex=f(this.zIndex,t.zIndex)};var jG=V2;var cfn=b(W(),1);function u2(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._radii=void 0,this._radiiSubscription=void 0,this._innerRadii=void 0,this._innerRadiiSubscription=void 0,this._minimumClock=void 0,this._minimumClockSubscription=void 0,this._maximumClock=void 0,this._maximumClockSubscription=void 0,this._minimumCone=void 0,this._minimumConeSubscription=void 0,this._maximumCone=void 0,this._maximumConeSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fill=void 0,this._fillSubscription=void 0,this._material=void 0,this._materialSubscription=void 0,this._outline=void 0,this._outlineSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._stackPartitions=void 0,this._stackPartitionsSubscription=void 0,this._slicePartitions=void 0,this._slicePartitionsSubscription=void 0,this._subdivisions=void 0,this._subdivisionsSubscription=void 0,this._shadows=void 0,this._shadowsSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(u2.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),radii:ft("radii"),innerRadii:ft("innerRadii"),minimumClock:ft("minimumClock"),maximumClock:ft("maximumClock"),minimumCone:ft("minimumCone"),maximumCone:ft("maximumCone"),heightReference:ft("heightReference"),fill:ft("fill"),material:la("material"),outline:ft("outline"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),stackPartitions:ft("stackPartitions"),slicePartitions:ft("slicePartitions"),subdivisions:ft("subdivisions"),shadows:ft("shadows"),distanceDisplayCondition:ft("distanceDisplayCondition")});u2.prototype.clone=function(t){return c(t)?(t.show=this.show,t.radii=this.radii,t.innerRadii=this.innerRadii,t.minimumClock=this.minimumClock,t.maximumClock=this.maximumClock,t.minimumCone=this.minimumCone,t.maximumCone=this.maximumCone,t.heightReference=this.heightReference,t.fill=this.fill,t.material=this.material,t.outline=this.outline,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.stackPartitions=this.stackPartitions,t.slicePartitions=this.slicePartitions,t.subdivisions=this.subdivisions,t.shadows=this.shadows,t.distanceDisplayCondition=this.distanceDisplayCondition,t):new u2(this)};u2.prototype.merge=function(t){this.show=f(this.show,t.show),this.radii=f(this.radii,t.radii),this.innerRadii=f(this.innerRadii,t.innerRadii),this.minimumClock=f(this.minimumClock,t.minimumClock),this.maximumClock=f(this.maximumClock,t.maximumClock),this.minimumCone=f(this.minimumCone,t.minimumCone),this.maximumCone=f(this.maximumCone,t.maximumCone),this.heightReference=f(this.heightReference,t.heightReference),this.fill=f(this.fill,t.fill),this.material=f(this.material,t.material),this.outline=f(this.outline,t.outline),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.stackPartitions=f(this.stackPartitions,t.stackPartitions),this.slicePartitions=f(this.slicePartitions,t.slicePartitions),this.subdivisions=f(this.subdivisions,t.subdivisions),this.shadows=f(this.shadows,t.shadows),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition)};var qG=u2;var Zfn=b(W(),1);function Z2(t){this._definitionChanged=new It,this._show=void 0,this._showSubscription=void 0,this._text=void 0,this._textSubscription=void 0,this._font=void 0,this._fontSubscription=void 0,this._style=void 0,this._styleSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this._showBackground=void 0,this._showBackgroundSubscription=void 0,this._backgroundColor=void 0,this._backgroundColorSubscription=void 0,this._backgroundPadding=void 0,this._backgroundPaddingSubscription=void 0,this._pixelOffset=void 0,this._pixelOffsetSubscription=void 0,this._eyeOffset=void 0,this._eyeOffsetSubscription=void 0,this._horizontalOrigin=void 0,this._horizontalOriginSubscription=void 0,this._verticalOrigin=void 0,this._verticalOriginSubscription=void 0,this._heightReference=void 0,this._heightReferenceSubscription=void 0,this._fillColor=void 0,this._fillColorSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this._translucencyByDistance=void 0,this._translucencyByDistanceSubscription=void 0,this._pixelOffsetScaleByDistance=void 0,this._pixelOffsetScaleByDistanceSubscription=void 0,this._scaleByDistance=void 0,this._scaleByDistanceSubscription=void 0,this._distanceDisplayCondition=void 0,this._distanceDisplayConditionSubscription=void 0,this._disableDepthTestDistance=void 0,this._disableDepthTestDistanceSubscription=void 0,this.merge(f(t,f.EMPTY_OBJECT))}Object.defineProperties(Z2.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},show:ft("show"),text:ft("text"),font:ft("font"),style:ft("style"),scale:ft("scale"),showBackground:ft("showBackground"),backgroundColor:ft("backgroundColor"),backgroundPadding:ft("backgroundPadding"),pixelOffset:ft("pixelOffset"),eyeOffset:ft("eyeOffset"),horizontalOrigin:ft("horizontalOrigin"),verticalOrigin:ft("verticalOrigin"),heightReference:ft("heightReference"),fillColor:ft("fillColor"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth"),translucencyByDistance:ft("translucencyByDistance"),pixelOffsetScaleByDistance:ft("pixelOffsetScaleByDistance"),scaleByDistance:ft("scaleByDistance"),distanceDisplayCondition:ft("distanceDisplayCondition"),disableDepthTestDistance:ft("disableDepthTestDistance")});Z2.prototype.clone=function(t){return c(t)?(t.show=this.show,t.text=this.text,t.font=this.font,t.style=this.style,t.scale=this.scale,t.showBackground=this.showBackground,t.backgroundColor=this.backgroundColor,t.backgroundPadding=this.backgroundPadding,t.pixelOffset=this.pixelOffset,t.eyeOffset=this.eyeOffset,t.horizontalOrigin=this.horizontalOrigin,t.verticalOrigin=this.verticalOrigin,t.heightReference=this.heightReference,t.fillColor=this.fillColor,t.outlineColor=this.outlineColor,t.outlineWidth=this.outlineWidth,t.translucencyByDistance=this.translucencyByDistance,t.pixelOffsetScaleByDistance=this.pixelOffsetScaleByDistance,t.scaleByDistance=this.scaleByDistance,t.distanceDisplayCondition=this.distanceDisplayCondition,t.disableDepthTestDistance=this.disableDepthTestDistance,t):new Z2(this)};Z2.prototype.merge=function(t){this.show=f(this.show,t.show),this.text=f(this.text,t.text),this.font=f(this.font,t.font),this.style=f(this.style,t.style),this.scale=f(this.scale,t.scale),this.showBackground=f(this.showBackground,t.showBackground),this.backgroundColor=f(this.backgroundColor,t.backgroundColor),this.backgroundPadding=f(this.backgroundPadding,t.backgroundPadding),this.pixelOffset=f(this.pixelOffset,t.pixelOffset),this.eyeOffset=f(this.eyeOffset,t.eyeOffset),this.horizontalOrigin=f(this.horizontalOrigin,t.horizontalOrigin),this.verticalOrigin=f(this.verticalOrigin,t.verticalOrigin),this.heightReference=f(this.heightReference,t.heightReference),this.fillColor=f(this.fillColor,t.fillColor),this.outlineColor=f(this.outlineColor,t.outlineColor),this.outlineWidth=f(this.outlineWidth,t.outlineWidth),this.translucencyByDistance=f(this.translucencyByDistance,t.translucencyByDistance),this.pixelOffsetScaleByDistance=f(this.pixelOffsetScaleByDistance,t.pixelOffsetScaleByDistance),this.scaleByDistance=f(this.scaleByDistance,t.scaleByDistance),this.distanceDisplayCondition=f(this.distanceDisplayCondition,t.distanceDisplayCondition),this.disableDepthTestDistance=f(this.disableDepthTestDistance,t.disableDepthTestDistance)};var au=Z2;var wfn=b(W(),1);var Ifn=b(W(),1);var Ufn=b(W(),1);var fzt=new p(1,1,1),Fzt=p.ZERO,Uzt=wt.IDENTITY;function sZt(t,e,n){this.translation=p.clone(f(t,Fzt)),this.rotation=wt.clone(f(e,Uzt)),this.scale=p.clone(f(n,fzt))}sZt.prototype.equals=function(t){return this===t||c(t)&&p.equals(this.translation,t.translation)&&wt.equals(this.rotation,t.rotation)&&p.equals(this.scale,t.scale)};var gf=sZt;var uq=new gf;function R2(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._translation=void 0,this._translationSubscription=void 0,this._rotation=void 0,this._rotationSubscription=void 0,this._scale=void 0,this._scaleSubscription=void 0,this.translation=t.translation,this.rotation=t.rotation,this.scale=t.scale}Object.defineProperties(R2.prototype,{isConstant:{get:function(){return et.isConstant(this._translation)&&et.isConstant(this._rotation)&&et.isConstant(this._scale)}},definitionChanged:{get:function(){return this._definitionChanged}},translation:ft("translation"),rotation:ft("rotation"),scale:ft("scale")});R2.prototype.getValue=function(t,e){return c(e)||(e=new gf),e.translation=et.getValueOrClonedDefault(this._translation,t,uq.translation,e.translation),e.rotation=et.getValueOrClonedDefault(this._rotation,t,uq.rotation,e.rotation),e.scale=et.getValueOrClonedDefault(this._scale,t,uq.scale,e.scale),e};R2.prototype.equals=function(t){return this===t||t instanceof R2&&et.equals(this._translation,t._translation)&&et.equals(this._rotation,t._rotation)&&et.equals(this._scale,t._scale)};var $G=R2;var Xfn=b(W(),1);function Xb(t,e){this._propertyNames=[],this._definitionChanged=new It,c(t)&&this.merge(t,e)}Object.defineProperties(Xb.prototype,{propertyNames:{get:function(){return this._propertyNames}},isConstant:{get:function(){let t=this._propertyNames;for(let e=0,n=t.length;e=e;i--)t[i]=t[l--]}for(i=0;i=0||c(h)&&rt.compare(m,h)>=0));){for(Rq[u++]=m,a=a+1,s=0;s0&&(bq.length=R,dZt(n,d,bq),Rq.length=u,dZt(e,r,Rq))}else{for(s=0;so)return;if(this._backwardExtrapolationType===Ah.HOLD)return a.unpack(s,0,e)}if(l>=i){l=i-1;let g=n[l];if(o=this._forwardExtrapolationDuration,this._forwardExtrapolationType===Ah.NONE||o!==0&&rt.secondsDifference(t,g)>o)return;if(this._forwardExtrapolationType===Ah.HOLD)return l=i-1,a.unpack(s,l*a.packedLength,e)}let r=this._xTable,d=this._yTable,m=this._interpolationAlgorithm,h=this._packedInterpolationLength,u=this._inputOrder;if(this._updateTableLength){this._updateTableLength=!1;let g=Math.min(m.getRequiredDataPoints(this._interpolationDegree,u),i);g!==this._numberOfPoints&&(this._numberOfPoints=g,r.length=g,d.length=g*h)}let R=this._numberOfPoints-1;if(R<1)return;let V=0,F=i-1;if(F-V+1>=R+1){let g=l-(R/2|0)-1;gF&&(C=F,g=C-R,g{this._terrainHeight=l.height,this.definitionChanged.raiseEvent()};this._removeCallbackFunc=t.updateHeight(o,s,this._heightReference)};gE.prototype.getValue=function(t,e){let n=et.getValueOrDefault(this._heightReference,t,Ge.NONE),i=et.getValueOrDefault(this._extrudedHeightReference,t,Ge.NONE);if(n===Ge.NONE&&!dE(i))return this._position=p.clone(p.ZERO,this._position),p.clone(p.ZERO,e);if(this._positionProperty.isConstant)return p.multiplyByScalar(this._normal,this._terrainHeight,e);let o=this._scene,a=this._positionProperty.getValue(t,VZt);if(!c(a)||p.equals(a,p.ZERO)||!c(o.globe))return p.clone(p.ZERO,e);if(p.equalsEpsilon(this._position,a,k.EPSILON10))return p.multiplyByScalar(this._normal,this._terrainHeight,e);this._position=p.clone(a,this._position),this._updateClamping();let s=o.globe.ellipsoid.geodeticSurfaceNormal(a,this._normal);return p.multiplyByScalar(s,this._terrainHeight,e)};gE.prototype.isDestroyed=function(){return!1};gE.prototype.destroy=function(){return c(this._removeEventListener)&&this._removeEventListener(),c(this._removeModeListener)&&this._removeModeListener(),c(this._removeCallbackFunc)&&this._removeCallbackFunc(),At(this)};var iA=gE;function Dzt(t,e,n,i){if(ro.prototype._onEntityPropertyChanged.call(this,t,e,n,i),this._observedPropertyNames.indexOf(e)===-1)return;let o=this._entity[this._geometryPropertyName];if(!c(o))return;c(this._terrainOffsetProperty)&&(this._terrainOffsetProperty.destroy(),this._terrainOffsetProperty=void 0);let a=o.heightReference;if(c(a)){let s=new Sh(this._computeCenter.bind(this),!this._dynamic);this._terrainOffsetProperty=new iA(this._scene,s,a)}}var Db=Dzt;var uZt=p.ZERO,ZZt=new p,Ozt=new p,RZt=new v;function Hzt(t){this.id=t,this.vertexFormat=void 0,this.dimensions=void 0,this.offsetAttribute=void 0}function Th(t,e){ro.call(this,{entity:t,scene:e,geometryOptions:new Hzt(t),geometryPropertyName:"box",observedPropertyNames:["availability","position","orientation","box"]}),this._onEntityPropertyChanged(t,"box",t.box,void 0)}c(Object.create)&&(Th.prototype=Object.create(ro.prototype),Th.prototype.constructor=Th);Object.defineProperties(Th.prototype,{terrainOffsetProperty:{get:function(){return this._terrainOffsetProperty}}});Th.prototype.createFillGeometryInstance=function(t){let e=this._entity,n=e.isAvailable(t),i=new pi(n&&e.isShowing&&this._showProperty.getValue(t)&&this._fillProperty.getValue(t)),o=this._distanceDisplayConditionProperty.getValue(t),a=Xi.fromDistanceDisplayCondition(o),s={show:i,distanceDisplayCondition:a,color:void 0,offset:void 0};if(this._materialProperty instanceof Cn){let l;c(this._materialProperty.color)&&(this._materialProperty.color.isConstant||n)&&(l=this._materialProperty.color.getValue(t,RZt)),c(l)||(l=v.WHITE),s.color=En.fromColor(l)}return c(this._options.offsetAttribute)&&(s.offset=aa.fromCartesian3(et.getValueOrDefault(this._terrainOffsetProperty,t,uZt,ZZt))),new $e({id:e,geometry:Am.fromDimensions(this._options),modelMatrix:e.computeModelMatrixForHeightReference(t,e.box.heightReference,this._options.dimensions.z*.5,this._scene.mapProjection.ellipsoid),attributes:s})};Th.prototype.createOutlineGeometryInstance=function(t){let e=this._entity,n=e.isAvailable(t),i=et.getValueOrDefault(this._outlineColorProperty,t,v.BLACK,RZt),o=this._distanceDisplayConditionProperty.getValue(t),a={show:new pi(n&&e.isShowing&&this._showProperty.getValue(t)&&this._showOutlineProperty.getValue(t)),color:En.fromColor(i),distanceDisplayCondition:Xi.fromDistanceDisplayCondition(o),offset:void 0};return c(this._options.offsetAttribute)&&(a.offset=aa.fromCartesian3(et.getValueOrDefault(this._terrainOffsetProperty,t,uZt,ZZt))),new $e({id:e,geometry:tu.fromDimensions(this._options),modelMatrix:e.computeModelMatrixForHeightReference(t,e.box.heightReference,this._options.dimensions.z*.5,this._scene.mapProjection.ellipsoid),attributes:a})};Th.prototype._computeCenter=function(t,e){return et.getValueOrUndefined(this._entity.position,t,e)};Th.prototype._isHidden=function(t,e){return!c(e.dimensions)||!c(t.position)||ro.prototype._isHidden.call(this,t,e)};Th.prototype._isDynamic=function(t,e){return!t.position.isConstant||!et.isConstant(t.orientation)||!e.dimensions.isConstant||!et.isConstant(e.outlineWidth)};Th.prototype._setStaticOptions=function(t,e){let n=et.getValueOrDefault(e.heightReference,be.MINIMUM_VALUE,Ge.NONE),i=this._options;i.vertexFormat=this._materialProperty instanceof Cn?jn.VERTEX_FORMAT:Fa.MaterialSupport.TEXTURED.vertexFormat,i.dimensions=e.dimensions.getValue(be.MINIMUM_VALUE,i.dimensions),i.offsetAttribute=n!==Ge.NONE?zn.ALL:void 0};Th.prototype._onEntityPropertyChanged=Db;Th.DynamicGeometryUpdater=EE;function EE(t,e,n){lo.call(this,t,e,n)}c(Object.create)&&(EE.prototype=Object.create(lo.prototype),EE.prototype.constructor=EE);EE.prototype._isHidden=function(t,e,n){let i=et.getValueOrUndefined(t.position,n,Ozt),o=this._options.dimensions;return!c(i)||!c(o)||lo.prototype._isHidden.call(this,t,e,n)};EE.prototype._setOptions=function(t,e,n){let i=et.getValueOrDefault(e.heightReference,n,Ge.NONE),o=this._options;o.dimensions=et.getValueOrUndefined(e.dimensions,n,o.dimensions),o.offsetAttribute=i!==Ge.NONE?zn.ALL:void 0};var C2=Th;var jri=b(W(),1);var Lri=b(W(),1);var bAn=b(W(),1),WZt=b(bZt(),1);var wzt=0,Aq={};function wZ(t,e){let n,i=t;c(Aq[i])?n=Aq[i]:(n=wzt++,Aq[i]=n),e=f(e,!1),this._id=n,this._html=t,this._showOnScreen=e,this._element=void 0}Object.defineProperties(wZ.prototype,{html:{get:function(){return this._html}},id:{get:function(){return this._id}},showOnScreen:{get:function(){return this._showOnScreen},set:function(t){this._showOnScreen=t}},element:{get:function(){if(!c(this._element)){let t=WZt.default.sanitize(this._html),e=document.createElement("div");e._creditId=this._id,e.style.display="inline",e.innerHTML=t;let n=e.querySelectorAll("a");for(let i=0;i0||this._imageBasedLightingFactor.y>0}},shouldRegenerateShaders:{get:function(){return this._shouldRegenerateShaders}},useDefaultSphericalHarmonics:{get:function(){return this._useDefaultSphericalHarmonics}},useSphericalHarmonicCoefficients:{get:function(){return c(this._sphericalHarmonicCoefficients)||this._useDefaultSphericalHarmonics}},specularEnvironmentMapAtlas:{get:function(){return this._specularEnvironmentMapAtlas}},useDefaultSpecularMaps:{get:function(){return this._useDefaultSpecularMaps}},useSpecularEnvironmentMaps:{get:function(){return c(this._specularEnvironmentMapAtlas)&&this._specularEnvironmentMapAtlas.ready||this._useDefaultSpecularMaps}}});function ejt(t,e){if(dZ.isSupported(e)){if(t._specularEnvironmentMapAtlas=t._specularEnvironmentMapAtlas&&t._specularEnvironmentMapAtlas.destroy(),c(t._specularEnvironmentMaps)){let n=new dZ(t._specularEnvironmentMaps);t._specularEnvironmentMapAtlas=n,t._removeErrorListener=n.errorEvent.addEventListener(i=>{console.error(`Error loading specularEnvironmentMaps: ${i}`)})}t._shouldRegenerateShaders=!0}}Bk.prototype.update=function(t){if(t.frameNumber===this._previousFrameNumber)return;this._previousFrameNumber=t.frameNumber;let e=t.context;t.brdfLutGenerator.update(t),this._shouldRegenerateShaders=!1;let n=this._imageBasedLightingFactor,i=this._previousImageBasedLightingFactor;K.equals(n,i)||(this._shouldRegenerateShaders=n.x>0&&i.x===0||n.x===0&&i.x>0,this._shouldRegenerateShaders=this._shouldRegenerateShaders||n.y>0&&i.y===0||n.y===0&&i.y>0,this._previousImageBasedLightingFactor=K.clone(this._imageBasedLightingFactor,this._previousImageBasedLightingFactor)),this._luminanceAtZenith!==this._previousLuminanceAtZenith&&(this._shouldRegenerateShaders=this._shouldRegenerateShaders||c(this._luminanceAtZenith)!==c(this._previousLuminanceAtZenith),this._previousLuminanceAtZenith=this._luminanceAtZenith),this._previousSphericalHarmonicCoefficients!==this._sphericalHarmonicCoefficients&&(this._shouldRegenerateShaders=this._shouldRegenerateShaders||c(this._previousSphericalHarmonicCoefficients)!==c(this._sphericalHarmonicCoefficients),this._previousSphericalHarmonicCoefficients=this._sphericalHarmonicCoefficients),this._shouldRegenerateShaders=this._shouldRegenerateShaders||this._previousSpecularEnvironmentMapLoaded!==this._specularEnvironmentMapLoaded,this._previousSpecularEnvironmentMapLoaded=this._specularEnvironmentMapLoaded,this._specularEnvironmentMapAtlasDirty&&(ejt(this,e),this._specularEnvironmentMapAtlasDirty=!1),c(this._specularEnvironmentMapAtlas)&&(this._specularEnvironmentMapAtlas.update(t),this._specularEnvironmentMapAtlas.ready&&(this._specularEnvironmentMapLoaded=!0));let o=!c(this._specularEnvironmentMapAtlas)&&c(t.specularEnvironmentMaps)&&!this._useDefaultSpecularMaps,a=!c(t.specularEnvironmentMaps)&&this._useDefaultSpecularMaps,s=!c(this._sphericalHarmonicCoefficients)&&c(t.sphericalHarmonicCoefficients)&&!this._useDefaultSphericalHarmonics,l=!c(t.sphericalHarmonicCoefficients)&&this._useDefaultSphericalHarmonics;this._shouldRegenerateShaders=this._shouldRegenerateShaders||o||a||s||l,this._useDefaultSpecularMaps=!c(this._specularEnvironmentMapAtlas)&&c(t.specularEnvironmentMaps),this._useDefaultSphericalHarmonics=!c(this._sphericalHarmonicCoefficients)&&c(t.sphericalHarmonicCoefficients)};Bk.prototype.isDestroyed=function(){return!1};Bk.prototype.destroy=function(){return this._specularEnvironmentMapAtlas=this._specularEnvironmentMapAtlas&&this._specularEnvironmentMapAtlas.destroy(),this._removeErrorListener=this._removeErrorListener&&this._removeErrorListener(),At(this)};var aA=Bk;var hTn=R(W(),1),gq=R(uh(),1);var oTn=R(W(),1);var Sq,TVt="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiJjM2I5YWEyNS02NzRiLTRmOTEtYWZhNi1jNzlhZTI5Yjc3YWYiLCJpZCI6MjU5LCJpYXQiOjE3MTE1NTQ2Njd9.dawdakmPEfdAKpH2-Cv-IDOlVHwicZ1Mgk7ZzI775hQ",hw={};hw.defaultAccessToken=TVt;hw.defaultServer=new te({url:"https://api.cesium.com/"});hw.getDefaultTokenCredit=function(t){if(t===TVt){if(!c(Sq)){let e=` This application is using Cesium's default ion access token. Please assign Cesium.Ion.defaultAccessToken with an access token from your ion account before making any Cesium API calls. You can sign up for a free ion account at https://cesium.com.`;Sq=new on(e,!0)}return Sq}};var cZ=hw;function Qc(t,e){let n,i=t.externalType,o=c(i);if(!o)n={url:t.url,retryAttempts:1,retryCallback:njt};else if(i==="3DTILES"||i==="STK_TERRAIN_SERVER")n={url:t.options.url};else throw new St("Ion.createResource does not support external imagery assets; use IonImageryProvider instead.");te.call(this,n),this._ionEndpoint=t,this._ionEndpointDomain=o?void 0:new gq.default(t.url).authority(),this._ionEndpointResource=e,this._ionRoot=void 0,this._pendingPromise=void 0,this._credits=void 0,this._isExternal=o}c(Object.create)&&(Qc.prototype=Object.create(te.prototype),Qc.prototype.constructor=Qc);Qc.fromAssetId=function(t,e){let n=Qc._createEndpointResource(t,e);return n.fetchJson().then(function(i){return new Qc(i,n)})};Object.defineProperties(Qc.prototype,{credits:{get:function(){return c(this._ionRoot)?this._ionRoot.credits:c(this._credits)?this._credits:(this._credits=Qc.getCreditsFromEndpoint(this._ionEndpoint,this._ionEndpointResource),this._credits)}}});Qc.getCreditsFromEndpoint=function(t,e){let n=t.attributions.map(on.getIonCredit),i=cZ.getDefaultTokenCredit(e.queryParameters.access_token);return c(i)&&n.push(on.clone(i)),n};Qc.prototype.clone=function(t){let e=f(this._ionRoot,this);return c(t)||(t=new Qc(e._ionEndpoint,e._ionEndpointResource)),t=te.prototype.clone.call(this,t),t._ionRoot=e,t._isExternal=this._isExternal,t};Qc.prototype.fetchImage=function(t){if(!this._isExternal){let e=t;t={preferBlob:!0},c(e)&&(t.flipY=e.flipY,t.preferImageBitmap=e.preferImageBitmap)}return te.prototype.fetchImage.call(this,t)};Qc.prototype._makeRequest=function(t){return this._isExternal||new gq.default(this.url).authority()!==this._ionEndpointDomain?te.prototype._makeRequest.call(this,t):(c(t.headers)||(t.headers={}),t.headers.Authorization=`Bearer ${this._ionEndpoint.accessToken}`,t.headers["X-Cesium-Client"]="CesiumJS",typeof CESIUM_VERSION<"u"&&(t.headers["X-Cesium-Client-Version"]=CESIUM_VERSION),te.prototype._makeRequest.call(this,t))};Qc._createEndpointResource=function(t,e){e=f(e,f.EMPTY_OBJECT);let n=f(e.server,cZ.defaultServer),i=f(e.accessToken,cZ.defaultAccessToken);n=te.createIfNeeded(n);let o={url:`v1/assets/${t}/endpoint`};return c(i)&&(o.queryParameters={access_token:i}),n.getDerivedResource(o)};function njt(t,e){let n=f(t._ionRoot,t),i=n._ionEndpointResource,o=typeof Image<"u";return!c(e)||e.statusCode!==401&&!(o&&e.target instanceof Image)?Promise.resolve(!1):(c(n._pendingPromise)||(n._pendingPromise=i.fetchJson().then(function(a){return n._ionEndpoint=a,a}).finally(function(a){return n._pendingPromise=void 0,a})),n._pendingPromise.then(function(a){return t._ionEndpoint=a,!0}))}var gh=Qc;var ZTn=R(W(),1);function PV(t){t=f(t,0),this._array=new Array(t),this._length=t}Object.defineProperties(PV.prototype,{length:{get:function(){return this._length},set:function(t){let e=this._array,n=this._length;if(te.length&&(e.length=t);this._length=t}},values:{get:function(){return this._array}}});PV.prototype.get=function(t){return this._array[t]};PV.prototype.set=function(t,e){t>=this._length&&(this.length=t+1),this._array[t]=e};PV.prototype.peek=function(){return this._array[this._length-1]};PV.prototype.push=function(t){let e=this.length++;this._array[e]=t};PV.prototype.pop=function(){if(this._length===0)return;let t=this._array[this._length-1];return--this.length,t};PV.prototype.reserve=function(t){t>this._array.length&&(this._array.length=t)};PV.prototype.resize=function(t){this.length=t};PV.prototype.trim=function(t){t=f(t,this._length),this._array.length=t};var kc=PV;var WTn=R(W(),1);var OR={X:0,Y:1,Z:2};OR.Y_UP_TO_Z_UP=L.fromRotationTranslation(ot.fromArray([1,0,0,0,0,1,0,-1,0]));OR.Z_UP_TO_Y_UP=L.fromRotationTranslation(ot.fromArray([1,0,0,0,0,-1,0,1,0]));OR.X_UP_TO_Z_UP=L.fromRotationTranslation(ot.fromArray([0,0,1,0,1,0,-1,0,0]));OR.Z_UP_TO_X_UP=L.fromRotationTranslation(ot.fromArray([0,0,-1,0,1,0,1,0,0]));OR.X_UP_TO_Y_UP=L.fromRotationTranslation(ot.fromArray([0,1,0,-1,0,0,0,0,1]));OR.Y_UP_TO_X_UP=L.fromRotationTranslation(ot.fromArray([0,-1,0,1,0,0,0,0,1]));OR.fromName=function(t){return OR[t]};var $a=Object.freeze(OR);var nsi=R(W(),1);var UTn=R(W(),1);function SVt(t){t=f(t,f.EMPTY_OBJECT),this._metadata=t.metadata}Object.defineProperties(SVt.prototype,{metadata:{get:function(){return this._metadata}}});var sA=SVt;var Iei=R(W(),1);var XTn=R(W(),1);var ITn=R(W(),1);var STn=R(W(),1);function Ef(t,e,n){return e=f(e,0),n=f(n,t.byteLength-e),t=t.subarray(e,e+n),Ef.decode(t)}Ef.decodeWithTextDecoder=function(t){return new TextDecoder("utf-8").decode(t)};Ef.decodeWithFromCharCode=function(t){let e="",n=ijt(t),i=n.length;for(let o=0;o>10)+55296,(a&1023)+56320))}return e};function Qk(t,e,n){return e<=t&&t<=n}function ijt(t){let e=0,n=0,i=0,o=128,a=191,s=[],l=t.length;for(let r=0;r0){let o=Math.min(e,Sn.maximumTextureSize),a=Math.ceil(e/Sn.maximumTextureSize),s=1/o,l=s*.5,r=1/a,d=r*.5;n=new K(o,a),i=new Rt(s,l,r,d)}this._translucentFeaturesLength=0,this._featuresLength=e,this._textureDimensions=n,this._textureStep=i,this._owner=t.owner,this._statistics=t.statistics,this._colorChangedCallback=t.colorChangedCallback}Object.defineProperties(Hd.prototype,{translucentFeaturesLength:{get:function(){return this._translucentFeaturesLength}},byteLength:{get:function(){let t=0;return c(this._pickTexture)&&(t+=this._pickTexture.sizeInBytes),c(this._batchTexture)&&(t+=this._batchTexture.sizeInBytes),t}},textureDimensions:{get:function(){return this._textureDimensions}},textureStep:{get:function(){return this._textureStep}},batchTexture:{get:function(){return this._batchTexture}},defaultTexture:{get:function(){return this._defaultTexture}},pickTexture:{get:function(){return this._pickTexture}}});Hd.DEFAULT_COLOR_VALUE=v.WHITE;Hd.DEFAULT_SHOW_VALUE=!0;function gVt(t){let e=t._textureDimensions;return e.x*e.y*4}function EVt(t){if(!c(t._batchValues)){let e=gVt(t),n=new Uint8Array(e).fill(255);t._batchValues=n}return t._batchValues}function CVt(t){if(!c(t._showAlphaProperties)){let e=2*t._featuresLength,n=new Uint8Array(e).fill(255);t._showAlphaProperties=n}return t._showAlphaProperties}Hd.prototype.setShow=function(t,e){if(e&&!c(this._showAlphaProperties))return;let n=CVt(this),i=t*2,o=e?255:0;if(n[i]!==o){n[i]=o;let a=EVt(this),s=t*4+3;a[s]=e?n[i+1]:0,this._batchValuesDirty=!0}};Hd.prototype.setAllShow=function(t){let e=this._featuresLength;for(let n=0;n0){let i=t._pickIds,o=gVt(t),a=new Uint8Array(o),s=t._owner,l=t._statistics;for(let r=0;r0;){if(e=m.pop(),r[e]===d)continue;r[e]=d;let h=n(t,e);if(c(h))return h;let Z=o[e],b=s[e];for(let u=0;u0||this._imageBasedLightingFactor.y>0}},shouldRegenerateShaders:{get:function(){return this._shouldRegenerateShaders}},useDefaultSphericalHarmonics:{get:function(){return this._useDefaultSphericalHarmonics}},useSphericalHarmonicCoefficients:{get:function(){return c(this._sphericalHarmonicCoefficients)||this._useDefaultSphericalHarmonics}},specularEnvironmentMapAtlas:{get:function(){return this._specularEnvironmentMapAtlas}},useDefaultSpecularMaps:{get:function(){return this._useDefaultSpecularMaps}},useSpecularEnvironmentMaps:{get:function(){return c(this._specularEnvironmentMapAtlas)&&this._specularEnvironmentMapAtlas.ready||this._useDefaultSpecularMaps}}});function ejt(t,e){if(du.isSupported(e)){if(t._specularEnvironmentMapAtlas=t._specularEnvironmentMapAtlas&&t._specularEnvironmentMapAtlas.destroy(),c(t._specularEnvironmentMaps)){let n=new du(t._specularEnvironmentMaps);t._specularEnvironmentMapAtlas=n,t._removeErrorListener=n.errorEvent.addEventListener(i=>{console.error(`Error loading specularEnvironmentMaps: ${i}`)})}t._shouldRegenerateShaders=!0}}B2.prototype.update=function(t){if(t.frameNumber===this._previousFrameNumber)return;this._previousFrameNumber=t.frameNumber;let e=t.context;t.brdfLutGenerator.update(t),this._shouldRegenerateShaders=!1;let n=this._imageBasedLightingFactor,i=this._previousImageBasedLightingFactor;K.equals(n,i)||(this._shouldRegenerateShaders=n.x>0&&i.x===0||n.x===0&&i.x>0,this._shouldRegenerateShaders=this._shouldRegenerateShaders||n.y>0&&i.y===0||n.y===0&&i.y>0,this._previousImageBasedLightingFactor=K.clone(this._imageBasedLightingFactor,this._previousImageBasedLightingFactor)),this._luminanceAtZenith!==this._previousLuminanceAtZenith&&(this._shouldRegenerateShaders=this._shouldRegenerateShaders||c(this._luminanceAtZenith)!==c(this._previousLuminanceAtZenith),this._previousLuminanceAtZenith=this._luminanceAtZenith),this._previousSphericalHarmonicCoefficients!==this._sphericalHarmonicCoefficients&&(this._shouldRegenerateShaders=this._shouldRegenerateShaders||c(this._previousSphericalHarmonicCoefficients)!==c(this._sphericalHarmonicCoefficients),this._previousSphericalHarmonicCoefficients=this._sphericalHarmonicCoefficients),this._shouldRegenerateShaders=this._shouldRegenerateShaders||this._previousSpecularEnvironmentMapLoaded!==this._specularEnvironmentMapLoaded,this._previousSpecularEnvironmentMapLoaded=this._specularEnvironmentMapLoaded,this._specularEnvironmentMapAtlasDirty&&(ejt(this,e),this._specularEnvironmentMapAtlasDirty=!1),c(this._specularEnvironmentMapAtlas)&&(this._specularEnvironmentMapAtlas.update(t),this._specularEnvironmentMapAtlas.ready&&(this._specularEnvironmentMapLoaded=!0));let o=!c(this._specularEnvironmentMapAtlas)&&c(t.specularEnvironmentMaps)&&!this._useDefaultSpecularMaps,a=!c(t.specularEnvironmentMaps)&&this._useDefaultSpecularMaps,s=!c(this._sphericalHarmonicCoefficients)&&c(t.sphericalHarmonicCoefficients)&&!this._useDefaultSphericalHarmonics,l=!c(t.sphericalHarmonicCoefficients)&&this._useDefaultSphericalHarmonics;this._shouldRegenerateShaders=this._shouldRegenerateShaders||o||a||s||l,this._useDefaultSpecularMaps=!c(this._specularEnvironmentMapAtlas)&&c(t.specularEnvironmentMaps),this._useDefaultSphericalHarmonics=!c(this._sphericalHarmonicCoefficients)&&c(t.sphericalHarmonicCoefficients)};B2.prototype.isDestroyed=function(){return!1};B2.prototype.destroy=function(){return this._specularEnvironmentMapAtlas=this._specularEnvironmentMapAtlas&&this._specularEnvironmentMapAtlas.destroy(),this._removeErrorListener=this._removeErrorListener&&this._removeErrorListener(),At(this)};var aA=B2;var hSn=b(W(),1),gq=b(Vh(),1);var oSn=b(W(),1);var Tq,SZt="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiJjM2I5YWEyNS02NzRiLTRmOTEtYWZhNi1jNzlhZTI5Yjc3YWYiLCJpZCI6MjU5LCJpYXQiOjE3MTE1NTQ2Njd9.dawdakmPEfdAKpH2-Cv-IDOlVHwicZ1Mgk7ZzI775hQ",hw={};hw.defaultAccessToken=SZt;hw.defaultServer=new te({url:"https://api.cesium.com/"});hw.getDefaultTokenCredit=function(t){if(t===SZt){if(!c(Tq)){let e=` This application is using Cesium's default ion access token. Please assign Cesium.Ion.defaultAccessToken with an access token from your ion account before making any Cesium API calls. You can sign up for a free ion account at https://cesium.com.`;Tq=new on(e,!0)}return Tq}};var cu=hw;function Qc(t,e){let n,i=t.externalType,o=c(i);if(!o)n={url:t.url,retryAttempts:1,retryCallback:njt};else if(i==="3DTILES"||i==="STK_TERRAIN_SERVER")n={url:t.options.url};else throw new Tt("Ion.createResource does not support external imagery assets; use IonImageryProvider instead.");te.call(this,n),this._ionEndpoint=t,this._ionEndpointDomain=o?void 0:new gq.default(t.url).authority(),this._ionEndpointResource=e,this._ionRoot=void 0,this._pendingPromise=void 0,this._credits=void 0,this._isExternal=o}c(Object.create)&&(Qc.prototype=Object.create(te.prototype),Qc.prototype.constructor=Qc);Qc.fromAssetId=function(t,e){let n=Qc._createEndpointResource(t,e);return n.fetchJson().then(function(i){return new Qc(i,n)})};Object.defineProperties(Qc.prototype,{credits:{get:function(){return c(this._ionRoot)?this._ionRoot.credits:c(this._credits)?this._credits:(this._credits=Qc.getCreditsFromEndpoint(this._ionEndpoint,this._ionEndpointResource),this._credits)}}});Qc.getCreditsFromEndpoint=function(t,e){let n=t.attributions.map(on.getIonCredit),i=cu.getDefaultTokenCredit(e.queryParameters.access_token);return c(i)&&n.push(on.clone(i)),n};Qc.prototype.clone=function(t){let e=f(this._ionRoot,this);return c(t)||(t=new Qc(e._ionEndpoint,e._ionEndpointResource)),t=te.prototype.clone.call(this,t),t._ionRoot=e,t._isExternal=this._isExternal,t};Qc.prototype.fetchImage=function(t){if(!this._isExternal){let e=t;t={preferBlob:!0},c(e)&&(t.flipY=e.flipY,t.preferImageBitmap=e.preferImageBitmap)}return te.prototype.fetchImage.call(this,t)};Qc.prototype._makeRequest=function(t){return this._isExternal||new gq.default(this.url).authority()!==this._ionEndpointDomain?te.prototype._makeRequest.call(this,t):(c(t.headers)||(t.headers={}),t.headers.Authorization=`Bearer ${this._ionEndpoint.accessToken}`,t.headers["X-Cesium-Client"]="CesiumJS",typeof CESIUM_VERSION<"u"&&(t.headers["X-Cesium-Client-Version"]=CESIUM_VERSION),te.prototype._makeRequest.call(this,t))};Qc._createEndpointResource=function(t,e){e=f(e,f.EMPTY_OBJECT);let n=f(e.server,cu.defaultServer),i=f(e.accessToken,cu.defaultAccessToken);n=te.createIfNeeded(n);let o={url:`v1/assets/${t}/endpoint`};return c(i)&&(o.queryParameters={access_token:i}),n.getDerivedResource(o)};function njt(t,e){let n=f(t._ionRoot,t),i=n._ionEndpointResource,o=typeof Image<"u";return!c(e)||e.statusCode!==401&&!(o&&e.target instanceof Image)?Promise.resolve(!1):(c(n._pendingPromise)||(n._pendingPromise=i.fetchJson().then(function(a){return n._ionEndpoint=a,a}).finally(function(a){return n._pendingPromise=void 0,a})),n._pendingPromise.then(function(a){return t._ionEndpoint=a,!0}))}var gh=Qc;var uSn=b(W(),1);function PZ(t){t=f(t,0),this._array=new Array(t),this._length=t}Object.defineProperties(PZ.prototype,{length:{get:function(){return this._length},set:function(t){let e=this._array,n=this._length;if(te.length&&(e.length=t);this._length=t}},values:{get:function(){return this._array}}});PZ.prototype.get=function(t){return this._array[t]};PZ.prototype.set=function(t,e){t>=this._length&&(this.length=t+1),this._array[t]=e};PZ.prototype.peek=function(){return this._array[this._length-1]};PZ.prototype.push=function(t){let e=this.length++;this._array[e]=t};PZ.prototype.pop=function(){if(this._length===0)return;let t=this._array[this._length-1];return--this.length,t};PZ.prototype.reserve=function(t){t>this._array.length&&(this._array.length=t)};PZ.prototype.resize=function(t){this.length=t};PZ.prototype.trim=function(t){t=f(t,this._length),this._array.length=t};var kc=PZ;var WSn=b(W(),1);var Ob={X:0,Y:1,Z:2};Ob.Y_UP_TO_Z_UP=L.fromRotationTranslation(ot.fromArray([1,0,0,0,0,1,0,-1,0]));Ob.Z_UP_TO_Y_UP=L.fromRotationTranslation(ot.fromArray([1,0,0,0,0,-1,0,1,0]));Ob.X_UP_TO_Z_UP=L.fromRotationTranslation(ot.fromArray([0,0,1,0,1,0,-1,0,0]));Ob.Z_UP_TO_X_UP=L.fromRotationTranslation(ot.fromArray([0,0,-1,0,1,0,1,0,0]));Ob.X_UP_TO_Y_UP=L.fromRotationTranslation(ot.fromArray([0,1,0,-1,0,0,0,0,1]));Ob.Y_UP_TO_X_UP=L.fromRotationTranslation(ot.fromArray([0,-1,0,1,0,0,0,0,1]));Ob.fromName=function(t){return Ob[t]};var $a=Object.freeze(Ob);var nsi=b(W(),1);var USn=b(W(),1);function TZt(t){t=f(t,f.EMPTY_OBJECT),this._metadata=t.metadata}Object.defineProperties(TZt.prototype,{metadata:{get:function(){return this._metadata}}});var sA=TZt;var Iei=b(W(),1);var XSn=b(W(),1);var ISn=b(W(),1);var TSn=b(W(),1);function Ef(t,e,n){return e=f(e,0),n=f(n,t.byteLength-e),t=t.subarray(e,e+n),Ef.decode(t)}Ef.decodeWithTextDecoder=function(t){return new TextDecoder("utf-8").decode(t)};Ef.decodeWithFromCharCode=function(t){let e="",n=ijt(t),i=n.length;for(let o=0;o>10)+55296,(a&1023)+56320))}return e};function Q2(t,e,n){return e<=t&&t<=n}function ijt(t){let e=0,n=0,i=0,o=128,a=191,s=[],l=t.length;for(let r=0;r0){let o=Math.min(e,Tn.maximumTextureSize),a=Math.ceil(e/Tn.maximumTextureSize),s=1/o,l=s*.5,r=1/a,d=r*.5;n=new K(o,a),i=new bt(s,l,r,d)}this._translucentFeaturesLength=0,this._featuresLength=e,this._textureDimensions=n,this._textureStep=i,this._owner=t.owner,this._statistics=t.statistics,this._colorChangedCallback=t.colorChangedCallback}Object.defineProperties(Hd.prototype,{translucentFeaturesLength:{get:function(){return this._translucentFeaturesLength}},byteLength:{get:function(){let t=0;return c(this._pickTexture)&&(t+=this._pickTexture.sizeInBytes),c(this._batchTexture)&&(t+=this._batchTexture.sizeInBytes),t}},textureDimensions:{get:function(){return this._textureDimensions}},textureStep:{get:function(){return this._textureStep}},batchTexture:{get:function(){return this._batchTexture}},defaultTexture:{get:function(){return this._defaultTexture}},pickTexture:{get:function(){return this._pickTexture}}});Hd.DEFAULT_COLOR_VALUE=v.WHITE;Hd.DEFAULT_SHOW_VALUE=!0;function gZt(t){let e=t._textureDimensions;return e.x*e.y*4}function EZt(t){if(!c(t._batchValues)){let e=gZt(t),n=new Uint8Array(e).fill(255);t._batchValues=n}return t._batchValues}function CZt(t){if(!c(t._showAlphaProperties)){let e=2*t._featuresLength,n=new Uint8Array(e).fill(255);t._showAlphaProperties=n}return t._showAlphaProperties}Hd.prototype.setShow=function(t,e){if(e&&!c(this._showAlphaProperties))return;let n=CZt(this),i=t*2,o=e?255:0;if(n[i]!==o){n[i]=o;let a=EZt(this),s=t*4+3;a[s]=e?n[i+1]:0,this._batchValuesDirty=!0}};Hd.prototype.setAllShow=function(t){let e=this._featuresLength;for(let n=0;n0){let i=t._pickIds,o=gZt(t),a=new Uint8Array(o),s=t._owner,l=t._statistics;for(let r=0;r0;){if(e=m.pop(),r[e]===d)continue;r[e]=d;let h=n(t,e);if(c(h))return h;let u=o[e],R=s[e];for(let V=0;V0?(s="",t&&(s+=`uniform bool tile_translucentCommand; +`}Ca.prototype.getVertexShaderCallback=function(t,e,n){if(this.featuresLength===0)return;let i=this;return function(o){let a=BZt(o,n,!1),s;return Tn.maximumVertexTextureImageUnits>0?(s="",t&&(s+=`uniform bool tile_translucentCommand; `),s+=`uniform sampler2D tile_batchTexture; out vec4 tile_featureColor; out vec2 tile_featureSt; @@ -6086,7 +6086,7 @@ void main() tile_color(vec4(1.0)); tile_featureSt = computeSt(${e}); }`,`${a} -${Cjt(i)}${s}`}};function NVt(t,e){return t=Ve.replaceMain(t,"tile_main"),e?`${t}uniform float tile_colorBlend; +${Cjt(i)}${s}`}};function NZt(t,e){return t=Ze.replaceMain(t,"tile_main"),e?`${t}uniform float tile_colorBlend; void tile_color(vec4 tile_featureColor) { tile_main(); @@ -6099,7 +6099,7 @@ void tile_color(vec4 tile_featureColor) { tile_main(); } -`}function Ijt(t,e){let n=`texture(${e}`,i=0,o=t.indexOf(n,i),a;for(;o>-1;){let s=0;for(let d=o;d-1;){let s=0;for(let d=o;d0?(i+=`uniform sampler2D tile_pickTexture; +`,t}Ca.prototype.getFragmentShaderCallback=function(t,e,n){if(this.featuresLength!==0)return function(i){return i=BZt(i,e,!0),Tn.maximumVertexTextureImageUnits>0?(i+=`uniform sampler2D tile_pickTexture; in vec2 tile_featureSt; in vec4 tile_featureColor; void main() @@ -6160,7 +6160,7 @@ void main() `),i+=` tile_color(featureProperties); `,n&&(i+=` out_FragColor.rgb *= out_FragColor.a; `),i+=`} -`),i}};Ca.prototype.getClassificationFragmentShaderCallback=function(){if(this.featuresLength!==0)return function(t){return t=Ve.replaceMain(t,"tile_main"),Sn.maximumVertexTextureImageUnits>0?t+=`uniform sampler2D tile_pickTexture; +`),i}};Ca.prototype.getClassificationFragmentShaderCallback=function(){if(this.featuresLength!==0)return function(t){return t=Ze.replaceMain(t,"tile_main"),Tn.maximumVertexTextureImageUnits>0?t+=`uniform sampler2D tile_pickTexture; in vec2 tile_featureSt; in vec4 tile_featureColor; void main() @@ -6181,7 +6181,7 @@ void main() out_FragColor = featureProperties; out_FragColor.rgb *= out_FragColor.a; } -`,t}};function Njt(t){let e=t._content.tileset,n=e.colorBlendMode,i=e.colorBlendAmount;if(n===Nm.HIGHLIGHT)return 0;if(n===Nm.REPLACE)return 1;if(n===Nm.MIX)return k.clamp(i,k.EPSILON4,1)}Ca.prototype.getUniformMapCallback=function(){if(this.featuresLength===0)return;let t=this;return function(e){return ze(e,{tile_batchTexture:function(){return f(t._batchTexture.batchTexture,t._batchTexture.defaultTexture)},tile_textureDimensions:function(){return t._batchTexture.textureDimensions},tile_textureStep:function(){return t._batchTexture.textureStep},tile_colorBlend:function(){return Njt(t)},tile_pickTexture:function(){return t._batchTexture.pickTexture}})}};Ca.prototype.getPickId=function(){return"texture(tile_pickTexture, tile_featureSt)"};var Cf={ALL_OPAQUE:0,ALL_TRANSLUCENT:1,OPAQUE_AND_TRANSLUCENT:2};Ca.prototype.addDerivedCommands=function(t,e){let n=t.commandList,i=n.length,o=this._content._tile,a=o._finalResolution,s=o.tileset,l=s.isSkippingLevelOfDetail&&s.hasMixedContent&&t.context.stencilBuffer,r=yjt(this);for(let d=e;d>>gn.SKIP_LOD_BIT_SHIFT}function Ljt(t){let e=be(t,!0);return e.cull.enabled=!1,e.depthTest.enabled=!0,e.depthMask=!1,e.blending=Pn.ALPHA_BLEND,e.stencilTest=gn.setCesium3DTileBit(),e.stencilMask=gn.CESIUM_3D_TILE_MASK,he.fromCache(e)}function Mjt(t){let e=be(t,!0);return e.stencilTest=gn.setCesium3DTileBit(),e.stencilMask=gn.CESIUM_3D_TILE_MASK,he.fromCache(e)}Ca.prototype.update=function(t,e){this._batchTexture.update(t,e)};Ca.prototype.isDestroyed=function(){return!1};Ca.prototype.destroy=function(){return this._batchTexture=this._batchTexture&&this._batchTexture.destroy(),At(this)};var wR=Ca;var aEn=R(W(),1);var KSn=R(W(),1);function _jt(t){this.offset=t.offset,this.count=t.count,this.color=t.color,this.batchIds=t.batchIds}var vV=_jt;var wgn=R(W(),1);var jSn=R(W(),1),CE=`in vec3 position; +`,t}};function Njt(t){let e=t._content.tileset,n=e.colorBlendMode,i=e.colorBlendAmount;if(n===Nm.HIGHLIGHT)return 0;if(n===Nm.REPLACE)return 1;if(n===Nm.MIX)return k.clamp(i,k.EPSILON4,1)}Ca.prototype.getUniformMapCallback=function(){if(this.featuresLength===0)return;let t=this;return function(e){return ze(e,{tile_batchTexture:function(){return f(t._batchTexture.batchTexture,t._batchTexture.defaultTexture)},tile_textureDimensions:function(){return t._batchTexture.textureDimensions},tile_textureStep:function(){return t._batchTexture.textureStep},tile_colorBlend:function(){return Njt(t)},tile_pickTexture:function(){return t._batchTexture.pickTexture}})}};Ca.prototype.getPickId=function(){return"texture(tile_pickTexture, tile_featureSt)"};var Cf={ALL_OPAQUE:0,ALL_TRANSLUCENT:1,OPAQUE_AND_TRANSLUCENT:2};Ca.prototype.addDerivedCommands=function(t,e){let n=t.commandList,i=n.length,o=this._content._tile,a=o._finalResolution,s=o.tileset,l=s.isSkippingLevelOfDetail&&s.hasMixedContent&&t.context.stencilBuffer,r=yjt(this);for(let d=e;d>>gn.SKIP_LOD_BIT_SHIFT}function Ljt(t){let e=Re(t,!0);return e.cull.enabled=!1,e.depthTest.enabled=!0,e.depthMask=!1,e.blending=Pn.ALPHA_BLEND,e.stencilTest=gn.setCesium3DTileBit(),e.stencilMask=gn.CESIUM_3D_TILE_MASK,he.fromCache(e)}function Mjt(t){let e=Re(t,!0);return e.stencilTest=gn.setCesium3DTileBit(),e.stencilMask=gn.CESIUM_3D_TILE_MASK,he.fromCache(e)}Ca.prototype.update=function(t,e){this._batchTexture.update(t,e)};Ca.prototype.isDestroyed=function(){return!1};Ca.prototype.destroy=function(){return this._batchTexture=this._batchTexture&&this._batchTexture.destroy(),At(this)};var wb=Ca;var aEn=b(W(),1);var KTn=b(W(),1);function _jt(t){this.offset=t.offset,this.count=t.count,this.color=t.color,this.batchIds=t.batchIds}var vZ=_jt;var wgn=b(W(),1);var jTn=b(W(),1),CE=`in vec3 position; in float a_batchId; uniform mat4 u_modifiedModelViewProjection; @@ -6190,31 +6190,31 @@ void main() { gl_Position = czm_depthClamp(u_modifiedModelViewProjection * vec4(position, 1.0)); } -`;var egn=R(W(),1);function Yp(t,e){this._content=t,this._batchId=e,this._color=void 0}Object.defineProperties(Yp.prototype,{show:{get:function(){return this._content.batchTable.getShow(this._batchId)},set:function(t){this._content.batchTable.setShow(this._batchId,t)}},color:{get:function(){return c(this._color)||(this._color=new v),this._content.batchTable.getColor(this._batchId,this._color)},set:function(t){this._content.batchTable.setColor(this._batchId,t)}},polylinePositions:{get:function(){if(c(this._content.getPolylinePositions))return this._content.getPolylinePositions(this._batchId)}},content:{get:function(){return this._content}},tileset:{get:function(){return this._content.tileset}},primitive:{get:function(){return this._content.tileset}},featureId:{get:function(){return this._batchId}},pickId:{get:function(){return this._content.batchTable.getPickColor(this._batchId)}}});Yp.prototype.hasProperty=function(t){return this._content.batchTable.hasProperty(this._batchId,t)};Yp.prototype.getPropertyIds=function(t){return this._content.batchTable.getPropertyIds(this._batchId,t)};Yp.prototype.getProperty=function(t){return this._content.batchTable.getProperty(this._batchId,t)};Yp.getPropertyInherited=function(t,e,n){let i=t.batchTable;if(c(i)){if(i.hasPropertyBySemantic(e,n))return i.getPropertyBySemantic(e,n);if(i.hasProperty(e,n))return i.getProperty(e,n)}let o=t.metadata;if(c(o)){if(o.hasPropertyBySemantic(n))return o.getPropertyBySemantic(n);if(o.hasProperty(n))return o.getProperty(n)}let a=t.tile,s=a.metadata;if(c(s)){if(s.hasPropertyBySemantic(n))return s.getPropertyBySemantic(n);if(s.hasProperty(n))return s.getProperty(n)}let l;if(c(a.implicitSubtree)&&(l=a.implicitSubtree.metadata),c(l)){if(l.hasPropertyBySemantic(n))return l.getPropertyBySemantic(n);if(l.hasProperty(n))return l.getProperty(n)}let r=c(t.group)?t.group.metadata:void 0;if(c(r)){if(r.hasPropertyBySemantic(n))return r.getPropertyBySemantic(n);if(r.hasProperty(n))return r.getProperty(n)}let d=t.tileset.metadata;if(c(d)){if(d.hasPropertyBySemantic(n))return d.getPropertyBySemantic(n);if(d.hasProperty(n))return d.getProperty(n)}};Yp.prototype.getPropertyInherited=function(t){return Yp.getPropertyInherited(this._content,this._batchId,t)};Yp.prototype.setProperty=function(t,e){this._content.batchTable.setProperty(this._batchId,t,e),this._content.featurePropertiesDirty=!0};Yp.prototype.isExactClass=function(t){return this._content.batchTable.isExactClass(this._batchId,t)};Yp.prototype.isClass=function(t){return this._content.batchTable.isClass(this._batchId,t)};Yp.prototype.getExactClassName=function(){return this._content.batchTable.getExactClassName(this._batchId)};var Fr=Yp;var Vgn=R(W(),1);var ign=R(W(),1),Iq=class{add(e,n,i){if(typeof arguments[0]!="string")for(let o in arguments[0])this.add(o,arguments[0][o],arguments[1]);else(Array.isArray(e)?e:[e]).forEach(function(o){this[o]=this[o]||[],n&&this[o][i?"unshift":"push"](n)},this)}run(e,n){this[e]=this[e]||[],this[e].forEach(function(i){i.call(n&&n.context?n.context:n,n)})}},Nq=class{constructor(e){this.jsep=e,this.registered={}}register(...e){e.forEach(n=>{if(typeof n!="object"||!n.name||!n.init)throw new Error("Invalid JSEP plugin format");this.registered[n.name]||(n.init(this.jsep),this.registered[n.name]=n)})}},ym=class t{static get version(){return"1.3.8"}static toString(){return"JavaScript Expression Parser (JSEP) v"+t.version}static addUnaryOp(e){return t.max_unop_len=Math.max(e.length,t.max_unop_len),t.unary_ops[e]=1,t}static addBinaryOp(e,n,i){return t.max_binop_len=Math.max(e.length,t.max_binop_len),t.binary_ops[e]=n,i?t.right_associative.add(e):t.right_associative.delete(e),t}static addIdentifierChar(e){return t.additional_identifier_chars.add(e),t}static addLiteral(e,n){return t.literals[e]=n,t}static removeUnaryOp(e){return delete t.unary_ops[e],e.length===t.max_unop_len&&(t.max_unop_len=t.getMaxKeyLen(t.unary_ops)),t}static removeAllUnaryOps(){return t.unary_ops={},t.max_unop_len=0,t}static removeIdentifierChar(e){return t.additional_identifier_chars.delete(e),t}static removeBinaryOp(e){return delete t.binary_ops[e],e.length===t.max_binop_len&&(t.max_binop_len=t.getMaxKeyLen(t.binary_ops)),t.right_associative.delete(e),t}static removeAllBinaryOps(){return t.binary_ops={},t.max_binop_len=0,t}static removeLiteral(e){return delete t.literals[e],t}static removeAllLiterals(){return t.literals={},t}get char(){return this.expr.charAt(this.index)}get code(){return this.expr.charCodeAt(this.index)}constructor(e){this.expr=e,this.index=0}static parse(e){return new t(e).parse()}static getMaxKeyLen(e){return Math.max(0,...Object.keys(e).map(n=>n.length))}static isDecimalDigit(e){return e>=48&&e<=57}static binaryPrecedence(e){return t.binary_ops[e]||0}static isIdentifierStart(e){return e>=65&&e<=90||e>=97&&e<=122||e>=128&&!t.binary_ops[String.fromCharCode(e)]||t.additional_identifier_chars.has(String.fromCharCode(e))}static isIdentifierPart(e){return t.isIdentifierStart(e)||t.isDecimalDigit(e)}throwError(e){let n=new Error(e+" at character "+this.index);throw n.index=this.index,n.description=e,n}runHook(e,n){if(t.hooks[e]){let i={context:this,node:n};return t.hooks.run(e,i),i.node}return n}searchHook(e){if(t.hooks[e]){let n={context:this};return t.hooks[e].find(function(i){return i.call(n.context,n),n.node}),n.node}}gobbleSpaces(){let e=this.code;for(;e===t.SPACE_CODE||e===t.TAB_CODE||e===t.LF_CODE||e===t.CR_CODE;)e=this.expr.charCodeAt(++this.index);this.runHook("gobble-spaces")}parse(){this.runHook("before-all");let e=this.gobbleExpressions(),n=e.length===1?e[0]:{type:t.COMPOUND,body:e};return this.runHook("after-all",n)}gobbleExpressions(e){let n=[],i,o;for(;this.index0;){if(t.binary_ops.hasOwnProperty(e)&&(!t.isIdentifierStart(this.code)||this.index+e.lengtha.right_a&&h.right_a?i>h.prec:i<=h.prec;for(;o.length>2&&m(o[o.length-2]);)l=o.pop(),n=o.pop().value,s=o.pop(),e={type:t.BINARY_EXP,operator:n,left:s,right:l},o.push(e);e=this.gobbleToken(),e||this.throwError("Expected expression after "+d),o.push(a,e)}for(r=o.length-1,e=o[r];r>1;)e={type:t.BINARY_EXP,operator:o[r-1].value,left:o[r-2],right:e},r-=2;return e}gobbleToken(){let e,n,i,o;if(this.gobbleSpaces(),o=this.searchHook("gobble-token"),o)return this.runHook("after-token",o);if(e=this.code,t.isDecimalDigit(e)||e===t.PERIOD_CODE)return this.gobbleNumericLiteral();if(e===t.SQUOTE_CODE||e===t.DQUOTE_CODE)o=this.gobbleStringLiteral();else if(e===t.OBRACK_CODE)o=this.gobbleArray();else{for(n=this.expr.substr(this.index,t.max_unop_len),i=n.length;i>0;){if(t.unary_ops.hasOwnProperty(n)&&(!t.isIdentifierStart(this.code)||this.index+n.length=n.length&&this.throwError("Unexpected token "+String.fromCharCode(e));break}else if(a===t.COMMA_CODE){if(this.index++,o++,o!==n.length){if(e===t.CPAREN_CODE)this.throwError("Unexpected token ,");else if(e===t.CBRACK_CODE)for(let s=n.length;s":7,"<=":7,">=":7,"<<":8,">>":8,">>>":8,"+":9,"-":9,"*":10,"/":10,"%":10},right_associative:new Set,additional_identifier_chars:new Set(["$","_"]),literals:{true:!0,false:!1,null:null},this_str:"this"});ym.max_unop_len=ym.getMaxKeyLen(ym.unary_ops);ym.max_binop_len=ym.getMaxKeyLen(ym.binary_ops);var If=t=>new ym(t).parse(),Ojt=Object.getOwnPropertyNames(ym);Ojt.forEach(t=>{If[t]===void 0&&t!=="prototype"&&(If[t]=ym[t])});If.Jsep=ym;var Hjt="ConditionalExpression",wjt={name:"ternary",init(t){t.hooks.add("after-expression",function(n){if(n.node&&this.code===t.QUMARK_CODE){this.index++;let i=n.node,o=this.gobbleExpression();if(o||this.throwError("Expected expression"),this.gobbleSpaces(),this.code===t.COLON_CODE){this.index++;let a=this.gobbleExpression();if(a||this.throwError("Expected expression"),n.node={type:Hjt,test:i,consequent:o,alternate:a},i.operator&&t.binary_ops[i.operator]<=.9){let s=i;for(;s.right.operator&&t.binary_ops[s.right.operator]<=.9;)s=s.right;n.node.test=s.right,s.right=n.node,n.node=i}}else this.throwError("Expected :")}})}};If.plugins.register(wjt);var agn=R(W(),1),Pjt={VARIABLE:0,UNARY:1,BINARY:2,TERNARY:3,CONDITIONAL:4,MEMBER:5,FUNCTION_CALL:6,ARRAY:7,REGEX:8,VARIABLE_IN_STRING:9,LITERAL_NULL:10,LITERAL_BOOLEAN:11,LITERAL_NUMBER:12,LITERAL_STRING:13,LITERAL_COLOR:14,LITERAL_VECTOR:15,LITERAL_REGEX:16,LITERAL_UNDEFINED:17,BUILTIN_VARIABLE:18},tn=Object.freeze(Pjt);function hZ(t,e){this._expression=t,t=s4t(t,e),t=r4t(l4t(t)),If.addBinaryOp("=~",0),If.addBinaryOp("!~",0);let n;try{n=If(t)}catch(i){throw new St(i)}this._runtimeAst=So(this,n)}Object.defineProperties(hZ.prototype,{expression:{get:function(){return this._expression}}});var Ti={arrayIndex:0,arrayArray:[[]],cartesian2Index:0,cartesian3Index:0,cartesian4Index:0,cartesian2Array:[new K],cartesian3Array:[new p],cartesian4Array:[new Rt],reset:function(){this.arrayIndex=0,this.cartesian2Index=0,this.cartesian3Index=0,this.cartesian4Index=0},getArray:function(){this.arrayIndex>=this.arrayArray.length&&this.arrayArray.push([]);let t=this.arrayArray[this.arrayIndex++];return t.length=0,t},getCartesian2:function(){return this.cartesian2Index>=this.cartesian2Array.length&&this.cartesian2Array.push(new K),this.cartesian2Array[this.cartesian2Index++]},getCartesian3:function(){return this.cartesian3Index>=this.cartesian3Array.length&&this.cartesian3Array.push(new p),this.cartesian3Array[this.cartesian3Index++]},getCartesian4:function(){return this.cartesian4Index>=this.cartesian4Array.length&&this.cartesian4Array.push(new Rt),this.cartesian4Array[this.cartesian4Index++]}};hZ.prototype.evaluate=function(t,e){Ti.reset();let n=this._runtimeAst.evaluate(t);return e instanceof v&&n instanceof Rt?v.fromCartesian4(n,e):n instanceof K||n instanceof p||n instanceof Rt?n.clone(e):n};hZ.prototype.evaluateColor=function(t,e){Ti.reset();let n=this._runtimeAst.evaluate(t);return v.fromCartesian4(n,e)};hZ.prototype.getShaderFunction=function(t,e,n,i){let o=this.getShaderExpression(e,n);return o=`${i} ${t} +`;var egn=b(W(),1);function Yp(t,e){this._content=t,this._batchId=e,this._color=void 0}Object.defineProperties(Yp.prototype,{show:{get:function(){return this._content.batchTable.getShow(this._batchId)},set:function(t){this._content.batchTable.setShow(this._batchId,t)}},color:{get:function(){return c(this._color)||(this._color=new v),this._content.batchTable.getColor(this._batchId,this._color)},set:function(t){this._content.batchTable.setColor(this._batchId,t)}},polylinePositions:{get:function(){if(c(this._content.getPolylinePositions))return this._content.getPolylinePositions(this._batchId)}},content:{get:function(){return this._content}},tileset:{get:function(){return this._content.tileset}},primitive:{get:function(){return this._content.tileset}},featureId:{get:function(){return this._batchId}},pickId:{get:function(){return this._content.batchTable.getPickColor(this._batchId)}}});Yp.prototype.hasProperty=function(t){return this._content.batchTable.hasProperty(this._batchId,t)};Yp.prototype.getPropertyIds=function(t){return this._content.batchTable.getPropertyIds(this._batchId,t)};Yp.prototype.getProperty=function(t){return this._content.batchTable.getProperty(this._batchId,t)};Yp.getPropertyInherited=function(t,e,n){let i=t.batchTable;if(c(i)){if(i.hasPropertyBySemantic(e,n))return i.getPropertyBySemantic(e,n);if(i.hasProperty(e,n))return i.getProperty(e,n)}let o=t.metadata;if(c(o)){if(o.hasPropertyBySemantic(n))return o.getPropertyBySemantic(n);if(o.hasProperty(n))return o.getProperty(n)}let a=t.tile,s=a.metadata;if(c(s)){if(s.hasPropertyBySemantic(n))return s.getPropertyBySemantic(n);if(s.hasProperty(n))return s.getProperty(n)}let l;if(c(a.implicitSubtree)&&(l=a.implicitSubtree.metadata),c(l)){if(l.hasPropertyBySemantic(n))return l.getPropertyBySemantic(n);if(l.hasProperty(n))return l.getProperty(n)}let r=c(t.group)?t.group.metadata:void 0;if(c(r)){if(r.hasPropertyBySemantic(n))return r.getPropertyBySemantic(n);if(r.hasProperty(n))return r.getProperty(n)}let d=t.tileset.metadata;if(c(d)){if(d.hasPropertyBySemantic(n))return d.getPropertyBySemantic(n);if(d.hasProperty(n))return d.getProperty(n)}};Yp.prototype.getPropertyInherited=function(t){return Yp.getPropertyInherited(this._content,this._batchId,t)};Yp.prototype.setProperty=function(t,e){this._content.batchTable.setProperty(this._batchId,t,e),this._content.featurePropertiesDirty=!0};Yp.prototype.isExactClass=function(t){return this._content.batchTable.isExactClass(this._batchId,t)};Yp.prototype.isClass=function(t){return this._content.batchTable.isClass(this._batchId,t)};Yp.prototype.getExactClassName=function(){return this._content.batchTable.getExactClassName(this._batchId)};var Fr=Yp;var Zgn=b(W(),1);var ign=b(W(),1),Iq=class{add(e,n,i){if(typeof arguments[0]!="string")for(let o in arguments[0])this.add(o,arguments[0][o],arguments[1]);else(Array.isArray(e)?e:[e]).forEach(function(o){this[o]=this[o]||[],n&&this[o][i?"unshift":"push"](n)},this)}run(e,n){this[e]=this[e]||[],this[e].forEach(function(i){i.call(n&&n.context?n.context:n,n)})}},Nq=class{constructor(e){this.jsep=e,this.registered={}}register(...e){e.forEach(n=>{if(typeof n!="object"||!n.name||!n.init)throw new Error("Invalid JSEP plugin format");this.registered[n.name]||(n.init(this.jsep),this.registered[n.name]=n)})}},ym=class t{static get version(){return"1.3.8"}static toString(){return"JavaScript Expression Parser (JSEP) v"+t.version}static addUnaryOp(e){return t.max_unop_len=Math.max(e.length,t.max_unop_len),t.unary_ops[e]=1,t}static addBinaryOp(e,n,i){return t.max_binop_len=Math.max(e.length,t.max_binop_len),t.binary_ops[e]=n,i?t.right_associative.add(e):t.right_associative.delete(e),t}static addIdentifierChar(e){return t.additional_identifier_chars.add(e),t}static addLiteral(e,n){return t.literals[e]=n,t}static removeUnaryOp(e){return delete t.unary_ops[e],e.length===t.max_unop_len&&(t.max_unop_len=t.getMaxKeyLen(t.unary_ops)),t}static removeAllUnaryOps(){return t.unary_ops={},t.max_unop_len=0,t}static removeIdentifierChar(e){return t.additional_identifier_chars.delete(e),t}static removeBinaryOp(e){return delete t.binary_ops[e],e.length===t.max_binop_len&&(t.max_binop_len=t.getMaxKeyLen(t.binary_ops)),t.right_associative.delete(e),t}static removeAllBinaryOps(){return t.binary_ops={},t.max_binop_len=0,t}static removeLiteral(e){return delete t.literals[e],t}static removeAllLiterals(){return t.literals={},t}get char(){return this.expr.charAt(this.index)}get code(){return this.expr.charCodeAt(this.index)}constructor(e){this.expr=e,this.index=0}static parse(e){return new t(e).parse()}static getMaxKeyLen(e){return Math.max(0,...Object.keys(e).map(n=>n.length))}static isDecimalDigit(e){return e>=48&&e<=57}static binaryPrecedence(e){return t.binary_ops[e]||0}static isIdentifierStart(e){return e>=65&&e<=90||e>=97&&e<=122||e>=128&&!t.binary_ops[String.fromCharCode(e)]||t.additional_identifier_chars.has(String.fromCharCode(e))}static isIdentifierPart(e){return t.isIdentifierStart(e)||t.isDecimalDigit(e)}throwError(e){let n=new Error(e+" at character "+this.index);throw n.index=this.index,n.description=e,n}runHook(e,n){if(t.hooks[e]){let i={context:this,node:n};return t.hooks.run(e,i),i.node}return n}searchHook(e){if(t.hooks[e]){let n={context:this};return t.hooks[e].find(function(i){return i.call(n.context,n),n.node}),n.node}}gobbleSpaces(){let e=this.code;for(;e===t.SPACE_CODE||e===t.TAB_CODE||e===t.LF_CODE||e===t.CR_CODE;)e=this.expr.charCodeAt(++this.index);this.runHook("gobble-spaces")}parse(){this.runHook("before-all");let e=this.gobbleExpressions(),n=e.length===1?e[0]:{type:t.COMPOUND,body:e};return this.runHook("after-all",n)}gobbleExpressions(e){let n=[],i,o;for(;this.index0;){if(t.binary_ops.hasOwnProperty(e)&&(!t.isIdentifierStart(this.code)||this.index+e.lengtha.right_a&&h.right_a?i>h.prec:i<=h.prec;for(;o.length>2&&m(o[o.length-2]);)l=o.pop(),n=o.pop().value,s=o.pop(),e={type:t.BINARY_EXP,operator:n,left:s,right:l},o.push(e);e=this.gobbleToken(),e||this.throwError("Expected expression after "+d),o.push(a,e)}for(r=o.length-1,e=o[r];r>1;)e={type:t.BINARY_EXP,operator:o[r-1].value,left:o[r-2],right:e},r-=2;return e}gobbleToken(){let e,n,i,o;if(this.gobbleSpaces(),o=this.searchHook("gobble-token"),o)return this.runHook("after-token",o);if(e=this.code,t.isDecimalDigit(e)||e===t.PERIOD_CODE)return this.gobbleNumericLiteral();if(e===t.SQUOTE_CODE||e===t.DQUOTE_CODE)o=this.gobbleStringLiteral();else if(e===t.OBRACK_CODE)o=this.gobbleArray();else{for(n=this.expr.substr(this.index,t.max_unop_len),i=n.length;i>0;){if(t.unary_ops.hasOwnProperty(n)&&(!t.isIdentifierStart(this.code)||this.index+n.length=n.length&&this.throwError("Unexpected token "+String.fromCharCode(e));break}else if(a===t.COMMA_CODE){if(this.index++,o++,o!==n.length){if(e===t.CPAREN_CODE)this.throwError("Unexpected token ,");else if(e===t.CBRACK_CODE)for(let s=n.length;s":7,"<=":7,">=":7,"<<":8,">>":8,">>>":8,"+":9,"-":9,"*":10,"/":10,"%":10},right_associative:new Set,additional_identifier_chars:new Set(["$","_"]),literals:{true:!0,false:!1,null:null},this_str:"this"});ym.max_unop_len=ym.getMaxKeyLen(ym.unary_ops);ym.max_binop_len=ym.getMaxKeyLen(ym.binary_ops);var If=t=>new ym(t).parse(),Ojt=Object.getOwnPropertyNames(ym);Ojt.forEach(t=>{If[t]===void 0&&t!=="prototype"&&(If[t]=ym[t])});If.Jsep=ym;var Hjt="ConditionalExpression",wjt={name:"ternary",init(t){t.hooks.add("after-expression",function(n){if(n.node&&this.code===t.QUMARK_CODE){this.index++;let i=n.node,o=this.gobbleExpression();if(o||this.throwError("Expected expression"),this.gobbleSpaces(),this.code===t.COLON_CODE){this.index++;let a=this.gobbleExpression();if(a||this.throwError("Expected expression"),n.node={type:Hjt,test:i,consequent:o,alternate:a},i.operator&&t.binary_ops[i.operator]<=.9){let s=i;for(;s.right.operator&&t.binary_ops[s.right.operator]<=.9;)s=s.right;n.node.test=s.right,s.right=n.node,n.node=i}}else this.throwError("Expected :")}})}};If.plugins.register(wjt);var agn=b(W(),1),Pjt={VARIABLE:0,UNARY:1,BINARY:2,TERNARY:3,CONDITIONAL:4,MEMBER:5,FUNCTION_CALL:6,ARRAY:7,REGEX:8,VARIABLE_IN_STRING:9,LITERAL_NULL:10,LITERAL_BOOLEAN:11,LITERAL_NUMBER:12,LITERAL_STRING:13,LITERAL_COLOR:14,LITERAL_VECTOR:15,LITERAL_REGEX:16,LITERAL_UNDEFINED:17,BUILTIN_VARIABLE:18},tn=Object.freeze(Pjt);function hu(t,e){this._expression=t,t=s4t(t,e),t=r4t(l4t(t)),If.addBinaryOp("=~",0),If.addBinaryOp("!~",0);let n;try{n=If(t)}catch(i){throw new Tt(i)}this._runtimeAst=To(this,n)}Object.defineProperties(hu.prototype,{expression:{get:function(){return this._expression}}});var Si={arrayIndex:0,arrayArray:[[]],cartesian2Index:0,cartesian3Index:0,cartesian4Index:0,cartesian2Array:[new K],cartesian3Array:[new p],cartesian4Array:[new bt],reset:function(){this.arrayIndex=0,this.cartesian2Index=0,this.cartesian3Index=0,this.cartesian4Index=0},getArray:function(){this.arrayIndex>=this.arrayArray.length&&this.arrayArray.push([]);let t=this.arrayArray[this.arrayIndex++];return t.length=0,t},getCartesian2:function(){return this.cartesian2Index>=this.cartesian2Array.length&&this.cartesian2Array.push(new K),this.cartesian2Array[this.cartesian2Index++]},getCartesian3:function(){return this.cartesian3Index>=this.cartesian3Array.length&&this.cartesian3Array.push(new p),this.cartesian3Array[this.cartesian3Index++]},getCartesian4:function(){return this.cartesian4Index>=this.cartesian4Array.length&&this.cartesian4Array.push(new bt),this.cartesian4Array[this.cartesian4Index++]}};hu.prototype.evaluate=function(t,e){Si.reset();let n=this._runtimeAst.evaluate(t);return e instanceof v&&n instanceof bt?v.fromCartesian4(n,e):n instanceof K||n instanceof p||n instanceof bt?n.clone(e):n};hu.prototype.evaluateColor=function(t,e){Si.reset();let n=this._runtimeAst.evaluate(t);return v.fromCartesian4(n,e)};hu.prototype.getShaderFunction=function(t,e,n,i){let o=this.getShaderExpression(e,n);return o=`${i} ${t} { return ${o}; } -`,o};hZ.prototype.getShaderExpression=function(t,e){return this._runtimeAst.getShaderExpression(t,e)};hZ.prototype.getVariables=function(){let t=[];return this._runtimeAst.getVariables(t),t=t.filter(function(e,n,i){return i.indexOf(e)===n}),t};var vjt=["!","-","+"],QVt=["+","-","*","/","%","===","!==",">",">=","<","<=","&&","||","!~","=~"],Zw=/\${(.*?)}/g,Kjt=/\\/g,zjt="@#%",jjt=/@#%/g,Vw=new v,bw={abs:Ur(Math.abs),sqrt:Ur(Math.sqrt),cos:Ur(Math.cos),sin:Ur(Math.sin),tan:Ur(Math.tan),acos:Ur(Math.acos),asin:Ur(Math.asin),atan:Ur(Math.atan),radians:Ur(k.toRadians),degrees:Ur(k.toDegrees),sign:Ur(k.sign),floor:Ur(Math.floor),ceil:Ur(Math.ceil),round:Ur(Math.round),exp:Ur(Math.exp),exp2:Ur($jt),log:Ur(Math.log),log2:Ur(t4t),fract:Ur(qjt),length:e4t,normalize:n4t},Rw={atan2:pw(Math.atan2,!1),pow:pw(Math.pow,!1),min:pw(Math.min,!0),max:pw(Math.max,!0),distance:i4t,dot:o4t,cross:a4t},Qq={clamp:kVt(k.clamp,!0),mix:kVt(k.lerp,!0)};function qjt(t){return t-Math.floor(t)}function $jt(t){return Math.pow(2,t)}function t4t(t){return k.log2(t)}function Ur(t){return function(e,n){if(typeof n=="number")return t(n);if(n instanceof K)return K.fromElements(t(n.x),t(n.y),Ti.getCartesian2());if(n instanceof p)return p.fromElements(t(n.x),t(n.y),t(n.z),Ti.getCartesian3());if(n instanceof Rt)return Rt.fromElements(t(n.x),t(n.y),t(n.z),t(n.w),Ti.getCartesian4());throw new St(`Function "${e}" requires a vector or number argument. Argument is ${n}.`)}}function pw(t,e){return function(n,i,o){if(e&&typeof o=="number"){if(typeof i=="number")return t(i,o);if(i instanceof K)return K.fromElements(t(i.x,o),t(i.y,o),Ti.getCartesian2());if(i instanceof p)return p.fromElements(t(i.x,o),t(i.y,o),t(i.z,o),Ti.getCartesian3());if(i instanceof Rt)return Rt.fromElements(t(i.x,o),t(i.y,o),t(i.z,o),t(i.w,o),Ti.getCartesian4())}if(typeof i=="number"&&typeof o=="number")return t(i,o);if(i instanceof K&&o instanceof K)return K.fromElements(t(i.x,o.x),t(i.y,o.y),Ti.getCartesian2());if(i instanceof p&&o instanceof p)return p.fromElements(t(i.x,o.x),t(i.y,o.y),t(i.z,o.z),Ti.getCartesian3());if(i instanceof Rt&&o instanceof Rt)return Rt.fromElements(t(i.x,o.x),t(i.y,o.y),t(i.z,o.z),t(i.w,o.w),Ti.getCartesian4());throw new St(`Function "${n}" requires vector or number arguments of matching types. Arguments are ${i} and ${o}.`)}}function kVt(t,e){return function(n,i,o,a){if(e&&typeof a=="number"){if(typeof i=="number"&&typeof o=="number")return t(i,o,a);if(i instanceof K&&o instanceof K)return K.fromElements(t(i.x,o.x,a),t(i.y,o.y,a),Ti.getCartesian2());if(i instanceof p&&o instanceof p)return p.fromElements(t(i.x,o.x,a),t(i.y,o.y,a),t(i.z,o.z,a),Ti.getCartesian3());if(i instanceof Rt&&o instanceof Rt)return Rt.fromElements(t(i.x,o.x,a),t(i.y,o.y,a),t(i.z,o.z,a),t(i.w,o.w,a),Ti.getCartesian4())}if(typeof i=="number"&&typeof o=="number"&&typeof a=="number")return t(i,o,a);if(i instanceof K&&o instanceof K&&a instanceof K)return K.fromElements(t(i.x,o.x,a.x),t(i.y,o.y,a.y),Ti.getCartesian2());if(i instanceof p&&o instanceof p&&a instanceof p)return p.fromElements(t(i.x,o.x,a.x),t(i.y,o.y,a.y),t(i.z,o.z,a.z),Ti.getCartesian3());if(i instanceof Rt&&o instanceof Rt&&a instanceof Rt)return Rt.fromElements(t(i.x,o.x,a.x),t(i.y,o.y,a.y),t(i.z,o.z,a.z),t(i.w,o.w,a.w),Ti.getCartesian4());throw new St(`Function "${n}" requires vector or number arguments of matching types. Arguments are ${i}, ${o}, and ${a}.`)}}function e4t(t,e){if(typeof e=="number")return Math.abs(e);if(e instanceof K)return K.magnitude(e);if(e instanceof p)return p.magnitude(e);if(e instanceof Rt)return Rt.magnitude(e);throw new St(`Function "${t}" requires a vector or number argument. Argument is ${e}.`)}function n4t(t,e){if(typeof e=="number")return 1;if(e instanceof K)return K.normalize(e,Ti.getCartesian2());if(e instanceof p)return p.normalize(e,Ti.getCartesian3());if(e instanceof Rt)return Rt.normalize(e,Ti.getCartesian4());throw new St(`Function "${t}" requires a vector or number argument. Argument is ${e}.`)}function i4t(t,e,n){if(typeof e=="number"&&typeof n=="number")return Math.abs(e-n);if(e instanceof K&&n instanceof K)return K.distance(e,n);if(e instanceof p&&n instanceof p)return p.distance(e,n);if(e instanceof Rt&&n instanceof Rt)return Rt.distance(e,n);throw new St(`Function "${t}" requires vector or number arguments of matching types. Arguments are ${e} and ${n}.`)}function o4t(t,e,n){if(typeof e=="number"&&typeof n=="number")return e*n;if(e instanceof K&&n instanceof K)return K.dot(e,n);if(e instanceof p&&n instanceof p)return p.dot(e,n);if(e instanceof Rt&&n instanceof Rt)return Rt.dot(e,n);throw new St(`Function "${t}" requires vector or number arguments of matching types. Arguments are ${e} and ${n}.`)}function a4t(t,e,n){if(e instanceof p&&n instanceof p)return p.cross(e,n,Ti.getCartesian3());throw new St(`Function "${t}" requires vec3 arguments. Arguments are ${e} and ${n}.`)}function an(t,e,n,i,o){this._type=t,this._value=e,this._left=n,this._right=i,this._test=o,this.evaluate=void 0,R4t(this)}function s4t(t,e){if(!c(e))return t;for(let n in e)if(e.hasOwnProperty(n)){let i=new RegExp(`\\$\\{${n}\\}`,"g"),o=`(${e[n]})`;c(o)&&(t=t.replace(i,o))}return t}function l4t(t){return t.replace(Kjt,zjt)}function Bq(t){return t.replace(jjt,"\\")}function r4t(t){let e=t,n="",i=e.indexOf("${");for(;i>=0;){let o=e.indexOf("'"),a=e.indexOf('"'),s;if(o>=0&&o=0&&a=0?new an(tn.VARIABLE_IN_STRING,t.value):new an(tn.LITERAL_STRING,Bq(t.value))}function c4t(t,e){let n=e.arguments,i=n.length,o,a,s,l;if(e.callee.type==="MemberExpression"){o=e.callee.property.name;let r=e.callee.object;if(o==="test"||o==="exec"){if(!c(r.callee)||r.callee.name!=="regExp")throw new St(`${o} is not a function.`);return i===0?o==="test"?new an(tn.LITERAL_BOOLEAN,!1):new an(tn.LITERAL_NULL,null):(s=So(t,r),l=So(t,n[0]),new an(tn.FUNCTION_CALL,o,s,l))}else if(o==="toString")return a=So(t,r),new an(tn.FUNCTION_CALL,o,a);throw new St(`Unexpected function call "${o}".`)}if(o=e.callee.name,o==="color"){if(i===0)return new an(tn.LITERAL_COLOR,o);if(a=So(t,n[0]),c(n[1])){let r=So(t,n[1]);return new an(tn.LITERAL_COLOR,o,[a,r])}return new an(tn.LITERAL_COLOR,o,[a])}else if(o==="rgb"||o==="hsl"){if(i<3)throw new St(`${o} requires three arguments.`);return a=[So(t,n[0]),So(t,n[1]),So(t,n[2])],new an(tn.LITERAL_COLOR,o,a)}else if(o==="rgba"||o==="hsla"){if(i<4)throw new St(`${o} requires four arguments.`);return a=[So(t,n[0]),So(t,n[1]),So(t,n[2]),So(t,n[3])],new an(tn.LITERAL_COLOR,o,a)}else if(o==="vec2"||o==="vec3"||o==="vec4"){a=new Array(i);for(let r=0;r1)throw new St(`${o} requires exactly one argument.`);return a=So(t,n[0]),new an(tn.UNARY,o,a)}else if(o==="getExactClassName"){if(i>0)throw new St(`${o} does not take any argument.`);return new an(tn.UNARY,o)}else if(c(bw[o])){if(i!==1)throw new St(`${o} requires exactly one argument.`);return a=So(t,n[0]),new an(tn.UNARY,o,a)}else if(c(Rw[o])){if(i!==2)throw new St(`${o} requires exactly two arguments.`);return s=So(t,n[0]),l=So(t,n[1]),new an(tn.BINARY,o,s,l)}else if(c(Qq[o])){if(i!==3)throw new St(`${o} requires exactly three arguments.`);s=So(t,n[0]),l=So(t,n[1]);let r=So(t,n[2]);return new an(tn.TERNARY,o,s,l,r)}else{if(o==="Boolean")return i===0?new an(tn.LITERAL_BOOLEAN,!1):(a=So(t,n[0]),new an(tn.UNARY,o,a));if(o==="Number")return i===0?new an(tn.LITERAL_NUMBER,0):(a=So(t,n[0]),new an(tn.UNARY,o,a));if(o==="String")return i===0?new an(tn.LITERAL_STRING,""):(a=So(t,n[0]),new an(tn.UNARY,o,a));if(o==="regExp")return m4t(t,e)}}throw new St(`Unexpected function call "${o}".`)}function m4t(t,e){let n=e.arguments;if(n.length===0)return new an(tn.LITERAL_REGEX,new RegExp);let i=So(t,n[0]),o;if(n.length>1){let a=So(t,n[1]);if(yq(i)&&yq(a)){try{o=new RegExp(Bq(String(i._value)),a._value)}catch(s){throw new St(s)}return new an(tn.LITERAL_REGEX,o)}return new an(tn.REGEX,i,a)}if(yq(i)){try{o=new RegExp(Bq(String(i._value)))}catch(a){throw new St(a)}return new an(tn.LITERAL_REGEX,o)}return new an(tn.REGEX,i)}function h4t(t){if(V4t(t.name)){let e=b4t(t.name);return e.substr(0,8)==="tiles3d_"?new an(tn.BUILTIN_VARIABLE,e):new an(tn.VARIABLE,e)}else{if(t.name==="NaN")return new an(tn.LITERAL_NUMBER,NaN);if(t.name==="Infinity")return new an(tn.LITERAL_NUMBER,1/0);if(t.name==="undefined")return new an(tn.LITERAL_UNDEFINED,void 0)}throw new St(`${t.name} is not defined.`)}function p4t(t){let e=t.property.name;if(e==="PI")return new an(tn.LITERAL_NUMBER,Math.PI);if(e==="E")return new an(tn.LITERAL_NUMBER,Math.E)}function u4t(t){if(t.property.name==="POSITIVE_INFINITY")return new an(tn.LITERAL_NUMBER,Number.POSITIVE_INFINITY)}function Z4t(t,e){if(e.object.name==="Math")return p4t(e);if(e.object.name==="Number")return u4t(e);let n,i=So(t,e.object);return e.computed?(n=So(t,e.property),new an(tn.MEMBER,"brackets",i,n)):(n=new an(tn.LITERAL_STRING,e.property.name),new an(tn.MEMBER,"dot",i,n))}function yq(t){return t._type>=tn.LITERAL_NULL}function V4t(t){return t.substr(0,4)==="czm_"}function b4t(t){return t.substr(4)}function So(t,e){let n,i,o,a;if(e.type==="Literal")n=d4t(e);else if(e.type==="CallExpression")n=c4t(t,e);else if(e.type==="Identifier")n=h4t(e);else if(e.type==="UnaryExpression"){i=e.operator;let s=So(t,e.argument);if(vjt.indexOf(i)>-1)n=new an(tn.UNARY,i,s);else throw new St(`Unexpected operator "${i}".`)}else if(e.type==="BinaryExpression")if(i=e.operator,o=So(t,e.left),a=So(t,e.right),QVt.indexOf(i)>-1)n=new an(tn.BINARY,i,o,a);else throw new St(`Unexpected operator "${i}".`);else if(e.type==="LogicalExpression")i=e.operator,o=So(t,e.left),a=So(t,e.right),QVt.indexOf(i)>-1&&(n=new an(tn.BINARY,i,o,a));else if(e.type==="ConditionalExpression"){let s=So(t,e.test);o=So(t,e.consequent),a=So(t,e.alternate),n=new an(tn.CONDITIONAL,"?",o,a,s)}else if(e.type==="MemberExpression")n=Z4t(t,e);else if(e.type==="ArrayExpression"){let s=[];for(let l=0;l"?t.evaluate=t._evaluateGreaterThan:t._value===">="?t.evaluate=t._evaluateGreaterThanOrEquals:t._value==="&&"?t.evaluate=t._evaluateAnd:t._value==="||"?t.evaluate=t._evaluateOr:t._value==="=~"?t.evaluate=t._evaluateRegExpMatch:t._value==="!~"?t.evaluate=t._evaluateRegExpNotMatch:c(Rw[t._value])&&(t.evaluate=F4t(t._value)):t._type===tn.TERNARY?t.evaluate=U4t(t._value):t._type===tn.MEMBER?t._value==="brackets"?t.evaluate=t._evaluateMemberBrackets:t.evaluate=t._evaluateMemberDot:t._type===tn.ARRAY?t.evaluate=t._evaluateArray:t._type===tn.VARIABLE?t.evaluate=t._evaluateVariable:t._type===tn.VARIABLE_IN_STRING?t.evaluate=t._evaluateVariableString:t._type===tn.LITERAL_COLOR?t.evaluate=t._evaluateLiteralColor:t._type===tn.LITERAL_VECTOR?t.evaluate=t._evaluateLiteralVector:t._type===tn.LITERAL_STRING?t.evaluate=t._evaluateLiteralString:t._type===tn.REGEX?t.evaluate=t._evaluateRegExp:t._type===tn.BUILTIN_VARIABLE?t._value==="tiles3d_tileset_time"&&(t.evaluate=W4t):t.evaluate=t._evaluateLiteral}function W4t(t){return c(t)?t.content.tileset.timeSinceLoad:0}function f4t(t){let e=bw[t];return function(n){let i=this._left.evaluate(n);return e(t,i)}}function F4t(t){let e=Rw[t];return function(n){let i=this._left.evaluate(n),o=this._right.evaluate(n);return e(t,i,o)}}function U4t(t){let e=Qq[t];return function(n){let i=this._left.evaluate(n),o=this._right.evaluate(n),a=this._test.evaluate(n);return e(t,i,o,a)}}function Ww(t,e){if(c(t))return t.getPropertyInherited(e)}an.prototype._evaluateLiteral=function(){return this._value};an.prototype._evaluateLiteralColor=function(t){let e=Vw,n=this._left;if(this._value==="color")c(n)?n.length>1?(v.fromCssColorString(n[0].evaluate(t),e),e.alpha=n[1].evaluate(t)):v.fromCssColorString(n[0].evaluate(t),e):v.fromBytes(255,255,255,255,e);else if(this._value==="rgb")v.fromBytes(n[0].evaluate(t),n[1].evaluate(t),n[2].evaluate(t),255,e);else if(this._value==="rgba"){let i=n[3].evaluate(t)*255;v.fromBytes(n[0].evaluate(t),n[1].evaluate(t),n[2].evaluate(t),i,e)}else this._value==="hsl"?v.fromHsl(n[0].evaluate(t),n[1].evaluate(t),n[2].evaluate(t),1,e):this._value==="hsla"&&v.fromHsl(n[0].evaluate(t),n[1].evaluate(t),n[2].evaluate(t),n[3].evaluate(t),e);return Rt.fromColor(e,Ti.getCartesian4())};an.prototype._evaluateLiteralVector=function(t){let e=Ti.getArray(),n=this._value,i=this._left,o=i.length;for(let l=0;l1)throw new St(`Invalid ${n} constructor. Not enough arguments.`);if(a>s&&o>1)throw new St(`Invalid ${n} constructor. Too many arguments.`);if(a===1){let l=e[0];e.push(l,l,l)}if(n==="vec2")return K.fromArray(e,0,Ti.getCartesian2());if(n==="vec3")return p.fromArray(e,0,Ti.getCartesian3());if(n==="vec4")return Rt.fromArray(e,0,Ti.getCartesian4())};an.prototype._evaluateLiteralString=function(){return this._value};an.prototype._evaluateVariableString=function(t){let e=this._value,n=Zw.exec(e);for(;n!==null;){let i=n[0],o=n[1],a=Ww(t,o);c(a)||(a=""),e=e.replace(i,a),n=Zw.exec(e)}return e};an.prototype._evaluateVariable=function(t){return Ww(t,this._value)};function rA(t){return t._value==="feature"}an.prototype._evaluateMemberDot=function(t){if(rA(this._left))return Ww(t,this._right.evaluate(t));let e=this._left.evaluate(t);if(!c(e))return;let n=this._right.evaluate(t);if(e instanceof K||e instanceof p||e instanceof Rt){if(n==="r")return e.x;if(n==="g")return e.y;if(n==="b")return e.z;if(n==="a")return e.w}return e[n]};an.prototype._evaluateMemberBrackets=function(t){if(rA(this._left))return Ww(t,this._right.evaluate(t));let e=this._left.evaluate(t);if(!c(e))return;let n=this._right.evaluate(t);if(e instanceof K||e instanceof p||e instanceof Rt){if(n===0||n==="r")return e.x;if(n===1||n==="g")return e.y;if(n===2||n==="b")return e.z;if(n===3||n==="a")return e.w}return e[n]};an.prototype._evaluateArray=function(t){let e=[];for(let n=0;n" requires number arguments. Arguments are ${e} and ${n}.`);return e>n};an.prototype._evaluateGreaterThanOrEquals=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(typeof e!="number"||typeof n!="number")throw new St(`Operator ">=" requires number arguments. Arguments are ${e} and ${n}.`);return e>=n};an.prototype._evaluateOr=function(t){let e=this._left.evaluate(t);if(typeof e!="boolean")throw new St(`Operator "||" requires boolean arguments. First argument is ${e}.`);if(e)return!0;let n=this._right.evaluate(t);if(typeof n!="boolean")throw new St(`Operator "||" requires boolean arguments. Second argument is ${n}.`);return e||n};an.prototype._evaluateAnd=function(t){let e=this._left.evaluate(t);if(typeof e!="boolean")throw new St(`Operator "&&" requires boolean arguments. First argument is ${e}.`);if(!e)return!1;let n=this._right.evaluate(t);if(typeof n!="boolean")throw new St(`Operator "&&" requires boolean arguments. Second argument is ${n}.`);return e&&n};an.prototype._evaluatePlus=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(n instanceof K&&e instanceof K)return K.add(e,n,Ti.getCartesian2());if(n instanceof p&&e instanceof p)return p.add(e,n,Ti.getCartesian3());if(n instanceof Rt&&e instanceof Rt)return Rt.add(e,n,Ti.getCartesian4());if(typeof e=="string"||typeof n=="string")return e+n;if(typeof e=="number"&&typeof n=="number")return e+n;throw new St(`Operator "+" requires vector or number arguments of matching types, or at least one string argument. Arguments are ${e} and ${n}.`)};an.prototype._evaluateMinus=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(n instanceof K&&e instanceof K)return K.subtract(e,n,Ti.getCartesian2());if(n instanceof p&&e instanceof p)return p.subtract(e,n,Ti.getCartesian3());if(n instanceof Rt&&e instanceof Rt)return Rt.subtract(e,n,Ti.getCartesian4());if(typeof e=="number"&&typeof n=="number")return e-n;throw new St(`Operator "-" requires vector or number arguments of matching types. Arguments are ${e} and ${n}.`)};an.prototype._evaluateTimes=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(n instanceof K&&e instanceof K)return K.multiplyComponents(e,n,Ti.getCartesian2());if(n instanceof K&&typeof e=="number")return K.multiplyByScalar(n,e,Ti.getCartesian2());if(e instanceof K&&typeof n=="number")return K.multiplyByScalar(e,n,Ti.getCartesian2());if(n instanceof p&&e instanceof p)return p.multiplyComponents(e,n,Ti.getCartesian3());if(n instanceof p&&typeof e=="number")return p.multiplyByScalar(n,e,Ti.getCartesian3());if(e instanceof p&&typeof n=="number")return p.multiplyByScalar(e,n,Ti.getCartesian3());if(n instanceof Rt&&e instanceof Rt)return Rt.multiplyComponents(e,n,Ti.getCartesian4());if(n instanceof Rt&&typeof e=="number")return Rt.multiplyByScalar(n,e,Ti.getCartesian4());if(e instanceof Rt&&typeof n=="number")return Rt.multiplyByScalar(e,n,Ti.getCartesian4());if(typeof e=="number"&&typeof n=="number")return e*n;throw new St(`Operator "*" requires vector or number arguments. If both arguments are vectors they must be matching types. Arguments are ${e} and ${n}.`)};an.prototype._evaluateDivide=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(n instanceof K&&e instanceof K)return K.divideComponents(e,n,Ti.getCartesian2());if(e instanceof K&&typeof n=="number")return K.divideByScalar(e,n,Ti.getCartesian2());if(n instanceof p&&e instanceof p)return p.divideComponents(e,n,Ti.getCartesian3());if(e instanceof p&&typeof n=="number")return p.divideByScalar(e,n,Ti.getCartesian3());if(n instanceof Rt&&e instanceof Rt)return Rt.divideComponents(e,n,Ti.getCartesian4());if(e instanceof Rt&&typeof n=="number")return Rt.divideByScalar(e,n,Ti.getCartesian4());if(typeof e=="number"&&typeof n=="number")return e/n;throw new St(`Operator "/" requires vector or number arguments of matching types, or a number as the second argument. Arguments are ${e} and ${n}.`)};an.prototype._evaluateMod=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(n instanceof K&&e instanceof K)return K.fromElements(e.x%n.x,e.y%n.y,Ti.getCartesian2());if(n instanceof p&&e instanceof p)return p.fromElements(e.x%n.x,e.y%n.y,e.z%n.z,Ti.getCartesian3());if(n instanceof Rt&&e instanceof Rt)return Rt.fromElements(e.x%n.x,e.y%n.y,e.z%n.z,e.w%n.w,Ti.getCartesian4());if(typeof e=="number"&&typeof n=="number")return e%n;throw new St(`Operator "%" requires vector or number arguments of matching types. Arguments are ${e} and ${n}.`)};an.prototype._evaluateEqualsStrict=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);return n instanceof K&&e instanceof K||n instanceof p&&e instanceof p||n instanceof Rt&&e instanceof Rt?e.equals(n):e===n};an.prototype._evaluateNotEqualsStrict=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);return n instanceof K&&e instanceof K||n instanceof p&&e instanceof p||n instanceof Rt&&e instanceof Rt?!e.equals(n):e!==n};an.prototype._evaluateConditional=function(t){let e=this._test.evaluate(t);if(typeof e!="boolean")throw new St(`Conditional argument of conditional expression must be a boolean. Argument is ${e}.`);return e?this._left.evaluate(t):this._right.evaluate(t)};an.prototype._evaluateNaN=function(t){return isNaN(this._left.evaluate(t))};an.prototype._evaluateIsFinite=function(t){return isFinite(this._left.evaluate(t))};an.prototype._evaluateIsExactClass=function(t){return c(t)?t.isExactClass(this._left.evaluate(t)):!1};an.prototype._evaluateIsClass=function(t){return c(t)?t.isClass(this._left.evaluate(t)):!1};an.prototype._evaluateGetExactClassName=function(t){if(c(t))return t.getExactClassName()};an.prototype._evaluateBooleanConversion=function(t){return!!this._left.evaluate(t)};an.prototype._evaluateNumberConversion=function(t){return Number(this._left.evaluate(t))};an.prototype._evaluateStringConversion=function(t){return String(this._left.evaluate(t))};an.prototype._evaluateRegExp=function(t){let e=this._value.evaluate(t),n="";c(this._left)&&(n=this._left.evaluate(t));let i;try{i=new RegExp(e,n)}catch(o){throw new St(o)}return i};an.prototype._evaluateRegExpTest=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(!(e instanceof RegExp&&typeof n=="string"))throw new St(`RegExp.test requires the first argument to be a RegExp and the second argument to be a string. Arguments are ${e} and ${n}.`);return e.test(n)};an.prototype._evaluateRegExpMatch=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(e instanceof RegExp&&typeof n=="string")return e.test(n);if(n instanceof RegExp&&typeof e=="string")return n.test(e);throw new St(`Operator "=~" requires one RegExp argument and one string argument. Arguments are ${e} and ${n}.`)};an.prototype._evaluateRegExpNotMatch=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(e instanceof RegExp&&typeof n=="string")return!e.test(n);if(n instanceof RegExp&&typeof e=="string")return!n.test(e);throw new St(`Operator "!~" requires one RegExp argument and one string argument. Arguments are ${e} and ${n}.`)};an.prototype._evaluateRegExpExec=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(!(e instanceof RegExp&&typeof n=="string"))throw new St(`RegExp.exec requires the first argument to be a RegExp and the second argument to be a string. Arguments are ${e} and ${n}.`);let i=e.exec(n);return c(i)?i[1]:null};an.prototype._evaluateToString=function(t){let e=this._left.evaluate(t);if(e instanceof RegExp||e instanceof K||e instanceof p||e instanceof Rt)return String(e);throw new St(`Unexpected function call "${this._value}".`)};function YVt(t){let e=t._left,n=e.length;for(let l=0;l1){let Z=d[0],b=d[1];return b!=="1.0"&&(e.translucent=!0),`vec4(${Z}, ${b})`}}else return"vec4(1.0)";return`vec4(${d[0]}, 1.0)`}else{if(r==="rgb")return i=xVt(this),c(i)?uw(i):`vec4(${d[0]} / 255.0, ${d[1]} / 255.0, ${d[2]} / 255.0, 1.0)`;if(r==="rgba")return d[3]!=="1.0"&&(e.translucent=!0),i=xVt(this),c(i)?uw(i):`vec4(${d[0]} / 255.0, ${d[1]} / 255.0, ${d[2]} / 255.0, ${d[3]})`;if(r==="hsl")return i=YVt(this),c(i)?uw(i):`vec4(czm_HSLToRGB(vec3(${d[0]}, ${d[1]}, ${d[2]})), 1.0)`;if(r==="hsla")return i=YVt(this),c(i)?(i.alpha!==1&&(e.translucent=!0),uw(i)):(d[3]!=="1.0"&&(e.translucent=!0),`vec4(czm_HSLToRGB(vec3(${d[0]}, ${d[1]}, ${d[2]})), ${d[3]})`)}break;case tn.LITERAL_VECTOR:m=o.length,h=`${r}(`;for(let Z=0;Z",">=","<","<=","&&","||","!~","=~"],uw=/\${(.*?)}/g,Kjt=/\\/g,zjt="@#%",jjt=/@#%/g,Zw=new v,Rw={abs:Ur(Math.abs),sqrt:Ur(Math.sqrt),cos:Ur(Math.cos),sin:Ur(Math.sin),tan:Ur(Math.tan),acos:Ur(Math.acos),asin:Ur(Math.asin),atan:Ur(Math.atan),radians:Ur(k.toRadians),degrees:Ur(k.toDegrees),sign:Ur(k.sign),floor:Ur(Math.floor),ceil:Ur(Math.ceil),round:Ur(Math.round),exp:Ur(Math.exp),exp2:Ur($jt),log:Ur(Math.log),log2:Ur(t4t),fract:Ur(qjt),length:e4t,normalize:n4t},bw={atan2:pw(Math.atan2,!1),pow:pw(Math.pow,!1),min:pw(Math.min,!0),max:pw(Math.max,!0),distance:i4t,dot:o4t,cross:a4t},Qq={clamp:kZt(k.clamp,!0),mix:kZt(k.lerp,!0)};function qjt(t){return t-Math.floor(t)}function $jt(t){return Math.pow(2,t)}function t4t(t){return k.log2(t)}function Ur(t){return function(e,n){if(typeof n=="number")return t(n);if(n instanceof K)return K.fromElements(t(n.x),t(n.y),Si.getCartesian2());if(n instanceof p)return p.fromElements(t(n.x),t(n.y),t(n.z),Si.getCartesian3());if(n instanceof bt)return bt.fromElements(t(n.x),t(n.y),t(n.z),t(n.w),Si.getCartesian4());throw new Tt(`Function "${e}" requires a vector or number argument. Argument is ${n}.`)}}function pw(t,e){return function(n,i,o){if(e&&typeof o=="number"){if(typeof i=="number")return t(i,o);if(i instanceof K)return K.fromElements(t(i.x,o),t(i.y,o),Si.getCartesian2());if(i instanceof p)return p.fromElements(t(i.x,o),t(i.y,o),t(i.z,o),Si.getCartesian3());if(i instanceof bt)return bt.fromElements(t(i.x,o),t(i.y,o),t(i.z,o),t(i.w,o),Si.getCartesian4())}if(typeof i=="number"&&typeof o=="number")return t(i,o);if(i instanceof K&&o instanceof K)return K.fromElements(t(i.x,o.x),t(i.y,o.y),Si.getCartesian2());if(i instanceof p&&o instanceof p)return p.fromElements(t(i.x,o.x),t(i.y,o.y),t(i.z,o.z),Si.getCartesian3());if(i instanceof bt&&o instanceof bt)return bt.fromElements(t(i.x,o.x),t(i.y,o.y),t(i.z,o.z),t(i.w,o.w),Si.getCartesian4());throw new Tt(`Function "${n}" requires vector or number arguments of matching types. Arguments are ${i} and ${o}.`)}}function kZt(t,e){return function(n,i,o,a){if(e&&typeof a=="number"){if(typeof i=="number"&&typeof o=="number")return t(i,o,a);if(i instanceof K&&o instanceof K)return K.fromElements(t(i.x,o.x,a),t(i.y,o.y,a),Si.getCartesian2());if(i instanceof p&&o instanceof p)return p.fromElements(t(i.x,o.x,a),t(i.y,o.y,a),t(i.z,o.z,a),Si.getCartesian3());if(i instanceof bt&&o instanceof bt)return bt.fromElements(t(i.x,o.x,a),t(i.y,o.y,a),t(i.z,o.z,a),t(i.w,o.w,a),Si.getCartesian4())}if(typeof i=="number"&&typeof o=="number"&&typeof a=="number")return t(i,o,a);if(i instanceof K&&o instanceof K&&a instanceof K)return K.fromElements(t(i.x,o.x,a.x),t(i.y,o.y,a.y),Si.getCartesian2());if(i instanceof p&&o instanceof p&&a instanceof p)return p.fromElements(t(i.x,o.x,a.x),t(i.y,o.y,a.y),t(i.z,o.z,a.z),Si.getCartesian3());if(i instanceof bt&&o instanceof bt&&a instanceof bt)return bt.fromElements(t(i.x,o.x,a.x),t(i.y,o.y,a.y),t(i.z,o.z,a.z),t(i.w,o.w,a.w),Si.getCartesian4());throw new Tt(`Function "${n}" requires vector or number arguments of matching types. Arguments are ${i}, ${o}, and ${a}.`)}}function e4t(t,e){if(typeof e=="number")return Math.abs(e);if(e instanceof K)return K.magnitude(e);if(e instanceof p)return p.magnitude(e);if(e instanceof bt)return bt.magnitude(e);throw new Tt(`Function "${t}" requires a vector or number argument. Argument is ${e}.`)}function n4t(t,e){if(typeof e=="number")return 1;if(e instanceof K)return K.normalize(e,Si.getCartesian2());if(e instanceof p)return p.normalize(e,Si.getCartesian3());if(e instanceof bt)return bt.normalize(e,Si.getCartesian4());throw new Tt(`Function "${t}" requires a vector or number argument. Argument is ${e}.`)}function i4t(t,e,n){if(typeof e=="number"&&typeof n=="number")return Math.abs(e-n);if(e instanceof K&&n instanceof K)return K.distance(e,n);if(e instanceof p&&n instanceof p)return p.distance(e,n);if(e instanceof bt&&n instanceof bt)return bt.distance(e,n);throw new Tt(`Function "${t}" requires vector or number arguments of matching types. Arguments are ${e} and ${n}.`)}function o4t(t,e,n){if(typeof e=="number"&&typeof n=="number")return e*n;if(e instanceof K&&n instanceof K)return K.dot(e,n);if(e instanceof p&&n instanceof p)return p.dot(e,n);if(e instanceof bt&&n instanceof bt)return bt.dot(e,n);throw new Tt(`Function "${t}" requires vector or number arguments of matching types. Arguments are ${e} and ${n}.`)}function a4t(t,e,n){if(e instanceof p&&n instanceof p)return p.cross(e,n,Si.getCartesian3());throw new Tt(`Function "${t}" requires vec3 arguments. Arguments are ${e} and ${n}.`)}function an(t,e,n,i,o){this._type=t,this._value=e,this._left=n,this._right=i,this._test=o,this.evaluate=void 0,b4t(this)}function s4t(t,e){if(!c(e))return t;for(let n in e)if(e.hasOwnProperty(n)){let i=new RegExp(`\\$\\{${n}\\}`,"g"),o=`(${e[n]})`;c(o)&&(t=t.replace(i,o))}return t}function l4t(t){return t.replace(Kjt,zjt)}function Bq(t){return t.replace(jjt,"\\")}function r4t(t){let e=t,n="",i=e.indexOf("${");for(;i>=0;){let o=e.indexOf("'"),a=e.indexOf('"'),s;if(o>=0&&o=0&&a=0?new an(tn.VARIABLE_IN_STRING,t.value):new an(tn.LITERAL_STRING,Bq(t.value))}function c4t(t,e){let n=e.arguments,i=n.length,o,a,s,l;if(e.callee.type==="MemberExpression"){o=e.callee.property.name;let r=e.callee.object;if(o==="test"||o==="exec"){if(!c(r.callee)||r.callee.name!=="regExp")throw new Tt(`${o} is not a function.`);return i===0?o==="test"?new an(tn.LITERAL_BOOLEAN,!1):new an(tn.LITERAL_NULL,null):(s=To(t,r),l=To(t,n[0]),new an(tn.FUNCTION_CALL,o,s,l))}else if(o==="toString")return a=To(t,r),new an(tn.FUNCTION_CALL,o,a);throw new Tt(`Unexpected function call "${o}".`)}if(o=e.callee.name,o==="color"){if(i===0)return new an(tn.LITERAL_COLOR,o);if(a=To(t,n[0]),c(n[1])){let r=To(t,n[1]);return new an(tn.LITERAL_COLOR,o,[a,r])}return new an(tn.LITERAL_COLOR,o,[a])}else if(o==="rgb"||o==="hsl"){if(i<3)throw new Tt(`${o} requires three arguments.`);return a=[To(t,n[0]),To(t,n[1]),To(t,n[2])],new an(tn.LITERAL_COLOR,o,a)}else if(o==="rgba"||o==="hsla"){if(i<4)throw new Tt(`${o} requires four arguments.`);return a=[To(t,n[0]),To(t,n[1]),To(t,n[2]),To(t,n[3])],new an(tn.LITERAL_COLOR,o,a)}else if(o==="vec2"||o==="vec3"||o==="vec4"){a=new Array(i);for(let r=0;r1)throw new Tt(`${o} requires exactly one argument.`);return a=To(t,n[0]),new an(tn.UNARY,o,a)}else if(o==="getExactClassName"){if(i>0)throw new Tt(`${o} does not take any argument.`);return new an(tn.UNARY,o)}else if(c(Rw[o])){if(i!==1)throw new Tt(`${o} requires exactly one argument.`);return a=To(t,n[0]),new an(tn.UNARY,o,a)}else if(c(bw[o])){if(i!==2)throw new Tt(`${o} requires exactly two arguments.`);return s=To(t,n[0]),l=To(t,n[1]),new an(tn.BINARY,o,s,l)}else if(c(Qq[o])){if(i!==3)throw new Tt(`${o} requires exactly three arguments.`);s=To(t,n[0]),l=To(t,n[1]);let r=To(t,n[2]);return new an(tn.TERNARY,o,s,l,r)}else{if(o==="Boolean")return i===0?new an(tn.LITERAL_BOOLEAN,!1):(a=To(t,n[0]),new an(tn.UNARY,o,a));if(o==="Number")return i===0?new an(tn.LITERAL_NUMBER,0):(a=To(t,n[0]),new an(tn.UNARY,o,a));if(o==="String")return i===0?new an(tn.LITERAL_STRING,""):(a=To(t,n[0]),new an(tn.UNARY,o,a));if(o==="regExp")return m4t(t,e)}}throw new Tt(`Unexpected function call "${o}".`)}function m4t(t,e){let n=e.arguments;if(n.length===0)return new an(tn.LITERAL_REGEX,new RegExp);let i=To(t,n[0]),o;if(n.length>1){let a=To(t,n[1]);if(yq(i)&&yq(a)){try{o=new RegExp(Bq(String(i._value)),a._value)}catch(s){throw new Tt(s)}return new an(tn.LITERAL_REGEX,o)}return new an(tn.REGEX,i,a)}if(yq(i)){try{o=new RegExp(Bq(String(i._value)))}catch(a){throw new Tt(a)}return new an(tn.LITERAL_REGEX,o)}return new an(tn.REGEX,i)}function h4t(t){if(Z4t(t.name)){let e=R4t(t.name);return e.substr(0,8)==="tiles3d_"?new an(tn.BUILTIN_VARIABLE,e):new an(tn.VARIABLE,e)}else{if(t.name==="NaN")return new an(tn.LITERAL_NUMBER,NaN);if(t.name==="Infinity")return new an(tn.LITERAL_NUMBER,1/0);if(t.name==="undefined")return new an(tn.LITERAL_UNDEFINED,void 0)}throw new Tt(`${t.name} is not defined.`)}function p4t(t){let e=t.property.name;if(e==="PI")return new an(tn.LITERAL_NUMBER,Math.PI);if(e==="E")return new an(tn.LITERAL_NUMBER,Math.E)}function V4t(t){if(t.property.name==="POSITIVE_INFINITY")return new an(tn.LITERAL_NUMBER,Number.POSITIVE_INFINITY)}function u4t(t,e){if(e.object.name==="Math")return p4t(e);if(e.object.name==="Number")return V4t(e);let n,i=To(t,e.object);return e.computed?(n=To(t,e.property),new an(tn.MEMBER,"brackets",i,n)):(n=new an(tn.LITERAL_STRING,e.property.name),new an(tn.MEMBER,"dot",i,n))}function yq(t){return t._type>=tn.LITERAL_NULL}function Z4t(t){return t.substr(0,4)==="czm_"}function R4t(t){return t.substr(4)}function To(t,e){let n,i,o,a;if(e.type==="Literal")n=d4t(e);else if(e.type==="CallExpression")n=c4t(t,e);else if(e.type==="Identifier")n=h4t(e);else if(e.type==="UnaryExpression"){i=e.operator;let s=To(t,e.argument);if(vjt.indexOf(i)>-1)n=new an(tn.UNARY,i,s);else throw new Tt(`Unexpected operator "${i}".`)}else if(e.type==="BinaryExpression")if(i=e.operator,o=To(t,e.left),a=To(t,e.right),QZt.indexOf(i)>-1)n=new an(tn.BINARY,i,o,a);else throw new Tt(`Unexpected operator "${i}".`);else if(e.type==="LogicalExpression")i=e.operator,o=To(t,e.left),a=To(t,e.right),QZt.indexOf(i)>-1&&(n=new an(tn.BINARY,i,o,a));else if(e.type==="ConditionalExpression"){let s=To(t,e.test);o=To(t,e.consequent),a=To(t,e.alternate),n=new an(tn.CONDITIONAL,"?",o,a,s)}else if(e.type==="MemberExpression")n=u4t(t,e);else if(e.type==="ArrayExpression"){let s=[];for(let l=0;l"?t.evaluate=t._evaluateGreaterThan:t._value===">="?t.evaluate=t._evaluateGreaterThanOrEquals:t._value==="&&"?t.evaluate=t._evaluateAnd:t._value==="||"?t.evaluate=t._evaluateOr:t._value==="=~"?t.evaluate=t._evaluateRegExpMatch:t._value==="!~"?t.evaluate=t._evaluateRegExpNotMatch:c(bw[t._value])&&(t.evaluate=F4t(t._value)):t._type===tn.TERNARY?t.evaluate=U4t(t._value):t._type===tn.MEMBER?t._value==="brackets"?t.evaluate=t._evaluateMemberBrackets:t.evaluate=t._evaluateMemberDot:t._type===tn.ARRAY?t.evaluate=t._evaluateArray:t._type===tn.VARIABLE?t.evaluate=t._evaluateVariable:t._type===tn.VARIABLE_IN_STRING?t.evaluate=t._evaluateVariableString:t._type===tn.LITERAL_COLOR?t.evaluate=t._evaluateLiteralColor:t._type===tn.LITERAL_VECTOR?t.evaluate=t._evaluateLiteralVector:t._type===tn.LITERAL_STRING?t.evaluate=t._evaluateLiteralString:t._type===tn.REGEX?t.evaluate=t._evaluateRegExp:t._type===tn.BUILTIN_VARIABLE?t._value==="tiles3d_tileset_time"&&(t.evaluate=W4t):t.evaluate=t._evaluateLiteral}function W4t(t){return c(t)?t.content.tileset.timeSinceLoad:0}function f4t(t){let e=Rw[t];return function(n){let i=this._left.evaluate(n);return e(t,i)}}function F4t(t){let e=bw[t];return function(n){let i=this._left.evaluate(n),o=this._right.evaluate(n);return e(t,i,o)}}function U4t(t){let e=Qq[t];return function(n){let i=this._left.evaluate(n),o=this._right.evaluate(n),a=this._test.evaluate(n);return e(t,i,o,a)}}function Ww(t,e){if(c(t))return t.getPropertyInherited(e)}an.prototype._evaluateLiteral=function(){return this._value};an.prototype._evaluateLiteralColor=function(t){let e=Zw,n=this._left;if(this._value==="color")c(n)?n.length>1?(v.fromCssColorString(n[0].evaluate(t),e),e.alpha=n[1].evaluate(t)):v.fromCssColorString(n[0].evaluate(t),e):v.fromBytes(255,255,255,255,e);else if(this._value==="rgb")v.fromBytes(n[0].evaluate(t),n[1].evaluate(t),n[2].evaluate(t),255,e);else if(this._value==="rgba"){let i=n[3].evaluate(t)*255;v.fromBytes(n[0].evaluate(t),n[1].evaluate(t),n[2].evaluate(t),i,e)}else this._value==="hsl"?v.fromHsl(n[0].evaluate(t),n[1].evaluate(t),n[2].evaluate(t),1,e):this._value==="hsla"&&v.fromHsl(n[0].evaluate(t),n[1].evaluate(t),n[2].evaluate(t),n[3].evaluate(t),e);return bt.fromColor(e,Si.getCartesian4())};an.prototype._evaluateLiteralVector=function(t){let e=Si.getArray(),n=this._value,i=this._left,o=i.length;for(let l=0;l1)throw new Tt(`Invalid ${n} constructor. Not enough arguments.`);if(a>s&&o>1)throw new Tt(`Invalid ${n} constructor. Too many arguments.`);if(a===1){let l=e[0];e.push(l,l,l)}if(n==="vec2")return K.fromArray(e,0,Si.getCartesian2());if(n==="vec3")return p.fromArray(e,0,Si.getCartesian3());if(n==="vec4")return bt.fromArray(e,0,Si.getCartesian4())};an.prototype._evaluateLiteralString=function(){return this._value};an.prototype._evaluateVariableString=function(t){let e=this._value,n=uw.exec(e);for(;n!==null;){let i=n[0],o=n[1],a=Ww(t,o);c(a)||(a=""),e=e.replace(i,a),n=uw.exec(e)}return e};an.prototype._evaluateVariable=function(t){return Ww(t,this._value)};function rA(t){return t._value==="feature"}an.prototype._evaluateMemberDot=function(t){if(rA(this._left))return Ww(t,this._right.evaluate(t));let e=this._left.evaluate(t);if(!c(e))return;let n=this._right.evaluate(t);if(e instanceof K||e instanceof p||e instanceof bt){if(n==="r")return e.x;if(n==="g")return e.y;if(n==="b")return e.z;if(n==="a")return e.w}return e[n]};an.prototype._evaluateMemberBrackets=function(t){if(rA(this._left))return Ww(t,this._right.evaluate(t));let e=this._left.evaluate(t);if(!c(e))return;let n=this._right.evaluate(t);if(e instanceof K||e instanceof p||e instanceof bt){if(n===0||n==="r")return e.x;if(n===1||n==="g")return e.y;if(n===2||n==="b")return e.z;if(n===3||n==="a")return e.w}return e[n]};an.prototype._evaluateArray=function(t){let e=[];for(let n=0;n" requires number arguments. Arguments are ${e} and ${n}.`);return e>n};an.prototype._evaluateGreaterThanOrEquals=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(typeof e!="number"||typeof n!="number")throw new Tt(`Operator ">=" requires number arguments. Arguments are ${e} and ${n}.`);return e>=n};an.prototype._evaluateOr=function(t){let e=this._left.evaluate(t);if(typeof e!="boolean")throw new Tt(`Operator "||" requires boolean arguments. First argument is ${e}.`);if(e)return!0;let n=this._right.evaluate(t);if(typeof n!="boolean")throw new Tt(`Operator "||" requires boolean arguments. Second argument is ${n}.`);return e||n};an.prototype._evaluateAnd=function(t){let e=this._left.evaluate(t);if(typeof e!="boolean")throw new Tt(`Operator "&&" requires boolean arguments. First argument is ${e}.`);if(!e)return!1;let n=this._right.evaluate(t);if(typeof n!="boolean")throw new Tt(`Operator "&&" requires boolean arguments. Second argument is ${n}.`);return e&&n};an.prototype._evaluatePlus=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(n instanceof K&&e instanceof K)return K.add(e,n,Si.getCartesian2());if(n instanceof p&&e instanceof p)return p.add(e,n,Si.getCartesian3());if(n instanceof bt&&e instanceof bt)return bt.add(e,n,Si.getCartesian4());if(typeof e=="string"||typeof n=="string")return e+n;if(typeof e=="number"&&typeof n=="number")return e+n;throw new Tt(`Operator "+" requires vector or number arguments of matching types, or at least one string argument. Arguments are ${e} and ${n}.`)};an.prototype._evaluateMinus=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(n instanceof K&&e instanceof K)return K.subtract(e,n,Si.getCartesian2());if(n instanceof p&&e instanceof p)return p.subtract(e,n,Si.getCartesian3());if(n instanceof bt&&e instanceof bt)return bt.subtract(e,n,Si.getCartesian4());if(typeof e=="number"&&typeof n=="number")return e-n;throw new Tt(`Operator "-" requires vector or number arguments of matching types. Arguments are ${e} and ${n}.`)};an.prototype._evaluateTimes=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(n instanceof K&&e instanceof K)return K.multiplyComponents(e,n,Si.getCartesian2());if(n instanceof K&&typeof e=="number")return K.multiplyByScalar(n,e,Si.getCartesian2());if(e instanceof K&&typeof n=="number")return K.multiplyByScalar(e,n,Si.getCartesian2());if(n instanceof p&&e instanceof p)return p.multiplyComponents(e,n,Si.getCartesian3());if(n instanceof p&&typeof e=="number")return p.multiplyByScalar(n,e,Si.getCartesian3());if(e instanceof p&&typeof n=="number")return p.multiplyByScalar(e,n,Si.getCartesian3());if(n instanceof bt&&e instanceof bt)return bt.multiplyComponents(e,n,Si.getCartesian4());if(n instanceof bt&&typeof e=="number")return bt.multiplyByScalar(n,e,Si.getCartesian4());if(e instanceof bt&&typeof n=="number")return bt.multiplyByScalar(e,n,Si.getCartesian4());if(typeof e=="number"&&typeof n=="number")return e*n;throw new Tt(`Operator "*" requires vector or number arguments. If both arguments are vectors they must be matching types. Arguments are ${e} and ${n}.`)};an.prototype._evaluateDivide=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(n instanceof K&&e instanceof K)return K.divideComponents(e,n,Si.getCartesian2());if(e instanceof K&&typeof n=="number")return K.divideByScalar(e,n,Si.getCartesian2());if(n instanceof p&&e instanceof p)return p.divideComponents(e,n,Si.getCartesian3());if(e instanceof p&&typeof n=="number")return p.divideByScalar(e,n,Si.getCartesian3());if(n instanceof bt&&e instanceof bt)return bt.divideComponents(e,n,Si.getCartesian4());if(e instanceof bt&&typeof n=="number")return bt.divideByScalar(e,n,Si.getCartesian4());if(typeof e=="number"&&typeof n=="number")return e/n;throw new Tt(`Operator "/" requires vector or number arguments of matching types, or a number as the second argument. Arguments are ${e} and ${n}.`)};an.prototype._evaluateMod=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(n instanceof K&&e instanceof K)return K.fromElements(e.x%n.x,e.y%n.y,Si.getCartesian2());if(n instanceof p&&e instanceof p)return p.fromElements(e.x%n.x,e.y%n.y,e.z%n.z,Si.getCartesian3());if(n instanceof bt&&e instanceof bt)return bt.fromElements(e.x%n.x,e.y%n.y,e.z%n.z,e.w%n.w,Si.getCartesian4());if(typeof e=="number"&&typeof n=="number")return e%n;throw new Tt(`Operator "%" requires vector or number arguments of matching types. Arguments are ${e} and ${n}.`)};an.prototype._evaluateEqualsStrict=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);return n instanceof K&&e instanceof K||n instanceof p&&e instanceof p||n instanceof bt&&e instanceof bt?e.equals(n):e===n};an.prototype._evaluateNotEqualsStrict=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);return n instanceof K&&e instanceof K||n instanceof p&&e instanceof p||n instanceof bt&&e instanceof bt?!e.equals(n):e!==n};an.prototype._evaluateConditional=function(t){let e=this._test.evaluate(t);if(typeof e!="boolean")throw new Tt(`Conditional argument of conditional expression must be a boolean. Argument is ${e}.`);return e?this._left.evaluate(t):this._right.evaluate(t)};an.prototype._evaluateNaN=function(t){return isNaN(this._left.evaluate(t))};an.prototype._evaluateIsFinite=function(t){return isFinite(this._left.evaluate(t))};an.prototype._evaluateIsExactClass=function(t){return c(t)?t.isExactClass(this._left.evaluate(t)):!1};an.prototype._evaluateIsClass=function(t){return c(t)?t.isClass(this._left.evaluate(t)):!1};an.prototype._evaluateGetExactClassName=function(t){if(c(t))return t.getExactClassName()};an.prototype._evaluateBooleanConversion=function(t){return!!this._left.evaluate(t)};an.prototype._evaluateNumberConversion=function(t){return Number(this._left.evaluate(t))};an.prototype._evaluateStringConversion=function(t){return String(this._left.evaluate(t))};an.prototype._evaluateRegExp=function(t){let e=this._value.evaluate(t),n="";c(this._left)&&(n=this._left.evaluate(t));let i;try{i=new RegExp(e,n)}catch(o){throw new Tt(o)}return i};an.prototype._evaluateRegExpTest=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(!(e instanceof RegExp&&typeof n=="string"))throw new Tt(`RegExp.test requires the first argument to be a RegExp and the second argument to be a string. Arguments are ${e} and ${n}.`);return e.test(n)};an.prototype._evaluateRegExpMatch=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(e instanceof RegExp&&typeof n=="string")return e.test(n);if(n instanceof RegExp&&typeof e=="string")return n.test(e);throw new Tt(`Operator "=~" requires one RegExp argument and one string argument. Arguments are ${e} and ${n}.`)};an.prototype._evaluateRegExpNotMatch=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(e instanceof RegExp&&typeof n=="string")return!e.test(n);if(n instanceof RegExp&&typeof e=="string")return!n.test(e);throw new Tt(`Operator "!~" requires one RegExp argument and one string argument. Arguments are ${e} and ${n}.`)};an.prototype._evaluateRegExpExec=function(t){let e=this._left.evaluate(t),n=this._right.evaluate(t);if(!(e instanceof RegExp&&typeof n=="string"))throw new Tt(`RegExp.exec requires the first argument to be a RegExp and the second argument to be a string. Arguments are ${e} and ${n}.`);let i=e.exec(n);return c(i)?i[1]:null};an.prototype._evaluateToString=function(t){let e=this._left.evaluate(t);if(e instanceof RegExp||e instanceof K||e instanceof p||e instanceof bt)return String(e);throw new Tt(`Unexpected function call "${this._value}".`)};function YZt(t){let e=t._left,n=e.length;for(let l=0;l1){let u=d[0],R=d[1];return R!=="1.0"&&(e.translucent=!0),`vec4(${u}, ${R})`}}else return"vec4(1.0)";return`vec4(${d[0]}, 1.0)`}else{if(r==="rgb")return i=xZt(this),c(i)?Vw(i):`vec4(${d[0]} / 255.0, ${d[1]} / 255.0, ${d[2]} / 255.0, 1.0)`;if(r==="rgba")return d[3]!=="1.0"&&(e.translucent=!0),i=xZt(this),c(i)?Vw(i):`vec4(${d[0]} / 255.0, ${d[1]} / 255.0, ${d[2]} / 255.0, ${d[3]})`;if(r==="hsl")return i=YZt(this),c(i)?Vw(i):`vec4(czm_HSLToRGB(vec3(${d[0]}, ${d[1]}, ${d[2]})), 1.0)`;if(r==="hsla")return i=YZt(this),c(i)?(i.alpha!==1&&(e.translucent=!0),Vw(i)):(d[3]!=="1.0"&&(e.translucent=!0),`vec4(czm_HSLToRGB(vec3(${d[0]}, ${d[1]}, ${d[2]})), ${d[3]})`)}break;case tn.LITERAL_VECTOR:m=o.length,h=`${r}(`;for(let u=0;u0;){let m=e.pop();if(v.equals(m.color,l.color))d=kq(n,s,d,i,o,m.batchIds,a),l.batchIds=l.batchIds.concat(m.batchIds),l.count=d-l.offset;else{let h=d;d=kq(n,s,d,i,o,m.batchIds,a),m.offset=h,m.count=d-h,r.push(m),l=m}}t._va.indexBuffer.copyFromArrayView(s),t._indices=s,t._batchedIndices=r}function Yq(t,e,n,i,o,a,s){let l=t.bytesPerIndex,r=a.length;for(let d=0;d0;){let h=e.pop();if(v.equals(h.color,a.color))d=Yq(l,r,d,n,i,h.batchIds,o),a.batchIds=a.batchIds.concat(h.batchIds),a.count=d-a.offset;else{let Z=d;d=Yq(l,r,d,n,i,h.batchIds,o),h.offset=Z,h.count=d-Z,s.push(h),a=h}}let m=t._va;t._va=t._vaSwap,t._vaSwap=m,t._batchedIndices=s}function B4t(t,e){return e.color.toRgba()-t.color.toRgba()}function Q4t(t,e){if(!t._batchDirty)return!1;let n=t._batchedIndices,i=n.length,o=!1,a={};for(let s=0;s=F&&s{t.isDestroyed()||(t._error=u)}):void 0}}function z4t(t){c(t._primitive)||(t._primitive=new cA({batchTable:t._batchTable,positions:t._positions,batchIds:t._batchIds,vertexBatchIds:t._vertexBatchIds,indices:t._indices,indexOffsets:t._indexOffsets,indexCounts:t._indexCounts,batchedIndices:t._batchedIndices,boundingVolume:t._boundingVolume,boundingVolumes:t._boundingVolumes,center:t._center,pickObject:f(t._pickObject,t)}),t._boxes=void 0,t._boxBatchIds=void 0,t._cylinders=void 0,t._cylinderBatchIds=void 0,t._ellipsoids=void 0,t._ellipsoidBatchIds=void 0,t._spheres=void 0,t._sphereBatchIds=void 0,t._center=void 0,t._modelMatrix=void 0,t._batchTable=void 0,t._boundingVolume=void 0,t._boundingVolumes=void 0,t._batchedIndices=void 0,t._indices=void 0,t._indexOffsets=void 0,t._indexCounts=void 0,t._positions=void 0,t._vertexBatchIds=void 0,t._batchIds=void 0,t._batchTableColors=void 0,t._packedBuffer=void 0,t._verticesPromise=void 0)}Ch.prototype.createFeatures=function(t,e){this._primitive.createFeatures(t,e)};Ch.prototype.applyDebugSettings=function(t,e){this._primitive.applyDebugSettings(t,e)};Ch.prototype.applyStyle=function(t,e){this._primitive.applyStyle(t,e)};Ch.prototype.updateCommands=function(t,e){this._primitive.updateCommands(t,e)};Ch.prototype.update=function(t){if(!this._ready){if(c(this._promise)||(this._promise=K4t(this)),c(this._error)){let e=this._error;throw this._error=void 0,e}return}this._primitive.debugWireframe=this.debugWireframe,this._primitive.forceRebatch=this.forceRebatch,this._primitive.classificationType=this.classificationType,this._primitive.update(t)};Ch.prototype.isDestroyed=function(){return!1};Ch.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),At(this)};var vR=Ch;function KV(t,e,n,i,o){this._tileset=t,this._tile=e,this._resource=n,this._geometries=void 0,this._metadata=void 0,this._batchTable=void 0,this._features=void 0,this.featurePropertiesDirty=!1,this._group=void 0,this._ready=!1,$4t(this,i,o)}Object.defineProperties(KV.prototype,{featuresLength:{get:function(){return c(this._batchTable)?this._batchTable.featuresLength:0}},pointsLength:{get:function(){return 0}},trianglesLength:{get:function(){return c(this._geometries)?this._geometries.trianglesLength:0}},geometryByteLength:{get:function(){return c(this._geometries)?this._geometries.geometryByteLength:0}},texturesByteLength:{get:function(){return 0}},batchTableByteLength:{get:function(){return c(this._batchTable)?this._batchTable.batchTableByteLength:0}},innerContents:{get:function(){}},ready:{get:function(){return this._ready}},tileset:{get:function(){return this._tileset}},tile:{get:function(){return this._tile}},url:{get:function(){return this._resource.getUrlComponent(!0)}},metadata:{get:function(){return this._metadata},set:function(t){this._metadata=t}},batchTable:{get:function(){return this._batchTable}},group:{get:function(){return this._group},set:function(t){this._group=t}}});function j4t(t){return function(e,n){c(t._geometries)&&t._geometries.updateCommands(e,n)}}function q4t(t,e){let n,i,o,a,s,l=f(t.BOXES_LENGTH,0),r=f(t.CYLINDERS_LENGTH,0),d=f(t.ELLIPSOIDS_LENGTH,0),m=f(t.SPHERES_LENGTH,0);if(l>0&&c(t.BOX_BATCH_IDS)){let u=e.byteOffset+t.BOX_BATCH_IDS.byteOffset;n=new Uint16Array(e.buffer,u,l)}if(r>0&&c(t.CYLINDER_BATCH_IDS)){let u=e.byteOffset+t.CYLINDER_BATCH_IDS.byteOffset;i=new Uint16Array(e.buffer,u,r)}if(d>0&&c(t.ELLIPSOID_BATCH_IDS)){let u=e.byteOffset+t.ELLIPSOID_BATCH_IDS.byteOffset;o=new Uint16Array(e.buffer,u,d)}if(m>0&&c(t.SPHERE_BATCH_IDS)){let u=e.byteOffset+t.SPHERE_BATCH_IDS.byteOffset;a=new Uint16Array(e.buffer,u,m)}let h=c(n)||c(i)||c(o)||c(a),Z=l>0&&!c(n)||r>0&&!c(i)||d>0&&!c(o)||m>0&&!c(a);if(h&&Z)throw new St("If one group of batch ids is defined, then all batch ids must be defined");if(!c(n)&&!c(i)&&!c(o)&&!c(a)){let u=0;if(!c(n)&&l>0)for(n=new Uint16Array(l),s=0;s0)for(i=new Uint16Array(r),s=0;s0)for(o=new Uint16Array(d),s=0;s0)for(a=new Uint16Array(m),s=0;s0&&(b=ts(i,n,d),n+=d,m>0&&(u=new Uint8Array(e,n,m),u=new Uint8Array(u)));let F=f(h.BOXES_LENGTH,0),U=f(h.CYLINDERS_LENGTH,0),G=f(h.ELLIPSOIDS_LENGTH,0),A=f(h.SPHERES_LENGTH,0),T=F+U+G+A,g=new wR(t,T,b,u,j4t(t));if(t._batchTable=g,T===0)return;let C=t.tile.computedTransform,y;c(h.RTC_CENTER)&&(y=p.unpack(h.RTC_CENTER),L.multiplyByPoint(C,y,y));let Y=q4t(h,Z);if(F>0||U>0||G>0||A>0){let Q,J,M,V;if(F>0){let E=Z.byteOffset+h.BOXES.byteOffset;Q=new Float32Array(Z.buffer,E,vR.packedBoxLength*F)}if(U>0){let E=Z.byteOffset+h.CYLINDERS.byteOffset;J=new Float32Array(Z.buffer,E,vR.packedCylinderLength*U)}if(G>0){let E=Z.byteOffset+h.ELLIPSOIDS.byteOffset;M=new Float32Array(Z.buffer,E,vR.packedEllipsoidLength*G)}if(A>0){let E=Z.byteOffset+h.SPHERES.byteOffset;V=new Float32Array(Z.buffer,E,vR.packedSphereLength*A)}return t._geometries=new vR({boxes:Q,boxBatchIds:Y.boxes,cylinders:J,cylinderBatchIds:Y.cylinders,ellipsoids:M,ellipsoidBatchIds:Y.ellipsoids,spheres:V,sphereBatchIds:Y.spheres,center:y,modelMatrix:C,batchTable:g,boundingVolume:t.tile.boundingVolume.boundingVolume}),t}return Promise.resolve(t)}function DVt(t){let e=t.featuresLength;if(!c(t._features)&&e>0){let n=new Array(e);c(t._geometries)&&t._geometries.createFeatures(t,n),t._features=n}}KV.prototype.hasProperty=function(t,e){return this._batchTable.hasProperty(t,e)};KV.prototype.getFeature=function(t){return DVt(this),this._features[t]};KV.prototype.applyDebugSettings=function(t,e){c(this._geometries)&&this._geometries.applyDebugSettings(t,e)};KV.prototype.applyStyle=function(t){DVt(this),c(this._geometries)&&this._geometries.applyStyle(t,this._features)};KV.prototype.update=function(t,e){c(this._geometries)&&(this._geometries.classificationType=this._tileset.classificationType,this._geometries.debugWireframe=this._tileset.debugWireframe,this._geometries.update(e)),c(this._batchTable)&&this._geometries.ready&&(this._batchTable.update(t,e),this._ready=!0)};KV.prototype.pick=function(t,e,n){};KV.prototype.isDestroyed=function(){return!1};KV.prototype.destroy=function(){return this._geometries=this._geometries&&this._geometries.destroy(),this._batchTable=this._batchTable&&this._batchTable.destroy(),At(this)};var Xk=KV;var z2n=R(W(),1);var REn=R(W(),1);var xq={};xq.encode2D=function(t,e,n){let i=Math.pow(2,t),o={x:e,y:n},a,s,l,r=BigInt(0);for(l=i/2;l>0;l/=2)a=(o.x&l)>0?1:0,s=(o.y&l)>0?1:0,r+=BigInt((3*a^s)*l*l),OVt(i,o,a,s);return r};xq.decode2D=function(t,e){let n=Math.pow(2,t),i={x:0,y:0},o,a,s,l;for(s=1,l=e;s>>0,Xq=2*hA+1,yf=4,PVt=[],vVt=[],n8t=[[0,1,3,2],[0,2,3,1],[3,2,0,1],[3,1,0,2]],Bf=1,NE=2,fw=[Bf,0,0,Bf|NE];function Gl(t){if(!In.supportsBigInt())throw new St("S2 required BigInt support");this._cellId=t,this._level=Gl.getLevel(t)}Gl.fromToken=function(t){return new Gl(Gl.getIdFromToken(t))};Gl.isValidId=function(t){return!(t<=0||t>>BigInt(Xq)>5||!(t&~t+BigInt(1)&BigInt("0x1555555555555555")))};Gl.isValidToken=function(t){return/^[0-9a-fA-F]{1,16}$/.test(t)?Gl.isValidId(Gl.getIdFromToken(t)):!1};Gl.getIdFromToken=function(t){return BigInt("0x"+t+"0".repeat(16-t.length))};Gl.getTokenFromId=function(t){let e=Math.floor(h8t(t)/4),n=t.toString(16).replace(/0*$/,"");return Array(17-e-n.length).join("0")+n};Gl.getLevel=function(t){let e=0;for(;t!==BigInt(0)&&!(t&BigInt(1));)e++,t=t>>BigInt(1);return hA-(e>>1)};Gl.prototype.getChild=function(t){let e=jVt(this._cellId)>>BigInt(2),n=this._cellId+BigInt(2*t+1-4)*e;return new Gl(n)};Gl.prototype.getParent=function(){let t=jVt(this._cellId)<>1&1;return zVt(i[0],o[0][a^n&1],o[1][a])}function a8t(t,e){let n=KVt(t),i=n[0],o=n[1],a=n[2],s=e===30,l=!s&&(BigInt(o)^t>>BigInt(2))&BigInt(1),r=s?1:l?2:0,d=(o<<1)+r,m=(a<<1)+r;return[i,d,m]}function KVt(t){PVt.length===0&&d8t();let e=Number(t>>BigInt(Xq)),n=e&Bf,i=(1<=0;s--){let r=(1<<2*(s===7?hA-7*yf:yf))-1;n+=Number(t>>BigInt(s*2*yf+1)&BigInt(r))<<2,n=vVt[n];let d=s*yf;o+=n>>yf+2<>2&i)<=.5?1/3*(4*t*t-1):1/3*(1-4*(1-t)*(1-t))}function HVt(t){return 1/e8t*t}function l8t(t,e){let n=[[],[]],i=r8t(e);for(let o=0;o<2;++o){let a=t[o]&-i,s=a+i;n[o][0]=Fw(wVt(a)),n[o][1]=Fw(wVt(s))}return n}function r8t(t){return 1<>>0}function wVt(t){return 1/t8t*t}function Qf(t,e,n,i,o,a){if(t===yf){let s=(e<>1),n+(s[0]&1),i,o,a^fw[0]),Qf(t,e+(s[1]>>1),n+(s[1]&1),i,o+1,a^fw[1]),Qf(t,e+(s[2]>>1),n+(s[2]&1),i,o+2,a^fw[2]),Qf(t,e+(s[3]>>1),n+(s[3]&1),i,o+3,a^fw[3])}}function d8t(){Qf(0,0,0,0,0,0),Qf(0,0,0,Bf,0,Bf),Qf(0,0,0,NE,0,NE),Qf(0,0,0,Bf|NE,0,Bf|NE)}function jVt(t){return t&~t+BigInt(1)}function c8t(t){return BigInt(1)<>3,a=i%8;n+=t[o]>>a&1}return n}Object.defineProperties(Jq.prototype,{lengthBits:{get:function(){return this._lengthBits}},availableCount:{get:function(){return this._availableCount}}});Jq.prototype.getBit=function(t){if(c(this._constant))return this._constant;let e=t>>3,n=t%8;return(this._bitstream[e]>>n&1)===1};var yE=Jq;var xEn=R(W(),1);function zR(t){t=f(t,f.EMPTY_OBJECT);let e=t.metadataTable,n=t.class,i=t.entityId,o=t.propertyTableJson;this._class=n,this._metadataTable=e,this._entityId=i,this._extensions=o.extensions,this._extras=o.extras}Object.defineProperties(zR.prototype,{class:{get:function(){return this._class}},extras:{get:function(){return this._extras}},extensions:{get:function(){return this._extensions}}});zR.prototype.hasProperty=function(t){return this._metadataTable.hasProperty(t)};zR.prototype.hasPropertyBySemantic=function(t){return this._metadataTable.hasPropertyBySemantic(t)};zR.prototype.getPropertyIds=function(t){return this._metadataTable.getPropertyIds(t)};zR.prototype.getProperty=function(t){return this._metadataTable.getProperty(this._entityId,t)};zR.prototype.setProperty=function(t,e){return this._metadataTable.setProperty(this._entityId,t,e)};zR.prototype.getPropertyBySemantic=function(t){return this._metadataTable.getPropertyBySemantic(this._entityId,t)};zR.prototype.setPropertyBySemantic=function(t,e){return this._metadataTable.setPropertyBySemantic(this._entityId,t,e)};var BE=zR;var JEn=R(W(),1);var Uw={QUADTREE:"QUADTREE",OCTREE:"OCTREE"};Uw.getBranchingFactor=function(t){switch(t){case Uw.OCTREE:return 8;case Uw.QUADTREE:return 4}};var Al=Object.freeze(Uw);var KEn=R(W(),1);var OEn=R(W(),1);function Dr(){}Object.defineProperties(Dr.prototype,{class:{get:function(){Ut.throwInstantiationError()}}});Dr.prototype.hasProperty=function(t){Ut.throwInstantiationError()};Dr.prototype.hasPropertyBySemantic=function(t){Ut.throwInstantiationError()};Dr.prototype.getPropertyIds=function(t){Ut.throwInstantiationError()};Dr.prototype.getProperty=function(t){Ut.throwInstantiationError()};Dr.prototype.setProperty=function(t,e){Ut.throwInstantiationError()};Dr.prototype.getPropertyBySemantic=function(t){Ut.throwInstantiationError()};Dr.prototype.setPropertyBySemantic=function(t,e){Ut.throwInstantiationError()};Dr.hasProperty=function(t,e,n){if(c(e[t]))return!0;let i=n.properties;if(!c(i))return!1;let o=i[t];return!!(c(o)&&c(o.default))};Dr.hasPropertyBySemantic=function(t,e,n){let i=n.propertiesBySemantic;if(!c(i))return!1;let o=i[t];return c(o)};Dr.getPropertyIds=function(t,e,n){n=c(n)?n:[],n.length=0;for(let o in t)t.hasOwnProperty(o)&&c(t[o])&&n.push(o);let i=e.properties;if(c(i))for(let o in i)i.hasOwnProperty(o)&&!c(t[o])&&c(i[o].default)&&n.push(o);return n};Dr.getProperty=function(t,e,n){let i=n.properties[t],o=e[t];Array.isArray(o)&&(o=o.slice());let a=!0;if(o=i.handleNoData(o),!c(o)&&c(i.default))return o=be(i.default,!0),i.unpackVectorAndMatrixTypes(o,a);if(c(o))return o=i.normalize(o),o=i.applyValueTransform(o),i.unpackVectorAndMatrixTypes(o,a)};Dr.setProperty=function(t,e,n,i){if(!c(n[t]))return!1;Array.isArray(e)&&(e=e.slice());let o,a=i.properties;return c(a)&&(o=a[t]),c(o)&&(e=o.packVectorAndMatrixTypes(e,!0),e=o.unapplyValueTransform(e),e=o.unnormalize(e)),n[t]=e,!0};Dr.getPropertyBySemantic=function(t,e,n){let i=n.propertiesBySemantic;if(!c(i))return;let o=i[t];if(c(o))return Dr.getProperty(o.id,e,n)};Dr.setPropertyBySemantic=function(t,e,n,i){let o=i.propertiesBySemantic;if(!c(o))return!1;let a=i.propertiesBySemantic[t];return c(a)?Dr.setProperty(a.id,e,n,i):!1};var Yi=Dr;function jR(t){t=f(t,f.EMPTY_OBJECT);let e=t.subtreeMetadata,n=t.class,i=c(e.properties)?e.properties:{};this._class=n,this._properties=i,this._extras=e.extras,this._extensions=e.extensions}Object.defineProperties(jR.prototype,{class:{get:function(){return this._class}},extras:{get:function(){return this._extras}},extensions:{get:function(){return this._extensions}}});jR.prototype.hasProperty=function(t){return Yi.hasProperty(t,this._properties,this._class)};jR.prototype.hasPropertyBySemantic=function(t){return Yi.hasPropertyBySemantic(t,this._properties,this._class)};jR.prototype.getPropertyIds=function(t){return Yi.getPropertyIds(this._properties,this._class,t)};jR.prototype.getProperty=function(t){return Yi.getProperty(t,this._properties,this._class)};jR.prototype.setProperty=function(t,e){return Yi.setProperty(t,e,this._properties,this._class)};jR.prototype.getPropertyBySemantic=function(t){return Yi.getPropertyBySemantic(t,this._properties,this._class)};jR.prototype.setPropertyBySemantic=function(t,e){return Yi.setPropertyBySemantic(t,e,this._properties,this._class)};var Jk=jR;var LCn=R(W(),1);var BCn=R(W(),1);var tCn=R(W(),1);var Fn={INT8:"INT8",UINT8:"UINT8",INT16:"INT16",UINT16:"UINT16",INT32:"INT32",UINT32:"UINT32",INT64:"INT64",UINT64:"UINT64",FLOAT32:"FLOAT32",FLOAT64:"FLOAT64"};Fn.getMinimum=function(t){switch(t){case Fn.INT8:return-128;case Fn.UINT8:return 0;case Fn.INT16:return-32768;case Fn.UINT16:return 0;case Fn.INT32:return-2147483648;case Fn.UINT32:return 0;case Fn.INT64:return In.supportsBigInt()?BigInt("-9223372036854775808"):-Math.pow(2,63);case Fn.UINT64:return In.supportsBigInt()?BigInt(0):0;case Fn.FLOAT32:return-34028234663852886e22;case Fn.FLOAT64:return-Number.MAX_VALUE}};Fn.getMaximum=function(t){switch(t){case Fn.INT8:return 127;case Fn.UINT8:return 255;case Fn.INT16:return 32767;case Fn.UINT16:return 65535;case Fn.INT32:return 2147483647;case Fn.UINT32:return 4294967295;case Fn.INT64:return In.supportsBigInt()?BigInt("9223372036854775807"):Math.pow(2,63)-1;case Fn.UINT64:return In.supportsBigInt()?BigInt("18446744073709551615"):Math.pow(2,64)-1;case Fn.FLOAT32:return 34028234663852886e22;case Fn.FLOAT64:return Number.MAX_VALUE}};Fn.isIntegerType=function(t){switch(t){case Fn.INT8:case Fn.UINT8:case Fn.INT16:case Fn.UINT16:case Fn.INT32:case Fn.UINT32:case Fn.INT64:case Fn.UINT64:return!0;default:return!1}};Fn.isUnsignedIntegerType=function(t){switch(t){case Fn.UINT8:case Fn.UINT16:case Fn.UINT32:case Fn.UINT64:return!0;default:return!1}};Fn.isVectorCompatible=function(t){switch(t){case Fn.INT8:case Fn.UINT8:case Fn.INT16:case Fn.UINT16:case Fn.INT32:case Fn.UINT32:case Fn.FLOAT32:case Fn.FLOAT64:return!0;default:return!1}};Fn.normalize=function(t,e){return Math.max(Number(t)/Number(Fn.getMaximum(e)),-1)};Fn.unnormalize=function(t,e){let n=Fn.getMaximum(e),i=Fn.isUnsignedIntegerType(e)?0:-n;return t=k.sign(t)*Math.round(Math.abs(t)*Number(n)),(e===Fn.INT64||e===Fn.UINT64)&&In.supportsBigInt()&&(t=BigInt(t)),t>n?n:t1;if(!n&&o===1)return t;if(!n)return new Array(o).fill(t);if(!a)return new Array(i).fill(t);if(!e)return new Array(this._arrayLength*o).fill(t);let s=new Array(o).fill(t);return new Array(this._arrayLength).fill(s)};Zd.prototype.handleNoData=function(t){let e=this._noData;if(!c(e))return t;if(!ebt(t,e))return t};function ebt(t,e){if(!Array.isArray(t))return t===e;if(!Array.isArray(e)||t.length!==e.length)return!1;for(let n=0;n1;return c(n)?e&&a?t.map(function(s){return n.unpack(s)}):i?n.unpackArray(t):n.unpack(t):t};Zd.prototype.packVectorAndMatrixTypes=function(t,e){e=f(e,!1);let n=Nn.getMathType(this._type),i=this._isArray,o=Nn.getComponentCount(this._type),a=i&&o>1;return c(n)?e&&a?t.map(function(s){return n.pack(s,[])}):i?n.packArray(t,[]):n.pack(t,[]):t};Zd.prototype.validate=function(t){if(!(!c(t)&&c(this._default)))return this._required&&!c(t)?"required property must have a value":this._isArray?b8t(this,t):nbt(this,t)};function b8t(t,e){if(!Array.isArray(e))return`value ${e} must be an array`;let n=e.length;if(!t._isVariableLengthArray&&n!==t._arrayLength)return"Array length does not match property.arrayLength";for(let i=0;i1?qVt(t,e,n):void 0}if(tvn.getMaximum(e))return qVt(t,e,n)}function tbt(t,e){return`value ${t} of type ${e} must be finite`}function Lq(t,e,n){if(!Array.isArray(t))return n(t,e);for(let i=0;i>3,i=t%8;return(e.typedArray[n]>>i&1)===1}function E8t(t,e,n){let i=t>>3,o=t%8;n?e.typedArray[i]|=1<0,s=!0;for(let l=0;l<8;++l){let r=n.getUint8(i+l);a&&(s?r!==0&&(r=~(r-1)&255,s=!1):r=~r&255),o+=r*Math.pow(256,l)}return a&&(o=-o),o}function I8t(t,e){let n=e.dataView,i=t*8,o=BigInt(0),a=(n.getUint8(i+7)&128)>0,s=!0;for(let l=0;l<8;++l){let r=n.getUint8(i+l);a&&(s?r!==0&&(r=~(r-1)&255,s=!1):r=~r&255),o+=BigInt(r)*(BigInt(1)<0;){let m=e.pop();if(v.equals(m.color,l.color))d=kq(n,s,d,i,o,m.batchIds,a),l.batchIds=l.batchIds.concat(m.batchIds),l.count=d-l.offset;else{let h=d;d=kq(n,s,d,i,o,m.batchIds,a),m.offset=h,m.count=d-h,r.push(m),l=m}}t._va.indexBuffer.copyFromArrayView(s),t._indices=s,t._batchedIndices=r}function Yq(t,e,n,i,o,a,s){let l=t.bytesPerIndex,r=a.length;for(let d=0;d0;){let h=e.pop();if(v.equals(h.color,a.color))d=Yq(l,r,d,n,i,h.batchIds,o),a.batchIds=a.batchIds.concat(h.batchIds),a.count=d-a.offset;else{let u=d;d=Yq(l,r,d,n,i,h.batchIds,o),h.offset=u,h.count=d-u,s.push(h),a=h}}let m=t._va;t._va=t._vaSwap,t._vaSwap=m,t._batchedIndices=s}function B4t(t,e){return e.color.toRgba()-t.color.toRgba()}function Q4t(t,e){if(!t._batchDirty)return!1;let n=t._batchedIndices,i=n.length,o=!1,a={};for(let s=0;s=F&&s{t.isDestroyed()||(t._error=V)}):void 0}}function z4t(t){c(t._primitive)||(t._primitive=new cA({batchTable:t._batchTable,positions:t._positions,batchIds:t._batchIds,vertexBatchIds:t._vertexBatchIds,indices:t._indices,indexOffsets:t._indexOffsets,indexCounts:t._indexCounts,batchedIndices:t._batchedIndices,boundingVolume:t._boundingVolume,boundingVolumes:t._boundingVolumes,center:t._center,pickObject:f(t._pickObject,t)}),t._boxes=void 0,t._boxBatchIds=void 0,t._cylinders=void 0,t._cylinderBatchIds=void 0,t._ellipsoids=void 0,t._ellipsoidBatchIds=void 0,t._spheres=void 0,t._sphereBatchIds=void 0,t._center=void 0,t._modelMatrix=void 0,t._batchTable=void 0,t._boundingVolume=void 0,t._boundingVolumes=void 0,t._batchedIndices=void 0,t._indices=void 0,t._indexOffsets=void 0,t._indexCounts=void 0,t._positions=void 0,t._vertexBatchIds=void 0,t._batchIds=void 0,t._batchTableColors=void 0,t._packedBuffer=void 0,t._verticesPromise=void 0)}Ch.prototype.createFeatures=function(t,e){this._primitive.createFeatures(t,e)};Ch.prototype.applyDebugSettings=function(t,e){this._primitive.applyDebugSettings(t,e)};Ch.prototype.applyStyle=function(t,e){this._primitive.applyStyle(t,e)};Ch.prototype.updateCommands=function(t,e){this._primitive.updateCommands(t,e)};Ch.prototype.update=function(t){if(!this._ready){if(c(this._promise)||(this._promise=K4t(this)),c(this._error)){let e=this._error;throw this._error=void 0,e}return}this._primitive.debugWireframe=this.debugWireframe,this._primitive.forceRebatch=this.forceRebatch,this._primitive.classificationType=this.classificationType,this._primitive.update(t)};Ch.prototype.isDestroyed=function(){return!1};Ch.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),At(this)};var vb=Ch;function KZ(t,e,n,i,o){this._tileset=t,this._tile=e,this._resource=n,this._geometries=void 0,this._metadata=void 0,this._batchTable=void 0,this._features=void 0,this.featurePropertiesDirty=!1,this._group=void 0,this._ready=!1,$4t(this,i,o)}Object.defineProperties(KZ.prototype,{featuresLength:{get:function(){return c(this._batchTable)?this._batchTable.featuresLength:0}},pointsLength:{get:function(){return 0}},trianglesLength:{get:function(){return c(this._geometries)?this._geometries.trianglesLength:0}},geometryByteLength:{get:function(){return c(this._geometries)?this._geometries.geometryByteLength:0}},texturesByteLength:{get:function(){return 0}},batchTableByteLength:{get:function(){return c(this._batchTable)?this._batchTable.batchTableByteLength:0}},innerContents:{get:function(){}},ready:{get:function(){return this._ready}},tileset:{get:function(){return this._tileset}},tile:{get:function(){return this._tile}},url:{get:function(){return this._resource.getUrlComponent(!0)}},metadata:{get:function(){return this._metadata},set:function(t){this._metadata=t}},batchTable:{get:function(){return this._batchTable}},group:{get:function(){return this._group},set:function(t){this._group=t}}});function j4t(t){return function(e,n){c(t._geometries)&&t._geometries.updateCommands(e,n)}}function q4t(t,e){let n,i,o,a,s,l=f(t.BOXES_LENGTH,0),r=f(t.CYLINDERS_LENGTH,0),d=f(t.ELLIPSOIDS_LENGTH,0),m=f(t.SPHERES_LENGTH,0);if(l>0&&c(t.BOX_BATCH_IDS)){let V=e.byteOffset+t.BOX_BATCH_IDS.byteOffset;n=new Uint16Array(e.buffer,V,l)}if(r>0&&c(t.CYLINDER_BATCH_IDS)){let V=e.byteOffset+t.CYLINDER_BATCH_IDS.byteOffset;i=new Uint16Array(e.buffer,V,r)}if(d>0&&c(t.ELLIPSOID_BATCH_IDS)){let V=e.byteOffset+t.ELLIPSOID_BATCH_IDS.byteOffset;o=new Uint16Array(e.buffer,V,d)}if(m>0&&c(t.SPHERE_BATCH_IDS)){let V=e.byteOffset+t.SPHERE_BATCH_IDS.byteOffset;a=new Uint16Array(e.buffer,V,m)}let h=c(n)||c(i)||c(o)||c(a),u=l>0&&!c(n)||r>0&&!c(i)||d>0&&!c(o)||m>0&&!c(a);if(h&&u)throw new Tt("If one group of batch ids is defined, then all batch ids must be defined");if(!c(n)&&!c(i)&&!c(o)&&!c(a)){let V=0;if(!c(n)&&l>0)for(n=new Uint16Array(l),s=0;s0)for(i=new Uint16Array(r),s=0;s0)for(o=new Uint16Array(d),s=0;s0)for(a=new Uint16Array(m),s=0;s0&&(R=ts(i,n,d),n+=d,m>0&&(V=new Uint8Array(e,n,m),V=new Uint8Array(V)));let F=f(h.BOXES_LENGTH,0),U=f(h.CYLINDERS_LENGTH,0),G=f(h.ELLIPSOIDS_LENGTH,0),A=f(h.SPHERES_LENGTH,0),S=F+U+G+A,g=new wb(t,S,R,V,j4t(t));if(t._batchTable=g,S===0)return;let C=t.tile.computedTransform,y;c(h.RTC_CENTER)&&(y=p.unpack(h.RTC_CENTER),L.multiplyByPoint(C,y,y));let Y=q4t(h,u);if(F>0||U>0||G>0||A>0){let Q,J,M,Z;if(F>0){let E=u.byteOffset+h.BOXES.byteOffset;Q=new Float32Array(u.buffer,E,vb.packedBoxLength*F)}if(U>0){let E=u.byteOffset+h.CYLINDERS.byteOffset;J=new Float32Array(u.buffer,E,vb.packedCylinderLength*U)}if(G>0){let E=u.byteOffset+h.ELLIPSOIDS.byteOffset;M=new Float32Array(u.buffer,E,vb.packedEllipsoidLength*G)}if(A>0){let E=u.byteOffset+h.SPHERES.byteOffset;Z=new Float32Array(u.buffer,E,vb.packedSphereLength*A)}return t._geometries=new vb({boxes:Q,boxBatchIds:Y.boxes,cylinders:J,cylinderBatchIds:Y.cylinders,ellipsoids:M,ellipsoidBatchIds:Y.ellipsoids,spheres:Z,sphereBatchIds:Y.spheres,center:y,modelMatrix:C,batchTable:g,boundingVolume:t.tile.boundingVolume.boundingVolume}),t}return Promise.resolve(t)}function DZt(t){let e=t.featuresLength;if(!c(t._features)&&e>0){let n=new Array(e);c(t._geometries)&&t._geometries.createFeatures(t,n),t._features=n}}KZ.prototype.hasProperty=function(t,e){return this._batchTable.hasProperty(t,e)};KZ.prototype.getFeature=function(t){return DZt(this),this._features[t]};KZ.prototype.applyDebugSettings=function(t,e){c(this._geometries)&&this._geometries.applyDebugSettings(t,e)};KZ.prototype.applyStyle=function(t){DZt(this),c(this._geometries)&&this._geometries.applyStyle(t,this._features)};KZ.prototype.update=function(t,e){c(this._geometries)&&(this._geometries.classificationType=this._tileset.classificationType,this._geometries.debugWireframe=this._tileset.debugWireframe,this._geometries.update(e)),c(this._batchTable)&&this._geometries.ready&&(this._batchTable.update(t,e),this._ready=!0)};KZ.prototype.pick=function(t,e,n){};KZ.prototype.isDestroyed=function(){return!1};KZ.prototype.destroy=function(){return this._geometries=this._geometries&&this._geometries.destroy(),this._batchTable=this._batchTable&&this._batchTable.destroy(),At(this)};var X2=KZ;var zkn=b(W(),1);var bEn=b(W(),1);var xq={};xq.encode2D=function(t,e,n){let i=Math.pow(2,t),o={x:e,y:n},a,s,l,r=BigInt(0);for(l=i/2;l>0;l/=2)a=(o.x&l)>0?1:0,s=(o.y&l)>0?1:0,r+=BigInt((3*a^s)*l*l),OZt(i,o,a,s);return r};xq.decode2D=function(t,e){let n=Math.pow(2,t),i={x:0,y:0},o,a,s,l;for(s=1,l=e;s>>0,Xq=2*hA+1,yf=4,PZt=[],vZt=[],n8t=[[0,1,3,2],[0,2,3,1],[3,2,0,1],[3,1,0,2]],Bf=1,NE=2,fw=[Bf,0,0,Bf|NE];function Gl(t){if(!In.supportsBigInt())throw new Tt("S2 required BigInt support");this._cellId=t,this._level=Gl.getLevel(t)}Gl.fromToken=function(t){return new Gl(Gl.getIdFromToken(t))};Gl.isValidId=function(t){return!(t<=0||t>>BigInt(Xq)>5||!(t&~t+BigInt(1)&BigInt("0x1555555555555555")))};Gl.isValidToken=function(t){return/^[0-9a-fA-F]{1,16}$/.test(t)?Gl.isValidId(Gl.getIdFromToken(t)):!1};Gl.getIdFromToken=function(t){return BigInt("0x"+t+"0".repeat(16-t.length))};Gl.getTokenFromId=function(t){let e=Math.floor(h8t(t)/4),n=t.toString(16).replace(/0*$/,"");return Array(17-e-n.length).join("0")+n};Gl.getLevel=function(t){let e=0;for(;t!==BigInt(0)&&!(t&BigInt(1));)e++,t=t>>BigInt(1);return hA-(e>>1)};Gl.prototype.getChild=function(t){let e=jZt(this._cellId)>>BigInt(2),n=this._cellId+BigInt(2*t+1-4)*e;return new Gl(n)};Gl.prototype.getParent=function(){let t=jZt(this._cellId)<>1&1;return zZt(i[0],o[0][a^n&1],o[1][a])}function a8t(t,e){let n=KZt(t),i=n[0],o=n[1],a=n[2],s=e===30,l=!s&&(BigInt(o)^t>>BigInt(2))&BigInt(1),r=s?1:l?2:0,d=(o<<1)+r,m=(a<<1)+r;return[i,d,m]}function KZt(t){PZt.length===0&&d8t();let e=Number(t>>BigInt(Xq)),n=e&Bf,i=(1<=0;s--){let r=(1<<2*(s===7?hA-7*yf:yf))-1;n+=Number(t>>BigInt(s*2*yf+1)&BigInt(r))<<2,n=vZt[n];let d=s*yf;o+=n>>yf+2<>2&i)<=.5?1/3*(4*t*t-1):1/3*(1-4*(1-t)*(1-t))}function HZt(t){return 1/e8t*t}function l8t(t,e){let n=[[],[]],i=r8t(e);for(let o=0;o<2;++o){let a=t[o]&-i,s=a+i;n[o][0]=Fw(wZt(a)),n[o][1]=Fw(wZt(s))}return n}function r8t(t){return 1<>>0}function wZt(t){return 1/t8t*t}function Qf(t,e,n,i,o,a){if(t===yf){let s=(e<>1),n+(s[0]&1),i,o,a^fw[0]),Qf(t,e+(s[1]>>1),n+(s[1]&1),i,o+1,a^fw[1]),Qf(t,e+(s[2]>>1),n+(s[2]&1),i,o+2,a^fw[2]),Qf(t,e+(s[3]>>1),n+(s[3]&1),i,o+3,a^fw[3])}}function d8t(){Qf(0,0,0,0,0,0),Qf(0,0,0,Bf,0,Bf),Qf(0,0,0,NE,0,NE),Qf(0,0,0,Bf|NE,0,Bf|NE)}function jZt(t){return t&~t+BigInt(1)}function c8t(t){return BigInt(1)<>3,a=i%8;n+=t[o]>>a&1}return n}Object.defineProperties(Jq.prototype,{lengthBits:{get:function(){return this._lengthBits}},availableCount:{get:function(){return this._availableCount}}});Jq.prototype.getBit=function(t){if(c(this._constant))return this._constant;let e=t>>3,n=t%8;return(this._bitstream[e]>>n&1)===1};var yE=Jq;var xEn=b(W(),1);function zb(t){t=f(t,f.EMPTY_OBJECT);let e=t.metadataTable,n=t.class,i=t.entityId,o=t.propertyTableJson;this._class=n,this._metadataTable=e,this._entityId=i,this._extensions=o.extensions,this._extras=o.extras}Object.defineProperties(zb.prototype,{class:{get:function(){return this._class}},extras:{get:function(){return this._extras}},extensions:{get:function(){return this._extensions}}});zb.prototype.hasProperty=function(t){return this._metadataTable.hasProperty(t)};zb.prototype.hasPropertyBySemantic=function(t){return this._metadataTable.hasPropertyBySemantic(t)};zb.prototype.getPropertyIds=function(t){return this._metadataTable.getPropertyIds(t)};zb.prototype.getProperty=function(t){return this._metadataTable.getProperty(this._entityId,t)};zb.prototype.setProperty=function(t,e){return this._metadataTable.setProperty(this._entityId,t,e)};zb.prototype.getPropertyBySemantic=function(t){return this._metadataTable.getPropertyBySemantic(this._entityId,t)};zb.prototype.setPropertyBySemantic=function(t,e){return this._metadataTable.setPropertyBySemantic(this._entityId,t,e)};var BE=zb;var JEn=b(W(),1);var Uw={QUADTREE:"QUADTREE",OCTREE:"OCTREE"};Uw.getBranchingFactor=function(t){switch(t){case Uw.OCTREE:return 8;case Uw.QUADTREE:return 4}};var Al=Object.freeze(Uw);var KEn=b(W(),1);var OEn=b(W(),1);function Dr(){}Object.defineProperties(Dr.prototype,{class:{get:function(){Ut.throwInstantiationError()}}});Dr.prototype.hasProperty=function(t){Ut.throwInstantiationError()};Dr.prototype.hasPropertyBySemantic=function(t){Ut.throwInstantiationError()};Dr.prototype.getPropertyIds=function(t){Ut.throwInstantiationError()};Dr.prototype.getProperty=function(t){Ut.throwInstantiationError()};Dr.prototype.setProperty=function(t,e){Ut.throwInstantiationError()};Dr.prototype.getPropertyBySemantic=function(t){Ut.throwInstantiationError()};Dr.prototype.setPropertyBySemantic=function(t,e){Ut.throwInstantiationError()};Dr.hasProperty=function(t,e,n){if(c(e[t]))return!0;let i=n.properties;if(!c(i))return!1;let o=i[t];return!!(c(o)&&c(o.default))};Dr.hasPropertyBySemantic=function(t,e,n){let i=n.propertiesBySemantic;if(!c(i))return!1;let o=i[t];return c(o)};Dr.getPropertyIds=function(t,e,n){n=c(n)?n:[],n.length=0;for(let o in t)t.hasOwnProperty(o)&&c(t[o])&&n.push(o);let i=e.properties;if(c(i))for(let o in i)i.hasOwnProperty(o)&&!c(t[o])&&c(i[o].default)&&n.push(o);return n};Dr.getProperty=function(t,e,n){let i=n.properties[t],o=e[t];Array.isArray(o)&&(o=o.slice());let a=!0;if(o=i.handleNoData(o),!c(o)&&c(i.default))return o=Re(i.default,!0),i.unpackVectorAndMatrixTypes(o,a);if(c(o))return o=i.normalize(o),o=i.applyValueTransform(o),i.unpackVectorAndMatrixTypes(o,a)};Dr.setProperty=function(t,e,n,i){if(!c(n[t]))return!1;Array.isArray(e)&&(e=e.slice());let o,a=i.properties;return c(a)&&(o=a[t]),c(o)&&(e=o.packVectorAndMatrixTypes(e,!0),e=o.unapplyValueTransform(e),e=o.unnormalize(e)),n[t]=e,!0};Dr.getPropertyBySemantic=function(t,e,n){let i=n.propertiesBySemantic;if(!c(i))return;let o=i[t];if(c(o))return Dr.getProperty(o.id,e,n)};Dr.setPropertyBySemantic=function(t,e,n,i){let o=i.propertiesBySemantic;if(!c(o))return!1;let a=i.propertiesBySemantic[t];return c(a)?Dr.setProperty(a.id,e,n,i):!1};var Yi=Dr;function jb(t){t=f(t,f.EMPTY_OBJECT);let e=t.subtreeMetadata,n=t.class,i=c(e.properties)?e.properties:{};this._class=n,this._properties=i,this._extras=e.extras,this._extensions=e.extensions}Object.defineProperties(jb.prototype,{class:{get:function(){return this._class}},extras:{get:function(){return this._extras}},extensions:{get:function(){return this._extensions}}});jb.prototype.hasProperty=function(t){return Yi.hasProperty(t,this._properties,this._class)};jb.prototype.hasPropertyBySemantic=function(t){return Yi.hasPropertyBySemantic(t,this._properties,this._class)};jb.prototype.getPropertyIds=function(t){return Yi.getPropertyIds(this._properties,this._class,t)};jb.prototype.getProperty=function(t){return Yi.getProperty(t,this._properties,this._class)};jb.prototype.setProperty=function(t,e){return Yi.setProperty(t,e,this._properties,this._class)};jb.prototype.getPropertyBySemantic=function(t){return Yi.getPropertyBySemantic(t,this._properties,this._class)};jb.prototype.setPropertyBySemantic=function(t,e){return Yi.setPropertyBySemantic(t,e,this._properties,this._class)};var J2=jb;var LCn=b(W(),1);var BCn=b(W(),1);var tCn=b(W(),1);var Fn={INT8:"INT8",UINT8:"UINT8",INT16:"INT16",UINT16:"UINT16",INT32:"INT32",UINT32:"UINT32",INT64:"INT64",UINT64:"UINT64",FLOAT32:"FLOAT32",FLOAT64:"FLOAT64"};Fn.getMinimum=function(t){switch(t){case Fn.INT8:return-128;case Fn.UINT8:return 0;case Fn.INT16:return-32768;case Fn.UINT16:return 0;case Fn.INT32:return-2147483648;case Fn.UINT32:return 0;case Fn.INT64:return In.supportsBigInt()?BigInt("-9223372036854775808"):-Math.pow(2,63);case Fn.UINT64:return In.supportsBigInt()?BigInt(0):0;case Fn.FLOAT32:return-34028234663852886e22;case Fn.FLOAT64:return-Number.MAX_VALUE}};Fn.getMaximum=function(t){switch(t){case Fn.INT8:return 127;case Fn.UINT8:return 255;case Fn.INT16:return 32767;case Fn.UINT16:return 65535;case Fn.INT32:return 2147483647;case Fn.UINT32:return 4294967295;case Fn.INT64:return In.supportsBigInt()?BigInt("9223372036854775807"):Math.pow(2,63)-1;case Fn.UINT64:return In.supportsBigInt()?BigInt("18446744073709551615"):Math.pow(2,64)-1;case Fn.FLOAT32:return 34028234663852886e22;case Fn.FLOAT64:return Number.MAX_VALUE}};Fn.isIntegerType=function(t){switch(t){case Fn.INT8:case Fn.UINT8:case Fn.INT16:case Fn.UINT16:case Fn.INT32:case Fn.UINT32:case Fn.INT64:case Fn.UINT64:return!0;default:return!1}};Fn.isUnsignedIntegerType=function(t){switch(t){case Fn.UINT8:case Fn.UINT16:case Fn.UINT32:case Fn.UINT64:return!0;default:return!1}};Fn.isVectorCompatible=function(t){switch(t){case Fn.INT8:case Fn.UINT8:case Fn.INT16:case Fn.UINT16:case Fn.INT32:case Fn.UINT32:case Fn.FLOAT32:case Fn.FLOAT64:return!0;default:return!1}};Fn.normalize=function(t,e){return Math.max(Number(t)/Number(Fn.getMaximum(e)),-1)};Fn.unnormalize=function(t,e){let n=Fn.getMaximum(e),i=Fn.isUnsignedIntegerType(e)?0:-n;return t=k.sign(t)*Math.round(Math.abs(t)*Number(n)),(e===Fn.INT64||e===Fn.UINT64)&&In.supportsBigInt()&&(t=BigInt(t)),t>n?n:t1;if(!n&&o===1)return t;if(!n)return new Array(o).fill(t);if(!a)return new Array(i).fill(t);if(!e)return new Array(this._arrayLength*o).fill(t);let s=new Array(o).fill(t);return new Array(this._arrayLength).fill(s)};ud.prototype.handleNoData=function(t){let e=this._noData;if(!c(e))return t;if(!eRt(t,e))return t};function eRt(t,e){if(!Array.isArray(t))return t===e;if(!Array.isArray(e)||t.length!==e.length)return!1;for(let n=0;n1;return c(n)?e&&a?t.map(function(s){return n.unpack(s)}):i?n.unpackArray(t):n.unpack(t):t};ud.prototype.packVectorAndMatrixTypes=function(t,e){e=f(e,!1);let n=Nn.getMathType(this._type),i=this._isArray,o=Nn.getComponentCount(this._type),a=i&&o>1;return c(n)?e&&a?t.map(function(s){return n.pack(s,[])}):i?n.packArray(t,[]):n.pack(t,[]):t};ud.prototype.validate=function(t){if(!(!c(t)&&c(this._default)))return this._required&&!c(t)?"required property must have a value":this._isArray?R8t(this,t):nRt(this,t)};function R8t(t,e){if(!Array.isArray(e))return`value ${e} must be an array`;let n=e.length;if(!t._isVariableLengthArray&&n!==t._arrayLength)return"Array length does not match property.arrayLength";for(let i=0;i1?qZt(t,e,n):void 0}if(tvn.getMaximum(e))return qZt(t,e,n)}function tRt(t,e){return`value ${t} of type ${e} must be finite`}function Lq(t,e,n){if(!Array.isArray(t))return n(t,e);for(let i=0;i>3,i=t%8;return(e.typedArray[n]>>i&1)===1}function E8t(t,e,n){let i=t>>3,o=t%8;n?e.typedArray[i]|=1<0,s=!0;for(let l=0;l<8;++l){let r=n.getUint8(i+l);a&&(s?r!==0&&(r=~(r-1)&255,s=!1):r=~r&255),o+=r*Math.pow(256,l)}return a&&(o=-o),o}function I8t(t,e){let n=e.dataView,i=t*8,o=BigInt(0),a=(n.getUint8(i+7)&128)>0,s=!0;for(let l=0;l<8;++l){let r=n.getUint8(i+l);a&&(s?r!==0&&(r=~(r-1)&255,s=!1):r=~r&255),o+=BigInt(r)*(BigInt(1)<96?U-97:U>64?U-39:U+4}for(var G=0,F=0;F=3),r(n.exports.meshopt_spatialSortRemap,b,b.length/u,u*4)},encodeVertexBuffer:function(b,u,F){a(F>0&&F<=256),a(F%4==0);var U=n.exports.meshopt_encodeVertexBufferBound(u,F);return d(n.exports.meshopt_encodeVertexBuffer,U,b,u,F)},encodeIndexBuffer:function(b,u,F){a(F==2||F==4),a(u%3==0);var U=h(b,F),G=n.exports.meshopt_encodeIndexBufferBound(u,m(U)+1);return d(n.exports.meshopt_encodeIndexBuffer,G,U,u,4)},encodeIndexSequence:function(b,u,F){a(F==2||F==4);var U=h(b,F),G=n.exports.meshopt_encodeIndexSequenceBound(u,m(U)+1);return d(n.exports.meshopt_encodeIndexSequence,G,U,u,4)},encodeGltfBuffer:function(b,u,F,U){var G={ATTRIBUTES:this.encodeVertexBuffer,TRIANGLES:this.encodeIndexBuffer,INDICES:this.encodeIndexSequence};return a(G[U]),G[U](b,u,F)},encodeFilterOct:function(b,u,F,U){return a(F==4||F==8),a(U>=1&&U<=16),Z(n.exports.meshopt_encodeFilterOct,b,u,F,U,16)},encodeFilterQuat:function(b,u,F,U){return a(F==8),a(U>=4&&U<=16),Z(n.exports.meshopt_encodeFilterQuat,b,u,F,U,16)},encodeFilterExp:function(b,u,F,U,G){a(F>0&&F%4==0),a(U>=1&&U<=24);var A={Separate:0,SharedVector:1,SharedComponent:2};return Z(n.exports.meshopt_encodeFilterExp,b,u,F,U,F,G?A[G]:1)}}}();var aIn=R(W()),lbt=function(){var t="b9H79Tebbbe8Fv9Gbb9Gvuuuuueu9Giuuub9Geueu9Giuuueuikqbeeedddillviebeoweuec:q;iekr;leDo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbeY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVbdE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbiL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtblK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949Wbol79IV9Rbrq;d8Yqdbk:yzeHu8Jjjjjbcj;eb9Rgv8Kjjjjbc9:hodnadcefal0mbcuhoaiRbbc:Ge9hmbavaialfgrad9Radz1jjjbhwcj;abad9UhlaicefhodnadTmbalc;WFbGglcjdalcjd6EhDcbhqinaqae9pmeaDaeaq9RaqaDfae6Egkcsfglcl4cifcd4hxdndndndnalc9WGgmTmbcbhPcehsawcjdfhzaohHinaraH9Rax6midnaraHaxfgo9RcK6mbczhlcbhOinalgic9WfgAawcj;cbffhldndndndndnaHaAco4fRbbaOcoG4ciGPlbedibkal9cb83ibalcwf9cb83ibxikalaoRblaoRbbgAco4gCaCciSgCE86bbawcj;cbfaifglcGfaoclfaCfgCRbbaAcl4ciGgXaXciSgXE86bbalcVfaCaXfgCRbbaAcd4ciGgXaXciSgXE86bbalc7faCaXfgCRbbaAciGgAaAciSgAE86bbalctfaCaAfgCRbbaoRbegAco4gXaXciSgXE86bbalc91faCaXfgCRbbaAcl4ciGgXaXciSgXE86bbalc4faCaXfgCRbbaAcd4ciGgXaXciSgXE86bbalc93faCaXfgCRbbaAciGgAaAciSgAE86bbalc94faCaAfgCRbbaoRbdgAco4gXaXciSgXE86bbalc95faCaXfgCRbbaAcl4ciGgXaXciSgXE86bbalc96faCaXfgCRbbaAcd4ciGgXaXciSgXE86bbalc97faCaXfgCRbbaAciGgAaAciSgAE86bbalc98faCaAfgARbbaoRbigoco4gCaCciSgCE86bbalc99faAaCfgARbbaocl4ciGgCaCciSgCE86bbalc9:faAaCfgARbbaocd4ciGgCaCciSgCE86bbalcufaAaCfglRbbaociGgoaociSgoE86bbalaofhoxdkalaoRbwaoRbbgAcl4gCaCcsSgCE86bbawcj;cbfaifglcGfaocwfaCfgCRbbaAcsGgAaAcsSgAE86bbalcVfaCaAfgARbbaoRbegCcl4gXaXcsSgXE86bbalc7faAaXfgARbbaCcsGgCaCcsSgCE86bbalctfaAaCfgARbbaoRbdgCcl4gXaXcsSgXE86bbalc91faAaXfgARbbaCcsGgCaCcsSgCE86bbalc4faAaCfgARbbaoRbigCcl4gXaXcsSgXE86bbalc93faAaXfgARbbaCcsGgCaCcsSgCE86bbalc94faAaCfgARbbaoRblgCcl4gXaXcsSgXE86bbalc95faAaXfgARbbaCcsGgCaCcsSgCE86bbalc96faAaCfgARbbaoRbvgCcl4gXaXcsSgXE86bbalc97faAaXfgARbbaCcsGgCaCcsSgCE86bbalc98faAaCfgARbbaoRbogCcl4gXaXcsSgXE86bbalc99faAaXfgARbbaCcsGgCaCcsSgCE86bbalc9:faAaCfgARbbaoRbrgocl4gCaCcsSgCE86bbalcufaAaCfglRbbaocsGgoaocsSgoE86bbalaofhoxekalao8Pbb83bbalcwfaocwf8Pbb83bbaoczfhokdnaiam9pmbaOcdfhOaiczfhlarao9RcL0mekkaiam6miaoTmidnakTmbawaPfRbbhOawcj;cbfhlazhiakhAinaialRbbgHce4cbaHceG9R7aOfgO86bbaiadfhialcefhlaAcufgAmbkkazcefhzaPcefgPad6hsaohHaPad9hmexvkkcbhoasceGmdxikaoaxad2fhXdnakTmbcbhmcehsawcjdfhCinarao9Rax6miaoTmdaoaxfhoawamfRbbhOawcj;cbfhlaChiakhAinaialRbbgHce4cbaHceG9R7aOfgO86bbaiadfhialcefhlaAcufgAmbkaCcefhCamcefgmad6hsamad9hmbkaXhoxikcbhlcehsinarao9Rax6mdaoTmeaoaxfhoalcefglad6hsadal9hmbkaXhoxdkcbhoasceGTmekc9:hoxikabaqad2fawcjdfakad2z1jjjb8Aawawcjdfakcufad2fadz1jjjb8Aakaqfhqaombkc9:hoxekcbc99arao9Radcaadca0ESEhokavcj;ebf8Kjjjjbaok;xzeHu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnaeci9UgrcHfal0mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecjez:jjjjb8AavcUf9cu83ibavc8Wf9cu83ibavcyf9cu83ibavcaf9cu83ibavcKf9cu83ibavczf9cu83ibav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhodnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhlindnaoaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfalaDcu7gPcl4fcsGcitfgsydlhzasydbhHdnaDcsGgDak9pmbavaiaPfcsGcdtfydbaxaDEhsaDThDdndnadcd9hmbabarcetfgPaH87ebaPcdfaz87ebaPclfas87ebxekabarcdtfgPaHBdbaPclfazBdbaPcwfasBdbkaxaDfhxavc;abfalcitfgPasBdbaPazBdlavaicdtfasBdbavc;abfalcefcsGglcitfgPaHBdbaPasBdlaiaDfhialcefhlxdkdndnaDcsSmbamaDfaDc987fcefhmxekaocefhDao8SbbgscFeGhPdndnascu9mmbaDhoxekaocvfhoaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhokaPce4cbaPceG9R7amfhmkdndnadcd9hmbabarcetfgDaH87ebaDcdfaz87ebaDclfam87ebxekabarcdtfgDaHBdbaDclfazBdbaDcwfamBdbkavc;abfalcitfgDamBdbaDazBdlavaicdtfamBdbavc;abfalcefcsGglcitfgDaHBdbaDamBdlaicefhialcefhlxekdnaDcpe0mbaxcefgOavaiaqaDcsGfRbbgscl49RcsGcdtfydbascz6gPEhDavaias9RcsGcdtfydbaOaPfgzascsGgOEhsaOThOdndnadcd9hmbabarcetfgHax87ebaHcdfaD87ebaHclfas87ebxekabarcdtfgHaxBdbaHclfaDBdbaHcwfasBdbkavaicdtfaxBdbavc;abfalcitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfalcefcsGcitfgHasBdbaHaDBdlavaiaPfcsGgicdtfasBdbavc;abfalcdfcsGglcitfgDaxBdbaDasBdlalcefhlaiaOfhiazaOfhxxekaxcbaoRbbgHEgAaDc;:eSgDfhzaHcsGhCaHcl4hXdndnaHcs0mbazcefhOxekazhOavaiaX9RcsGcdtfydbhzkdndnaCmbaOcefhxxekaOhxavaiaH9RcsGcdtfydbhOkdndnaDTmbaocefhDxekaocdfhDao8SbegPcFeGhsdnaPcu9kmbaocofhAascFbGhscrhodninaD8SbbgPcFbGaotasVhsaPcu9kmeaDcefhDaocrfgoc8J9hmbkaAhDxekaDcefhDkasce4cbasceG9R7amfgmhAkdndnaXcsSmbaDhsxekaDcefhsaD8SbbgocFeGhPdnaocu9kmbaDcvfhzaPcFbGhPcrhodninas8SbbgDcFbGaotaPVhPaDcu9kmeascefhsaocrfgoc8J9hmbkazhsxekascefhskaPce4cbaPceG9R7amfgmhzkdndnaCcsSmbashoxekascefhoas8SbbgDcFeGhPdnaDcu9kmbascvfhOaPcFbGhPcrhDdninao8SbbgscFbGaDtaPVhPascu9kmeaocefhoaDcrfgDc8J9hmbkaOhoxekaocefhokaPce4cbaPceG9R7amfgmhOkdndnadcd9hmbabarcetfgDaA87ebaDcdfaz87ebaDclfaO87ebxekabarcdtfgDaABdbaDclfazBdbaDcwfaOBdbkavc;abfalcitfgDazBdbaDaABdlavaicdtfaABdbavc;abfalcefcsGcitfgDaOBdbaDazBdlavaicefgicsGcdtfazBdbavc;abfalcdfcsGcitfgDaABdbaDaOBdlavaiaHcz6aXcsSVfgicsGcdtfaOBdbaiaCTaCcsSVfhialcifhlkawcefhwalcsGhlaicsGhiarcifgrae6mbkkcbc99aoaqSEhokavc;aef8Kjjjjbaok:flevu8Jjjjjbcz9Rhvc9:hodnaecvfal0mbcuhoaiRbbc;:eGc;qe9hmbav9cb83iwaicefhraialfc98fhwdnaeTmbdnadcdSmbcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcdtfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfglBdbaoalBdbaDcefgDae9hmbxdkkcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcetfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfgl87ebaoalBdbaDcefgDae9hmbkkcbc99arawSEhokaok:Lvoeue99dud99eud99dndnadcl9hmbaeTmeindndnabcdfgd8Sbb:Yab8Sbbgi:Ygl:l:tabcefgv8Sbbgo:Ygr:l:tgwJbb;:9cawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai86bbdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad86bbdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad86bbabclfhbaecufgembxdkkaeTmbindndnabclfgd8Ueb:Yab8Uebgi:Ygl:l:tabcdfgv8Uebgo:Ygr:l:tgwJb;:FSawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai87ebdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad87ebdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad87ebabcwfhbaecufgembkkk;siliui99iue99dnaeTmbcbhiabhlindndnJ;Zl81Zalcof8UebgvciV:Y:vgoal8Ueb:YNgrJb;:FSNJbbbZJbbb:;arJbbbb9GEMgw:lJbbb9p9DTmbaw:OhDxekcjjjj94hDkalclf8Uebhqalcdf8UebhkabaiavcefciGfcetfaD87ebdndnaoak:YNgwJb;:FSNJbbbZJbbb:;awJbbbb9GEMgx:lJbbb9p9DTmbax:Ohkxekcjjjj94hkkabaiavcdfciGfcetfak87ebdndnaoaq:YNgoJb;:FSNJbbbZJbbb:;aoJbbbb9GEMgx:lJbbb9p9DTmbax:Ohqxekcjjjj94hqkabaiavcufciGfcetfaq87ebdndnJbbjZararN:tawawN:taoaoN:tgrJbbbbarJbbbb9GE:rJb;:FSNJbbbZMgr:lJbbb9p9DTmbar:Ohqxekcjjjj94hqkabaiavciGfcetfaq87ebalcwfhlaiclfhiaecufgembkkk9mbdnadcd4ae2gdTmbinababydbgecwtcw91:Yaece91cjjj98Gcjjj;8if::NUdbabclfhbadcufgdmbkkk9teiucbcbydj1jjbgeabcifc98GfgbBdj1jjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabkkkebcjwklz9Kbb",e="b9H79TebbbeKl9Gbb9Gvuuuuueu9Giuuub9Geueuikqbbebeedddilve9Weeeviebeoweuec:q;Aekr;leDo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbdY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVblE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtboK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbrL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949Wbwl79IV9RbDq;b9tqlbzik9:evu8Jjjjjbcz9Rhbcbheincbhdcbhiinabcwfadfaicjuaead4ceGglE86bbaialfhiadcefgdcw9hmbkaec:q:yjjbfai86bbaecitc:q1jjbfab8Piw83ibaecefgecjd9hmbkk;e8JlHud97euo978Jjjjjbcj;kb9Rgv8Kjjjjbc9:hodnadcefal0mbcuhoaiRbbc:Ge9hmbavaialfgrad9Rad;8qbbcj;abad9UhoaicefhldnadTmbaoc;WFbGgocjdaocjd6EhwcbhDinaDae9pmeawaeaD9RaDawfae6Egqcsfgoc9WGgkci2hxakcethmaocl4cifcd4hPabaDad2fhscbhzdnincbhHalhOcbhAdninaraO9RaP6miavcj;cbfaAak2fhCaOaPfhlcbhidnakc;ab6mbaral9Rc;Gb6mbcbhoinaCaofhidndndndndnaOaoco4fRbbgXciGPlbedibkaipxbbbbbbbbbbbbbbbbpklbxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklbalczfhlkdndndndndnaXcd4ciGPlbedibkaipxbbbbbbbbbbbbbbbbpklzxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklzalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklzalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklzalczfhlkdndndndndnaXcl4ciGPlbedibkaipxbbbbbbbbbbbbbbbbpklaxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklaalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklaalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklaalczfhlkdndndndndnaXco4Plbedibkaipxbbbbbbbbbbbbbbbbpkl8WxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibaXc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spkl8WalclfaYpQbfaXc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibaXc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spkl8WalcwfaYpQbfaXc:q:yjjbfRbbfhlxekaialpbbbpkl8Walczfhlkaoc;abfhiaocjefak0meaihoaral9Rc;Fb0mbkkdndnaiak9pmbaici4hoinaral9RcK6mdaCaifhXdndndndndnaOaico4fRbbaocoG4ciGPlbedibkaXpxbbbbbbbbbbbbbbbbpklbxikaXalpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaXalpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaXalpbbbpklbalczfhlkaocdfhoaiczfgiak6mbkkalTmbaAcd0hHalhOaAcefgAclSmdxekkcbhlaHceGTmdkdnakTmbavcjdfazfhiavazfpbdbhYcbhXinaiavcj;cbfaXfgopblbgLcep9TaLpxeeeeeeeeeeeeeeeegQp9op9Hp9rgLaoakfpblbg8Acep9Ta8AaQp9op9Hp9rg8ApmbzeHdOiAlCvXoQrLgEaoamfpblbg3cep9Ta3aQp9op9Hp9rg3aoaxfpblbg5cep9Ta5aQp9op9Hp9rg5pmbzeHdOiAlCvXoQrLg8EpmbezHdiOAlvCXorQLgQaQpmbedibedibedibediaYp9UgYp9AdbbaiadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaEa8EpmwDKYqk8AExm35Ps8E8FgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaLa8ApmwKDYq8AkEx3m5P8Es8FgLa3a5pmwKDYq8AkEx3m5P8Es8Fg8ApmbezHdiOAlvCXorQLgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaLa8ApmwDKYqk8AExm35Ps8E8FgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfhiaXczfgXak6mbkkazclfgzad6mbkasavcjdfaqad2;8qbbavavcjdfaqcufad2fad;8qbbaqaDfhDc9:hoalmexikkc9:hoxekcbc99aral9Radcaadca0ESEhokavcj;kbf8Kjjjjbaokwbz:bjjjbk;tzeHu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnaeci9UgrcHfal0mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecje;8kbavcUf9cu83ibavc8Wf9cu83ibavcyf9cu83ibavcaf9cu83ibavcKf9cu83ibavczf9cu83ibav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhodnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhlindnaoaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfalaDcu7gPcl4fcsGcitfgsydlhzasydbhHdnaDcsGgDak9pmbavaiaPfcsGcdtfydbaxaDEhsaDThDdndnadcd9hmbabarcetfgPaH87ebaPcdfaz87ebaPclfas87ebxekabarcdtfgPaHBdbaPclfazBdbaPcwfasBdbkaxaDfhxavc;abfalcitfgPasBdbaPazBdlavaicdtfasBdbavc;abfalcefcsGglcitfgPaHBdbaPasBdlaiaDfhialcefhlxdkdndnaDcsSmbamaDfaDc987fcefhmxekaocefhDao8SbbgscFeGhPdndnascu9mmbaDhoxekaocvfhoaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhokaPce4cbaPceG9R7amfhmkdndnadcd9hmbabarcetfgDaH87ebaDcdfaz87ebaDclfam87ebxekabarcdtfgDaHBdbaDclfazBdbaDcwfamBdbkavc;abfalcitfgDamBdbaDazBdlavaicdtfamBdbavc;abfalcefcsGglcitfgDaHBdbaDamBdlaicefhialcefhlxekdnaDcpe0mbaxcefgOavaiaqaDcsGfRbbgscl49RcsGcdtfydbascz6gPEhDavaias9RcsGcdtfydbaOaPfgzascsGgOEhsaOThOdndnadcd9hmbabarcetfgHax87ebaHcdfaD87ebaHclfas87ebxekabarcdtfgHaxBdbaHclfaDBdbaHcwfasBdbkavaicdtfaxBdbavc;abfalcitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfalcefcsGcitfgHasBdbaHaDBdlavaiaPfcsGgicdtfasBdbavc;abfalcdfcsGglcitfgDaxBdbaDasBdlalcefhlaiaOfhiazaOfhxxekaxcbaoRbbgHEgAaDc;:eSgDfhzaHcsGhCaHcl4hXdndnaHcs0mbazcefhOxekazhOavaiaX9RcsGcdtfydbhzkdndnaCmbaOcefhxxekaOhxavaiaH9RcsGcdtfydbhOkdndnaDTmbaocefhDxekaocdfhDao8SbegPcFeGhsdnaPcu9kmbaocofhAascFbGhscrhodninaD8SbbgPcFbGaotasVhsaPcu9kmeaDcefhDaocrfgoc8J9hmbkaAhDxekaDcefhDkasce4cbasceG9R7amfgmhAkdndnaXcsSmbaDhsxekaDcefhsaD8SbbgocFeGhPdnaocu9kmbaDcvfhzaPcFbGhPcrhodninas8SbbgDcFbGaotaPVhPaDcu9kmeascefhsaocrfgoc8J9hmbkazhsxekascefhskaPce4cbaPceG9R7amfgmhzkdndnaCcsSmbashoxekascefhoas8SbbgDcFeGhPdnaDcu9kmbascvfhOaPcFbGhPcrhDdninao8SbbgscFbGaDtaPVhPascu9kmeaocefhoaDcrfgDc8J9hmbkaOhoxekaocefhokaPce4cbaPceG9R7amfgmhOkdndnadcd9hmbabarcetfgDaA87ebaDcdfaz87ebaDclfaO87ebxekabarcdtfgDaABdbaDclfazBdbaDcwfaOBdbkavc;abfalcitfgDazBdbaDaABdlavaicdtfaABdbavc;abfalcefcsGcitfgDaOBdbaDazBdlavaicefgicsGcdtfazBdbavc;abfalcdfcsGcitfgDaABdbaDaOBdlavaiaHcz6aXcsSVfgicsGcdtfaOBdbaiaCTaCcsSVfhialcifhlkawcefhwalcsGhlaicsGhiarcifgrae6mbkkcbc99aoaqSEhokavc;aef8Kjjjjbaok:flevu8Jjjjjbcz9Rhvc9:hodnaecvfal0mbcuhoaiRbbc;:eGc;qe9hmbav9cb83iwaicefhraialfc98fhwdnaeTmbdnadcdSmbcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcdtfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfglBdbaoalBdbaDcefgDae9hmbxdkkcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcetfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfgl87ebaoalBdbaDcefgDae9hmbkkcbc99arawSEhokaok:wPliuo97eue978Jjjjjbca9Rhiaec98Ghldndnadcl9hmbdnalTmbcbhvabhdinadadpbbbgocKp:RecKp:Sep;6egraocwp:RecKp:Sep;6earp;Geaoczp:RecKp:Sep;6egwp;Gep;Kep;LegDpxbbbbbbbbbbbbbbbbp:2egqarpxbbbjbbbjbbbjbbbjgkp9op9rp;Kegrpxbb;:9cbb;:9cbb;:9cbb;:9cararp;MeaDaDp;Meawaqawakp9op9rp;Kegrarp;Mep;Kep;Kep;Jep;Negwp;Mepxbbn0bbn0bbn0bbn0gqp;KepxFbbbFbbbFbbbFbbbp9oaopxbbbFbbbFbbbFbbbFp9op9qarawp;Meaqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaDawp;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpkbbadczfhdavclfgval6mbkkalae9pmeaipxbbbbbbbbbbbbbbbbgqpklbaiabalcdtfgdaeciGglcdtgv;8qbbdnalTmbaiaipblbgocKp:RecKp:Sep;6egraocwp:RecKp:Sep;6earp;Geaoczp:RecKp:Sep;6egwp;Gep;Kep;LegDaqp:2egqarpxbbbjbbbjbbbjbbbjgkp9op9rp;Kegrpxbb;:9cbb;:9cbb;:9cbb;:9cararp;MeaDaDp;Meawaqawakp9op9rp;Kegrarp;Mep;Kep;Kep;Jep;Negwp;Mepxbbn0bbn0bbn0bbn0gqp;KepxFbbbFbbbFbbbFbbbp9oaopxbbbFbbbFbbbFbbbFp9op9qarawp;Meaqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaDawp;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpklbkadaiav;8qbbskdnalTmbcbhvabhdinadczfgxaxpbbbgopxbbbbbbFFbbbbbbFFgkp9oadpbbbgDaopmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eaDaopmbediwDqkzHOAKY8AEgoczp:Sep;6egrp;Geaoczp:Reczp:Sep;6egwp;Gep;Kep;Legopxb;:FSb;:FSb;:FSb;:FSawaopxbbbbbbbbbbbbbbbbp:2egqawpxbbbjbbbjbbbjbbbjgmp9op9rp;Kegwawp;Meaoaop;Mearaqaramp9op9rp;Kegoaop;Mep;Kep;Kep;Jep;Negrp;Mepxbbn0bbn0bbn0bbn0gqp;Keczp:Reawarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9op9qgwaoarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9ogopmwDKYqk8AExm35Ps8E8Fp9qpkbbadaDakp9oawaopmbezHdiOAlvCXorQLp9qpkbbadcafhdavclfgval6mbkkalae9pmbaiaeciGgvcitgdfcbcaad9R;8kbaiabalcitfglad;8qbbdnavTmbaiaipblzgopxbbbbbbFFbbbbbbFFgkp9oaipblbgDaopmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eaDaopmbediwDqkzHOAKY8AEgoczp:Sep;6egrp;Geaoczp:Reczp:Sep;6egwp;Gep;Kep;Legopxb;:FSb;:FSb;:FSb;:FSawaopxbbbbbbbbbbbbbbbbp:2egqawpxbbbjbbbjbbbjbbbjgmp9op9rp;Kegwawp;Meaoaop;Mearaqaramp9op9rp;Kegoaop;Mep;Kep;Kep;Jep;Negrp;Mepxbbn0bbn0bbn0bbn0gqp;Keczp:Reawarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9op9qgwaoarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9ogopmwDKYqk8AExm35Ps8E8Fp9qpklzaiaDakp9oawaopmbezHdiOAlvCXorQLp9qpklbkalaiad;8qbbkk;4wllue97euv978Jjjjjbc8W9Rhidnaec98GglTmbcbhvabhoinaiaopbbbgraoczfgwpbbbgDpmlvorxmPsCXQL358E8Fgqczp:Segkclp:RepklbaopxbbjZbbjZbbjZbbjZpx;Zl81Z;Zl81Z;Zl81Z;Zl81Zakpxibbbibbbibbbibbbp9qp;6ep;NegkaraDpmbediwDqkzHOAKY8AEgrczp:Reczp:Sep;6ep;MegDaDp;Meakarczp:Sep;6ep;Megxaxp;Meakaqczp:Reczp:Sep;6ep;Megqaqp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jepxb;:FSb;:FSb;:FSb;:FSgkp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbgmp9oaxakp;Mearp;Keczp:Rep9qgxaqakp;Mearp;Keczp:ReaDakp;Mearp;Keamp9op9qgkpmbezHdiOAlvCXorQLgrp5baipblbpEb:T:j83ibaocwfarp5eaipblbpEe:T:j83ibawaxakpmwDKYqk8AExm35Ps8E8Fgkp5baipblbpEd:T:j83ibaocKfakp5eaipblbpEi:T:j83ibaocafhoavclfgval6mbkkdnalae9pmbaiaeciGgvcitgofcbcaao9R;8kbaiabalcitfgwao;8qbbdnavTmbaiaipblbgraipblzgDpmlvorxmPsCXQL358E8Fgqczp:Segkclp:RepklaaipxbbjZbbjZbbjZbbjZpx;Zl81Z;Zl81Z;Zl81Z;Zl81Zakpxibbbibbbibbbibbbp9qp;6ep;NegkaraDpmbediwDqkzHOAKY8AEgrczp:Reczp:Sep;6ep;MegDaDp;Meakarczp:Sep;6ep;Megxaxp;Meakaqczp:Reczp:Sep;6ep;Megqaqp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jepxb;:FSb;:FSb;:FSb;:FSgkp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbgmp9oaxakp;Mearp;Keczp:Rep9qgxaqakp;Mearp;Keczp:ReaDakp;Mearp;Keamp9op9qgkpmbezHdiOAlvCXorQLgrp5baipblapEb:T:j83ibaiarp5eaipblapEe:T:j83iwaiaxakpmwDKYqk8AExm35Ps8E8Fgkp5baipblapEd:T:j83izaiakp5eaipblapEi:T:j83iKkawaiao;8qbbkk:Pddiue978Jjjjjbc;ab9Rhidnadcd4ae2glc98GgvTmbcbheabhdinadadpbbbgocwp:Recwp:Sep;6eaocep:SepxbbjFbbjFbbjFbbjFp9opxbbjZbbjZbbjZbbjZp:Uep;Mepkbbadczfhdaeclfgeav6mbkkdnaval9pmbaialciGgecdtgdVcbc;abad9R;8kbaiabavcdtfgvad;8qbbdnaeTmbaiaipblbgocwp:Recwp:Sep;6eaocep:SepxbbjFbbjFbbjFbbjFp9opxbbjZbbjZbbjZbbjZp:Uep;Mepklbkavaiad;8qbbkk9teiucbcbydj1jjbgeabcifc98GfgbBdj1jjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikkkebcjwklz9Tbb",n=new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,3,2,0,0,5,3,1,0,1,12,1,0,10,22,2,12,0,65,0,65,0,65,0,252,10,0,0,11,7,0,65,0,253,15,26,11]),i=new Uint8Array([32,0,65,2,1,106,34,33,3,128,11,4,13,64,6,253,10,7,15,116,127,5,8,12,40,16,19,54,20,9,27,255,113,17,42,67,24,23,146,148,18,14,22,45,70,69,56,114,101,21,25,63,75,136,108,28,118,29,73,115]);if(typeof WebAssembly!="object")return{supported:!1};var o=WebAssembly.validate(n)?e:t,a,s=WebAssembly.instantiate(l(o),{}).then(function(G){a=G.instance,a.exports.__wasm_call_ctors()});function l(G){for(var A=new Uint8Array(G.length),T=0;T96?g-97:g>64?g-39:g+4}for(var C=0,T=0;T0?F(G,A,T,m[g],d[C]):s.then(function(){var y=new Uint8Array(G*A);return r(a,a.exports[m[g]],y,G,A,T,a.exports[d[C]]),y})}}}();var rIn=R(W()),sIn=function(){var t="b9H79Tebbbe9Ek9Geueu9Geub9Gbb9GPuuuuuuuuuuu99uueu9Gvuuuuub9Gluuuub9Gquuuuuuu99uueu9Gwuuuuuu99ueu9Giuuue999Gluuuueu9GiuuueuizsdilvoirwDbqqbeqlve9Weiiviebeoweuec:G;jekr:Tewo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bbz9TW79O9V9Wt9F79P9T9W29P9M95bl8E9TW79O9V9Wt9F79P9T9W29P9M959x9Pt9OcttV9P9I91tW7bvQ9TW79O9V9Wt9F79P9T9W29P9M959q9V9P9Ut7boX9TW79O9V9Wt9F79P9T9W29P9M959t9J9H2Wbra9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94SWt9J9O9sW9T9H9Wbwl79IV9RbDDwebcekdxmq::9Usdbk;i6iKuY99Ou8Jjjjjbc;W;ab9RgP8KjjjjbaPcwfcbc;Kbz:ljjjb8AaPcualcefgscdtascFFFFi0Ecbyd1:jjjbHjjjjbbgzBdwaPceBd9OaPazBdbaPcuadcitadcFFFFe0Ecbyd1:jjjbHjjjjbbgHBdxaPcdBd9OaPaHBdlaPaeadalcbz:cjjjbaPcualcdtgOalcFFFFi0EgAcbyd1:jjjbHjjjjbbgCBdzaPciBd9OaPaAcbyd1:jjjbHjjjjbbgXBdCaPclBd9Oalcd4alfhQcehLinaLgscethLasaQ6mbkcbhKaPcuascdtgLascFFFFi0Ecbyd1:jjjbHjjjjbbgQBdKaPcvBd9OaQcFeaLz:ljjjbhYdnalTmbavcd4h8AascufhEinaiaKa8A2cdtfg3ydlgscH4as7c:F:b:DD2a3ydbgscH4as7c;D;O:B8J27a3ydwgscH4as7c:3F;N8N27hQcbhsdndninaYaQaEGgQcdtfg5ydbgLcuSmeaiaLa8A2cdtfa3cxz:ojjjbTmdascefgsaQfhQasaE9nmbxdkka5aKBdbaKhLkaCaKcdtfaLBdbaKcefgKal9hmbkcbhsaXhLinaLasBdbaLclfhLalascefgs9hmbkcbhsaChLaXhQindnasaLydbgESmbaQaXaEcdtfgEydbBdbaEasBdbkaLclfhLaQclfhQalascefgs9hmbkkcbh8EaYcbyd:m:jjjbH:bjjjbbaPclBd9OaPalcbyd1:jjjbHjjjjbbgEBdKaPcvBd9OaPaAcbyd1:jjjbHjjjjbbgsBd3aPcoBd9OaPaAcbyd1:jjjbHjjjjbbgLBdaaPcrBd9OascFeaOz:ljjjbh8FaLcFeaOz:ljjjbhadnalTmbaHcwfhhindnaza8EgQcefg8Ecdtfydbg3azaQcdtgsfydbgLSmba3aL9RhOaHaLcitfhgaaasfh8Ja8FasfhKcbh8Aindndnaga8Acitfydbg5aQ9hmbaKaQBdba8JaQBdbxekdnaza5cdtg8KfgsclfydbgLasydbgsSmbaHascitg3fydbaQSmeaLas9Rh8Lascu7aLfhYaha3fhLcbhsinaYasSmeascefhsaLydbh3aLcwfhLa3aQ9hmbkasa8L6mekaaa8KfgsaQa5asydbcuSEBdbaKa5aQaKydbcuSEBdbka8Acefg8AaO9hmbkka8Eal9hmbkaChLaXhQaah3a8Fh8AcbhsindndnasaLydbg59hmbdnasaQydbg59hmba8Aydbh5dna3ydbgYcu9hmba5cu9hmbaEasfcb86bbxikaEasfhKdnasaYSmbasa5SmbaKce86bbxikaKcl86bbxdkdnasaXa5cdtgYfydb9hmbdna3ydbgKcuSmbasaKSmba8AydbgOcuSmbasaOSmbaaaYfydbggcuSmbaga5Smba8FaYfydbgYcuSmbaYa5SmbdnaCaKcdtfydbaCaYcdtfydb9hmbaCaOcdtfydbaCagcdtfydb9hmbaEasfcd86bbxlkaEasfcl86bbxikaEasfcl86bbxdkaEasfcl86bbxekaEasfaEa5fRbb86bbkaLclfhLaQclfhQa3clfh3a8Aclfh8Aalascefgs9hmbkaxceGTmbaEhsalhLindnasRbbce9hmbascl86bbkascefhsaLcufgLmbkkcualcx2alc;v:Q;v:Qe0Ecbyd1:jjjbHjjjjbbh8JaPcwfaPyd9Ogscdtfa8JBdbaPascefgOBd9Oa8Jaialavz:djjjbdndnaDmbcbhvxekcbh5aPcwfaOcdtfcuaDal2gLcdtaLcFFFFi0Ecbyd1:jjjbHjjjjbbgvBdbaPascdfgOBd9OalTmbarcd4cdthYaDcdthKavh8AinaohsawhLa8AhQaDh3inaQasIdbaLIdbNUdbasclfhsaLclfhLaQclfhQa3cufg3mbkaoaYfhoa8AaKfh8Aa5cefg5al9hmbkkaPcwfaOcdtfcualc8S2gsalc;D;O;f8U0EgQcbyd1:jjjbHjjjjbbgLBdbaPaOcefg3Bd9OaLcbasz:ljjjbh8EdndndnaDTmbaPcwfa3cdtfaQcbyd1:jjjbHjjjjbbgoBdbaPaOcdfgLBd9Oaocbasz:ljjjb8AaPcwfaLcdtfcuaDal2gscltgLascFFFFb0Ecbyd1:jjjbHjjjjbbgwBdbaPaOcifBd9OawcbaLz:ljjjb8AadmexdkcbhocbhwadTmekcbh8AaehLindna8JaLclfydbg5cx2fgsIdba8JaLydbgYcx2fgQIdbg8M:tg8Na8JaLcwfydbgKcx2fg3IdlaQIdlgy:tg8PNa3Idba8M:tgIasIdlay:tg8RN:tg8Sa8SNa8Ra3IdwaQIdwgR:tg8UNa8PasIdwaR:tg8RN:tg8Pa8PNa8RaINa8Ua8NN:tg8Na8NNMM:rgIJbbbb9ETmba8SaI:vh8Sa8NaI:vh8Na8PaI:vh8Pka8EaCaYcdtfydbc8S2fgsa8PaI:rgIa8PNNg8RasIdbMUdbasa8NaIa8NNg8VNg8UasIdlMUdlasa8SaIa8SNg8WNg8XasIdwMUdwasa8Va8PNg8VasIdxMUdxasa8Wa8PNg8YasIdzMUdzasa8Wa8NNg8WasIdCMUdCasa8PaIa8SaRNa8Pa8MNaya8NNMM:mgyNg8MNg8PasIdKMUdKasa8Na8MNg8NasId3MUd3asa8Sa8MNg8SasIdaMUdaasa8MayNg8MasId8KMUd8KasaIasIdyMUdya8EaCa5cdtfydbc8S2fgsa8RasIdbMUdbasa8UasIdlMUdlasa8XasIdwMUdwasa8VasIdxMUdxasa8YasIdzMUdzasa8WasIdCMUdCasa8PasIdKMUdKasa8NasId3MUd3asa8SasIdaMUdaasa8MasId8KMUd8KasaIasIdyMUdya8EaCaKcdtfydbc8S2fgsa8RasIdbMUdbasa8UasIdlMUdlasa8XasIdwMUdwasa8VasIdxMUdxasa8YasIdzMUdzasa8WasIdCMUdCasa8PasIdKMUdKasa8NasId3MUd3asa8SasIdaMUdaasa8MasId8KMUd8KasaIasIdyMUdyaLcxfhLa8Acifg8Aad6mbkcbh5aehYincbhLinaEaeaLc:G1jjbfydba5fcdtfydbgQfRbbhsdndnaEaYaLfydbg3fRbbg8Ac99fcFeGcpe0mbasceSmbascd9hmekdna8AcufcFeGce0mba8Fa3cdtfydbaQ9hmekdnascufcFeGce0mbaaaQcdtfydba39hmekdna8Acv2asfc:W1jjbfRbbTmbaCaQcdtfydbaCa3cdtfydb0mekJbbacJbbjZasceSEhIa8AceShOa8JaeaLc:K1jjbfydba5fcdtfydbcx2fhsdna8JaQcx2fg8AIdwa8Ja3cx2fgKIdwgy:tg8Pa8PNa8AIdbaKIdbgR:tg8Na8NNa8AIdlaKIdlg8R:tg8Sa8SNMM:rg8MJbbbb9ETmba8Pa8M:vh8Pa8Sa8M:vh8Sa8Na8M:vh8NkJbbacaIaOEh8WdnasIdway:tgIa8PaIa8PNasIdbaR:tg8Xa8NNa8SasIdla8R:tg8VNMMg8UN:tgIaINa8Xa8Na8UN:tg8Pa8PNa8Va8Sa8UN:tg8Na8NNMM:rg8SJbbbb9ETmbaIa8S:vhIa8Na8S:vh8Na8Pa8S:vh8Pka8EaCa3cdtfydbc8S2fgsa8Pa8Wa8MNg8Sa8PNNg8UasIdbMUdbasa8Na8Sa8NNg8WNg8XasIdlMUdlasaIa8SaINg8MNg8VasIdwMUdwasa8Wa8PNg8WasIdxMUdxasa8Ma8PNg8YasIdzMUdzasa8Ma8NNg8ZasIdCMUdCasa8Pa8SaIayNa8PaRNa8Ra8NNMM:mgyNg8MNg8PasIdKMUdKasa8Na8MNg8NasId3MUd3asaIa8MNgIasIdaMUdaasa8MayNg8MasId8KMUd8Kasa8SasIdyMUdya8EaCaQcdtfydbc8S2fgsa8UasIdbMUdbasa8XasIdlMUdlasa8VasIdwMUdwasa8WasIdxMUdxasa8YasIdzMUdzasa8ZasIdCMUdCasa8PasIdKMUdKasa8NasId3MUd3asaIasIdaMUdaasa8MasId8KMUd8Kasa8SasIdyMUdykaLclfgLcx9hmbkaYcxfhYa5cifg5ad6mbkaDTmbcbhYinJbbbbhRa8JaeaYcdtfgsclfydbgKcx2fgLIdwa8JasydbgOcx2fgQIdwg8V:tg8Na8NNaLIdbaQIdbg8Y:tgIaINaLIdlaQIdlg8Z:tg8Sa8SNMMg8Wa8Jascwfydbggcx2fgsIdwa8V:tg8MNa8Na8Na8MNaIasIdba8Y:tgyNa8SasIdla8Z:tg8RNMMg8PN:tJbbbbJbbjZa8Wa8Ma8MNayayNa8Ra8RNMMg8XNa8Pa8PN:tg8U:va8UJbbbb9BEg8UNh80a8Xa8NNa8Ma8PN:ta8UNh81a8Wa8RNa8Sa8PN:ta8UNhBa8Xa8SNa8Ra8PN:ta8UNh83a8WayNaIa8PN:ta8UNhUa8XaINaya8PN:ta8UNh85aIa8RNaya8SN:tg8Pa8PNa8Sa8MNa8Ra8NN:tg8Pa8PNa8NayNa8MaIN:tg8Pa8PNMM:r:rh8PavaOaD2cdtfhLavagaD2cdtfhQavaKaD2cdtfh3a8V:mh86a8Z:mh87a8Y:mh88cbh8AaDh5Jbbbbh8RJbbbbh8UJbbbbh8WJbbbbh8XJbbbbh8VJbbbbh8YJbbbbh8ZJbbbbh89Jbbbbh8:inaPc;Wbfa8Afgscwfa8Pa81a3IdbaLIdbg8M:tg8SNa80aQIdba8M:tgyNMg8NNUdbasclfa8Pa83a8SNaBayNMgINUdbasa8Pa85a8SNaUayNMg8SNUdbascxfa8Pa86a8NNa87aINa8Ma88a8SNMMMg8MNUdba8Pa8NaINNa8XMh8Xa8Pa8Na8SNNa8VMh8Va8PaIa8SNNa8YMh8Ya8Pa8Ma8MNNaRMhRa8Pa8Na8MNNa8RMh8Ra8PaIa8MNNa8UMh8Ua8Pa8Sa8MNNa8WMh8Wa8Pa8Na8NNNa8ZMh8Za8PaIaINNa89Mh89a8Pa8Sa8SNNa8:Mh8:aLclfhLa3clfh3aQclfhQa8Aczfh8Aa5cufg5mbkaoaCaOcdtfydbgLc8S2fgsa8:asIdbMUdbasa89asIdlMUdlasa8ZasIdwMUdwasa8YasIdxMUdxasa8VasIdzMUdzasa8XasIdCMUdCasa8WasIdKMUdKasa8UasId3MUd3asa8RasIdaMUdaasaRasId8KMUd8Kasa8PasIdyMUdyaoaCaKcdtfydbgKc8S2fgsa8:asIdbMUdbasa89asIdlMUdlasa8ZasIdwMUdwasa8YasIdxMUdxasa8VasIdzMUdzasa8XasIdCMUdCasa8WasIdKMUdKasa8UasId3MUd3asa8RasIdaMUdaasaRasId8KMUd8Kasa8PasIdyMUdyaoaCagcdtfydbgOc8S2fgsa8:asIdbMUdbasa89asIdlMUdlasa8ZasIdwMUdwasa8YasIdxMUdxasa8VasIdzMUdzasa8XasIdCMUdCasa8WasIdKMUdKasa8UasId3MUd3asa8RasIdaMUdaasaRasId8KMUd8Kasa8PasIdyMUdyawaLaD2cltfh5cbhLaDh3ina5aLfgsaPc;WbfaLfgQIdbasIdbMUdbasclfg8AaQclfIdba8AIdbMUdbascwfg8AaQcwfIdba8AIdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa3cufg3mbkawaKaD2cltfh5cbhLaDh3ina5aLfgsaPc;WbfaLfgQIdbasIdbMUdbasclfg8AaQclfIdba8AIdbMUdbascwfg8AaQcwfIdba8AIdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa3cufg3mbkawaOaD2cltfh5cbhLaDh3ina5aLfgsaPc;WbfaLfgQIdbasIdbMUdbasclfg8AaQclfIdba8AIdbMUdbascwfg8AaQcwfIdba8AIdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa3cufg3mbkaYcifgYad6mbkkdnabaeSmbabaeadcdtz:kjjjb8AkaPydbhZcbhsdnalTmbaZclfhsaZydbh3aEhLalh8AcbhQincbasydbg5a39RaLRbbcpeGEaQfhQaLcefhLasclfhsa5h3a8Acufg8AmbkaQce4hskcuadas9Rcifgrcx2arc;v:Q;v:Qe0Ecbyd1:jjjbHjjjjbbh8LaPcwfaPyd9Ogscdtfa8LBdbaPascefgLBd9OaPcwfaLcdtfcuarcdtarcFFFFi0Ecbyd1:jjjbHjjjjbbgxBdbaPascdfgLBd9OaPcwfaLcdtfaAcbyd1:jjjbHjjjjbbgHBdbaPascifgLBd9OaPcwfaLcdtfalcbyd1:jjjbHjjjjbbgnBdbaPasclfBd9OJbbbbh8Ydnadaq9nmbdnarci6mbakakNh8VaDclthca8Lcwfh9cJbbbbh8YinaPabadghalaCz:cjjjbabhOcbhzcbhKincbhsindnaCaOasfydbgQcdtgYfydbg8AaCabasc;m1jjbfydbaKfcdtfydbgLcdtfydbg5SmbaEaLfRbbgecv2aEaQfRbbg3fc;G1jjbfRbbg8Ka3cv2aefggc;G1jjbfRbbgiVcFeGTmbdnagc:W1jjbfRbbTmba5a8A0mekdna3ae9hmba3cufcFeGce0mba8FaYfydbaL9hmeka8Lazcx2fg3aLaQaicFeGg8AEBdla3aQaLa8AEBdba3a8Aa8KGcb9hBdwazcefhzkasclfgscx9hmbkdnaKcifgKah9pmbaOcxfhOazcifar9nmekkdnazmbahhdxikcbheinJbbbbJbbjZa8EaCa8Laecx2fg3ydlg8Aa3ydbg5a3ydwgLEgKcdtfydbg8Kc8S2gifgsIdyg8P:va8PJbbbb9BEasIdwa8Ja5a8AaLEgYcx2fgLIdwg8SNasIdzaLIdbg8MNasIdaMg8Pa8PMMa8SNasIdlaLIdlgyNasIdCa8SNasId3Mg8Pa8PMMayNasIdba8MNasIdxayNasIdKMg8Pa8PMMa8MNasId8KMMM:lNh8WJbbbbJbbjZa8EaCa5cdtfydbgdc8S2gQfgsIdyg8P:va8PJbbbb9BEasIdwa8Ja8Acx2fgLIdwgINasIdzaLIdbgRNasIdaMg8Pa8PMMaINasIdlaLIdlg8RNasIdCaINasId3Mg8Pa8PMMa8RNasIdbaRNasIdxa8RNasIdKMg8Pa8PMMaRNasId8KMMM:lNh8Xa3cwfhOa3clfhgdnaDTmbaoaQfgQIdwaINaQIdzaRNaQIdaMg8Pa8PMMaINaQIdla8RNaQIdCaINaQId3Mg8Pa8PMMa8RNaQIdbaRNaQIdxa8RNaQIdKMg8Pa8PMMaRNaQId8KMMMh8Nava8AaD2cdtfhLawadaD2cltfhsaQIdyh8UaDhQinaLIdbg8PJbbb;aNascxfIdbaIascwfIdbNaRasIdbNa8RasclfIdbNMMMNa8Pa8PNa8UNa8NMMh8NaLclfhLasczfhsaQcufgQmbkaoaifgQIdwa8SNaQIdza8MNaQIdaMg8Pa8PMMa8SNaQIdlayNaQIdCa8SNaQId3Mg8Pa8PMMayNaQIdba8MNaQIdxayNaQIdKMg8Pa8PMMa8MNaQId8KMMMhIavaYaD2cdtfhLawa8KaD2cltfhsaQIdyhRaDhQinaLIdbg8PJbbb;aNascxfIdba8SascwfIdbNa8MasIdbNayasclfIdbNMMMNa8Pa8PNaRNaIMMhIaLclfhLasczfhsaQcufgQmbka8WaI:lMh8Wa8Xa8N:lMh8Xkaga8AaYa8Xa8W9FgsEBdba3a5aKasEBdbaOa8Xa8WasEUdbaecefgeaz9hmbkaPc;Wbfcbcj;abz:ljjjb8Aa9chsazhLinaPc;WbfasydbcO4c;8ZGfgQaQydbcefBdbascxfhsaLcufgLmbkcbhscbhLinaPc;WbfasfgQydbh3aQaLBdba3aLfhLasclfgscj;ab9hmbkcbhsa9chLinaPc;WbfaLydbcO4c;8ZGfgQaQydbgQcefBdbaxaQcdtfasBdbaLcxfhLazascefgs9hmbkahaq9RgQci9UhJdnalTmbcbhsaHhLinaLasBdbaLclfhLalascefgs9hmbkkcbh9eancbalz:ljjjbhTaQcO9UhSaJce4h9haPydlh9icbhicbhgdnina8Laxagcdtfydbcx2fgOIdwg8Na8V9EmeaiaJ9pmeJFFuuh8Pdna9haz9pmba8Laxa9hcdtfydbcx2fIdwJbb;aZNh8Pkdna8Na8P9ETmbaiaS0mdkdnaTaCaOydlg6cdtg9kfydbg3fg0RbbaTaCaOydbgKcdtg9mfydbg9nfg9oRbbVmbdnaZa9ncdtfgsclfydbgLasydbgsSmbaLas9Rh5a9iascitfhsa8Ja3cx2fgYcwfhdaYclfhAa8Ja9ncx2fg8Kcwfh9pa8Kclfh9qcbhLcehednindnaHasydbcdtfydbgQa3SmbaHasclfydbcdtfydbg8Aa3SmbaQa8ASmba8Ja8Acx2fg8AIdba8JaQcx2fgQIdbgI:tg8Pa9qIdbaQIdlg8S:tg8MNa8KIdbaI:tgya8AIdla8S:tg8NN:ta8PaAIdba8S:tgRNaYIdbaI:tg8Ra8NN:tNa8Na9pIdbaQIdwg8S:tg8UNa8Ma8AIdwa8S:tgIN:ta8NadIdba8S:tg8SNaRaIN:tNaIayNa8Ua8PN:taIa8RNa8Sa8PN:tNMMJbbbb9FmdkascwfhsaLcefgLa56hea5aL9hmbkkaeceGTmba9hcefh9hxeka8Ea3c8S2gQfgsa8Ea9nc8S2g8AfgLIdbasIdbMUdbasaLIdlasIdlMUdlasaLIdwasIdwMUdwasaLIdxasIdxMUdxasaLIdzasIdzMUdzasaLIdCasIdCMUdCasaLIdKasIdKMUdKasaLId3asId3MUd3asaLIdaasIdaMUdaasaLId8KasId8KMUd8KasaLIdyasIdyMUdydnaDTmbaoaQfgsaoa8AfgLIdbasIdbMUdbasaLIdlasIdlMUdlasaLIdwasIdwMUdwasaLIdxasIdxMUdxasaLIdzasIdzMUdzasaLIdCasIdCMUdCasaLIdKasIdKMUdKasaLId3asId3MUd3asaLIdaasIdaMUdaasaLId8KasId8KMUd8KasaLIdyasIdyMUdyaca9n2heaca32hYawhLaDh8AinaLaYfgsaLaefgQIdbasIdbMUdbasclfg5aQclfIdba5IdbMUdbascwfg5aQcwfIdba5IdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa8Acufg8AmbkkaOcwfhLdndndndnaEaKfgQRbbc9:fPdebdkaKhsinaHascdtgsfa3BdbaXasfydbgsaK9hmbxikkaXa9kfydbhsaXa9mfydbhKaHa9mfa6Bdbash6kaHaKcdtfa6Bdbka9oce86bba0ce86bbaLIdbg8Pa8Ya8Ya8P9DEh8Ya9ecefh9ececdaQRbbceSEaifhikagcefggaz9hmbkkdna9embahhdxikdnalTmbcbhLa8FhsindnasydbgQcuSmbdnaLaHaQcdtg3fydbgQ9hmba8Fa3fydbhQkasaQBdbkasclfhsalaLcefgL9hmbkcbhLaahsindnasydbgQcuSmbdnaLaHaQcdtg3fydbgQ9hmbaaa3fydbhQkasaQBdbkasclfhsalaLcefgL9hmbkkcbhdabhscbh8AindnaHasydbcdtfydbgLaHasclfydbcdtfydbgQSmbaLaHascwfydbcdtfydbg3SmbaQa3Smbabadcdtfg5aLBdba5clfaQBdba5cwfa3Bdbadcifhdkascxfhsa8Acifg8Aah6mbkadaq9nmdxbkkaPabadalaCz:cjjjbkdnamTmbama8Y:rUdbkaPyd9OgscdtaPcwffc98fhCdninasTmeaCydbcbyd:m:jjjbH:bjjjbbaCc98fhCascufhsxbkkaPc;W;abf8Kjjjjbadk;:ieouabydlhvabydbclfcbaicdtz:ljjjbhoadci9UhrdnadTmbdnalTmbaehwadhDinaoalawydbcdtfydbcdtfgqaqydbcefBdbawclfhwaDcufgDmbxdkkaehwadhDinaoawydbcdtfgqaqydbcefBdbawclfhwaDcufgDmbkkdnaiTmbcbhDaohwinawydbhqawaDBdbawclfhwaqaDfhDaicufgimbkkdnadci6mbarcearce0EhdinaecwfydbhwaeclfydbhDaeydbhidnalTmbalawcdtfydbhwalaDcdtfydbhDalaicdtfydbhikavaoaicdtfgqydbcitfaDBdbavaqydbcitfawBdlaqaqydbcefBdbavaoaDcdtfgqydbcitfawBdbavaqydbcitfaiBdlaqaqydbcefBdbavaoawcdtfgwydbcitfaiBdbavawydbcitfaDBdlawawydbcefBdbaecxfheadcufgdmbkkabydbcbBdbk:Zldouv998Jjjjjbca9Rglczfcwfcbyd11jjbBdbalcb8Pdj1jjb83izalcwfcbydN1jjbBdbalcb8Pd:m1jjb83ibdnadTmbaicd4hvdnabTmbavcdthocbhraehwinabarcx2fgiaearav2cdtfgDIdbUdbaiaDIdlUdlaiaDIdwUdwcbhiinalczfaifgDawaifIdbgqaDIdbgkakaq9EEUdbalaifgDaqaDIdbgkakaq9DEUdbaiclfgicx9hmbkawaofhwarcefgrad9hmbxdkkavcdthrcbhwincbhiinalczfaifgDaeaifIdbgqaDIdbgkakaq9EEUdbalaifgDaqaDIdbgkakaq9DEUdbaiclfgicx9hmbkaearfheawcefgwad9hmbkkdnabTmbadTmbJbbbbJbbjZalIdbalIdzgk:tJbbbb:xgqalIdlalIdCgx:tgmamaq9DEgqalIdwalIdKgm:tgPaPaq9DEgq:vaqJbbbb9BEhqinabaqabIdbak:tNUdbabclfgiaqaiIdbax:tNUdbabcwfgiaqaiIdbam:tNUdbabcxfhbadcufgdmbkkk8KbabaeadaialavcbcbcbcbaoarawaDz:bjjjbk8KbabaeadaialavaoarawaDaqakaxamz:bjjjbk;lOowud99wue99iul998Jjjjjbc;Wb9Rgw8KjjjjbdndnarmbcbhDxekawcwfcbc;Kbz:ljjjb8Aawcuadcx2adc;v:Q;v:Qe0Ecbyd1:jjjbHjjjjbbgqBdwawceBd9Oaqaeadaiz:djjjbawcuadcdtadcFFFFi0Egkcbyd1:jjjbHjjjjbbgxBdxawcdBd9Oadcd4adfhmceheinaegicetheaiam6mbkcbhmawcuaicdtgPaicFFFFi0Ecbyd1:jjjbHjjjjbbgsBdzawciBd9Odndnar:Zgz:rJbbbZMgH:lJbbb9p9DTmbaH:Ohexekcjjjj94hekaicufhOc:bwhAcbhCcbhXadhQinaChLaeaAgKcufaeaK9iEamgDcefaeaD9kEhYdndnadTmbaYcuf:YhHaqhiaxheadhmindndnaiIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhAxekcjjjj94hAkaAcCthAdndnaiclfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaCcqtaAVhAdndnaicwfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaeaAaCVBdbaicxfhiaeclfheamcufgmmbkascFeaPz:ljjjbhEcbh3cbh5indnaEaxa5cdtfydbgAcm4aA7c:v;t;h;Ev2gics4ai7aOGgmcdtfgCydbgecuSmbaeaASmbcehiinaEamaifaOGgmcdtfgCydbgecuSmeaicefhiaeaA9hmbkkaCaABdba3aecuSfh3a5cefg5ad9hmbxdkkascFeaPz:ljjjb8Acbh3kaDaYa3ar0giEhmaLa3aiEhCdna3arSmbaYaKaiEgAam9Rcd9imbdndnaXcl0mbdnaQ:ZgHaL:Zg8A:taY:Yg8EaD:Y:tg8Fa8EaK:Y:tgaa3:Zghaz:tNNNaHaz:taaNa8Aah:tNa8Aaz:ta8FNahaH:tNM:va8EMJbbbZMgH:lJbbb9p9DTmbaH:Ohexdkcjjjj94hexekamaAfcd9Theka3aQaiEhQaXcefgXcs9hmekkdndnaCmbcihicbhDxekcbhiawakcbyd1:jjjbHjjjjbbg5BdCawclBd9OdndnadTmbamcuf:YhHaqhiaxheadhmindndnaiIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhAxekcjjjj94hAkaAcCthAdndnaiclfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaCcqtaAVhAdndnaicwfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaeaAaCVBdbaicxfhiaeclfheamcufgmmbkascFeaPz:ljjjbhEcbhDcbh3inaxa3cdtgYfydbgAcm4aA7c:v;t;h;Ev2gics4ai7hecbhidndninaEaeaOGgmcdtfgCydbgecuSmednaxaecdtgCfydbaASmbaicefgiamfheaiaO9nmekka5aCfydbhixekaCa3BdbaDhiaDcefhDka5aYfaiBdba3cefg3ad9hmbkcuaDc32giaDc;j:KM;jb0EhexekascFeaPz:ljjjb8AcbhDcbhekawaecbyd1:jjjbHjjjjbbgeBdKawcvBd9Oaecbaiz:ljjjbhOavcd4hxdnadTmbaxcdth3a5hmalhAaqheadhEinaOamydbc32fgiaeIdbaiIdbMUdbaiaeclfIdbaiIdlMUdlaiaecwfIdbaiIdwMUdwaiaAc;81jjbalEgCIdbaiIdxMUdxaiaCIdlaiIdzMUdzaiaCIdwaiIdCMUdCaiaiIdKJbbjZMUdKamclfhmaAa3fhAaecxfheaEcufgEmbkkdnaDTmbaOcxfhiaDheinaictfgmamIdbJbbbbJbbjZaicxfIdbgH:vaHJbbbb9BEgHNUdbaic94fgmaHamIdbNUdbaic98fgmaHamIdbNUdbaiaHaiIdbNUdbaiclfgmaHamIdbNUdbaicwfgmaHamIdbNUdbaic3fhiaecufgembkkcbhAawcuaDcdtgYaDcFFFFi0Egicbyd1:jjjbHjjjjbbgeBd3awcoBd9Oawaicbyd1:jjjbHjjjjbbgEBdaaecFeaYz:ljjjbh3dnadTmbaoaoNh8Aaxcdthxalheina8Aaec;81jjbalEgmIdwaOa5ydbgCc32fgiIdC:tgHaHNamIdbaiIdx:tgHaHNamIdlaiIdz:tgHaHNMMNaqcwfIdbaiIdw:tgHaHNaqIdbaiIdb:tgHaHNaqclfIdbaiIdl:tgHaHNMMMhHdndna3aCcdtgifgmydbcuSmbaEaifIdbaH9ETmekamaABdbaEaifaHUdbka5clfh5aeaxfheaqcxfhqadaAcefgA9hmbkkaba3aYz:kjjjb8AcrhikaicdthiinaiTmeaic98fgiawcwffydbcbyd:m:jjjbH:bjjjbbxbkkawc;Wbf8KjjjjbaDk:Qdidui99ducbhi8Jjjjjbca9Rglczfcwfcbyd11jjbBdbalcb8Pdj1jjb83izalcwfcbydN1jjbBdbalcb8Pd:m1jjb83ibdndnaembJbbjFhvJbbjFhoJbbjFhrxekadcd4cdthwincbhdinalczfadfgDabadfIdbgoaDIdbgrarao9EEUdbaladfgDaoaDIdbgrarao9DEUdbadclfgdcx9hmbkabawfhbaicefgiae9hmbkalIdwalIdK:thralIdlalIdC:thoalIdbalIdz:thvkavJbbbb:xgvaoaoav9DEgoararao9DEk9DeeuabcFeaicdtz:ljjjbhlcbhbdnadTmbindnalaeydbcdtfgiydbcu9hmbaiabBdbabcefhbkaeclfheadcufgdmbkkabk9teiucbcbyd:q:jjjbgeabcifc98GfgbBd:q:jjjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd:q:jjjbgeabcrfc94GfgbBd:q:jjjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik9:eiuZbhedndncbyd:q:jjjbgdaecztgi9nmbcuheadai9RcFFifcz4nbcuSmekadhekcbabae9Rcifc98Gcbyd:q:jjjbfgdBd:q:jjjbdnadZbcztge9nmbadae9RcFFifcz4nb8Akk6eiucbhidnadTmbdninabRbbglaeRbbgv9hmeaecefheabcefhbadcufgdmbxdkkalav9Rhikaikk:Iedbcjwk1eFFuuFFuuFFuuFFuFFFuFFFuFbbbbbbbbebbbdbbbbbbbebbbeeebeebebbeeebebbbbbebebbbbbebbbdbbbbbbbbbbbbbbbeeeeebebbbbbebbbbbeebbbbbbbbbbbbbbbbbbbbbc1Dkxebbbdbbb:G9Kbb",e=new Uint8Array([32,0,65,2,1,106,34,33,3,128,11,4,13,64,6,253,10,7,15,116,127,5,8,12,40,16,19,54,20,9,27,255,113,17,42,67,24,23,146,148,18,14,22,45,70,69,56,114,101,21,25,63,75,136,108,28,118,29,73,115]);if(typeof WebAssembly!="object")return{supported:!1};var n,i=WebAssembly.instantiate(o(t),{}).then(function(u){n=u.instance,n.exports.__wasm_call_ctors()});function o(u){for(var F=new Uint8Array(u.length),U=0;U96?G-97:G>64?G-39:G+4}for(var A=0,U=0;U=3),a(G>=0&&G<=u.length),a(G%3==0),a(A>=0&&A<=1);for(var g=0,C=0;C<(T?T.length:0);++C)g|=b[T[C]];var y=u.BYTES_PER_ELEMENT==4?u:new Uint32Array(u),Y=d(n.exports.meshopt_simplify,y,u.length,F,F.length/U,U*4,G,A,g);return Y[0]=u instanceof Uint32Array?Y[0]:new u.constructor(Y[0]),Y},simplifyWithAttributes:function(u,F,U,G,A,T,g,C,y){a(this.useExperimentalFeatures),a(u instanceof Uint32Array||u instanceof Int32Array||u instanceof Uint16Array||u instanceof Int16Array),a(u.length%3==0),a(F instanceof Float32Array),a(F.length%U==0),a(U>=3),a(G instanceof Float32Array),a(G.length%A==0),a(A>=0),a(g>=0&&g<=u.length),a(g%3==0),a(C>=0&&C<=1),a(Array.isArray(T)),a(A>=T.length),a(T.length<=16);for(var Y=0,Q=0;Q<(y?y.length:0);++Q)Y|=b[y[Q]];var J=u.BYTES_PER_ELEMENT==4?u:new Uint32Array(u),M=m(n.exports.meshopt_simplifyWithAttributes,J,u.length,F,F.length/U,U*4,G,A*4,new Float32Array(T),g,C,Y);return M[0]=u instanceof Uint32Array?M[0]:new u.constructor(M[0]),M},getScale:function(u,F){return a(u instanceof Float32Array),a(u.length%F==0),a(F>=3),h(n.exports.meshopt_simplifyScale,u,u.length/F,F*4)},simplifyPoints:function(u,F,U,G,A,T){return a(this.useExperimentalFeatures),a(u instanceof Float32Array),a(u.length%F==0),a(F>=3),a(U>=0&&U<=u.length/F),G?(a(G instanceof Float32Array),a(G.length%A==0),a(A>=3),a(u.length/F==G.length/A),Z(n.exports.meshopt_simplifyPoints,u,u.length/F,F*4,G,A*4,T,U)):Z(n.exports.meshopt_simplifyPoints,u,u.length/F,F*4,void 0,0,0,U)}}}();function uA(t){t=f(t,f.EMPTY_OBJECT);let e=t.resourceCache,n=t.gltf,i=t.bufferViewId,o=t.gltfResource,a=t.baseResource,s=t.cacheKey,l=n.bufferViews[i],r=l.buffer,d=l.byteOffset,m=l.byteLength,h=!1,Z,b,u,F;if(co(l,"EXT_meshopt_compression")){let G=l.extensions.EXT_meshopt_compression;r=G.buffer,d=f(G.byteOffset,0),m=G.byteLength,h=!0,Z=G.byteStride,b=G.count,u=G.mode,F=f(G.filter,"NONE")}let U=n.buffers[r];this._hasMeshopt=h,this._meshoptByteStride=Z,this._meshoptCount=b,this._meshoptMode=u,this._meshoptFilter=F,this._resourceCache=e,this._gltfResource=o,this._baseResource=a,this._buffer=U,this._bufferId=r,this._byteOffset=d,this._byteLength=m,this._cacheKey=s,this._bufferLoader=void 0,this._typedArray=void 0,this._state=pn.UNLOADED,this._promise=void 0}c(Object.create)&&(uA.prototype=Object.create(Va.prototype),uA.prototype.constructor=uA);Object.defineProperties(uA.prototype,{cacheKey:{get:function(){return this._cacheKey}},typedArray:{get:function(){return this._typedArray}}});async function M8t(t){try{let e=_8t(t);if(t._bufferLoader=e,await e.load(),t.isDestroyed())return;let n=e.typedArray,i=new Uint8Array(n.buffer,n.byteOffset+t._byteOffset,t._byteLength);if(t.unload(),t._typedArray=i,t._hasMeshopt){let o=t._meshoptCount,a=t._meshoptByteStride,s=new Uint8Array(o*a);lbt.decodeGltfBuffer(s,o,a,t._typedArray,t._meshoptMode,t._meshoptFilter),t._typedArray=s}return t._state=pn.READY,t}catch(e){if(t.isDestroyed())return;throw t.unload(),t._state=pn.FAILED,t.getError("Failed to load buffer view",e)}}uA.prototype.load=async function(){return c(this._promise)?this._promise:(this._state=pn.LOADING,this._promise=M8t(this),this._promise)};function _8t(t){let e=t._resourceCache,n=t._buffer;if(c(n.uri)){let o=t._baseResource.getDerivedResource({url:n.uri});return e.getExternalBufferLoader({resource:o})}return e.getEmbeddedBufferLoader({parentResource:t._gltfResource,bufferId:t._bufferId})}uA.prototype.unload=function(){c(this._bufferLoader)&&!this._bufferLoader.isDestroyed()&&this._resourceCache.unload(this._bufferLoader),this._bufferLoader=void 0,this._typedArray=void 0};var QE=uA;var QIn=R(W(),1);var gIn=R(W(),1);function il(){}il._maxDecodingConcurrency=Math.max(In.hardwareConcurrency-1,1);il._decoderTaskProcessor=void 0;il._taskProcessorReady=!1;il._error=void 0;il._getDecoderTaskProcessor=function(){if(!c(il._decoderTaskProcessor)){let t=new $i("decodeDraco",il._maxDecodingConcurrency);t.initWebAssemblyModule({wasmBinaryFile:"ThirdParty/draco_decoder.wasm"}).then(function(e){e?il._taskProcessorReady=!0:il._error=new St("Draco decoder could not be initialized.")}).catch(e=>{il._error=e}),il._decoderTaskProcessor=t}return il._decoderTaskProcessor};il.decodePointCloud=function(t){let e=il._getDecoderTaskProcessor();if(c(il._error))throw il._error;if(il._taskProcessorReady)return e.scheduleTask(t,[t.buffer.buffer])};il.decodeBufferView=function(t){let e=il._getDecoderTaskProcessor();if(c(il._error))throw il._error;if(il._taskProcessorReady)return e.scheduleTask(t,[t.array.buffer])};var $R=il;function xf(t){t=f(t,f.EMPTY_OBJECT);let e=t.resourceCache,n=t.gltf,i=t.draco,o=t.gltfResource,a=t.baseResource,s=t.cacheKey;this._resourceCache=e,this._gltfResource=o,this._baseResource=a,this._gltf=n,this._draco=i,this._cacheKey=s,this._bufferViewLoader=void 0,this._bufferViewTypedArray=void 0,this._decodePromise=void 0,this._decodedData=void 0,this._state=pn.UNLOADED,this._promise=void 0,this._dracoError=void 0}c(Object.create)&&(xf.prototype=Object.create(Va.prototype),xf.prototype.constructor=xf);Object.defineProperties(xf.prototype,{cacheKey:{get:function(){return this._cacheKey}},decodedData:{get:function(){return this._decodedData}}});async function D8t(t){let e=t._resourceCache;try{let n=e.getBufferViewLoader({gltf:t._gltf,bufferViewId:t._draco.bufferView,gltfResource:t._gltfResource,baseResource:t._baseResource});return t._bufferViewLoader=n,await n.load(),t.isDestroyed()?void 0:(t._bufferViewTypedArray=n.typedArray,t._state=pn.PROCESSING,t)}catch(n){if(t.isDestroyed())return;rbt(t,n)}}xf.prototype.load=async function(){return c(this._promise)?this._promise:(this._state=pn.LOADING,this._promise=D8t(this),this._promise)};function rbt(t,e){throw t.unload(),t._state=pn.FAILED,t.getError("Failed to load Draco",e)}async function O8t(t,e){try{let n=await e;return t.isDestroyed()?void 0:(t.unload(),t._decodedData={indices:n.indexArray,vertexAttributes:n.attributeData},t._state=pn.READY,t._baseResource)}catch(n){if(t.isDestroyed())return;t._dracoError=n}}xf.prototype.process=function(t){if(this._state===pn.READY)return!0;if(this._state!==pn.PROCESSING||(c(this._dracoError)&&rbt(this,this._dracoError),!c(this._bufferViewTypedArray))||c(this._decodePromise))return!1;let e=this._draco,i=this._gltf.bufferViews,o=e.bufferView,a=i[o],s=e.attributes,l={array:new Uint8Array(this._bufferViewTypedArray),bufferView:a,compressedAttributes:s,dequantizeInShader:!0},r=$R.decodeBufferView(l);if(!c(r))return!1;this._decodePromise=O8t(this,r)};xf.prototype.unload=function(){c(this._bufferViewLoader)&&this._resourceCache.unload(this._bufferViewLoader),this._bufferViewLoader=void 0,this._bufferViewTypedArray=void 0,this._decodedData=void 0,this._gltf=void 0};var kE=xf;var vIn=R(W(),1);var JIn=R(W(),1);function H8t(t){let e=t.uint8Array,n=t.format,i=t.request,o=f(t.flipY,!1),a=f(t.skipColorSpaceConversion,!1),s=new Blob([e],{type:n}),l;return te.supportsImageBitmapOptions().then(function(r){return r?Promise.resolve(te.createImageBitmapFromBlob(s,{flipY:o,premultiplyAlpha:!1,skipColorSpaceConversion:a})):(l=window.URL.createObjectURL(s),new te({url:l,request:i}).fetchImage({flipY:o,skipColorSpaceConversion:a}))}).then(function(r){return c(l)&&window.URL.revokeObjectURL(l),r}).catch(function(r){return c(l)&&window.URL.revokeObjectURL(l),Promise.reject(r)})}var ZA=H8t;function t0(t){t=f(t,f.EMPTY_OBJECT);let e=t.resourceCache,n=t.gltf,i=t.imageId,o=t.gltfResource,a=t.baseResource,s=t.cacheKey,l=n.images[i],r=l.bufferView,d=l.uri;this._resourceCache=e,this._gltfResource=o,this._baseResource=a,this._gltf=n,this._bufferViewId=r,this._uri=d,this._cacheKey=s,this._bufferViewLoader=void 0,this._image=void 0,this._mipLevels=void 0,this._state=pn.UNLOADED,this._promise=void 0}c(Object.create)&&(t0.prototype=Object.create(Va.prototype),t0.prototype.constructor=t0);Object.defineProperties(t0.prototype,{cacheKey:{get:function(){return this._cacheKey}},image:{get:function(){return this._image}},mipLevels:{get:function(){return this._mipLevels}}});t0.prototype.load=function(){return c(this._promise)?this._promise:c(this._bufferViewId)?(this._promise=w8t(this),this._promise):(this._promise=P8t(this),this._promise)};function dbt(t){let e;return Array.isArray(t)&&(e=t.slice(1,t.length).map(function(n){return n.bufferView}),t=t[0]),{image:t,mipLevels:e}}async function w8t(t){t._state=pn.LOADING;let e=t._resourceCache;try{let n=e.getBufferViewLoader({gltf:t._gltf,bufferViewId:t._bufferViewId,gltfResource:t._gltfResource,baseResource:t._baseResource});if(t._bufferViewLoader=n,await n.load(),t.isDestroyed())return;let i=n.typedArray,o=await K8t(i);if(t.isDestroyed())return;let a=dbt(o);return t.unload(),t._image=a.image,t._mipLevels=a.mipLevels,t._state=pn.READY,t}catch(n){return t.isDestroyed()?void 0:cbt(t,n,"Failed to load embedded image")}}async function P8t(t){t._state=pn.LOADING;let e=t._baseResource,n=t._uri,i=e.getDerivedResource({url:n});try{let o=await j8t(i);if(t.isDestroyed())return;let a=dbt(o);return t.unload(),t._image=a.image,t._mipLevels=a.mipLevels,t._state=pn.READY,t}catch(o){return t.isDestroyed()?void 0:cbt(t,o,`Failed to load image: ${n}`)}}function cbt(t,e,n){return t.unload(),t._state=pn.FAILED,Promise.reject(t.getError(n,e))}function v8t(t){let e=t.subarray(0,2),n=t.subarray(0,4),i=t.subarray(8,12);if(e[0]===255&&e[1]===216)return"image/jpeg";if(e[0]===137&&e[1]===80)return"image/png";if(e[0]===171&&e[1]===75)return"image/ktx2";if(n[0]===82&&n[1]===73&&n[2]===70&&n[3]===70&&i[0]===87&&i[1]===69&&i[2]===66&&i[3]===80)return"image/webp";throw new St("Image format is not recognized")}async function K8t(t){let e=v8t(t);if(e==="image/ktx2"){let n=new Uint8Array(t);return Fm(n)}return t0._loadImageFromTypedArray({uint8Array:t,format:e,flipY:!1,skipColorSpaceConversion:!0})}var z8t=/(^data:image\/ktx2)|(\.ktx2$)/i;function j8t(t){let e=t.getUrlComponent(!1,!0);return z8t.test(e)?Fm(t):t.fetchImage({skipColorSpaceConversion:!0,preferImageBitmap:!0})}t0.prototype.unload=function(){c(this._bufferViewLoader)&&!this._bufferViewLoader.isDestroyed()&&this._resourceCache.unload(this._bufferViewLoader),this._bufferViewLoader=void 0,this._uri=void 0,this._image=void 0,this._mipLevels=void 0,this._gltf=void 0};t0._loadImageFromTypedArray=ZA;var YE=t0;var r1n=R(W(),1);var zIn=R(W(),1),q8t={TEXTURE:0,PROGRAM:1,BUFFER:2,NUMBER_OF_JOB_TYPES:3},Vd=Object.freeze(q8t);function Xf(t){t=f(t,f.EMPTY_OBJECT);let e=t.resourceCache,n=t.gltf,i=t.accessorId,o=t.gltfResource,a=t.baseResource,s=t.draco,l=t.cacheKey,r=f(t.asynchronous,!0),d=f(t.loadBuffer,!1),m=f(t.loadTypedArray,!1),h=n.accessors[i].componentType;this._resourceCache=e,this._gltfResource=o,this._baseResource=a,this._gltf=n,this._accessorId=i,this._indexDatatype=h,this._draco=s,this._cacheKey=l,this._asynchronous=r,this._loadBuffer=d,this._loadTypedArray=m,this._bufferViewLoader=void 0,this._dracoLoader=void 0,this._typedArray=void 0,this._buffer=void 0,this._state=pn.UNLOADED,this._promise=void 0}c(Object.create)&&(Xf.prototype=Object.create(Va.prototype),Xf.prototype.constructor=Xf);Object.defineProperties(Xf.prototype,{cacheKey:{get:function(){return this._cacheKey}},buffer:{get:function(){return this._buffer}},typedArray:{get:function(){return this._typedArray}},indexDatatype:{get:function(){return this._indexDatatype}}});var $8t=new Dq;Xf.prototype.load=async function(){return c(this._promise)?this._promise:c(this._draco)?(this._promise=t6t(this),this._promise):(this._promise=e6t(this),this._promise)};async function t6t(t){t._state=pn.LOADING;let e=t._resourceCache;try{let n=e.getDracoLoader({gltf:t._gltf,draco:t._draco,gltfResource:t._gltfResource,baseResource:t._baseResource});return t._dracoLoader=n,await n.load(),t.isDestroyed()?void 0:(t._state=pn.LOADED,t)}catch(n){if(t.isDestroyed())return;_q(t,n)}}async function e6t(t){let e=t._gltf,n=t._accessorId,o=e.accessors[n].bufferView;t._state=pn.LOADING;let a=t._resourceCache;try{let s=a.getBufferViewLoader({gltf:e,bufferViewId:o,gltfResource:t._gltfResource,baseResource:t._baseResource});if(t._bufferViewLoader=s,await s.load(),t.isDestroyed())return;let l=s.typedArray;return t._typedArray=n6t(t,l),t._state=pn.PROCESSING,t}catch(s){if(t.isDestroyed())return;_q(t,s)}}function n6t(t,e){let n=t._gltf,i=t._accessorId,o=n.accessors[i],a=o.count,s=o.componentType,l=re.getSizeInBytes(s),r=e.buffer,d=e.byteOffset+o.byteOffset;if(d%l!==0){let h=a*l,Z=new Uint8Array(r,d,h);r=new Uint8Array(Z).buffer,d=0,Zr("index-buffer-unaligned",`The index array is not aligned to a ${l}-byte boundary.`)}let m;return s===re.UNSIGNED_BYTE?m=new Uint8Array(r,d,a):s===re.UNSIGNED_SHORT?m=new Uint16Array(r,d,a):s===re.UNSIGNED_INT&&(m=new Uint32Array(r,d,a)),m}function _q(t,e){throw t.unload(),t._state=pn.FAILED,t.getError("Failed to load index buffer",e)}function Dq(){this.typedArray=void 0,this.indexDatatype=void 0,this.context=void 0,this.buffer=void 0}Dq.prototype.set=function(t,e,n){this.typedArray=t,this.indexDatatype=e,this.context=n};Dq.prototype.execute=function(){this.buffer=mbt(this.typedArray,this.indexDatatype,this.context)};function mbt(t,e,n){let i=we.createIndexBuffer({typedArray:t,context:n,usage:ce.STATIC_DRAW,indexDatatype:e});return i.vertexArrayDestroyable=!1,i}Xf.prototype.process=function(t){if(this._state===pn.READY)return!0;if(this._state!==pn.LOADED&&this._state!==pn.PROCESSING)return!1;let e=this._typedArray,n=this._indexDatatype;if(c(this._dracoLoader))try{this._dracoLoader.process(t)&&(e=this._dracoLoader.decodedData.indices.typedArray,this._typedArray=e,n=it.fromTypedArray(e),this._indexDatatype=n)}catch(o){_q(this,o)}if(!c(e))return!1;let i;if(this._loadBuffer&&this._asynchronous){let o=$8t;if(o.set(e,n,t.context),!t.jobScheduler.execute(o,Vd.BUFFER))return!1;i=o.buffer}else this._loadBuffer&&(i=mbt(e,n,t.context));return this.unload(),this._buffer=i,this._typedArray=this._loadTypedArray?e:void 0,this._state=pn.READY,this._resourceCache.statistics.addGeometryLoader(this),!0};Xf.prototype.unload=function(){c(this._buffer)&&this._buffer.destroy();let t=this._resourceCache;c(this._bufferViewLoader)&&!this._bufferViewLoader.isDestroyed()&&t.unload(this._bufferViewLoader),c(this._dracoLoader)&&t.unload(this._dracoLoader),this._bufferViewLoader=void 0,this._dracoLoader=void 0,this._typedArray=void 0,this._buffer=void 0,this._gltf=void 0};var xE=Xf;var WBn=R(W(),1);var B1n=R(W(),1);var m1n=R(W(),1);function i6t(t,e,n){if(n=f(n,!1),n){let i=t.indexOf(e);if(i>-1)return i}return t.push(e),t.length-1}var $l=i6t;var R1n=R(W(),1);var u1n=R(W(),1);function o6t(t,e){return c(t.extensionsUsed)&&t.extensionsUsed.indexOf(e)>=0}var Cs=o6t;function Qn(){}Qn.objectLegacy=function(t,e){if(c(t)){for(let n in t)if(Object.prototype.hasOwnProperty.call(t,n)){let i=t[n],o=e(i,n);if(c(o))return o}}};Qn.object=function(t,e){if(c(t)){let n=t.length;for(let i=0;i0)return i.byteStride}return it.getSizeInBytes(e.componentType)*Ih(e.type)}var Qm=s6t;function l6t(t){ne.accessor(t,function(n){c(n.bufferView)&&(n.byteOffset=f(n.byteOffset,0))}),ne.bufferView(t,function(n){c(n.buffer)&&(n.byteOffset=f(n.byteOffset,0))}),ne.mesh(t,function(n){ne.meshPrimitive(n,function(i){if(i.mode=f(i.mode,pt.TRIANGLES),!c(i.material)){c(t.materials)||(t.materials=[]);let o={name:"default"};i.material=$l(t.materials,o)}})}),ne.accessorContainingVertexAttributeData(t,function(n){let i=t.accessors[n],o=i.bufferView;if(i.normalized=f(i.normalized,!1),c(o)){let a=t.bufferViews[o];a.byteStride=Qm(t,i),a.target=pt.ARRAY_BUFFER}}),ne.accessorContainingIndexData(t,function(n){let o=t.accessors[n].bufferView;if(c(o)){let a=t.bufferViews[o];a.target=pt.ELEMENT_ARRAY_BUFFER}}),ne.material(t,function(n){let i=f(n.extensions,f.EMPTY_OBJECT),o=i.KHR_materials_common;if(c(o)){let r=o.technique,d=c(o.values)?o.values:{};o.values=d,d.ambient=c(d.ambient)?d.ambient:[0,0,0,1],d.emission=c(d.emission)?d.emission:[0,0,0,1],d.transparency=f(d.transparency,1),r!=="CONSTANT"&&(d.diffuse=c(d.diffuse)?d.diffuse:[0,0,0,1],r!=="LAMBERT"&&(d.specular=c(d.specular)?d.specular:[0,0,0,1],d.shininess=f(d.shininess,0))),o.transparent=f(o.transparent,!1),o.doubleSided=f(o.doubleSided,!1);return}n.emissiveFactor=f(n.emissiveFactor,[0,0,0]),n.alphaMode=f(n.alphaMode,"OPAQUE"),n.doubleSided=f(n.doubleSided,!1),n.alphaMode==="MASK"&&(n.alphaCutoff=f(n.alphaCutoff,.5));let a=i.KHR_techniques_webgl;c(a)&&ne.materialValue(n,function(r){c(r.index)&&VA(r)}),VA(n.emissiveTexture),VA(n.normalTexture),VA(n.occlusionTexture);let s=n.pbrMetallicRoughness;c(s)&&(s.baseColorFactor=f(s.baseColorFactor,[1,1,1,1]),s.metallicFactor=f(s.metallicFactor,1),s.roughnessFactor=f(s.roughnessFactor,1),VA(s.baseColorTexture),VA(s.metallicRoughnessTexture));let l=i.KHR_materials_pbrSpecularGlossiness;c(l)&&(l.diffuseFactor=f(l.diffuseFactor,[1,1,1,1]),l.specularFactor=f(l.specularFactor,[1,1,1]),l.glossinessFactor=f(l.glossinessFactor,1),VA(l.specularGlossinessTexture))}),ne.animation(t,function(n){ne.animationSampler(n,function(i){i.interpolation=f(i.interpolation,"LINEAR")})});let e=r6t(t);return ne.node(t,function(n,i){c(e[i])||c(n.translation)||c(n.rotation)||c(n.scale)?(n.translation=f(n.translation,[0,0,0]),n.rotation=f(n.rotation,[0,0,0,1]),n.scale=f(n.scale,[1,1,1])):n.matrix=f(n.matrix,[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])}),ne.sampler(t,function(n){n.wrapS=f(n.wrapS,pt.REPEAT),n.wrapT=f(n.wrapT,pt.REPEAT)}),c(t.scenes)&&!c(t.scene)&&(t.scene=0),t}function r6t(t){let e={};return ne.animation(t,function(n){ne.animationChannel(n,function(i){let o=i.target,a=o.node,s=o.path;(s==="translation"||s==="rotation"||s==="scale")&&(e[a]=!0)})}),e}function VA(t){c(t)&&(t.texCoord=f(t.texCoord,0))}var _k=l6t;var x1n=R(W(),1);function d6t(t){return ne.shader(t,function(e){Aw(e)}),ne.buffer(t,function(e){Aw(e)}),ne.image(t,function(e){Aw(e)}),Aw(t),t}function Aw(t){t.extras=c(t.extras)?t.extras:{},t.extras._pipeline=c(t.extras._pipeline)?t.extras._pipeline:{}}var Jf=d6t;var $1n=R(W(),1);var O1n=R(W(),1);var L1n=R(W(),1);function c6t(t,e){let n=t.extensionsRequired;if(c(n)){let i=n.indexOf(e);i>=0&&n.splice(i,1),n.length===0&&delete t.extensionsRequired}}var Dk=c6t;function m6t(t,e){let n=t.extensionsUsed;if(c(n)){let i=n.indexOf(e);i>=0&&n.splice(i,1),Dk(t,e),n.length===0&&delete t.extensionsUsed}}var bA=m6t;var h6t=4;function p6t(t){if(mZ(t)!=="glTF")throw new St("File is not valid binary glTF");let n=hbt(t,0,5),i=n[1];if(i!==1&&i!==2)throw new St("Binary glTF version is not 1 or 2");return i===1?u6t(t,n):Z6t(t,n)}function hbt(t,e,n){let i=new DataView(t.buffer),o=new Array(n);for(let a=0;a0){let h=f(m.binary_glTF,m.KHR_binary_glTF);c(h)&&(h.extras._pipeline.source=d,delete h.uri)}return bA(r,"KHR_binary_glTF"),r}function Z6t(t,e){let n=e[2],i=12,o,a;for(;i0){let l=s[0];l.extras._pipeline.source=a}}return o}var Ok=p6t;var iNn=R(W(),1);function V6t(t){return ne.shader(t,function(e){Tw(e)}),ne.buffer(t,function(e){Tw(e)}),ne.image(t,function(e){Tw(e)}),Tw(t),t}function Tw(t){c(t.extras)&&(c(t.extras._pipeline)&&delete t.extras._pipeline,Object.keys(t.extras).length===0&&delete t.extras)}var Hk=V6t;var Xyn=R(W(),1);var lNn=R(W(),1);function b6t(t,e){let n=t.extensionsUsed;c(n)||(n=[],t.extensionsUsed=n),$l(n,e,!0)}var Xp=b6t;var bNn=R(W(),1);var cNn=R(W(),1);function R6t(t){switch(t){case it.BYTE:return function(e,n,i,o,a){for(let s=0;s-1:!1}var U6t=[pt.ZERO,pt.ONE,pt.SRC_COLOR,pt.ONE_MINUS_SRC_COLOR,pt.SRC_ALPHA,pt.ONE_MINUS_SRC_ALPHA,pt.DST_ALPHA,pt.ONE_MINUS_DST_ALPHA,pt.DST_COLOR,pt.ONE_MINUS_DST_COLOR];function G6t(t,e){if(!c(t))return e;for(let n=0;n<4;n++)if(U6t.indexOf(t[n])===-1)return e;return t}function A6t(t){let e={},n={},i=t.techniques;return c(i)&&(ne.technique(t,function(o,a){let s=o.states;if(c(s)){let l=n[a]={};if(pbt(s,pt.BLEND)){l.alphaMode="BLEND";let r=s.functions;c(r)&&(c(r.blendEquationSeparate)||c(r.blendFuncSeparate))&&(e[a]={blendEquation:f(r.blendEquationSeparate,f6t),blendFactors:G6t(r.blendFuncSeparate,F6t)})}pbt(s,pt.CULL_FACE)||(l.doubleSided=!0),delete o.states}}),Object.keys(e).length>0&&(c(t.extensions)||(t.extensions={}),Xp(t,"KHR_blend")),ne.material(t,function(o){if(c(o.technique)){let a=n[o.technique];ne.objectLegacy(a,function(l,r){o[r]=l});let s=e[o.technique];c(s)&&(c(o.extensions)||(o.extensions={}),o.extensions.KHR_blend=s)}})),t}var wk=A6t;var YNn=R(W(),1);var CNn=R(W(),1);function T6t(t,e){let n=t.extensionsRequired;c(n)||(n=[],t.extensionsRequired=n),$l(n,e,!0),Xp(t,e)}var Pk=T6t;function S6t(t){let e=t.techniques,n={},i={},o={};if(c(e)){let a={programs:[],shaders:[],techniques:[]},s=t.glExtensionsUsed;delete t.glExtensionsUsed,ne.technique(t,function(l,r){let d={name:l.name,program:void 0,attributes:{},uniforms:{}},m;if(ne.techniqueAttribute(l,function(h,Z){m=l.parameters[h],d.attributes[Z]={semantic:m.semantic}}),ne.techniqueUniform(l,function(h,Z){m=l.parameters[h],d.uniforms[Z]={count:m.count,node:m.node,type:m.type,semantic:m.semantic,value:m.value},c(n[r])||(n[r]={}),n[r][h]=Z}),c(o[l.program]))d.program=o[l.program];else{let h=t.programs[l.program],Z={name:h.name,fragmentShader:void 0,vertexShader:void 0,glExtensions:s},b=t.shaders[h.fragmentShader];Z.fragmentShader=$l(a.shaders,b,!0);let u=t.shaders[h.vertexShader];Z.vertexShader=$l(a.shaders,u,!0),d.program=$l(a.programs,Z),o[l.program]=d.program}i[r]=$l(a.techniques,d)}),a.techniques.length>0&&(c(t.extensions)||(t.extensions={}),t.extensions.KHR_techniques_webgl=a,Xp(t,"KHR_techniques_webgl"),Pk(t,"KHR_techniques_webgl"))}return ne.material(t,function(a){if(c(a.technique)){let s={technique:i[a.technique]};ne.objectLegacy(a.values,function(l,r){c(s.values)||(s.values={});let d=n[a.technique][r];c(d)&&(s.values[d]=l)}),c(a.extensions)||(a.extensions={}),a.extensions.KHR_techniques_webgl=s}delete a.technique,delete a.values}),delete t.techniques,delete t.programs,delete t.shaders,t}var vk=S6t;var vNn=R(W(),1);var MNn=R(W(),1);function g6t(t,e){Xa.typeOf.object("material",t),Xa.defined("handler",e);let n=t.pbrMetallicRoughness;if(c(n)){if(c(n.baseColorTexture)){let o=n.baseColorTexture,a=e(o.index,o);if(c(a))return a}if(c(n.metallicRoughnessTexture)){let o=n.metallicRoughnessTexture,a=e(o.index,o);if(c(a))return a}}if(c(t.extensions)){let o=t.extensions.KHR_materials_pbrSpecularGlossiness;if(c(o)){if(c(o.diffuseTexture)){let s=o.diffuseTexture,l=e(s.index,s);if(c(l))return l}if(c(o.specularGlossinessTexture)){let s=o.specularGlossinessTexture,l=e(s.index,s);if(c(l))return l}}let a=t.extensions.KHR_materials_common;if(c(a)&&c(a.values)){let s=a.values.diffuse,l=a.values.ambient,r=a.values.emission,d=a.values.specular;if(c(s)&&c(s.index)){let m=e(s.index,s);if(c(m))return m}if(c(l)&&c(l.index)){let m=e(l.index,l);if(c(m))return m}if(c(r)&&c(r.index)){let m=e(r.index,r);if(c(m))return m}if(c(d)&&c(d.index)){let m=e(d.index,d);if(c(m))return m}}}let i=ne.materialValue(t,function(o){if(c(o.index)){let a=e(o.index,o);if(c(a))return a}});if(c(i))return i;if(c(t.emissiveTexture)){let o=t.emissiveTexture,a=e(o.index,o);if(c(a))return a}if(c(t.normalTexture)){let o=t.normalTexture,a=e(o.index,o);if(c(a))return a}if(c(t.occlusionTexture)){let o=t.occlusionTexture,a=e(o.index,o);if(c(a))return a}}var XE=g6t;var ubt=["mesh","node","material","accessor","bufferView","buffer","texture","sampler","image"];function E6t(t,e){return e=f(e,ubt),ubt.forEach(function(n){e.indexOf(n)>-1&&I6t(t,n)}),t}var C6t={accessor:"accessors",buffer:"buffers",bufferView:"bufferViews",image:"images",node:"nodes",material:"materials",mesh:"meshes",sampler:"samplers",texture:"textures"};function I6t(t,e){let n=C6t[e],i=t[n];if(c(i)){let o=0,a=jV[e](t),s=i.length;for(let l=0;le&&o.attributes[r]--}),ne.meshPrimitiveTarget(o,function(l){ne.meshPrimitiveTargetAttribute(l,function(r,d){r>e&&l[d]--})});let a=o.indices;c(a)&&a>e&&o.indices--;let s=o.extensions;c(s)&&c(s.CESIUM_primitive_outline)&&s.CESIUM_primitive_outline.indices>e&&--s.CESIUM_primitive_outline.indices})}),ne.skin(t,function(i){c(i.inverseBindMatrices)&&i.inverseBindMatrices>e&&i.inverseBindMatrices--}),ne.animation(t,function(i){ne.animationSampler(i,function(o){c(o.input)&&o.input>e&&o.input--,c(o.output)&&o.output>e&&o.output--})})};zV.buffer=function(t,e){t.buffers.splice(e,1),ne.bufferView(t,function(i){c(i.buffer)&&i.buffer>e&&i.buffer--,c(i.extensions)&&c(i.extensions.EXT_meshopt_compression)&&i.extensions.EXT_meshopt_compression.buffer--})};zV.bufferView=function(t,e){if(t.bufferViews.splice(e,1),ne.accessor(t,function(i){c(i.bufferView)&&i.bufferView>e&&i.bufferView--}),ne.shader(t,function(i){c(i.bufferView)&&i.bufferView>e&&i.bufferView--}),ne.image(t,function(i){c(i.bufferView)&&i.bufferView>e&&i.bufferView--}),Cs(t,"KHR_draco_mesh_compression")&&ne.mesh(t,function(i){ne.meshPrimitive(i,function(o){c(o.extensions)&&c(o.extensions.KHR_draco_mesh_compression)&&o.extensions.KHR_draco_mesh_compression.bufferView>e&&o.extensions.KHR_draco_mesh_compression.bufferView--})}),Cs(t,"EXT_feature_metadata")){let o=t.extensions.EXT_feature_metadata.featureTables;for(let a in o)if(o.hasOwnProperty(a)){let l=o[a].properties;if(c(l)){for(let r in l)if(l.hasOwnProperty(r)){let d=l[r];c(d.bufferView)&&d.bufferView>e&&d.bufferView--,c(d.arrayOffsetBufferView)&&d.arrayOffsetBufferView>e&&d.arrayOffsetBufferView--,c(d.stringOffsetBufferView)&&d.stringOffsetBufferView>e&&d.stringOffsetBufferView--}}}}if(Cs(t,"EXT_structural_metadata")){let o=t.extensions.EXT_structural_metadata.propertyTables;if(c(o)){let a=o.length;for(let s=0;se&&m.values--,c(m.arrayOffsets)&&m.arrayOffsets>e&&m.arrayOffsets--,c(m.stringOffsets)&&m.stringOffsets>e&&m.stringOffsets--}}}}};zV.image=function(t,e){t.images.splice(e,1),ne.texture(t,function(i){c(i.source)&&i.source>e&&--i.source;let o=i.extensions;c(o)&&c(o.EXT_texture_webp)&&o.EXT_texture_webp.source>e?--i.extensions.EXT_texture_webp.source:c(o)&&c(o.KHR_texture_basisu)&&o.KHR_texture_basisu.source>e&&--i.extensions.KHR_texture_basisu.source})};zV.mesh=function(t,e){t.meshes.splice(e,1),ne.node(t,function(i){c(i.mesh)&&(i.mesh>e?i.mesh--:i.mesh===e&&delete i.mesh)})};zV.node=function(t,e){t.nodes.splice(e,1),ne.skin(t,function(i){c(i.skeleton)&&i.skeleton>e&&i.skeleton--,i.joints=i.joints.map(function(o){return o>e?o-1:o})}),ne.animation(t,function(i){ne.animationChannel(i,function(o){c(o.target)&&c(o.target.node)&&o.target.node>e&&o.target.node--})}),ne.technique(t,function(i){ne.techniqueUniform(i,function(o){c(o.node)&&o.node>e&&o.node--})}),ne.node(t,function(i){c(i.children)&&(i.children=i.children.filter(function(o){return o!==e}).map(function(o){return o>e?o-1:o}))}),ne.scene(t,function(i){i.nodes=i.nodes.filter(function(o){return o!==e}).map(function(o){return o>e?o-1:o})})};zV.material=function(t,e){t.materials.splice(e,1),ne.mesh(t,function(i){ne.meshPrimitive(i,function(o){c(o.material)&&o.material>e&&o.material--})})};zV.sampler=function(t,e){t.samplers.splice(e,1),ne.texture(t,function(i){c(i.sampler)&&i.sampler>e&&--i.sampler})};zV.texture=function(t,e){if(t.textures.splice(e,1),ne.material(t,function(i){XE(i,function(o,a){a.index>e&&--a.index})}),Cs(t,"EXT_feature_metadata")){ne.mesh(t,function(a){ne.meshPrimitive(a,function(s){let l=s.extensions;if(c(l)&&c(l.EXT_feature_metadata)){let d=l.EXT_feature_metadata.featureIdTextures;if(c(d)){let m=d.length;for(let h=0;he&&--b.index}}}})});let o=t.extensions.EXT_feature_metadata.featureTextures;for(let a in o)if(o.hasOwnProperty(a)){let l=o[a].properties;if(c(l)){for(let r in l)if(l.hasOwnProperty(r)){let m=l[r].texture;m.index>e&&--m.index}}}}if(Cs(t,"EXT_mesh_features")&&ne.mesh(t,function(i){ne.meshPrimitive(i,function(o){let a=o.extensions;if(c(a)&&c(a.EXT_mesh_features)){let l=a.EXT_mesh_features.featureIds;if(c(l)){let r=l.length;for(let d=0;de&&--m.texture.index}}}})}),Cs(t,"EXT_structural_metadata")){let o=t.extensions.EXT_structural_metadata.propertyTextures;if(c(o)){let a=o.length;for(let s=0;se&&--m.index}}}}};function jV(){}jV.accessor=function(t){let e={};return ne.mesh(t,function(n){ne.meshPrimitive(n,function(i){ne.meshPrimitiveAttribute(i,function(a){e[a]=!0}),ne.meshPrimitiveTarget(i,function(a){ne.meshPrimitiveTargetAttribute(a,function(s){e[s]=!0})});let o=i.indices;c(o)&&(e[o]=!0)})}),ne.skin(t,function(n){c(n.inverseBindMatrices)&&(e[n.inverseBindMatrices]=!0)}),ne.animation(t,function(n){ne.animationSampler(n,function(i){c(i.input)&&(e[i.input]=!0),c(i.output)&&(e[i.output]=!0)})}),Cs(t,"EXT_mesh_gpu_instancing")&&ne.node(t,function(n){c(n.extensions)&&c(n.extensions.EXT_mesh_gpu_instancing)&&Object.keys(n.extensions.EXT_mesh_gpu_instancing.attributes).forEach(function(i){let o=n.extensions.EXT_mesh_gpu_instancing.attributes[i];e[o]=!0})}),Cs(t,"CESIUM_primitive_outline")&&ne.mesh(t,function(n){ne.meshPrimitive(n,function(i){let o=i.extensions;if(c(o)&&c(o.CESIUM_primitive_outline)){let s=o.CESIUM_primitive_outline.indices;c(s)&&(e[s]=!0)}})}),e};jV.buffer=function(t){let e={};return ne.bufferView(t,function(n){c(n.buffer)&&(e[n.buffer]=!0),c(n.extensions)&&c(n.extensions.EXT_meshopt_compression)&&(e[n.extensions.EXT_meshopt_compression.buffer]=!0)}),e};jV.bufferView=function(t){let e={};if(ne.accessor(t,function(n){c(n.bufferView)&&(e[n.bufferView]=!0)}),ne.shader(t,function(n){c(n.bufferView)&&(e[n.bufferView]=!0)}),ne.image(t,function(n){c(n.bufferView)&&(e[n.bufferView]=!0)}),Cs(t,"KHR_draco_mesh_compression")&&ne.mesh(t,function(n){ne.meshPrimitive(n,function(i){c(i.extensions)&&c(i.extensions.KHR_draco_mesh_compression)&&(e[i.extensions.KHR_draco_mesh_compression.bufferView]=!0)})}),Cs(t,"EXT_feature_metadata")){let i=t.extensions.EXT_feature_metadata.featureTables;for(let o in i)if(i.hasOwnProperty(o)){let s=i[o].properties;if(c(s)){for(let l in s)if(s.hasOwnProperty(l)){let r=s[l];c(r.bufferView)&&(e[r.bufferView]=!0),c(r.arrayOffsetBufferView)&&(e[r.arrayOffsetBufferView]=!0),c(r.stringOffsetBufferView)&&(e[r.stringOffsetBufferView]=!0)}}}}if(Cs(t,"EXT_structural_metadata")){let i=t.extensions.EXT_structural_metadata.propertyTables;if(c(i)){let o=i.length;for(let a=0;a0&&(e[n.mesh]=!0)}}),e};function Zbt(t,e,n){let i=t.nodes[e];return c(i.mesh)||c(i.camera)||c(i.skin)||c(i.weights)||c(i.extras)||c(i.extensions)&&Object.keys(i.extensions).length!==0||c(n[e])?!1:!c(i.children)||i.children.filter(function(o){return!Zbt(t,o,n)}).length===0}jV.node=function(t){let e={};return ne.skin(t,function(n){c(n.skeleton)&&(e[n.skeleton]=!0),ne.skinJoint(n,function(i){e[i]=!0})}),ne.animation(t,function(n){ne.animationChannel(n,function(i){c(i.target)&&c(i.target.node)&&(e[i.target.node]=!0)})}),ne.technique(t,function(n){ne.techniqueUniform(n,function(i){c(i.node)&&(e[i.node]=!0)})}),ne.node(t,function(n,i){Zbt(t,i,e)||(e[i]=!0)}),e};jV.material=function(t){let e={};return ne.mesh(t,function(n){ne.meshPrimitive(n,function(i){c(i.material)&&(e[i.material]=!0)})}),e};jV.texture=function(t){let e={};if(ne.material(t,function(n){XE(n,function(i){e[i]=!0})}),Cs(t,"EXT_feature_metadata")){ne.mesh(t,function(o){ne.meshPrimitive(o,function(a){let s=a.extensions;if(c(s)&&c(s.EXT_feature_metadata)){let r=s.EXT_feature_metadata.featureIdTextures;if(c(r)){let d=r.length;for(let m=0;m0)for(s.mesh=n.meshes[r[0]],e=1;e0&&c(s.skin)){let m=t.skins[s.skin];m.skeleton=n.nodes[r[0]]}delete s.skeletons}c(s.jointName)&&delete s.jointName}),ne.skin(t,function(s){c(s.inverseBindMatrices)&&(s.inverseBindMatrices=n.accessors[s.inverseBindMatrices]);let l=s.jointNames;if(c(l)){let r=[],d=l.length;for(e=0;e=0&&(l=a.substring(0,s),r=a.substring(s));let d,m=$6t[l];c(m)?(d=m+r,e[a]=d):c(q6t[l])||(d=`_${a}`,e[a]=d)}});for(let o in e)if(Object.prototype.hasOwnProperty.call(e,o)){let a=e[o],s=i.attributes[o];c(s)&&(delete i.attributes[o],i.attributes[a]=s)}})}),ne.technique(t,function(n){ne.techniqueParameter(n,function(i){let o=e[i.semantic];c(o)&&(i.semantic=o)})})}function e7t(t){ne.camera(t,function(e){let n=e.perspective;if(c(n)){let i=n.aspectRatio;c(i)&&i===0&&delete n.aspectRatio;let o=n.yfov;c(o)&&o===0&&(n.yfov=1)}})}function wq(t,e){return c(e.byteStride)&&e.byteStride!==0?e.byteStride:Qm(t,e)}function n7t(t){ne.buffer(t,function(e){c(e.byteLength)||(e.byteLength=e.extras._pipeline.source.length)}),ne.accessor(t,function(e){let n=e.bufferView;if(c(n)){let i=t.bufferViews[n],o=wq(t,e),a=e.byteOffset+e.count*o;i.byteLength=Math.max(f(i.byteLength,0),a)}})}function i7t(t){let e,n,i,o=t.bufferViews,a={};ne.accessorContainingVertexAttributeData(t,function(l){let r=t.accessors[l];c(r.bufferView)&&(a[r.bufferView]=!0)});let s={};ne.accessor(t,function(l){c(l.bufferView)&&(s[l.bufferView]=f(s[l.bufferView],[]),s[l.bufferView].push(l))});for(let l in s)if(Object.prototype.hasOwnProperty.call(s,l)){i=o[l];let r=s[l];r.sort(function(Z,b){return Z.byteOffset-b.byteOffset});let d=0,m=0,h=r.length;for(e=0;e=0;--a)if(i[a]===e){i.splice(a,1);return}}}),ne.node(t,function(n,i){if(c(n.children)){let o=n.children.indexOf(e);o>-1&&(n.children.splice(o,1),Wbt(n)&&fbt(t,i))}}),delete t.nodes[e]}function a7t(t){return ne.node(t,function(e,n){Wbt(e)&&fbt(t,n)}),t}function s7t(t){ne.animation(t,function(e){ne.animationSampler(e,function(n){let i=t.accessors[n.input];if(!c(i.min)||!c(i.max)){let o=RA(t,i);i.min=o.min,i.max=o.max}})})}function l7t(t){ne.accessor(t,function(e){if(c(e.min)||c(e.max)){let n=RA(t,e);c(e.min)&&(e.min=n.min),c(e.max)&&(e.max=n.max)}})}function r7t(t){t.asset=f(t.asset,{}),t.asset.version="2.0",Rbt(t),_6t(t),a7t(t),D6t(t),O6t(t),w6t(t),v6t(t),n7t(t),i7t(t),o7t(t),s7t(t),l7t(t),K6t(t),z6t(t),j6t(t),t7t(t),qk(t),e7t(t),wk(t),vk(t),H6t(t)}var d7t=["u_tex","u_diffuse","u_emission","u_diffuse_tex"],c7t=["u_diffuse","u_diffuse_mat"];function Pq(t){t.pbrMetallicRoughness=c(t.pbrMetallicRoughness)?t.pbrMetallicRoughness:{},t.pbrMetallicRoughness.roughnessFactor=1,t.pbrMetallicRoughness.metallicFactor=0}function vq(t){return c(t.index)}function Kq(t){return Array.isArray(t)&&t.length===4}function Fbt(t){let e=new Array(4);e[3]=t[3];for(let n=0;n<3;n++){let i=t[n];i<=.04045?e[n]=t[n]*.07739938080495357:e[n]=Math.pow((i+.055)*.9478672985781991,2.4)}return e}function m7t(t,e){e=f(e,f.EMPTY_OBJECT);let n=f(e.baseColorTextureNames,d7t),i=f(e.baseColorFactorNames,c7t);ne.material(t,function(o){ne.materialValue(o,function(a,s){n.indexOf(s)!==-1&&vq(a)?(Pq(o),o.pbrMetallicRoughness.baseColorTexture=a):i.indexOf(s)!==-1&&Kq(a)&&(Pq(o),o.pbrMetallicRoughness.baseColorFactor=Fbt(a))})}),WA(t,"KHR_techniques_webgl"),WA(t,"KHR_blend")}function Hq(t,e){c(e)&&(Kq(e)?t.pbrMetallicRoughness.baseColorFactor=Fbt(e):vq(e)&&(t.pbrMetallicRoughness.baseColorTexture=e))}function bbt(t,e){c(e)&&(Kq(e)?t.emissiveFactor=e.slice(0,3):vq(e)&&(t.emissiveTexture=e))}function h7t(t){ne.material(t,function(e){let n=f(e.extensions,f.EMPTY_OBJECT).KHR_materials_common;if(!c(n))return;let i=f(n.values,{}),o=i.ambient,a=i.diffuse,s=i.emission,l=i.transparency,r=n.doubleSided,d=n.transparent;Pq(e),n.technique==="CONSTANT"?(Xp(t,"KHR_materials_unlit"),e.extensions=c(e.extensions)?e.extensions:{},e.extensions.KHR_materials_unlit={},Hq(e,s),Hq(e,o)):(Hq(e,a),bbt(e,o),bbt(e,s)),c(r)&&(e.doubleSided=r),c(l)&&(c(e.pbrMetallicRoughness.baseColorFactor)?e.pbrMetallicRoughness.baseColorFactor[3]*=l:e.pbrMetallicRoughness.baseColorFactor=[1,1,1,l]),c(d)&&(e.alphaMode=d?"BLEND":"OPAQUE")}),WA(t,"KHR_materials_common")}var $k=Y6t;var tBn=R(W(),1);var Myn=R(W(),1);var mo={POSITION:"POSITION",NORMAL:"NORMAL",TANGENT:"TANGENT",TEXCOORD:"TEXCOORD",COLOR:"COLOR",JOINTS:"JOINTS",WEIGHTS:"WEIGHTS",FEATURE_ID:"_FEATURE_ID"};function p7t(t){switch(t){case mo.POSITION:return"positionMC";case mo.NORMAL:return"normalMC";case mo.TANGENT:return"tangentMC";case mo.TEXCOORD:return"texCoord";case mo.COLOR:return"color";case mo.JOINTS:return"joints";case mo.WEIGHTS:return"weights";case mo.FEATURE_ID:return"featureId"}}mo.hasSetIndex=function(t){switch(t){case mo.POSITION:case mo.NORMAL:case mo.TANGENT:return!1;case mo.TEXCOORD:case mo.COLOR:case mo.JOINTS:case mo.WEIGHTS:case mo.FEATURE_ID:return!0}};mo.fromGltfSemantic=function(t){let e=t,i=/^(\w+)_\d+$/.exec(t);switch(i!==null&&(e=i[1]),e){case"POSITION":return mo.POSITION;case"NORMAL":return mo.NORMAL;case"TANGENT":return mo.TANGENT;case"TEXCOORD":return mo.TEXCOORD;case"COLOR":return mo.COLOR;case"JOINTS":return mo.JOINTS;case"WEIGHTS":return mo.WEIGHTS;case"_FEATURE_ID":return mo.FEATURE_ID}};mo.fromPntsSemantic=function(t){switch(t){case"POSITION":case"POSITION_QUANTIZED":return mo.POSITION;case"RGBA":case"RGB":case"RGB565":return mo.COLOR;case"NORMAL":case"NORMAL_OCT16P":return mo.NORMAL;case"BATCH_ID":return mo.FEATURE_ID}};mo.getGlslType=function(t){switch(t){case mo.POSITION:case mo.NORMAL:case mo.TANGENT:return"vec3";case mo.TEXCOORD:return"vec2";case mo.COLOR:return"vec4";case mo.JOINTS:return"ivec4";case mo.WEIGHTS:return"vec4";case mo.FEATURE_ID:return"int"}};mo.getVariableName=function(t,e){let n=p7t(t);return c(e)&&(n+=`_${e}`),n};var sn=Object.freeze(mo);function wd(){}wd.getError=function(t,e,n){let i=`Failed to load ${t}: ${e}`;c(n)&&c(n.message)&&(i+=` -${n.message}`);let o=new St(i);return c(n)&&(o.stack=`Original stack: +${n.stack}`),n};Yf.prototype.isDestroyed=function(){return!1};Yf.prototype.destroy=function(){return this.unload(),At(this)};var Za=Yf;var vCn=b(W(),1),J8t={UNLOADED:0,LOADING:1,LOADED:2,PROCESSING:3,READY:4,FAILED:5},pn=Object.freeze(J8t);function qb(t){t=f(t,f.EMPTY_OBJECT);let e=t.typedArray,n=t.resource,i=t.cacheKey;this._typedArray=e,this._resource=n,this._cacheKey=i,this._state=pn.UNLOADED,this._promise=void 0}c(Object.create)&&(qb.prototype=Object.create(Za.prototype),qb.prototype.constructor=qb);Object.defineProperties(qb.prototype,{cacheKey:{get:function(){return this._cacheKey}},typedArray:{get:function(){return this._typedArray}}});qb.prototype.load=async function(){return c(this._promise)?this._promise:c(this._typedArray)?(this._promise=Promise.resolve(this),this._promise):(this._promise=L8t(this),this._promise)};async function L8t(t){let e=t._resource;t._state=pn.LOADING;try{let n=await qb._fetchArrayBuffer(e);return t.isDestroyed()?void 0:(t._typedArray=new Uint8Array(n),t._state=pn.READY,t)}catch(n){if(t.isDestroyed())return;t._state=pn.FAILED;let i=`Failed to load external buffer: ${e.url}`;throw t.getError(i,n)}}qb._fetchArrayBuffer=function(t){return t.fetchArrayBuffer()};qb.prototype.unload=function(){this._typedArray=void 0};var pA=qb;var FIn=b(W(),1);var cIn=b(W());var iIn=b(W()),eIn=function(){var t="b9H79TebbbeJq9Geueu9Geub9Gbb9Gvuuuuueu9Gduueu9Gluuuueu9Gvuuuuub9Gouuuuuub9Gluuuub9GiuuueuiKLdilevlevlooroowwvwbDDbelve9Weiiviebeoweuec:W;kekr;RiOo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949c919M9MWVbe8F9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949c919M9MWV9c9V919U9KbdE9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949wWV79P9V9UbiY9TW79O9V9Wt9FW9U9J9V9KW69U9KW949c919M9MWVbl8E9TW79O9V9Wt9FW9U9J9V9KW69U9KW949c919M9MWV9c9V919U9Kbv8A9TW79O9V9Wt9FW9U9J9V9KW69U9KW949wWV79P9V9UboE9TW79O9V9Wt9FW9U9J9V9KW69U9KW949tWG91W9U9JWbra9TW79O9V9Wt9FW9U9J9V9KW69U9KW949tWG91W9U9JW9c9V919U9KbwL9TW79O9V9Wt9FW9U9J9V9KWS9P2tWV9p9JtbDK9TW79O9V9Wt9FW9U9J9V9KWS9P2tWV9r919HtbqL9TW79O9V9Wt9FW9U9J9V9KWS9P2tWVT949WbkE9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94J9H9J9OWbPa9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94J9H9J9OW9ttV9P9Wbsa9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94SWt9J9O9sW9T9H9WbzK9TW79O9V9Wt9F79W9Ht9P9H29t9VVt9sW9T9H9WbHl79IV9RbODwebcekdQXq:g9sLdbk;3keYu8Jjjjjbcjo9Rgv8Kjjjjbcbhodnalcefae0mbabcbRb:S:kjjbc:GeV86bbavcjdfcbcjdzNjjjb8AdnaiTmbavcjdfadalz:tjjjb8Akabaefhrabcefhwavalfcbcbcjdal9RalcFe0EzNjjjb8Aavavcjdfalz:tjjjbhDcj;abal9UhodndndndndnalTmbaoc;WFbGgecjdaecjd6Ehqcbhkdninakai9pmiaDcjlfcbcjdzNjjjb8Aaqaiak9Rakaqfai6Egxcsfgecl4cifcd4hmadakal2fhPdndndndndnaec9WGgsTmbcbhzcehHaPhOawhAxekdnaxTmbcbhAcehHaPhCinaDaAfRbbhXaDcjlfheaChoaxhQinaeaoRbbgLaX9RgXcetaX;acr4786bbaoalfhoaecefheaLhXaQcufgQmbkaraw9Ram6miawcbamzNjjjbgeTmiaCcefhCaeamfhwaAcefgAal6hHaAal9hmbxvkkaraw9Ram6mvawcbamzNjjjb8AceheinawgXamfhwalaegoSmldnaraw9Ram6mbaocefheawcbamzNjjjb8AaXmekkaoal6hHxekindnaxTmbaDazfRbbhXaDcjlfheaOhoaxhQinaeaoRbbgLaX9RgXcetaX;acr4786bbaoalfhoaecefheaLhXaQcufgQmbkkaraA9Ram6mearaAcbamzNjjjbgKamfgw9RcK6mdcbhYaDcjlfhAinaDcjlfaYfh8AcwhCczhLcehQindndnaQce9hmbcuhoa8ARbbmecbhodninaogecsSmeaecefhoaAaefcefRbbTmbkkcucbaecs6EhoxekaQcetc;:FFFeGhocuaQtcu7cFeGhXcbheinaoaXaAaefRbb9nfhoaecefgecz9hmbkkaoaLaoaL6geEhLaQaCaeEhCaQcetgQcw6mbkdndndndnaCcufPdiebkaKaYco4fgeaeRbbcdciaCclSEaYci4coGtV86bbaCcw9hmeawa8A8Pbb83bbawcwfa8Acwf8Pbb83bbawczfhwxdkaKaYco4fgeaeRbbceaYci4coGtV86bbkdncwaC9TgEmbinawcb86bbawcefhwxbkkcuaCtcu7h8Acbh3aAh5ina5heaEhQcbhoinaeRbbgLa8AcFeGgXaLaX6EaoaCtVhoaecefheaQcufgQmbkawao86bba5aEfh5awcefhwa3aEfg3cz6mbkcbheindnaAaefRbbgoaX6mbawao86bbawcefhwkaecefgecz9hmbkkdnaYczfgYas9pmbaAczfhAaraw9RcL0mekkaYas6meawTmeaOcefhOazcefgzal6hHawhAazalSmixbkkcbhwaHceGTmexikcbhwaHceGmdkaDaPaxcufal2falz:tjjjb8AaxakfhkawmbkcbhoxokcbhoxvkaiTmekcbhoaraw9Ralcaalca0E6mialc8F9nmexdkcbhoaecufca6mdkawcbcaal9RgezNjjjbaefhwkawaDcjdfalz:tjjjbalfab9Rhokavcjof8Kjjjjbaok9heeuaecaaeca0Eabcj;abae9Uc;WFbGgdcjdadcjd6Egdfcufad9Uae2adcl4cifcd4adV2fcefkmbcbabBd:S:kjjbk;rse3u8Jjjjjbc;ae9Rgl8Kjjjjbcbhvdnaici9UgocHfae0mbabcbyd:C:kjjbgrc;GeV86bbalc;abfcFecjezNjjjb8AalcUfgw9cu83ibalc8WfgD9cu83ibalcyfgq9cu83ibalcafgk9cu83ibalcKfgx9cu83ibalczfgm9cu83ibal9cu83iwal9cu83ibabaefc9WfhPabcefgsaofhednaiTmbcmcsarcb9kgzEhHcbhOcbhAcbhCcbhXcbhQindnaeaP9nmbcbhvxikaQcufhvadaCcdtfgoydbhLaocwfydbhKaoclfydbhYcbh8Adndninalc;abfavcsGcitfgoydlhEdndndnaoydbgoaL9hmbaEaYSmekdnaoaY9hmbaEaK9hmba8Acefh8AxekaoaK9hmeaEaL9hmea8Acdfh8Aka8Ac870mdaXcufhvada8AciGcx2goc:y1jjbfydbaCfcdtfydbhEadaocN1jjbfydbaCfcdtfydbhKadaoc:q1jjbfydbaCfcdtfydbhLcbhodnindnalavcsGcdtfydbaE9hmbaohYxdkcuhYavcufhvaocefgocz9hmbkkaEaOSgvaYce9iaYaH9oVgoGh3dndndndndncbcsavEaYaoEgvcs9hmbarce9imbaEaEaAaEcefaASgvEgAcefSmecmcsavEhvkasava8Acdtc;WeGV86bbavcs9hmeaEaA9Rgvcetavc8F917hvinaeavcFb0crtavcFbGV86bbaecefheavcje6hoavcr4hvaoTmbkaEhAxdkcPhvasa8AcdtcPV86bbaEhAkavTmbavaH9imekalaXcdtfaEBdbaXcefcsGhXkaOa3fhOalc;abfaQcitfgvaKBdlavaEBdbalc;abfaQcefcsGgvcitfgoaEBdlaoaLBdbavcefhoxikavcufhva8Aclfg8Ac;ab9hmbkkdnadceaKaOScetaYaOSEcx2gvc:q1jjbfydbaCfcdtfydbgLTadavcN1jjbfydbaCfcdtfydbg8AceSGadavc:y1jjbfydbaCfcdtfydbgYcdSGaOcb9hGazGg5ce9hmbaw9cu83ibaD9cu83ibaq9cu83ibak9cu83ibax9cu83ibam9cu83ibal9cu83iwal9cu83ibcbhOkcbhEaXcufgvhodnindnalaocsGcdtfydba8A9hmbaEhKxdkcuhKaocufhoaEcefgEcz9hmbkkcbhodnindnalavcsGcdtfydbaY9hmbaohExdkcuhEavcufhvaocefgocz9hmbkkaOaLaOSg8Efh3dndnaKcm0mbaKcefhKxekcbcsa8Aa3SgvEhKa3avfh3kdndnaEcm0mbaEcefhExekcbcsaYa3SgvEhEa3avfh3kc9:cua8EEh8FaEaKcltVhocbhvdndndninavcj1jjbfRbbaocFeGSmeavcefgvcz9hmbxdkka5aLaO9havcm0VVmbasavc;WeV86bbxekasa8F86bbaeao86bbaecefhekdna8EmbaLaA9Rgvcetavc8F917hvinaeavcFb0gocrtavcFbGV86bbavcr4hvaecefheaombkaLhAkdnaKcs9hmba8AaA9Rgvcetavc8F917hvinaeavcFb0gocrtavcFbGV86bbavcr4hvaecefheaombka8AhAkdnaEcs9hmbaYaA9Rgvcetavc8F917hvinaeavcFb0gocrtavcFbGV86bbavcr4hvaecefheaombkaYhAkalaXcdtfaLBdbaXcefcsGhvdndnaKPzbeeeeeeeeeeeeeebekalavcdtfa8ABdbaXcdfcsGhvkdndnaEPzbeeeeeeeeeeeeeebekalavcdtfaYBdbavcefcsGhvkalc;abfaQcitfgoaLBdlaoa8ABdbalc;abfaQcefcsGcitfgoa8ABdlaoaYBdbalc;abfaQcdfcsGcitfgoaYBdlaoaLBdbaQcifhoavhXa3hOkascefhsaocsGhQaCcifgCai6mbkkcbhvaeaP0mbcbhvinaeavfavcj1jjbfRbb86bbavcefgvcz9hmbkaeab9Ravfhvkalc;aef8KjjjjbavkZeeucbhddninadcefgdc8F0meceadtae6mbkkadcrfcFeGcr9Uci2cdfabci9U2cHfkmbcbabBd:C:kjjbk:ydewu8Jjjjjbcz9Rhlcbhvdnaicvfae0mbcbhvabcbRb:C:kjjbc;qeV86bbal9cb83iwabcefhoabaefc98fhrdnaiTmbcbhwcbhDindnaoar6mbcbskadaDcdtfydbgqalcwfawaqav9Rgvavc8F91gv7av9Rc507gwcdtfgkydb9Rgvc8E91c9:Gavcdt7awVhvinaoavcFb0gecrtavcFbGV86bbavcr4hvaocefhoaembkakaqBdbaqhvaDcefgDai9hmbkkcbhvaoar0mbaocbBbbaoab9RclfhvkavkBeeucbhddninadcefgdc8F0meceadtae6mbkkadcwfcFeGcr9Uab2cvfk:dvli99dui99ludnaeTmbcuadcetcuftcu7:Yhvdndncuaicuftcu7:YgoJbbbZMgr:lJbbb9p9DTmbar:Ohwxekcjjjj94hwkcbhicbhDinalclfIdbgrJbbbbJbbjZalIdbgq:lar:lMalcwfIdbgk:lMgr:varJbbbb9BEgrNhxaqarNhralcxfIdbhqdndnakJbbbb9GTmbaxhkxekJbbjZar:l:tgkak:maxJbbbb9GEhkJbbjZax:l:tgxax:marJbbbb9GEhrkdndnaqJbbj:;aqJbbj:;9GEgxJbbjZaxJbbjZ9FEavNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohmxekcjjjj94hmkdndnakJbbj:;akJbbj:;9GEgqJbbjZaqJbbjZ9FEaoNJbbbZJbbb:;akJbbbb9GEMgq:lJbbb9p9DTmbaq:OhPxekcjjjj94hPkdndnarJbbj:;arJbbj:;9GEgqJbbjZaqJbbjZ9FEaoNJbbbZJbbb:;arJbbbb9GEMgr:lJbbb9p9DTmbar:Ohsxekcjjjj94hskdndnadcl9hmbabaifgzas86bbazcifam86bbazcdfaw86bbazcefaP86bbxekabaDfgzas87ebazcofam87ebazclfaw87ebazcdfaP87ebkalczfhlaiclfhiaDcwfhDaecufgembkkk;klld99eud99eudnaeTmbdndncuaicuftcu7:YgvJbbbZMgo:lJbbb9p9DTmbao:Ohixekcjjjj94hikaic;8FiGhrinabcofcicdalclfIdb:lalIdb:l9EgialcwfIdb:lalaicdtfIdb:l9EEgialcxfIdb:lalaicdtfIdb:l9EEgiarV87ebdndnalaicefciGcdtfIdbJ;Zl:1ZNJbbj:;JbbjZalaicdtfIdbJbbbb9DEgoNgwJbbj:;awJbbj:;9GEgDJbbjZaDJbbjZ9FEavNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohqxekcjjjj94hqkabaq87ebdndnaoalaicdfciGcdtfIdbJ;Zl:1ZNNgwJbbj:;awJbbj:;9GEgDJbbjZaDJbbjZ9FEavNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohqxekcjjjj94hqkabcdfaq87ebdndnaoalaicufciGcdtfIdbJ;Zl:1ZNNgoJbbj:;aoJbbj:;9GEgwJbbjZawJbbjZ9FEavNJbbbZJbbb:;aoJbbbb9GEMgo:lJbbb9p9DTmbao:Ohixekcjjjj94hikabclfai87ebabcwfhbalczfhlaecufgembkkk:Hvdxue998Jjjjjbcjd9Rgo8Kjjjjbadcd4hrdndndndnavcd9hmbadcl6mearcearce0EhwaohDinaDc:CuBdbaDclfhDawcufgwmbkaeTmiadcl6mdarcearce0EhqarcdthkalhxcbhminaohDaxhwaqhPinaDaDydbgsawydbgzcL4cFeGc:cufcbazEgzasaz9kEBdbawclfhwaDclfhDaPcufgPmbkaxakfhxamcefgmae9hmbkkaeTmdxekaeTmekavcb9hadcl6gqVhHarcearce0Ehkarcdthrceai9Rhmcbhdindndndnavce9hmbaqmdc:CuhwalhDakhPinawaDydbgscL4cFeGc:cufcbasEgsawas9kEhwaDclfhDaPcufgPmbxdkkc:CuhwaHmbaohDalhPakhsinaDaPydbgzcL4cFeGgxc8Aaxc8A9kEc:cufcbazEBdbaPclfhPaDclfhDascufgsmbkkaqmbcbhDakhsinawhPdnavceSmbaoaDfydbhPkdndnalaDfIdbgOcjjj;8iamaPfgPcLt9R::NJbbbZJbbb:;aOJbbbb9GEMgO:lJbbb9p9DTmbaO:Ohzxekcjjjj94hzkabaDfazcFFFrGaPcKtVBdbaDclfhDascufgsmbkkabarfhbalarfhladcefgdae9hmbkkaocjdf8KjjjjbkFkdCui998Jjjjjbc:Gd9Rgv8Kjjjjbavc:4efcbc;KbzNjjjb8AcbhodnadTmbcbhoaiTmbdnabae9hmbavcuadcdtgoadcFFFFi0Ecbyd:K:kjjbHjjjjbbgeBd:4eavceBd:ydaeabaoz:tjjjb8Akavc:OefcwfcbBdbav9cb83i:Oeavc:Oefaeadaiavc:4efz:njjjbcuaicdtgraicFFFFi0Egwcbyd:K:kjjbHjjjjbbhoavc:4efavyd:ydgDcdtfaoBdbavaDcefgqBd:ydaoavyd:Oegkarz:tjjjbhxavc:4efaqcdtfadci9Ugmcbyd:K:kjjbHjjjjbbgoBdbavaDcdfgrBd:ydaocbamzNjjjbhPavc:4efarcdtfawcbyd:K:kjjbHjjjjbbgsBdbavaDcifgqBd:ydaxhoashrinaralIdbalaoydbgwcwawcw6Ecdtfc;ebfIdbMUdbaoclfhoarclfhraicufgimbkavc:4efaqcdtfcuamcdtadcFFFF970Ecbyd:K:kjjbHjjjjbbgqBdbavaDclfBd:yddnadci6mbamceamce0EhiaehoaqhrinarasaoydbcdtfIdbasaoclfydbcdtfIdbMasaocwfydbcdtfIdbMUdbaocxfhoarclfhraicufgimbkkavc;qbfhzavhoavyd:SehHavyd:WehOcbhwcbhrcbhAcehCinaohXcihQaearci2gLcdtfgocwfydbhdaoydbhDabaAcx2fgiclfaoclfydbgKBdbaiaDBdbaicwfadBdbaParfce86bbazadBdwazaKBdlazaDBdbaqarcdtfcbBdbdnawTmbcihQaXhiinazaQcdtfaiydbgoBdbaQaoaD9haoaK9hGaoad9hGfhQaiclfhiawcufgwmbkkaAcefhAaxaDcdtfgoaoydbcufBdbaxaKcdtfgoaoydbcufBdbaxadcdtfgoaoydbcufBdbcbhwinaOaHaeawaLfcdtfydbcdtgifydbcdtfgKhoakaifgDydbgdhidnadTmbdninaoydbarSmeaoclfhoaicufgiTmdxbkkaoadcdtaKfc98fydbBdbaDaDydbcufBdbkawcefgwci9hmbkdndndnaQTmbcuhrJbbbbhYcbhDavyd:SehKavyd:WehLindndnakazaDcdtfydbcdtgofydbgimbaDcefhDxekaDcs0hwasaofgdIdbh8AadalcbaDcefgDawEcdtfIdbalaxaofydbgwcwawcw6Ecdtfc;ebfIdbMgEUdbaEa8A:thEaicdthiaLaKaofydbcdtfhoinaqaoydbgwcdtfgdaEadIdbMg8AUdba8AaYaYa8A9DgdEhYawaradEhraoclfhoaic98fgimbkkaDaQ9hmbkarcu9hmekaCam9pmeindnaPaCfRbbmbaChrxdkamaCcefgC9hmbxdkkaQczaQcz6EhwazhoaXhzarcu9hmekkavyd:ydhokaocdtavc:4effc98fhrdninaoTmearydbcbyd:G:kjjbH:bjjjbbarc98fhraocufhoxbkkavc:Gdf8Kjjjjbk;UlevucuaicdtgvaicFFFFi0Egocbyd:K:kjjbHjjjjbbhralalyd9GgwcdtfarBdbalawcefBd9GabarBdbaocbyd:K:kjjbHjjjjbbhralalyd9GgocdtfarBdbalaocefBd9GabarBdlcuadcdtadcFFFFi0Ecbyd:K:kjjbHjjjjbbhralalyd9GgocdtfarBdbalaocefBd9GabarBdwabydbcbavzNjjjb8Aadci9UhwdnadTmbabydbhoaehladhrinaoalydbcdtfgvavydbcefBdbalclfhlarcufgrmbkkdnaiTmbabydbhlabydlhrcbhvaihoinaravBdbarclfhralydbavfhvalclfhlaocufgombkkdnadci6mbawceawce0EhDabydlhrabydwhvcbhlinaecwfydbhoaeclfydbhdaraeydbcdtfgwawydbgwcefBdbavawcdtfalBdbaradcdtfgdadydbgdcefBdbavadcdtfalBdbaraocdtfgoaoydbgocefBdbavaocdtfalBdbaecxfheaDalcefgl9hmbkkdnaiTmbabydlheabydbhlinaeaeydbalydb9RBdbalclfhlaeclfheaicufgimbkkkQbabaeadaic:01jjbz:mjjjbkQbabaeadaic:C:jjjbz:mjjjbk9DeeuabcFeaicdtzNjjjbhlcbhbdnadTmbindnalaeydbcdtfgiydbcu9hmbaiabBdbabcefhbkaeclfheadcufgdmbkkabk;:kivuo99lu8Jjjjjbcj;Hb9Rgl8Kjjjjbcbhvalc1;Gbfcbc;KbzNjjjb8AalcuadcdtadcFFFFi0Egocbyd:K:kjjbHjjjjbbgrBd19GalceBd;O9Galcwfcbyd:m:kjjbBdbalcb8Pd:e:kjjb83ibalc;W;Gbfcwfcbyd:y:kjjbBdbalcb8Pd:q:kjjb83i;W9Gaicd4hwdndnadmbJFFuFhDJFFuuhqJFFuuhkJFFuFhxJFFuuhmJFFuFhPxekawcdthsaehzincbhiinalaifgHazaifIdbgDaHIdbgxaxaD9EEUdbalc;W;GbfaifgHaDaHIdbgxaxaD9DEUdbaiclfgicx9hmbkazasfhzavcefgvad9hmbkalIdwhqalId;49GhDalIdlhkalId;09GhxalIdbhmalId;W9GhPkdndnadTmbJbbbbJbbjZaPam:tJbbbb:xgPaxak:tgxaxaP9DEgxaDaq:tgDaDax9DEgD:vaDJbbbb9BEhDawcdthsarhHadhzindndnaDaeIdbam:tNJb;au9eNJbbbZMgx:lJbbb9p9DTmbax:Ohixekcjjjj94hikaicztaicwtcj;GiGVaicsGVc:p;G:dKGcH2c;d;H:WKGcv2c;j:KM;jbGhvdndnaDaeclfIdbak:tNJb;au9eNJbbbZMgx:lJbbb9p9DTmbax:Ohixekcjjjj94hikaicztaicwtcj;GiGVaicsGVc:p;G:dKGcH2c;d;H:WKGcq2cM;j:KMeGavVhvdndnaDaecwfIdbaq:tNJb;au9eNJbbbZMgx:lJbbb9p9DTmbax:Ohixekcjjjj94hikaHavaicztaicwtcj;GiGVaicsGVc:p;G:dKGcH2c;d;H:WKGcC2c:KM;j:KdGVBdbaeasfheaHclfhHazcufgzmbkalcbcj;GbzNjjjbhiarhHadheinaiaHydbgzcFrGcx2fgvavydbcefBdbaiazcq4cFrGcx2fgvavydlcefBdlaiazcC4cFrGcx2fgzazydwcefBdwaHclfhHaecufgembxdkkalcbcj;GbzNjjjb8AkcbhHcbhzcbhecbhvinalaHfgiydbhsaiazBdbaicwfgwydbhOawavBdbaiclfgiydbhwaiaeBdbasazfhzaOavfhvawaefheaHcxfgHcj;Gb9hmbkcbhialaocbyd:K:kjjbHjjjjbbgzBd:m9GdnadTmbabhHinaHaiBdbaHclfhHadaicefgi9hmbkadTmbabhiadhHinalaraiydbgecdtfydbcFrGcx2fgvavydbgvcefBdbazavcdtfaeBdbaiclfhiaHcufgHmbkazhiadhHinalaraiydbgecdtfydbcq4cFrGcx2fgvavydlgvcefBdlabavcdtfaeBdbaiclfhiaHcufgHmbkabhiadhHinalaraiydbgecdtfydbcC4cFrGcx2fgvavydwgvcefBdwazavcdtfaeBdbaiclfhiaHcufgHmbkadTmbcbhiinabazydbcdtfaiBdbazclfhzadaicefgi9hmbkkclhidninaic98Smealc1;Gbfaifydbcbyd:G:kjjbH:bjjjbbaic98fhixbkkalcj;Hbf8Kjjjjbk9teiucbcbyd:O:kjjbgeabcifc98GfgbBd:O:kjjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd:O:kjjbgeabcrfc94GfgbBd:O:kjjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik9:eiuZbhedndncbyd:O:kjjbgdaecztgi9nmbcuheadai9RcFFifcz4nbcuSmekadhekcbabae9Rcifc98Gcbyd:O:kjjbfgdBd:O:kjjbdnadZbcztge9nmbadae9RcFFifcz4nb8Akkk:6ddbcjwk:Cdb4:h9w9N94:P:gW:j9O:ye9Pbbbbbbebbbdbbbebbbdbbbbbbbdbbbbbbbebbbbbbb:l29hZ;69:9kZ;N;76Z;rg97Z;z;o9xZ8J;B85Z;:;u9yZ;b;k9HZ:2;Z9DZ9e:l9mZ59A8KZ:r;T3Z:A:zYZ79OHZ;j4::8::Y:D9V8:bbbb9s:49:Z8R:hBZ9M9M;M8:L;z;o8:;8:PG89q;x:J878R:hQ8::M:B;e87bbbbbbjZbbjZbbjZ:E;V;N8::Y:DsZ9i;H;68:xd;R8:;h0838:;W:NoZbbbb:WV9O8:uf888:9i;H;68:9c9G;L89;n;m9m89;D8Ko8:bbbbf:8tZ9m836ZS:2AZL;zPZZ818EZ9e:lxZ;U98F8:819E;68:FFuuFFuuFFuuFFuFFFuFFFuFbc:Cqkzebbbebbbdbbb8WWbb",e=new Uint8Array([32,0,65,2,1,106,34,33,3,128,11,4,13,64,6,253,10,7,15,116,127,5,8,12,40,16,19,54,20,9,27,255,113,17,42,67,24,23,146,148,18,14,22,45,70,69,56,114,101,21,25,63,75,136,108,28,118,29,73,115]);if(typeof WebAssembly!="object")return{supported:!1};var n,i=WebAssembly.instantiate(o(t),{}).then(function(R){n=R.instance,n.exports.__wasm_call_ctors(),n.exports.meshopt_encodeVertexVersion(0),n.exports.meshopt_encodeIndexVersion(1)});function o(R){for(var V=new Uint8Array(R.length),F=0;F96?U-97:U>64?U-39:U+4}for(var G=0,F=0;F=3),r(n.exports.meshopt_spatialSortRemap,R,R.length/V,V*4)},encodeVertexBuffer:function(R,V,F){a(F>0&&F<=256),a(F%4==0);var U=n.exports.meshopt_encodeVertexBufferBound(V,F);return d(n.exports.meshopt_encodeVertexBuffer,U,R,V,F)},encodeIndexBuffer:function(R,V,F){a(F==2||F==4),a(V%3==0);var U=h(R,F),G=n.exports.meshopt_encodeIndexBufferBound(V,m(U)+1);return d(n.exports.meshopt_encodeIndexBuffer,G,U,V,4)},encodeIndexSequence:function(R,V,F){a(F==2||F==4);var U=h(R,F),G=n.exports.meshopt_encodeIndexSequenceBound(V,m(U)+1);return d(n.exports.meshopt_encodeIndexSequence,G,U,V,4)},encodeGltfBuffer:function(R,V,F,U){var G={ATTRIBUTES:this.encodeVertexBuffer,TRIANGLES:this.encodeIndexBuffer,INDICES:this.encodeIndexSequence};return a(G[U]),G[U](R,V,F)},encodeFilterOct:function(R,V,F,U){return a(F==4||F==8),a(U>=1&&U<=16),u(n.exports.meshopt_encodeFilterOct,R,V,F,U,16)},encodeFilterQuat:function(R,V,F,U){return a(F==8),a(U>=4&&U<=16),u(n.exports.meshopt_encodeFilterQuat,R,V,F,U,16)},encodeFilterExp:function(R,V,F,U,G){a(F>0&&F%4==0),a(U>=1&&U<=24);var A={Separate:0,SharedVector:1,SharedComponent:2};return u(n.exports.meshopt_encodeFilterExp,R,V,F,U,F,G?A[G]:1)}}}();var aIn=b(W()),lRt=function(){var t="b9H79Tebbbe8Fv9Gbb9Gvuuuuueu9Giuuub9Geueu9Giuuueuikqbeeedddillviebeoweuec:q;iekr;leDo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbeY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVbdE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbiL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtblK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949Wbol79IV9Rbrq;d8Yqdbk:yzeHu8Jjjjjbcj;eb9Rgv8Kjjjjbc9:hodnadcefal0mbcuhoaiRbbc:Ge9hmbavaialfgrad9Radz1jjjbhwcj;abad9UhlaicefhodnadTmbalc;WFbGglcjdalcjd6EhDcbhqinaqae9pmeaDaeaq9RaqaDfae6Egkcsfglcl4cifcd4hxdndndndnalc9WGgmTmbcbhPcehsawcjdfhzaohHinaraH9Rax6midnaraHaxfgo9RcK6mbczhlcbhOinalgic9WfgAawcj;cbffhldndndndndnaHaAco4fRbbaOcoG4ciGPlbedibkal9cb83ibalcwf9cb83ibxikalaoRblaoRbbgAco4gCaCciSgCE86bbawcj;cbfaifglcGfaoclfaCfgCRbbaAcl4ciGgXaXciSgXE86bbalcVfaCaXfgCRbbaAcd4ciGgXaXciSgXE86bbalc7faCaXfgCRbbaAciGgAaAciSgAE86bbalctfaCaAfgCRbbaoRbegAco4gXaXciSgXE86bbalc91faCaXfgCRbbaAcl4ciGgXaXciSgXE86bbalc4faCaXfgCRbbaAcd4ciGgXaXciSgXE86bbalc93faCaXfgCRbbaAciGgAaAciSgAE86bbalc94faCaAfgCRbbaoRbdgAco4gXaXciSgXE86bbalc95faCaXfgCRbbaAcl4ciGgXaXciSgXE86bbalc96faCaXfgCRbbaAcd4ciGgXaXciSgXE86bbalc97faCaXfgCRbbaAciGgAaAciSgAE86bbalc98faCaAfgARbbaoRbigoco4gCaCciSgCE86bbalc99faAaCfgARbbaocl4ciGgCaCciSgCE86bbalc9:faAaCfgARbbaocd4ciGgCaCciSgCE86bbalcufaAaCfglRbbaociGgoaociSgoE86bbalaofhoxdkalaoRbwaoRbbgAcl4gCaCcsSgCE86bbawcj;cbfaifglcGfaocwfaCfgCRbbaAcsGgAaAcsSgAE86bbalcVfaCaAfgARbbaoRbegCcl4gXaXcsSgXE86bbalc7faAaXfgARbbaCcsGgCaCcsSgCE86bbalctfaAaCfgARbbaoRbdgCcl4gXaXcsSgXE86bbalc91faAaXfgARbbaCcsGgCaCcsSgCE86bbalc4faAaCfgARbbaoRbigCcl4gXaXcsSgXE86bbalc93faAaXfgARbbaCcsGgCaCcsSgCE86bbalc94faAaCfgARbbaoRblgCcl4gXaXcsSgXE86bbalc95faAaXfgARbbaCcsGgCaCcsSgCE86bbalc96faAaCfgARbbaoRbvgCcl4gXaXcsSgXE86bbalc97faAaXfgARbbaCcsGgCaCcsSgCE86bbalc98faAaCfgARbbaoRbogCcl4gXaXcsSgXE86bbalc99faAaXfgARbbaCcsGgCaCcsSgCE86bbalc9:faAaCfgARbbaoRbrgocl4gCaCcsSgCE86bbalcufaAaCfglRbbaocsGgoaocsSgoE86bbalaofhoxekalao8Pbb83bbalcwfaocwf8Pbb83bbaoczfhokdnaiam9pmbaOcdfhOaiczfhlarao9RcL0mekkaiam6miaoTmidnakTmbawaPfRbbhOawcj;cbfhlazhiakhAinaialRbbgHce4cbaHceG9R7aOfgO86bbaiadfhialcefhlaAcufgAmbkkazcefhzaPcefgPad6hsaohHaPad9hmexvkkcbhoasceGmdxikaoaxad2fhXdnakTmbcbhmcehsawcjdfhCinarao9Rax6miaoTmdaoaxfhoawamfRbbhOawcj;cbfhlaChiakhAinaialRbbgHce4cbaHceG9R7aOfgO86bbaiadfhialcefhlaAcufgAmbkaCcefhCamcefgmad6hsamad9hmbkaXhoxikcbhlcehsinarao9Rax6mdaoTmeaoaxfhoalcefglad6hsadal9hmbkaXhoxdkcbhoasceGTmekc9:hoxikabaqad2fawcjdfakad2z1jjjb8Aawawcjdfakcufad2fadz1jjjb8Aakaqfhqaombkc9:hoxekcbc99arao9Radcaadca0ESEhokavcj;ebf8Kjjjjbaok;xzeHu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnaeci9UgrcHfal0mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecjez:jjjjb8AavcUf9cu83ibavc8Wf9cu83ibavcyf9cu83ibavcaf9cu83ibavcKf9cu83ibavczf9cu83ibav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhodnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhlindnaoaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfalaDcu7gPcl4fcsGcitfgsydlhzasydbhHdnaDcsGgDak9pmbavaiaPfcsGcdtfydbaxaDEhsaDThDdndnadcd9hmbabarcetfgPaH87ebaPcdfaz87ebaPclfas87ebxekabarcdtfgPaHBdbaPclfazBdbaPcwfasBdbkaxaDfhxavc;abfalcitfgPasBdbaPazBdlavaicdtfasBdbavc;abfalcefcsGglcitfgPaHBdbaPasBdlaiaDfhialcefhlxdkdndnaDcsSmbamaDfaDc987fcefhmxekaocefhDao8SbbgscFeGhPdndnascu9mmbaDhoxekaocvfhoaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhokaPce4cbaPceG9R7amfhmkdndnadcd9hmbabarcetfgDaH87ebaDcdfaz87ebaDclfam87ebxekabarcdtfgDaHBdbaDclfazBdbaDcwfamBdbkavc;abfalcitfgDamBdbaDazBdlavaicdtfamBdbavc;abfalcefcsGglcitfgDaHBdbaDamBdlaicefhialcefhlxekdnaDcpe0mbaxcefgOavaiaqaDcsGfRbbgscl49RcsGcdtfydbascz6gPEhDavaias9RcsGcdtfydbaOaPfgzascsGgOEhsaOThOdndnadcd9hmbabarcetfgHax87ebaHcdfaD87ebaHclfas87ebxekabarcdtfgHaxBdbaHclfaDBdbaHcwfasBdbkavaicdtfaxBdbavc;abfalcitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfalcefcsGcitfgHasBdbaHaDBdlavaiaPfcsGgicdtfasBdbavc;abfalcdfcsGglcitfgDaxBdbaDasBdlalcefhlaiaOfhiazaOfhxxekaxcbaoRbbgHEgAaDc;:eSgDfhzaHcsGhCaHcl4hXdndnaHcs0mbazcefhOxekazhOavaiaX9RcsGcdtfydbhzkdndnaCmbaOcefhxxekaOhxavaiaH9RcsGcdtfydbhOkdndnaDTmbaocefhDxekaocdfhDao8SbegPcFeGhsdnaPcu9kmbaocofhAascFbGhscrhodninaD8SbbgPcFbGaotasVhsaPcu9kmeaDcefhDaocrfgoc8J9hmbkaAhDxekaDcefhDkasce4cbasceG9R7amfgmhAkdndnaXcsSmbaDhsxekaDcefhsaD8SbbgocFeGhPdnaocu9kmbaDcvfhzaPcFbGhPcrhodninas8SbbgDcFbGaotaPVhPaDcu9kmeascefhsaocrfgoc8J9hmbkazhsxekascefhskaPce4cbaPceG9R7amfgmhzkdndnaCcsSmbashoxekascefhoas8SbbgDcFeGhPdnaDcu9kmbascvfhOaPcFbGhPcrhDdninao8SbbgscFbGaDtaPVhPascu9kmeaocefhoaDcrfgDc8J9hmbkaOhoxekaocefhokaPce4cbaPceG9R7amfgmhOkdndnadcd9hmbabarcetfgDaA87ebaDcdfaz87ebaDclfaO87ebxekabarcdtfgDaABdbaDclfazBdbaDcwfaOBdbkavc;abfalcitfgDazBdbaDaABdlavaicdtfaABdbavc;abfalcefcsGcitfgDaOBdbaDazBdlavaicefgicsGcdtfazBdbavc;abfalcdfcsGcitfgDaABdbaDaOBdlavaiaHcz6aXcsSVfgicsGcdtfaOBdbaiaCTaCcsSVfhialcifhlkawcefhwalcsGhlaicsGhiarcifgrae6mbkkcbc99aoaqSEhokavc;aef8Kjjjjbaok:flevu8Jjjjjbcz9Rhvc9:hodnaecvfal0mbcuhoaiRbbc;:eGc;qe9hmbav9cb83iwaicefhraialfc98fhwdnaeTmbdnadcdSmbcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcdtfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfglBdbaoalBdbaDcefgDae9hmbxdkkcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcetfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfgl87ebaoalBdbaDcefgDae9hmbkkcbc99arawSEhokaok:Lvoeue99dud99eud99dndnadcl9hmbaeTmeindndnabcdfgd8Sbb:Yab8Sbbgi:Ygl:l:tabcefgv8Sbbgo:Ygr:l:tgwJbb;:9cawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai86bbdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad86bbdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad86bbabclfhbaecufgembxdkkaeTmbindndnabclfgd8Ueb:Yab8Uebgi:Ygl:l:tabcdfgv8Uebgo:Ygr:l:tgwJb;:FSawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai87ebdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad87ebdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad87ebabcwfhbaecufgembkkk;siliui99iue99dnaeTmbcbhiabhlindndnJ;Zl81Zalcof8UebgvciV:Y:vgoal8Ueb:YNgrJb;:FSNJbbbZJbbb:;arJbbbb9GEMgw:lJbbb9p9DTmbaw:OhDxekcjjjj94hDkalclf8Uebhqalcdf8UebhkabaiavcefciGfcetfaD87ebdndnaoak:YNgwJb;:FSNJbbbZJbbb:;awJbbbb9GEMgx:lJbbb9p9DTmbax:Ohkxekcjjjj94hkkabaiavcdfciGfcetfak87ebdndnaoaq:YNgoJb;:FSNJbbbZJbbb:;aoJbbbb9GEMgx:lJbbb9p9DTmbax:Ohqxekcjjjj94hqkabaiavcufciGfcetfaq87ebdndnJbbjZararN:tawawN:taoaoN:tgrJbbbbarJbbbb9GE:rJb;:FSNJbbbZMgr:lJbbb9p9DTmbar:Ohqxekcjjjj94hqkabaiavciGfcetfaq87ebalcwfhlaiclfhiaecufgembkkk9mbdnadcd4ae2gdTmbinababydbgecwtcw91:Yaece91cjjj98Gcjjj;8if::NUdbabclfhbadcufgdmbkkk9teiucbcbydj1jjbgeabcifc98GfgbBdj1jjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabkkkebcjwklz9Kbb",e="b9H79TebbbeKl9Gbb9Gvuuuuueu9Giuuub9Geueuikqbbebeedddilve9Weeeviebeoweuec:q;Aekr;leDo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbdY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVblE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtboK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbrL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949Wbwl79IV9RbDq;b9tqlbzik9:evu8Jjjjjbcz9Rhbcbheincbhdcbhiinabcwfadfaicjuaead4ceGglE86bbaialfhiadcefgdcw9hmbkaec:q:yjjbfai86bbaecitc:q1jjbfab8Piw83ibaecefgecjd9hmbkk;e8JlHud97euo978Jjjjjbcj;kb9Rgv8Kjjjjbc9:hodnadcefal0mbcuhoaiRbbc:Ge9hmbavaialfgrad9Rad;8qbbcj;abad9UhoaicefhldnadTmbaoc;WFbGgocjdaocjd6EhwcbhDinaDae9pmeawaeaD9RaDawfae6Egqcsfgoc9WGgkci2hxakcethmaocl4cifcd4hPabaDad2fhscbhzdnincbhHalhOcbhAdninaraO9RaP6miavcj;cbfaAak2fhCaOaPfhlcbhidnakc;ab6mbaral9Rc;Gb6mbcbhoinaCaofhidndndndndnaOaoco4fRbbgXciGPlbedibkaipxbbbbbbbbbbbbbbbbpklbxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklbalczfhlkdndndndndnaXcd4ciGPlbedibkaipxbbbbbbbbbbbbbbbbpklzxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklzalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklzalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklzalczfhlkdndndndndnaXcl4ciGPlbedibkaipxbbbbbbbbbbbbbbbbpklaxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklaalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklaalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklaalczfhlkdndndndndnaXco4Plbedibkaipxbbbbbbbbbbbbbbbbpkl8WxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibaXc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spkl8WalclfaYpQbfaXc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibaXc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spkl8WalcwfaYpQbfaXc:q:yjjbfRbbfhlxekaialpbbbpkl8Walczfhlkaoc;abfhiaocjefak0meaihoaral9Rc;Fb0mbkkdndnaiak9pmbaici4hoinaral9RcK6mdaCaifhXdndndndndnaOaico4fRbbaocoG4ciGPlbedibkaXpxbbbbbbbbbbbbbbbbpklbxikaXalpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaXalpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaXalpbbbpklbalczfhlkaocdfhoaiczfgiak6mbkkalTmbaAcd0hHalhOaAcefgAclSmdxekkcbhlaHceGTmdkdnakTmbavcjdfazfhiavazfpbdbhYcbhXinaiavcj;cbfaXfgopblbgLcep9TaLpxeeeeeeeeeeeeeeeegQp9op9Hp9rgLaoakfpblbg8Acep9Ta8AaQp9op9Hp9rg8ApmbzeHdOiAlCvXoQrLgEaoamfpblbg3cep9Ta3aQp9op9Hp9rg3aoaxfpblbg5cep9Ta5aQp9op9Hp9rg5pmbzeHdOiAlCvXoQrLg8EpmbezHdiOAlvCXorQLgQaQpmbedibedibedibediaYp9UgYp9AdbbaiadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaEa8EpmwDKYqk8AExm35Ps8E8FgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaLa8ApmwKDYq8AkEx3m5P8Es8FgLa3a5pmwKDYq8AkEx3m5P8Es8Fg8ApmbezHdiOAlvCXorQLgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaLa8ApmwDKYqk8AExm35Ps8E8FgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfhiaXczfgXak6mbkkazclfgzad6mbkasavcjdfaqad2;8qbbavavcjdfaqcufad2fad;8qbbaqaDfhDc9:hoalmexikkc9:hoxekcbc99aral9Radcaadca0ESEhokavcj;kbf8Kjjjjbaokwbz:bjjjbk;tzeHu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnaeci9UgrcHfal0mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecje;8kbavcUf9cu83ibavc8Wf9cu83ibavcyf9cu83ibavcaf9cu83ibavcKf9cu83ibavczf9cu83ibav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhodnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhlindnaoaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfalaDcu7gPcl4fcsGcitfgsydlhzasydbhHdnaDcsGgDak9pmbavaiaPfcsGcdtfydbaxaDEhsaDThDdndnadcd9hmbabarcetfgPaH87ebaPcdfaz87ebaPclfas87ebxekabarcdtfgPaHBdbaPclfazBdbaPcwfasBdbkaxaDfhxavc;abfalcitfgPasBdbaPazBdlavaicdtfasBdbavc;abfalcefcsGglcitfgPaHBdbaPasBdlaiaDfhialcefhlxdkdndnaDcsSmbamaDfaDc987fcefhmxekaocefhDao8SbbgscFeGhPdndnascu9mmbaDhoxekaocvfhoaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhokaPce4cbaPceG9R7amfhmkdndnadcd9hmbabarcetfgDaH87ebaDcdfaz87ebaDclfam87ebxekabarcdtfgDaHBdbaDclfazBdbaDcwfamBdbkavc;abfalcitfgDamBdbaDazBdlavaicdtfamBdbavc;abfalcefcsGglcitfgDaHBdbaDamBdlaicefhialcefhlxekdnaDcpe0mbaxcefgOavaiaqaDcsGfRbbgscl49RcsGcdtfydbascz6gPEhDavaias9RcsGcdtfydbaOaPfgzascsGgOEhsaOThOdndnadcd9hmbabarcetfgHax87ebaHcdfaD87ebaHclfas87ebxekabarcdtfgHaxBdbaHclfaDBdbaHcwfasBdbkavaicdtfaxBdbavc;abfalcitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfalcefcsGcitfgHasBdbaHaDBdlavaiaPfcsGgicdtfasBdbavc;abfalcdfcsGglcitfgDaxBdbaDasBdlalcefhlaiaOfhiazaOfhxxekaxcbaoRbbgHEgAaDc;:eSgDfhzaHcsGhCaHcl4hXdndnaHcs0mbazcefhOxekazhOavaiaX9RcsGcdtfydbhzkdndnaCmbaOcefhxxekaOhxavaiaH9RcsGcdtfydbhOkdndnaDTmbaocefhDxekaocdfhDao8SbegPcFeGhsdnaPcu9kmbaocofhAascFbGhscrhodninaD8SbbgPcFbGaotasVhsaPcu9kmeaDcefhDaocrfgoc8J9hmbkaAhDxekaDcefhDkasce4cbasceG9R7amfgmhAkdndnaXcsSmbaDhsxekaDcefhsaD8SbbgocFeGhPdnaocu9kmbaDcvfhzaPcFbGhPcrhodninas8SbbgDcFbGaotaPVhPaDcu9kmeascefhsaocrfgoc8J9hmbkazhsxekascefhskaPce4cbaPceG9R7amfgmhzkdndnaCcsSmbashoxekascefhoas8SbbgDcFeGhPdnaDcu9kmbascvfhOaPcFbGhPcrhDdninao8SbbgscFbGaDtaPVhPascu9kmeaocefhoaDcrfgDc8J9hmbkaOhoxekaocefhokaPce4cbaPceG9R7amfgmhOkdndnadcd9hmbabarcetfgDaA87ebaDcdfaz87ebaDclfaO87ebxekabarcdtfgDaABdbaDclfazBdbaDcwfaOBdbkavc;abfalcitfgDazBdbaDaABdlavaicdtfaABdbavc;abfalcefcsGcitfgDaOBdbaDazBdlavaicefgicsGcdtfazBdbavc;abfalcdfcsGcitfgDaABdbaDaOBdlavaiaHcz6aXcsSVfgicsGcdtfaOBdbaiaCTaCcsSVfhialcifhlkawcefhwalcsGhlaicsGhiarcifgrae6mbkkcbc99aoaqSEhokavc;aef8Kjjjjbaok:flevu8Jjjjjbcz9Rhvc9:hodnaecvfal0mbcuhoaiRbbc;:eGc;qe9hmbav9cb83iwaicefhraialfc98fhwdnaeTmbdnadcdSmbcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcdtfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfglBdbaoalBdbaDcefgDae9hmbxdkkcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcetfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfgl87ebaoalBdbaDcefgDae9hmbkkcbc99arawSEhokaok:wPliuo97eue978Jjjjjbca9Rhiaec98Ghldndnadcl9hmbdnalTmbcbhvabhdinadadpbbbgocKp:RecKp:Sep;6egraocwp:RecKp:Sep;6earp;Geaoczp:RecKp:Sep;6egwp;Gep;Kep;LegDpxbbbbbbbbbbbbbbbbp:2egqarpxbbbjbbbjbbbjbbbjgkp9op9rp;Kegrpxbb;:9cbb;:9cbb;:9cbb;:9cararp;MeaDaDp;Meawaqawakp9op9rp;Kegrarp;Mep;Kep;Kep;Jep;Negwp;Mepxbbn0bbn0bbn0bbn0gqp;KepxFbbbFbbbFbbbFbbbp9oaopxbbbFbbbFbbbFbbbFp9op9qarawp;Meaqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaDawp;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpkbbadczfhdavclfgval6mbkkalae9pmeaipxbbbbbbbbbbbbbbbbgqpklbaiabalcdtfgdaeciGglcdtgv;8qbbdnalTmbaiaipblbgocKp:RecKp:Sep;6egraocwp:RecKp:Sep;6earp;Geaoczp:RecKp:Sep;6egwp;Gep;Kep;LegDaqp:2egqarpxbbbjbbbjbbbjbbbjgkp9op9rp;Kegrpxbb;:9cbb;:9cbb;:9cbb;:9cararp;MeaDaDp;Meawaqawakp9op9rp;Kegrarp;Mep;Kep;Kep;Jep;Negwp;Mepxbbn0bbn0bbn0bbn0gqp;KepxFbbbFbbbFbbbFbbbp9oaopxbbbFbbbFbbbFbbbFp9op9qarawp;Meaqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaDawp;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpklbkadaiav;8qbbskdnalTmbcbhvabhdinadczfgxaxpbbbgopxbbbbbbFFbbbbbbFFgkp9oadpbbbgDaopmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eaDaopmbediwDqkzHOAKY8AEgoczp:Sep;6egrp;Geaoczp:Reczp:Sep;6egwp;Gep;Kep;Legopxb;:FSb;:FSb;:FSb;:FSawaopxbbbbbbbbbbbbbbbbp:2egqawpxbbbjbbbjbbbjbbbjgmp9op9rp;Kegwawp;Meaoaop;Mearaqaramp9op9rp;Kegoaop;Mep;Kep;Kep;Jep;Negrp;Mepxbbn0bbn0bbn0bbn0gqp;Keczp:Reawarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9op9qgwaoarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9ogopmwDKYqk8AExm35Ps8E8Fp9qpkbbadaDakp9oawaopmbezHdiOAlvCXorQLp9qpkbbadcafhdavclfgval6mbkkalae9pmbaiaeciGgvcitgdfcbcaad9R;8kbaiabalcitfglad;8qbbdnavTmbaiaipblzgopxbbbbbbFFbbbbbbFFgkp9oaipblbgDaopmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eaDaopmbediwDqkzHOAKY8AEgoczp:Sep;6egrp;Geaoczp:Reczp:Sep;6egwp;Gep;Kep;Legopxb;:FSb;:FSb;:FSb;:FSawaopxbbbbbbbbbbbbbbbbp:2egqawpxbbbjbbbjbbbjbbbjgmp9op9rp;Kegwawp;Meaoaop;Mearaqaramp9op9rp;Kegoaop;Mep;Kep;Kep;Jep;Negrp;Mepxbbn0bbn0bbn0bbn0gqp;Keczp:Reawarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9op9qgwaoarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9ogopmwDKYqk8AExm35Ps8E8Fp9qpklzaiaDakp9oawaopmbezHdiOAlvCXorQLp9qpklbkalaiad;8qbbkk;4wllue97euv978Jjjjjbc8W9Rhidnaec98GglTmbcbhvabhoinaiaopbbbgraoczfgwpbbbgDpmlvorxmPsCXQL358E8Fgqczp:Segkclp:RepklbaopxbbjZbbjZbbjZbbjZpx;Zl81Z;Zl81Z;Zl81Z;Zl81Zakpxibbbibbbibbbibbbp9qp;6ep;NegkaraDpmbediwDqkzHOAKY8AEgrczp:Reczp:Sep;6ep;MegDaDp;Meakarczp:Sep;6ep;Megxaxp;Meakaqczp:Reczp:Sep;6ep;Megqaqp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jepxb;:FSb;:FSb;:FSb;:FSgkp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbgmp9oaxakp;Mearp;Keczp:Rep9qgxaqakp;Mearp;Keczp:ReaDakp;Mearp;Keamp9op9qgkpmbezHdiOAlvCXorQLgrp5baipblbpEb:T:j83ibaocwfarp5eaipblbpEe:T:j83ibawaxakpmwDKYqk8AExm35Ps8E8Fgkp5baipblbpEd:T:j83ibaocKfakp5eaipblbpEi:T:j83ibaocafhoavclfgval6mbkkdnalae9pmbaiaeciGgvcitgofcbcaao9R;8kbaiabalcitfgwao;8qbbdnavTmbaiaipblbgraipblzgDpmlvorxmPsCXQL358E8Fgqczp:Segkclp:RepklaaipxbbjZbbjZbbjZbbjZpx;Zl81Z;Zl81Z;Zl81Z;Zl81Zakpxibbbibbbibbbibbbp9qp;6ep;NegkaraDpmbediwDqkzHOAKY8AEgrczp:Reczp:Sep;6ep;MegDaDp;Meakarczp:Sep;6ep;Megxaxp;Meakaqczp:Reczp:Sep;6ep;Megqaqp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jepxb;:FSb;:FSb;:FSb;:FSgkp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbgmp9oaxakp;Mearp;Keczp:Rep9qgxaqakp;Mearp;Keczp:ReaDakp;Mearp;Keamp9op9qgkpmbezHdiOAlvCXorQLgrp5baipblapEb:T:j83ibaiarp5eaipblapEe:T:j83iwaiaxakpmwDKYqk8AExm35Ps8E8Fgkp5baipblapEd:T:j83izaiakp5eaipblapEi:T:j83iKkawaiao;8qbbkk:Pddiue978Jjjjjbc;ab9Rhidnadcd4ae2glc98GgvTmbcbheabhdinadadpbbbgocwp:Recwp:Sep;6eaocep:SepxbbjFbbjFbbjFbbjFp9opxbbjZbbjZbbjZbbjZp:Uep;Mepkbbadczfhdaeclfgeav6mbkkdnaval9pmbaialciGgecdtgdVcbc;abad9R;8kbaiabavcdtfgvad;8qbbdnaeTmbaiaipblbgocwp:Recwp:Sep;6eaocep:SepxbbjFbbjFbbjFbbjFp9opxbbjZbbjZbbjZbbjZp:Uep;Mepklbkavaiad;8qbbkk9teiucbcbydj1jjbgeabcifc98GfgbBdj1jjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikkkebcjwklz9Tbb",n=new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,3,2,0,0,5,3,1,0,1,12,1,0,10,22,2,12,0,65,0,65,0,65,0,252,10,0,0,11,7,0,65,0,253,15,26,11]),i=new Uint8Array([32,0,65,2,1,106,34,33,3,128,11,4,13,64,6,253,10,7,15,116,127,5,8,12,40,16,19,54,20,9,27,255,113,17,42,67,24,23,146,148,18,14,22,45,70,69,56,114,101,21,25,63,75,136,108,28,118,29,73,115]);if(typeof WebAssembly!="object")return{supported:!1};var o=WebAssembly.validate(n)?e:t,a,s=WebAssembly.instantiate(l(o),{}).then(function(G){a=G.instance,a.exports.__wasm_call_ctors()});function l(G){for(var A=new Uint8Array(G.length),S=0;S96?g-97:g>64?g-39:g+4}for(var C=0,S=0;S0?F(G,A,S,m[g],d[C]):s.then(function(){var y=new Uint8Array(G*A);return r(a,a.exports[m[g]],y,G,A,S,a.exports[d[C]]),y})}}}();var rIn=b(W()),sIn=function(){var t="b9H79Tebbbe9Ek9Geueu9Geub9Gbb9GPuuuuuuuuuuu99uueu9Gvuuuuub9Gluuuub9Gquuuuuuu99uueu9Gwuuuuuu99ueu9Giuuue999Gluuuueu9GiuuueuizsdilvoirwDbqqbeqlve9Weiiviebeoweuec:G;jekr:Tewo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bbz9TW79O9V9Wt9F79P9T9W29P9M95bl8E9TW79O9V9Wt9F79P9T9W29P9M959x9Pt9OcttV9P9I91tW7bvQ9TW79O9V9Wt9F79P9T9W29P9M959q9V9P9Ut7boX9TW79O9V9Wt9F79P9T9W29P9M959t9J9H2Wbra9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94SWt9J9O9sW9T9H9Wbwl79IV9RbDDwebcekdxmq::9Usdbk;i6iKuY99Ou8Jjjjjbc;W;ab9RgP8KjjjjbaPcwfcbc;Kbz:ljjjb8AaPcualcefgscdtascFFFFi0Ecbyd1:jjjbHjjjjbbgzBdwaPceBd9OaPazBdbaPcuadcitadcFFFFe0Ecbyd1:jjjbHjjjjbbgHBdxaPcdBd9OaPaHBdlaPaeadalcbz:cjjjbaPcualcdtgOalcFFFFi0EgAcbyd1:jjjbHjjjjbbgCBdzaPciBd9OaPaAcbyd1:jjjbHjjjjbbgXBdCaPclBd9Oalcd4alfhQcehLinaLgscethLasaQ6mbkcbhKaPcuascdtgLascFFFFi0Ecbyd1:jjjbHjjjjbbgQBdKaPcvBd9OaQcFeaLz:ljjjbhYdnalTmbavcd4h8AascufhEinaiaKa8A2cdtfg3ydlgscH4as7c:F:b:DD2a3ydbgscH4as7c;D;O:B8J27a3ydwgscH4as7c:3F;N8N27hQcbhsdndninaYaQaEGgQcdtfg5ydbgLcuSmeaiaLa8A2cdtfa3cxz:ojjjbTmdascefgsaQfhQasaE9nmbxdkka5aKBdbaKhLkaCaKcdtfaLBdbaKcefgKal9hmbkcbhsaXhLinaLasBdbaLclfhLalascefgs9hmbkcbhsaChLaXhQindnasaLydbgESmbaQaXaEcdtfgEydbBdbaEasBdbkaLclfhLaQclfhQalascefgs9hmbkkcbh8EaYcbyd:m:jjjbH:bjjjbbaPclBd9OaPalcbyd1:jjjbHjjjjbbgEBdKaPcvBd9OaPaAcbyd1:jjjbHjjjjbbgsBd3aPcoBd9OaPaAcbyd1:jjjbHjjjjbbgLBdaaPcrBd9OascFeaOz:ljjjbh8FaLcFeaOz:ljjjbhadnalTmbaHcwfhhindnaza8EgQcefg8Ecdtfydbg3azaQcdtgsfydbgLSmba3aL9RhOaHaLcitfhgaaasfh8Ja8FasfhKcbh8Aindndnaga8Acitfydbg5aQ9hmbaKaQBdba8JaQBdbxekdnaza5cdtg8KfgsclfydbgLasydbgsSmbaHascitg3fydbaQSmeaLas9Rh8Lascu7aLfhYaha3fhLcbhsinaYasSmeascefhsaLydbh3aLcwfhLa3aQ9hmbkasa8L6mekaaa8KfgsaQa5asydbcuSEBdbaKa5aQaKydbcuSEBdbka8Acefg8AaO9hmbkka8Eal9hmbkaChLaXhQaah3a8Fh8AcbhsindndnasaLydbg59hmbdnasaQydbg59hmba8Aydbh5dna3ydbgYcu9hmba5cu9hmbaEasfcb86bbxikaEasfhKdnasaYSmbasa5SmbaKce86bbxikaKcl86bbxdkdnasaXa5cdtgYfydb9hmbdna3ydbgKcuSmbasaKSmba8AydbgOcuSmbasaOSmbaaaYfydbggcuSmbaga5Smba8FaYfydbgYcuSmbaYa5SmbdnaCaKcdtfydbaCaYcdtfydb9hmbaCaOcdtfydbaCagcdtfydb9hmbaEasfcd86bbxlkaEasfcl86bbxikaEasfcl86bbxdkaEasfcl86bbxekaEasfaEa5fRbb86bbkaLclfhLaQclfhQa3clfh3a8Aclfh8Aalascefgs9hmbkaxceGTmbaEhsalhLindnasRbbce9hmbascl86bbkascefhsaLcufgLmbkkcualcx2alc;v:Q;v:Qe0Ecbyd1:jjjbHjjjjbbh8JaPcwfaPyd9Ogscdtfa8JBdbaPascefgOBd9Oa8Jaialavz:djjjbdndnaDmbcbhvxekcbh5aPcwfaOcdtfcuaDal2gLcdtaLcFFFFi0Ecbyd1:jjjbHjjjjbbgvBdbaPascdfgOBd9OalTmbarcd4cdthYaDcdthKavh8AinaohsawhLa8AhQaDh3inaQasIdbaLIdbNUdbasclfhsaLclfhLaQclfhQa3cufg3mbkaoaYfhoa8AaKfh8Aa5cefg5al9hmbkkaPcwfaOcdtfcualc8S2gsalc;D;O;f8U0EgQcbyd1:jjjbHjjjjbbgLBdbaPaOcefg3Bd9OaLcbasz:ljjjbh8EdndndnaDTmbaPcwfa3cdtfaQcbyd1:jjjbHjjjjbbgoBdbaPaOcdfgLBd9Oaocbasz:ljjjb8AaPcwfaLcdtfcuaDal2gscltgLascFFFFb0Ecbyd1:jjjbHjjjjbbgwBdbaPaOcifBd9OawcbaLz:ljjjb8AadmexdkcbhocbhwadTmekcbh8AaehLindna8JaLclfydbg5cx2fgsIdba8JaLydbgYcx2fgQIdbg8M:tg8Na8JaLcwfydbgKcx2fg3IdlaQIdlgy:tg8PNa3Idba8M:tgIasIdlay:tg8RN:tg8Sa8SNa8Ra3IdwaQIdwgR:tg8UNa8PasIdwaR:tg8RN:tg8Pa8PNa8RaINa8Ua8NN:tg8Na8NNMM:rgIJbbbb9ETmba8SaI:vh8Sa8NaI:vh8Na8PaI:vh8Pka8EaCaYcdtfydbc8S2fgsa8PaI:rgIa8PNNg8RasIdbMUdbasa8NaIa8NNg8VNg8UasIdlMUdlasa8SaIa8SNg8WNg8XasIdwMUdwasa8Va8PNg8VasIdxMUdxasa8Wa8PNg8YasIdzMUdzasa8Wa8NNg8WasIdCMUdCasa8PaIa8SaRNa8Pa8MNaya8NNMM:mgyNg8MNg8PasIdKMUdKasa8Na8MNg8NasId3MUd3asa8Sa8MNg8SasIdaMUdaasa8MayNg8MasId8KMUd8KasaIasIdyMUdya8EaCa5cdtfydbc8S2fgsa8RasIdbMUdbasa8UasIdlMUdlasa8XasIdwMUdwasa8VasIdxMUdxasa8YasIdzMUdzasa8WasIdCMUdCasa8PasIdKMUdKasa8NasId3MUd3asa8SasIdaMUdaasa8MasId8KMUd8KasaIasIdyMUdya8EaCaKcdtfydbc8S2fgsa8RasIdbMUdbasa8UasIdlMUdlasa8XasIdwMUdwasa8VasIdxMUdxasa8YasIdzMUdzasa8WasIdCMUdCasa8PasIdKMUdKasa8NasId3MUd3asa8SasIdaMUdaasa8MasId8KMUd8KasaIasIdyMUdyaLcxfhLa8Acifg8Aad6mbkcbh5aehYincbhLinaEaeaLc:G1jjbfydba5fcdtfydbgQfRbbhsdndnaEaYaLfydbg3fRbbg8Ac99fcFeGcpe0mbasceSmbascd9hmekdna8AcufcFeGce0mba8Fa3cdtfydbaQ9hmekdnascufcFeGce0mbaaaQcdtfydba39hmekdna8Acv2asfc:W1jjbfRbbTmbaCaQcdtfydbaCa3cdtfydb0mekJbbacJbbjZasceSEhIa8AceShOa8JaeaLc:K1jjbfydba5fcdtfydbcx2fhsdna8JaQcx2fg8AIdwa8Ja3cx2fgKIdwgy:tg8Pa8PNa8AIdbaKIdbgR:tg8Na8NNa8AIdlaKIdlg8R:tg8Sa8SNMM:rg8MJbbbb9ETmba8Pa8M:vh8Pa8Sa8M:vh8Sa8Na8M:vh8NkJbbacaIaOEh8WdnasIdway:tgIa8PaIa8PNasIdbaR:tg8Xa8NNa8SasIdla8R:tg8VNMMg8UN:tgIaINa8Xa8Na8UN:tg8Pa8PNa8Va8Sa8UN:tg8Na8NNMM:rg8SJbbbb9ETmbaIa8S:vhIa8Na8S:vh8Na8Pa8S:vh8Pka8EaCa3cdtfydbc8S2fgsa8Pa8Wa8MNg8Sa8PNNg8UasIdbMUdbasa8Na8Sa8NNg8WNg8XasIdlMUdlasaIa8SaINg8MNg8VasIdwMUdwasa8Wa8PNg8WasIdxMUdxasa8Ma8PNg8YasIdzMUdzasa8Ma8NNg8ZasIdCMUdCasa8Pa8SaIayNa8PaRNa8Ra8NNMM:mgyNg8MNg8PasIdKMUdKasa8Na8MNg8NasId3MUd3asaIa8MNgIasIdaMUdaasa8MayNg8MasId8KMUd8Kasa8SasIdyMUdya8EaCaQcdtfydbc8S2fgsa8UasIdbMUdbasa8XasIdlMUdlasa8VasIdwMUdwasa8WasIdxMUdxasa8YasIdzMUdzasa8ZasIdCMUdCasa8PasIdKMUdKasa8NasId3MUd3asaIasIdaMUdaasa8MasId8KMUd8Kasa8SasIdyMUdykaLclfgLcx9hmbkaYcxfhYa5cifg5ad6mbkaDTmbcbhYinJbbbbhRa8JaeaYcdtfgsclfydbgKcx2fgLIdwa8JasydbgOcx2fgQIdwg8V:tg8Na8NNaLIdbaQIdbg8Y:tgIaINaLIdlaQIdlg8Z:tg8Sa8SNMMg8Wa8Jascwfydbggcx2fgsIdwa8V:tg8MNa8Na8Na8MNaIasIdba8Y:tgyNa8SasIdla8Z:tg8RNMMg8PN:tJbbbbJbbjZa8Wa8Ma8MNayayNa8Ra8RNMMg8XNa8Pa8PN:tg8U:va8UJbbbb9BEg8UNh80a8Xa8NNa8Ma8PN:ta8UNh81a8Wa8RNa8Sa8PN:ta8UNhBa8Xa8SNa8Ra8PN:ta8UNh83a8WayNaIa8PN:ta8UNhUa8XaINaya8PN:ta8UNh85aIa8RNaya8SN:tg8Pa8PNa8Sa8MNa8Ra8NN:tg8Pa8PNa8NayNa8MaIN:tg8Pa8PNMM:r:rh8PavaOaD2cdtfhLavagaD2cdtfhQavaKaD2cdtfh3a8V:mh86a8Z:mh87a8Y:mh88cbh8AaDh5Jbbbbh8RJbbbbh8UJbbbbh8WJbbbbh8XJbbbbh8VJbbbbh8YJbbbbh8ZJbbbbh89Jbbbbh8:inaPc;Wbfa8Afgscwfa8Pa81a3IdbaLIdbg8M:tg8SNa80aQIdba8M:tgyNMg8NNUdbasclfa8Pa83a8SNaBayNMgINUdbasa8Pa85a8SNaUayNMg8SNUdbascxfa8Pa86a8NNa87aINa8Ma88a8SNMMMg8MNUdba8Pa8NaINNa8XMh8Xa8Pa8Na8SNNa8VMh8Va8PaIa8SNNa8YMh8Ya8Pa8Ma8MNNaRMhRa8Pa8Na8MNNa8RMh8Ra8PaIa8MNNa8UMh8Ua8Pa8Sa8MNNa8WMh8Wa8Pa8Na8NNNa8ZMh8Za8PaIaINNa89Mh89a8Pa8Sa8SNNa8:Mh8:aLclfhLa3clfh3aQclfhQa8Aczfh8Aa5cufg5mbkaoaCaOcdtfydbgLc8S2fgsa8:asIdbMUdbasa89asIdlMUdlasa8ZasIdwMUdwasa8YasIdxMUdxasa8VasIdzMUdzasa8XasIdCMUdCasa8WasIdKMUdKasa8UasId3MUd3asa8RasIdaMUdaasaRasId8KMUd8Kasa8PasIdyMUdyaoaCaKcdtfydbgKc8S2fgsa8:asIdbMUdbasa89asIdlMUdlasa8ZasIdwMUdwasa8YasIdxMUdxasa8VasIdzMUdzasa8XasIdCMUdCasa8WasIdKMUdKasa8UasId3MUd3asa8RasIdaMUdaasaRasId8KMUd8Kasa8PasIdyMUdyaoaCagcdtfydbgOc8S2fgsa8:asIdbMUdbasa89asIdlMUdlasa8ZasIdwMUdwasa8YasIdxMUdxasa8VasIdzMUdzasa8XasIdCMUdCasa8WasIdKMUdKasa8UasId3MUd3asa8RasIdaMUdaasaRasId8KMUd8Kasa8PasIdyMUdyawaLaD2cltfh5cbhLaDh3ina5aLfgsaPc;WbfaLfgQIdbasIdbMUdbasclfg8AaQclfIdba8AIdbMUdbascwfg8AaQcwfIdba8AIdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa3cufg3mbkawaKaD2cltfh5cbhLaDh3ina5aLfgsaPc;WbfaLfgQIdbasIdbMUdbasclfg8AaQclfIdba8AIdbMUdbascwfg8AaQcwfIdba8AIdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa3cufg3mbkawaOaD2cltfh5cbhLaDh3ina5aLfgsaPc;WbfaLfgQIdbasIdbMUdbasclfg8AaQclfIdba8AIdbMUdbascwfg8AaQcwfIdba8AIdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa3cufg3mbkaYcifgYad6mbkkdnabaeSmbabaeadcdtz:kjjjb8AkaPydbhZcbhsdnalTmbaZclfhsaZydbh3aEhLalh8AcbhQincbasydbg5a39RaLRbbcpeGEaQfhQaLcefhLasclfhsa5h3a8Acufg8AmbkaQce4hskcuadas9Rcifgrcx2arc;v:Q;v:Qe0Ecbyd1:jjjbHjjjjbbh8LaPcwfaPyd9Ogscdtfa8LBdbaPascefgLBd9OaPcwfaLcdtfcuarcdtarcFFFFi0Ecbyd1:jjjbHjjjjbbgxBdbaPascdfgLBd9OaPcwfaLcdtfaAcbyd1:jjjbHjjjjbbgHBdbaPascifgLBd9OaPcwfaLcdtfalcbyd1:jjjbHjjjjbbgnBdbaPasclfBd9OJbbbbh8Ydnadaq9nmbdnarci6mbakakNh8VaDclthca8Lcwfh9cJbbbbh8YinaPabadghalaCz:cjjjbabhOcbhzcbhKincbhsindnaCaOasfydbgQcdtgYfydbg8AaCabasc;m1jjbfydbaKfcdtfydbgLcdtfydbg5SmbaEaLfRbbgecv2aEaQfRbbg3fc;G1jjbfRbbg8Ka3cv2aefggc;G1jjbfRbbgiVcFeGTmbdnagc:W1jjbfRbbTmba5a8A0mekdna3ae9hmba3cufcFeGce0mba8FaYfydbaL9hmeka8Lazcx2fg3aLaQaicFeGg8AEBdla3aQaLa8AEBdba3a8Aa8KGcb9hBdwazcefhzkasclfgscx9hmbkdnaKcifgKah9pmbaOcxfhOazcifar9nmekkdnazmbahhdxikcbheinJbbbbJbbjZa8EaCa8Laecx2fg3ydlg8Aa3ydbg5a3ydwgLEgKcdtfydbg8Kc8S2gifgsIdyg8P:va8PJbbbb9BEasIdwa8Ja5a8AaLEgYcx2fgLIdwg8SNasIdzaLIdbg8MNasIdaMg8Pa8PMMa8SNasIdlaLIdlgyNasIdCa8SNasId3Mg8Pa8PMMayNasIdba8MNasIdxayNasIdKMg8Pa8PMMa8MNasId8KMMM:lNh8WJbbbbJbbjZa8EaCa5cdtfydbgdc8S2gQfgsIdyg8P:va8PJbbbb9BEasIdwa8Ja8Acx2fgLIdwgINasIdzaLIdbgRNasIdaMg8Pa8PMMaINasIdlaLIdlg8RNasIdCaINasId3Mg8Pa8PMMa8RNasIdbaRNasIdxa8RNasIdKMg8Pa8PMMaRNasId8KMMM:lNh8Xa3cwfhOa3clfhgdnaDTmbaoaQfgQIdwaINaQIdzaRNaQIdaMg8Pa8PMMaINaQIdla8RNaQIdCaINaQId3Mg8Pa8PMMa8RNaQIdbaRNaQIdxa8RNaQIdKMg8Pa8PMMaRNaQId8KMMMh8Nava8AaD2cdtfhLawadaD2cltfhsaQIdyh8UaDhQinaLIdbg8PJbbb;aNascxfIdbaIascwfIdbNaRasIdbNa8RasclfIdbNMMMNa8Pa8PNa8UNa8NMMh8NaLclfhLasczfhsaQcufgQmbkaoaifgQIdwa8SNaQIdza8MNaQIdaMg8Pa8PMMa8SNaQIdlayNaQIdCa8SNaQId3Mg8Pa8PMMayNaQIdba8MNaQIdxayNaQIdKMg8Pa8PMMa8MNaQId8KMMMhIavaYaD2cdtfhLawa8KaD2cltfhsaQIdyhRaDhQinaLIdbg8PJbbb;aNascxfIdba8SascwfIdbNa8MasIdbNayasclfIdbNMMMNa8Pa8PNaRNaIMMhIaLclfhLasczfhsaQcufgQmbka8WaI:lMh8Wa8Xa8N:lMh8Xkaga8AaYa8Xa8W9FgsEBdba3a5aKasEBdbaOa8Xa8WasEUdbaecefgeaz9hmbkaPc;Wbfcbcj;abz:ljjjb8Aa9chsazhLinaPc;WbfasydbcO4c;8ZGfgQaQydbcefBdbascxfhsaLcufgLmbkcbhscbhLinaPc;WbfasfgQydbh3aQaLBdba3aLfhLasclfgscj;ab9hmbkcbhsa9chLinaPc;WbfaLydbcO4c;8ZGfgQaQydbgQcefBdbaxaQcdtfasBdbaLcxfhLazascefgs9hmbkahaq9RgQci9UhJdnalTmbcbhsaHhLinaLasBdbaLclfhLalascefgs9hmbkkcbh9eancbalz:ljjjbhTaQcO9UhSaJce4h9haPydlh9icbhicbhgdnina8Laxagcdtfydbcx2fgOIdwg8Na8V9EmeaiaJ9pmeJFFuuh8Pdna9haz9pmba8Laxa9hcdtfydbcx2fIdwJbb;aZNh8Pkdna8Na8P9ETmbaiaS0mdkdnaTaCaOydlg6cdtg9kfydbg3fg0RbbaTaCaOydbgKcdtg9mfydbg9nfg9oRbbVmbdnaZa9ncdtfgsclfydbgLasydbgsSmbaLas9Rh5a9iascitfhsa8Ja3cx2fgYcwfhdaYclfhAa8Ja9ncx2fg8Kcwfh9pa8Kclfh9qcbhLcehednindnaHasydbcdtfydbgQa3SmbaHasclfydbcdtfydbg8Aa3SmbaQa8ASmba8Ja8Acx2fg8AIdba8JaQcx2fgQIdbgI:tg8Pa9qIdbaQIdlg8S:tg8MNa8KIdbaI:tgya8AIdla8S:tg8NN:ta8PaAIdba8S:tgRNaYIdbaI:tg8Ra8NN:tNa8Na9pIdbaQIdwg8S:tg8UNa8Ma8AIdwa8S:tgIN:ta8NadIdba8S:tg8SNaRaIN:tNaIayNa8Ua8PN:taIa8RNa8Sa8PN:tNMMJbbbb9FmdkascwfhsaLcefgLa56hea5aL9hmbkkaeceGTmba9hcefh9hxeka8Ea3c8S2gQfgsa8Ea9nc8S2g8AfgLIdbasIdbMUdbasaLIdlasIdlMUdlasaLIdwasIdwMUdwasaLIdxasIdxMUdxasaLIdzasIdzMUdzasaLIdCasIdCMUdCasaLIdKasIdKMUdKasaLId3asId3MUd3asaLIdaasIdaMUdaasaLId8KasId8KMUd8KasaLIdyasIdyMUdydnaDTmbaoaQfgsaoa8AfgLIdbasIdbMUdbasaLIdlasIdlMUdlasaLIdwasIdwMUdwasaLIdxasIdxMUdxasaLIdzasIdzMUdzasaLIdCasIdCMUdCasaLIdKasIdKMUdKasaLId3asId3MUd3asaLIdaasIdaMUdaasaLId8KasId8KMUd8KasaLIdyasIdyMUdyaca9n2heaca32hYawhLaDh8AinaLaYfgsaLaefgQIdbasIdbMUdbasclfg5aQclfIdba5IdbMUdbascwfg5aQcwfIdba5IdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa8Acufg8AmbkkaOcwfhLdndndndnaEaKfgQRbbc9:fPdebdkaKhsinaHascdtgsfa3BdbaXasfydbgsaK9hmbxikkaXa9kfydbhsaXa9mfydbhKaHa9mfa6Bdbash6kaHaKcdtfa6Bdbka9oce86bba0ce86bbaLIdbg8Pa8Ya8Ya8P9DEh8Ya9ecefh9ececdaQRbbceSEaifhikagcefggaz9hmbkkdna9embahhdxikdnalTmbcbhLa8FhsindnasydbgQcuSmbdnaLaHaQcdtg3fydbgQ9hmba8Fa3fydbhQkasaQBdbkasclfhsalaLcefgL9hmbkcbhLaahsindnasydbgQcuSmbdnaLaHaQcdtg3fydbgQ9hmbaaa3fydbhQkasaQBdbkasclfhsalaLcefgL9hmbkkcbhdabhscbh8AindnaHasydbcdtfydbgLaHasclfydbcdtfydbgQSmbaLaHascwfydbcdtfydbg3SmbaQa3Smbabadcdtfg5aLBdba5clfaQBdba5cwfa3Bdbadcifhdkascxfhsa8Acifg8Aah6mbkadaq9nmdxbkkaPabadalaCz:cjjjbkdnamTmbama8Y:rUdbkaPyd9OgscdtaPcwffc98fhCdninasTmeaCydbcbyd:m:jjjbH:bjjjbbaCc98fhCascufhsxbkkaPc;W;abf8Kjjjjbadk;:ieouabydlhvabydbclfcbaicdtz:ljjjbhoadci9UhrdnadTmbdnalTmbaehwadhDinaoalawydbcdtfydbcdtfgqaqydbcefBdbawclfhwaDcufgDmbxdkkaehwadhDinaoawydbcdtfgqaqydbcefBdbawclfhwaDcufgDmbkkdnaiTmbcbhDaohwinawydbhqawaDBdbawclfhwaqaDfhDaicufgimbkkdnadci6mbarcearce0EhdinaecwfydbhwaeclfydbhDaeydbhidnalTmbalawcdtfydbhwalaDcdtfydbhDalaicdtfydbhikavaoaicdtfgqydbcitfaDBdbavaqydbcitfawBdlaqaqydbcefBdbavaoaDcdtfgqydbcitfawBdbavaqydbcitfaiBdlaqaqydbcefBdbavaoawcdtfgwydbcitfaiBdbavawydbcitfaDBdlawawydbcefBdbaecxfheadcufgdmbkkabydbcbBdbk:Zldouv998Jjjjjbca9Rglczfcwfcbyd11jjbBdbalcb8Pdj1jjb83izalcwfcbydN1jjbBdbalcb8Pd:m1jjb83ibdnadTmbaicd4hvdnabTmbavcdthocbhraehwinabarcx2fgiaearav2cdtfgDIdbUdbaiaDIdlUdlaiaDIdwUdwcbhiinalczfaifgDawaifIdbgqaDIdbgkakaq9EEUdbalaifgDaqaDIdbgkakaq9DEUdbaiclfgicx9hmbkawaofhwarcefgrad9hmbxdkkavcdthrcbhwincbhiinalczfaifgDaeaifIdbgqaDIdbgkakaq9EEUdbalaifgDaqaDIdbgkakaq9DEUdbaiclfgicx9hmbkaearfheawcefgwad9hmbkkdnabTmbadTmbJbbbbJbbjZalIdbalIdzgk:tJbbbb:xgqalIdlalIdCgx:tgmamaq9DEgqalIdwalIdKgm:tgPaPaq9DEgq:vaqJbbbb9BEhqinabaqabIdbak:tNUdbabclfgiaqaiIdbax:tNUdbabcwfgiaqaiIdbam:tNUdbabcxfhbadcufgdmbkkk8KbabaeadaialavcbcbcbcbaoarawaDz:bjjjbk8KbabaeadaialavaoarawaDaqakaxamz:bjjjbk;lOowud99wue99iul998Jjjjjbc;Wb9Rgw8KjjjjbdndnarmbcbhDxekawcwfcbc;Kbz:ljjjb8Aawcuadcx2adc;v:Q;v:Qe0Ecbyd1:jjjbHjjjjbbgqBdwawceBd9Oaqaeadaiz:djjjbawcuadcdtadcFFFFi0Egkcbyd1:jjjbHjjjjbbgxBdxawcdBd9Oadcd4adfhmceheinaegicetheaiam6mbkcbhmawcuaicdtgPaicFFFFi0Ecbyd1:jjjbHjjjjbbgsBdzawciBd9Odndnar:Zgz:rJbbbZMgH:lJbbb9p9DTmbaH:Ohexekcjjjj94hekaicufhOc:bwhAcbhCcbhXadhQinaChLaeaAgKcufaeaK9iEamgDcefaeaD9kEhYdndnadTmbaYcuf:YhHaqhiaxheadhmindndnaiIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhAxekcjjjj94hAkaAcCthAdndnaiclfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaCcqtaAVhAdndnaicwfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaeaAaCVBdbaicxfhiaeclfheamcufgmmbkascFeaPz:ljjjbhEcbh3cbh5indnaEaxa5cdtfydbgAcm4aA7c:v;t;h;Ev2gics4ai7aOGgmcdtfgCydbgecuSmbaeaASmbcehiinaEamaifaOGgmcdtfgCydbgecuSmeaicefhiaeaA9hmbkkaCaABdba3aecuSfh3a5cefg5ad9hmbxdkkascFeaPz:ljjjb8Acbh3kaDaYa3ar0giEhmaLa3aiEhCdna3arSmbaYaKaiEgAam9Rcd9imbdndnaXcl0mbdnaQ:ZgHaL:Zg8A:taY:Yg8EaD:Y:tg8Fa8EaK:Y:tgaa3:Zghaz:tNNNaHaz:taaNa8Aah:tNa8Aaz:ta8FNahaH:tNM:va8EMJbbbZMgH:lJbbb9p9DTmbaH:Ohexdkcjjjj94hexekamaAfcd9Theka3aQaiEhQaXcefgXcs9hmekkdndnaCmbcihicbhDxekcbhiawakcbyd1:jjjbHjjjjbbg5BdCawclBd9OdndnadTmbamcuf:YhHaqhiaxheadhmindndnaiIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhAxekcjjjj94hAkaAcCthAdndnaiclfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaCcqtaAVhAdndnaicwfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaeaAaCVBdbaicxfhiaeclfheamcufgmmbkascFeaPz:ljjjbhEcbhDcbh3inaxa3cdtgYfydbgAcm4aA7c:v;t;h;Ev2gics4ai7hecbhidndninaEaeaOGgmcdtfgCydbgecuSmednaxaecdtgCfydbaASmbaicefgiamfheaiaO9nmekka5aCfydbhixekaCa3BdbaDhiaDcefhDka5aYfaiBdba3cefg3ad9hmbkcuaDc32giaDc;j:KM;jb0EhexekascFeaPz:ljjjb8AcbhDcbhekawaecbyd1:jjjbHjjjjbbgeBdKawcvBd9Oaecbaiz:ljjjbhOavcd4hxdnadTmbaxcdth3a5hmalhAaqheadhEinaOamydbc32fgiaeIdbaiIdbMUdbaiaeclfIdbaiIdlMUdlaiaecwfIdbaiIdwMUdwaiaAc;81jjbalEgCIdbaiIdxMUdxaiaCIdlaiIdzMUdzaiaCIdwaiIdCMUdCaiaiIdKJbbjZMUdKamclfhmaAa3fhAaecxfheaEcufgEmbkkdnaDTmbaOcxfhiaDheinaictfgmamIdbJbbbbJbbjZaicxfIdbgH:vaHJbbbb9BEgHNUdbaic94fgmaHamIdbNUdbaic98fgmaHamIdbNUdbaiaHaiIdbNUdbaiclfgmaHamIdbNUdbaicwfgmaHamIdbNUdbaic3fhiaecufgembkkcbhAawcuaDcdtgYaDcFFFFi0Egicbyd1:jjjbHjjjjbbgeBd3awcoBd9Oawaicbyd1:jjjbHjjjjbbgEBdaaecFeaYz:ljjjbh3dnadTmbaoaoNh8Aaxcdthxalheina8Aaec;81jjbalEgmIdwaOa5ydbgCc32fgiIdC:tgHaHNamIdbaiIdx:tgHaHNamIdlaiIdz:tgHaHNMMNaqcwfIdbaiIdw:tgHaHNaqIdbaiIdb:tgHaHNaqclfIdbaiIdl:tgHaHNMMMhHdndna3aCcdtgifgmydbcuSmbaEaifIdbaH9ETmekamaABdbaEaifaHUdbka5clfh5aeaxfheaqcxfhqadaAcefgA9hmbkkaba3aYz:kjjjb8AcrhikaicdthiinaiTmeaic98fgiawcwffydbcbyd:m:jjjbH:bjjjbbxbkkawc;Wbf8KjjjjbaDk:Qdidui99ducbhi8Jjjjjbca9Rglczfcwfcbyd11jjbBdbalcb8Pdj1jjb83izalcwfcbydN1jjbBdbalcb8Pd:m1jjb83ibdndnaembJbbjFhvJbbjFhoJbbjFhrxekadcd4cdthwincbhdinalczfadfgDabadfIdbgoaDIdbgrarao9EEUdbaladfgDaoaDIdbgrarao9DEUdbadclfgdcx9hmbkabawfhbaicefgiae9hmbkalIdwalIdK:thralIdlalIdC:thoalIdbalIdz:thvkavJbbbb:xgvaoaoav9DEgoararao9DEk9DeeuabcFeaicdtz:ljjjbhlcbhbdnadTmbindnalaeydbcdtfgiydbcu9hmbaiabBdbabcefhbkaeclfheadcufgdmbkkabk9teiucbcbyd:q:jjjbgeabcifc98GfgbBd:q:jjjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd:q:jjjbgeabcrfc94GfgbBd:q:jjjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik9:eiuZbhedndncbyd:q:jjjbgdaecztgi9nmbcuheadai9RcFFifcz4nbcuSmekadhekcbabae9Rcifc98Gcbyd:q:jjjbfgdBd:q:jjjbdnadZbcztge9nmbadae9RcFFifcz4nb8Akk6eiucbhidnadTmbdninabRbbglaeRbbgv9hmeaecefheabcefhbadcufgdmbxdkkalav9Rhikaikk:Iedbcjwk1eFFuuFFuuFFuuFFuFFFuFFFuFbbbbbbbbebbbdbbbbbbbebbbeeebeebebbeeebebbbbbebebbbbbebbbdbbbbbbbbbbbbbbbeeeeebebbbbbebbbbbeebbbbbbbbbbbbbbbbbbbbbc1Dkxebbbdbbb:G9Kbb",e=new Uint8Array([32,0,65,2,1,106,34,33,3,128,11,4,13,64,6,253,10,7,15,116,127,5,8,12,40,16,19,54,20,9,27,255,113,17,42,67,24,23,146,148,18,14,22,45,70,69,56,114,101,21,25,63,75,136,108,28,118,29,73,115]);if(typeof WebAssembly!="object")return{supported:!1};var n,i=WebAssembly.instantiate(o(t),{}).then(function(V){n=V.instance,n.exports.__wasm_call_ctors()});function o(V){for(var F=new Uint8Array(V.length),U=0;U96?G-97:G>64?G-39:G+4}for(var A=0,U=0;U=3),a(G>=0&&G<=V.length),a(G%3==0),a(A>=0&&A<=1);for(var g=0,C=0;C<(S?S.length:0);++C)g|=R[S[C]];var y=V.BYTES_PER_ELEMENT==4?V:new Uint32Array(V),Y=d(n.exports.meshopt_simplify,y,V.length,F,F.length/U,U*4,G,A,g);return Y[0]=V instanceof Uint32Array?Y[0]:new V.constructor(Y[0]),Y},simplifyWithAttributes:function(V,F,U,G,A,S,g,C,y){a(this.useExperimentalFeatures),a(V instanceof Uint32Array||V instanceof Int32Array||V instanceof Uint16Array||V instanceof Int16Array),a(V.length%3==0),a(F instanceof Float32Array),a(F.length%U==0),a(U>=3),a(G instanceof Float32Array),a(G.length%A==0),a(A>=0),a(g>=0&&g<=V.length),a(g%3==0),a(C>=0&&C<=1),a(Array.isArray(S)),a(A>=S.length),a(S.length<=16);for(var Y=0,Q=0;Q<(y?y.length:0);++Q)Y|=R[y[Q]];var J=V.BYTES_PER_ELEMENT==4?V:new Uint32Array(V),M=m(n.exports.meshopt_simplifyWithAttributes,J,V.length,F,F.length/U,U*4,G,A*4,new Float32Array(S),g,C,Y);return M[0]=V instanceof Uint32Array?M[0]:new V.constructor(M[0]),M},getScale:function(V,F){return a(V instanceof Float32Array),a(V.length%F==0),a(F>=3),h(n.exports.meshopt_simplifyScale,V,V.length/F,F*4)},simplifyPoints:function(V,F,U,G,A,S){return a(this.useExperimentalFeatures),a(V instanceof Float32Array),a(V.length%F==0),a(F>=3),a(U>=0&&U<=V.length/F),G?(a(G instanceof Float32Array),a(G.length%A==0),a(A>=3),a(V.length/F==G.length/A),u(n.exports.meshopt_simplifyPoints,V,V.length/F,F*4,G,A*4,S,U)):u(n.exports.meshopt_simplifyPoints,V,V.length/F,F*4,void 0,0,0,U)}}}();function VA(t){t=f(t,f.EMPTY_OBJECT);let e=t.resourceCache,n=t.gltf,i=t.bufferViewId,o=t.gltfResource,a=t.baseResource,s=t.cacheKey,l=n.bufferViews[i],r=l.buffer,d=l.byteOffset,m=l.byteLength,h=!1,u,R,V,F;if(co(l,"EXT_meshopt_compression")){let G=l.extensions.EXT_meshopt_compression;r=G.buffer,d=f(G.byteOffset,0),m=G.byteLength,h=!0,u=G.byteStride,R=G.count,V=G.mode,F=f(G.filter,"NONE")}let U=n.buffers[r];this._hasMeshopt=h,this._meshoptByteStride=u,this._meshoptCount=R,this._meshoptMode=V,this._meshoptFilter=F,this._resourceCache=e,this._gltfResource=o,this._baseResource=a,this._buffer=U,this._bufferId=r,this._byteOffset=d,this._byteLength=m,this._cacheKey=s,this._bufferLoader=void 0,this._typedArray=void 0,this._state=pn.UNLOADED,this._promise=void 0}c(Object.create)&&(VA.prototype=Object.create(Za.prototype),VA.prototype.constructor=VA);Object.defineProperties(VA.prototype,{cacheKey:{get:function(){return this._cacheKey}},typedArray:{get:function(){return this._typedArray}}});async function M8t(t){try{let e=_8t(t);if(t._bufferLoader=e,await e.load(),t.isDestroyed())return;let n=e.typedArray,i=new Uint8Array(n.buffer,n.byteOffset+t._byteOffset,t._byteLength);if(t.unload(),t._typedArray=i,t._hasMeshopt){let o=t._meshoptCount,a=t._meshoptByteStride,s=new Uint8Array(o*a);lRt.decodeGltfBuffer(s,o,a,t._typedArray,t._meshoptMode,t._meshoptFilter),t._typedArray=s}return t._state=pn.READY,t}catch(e){if(t.isDestroyed())return;throw t.unload(),t._state=pn.FAILED,t.getError("Failed to load buffer view",e)}}VA.prototype.load=async function(){return c(this._promise)?this._promise:(this._state=pn.LOADING,this._promise=M8t(this),this._promise)};function _8t(t){let e=t._resourceCache,n=t._buffer;if(c(n.uri)){let o=t._baseResource.getDerivedResource({url:n.uri});return e.getExternalBufferLoader({resource:o})}return e.getEmbeddedBufferLoader({parentResource:t._gltfResource,bufferId:t._bufferId})}VA.prototype.unload=function(){c(this._bufferLoader)&&!this._bufferLoader.isDestroyed()&&this._resourceCache.unload(this._bufferLoader),this._bufferLoader=void 0,this._typedArray=void 0};var QE=VA;var QIn=b(W(),1);var gIn=b(W(),1);function il(){}il._maxDecodingConcurrency=Math.max(In.hardwareConcurrency-1,1);il._decoderTaskProcessor=void 0;il._taskProcessorReady=!1;il._error=void 0;il._getDecoderTaskProcessor=function(){if(!c(il._decoderTaskProcessor)){let t=new $i("decodeDraco",il._maxDecodingConcurrency);t.initWebAssemblyModule({wasmBinaryFile:"ThirdParty/draco_decoder.wasm"}).then(function(e){e?il._taskProcessorReady=!0:il._error=new Tt("Draco decoder could not be initialized.")}).catch(e=>{il._error=e}),il._decoderTaskProcessor=t}return il._decoderTaskProcessor};il.decodePointCloud=function(t){let e=il._getDecoderTaskProcessor();if(c(il._error))throw il._error;if(il._taskProcessorReady)return e.scheduleTask(t,[t.buffer.buffer])};il.decodeBufferView=function(t){let e=il._getDecoderTaskProcessor();if(c(il._error))throw il._error;if(il._taskProcessorReady)return e.scheduleTask(t,[t.array.buffer])};var $b=il;function xf(t){t=f(t,f.EMPTY_OBJECT);let e=t.resourceCache,n=t.gltf,i=t.draco,o=t.gltfResource,a=t.baseResource,s=t.cacheKey;this._resourceCache=e,this._gltfResource=o,this._baseResource=a,this._gltf=n,this._draco=i,this._cacheKey=s,this._bufferViewLoader=void 0,this._bufferViewTypedArray=void 0,this._decodePromise=void 0,this._decodedData=void 0,this._state=pn.UNLOADED,this._promise=void 0,this._dracoError=void 0}c(Object.create)&&(xf.prototype=Object.create(Za.prototype),xf.prototype.constructor=xf);Object.defineProperties(xf.prototype,{cacheKey:{get:function(){return this._cacheKey}},decodedData:{get:function(){return this._decodedData}}});async function D8t(t){let e=t._resourceCache;try{let n=e.getBufferViewLoader({gltf:t._gltf,bufferViewId:t._draco.bufferView,gltfResource:t._gltfResource,baseResource:t._baseResource});return t._bufferViewLoader=n,await n.load(),t.isDestroyed()?void 0:(t._bufferViewTypedArray=n.typedArray,t._state=pn.PROCESSING,t)}catch(n){if(t.isDestroyed())return;rRt(t,n)}}xf.prototype.load=async function(){return c(this._promise)?this._promise:(this._state=pn.LOADING,this._promise=D8t(this),this._promise)};function rRt(t,e){throw t.unload(),t._state=pn.FAILED,t.getError("Failed to load Draco",e)}async function O8t(t,e){try{let n=await e;return t.isDestroyed()?void 0:(t.unload(),t._decodedData={indices:n.indexArray,vertexAttributes:n.attributeData},t._state=pn.READY,t._baseResource)}catch(n){if(t.isDestroyed())return;t._dracoError=n}}xf.prototype.process=function(t){if(this._state===pn.READY)return!0;if(this._state!==pn.PROCESSING||(c(this._dracoError)&&rRt(this,this._dracoError),!c(this._bufferViewTypedArray))||c(this._decodePromise))return!1;let e=this._draco,i=this._gltf.bufferViews,o=e.bufferView,a=i[o],s=e.attributes,l={array:new Uint8Array(this._bufferViewTypedArray),bufferView:a,compressedAttributes:s,dequantizeInShader:!0},r=$b.decodeBufferView(l);if(!c(r))return!1;this._decodePromise=O8t(this,r)};xf.prototype.unload=function(){c(this._bufferViewLoader)&&this._resourceCache.unload(this._bufferViewLoader),this._bufferViewLoader=void 0,this._bufferViewTypedArray=void 0,this._decodedData=void 0,this._gltf=void 0};var kE=xf;var vIn=b(W(),1);var JIn=b(W(),1);function H8t(t){let e=t.uint8Array,n=t.format,i=t.request,o=f(t.flipY,!1),a=f(t.skipColorSpaceConversion,!1),s=new Blob([e],{type:n}),l;return te.supportsImageBitmapOptions().then(function(r){return r?Promise.resolve(te.createImageBitmapFromBlob(s,{flipY:o,premultiplyAlpha:!1,skipColorSpaceConversion:a})):(l=window.URL.createObjectURL(s),new te({url:l,request:i}).fetchImage({flipY:o,skipColorSpaceConversion:a}))}).then(function(r){return c(l)&&window.URL.revokeObjectURL(l),r}).catch(function(r){return c(l)&&window.URL.revokeObjectURL(l),Promise.reject(r)})}var uA=H8t;function t0(t){t=f(t,f.EMPTY_OBJECT);let e=t.resourceCache,n=t.gltf,i=t.imageId,o=t.gltfResource,a=t.baseResource,s=t.cacheKey,l=n.images[i],r=l.bufferView,d=l.uri;this._resourceCache=e,this._gltfResource=o,this._baseResource=a,this._gltf=n,this._bufferViewId=r,this._uri=d,this._cacheKey=s,this._bufferViewLoader=void 0,this._image=void 0,this._mipLevels=void 0,this._state=pn.UNLOADED,this._promise=void 0}c(Object.create)&&(t0.prototype=Object.create(Za.prototype),t0.prototype.constructor=t0);Object.defineProperties(t0.prototype,{cacheKey:{get:function(){return this._cacheKey}},image:{get:function(){return this._image}},mipLevels:{get:function(){return this._mipLevels}}});t0.prototype.load=function(){return c(this._promise)?this._promise:c(this._bufferViewId)?(this._promise=w8t(this),this._promise):(this._promise=P8t(this),this._promise)};function dRt(t){let e;return Array.isArray(t)&&(e=t.slice(1,t.length).map(function(n){return n.bufferView}),t=t[0]),{image:t,mipLevels:e}}async function w8t(t){t._state=pn.LOADING;let e=t._resourceCache;try{let n=e.getBufferViewLoader({gltf:t._gltf,bufferViewId:t._bufferViewId,gltfResource:t._gltfResource,baseResource:t._baseResource});if(t._bufferViewLoader=n,await n.load(),t.isDestroyed())return;let i=n.typedArray,o=await K8t(i);if(t.isDestroyed())return;let a=dRt(o);return t.unload(),t._image=a.image,t._mipLevels=a.mipLevels,t._state=pn.READY,t}catch(n){return t.isDestroyed()?void 0:cRt(t,n,"Failed to load embedded image")}}async function P8t(t){t._state=pn.LOADING;let e=t._baseResource,n=t._uri,i=e.getDerivedResource({url:n});try{let o=await j8t(i);if(t.isDestroyed())return;let a=dRt(o);return t.unload(),t._image=a.image,t._mipLevels=a.mipLevels,t._state=pn.READY,t}catch(o){return t.isDestroyed()?void 0:cRt(t,o,`Failed to load image: ${n}`)}}function cRt(t,e,n){return t.unload(),t._state=pn.FAILED,Promise.reject(t.getError(n,e))}function v8t(t){let e=t.subarray(0,2),n=t.subarray(0,4),i=t.subarray(8,12);if(e[0]===255&&e[1]===216)return"image/jpeg";if(e[0]===137&&e[1]===80)return"image/png";if(e[0]===171&&e[1]===75)return"image/ktx2";if(n[0]===82&&n[1]===73&&n[2]===70&&n[3]===70&&i[0]===87&&i[1]===69&&i[2]===66&&i[3]===80)return"image/webp";throw new Tt("Image format is not recognized")}async function K8t(t){let e=v8t(t);if(e==="image/ktx2"){let n=new Uint8Array(t);return Fm(n)}return t0._loadImageFromTypedArray({uint8Array:t,format:e,flipY:!1,skipColorSpaceConversion:!0})}var z8t=/(^data:image\/ktx2)|(\.ktx2$)/i;function j8t(t){let e=t.getUrlComponent(!1,!0);return z8t.test(e)?Fm(t):t.fetchImage({skipColorSpaceConversion:!0,preferImageBitmap:!0})}t0.prototype.unload=function(){c(this._bufferViewLoader)&&!this._bufferViewLoader.isDestroyed()&&this._resourceCache.unload(this._bufferViewLoader),this._bufferViewLoader=void 0,this._uri=void 0,this._image=void 0,this._mipLevels=void 0,this._gltf=void 0};t0._loadImageFromTypedArray=uA;var YE=t0;var r1n=b(W(),1);var zIn=b(W(),1),q8t={TEXTURE:0,PROGRAM:1,BUFFER:2,NUMBER_OF_JOB_TYPES:3},Zd=Object.freeze(q8t);function Xf(t){t=f(t,f.EMPTY_OBJECT);let e=t.resourceCache,n=t.gltf,i=t.accessorId,o=t.gltfResource,a=t.baseResource,s=t.draco,l=t.cacheKey,r=f(t.asynchronous,!0),d=f(t.loadBuffer,!1),m=f(t.loadTypedArray,!1),h=n.accessors[i].componentType;this._resourceCache=e,this._gltfResource=o,this._baseResource=a,this._gltf=n,this._accessorId=i,this._indexDatatype=h,this._draco=s,this._cacheKey=l,this._asynchronous=r,this._loadBuffer=d,this._loadTypedArray=m,this._bufferViewLoader=void 0,this._dracoLoader=void 0,this._typedArray=void 0,this._buffer=void 0,this._state=pn.UNLOADED,this._promise=void 0}c(Object.create)&&(Xf.prototype=Object.create(Za.prototype),Xf.prototype.constructor=Xf);Object.defineProperties(Xf.prototype,{cacheKey:{get:function(){return this._cacheKey}},buffer:{get:function(){return this._buffer}},typedArray:{get:function(){return this._typedArray}},indexDatatype:{get:function(){return this._indexDatatype}}});var $8t=new Dq;Xf.prototype.load=async function(){return c(this._promise)?this._promise:c(this._draco)?(this._promise=t6t(this),this._promise):(this._promise=e6t(this),this._promise)};async function t6t(t){t._state=pn.LOADING;let e=t._resourceCache;try{let n=e.getDracoLoader({gltf:t._gltf,draco:t._draco,gltfResource:t._gltfResource,baseResource:t._baseResource});return t._dracoLoader=n,await n.load(),t.isDestroyed()?void 0:(t._state=pn.LOADED,t)}catch(n){if(t.isDestroyed())return;_q(t,n)}}async function e6t(t){let e=t._gltf,n=t._accessorId,o=e.accessors[n].bufferView;t._state=pn.LOADING;let a=t._resourceCache;try{let s=a.getBufferViewLoader({gltf:e,bufferViewId:o,gltfResource:t._gltfResource,baseResource:t._baseResource});if(t._bufferViewLoader=s,await s.load(),t.isDestroyed())return;let l=s.typedArray;return t._typedArray=n6t(t,l),t._state=pn.PROCESSING,t}catch(s){if(t.isDestroyed())return;_q(t,s)}}function n6t(t,e){let n=t._gltf,i=t._accessorId,o=n.accessors[i],a=o.count,s=o.componentType,l=re.getSizeInBytes(s),r=e.buffer,d=e.byteOffset+o.byteOffset;if(d%l!==0){let h=a*l,u=new Uint8Array(r,d,h);r=new Uint8Array(u).buffer,d=0,ur("index-buffer-unaligned",`The index array is not aligned to a ${l}-byte boundary.`)}let m;return s===re.UNSIGNED_BYTE?m=new Uint8Array(r,d,a):s===re.UNSIGNED_SHORT?m=new Uint16Array(r,d,a):s===re.UNSIGNED_INT&&(m=new Uint32Array(r,d,a)),m}function _q(t,e){throw t.unload(),t._state=pn.FAILED,t.getError("Failed to load index buffer",e)}function Dq(){this.typedArray=void 0,this.indexDatatype=void 0,this.context=void 0,this.buffer=void 0}Dq.prototype.set=function(t,e,n){this.typedArray=t,this.indexDatatype=e,this.context=n};Dq.prototype.execute=function(){this.buffer=mRt(this.typedArray,this.indexDatatype,this.context)};function mRt(t,e,n){let i=we.createIndexBuffer({typedArray:t,context:n,usage:ce.STATIC_DRAW,indexDatatype:e});return i.vertexArrayDestroyable=!1,i}Xf.prototype.process=function(t){if(this._state===pn.READY)return!0;if(this._state!==pn.LOADED&&this._state!==pn.PROCESSING)return!1;let e=this._typedArray,n=this._indexDatatype;if(c(this._dracoLoader))try{this._dracoLoader.process(t)&&(e=this._dracoLoader.decodedData.indices.typedArray,this._typedArray=e,n=it.fromTypedArray(e),this._indexDatatype=n)}catch(o){_q(this,o)}if(!c(e))return!1;let i;if(this._loadBuffer&&this._asynchronous){let o=$8t;if(o.set(e,n,t.context),!t.jobScheduler.execute(o,Zd.BUFFER))return!1;i=o.buffer}else this._loadBuffer&&(i=mRt(e,n,t.context));return this.unload(),this._buffer=i,this._typedArray=this._loadTypedArray?e:void 0,this._state=pn.READY,this._resourceCache.statistics.addGeometryLoader(this),!0};Xf.prototype.unload=function(){c(this._buffer)&&this._buffer.destroy();let t=this._resourceCache;c(this._bufferViewLoader)&&!this._bufferViewLoader.isDestroyed()&&t.unload(this._bufferViewLoader),c(this._dracoLoader)&&t.unload(this._dracoLoader),this._bufferViewLoader=void 0,this._dracoLoader=void 0,this._typedArray=void 0,this._buffer=void 0,this._gltf=void 0};var xE=Xf;var WBn=b(W(),1);var B1n=b(W(),1);var m1n=b(W(),1);function i6t(t,e,n){if(n=f(n,!1),n){let i=t.indexOf(e);if(i>-1)return i}return t.push(e),t.length-1}var $l=i6t;var b1n=b(W(),1);var V1n=b(W(),1);function o6t(t,e){return c(t.extensionsUsed)&&t.extensionsUsed.indexOf(e)>=0}var Cs=o6t;function Qn(){}Qn.objectLegacy=function(t,e){if(c(t)){for(let n in t)if(Object.prototype.hasOwnProperty.call(t,n)){let i=t[n],o=e(i,n);if(c(o))return o}}};Qn.object=function(t,e){if(c(t)){let n=t.length;for(let i=0;i0)return i.byteStride}return it.getSizeInBytes(e.componentType)*Ih(e.type)}var Qm=s6t;function l6t(t){ne.accessor(t,function(n){c(n.bufferView)&&(n.byteOffset=f(n.byteOffset,0))}),ne.bufferView(t,function(n){c(n.buffer)&&(n.byteOffset=f(n.byteOffset,0))}),ne.mesh(t,function(n){ne.meshPrimitive(n,function(i){if(i.mode=f(i.mode,pt.TRIANGLES),!c(i.material)){c(t.materials)||(t.materials=[]);let o={name:"default"};i.material=$l(t.materials,o)}})}),ne.accessorContainingVertexAttributeData(t,function(n){let i=t.accessors[n],o=i.bufferView;if(i.normalized=f(i.normalized,!1),c(o)){let a=t.bufferViews[o];a.byteStride=Qm(t,i),a.target=pt.ARRAY_BUFFER}}),ne.accessorContainingIndexData(t,function(n){let o=t.accessors[n].bufferView;if(c(o)){let a=t.bufferViews[o];a.target=pt.ELEMENT_ARRAY_BUFFER}}),ne.material(t,function(n){let i=f(n.extensions,f.EMPTY_OBJECT),o=i.KHR_materials_common;if(c(o)){let r=o.technique,d=c(o.values)?o.values:{};o.values=d,d.ambient=c(d.ambient)?d.ambient:[0,0,0,1],d.emission=c(d.emission)?d.emission:[0,0,0,1],d.transparency=f(d.transparency,1),r!=="CONSTANT"&&(d.diffuse=c(d.diffuse)?d.diffuse:[0,0,0,1],r!=="LAMBERT"&&(d.specular=c(d.specular)?d.specular:[0,0,0,1],d.shininess=f(d.shininess,0))),o.transparent=f(o.transparent,!1),o.doubleSided=f(o.doubleSided,!1);return}n.emissiveFactor=f(n.emissiveFactor,[0,0,0]),n.alphaMode=f(n.alphaMode,"OPAQUE"),n.doubleSided=f(n.doubleSided,!1),n.alphaMode==="MASK"&&(n.alphaCutoff=f(n.alphaCutoff,.5));let a=i.KHR_techniques_webgl;c(a)&&ne.materialValue(n,function(r){c(r.index)&&ZA(r)}),ZA(n.emissiveTexture),ZA(n.normalTexture),ZA(n.occlusionTexture);let s=n.pbrMetallicRoughness;c(s)&&(s.baseColorFactor=f(s.baseColorFactor,[1,1,1,1]),s.metallicFactor=f(s.metallicFactor,1),s.roughnessFactor=f(s.roughnessFactor,1),ZA(s.baseColorTexture),ZA(s.metallicRoughnessTexture));let l=i.KHR_materials_pbrSpecularGlossiness;c(l)&&(l.diffuseFactor=f(l.diffuseFactor,[1,1,1,1]),l.specularFactor=f(l.specularFactor,[1,1,1]),l.glossinessFactor=f(l.glossinessFactor,1),ZA(l.specularGlossinessTexture))}),ne.animation(t,function(n){ne.animationSampler(n,function(i){i.interpolation=f(i.interpolation,"LINEAR")})});let e=r6t(t);return ne.node(t,function(n,i){c(e[i])||c(n.translation)||c(n.rotation)||c(n.scale)?(n.translation=f(n.translation,[0,0,0]),n.rotation=f(n.rotation,[0,0,0,1]),n.scale=f(n.scale,[1,1,1])):n.matrix=f(n.matrix,[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])}),ne.sampler(t,function(n){n.wrapS=f(n.wrapS,pt.REPEAT),n.wrapT=f(n.wrapT,pt.REPEAT)}),c(t.scenes)&&!c(t.scene)&&(t.scene=0),t}function r6t(t){let e={};return ne.animation(t,function(n){ne.animationChannel(n,function(i){let o=i.target,a=o.node,s=o.path;(s==="translation"||s==="rotation"||s==="scale")&&(e[a]=!0)})}),e}function ZA(t){c(t)&&(t.texCoord=f(t.texCoord,0))}var _2=l6t;var x1n=b(W(),1);function d6t(t){return ne.shader(t,function(e){Aw(e)}),ne.buffer(t,function(e){Aw(e)}),ne.image(t,function(e){Aw(e)}),Aw(t),t}function Aw(t){t.extras=c(t.extras)?t.extras:{},t.extras._pipeline=c(t.extras._pipeline)?t.extras._pipeline:{}}var Jf=d6t;var $1n=b(W(),1);var O1n=b(W(),1);var L1n=b(W(),1);function c6t(t,e){let n=t.extensionsRequired;if(c(n)){let i=n.indexOf(e);i>=0&&n.splice(i,1),n.length===0&&delete t.extensionsRequired}}var D2=c6t;function m6t(t,e){let n=t.extensionsUsed;if(c(n)){let i=n.indexOf(e);i>=0&&n.splice(i,1),D2(t,e),n.length===0&&delete t.extensionsUsed}}var RA=m6t;var h6t=4;function p6t(t){if(mu(t)!=="glTF")throw new Tt("File is not valid binary glTF");let n=hRt(t,0,5),i=n[1];if(i!==1&&i!==2)throw new Tt("Binary glTF version is not 1 or 2");return i===1?V6t(t,n):u6t(t,n)}function hRt(t,e,n){let i=new DataView(t.buffer),o=new Array(n);for(let a=0;a0){let h=f(m.binary_glTF,m.KHR_binary_glTF);c(h)&&(h.extras._pipeline.source=d,delete h.uri)}return RA(r,"KHR_binary_glTF"),r}function u6t(t,e){let n=e[2],i=12,o,a;for(;i0){let l=s[0];l.extras._pipeline.source=a}}return o}var O2=p6t;var iNn=b(W(),1);function Z6t(t){return ne.shader(t,function(e){Sw(e)}),ne.buffer(t,function(e){Sw(e)}),ne.image(t,function(e){Sw(e)}),Sw(t),t}function Sw(t){c(t.extras)&&(c(t.extras._pipeline)&&delete t.extras._pipeline,Object.keys(t.extras).length===0&&delete t.extras)}var H2=Z6t;var Xyn=b(W(),1);var lNn=b(W(),1);function R6t(t,e){let n=t.extensionsUsed;c(n)||(n=[],t.extensionsUsed=n),$l(n,e,!0)}var Xp=R6t;var RNn=b(W(),1);var cNn=b(W(),1);function b6t(t){switch(t){case it.BYTE:return function(e,n,i,o,a){for(let s=0;s-1:!1}var U6t=[pt.ZERO,pt.ONE,pt.SRC_COLOR,pt.ONE_MINUS_SRC_COLOR,pt.SRC_ALPHA,pt.ONE_MINUS_SRC_ALPHA,pt.DST_ALPHA,pt.ONE_MINUS_DST_ALPHA,pt.DST_COLOR,pt.ONE_MINUS_DST_COLOR];function G6t(t,e){if(!c(t))return e;for(let n=0;n<4;n++)if(U6t.indexOf(t[n])===-1)return e;return t}function A6t(t){let e={},n={},i=t.techniques;return c(i)&&(ne.technique(t,function(o,a){let s=o.states;if(c(s)){let l=n[a]={};if(pRt(s,pt.BLEND)){l.alphaMode="BLEND";let r=s.functions;c(r)&&(c(r.blendEquationSeparate)||c(r.blendFuncSeparate))&&(e[a]={blendEquation:f(r.blendEquationSeparate,f6t),blendFactors:G6t(r.blendFuncSeparate,F6t)})}pRt(s,pt.CULL_FACE)||(l.doubleSided=!0),delete o.states}}),Object.keys(e).length>0&&(c(t.extensions)||(t.extensions={}),Xp(t,"KHR_blend")),ne.material(t,function(o){if(c(o.technique)){let a=n[o.technique];ne.objectLegacy(a,function(l,r){o[r]=l});let s=e[o.technique];c(s)&&(c(o.extensions)||(o.extensions={}),o.extensions.KHR_blend=s)}})),t}var w2=A6t;var YNn=b(W(),1);var CNn=b(W(),1);function S6t(t,e){let n=t.extensionsRequired;c(n)||(n=[],t.extensionsRequired=n),$l(n,e,!0),Xp(t,e)}var P2=S6t;function T6t(t){let e=t.techniques,n={},i={},o={};if(c(e)){let a={programs:[],shaders:[],techniques:[]},s=t.glExtensionsUsed;delete t.glExtensionsUsed,ne.technique(t,function(l,r){let d={name:l.name,program:void 0,attributes:{},uniforms:{}},m;if(ne.techniqueAttribute(l,function(h,u){m=l.parameters[h],d.attributes[u]={semantic:m.semantic}}),ne.techniqueUniform(l,function(h,u){m=l.parameters[h],d.uniforms[u]={count:m.count,node:m.node,type:m.type,semantic:m.semantic,value:m.value},c(n[r])||(n[r]={}),n[r][h]=u}),c(o[l.program]))d.program=o[l.program];else{let h=t.programs[l.program],u={name:h.name,fragmentShader:void 0,vertexShader:void 0,glExtensions:s},R=t.shaders[h.fragmentShader];u.fragmentShader=$l(a.shaders,R,!0);let V=t.shaders[h.vertexShader];u.vertexShader=$l(a.shaders,V,!0),d.program=$l(a.programs,u),o[l.program]=d.program}i[r]=$l(a.techniques,d)}),a.techniques.length>0&&(c(t.extensions)||(t.extensions={}),t.extensions.KHR_techniques_webgl=a,Xp(t,"KHR_techniques_webgl"),P2(t,"KHR_techniques_webgl"))}return ne.material(t,function(a){if(c(a.technique)){let s={technique:i[a.technique]};ne.objectLegacy(a.values,function(l,r){c(s.values)||(s.values={});let d=n[a.technique][r];c(d)&&(s.values[d]=l)}),c(a.extensions)||(a.extensions={}),a.extensions.KHR_techniques_webgl=s}delete a.technique,delete a.values}),delete t.techniques,delete t.programs,delete t.shaders,t}var v2=T6t;var vNn=b(W(),1);var MNn=b(W(),1);function g6t(t,e){Xa.typeOf.object("material",t),Xa.defined("handler",e);let n=t.pbrMetallicRoughness;if(c(n)){if(c(n.baseColorTexture)){let o=n.baseColorTexture,a=e(o.index,o);if(c(a))return a}if(c(n.metallicRoughnessTexture)){let o=n.metallicRoughnessTexture,a=e(o.index,o);if(c(a))return a}}if(c(t.extensions)){let o=t.extensions.KHR_materials_pbrSpecularGlossiness;if(c(o)){if(c(o.diffuseTexture)){let s=o.diffuseTexture,l=e(s.index,s);if(c(l))return l}if(c(o.specularGlossinessTexture)){let s=o.specularGlossinessTexture,l=e(s.index,s);if(c(l))return l}}let a=t.extensions.KHR_materials_common;if(c(a)&&c(a.values)){let s=a.values.diffuse,l=a.values.ambient,r=a.values.emission,d=a.values.specular;if(c(s)&&c(s.index)){let m=e(s.index,s);if(c(m))return m}if(c(l)&&c(l.index)){let m=e(l.index,l);if(c(m))return m}if(c(r)&&c(r.index)){let m=e(r.index,r);if(c(m))return m}if(c(d)&&c(d.index)){let m=e(d.index,d);if(c(m))return m}}}let i=ne.materialValue(t,function(o){if(c(o.index)){let a=e(o.index,o);if(c(a))return a}});if(c(i))return i;if(c(t.emissiveTexture)){let o=t.emissiveTexture,a=e(o.index,o);if(c(a))return a}if(c(t.normalTexture)){let o=t.normalTexture,a=e(o.index,o);if(c(a))return a}if(c(t.occlusionTexture)){let o=t.occlusionTexture,a=e(o.index,o);if(c(a))return a}}var XE=g6t;var VRt=["mesh","node","material","accessor","bufferView","buffer","texture","sampler","image"];function E6t(t,e){return e=f(e,VRt),VRt.forEach(function(n){e.indexOf(n)>-1&&I6t(t,n)}),t}var C6t={accessor:"accessors",buffer:"buffers",bufferView:"bufferViews",image:"images",node:"nodes",material:"materials",mesh:"meshes",sampler:"samplers",texture:"textures"};function I6t(t,e){let n=C6t[e],i=t[n];if(c(i)){let o=0,a=jZ[e](t),s=i.length;for(let l=0;le&&o.attributes[r]--}),ne.meshPrimitiveTarget(o,function(l){ne.meshPrimitiveTargetAttribute(l,function(r,d){r>e&&l[d]--})});let a=o.indices;c(a)&&a>e&&o.indices--;let s=o.extensions;c(s)&&c(s.CESIUM_primitive_outline)&&s.CESIUM_primitive_outline.indices>e&&--s.CESIUM_primitive_outline.indices})}),ne.skin(t,function(i){c(i.inverseBindMatrices)&&i.inverseBindMatrices>e&&i.inverseBindMatrices--}),ne.animation(t,function(i){ne.animationSampler(i,function(o){c(o.input)&&o.input>e&&o.input--,c(o.output)&&o.output>e&&o.output--})})};zZ.buffer=function(t,e){t.buffers.splice(e,1),ne.bufferView(t,function(i){c(i.buffer)&&i.buffer>e&&i.buffer--,c(i.extensions)&&c(i.extensions.EXT_meshopt_compression)&&i.extensions.EXT_meshopt_compression.buffer--})};zZ.bufferView=function(t,e){if(t.bufferViews.splice(e,1),ne.accessor(t,function(i){c(i.bufferView)&&i.bufferView>e&&i.bufferView--}),ne.shader(t,function(i){c(i.bufferView)&&i.bufferView>e&&i.bufferView--}),ne.image(t,function(i){c(i.bufferView)&&i.bufferView>e&&i.bufferView--}),Cs(t,"KHR_draco_mesh_compression")&&ne.mesh(t,function(i){ne.meshPrimitive(i,function(o){c(o.extensions)&&c(o.extensions.KHR_draco_mesh_compression)&&o.extensions.KHR_draco_mesh_compression.bufferView>e&&o.extensions.KHR_draco_mesh_compression.bufferView--})}),Cs(t,"EXT_feature_metadata")){let o=t.extensions.EXT_feature_metadata.featureTables;for(let a in o)if(o.hasOwnProperty(a)){let l=o[a].properties;if(c(l)){for(let r in l)if(l.hasOwnProperty(r)){let d=l[r];c(d.bufferView)&&d.bufferView>e&&d.bufferView--,c(d.arrayOffsetBufferView)&&d.arrayOffsetBufferView>e&&d.arrayOffsetBufferView--,c(d.stringOffsetBufferView)&&d.stringOffsetBufferView>e&&d.stringOffsetBufferView--}}}}if(Cs(t,"EXT_structural_metadata")){let o=t.extensions.EXT_structural_metadata.propertyTables;if(c(o)){let a=o.length;for(let s=0;se&&m.values--,c(m.arrayOffsets)&&m.arrayOffsets>e&&m.arrayOffsets--,c(m.stringOffsets)&&m.stringOffsets>e&&m.stringOffsets--}}}}};zZ.image=function(t,e){t.images.splice(e,1),ne.texture(t,function(i){c(i.source)&&i.source>e&&--i.source;let o=i.extensions;c(o)&&c(o.EXT_texture_webp)&&o.EXT_texture_webp.source>e?--i.extensions.EXT_texture_webp.source:c(o)&&c(o.KHR_texture_basisu)&&o.KHR_texture_basisu.source>e&&--i.extensions.KHR_texture_basisu.source})};zZ.mesh=function(t,e){t.meshes.splice(e,1),ne.node(t,function(i){c(i.mesh)&&(i.mesh>e?i.mesh--:i.mesh===e&&delete i.mesh)})};zZ.node=function(t,e){t.nodes.splice(e,1),ne.skin(t,function(i){c(i.skeleton)&&i.skeleton>e&&i.skeleton--,i.joints=i.joints.map(function(o){return o>e?o-1:o})}),ne.animation(t,function(i){ne.animationChannel(i,function(o){c(o.target)&&c(o.target.node)&&o.target.node>e&&o.target.node--})}),ne.technique(t,function(i){ne.techniqueUniform(i,function(o){c(o.node)&&o.node>e&&o.node--})}),ne.node(t,function(i){c(i.children)&&(i.children=i.children.filter(function(o){return o!==e}).map(function(o){return o>e?o-1:o}))}),ne.scene(t,function(i){i.nodes=i.nodes.filter(function(o){return o!==e}).map(function(o){return o>e?o-1:o})})};zZ.material=function(t,e){t.materials.splice(e,1),ne.mesh(t,function(i){ne.meshPrimitive(i,function(o){c(o.material)&&o.material>e&&o.material--})})};zZ.sampler=function(t,e){t.samplers.splice(e,1),ne.texture(t,function(i){c(i.sampler)&&i.sampler>e&&--i.sampler})};zZ.texture=function(t,e){if(t.textures.splice(e,1),ne.material(t,function(i){XE(i,function(o,a){a.index>e&&--a.index})}),Cs(t,"EXT_feature_metadata")){ne.mesh(t,function(a){ne.meshPrimitive(a,function(s){let l=s.extensions;if(c(l)&&c(l.EXT_feature_metadata)){let d=l.EXT_feature_metadata.featureIdTextures;if(c(d)){let m=d.length;for(let h=0;he&&--R.index}}}})});let o=t.extensions.EXT_feature_metadata.featureTextures;for(let a in o)if(o.hasOwnProperty(a)){let l=o[a].properties;if(c(l)){for(let r in l)if(l.hasOwnProperty(r)){let m=l[r].texture;m.index>e&&--m.index}}}}if(Cs(t,"EXT_mesh_features")&&ne.mesh(t,function(i){ne.meshPrimitive(i,function(o){let a=o.extensions;if(c(a)&&c(a.EXT_mesh_features)){let l=a.EXT_mesh_features.featureIds;if(c(l)){let r=l.length;for(let d=0;de&&--m.texture.index}}}})}),Cs(t,"EXT_structural_metadata")){let o=t.extensions.EXT_structural_metadata.propertyTextures;if(c(o)){let a=o.length;for(let s=0;se&&--m.index}}}}};function jZ(){}jZ.accessor=function(t){let e={};return ne.mesh(t,function(n){ne.meshPrimitive(n,function(i){ne.meshPrimitiveAttribute(i,function(a){e[a]=!0}),ne.meshPrimitiveTarget(i,function(a){ne.meshPrimitiveTargetAttribute(a,function(s){e[s]=!0})});let o=i.indices;c(o)&&(e[o]=!0)})}),ne.skin(t,function(n){c(n.inverseBindMatrices)&&(e[n.inverseBindMatrices]=!0)}),ne.animation(t,function(n){ne.animationSampler(n,function(i){c(i.input)&&(e[i.input]=!0),c(i.output)&&(e[i.output]=!0)})}),Cs(t,"EXT_mesh_gpu_instancing")&&ne.node(t,function(n){c(n.extensions)&&c(n.extensions.EXT_mesh_gpu_instancing)&&Object.keys(n.extensions.EXT_mesh_gpu_instancing.attributes).forEach(function(i){let o=n.extensions.EXT_mesh_gpu_instancing.attributes[i];e[o]=!0})}),Cs(t,"CESIUM_primitive_outline")&&ne.mesh(t,function(n){ne.meshPrimitive(n,function(i){let o=i.extensions;if(c(o)&&c(o.CESIUM_primitive_outline)){let s=o.CESIUM_primitive_outline.indices;c(s)&&(e[s]=!0)}})}),e};jZ.buffer=function(t){let e={};return ne.bufferView(t,function(n){c(n.buffer)&&(e[n.buffer]=!0),c(n.extensions)&&c(n.extensions.EXT_meshopt_compression)&&(e[n.extensions.EXT_meshopt_compression.buffer]=!0)}),e};jZ.bufferView=function(t){let e={};if(ne.accessor(t,function(n){c(n.bufferView)&&(e[n.bufferView]=!0)}),ne.shader(t,function(n){c(n.bufferView)&&(e[n.bufferView]=!0)}),ne.image(t,function(n){c(n.bufferView)&&(e[n.bufferView]=!0)}),Cs(t,"KHR_draco_mesh_compression")&&ne.mesh(t,function(n){ne.meshPrimitive(n,function(i){c(i.extensions)&&c(i.extensions.KHR_draco_mesh_compression)&&(e[i.extensions.KHR_draco_mesh_compression.bufferView]=!0)})}),Cs(t,"EXT_feature_metadata")){let i=t.extensions.EXT_feature_metadata.featureTables;for(let o in i)if(i.hasOwnProperty(o)){let s=i[o].properties;if(c(s)){for(let l in s)if(s.hasOwnProperty(l)){let r=s[l];c(r.bufferView)&&(e[r.bufferView]=!0),c(r.arrayOffsetBufferView)&&(e[r.arrayOffsetBufferView]=!0),c(r.stringOffsetBufferView)&&(e[r.stringOffsetBufferView]=!0)}}}}if(Cs(t,"EXT_structural_metadata")){let i=t.extensions.EXT_structural_metadata.propertyTables;if(c(i)){let o=i.length;for(let a=0;a0&&(e[n.mesh]=!0)}}),e};function uRt(t,e,n){let i=t.nodes[e];return c(i.mesh)||c(i.camera)||c(i.skin)||c(i.weights)||c(i.extras)||c(i.extensions)&&Object.keys(i.extensions).length!==0||c(n[e])?!1:!c(i.children)||i.children.filter(function(o){return!uRt(t,o,n)}).length===0}jZ.node=function(t){let e={};return ne.skin(t,function(n){c(n.skeleton)&&(e[n.skeleton]=!0),ne.skinJoint(n,function(i){e[i]=!0})}),ne.animation(t,function(n){ne.animationChannel(n,function(i){c(i.target)&&c(i.target.node)&&(e[i.target.node]=!0)})}),ne.technique(t,function(n){ne.techniqueUniform(n,function(i){c(i.node)&&(e[i.node]=!0)})}),ne.node(t,function(n,i){uRt(t,i,e)||(e[i]=!0)}),e};jZ.material=function(t){let e={};return ne.mesh(t,function(n){ne.meshPrimitive(n,function(i){c(i.material)&&(e[i.material]=!0)})}),e};jZ.texture=function(t){let e={};if(ne.material(t,function(n){XE(n,function(i){e[i]=!0})}),Cs(t,"EXT_feature_metadata")){ne.mesh(t,function(o){ne.meshPrimitive(o,function(a){let s=a.extensions;if(c(s)&&c(s.EXT_feature_metadata)){let r=s.EXT_feature_metadata.featureIdTextures;if(c(r)){let d=r.length;for(let m=0;m0)for(s.mesh=n.meshes[r[0]],e=1;e0&&c(s.skin)){let m=t.skins[s.skin];m.skeleton=n.nodes[r[0]]}delete s.skeletons}c(s.jointName)&&delete s.jointName}),ne.skin(t,function(s){c(s.inverseBindMatrices)&&(s.inverseBindMatrices=n.accessors[s.inverseBindMatrices]);let l=s.jointNames;if(c(l)){let r=[],d=l.length;for(e=0;e=0&&(l=a.substring(0,s),r=a.substring(s));let d,m=$6t[l];c(m)?(d=m+r,e[a]=d):c(q6t[l])||(d=`_${a}`,e[a]=d)}});for(let o in e)if(Object.prototype.hasOwnProperty.call(e,o)){let a=e[o],s=i.attributes[o];c(s)&&(delete i.attributes[o],i.attributes[a]=s)}})}),ne.technique(t,function(n){ne.techniqueParameter(n,function(i){let o=e[i.semantic];c(o)&&(i.semantic=o)})})}function e7t(t){ne.camera(t,function(e){let n=e.perspective;if(c(n)){let i=n.aspectRatio;c(i)&&i===0&&delete n.aspectRatio;let o=n.yfov;c(o)&&o===0&&(n.yfov=1)}})}function wq(t,e){return c(e.byteStride)&&e.byteStride!==0?e.byteStride:Qm(t,e)}function n7t(t){ne.buffer(t,function(e){c(e.byteLength)||(e.byteLength=e.extras._pipeline.source.length)}),ne.accessor(t,function(e){let n=e.bufferView;if(c(n)){let i=t.bufferViews[n],o=wq(t,e),a=e.byteOffset+e.count*o;i.byteLength=Math.max(f(i.byteLength,0),a)}})}function i7t(t){let e,n,i,o=t.bufferViews,a={};ne.accessorContainingVertexAttributeData(t,function(l){let r=t.accessors[l];c(r.bufferView)&&(a[r.bufferView]=!0)});let s={};ne.accessor(t,function(l){c(l.bufferView)&&(s[l.bufferView]=f(s[l.bufferView],[]),s[l.bufferView].push(l))});for(let l in s)if(Object.prototype.hasOwnProperty.call(s,l)){i=o[l];let r=s[l];r.sort(function(u,R){return u.byteOffset-R.byteOffset});let d=0,m=0,h=r.length;for(e=0;e=0;--a)if(i[a]===e){i.splice(a,1);return}}}),ne.node(t,function(n,i){if(c(n.children)){let o=n.children.indexOf(e);o>-1&&(n.children.splice(o,1),WRt(n)&&fRt(t,i))}}),delete t.nodes[e]}function a7t(t){return ne.node(t,function(e,n){WRt(e)&&fRt(t,n)}),t}function s7t(t){ne.animation(t,function(e){ne.animationSampler(e,function(n){let i=t.accessors[n.input];if(!c(i.min)||!c(i.max)){let o=bA(t,i);i.min=o.min,i.max=o.max}})})}function l7t(t){ne.accessor(t,function(e){if(c(e.min)||c(e.max)){let n=bA(t,e);c(e.min)&&(e.min=n.min),c(e.max)&&(e.max=n.max)}})}function r7t(t){t.asset=f(t.asset,{}),t.asset.version="2.0",bRt(t),_6t(t),a7t(t),D6t(t),O6t(t),w6t(t),v6t(t),n7t(t),i7t(t),o7t(t),s7t(t),l7t(t),K6t(t),z6t(t),j6t(t),t7t(t),q2(t),e7t(t),w2(t),v2(t),H6t(t)}var d7t=["u_tex","u_diffuse","u_emission","u_diffuse_tex"],c7t=["u_diffuse","u_diffuse_mat"];function Pq(t){t.pbrMetallicRoughness=c(t.pbrMetallicRoughness)?t.pbrMetallicRoughness:{},t.pbrMetallicRoughness.roughnessFactor=1,t.pbrMetallicRoughness.metallicFactor=0}function vq(t){return c(t.index)}function Kq(t){return Array.isArray(t)&&t.length===4}function FRt(t){let e=new Array(4);e[3]=t[3];for(let n=0;n<3;n++){let i=t[n];i<=.04045?e[n]=t[n]*.07739938080495357:e[n]=Math.pow((i+.055)*.9478672985781991,2.4)}return e}function m7t(t,e){e=f(e,f.EMPTY_OBJECT);let n=f(e.baseColorTextureNames,d7t),i=f(e.baseColorFactorNames,c7t);ne.material(t,function(o){ne.materialValue(o,function(a,s){n.indexOf(s)!==-1&&vq(a)?(Pq(o),o.pbrMetallicRoughness.baseColorTexture=a):i.indexOf(s)!==-1&&Kq(a)&&(Pq(o),o.pbrMetallicRoughness.baseColorFactor=FRt(a))})}),WA(t,"KHR_techniques_webgl"),WA(t,"KHR_blend")}function Hq(t,e){c(e)&&(Kq(e)?t.pbrMetallicRoughness.baseColorFactor=FRt(e):vq(e)&&(t.pbrMetallicRoughness.baseColorTexture=e))}function RRt(t,e){c(e)&&(Kq(e)?t.emissiveFactor=e.slice(0,3):vq(e)&&(t.emissiveTexture=e))}function h7t(t){ne.material(t,function(e){let n=f(e.extensions,f.EMPTY_OBJECT).KHR_materials_common;if(!c(n))return;let i=f(n.values,{}),o=i.ambient,a=i.diffuse,s=i.emission,l=i.transparency,r=n.doubleSided,d=n.transparent;Pq(e),n.technique==="CONSTANT"?(Xp(t,"KHR_materials_unlit"),e.extensions=c(e.extensions)?e.extensions:{},e.extensions.KHR_materials_unlit={},Hq(e,s),Hq(e,o)):(Hq(e,a),RRt(e,o),RRt(e,s)),c(r)&&(e.doubleSided=r),c(l)&&(c(e.pbrMetallicRoughness.baseColorFactor)?e.pbrMetallicRoughness.baseColorFactor[3]*=l:e.pbrMetallicRoughness.baseColorFactor=[1,1,1,l]),c(d)&&(e.alphaMode=d?"BLEND":"OPAQUE")}),WA(t,"KHR_materials_common")}var $2=Y6t;var tBn=b(W(),1);var Myn=b(W(),1);var mo={POSITION:"POSITION",NORMAL:"NORMAL",TANGENT:"TANGENT",TEXCOORD:"TEXCOORD",COLOR:"COLOR",JOINTS:"JOINTS",WEIGHTS:"WEIGHTS",FEATURE_ID:"_FEATURE_ID"};function p7t(t){switch(t){case mo.POSITION:return"positionMC";case mo.NORMAL:return"normalMC";case mo.TANGENT:return"tangentMC";case mo.TEXCOORD:return"texCoord";case mo.COLOR:return"color";case mo.JOINTS:return"joints";case mo.WEIGHTS:return"weights";case mo.FEATURE_ID:return"featureId"}}mo.hasSetIndex=function(t){switch(t){case mo.POSITION:case mo.NORMAL:case mo.TANGENT:return!1;case mo.TEXCOORD:case mo.COLOR:case mo.JOINTS:case mo.WEIGHTS:case mo.FEATURE_ID:return!0}};mo.fromGltfSemantic=function(t){let e=t,i=/^(\w+)_\d+$/.exec(t);switch(i!==null&&(e=i[1]),e){case"POSITION":return mo.POSITION;case"NORMAL":return mo.NORMAL;case"TANGENT":return mo.TANGENT;case"TEXCOORD":return mo.TEXCOORD;case"COLOR":return mo.COLOR;case"JOINTS":return mo.JOINTS;case"WEIGHTS":return mo.WEIGHTS;case"_FEATURE_ID":return mo.FEATURE_ID}};mo.fromPntsSemantic=function(t){switch(t){case"POSITION":case"POSITION_QUANTIZED":return mo.POSITION;case"RGBA":case"RGB":case"RGB565":return mo.COLOR;case"NORMAL":case"NORMAL_OCT16P":return mo.NORMAL;case"BATCH_ID":return mo.FEATURE_ID}};mo.getGlslType=function(t){switch(t){case mo.POSITION:case mo.NORMAL:case mo.TANGENT:return"vec3";case mo.TEXCOORD:return"vec2";case mo.COLOR:return"vec4";case mo.JOINTS:return"ivec4";case mo.WEIGHTS:return"vec4";case mo.FEATURE_ID:return"int"}};mo.getVariableName=function(t,e){let n=p7t(t);return c(e)&&(n+=`_${e}`),n};var sn=Object.freeze(mo);function wd(){}wd.getError=function(t,e,n){let i=`Failed to load ${t}: ${e}`;c(n)&&c(n.message)&&(i+=` +${n.message}`);let o=new Tt(i);return c(n)&&(o.stack=`Original stack: ${n.stack} Handler stack: -${o.stack}`),o};wd.getNodeTransform=function(t){return c(t.matrix)?t.matrix:L.fromTranslationQuaternionRotationScale(c(t.translation)?t.translation:p.ZERO,c(t.rotation)?t.rotation:wt.IDENTITY,c(t.scale)?t.scale:p.ONE)};wd.getAttributeBySemantic=function(t,e,n){let i=t.attributes,o=i.length;for(let a=0;a>e};Or.fromSubtreeJson=async function(t,e,n,i,o){let a=new Or(t,i,o),s;c(e)?s={json:e,binary:void 0}:s=iqt(n);let l=s.json;a._subtreeJson=l;let r;if(co(l,"3DTILES_metadata"))r=l.extensions["3DTILES_metadata"];else if(c(l.tileMetadata)){let A=l.tileMetadata;r=l.propertyTables[A]}let d=[];if(c(l.contentMetadata)){let A=l.contentMetadata.length;for(let T=0;T0;m=m||h;for(let Z=0;Z>BigInt(61)),d=r%2===0?IE.encode2D(i,o,a):IE.encode2D(i,a,o),m=KR.fromFacePositionLevel(r,BigInt(d),i),h,Z;if(c(s)){let b=(l.maximumHeight+l.minimumHeight)/2;h=n<4?l.minimumHeight:b,Z=n<4?b:l.maximumHeight}else h=l.minimumHeight,Z=l.maximumHeight;return{extensions:{"3DTILES_bounding_volume_S2":{token:KR.getTokenFromId(m._cellId),minimumHeight:h,maximumHeight:Z}}}}var Tqt=new p,Sqt=new p,i$=new p,gqt=new ot;function Ybt(t,e,n,i,o){if(e===0)return t;let a=p.unpack(t,0,Sqt),s=ot.unpack(t,3,gqt),l=Math.pow(2,-e),r=-1+(2*n+1)*l,d=-1+(2*i+1)*l,m=0,h=p.fromElements(l,l,1,Tqt);c(o)&&(m=-1+(2*o+1)*l,h.z=l);let Z=p.fromElements(r,d,m,i$);Z=ot.multiplyByVector(s,Z,i$),Z=p.add(Z,a,i$);let b=ot.clone(s);b=ot.multiplyByScale(b,h,b);let u=new Array(12);return p.pack(Z,u),ot.pack(b,u,3),u}var Eqt=new Gt;function xbt(t,e,n,i,o){if(e===0)return t.slice();let a=Gt.unpack(t,0,Eqt),s=t[4],l=t[5],r=Math.pow(2,-e),d=r*a.width,m=k.negativePiToPi(a.west+n*d),h=k.negativePiToPi(m+d),Z=r*a.height,b=k.negativePiToPi(a.south+i*Z),u=k.negativePiToPi(b+Z),F=s,U=l;if(c(o)){let G=r*(l-s);F+=o*G,U=F+G}return[m,b,h,u,F,U]}function Cqt(t,e,n){let i=t._implicitTileset,o=e.implicitCoordinates.getChildCoordinates(n),a=Qbt(i,o,n,!1,e),s=Bbt(void 0,i,o),l=i.subtreeUriTemplate.getDerivedResource({templateValues:o.getTemplateValues()}).url,r={boundingVolume:a,geometricError:s,refine:i.refine,contents:[{uri:l}]},d=Xbt(t,i.baseResource,r,e);return d.implicitTileset=i,d.implicitCoordinates=o,d}function Xbt(t,e,n,i){let o=t._tile.constructor;return new o(t._tileset,e,n,i)}xc.prototype.hasProperty=function(t,e){return!1};xc.prototype.getFeature=function(t){};xc.prototype.applyDebugSettings=function(t,e){};xc.prototype.applyStyle=function(t){};xc.prototype.update=function(t,e){};xc.prototype.pick=function(t,e,n){};xc.prototype.isDestroyed=function(){return!1};xc.prototype.destroy=function(){return this._implicitSubtree=this._implicitSubtree&&this._implicitSubtree.destroy(),At(this)};xc._deriveBoundingBox=Ybt;xc._deriveBoundingRegion=xbt;xc._deriveBoundingVolumeS2=kbt;var DE=xc;var u8n=R(W(),1);var q2n=R(W(),1),Iqt={NONE:0,REPEAT:1,MIRRORED_REPEAT:2},xm=Object.freeze(Iqt);var o8n=R(W(),1);var Ukn=R(W(),1);var nkn=R(W(),1);function OE(t,e){this._distance=e,this._normal=new Jbt(t,this),this.onChangeCallback=void 0,this.index=-1}Object.defineProperties(OE.prototype,{distance:{get:function(){return this._distance},set:function(t){c(this.onChangeCallback)&&t!==this._distance&&this.onChangeCallback(this.index),this._distance=t}},normal:{get:function(){return this._normal},set:function(t){c(this.onChangeCallback)&&!p.equals(this._normal._cartesian3,t)&&this.onChangeCallback(this.index),p.clone(t,this._normal._cartesian3)}}});OE.fromPlane=function(t,e){return c(e)?(e.normal=t.normal,e.distance=t.distance):e=new OE(t.normal,t.distance),e};OE.clone=function(t,e){return c(e)?(e.normal=t.normal,e.distance=t.distance,e):new OE(t.normal,t.distance)};function Jbt(t,e){this._clippingPlane=e,this._cartesian3=p.clone(t)}Object.defineProperties(Jbt.prototype,{x:{get:function(){return this._cartesian3.x},set:function(t){c(this._clippingPlane.onChangeCallback)&&t!==this._cartesian3.x&&this._clippingPlane.onChangeCallback(this._clippingPlane.index),this._cartesian3.x=t}},y:{get:function(){return this._cartesian3.y},set:function(t){c(this._clippingPlane.onChangeCallback)&&t!==this._cartesian3.y&&this._clippingPlane.onChangeCallback(this._clippingPlane.index),this._cartesian3.y=t}},z:{get:function(){return this._cartesian3.z},set:function(t){c(this._clippingPlane.onChangeCallback)&&t!==this._cartesian3.z&&this._clippingPlane.onChangeCallback(this._clippingPlane.index),this._cartesian3.z=t}}});var TA=OE;function Pd(t){t=f(t,f.EMPTY_OBJECT),this._planes=[],this._dirtyIndex=-1,this._multipleDirtyPlanes=!1,this._enabled=f(t.enabled,!0),this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this.edgeColor=v.clone(f(t.edgeColor,v.WHITE)),this.edgeWidth=f(t.edgeWidth,0),this.planeAdded=new It,this.planeRemoved=new It,this._owner=void 0;let e=f(t.unionClippingRegions,!1);this._unionClippingRegions=e,this._testIntersection=e?Obt:Hbt,this._uint8View=void 0,this._float32View=void 0,this._clippingPlanesTexture=void 0;let n=t.planes;if(c(n)){let i=n.length;for(let o=0;o0&&(a=yn.OUTSIDE);for(let s=0;s0?ws.COUNTER_CLOCKWISE:ws.CLOCKWISE};Hf.triangulate=function(t,e){let n=K.packArray(t);return(0,nRt.default)(n,e,2)};var iRt=new p,oRt=new p,aRt=new p,$bt=new p,tRt=new p,eRt=new p,n0=new p,sRt=new K,lRt=new K,rRt=new K,wE=new K;Hf.computeSubdivision=function(t,e,n,i,o){o=f(o,k.RADIANS_PER_DEGREE);let a=c(i),s=n.slice(0),l,r=e.length,d=new Array(r*3),m=new Array(r*2),h=0,Z=0;for(l=0;l0;){let T=s.pop(),g=s.pop(),C=s.pop(),y=p.fromArray(d,C*3,iRt),Y=p.fromArray(d,g*3,oRt),Q=p.fromArray(d,T*3,aRt),J,M,V;a&&(J=K.fromArray(m,C*2,sRt),M=K.fromArray(m,g*2,lRt),V=K.fromArray(m,T*2,rRt));let E=p.multiplyByScalar(p.normalize(y,$bt),F,$bt),I=p.multiplyByScalar(p.normalize(Y,tRt),F,tRt),B=p.multiplyByScalar(p.normalize(Q,eRt),F,eRt),X=p.magnitudeSquared(p.subtract(E,I,n0)),_=p.magnitudeSquared(p.subtract(I,B,n0)),P=p.magnitudeSquared(p.subtract(B,E,n0)),w=Math.max(X,_,P),z,H,nt;w>G?X===w?(z=`${Math.min(C,g)} ${Math.max(C,g)}`,l=u[z],c(l)||(H=p.add(y,Y,n0),p.multiplyByScalar(H,.5,H),d.push(H.x,H.y,H.z),l=d.length/3-1,u[z]=l,a&&(nt=K.add(J,M,wE),K.multiplyByScalar(nt,.5,nt),m.push(nt.x,nt.y))),s.push(C,l,T),s.push(l,g,T)):_===w?(z=`${Math.min(g,T)} ${Math.max(g,T)}`,l=u[z],c(l)||(H=p.add(Y,Q,n0),p.multiplyByScalar(H,.5,H),d.push(H.x,H.y,H.z),l=d.length/3-1,u[z]=l,a&&(nt=K.add(M,V,wE),K.multiplyByScalar(nt,.5,nt),m.push(nt.x,nt.y))),s.push(g,l,C),s.push(l,T,C)):P===w&&(z=`${Math.min(T,C)} ${Math.max(T,C)}`,l=u[z],c(l)||(H=p.add(Q,y,n0),p.multiplyByScalar(H,.5,H),d.push(H.x,H.y,H.z),l=d.length/3-1,u[z]=l,a&&(nt=K.add(V,J,wE),K.multiplyByScalar(nt,.5,nt),m.push(nt.x,nt.y))),s.push(T,l,g),s.push(l,C,g)):(b.push(C),b.push(g),b.push(T))}let A={attributes:{position:new jt({componentDatatype:it.DOUBLE,componentsPerAttribute:3,values:d})},indices:b,primitiveType:le.TRIANGLES};return a&&(A.attributes.st=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:m})),new _e(A)};var qqt=new gt,$qt=new gt,t$t=new gt,d$=new gt;Hf.computeRhumbLineSubdivision=function(t,e,n,i,o){o=f(o,k.RADIANS_PER_DEGREE);let a=c(i),s=n.slice(0),l,r=e.length,d=new Array(r*3),m=new Array(r*2),h=0,Z=0;for(l=0;l0;){let C=s.pop(),y=s.pop(),Y=s.pop(),Q=p.fromArray(d,Y*3,iRt),J=p.fromArray(d,y*3,oRt),M=p.fromArray(d,C*3,aRt),V,E,I;a&&(V=K.fromArray(m,Y*2,sRt),E=K.fromArray(m,y*2,lRt),I=K.fromArray(m,C*2,rRt));let B=t.cartesianToCartographic(Q,qqt),X=t.cartesianToCartographic(J,$qt),_=t.cartesianToCartographic(M,t$t);G.setEndPoints(B,X);let P=G.surfaceDistance;A.setEndPoints(X,_);let w=A.surfaceDistance;T.setEndPoints(_,B);let z=T.surfaceDistance,H=Math.max(P,w,z),nt,$,dt,q,at;H>U?P===H?(nt=`${Math.min(Y,y)} ${Math.max(Y,y)}`,l=u[nt],c(l)||($=G.interpolateUsingFraction(.5,d$),dt=(B.height+X.height)*.5,q=p.fromRadians($.longitude,$.latitude,dt,t,n0),d.push(q.x,q.y,q.z),l=d.length/3-1,u[nt]=l,a&&(at=K.add(V,E,wE),K.multiplyByScalar(at,.5,at),m.push(at.x,at.y))),s.push(Y,l,C),s.push(l,y,C)):w===H?(nt=`${Math.min(y,C)} ${Math.max(y,C)}`,l=u[nt],c(l)||($=A.interpolateUsingFraction(.5,d$),dt=(X.height+_.height)*.5,q=p.fromRadians($.longitude,$.latitude,dt,t,n0),d.push(q.x,q.y,q.z),l=d.length/3-1,u[nt]=l,a&&(at=K.add(E,I,wE),K.multiplyByScalar(at,.5,at),m.push(at.x,at.y))),s.push(y,l,Y),s.push(l,C,Y)):z===H&&(nt=`${Math.min(C,Y)} ${Math.max(C,Y)}`,l=u[nt],c(l)||($=T.interpolateUsingFraction(.5,d$),dt=(_.height+B.height)*.5,q=p.fromRadians($.longitude,$.latitude,dt,t,n0),d.push(q.x,q.y,q.z),l=d.length/3-1,u[nt]=l,a&&(at=K.add(I,V,wE),K.multiplyByScalar(at,.5,at),m.push(at.x,at.y))),s.push(C,l,y),s.push(l,Y,y)):(b.push(Y),b.push(y),b.push(C))}let g={attributes:{position:new jt({componentDatatype:it.DOUBLE,componentsPerAttribute:3,values:d})},indices:b,primitiveType:le.TRIANGLES};return a&&(g.attributes.st=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:m})),new _e(g)};Hf.scaleToGeodeticHeight=function(t,e,n,i){n=f(n,mt.WGS84);let o=zqt,a=jqt;if(e=f(e,0),i=f(i,!0),c(t)){let s=t.length;for(let l=0;l10&&e*2>t.length&&(this._array=t.slice(e),e=0),this._offset=e,this._length--,n};wf.prototype.peek=function(){if(this._length!==0)return this._array[this._offset]};wf.prototype.contains=function(t){return this._array.indexOf(t)!==-1};wf.prototype.clear=function(){this._array.length=this._offset=this._length=0};wf.prototype.sort=function(t){this._offset>0&&(this._array=this._array.slice(this._offset),this._offset=0),this._array.sort(t)};var $V=wf;var Ws={};Ws.computeHierarchyPackedLength=function(t,e){let n=0,i=[t];for(;i.length>0;){let o=i.pop();if(!c(o))continue;n+=2;let a=o.positions,s=o.holes;if(c(a)&&a.length>0&&(n+=a.length*e.packedLength),c(s)){let l=s.length;for(let r=0;r0;){let a=o.pop();if(!c(a))continue;let s=a.positions,l=a.holes;if(e[n++]=c(s)?s.length:0,e[n++]=c(l)?l.length:0,c(s)){let r=s.length;for(let d=0;d0?new Array(o):void 0;for(let l=0;lk.PI){let r=s;s=l,l=r}if(!(a.longitudel))return n.cartographicToCartesian(a)}function c$t(t,e,n,i){if(i===Ln.RHUMB)return d$t(t,e,n);let o=no.lineSegmentPlane(t,e,Kn.ORIGIN_XY_PLANE);if(c(o))return n.scaleToGeodeticSurface(o,o)}var m$t=new gt;function h$t(t,e,n){let i=[],o,a,s,l,r,d=0;for(;de.cartesianToCartographic(h,m$t).longitude;if(s===0)i.push({position:d,type:s,visited:!1,next:l,theta:m(o)});else if(l!==0){if(r=c$t(o,a,e,n),++d,!c(r))continue;t.splice(d,0,r),i.push({position:d,type:s,visited:!1,next:l,theta:m(r)})}++d}return i}function hRt(t,e,n,i,o,a,s){let l=[],r=a,d=h=>Z=>Z.position===h,m=[];do{let h=n[r];l.push(h);let Z=i.findIndex(d(r)),b=i[Z];if(!c(b)){++r;continue}let{visited:u,type:F,next:U}=b;if(b.visited=!0,F===0){if(U===0){let g=i[Z-(s?1:-1)];if(g?.position===r+1)g.visited=!0;else{++r;continue}}if(!u&&s&&U>0||a===r&&!s&&U<0){++r;continue}}if(!(s?F>=0:F<=0)){++r;continue}u||m.push(r);let A=Z+(s?1:-1),T=i[A];if(!c(T)){++r;continue}r=T.position}while(r=0&&r!==a&&l.lengthd.theta-m.theta);let r=s[0].z>=0;o=hRt(i,o,s,l,1,0,r)}return i};Ws.polygonsFromHierarchy=function(t,e,n,i,o,a){let s=[],l=[],r=new $V;r.enqueue(t);let d=c(a);for(;r.length!==0;){let m=r.dequeue(),h=m.positions,Z=m.holes,b,u;if(i)for(u=h.length,b=0;b1){for(let Y of y)r.enqueue(new Wr(Y,Z));continue}}let A=h.slice(),T=c(Z)?Z.length:0,g=[],C;for(b=0;bMath.PI&&(t-=k.TWO_PI),t}}});var PE=new gt,W$t=new p;al.prototype.getLatitude=function(t){c(t)||(t=mt.WGS84),PE.latitude=this.conformalLatitude,PE.longitude=this.longitude,PE.height=0;let e=this.ellipsoid.cartographicToCartesian(PE,W$t);return t.cartesianToCartographic(e,PE),PE.latitude};var f$t=new di,F$t=new p,U$t=new p;al.fromCartesian=function(t,e){let n=k.signNotZero(t.z),i=al.NORTH_POLE_TANGENT_PLANE,o=al.SOUTH_POLE;n<0&&(i=al.SOUTH_POLE_TANGENT_PLANE,o=al.NORTH_POLE);let a=f$t;a.origin=i.ellipsoid.scaleToGeocentricSurface(t,a.origin),a.direction=p.subtract(a.origin,o,F$t),p.normalize(a.direction,a.direction);let s=no.rayPlane(a,i.plane,U$t),l=p.subtract(s,o,s),r=p.dot(i.xAxis,l),d=n*p.dot(i.yAxis,l);return c(e)?(e.position=new K(r,d),e.tangentPlane=i,e):new al(new K(r,d),i)};al.fromCartesianArray=function(t,e){let n=t.length;c(e)?e.length=n:e=new Array(n);for(let i=0;i=0?s:s+k.TWO_PI;o.westOverIdl=Math.min(o.westOverIdl,l),o.eastOverIdl=Math.max(o.eastOverIdl,l),a.west=Math.min(a.west,s),a.east=Math.max(a.east,s);let r=t.getLatitude(n),d=r;if(a.south=Math.min(a.south,r),a.north=Math.max(a.north,r),i!==Ln.RHUMB){let Z=K.subtract(e.position,t.position,L$t),b=K.dot(e.position,Z)/K.dot(Z,Z);if(b>0&&b<1){let u=K.add(e.position,K.multiplyByScalar(Z,-b,Z),M$t),F=vd.clone(e,_$t);F.position=u;let U=F.getLatitude(n);a.south=Math.min(a.south,U),a.north=Math.max(a.north,U),Math.abs(r)>Math.abs(U)&&(d=U)}}let m=e.x*t.y-t.x*e.y,h=Math.sign(m);h!==0&&(h*=K.angleBetween(e.position,t.position)),d>=0&&(o.northAngle+=h),d<=0&&(o.southAngle+=h)}var RRt=new vd,D$t=new vd,Jp={northAngle:0,southAngle:0,westOverIdl:0,eastOverIdl:0};Lp.computeRectangleFromPositions=function(t,e,n,i){if(c(i)||(i=new Gt),t.length<3)return i;i.west=Number.POSITIVE_INFINITY,i.east=Number.NEGATIVE_INFINITY,i.south=Number.POSITIVE_INFINITY,i.north=Number.NEGATIVE_INFINITY,Jp.northAngle=0,Jp.southAngle=0,Jp.westOverIdl=Number.POSITIVE_INFINITY,Jp.eastOverIdl=Number.NEGATIVE_INFINITY;let o=t.length,a=vd.fromCartesian(t[0],D$t);for(let s=1;sJp.eastOverIdl-Jp.westOverIdl&&(i.west=Jp.westOverIdl,i.east=Jp.eastOverIdl,i.east>k.PI&&(i.east=i.east-k.TWO_PI),i.west>k.PI&&(i.west=i.west-k.TWO_PI)),k.equalsEpsilon(Math.abs(Jp.northAngle),k.TWO_PI,k.EPSILON10)&&(i.north=k.PI_OVER_TWO,i.east=k.PI,i.west=-k.PI),k.equalsEpsilon(Math.abs(Jp.southAngle),k.TWO_PI,k.EPSILON10)&&(i.south=-k.PI_OVER_TWO,i.east=k.PI,i.west=-k.PI),i};var O$t=new vd;function H$t(t,e,n){return t.height>=k.PI||t.width>=k.PI?vd.fromCartesian(e[0],O$t).tangentPlane:Fl.fromPoints(e,n)}var WRt=new gt;function w$t(t,e,n){return(i,o)=>{if(t.height>=k.PI||t.width>=k.PI){if(t.south<0&&t.north>0){c(o)||(o=[]);for(let s=0;s=k.PI||t.width>=k.PI)return(o,a)=>{if(t.south<0&&t.north>0){let s=n.cartesianToCartographic(o,WRt);return c(a)||(a=new K),a.x=s.longitude/k.PI,a.y=s.latitude/k.PI_OVER_TWO,a}return vd.fromCartesian(o,a)};let i=Fl.fromPoints(e,n);return(o,a)=>i.projectPointsOntoPlane(o,a)}function v$t(t,e,n,i){return(o,a)=>!i&&(t.height>=k.PI_OVER_TWO||t.width>=2*k.PI_OVER_THREE)?Fi.splitPolygonsOnEquator(o,e,n,a):o}function K$t(t,e,n,i){if(e.height>=k.PI||e.width>=k.PI)return Fe.fromRectangle(e,void 0,uRt);let o=t,a=Fl.fromPoints(o,n);return Fi.computeBoundingRectangle(a.plane.normal,a.projectPointOntoPlane.bind(a),o,i,uRt)}Lp.createGeometry=function(t){let e=t._vertexFormat,n=t._ellipsoid,i=t._granularity,o=t._stRotation,a=t._polygonHierarchy,s=t._perPositionHeight,l=t._closeTop,r=t._closeBottom,d=t._arcType,m=t._textureCoordinates,h=c(m),Z=a.positions;if(Z.length<3)return;let b=t.rectangle,u=Fi.polygonsFromHierarchy(a,h,w$t(b,Z,n),!s,n,v$t(b,n,d,s)),F=u.hierarchy,U=u.polygons,G=function(B){return B},A=h?Fi.polygonsFromHierarchy(m,!0,G,!1,n).polygons:void 0;if(F.length===0)return;let T=F[0].outerRing,g=K$t(T,b,n,o),C=[],y=t._height,Y=t._extrudedHeight,Q=t._perPositionHeightExtrude||!k.equalsEpsilon(y,Y,0,k.EPSILON2),J={perPositionHeight:s,vertexFormat:e,geometry:void 0,rotationAxis:H$t(b,T,n).plane.normal,projectTo2d:P$t(b,T,n),boundingRectangle:g,ellipsoid:n,stRotation:o,textureCoordinates:void 0,bottom:!1,top:!0,wall:!1,extrude:!1,arcType:d},M;if(Q)for(J.extrude=!0,J.top=l,J.bottom=r,J.shadowVolume=t._shadowVolume,J.offsetAttribute=t._offsetAttribute,M=0;M>e};Or.fromSubtreeJson=async function(t,e,n,i,o){let a=new Or(t,i,o),s;c(e)?s={json:e,binary:void 0}:s=iqt(n);let l=s.json;a._subtreeJson=l;let r;if(co(l,"3DTILES_metadata"))r=l.extensions["3DTILES_metadata"];else if(c(l.tileMetadata)){let A=l.tileMetadata;r=l.propertyTables[A]}let d=[];if(c(l.contentMetadata)){let A=l.contentMetadata.length;for(let S=0;S0;m=m||h;for(let u=0;u>BigInt(61)),d=r%2===0?IE.encode2D(i,o,a):IE.encode2D(i,a,o),m=Kb.fromFacePositionLevel(r,BigInt(d),i),h,u;if(c(s)){let R=(l.maximumHeight+l.minimumHeight)/2;h=n<4?l.minimumHeight:R,u=n<4?R:l.maximumHeight}else h=l.minimumHeight,u=l.maximumHeight;return{extensions:{"3DTILES_bounding_volume_S2":{token:Kb.getTokenFromId(m._cellId),minimumHeight:h,maximumHeight:u}}}}var Sqt=new p,Tqt=new p,i$=new p,gqt=new ot;function YRt(t,e,n,i,o){if(e===0)return t;let a=p.unpack(t,0,Tqt),s=ot.unpack(t,3,gqt),l=Math.pow(2,-e),r=-1+(2*n+1)*l,d=-1+(2*i+1)*l,m=0,h=p.fromElements(l,l,1,Sqt);c(o)&&(m=-1+(2*o+1)*l,h.z=l);let u=p.fromElements(r,d,m,i$);u=ot.multiplyByVector(s,u,i$),u=p.add(u,a,i$);let R=ot.clone(s);R=ot.multiplyByScale(R,h,R);let V=new Array(12);return p.pack(u,V),ot.pack(R,V,3),V}var Eqt=new Gt;function xRt(t,e,n,i,o){if(e===0)return t.slice();let a=Gt.unpack(t,0,Eqt),s=t[4],l=t[5],r=Math.pow(2,-e),d=r*a.width,m=k.negativePiToPi(a.west+n*d),h=k.negativePiToPi(m+d),u=r*a.height,R=k.negativePiToPi(a.south+i*u),V=k.negativePiToPi(R+u),F=s,U=l;if(c(o)){let G=r*(l-s);F+=o*G,U=F+G}return[m,R,h,V,F,U]}function Cqt(t,e,n){let i=t._implicitTileset,o=e.implicitCoordinates.getChildCoordinates(n),a=QRt(i,o,n,!1,e),s=BRt(void 0,i,o),l=i.subtreeUriTemplate.getDerivedResource({templateValues:o.getTemplateValues()}).url,r={boundingVolume:a,geometricError:s,refine:i.refine,contents:[{uri:l}]},d=XRt(t,i.baseResource,r,e);return d.implicitTileset=i,d.implicitCoordinates=o,d}function XRt(t,e,n,i){let o=t._tile.constructor;return new o(t._tileset,e,n,i)}xc.prototype.hasProperty=function(t,e){return!1};xc.prototype.getFeature=function(t){};xc.prototype.applyDebugSettings=function(t,e){};xc.prototype.applyStyle=function(t){};xc.prototype.update=function(t,e){};xc.prototype.pick=function(t,e,n){};xc.prototype.isDestroyed=function(){return!1};xc.prototype.destroy=function(){return this._implicitSubtree=this._implicitSubtree&&this._implicitSubtree.destroy(),At(this)};xc._deriveBoundingBox=YRt;xc._deriveBoundingRegion=xRt;xc._deriveBoundingVolumeS2=kRt;var DE=xc;var V8n=b(W(),1);var qkn=b(W(),1),Iqt={NONE:0,REPEAT:1,MIRRORED_REPEAT:2},xm=Object.freeze(Iqt);var o8n=b(W(),1);var U2n=b(W(),1);var n2n=b(W(),1);function OE(t,e){this._distance=e,this._normal=new JRt(t,this),this.onChangeCallback=void 0,this.index=-1}Object.defineProperties(OE.prototype,{distance:{get:function(){return this._distance},set:function(t){c(this.onChangeCallback)&&t!==this._distance&&this.onChangeCallback(this.index),this._distance=t}},normal:{get:function(){return this._normal},set:function(t){c(this.onChangeCallback)&&!p.equals(this._normal._cartesian3,t)&&this.onChangeCallback(this.index),p.clone(t,this._normal._cartesian3)}}});OE.fromPlane=function(t,e){return c(e)?(e.normal=t.normal,e.distance=t.distance):e=new OE(t.normal,t.distance),e};OE.clone=function(t,e){return c(e)?(e.normal=t.normal,e.distance=t.distance,e):new OE(t.normal,t.distance)};function JRt(t,e){this._clippingPlane=e,this._cartesian3=p.clone(t)}Object.defineProperties(JRt.prototype,{x:{get:function(){return this._cartesian3.x},set:function(t){c(this._clippingPlane.onChangeCallback)&&t!==this._cartesian3.x&&this._clippingPlane.onChangeCallback(this._clippingPlane.index),this._cartesian3.x=t}},y:{get:function(){return this._cartesian3.y},set:function(t){c(this._clippingPlane.onChangeCallback)&&t!==this._cartesian3.y&&this._clippingPlane.onChangeCallback(this._clippingPlane.index),this._cartesian3.y=t}},z:{get:function(){return this._cartesian3.z},set:function(t){c(this._clippingPlane.onChangeCallback)&&t!==this._cartesian3.z&&this._clippingPlane.onChangeCallback(this._clippingPlane.index),this._cartesian3.z=t}}});var SA=OE;function Pd(t){t=f(t,f.EMPTY_OBJECT),this._planes=[],this._dirtyIndex=-1,this._multipleDirtyPlanes=!1,this._enabled=f(t.enabled,!0),this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this.edgeColor=v.clone(f(t.edgeColor,v.WHITE)),this.edgeWidth=f(t.edgeWidth,0),this.planeAdded=new It,this.planeRemoved=new It,this._owner=void 0;let e=f(t.unionClippingRegions,!1);this._unionClippingRegions=e,this._testIntersection=e?ORt:HRt,this._uint8View=void 0,this._float32View=void 0,this._clippingPlanesTexture=void 0;let n=t.planes;if(c(n)){let i=n.length;for(let o=0;o0&&(a=yn.OUTSIDE);for(let s=0;s0?ws.COUNTER_CLOCKWISE:ws.CLOCKWISE};Hf.triangulate=function(t,e){let n=K.packArray(t);return(0,nbt.default)(n,e,2)};var ibt=new p,obt=new p,abt=new p,$Rt=new p,tbt=new p,ebt=new p,n0=new p,sbt=new K,lbt=new K,rbt=new K,wE=new K;Hf.computeSubdivision=function(t,e,n,i,o){o=f(o,k.RADIANS_PER_DEGREE);let a=c(i),s=n.slice(0),l,r=e.length,d=new Array(r*3),m=new Array(r*2),h=0,u=0;for(l=0;l0;){let S=s.pop(),g=s.pop(),C=s.pop(),y=p.fromArray(d,C*3,ibt),Y=p.fromArray(d,g*3,obt),Q=p.fromArray(d,S*3,abt),J,M,Z;a&&(J=K.fromArray(m,C*2,sbt),M=K.fromArray(m,g*2,lbt),Z=K.fromArray(m,S*2,rbt));let E=p.multiplyByScalar(p.normalize(y,$Rt),F,$Rt),I=p.multiplyByScalar(p.normalize(Y,tbt),F,tbt),B=p.multiplyByScalar(p.normalize(Q,ebt),F,ebt),X=p.magnitudeSquared(p.subtract(E,I,n0)),_=p.magnitudeSquared(p.subtract(I,B,n0)),P=p.magnitudeSquared(p.subtract(B,E,n0)),w=Math.max(X,_,P),z,H,nt;w>G?X===w?(z=`${Math.min(C,g)} ${Math.max(C,g)}`,l=V[z],c(l)||(H=p.add(y,Y,n0),p.multiplyByScalar(H,.5,H),d.push(H.x,H.y,H.z),l=d.length/3-1,V[z]=l,a&&(nt=K.add(J,M,wE),K.multiplyByScalar(nt,.5,nt),m.push(nt.x,nt.y))),s.push(C,l,S),s.push(l,g,S)):_===w?(z=`${Math.min(g,S)} ${Math.max(g,S)}`,l=V[z],c(l)||(H=p.add(Y,Q,n0),p.multiplyByScalar(H,.5,H),d.push(H.x,H.y,H.z),l=d.length/3-1,V[z]=l,a&&(nt=K.add(M,Z,wE),K.multiplyByScalar(nt,.5,nt),m.push(nt.x,nt.y))),s.push(g,l,C),s.push(l,S,C)):P===w&&(z=`${Math.min(S,C)} ${Math.max(S,C)}`,l=V[z],c(l)||(H=p.add(Q,y,n0),p.multiplyByScalar(H,.5,H),d.push(H.x,H.y,H.z),l=d.length/3-1,V[z]=l,a&&(nt=K.add(Z,J,wE),K.multiplyByScalar(nt,.5,nt),m.push(nt.x,nt.y))),s.push(S,l,g),s.push(l,C,g)):(R.push(C),R.push(g),R.push(S))}let A={attributes:{position:new jt({componentDatatype:it.DOUBLE,componentsPerAttribute:3,values:d})},indices:R,primitiveType:le.TRIANGLES};return a&&(A.attributes.st=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:m})),new _e(A)};var qqt=new gt,$qt=new gt,t$t=new gt,d$=new gt;Hf.computeRhumbLineSubdivision=function(t,e,n,i,o){o=f(o,k.RADIANS_PER_DEGREE);let a=c(i),s=n.slice(0),l,r=e.length,d=new Array(r*3),m=new Array(r*2),h=0,u=0;for(l=0;l0;){let C=s.pop(),y=s.pop(),Y=s.pop(),Q=p.fromArray(d,Y*3,ibt),J=p.fromArray(d,y*3,obt),M=p.fromArray(d,C*3,abt),Z,E,I;a&&(Z=K.fromArray(m,Y*2,sbt),E=K.fromArray(m,y*2,lbt),I=K.fromArray(m,C*2,rbt));let B=t.cartesianToCartographic(Q,qqt),X=t.cartesianToCartographic(J,$qt),_=t.cartesianToCartographic(M,t$t);G.setEndPoints(B,X);let P=G.surfaceDistance;A.setEndPoints(X,_);let w=A.surfaceDistance;S.setEndPoints(_,B);let z=S.surfaceDistance,H=Math.max(P,w,z),nt,$,dt,q,at;H>U?P===H?(nt=`${Math.min(Y,y)} ${Math.max(Y,y)}`,l=V[nt],c(l)||($=G.interpolateUsingFraction(.5,d$),dt=(B.height+X.height)*.5,q=p.fromRadians($.longitude,$.latitude,dt,t,n0),d.push(q.x,q.y,q.z),l=d.length/3-1,V[nt]=l,a&&(at=K.add(Z,E,wE),K.multiplyByScalar(at,.5,at),m.push(at.x,at.y))),s.push(Y,l,C),s.push(l,y,C)):w===H?(nt=`${Math.min(y,C)} ${Math.max(y,C)}`,l=V[nt],c(l)||($=A.interpolateUsingFraction(.5,d$),dt=(X.height+_.height)*.5,q=p.fromRadians($.longitude,$.latitude,dt,t,n0),d.push(q.x,q.y,q.z),l=d.length/3-1,V[nt]=l,a&&(at=K.add(E,I,wE),K.multiplyByScalar(at,.5,at),m.push(at.x,at.y))),s.push(y,l,Y),s.push(l,C,Y)):z===H&&(nt=`${Math.min(C,Y)} ${Math.max(C,Y)}`,l=V[nt],c(l)||($=S.interpolateUsingFraction(.5,d$),dt=(_.height+B.height)*.5,q=p.fromRadians($.longitude,$.latitude,dt,t,n0),d.push(q.x,q.y,q.z),l=d.length/3-1,V[nt]=l,a&&(at=K.add(I,Z,wE),K.multiplyByScalar(at,.5,at),m.push(at.x,at.y))),s.push(C,l,y),s.push(l,Y,y)):(R.push(Y),R.push(y),R.push(C))}let g={attributes:{position:new jt({componentDatatype:it.DOUBLE,componentsPerAttribute:3,values:d})},indices:R,primitiveType:le.TRIANGLES};return a&&(g.attributes.st=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:m})),new _e(g)};Hf.scaleToGeodeticHeight=function(t,e,n,i){n=f(n,mt.WGS84);let o=zqt,a=jqt;if(e=f(e,0),i=f(i,!0),c(t)){let s=t.length;for(let l=0;l10&&e*2>t.length&&(this._array=t.slice(e),e=0),this._offset=e,this._length--,n};wf.prototype.peek=function(){if(this._length!==0)return this._array[this._offset]};wf.prototype.contains=function(t){return this._array.indexOf(t)!==-1};wf.prototype.clear=function(){this._array.length=this._offset=this._length=0};wf.prototype.sort=function(t){this._offset>0&&(this._array=this._array.slice(this._offset),this._offset=0),this._array.sort(t)};var $Z=wf;var Ws={};Ws.computeHierarchyPackedLength=function(t,e){let n=0,i=[t];for(;i.length>0;){let o=i.pop();if(!c(o))continue;n+=2;let a=o.positions,s=o.holes;if(c(a)&&a.length>0&&(n+=a.length*e.packedLength),c(s)){let l=s.length;for(let r=0;r0;){let a=o.pop();if(!c(a))continue;let s=a.positions,l=a.holes;if(e[n++]=c(s)?s.length:0,e[n++]=c(l)?l.length:0,c(s)){let r=s.length;for(let d=0;d0?new Array(o):void 0;for(let l=0;lk.PI){let r=s;s=l,l=r}if(!(a.longitudel))return n.cartographicToCartesian(a)}function c$t(t,e,n,i){if(i===Ln.RHUMB)return d$t(t,e,n);let o=no.lineSegmentPlane(t,e,Kn.ORIGIN_XY_PLANE);if(c(o))return n.scaleToGeodeticSurface(o,o)}var m$t=new gt;function h$t(t,e,n){let i=[],o,a,s,l,r,d=0;for(;de.cartesianToCartographic(h,m$t).longitude;if(s===0)i.push({position:d,type:s,visited:!1,next:l,theta:m(o)});else if(l!==0){if(r=c$t(o,a,e,n),++d,!c(r))continue;t.splice(d,0,r),i.push({position:d,type:s,visited:!1,next:l,theta:m(r)})}++d}return i}function hbt(t,e,n,i,o,a,s){let l=[],r=a,d=h=>u=>u.position===h,m=[];do{let h=n[r];l.push(h);let u=i.findIndex(d(r)),R=i[u];if(!c(R)){++r;continue}let{visited:V,type:F,next:U}=R;if(R.visited=!0,F===0){if(U===0){let g=i[u-(s?1:-1)];if(g?.position===r+1)g.visited=!0;else{++r;continue}}if(!V&&s&&U>0||a===r&&!s&&U<0){++r;continue}}if(!(s?F>=0:F<=0)){++r;continue}V||m.push(r);let A=u+(s?1:-1),S=i[A];if(!c(S)){++r;continue}r=S.position}while(r=0&&r!==a&&l.lengthd.theta-m.theta);let r=s[0].z>=0;o=hbt(i,o,s,l,1,0,r)}return i};Ws.polygonsFromHierarchy=function(t,e,n,i,o,a){let s=[],l=[],r=new $Z;r.enqueue(t);let d=c(a);for(;r.length!==0;){let m=r.dequeue(),h=m.positions,u=m.holes,R,V;if(i)for(V=h.length,R=0;R1){for(let Y of y)r.enqueue(new Wr(Y,u));continue}}let A=h.slice(),S=c(u)?u.length:0,g=[],C;for(R=0;RMath.PI&&(t-=k.TWO_PI),t}}});var PE=new gt,W$t=new p;al.prototype.getLatitude=function(t){c(t)||(t=mt.WGS84),PE.latitude=this.conformalLatitude,PE.longitude=this.longitude,PE.height=0;let e=this.ellipsoid.cartographicToCartesian(PE,W$t);return t.cartesianToCartographic(e,PE),PE.latitude};var f$t=new di,F$t=new p,U$t=new p;al.fromCartesian=function(t,e){let n=k.signNotZero(t.z),i=al.NORTH_POLE_TANGENT_PLANE,o=al.SOUTH_POLE;n<0&&(i=al.SOUTH_POLE_TANGENT_PLANE,o=al.NORTH_POLE);let a=f$t;a.origin=i.ellipsoid.scaleToGeocentricSurface(t,a.origin),a.direction=p.subtract(a.origin,o,F$t),p.normalize(a.direction,a.direction);let s=no.rayPlane(a,i.plane,U$t),l=p.subtract(s,o,s),r=p.dot(i.xAxis,l),d=n*p.dot(i.yAxis,l);return c(e)?(e.position=new K(r,d),e.tangentPlane=i,e):new al(new K(r,d),i)};al.fromCartesianArray=function(t,e){let n=t.length;c(e)?e.length=n:e=new Array(n);for(let i=0;i=0?s:s+k.TWO_PI;o.westOverIdl=Math.min(o.westOverIdl,l),o.eastOverIdl=Math.max(o.eastOverIdl,l),a.west=Math.min(a.west,s),a.east=Math.max(a.east,s);let r=t.getLatitude(n),d=r;if(a.south=Math.min(a.south,r),a.north=Math.max(a.north,r),i!==Ln.RHUMB){let u=K.subtract(e.position,t.position,L$t),R=K.dot(e.position,u)/K.dot(u,u);if(R>0&&R<1){let V=K.add(e.position,K.multiplyByScalar(u,-R,u),M$t),F=vd.clone(e,_$t);F.position=V;let U=F.getLatitude(n);a.south=Math.min(a.south,U),a.north=Math.max(a.north,U),Math.abs(r)>Math.abs(U)&&(d=U)}}let m=e.x*t.y-t.x*e.y,h=Math.sign(m);h!==0&&(h*=K.angleBetween(e.position,t.position)),d>=0&&(o.northAngle+=h),d<=0&&(o.southAngle+=h)}var bbt=new vd,D$t=new vd,Jp={northAngle:0,southAngle:0,westOverIdl:0,eastOverIdl:0};Lp.computeRectangleFromPositions=function(t,e,n,i){if(c(i)||(i=new Gt),t.length<3)return i;i.west=Number.POSITIVE_INFINITY,i.east=Number.NEGATIVE_INFINITY,i.south=Number.POSITIVE_INFINITY,i.north=Number.NEGATIVE_INFINITY,Jp.northAngle=0,Jp.southAngle=0,Jp.westOverIdl=Number.POSITIVE_INFINITY,Jp.eastOverIdl=Number.NEGATIVE_INFINITY;let o=t.length,a=vd.fromCartesian(t[0],D$t);for(let s=1;sJp.eastOverIdl-Jp.westOverIdl&&(i.west=Jp.westOverIdl,i.east=Jp.eastOverIdl,i.east>k.PI&&(i.east=i.east-k.TWO_PI),i.west>k.PI&&(i.west=i.west-k.TWO_PI)),k.equalsEpsilon(Math.abs(Jp.northAngle),k.TWO_PI,k.EPSILON10)&&(i.north=k.PI_OVER_TWO,i.east=k.PI,i.west=-k.PI),k.equalsEpsilon(Math.abs(Jp.southAngle),k.TWO_PI,k.EPSILON10)&&(i.south=-k.PI_OVER_TWO,i.east=k.PI,i.west=-k.PI),i};var O$t=new vd;function H$t(t,e,n){return t.height>=k.PI||t.width>=k.PI?vd.fromCartesian(e[0],O$t).tangentPlane:Fl.fromPoints(e,n)}var Wbt=new gt;function w$t(t,e,n){return(i,o)=>{if(t.height>=k.PI||t.width>=k.PI){if(t.south<0&&t.north>0){c(o)||(o=[]);for(let s=0;s=k.PI||t.width>=k.PI)return(o,a)=>{if(t.south<0&&t.north>0){let s=n.cartesianToCartographic(o,Wbt);return c(a)||(a=new K),a.x=s.longitude/k.PI,a.y=s.latitude/k.PI_OVER_TWO,a}return vd.fromCartesian(o,a)};let i=Fl.fromPoints(e,n);return(o,a)=>i.projectPointsOntoPlane(o,a)}function v$t(t,e,n,i){return(o,a)=>!i&&(t.height>=k.PI_OVER_TWO||t.width>=2*k.PI_OVER_THREE)?Fi.splitPolygonsOnEquator(o,e,n,a):o}function K$t(t,e,n,i){if(e.height>=k.PI||e.width>=k.PI)return Fe.fromRectangle(e,void 0,Vbt);let o=t,a=Fl.fromPoints(o,n);return Fi.computeBoundingRectangle(a.plane.normal,a.projectPointOntoPlane.bind(a),o,i,Vbt)}Lp.createGeometry=function(t){let e=t._vertexFormat,n=t._ellipsoid,i=t._granularity,o=t._stRotation,a=t._polygonHierarchy,s=t._perPositionHeight,l=t._closeTop,r=t._closeBottom,d=t._arcType,m=t._textureCoordinates,h=c(m),u=a.positions;if(u.length<3)return;let R=t.rectangle,V=Fi.polygonsFromHierarchy(a,h,w$t(R,u,n),!s,n,v$t(R,n,d,s)),F=V.hierarchy,U=V.polygons,G=function(B){return B},A=h?Fi.polygonsFromHierarchy(m,!0,G,!1,n).polygons:void 0;if(F.length===0)return;let S=F[0].outerRing,g=K$t(S,R,n,o),C=[],y=t._height,Y=t._extrudedHeight,Q=t._perPositionHeightExtrude||!k.equalsEpsilon(y,Y,0,k.EPSILON2),J={perPositionHeight:s,vertexFormat:e,geometry:void 0,rotationAxis:H$t(R,S,n).plane.normal,projectTo2d:P$t(R,S,n),boundingRectangle:g,ellipsoid:n,stRotation:o,textureCoordinates:void 0,bottom:!1,top:!0,wall:!1,extrude:!1,arcType:d},M;if(Q)for(J.extrude=!0,J.top=l,J.bottom=r,J.shadowVolume=t._shadowVolume,J.offsetAttribute=t._offsetAttribute,M=0;MKE.equals(e,t))};Tl.prototype.remove=function(t){let e=this._polygons,n=e.findIndex(i=>KE.equals(i,t));return n===-1?!1:(e.splice(n,1),this.polygonRemoved.raiseEvent(t,n),!0)};var q$t=new Gt;function $$t(t){let e=[],n=[],i=t.length;for(let a=0;aGt.union(t[U].computeSphericalExtents(q$t),F,F),l),e[Z]=void 0,n[Z]=void 0,r=Math.max(l.height*2.5,.001),d=Math.max(l.width*2.5,.001),m=Gt.clone(l,m),m.south-=r,m.west-=d,m.north+=r,m.east+=d,m.south=Math.max(m.south,-Math.PI),m.west=Math.max(m.west,-Math.PI),m.north=Math.min(m.north,Math.PI),m.east=Math.min(m.east,Math.PI),Z=-1}}e.push(m),n.push(h)}let o=new Map;return n.filter(c).forEach((a,s)=>a.forEach(l=>o.set(l,s))),{extentsList:e.filter(c),extentsIndexByPolygon:o}}Tl.prototype.removeAll=function(){let t=this._polygons,e=t.length;for(let n=0;ns+l.length,0);if(n===this.totalPositions||(this._totalPositions=n,this.length===0))return;c(this._signedDistanceComputeCommand)&&(this._signedDistanceComputeCommand.canceled=!0,this._signedDistanceComputeCommand=void 0);let i=this._polygonsTexture,o=this._extentsTexture,a=this._signedDistanceTexture;if(c(i)){let s=i.width*i.height;(s{t._signedDistanceComputeCommand=void 0}})}var FRt=new Gt,nte=new Gt;Tl.prototype.computeIntersectionWithBoundingVolume=function(t,e){let n=this._polygons,i=n.length,o=yn.OUTSIDE;this.inverse&&(o=yn.INSIDE);for(let a=0;a=a;)G=o[G-a];o.push(G),s[F]=U}U>Tte&&(e instanceof Uint16Array||e instanceof Uint8Array)?e=new Uint32Array(e):U>Ste&&e instanceof Uint8Array&&(e=new Uint16Array(e)),F===r?(r=U,e[l]=U):F===d?(d=U,e[l+1]=U):(m=U,e[l+2]=U),F=TRt(i,r,d,m,Z,b,u)}}t._triangleIndices=e,t._outlineCoordinatesTypedArray=new Float32Array(i)}function TRt(t,e,n,i,o,a,s){let l=s?1:0,r=o?1:0,d=0,m=Z$(t,e,l,r,d);if(m===0)return e;let h=0,Z=o?1:0,b=a?1:0,u=Z$(t,n,h,Z,b);if(u===0)return n;let F=s?1:0,U=0,G=a?1:0,A=Z$(t,i,F,U,G);if(A===0)return i;let T=m&u&A,g,C,y;if(T&1)g=0,C=1,y=2;else if(T&2)g=0,y=1,C=2;else if(T&4)C=0,g=1,y=2;else if(T&8)C=0,y=1,g=2;else if(T&16)y=0,g=1,C=2;else if(T&32)y=0,C=1,g=2;else{let M=V$(m),V=V$(u),E=V$(A);return M>1&1)+(t>>2&1)+(t>>3&1)+(t>>4&1)+(t>>5&1)}_w.prototype.updateAttribute=function(t){let e=this._extraVertices,n=t.length,i=n/this._originalVertexCount,o=e.length,a=t.constructor,s=new a(t.length+o*i);s.set(t);for(let l=0;l1;)i>>=1,a.push(SRt(i));let s=new hn({context:t,source:{arrayBufferView:o,mipLevels:a},width:n,height:1,pixelFormat:Ye.LUMINANCE,sampler:new Hn({wrapS:Vi.CLAMP_TO_EDGE,wrapT:Vi.CLAMP_TO_EDGE,minificationFilter:On.LINEAR_MIPMAP_LINEAR,magnificationFilter:bo.LINEAR})});return e.outlineTexture=s,s};function SRt(t){let e=new Uint8Array(t);return e[t-1]=192,t===8?e[t-1]=96:t===4?e[t-1]=48:t===2?e[t-1]=24:t===1&&(e[t-1]=12),e}function gRt(t,e){this._originalVertexCount=e,this._edges=new Set;for(let n=0;n{this._resourcesLoaded=!0}).catch(o=>{this._processError=o})),c(this._processError)){this._state=es.FAILED;let o=this._processError;this._processError=void 0,Ow(this,o)}let e=this._textureErrors.pop();if(c(e)){let o=this.getError("Failed to load glTF texture",e);throw o.name="TextureError",o}if(this._state===es.FAILED)return!1;let n=!1;try{n=this._process(t)}catch(o){this._state=es.FAILED,Ow(this,o)}let i=!1;try{i=this._processTextures(t)}catch(o){this._textureState=es.FAILED,Ow(this,o)}return this._incrementallyLoadTextures?n:n&&i};function see(t,e,n,i,o,a,s,l){let d=e.accessors[n].bufferView;return jo.getVertexBufferLoader({gltf:e,gltfResource:t._gltfResource,baseResource:t._baseResource,frameState:l,bufferViewId:d,draco:o,attributeSemantic:i,accessorId:n,asynchronous:t._asynchronous,loadBuffer:a,loadTypedArray:s})}function lee(t,e,n,i,o,a,s){return jo.getIndexBufferLoader({gltf:e,accessorId:n,gltfResource:t._gltfResource,baseResource:t._baseResource,frameState:s,draco:i,asynchronous:t._asynchronous,loadBuffer:o,loadTypedArray:a})}function ree(t,e,n){let i=jo.getBufferViewLoader({gltf:e,bufferViewId:n,gltfResource:t._gltfResource,baseResource:t._baseResource});return t._bufferViewLoaders.push(i),i}function yRt(t,e,n){let i=e.byteOffset,o=Qm(t,e),a=e.count,s=Ih(e.type),l=e.componentType,r=it.getSizeInBytes(l),d=r*s,m=a*s;if(o===d)return n=new Uint8Array(n),it.createArrayBufferView(l,n.buffer,n.byteOffset+i,m);let h=it.createTypedArray(l,m),Z=new DataView(n.buffer),b=new Array(s),u=e0(e.componentType);i=n.byteOffset+i;for(let F=0;F{c(o)&&c(o.attributes)&&c(o.attributes[m])?fee(F,U,a,s):Fee(e,r,F,U,a,s)},F}function kRt(t,e,n,i,o,a,s,l){let r=i.modelSemantic,d=r===sn.POSITION,m=r===sn.FEATURE_ID,h=d&&!a&&t._loadAttributesFor2D&&!l.scene3DOnly,Z=d&&t._enablePick&&!l.context.webgl2,b=t._loadForClassification&&m,u=t._loadAttributesAsTypedArray,F=!u,U=u||h||Z||b,T=QRt(t,e,n,i,o,s?!1:F,s?!0:U,l),g=new yA.AttributeLoadPlan(T);return g.loadBuffer=F,g.loadTypedArray=U,g}function Uee(t,e,n,i,o,a){let s=c(i.ROTATION),l=c(i.TRANSLATION)&&c(e.accessors[i.TRANSLATION].min)&&c(e.accessors[i.TRANSLATION].max),r=b$(t,Sl,o),d=r.modelSemantic,m=d===Sl.TRANSLATION||d===Sl.ROTATION||d===Sl.SCALE,h=d===Sl.TRANSLATION,Z=t._loadAttributesAsTypedArray||s&&m||!a.context.instancedArrays,b=t._enablePick&&!a.context.webgl2,u=!Z,F=t._loadAttributesFor2D&&!a.scene3DOnly;return QRt(t,e,n,r,void 0,u,Z||h&&(!l||F||b),a)}function Gee(t,e,n,i,o,a,s){let l=e.accessors[n],r=l.bufferView;if(!c(i)&&!c(r))return;let d=new Yte;d.count=l.count;let m=t._loadAttributesAsTypedArray,h=(t._loadIndicesForWireframe||t._enablePick)&&!s.context.webgl2,Z=t._loadForClassification&&o,u=!m,F=m||h||Z,A=lee(t,e,n,i,a?!1:u,a?!0:F,s),T=t._geometryLoaders.length;t._geometryLoaders.push(A);let g=A.load();t._loaderPromises.push(g),t._geometryCallbacks[T]=()=>{d.indexDatatype=A.indexDatatype,d.buffer=A.buffer,d.typedArray=A.typedArray};let C=new yA.IndicesLoadPlan(d);return C.loadBuffer=u,C.loadTypedArray=F,C}function a0(t,e,n,i,o,a){let s=km.getImageIdFromTexture({gltf:e,textureId:n.index,supportedImageFormats:i});if(!c(s))return;let l=jo.getTextureLoader({gltf:e,textureInfo:n,gltfResource:t._gltfResource,baseResource:t._baseResource,supportedImageFormats:i,frameState:o,asynchronous:t._asynchronous}),r=km.createModelTextureReader({textureInfo:n}),d=t._textureLoaders.length;t._textureLoaders.push(l);let m=l.load().catch(h=>{if(!t.isDestroyed()){if(!t._incrementallyLoadTextures)throw h;t._textureState=es.FAILED,t._textureErrors.push(h)}});return t._texturesPromises.push(m),t._textureCallbacks[d]=()=>{r.texture=l.texture,c(a)&&(r.texture.sampler=a)},r}function Aee(t,e,n,i,o){let a=new tee,s=f(n.extensions,f.EMPTY_OBJECT),l=s.KHR_materials_pbrSpecularGlossiness,r=n.pbrMetallicRoughness;if(a.unlit=c(s.KHR_materials_unlit),c(l)){let d=new $te;a.specularGlossiness=d,c(l.diffuseTexture)&&(d.diffuseTexture=a0(t,e,l.diffuseTexture,i,o)),c(l.specularGlossinessTexture)&&c(l.specularGlossinessTexture)&&(d.specularGlossinessTexture=a0(t,e,l.specularGlossinessTexture,i,o)),d.diffuseFactor=Mp(Rt,l.diffuseFactor),d.specularFactor=Mp(p,l.specularFactor),d.glossinessFactor=l.glossinessFactor,a.pbrSpecularGlossiness=l}else if(c(r)){let d=new qte;c(r.baseColorTexture)&&(d.baseColorTexture=a0(t,e,r.baseColorTexture,i,o)),c(r.metallicRoughnessTexture)&&(d.metallicRoughnessTexture=a0(t,e,r.metallicRoughnessTexture,i,o)),d.baseColorFactor=Mp(Rt,r.baseColorFactor),d.metallicFactor=r.metallicFactor,d.roughnessFactor=r.roughnessFactor,a.metallicRoughness=d}return c(n.emissiveTexture)&&(a.emissiveTexture=a0(t,e,n.emissiveTexture,i,o)),c(n.normalTexture)&&!t._loadForClassification&&(a.normalTexture=a0(t,e,n.normalTexture,i,o)),c(n.occlusionTexture)&&(a.occlusionTexture=a0(t,e,n.occlusionTexture,i,o)),a.emissiveFactor=Mp(p,n.emissiveFactor),a.alphaMode=n.alphaMode,a.alphaCutoff=n.alphaCutoff,a.doubleSided=n.doubleSided,a}function YRt(t,e){let n=new CRt;return n.featureCount=t.featureCount,n.nullFeatureId=t.nullFeatureId,n.propertyTableId=t.propertyTable,n.setIndex=t.attribute,n.label=t.label,n.positionalLabel=e,n}function xRt(t,e,n,i){let o=new CRt,a=t.featureIds;return o.featureCount=n,o.propertyTableId=e,o.setIndex=BRt(a.attribute),o.positionalLabel=i,o}function XRt(t,e){let n=new NRt;return n.propertyTableId=t.propertyTable,n.featureCount=t.featureCount,n.nullFeatureId=t.nullFeatureId,n.label=t.label,n.positionalLabel=e,n.offset=0,n.repeat=1,n}function JRt(t,e,n,i){let o=new NRt,a=t.featureIds;o.propertyTableId=e,o.featureCount=n,o.offset=f(a.constant,0);let s=f(a.divisor,0);return o.repeat=s===0?void 0:s,o.positionalLabel=i,o}function Tee(t,e,n,i,o,a){let s=new IRt;s.featureCount=n.featureCount,s.nullFeatureId=n.nullFeatureId,s.propertyTableId=n.propertyTable,s.label=n.label,s.positionalLabel=a;let l=n.texture;s.textureReader=a0(t,e,l,i,o,Hn.NEAREST);let d=(c(l.channels)?l.channels:[0]).map(function(m){return"rgba".charAt(m)}).join("");return s.textureReader.channels=d,s}function See(t,e,n,i,o,a,s,l){let r=new IRt,d=n.featureIds,m=d.texture;return r.featureCount=s,r.propertyTableId=i,r.textureReader=a0(t,e,m,o,a,Hn.NEAREST),r.textureReader.channels=d.channels,r.positionalLabel=l,r}function gee(t,e,n,i,o,a){let s=new xte,l=void 0,r=!1;for(let d in n)if(n.hasOwnProperty(d)){let m=n[d],h=b$(t,sn,d),Z=kRt(t,e,m,h,l,r,i,a);s.attributes.push(Z.attribute),o.attributePlans.push(Z)}return s}function Eee(t,e,n,i,o,a){let s=new Xte,l=new yA(s);t._primitiveLoadPlans.push(l);let r=n.material;c(r)&&(s.material=Aee(t,e,e.materials[r],o,a));let d=f(n.extensions,f.EMPTY_OBJECT),m=!1,h=d.CESIUM_primitive_outline;t._loadPrimitiveOutline&&c(h)&&(m=!0,l.needsOutlines=!0,l.outlineIndices=Cee(t,e,h,l));let Z=t._loadForClassification,b=d.KHR_draco_mesh_compression,u=!1,F=n.attributes;if(c(F)){for(let Y in F)if(F.hasOwnProperty(Y)){let Q=F[Y],J=b$(t,sn,Y),M=J.modelSemantic;if(Z&&!Wee(M))continue;M===sn.FEATURE_ID&&(u=!0);let V=kRt(t,e,Q,J,b,i,m,a);l.attributePlans.push(V),s.attributes.push(V.attribute)}}let U=n.targets;if(c(U)&&!Z){let Y=U.length;for(let Q=0;QKE.equals(e,t))};Sl.prototype.remove=function(t){let e=this._polygons,n=e.findIndex(i=>KE.equals(i,t));return n===-1?!1:(e.splice(n,1),this.polygonRemoved.raiseEvent(t,n),!0)};var q$t=new Gt;function $$t(t){let e=[],n=[],i=t.length;for(let a=0;aGt.union(t[U].computeSphericalExtents(q$t),F,F),l),e[u]=void 0,n[u]=void 0,r=Math.max(l.height*2.5,.001),d=Math.max(l.width*2.5,.001),m=Gt.clone(l,m),m.south-=r,m.west-=d,m.north+=r,m.east+=d,m.south=Math.max(m.south,-Math.PI),m.west=Math.max(m.west,-Math.PI),m.north=Math.min(m.north,Math.PI),m.east=Math.min(m.east,Math.PI),u=-1}}e.push(m),n.push(h)}let o=new Map;return n.filter(c).forEach((a,s)=>a.forEach(l=>o.set(l,s))),{extentsList:e.filter(c),extentsIndexByPolygon:o}}Sl.prototype.removeAll=function(){let t=this._polygons,e=t.length;for(let n=0;ns+l.length,0);if(n===this.totalPositions||(this._totalPositions=n,this.length===0))return;c(this._signedDistanceComputeCommand)&&(this._signedDistanceComputeCommand.canceled=!0,this._signedDistanceComputeCommand=void 0);let i=this._polygonsTexture,o=this._extentsTexture,a=this._signedDistanceTexture;if(c(i)){let s=i.width*i.height;(s{t._signedDistanceComputeCommand=void 0}})}var Fbt=new Gt,nte=new Gt;Sl.prototype.computeIntersectionWithBoundingVolume=function(t,e){let n=this._polygons,i=n.length,o=yn.OUTSIDE;this.inverse&&(o=yn.INSIDE);for(let a=0;a=a;)G=o[G-a];o.push(G),s[F]=U}U>Ste&&(e instanceof Uint16Array||e instanceof Uint8Array)?e=new Uint32Array(e):U>Tte&&e instanceof Uint8Array&&(e=new Uint16Array(e)),F===r?(r=U,e[l]=U):F===d?(d=U,e[l+1]=U):(m=U,e[l+2]=U),F=Sbt(i,r,d,m,u,R,V)}}t._triangleIndices=e,t._outlineCoordinatesTypedArray=new Float32Array(i)}function Sbt(t,e,n,i,o,a,s){let l=s?1:0,r=o?1:0,d=0,m=u$(t,e,l,r,d);if(m===0)return e;let h=0,u=o?1:0,R=a?1:0,V=u$(t,n,h,u,R);if(V===0)return n;let F=s?1:0,U=0,G=a?1:0,A=u$(t,i,F,U,G);if(A===0)return i;let S=m&V&A,g,C,y;if(S&1)g=0,C=1,y=2;else if(S&2)g=0,y=1,C=2;else if(S&4)C=0,g=1,y=2;else if(S&8)C=0,y=1,g=2;else if(S&16)y=0,g=1,C=2;else if(S&32)y=0,C=1,g=2;else{let M=Z$(m),Z=Z$(V),E=Z$(A);return M>1&1)+(t>>2&1)+(t>>3&1)+(t>>4&1)+(t>>5&1)}_w.prototype.updateAttribute=function(t){let e=this._extraVertices,n=t.length,i=n/this._originalVertexCount,o=e.length,a=t.constructor,s=new a(t.length+o*i);s.set(t);for(let l=0;l1;)i>>=1,a.push(Tbt(i));let s=new hn({context:t,source:{arrayBufferView:o,mipLevels:a},width:n,height:1,pixelFormat:Ye.LUMINANCE,sampler:new Hn({wrapS:Zi.CLAMP_TO_EDGE,wrapT:Zi.CLAMP_TO_EDGE,minificationFilter:On.LINEAR_MIPMAP_LINEAR,magnificationFilter:Ro.LINEAR})});return e.outlineTexture=s,s};function Tbt(t){let e=new Uint8Array(t);return e[t-1]=192,t===8?e[t-1]=96:t===4?e[t-1]=48:t===2?e[t-1]=24:t===1&&(e[t-1]=12),e}function gbt(t,e){this._originalVertexCount=e,this._edges=new Set;for(let n=0;n{this._resourcesLoaded=!0}).catch(o=>{this._processError=o})),c(this._processError)){this._state=es.FAILED;let o=this._processError;this._processError=void 0,Ow(this,o)}let e=this._textureErrors.pop();if(c(e)){let o=this.getError("Failed to load glTF texture",e);throw o.name="TextureError",o}if(this._state===es.FAILED)return!1;let n=!1;try{n=this._process(t)}catch(o){this._state=es.FAILED,Ow(this,o)}let i=!1;try{i=this._processTextures(t)}catch(o){this._textureState=es.FAILED,Ow(this,o)}return this._incrementallyLoadTextures?n:n&&i};function see(t,e,n,i,o,a,s,l){let d=e.accessors[n].bufferView;return jo.getVertexBufferLoader({gltf:e,gltfResource:t._gltfResource,baseResource:t._baseResource,frameState:l,bufferViewId:d,draco:o,attributeSemantic:i,accessorId:n,asynchronous:t._asynchronous,loadBuffer:a,loadTypedArray:s})}function lee(t,e,n,i,o,a,s){return jo.getIndexBufferLoader({gltf:e,accessorId:n,gltfResource:t._gltfResource,baseResource:t._baseResource,frameState:s,draco:i,asynchronous:t._asynchronous,loadBuffer:o,loadTypedArray:a})}function ree(t,e,n){let i=jo.getBufferViewLoader({gltf:e,bufferViewId:n,gltfResource:t._gltfResource,baseResource:t._baseResource});return t._bufferViewLoaders.push(i),i}function ybt(t,e,n){let i=e.byteOffset,o=Qm(t,e),a=e.count,s=Ih(e.type),l=e.componentType,r=it.getSizeInBytes(l),d=r*s,m=a*s;if(o===d)return n=new Uint8Array(n),it.createArrayBufferView(l,n.buffer,n.byteOffset+i,m);let h=it.createTypedArray(l,m),u=new DataView(n.buffer),R=new Array(s),V=e0(e.componentType);i=n.byteOffset+i;for(let F=0;F{c(o)&&c(o.attributes)&&c(o.attributes[m])?fee(F,U,a,s):Fee(e,r,F,U,a,s)},F}function kbt(t,e,n,i,o,a,s,l){let r=i.modelSemantic,d=r===sn.POSITION,m=r===sn.FEATURE_ID,h=d&&!a&&t._loadAttributesFor2D&&!l.scene3DOnly,u=d&&t._enablePick&&!l.context.webgl2,R=t._loadForClassification&&m,V=t._loadAttributesAsTypedArray,F=!V,U=V||h||u||R,S=Qbt(t,e,n,i,o,s?!1:F,s?!0:U,l),g=new yA.AttributeLoadPlan(S);return g.loadBuffer=F,g.loadTypedArray=U,g}function Uee(t,e,n,i,o,a){let s=c(i.ROTATION),l=c(i.TRANSLATION)&&c(e.accessors[i.TRANSLATION].min)&&c(e.accessors[i.TRANSLATION].max),r=R$(t,Tl,o),d=r.modelSemantic,m=d===Tl.TRANSLATION||d===Tl.ROTATION||d===Tl.SCALE,h=d===Tl.TRANSLATION,u=t._loadAttributesAsTypedArray||s&&m||!a.context.instancedArrays,R=t._enablePick&&!a.context.webgl2,V=!u,F=t._loadAttributesFor2D&&!a.scene3DOnly;return Qbt(t,e,n,r,void 0,V,u||h&&(!l||F||R),a)}function Gee(t,e,n,i,o,a,s){let l=e.accessors[n],r=l.bufferView;if(!c(i)&&!c(r))return;let d=new Yte;d.count=l.count;let m=t._loadAttributesAsTypedArray,h=(t._loadIndicesForWireframe||t._enablePick)&&!s.context.webgl2,u=t._loadForClassification&&o,V=!m,F=m||h||u,A=lee(t,e,n,i,a?!1:V,a?!0:F,s),S=t._geometryLoaders.length;t._geometryLoaders.push(A);let g=A.load();t._loaderPromises.push(g),t._geometryCallbacks[S]=()=>{d.indexDatatype=A.indexDatatype,d.buffer=A.buffer,d.typedArray=A.typedArray};let C=new yA.IndicesLoadPlan(d);return C.loadBuffer=V,C.loadTypedArray=F,C}function a0(t,e,n,i,o,a){let s=km.getImageIdFromTexture({gltf:e,textureId:n.index,supportedImageFormats:i});if(!c(s))return;let l=jo.getTextureLoader({gltf:e,textureInfo:n,gltfResource:t._gltfResource,baseResource:t._baseResource,supportedImageFormats:i,frameState:o,asynchronous:t._asynchronous}),r=km.createModelTextureReader({textureInfo:n}),d=t._textureLoaders.length;t._textureLoaders.push(l);let m=l.load().catch(h=>{if(!t.isDestroyed()){if(!t._incrementallyLoadTextures)throw h;t._textureState=es.FAILED,t._textureErrors.push(h)}});return t._texturesPromises.push(m),t._textureCallbacks[d]=()=>{r.texture=l.texture,c(a)&&(r.texture.sampler=a)},r}function Aee(t,e,n,i,o){let a=new tee,s=f(n.extensions,f.EMPTY_OBJECT),l=s.KHR_materials_pbrSpecularGlossiness,r=n.pbrMetallicRoughness;if(a.unlit=c(s.KHR_materials_unlit),c(l)){let d=new $te;a.specularGlossiness=d,c(l.diffuseTexture)&&(d.diffuseTexture=a0(t,e,l.diffuseTexture,i,o)),c(l.specularGlossinessTexture)&&c(l.specularGlossinessTexture)&&(d.specularGlossinessTexture=a0(t,e,l.specularGlossinessTexture,i,o)),d.diffuseFactor=Mp(bt,l.diffuseFactor),d.specularFactor=Mp(p,l.specularFactor),d.glossinessFactor=l.glossinessFactor,a.pbrSpecularGlossiness=l}else if(c(r)){let d=new qte;c(r.baseColorTexture)&&(d.baseColorTexture=a0(t,e,r.baseColorTexture,i,o)),c(r.metallicRoughnessTexture)&&(d.metallicRoughnessTexture=a0(t,e,r.metallicRoughnessTexture,i,o)),d.baseColorFactor=Mp(bt,r.baseColorFactor),d.metallicFactor=r.metallicFactor,d.roughnessFactor=r.roughnessFactor,a.metallicRoughness=d}return c(n.emissiveTexture)&&(a.emissiveTexture=a0(t,e,n.emissiveTexture,i,o)),c(n.normalTexture)&&!t._loadForClassification&&(a.normalTexture=a0(t,e,n.normalTexture,i,o)),c(n.occlusionTexture)&&(a.occlusionTexture=a0(t,e,n.occlusionTexture,i,o)),a.emissiveFactor=Mp(p,n.emissiveFactor),a.alphaMode=n.alphaMode,a.alphaCutoff=n.alphaCutoff,a.doubleSided=n.doubleSided,a}function Ybt(t,e){let n=new Cbt;return n.featureCount=t.featureCount,n.nullFeatureId=t.nullFeatureId,n.propertyTableId=t.propertyTable,n.setIndex=t.attribute,n.label=t.label,n.positionalLabel=e,n}function xbt(t,e,n,i){let o=new Cbt,a=t.featureIds;return o.featureCount=n,o.propertyTableId=e,o.setIndex=Bbt(a.attribute),o.positionalLabel=i,o}function Xbt(t,e){let n=new Nbt;return n.propertyTableId=t.propertyTable,n.featureCount=t.featureCount,n.nullFeatureId=t.nullFeatureId,n.label=t.label,n.positionalLabel=e,n.offset=0,n.repeat=1,n}function Jbt(t,e,n,i){let o=new Nbt,a=t.featureIds;o.propertyTableId=e,o.featureCount=n,o.offset=f(a.constant,0);let s=f(a.divisor,0);return o.repeat=s===0?void 0:s,o.positionalLabel=i,o}function See(t,e,n,i,o,a){let s=new Ibt;s.featureCount=n.featureCount,s.nullFeatureId=n.nullFeatureId,s.propertyTableId=n.propertyTable,s.label=n.label,s.positionalLabel=a;let l=n.texture;s.textureReader=a0(t,e,l,i,o,Hn.NEAREST);let d=(c(l.channels)?l.channels:[0]).map(function(m){return"rgba".charAt(m)}).join("");return s.textureReader.channels=d,s}function Tee(t,e,n,i,o,a,s,l){let r=new Ibt,d=n.featureIds,m=d.texture;return r.featureCount=s,r.propertyTableId=i,r.textureReader=a0(t,e,m,o,a,Hn.NEAREST),r.textureReader.channels=d.channels,r.positionalLabel=l,r}function gee(t,e,n,i,o,a){let s=new xte,l=void 0,r=!1;for(let d in n)if(n.hasOwnProperty(d)){let m=n[d],h=R$(t,sn,d),u=kbt(t,e,m,h,l,r,i,a);s.attributes.push(u.attribute),o.attributePlans.push(u)}return s}function Eee(t,e,n,i,o,a){let s=new Xte,l=new yA(s);t._primitiveLoadPlans.push(l);let r=n.material;c(r)&&(s.material=Aee(t,e,e.materials[r],o,a));let d=f(n.extensions,f.EMPTY_OBJECT),m=!1,h=d.CESIUM_primitive_outline;t._loadPrimitiveOutline&&c(h)&&(m=!0,l.needsOutlines=!0,l.outlineIndices=Cee(t,e,h,l));let u=t._loadForClassification,R=d.KHR_draco_mesh_compression,V=!1,F=n.attributes;if(c(F)){for(let Y in F)if(F.hasOwnProperty(Y)){let Q=F[Y],J=R$(t,sn,Y),M=J.modelSemantic;if(u&&!Wee(M))continue;M===sn.FEATURE_ID&&(V=!0);let Z=kbt(t,e,Q,J,R,i,m,a);l.attributePlans.push(Z),s.attributes.push(Z.attribute)}}let U=n.targets;if(c(U)&&!u){let Y=U.length;for(let Q=0;Q=s.clientWidth)d=!0;else{if(T.x>s.clientWidth*.5){l.width=T.x,r.frustum.right=Z.x-G,qd=UY(a,n,r,qd),Rd.clipToGLWindowCoordinates(l,qd,W$),l.x+=T.x,r.position.x=-r.position.x;let g=r.frustum.right;r.frustum.right=-r.frustum.left,r.frustum.left=-g,qd=UY(a,n,r,qd),Rd.clipToGLWindowCoordinates(l,qd,f$)}else{l.x+=T.x,l.width-=T.x,r.frustum.left=-Z.x-G,qd=UY(a,n,r,qd),Rd.clipToGLWindowCoordinates(l,qd,W$),l.x=l.x-l.width,r.position.x=-r.position.x;let g=r.frustum.left;r.frustum.left=-r.frustum.right,r.frustum.right=-g,qd=UY(a,n,r,qd),Rd.clipToGLWindowCoordinates(l,qd,f$)}p.clone(b,r.position),r.frustum=u.clone(),i=K.clone(W$,i),(i.x<0||i.x>s.clientWidth)&&(i.x=f$.x)}}if(o.mode!==ut.SCENE2D||d){if(qd=UY(a,n,r,qd),qd.z<0&&!(r.frustum instanceof wn)&&!(r.frustum instanceof el))return;i=Rd.clipToGLWindowCoordinates(l,qd,i)}return i.y=s.clientHeight-i.y,i};Rd.wgs84ToDrawingBufferCoordinates=function(t,e,n){if(n=Rd.wgs84ToWindowCoordinates(t,e,n),!!c(n))return Rd.transformWindowToDrawingBuffer(t,n,n)};var r0=new p,pne=new gt;Rd.computeActualWgs84Position=function(t,e,n){let i=t.mode;if(i===ut.SCENE3D)return p.clone(e,n);let o=t.mapProjection,a=o.ellipsoid.cartesianToCartographic(e,pne);if(!c(a))return;if(o.project(a,r0),i===ut.COLUMBUS_VIEW)return p.fromElements(r0.z,r0.x,r0.y,n);if(i===ut.SCENE2D)return p.fromElements(0,r0.x,r0.y,n);let s=t.morphTime;return p.fromElements(k.lerp(r0.z,e.x,s),k.lerp(r0.x,e.y,s),k.lerp(r0.y,e.z,s),n)};var HRt=new p,wRt=new p,PRt=new L;Rd.clipToGLWindowCoordinates=function(t,e,n){return p.divideByScalar(e,e.w,HRt),L.computeViewportTransformation(t,0,1,PRt),L.multiplyByPoint(PRt,HRt,wRt),K.fromCartesian3(wRt,n)};Rd.transformWindowToDrawingBuffer=function(t,e,n){let i=t.canvas,o=t.drawingBufferWidth/i.clientWidth,a=t.drawingBufferHeight/i.clientHeight;return K.fromElements(e.x*o,e.y*a,n)};var une=new Rt,vRt=new Rt;Rd.drawingBufferToWgs84Coordinates=function(t,e,n,i){let a=t.context.uniformState,s=a.currentFrustum,l=s.x,r=s.y;if(t.frameState.useLogDepth){let b=n*a.log2FarDepthFromNearPlusOne,u=Math.pow(2,b)-1;n=r*(1-l/(u+l))/(r-l)}let d=t.view.passState.viewport,m=Rt.clone(Rt.UNIT_W,une);m.x=(e.x-d.x)/d.width*2-1,m.y=(e.y-d.y)/d.height*2-1,m.z=n*2-1,m.w=1;let h,Z=t.camera.frustum;if(c(Z.fovy)){h=L.multiplyByVector(a.inverseViewProjection,m,vRt);let b=1/h.w;p.multiplyByScalar(h,b,h)}else{let b=Z.offCenterFrustum;c(b)&&(Z=b),h=vRt,h.x=(m.x*(Z.right-Z.left)+Z.left+Z.right)*.5,h.y=(m.y*(Z.top-Z.bottom)+Z.bottom+Z.top)*.5,h.z=(m.z*(l-r)-l-r)*.5,h.w=1,h=L.multiplyByVector(a.inverseView,h,h)}return p.fromCartesian4(h,i)};var qo=Rd;var YLn=R(W(),1),Zne={LEFT:-1,NONE:0,RIGHT:1},Jc=Object.freeze(Zne);var NMn=R(W(),1);var _Ln=R(W(),1);var qE={};qE._deprecationWarning=Zr;var d0=Uint32Array.BYTES_PER_ELEMENT;qE.parse=function(t,e){let n=f(e,0);e=n;let i=new Uint8Array(t),o=new DataView(t);e+=d0;let a=o.getUint32(e,!0);if(a!==1)throw new St(`Only Batched 3D Model version 1 is supported. Version ${a} is not.`);e+=d0;let s=o.getUint32(e,!0);e+=d0;let l=o.getUint32(e,!0);e+=d0;let r=o.getUint32(e,!0);e+=d0;let d=o.getUint32(e,!0);e+=d0;let m=o.getUint32(e,!0);e+=d0;let h;d>=570425344?(e-=d0*2,h=l,d=r,m=0,l=0,r=0,qE._deprecationWarning("b3dm-legacy-header","This b3dm header is using the legacy format [batchLength] [batchTableByteLength]. The new format is [featureTableJsonByteLength] [featureTableBinaryByteLength] [batchTableJsonByteLength] [batchTableBinaryByteLength] from https://github.com/CesiumGS/3d-tiles/tree/main/specification/TileFormats/Batched3DModel.")):m>=570425344&&(e-=d0,h=d,d=l,m=r,l=0,r=0,qE._deprecationWarning("b3dm-legacy-header","This b3dm header is using the legacy format [batchTableJsonByteLength] [batchTableBinaryByteLength] [batchLength]. The new format is [featureTableJsonByteLength] [featureTableBinaryByteLength] [batchTableJsonByteLength] [batchTableBinaryByteLength] from https://github.com/CesiumGS/3d-tiles/tree/main/specification/TileFormats/Batched3DModel."));let Z;l===0?Z={BATCH_LENGTH:f(h,0)}:(Z=ts(i,e,l),e+=l);let b=new Uint8Array(t,e,r);e+=r;let u,F;d>0&&(u=ts(i,e,d),e+=d,m>0&&(F=new Uint8Array(t,e,m),F=new Uint8Array(F),e+=m));let U=n+s-e;if(U===0)throw new St("glTF byte length must be greater than 0.");let G;return e%4===0?G=new Uint8Array(t,e,U):(qE._deprecationWarning("b3dm-glb-unaligned","The embedded glb is not aligned to a 4-byte boundary."),G=new Uint8Array(i.subarray(e,e+U))),{batchLength:h,featureTableJson:Z,featureTableBinary:b,batchTableJson:u,batchTableBinary:F,gltf:G}};var GY=qE;var PLn=R(W(),1);function AY(t,e){this.json=t,this.buffer=e,this._cachedTypedArrays={},this.featuresLength=0}function KRt(t,e,n,i,o,a){let s=t._cachedTypedArrays,l=s[e];return c(l)||(l=it.createArrayBufferView(n,t.buffer.buffer,t.buffer.byteOffset+a,o*i),s[e]=l),l}function Vne(t,e,n,i){let o=t._cachedTypedArrays,a=o[e];return c(a)||(a=it.createTypedArray(n,i),o[e]=a),a}AY.prototype.getGlobalProperty=function(t,e,n){let i=this.json[t];if(c(i))return c(i.byteOffset)?(e=f(e,it.UNSIGNED_INT),n=f(n,1),KRt(this,t,e,n,1,i.byteOffset)):i};AY.prototype.hasProperty=function(t){return c(this.json[t])};AY.prototype.getPropertyArray=function(t,e,n){let i=this.json[t];if(c(i))return c(i.byteOffset)?(c(i.componentType)&&(e=it.fromName(i.componentType)),KRt(this,t,e,n,this.featuresLength,i.byteOffset)):Vne(this,t,e,i)};AY.prototype.getProperty=function(t,e,n,i,o){let a=this.json[t];if(!c(a))return;let s=this.getPropertyArray(t,e,n);if(n===1)return s[i];for(let l=0;l0&&(u=ts(i,e,d),e+=d,m>0&&(F=new Uint8Array(t,e,m),F=new Uint8Array(F),e+=m));let U=n+s-e;if(U===0)throw new St("glTF byte length must be greater than 0.");let G;return e%4===0?G=new Uint8Array(t,e,U):(Pw._deprecationWarning("i3dm-glb-unaligned","The embedded glb is not aligned to a 4-byte boundary."),G=new Uint8Array(i.subarray(e,e+U))),{gltfFormat:h,featureTableJson:Z,featureTableBinary:b,batchTableJson:u,batchTableBinary:F,gltf:G}};var EY=Pw;var m0={NOT_LOADED:0,LOADING:1,PROCESSING:2,POST_PROCESSING:3,READY:4,FAILED:5,UNLOADED:6},vw=Tn.Attribute,xne=Tn.FeatureIdAttribute,e0t=Tn.Instances;function h0(t){t=f(t,f.EMPTY_OBJECT);let e=t.i3dmResource,n=t.arrayBuffer,i=t.baseResource,o=f(t.byteOffset,0),a=f(t.releaseGltfJson,!1),s=f(t.asynchronous,!0),l=f(t.incrementallyLoadTextures,!0),r=f(t.upAxis,$a.Y),d=f(t.forwardAxis,$a.X),m=f(t.loadAttributesAsTypedArray,!1),h=f(t.loadIndicesForWireframe,!1),Z=f(t.loadPrimitiveOutline,!0),b=f(t.enablePick,!1);i=c(i)?i:e.clone(),this._i3dmResource=e,this._baseResource=i,this._arrayBuffer=n,this._byteOffset=o,this._releaseGltfJson=a,this._asynchronous=s,this._incrementallyLoadTextures=l,this._upAxis=r,this._forwardAxis=d,this._loadAttributesAsTypedArray=m,this._loadIndicesForWireframe=h,this._loadPrimitiveOutline=Z,this._enablePick=b,this._state=m0.NOT_LOADED,this._promise=void 0,this._gltfLoader=void 0,this._buffers=[],this._components=void 0,this._transform=L.IDENTITY,this._batchTable=void 0,this._featureTable=void 0,this._instancesLength=0}c(Object.create)&&(h0.prototype=Object.create(Va.prototype),h0.prototype.constructor=h0);Object.defineProperties(h0.prototype,{texturesLoaded:{get:function(){return this._gltfLoader?.texturesLoaded}},cacheKey:{get:function(){}},components:{get:function(){return this._components}}});h0.prototype.load=function(){if(c(this._promise))return this._promise;let t=EY.parse(this._arrayBuffer,this._byteOffset),e=t.featureTableJson,n=t.featureTableBinary,i=t.batchTableJson,o=t.batchTableBinary,a=t.gltfFormat,s=new FZ(e,n);this._featureTable=s;let l=s.getGlobalProperty("INSTANCES_LENGTH");if(s.featuresLength=l,!c(l))throw new St("Feature table global property: INSTANCES_LENGTH must be defined");this._instancesLength=l;let r=s.getGlobalProperty("RTC_CENTER",it.FLOAT,3);c(r)&&(this._transform=L.fromTranslation(p.fromArray(r))),this._batchTable={json:i,binary:o};let d={upAxis:this._upAxis,forwardAxis:this._forwardAxis,releaseGltfJson:this._releaseGltfJson,incrementallyLoadTextures:this._incrementallyLoadTextures,loadAttributesAsTypedArray:this._loadAttributesAsTypedArray,enablePick:this._enablePick,loadIndicesForWireframe:this._loadIndicesForWireframe,loadPrimitiveOutline:this._loadPrimitiveOutline};if(a===0){let h=Im(t.gltf);h=h.replace(/[\s\0]+$/,"");let Z=this._baseResource.getDerivedResource({url:h});d.gltfResource=Z,d.baseResource=Z}else d.gltfResource=this._i3dmResource,d.typedArray=t.gltf;let m=new s0(d);return this._gltfLoader=m,this._state=m0.LOADING,this._promise=m.load().then(()=>{if(!this.isDestroyed())return this._state=m0.PROCESSING,this}).catch(h=>{if(!this.isDestroyed())throw Xne(this,h)}),this._promise};function Xne(t,e){return t.unload(),t._state=m0.FAILED,t.getError("Failed to load i3dm",e)}h0.prototype.process=function(t){if(this._state===m0.READY)return!0;let e=this._gltfLoader,n=!1;if(this._state===m0.PROCESSING&&(n=e.process(t)),!n)return!1;let i=e.components;return i.transform=L.multiplyTransformation(this._transform,i.transform,i.transform),Mne(this,i,t),Jne(this,i),this._components=i,this._arrayBuffer=void 0,this._state=m0.READY,!0};function Jne(t,e){let n=t._batchTable,i=t._instancesLength;if(i===0)return;let o;if(c(n.json))o=c0({count:i,batchTable:n.json,binaryBody:n.binary});else{let a=new Xc({name:uZ.BATCH_TABLE_CLASS_NAME,count:i});o=new bd({schema:{},propertyTables:[a]})}e.structuralMetadata=o}var Kw=new p,G$=new Array(4),Lne=new L;function Mne(t,e,n){let i,o=t._featureTable,a=t._instancesLength;if(a===0)return;let s=o.getGlobalProperty("RTC_CENTER",it.FLOAT,3),l=o.getGlobalProperty("EAST_NORTH_UP"),r=o.hasProperty("NORMAL_UP")||o.hasProperty("NORMAL_UP_OCT32P")||l,d=o.hasProperty("SCALE")||o.hasProperty("SCALE_NON_UNIFORM"),m=Dne(o,a),h;r&&(h=new Float32Array(4*a));let Z;d&&(Z=new Float32Array(3*a));let b=new Float32Array(a),u=p.unpackArray(m),F=new p,U=new p,G=new p,A=new p,T=new ot,g=new wt,C=new Array(4),y=new p,Y=new Array(3),Q=new L;if(!c(s)||p.equals(p.unpack(s),p.ZERO)){let w=Ft.fromPoints(u);for(i=0;i0&&(w.instances=P?_ne(J):J,P=!0)}}function _ne(t){let e=new e0t;e.transformInWorldSpace=t.transformInWorldSpace;let n=t.attributes,i=n.length;for(let o=0;o=n[e]){if(e+1=0&&t>=n[e-1])return e-1;let o;if(t>n[e])for(o=e;o=n[o]&&t=0&&!(t>=n[o]&&tn&&(a=Math.floor((t-n)/o)+1,t-=a*o),t};$E.prototype.clampTime=function(t){let e=this.times;return k.clamp(t,e[0],e[e.length-1])};var ba=$E;function tC(t){this._value=t,this._valueType=ba.getPointType(t)}Object.defineProperties(tC.prototype,{value:{get:function(){return this._value}}});tC.prototype.findTimeInterval=function(t){};tC.prototype.wrapTime=function(t){return 0};tC.prototype.clampTime=function(t){return 0};tC.prototype.evaluate=function(t,e){let n=this._value,i=this._valueType;return i===Number?n:i.clone(n,e)};var IY=tC;var h9n=R(W(),1);var $_n=R(W(),1);function eC(t){t=f(t,f.EMPTY_OBJECT);let e=t.points,n=t.times;this._times=n,this._points=e,this._pointType=ba.getPointType(e[0]),this._lastTimeIndex=0}Object.defineProperties(eC.prototype,{times:{get:function(){return this._times}},points:{get:function(){return this._points}}});eC.prototype.findTimeInterval=ba.prototype.findTimeInterval;eC.prototype.wrapTime=ba.prototype.wrapTime;eC.prototype.clampTime=ba.prototype.clampTime;eC.prototype.evaluate=function(t,e){let n=this.points,i=this.times,o=this._lastTimeIndex=this.findTimeInterval(t,this._lastTimeIndex),a=(t-i[o])/(i[o+1]-i[o]);return this._pointType===Number?(1-a)*n[o]+a*n[o+1]:(c(e)||(e=new p),p.lerp(n[o],n[o+1],a,e))};var qf=eC;var n9n=R(W(),1);var n0t={};n0t.solve=function(t,e,n,i){let o=new Array(n.length),a=new Array(i.length),s=new Array(i.length),l;for(l=0;l=0;--l)s[l]=p.subtract(a[l],p.multiplyByScalar(s[l+1],o[l],s[l]),s[l]);return s};var nC=n0t;var i0t=[],o0t=[],a0t=[],s0t=[];function vne(t,e,n){let i=i0t,o=a0t,a=o0t,s=s0t;i.length=o.length=t.length-1,a.length=s.length=t.length;let l;i[0]=a[0]=1,o[0]=0;let r=s[0];for(c(r)||(r=s[0]=new p),p.clone(e,r),l=1;l0&&t.afterRender.push(l._raiseStartEvent)),l.loop===xm.REPEAT)b=b-Math.floor(b);else if(l.loop===xm.MIRRORED_REPEAT){let G=Math.floor(b),A=b-G;b=G%2===1?1-A:A}l.reverse&&(b=1-b);let U=b*d*l.multiplier;U=k.clamp(U,l.localStartTime,l.localStopTime),l.animate(U),l.update.numberOfListeners>0&&(l._updateEventTime=U,t.afterRender.push(l._raiseUpdateEvent)),i=!0,F||(l._state=UZ.STOPPED,l.stop.numberOfListeners>0&&t.afterRender.push(l._raiseStopEvent),l.removeOnStop&&zw.push(l))}}n=zw.length;for(let s=0;s=s.clientWidth)d=!0;else{if(S.x>s.clientWidth*.5){l.width=S.x,r.frustum.right=u.x-G,qd=UY(a,n,r,qd),bd.clipToGLWindowCoordinates(l,qd,W$),l.x+=S.x,r.position.x=-r.position.x;let g=r.frustum.right;r.frustum.right=-r.frustum.left,r.frustum.left=-g,qd=UY(a,n,r,qd),bd.clipToGLWindowCoordinates(l,qd,f$)}else{l.x+=S.x,l.width-=S.x,r.frustum.left=-u.x-G,qd=UY(a,n,r,qd),bd.clipToGLWindowCoordinates(l,qd,W$),l.x=l.x-l.width,r.position.x=-r.position.x;let g=r.frustum.left;r.frustum.left=-r.frustum.right,r.frustum.right=-g,qd=UY(a,n,r,qd),bd.clipToGLWindowCoordinates(l,qd,f$)}p.clone(R,r.position),r.frustum=V.clone(),i=K.clone(W$,i),(i.x<0||i.x>s.clientWidth)&&(i.x=f$.x)}}if(o.mode!==Vt.SCENE2D||d){if(qd=UY(a,n,r,qd),qd.z<0&&!(r.frustum instanceof wn)&&!(r.frustum instanceof el))return;i=bd.clipToGLWindowCoordinates(l,qd,i)}return i.y=s.clientHeight-i.y,i};bd.wgs84ToDrawingBufferCoordinates=function(t,e,n){if(n=bd.wgs84ToWindowCoordinates(t,e,n),!!c(n))return bd.transformWindowToDrawingBuffer(t,n,n)};var r0=new p,pne=new gt;bd.computeActualWgs84Position=function(t,e,n){let i=t.mode;if(i===Vt.SCENE3D)return p.clone(e,n);let o=t.mapProjection,a=o.ellipsoid.cartesianToCartographic(e,pne);if(!c(a))return;if(o.project(a,r0),i===Vt.COLUMBUS_VIEW)return p.fromElements(r0.z,r0.x,r0.y,n);if(i===Vt.SCENE2D)return p.fromElements(0,r0.x,r0.y,n);let s=t.morphTime;return p.fromElements(k.lerp(r0.z,e.x,s),k.lerp(r0.x,e.y,s),k.lerp(r0.y,e.z,s),n)};var Hbt=new p,wbt=new p,Pbt=new L;bd.clipToGLWindowCoordinates=function(t,e,n){return p.divideByScalar(e,e.w,Hbt),L.computeViewportTransformation(t,0,1,Pbt),L.multiplyByPoint(Pbt,Hbt,wbt),K.fromCartesian3(wbt,n)};bd.transformWindowToDrawingBuffer=function(t,e,n){let i=t.canvas,o=t.drawingBufferWidth/i.clientWidth,a=t.drawingBufferHeight/i.clientHeight;return K.fromElements(e.x*o,e.y*a,n)};var Vne=new bt,vbt=new bt;bd.drawingBufferToWgs84Coordinates=function(t,e,n,i){let a=t.context.uniformState,s=a.currentFrustum,l=s.x,r=s.y;if(t.frameState.useLogDepth){let R=n*a.log2FarDepthFromNearPlusOne,V=Math.pow(2,R)-1;n=r*(1-l/(V+l))/(r-l)}let d=t.view.passState.viewport,m=bt.clone(bt.UNIT_W,Vne);m.x=(e.x-d.x)/d.width*2-1,m.y=(e.y-d.y)/d.height*2-1,m.z=n*2-1,m.w=1;let h,u=t.camera.frustum;if(c(u.fovy)){h=L.multiplyByVector(a.inverseViewProjection,m,vbt);let R=1/h.w;p.multiplyByScalar(h,R,h)}else{let R=u.offCenterFrustum;c(R)&&(u=R),h=vbt,h.x=(m.x*(u.right-u.left)+u.left+u.right)*.5,h.y=(m.y*(u.top-u.bottom)+u.bottom+u.top)*.5,h.z=(m.z*(l-r)-l-r)*.5,h.w=1,h=L.multiplyByVector(a.inverseView,h,h)}return p.fromCartesian4(h,i)};var qo=bd;var YLn=b(W(),1),une={LEFT:-1,NONE:0,RIGHT:1},Jc=Object.freeze(une);var NMn=b(W(),1);var _Ln=b(W(),1);var qE={};qE._deprecationWarning=ur;var d0=Uint32Array.BYTES_PER_ELEMENT;qE.parse=function(t,e){let n=f(e,0);e=n;let i=new Uint8Array(t),o=new DataView(t);e+=d0;let a=o.getUint32(e,!0);if(a!==1)throw new Tt(`Only Batched 3D Model version 1 is supported. Version ${a} is not.`);e+=d0;let s=o.getUint32(e,!0);e+=d0;let l=o.getUint32(e,!0);e+=d0;let r=o.getUint32(e,!0);e+=d0;let d=o.getUint32(e,!0);e+=d0;let m=o.getUint32(e,!0);e+=d0;let h;d>=570425344?(e-=d0*2,h=l,d=r,m=0,l=0,r=0,qE._deprecationWarning("b3dm-legacy-header","This b3dm header is using the legacy format [batchLength] [batchTableByteLength]. The new format is [featureTableJsonByteLength] [featureTableBinaryByteLength] [batchTableJsonByteLength] [batchTableBinaryByteLength] from https://github.com/CesiumGS/3d-tiles/tree/main/specification/TileFormats/Batched3DModel.")):m>=570425344&&(e-=d0,h=d,d=l,m=r,l=0,r=0,qE._deprecationWarning("b3dm-legacy-header","This b3dm header is using the legacy format [batchTableJsonByteLength] [batchTableBinaryByteLength] [batchLength]. The new format is [featureTableJsonByteLength] [featureTableBinaryByteLength] [batchTableJsonByteLength] [batchTableBinaryByteLength] from https://github.com/CesiumGS/3d-tiles/tree/main/specification/TileFormats/Batched3DModel."));let u;l===0?u={BATCH_LENGTH:f(h,0)}:(u=ts(i,e,l),e+=l);let R=new Uint8Array(t,e,r);e+=r;let V,F;d>0&&(V=ts(i,e,d),e+=d,m>0&&(F=new Uint8Array(t,e,m),F=new Uint8Array(F),e+=m));let U=n+s-e;if(U===0)throw new Tt("glTF byte length must be greater than 0.");let G;return e%4===0?G=new Uint8Array(t,e,U):(qE._deprecationWarning("b3dm-glb-unaligned","The embedded glb is not aligned to a 4-byte boundary."),G=new Uint8Array(i.subarray(e,e+U))),{batchLength:h,featureTableJson:u,featureTableBinary:R,batchTableJson:V,batchTableBinary:F,gltf:G}};var GY=qE;var PLn=b(W(),1);function AY(t,e){this.json=t,this.buffer=e,this._cachedTypedArrays={},this.featuresLength=0}function Kbt(t,e,n,i,o,a){let s=t._cachedTypedArrays,l=s[e];return c(l)||(l=it.createArrayBufferView(n,t.buffer.buffer,t.buffer.byteOffset+a,o*i),s[e]=l),l}function Zne(t,e,n,i){let o=t._cachedTypedArrays,a=o[e];return c(a)||(a=it.createTypedArray(n,i),o[e]=a),a}AY.prototype.getGlobalProperty=function(t,e,n){let i=this.json[t];if(c(i))return c(i.byteOffset)?(e=f(e,it.UNSIGNED_INT),n=f(n,1),Kbt(this,t,e,n,1,i.byteOffset)):i};AY.prototype.hasProperty=function(t){return c(this.json[t])};AY.prototype.getPropertyArray=function(t,e,n){let i=this.json[t];if(c(i))return c(i.byteOffset)?(c(i.componentType)&&(e=it.fromName(i.componentType)),Kbt(this,t,e,n,this.featuresLength,i.byteOffset)):Zne(this,t,e,i)};AY.prototype.getProperty=function(t,e,n,i,o){let a=this.json[t];if(!c(a))return;let s=this.getPropertyArray(t,e,n);if(n===1)return s[i];for(let l=0;l0&&(V=ts(i,e,d),e+=d,m>0&&(F=new Uint8Array(t,e,m),F=new Uint8Array(F),e+=m));let U=n+s-e;if(U===0)throw new Tt("glTF byte length must be greater than 0.");let G;return e%4===0?G=new Uint8Array(t,e,U):(Pw._deprecationWarning("i3dm-glb-unaligned","The embedded glb is not aligned to a 4-byte boundary."),G=new Uint8Array(i.subarray(e,e+U))),{gltfFormat:h,featureTableJson:u,featureTableBinary:R,batchTableJson:V,batchTableBinary:F,gltf:G}};var EY=Pw;var m0={NOT_LOADED:0,LOADING:1,PROCESSING:2,POST_PROCESSING:3,READY:4,FAILED:5,UNLOADED:6},vw=Sn.Attribute,xne=Sn.FeatureIdAttribute,e0t=Sn.Instances;function h0(t){t=f(t,f.EMPTY_OBJECT);let e=t.i3dmResource,n=t.arrayBuffer,i=t.baseResource,o=f(t.byteOffset,0),a=f(t.releaseGltfJson,!1),s=f(t.asynchronous,!0),l=f(t.incrementallyLoadTextures,!0),r=f(t.upAxis,$a.Y),d=f(t.forwardAxis,$a.X),m=f(t.loadAttributesAsTypedArray,!1),h=f(t.loadIndicesForWireframe,!1),u=f(t.loadPrimitiveOutline,!0),R=f(t.enablePick,!1);i=c(i)?i:e.clone(),this._i3dmResource=e,this._baseResource=i,this._arrayBuffer=n,this._byteOffset=o,this._releaseGltfJson=a,this._asynchronous=s,this._incrementallyLoadTextures=l,this._upAxis=r,this._forwardAxis=d,this._loadAttributesAsTypedArray=m,this._loadIndicesForWireframe=h,this._loadPrimitiveOutline=u,this._enablePick=R,this._state=m0.NOT_LOADED,this._promise=void 0,this._gltfLoader=void 0,this._buffers=[],this._components=void 0,this._transform=L.IDENTITY,this._batchTable=void 0,this._featureTable=void 0,this._instancesLength=0}c(Object.create)&&(h0.prototype=Object.create(Za.prototype),h0.prototype.constructor=h0);Object.defineProperties(h0.prototype,{texturesLoaded:{get:function(){return this._gltfLoader?.texturesLoaded}},cacheKey:{get:function(){}},components:{get:function(){return this._components}}});h0.prototype.load=function(){if(c(this._promise))return this._promise;let t=EY.parse(this._arrayBuffer,this._byteOffset),e=t.featureTableJson,n=t.featureTableBinary,i=t.batchTableJson,o=t.batchTableBinary,a=t.gltfFormat,s=new Fu(e,n);this._featureTable=s;let l=s.getGlobalProperty("INSTANCES_LENGTH");if(s.featuresLength=l,!c(l))throw new Tt("Feature table global property: INSTANCES_LENGTH must be defined");this._instancesLength=l;let r=s.getGlobalProperty("RTC_CENTER",it.FLOAT,3);c(r)&&(this._transform=L.fromTranslation(p.fromArray(r))),this._batchTable={json:i,binary:o};let d={upAxis:this._upAxis,forwardAxis:this._forwardAxis,releaseGltfJson:this._releaseGltfJson,incrementallyLoadTextures:this._incrementallyLoadTextures,loadAttributesAsTypedArray:this._loadAttributesAsTypedArray,enablePick:this._enablePick,loadIndicesForWireframe:this._loadIndicesForWireframe,loadPrimitiveOutline:this._loadPrimitiveOutline};if(a===0){let h=Im(t.gltf);h=h.replace(/[\s\0]+$/,"");let u=this._baseResource.getDerivedResource({url:h});d.gltfResource=u,d.baseResource=u}else d.gltfResource=this._i3dmResource,d.typedArray=t.gltf;let m=new s0(d);return this._gltfLoader=m,this._state=m0.LOADING,this._promise=m.load().then(()=>{if(!this.isDestroyed())return this._state=m0.PROCESSING,this}).catch(h=>{if(!this.isDestroyed())throw Xne(this,h)}),this._promise};function Xne(t,e){return t.unload(),t._state=m0.FAILED,t.getError("Failed to load i3dm",e)}h0.prototype.process=function(t){if(this._state===m0.READY)return!0;let e=this._gltfLoader,n=!1;if(this._state===m0.PROCESSING&&(n=e.process(t)),!n)return!1;let i=e.components;return i.transform=L.multiplyTransformation(this._transform,i.transform,i.transform),Mne(this,i,t),Jne(this,i),this._components=i,this._arrayBuffer=void 0,this._state=m0.READY,!0};function Jne(t,e){let n=t._batchTable,i=t._instancesLength;if(i===0)return;let o;if(c(n.json))o=c0({count:i,batchTable:n.json,binaryBody:n.binary});else{let a=new Xc({name:Vu.BATCH_TABLE_CLASS_NAME,count:i});o=new Rd({schema:{},propertyTables:[a]})}e.structuralMetadata=o}var Kw=new p,G$=new Array(4),Lne=new L;function Mne(t,e,n){let i,o=t._featureTable,a=t._instancesLength;if(a===0)return;let s=o.getGlobalProperty("RTC_CENTER",it.FLOAT,3),l=o.getGlobalProperty("EAST_NORTH_UP"),r=o.hasProperty("NORMAL_UP")||o.hasProperty("NORMAL_UP_OCT32P")||l,d=o.hasProperty("SCALE")||o.hasProperty("SCALE_NON_UNIFORM"),m=Dne(o,a),h;r&&(h=new Float32Array(4*a));let u;d&&(u=new Float32Array(3*a));let R=new Float32Array(a),V=p.unpackArray(m),F=new p,U=new p,G=new p,A=new p,S=new ot,g=new wt,C=new Array(4),y=new p,Y=new Array(3),Q=new L;if(!c(s)||p.equals(p.unpack(s),p.ZERO)){let w=Ft.fromPoints(V);for(i=0;i0&&(w.instances=P?_ne(J):J,P=!0)}}function _ne(t){let e=new e0t;e.transformInWorldSpace=t.transformInWorldSpace;let n=t.attributes,i=n.length;for(let o=0;o=n[e]){if(e+1=0&&t>=n[e-1])return e-1;let o;if(t>n[e])for(o=e;o=n[o]&&t=0&&!(t>=n[o]&&tn&&(a=Math.floor((t-n)/o)+1,t-=a*o),t};$E.prototype.clampTime=function(t){let e=this.times;return k.clamp(t,e[0],e[e.length-1])};var Ra=$E;function tC(t){this._value=t,this._valueType=Ra.getPointType(t)}Object.defineProperties(tC.prototype,{value:{get:function(){return this._value}}});tC.prototype.findTimeInterval=function(t){};tC.prototype.wrapTime=function(t){return 0};tC.prototype.clampTime=function(t){return 0};tC.prototype.evaluate=function(t,e){let n=this._value,i=this._valueType;return i===Number?n:i.clone(n,e)};var IY=tC;var h9n=b(W(),1);var $_n=b(W(),1);function eC(t){t=f(t,f.EMPTY_OBJECT);let e=t.points,n=t.times;this._times=n,this._points=e,this._pointType=Ra.getPointType(e[0]),this._lastTimeIndex=0}Object.defineProperties(eC.prototype,{times:{get:function(){return this._times}},points:{get:function(){return this._points}}});eC.prototype.findTimeInterval=Ra.prototype.findTimeInterval;eC.prototype.wrapTime=Ra.prototype.wrapTime;eC.prototype.clampTime=Ra.prototype.clampTime;eC.prototype.evaluate=function(t,e){let n=this.points,i=this.times,o=this._lastTimeIndex=this.findTimeInterval(t,this._lastTimeIndex),a=(t-i[o])/(i[o+1]-i[o]);return this._pointType===Number?(1-a)*n[o]+a*n[o+1]:(c(e)||(e=new p),p.lerp(n[o],n[o+1],a,e))};var qf=eC;var n9n=b(W(),1);var n0t={};n0t.solve=function(t,e,n,i){let o=new Array(n.length),a=new Array(i.length),s=new Array(i.length),l;for(l=0;l=0;--l)s[l]=p.subtract(a[l],p.multiplyByScalar(s[l+1],o[l],s[l]),s[l]);return s};var nC=n0t;var i0t=[],o0t=[],a0t=[],s0t=[];function vne(t,e,n){let i=i0t,o=a0t,a=o0t,s=s0t;i.length=o.length=t.length-1,a.length=s.length=t.length;let l;i[0]=a[0]=1,o[0]=0;let r=s[0];for(c(r)||(r=s[0]=new p),p.clone(e,r),l=1;l0&&t.afterRender.push(l._raiseStartEvent)),l.loop===xm.REPEAT)R=R-Math.floor(R);else if(l.loop===xm.MIRRORED_REPEAT){let G=Math.floor(R),A=R-G;R=G%2===1?1-A:A}l.reverse&&(R=1-R);let U=R*d*l.multiplier;U=k.clamp(U,l.localStartTime,l.localStopTime),l.animate(U),l.update.numberOfListeners>0&&(l._updateEventTime=U,t.afterRender.push(l._raiseUpdateEvent)),i=!0,F||(l._state=Uu.STOPPED,l.stop.numberOfListeners>0&&t.afterRender.push(l._raiseStopEvent),l.removeOnStop&&zw.push(l))}}n=zw.length;for(let s=0;ss||o<-s&&a>-s}function lC(t,e){if(!c(e))return;let n=u0.clone(e),i=Ee.shallowClone(e.command);return i.modelMatrix=t._modelMatrix2D,i.boundingVolume=t._boundingVolume2D,n.command=i,n.updateShadows=!1,n.is2D=!0,e.derivedCommand2D=n,t._derivedCommands.push(n),n}function Rie(t){lC(t,t._originalCommand),lC(t,t._translucentCommand),lC(t,t._skipLodBackfaceCommand),lC(t,t._skipLodStencilCommand),lC(t,t._silhouetteModelCommand),lC(t,t._silhouetteColorCommand)}function Wie(t){let e=Ee.shallowClone(t);e.pass=Pt.TRANSLUCENT;let n=be(t.renderState,!0);return n.cull.enabled=!1,n.depthMask=!1,n.blending=Pn.ALPHA_BLEND,e.renderState=he.fromCache(n),e}function fie(t,e){let n=e._silhouetteId%255,i=Ee.shallowClone(t),o=be(t.renderState,!0);return o.stencilTest={enabled:!0,frontFunction:pt.ALWAYS,backFunction:pt.ALWAYS,reference:n,mask:-1,frontOperation:{fail:pt.KEEP,zFail:pt.KEEP,zPass:pt.REPLACE},backOperation:{fail:pt.KEEP,zFail:pt.KEEP,zPass:pt.REPLACE}},e.isInvisible()&&(o.colorMask={red:!1,green:!1,blue:!1,alpha:!1}),i.renderState=he.fromCache(o),i}function Fie(t,e){let n=e._silhouetteId%255,i=Ee.shallowClone(t),o=be(t.renderState,!0);o.cull.enabled=!1,(t.pass===Pt.TRANSLUCENT||e.silhouetteColor.alpha<1)&&(i.pass=Pt.TRANSLUCENT,o.depthMask=!1,o.blending=Pn.ALPHA_BLEND),o.stencilTest={enabled:!0,frontFunction:pt.NOTEQUAL,backFunction:pt.NOTEQUAL,reference:n,mask:-1,frontOperation:{fail:pt.KEEP,zFail:pt.KEEP,zPass:pt.KEEP},backOperation:{fail:pt.KEEP,zFail:pt.KEEP,zPass:pt.KEEP}};let s=be(t.uniformMap);return s.model_silhouettePass=function(){return!0},i.renderState=he.fromCache(o),i.uniformMap=s,i.castShadows=!1,i.receiveShadows=!1,i}function Uie(t,e,n){let i=t._skipLodStencilCommand,o=i.command,a=e._selectionDepth,s=Gie(o);if(a!==s){let l=Aie(a),r=be(o.renderState,!0);r.stencilTest.reference=l,o.renderState=he.fromCache(r),n&&(i.derivedCommand2D.renderState=r)}}function Gie(t){return(t.renderState.stencilTest.reference&gn.SKIP_LOD_MASK)>>>gn.SKIP_LOD_BIT_SHIFT}function Aie(t){return gn.CESIUM_3D_TILE_MASK|t<s||o<-s&&a>-s}function lC(t,e){if(!c(e))return;let n=V0.clone(e),i=Ee.shallowClone(e.command);return i.modelMatrix=t._modelMatrix2D,i.boundingVolume=t._boundingVolume2D,n.command=i,n.updateShadows=!1,n.is2D=!0,e.derivedCommand2D=n,t._derivedCommands.push(n),n}function bie(t){lC(t,t._originalCommand),lC(t,t._translucentCommand),lC(t,t._skipLodBackfaceCommand),lC(t,t._skipLodStencilCommand),lC(t,t._silhouetteModelCommand),lC(t,t._silhouetteColorCommand)}function Wie(t){let e=Ee.shallowClone(t);e.pass=Pt.TRANSLUCENT;let n=Re(t.renderState,!0);return n.cull.enabled=!1,n.depthMask=!1,n.blending=Pn.ALPHA_BLEND,e.renderState=he.fromCache(n),e}function fie(t,e){let n=e._silhouetteId%255,i=Ee.shallowClone(t),o=Re(t.renderState,!0);return o.stencilTest={enabled:!0,frontFunction:pt.ALWAYS,backFunction:pt.ALWAYS,reference:n,mask:-1,frontOperation:{fail:pt.KEEP,zFail:pt.KEEP,zPass:pt.REPLACE},backOperation:{fail:pt.KEEP,zFail:pt.KEEP,zPass:pt.REPLACE}},e.isInvisible()&&(o.colorMask={red:!1,green:!1,blue:!1,alpha:!1}),i.renderState=he.fromCache(o),i}function Fie(t,e){let n=e._silhouetteId%255,i=Ee.shallowClone(t),o=Re(t.renderState,!0);o.cull.enabled=!1,(t.pass===Pt.TRANSLUCENT||e.silhouetteColor.alpha<1)&&(i.pass=Pt.TRANSLUCENT,o.depthMask=!1,o.blending=Pn.ALPHA_BLEND),o.stencilTest={enabled:!0,frontFunction:pt.NOTEQUAL,backFunction:pt.NOTEQUAL,reference:n,mask:-1,frontOperation:{fail:pt.KEEP,zFail:pt.KEEP,zPass:pt.KEEP},backOperation:{fail:pt.KEEP,zFail:pt.KEEP,zPass:pt.KEEP}};let s=Re(t.uniformMap);return s.model_silhouettePass=function(){return!0},i.renderState=he.fromCache(o),i.uniformMap=s,i.castShadows=!1,i.receiveShadows=!1,i}function Uie(t,e,n){let i=t._skipLodStencilCommand,o=i.command,a=e._selectionDepth,s=Gie(o);if(a!==s){let l=Aie(a),r=Re(o.renderState,!0);r.stencilTest.reference=l,o.renderState=he.fromCache(r),n&&(i.derivedCommand2D.renderState=r)}}function Gie(t){return(t.renderState.stencilTest.reference&gn.SKIP_LOD_MASK)>>>gn.SKIP_LOD_BIT_SHIFT}function Aie(t){return gn.CESIUM_3D_TILE_MASK|t<k.EPSILON3}};var vY=p0t;var PDn=R(W(),1);var LDn=R(W(),1),KY=`vec3 proceduralIBL( +`;var p0t={name:"AtmospherePipelineStage"};p0t.process=function(t,e,n){let i=t.shaderBuilder;i.addDefine("HAS_ATMOSPHERE",void 0,Xt.BOTH),i.addDefine("COMPUTE_POSITION_WC_ATMOSPHERE",void 0,Xt.BOTH),i.addVarying("vec3","v_atmosphereRayleighColor"),i.addVarying("vec3","v_atmosphereMieColor"),i.addVarying("float","v_atmosphereOpacity"),i.addVertexLines([PY]),i.addFragmentLines([wY]),i.addUniform("bool","u_isInFog",Xt.FRAGMENT),t.uniformMap.u_isInFog=function(){let o=p.distance(n.camera.positionWC,e.boundingSphere.center);return k.fog(o,n.fog.density)>k.EPSILON3}};var vY=p0t;var PDn=b(W(),1);var LDn=b(W(),1),KY=`vec3 proceduralIBL( vec3 positionEC, vec3 normalEC, vec3 lightDirectionEC, @@ -6913,14 +6913,14 @@ vec3 imageBasedLightingStage( pbrParameters ); #endif -}`;var u0t={name:"ImageBasedLightingPipelineStage"};u0t.process=function(t,e,n){let i=e.imageBasedLighting,o=t.shaderBuilder;o.addDefine("USE_IBL_LIGHTING",void 0,Xt.FRAGMENT),o.addUniform("vec2","model_iblFactor",Xt.FRAGMENT),dZ.isSupported(n.context)&&((i.useSphericalHarmonics||i.useSpecularEnvironmentMaps||i.enabled)&&o.addUniform("mat3","model_iblReferenceFrameMatrix",Xt.FRAGMENT),c(i.sphericalHarmonicCoefficients)?(o.addDefine("DIFFUSE_IBL",void 0,Xt.FRAGMENT),o.addDefine("CUSTOM_SPHERICAL_HARMONICS",void 0,Xt.FRAGMENT),o.addUniform("vec3","model_sphericalHarmonicCoefficients[9]",Xt.FRAGMENT)):i.useDefaultSphericalHarmonics&&o.addDefine("DIFFUSE_IBL",void 0,Xt.FRAGMENT),c(i.specularEnvironmentMapAtlas)&&i.specularEnvironmentMapAtlas.ready?(o.addDefine("SPECULAR_IBL",void 0,Xt.FRAGMENT),o.addDefine("CUSTOM_SPECULAR_IBL",void 0,Xt.FRAGMENT),o.addUniform("sampler2D","model_specularEnvironmentMaps",Xt.FRAGMENT),o.addUniform("vec2","model_specularEnvironmentMapsSize",Xt.FRAGMENT),o.addUniform("float","model_specularEnvironmentMapsMaximumLOD",Xt.FRAGMENT)):e.useDefaultSpecularMaps&&o.addDefine("SPECULAR_IBL",void 0,Xt.FRAGMENT)),c(i.luminanceAtZenith)&&(o.addDefine("USE_SUN_LUMINANCE",void 0,Xt.FRAGMENT),o.addUniform("float","model_luminanceAtZenith",Xt.FRAGMENT)),o.addFragmentLines(KY);let a={model_iblFactor:function(){return i.imageBasedLightingFactor},model_iblReferenceFrameMatrix:function(){return e._iblReferenceFrameMatrix},model_luminanceAtZenith:function(){return i.luminanceAtZenith},model_sphericalHarmonicCoefficients:function(){return i.sphericalHarmonicCoefficients},model_specularEnvironmentMaps:function(){return i.specularEnvironmentMapAtlas.texture},model_specularEnvironmentMapsSize:function(){return i.specularEnvironmentMapAtlas.texture.dimensions},model_specularEnvironmentMapsMaximumLOD:function(){return i.specularEnvironmentMapAtlas.maximumMipmapLevel}};t.uniformMap=ze(a,t.uniformMap)};var zY=u0t;var lOn=R(W(),1);var eOn=R(W(),1);var Cie=k.EPSILON16;function I$(t){t=f(t,f.EMPTY_OBJECT);let e=t.stage,n=t.runtimeArticulation;this._stage=e,this._runtimeArticulation=n,this._name=e.name,this._type=e.type,this._minimumValue=e.minimumValue,this._maximumValue=e.maximumValue,this._currentValue=e.initialValue}Object.defineProperties(I$.prototype,{stage:{get:function(){return this._stage}},runtimeArticulation:{get:function(){return this._runtimeArticulation}},name:{get:function(){return this._name}},type:{get:function(){return this._type}},minimumValue:{get:function(){return this._minimumValue}},maximumValue:{get:function(){return this._maximumValue}},currentValue:{get:function(){return this._currentValue},set:function(t){t=k.clamp(t,this.minimumValue,this.maximumValue),k.equalsEpsilon(this._currentValue,t,Cie)||(this._currentValue=t,this.runtimeArticulation._dirty=!0)}}});var Iie=new p,C$=new ot;I$.prototype.applyStageToMatrix=function(t){let e=this.type,n=this.currentValue,i=Iie,o;switch(e){case zd.XROTATE:o=ot.fromRotationX(k.toRadians(n),C$),t=L.multiplyByMatrix3(t,o,t);break;case zd.YROTATE:o=ot.fromRotationY(k.toRadians(n),C$),t=L.multiplyByMatrix3(t,o,t);break;case zd.ZROTATE:o=ot.fromRotationZ(k.toRadians(n),C$),t=L.multiplyByMatrix3(t,o,t);break;case zd.XTRANSLATE:i.x=n,i.y=0,i.z=0,t=L.multiplyByTranslation(t,i,t);break;case zd.YTRANSLATE:i.x=0,i.y=n,i.z=0,t=L.multiplyByTranslation(t,i,t);break;case zd.ZTRANSLATE:i.x=0,i.y=0,i.z=n,t=L.multiplyByTranslation(t,i,t);break;case zd.XSCALE:i.x=n,i.y=1,i.z=1,t=L.multiplyByScale(t,i,t);break;case zd.YSCALE:i.x=1,i.y=n,i.z=1,t=L.multiplyByScale(t,i,t);break;case zd.ZSCALE:i.x=1,i.y=1,i.z=n,t=L.multiplyByScale(t,i,t);break;case zd.UNIFORMSCALE:t=L.multiplyByUniformScale(t,n,t);break;default:break}return t};var jY=I$;function qw(t){t=f(t,f.EMPTY_OBJECT);let e=t.articulation,n=t.sceneGraph;this._articulation=e,this._sceneGraph=n,this._name=e.name,this._runtimeStages=[],this._runtimeStagesByName={},this._runtimeNodes=[],this._dirty=!0,Nie(this)}Object.defineProperties(qw.prototype,{articulation:{get:function(){return this._articulation}},sceneGraph:{get:function(){return this._sceneGraph}},name:{get:function(){return this._name}},runtimeStages:{get:function(){return this._runtimeStages}},runtimeNodes:{get:function(){return this._runtimeNodes}}});function Nie(t){let n=t.articulation.stages,i=n.length,o=t._runtimeStages,a=t._runtimeStagesByName;for(let s=0;s=t.featureIdVertexAttributeSetIndex&&(t.featureIdVertexAttributeSetIndex=l.setIndex+1),i.push({index:t.attributeIndex++,vertexBuffer:l.buffer,componentsPerAttribute:_n.getNumberOfComponents(l.type),componentDatatype:l.componentDatatype,normalize:!1,offsetInBytes:l.byteOffset,strideInBytes:l.byteStride,instanceDivisor:1}),a.addAttribute("float",`a_instanceFeatureId_${l.setIndex}`))}}var cx=W0t;var RHn=R(W(),1);var Q$={};Q$.name="ModelMatrixUpdateStage";Q$.update=function(t,e,n){let i=n.mode!==ut.SCENE3D;if(!(i&&e._model._projectTo2D)&&t._transformDirty){let o=i?e._computedModelMatrix2D:e._computedModelMatrix;T0t(t,e,o,t.transformToRoot),t._transformDirty=!1}};function T0t(t,e,n,i){let o;i=L.multiplyTransformation(i,t.transform,new L),t.updateComputedTransform();let a=t.runtimePrimitives.length;for(o=0;o1&&(i.addDefine("MULTILINE_BATCH_TEXTURE"),i.addUniform("vec2","model_textureDimensions"),o.model_textureDimensions=function(){return r.textureDimensions}),t.uniformMap=ze(o,t.uniformMap)};var Zx=I0t;var zHn=R(W(),1);var N0t={name:"ClassificationPipelineStage"};N0t.process=function(t,e,n){t.shaderBuilder.addDefine("HAS_CLASSIFICATION",void 0,Xt.BOTH);let o=t.runtimePrimitive;c(o.batchLengths)||noe(e,o)};function noe(t,e){let n=Mn.getAttributeBySemantic(t,sn.POSITION);if(!c(n))throw new St("Primitives must have a position attribute to be used for classification.");let i,o=t.indices,a=c(o);a&&(i=o.typedArray,o.typedArray=void 0);let s=a?o.count:n.count,l=Mn.getAttributeBySemantic(t,sn.FEATURE_ID,0);if(!c(l)){e.batchLengths=[s],e.batchOffsets=[0];return}let r=l.typedArray;l.typedArray=void 0;let d=[],m=[0],h=a?i[0]:0,Z=r[h],b=0;for(let F=1;F=t.featureIdVertexAttributeSetIndex&&(t.featureIdVertexAttributeSetIndex=l.setIndex+1),i.push({index:t.attributeIndex++,vertexBuffer:l.buffer,componentsPerAttribute:_n.getNumberOfComponents(l.type),componentDatatype:l.componentDatatype,normalize:!1,offsetInBytes:l.byteOffset,strideInBytes:l.byteStride,instanceDivisor:1}),a.addAttribute("float",`a_instanceFeatureId_${l.setIndex}`))}}var cx=W0t;var bHn=b(W(),1);var Q$={};Q$.name="ModelMatrixUpdateStage";Q$.update=function(t,e,n){let i=n.mode!==Vt.SCENE3D;if(!(i&&e._model._projectTo2D)&&t._transformDirty){let o=i?e._computedModelMatrix2D:e._computedModelMatrix;S0t(t,e,o,t.transformToRoot),t._transformDirty=!1}};function S0t(t,e,n,i){let o;i=L.multiplyTransformation(i,t.transform,new L),t.updateComputedTransform();let a=t.runtimePrimitives.length;for(o=0;o1&&(i.addDefine("MULTILINE_BATCH_TEXTURE"),i.addUniform("vec2","model_textureDimensions"),o.model_textureDimensions=function(){return r.textureDimensions}),t.uniformMap=ze(o,t.uniformMap)};var ux=I0t;var zHn=b(W(),1);var N0t={name:"ClassificationPipelineStage"};N0t.process=function(t,e,n){t.shaderBuilder.addDefine("HAS_CLASSIFICATION",void 0,Xt.BOTH);let o=t.runtimePrimitive;c(o.batchLengths)||noe(e,o)};function noe(t,e){let n=Mn.getAttributeBySemantic(t,sn.POSITION);if(!c(n))throw new Tt("Primitives must have a position attribute to be used for classification.");let i,o=t.indices,a=c(o);a&&(i=o.typedArray,o.typedArray=void 0);let s=a?o.count:n.count,l=Mn.getAttributeBySemantic(t,sn.FEATURE_ID,0);if(!c(l)){e.batchLengths=[s],e.batchOffsets=[0];return}let r=l.typedArray;l.typedArray=void 0;let d=[],m=[0],h=a?i[0]:0,u=r[h],R=0;for(let F=1;Fhoe(i,e,n)):[]}function hoe(t,e,n){let{getAttributeByName:i,getAttributeInfo:o,sanitizeGlslIdentifier:a}=Mn,s=t.class.id,l=n?.classes[s],r=Object.entries(t.properties),d=new Array(r.length);for(let m=0;muoe(n,e)):[]}function uoe(t,e){let{sanitizeGlslIdentifier:n}=Mn,i=t.class.id,o=e?.classes[i],a=Object.entries(t.properties).filter(([l,r])=>r.isGpuCompatible()),s=new Array(a.length);for(let l=0;lm),n.addStructField(go.STRUCT_ID_METADATA_FS,a,o);let b=`attributes.texCoord_${l}`,u=b;if(c(h)&&!ot.equals(h,ot.IDENTITY)){let T=`${Z}Transform`;n.addUniform("mat3",T,Xt.FRAGMENT),i[T]=function(){return h},u=`vec2(${T} * vec3(${b}, 1.0))`}let F=`texture(${Z}, ${u}).${r}`,U=s.unpackInShader(F),G=J0t({valueExpression:U,renderResources:t,glslType:a,metadataVariable:o,shaderDestination:Xt.FRAGMENT,property:s}),A=`metadata.${o} = ${G};`;n.addFunctionLines(go.FUNCTION_ID_INITIALIZE_METADATA_FS,[A])}function Y0t(t,e){let{classProperty:n}=e.property,{metadataVariable:i,glslType:o,shaderDestination:a}=e,s=X0t(go.METADATA_CLASS_FIELDS,n,`metadataClass.${i}`,o),l=`${o}MetadataClass`;t.addStructField(go.STRUCT_ID_METADATA_CLASS_FS,l,i),t.addFunctionLines(go.FUNCTION_ID_INITIALIZE_METADATA_FS,s),Xt.includesVertexShader(a)&&(t.addStructField(go.STRUCT_ID_METADATA_CLASS_VS,l,i),t.addFunctionLines(go.FUNCTION_ID_INITIALIZE_METADATA_VS,s))}function x0t(t,e){let{propertyStatistics:n}=e;if(!c(n))return;let{metadataVariable:i,type:o,glslType:a}=e;if(o===Nn.ENUM)return;let s=go.METADATA_STATISTICS_FIELDS,l=`metadataStatistics.${i}`,r=X0t(s,n,l,a),d=`${a}MetadataStatistics`;t.addStructField(go.STRUCT_ID_METADATA_STATISTICS_FS,d,i),t.addFunctionLines(go.FUNCTION_ID_INITIALIZE_METADATA_FS,r),Xt.includesVertexShader(e.shaderDestination)&&(t.addStructField(go.STRUCT_ID_METADATA_STATISTICS_VS,d,i),t.addFunctionLines(go.FUNCTION_ID_INITIALIZE_METADATA_VS,r))}function X0t(t,e,n,i){function o(a){let s=e[a.specName];if(c(s))return`${n}.${a.shaderName} = ${i}(${s});`}return c(e)?t.map(o).filter(c):[]}function J0t(t){let{valueExpression:e,property:n}=t;if(!n.hasValueTransform)return e;let i=t.metadataVariable,o=`u_${i}_offset`,a=`u_${i}_scale`,{shaderBuilder:s,uniformMap:l}=t.renderResources,{glslType:r,shaderDestination:d}=t;s.addUniform(r,o,d),s.addUniform(r,a,d);let{offset:m,scale:h}=n;return l[o]=()=>m,l[a]=()=>h,`czm_valueTransform(${o}, ${a}, ${e})`}var _p=go;var vwn=R(W(),1),Goe={INHERIT:0,OPAQUE:1,TRANSLUCENT:2},iF=Object.freeze(Goe);var Hr={name:"CustomShaderPipelineStage",STRUCT_ID_ATTRIBUTES_VS:"AttributesVS",STRUCT_ID_ATTRIBUTES_FS:"AttributesFS",STRUCT_NAME_ATTRIBUTES:"Attributes",STRUCT_ID_VERTEX_INPUT:"VertexInput",STRUCT_NAME_VERTEX_INPUT:"VertexInput",STRUCT_ID_FRAGMENT_INPUT:"FragmentInput",STRUCT_NAME_FRAGMENT_INPUT:"FragmentInput",FUNCTION_ID_INITIALIZE_INPUT_STRUCT_VS:"initializeInputStructVS",FUNCTION_SIGNATURE_INITIALIZE_INPUT_STRUCT_VS:"void initializeInputStruct(out VertexInput vsInput, ProcessedAttributes attributes)",FUNCTION_ID_INITIALIZE_INPUT_STRUCT_FS:"initializeInputStructFS",FUNCTION_SIGNATURE_INITIALIZE_INPUT_STRUCT_FS:"void initializeInputStruct(out FragmentInput fsInput, ProcessedAttributes attributes)",_oneTimeWarning:Gn};Hr.process=function(t,e,n){let{shaderBuilder:i,model:o,alphaOptions:a}=t,{customShader:s}=o,{lightingModel:l,translucencyMode:r}=s;c(l)&&(t.lightingOptions.lightingModel=l),r===iF.TRANSLUCENT?a.pass=Pt.TRANSLUCENT:r===iF.OPAQUE&&(a.pass=void 0);let d=Noe(s,e);if(!d.customShaderEnabled)return;if(koe(i,s,d),d.shouldComputePositionWC&&i.addDefine("COMPUTE_POSITION_WC_CUSTOM_SHADER",void 0,Xt.BOTH),c(s.vertexShaderText)&&i.addDefine("HAS_CUSTOM_VERTEX_SHADER",void 0,Xt.VERTEX),c(s.fragmentShaderText)){i.addDefine("HAS_CUSTOM_FRAGMENT_SHADER",void 0,Xt.FRAGMENT);let Z=Z0.getDefineName(s.mode);i.addDefine(Z,void 0,Xt.FRAGMENT)}let m=s.uniforms;for(let Z in m)if(m.hasOwnProperty(Z)){let b=m[Z];i.addUniform(b.type,Z)}let h=s.varyings;for(let Z in h)if(h.hasOwnProperty(Z)){let b=h[Z];i.addVarying(b,Z)}t.uniformMap=ze(t.uniformMap,s.uniformMap)};function Aoe(t){let e={};for(let n=0;nhoe(i,e,n)):[]}function hoe(t,e,n){let{getAttributeByName:i,getAttributeInfo:o,sanitizeGlslIdentifier:a}=Mn,s=t.class.id,l=n?.classes[s],r=Object.entries(t.properties),d=new Array(r.length);for(let m=0;mVoe(n,e)):[]}function Voe(t,e){let{sanitizeGlslIdentifier:n}=Mn,i=t.class.id,o=e?.classes[i],a=Object.entries(t.properties).filter(([l,r])=>r.isGpuCompatible()),s=new Array(a.length);for(let l=0;lm),n.addStructField(go.STRUCT_ID_METADATA_FS,a,o);let R=`attributes.texCoord_${l}`,V=R;if(c(h)&&!ot.equals(h,ot.IDENTITY)){let S=`${u}Transform`;n.addUniform("mat3",S,Xt.FRAGMENT),i[S]=function(){return h},V=`vec2(${S} * vec3(${R}, 1.0))`}let F=`texture(${u}, ${V}).${r}`,U=s.unpackInShader(F),G=J0t({valueExpression:U,renderResources:t,glslType:a,metadataVariable:o,shaderDestination:Xt.FRAGMENT,property:s}),A=`metadata.${o} = ${G};`;n.addFunctionLines(go.FUNCTION_ID_INITIALIZE_METADATA_FS,[A])}function Y0t(t,e){let{classProperty:n}=e.property,{metadataVariable:i,glslType:o,shaderDestination:a}=e,s=X0t(go.METADATA_CLASS_FIELDS,n,`metadataClass.${i}`,o),l=`${o}MetadataClass`;t.addStructField(go.STRUCT_ID_METADATA_CLASS_FS,l,i),t.addFunctionLines(go.FUNCTION_ID_INITIALIZE_METADATA_FS,s),Xt.includesVertexShader(a)&&(t.addStructField(go.STRUCT_ID_METADATA_CLASS_VS,l,i),t.addFunctionLines(go.FUNCTION_ID_INITIALIZE_METADATA_VS,s))}function x0t(t,e){let{propertyStatistics:n}=e;if(!c(n))return;let{metadataVariable:i,type:o,glslType:a}=e;if(o===Nn.ENUM)return;let s=go.METADATA_STATISTICS_FIELDS,l=`metadataStatistics.${i}`,r=X0t(s,n,l,a),d=`${a}MetadataStatistics`;t.addStructField(go.STRUCT_ID_METADATA_STATISTICS_FS,d,i),t.addFunctionLines(go.FUNCTION_ID_INITIALIZE_METADATA_FS,r),Xt.includesVertexShader(e.shaderDestination)&&(t.addStructField(go.STRUCT_ID_METADATA_STATISTICS_VS,d,i),t.addFunctionLines(go.FUNCTION_ID_INITIALIZE_METADATA_VS,r))}function X0t(t,e,n,i){function o(a){let s=e[a.specName];if(c(s))return`${n}.${a.shaderName} = ${i}(${s});`}return c(e)?t.map(o).filter(c):[]}function J0t(t){let{valueExpression:e,property:n}=t;if(!n.hasValueTransform)return e;let i=t.metadataVariable,o=`u_${i}_offset`,a=`u_${i}_scale`,{shaderBuilder:s,uniformMap:l}=t.renderResources,{glslType:r,shaderDestination:d}=t;s.addUniform(r,o,d),s.addUniform(r,a,d);let{offset:m,scale:h}=n;return l[o]=()=>m,l[a]=()=>h,`czm_valueTransform(${o}, ${a}, ${e})`}var _p=go;var vwn=b(W(),1),Goe={INHERIT:0,OPAQUE:1,TRANSLUCENT:2},iF=Object.freeze(Goe);var Hr={name:"CustomShaderPipelineStage",STRUCT_ID_ATTRIBUTES_VS:"AttributesVS",STRUCT_ID_ATTRIBUTES_FS:"AttributesFS",STRUCT_NAME_ATTRIBUTES:"Attributes",STRUCT_ID_VERTEX_INPUT:"VertexInput",STRUCT_NAME_VERTEX_INPUT:"VertexInput",STRUCT_ID_FRAGMENT_INPUT:"FragmentInput",STRUCT_NAME_FRAGMENT_INPUT:"FragmentInput",FUNCTION_ID_INITIALIZE_INPUT_STRUCT_VS:"initializeInputStructVS",FUNCTION_SIGNATURE_INITIALIZE_INPUT_STRUCT_VS:"void initializeInputStruct(out VertexInput vsInput, ProcessedAttributes attributes)",FUNCTION_ID_INITIALIZE_INPUT_STRUCT_FS:"initializeInputStructFS",FUNCTION_SIGNATURE_INITIALIZE_INPUT_STRUCT_FS:"void initializeInputStruct(out FragmentInput fsInput, ProcessedAttributes attributes)",_oneTimeWarning:Gn};Hr.process=function(t,e,n){let{shaderBuilder:i,model:o,alphaOptions:a}=t,{customShader:s}=o,{lightingModel:l,translucencyMode:r}=s;c(l)&&(t.lightingOptions.lightingModel=l),r===iF.TRANSLUCENT?a.pass=Pt.TRANSLUCENT:r===iF.OPAQUE&&(a.pass=void 0);let d=Noe(s,e);if(!d.customShaderEnabled)return;if(koe(i,s,d),d.shouldComputePositionWC&&i.addDefine("COMPUTE_POSITION_WC_CUSTOM_SHADER",void 0,Xt.BOTH),c(s.vertexShaderText)&&i.addDefine("HAS_CUSTOM_VERTEX_SHADER",void 0,Xt.VERTEX),c(s.fragmentShaderText)){i.addDefine("HAS_CUSTOM_FRAGMENT_SHADER",void 0,Xt.FRAGMENT);let u=u0.getDefineName(s.mode);i.addDefine(u,void 0,Xt.FRAGMENT)}let m=s.uniforms;for(let u in m)if(m.hasOwnProperty(u)){let R=m[u];i.addUniform(R.type,u)}let h=s.varyings;for(let u in h)if(h.hasOwnProperty(u)){let R=h[u];i.addVarying(R,u)}t.uniformMap=ze(t.uniformMap,s.uniformMap)};function Aoe(t){let e={};for(let n=0;n1?(u=t.attributeIndex,t.attributeIndex+=Z):b&&!r?u=0:u=t.attributeIndex++,_oe(t,h,u,Z,s,l)}joe(i,e.attributes),e.primitiveType===le.POINTS&&i.addDefine("PRIMITIVE_TYPE_POINTS"),i.addVertexLines(Ix),i.addFragmentLines(Cx)};function _oe(t,e,n,i,o,a){let s=t.shaderBuilder,l=Mn.getAttributeInfo(e),r=o&&!a;i>1?Hoe(t,e,n,i):Ooe(t,e,n,r),Poe(s,l,r),woe(s,l),c(e.semantic)&&Doe(s,e),voe(s,l,o),Koe(s,l,r),zoe(s,l)}function Doe(t,e){let n=e.semantic,i=e.setIndex;switch(n){case sn.NORMAL:t.addDefine("HAS_NORMALS");break;case sn.TANGENT:t.addDefine("HAS_TANGENTS");break;case sn.FEATURE_ID:t.addDefine(`HAS${n}_${i}`);break;case sn.TEXCOORD:case sn.COLOR:t.addDefine(`HAS_${n}_${i}`)}}function Ooe(t,e,n,i){let o=e.quantization,a,s;c(o)?(a=o.type,s=o.componentDatatype):(a=e.type,s=e.componentDatatype);let l=e.semantic,r=e.setIndex;l===sn.FEATURE_ID&&r>=t.featureIdVertexAttributeSetIndex&&(t.featureIdVertexAttributeSetIndex=r+1);let d=l===sn.POSITION,m=d?0:n,h=_n.getNumberOfComponents(a),Z={index:m,value:c(e.buffer)?void 0:e.constant,vertexBuffer:e.buffer,count:e.count,componentsPerAttribute:h,componentDatatype:s,offsetInBytes:e.byteOffset,strideInBytes:e.byteStride,normalize:e.normalized};if(t.attributes.push(Z),!d||!i)return;let b=t.runtimePrimitive.positionBuffer2D,u={index:n,vertexBuffer:b,count:e.count,componentsPerAttribute:h,componentDatatype:it.FLOAT,offsetInBytes:0,strideInBytes:void 0,normalize:e.normalized};t.attributes.push(u)}function Hoe(t,e,n,i){let o=e.quantization,a,s;c(o)?(a=o.type,s=o.componentDatatype):(a=e.type,s=e.componentDatatype);let l=e.normalized,d=_n.getNumberOfComponents(a)/i,m=it.getSizeInBytes(s),h=d*m,Z=e.byteStride;for(let b=0;b1?(V=t.attributeIndex,t.attributeIndex+=u):R&&!r?V=0:V=t.attributeIndex++,_oe(t,h,V,u,s,l)}joe(i,e.attributes),e.primitiveType===le.POINTS&&i.addDefine("PRIMITIVE_TYPE_POINTS"),i.addVertexLines(Ix),i.addFragmentLines(Cx)};function _oe(t,e,n,i,o,a){let s=t.shaderBuilder,l=Mn.getAttributeInfo(e),r=o&&!a;i>1?Hoe(t,e,n,i):Ooe(t,e,n,r),Poe(s,l,r),woe(s,l),c(e.semantic)&&Doe(s,e),voe(s,l,o),Koe(s,l,r),zoe(s,l)}function Doe(t,e){let n=e.semantic,i=e.setIndex;switch(n){case sn.NORMAL:t.addDefine("HAS_NORMALS");break;case sn.TANGENT:t.addDefine("HAS_TANGENTS");break;case sn.FEATURE_ID:t.addDefine(`HAS${n}_${i}`);break;case sn.TEXCOORD:case sn.COLOR:t.addDefine(`HAS_${n}_${i}`)}}function Ooe(t,e,n,i){let o=e.quantization,a,s;c(o)?(a=o.type,s=o.componentDatatype):(a=e.type,s=e.componentDatatype);let l=e.semantic,r=e.setIndex;l===sn.FEATURE_ID&&r>=t.featureIdVertexAttributeSetIndex&&(t.featureIdVertexAttributeSetIndex=r+1);let d=l===sn.POSITION,m=d?0:n,h=_n.getNumberOfComponents(a),u={index:m,value:c(e.buffer)?void 0:e.constant,vertexBuffer:e.buffer,count:e.count,componentsPerAttribute:h,componentDatatype:s,offsetInBytes:e.byteOffset,strideInBytes:e.byteStride,normalize:e.normalized};if(t.attributes.push(u),!d||!i)return;let R=t.runtimePrimitive.positionBuffer2D,V={index:n,vertexBuffer:R,count:e.count,componentsPerAttribute:h,componentDatatype:it.FLOAT,offsetInBytes:0,strideInBytes:void 0,normalize:e.normalized};t.attributes.push(V)}function Hoe(t,e,n,i){let o=e.quantization,a,s;c(o)?(a=o.type,s=o.componentDatatype):(a=e.type,s=e.componentDatatype);let l=e.normalized,d=_n.getNumberOfComponents(a)/i,m=it.getSizeInBytes(s),h=d*m,u=e.byteStride;for(let R=0;R0,d=!c(l)&&r;if(c(a)&&!d){let F=bae(l),U=Rae(a,F);Wae(i,U);let A=fae(U).indexOf("normalMC")>=0,T=Mn.getAttributeBySemantic(e,sn.NORMAL);if(A&&!T)throw new St("Style references the NORMAL semantic but the point cloud does not have normals");i.addDefine("COMPUTE_POSITION_WC_STYLE",void 0,Xt.VERTEX),U.styleTranslucent&&(t.alphaOptions.pass=Pt.TRANSLUCENT)}let m=o.pointCloudShading;m.attenuation&&i.addDefine("HAS_POINT_CLOUD_ATTENUATION",void 0,Xt.VERTEX),m.backFaceCulling&&i.addDefine("HAS_POINT_CLOUD_BACK_FACE_CULLING",void 0,Xt.VERTEX);let h,Z,b;Is.is3DTiles(o.type)&&(Z=!0,h=o.content,b=h.tile.refine===ss.ADD),i.addUniform("vec4","model_pointCloudParameters",Xt.VERTEX),i.addVertexLines(Lx);let u=t.uniformMap;u.model_pointCloudParameters=function(){let F=pae,U=1;Z&&(U=b?5:h.tileset.memoryAdjustedScreenSpaceError),F.x=f(m.maximumAttenuation,U),F.x*=n.pixelRatio;let G=uae(t,e,m,h);F.y=G*m.geometricErrorScale;let A=n.context,T=n.camera.frustum,g;return n.mode===ut.SCENE2D||T instanceof wn?g=Number.POSITIVE_INFINITY:g=A.drawingBufferHeight/n.camera.frustum.sseDenominator,F.z=g,Z&&(F.w=h.tileset.timeSinceLoad),F}};var j0t=new p;function uae(t,e,n,i){if(c(i)){let m=i.tile.geometricError;if(m>0)return m}if(c(n.baseResolution))return n.baseResolution;let o=Mn.getAttributeBySemantic(e,sn.POSITION),a=o.count,s=t.runtimeNode.transform,l=p.subtract(o.max,o.min,j0t);l=L.multiplyByPointAsVector(s,l,j0t);let r=l.x*l.y*l.z;return k.cbrt(r/a)}var Zae={colorStyleFunction:void 0,showStyleFunction:void 0,pointSizeStyleFunction:void 0,styleTranslucent:!1},Vae={POSITION:"attributes.positionMC",POSITION_ABSOLUTE:"v_positionWC",COLOR:"attributes.color_0",NORMAL:"attributes.normalMC"};function bae(t){let e=be(Vae);if(!c(t))return e;for(let n=0;n0,d=!c(l)&&r;if(c(a)&&!d){let F=Rae(l),U=bae(a,F);Wae(i,U);let A=fae(U).indexOf("normalMC")>=0,S=Mn.getAttributeBySemantic(e,sn.NORMAL);if(A&&!S)throw new Tt("Style references the NORMAL semantic but the point cloud does not have normals");i.addDefine("COMPUTE_POSITION_WC_STYLE",void 0,Xt.VERTEX),U.styleTranslucent&&(t.alphaOptions.pass=Pt.TRANSLUCENT)}let m=o.pointCloudShading;m.attenuation&&i.addDefine("HAS_POINT_CLOUD_ATTENUATION",void 0,Xt.VERTEX),m.backFaceCulling&&i.addDefine("HAS_POINT_CLOUD_BACK_FACE_CULLING",void 0,Xt.VERTEX);let h,u,R;Is.is3DTiles(o.type)&&(u=!0,h=o.content,R=h.tile.refine===ss.ADD),i.addUniform("vec4","model_pointCloudParameters",Xt.VERTEX),i.addVertexLines(Lx);let V=t.uniformMap;V.model_pointCloudParameters=function(){let F=pae,U=1;u&&(U=R?5:h.tileset.memoryAdjustedScreenSpaceError),F.x=f(m.maximumAttenuation,U),F.x*=n.pixelRatio;let G=Vae(t,e,m,h);F.y=G*m.geometricErrorScale;let A=n.context,S=n.camera.frustum,g;return n.mode===Vt.SCENE2D||S instanceof wn?g=Number.POSITIVE_INFINITY:g=A.drawingBufferHeight/n.camera.frustum.sseDenominator,F.z=g,u&&(F.w=h.tileset.timeSinceLoad),F}};var j0t=new p;function Vae(t,e,n,i){if(c(i)){let m=i.tile.geometricError;if(m>0)return m}if(c(n.baseResolution))return n.baseResolution;let o=Mn.getAttributeBySemantic(e,sn.POSITION),a=o.count,s=t.runtimeNode.transform,l=p.subtract(o.max,o.min,j0t);l=L.multiplyByPointAsVector(s,l,j0t);let r=l.x*l.y*l.z;return k.cbrt(r/a)}var uae={colorStyleFunction:void 0,showStyleFunction:void 0,pointSizeStyleFunction:void 0,styleTranslucent:!1},Zae={POSITION:"attributes.positionMC",POSITION_ABSOLUTE:"v_positionWC",COLOR:"attributes.color_0",NORMAL:"attributes.normalMC"};function Rae(t){let e=Re(Zae);if(!c(t))return e;for(let n=0;n0,Z=c(i.skin),b=c(a),F=!(b&&c(a.fragmentShaderText))||a.mode!==Z0.REPLACE_MATERIAL,U=Mn.hasQuantizedAttributes(n.attributes),G=o.debugWireframe&&le.isTriangles(n.primitiveType)&&(o._enableDebugWireframe||l),A=o.pointCloudShading,T=c(A)&&A.attenuation,g=c(A)&&A.backFaceCulling,C=n.primitiveType===le.POINTS&&(c(s)||T||g),y=o._enableShowOutline&&c(n.outlineCoordinates),Y=_ae(o,i,n),Q=c(o.classificationType);d&&e.push(wx),e.push(yx),G&&e.push(jx),Q&&e.push(Vx),h&&e.push(Xx),Z&&e.push(vx),C&&e.push(Mx),U&&e.push(Ex),F&&e.push(Yx),e.push(nF),e.push(_p),Y.hasPropertyTable&&(e.push(oF),e.push(Zx),e.push(Wx)),m&&e.push(zx),b&&e.push(Sx),e.push(Qx),o.allowPicking&&e.push(Jx),y&&e.push(Ox),e.push(ux),e.push(Hx)};function _ae(t,e,n){let i;return c(e.instances)&&(i=Mn.getFeatureIdsByLabel(e.instances.featureIds,t.instanceFeatureIdLabel),c(i))?{hasFeatureIds:!0,hasPropertyTable:c(i.propertyTableId)}:(i=Mn.getFeatureIdsByLabel(n.featureIds,t.featureIdLabel),c(i)?{hasFeatureIds:!0,hasPropertyTable:c(i.propertyTableId)}:{hasFeatureIds:!1,hasPropertyTable:!1})}var qx=mWt;var v3n=R(W(),1);function M$(t){t=f(t,f.EMPTY_OBJECT),this._sceneGraph=t.sceneGraph;let e=t.skin;this._skin=e,this._inverseBindMatrices=void 0,this._joints=[],this._jointMatrices=[],Dae(this)}Object.defineProperties(M$.prototype,{skin:{get:function(){return this._skin}},sceneGraph:{get:function(){return this._sceneGraph}},inverseBindMatrices:{get:function(){return this._inverseBindMatrices}},joints:{get:function(){return this._joints}},jointMatrices:{get:function(){return this._jointMatrices}}});function Dae(t){let e=t.skin,n=e.inverseBindMatrices;t._inverseBindMatrices=n;let i=e.joints,o=i.length,a=t.sceneGraph._runtimeNodes,s=t.joints,l=t._jointMatrices;for(let r=0;r0,u=c(i.skin),R=c(a),F=!(R&&c(a.fragmentShaderText))||a.mode!==u0.REPLACE_MATERIAL,U=Mn.hasQuantizedAttributes(n.attributes),G=o.debugWireframe&&le.isTriangles(n.primitiveType)&&(o._enableDebugWireframe||l),A=o.pointCloudShading,S=c(A)&&A.attenuation,g=c(A)&&A.backFaceCulling,C=n.primitiveType===le.POINTS&&(c(s)||S||g),y=o._enableShowOutline&&c(n.outlineCoordinates),Y=_ae(o,i,n),Q=c(o.classificationType);d&&e.push(wx),e.push(yx),G&&e.push(jx),Q&&e.push(Zx),h&&e.push(Xx),u&&e.push(vx),C&&e.push(Mx),U&&e.push(Ex),F&&e.push(Yx),e.push(nF),e.push(_p),Y.hasPropertyTable&&(e.push(oF),e.push(ux),e.push(Wx)),m&&e.push(zx),R&&e.push(Tx),e.push(Qx),o.allowPicking&&e.push(Jx),y&&e.push(Ox),e.push(Vx),e.push(Hx)};function _ae(t,e,n){let i;return c(e.instances)&&(i=Mn.getFeatureIdsByLabel(e.instances.featureIds,t.instanceFeatureIdLabel),c(i))?{hasFeatureIds:!0,hasPropertyTable:c(i.propertyTableId)}:(i=Mn.getFeatureIdsByLabel(n.featureIds,t.featureIdLabel),c(i)?{hasFeatureIds:!0,hasPropertyTable:c(i.propertyTableId)}:{hasFeatureIds:!1,hasPropertyTable:!1})}var qx=mWt;var vKn=b(W(),1);function M$(t){t=f(t,f.EMPTY_OBJECT),this._sceneGraph=t.sceneGraph;let e=t.skin;this._skin=e,this._inverseBindMatrices=void 0,this._joints=[],this._jointMatrices=[],Dae(this)}Object.defineProperties(M$.prototype,{skin:{get:function(){return this._skin}},sceneGraph:{get:function(){return this._sceneGraph}},inverseBindMatrices:{get:function(){return this._inverseBindMatrices}},joints:{get:function(){return this._joints}},jointMatrices:{get:function(){return this._jointMatrices}}});function Dae(t){let e=t.skin,n=e.inverseBindMatrices;t._inverseBindMatrices=n;let i=e.joints,o=i.length,a=t.sceneGraph._runtimeNodes,s=t.joints,l=t._jointMatrices;for(let r=0;r 0.0 && gl_FragCoord.x < czm_splitPosition) discard; #endif } -`;var eP={name:"ModelSplitterPipelineStage",SPLIT_DIRECTION_UNIFORM_NAME:"model_splitDirection"};eP.process=function(t,e,n){let i=t.shaderBuilder;i.addDefine("HAS_MODEL_SPLITTER",void 0,Xt.FRAGMENT),i.addFragmentLines(aX);let o={};i.addUniform("float",eP.SPLIT_DIRECTION_UNIFORM_NAME,Xt.FRAGMENT),o[eP.SPLIT_DIRECTION_UNIFORM_NAME]=function(){return e.splitDirection},t.uniformMap=ze(o,t.uniformMap)};var sX=eP;var Gzn=R(W(),1);function wae(t,e){this.model=t.model,this.shaderBuilder=t.shaderBuilder.clone(),this.uniformMap=be(t.uniformMap),this.alphaOptions=be(t.alphaOptions),this.renderStateOptions=be(t.renderStateOptions,!0),this.hasSilhouette=t.hasSilhouette,this.hasSkipLevelOfDetail=t.hasSkipLevelOfDetail,this.runtimeNode=e,this.attributes=[],this.attributeIndex=1,this.featureIdVertexAttributeSetIndex=0,this.instanceCount=0}var lX=wae;var kzn=R(W(),1);var gzn=R(W(),1);function Pae(t){t=f(t,f.EMPTY_OBJECT),this.lightingModel=f(t.lightingModel,nb.UNLIT)}var rX=Pae;function vae(t,e){this.model=t.model,this.runtimeNode=t.runtimeNode,this.attributes=t.attributes.slice(),this.attributeIndex=t.attributeIndex,this.featureIdVertexAttributeSetIndex=t.featureIdVertexAttributeSetIndex,this.uniformMap=be(t.uniformMap),this.alphaOptions=be(t.alphaOptions),this.renderStateOptions=be(t.renderStateOptions,!0),this.hasSilhouette=t.hasSilhouette,this.hasSkipLevelOfDetail=t.hasSkipLevelOfDetail,this.shaderBuilder=t.shaderBuilder.clone(),this.instanceCount=t.instanceCount,this.runtimePrimitive=e;let n=e.primitive;this.count=c(n.indices)?n.indices.count:Mn.getAttributeBySemantic(n,"POSITION").count,this.hasPropertyTable=!1,this.indices=n.indices,this.wireframeIndexBuffer=void 0,this.primitiveType=n.primitiveType;let i=Mn.getPositionMinMax(n,this.runtimeNode.instancingTranslationMin,this.runtimeNode.instancingTranslationMax);this.positionMin=p.clone(i.min,new p),this.positionMax=p.clone(i.max,new p),this.boundingSphere=Ft.fromCornerPoints(this.positionMin,this.positionMax,new Ft),this.lightingOptions=new rX,this.pickId=void 0}var dX=vae;function Nh(t){t=f(t,f.EMPTY_OBJECT);let e=t.modelComponents;this._model=t.model,this._components=e,this._pipelineStages=[],this._updateStages=[],this._runtimeNodes=[],this._rootNodes=[],this._skinnedNodes=[],this._runtimeSkins=[],this.modelPipelineStages=[],this._boundingSphere=void 0,this._boundingSphere2D=void 0,this._computedModelMatrix=L.clone(L.IDENTITY),this._computedModelMatrix2D=L.clone(L.IDENTITY),this._axisCorrectionMatrix=Mn.getAxisCorrectionMatrix(e.upAxis,e.forwardAxis,new L),this._runtimeArticulations={},Kae(this)}Object.defineProperties(Nh.prototype,{components:{get:function(){return this._components}},computedModelMatrix:{get:function(){return this._computedModelMatrix}},axisCorrectionMatrix:{get:function(){return this._axisCorrectionMatrix}},boundingSphere:{get:function(){return this._boundingSphere}}});function Kae(t){let e=t._components,n=e.scene,o=t._model.modelMatrix;pWt(t,o);let a=e.articulations,s=a.length,l=t._runtimeArticulations;for(let A=0;A0&&(h=ts(n,e,l),e+=l,r>0&&(Z=new Uint8Array(t,e,r),e+=r));let b=new FZ(d,m),u=b.getGlobalProperty("POINTS_LENGTH");if(b.featuresLength=u,!c(u))throw new St("Feature table global property: POINTS_LENGTH must be defined");let F=b.getGlobalProperty("RTC_CENTER",it.FLOAT,3);c(F)&&(F=p.unpack(F));let U=cse(b,h);if(U.rtcCenter=F,U.pointsLength=u,!U.hasPositions){let G=mse(b);U.positions=G,U.hasPositions=U.hasPositions||c(G)}if(!U.hasPositions)throw new St("Either POSITION or POSITION_QUANTIZED must be defined.");if(!U.hasNormals){let G=pse(b);U.normals=G,U.hasNormals=U.hasNormals||c(G)}if(!U.hasColors){let G=hse(b);U.colors=G,U.hasColors=U.hasColors||c(G),U.hasConstantColor=c(U.constantColor),U.isTranslucent=c(G)&&G.isTranslucent}if(!U.hasBatchIds){let G=use(b);U.batchIds=G,U.hasBatchIds=U.hasBatchIds||c(G)}if(U.hasBatchIds){let G=b.getGlobalProperty("BATCH_LENGTH");if(!c(G))throw new St("Global property: BATCH_LENGTH must be defined when BATCH_ID is defined.");U.batchLength=G}return c(Z)&&(Z=new Uint8Array(Z),U.batchTableJson=h,U.batchTableBinary=Z),U};function cse(t,e){let n=t.json,i,o,a,s=c(n.extensions)?n.extensions["3DTILES_draco_point_compression"]:void 0,l=c(e)&&c(e.extensions)?e.extensions["3DTILES_draco_point_compression"]:void 0;c(l)&&(a=l.properties);let r,d,m,h,Z;if(c(s)){o=s.properties;let u=s.byteOffset,F=s.byteLength;if(!c(o)||!c(u)||!c(F))throw new St("Draco properties, byteOffset, and byteLength must be defined");i=t.buffer.slice(u,u+F),r=c(o.POSITION),d=c(o.RGB)||c(o.RGBA),m=c(o.NORMAL),h=c(o.BATCH_ID),Z=c(o.RGBA)}let b;return c(i)&&(b={buffer:i,featureTableProperties:o,batchTableProperties:a,properties:ze(o,a),dequantizeInShader:!0}),{draco:b,hasPositions:r,hasColors:d,isTranslucent:Z,hasNormals:m,hasBatchIds:h}}function mse(t){let e=t.json,n;if(c(e.POSITION))return n=t.getPropertyArray("POSITION",it.FLOAT,3),{name:sn.POSITION,semantic:sn.POSITION,typedArray:n,isQuantized:!1,componentDatatype:it.FLOAT,type:_n.VEC3};if(c(e.POSITION_QUANTIZED)){n=t.getPropertyArray("POSITION_QUANTIZED",it.UNSIGNED_SHORT,3);let i=t.getGlobalProperty("QUANTIZED_VOLUME_SCALE",it.FLOAT,3);if(!c(i))throw new St("Global property: QUANTIZED_VOLUME_SCALE must be defined for quantized positions.");let o=65535,a=t.getGlobalProperty("QUANTIZED_VOLUME_OFFSET",it.FLOAT,3);if(!c(a))throw new St("Global property: QUANTIZED_VOLUME_OFFSET must be defined for quantized positions.");return{name:sn.POSITION,semantic:sn.POSITION,typedArray:n,isQuantized:!0,componentDatatype:it.FLOAT,type:_n.VEC3,quantizedRange:o,quantizedVolumeOffset:p.unpack(a),quantizedVolumeScale:p.unpack(i),quantizedComponentDatatype:it.UNSIGNED_SHORT,quantizedType:_n.VEC3}}}function hse(t){let e=t.json,n;if(c(e.RGBA))return n=t.getPropertyArray("RGBA",it.UNSIGNED_BYTE,4),{name:sn.COLOR,semantic:sn.COLOR,setIndex:0,typedArray:n,componentDatatype:it.UNSIGNED_BYTE,type:_n.VEC4,normalized:!0,isRGB565:!1,isTranslucent:!0};if(c(e.RGB))return n=t.getPropertyArray("RGB",it.UNSIGNED_BYTE,3),{name:"COLOR",semantic:sn.COLOR,setIndex:0,typedArray:n,componentDatatype:it.UNSIGNED_BYTE,type:_n.VEC3,normalized:!0,isRGB565:!1,isTranslucent:!1};if(c(e.RGB565))return n=t.getPropertyArray("RGB565",it.UNSIGNED_SHORT,1),{name:"COLOR",semantic:sn.COLOR,setIndex:0,typedArray:n,componentDatatype:it.FLOAT,type:_n.VEC3,normalized:!1,isRGB565:!0,isTranslucent:!1};if(c(e.CONSTANT_RGBA)){let i=t.getGlobalProperty("CONSTANT_RGBA",it.UNSIGNED_BYTE,4),o=i[3],a=v.fromBytes(i[0],i[1],i[2],o),s=o<255;return{name:sn.COLOR,semantic:sn.COLOR,setIndex:0,constantColor:a,componentDatatype:it.FLOAT,type:_n.VEC4,isQuantized:!1,isTranslucent:s}}}function pse(t){let e=t.json,n;if(c(e.NORMAL))return n=t.getPropertyArray("NORMAL",it.FLOAT,3),{name:sn.NORMAL,semantic:sn.NORMAL,typedArray:n,octEncoded:!1,octEncodedZXY:!1,componentDatatype:it.FLOAT,type:_n.VEC3};if(c(e.NORMAL_OCT16P))return n=t.getPropertyArray("NORMAL_OCT16P",it.UNSIGNED_BYTE,2),{name:sn.NORMAL,semantic:sn.NORMAL,typedArray:n,octEncoded:!0,octEncodedZXY:!1,quantizedRange:(1<<8)-1,quantizedType:_n.VEC2,quantizedComponentDatatype:it.UNSIGNED_BYTE,componentDatatype:it.FLOAT,type:_n.VEC3}}function use(t){let e=t.json;if(c(e.BATCH_ID)){let n=t.getPropertyArray("BATCH_ID",it.UNSIGNED_SHORT,1);return{name:sn.FEATURE_ID,semantic:sn.FEATURE_ID,setIndex:0,typedArray:n,componentDatatype:it.fromTypedArray(n),type:_n.SCALAR}}}var xA=bWt;var Zse=Tn.Components,Vse=Tn.Scene,bse=Tn.Node,Rse=Tn.Primitive,Wse=Tn.Attribute,RWt=Tn.Quantization,fse=Tn.FeatureIdAttribute,Fse=Tn.Material,Use=Tn.MetallicRoughness;function sF(t){t=f(t,f.EMPTY_OBJECT);let e=t.arrayBuffer,n=f(t.byteOffset,0);this._arrayBuffer=e,this._byteOffset=n,this._loadAttributesFor2D=f(t.loadAttributesFor2D,!1),this._parsedContent=void 0,this._decodePromise=void 0,this._decodedAttributes=void 0,this._promise=void 0,this._error=void 0,this._state=pn.UNLOADED,this._buffers=[],this._components=void 0,this._transform=L.IDENTITY}c(Object.create)&&(sF.prototype=Object.create(Va.prototype),sF.prototype.constructor=sF);Object.defineProperties(sF.prototype,{cacheKey:{get:function(){}},components:{get:function(){return this._components}},transform:{get:function(){return this._transform}}});sF.prototype.load=function(){if(c(this._promise))return this._promise;this._parsedContent=xA.parse(this._arrayBuffer,this._byteOffset),this._state=pn.PROCESSING,this._promise=Promise.resolve(this)};sF.prototype.process=function(t){if(c(this._error)){let e=this._error;throw this._error=void 0,e}if(this._state===pn.READY)return!0;if(this._state===pn.PROCESSING){if(c(this._decodePromise))return!1;this._decodePromise=Gse(this,t.context)}return!1};function Gse(t,e){let i=t._parsedContent.draco,o;if(c(i)?o=$R.decodePointCloud(i,e):o=Promise.resolve(),!!c(o))return t._decodePromise=o,o.then(function(a){if(!t.isDestroyed())return c(a)&&Ase(t,i,a),kse(t,e),t._state=pn.READY,t}).catch(function(a){t.unload(),t._state=pn.FAILED;let s="Failed to load Draco pnts";t._error=t.getError(s,a)})}function Ase(t,e,n){t._state=pn.READY;let i=t._parsedContent,o;if(c(n.POSITION)){if(o={name:"POSITION",semantic:sn.POSITION,typedArray:n.POSITION.array,componentDatatype:it.FLOAT,type:_n.VEC3,isQuantized:!1},c(n.POSITION.data.quantization)){let l=n.POSITION.data.quantization,r=l.range,d=p.fromElements(r,r,r),m=p.unpack(l.minValues),h=(1<0&&Yse(t,l,h,e),c(n.rtcCenter)&&(m.transform=L.multiplyByTranslation(m.transform,n.rtcCenter,m.transform));let Z=n.positions;c(Z)&&Z.isQuantized&&(m.transform=L.multiplyByTranslation(m.transform,Z.quantizedVolumeOffset,m.transform)),t._components=m,t._parsedContent=void 0,t._arrayBuffer=void 0}function Yse(t,e,n,i){let o=e.attributes,a=n.length;for(let s=0;s=0&&(l=Nt)}}}}if(l!==Number.MAX_VALUE){if(s=di.getPoint(e,l,s),n.mode!==ut.SCENE3D){p.fromElements(s.y,s.z,s.x,s);let m=n.mapProjection,h=m.ellipsoid,Z=m.unproject(s,Dse);h.cartographicToCartesian(Z,s)}return s}}function _$(t,e,n,i,o,a,s,l,r,d){let m=n+e*i;if(d.x=t[m],d.y=t[m+1],d.z=t[m+2],c(o))if(o.octEncoded){if(d=Ni.octDecodeInRange(d,o.normalizationRange,d),o.octEncodedZXY){let h=d.x;d.x=d.z,d.z=d.y,d.y=h}}else d=p.multiplyComponents(d,o.quantizedVolumeStepSize,d),d=p.add(d,o.quantizedVolumeOffset,d);return d=L.multiplyByPoint(a,d,d),s!==1&&Ps.getPosition(d,r,s,l,d),d}function Ia(t){t=f(t,f.EMPTY_OBJECT),this._loader=t.loader,this._resource=t.resource,this.type=f(t.type,Is.GLTF),this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._modelMatrix=L.clone(this.modelMatrix),this._scale=f(t.scale,1),this._minimumPixelSize=f(t.minimumPixelSize,0),this._maximumScale=t.maximumScale,this._clampedScale=c(this._maximumScale)?Math.min(this._scale,this._maximumScale):this._scale,this._computedScale=this._clampedScale,this._updateModelMatrix=!1,this.referenceMatrix=void 0,this._iblReferenceFrameMatrix=ot.clone(ot.IDENTITY),this._resourcesLoaded=!1,this._drawCommandsBuilt=!1,this._ready=!1,this._customShader=t.customShader,this._content=t.content,this._texturesLoaded=!1,this._defaultTexture=void 0,this._activeAnimations=new kY(this),this._clampAnimations=f(t.clampAnimations,!0),this._userAnimationDirty=!1,this._id=t.id,this._idDirty=!1,this._color=v.clone(t.color),this._colorBlendMode=f(t.colorBlendMode,Kd.HIGHLIGHT),this._colorBlendAmount=f(t.colorBlendAmount,.5);let e=f(t.silhouetteColor,v.RED);this._silhouetteColor=v.clone(e),this._silhouetteSize=f(t.silhouetteSize,0),this._silhouetteDirty=!1,this._silhouetteId=void 0,this._cull=f(t.cull,!0),this._opaquePass=f(t.opaquePass,Pt.OPAQUE),this._allowPicking=f(t.allowPicking,!0),this._show=f(t.show,!0),this._style=void 0,this._styleDirty=!1,this._styleCommandsNeeded=void 0;let n=f(t.featureIdLabel,"featureId_0");typeof n=="number"&&(n=`featureId_${n}`),this._featureIdLabel=n;let i=f(t.instanceFeatureIdLabel,"instanceFeatureId_0");typeof i=="number"&&(i=`instanceFeatureId_${i}`),this._instanceFeatureIdLabel=i,this._featureTables=[],this._featureTableId=void 0,this._featureTableIdDirty=!0,this._pipelineResources=[],this._modelResources=[],this._pickIds=[],this._boundingSphere=new Ft,this._initialRadius=void 0,this._heightReference=f(t.heightReference,Ge.NONE),this._heightDirty=this._heightReference!==Ge.NONE,this._removeUpdateHeightCallback=void 0,this._verticalExaggerationOn=!1,this._clampedModelMatrix=void 0;let o=t.scene;c(o)&&c(o.terrainProviderChanged)&&(this._terrainProviderChangedCallback=o.terrainProviderChanged.addEventListener(()=>{this._heightDirty=!0})),this._scene=o,this._distanceDisplayCondition=t.distanceDisplayCondition;let a=new eb(t.pointCloudShading);this._pointCloudShading=a,this._attenuation=a.attenuation,this._pointCloudBackFaceCulling=a.backFaceCulling;let s=t.clippingPlanes;c(s)&&s.owner===void 0?Ml.setOwner(s,this,"_clippingPlanes"):this._clippingPlanes=s,this._clippingPlanesState=0,this._clippingPlanesMatrix=L.clone(L.IDENTITY);let l=t.clippingPolygons;c(l)&&l.owner===void 0?RZ.setOwner(l,this,"_clippingPolygons"):this._clippingPolygons=l,this._clippingPolygonsState=0,this._lightColor=p.clone(t.lightColor),this._imageBasedLighting=c(t.imageBasedLighting)?t.imageBasedLighting:new aA,this._shouldDestroyImageBasedLighting=!c(t.imageBasedLighting),this._backFaceCulling=f(t.backFaceCulling,!0),this._backFaceCullingDirty=!1,this._shadows=f(t.shadows,ui.ENABLED),this._shadowsDirty=!1,this._debugShowBoundingVolumeDirty=!1,this._debugShowBoundingVolume=f(t.debugShowBoundingVolume,!1),this._enableDebugWireframe=f(t.enableDebugWireframe,!1),this._enableShowOutline=f(t.enableShowOutline,!0),this._debugWireframe=f(t.debugWireframe,!1),this._debugWireframe===!0&&this._enableDebugWireframe===!1&&this.type===Is.GLTF&&Gn("model-debug-wireframe-ignored","enableDebugWireframe must be set to true in Model.fromGltf, otherwise debugWireframe will be ignored.");let r=t.credit;typeof r=="string"&&(r=new on(r)),this._credits=[],this._credit=r,this._resourceCredits=[],this._gltfCredits=[],this._showCreditsOnScreen=f(t.showCreditsOnScreen,!1),this._showCreditsOnScreenDirty=!0,this._splitDirection=f(t.splitDirection,Jc.NONE),this._enableShowOutline=f(t.enableShowOutline,!0),this.showOutline=f(t.showOutline,!0),this.outlineColor=f(t.outlineColor,v.BLACK),this._classificationType=t.classificationType,this._statistics=new mX,this._sceneMode=void 0,this._projectTo2D=f(t.projectTo2D,!1),this._enablePick=f(t.enablePick,!1),this._fogRenderable=void 0,this._skipLevelOfDetail=!1,this._ignoreCommands=f(t.ignoreCommands,!1),this._errorEvent=new It,this._readyEvent=new It,this._texturesReadyEvent=new It,this._sceneGraph=void 0,this._nodesByName={},this.pickObject=t.pickObject}function D$(t,e){if(t._errorEvent.numberOfListeners>0){t._errorEvent.raiseEvent(e);return}console.log(e)}function Hse(t,e){let n=t._featureTables,i=e.propertyTables,o=i.length;for(let a=0;a0&&e===0||t===0&&e>0;this._silhouetteDirty=this._silhouetteDirty||n,this._backFaceCullingDirty=this._backFaceCullingDirty||n}this._silhouetteSize=t}},boundingSphere:{get:function(){let t=c(this._clampedModelMatrix)?this._clampedModelMatrix:this.modelMatrix;return GWt(this,t),this._boundingSphere}},debugShowBoundingVolume:{get:function(){return this._debugShowBoundingVolume},set:function(t){this._debugShowBoundingVolume!==t&&(this._debugShowBoundingVolumeDirty=!0),this._debugShowBoundingVolume=t}},debugWireframe:{get:function(){return this._debugWireframe},set:function(t){this._debugWireframe!==t&&this.resetDrawCommands(),this._debugWireframe=t,this._debugWireframe===!0&&this._enableDebugWireframe===!1&&this.type===Is.GLTF&&Gn("model-debug-wireframe-ignored","enableDebugWireframe must be set to true in Model.fromGltfAsync, otherwise debugWireframe will be ignored.")}},show:{get:function(){return this._show},set:function(t){this._show=t}},featureIdLabel:{get:function(){return this._featureIdLabel},set:function(t){typeof t=="number"&&(t=`featureId_${t}`),t!==this._featureIdLabel&&(this._featureTableIdDirty=!0),this._featureIdLabel=t}},instanceFeatureIdLabel:{get:function(){return this._instanceFeatureIdLabel},set:function(t){typeof t=="number"&&(t=`instanceFeatureId_${t}`),t!==this._instanceFeatureIdLabel&&(this._featureTableIdDirty=!0),this._instanceFeatureIdLabel=t}},clippingPlanes:{get:function(){return this._clippingPlanes},set:function(t){t!==this._clippingPlanes&&(Ml.setOwner(t,this,"_clippingPlanes"),this.resetDrawCommands())}},clippingPolygons:{get:function(){return this._clippingPolygons},set:function(t){t!==this._clippingPolygons&&(RZ.setOwner(t,this,"_clippingPolygons"),this.resetDrawCommands())}},lightColor:{get:function(){return this._lightColor},set:function(t){c(t)!==c(this._lightColor)&&this.resetDrawCommands(),this._lightColor=p.clone(t,this._lightColor)}},imageBasedLighting:{get:function(){return this._imageBasedLighting},set:function(t){t!==this._imageBasedLighting&&(this._shouldDestroyImageBasedLighting&&!this._imageBasedLighting.isDestroyed()&&this._imageBasedLighting.destroy(),this._imageBasedLighting=t,this._shouldDestroyImageBasedLighting=!1,this.resetDrawCommands())}},backFaceCulling:{get:function(){return this._backFaceCulling},set:function(t){t!==this._backFaceCulling&&(this._backFaceCullingDirty=!0),this._backFaceCulling=t}},scale:{get:function(){return this._scale},set:function(t){t!==this._scale&&(this._updateModelMatrix=!0),this._scale=t}},computedScale:{get:function(){return this._computedScale}},minimumPixelSize:{get:function(){return this._minimumPixelSize},set:function(t){t!==this._minimumPixelSize&&(this._updateModelMatrix=!0),this._minimumPixelSize=t}},maximumScale:{get:function(){return this._maximumScale},set:function(t){t!==this._maximumScale&&(this._updateModelMatrix=!0),this._maximumScale=t}},shadows:{get:function(){return this._shadows},set:function(t){t!==this._shadows&&(this._shadowsDirty=!0),this._shadows=t}},credit:{get:function(){return this._credit}},showCreditsOnScreen:{get:function(){return this._showCreditsOnScreen},set:function(t){this._showCreditsOnScreen!==t&&(this._showCreditsOnScreenDirty=!0),this._showCreditsOnScreen=t}},splitDirection:{get:function(){return this._splitDirection},set:function(t){this._splitDirection!==t&&this.resetDrawCommands(),this._splitDirection=t}},classificationType:{get:function(){return this._classificationType}},pickIds:{get:function(){return this._pickIds}},styleCommandsNeeded:{get:function(){return this._styleCommandsNeeded}}});Ia.prototype.getNode=function(t){return this._nodesByName[t]};Ia.prototype.setArticulationStage=function(t,e){this._sceneGraph.setArticulationStage(t,e)};Ia.prototype.applyArticulations=function(){this._sceneGraph.applyArticulations()};Ia.prototype.makeStyleDirty=function(){this._styleDirty=!0};Ia.prototype.resetDrawCommands=function(){this._drawCommandsBuilt=!1};var Pse=new L,vse=new ot,Kse=new L;Ia.prototype.update=function(t){let e=!1;try{e=zse(this,t)}catch(n){if(!this._loader.incrementallyLoadTextures&&n.name==="TextureError")D$(this,n);else{let i=Mn.getError("model",this._resource,n);D$(this,i)}}if(jse(this,t),qse(this,t),!this._resourcesLoaded&&e){this._resourcesLoaded=!0;let n=this._loader.components;if(!c(n)){if(this._loader.isUnloaded())return;let a=Mn.getError("model",this._resource,new St("Failed to load model."));D$(a),this._rejectLoad=this._rejectLoad&&this._rejectLoad(a)}let i=n.structuralMetadata;c(i)&&i.propertyTableCount>0&&Hse(this,i);let o=new cX({model:this,modelComponents:n});this._sceneGraph=o,this._gltfCredits=o.components.asset.credits}if(!(!this._resourcesLoaded||t.mode===ut.MORPHING)){if($se(this),tle(this),ele(this,t),nle(this),ile(this,t),ole(this,t),ale(this,t),sle(this,t),lle(this,t),rle(this,t),dle(this,t),this._defaultTexture=t.context.defaultTexture,cle(this,t),mle(this,t),hle(this),ple(this,t),Vle(this,t),!this._ready){t.afterRender.push(()=>{this._ready=!0,this._readyEvent.raiseEvent(this)});return}this._loader.incrementallyLoadTextures&&!this._texturesLoaded&&this._loader.texturesLoaded&&(this.resetDrawCommands(),this._texturesLoaded=!0,this._texturesReadyEvent.raiseEvent(this)),Zle(this),ble(this,t),Rle(this),Wle(this,t)}};function zse(t,e){return!t._resourcesLoaded||t._loader.incrementallyLoadTextures&&!t._texturesLoaded?(e.afterRender.push(()=>!0),t._loader.process(e)):!0}function jse(t,e){c(t._customShader)&&t._customShader.update(e)}function qse(t,e){t._imageBasedLighting.update(e),t._imageBasedLighting.shouldRegenerateShaders&&t.resetDrawCommands()}function $se(t){if(!t._featureTableIdDirty)return;t._featureTableIdDirty=!1;let e=t._sceneGraph.components,n=e.structuralMetadata;c(n)&&n.propertyTableCount>0&&(t.featureTableId=wse(e,t),t._styleDirty=!0,t.resetDrawCommands())}function tle(t){t._styleDirty&&(t.applyStyle(t._style),t._styleDirty=!1)}function ele(t,e){let n=t._featureTables,i=n.length,o=!1;for(let a=0;a=i&&a<=o}function Gle(t,e){let n=e.creditDisplay,i=t._credits,o=i.length;for(let a=0;a0&&t.alpha<1};Ia.prototype.isInvisible=function(){let t=this.color;return c(t)&&t.alpha===0};function AWt(t){return t.context.stencilBuffer}Ia.prototype.hasSilhouette=function(t){return AWt(t)&&this._silhouetteSize>0&&this._silhouetteColor.alpha>0&&!c(this._classificationType)};Ia.prototype.hasSkipLevelOfDetail=function(t){if(!Is.is3DTiles(this.type))return!1;let e=t.context.stencilBuffer,n=this._content.tileset;return e&&n.isSkippingLevelOfDetail};Ia.prototype.isClippingEnabled=function(){let t=this._clippingPlanes;return c(t)&&t.enabled&&t.length!==0};Ia.prototype.pick=function(t,e,n,i,o){return uC(this,t,e,n,i,o)};Ia.prototype.isClippingPolygonsEnabled=function(){let t=this._clippingPolygons;return c(t)&&t.enabled&&t.length!==0};Ia.prototype.isDestroyed=function(){return!1};Ia.prototype.destroy=function(){let t=this._loader;c(t)&&t.destroy();let e=this._featureTables;if(c(e)){let o=e.length;for(let a=0;a0,i=c(this.structuralMetadata)?this.structuralMetadata.propertyAttributes:void 0,o=c(i)&&c(i[0]);if(e&&(!n||o)){this.resetDrawCommands();return}n?(this.featureTables[this.featureTableId].applyStyle(t),UWt(this,t)):(this.applyColorAndShow(t),this._styleCommandsNeeded=void 0)};function uX(t,e,n){return{loader:t,type:e,resource:n.resource,show:n.show,modelMatrix:n.modelMatrix,scale:n.scale,minimumPixelSize:n.minimumPixelSize,maximumScale:n.maximumScale,id:n.id,allowPicking:n.allowPicking,clampAnimations:n.clampAnimations,shadows:n.shadows,debugShowBoundingVolume:n.debugShowBoundingVolume,enableDebugWireframe:n.enableDebugWireframe,debugWireframe:n.debugWireframe,cull:n.cull,opaquePass:n.opaquePass,customShader:n.customShader,content:n.content,heightReference:n.heightReference,scene:n.scene,distanceDisplayCondition:n.distanceDisplayCondition,color:n.color,colorBlendAmount:n.colorBlendAmount,colorBlendMode:n.colorBlendMode,silhouetteColor:n.silhouetteColor,silhouetteSize:n.silhouetteSize,enableShowOutline:n.enableShowOutline,showOutline:n.showOutline,outlineColor:n.outlineColor,clippingPlanes:n.clippingPlanes,clippingPolygons:n.clippingPolygons,lightColor:n.lightColor,imageBasedLighting:n.imageBasedLighting,backFaceCulling:n.backFaceCulling,credit:n.credit,showCreditsOnScreen:n.showCreditsOnScreen,splitDirection:n.splitDirection,projectTo2D:n.projectTo2D,enablePick:n.enablePick,featureIdLabel:n.featureIdLabel,instanceFeatureIdLabel:n.instanceFeatureIdLabel,pointCloudShading:n.pointCloudShading,classificationType:n.classificationType,pickObject:n.pickObject}}var AZ=Ia;function tr(t,e,n){this._tileset=t,this._tile=e,this._resource=n,this._model=void 0,this._metadata=void 0,this._group=void 0,this._ready=!1}Object.defineProperties(tr.prototype,{featuresLength:{get:function(){let t=this._model,e=t.featureTables,n=t.featureTableId;return c(e)&&c(e[n])?e[n].featuresLength:0}},pointsLength:{get:function(){return this._model.statistics.pointsLength}},trianglesLength:{get:function(){return this._model.statistics.trianglesLength}},geometryByteLength:{get:function(){return this._model.statistics.geometryByteLength}},texturesByteLength:{get:function(){return this._model.statistics.texturesByteLength}},batchTableByteLength:{get:function(){let t=this._model.statistics;return t.propertyTablesByteLength+t.batchTexturesByteLength}},innerContents:{get:function(){}},ready:{get:function(){return this._ready}},tileset:{get:function(){return this._tileset}},tile:{get:function(){return this._tile}},url:{get:function(){return this._resource.getUrlComponent(!0)}},batchTable:{get:function(){let t=this._model,e=t.featureTables,n=t.featureTableId;if(c(e)&&c(e[n]))return e[n]}},metadata:{get:function(){return this._metadata},set:function(t){this._metadata=t}},group:{get:function(){return this._group},set:function(t){this._group=t}}});tr.prototype.getFeature=function(t){let e=this._model,n=e.featureTableId;return e.featureTables[n].getFeature(t)};tr.prototype.hasProperty=function(t,e){let n=this._model,i=n.featureTableId;return c(i)?n.featureTables[i].hasProperty(t,e):!1};tr.prototype.applyDebugSettings=function(t,e){e=t?e:v.WHITE,this.featuresLength===0?this._model.color=e:c(this.batchTable)&&this.batchTable.setAllColor(e)};tr.prototype.applyStyle=function(t){this._model.style=t};tr.prototype.update=function(t,e){let n=this._model,i=this._tile;n.colorBlendAmount=t.colorBlendAmount,n.colorBlendMode=t.colorBlendMode,n.modelMatrix=i.computedTransform,n.customShader=t.customShader,n.featureIdLabel=t.featureIdLabel,n.instanceFeatureIdLabel=t.instanceFeatureIdLabel,n.lightColor=t.lightColor,n.imageBasedLighting=t.imageBasedLighting,n.backFaceCulling=t.backFaceCulling,n.shadows=t.shadows,n.showCreditsOnScreen=t.showCreditsOnScreen,n.splitDirection=t.splitDirection,n.debugWireframe=t.debugWireframe,n.showOutline=t.showOutline,n.outlineColor=t.outlineColor,n.pointCloudShading=t.pointCloudShading;let o=t.clippingPlanes;n.referenceMatrix=t.clippingPlanesOriginMatrix,c(o)&&i.clippingPlanesDirty&&(n._clippingPlanes=o.enabled&&i._isClipped?o:void 0),c(o)&&c(n._clippingPlanes)&&n._clippingPlanes!==o&&(n._clippingPlanes=o,n._clippingPlanesState=0);let a=t.clippingPolygons;c(a)&&i.clippingPolygonsDirty&&(n._clippingPolygons=a.enabled&&i._isClippedByPolygon?a:void 0),c(a)&&c(n._clippingPolygons)&&n._clippingPolygons!==a&&(n._clippingPolygons=a,n._clippingPolygonsState=0),n.update(e),!this._ready&&n.ready&&(n.activeAnimations.addAll({loop:xm.REPEAT}),this._ready=!0)};tr.prototype.isDestroyed=function(){return!1};tr.prototype.destroy=function(){return this._model=this._model&&this._model.destroy(),At(this)};tr.fromGltf=async function(t,e,n,i){let o=new tr(t,e,n),s=ZX(t,e,o,{gltf:i,basePath:n}),l=t.vectorClassificationOnly?void 0:t.classificationType;s.classificationType=l;let r=await AZ.fromGltfAsync(s);return o._model=r,o};tr.fromB3dm=async function(t,e,n,i,o){let a=new tr(t,e,n),l=ZX(t,e,a,{arrayBuffer:i,byteOffset:o,resource:n}),r=t.vectorClassificationOnly?void 0:t.classificationType;l.classificationType=r;let d=await AZ.fromB3dm(l);return a._model=d,a};tr.fromI3dm=async function(t,e,n,i,o){let a=new tr(t,e,n),l=ZX(t,e,a,{arrayBuffer:i,byteOffset:o,resource:n}),r=await AZ.fromI3dm(l);return a._model=r,a};tr.fromPnts=async function(t,e,n,i,o){let a=new tr(t,e,n),l=ZX(t,e,a,{arrayBuffer:i,byteOffset:o,resource:n}),r=await AZ.fromPnts(l);return a._model=r,a};tr.fromGeoJson=async function(t,e,n,i){let o=new tr(t,e,n),s=ZX(t,e,o,{geoJson:i,resource:n}),l=await AZ.fromGeoJson(s);return o._model=l,o};tr.prototype.pick=function(t,e,n){if(!c(this._model)||!this._ready)return;let i=e.verticalExaggeration,o=e.verticalExaggerationRelativeHeight;return this._model.pick(t,e,i,o,mt.WGS84,n)};function ZX(t,e,n,i){let o={cull:!1,releaseGltfJson:!0,opaquePass:Pt.CESIUM_3D_TILE,modelMatrix:e.computedTransform,upAxis:t._modelUpAxis,forwardAxis:t._modelForwardAxis,incrementallyLoadTextures:!1,customShader:t.customShader,content:n,colorBlendMode:t.colorBlendMode,colorBlendAmount:t.colorBlendAmount,lightColor:t.lightColor,imageBasedLighting:t.imageBasedLighting,featureIdLabel:t.featureIdLabel,instanceFeatureIdLabel:t.instanceFeatureIdLabel,pointCloudShading:t.pointCloudShading,clippingPlanes:t.clippingPlanes,backFaceCulling:t.backFaceCulling,shadows:t.shadows,showCreditsOnScreen:t.showCreditsOnScreen,splitDirection:t.splitDirection,enableDebugWireframe:t._enableDebugWireframe,debugWireframe:t.debugWireframe,projectTo2D:t._projectTo2D,enablePick:t._enablePick,enableShowOutline:t._enableShowOutline,showOutline:t.showOutline,outlineColor:t.outlineColor};return ze(i,o)}var ib=tr;var b8n=R(W(),1);function Dp(t,e,n){this._tileset=t,this._tile=e,this._resource=n,this.featurePropertiesDirty=!1,this._metadata=void 0,this._group=void 0,this._ready=!1}Object.defineProperties(Dp.prototype,{featuresLength:{get:function(){return 0}},pointsLength:{get:function(){return 0}},trianglesLength:{get:function(){return 0}},geometryByteLength:{get:function(){return 0}},texturesByteLength:{get:function(){return 0}},batchTableByteLength:{get:function(){return 0}},innerContents:{get:function(){}},ready:{get:function(){return this._ready}},tileset:{get:function(){return this._tileset}},tile:{get:function(){return this._tile}},url:{get:function(){return this._resource.getUrlComponent(!0)}},batchTable:{get:function(){}},metadata:{get:function(){return this._metadata},set:function(t){this._metadata=t}},group:{get:function(){return this._group},set:function(t){this._group=t}}});Dp.fromJson=function(t,e,n,i){let o=new Dp(t,e,n);return o._tileset.loadTileset(o._resource,i,o._tile),o._ready=!0,o};Dp.prototype.hasProperty=function(t,e){return!1};Dp.prototype.getFeature=function(t){};Dp.prototype.applyDebugSettings=function(t,e){};Dp.prototype.applyStyle=function(t){};Dp.prototype.update=function(t,e){};Dp.prototype.pick=function(t,e,n){};Dp.prototype.isDestroyed=function(){return!1};Dp.prototype.destroy=function(){return At(this)};var VX=Dp;var Fei=R(W(),1);var f$n=R(W(),1);var M6n=R(W(),1);var W8n=R(W(),1),bX=`uniform sampler2D u_atlas; +`;var eP={name:"ModelSplitterPipelineStage",SPLIT_DIRECTION_UNIFORM_NAME:"model_splitDirection"};eP.process=function(t,e,n){let i=t.shaderBuilder;i.addDefine("HAS_MODEL_SPLITTER",void 0,Xt.FRAGMENT),i.addFragmentLines(aX);let o={};i.addUniform("float",eP.SPLIT_DIRECTION_UNIFORM_NAME,Xt.FRAGMENT),o[eP.SPLIT_DIRECTION_UNIFORM_NAME]=function(){return e.splitDirection},t.uniformMap=ze(o,t.uniformMap)};var sX=eP;var Gzn=b(W(),1);function wae(t,e){this.model=t.model,this.shaderBuilder=t.shaderBuilder.clone(),this.uniformMap=Re(t.uniformMap),this.alphaOptions=Re(t.alphaOptions),this.renderStateOptions=Re(t.renderStateOptions,!0),this.hasSilhouette=t.hasSilhouette,this.hasSkipLevelOfDetail=t.hasSkipLevelOfDetail,this.runtimeNode=e,this.attributes=[],this.attributeIndex=1,this.featureIdVertexAttributeSetIndex=0,this.instanceCount=0}var lX=wae;var kzn=b(W(),1);var gzn=b(W(),1);function Pae(t){t=f(t,f.EMPTY_OBJECT),this.lightingModel=f(t.lightingModel,nR.UNLIT)}var rX=Pae;function vae(t,e){this.model=t.model,this.runtimeNode=t.runtimeNode,this.attributes=t.attributes.slice(),this.attributeIndex=t.attributeIndex,this.featureIdVertexAttributeSetIndex=t.featureIdVertexAttributeSetIndex,this.uniformMap=Re(t.uniformMap),this.alphaOptions=Re(t.alphaOptions),this.renderStateOptions=Re(t.renderStateOptions,!0),this.hasSilhouette=t.hasSilhouette,this.hasSkipLevelOfDetail=t.hasSkipLevelOfDetail,this.shaderBuilder=t.shaderBuilder.clone(),this.instanceCount=t.instanceCount,this.runtimePrimitive=e;let n=e.primitive;this.count=c(n.indices)?n.indices.count:Mn.getAttributeBySemantic(n,"POSITION").count,this.hasPropertyTable=!1,this.indices=n.indices,this.wireframeIndexBuffer=void 0,this.primitiveType=n.primitiveType;let i=Mn.getPositionMinMax(n,this.runtimeNode.instancingTranslationMin,this.runtimeNode.instancingTranslationMax);this.positionMin=p.clone(i.min,new p),this.positionMax=p.clone(i.max,new p),this.boundingSphere=Ft.fromCornerPoints(this.positionMin,this.positionMax,new Ft),this.lightingOptions=new rX,this.pickId=void 0}var dX=vae;function Nh(t){t=f(t,f.EMPTY_OBJECT);let e=t.modelComponents;this._model=t.model,this._components=e,this._pipelineStages=[],this._updateStages=[],this._runtimeNodes=[],this._rootNodes=[],this._skinnedNodes=[],this._runtimeSkins=[],this.modelPipelineStages=[],this._boundingSphere=void 0,this._boundingSphere2D=void 0,this._computedModelMatrix=L.clone(L.IDENTITY),this._computedModelMatrix2D=L.clone(L.IDENTITY),this._axisCorrectionMatrix=Mn.getAxisCorrectionMatrix(e.upAxis,e.forwardAxis,new L),this._runtimeArticulations={},Kae(this)}Object.defineProperties(Nh.prototype,{components:{get:function(){return this._components}},computedModelMatrix:{get:function(){return this._computedModelMatrix}},axisCorrectionMatrix:{get:function(){return this._axisCorrectionMatrix}},boundingSphere:{get:function(){return this._boundingSphere}}});function Kae(t){let e=t._components,n=e.scene,o=t._model.modelMatrix;pWt(t,o);let a=e.articulations,s=a.length,l=t._runtimeArticulations;for(let A=0;A0&&(h=ts(n,e,l),e+=l,r>0&&(u=new Uint8Array(t,e,r),e+=r));let R=new Fu(d,m),V=R.getGlobalProperty("POINTS_LENGTH");if(R.featuresLength=V,!c(V))throw new Tt("Feature table global property: POINTS_LENGTH must be defined");let F=R.getGlobalProperty("RTC_CENTER",it.FLOAT,3);c(F)&&(F=p.unpack(F));let U=cse(R,h);if(U.rtcCenter=F,U.pointsLength=V,!U.hasPositions){let G=mse(R);U.positions=G,U.hasPositions=U.hasPositions||c(G)}if(!U.hasPositions)throw new Tt("Either POSITION or POSITION_QUANTIZED must be defined.");if(!U.hasNormals){let G=pse(R);U.normals=G,U.hasNormals=U.hasNormals||c(G)}if(!U.hasColors){let G=hse(R);U.colors=G,U.hasColors=U.hasColors||c(G),U.hasConstantColor=c(U.constantColor),U.isTranslucent=c(G)&&G.isTranslucent}if(!U.hasBatchIds){let G=Vse(R);U.batchIds=G,U.hasBatchIds=U.hasBatchIds||c(G)}if(U.hasBatchIds){let G=R.getGlobalProperty("BATCH_LENGTH");if(!c(G))throw new Tt("Global property: BATCH_LENGTH must be defined when BATCH_ID is defined.");U.batchLength=G}return c(u)&&(u=new Uint8Array(u),U.batchTableJson=h,U.batchTableBinary=u),U};function cse(t,e){let n=t.json,i,o,a,s=c(n.extensions)?n.extensions["3DTILES_draco_point_compression"]:void 0,l=c(e)&&c(e.extensions)?e.extensions["3DTILES_draco_point_compression"]:void 0;c(l)&&(a=l.properties);let r,d,m,h,u;if(c(s)){o=s.properties;let V=s.byteOffset,F=s.byteLength;if(!c(o)||!c(V)||!c(F))throw new Tt("Draco properties, byteOffset, and byteLength must be defined");i=t.buffer.slice(V,V+F),r=c(o.POSITION),d=c(o.RGB)||c(o.RGBA),m=c(o.NORMAL),h=c(o.BATCH_ID),u=c(o.RGBA)}let R;return c(i)&&(R={buffer:i,featureTableProperties:o,batchTableProperties:a,properties:ze(o,a),dequantizeInShader:!0}),{draco:R,hasPositions:r,hasColors:d,isTranslucent:u,hasNormals:m,hasBatchIds:h}}function mse(t){let e=t.json,n;if(c(e.POSITION))return n=t.getPropertyArray("POSITION",it.FLOAT,3),{name:sn.POSITION,semantic:sn.POSITION,typedArray:n,isQuantized:!1,componentDatatype:it.FLOAT,type:_n.VEC3};if(c(e.POSITION_QUANTIZED)){n=t.getPropertyArray("POSITION_QUANTIZED",it.UNSIGNED_SHORT,3);let i=t.getGlobalProperty("QUANTIZED_VOLUME_SCALE",it.FLOAT,3);if(!c(i))throw new Tt("Global property: QUANTIZED_VOLUME_SCALE must be defined for quantized positions.");let o=65535,a=t.getGlobalProperty("QUANTIZED_VOLUME_OFFSET",it.FLOAT,3);if(!c(a))throw new Tt("Global property: QUANTIZED_VOLUME_OFFSET must be defined for quantized positions.");return{name:sn.POSITION,semantic:sn.POSITION,typedArray:n,isQuantized:!0,componentDatatype:it.FLOAT,type:_n.VEC3,quantizedRange:o,quantizedVolumeOffset:p.unpack(a),quantizedVolumeScale:p.unpack(i),quantizedComponentDatatype:it.UNSIGNED_SHORT,quantizedType:_n.VEC3}}}function hse(t){let e=t.json,n;if(c(e.RGBA))return n=t.getPropertyArray("RGBA",it.UNSIGNED_BYTE,4),{name:sn.COLOR,semantic:sn.COLOR,setIndex:0,typedArray:n,componentDatatype:it.UNSIGNED_BYTE,type:_n.VEC4,normalized:!0,isRGB565:!1,isTranslucent:!0};if(c(e.RGB))return n=t.getPropertyArray("RGB",it.UNSIGNED_BYTE,3),{name:"COLOR",semantic:sn.COLOR,setIndex:0,typedArray:n,componentDatatype:it.UNSIGNED_BYTE,type:_n.VEC3,normalized:!0,isRGB565:!1,isTranslucent:!1};if(c(e.RGB565))return n=t.getPropertyArray("RGB565",it.UNSIGNED_SHORT,1),{name:"COLOR",semantic:sn.COLOR,setIndex:0,typedArray:n,componentDatatype:it.FLOAT,type:_n.VEC3,normalized:!1,isRGB565:!0,isTranslucent:!1};if(c(e.CONSTANT_RGBA)){let i=t.getGlobalProperty("CONSTANT_RGBA",it.UNSIGNED_BYTE,4),o=i[3],a=v.fromBytes(i[0],i[1],i[2],o),s=o<255;return{name:sn.COLOR,semantic:sn.COLOR,setIndex:0,constantColor:a,componentDatatype:it.FLOAT,type:_n.VEC4,isQuantized:!1,isTranslucent:s}}}function pse(t){let e=t.json,n;if(c(e.NORMAL))return n=t.getPropertyArray("NORMAL",it.FLOAT,3),{name:sn.NORMAL,semantic:sn.NORMAL,typedArray:n,octEncoded:!1,octEncodedZXY:!1,componentDatatype:it.FLOAT,type:_n.VEC3};if(c(e.NORMAL_OCT16P))return n=t.getPropertyArray("NORMAL_OCT16P",it.UNSIGNED_BYTE,2),{name:sn.NORMAL,semantic:sn.NORMAL,typedArray:n,octEncoded:!0,octEncodedZXY:!1,quantizedRange:(1<<8)-1,quantizedType:_n.VEC2,quantizedComponentDatatype:it.UNSIGNED_BYTE,componentDatatype:it.FLOAT,type:_n.VEC3}}function Vse(t){let e=t.json;if(c(e.BATCH_ID)){let n=t.getPropertyArray("BATCH_ID",it.UNSIGNED_SHORT,1);return{name:sn.FEATURE_ID,semantic:sn.FEATURE_ID,setIndex:0,typedArray:n,componentDatatype:it.fromTypedArray(n),type:_n.SCALAR}}}var xA=RWt;var use=Sn.Components,Zse=Sn.Scene,Rse=Sn.Node,bse=Sn.Primitive,Wse=Sn.Attribute,bWt=Sn.Quantization,fse=Sn.FeatureIdAttribute,Fse=Sn.Material,Use=Sn.MetallicRoughness;function sF(t){t=f(t,f.EMPTY_OBJECT);let e=t.arrayBuffer,n=f(t.byteOffset,0);this._arrayBuffer=e,this._byteOffset=n,this._loadAttributesFor2D=f(t.loadAttributesFor2D,!1),this._parsedContent=void 0,this._decodePromise=void 0,this._decodedAttributes=void 0,this._promise=void 0,this._error=void 0,this._state=pn.UNLOADED,this._buffers=[],this._components=void 0,this._transform=L.IDENTITY}c(Object.create)&&(sF.prototype=Object.create(Za.prototype),sF.prototype.constructor=sF);Object.defineProperties(sF.prototype,{cacheKey:{get:function(){}},components:{get:function(){return this._components}},transform:{get:function(){return this._transform}}});sF.prototype.load=function(){if(c(this._promise))return this._promise;this._parsedContent=xA.parse(this._arrayBuffer,this._byteOffset),this._state=pn.PROCESSING,this._promise=Promise.resolve(this)};sF.prototype.process=function(t){if(c(this._error)){let e=this._error;throw this._error=void 0,e}if(this._state===pn.READY)return!0;if(this._state===pn.PROCESSING){if(c(this._decodePromise))return!1;this._decodePromise=Gse(this,t.context)}return!1};function Gse(t,e){let i=t._parsedContent.draco,o;if(c(i)?o=$b.decodePointCloud(i,e):o=Promise.resolve(),!!c(o))return t._decodePromise=o,o.then(function(a){if(!t.isDestroyed())return c(a)&&Ase(t,i,a),kse(t,e),t._state=pn.READY,t}).catch(function(a){t.unload(),t._state=pn.FAILED;let s="Failed to load Draco pnts";t._error=t.getError(s,a)})}function Ase(t,e,n){t._state=pn.READY;let i=t._parsedContent,o;if(c(n.POSITION)){if(o={name:"POSITION",semantic:sn.POSITION,typedArray:n.POSITION.array,componentDatatype:it.FLOAT,type:_n.VEC3,isQuantized:!1},c(n.POSITION.data.quantization)){let l=n.POSITION.data.quantization,r=l.range,d=p.fromElements(r,r,r),m=p.unpack(l.minValues),h=(1<0&&Yse(t,l,h,e),c(n.rtcCenter)&&(m.transform=L.multiplyByTranslation(m.transform,n.rtcCenter,m.transform));let u=n.positions;c(u)&&u.isQuantized&&(m.transform=L.multiplyByTranslation(m.transform,u.quantizedVolumeOffset,m.transform)),t._components=m,t._parsedContent=void 0,t._arrayBuffer=void 0}function Yse(t,e,n,i){let o=e.attributes,a=n.length;for(let s=0;s=0&&(l=Nt)}}}}if(l!==Number.MAX_VALUE){if(s=di.getPoint(e,l,s),n.mode!==Vt.SCENE3D){p.fromElements(s.y,s.z,s.x,s);let m=n.mapProjection,h=m.ellipsoid,u=m.unproject(s,Dse);h.cartographicToCartesian(u,s)}return s}}function _$(t,e,n,i,o,a,s,l,r,d){let m=n+e*i;if(d.x=t[m],d.y=t[m+1],d.z=t[m+2],c(o))if(o.octEncoded){if(d=Ni.octDecodeInRange(d,o.normalizationRange,d),o.octEncodedZXY){let h=d.x;d.x=d.z,d.z=d.y,d.y=h}}else d=p.multiplyComponents(d,o.quantizedVolumeStepSize,d),d=p.add(d,o.quantizedVolumeOffset,d);return d=L.multiplyByPoint(a,d,d),s!==1&&Ps.getPosition(d,r,s,l,d),d}function Ia(t){t=f(t,f.EMPTY_OBJECT),this._loader=t.loader,this._resource=t.resource,this.type=f(t.type,Is.GLTF),this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._modelMatrix=L.clone(this.modelMatrix),this._scale=f(t.scale,1),this._minimumPixelSize=f(t.minimumPixelSize,0),this._maximumScale=t.maximumScale,this._clampedScale=c(this._maximumScale)?Math.min(this._scale,this._maximumScale):this._scale,this._computedScale=this._clampedScale,this._updateModelMatrix=!1,this.referenceMatrix=void 0,this._iblReferenceFrameMatrix=ot.clone(ot.IDENTITY),this._resourcesLoaded=!1,this._drawCommandsBuilt=!1,this._ready=!1,this._customShader=t.customShader,this._content=t.content,this._texturesLoaded=!1,this._defaultTexture=void 0,this._activeAnimations=new kY(this),this._clampAnimations=f(t.clampAnimations,!0),this._userAnimationDirty=!1,this._id=t.id,this._idDirty=!1,this._color=v.clone(t.color),this._colorBlendMode=f(t.colorBlendMode,Kd.HIGHLIGHT),this._colorBlendAmount=f(t.colorBlendAmount,.5);let e=f(t.silhouetteColor,v.RED);this._silhouetteColor=v.clone(e),this._silhouetteSize=f(t.silhouetteSize,0),this._silhouetteDirty=!1,this._silhouetteId=void 0,this._cull=f(t.cull,!0),this._opaquePass=f(t.opaquePass,Pt.OPAQUE),this._allowPicking=f(t.allowPicking,!0),this._show=f(t.show,!0),this._style=void 0,this._styleDirty=!1,this._styleCommandsNeeded=void 0;let n=f(t.featureIdLabel,"featureId_0");typeof n=="number"&&(n=`featureId_${n}`),this._featureIdLabel=n;let i=f(t.instanceFeatureIdLabel,"instanceFeatureId_0");typeof i=="number"&&(i=`instanceFeatureId_${i}`),this._instanceFeatureIdLabel=i,this._featureTables=[],this._featureTableId=void 0,this._featureTableIdDirty=!0,this._pipelineResources=[],this._modelResources=[],this._pickIds=[],this._boundingSphere=new Ft,this._initialRadius=void 0,this._heightReference=f(t.heightReference,Ge.NONE),this._heightDirty=this._heightReference!==Ge.NONE,this._removeUpdateHeightCallback=void 0,this._verticalExaggerationOn=!1,this._clampedModelMatrix=void 0;let o=t.scene;c(o)&&c(o.terrainProviderChanged)&&(this._terrainProviderChangedCallback=o.terrainProviderChanged.addEventListener(()=>{this._heightDirty=!0})),this._scene=o,this._distanceDisplayCondition=t.distanceDisplayCondition;let a=new eR(t.pointCloudShading);this._pointCloudShading=a,this._attenuation=a.attenuation,this._pointCloudBackFaceCulling=a.backFaceCulling;let s=t.clippingPlanes;c(s)&&s.owner===void 0?Ml.setOwner(s,this,"_clippingPlanes"):this._clippingPlanes=s,this._clippingPlanesState=0,this._clippingPlanesMatrix=L.clone(L.IDENTITY);let l=t.clippingPolygons;c(l)&&l.owner===void 0?bu.setOwner(l,this,"_clippingPolygons"):this._clippingPolygons=l,this._clippingPolygonsState=0,this._lightColor=p.clone(t.lightColor),this._imageBasedLighting=c(t.imageBasedLighting)?t.imageBasedLighting:new aA,this._shouldDestroyImageBasedLighting=!c(t.imageBasedLighting),this._backFaceCulling=f(t.backFaceCulling,!0),this._backFaceCullingDirty=!1,this._shadows=f(t.shadows,Vi.ENABLED),this._shadowsDirty=!1,this._debugShowBoundingVolumeDirty=!1,this._debugShowBoundingVolume=f(t.debugShowBoundingVolume,!1),this._enableDebugWireframe=f(t.enableDebugWireframe,!1),this._enableShowOutline=f(t.enableShowOutline,!0),this._debugWireframe=f(t.debugWireframe,!1),this._debugWireframe===!0&&this._enableDebugWireframe===!1&&this.type===Is.GLTF&&Gn("model-debug-wireframe-ignored","enableDebugWireframe must be set to true in Model.fromGltf, otherwise debugWireframe will be ignored.");let r=t.credit;typeof r=="string"&&(r=new on(r)),this._credits=[],this._credit=r,this._resourceCredits=[],this._gltfCredits=[],this._showCreditsOnScreen=f(t.showCreditsOnScreen,!1),this._showCreditsOnScreenDirty=!0,this._splitDirection=f(t.splitDirection,Jc.NONE),this._enableShowOutline=f(t.enableShowOutline,!0),this.showOutline=f(t.showOutline,!0),this.outlineColor=f(t.outlineColor,v.BLACK),this._classificationType=t.classificationType,this._statistics=new mX,this._sceneMode=void 0,this._projectTo2D=f(t.projectTo2D,!1),this._enablePick=f(t.enablePick,!1),this._fogRenderable=void 0,this._skipLevelOfDetail=!1,this._ignoreCommands=f(t.ignoreCommands,!1),this._errorEvent=new It,this._readyEvent=new It,this._texturesReadyEvent=new It,this._sceneGraph=void 0,this._nodesByName={},this.pickObject=t.pickObject}function D$(t,e){if(t._errorEvent.numberOfListeners>0){t._errorEvent.raiseEvent(e);return}console.log(e)}function Hse(t,e){let n=t._featureTables,i=e.propertyTables,o=i.length;for(let a=0;a0&&e===0||t===0&&e>0;this._silhouetteDirty=this._silhouetteDirty||n,this._backFaceCullingDirty=this._backFaceCullingDirty||n}this._silhouetteSize=t}},boundingSphere:{get:function(){let t=c(this._clampedModelMatrix)?this._clampedModelMatrix:this.modelMatrix;return GWt(this,t),this._boundingSphere}},debugShowBoundingVolume:{get:function(){return this._debugShowBoundingVolume},set:function(t){this._debugShowBoundingVolume!==t&&(this._debugShowBoundingVolumeDirty=!0),this._debugShowBoundingVolume=t}},debugWireframe:{get:function(){return this._debugWireframe},set:function(t){this._debugWireframe!==t&&this.resetDrawCommands(),this._debugWireframe=t,this._debugWireframe===!0&&this._enableDebugWireframe===!1&&this.type===Is.GLTF&&Gn("model-debug-wireframe-ignored","enableDebugWireframe must be set to true in Model.fromGltfAsync, otherwise debugWireframe will be ignored.")}},show:{get:function(){return this._show},set:function(t){this._show=t}},featureIdLabel:{get:function(){return this._featureIdLabel},set:function(t){typeof t=="number"&&(t=`featureId_${t}`),t!==this._featureIdLabel&&(this._featureTableIdDirty=!0),this._featureIdLabel=t}},instanceFeatureIdLabel:{get:function(){return this._instanceFeatureIdLabel},set:function(t){typeof t=="number"&&(t=`instanceFeatureId_${t}`),t!==this._instanceFeatureIdLabel&&(this._featureTableIdDirty=!0),this._instanceFeatureIdLabel=t}},clippingPlanes:{get:function(){return this._clippingPlanes},set:function(t){t!==this._clippingPlanes&&(Ml.setOwner(t,this,"_clippingPlanes"),this.resetDrawCommands())}},clippingPolygons:{get:function(){return this._clippingPolygons},set:function(t){t!==this._clippingPolygons&&(bu.setOwner(t,this,"_clippingPolygons"),this.resetDrawCommands())}},lightColor:{get:function(){return this._lightColor},set:function(t){c(t)!==c(this._lightColor)&&this.resetDrawCommands(),this._lightColor=p.clone(t,this._lightColor)}},imageBasedLighting:{get:function(){return this._imageBasedLighting},set:function(t){t!==this._imageBasedLighting&&(this._shouldDestroyImageBasedLighting&&!this._imageBasedLighting.isDestroyed()&&this._imageBasedLighting.destroy(),this._imageBasedLighting=t,this._shouldDestroyImageBasedLighting=!1,this.resetDrawCommands())}},backFaceCulling:{get:function(){return this._backFaceCulling},set:function(t){t!==this._backFaceCulling&&(this._backFaceCullingDirty=!0),this._backFaceCulling=t}},scale:{get:function(){return this._scale},set:function(t){t!==this._scale&&(this._updateModelMatrix=!0),this._scale=t}},computedScale:{get:function(){return this._computedScale}},minimumPixelSize:{get:function(){return this._minimumPixelSize},set:function(t){t!==this._minimumPixelSize&&(this._updateModelMatrix=!0),this._minimumPixelSize=t}},maximumScale:{get:function(){return this._maximumScale},set:function(t){t!==this._maximumScale&&(this._updateModelMatrix=!0),this._maximumScale=t}},shadows:{get:function(){return this._shadows},set:function(t){t!==this._shadows&&(this._shadowsDirty=!0),this._shadows=t}},credit:{get:function(){return this._credit}},showCreditsOnScreen:{get:function(){return this._showCreditsOnScreen},set:function(t){this._showCreditsOnScreen!==t&&(this._showCreditsOnScreenDirty=!0),this._showCreditsOnScreen=t}},splitDirection:{get:function(){return this._splitDirection},set:function(t){this._splitDirection!==t&&this.resetDrawCommands(),this._splitDirection=t}},classificationType:{get:function(){return this._classificationType}},pickIds:{get:function(){return this._pickIds}},styleCommandsNeeded:{get:function(){return this._styleCommandsNeeded}}});Ia.prototype.getNode=function(t){return this._nodesByName[t]};Ia.prototype.setArticulationStage=function(t,e){this._sceneGraph.setArticulationStage(t,e)};Ia.prototype.applyArticulations=function(){this._sceneGraph.applyArticulations()};Ia.prototype.makeStyleDirty=function(){this._styleDirty=!0};Ia.prototype.resetDrawCommands=function(){this._drawCommandsBuilt=!1};var Pse=new L,vse=new ot,Kse=new L;Ia.prototype.update=function(t){let e=!1;try{e=zse(this,t)}catch(n){if(!this._loader.incrementallyLoadTextures&&n.name==="TextureError")D$(this,n);else{let i=Mn.getError("model",this._resource,n);D$(this,i)}}if(jse(this,t),qse(this,t),!this._resourcesLoaded&&e){this._resourcesLoaded=!0;let n=this._loader.components;if(!c(n)){if(this._loader.isUnloaded())return;let a=Mn.getError("model",this._resource,new Tt("Failed to load model."));D$(a),this._rejectLoad=this._rejectLoad&&this._rejectLoad(a)}let i=n.structuralMetadata;c(i)&&i.propertyTableCount>0&&Hse(this,i);let o=new cX({model:this,modelComponents:n});this._sceneGraph=o,this._gltfCredits=o.components.asset.credits}if(!(!this._resourcesLoaded||t.mode===Vt.MORPHING)){if($se(this),tle(this),ele(this,t),nle(this),ile(this,t),ole(this,t),ale(this,t),sle(this,t),lle(this,t),rle(this,t),dle(this,t),this._defaultTexture=t.context.defaultTexture,cle(this,t),mle(this,t),hle(this),ple(this,t),Zle(this,t),!this._ready){t.afterRender.push(()=>{this._ready=!0,this._readyEvent.raiseEvent(this)});return}this._loader.incrementallyLoadTextures&&!this._texturesLoaded&&this._loader.texturesLoaded&&(this.resetDrawCommands(),this._texturesLoaded=!0,this._texturesReadyEvent.raiseEvent(this)),ule(this),Rle(this,t),ble(this),Wle(this,t)}};function zse(t,e){return!t._resourcesLoaded||t._loader.incrementallyLoadTextures&&!t._texturesLoaded?(e.afterRender.push(()=>!0),t._loader.process(e)):!0}function jse(t,e){c(t._customShader)&&t._customShader.update(e)}function qse(t,e){t._imageBasedLighting.update(e),t._imageBasedLighting.shouldRegenerateShaders&&t.resetDrawCommands()}function $se(t){if(!t._featureTableIdDirty)return;t._featureTableIdDirty=!1;let e=t._sceneGraph.components,n=e.structuralMetadata;c(n)&&n.propertyTableCount>0&&(t.featureTableId=wse(e,t),t._styleDirty=!0,t.resetDrawCommands())}function tle(t){t._styleDirty&&(t.applyStyle(t._style),t._styleDirty=!1)}function ele(t,e){let n=t._featureTables,i=n.length,o=!1;for(let a=0;a=i&&a<=o}function Gle(t,e){let n=e.creditDisplay,i=t._credits,o=i.length;for(let a=0;a0&&t.alpha<1};Ia.prototype.isInvisible=function(){let t=this.color;return c(t)&&t.alpha===0};function AWt(t){return t.context.stencilBuffer}Ia.prototype.hasSilhouette=function(t){return AWt(t)&&this._silhouetteSize>0&&this._silhouetteColor.alpha>0&&!c(this._classificationType)};Ia.prototype.hasSkipLevelOfDetail=function(t){if(!Is.is3DTiles(this.type))return!1;let e=t.context.stencilBuffer,n=this._content.tileset;return e&&n.isSkippingLevelOfDetail};Ia.prototype.isClippingEnabled=function(){let t=this._clippingPlanes;return c(t)&&t.enabled&&t.length!==0};Ia.prototype.pick=function(t,e,n,i,o){return VC(this,t,e,n,i,o)};Ia.prototype.isClippingPolygonsEnabled=function(){let t=this._clippingPolygons;return c(t)&&t.enabled&&t.length!==0};Ia.prototype.isDestroyed=function(){return!1};Ia.prototype.destroy=function(){let t=this._loader;c(t)&&t.destroy();let e=this._featureTables;if(c(e)){let o=e.length;for(let a=0;a0,i=c(this.structuralMetadata)?this.structuralMetadata.propertyAttributes:void 0,o=c(i)&&c(i[0]);if(e&&(!n||o)){this.resetDrawCommands();return}n?(this.featureTables[this.featureTableId].applyStyle(t),UWt(this,t)):(this.applyColorAndShow(t),this._styleCommandsNeeded=void 0)};function VX(t,e,n){return{loader:t,type:e,resource:n.resource,show:n.show,modelMatrix:n.modelMatrix,scale:n.scale,minimumPixelSize:n.minimumPixelSize,maximumScale:n.maximumScale,id:n.id,allowPicking:n.allowPicking,clampAnimations:n.clampAnimations,shadows:n.shadows,debugShowBoundingVolume:n.debugShowBoundingVolume,enableDebugWireframe:n.enableDebugWireframe,debugWireframe:n.debugWireframe,cull:n.cull,opaquePass:n.opaquePass,customShader:n.customShader,content:n.content,heightReference:n.heightReference,scene:n.scene,distanceDisplayCondition:n.distanceDisplayCondition,color:n.color,colorBlendAmount:n.colorBlendAmount,colorBlendMode:n.colorBlendMode,silhouetteColor:n.silhouetteColor,silhouetteSize:n.silhouetteSize,enableShowOutline:n.enableShowOutline,showOutline:n.showOutline,outlineColor:n.outlineColor,clippingPlanes:n.clippingPlanes,clippingPolygons:n.clippingPolygons,lightColor:n.lightColor,imageBasedLighting:n.imageBasedLighting,backFaceCulling:n.backFaceCulling,credit:n.credit,showCreditsOnScreen:n.showCreditsOnScreen,splitDirection:n.splitDirection,projectTo2D:n.projectTo2D,enablePick:n.enablePick,featureIdLabel:n.featureIdLabel,instanceFeatureIdLabel:n.instanceFeatureIdLabel,pointCloudShading:n.pointCloudShading,classificationType:n.classificationType,pickObject:n.pickObject}}var Au=Ia;function tr(t,e,n){this._tileset=t,this._tile=e,this._resource=n,this._model=void 0,this._metadata=void 0,this._group=void 0,this._ready=!1}Object.defineProperties(tr.prototype,{featuresLength:{get:function(){let t=this._model,e=t.featureTables,n=t.featureTableId;return c(e)&&c(e[n])?e[n].featuresLength:0}},pointsLength:{get:function(){return this._model.statistics.pointsLength}},trianglesLength:{get:function(){return this._model.statistics.trianglesLength}},geometryByteLength:{get:function(){return this._model.statistics.geometryByteLength}},texturesByteLength:{get:function(){return this._model.statistics.texturesByteLength}},batchTableByteLength:{get:function(){let t=this._model.statistics;return t.propertyTablesByteLength+t.batchTexturesByteLength}},innerContents:{get:function(){}},ready:{get:function(){return this._ready}},tileset:{get:function(){return this._tileset}},tile:{get:function(){return this._tile}},url:{get:function(){return this._resource.getUrlComponent(!0)}},batchTable:{get:function(){let t=this._model,e=t.featureTables,n=t.featureTableId;if(c(e)&&c(e[n]))return e[n]}},metadata:{get:function(){return this._metadata},set:function(t){this._metadata=t}},group:{get:function(){return this._group},set:function(t){this._group=t}}});tr.prototype.getFeature=function(t){let e=this._model,n=e.featureTableId;return e.featureTables[n].getFeature(t)};tr.prototype.hasProperty=function(t,e){let n=this._model,i=n.featureTableId;return c(i)?n.featureTables[i].hasProperty(t,e):!1};tr.prototype.applyDebugSettings=function(t,e){e=t?e:v.WHITE,this.featuresLength===0?this._model.color=e:c(this.batchTable)&&this.batchTable.setAllColor(e)};tr.prototype.applyStyle=function(t){this._model.style=t};tr.prototype.update=function(t,e){let n=this._model,i=this._tile;n.colorBlendAmount=t.colorBlendAmount,n.colorBlendMode=t.colorBlendMode,n.modelMatrix=i.computedTransform,n.customShader=t.customShader,n.featureIdLabel=t.featureIdLabel,n.instanceFeatureIdLabel=t.instanceFeatureIdLabel,n.lightColor=t.lightColor,n.imageBasedLighting=t.imageBasedLighting,n.backFaceCulling=t.backFaceCulling,n.shadows=t.shadows,n.showCreditsOnScreen=t.showCreditsOnScreen,n.splitDirection=t.splitDirection,n.debugWireframe=t.debugWireframe,n.showOutline=t.showOutline,n.outlineColor=t.outlineColor,n.pointCloudShading=t.pointCloudShading;let o=t.clippingPlanes;n.referenceMatrix=t.clippingPlanesOriginMatrix,c(o)&&i.clippingPlanesDirty&&(n._clippingPlanes=o.enabled&&i._isClipped?o:void 0),c(o)&&c(n._clippingPlanes)&&n._clippingPlanes!==o&&(n._clippingPlanes=o,n._clippingPlanesState=0);let a=t.clippingPolygons;c(a)&&i.clippingPolygonsDirty&&(n._clippingPolygons=a.enabled&&i._isClippedByPolygon?a:void 0),c(a)&&c(n._clippingPolygons)&&n._clippingPolygons!==a&&(n._clippingPolygons=a,n._clippingPolygonsState=0),n.update(e),!this._ready&&n.ready&&(n.activeAnimations.addAll({loop:xm.REPEAT}),this._ready=!0)};tr.prototype.isDestroyed=function(){return!1};tr.prototype.destroy=function(){return this._model=this._model&&this._model.destroy(),At(this)};tr.fromGltf=async function(t,e,n,i){let o=new tr(t,e,n),s=uX(t,e,o,{gltf:i,basePath:n}),l=t.vectorClassificationOnly?void 0:t.classificationType;s.classificationType=l;let r=await Au.fromGltfAsync(s);return o._model=r,o};tr.fromB3dm=async function(t,e,n,i,o){let a=new tr(t,e,n),l=uX(t,e,a,{arrayBuffer:i,byteOffset:o,resource:n}),r=t.vectorClassificationOnly?void 0:t.classificationType;l.classificationType=r;let d=await Au.fromB3dm(l);return a._model=d,a};tr.fromI3dm=async function(t,e,n,i,o){let a=new tr(t,e,n),l=uX(t,e,a,{arrayBuffer:i,byteOffset:o,resource:n}),r=await Au.fromI3dm(l);return a._model=r,a};tr.fromPnts=async function(t,e,n,i,o){let a=new tr(t,e,n),l=uX(t,e,a,{arrayBuffer:i,byteOffset:o,resource:n}),r=await Au.fromPnts(l);return a._model=r,a};tr.fromGeoJson=async function(t,e,n,i){let o=new tr(t,e,n),s=uX(t,e,o,{geoJson:i,resource:n}),l=await Au.fromGeoJson(s);return o._model=l,o};tr.prototype.pick=function(t,e,n){if(!c(this._model)||!this._ready)return;let i=e.verticalExaggeration,o=e.verticalExaggerationRelativeHeight;return this._model.pick(t,e,i,o,mt.WGS84,n)};function uX(t,e,n,i){let o={cull:!1,releaseGltfJson:!0,opaquePass:Pt.CESIUM_3D_TILE,modelMatrix:e.computedTransform,upAxis:t._modelUpAxis,forwardAxis:t._modelForwardAxis,incrementallyLoadTextures:!1,customShader:t.customShader,content:n,colorBlendMode:t.colorBlendMode,colorBlendAmount:t.colorBlendAmount,lightColor:t.lightColor,imageBasedLighting:t.imageBasedLighting,featureIdLabel:t.featureIdLabel,instanceFeatureIdLabel:t.instanceFeatureIdLabel,pointCloudShading:t.pointCloudShading,clippingPlanes:t.clippingPlanes,backFaceCulling:t.backFaceCulling,shadows:t.shadows,showCreditsOnScreen:t.showCreditsOnScreen,splitDirection:t.splitDirection,enableDebugWireframe:t._enableDebugWireframe,debugWireframe:t.debugWireframe,projectTo2D:t._projectTo2D,enablePick:t._enablePick,enableShowOutline:t._enableShowOutline,showOutline:t.showOutline,outlineColor:t.outlineColor};return ze(i,o)}var iR=tr;var R8n=b(W(),1);function Dp(t,e,n){this._tileset=t,this._tile=e,this._resource=n,this.featurePropertiesDirty=!1,this._metadata=void 0,this._group=void 0,this._ready=!1}Object.defineProperties(Dp.prototype,{featuresLength:{get:function(){return 0}},pointsLength:{get:function(){return 0}},trianglesLength:{get:function(){return 0}},geometryByteLength:{get:function(){return 0}},texturesByteLength:{get:function(){return 0}},batchTableByteLength:{get:function(){return 0}},innerContents:{get:function(){}},ready:{get:function(){return this._ready}},tileset:{get:function(){return this._tileset}},tile:{get:function(){return this._tile}},url:{get:function(){return this._resource.getUrlComponent(!0)}},batchTable:{get:function(){}},metadata:{get:function(){return this._metadata},set:function(t){this._metadata=t}},group:{get:function(){return this._group},set:function(t){this._group=t}}});Dp.fromJson=function(t,e,n,i){let o=new Dp(t,e,n);return o._tileset.loadTileset(o._resource,i,o._tile),o._ready=!0,o};Dp.prototype.hasProperty=function(t,e){return!1};Dp.prototype.getFeature=function(t){};Dp.prototype.applyDebugSettings=function(t,e){};Dp.prototype.applyStyle=function(t){};Dp.prototype.update=function(t,e){};Dp.prototype.pick=function(t,e,n){};Dp.prototype.isDestroyed=function(){return!1};Dp.prototype.destroy=function(){return At(this)};var ZX=Dp;var Fei=b(W(),1);var f$n=b(W(),1);var M6n=b(W(),1);var W8n=b(W(),1),RX=`uniform sampler2D u_atlas; #ifdef VECTOR_TILE uniform vec4 u_highlightColor; @@ -8068,7 +8068,7 @@ void main() #endif } -`;var F8n=R(W(),1),RX=`#ifdef INSTANCED +`;var F8n=b(W(),1),bX=`#ifdef INSTANCED in vec2 direction; #endif in vec4 positionHighAndScale; @@ -8502,19 +8502,19 @@ if (lengthSq < disableDepthTestDistance) { v_color.a *= translucency; } -`;var _8n=R(W(),1);function Eo(t,e){t=f(t,f.EMPTY_OBJECT);let n=t.translucencyByDistance,i=t.pixelOffsetScaleByDistance,o=t.scaleByDistance,a=t.distanceDisplayCondition;c(n)&&(n=ln.clone(n)),c(i)&&(i=ln.clone(i)),c(o)&&(o=ln.clone(o)),c(a)&&(a=Wn.clone(a)),this._show=f(t.show,!0),this._position=p.clone(f(t.position,p.ZERO)),this._actualPosition=p.clone(this._position),this._pixelOffset=K.clone(f(t.pixelOffset,K.ZERO)),this._translate=new K(0,0),this._eyeOffset=p.clone(f(t.eyeOffset,p.ZERO)),this._heightReference=f(t.heightReference,Ge.NONE),this._verticalOrigin=f(t.verticalOrigin,hi.CENTER),this._horizontalOrigin=f(t.horizontalOrigin,to.CENTER),this._scale=f(t.scale,1),this._color=v.clone(f(t.color,v.WHITE)),this._rotation=f(t.rotation,0),this._alignedAxis=p.clone(f(t.alignedAxis,p.ZERO)),this._width=t.width,this._height=t.height,this._scaleByDistance=o,this._translucencyByDistance=n,this._pixelOffsetScaleByDistance=i,this._sizeInMeters=f(t.sizeInMeters,!1),this._distanceDisplayCondition=a,this._disableDepthTestDistance=t.disableDepthTestDistance,this._id=t.id,this._collection=f(t.collection,e),this._pickId=void 0,this._pickPrimitive=f(t._pickPrimitive,this),this._billboardCollection=e,this._dirty=!1,this._index=-1,this._batchIndex=void 0,this._imageIndex=-1,this._imageIndexPromise=void 0,this._imageId=void 0,this._image=void 0,this._imageSubRegion=void 0,this._imageWidth=void 0,this._imageHeight=void 0,this._labelDimensions=void 0,this._labelHorizontalOrigin=void 0,this._labelTranslate=void 0;let s=t.image,l=t.imageId;c(s)&&(c(l)||(typeof s=="string"?l=s:c(s.src)?l=s.src:l=Si()),this._imageId=l,this._image=s),c(t.imageSubRegion)&&(this._imageId=l,this._imageSubRegion=t.imageSubRegion),c(this._billboardCollection._textureAtlas)&&this._loadImage(),this._actualClampedPosition=void 0,this._removeCallbackFunc=void 0,this._mode=ut.SCENE3D,this._clusterShow=!0,this._outlineColor=v.clone(f(t.outlineColor,v.BLACK)),this._outlineWidth=f(t.outlineWidth,0),this._updateClamping()}var TWt=Eo.SHOW_INDEX=0,sP=Eo.POSITION_INDEX=1,CWt=Eo.PIXEL_OFFSET_INDEX=2,Tle=Eo.EYE_OFFSET_INDEX=3,Sle=Eo.HORIZONTAL_ORIGIN_INDEX=4,gle=Eo.VERTICAL_ORIGIN_INDEX=5,Ele=Eo.SCALE_INDEX=6,lP=Eo.IMAGE_INDEX_INDEX=7,SWt=Eo.COLOR_INDEX=8,Cle=Eo.ROTATION_INDEX=9,Ile=Eo.ALIGNED_AXIS_INDEX=10,Nle=Eo.SCALE_BY_DISTANCE_INDEX=11,yle=Eo.TRANSLUCENCY_BY_DISTANCE_INDEX=12,Ble=Eo.PIXEL_OFFSET_SCALE_BY_DISTANCE_INDEX=13,Qle=Eo.DISTANCE_DISPLAY_CONDITION=14,kle=Eo.DISABLE_DEPTH_DISTANCE=15;Eo.TEXTURE_COORDINATE_BOUNDS=16;var gWt=Eo.SDF_INDEX=17;Eo.NUMBER_OF_PROPERTIES=18;function ls(t,e){let n=t._billboardCollection;c(n)&&(n._updateBillboard(t,e),t._dirty=!0)}Object.defineProperties(Eo.prototype,{show:{get:function(){return this._show},set:function(t){this._show!==t&&(this._show=t,ls(this,TWt))}},position:{get:function(){return this._position},set:function(t){let e=this._position;p.equals(e,t)||(p.clone(t,e),p.clone(t,this._actualPosition),this._updateClamping(),ls(this,sP))}},heightReference:{get:function(){return this._heightReference},set:function(t){let e=this._heightReference;t!==e&&(this._heightReference=t,this._updateClamping(),ls(this,sP))}},pixelOffset:{get:function(){return this._pixelOffset},set:function(t){let e=this._pixelOffset;K.equals(e,t)||(K.clone(t,e),ls(this,CWt))}},scaleByDistance:{get:function(){return this._scaleByDistance},set:function(t){let e=this._scaleByDistance;ln.equals(e,t)||(this._scaleByDistance=ln.clone(t,e),ls(this,Nle))}},translucencyByDistance:{get:function(){return this._translucencyByDistance},set:function(t){let e=this._translucencyByDistance;ln.equals(e,t)||(this._translucencyByDistance=ln.clone(t,e),ls(this,yle))}},pixelOffsetScaleByDistance:{get:function(){return this._pixelOffsetScaleByDistance},set:function(t){let e=this._pixelOffsetScaleByDistance;ln.equals(e,t)||(this._pixelOffsetScaleByDistance=ln.clone(t,e),ls(this,Ble))}},eyeOffset:{get:function(){return this._eyeOffset},set:function(t){let e=this._eyeOffset;p.equals(e,t)||(p.clone(t,e),ls(this,Tle))}},horizontalOrigin:{get:function(){return this._horizontalOrigin},set:function(t){this._horizontalOrigin!==t&&(this._horizontalOrigin=t,ls(this,Sle))}},verticalOrigin:{get:function(){return this._verticalOrigin},set:function(t){this._verticalOrigin!==t&&(this._verticalOrigin=t,ls(this,gle))}},scale:{get:function(){return this._scale},set:function(t){this._scale!==t&&(this._scale=t,ls(this,Ele))}},color:{get:function(){return this._color},set:function(t){let e=this._color;v.equals(e,t)||(v.clone(t,e),ls(this,SWt))}},rotation:{get:function(){return this._rotation},set:function(t){this._rotation!==t&&(this._rotation=t,ls(this,Cle))}},alignedAxis:{get:function(){return this._alignedAxis},set:function(t){let e=this._alignedAxis;p.equals(e,t)||(p.clone(t,e),ls(this,Ile))}},width:{get:function(){return f(this._width,this._imageWidth)},set:function(t){this._width!==t&&(this._width=t,ls(this,lP))}},height:{get:function(){return f(this._height,this._imageHeight)},set:function(t){this._height!==t&&(this._height=t,ls(this,lP))}},sizeInMeters:{get:function(){return this._sizeInMeters},set:function(t){this._sizeInMeters!==t&&(this._sizeInMeters=t,ls(this,SWt))}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){Wn.equals(t,this._distanceDisplayCondition)||(this._distanceDisplayCondition=Wn.clone(t,this._distanceDisplayCondition),ls(this,Qle))}},disableDepthTestDistance:{get:function(){return this._disableDepthTestDistance},set:function(t){this._disableDepthTestDistance!==t&&(this._disableDepthTestDistance=t,ls(this,kle))}},id:{get:function(){return this._id},set:function(t){this._id=t,c(this._pickId)&&(this._pickId.object.id=t)}},pickPrimitive:{get:function(){return this._pickPrimitive},set:function(t){this._pickPrimitive=t,c(this._pickId)&&(this._pickId.object.primitive=t)}},pickId:{get:function(){return this._pickId}},image:{get:function(){return this._imageId},set:function(t){c(t)?typeof t=="string"?this.setImage(t,t):t instanceof te?this.setImage(t.url,t):c(t.src)?this.setImage(t.src,t):this.setImage(Si(),t):(this._imageIndex=-1,this._imageSubRegion=void 0,this._imageId=void 0,this._image=void 0,this._imageIndexPromise=void 0,ls(this,lP))}},ready:{get:function(){return this._imageIndex!==-1}},_clampedPosition:{get:function(){return this._actualClampedPosition},set:function(t){this._actualClampedPosition=p.clone(t,this._actualClampedPosition),ls(this,sP)}},clusterShow:{get:function(){return this._clusterShow},set:function(t){this._clusterShow!==t&&(this._clusterShow=t,ls(this,TWt))}},outlineColor:{get:function(){return this._outlineColor},set:function(t){let e=this._outlineColor;v.equals(e,t)||(v.clone(t,e),ls(this,gWt))}},outlineWidth:{get:function(){return this._outlineWidth},set:function(t){this._outlineWidth!==t&&(this._outlineWidth=t,ls(this,gWt))}}});Eo.prototype.getPickId=function(t){return c(this._pickId)||(this._pickId=t.createPickId({primitive:this._pickPrimitive,collection:this._collection,id:this._id})),this._pickId};Eo.prototype._updateClamping=function(){Eo._updateClamping(this._billboardCollection,this)};var rP=new gt;Eo._updateClamping=function(t,e){let n=t._scene;if(!c(n))return;let i=n.globe,o=f(i?.ellipsoid,mt.WGS84),a=n.frameState.mode,s=a!==e._mode;if(e._mode=a,(e._heightReference===Ge.NONE||s)&&c(e._removeCallbackFunc)&&(e._removeCallbackFunc(),e._removeCallbackFunc=void 0,e._clampedPosition=void 0),e._heightReference===Ge.NONE||!c(e._position))return;c(e._removeCallbackFunc)&&e._removeCallbackFunc();let l=o.cartesianToCartographic(e._position);if(!c(l)){e._actualClampedPosition=void 0;return}function r(m){let h=o.cartographicToCartesian(m,e._clampedPosition);dE(e._heightReference)&&(e._mode===ut.SCENE3D?(m.height+=l.height,o.cartographicToCartesian(m,h)):h.x+=l.height),e._clampedPosition=h}e._removeCallbackFunc=n.updateHeight(l,r,e._heightReference),gt.clone(l,rP);let d=n.getHeight(l,e._heightReference);c(d)&&(rP.height=d),r(rP)};Eo.prototype._loadImage=function(){let t=this._billboardCollection._textureAtlas,e=this._imageId,n=this._image,i=this._imageSubRegion,o,a=this;function s(r){if(a._imageId!==e||a._image!==n||!Fe.equals(a._imageSubRegion,i))return;let d=t.textureCoordinates[r];a._imageWidth=t.texture.width*d.width,a._imageHeight=t.texture.height*d.height,a._imageIndex=r,a._ready=!0,a._image=void 0,a._imageIndexPromise=void 0,ls(a,lP);let m=a._billboardCollection._scene;c(m)&&m.frameState.afterRender.push(()=>!0)}if(c(n)&&(o=t.addImage(e,n)),c(i)&&(o=t.addSubRegion(e,i)),this._imageIndexPromise=o,!c(o))return;let l=t.getImageIndex(e);if(c(l)&&!c(i)){s(l);return}o.then(s).catch(function(r){console.error(`Error loading image for billboard: ${r}`),a._imageIndexPromise=void 0})};Eo.prototype.setImage=function(t,e){this._imageId!==t&&(this._imageIndex=-1,this._imageSubRegion=void 0,this._imageId=t,this._image=e,c(this._billboardCollection._textureAtlas)&&this._loadImage())};Eo.prototype.setImageSubRegion=function(t,e){this._imageId===t&&Fe.equals(this._imageSubRegion,e)||(this._imageIndex=-1,this._imageId=t,this._imageSubRegion=Fe.clone(e),c(this._billboardCollection._textureAtlas)&&this._loadImage())};Eo.prototype._setTranslate=function(t){let e=this._translate;K.equals(e,t)||(K.clone(t,e),ls(this,CWt))};Eo.prototype._getActualPosition=function(){return c(this._clampedPosition)?this._clampedPosition:this._actualPosition};Eo.prototype._setActualPosition=function(t){c(this._clampedPosition)||p.clone(t,this._actualPosition),ls(this,sP)};var EWt=new Rt;Eo._computeActualPosition=function(t,e,n,i){return c(t._clampedPosition)?(n.mode!==t._mode&&t._updateClamping(),t._clampedPosition):n.mode===ut.SCENE3D?e:(L.multiplyByPoint(i,e,EWt),qo.computeActualWgs84Position(n,EWt))};var IWt=new p;Eo._computeScreenSpacePosition=function(t,e,n,i,o,a){let s=L.multiplyByPoint(t,e,IWt),l=qo.wgs84WithEyeOffsetToWindowCoordinates(o,s,n,a);if(c(l))return K.add(l,i,l),l};var aP=new K(0,0);Eo.prototype.computeScreenSpacePosition=function(t,e){let n=this._billboardCollection;c(e)||(e=new K),K.clone(this._pixelOffset,aP),K.add(aP,this._translate,aP);let i=n.modelMatrix,o=this._position;if(c(this._clampedPosition)&&(o=this._clampedPosition,t.mode!==ut.SCENE3D)){let s=t.mapProjection,l=s.ellipsoid,r=s.unproject(o,rP);o=l.cartographicToCartesian(r,IWt),i=L.IDENTITY}return Eo._computeScreenSpacePosition(i,o,this._eyeOffset,aP,t,e)};Eo.getScreenSpaceBoundingBox=function(t,e,n){let i=t.width,o=t.height,a=t.scale;i*=a,o*=a;let s=e.x;t.horizontalOrigin===to.RIGHT?s-=i:t.horizontalOrigin===to.CENTER&&(s-=i*.5);let l=e.y;return t.verticalOrigin===hi.BOTTOM||t.verticalOrigin===hi.BASELINE?l-=o:t.verticalOrigin===hi.CENTER&&(l-=o*.5),c(n)||(n=new Fe),n.x=s,n.y=l,n.width=i,n.height=o,n};Eo.prototype.equals=function(t){return this===t||c(t)&&this._id===t._id&&p.equals(this._position,t._position)&&this._imageId===t._imageId&&this._show===t._show&&this._scale===t._scale&&this._verticalOrigin===t._verticalOrigin&&this._horizontalOrigin===t._horizontalOrigin&&this._heightReference===t._heightReference&&Fe.equals(this._imageSubRegion,t._imageSubRegion)&&v.equals(this._color,t._color)&&K.equals(this._pixelOffset,t._pixelOffset)&&K.equals(this._translate,t._translate)&&p.equals(this._eyeOffset,t._eyeOffset)&&ln.equals(this._scaleByDistance,t._scaleByDistance)&&ln.equals(this._translucencyByDistance,t._translucencyByDistance)&&ln.equals(this._pixelOffsetScaleByDistance,t._pixelOffsetScaleByDistance)&&Wn.equals(this._distanceDisplayCondition,t._distanceDisplayCondition)&&this._disableDepthTestDistance===t._disableDepthTestDistance};Eo.prototype._destroy=function(){c(this._customData)&&(this._billboardCollection._scene.globe._surface.removeTileCustomData(this._customData),this._customData=void 0),c(this._removeCallbackFunc)&&(this._removeCallbackFunc(),this._removeCallbackFunc=void 0),this.image=void 0,this._pickId=this._pickId&&this._pickId.destroy(),this._billboardCollection=void 0};var Na=Eo;var O8n=R(W(),1),Yle={OPAQUE:0,TRANSLUCENT:1,OPAQUE_AND_TRANSLUCENT:2},wa=Object.freeze(Yle);var w8n=R(W(),1),xle={FONT_SIZE:48,PADDING:10,RADIUS:8,CUTOFF:.25},Ar=Object.freeze(xle);var a6n=R(W(),1);function V0(t,e,n,i,o){this.bottomLeft=f(t,K.ZERO),this.topRight=f(e,K.ZERO),this.childNode1=n,this.childNode2=i,this.imageIndex=o}var Xle=new K(16,16);function rF(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.borderWidthInPixels,1),n=f(t.initialSize,Xle);this._context=t.context,this._pixelFormat=f(t.pixelFormat,Ye.RGBA),this._borderWidthInPixels=e,this._textureCoordinates=[],this._guid=Si(),this._idHash={},this._indexHash={},this._initialSize=n,this._root=void 0}Object.defineProperties(rF.prototype,{borderWidthInPixels:{get:function(){return this._borderWidthInPixels}},textureCoordinates:{get:function(){return this._textureCoordinates}},texture:{get:function(){return c(this._texture)||(this._texture=new hn({context:this._context,width:this._initialSize.x,height:this._initialSize.y,pixelFormat:this._pixelFormat})),this._texture}},numberOfImages:{get:function(){return this._textureCoordinates.length}},guid:{get:function(){return this._guid}}});function Jle(t,e){let n=t._context,i=t.numberOfImages,o=2,a=t._borderWidthInPixels;if(i>0){let s=t._texture.width,l=t._texture.height,r=o*(s+e.width+a),d=o*(l+e.height+a),m=s/r,h=l/d,Z=new V0(new K(s+a,a),new K(r,l)),b=new V0(new K,new K(r,l),t._root,Z),u=new V0(new K(a,l+a),new K(r,d)),F=new V0(new K,new K(r,d),b,u);for(let A=0;As){e.childNode1=new V0(new K(e.bottomLeft.x,e.bottomLeft.y),new K(e.bottomLeft.x+n.width,e.topRight.y));let l=e.bottomLeft.x+n.width+t._borderWidthInPixels;l0)&&(t._shaderDisableDepthDistance=!0,m===Number.POSITIVE_INFINITY&&(m=-1));let Z,b;if(c(o._labelDimensions))b=o._labelDimensions.x,Z=o._labelDimensions.y;else{let G=0,A=0,T=o._imageIndex;if(T!==-1){let C=n[T];G=C.height,A=C.width}Z=Math.round(f(o.height,t._textureAtlas.texture.dimensions.y*G));let g=t._textureAtlas.texture.width;b=Math.round(f(o.width,g*A))}let u=Math.floor(k.clamp(b,0,K$)),F=Math.floor(k.clamp(Z,0,K$)),U=u*K$+F;t._instanced?(a=o._index,s(a,l,r,m,U)):(a=o._index*4,s(a+0,l,r,m,U),s(a+1,l,r,m,U),s(a+2,l,r,m,U),s(a+3,l,r,m,U))}function $Wt(t,e,n,i,o){if(Np(o.heightReference)){let u=t._scene,F=e.context,U=e.globeTranslucencyState.translucent,G=c(u.globe)&&u.globe.depthTestAgainstTerrain;t._shaderClampToGround=F.depthTexture&&!U&&G}let a,s=i[Ma.textureCoordinateBoundsOrLabelTranslate];if(Sn.maximumVertexTextureImageUnits>0){let u=0,F=0;c(o._labelTranslate)&&(u=o._labelTranslate.x,F=o._labelTranslate.y),t._instanced?(a=o._index,s(a,u,F,0,0)):(a=o._index*4,s(a+0,u,F,0,0),s(a+1,u,F,0,0),s(a+2,u,F,0,0),s(a+3,u,F,0,0));return}let l=0,r=0,d=0,m=0,h=o._imageIndex;if(h!==-1){let u=n[h];l=u.x,r=u.y,d=u.width,m=u.height}let Z=l+d,b=r+m;t._instanced?(a=o._index,s(a,l,r,Z,b)):(a=o._index*4,s(a+0,l,r,Z,b),s(a+1,l,r,Z,b),s(a+2,l,r,Z,b),s(a+3,l,r,Z,b))}function ore(t,e,n,i,o){if(!c(t._batchTable))return;let a=i[Ma.a_batchId],s=o._batchIndex,l;t._instanced?(l=o._index,a(l,s)):(l=o._index*4,a(l+0,s),a(l+1,s),a(l+2,s),a(l+3,s))}function tft(t,e,n,i,o){if(!t._sdf)return;let a,s=i[Ma.sdf],l=o.outlineColor,r=o.outlineWidth,d=v.floatToByte(l.red),m=v.floatToByte(l.green),h=v.floatToByte(l.blue),Z=d*ZC+m*ob+h,b=r/Ar.RADIUS,u=v.floatToByte(l.alpha)*ZC+v.floatToByte(b)*ob;t._instanced?(a=o._index,s(a,Z,u)):(a=o._index*4,s(a+0,Z+OWt,u),s(a+1,Z+HWt,u),s(a+2,Z+wWt,u),s(a+3,Z+PWt,u))}function are(t,e,n,i,o){_Wt(t,e,n,i,o),vWt(t,e,n,i,o),KWt(t,e,n,i,o),j$(t,e,n,i,o),q$(t,e,n,i,o),zWt(t,e,n,i,o),jWt(t,e,n,i,o),qWt(t,e,n,i,o),$Wt(t,e,n,i,o),ore(t,e,n,i,o),tft(t,e,n,i,o)}function z$(t,e,n,i,o,a){let s;i.mode===ut.SCENE3D?(s=t._baseVolume,t._boundingVolumeDirty=!0):s=t._baseVolume2D;let l=[];for(let r=0;r!0)}if(c(n)&&(o=t.addImage(e,n)),c(i)&&(o=t.addSubRegion(e,i)),this._imageIndexPromise=o,!c(o))return;let l=t.getImageIndex(e);if(c(l)&&!c(i)){s(l);return}o.then(s).catch(function(r){console.error(`Error loading image for billboard: ${r}`),a._imageIndexPromise=void 0})};Eo.prototype.setImage=function(t,e){this._imageId!==t&&(this._imageIndex=-1,this._imageSubRegion=void 0,this._imageId=t,this._image=e,c(this._billboardCollection._textureAtlas)&&this._loadImage())};Eo.prototype.setImageSubRegion=function(t,e){this._imageId===t&&Fe.equals(this._imageSubRegion,e)||(this._imageIndex=-1,this._imageId=t,this._imageSubRegion=Fe.clone(e),c(this._billboardCollection._textureAtlas)&&this._loadImage())};Eo.prototype._setTranslate=function(t){let e=this._translate;K.equals(e,t)||(K.clone(t,e),ls(this,CWt))};Eo.prototype._getActualPosition=function(){return c(this._clampedPosition)?this._clampedPosition:this._actualPosition};Eo.prototype._setActualPosition=function(t){c(this._clampedPosition)||p.clone(t,this._actualPosition),ls(this,sP)};var EWt=new bt;Eo._computeActualPosition=function(t,e,n,i){return c(t._clampedPosition)?(n.mode!==t._mode&&t._updateClamping(),t._clampedPosition):n.mode===Vt.SCENE3D?e:(L.multiplyByPoint(i,e,EWt),qo.computeActualWgs84Position(n,EWt))};var IWt=new p;Eo._computeScreenSpacePosition=function(t,e,n,i,o,a){let s=L.multiplyByPoint(t,e,IWt),l=qo.wgs84WithEyeOffsetToWindowCoordinates(o,s,n,a);if(c(l))return K.add(l,i,l),l};var aP=new K(0,0);Eo.prototype.computeScreenSpacePosition=function(t,e){let n=this._billboardCollection;c(e)||(e=new K),K.clone(this._pixelOffset,aP),K.add(aP,this._translate,aP);let i=n.modelMatrix,o=this._position;if(c(this._clampedPosition)&&(o=this._clampedPosition,t.mode!==Vt.SCENE3D)){let s=t.mapProjection,l=s.ellipsoid,r=s.unproject(o,rP);o=l.cartographicToCartesian(r,IWt),i=L.IDENTITY}return Eo._computeScreenSpacePosition(i,o,this._eyeOffset,aP,t,e)};Eo.getScreenSpaceBoundingBox=function(t,e,n){let i=t.width,o=t.height,a=t.scale;i*=a,o*=a;let s=e.x;t.horizontalOrigin===to.RIGHT?s-=i:t.horizontalOrigin===to.CENTER&&(s-=i*.5);let l=e.y;return t.verticalOrigin===hi.BOTTOM||t.verticalOrigin===hi.BASELINE?l-=o:t.verticalOrigin===hi.CENTER&&(l-=o*.5),c(n)||(n=new Fe),n.x=s,n.y=l,n.width=i,n.height=o,n};Eo.prototype.equals=function(t){return this===t||c(t)&&this._id===t._id&&p.equals(this._position,t._position)&&this._imageId===t._imageId&&this._show===t._show&&this._scale===t._scale&&this._verticalOrigin===t._verticalOrigin&&this._horizontalOrigin===t._horizontalOrigin&&this._heightReference===t._heightReference&&Fe.equals(this._imageSubRegion,t._imageSubRegion)&&v.equals(this._color,t._color)&&K.equals(this._pixelOffset,t._pixelOffset)&&K.equals(this._translate,t._translate)&&p.equals(this._eyeOffset,t._eyeOffset)&&ln.equals(this._scaleByDistance,t._scaleByDistance)&&ln.equals(this._translucencyByDistance,t._translucencyByDistance)&&ln.equals(this._pixelOffsetScaleByDistance,t._pixelOffsetScaleByDistance)&&Wn.equals(this._distanceDisplayCondition,t._distanceDisplayCondition)&&this._disableDepthTestDistance===t._disableDepthTestDistance};Eo.prototype._destroy=function(){c(this._customData)&&(this._billboardCollection._scene.globe._surface.removeTileCustomData(this._customData),this._customData=void 0),c(this._removeCallbackFunc)&&(this._removeCallbackFunc(),this._removeCallbackFunc=void 0),this.image=void 0,this._pickId=this._pickId&&this._pickId.destroy(),this._billboardCollection=void 0};var Na=Eo;var O8n=b(W(),1),Yle={OPAQUE:0,TRANSLUCENT:1,OPAQUE_AND_TRANSLUCENT:2},wa=Object.freeze(Yle);var w8n=b(W(),1),xle={FONT_SIZE:48,PADDING:10,RADIUS:8,CUTOFF:.25},Ar=Object.freeze(xle);var a6n=b(W(),1);function Z0(t,e,n,i,o){this.bottomLeft=f(t,K.ZERO),this.topRight=f(e,K.ZERO),this.childNode1=n,this.childNode2=i,this.imageIndex=o}var Xle=new K(16,16);function rF(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.borderWidthInPixels,1),n=f(t.initialSize,Xle);this._context=t.context,this._pixelFormat=f(t.pixelFormat,Ye.RGBA),this._borderWidthInPixels=e,this._textureCoordinates=[],this._guid=Ti(),this._idHash={},this._indexHash={},this._initialSize=n,this._root=void 0}Object.defineProperties(rF.prototype,{borderWidthInPixels:{get:function(){return this._borderWidthInPixels}},textureCoordinates:{get:function(){return this._textureCoordinates}},texture:{get:function(){return c(this._texture)||(this._texture=new hn({context:this._context,width:this._initialSize.x,height:this._initialSize.y,pixelFormat:this._pixelFormat})),this._texture}},numberOfImages:{get:function(){return this._textureCoordinates.length}},guid:{get:function(){return this._guid}}});function Jle(t,e){let n=t._context,i=t.numberOfImages,o=2,a=t._borderWidthInPixels;if(i>0){let s=t._texture.width,l=t._texture.height,r=o*(s+e.width+a),d=o*(l+e.height+a),m=s/r,h=l/d,u=new Z0(new K(s+a,a),new K(r,l)),R=new Z0(new K,new K(r,l),t._root,u),V=new Z0(new K(a,l+a),new K(r,d)),F=new Z0(new K,new K(r,d),R,V);for(let A=0;As){e.childNode1=new Z0(new K(e.bottomLeft.x,e.bottomLeft.y),new K(e.bottomLeft.x+n.width,e.topRight.y));let l=e.bottomLeft.x+n.width+t._borderWidthInPixels;l0)&&(t._shaderDisableDepthDistance=!0,m===Number.POSITIVE_INFINITY&&(m=-1));let u,R;if(c(o._labelDimensions))R=o._labelDimensions.x,u=o._labelDimensions.y;else{let G=0,A=0,S=o._imageIndex;if(S!==-1){let C=n[S];G=C.height,A=C.width}u=Math.round(f(o.height,t._textureAtlas.texture.dimensions.y*G));let g=t._textureAtlas.texture.width;R=Math.round(f(o.width,g*A))}let V=Math.floor(k.clamp(R,0,K$)),F=Math.floor(k.clamp(u,0,K$)),U=V*K$+F;t._instanced?(a=o._index,s(a,l,r,m,U)):(a=o._index*4,s(a+0,l,r,m,U),s(a+1,l,r,m,U),s(a+2,l,r,m,U),s(a+3,l,r,m,U))}function $Wt(t,e,n,i,o){if(Np(o.heightReference)){let V=t._scene,F=e.context,U=e.globeTranslucencyState.translucent,G=c(V.globe)&&V.globe.depthTestAgainstTerrain;t._shaderClampToGround=F.depthTexture&&!U&&G}let a,s=i[Ma.textureCoordinateBoundsOrLabelTranslate];if(Tn.maximumVertexTextureImageUnits>0){let V=0,F=0;c(o._labelTranslate)&&(V=o._labelTranslate.x,F=o._labelTranslate.y),t._instanced?(a=o._index,s(a,V,F,0,0)):(a=o._index*4,s(a+0,V,F,0,0),s(a+1,V,F,0,0),s(a+2,V,F,0,0),s(a+3,V,F,0,0));return}let l=0,r=0,d=0,m=0,h=o._imageIndex;if(h!==-1){let V=n[h];l=V.x,r=V.y,d=V.width,m=V.height}let u=l+d,R=r+m;t._instanced?(a=o._index,s(a,l,r,u,R)):(a=o._index*4,s(a+0,l,r,u,R),s(a+1,l,r,u,R),s(a+2,l,r,u,R),s(a+3,l,r,u,R))}function ore(t,e,n,i,o){if(!c(t._batchTable))return;let a=i[Ma.a_batchId],s=o._batchIndex,l;t._instanced?(l=o._index,a(l,s)):(l=o._index*4,a(l+0,s),a(l+1,s),a(l+2,s),a(l+3,s))}function tft(t,e,n,i,o){if(!t._sdf)return;let a,s=i[Ma.sdf],l=o.outlineColor,r=o.outlineWidth,d=v.floatToByte(l.red),m=v.floatToByte(l.green),h=v.floatToByte(l.blue),u=d*uC+m*oR+h,R=r/Ar.RADIUS,V=v.floatToByte(l.alpha)*uC+v.floatToByte(R)*oR;t._instanced?(a=o._index,s(a,u,V)):(a=o._index*4,s(a+0,u+OWt,V),s(a+1,u+HWt,V),s(a+2,u+wWt,V),s(a+3,u+PWt,V))}function are(t,e,n,i,o){_Wt(t,e,n,i,o),vWt(t,e,n,i,o),KWt(t,e,n,i,o),j$(t,e,n,i,o),q$(t,e,n,i,o),zWt(t,e,n,i,o),jWt(t,e,n,i,o),qWt(t,e,n,i,o),$Wt(t,e,n,i,o),ore(t,e,n,i,o),tft(t,e,n,i,o)}function z$(t,e,n,i,o,a){let s;i.mode===Vt.SCENE3D?(s=t._baseVolume,t._boundingVolumeDirty=!0):s=t._baseVolume2D;let l=[];for(let r=0;r0){this._vaf=$le(i,n,this._buffersUsage,this._instanced,this._batchTable,this._sdf),h=this._vaf.writers;for(let Q=0;Q0){let Q=dre;Q.length=0,(r[fX]||r[Ole]||r[Dle])&&Q.push(_Wt),(r[WX]||r[BWt]||r[Mle]||r[_le]||r[Lle])&&(Q.push(vWt),this._instanced&&Q.push(q$)),(r[WX]||r[Hle]||r[xWt])&&(Q.push(KWt),Q.push(j$)),(r[WX]||r[kWt])&&Q.push(j$),r[QWt]&&Q.push(q$),r[YWt]&&Q.push(zWt),r[XWt]&&Q.push(jWt),(r[JWt]||r[wle]||r[WX]||r[fX])&&Q.push(qWt),(r[WX]||r[fX])&&Q.push($Wt),r[LWt]&&Q.push(tft);let J=Q.length;if(h=this._vaf.writers,l/n>.1){for(let M=0;Mn*1.5&&(s.length=n),!c(this._vaf)||!c(this._vaf.va))return;this._boundingVolumeDirty&&(this._boundingVolumeDirty=!1,Ft.transform(this._baseVolume,this.modelMatrix,this._baseVolumeWC));let u,F=L.IDENTITY;t.mode===ut.SCENE3D?(F=this.modelMatrix,u=Ft.clone(this._baseVolumeWC,this._boundingVolume)):u=Ft.clone(this._baseVolume2D,this._boundingVolume),lre(this,t,u);let U=this._blendOption!==this.blendOption;if(this._blendOption=this.blendOption,U){this._blendOption===wa.OPAQUE||this._blendOption===wa.OPAQUE_AND_TRANSLUCENT?this._rsOpaque=he.fromCache({depthTest:{enabled:!0,func:pt.LESS},depthMask:!0}):this._rsOpaque=void 0;let Q=this._blendOption===wa.TRANSLUCENT;this._blendOption===wa.TRANSLUCENT||this._blendOption===wa.OPAQUE_AND_TRANSLUCENT?this._rsTranslucent=he.fromCache({depthTest:{enabled:!0,func:Q?pt.LEQUAL:pt.LESS},depthMask:Q,blending:Pn.ALPHA_BLEND}):this._rsTranslucent=void 0}this._shaderDisableDepthDistance=this._shaderDisableDepthDistance||t.minimumDisableDepthTestDistance!==0;let G,A,T,g,C,y=Sn.maximumVertexTextureImageUnits>0;if(U||this._shaderRotation!==this._compiledShaderRotation||this._shaderAlignedAxis!==this._compiledShaderAlignedAxis||this._shaderScaleByDistance!==this._compiledShaderScaleByDistance||this._shaderTranslucencyByDistance!==this._compiledShaderTranslucencyByDistance||this._shaderPixelOffsetScaleByDistance!==this._compiledShaderPixelOffsetScaleByDistance||this._shaderDistanceDisplayCondition!==this._compiledShaderDistanceDisplayCondition||this._shaderDisableDepthDistance!==this._compiledShaderDisableDepthDistance||this._shaderClampToGround!==this._compiledShaderClampToGround||this._sdf!==this._compiledSDF){G=RX,A=bX,C=[],c(this._batchTable)&&(C.push("VECTOR_TILE"),G=this._batchTable.getVertexShaderCallback(!1,"a_batchId",void 0)(G),A=this._batchTable.getFragmentShaderCallback(!1,void 0)(A)),T=new Ve({defines:C,sources:[G]}),this._instanced&&T.defines.push("INSTANCED"),this._shaderRotation&&T.defines.push("ROTATION"),this._shaderAlignedAxis&&T.defines.push("ALIGNED_AXIS"),this._shaderScaleByDistance&&T.defines.push("EYE_DISTANCE_SCALING"),this._shaderTranslucencyByDistance&&T.defines.push("EYE_DISTANCE_TRANSLUCENCY"),this._shaderPixelOffsetScaleByDistance&&T.defines.push("EYE_DISTANCE_PIXEL_OFFSET"),this._shaderDistanceDisplayCondition&&T.defines.push("DISTANCE_DISPLAY_CONDITION"),this._shaderDisableDepthDistance&&T.defines.push("DISABLE_DEPTH_DISTANCE"),this._shaderClampToGround&&(y?T.defines.push("VERTEX_DEPTH_CHECK"):T.defines.push("FRAGMENT_DEPTH_CHECK"));let Q=1-Ar.CUTOFF;this._sdf&&T.defines.push("SDF");let J=c(this._batchTable)?"VECTOR_TILE":"";this._blendOption===wa.OPAQUE_AND_TRANSLUCENT&&(g=new Ve({defines:["OPAQUE",J],sources:[A]}),this._shaderClampToGround&&(y?g.defines.push("VERTEX_DEPTH_CHECK"):g.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(g.defines.push("SDF"),g.defines.push(`SDF_EDGE ${Q}`)),this._sp=xn.replaceCache({context:i,shaderProgram:this._sp,vertexShaderSource:T,fragmentShaderSource:g,attributeLocations:Ma}),g=new Ve({defines:["TRANSLUCENT",J],sources:[A]}),this._shaderClampToGround&&(y?g.defines.push("VERTEX_DEPTH_CHECK"):g.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(g.defines.push("SDF"),g.defines.push(`SDF_EDGE ${Q}`)),this._spTranslucent=xn.replaceCache({context:i,shaderProgram:this._spTranslucent,vertexShaderSource:T,fragmentShaderSource:g,attributeLocations:Ma})),this._blendOption===wa.OPAQUE&&(g=new Ve({defines:[J],sources:[A]}),this._shaderClampToGround&&(y?g.defines.push("VERTEX_DEPTH_CHECK"):g.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(g.defines.push("SDF"),g.defines.push(`SDF_EDGE ${Q}`)),this._sp=xn.replaceCache({context:i,shaderProgram:this._sp,vertexShaderSource:T,fragmentShaderSource:g,attributeLocations:Ma})),this._blendOption===wa.TRANSLUCENT&&(g=new Ve({defines:[J],sources:[A]}),this._shaderClampToGround&&(y?g.defines.push("VERTEX_DEPTH_CHECK"):g.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(g.defines.push("SDF"),g.defines.push(`SDF_EDGE ${Q}`)),this._spTranslucent=xn.replaceCache({context:i,shaderProgram:this._spTranslucent,vertexShaderSource:T,fragmentShaderSource:g,attributeLocations:Ma})),this._compiledShaderRotation=this._shaderRotation,this._compiledShaderAlignedAxis=this._shaderAlignedAxis,this._compiledShaderScaleByDistance=this._shaderScaleByDistance,this._compiledShaderTranslucencyByDistance=this._shaderTranslucencyByDistance,this._compiledShaderPixelOffsetScaleByDistance=this._shaderPixelOffsetScaleByDistance,this._compiledShaderDistanceDisplayCondition=this._shaderDistanceDisplayCondition,this._compiledShaderDisableDepthDistance=this._shaderDisableDepthDistance,this._compiledShaderClampToGround=this._shaderClampToGround,this._compiledSDF=this._sdf}let Y=t.commandList;if(Z.render||Z.pick){let Q=this._colorCommands,J=this._blendOption===wa.OPAQUE,M=this._blendOption===wa.OPAQUE_AND_TRANSLUCENT,V=this._vaf.va,E=V.length,I=this._uniforms,B;c(this._batchTable)?(I=this._batchTable.getUniformMapCallback()(I),B=this._batchTable.getPickId()):B="v_pickColor",Q.length=E;let X=M?E*2:E;for(let _=0;_0}},labelOutlineColor:{get:function(){return this._label.outlineColor},set:function(t){this._label.outlineColor=t}},labelOutlineWidth:{get:function(){return this._label.outlineWidth},set:function(t){this._label.outlineWidth=t}},font:{get:function(){return this._label.font},set:function(t){this._label.font=t}},labelStyle:{get:function(){return this._label.style},set:function(t){this._label.style=t}},labelText:{get:function(){return this._label.text},set:function(t){c(t)||(t=""),this._label.text=t}},backgroundColor:{get:function(){return this._label.backgroundColor},set:function(t){this._label.backgroundColor=t}},backgroundPadding:{get:function(){return this._label.backgroundPadding},set:function(t){this._label.backgroundPadding=t}},backgroundEnabled:{get:function(){return this._label.showBackground},set:function(t){this._label.showBackground=t}},scaleByDistance:{get:function(){return this._label.scaleByDistance},set:function(t){this._label.scaleByDistance=t,this._billboard.scaleByDistance=t}},translucencyByDistance:{get:function(){return this._label.translucencyByDistance},set:function(t){this._label.translucencyByDistance=t,this._billboard.translucencyByDistance=t}},distanceDisplayCondition:{get:function(){return this._label.distanceDisplayCondition},set:function(t){this._label.distanceDisplayCondition=t,this._polyline.distanceDisplayCondition=t,this._billboard.distanceDisplayCondition=t}},heightOffset:{get:function(){return this._heightOffset},set:function(t){let e=f(this._heightOffset,0),n=this._content.tileset.ellipsoid,i=n.cartesianToCartographic(this._billboard.position,mre);i.height=i.height-e+t;let o=n.cartographicToCartesian(i);this._billboard.position=o,this._label.position=this._billboard.position,this._polyline.positions=[this._polyline.positions[0],o],this._heightOffset=t}},anchorLineEnabled:{get:function(){return this._polyline.show},set:function(t){this._polyline.show=t}},anchorLineColor:{get:function(){return this._polyline.material.uniforms.color},set:function(t){this._polyline.material.uniforms.color=v.clone(t,this._polyline.material.uniforms.color)}},image:{get:function(){return this._billboardImage},set:function(t){let e=this._billboardImage!==t;this._billboardImage=t,e&&VC(this)}},disableDepthTestDistance:{get:function(){return this._label.disableDepthTestDistance},set:function(t){this._label.disableDepthTestDistance=t,this._billboard.disableDepthTestDistance=t}},horizontalOrigin:{get:function(){return this._billboard.horizontalOrigin},set:function(t){this._billboard.horizontalOrigin=t}},verticalOrigin:{get:function(){return this._billboard.verticalOrigin},set:function(t){this._billboard.verticalOrigin=t}},labelHorizontalOrigin:{get:function(){return this._label.horizontalOrigin},set:function(t){this._label.horizontalOrigin=t}},labelVerticalOrigin:{get:function(){return this._label.verticalOrigin},set:function(t){this._label.verticalOrigin=t}},content:{get:function(){return this._content}},tileset:{get:function(){return this._content.tileset}},primitive:{get:function(){return this._content.tileset}},pickIds:{get:function(){let t=this._pickIds;return t[0]=this._billboard.pickId,t[1]=this._label.pickId,t[2]=this._polyline.pickId,t}}});wr.defaultColor=v.WHITE;wr.defaultPointOutlineColor=v.BLACK;wr.defaultPointOutlineWidth=0;wr.defaultPointSize=8;function VC(t){let e=t._billboard;if(c(t._billboardImage)&&t._billboardImage!==e.image){e.image=t._billboardImage;return}if(c(t._billboardImage))return;let n=f(t._color,wr.defaultColor),i=f(t._pointOutlineColor,wr.defaultPointOutlineColor),o=f(t._pointOutlineWidth,wr.defaultPointOutlineWidth),a=f(t._pointSize,wr.defaultPointSize),s=t._billboardColor,l=t._billboardOutlineColor,r=t._billboardOutlineWidth,d=t._billboardSize;if(v.equals(n,s)&&v.equals(i,l)&&o===r&&a===d)return;t._billboardColor=v.clone(n,t._billboardColor),t._billboardOutlineColor=v.clone(i,t._billboardOutlineColor),t._billboardOutlineWidth=o,t._billboardSize=a;let m=n.alpha,h=n.toCssColorString(),Z=i.toCssColorString(),b=JSON.stringify([h,a,Z,o]);e.setImage(b,XA(m,h,Z,o,a))}wr.prototype.hasProperty=function(t){return this._content.batchTable.hasProperty(this._batchId,t)};wr.prototype.getPropertyIds=function(t){return this._content.batchTable.getPropertyIds(this._batchId,t)};wr.prototype.getProperty=function(t){return this._content.batchTable.getProperty(this._batchId,t)};wr.prototype.getPropertyInherited=function(t){return Fr.getPropertyInherited(this._content,this._batchId,t)};wr.prototype.setProperty=function(t,e){this._content.batchTable.setProperty(this._batchId,t,e),this._content.featurePropertiesDirty=!0};wr.prototype.isExactClass=function(t){return this._content.batchTable.isExactClass(this._batchId,t)};wr.prototype.isClass=function(t){return this._content.batchTable.isClass(this._batchId,t)};wr.prototype.getExactClassName=function(){return this._content.batchTable.getExactClassName(this._batchId)};var b0=wr;var D7n=R(W(),1);var n7n=R(W(),1);function hre(t,e,n,i,o){let a=t.measureText(e);if(!!/\S/.test(e)){let l=document.defaultView.getComputedStyle(t.canvas).getPropertyValue("font-size").replace("px",""),r=document.createElement("canvas"),d=100,m=a.width+d|0,h=3*l,Z=h/2;r.width=m,r.height=h;let b=r.getContext("2d");b.font=n,b.fillStyle="white",b.fillRect(0,0,r.width+1,r.height+1),i&&(b.strokeStyle="black",b.lineWidth=t.lineWidth,b.strokeText(e,d/2,Z)),o&&(b.fillStyle="black",b.fillText(e,d/2,Z));let u=b.getImageData(0,0,m,h).data,F=u.length,U=m*4,G,A,T,g;for(G=0;G=0;--G)if(u[G]!==255){g=G/U|0;break}let C=-1;for(G=0;G]/,o=[],a="",s=_l.LTR,l="",r=t.length;for(let d=0;d";case">":return"<"}}var Ure="\u05D0-\u05EA",Gre="\u0600-\u06FF\u0750-\u077F\u08A0-\u08FF",lft=new RegExp(`[${Ure}${Gre}]`);function Are(t){let e=t.split(` +`,{uniformMap:{billboard_texture:function(){return t._textureAtlas.texture}}});return i.pass=Pt.OVERLAY,i}var dre=[];wp.prototype.update=function(t){if(ttt(this),!this.show)return;let e=this._billboards,n=e.length,i=t.context;this._instanced=i.instancedArrays,Ma=this._instanced?Kle:vle,P$=this._instanced?jle:zle;let o=this._textureAtlas;if(!c(o)){o=this._textureAtlas=new dF({context:i});for(let Q=0;Q0){this._vaf=$le(i,n,this._buffersUsage,this._instanced,this._batchTable,this._sdf),h=this._vaf.writers;for(let Q=0;Q0){let Q=dre;Q.length=0,(r[fX]||r[Ole]||r[Dle])&&Q.push(_Wt),(r[WX]||r[BWt]||r[Mle]||r[_le]||r[Lle])&&(Q.push(vWt),this._instanced&&Q.push(q$)),(r[WX]||r[Hle]||r[xWt])&&(Q.push(KWt),Q.push(j$)),(r[WX]||r[kWt])&&Q.push(j$),r[QWt]&&Q.push(q$),r[YWt]&&Q.push(zWt),r[XWt]&&Q.push(jWt),(r[JWt]||r[wle]||r[WX]||r[fX])&&Q.push(qWt),(r[WX]||r[fX])&&Q.push($Wt),r[LWt]&&Q.push(tft);let J=Q.length;if(h=this._vaf.writers,l/n>.1){for(let M=0;Mn*1.5&&(s.length=n),!c(this._vaf)||!c(this._vaf.va))return;this._boundingVolumeDirty&&(this._boundingVolumeDirty=!1,Ft.transform(this._baseVolume,this.modelMatrix,this._baseVolumeWC));let V,F=L.IDENTITY;t.mode===Vt.SCENE3D?(F=this.modelMatrix,V=Ft.clone(this._baseVolumeWC,this._boundingVolume)):V=Ft.clone(this._baseVolume2D,this._boundingVolume),lre(this,t,V);let U=this._blendOption!==this.blendOption;if(this._blendOption=this.blendOption,U){this._blendOption===wa.OPAQUE||this._blendOption===wa.OPAQUE_AND_TRANSLUCENT?this._rsOpaque=he.fromCache({depthTest:{enabled:!0,func:pt.LESS},depthMask:!0}):this._rsOpaque=void 0;let Q=this._blendOption===wa.TRANSLUCENT;this._blendOption===wa.TRANSLUCENT||this._blendOption===wa.OPAQUE_AND_TRANSLUCENT?this._rsTranslucent=he.fromCache({depthTest:{enabled:!0,func:Q?pt.LEQUAL:pt.LESS},depthMask:Q,blending:Pn.ALPHA_BLEND}):this._rsTranslucent=void 0}this._shaderDisableDepthDistance=this._shaderDisableDepthDistance||t.minimumDisableDepthTestDistance!==0;let G,A,S,g,C,y=Tn.maximumVertexTextureImageUnits>0;if(U||this._shaderRotation!==this._compiledShaderRotation||this._shaderAlignedAxis!==this._compiledShaderAlignedAxis||this._shaderScaleByDistance!==this._compiledShaderScaleByDistance||this._shaderTranslucencyByDistance!==this._compiledShaderTranslucencyByDistance||this._shaderPixelOffsetScaleByDistance!==this._compiledShaderPixelOffsetScaleByDistance||this._shaderDistanceDisplayCondition!==this._compiledShaderDistanceDisplayCondition||this._shaderDisableDepthDistance!==this._compiledShaderDisableDepthDistance||this._shaderClampToGround!==this._compiledShaderClampToGround||this._sdf!==this._compiledSDF){G=bX,A=RX,C=[],c(this._batchTable)&&(C.push("VECTOR_TILE"),G=this._batchTable.getVertexShaderCallback(!1,"a_batchId",void 0)(G),A=this._batchTable.getFragmentShaderCallback(!1,void 0)(A)),S=new Ze({defines:C,sources:[G]}),this._instanced&&S.defines.push("INSTANCED"),this._shaderRotation&&S.defines.push("ROTATION"),this._shaderAlignedAxis&&S.defines.push("ALIGNED_AXIS"),this._shaderScaleByDistance&&S.defines.push("EYE_DISTANCE_SCALING"),this._shaderTranslucencyByDistance&&S.defines.push("EYE_DISTANCE_TRANSLUCENCY"),this._shaderPixelOffsetScaleByDistance&&S.defines.push("EYE_DISTANCE_PIXEL_OFFSET"),this._shaderDistanceDisplayCondition&&S.defines.push("DISTANCE_DISPLAY_CONDITION"),this._shaderDisableDepthDistance&&S.defines.push("DISABLE_DEPTH_DISTANCE"),this._shaderClampToGround&&(y?S.defines.push("VERTEX_DEPTH_CHECK"):S.defines.push("FRAGMENT_DEPTH_CHECK"));let Q=1-Ar.CUTOFF;this._sdf&&S.defines.push("SDF");let J=c(this._batchTable)?"VECTOR_TILE":"";this._blendOption===wa.OPAQUE_AND_TRANSLUCENT&&(g=new Ze({defines:["OPAQUE",J],sources:[A]}),this._shaderClampToGround&&(y?g.defines.push("VERTEX_DEPTH_CHECK"):g.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(g.defines.push("SDF"),g.defines.push(`SDF_EDGE ${Q}`)),this._sp=xn.replaceCache({context:i,shaderProgram:this._sp,vertexShaderSource:S,fragmentShaderSource:g,attributeLocations:Ma}),g=new Ze({defines:["TRANSLUCENT",J],sources:[A]}),this._shaderClampToGround&&(y?g.defines.push("VERTEX_DEPTH_CHECK"):g.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(g.defines.push("SDF"),g.defines.push(`SDF_EDGE ${Q}`)),this._spTranslucent=xn.replaceCache({context:i,shaderProgram:this._spTranslucent,vertexShaderSource:S,fragmentShaderSource:g,attributeLocations:Ma})),this._blendOption===wa.OPAQUE&&(g=new Ze({defines:[J],sources:[A]}),this._shaderClampToGround&&(y?g.defines.push("VERTEX_DEPTH_CHECK"):g.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(g.defines.push("SDF"),g.defines.push(`SDF_EDGE ${Q}`)),this._sp=xn.replaceCache({context:i,shaderProgram:this._sp,vertexShaderSource:S,fragmentShaderSource:g,attributeLocations:Ma})),this._blendOption===wa.TRANSLUCENT&&(g=new Ze({defines:[J],sources:[A]}),this._shaderClampToGround&&(y?g.defines.push("VERTEX_DEPTH_CHECK"):g.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(g.defines.push("SDF"),g.defines.push(`SDF_EDGE ${Q}`)),this._spTranslucent=xn.replaceCache({context:i,shaderProgram:this._spTranslucent,vertexShaderSource:S,fragmentShaderSource:g,attributeLocations:Ma})),this._compiledShaderRotation=this._shaderRotation,this._compiledShaderAlignedAxis=this._shaderAlignedAxis,this._compiledShaderScaleByDistance=this._shaderScaleByDistance,this._compiledShaderTranslucencyByDistance=this._shaderTranslucencyByDistance,this._compiledShaderPixelOffsetScaleByDistance=this._shaderPixelOffsetScaleByDistance,this._compiledShaderDistanceDisplayCondition=this._shaderDistanceDisplayCondition,this._compiledShaderDisableDepthDistance=this._shaderDisableDepthDistance,this._compiledShaderClampToGround=this._shaderClampToGround,this._compiledSDF=this._sdf}let Y=t.commandList;if(u.render||u.pick){let Q=this._colorCommands,J=this._blendOption===wa.OPAQUE,M=this._blendOption===wa.OPAQUE_AND_TRANSLUCENT,Z=this._vaf.va,E=Z.length,I=this._uniforms,B;c(this._batchTable)?(I=this._batchTable.getUniformMapCallback()(I),B=this._batchTable.getPickId()):B="v_pickColor",Q.length=E;let X=M?E*2:E;for(let _=0;_0}},labelOutlineColor:{get:function(){return this._label.outlineColor},set:function(t){this._label.outlineColor=t}},labelOutlineWidth:{get:function(){return this._label.outlineWidth},set:function(t){this._label.outlineWidth=t}},font:{get:function(){return this._label.font},set:function(t){this._label.font=t}},labelStyle:{get:function(){return this._label.style},set:function(t){this._label.style=t}},labelText:{get:function(){return this._label.text},set:function(t){c(t)||(t=""),this._label.text=t}},backgroundColor:{get:function(){return this._label.backgroundColor},set:function(t){this._label.backgroundColor=t}},backgroundPadding:{get:function(){return this._label.backgroundPadding},set:function(t){this._label.backgroundPadding=t}},backgroundEnabled:{get:function(){return this._label.showBackground},set:function(t){this._label.showBackground=t}},scaleByDistance:{get:function(){return this._label.scaleByDistance},set:function(t){this._label.scaleByDistance=t,this._billboard.scaleByDistance=t}},translucencyByDistance:{get:function(){return this._label.translucencyByDistance},set:function(t){this._label.translucencyByDistance=t,this._billboard.translucencyByDistance=t}},distanceDisplayCondition:{get:function(){return this._label.distanceDisplayCondition},set:function(t){this._label.distanceDisplayCondition=t,this._polyline.distanceDisplayCondition=t,this._billboard.distanceDisplayCondition=t}},heightOffset:{get:function(){return this._heightOffset},set:function(t){let e=f(this._heightOffset,0),n=this._content.tileset.ellipsoid,i=n.cartesianToCartographic(this._billboard.position,mre);i.height=i.height-e+t;let o=n.cartographicToCartesian(i);this._billboard.position=o,this._label.position=this._billboard.position,this._polyline.positions=[this._polyline.positions[0],o],this._heightOffset=t}},anchorLineEnabled:{get:function(){return this._polyline.show},set:function(t){this._polyline.show=t}},anchorLineColor:{get:function(){return this._polyline.material.uniforms.color},set:function(t){this._polyline.material.uniforms.color=v.clone(t,this._polyline.material.uniforms.color)}},image:{get:function(){return this._billboardImage},set:function(t){let e=this._billboardImage!==t;this._billboardImage=t,e&&ZC(this)}},disableDepthTestDistance:{get:function(){return this._label.disableDepthTestDistance},set:function(t){this._label.disableDepthTestDistance=t,this._billboard.disableDepthTestDistance=t}},horizontalOrigin:{get:function(){return this._billboard.horizontalOrigin},set:function(t){this._billboard.horizontalOrigin=t}},verticalOrigin:{get:function(){return this._billboard.verticalOrigin},set:function(t){this._billboard.verticalOrigin=t}},labelHorizontalOrigin:{get:function(){return this._label.horizontalOrigin},set:function(t){this._label.horizontalOrigin=t}},labelVerticalOrigin:{get:function(){return this._label.verticalOrigin},set:function(t){this._label.verticalOrigin=t}},content:{get:function(){return this._content}},tileset:{get:function(){return this._content.tileset}},primitive:{get:function(){return this._content.tileset}},pickIds:{get:function(){let t=this._pickIds;return t[0]=this._billboard.pickId,t[1]=this._label.pickId,t[2]=this._polyline.pickId,t}}});wr.defaultColor=v.WHITE;wr.defaultPointOutlineColor=v.BLACK;wr.defaultPointOutlineWidth=0;wr.defaultPointSize=8;function ZC(t){let e=t._billboard;if(c(t._billboardImage)&&t._billboardImage!==e.image){e.image=t._billboardImage;return}if(c(t._billboardImage))return;let n=f(t._color,wr.defaultColor),i=f(t._pointOutlineColor,wr.defaultPointOutlineColor),o=f(t._pointOutlineWidth,wr.defaultPointOutlineWidth),a=f(t._pointSize,wr.defaultPointSize),s=t._billboardColor,l=t._billboardOutlineColor,r=t._billboardOutlineWidth,d=t._billboardSize;if(v.equals(n,s)&&v.equals(i,l)&&o===r&&a===d)return;t._billboardColor=v.clone(n,t._billboardColor),t._billboardOutlineColor=v.clone(i,t._billboardOutlineColor),t._billboardOutlineWidth=o,t._billboardSize=a;let m=n.alpha,h=n.toCssColorString(),u=i.toCssColorString(),R=JSON.stringify([h,a,u,o]);e.setImage(R,XA(m,h,u,o,a))}wr.prototype.hasProperty=function(t){return this._content.batchTable.hasProperty(this._batchId,t)};wr.prototype.getPropertyIds=function(t){return this._content.batchTable.getPropertyIds(this._batchId,t)};wr.prototype.getProperty=function(t){return this._content.batchTable.getProperty(this._batchId,t)};wr.prototype.getPropertyInherited=function(t){return Fr.getPropertyInherited(this._content,this._batchId,t)};wr.prototype.setProperty=function(t,e){this._content.batchTable.setProperty(this._batchId,t,e),this._content.featurePropertiesDirty=!0};wr.prototype.isExactClass=function(t){return this._content.batchTable.isExactClass(this._batchId,t)};wr.prototype.isClass=function(t){return this._content.batchTable.isClass(this._batchId,t)};wr.prototype.getExactClassName=function(){return this._content.batchTable.getExactClassName(this._batchId)};var R0=wr;var D7n=b(W(),1);var n7n=b(W(),1);function hre(t,e,n,i,o){let a=t.measureText(e);if(!!/\S/.test(e)){let l=document.defaultView.getComputedStyle(t.canvas).getPropertyValue("font-size").replace("px",""),r=document.createElement("canvas"),d=100,m=a.width+d|0,h=3*l,u=h/2;r.width=m,r.height=h;let R=r.getContext("2d");R.font=n,R.fillStyle="white",R.fillRect(0,0,r.width+1,r.height+1),i&&(R.strokeStyle="black",R.lineWidth=t.lineWidth,R.strokeText(e,d/2,u)),o&&(R.fillStyle="black",R.fillText(e,d/2,u));let V=R.getImageData(0,0,m,h).data,F=V.length,U=m*4,G,A,S,g;for(G=0;G=0;--G)if(V[G]!==255){g=G/U|0;break}let C=-1;for(G=0;G]/,o=[],a="",s=_l.LTR,l="",r=t.length;for(let d=0;d";case">":return"<"}}var Ure="\u05D0-\u05EA",Gre="\u0600-\u06FF\u0750-\u077F\u08A0-\u08FF",lft=new RegExp(`[${Ure}${Gre}]`);function Are(t){let e=t.split(` `),n="";for(let i=0;id+1?s[d+1].Type===_l.RTL?(r=h+r,l=0):(r=AX(r,l,m.Word),l+=m.Word.length):r=AX(r,0,h)):m.Type===_l.RTL?r=AX(r,l,h):m.Type===_l.LTR?(r+=m.Word,l=r.length):(m.Type===_l.WEAK||m.Type===_l.BRACKETS)&&(d>0&&s[d-1].Type===_l.RTL?s.length>d+1?s[d+1].Type===_l.RTL?r=AX(r,l,h):(r+=m.Word,l=r.length):r+=m.Word:(r+=m.Word,l=r.length))}n+=r,i0,h=e._backgroundBillboard,Z=t._backgroundBillboardCollection;m?(c(h)||(h=Z.add({collection:t,image:pft,imageSubRegion:Cre}),e._backgroundBillboard=h),h.color=e._backgroundColor,h.show=e._show,h.position=e._position,h.eyeOffset=e._eyeOffset,h.pixelOffset=e._pixelOffset,h.horizontalOrigin=to.LEFT,h.verticalOrigin=e._verticalOrigin,h.heightReference=e._heightReference,h.scale=e.totalScale,h.pickPrimitive=e,h.id=e._id,h.translucencyByDistance=e._translucencyByDistance,h.pixelOffsetScaleByDistance=e._pixelOffsetScaleByDistance,h.scaleByDistance=e._scaleByDistance,h.distanceDisplayCondition=e._distanceDisplayCondition,h.disableDepthTestDistance=e._disableDepthTestDistance,h.clusterShow=e.clusterShow):c(h)&&(Z.remove(h),e._backgroundBillboard=h=void 0);let b=t._glyphTextureCache;for(d=0;d0&&T.height>0){let g=(0,mft.default)(T,{cutoff:Ar.CUTOFF,radius:Ar.RADIUS}),C=T.getContext("2d"),y=T.width,Y=T.height,Q=C.getImageData(0,0,y,Y);for(let J=0;J0?A=T.pop():(A=t._billboardCollection.add({collection:t}),A._labelDimensions=new K,A._labelTranslate=new K),l.billboard=A),A.show=e._show,A.position=e._position,A.eyeOffset=e._eyeOffset,A.pixelOffset=e._pixelOffset,A.horizontalOrigin=to.LEFT,A.verticalOrigin=e._verticalOrigin,A.heightReference=e._heightReference,A.scale=e.totalScale,A.pickPrimitive=e,A.id=e._id,A.image=U,A.translucencyByDistance=e._translucencyByDistance,A.pixelOffsetScaleByDistance=e._pixelOffsetScaleByDistance,A.scaleByDistance=e._scaleByDistance,A.distanceDisplayCondition=e._distanceDisplayCondition,A.disableDepthTestDistance=e._disableDepthTestDistance,A._batchIndex=e._batchIndex,A.outlineColor=e.outlineColor,e.style===Pa.FILL_AND_OUTLINE?(A.color=e._fillColor,A.outlineWidth=e.outlineWidth):e.style===Pa.FILL?(A.color=e._fillColor,A.outlineWidth=0):e.style===Pa.OUTLINE&&(A.color=v.TRANSPARENT,A.outlineWidth=e.outlineWidth)}}e._repositionAllGlyphs=!0}function cft(t,e,n){return e===to.CENTER?-t/2:e===to.RIGHT?-(t+n.x):n.x}var Ns=new K,kre=new K;function Yre(t){let e=t._glyphs,n=t._renderedText,i,o,a=0,s=0,l=[],r=Number.NEGATIVE_INFINITY,d=0,m=1,h,Z=e.length,b=t._backgroundBillboard,u=K.clone(c(b)?t._backgroundPadding:K.ZERO,kre);for(u.x/=t._relativeSize,u.y/=t._relativeSize,h=0;h0&&(G===to.CENTER?C=-s/2-u.x:G===to.RIGHT?C=-(s+u.x*2):C=0,Ns.x=C*U,A===hi.TOP?Ns.y=F-d-r:A===hi.CENTER?Ns.y=(F-d)/2-r:A===hi.BASELINE?Ns.y=-u.y-r:Ns.y=0,Ns.y=Ns.y*U,b.width=Q,b.height=J,b._setTranslate(Ns),b._labelTranslate=K.clone(Ns,b._labelTranslate)),Np(t.heightReference))for(h=0;h0?wa.TRANSLUCENT:this.blendOption;e.blendOption=a,n.blendOption=a,e._highlightColor=this._highlightColor,n._highlightColor=this._highlightColor,this._labelsToUpdate.length=0,n.update(t),e.update(t)};ab.prototype.isDestroyed=function(){return!1};ab.prototype.destroy=function(){return this.removeAll(),this._billboardCollection=this._billboardCollection.destroy(),this._textureAtlas=this._textureAtlas&&this._textureAtlas.destroy(),this._backgroundBillboardCollection=this._backgroundBillboardCollection.destroy(),this._backgroundTextureAtlas=this._backgroundTextureAtlas&&this._backgroundTextureAtlas.destroy(),At(this)};var sb=ab;var e$n=R(W(),1);var H7n=R(W(),1),TX=`in vec3 position3DHigh; +`)}return n}var cF=b0;var hft=b(dft(),1);function Tre(){this.textureInfo=void 0,this.dimensions=void 0,this.billboard=void 0}function gre(t,e,n){this.labelCollection=t,this.index=e,this.dimensions=n}var Ere=1.2,pft="ID_WHITE_PIXEL",ett=new K(4,4),Cre=new Fe(1,1,1,1);function Ire(t){let e=document.createElement("canvas");e.width=ett.x,e.height=ett.y;let n=e.getContext("2d");return n.fillStyle="#fff",n.fillRect(0,0,e.width,e.height),t.addImage(pft,e)}var Pp={};function Nre(t,e,n,i,o,a,s){return Pp.font=e,Pp.fillColor=n,Pp.strokeColor=i,Pp.strokeWidth=o,Pp.padding=Ar.PADDING,s===hi.CENTER?Pp.textBaseline="middle":s===hi.TOP?Pp.textBaseline="top":Pp.textBaseline="bottom",Pp.fill=a===Pa.FILL||a===Pa.FILL_AND_OUTLINE,Pp.stroke=a===Pa.OUTLINE||a===Pa.FILL_AND_OUTLINE,Pp.backgroundColor=v.BLACK,LA(t,Pp)}function ntt(t,e){e.textureInfo=void 0,e.dimensions=void 0;let n=e.billboard;c(n)&&(n.show=!1,n.image=void 0,c(n._removeCallbackFunc)&&(n._removeCallbackFunc(),n._removeCallbackFunc=void 0),t._spareBillboards.push(n),e.billboard=void 0)}function yre(t,e,n,i){i.index=t.addImageSync(e,n)}var Bre=new hft.default;function Qre(t,e){let n=e._renderedText,i=Bre.splitGraphemes(n),o=i.length,a=e._glyphs,s=a.length,l,r,d;if(e._relativeSize=e._fontSize/Ar.FONT_SIZE,o0,h=e._backgroundBillboard,u=t._backgroundBillboardCollection;m?(c(h)||(h=u.add({collection:t,image:pft,imageSubRegion:Cre}),e._backgroundBillboard=h),h.color=e._backgroundColor,h.show=e._show,h.position=e._position,h.eyeOffset=e._eyeOffset,h.pixelOffset=e._pixelOffset,h.horizontalOrigin=to.LEFT,h.verticalOrigin=e._verticalOrigin,h.heightReference=e._heightReference,h.scale=e.totalScale,h.pickPrimitive=e,h.id=e._id,h.translucencyByDistance=e._translucencyByDistance,h.pixelOffsetScaleByDistance=e._pixelOffsetScaleByDistance,h.scaleByDistance=e._scaleByDistance,h.distanceDisplayCondition=e._distanceDisplayCondition,h.disableDepthTestDistance=e._disableDepthTestDistance,h.clusterShow=e.clusterShow):c(h)&&(u.remove(h),e._backgroundBillboard=h=void 0);let R=t._glyphTextureCache;for(d=0;d0&&S.height>0){let g=(0,mft.default)(S,{cutoff:Ar.CUTOFF,radius:Ar.RADIUS}),C=S.getContext("2d"),y=S.width,Y=S.height,Q=C.getImageData(0,0,y,Y);for(let J=0;J0?A=S.pop():(A=t._billboardCollection.add({collection:t}),A._labelDimensions=new K,A._labelTranslate=new K),l.billboard=A),A.show=e._show,A.position=e._position,A.eyeOffset=e._eyeOffset,A.pixelOffset=e._pixelOffset,A.horizontalOrigin=to.LEFT,A.verticalOrigin=e._verticalOrigin,A.heightReference=e._heightReference,A.scale=e.totalScale,A.pickPrimitive=e,A.id=e._id,A.image=U,A.translucencyByDistance=e._translucencyByDistance,A.pixelOffsetScaleByDistance=e._pixelOffsetScaleByDistance,A.scaleByDistance=e._scaleByDistance,A.distanceDisplayCondition=e._distanceDisplayCondition,A.disableDepthTestDistance=e._disableDepthTestDistance,A._batchIndex=e._batchIndex,A.outlineColor=e.outlineColor,e.style===Pa.FILL_AND_OUTLINE?(A.color=e._fillColor,A.outlineWidth=e.outlineWidth):e.style===Pa.FILL?(A.color=e._fillColor,A.outlineWidth=0):e.style===Pa.OUTLINE&&(A.color=v.TRANSPARENT,A.outlineWidth=e.outlineWidth)}}e._repositionAllGlyphs=!0}function cft(t,e,n){return e===to.CENTER?-t/2:e===to.RIGHT?-(t+n.x):n.x}var Ns=new K,kre=new K;function Yre(t){let e=t._glyphs,n=t._renderedText,i,o,a=0,s=0,l=[],r=Number.NEGATIVE_INFINITY,d=0,m=1,h,u=e.length,R=t._backgroundBillboard,V=K.clone(c(R)?t._backgroundPadding:K.ZERO,kre);for(V.x/=t._relativeSize,V.y/=t._relativeSize,h=0;h0&&(G===to.CENTER?C=-s/2-V.x:G===to.RIGHT?C=-(s+V.x*2):C=0,Ns.x=C*U,A===hi.TOP?Ns.y=F-d-r:A===hi.CENTER?Ns.y=(F-d)/2-r:A===hi.BASELINE?Ns.y=-V.y-r:Ns.y=0,Ns.y=Ns.y*U,R.width=Q,R.height=J,R._setTranslate(Ns),R._labelTranslate=K.clone(Ns,R._labelTranslate)),Np(t.heightReference))for(h=0;h0?wa.TRANSLUCENT:this.blendOption;e.blendOption=a,n.blendOption=a,e._highlightColor=this._highlightColor,n._highlightColor=this._highlightColor,this._labelsToUpdate.length=0,n.update(t),e.update(t)};aR.prototype.isDestroyed=function(){return!1};aR.prototype.destroy=function(){return this.removeAll(),this._billboardCollection=this._billboardCollection.destroy(),this._textureAtlas=this._textureAtlas&&this._textureAtlas.destroy(),this._backgroundBillboardCollection=this._backgroundBillboardCollection.destroy(),this._backgroundTextureAtlas=this._backgroundTextureAtlas&&this._backgroundTextureAtlas.destroy(),At(this)};var sR=aR;var e$n=b(W(),1);var H7n=b(W(),1),SX=`in vec3 position3DHigh; in vec3 position3DLow; in vec3 position2DHigh; in vec3 position2DLow; @@ -8617,8 +8617,8 @@ void main() v_pickColor = pickColor; v_polylineAngle = polylineAngle; } -`;var Vqn=R(W(),1);var oqn=R(W(),1);var Lc={};Lc.numberOfPoints=function(t,e,n){let i=p.distance(t,e);return Math.ceil(i/n)};Lc.numberOfPointsRhumbLine=function(t,e,n){let i=Math.pow(t.longitude-e.longitude,2)+Math.pow(t.latitude-e.latitude,2);return Math.max(1,Math.ceil(Math.sqrt(i/(n*n))))};var xre=new gt;Lc.extractHeights=function(t,e){let n=t.length,i=new Array(n);for(let o=0;o0){e=f(e,L.IDENTITY);let o=L.inverseTransformation(e,Xre),a=L.multiplyByPoint(o,p.ZERO,Jre),s=p.normalize(L.multiplyByPointAsVector(o,p.UNIT_Y,Zft),Zft),l=Kn.fromPointNormal(a,s,Lre),r=p.normalize(L.multiplyByPointAsVector(o,p.UNIT_X,Vft),Vft),d=Kn.fromPointNormal(a,r,Mre),m=1;n.push(p.clone(t[0]));let h=n[0],Z=t.length;for(let b=1;b2&&(this._actualPositions===this._positions&&(this._actualPositions=n.slice()),this._actualPositions.push(p.clone(this._actualPositions[0]))),this._length=this._actualPositions.length,this._id=t.id;let i;c(e)&&(i=L.clone(e.modelMatrix)),this._modelMatrix=i,this._segments=xo.wrapLongitude(this._actualPositions,i),this._actualLength=void 0,this._propertiesChanged=new Uint32Array(fft),this._polylineCollection=e,this._dirty=!1,this._pickId=void 0,this._boundingVolume=Ft.fromPoints(this._actualPositions),this._boundingVolumeWC=Ft.transform(this._boundingVolume,this._modelMatrix),this._boundingVolume2D=new Ft}var Wft=Bh.POSITION_INDEX=0,vre=Bh.SHOW_INDEX=1,Kre=Bh.WIDTH_INDEX=2,zre=Bh.MATERIAL_INDEX=3,gX=Bh.POSITION_SIZE_INDEX=4,jre=Bh.DISTANCE_DISPLAY_CONDITION=5,fft=Bh.NUMBER_OF_PROPERTIES=6;function W0(t,e){++t._propertiesChanged[e];let n=t._polylineCollection;c(n)&&(n._updatePolyline(t,e),t._dirty=!0)}Object.defineProperties(Bh.prototype,{show:{get:function(){return this._show},set:function(t){t!==this._show&&(this._show=t,W0(this,vre))}},positions:{get:function(){return this._positions},set:function(t){let e=sa(t,p.equalsEpsilon);this._loop&&e.length>2&&(e===t&&(e=t.slice()),e.push(p.clone(e[0]))),(this._actualPositions.length!==e.length||this._actualPositions.length!==this._length)&&W0(this,gX),this._positions=t,this._actualPositions=e,this._length=e.length,this._boundingVolume=Ft.fromPoints(this._actualPositions,this._boundingVolume),this._boundingVolumeWC=Ft.transform(this._boundingVolume,this._modelMatrix,this._boundingVolumeWC),W0(this,Wft),this.update()}},material:{get:function(){return this._material},set:function(t){this._material!==t&&(this._material=t,W0(this,zre))}},width:{get:function(){return this._width},set:function(t){let e=this._width;t!==e&&(this._width=t,W0(this,Kre))}},loop:{get:function(){return this._loop},set:function(t){if(t!==this._loop){let e=this._actualPositions;t?e.length>2&&!p.equals(e[0],e[e.length-1])&&(e.length===this._positions.length&&(this._actualPositions=e=this._positions.slice()),e.push(p.clone(e[0]))):e.length>2&&p.equals(e[0],e[e.length-1])&&(e.length-1===this._positions.length?this._actualPositions=this._positions:e.pop()),this._loop=t,W0(this,gX)}}},id:{get:function(){return this._id},set:function(t){this._id=t,c(this._pickId)&&(this._pickId.object.id=t)}},pickId:{get:function(){return this._pickId}},isDestroyed:{get:function(){return!c(this._polylineCollection)}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){Wn.equals(t,this._distanceDisplayCondition)||(this._distanceDisplayCondition=Wn.clone(t,this._distanceDisplayCondition),W0(this,jre))}}});Bh.prototype.update=function(){let t=L.IDENTITY;c(this._polylineCollection)&&(t=this._polylineCollection.modelMatrix);let e=this._segments.positions.length,n=this._segments.lengths,i=this._propertiesChanged[Wft]>0||this._propertiesChanged[gX]>0;if((!L.equals(t,this._modelMatrix)||i)&&(this._segments=xo.wrapLongitude(this._actualPositions,t),this._boundingVolumeWC=Ft.transform(this._boundingVolume,t,this._boundingVolumeWC)),this._modelMatrix=L.clone(t,this._modelMatrix),this._segments.positions.length!==e)W0(this,gX);else{let o=n.length;for(let a=0;a2){if(o[ltt]||o[Fft]){let u=t.mode===ut.SCENE2D?i._boundingVolume2D:i._boundingVolumeWC,F=Mi.fromCartesian(u.center,Cft),U=Rt.fromElements(F.low.x,F.low.y,F.low.z,u.radius,Ift);this._batchTable.setBatchedAttribute(i._index,2,F.high),this._batchTable.setBatchedAttribute(i._index,3,U)}if(o[ede]){let u=Nft;u.x=0,u.y=Number.MAX_VALUE;let F=i.distanceDisplayCondition;c(F)&&(u.x=F.near,u.y=F.far),this._batchTable.setBatchedAttribute(i._index,4,u)}}i._clean()}}r.length=0,this._polylinesUpdated=!1}o=this._propertiesChanged;for(let r=0;r0){let z=J.isTranslucent();l>=s?(V=new Ee({owner:t}),n.push(V)):V=n[l],++l,E=ze(Z(J._uniforms),t._uniformMap),V.boundingVolume=Ft.clone(EX,V.boundingVolume),V.modelMatrix=i,V.shaderProgram=C,V.vertexArray=F.va,V.renderState=z?t._translucentRS:t._opaqueRS,V.pass=z?Pt.TRANSLUCENT:Pt.OPAQUE,V.debugShowBoundingVolume=m,V.pickId="v_pickColor",V.uniformMap=E,V.count=M,V.offset=g,g+=M,M=0,r=!0,a.push(V)}J=B._material,J.update(o),Q=X}let _=B._locatorBuckets,P=_.length;for(let z=0;z0&&(l>=s?(V=new Ee({owner:t}),n.push(V)):V=n[l],++l,E=ze(Z(J._uniforms),t._uniformMap),V.boundingVolume=Ft.clone(EX,V.boundingVolume),V.modelMatrix=i,V.shaderProgram=C,V.vertexArray=F.va,V.renderState=J.isTranslucent()?t._translucentRS:t._opaqueRS,V.pass=J.isTranslucent()?Pt.TRANSLUCENT:Pt.OPAQUE,V.debugShowBoundingVolume=m,V.pickId="v_pickColor",V.uniformMap=E,V.count=M,V.offset=g,r=!0,a.push(V)),Q=void 0}}n.length=l}TZ.prototype.isDestroyed=function(){return!1};TZ.prototype.destroy=function(){return yft(this),dtt(this),Bft(this),this._batchTable=this._batchTable&&this._batchTable.destroy(),At(this)};function ode(t){let e=!1,n=t._propertiesChanged,i=t._positionBufferUsage;return n[ltt]?(i.bufferUsage!==ce.STREAM_DRAW&&(e=!0,i.bufferUsage=ce.STREAM_DRAW),i.frameCount=100):i.bufferUsage!==ce.STATIC_DRAW&&(i.frameCount===0?(e=!0,i.bufferUsage=ce.STATIC_DRAW):i.frameCount--),e}var Gft=[0,0,0];function Aft(t,e,n){t._createVertexArray=!1,dtt(t),yft(t),lde(t);let i=[[]],o=i[0],a=t._batchTable,s=t._useHighlightColor,l=[0],r=0,d=[[]],m=0,h=t._polylineBuckets,Z,b;for(Z in h)h.hasOwnProperty(Z)&&(b=h[Z],b.updateShader(e,a,s),m+=b.lengthOfPositions);if(m>0){let u=t._mode,F=new Float32Array(6*m*3),U=new Float32Array(m*4),G,A=0,T=0,g=0;for(Z in h)if(h.hasOwnProperty(Z)){b=h[Z],b.write(F,U,A,T,g,a,e,n),u===ut.MORPHING&&(c(G)||(G=new Float32Array(6*m*3)),b.writeForMorph(G,A));let E=b.lengthOfPositions;A+=6*E*3,T+=E*4,g+=E*4,r=b.updateIndices(i,l,d,r)}let C=t._positionBufferUsage.bufferUsage,y=ce.STATIC_DRAW;t._positionBuffer=we.createVertexBuffer({context:e,typedArray:F,usage:C});let Y;c(G)&&(Y=we.createVertexBuffer({context:e,typedArray:G,usage:C})),t._texCoordExpandAndBatchIndexBuffer=we.createVertexBuffer({context:e,typedArray:U,usage:y});let Q=3*Float32Array.BYTES_PER_ELEMENT,J=4*Float32Array.BYTES_PER_ELEMENT,M=0,V=i.length;for(let E=0;E0){let I=new Uint16Array(o),B=we.createIndexBuffer({context:e,typedArray:I,usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT});M+=l[E];let X=6*(E*(Q*k.SIXTY_FOUR_KILOBYTES)-M*Q),_=Q+X,P=Q+_,w=Q+P,z=Q+w,H=Q+z,nt=E*(J*k.SIXTY_FOUR_KILOBYTES)-M*J,$=[{index:Jm.position3DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:X,strideInBytes:6*Q},{index:Jm.position3DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:_,strideInBytes:6*Q},{index:Jm.position2DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:X,strideInBytes:6*Q},{index:Jm.position2DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:_,strideInBytes:6*Q},{index:Jm.prevPosition3DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:P,strideInBytes:6*Q},{index:Jm.prevPosition3DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:w,strideInBytes:6*Q},{index:Jm.prevPosition2DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:P,strideInBytes:6*Q},{index:Jm.prevPosition2DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:w,strideInBytes:6*Q},{index:Jm.nextPosition3DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:z,strideInBytes:6*Q},{index:Jm.nextPosition3DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:H,strideInBytes:6*Q},{index:Jm.nextPosition2DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:z,strideInBytes:6*Q},{index:Jm.nextPosition2DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:H,strideInBytes:6*Q},{index:Jm.texCoordExpandAndBatchIndex,componentsPerAttribute:4,componentDatatype:it.FLOAT,vertexBuffer:t._texCoordExpandAndBatchIndexBuffer,offsetInBytes:nt}],dt,q,at,st;u===ut.SCENE3D?(q=t._positionBuffer,dt="vertexBuffer",at=Gft,st="value"):u===ut.SCENE2D||u===ut.COLUMBUS_VIEW?(q=Gft,dt="value",at=t._positionBuffer,st="vertexBuffer"):(q=Y,dt="vertexBuffer",at=t._positionBuffer,st="vertexBuffer"),$[0][dt]=q,$[1][dt]=q,$[2][st]=at,$[3][st]=at,$[4][dt]=q,$[5][dt]=q,$[6][st]=at,$[7][st]=at,$[8][dt]=q,$[9][dt]=q,$[10][st]=at,$[11][st]=at;let Et=new Ki({context:e,attributes:$,indexBuffer:B});t._vertexArrays.push({va:Et,buckets:d[E]})}}}function ade(t,e){return e instanceof hn?e.id:e}var pP=[];function sde(t){let e=eo._uniformList[t.type],n=e.length;pP.length=2*n;let i=0;for(let o=0;o1){l.update();let r=l.material,d=i[r.type];c(d)||(d=i[r.type]=new lb(r,e,n)),d.addPolyline(l)}}}function rde(t,e){let n=e.mode;(t._mode!==n||!L.equals(t._modelMatrix,t.modelMatrix))&&(t._mode=n,t._modelMatrix=L.clone(t.modelMatrix),t._createVertexArray=!0)}function rtt(t){if(t._polylinesRemoved){t._polylinesRemoved=!1;let e=[],n=[],i=0,o,a=t._polylines.length;for(let s=0;s0,U=b._index,G=this.getSegments(b,l),A=G.positions,T=G.lengths,g=A.length,C=b.getPickId(s).color,y=0,Y=0,Q;for(let P=0;P0||er.x>0&&Kp.x<0)&&p.clone(er,Kp),(er.x<0&&zp.x>0||er.x>0&&zp.x<0)&&p.clone(er,zp));let nt=z?2:0,$=H?2:4;for(let dt=nt;dt<$;++dt){Mi.writeElements(er,t,n),Mi.writeElements(Kp,t,n+6),Mi.writeElements(zp,t,n+12);let q=dt-2<0?-1:1;e[o]=P/(g-1),e[o+1]=2*(dt%2)-1,e[o+2]=q,e[o+3]=U,n+=6*3,o+=4}}let J=dde;J.x=v.floatToByte(C.red),J.y=v.floatToByte(C.green),J.z=v.floatToByte(C.blue),J.w=v.floatToByte(C.alpha);let M=cde;M.x=u,M.y=F?1:0;let V=r===ut.SCENE2D?b._boundingVolume2D:b._boundingVolumeWC,E=Mi.fromCartesian(V.center,Cft),I=E.high,B=Rt.fromElements(E.low.x,E.low.y,E.low.z,V.radius,Ift),X=Nft;X.x=0,X.y=Number.MAX_VALUE;let _=b.distanceDisplayCondition;c(_)&&(X.x=_.near,X.y=_.far),a.setBatchedAttribute(U,0,M),a.setBatchedAttribute(U,1,J),a.attributes.length>2&&(a.setBatchedAttribute(U,2,I),a.setBatchedAttribute(U,3,B),a.setBatchedAttribute(U,4,X))}};var mde=new p,hde=new p,pde=new p,Tft=new p;lb.prototype.writeForMorph=function(t,e){let n=this.modelMatrix,i=this.polylines,o=i.length;for(let a=0;a0&&(r=l[l.length-1]+1);let d=this.polylines,m=d.length;for(let h=0;h0)b[0]=F;else continue}else b=Z._segments.lengths;let u=b.length;if(u>0){let F=0;for(let U=0;Uk.SIXTY_FOUR_KILOBYTES&&(Z._locatorBuckets.push({locator:a,count:F}),F=0,e.push(4),l=[],t.push(l),r=0,a.count=s,s=0,i=0,a=new stt(0,0,this),n[++o]=[a]),l.push(r,r+2,r+1),l.push(r+1,r+2,r+3),F+=6,s+=6,i+=6,r+=4}Z._locatorBuckets.push({locator:a,count:F}),r+4>k.SIXTY_FOUR_KILOBYTES&&(e.push(0),l=[],t.push(l),r=0,a.count=s,i=0,s=0,a=new stt(0,0,this),n[++o]=[a])}Z._clean()}return a.count=s,i};lb.prototype.getPolylineStartIndex=function(t){let e=this.polylines,n=0,i=e.length;for(let o=0;o0){t._boundingVolume2D=Ft.fromPoints(o,t._boundingVolume2D);let d=t._boundingVolume2D.center;t._boundingVolume2D.center=new p(d.z,d.x,d.y)}return bC.positions=o,bC.lengths=t._segments.lengths,bC};var gft;lb.prototype.writeUpdate=function(t,e,n,i){let o=this.mode,a=i.ellipsoid.maximumRadius*k.PI,s=e._actualLength;if(s){t+=this.getPolylineStartIndex(e);let l=gft,r=6*s*3;!c(l)||l.lengthr&&(l=new Float32Array(l.buffer,0,r));let d=this.getSegments(e,i),m=d.positions,h=d.lengths,Z=0,b=0,u=0,F;s=m.length;for(let U=0;U0||er.x>0&&Kp.x<0)&&p.clone(er,Kp),(er.x<0&&zp.x>0||er.x>0&&zp.x<0)&&p.clone(er,zp));let g=A?2:0,C=T?2:4;for(let y=g;y{if(t.isDestroyed())return;t._positions=new Float64Array(l.positions);let r=t._billboardCollection,d=t._labelCollection,m=t._polylineCollection;n=t._positions;let h=t._batchIds,Z=n.length/3;for(let b=0;b{t.isDestroyed()||(t._error=l)})}hF.prototype.createFeatures=function(t,e){let n=this._billboardCollection,i=this._labelCollection,o=this._polylineCollection,a=this._batchIds,s=a.length;for(let l=0;l{if(t.isDestroyed())return;t._positions=void 0,t._counts=void 0,t._polygonMinimumHeights=void 0,t._polygonMaximumHeights=void 0;let u=new Float64Array(b.packedBuffer),F=u[0];Cde(t,u),t._indices=re.getSizeInBytes(F)===2?new Uint16Array(b.indices):new Uint32Array(b.indices),t._indexOffsets=new Uint32Array(b.indexOffsets),t._indexCounts=new Uint32Array(b.indexCounts),t._batchedPositions=new Float32Array(b.positions),t._vertexBatchIds=new Uint16Array(b.batchIds),Bde(t),t._ready=!0}).catch(b=>{t.isDestroyed()||(t._error=b)})}function Bde(t){c(t._primitive)||(t._primitive=new cA({batchTable:t._batchTable,positions:t._batchedPositions,batchIds:t._batchIds,vertexBatchIds:t._vertexBatchIds,indices:t._indices,indexOffsets:t._indexOffsets,indexCounts:t._indexCounts,batchedIndices:t._batchedIndices,boundingVolume:t._boundingVolume,boundingVolumes:t._boundingVolumes,center:t._center}),t._batchTable=void 0,t._batchIds=void 0,t._positions=void 0,t._counts=void 0,t._indices=void 0,t._indexCounts=void 0,t._indexOffsets=void 0,t._batchTableColors=void 0,t._packedBuffer=void 0,t._batchedPositions=void 0,t._transferrableBatchIds=void 0,t._vertexBatchIds=void 0,t._ellipsoid=void 0,t._minimumHeight=void 0,t._maximumHeight=void 0,t._polygonMinimumHeights=void 0,t._polygonMaximumHeights=void 0,t._center=void 0,t._rectangle=void 0,t._boundingVolume=void 0,t._boundingVolumes=void 0,t._batchedIndices=void 0)}f0.prototype.createFeatures=function(t,e){this._primitive.createFeatures(t,e)};f0.prototype.applyDebugSettings=function(t,e){this._primitive.applyDebugSettings(t,e)};f0.prototype.applyStyle=function(t,e){this._primitive.applyStyle(t,e)};f0.prototype.updateCommands=function(t,e){this._primitive.updateCommands(t,e)};f0.prototype.update=function(t){if(!this._ready){if(c(this._promise)||(this._promise=yde(this)),c(this._error)){let e=this._error;throw this._error=void 0,e}return}this._primitive.debugWireframe=this.debugWireframe,this._primitive.forceRebatch=this.forceRebatch,this._primitive.classificationType=this.classificationType,this._primitive.update(t)};f0.prototype.isDestroyed=function(){return!1};f0.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),At(this)};var yX=f0;var dti=R(W(),1);var x$n=R(W(),1),BX=`in vec4 currentPosition; +`;var Zqn=b(W(),1);var oqn=b(W(),1);var Lc={};Lc.numberOfPoints=function(t,e,n){let i=p.distance(t,e);return Math.ceil(i/n)};Lc.numberOfPointsRhumbLine=function(t,e,n){let i=Math.pow(t.longitude-e.longitude,2)+Math.pow(t.latitude-e.latitude,2);return Math.max(1,Math.ceil(Math.sqrt(i/(n*n))))};var xre=new gt;Lc.extractHeights=function(t,e){let n=t.length,i=new Array(n);for(let o=0;o0){e=f(e,L.IDENTITY);let o=L.inverseTransformation(e,Xre),a=L.multiplyByPoint(o,p.ZERO,Jre),s=p.normalize(L.multiplyByPointAsVector(o,p.UNIT_Y,uft),uft),l=Kn.fromPointNormal(a,s,Lre),r=p.normalize(L.multiplyByPointAsVector(o,p.UNIT_X,Zft),Zft),d=Kn.fromPointNormal(a,r,Mre),m=1;n.push(p.clone(t[0]));let h=n[0],u=t.length;for(let R=1;R2&&(this._actualPositions===this._positions&&(this._actualPositions=n.slice()),this._actualPositions.push(p.clone(this._actualPositions[0]))),this._length=this._actualPositions.length,this._id=t.id;let i;c(e)&&(i=L.clone(e.modelMatrix)),this._modelMatrix=i,this._segments=xo.wrapLongitude(this._actualPositions,i),this._actualLength=void 0,this._propertiesChanged=new Uint32Array(fft),this._polylineCollection=e,this._dirty=!1,this._pickId=void 0,this._boundingVolume=Ft.fromPoints(this._actualPositions),this._boundingVolumeWC=Ft.transform(this._boundingVolume,this._modelMatrix),this._boundingVolume2D=new Ft}var Wft=Bh.POSITION_INDEX=0,vre=Bh.SHOW_INDEX=1,Kre=Bh.WIDTH_INDEX=2,zre=Bh.MATERIAL_INDEX=3,gX=Bh.POSITION_SIZE_INDEX=4,jre=Bh.DISTANCE_DISPLAY_CONDITION=5,fft=Bh.NUMBER_OF_PROPERTIES=6;function W0(t,e){++t._propertiesChanged[e];let n=t._polylineCollection;c(n)&&(n._updatePolyline(t,e),t._dirty=!0)}Object.defineProperties(Bh.prototype,{show:{get:function(){return this._show},set:function(t){t!==this._show&&(this._show=t,W0(this,vre))}},positions:{get:function(){return this._positions},set:function(t){let e=sa(t,p.equalsEpsilon);this._loop&&e.length>2&&(e===t&&(e=t.slice()),e.push(p.clone(e[0]))),(this._actualPositions.length!==e.length||this._actualPositions.length!==this._length)&&W0(this,gX),this._positions=t,this._actualPositions=e,this._length=e.length,this._boundingVolume=Ft.fromPoints(this._actualPositions,this._boundingVolume),this._boundingVolumeWC=Ft.transform(this._boundingVolume,this._modelMatrix,this._boundingVolumeWC),W0(this,Wft),this.update()}},material:{get:function(){return this._material},set:function(t){this._material!==t&&(this._material=t,W0(this,zre))}},width:{get:function(){return this._width},set:function(t){let e=this._width;t!==e&&(this._width=t,W0(this,Kre))}},loop:{get:function(){return this._loop},set:function(t){if(t!==this._loop){let e=this._actualPositions;t?e.length>2&&!p.equals(e[0],e[e.length-1])&&(e.length===this._positions.length&&(this._actualPositions=e=this._positions.slice()),e.push(p.clone(e[0]))):e.length>2&&p.equals(e[0],e[e.length-1])&&(e.length-1===this._positions.length?this._actualPositions=this._positions:e.pop()),this._loop=t,W0(this,gX)}}},id:{get:function(){return this._id},set:function(t){this._id=t,c(this._pickId)&&(this._pickId.object.id=t)}},pickId:{get:function(){return this._pickId}},isDestroyed:{get:function(){return!c(this._polylineCollection)}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){Wn.equals(t,this._distanceDisplayCondition)||(this._distanceDisplayCondition=Wn.clone(t,this._distanceDisplayCondition),W0(this,jre))}}});Bh.prototype.update=function(){let t=L.IDENTITY;c(this._polylineCollection)&&(t=this._polylineCollection.modelMatrix);let e=this._segments.positions.length,n=this._segments.lengths,i=this._propertiesChanged[Wft]>0||this._propertiesChanged[gX]>0;if((!L.equals(t,this._modelMatrix)||i)&&(this._segments=xo.wrapLongitude(this._actualPositions,t),this._boundingVolumeWC=Ft.transform(this._boundingVolume,t,this._boundingVolumeWC)),this._modelMatrix=L.clone(t,this._modelMatrix),this._segments.positions.length!==e)W0(this,gX);else{let o=n.length;for(let a=0;a2){if(o[ltt]||o[Fft]){let V=t.mode===Vt.SCENE2D?i._boundingVolume2D:i._boundingVolumeWC,F=Mi.fromCartesian(V.center,Cft),U=bt.fromElements(F.low.x,F.low.y,F.low.z,V.radius,Ift);this._batchTable.setBatchedAttribute(i._index,2,F.high),this._batchTable.setBatchedAttribute(i._index,3,U)}if(o[ede]){let V=Nft;V.x=0,V.y=Number.MAX_VALUE;let F=i.distanceDisplayCondition;c(F)&&(V.x=F.near,V.y=F.far),this._batchTable.setBatchedAttribute(i._index,4,V)}}i._clean()}}r.length=0,this._polylinesUpdated=!1}o=this._propertiesChanged;for(let r=0;r0){let z=J.isTranslucent();l>=s?(Z=new Ee({owner:t}),n.push(Z)):Z=n[l],++l,E=ze(u(J._uniforms),t._uniformMap),Z.boundingVolume=Ft.clone(EX,Z.boundingVolume),Z.modelMatrix=i,Z.shaderProgram=C,Z.vertexArray=F.va,Z.renderState=z?t._translucentRS:t._opaqueRS,Z.pass=z?Pt.TRANSLUCENT:Pt.OPAQUE,Z.debugShowBoundingVolume=m,Z.pickId="v_pickColor",Z.uniformMap=E,Z.count=M,Z.offset=g,g+=M,M=0,r=!0,a.push(Z)}J=B._material,J.update(o),Q=X}let _=B._locatorBuckets,P=_.length;for(let z=0;z0&&(l>=s?(Z=new Ee({owner:t}),n.push(Z)):Z=n[l],++l,E=ze(u(J._uniforms),t._uniformMap),Z.boundingVolume=Ft.clone(EX,Z.boundingVolume),Z.modelMatrix=i,Z.shaderProgram=C,Z.vertexArray=F.va,Z.renderState=J.isTranslucent()?t._translucentRS:t._opaqueRS,Z.pass=J.isTranslucent()?Pt.TRANSLUCENT:Pt.OPAQUE,Z.debugShowBoundingVolume=m,Z.pickId="v_pickColor",Z.uniformMap=E,Z.count=M,Z.offset=g,r=!0,a.push(Z)),Q=void 0}}n.length=l}Su.prototype.isDestroyed=function(){return!1};Su.prototype.destroy=function(){return yft(this),dtt(this),Bft(this),this._batchTable=this._batchTable&&this._batchTable.destroy(),At(this)};function ode(t){let e=!1,n=t._propertiesChanged,i=t._positionBufferUsage;return n[ltt]?(i.bufferUsage!==ce.STREAM_DRAW&&(e=!0,i.bufferUsage=ce.STREAM_DRAW),i.frameCount=100):i.bufferUsage!==ce.STATIC_DRAW&&(i.frameCount===0?(e=!0,i.bufferUsage=ce.STATIC_DRAW):i.frameCount--),e}var Gft=[0,0,0];function Aft(t,e,n){t._createVertexArray=!1,dtt(t),yft(t),lde(t);let i=[[]],o=i[0],a=t._batchTable,s=t._useHighlightColor,l=[0],r=0,d=[[]],m=0,h=t._polylineBuckets,u,R;for(u in h)h.hasOwnProperty(u)&&(R=h[u],R.updateShader(e,a,s),m+=R.lengthOfPositions);if(m>0){let V=t._mode,F=new Float32Array(6*m*3),U=new Float32Array(m*4),G,A=0,S=0,g=0;for(u in h)if(h.hasOwnProperty(u)){R=h[u],R.write(F,U,A,S,g,a,e,n),V===Vt.MORPHING&&(c(G)||(G=new Float32Array(6*m*3)),R.writeForMorph(G,A));let E=R.lengthOfPositions;A+=6*E*3,S+=E*4,g+=E*4,r=R.updateIndices(i,l,d,r)}let C=t._positionBufferUsage.bufferUsage,y=ce.STATIC_DRAW;t._positionBuffer=we.createVertexBuffer({context:e,typedArray:F,usage:C});let Y;c(G)&&(Y=we.createVertexBuffer({context:e,typedArray:G,usage:C})),t._texCoordExpandAndBatchIndexBuffer=we.createVertexBuffer({context:e,typedArray:U,usage:y});let Q=3*Float32Array.BYTES_PER_ELEMENT,J=4*Float32Array.BYTES_PER_ELEMENT,M=0,Z=i.length;for(let E=0;E0){let I=new Uint16Array(o),B=we.createIndexBuffer({context:e,typedArray:I,usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT});M+=l[E];let X=6*(E*(Q*k.SIXTY_FOUR_KILOBYTES)-M*Q),_=Q+X,P=Q+_,w=Q+P,z=Q+w,H=Q+z,nt=E*(J*k.SIXTY_FOUR_KILOBYTES)-M*J,$=[{index:Jm.position3DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:X,strideInBytes:6*Q},{index:Jm.position3DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:_,strideInBytes:6*Q},{index:Jm.position2DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:X,strideInBytes:6*Q},{index:Jm.position2DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:_,strideInBytes:6*Q},{index:Jm.prevPosition3DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:P,strideInBytes:6*Q},{index:Jm.prevPosition3DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:w,strideInBytes:6*Q},{index:Jm.prevPosition2DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:P,strideInBytes:6*Q},{index:Jm.prevPosition2DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:w,strideInBytes:6*Q},{index:Jm.nextPosition3DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:z,strideInBytes:6*Q},{index:Jm.nextPosition3DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:H,strideInBytes:6*Q},{index:Jm.nextPosition2DHigh,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:z,strideInBytes:6*Q},{index:Jm.nextPosition2DLow,componentsPerAttribute:3,componentDatatype:it.FLOAT,offsetInBytes:H,strideInBytes:6*Q},{index:Jm.texCoordExpandAndBatchIndex,componentsPerAttribute:4,componentDatatype:it.FLOAT,vertexBuffer:t._texCoordExpandAndBatchIndexBuffer,offsetInBytes:nt}],dt,q,at,st;V===Vt.SCENE3D?(q=t._positionBuffer,dt="vertexBuffer",at=Gft,st="value"):V===Vt.SCENE2D||V===Vt.COLUMBUS_VIEW?(q=Gft,dt="value",at=t._positionBuffer,st="vertexBuffer"):(q=Y,dt="vertexBuffer",at=t._positionBuffer,st="vertexBuffer"),$[0][dt]=q,$[1][dt]=q,$[2][st]=at,$[3][st]=at,$[4][dt]=q,$[5][dt]=q,$[6][st]=at,$[7][st]=at,$[8][dt]=q,$[9][dt]=q,$[10][st]=at,$[11][st]=at;let Et=new Ki({context:e,attributes:$,indexBuffer:B});t._vertexArrays.push({va:Et,buckets:d[E]})}}}function ade(t,e){return e instanceof hn?e.id:e}var pP=[];function sde(t){let e=eo._uniformList[t.type],n=e.length;pP.length=2*n;let i=0;for(let o=0;o1){l.update();let r=l.material,d=i[r.type];c(d)||(d=i[r.type]=new lR(r,e,n)),d.addPolyline(l)}}}function rde(t,e){let n=e.mode;(t._mode!==n||!L.equals(t._modelMatrix,t.modelMatrix))&&(t._mode=n,t._modelMatrix=L.clone(t.modelMatrix),t._createVertexArray=!0)}function rtt(t){if(t._polylinesRemoved){t._polylinesRemoved=!1;let e=[],n=[],i=0,o,a=t._polylines.length;for(let s=0;s0,U=R._index,G=this.getSegments(R,l),A=G.positions,S=G.lengths,g=A.length,C=R.getPickId(s).color,y=0,Y=0,Q;for(let P=0;P0||er.x>0&&Kp.x<0)&&p.clone(er,Kp),(er.x<0&&zp.x>0||er.x>0&&zp.x<0)&&p.clone(er,zp));let nt=z?2:0,$=H?2:4;for(let dt=nt;dt<$;++dt){Mi.writeElements(er,t,n),Mi.writeElements(Kp,t,n+6),Mi.writeElements(zp,t,n+12);let q=dt-2<0?-1:1;e[o]=P/(g-1),e[o+1]=2*(dt%2)-1,e[o+2]=q,e[o+3]=U,n+=6*3,o+=4}}let J=dde;J.x=v.floatToByte(C.red),J.y=v.floatToByte(C.green),J.z=v.floatToByte(C.blue),J.w=v.floatToByte(C.alpha);let M=cde;M.x=V,M.y=F?1:0;let Z=r===Vt.SCENE2D?R._boundingVolume2D:R._boundingVolumeWC,E=Mi.fromCartesian(Z.center,Cft),I=E.high,B=bt.fromElements(E.low.x,E.low.y,E.low.z,Z.radius,Ift),X=Nft;X.x=0,X.y=Number.MAX_VALUE;let _=R.distanceDisplayCondition;c(_)&&(X.x=_.near,X.y=_.far),a.setBatchedAttribute(U,0,M),a.setBatchedAttribute(U,1,J),a.attributes.length>2&&(a.setBatchedAttribute(U,2,I),a.setBatchedAttribute(U,3,B),a.setBatchedAttribute(U,4,X))}};var mde=new p,hde=new p,pde=new p,Sft=new p;lR.prototype.writeForMorph=function(t,e){let n=this.modelMatrix,i=this.polylines,o=i.length;for(let a=0;a0&&(r=l[l.length-1]+1);let d=this.polylines,m=d.length;for(let h=0;h0)R[0]=F;else continue}else R=u._segments.lengths;let V=R.length;if(V>0){let F=0;for(let U=0;Uk.SIXTY_FOUR_KILOBYTES&&(u._locatorBuckets.push({locator:a,count:F}),F=0,e.push(4),l=[],t.push(l),r=0,a.count=s,s=0,i=0,a=new stt(0,0,this),n[++o]=[a]),l.push(r,r+2,r+1),l.push(r+1,r+2,r+3),F+=6,s+=6,i+=6,r+=4}u._locatorBuckets.push({locator:a,count:F}),r+4>k.SIXTY_FOUR_KILOBYTES&&(e.push(0),l=[],t.push(l),r=0,a.count=s,i=0,s=0,a=new stt(0,0,this),n[++o]=[a])}u._clean()}return a.count=s,i};lR.prototype.getPolylineStartIndex=function(t){let e=this.polylines,n=0,i=e.length;for(let o=0;o0){t._boundingVolume2D=Ft.fromPoints(o,t._boundingVolume2D);let d=t._boundingVolume2D.center;t._boundingVolume2D.center=new p(d.z,d.x,d.y)}return RC.positions=o,RC.lengths=t._segments.lengths,RC};var gft;lR.prototype.writeUpdate=function(t,e,n,i){let o=this.mode,a=i.ellipsoid.maximumRadius*k.PI,s=e._actualLength;if(s){t+=this.getPolylineStartIndex(e);let l=gft,r=6*s*3;!c(l)||l.lengthr&&(l=new Float32Array(l.buffer,0,r));let d=this.getSegments(e,i),m=d.positions,h=d.lengths,u=0,R=0,V=0,F;s=m.length;for(let U=0;U0||er.x>0&&Kp.x<0)&&p.clone(er,Kp),(er.x<0&&zp.x>0||er.x>0&&zp.x<0)&&p.clone(er,zp));let g=A?2:0,C=S?2:4;for(let y=g;y{if(t.isDestroyed())return;t._positions=new Float64Array(l.positions);let r=t._billboardCollection,d=t._labelCollection,m=t._polylineCollection;n=t._positions;let h=t._batchIds,u=n.length/3;for(let R=0;R{t.isDestroyed()||(t._error=l)})}hF.prototype.createFeatures=function(t,e){let n=this._billboardCollection,i=this._labelCollection,o=this._polylineCollection,a=this._batchIds,s=a.length;for(let l=0;l{if(t.isDestroyed())return;t._positions=void 0,t._counts=void 0,t._polygonMinimumHeights=void 0,t._polygonMaximumHeights=void 0;let V=new Float64Array(R.packedBuffer),F=V[0];Cde(t,V),t._indices=re.getSizeInBytes(F)===2?new Uint16Array(R.indices):new Uint32Array(R.indices),t._indexOffsets=new Uint32Array(R.indexOffsets),t._indexCounts=new Uint32Array(R.indexCounts),t._batchedPositions=new Float32Array(R.positions),t._vertexBatchIds=new Uint16Array(R.batchIds),Bde(t),t._ready=!0}).catch(R=>{t.isDestroyed()||(t._error=R)})}function Bde(t){c(t._primitive)||(t._primitive=new cA({batchTable:t._batchTable,positions:t._batchedPositions,batchIds:t._batchIds,vertexBatchIds:t._vertexBatchIds,indices:t._indices,indexOffsets:t._indexOffsets,indexCounts:t._indexCounts,batchedIndices:t._batchedIndices,boundingVolume:t._boundingVolume,boundingVolumes:t._boundingVolumes,center:t._center}),t._batchTable=void 0,t._batchIds=void 0,t._positions=void 0,t._counts=void 0,t._indices=void 0,t._indexCounts=void 0,t._indexOffsets=void 0,t._batchTableColors=void 0,t._packedBuffer=void 0,t._batchedPositions=void 0,t._transferrableBatchIds=void 0,t._vertexBatchIds=void 0,t._ellipsoid=void 0,t._minimumHeight=void 0,t._maximumHeight=void 0,t._polygonMinimumHeights=void 0,t._polygonMaximumHeights=void 0,t._center=void 0,t._rectangle=void 0,t._boundingVolume=void 0,t._boundingVolumes=void 0,t._batchedIndices=void 0)}f0.prototype.createFeatures=function(t,e){this._primitive.createFeatures(t,e)};f0.prototype.applyDebugSettings=function(t,e){this._primitive.applyDebugSettings(t,e)};f0.prototype.applyStyle=function(t,e){this._primitive.applyStyle(t,e)};f0.prototype.updateCommands=function(t,e){this._primitive.updateCommands(t,e)};f0.prototype.update=function(t){if(!this._ready){if(c(this._promise)||(this._promise=yde(this)),c(this._error)){let e=this._error;throw this._error=void 0,e}return}this._primitive.debugWireframe=this.debugWireframe,this._primitive.forceRebatch=this.forceRebatch,this._primitive.classificationType=this.classificationType,this._primitive.update(t)};f0.prototype.isDestroyed=function(){return!1};f0.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),At(this)};var yX=f0;var dti=b(W(),1);var x$n=b(W(),1),BX=`in vec4 currentPosition; in vec4 previousPosition; in vec4 nextPosition; in vec2 expandAndWidth; @@ -8640,12 +8640,12 @@ void main() vec4 positionWC = getPolylineWindowCoordinatesEC(p, prev, next, expandDir, width, usePrev, angle); gl_Position = czm_viewportOrthographic * positionWC; } -`;function SZ(t){this._positions=t.positions,this._widths=t.widths,this._counts=t.counts,this._batchIds=t.batchIds,this._ellipsoid=f(t.ellipsoid,mt.WGS84),this._minimumHeight=t.minimumHeight,this._maximumHeight=t.maximumHeight,this._center=t.center,this._rectangle=t.rectangle,this._boundingVolume=t.boundingVolume,this._batchTable=t.batchTable,this._va=void 0,this._sp=void 0,this._rs=void 0,this._uniformMap=void 0,this._command=void 0,this._transferrableBatchIds=void 0,this._packedBuffer=void 0,this._keepDecodedPositions=t.keepDecodedPositions,this._decodedPositions=void 0,this._decodedPositionOffsets=void 0,this._currentPositions=void 0,this._previousPositions=void 0,this._nextPositions=void 0,this._expandAndWidth=void 0,this._vertexBatchIds=void 0,this._indices=void 0,this._constantColor=v.clone(v.WHITE),this._highlightColor=this._constantColor,this._trianglesLength=0,this._geometryByteLength=0,this._ready=!1,this._promise=void 0,this._error=void 0}Object.defineProperties(SZ.prototype,{trianglesLength:{get:function(){return this._trianglesLength}},geometryByteLength:{get:function(){return this._geometryByteLength}},ready:{get:function(){return this._ready}}});function Qde(t){let e=t._rectangle,n=t._minimumHeight,i=t._maximumHeight,o=t._ellipsoid,a=t._center,s=2+Gt.packedLength+mt.packedLength+p.packedLength,l=new Float64Array(s),r=0;return l[r++]=n,l[r++]=i,Gt.pack(e,l,r),r+=Gt.packedLength,mt.pack(o,l,r),r+=mt.packedLength,p.pack(a,l,r),l}var kde=new $i("createVectorTilePolylines",5),RC={previousPosition:0,currentPosition:1,nextPosition:2,expandAndWidth:3,a_batchId:4};function Yde(t,e){if(c(t._va))return;let n=t._positions,i=t._widths,o=t._counts,a=t._transferrableBatchIds,s=t._packedBuffer;c(s)||(n=t._positions=n.slice(),i=t._widths=i.slice(),o=t._counts=o.slice(),a=t._transferrableBatchIds=t._batchIds.slice(),s=t._packedBuffer=Qde(t));let l=[n.buffer,i.buffer,o.buffer,a.buffer,s.buffer],r={positions:n.buffer,widths:i.buffer,counts:o.buffer,batchIds:a.buffer,packedBuffer:s.buffer,keepDecodedPositions:t._keepDecodedPositions},d=kde.scheduleTask(r,l);if(c(d))return d.then(function(m){if(t.isDestroyed())return;t._keepDecodedPositions&&(t._decodedPositions=new Float64Array(m.decodedPositions),t._decodedPositionOffsets=new Uint32Array(m.decodedPositionOffsets)),t._currentPositions=new Float32Array(m.currentPositions),t._previousPositions=new Float32Array(m.previousPositions),t._nextPositions=new Float32Array(m.nextPositions),t._expandAndWidth=new Float32Array(m.expandAndWidth),t._vertexBatchIds=new Uint16Array(m.batchIds);let h=m.indexDatatype;t._indices=h===re.UNSIGNED_SHORT?new Uint16Array(m.indices):new Uint32Array(m.indices),xde(t,e),t._ready=!0}).catch(m=>{t.isDestroyed()||(t._error=m)})}function xde(t,e){if(!c(t._va)){let n=t._currentPositions,i=t._previousPositions,o=t._nextPositions,a=t._expandAndWidth,s=t._vertexBatchIds,l=t._indices,r=i.byteLength+n.byteLength+o.byteLength;r+=a.byteLength+s.byteLength+l.byteLength,t._trianglesLength=l.length/3,t._geometryByteLength=r;let d=we.createVertexBuffer({context:e,typedArray:i,usage:ce.STATIC_DRAW}),m=we.createVertexBuffer({context:e,typedArray:n,usage:ce.STATIC_DRAW}),h=we.createVertexBuffer({context:e,typedArray:o,usage:ce.STATIC_DRAW}),Z=we.createVertexBuffer({context:e,typedArray:a,usage:ce.STATIC_DRAW}),b=we.createVertexBuffer({context:e,typedArray:s,usage:ce.STATIC_DRAW}),u=we.createIndexBuffer({context:e,typedArray:l,usage:ce.STATIC_DRAW,indexDatatype:l.BYTES_PER_ELEMENT===2?re.UNSIGNED_SHORT:re.UNSIGNED_INT}),F=[{index:RC.previousPosition,vertexBuffer:d,componentDatatype:it.FLOAT,componentsPerAttribute:3},{index:RC.currentPosition,vertexBuffer:m,componentDatatype:it.FLOAT,componentsPerAttribute:3},{index:RC.nextPosition,vertexBuffer:h,componentDatatype:it.FLOAT,componentsPerAttribute:3},{index:RC.expandAndWidth,vertexBuffer:Z,componentDatatype:it.FLOAT,componentsPerAttribute:2},{index:RC.a_batchId,vertexBuffer:b,componentDatatype:it.UNSIGNED_SHORT,componentsPerAttribute:1}];t._va=new Ki({context:e,attributes:F,indexBuffer:u}),t._positions=void 0,t._widths=void 0,t._counts=void 0,t._ellipsoid=void 0,t._minimumHeight=void 0,t._maximumHeight=void 0,t._rectangle=void 0,t._transferrableBatchIds=void 0,t._packedBuffer=void 0,t._currentPositions=void 0,t._previousPositions=void 0,t._nextPositions=void 0,t._expandAndWidth=void 0,t._vertexBatchIds=void 0,t._indices=void 0}}var QX=new L,kft=new p;function Xde(t,e){c(t._uniformMap)||(t._uniformMap={u_modifiedModelView:function(){let n=e.uniformState.view;return L.clone(n,QX),L.multiplyByPoint(QX,t._center,kft),L.setTranslation(QX,kft,QX),QX},u_highlightColor:function(){return t._highlightColor}})}function Jde(t){if(c(t._rs))return;let e={enabled:!0,factor:-5,units:-5};t._rs=he.fromCache({blending:Pn.ALPHA_BLEND,depthMask:!1,depthTest:{enabled:!0},polygonOffset:e})}var Lde=`uniform vec4 u_highlightColor; +`;function Tu(t){this._positions=t.positions,this._widths=t.widths,this._counts=t.counts,this._batchIds=t.batchIds,this._ellipsoid=f(t.ellipsoid,mt.WGS84),this._minimumHeight=t.minimumHeight,this._maximumHeight=t.maximumHeight,this._center=t.center,this._rectangle=t.rectangle,this._boundingVolume=t.boundingVolume,this._batchTable=t.batchTable,this._va=void 0,this._sp=void 0,this._rs=void 0,this._uniformMap=void 0,this._command=void 0,this._transferrableBatchIds=void 0,this._packedBuffer=void 0,this._keepDecodedPositions=t.keepDecodedPositions,this._decodedPositions=void 0,this._decodedPositionOffsets=void 0,this._currentPositions=void 0,this._previousPositions=void 0,this._nextPositions=void 0,this._expandAndWidth=void 0,this._vertexBatchIds=void 0,this._indices=void 0,this._constantColor=v.clone(v.WHITE),this._highlightColor=this._constantColor,this._trianglesLength=0,this._geometryByteLength=0,this._ready=!1,this._promise=void 0,this._error=void 0}Object.defineProperties(Tu.prototype,{trianglesLength:{get:function(){return this._trianglesLength}},geometryByteLength:{get:function(){return this._geometryByteLength}},ready:{get:function(){return this._ready}}});function Qde(t){let e=t._rectangle,n=t._minimumHeight,i=t._maximumHeight,o=t._ellipsoid,a=t._center,s=2+Gt.packedLength+mt.packedLength+p.packedLength,l=new Float64Array(s),r=0;return l[r++]=n,l[r++]=i,Gt.pack(e,l,r),r+=Gt.packedLength,mt.pack(o,l,r),r+=mt.packedLength,p.pack(a,l,r),l}var kde=new $i("createVectorTilePolylines",5),bC={previousPosition:0,currentPosition:1,nextPosition:2,expandAndWidth:3,a_batchId:4};function Yde(t,e){if(c(t._va))return;let n=t._positions,i=t._widths,o=t._counts,a=t._transferrableBatchIds,s=t._packedBuffer;c(s)||(n=t._positions=n.slice(),i=t._widths=i.slice(),o=t._counts=o.slice(),a=t._transferrableBatchIds=t._batchIds.slice(),s=t._packedBuffer=Qde(t));let l=[n.buffer,i.buffer,o.buffer,a.buffer,s.buffer],r={positions:n.buffer,widths:i.buffer,counts:o.buffer,batchIds:a.buffer,packedBuffer:s.buffer,keepDecodedPositions:t._keepDecodedPositions},d=kde.scheduleTask(r,l);if(c(d))return d.then(function(m){if(t.isDestroyed())return;t._keepDecodedPositions&&(t._decodedPositions=new Float64Array(m.decodedPositions),t._decodedPositionOffsets=new Uint32Array(m.decodedPositionOffsets)),t._currentPositions=new Float32Array(m.currentPositions),t._previousPositions=new Float32Array(m.previousPositions),t._nextPositions=new Float32Array(m.nextPositions),t._expandAndWidth=new Float32Array(m.expandAndWidth),t._vertexBatchIds=new Uint16Array(m.batchIds);let h=m.indexDatatype;t._indices=h===re.UNSIGNED_SHORT?new Uint16Array(m.indices):new Uint32Array(m.indices),xde(t,e),t._ready=!0}).catch(m=>{t.isDestroyed()||(t._error=m)})}function xde(t,e){if(!c(t._va)){let n=t._currentPositions,i=t._previousPositions,o=t._nextPositions,a=t._expandAndWidth,s=t._vertexBatchIds,l=t._indices,r=i.byteLength+n.byteLength+o.byteLength;r+=a.byteLength+s.byteLength+l.byteLength,t._trianglesLength=l.length/3,t._geometryByteLength=r;let d=we.createVertexBuffer({context:e,typedArray:i,usage:ce.STATIC_DRAW}),m=we.createVertexBuffer({context:e,typedArray:n,usage:ce.STATIC_DRAW}),h=we.createVertexBuffer({context:e,typedArray:o,usage:ce.STATIC_DRAW}),u=we.createVertexBuffer({context:e,typedArray:a,usage:ce.STATIC_DRAW}),R=we.createVertexBuffer({context:e,typedArray:s,usage:ce.STATIC_DRAW}),V=we.createIndexBuffer({context:e,typedArray:l,usage:ce.STATIC_DRAW,indexDatatype:l.BYTES_PER_ELEMENT===2?re.UNSIGNED_SHORT:re.UNSIGNED_INT}),F=[{index:bC.previousPosition,vertexBuffer:d,componentDatatype:it.FLOAT,componentsPerAttribute:3},{index:bC.currentPosition,vertexBuffer:m,componentDatatype:it.FLOAT,componentsPerAttribute:3},{index:bC.nextPosition,vertexBuffer:h,componentDatatype:it.FLOAT,componentsPerAttribute:3},{index:bC.expandAndWidth,vertexBuffer:u,componentDatatype:it.FLOAT,componentsPerAttribute:2},{index:bC.a_batchId,vertexBuffer:R,componentDatatype:it.UNSIGNED_SHORT,componentsPerAttribute:1}];t._va=new Ki({context:e,attributes:F,indexBuffer:V}),t._positions=void 0,t._widths=void 0,t._counts=void 0,t._ellipsoid=void 0,t._minimumHeight=void 0,t._maximumHeight=void 0,t._rectangle=void 0,t._transferrableBatchIds=void 0,t._packedBuffer=void 0,t._currentPositions=void 0,t._previousPositions=void 0,t._nextPositions=void 0,t._expandAndWidth=void 0,t._vertexBatchIds=void 0,t._indices=void 0}}var QX=new L,kft=new p;function Xde(t,e){c(t._uniformMap)||(t._uniformMap={u_modifiedModelView:function(){let n=e.uniformState.view;return L.clone(n,QX),L.multiplyByPoint(QX,t._center,kft),L.setTranslation(QX,kft,QX),QX},u_highlightColor:function(){return t._highlightColor}})}function Jde(t){if(c(t._rs))return;let e={enabled:!0,factor:-5,units:-5};t._rs=he.fromCache({blending:Pn.ALPHA_BLEND,depthMask:!1,depthTest:{enabled:!0},polygonOffset:e})}var Lde=`uniform vec4 u_highlightColor; void main() { out_FragColor = u_highlightColor; } -`;function Mde(t,e){if(c(t._sp))return;let n=t._batchTable,i=n.getVertexShaderCallback(!1,"a_batchId",void 0)(BX),o=n.getFragmentShaderCallback(!1,void 0,!1)(Lde),a=new Ve({defines:["VECTOR_TILE",In.isInternetExplorer()?"":"CLIP_POLYLINE"],sources:[Uh,i]}),s=new Ve({defines:["VECTOR_TILE"],sources:[o]});t._sp=xn.fromCache({context:e,vertexShaderSource:a,fragmentShaderSource:s,attributeLocations:RC})}function _de(t,e){if(!c(t._command)){let n=t._batchTable.getUniformMapCallback()(t._uniformMap);t._command=new Ee({owner:t,vertexArray:t._va,renderState:t._rs,shaderProgram:t._sp,uniformMap:n,boundingVolume:t._boundingVolume,pass:Pt.TRANSLUCENT,pickId:t._batchTable.getPickId()})}e.commandList.push(t._command)}SZ.getPolylinePositions=function(t,e){let n=t._batchIds,i=t._decodedPositions,o=t._decodedPositionOffsets;if(!c(n)||!c(i))return;let a,s,l=n.length,r=0,d=0;for(a=0;a{t.isDestroyed()||(t._error=m)})}function jde(t,e){if(!c(t._va)){let n=t._startEllipsoidNormals,i=t._endEllipsoidNormals,o=t._startPositionAndHeights,a=t._endPositionAndHeights,s=t._startFaceNormalAndVertexCornerIds,l=t._endFaceNormalAndHalfWidths,r=t._vertexBatchIds,d=t._indices,m=n.byteLength+i.byteLength;m+=o.byteLength+a.byteLength,m+=s.byteLength+l.byteLength,m+=r.byteLength+d.byteLength,t._trianglesLength=d.length/3,t._geometryByteLength=m;let h=we.createVertexBuffer({context:e,typedArray:n,usage:ce.STATIC_DRAW}),Z=we.createVertexBuffer({context:e,typedArray:i,usage:ce.STATIC_DRAW}),b=we.createVertexBuffer({context:e,typedArray:o,usage:ce.STATIC_DRAW}),u=we.createVertexBuffer({context:e,typedArray:a,usage:ce.STATIC_DRAW}),F=we.createVertexBuffer({context:e,typedArray:s,usage:ce.STATIC_DRAW}),U=we.createVertexBuffer({context:e,typedArray:l,usage:ce.STATIC_DRAW}),G=we.createVertexBuffer({context:e,typedArray:r,usage:ce.STATIC_DRAW}),A=we.createIndexBuffer({context:e,typedArray:d,usage:ce.STATIC_DRAW,indexDatatype:d.BYTES_PER_ELEMENT===2?re.UNSIGNED_SHORT:re.UNSIGNED_INT}),T=[{index:pF.startEllipsoidNormal,vertexBuffer:h,componentDatatype:it.FLOAT,componentsPerAttribute:3},{index:pF.endEllipsoidNormal,vertexBuffer:Z,componentDatatype:it.FLOAT,componentsPerAttribute:3},{index:pF.startPositionAndHeight,vertexBuffer:b,componentDatatype:it.FLOAT,componentsPerAttribute:4},{index:pF.endPositionAndHeight,vertexBuffer:u,componentDatatype:it.FLOAT,componentsPerAttribute:4},{index:pF.startFaceNormalAndVertexCorner,vertexBuffer:F,componentDatatype:it.FLOAT,componentsPerAttribute:4},{index:pF.endFaceNormalAndHalfWidth,vertexBuffer:U,componentDatatype:it.FLOAT,componentsPerAttribute:4},{index:pF.a_batchId,vertexBuffer:G,componentDatatype:it.UNSIGNED_SHORT,componentsPerAttribute:1}];t._va=new Ki({context:e,attributes:T,indexBuffer:A}),t._positions=void 0,t._widths=void 0,t._counts=void 0,t._ellipsoid=void 0,t._minimumHeight=void 0,t._maximumHeight=void 0,t._rectangle=void 0,t._transferrableBatchIds=void 0,t._packedBuffer=void 0,t._startEllipsoidNormals=void 0,t._endEllipsoidNormals=void 0,t._startPositionAndHeights=void 0,t._startFaceNormalAndVertexCornerIds=void 0,t._endPositionAndHeights=void 0,t._endFaceNormalAndHalfWidths=void 0,t._vertexBatchIds=void 0,t._indices=void 0}}var xX=new L,Yft=new p;function qde(t,e){c(t._uniformMap)||(t._uniformMap={u_modifiedModelView:function(){let n=e.uniformState.view;return L.clone(n,xX),L.multiplyByPoint(xX,t._center,Yft),L.setTranslation(xX,Yft,xX),xX},u_highlightColor:function(){return t._highlightColor},u_minimumMaximumVectorHeights:function(){return t._minimumMaximumVectorHeights}})}function xft(t){return he.fromCache({cull:{enabled:!0,face:so.FRONT},blending:Pn.PRE_MULTIPLIED_ALPHA_BLEND,depthMask:!1,stencilTest:{enabled:t,frontFunction:Li.EQUAL,frontOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.KEEP},backFunction:Li.EQUAL,backOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.KEEP},reference:gn.CESIUM_3D_TILE_MASK,mask:gn.CESIUM_3D_TILE_MASK}})}function $de(t){c(t._rs)||(t._rs=xft(!1),t._rs3DTiles=xft(!0))}function tce(t,e){if(c(t._sp))return;let n=t._batchTable,i=n.getVertexShaderCallback(!1,"a_batchId",void 0)(kX),o=n.getFragmentShaderCallback(!1,void 0,!0)(YX),a=new Ve({defines:["VECTOR_TILE",In.isInternetExplorer()?"":"CLIP_POLYLINE"],sources:[Uh,i]}),s=new Ve({defines:["VECTOR_TILE"],sources:[o]});t._sp=xn.fromCache({context:e,vertexShaderSource:a,fragmentShaderSource:s,attributeLocations:pF})}function ece(t,e){let n=t._command;if(!c(t._command)){let o=t._batchTable.getUniformMapCallback()(t._uniformMap);n=t._command=new Ee({owner:t,vertexArray:t._va,renderState:t._rs,shaderProgram:t._sp,uniformMap:o,boundingVolume:t._boundingVolume,pass:Pt.TERRAIN_CLASSIFICATION,pickId:t._batchTable.getPickId()});let a=Ee.shallowClone(n,n.derivedCommands.tileset);a.renderState=t._rs3DTiles,a.pass=Pt.CESIUM_3D_TILE_CLASSIFICATION,n.derivedCommands.tileset=a}let i=t._classificationType;(i===Ji.TERRAIN||i===Ji.BOTH)&&e.commandList.push(n),(i===Ji.CESIUM_3D_TILE||i===Ji.BOTH)&&e.commandList.push(n.derivedCommands.tileset)}F0.prototype.getPositions=function(t){return _A.getPolylinePositions(this,t)};F0.prototype.createFeatures=function(t,e){let n=this._batchIds,i=n.length;for(let o=0;o{t.isDestroyed()||(t._error=e)})}F0.prototype.update=function(t){let e=t.context;if(!this._ready){if(c(this._promise)||(this._promise=sce(this).then(zde(this,e))),c(this._error)){let i=this._error;throw this._error=void 0,i}return}qde(this,e),tce(this,e),$de(this);let n=t.passes;(n.render||n.pick)&&ece(this,t)};F0.prototype.isDestroyed=function(){return!1};F0.prototype.destroy=function(){return this._va=this._va&&this._va.destroy(),this._sp=this._sp&&this._sp.destroy(),At(this)};var XX=F0;var eei=R(W(),1);var mtt=32767,lce=new gt,rce=new p;function dce(t,e,n,i,o){let a=t.length/3,s=t.subarray(0,a),l=t.subarray(a,2*a),r=t.subarray(2*a,3*a);Ni.zigZagDeltaDecode(s,l,r);let d=new Float64Array(t.length);for(let m=0;m0&&c(t.POLYGON_BATCH_IDS)){let Z=e.byteOffset+t.POLYGON_BATCH_IDS.byteOffset;n=new Uint16Array(e.buffer,Z,s)}if(l>0&&c(t.POLYLINE_BATCH_IDS)){let Z=e.byteOffset+t.POLYLINE_BATCH_IDS.byteOffset;i=new Uint16Array(e.buffer,Z,l)}if(r>0&&c(t.POINT_BATCH_IDS)){let Z=e.byteOffset+t.POINT_BATCH_IDS.byteOffset;o=new Uint16Array(e.buffer,Z,r)}let d=c(n)||c(i)||c(o),m=s>0&&!c(n)||l>0&&!c(i)||r>0&&!c(o);if(d&&m)throw new St("If one group of batch ids is defined, then all batch ids must be defined");if(!c(n)&&!c(i)&&!c(o)){let Z=0;if(!c(n)&&s>0)for(n=new Uint16Array(s),a=0;a0)for(i=new Uint16Array(l),a=0;a0)for(o=new Uint16Array(r),a=0;a0&&(G=ts(i,n,d),n+=d,m>0&&(A=new Uint8Array(e,n,m),A=new Uint8Array(A),n+=m));let T=f(F.POLYGONS_LENGTH,0),g=f(F.POLYLINES_LENGTH,0),C=f(F.POINTS_LENGTH,0),y=T+g+C,Y=new wR(t,y,G,A,cce(t));if(t._batchTable=Y,y===0)return;let Q=new FZ(F,U),J=Q.getGlobalProperty("REGION");if(!c(J))throw new St("Feature table global property: REGION must be defined");let M=Gt.unpack(J),V=J[4],E=J[5],I=t._tile.computedTransform,B=Q.getGlobalProperty("RTC_CENTER",it.FLOAT,3);c(B)?(B=p.unpack(B),L.multiplyByPoint(I,B,B)):(B=Gt.center(M),B.height=k.lerp(V,E,.5),B=mt.WGS84.cartographicToCartesian(B));let X=mce(F,U);if(n+=(4-n%4)%4,T>0){Q.featuresLength=T;let _=f(Q.getPropertyArray("POLYGON_COUNTS",it.UNSIGNED_INT,1),Q.getPropertyArray("POLYGON_COUNT",it.UNSIGNED_INT,1));if(!c(_))throw new St("Feature table property: POLYGON_COUNTS must be defined when POLYGONS_LENGTH is greater than 0");let P=f(Q.getPropertyArray("POLYGON_INDEX_COUNTS",it.UNSIGNED_INT,1),Q.getPropertyArray("POLYGON_INDEX_COUNT",it.UNSIGNED_INT,1));if(!c(P))throw new St("Feature table property: POLYGON_INDEX_COUNTS must be defined when POLYGONS_LENGTH is greater than 0");let w=_.reduce(function(q,at){return q+at*2},0),z=P.reduce(function(q,at){return q+at},0),H=new Uint32Array(e,n,z);n+=h;let nt=new Uint16Array(e,n,w);n+=Z;let $,dt;c(F.POLYGON_MINIMUM_HEIGHTS)&&c(F.POLYGON_MAXIMUM_HEIGHTS)&&($=Q.getPropertyArray("POLYGON_MINIMUM_HEIGHTS",it.FLOAT,1),dt=Q.getPropertyArray("POLYGON_MAXIMUM_HEIGHTS",it.FLOAT,1)),t._polygons=new yX({positions:nt,counts:_,indexCounts:P,indices:H,minimumHeight:V,maximumHeight:E,polygonMinimumHeights:$,polygonMaximumHeights:dt,center:B,rectangle:M,boundingVolume:t.tile.boundingVolume.boundingVolume,batchTable:Y,batchIds:X.polygons,modelMatrix:I})}if(g>0){Q.featuresLength=g;let _=f(Q.getPropertyArray("POLYLINE_COUNTS",it.UNSIGNED_INT,1),Q.getPropertyArray("POLYLINE_COUNT",it.UNSIGNED_INT,1));if(!c(_))throw new St("Feature table property: POLYLINE_COUNTS must be defined when POLYLINES_LENGTH is greater than 0");let P=Q.getPropertyArray("POLYLINE_WIDTHS",it.UNSIGNED_SHORT,1);if(!c(P)){P=new Uint16Array(g);for(let dt=0;dt0){let _=new Uint16Array(e,n,C*3);n+=u,t._points=new NX({positions:_,batchIds:X.points,minimumHeight:V,maximumHeight:E,rectangle:M,batchTable:Y})}}function htt(t){let e=t.featuresLength;if(!c(t._features)&&e>0){let n=new Array(e);c(t._polygons)&&t._polygons.createFeatures(t,n),c(t._polylines)&&t._polylines.createFeatures(t,n),c(t._points)&&t._points.createFeatures(t,n),t._features=n}}EZ.prototype.hasProperty=function(t,e){return this._batchTable.hasProperty(t,e)};EZ.prototype.getFeature=function(t){return c(this._features)||htt(this),this._features[t]};EZ.prototype.applyDebugSettings=function(t,e){c(this._polygons)&&this._polygons.applyDebugSettings(t,e),c(this._polylines)&&this._polylines.applyDebugSettings(t,e),c(this._points)&&this._points.applyDebugSettings(t,e)};EZ.prototype.applyStyle=function(t){c(this._features)||htt(this),c(this._polygons)&&this._polygons.applyStyle(t,this._features),c(this._polylines)&&this._polylines.applyStyle(t,this._features),c(this._points)&&this._points.applyStyle(t,this._features)};EZ.prototype.update=function(t,e){let n=!0;c(this._polygons)&&(this._polygons.classificationType=this._tileset.classificationType,this._polygons.debugWireframe=this._tileset.debugWireframe,this._polygons.update(e),n=n&&this._polygons.ready),c(this._polylines)&&(this._polylines.update(e),n=n&&this._polylines.ready),c(this._points)&&(this._points.update(e),n=n&&this._points.ready),c(this._batchTable)&&n&&(c(this._features)||htt(this),this._batchTable.update(t,e),this._ready=!0)};EZ.prototype.pick=function(t,e,n){};EZ.prototype.getPolylinePositions=function(t){let e=this._polylines;if(c(e))return e.getPositions(t)};EZ.prototype.isDestroyed=function(){return!1};EZ.prototype.destroy=function(){return this._polygons=this._polygons&&this._polygons.destroy(),this._polylines=this._polylines&&this._polylines.destroy(),this._points=this._points&&this._points.destroy(),this._batchTable=this._batchTable&&this._batchTable.destroy(),At(this)};function Zce(t,e,n,i,o,a){let s=e.length,l=0;for(let r=0;r=0?i[a]:void 0}var HA=Rce;var pni=R(W(),1);var sni=R(W(),1);function A0(t){t=f(t,f.EMPTY_OBJECT);let e=t.tile,n=t.class;this._class=n,this._properties=e.properties,this._extensions=e.extensions,this._extras=e.extras}Object.defineProperties(A0.prototype,{class:{get:function(){return this._class}},extras:{get:function(){return this._extras}},extensions:{get:function(){return this._extensions}}});A0.prototype.hasProperty=function(t){return Yi.hasProperty(t,this._properties,this._class)};A0.prototype.hasPropertyBySemantic=function(t){return Yi.hasPropertyBySemantic(t,this._properties,this._class)};A0.prototype.getPropertyIds=function(t){return Yi.getPropertyIds(this._properties,this._class,t)};A0.prototype.getProperty=function(t){return Yi.getProperty(t,this._properties,this._class)};A0.prototype.setProperty=function(t,e){return Yi.setProperty(t,e,this._properties,this._class)};A0.prototype.getPropertyBySemantic=function(t){return Yi.getPropertyBySemantic(t,this._properties,this._class)};A0.prototype.setPropertyBySemantic=function(t,e){return Yi.setPropertyBySemantic(t,e,this._properties,this._class)};var _X=A0;function utt(t,e){let n=co(e,"3DTILES_metadata")?e.extensions["3DTILES_metadata"]:e.metadata;if(!c(n))return;if(!c(t.schema)){utt._oneTimeWarning("findTileMetadata-missing-root-schema","Could not find a metadata schema for tile metadata. For tilesets that contain external tilesets, make sure the schema is added to the root tileset.json.");return}let i=f(t.schema.classes,f.EMPTY_OBJECT);if(c(n.class)){let o=i[n.class];return new _X({tile:n,class:o})}}utt._oneTimeWarning=Gn;var DX=utt;var Yni=R(W(),1);var fni=R(W(),1);function Wce(t){let e=new Uint8Array(t),n=mZ(e);if(n==="glTF"&&(n="glb"),nr.isBinaryFormat(n))return{contentType:n,binaryPayload:e};let i=fce(e);if(c(i.root))return{contentType:nr.EXTERNAL_TILESET,jsonPayload:i};if(c(i.asset))return{contentType:nr.GLTF,jsonPayload:i};if(c(i.tileAvailability))return{contentType:nr.IMPLICIT_SUBTREE_JSON,jsonPayload:i};if(c(i.type))return{contentType:nr.GEOJSON,jsonPayload:i};if(c(i.voxelTable))return{contentType:nr.VOXEL_JSON,jsonPayload:i};throw new St("Invalid tile content.")}function fce(t){let e;try{e=ts(t)}catch{throw new St("Invalid tile content.")}return e}var db=Wce;function qp(t,e,n,i){this._tileset=t,this._tile=e,this._tilesetResource=n,this._contents=[],this._contentsCreated=!1;let o=c(i.contents)?i.contents:i.content;this._innerContentHeaders=o,this._requestsInFlight=0,this._cancelCount=0;let a=this._innerContentHeaders.length;this._arrayFetchPromises=new Array(a),this._requests=new Array(a),this._ready=!1,this._innerContentResources=new Array(a),this._serverKeys=new Array(a);for(let s=0;sAce(t,a,s)),o=await Promise.all(i);return t._contentsCreated=!0,t._contents=o.filter(c),o}async function Ace(t,e,n){if(c(e))try{let i=db(e);if(i.contentType===nr.EXTERNAL_TILESET)throw new St("External tilesets are disallowed inside multiple contents");t._disableSkipLevelOfDetail=t._disableSkipLevelOfDetail||i.contentType===nr.GEOMETRY||i.contentType===nr.VECTOR;let o=t._tileset,a=t._innerContentResources[n],s=t._tile,l,r=DA[i.contentType];c(i.binaryPayload)?l=await Promise.resolve(r(o,s,a,i.binaryPayload.buffer,0)):l=await Promise.resolve(r(o,s,a,i.jsonPayload));let d=t._innerContentHeaders[n];if(s.hasImplicitContentMetadata){let h=s.implicitSubtree,Z=s.implicitCoordinates;l.metadata=h.getContentMetadataView(Z,n)}else s.hasImplicitContent||(l.metadata=OA(o,d));let m=HA(o,d);return c(m)&&(l.group=new sA({metadata:m})),l}catch(i){Lft(t,n,i)}}function Lft(t,e,n){let i=t._tileset,o=t._innerContentResources[e].url,a=c(n.message)?n.message:n.toString();i.tileFailed.numberOfListeners>0?i.tileFailed.raiseEvent({url:o,message:a}):(console.log(`A content failed to load: ${o}`),console.log(`Error: ${a}`))}qp.prototype.cancelRequests=function(){for(let t=0;tl?b=k.TWO_PI-r+l:b=l-r;let F=Math.ceil(b/e)+1,U=Math.ceil(u/e)+1,G=b/(F-1),A=u/(U-1),T=Gt.northwest(t,a),g=Gt.center(t,gce);(n!==0||i!==0)&&(g.longitude=0;u--)ir.computePosition(e,n,!1,b,u,F),h[Z++]=F.x,h[Z++]=F.y,h[Z++]=F.z;for(u=0,b=i-2;b>0;b--)ir.computePosition(e,n,!1,b,u,F),h[Z++]=F.x,h[Z++]=F.y,h[Z++]=F.z;let U=h.length/3*2,G=re.createTypedArray(h.length/3,U),A=0;for(let g=0;g0){tu.longitude=(e.west+e.east)*.5,tu.latitude=d;let F=n.cartographicToCartesian(tu,UC.origin);p.clone(r,UC.direction);let U=Kn.fromPointNormal(t.southwestCornerCartesian,t.westNormal,Kft);no.rayPlane(UC,U,t.southwestCornerCartesian),m=n.geodeticSurfaceNormal(F,VP)}else m=n.geodeticSurfaceNormalCartographic(Gt.southeast(e),VP);let h=p.cross(m,l,vft);p.normalize(h,t.southNormal);let Z=e.north,b;if(Z<0){tu.longitude=(e.west+e.east)*.5,tu.latitude=Z;let F=n.cartographicToCartesian(tu,UC.origin);p.negate(r,UC.direction);let U=Kn.fromPointNormal(t.northeastCornerCartesian,t.eastNormal,Kft);no.rayPlane(UC,U,t.northeastCornerCartesian),b=n.geodeticSurfaceNormal(F,VP)}else b=n.geodeticSurfaceNormalCartographic(Gt.northwest(e),VP);let u=p.cross(l,b,vft);p.normalize(u,t.northNormal)}var Jce=new p,Lce=new p,Mce=new p(0,-1,0),_ce=new p(0,0,-1),zft=new p;function Dce(t,e){let n=e.camera,i=n.positionWC,o=n.positionCartographic,a=0;if(!Gt.contains(t.rectangle,o)){let d=t.southwestCornerCartesian,m=t.northeastCornerCartesian,h=t.westNormal,Z=t.southNormal,b=t.eastNormal,u=t.northNormal;e.mode!==ut.SCENE3D&&(d=e.mapProjection.project(Gt.southwest(t.rectangle),Jce),d.z=d.y,d.y=d.x,d.x=0,m=e.mapProjection.project(Gt.northeast(t.rectangle),Lce),m.z=m.y,m.y=m.x,m.x=0,h=Mce,b=p.UNIT_Y,Z=_ce,u=p.UNIT_Z);let F=p.subtract(i,d,zft),U=p.dot(F,h),G=p.dot(F,Z),A=p.subtract(i,m,zft),T=p.dot(A,b),g=p.dot(A,u);U>0?a+=U*U:T>0&&(a+=T*T),G>0?a+=G*G:g>0&&(a+=g*g)}let s,l,r;if(e.mode===ut.SCENE3D?(s=o.height,l=t.minimumHeight,r=t.maximumHeight):(s=i.x,l=0,r=0),s>r){let d=s-r;a+=d*d}else if(s0?(n.push(0),i.push(this._planeVertices[0]),o=this._edgeNormals[0]):Kn.getPointDistance(this._boundingPlanes[1],e)>0&&(n.push(1),i.push(this._planeVertices[1]),o=this._edgeNormals[1]);let a,s;for(a=0;a<4;a++)s=2+a,Kn.getPointDistance(this._boundingPlanes[s],e)>0&&(n.push(s),i.push(this._planeVertices[s]),o=this._edgeNormals[s]);if(n.length===0)return 0;let l,r;if(n.length===1)return r=this._boundingPlanes[n[0]],l=gtt(Kn.projectPointOntoPlane(r,e,Stt),i[0],r,o),p.distance(l,e);if(n.length===2){if(n[0]===0){let Z=[this._vertices[4*n[0]+(n[1]-2)],this._vertices[4*n[0]+(n[1]-2+1)%4]];return l=iFt(e,Z[0],Z[1]),p.distance(l,e)}let m=Number.MAX_VALUE,h;for(a=0;a<2;a++)r=this._boundingPlanes[n[a]],l=gtt(Kn.projectPointOntoPlane(r,e,Stt),i[a],r,this._edgeNormals[n[a]]),h=p.distanceSquared(l,e),h3)return l=gtt(Kn.projectPointOntoPlane(this._boundingPlanes[1],e,Stt),this._planeVertices[1],this._boundingPlanes[1],this._edgeNormals[1]),p.distance(l,e);let d=n[1]===2&&n[2]===5?0:1;return n[0]===0?p.distance(e,this._vertices[(n[1]-2+d)%4]):p.distance(e,this._vertices[4+(n[1]-2+d)%4])};var sme=new p,lme=new p;function iFt(t,e,n){let i=p.subtract(n,e,sme),o=p.subtract(t,e,lme),a=p.dot(i,o);if(a<=0)return e;let s=p.dot(i,i);return a>=s?n:(a=a/s,new p((1-a)*e.x+a*n.x,(1-a)*e.y+a*n.y,(1-a)*e.z+a*n.z))}var rme=new Kn(p.UNIT_X,0);function gtt(t,e,n,i){let o=Number.MAX_VALUE,a,s,l;for(let r=0;r0&&(u=!0,h+=d),s1||co(n,"3DTILES_multiple_contents"),s=o&&!a?n.contents[0]:n.content;this._contentHeader=s,this.transform=c(n.transform)?L.unpack(n.transform):L.clone(L.IDENTITY);let l=c(i)?i.computedTransform:t.modelMatrix,r=L.multiply(l,this.transform,new L),d=c(i)?i._initialTransform:L.IDENTITY;this._initialTransform=L.multiply(d,this.transform,new L),this.computedTransform=r,this.metadata=DX(t,n),this._verticalExaggeration=1,this._verticalExaggerationRelativeHeight=0,this._boundingVolume=this.createBoundingVolume(n.boundingVolume,r),this._boundingVolume2D=void 0;let m;c(s)&&c(s.boundingVolume)&&(m=this.createBoundingVolume(s.boundingVolume,r)),this._contentBoundingVolume=m,this._contentBoundingVolume2D=void 0;let h;c(n.viewerRequestVolume)&&(h=this.createBoundingVolume(n.viewerRequestVolume,r)),this._viewerRequestVolume=h,this.geometricError=n.geometricError,this._geometricError=n.geometricError,c(this._geometricError)||(this._geometricError=c(i)?i._geometricError:t._geometricError,fs._deprecationWarning("geometricErrorUndefined","Required property geometricError is undefined for this tile. Using parent's geometric error instead.")),this.updateGeometricErrorScale();let Z;c(n.refine)?((n.refine==="replace"||n.refine==="add")&&fs._deprecationWarning("lowercase-refine",`This tile uses a lowercase refine "${n.refine}". Instead use "${n.refine.toUpperCase()}".`),Z=n.refine.toUpperCase()==="REPLACE"?ss.REPLACE:ss.ADD):c(i)?Z=i.refine:Z=ss.REPLACE,this.refine=Z,this.children=[],this.parent=i;let b,u=!1,F,U,G;if(e=te.createIfNeeded(e),a)F=rs.UNLOADED,U=e.clone();else if(c(s)){let C=s.uri;c(s.url)&&(fs._deprecationWarning("contentUrl",'This tileset JSON uses the "content.url" property which has been deprecated. Use "content.uri" instead.'),C=s.url),C===""?(fs._deprecationWarning("contentUriEmpty","content.uri property is an empty string, which creates a circular dependency, making this tileset invalid. Omit the content property instead"),b=new WC(t,this),u=!0,F=rs.READY):(F=rs.UNLOADED,U=e.getDerivedResource({url:C}),G=xd.getServerKey(U.getUrlComponent()))}else b=new WC(t,this),u=!0,F=rs.READY;this._content=b,this._contentResource=U,this._contentState=F,this._expiredContent=void 0,this._serverKey=G,this.hasEmptyContent=u,this.hasTilesetContent=!1,this.hasImplicitContent=!1,this.hasImplicitContentMetadata=!1,this.hasMultipleContents=a,this.cacheNode=void 0;let A=n.expire,T,g;c(A)&&(T=A.duration,c(A.date)&&(g=rt.fromIso8601(A.date))),this.expireDuration=T,this.expireDate=g,this.lastStyleTime=0,this._optimChildrenWithinParent=jp.NOT_COMPUTED,this.clippingPlanesDirty=!1,this.clippingPolygonsDirty=!1,this.priorityDeferred=!1,this.implicitTileset=void 0,this.implicitCoordinates=void 0,this.implicitSubtree=void 0,this._distanceToCamera=0,this._centerZDepth=0,this._screenSpaceError=0,this._screenSpaceErrorProgressiveResolution=0,this._visibilityPlaneMask=0,this._visible=!1,this._inRequestVolume=!1,this._finalResolution=!0,this._depth=0,this._stackLength=0,this._selectionDepth=0,this._updatedVisibilityFrame=0,this._touchedFrame=0,this._visitedFrame=0,this._selectedFrame=0,this._wasSelectedLastFrame=!1,this._requestedFrame=0,this._ancestorWithContent=void 0,this._ancestorWithContentAvailable=void 0,this._refines=!1,this._shouldSelect=!1,this._isClipped=!0,this._isClippedByPolygon=!1,this._clippingPlanesState=0,this._clippingPolygonsState=0,this._debugBoundingVolume=void 0,this._debugContentBoundingVolume=void 0,this._debugViewerRequestVolume=void 0,this._debugColor=v.fromRandom({alpha:1}),this._debugColorizeTiles=!1,this._priority=0,this._priorityHolder=this,this._priorityProgressiveResolution=!1,this._priorityProgressiveResolutionScreenSpaceErrorLeaf=!1,this._priorityReverseScreenSpaceError=0,this._foveatedFactor=0,this._wasMinPriorityChild=!1,this._loadTimestamp=new rt,this._commandsLength=0,this._color=void 0,this._colorDirty=!1,this._request=void 0}fs._deprecationWarning=Zr;Object.defineProperties(fs.prototype,{tileset:{get:function(){return this._tileset}},content:{get:function(){return this._content}},boundingVolume:{get:function(){return this._boundingVolume}},contentBoundingVolume:{get:function(){return f(this._contentBoundingVolume,this._boundingVolume)}},boundingSphere:{get:function(){return this._boundingVolume.boundingSphere}},isVisible:{get:function(){return this._visible&&this._inRequestVolume}},extras:{get:function(){return this._header.extras}},color:{get:function(){return c(this._color)||(this._color=new v),v.clone(this._color)},set:function(t){this._color=v.clone(t,this._color),this._colorDirty=!0}},hasRenderableContent:{get:function(){return!this.hasEmptyContent&&!this.hasTilesetContent&&!this.hasImplicitContent}},contentAvailable:{get:function(){return this.contentReady&&this.hasRenderableContent||c(this._expiredContent)&&!this.contentFailed}},contentReady:{get:function(){return this._contentState===rs.READY}},contentUnloaded:{get:function(){return this._contentState===rs.UNLOADED}},hasUnloadedRenderableContent:{get:function(){return this.hasRenderableContent&&this.contentUnloaded}},contentExpired:{get:function(){return this._contentState===rs.EXPIRED}},contentFailed:{get:function(){return this._contentState===rs.FAILED}},commandsLength:{get:function(){return this._commandsLength}}});var ZF=new p;function Zme(t,e){let{tileset:n,boundingSphere:i}=t,{radius:o,center:a}=i,{camera:s}=e,l=p.multiplyByScalar(s.directionWC,t._centerZDepth,ZF),r=p.add(s.positionWC,l,ZF),d=p.subtract(r,a,ZF);if(p.magnitude(d)>o){let g=p.normalize(d,ZF),C=p.multiplyByScalar(g,o,ZF),y=p.add(a,C,ZF),Y=p.subtract(y,s.positionWC,ZF),Q=p.normalize(Y,ZF);t._foveatedFactor=1-Math.abs(p.dot(s.directionWC,Q))}else t._foveatedFactor=0;let Z=t.refine===ss.REPLACE,b=n.isSkippingLevelOfDetail;if(Z&&!b||!n.foveatedScreenSpaceError||n.foveatedConeSize===1||t._priorityProgressiveResolution&&Z&&b||n._pass===ns.PRELOAD_FLIGHT||n._pass===ns.PRELOAD)return!1;let u=1-Math.cos(s.frustum.fov*.5),F=n.foveatedConeSize*u;if(t._foveatedFactor<=F)return!1;let U=u-F,G=k.clamp((t._foveatedFactor-F)/U,0,1),A=n.foveatedInterpolationCallback(n.foveatedMinimumScreenSpaceErrorRelaxation,n.memoryAdjustedScreenSpaceError,G),T=t._screenSpaceError===0&&c(t.parent)?t.parent._screenSpaceError*.5:t._screenSpaceError;return n.memoryAdjustedScreenSpaceError-A<=T}var cFt=new rt;fs.prototype.getScreenSpaceError=function(t,e,n){let i=this._tileset,o=f(n,1),a=c(this.parent)?this.parent.geometricError:i._scaledGeometricError,s=e?a:this.geometricError;if(s===0)return 0;let{camera:l,context:r}=t,d=l.frustum,m=r.drawingBufferWidth,h=r.drawingBufferHeight*o,Z;if(t.mode===ut.SCENE2D||d instanceof wn){let b=d.offCenterFrustum;c(b)&&(d=b);let u=Math.max(d.top-d.bottom,d.right-d.left)/Math.max(m,h);Z=s/u}else{let b=Math.max(this._distanceToCamera,k.EPSILON7),u=d.sseDenominator;if(Z=s*h/(b*u),i.dynamicScreenSpaceError){let F=i._dynamicScreenSpaceErrorComputedDensity,U=i.dynamicScreenSpaceErrorFactor,G=k.fog(b,F)*U;Z-=G}}return Z/=t.pixelRatio,Z};function Vme(t,e){if(t.progressiveResolutionHeightFraction<=0||t.progressiveResolutionHeightFraction>.5)return!1;let n=t.memoryAdjustedScreenSpaceError,i=e._screenSpaceErrorProgressiveResolution>n;e._priorityProgressiveResolutionScreenSpaceErrorLeaf=!1;let o=e.parent,a=e._screenSpaceErrorProgressiveResolution<=n,s=c(o)&&o._screenSpaceErrorProgressiveResolution>n;return a&&s&&(e._priorityProgressiveResolutionScreenSpaceErrorLeaf=!0,i=!0),i}function bme(t,e){let n=e.parent,o=c(n)&&(!t.isSkippingLevelOfDetail||e._screenSpaceError===0||n.hasTilesetContent||n.hasImplicitContent)?n._screenSpaceError:e._screenSpaceError;return t.root._screenSpaceError-o}fs.prototype.updateVisibility=function(t){let{parent:e,tileset:n}=this;if(this._updatedVisibilityFrame===n._updatedVisibilityFrame)return;let i=c(e)?e.computedTransform:n.modelMatrix,o=c(e)?e._visibilityPlaneMask:Jl.MASK_INDETERMINATE;this.updateTransform(i,t),this._distanceToCamera=this.distanceToTile(t),this._centerZDepth=this.distanceToTileCenter(t),this._screenSpaceError=this.getScreenSpaceError(t,!1),this._screenSpaceErrorProgressiveResolution=this.getScreenSpaceError(t,!1,n.progressiveResolutionHeightFraction),this._visibilityPlaneMask=this.visibility(t,o),this._visible=this._visibilityPlaneMask!==Jl.MASK_OUTSIDE,this._inRequestVolume=this.insideViewerRequestVolume(t),this._priorityReverseScreenSpaceError=bme(n,this),this._priorityProgressiveResolution=Vme(n,this),this.priorityDeferred=Zme(this,t),this._updatedVisibilityFrame=n._updatedVisibilityFrame};fs.prototype.updateExpiration=function(){if(c(this.expireDate)&&this.contentReady&&!this.hasEmptyContent&&!this.hasMultipleContents){let t=rt.now(cFt);rt.lessThan(this.expireDate,t)&&(this._contentState=rs.EXPIRED,this._expiredContent=this._content)}};function Rme(t){if(!c(t.expireDuration))return;let e=rt.now(cFt);rt.addSeconds(e,t.expireDuration,e),c(t.expireDate)?rt.lessThan(t.expireDate,e)&&rt.clone(e,t.expireDate):t.expireDate=rt.clone(e)}function Wme(t){return function(){return t._priority}}fs.prototype.requestContent=function(){if(!this.hasEmptyContent)return this.hasMultipleContents?fme(this):Ume(this)};function fme(t){let e=t._content,n=t._tileset;if(!c(e)){let o=co(t._header,"3DTILES_multiple_contents")?t._header.extensions["3DTILES_multiple_contents"]:t._header;e=new OX(n,t,t._contentResource.clone(),o),t._content=e}let i=e.requestInnerContents();if(c(i))return t._contentState=rs.LOADING,i.then(o=>{if(!t.isDestroyed()&&c(o))return t._contentState=rs.PROCESSING,e}).catch(o=>{if(!t.isDestroyed())throw t._contentState=rs.FAILED,o})}async function Fme(t,e,n,i,o){let a=t._contentState;t._contentState=rs.LOADING,++e.statistics.numberOfPendingRequests;let s;try{s=await o}catch(l){if(--e.statistics.numberOfPendingRequests,t.isDestroyed())return;if(n.cancelled||n.state===qi.CANCELLED){t._contentState=a,++e.statistics.numberOfAttemptedRequests;return}throw t._contentState=rs.FAILED,l}if(t.isDestroyed()){--e.statistics.numberOfPendingRequests;return}if(n.cancelled||n.state===qi.CANCELLED){t._contentState=a,--e.statistics.numberOfPendingRequests,++e.statistics.numberOfAttemptedRequests;return}try{let l=await Gme(t,s);return--e.statistics.numberOfPendingRequests,t.isDestroyed()?void 0:(i&&(t.expireDate=void 0),t._content=l,t._contentState=rs.PROCESSING,l)}catch(l){if(--e.statistics.numberOfPendingRequests,t.isDestroyed())return;throw t._contentState=rs.FAILED,l}}function Ume(t){let e=t._contentResource.clone(),n=t.contentExpired;n&&e.setQueryParameters({expired:t.expireDate.toString()});let i=new Zs({throttle:!0,throttleByServer:!0,type:Xl.TILES3D,priorityFunction:Wme(t),serverKey:t._serverKey});t._request=i,e.request=i;let o=t._tileset,a=e.fetchArrayBuffer();if(!c(a)){++o.statistics.numberOfAttemptedRequests;return}return Fme(t,o,i,n,a)}async function Gme(t,e){let n=db(e),i=t._tileset;i._disableSkipLevelOfDetail=i._disableSkipLevelOfDetail||n.contentType===nr.GEOMETRY||n.contentType===nr.VECTOR,(n.contentType===nr.IMPLICIT_SUBTREE||n.contentType===nr.IMPLICIT_SUBTREE_JSON)&&(t.hasImplicitContent=!0),n.contentType===nr.EXTERNAL_TILESET&&(t.hasTilesetContent=!0);let o,a=DA[n.contentType];if(t.isDestroyed())return;c(n.binaryPayload)?o=await Promise.resolve(a(i,t,t._contentResource,n.binaryPayload.buffer,0)):o=await Promise.resolve(a(i,t,t._contentResource,n.jsonPayload));let s=t._contentHeader;if(t.hasImplicitContentMetadata){let r=t.implicitSubtree,d=t.implicitCoordinates;o.metadata=r.getContentMetadataView(d,0)}else t.hasImplicitContent||(o.metadata=OA(i,s));let l=HA(i,s);return c(l)&&(o.group=new sA({metadata:l})),o}fs.prototype.cancelRequests=function(){this.hasMultipleContents?this._content.cancelRequests():this._request.cancel()};fs.prototype.unloadContent=function(){this.hasRenderableContent&&(this._content=this._content&&this._content.destroy(),this._contentState=rs.UNLOADED,this.lastStyleTime=0,this.clippingPlanesDirty=this._clippingPlanesState===0,this._clippingPlanesState=0,this.clippingPolygonsDirty=this._clippingPolygonsState===0,this._clippingPolygonsState=0,this._debugColorizeTiles=!1,this._debugBoundingVolume=this._debugBoundingVolume&&this._debugBoundingVolume.destroy(),this._debugContentBoundingVolume=this._debugContentBoundingVolume&&this._debugContentBoundingVolume.destroy(),this._debugViewerRequestVolume=this._debugViewerRequestVolume&&this._debugViewerRequestVolume.destroy())};var mFt=new Ft;function Itt(t,e){if(e.mode!==ut.SCENE3D&&!c(t._boundingVolume2D)){let n=t._boundingVolume.boundingSphere,i=Ft.projectTo2D(n,e.mapProjection,mFt);t._boundingVolume2D=new E0(i.center,i.radius)}return e.mode!==ut.SCENE3D?t._boundingVolume2D:t._boundingVolume}function Ame(t,e){if(e.mode!==ut.SCENE3D&&!c(t._contentBoundingVolume2D)){let n=t._contentBoundingVolume.boundingSphere,i=Ft.projectTo2D(n,e.mapProjection,mFt);t._contentBoundingVolume2D=new E0(i.center,i.radius)}return e.mode!==ut.SCENE3D?t._contentBoundingVolume2D:t._contentBoundingVolume}fs.prototype.visibility=function(t,e){let n=t.cullingVolume,i=Itt(this,t),o=this._tileset,a=o.clippingPlanes;if(c(a)&&a.enabled){let l=a.computeIntersectionWithBoundingVolume(i,o.clippingPlanesOriginMatrix);if(this._isClipped=l!==yn.INSIDE,l===yn.OUTSIDE)return Jl.MASK_OUTSIDE}let s=o.clippingPolygons;if(c(s)&&s.enabled){let l=s.computeIntersectionWithBoundingVolume(i);this._isClippedByPolygon=l!==yn.OUTSIDE}return n.computeVisibilityWithPlaneMask(i,e)};fs.prototype.contentVisibility=function(t){if(!c(this._contentBoundingVolume))return yn.INSIDE;if(this._visibilityPlaneMask===Jl.MASK_INSIDE)return yn.INSIDE;let e=t.cullingVolume,n=Ame(this,t),i=this._tileset,o=i.clippingPlanes;if(c(o)&&o.enabled){let s=o.computeIntersectionWithBoundingVolume(n,i.clippingPlanesOriginMatrix);if(this._isClipped=s!==yn.INSIDE,s===yn.OUTSIDE)return yn.OUTSIDE}let a=i.clippingPolygons;if(c(a)&&a.enabled){let s=a.computeIntersectionWithBoundingVolume(n);if(this._isClippedByPolygon=s!==yn.OUTSIDE,s===yn.INSIDE)return yn.OUTSIDE}return e.computeVisibility(n)};fs.prototype.distanceToTile=function(t){return Itt(this,t).distanceToCamera(t)};var Tme=new p;fs.prototype.distanceToTileCenter=function(t){let n=Itt(this,t).boundingVolume,i=p.subtract(n.center,t.camera.positionWC,Tme);return p.dot(t.camera.directionWC,i)};fs.prototype.insideViewerRequestVolume=function(t){let e=this._viewerRequestVolume;return!c(e)||e.distanceToCamera(t)===0};var hFt=new ot,pFt=new p,Sme=new ot,Ntt=new p,uFt=new Gt,ZFt=new ci,Ctt=new L;function gme(t,e,n){let i=p.fromElements(t[0],t[1],t[2],Ntt),o=ot.fromArray(t,3,Sme);i=L.multiplyByPoint(e,i,i);let a=L.getMatrix3(e,hFt);return o=ot.multiply(a,o,o),c(n)?(n.update(i,o),n):new kh(i,o)}function Eme(t,e,n,i){let o=Gt.unpack(t,0,uFt),a=t[4],s=t[5],l=ci.fromRectangle(o,a,s,mt.WGS84,ZFt),r=l.center,d=l.halfAxes;e=L.multiplyTransformation(e,L.inverseTransformation(n,Ctt),Ctt),r=L.multiplyByPoint(e,r,r);let m=L.getMatrix3(e,hFt);return d=ot.multiply(m,d,d),c(i)&&i instanceof kh?(i.update(r,d),i):new kh(r,d)}function Cme(t,e,n,i){if(!L.equalsEpsilon(e,n,k.EPSILON8))return Eme(t,e,n,i);let o=Gt.unpack(t,0,uFt);return c(i)?(i.rectangle=Gt.clone(o,i.rectangle),i.minimumHeight=t[4],i.maximumHeight=t[5],i.computeBoundingVolumes(mt.WGS84),i):new eu({rectangle:o,minimumHeight:t[4],maximumHeight:t[5]})}function Ime(t,e,n){let i=p.fromElements(t[0],t[1],t[2],Ntt),o=t[3];i=L.multiplyByPoint(e,i,i);let a=L.getScale(e,pFt),s=p.maximumComponent(a);return o*=s,c(n)?(n.update(i,o),n):new E0(i,o)}fs.prototype.createBoundingVolume=function(t,e,n){let i=this.metadata,o;if(c(i)&&(o=AA.parseBoundingVolumeSemantic("TILE",i)),c(o)&&(t=o),!c(t))throw new St("boundingVolume must be defined");if(co(t,"3DTILES_bounding_volume_S2"))return new PX(t.extensions["3DTILES_bounding_volume_S2"]);let{box:a,region:s,sphere:l}=t;if(c(a)){let r=gme(a,e,n);return this._verticalExaggeration!==1&&lFt(r,this._verticalExaggeration,this._verticalExaggerationRelativeHeight),r}if(c(s)){let r=Cme(s,e,this._initialTransform,n);return this._verticalExaggeration===1||(r instanceof kh?lFt(r,this._verticalExaggeration,this._verticalExaggerationRelativeHeight):(r.minimumHeight=Ps.getHeight(r.minimumHeight,this._verticalExaggeration,this._verticalExaggerationRelativeHeight),r.maximumHeight=Ps.getHeight(r.maximumHeight,this._verticalExaggeration,this._verticalExaggerationRelativeHeight),r.computeBoundingVolumes(mt.WGS84))),r}if(c(l)){let r=Ime(l,e,n);if(this._verticalExaggeration!==1){let d=Ps.getPosition(r.center,mt.WGS84,this._verticalExaggeration,this._verticalExaggerationRelativeHeight,Ntt),m=r.radius*this._verticalExaggeration;r.update(d,m)}return r}throw new St("boundingVolume must contain a sphere, region, or box")};var Nme=p.unpackArray(new Array(8*3).fill(0));function lFt(t,e,n){let i=t.boundingVolume.computeCorners(Nme).map(a=>Ps.getPosition(a,mt.WGS84,e,n,a)),o=ci.fromPoints(i,ZFt);t.update(o.center,o.halfAxes)}fs.prototype.updateTransform=function(t,e){t=f(t,L.IDENTITY);let n=L.multiplyTransformation(t,this.transform,Ctt),i=!L.equals(n,this.computedTransform),o=c(e)&&(this._verticalExaggeration!==e.verticalExaggeration||this._verticalExaggerationRelativeHeight!==e.verticalExaggerationRelativeHeight);if(!i&&!o)return;i&&L.clone(n,this.computedTransform),o&&(this._verticalExaggeration=e.verticalExaggeration,this._verticalExaggerationRelativeHeight=e.verticalExaggerationRelativeHeight);let a=this._header,s=this._contentHeader;this._boundingVolume=this.createBoundingVolume(a.boundingVolume,this.computedTransform,this._boundingVolume),c(this._contentBoundingVolume)&&(this._contentBoundingVolume=this.createBoundingVolume(s.boundingVolume,this.computedTransform,this._contentBoundingVolume)),c(this._viewerRequestVolume)&&(this._viewerRequestVolume=this.createBoundingVolume(a.viewerRequestVolume,this.computedTransform,this._viewerRequestVolume)),this.updateGeometricErrorScale(),this._debugBoundingVolume=this._debugBoundingVolume&&this._debugBoundingVolume.destroy(),this._debugContentBoundingVolume=this._debugContentBoundingVolume&&this._debugContentBoundingVolume.destroy(),this._debugViewerRequestVolume=this._debugViewerRequestVolume&&this._debugViewerRequestVolume.destroy()};fs.prototype.updateGeometricErrorScale=function(){let t=L.getScale(this.computedTransform,pFt),e=p.maximumComponent(t);if(this.geometricError=this._geometricError*e,!c(this.parent)){let n=this._tileset;n._scaledGeometricError=n._geometricError*e}};function yme(t,e,n,i){if(!i.isRender)return;let o=c(t._contentHeader)&&c(t._contentHeader.boundingVolume),a=e.debugShowBoundingVolume||e.debugShowContentBoundingVolume&&!o;if(a){let r;t._finalResolution?t.hasRenderableContent?r=v.WHITE:r=v.DARKGRAY:r=v.YELLOW,c(t._debugBoundingVolume)||(t._debugBoundingVolume=t._boundingVolume.createDebugVolume(r)),t._debugBoundingVolume.update(n);let d=t._debugBoundingVolume.getGeometryInstanceAttributes("outline");d.color=En.toValue(r,d.color)}else!a&&c(t._debugBoundingVolume)&&(t._debugBoundingVolume=t._debugBoundingVolume.destroy());e.debugShowContentBoundingVolume&&o?(c(t._debugContentBoundingVolume)||(t._debugContentBoundingVolume=t._contentBoundingVolume.createDebugVolume(v.BLUE)),t._debugContentBoundingVolume.update(n)):!e.debugShowContentBoundingVolume&&c(t._debugContentBoundingVolume)&&(t._debugContentBoundingVolume=t._debugContentBoundingVolume.destroy()),e.debugShowViewerRequestVolume&&c(t._viewerRequestVolume)?(c(t._debugViewerRequestVolume)||(t._debugViewerRequestVolume=t._viewerRequestVolume.createDebugVolume(v.YELLOW)),t._debugViewerRequestVolume.update(n)):!e.debugShowViewerRequestVolume&&c(t._debugViewerRequestVolume)&&(t._debugViewerRequestVolume=t._debugViewerRequestVolume.destroy());let s=e.debugColorizeTiles&&!t._debugColorizeTiles||c(e._heatmap.tilePropertyName),l=!e.debugColorizeTiles&&t._debugColorizeTiles;s?(e._heatmap.colorize(t,n),t._debugColorizeTiles=!0,t.color=t._debugColor):l&&(t._debugColorizeTiles=!1,t.color=v.WHITE),t._colorDirty&&(t._colorDirty=!1,t._content.applyDebugSettings(!0,t._color)),l&&e.makeStyleDirty()}function Bme(t,e,n){let i=t._expiredContent;if(!t.hasMultipleContents&&c(i)){if(!t.contentReady){try{i.update(e,n)}catch{}return}t._expiredContent.destroy(),t._expiredContent=void 0}if(c(t.content))try{t.content.update(e,n)}catch(o){throw t._contentState=rs.FAILED,o}}function Qme(t,e){let n=e.clippingPlanes,i=0;c(n)&&t._isClipped&&n.enabled&&(i=n.clippingPlanesState),i!==t._clippingPlanesState&&(t._clippingPlanesState=i,t.clippingPlanesDirty=!0)}function kme(t,e){let n=e.clippingPolygons,i=0;c(n)&&t._isClippedByPolygon&&n.enabled&&(i=n.clippingPolygonsState),i!==t._clippingPolygonsState&&(t._clippingPolygonsState=i,t.clippingPolygonsDirty=!0)}fs.prototype.update=function(t,e,n){let{commandList:i}=e,o=i.length;Qme(this,t),kme(this,t),yme(this,t,e,n),Bme(this,t,e);let a=i.length;this._commandsLength=a-o;for(let s=o;st.cacheBytes||n);){let s=a.item;a=a.next,this.unloadTile(t,s,e)}};tT.prototype.trim=function(){this._trimTiles=!0};var qX=tT;var xsi=R(W(),1);function FP(t){this.tilePropertyName=t,this._minimum=Number.MAX_VALUE,this._maximum=-Number.MAX_VALUE,this._previousMinimum=Number.MAX_VALUE,this._previousMaximum=-Number.MAX_VALUE,this._referenceMinimum={},this._referenceMaximum={}}function Btt(t,e){let n;return e==="_loadTimestamp"?n=rt.toDate(t).getTime():n=t,n}FP.prototype.setReferenceMinimumMaximum=function(t,e,n){this._referenceMinimum[n]=Btt(t,n),this._referenceMaximum[n]=Btt(e,n)};function Xme(t,e){let n=t.tilePropertyName;if(c(n)){let i=Btt(e[n],n);return c(i)?(t._maximum=Math.max(i,t._maximum),t._minimum=Math.min(i,t._minimum),i):(t.tilePropertyName=void 0,i)}}var ytt=[new v(.1,.1,.1,1),new v(.153,.278,.878,1),new v(.827,.231,.49,1),new v(.827,.188,.22,1),new v(1,.592,.259,1),new v(1,.843,0,1)];FP.prototype.colorize=function(t,e){let n=this.tilePropertyName;if(!c(n)||!t.contentAvailable||t._selectedFrame!==e.frameNumber)return;let i=Xme(this,t),o=this._previousMinimum,a=this._previousMaximum;if(o===Number.MAX_VALUE||a===-Number.MAX_VALUE)return;let s=a-o+k.EPSILON7,r=k.clamp(i-o,0,s)/s,d=ytt.length-1,m=r*d,h=Math.floor(m),Z=Math.ceil(m),b=m-h,u=ytt[h],F=ytt[Z],U=v.clone(v.WHITE);U.red=k.lerp(u.red,F.red,b),U.green=k.lerp(u.green,F.green,b),U.blue=k.lerp(u.blue,F.blue,b),t._debugColor=U};FP.prototype.resetMinimumMaximum=function(){let t=this.tilePropertyName;if(c(t)){let e=this._referenceMinimum[t],n=this._referenceMaximum[t],i=c(e)&&c(n);this._previousMinimum=i?e:this._minimum,this._previousMaximum=i?n:this._maximum,this._minimum=Number.MAX_VALUE,this._maximum=-Number.MAX_VALUE}};var $X=FP;var Lsi=R(W(),1);function IC(){this.selected=0,this.visited=0,this.numberOfCommands=0,this.numberOfAttemptedRequests=0,this.numberOfPendingRequests=0,this.numberOfTilesProcessing=0,this.numberOfTilesWithContentReady=0,this.numberOfTilesTotal=0,this.numberOfLoadedTilesTotal=0,this.numberOfFeaturesSelected=0,this.numberOfFeaturesLoaded=0,this.numberOfPointsSelected=0,this.numberOfPointsLoaded=0,this.numberOfTrianglesSelected=0,this.numberOfTilesStyled=0,this.numberOfFeaturesStyled=0,this.numberOfTilesCulledWithChildrenUnion=0,this.geometryByteLength=0,this.texturesByteLength=0,this.batchTableByteLength=0}IC.prototype.clear=function(){this.selected=0,this.visited=0,this.numberOfCommands=0,this.numberOfAttemptedRequests=0,this.numberOfFeaturesSelected=0,this.numberOfPointsSelected=0,this.numberOfTrianglesSelected=0,this.numberOfTilesStyled=0,this.numberOfFeaturesStyled=0,this.numberOfTilesCulledWithChildrenUnion=0};function UP(t,e,n,i){let o=e.innerContents,a=e.pointsLength,s=e.trianglesLength,l=e.featuresLength,r=e.geometryByteLength,d=e.texturesByteLength,m=e.batchTableByteLength;if(i?(t.numberOfFeaturesLoaded+=n?-l:l,t.numberOfPointsLoaded+=n?-a:a,t.geometryByteLength+=n?-r:r,t.texturesByteLength+=n?-d:d,t.batchTableByteLength+=n?-m:m):(t.numberOfFeaturesSelected+=n?-l:l,t.numberOfPointsSelected+=n?-a:a,t.numberOfTrianglesSelected+=n?-s:s),c(o)){let h=o.length;for(let Z=0;Z>1)&858993459,t=(t^t>>2)&252645135,t=(t^t>>4)&16711935,t=(t^t>>8)&65535,t}function ktt(t){return t&=153391689,t=(t^t>>2)&51130563,t=(t^t>>4)&50393103,t=(t^t>>8)&4278190335,t=(t^t>>16)&1023,t}nJ.encode2D=function(t,e){return(WFt(t)|WFt(e)<<1)>>>0};nJ.decode2D=function(t,e){return c(e)||(e=new Array(2)),e[0]=fFt(t),e[1]=fFt(t>>1),e};nJ.encode3D=function(t,e,n){return Qtt(t)|Qtt(e)<<1|Qtt(n)<<2};nJ.decode3D=function(t,e){return c(e)||(e=new Array(3)),e[0]=ktt(t),e[1]=ktt(t>>1),e[2]=ktt(t>>2),e};var VF=nJ;function ds(t){this.subdivisionScheme=t.subdivisionScheme,this.subtreeLevels=t.subtreeLevels,this.level=t.level,this.x=t.x,this.y=t.y,this.z=void 0,t.subdivisionScheme===Al.OCTREE&&(this.z=t.z)}Object.defineProperties(ds.prototype,{childIndex:{get:function(){let t=0;return t|=this.x&1,t|=(this.y&1)<<1,this.subdivisionScheme===Al.OCTREE&&(t|=(this.z&1)<<2),t}},mortonIndex:{get:function(){return this.subdivisionScheme===Al.OCTREE?VF.encode3D(this.x,this.y,this.z):VF.encode2D(this.x,this.y)}},tileIndex:{get:function(){let t=this.subdivisionScheme===Al.OCTREE?((1<<3*this.level)-1)/7:((1<<2*this.level)-1)/3,e=this.mortonIndex;return t+e}}});ds.prototype.getDescendantCoordinates=function(t){let e=this.level+t.level,n=(this.x<>e,i=t.y>>e,o=this.x===n,a=this.y===i;if(this.subdivisionScheme===Al.OCTREE){let s=t.z>>e,l=this.z===s;return o&&a&&l}return o&&a};ds.prototype.isEqual=function(t){return this.subdivisionScheme===t.subdivisionScheme&&this.subtreeLevels===t.subtreeLevels&&this.level===t.level&&this.x===t.x&&this.y===t.y&&(this.subdivisionScheme===Al.OCTREE?this.z===t.z:!0)};ds.prototype.isImplicitTilesetRoot=function(){return this.level===0};ds.prototype.isSubtreeRoot=function(){return this.level%this.subtreeLevels===0};ds.prototype.isBottomOfSubtree=function(){return this.level%this.subtreeLevels===this.subtreeLevels-1};ds.prototype.getTemplateValues=function(){let t={level:this.level,x:this.x,y:this.y};return this.subdivisionScheme===Al.OCTREE&&(t.z=this.z),t};var FFt=[0,0,0];ds.fromMortonIndex=function(t,e,n,i){let o;return t===Al.OCTREE?(o=VF.decode3D(i,FFt),new ds({subdivisionScheme:t,subtreeLevels:e,level:n,x:o[0],y:o[1],z:o[2]})):(o=VF.decode2D(i,FFt),new ds({subdivisionScheme:t,subtreeLevels:e,level:n,x:o[0],y:o[1]}))};ds.fromTileIndex=function(t,e,n){let i,o,a;return t===Al.OCTREE?(i=Math.floor(k.log2(7*n+1)/3),o=((1<<3*i)-1)/7,a=n-o):(i=Math.floor(k.log2(3*n+1)/2),o=((1<<2*i)-1)/3,a=n-o),ds.fromMortonIndex(t,e,i,a)};var nT=ds;var Rli=R(W(),1);var hli=R(W(),1);function y0(){}y0.selectTiles=function(t,e){Ut.throwInstantiationError()};y0.sortChildrenByDistanceToCamera=function(t,e){return e._distanceToCamera===0&&t._distanceToCamera===0?e._centerZDepth-t._centerZDepth:e._distanceToCamera-t._distanceToCamera};y0.canTraverse=function(t){return t.children.length===0?!1:t.hasTilesetContent||t.hasImplicitContent?!t.contentExpired:t._screenSpaceError>t.tileset.memoryAdjustedScreenSpaceError};y0.selectTile=function(t,e){if(t.contentVisibility(e)===yn.OUTSIDE)return;t._wasSelectedLastFrame=!0;let{content:n,tileset:i}=t;n.featurePropertiesDirty?(n.featurePropertiesDirty=!1,t.lastStyleTime=0,i._selectedTilesToStyle.push(t)):t._selectedFrame0;if((t.hasTilesetContent||t.hasImplicitContent)&&n){let a=t.children[0];UFt(a,e),t._visible=a._visible;return}if(Dme(t,e)){t._visible=!1;return}let i=t.refine===ss.REPLACE,o=t._optimChildrenWithinParent===jp.USE_OPTIMIZATION;if(i&&o&&n&&!Ome(t,e)){++t.tileset._statistics.numberOfTilesCulledWithChildrenUnion,t._visible=!1;return}}function Dme(t,e){let{parent:n,tileset:i}=t;return!c(n)||n.hasTilesetContent||n.hasImplicitContent||n.refine!==ss.ADD?!1:t.getScreenSpaceError(e,!0)<=i.memoryAdjustedScreenSpaceError}function Ome(t,e){let n=!1,i=t.children;for(let o=0;o0;){iJ.stackMaximumLength=Math.max(iJ.stackMaximumLength,s.length);let l=s.pop(),r=l.refine===ss.ADD,d=l.refine===ss.REPLACE,m=wme(l);m&&Pme(l,s,e),(r||d&&!m)&&(vme(t,l),o(l,e),Kme(l,e),l.hasRenderableContent&&!l.contentAvailable&&(n=!1)),a(l,e)}return iJ.stack.trim(iJ.stackMaximumLength),n};function wme(t){return t.children.length===0?!1:t.hasTilesetContent||t.hasImplicitContent?!t.contentExpired:(t.hasEmptyContent,!0)}function Pme(t,e,n){let{children:i}=t;for(let o=0;o0;){aJ.stackMaximumLength=Math.max(aJ.stackMaximumLength,l.length);let r=l.pop(),d=r.parent,m=!c(d)||d._refines;r._refines=i(r)?zme(r,l,e)&&m:!1;let h=!r._refines&&m;r.hasRenderableContent?r.refine===ss.ADD?(Ytt(r,e),o(r,e)):r.refine===ss.REPLACE&&(o(r,e),h&&Ytt(r,e)):(n._emptyTiles.push(r),o(r,e),h&&Ytt(r,e)),a(r,e),s(r,e)}}function qme(t,e){let{canTraverse:n,updateTile:i,loadTile:o,touchTile:a}=Sr,s=!0,l=sJ.stack;for(l.push(t);l.length>0;){sJ.stackMaximumLength=Math.max(sJ.stackMaximumLength,l.length);let r=l.pop(),d=r.children,m=d.length,h=!r.hasRenderableContent&&n(r);if(!h&&!r.contentAvailable&&(s=!1),i(r,e),r.isVisible||(o(r,e),a(r,e)),h)for(let Z=0;Z0;){dJ.stackMaximumLength=Math.max(dJ.stackMaximumLength,a.length);let l=a.pop().children;for(let r=0;rn._depth+t.skipLevels)}function ihe(t,e,n){let{tileset:i,children:o}=t,{updateTile:a,loadTile:s,touchTile:l}=Sr;for(let d=0;de:t._screenSpaceError>e:!0}function ahe(t,e){let{tileset:n}=t,i=n.immediatelyLoadDesiredLevelOfDetail?Number.MAX_VALUE:Math.max(n.baseScreenSpaceError,n.memoryAdjustedScreenSpaceError),{canTraverse:o,loadTile:a,visitTile:s,touchTile:l}=Sr,r=rJ.stack;for(r.push(t);r.length>0;){rJ.stackMaximumLength=Math.max(rJ.stackMaximumLength,r.length);let d=r.pop();ehe(d,e);let m=d.parent,h=!c(m)||m._refines;d._refines=o(d)?ihe(d,r,e)&&h:!1;let Z=!d._refines&&h;d.hasRenderableContent?d.refine===ss.ADD?(GP(d,e),a(d,e)):d.refine===ss.REPLACE&&(ohe(d,i)?(a(d,e),Z&&GP(d,e)):Z?(GP(d,e),a(d,e)):nhe(n,d)&&a(d,e)):(n._emptyTiles.push(d),a(d,e),Z&&GP(d,e)),s(d,e),l(d,e)}}function she(t,e){let{selectTile:n,canTraverse:i}=Sr,{stack:o,ancestorStack:a}=B0,s;for(o.push(t);o.length>0||a.length>0;){if(B0.stackMaximumLength=Math.max(B0.stackMaximumLength,o.length),B0.ancestorStackMaximumLength=Math.max(B0.ancestorStackMaximumLength,a.length),a.length>0){let d=a.peek();if(d._stackLength===o.length){a.pop(),d!==s&&(d._finalResolution=!1),n(d,e);continue}}let l=o.pop();if(!c(l))continue;let r=i(l);if(l._shouldSelect)if(l.refine===ss.ADD)n(l,e);else{if(l._selectionDepth=a.length,l._selectionDepth>0&&(l.tileset.hasMixedContent=!0),s=l,!r){n(l,e);continue}a.push(l),l._stackLength=o.length}if(r){let d=l.children;for(let m=0;muo._defaultMinTerrainHeight&&(s._initialClippingPlanesOriginMatrix=Pe.eastNorthUpToFixedFrame(Z)),s._clippingPlanesOriginMatrix=L.clone(s._initialClippingPlanesOriginMatrix),s};Fs.loadJson=function(t){return te.createIfNeeded(t).fetchJson()};Fs.prototype.makeStyleDirty=function(){this._styleEngine.makeDirty()};Fs.prototype.loadTileset=function(t,e,n){let i=e.asset;if(!c(i))throw new St("Tileset must have an asset property.");if(i.version!=="0.0"&&i.version!=="1.0"&&i.version!=="1.1")throw new St("The tileset must be 3D Tiles version 0.0, 1.0, or 1.1");c(e.extensionsRequired)&&Fs.checkSupportedExtensions(e.extensionsRequired);let o=this._statistics,a=i.tilesetVersion;c(a)&&(this._basePath+=`?v=${a}`,t=t.clone(),t.setQueryParameters({v:a}));let s=SFt(this,t,e.root,n);c(n)&&(n.children.push(s),s._depth=n._depth+1);let l=[];for(l.push(s);l.length>0;){let r=l.pop();++o.numberOfTilesTotal,this._allTilesAdditive=this._allTilesAdditive&&r.refine===ss.ADD;let d=r._header.children;if(c(d))for(let m=0;mU.minimumRadius){let T=gt.fromCartesian(A,U,rhe);n=p.normalize(l.positionWC,gFt),i=l.directionWC,o=l.positionCartographic.height,a=0,s=T.height*2}else{let T=L.multiplyByPoint(F,l.positionWC,mhe);if(n=p.UNIT_Z,i=L.multiplyByPointAsVector(F,l.directionWC,hhe),i=p.normalize(i,i),o=T.z,d instanceof kh){let g=ot.getColumn(G.halfAxes,2,phe),C=p.magnitude(g);a=A.z-C,s=A.z+C}else if(d instanceof E0){let g=G.radius;a=A.z-g,s=A.z+g}}}let m=t.dynamicScreenSpaceErrorHeightFalloff,h=a+(s-a)*m,Z=s,b=k.clamp((o-h)/(Z-h),0,1),u=1-Math.abs(p.dot(i,n));u=u*(1-b),t._dynamicScreenSpaceErrorComputedDensity=t.dynamicScreenSpaceErrorDensity*u}function Zhe(t,e){if(e.hasEmptyContent)return;let{statistics:n}=t,i=e.contentExpired,o=e.requestContent();c(o)&&(o.then(a=>{!c(a)||e.isDestroyed()||t.isDestroyed()||(t._processingQueue.push(e),++n.numberOfTilesProcessing)}).catch(a=>{IFt(a,t,e)}),i&&(e.hasTilesetContent||e.hasImplicitContent?Che(t,e):(n.decrementLoadCounts(e.content),--n.numberOfTilesWithContentReady)),t._requestedTilesInFlight.push(e))}function CFt(t,e){return t._priority-e._priority}Fs.prototype.postPassesUpdate=function(t){c(this._root)&&(Vhe(this,t),Nhe(this,t),this._cache.unloadTiles(this,yFt),this._styleApplied&&this._styleEngine.resetDirty(),this._styleApplied=!1)};Fs.prototype.prePassesUpdate=function(t){if(!c(this._root))return;Ghe(this,t);let e=this._clippingPlanes;this._clippingPlanesOriginMatrixDirty=!0,c(e)&&e.enabled&&e.update(t);let n=this._clippingPolygons;c(n)&&n.enabled&&n.update(t),c(this._loadTimestamp)||(this._loadTimestamp=rt.clone(t.time)),this._timeSinceLoad=Math.max(rt.secondsDifference(t.time,this._loadTimestamp)*1e3,0),this.dynamicScreenSpaceError&&uhe(this,t),t.newFrame&&this._cache.reset()};function Vhe(t,e){let n=t._requestedTilesInFlight,i=0;for(let o=0;o=1;if(a._contentState!==rs.LOADING){++i;continue}else if(s){a.cancelRequests(),++i;continue}i>0&&(n[o-i]=a)}n.length-=i}function bhe(t){let e=t._requestedTiles;e.sort(CFt);for(let n=0;n0?e.tileFailed.raiseEvent({url:i,message:o}):(console.log(`A 3D tile failed to load: ${i}`),console.log(`Error: ${o}`))}function Rhe(t){let e=t._processingQueue,n=0;for(let i=0;i0&&(e[i-n]=o)}e.length-=n}var Whe=new gt,fhe=new gt,Fhe=new p;function Uhe(t,e,n){if(!t.enableCollision||!t.show)return;let i=t._addHeightCallbacks,o=e.boundingSphere;for(let a of i){if(a.invoked||e._wasSelectedLastFrame)continue;let s=a.ellipsoid,l=gt.clone(a.positionCartographic,Whe),r=gt.fromCartesian(o.center,s,fhe);c(r)&&(l.height=r.height);let d=gt.toCartesian(l,s,Fhe);p.distance(d,o.center)<=o.radius&&n.afterRender.push(()=>{c(a.callback)&&a.callback(l),a.invoked=!1})}}function Ghe(t,e){Rhe(t);let n=t._processingQueue,{cacheBytes:i,maximumCacheOverflowBytes:o,statistics:a}=t,s=i+o,l=!1;for(let r=0;rs){l=!0;break}let d=n[r];try{d.process(t,e),d.contentReady&&(--a.numberOfTilesProcessing,t.tileLoad.raiseEvent(d))}catch(m){--a.numberOfTilesProcessing,IFt(m,t,d)}}t.totalMemoryUsageInBytes0&&Ahe(t)}function Ahe(t){t._memoryAdjustedScreenSpaceError*=1.02;let e=t._processingQueue;for(let n=0;n{t.isDestroyed()||(t._error=m)})}function jde(t,e){if(!c(t._va)){let n=t._startEllipsoidNormals,i=t._endEllipsoidNormals,o=t._startPositionAndHeights,a=t._endPositionAndHeights,s=t._startFaceNormalAndVertexCornerIds,l=t._endFaceNormalAndHalfWidths,r=t._vertexBatchIds,d=t._indices,m=n.byteLength+i.byteLength;m+=o.byteLength+a.byteLength,m+=s.byteLength+l.byteLength,m+=r.byteLength+d.byteLength,t._trianglesLength=d.length/3,t._geometryByteLength=m;let h=we.createVertexBuffer({context:e,typedArray:n,usage:ce.STATIC_DRAW}),u=we.createVertexBuffer({context:e,typedArray:i,usage:ce.STATIC_DRAW}),R=we.createVertexBuffer({context:e,typedArray:o,usage:ce.STATIC_DRAW}),V=we.createVertexBuffer({context:e,typedArray:a,usage:ce.STATIC_DRAW}),F=we.createVertexBuffer({context:e,typedArray:s,usage:ce.STATIC_DRAW}),U=we.createVertexBuffer({context:e,typedArray:l,usage:ce.STATIC_DRAW}),G=we.createVertexBuffer({context:e,typedArray:r,usage:ce.STATIC_DRAW}),A=we.createIndexBuffer({context:e,typedArray:d,usage:ce.STATIC_DRAW,indexDatatype:d.BYTES_PER_ELEMENT===2?re.UNSIGNED_SHORT:re.UNSIGNED_INT}),S=[{index:pF.startEllipsoidNormal,vertexBuffer:h,componentDatatype:it.FLOAT,componentsPerAttribute:3},{index:pF.endEllipsoidNormal,vertexBuffer:u,componentDatatype:it.FLOAT,componentsPerAttribute:3},{index:pF.startPositionAndHeight,vertexBuffer:R,componentDatatype:it.FLOAT,componentsPerAttribute:4},{index:pF.endPositionAndHeight,vertexBuffer:V,componentDatatype:it.FLOAT,componentsPerAttribute:4},{index:pF.startFaceNormalAndVertexCorner,vertexBuffer:F,componentDatatype:it.FLOAT,componentsPerAttribute:4},{index:pF.endFaceNormalAndHalfWidth,vertexBuffer:U,componentDatatype:it.FLOAT,componentsPerAttribute:4},{index:pF.a_batchId,vertexBuffer:G,componentDatatype:it.UNSIGNED_SHORT,componentsPerAttribute:1}];t._va=new Ki({context:e,attributes:S,indexBuffer:A}),t._positions=void 0,t._widths=void 0,t._counts=void 0,t._ellipsoid=void 0,t._minimumHeight=void 0,t._maximumHeight=void 0,t._rectangle=void 0,t._transferrableBatchIds=void 0,t._packedBuffer=void 0,t._startEllipsoidNormals=void 0,t._endEllipsoidNormals=void 0,t._startPositionAndHeights=void 0,t._startFaceNormalAndVertexCornerIds=void 0,t._endPositionAndHeights=void 0,t._endFaceNormalAndHalfWidths=void 0,t._vertexBatchIds=void 0,t._indices=void 0}}var xX=new L,Yft=new p;function qde(t,e){c(t._uniformMap)||(t._uniformMap={u_modifiedModelView:function(){let n=e.uniformState.view;return L.clone(n,xX),L.multiplyByPoint(xX,t._center,Yft),L.setTranslation(xX,Yft,xX),xX},u_highlightColor:function(){return t._highlightColor},u_minimumMaximumVectorHeights:function(){return t._minimumMaximumVectorHeights}})}function xft(t){return he.fromCache({cull:{enabled:!0,face:so.FRONT},blending:Pn.PRE_MULTIPLIED_ALPHA_BLEND,depthMask:!1,stencilTest:{enabled:t,frontFunction:Li.EQUAL,frontOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.KEEP},backFunction:Li.EQUAL,backOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.KEEP},reference:gn.CESIUM_3D_TILE_MASK,mask:gn.CESIUM_3D_TILE_MASK}})}function $de(t){c(t._rs)||(t._rs=xft(!1),t._rs3DTiles=xft(!0))}function tce(t,e){if(c(t._sp))return;let n=t._batchTable,i=n.getVertexShaderCallback(!1,"a_batchId",void 0)(kX),o=n.getFragmentShaderCallback(!1,void 0,!0)(YX),a=new Ze({defines:["VECTOR_TILE",In.isInternetExplorer()?"":"CLIP_POLYLINE"],sources:[Uh,i]}),s=new Ze({defines:["VECTOR_TILE"],sources:[o]});t._sp=xn.fromCache({context:e,vertexShaderSource:a,fragmentShaderSource:s,attributeLocations:pF})}function ece(t,e){let n=t._command;if(!c(t._command)){let o=t._batchTable.getUniformMapCallback()(t._uniformMap);n=t._command=new Ee({owner:t,vertexArray:t._va,renderState:t._rs,shaderProgram:t._sp,uniformMap:o,boundingVolume:t._boundingVolume,pass:Pt.TERRAIN_CLASSIFICATION,pickId:t._batchTable.getPickId()});let a=Ee.shallowClone(n,n.derivedCommands.tileset);a.renderState=t._rs3DTiles,a.pass=Pt.CESIUM_3D_TILE_CLASSIFICATION,n.derivedCommands.tileset=a}let i=t._classificationType;(i===Ji.TERRAIN||i===Ji.BOTH)&&e.commandList.push(n),(i===Ji.CESIUM_3D_TILE||i===Ji.BOTH)&&e.commandList.push(n.derivedCommands.tileset)}F0.prototype.getPositions=function(t){return _A.getPolylinePositions(this,t)};F0.prototype.createFeatures=function(t,e){let n=this._batchIds,i=n.length;for(let o=0;o{t.isDestroyed()||(t._error=e)})}F0.prototype.update=function(t){let e=t.context;if(!this._ready){if(c(this._promise)||(this._promise=sce(this).then(zde(this,e))),c(this._error)){let i=this._error;throw this._error=void 0,i}return}qde(this,e),tce(this,e),$de(this);let n=t.passes;(n.render||n.pick)&&ece(this,t)};F0.prototype.isDestroyed=function(){return!1};F0.prototype.destroy=function(){return this._va=this._va&&this._va.destroy(),this._sp=this._sp&&this._sp.destroy(),At(this)};var XX=F0;var eei=b(W(),1);var mtt=32767,lce=new gt,rce=new p;function dce(t,e,n,i,o){let a=t.length/3,s=t.subarray(0,a),l=t.subarray(a,2*a),r=t.subarray(2*a,3*a);Ni.zigZagDeltaDecode(s,l,r);let d=new Float64Array(t.length);for(let m=0;m0&&c(t.POLYGON_BATCH_IDS)){let u=e.byteOffset+t.POLYGON_BATCH_IDS.byteOffset;n=new Uint16Array(e.buffer,u,s)}if(l>0&&c(t.POLYLINE_BATCH_IDS)){let u=e.byteOffset+t.POLYLINE_BATCH_IDS.byteOffset;i=new Uint16Array(e.buffer,u,l)}if(r>0&&c(t.POINT_BATCH_IDS)){let u=e.byteOffset+t.POINT_BATCH_IDS.byteOffset;o=new Uint16Array(e.buffer,u,r)}let d=c(n)||c(i)||c(o),m=s>0&&!c(n)||l>0&&!c(i)||r>0&&!c(o);if(d&&m)throw new Tt("If one group of batch ids is defined, then all batch ids must be defined");if(!c(n)&&!c(i)&&!c(o)){let u=0;if(!c(n)&&s>0)for(n=new Uint16Array(s),a=0;a0)for(i=new Uint16Array(l),a=0;a0)for(o=new Uint16Array(r),a=0;a0&&(G=ts(i,n,d),n+=d,m>0&&(A=new Uint8Array(e,n,m),A=new Uint8Array(A),n+=m));let S=f(F.POLYGONS_LENGTH,0),g=f(F.POLYLINES_LENGTH,0),C=f(F.POINTS_LENGTH,0),y=S+g+C,Y=new wb(t,y,G,A,cce(t));if(t._batchTable=Y,y===0)return;let Q=new Fu(F,U),J=Q.getGlobalProperty("REGION");if(!c(J))throw new Tt("Feature table global property: REGION must be defined");let M=Gt.unpack(J),Z=J[4],E=J[5],I=t._tile.computedTransform,B=Q.getGlobalProperty("RTC_CENTER",it.FLOAT,3);c(B)?(B=p.unpack(B),L.multiplyByPoint(I,B,B)):(B=Gt.center(M),B.height=k.lerp(Z,E,.5),B=mt.WGS84.cartographicToCartesian(B));let X=mce(F,U);if(n+=(4-n%4)%4,S>0){Q.featuresLength=S;let _=f(Q.getPropertyArray("POLYGON_COUNTS",it.UNSIGNED_INT,1),Q.getPropertyArray("POLYGON_COUNT",it.UNSIGNED_INT,1));if(!c(_))throw new Tt("Feature table property: POLYGON_COUNTS must be defined when POLYGONS_LENGTH is greater than 0");let P=f(Q.getPropertyArray("POLYGON_INDEX_COUNTS",it.UNSIGNED_INT,1),Q.getPropertyArray("POLYGON_INDEX_COUNT",it.UNSIGNED_INT,1));if(!c(P))throw new Tt("Feature table property: POLYGON_INDEX_COUNTS must be defined when POLYGONS_LENGTH is greater than 0");let w=_.reduce(function(q,at){return q+at*2},0),z=P.reduce(function(q,at){return q+at},0),H=new Uint32Array(e,n,z);n+=h;let nt=new Uint16Array(e,n,w);n+=u;let $,dt;c(F.POLYGON_MINIMUM_HEIGHTS)&&c(F.POLYGON_MAXIMUM_HEIGHTS)&&($=Q.getPropertyArray("POLYGON_MINIMUM_HEIGHTS",it.FLOAT,1),dt=Q.getPropertyArray("POLYGON_MAXIMUM_HEIGHTS",it.FLOAT,1)),t._polygons=new yX({positions:nt,counts:_,indexCounts:P,indices:H,minimumHeight:Z,maximumHeight:E,polygonMinimumHeights:$,polygonMaximumHeights:dt,center:B,rectangle:M,boundingVolume:t.tile.boundingVolume.boundingVolume,batchTable:Y,batchIds:X.polygons,modelMatrix:I})}if(g>0){Q.featuresLength=g;let _=f(Q.getPropertyArray("POLYLINE_COUNTS",it.UNSIGNED_INT,1),Q.getPropertyArray("POLYLINE_COUNT",it.UNSIGNED_INT,1));if(!c(_))throw new Tt("Feature table property: POLYLINE_COUNTS must be defined when POLYLINES_LENGTH is greater than 0");let P=Q.getPropertyArray("POLYLINE_WIDTHS",it.UNSIGNED_SHORT,1);if(!c(P)){P=new Uint16Array(g);for(let dt=0;dt0){let _=new Uint16Array(e,n,C*3);n+=V,t._points=new NX({positions:_,batchIds:X.points,minimumHeight:Z,maximumHeight:E,rectangle:M,batchTable:Y})}}function htt(t){let e=t.featuresLength;if(!c(t._features)&&e>0){let n=new Array(e);c(t._polygons)&&t._polygons.createFeatures(t,n),c(t._polylines)&&t._polylines.createFeatures(t,n),c(t._points)&&t._points.createFeatures(t,n),t._features=n}}Eu.prototype.hasProperty=function(t,e){return this._batchTable.hasProperty(t,e)};Eu.prototype.getFeature=function(t){return c(this._features)||htt(this),this._features[t]};Eu.prototype.applyDebugSettings=function(t,e){c(this._polygons)&&this._polygons.applyDebugSettings(t,e),c(this._polylines)&&this._polylines.applyDebugSettings(t,e),c(this._points)&&this._points.applyDebugSettings(t,e)};Eu.prototype.applyStyle=function(t){c(this._features)||htt(this),c(this._polygons)&&this._polygons.applyStyle(t,this._features),c(this._polylines)&&this._polylines.applyStyle(t,this._features),c(this._points)&&this._points.applyStyle(t,this._features)};Eu.prototype.update=function(t,e){let n=!0;c(this._polygons)&&(this._polygons.classificationType=this._tileset.classificationType,this._polygons.debugWireframe=this._tileset.debugWireframe,this._polygons.update(e),n=n&&this._polygons.ready),c(this._polylines)&&(this._polylines.update(e),n=n&&this._polylines.ready),c(this._points)&&(this._points.update(e),n=n&&this._points.ready),c(this._batchTable)&&n&&(c(this._features)||htt(this),this._batchTable.update(t,e),this._ready=!0)};Eu.prototype.pick=function(t,e,n){};Eu.prototype.getPolylinePositions=function(t){let e=this._polylines;if(c(e))return e.getPositions(t)};Eu.prototype.isDestroyed=function(){return!1};Eu.prototype.destroy=function(){return this._polygons=this._polygons&&this._polygons.destroy(),this._polylines=this._polylines&&this._polylines.destroy(),this._points=this._points&&this._points.destroy(),this._batchTable=this._batchTable&&this._batchTable.destroy(),At(this)};function uce(t,e,n,i,o,a){let s=e.length,l=0;for(let r=0;r=0?i[a]:void 0}var HA=bce;var pni=b(W(),1);var sni=b(W(),1);function A0(t){t=f(t,f.EMPTY_OBJECT);let e=t.tile,n=t.class;this._class=n,this._properties=e.properties,this._extensions=e.extensions,this._extras=e.extras}Object.defineProperties(A0.prototype,{class:{get:function(){return this._class}},extras:{get:function(){return this._extras}},extensions:{get:function(){return this._extensions}}});A0.prototype.hasProperty=function(t){return Yi.hasProperty(t,this._properties,this._class)};A0.prototype.hasPropertyBySemantic=function(t){return Yi.hasPropertyBySemantic(t,this._properties,this._class)};A0.prototype.getPropertyIds=function(t){return Yi.getPropertyIds(this._properties,this._class,t)};A0.prototype.getProperty=function(t){return Yi.getProperty(t,this._properties,this._class)};A0.prototype.setProperty=function(t,e){return Yi.setProperty(t,e,this._properties,this._class)};A0.prototype.getPropertyBySemantic=function(t){return Yi.getPropertyBySemantic(t,this._properties,this._class)};A0.prototype.setPropertyBySemantic=function(t,e){return Yi.setPropertyBySemantic(t,e,this._properties,this._class)};var _X=A0;function Vtt(t,e){let n=co(e,"3DTILES_metadata")?e.extensions["3DTILES_metadata"]:e.metadata;if(!c(n))return;if(!c(t.schema)){Vtt._oneTimeWarning("findTileMetadata-missing-root-schema","Could not find a metadata schema for tile metadata. For tilesets that contain external tilesets, make sure the schema is added to the root tileset.json.");return}let i=f(t.schema.classes,f.EMPTY_OBJECT);if(c(n.class)){let o=i[n.class];return new _X({tile:n,class:o})}}Vtt._oneTimeWarning=Gn;var DX=Vtt;var Yni=b(W(),1);var fni=b(W(),1);function Wce(t){let e=new Uint8Array(t),n=mu(e);if(n==="glTF"&&(n="glb"),nr.isBinaryFormat(n))return{contentType:n,binaryPayload:e};let i=fce(e);if(c(i.root))return{contentType:nr.EXTERNAL_TILESET,jsonPayload:i};if(c(i.asset))return{contentType:nr.GLTF,jsonPayload:i};if(c(i.tileAvailability))return{contentType:nr.IMPLICIT_SUBTREE_JSON,jsonPayload:i};if(c(i.type))return{contentType:nr.GEOJSON,jsonPayload:i};if(c(i.voxelTable))return{contentType:nr.VOXEL_JSON,jsonPayload:i};throw new Tt("Invalid tile content.")}function fce(t){let e;try{e=ts(t)}catch{throw new Tt("Invalid tile content.")}return e}var dR=Wce;function qp(t,e,n,i){this._tileset=t,this._tile=e,this._tilesetResource=n,this._contents=[],this._contentsCreated=!1;let o=c(i.contents)?i.contents:i.content;this._innerContentHeaders=o,this._requestsInFlight=0,this._cancelCount=0;let a=this._innerContentHeaders.length;this._arrayFetchPromises=new Array(a),this._requests=new Array(a),this._ready=!1,this._innerContentResources=new Array(a),this._serverKeys=new Array(a);for(let s=0;sAce(t,a,s)),o=await Promise.all(i);return t._contentsCreated=!0,t._contents=o.filter(c),o}async function Ace(t,e,n){if(c(e))try{let i=dR(e);if(i.contentType===nr.EXTERNAL_TILESET)throw new Tt("External tilesets are disallowed inside multiple contents");t._disableSkipLevelOfDetail=t._disableSkipLevelOfDetail||i.contentType===nr.GEOMETRY||i.contentType===nr.VECTOR;let o=t._tileset,a=t._innerContentResources[n],s=t._tile,l,r=DA[i.contentType];c(i.binaryPayload)?l=await Promise.resolve(r(o,s,a,i.binaryPayload.buffer,0)):l=await Promise.resolve(r(o,s,a,i.jsonPayload));let d=t._innerContentHeaders[n];if(s.hasImplicitContentMetadata){let h=s.implicitSubtree,u=s.implicitCoordinates;l.metadata=h.getContentMetadataView(u,n)}else s.hasImplicitContent||(l.metadata=OA(o,d));let m=HA(o,d);return c(m)&&(l.group=new sA({metadata:m})),l}catch(i){Lft(t,n,i)}}function Lft(t,e,n){let i=t._tileset,o=t._innerContentResources[e].url,a=c(n.message)?n.message:n.toString();i.tileFailed.numberOfListeners>0?i.tileFailed.raiseEvent({url:o,message:a}):(console.log(`A content failed to load: ${o}`),console.log(`Error: ${a}`))}qp.prototype.cancelRequests=function(){for(let t=0;tl?R=k.TWO_PI-r+l:R=l-r;let F=Math.ceil(R/e)+1,U=Math.ceil(V/e)+1,G=R/(F-1),A=V/(U-1),S=Gt.northwest(t,a),g=Gt.center(t,gce);(n!==0||i!==0)&&(g.longitude=0;V--)ir.computePosition(e,n,!1,R,V,F),h[u++]=F.x,h[u++]=F.y,h[u++]=F.z;for(V=0,R=i-2;R>0;R--)ir.computePosition(e,n,!1,R,V,F),h[u++]=F.x,h[u++]=F.y,h[u++]=F.z;let U=h.length/3*2,G=re.createTypedArray(h.length/3,U),A=0;for(let g=0;g0){tV.longitude=(e.west+e.east)*.5,tV.latitude=d;let F=n.cartographicToCartesian(tV,UC.origin);p.clone(r,UC.direction);let U=Kn.fromPointNormal(t.southwestCornerCartesian,t.westNormal,Kft);no.rayPlane(UC,U,t.southwestCornerCartesian),m=n.geodeticSurfaceNormal(F,ZP)}else m=n.geodeticSurfaceNormalCartographic(Gt.southeast(e),ZP);let h=p.cross(m,l,vft);p.normalize(h,t.southNormal);let u=e.north,R;if(u<0){tV.longitude=(e.west+e.east)*.5,tV.latitude=u;let F=n.cartographicToCartesian(tV,UC.origin);p.negate(r,UC.direction);let U=Kn.fromPointNormal(t.northeastCornerCartesian,t.eastNormal,Kft);no.rayPlane(UC,U,t.northeastCornerCartesian),R=n.geodeticSurfaceNormal(F,ZP)}else R=n.geodeticSurfaceNormalCartographic(Gt.northwest(e),ZP);let V=p.cross(l,R,vft);p.normalize(V,t.northNormal)}var Jce=new p,Lce=new p,Mce=new p(0,-1,0),_ce=new p(0,0,-1),zft=new p;function Dce(t,e){let n=e.camera,i=n.positionWC,o=n.positionCartographic,a=0;if(!Gt.contains(t.rectangle,o)){let d=t.southwestCornerCartesian,m=t.northeastCornerCartesian,h=t.westNormal,u=t.southNormal,R=t.eastNormal,V=t.northNormal;e.mode!==Vt.SCENE3D&&(d=e.mapProjection.project(Gt.southwest(t.rectangle),Jce),d.z=d.y,d.y=d.x,d.x=0,m=e.mapProjection.project(Gt.northeast(t.rectangle),Lce),m.z=m.y,m.y=m.x,m.x=0,h=Mce,R=p.UNIT_Y,u=_ce,V=p.UNIT_Z);let F=p.subtract(i,d,zft),U=p.dot(F,h),G=p.dot(F,u),A=p.subtract(i,m,zft),S=p.dot(A,R),g=p.dot(A,V);U>0?a+=U*U:S>0&&(a+=S*S),G>0?a+=G*G:g>0&&(a+=g*g)}let s,l,r;if(e.mode===Vt.SCENE3D?(s=o.height,l=t.minimumHeight,r=t.maximumHeight):(s=i.x,l=0,r=0),s>r){let d=s-r;a+=d*d}else if(s0?(n.push(0),i.push(this._planeVertices[0]),o=this._edgeNormals[0]):Kn.getPointDistance(this._boundingPlanes[1],e)>0&&(n.push(1),i.push(this._planeVertices[1]),o=this._edgeNormals[1]);let a,s;for(a=0;a<4;a++)s=2+a,Kn.getPointDistance(this._boundingPlanes[s],e)>0&&(n.push(s),i.push(this._planeVertices[s]),o=this._edgeNormals[s]);if(n.length===0)return 0;let l,r;if(n.length===1)return r=this._boundingPlanes[n[0]],l=gtt(Kn.projectPointOntoPlane(r,e,Ttt),i[0],r,o),p.distance(l,e);if(n.length===2){if(n[0]===0){let u=[this._vertices[4*n[0]+(n[1]-2)],this._vertices[4*n[0]+(n[1]-2+1)%4]];return l=iFt(e,u[0],u[1]),p.distance(l,e)}let m=Number.MAX_VALUE,h;for(a=0;a<2;a++)r=this._boundingPlanes[n[a]],l=gtt(Kn.projectPointOntoPlane(r,e,Ttt),i[a],r,this._edgeNormals[n[a]]),h=p.distanceSquared(l,e),h3)return l=gtt(Kn.projectPointOntoPlane(this._boundingPlanes[1],e,Ttt),this._planeVertices[1],this._boundingPlanes[1],this._edgeNormals[1]),p.distance(l,e);let d=n[1]===2&&n[2]===5?0:1;return n[0]===0?p.distance(e,this._vertices[(n[1]-2+d)%4]):p.distance(e,this._vertices[4+(n[1]-2+d)%4])};var sme=new p,lme=new p;function iFt(t,e,n){let i=p.subtract(n,e,sme),o=p.subtract(t,e,lme),a=p.dot(i,o);if(a<=0)return e;let s=p.dot(i,i);return a>=s?n:(a=a/s,new p((1-a)*e.x+a*n.x,(1-a)*e.y+a*n.y,(1-a)*e.z+a*n.z))}var rme=new Kn(p.UNIT_X,0);function gtt(t,e,n,i){let o=Number.MAX_VALUE,a,s,l;for(let r=0;r0&&(V=!0,h+=d),s1||co(n,"3DTILES_multiple_contents"),s=o&&!a?n.contents[0]:n.content;this._contentHeader=s,this.transform=c(n.transform)?L.unpack(n.transform):L.clone(L.IDENTITY);let l=c(i)?i.computedTransform:t.modelMatrix,r=L.multiply(l,this.transform,new L),d=c(i)?i._initialTransform:L.IDENTITY;this._initialTransform=L.multiply(d,this.transform,new L),this.computedTransform=r,this.metadata=DX(t,n),this._verticalExaggeration=1,this._verticalExaggerationRelativeHeight=0,this._boundingVolume=this.createBoundingVolume(n.boundingVolume,r),this._boundingVolume2D=void 0;let m;c(s)&&c(s.boundingVolume)&&(m=this.createBoundingVolume(s.boundingVolume,r)),this._contentBoundingVolume=m,this._contentBoundingVolume2D=void 0;let h;c(n.viewerRequestVolume)&&(h=this.createBoundingVolume(n.viewerRequestVolume,r)),this._viewerRequestVolume=h,this.geometricError=n.geometricError,this._geometricError=n.geometricError,c(this._geometricError)||(this._geometricError=c(i)?i._geometricError:t._geometricError,fs._deprecationWarning("geometricErrorUndefined","Required property geometricError is undefined for this tile. Using parent's geometric error instead.")),this.updateGeometricErrorScale();let u;c(n.refine)?((n.refine==="replace"||n.refine==="add")&&fs._deprecationWarning("lowercase-refine",`This tile uses a lowercase refine "${n.refine}". Instead use "${n.refine.toUpperCase()}".`),u=n.refine.toUpperCase()==="REPLACE"?ss.REPLACE:ss.ADD):c(i)?u=i.refine:u=ss.REPLACE,this.refine=u,this.children=[],this.parent=i;let R,V=!1,F,U,G;if(e=te.createIfNeeded(e),a)F=rs.UNLOADED,U=e.clone();else if(c(s)){let C=s.uri;c(s.url)&&(fs._deprecationWarning("contentUrl",'This tileset JSON uses the "content.url" property which has been deprecated. Use "content.uri" instead.'),C=s.url),C===""?(fs._deprecationWarning("contentUriEmpty","content.uri property is an empty string, which creates a circular dependency, making this tileset invalid. Omit the content property instead"),R=new WC(t,this),V=!0,F=rs.READY):(F=rs.UNLOADED,U=e.getDerivedResource({url:C}),G=xd.getServerKey(U.getUrlComponent()))}else R=new WC(t,this),V=!0,F=rs.READY;this._content=R,this._contentResource=U,this._contentState=F,this._expiredContent=void 0,this._serverKey=G,this.hasEmptyContent=V,this.hasTilesetContent=!1,this.hasImplicitContent=!1,this.hasImplicitContentMetadata=!1,this.hasMultipleContents=a,this.cacheNode=void 0;let A=n.expire,S,g;c(A)&&(S=A.duration,c(A.date)&&(g=rt.fromIso8601(A.date))),this.expireDuration=S,this.expireDate=g,this.lastStyleTime=0,this._optimChildrenWithinParent=jp.NOT_COMPUTED,this.clippingPlanesDirty=!1,this.clippingPolygonsDirty=!1,this.priorityDeferred=!1,this.implicitTileset=void 0,this.implicitCoordinates=void 0,this.implicitSubtree=void 0,this._distanceToCamera=0,this._centerZDepth=0,this._screenSpaceError=0,this._screenSpaceErrorProgressiveResolution=0,this._visibilityPlaneMask=0,this._visible=!1,this._inRequestVolume=!1,this._finalResolution=!0,this._depth=0,this._stackLength=0,this._selectionDepth=0,this._updatedVisibilityFrame=0,this._touchedFrame=0,this._visitedFrame=0,this._selectedFrame=0,this._wasSelectedLastFrame=!1,this._requestedFrame=0,this._ancestorWithContent=void 0,this._ancestorWithContentAvailable=void 0,this._refines=!1,this._shouldSelect=!1,this._isClipped=!0,this._isClippedByPolygon=!1,this._clippingPlanesState=0,this._clippingPolygonsState=0,this._debugBoundingVolume=void 0,this._debugContentBoundingVolume=void 0,this._debugViewerRequestVolume=void 0,this._debugColor=v.fromRandom({alpha:1}),this._debugColorizeTiles=!1,this._priority=0,this._priorityHolder=this,this._priorityProgressiveResolution=!1,this._priorityProgressiveResolutionScreenSpaceErrorLeaf=!1,this._priorityReverseScreenSpaceError=0,this._foveatedFactor=0,this._wasMinPriorityChild=!1,this._loadTimestamp=new rt,this._commandsLength=0,this._color=void 0,this._colorDirty=!1,this._request=void 0}fs._deprecationWarning=ur;Object.defineProperties(fs.prototype,{tileset:{get:function(){return this._tileset}},content:{get:function(){return this._content}},boundingVolume:{get:function(){return this._boundingVolume}},contentBoundingVolume:{get:function(){return f(this._contentBoundingVolume,this._boundingVolume)}},boundingSphere:{get:function(){return this._boundingVolume.boundingSphere}},isVisible:{get:function(){return this._visible&&this._inRequestVolume}},extras:{get:function(){return this._header.extras}},color:{get:function(){return c(this._color)||(this._color=new v),v.clone(this._color)},set:function(t){this._color=v.clone(t,this._color),this._colorDirty=!0}},hasRenderableContent:{get:function(){return!this.hasEmptyContent&&!this.hasTilesetContent&&!this.hasImplicitContent}},contentAvailable:{get:function(){return this.contentReady&&this.hasRenderableContent||c(this._expiredContent)&&!this.contentFailed}},contentReady:{get:function(){return this._contentState===rs.READY}},contentUnloaded:{get:function(){return this._contentState===rs.UNLOADED}},hasUnloadedRenderableContent:{get:function(){return this.hasRenderableContent&&this.contentUnloaded}},contentExpired:{get:function(){return this._contentState===rs.EXPIRED}},contentFailed:{get:function(){return this._contentState===rs.FAILED}},commandsLength:{get:function(){return this._commandsLength}}});var uF=new p;function ume(t,e){let{tileset:n,boundingSphere:i}=t,{radius:o,center:a}=i,{camera:s}=e,l=p.multiplyByScalar(s.directionWC,t._centerZDepth,uF),r=p.add(s.positionWC,l,uF),d=p.subtract(r,a,uF);if(p.magnitude(d)>o){let g=p.normalize(d,uF),C=p.multiplyByScalar(g,o,uF),y=p.add(a,C,uF),Y=p.subtract(y,s.positionWC,uF),Q=p.normalize(Y,uF);t._foveatedFactor=1-Math.abs(p.dot(s.directionWC,Q))}else t._foveatedFactor=0;let u=t.refine===ss.REPLACE,R=n.isSkippingLevelOfDetail;if(u&&!R||!n.foveatedScreenSpaceError||n.foveatedConeSize===1||t._priorityProgressiveResolution&&u&&R||n._pass===ns.PRELOAD_FLIGHT||n._pass===ns.PRELOAD)return!1;let V=1-Math.cos(s.frustum.fov*.5),F=n.foveatedConeSize*V;if(t._foveatedFactor<=F)return!1;let U=V-F,G=k.clamp((t._foveatedFactor-F)/U,0,1),A=n.foveatedInterpolationCallback(n.foveatedMinimumScreenSpaceErrorRelaxation,n.memoryAdjustedScreenSpaceError,G),S=t._screenSpaceError===0&&c(t.parent)?t.parent._screenSpaceError*.5:t._screenSpaceError;return n.memoryAdjustedScreenSpaceError-A<=S}var cFt=new rt;fs.prototype.getScreenSpaceError=function(t,e,n){let i=this._tileset,o=f(n,1),a=c(this.parent)?this.parent.geometricError:i._scaledGeometricError,s=e?a:this.geometricError;if(s===0)return 0;let{camera:l,context:r}=t,d=l.frustum,m=r.drawingBufferWidth,h=r.drawingBufferHeight*o,u;if(t.mode===Vt.SCENE2D||d instanceof wn){let R=d.offCenterFrustum;c(R)&&(d=R);let V=Math.max(d.top-d.bottom,d.right-d.left)/Math.max(m,h);u=s/V}else{let R=Math.max(this._distanceToCamera,k.EPSILON7),V=d.sseDenominator;if(u=s*h/(R*V),i.dynamicScreenSpaceError){let F=i._dynamicScreenSpaceErrorComputedDensity,U=i.dynamicScreenSpaceErrorFactor,G=k.fog(R,F)*U;u-=G}}return u/=t.pixelRatio,u};function Zme(t,e){if(t.progressiveResolutionHeightFraction<=0||t.progressiveResolutionHeightFraction>.5)return!1;let n=t.memoryAdjustedScreenSpaceError,i=e._screenSpaceErrorProgressiveResolution>n;e._priorityProgressiveResolutionScreenSpaceErrorLeaf=!1;let o=e.parent,a=e._screenSpaceErrorProgressiveResolution<=n,s=c(o)&&o._screenSpaceErrorProgressiveResolution>n;return a&&s&&(e._priorityProgressiveResolutionScreenSpaceErrorLeaf=!0,i=!0),i}function Rme(t,e){let n=e.parent,o=c(n)&&(!t.isSkippingLevelOfDetail||e._screenSpaceError===0||n.hasTilesetContent||n.hasImplicitContent)?n._screenSpaceError:e._screenSpaceError;return t.root._screenSpaceError-o}fs.prototype.updateVisibility=function(t){let{parent:e,tileset:n}=this;if(this._updatedVisibilityFrame===n._updatedVisibilityFrame)return;let i=c(e)?e.computedTransform:n.modelMatrix,o=c(e)?e._visibilityPlaneMask:Jl.MASK_INDETERMINATE;this.updateTransform(i,t),this._distanceToCamera=this.distanceToTile(t),this._centerZDepth=this.distanceToTileCenter(t),this._screenSpaceError=this.getScreenSpaceError(t,!1),this._screenSpaceErrorProgressiveResolution=this.getScreenSpaceError(t,!1,n.progressiveResolutionHeightFraction),this._visibilityPlaneMask=this.visibility(t,o),this._visible=this._visibilityPlaneMask!==Jl.MASK_OUTSIDE,this._inRequestVolume=this.insideViewerRequestVolume(t),this._priorityReverseScreenSpaceError=Rme(n,this),this._priorityProgressiveResolution=Zme(n,this),this.priorityDeferred=ume(this,t),this._updatedVisibilityFrame=n._updatedVisibilityFrame};fs.prototype.updateExpiration=function(){if(c(this.expireDate)&&this.contentReady&&!this.hasEmptyContent&&!this.hasMultipleContents){let t=rt.now(cFt);rt.lessThan(this.expireDate,t)&&(this._contentState=rs.EXPIRED,this._expiredContent=this._content)}};function bme(t){if(!c(t.expireDuration))return;let e=rt.now(cFt);rt.addSeconds(e,t.expireDuration,e),c(t.expireDate)?rt.lessThan(t.expireDate,e)&&rt.clone(e,t.expireDate):t.expireDate=rt.clone(e)}function Wme(t){return function(){return t._priority}}fs.prototype.requestContent=function(){if(!this.hasEmptyContent)return this.hasMultipleContents?fme(this):Ume(this)};function fme(t){let e=t._content,n=t._tileset;if(!c(e)){let o=co(t._header,"3DTILES_multiple_contents")?t._header.extensions["3DTILES_multiple_contents"]:t._header;e=new OX(n,t,t._contentResource.clone(),o),t._content=e}let i=e.requestInnerContents();if(c(i))return t._contentState=rs.LOADING,i.then(o=>{if(!t.isDestroyed()&&c(o))return t._contentState=rs.PROCESSING,e}).catch(o=>{if(!t.isDestroyed())throw t._contentState=rs.FAILED,o})}async function Fme(t,e,n,i,o){let a=t._contentState;t._contentState=rs.LOADING,++e.statistics.numberOfPendingRequests;let s;try{s=await o}catch(l){if(--e.statistics.numberOfPendingRequests,t.isDestroyed())return;if(n.cancelled||n.state===qi.CANCELLED){t._contentState=a,++e.statistics.numberOfAttemptedRequests;return}throw t._contentState=rs.FAILED,l}if(t.isDestroyed()){--e.statistics.numberOfPendingRequests;return}if(n.cancelled||n.state===qi.CANCELLED){t._contentState=a,--e.statistics.numberOfPendingRequests,++e.statistics.numberOfAttemptedRequests;return}try{let l=await Gme(t,s);return--e.statistics.numberOfPendingRequests,t.isDestroyed()?void 0:(i&&(t.expireDate=void 0),t._content=l,t._contentState=rs.PROCESSING,l)}catch(l){if(--e.statistics.numberOfPendingRequests,t.isDestroyed())return;throw t._contentState=rs.FAILED,l}}function Ume(t){let e=t._contentResource.clone(),n=t.contentExpired;n&&e.setQueryParameters({expired:t.expireDate.toString()});let i=new us({throttle:!0,throttleByServer:!0,type:Xl.TILES3D,priorityFunction:Wme(t),serverKey:t._serverKey});t._request=i,e.request=i;let o=t._tileset,a=e.fetchArrayBuffer();if(!c(a)){++o.statistics.numberOfAttemptedRequests;return}return Fme(t,o,i,n,a)}async function Gme(t,e){let n=dR(e),i=t._tileset;i._disableSkipLevelOfDetail=i._disableSkipLevelOfDetail||n.contentType===nr.GEOMETRY||n.contentType===nr.VECTOR,(n.contentType===nr.IMPLICIT_SUBTREE||n.contentType===nr.IMPLICIT_SUBTREE_JSON)&&(t.hasImplicitContent=!0),n.contentType===nr.EXTERNAL_TILESET&&(t.hasTilesetContent=!0);let o,a=DA[n.contentType];if(t.isDestroyed())return;c(n.binaryPayload)?o=await Promise.resolve(a(i,t,t._contentResource,n.binaryPayload.buffer,0)):o=await Promise.resolve(a(i,t,t._contentResource,n.jsonPayload));let s=t._contentHeader;if(t.hasImplicitContentMetadata){let r=t.implicitSubtree,d=t.implicitCoordinates;o.metadata=r.getContentMetadataView(d,0)}else t.hasImplicitContent||(o.metadata=OA(i,s));let l=HA(i,s);return c(l)&&(o.group=new sA({metadata:l})),o}fs.prototype.cancelRequests=function(){this.hasMultipleContents?this._content.cancelRequests():this._request.cancel()};fs.prototype.unloadContent=function(){this.hasRenderableContent&&(this._content=this._content&&this._content.destroy(),this._contentState=rs.UNLOADED,this.lastStyleTime=0,this.clippingPlanesDirty=this._clippingPlanesState===0,this._clippingPlanesState=0,this.clippingPolygonsDirty=this._clippingPolygonsState===0,this._clippingPolygonsState=0,this._debugColorizeTiles=!1,this._debugBoundingVolume=this._debugBoundingVolume&&this._debugBoundingVolume.destroy(),this._debugContentBoundingVolume=this._debugContentBoundingVolume&&this._debugContentBoundingVolume.destroy(),this._debugViewerRequestVolume=this._debugViewerRequestVolume&&this._debugViewerRequestVolume.destroy())};var mFt=new Ft;function Itt(t,e){if(e.mode!==Vt.SCENE3D&&!c(t._boundingVolume2D)){let n=t._boundingVolume.boundingSphere,i=Ft.projectTo2D(n,e.mapProjection,mFt);t._boundingVolume2D=new E0(i.center,i.radius)}return e.mode!==Vt.SCENE3D?t._boundingVolume2D:t._boundingVolume}function Ame(t,e){if(e.mode!==Vt.SCENE3D&&!c(t._contentBoundingVolume2D)){let n=t._contentBoundingVolume.boundingSphere,i=Ft.projectTo2D(n,e.mapProjection,mFt);t._contentBoundingVolume2D=new E0(i.center,i.radius)}return e.mode!==Vt.SCENE3D?t._contentBoundingVolume2D:t._contentBoundingVolume}fs.prototype.visibility=function(t,e){let n=t.cullingVolume,i=Itt(this,t),o=this._tileset,a=o.clippingPlanes;if(c(a)&&a.enabled){let l=a.computeIntersectionWithBoundingVolume(i,o.clippingPlanesOriginMatrix);if(this._isClipped=l!==yn.INSIDE,l===yn.OUTSIDE)return Jl.MASK_OUTSIDE}let s=o.clippingPolygons;if(c(s)&&s.enabled){let l=s.computeIntersectionWithBoundingVolume(i);this._isClippedByPolygon=l!==yn.OUTSIDE}return n.computeVisibilityWithPlaneMask(i,e)};fs.prototype.contentVisibility=function(t){if(!c(this._contentBoundingVolume))return yn.INSIDE;if(this._visibilityPlaneMask===Jl.MASK_INSIDE)return yn.INSIDE;let e=t.cullingVolume,n=Ame(this,t),i=this._tileset,o=i.clippingPlanes;if(c(o)&&o.enabled){let s=o.computeIntersectionWithBoundingVolume(n,i.clippingPlanesOriginMatrix);if(this._isClipped=s!==yn.INSIDE,s===yn.OUTSIDE)return yn.OUTSIDE}let a=i.clippingPolygons;if(c(a)&&a.enabled){let s=a.computeIntersectionWithBoundingVolume(n);if(this._isClippedByPolygon=s!==yn.OUTSIDE,s===yn.INSIDE)return yn.OUTSIDE}return e.computeVisibility(n)};fs.prototype.distanceToTile=function(t){return Itt(this,t).distanceToCamera(t)};var Sme=new p;fs.prototype.distanceToTileCenter=function(t){let n=Itt(this,t).boundingVolume,i=p.subtract(n.center,t.camera.positionWC,Sme);return p.dot(t.camera.directionWC,i)};fs.prototype.insideViewerRequestVolume=function(t){let e=this._viewerRequestVolume;return!c(e)||e.distanceToCamera(t)===0};var hFt=new ot,pFt=new p,Tme=new ot,Ntt=new p,VFt=new Gt,uFt=new ci,Ctt=new L;function gme(t,e,n){let i=p.fromElements(t[0],t[1],t[2],Ntt),o=ot.fromArray(t,3,Tme);i=L.multiplyByPoint(e,i,i);let a=L.getMatrix3(e,hFt);return o=ot.multiply(a,o,o),c(n)?(n.update(i,o),n):new kh(i,o)}function Eme(t,e,n,i){let o=Gt.unpack(t,0,VFt),a=t[4],s=t[5],l=ci.fromRectangle(o,a,s,mt.WGS84,uFt),r=l.center,d=l.halfAxes;e=L.multiplyTransformation(e,L.inverseTransformation(n,Ctt),Ctt),r=L.multiplyByPoint(e,r,r);let m=L.getMatrix3(e,hFt);return d=ot.multiply(m,d,d),c(i)&&i instanceof kh?(i.update(r,d),i):new kh(r,d)}function Cme(t,e,n,i){if(!L.equalsEpsilon(e,n,k.EPSILON8))return Eme(t,e,n,i);let o=Gt.unpack(t,0,VFt);return c(i)?(i.rectangle=Gt.clone(o,i.rectangle),i.minimumHeight=t[4],i.maximumHeight=t[5],i.computeBoundingVolumes(mt.WGS84),i):new eV({rectangle:o,minimumHeight:t[4],maximumHeight:t[5]})}function Ime(t,e,n){let i=p.fromElements(t[0],t[1],t[2],Ntt),o=t[3];i=L.multiplyByPoint(e,i,i);let a=L.getScale(e,pFt),s=p.maximumComponent(a);return o*=s,c(n)?(n.update(i,o),n):new E0(i,o)}fs.prototype.createBoundingVolume=function(t,e,n){let i=this.metadata,o;if(c(i)&&(o=AA.parseBoundingVolumeSemantic("TILE",i)),c(o)&&(t=o),!c(t))throw new Tt("boundingVolume must be defined");if(co(t,"3DTILES_bounding_volume_S2"))return new PX(t.extensions["3DTILES_bounding_volume_S2"]);let{box:a,region:s,sphere:l}=t;if(c(a)){let r=gme(a,e,n);return this._verticalExaggeration!==1&&lFt(r,this._verticalExaggeration,this._verticalExaggerationRelativeHeight),r}if(c(s)){let r=Cme(s,e,this._initialTransform,n);return this._verticalExaggeration===1||(r instanceof kh?lFt(r,this._verticalExaggeration,this._verticalExaggerationRelativeHeight):(r.minimumHeight=Ps.getHeight(r.minimumHeight,this._verticalExaggeration,this._verticalExaggerationRelativeHeight),r.maximumHeight=Ps.getHeight(r.maximumHeight,this._verticalExaggeration,this._verticalExaggerationRelativeHeight),r.computeBoundingVolumes(mt.WGS84))),r}if(c(l)){let r=Ime(l,e,n);if(this._verticalExaggeration!==1){let d=Ps.getPosition(r.center,mt.WGS84,this._verticalExaggeration,this._verticalExaggerationRelativeHeight,Ntt),m=r.radius*this._verticalExaggeration;r.update(d,m)}return r}throw new Tt("boundingVolume must contain a sphere, region, or box")};var Nme=p.unpackArray(new Array(8*3).fill(0));function lFt(t,e,n){let i=t.boundingVolume.computeCorners(Nme).map(a=>Ps.getPosition(a,mt.WGS84,e,n,a)),o=ci.fromPoints(i,uFt);t.update(o.center,o.halfAxes)}fs.prototype.updateTransform=function(t,e){t=f(t,L.IDENTITY);let n=L.multiplyTransformation(t,this.transform,Ctt),i=!L.equals(n,this.computedTransform),o=c(e)&&(this._verticalExaggeration!==e.verticalExaggeration||this._verticalExaggerationRelativeHeight!==e.verticalExaggerationRelativeHeight);if(!i&&!o)return;i&&L.clone(n,this.computedTransform),o&&(this._verticalExaggeration=e.verticalExaggeration,this._verticalExaggerationRelativeHeight=e.verticalExaggerationRelativeHeight);let a=this._header,s=this._contentHeader;this._boundingVolume=this.createBoundingVolume(a.boundingVolume,this.computedTransform,this._boundingVolume),c(this._contentBoundingVolume)&&(this._contentBoundingVolume=this.createBoundingVolume(s.boundingVolume,this.computedTransform,this._contentBoundingVolume)),c(this._viewerRequestVolume)&&(this._viewerRequestVolume=this.createBoundingVolume(a.viewerRequestVolume,this.computedTransform,this._viewerRequestVolume)),this.updateGeometricErrorScale(),this._debugBoundingVolume=this._debugBoundingVolume&&this._debugBoundingVolume.destroy(),this._debugContentBoundingVolume=this._debugContentBoundingVolume&&this._debugContentBoundingVolume.destroy(),this._debugViewerRequestVolume=this._debugViewerRequestVolume&&this._debugViewerRequestVolume.destroy()};fs.prototype.updateGeometricErrorScale=function(){let t=L.getScale(this.computedTransform,pFt),e=p.maximumComponent(t);if(this.geometricError=this._geometricError*e,!c(this.parent)){let n=this._tileset;n._scaledGeometricError=n._geometricError*e}};function yme(t,e,n,i){if(!i.isRender)return;let o=c(t._contentHeader)&&c(t._contentHeader.boundingVolume),a=e.debugShowBoundingVolume||e.debugShowContentBoundingVolume&&!o;if(a){let r;t._finalResolution?t.hasRenderableContent?r=v.WHITE:r=v.DARKGRAY:r=v.YELLOW,c(t._debugBoundingVolume)||(t._debugBoundingVolume=t._boundingVolume.createDebugVolume(r)),t._debugBoundingVolume.update(n);let d=t._debugBoundingVolume.getGeometryInstanceAttributes("outline");d.color=En.toValue(r,d.color)}else!a&&c(t._debugBoundingVolume)&&(t._debugBoundingVolume=t._debugBoundingVolume.destroy());e.debugShowContentBoundingVolume&&o?(c(t._debugContentBoundingVolume)||(t._debugContentBoundingVolume=t._contentBoundingVolume.createDebugVolume(v.BLUE)),t._debugContentBoundingVolume.update(n)):!e.debugShowContentBoundingVolume&&c(t._debugContentBoundingVolume)&&(t._debugContentBoundingVolume=t._debugContentBoundingVolume.destroy()),e.debugShowViewerRequestVolume&&c(t._viewerRequestVolume)?(c(t._debugViewerRequestVolume)||(t._debugViewerRequestVolume=t._viewerRequestVolume.createDebugVolume(v.YELLOW)),t._debugViewerRequestVolume.update(n)):!e.debugShowViewerRequestVolume&&c(t._debugViewerRequestVolume)&&(t._debugViewerRequestVolume=t._debugViewerRequestVolume.destroy());let s=e.debugColorizeTiles&&!t._debugColorizeTiles||c(e._heatmap.tilePropertyName),l=!e.debugColorizeTiles&&t._debugColorizeTiles;s?(e._heatmap.colorize(t,n),t._debugColorizeTiles=!0,t.color=t._debugColor):l&&(t._debugColorizeTiles=!1,t.color=v.WHITE),t._colorDirty&&(t._colorDirty=!1,t._content.applyDebugSettings(!0,t._color)),l&&e.makeStyleDirty()}function Bme(t,e,n){let i=t._expiredContent;if(!t.hasMultipleContents&&c(i)){if(!t.contentReady){try{i.update(e,n)}catch{}return}t._expiredContent.destroy(),t._expiredContent=void 0}if(c(t.content))try{t.content.update(e,n)}catch(o){throw t._contentState=rs.FAILED,o}}function Qme(t,e){let n=e.clippingPlanes,i=0;c(n)&&t._isClipped&&n.enabled&&(i=n.clippingPlanesState),i!==t._clippingPlanesState&&(t._clippingPlanesState=i,t.clippingPlanesDirty=!0)}function kme(t,e){let n=e.clippingPolygons,i=0;c(n)&&t._isClippedByPolygon&&n.enabled&&(i=n.clippingPolygonsState),i!==t._clippingPolygonsState&&(t._clippingPolygonsState=i,t.clippingPolygonsDirty=!0)}fs.prototype.update=function(t,e,n){let{commandList:i}=e,o=i.length;Qme(this,t),kme(this,t),yme(this,t,e,n),Bme(this,t,e);let a=i.length;this._commandsLength=a-o;for(let s=o;st.cacheBytes||n);){let s=a.item;a=a.next,this.unloadTile(t,s,e)}};tS.prototype.trim=function(){this._trimTiles=!0};var qX=tS;var xsi=b(W(),1);function FP(t){this.tilePropertyName=t,this._minimum=Number.MAX_VALUE,this._maximum=-Number.MAX_VALUE,this._previousMinimum=Number.MAX_VALUE,this._previousMaximum=-Number.MAX_VALUE,this._referenceMinimum={},this._referenceMaximum={}}function Btt(t,e){let n;return e==="_loadTimestamp"?n=rt.toDate(t).getTime():n=t,n}FP.prototype.setReferenceMinimumMaximum=function(t,e,n){this._referenceMinimum[n]=Btt(t,n),this._referenceMaximum[n]=Btt(e,n)};function Xme(t,e){let n=t.tilePropertyName;if(c(n)){let i=Btt(e[n],n);return c(i)?(t._maximum=Math.max(i,t._maximum),t._minimum=Math.min(i,t._minimum),i):(t.tilePropertyName=void 0,i)}}var ytt=[new v(.1,.1,.1,1),new v(.153,.278,.878,1),new v(.827,.231,.49,1),new v(.827,.188,.22,1),new v(1,.592,.259,1),new v(1,.843,0,1)];FP.prototype.colorize=function(t,e){let n=this.tilePropertyName;if(!c(n)||!t.contentAvailable||t._selectedFrame!==e.frameNumber)return;let i=Xme(this,t),o=this._previousMinimum,a=this._previousMaximum;if(o===Number.MAX_VALUE||a===-Number.MAX_VALUE)return;let s=a-o+k.EPSILON7,r=k.clamp(i-o,0,s)/s,d=ytt.length-1,m=r*d,h=Math.floor(m),u=Math.ceil(m),R=m-h,V=ytt[h],F=ytt[u],U=v.clone(v.WHITE);U.red=k.lerp(V.red,F.red,R),U.green=k.lerp(V.green,F.green,R),U.blue=k.lerp(V.blue,F.blue,R),t._debugColor=U};FP.prototype.resetMinimumMaximum=function(){let t=this.tilePropertyName;if(c(t)){let e=this._referenceMinimum[t],n=this._referenceMaximum[t],i=c(e)&&c(n);this._previousMinimum=i?e:this._minimum,this._previousMaximum=i?n:this._maximum,this._minimum=Number.MAX_VALUE,this._maximum=-Number.MAX_VALUE}};var $X=FP;var Lsi=b(W(),1);function IC(){this.selected=0,this.visited=0,this.numberOfCommands=0,this.numberOfAttemptedRequests=0,this.numberOfPendingRequests=0,this.numberOfTilesProcessing=0,this.numberOfTilesWithContentReady=0,this.numberOfTilesTotal=0,this.numberOfLoadedTilesTotal=0,this.numberOfFeaturesSelected=0,this.numberOfFeaturesLoaded=0,this.numberOfPointsSelected=0,this.numberOfPointsLoaded=0,this.numberOfTrianglesSelected=0,this.numberOfTilesStyled=0,this.numberOfFeaturesStyled=0,this.numberOfTilesCulledWithChildrenUnion=0,this.geometryByteLength=0,this.texturesByteLength=0,this.batchTableByteLength=0}IC.prototype.clear=function(){this.selected=0,this.visited=0,this.numberOfCommands=0,this.numberOfAttemptedRequests=0,this.numberOfFeaturesSelected=0,this.numberOfPointsSelected=0,this.numberOfTrianglesSelected=0,this.numberOfTilesStyled=0,this.numberOfFeaturesStyled=0,this.numberOfTilesCulledWithChildrenUnion=0};function UP(t,e,n,i){let o=e.innerContents,a=e.pointsLength,s=e.trianglesLength,l=e.featuresLength,r=e.geometryByteLength,d=e.texturesByteLength,m=e.batchTableByteLength;if(i?(t.numberOfFeaturesLoaded+=n?-l:l,t.numberOfPointsLoaded+=n?-a:a,t.geometryByteLength+=n?-r:r,t.texturesByteLength+=n?-d:d,t.batchTableByteLength+=n?-m:m):(t.numberOfFeaturesSelected+=n?-l:l,t.numberOfPointsSelected+=n?-a:a,t.numberOfTrianglesSelected+=n?-s:s),c(o)){let h=o.length;for(let u=0;u>1)&858993459,t=(t^t>>2)&252645135,t=(t^t>>4)&16711935,t=(t^t>>8)&65535,t}function ktt(t){return t&=153391689,t=(t^t>>2)&51130563,t=(t^t>>4)&50393103,t=(t^t>>8)&4278190335,t=(t^t>>16)&1023,t}nJ.encode2D=function(t,e){return(WFt(t)|WFt(e)<<1)>>>0};nJ.decode2D=function(t,e){return c(e)||(e=new Array(2)),e[0]=fFt(t),e[1]=fFt(t>>1),e};nJ.encode3D=function(t,e,n){return Qtt(t)|Qtt(e)<<1|Qtt(n)<<2};nJ.decode3D=function(t,e){return c(e)||(e=new Array(3)),e[0]=ktt(t),e[1]=ktt(t>>1),e[2]=ktt(t>>2),e};var ZF=nJ;function ds(t){this.subdivisionScheme=t.subdivisionScheme,this.subtreeLevels=t.subtreeLevels,this.level=t.level,this.x=t.x,this.y=t.y,this.z=void 0,t.subdivisionScheme===Al.OCTREE&&(this.z=t.z)}Object.defineProperties(ds.prototype,{childIndex:{get:function(){let t=0;return t|=this.x&1,t|=(this.y&1)<<1,this.subdivisionScheme===Al.OCTREE&&(t|=(this.z&1)<<2),t}},mortonIndex:{get:function(){return this.subdivisionScheme===Al.OCTREE?ZF.encode3D(this.x,this.y,this.z):ZF.encode2D(this.x,this.y)}},tileIndex:{get:function(){let t=this.subdivisionScheme===Al.OCTREE?((1<<3*this.level)-1)/7:((1<<2*this.level)-1)/3,e=this.mortonIndex;return t+e}}});ds.prototype.getDescendantCoordinates=function(t){let e=this.level+t.level,n=(this.x<>e,i=t.y>>e,o=this.x===n,a=this.y===i;if(this.subdivisionScheme===Al.OCTREE){let s=t.z>>e,l=this.z===s;return o&&a&&l}return o&&a};ds.prototype.isEqual=function(t){return this.subdivisionScheme===t.subdivisionScheme&&this.subtreeLevels===t.subtreeLevels&&this.level===t.level&&this.x===t.x&&this.y===t.y&&(this.subdivisionScheme===Al.OCTREE?this.z===t.z:!0)};ds.prototype.isImplicitTilesetRoot=function(){return this.level===0};ds.prototype.isSubtreeRoot=function(){return this.level%this.subtreeLevels===0};ds.prototype.isBottomOfSubtree=function(){return this.level%this.subtreeLevels===this.subtreeLevels-1};ds.prototype.getTemplateValues=function(){let t={level:this.level,x:this.x,y:this.y};return this.subdivisionScheme===Al.OCTREE&&(t.z=this.z),t};var FFt=[0,0,0];ds.fromMortonIndex=function(t,e,n,i){let o;return t===Al.OCTREE?(o=ZF.decode3D(i,FFt),new ds({subdivisionScheme:t,subtreeLevels:e,level:n,x:o[0],y:o[1],z:o[2]})):(o=ZF.decode2D(i,FFt),new ds({subdivisionScheme:t,subtreeLevels:e,level:n,x:o[0],y:o[1]}))};ds.fromTileIndex=function(t,e,n){let i,o,a;return t===Al.OCTREE?(i=Math.floor(k.log2(7*n+1)/3),o=((1<<3*i)-1)/7,a=n-o):(i=Math.floor(k.log2(3*n+1)/2),o=((1<<2*i)-1)/3,a=n-o),ds.fromMortonIndex(t,e,i,a)};var nS=ds;var bli=b(W(),1);var hli=b(W(),1);function y0(){}y0.selectTiles=function(t,e){Ut.throwInstantiationError()};y0.sortChildrenByDistanceToCamera=function(t,e){return e._distanceToCamera===0&&t._distanceToCamera===0?e._centerZDepth-t._centerZDepth:e._distanceToCamera-t._distanceToCamera};y0.canTraverse=function(t){return t.children.length===0?!1:t.hasTilesetContent||t.hasImplicitContent?!t.contentExpired:t._screenSpaceError>t.tileset.memoryAdjustedScreenSpaceError};y0.selectTile=function(t,e){if(t.contentVisibility(e)===yn.OUTSIDE)return;t._wasSelectedLastFrame=!0;let{content:n,tileset:i}=t;n.featurePropertiesDirty?(n.featurePropertiesDirty=!1,t.lastStyleTime=0,i._selectedTilesToStyle.push(t)):t._selectedFrame0;if((t.hasTilesetContent||t.hasImplicitContent)&&n){let a=t.children[0];UFt(a,e),t._visible=a._visible;return}if(Dme(t,e)){t._visible=!1;return}let i=t.refine===ss.REPLACE,o=t._optimChildrenWithinParent===jp.USE_OPTIMIZATION;if(i&&o&&n&&!Ome(t,e)){++t.tileset._statistics.numberOfTilesCulledWithChildrenUnion,t._visible=!1;return}}function Dme(t,e){let{parent:n,tileset:i}=t;return!c(n)||n.hasTilesetContent||n.hasImplicitContent||n.refine!==ss.ADD?!1:t.getScreenSpaceError(e,!0)<=i.memoryAdjustedScreenSpaceError}function Ome(t,e){let n=!1,i=t.children;for(let o=0;o0;){iJ.stackMaximumLength=Math.max(iJ.stackMaximumLength,s.length);let l=s.pop(),r=l.refine===ss.ADD,d=l.refine===ss.REPLACE,m=wme(l);m&&Pme(l,s,e),(r||d&&!m)&&(vme(t,l),o(l,e),Kme(l,e),l.hasRenderableContent&&!l.contentAvailable&&(n=!1)),a(l,e)}return iJ.stack.trim(iJ.stackMaximumLength),n};function wme(t){return t.children.length===0?!1:t.hasTilesetContent||t.hasImplicitContent?!t.contentExpired:(t.hasEmptyContent,!0)}function Pme(t,e,n){let{children:i}=t;for(let o=0;o0;){aJ.stackMaximumLength=Math.max(aJ.stackMaximumLength,l.length);let r=l.pop(),d=r.parent,m=!c(d)||d._refines;r._refines=i(r)?zme(r,l,e)&&m:!1;let h=!r._refines&&m;r.hasRenderableContent?r.refine===ss.ADD?(Ytt(r,e),o(r,e)):r.refine===ss.REPLACE&&(o(r,e),h&&Ytt(r,e)):(n._emptyTiles.push(r),o(r,e),h&&Ytt(r,e)),a(r,e),s(r,e)}}function qme(t,e){let{canTraverse:n,updateTile:i,loadTile:o,touchTile:a}=Tr,s=!0,l=sJ.stack;for(l.push(t);l.length>0;){sJ.stackMaximumLength=Math.max(sJ.stackMaximumLength,l.length);let r=l.pop(),d=r.children,m=d.length,h=!r.hasRenderableContent&&n(r);if(!h&&!r.contentAvailable&&(s=!1),i(r,e),r.isVisible||(o(r,e),a(r,e)),h)for(let u=0;u0;){dJ.stackMaximumLength=Math.max(dJ.stackMaximumLength,a.length);let l=a.pop().children;for(let r=0;rn._depth+t.skipLevels)}function ihe(t,e,n){let{tileset:i,children:o}=t,{updateTile:a,loadTile:s,touchTile:l}=Tr;for(let d=0;de:t._screenSpaceError>e:!0}function ahe(t,e){let{tileset:n}=t,i=n.immediatelyLoadDesiredLevelOfDetail?Number.MAX_VALUE:Math.max(n.baseScreenSpaceError,n.memoryAdjustedScreenSpaceError),{canTraverse:o,loadTile:a,visitTile:s,touchTile:l}=Tr,r=rJ.stack;for(r.push(t);r.length>0;){rJ.stackMaximumLength=Math.max(rJ.stackMaximumLength,r.length);let d=r.pop();ehe(d,e);let m=d.parent,h=!c(m)||m._refines;d._refines=o(d)?ihe(d,r,e)&&h:!1;let u=!d._refines&&h;d.hasRenderableContent?d.refine===ss.ADD?(GP(d,e),a(d,e)):d.refine===ss.REPLACE&&(ohe(d,i)?(a(d,e),u&&GP(d,e)):u?(GP(d,e),a(d,e)):nhe(n,d)&&a(d,e)):(n._emptyTiles.push(d),a(d,e),u&&GP(d,e)),s(d,e),l(d,e)}}function she(t,e){let{selectTile:n,canTraverse:i}=Tr,{stack:o,ancestorStack:a}=B0,s;for(o.push(t);o.length>0||a.length>0;){if(B0.stackMaximumLength=Math.max(B0.stackMaximumLength,o.length),B0.ancestorStackMaximumLength=Math.max(B0.ancestorStackMaximumLength,a.length),a.length>0){let d=a.peek();if(d._stackLength===o.length){a.pop(),d!==s&&(d._finalResolution=!1),n(d,e);continue}}let l=o.pop();if(!c(l))continue;let r=i(l);if(l._shouldSelect)if(l.refine===ss.ADD)n(l,e);else{if(l._selectionDepth=a.length,l._selectionDepth>0&&(l.tileset.hasMixedContent=!0),s=l,!r){n(l,e);continue}a.push(l),l._stackLength=o.length}if(r){let d=l.children;for(let m=0;mVo._defaultMinTerrainHeight&&(s._initialClippingPlanesOriginMatrix=Pe.eastNorthUpToFixedFrame(u)),s._clippingPlanesOriginMatrix=L.clone(s._initialClippingPlanesOriginMatrix),s};Fs.loadJson=function(t){return te.createIfNeeded(t).fetchJson()};Fs.prototype.makeStyleDirty=function(){this._styleEngine.makeDirty()};Fs.prototype.loadTileset=function(t,e,n){let i=e.asset;if(!c(i))throw new Tt("Tileset must have an asset property.");if(i.version!=="0.0"&&i.version!=="1.0"&&i.version!=="1.1")throw new Tt("The tileset must be 3D Tiles version 0.0, 1.0, or 1.1");c(e.extensionsRequired)&&Fs.checkSupportedExtensions(e.extensionsRequired);let o=this._statistics,a=i.tilesetVersion;c(a)&&(this._basePath+=`?v=${a}`,t=t.clone(),t.setQueryParameters({v:a}));let s=TFt(this,t,e.root,n);c(n)&&(n.children.push(s),s._depth=n._depth+1);let l=[];for(l.push(s);l.length>0;){let r=l.pop();++o.numberOfTilesTotal,this._allTilesAdditive=this._allTilesAdditive&&r.refine===ss.ADD;let d=r._header.children;if(c(d))for(let m=0;mU.minimumRadius){let S=gt.fromCartesian(A,U,rhe);n=p.normalize(l.positionWC,gFt),i=l.directionWC,o=l.positionCartographic.height,a=0,s=S.height*2}else{let S=L.multiplyByPoint(F,l.positionWC,mhe);if(n=p.UNIT_Z,i=L.multiplyByPointAsVector(F,l.directionWC,hhe),i=p.normalize(i,i),o=S.z,d instanceof kh){let g=ot.getColumn(G.halfAxes,2,phe),C=p.magnitude(g);a=A.z-C,s=A.z+C}else if(d instanceof E0){let g=G.radius;a=A.z-g,s=A.z+g}}}let m=t.dynamicScreenSpaceErrorHeightFalloff,h=a+(s-a)*m,u=s,R=k.clamp((o-h)/(u-h),0,1),V=1-Math.abs(p.dot(i,n));V=V*(1-R),t._dynamicScreenSpaceErrorComputedDensity=t.dynamicScreenSpaceErrorDensity*V}function uhe(t,e){if(e.hasEmptyContent)return;let{statistics:n}=t,i=e.contentExpired,o=e.requestContent();c(o)&&(o.then(a=>{!c(a)||e.isDestroyed()||t.isDestroyed()||(t._processingQueue.push(e),++n.numberOfTilesProcessing)}).catch(a=>{IFt(a,t,e)}),i&&(e.hasTilesetContent||e.hasImplicitContent?Che(t,e):(n.decrementLoadCounts(e.content),--n.numberOfTilesWithContentReady)),t._requestedTilesInFlight.push(e))}function CFt(t,e){return t._priority-e._priority}Fs.prototype.postPassesUpdate=function(t){c(this._root)&&(Zhe(this,t),Nhe(this,t),this._cache.unloadTiles(this,yFt),this._styleApplied&&this._styleEngine.resetDirty(),this._styleApplied=!1)};Fs.prototype.prePassesUpdate=function(t){if(!c(this._root))return;Ghe(this,t);let e=this._clippingPlanes;this._clippingPlanesOriginMatrixDirty=!0,c(e)&&e.enabled&&e.update(t);let n=this._clippingPolygons;c(n)&&n.enabled&&n.update(t),c(this._loadTimestamp)||(this._loadTimestamp=rt.clone(t.time)),this._timeSinceLoad=Math.max(rt.secondsDifference(t.time,this._loadTimestamp)*1e3,0),this.dynamicScreenSpaceError&&Vhe(this,t),t.newFrame&&this._cache.reset()};function Zhe(t,e){let n=t._requestedTilesInFlight,i=0;for(let o=0;o=1;if(a._contentState!==rs.LOADING){++i;continue}else if(s){a.cancelRequests(),++i;continue}i>0&&(n[o-i]=a)}n.length-=i}function Rhe(t){let e=t._requestedTiles;e.sort(CFt);for(let n=0;n0?e.tileFailed.raiseEvent({url:i,message:o}):(console.log(`A 3D tile failed to load: ${i}`),console.log(`Error: ${o}`))}function bhe(t){let e=t._processingQueue,n=0;for(let i=0;i0&&(e[i-n]=o)}e.length-=n}var Whe=new gt,fhe=new gt,Fhe=new p;function Uhe(t,e,n){if(!t.enableCollision||!t.show)return;let i=t._addHeightCallbacks,o=e.boundingSphere;for(let a of i){if(a.invoked||e._wasSelectedLastFrame)continue;let s=a.ellipsoid,l=gt.clone(a.positionCartographic,Whe),r=gt.fromCartesian(o.center,s,fhe);c(r)&&(l.height=r.height);let d=gt.toCartesian(l,s,Fhe);p.distance(d,o.center)<=o.radius&&n.afterRender.push(()=>{c(a.callback)&&a.callback(l),a.invoked=!1})}}function Ghe(t,e){bhe(t);let n=t._processingQueue,{cacheBytes:i,maximumCacheOverflowBytes:o,statistics:a}=t,s=i+o,l=!1;for(let r=0;rs){l=!0;break}let d=n[r];try{d.process(t,e),d.contentReady&&(--a.numberOfTilesProcessing,t.tileLoad.raiseEvent(d))}catch(m){--a.numberOfTilesProcessing,IFt(m,t,d)}}t.totalMemoryUsageInBytes0&&Ahe(t)}function Ahe(t){t._memoryAdjustedScreenSpaceError*=1.02;let e=t._processingQueue;for(let n=0;n0&&(i+=` Points: ${t.content.pointsLength}`,o++),t.content.trianglesLength>0&&(i+=` @@ -8788,7 +8788,7 @@ Texture Memory: ${EFt(t.content.texturesByteLength)}`,i+=` Geometry Memory: ${EFt(t.content.geometryByteLength)}`,o+=2),e.debugShowUrl)if(t.hasMultipleContents){i+=` Urls:`;let s=t.content.innerContentUrls;for(let l=0;l0;t._backfaceCommands.length=0,l&&(c(t._stencilClearCommand)||(t._stencilClearCommand=new ao({stencil:0,pass:Pt.CESIUM_3D_TILE,renderState:he.fromCache({stencilMask:gn.SKIP_LOD_MASK})})),i.push(t._stencilClearCommand));let{statistics:r,tileVisible:d}=t,m=n.isRender,h=i.length;for(let u=0;u=0;--U)i[h+F+U]=i[h+U];for(let U=0;U0&&t._pointCloudEyeDomeLighting.update(e,a,t.pointCloudShading,t.boundingSphere),t.debugShowGeometricError||t.debugShowRenderingStatistics||t.debugShowMemoryUsage||t.debugShowUrl?(c(t._tileDebugLabels)||(t._tileDebugLabels=new sb),ghe(t,e)):t._tileDebugLabels=t._tileDebugLabels&&t._tileDebugLabels.destroy())}var NFt=[];function Che(t,e){let n=e,i=NFt;for(i.push(e);i.length>0;){e=i.pop();let o=e.children;for(let a=0;a{e.push(on.clone(i))});let n=t.asset.extras;if(c(n)&&c(n.cesium)&&c(n.cesium.credits)){let i=n.cesium.credits;for(let o=0;oi.showOnScreen=i.showOnScreen||t._showCreditsOnScreen),t._credits=e}Fs.prototype.getTraversal=function(t){let{pass:e}=t;return e===ns.MOST_DETAILED_PRELOAD||e===ns.MOST_DETAILED_PICK?oJ:this.isSkippingLevelOfDetail?cJ:lJ};Fs.prototype.update=function(t){this.updateForPass(t,t.tilesetPassState)};Fs.prototype.updateForPass=function(t,e){let n=e.pass;if(n===ns.PRELOAD&&(!this.preloadWhenHidden||this.show)||n===ns.PRELOAD_FLIGHT&&(!this.preloadFlightDestinations||!this.show&&!this.preloadWhenHidden)||n===ns.REQUEST_RENDER_MODE_DEFER_CHECK&&(!this._cullRequestsWhileMoving&&this.foveatedTimeDelay<=0||!this.show))return;let i=t.commandList,o=t.camera,a=t.cullingVolume;e.ready=!1;let s=ns.getPassOptions(n),l=s.ignoreCommands,r=f(e.commandList,i),d=r.length;t.commandList=r,t.camera=f(e.camera,o),t.cullingVolume=f(e.cullingVolume,a);let m=this._clippingPolygons;c(m)&&m.enabled&&m.queueCommands(t);let h=this._statisticsPerPass[n];(this.show||l)&&(this._pass=n,e.ready=Qhe(this,t,h,s)),l&&(r.length=d),t.commandList=i,t.camera=o,t.cullingVolume=a};Fs.prototype.hasExtension=function(t){return c(this._extensionsUsed)?this._extensionsUsed.indexOf(t)>-1:!1};Fs.prototype.isDestroyed=function(){return!1};Fs.prototype.destroy=function(){if(this._tileDebugLabels=this._tileDebugLabels&&this._tileDebugLabels.destroy(),this._clippingPlanes=this._clippingPlanes&&this._clippingPlanes.destroy(),this._clippingPolygons=this._clippingPolygons&&this._clippingPolygons.destroy(),c(this._root)){let t=NFt;for(t.push(this._root);t.length>0;){let e=t.pop();e.destroy();let n=e.children;for(let i=0;i{let a=this._addHeightCallbacks,s=a.length;for(let l=0;l{let m=Ft.distanceSquaredTo(r.contentBoundingVolume.boundingSphere,t.origin),h=Ft.distanceSquaredTo(d.contentBoundingVolume.boundingSphere,t.origin);return m-h});let l;for(let r=0;r-1;i--)Jtt(this,t[i],e,n);return At(this)};bF.prototype.getBoundingSphere=function(t,e){let n=this._tilesetHash[t.id];if(!c(n)||n.loadFail)return ve.FAILED;let i=n.tilesetPrimitive;return c(i)?i.show?(Ft.clone(i.boundingSphere,e),ve.DONE):ve.FAILED:ve.PENDING};bF.prototype._onCollectionChanged=function(t,e,n,i){let o,a,s=this._entitiesToVisualize,l=this._tilesetHash,r=this._primitives;for(o=e.length-1;o>-1;o--)a=e[o],c(a._tileset)&&s.set(a.id,a);for(o=i.length-1;o>-1;o--)a=i[o],c(a._tileset)?s.set(a.id,a):(Jtt(this,a,l,r),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],Jtt(this,a,l,r),s.remove(a.id)};function Jtt(t,e,n,i){let o=n[e.id];c(o)&&(c(o.tilesetPrimitive)&&i.removeAndDestroy(o.tilesetPrimitive),delete n[e.id])}async function Mhe(t,e,n,i){e[n.id]={url:t.url,loadFail:!1};try{let o=await Pr.fromUrl(t);if(o.id=n,i.add(o),!c(e[n.id]))return;e[n.id].tilesetPrimitive=o}catch(o){console.error(o),e[n.id].loadFail=!0}}var mJ=bF;var sdi=R(W(),1);var _he=v.WHITE,Dhe=v.BLACK,Ohe=new K(2,2);function NC(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._evenColor=void 0,this._evenColorSubscription=void 0,this._oddColor=void 0,this._oddColorSubscription=void 0,this._repeat=void 0,this._repeatSubscription=void 0,this.evenColor=t.evenColor,this.oddColor=t.oddColor,this.repeat=t.repeat}Object.defineProperties(NC.prototype,{isConstant:{get:function(){return et.isConstant(this._evenColor)&&et.isConstant(this._oddColor)&&et.isConstant(this._repeat)}},definitionChanged:{get:function(){return this._definitionChanged}},evenColor:ft("evenColor"),oddColor:ft("oddColor"),repeat:ft("repeat")});NC.prototype.getType=function(t){return"Checkerboard"};NC.prototype.getValue=function(t,e){return c(e)||(e={}),e.lightColor=et.getValueOrClonedDefault(this._evenColor,t,_he,e.lightColor),e.darkColor=et.getValueOrClonedDefault(this._oddColor,t,Dhe,e.darkColor),e.repeat=et.getValueOrDefault(this._repeat,t,Ohe),e};NC.prototype.equals=function(t){return this===t||t instanceof NC&&et.equals(this._evenColor,t._evenColor)&&et.equals(this._oddColor,t._oddColor)&&et.equals(this._repeat,t._repeat)};var yC=NC;var hdi=R(W(),1);var Co={LEO:"Low Earth Orbit",MEO:"Medium Earth Orbit",HEO:"Highly Elliptical Orbit",GEO:"Geostationary Orbit",IGO:"Inclined Geosynchronous Orbit",EGO:"Extended Geostationary Orbit",GEOIADC:"IADC GEO Protected Region",GEOSYNC:"Geosynchronous Orbit",SUNSYNC:"Sun Synchronous Orbit",SEMISYNC:"Semi Synchronous Orbit",POLAR:"POLAR Orbit",UNKNOWN:"UNKNOWN"},Ltt=86164.0905;function Mtt(t){let e=[],n=t.properties.CAT.getValue(),i=t.properties.OMM.getValue(),o=i.SEMI_MAJOR_AXIS;if(n.PERIOD<128*60&&i.ECCENTRICITY<.25&&e.push(Co.LEO),o>36e3){let a=rt.now(),s=rt.addMinutes(a,1440,new rt),l=10,r=1/0,d=-1/0;for(let m=a;rt.lessThan(m,s);m=rt.addMinutes(m,l,new rt)){let h=t.position.getValue(m),{latitude:Z}=gt.fromCartesian(h,mt.WGS84)||{latitude:0},b=k.toDegrees(Z);r=Math.min(r,b),d=Math.max(d,b)}n.PERIOD>Ltt-60&&n.PERIOD=25&&i.INCLINATION<=180&&o>=37948&&o<=46380&&i.ECCENTRICITY<=.25&&e.push(Co.IGO),i.INCLINATION>=0&&i.INCLINATION<=25&&o>=37948&&o<=46380&&i.ECCENTRICITY<=.25&&e.push(Co.EGO),r>=-15&&d<=15&&n.PERIGEE>=35586&&n.PERIGEE<=35986&&e.push(Co.GEOIADC)}return n.PERIGEE>=2e3&&n.PERIGEE<35700?e.push(Co.MEO):n.PERIGEE>35786&&e.push(Co.HEO),i.INCLINATION>97&&i.INCLINATION<99&&e.push(Co.SUNSYNC),Math.abs(n.PERIOD-.5*Ltt)<1&&e.push(Co.SEMISYNC),i.INCLINATION>=80&&i.INCLINATION<=100&&e.push(Co.POLAR),e.length===0&&e.push(Co.UNKNOWN),e}var _tt=Mtt;var Idi=R(W(),1);var Gdi=R(W(),1);var QFt={id:void 0};function hJ(t){if(t._firing){t._refire=!0;return}if(t._suspendCount===0){let e=t._addedEntities,n=t._removedEntities,i=t._changedEntities;if(i.length!==0||e.length!==0||n.length!==0){t._firing=!0;do{t._refire=!1;let o=e.values.slice(0),a=n.values.slice(0),s=i.values.slice(0);e.removeAll(),n.removeAll(),i.removeAll(),t._collectionChanged.raiseEvent(t,o,a,s)}while(t._refire);t._firing=!1}}}function $d(t){this._owner=t,this._entities=new qe,this._addedEntities=new qe,this._removedEntities=new qe,this._changedEntities=new qe,this._suspendCount=0,this._collectionChanged=new It,this._id=Si(),this._show=!0,this._firing=!1,this._refire=!1}$d.prototype.suspendEvents=function(){this._suspendCount++};$d.prototype.resumeEvents=function(){this._suspendCount--,hJ(this)};Object.defineProperties($d.prototype,{collectionChanged:{get:function(){return this._collectionChanged}},id:{get:function(){return this._id}},values:{get:function(){return this._entities.values}},show:{get:function(){return this._show},set:function(t){if(t===this._show)return;this.suspendEvents();let e,n=[],i=this._entities.values,o=i.length;for(e=0;e-1;r--)s=l[r],YFt(t,Z,b,s);for(a=n-1;a>=0;a--)for(d=e[a],d.collectionChanged.addEventListener(ll.prototype._onCollectionChanged,t),l=d.values,b=d.id,r=l.length-1;r>-1;r--){s=l[r],kFt(t,Z,b,s);let F=h.getById(s.id);c(F)||(F=m.getById(s.id),c(F)?Dtt(F):(TP.id=s.id,F=new qa(TP)),h.add(F)),F.merge(s)}t._collectionsCopy=e.slice(0),m.suspendEvents(),m.removeAll();let u=h.values;for(a=0;a=0;l--)r=i[l].getById(F),c(r)&&(c(d)||(d=a.getById(F),Dtt(d)),d.merge(r));c(d)||a.removeById(F),d=void 0}let b=e.length;for(s=0;s=0;l--)r=i[l].getById(F),c(r)&&(c(d)||(d=a.getById(F),c(d)?Dtt(d):(TP.id=F,d=new qa(TP),a.add(d))),d.merge(r));d=void 0}a.resumeEvents()};ll.prototype._onDefinitionChanged=function(t,e,n,i){let o=this._collections,a=this._composite,s=o.length,l=t.id,r=a.getById(l),d=r[e],m=!c(d),h=!0;for(let Z=s-1;Z>=0;Z--){let b=o[Z].getById(t.id);if(c(b)){let u=b[e];if(c(u)){if(h)if(h=!1,c(u.merge)&&c(u.clone))d=u.clone(d);else{d=u;break}d.merge(u)}}}m&&r.propertyNames.indexOf(e)===-1&&r.addProperty(e),r[e]=d};var Ott=ll;var nci=R(W(),1);var zdi=R(W(),1);var ydi=R(W(),1);function Htt(){this._removalFunctions=[]}Htt.prototype.add=function(t,e,n){let i=t.addEventListener(e,n);this._removalFunctions.push(i);let o=this;return function(){i();let a=o._removalFunctions;a.splice(a.indexOf(i),1)}};Htt.prototype.removeAll=function(){let t=this._removalFunctions;for(let e=0,n=t.length;e0&&(this._intervals.length=0,this._changedEvent.raiseEvent(this))};dl.prototype.findIntervalContainingDate=function(t){let e=this.indexOf(t);return e>=0?this._intervals[e]:void 0};dl.prototype.findDataForIntervalContainingDate=function(t){let e=this.indexOf(t);return e>=0?this._intervals[e].data:void 0};dl.prototype.contains=function(t){return this.indexOf(t)>=0};var wtt=new ai;dl.prototype.indexOf=function(t){let e=this._intervals;wtt.start=t,wtt.stop=t;let n=Ja(e,wtt,vtt);return n>=0?e[n].isStartIncluded?n:n>0&&e[n-1].stop.equals(t)&&e[n-1].isStopIncluded?n-1:~n:(n=~n,n>0&&n-10&&t.isStartIncluded&&n[i-1].isStartIncluded&&n[i-1].start.equals(t.start)?--i:i0&&(o=rt.compare(n[i-1].stop,t.start),(o>0||o===0&&(n[i-1].isStopIncluded||t.isStartIncluded))&&((c(e)?e(n[i-1].data,t.data):n[i-1].data===t.data)?(rt.greaterThan(t.stop,n[i-1].stop)?t=new ai({start:n[i-1].start,stop:t.stop,isStartIncluded:n[i-1].isStartIncluded,isStopIncluded:t.isStopIncluded,data:t.data}):t=new ai({start:n[i-1].start,stop:n[i-1].stop,isStartIncluded:n[i-1].isStartIncluded,isStopIncluded:n[i-1].isStopIncluded||t.stop.equals(n[i-1].stop)&&t.isStopIncluded,data:t.data}),n.splice(i-1,1),--i):(o=rt.compare(n[i-1].stop,t.stop),(o>0||o===0&&n[i-1].isStopIncluded&&!t.isStopIncluded)&&n.splice(i,0,new ai({start:t.stop,stop:n[i-1].stop,isStartIncluded:!t.isStopIncluded,isStopIncluded:n[i-1].isStopIncluded,data:n[i-1].data})),n[i-1]=new ai({start:n[i-1].start,stop:t.start,isStartIncluded:n[i-1].isStartIncluded,isStopIncluded:!t.isStartIncluded,data:n[i-1].data}))));i0||o===0&&(t.isStopIncluded||n[i].isStartIncluded));)if(c(e)?e(n[i].data,t.data):n[i].data===t.data)t=new ai({start:t.start,stop:rt.greaterThan(n[i].stop,t.stop)?n[i].stop:t.stop,isStartIncluded:t.isStartIncluded,isStopIncluded:rt.greaterThan(n[i].stop,t.stop)?n[i].isStopIncluded:t.isStopIncluded,data:t.data}),n.splice(i,1);else if(n[i]=new ai({start:t.stop,stop:n[i].stop,isStartIncluded:!t.isStopIncluded,isStopIncluded:n[i].isStopIncluded,data:n[i].data}),n[i].isEmpty)n.splice(i,1);else break;n.splice(i,0,t),this._changedEvent.raiseEvent(this)};dl.prototype.removeInterval=function(t){if(t.isEmpty)return!1;let e=this._intervals,n=Ja(e,t,vtt);n<0&&(n=~n);let i=!1;for(n>0&&(rt.greaterThan(e[n-1].stop,t.start)||e[n-1].stop.equals(t.start)&&e[n-1].isStopIncluded&&t.isStartIncluded)&&(i=!0,(rt.greaterThan(e[n-1].stop,t.stop)||e[n-1].isStopIncluded&&!t.isStopIncluded&&e[n-1].stop.equals(t.stop))&&e.splice(n,0,new ai({start:t.stop,stop:e[n-1].stop,isStartIncluded:!t.isStopIncluded,isStopIncluded:e[n-1].isStopIncluded,data:e[n-1].data})),e[n-1]=new ai({start:e[n-1].start,stop:t.start,isStartIncluded:e[n-1].isStartIncluded,isStopIncluded:!t.isStartIncluded,data:e[n-1].data})),n=1e3&&(o+=Math.floor(i/1e3),i=i%1e3),o>=60&&(a+=Math.floor(o/60),o=o%60),a>=60&&(s+=Math.floor(a/60),a=a%60),s>=24&&(l+=Math.floor(s/24),s=s%24),pJ[2]=Pu(d)?29:28;l>pJ[r]||r>=13;)l>pJ[r]&&(l-=pJ[r],++r),r>=13&&(--r,d+=Math.floor(r/12),r=r%12,++r),pJ[2]=Pu(d)?29:28;return tc.millisecond=i,tc.second=o,tc.minute=a,tc.hour=s,tc.day=l,tc.month=r,tc.year=d,rt.fromGregorianDate(tc,n)}var Hhe=new rt,whe=/P(?:([\d.,]+)Y)?(?:([\d.,]+)M)?(?:([\d.,]+)W)?(?:([\d.,]+)D)?(?:T(?:([\d.,]+)H)?(?:([\d.,]+)M)?(?:([\d.,]+)S)?)?/;function XFt(t,e){if(!c(t)||t.length===0)return!1;if(e.year=0,e.month=0,e.day=0,e.hour=0,e.minute=0,e.second=0,e.millisecond=0,t[0]==="P"){let n=t.match(whe);if(!c(n))return!1;if(c(n[1])&&(e.year=Number(n[1].replace(",","."))),c(n[2])&&(e.month=Number(n[2].replace(",","."))),c(n[3])&&(e.day=Number(n[3].replace(",","."))*7),c(n[4])&&(e.day+=Number(n[4].replace(",","."))),c(n[5])&&(e.hour=Number(n[5].replace(",","."))),c(n[6])&&(e.minute=Number(n[6].replace(",","."))),c(n[7])){let i=Number(n[7].replace(",","."));e.second=Math.floor(i),e.millisecond=i%1*1e3}}else t[t.length-1]!=="Z"&&(t+="Z"),rt.toGregorianDate(rt.fromIso8601(t,Hhe),e);return e.year||e.month||e.day||e.hour||e.minute||e.second||e.millisecond}var uJ=new WR;dl.fromIso8601=function(t,e){let n=t.iso8601.split("/"),i=rt.fromIso8601(n[0]),o=rt.fromIso8601(n[1]),a=[];if(!XFt(n[2],uJ))a.push(i,o);else{let s=rt.clone(i);for(a.push(s);rt.compare(s,o)<0;)s=Ptt(s,uJ),rt.compare(o,s)<=0&&rt.clone(o,s),a.push(s)}return dl.fromJulianDateArray({julianDates:a,isStartIncluded:t.isStartIncluded,isStopIncluded:t.isStopIncluded,leadingInterval:t.leadingInterval,trailingInterval:t.trailingInterval,dataCallback:t.dataCallback},e)};dl.fromIso8601DateArray=function(t,e){return dl.fromJulianDateArray({julianDates:t.iso8601Dates.map(function(n){return rt.fromIso8601(n)}),isStartIncluded:t.isStartIncluded,isStopIncluded:t.isStopIncluded,leadingInterval:t.leadingInterval,trailingInterval:t.trailingInterval,dataCallback:t.dataCallback},e)};dl.fromIso8601DurationArray=function(t,e){let n=t.epoch,i=t.iso8601Durations,o=f(t.relativeToPrevious,!1),a=[],s,l,r=i.length;for(let d=0;d=0?-l:l}var spe=new p(-1,0,0),oT=new L,lpe=new L,jtt=new ot,rpe=ot.IDENTITY.clone(),dpe=new p,cpe=new Rt,JFt=new p;function Q0(t,e,n,i,o,a,s,l){let r=dpe,d=cpe;oT=Pe.eastNorthUpToFixedFrame(t,o,oT),r=L.multiplyByPointAsVector(oT,spe,r),r=p.normalize(r,r);let m=ape(r,e,t,o);jtt=ot.fromRotationZ(m,jtt),JFt.z=a,oT=L.multiplyTransformation(oT,L.fromRotationTranslation(jtt,JFt,lpe),oT);let h=rpe;h[0]=s;for(let Z=0;Z0){let F=d?2:1;for(let U=0;U=0};var ppe=new p,upe=new p;ZJ.computePositions=function(t,e,n,i,o){let a=i._ellipsoid,s=ope(t,a),l=i._granularity,r=i._cornerType,d=o?hpe(e,n):LFt(e,n),m=o?LFt(e,n):void 0,h=n.height/2,Z=n.width/2,b=t.length,u=[],F=o?[]:void 0,U=Khe,G=zhe,A=jhe,T=qhe,g=$he,C=tpe,y=epe,Y=npe,Q=ipe,J=t[0],M=t[1];T=a.geodeticSurfaceNormal(J,T),U=p.subtract(M,J,U),U=p.normalize(U,U),Y=p.cross(T,U,Y),Y=p.normalize(Y,Y);let V=s[0],E=s[1];o&&(F=Q0(J,Y,m,F,a,V+h,1,1)),Q=p.clone(J,Q),J=M,G=p.negate(U,G);let I,B;for(let P=1;PMt;Z--)kt=k.PI_OVER_TWO-Z*Nt,st[Wt++]=1-Et*(1+Math.cos(kt)),st[Wt++]=.5*(1+Math.sin(kt));for(Z=Mt;Z>0;Z--)kt=k.PI_OVER_TWO-Nt*Z,st[Wt++]=1-Qt*(1+Math.cos(kt)),st[Wt++]=.5*(1+Math.sin(kt));for(Z=m-U;Z>0;Z--)st[Wt++]=Z*Qt,st[Wt++]=1;for(Z=1;Z0;Z--)st[Wt++]=(Z-1)*Qt,st[Wt++]=1}r.st=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:st})}return e.normal&&(r.normal=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:y.normals})),e.tangent&&(r.tangent=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:y.tangents})),e.bitangent&&(r.bitangent=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:y.bitangents})),{attributes:r,indices:w}}function gpe(t,e){if(!e.normal&&!e.tangent&&!e.bitangent&&!e.st)return t;let n=t.position.values,i,o;(e.normal||e.bitangent)&&(i=t.normal.values,o=t.bitangent.values);let a=t.position.values.length/18,s=a*3,l=a*2,r=s*2,d;if(e.normal||e.bitangent||e.tangent){let m=e.normal?new Float32Array(s*6):void 0,h=e.tangent?new Float32Array(s*6):void 0,Z=e.bitangent?new Float32Array(s*6):void 0,b=eUt,u=nUt,F=NP,U=yP,G=Spe,A=iUt,T=r;for(d=0;d-e?(o=Qpe,o.x=this._cameraPosition.x/(n.radii.x+e),o.y=this._cameraPosition.y/(n.radii.y+e),o.z=this._cameraPosition.z/(n.radii.z+e),i=o.x*o.x+o.y*o.y+o.z*o.z-1):(o=this._cameraPositionInScaledSpace,i=this._distanceToLimbInScaledSpaceSquared),iet(t,o,i)};mb.prototype.computeHorizonCullingPoint=function(t,e,n){return fUt(this._ellipsoid,t,e,n)};var RUt=mt.clone(mt.UNIT_SPHERE);mb.prototype.computeHorizonCullingPointPossiblyUnderEllipsoid=function(t,e,n,i){let o=WUt(this._ellipsoid,n,RUt);return fUt(o,t,e,i)};mb.prototype.computeHorizonCullingPointFromVertices=function(t,e,n,i,o){return FUt(this._ellipsoid,t,e,n,i,o)};mb.prototype.computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid=function(t,e,n,i,o,a){let s=WUt(this._ellipsoid,o,RUt);return FUt(s,t,e,n,i,a)};var kpe=[];mb.prototype.computeHorizonCullingPointFromRectangle=function(t,e,n){let i=Gt.subsample(t,e,0,kpe),o=Ft.fromPoints(i);if(!(p.magnitude(o.center)<.1*e.minimumRadius))return this.computeHorizonCullingPoint(o.center,i,n)};var Ype=new p;function WUt(t,e,n){if(c(e)&&e<0&&t.minimumRadius>-e){let i=p.fromElements(t.radii.x+e,t.radii.y+e,t.radii.z+e,Ype);t=mt.fromCartesian3(i,n)}return t}function fUt(t,e,n,i){c(i)||(i=new p);let o=AUt(t,e),a=0;for(let s=0,l=n.length;s0:s>o&&s*s/p.magnitudeSquared(a)>o)}var xpe=new p,Xpe=new p;function UUt(t,e,n){let i=t.transformPositionToScaledSpace(e,xpe),o=p.magnitudeSquared(i),a=Math.sqrt(o),s=p.divideByScalar(i,a,Xpe);o=Math.max(1,o),a=Math.max(1,a);let l=p.dot(s,n),r=p.magnitude(p.cross(s,n,s)),d=1/a,m=Math.sqrt(o-1)*d;return 1/(l*d-r*m)}function GUt(t,e,n){if(!(e<=0||e===1/0||e!==e))return p.multiplyByScalar(t,e,n)}var net=new p;function AUt(t,e){return p.equals(e,p.ZERO)?e:(t.transformPositionToScaledSpace(e,net),p.normalize(net,net))}var BZ=mb;var Nhi=R(W(),1);function hl(t,e){t=f(t,f.EMPTY_OBJECT);let n=t.translucencyByDistance,i=t.scaleByDistance,o=t.distanceDisplayCondition;c(n)&&(n=ln.clone(n)),c(i)&&(i=ln.clone(i)),c(o)&&(o=Wn.clone(o)),this._show=f(t.show,!0),this._position=p.clone(f(t.position,p.ZERO)),this._actualPosition=p.clone(this._position),this._color=v.clone(f(t.color,v.WHITE)),this._outlineColor=v.clone(f(t.outlineColor,v.TRANSPARENT)),this._outlineWidth=f(t.outlineWidth,0),this._pixelSize=f(t.pixelSize,10),this._scaleByDistance=i,this._translucencyByDistance=n,this._distanceDisplayCondition=o,this._disableDepthTestDistance=f(t.disableDepthTestDistance,0),this._id=t.id,this._collection=f(t.collection,e),this._clusterShow=!0,this._pickId=void 0,this._pointPrimitiveCollection=e,this._dirty=!1,this._index=-1}var TUt=hl.SHOW_INDEX=0,EUt=hl.POSITION_INDEX=1,Jpe=hl.COLOR_INDEX=2,Lpe=hl.OUTLINE_COLOR_INDEX=3,Mpe=hl.OUTLINE_WIDTH_INDEX=4,_pe=hl.PIXEL_SIZE_INDEX=5,Dpe=hl.SCALE_BY_DISTANCE_INDEX=6,Ope=hl.TRANSLUCENCY_BY_DISTANCE_INDEX=7,Hpe=hl.DISTANCE_DISPLAY_CONDITION_INDEX=8,wpe=hl.DISABLE_DEPTH_DISTANCE_INDEX=9;hl.NUMBER_OF_PROPERTIES=10;function su(t,e){let n=t._pointPrimitiveCollection;c(n)&&(n._updatePointPrimitive(t,e),t._dirty=!0)}Object.defineProperties(hl.prototype,{show:{get:function(){return this._show},set:function(t){this._show!==t&&(this._show=t,su(this,TUt))}},position:{get:function(){return this._position},set:function(t){let e=this._position;p.equals(e,t)||(p.clone(t,e),p.clone(t,this._actualPosition),su(this,EUt))}},scaleByDistance:{get:function(){return this._scaleByDistance},set:function(t){let e=this._scaleByDistance;ln.equals(e,t)||(this._scaleByDistance=ln.clone(t,e),su(this,Dpe))}},translucencyByDistance:{get:function(){return this._translucencyByDistance},set:function(t){let e=this._translucencyByDistance;ln.equals(e,t)||(this._translucencyByDistance=ln.clone(t,e),su(this,Ope))}},pixelSize:{get:function(){return this._pixelSize},set:function(t){this._pixelSize!==t&&(this._pixelSize=t,su(this,_pe))}},color:{get:function(){return this._color},set:function(t){let e=this._color;v.equals(e,t)||(v.clone(t,e),su(this,Jpe))}},outlineColor:{get:function(){return this._outlineColor},set:function(t){let e=this._outlineColor;v.equals(e,t)||(v.clone(t,e),su(this,Lpe))}},outlineWidth:{get:function(){return this._outlineWidth},set:function(t){this._outlineWidth!==t&&(this._outlineWidth=t,su(this,Mpe))}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){Wn.equals(this._distanceDisplayCondition,t)||(this._distanceDisplayCondition=Wn.clone(t,this._distanceDisplayCondition),su(this,Hpe))}},disableDepthTestDistance:{get:function(){return this._disableDepthTestDistance},set:function(t){this._disableDepthTestDistance!==t&&(this._disableDepthTestDistance=t,su(this,wpe))}},id:{get:function(){return this._id},set:function(t){this._id=t,c(this._pickId)&&(this._pickId.object.id=t)}},pickId:{get:function(){return this._pickId}},clusterShow:{get:function(){return this._clusterShow},set:function(t){this._clusterShow!==t&&(this._clusterShow=t,su(this,TUt))}}});hl.prototype.getPickId=function(t){return c(this._pickId)||(this._pickId=t.createPickId({primitive:this,collection:this._collection,id:this._id})),this._pickId};hl.prototype._getActualPosition=function(){return this._actualPosition};hl.prototype._setActualPosition=function(t){p.clone(t,this._actualPosition),su(this,EUt)};var SUt=new Rt;hl._computeActualPosition=function(t,e,n){return e.mode===ut.SCENE3D?t:(L.multiplyByPoint(n,t,SUt),qo.computeActualWgs84Position(e,SUt))};var gUt=new Rt;hl._computeScreenSpacePosition=function(t,e,n,i){let o=L.multiplyByVector(t,Rt.fromElements(e.x,e.y,e.z,1,gUt),gUt);return qo.wgs84ToWindowCoordinates(n,o,i)};hl.prototype.computeScreenSpacePosition=function(t,e){let n=this._pointPrimitiveCollection;c(e)||(e=new K);let i=n.modelMatrix,o=hl._computeScreenSpacePosition(i,this._actualPosition,t,e);if(c(o))return o.y=t.canvas.clientHeight-o.y,o};hl.getScreenSpaceBoundingBox=function(t,e,n){let i=t.pixelSize,o=i*.5,a=e.x-o,s=e.y-o,l=i,r=i;return c(n)||(n=new Fe),n.x=a,n.y=s,n.width=l,n.height=r,n};hl.prototype.equals=function(t){return this===t||c(t)&&this._id===t._id&&p.equals(this._position,t._position)&&v.equals(this._color,t._color)&&this._pixelSize===t._pixelSize&&this._outlineWidth===t._outlineWidth&&this._show===t._show&&v.equals(this._outlineColor,t._outlineColor)&&ln.equals(this._scaleByDistance,t._scaleByDistance)&&ln.equals(this._translucencyByDistance,t._translucencyByDistance)&&Wn.equals(this._distanceDisplayCondition,t._distanceDisplayCondition)&&this._disableDepthTestDistance===t._disableDepthTestDistance};hl.prototype._destroy=function(){this._pickId=this._pickId&&this._pickId.destroy(),this._pointPrimitiveCollection=void 0};var Er=hl;var rpi=R(W(),1);var Bhi=R(W(),1),GF=`in vec4 v_color; +Url: ${t._contentHeader.uri}`,o++;let a={text:i.substring(1),position:n,font:`${19-o}px sans-serif`,showBackground:!0,disableDepthTestDistance:Number.POSITIVE_INFINITY};return e._tileDebugLabels.add(a)}function ghe(t,e){let n=t._selectedTiles,i=n.length,o=t._emptyTiles,a=o.length;if(t._tileDebugLabels.removeAll(),t.debugPickedTileLabelOnly){if(c(t.debugPickedTile)){let s=c(t.debugPickPosition)?t.debugPickPosition:xtt(t.debugPickedTile),l=Xtt(t.debugPickedTile,t,s);l.pixelOffset=new K(15,-15)}}else{for(let s=0;s0;t._backfaceCommands.length=0,l&&(c(t._stencilClearCommand)||(t._stencilClearCommand=new ao({stencil:0,pass:Pt.CESIUM_3D_TILE,renderState:he.fromCache({stencilMask:gn.SKIP_LOD_MASK})})),i.push(t._stencilClearCommand));let{statistics:r,tileVisible:d}=t,m=n.isRender,h=i.length;for(let V=0;V=0;--U)i[h+F+U]=i[h+U];for(let U=0;U0&&t._pointCloudEyeDomeLighting.update(e,a,t.pointCloudShading,t.boundingSphere),t.debugShowGeometricError||t.debugShowRenderingStatistics||t.debugShowMemoryUsage||t.debugShowUrl?(c(t._tileDebugLabels)||(t._tileDebugLabels=new sR),ghe(t,e)):t._tileDebugLabels=t._tileDebugLabels&&t._tileDebugLabels.destroy())}var NFt=[];function Che(t,e){let n=e,i=NFt;for(i.push(e);i.length>0;){e=i.pop();let o=e.children;for(let a=0;a{e.push(on.clone(i))});let n=t.asset.extras;if(c(n)&&c(n.cesium)&&c(n.cesium.credits)){let i=n.cesium.credits;for(let o=0;oi.showOnScreen=i.showOnScreen||t._showCreditsOnScreen),t._credits=e}Fs.prototype.getTraversal=function(t){let{pass:e}=t;return e===ns.MOST_DETAILED_PRELOAD||e===ns.MOST_DETAILED_PICK?oJ:this.isSkippingLevelOfDetail?cJ:lJ};Fs.prototype.update=function(t){this.updateForPass(t,t.tilesetPassState)};Fs.prototype.updateForPass=function(t,e){let n=e.pass;if(n===ns.PRELOAD&&(!this.preloadWhenHidden||this.show)||n===ns.PRELOAD_FLIGHT&&(!this.preloadFlightDestinations||!this.show&&!this.preloadWhenHidden)||n===ns.REQUEST_RENDER_MODE_DEFER_CHECK&&(!this._cullRequestsWhileMoving&&this.foveatedTimeDelay<=0||!this.show))return;let i=t.commandList,o=t.camera,a=t.cullingVolume;e.ready=!1;let s=ns.getPassOptions(n),l=s.ignoreCommands,r=f(e.commandList,i),d=r.length;t.commandList=r,t.camera=f(e.camera,o),t.cullingVolume=f(e.cullingVolume,a);let m=this._clippingPolygons;c(m)&&m.enabled&&m.queueCommands(t);let h=this._statisticsPerPass[n];(this.show||l)&&(this._pass=n,e.ready=Qhe(this,t,h,s)),l&&(r.length=d),t.commandList=i,t.camera=o,t.cullingVolume=a};Fs.prototype.hasExtension=function(t){return c(this._extensionsUsed)?this._extensionsUsed.indexOf(t)>-1:!1};Fs.prototype.isDestroyed=function(){return!1};Fs.prototype.destroy=function(){if(this._tileDebugLabels=this._tileDebugLabels&&this._tileDebugLabels.destroy(),this._clippingPlanes=this._clippingPlanes&&this._clippingPlanes.destroy(),this._clippingPolygons=this._clippingPolygons&&this._clippingPolygons.destroy(),c(this._root)){let t=NFt;for(t.push(this._root);t.length>0;){let e=t.pop();e.destroy();let n=e.children;for(let i=0;i{let a=this._addHeightCallbacks,s=a.length;for(let l=0;l{let m=Ft.distanceSquaredTo(r.contentBoundingVolume.boundingSphere,t.origin),h=Ft.distanceSquaredTo(d.contentBoundingVolume.boundingSphere,t.origin);return m-h});let l;for(let r=0;r-1;i--)Jtt(this,t[i],e,n);return At(this)};RF.prototype.getBoundingSphere=function(t,e){let n=this._tilesetHash[t.id];if(!c(n)||n.loadFail)return ve.FAILED;let i=n.tilesetPrimitive;return c(i)?i.show?(Ft.clone(i.boundingSphere,e),ve.DONE):ve.FAILED:ve.PENDING};RF.prototype._onCollectionChanged=function(t,e,n,i){let o,a,s=this._entitiesToVisualize,l=this._tilesetHash,r=this._primitives;for(o=e.length-1;o>-1;o--)a=e[o],c(a._tileset)&&s.set(a.id,a);for(o=i.length-1;o>-1;o--)a=i[o],c(a._tileset)?s.set(a.id,a):(Jtt(this,a,l,r),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],Jtt(this,a,l,r),s.remove(a.id)};function Jtt(t,e,n,i){let o=n[e.id];c(o)&&(c(o.tilesetPrimitive)&&i.removeAndDestroy(o.tilesetPrimitive),delete n[e.id])}async function Mhe(t,e,n,i){e[n.id]={url:t.url,loadFail:!1};try{let o=await Pr.fromUrl(t);if(o.id=n,i.add(o),!c(e[n.id]))return;e[n.id].tilesetPrimitive=o}catch(o){console.error(o),e[n.id].loadFail=!0}}var mJ=RF;var sdi=b(W(),1);var _he=v.WHITE,Dhe=v.BLACK,Ohe=new K(2,2);function NC(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._evenColor=void 0,this._evenColorSubscription=void 0,this._oddColor=void 0,this._oddColorSubscription=void 0,this._repeat=void 0,this._repeatSubscription=void 0,this.evenColor=t.evenColor,this.oddColor=t.oddColor,this.repeat=t.repeat}Object.defineProperties(NC.prototype,{isConstant:{get:function(){return et.isConstant(this._evenColor)&&et.isConstant(this._oddColor)&&et.isConstant(this._repeat)}},definitionChanged:{get:function(){return this._definitionChanged}},evenColor:ft("evenColor"),oddColor:ft("oddColor"),repeat:ft("repeat")});NC.prototype.getType=function(t){return"Checkerboard"};NC.prototype.getValue=function(t,e){return c(e)||(e={}),e.lightColor=et.getValueOrClonedDefault(this._evenColor,t,_he,e.lightColor),e.darkColor=et.getValueOrClonedDefault(this._oddColor,t,Dhe,e.darkColor),e.repeat=et.getValueOrDefault(this._repeat,t,Ohe),e};NC.prototype.equals=function(t){return this===t||t instanceof NC&&et.equals(this._evenColor,t._evenColor)&&et.equals(this._oddColor,t._oddColor)&&et.equals(this._repeat,t._repeat)};var yC=NC;var hdi=b(W(),1);var Co={LEO:"Low Earth Orbit",MEO:"Medium Earth Orbit",HEO:"Highly Elliptical Orbit",GEO:"Geostationary Orbit",IGO:"Inclined Geosynchronous Orbit",EGO:"Extended Geostationary Orbit",GEOIADC:"IADC GEO Protected Region",GEOSYNC:"Geosynchronous Orbit",SUNSYNC:"Sun Synchronous Orbit",SEMISYNC:"Semi Synchronous Orbit",POLAR:"POLAR Orbit",UNKNOWN:"UNKNOWN"},Ltt=86164.0905;function Mtt(t){let e=[],n=t.properties.CAT.getValue(),i=t.properties.OMM.getValue(),o=i.SEMI_MAJOR_AXIS;if(n.PERIOD<128*60&&i.ECCENTRICITY<.25&&e.push(Co.LEO),o>36e3){let a=rt.now(),s=rt.addMinutes(a,1440,new rt),l=10,r=1/0,d=-1/0;for(let m=a;rt.lessThan(m,s);m=rt.addMinutes(m,l,new rt)){let h=t.position.getValue(m),{latitude:u}=gt.fromCartesian(h,mt.WGS84)||{latitude:0},R=k.toDegrees(u);r=Math.min(r,R),d=Math.max(d,R)}n.PERIOD>Ltt-60&&n.PERIOD=25&&i.INCLINATION<=180&&o>=37948&&o<=46380&&i.ECCENTRICITY<=.25&&e.push(Co.IGO),i.INCLINATION>=0&&i.INCLINATION<=25&&o>=37948&&o<=46380&&i.ECCENTRICITY<=.25&&e.push(Co.EGO),r>=-15&&d<=15&&n.PERIGEE>=35586&&n.PERIGEE<=35986&&e.push(Co.GEOIADC)}return n.PERIGEE>=2e3&&n.PERIGEE<35700?e.push(Co.MEO):n.PERIGEE>35786&&e.push(Co.HEO),i.INCLINATION>97&&i.INCLINATION<99&&e.push(Co.SUNSYNC),Math.abs(n.PERIOD-.5*Ltt)<1&&e.push(Co.SEMISYNC),i.INCLINATION>=80&&i.INCLINATION<=100&&e.push(Co.POLAR),e.length===0&&e.push(Co.UNKNOWN),e}var _tt=Mtt;var Idi=b(W(),1);var Gdi=b(W(),1);var QFt={id:void 0};function hJ(t){if(t._firing){t._refire=!0;return}if(t._suspendCount===0){let e=t._addedEntities,n=t._removedEntities,i=t._changedEntities;if(i.length!==0||e.length!==0||n.length!==0){t._firing=!0;do{t._refire=!1;let o=e.values.slice(0),a=n.values.slice(0),s=i.values.slice(0);e.removeAll(),n.removeAll(),i.removeAll(),t._collectionChanged.raiseEvent(t,o,a,s)}while(t._refire);t._firing=!1}}}function $d(t){this._owner=t,this._entities=new qe,this._addedEntities=new qe,this._removedEntities=new qe,this._changedEntities=new qe,this._suspendCount=0,this._collectionChanged=new It,this._id=Ti(),this._show=!0,this._firing=!1,this._refire=!1}$d.prototype.suspendEvents=function(){this._suspendCount++};$d.prototype.resumeEvents=function(){this._suspendCount--,hJ(this)};Object.defineProperties($d.prototype,{collectionChanged:{get:function(){return this._collectionChanged}},id:{get:function(){return this._id}},values:{get:function(){return this._entities.values}},show:{get:function(){return this._show},set:function(t){if(t===this._show)return;this.suspendEvents();let e,n=[],i=this._entities.values,o=i.length;for(e=0;e-1;r--)s=l[r],YFt(t,u,R,s);for(a=n-1;a>=0;a--)for(d=e[a],d.collectionChanged.addEventListener(ll.prototype._onCollectionChanged,t),l=d.values,R=d.id,r=l.length-1;r>-1;r--){s=l[r],kFt(t,u,R,s);let F=h.getById(s.id);c(F)||(F=m.getById(s.id),c(F)?Dtt(F):(SP.id=s.id,F=new qa(SP)),h.add(F)),F.merge(s)}t._collectionsCopy=e.slice(0),m.suspendEvents(),m.removeAll();let V=h.values;for(a=0;a=0;l--)r=i[l].getById(F),c(r)&&(c(d)||(d=a.getById(F),Dtt(d)),d.merge(r));c(d)||a.removeById(F),d=void 0}let R=e.length;for(s=0;s=0;l--)r=i[l].getById(F),c(r)&&(c(d)||(d=a.getById(F),c(d)?Dtt(d):(SP.id=F,d=new qa(SP),a.add(d))),d.merge(r));d=void 0}a.resumeEvents()};ll.prototype._onDefinitionChanged=function(t,e,n,i){let o=this._collections,a=this._composite,s=o.length,l=t.id,r=a.getById(l),d=r[e],m=!c(d),h=!0;for(let u=s-1;u>=0;u--){let R=o[u].getById(t.id);if(c(R)){let V=R[e];if(c(V)){if(h)if(h=!1,c(V.merge)&&c(V.clone))d=V.clone(d);else{d=V;break}d.merge(V)}}}m&&r.propertyNames.indexOf(e)===-1&&r.addProperty(e),r[e]=d};var Ott=ll;var nci=b(W(),1);var zdi=b(W(),1);var ydi=b(W(),1);function Htt(){this._removalFunctions=[]}Htt.prototype.add=function(t,e,n){let i=t.addEventListener(e,n);this._removalFunctions.push(i);let o=this;return function(){i();let a=o._removalFunctions;a.splice(a.indexOf(i),1)}};Htt.prototype.removeAll=function(){let t=this._removalFunctions;for(let e=0,n=t.length;e0&&(this._intervals.length=0,this._changedEvent.raiseEvent(this))};dl.prototype.findIntervalContainingDate=function(t){let e=this.indexOf(t);return e>=0?this._intervals[e]:void 0};dl.prototype.findDataForIntervalContainingDate=function(t){let e=this.indexOf(t);return e>=0?this._intervals[e].data:void 0};dl.prototype.contains=function(t){return this.indexOf(t)>=0};var wtt=new ai;dl.prototype.indexOf=function(t){let e=this._intervals;wtt.start=t,wtt.stop=t;let n=Ja(e,wtt,vtt);return n>=0?e[n].isStartIncluded?n:n>0&&e[n-1].stop.equals(t)&&e[n-1].isStopIncluded?n-1:~n:(n=~n,n>0&&n-10&&t.isStartIncluded&&n[i-1].isStartIncluded&&n[i-1].start.equals(t.start)?--i:i0&&(o=rt.compare(n[i-1].stop,t.start),(o>0||o===0&&(n[i-1].isStopIncluded||t.isStartIncluded))&&((c(e)?e(n[i-1].data,t.data):n[i-1].data===t.data)?(rt.greaterThan(t.stop,n[i-1].stop)?t=new ai({start:n[i-1].start,stop:t.stop,isStartIncluded:n[i-1].isStartIncluded,isStopIncluded:t.isStopIncluded,data:t.data}):t=new ai({start:n[i-1].start,stop:n[i-1].stop,isStartIncluded:n[i-1].isStartIncluded,isStopIncluded:n[i-1].isStopIncluded||t.stop.equals(n[i-1].stop)&&t.isStopIncluded,data:t.data}),n.splice(i-1,1),--i):(o=rt.compare(n[i-1].stop,t.stop),(o>0||o===0&&n[i-1].isStopIncluded&&!t.isStopIncluded)&&n.splice(i,0,new ai({start:t.stop,stop:n[i-1].stop,isStartIncluded:!t.isStopIncluded,isStopIncluded:n[i-1].isStopIncluded,data:n[i-1].data})),n[i-1]=new ai({start:n[i-1].start,stop:t.start,isStartIncluded:n[i-1].isStartIncluded,isStopIncluded:!t.isStartIncluded,data:n[i-1].data}))));i0||o===0&&(t.isStopIncluded||n[i].isStartIncluded));)if(c(e)?e(n[i].data,t.data):n[i].data===t.data)t=new ai({start:t.start,stop:rt.greaterThan(n[i].stop,t.stop)?n[i].stop:t.stop,isStartIncluded:t.isStartIncluded,isStopIncluded:rt.greaterThan(n[i].stop,t.stop)?n[i].isStopIncluded:t.isStopIncluded,data:t.data}),n.splice(i,1);else if(n[i]=new ai({start:t.stop,stop:n[i].stop,isStartIncluded:!t.isStopIncluded,isStopIncluded:n[i].isStopIncluded,data:n[i].data}),n[i].isEmpty)n.splice(i,1);else break;n.splice(i,0,t),this._changedEvent.raiseEvent(this)};dl.prototype.removeInterval=function(t){if(t.isEmpty)return!1;let e=this._intervals,n=Ja(e,t,vtt);n<0&&(n=~n);let i=!1;for(n>0&&(rt.greaterThan(e[n-1].stop,t.start)||e[n-1].stop.equals(t.start)&&e[n-1].isStopIncluded&&t.isStartIncluded)&&(i=!0,(rt.greaterThan(e[n-1].stop,t.stop)||e[n-1].isStopIncluded&&!t.isStopIncluded&&e[n-1].stop.equals(t.stop))&&e.splice(n,0,new ai({start:t.stop,stop:e[n-1].stop,isStartIncluded:!t.isStopIncluded,isStopIncluded:e[n-1].isStopIncluded,data:e[n-1].data})),e[n-1]=new ai({start:e[n-1].start,stop:t.start,isStartIncluded:e[n-1].isStartIncluded,isStopIncluded:!t.isStartIncluded,data:e[n-1].data})),n=1e3&&(o+=Math.floor(i/1e3),i=i%1e3),o>=60&&(a+=Math.floor(o/60),o=o%60),a>=60&&(s+=Math.floor(a/60),a=a%60),s>=24&&(l+=Math.floor(s/24),s=s%24),pJ[2]=PV(d)?29:28;l>pJ[r]||r>=13;)l>pJ[r]&&(l-=pJ[r],++r),r>=13&&(--r,d+=Math.floor(r/12),r=r%12,++r),pJ[2]=PV(d)?29:28;return tc.millisecond=i,tc.second=o,tc.minute=a,tc.hour=s,tc.day=l,tc.month=r,tc.year=d,rt.fromGregorianDate(tc,n)}var Hhe=new rt,whe=/P(?:([\d.,]+)Y)?(?:([\d.,]+)M)?(?:([\d.,]+)W)?(?:([\d.,]+)D)?(?:T(?:([\d.,]+)H)?(?:([\d.,]+)M)?(?:([\d.,]+)S)?)?/;function XFt(t,e){if(!c(t)||t.length===0)return!1;if(e.year=0,e.month=0,e.day=0,e.hour=0,e.minute=0,e.second=0,e.millisecond=0,t[0]==="P"){let n=t.match(whe);if(!c(n))return!1;if(c(n[1])&&(e.year=Number(n[1].replace(",","."))),c(n[2])&&(e.month=Number(n[2].replace(",","."))),c(n[3])&&(e.day=Number(n[3].replace(",","."))*7),c(n[4])&&(e.day+=Number(n[4].replace(",","."))),c(n[5])&&(e.hour=Number(n[5].replace(",","."))),c(n[6])&&(e.minute=Number(n[6].replace(",","."))),c(n[7])){let i=Number(n[7].replace(",","."));e.second=Math.floor(i),e.millisecond=i%1*1e3}}else t[t.length-1]!=="Z"&&(t+="Z"),rt.toGregorianDate(rt.fromIso8601(t,Hhe),e);return e.year||e.month||e.day||e.hour||e.minute||e.second||e.millisecond}var VJ=new Wb;dl.fromIso8601=function(t,e){let n=t.iso8601.split("/"),i=rt.fromIso8601(n[0]),o=rt.fromIso8601(n[1]),a=[];if(!XFt(n[2],VJ))a.push(i,o);else{let s=rt.clone(i);for(a.push(s);rt.compare(s,o)<0;)s=Ptt(s,VJ),rt.compare(o,s)<=0&&rt.clone(o,s),a.push(s)}return dl.fromJulianDateArray({julianDates:a,isStartIncluded:t.isStartIncluded,isStopIncluded:t.isStopIncluded,leadingInterval:t.leadingInterval,trailingInterval:t.trailingInterval,dataCallback:t.dataCallback},e)};dl.fromIso8601DateArray=function(t,e){return dl.fromJulianDateArray({julianDates:t.iso8601Dates.map(function(n){return rt.fromIso8601(n)}),isStartIncluded:t.isStartIncluded,isStopIncluded:t.isStopIncluded,leadingInterval:t.leadingInterval,trailingInterval:t.trailingInterval,dataCallback:t.dataCallback},e)};dl.fromIso8601DurationArray=function(t,e){let n=t.epoch,i=t.iso8601Durations,o=f(t.relativeToPrevious,!1),a=[],s,l,r=i.length;for(let d=0;d=0?-l:l}var spe=new p(-1,0,0),oS=new L,lpe=new L,jtt=new ot,rpe=ot.IDENTITY.clone(),dpe=new p,cpe=new bt,JFt=new p;function Q0(t,e,n,i,o,a,s,l){let r=dpe,d=cpe;oS=Pe.eastNorthUpToFixedFrame(t,o,oS),r=L.multiplyByPointAsVector(oS,spe,r),r=p.normalize(r,r);let m=ape(r,e,t,o);jtt=ot.fromRotationZ(m,jtt),JFt.z=a,oS=L.multiplyTransformation(oS,L.fromRotationTranslation(jtt,JFt,lpe),oS);let h=rpe;h[0]=s;for(let u=0;u0){let F=d?2:1;for(let U=0;U=0};var ppe=new p,Vpe=new p;uJ.computePositions=function(t,e,n,i,o){let a=i._ellipsoid,s=ope(t,a),l=i._granularity,r=i._cornerType,d=o?hpe(e,n):LFt(e,n),m=o?LFt(e,n):void 0,h=n.height/2,u=n.width/2,R=t.length,V=[],F=o?[]:void 0,U=Khe,G=zhe,A=jhe,S=qhe,g=$he,C=tpe,y=epe,Y=npe,Q=ipe,J=t[0],M=t[1];S=a.geodeticSurfaceNormal(J,S),U=p.subtract(M,J,U),U=p.normalize(U,U),Y=p.cross(S,U,Y),Y=p.normalize(Y,Y);let Z=s[0],E=s[1];o&&(F=Q0(J,Y,m,F,a,Z+h,1,1)),Q=p.clone(J,Q),J=M,G=p.negate(U,G);let I,B;for(let P=1;PMt;u--)kt=k.PI_OVER_TWO-u*Nt,st[Wt++]=1-Et*(1+Math.cos(kt)),st[Wt++]=.5*(1+Math.sin(kt));for(u=Mt;u>0;u--)kt=k.PI_OVER_TWO-Nt*u,st[Wt++]=1-Qt*(1+Math.cos(kt)),st[Wt++]=.5*(1+Math.sin(kt));for(u=m-U;u>0;u--)st[Wt++]=u*Qt,st[Wt++]=1;for(u=1;u0;u--)st[Wt++]=(u-1)*Qt,st[Wt++]=1}r.st=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:st})}return e.normal&&(r.normal=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:y.normals})),e.tangent&&(r.tangent=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:y.tangents})),e.bitangent&&(r.bitangent=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:y.bitangents})),{attributes:r,indices:w}}function gpe(t,e){if(!e.normal&&!e.tangent&&!e.bitangent&&!e.st)return t;let n=t.position.values,i,o;(e.normal||e.bitangent)&&(i=t.normal.values,o=t.bitangent.values);let a=t.position.values.length/18,s=a*3,l=a*2,r=s*2,d;if(e.normal||e.bitangent||e.tangent){let m=e.normal?new Float32Array(s*6):void 0,h=e.tangent?new Float32Array(s*6):void 0,u=e.bitangent?new Float32Array(s*6):void 0,R=eUt,V=nUt,F=NP,U=yP,G=Tpe,A=iUt,S=r;for(d=0;d-e?(o=Qpe,o.x=this._cameraPosition.x/(n.radii.x+e),o.y=this._cameraPosition.y/(n.radii.y+e),o.z=this._cameraPosition.z/(n.radii.z+e),i=o.x*o.x+o.y*o.y+o.z*o.z-1):(o=this._cameraPositionInScaledSpace,i=this._distanceToLimbInScaledSpaceSquared),iet(t,o,i)};mR.prototype.computeHorizonCullingPoint=function(t,e,n){return fUt(this._ellipsoid,t,e,n)};var bUt=mt.clone(mt.UNIT_SPHERE);mR.prototype.computeHorizonCullingPointPossiblyUnderEllipsoid=function(t,e,n,i){let o=WUt(this._ellipsoid,n,bUt);return fUt(o,t,e,i)};mR.prototype.computeHorizonCullingPointFromVertices=function(t,e,n,i,o){return FUt(this._ellipsoid,t,e,n,i,o)};mR.prototype.computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid=function(t,e,n,i,o,a){let s=WUt(this._ellipsoid,o,bUt);return FUt(s,t,e,n,i,a)};var kpe=[];mR.prototype.computeHorizonCullingPointFromRectangle=function(t,e,n){let i=Gt.subsample(t,e,0,kpe),o=Ft.fromPoints(i);if(!(p.magnitude(o.center)<.1*e.minimumRadius))return this.computeHorizonCullingPoint(o.center,i,n)};var Ype=new p;function WUt(t,e,n){if(c(e)&&e<0&&t.minimumRadius>-e){let i=p.fromElements(t.radii.x+e,t.radii.y+e,t.radii.z+e,Ype);t=mt.fromCartesian3(i,n)}return t}function fUt(t,e,n,i){c(i)||(i=new p);let o=AUt(t,e),a=0;for(let s=0,l=n.length;s0:s>o&&s*s/p.magnitudeSquared(a)>o)}var xpe=new p,Xpe=new p;function UUt(t,e,n){let i=t.transformPositionToScaledSpace(e,xpe),o=p.magnitudeSquared(i),a=Math.sqrt(o),s=p.divideByScalar(i,a,Xpe);o=Math.max(1,o),a=Math.max(1,a);let l=p.dot(s,n),r=p.magnitude(p.cross(s,n,s)),d=1/a,m=Math.sqrt(o-1)*d;return 1/(l*d-r*m)}function GUt(t,e,n){if(!(e<=0||e===1/0||e!==e))return p.multiplyByScalar(t,e,n)}var net=new p;function AUt(t,e){return p.equals(e,p.ZERO)?e:(t.transformPositionToScaledSpace(e,net),p.normalize(net,net))}var Bu=mR;var Nhi=b(W(),1);function hl(t,e){t=f(t,f.EMPTY_OBJECT);let n=t.translucencyByDistance,i=t.scaleByDistance,o=t.distanceDisplayCondition;c(n)&&(n=ln.clone(n)),c(i)&&(i=ln.clone(i)),c(o)&&(o=Wn.clone(o)),this._show=f(t.show,!0),this._position=p.clone(f(t.position,p.ZERO)),this._actualPosition=p.clone(this._position),this._color=v.clone(f(t.color,v.WHITE)),this._outlineColor=v.clone(f(t.outlineColor,v.TRANSPARENT)),this._outlineWidth=f(t.outlineWidth,0),this._pixelSize=f(t.pixelSize,10),this._scaleByDistance=i,this._translucencyByDistance=n,this._distanceDisplayCondition=o,this._disableDepthTestDistance=f(t.disableDepthTestDistance,0),this._id=t.id,this._collection=f(t.collection,e),this._clusterShow=!0,this._pickId=void 0,this._pointPrimitiveCollection=e,this._dirty=!1,this._index=-1}var SUt=hl.SHOW_INDEX=0,EUt=hl.POSITION_INDEX=1,Jpe=hl.COLOR_INDEX=2,Lpe=hl.OUTLINE_COLOR_INDEX=3,Mpe=hl.OUTLINE_WIDTH_INDEX=4,_pe=hl.PIXEL_SIZE_INDEX=5,Dpe=hl.SCALE_BY_DISTANCE_INDEX=6,Ope=hl.TRANSLUCENCY_BY_DISTANCE_INDEX=7,Hpe=hl.DISTANCE_DISPLAY_CONDITION_INDEX=8,wpe=hl.DISABLE_DEPTH_DISTANCE_INDEX=9;hl.NUMBER_OF_PROPERTIES=10;function sV(t,e){let n=t._pointPrimitiveCollection;c(n)&&(n._updatePointPrimitive(t,e),t._dirty=!0)}Object.defineProperties(hl.prototype,{show:{get:function(){return this._show},set:function(t){this._show!==t&&(this._show=t,sV(this,SUt))}},position:{get:function(){return this._position},set:function(t){let e=this._position;p.equals(e,t)||(p.clone(t,e),p.clone(t,this._actualPosition),sV(this,EUt))}},scaleByDistance:{get:function(){return this._scaleByDistance},set:function(t){let e=this._scaleByDistance;ln.equals(e,t)||(this._scaleByDistance=ln.clone(t,e),sV(this,Dpe))}},translucencyByDistance:{get:function(){return this._translucencyByDistance},set:function(t){let e=this._translucencyByDistance;ln.equals(e,t)||(this._translucencyByDistance=ln.clone(t,e),sV(this,Ope))}},pixelSize:{get:function(){return this._pixelSize},set:function(t){this._pixelSize!==t&&(this._pixelSize=t,sV(this,_pe))}},color:{get:function(){return this._color},set:function(t){let e=this._color;v.equals(e,t)||(v.clone(t,e),sV(this,Jpe))}},outlineColor:{get:function(){return this._outlineColor},set:function(t){let e=this._outlineColor;v.equals(e,t)||(v.clone(t,e),sV(this,Lpe))}},outlineWidth:{get:function(){return this._outlineWidth},set:function(t){this._outlineWidth!==t&&(this._outlineWidth=t,sV(this,Mpe))}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){Wn.equals(this._distanceDisplayCondition,t)||(this._distanceDisplayCondition=Wn.clone(t,this._distanceDisplayCondition),sV(this,Hpe))}},disableDepthTestDistance:{get:function(){return this._disableDepthTestDistance},set:function(t){this._disableDepthTestDistance!==t&&(this._disableDepthTestDistance=t,sV(this,wpe))}},id:{get:function(){return this._id},set:function(t){this._id=t,c(this._pickId)&&(this._pickId.object.id=t)}},pickId:{get:function(){return this._pickId}},clusterShow:{get:function(){return this._clusterShow},set:function(t){this._clusterShow!==t&&(this._clusterShow=t,sV(this,SUt))}}});hl.prototype.getPickId=function(t){return c(this._pickId)||(this._pickId=t.createPickId({primitive:this,collection:this._collection,id:this._id})),this._pickId};hl.prototype._getActualPosition=function(){return this._actualPosition};hl.prototype._setActualPosition=function(t){p.clone(t,this._actualPosition),sV(this,EUt)};var TUt=new bt;hl._computeActualPosition=function(t,e,n){return e.mode===Vt.SCENE3D?t:(L.multiplyByPoint(n,t,TUt),qo.computeActualWgs84Position(e,TUt))};var gUt=new bt;hl._computeScreenSpacePosition=function(t,e,n,i){let o=L.multiplyByVector(t,bt.fromElements(e.x,e.y,e.z,1,gUt),gUt);return qo.wgs84ToWindowCoordinates(n,o,i)};hl.prototype.computeScreenSpacePosition=function(t,e){let n=this._pointPrimitiveCollection;c(e)||(e=new K);let i=n.modelMatrix,o=hl._computeScreenSpacePosition(i,this._actualPosition,t,e);if(c(o))return o.y=t.canvas.clientHeight-o.y,o};hl.getScreenSpaceBoundingBox=function(t,e,n){let i=t.pixelSize,o=i*.5,a=e.x-o,s=e.y-o,l=i,r=i;return c(n)||(n=new Fe),n.x=a,n.y=s,n.width=l,n.height=r,n};hl.prototype.equals=function(t){return this===t||c(t)&&this._id===t._id&&p.equals(this._position,t._position)&&v.equals(this._color,t._color)&&this._pixelSize===t._pixelSize&&this._outlineWidth===t._outlineWidth&&this._show===t._show&&v.equals(this._outlineColor,t._outlineColor)&&ln.equals(this._scaleByDistance,t._scaleByDistance)&&ln.equals(this._translucencyByDistance,t._translucencyByDistance)&&Wn.equals(this._distanceDisplayCondition,t._distanceDisplayCondition)&&this._disableDepthTestDistance===t._disableDepthTestDistance};hl.prototype._destroy=function(){this._pickId=this._pickId&&this._pickId.destroy(),this._pointPrimitiveCollection=void 0};var Er=hl;var rpi=b(W(),1);var Bhi=b(W(),1),GF=`in vec4 v_color; in vec4 v_outlineColor; in float v_innerPercent; in float v_pixelDistance; @@ -8831,7 +8831,7 @@ void main() out_FragColor = czm_gammaCorrect(color); czm_writeLogDepth(); } -`;var khi=R(W(),1),FJ=`uniform float u_maxTotalPointSize; +`;var khi=b(W(),1),FJ=`uniform float u_maxTotalPointSize; in vec4 positionHighAndSize; in vec4 positionLowAndOutline; @@ -9014,27 +9014,27 @@ void main() v_pickColor = pickColor; } -`;var Ppe=Er.SHOW_INDEX,set=Er.POSITION_INDEX,CUt=Er.COLOR_INDEX,vpe=Er.OUTLINE_COLOR_INDEX,Kpe=Er.OUTLINE_WIDTH_INDEX,zpe=Er.PIXEL_SIZE_INDEX,IUt=Er.SCALE_BY_DISTANCE_INDEX,NUt=Er.TRANSLUCENCY_BY_DISTANCE_INDEX,yUt=Er.DISTANCE_DISPLAY_CONDITION_INDEX,jpe=Er.DISABLE_DEPTH_DISTANCE_INDEX,ret=Er.NUMBER_OF_PROPERTIES,nc={positionHighAndSize:0,positionLowAndOutline:1,compressedAttribute0:2,compressedAttribute1:3,scaleByDistance:4,distanceDisplayConditionAndDisableDepth:5};function lu(t){t=f(t,f.EMPTY_OBJECT),this._sp=void 0,this._spTranslucent=void 0,this._rsOpaque=void 0,this._rsTranslucent=void 0,this._vaf=void 0,this._pointPrimitives=[],this._pointPrimitivesToUpdate=[],this._pointPrimitivesToUpdateIndex=0,this._pointPrimitivesRemoved=!1,this._createVertexArray=!1,this._shaderScaleByDistance=!1,this._compiledShaderScaleByDistance=!1,this._shaderTranslucencyByDistance=!1,this._compiledShaderTranslucencyByDistance=!1,this._shaderDistanceDisplayCondition=!1,this._compiledShaderDistanceDisplayCondition=!1,this._shaderDisableDepthDistance=!1,this._compiledShaderDisableDepthDistance=!1,this._propertiesChanged=new Uint32Array(ret),this._maxPixelSize=1,this._baseVolume=new Ft,this._baseVolumeWC=new Ft,this._baseVolume2D=new Ft,this._boundingVolume=new Ft,this._boundingVolumeDirty=!1,this._colorCommands=[],this.show=f(t.show,!0),this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._modelMatrix=L.clone(L.IDENTITY),this.debugShowBoundingVolume=f(t.debugShowBoundingVolume,!1),this.blendOption=f(t.blendOption,wa.OPAQUE_AND_TRANSLUCENT),this._blendOption=void 0,this._mode=ut.SCENE3D,this._maxTotalPointSize=1,this._buffersUsage=[ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW];let e=this;this._uniforms={u_maxTotalPointSize:function(){return e._maxTotalPointSize}}}Object.defineProperties(lu.prototype,{length:{get:function(){return det(this),this._pointPrimitives.length}}});function BUt(t){let e=t.length;for(let n=0;n0&&(t._shaderDisableDepthDistance=!0,d===Number.POSITIVE_INFINITY&&(d=-1)),a(o,s,l,d)}function $pe(t,e,n,i){QUt(t,e,n,i),kUt(t,e,n,i),YUt(t,e,n,i),xUt(t,e,n,i),XUt(t,e,n,i)}function aet(t,e,n,i,o,a){let s;i.mode===ut.SCENE3D?(s=t._baseVolume,t._boundingVolumeDirty=!0):s=t._baseVolume2D;let l=[];for(let r=0;r0){this._vaf=qpe(r,n,this._buffersUsage),l=this._vaf.writers;for(let C=0;C0){let C=nue;C.length=0,(a[set]||a[Kpe]||a[zpe])&&C.push(QUt),(a[CUt]||a[vpe])&&C.push(kUt),(a[Ppe]||a[NUt])&&C.push(YUt),a[IUt]&&C.push(xUt),(a[yUt]||a[jpe])&&C.push(XUt);let y=C.length;if(l=this._vaf.writers,o/n>.1){for(let Y=0;Yn*1.5&&(i.length=n),!c(this._vaf)||!c(this._vaf.va))return;this._boundingVolumeDirty&&(this._boundingVolumeDirty=!1,Ft.transform(this._baseVolume,this.modelMatrix,this._baseVolumeWC));let h,Z=L.IDENTITY;t.mode===ut.SCENE3D?(Z=this.modelMatrix,h=Ft.clone(this._baseVolumeWC,this._boundingVolume)):h=Ft.clone(this._baseVolume2D,this._boundingVolume),eue(this,t,h);let b=this._blendOption!==this.blendOption;this._blendOption=this.blendOption,b&&(this._blendOption===wa.OPAQUE||this._blendOption===wa.OPAQUE_AND_TRANSLUCENT?this._rsOpaque=he.fromCache({depthTest:{enabled:!0,func:pt.LEQUAL},depthMask:!0}):this._rsOpaque=void 0,this._blendOption===wa.TRANSLUCENT||this._blendOption===wa.OPAQUE_AND_TRANSLUCENT?this._rsTranslucent=he.fromCache({depthTest:{enabled:!0,func:pt.LEQUAL},depthMask:!1,blending:Pn.ALPHA_BLEND}):this._rsTranslucent=void 0),this._shaderDisableDepthDistance=this._shaderDisableDepthDistance||t.minimumDisableDepthTestDistance!==0;let u,F;(b||this._shaderScaleByDistance&&!this._compiledShaderScaleByDistance||this._shaderTranslucencyByDistance&&!this._compiledShaderTranslucencyByDistance||this._shaderDistanceDisplayCondition&&!this._compiledShaderDistanceDisplayCondition||this._shaderDisableDepthDistance!==this._compiledShaderDisableDepthDistance)&&(u=new Ve({sources:[FJ]}),this._shaderScaleByDistance&&u.defines.push("EYE_DISTANCE_SCALING"),this._shaderTranslucencyByDistance&&u.defines.push("EYE_DISTANCE_TRANSLUCENCY"),this._shaderDistanceDisplayCondition&&u.defines.push("DISTANCE_DISPLAY_CONDITION"),this._shaderDisableDepthDistance&&u.defines.push("DISABLE_DEPTH_DISTANCE"),this._blendOption===wa.OPAQUE_AND_TRANSLUCENT&&(F=new Ve({defines:["OPAQUE"],sources:[GF]}),this._sp=xn.replaceCache({context:r,shaderProgram:this._sp,vertexShaderSource:u,fragmentShaderSource:F,attributeLocations:nc}),F=new Ve({defines:["TRANSLUCENT"],sources:[GF]}),this._spTranslucent=xn.replaceCache({context:r,shaderProgram:this._spTranslucent,vertexShaderSource:u,fragmentShaderSource:F,attributeLocations:nc})),this._blendOption===wa.OPAQUE&&(F=new Ve({sources:[GF]}),this._sp=xn.replaceCache({context:r,shaderProgram:this._sp,vertexShaderSource:u,fragmentShaderSource:F,attributeLocations:nc})),this._blendOption===wa.TRANSLUCENT&&(F=new Ve({sources:[GF]}),this._spTranslucent=xn.replaceCache({context:r,shaderProgram:this._spTranslucent,vertexShaderSource:u,fragmentShaderSource:F,attributeLocations:nc})),this._compiledShaderScaleByDistance=this._shaderScaleByDistance,this._compiledShaderTranslucencyByDistance=this._shaderTranslucencyByDistance,this._compiledShaderDistanceDisplayCondition=this._shaderDistanceDisplayCondition,this._compiledShaderDisableDepthDistance=this._shaderDisableDepthDistance);let U,G,A,T,g=t.commandList;if(d.render||m){let C=this._colorCommands,y=this._blendOption===wa.OPAQUE,Y=this._blendOption===wa.OPAQUE_AND_TRANSLUCENT;U=this._vaf.va,G=U.length,C.length=G;let Q=Y?G*2:G;for(T=0;T>4;if(o!==cet)throw new Error(`Got v${o} data when expected v${cet}.`);let a=JUt[i&15];if(!a)throw new Error("Unrecognized array type.");let[s]=new Uint16Array(e,2,1),[l]=new Uint32Array(e,4,1);return new t(l,s,a,e)}constructor(e,n=64,i=Float64Array,o){if(isNaN(e)||e<0)throw new Error(`Unpexpected numItems value: ${e}.`);this.numItems=+e,this.nodeSize=Math.min(Math.max(+n,2),65535),this.ArrayType=i,this.IndexArrayType=e<65536?Uint16Array:Uint32Array;let a=JUt.indexOf(this.ArrayType),s=e*2*this.ArrayType.BYTES_PER_ELEMENT,l=e*this.IndexArrayType.BYTES_PER_ELEMENT,r=(8-l%8)%8;if(a<0)throw new Error(`Unexpected typed array class: ${i}.`);o&&o instanceof ArrayBuffer?(this.data=o,this.ids=new this.IndexArrayType(this.data,GJ,e),this.coords=new this.ArrayType(this.data,GJ+l+r,e*2),this._pos=e*2,this._finished=!0):(this.data=new ArrayBuffer(GJ+s+l+r),this.ids=new this.IndexArrayType(this.data,GJ,e),this.coords=new this.ArrayType(this.data,GJ+l+r,e*2),this._pos=0,this._finished=!1,new Uint8Array(this.data,0,2).set([219,(cet<<4)+a]),new Uint16Array(this.data,2,1)[0]=n,new Uint32Array(this.data,4,1)[0]=e)}add(e,n){let i=this._pos>>1;return this.ids[i]=i,this.coords[this._pos++]=e,this.coords[this._pos++]=n,i}finish(){let e=this._pos>>1;if(e!==this.numItems)throw new Error(`Added ${e} items when expected ${this.numItems}.`);return het(this.ids,this.coords,this.nodeSize,0,this.numItems-1,0),this._finished=!0,this}range(e,n,i,o){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");let{ids:a,coords:s,nodeSize:l}=this,r=[0,a.length-1,0],d=[];for(;r.length;){let m=r.pop()||0,h=r.pop()||0,Z=r.pop()||0;if(h-Z<=l){for(let U=Z;U<=h;U++){let G=s[2*U],A=s[2*U+1];G>=e&&G<=i&&A>=n&&A<=o&&d.push(a[U])}continue}let b=Z+h>>1,u=s[2*b],F=s[2*b+1];u>=e&&u<=i&&F>=n&&F<=o&&d.push(a[b]),(m===0?e<=u:n<=F)&&(r.push(Z),r.push(b-1),r.push(1-m)),(m===0?i>=u:o>=F)&&(r.push(b+1),r.push(h),r.push(1-m))}return d}within(e,n,i){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");let{ids:o,coords:a,nodeSize:s}=this,l=[0,o.length-1,0],r=[],d=i*i;for(;l.length;){let m=l.pop()||0,h=l.pop()||0,Z=l.pop()||0;if(h-Z<=s){for(let U=Z;U<=h;U++)LUt(a[2*U],a[2*U+1],e,n)<=d&&r.push(o[U]);continue}let b=Z+h>>1,u=a[2*b],F=a[2*b+1];LUt(u,F,e,n)<=d&&r.push(o[b]),(m===0?e-i<=u:n-i<=F)&&(l.push(Z),l.push(b-1),l.push(1-m)),(m===0?e+i>=u:n+i>=F)&&(l.push(b+1),l.push(h),l.push(1-m))}return r}};function het(t,e,n,i,o,a){if(o-i<=n)return;let s=i+o>>1;MUt(t,e,s,i,o,a),het(t,e,n,i,s-1,1-a),het(t,e,n,s+1,o,1-a)}function MUt(t,e,n,i,o,a){for(;o>i;){if(o-i>600){let d=o-i+1,m=n-i+1,h=Math.log(d),Z=.5*Math.exp(2*h/3),b=.5*Math.sqrt(h*Z*(d-Z)/d)*(m-d/2<0?-1:1),u=Math.max(i,Math.floor(n-m*Z/d+b)),F=Math.min(o,Math.floor(n+(d-m)*Z/d+b));MUt(t,e,n,u,F,a)}let s=e[2*n+a],l=i,r=o;for(AJ(t,e,i,n),e[2*o+a]>s&&AJ(t,e,i,o);ls;)r--}e[2*i+a]===s?AJ(t,e,i,r):(r++,AJ(t,e,r,o)),r<=n&&(i=r+1),n<=r&&(o=r-1)}}function AJ(t,e,n,i){met(t,n,i),met(e,2*n,2*i),met(e,2*n+1,2*i+1)}function met(t,e,n){let i=t[e];t[e]=t[n],t[n]=i}function LUt(t,e,n,i){let o=t-n,a=e-i;return o*o+a*a}function QZ(t){t=f(t,f.EMPTY_OBJECT),this._enabled=f(t.enabled,!1),this._pixelRange=f(t.pixelRange,80),this._minimumClusterSize=f(t.minimumClusterSize,2),this._clusterBillboards=f(t.clusterBillboards,!0),this._clusterLabels=f(t.clusterLabels,!0),this._clusterPoints=f(t.clusterPoints,!0),this._labelCollection=void 0,this._billboardCollection=void 0,this._pointCollection=void 0,this._clusterBillboardCollection=void 0,this._clusterLabelCollection=void 0,this._clusterPointCollection=void 0,this._collectionIndicesByEntity={},this._unusedLabelIndices=[],this._unusedBillboardIndices=[],this._unusedPointIndices=[],this._previousClusters=[],this._previousHeight=void 0,this._enabledDirty=!1,this._clusterDirty=!1,this._cluster=void 0,this._removeEventListener=void 0,this._clusterEvent=new It,this.show=f(t.show,!0)}function _Ut(t,e){t.x-=e,t.y-=e,t.width+=e*2,t.height+=e*2}var iue=new Fe;function DUt(t,e,n,i,o){if(c(t._labelCollection)&&i._clusterLabels?o=cF.getScreenSpaceBoundingBox(t,e,o):c(t._billboardCollection)&&i._clusterBillboards?o=Na.getScreenSpaceBoundingBox(t,e,o):c(t._pointPrimitiveCollection)&&i._clusterPoints&&(o=Er.getScreenSpaceBoundingBox(t,e,o)),_Ut(o,n),i._clusterLabels&&!c(t._labelCollection)&&c(t.id)&&HUt(i,t.id.id)&&c(t.id._label)){let a=i._collectionIndicesByEntity[t.id.id].labelIndex,s=i._labelCollection.get(a),l=cF.getScreenSpaceBoundingBox(s,e,iue);_Ut(l,n),o=Fe.union(o,l,o)}return o}function oue(t,e){if(t.clusterShow=!0,!c(t._labelCollection)&&c(t.id)&&HUt(e,t.id.id)&&c(t.id._label)){let n=e._collectionIndicesByEntity[t.id.id].labelIndex,i=e._labelCollection.get(n);i.clusterShow=!0}}function OUt(t,e,n,i){let o={billboard:i._clusterBillboardCollection.add(),label:i._clusterLabelCollection.add(),point:i._clusterPointCollection.add()};o.billboard.show=!1,o.point.show=!1,o.label.show=!0,o.label.text=e.toLocaleString(),o.label.id=n,o.billboard.position=o.label.position=o.point.position=t,i._clusterEvent.raiseEvent(n,o)}function HUt(t,e){return c(t)&&c(t._collectionIndicesByEntity[e])&&c(t._collectionIndicesByEntity[e].labelIndex)}function pet(t,e,n,i,o){if(!c(t))return;let a=t.length;for(let s=0;s0){let X=new TJ(A.length,64,Uint32Array);for(let _=0;_=m)for(OUt(_.position,E,V,t),Z.push(_),g=0;g=m){let H=p.multiplyByScalar(z,1/E,z);for(OUt(H,E,V,t),Z.push({position:H,width:w.width,height:w.height,minimumWidth:y.width,minimumHeight:y.height}),g=0;g0?(l=d.shift(),r=a.get(l)):(r=a.add(),l=a.length-1),s[i]=l;let m=this;return Promise.resolve().then(function(){m._clusterDirty=!0}),r}}function Vet(t,e){let n=t._collectionIndicesByEntity[e];!c(n.billboardIndex)&&!c(n.labelIndex)&&!c(n.pointIndex)&&delete t._collectionIndicesByEntity[e]}QZ.prototype.getLabel=Zet("_labelCollection",sb,"_unusedLabelIndices","labelIndex");QZ.prototype.removeLabel=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!c(this._labelCollection)||!c(e)||!c(e.labelIndex))return;let n=e.labelIndex;e.labelIndex=void 0,Vet(this,t.id);let i=this._labelCollection.get(n);i.show=!1,i.text="",i.id=void 0,this._unusedLabelIndices.push(n),this._clusterDirty=!0};QZ.prototype.getBillboard=Zet("_billboardCollection",yh,"_unusedBillboardIndices","billboardIndex");QZ.prototype.removeBillboard=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!c(this._billboardCollection)||!c(e)||!c(e.billboardIndex))return;let n=e.billboardIndex;e.billboardIndex=void 0,Vet(this,t.id);let i=this._billboardCollection.get(n);i.id=void 0,i.show=!1,i.image=void 0,this._unusedBillboardIndices.push(n),this._clusterDirty=!0};QZ.prototype.getPoint=Zet("_pointCollection",JC,"_unusedPointIndices","pointIndex");QZ.prototype.removePoint=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!c(this._pointCollection)||!c(e)||!c(e.pointIndex))return;let n=e.pointIndex;e.pointIndex=void 0,Vet(this,t.id);let i=this._pointCollection.get(n);i.show=!1,i.id=void 0,this._unusedPointIndices.push(n),this._clusterDirty=!0};function uet(t){if(!c(t))return;let e=t.length;for(let n=0;n0&&this._labelCollection.get(0)._glyphs.length===0&&(e=t.commandList,t.commandList=[],this._labelCollection.update(t),t.commandList=e),c(this._billboardCollection)&&this._billboardCollection.length>0&&!c(this._billboardCollection.get(0).width)&&(e=t.commandList,t.commandList=[],this._billboardCollection.update(t),t.commandList=e),this._enabledDirty&&(this._enabledDirty=!1,due(this),this._clusterDirty=!0),this._clusterDirty&&(this._clusterDirty=!1,this._cluster()),c(this._clusterLabelCollection)&&this._clusterLabelCollection.update(t),c(this._clusterBillboardCollection)&&this._clusterBillboardCollection.update(t),c(this._clusterPointCollection)&&this._clusterPointCollection.update(t),c(this._labelCollection)&&this._labelCollection.update(t),c(this._billboardCollection)&&this._billboardCollection.update(t),c(this._pointCollection)&&this._pointCollection.update(t)};QZ.prototype.destroy=function(){this._labelCollection=this._labelCollection&&this._labelCollection.destroy(),this._billboardCollection=this._billboardCollection&&this._billboardCollection.destroy(),this._pointCollection=this._pointCollection&&this._pointCollection.destroy(),this._clusterLabelCollection=this._clusterLabelCollection&&this._clusterLabelCollection.destroy(),this._clusterBillboardCollection=this._clusterBillboardCollection&&this._clusterBillboardCollection.destroy(),this._clusterPointCollection=this._clusterPointCollection&&this._clusterPointCollection.destroy(),c(this._removeEventListener)&&(this._removeEventListener(),this._removeEventListener=void 0),this._labelCollection=void 0,this._billboardCollection=void 0,this._pointCollection=void 0,this._clusterBillboardCollection=void 0,this._clusterLabelCollection=void 0,this._clusterPointCollection=void 0,this._collectionIndicesByEntity=void 0,this._unusedLabelIndices=[],this._unusedBillboardIndices=[],this._unusedPointIndices=[],this._previousClusters=[],this._previousHeight=void 0,this._enabledDirty=!1,this._pixelRangeDirty=!1,this._minimumClusterSizeDirty=!1};var Yh=QZ;function bet(t){this._name=t,this._clock=void 0,this._changed=new It,this._error=new It,this._isLoading=!1,this._loading=new It,this._entityCollection=new gr(this),this._entityCluster=new Yh}Object.defineProperties(bet.prototype,{name:{get:function(){return this._name},set:function(t){this._name!==t&&(this._name=t,this._changed.raiseEvent(this))}},clock:{get:function(){return this._clock},set:function(t){this._clock!==t&&(this._clock=t,this._changed.raiseEvent(this))}},entities:{get:function(){return this._entityCollection}},isLoading:{get:function(){return this._isLoading},set:function(t){ml.setLoading(this,t)}},changedEvent:{get:function(){return this._changed}},errorEvent:{get:function(){return this._error}},loadingEvent:{get:function(){return this._loading}},show:{get:function(){return this._entityCollection.show},set:function(t){this._entityCollection.show=t}},clustering:{get:function(){return this._entityCluster},set:function(t){this._entityCluster=t}}});bet.prototype.update=function(t){return!0};var hb=bet;var Ret=class extends hb{constructor(e){if(!(e.sdc instanceof hb)||!e.sdc._wasmModule)throw new Ut("Invalid SpaceCatalogDataSource");super(`${e.sdc.name}_coverageGroup`),this.objectList=[],this.sdc=e.sdc,this.sdc.entities.collectionChanged.addEventListener((n,i,o,a)=>{for(let s=0;s{this.ph.positionsArray=[],this.ph.positions=[];for(let o=0;o!0,set:()=>{}}})}}getById(e){return this.objectList.filter(n=>n.id===e)}push(e){this.objectList.filter(n=>n.id===e.id).length||(this.objectList.push(e),this.createGeometry())}remove(e){this.objectList=this.objectList.filter(n=>n.id!==e.id),Object.defineProperties(e,{show:{configurable:!0,get:()=>e._show,set:n=>{e._show=n}}}),this.createGeometry()}},SJ=Ret;var Hui=R(W(),1);var rui=R(W(),1);var Hpi=R(W(),1);var wUt={};wUt.computePositions=function(t,e,n,i,o){let a=t*.5,s=-a,l=i+i,r=o?2*l:l,d=new Float64Array(r*3),m,h=0,Z=0,b=o?l*3:0,u=o?(l+i)*3:i*3;for(m=0;m0){let F=Math.min(a,o);d=Math.round(o/F),r+=F}let m=re.createTypedArray(s,r*2),h=0,Z;for(Z=0;Z0)for(Z=0;Z0){for(r=0;r=3e4)console.log("synch"),e=rt.now(e),this._lastSystemClockUpdate=t;else{let i=this._multiplier;if(n===ya.TICK_DEPENDENT)e=rt.addSeconds(e,i,e);else{let l=t-this._lastSystemTime;e=rt.addSeconds(e,i*(l/1e3),e)}let o=this.clockRange,a=this.startTime,s=this.stopTime;if(o===pl.CLAMPED)rt.lessThan(e,a)?e=rt.clone(a,e):rt.greaterThan(e,s)&&(e=rt.clone(s,e),this.onStop.raiseEvent(this));else if(o===pl.LOOP_STOP)for(rt.lessThan(e,a)&&(e=rt.clone(a,e));rt.greaterThan(e,s);)e=rt.addSeconds(a,rt.secondsDifference(e,s),e),this.onStop.raiseEvent(this)}}return this._currentTime=e,this._lastSystemTime=t,this.onTick.raiseEvent(this),e};var kZ=Tet;function cT(){this._definitionChanged=new It,this._startTime=void 0,this._stopTime=void 0,this._currentTime=void 0,this._clockRange=void 0,this._clockStep=void 0,this._multiplier=void 0}Object.defineProperties(cT.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},startTime:gm("startTime"),stopTime:gm("stopTime"),currentTime:gm("currentTime"),clockRange:gm("clockRange"),clockStep:gm("clockStep"),multiplier:gm("multiplier")});cT.prototype.clone=function(t){return c(t)||(t=new cT),t.startTime=this.startTime,t.stopTime=this.stopTime,t.currentTime=this.currentTime,t.clockRange=this.clockRange,t.clockStep=this.clockStep,t.multiplier=this.multiplier,t};cT.prototype.equals=function(t){return this===t||c(t)&&rt.equals(this.startTime,t.startTime)&&rt.equals(this.stopTime,t.stopTime)&&rt.equals(this.currentTime,t.currentTime)&&this.clockRange===t.clockRange&&this.clockStep===t.clockStep&&this.multiplier===t.multiplier};cT.prototype.merge=function(t){this.startTime=f(this.startTime,t.startTime),this.stopTime=f(this.stopTime,t.stopTime),this.currentTime=f(this.currentTime,t.currentTime),this.clockRange=f(this.clockRange,t.clockRange),this.clockStep=f(this.clockStep,t.clockStep),this.multiplier=f(this.multiplier,t.multiplier)};cT.prototype.getValue=function(t){return c(t)||(t=new kZ),t.startTime=f(this.startTime,t.startTime),t.stopTime=f(this.stopTime,t.stopTime),t.currentTime=f(this.currentTime,t.currentTime),t.clockRange=f(this.clockRange,t.clockRange),t.multiplier=f(this.multiplier,t.multiplier),t.clockStep=f(this.clockStep,t.clockStep),t};var YZ=cT;var xZi=R(W(),1);var Uue=v.WHITE,Gue=.1,Aue=new K(8,8),Tue=new K(0,0),Sue=new K(1,1);function DC(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this._cellAlpha=void 0,this._cellAlphaSubscription=void 0,this._lineCount=void 0,this._lineCountSubscription=void 0,this._lineThickness=void 0,this._lineThicknessSubscription=void 0,this._lineOffset=void 0,this._lineOffsetSubscription=void 0,this.color=t.color,this.cellAlpha=t.cellAlpha,this.lineCount=t.lineCount,this.lineThickness=t.lineThickness,this.lineOffset=t.lineOffset}Object.defineProperties(DC.prototype,{isConstant:{get:function(){return et.isConstant(this._color)&&et.isConstant(this._cellAlpha)&&et.isConstant(this._lineCount)&&et.isConstant(this._lineThickness)&&et.isConstant(this._lineOffset)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color"),cellAlpha:ft("cellAlpha"),lineCount:ft("lineCount"),lineThickness:ft("lineThickness"),lineOffset:ft("lineOffset")});DC.prototype.getType=function(t){return"Grid"};DC.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,Uue,e.color),e.cellAlpha=et.getValueOrDefault(this._cellAlpha,t,Gue),e.lineCount=et.getValueOrClonedDefault(this._lineCount,t,Aue,e.lineCount),e.lineThickness=et.getValueOrClonedDefault(this._lineThickness,t,Sue,e.lineThickness),e.lineOffset=et.getValueOrClonedDefault(this._lineOffset,t,Tue,e.lineOffset),e};DC.prototype.equals=function(t){return this===t||t instanceof DC&&et.equals(this._color,t._color)&&et.equals(this._cellAlpha,t._cellAlpha)&&et.equals(this._lineCount,t._lineCount)&&et.equals(this._lineThickness,t._lineThickness)&&et.equals(this._lineOffset,t._lineOffset)};var OC=DC;var OZi=R(W(),1);function HC(t){this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this.color=t}Object.defineProperties(HC.prototype,{isConstant:{get:function(){return et.isConstant(this._color)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color")});HC.prototype.getType=function(t){return"PolylineArrow"};HC.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,v.WHITE,e.color),e};HC.prototype.equals=function(t){return this===t||t instanceof HC&&et.equals(this._color,t._color)};var wC=HC;var qZi=R(W(),1);var gue=v.WHITE,Eue=v.TRANSPARENT,Cue=16,Iue=255;function PC(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this._gapColor=void 0,this._gapColorSubscription=void 0,this._dashLength=void 0,this._dashLengthSubscription=void 0,this._dashPattern=void 0,this._dashPatternSubscription=void 0,this.color=t.color,this.gapColor=t.gapColor,this.dashLength=t.dashLength,this.dashPattern=t.dashPattern}Object.defineProperties(PC.prototype,{isConstant:{get:function(){return et.isConstant(this._color)&&et.isConstant(this._gapColor)&&et.isConstant(this._dashLength)&&et.isConstant(this._dashPattern)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color"),gapColor:ft("gapColor"),dashLength:ft("dashLength"),dashPattern:ft("dashPattern")});PC.prototype.getType=function(t){return"PolylineDash"};PC.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,gue,e.color),e.gapColor=et.getValueOrClonedDefault(this._gapColor,t,Eue,e.gapColor),e.dashLength=et.getValueOrDefault(this._dashLength,t,Cue,e.dashLength),e.dashPattern=et.getValueOrDefault(this._dashPattern,t,Iue,e.dashPattern),e};PC.prototype.equals=function(t){return this===t||t instanceof PC&&et.equals(this._color,t._color)&&et.equals(this._gapColor,t._gapColor)&&et.equals(this._dashLength,t._dashLength)&&et.equals(this._dashPattern,t._dashPattern)};var vC=PC;var sVi=R(W(),1);var Nue=v.WHITE,yue=.25,Bue=1;function KC(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this._glowPower=void 0,this._glowPowerSubscription=void 0,this._taperPower=void 0,this._taperPowerSubscription=void 0,this.color=t.color,this.glowPower=t.glowPower,this.taperPower=t.taperPower}Object.defineProperties(KC.prototype,{isConstant:{get:function(){return et.isConstant(this._color)&&et.isConstant(this._glow)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color"),glowPower:ft("glowPower"),taperPower:ft("taperPower")});KC.prototype.getType=function(t){return"PolylineGlow"};KC.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,Nue,e.color),e.glowPower=et.getValueOrDefault(this._glowPower,t,yue,e.glowPower),e.taperPower=et.getValueOrDefault(this._taperPower,t,Bue,e.taperPower),e};KC.prototype.equals=function(t){return this===t||t instanceof KC&&et.equals(this._color,t._color)&&et.equals(this._glowPower,t._glowPower)&&et.equals(this._taperPower,t._taperPower)};var zC=KC;var uVi=R(W(),1);var Que=v.WHITE,kue=v.BLACK,Yue=1;function jC(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this.color=t.color,this.outlineColor=t.outlineColor,this.outlineWidth=t.outlineWidth}Object.defineProperties(jC.prototype,{isConstant:{get:function(){return et.isConstant(this._color)&&et.isConstant(this._outlineColor)&&et.isConstant(this._outlineWidth)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth")});jC.prototype.getType=function(t){return"PolylineOutline"};jC.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,Que,e.color),e.outlineColor=et.getValueOrClonedDefault(this._outlineColor,t,kue,e.outlineColor),e.outlineWidth=et.getValueOrDefault(this._outlineWidth,t,Yue),e};jC.prototype.equals=function(t){return this===t||t instanceof jC&&et.equals(this._color,t._color)&&et.equals(this._outlineColor,t._outlineColor)&&et.equals(this._outlineWidth,t._outlineWidth)};var AF=jC;var UVi=R(W(),1);function J0(t,e){this._value=void 0,this._definitionChanged=new It,this._eventHelper=new rl,this._referenceFrame=f(e,ri.FIXED),this.setValue(t)}Object.defineProperties(J0.prototype,{isConstant:{get:function(){let t=this._value;if(!c(t))return!0;let e=t.length;for(let n=0;n0){n=new Array(e);for(let i=0;ir&&t!==Object}let u=typeof t.unpack=="function"&&t!==ru;if(!b&&!Z){h?e[n]=new Ii(u?t.unpack(d,0):d):e[n]=nGt(t,s,i);return}let F=e[n],U,G=i.epoch;if(c(G)&&(U=rt.fromIso8601(G)),b&&!Z){F instanceof ql||(e[n]=F=new ql(t)),F.addSamplesPackedArray(d,U),XP(i,F);return}let A;if(!b&&Z){l=l.clone(),h?l.data=u?t.unpack(d,0):d:l.data=nGt(t,s,i),c(F)||(e[n]=F=h?new _m:new ec),h&&F instanceof _m?F.intervals.addInterval(l):F instanceof ec?(h&&(l.data=new Ii(l.data)),F.intervals.addInterval(l)):(e[n]=F=rGt(F),h&&(l.data=new Ii(l.data)),F.intervals.addInterval(l));return}c(F)||(e[n]=F=new ec),F instanceof ec||(e[n]=F=rGt(F));let T=F.intervals;A=T.findInterval(l),(!c(A)||!(A.data instanceof ql))&&(A=l.clone(),A.data=new ql(t),T.addInterval(A)),A.data.addSamplesPackedArray(d,U),XP(i,A.data)}function fGt(t,e){if(t instanceof ql){t.removeSamples(e);return}else if(t instanceof _m){t.intervals.removeInterval(e);return}else if(t instanceof ec){let n=t.intervals;for(let i=0;ir),!u&&!Z){h?t[e]=new jl(p.unpack(d),b):t[e]=yJ(a,n.reference);return}let F=t[e],U,G=n.epoch;if(c(G)&&(U=rt.fromIso8601(G)),u&&!Z){(!(F instanceof Bs)||c(b)&&F.referenceFrame!==b)&&(t[e]=F=new Bs(b,l)),F.addSamplesPackedArray(d,U),XP(n,F);return}let A;if(!u&&Z){s=s.clone(),h?s.data=p.unpack(d):s.data=yJ(a,n.reference),c(F)||(h?F=new _0(b):F=new cl(b),t[e]=F),h&&F instanceof _0&&c(b)&&F.referenceFrame===b?F.intervals.addInterval(s):F instanceof cl?(h&&(s.data=new jl(s.data,b)),F.intervals.addInterval(s)):(t[e]=F=dGt(F),h&&(s.data=new jl(s.data,b)),F.intervals.addInterval(s));return}c(F)?F instanceof cl||(t[e]=F=dGt(F)):t[e]=F=new cl(b);let T=F.intervals;A=T.findInterval(s),(!c(A)||!(A.data instanceof Bs)||c(b)&&A.data.referenceFrame!==b)&&(A=s.clone(),A.data=new Bs(b,l),T.addInterval(A)),A.data.addSamplesPackedArray(d,U),XP(n,A.data)}function FGt(t,e){if(t instanceof Bs){t.removeSamples(e);return}else if(t instanceof _0){t.intervals.removeInterval(e);return}else if(t instanceof cl){let n=t.intervals;for(let i=0;i. version format.");let i=e._documentPacket;c(t.name)&&(i.name=t.name);let o=t.clock;if(c(o)){let a=i.clock;c(a)?(a.interval=f(o.interval,a.interval),a.currentTime=f(o.currentTime,a.currentTime),a.range=f(o.range,a.range),a.step=f(o.step,a.step),a.multiplier=f(o.multiplier,a.multiplier)):i.clock={interval:o.interval,currentTime:o.currentTime,range:o.range,step:o.step,multiplier:o.multiplier}}}function FZe(t,e,n,i){let o=e.ellipse;if(!c(o))return;let a=Qs(o.interval),s=t.ellipse;c(s)||(t.ellipse=s=new jG),Bt(Boolean,s,"show",o.show,a,i,n),Bt(Number,s,"semiMajorAxis",o.semiMajorAxis,a,i,n),Bt(Number,s,"semiMinorAxis",o.semiMinorAxis,a,i,n),Bt(Number,s,"height",o.height,a,i,n),Bt(Ge,s,"heightReference",o.heightReference,a,i,n),Bt(Number,s,"extrudedHeight",o.extrudedHeight,a,i,n),Bt(Ge,s,"extrudedHeightReference",o.extrudedHeightReference,a,i,n),Bt(ru,s,"rotation",o.rotation,a,i,n),Bt(ru,s,"stRotation",o.stRotation,a,i,n),Bt(Number,s,"granularity",o.granularity,a,i,n),Bt(Boolean,s,"fill",o.fill,a,i,n),Jh(s,"material",o.material,a,i,n),Bt(Boolean,s,"outline",o.outline,a,i,n),Bt(v,s,"outlineColor",o.outlineColor,a,i,n),Bt(Number,s,"outlineWidth",o.outlineWidth,a,i,n),Bt(Number,s,"numberOfVerticalLines",o.numberOfVerticalLines,a,i,n),Bt(ui,s,"shadows",o.shadows,a,i,n),Bt(Wn,s,"distanceDisplayCondition",o.distanceDisplayCondition,a,i,n),Bt(Ji,s,"classificationType",o.classificationType,a,i,n),Bt(Number,s,"zIndex",o.zIndex,a,i,n)}function UZe(t,e,n,i){let o=e.ellipsoid;if(!c(o))return;let a=Qs(o.interval),s=t.ellipsoid;c(s)||(t.ellipsoid=s=new qG),Bt(Boolean,s,"show",o.show,a,i,n),Bt(p,s,"radii",o.radii,a,i,n),Bt(p,s,"innerRadii",o.innerRadii,a,i,n),Bt(Number,s,"minimumClock",o.minimumClock,a,i,n),Bt(Number,s,"maximumClock",o.maximumClock,a,i,n),Bt(Number,s,"minimumCone",o.minimumCone,a,i,n),Bt(Number,s,"maximumCone",o.maximumCone,a,i,n),Bt(Ge,s,"heightReference",o.heightReference,a,i,n),Bt(Boolean,s,"fill",o.fill,a,i,n),Jh(s,"material",o.material,a,i,n),Bt(Boolean,s,"outline",o.outline,a,i,n),Bt(v,s,"outlineColor",o.outlineColor,a,i,n),Bt(Number,s,"outlineWidth",o.outlineWidth,a,i,n),Bt(Number,s,"stackPartitions",o.stackPartitions,a,i,n),Bt(Number,s,"slicePartitions",o.slicePartitions,a,i,n),Bt(Number,s,"subdivisions",o.subdivisions,a,i,n),Bt(ui,s,"shadows",o.shadows,a,i,n),Bt(Wn,s,"distanceDisplayCondition",o.distanceDisplayCondition,a,i,n)}function GZe(t,e,n,i){let o=e.label;if(!c(o))return;let a=Qs(o.interval),s=t.label;c(s)||(t.label=s=new aZ),Bt(Boolean,s,"show",o.show,a,i,n),Bt(String,s,"text",o.text,a,i,n),Bt(String,s,"font",o.font,a,i,n),Bt(Pa,s,"style",o.style,a,i,n),Bt(Number,s,"scale",o.scale,a,i,n),Bt(Boolean,s,"showBackground",o.showBackground,a,i,n),Bt(v,s,"backgroundColor",o.backgroundColor,a,i,n),Bt(K,s,"backgroundPadding",o.backgroundPadding,a,i,n),Bt(K,s,"pixelOffset",o.pixelOffset,a,i,n),Bt(p,s,"eyeOffset",o.eyeOffset,a,i,n),Bt(to,s,"horizontalOrigin",o.horizontalOrigin,a,i,n),Bt(hi,s,"verticalOrigin",o.verticalOrigin,a,i,n),Bt(Ge,s,"heightReference",o.heightReference,a,i,n),Bt(v,s,"fillColor",o.fillColor,a,i,n),Bt(v,s,"outlineColor",o.outlineColor,a,i,n),Bt(Number,s,"outlineWidth",o.outlineWidth,a,i,n),Bt(ln,s,"translucencyByDistance",o.translucencyByDistance,a,i,n),Bt(ln,s,"pixelOffsetScaleByDistance",o.pixelOffsetScaleByDistance,a,i,n),Bt(ln,s,"scaleByDistance",o.scaleByDistance,a,i,n),Bt(Wn,s,"distanceDisplayCondition",o.distanceDisplayCondition,a,i,n),Bt(Number,s,"disableDepthTestDistance",o.disableDepthTestDistance,a,i,n)}function AZe(t,e,n,i){let o=e.model;if(!c(o))return;let a=Qs(o.interval),s=t.model;c(s)||(t.model=s=new JR),Bt(Boolean,s,"show",o.show,a,i,n),Bt(QJ.default,s,"uri",o.gltf,a,i,n),Bt(Number,s,"scale",o.scale,a,i,n),Bt(Number,s,"minimumPixelSize",o.minimumPixelSize,a,i,n),Bt(Number,s,"maximumScale",o.maximumScale,a,i,n),Bt(Boolean,s,"incrementallyLoadTextures",o.incrementallyLoadTextures,a,i,n),Bt(Boolean,s,"runAnimations",o.runAnimations,a,i,n),Bt(Boolean,s,"clampAnimations",o.clampAnimations,a,i,n),Bt(ui,s,"shadows",o.shadows,a,i,n),Bt(Ge,s,"heightReference",o.heightReference,a,i,n),Bt(v,s,"silhouetteColor",o.silhouetteColor,a,i,n),Bt(Number,s,"silhouetteSize",o.silhouetteSize,a,i,n),Bt(v,s,"color",o.color,a,i,n),Bt(Kd,s,"colorBlendMode",o.colorBlendMode,a,i,n),Bt(Number,s,"colorBlendAmount",o.colorBlendAmount,a,i,n),Bt(Wn,s,"distanceDisplayCondition",o.distanceDisplayCondition,a,i,n);let l,r,d=o.nodeTransformations;if(c(d))if(Array.isArray(d))for(l=0,r=d.length;l-1;r--)n[r](s,t,e,i)}Eet=void 0}function QZe(t){let e,n=t._documentPacket.clock;if(!c(n)){if(!c(t._clock)){let o=t._entityCollection.computeAvailability();if(!o.start.equals(Re.MINIMUM_VALUE)){let a=o.start,s=o.stop,l=rt.secondsDifference(s,a),r=Math.round(l/120);return e=new YZ,e.startTime=rt.clone(a),e.stopTime=rt.clone(s),e.clockRange=pl.LOOP_STOP,e.multiplier=r,e.currentTime=rt.clone(a),e.clockStep=ya.SYSTEM_CLOCK_MULTIPLIER,t._clock=e,!0}}return!1}c(t._clock)?e=t._clock.clone():(e=new YZ,e.startTime=Re.MINIMUM_VALUE.clone(),e.stopTime=Re.MAXIMUM_VALUE.clone(),e.currentTime=Re.MINIMUM_VALUE.clone(),e.clockRange=pl.LOOP_STOP,e.clockStep=ya.SYSTEM_CLOCK_MULTIPLIER,e.multiplier=1);let i=Qs(n.interval);return c(i)&&(e.startTime=i.start,e.stopTime=i.stop),c(n.currentTime)&&(e.currentTime=rt.fromIso8601(n.currentTime)),c(n.range)&&(e.clockRange=f(pl[n.range],pl.LOOP_STOP)),c(n.step)&&(e.clockStep=f(ya[n.step],ya.SYSTEM_CLOCK_MULTIPLIER)),c(n.multiplier)&&(e.multiplier=n.multiplier),e.equals(t._clock)?!1:(t._clock=e.clone(t._clock),!0)}function GGt(t,e,n,i){n=f(n,f.EMPTY_OBJECT);let o=e,a=n.sourceUri,s=n.credit;if(typeof s=="string"&&(s=new on(s)),t._credit=s,typeof e=="string"||e instanceof te){e=te.createIfNeeded(e),o=e.fetchJson(),a=f(a,e.clone());let l=t._resourceCredits,r=e.credits;if(c(r)){let d=r.length;for(let m=0;m1;--V){if(G=k.PI_OVER_TWO-(V-1)*U,C=oI(-G,a,u,b,r,m,d,h,Z,C),y=oI(G+Math.PI,a,u,b,r,m,d,h,Z,y),e){for(T[g++]=C.x,T[g++]=C.y,T[g++]=C.z,I=2*(V-1)+2,E=1;E1;--s){for(e[n++]=i++,e[n++]=i,e[n++]=a,o=2*s,l=0;lk.PI&&(h.north=h.north>0?k.PI_OVER_TWO-k.EPSILON7:h.north,h.south=h.south<0?k.EPSILON7-k.PI_OVER_TWO:h.south,h.east=k.PI,h.west=-k.PI),h}function Zb(t){t=f(t,f.EMPTY_OBJECT);let e=t.center,n=f(t.ellipsoid,mt.WGS84),i=t.semiMajorAxis,o=t.semiMinorAxis,a=f(t.granularity,k.RADIANS_PER_DEGREE),s=f(t.vertexFormat,ee.DEFAULT),l=f(t.height,0),r=f(t.extrudedHeight,l);this._center=p.clone(e),this._semiMajorAxis=i,this._semiMinorAxis=o,this._ellipsoid=mt.clone(n),this._rotation=f(t.rotation,0),this._stRotation=f(t.stRotation,0),this._height=Math.max(r,l),this._granularity=a,this._vertexFormat=ee.clone(s),this._extrudedHeight=Math.min(r,l),this._shadowVolume=f(t.shadowVolume,!1),this._workerName="createEllipseGeometry",this._offsetAttribute=t.offsetAttribute,this._rectangle=void 0,this._textureCoordinateRotationPoints=void 0}Zb.packedLength=p.packedLength+mt.packedLength+ee.packedLength+9;Zb.pack=function(t,e,n){return n=f(n,0),p.pack(t._center,e,n),n+=p.packedLength,mt.pack(t._ellipsoid,e,n),n+=mt.packedLength,ee.pack(t._vertexFormat,e,n),n+=ee.packedLength,e[n++]=t._semiMajorAxis,e[n++]=t._semiMinorAxis,e[n++]=t._rotation,e[n++]=t._stRotation,e[n++]=t._height,e[n++]=t._granularity,e[n++]=t._extrudedHeight,e[n++]=t._shadowVolume?1:0,e[n]=f(t._offsetAttribute,-1),e};var _Gt=new p,DGt=new mt,OGt=new ee,ub={center:_Gt,ellipsoid:DGt,vertexFormat:OGt,semiMajorAxis:void 0,semiMinorAxis:void 0,rotation:void 0,stRotation:void 0,height:void 0,granularity:void 0,extrudedHeight:void 0,shadowVolume:void 0,offsetAttribute:void 0};Zb.unpack=function(t,e,n){e=f(e,0);let i=p.unpack(t,e,_Gt);e+=p.packedLength;let o=mt.unpack(t,e,DGt);e+=mt.packedLength;let a=ee.unpack(t,e,OGt);e+=ee.packedLength;let s=t[e++],l=t[e++],r=t[e++],d=t[e++],m=t[e++],h=t[e++],Z=t[e++],b=t[e++]===1,u=t[e];return c(n)?(n._center=p.clone(i,n._center),n._ellipsoid=mt.clone(o,n._ellipsoid),n._vertexFormat=ee.clone(a,n._vertexFormat),n._semiMajorAxis=s,n._semiMinorAxis=l,n._rotation=r,n._stRotation=d,n._height=m,n._granularity=h,n._extrudedHeight=Z,n._shadowVolume=b,n._offsetAttribute=u===-1?void 0:u,n):(ub.height=m,ub.extrudedHeight=Z,ub.granularity=h,ub.stRotation=d,ub.rotation=r,ub.semiMajorAxis=s,ub.semiMinorAxis=l,ub.shadowVolume=b,ub.offsetAttribute=u===-1?void 0:u,new Zb(ub))};Zb.computeRectangle=function(t,e){t=f(t,f.EMPTY_OBJECT);let n=t.center,i=f(t.ellipsoid,mt.WGS84),o=t.semiMajorAxis,a=t.semiMinorAxis,s=f(t.granularity,k.RADIANS_PER_DEGREE),l=f(t.rotation,0);return MGt(n,o,a,l,s,i,e)};Zb.createGeometry=function(t){if(t._semiMajorAxis<=0||t._semiMinorAxis<=0)return;let e=t._height,n=t._extrudedHeight,i=!k.equalsEpsilon(e,n,0,k.EPSILON2);t._center=t._ellipsoid.scaleToGeodeticSurface(t._center,t._center);let o={center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,ellipsoid:t._ellipsoid,rotation:t._rotation,height:e,granularity:t._granularity,vertexFormat:t._vertexFormat,stRotation:t._stRotation},a;if(i)o.extrudedHeight=n,o.shadowVolume=t._shadowVolume,o.offsetAttribute=t._offsetAttribute,a=OZe(o);else if(a=MZe(o),c(t._offsetAttribute)){let s=a.attributes.position.values.length,l=t._offsetAttribute===zn.NONE?0:1,r=new Uint8Array(s/3).fill(l);a.attributes.applyOffset=new jt({componentDatatype:it.UNSIGNED_BYTE,componentsPerAttribute:1,values:r})}return new _e({attributes:a.attributes,indices:a.indices,primitiveType:le.TRIANGLES,boundingSphere:a.boundingSphere,offsetAttribute:t._offsetAttribute})};Zb.createShadowVolume=function(t,e,n){let i=t._granularity,o=t._ellipsoid,a=e(i,o),s=n(i,o);return new Zb({center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,ellipsoid:o,rotation:t._rotation,stRotation:t._stRotation,granularity:i,extrudedHeight:a,height:s,vertexFormat:ee.POSITION_ONLY,shadowVolume:!0})};function HZe(t){let e=-t._stRotation;if(e===0)return[0,0,0,1,1,0];let i=Om.computeEllipsePositions({center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,rotation:t._rotation,granularity:t._granularity},!1,!0).outerPositions,o=i.length/3,a=new Array(o);for(let r=0;r0){let u=Math.min(d,r);b=Math.round(r/u);let F=Math.min(b*d,r);for(Z=0;Z0&&(g=!0,G+=r-1),s0&&m!==F-1&&h!==0&&h!==U-1&&(M[$]=!0),$++;Z=0;let dt,q;for(m=1;m=zt&&m1||C>1))for(let E=0;E0;m-=d)kt=m*3,nt=ZI(nt,st,kt,Z,U),st+=6,o.st&&(q=VI(q,Et,m*2,C),Et+=4),n&&(Qt+=3,$[Qt++]=y[kt],$[Qt++]=y[kt+1],$[Qt++]=y[kt+2]),at&&(dt[Wt++]=1,Wt+=1);if(I){let zt=Nt;for(kt=zt*3,m=0;m<2;m++)nt=ZI(nt,st,kt,Z,U),st+=6,o.st&&(q=VI(q,Et,zt*2,C),Et+=4),n&&(Qt+=3,$[Qt++]=y[kt],$[Qt++]=y[kt+1],$[Qt++]=y[kt+2]),at&&(dt[Wt++]=1,Wt+=1)}else for(m=d-1;m>=0;m--)kt=m*3,nt=ZI(nt,st,kt,Z,U),st+=6,o.st&&(q=VI(q,Et,m*2,C),Et+=4),n&&(Qt+=3,$[Qt++]=y[kt],$[Qt++]=y[kt+1],$[Qt++]=y[kt+2]),at&&(dt[Wt++]=1,Wt+=1);let Mt=mbe(nt,o,l);o.st&&(Mt.attributes.st=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:q})),n&&(Mt.attributes.extrudeDirection=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:$})),Q&&(Mt.attributes.applyOffset=new jt({componentDatatype:it.UNSIGNED_BYTE,componentsPerAttribute:1,values:dt}));let qt=re.createTypedArray(H,P*6),ie,oe,He,rn;b=nt.length/3;let de=0;for(m=0;m0)for(s=new Array(o),i=0;i0)for(l=new Array(o),i=0;i0)for(s=new Array(o),i=0;i0)for(l=new Array(o),i=0;i{i.raiseEvent(l)}),n[a]=s}this.updaters=n,this.geometryChanged=i,this.eventHelper=o,this._removeEntitySubscription=t.definitionChanged.addEventListener(ST.prototype._onEntityPropertyChanged,this)}ST.prototype._onEntityPropertyChanged=function(t,e,n,i){let o=this.updaters;for(let a=0;a0){c(i)&&(c(this.oldPrimitive)?o.remove(i):this.oldPrimitive=i);let r;c(this.depthFailAppearanceType)&&(c(this.depthFailMaterialProperty)&&(this.depthFailMaterial=Ua.getValue(t,this.depthFailMaterialProperty,this.depthFailMaterial)),r=new this.depthFailAppearanceType({material:this.depthFailMaterial,translucent:this.translucent,closed:this.closed})),i=new Wi({show:!1,asynchronous:!0,geometryInstances:s.slice(),appearance:new this.appearanceType({translucent:this.translucent,closed:this.closed}),depthFailAppearance:r,shadows:this.shadows}),o.add(i),e=!1}else{c(i)&&(o.remove(i),i=void 0);let r=this.oldPrimitive;c(r)&&(o.remove(r),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=i,this.createPrimitive=!1,this.waitingOnCreate=!0}else if(c(i)&&i.ready){i.show=!0,c(this.oldPrimitive)&&(o.remove(this.oldPrimitive),this.oldPrimitive=void 0),c(this.depthFailAppearanceType)&&!(this.depthFailMaterialProperty instanceof Cn)&&(this.depthFailMaterial=Ua.getValue(t,this.depthFailMaterialProperty,this.depthFailMaterial),this.primitive.depthFailAppearance.material=this.depthFailMaterial);let s=this.updatersWithAttributes.values,l=s.length,r=this.waitingOnCreate;for(a=0;a=0;i--){let o=t[i];if(o.remove(e))return o.updaters.length===0&&(t.splice(i,1),o.destroy()),!0}return!1}WI.prototype.remove=function(t){vAt(this._solidItems,t)||vAt(this._translucentItems,t)};function KAt(t,e,n){let i=!1,o=e.length;for(let a=0;a0)for(a=0;a=0;a--){let s=e[a];if(s.invalidated){e.splice(a,1);let l=s.updaters.values,r=l.length;for(let d=0;d0){c(n)&&(c(this.oldPrimitive)?i.remove(n):this.oldPrimitive=n),this.material=Ua.getValue(t,this.materialProperty,this.material);let l;c(this.depthFailMaterialProperty)&&(this.depthFailMaterial=Ua.getValue(t,this.depthFailMaterialProperty,this.depthFailMaterial),l=new this.depthFailAppearanceType({material:this.depthFailMaterial,translucent:this.depthFailMaterial.isTranslucent(),closed:this.closed})),n=new Wi({show:!1,asynchronous:!0,geometryInstances:o.slice(),appearance:new this.appearanceType({material:this.material,translucent:this.material.isTranslucent(),closed:this.closed}),depthFailAppearance:l,shadows:this.shadows}),i.add(n),e=!1}else{c(n)&&(i.remove(n),n=void 0);let l=this.oldPrimitive;c(l)&&(i.remove(l),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=n,this.createPrimitive=!1}else if(c(n)&&n.ready){n.show=!0,c(this.oldPrimitive)&&(i.remove(this.oldPrimitive),this.oldPrimitive=void 0),this.material=Ua.getValue(t,this.materialProperty,this.material),this.primitive.appearance.material=this.material,c(this.depthFailAppearanceType)&&!(this.depthFailMaterialProperty instanceof Cn)&&(this.depthFailMaterial=Ua.getValue(t,this.depthFailMaterialProperty,this.depthFailMaterial),this.primitive.depthFailAppearance.material=this.depthFailMaterial);let s=this.updatersWithAttributes.values,l=s.length;for(a=0;a=0;i--){let o=e[i];if(o.remove(t)){o.updaters.length===0&&(e.splice(i,1),o.destroy());break}}};fI.prototype.update=function(t){let e,n=this._items,i=n.length;for(e=i-1;e>=0;e--){let a=n[e];if(a.invalidated){n.splice(e,1);let s=a.updaters.values,l=s.length;for(let r=0;r0)c(i)&&(c(this.oldPrimitive)?o.remove(i):this.oldPrimitive=i),i=new Nc({show:!1,asynchronous:!0,geometryInstances:s.slice(),classificationType:this.classificationType}),o.add(i,this.zIndex),e=!1;else{c(i)&&(o.remove(i),i=void 0);let r=this.oldPrimitive;c(r)&&(o.remove(r),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=i,this.createPrimitive=!1,this.waitingOnCreate=!0}else if(c(i)&&i.ready){i.show=!0,c(this.oldPrimitive)&&(o.remove(this.oldPrimitive),this.oldPrimitive=void 0);let s=this.updatersWithAttributes.values,l=s.length,r=this.waitingOnCreate;for(a=0;a=0;--e){let s=o[e];s.isDirty&&(i=o[e].update(t)&&i,s.isDirty=!1),s.geometry.length===0&&o.splice(e,1)}return i};FI.prototype.getBoundingSphere=function(t,e){let n=this._batches,i=n.length;for(let o=0;o0)c(n)&&(c(this.oldPrimitive)?i.remove(n):this.oldPrimitive=n),this.material=Ua.getValue(t,this.materialProperty,this.material),n=new Nc({show:!1,asynchronous:!0,geometryInstances:o.slice(),appearance:new this.appearanceType({material:this.material}),classificationType:this.classificationType}),i.add(n,this.zIndex),e=!1;else{c(n)&&(i.remove(n),n=void 0);let l=this.oldPrimitive;c(l)&&(i.remove(l),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=n,this.createPrimitive=!1}else if(c(n)&&n.ready){n.show=!0,c(this.oldPrimitive)&&(i.remove(this.oldPrimitive),this.oldPrimitive=void 0),this.material=Ua.getValue(t,this.materialProperty,this.material),this.primitive.appearance.material=this.material;let s=this.updatersWithAttributes.values,l=s.length;for(a=0;a=0;i--){let o=e[i];if(o.remove(t)){o.updaters.length===0&&(e.splice(i,1),o.destroy());break}}};GI.prototype.update=function(t){let e,n=this._items,i=n.length;for(e=i-1;e>=0;e--){let a=n[e];if(a.invalidated){n.splice(e,1);let s=a.updaters.values,l=s.length;for(let r=0;r0)c(i)&&(c(this.oldPrimitive)?o.remove(i):this.oldPrimitive=i),i=new Wi({show:!1,asynchronous:!0,geometryInstances:s.slice(),appearance:new jn({flat:!0,translucent:this.translucent,renderState:{lineWidth:this.width}}),shadows:this.shadows}),o.add(i),e=!1;else{c(i)&&(o.remove(i),i=void 0);let r=this.oldPrimitive;c(r)&&(o.remove(r),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=i,this.createPrimitive=!1,this.waitingOnCreate=!0}else if(c(i)&&i.ready){i.show=!0,c(this.oldPrimitive)&&(o.remove(this.oldPrimitive),this.oldPrimitive=void 0);let s=this.updatersWithAttributes.values,l=s.length,r=this.waitingOnCreate;for(a=0;a0)for(h=!0,e=0;e0)for(h=!0,e=0;e-1;l--)r=s[l],d=r.id,m=this._updaterSets.get(d),m.entity===r?m.forEach(function(F){h._removeUpdater(F),h._insertUpdaterIntoBatch(t,F)}):(o.push(r),n.push(r));for(l=o.length-1;l>-1;l--)r=o[l],d=r.id,m=this._updaterSets.get(d),m.forEach(this._removeUpdater.bind(this)),m.destroy(),this._updaterSets.remove(d),this._subscriptions.get(d)(),this._subscriptions.remove(d);for(l=n.length-1;l>-1;l--)r=n[l],d=r.id,m=new gT(r,this._scene),this._updaterSets.set(d,m),m.forEach(function(F){h._insertUpdaterIntoBatch(t,F)}),this._subscriptions.set(d,m.geometryChanged.addEventListener(Hm._onGeometryChanged,this));e.removeAll(),i.removeAll(),a.removeAll();let Z=!0,b=this._batches,u=b.length;for(l=0;l-1;s--)r=n[s],l=r.id,i.remove(l)||(o.set(l,r),a.remove(l));for(s=e.length-1;s>-1;s--)r=e[s],l=r.id,o.remove(l)?a.set(l,r):i.set(l,r)};var dL=Hm;var gCi=R(W(),1);var lRe=1,rRe="30px sans-serif",dRe=Pa.FILL,cRe=v.WHITE,mRe=v.BLACK,hRe=1,pRe=!1,uRe=new v(.165,.165,.165,.8),ZRe=new K(7,5),VRe=K.ZERO,bRe=p.ZERO,RRe=Ge.NONE,WRe=to.CENTER,fRe=hi.CENTER,FRe=new p,URe=new v,GRe=new v,ARe=new v,TRe=new K,SRe=new p,gRe=new K,ERe=new ln,CRe=new ln,IRe=new ln,NRe=new Wn;function tTt(t){this.entity=t,this.label=void 0,this.index=void 0}function NF(t,e){e.collectionChanged.addEventListener(NF.prototype._onCollectionChanged,this),this._cluster=t,this._entityCollection=e,this._items=new qe,this._toRemove=[],this._onCollectionChanged(e,e.values,[],[])}NF.prototype.update=function(t){let e=this._items.values,n=this._cluster;for(let i=0,o=e.length;i-1;o--)a=e[o],c(a._label)&&c(a._position)&&s.set(a.id,new tTt(a));for(o=i.length-1;o>-1;o--)a=i[o],c(a._label)&&c(a._position)?s.contains(a.id)||s.set(a.id,new tTt(a)):(vet(s.get(a.id),a,l),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],vet(s.get(a.id),a,l),s.remove(a.id)};function vet(t,e,n){c(t)&&(t.label=void 0,n.removeLabel(e))}var cL=NF;var KCi=R(W(),1);var yRe=1,BRe=0,QRe=!0,kRe=!0,YRe=ui.ENABLED,xRe=Ge.NONE,XRe=v.RED,JRe=0,LRe=v.WHITE,MRe=Kd.HIGHLIGHT,_Re=.5,DRe=new K(1,1),ORe=new L,HRe=new L,eTt=new v,nTt=new Array(4),wRe=new p;function yF(t,e){e.collectionChanged.addEventListener(yF.prototype._onCollectionChanged,this),this._scene=t,this._primitives=t.primitives,this._entityCollection=e,this._modelHash={},this._entitiesToVisualize=new qe,this._onCollectionChanged(e,e.values,[],[])}async function PRe(t,e,n,i){let o=t._primitives,a=t._modelHash;try{let s=await AZ.fromGltfAsync({url:n,incrementallyLoadTextures:i,scene:t._scene});if(t.isDestroyed()||!c(a[e.id]))return;s.id=e,o.add(s),a[e.id].modelPrimitive=s,s.errorEvent.addEventListener(l=>{c(a[e.id])&&(console.log(l),l.name!=="TextureError"&&s.incrementallyLoadTextures&&(a[e.id].loadFailed=!0))})}catch(s){if(t.isDestroyed()||!c(a[e.id]))return;console.log(s),a[e.id].loadFailed=!0}}yF.prototype.update=function(t){let e=this._entitiesToVisualize.values,n=this._modelHash,i=this._primitives;for(let o=0,a=e.length;o-1;i--)Ket(this,t[i],e,n);return At(this)};var iv=new p,vRe=new gt;yF.prototype.getBoundingSphere=function(t,e){let n=this._modelHash[t.id];if(!c(n))return ve.FAILED;if(n.loadFailed)return ve.FAILED;let i=n.modelPrimitive;if(!c(i)||!i.show)return ve.PENDING;if(!i.ready||!n.modelUpdated)return ve.PENDING;let o=this._scene,a=o.globe,s=f(a?.ellipsoid,mt.WGS84);if(i.heightReference!==Ge.NONE){let r=i.modelMatrix;iv.x=r[12],iv.y=r[13],iv.z=r[14];let d=s.cartesianToCartographic(iv,vRe),m=o.getHeight(d,i.heightReference);return c(m)&&(Np(i.heightReference)?d.height=m:d.height+=m),Ft.clone(i.boundingSphere,e),e.center=s.cartographicToCartesian(d),ve.DONE}return Ft.clone(i.boundingSphere,e),ve.DONE};yF.prototype._onCollectionChanged=function(t,e,n,i){let o,a,s=this._entitiesToVisualize,l=this._modelHash,r=this._primitives;for(o=e.length-1;o>-1;o--)a=e[o],c(a._model)&&c(a._position)&&s.set(a.id,a);for(o=i.length-1;o>-1;o--)a=i[o],c(a._model)&&c(a._position)?(KRe(a,l),s.set(a.id,a)):(Ket(this,a,l,r),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],Ket(this,a,l,r),s.remove(a.id)};function Ket(t,e,n,i){let o=n[e.id];c(o)&&(i.removeAndDestroy(o.modelPrimitive),delete n[e.id])}function KRe(t,e){let n=e[t.id];c(n)&&(n.nodeTransformationsScratch={},n.articulationsScratch={})}var mL=yF;var gIi=R(W(),1);var nIi=R(W(),1);function BF(t){this._definitionChanged=new It,this._value=void 0,this._removeSubscription=void 0,this.setValue(t)}Object.defineProperties(BF.prototype,{isConstant:{get:function(){return et.isConstant(this._value)}},definitionChanged:{get:function(){return this._definitionChanged}},referenceFrame:{get:function(){return c(this._value)?this._value.referenceFrame:ri.FIXED}}});BF.prototype.getValue=function(t,e){return this.getValueInReferenceFrame(t,ri.FIXED,e)};BF.prototype.setValue=function(t){this._value!==t&&(this._value=t,c(this._removeSubscription)&&(this._removeSubscription(),this._removeSubscription=void 0),c(t)&&(this._removeSubscription=t.definitionChanged.addEventListener(this._raiseDefinitionChanged,this)),this._definitionChanged.raiseEvent(this))};BF.prototype.getValueInReferenceFrame=function(t,e,n){if(c(this._value))return n=this._value.getValueInReferenceFrame(t,e,n),c(n)?mt.WGS84.scaleToGeodeticSurface(n,n):void 0};BF.prototype.equals=function(t){return this===t||t instanceof BF&&this._value===t._value};BF.prototype._raiseDefinitionChanged=function(){this._definitionChanged.raiseEvent(this)};var vc=BF;var zRe=60,jRe=1,sTt=new ai,zet=new ai,jet=new ai;function iTt(t){this.entity=t,this.polyline=void 0,this.index=void 0,this.updater=void 0}function oTt(t,e){let n=Math.sin(t)*Math.sqrt(1-Math.pow(e,2))/(1+e*Math.cos(t)),i=(e+Math.cos(t))/(1+e*Math.cos(t)),o=Math.atan2(n,i),a=o-e*Math.sin(o);return a<0&&(a=a+2*Math.PI),a}function qRe(t){t._timeSegments={segments:[],globalIndex:null,splitInterval:null,settings:null}}function lTt(t){t._timeSegments.segments.length=0}function $Re(t,e,n,i,o,a,s,l,r){let d=l,m;m=t.getValueInReferenceFrame(e,a,r[d]),c(m)&&(r[d++]=m);let h=!c(o)||rt.lessThanOrEquals(o,e)||rt.greaterThanOrEquals(o,n),Z=!1;if(s.method){let C=rt.secondsDifference(n,e);if(i.length0&&!G){let C=i[b+1],y=rt.secondsDifference(C,F);G=y>s,G&&(A=Math.ceil(y/s),T=0,g=y/Math.max(A,2),A=Math.max(A-1,1))}if(G&&T1&&(F=1);let U;if(r._timeSegments.splitInterval)U=r._timeSegments.splitInterval;else{let q;for(q=0;q=I)lTt(r);else if(_>0)r._timeSegments.segments.splice(0,_);else if(_<0){r._timeSegments.segments.splice(_,-_);for(let q=0;qz&&(d=av(t,nt,$,i,o,m,d-1,l,r,h),dt=!0),l.splice(d-1,r._timeSegments.segments[at].length,...r._timeSegments.segments[at]),d+=r._timeSegments.segments[at].length-1}return P.length&&(l.splice(d-1,P.length,...P),d+=P.length-1),t._property._refFrame!==o&&(t._property._refFrame=o),l.length=d,Z&&(t._property._samples=l.length),l.length}function av(t,e,n,i,o,a,s,l,r,d){let m=a.method==="trueAnomaly",h=s;return m&&m!=="constant condition"?h=n0e(t,e,n,i,o,a,s,l,d):h=t0e(t,e,n,i,o,a,s,l,d),h}var Dh=new p,SI=new p,hL=new p,sv=new p,IT=new p;function n0e(t,e,n,i,o,a,s,l,r){let d=rt.lessThanOrEquals(n,e),m,h=s,Z=e,b=a.samplesPerPeriod||360,u=a.period||rt.secondsDifference(n,e),F=a.extraEpochSamples||0,U=a.resolutionAtEpoch||1,G=a.extraSamples||3,A=rt.addSeconds(i,-(Math.floor(F/2)*U),new rt),T=!1,g=rt.clone(e),C=t._property._samples||void 0,y=null;for(;!d;){m=t.getValueInReferenceFrame(Z,o,Dh,!0),rt.greaterThanOrEquals(Z,g)&&(l[h++]=p.clone(m)),IT=t.getValueInReferenceFrame(Z,ri.TEME),sv=t._velocity.getValueInReferenceFrame(Z,ri.TEME),Dh=p.cross(IT,sv,Dh),SI=p.cross(sv,Dh,SI),Dh=p.divideByScalar(SI,k.GRAVITATIONALPARAMETER,Dh),SI=p.divideByScalar(IT,p.magnitude(IT),SI),hL=p.subtract(Dh,SI,hL);let Q=p.magnitude(hL),J=p.dot(hL,IT)/(p.magnitude(hL)*p.magnitude(IT)),M=p.dot(IT,sv),V=Math.acos(J);M<0&&(V=2*Math.PI-V);let E=2*Math.PI/b;y!==null&&(E=2*E-Math.abs(V-y));let I=V+E;I>2*Math.PI&&(I-=2*Math.PI),y=V;let B=oTt(V,Q),X=oTt(I,Q),_=Math.abs(X-B);_>Math.PI&&(_=2*Math.PI-_);let P=u*(_/(2*Math.PI));if(Z=rt.addSeconds(Z,P,new rt),!T&&rt.greaterThanOrEquals(Z,A)){for(let w=0;w0){let u=Z.pop();r=this._polylineCollection.get(u),e.index=u}else e.index=this._polylineCollection.length,r=this._polylineCollection.add();r.id=n,e.polyline=r,qRe(e.polyline)}let m=et.getValueOrDefault(i._resolution,t,zRe);r.show=!0;let h=[];if(c(n._localReferenceEntity)){let Z=l0e(a,s,m),b=n._localReferenceEntity;for(let u=0;u=1/this._maxFPS))return!0;this._lastUpdate=i}let e=this._updaters;for(let i in e)e.hasOwnProperty(i)&&e[i].update(t);let n=this._items.values;if(!n.length&&c(this._updaters)&&Object.values(this._updaters).length){for(let i in this._updaters)this._updaters[i]&&this._scene.primitives.removeAndDestroy(this._updaters[i]._polylineCollection);this._updaters={}}for(let i=0,o=n.length;i-1;o--)a=e[o],c(a._path)&&c(a._position)&&l.set(a.id,new iTt(a));for(o=i.length-1;o>-1;o--)a=i[o],c(a._path)&&c(a._position)?l.contains(a.id)||l.set(a.id,new iTt(a)):(s=l.get(a.id),c(s)&&(c(s.updater)&&s.updater.removeObject(s),l.remove(a.id)));for(o=n.length-1;o>-1;o--)a=n[o],s=l.get(a.id),c(s)&&(c(s.updater)&&s.updater.removeObject(s),l.remove(a.id))};QF._subSample=dTt;var uL=QF;var i1i=R(W(),1);var MIi=R(W(),1);var kIi=R(W(),1);var NIi=R(W(),1),d0e={};var r0e=(()=>{var t=d0e.url;return function(e={}){var n=e,i,o;n.ready=new Promise((x,D)=>{i=x,o=D}),["_getCoveragePositions","_inflateEllipsoid","_malloc","_free","_memory","_fflush","__embind_initialize_bindings","___indirect_function_table","___start_em_asm","___stop_em_asm","onRuntimeInitialized"].forEach(x=>{Object.getOwnPropertyDescriptor(n.ready,x)||Object.defineProperty(n.ready,x,{get:()=>We("You are getting "+x+" on the Promise object, instead of the instance. Use .then() to get called back with the instance, see the MODULARIZE docs in src/settings.js"),set:()=>We("You are setting "+x+" on the Promise object, instead of the instance. Use .then() to get called back with the instance, see the MODULARIZE docs in src/settings.js")})}),globalThis.__dirname=globalThis.__dirname||"";var a=Object.assign({},n),s=[],l="./this.program",r=(x,D)=>{throw D},d=!0,m=!1,h=!1,Z=!1;if(n.ENVIRONMENT)throw new Error("Module.ENVIRONMENT has been deprecated. To force the environment, use the ENVIRONMENT compile-time option (for example, -sENVIRONMENT=web or -sENVIRONMENT=node)");var b="";function u(x){return n.locateFile?n.locateFile(x,b):b+x}var F,U,G,A;if(Z){if(typeof process=="object"&&typeof Og=="function"||typeof window=="object"||typeof importScripts=="function")throw new Error("not compiled for this environment (did you build to HTML and try to run it not on the web, or set ENVIRONMENT to something - like node - and run it someplace else - like on the web?)");typeof read<"u"&&(F=read),G=x=>{if(typeof readbuffer=="function")return new Uint8Array(readbuffer(x));let D=read(x,"binary");return V(typeof D=="object"),D},U=(x,D,j)=>{setTimeout(()=>D(G(x)))},typeof clearTimeout>"u"&&(globalThis.clearTimeout=x=>{}),typeof setTimeout>"u"&&(globalThis.setTimeout=x=>typeof x=="function"?x():We()),typeof scriptArgs<"u"?s=scriptArgs:typeof arguments<"u"&&(s=arguments),typeof quit=="function"&&(r=(x,D)=>{throw setTimeout(()=>{if(!(D instanceof _a)){let j=D;D&&typeof D=="object"&&D.stack&&(j=[D,D.stack]),g(`exiting due to exception: ${j}`)}quit(x)}),D}),typeof print<"u"&&(typeof console>"u"&&(console={}),console.log=print,console.warn=console.error=typeof printErr<"u"?printErr:print)}else if(d||m){if(m?b=self.location.href:typeof document<"u"&&document.currentScript&&(b=document.currentScript.src),t&&(b=t),b.indexOf("blob:")!==0?b=b.substr(0,b.replace(/[?#].*/,"").lastIndexOf("/")+1):b="",!(typeof window=="object"||typeof importScripts=="function"))throw new Error("not compiled for this environment (did you build to HTML and try to run it not on the web, or set ENVIRONMENT to something - like node - and run it someplace else - like on the web?)");F=x=>{var D=new XMLHttpRequest;return D.open("GET",x,!1),D.send(null),D.responseText},m&&(G=x=>{var D=new XMLHttpRequest;return D.open("GET",x,!1),D.responseType="arraybuffer",D.send(null),new Uint8Array(D.response)}),U=(x,D,j)=>{var lt=new XMLHttpRequest;lt.open("GET",x,!0),lt.responseType="arraybuffer",lt.onload=()=>{if(lt.status==200||lt.status==0&<.response){D(lt.response);return}j()},lt.onerror=j,lt.send(null)},A=x=>document.title=x}else throw new Error("environment detection error");var T=n.print||console.log.bind(console),g=n.printErr||console.error.bind(console);Object.assign(n,a),a=null,n8(),n.arguments&&(s=n.arguments),fe("arguments","arguments_"),n.thisProgram&&(l=n.thisProgram),fe("thisProgram","thisProgram"),n.quit&&(r=n.quit),fe("quit","quit_"),V(typeof n.memoryInitializerPrefixURL>"u","Module.memoryInitializerPrefixURL option was removed, use Module.locateFile instead"),V(typeof n.pthreadMainPrefixURL>"u","Module.pthreadMainPrefixURL option was removed, use Module.locateFile instead"),V(typeof n.cdInitializerPrefixURL>"u","Module.cdInitializerPrefixURL option was removed, use Module.locateFile instead"),V(typeof n.filePackagePrefixURL>"u","Module.filePackagePrefixURL option was removed, use Module.locateFile instead"),V(typeof n.read>"u","Module.read option was removed (modify read_ in JS)"),V(typeof n.readAsync>"u","Module.readAsync option was removed (modify readAsync in JS)"),V(typeof n.readBinary>"u","Module.readBinary option was removed (modify readBinary in JS)"),V(typeof n.setWindowTitle>"u","Module.setWindowTitle option was removed (modify setWindowTitle in JS)"),V(typeof n.TOTAL_MEMORY>"u","Module.TOTAL_MEMORY has been renamed Module.INITIAL_MEMORY"),fe("asm","wasmExports"),fe("read","read_"),fe("readAsync","readAsync"),fe("readBinary","readBinary"),fe("setWindowTitle","setWindowTitle"),V(!m,"worker environment detected but not enabled at build time. Add 'worker' to `-sENVIRONMENT` to enable."),V(!h,"node environment detected but not enabled at build time. Add 'node' to `-sENVIRONMENT` to enable."),V(!Z,"shell environment detected but not enabled at build time. Add 'shell' to `-sENVIRONMENT` to enable.");var C;n.wasmBinary&&(C=n.wasmBinary),fe("wasmBinary","wasmBinary");var y=n.noExitRuntime||!0;fe("noExitRuntime","noExitRuntime"),typeof WebAssembly!="object"&&We("no native wasm support detected");var Y,Q,J=!1,M;function V(x,D){x||We("Assertion failed"+(D?": "+D:""))}var E,I,B,X,_,P,w,z;function H(){var x=Y.buffer;n.HEAP8=E=new Int8Array(x),n.HEAP16=B=new Int16Array(x),n.HEAP32=_=new Int32Array(x),n.HEAPU8=I=new Uint8Array(x),n.HEAPU16=X=new Uint16Array(x),n.HEAPU32=P=new Uint32Array(x),n.HEAPF32=w=new Float32Array(x),n.HEAPF64=z=new Float64Array(x)}V(!n.STACK_SIZE,"STACK_SIZE can no longer be set at runtime. Use -sSTACK_SIZE at link time"),V(typeof Int32Array<"u"&&typeof Float64Array<"u"&&Int32Array.prototype.subarray!=null&&Int32Array.prototype.set!=null,"JS engine does not provide full typed array support"),V(!n.wasmMemory,"Use of `wasmMemory` detected. Use -sIMPORTED_MEMORY to define wasmMemory externally"),V(!n.INITIAL_MEMORY,"Detected runtime INITIAL_MEMORY setting. Use -sIMPORTED_MEMORY to define wasmMemory dynamically");var nt;function $(){var x=qW();V((x&3)==0),x==0&&(x+=4),P[x>>2]=34821223,P[x+4>>2]=2310721022,P[0]=1668509029}function dt(){if(!J){var x=qW();x==0&&(x+=4);var D=P[x>>2],j=P[x+4>>2];(D!=34821223||j!=2310721022)&&We(`Stack overflow! Stack cookie has been overwritten at ${na(x)}, expected hex dwords 0x89BACDFE and 0x2135467, but received ${na(j)} ${na(D)}`),P[0]!=1668509029&&We("Runtime error: The application has corrupted its heap memory area (address zero)!")}}(function(){var x=new Int16Array(1),D=new Int8Array(x.buffer);if(x[0]=25459,D[0]!==115||D[1]!==99)throw"Runtime error: expected the system to be little-endian! (Run with -sSUPPORT_BIG_ENDIAN to bypass)"})();var q=[],at=[],st=[],Et=!1,Qt=0;function Wt(){if(n.preRun)for(typeof n.preRun=="function"&&(n.preRun=[n.preRun]);n.preRun.length;)Mt(n.preRun.shift());bl(q)}function Nt(){V(!Et),Et=!0,dt(),!n.noFSInit&&!ht.init.initialized&&ht.init(),ht.ignorePermissions=!1,Ai.init(),bl(at)}function kt(){if(dt(),n.postRun)for(typeof n.postRun=="function"&&(n.postRun=[n.postRun]);n.postRun.length;)ie(n.postRun.shift());bl(st)}function Mt(x){q.unshift(x)}function qt(x){at.unshift(x)}function ie(x){st.unshift(x)}V(Math.imul,"This browser does not support Math.imul(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),V(Math.fround,"This browser does not support Math.fround(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),V(Math.clz32,"This browser does not support Math.clz32(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),V(Math.trunc,"This browser does not support Math.trunc(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill");var oe=0,He=null,rn=null,de={};function zt(x){for(var D=x;;){if(!de[x])return x;x=D+Math.random()}}function ke(x){oe++,n.monitorRunDependencies&&n.monitorRunDependencies(oe),x?(V(!de[x]),de[x]=1,He===null&&typeof setInterval<"u"&&(He=setInterval(()=>{if(J){clearInterval(He),He=null;return}var D=!1;for(var j in de)D||(D=!0,g("still waiting on run dependencies:")),g("dependency: "+j);D&&g("(end of list)")},1e4))):g("warning: run dependency added without ID")}function ue(x){if(oe--,n.monitorRunDependencies&&n.monitorRunDependencies(oe),x?(V(de[x]),delete de[x]):g("warning: run dependency removed without ID"),oe==0&&(He!==null&&(clearInterval(He),He=null),rn)){var D=rn;rn=null,D()}}function We(x){n.onAbort&&n.onAbort(x),x="Aborted("+x+")",g(x),J=!0,M=1;var D=new WebAssembly.RuntimeError(x);throw o(D),D}var un="data:application/octet-stream;base64,";function Ct(x){return x.startsWith(un)}function _t(x){return x.startsWith("file://")}function Je(x){return function(){V(Et,`native function \`${x}\` called before runtime initialization`);var D=Q[x];return V(D,`exported native function \`${x}\` not found`),D.apply(null,arguments)}}var xe;xe="data:application/octet-stream;base64,AGFzbQEAAAABrwRGYAF/AX9gAX8AYAJ/fwBgAn9/AX9gA39/fwF/YAZ/f39/f38Bf2AEf39/fwF/YAV/f39/fwF/YAN/f38AYAAAYAR/f39/AGAIf39/f39/f38Bf2AGf39/f39/AGAFf39/f38AYAABf2AHf39/f39/fwF/YAd/f39/f39/AGAFf35+fn4AYAF8AXxgBH98f38Bf2AFf39/f34Bf2ACfHwBfGADf35/AX5gC39/f39/f39/f39/AX9gCn9/f39/f39/f38AYAR/fn5/AGACf3wBf2AEf398fwF/YAZ/f39/fn4Bf2AHf39/f39+fgF/YAN/f38BfGACfH8BfGAFf398f38AYAN8fH8BfGAGf3x/f39/AX9gBX9/fn9/AGADf39/AX5gBH9/f38BfmAMf39/f39/f39/f39/AX9gBX9/f398AX9gD39/f39/f39/f39/f39/fwBgCH9/f39/f39/AGANf39/f39/f39/f39/fwBgCX9/f39/f39/fwBgAAF8YAR+fn5+AX9gA35+fgF/YAF+AX9gAn5+AXxgAn98AGACfn4BfWACf38BfGADf398AGAEf3x/fwBgA39/fAF/YAF+AX5gBX9/f3x/AX9gBn9/f3x/fwBgAXwAYAJ8fwF/YAJ+fwF/YAJ/fgBgAn9/AX5gA39/fgBgAn9+AX9gBH9/f34BfmADf39/AX1gCX9/f39/f39/fwF/YAp/f39/f39/f39/AX9gBH9/fn4AArEIJQNlbnYcZW1zY3JpcHRlbl9ydW5fc2NyaXB0X3N0cmluZwAAA2VudgtfX2N4YV90aHJvdwAIA2Vudg1fZW12YWxfZGVjcmVmAAEDZW52Fl9lbWJpbmRfcmVnaXN0ZXJfY2xhc3MAKgNlbnYiX2VtYmluZF9yZWdpc3Rlcl9jbGFzc19jb25zdHJ1Y3RvcgAMA2Vudh9fZW1iaW5kX3JlZ2lzdGVyX2NsYXNzX2Z1bmN0aW9uACsDZW52H19lbWJpbmRfcmVnaXN0ZXJfY2xhc3NfcHJvcGVydHkAGANlbnYTX2VtdmFsX2dldF9wcm9wZXJ0eQADA2VudhJfZW12YWxfbmV3X2NzdHJpbmcAAANlbnYJX2VtdmFsX2FzAB4DZW52Fl9lbXZhbF9ydW5fZGVzdHJ1Y3RvcnMAAQNlbnYZX2VtYmluZF9yZWdpc3Rlcl9mdW5jdGlvbgAQA2VudhhlbXNjcmlwdGVuX2FzbV9jb25zdF9pbnQABANlbnYVX2VtYmluZF9yZWdpc3Rlcl92b2lkAAIDZW52FV9lbWJpbmRfcmVnaXN0ZXJfYm9vbAANA2VudhtfZW1iaW5kX3JlZ2lzdGVyX3N0ZF9zdHJpbmcAAgNlbnYcX2VtYmluZF9yZWdpc3Rlcl9zdGRfd3N0cmluZwAIA2VudhZfZW1iaW5kX3JlZ2lzdGVyX2VtdmFsAAIDZW52GF9lbWJpbmRfcmVnaXN0ZXJfaW50ZWdlcgANA2VudhZfZW1iaW5kX3JlZ2lzdGVyX2Zsb2F0AAgDZW52HF9lbWJpbmRfcmVnaXN0ZXJfbWVtb3J5X3ZpZXcACANlbnYTZW1zY3JpcHRlbl9kYXRlX25vdwAsA2VudiBfZW1zY3JpcHRlbl9nZXRfbm93X2lzX21vbm90b25pYwAOFndhc2lfc25hcHNob3RfcHJldmlldzEHZmRfcmVhZAAGFndhc2lfc25hcHNob3RfcHJldmlldzEIZmRfd3JpdGUABhZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxCGZkX2Nsb3NlAAADZW52FWVtc2NyaXB0ZW5fbWVtY3B5X2JpZwAIA2VudglfdHpzZXRfanMACANlbnYWZW1zY3JpcHRlbl9yZXNpemVfaGVhcAAAA2VudgVhYm9ydAAJFndhc2lfc25hcHNob3RfcHJldmlldzERZW52aXJvbl9zaXplc19nZXQAAxZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxC2Vudmlyb25fZ2V0AAMDZW52CnN0cmZ0aW1lX2wABwNlbnYXX2VtYmluZF9yZWdpc3Rlcl9iaWdpbnQAEBZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxB2ZkX3NlZWsABwNlbnYKX21rdGltZV9qcwAAA2VudgpfZ210aW1lX2pzAAgDxATCBAkOAAEEAAQEBgkAHxEAAAEDAi0uGREZEREAAQkODg4OAQARERUvBBUwAjECMgECAAkBCQEAAAIJAAABAA4DBDM0AwgBBBISFTUCEwkBAwADCAgAAQkBDgMIGjYAAgMIEzcCBAQBCQ4DAwACAQECAgkAAAIBAhobOBsAAQAJOSAJEhISOgUJAAkSAAQEFgAJBAAWAyE7HwcPCAAKPA0DBCICCAAAPQAGERkKPj8GBAQDCUAAAAEAAQIEIwoEBAAAAwQECgoDAAEAAQABAQEBAAMDAAAAAAEAAQIAAQQEAAQAAQADAAAAAgIEAgIIBAADAQgCCAICAAIABAMCAAMAAwIEAwIAAwADAwADAQZBCgcKBAcKBAIABAUADwAAAQUACBcGCgQOJAIFJQUGJAUGBSUFDSZCBR4FCgUEAwUADwAFAwgXBAUFBQUFDSYFBQUHAAAHCgcEEAIUBxQnBAYQHAcHAAcQBQQUBxQnEBwHCwAFBQUMBQwFDQcLCwUFBQwFDAUNBwsPDA8AAgICAAICDxcCCAgAAAMDDw0PFwICAAIAAw8NHRgoBAUdGCgEBQQMDAIBCAIOCAgBAQABAAAAAAIBAAEAAQABAAECAQEAAAAAAQABAAEAAQECAQEBAAAAAgICAQAAAAICAgsLBwcACwsHAQALBAsHBwAABwALBwQGBgYDBAMEBgQHAQADBAMEBgQHAQABKSkDAwMDAwEJAQkEBAQDDAoNCggKDQoEAw0QDA0MDAAAAAABACEVBxAPQ0RFBAcBcAHOA84DBQcBAYAMgIACBhcEfwFBwLIYC38BQQALfwFBAAt/AUEACwedBBsGbWVtb3J5AgARX193YXNtX2NhbGxfY3RvcnMAJQZtYWxsb2MAMwRmcmVlADQQaW5mbGF0ZUVsbGlwc29pZACoARRnZXRDb3ZlcmFnZVBvc2l0aW9ucwCjAQZmZmx1c2gArgENX19nZXRUeXBlTmFtZQCrARtfZW1iaW5kX2luaXRpYWxpemVfYmluZGluZ3MArAEQX19lcnJub19sb2NhdGlvbgAmGV9faW5kaXJlY3RfZnVuY3Rpb25fdGFibGUBAAtzZXRUZW1wUmV0MAA/FWVtc2NyaXB0ZW5fc3RhY2tfaW5pdABAGWVtc2NyaXB0ZW5fc3RhY2tfZ2V0X2ZyZWUAQRllbXNjcmlwdGVuX3N0YWNrX2dldF9iYXNlAEIYZW1zY3JpcHRlbl9zdGFja19nZXRfZW5kAEMJc3RhY2tTYXZlAEQMc3RhY2tSZXN0b3JlAEUKc3RhY2tBbGxvYwBGHGVtc2NyaXB0ZW5fc3RhY2tfZ2V0X2N1cnJlbnQARCJfX2N4YV9pbmNyZW1lbnRfZXhjZXB0aW9uX3JlZmNvdW50AMMEFV9fY3hhX2lzX3BvaW50ZXJfdHlwZQDZBAxkeW5DYWxsX2ppamkA4QQOZHluQ2FsbF92aWlqaWkA4gQOZHluQ2FsbF9paWlpaWoA4wQPZHluQ2FsbF9paWlpaWpqAOQEEGR5bkNhbGxfaWlpaWlpamoA5QQJ4QYBAEEBC80DUlpcXV5eX2BhYmNkZWZncF1xcnN0dXldemB7fH1+f4ABgQGCAYMBVokBigFdcWCLAYwBXV5ecY0BjgGMAY8BkAGUAV1eXnFylQGWAYIBlwGDAZgBmQGaAX+bAZwBmwGdAZ4BggGhAaIBowFeqgHTAcQBxQHSAZQCNMECKPAD7wPtA+UD5wPpA+sD/wP+A/wD9QP3A/kD+wNvhAFekQGTAZEBkgGgAZ8Bd3iyAbABsQG1AbYBrwHaAdsB3AHdAd4B3wG1AbUB4AHiAeMB5AHlAeQB/gH/AdwB3QHeAd8BtQG1AYAC4gGCAuQBgwLkAdsBpwKoAqoCqwLsAe0B7gHvAdcB2QHYAdkB2wGkApwCpQKmAvkB+gH7AfwB/wGfAqACogKjAuwB7QHuAe8B1wHZAf8BmwKcAp0CngL5AfoB+wH8AbgEtwTcA68ErgSwBLEEsgSzBOkBtAS1BLYElwSWBJgEmgScBJ0EtQGfBKAEiASHBIkEigSLBIwEjQSBBIAEggSDBIQEhQSGBF6RAZEBowSkBKUEpgSnBKgEqQSqBOkBqwSsBK0EkQGhBKEEkAQnJ6IEJ5EBkwSUBJAEtQG1AZUEkgSRAZMElASQBLUBtQGVBJIEkQGOBI8EkAS1AbUBkQSSBJEBjgSPBJAEtQG1AZEEkgRekQGzArQCtQJekQG2ArcCuwKRAbwCwgLMAs4C0QLRAtMC1QLZAtsC3QKRAeAC5ALpAuoC6wLrAuwC7QLwAvEC8gKRAfMC9gL8Av0C/gL/AoMDhAORAYUDhwOLA4wDjQOOA5ADkQNekQGTA5QDlQOWA5gDmgOdA/ED8gPzA/QD9gP4A/oDXpEBkwOfA6ADoQOjA6UDqAPgA+ED4gPjA+YD6APqA94D3wOpA94D3wOrA5EBrAOsA60DrQOtA64DtQGvA68DkQGsA6wDrQOtA60DrgO1Aa8DrwORAbADsAOtA60DrQOxA7UBrwOvA5EBsAOwA60DrQOtA7EDtQGvA68DkQGzA7wDkQG+A8YDkQHIA8wD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AyABNgIwIAMgADYCNAsCQCACIAVGDQAgBUF/cyACaiEGAkAgAEEHcSIHRQRAIAUhAAwBC0EAIQQgBSEAA0AgASAALQAAOgAAIAFBAWohASAAQQFqIQAgBEEBaiIEIAdHDQALCyAGQQdJDQADQCABIAAtAAA6AAAgASAALQABOgABIAEgAC0AAjoAAiABIAAtAAM6AAMgASAALQAEOgAEIAEgAC0ABToABSABIAAtAAY6AAYgASAALQAHOgAHIAFBCGohASAAQQhqIgAgAkcNAAsLQQAhAiABQQA6AABB4AAQVEGO5RJB2AAQKyIJQQA6AFggA0EANgIoIANCADcDICADKAI0IAMsADsiCEH/AXEgCEEASCIAGyIBBH8gAygCMCADQTBqIAAbIQADQCADQSBqIAkgAkHYAHBqLQAAIAAgAmotAABzwBCGASACQQFqIgIgAUcNAAsgAygCICADQSBqIAMtACvAQQBIGwUgA0EgagsQACECIAMsACtBAEgEQCADKAIgEDQLIAIQLyIBQfD///8HTw0CAkAgAUEKTQRAIAMgAToAKyADQSBqIQAMAQsgAUEPckEBaiIEEFQhACADIARBgICAgHhyNgIoIAMgADYCICADIAE2AiQLIAAgAiABEEsgAWpBADoAACMAQRBrIgYkACAGQRA2AgwgA0EgaiIAKAIEIAAtAAsiAUH/AHEgAUGAAXFBB3YbIgFBAEkEQBDVAQALIAAoAgAgACAALQALQYABcUEHdhshCiAGIAE2AgggA0EIaiIBIQAgBkEIaiAGQQxqIAYoAgggBigCDEkbKAIAIQQjAEEQayIHJAACQCAEQfD///8HSQRAAkAgBEELSQRAIAAgBDoACwwBCyAHQQhqIARBC08EfyAEQRBqQXBxIgIgAkEBayICIAJBC0YbBUEKC0EBahCOAiAAIAcoAggiAjYCACAAIAcoAgxBgICAgHhyNgIIIAAgBDYCBCACIQALIAAgCiAEEOEBIARqQQA6AAAgB0EQaiQADAELEFUACyAGQRBqJAAgA0EUaiABIgAQWyAALAALQQBIBEAgACgCABA0C0GAAhBUQdzBAEHwARArIgFBADoA8AECQCADKAIYIAMtAB8iACAAwEEASCIAGyIGBEAgAUHwAWohBCADKAIUIANBFGogABshBwJAAkACQCAGQfABSg0AIAcs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IgZB//8BRwRAQQQgBg0BGkECQQMgAyAKhFAbDAILIAMgCoRQCwshBiACQjCIpyIIQf//AXEiB0H//wFGDQAgBg0BCyAFQRBqIAEgAiADIAQQPCAFIAUpAxAiAiAFKQMYIgEgAiABEDogBSkDCCECIAUpAwAhBAwBCyABIAJC////////////AIMiCiADIARC////////////AIMiCRA3QQBMBEAgASAKIAMgCRA3BEAgASEEDAILIAVB8ABqIAEgAkIAQgAQPCAFKQN4IQIgBSkDcCEEDAELIARCMIinQf//AXEhBiAHBH4gAQUgBUHgAGogASAKQgBCgICAgICAwLvAABA8IAUpA2giCkIwiKdB+ABrIQcgBSkDYAshBCAGRQRAIAVB0ABqIAMgCUIAQoCAgICAgMC7wAAQPCAFKQNYIglCMIinQfgAayEGIAUpA1AhAwsgCUL///////8/g0KAgICAgIDAAIQhCyAKQv///////z+DQoCAgICAgMAAhCEKIAYgB0gEQANAAn4gCiALfSADIARWrX0iCUIAWQRAIAkgBCADfSIEhFAEQCAFQSBqIAEgAkIAQgAQPCAFKQMoIQIgBSkDICEEDAULIAlCAYYgBEI/iIQMAQsgCkIBhiAEQj+IhAshCiAEQgGGIQQgB0EBayIHIAZKDQALIAYhBwsCQCAKIAt9IAMgBFatfSIJQgBTBEAgCiEJDAELIAkgBCADfSIEhEIAUg0AIAVBMGogASACQgBCABA8IAUpAzghAiAFKQMwIQQMAQsgCUL///////8/WARAA0AgBEI/iCEBIAdBAWshByAEQgGGIQQgASAJQgGGhCIJQoCAgICAgMAAVA0ACwsgCEGAgAJxIQYgB0EATARAIAVBQGsgBCAJQv///////z+DIAdB+ABqIAZyrUIwhoRCAEKAgICAgIDAwz8QPCAFKQNIIQIgBSkDQCEEDAELIAlC////////P4MgBiAHcq1CMIaEIQILIAAgBDcDACAAIAI3AwggBUGAAWokAAtSAQJ/Qaj7EygCACIBIABBB2pBeHEiAmohAAJAIAJBACAAIAFNGw0AIAA/AEEQdEsEQCAAEBxFDQELQaj7EyAANgIAIAEPC0Gg/xNBMDYCAEF/C8goAQt/IwBBEGsiCiQAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkAC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IAQgB3I2AgAgAiAANgIAIAAgAjYCGAwBCyABQRkgA0EBdmtBACADQR9HG3QhAyACKAIAIQIDQCACIgQoAgRBeHEgAUYNAiADQR12IQIgA0EBdCEDIAQgAkEEcWoiB0EQaigCACICDQALIAcgADYCECAAIAQ2AhgLIAAgADYCDCAAIAA2AggPCyAEKAIIIgEgADYCDCAEIAA2AgggAEEANgIYIAAgBDYCDCAAIAE2AggLC9sBAgF/An5BASEEAkAgAEIAUiABQv///////////wCDIgVCgICAgICAwP//AFYgBUKAgICAgIDA//8AURsNACACQgBSIANC////////////AIMiBkKAgICAgIDA//8AViAGQoCAgICAgMD//wBRGw0AIAAgAoQgBSAGhIRQBEBBAA8LIAEgA4NCAFkEQEF/IQQgACACVCABIANTIAEgA1EbDQEgACAChSABIAOFhEIAUg8LQX8hBCAAIAJWIAEgA1UgASADURsNACAAIAKFIAEgA4WEQgBSIQQLIAQLwAECAX8CfkF/IQMCQCAAQgBSIAFC////////////AIMiBEKAgICAgIDA//8AViAEQoCAgICAgMD//wBRGw0AIAJC////////////AIMiBUKAgICAgIDA//8AViAFQoCAgICAgMD//wBScQ0AIAAgBCAFhIRQBEBBAA8LIAEgAoNCAFkEQCABIAJSIAEgAlNxDQEgACABIAKFhEIAUg8LIABCAFIgASACVSABIAJRGw0AIAAgASAChYRCAFIhAwsgAwtQAQF+AkAgA0HAAHEEQCABIANBQGqthiECQgAhAQwBCyADRQ0AIAIgA60iBIYgAUHAACADa62IhCECIAEgBIYhAQsgACABNwMAIAAgAjcDCAupDwIFfw9+IwBB0AJrIgUkACAEQv///////z+DIQsgAkL///////8/gyEKIAIgBIVCgICAgICAgICAf4MhDSAEQjCIp0H//wFxIQgCQAJAIAJCMIinQf//AXEiCUH//wFrQYKAfk8EQCAIQf//AWtBgYB+Sw0BCyABUCACQv///////////wCDIgxCgICAgICAwP//AFQgDEKAgICAgIDA//8AURtFBEAgAkKAgICAgIAghCENDAILIANQIARC////////////AIMiAkKAgICAgIDA//8AVCACQoCAgICAgMD/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IQILIAAgATcDACAAIAI3AwgLwwoCBX8PfiMAQeAAayIFJAAgBEL///////8/gyEMIAIgBIVCgICAgICAgICAf4MhCiACQv///////z+DIg1CIIghDiAEQjCIp0H//wFxIQcCQAJAIAJCMIinQf//AXEiCUH//wFrQYKAfk8EQCAHQf//AWtBgYB+Sw0BCyABUCACQv///////////wCDIgtCgICAgICAwP//AFQgC0KAgICAgIDA//8AURtFBEAgAkKAgICAgIAghCEKDAILIANQIARC////////////AIMiAkKAgICAgIDA//8AVCACQoCAgICAgMD//wBRG0UEQCAEQoCAgICAgCCEIQogAyEBDAILIAEgC0KAgICAgIDA//8AhYRQBEAgAiADhFAEQEKAgICAgIDg//8AIQpCACEBDAMLIApCgICAgICAwP//AIQhCkIAIQEMAgsgAyACQoCAgICAgMD//wCFhFAEQCABIAuEIQJCACEBIAJQBEBCgICAgICA4P//ACEKDAMLIApCgICAgICAwP//AIQhCgwCCyABIAuEUARAQgAhAQwCCyACIAOEUARAQgAhAQwCCyALQv///////z9YBEAgBUHQAGogASANIAEgDSANUCIGG3kgBkEGdK18pyIGQQ9rEDlBECAGayEGIAUpA1giDUIgiCEOIAUpA1AhAQsgAkL///////8/Vg0AIAVBQGsgAyAMIAMgDCAMUCIIG3kgCEEGdK18pyIIQQ9rEDkgBiAIa0EQaiEGIAUpA0ghDCAFKQNAIQMLIANCD4YiC0KAgP7/D4MiAiABQiCIIgR+IhAgC0IgiCITIAFC/////w+DIgF+fCIPQiCGIhEgASACfnwiCyARVK0gAiANQv////8PgyINfiIVIAQgE358IhEgDEIPhiISIANCMYiEQv////8PgyIDIAF+fCIUIA8gEFStQiCGIA9CIIiEfCIPIAIgDkKAgASEIgx+IhYgDSATfnwiDiASQiCIQoCAgIAIhCICIAF+fCIQIAMgBH58IhJCIIZ8Ihd8IQEgByAJaiAGakH//wBrIQYCQCACIAR+IhggDCATfnwiBCAYVK0gBCAEIAMgDX58IgRWrXwgAiAMfnwgBCAEIBEgFVStIBEgFFatfHwiBFatfCADIAx+IgMgAiANfnwiAiADVK1CIIYgAkIgiIR8IAQgAkIghnwiAiAEVK18IAIgAiAQIBJWrSAOIBZUrSAOIBBWrXx8QiCGIBJCIIiEfCICVq18IAIgAiAPIBRUrSAPIBdWrXx8IgJWrXwiBEKAgICAgIDAAINCAFIEQCAGQQFqIQYMAQsgC0I/iCEDIARCAYYgAkI/iIQhBCACQgGGIAFCP4iEIQIgC0IBhiELIAMgAUIBhoQhAQsgBkH//wFOBEAgCkKAgICAgIDA//8AhCEKQgAhAQwBCwJ+IAZBAEwEQEEBIAZrIgdB/wBNBEAgBUEwaiALIAEgBkH/AGoiBhA5IAVBIGogAiAEIAYQOSAFQRBqIAsgASAHEDsgBSACIAQgBxA7IAUpAzAgBSkDOIRCAFKtIAUpAyAgBSkDEISEIQsgBSkDKCAFKQMYhCEBIAUpAwAhAiAFKQMIDAILQgAhAQwCCyAEQv///////z+DIAatQjCGhAsgCoQhCiALUCABQgBZIAFCgICAgICAgICAf1EbRQRAIAogAkIBfCIBUK18IQoMAQsgCyABQoCAgICAgICAgH+FhEIAUgRAIAIhAQwBCyAKIAIgAkIBg3wiASACVK18IQoLIAAgATcDACAAIAo3AwggBUHgAGokAAt1AQF+IAAgASAEfiACIAN+fCADQiCIIgIgAUIgiCIEfnwgA0L/////D4MiAyABQv////8PgyIBfiIFQiCIIAMgBH58IgNCIIh8IAEgAn4gA0L/////D4N8IgFCIIh8NwMIIAAgBUL/////D4MgAUIghoQ3AwALpgEBAX8CfwJAIAAoAkwiAUEATgRAIAFFDQFBhJkUKAIAIAFB/////3txRw0BCyAAKAIEIgEgACgCCEcEQCAAIAFBAWo2AgQgAS0AAAwCCyAAEMgBDAELIAAgACgCTCIBQf////8DIAEbNgJMAn8gACgCBCIBIAAoAghHBEAgACABQQFqNgIEIAEtAAAMAQsgABDIAQshASAAKAJMGiAAQQA2AkwgAQsLBgAgACQBCw4AQcCyGCQDQcCyFCQCCwcAIwAjAmsLBAAjAwsEACMCCwQAIwALBgAgACQACxAAIwAgAGtBcHEiACQAIAALxQkCBH8FfiMAQfAAayIGJAAgBEL///////////8AgyEJAkACQCABUCIFIAJC////////////AIMiCkKAgICAgIDA//8AfUKAgICAgIDAgIB/VCAKUBtFBEAgA0IAUiAJQoCAgICAgMD//wB9IgtCgICAgICAwICAf1YgC0KAgICAgIDAgIB/URsNAQsgBSAKQoCAgICAgMD//wBUIApCgICAgICAwP//AFEbRQRAIAJCgICAgICAIIQhBCABIQMMAgsgA1AgCUKAgICAgIDA//8AVCAJQoCAgICAgMD//wBRG0UEQCAEQoCAgICAgCCEIQQMAgsgASAKQoCAgICAgMD//wCFhFAEQEKAgICAgIDg//8AIAIgASADhSACIASFQoCAgICAgICAgH+FhFAiBRshBEIAIAEgBRshAwwCCyADIAlCgICAgICAwP//AIWEUA0BIAEgCoRQBEAgAyAJhEIAUg0CIAEgA4MhAyACIASDIQQMAgsgAyAJhEIAUg0AIAEhAyACIQQMAQsgAyABIAEgA1QgCSAKViAJIApRGyIIGyEKIAQgAiAIGyILQv///////z+DIQkgAiAEIAgbIgJCMIinQf//AXEhByALQjCIp0H//wFxIgVFBEAgBkHgAGogCiAJIAogCSAJUCIFG3kgBUEGdK18pyIFQQ9rEDkgBikDaCEJIAYpA2AhCkEQIAVrIQULIAEgAyAIGyEDIAJC////////P4MhBCAHRQRAIAZB0ABqIAMgBCADIAQgBFAiBxt5IAdBBnStfKciB0EPaxA5QRAgB2shByAGKQNYIQQgBikDUCEDCyAEQgOGIANCPYiEQoCAgICAgIAEhCEBIAlCA4YgCkI9iIQhBCACIAuFIQ0CfiADQgOGIgIgBSAHRg0AGiAFIAdrIgdB/wBLBEBCACEBQgEMAQsgBkFAayACIAFBgAEgB2sQOSAGQTBqIAIgASAHEDsgBikDOCEBIAYpAzAgBikDQCAGKQNIhEIAUq2ECyEJIARCgICAgICAgASEIQwgCkIDhiEKAkAgDUIAUwRAQgAhA0IAIQQgCSAKhSABIAyFhFANAiAKIAl9IQIgDCABfSAJIApWrX0iBEL/////////A1YNASAGQSBqIAIgBCACIAQgBFAiBxt5IAdBBnStfKdBDGsiBxA5IAUgB2shBSAGKQMoIQQgBikDICECDAELIAkgCnwiAiAJVK0gASAMfHwiBEKAgICAgICACINQDQAgCUIBgyAEQj+GIAJCAYiEhCECIAVBAWohBSAEQgGIIQQLIAtCgICAgICAgICAf4MhASAFQf//AU4EQCABQoCAgICAgMD//wCEIQRCACEDDAELQQAhBwJAIAVBAEoEQCAFIQcMAQsgBkEQaiACIAQgBUH/AGoQOSAGIAIgBEEBIAVrEDsgBikDACAGKQMQIAYpAxiEQgBSrYQhAiAGKQMIIQQLIAKnQQdxIgVBBEutIARCPYYgAkIDiIQiAnwiAyACVK0gBEIDiEL///////8/gyAHrUIwhoQgAYR8IQQCQCAFQQRGBEAgBCADQgGDIgEgA3wiAyABVK18IQQMAQsgBUUNAQsLIAAgAzcDACAAIAQ3AwggBkHwAGokAAtEAQF/IwBBEGsiBSQAIAUgASACIAMgBEKAgICAgICAgIB/hRBHIAUpAwAhASAAIAUpAwg3AwggACABNwMAIAVBEGokAAuBDAMFfAN+Bn8jAEEQayINJAACQAJAIAG9IghCNIinIgxB/w9xIg5BvghrIg9B/35LIAC9IgdCNIinIgpB/w9rQYJwT3ENACAIQgGGQoCAgICAgIAQfEKBgICAgICAEFQEQEQAAAAAAADwPyECIAdCgICAgICAgPg/UQ0CIAhCAYYiCVANAiAJQoGAgICAgIBwVCAHQgGGIgdCgICAgICAgHBYcUUEQCAAIAGgIQIMAwsgB0KAgICAgICA8P8AUQ0CRAAAAAAAAAAAIAEgAaIgB0L/////////7/8AViAIQgBZcxshAgwCCyAHQgGGQoCAgICAgIAQfEKBgICAgICAEFQEQCAAIACiIQIgB0IAUwRAIAKaIAIgCBBKQQFGGyECCyAIQgBZDQIjAEEQayIKRAAAAAAAAPA/IAKjOQMIIAorAwghAgwCCyAHQgBTBEAgCBBKIgtFBEAgACAAoSIAIACjIQIMAwsgCkH/D3EhCiALQQFGQRJ0IQsgB0L///////////8AgyEHCyAPQf9+TQRARAAAAAAAAPA/IQIgB0KAgICAgICA+D9RDQIgDkG9B00EQCABIAGaIAdCgICAgICAgPg/VhtEAAAAAAAA8D+gIQIMAwsgDEGAEEkgB0KBgICAgICA+D9URwRAIwBBEGsiCkQAAAAAAAAAcDkDCCAKKwMIRAAAAAAAAABwoiECDAMLIwBBEGsiCkQAAAAAAAAAEDkDCCAKKwMIRAAAAAAAAAAQoiECDAILIAoNACAARAAAAAAAADBDor1C////////////AINCgICAgICAgKADfSEHCwJ8IAhCgICAQIO/IgUgDSAHQoCAgIDQqqXzP30iCEI0h6e3IgNB+BgrAwCiIAhCLYinQf8AcUEFdCIKQdAZaisDAKAgByAIQoCAgICAgIB4g30iB0KAgICACHxCgICAgHCDvyIAIApBuBlqKwMAIgSiRAAAAAAAAPC/oCICIAe/IAChIASiIgSgIgAgA0HwGCsDAKIgCkHIGWorAwCgIgMgACADoCIDoaCgIAQgAEGAGSsDACIEoiIGIAIgBKIiBKCioCACIASiIgIgAyADIAKgIgKhoKAgACAAIAaiIgOiIAMgAyAAQbAZKwMAokGoGSsDAKCiIABBoBkrAwCiQZgZKwMAoKCiIABBkBkrAwCiQYgZKwMAoKCioCIAIAIgAiAAoCICoaA5AwggAr1CgICAQIO/IgOiIQAgASAFoSADoiANKwMIIAIgA6GgIAGioCEBAkAgAL1CNIinQf8PcSIKQckHa0E/SQ0AIApByQdJBEAgAEQAAAAAAADwP6AiAJogACALGwwCCyAKQYkISSEMQQAhCiAMDQAgAL1CAFMEQCMAQRBrIgpEAAAAAAAAAJBEAAAAAAAAABAgCxs5AwggCisDCEQAAAAAAAAAEKIMAgsjAEEQayIKRAAAAAAAAADwRAAAAAAAAABwIAsbOQMIIAorAwhEAAAAAAAAAHCiDAELQYAIKwMAIACiQYgIKwMAIgKgIgMgAqEiAkGYCCsDAKIgAkGQCCsDAKIgAKCgIAGgIgAgAKIiASABoiAAQbgIKwMAokGwCCsDAKCiIAEgAEGoCCsDAKJBoAgrAwCgoiADvSIIp0EEdEHwD3EiDEHwCGorAwAgAKCgoCEAIAxB+AhqKQMAIAggC618Qi2GfCEHIApFBEACfCAIQoCAgIAIg1AEQCAHQoCAgICAgICIP32/IgEgAKIgAaBEAAAAAAAAAH+iDAELIAdCgICAgICAgPA/fCIHvyIBIACiIgMgAaAiAJlEAAAAAAAA8D9jBHwjAEEQayIKIApEAAAAAAAAEAA5AwggCisDCEQAAAAAAAAQAKI5AwggB0KAgICAgICAgIB/g78gAEQAAAAAAADwv0QAAAAAAADwPyAARAAAAAAAAAAAYxsiAqAiBSADIAEgAKGgIAAgAiAFoaCgoCACoSIAIABEAAAAAAAAAABhGwUgAAtEAAAAAAAAEACiCwwBCyAHvyIBIACiIAGgCyECCyANQRBqJAAgAgtOAgF/AX4Cf0EAIABCNIinQf8PcSIBQf8HSQ0AGkECIAFBswhLDQAaQQBCAUGzCCABa62GIgJCAX0gAINCAFINABpBAkEBIAAgAoNQGwsL6AIBAn8CQCAAIAFGDQAgASAAIAJqIgRrQQAgAkEBdGtNBEAgACABIAIQKw8LIAAgAXNBA3EhAwJAAkAgACABSQRAIAMEQCAAIQMMAwsgAEEDcUUEQCAAIQMMAgsgACEDA0AgAkUNBCADIAEtAAA6AAAgAUEBaiEBIAJBAWshAiADQQFqIgNBA3ENAAsMAQsCQCADDQAgBEEDcQRAA0AgAkUNBSAAIAJBAWsiAmoiAyABIAJqLQAAOgAAIANBA3ENAAsLIAJBA00NAANAIAAgAkEEayICaiABIAJqKAIANgIAIAJBA0sNAAsLIAJFDQIDQCAAIAJBAWsiAmogASACai0AADoAACACDQALDAILIAJBA00NAANAIAMgASgCADYCACABQQRqIQEgA0EEaiEDIAJBBGsiAkEDSw0ACwsgAkUNAANAIAMgAS0AADoAACADQQFqIQMgAUEBaiEBIAJBAWsiAg0ACwsgAAuQBAIEfgJ/AkACQCABvSIEQgGGIgNQDQAgAb0hAiAAvSIFQjSIp0H/D3EiBkH/D0YNACACQv///////////wCDQoGAgICAgID4/wBUDQELIAAgAaIiACAAow8LIAMgBUIBhiICWgRAIABEAAAAAAAAAACiIAAgAiADURsPCyAEQjSIp0H/D3EhBwJ+IAZFBEBBACEGIAVCDIYiAkIAWQRAA0AgBkEBayEGIAJCAYYiAkIAWQ0ACwsgBUEBIAZrrYYMAQsgBUL/////////B4NCgICAgICAgAiECyECAn4gB0UEQEEAIQcgBEIMhiIDQgBZBEADQCAHQQFrIQcgA0IBhiIDQgBZDQALCyAEQQEgB2uthgwBCyAEQv////////8Hg0KAgICAgICACIQLIQQgBiAHSgRAA0ACQCACIAR9IgNCAFMNACADIgJCAFINACAARAAAAAAAAAAAog8LIAJCAYYhAiAGQQFrIgYgB0oNAAsgByEGCwJAIAIgBH0iA0IAUw0AIAMiAkIAUg0AIABEAAAAAAAAAACiDwsCQCACQv////////8HVgRAIAIhAwwBCwNAIAZBAWshBiACQoCAgICAgIAEVCEHIAJCAYYiAyECIAcNAAsLIAVCgICAgICAgICAf4MhAiAGQQBKBH4gA0KAgICAgICACH0gBq1CNIaEBSADQQEgBmutiAsgAoS/C9EDAgJ+An8jAEEgayIEJAACQCABQv///////////wCDIgNCgICAgICAwIA8fSADQoCAgICAgMD/wwB9VARAIAFCBIYgAEI8iIQhAyAAQv//////////D4MiAEKBgICAgICAgAhaBEAgA0KBgICAgICAgMAAfCECDAILIANCgICAgICAgIBAfSECIABCgICAgICAgIAIUg0BIAIgA0IBg3whAgwBCyAAUCADQoCAgICAgMD//wBUIANCgICAgICAwP//AFEbRQRAIAFCBIYgAEI8iIRC/////////wODQoCAgICAgID8/wCEIQIMAQtCgICAgICAgPj/ACECIANC////////v//DAFYNAEIAIQIgA0IwiKciBUGR9wBJDQAgBEEQaiAAIAFC////////P4NCgICAgICAwACEIgIgBUGB9wBrEDkgBCAAIAJBgfgAIAVrEDsgBCkDCEIEhiAEKQMAIgBCPIiEIQIgBCkDECAEKQMYhEIAUq0gAEL//////////w+DhCIAQoGAgICAgICACFoEQCACQgF8IQIMAQsgAEKAgICAgICAgAhSDQAgAkIBgyACfCECCyAEQSBqJAAgAiABQoCAgICAgICAgH+DhL8LfgICfwF+IwBBEGsiAyQAIAACfiABRQRAQgAMAQsgAyABIAFBH3UiAnMgAmsiAq1CACACZyICQdEAahA5IAMpAwhCgICAgICAwACFQZ6AASACa61CMIZ8IAFBgICAgHhxrUIghoQhBCADKQMACzcDACAAIAQ3AwggA0EQaiQAC/kBAgN+An8jAEEQayIFJAACfiABvSIDQv///////////wCDIgJCgICAgICAgAh9Qv/////////v/wBYBEAgAkI8hiEEIAJCBIhCgICAgICAgIA8fAwBCyACQoCAgICAgID4/wBaBEAgA0I8hiEEIANCBIhCgICAgICAwP//AIQMAQsgAlAEQEIADAELIAUgAkIAIAOnZ0EgaiACQiCIp2cgAkKAgICAEFQbIgZBMWoQOSAFKQMAIQQgBSkDCEKAgICAgIDAAIVBjPgAIAZrrUIwhoQLIQIgACAENwMAIAAgAiADQoCAgICAgICAgH+DhDcDCCAFQRBqJAALYwIBfwF+IwBBEGsiAiQAIAACfiABRQRAQgAMAQsgAiABrUIAIAFnIgFB0QBqEDkgAikDCEKAgICAgIDAAIVBnoABIAFrrUIwhnwhAyACKQMACzcDACAAIAM3AwggAkEQaiQAC7QDAgN/AX4jAEEgayIDJAACQCABQv///////////wCDIgVCgICAgICAwMA/fSAFQoCAgICAgMC/wAB9VARAIAFCGYinIQQgAFAgAUL///8PgyIFQoCAgAhUIAVCgICACFEbRQRAIARBgYCAgARqIQIMAgsgBEGAgICABGohAiAAIAVCgICACIWEQgBSDQEgAiAEQQFxaiECDAELIABQIAVCgICAgICAwP//AFQgBUKAgICAgIDA//8AURtFBEAgAUIZiKdB////AXFBgICA/gdyIQIMAQtBgICA/AchAiAFQv///////7+/wABWDQBBACECIAVCMIinIgRBkf4ASQ0AIANBEGogACABQv///////z+DQoCAgICAgMAAhCIFIARBgf4AaxA5IAMgACAFQYH/ACAEaxA7IAMpAwgiAEIZiKchAiADKQMAIAMpAxAgAykDGIRCAFKthCIFUCAAQv///w+DIgBCgICACFQgAEKAgIAIURtFBEAgAkEBaiECDAELIAUgAEKAgIAIhYRCAFINACACQQFxIAJqIQILIANBIGokACACIAFCIIinQYCAgIB4cXK+CxgAQa+DFCwAAEEASARAQaSDFCgCABA0CwtqAQN/IAEQLyICQfD///8HSQRAAkAgAkEKTQRAIAAgAjoACyAAIQMMAQsgAkEPckEBaiIEEFQhAyAAIARBgICAgHhyNgIIIAAgAzYCACAAIAI2AgQLIAMgASACEEsgAmpBADoAAA8LEFUACzYBAX9BASAAIABBAU0bIQACQANAIAAQMyIBDQFBsLIUKAIAIgEEQCABEQkADAELCxAdAAsgAQsIAEGoPxBYAAsYAEGfgxQsAABBAEgEQEGUgxQoAgAQNAsLCABBuzwQWAALYQEDf0EIEFkiAUGc+xM2AgAgAUHI+RM2AgAgABAvIgJBDWoQVCIDQQA2AgggAyACNgIEIAMgAjYCACABIANB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w6T/A00EQCACQYCAwPIDSQ0BIABEAAAAAAAAAABBABDfBCEADAELIAJBgIDA/wdPBEAgACAAoSEADAELAkACQAJAAkAgACABELkBQQNxDgMAAQIDCyABKwMAIAErAwhBARDfBCEADAMLIAErAwAgASsDCBDgBCEADAILIAErAwAgASsDCEEBEN8EmiEADAELIAErAwAgASsDCBDgBJohAAsgAUEQaiQAIAALqAMCBX8BfiAAvUL///////////8Ag0KBgICAgICA+P8AVCABvUL///////////8Ag0KAgICAgICA+P8AWHFFBEAgACABoA8LIAG9IgdCIIinIgJBgIDA/wNrIAenIgVyRQRAIAAQpwEPCyACQR52QQJxIgYgAL0iB0I/iKdyIQMCQCAHQiCIp0H/////B3EiBCAHp3JFBEACQAJAIANBAmsOAgABAwtEGC1EVPshCUAPC0QYLURU+yEJwA8LIAJB/////wdxIgIgBXJFBEBEGC1EVPsh+T8gAKYPCwJAIAJBgIDA/wdGBEAgBEGAgMD/B0cNASADQQN0QYD2EmorAwAPCyAEQYCAwP8HRyACQYCAgCBqIARPcUUEQEQYLURU+yH5PyAApg8LAnwgBgRARAAAAAAAAAAAIARBgICAIGogAkkNARoLIAAgAaOZEKcBCyEAAkACQAJAIAMOAwQAAQILIACaDwtEGC1EVPshCUAgAEQHXBQzJqahvKChDwsgAEQHXBQzJqahvKBEGC1EVPshCcCgDwsgA0EDdEGg9hJqKwMAIQALIAALryACMXwEfyMAQTBrIjUkACAAIAE5A4ABIABBADYCDCAAKwPYASABIAGiIgWiIQggACsDwAEgAaIgACsD+AWgIQogBSAAKwOIAaIhEiAAKwPgBSIGIAArAzCiIAGiIRhEAAAAAAAA8D8gACsDKCABoqEhDyAAKwNoIicgAaIgACsDiAYiKKAhDCAAKwO4ASABoiAAKwOQBqAhBCAAKwOQByEdIAArA4gHIR8gACgCFEEBRwRAIAUgAaIiCSABoiIHIAEgACsDoAGiIAArA5gBoKIgACsDkAEgCaIgEqCgIRIgDyAAKwNAIAWioSAAKwNIIAmioSAAKwNQIAeioSEPIAArA2AhBSAEEGohCSAMIAArA3AgAaIgACsD0AEgBSAJokQAAAAAAADwP6AiBSAF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aiAJIARrQQJ0aigCAEUNAAsgAyAEaiEEA0AgBkHAAmogAyAKaiIHQQN0aiADQQFqIgMgEGpBAnRB0PYSaigCALc5AwBBACECRAAAAAAAAAAAIQAgCkEASgRAA0AgDyACQQN0aisDACAGQcACaiAHIAJrQQN0aisDAKIgAKAhACACQQFqIgIgCkcNAAsLIAYgA0EDdGogADkDACADIARIDQALIAQhAwwACwALIQMgCCsDACEAIBpCAFMEQCABIACaOQMAIAEgCCsDCJo5AwhBACADayEDDAELIAEgADkDACABIAgrAwg5AwgLIAhBMGokACADC38CAX8BfiAAvSIDQjSIp0H/D3EiAkH/D0cEfCACRQRAIAEgAEQAAAAAAAAAAGEEf0EABSAARAAAAAAAAPBDoiABELoBIQAgASgCAEFAags2AgAgAA8LIAEgAkH+B2s2AgAgA0L/////////h4B/g0KAgICAgICA8D+EvwUgAAsLxgIBBH8jAEHQAWsiBSQAIAUgAjYCzAEgBUGgAWoiAkEAQSgQKRogBSAFKALMATYCyAECQEEAIAEgBUHIAWogBUHQAGogAiADIAQQvAFBAEgEQEF/IQQMAQsgACgCTEEATiEGIAAgACgCACIIQV9xNgIAAn8CQAJAIAAoAjBFBEAgAEHQADYCMCAAQQA2AhwgAEIANwMQIAAoAiwhByAAIAU2AiwMAQsgACgCEA0BC0F/IAAQKg0BGgsgACABIAVByAFqIAVB0ABqIAVBoAFqIAMgBBC8AQshAiAHBEAgAEEAQQAgACgCJBEEABogAEEANgIwIAAgBzYCLCAAQQA2AhwgACgCFCEBIABCADcDECACQX8gARshAgsgACAAKAIAIgAgCEEgcXI2AgBBfyACIABBIHEbIQQgBkUNAAsgBUHQAWokACAEC50TAhN/AX4jAEHQAGsiCCQAIAggATYCTCAIQTdqIRggCEE4aiESAkACQAJAA0BBACEHA0AgASENIAcgEUH/////B3NKDQIgByARaiERAkACQAJAIA0iBy0AACILBEADQAJAAkAgC0H/AXEiAUUEQCAHIQEMAQsgAUElRw0BIAchCwNAIAstAAFBJUcEQCALIQEMAgsgB0EBaiEHIAstAAIhCSALQQJqIgEhCyAJQSVGDQALCyAHIA1rIgcgEUH/////B3MiGUoNCCAABEAgACANIAcQvQELIAcNBiAIIAE2AkwgAUEBaiEHQX8hEAJAIAEsAAEiCUEwa0EKTw0AIAEtAAJBJEcNACABQQNqIQcgCUEwayEQQQEhEwsgCCAHNgJMQQAhDAJAIAcsAAAiC0EgayIBQR9LBEAgByEJDAELIAchCUEBIAF0IgFBidEEcUUNAANAIAggB0EBaiIJNgJMIAEgDHIhDCAHLAABIgtBIGsiAUEgTw0BIAkhB0EBIAF0IgFBidEEcQ0ACwsCQCALQSpGBEACfwJAIAksAAEiAUEwa0EKTw0AIAktAAJBJEcNACABQTBrIQECfyAARQRAIAQgAUECdGpBCjYCAEEADAELIAMgAUEDdGooAgALIQ8gCUEDaiEBQQEMAQsgEw0GIAlBAWohASAARQRAIAggATYCTEEAIRNBACEPDAMLIAIgAigCACIHQQRqNgIAIAcoAgAhD0EACyETIAggATYCTCAPQQBODQFBACAPayEPIAxBgMAAciEMDAELIAhBzABqEL4BIg9BAEgNCSAIKAJMIQELQQAhB0F/IQoCf0EAIAEtAABBLkcNABogAS0AAUEqRgRAAn8CQCABLAACIglBMGtBCk8NACABLQADQSRHDQAgCUEwayEJIAFBBGohAQJ/IABFBEAgBCAJQQJ0akEKNgIAQQAMAQsgAyAJQQN0aigCAAsMAQsgEw0GIAFBAmohAUEAIABFDQAaIAIgAigCACIJQQRqNgIAIAkoAgALIQogCCABNgJMIApBf3NBH3YMAQsgCCABQQFqNgJMIAhBzABqEL4BIQogCCgCTCEBQQELIRQDQCAHIRVBHCEOIAEiFywAACIHQfsAa0FGSQ0KIBdBAWohASAHIBVBOmxqQZ+ME2otAAAiB0EBa0EISQ0ACyAIIAE2AkwCQCAHQRtHBEAgB0UNCyAQQQBOBEAgAEUEQCAEIBBBAnRqIAc2AgAMCwsgCCADIBBBA3RqKQMANwNADAILIABFDQcgCEFAayAHIAIgBhC/AQwBCyAQQQBODQpBACEHIABFDQcLQX8hDiAALQAAQSBxDQogDEH//3txIgsgDCAMQYDAAHEbIQxBACEQQYo7IRYgEiEJAkACQAJAAn8CQAJAAkACQAJ/AkACQAJAAkACQAJAAkAgFywAACIHQV9xIAcgB0EPcUEDRhsgByAVGyIHQdgAaw4hBBQUFBQUFBQUDhQPBg4ODhQGFBQUFAIFAxQUCRQBFBQEAAsCQCAHQcEAaw4HDhQLFA4ODgALIAdB0wBGDQkMEwsgCCkDQCEaQYo7DAULQQAhBwJAAkACQAJAAkACQAJAIBVB/wFxDggAAQIDBBoFBhoLIAgoAkAgETYCAAwZCyAIKAJAIBE2AgAMGAsgCCgCQCARrDcDAAwXCyAIKAJAIBE7AQAMFgsgCCgCQCAROgAADBULIAgoAkAgETYCAAwUCyAIKAJAIBGsNwMADBMLQQggCiAKQQhNGyEKIAxBCHIhDEH4ACEHCyASIQ0gB0EgcSELIAgpA0AiGkIAUgRAA0AgDUEBayINIBqnQQ9xQbCQE2otAAAgC3I6AAAgGkIPViEOIBpCBIghGiAODQALCyAIKQNAUA0DIAxBCHFFDQMgB0EEdkGKO2ohFkECIRAMAwsgEiEHIAgpA0AiGkIAUgRAA0AgB0EBayIHIBqnQQdxQTByOgAAIBpCB1YhDSAaQgOIIRogDQ0ACwsgByENIAxBCHFFDQIgCiASIA1rIgdBAWogByAKSBshCgwCCyAIKQNAIhpCAFMEQCAIQgAgGn0iGjcDQEEBIRBBijsMAQsgDEGAEHEEQEEBIRBBizsMAQtBjDtBijsgDEEBcSIQGwshFiAaIBIQwAEhDQsgFEEAIApBAEgbDQ8gDEH//3txIAwgFBshDAJAIAgpA0AiGkIAUg0AIAoNACASIQ1BACEKDAwLIAogGlAgEiANa2oiByAHIApIGyEKDAsLIAgoAkAiB0G95hIgBxsiDSIHQQBB/////wcgCiAKQf////8HTxsiCRCHASIMIAdrIAkgDBsiByANaiEJIApBAE4EQCALIQwgByEKDAsLIAshDCAHIQogCS0AAA0ODAoLIAoEQCAIKAJADAILQQAhByAAQSAgD0EAIAwQwQEMAgsgCEEANgIMIAggCCkDQD4CCCAIIAhBCGoiBzYCQEF/IQogBwshC0EAIQcCQANAIAsoAgAiCUUNAQJAIAhBBGogCRDCASIJQQBIIg0NACAJIAogB2tLDQAgC0EEaiELIAcgCWoiByAKSQ0BDAILCyANDQ4LQT0hDiAHQQBIDQwgAEEgIA8gByAMEMEBIAdFBEBBACEHDAELQQAhCSAIKAJAIQsDQCALKAIAIg1FDQEgCEEEaiANEMIBIg0gCWoiCSAHSw0BIAAgCEEEaiANEL0BIAtBBGohCyAHIAlLDQALCyAAQSAgDyAHIAxBgMAAcxDBASAPIAcgByAPSBshBwwICyAUQQAgCkEASBsNCUE9IQ4gACAIKwNAIA8gCiAMIAcgBREiACIHQQBODQcMCgsgCCAIKQNAPAA3QQEhCiAYIQ0gCyEMDAQLIActAAEhCyAHQQFqIQcMAAsACyARIQ4gAA0HIBNFDQJBASEHA0AgBCAHQQJ0aigCACIABEAgAyAHQQN0aiAAIAIgBhC/AUEBIQ4gB0EBaiIHQQpHDQEMCQsLQQEhDiAHQQpPDQcDQCAEIAdBAnRqKAIADQEgB0EBaiIHQQpHDQALDAcLQRwhDgwFCyAKIAkgDWsiCyAKIAtKGyIKIBBB/////wdzSg0DQT0hDiAPIAogEGoiCSAJIA9IGyIHIBlKDQQgAEEgIAcgCSAMEMEBIAAgFiAQEL0BIABBMCAHIAkgDEGAgARzEMEBIABBMCAKIAtBABDBASAAIA0gCxC9ASAAQSAgByAJIAxBgMAAcxDBAQwBCwsLQQAhDgwCC0E9IQ4LQaD/EyAONgIAQX8hDgsgCEHQAGokACAOCxcAIAAtAABBIHFFBEAgASACIAAQLBoLC10BA38gACgCACECA0AgAiwAACIDQTBrQQpJBEAgACACQQFqIgI2AgAgAUHMmbPmAE0Ef0F/IANBMGsiAyABQQpsIgFqIAMgAUH/////B3NKGwVBfwshAQwBCwsgAQvEAgACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQCABQQlrDhIACgsMCgsCAwQFDAsMDAoLBwgJCyACIAIoAgAiAUEEajYCACAAIAEoAgA2AgAPCwALIAIgAigCACIBQQRqNgIAIAAgATIBADcDAA8LIAIgAigCACIBQQRqNgIAIAAgATMBADcDAA8LIAIgAigCACIBQQRqNgIAIAAgATAAADcDAA8LIAIgAigCACIBQQRqNgIAIAAgATEAADcDAA8LAAsgAiACKAIAQQdqQXhxIgFBCGo2AgAgACABKwMAOQMADwsgACACIAMRAgALDwsgAiACKAIAIgFBBGo2AgAgACABNAIANwMADwsgAiACKAIAIgFBBGo2AgAgACABNQIANwMADwsgAiACKAIAQQdqQXhxIgFBCGo2AgAgACABKQMANwMAC4UBAgN/AX4CQCAAQoCAgIAQVARAIAAhBQwBCwNAIAFBAWsiASAAQgqAIgVC9gF+IAB8p0EwcjoAACAAQv////+fAVYhAiAFIQAgAg0ACwsgBaciAgRAA0AgAUEBayIBIAJBCm4iA0H2AWwgAmpBMHI6AAAgAkEJSyEEIAMhAiAEDQALCyABC3EBAX8jAEGAAmsiBSQAAkAgAiADTA0AIARBgMAEcQ0AIAUgAUH/AXEgAiADayIDQYACIANBgAJJIgEbECkaIAFFBEADQCAAIAVBgAIQvQEgA0GAAmsiA0H/AUsNAAsLIAAgBSADEL0BCyAFQYACaiQACxIAIABFBEBBAA8LIAAgARDUAQsRACAAIAEgAkHQAEHRABC7AQuzGAMSfwF8A34jAEGwBGsiDCQAIAxBADYCLAJAIAG9IhlCAFMEQEEBIRFBlDshEyABmiIBvSEZDAELIARBgBBxBEBBASERQZc7IRMMAQtBmjtBlTsgBEEBcSIRGyETIBFFIRULAkAgGUKAgICAgICA+P8Ag0KAgICAgICA+P8AUQRAIABBICACIBFBA2oiAyAEQf//e3EQwQEgACATIBEQvQEgAEGQPkHvxAAgBUEgcSIFG0HfP0GcxQAgBRsgASABYhtBAxC9ASAAQSAgAiADIARBgMAAcxDBASADIAIgAiADSBshCQwBCyAMQRBqIRICQAJ/AkAgASAMQSxqELoBIgEgAaAiAUQAAAAAAAAAAGIEQCAMIAwoAiwiBkEBazYCLCAFQSByIg5B4QBHDQEMAwsgBUEgciIOQeEARg0CIAwoAiwhCkEGIAMgA0EASBsMAQsgDCAGQR1rIgo2AiwgAUQAAAAAAACwQaIhAUEGIAMgA0EASBsLIQsgDEEwakGgAkEAIApBAE4baiINIQcDQCAHAn8gAUQAAAAAAADwQWMgAUQAAAAAAAAAAGZxBEAgAasMAQtBAAsiAzYCACAHQQRqIQcgASADuKFEAAAAAGXNzUGiIgFEAAAAAAAAAABiDQALAkAgCkEATARAIAohAyAHIQYgDSEIDAELIA0hCCAKIQMDQEEdIAMgA0EdThshAwJAIAdBBGsiBiAISQ0AIAOtIRpCACEZA0AgBiAZQv////8PgyAGNQIAIBqGfCIbQoCU69wDgCIZQoDslKMMfiAbfD4CACAGQQRrIgYgCE8NAAsgGaciBkUNACAIQQRrIgggBjYCAAsDQCAIIAciBkkEQCAGQQRrIgcoAgBFDQELCyAMIAwoAiwgA2siAzYCLCAGIQcgA0EASg0ACwsgA0EASARAIAtBGWpBCW5BAWohDyAOQeYARiEQA0BBCUEAIANrIgMgA0EJThshCQJAIAYgCE0EQCAIKAIAIQcMAQtBgJTr3AMgCXYhFEF/IAl0QX9zIRZBACEDIAghBwNAIAcgAyAHKAIAIhcgCXZqNgIAIBYgF3EgFGwhAyAHQQRqIgcgBkkNAAsgCCgCACEHIANFDQAgBiADNgIAIAZBBGohBgsgDCAMKAIsIAlqIgM2AiwgDSAIIAdFQQJ0aiIIIBAbIgcgD0ECdGogBiAGIAdrQQJ1IA9KGyEGIANBAEgNAAsLQQAhAwJAIAYgCE0NACANIAhrQQJ1QQlsIQNBCiEHIAgoAgAiCUEKSQ0AA0AgA0EBaiEDIAkgB0EKbCIHTw0ACwsgCyADQQAgDkHmAEcbayAOQecARiALQQBHcWsiByAGIA1rQQJ1QQlsQQlrSARAQQRBpAIgCkEASBsgDGogB0GAyABqIglBCW0iD0ECdGpB0B9rIQpBCiEHIA9Bd2wgCWoiCUEHTARAA0AgB0EKbCEHIAlBAWoiCUEIRw0ACwsCQCAKKAIAIhAgECAHbiIPIAdsIglGIApBBGoiFCAGRnENACAQIAlrIRACQCAPQQFxRQRARAAAAAAAAEBDIQEgB0GAlOvcA0cNASAIIApPDQEgCkEEay0AAEEBcUUNAQtEAQAAAAAAQEMhAQtEAAAAAAAA4D9EAAAAAAAA8D9EAAAAAAAA+D8gBiAURhtEAAAAAAAA+D8gECAHQQF2IhRGGyAQIBRJGyEYAkAgFQ0AIBMtAABBLUcNACAYmiEYIAGaIQELIAogCTYCACABIBigIAFhDQAgCiAHIAlqIgM2AgAgA0GAlOvcA08EQANAIApBADYCACAIIApBBGsiCksEQCAIQQRrIghBADYCAAsgCiAKKAIAQQFqIgM2AgAgA0H/k+vcA0sNAAsLIA0gCGtBAnVBCWwhA0EKIQcgCCgCACIJQQpJDQADQCADQQFqIQMgCSAHQQpsIgdPDQALCyAKQQRqIgcgBiAGIAdLGyEGCwNAIAYiByAITSIJRQRAIAdBBGsiBigCAEUNAQsLAkAgDkHnAEcEQCAEQQhxIQoMAQsgA0F/c0F/IAtBASALGyIGIANKIANBe0pxIgobIAZqIQtBf0F+IAobIAVqIQUgBEEIcSIKDQBBdyEGAkAgCQ0AIAdBBGsoAgAiDkUNAEEKIQlBACEGIA5BCnANAANAIAYiCkEBaiEGIA4gCUEKbCIJcEUNAAsgCkF/cyEGCyAHIA1rQQJ1QQlsIQkgBUFfcUHGAEYEQEEAIQogCyAGIAlqQQlrIgZBACAGQQBKGyIGIAYgC0obIQsMAQtBACEKIAsgAyAJaiAGakEJayIGQQAgBkEAShsiBiAGIAtKGyELC0F/IQkgC0H9////B0H+////ByAKIAtyIhAbSg0BIAsgEEEAR2pBAWohDgJAIAVBX3EiFUHGAEYEQCADIA5B/////wdzSg0DIANBACADQQBKGyEGDAELIBIgAyADQR91IgZzIAZrrSASEMABIgZrQQFMBEADQCAGQQFrIgZBMDoAACASIAZrQQJIDQALCyAGQQJrIg8gBToAACAGQQFrQS1BKyADQQBIGzoAACASIA9rIgYgDkH/////B3NKDQILIAYgDmoiAyARQf////8Hc0oNASAAQSAgAiADIBFqIgUgBBDBASAAIBMgERC9ASAAQTAgAiAFIARBgIAEcxDBAQJAAkACQCAVQcYARgRAIAxBEGoiBkEIciEDIAZBCXIhCiANIAggCCANSxsiCSEIA0AgCDUCACAKEMABIQYCQCAIIAlHBEAgBiAMQRBqTQ0BA0AgBkEBayIGQTA6AAAgBiAMQRBqSw0ACwwBCyAGIApHDQAgDEEwOgAYIAMhBgsgACAGIAogBmsQvQEgCEEEaiIIIA1NDQALIBAEQCAAQbvmEkEBEL0BCyAHIAhNDQEgC0EATA0BA0AgCDUCACAKEMABIgYgDEEQaksEQANAIAZBAWsiBkEwOgAAIAYgDEEQaksNAAsLIAAgBkEJIAsgC0EJThsQvQEgC0EJayEGIAhBBGoiCCAHTw0DIAtBCUohAyAGIQsgAw0ACwwCCwJAIAtBAEgNACAHIAhBBGogByAISxshCSAMQRBqIgZBCHIhAyAGQQlyIQ0gCCEHA0AgDSAHNQIAIA0QwAEiBkYEQCAMQTA6ABggAyEGCwJAIAcgCEcEQCAGIAxBEGpNDQEDQCAGQQFrIgZBMDoAACAGIAxBEGpLDQALDAELIAAgBkEBEL0BIAZBAWohBiAKIAtyRQ0AIABBu+YSQQEQvQELIAAgBiANIAZrIgYgCyAGIAtIGxC9ASALIAZrIQsgB0EEaiIHIAlPDQEgC0EATg0ACwsgAEEwIAtBEmpBEkEAEMEBIAAgDyASIA9rEL0BDAILIAshBgsgAEEwIAZBCWpBCUEAEMEBCyAAQSAgAiAFIARBgMAAcxDBASAFIAIgAiAFSBshCQwBCyATIAVBGnRBH3VBCXFqIQgCQCADQQtLDQBBDCADayEGRAAAAAAAADBAIRgDQCAYRAAAAAAAADBAoiEYIAZBAWsiBg0ACyAILQAAQS1GBEAgGCABmiAYoaCaIQEMAQsgASAYoCAYoSEBCyARQQJyIQsgBUEgcSENIBIgDCgCLCIHIAdBH3UiBnMgBmutIBIQwAEiBkYEQCAMQTA6AA8gDEEPaiEGCyAGQQJrIgogBUEPajoAACAGQQFrQS1BKyAHQQBIGzoAACAEQQhxIQYgDEEQaiEHA0AgByIFAn8gAZlEAAAAAAAA4EFjBEAgAaoMAQtBgICAgHgLIgdBsJATai0AACANcjoAACABIAe3oUQAAAAAAAAwQKIhAQJAIAVBAWoiByAMQRBqa0EBRw0AAkAgBg0AIANBAEoNACABRAAAAAAAAAAAYQ0BCyAFQS46AAEgBUECaiEHCyABRAAAAAAAAAAAYg0AC0F/IQlB/f///wcgCyASIAprIgZqIg1rIANIDQAgAEEgIAIgDSADQQJqIAcgDEEQaiIHayIFIAVBAmsgA0gbIAUgAxsiCWoiAyAEEMEBIAAgCCALEL0BIABBMCACIAMgBEGAgARzEMEBIAAgByAFEL0BIABBMCAJIAVrQQBBABDBASAAIAogBhC9ASAAQSAgAiADIARBgMAAcxDBASADIAIgAiADSBshCQsgDEGwBGokACAJCygAIAEgASgCAEEHakF4cSIBQRBqNgIAIAAgASkDACABKQMIEE05AwALEAAgACABIAJBAEEAELsBGgt8AQJ/IAAgACgCSCIBQQFrIAFyNgJIIAAoAhQgACgCHEcEQCAAQQBBACAAKAIkEQQAGgsgAEEANgIcIABCADcDECAAKAIAIgFBBHEEQCAAIAFBIHI2AgBBfw8LIAAgACgCLCAAKAIwaiICNgIIIAAgAjYCBCABQRt0QR91C0EBAn8jAEEQayIBJABBfyECAkAgABDHAQ0AIAAgAUEPakEBIAAoAiARBABBAUcNACABLQAPIQILIAFBEGokACACC0cBAn8gACABNwNwIAAgACgCLCAAKAIEIgNrrDcDeCAAKAIIIQICQCABUA0AIAIgA2usIAFXDQAgAyABp2ohAgsgACACNgJoC9QBAgN/An4CQCAAKQNwIgRCAFIgBCAAKQN4IAAoAgQiASAAKAIsIgJrrHwiBVdxRQRAIAAQyAEiA0EATg0BIAAoAiwhAiAAKAIEIQELIABCfzcDcCAAIAE2AmggACAFIAIgAWusfDcDeEF/DwsgBUIBfCEFIAAoAgQhASAAKAIIIQICQCAAKQNwIgRQDQAgBCAFfSIEIAIgAWusWQ0AIAEgBKdqIQILIAAgAjYCaCAAIAUgACgCLCIAIAFrrHw3A3ggACABTwRAIAFBAWsgAzoAAAsgAwu/AgEEfyADQfCZFCADGyIFKAIAIQMCQAJ/AkAgAUUEQCADDQFBAA8LQX4gAkUNARoCQCADBEAgAiEEDAELIAEtAAAiA8AiBEEATgRAIAAEQCAAIAM2AgALIARBAEcPC0HMmRQoAgAoAgBFBEBBASAARQ0DGiAAIARB/78DcTYCAEEBDwsgA0HCAWsiA0EySw0BIANBAnRBwLcTaigCACEDIAJBAWsiBEUNAyABQQFqIQELIAEtAAAiBkEDdiIHQRBrIANBGnUgB2pyQQdLDQADQCAEQQFrIQQgBkGAAWsgA0EGdHIiA0EATgRAIAVBADYCACAABEAgACADNgIACyACIARrDwsgBEUNAyABQQFqIgEtAAAiBkHAAXFBgAFGDQALCyAFQQA2AgBBoP8TQRk2AgBBfwsPCyAFIAM2AgBBfgs1ACAAIAE3AwAgACACQv///////z+DIARCMIinQYCAAnEgAkIwiKdB//8BcXKtQjCGhDcDCAu/AgEBfyMAQdAAayIEJAACQCADQYCAAU4EQCAEQSBqIAEgAkIAQoCAgICAgID//wAQPCAEKQMoIQIgBCkDICEBIANB//8BSQRAIANB//8AayEDDAILIARBEGogASACQgBCgICAgICAgP//ABA8Qf3/AiADIANB/f8CThtB/v8BayEDIAQpAxghAiAEKQMQIQEMAQsgA0GBgH9KDQAgBEFAayABIAJCAEKAgICAgICAORA8IAQpA0ghAiAEKQNAIQEgA0H0gH5LBEAgA0GN/wBqIQMMAQsgBEEwaiABIAJCAEKAgICAgICAORA8QeiBfSADIANB6IF9TBtBmv4BaiEDIAQpAzghAiAEKQMwIQELIAQgASACQgAgA0H//wBqrUIwhhA8IAAgBCkDCDcDCCAAIAQpAwA3AwAgBEHQAGokAAvUMgMPfwd+AXwjAEEwayIMJAACQCACQQJNBEAgAkECdCICQYyTE2ooAgAhDyACQYCTE2ooAgAhDgNAAn8gASgCBCICIAEoAmhHBEAgASACQQFqNgIEIAItAAAMAQsgARDKAQsiAkEgRiACQQlrQQVJcg0AC0EBIQoCQAJAIAJBK2sOAwABAAELQX9BASACQS1GGyEKIAEoAgQiAiABKAJoRwRAIAEgAkEBajYCBCACLQAAIQIMAQsgARDKASECCwJAAkADQCAFQeA5aiwAACACQSByRgRAAkAgBUEGSw0AIAEoAgQiAiABKAJoRwRAIAEgAkEBajYCBCACLQAAIQIMAQsgARDKASECCyAFQQFqIgVBCEcNAQwCCwsgBUEDRwRAIAVBCEYNASADRQ0CIAVBBEkNAiAFQQhGDQELIAEpA3AiE0IAWQRAIAEgASgCBEEBazYCBAsgA0UNACAFQQRJDQAgE0IAUyECA0AgAkUEQCABIAEoAgRBAWs2AgQLIAVBAWsiBUEDSw0ACwtCACETIwBBEGsiAiQAAn4gCrJDAACAf5S8IgNB/////wdxIgFBgICABGtB////9wdNBEAgAa1CGYZCgICAgICAgMA/fAwBCyADrUIZhkKAgICAgIDA//8AhCABQYCAgPwHTw0AGkIAIAFFDQAaIAIgAa1CACABZyIBQdEAahA5IAIpAwAhEyACKQMIQoCAgICAgMAAhUGJ/wAgAWutQjCGhAshFCAMIBM3AwAgDCAUIANBgICAgHhxrUIghoQ3AwggAkEQaiQAIAwpAwghEyAMKQMAIRQMAgsCQAJAAkAgBQ0AQQAhBQNAIAVBkD5qLAAAIAJBIHJHDQECQCAFQQFLDQAgASgCBCICIAEoAmhHBEAgASACQQFqNgIEIAItAAAhAgwBCyABEMoBIQILIAVBAWoiBUEDRw0ACwwBCwJAAkAgBQ4EAAEBAgELAkAgAkEwRw0AAn8gASgCBCIFIAEoAmhHBEAgASAFQQFqNgIEIAUtAAAMAQsgARDKAQtBX3FB2ABGBEAjAEGwA2siAiQAAn8gASgCBCIFIAEoAmhHBEAgASAFQQFqNgIEIAUtAAAMAQsgARDKAQshBQJAAn8DQCAFQTBHBEACQCAFQS5HDQQgASgCBCIFIAEoAmhGDQAgASAFQQFqNgIEIAUtAAAMAwsFIAEoAgQiBSABKAJoRwR/QQEhCSABIAVBAWo2AgQgBS0AAAVBASEJIAEQygELIQUMAQsLIAEQygELIQVBASEIIAVBMEcNAANAIBZCAX0hFgJ/IAEoAgQiBSABKAJoRwRAIAEgBUEBajYCBCAFLQAADAELIAEQygELIgVBMEYNAAtBASEJC0KAgICAgIDA/z8hFAJAA0ACQCAFQSByIQQCQAJAIAVBMGsiB0EKSQ0AIAVBLkcgBEHhAGtBBUtxDQQgBUEuRw0AIAgNAkEBIQggEyEWDAELIARB1wBrIAcgBUE5ShshBQJAIBNCB1cEQCAFIAZBBHRqIQYMAQsgE0IcWARAIAJBMGogBRBOIAJBIGogGCAUQgBCgICAgICAwP0/EDwgAkEQaiACKQMwIAIpAzggAikDICIYIAIpAygiFBA8IAIgAikDECACKQMYIBUgFxBHIAIpAwghFyACKQMAIRUMAQsgBUUNACALDQAgAkHQAGogGCAUQgBCgICAgICAgP8/EDwgAkFAayACKQNQIAIpA1ggFSAXEEcgAikDSCEXQQEhCyACKQNAIRULIBNCAXwhE0EBIQkLIAEoAgQiBSABKAJoRwR/IAEgBUEBajYCBCAFLQAABSABEMoBCyEFDAELC0EuIQULAn4gCUUEQAJAAkAgASkDcEIAWQRAIAEgASgCBCIGQQFrNgIEIANFDQEgASAGQQJrNgIEIAhFDQIgASAGQQNrNgIEDAILIAMNAQsgAUIAEMkBCyACQeAAaiAKt0QAAAAAAAAAAKIQTyACKQNgIRUgAikDaAwBCyATQgdXBEAgEyEUA0AgBkEEdCEGIBRCAXwiFEIIUg0ACwsCQAJAAkAgBUFfcUHQAEYEQCABIAMQzwEiFEKAgICAgICAgIB/Ug0DIAMEQCABKQNwQgBZDQIMAwtCACEVIAFCABDJAUIADAQLQgAhFCABKQNwQgBTDQILIAEgASgCBEEBazYCBAtCACEUCyAGRQRAIAJB8ABqIAq3RAAAAAAAAAAAohBPIAIpA3AhFSACKQN4DAELIBYgEyAIG0IChiAUfEIgfSITQQAgD2utVQRAQaD/E0HEADYCACACQaABaiAKEE4gAkGQAWogAikDoAEgAikDqAFCf0L///////+///8AEDwgAkGAAWogAikDkAEgAikDmAFCf0L///////+///8AEDwgAikDgAEhFSACKQOIAQwBCyAPQeIBa6wgE1cEQCAGQQBOBEADQCACQaADaiAVIBdCAEKAgICAgIDA/79/EEcgFSAXQoCAgICAgID/PxA4IQEgAkGQA2ogFSAXIAIpA6ADIBUgAUEATiIBGyACKQOoAyAXIAEbEEcgE0IBfSETIAIpA5gDIRcgAikDkAMhFSAGQQF0IAFyIgZBAE4NAAsLAn4gEyAPrH1CIHwiFKciAUEAIAFBAEobIA4gFCAOrVMbIgFB8QBOBEAgAkGAA2ogChBOIAIpA4gDIRYgAikDgAMhGEIADAELIAJB4AJqRAAAAAAAAPA/QZABIAFrEDAQTyACQdACaiAKEE4gAkHwAmogAikD4AIgAikD6AIgAikD0AIiGCACKQPYAiIWEMwBIAIpA/gCIRkgAikD8AILIRQgAkHAAmogBiAGQQFxRSAVIBdCAEIAEDdBAEcgAUEgSHFxIgFqEFAgAkGwAmogGCAWIAIpA8ACIAIpA8gCEDwgAkGQAmogAikDsAIgAikDuAIgFCAZEEcgAkGgAmogGCAWQgAgFSABG0IAIBcgARsQPCACQYACaiACKQOgAiACKQOoAiACKQOQAiACKQOYAhBHIAJB8AFqIAIpA4ACIAIpA4gCIBQgGRBIIAIpA/ABIhQgAikD+AEiFkIAQgAQN0UEQEGg/xNBxAA2AgALIAJB4AFqIBQgFiATpxDNASACKQPgASEVIAIpA+gBDAELQaD/E0HEADYCACACQdABaiAKEE4gAkHAAWogAikD0AEgAikD2AFCAEKAgICAgIDAABA8IAJBsAFqIAIpA8ABIAIpA8gBQgBCgICAgICAwAAQPCACKQOwASEVIAIpA7gBCyETIAwgFTcDECAMIBM3AxggAkGwA2okACAMKQMYIRMgDCkDECEUDAYLIAEpA3BCAFMNACABIAEoAgRBAWs2AgQLIAEhBSACIQYgAyEJQQAhAyMAQZDGAGsiBCQAQQAgD2siECAOayESAkACfwNAAkAgBkEwRwRAIAZBLkcNBCAFKAIEIgEgBSgCaEYNASAFIAFBAWo2AgQgAS0AAAwDCyAFKAIEIgEgBSgCaEcEQCAFIAFBAWo2AgQgAS0AACEGBSAFEMoBIQYLQQEhAwwBCwsgBRDKAQshBkEBIQ0gBkEwRw0AA0AgE0IBfSETAn8gBSgCBCIBIAUoAmhHBEAgBSABQQFqNgIEIAEtAAAMAQsgBRDKAQsiBkEwRg0AC0EBIQMLIARBADYCkAYgBkEwayECIAwCfgJAAkACQAJAAkACQCAGQS5GIgENACACQQlNDQAMAQsDQAJAIAFBAXEEQCANRQRAIBQhE0EBIQ0MAgsgA0UhAQwECyAUQgF8IRQgCEH8D0wEQCALIBSnIAZBMEYbIQsgBEGQBmogCEECdGoiASAHBH8gBiABKAIAQQpsakEwawUgAgs2AgBBASEDQQAgB0EBaiIBIAFBCUYiARshByABIAhqIQgMAQsgBkEwRg0AIAQgBCgCgEZBAXI2AoBGQdyPASELCwJ/IAUoAgQiASAFKAJoRwRAIAUgAUEBajYCBCABLQAADAELIAUQygELIgZBMGshAiAGQS5GIgENACACQQpJDQALCyATIBQgDRshEwJAIANFDQAgBkFfcUHFAEcNAAJAIAUgCRDPASIVQoCAgICAgICAgH9SDQAgCUUNBEIAIRUgBSkDcEIAUw0AIAUgBSgCBEEBazYCBAsgEyAVfCETDAQLIANFIQEgBkEASA0BCyAFKQNwQgBTDQAgBSAFKAIEQQFrNgIECyABRQ0BQaD/E0EcNgIAC0IAIRQgBUIAEMkBQgAMAQsgBCgCkAYiAUUEQCAEIAq3RAAAAAAAAAAAohBPIAQpAwAhFCAEKQMIDAELAkAgFEIJVQ0AIBMgFFINACAOQR5MQQAgASAOdhsNACAEQTBqIAoQTiAEQSBqIAEQUCAEQRBqIAQpAzAgBCkDOCAEKQMgIAQpAygQPCAEKQMQIRQgBCkDGAwBCyAQQQF2rSATUwRAQaD/E0HEADYCACAEQeAAaiAKEE4gBEHQAGogBCkDYCAEKQNoQn9C////////v///ABA8IARBQGsgBCkDUCAEKQNYQn9C////////v///ABA8IAQpA0AhFCAEKQNIDAELIA9B4gFrrCATVQRAQaD/E0HEADYCACAEQZABaiAKEE4gBEGAAWogBCkDkAEgBCkDmAFCAEKAgICAgIDAABA8IARB8ABqIAQpA4ABIAQpA4gBQgBCgICAgICAwAAQPCAEKQNwIRQgBCkDeAwBCyAHBEAgB0EITARAIARBkAZqIAhBAnRqIgEoAgAhBQNAIAVBCmwhBSAHQQFqIgdBCUcNAAsgASAFNgIACyAIQQFqIQgLIBOnIQcCQCALQQlODQAgByALSA0AIAdBEUoNACAHQQlGBEAgBEHAAWogChBOIARBsAFqIAQoApAGEFAgBEGgAWogBCkDwAEgBCkDyAEgBCkDsAEgBCkDuAEQPCAEKQOgASEUIAQpA6gBDAILIAdBCEwEQCAEQZACaiAKEE4gBEGAAmogBCgCkAYQUCAEQfABaiAEKQOQAiAEKQOYAiAEKQOAAiAEKQOIAhA8IARB4AFqQQAgB2tBAnRBgJMTaigCABBOIARB0AFqIAQpA/ABIAQpA/gBIAQpA+ABIAQpA+gBEDogBCkD0AEhFCAEKQPYAQwCCyAOIAdBfWxqQRtqIgFBHkxBACAEKAKQBiICIAF2Gw0AIARB4AJqIAoQTiAEQdACaiACEFAgBEHAAmogBCkD4AIgBCkD6AIgBCkD0AIgBCkD2AIQPCAEQbACaiAHQQJ0QbiSE2ooAgAQTiAEQaACaiAEKQPAAiAEKQPIAiAEKQOwAiAEKQO4AhA8IAQpA6ACIRQgBCkDqAIMAQsDQCAEQZAGaiAIIgFBAWsiCEECdGooAgBFDQALQQAhCwJAIAdBCW8iA0UEQEEAIQIMAQtBACECIANBCWogAyAHQQBIGyEDAkAgAUUEQEEAIQEMAQtBgJTr3ANBACADa0ECdEGAkxNqKAIAIghtIQlBACEGQQAhBQNAIARBkAZqIAVBAnRqIg0gBiANKAIAIg0gCG4iEGoiBjYCACACQQFqQf8PcSACIAZFIAIgBUZxIgYbIQIgB0EJayAHIAYbIQcgCSANIAggEGxrbCEGIAVBAWoiBSABRw0ACyAGRQ0AIARBkAZqIAFBAnRqIAY2AgAgAUEBaiEBCyAHIANrQQlqIQcLA0AgBEGQBmogAkECdGohDQJAA0ACQCAHQSRIDQAgB0EkRw0CIA0oAgBB0On5BE0NAEEkIQcMAgsgAUH/D2ohCEEAIQMDQCABIQYgA60gBEGQBmogCEH/D3EiCUECdGoiATUCAEIdhnwiE0KBlOvcA1QEf0EABSATQoCU69wDgCIUQoDslKN8fiATfCETIBSnCyEDIAEgE6ciATYCACAGIAYgBiAJIAEbIAIgCUYbIAkgBkEBa0H/D3EiBUcbIQEgCUEBayEIIAIgCUcNAAsgC0EdayELIAYhASADRQ0ACyACQQFrQf8PcSICIAFGBEAgBEGQBmoiBiABQf4PakH/D3FBAnRqIgEgASgCACAFQQJ0IAZqKAIAcjYCACAFIQELIAdBCWohByAEQZAGaiACQQJ0aiADNgIADAELCwJAA0AgAUEBakH/D3EhBiAEQZAGaiABQQFrQf8PcUECdGohCQNAQQlBASAHQS1KGyEIAkADQCACIQNBACEFAkADQAJAIAMgBWpB/w9xIgIgAUYNACAEQZAGaiACQQJ0aigCACICIAVBAnRB0JITaigCACINSQ0AIAIgDUsNAiAFQQFqIgVBBEcNAQsLIAdBJEcNAEEAIQVCACETQgAhFANAIAEgAyAFakH/D3EiAkYEQCABQQFqQf8PcSIBQQJ0IARqQQA2AowGCyAEQYAGaiAEQZAGaiACQQJ0aigCABBQIARB8AVqIBMgFEIAQoCAgIDlmreOwAAQPCAEQeAFaiAEKQPwBSAEKQP4BSAEKQOABiAEKQOIBhBHIAQpA+gFIRQgBCkD4AUhEyAFQQFqIgVBBEcNAAsgBEHQBWogChBOIARBwAVqIBMgFCAEKQPQBSAEKQPYBRA8IAQpA8gFIRRCACETIAQpA8AFIRUgC0HxAGoiCCAPayIGQQAgBkEAShsgDiAGIA5IIgkbIgJB8ABMDQIMBQsgCCALaiELIAEhAiABIANGDQALQYCU69wDIAh2IQ1BfyAIdEF/cyEQQQAhBSADIQIDQCAEQZAGaiADQQJ0aiIRIAUgESgCACIRIAh2aiIFNgIAIAJBAWpB/w9xIAIgBUUgAiADRnEiBRshAiAHQQlrIAcgBRshByAQIBFxIA1sIQUgA0EBakH/D3EiAyABRw0ACyAFRQ0BIAIgBkcEQCAEQZAGaiABQQJ0aiAFNgIAIAYhAQwDCyAJIAkoAgBBAXI2AgAMAQsLCyAEQZAFakQAAAAAAADwP0HhASACaxAwEE8gBEGwBWogBCkDkAUgBCkDmAUgFSAUEMwBIAQpA7gFIRggBCkDsAUhFyAEQYAFakQAAAAAAADwP0HxACACaxAwEE8gBEGgBWogFSAUIAQpA4AFIAQpA4gFEDEgBEHwBGogFSAUIAQpA6AFIhMgBCkDqAUiFhBIIARB4ARqIBcgGCAEKQPwBCAEKQP4BBBHIAQpA+gEIRQgBCkD4AQhFQsCQCADQQRqQf8PcSIFIAFGDQACQCAEQZAGaiAFQQJ0aigCACIFQf/Jte4BTQRAIAVFIANBBWpB/w9xIAFGcQ0BIARB8ANqIAq3RAAAAAAAANA/ohBPIARB4ANqIBMgFiAEKQPwAyAEKQP4AxBHIAQpA+gDIRYgBCkD4AMhEwwBCyAFQYDKte4BRwRAIARB0ARqIAq3RAAAAAAAAOg/ohBPIARBwARqIBMgFiAEKQPQBCAEKQPYBBBHIAQpA8gEIRYgBCkDwAQhEwwBCyAKtyEaIAEgA0EFakH/D3FGBEAgBEGQBGogGkQAAAAAAADgP6IQTyAEQYAEaiATIBYgBCkDkAQgBCkDmAQQRyAEKQOIBCEWIAQpA4AEIRMMAQsgBEGwBGogGkQAAAAAAADoP6IQTyAEQaAEaiATIBYgBCkDsAQgBCkDuAQQRyAEKQOoBCEWIAQpA6AEIRMLIAJB7wBKDQAgBEHQA2ogEyAWQgBCgICAgICAwP8/EDEgBCkD0AMgBCkD2ANCAEIAEDcNACAEQcADaiATIBZCAEKAgICAgIDA/z8QRyAEKQPIAyEWIAQpA8ADIRMLIARBsANqIBUgFCATIBYQRyAEQaADaiAEKQOwAyAEKQO4AyAXIBgQSCAEKQOoAyEUIAQpA6ADIRUCQCASQQJrIAhB/////wdxTg0AIAQgFEL///////////8AgzcDmAMgBCAVNwOQAyAEQYADaiAVIBRCAEKAgICAgICA/z8QPCAEKQOQAyAEKQOYA0KAgICAgICAuMAAEDghASAEKQOIAyAUIAFBAE4iAxshFCAEKQOAAyAVIAMbIRUgEyAWQgBCABA3IQUgEiADIAtqIgtB7gBqTgRAIAkgAiAGRyABQQBIcnEgBUEAR3FFDQELQaD/E0HEADYCAAsgBEHwAmogFSAUIAsQzQEgBCkD8AIhFCAEKQP4Ags3AyggDCAUNwMgIARBkMYAaiQAIAwpAyghEyAMKQMgIRQMBAsgASkDcEIAWQRAIAEgASgCBEEBazYCBAsMAQsCQAJ/IAEoAgQiAiABKAJoRwRAIAEgAkEBajYCBCACLQAADAELIAEQygELQShGBEBBASEFDAELQoCAgICAgOD//wAhEyABKQNwQgBTDQMgASABKAIEQQFrNgIEDAMLA0ACfyABKAIEIgIgASgCaEcEQCABIAJBAWo2AgQgAi0AAAwBCyABEMoBCyICQcEAayEGAkACQCACQTBrQQpJDQAgBkEaSQ0AIAJB3wBGDQAgAkHhAGtBGk8NAQsgBUEBaiEFDAELC0KAgICAgIDg//8AIRMgAkEpRg0CIAEpA3AiFkIAWQRAIAEgASgCBEEBazYCBAsCQCADBEAgBQ0BDAQLDAELA0AgFkIAWQRAIAEgASgCBEEBazYCBAsgBUEBayIFDQALDAILQaD/E0EcNgIAIAFCABDJAQtCACETCyAAIBQ3AwAgACATNwMIIAxBMGokAAuGBAIEfwF+AkACQAJAAkACQAJAAkACfyAAKAIEIgIgACgCaEcEQCAAIAJBAWo2AgQgAi0AAAwBCyAAEMoBCyICQStrDgMAAQABCyACQS1GIQUCfyAAKAIEIgMgACgCaEcEQCAAIANBAWo2AgQgAy0AAAwBCyAAEMoBCyIDQTprIQQgAUUNASAEQXVLDQEgACkDcEIAWQ0CDAULIAJBOmshBCACIQMLIARBdkkNASADQTBrIgRBCkkEQEEAIQIDQCADIAJBCmxqIQECfyAAKAIEIgIgACgCaEcEQCAAIAJBAWo2AgQgAi0AAAwBCyAAEMoBCyIDQTBrIgRBCU0gAUEwayICQcyZs+YASHENAAsgAqwhBgsCQCAEQQpPDQADQCADrSAGQgp+fEIwfSEGAn8gACgCBCIBIAAoAmhHBEAgACABQQFqNgIEIAEtAAAMAQsgABDKAQsiA0EwayIEQQlLDQEgBkKuj4XXx8LrowFTDQALCyAEQQpJBEADQAJ/IAAoAgQiASAAKAJoRwRAIAAgAUEBajYCBCABLQAADAELIAAQygELQTBrQQpJDQALCyAAKQNwQgBZBEAgACAAKAIEQQFrNgIEC0IAIAZ9IAYgBRsPCyAAIAAoAgRBAWs2AgQMAQsgACkDcEIAUw0BCyAAIAAoAgRBAWs2AgQLQoCAgICAgICAgH8LQwACQCAARQ0AAkACQAJAAkAgAUECag4GAAECAgQDBAsgACACPAAADwsgACACPQEADwsgACACPgIADwsgACACNwMACwu1AQICfwF+IwBBoAFrIgQkACAEIAAgBEGeAWogARsiBTYClAEgBCABQQFrIgBBACAAIAFNGzYCmAEDQCAEIAanakEAOgAAIAZCAXwiBkKQAVQNAAtBfyEAIARBfzYCTCAEQdIANgIkIARBfzYCUCAEIARBnwFqNgIsIAQgBEGUAWo2AlQCQCABQQBIBEBBoP8TQT02AgAMAQsgBUEAOgAAIAQgAiADEMMBIQALIARBoAFqJAAgAAuoAQEFfyAAKAJUIgMoAgAhBSADKAIEIgQgACgCFCAAKAIcIgdrIgYgBCAGSRsiBgRAIAUgByAGECsaIAMgAygCACAGaiIFNgIAIAMgAygCBCAGayIENgIECyAEIAIgAiAESxsiBARAIAUgASAEECsaIAMgAygCACAEaiIFNgIAIAMgAygCBCAEazYCBAsgBUEAOgAAIAAgACgCLCIBNgIcIAAgATYCFCACC1QBAn8gASAAKAJUIgEgAUEAIAJBgAJqIgMQhwEiBCABayADIAQbIgMgAiACIANLGyICECsaIAAgASADaiIDNgJUIAAgAzYCCCAAIAEgAmo2AgQgAguJAgACQCAABH8gAUH/AE0NAQJAQcyZFCgCACgCAEUEQCABQYB/cUGAvwNGDQMMAQsgAUH/D00EQCAAIAFBP3FBgAFyOgABIAAgAUEGdkHAAXI6AABBAg8LIAFBgEBxQYDAA0cgAUGAsANPcUUEQCAAIAFBP3FBgAFyOgACIAAgAUEMdkHgAXI6AAAgACABQQZ2QT9xQYABcjoAAUEDDwsgAUGAgARrQf//P00EQCAAIAFBP3FBgAFyOgADIAAgAUESdkHwAXI6AAAgACABQQZ2QT9xQYABcjoAAiAAIAFBDHZBP3FBgAFyOgABQQQPCwtBoP8TQRk2AgBBfwVBAQsPCyAAIAE6AABBAQsFABAdAAswAQF/IwBBEGsiAiQAIAIgAULAhD1+NwMIIAIpAwghASACQRBqJAAgACABNwMAIAALBwAgABDYAQuMAQECfyAAQfyZEzYCACAAKAIoIQEDQCABBEBBACAAIAFBAWsiAUECdCICIAAoAiRqKAIAIAAoAiAgAmooAgARCAAMAQsLIAAoAhwiASABKAIEQQFrIgI2AgQgAkF/RgRAIAEgASgCACgCCBEBAAsgACgCIBA0IAAoAiQQNCAAKAIwEDQgACgCPBA0IAALCQAgABDYARA0CzgBAn8gAEGwlBM2AgAgACgCBCIBIAEoAgRBAWsiAjYCBCACQX9GBEAgASABKAIAKAIIEQEACyAACwkAIAAQ2gEQNAsDAAELBAAgAAsQACAAQn83AwggAEIANwMACxAAIABCfzcDCCAAQgA3AwAL2AEBBH8jAEEQayIEJAADQAJAIAIgBUwNAAJ/IAAoAgwiAyAAKAIQIgZJBEAgBEH/////BzYCDCAEIAYgA2s2AgggBCACIAVrNgIEIAEgAyAEQQRqIgEgBEEIaiIDIAEoAgAgAygCAEgbIgEgBEEMaiIDIAEoAgAgAygCAEgbKAIAIgMQ4QEhASAAIAAoAgwgA2o2AgwgASADagwBCyAAIAAoAgAoAigRAAAiA0F/Rg0BIAEgA8A6AABBASEDIAFBAWoLIQEgAyAFaiEFDAELCyAEQRBqJAAgBQsRACABIAEgAmogABDmARogAAsEAEF/CywAIAAgACgCACgCJBEAAEF/RwR/IAAgACgCDCIAQQFqNgIMIAAtAAAFQX8LCwQAQX8LsQEBBH8jAEEQayIFJAADQAJAIAIgBEwNACAAKAIYIgMgACgCHCIGTwR/IAAgAS0AACAAKAIAKAI0EQMAQX9GDQEgBEEBaiEEIAFBAWoFIAUgBiADazYCDCAFIAIgBGs2AgggAyABIAVBCGoiAyAFQQxqIgYgAygCACAGKAIASBsoAgAiAxDhARogACADIAAoAhhqNgIYIAMgBGohBCABIANqCyEBDAELCyAFQRBqJAAgBAsrAQF/IwBBEGsiAyQAIANBCGogACABIAIQ5wEgAygCDCEAIANBEGokACAAC3IBAn8jAEEgayIEJAAjAEEQayIFJAAgBSACNgIMIAQgATYCGCAEIAUoAgw2AhwgBUEQaiQAIARBEGogBCgCGCAEKAIcIAMQ6AEgBCgCECEBIAQgBCgCFDYCDCAAIAE2AgAgACAEKAIMNgIEIARBIGokAAs6AQF/IwBBEGsiBCQAIAQgAyABIAIgAWsiARBLIAFqNgIMIAAgAjYCACAAIAQoAgw2AgQgBEEQaiQACwQAIAELKgAgAEGwlBM2AgAgAEEEahDrASAAQgA3AhggAEIANwIQIABCADcCCCAAC4wSAQJ/IAACf0G0pBQtAAAEQEGwpBQoAgAMAQtBrKQUAn9BqKQULQAABEBBpKQUKAIADAELQYyxFEEANgIAQYixFEHA8hM2AgBBiLEUQdDGEzYCAEGIsRRBiLsTNgIAIwBBEGsiASQAQZCxFEIANwMAQZixFEEANgIAQZiyFEEAOgAAIAFBkLEUNgIMIwBBEGsiACQAENkDQR1NBEAQVwALIABBCGpBoLEUQR4Q2gNBlLEUIAAoAggiAjYCAEGQsRQgAjYCAEGYsRQgAiAAKAIMQQJ0ajYCACAAQRBqJABBkLEUQR4Q1QMgAUEQaiQAQaCyFEHpxQAQU0GQsRQQ1gNBxK4UQQA2AgBBwK4UQcDyEzYCAEHArhRB0MYTNgIAQcCuFEGkzxM2AgBBiLEUQcCuFEH4ohQQwAIQ1wNBzK4UQQA2AgBByK4UQcDyEzYCAEHIrhRB0MYTNgIAQciuFEHEzxM2AgBBiLEUQciuFEGAoxQQwAIQ1wNB1K4UQQA2AgBB0K4UQcDyEzYCAEHQrhRB0MYTNgIAQdyuFEEAOgAAQdiuFEEANgIAQdCuFEGcuxM2AgBB2K4UQdC7EzYCAEGIsRRB0K4UQcSkFBDAAhDXA0HkrhRBADYCAEHgrhRBwPITNgIAQeCuFEHQxhM2AgBB4K4UQYjHEzYCAEGIsRRB4K4UQbykFBDAAhDXA0HsrhRBADYCAEHorhRBwPITNgIAQeiuFEHQxhM2AgBB6K4UQZzIEzYCAEGIsRRB6K4UQcykFBDAAhDXA0H0rhRBADYCAEHwrhRBwPITNgIAQfCuFEHQxhM2AgBB8K4UQdjDEzYCAEH4rhQQyQI2AgBBiLEUQfCuFEHUpBQQwAIQ1wNBhK8UQQA2AgBBgK8UQcDyEzYCAEGArxRB0MYTNgIAQYCvFEGwyRM2AgBBiLEUQYCvFEHcpBQQwAIQ1wNBjK8UQQA2AgBBiK8UQcDyEzYCAEGIrxRB0MYTNgIAQYivFEGYyxM2AgBBiLEUQYivFEHspBQQwAIQ1wNBlK8UQQA2AgBBkK8UQcDyEzYCAEGQrxRB0MYTNgIAQZCvFEGkyhM2AgBBiLEUQZCvFEHkpBQQwAIQ1wNBnK8UQQA2AgBBmK8UQcDyEzYCAEGYrxRB0MYTNgIAQZivFEGMzBM2AgBBiLEUQZivFEH0pBQQwAIQ1wNBpK8UQQA2AgBBoK8UQcDyEzYCAEGgrxRB0MYTNgIAQaivFEGu2AA7AQBBoK8UQYjEEzYCAEGsrxRCADcCAEG0rxRBADYCAEGIsRRBoK8UQfykFBDAAhDXA0G8rxRBADYCAEG4rxRBwPITNgIAQbivFEHQxhM2AgBBwK8UQq6AgIDABTcCAEG4rxRBsMQTNgIAQcivFEIANwIAQdCvFEEANgIAQYixFEG4rxRBhKUUEMACENcDQdyvFEEANgIAQdivFEHA8hM2AgBB2K8UQdDGEzYCAEHYrxRB5M8TNgIAQYixFEHYrxRBiKMUEMACENcDQeSvFEEANgIAQeCvFEHA8hM2AgBB4K8UQdDGEzYCAEHgrxRB2NETNgIAQYixFEHgrxRBkKMUEMACENcDQeyvFEEANgIAQeivFEHA8hM2AgBB6K8UQdDGEzYCAEHorxRBrNMTNgIAQYixFEHorxRBmKMUEMACENcDQfSvFEEANgIAQfCvFEHA8hM2AgBB8K8UQdDGEzYCAEHwrxRBlNUTNgIAQYixFEHwrxRBoKMUEMACENcDQfyvFEEANgIAQfivFEHA8hM2AgBB+K8UQdDGEzYCAEH4rxRB7NwTNgIAQYixFEH4rxRByKMUEMACENcDQYSwFEEANgIAQYCwFEHA8hM2AgBBgLAUQdDGEzYCAEGAsBRBgN4TNgIAQYixFEGAsBRB0KMUEMACENcDQYywFEEANgIAQYiwFEHA8hM2AgBBiLAUQdDGEzYCAEGIsBRB9N4TNgIAQYixFEGIsBRB2KMUEMACENcDQZSwFEEANgIAQZCwFEHA8hM2AgBBkLAUQdDGEzYCAEGQsBRB6N8TNgIAQYixFEGQsBRB4KMUEMACENcDQZywFEEANgIAQZiwFEHA8hM2AgBBmLAUQdDGEzYCAEGYsBRB3OATNgIAQYixFEGYsBRB6KMUEMACENcDQaSwFEEANgIAQaCwFEHA8hM2AgBBoLAUQdDGEzYCAEGgsBRBgOITNgIAQYixFEGgsBRB8KMUEMACENcDQaywFEEANgIAQaiwFEHA8hM2AgBBqLAUQdDGEzYCAEGosBRBpOMTNgIAQYixFEGosBRB+KMUEMACENcDQbSwFEEANgIAQbCwFEHA8hM2AgBBsLAUQdDGEzYCAEGwsBRByOQTNgIAQYixFEGwsBRBgKQUEMACENcDQbywFEEANgIAQbiwFEHA8hM2AgBBuLAUQdDGEzYCAEHAsBRBsO4TNgIAQcCwFEGM1xM2AgBBuLAUQdzWEzYCAEGIsRRBuLAUQaijFBDAAhDXA0HMsBRBADYCAEHIsBRBwPITNgIAQciwFEHQxhM2AgBB0LAUQdTuEzYCAEHQsBRBlNkTNgIAQciwFEHk2BM2AgBBiLEUQciwFEGwoxQQwAIQ1wNB3LAUQQA2AgBB2LAUQcDyEzYCAEHYsBRB0MYTNgIAQeCwFBDdA0HYsBRB0NoTNgIAQYixFEHYsBRBuKMUEMACENcDQeywFEEANgIAQeiwFEHA8hM2AgBB6LAUQdDGEzYCAEHwsBQQ3QNB6LAUQezbEzYCAEGIsRRB6LAUQcCjFBDAAhDXA0H8sBRBADYCAEH4sBRBwPITNgIAQfiwFEHQxhM2AgBB+LAUQezlEzYCAEGIsRRB+LAUQYikFBDAAhDXA0GEsRRBADYCAEGAsRRBwPITNgIAQYCxFEHQxhM2AgBBgLEUQeTmEzYCAEGIsRRBgLEUQZCkFBDAAhDXA0GgpBRBiLEUNgIAQaikFEEBOgAAQaSkFEGgpBQ2AgBBoKQUCygCACIANgIAIAAgACgCBEEBajYCBEG0pBRBAToAAEGwpBRBrKQUNgIAQaykFAsoAgAiADYCACAAIAAoAgRBAWo2AgQLDQAgAEEIahDYARogAAsJACAAEOwBEDQLEwAgACAAKAIAQQxrKAIAahDsAQsTACAAIAAoAgBBDGsoAgBqEO0BC6wBAQN/IwBBEGsiAyQAIAAgACgCAEEMaygCAGooAhgEQCADQQhqIgIgADYCBCACQQA6AAAgACAAKAIAQQxrKAIAaiIBKAIQRQRAIAEoAkgiAQRAIAEQ8AELIAJBAToAAAsCQCACLQAARQ0AIAAgACgCAEEMaygCAGooAhgiASABKAIAKAIYEQAAQX9HDQAgACAAKAIAQQxrKAIAahDyAQsgAhDxAQsgA0EQaiQAC14BAn8CQCAAKAIEIgEgASgCAEEMaygCAGoiASgCGCICRQ0AIAEoAhANACABLQAFQSBxRQ0AIAIgAigCACgCGBEAAEF/Rw0AIAAoAgQiACAAKAIAQQxrKAIAahDyAQsLKQEBfyAAIAAoAhhFIAAoAhBBAXJyIgE2AhAgACgCFCABcQRAENUBAAsLCwAgAEHEpBQQ9AELQwAgARDAAiEBIAEgACgCDCAAKAIIIgBrQQJ1SQR/IAAgAUECdGooAgBBAEcFQQALRQRAENUBAAsgACABQQJ0aigCAAsQACAAEPYBIAEQ9gFzQQFzC0sBAn8gACgCACIBBEACfyABKAIMIgIgASgCEEYEQCABIAEoAgAoAiQRAAAMAQsgAi0AAAtBf0cEQCAAKAIARQ8LIABBADYCAAtBAQsNACAAKAIAEPgBGiAACzEBAX8gACgCDCIBIAAoAhBGBEAgACAAKAIAKAIoEQAADwsgACABQQFqNgIMIAEtAAALDQAgAEEEahDYARogAAsJACAAEPkBEDQLEwAgACAAKAIAQQxrKAIAahD5AQsTACAAIAAoAgBBDGsoAgBqEPoBC1wBAn8CQCAAKAIAIgJFDQACfyACKAIYIgMgAigCHEYEQCACIAFB/wFxIAIoAgAoAjQRAwAMAQsgAiADQQFqNgIYIAMgAToAACABQf8BcQtBf0cNACAAQQA2AgALCzgBAn8gAEHwlBM2AgAgACgCBCIBIAEoAgRBAWsiAjYCBCACQX9GBEAgASABKAIAKAIIEQEACyAACwkAIAAQ/gEQNAvfAQEEfyMAQRBrIgQkAANAAkAgAiAFTA0AAn8gACgCDCIDIAAoAhAiBkkEQCAEQf////8HNgIMIAQgBiADa0ECdTYCCCAEIAIgBWs2AgQgASADIARBBGoiASAEQQhqIgMgASgCACADKAIASBsiASAEQQxqIgMgASgCACADKAIASBsoAgAiAxCBAiEBIAAgA0ECdCIGIAAoAgxqNgIMIAEgBmoMAQsgACAAKAIAKAIoEQAAIgNBf0YNASABIAM2AgBBASEDIAFBBGoLIQEgAyAFaiEFDAELCyAEQRBqJAAgBQsqAQF/IwBBEGsiAyQAIANBCGogASABIAJBAnRqIAAQ5wEgA0EQaiQAIAALMgEBf0F/IQEgACAAKAIAKAIkEQAAQX9HBH8gACAAKAIMIgBBBGo2AgwgACgCAAVBfwsLuwEBBH8jAEEQayIFJAADQAJAIAIgBEwNACAAKAIYIgMgACgCHCIGTwRAIAAgASgCACAAKAIAKAI0EQMAQX9GDQEgBEEBaiEEIAFBBGohAQUgBSAGIANrQQJ1NgIMIAUgAiAEazYCCCADIAEgBUEIaiIDIAVBDGoiBiADKAIAIAYoAgBIGygCACIDEIECGiAAIANBAnQiBiAAKAIYajYCGCADIARqIQQgASAGaiEBCwwBCwsgBUEQaiQAIAQLKgAgAEHwlBM2AgAgAEEEahDrASAAQgA3AhggAEIANwIQIABCADcCCCAAC6wBAQN/IwBBEGsiAyQAIAAgACgCAEEMaygCAGooAhgEQCADQQhqIgIgADYCBCACQQA6AAAgACAAKAIAQQxrKAIAaiIBKAIQRQRAIAEoAkgiAQRAIAEQhQILIAJBAToAAAsCQCACLQAARQ0AIAAgACgCAEEMaygCAGooAhgiASABKAIAKAIYEQAAQX9HDQAgACAAKAIAQQxrKAIAahDyAQsgAhDxAQsgA0EQaiQACwsAIABBvKQUEPQBCxAAIAAQiAIgARCIAnNBAXMLSwECfyAAKAIAIgEEQAJ/IAEoAgwiAiABKAIQRgRAIAEgASgCACgCJBEAAAwBCyACKAIAC0F/RwRAIAAoAgBFDwsgAEEANgIAC0EBCw0AIAAoAgAQigIaIAALMQEBfyAAKAIMIgEgACgCEEYEQCAAIAAoAgAoAigRAAAPCyAAIAFBBGo2AgwgASgCAAtUAQJ/AkAgACgCACICRQ0AAn8gAigCGCIDIAIoAhxGBEAgAiABIAIoAgAoAjQRAwAMAQsgAiADQQRqNgIYIAMgATYCACABC0F/Rw0AIABBADYCAAsLOgAgAC0AC0GAAXFBB3YEQCAAKAIAEDQLIAAgASkCADcCACAAIAEoAgg2AgggAUEAOgALIAFBADoAAAvIAQEEfyAAIQMjAEEQayIGJAACQCACIAFrIgRB8P///wdJBEACQCAEQQtJBEAgAyAEOgALDAELIAZBCGogBEELTwR/IARBEGpBcHEiBSAFQQFrIgUgBUELRhsFQQoLQQFqEI4CIAMgBigCCCIFNgIAIAMgBigCDEGAgICAeHI2AgggAyAENgIEIAUhAwsDQCABIAJHBEAgAyABLQAAOgAAIANBAWohAyABQQFqIQEMAQsLIANBADoAACAGQRBqJAAMAQsQVQALIAALGAEBfyABEFQhAiAAIAE2AgQgACACNgIAC/0BAQJ/AkAgACgCBCAALQALIgJB/wBxIAJBgAFxQQd2GyICIAFJBEAgASACayICBEAgAiAALQALQYABcUEHdgR/IAAoAghB/////wdxQQFrBUEKCyIDIAAoAgQgAC0ACyIBQf8AcSABQYABcUEHdhsiAWtLBEAgACADIAIgA2sgAWogASABEL0DCyAAKAIAIAAgAC0AC0GAAXFBB3YbIgMgAWogAkEAEJECGiABIAJqIQECQCAALQALQYABcUEHdgRAIAAgATYCBAwBCyAAIAE6AAsLIAEgA2pBADoAAAsMAQsgACAAKAIAIAAgAC0AC0GAAXFBB3YbIAEQkAILCy4AAkAgAC0AC0GAAXFBB3YEQCAAIAI2AgQMAQsgACACOgALCyABIAJqQQA6AAALQwEBfyMAQRBrIgMkACADIAI6AA8gACECA0AgAQRAIAIgAy0ADzoAACABQQFrIQEgAkEBaiECDAELCyADQRBqJAAgAAsLACAAQcykFBD0AQt8AQN/QX8hAwJAIABBf0YNACABKAJMQQBOIQQCQAJAIAEoAgQiAkUEQCABEMcBGiABKAIEIgJFDQELIAIgASgCLEEIa0sNAQsgBEUNAUF/DwsgASACQQFrIgI2AgQgAiAAOgAAIAEgASgCAEFvcTYCACAAQf8BcSEDCyADCx4AQaSbFBDwAUH0nRQQ8AFB+JsUEIUCQcieFBCFAguVAQEDfyMAQRBrIgMkACAAEOoBIgAgATYCICAAQZSaEzYCACADIAAoAgQiATYCDCABIAEoAgRBAWo2AgQgAygCDBCSAiEBIAMoAgwiBCAEKAIEQQFrIgU2AgQgBUF/RgRAIAQgBCgCACgCCBEBAAsgACACNgIoIAAgATYCJCAAIAEgASgCACgCHBEAADoALCADQRBqJAALNAEBfyAAQQRqIgJB/JkTNgIAIAJB4JkTNgIAIABBgJsTNgIAIAJBlJsTNgIAIAIgARCZAguVAQEDfyMAQRBrIgMkACAAEIQCIgAgATYCICAAQYSdEzYCACADIAAoAgQiATYCDCABIAEoAgRBAWo2AgQgAygCDBCaAiEBIAMoAgwiBCAEKAIEQQFrIgU2AgQgBUF/RgRAIAQgBCgCACgCCBEBAAsgACACNgIoIAAgATYCJCAAIAEgASgCACgCHBEAADoALCADQRBqJAALNAEBfyAAQQRqIgJB/JkTNgIAIAJB6JwTNgIAIABB8J0TNgIAIAJBhJ4TNgIAIAIgARCZAgtKACAAQQA2AhQgACABNgIYIABBADYCDCAAQoKggIDgADcCBCAAIAFFNgIQIABBIGpBAEEoECkaIABBHGoQ6wEgAEKAgICAcDcCSAsLACAAQdSkFBD0AQsxACAAIAAoAgAoAhgRAAAaIAAgASgCABCaAiIBNgIkIAAgASABKAIAKAIcEQAAOgAsC4QBAQV/IwBBEGsiASQAIAFBEGohBAJAA0AgACgCJCICIAAoAiggAUEIaiIDIAQgAUEEaiACKAIAKAIUEQcAIQVBfyECIANBASABKAIEIANrIgMgACgCIBAtIANHDQECQCAFQQFrDgIBAgALC0F/QQAgACgCIBCuARshAgsgAUEQaiQAIAILZQEBfwJAIAAtACxFBEAgAkEAIAJBAEobIQIDQCACIANGDQIgACABKAIAIAAoAgAoAjQRAwBBf0YEQCADDwUgAUEEaiEBIANBAWohAwwBCwALAAsgAUEEIAIgACgCIBAtIQILIAILhwIBBX8jAEEgayICJAACQAJAAkAgAUF/Rg0AIAIgATYCFCAALQAsBEBBfyEDIAJBFGpBBEEBIAAoAiAQLUEBRg0BDAMLIAIgAkEYaiIFNgIQIAJBIGohBiACQRRqIQMDQCAAKAIkIgQgACgCKCADIAUgAkEMaiACQRhqIAYgAkEQaiAEKAIAKAIMEQsAIQQgAigCDCADRg0CIARBA0YEQCADQQFBASAAKAIgEC1BAUYNAgwDCyAEQQFLDQIgAkEYaiIDQQEgAigCECADayIDIAAoAiAQLSADRw0CIAIoAgwhAyAEQQFGDQALCyABQQAgAUF/RxshAwwBC0F/IQMLIAJBIGokACADC0kAIAAgASgCABCaAiIBNgIkIAAgASABKAIAKAIYEQAANgIsIAAgACgCJCIBIAEoAgAoAhwRAAA6ADUgACgCLEEJTgRAENUBAAsLCQAgAEEAEKECC58DAgZ/AX4jAEEgayICJAACQCAALQA0BEAgACgCMCEDIAFFDQEgAEEAOgA0IABBfzYCMAwBCyACQQE2AhggAEEsaiIEIAJBGGoiAyADKAIAIAQoAgBIGygCACIEQQAgBEEAShshBgNAIAUgBkcEQEF/IQMgACgCIBA+IgdBf0YNAiACQRhqIAVqIAc6AAAgBUEBaiEFDAELCwJAAkAgAC0ANQRAIAIgAiwAGDYCFAwBCyACQRhqIQMDQAJAIAAoAigiBSkCACEIAkAgACgCJCIGIAUgAkEYaiIFIAQgBWoiBSACQRBqIAJBFGogAyACQQxqIAYoAgAoAhARCwBBAWsOAwAEAQMLIAAoAiggCDcCACAEQQhGDQMgACgCIBA+IgZBf0YNAyAFIAY6AAAgBEEBaiEEDAELCyACIAIsABg2AhQLAkAgAUUEQANAIARBAEwNAkF/IQMgBEEBayIEIAJBGGpqLAAAIAAoAiAQkwJBf0cNAAwECwALIAAgAigCFCIDNgIwDAILIAIoAhQhAwwBC0F/IQMLIAJBIGokACADCwkAIABBARChAgvxAQEDfyMAQSBrIgIkACAALQA0IQMCQCABQX9GBEAgAw0BIAAgACgCMCIBQX9HOgA0DAELAkAgA0UNACACIAAoAjA2AhACQAJAAkAgACgCJCIDIAAoAiggAkEQaiACQRRqIgQgAkEMaiACQRhqIAJBIGogBCADKAIAKAIMEQsAQQFrDgMCAgABCyAAKAIwIQMgAiACQRlqNgIUIAIgAzoAGAsDQCACKAIUIgMgAkEYak0NAiACIANBAWsiAzYCFCADLAAAIAAoAiAQkwJBf0cNAAsLQX8hAQwBCyAAQQE6ADQgACABNgIwCyACQSBqJAAgAQsxACAAIAAoAgAoAhgRAAAaIAAgASgCABCSAiIBNgIkIAAgASABKAIAKAIcEQAAOgAsC2UBAX8CQCAALQAsRQRAIAJBACACQQBKGyECA0AgAiADRg0CIAAgAS0AACAAKAIAKAI0EQMAQX9GBEAgAw8FIAFBAWohASADQQFqIQMMAQsACwALIAFBASACIAAoAiAQLSECCyACC4gCAQV/IwBBIGsiAiQAAkACQAJAIAFBf0YNACACIAHAOgAXIAAtACwEQEF/IQMgAkEXakEBQQEgACgCIBAtQQFGDQEMAwsgAiACQRhqIgU2AhAgAkEgaiEGIAJBF2ohAwNAIAAoAiQiBCAAKAIoIAMgBSACQQxqIAJBGGogBiACQRBqIAQoAgAoAgwRCwAhBCACKAIMIANGDQIgBEEDRgRAIANBAUEBIAAoAiAQLUEBRg0CDAMLIARBAUsNAiACQRhqIgNBASACKAIQIANrIgMgACgCIBAtIANHDQIgAigCDCEDIARBAUYNAAsLIAFBACABQX9HGyEDDAELQX8hAwsgAkEgaiQAIAMLSQAgACABKAIAEJICIgE2AiQgACABIAEoAgAoAhgRAAA2AiwgACAAKAIkIgEgASgCACgCHBEAADoANSAAKAIsQQlOBEAQ1QEACwsJACAAQQAQqQILnwMCBn8BfiMAQSBrIgIkAAJAIAAtADQEQCAAKAIwIQMgAUUNASAAQQA6ADQgAEF/NgIwDAELIAJBATYCGCAAQSxqIgQgAkEYaiIDIAMoAgAgBCgCAEgbKAIAIgRBACAEQQBKGyEGA0AgBSAGRwRAQX8hAyAAKAIgED4iB0F/Rg0CIAJBGGogBWogBzoAACAFQQFqIQUMAQsLAkACQCAALQA1BEAgAiACLQAYOgAXDAELIAJBGGohAwNAAkAgACgCKCIFKQIAIQgCQCAAKAIkIgYgBSACQRhqIgUgBCAFaiIFIAJBEGogAkEXaiADIAJBDGogBigCACgCEBELAEEBaw4DAAQBAwsgACgCKCAINwIAIARBCEYNAyAAKAIgED4iBkF/Rg0DIAUgBjoAACAEQQFqIQQMAQsLIAIgAi0AGDoAFwsCQCABRQRAA0AgBEEATA0CQX8hAyAEQQFrIgQgAkEYamotAAAgACgCIBCTAkF/Rw0ADAQLAAsgACACLQAXIgM2AjAMAgsgAi0AFyEDDAELQX8hAwsgAkEgaiQAIAMLCQAgAEEBEKkCC/IBAQN/IwBBIGsiAiQAIAAtADQhAwJAIAFBf0YEQCADDQEgACAAKAIwIgFBf0c6ADQMAQsCQCADRQ0AIAIgACgCMMA6ABMCQAJAAkAgACgCJCIDIAAoAiggAkETaiACQRRqIgQgAkEMaiACQRhqIAJBIGogBCADKAIAKAIMEQsAQQFrDgMCAgABCyAAKAIwIQMgAiACQRlqNgIUIAIgAzoAGAsDQCACKAIUIgMgAkEYak0NAiACIANBAWsiAzYCFCADLAAAIAAoAiAQkwJBf0cNAAsLQX8hAQwBCyAAQQE6ADQgACABNgIwCyACQSBqJAAgAQssAQF/IwBBEGsiAiQAIAIgATYCDCAAQeQAQfs/IAEQ0QEhACACQRBqJAAgAAuYAwEKfyAAAn8CQCAAIgFBA3EEQANAIAEtAAAiAkUNAiACQT1GDQIgAUEBaiIBQQNxDQALCwJAIAEoAgAiAkF/cyACQYGChAhrcUGAgYKEeHENAANAIAJBvfr06QNzQYGChAhrIAJBf3NxQYCBgoR4cQ0BIAEoAgQhAiABQQRqIQEgAkGBgoQIayACQX9zcUGAgYKEeHFFDQALCwNAIAEiAi0AACIDQT1HBEAgAkEBaiEBIAMNAQsLIAIMAQsgAQsiAUYEQEEADwsCQCAAIAEgAGsiBmotAAANAEGAohQoAgAiBEUNACAEKAIAIgFFDQADQAJAAn8gACECIAEhA0EAIQdBACAGIghFDQAaAkAgAi0AACIFRQ0AA0ACQCAFIAMtAAAiCUcNACAJRQ0AIAhBAWsiCEUNACADQQFqIQMgAi0AASEFIAJBAWohAiAFDQEMAgsLIAUhBwsgB0H/AXEgAy0AAGsLRQRAIAEgBmoiAS0AAEE9Rg0BCyAEKAIEIQEgBEEEaiEEIAENAQwCCwsgAUEBaiEKCyAKC/ACAQN/AkAgAS0AAA0AQYPFABCtAiIBBEAgAS0AAA0BCyAAQQxsQdCeE2oQrQIiAQRAIAEtAAANAQtBl8UAEK0CIgEEQCABLQAADQELQfLlEiEBCwJAA0ACQCABIAJqLQAAIgRFDQAgBEEvRg0AQRchBCACQQFqIgJBF0cNAQwCCwsgAiEEC0Hy5RIhAwJAAkACQAJAAkAgAS0AACICQS5GDQAgASAEai0AAA0AIAEhAyACQcMARw0BCyADLQABRQ0BCyADQfLlEhC3AUUNACADQfzDABC3AQ0BCyAARQRAQZifEyECIAMtAAFBLkYNAgtBAA8LQYSiFCgCACICBEADQCADIAJBCGoQtwFFDQIgAigCICICDQALC0EkEDMiAgRAIAJBFDYCBCACQbCeEzYCACACQQhqIgEgAyAEECsaIAEgBGpBADoAACACQYSiFCgCADYCIEGEohQgAjYCAAsgAkGYnxMgACACchshAgsgAgsuACAAQQBHIABBjO8TR3EgAEGk7xNHcSAAQYiiFEdxIABBoKIUR3EEQCAAEDQLC7IIAQV/IAEoAgAhBAJAAkACQAJAAkACQAJAAn8CQAJAAkACQCADRQ0AIAMoAgAiBkUNACAARQRAIAIhAwwDCyADQQA2AgAgAiEDDAELAkBBzJkUKAIAKAIARQRAIABFDQEgAkUNDCACIQYDQCAELAAAIgMEQCAAIANB/78DcTYCACAAQQRqIQAgBEEBaiEEIAZBAWsiBg0BDA4LCyAAQQA2AgAgAUEANgIAIAIgBmsPCyACIQMgAEUNAwwFCyAEEC8PC0EBIQUMAwtBAAwBC0EBCyEFA0AgBUUEQCAELQAAQQN2IgVBEGsgBkEadSAFanJBB0sNAwJ/IARBAWoiBSAGQYCAgBBxRQ0AGiAFLQAAQcABcUGAAUcEQCAEQQFrIQQMBwsgBEECaiIFIAZBgIAgcUUNABogBS0AAEHAAXFBgAFHBEAgBEEBayEEDAcLIARBA2oLIQQgA0EBayEDQQEhBQwBCwNAIAQtAAAhBgJAIARBA3ENACAGQQFrQf4ASw0AIAQoAgAiBkGBgoQIayAGckGAgYKEeHENAANAIANBBGshAyAEKAIEIQYgBEEEaiEEIAYgBkGBgoQIa3JBgIGChHhxRQ0ACwsgBkH/AXEiBUEBa0H+AE0EQCADQQFrIQMgBEEBaiEEDAELCyAFQcIBayIFQTJLDQMgBEEBaiEEIAVBAnRBwLcTaigCACEGQQAhBQwACwALA0AgBUUEQCADRQ0HA0ACQAJAAkAgBC0AACIFQQFrIgdB/gBLBEAgBSEGDAELIANBBUkNASAEQQNxDQECQANAIAQoAgAiBkGBgoQIayAGckGAgYKEeHENASAAIAZB/wFxNgIAIAAgBC0AATYCBCAAIAQtAAI2AgggACAELQADNgIMIABBEGohACAEQQRqIQQgA0EEayIDQQRLDQALIAQtAAAhBgsgBkH/AXEiBUEBayEHCyAHQf4ASw0BCyAAIAU2AgAgAEEEaiEAIARBAWohBCADQQFrIgMNAQwJCwsgBUHCAWsiBUEySw0DIARBAWohBCAFQQJ0QcC3E2ooAgAhBkEBIQUMAQsgBC0AACIFQQN2IgdBEGsgByAGQRp1anJBB0sNAQJAAkACfyAEQQFqIgcgBUGAAWsgBkEGdHIiBUEATg0AGiAHLQAAQYABayIHQT9LDQEgBEECaiIIIAcgBUEGdHIiBUEATg0AGiAILQAAQYABayIHQT9LDQEgByAFQQZ0ciEFIARBA2oLIQQgACAFNgIAIANBAWshAyAAQQRqIQAMAQtBoP8TQRk2AgAgBEEBayEEDAULQQAhBQwACwALIARBAWshBCAGDQEgBC0AACEGCyAGQf8BcQ0AIAAEQCAAQQA2AgAgAUEANgIACyACIANrDwtBoP8TQRk2AgAgAEUNAQsgASAENgIAC0F/DwsgASAENgIAIAILhwQCB38EfiMAQRBrIggkAAJAIAAtAAAiBUUEQCAAIQQMAQsgACEEAkADQCAFwCIGQSBGIAZBCWtBBUlyRQ0BIAQtAAEhBSAEQQFqIQQgBQ0ACwwBCwJAIAVB/wFxIgVBK2sOAwABAAELQX9BACAFQS1GGyEHIARBAWohBAsCfwJAIAJBEHJBEEcNACAELQAAQTBHDQBBASEJIAQtAAFB3wFxQdgARgRAIARBAmohBEEQDAILIARBAWohBCACQQggAhsMAQsgAkEKIAIbCyIKrSEMQQAhAgNAAkBBUCEFAkAgBCwAACIGQTBrQf8BcUEKSQ0AQal/IQUgBkHhAGtB/wFxQRpJDQBBSSEFIAZBwQBrQf8BcUEZSw0BCyAFIAZqIgYgCk4NACAIIAxCACALQgAQPUEBIQUCQCAIKQMIQgBSDQAgCyAMfiINIAatIg5Cf4VWDQAgDSAOfCELQQEhCSACIQULIARBAWohBCAFIQIMAQsLIAEEQCABIAQgACAJGzYCAAsCQAJAAkAgAgRAQaD/E0HEADYCACAHQQAgA0IBgyIMUBshByADIQsMAQsgAyALVg0BIANCAYMhDAsCQCAMpw0AIAcNAEGg/xNBxAA2AgAgA0IBfSEDDAILIAMgC1oNAEGg/xNBxAA2AgAMAQsgCyAHrCIDhSADfSEDCyAIQRBqJAAgAwt/AgJ/An4jAEGgAWsiBCQAIAQgATYCPCAEIAE2AhQgBEF/NgIYIARBEGoiBUIAEMkBIAQgBSADQQEQzgEgBCkDCCEGIAQpAwAhByACBEAgAiABIAQoAhQgBCgCiAFqIAQoAjxrajYCAAsgACAGNwMIIAAgBzcDACAEQaABaiQAC14BA38gASAEIANraiEFAkADQCADIARHBEBBfyEAIAEgAkYNAiABLAAAIgYgAywAACIHSA0CIAYgB0oEQEEBDwUgA0EBaiEDIAFBAWohAQwCCwALCyACIAVHIQALIAALDAAgACACIAMQjQIaC0ABAX9BACEAA38gASACRgR/IAAFIAEsAAAgAEEEdGoiAEGAgICAf3EiA0EYdiADciAAcyEAIAFBAWohAQwBCwsLVAECfwJAA0AgAyAERwRAQX8hACABIAJGDQIgASgCACIFIAMoAgAiBkgNAiAFIAZKBEBBAQ8FIANBBGohAyABQQRqIQEMAgsACwsgASACRyEACyAACwwAIAAgAiADELgCGgvLAQEEfyAAIQMjAEEQayIGJAACQCACIAFrQQJ1IgRB8P///wNJBEACQCAEQQJJBEAgAyAEOgALDAELIAZBCGogBEECTwR/IARBBGpBfHEiBSAFQQFrIgUgBUECRhsFQQELQQFqELkCIAMgBigCCCIFNgIAIAMgBigCDEGAgICAeHI2AgggAyAENgIEIAUhAwsDQCABIAJHBEAgAyABKAIANgIAIANBBGohAyABQQRqIQEMAQsLIANBADYCACAGQRBqJAAMAQsQVQALIAALGQEBfyABELoCIQIgACABNgIEIAAgAjYCAAsZACAAQYCAgIAETwRAEKQBAAsgAEECdBBUC0ABAX9BACEAA38gASACRgR/IAAFIAEoAgAgAEEEdGoiAEGAgICAf3EiA0EYdiADciAAcyEAIAFBBGohAQwBCwsL9AIBAn8jAEEgayIGJAAgBiABNgIcAkAgAy0ABEEBcUUEQCAGQX82AgAgACABIAIgAyAEIAYgACgCACgCEBEFACEBAkACQAJAIAYoAgAOAgABAgsgBUEAOgAADAMLIAVBAToAAAwCCyAFQQE6AAAgBEEENgIADAELIAYgAygCHCIANgIAIAAgACgCBEEBajYCBCAGKAIAEPMBIQcgBigCACIAIAAoAgRBAWsiATYCBCABQX9GBEAgACAAKAIAKAIIEQEACyAGIAMoAhwiADYCACAAIAAoAgRBAWo2AgQgBigCABC9AiEAIAYoAgAiASABKAIEQQFrIgM2AgQgA0F/RgRAIAEgASgCACgCCBEBAAsgBiAAIAAoAgAoAhgRAgAgBkEMciAAIAAoAgAoAhwRAgAgBSAGQRxqIAIgBiAGQRhqIgMgByAEQQEQvgIgBkY6AAAgBigCHCEBA0AgA0EMaxC/AiIDIAZHDQALCyAGQSBqJAAgAQsLACAAQfykFBD0AQv4BQELfyMAQYABayIKJAAgCiABNgJ8IApB1AA2AhAgCkEIaiIBQQA2AgAgASAKQRBqIgkoAgA2AgQgASENAkACQCADIAJrQQxtIgtB5QBPBEAgCxAzIglFDQEgDSgCACEBIA0gCTYCACABBEAgASANKAIEEQEACwsgCSEHIAIhAQNAIAEgA0YEQANAIAAgCkH8AGoQ9QFBASALGwRAIAAgCkH8AGoQ9QEEQCAFIAUoAgBBAnI2AgALDAULAn8gACgCACIHKAIMIgEgBygCEEYEQCAHIAcoAgAoAiQRAAAMAQsgAS0AAAvAIQ4gBkUEQCAEIA4gBCgCACgCDBEDACEOCyAQQQFqIQhBACERIAkhByACIQEDQCABIANGBEAgCCEQIBFFDQIgABD3ARogCSEHIAIhASALIAxqQQJJDQIDQCABIANGBEAMBAUCQCAHLQAAQQJHDQAgECABKAIEIAEtAAsiCEH/AHEgCEGAAXFBB3YbRg0AIAdBADoAACAMQQFrIQwLIAdBAWohByABQQxqIQEMAQsACwAFAkAgBy0AAEEBRw0AIBAgASgCACABIAEtAAtBgAFxQQd2G2otAAAhDwJAIA5B/wFxIAYEfyAPBSAEIA/AIAQoAgAoAgwRAwALQf8BcUYEQEEBIREgCCABKAIEIAEtAAsiD0H/AHEgD0GAAXFBB3YbRw0CIAdBAjoAACAMQQFqIQwMAQsgB0EAOgAACyALQQFrIQsLIAdBAWohByABQQxqIQEMAQsACwALAAUgB0ECQQEgASgCBCABLQALIghB/wBxIAhBgAFxQQd2G0UiCBs6AAAgCCAMaiEMIAsgCGshCyAHQQFqIQcgAUEMaiEBDAELAAsACxDVAQALAkACQANAIAIgA0YNASAJLQAAQQJHBEAgCUEBaiEJIAJBDGohAgwBCwsgAiEDDAELIAUgBSgCAEEEcjYCAAsgDSIAKAIAIQEgAEEANgIAIAEEQCABIAAoAgQRAQALIApBgAFqJAAgAwsaACAALQALQYABcUEHdgRAIAAoAgAQNAsgAAvOAQEFfyMAQRBrIgUkACAFQQRqIgFB1QA2AgQgASAANgIAIAFBADYCCCMAQRBrIgMkACAAKAIAQX9HBEAgA0EMaiIEIAE2AgAgA0EIaiICIAQ2AgADQCAAKAIAQQFGDQALIAAoAgBFBEAgAEEBNgIAIAIoAgAoAgAiASgCACABKAIIIgRBAXVqIQIgASgCBCEBIAIgBEEBcQR/IAIoAgAgAWooAgAFIAELEQEAIABBfzYCAAsLIANBEGokACAAKAIEIQAgBUEQaiQAIABBAWsLHAAgAEG4pBRBuKQUKAIAQQFqIgA2AgAgADYCBAvlBAECfyADKAIEIQAgAygCHCEGIwBB4AFrIgMkACADIAI2AtgBIAMgATYC3AEgABDDAiEHIANByAFqIAYgA0HXAWoQxAIgA0G8AWoiAkIANwIAIAJBADYCCCACIAItAAtBgAFxQQd2BH8gAigCCEH/////B3FBAWsFQQoLEI8CIAMgAigCACACIAItAAtBgAFxQQd2GyIGNgK4ASADIANBEGo2AgwgA0EANgIIA0ACQCADQdwBaiADQdgBahD1AQ0AIAMoArgBIAYgAigCBCACLQALIgBB/wBxIABBgAFxQQd2GyIAakYEQCACIABBAXQQjwIgAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCPAiADIAIoAgAgAiACLQALQYABcUEHdhsiBiAAajYCuAELAn8gAygC3AEiACgCDCIBIAAoAhBGBEAgACAAKAIAKAIkEQAADAELIAEtAAALwCAHIAYgA0G4AWogA0EIaiADLADXASADKALMASADLQDTASADQRBqIANBDGpBkLkTEMUCDQAgA0HcAWoQ9wEaDAELCyADKAIMIQACQAJAIAMoAswBIAMtANMBIgFB/wBxIAFBgAFxQQd2G0UNACAAIANBEGprQZ8BSg0AIAMgAEEEaiIBNgIMIAAgAygCCDYCAAwBCyAAIQELIAUgBiADKAK4ASAEIAcQxgI2AgAgA0HIAWogA0EQaiABIAQQxwIgA0HcAWogA0HYAWoQ9QEEQCAEIAQoAgBBAnI2AgALIAMoAtwBIQAgAhC/AhogA0HIAWoQvwIaIANB4AFqJAAgAAsrAAJAIABBygBxIgAEQCAAQcAARgRAQQgPCyAAQQhHDQFBEA8LQQAPC0EKC3oBAX8jAEEQayIDJAAgAyABNgIMIAEgASgCBEEBajYCBCACIAMoAgwQvQIiASABKAIAKAIQEQAAOgAAIAAgASABKAIAKAIUEQIAIAMoAgwiACAAKAIEQQFrIgE2AgQgAUF/RgRAIAAgACgCACgCCBEBAAsgA0EQaiQAC9gCAQN/AkACQCADKAIAIgsgAkcNAEErIQwgAEH/AXEiDSAKLQAYRwRAQS0hDCAKLQAZIA1HDQELIAMgAkEBajYCACACIAw6AAAMAQsCQAJAIAYgB0H/AHEgB0GAAXFBB3YbRQ0AIAAgBUcNAEEAIQcgCSgCACIAIAhrQZ8BSg0BIAQoAgAhASAJIABBBGo2AgAgACABNgIADAILQX8hByAKIApBGmogABDIAiAKayIAQRdKDQACQAJAAkAgAUEIaw4DAAIAAQsgACABSA0BDAILIAFBEEcNACAAQRZIDQAgAiALRg0BIAsgAmtBAkoNASALQQFrLQAAQTBHDQEgBEEANgIAIAMgC0EBajYCACALIABBkLkTai0AADoAAEEADwsgAyALQQFqNgIAIAsgAEGQuRNqLQAAOgAAIAQgBCgCAEEBajYCAEEAIQcLIAcPCyAEQQA2AgBBAAviAQICfwF+IwBBEGsiBCQAAn8CQCAAIAFHBEACQEGg/xMoAgAhBUGg/xNBADYCABDJAhogACAEQQxqIAMQygIhBgJAQaD/EygCACIABEAgBCgCDCABRw0CIABBxABHDQEgAkEENgIAQf////8HIAZCAFUNBRoMBAtBoP8TIAU2AgAgBCgCDCABRg0ADAELIAZC/////3dXBEAgAkEENgIADAMLIAZCgICAgAhZBEAgAkEENgIAQf////8HDAQLIAanDAMLCyACQQQ2AgBBAAwBC0GAgICAeAshACAEQRBqJAAgAAvaAQEDfyAAKAIEIAAtAAsiBEH/AHEgBEGAAXFBB3YbIQQCQCACIAFrQQVIDQAgBEUNACABIAIQywIgAkEEayEEIAAoAgQgAC0ACyICQf8AcSACQYABcUEHdhsgACgCACAAIAJBgAFxQQd2GyICaiEGAkADQAJAIAIsAAAiAEH/AGshBSABIARPDQAgBUH/AXFBggFPBEAgASgCACAARw0DCyABQQRqIQEgAiAGIAJrQQFKaiECDAELCyAFQf8BcUGCAUkNASAEKAIAQQFrIABJDQELIANBBDYCAAsLMgAgAkH/AXEhAgNAAkAgACABRwR/IAAtAAAgAkcNASAABSABCw8LIABBAWohAAwACwAL1AIBA39BnKQULQAABEBBmKQUKAIADwsjAEEgayIBJAACQAJAA0AgAUEIaiAAQQJ0aiAAQenFAEHt5hJBASAAdEH/////B3EbEK4CIgI2AgAgAkF/Rg0BIABBAWoiAEEGRw0AC0GM7xMhACABQQhqQYzvE0EYEIgBRQ0BQaTvEyEAIAFBCGpBpO8TQRgQiAFFDQFBACEAQbiiFC0AAEUEQANAIABBAnRBiKIUaiAAQe3mEhCuAjYCACAAQQFqIgBBBkcNAAtBuKIUQQE6AABBoKIUQYiiFCgCADYCAAtBiKIUIQAgAUEIakGIohRBGBCIAUUNAUGgohQhACABQQhqQaCiFEEYEIgBRQ0BQRgQMyIARQ0AIAAgASkCCDcCACAAIAEpAhg3AhAgACABKQIQNwIIDAELQQAhAAsgAUEgaiQAQZykFEEBOgAAQZikFCAANgIAIAALFgAgACABIAJCgICAgICAgICAfxCxAgs/AQF/AkAgACABRg0AA0AgACABQQRrIgFPDQEgACgCACECIAAgASgCADYCACABIAI2AgAgAEEEaiEADAALAAsL5QQBAn8gAygCBCEAIAMoAhwhBiMAQeABayIDJAAgAyACNgLYASADIAE2AtwBIAAQwwIhByADQcgBaiAGIANB1wFqEMQCIANBvAFqIgJCADcCACACQQA2AgggAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCPAiADIAIoAgAgAiACLQALQYABcUEHdhsiBjYCuAEgAyADQRBqNgIMIANBADYCCANAAkAgA0HcAWogA0HYAWoQ9QENACADKAK4ASAGIAIoAgQgAi0ACyIAQf8AcSAAQYABcUEHdhsiAGpGBEAgAiAAQQF0EI8CIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQjwIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgYgAGo2ArgBCwJ/IAMoAtwBIgAoAgwiASAAKAIQRgRAIAAgACgCACgCJBEAAAwBCyABLQAAC8AgByAGIANBuAFqIANBCGogAywA1wEgAygCzAEgAy0A0wEgA0EQaiADQQxqQZC5ExDFAg0AIANB3AFqEPcBGgwBCwsgAygCDCEAAkACQCADKALMASADLQDTASIBQf8AcSABQYABcUEHdhtFDQAgACADQRBqa0GfAUoNACADIABBBGoiATYCDCAAIAMoAgg2AgAMAQsgACEBCyAFIAYgAygCuAEgBCAHEM0CNwMAIANByAFqIANBEGogASAEEMcCIANB3AFqIANB2AFqEPUBBEAgBCAEKAIAQQJyNgIACyADKALcASEAIAIQvwIaIANByAFqEL8CGiADQeABaiQAIAALrQECAn8BfiMAQRBrIgQkAAJAIAAgAUcEQEGg/xMoAgAhBUGg/xNBADYCABDJAhogACAEQQxqIAMQygIhBgJAQaD/EygCACIABEAgBCgCDCABRw0BIABBxABHDQMgAkEENgIAQv//////////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aiAGIANBwAFqIAcgASADQdABaiADQSBqIANBHGogA0EYaiADQeABahDXAg0AIANBjAJqEPcBGgwBCwsgAygCHCEAAkACQCADKALUASADLQDbASIBQf8AcSABQYABcUEHdhtFDQAgAy0AF0UNACAAIANBIGprQZ8BSg0AIAMgAEEEaiIBNgIcIAAgAygCGDYCAAwBCyAAIQELIAMgBiADKALAASAEENwCIAMpAwAhCSAFIAMpAwg3AwggBSAJNwMAIANB0AFqIANBIGogASAEEMcCIANBjAJqIANBiAJqEPUBBEAgBCAEKAIAQQJyNgIACyADKAKMAiEAIAIQvwIaIANB0AFqEL8CGiADQZACaiQAIAALsgICBH4FfyMAQSBrIggkAAJAAkACQCABIAJHBEBBoP8TKAIAIQxBoP8TQQA2AgAjAEEQayIJJAAQyQIaIwBBEGsiCiQAIwBBEGsiCyQAIAsgASAIQRxqQQIQsgIgCykDACEEIAogCykDCDcDCCAKIAQ3AwAgC0EQaiQAIAopAwAhBCAJIAopAwg3AwggCSAENwMAIApBEGokACAJKQMAIQQgCCAJKQMINwMQIAggBDcDCCAJQRBqJAAgCCkDECEEIAgpAwghBUGg/xMoAgAiAUUNASAIKAIcIAJHDQIgBSEGIAQhByABQcQARw0DDAILIANBBDYCAAwCC0Gg/xMgDDYCACAIKAIcIAJGDQELIANBBDYCACAGIQUgByEECyAAIAU3AwAgACAENwMIIAhBIGokAAuMBQECfyMAQYACayIAJAAgACACNgL4ASAAIAE2AvwBIABBxAFqIgdCADcCACAHQQA2AgggAEEQaiIGIAMoAhwiATYCACABIAEoAgRBAWo2AgQgACgCEBDzASIBQZC5E0GquRMgAEHQAWogASgCACgCIBEGABogACgCECIBIAEoAgRBAWsiAjYCBCACQX9GBEAgASABKAIAKAIIEQEACyAAQbgBaiICQgA3AgAgAkEANgIIIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQjwIgACACKAIAIAIgAi0AC0GAAXFBB3YbIgM2ArQBIAAgBjYCDCAAQQA2AgggAyEBA0ACQCACIABB/AFqIABB+AFqEPUBBH8gAwUgAyABIAIoAgQgAi0ACyIGQf8AcSAGQYABcUEH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iQUBA38gAygCHCEAIwBB8AJrIgMkACADIAI2AugCIAMgATYC7AIgA0HMAWogACADQeABaiADQdwBaiADQdgBahDuAiADQcABaiICQgA3AgAgAkEANgIIIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQjwIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgY2ArwBIAMgA0EQajYCDCADQQA2AgggA0EBOgAHIANBxQA6AAYgAygC2AEhASADKALcASEHA0ACQCADQewCaiADQegCahCHAg0AIAMoArwBIAYgAigCBCACLQALIgBB/wBxIABBgAFxQQd2GyIAakYEQCACIABBAXQQjwIgAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCPAiADIAIoAgAgAiACLQALQYABcUEHdhsiBiAAajYCvAELAn8gAygC7AIiACgCDCIIIAAoAhBGBEAgACAAKAIAKAIkEQAADAELIAgoAgALIANBB2ogA0EGaiAGIANBvAFqIAcgASADQcwBaiADQRBqIANBDGogA0EIaiADQeABahDvAg0AIANB7AJqEIkCGgwBCwsgAygCDCEAAkACQCADKALQASADLQDXASIBQf8AcSABQYABcUEHdhtFDQAgAy0AB0UNACAAIANBEGprQZ8BSg0AIAMgAEEEaiIBNgIMIAAgAygCCDYCAAwBCyAAIQELIAUgBiADKAK8ASAEENgCOAIAIANBzAFqIANBEGogASAEEMcCIANB7AJqIANB6AJqEIcCBEAgBCAEKAIAQQJyNgIACyADKALsAiEAIAIQvwIaIANBzAFqEL8CGiADQfACaiQAIAALrAEBAX8jAEEQayIFJAAgBSABNgIMIAEgASgCBEEBajYCBCAFKAIMEIYCIgFBkLkTQbC5EyACIAEoAgAoAjARBgAaIAMgBSgCDBDhAiIBIAEoAgAoAgwRAAA2AgAgBCABIAEoAgAoAhARAAA2AgAgACABIAEoAgAoAhQRAgAgBSgCDCIAIAAoAgRBAWsiATYCBCABQX9GBEAgACAAKAIAKAIIEQEACyAFQRBqJAALxgQAAkACQCAAIAVGBEAgAS0AAEUNAkEAIQUgAUEAOgAAIAQgBCgCACIAQQFqNgIAIABBLjoAACAHKAIEIActAAsiAEH/AHEgAEGA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AygC/AIhACACEL8CGiADQdwBahC/AhogA0GAA2okACAAC4sFAQJ/IwBBwAJrIgAkACAAIAI2ArgCIAAgATYCvAIgAEHEAWoiB0IANwIAIAdBADYCCCAAQRBqIgYgAygCHCIBNgIAIAEgASgCBEEBajYCBCAAKAIQEIYCIgFBkLkTQaq5EyAAQdABaiABKAIAKAIwEQYAGiAAKAIQIgEgASgCBEEBayICNgIEIAJBf0YEQCABIAEoAgAoAggRAQALIABBuAFqIgJCADcCACACQQA2AgggAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCPAiAAIAIoAgAgAiACLQALQYABcUEHdhsiAzYCtAEgACAGNgIMIABBADYCCCADIQEDQAJAIAIgAEG8AmogAEG4AmoQhwIEfyADBSADIAEgAigCBCACLQALIgZB/wBxIAZBgAFxQQd2GyIGakYEQCACIAZBAXQQjwIgAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCPAiAAIAIoAgAgAiACLQALQYABcUEHdhsiASAGajYCtAELAn8gACgCvAIiAygCDCIGIAMoAhBGBEAgAyADKAIAKAIkEQAADAELIAYoAgALQRAgASAAQbQBaiAAQQhqQQAgBygCBCAHLQALIABBEGogAEEMaiAAQdABahDnAkUNASAAKAK0AQsgAWsQjwIgAigCACACIAItAAtBgAFxQQd2GyEBEMkCIQMgACAFNgIAIAEgAyAAEN4CQQFHBEAgBEEENgIACyAAQbwCaiAAQbgCahCHAgRAIAQgBCgCAEECcjYCAAsgACgCvAIhASACEL8CGiAHEL8CGiAAQcACaiQAIAEPCyAAQbwCahCJAhogACgCtAEhAwwACwALkwIBAX8jAEEgayIFJAAgBSABNgIcAkAgAi0ABEEBcUUEQCAAIAEgAiADIAQgACgCACgCGBEHACECDAELIAUgAigCHCIANgIQIAAgACgCBEEBajYCBCAFKAIQEL0CIQAgBSgCECIBIAEoAgRBAWsiAjYCBCACQX9GBEAgASABKAIAKAIIEQEACwJAIAQEQCAFQRBqIAAgACgCACgCGBECAAwBCyAFQRBqIAAgACgCACgCHBECAAsgBSAFQRBqEPQCNgIMA0AgBUEQahD1AiEAIAAgBSgC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QRBqJAAgACgCECEBIAAgACgCFDYCDCACIAE2AgggAiAAKAIMNgIMIABBIGokACACKAIMIQAgAkEQaiQAIAMkACAACwUAQf8ACxAAIABCADcCACAAQQA2AggLJwAjAEEQayIBJAAgAEEBOgALIABBAUEtEJECQQA6AAEgAUEQaiQACwwAIABBgoaAIDYAAAsIAEH/////BwsMACAAQQFBLRCKAxoLNQAgAS0AC0GAAXFBB3ZFBEAgACABKQIANwIAIAAgASgCCDYCCA8LIAAgASgCACABKAIEEHYL8wQBAn8jAEGQAmsiACQAIAAgAjYCiAIgACABNgKMAiAAQdYANgIQIABBmAFqIgcgAEGgAWo2AgAgByAAKAIQNgIEIABBkAFqIgggBCgCHCIBNgIAIAEgASgCBEEBajYCBCAAKAKQARDzASEBIABBADoAjwECQCAAQYwCaiACIAMgCCAEKAIEIAUgAEGPAWogASAHIABBlAFqIABBhAJqELQDRQ0AIABB7uUSKAAANgCHASAAQeflEikAADcDgAEgASAAQYABaiAAQYoBaiAAQfYAaiABKAIAKAIgEQYAGiAAQdQANgIQIABBCGoiA0EANgIAIAMgAEEQaiIEKAIANgIEAkAgACgClAEiASAHKAIAayICQeMATgRAIAJBAmoQMyEEIAMoAgAhAiADIAQ2AgAgAgRAIAIgAygCBBEBAAsgAygCACIERQ0BCyAALQCPAQRAIARBLToAACAEQQFqIQQLIAcoAgAhAgNAIAEgAk0EQAJAIARBADoAACAAIAY2AgAgAEEQakGBwAAgABBpQQFHDQAgAygCACEBIANBADYCACABBEAgASADKAIEEQEACwwECwUgBCAAQfYAaiIBIAFBCmogAi0AABDIAiAAayAAai0ACjoAACAEQQFqIQQgAkEBaiECIAAoApQBIQEMAQsLENUBAAsQ1QEACyAAQYwCaiAAQYgCahD1AQRAIAUgBSgCAEECcjYCAAsgACgCjAIhAiAAKAKQASIBIAEoAgRBAWsiAzYCBCADQX9GBEAgASABKAIAKAIIEQEACyAHKAIAIQEgB0EANgIAIAEEQCABIAcoAgQRAQALIABBkAJqJAAgAguGGAEPfyMAQZAEayILJAAgCyAKNgKIBCALIAE2AowEAkAgACALQYwEahD1AQRAIAUgBSgCAEEEcjYCAEEAIQAMAQsgC0HWADYCTCALQegAaiIBIAtB8ABqNgIAIAEgC0HMAGoiESgCADYCBCALIAEiEygCACIONgJkIAsgDkGQA2o2AmAgEUIANwIAIBFBADYCCCALQUBrIg9CADcCACAPQQA2AgggC0E0aiIMQgA3AgAgDEEANgIIIAtBKGoiDUIANwIAIA1BADYCCCALQRxqIhJCADcCACASQQA2AgggAygCACEBIwBBEGsiAyQAIAsCfyACBEAgA0EEaiICIAEQuAMiASABKAIAKAIsEQIAIAsgAygCBDYAXCACIAEgASgCACgCIBECACANIAIQjAIgAhC/AhogAiABIAEoAgAoAhwRAgAgDCACEIwCIAIQvwIaIAsgASABKAIAKAIMEQAAOgBbIAsgASABKAIAKAIQEQAAOgBaIAIgASABKAIAKAIUEQIAIBEgAhCMAiACEL8CGiACIAEgASgCACgCGBECACAPIAIQjAIgAhC/AhogASABKAIAKAIkEQAADAELIANBBGoiAiABELkDIgEgASgCACgCLBECACALIAMoAgQ2AFwgAiABIAEoAgAoAiARAgAgDSACEIwCIAIQvwIaIAIgASABKAIAKAIcEQIAIAwgAhCMAiACEL8CGiALIAEgASgCACgCDBEAADoAWyALIAEgASgCACgCEBEAADoAWiACIAEgASgCACgCFBECACARIAIQjAIgAhC/AhogAiABIAEoAgAoAhgRAgAgDyACEIwCIAIQvwIaIAEgASgCACgCJBEAAAs2AhggA0EQaiQAIAkgCCgCADYCACAEQYAEcSEWIAsoAhghFCALLQBfIRcgCy0AWyEYIAstAFohGSAOIQRBACECA0ACQAJAAkACQCACQQRGDQAgACALQYwEahD1AQ0AQQAhAQJAAkACQAJAAkACQAJAIAtB3ABqIAJqLAAADgUBAAQDBQkLIAJBA0YNCAJ/IAAoAgAiASgCDCIDIAEoAhBGBEAgASABKAIAKAIkEQAADAELIAMtAAALwCEBIAcoAgghAyABQQBOBH8gAyABQf8BcUECdGooAgBBAXEFQQALBEAgC0EQaiAAELUDIBIgCywAEBCGAQwCCyAFIAUoAgBBBHI2AgBBACEADAkLIAJBA0YNBwsDQCAAIAtBjARqEPUBDQcCfyAAKAIAIgEoAgwiAyABKAIQ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AiAAKAIkIAAoAiAgAyAEEKkBIQIgACgCKCEBIABBADYCKCABBEAgASAAKAIsEQEACyAHEL8CGiAIEL8CGiANEL8CGiAAKALMASIBIAEoAgRBAWsiAzYCBCADQX9GBEAgASABKAIAKAIIEQEACyAAKALQASEBIABBADYC0AEgAQRAIAEgACgC1AERAQALIAsoAgAhASALQQA2AgAgAQRAIAEgCygCBBEBAAsgAEHAA2okACACDwsQ1QEAC+8DAQF/IwBBEGsiCiQAIAkCfyAABEAgAhC4AyEAAkAgAQRAIApBBGoiASAAIAAoAgAoAiwRAgAgAyAKKAIENgAAIAEgACAAKAIAKAIgEQIADAELIApBBGoiASAAIAAoAgAoAigRAgAgAyAKKAIENgAAIAEgACAAKAIAKAIcEQIACyAIIAEQjAIgARC/AhogBCAAIAAoAgAoAgwRAAA6AAAgBSAAIAAoAgAoAhARAAA6AAAgCkEEaiIBIAAgACgCACgCFBECACAGIAEQjAIgARC/AhogASAAIAAoAgAoAhgRAgAgByABEIwCIAEQvwIaIAAgACgCACgCJBEAAAwBCyACELkDIQACQCABBEAgCkEEaiIBIAAgACgCACgCLBECACADIAooAgQ2AAAgASAAIAAoAgAoAiARAgAMAQsgCkEEaiIBIAAgACgCACgCKBECACADIAooAgQ2AAAgASAAIAAoAgAoAhwRAgALIAggARCMAiABEL8CGiAEIAAgACgCACgCDBEAADoAACAFIAAgACgCACgCEBEAADoAACAKQQRqIgEgACAAKAIAKAIUEQIAIAYgARCMAiABEL8CGiABIAAgACgCACgCGBECACAHIAEQjAIgARC/AhogACAAKAIAKAIkEQAACzYCACAKQRBqJAALqAcBCX8gAiAANgIAIANBgARxIRUDQCAUQQRGBEAgDSgCBCANLQALIgRB/wBxIARBgAFxQQd2G0EBSwRAIAIgDRD0AkEBELoDIA0Q9QIgAigCABDLAzYCAAsgA0GwAXEiA0EQRwRAIAEgA0EgRgR/IAIoAgAFIAALNgIACwUCQAJAAkACQAJAAkAgCCAUaiwAAA4FAAEDAgQFCyABIAIoAgA2AgAMBAsgASACKAIANgIAIAZBICAGKAIAKAIcEQMAIQ8gAiACKAIAIhBBAWo2AgAgECAPOgAA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AgAgCkEEaiIBIAAgACgCACgCFBECACAGIAEQjAIgARC/AhogASAAIAAoAgAoAhgRAgAgByABEMMDIAEQ4wIaIAAgACgCACgCJBEAAAwBCyACEMQDIQACQCABBEAgCkEEaiIBIAAgACgCACgCLBECACADIAooAgQ2AAAgASAAIAAoAgAoAiARAgAMAQsgCkEEaiIBIAAgACgCACgCKBECACADIAooAgQ2AAAgASAAIAAoAgAoAhwRAgALIAggARDDAyABEOMCGiAEIAAgACgCACgCDBEAADYCACAFIAAgACgCACgCEBEAADYCACAKQQRqIgEgACAAKAIAKAIUEQIAIAYgARCMAiABEL8CGiABIAAgACgCACgCGBECACAHIAEQwwMgARDjAhogACAAKAIAKAIkEQAACzYCACAKQRBqJAALuwcBCX8gAiAANgIAIANBgARxIRUgB0ECdCEWA0AgFEEERgRAIA0oAgQgDS0ACyIEQf8AcSAEQYABcUEHdhtBAUsEQCACIA0Q9AJBARDFAyANEIYDIAIoAgAQ0AM2AgALIANBsAFxIgNBEEcEQCABIANBIEYEfyACKAIABSAACzYCAAsFAkACQAJAAkACQAJAIAggFGosAAAOBQABAwIEBQsgASACKAIANgIADAQLIAEgAigCADYCACAGQSAgBigCACgCLBEDACEHIAIgAigCACIPQQRqNgIAIA8gBzYCAAwDCyANKAIEIA0tAAsiB0H/AHEgB0GAAXFBB3YbRQ0CIA0oAgAgDSANLQALQYABcUEHdhsoAgAhByACIAIoAgAiD0EEajYCACAPIAc2AgAMAgsgDCgCBCAMLQALIgdB/wBxIAdBgAFxQQd2G0UhByAVRQ0BIAcNASACIAwQ9AIgDBCGAyACKAIAENADNgIADAELIAIoAgAhFyAEIBZqIgQhBwNAAkAgBSAHTQ0AIAZBwAAgBygCACAGKAIAKAIMEQQARQ0AIAdBBGohBwwBCwsgDkEASgRAIAIoAgAhDyAOIRADQAJAIAQgB08NACAQRQ0AIBBBAWshECAHQQRrIgcoAgAhESACIA9BBGoiEjYCACAPIBE2AgAgEiEPDAELCwJAIBBFBEBBACERDAELIAZBMCAGKAIAKAIsEQMAIREgAigCACEPCwNAIA9BBGohEiAQQQBKBEAgDyARNgIAIBBBAWsh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dEHAoxNqKAIABSABCws8AANAIAEgAkZFBEAgASABKAIAIgBB/wBNBH8gAEECdEHAoxNqKAIABSAACzYCACABQQRqIQEMAQsLIAILKgADQCABIAJGRQRAIAMgASwAADYCACADQQRqIQMgAUEBaiEBDAELCyACCw4AIAEgAiABQYABSRvACzUAA0AgASACRkUEQCAEIAEoAgAiACADIABBgAFJGzoAACAEQQFqIQQgAUEEaiEBDAELCyACCwkAIAAQrwQQNAsoAQF/IABBnLsTNgIAAkAgACgCCCIBRQ0AIAAtAAxFDQAgARA0CyAACx8AIAFBAE4EfyABQf8BcUECdEHArxNqKAIABSABC8ALOwADQCABIAJGRQRAIAEgASwAACIAQQBOBH8gAEECdEHArxNqKAIABSAACzoAACABQQFqIQEMAQsLIAILHwAgAUEATgR/IAFB/wFxQQJ0QcCjE2ooAgAFIAELwAs7AANAIAEgAkZFBEAgASABLAAAIgBBAE4EfyAAQQJ0QcCjE2ooAgAFIAALOgAAIAFBAWohAQwBCwsgAgsqAANAIAEgAkZFBEAgAyABLQAAOgAAIANBAWohAyABQQFqIQEMAQsLIAILDAAgAiABIAFBAEgbCzQAA0AgASACRkUEQCAEIAMgASwAACIAIABBAEgbOgAAIARBAWohBCABQQFqIQEMAQsLIAILCQAgABC4BBA0C74BAQR/IABBiLsTNgIAIABBCGohAwNAIAIgACgCDCAAKAIIIgFrQQJ1SQRAIAEgAkECdGooAgAiAQRAIAEgASgCBEEBayIENgIEIARBf0YEQCABIAEoAgAoAggRAQALCyACQQFqIQIMAQsLIABBmAFqEL8CGiMAQRBrIgEkACABIAM2AgwgASgCDCICKAIABEAgAhDWAyABKAIMIgJBEGogAigCACIDIAIoAgggA2tBAnUQ2wMLIAFBEGokACAACwMAAAu9AgEDfyMAQRBrIggkACACQe7///8HIAFrTQRAIAAoAgAgACAALQALQYABcUEHdhshCSAIQQRqIAFB5v///wNNBH8gCCABQQF0NgIMIAggASACajYCBCAIQQxqIgIgCEEEaiIKIAooAgAgAigCAEkbKAIAIgJBC08EfyACQRBqQXBxIgIgAkEBayICIAJBC0YbBUEKC0EBagVB7////wcLEI4C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AyAEIAUgACgCACgCFBEMAAuaAQAgAEEBOgA1AkAgACgCBCACRw0AIABBAToANAJAIAAoAhAiAkUEQCAAQQE2AiQgACADNgIYIAAgATYCECADQQFHDQIgACgCMEEBRg0BDAILIAEgAkYEQCAAKAIYIgJBAkYEQCAAIAM2AhggAyECCyAAKAIwQQFHDQIgAkEBRg0BDAILIAAgACgCJEEBajYCJAsgAEEBOgA2CwuKAgAgACABKAIIIAQQxgQEQAJAIAEoAgQgAkcNACABKAIcQQFGDQAgASADNgIcCw8LAkAgACABKAIAIAQQxgQEQAJAIAIgASgCEEcEQCABKAIUIAJHDQELIANBAUcNAiABQQE2AiAPCyABIAM2AiACQCABKAIsQQRGDQAgAUEAOwE0IAAoAggiACABIAIgAkEBIAQgACgCACgCFBEMACABLQA1BEAgAUEDNgIsIAEtADRFDQEMAwsgAUEENgIsCyABIAI2AhQgASABKAIoQQFqNgIoIAEoAiRBAUcNASABKAIYQQJHDQEgAUEBOgA2DwsgACgCCCIAIAEgAiADIAQgACgCACgCGBENAAsLMwAgACABKAIIQQAQxgQEQCABIAIgAxDNBA8LIAAoAggiACABIAIgAyAAKAIAKAIcEQoAC10BAX8gACgCECIDRQRAIABBATYCJCAAIAI2AhggACABNgIQDwsCQCABIANGBEAgACgCGEECRw0BIAAgAjYCGA8LIABBAToANiAAQQI2AhggACAAKAIkQQFqNgIkCwsaACAAIAEoAghBABDGBARAIAEgAiADEM0ECwtEACAAIAICf0EAIANFDQAaIAFBCHUiAiABQQFxRQ0AGiACIAMoAgBqKAIACyADaiAEQQIgAUECcRsgACgCACgCHBEKAAt6AQJ/IAAgASgCCEEAEMYEBEAgASACIAMQzQQPCyAAKAIMIQUgACgCECAAKAIUIAEgAiADEM8EAkAgAEEYaiIEIABBEGogBUEDdGoiAE8NAANAIAQoAgAgBCgCBCABIAIgAxDPBCABLQA2DQEgBEEIaiIEIABJDQALCwviBAEFfyMAQUBqIgUkAAJAIAFB3PUTQQAQxgQEQCACQQA2AgBBASEEDAELAn8gAC0ACEEYcQRAIAAgAUEBEMYEDAELAkAgAUUNACABQdDzExDIBCIGRQ0AIAAgASAG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AEGJOAsX6NUjtBnUP53gkOw25Ag9AAAAAABA5z8AQak4CxfIccKNcdQ/ddZnCc4nL70AAAAAACDnPwBByTgLFzAXnuDJ1D+k2AobiSAuvQAAAAAAAOc/AEHpOAsXoDgHriLVP1nHZIFwvi49AAAAAADg5j8AQYk5CxfQyFP3e9U/70Bd7u2tHz0AAAAAAMDmPwBBqTkL+7MSYFnfvdXVP9xlpAgqCwq9UHJvcGFnYXRlZFBvc2l0aW9uUHJvcGVydHkAcmVtb3ZlRW50aXR5AGluZmluaXR5AGdldFZlbG9jaXR5AFBvc2l0aW9uUmVnaXN0cnkARmVicnVhcnkASmFudWFyeQBKdWx5AFRodXJzZGF5AFR1ZXNkYXkAV2VkbmVzZGF5AFNhdHVyZGF5AFN1bmRheQBNb25kYXkARnJpZGF5AE1heQAlbS8lZC8leQAlMDE2bGx4AGFycmF5X2luZGV4AGVwaGVtZXJpc19zdGFydF9pZHgALSsgICAwWDB4AC0wWCswWCAwWC0weCsweCAweABOb3YAVGh1AEF1Z3VzdAB1bnNpZ25lZCBzaG9ydABlcGhlbWVyaXNfc3RhcnQAdW5zaWduZWQgaW50AE9jdABmbG9hdABTYXQAdWludDY0X3QAU3ViY2xhc3MAZ2V0Q292ZXJhZ2VQb3NpdGlvbnMAc2VtaV9taW5vcl9heGlzAHNlbWlfbWFqb3JfYXhpcwBBcHIAdmVjdG9yAGdldFZlbG9jaXR5UG9pbnRlcgBPY3RvYmVyAE5vdmVtYmVyAFNlcHRlbWJlcgBEZWNlbWJlcgB1bnNpZ25lZCBjaGFyAE1hcgBhbHRwAGVwaGVtZXJpc19zdG9wAHVuaXhfdGltZXN0YW1wAGVwaGVtZXJpc19zdGVwAFNlcAAlSTolTTolUyAlcABpbmNsbwBlY2NvAFN1bgBKdW4Ac3RkOjpleGNlcHRpb24AZ2V0UG9zaXRpb24ARW50aXR5Q29sbGVjdGlvbgBNb24AbmFuAEphbgBSZWNlaXZlZDogJXNcbgByYWRpdXNlYXJ0aGttAEp1bABib29sAHJlbW92ZUFsbABBcHJpbABlbXNjcmlwdGVuOjp2YWwARnJpAGJhZF9hcnJheV9uZXdfbGVuZ3RoAE1hcmNoAEF1ZwB1bnNpZ25lZCBsb25nAHRlcm1pbmF0aW5nAHN0ZDo6d3N0cmluZwBiYXNpY19zdHJpbmcAc3RkOjpzdHJpbmcAc3RkOjp1MTZzdHJpbmcAc3RkOjp1MzJzdHJpbmcAaW5mACU0ZC0lMmQtJTJkVCUyZDolMmQ6JWxmACUuMExmACVMZgBzaXplAHRydWUAVHVlAHVwZGF0ZQBmYWxzZQB0YWtlQmFzZQBKdW5lAGdldFBvc2l0aW9uSW5SZWZlcmVuY2VGcmFtZQBnZXROYW1lAGRvdWJsZQB2aXNpYmxlAGFwb2dlZQBwZXJpZ2VlAHBlcmlvZAB2b2lkAG5vcmFkX2NhdF9pZAB0ZXJtaW5hdGVfaGFuZGxlciB1bmV4cGVjdGVkbHkgcmV0dXJuZWQAV2VkAHN0ZDo6YmFkX2FsbG9jAHBlcmlvZF9zZWMARGVjAEZlYgBhbHRhAGY2Y2FlMTZkNjcxNGFlODc5N2RjYzY5NDI0NTgwYzJkMTczYjMyOWJmY2YwNDYyZjQ0MTA3YjlmMzBkNDA4ZTYxY2EyMDYxMjBjZjY1YzI1YWE1OGRiNWIzNWJhNGQ0YWRhNjQwZDIxNzJkYzc5NDU0ODdhNDdhZmIzNzM4ZTEzYjUxY2M5Y2M3NTk4NGRjMTg2N2IyZjgwNTc1MjE2Mzk1MTM4OGE1OTA1YWI2MGE2OTlmY2ZlMzE5NDFhMjZmNzAwODYxZjM1OTlkY2E0NTM4NmMwOTcyMGNlYTI2NTFlYzM5MWFkNDNkMjZkNmQ4YQBFQ0NFTlRSSUNJVFkATUVBTl9BTk9NQUxZACVhICViICVkICVIOiVNOiVTICVZAFBPU0lYAE1FQU5fTU9USU9OX0RPVABNRUFOX01PVElPTl9ERE9UAEdNVAAlSDolTTolUwBBUkdfT0ZfUEVSSUNFTlRFUgBCU1RBUgBFTEVNRU5UX1NFVF9OTwBNRUFOX01PVElPTgBJTkNMSU5BVElPTgBOQU4AUE0AYWRkT01NAEdNAEFNAExDX0FMTABSRVZfQVRfRVBPQ0gATEFORwBJTkYARVBIRU1FUklTX1RZUEUAQ0xBU1NJRklDQVRJT05fVFlQRQBSQV9PRl9BU0NfTk9ERQBPQkpFQ1RfSUQATk9SQURfQ0FUX0lEAEMAZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8c2hvcnQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIHNob3J0PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxpbnQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIGludD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8ZmxvYXQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVpbnQ4X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludDhfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dWludDE2X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludDE2X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVpbnQ2NF90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxpbnQ2NF90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzx1aW50MzJfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8aW50MzJfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8Y2hhcj4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgY2hhcj4Ac3RkOjpiYXNpY19zdHJpbmc8dW5zaWduZWQgY2hhcj4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8c2lnbmVkIGNoYXI+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGxvbmc+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIGxvbmc+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGRvdWJsZT4ARmZoYTBmNmRPZENmNWJqZENhQ2JRZElnWGRRZHRlQWNNYUFiVWg1ZU9oRGZrYUhiVGNHZ1ZjMGVVZHdiMWdaZUJhUmhnZGthTWZ6ZllneGJEaGdmSWRQYUdoemhNZzViRGNUZFllOGVLZkJiRWNZY1ZlbGFnZnVoU2FnYU1ndWRWZzFhSWhwY0JnamNWY1NjQWRTZGxiVGVDaFJjWWJHZVZmaWJjaDBkRmgxZU1ocmhOZEJmQWJ4YUZjZ2R4Z1hmTGd5ZkJlUWdXZlNkQmJWaEloQ2VjZm5nTWVSZ01ldWRIZUFlWmJiYVhjQmFNZ1RiTWZpZW9iOGFJY2dic2ZyZURhVWg0ZlVjVWNTZElmTmVNaERoY2JVZEFiMWFNZjVlTWdGYk1iTmRXZFFjVWZZYUpnRGhNZzJiTWdRYzRoQ2REZnhic2N6ZE9lUWIwZjJjUGNDZGdjUmhHZkZjWmdZYkxja2VvY0RlTGJsY2RlU2ZLY1FjWWUxZlVnZ2NFY3BmVWN3Y2tiV2ZCZWxmWWhuY05mQmRkY1RkS2Z6YVFmUWdNaFJiWWZNZlZoeWQ4Y2dnVWFGY2tkZ2NWZ1NiQWJuZUpoemJFYVRnTGJoaHdjR2RXZDFjd2FUZUVhemhJaHFkUGRDaEljTGJLaHdnMWJPaEZnRmdFZ2loRGdUYkFhM2dGZkFjTmJUYk9kVGNCaFRhRGVWYmtoRmVHYkNnUWJ6YU5hamdFYU9hQWRnYjhoYmVNY3pla2JOaE5namV3Zm9lRWVSZGhnV2VXYUNkNWdLZUFieWM1YVhlVWVpZGtoR2NOYlZmSWhCYktnVmhNZEplRmNnZVpkV2VKZ3piUWhYYVVneWVzYjBiRWREZkVkV2FEZEZoY2d2YUlnRmFCaFpmSWRGZ1VoZ2FKZHlmY2d4ZUVheWI0ZGNoQmNsYXRlY2dFZnhoTWR5YUtoamZ3ZWlmQ2Z5YnNhTmhUaGhhUmhSZUlhZ2QwZXdkTmZ4ZVFnRGJVZXpia2R3Z1Vnd2ExYVpiQmhSZGdoa2JNZXpoWWF4Z0RiZ2FJZVBkR2V6ZE1hNWZEZVRmWWQ4Y0tlQmhFaFlmVmJsZWdhdWhTY2doTWV1Y1ZnMWFJZ3BlQmNqYVZiU2dBYlNibGVUaENmUmVZZEdjVmFpaGNmMGdGZjFoTWFyY05kQmdBYXhhRmhnaHhoWGVMZnljQmRRZldhU2hCZVZoSWFDZmNlbmdNZFJoTWV1ZUhkQWhaZWJjWGVCZ01mVGJNZGlkb2Q4aElhZ2ZzYXJjRGVVZTRjVWFVY1NkSWNOZE1nRGNjYlVnQWgxZk1mNWdNY0ZmTWJOZVdjUWNVaFllSmREYk1hMmVNYVFoNGVDZERmeGRzaHplT2ZRaDBkMmdQZENlZ2NSZEdiRmhaY1ljTGJrZm9kRGRMZGxmZGhTZktlUWJZZjFkVWRnaEVocGRVYndia2NXZ0JnbGFZaG5kTmhCZ2RjVGVLZXpiUWRRaE1jUmNZY01kVmZ5YThjZ2RVZ0Zha2dnYVZiU2VBaG5nSmR6ZUViVGdMY2hid2ZHYVdnMWN3aFRkRWV6YklocWNQYUNoSWdMZ0tmd2cxZ09kRmNGZEVmaWNEZVRlQWczZ0ZnQWVOYVRoT2VUZUJkVGZEaFZka2hGZEdjQ2VRZHpoTmRqZEVhT2FBZWdlOGFiZE1memNraE5oTmhqYXdob2hFaFJnaGVXZldhQ2U1YkthQWR5ZTVmWGJVY2lna2JHZE5mVmJJZEJnS2dWZU1iSmRGZGdjWmhXY0poemVRYlhkVWh5ZXNmMGFFaERmRWFXaERlRmVjYnZjSWVGZkJiWmdJYUZiVWdnZEpoeWdjZ3hkRWV5ZjRiY2VCZ2xldGRjZEVjeGdNZ3loS2NqZXdkaWJDYnlmc2ZOZFRiaGVSYVJiSWhnZjBhd2JOZXhnUWJEY1VhemJrZndiVWd3ZDFnWmFCY1JoZ2VrYk1lemJZYnhoRGRnaEloUGdHZnpkTWI1ZkRkVGRZYThnS2FCY0VjWWNWZ2xoZ2d1ZlNoZ2NNYnVkVmIxZElhcGVCY2poVmFTYUFkU2dsZlRoQ2JSaFljR2VWZWlhY2UwZUZiMWJNYXJmTmdCZEFieGhGZGdheGRYZExheWZCZ1FmV2ZTaEJoVmZJZ0NkY2JuZ01iUmdNZ3VkSGRBYlplYmJYY0JoTWVUYU1maWFvZDhoSWdnZ3NlcmJEZFVnNGJVZVVjU2JJZk5iTWVEZWNjVWRBaDFoTWE1ZE1oRmJNZk5hV2FRZ1VmWWhKY0RkTWMyaE1jUWg0Y0NhRGd4aHNkemNPaFFlMGMyaFBlQ2ZnYVJoR2NGZVplWWJMY2tob2NEYUxhbGdkaFNjS2NRZVlmMWJVZ2dmRWFwYVVmd2VrZVdhQmVsZllnbmhOZEJmZGZUaEtnemVRY1FjTWJSZFliTWdWaHlhOGJnZlVhRmFrYWdhVmhTZEFnbmhKYnpoRWFUaExoaGZ3YkdjV2gxY3diVGJFZ3pmSWhxZ1BiQ2hJY0xkS2V3ZzFhT2FGaEZnRWFpZ0RnVGNBaDNhRmhBaE5kVGNPZlRoQmJUYkRnVmZrZEZjR2JDaFFkemdOZWpiRWRPaEFmZ2Y4Z2JnTWF6YWtoTmVOZ2pod2RvZ0VnUmZoYldjV2FDYTVjS2JBZ3lnNWRYY1VjaWRrYkdoTmVWZUlmQmVLY1ZiTWJKYUZiZ2VaZ1dnSmh6Y1FoWGdVZHlkc2YwZUVlRGFFZVdmRGNGYWNhdmdJY0ZoQmVaYklnRmJVYmdmSmh5YmNmeGJFZHloNGdjYkJlbGR0ZGNlRWZ4aE1jeWJLZWpjd2NpZkNneWVzZk5lVGFoaFJlUmNJYmdlMGh3ZU5meGRRaERnVWV6ZWtmd2RVZndhMWRaZ0JiUmVnaGtiTWV6ZVlheGNEY2dkSWdQY0diemZNYzVhRGNUZlllOGZLYUJmRWVZYVZlbGFnZ3VlU2JnZE1ldWNWZjFjSWJwZEJnamJWZFNiQWVTYWxmVGVDZlJnWWJHY1ZmaWFjZzBlRmMxZ01kcmdOaEJiQWR4Z0ZmZ2Z4ZlhjTGV5YkJnUWVXZlNmQmhWZUljQ2ZjZW5kTWRSZU1mdWFIY0FjWmZiZ1hlQmJNYVRnTWFpZG9jOGFJY2dhc2ZyYkRhVWc0YlViVWRTZklkTmVNaERjY2dVZUFoMWZNYjVoTWZGZk1oTmJXZFFmVWNZZ0plRGJNYjJmTWRRYzRjQ2VEZXhkc2R6YU9kUWIwZzJoUGVDaGdjUmJHaEZkWmhZYkxka2dvYkRnTGdsY2RjU2FLYVFmWWgxaFVnZ2JFYXBoVWF3ZmtkV2FCYmxnWWJuZ05lQmNkYlRlS2V6YVFoUWNNYlJkWWdNY1ZheWM4ZGdlVWZGY2tkZ2RWYVNoQWNuaEpkemNFYVRlTGJoZHdhR2hXZDFod2NUZUViemRJZXFjUGVDZklnTGFLYXdmMWFPY0ZlRmRFZWlkRGVUaEFnM2ZGZ0FmTmRUZU9nVGZCZlRhRGJWYmtkRmZHZENjUWV6Z05oamdFZ09lQWZnZzhlYmdNYnpma2NOZ05mamR3YW9lRWVSZ2hmV2ZXZkNjNWdLYkFjeWM1Z1hoVWNpYmthR2VOYlZnSWhCYUthVmZNZEpjRmJnaFpjV2FKZXpjUWNYZVVjeWZzZzBkRWhEYkVhV2JEZEZlY2h2ZElnRmRCaFpjSWVGY1ViZ2JKZHlhY2Z4aEVoeWY0aGNnQmFsZ3RiY2FFYXhhTWR5Z0thamV3YmljQ2Z5ZHNlTmVUZGhmUmhSYUloZ2MwYndmTmF4aFFiRGdVZnpma2R3ZFVld2ExYVplQmNSZmdia2RNYXpjWWN4Y0RiZ2NJZ1BjR2F6ZE1jNWhEZ1RkWWg4Y0tkQmFFZVlnVmVsZ2dodWRTZGdiTWZ1ZFZnMWVJZXBlQmVqZ1ZiU2FBY1NhbGZUZ0NlUmJZY0dkVmJpaGNmMGFGZzFjTWdyZU5lQmdBZnhlRmVnZHhhWGVMYXlkQmVRZldoU2VCZ1ZnSWFDZGNibmFNZlJjTWd1aEhiQWRaYWJkWGhCYk1iVGRNZGlnb2E4YUloZ2JzYnJhRGhVYzRnVWNVZFNnSWJOYU1lRGdjZ1VlQWQxY01kNWhNZUZlTWhOaFdoUWdVZ1lhSmFEY01mMmZNZ1FjNGhDZERjeGJzZXphT2ZRaDBnMmdQZUNkZ2NSYUdkRmJaYVlhTGdrZG9kRGVMZmxjZGZTZEtmUWJZaDFhVWFnYkVmcGVVY3dha2FXZEJlbGRZZG5lTmZCaGRlVGhLY3pkUWVRaE1iUmNZZE1oVmZ5YjhlZ2dVZkZia2FnYlZnU2NBZm5hSmZ6ZUVmVGRMZmhjd2RHZldmMWd3Z1RnRWd6aElncWNQZ0NmSWNMZUtkd2cxYU9oRmRGYkVlaWZEZlRiQWUzYUZhQWdOZVRkT2dUZUJiVGhEY1Zla2NGaEdlQ2dRZnpnTmVqZUVoT2JBZ2diOGRiaE1jemZrZU5hTmNqYXdob2NFZ1JlaGVXZ1diQ2U1ZktkQWd5ZjVnWGRVZWlna2hHZk5iVmhJZEJjS2RWZE1mSmNGYmdlWmFXaEplemFRYlhnVWh5Y3NkMGhFZERkRWZXZERjRmJjaHZjSWJGaEJkWmVJYUZoVWhnZEpkeWVjYXhnRWJ5ZjRmY2RCZGxjdGZjZkVleGdNZ3llS2hqYndlaWFDYnllc2ROY1RmaGdSY1JnSWJnaDBid2JOaHhhUWhEY1ViemNrY3dnVWV3YTFiWmVCaFJjZ2hrZE1oemZZaHhhRGdnZEljUGdHYXphTWQ1ZURnVGZZYThnS2NCZkVjWWdWZGxmZ2V1ZFNhZ2FNZ3ViVmQxYUllcGFCY2piVmRTZUFiU2dsZ1RnQ2ZSY1lmR2FWYWlkY2cwY0ZkMWJNYXJmTmNCZkFoeGRGY2djeGZYZExmeWNCYVFhV2NTZ0JlVmZJZENiY2JuZk1iUmVNY3ViSGJBaFpkYmRYZkJmTWhUYk1haWdvZThkSWJnZHNmcmVEYVViNGVVZlVjU2ZJZ05mTWZEZGNmVWNBYzFmTWY1aE1iRmhNYU5mV2JRZFVlWWFKZURiTWcyYU1iUWI0ZkNhRGJ4YXNnemdPZ1FnMGgyZVBnQ2hnY1JhR2hGYlpkWWZMZWtlb2VEZUxhbGZkZFNjS2RRZ1lmMWNVaGdnRWJwZ1Vjd2JraFdnQmZsaFllbmFOZ0JiZGNUZUtkemNRaFFjTWhSY1lhTWhWZXloOGdnZ1ViRmRraGdoVmJTZ0FlbmJKYXpmRWVUYkxiaGR3ZUdiV2YxZndhVGJFZHpiSWVxZVBmQ2FJZExoS2V3YzFoT2RGY0ZkRWdpZURhVGNBZzNlRmhBY05nVGFPZFRiQmVUY0RlVmdrZEZmR2ZDZ1FhemdOZ2plRWNPY0FhZ2Q4ZmJiTWR6YmtiTmJOZGpod2VvYkVkUmJoaFdiV2NDYzVlS2JBYnllNWVYYVVhaWVraEdkTmJWY0lkQmZLZlZjTWdKYUZhZ2JaaFdlSmV6Y1FoWGZVYnloc2UwZEVhRGRFY1dmRGJGYWNkdmhJZ0ZkQmJaZUlnRmFVY2dhSmR5aGNieGdFY3loNGhjZ0JhbGR0Z2NlRWZ4ZU1ieWVLY2pjd2hpaENheWFzY05mVGJoaFJiUmRJZWdlMGZ3aE5jeGFRYkRkVWh6Y2tkd2hVZXdiMWVaZkJhUmVnZmtmTWR6YVljeGhEZmdlSWRQYUdnemNNZDVnRGdUaFllOGRLYUJmRWJZZlZibGRnZHVoU2dnZ01ndWRWYTFiSWNwZUJlamJWZFNhQWhTZ2xmVGRDZlJhWWhHZlZhaWZjYjBmRmExaE1mcmdOZkJoQWJ4Y0ZmZ2J4ZFhoTGh5ZEJnUWFXZFNhQmZWYklnQ2RjY25jTWFSYU1kdWVIZ0FhWmZiaFhoQmNNYlRjTWNpaG9iOGNJZGdhc2hyY0RkVWM0ZFVmVWJTZkllTmJNYURmY2hVYUFoMWhNZjVhTWdGZk1jTmVXYlFoVWdZaEpoRGFNYjJhTWdRZTRnQ2NEZXhic2d6Y09iUWQwZTJjUGdDZWdlUmJHYUZoWmhZZUxna2JvaERmTGZsZWRoU2ZLYlFiWWgxZVVoZ2RFY3BiVWZ3ZWthV2dCZGxmWWhuY05oQmhkaFRhS2d6YVFhUWFNaFJhWWFNYVZleWM4Z2dhVWRGaGtkZ2ZWZFNoQWRuYkpnemdFYVRhTGdoY3diR2NXZDFld2VUZUVmemhJaHFjUGNDYklhTGhLZXdiMWRPZ0ZkRmNFY2lnRGRUZEFmM2RGZEFhTmdUYU9iVGhCYVRjRGRWYmtkRmhHZkNiUWN6Z05namhFY09oQWVnZDhhYmNNZHpka2ROYk5jamF3Y29iRWZSYWhnV2ZXZUNkNWVLZEFkeWU1ZlhhVWZpY2tmR2JOYVZkSWhCZkthVmhNZkpkRmhnaFplV2NKZ3plUWhYaFVheWFzZDBkRWZEZUVoV2JEYUZjY2N2Y0lhRmZCZFpnSWNGaFVnZ2ZKZ3lhY2V4YkVmeWM0aGNoQmFsZHRlY2dFYXhkTWZ5Y0toamJ3YmliQ2R5aHNkTmNUYWhnUmNSY0llZ2cwaHdmTmN4aFFiRGNVYnpoa2d3Y1Vnd2YxZFpnQmRSZmdma2hNYnpjWWZ4Z0RoZ2JJZlBoR2V6aE1mNWdEY1RiWWQ4ZUtlQmFFYVlmVmdsaGdkdWFTZWdhTWR1YlZkMWNJaHBhQmFqZ1ZlU2RBZVNnbGZUYUNmUmNZaEdhVmJpY2NoMGhGZzFiTWZyYU5nQmJBaHhmRmhnYXhjWGNMYXlkQmdRYldlU2VCZ1ZiSWhDZGNnbmVNY1JnTWd1ZEhkQWNaYWJkWGJCZE1hVGZNaGlob2E4YUlhZ2VzY3JiRGNVZTRkVWJVYVNoSWdOYk1nRGRjY1ViQWMxZ01lNWdNZUZhTWhOZ1dmUWVVYllmSmdEY01nMmdNZlFjNGFDaERoeGVzaHpkT2JRYTBiMmRQZ0NmZ2hSY0djRmhaZ1liTGdraG9lRGRMZmxnZGJTYUtiUWNZZDFkVWJnZkVhcGVVaHdia2hXYkJibGFZZG5mTmZCZ2RnVGNLYXpoUWdRYk1oUmFZYU1jVmh5ZzhiZ2RVZEZia2VnZlZiU2NBYW5mSmJ6ZEVmVGdMZ2hmd2FHZFdlMWd3ZVRjRWF6YklkcWFQZkNoSWVMZEtld2cxZE9mRmFGaEVnaWhEYlRnQWEzYUZhQWdOY1RmT2JUZEJmVGFEZ1Zha2dGZEdkQ2JRYnpmTmRqZEViT2NBZ2dmOGViaE1lemhrZE5oTmVqZXdhb2ZFZ1JlaGVXaFdnQ2M1Y0tmQWd5ZTVhWGZVY2loa2dHZE5hVmZJZUJmS2VWYU1lSmNGYWdnWmNXaEplemJRZVhoVWh5Z3NoMGdFZ0RmRWZXY0RlRmJjY3ZhSWFGZ0JjWmZJZkZkVWNnZEpoeWdjY3hjRWR5YjRlY2dCZmxmdGJjZ0VieGdNZHlnS2NqZ3dnaWVDY3lic2JOYlRjaGFSaFJkSWdnYzBhd2VOYnhhUWdEY1VoemZrZXdhVWd3YzFkWmFCYlJiZ2ZrZE1lemJZZ3hoRGRnaEliUGNHYnpkTWQ1Z0RnVGVZZDhoS2VCaEVnWWVWZGxiZ2Z1aFNiZ2FNY3VhVmUxZkllcGRCYWpnVmVTZUFlU2dsaFRjQ2JSYlloR2NWZGljY2gwZUZlMWhNaHJhTmVCZ0FheGVGZmdoeGZYZExmeWRCYVFjV2hTZkJlVmdJYkNhY2huZ01iUmRNYXVoSGRBYVpjYmFYYUJoTWZUY01naWFvYThoSWNnZHNkcmZEZFVmNGRVY1VlU2NJaE5hTWZEYWNmVWhBZTFoTWM1ZU1nRmFNZE5iV2VRaFVlWWRKZURjTWEyZk1kUWE0ZENmRGV4aHNhemNPZlFlMGIyYlBnQ2VnZ1JjR2NGZFpkWWVMZ2tib2JEYUxmbGFkZ1NjS2RRYlloMWNVaGdhRWhwZ1Vhd2VrYVdmQmhsYVlnbmNOZEJoZGVUZEtnemhRZVFmTWNSaFlnTWRWZnlmOGRnZlViRmZraGdoVmdTY0FmbmdKYXpjRWNUY0xoaGJ3Y0doV2IxZXdkVGFFZ3poSWZxYVBkQ2NJZ0xoS2h3ZTFjT2hGYUZnRWdpZURlVGNBYjNjRmVBY05kVGFPY1RhQmJUZERkVmdrYUZnR2FDYVFiemFOYmpnRWZPZUFlZ2U4YWJlTWJ6ZGtmTmROaGpld2ZvYUVmUmZoZ1dlV2hDZjVlS2NBZXliNWRYY1VhaWZrY0djTmZWYkloQmJLZFZiTWJKYkZlZ2haZldlSmJ6ZFFmWGdVYXlic2EwaEVoRGhFaFdlRGFGY2NhdmZJYkZkQmVaYUljRmFVaGdjSmF5aGNieGRFZnloNGZjYkJnbGd0Z2NiRWJ4Z01meWdLZWpld2VpZENjeWhzYk5oVGNoaFJhUmZJZ2djMGd3aE5leGZRY0RhVWh6Y2tld2RVZ3doMWhaY0JhUmhnZWthTWJ6Z1lieGNEZGdmSWNQZkdkemdNZjVjRGNUYlllOGZLZ0JjRWFZY1ZobGdnaHVmU2JnYU1idWVWZDFhSWJwaEJoamRWaFNiQWVTZ2xmVGJDZFJjWWVHY1ZnaWZjZjBnRmExaE1hcmFOYUJjQWJ4YkZnZ2V4ZFhjTGJ5aEJiUWRXZVNmQmJWZ0loQ2RjaG5oTWdSZU1idWVIaEFhWmhiYlhoQmhNaFRmTWdpYm9iOGdJZmdic2NyZURmVWg0ZFVoVWRTZUlnTmVNZERoY2NVZUFnMWVNZzVoTWRGZU1jTmFXaFFlVWRZZEpmRGdNZDJnTWRRYTRkQ2NEY3hic2Z6Zk9hUWYwZTJkUGJDZGdjUmZHZEZkWmRZZUxka2dvYURlTGhsZGRjU2FLZFFlWWQxaFVjZ2JFZXBjVWJ3Z2tnV2FCZWxkWWVuYU5kQmdkYlRoS2F6ZFFoUWdNYVJlWWVNaFZieWE4YmdnVWZGYmthZ2NWY1NnQWZuZEplemJFZFRjTGRoaHdmR2VXZDFhd2RUY0VoemZJaHFkUGhDY0liTGZLZXdmMWdPYkZmRmdFY2lmRGhUaEFjM2RGaEFhTmdUYk9lVGVCYVRiRGhWZ2tnRmFHZkNiUWJ6Zk5kamdFYk9mQWFnZzhlYmJNZnpma2ROYk5oamR3aG9nRWNSaGhiV2VXY0NjNWRLZEFkeWU1YVhoVWVpYmtjR2ZOZFZjSWNCZktkVmFNZUpnRmFnZVphV2RKZ3plUWhYaFVmeWZzZDBjRWhEYkVkV2ZEZUZhY2Z2Z0lmRmZCY1pkSWhGZlVnZ2FKY3lkY2R4aEVneWg0YmNmQmRsZnRnY2FFZnhhTWZ5ZUtlamR3ZWllQ2V5ZHNjTmFUZGhnUmdSZ0loZ2IwYndoTmV4ZFFoRGdVZHpka2J3YVVjd2UxZFpjQmZSYmdma2ZNYnpiWWV4Y0RiZ2JJZVBlR2J6aE1mNWJEY1RiWWQ4aEthQmhFY1ljVmRsZmdhdWZTY2djTWh1Z1ZlMWdJY3BlQmdqZFZlU2JBZVNjbGVUY0NlUmRZZEdmVmVpaGNlMGhGZDFiTWFyZ05hQmNBZnhhRmRnZXhjWGhMYnlhQmFRYVdmU2FCYlZlSWVDZ2NlbmhNZFJlTWF1ZEhiQWFaYWJnWGJCaE1iVGJNY2ljb2M4aElhZ2JzYXJhRGFVZzRkVWNVaFNjSWNOY01iRGFjaFVhQWQxZU1hNWdNYkZoTWNOYldoUWZVZllhSmdEY01hMmVNZVFoNGFDZURjeGJzYXplT2dRZzBoMmJQZkNjZ2dSZUdnRmFaaFloTGdraG9mRGVMY2xnZGdTZ0thUWdZZTFiVWJnaEVhcGdVZXdoa2NXYkJobGZZZW5jTmhCYWRnVGZLZ3poUWRRY01kUmNZZ01kVmh5aDhlZ2dVYkZoa2JnY1ZoU2ZBZG5nSmR6Z0ViVGRMZGhmd2VHYVdlMWZ3Z1RhRWN6ZkljcWRQY0NmSWJMaEtid2MxZ09hRmFGYkVmaWdEY1RiQWYzY0ZlQWhOaFRkT2FUZkJiVGNEY1Zla2RGZEdmQ2ZRZXpiTmJqZkVlT2JBZ2dmOGdiYU1nemJrYk5nTmZqZHdnb2JFZVJkaGVXY1dlQ2M1ZkthQWF5ZzVjWGdVZ2lha2VHYU5kVmVJaEJhS2hWZk1oSmZGYmdlWmZXZEplemhRYVhiVWJ5Y3NiMGdFYURlRWRXYkRnRmhjZHZhSWVGY0JlWmNJYUZjVWFnZ0pieWFjZXhnRWZ5ZjRmY2NCaGxndGdjZUVmeGdNYnljS2FqZ3dlaWJDZHljc2FOY1RlaGhSZVJhSWFnZTBmd2dOZ3hiUWhEZ1VjemJraHdlVWV3ZTFkWmVCYlJkZ2drZU1hemJZZXhlRGZnZElhUGJHYXplTWQ1ZkRmVGRZYjhkS2VCZkVjWWRWaGxlZ2R1ZVNjZ2NNYnVlVmQxZ0llcGRCZWpoVmRTZ0FoU2FsY1RiQ2FSaFlkR2FWY2lhY2YwZ0ZlMWZNY3JmTmVCZUFleGZGZGdleGJYZkxkeWRCZFFkV2RTaEJjVmFJY0NhY2VuZ01oUmVNaHVnSGRBZ1pjYmNYZEJhTWFUYU1oaWhvYThlSWVnZHNicmFEZVVkNGhVaFVnU2RJZ05lTWhEYmNlVWhBYzFjTWc1ZE1iRmNNaE5mV2hRaFVjWWFKZkRhTWIyZE1nUWE0YkNoRGN4ZXNkemhPY1FoMGQyZVBjQ2ZnZ1JkR2JGYVphWWRMaGtnb2NEZUxkbGFkYlNmS2ZRaFlkMWJVZWdkRWJwaFVmd2NrZ1doQmRsY1ljbmhOZkJjZGJUZUtlemZRZlFoTWZSZVlhTWNWY3ljOGZnZlVjRmdrYWdmVmJTZ0FkbmRKYXpnRWRUYUxmaGV3ZkdlV2MxY3doVGdFZXpjSWRxZlBjQ2VJZkxhS2N3ZzFoT2NGZEZkRWJpYkRmVGdBYzNnRmNBZE5hVGdPZVRhQmVUZkRnVmJrYkZnR2JDZVFhemVOZWpiRWhPYkFnZ2Q4Y2JnTWh6YmtjTmFOZGpmd2JvYkVjUmdoYVdhV2hDZDVkS2JBZ3lmNWRYZVVjaWFrZEdnTmVWZkloQmhLaFZiTWNKZUZkZ2FaZ1dkSmN6ZlFmWGVVZnlkc2IwZUVjRGJFYldoRGFGYmNldmJJY0ZnQmFaZEloRmNVZmdhSmd5YWNneGNFaHliNGVjZUJibGF0ZGNkRWh4Yk1ieWJLZmphd2hpZ0NheWVzaE5kVGFoZFJoUmZJZ2dmMGh3Zk5oeGhRYkRhVWV6YWtld2hVYXdmMWFaZ0JnUmNnYmtkTWh6YVlneGdEZGdlSWNQYUdjemNNaDVhRGNUZlllOGZLZ0JlRWdZZlZmbGdnZ3VkU2FnaE1jdWRWZTFnSWJwZEJlamNWYVNoQWNTYWxiVGdDZFJlWWhHZVZmaWZjZzBjRmUxZ01ocmNOY0JiQWZ4YUZiZ2h4ZFhmTGJ5Z0JiUWNXYlNnQmhWYkliQ2FjZG5lTWFSZE1jdWhIY0FkWmJiZ1hoQmdNZFRoTWZpZ29oOGFJZmdkc2JyZURoVWU0Z1VhVWFTZklkTmZNZERlY2NVYUFjMWFNZzVkTWRGaE1oTmNXZ1FoVWNZaEpnRGdNZjJiTWRRYjRnQ2hEZ3hjc2Z6Y09hUWYwZDJhUGJDZ2dnUmRHZ0ZnWmJZZkxna2VvYkRkTGZsZ2RlU2hLYlFjWWUxZ1VnZ2ZFZHBmVWh3ZmthV2hCZWxlWWhuZU5hQmVkZFRkS2Z6Z1FmUWhNZ1JoWWVNYlZjeWI4aGdlVWVGYWthZ2JWYVNnQWNuZEpjemFFZVRiTGFoYXdjR2VXYzFjd2dUY0ViemNJY3FhUGNDY0liTGZLaHdlMWNPYUZoRmhFYmllRGFUYUFkM2hGZEFmTmFUYk9kVGJCYVRlRGFWY2tiRmhHZENiUWR6Z05hamJFY09lQWNnZDhnYmJNZnpka2JOYk5jamV3ZG9hRWJSYmhiV2JXZUNmNWNLY0FjeWc1ZFhlVWFpY2tnR2dOZVZkSWVCZktiVmJNY0phRmRnY1plV2NKZnpnUWVYY1VheWNzZTBnRWZEYkVnV2dEZkZkY2Z2ZEliRmNCZlphSWNGYlViZ2dKaHliY2Z4Y0VheWg0Z2NhQmhsYnRoY2NFZnhiTWN5ZUtnamF3ZWlmQ2F5YXNlTmRUY2hlUmZSZkloZ2QwZndhTmZ4ZFFnRGRVY3poa2F3YVVnd2IxaFpkQmJSaGdka2RNYXpnWWV4aERmZ2hJY1BoR2N6Z01kNWdEYVRlWWY4YktlQmNFYVliVmdsY2dkdWdTYWdiTWR1Z1ZlMWNJZXBhQmZqY1ZhU2ZBZVNnbGFUZENmUmdZZkdnVmJpZGNiMGFGYzFlTWZyZk5nQmVBZHhoRmhnYXhlWGhMaHliQmRRZVdmU2NCZFZkSWNDYmNkbmRNYVJjTWV1Y0hoQWZaYWJhWGNCYk1nVGNNYmlnb2U4Z0ljZ2NzZXJkRGFVYTRmVWRVZlNnSWZOY01nRGZjZ1VoQWgxZ01nNWhNZkZhTWdOY1dnUWhVaFliSmdEY01kMmdNY1FhNGJDZURkeGJzZnpmT2RRYzBiMmdQaENhZ2JSZUdoRmNaZFliTGZrZG9nRGFMZmxoZGVTYUtmUWVZYzFlVWRnZkVmcGdVZ3dja2FXaEJjbGFZYW5lTmNCaGRjVGFLZHplUWFRYU1iUmJZYk1iVmJ5ZThhZ2ZVYkZma2hnZFZjU2hBZm5mSmd6ZUVmVGZMZmhmd2hHZ1djMWV3ZFRnRWV6ZklhcWRQZUNlSWVMaEtid2ExYU9nRmZGaEVhaWJEaFRjQWUzYkZnQWdOYVRiT2VUYUJmVGVEZFZia2JGY0dlQ2NRZnpiTmhqY0VnT2JBZWdlOGJiZ01jemNrZk5hTmhqZHdmb2RFYVJiaGNXYVdiQ2Q1ZUtnQWF5aDVlWGZVY2lka2RHZk5hVmRJYkJoS2RWZE1lSmJGZGdhWmZXYUpoemZRaFhnVWJ5ZXNiMGJFaERoRWJXYkRoRmhjZ3ZlSWFGZUJmWmNJYkZkVWhnZkpheWhjYXhmRWJ5YTRmY2JCaGxodGZjZUVoeGRNYnlhS2hqYndmaWJDYnlmc2ZOZ1RkaGdSZVJmSWZnYjBmd2NOZ3hjUWREZVViemNrZXdiVWZ3ZjFiWmVCZVJoZ2hrYk1memFZY3hlRGVnYkljUGhHYnpjTWE1YkRiVGhZYzhkS2hCYkViWWRWYmxnZ2d1YlNoZ2VNYXVoVmMxY0lmcGdCZWpoVmZTZEFnU2NsZVRkQ2VSZ1llR2RWZWliY2QwYkZmMWVNZ3JnTmhCZkFieGdGZmdkeGRYZ0xleWVCZVFlV2JTYUJiVmZJYUNnY2VuZU1oUmJNaHVkSGhBYlpnYmVYZEJkTWVUYU1laWZvZDhhSWNnZXNmcmdEYlViNGdVZFVjU2hJYU5lTWREaGNnVWJBZjFjTWI1aE1kRmRNZU5oV2RRaFViWWRKY0RmTWIyZ01iUWI0aENmRGV4YnNlemhPZ1FmMGMyaFBlQ2VnZVJiR2JGYVpoWWhMZWthb2VEY0xibGJkZVNlS2NRYllnMWRVYWdjRWVwZVVkd2ZrYVdlQmNsZ1libmNOZUJoZGNUZktlemdRZlFjTWFSY1lmTWNWZXllOGVnYVVmRmNrZ2dnVmFTaEFjbmNKY3poRWRUaExoaGR3Z0dhV2cxYndoVGdFaHpnSWJxaFBjQ2dJaExjS2R3YTFiT2JGYUZlRWhpYkRkVGhBZzNkRmhBZk5nVGRPaFRkQmNUZURiVmhrYkZmR2VDYVFkemJOaGphRWJPZ0FmZ2c4aGJmTWR6YWtnTmhOZWpkd2RvZ0VnUmJoYldnV2NDYjVkS2JBZXllNWdYYVVkaWRrYUdmTmhWZ0liQmdLYlZlTWdKZUZnZ2VaZldnSmh6ZlFjWGRVZ3lkc2YwZUVoRGVFaFdlRGhGY2NmdmRJZkZiQmFaY0liRmhVaGdmSmN5ZGNieGJFZXlmNGRjYkJhbGR0YWNjRWN4Zk1heWVLZWpld2RpYUNheWVzYk5jVGFoZlJnUmdJZGdkMGR3ZU5jeGhRYURjVWh6Ymtld2FVZHdjMWJaaEJkUmdnZmtjTWh6Z1lieGhEZWdhSWNQaEdhemZNZzViRGVUZVlhOGdLZEJjRWJZYVZnbGZnZnVkU2RnZU1odWVWZzFnSWVwZEJjamZWZlNnQWFTZGxlVGRDYlJkWWJHYVZoaWhjYTBnRmExYk1kcmROZUJiQWF4Y0ZmZ2R4YlhoTGR5Z0JhUWhXZlNhQmNWYUlnQ2JjaG5oTWhSZU1kdWdIZkFhWmFiYlhkQmRNY1RnTWRpZ29iOGZJZmdhc2dyZ0RnVWU0ZVVjVWdTaElmTmZNZ0RiY2VVZEFkMWhNZjVlTWJGZU1mTmNXYVFmVWJZYUphRGFNZDJhTWdRYzRnQ2dEZnhhc2d6aE9nUWQwZzJlUGJDZ2djUmNHZ0ZlWmFZYUxka2VvZERhTGNsY2RlU2hLYVFmWWQxZVVoZ2NFZXBkVWZ3YWtmV2NCZWxnWWFuY05iQmFkYVRmS2h6YlFmUWdNY1JoWWZNZFZheWc4ZmdhVWFGYmtoZ2FWYVNlQWRuY0poemhFaFRhTGdoY3djR2hXYzFnd2dUZkVjemJJZHFnUGVDZElkTGJLZXdmMWNPZ0ZlRmZFY2lhRGZUZUFmM2ZGY0FoTmFUZE9jVGdCaFRjRGRWZmtmRmhHaENmUWF6YU5iamNFYk9kQWdnZDhhYmNNYXpma2JOZk5lamR3aG9nRWNSZmhoV2RXaENnNWdLZ0FheWI1YVhhVWFpZmtkR2JOYlZlSWVCZEtnVmVNaEphRmdnZlpjV2JKZHpiUWZYZVVjeWRzZTBmRWdEYUVmV2NEYUZhY2d2ZElhRmFCYVpjSWNGZ1VoZ2FKZHloY2F4YUVoeWc0YmNlQmNsaHRkY2ZFZnhhTWF5ZkthamR3YmlmQ2J5aHNjTmVUZmhnUmZSZUlkZ2MwZHdhTmF4Y1FjRGhVY3pka2F3Y1Vid2UxZlphQmFSZGdja2dNY3pmWWV4Y0RjZ2dJY1BmR2R6Z01nNWNEZ1RjWWY4ZEtoQmFFYVliVmFsZ2dldWNTZGdoTWF1ZVZjMWZJYXBoQmVqaFZnU2NBYVNkbGFUZ0NiUmFZZkdkVmhpZGNlMGhGZzFhTWhyZU5hQmhBaHhoRmVnZnhkWGdMY3lmQmRRZ1dkU2RCYVZkSWRDY2NkbmNNY1JkTWh1YkhnQWFaYmJiWGJCZU1jVGhNYmlib2g4ZklhZ2ZzZHJiRGJVYTRlVWFVZVNhSWFOYk1jRGVjaFVoQWUxYk1lNWRNZEZjTWVOYVdiUWNVYVlmSmZEY01mMmhNZ1FhNGNDZ0RheGNzZnphT2hRZjBiMmJQZkNlZ2dSY0dkRmFaY1liTGFrZ29kRGFMZ2xiZGhTYkthUWdZZzFjVWNnYkVjcGNVZndma2hXYUJjbGJZaG5nTmFCYWRmVGFLZXphUWFRYk1lUmNZZk1oVmh5ZThkZ2dVZkZla2FnZVZoU2VBYm5oSmN6YkVnVGdMZmhhd2VHZFdoMWJ3ZlRoRWV6ZUljcWVQYUNiSWVMZ0tnd2UxZE9oRmhGY0ViaWJEaFRhQWUzZEZlQWhOYVRkT2JUYUJoVGhEYVZia2VGZkdkQ2JRZ3pjTmNqYUViT2ZBZGdhOGViYk1lemRrZE5lTmZqZXdhb2dFYlJmaGNXYVdhQ2U1YUtlQWN5YTVnWGJVZ2lka2hHZE5iVmJJZEJoS2RWZE1nSmFGZ2dkWmFXZUpnemNRZlhhVWR5YnNiMGNFYURiRWdXY0RoRmFjZnZkSWFGZ0JlWmdJZ0ZhVWFnZkpieWJjZXhhRWR5ZTRmY2RCZmxidGFjZUVmeGRNYnlkS2JqZ3diaWZDZnlkc2ZOZVRiaGFSaFJoSWhnZjBid2VOZ3hhUWZEZVVhemRrZndkVWR3ZzFmWmNCaFJlZ2hrZE1iemhZZnhhRGVnZElnUGNHYnpnTWg1ZURmVGhZZDhlS2hCYUVkWWNWYWxjZ2Z1Y1NjZ2VNYnViVmIxZElocGVCYWpoVmdTYUFhU2hsaFRhQ2FSYVloR2NWZGloY2MwY0ZhMWFNYnJnTmRCaEFoeGFGY2dleGdYYkxheWFCZlFkV2VTY0JmVmRJY0NkY2NuY01nUmJNZXVmSGNBYVpnYmNYY0JoTWVUZU1oaWFvZDhjSWZnZHNjcmNEZFVnNGNVZFVnU2VJaE5jTWREY2NoVWRBYTFnTWQ1ZE1lRmJNaE5iV2VRY1VhWWNKYURlTWUyZU1hUWc0Z0NkRGh4Z3NnemdPYVFiMGYyZVBoQ2hnaFJhR2VGZFpkWWRMaGtnb2hEZExibGFkZ1NoS2hRaFlnMWNVY2dlRWdwZlVnd2RrZldjQmFsZ1lhbmdOZ0JoZGJUY0tjemdRY1FnTWZSY1llTWFWZ3llOGhnaFVnRmRrZmdkVmhTY0FkbmJKZXpoRWFUZ0xlaGR3aEdjV2ExY3dkVGhFY3pjSWVxZFBlQ2RJY0xmS2h3ZjFhT2ZGZ0ZhRWRpZ0RmVGVBZDNlRmdBZk5jVGJPYVRmQmhUY0RoVmNrZ0ZnR2dDZFFiemdOZWpnRWFPaEFnZ2E4YWJhTWR6aGtiTmZOZ2pld2dvYkVoUmdoYldlV2ZDZzVjS2ZBYnlnNWVYYlVnaWhrZkdjTmZWaElnQmhLYlZmTWhKY0ZmZ2haaFdnSmd6ZlFjWGdVaHlnc2MwZUVnRGhFY1diRGhGYmNodmFJaEZhQmdaZklkRmhVZGdhSmF5YmNjeGJFYXliNGJjZ0JlbGh0ZWNoRWF4Y01leWFLaGpid2VpZkNmeWdzYU5mVGhoZlJmUmRJaGdoMGV3aE5oeGdRYkRmVWJ6ZWtid2NVaHdhMWVaYkJlUmRnZmtlTWh6ZFloeGNEZmdjSWdQZ0dnemhNYzVlRGFUYlllOGdLY0JoRWRZZVZibGFnY3VmU2RnaE1ldWZWYjFkSWVwZ0JnamhWYVNkQWJTYmxmVGFDZVJjWWdHZVZmaWJjYzBhRmUxZ01kcmFOZEJiQWN4ZUZnZ2Z4ZVhlTGR5Z0JhUWhXZFNlQmVWY0liQ2ZjZ25lTWFSZU1ndWFIZ0FhWmZiY1hkQmJNZlRmTWRpYW9oOGFJYmdmc2FyYURhVWM0Y1VjVWdTYkllTmhNZkRoY2NVaEFkMWNNZjVhTWJGYk1lTmZXZlFoVWJZYUpkRGJNaDJiTWNRZzRmQ2REY3hmc2F6ZU9oUWcwZzJlUGNDZWdjUmZHaEZlWmdZaExia2hvYkRkTGZsYmRmU2VLY1FlWWQxZVViZ2JFZnBiVWF3YmtlV2JCZmxhWWRuY05oQmFkZVRmS2d6YlFlUWVNYlJlWWhNZlZheWE4ZGdjVWdGYmtnZ2dWZVNmQWFuYkpoemVFZ1RiTGhoaHdhR2JXYzFjd2dUaEVhemNJYXFoUGRDZEllTGVLY3dhMWhPZ0ZjRmFFZWliRGhUZkFkM2JGZ0FlTmJUZk9kVGhCZ1RoRGJWZWtjRmZHZkNkUWR6ZU5hamFFZ09lQWRnZzhjYmhNZXpia2FOZU5namF3ZG9kRWhSZmhjV2RXZENnNWRLZEFoeWQ1aFhmVWFpYWtmR2ZOZlZnSWRCaEthVmRNZEpkRmZnYVpoV2hKY3phUWJYYVVoeWNzZjBoRWhEYUVmV2NEZEZmY2Z2Z0lmRmhCaFpnSWhGZVVkZ2JKYXliY2h4Y0VleWQ0Y2NlQmRsZHRlY2hFYXhoTWh5ZEtjamN3Z2lhQ2d5ZHNjTmZUaGhjUmZSaEljZ2gwZHdnTmJ4ZFFoRGJVZHpja2R3Y1Vid2YxZlpiQmhSYmdja2hNYXpiWWd4YkRmZ2hJY1BoR2F6Zk1jNWJEZ1RnWWY4ZktmQmRFYllkVmFsZGdjdWhTYWdnTWh1Z1ZjMWhJZHBlQmNqYlZkU2NBaFNkbGhUZENmUmZZaEdmVmNpZWNoMGhGYTFjTWVyYk5lQmhBZ3hjRmRnaHhkWGFMY3ljQmVRZ1dkU2JCZVZhSWdDZmNhbmNNY1JjTWJ1YkhkQWRaZmJhWGJCZE1mVGZNY2lmb2g4YUljZ2JzZnJmRGZVZzRhVWFVYlNiSWhOZU1iRGJjZFVnQWYxaE1nNWFNZEZiTWdOY1doUWVVYllhSmNEYU1iMmFNZ1FkNGRDZURneGVzZnpkT2RRYTBoMmdQZ0NjZ2FSaEdlRmJaYVliTGdrYW9iRGJMZmxlZGRTY0thUWZZZzFhVWNnaEVlcGZVYndia2JXYkJlbGdZZm5kTmdCYmRiVGRLZnpoUWVRZk1mUmVZZk1lVmN5ZThiZ2hVYUZka2FnY1ZoU2ZBaG5oSmR6ZEVjVGVMYWhld2JHaFdoMWV3ZlRhRWJ6YkllcWFQZkNlSWNMZ0tmd2MxYk9iRmVGZUVjaWREaFRkQWUzaEZkQWFOY1RlT2dUY0JlVGVEZFZma2ZGZUdhQ2FRY3pmTmdqaEVkT2hBYWdjOGhiYk1iemJraE5mTmZqZndlb2RFYVJmaGdXYVdmQ2Q1Y0thQWF5YjVjWGFVY2lma2NHaE5kVmVJZEJlS2NWZU1nSmFGYWdoWmZXZ0plemNRZVhnVWR5Y3NkMGVFZERoRWJXZkRhRmJjaHZhSWZGY0JmWmNJYUZhVWJnYUpneWFjYXhnRWF5YzRjY2NCaGxndGRjZ0VleGRNZ3lnS2RqZ3diaWNDYnlmc2hOZVRoaGVSZVJnSWhnaDBhd2ZOZHhjUWZEZFVnemNrZ3diVWJ3YTFiWmFCZlJnZ2VrZU1iemJZYXhjRGdnaElnUGJHYnpkTWI1aERjVGdZZzhmS2VCZEViWWFWZ2xmZ2d1ZFNoZ2hNZnVnVmUxZUlocGZCYWphVmRTZ0FlU2ZsYlRkQ2ZSZFljR2VWZmlkY2QwY0ZiMWJNaHJiTmZCYUFneGVGZmdneGhYaExieWVCYlFoV2ZTaEJlVmZJYkNmY2FuZU1lUmNNZXVjSGdBYVpjYmdYZEJkTWJUZk1maWRvZjhjSWJnYnNicmJEZFVhNGdVaFVkU2RJY05jTWFEY2NiVWNBYjFiTWg1aE1iRmJNY05hV2VRYlVkWWNKYURmTWYyZk1oUWM0Y0NnRGN4ZHNjemVPZlFjMGgyYlBjQ2JnZ1JnR2VGaFpkWWZMZWtlb2hEZUxibGNkZlNiS2hRYllmMWNVYWdoRWJwaFVkd2RrYldiQmhsZllobmNOY0JnZGNUZUtoemFRY1FoTWRSZllmTWRWZ3ljOGVnYVVmRmhraGdmVmZTZEFlbmNKYXpjRWhUY0xjaGZ3Y0dlV2QxYndlVGJFZHpnSWZxZVBkQ2ZJZExkS2F3ZDFjT2RGZkZoRWdpYkRnVGVBYjNhRmRBYk5iVGJPZVRlQmNUY0RiVmFrZkZnR2FDZVFiemhOaGpoRWdPY0FiZ2U4Z2JnTWN6ZWtnTmZOYmpnd2hvZEVlUmhoZVdnV2hDZzViS2RBaHlmNWdYZFViaWdrYkdlTmRWYkljQmFLYlZkTWJKYUZoZ2ZaaFdoSmN6ZFFlWGZVZnlnc2cwYkViRGJFaFdlRGdGZ2NhdmZJY0ZnQmdaZklnRmNVaGdjSmN5Y2NheGJFaHlnNGVjZEJibGR0Y2NjRWR4aE1ieWVLZ2pjd2RpZUNkeWdzZU5nVGFoYVJlUmNJYmdoMGd3ZU5heGhRY0RkVWF6Z2tkd2hVYXdnMWZaZ0JlUmdnZ2tnTWJ6Z1lmeGNEYmdlSWZQZkdiemNNZDVlRGZUZ1llOGRLZUJiRWVZZlZnbGZnZXVhU2hnZk1ldWJWYjFnSWVwaEJjamVWYVNjQWJTYmxkVGNDZFJlWWFHYlZlaWVjZDBkRmYxYU1lcmNOYUJmQWh4Y0ZmZ2R4aFhmTGJ5ZUJoUWRXZVNkQmhWZEljQ2JjZm5oTWdSZU1ndWhIYkFkWmRiZlhhQmZNYlRhTWRpaG9jOGVJaGdjc2FyYURnVWc0YVViVWNTYklkTmZNZ0RnY2hVaEFjMWZNYjVkTWdGaE1hTmVXZlFiVWhZYkpkRGJNZjJoTWhRYjRlQ2dEYXhoc2F6ZU9lUWQwYzJjUGJDaGdiUmhHZ0ZkWmVZZUxla2VvYkRlTGFsYmRkU2JLZlFnWWcxZFViZ2JFaHBiVWF3ZWtoV2NCY2xoWWZuZ05kQmVkZFRnS2Z6YlFlUWNNZlJhWWhNZ1ZoeWM4Y2dhVWRGZ2thZ2JWYlNhQWVuaEpnemVFaFRkTGdoZndjR2VXZjFod2RUaEVjemhJZXFlUGZDYUlnTGZLZ3dnMWdPY0ZnRmhFZmlkRGFUYUFiM2ZGaEFkTmNUZU9mVGVCYVRlRGhWYWtmRmVHZENmUWV6ZE5iamZFY09iQWhnZjhoYmVNZXpna2dOZk5namh3Y29jRWJSYmhkV2FXaENmNWVLYkFkeWY1YlhiVWZpYmtoR2JOY1ZoSWJCY0tnVmRNZkpjRmNnY1poV2hKZHplUWdYaFVoeWZzZzBhRWFEZEVlV2dEYUZhY2h2aEllRmJCZVpiSWNGY1VjZ2JKZHliY2N4YkVleWQ0Z2NlQmVsZ3RkY2NFYXhlTWd5ZUtnamd3ZGliQ2Z5Y3NjTmRUaGhkUmNSZElnZ2EwZHdmTmZ4aFFmRGJVZnpha2R3aFVhd2UxZFpmQmVSY2dha2dNY3piWWd4YkRlZ2dJZVBlR2J6Zk1iNWREZVRhWWg4ZUtiQmdFYVlhVmVsZWdkdWRTYWdhTWN1Z1ZhMWZJZXBkQmdqZ1ZnU2JBZVNibGFUaENiUmNZZ0dnVmFpZWNoMGJGYzFiTWVyaE5lQmdBaHhlRmJnZnhnWGZMYnliQmFRZldkU2RCZVZlSWhDZWNhbmNNY1JhTWR1YkhmQWZaZmJiWGdCZE1iVGdNZWljb2Y4YUlhZ2ZzZXJiRGJVYTRjVWVVYlNhSWhOZ01oRGJjZlVnQWgxYU1jNWVNYkZjTWhOY1dhUWdVYllhSmREZU1nMmhNYVFoNGFDY0RjeGZzY3plT2JRZzBlMmJQZ0NhZ2JSYkdlRmhaZlloTGhrZm9iRGNMZmxmZGNTY0tiUWdZZDFjVWdnZ0VicGJVZHdja2hXZEJjbGVZYm5nTmVCaGRoVGVLY3phUWdRYk1iUmFZY01jVmN5YzhkZ2FVZkZma2FnZFZoU2VBZ25kSmF6ZEVlVGRMZ2hid2NHZFdmMWV3YVRiRWZ6YklkcWZQZENiSWVMYktod2QxZk9kRmhGYkVhaWJEYlRmQWYzYUZhQWROZFRjT2JUYUJiVGVEYVZla2hGZEdkQ2JRY3poTmdqYUVkT2VBYWdiOGdiZE1hemFrZU5jTmhqZndjb2hFZlJoaGdXZVdkQ2M1Y0toQWF5aDVnWGFVZGlna2dHYk5hVmNJZkJlS2ZWaE1mSmhGZGdkWmdXZUpnemdRaFhmVWh5aHNiMGRFYURjRWVXYURoRmVjY3ZoSWFGaEJlWmZJZkZmVWNnZ0pieWJjZXhhRWR5YjRhY2ZCY2xndGZjaEVkeGdNZHljS2FqYXdoaWRDaHlmc2NOY1RnaGZSZlJkSWhnYTBod2JOYnhhUWREYlVhemJrZXdhVWJ3YzFjWmdCZlJhZ2RrZU1iemdZY3hoRGNnZklkUGVHZXpmTWQ1ZkRhVGNZYThmS2JCZUVhWWJWZWxmZ2V1YlNjZ2ZNYXVnVmgxZklmcGZCZWpkVmFTYUFjU2dsZ1RhQ2hSaFlkR2NWYWllY2cwaEZhMWJNZXJnTmRCYUFkeGNGZWdkeGdYY0xleWJCYVFmV2FTY0JlVmZJYUNlY2RuZk1jUmNNYXVkSGdBZlplYmZYYUJoTWJUYU1jaWVvZThkSWVnYnNlcmFEZFViNGJVYVViU2RJZ05jTWFEZGNoVWJBZzFmTWI1Zk1iRmdNZE5oV2JRaFVlWWRKZERhTWMyZU1jUWY0YUNlRGJ4ZnNhemRPZlFkMGEyZlBlQ2dnaFJhR2hGZlpjWWNMZ2tmb2JEYkxjbGZkaFNiS2VRY1ljMWFVZmdnRWdwYVVid2hrZVdnQmJsYllobmFOYkJmZGdUZktlemNRaFFkTWFSZFllTWRWZnlnOGFnZVVjRmFrZGdnVmZTY0FlbmJKZ3plRWVUZ0xjaGZ3YUdkV2cxZHdmVGZFZXpkSWZxY1BhQ2RJYkxmS2N3ZjFoT2JGZEZmRWFpZ0RiVGhBZjNoRmVBYk5oVGZPYVRlQmZUZURnVmFrZkZjR2NDY1FoemJOYWpoRWhPZEFmZ2c4ZGJjTWJ6ZGtjTmZOaGphd2JvZ0VoUmhoZVdlV2hDaDVhS2JBaHlmNWdYaFVlaWZrZUdkTmFWYUlkQmVLZFZmTWNKZ0ZlZ2ZaYldhSmN6YVFiWGNVZHloc2YwZEVoRGVFYVdnRGVGY2NldmhJZkZhQmJaYUlmRmhVYWdjSmN5Z2NleGZFY3lkNGFjZUJlbGZ0YmNnRWh4Zk1jeWJLYWpjd2RpZUNjeWZzYU5kVGdoYVJkUmhJYWdoMGh3aE5keGdRZkRmVWN6ZGtjd2VVYndkMWVaZ0JlUmhnY2thTWJ6Z1lieGREZ2dhSWJQZkdkemRNZzVnRGJUYllkOGJLZUJmRWRZZVZmbGZnZnVmU2ZnY01mdWFWZDFlSWNwZ0JlamhWaFNjQWJTZWxmVGZDZFJmWWZHZFZiaWRjZjBoRmQxZU1kcmFOZUJkQWR4ZkZjZ2Z4Y1hmTGF5ZUJlUWVXZlNhQmdWZElnQ2ZjYm5oTWdSaE1idWZIYkFjWmJiZlhmQmVNYVRjTWJpZ29iOGhJZmdoc2hyZ0RkVWM0aFVoVWRTYUlkTmZNZURhY2NVY0FhMWNNYjVoTWVGY01nTmRXZVFoVWFZaEpkRGVNaDJlTWNRZzRhQ2ZEZ3hjc2Z6ZU9jUWgwYTJhUGhDY2doUmRHYUZjWmRZY0xla2hvY0RlTGhsZ2RlU2NLY1FkWWQxZ1ViZ2RFZHBhVWJ3Z2tnV2ZCYWxhWWhuZU5mQmhkY1RjS2R6YVFmUWZNZlJoWWZNaFZleWg4Y2dmVWVGZmtjZ2hWZFNkQWVuZEpoemNFZVRnTGNoY3diR2RXZDFid2NUZ0VjemhJZXFmUGVDZ0ljTGZLYXdiMWFPZ0ZnRmFFYmlmRGhUaEFoM2RGY0FiTmFUZ09iVGVCY1RkRGZWY2thRmFHZUNhUWh6Z05iamRFZk9oQWhnYzhmYmNNaHpla2ROYU5oamJ3Z29jRWRSZ2hmV2hXYkNkNWVLYkFneWE1YVhkVWVpY2tnR2FOYVZnSWhCY0tkVmJNZEpjRmVnYVpjV2FKaHpoUWJYY1VheWRzZzBlRWNEYkVmV2JEZEZkY2h2ZklhRmZCYlplSWZGYlVoZ2FKZXliY2J4aEVoeWE0ZGNkQmFsZ3RjY2dFaHhiTWd5aEthamJ3ZGlhQ2V5aHNiTmdUZWhjUmFSYklhZ2cwaHdiTmd4Z1FiRGdVY3pja2V3ZlVmd2UxZVphQmJSYWdoa2JNYXphWWh4Y0RhZ2JJZlBhR2F6Yk1hNWJEY1RnWWY4ZEthQmZFYllhVmFsZGdkdWVTY2dhTWR1Z1ZiMWRJZHBhQmZqaFZhU2hBZFNjbGNUZUNlUmNZZUdnVmNpZmNoMGVGYzFoTWZyYU5nQmVBZ3hlRmhnZ3hnWGFMYnllQmhRZVdkU2RCYlZhSWNDaGNjbmRNZ1JnTWd1Y0hmQWdaYmJhWGFCZ01oVGFNZmlmb2U4Z0lhZ2JzZnJnRGJVZDRlVWVVZFNlSWFOZE1hRGVjZ1VmQWcxYU1nNWNNZUZkTWdOZ1dhUWhVZllhSmZEZE1oMmFNZ1FiNGdDYkRkeGJzYnpiT2hRYTBhMmhQYkNoZ2hSaEdhRmZaYVloTGNrYm9lRGRMZWxmZGhTY0tkUWFZaDFoVWFnYUVkcGdVZXdia2hXYkJjbGJZZG5hTmNCYmRlVGNLYXphUWhRZE1iUmZZYU1jVmh5YjhkZ2VVYUZoa2JnZFZjU2RBY25kSmF6ZkVoVGNMZWhhd2hHZldkMWV3ZVRnRWd6ZklocWZQaENlSWdMaEtod2UxaE9lRmdGaEViaWREZlRhQWEzYkZnQWdOZlRkT2FUZ0JhVGFEYlZna2hGYkdjQ2FRZnphTmNqY0VnT2hBYmdkOGhiZE1memZrY05kTmZqZXdkb2NFZlJjaGhXaFdiQ2I1aEtjQWV5aDVjWGJVYmlha2FHZ05nVmRJaEJhS2FWZU1lSmNGaGdoWmFXZkpkemZRaFhjVWR5YXNiMGVFYkRjRWRXaERoRmNjZnZoSWJGYUJkWmRJaEZlVWRnY0pneWNjZHhlRWh5YTRoY2ZCYWxidGJjZ0VheGVNZnliS2FqZXdjaWdDZXllc2hOaFRlaGFSaFJnSWRnaDBhd2VOYnhjUWhEYVVkemhrZXdoVWV3YzFnWmhCY1JkZ2JrYU1iemJZYnhoRGVnZElnUGVHaHplTWU1YURnVGJZZThjS2hCZ0VkWWVWY2xoZ2V1ZlNoZ2FNZXVlVmExZElmcGFCYmpjVmdTZ0FjU2NsZ1RoQ2VSZFlhR2NWZmlhY2cwY0ZlMWdNYnJkTmFCZkFoeGVGZWdheGNYYkxjeWVCZVFhV2FTaEJiVmhJZ0NoY2JuZk1hUmRNZXVkSGdBZlplYmZYZEJnTWJUZE1maWJvYjhiSWdnaHNjcmJEZFVhNGFVZlVnU2ZJZE5nTWFEZmNnVWFBYzFoTWI1ZU1mRmFNZ05kV2dRZ1VjWWdKZ0RiTWUyZ01mUWg0YkNiRGd4ZHNmemFPaFFjMGcyZlBoQ2JnZ1JmR2ZGZ1phWWdMZWtjb2NEZExibGdkYVNoS2hRZ1lkMWJVZ2doRWdwZ1Vmd2draFdiQmJsY1ljbmNOZEJoZGZUaEtoemRRYVFjTWJSZFliTWhWYXliOGFnZFVhRmRrYWdoVmVTY0FkbmNKaHpiRWZUaExiaGd3Y0dkV2QxaHdhVGRFY3pmSWFxY1BlQ2JJZExjS2d3YzFoT2NGYkZiRWJpY0RhVGhBZjNnRmRBYk5iVGVPYVRiQmJUZkRiVmJrY0ZiR2VDZVFnemROYWpkRWJPZkFhZ2Y4Z2JnTWF6aGtjTmROZmpod2ZvY0VhUmVoZVdjV2NDYTVmS2RBZXljNWdYaFVhaWhrY0doTmJWZEliQmZLZFZoTWJKYkZnZ2FaZFdoSmR6YlFoWGhVaHloc2QwZ0VmRGJFYldjRGhGYWNmdmNJZkZhQmhaaEljRmJVZGdoSmZ5YWNkeGRFZHlhNGhjY0JjbGJ0ZWNjRWN4ZU1leWhLZWpnd2dpZUNheWVzYk5oVGZoZFJmUmZJYWdjMGV3Zk5leGNRYURoVWd6Zmtod2hVY3dnMWVaZUJnUmFnaGtiTWN6Y1lheGVEZWdkSWdQZUdnemJNZTVlRGJUYllhOGdLYUJnRWJZZlZobGZnZXVkU2RnY01ldWdWYjFnSWFwZkJjamhWZ1NoQWJTYmxlVGJDY1JkWWFHaFZnaWJjZTBiRmQxZk1ncmROZkJjQWN4aEZhZ2d4YVhiTGJ5YUJkUWFXZlNmQmhWZUlhQ2djYm5kTWFSY01idWdIYkFjWmRiZVhiQmZNZlRnTWdpaG9iOGVJZ2djc2VyZkRmVWc0ZlVoVWRTY0lhTmVNZERoY2NVZ0FhMWhNZTVhTWJGZk1iTmJXZFFkVWFZZ0poRGdNYzJlTWdRZjRoQ2REYnhkc2N6YU9iUWgwZjJnUGZDYmdjUmNHYkZjWmhZZkxma2dvZkRlTGhsYWRnU2JLY1FhWWMxY1VoZ2VFY3BmVWh3ZGtjV2RCZmxlWWFuZE5oQmNkZlRnS2V6aFFmUWRNZ1JhWWJNaFZieWQ4Z2dhVWhGZ2tmZ2NWaFNjQWRuZkpiemJFZlRiTGVoY3djR2JXZTFjd2dUaEVkemdJZ3FmUGZDZ0lkTGJLZHdhMWRPZEZjRmRFZ2ljRGVUZkFnM2RGZUFmTmZUZk9lVGNCZlRjRGNWYWtnRmJHZ0NlUWh6Yk5kamFFYU9nQWVnaDhlYmhNZnpka2NOaE5lamh3aG9kRWFSaGhhV2dXY0NoNWZLYkFoeWE1YlhjVWFpZ2tnR2dOZFZmSWFCY0tlVmdNaEpoRmJnZlpiV2JKYXpoUWNYaFVoeWFzYjBlRWhEZ0VmV2dEYkZlY2J2YUlnRmZCaFpkSWhGYlVkZ2dKZnllY2h4aEVjeWM0Z2NmQmNsZHRmY2JFaHhlTWF5Y0tnamd3ZWlmQ2N5ZXNlTmFUZWhhUmZSYUlmZ2EwYXdkTmV4ZlFnRGJVZ3pma2Z3Y1Vnd2cxZFpmQmFSZmdma2NNYXpiWWZ4YkRkZ2ZJZ1BjR2h6YU1hNWJEZlRlWWQ4YktlQmhFaFlkVmNsZ2dhdWJTZmdhTWV1ZlZhMWNJY3BlQmJqaFZnU2JBZlNjbGFUY0NkUmhZYkdhVmNpYmNkMGFGaDFhTWRyYU5mQmhBZ3hiRmFnZHhnWGFMaHloQmdRY1diU2dCYlZkSWVDY2NhbmJNYVJlTWF1ZEhhQWNaYWJlWGVCZU1kVGNNYWlob2g4ZklmZ2JzZnJmRGZVaDRoVWJVYlNkSWVOYk1jRGdjYVVnQWIxZE1hNWFNaEZiTWROZFdhUWZVYVlmSmZEZU1oMmZNZ1FnNGRDaERneGVzZHpoT2dRZjBjMmJQYkNmZ2ZSYUdkRmVaZVlnTGZrY29kRGVMZmxoZGVTZUtmUWdZZTFjVWFnaEVncGNVZXdka2FXZUJkbGVZZW5jTmRCZWRjVGVLaHpiUWNRZU1kUmVZZk1nVmZ5YThiZ2RVZkZha2VnZlZkU2hBaG5jSmN6YkVmVGRMY2hjd2VHZFdhMWF3aFRkRWZ6YUljcWdQYUNiSWhMYktnd2cxZU9mRmZGYUViaWJEYlRhQWgzZEZkQWFOYVRiT2dUYkJhVGNEaFZna2VGYkdiQ2hRaHpkTmRqYkVhT2NBZmdhOGRiZU1jemRrZk5jTmZqZndib2FFZlJiaGVXYVdiQ2M1YktmQWN5ZTViWGhVZGloa2dHY05hVmNJZkJjS2ZWZk1jSmNGY2diWmRXZkphemFRZ1hkVWV5ZHNkMGRFZ0RmRWRXZkRmRmRjYnZiSWZGZ0JlWmVJZkZnVWRnZkpieWRjYXhnRWN5ZDRkY2VCaGxidGdjYUVneGdNY3liS2FqZXdlaWhDZ3lmc2ZOYVRlaGhSY1JjSWNnZTBod2ZOYXhkUWFEYlVmemhrZXdlVWJ3ZDFlWmhCZ1JiZ2hrYU1jemFZZXhnRGhnZElkUGRHYnpiTWc1Y0RhVGRZZjhkS2FCZUViWWVWZGxlZ2R1YlNmZ2ZNYnVmVmQxZ0lhcGFCZmpmVmdTYkFnU2FsZFRlQ2FSYllmR2RWZWloY2IwZkZhMWVNZXJmTmhCaEFmeGZGaGdjeGVYZkxoeWRCY1FmV2VTZUJnVmVJaENkY2ZuY01kUmFNYXVlSGRBaFplYmRYaEJjTWRUYU1naWFvaDhkSWFnYnNkcmJEZlVnNGRVZVVkU2dJaE5nTWNEaGNhVWdBYzFjTWY1aE1mRmdNYU5jV2dRaFVmWWRKYkRlTWgyZk1nUWM0Y0NhRGZ4ZXNjemJPYVFlMGEyY1BiQ2RnZVJmR2RGY1pnWWFMZWtib2FEZkxlbGdkYlNjS2dRY1llMWZVZGdoRWZwZlVkd2FrYldmQmZsaFllbmFOYUJhZGFUaEtnemJRaFFkTWhSZ1lnTWdWaHllOGNnZVVmRmdraGdkVmZTZEFobmRKY3pjRWVUaExjaGZ3ZkdiV2MxaHdlVGZFZXpjSWhxZVBiQ2NJZExoS2h3YjFnT2RGYUZlRWhpaERmVGJBZjNhRmFBYU5jVGdPZFRjQmNUZkRiVmdraEZjR2JDaFFlemhOZmphRWFPZUFjZ2I4YmJnTWZ6aGtjTmdOYWpod2VvZkVkUmRoZVdmV2FDZDVjS2hBZXliNWhYYlVoaWFrZkdlTmVWYklmQmJLZVZiTWNKYkZiZ2FaZFdmSmV6YVFoWGJVZnlnc2UwZ0ViRGhFZVdoRGRGYWNkdmFJZkZhQmFaZEloRmRVY2dnSmd5Y2NleGFFZXliNGZjYkJmbGd0ZWNoRWF4Z01keWdLYmphd2NpZUNoeWRzZU5iVGNoZlJoUmZJaGdkMGh3aE5neGVRZERnVWN6Y2tkd2NVYndoMWhaYUJoUmhnYmtnTWF6ZVloeGJEZGdoSWNQaEdmemdNaDVlRGJUZllhOGJLZUJnRWNZY1ZjbGZnZHVmU2hnZE1jdWZWYjFjSWVwY0JiamNWZVNiQWJTZGxiVGFDY1JlWWZHZlZnaWVjZTBmRmMxY01ocmVOZ0JjQWJ4YkZjZ2Z4ZVhoTGN5Y0JnUWRXYVNiQmVWZ0lmQ2djY25jTWRSYU1mdWJIZ0FiWmFiaFhoQmJNYlRkTWVpYW9hOGZJZmdlc2ZyY0RkVWY0ZFVkVWRTZUloTmFNYURkY2JVZ0FnMWFNZTVoTWhGZU1hTmdXZVFnVWdZZEpiRGhNYjJoTWFRYzRlQ2JEY3hkc2N6Y09jUWQwYjJlUGVDZWdhUmVHYUZhWmVZYkxka2JvZURhTGRsZWRmU2FLZFFiWWYxY1VhZ2JFZ3BoVWJ3Y2tjV2dCaGxjWWRuZE5iQmNkYlRhS2R6Z1FlUWZNYVJiWWFNZFZkeWQ4ZWdhVWdGZWtiZ2ZWaFNnQWduZ0phemVFZVRlTGhoaHdkR2FXZDFjd2dUY0VjemZJYXFmUGFDYklkTGRLZndiMWNPZUZjRmZFZGlmRGNUZ0FhM2ZGZ0FkTmRUaE9kVGNCZVRlRGRWY2tjRmJHZ0NkUWh6Zk5kamFFZ09jQWJnZjhiYmJNZnpoa2NOYU5oamh3YW9iRWVSYmhiV2FXZkNlNWNLZkFieWI1Z1hoVWZpZ2tjR2FOaFZkSWVCaEthVmRNYUplRmJnYlpjV2VKYnpnUWVYYlVkeWJzYTBiRWFEYUVnV2ZEYUZnY2V2Y0lhRmhCZVpkSWhGZVVlZ2VKZXliY2V4ZUVheWc0Z2NlQmRsaHRmY2VFYXhhTWR5ZEtlamd3ZGlhQ2Z5Y3NlTmVUaGhnUmVSYklnZ2IwaHdlTmN4Y1FmRGFVaHpia2N3YVVkd2QxYVpnQmNSZmdja2NNZHphWWZ4ZERjZ2NJZlBlR2d6Y01kNWVEZVRoWWI4aEtnQmJFYVljVmJsaGdhdWFTYWdoTWZ1YVZmMWNJZHBnQmRqZVZnU2JBYVNlbGFUZkNlUmdZaEdjVmJpY2NnMGdGYTFoTWFyZ05oQmdBZHhiRmFnaHhnWGdMZnlmQmdRZVdiU2hCZlZnSWZDYWNobmZNYlJlTWh1aEhkQWJaYmJmWGJCY01iVGdNZmlnb2I4ZUlhZ2hzYXJnRGJVZTRkVWRVZFNhSWFOZk1nRGNjYlVoQWIxZk1nNWNNZ0ZoTWdOZldjUWhVZFlmSmFEYU1mMmhNY1FhNGdDY0RkeGJzY3piT2FRYzBmMmVQZENjZ2JSYkdhRmZaYlljTGdrZW9iRGVMZmxnZGFTYktlUWNZYjFoVWdnY0VlcGVVYndka2VXZEJobGRZZm5jTmJCaGRiVGhLZHphUWVRYk1oUmZZZE1hVmd5ZzhoZ2VVZEZka2ZnYVZlU2JBYm5mSmR6ZEVlVGZMYmhmd2ZHY1dmMWZ3aFRjRWV6ZklncWhQZUNlSWVMY0tid2cxaE9mRmVGZEVhaWFEYlRiQWIzZ0ZmQWVOZVRlT2JUZEJmVGZEaFZma2VGYkdjQ2RRZXpmTmhqYUVmT2dBYWdlOGdiZk1oemFrZk5hTmFqY3dib2JFZFJkaGZXZ1djQ2Y1Z0thQWd5ZDVoWGZVYmlma2JHZU5mVmNJZUJhS2VWYU1mSmFGZWdjWmVXZ0pjemdRY1hkVWJ5ZnNlMGhFaERiRWZXZ0RlRmRjZHZnSWdGaEJoWmZJYkZhVWNnZkpleWRjYnhhRWF5ZjRjY2FCaGxkdGhjZkVkeGVNYnlhS2dqYndoaWJDY3ljc2ROZVRjaGRSZVJkSWZnZjBhd2ROYXhlUWJEY1VlemZrYndiVWh3YjFoWmRCZFJkZ2VraE1nemVZZ3hlRGVnZUlnUGFHZXpjTWI1ZURoVGNZZDhmS2ZCZEVhWWhWZGxnZ2Z1ZlNmZ2VNZnVkVmgxYUlkcGNCZWplVmJTaEFnU2VsY1RnQ2RSYllmR2dWZ2lhY2gwZUZlMWJNZnJlTmVCYkFjeGFGaGdmeGNYYkxjeWdCYlFhV2ZTZ0JoVmZJZ0NiY2huZ01jUmdNZHVhSGFBY1phYmRYZkJlTWVUZk1kaWZvYzhoSWRnZHNmcmdEZlVlNGdVZVViU2RJZ05hTWVEZWNmVWdBaDFkTWM1Yk1mRmJNaE5jV2RRZlVlWWRKZ0RlTWIyZU1oUWM0ZENhRGF4aHNhemNPZFFjMGQyZ1BkQ2hnZlJjR2NGZFpkWWhMY2tlb2REYUxlbGRkZFNkS2RRYllhMWRVaGdiRWRwZlVhd2ZrYldjQmNsYVlmbmZOYkJiZGNUZkthemFRaFFkTWdSYVloTWNWYXlnOGhnZVVmRmFraGdoVmVTZ0FjbmhKaHpjRWdUYkxkaGd3ZkdoV2MxZHdiVGhFZ3pnSWdxaFBkQ2hJY0xoS2R3ZDFiT2RGZ0ZiRWZpaERoVGZBZjNmRmFBZU5mVGRPaFRkQmFUYkRnVmhrZUZhR2JDY1FmemROZWplRWFPZUFiZ2I4ZmJmTWJ6aGthTmVOaGpod2FvYUVjUmNoZldnV2VDYjVkS2VBY3ljNWJYYlVkaWJrY0diTmRWYklnQmJLZ1ZmTWRKZ0ZkZ2JaYldoSmJ6aFFiWGNVaHlmc2IwY0VhRGRFZ1dkRGVGYWNjdmRJYkZmQmFaZElmRmVVYWdlSmh5Y2NneGJFaHlhNGNjY0JnbGh0YmNmRWZ4Zk1heWhLZGpnd2NpZ0NneWZzY05lVGJoaFJjUmJJYWdnMGJ3Z05keGNRYkRlVWZ6aGtkd2dVZXdkMWRaY0JjUmVnZWtjTWJ6ZFloeGJEZ2djSWRQY0djemJNYTViRGNUZFloOGRLZEJoRWVZZFZibGdnZHVkU2FnY01mdWhWYjFjSWFwZUJhamZWaFNhQWRTaGxlVGhDZ1JiWWRHaFZmaWFjZDBiRmQxZk1hcmZOZkJhQWR4Z0ZmZ2d4Y1hhTGN5ZUJjUWNXYVNlQmFWZklhQ2FjZ25jTWhSZ01idWdIYUFhWmNiZlhiQmFNY1RiTWFpZG9jOGRJYmdkc2FyZ0RjVWU0ZFViVWhTYklhTmZNY0RjY2NVZEFmMWFNZzViTWVGY01lTmRXZ1FkVWFZZkpoRGhNZzJoTWJRZTRiQ2VEYnhmc2Z6Y09hUWYwZTJjUGJDZmdlUmFHZ0ZjWmFZaExla2RvZkRnTGFsZ2RiU2FLZ1FlWWUxY1VjZ2VFaHBhVWN3Z2thV2RCZ2xoWWRuYU5jQmZkY1RkS2R6YlFnUWFNZlJiWWFNZ1ZieWc4ZWdnVWRGZGtoZ2hWY1NoQWRuYkpjemVFY1RoTGFoYndhR2VXZTFld2JUYUVhemNJZ3FmUGhDZkloTGNLZHdnMWFPYUZjRmVFZmlnRGVUYkFiM2dGYkFhTmJUZE9oVGVCYVRlRGNWZmtnRmdHZkNhUWF6YU5hamVFY09oQWRnZjhiYmFNZXpja2ROZE5kamV3Zm9kRWJSYmhmV2JXYUNiNWRLYUFieWY1Z1hoVWhpY2tnR2dOYVZnSWRCYktiVmVNZUplRmhnaFphV2VKZ3pnUWNYYVVieWdzaDBkRWhEaEViV2NEZEZmY2d2ZkljRmVCZlpiSWZGYVVkZ2VKYnlhY2J4ZkVieWU0Z2NjQmNsZHRkY2dFYnhhTWR5ZktlamF3ZWloQ2F5ZnNnTmhUaGhjUmFSZkliZ2MwaHdiTmZ4ZlFnRGJVZ3pna2V3Y1Vid2cxY1pkQmNSYmdia2FNZHpjWWh4YkRkZ2ZJaFBiR2F6YU1lNWdEYVRjWWY4ZEtjQmhFYVlnVmZsaGdmdWFTYmdnTWZ1Y1ZlMWJJZXBmQmRqYlZkU2JBZVNjbGdUZkNkUmhZZkdmVmdpZGNkMGVGaDFiTWVyaE5jQmZBZXhkRmRnZHhiWGdMY3lkQmRRZldlU2hCZ1ZkSWRDaGNlbmRNY1JjTWR1ZEhmQWRaZ2JlWGRCYk1hVGZNZGlnb2Y4ZEliZ2VzY3JhRGVVYzRmVWZVZlNlSWhOYk1lRGNjZlVoQWExaE1mNWNNY0ZiTWFOY1dmUWdVZ1lhSmREZE1nMmFNY1FmNGJDY0RleGVzY3plT2RRZzBoMmJQaENmZ2JSZUdoRmJaY1lnTGZraG9lRGRMZGxhZGJTYktiUWVZZDFiVWZnYkVicGZVZndma2dXZUJmbGVZZG5jTmZCZmRkVGJLZHplUWdRZk1oUmRZaE1lVmh5YjhmZ2dVZUZha2JnZ1ZhU2RBaG5lSmF6ZEVkVGVMYmhhd2VHYldnMWF3YVRhRWJ6Y0llcWJQaENhSWRMYUtkd2QxaE9oRmFGYUVjaWZEZ1RkQWQzZ0ZmQWNOZ1RkT2RUZEJjVGVEZlZna2NGYUdiQ2dRZ3piTmVqYkVnT2JBZ2dlOGNiaE1nemFrYU5lTmVqZ3dob2VFYlJmaGFXYldnQ2U1Z0toQWd5YjVnWGVVaGlia2ZHZE5oVmNJZkJjS2VWZk1jSmJGZGdoWmNXY0phemRRYlhhVWd5aHNoMGZFZERhRWZXZkRkRmZjZnZlSWJGZUJlWmFJZUZiVWVnYkpieWNjY3hoRWh5aDRkY2FCZGxjdGZjY0VkeGhNZXlmS2NqZndiaWVDZHloc2NOaFRhaGVSZlJhSWVnZzBid2NOZnhjUWZEY1VhemhrYndlVWJ3YTFhWmdCZFJoZ2FrZk1hemRZZ3hoRGFnZElkUGhHaHplTWU1YURiVGZZaDhnS2dCZ0ViWWhWYWxhZ2J1Z1NhZ2JNYnVjVmcxY0lhcGZCZ2pkVmVTaEFhU2FsZ1RoQ2FSZ1loR2JWYmlhY2cwZUZoMWJNZ3JiTmFCZUFneGJGaGdieGJYZ0xkeWFCZVFoV2JTYkJhVmJJYUNmY2VuYU1nUmRNZnViSGFBYVpkYmhYZ0JkTWNUZk1oaWdvaDhmSWVnYnNjcmREYlVjNGZVYVVoU2FJYU5jTWREZWNnVWVBaDFlTWI1ZU1mRmdNZE5hV2VRY1VhWWZKZURjTWIyaE1nUWE0Z0NiRGZ4ZnNnemRPZlFnMGcyYVBnQ2NnZVJlR2JGaFpnWWFMZmtmb2hEYkxkbGNkYlNkS2JRY1lhMWhVZmdnRWFwZ1Vid2drZ1diQmVsZVlnbmFOZ0JjZGZUY0toemVRZlFoTWhSZFlkTWVWaHloOGFnYVVhRmhrYmdmVmJTZkFmbmZKZnpkRWNUZExmaGN3ZkdoV2IxYndjVGZFZnpjSWFxZVBmQ2ZJZUxiS2Z3ZzFlT2FGYUZlRWRpZ0RmVGJBZDNoRmNBY05lVGdPYlRlQmdUZURkVmNrZEZlR2ZDZ1FkemhOaGpnRWRPZUFmZ2Q4YmJnTWV6Z2toTmVOY2pmd2NvZ0VoUmdoZ1dlV2NDYjVnS2hBYnliNWVYaFVmaWhrZUdiTmZWZUlhQmFLYlZiTWhKZEZkZ2daZ1dkSmh6Z1FiWGZVaHlhc2cwYUViRGZFZ1dmRGJGYmNjdmJJZEZoQmFaYklhRmVVYmdlSmJ5aGNoeGNFaHllNGNjYUJhbGV0ZWNiRWJ4ZU1oeWhLYWpld2RpY0NjeWVzZk5oVGRoZVJoUmdJYWdlMGN3ZE5heGJRZkRkVWV6ZGtld2VVZXdoMWhaYUJiUmhnaGtlTWJ6ZFlleGNEY2doSWVQYkdoemdNYzVkRGZUZllmOGNLZkJoRWhZaFZkbGhnYXVlU2hnZ01ldWdWZDFjSWVwZ0JhamJWYVNlQWVTZ2xkVGRDYVJlWWNHaFZoaWFjZTBmRmIxZU1icmJOY0JnQWZ4aEZnZ2J4Z1hmTGR5Z0JoUWNXZFNkQmNWZEllQ2VjaG5nTWdSZE1odWVIY0FmWmViaFhlQmhNYlRkTWNpZm9kOGRJY2dnc2VyYURoVWI0YVVhVWZTZ0ljTmdNYURkY2ZVY0FnMWVNZTVnTWJGZU1kTmZXYlFjVWZZaEpnRGZNZTJjTWVRZTRnQ2hEYnhlc2R6aE9iUWMwZDJoUGZDZWdjUmVHYkZhWmNZZ0xma2hvY0RlTGhsZ2RhU2hLY1FjWWYxY1VjZ2VFZXBiVWJ3aGthV2JCYmxhWWNuaE5kQmdkY1RnS2N6ZlFhUWVNYVJhWWdNY1ZoeWE4ZGdlVWFGZWtkZ2dWZ1NoQWNuZkphemJFY1RkTGZoYndiR2FXZDFid2dUYUVkemhJYnFiUGZDaElmTGJLY3dhMWNPYUZiRmdFZ2loRGhUZ0FoM2dGZEFhTmNUYk9kVGNCYlRhRGRWaGtmRmJHZENnUWd6YU5iamRFZk9iQWFnZjhiYmhNZnpha2VOZE5hamJ3YW9mRWhSYmhnV2VXZkNnNWdLYUFjeWU1ZFhoVWhpaGtnR2JOY1ZkSWZCYUtlVmVNZ0pmRmFnY1piV2JKaHphUWNYZFVieWNzYjBiRWdEZUVkV2hEZEZnY2V2YUljRmdCYVpoSWhGZFVmZ2dKYnlnY2d4ZEVjeWI0YmNlQmFsaHRjY2hFaHhoTWh5YUtiamF3ZWloQ2Z5YnNkTmdUYWhiUmhSZklkZ2EwZ3dmTmV4Y1FjRGNVZnpia2V3aFVkd2UxaFpnQmFSaGdma2RNY3poWWR4YURjZ2VJZlBmR2d6Z01hNWJEZ1RkWWQ4aEtjQmZFY1lhVmFsZGdmdWhTYmdiTWN1YVZmMWFJZ3BlQmVqY1ZkU2hBYlNhbGhUaENoUmVZaEdiVmZpZ2NoMGdGZDFjTWhyZ05hQmVBYnhjRmZnZHhhWGFMY3liQmhRZ1dkU2FCZ1ZjSWFDZWNmbmVNZ1JnTWF1YUhlQWNaYWJoWGVCZE1kVGZNZ2lmb2g4ZEliZ2FzZnJiRGFVaDRlVWNVZ1NiSWROZE1mRGFjZlVlQWMxZU1mNWNNY0ZiTWZOZVdnUWZVZ1lnSmVEY01oMmdNZ1FkNGhDaERieGJzYnpjT2hRZTBlMmVQZkNmZ2NSZEdhRmdaZllkTGhrY29jRGhMZWxmZGNTYUtmUWNZZTFiVWNnZEVkcGdVZXdoa2dXZkJobGdZZW5iTmNCZmRiVGNLYnpiUWVRaE1hUmhZaE1nVmZ5YzhoZ2FVY0Zoa2NnZlZkU2hBYm5hSmd6Y0VlVGdMaGhld2RHYVdiMWZ3Y1RjRWN6aEljcWdQZUNlSWZMZEthd2cxZ09kRmNGaEVoaWJEaFRmQWgzZEZnQWNOaFRnT2VUYUJlVGJEYVZna2ZGY0diQ2RRZXpjTmJqY0ViT2dBZGdmOGdiYk1memJrZ05iTmNqaHdjb2NFYlJjaGNXZFdmQ2I1aEtnQWN5YTVoWGJVYWlma2RHYk5kVmVJaEJkS2JWaE1kSmRGaGdiWmdXY0pmemJRY1hoVWZ5ZHNmMGFFZ0RoRWdXYkRmRmZjaHZkSWRGYkJkWmdJYUZiVWNnZUpoeWdjYXhoRWZ5ZzRjY2dCYWxjdGNjYUVleGZNZnloS2ZqYndlaWhDZHllc2VOZ1RoaGdSZFJmSWVnYjBhd2JOZnhoUWJEYlVmemVrZXdnVWJ3YjFkWmJCZVJhZ2JrYU1nemFZZ3hjRGVnYUloUGhHZXpmTWg1ZERhVGJZaDhhS2JCYkViWWFWZGxhZ2J1ZFNlZ2RNZnVjVmMxY0lkcGdCaGpiVmdTZ0FmU2FsY1RnQ2ZSYVllR2FWaGljY2UwaEZnMWNNYnJlTmFCZkFleGhGYWdjeGFYZUxkeWhCZlFkV2FTZUJnVmRJZENiY2FuaE1nUmNNaHVhSGdBZlphYmRYZ0JkTWZUZ01maWZvZThkSWdnZnNkcmNEZ1VkNGNVY1VmU2NJY05jTWVEY2NjVWFBZTFjTWI1Z01iRmFNZ05oV2dRYVVkWWFKZ0RlTWgyZ01jUWg0Z0NkRGR4aHNkemhPaFFlMGQyYVBmQ2ZnZ1JiR2JGYlpkWWdMZmtmb2hEYUxobGVkZ1NkS2RRYlllMWZVaGdkRWZwYlVid2JrYVdjQmRsZFlnbmJOY0JkZGhUZUthemRRY1FjTWZSZFlmTWVWZ3liOGJnZVVlRmNrZmdlVmZTYUFmbmFKZXpnRWJUY0xnaGV3ZkdoV2cxZndmVGhFZnphSWFxaFBmQ2RJZExmS2J3aDFmT2JGZ0ZjRWNpaERlVGdBYzNmRmNBYU5kVGhPY1RjQmJUZ0RhVmdrZkZoR2NDZlFlemdOZmpkRWFPZ0FlZ2c4YmJhTWZ6Z2tmTmNOZWpmd2hvZkVoUmdoZ1dmV2FDaDViS2FBZHlkNWdYZFVjaWNraEdhTmZWZ0lnQmdLYlZkTWdKY0ZiZ2VaZldkSmh6YlFoWGZVZnlkc2cwYUVnRGhFZ1dnRGNGYmNmdmNJYUZmQmFaZUlmRmdVYWdhSmh5ZWNmeGRFY3ljNGFjZkJobGh0ZWNnRWF4aE1keWVLYWpnd2ZpYkNleWFzZk5oVGNoZFJjUmhJYWdmMGJ3Zk5oeGNRZURjVWR6Y2tjd2NVaHdkMWVaZkJkUmdnZGtkTWZ6Y1lmeGREZGdnSWJQZEdjemZNZTVjRGZUaFlmOGRLZUJnRWJZaFZobGdnYXViU2ZnZ01hdWhWZjFnSWZwYUJhamdWZVNnQWZTZWxnVGNDYlJkWWNHZFZmaWhjYTBhRmYxYk1kcmdOZ0JhQWV4ZkZhZ2V4Y1hjTGJ5Y0JiUWdXZVNiQmdWY0llQ2RjY25jTWdSZk1idWVIZkFmWmZiZVhmQmVNZlRkTWJpY29hOGFJZ2dhc2JyZkRnVWI0aFVjVWJTZ0lhTmFNaERhY2VVaEFkMWhNaDVjTWVGZk1nTmhXZ1FiVWVZY0poRGZNYTJnTWFRYjRkQ2dEaHhic2F6Zk9kUWgwaDJiUGVDZ2diUmdHYUZoWmdZZ0xoa2ZvZ0RjTGhsY2RnU2RLZ1FmWWgxYVVhZ2hFZHBiVWZ3aGtoV2hCYWxkWWduYk5kQmFkaFRhS2Z6YVFmUWdNZ1JnWWZNY1ZheWg4aGdnVWVGaGthZ2dWZ1NhQWhuZEpmemVFYlRnTGFoYXdnR2dXZjFnd2dUYkViemhJZXFhUGVDYkliTGVLZXdlMWdPZkZjRmhFZ2lnRGFUZkFnM2JGYkFlTmZUYk9kVGhCZlRlRGJWZWthRmhHZENlUWF6YU5kamNFZk9iQWhnYThmYmJNaHpha2dOY05namd3Ym9lRWNSaGhkV2dXZUNoNWNLYkFjeWI1ZlhkVWhpYWtnR2ROZFZjSWVCY0toVmVNZEpoRmJnZFplV2JKZHpjUWRYaFVleWRzZzBoRWNEZ0VmV2VEYUZiY2R2YklnRmhCaFpjSWNGZFVlZ2hKY3loY2V4ZUVoeWI0YWNoQmZsZ3RoY2hFZ3hnTWZ5YUtmamN3Z2lnQ2R5ZXNnTmdUZmhiUmJSZElkZ2IwYndiTmN4ZFFhRGNVYnpha2Z3aFVhd2gxaFpmQmFSZGdha2NNY3pnWWF4Z0RnZ2FJZ1BjR2h6Yk1hNWVEY1RlWWU4ZEtkQmhFZ1lkVmJsZGdodWdTY2dmTWF1YVZmMWNJY3BhQmhqYVZoU2ZBaFNhbGZUZkNmUmdZZkdnVmFpZGNoMGdGYjFmTWFyaE5oQmZBY3hoRmVnY3hkWGRMZ3lkQmZRZVdkU2RCYlZmSWFDY2NkbmZNZVJiTWR1ZUhlQWVaZmJjWGRCZE1hVGRNZWlob2c4ZkllZ2JzZHJjRGVVYjRoVWZVZFNmSWNOZU1hRGNjZFVoQWQxZE1jNWJNZUZjTWVOZVdiUWZVZFlhSmVEZ01iMmVNZ1FjNGVDZURneGRzZnpnT2hRZTBjMmhQZENmZ2hSaEdkRmFaZVllTGFrZm9iRGdMYWxlZGFTaEthUWJZZDFjVWdnY0VncGVVZndma2JXY0JnbGVZY25hTmVCZWRjVGRLYXpiUWZRZk1mUmVZY01oVmh5ZjhkZ2dVYUZha2RnZVZmU2NBZW5kSmV6YkVlVGhMaGhkd2dHZFdiMWR3ZlRkRWF6ZklocWZQZENkSWVMZktid2gxZ09nRmdGYUVnaWhEY1RnQWYzY0ZiQWdOYlRhT2dUaEJnVGREZVZka2NGY0diQ2dRZnphTmRqZEViT2NBYWdkOGRiZE1oemdrZU5lTmNqZ3djb2VFZ1JkaGVXYldiQ2I1ZUtoQWV5ZDVhWGFVYWlka2ZHZk5kVmVJZEJhS2hWaE1oSmNGZGdiWmRXZEpjemJRYVhhVWZ5YnNhMGJFYURjRWRXZkRhRmZjZHZlSWJGZEJlWmNJZkZmVWNnZ0pleWNjYXhjRWN5YzRlY2ZCZ2xldGFjY0VoeGRNZHlmS2FqaHdiaWJDZ3loc2FOYlRiaGNSaFJnSWhnYzBjd2VOZ3hoUWFEY1VjemVrZXdjVWV3YTFlWmFCYVJiZ2FrZ01nemZZZXhjRGdnaElnUGJHYXpnTWM1aERhVGNZYjhoS2ZCaEVkWWZWY2xhZ2F1ZVNjZ2dNZnViVmQxZ0locGNCZmpkVmVTZ0FmU2RsY1RnQ2VSZlliR2RWZmllY2gwZkZoMWVNZnJlTmJCYkFmeGJGZWdneGFYYkxoeWZCY1FoV2RTZUJnVmhJZkNnY2JuZU1jUmhNY3VkSGRBZFphYmhYaEJoTWJUZ01laWhvYjhnSWNnZXNicmJEY1VjNGJVaFVoU2NJZ05mTWJEYmNiVWFBYzFjTWY1Yk1lRmFNY05kV2ZRZlVjWWVKZkRlTWcyYk1oUWM0YkNiRGV4ZXNkemZPZVFjMGEyZVBlQ2NnZVJoR2VGZ1plWWZMaGtkb2REZkxlbGJkaFNkS2RRZVljMWhVZ2dmRWRwZlVid2RrZFdmQmhsYVljbmZOYUJmZGJUYUtnemdRYVFlTWRSYlliTWVWYXlmOGdnZ1VlRmJrZmdnVmNTYkFnbmFKYnphRWZUYUxiaGV3Y0dnV2ExY3dhVGhFZnpiSWZxZVBjQ2VJZkxiS2R3ZjFhT2VGZEZjRWRpY0RoVGVBZzNhRmdBZU5jVGRPYlRhQmFUZ0RlVmFraEZmR2hDZFFoemZOYmpoRWJPZUFnZ2E4YmJnTWN6aGthTmhOYmpjd2dvYkVhUmFoZldiV2dDaDVmS2dBZHlmNWVYZFVkaWZrYkdjTmdWY0llQmNLZVZmTWFKZEZkZ2RaYldkSmN6YlFhWGFVZ3lmc2YwZ0VnRGVFZVdnRGZGYmNjdmhJZUZoQmZaYUllRmNVZGdiSmZ5YmNkeGhFYXlkNGNjZ0JnbGF0Z2NoRWh4Y01ieWdLYmpmd2JpZ0NkeWdzYk5hVGZoaFJoUmZJYmdmMGV3Y05keGhRZERnVWZ6YWtjd2JVZ3dmMWNaYkJoUmZnZWtlTWF6YVlleGdEaGdoSWZQYkdnemJNaDVhRGZUY1lnOGFLYkJmRWNZZlZlbGhnYnViU2hnYU1odWhWYzFlSWFwZ0JhamZWY1NhQWhTZWxmVGRDYVJjWWRHZFZoaWVjYjBiRmQxZU1ocmNOaEJoQWV4ZUZlZ2d4aFhiTGF5Y0JnUWJXZlNoQmNWY0lhQ2ZjYm5jTWFSYU1jdWVIY0FoWmViY1hjQmJNaFRnTWRpaG9kOGNJaGdmc2NyYkRhVWI0Y1VjVWZTZ0liTmVNZURnY2FVZkFlMWFNZjVhTWVGaE1mTmZXZlFlVWdZY0phRGVNZDJiTWNRYTRlQ2dEZnhkc2V6ZE9hUWUwZzJlUGVDYmdnUmRHZkZoWmhZYkxha2ZvZkRjTGZsYmRiU2JLZlFiWWcxZFVoZ2ZFaHBiVWJ3ZWthV2FCYWxkWWVuY05nQmJkaFRiS2R6aFFlUWFNYlJoWWZNZ1ZieWM4ZmdlVWhGY2thZ2FWaFNmQWZuaEphemRFY1RlTGJoZHdiR2FXZjFhd2RUZ0VjemFJYXFnUGZDZUlmTGRLZ3djMWVPaEZiRmVFZ2lmRGJUZUFnM2dGY0FlTmZUZU9iVGRCZFRjRGVWZGthRmRHZkNhUWR6Yk5namJFZE9iQWZnZThkYmJNZnpha2JOaE5lamV3ZG9mRWRSY2hhV2hXZENiNWdLYUFieWQ1YlhkVWNpZGtkR2dOZlZhSWRCaEtnVmhNYkphRmJnZVphV2RKZ3pjUWZYZFVmeWhzYzBkRWFEZUVlV2JEZkZjY2Z2ZUllRmFCaFpmSWVGYVVnZ2NKZXlhY2R4ZUVneWE0YWNoQmJsZnRiY2FFZXhhTWN5YUtlamN3Z2loQ2J5ZHNmTmNUYWhhUmFSYUllZ2cwZXdmTmh4aFFoRGdVY3pka2J3ZlVid2UxZVpnQmRSY2dma2dNZnpjWWJ4ZURjZ2hJZFBlR2J6Zk1hNWZEYVRiWWc4ZUtjQmNFY1liVmhsYmdldWVTYWdmTWZ1Y1ZkMWNJYnBnQmRqaFZhU2hBYlNobGdUZ0NiUmJZY0doVmhpY2NiMGZGYjFoTWRyaE5nQmVBZXhmRmFnZnhkWGFMY3lnQmJRZ1dlU2hCYVZlSWRDZWNlbmVNZVJjTWZ1YkhiQWRaYmJjWGZCY01mVGhNZWllb2c4ZklmZ2NzYXJkRGJVZzRiVWJVY1NnSWFOaE1jRGVjaFVhQWUxZU1mNWVNYUZhTWVOZFdoUWhVYllhSmVEYU1hMmJNZVFjNGdDY0RmeGVzYXpkT2JRYjBjMmJQYkNlZ2NSYkdmRmRaY1llTGVrZG9oRGFMY2xiZGdTZEtoUWhZYzFkVWNnY0VncGhVaHdma2RXZUJnbGRZZW5iTmRCY2RkVGZLZXpoUWRRZk1iUmhZY01oVmh5ZzhiZ2FVaEZia2FnY1ZmU2hBYm5mSmZ6ZkViVGVMaGhmd2dHaFdjMWZ3aFRkRWR6aElocWFQY0NhSWFMaEtjd2ExZ09hRmJGYkVjaWhEZVRkQWczYkZoQWFOZ1RoT2ZUZEJkVGNEYlZka2NGY0doQ2ZRZHphTmFqYkVmT2RBZ2diOGJiY01nemRrY05lTmNqZ3dkb2dFZVJlaGdXYldiQ2c1YUtlQWJ5ZzViWGhVZ2loa2NHaE5mVmZJY0JlS2RWZE1nSmJGYmdkWmRXYkpiemhRZ1hnVWN5ZnNmMGJFZkRjRWVXYkRlRmhjYXZoSWJGaEJjWmVJZ0ZnVWNnaEpjeWVjZnhkRWd5ZzRnY2hCZmxndGZjZEVheGRNYnljS2RqZndmaWJDZXljc2VOaFRnaGVSYlJiSWRnYTBid2ROZnhkUWhEZ1VnemZrZndkVWZ3ZjFnWmJCY1JjZ2FrZ01kemJZY3hoRGZnaEliUGNHZXpjTWE1aERoVGdZYjhjS2NCZEVkWWVWZmxnZ2J1YlNkZ2JNYXVlVmMxZUlkcGdCYmpnVmVTZEFoU2FsZ1RnQ2RSZllhR2RWZ2ljY2UwYUZlMWNNZXJiTmFCY0FoeGFGZWdheGNYY0xleWNCY1FoV2RTaEJiVmRJaENiY2RuZE1lUmJNZXVjSGJBY1pjYmdYZUJjTWRUZk1maWdvYThiSWJnZXNocmVEZVVmNGNVZlVoU2VJZk5kTWFEZGNkVWZBaDFiTWY1ZU1jRmZNYk5jV2ZRZFVkWWZKZERkTWIyYk1kUWM0Y0NlRGh4ZnNhemFPZVFoMGEyY1BnQ2dnZFJoR2dGZ1pjWWNMY2tob2REZUxjbGFkYlNjS2ZRYllmMWZVY2djRWFwYVVod2drZldnQmRsYllnbmZOYUJhZGRUaEtjemdRYVFjTWFSZFlnTWVWYnliOGdnYVVnRmJrYWdhVmNTZEFkbmNKYnpnRWNUYUxhaGd3Z0djV2ExYXdnVGdFYnpnSWdxZFBiQ2ZJZkxiS2V3YzFhT2FGY0ZkRWRpZURhVGFBYzNjRmRBaE5kVGdPZ1RkQmNUYkRlVmRrYkZhR2JDZ1FjemdOZGpnRWhPYkFhZ2c4Y2JiTWd6ZGtoTmVOZWpnd2VvZkVjUmNoZldoV2VDZTVkS2VBZ3llNWFYaFVlaWZrZUdlTmhWaEliQmhLaFZjTWRKYUZlZ2NaYldmSmZ6ZFFjWGNVZnljc2UwZkVkRGNFY1dhRGJGZmNodmhJYkZlQmVaZEllRmNVZ2dkSmZ5YmNoeGNFY3lhNGFjY0JibGF0ZWNlRWJ4YU1heWFLaGphd2VpaENleWdzZU5jVGJoZFJjUmVJZGdlMGR3Zk5meGJRYURhVWh6Zmtmd2FVZHdmMWVaYkJmUmdnYWtoTWN6Y1lneGREY2djSWRQZUdiemhNZTViRGVUYVllOGhLZkJjRWNZZVZobGZnZHVoU2JnZU1kdWJWYTFhSWFwYUJhamVWYlNjQWNTY2xoVGhDZlJhWWZHZ1ZlaWZjYjBkRmgxZE1kcmFOaEJlQWF4ZUZhZ2J4ZlhiTGN5ZEJlUWdXaFNhQmhWYkloQ2djZm5nTWJSZE1hdWZIYUFiWmdiaFhhQmJNZ1RoTWNpYW9oOGdJZ2doc2NyZkRjVWI0YlVkVWdTaEljTmRNZ0RkY2NVYkFoMWhNaDVoTWVGaE1jTmRXaFFhVWVZZkpkRGFNZDJkTWRRZDRiQ2REYXhjc2J6aE9iUWQwYzJnUGdDZGdmUmFHYUZhWmNZaExka2dvY0RnTGZsZmRjU2hLY1FnWWIxZ1VlZ2NFYnBnVWh3Y2tiV2hCYWxoWWJuZU5nQmNkZVRkS2Z6ZlFhUWNNZVJoWWFNaFZkeWc4aGdnVWRGZmtlZ2JWZlNlQWRuYUphemZFYlRjTGVoZndhR2JXYTFod2dUY0VlemdJZnFlUGVDaElkTGhLZHdmMWVPYUZmRmVFZmloRGJUZ0FmM2ZGZ0FiTmVUZ09hVGNCaFRhRGRWaGtnRmVHY0NnUWF6ZU5iamZFZk9mQWNnZThoYmRNZHpha2dOY05jamV3aG9oRWRSaGhkV2dXZENjNWVLYUFleWQ1Z1hjVWFpYmtkR2ZOYVZmSWJCYUtiVmhNaEpiRmVnZFpmV2RKYXpjUWFYaFVneWRzZjBnRWVEZ0VlV2hEZEZlY2N2YklnRmZCZFpoSWdGZFVoZ2NKaHllY2h4Y0VjeWM0YmNkQmdsY3RiY2RFY3hoTWh5aEtiamR3ZGlnQ2V5ZXNmTmhUZGhhUmFSaElkZ2IwZXdmTmF4ZVFkRGFVZHpna2h3YlVkd2MxaFpkQmVSZGdia2dNZ3pjWWR4ZkRoZ2JJZFBjR2V6ZU1lNWdEZlRkWWY4Z0toQmZFZVljVmdsYmdhdWNTZ2dmTWJ1Y1ZnMWJJYXBhQmhqY1ZkU2VBaFNobGRUZ0NiUmZZZEdjVmNpYmNiMGZGYzFkTWRyY05jQmZBZXhlRmhnYXhlWGFMYnlnQmJRaFdhU2JCY1ZjSWVDZmNobmhNZlJlTWV1ZUhmQWZaZmJnWGFCZU1hVGJNaGlnb2U4ZUlnZ2ZzY3JnRGdVZzRnVWZVZ1NmSWZOYk1oRGVjaFViQWMxYU1jNWJNZUZkTWdOZ1djUWdVYVlnSmdEYk1iMmZNYlFjNGhDYkRkeGNzZXpiT2NRZDBlMmNQYkNlZ2ZSZ0doRmVaZVlnTGNrZ29hRGdMZWxlZGVTY0tnUWNZYzFjVWJnZ0VkcGVVZXdna2FXZkJjbGZZYW5iTmJCZGRmVGhLYnpmUWNRZE1mUmZZaE1iVmd5ZzhnZ2RVYkZia2RnZVZjU2ZBZW5oSmR6aEVmVGVMYmhkd2RHYVdjMWJ3ZFRmRWR6Y0ljcWNQZUNoSWdMZEtod2IxYU9iRmJGYUVnaWNEY1RmQWYzZ0ZjQWhOZ1RkT2ZUY0JkVGhEYVZna2VGaEdhQ2JRaHpjTmNqY0VjT2NBZmdmOGViaE1oemZrY05oTmJqYndlb2ZFY1JhaGVXY1dlQ2M1ZEtlQWN5ZTViWGNVZWlla2JHYU5jVmJJYkJjS2FWZ01iSmVGYWdmWmhXZkpiemRRZlhiVWJ5ZXNhMGdFYkRnRWVXYkRlRmdjYXZiSWVGZkJnWmZJZUZiVWRnY0pheWVjZXhmRWN5aDRnY2RCY2xndGFjYkVjeGRNYXllS2dqaHdhaWFDZXlmc2VOZlRjaGNSZFJjSWRnZjBld2ZOYnhiUWFEYlVnemFrZXdhVWR3YzFiWmRCZ1JkZ2FraE1oemNZZHhmRGhnYkllUGVHaHpoTWM1aERjVGRZZThnS2hCZEVlWWVWZWxmZ2d1ZlNnZ2ZNZnVoVmUxYklkcGdCYWpoVmdTY0FhU2ZsZFRiQ2hSaFlnR2hWYmlkY2QwZkZoMWRNY3JmTmFCYUFleGJGZGdneGZYZUxmeWRCZ1FjV2NTZkJiVmNJYUNkY2RuZ01nUmhNYnViSGhBZ1phYmVYZkJiTWhUaE1jaWdvZzhmSWFnZnNkcmNEYVVmNGJVZlVlU2hJZ05oTWJEYWNiVWVBYzFoTWc1Yk1kRmNNZE5kV2NRY1VmWWdKY0RkTWEyYk1lUWY0YUNhRGJ4aHNjemhPZ1FjMGUyY1BiQ2dnY1JhR2NGaFpnWWdMYmthb2VEYkxkbGVkZlNlS2RRZ1loMWRVZ2dhRWJwZ1Vmd2hrZ1djQmRsZllibmJOZEJoZGJUYktnemNRZ1FjTWVSYllnTWFWZ3lmOGhnaFVhRmVrYmdmVmZTZUFnbmFKZXpmRWJUYUxhaGh3Z0dkV2UxZndmVGJFYnpoSWdxZFBmQ2ZJZUxiS2Z3ZTFnT2hGZEZoRWdpaERmVGNBaDNnRmVBZk5kVGNPY1RjQmFUZURlVmhrYUZjR2RDY1FoemVOaGpnRWNPZ0FlZ2I4Z2JkTWd6ZGtlTmZOaGphd2hvZkVnUmVoYVdlV2ZDYTVmS2ZBZXloNWNYZFVoaWRraEdlTmNWZUljQmhLY1ZmTWRKZkZiZ2NaZ1dhSmR6ZFFlWGZVZXlkc2QwZ0VlRGNFYldhRGdGZWNmdmdJZEZjQmZaY0lnRmZVY2dmSmV5ZWNjeGZFaHlnNGJjZkJmbGV0ZGNkRWF4ZU1heWJLZGpjd2hpZ0NjeWhzZk5lVGFoaFJiUmdJaGdnMGd3Zk5oeGVRZERkVWN6Y2thd2FVZ3dmMWRaZkJmUmFnY2tmTWF6Z1loeGdEZmdjSWRQZEdnemFNZTVkRGFUZ1llOGhLYkJnRWZZYlZobGdnY3VjU2JnYk1jdWNWZjFiSWJwaEJoamFWYlNkQWZTYWxnVGFDZ1JiWWJHZ1ZoaWFjaDBhRmUxY01jcmROZEJmQWJ4ZEZiZ2N4ZVhkTGV5Z0JkUWZXYVNlQmFWYUlmQ2NjaG5kTWdSY01odWJIY0FhWmViZlhoQmhNZlRoTWdpYW9oOGdJZGdhc2dyZERhVWE0Z1VoVWNTYklnTmhNY0RhY2VVYUFjMWFNaDVmTWVGYk1kTmFXZlFoVWhZY0poRGVNZzJmTWFRZTRhQ2NEZnhlc2F6aE9oUWUwZjJnUGRDYWdnUmhHaEZnWmRZYkxla2FvY0RhTGVsZmRoU2VLZVFiWWQxZVVjZ2dFYXBlVWd3Z2tjV2VCYWxnWWNuZk5nQmVkZFRoS2J6ZFFiUWhNYVJkWWZNZ1ZmeWQ4ZmdkVWZGZmtjZ2FWZVNoQWFuZEpiemFFaFRhTGFoZHdkR2FXZDFnd2RUZ0VkemhJZnFmUGJDZklnTGdLYXdoMWRPZUZmRmFFY2lnRGRUZEFmM2FGYUFoTmFUYU9oVGhCZFRmRGFWZmtiRmNHYkNoUWV6aE5kamRFY09oQWJnZDhhYmVNZnpia2VOZE5hamR3Zm9jRWhSZWhlV2VXY0NjNWRLaEFmeWY1ZVhjVWFpZGtmR2ZOY1ZlSWZCYUthVmZNYkpjRmNnYlpkV2FKYnpmUWRYY1VleWJzZzBnRWFEZEVjV2REZUZlY2V2YUlhRmJCZ1pkSWhGYVVjZ2FKZHlnY2F4ZUVheWU0Y2NnQmRsYXRmY2NFY3hlTWh5Y0toamR3ZGlhQ2J5Z3NjTmRUZWhlUmNSY0lmZ2IwYndhTmd4aFFjRGhVYXpoa2Z3ZFVkd2gxY1phQmdSZmdka2JNZnpiWWd4Z0RlZ2dJZlBhR2V6Zk1iNWNEYVRlWWY4ZUtmQmRFY1llVmFsYWdmdWZTZGdjTWR1YlZmMWFJYXBhQmhqZlZoU2VBaFNkbGVUYUNnUmdZZUdkVmVpYmNmMGJGZjFjTWRyZk5lQmRBZnhoRmNnaHhjWGRMaHloQmJRaFdmU2JCYVZkSWdDY2NjbmVNYlJiTWV1Y0hmQWVaZGJlWGVCYk1kVGVNZGlnb2Q4ZElhZ2JzZ3JoRGNVYTRnVWRVZFNoSWVOZ01mRGVjaFVjQWYxZk1jNWRNZkZmTWROYldiUWFVZ1loSmNEYU1mMmNNZ1FkNGRDYkRmeGJzY3plT2dRaDBoMmVQZ0NmZ2NSaEdjRmJaYlloTGFrZm9kRGRMZWxnZGhTZUthUWFZYzFiVWNnZkVncGRVZHdna2JXYkJlbGNZZ25oTmFCZGRmVGRLZ3phUWZRYU1jUmRZZ01lVmR5YjhmZ2FVZUZna2ZnaFZkU2JBYW5hSmV6YkVjVGhMZGhjd2NHYVdhMWF3YlRlRWN6Z0locWRQaENhSWJMZktid2IxZU9kRmVGZUVnaWREZlRkQWczZ0ZlQWROYVRnT2JUZkJhVGVEYlZja2RGZkdoQ2NRZnpnTmFqZkVhT2ZBZGdhOGJiZk1jemFrZU5mTmhqZndhb2dFZ1JoaGFXZ1dnQ2E1aEtkQWJ5ZjVkWGNVYmlka2dHaE5kVmVJYkJoS2NWZE1jSmFGYWdlWmVXaEplemZRaFhjVWV5ZXNoMGVFaERmRWdXaERmRmdjZXZoSWhGYUJmWmhJaEZiVWNnY0poeWRjZ3hkRWV5aDRkY2dCZmxkdGNjYUVmeGJNZHlmS2hqZHdjaWRDZXlnc2dOZVRhaGFSYVJjSWZnZjBnd2FOZnhnUWFEZVVkemNrYXdhVWN3ZTFoWmNCZ1JiZ2JrZ01iemNZYnhlRGdnZklhUGhHZHplTWY1ZURhVGhZZjhnS2RCaEVoWWRWZmxmZ2R1aFNiZ2dNYnViVmgxYUlicGdCZGpnVmVTZ0FlU2hsZVRiQ2JSZFlhR2dWYWllY2gwaEZjMWNNZnJoTmdCZ0FoeGRGZGdleGJYaExmeWVCY1FiV2JTZEJiVmNJZ0NmY2duZE1oUmhNZnVkSGNBZlpoYmNYYUJnTWZUZ01haWVvYjhjSWhnZHNlcmdEYlVmNGdVZVVhU2VJYU5lTWFEYWNnVWNBZTFoTWY1aE1iRmJNY05jV2RRYlVmWWRKYkRjTWgyZk1jUWY0ZUNnRGJ4ZXNhemJPYVFiMGUyZlBhQ2ZnaFJlR2JGaFphWWNMYWtlb2JEZUxmbGdkZlNkS2dRZllkMWFVZGdmRWNwZFVjd2RrZ1dlQmhsaFlibmhOZUJlZGJUZUtkemRRZVFkTWRSaFlkTWdWZnlnOGhnZVVlRmFrYmdkVmhTZ0FhbmNKZHpmRWRUaExjaGN3YkdiV2QxZ3dkVGhFZXphSWVxZVBhQ2VJZExlS2J3YTFlT2dGYUZiRWNpZkRlVGFBZDNoRmNBY05nVGhPaFRkQmRUYkRjVmRrYUZhR2RDYVFoemROZGpnRWVPaEFmZ2Q4Z2JiTWR6ZmthTmJOZGpjd2NvZEVhUmRoYldiV2hDYjViS2VBYXlkNWFYY1VkaWFrZkdjTmdWZkloQmJLZ1ZmTWhKYUZiZ2ZaZFdiSmV6ZVFoWGJVZ3lmc2YwaEViRGNFZ1dlRGhGY2NhdmhJZ0ZhQmRaaElmRmhVZmdhSmd5Z2NneGVFYnlkNGJjZUJjbGd0YmNhRWh4YU1jeWZLY2pod2RpaENleWZzYk5jVGhoYlJhUmdJZWdlMGN3ZU5ieGVRaERnVWN6Ymtjd2ZVYndjMWNaYUJhUmFnY2tkTWR6Y1ljeGVEZmdmSWJQYkdnemNNZzVjRGJUZVljOGNLZUJhRWFZYVZhbGVnZHVhU2FnaE1ndWdWYTFmSWJwaEJlamdWYlNkQWhTY2xiVGdDZFJnWWhHZ1ZnaWVjZjBoRmcxZk1ncmROZUJiQWR4Y0ZoZ2d4YVhjTGJ5YUJnUWRXZlNmQmNWZEljQ2ZjYm5iTWdSZ01idWhIY0FoWmhiYlhjQmRNZlRoTWhpYm9hOGFJaGdjc2FyZ0RiVWQ0aFViVWJTZ0liTmJNZERlY2FVZ0FmMWFNYTVjTWFGYU1iTmNXZ1FlVWhZZkpjRGNNYzJlTWVRYTRlQ2NEZHhmc2d6Z09iUWYwZTJjUGNDYmdoUmFHYkZkWmNZYkxma2NvZURjTGdsY2RjU2NLZlFhWWExY1ViZ2dFZXBlVWN3YmthV2dCYWxnWWFuZU5jQmRkZ1RoS2R6ZVFnUWVNaFJkWWJNYVZkeWM4ZGdjVWNGZWtkZ2ZWYVNlQWNuZUpnemVFZVRoTGhoZHdlR2dXZTFld2RUYkVlemZJZnFjUGdDaEloTGRLZ3dmMWhPYkZiRmRFYmllRGFUY0FhM2dGZEFjTmhUZk9kVGJCZ1RiRGhWZmtkRmJHaENlUWN6YU5iamZFYk9oQWJnYzhhYmhNZXpja2VOZU5oamZ3Z29hRWNSZGhhV2NXaENoNWhLaEFkeWc1aFhoVWNpZmtiR2ROZVZkSWdCZktjVmNNZEpmRmVnZlplV2dKZHpiUWZYZ1VjeWRzYjBiRWZEYUVlV2REZEZoY2N2aEliRmJCYVpiSWJGYlVlZ2hKZ3loY2N4ZEVjeWE0YmNnQmVsaHRkY2ZFY3hmTWh5Z0tmamR3Z2llQ2Z5ZnNjTmVUY2hlUmZSaEllZ2MwZHdnTmF4Y1FkRGdVZHpia2F3Z1Vjd2gxYVpiQmZSY2dla2NNZ3pmWWR4YkRoZ2hJZVBoR2V6Zk1iNWNEaFRnWWE4YkthQmVFYVliVmZsYmdhdWZTaGdiTWF1aFZiMWNJY3BiQmdqZ1ZiU2VBYVNibGFUZUNjUmdZaEdlVmRpaGNjMGdGYjFkTWdyZE5lQmVBZnhnRmhnYnhjWGJMZXlmQmRRY1doU2NCZlZkSWVDY2NlbmVNZVJhTWN1Y0hiQWRaZmJmWGJCZk1iVGhNYmlmb2M4aElkZ2VzZHJlRGNVYjRjVWdVYlNhSWNOZE1mRGNjYlVjQWgxZE1lNWFNY0ZnTWJOZFdlUWVVY1liSmZEZ01jMmFNaFFoNGNDZURheGJzZHpjT2RRYzBjMmVQZENmZ2JSaEdkRmdaY1lnTGVrZ29hRGJMaGxjZGZTYUtjUWVZYjFlVWNnZ0VlcGdVY3dka2VXaEJlbGRZaG5mTmFCYWRmVGNLZHpoUWNRZ01jUmRZZU1jVmd5ZDhoZ2VVYkZla2NnZlZiU2ZBY25nSmN6aEVmVGJMZGhid2ZHZ1dlMWZ3Z1RnRWF6ZEljcWhQZkNhSWRMZkthd2UxaE9iRmJGYUVlaWdEZlRmQWgzYkZkQWhOaFRoT2dUY0JmVGVEYlZha2JGZkdlQ2hRYnpkTmZqaEViT2hBZWdkOGRiZ01lemdraE5nTmJqYndob2ZFZFJmaGRXZ1dnQ2E1aEtnQWd5ZzVlWGhVYWloa2JHY05iVmFJZ0JiS2NWZU1oSmJGYWdhWmVXZUpkemRRZFhmVWZ5YXNhMGFFY0RhRWZXaERnRmhjZnZmSWNGZUJnWmNJaEZkVWZnZ0pjeWJjYnhkRWN5aDRoY2dCYmxldGZjZEVneGJNZ3lhS2FqYXdhaWZDZXlnc2dOZ1RnaGRSY1JhSWRnYTBkd2VOZnhhUWhEaFViemdrZXdoVWJ3YjFjWmJCY1JlZ2JrZU1oemZZZXhlRGFnZklkUGdHZHpnTWI1Y0RlVGJZYThmS2FCZkVkWWZWYmxkZ2J1ZlNiZ2JNZHVlVmMxZUlmcGVCZ2poVmhTZkFiU2ZsZFRiQ2JSY1lmR2VWZ2loY2cwZEZjMWdNYXJmTmVCZEFkeGVGZGdjeGhYZkxmeWhCZlFmV2dTaEJkVmFJZkNnY2huZU1hUmVNZHVhSGRBZlpiYmFYZ0JoTWJUZk1jaWRvZzhmSWNnYnNmcmdEZ1VhNGVVaFVnU2hJYU5nTWJEZWNlVWNBYTFoTWI1Z01mRmVNZk5iV2JRZ1VkWWhKaERmTWUyZU1hUWg0YkNhRGV4YnNmemVPZFFjMGgyYlBhQ2RnZ1JnR2ZGYlphWWVMZWtjb2ZEZkxibGdkZVNjS2dRYVlhMWZVaGdiRWZwYlVld2drY1dnQmRsYllobmNOZ0JjZGVUYUtjemdRZlFmTWFSYVljTWFWZXloOGZnaFViRmhrZGdnVmdTZ0FibmRKaHphRWhUYUxiaGh3YkdiV2MxYXdmVGhFZnpjSWZxaFBlQ2dJZkxkS2R3ZjFiT2ZGaEZhRWVpaERmVGdBYzNjRmJBY05nVGhPaFRlQmRUYURmVmdraEZjR2hDYVFiemJOYWpiRWdPZUFnZ2g4Y2JmTWJ6YWtlTmVOaGpnd2FvaEVnUmNoYldoV2VDYzVmS2RBYnlkNWJYZlVoaWNrY0dnTmJWZ0lhQmNLY1ZnTWdKZ0ZmZ2JaY1dhSmZ6YlFnWGZVaHlmc2QwZkVkRGJFZ1dmRGhGZ2NhdmdJYUZoQmdaZElnRmVVZ2dnSmF5aGNmeGRFZ3lkNGdjZ0JmbGV0YmNmRWd4Z01ieWJLZGpld2hpZkNmeWZzYU5oVGVoZFJlUmRJZWdoMGV3aE5jeGVRZERlVWJ6Ymtnd2FVZndnMWRaYUJoUmJnY2thTWF6Y1lieGdEaGdmSWVQZkdmemZNZDViRGFUZ1loOGFLaEJkRWVZZlZjbGNnZ3VmU2dnYU1ldWZWaDFjSWdwZkJoamhWZVNiQWVTZ2xlVGdDY1JnWWFHaFZkaWdjZTBkRmExZ01ncmJOYkJiQWZ4ZUZlZ2F4YVhoTGV5aEJlUWdXZlNhQmJWZklnQ2NjZm5oTWRSaE1kdWJIaEFiWmJiYlhlQmFNZVRnTWdpY29lOGJJZmdhc2FyZ0RjVWc0ZlVmVWNTZklkTmhNZkRjY2ZVYkFhMWdNaDVkTWJGZk1oTmZXYVFlVWhZYkpnRGRNaDJjTWFRYTRhQ2NEYXhhc2h6ZU9nUWgwYzJkUGNDZWdhUmhHZUZlWmFZYUxna2VvY0RiTGFsZ2RmU2RLYVFoWWYxYVVkZ2JFZnBnVWN3YWtoV2hCZWxlWWRuYU5hQmZkZlRlS2J6YVFhUWdNY1JmWWJNYVZjeWg4Z2djVWVGYmtnZ2JWZFNmQWZuZEplemhFYVRiTGRoYndjR2dXZDFid2NUaEVkemdJY3FlUGdDZElmTGJLZHdoMWZPZ0ZoRmdFaGlmRGVUaEFjM2RGZkFiTmNUY09hVGJCYlRhRGdWYWtkRmNHY0NkUWV6Yk5lamdFZE9hQWZnZDhnYmFNZ3pha2NOZ05iamJ3aG9oRWNSY2hiV2RXY0NkNWdLYkFheWg1YlhlVWVpY2toR2dOaFZnSWhCZEtjVmNNaEphRmRnYVpkV2RKY3pmUWFYY1VieWVzYjBoRWhEaEVnV2dEZ0ZhY2Z2YUlhRmVCYlpjSWZGaFVoZ2NKYXloY2R4ZEVleWc0YWNoQmZsZ3RiY2VFaHhlTWF5YUtmamJ3ZmliQ2R5ZnNiTmJUZ2hnUmdSZ0ljZ2EwZ3dmTmZ4YlFlRGJVZHpla2R3Y1Vld2cxaFplQmhSZGdia2RNZnpiWWF4YURoZ2JJYlBnR2J6Z01hNWZEZlRlWWE4YktmQmdFYlliVmFsaGdkdWRTYmdkTWF1ZFZmMWdJYnBiQmVqZ1ZnU2VBZVNlbGNUYkNkUmFZYUdkVmFpaGNjMGFGYTFkTWJyYk5oQmZBZnhlRmJnZ3hjWGZMYnliQmVRYVdoU2dCZFZkSWhDaGNjbmdNZlJlTWZ1YUhiQWhaZmJjWGRCZk1hVGFNYWllb2M4YUlkZ2JzYXJjRGdVYjRkVWJVZlNlSWROYk1nRGJjZVVhQWYxYk1lNWVNYkZiTWROYldnUWJVaFlkSmdEZ01lMmVNZlFiNGVDZkRmeGhzYnplT2ZRYzBmMmVQZENiZ2RSZkdmRmVaZVlnTGJrZm9kRGRMY2xkZGJTYUtkUWdZaDFkVWJnZkVhcGZVYndka2dXY0JibGFZY25jTmVCZGRhVGdLYXplUWdRZE1jUmZZaE1oVmN5ZzhlZ2FVY0Zma2JnYVZmU2ZBZW5iSmd6YkViVGZMZGhkd2RHZldoMWh3Z1RlRWZ6YUlkcWhQYkNiSWZMZktid2ExYU9iRmFGYkVnaWVEYVRjQWgzY0ZnQWVOZlRlT2RUaEJhVGZEZlZoa2NGY0dkQ2JRY3piTmZqYUVmT2ZBZWdjOGFiYU1hemhrY05jTmNqZ3djb2dFZlJhaGJXZVdhQ2Q1YUtkQWZ5ZzVlWGRVZWlha2VHYU5lVmVJZ0JhS2JWZU1lSmNGZ2doWmhXZkpiemJRZFhmVWF5Y3NlMGdFaERhRWRXZkRmRmZjZ3ZiSWZGZkJlWmFJY0ZiVWZnZEpieWZjY3hnRWh5ZzRiY2JCYWxldGFjZUVmeGVNYnlkS2ZqYXdkaWZDYnlmc2ZOaFRhaGVSY1JoSWZnaDBid2dOZ3hhUWFEYVVkemRrY3djVWN3YjFhWmdCZVJmZ2NrY01kemhZZXhhRGdnZkliUGdHYXpoTWg1ZERoVGdZaDhiS2dCZ0VnWWNWY2xnZ2h1YlNkZ2JNY3ViVmIxaElmcGhCZmpoVmVTaEFkU2dsZ1RmQ2NSZVloR2RWZWloY2gwY0ZhMWRNZXJiTmFCZEFkeGdGZmdmeGFYYUxkeWJCYlFmV2RTY0JkVmdJZ0NlY2JuZU1oUmdNY3VjSGFBaFpmYmhYZEJnTWVUaE1naWhvYjhiSWFnY3NmcmVEaFVmNGVVZ1VmU2VJYU5hTWJEaGNoVWRBZTFoTWY1Z01lRmJNaE5iV2FRYVViWWVKYURjTWQyZE1mUWM0aENnRGR4ZHNjemNPY1FoMGMyZlBjQ2FnZ1JoR2ZGaFpoWWRMaGtkb2hEZ0xlbGZkZFNoS2FRY1lnMWVVYmdhRWJwZ1Vkd2VrY1dlQmhsYVlibmhOYkJiZGRUYktmemFRZ1FjTWhSYVliTWVWYnlnOGFnZ1VlRmhrZmdhVmNTZEFjbmNKZ3pnRWZUZExjaGZ3YUdjV2UxZHdlVGdFYXpkSWNxZVBiQ2VJZExkS2N3aDFlT2VGYkZiRWdpZURkVGVBZDNhRmdBaE5iVGRPZlRiQmdUYkRnVmFraEZnR2ZDZFFjemROZGpjRWFPaEFjZ2U4aGJoTWd6Z2thTmVOYmphd2FvY0VjUmdoY1dmV2FDZDVhS2FBZXlkNWRYaFVjaWZrY0diTmFWaElhQmFLYVZhTWJKaEZnZ2haZldmSmZ6Z1FiWGFVaHlkc2IwYUVlRGJFY1dnRGhGaGNkdmJJaEZnQmFaY0ljRmJVZGdlSmd5ZmNleGFFYnllNGFjaEJibGR0ZWNmRWN4Zk1keWNLZWpid2NpZUNleWJzZE5nVGhoaFJnUmRJZGdkMGh3Y05ieGJRZkRiVWd6Y2tmd2NVZndoMWJaZ0JkUmFnYmthTWh6YVlmeGFEZ2dnSWZQaEdlemdNYjVmRGdUaFljOGVLZUJjRWNZYVZhbGNnZ3VhU2JnZ01kdWhWYjFoSWVwYkJmamZWY1NnQWhTZGxmVGdDZ1JoWWVHY1ZjaWhjZjBhRmExY01hcmJOY0JjQWN4ZEZjZ2d4YlhjTGR5Y0JkUWdXaFNnQmdWZkljQ2hjZW5nTWRSZ01idWFIYkFkWmNiYVhiQmFNZ1RhTWhpZG9kOGFJYmdjc2NyZkRnVWU0Z1VjVWNTZ0loTmFNYURhY2NVZEFnMWFNZjVoTWVGYk1oTmhXZVFjVWhZYkpiRGdNZzJlTWhRYTRhQ2FEZHhic2F6YU9iUWQwYjJmUGNDZmdmUmNHYUZkWmVZZUxma2JvYURkTGNsaGRjU2hLZFFkWWMxY1VnZ2ZFZHBlVWV3Z2tjV2FCY2xiWWhuZE5lQmJkaFRoS2F6ZFFkUWFNZ1JiWWRNYVZheWc4Y2djVWhGaGtjZ2FWZlNnQWduZkpoemhFZFRlTGdoZndlR2JXZDFhd2JUZ0ViemhJY3FlUGRDZUlhTGFLYXdlMWdPZEZiRmhFYWlhRGZUYkFmM2hGaEFkTmRUZU9kVGdCZlRlRGFWZWthRmhHZUNkUWV6YU5namNFYU9kQWhnYThnYmVNZHpja2ZOZ05iamR3Ym9hRWNSYmhlV2hXYUNlNWhLYUFjeWg1YVhoVWVpYWtiR2hOYVZmSWJCYkthVmFNZEplRmZnaFphV2dKZnplUWdYY1VheWVzYzBiRWZEZkVhV2JEaEZkY2Z2aEllRmdCaFpoSWRGZVVkZ2ZKaHliY2V4Z0VkeWg0Z2NhQmhsaHRjY2RFZXhoTWN5ZEtiamZ3YWllQ2V5Y3NoTmFUZWhhUmRSY0ljZ2YwaHdmTmV4YVFlRGRVY3pma2h3ZlVjd2UxaFpnQmNSZmdka2JNZHpiWWh4ZURjZ2dJZlBmR2V6aE1hNWhEYVRlWWc4Z0tiQmhFZVllVmNsYWdidWVTZGdkTWF1YlZhMWZJZHBmQmVqYVZhU2ZBY1NibGFUaENiUmJZYkdoVmZpYmNoMGFGZzFkTWVyZ05mQmVBaHhmRmNnZ3hmWGZMYXlmQmNRZFdhU2ZCZFZmSWhDZWNnbmJNZVJnTWF1YUhoQWFaYmJoWGFCZk1iVGRNY2lhb2Q4Y0ljZ2dzZnJnRGNVZzRnVWVVZVNmSWNOZE1kRGZjZFVnQWgxYU1jNWNNYUZmTWZOZVdlUWJVZVlkSmJEZU1nMmRNZVFiNGJDYkRkeGZzZXpmT2RRZDBkMmhQZUNmZ2JSZkdlRmVaaFloTGNrZ29hRGFMZmxlZGFTZUtmUWdZZzFmVWRnY0VjcGJVZHdja2FXZEJmbGRZY25iTmdCZ2RiVGhLYXpoUWhRZE1nUmJZZE1iVmV5ZjhmZ2NVZEZia2ZnYlZkU2VBZm5mSmh6YkViVGRMZWhld2hHY1dkMWR3YVRkRWJ6ZUlncWVQY0NnSWhMYkthd2ExZk9hRmZGZEVkaWFEZlRhQWQzYkZmQWdOYlRmT2JUY0JlVGFEZFZha2FGaEdkQ2hRY3pjTmhqZkVnT2RBYmdiOGFiYk1iemdrZ05lTmFqYndjb2JFYVJmaGNXZ1doQ2g1ZUtmQWV5YzVjWGZVZGlha2NHZU5lVmhJaEJlS2FWYU1hSmhGY2dkWmhXYUpnemRRaFhhVWZ5Y3NkMGZFaERlRWdXZERiRmFjZHZhSWVGZUJiWmRJYUZmVWdnZEpneWhjaHhjRWR5YzRlY2FCZ2xldGVjZEVheGFNZXlkS2ZqZndkaWhDZXljc2ROaFRkaGFSYlJlSWVnZTBjd2ZOZnhoUWhEZVVhemJrZXdoVWZ3YTFlWmNCY1JmZ2hrY01hemdZYnhhRGJnY0lmUGdHZnpmTWY1ZERkVGZZZDhlS2RCY0VnWWZWZ2xmZ2R1ZFNiZ2VNZXVhVmExY0llcGVCYWpjVmVTZEFkU2ZsZFRhQ2RSZVljR2hWYmlmY2MwZ0ZkMWJNZXJhTmFCaEFneGdGZWdheGRYZ0xkeWJCaFFjV2ZTZkJkVmdJZENnY2FuY01mUmZNYnVoSGJBYVphYmJYZEJoTWRUaE1kaWRvZThlSWJnY3NncmZEZVVkNGhVY1VoU2VJZE5kTWREYWNjVWJBZTFhTWI1ZE1lRmJNYk5iV2dRZVVoWWNKY0RlTWcyZk1kUWc0ZUNiRGF4Y3NkemJPZ1FhMGQyZlBiQ2NnY1JjR2JGYlpnWWJMZmthb2NEZExmbGNkYVNoS2RRYlloMWZVYWdkRWRwYVVid2JrZldlQmVsY1ljbmFOZUJmZGZUaEtjemFRYlFhTWJSZ1loTWJWZHloOGhnYVVnRmJrZ2dlVmJTY0FkbmZKZnpjRWJUZUxhaGh3ZkdmV2YxYndkVGNFZXpjSWZxaFBjQ2NJZ0xnS2d3YzFmT2FGZUZlRWRpZERhVGdBZzNkRmhBZE5lVGdPZlRkQmdUZkRhVmFrZkZmR2NDaFFmemNOY2pnRWVPYUFnZ2U4YWJjTWN6aGtiTmJOYWpjd2JvaEVoUmhoY1dnV2JDZjVlS2JBY3llNWhYaFVnaWNraEdiTmhWYkllQmhLY1ZlTWRKZEZmZ2ZaZFdjSmh6YVFlWGZVY3loc2gwZkVjRGdFaFdlRGZGZGNjdmhJZEZmQmFaZ0lkRmRVYmdlSmV5aGNoeGRFYnloNGdjYUJnbGV0Z2NoRWd4Y01oeWNLY2pid2FpZUNjeWhzYU5iVGhoY1JiUmhJaGdhMGV3aE5keGJRZERoVWV6Ymtod2RVZ3dhMWRaYUJnUmZnZ2tiTWd6ZllheGNEYWdkSWNQaEdkemVNYTVmRGRUZ1llOGRLYkJlRWFZZ1ZobGZnY3VoU2RnaE1hdWFWaDFmSWhwY0JlamdWZFNmQWRTZGxiVGJDZlJhWWJHZFZiaWNjaDBiRmgxaE1ocmFOZEJlQWd4ZkZjZ2F4ZlhjTGZ5Y0JoUWhXZFNhQmJWY0loQ2FjaG5kTWFSaE1ndWVIaEFiWmJiZFhnQmdNYVRnTWdpZ29oOGFJZGdic2NyaERoVWE0Y1ViVWFTZUllTmJNZkRoY2ZVZEFoMWVNZzViTWJGY01oTmJXZ1FnVWFZZUpiRGNNZDJoTWNRYjRoQ2JEaHhnc2N6Zk9lUWUwYjJlUGRDYWdkUmZHZUZlWmhZYUxka2FvYURjTGdsZ2RiU2dLZ1FoWWgxY1VmZ2dFZnBkVWN3aGtjV2VCZGxlWWZuYU5jQmNkZ1RiS2N6ZFFkUWNNZlJiWWJNaFZkeWc4ZWdoVWJGZ2thZ2RWZ1NmQWhuZkpnemRFaFRnTGdoZndhR2ZXaDFid2RUZkViemhJZHFiUGRDZkliTGRLYndkMWNPZUZlRmNFZ2llRGJUYkFhM2VGaEFjTmJUYU9kVGhCY1RhRGJWZmtnRmZHaENnUWV6Y05hamJFZE9mQWJnZjhmYmNNZXpka2NOZU5hamJ3Zm9jRWdSZmhmV2dXZ0NkNWJLaEFkeWI1YlhlVWdpY2toR2VOZ1ZhSWdCYUtkVmhNZEpiRmFnYlpjV2ZKZXpmUWdYZ1VjeWFzaDBnRWJEYkVoV2ZEY0ZjY2Z2ZkliRmhCZVpmSWFGZVVkZ2NKZXlhY2F4YUVheWc0YmNmQmZsYXRlY2NFZHhkTWZ5YUtjamR3ZGliQ2N5Y3NmTmZUZ2hnUmRSZkliZ2YwZndmTmh4ZlFmRGNVZXpha2N3YVVid2ExZVpiQmhSYmdoa2JNZnpnWWJ4ZkRjZ2dJaFBnR2F6ZU1iNWREYlRnWWE4ZktkQmZFZFlhVmFsZWdndWZTYWdnTWh1ZFZhMWRJYXBiQmFqaFZjU2hBZ1NibGhUYkNkUmhZZUdjVmJpZGNoMGZGZDFiTWdyY05kQmVBY3hkRmVnZ3hiWGhMZ3loQmJRYldlU2JCZVZkSWdDZmNlbmJNZlJjTWF1YkhlQWhaYmJjWGNCaE1oVGhNZGljb2c4Z0liZ2VzZ3JiRGNVZzRmVWdVYlNlSWJOZU1lRGZjZ1VjQWMxZU1hNWdNYkZkTWJOaFdlUWVVZFllSmJEYU1kMmFNY1FmNGFDYURkeGFzaHplT2VRYzBlMmdQZkNlZ2NSZ0dkRmdaZlljTGRrZm9lRGhMaGxlZGFTZkthUWZZZzFnVWhnZEVkcGJVYndka2ZXYUJjbGdZZ25iTmFCZGRkVGVLZXpoUWRRY01oUmFZZ01mVmZ5ZjhiZ2NVZkZja2FnZlZkU2RBZG5nSmJ6ZUViVGRMZWhjd2FHZVdjMWR3Y1RiRWJ6Y0lmcWZQZkNoSWNMaEthd2ExYU9mRmZGZUViaWREZFRiQWUzZkZhQWZOYVRmT2JUaEJhVGNEZFZoa2hGZ0dhQ2dRZ3piTmNqaEVlT2FBYmdjOGNiZE1hemdrYk5kTmdqZHdnb2hFY1JiaGFXZVdjQ2M1aEtkQWR5aDVjWGdVZGlla2hHZE5nVmZJZ0JoS2FWYk1jSmFGaGdiWmVXY0pmemVRZlhmVWN5YXNmMGdFZURiRWZXaERoRmNjZ3ZhSWVGZ0JjWmNJZUZnVWFnY0pmeWFjaHhoRWN5YjRmY2RCYWxmdGZjY0VkeGVNY3lmS2JqZ3doaWFDY3loc2hOZVRlaGVSZ1JlSWFnZjBnd2FOYXhkUWFEY1VhemNrZHdhVWF3ZjFjWmdCaFJiZ2hrYU1nemFZZHhiRGRnZEloUGFHZHplTWg1Y0RmVGdZYzhiS2NCYUVmWWVWYWxhZ2V1ZlNoZ2FNZHVnVmUxZUlmcGNCZWpnVmFTaEFiU2dsZlRhQ2dSY1ljR2ZWYWlmY2UwZUZlMWZNZ3JiTmdCZkFoeGNGZ2doeGJYYkxleWJCYlFlV2VTZkJiVmhJZkNiY2VuZk1oUmNNYXVkSGZBZlplYmZYZ0JoTWJUZE1kaWFvYzhmSWVnYnNhcmZEZlVmNGRVZVVoU2dJZk5nTWREYWNjVWZBaDFhTWg1Z01lRmFNaE5nV2JRYVVlWWZKaERmTWQyZE1kUWU0YUNlRGR4ZHNmemNPYVFmMGUyaFBhQ2hnYlJiR2VGZVpiWWVMaGtib2VEYUxobGZkZFNmS2hRZllhMWJVZGdkRWNwY1Vod2drYVdhQmJsZVlmbmNOZkJoZGVUZktkemhRaFFiTWVSYVljTWVWZnlkOGNnZVVnRmdrZ2doVmdTYkFkbmFKZ3poRWhUYkxiaGJ3Y0doV2gxZndhVGRFZHpmSWRxY1BnQ2hJZUxnS2J3ZzFlT2NGZkZjRWVpZERkVGdBZjNmRmdBZ05jVGNPYlRoQmhUaERkVmdrZkZoR2FDY1FhemROZGplRWdPYUFoZ2Y4Y2JjTWV6ZWtkTmhOY2pid2ZvYUVjUmRoZFdkV2RDZjViS2VBY3loNWVYZ1VmaWZrZ0dkTmJWZElhQmJLYlZmTWJKZUZkZ2FaaFdkSmF6ZlFiWGhVZ3lkc2gwZEVkRGRFZldmRGZGZWNndmRJYUZhQmVaZ0lnRmhVYmdjSmJ5YmNheGdFZXliNGhjYUJhbGR0ZWNmRWh4Yk1leWRLZmpod2RpYkNheWJzZE5nVGZoYlJhUmhJY2diMGV3Zk5ieGZRaERhVWZ6ZGthd2FVYXdmMWRaYkJhUmJnY2tkTWJ6ZVlleGdEZGdoSWVQZkdjemJNZDVnRGFUYllmOGRLZ0JoRWJZYVZibGRnYnViU2JnYU1kdWJWZDFnSWdwZUJhamNWZVNnQWJTaGxiVGRDZVJjWWNHZFZhaWZjZzBjRmIxYk1hcmJOaEJmQWF4ZkZoZ2J4ZVhlTGJ5Z0JmUWJXaFNnQmVWZklhQ2RjZW5jTWRSYU1mdWVIZEFjWmdiY1hhQmZNZVRnTWRpYm9iOGNJYmdlc2VyZERoVWU0YlVkVWNTZ0lnTmhNY0RkY2dVZkFkMWhNZDVkTWRGY01mTmJXaFFiVWRZaEpoRGdNYzJhTWJRYzRhQ2REYXhhc2d6YU9jUWEwYjJkUGFDaGdmUmNHYUZoWmdZY0xka2ZvaERmTGRsZmRkU2hLaFFoWWYxZ1VhZ2JFZXBhVWJ3YmtlV2VCZ2xoWWFuYU5oQmRkZFRmS2Z6Y1FlUWVNYVJnWWVNYVZmeWE4YWdmVWJGZmtkZ2dWYVNoQWZuZkpoemNFZFRnTGdoZndoR2RXZDFhd2dUY0VjemNJY3FnUGFDYkllTGJLZndkMWZPYUZlRmdFZ2ljRGdUYUFnM2VGZEFiTmdUaE9nVGRCZFRoRGFWZGtmRmRHYkNiUWV6Zk5hamRFYk9oQWZnZThmYmNNaHpma2FOZ05kamZ3ZW9kRWhSZWhnV2FXZENiNWVLaEFleWE1YVhiVWZpZGtnR2VOZFZlSWZCZUthVmFNZ0plRmdnaFpkV2JKZ3plUWhYZFVneWVzaDBlRWhEaEVjV2REZUZjY2N2YklhRmZCY1poSWdGY1VhZ2VKZnllY2V4YkVneWY0YmNmQmhsYXRkY2VFaHhmTWF5Z0toamZ3ZWlmQ2J5aHNiTmdUZmhnUmRSZklnZ2MwYXdmTmJ4YlFhRGZVYXpja2h3YVVld2QxZlpmQmJSaGdna2hNaHpiWWd4ZURhZ2FJYVBmR2N6Y01oNWJEaFRmWWU4Z0tlQmhFZ1lkVmdsaGdndWNTZGdoTWJ1aFZoMWZJZ3BnQmNqZlZjU2VBZFNlbGNUY0NmUmZZYUdoVmZpZ2NoMGVGYTFkTWFyZ05nQmhBZ3hiRmdnZHhlWGFMYnllQmVRZ1dnU2RCaFZiSWdDZ2NnbmNNZ1JnTWJ1YUhjQWdaYmJoWGRCZk1oVGNNYmlob2M4ZUlhZ2RzYnJjRGVVYzRoVWZVZ1NnSWhOYU1iRGdjYVViQWIxYk1iNWNNY0ZmTWhOZldiUWVVZ1liSmFEZU1oMmVNZ1FoNGNDZ0RheGRzYnpkT2FRYjBoMmVQYUNmZ2JSZ0diRmZaaFlnTGJrZ29iRGFMZ2xhZGJTZ0tiUWhZYTFhVWFnZkVhcGVVZ3doa2FXZUJkbGVZZ25iTmFCZmRoVGZLYnphUWdRYk1hUmNZZk1nVmF5YzhhZ2ZVaEZia2JnaFZoU2JBZm5kSmJ6ZUVnVGRMZ2hnd2VHaFdnMWZ3ZVRjRWZ6YUlkcWRQZ0NhSWhMY0tkd2QxZE9lRmhGYUViaWZEYVRhQWMzZ0ZmQWVOYVRiT2RUY0JlVGhEZVZna2NGZ0djQ2NRZ3pnTmZqZkViT2VBY2doOGNiYk1lemNrZk5oTmdqZXdnb2hFZlJoaGhXYldjQ2M1Y0tnQWh5ZDVhWGZVYWlma2FHY05mVmVJYkJoS2FWYk1jSmVGaGdjWmJXZUpjemhRZlhjVWZ5YXNiMGNFaERjRWNXZkRoRmNjaHZoSWdGY0JjWmdJYkZlVWRnaEpieWZjYXhiRWV5ZTRoY2ZCZGxndGhjYkVjeGRNaHllS2dqZ3djaWhDY3lmc2ROZ1RnaGJSZlJoSWZnYTBjd2NOZHhnUWFEZVVoemZrZ3dnVWN3aDFhWmNCY1JhZ2RrYU1hemhZZ3hmRGRnaElmUGJHYXpkTWg1ZURkVGNZYThhS2dCY0VnWWVWY2xlZ2h1ZVNoZ2VNZXVlVmgxZklkcGJCYmpiVmJTZUFkU2JsZFRnQ2ZSZllkR2RWZ2liY2YwZ0ZiMWZNZHJlTmFCYkFleGRGYmdmeGhYY0xkeWdCZ1FkV2ZTZkJkVmNJY0NlY2VuYk1oUmZNZnVoSGVBZFplYmRYZkJoTWVUZE1naWZvZThkSWVnZnNjcmNEY1VlNGVVaFVkU2NJZU5lTWdEZmNjVWNBYTFlTWE1Y01mRmRNZ05jV2VRYVVoWWFKZkRoTWUyZE1jUWg0Y0NhRGZ4ZHNiemNPZ1FjMGQyZ1BiQ2dnZ1JhR2RGY1piWWJMZ2tlb2REZExibGVkYVNlS2FRZFlkMWdVaGdlRWZwZVVkd2NrY1dmQmhsZVlnbmZOZkJkZGVUY0toemRRZFFhTWVSZ1ljTWRWZHliOGhnZ1VoRmNrY2doVmNTYUFjbmFKYXpoRWJUZkxlaGh3aEdlV2MxZndlVGNFY3pkSWhxY1BoQ2JJYUxlS2d3YzFmT2VGZUZkRWhpaERkVGJBZjNkRmhBZ05nVGFPY1RoQmZUaERiVmVraEZmR2VDZlFkemZOaGpiRWZPaEFkZ2E4YmJkTWh6YWtnTmVOZGphd2ZvZEVkUmJoZVdkV2JDZjVoS2FBYnlkNWFYYVVoaWNrZ0dmTmdWZUllQmVLY1ZkTWJKZkZoZ2ZaZFdiSmh6ZlFlWGFVZXloc2IwZEViRGVFZVdkRGhGYmNndmJJaEZkQmZaYkllRmVVY2dmSmh5YmNieGdFZ3ljNGRjZkJobGh0Y2NhRWZ4Yk1leWFLaGpod2VpZENleWZzZ05jVGdoZ1JjUmJJYWdjMGV3Y05keGhRZERiVWh6YWtld2VVaHdkMWJaYkJoUmFnYWtiTWR6YVlneGdEY2dkSWZQY0dhemZNaDVjRGVUYllnOGhLZ0JhRWFZYVZlbGNnZnVkU2RnZU1odWdWYjFjSWRwZEJjamZWZFNoQWZTZ2xoVGdDYVJkWWdHaFZhaWRjZTBoRmExZE1kcmNOaEJjQWV4Z0ZoZ2Z4Z1hhTGZ5ZUJjUWJXY1NhQmVWaElmQ2FjYm5jTWJSYk1odWNIZUFoWmZiZVhmQmFNZVRiTWdpYm9hOGJJYWdmc2dyZURlVWM0YlViVWhTZUloTmdNYURiY2hVY0FjMWVNYjViTWhGZE1hTmNXYVFnVWRZZkpnRGhNZzJhTWJRZTRoQ2VEY3hic2h6Y09nUWEwaDJiUGNDZWdjUmhHZ0ZoWmJZZ0xha2dvZERlTGNsZGRhU2VLaFFmWWcxZlVkZ2RFaHBkVWJ3ZGtiV2RCZGxlWWRuYU5mQmZkYVRmS2N6Y1FnUWJNYlJjWWZNY1ZjeWQ4YWdmVWVGZGtiZ2ZWZ1NkQWJuY0poemZFaFRiTGJoaHdnR2VXYTFhd2dUZEVnemNJZnFmUGRDZUlmTGdLZXdhMWhPYUZmRmVFY2lhRGhUZkFnM2hGaEFkTmVUZ09nVGJCaFRiRGRWYmtjRmNHZENjUWZ6Y05lamRFY09iQWFnYzhoYmRNYnpia2ROZk5kamV3ZW9lRWhSYmhnV2dXY0NkNWVLYUFkeWM1Z1hhVWNpZmtiR2FOZVZhSWdCYktnVmNNaEpoRmdnZlpjV2FKYnphUWJYYVVheWFzYTBmRWdEZEVmV2dEYkZlY2R2aElkRmVCYlpmSWdGaFVhZ2VKYnlmY2J4YkVkeWg0ZGNnQmJsY3RhY2ZFaHhkTWJ5YUtlamN3YmljQ2d5ZnNmTmVUaGhhUmFSaEliZ2IwZ3djTmN4Z1FkRGRVZ3pna2J3ZlVnd2QxaFphQmVSYmdka2NNZHplWWF4ZURmZ2JJZlBnR2Z6Zk1iNWFEY1RiWWY4ZUthQmRFZ1loVmRsYmdndWhTaGdlTWd1ZVZjMWhJZ3BiQmdqYlZjU2FBYlNibGdUYUNhUmJZYUdhVmhpZmNjMGZGaDFiTWFyYk5oQmhBYXhiRmdnZXhjWGNMZHljQmRRYldhU2NCZlZjSWFDZGNjbmhNZ1JhTWZ1YkhmQWdaZGJoWGhCZU1lVGVNYmljb2Y4ZklhZ2VzYXJkRGJVaDRoVWhVZVNkSWROZE1iRGJjYlVnQWIxZU1kNWFNY0ZnTWJOZVdkUWdVaFlhSmNEYk1nMmFNZFFlNGRDaERkeGNzYnpkT2RRZTBhMmdQaENhZ2JSZkdkRmhaZ1ljTGhrYm9kRGdMZmxjZGNTaEtmUWdZZDFnVWZnY0VocGNVaHdja2JXZkJkbGFZY25lTmNCZmRiVGRLZ3pjUWZRaE1lUmZZZU1oVmV5YThnZ2ZVZ0Zja2JnYlZhU2hBYm5hSmJ6YkVhVGNMYWhhd2hHZldiMWJ3aFRjRWR6ZUllcWVQZUNjSWdMZktmd2gxYU9hRmNGZUVlaWVEZFRkQWQzYkZoQWVOZ1RjT2FUZ0JiVGJEY1Zka2hGZkdjQ2hRZHplTmJqYUVhT2RBZGdkOGdiYk1hemhraE5oTmZqYXdmb2NFZlJmaGFXYldkQ2I1aEtoQWd5YjVoWGRVZGlia2VHY05lVmRJaEJnS2VWYU1oSmJGaGdnWmhXaEpnemFRYVhmVWF5aHNoMGNFY0RjRWZXaERoRmRjaHZkSWRGZkJiWmNJaEZlVWJnYkpmeWJjaHhiRWN5ZzRlY2FCZmxhdGJjYUVoeGRNZnlhS2FqZndmaWdDZnlhc2ZOY1RlaGZSaFJnSWZnZDBld2NOZHhkUWVEZlViemVrYndnVWV3YzFjWmNCZVJoZ2drYk1memRZY3hmRGRnZElkUGZHZnpmTWE1ZERkVGVZZDhmS2RCZkVnWWVWYWxkZ2F1aFNnZ2RNZnVjVmExZklhcGRCZ2pkVmhTZ0FhU2hsZVRjQ2NSZ1liR2ZWaGlmY2EwZkZiMWJNZnJiTmZCYkFoeGZGZGdjeGNYaExoeWRCaFFnV2NTYUJkVmNJYkNmY2huZU1kUmdNaHVmSGRBZVpiYmJYYUJjTWZUYk1laWJvYjhjSWdnY3NmcmhEZVVkNGNVaFVjU2JJZk5oTWFEYWNmVWhBYTFoTWQ1ZE1kRmdNZE5jV2JRaFVoWWRKZ0RjTWQyZ01nUWQ0ZkNiRGF4Z3NmemFPYlFiMGUyZlBnQ2NnZlJlR2hGZFpjWWRMYmtib2JEZ0xibGFkYlNiS2VRZ1lhMWFVYWdkRWVwaFVmd2ZrZldhQmFsY1ljbmNOZUJjZGdUZ0tiemZRZlFmTWZSY1lkTWNWYnlkOGNnYlViRmNrY2djVmNTaEFkbmVKZXphRWhUZ0xmaGh3ZkdjV2QxZXdoVGdFYnpnSWhxY1BnQ2NJZUxiS2V3YjFoT2FGZEZiRWFpZkRiVGRBYTNjRmRBZU5lVGhPaFRhQmdUYURnVmRrZ0ZhR2NDaFFkemhOZGpkRWRPYUFoZ2U4aGJnTWN6aGtkTmROYmpid2FvaEVoUmZoZFdhV2hDYTViS2VBZHlmNWdYYlVmaWJrYkdhTmZWY0llQmZLZFZmTWVKZUZhZ2ZaYldiSmh6ZVFkWGhVYXlmc2gwZ0VhRGZFZ1dnRGVGZ2NkdmFJZEZoQmRaZklhRmhVZmdlSmV5ZmNkeGJFYnljNGJjZUJlbGF0ZGNlRWZ4Z01keWhLZWpmd2NpYkNieWdzZk5kVGJoZlJoUmVJY2djMGJ3Yk5neGZRZ0RnVWh6ZWtkd2ZVZXdlMWRaY0JjUmdnZ2tnTWh6aFloeGhEYmdnSWZQYUdlemVNZTVnRGNUZVlnOGdLZkJhRWZZZlZibGFnYXVjU2RnZU1jdWdWYzFlSWRwY0JjamZWZ1NoQWRTYWxlVGNDZVJnWWJHZ1ZjaWFjaDBhRmUxZE1ncmFOYkJlQWJ4aEZlZ2h4Z1hlTGJ5Z0JhUWhXZVNlQmJWZUloQ2JjaG5kTWZSZU1ldWVIZUFmWmJiZFhnQmZNZFRnTWJpY29jOGhJYWdoc2hyZkRmVWI0Y1ViVWdTZUlhTmVNZERlY2hVYkFhMWJNZzVhTWRGZk1jTmdXZFFnVWNZZ0pmRGNNZjJnTWVRZjRjQ2FEZ3hjc2Z6aE9kUWIwZzJhUGNDZWdjUmRHZ0ZoWmdZYUxha2RvYURnTGZsaGRnU2VLZFFhWWIxYVVnZ2hFY3BhVWZ3Y2tiV2VCZ2xoWWRuYU5hQmNkZ1RkS2h6Y1FnUWRNaFJkWWZNYlZoeWY4ZGdlVWdGaGthZ2FWZFNiQWhuZ0pnemFFZ1RmTGJoY3doR2NXYzFnd2JUZ0VlemJJaHFhUGhDZUlnTGFLY3doMWNPZkZkRmFFZmliRGFUZEFoM2JGY0FkTmVUYk9iVGRCY1RmRGRWY2thRmNHZENnUWF6Zk5iamFFZE9nQWFnZjhlYmdNY3pla2NOZU5lamN3YW9nRWdSZ2hnV2ZXaENhNWFLaEFjeWc1YlhnVWNpYWtnR2NOaFZkSWdCZ0tjVmVNYUpjRmFnZ1pnV2RKZHpiUWJYY1VkeWdzaDBmRWhEYkVkV2NEYUZlY2R2ZkloRmZCYlpnSWhGYlVjZ2FKZXliY2d4Z0VjeWg0ZGNjQmVsY3RiY2ZFYnhiTWZ5YktiamV3Z2llQ2V5YnNlTmVUZGhiUmFSYklkZ2cwZ3dhTmV4YlFlRGVVZnpka2d3ZFVod2ExYlpnQmhSZWdka2JNZnpoWWJ4Y0RkZ2NJZlBhR2R6Zk1hNWJEZ1RoWWg4Z0thQmZFYllnVmZsY2dodWdTZ2dlTWV1Z1ZhMWJJaHBmQmJqaFZkU2dBY1NibGZUZUNjUmhZaEdnVmRpYmNnMGNGYjFnTWVyZE5lQmNBZ3hhRmhnY3hnWGdMZXlnQmJRZVdiU2NCaFZhSWNDZWNjbmFNZVJmTWh1ZkhiQWZaZ2JiWGZCYU1kVGdNZGlkb2E4aElkZ2FzY3JlRGJVaDRkVWNVZVNjSWhOZU1lRGFjYlVmQWQxZk1nNWRNZEZiTWJOY1dnUWZVZlllSmNEaE1jMmZNYVFmNGNDYURjeGFzZnplT2RRZDBhMmZQZUNiZ2JSYUdiRmRaY1lmTGhrZW9jRGdMYWxnZGNTaEtiUWJZYzFkVWRnZEVicGdVaHdma2RXYUJhbGdZaG5nTmJCZ2RmVGhLYXpjUWFRYU1iUmRZZU1lVmF5YjhnZ2RVaEZna2ZnZVZoU2FBZ25iSmN6Y0ViVGhMYWhmd2ZHY1dlMWZ3Z1RiRWN6Y0lncWdQY0NjSWdMY0tod2UxZ09hRmRGZ0VkaWNEZFRhQWIzYkZmQWNOY1RjT2hUYkJlVGNEaFZoa2VGZUdkQ2ZRZHpjTmFqZUVlT2dBYmdiOGNiZE1oemVrYk5nTmJqZndhb2NFYVJiaGhXZ1diQ2E1ZktiQWR5ZzViWGVVZGlka2VHZU5nVmNJZUJnS2dWaE1mSmVGaGdiWmFXZ0piemFRZlhhVWF5aHNkMGZFYkRkRWhXaERnRmFjYXZkSWhGYkJoWmVJY0ZhVWJnYUpmeWdjY3hnRWd5ZDRlY2ZCaGxodGNjZUVieGhNYnllS2dqZXdhaWdDaHljc2FOaFRlaGhSZFJlSWFnZzBod2hOaHhmUWdEZFViemdrZndlVWV3YjFhWmNCYVJnZ2ZrY01jemNZYXhlRGVnYUlnUGZHaHpnTWM1Z0RjVGhZaDhhS2hCZEVjWWRWZmxiZ2Z1ZFNiZ2dNYnViVmUxY0lncGFCY2poVmhTZ0FjU2dsYVRlQ2NSaFlnR2JWY2lkY2QwZUZiMWRNZXJiTmdCYUFheGRGYmdheGJYY0xoeWhCZlFoV2JTZkJhVmhJZkNlY2VuYU1iUmFNYXViSGdBYlpiYmNYZEJnTWJUZ01kaWNvZzhlSWZnaHNhcmZEY1VhNGdVZ1VkU2dJZU5kTWdEaGNoVWZBZDFmTWY1ZU1iRmRNY05lV2RRZFVkWWJKYURhTWIyZU1iUWc0YkNiRGF4ZnNmemVPYVFjMGEyZlBjQ2FnYVJkR2hGY1plWWNMZmtmb2REYkxnbGhkZ1NjS2NRZ1llMWJVZmdjRWFwY1Vmd2drYldlQmFsZVlibmFOZkJoZGdUY0tmemFRY1FmTWdSaFlmTWNWZHlnOGRnYVVhRmhrZmdhVmFTZUFobmNKZXpkRWRUZExnaGJ3Z0djV2gxZ3dkVGRFY3phSWZxYlBlQ2ZJZExnS2h3ZTFnT2dGYkZjRWNpZkRjVGZBZDNlRmNBYU5oVGVPYlRkQmVUYURkVmRrZEZiR2RDZVFhemNOZGpjRWRPZkFlZ2M4ZGJnTWJ6ZWtkTmdOZWpkd2NvZEVlUmhoYVdkV2dDZDVkS2dBaHliNWRYZlVoaWJrZUdiTmhWYkllQmVLZFZlTWJKaEZoZ2ZaYVdnSmZ6ZlFkWGNVYnlic2MwZUVnRGNFYldjRGFGYmNmdmVJZkZkQmJaZEloRmZVaGdnSmR5aGNieGdFZ3loNGJjZ0JmbGR0YWNkRWd4Z01jeWRLYWpod2JpZ0NmeWFzYU5mVGFoaFJiUmJJZ2dmMGR3YU5meGhRZ0RjVWV6ZGtld2RVYXdlMWNaYkJlUmZnZ2toTWN6YVlheGREZ2dhSWRQY0dkemZNYzVnRGNUZ1loOGdLaEJoRWdZZ1ZnbGhnYXVhU2NnZk1odWZWZDFiSWJwY0JiamNWYlNkQWJTZGxkVGhDaFJhWWNHZFZmaWhjaDBjRmUxZ01icmZOaEJhQWR4Y0ZiZ2h4ZVhiTGZ5aEJlUWRXZVNnQmVWYklnQ2JjY25iTWZSZU1idWJIYUFnWmZiZVhoQmhNZVRiTWJpZm9jOGJJYmdlc2hyYURoVWU0aFVlVWJTZUloTmJNZkRjY2dVaEFkMWFNYjVnTWhGYk1lTmJXZlFhVWFZZUphRGZNYjJhTWRRZTRiQ2JEYXhkc2R6YU9oUWgwaDJiUGNDZGdoUmFHaEZlWmhZYkxha2hvZkRkTGhsZWRmU2FLY1FoWWgxYlVnZ2NFZXBkVWh3ZWtlV2hCYWxoWWduY05iQmNkaFRkS2R6ZlFmUWJNYlJiWWdNZFZjeWY4ZWdhVWRGY2tlZ2hWY1NoQWVuY0pmemhFYlRjTGZoaHdhR2dXYzFjd2NUZ0VkemdJYnFhUGFDZ0liTGhLZXdhMWZPYkZmRmJFYmljRGdUZEFlM2ZGYkFiTmhUYU9jVGhCZ1RnRGhWY2tiRmVHaENjUWV6Y05mamFFZU9nQWRnZDhhYmFNYnpka2NOZE5kamV3Y29jRWNSYmhnV2ZXZ0NlNWJLZkFmeWY1Y1hjVWhpYmtnR2FOY1ZkSWZCYUtjVmVNZUpoRmVnZFpjV2VKZHpkUWRYZVVneWhzZzBlRWVEY0VnV2REYUZnY2N2ZUloRmRCZ1plSWdGZFVhZ2JKYXlnY2N4Y0VleWc0ZWNmQmJsZHRlY2hFaHhoTWN5Z0tlamJ3Y2ljQ2F5aHNiTmVUaGhkUmhSZ0llZ2cwY3dhTmN4ZlFjRGZVZnpoa2F3ZlVnd2IxZVpkQmNSYmdla2ZNZnpiWWR4ZkRnZ2ZJYVBhR2R6ZU1iNWhEYlRjWWg4Y0tlQmdFaFlhVmFsZWdkdWVTYWdiTWJ1Y1ZiMWZJY3BkQmFqYVZmU2dBYlNobGNUaENmUmNZZkdhVmNpY2NoMGVGZDFlTWRyY05iQmhBYXhoRmFnYnhkWGVMYnljQmhRYVdhU2dCZVZiSWhDYWNibmJNZVJnTWV1Z0hjQWRaYWJlWGhCY01iVGVNY2lnb2g4ZEllZ2NzZXJhRGFVYTRhVWdVYVNiSWFOZ01jRGZjY1VhQWUxY01kNWNNaEZmTWVOaFdmUWZVY1loSmZEZk1oMmZNYlFmNGNDY0RleGJzZXpiT2JRYzBmMmdQZUNmZ2VSZ0dkRmVaYVlkTGhrZm9iRGNMZ2xhZGhTaEtjUWZZaDFhVWFnZUVncGRVZHdka2JXZUJobGVZZW5lTmVCYWRlVGFLZHphUWFRZ01mUmFZaE1lVmN5ZThkZ2VVZ0Zja2VnZlZhU2ZBZW5mSmZ6Y0VlVGNMYWhmd2RHZldlMWR3ZlRoRWJ6ZEllcWVQYUNnSWdMZEthd2gxYk9jRmhGaEVnaWZEZ1RlQWMzYUZnQWhOZ1RlT2FUaEJoVGVEaFZoa2VGZkdiQ2RRY3pmTmhqaEVhT2VBaGdjOGhiYk1hemVrZU5nTmFqY3dkb2VFZ1JmaGJXZFdjQ2Y1YkthQWd5ZzVlWGRVZmlma2hHZU5iVmJJZkJjS2VWZk1mSmNGYWdjWmZXZUpmemZRZlhoVWR5ZnNlMGZFY0RiRWhXY0RoRmNjZ3ZkSWVGZEJhWmNJYUZiVWNnZEpheWFjYnhkRWR5YzRlY2JCZWxodGFjYUVleGhNZHlhS2FqZndhaWdDY3ljc2hOZ1RkaGVSZ1JhSWRnYjBhd2FOYXhiUWZEZVVjemZrYXdiVWh3ZzFnWmRCZlJiZ2ZrYk1lemNZZXhhRGNnaEljUGNHZHpoTWE1YkRmVGJZZThnS2RCZkVkWWhWY2xmZ2h1ZVNmZ2VNY3VoVmQxYUlicGJCYWplVmZTZ0FkU2ZsZFRiQ2JSZlljR2dWaGllY2UwZUZjMWFNZ3JjTmdCY0FheGRGZGdoeGdYYUxieWdCZlFhV2NTYUJlVmZJY0NiY2duYk1iUmhNYXVoSGNBZlplYmZYYUJmTWVUYk1iaWJvYjhlSWZnZ3NhcmFEY1ViNGNVZFVlU2FJaE5jTWFEZWNoVWdBZDFhTWY1Yk1mRmNNY05hV2NRYlVjWWhKYURjTWIyaE1jUWE0Y0NoRGR4YnNlemdPZ1FjMGYyZVBkQ2NnZVJkR2FGZ1phWWdMYWthb2VEYkxobGNkYVNoS2FRZVlhMWdVYmdlRWVwZ1Vmd2ZrZFdjQmZsZVlobmdOZEJiZGhUYUtlemJRYlFoTWFSaFlmTWVWZXlmOGdnYVVhRmNraGdnVmNTaEFjbmFKZXpnRWhUZkxlaGN3aEdjV2QxZHdmVGNFZXplSWhxYlBnQ2dJaExnS2J3aDFjT2FGZEZnRWNpZERhVGRBYjNjRmhBYU5iVGhPaFRoQmVUaERiVmNrY0ZiR2JDaFFkemFOY2pkRWZPYUFiZ2I4aGJkTWV6ZmtlTmVOZGpld2FvZUVnUmJoZVdhV2FDYzVnS2JBYnlnNWdYZlVmaWNraEdmTmRWZEloQmNLZVZhTWVKZEZlZ2VaaFdiSmZ6ZlFmWGFVaHlmc2YwZUVhRGdFYVdiRGZGZWNldmFJY0ZlQmdaZUlkRmhVY2dhSmV5Y2NieGJFYXlmNGFjaEJmbGV0ZGNnRWV4Yk1meWRLY2pld2JpaENoeWJzZU5kVGFoaFJoUmJJZGdoMGJ3YU5leGVRYkRoVWN6ZWtnd2ZVYXdkMWRaZEJjUmFnaGtjTWJ6aFlneGZEZmdnSWhQaEdnemNNYjViRGFUZVljOGVLZEJkRWJZYlZkbGJnZXViU2hnZE1kdWNWYTFiSWNwZEJkamdWZFNnQWVTZ2xjVGVDZFJhWWJHaFZmaWRjZTBhRmQxYk1lcmROZEJhQWJ4ZUZiZ2N4Z1hiTGZ5ZkJlUWFXYlNnQmNWaElhQ2ZjZm5nTWZSZ01idWRIZEFoWmNiZ1hnQmNNZVRjTWJpYm9nOGZJaGdmc2dyZERoVWg0Y1VoVWVTZklkTmZNYURhY2dVY0FjMWJNYjVoTWNGY01kTmhXZFFjVWFZYkpiRGFNZDJhTWJRYTRmQ2FEZnhic2F6Y09nUWgwYTJoUGRDYmdlUmVHZUZnWmVZZkxia2NvZkRnTGdsZGRoU2NLYlFoWWIxZVVoZ2JFYXBlVWV3ZGtmV2JCaGxnWWVuZE5jQmVkZFRkS2d6ZVFmUWZNaFJiWWZNZFZieWI4ZGdiVWJGZWtmZ2VWaFNnQWVuZkphemZFZFRmTGFoZndnR2ZXYTFod2NUZUVlemhJZ3FkUGJDY0lnTGVLY3dnMWZPYUZmRmVFY2llRGNUZUFmM2hGYUFmTmRUZk9hVGJCYlRnRGVWZWthRmVHaENjUWR6ZU5jamFFYk9oQWJnYzhnYmRNaHpia2JOZ05jamh3aG9oRWJSZ2hoV2RXaENnNWVLaEFmeWE1aFhiVWVpYWtiR2NOZlZnSWdCYUtlVmdNaEplRmRnZVphV2JKYXplUWdYYlVneWdzZjBkRWVEaEVlV2JEZ0ZoY2F2Y0ljRmRCZ1plSWJGZ1VnZ2dKY3lhY2h4YUViMmMxZ0JkQWhGYUZjU2FGaHhmTWY0aEhmemVJZ3FhSGdtZ1FoMGNRY0FiSmFWaEtmZ2FrZWtlZGJrZDliQ2dVYWpjUWI1aFViQWFwZVVhTmR4Y0VlcmNJZFhlNGgvYkdnQWZZYkhhSGh5Z2RiamRZYlRoQWcyZEphaGFVZVlkWGdHZzBnZ2FRZWhoWmdoZVhia2dNYnFiQ2hUZ1pjQmRSZDNlVWdWYkVod2MxYWNiT2JrZHdkeGNHYlZnc2c1YUpkbGNFZmphR2NDZmRlUGNEZHllQmFZZVNmMmhZZEpiWmVpaFpjdWZlZGxoOWJGYVdia2QwY2RjZGNCZE5nU2VMaFNiUWV2Z1lod2hVZHJjSGFVZHBmU2RWZXlmc2dZZkloamJNYWNmUWhrZUVnd2VQYTBoRmNMZ1hoZ2JJaExmYmZuYkllN2NQY2diY2RVaFNmUWI0ZWliTmEwaHNmamdNY2lhQWRaaEhna2JNZURnUWZnZ3RmUGRSYlJjRWJaZGJoMWZaYjljRWUwZWNlQmVFZmdiVmJRZURjbGgwZzJiSWJCYk5lR2ZPZFRlY2RWYWVhWGIxYUtmSGZHZGxmemVHZEJoaGdtZllneWU0Y25kTmJUY1VoRGZLZWdjaGJIY1JnRmZJZ0FhQWRIZVFmN2FOY2lnSWJEYU9iVWZ0Z09jQWZGZlZlb2dUaERhOGFpZ1ZoUmZFYlZmTmVqYmxlR2FTZTBkOGJNZENiemNZZjZnY2hEZWtoY2hUZFdhTmJhZmZiMWZKYUxiZmVYZlVhcGVUZ0hoTWU2Y0ZobWVkZkRlRWFUZ3RhQmJRaEhoVmVJYmZlRmRRZ09hUGdGZTBkZGdFZGtkbGhUYktnVGQ5ZFpmUmNTYU1nM2ZBYXljVWVTYUNhUmdrY2piTWNoaHRnQWFQZmxmd2ZuYk5lU2hsY2FiVmNHaGNnY2VFZmxlTmhlZEFkUmhzZzdoSmhYZXBhcmNHYVdoWmNMZlhkVmVzY1FoUGgyYlpoMmFkYWdhWWZRYlFkRGIxZmNnRWdrZHNnWWJRZTBoWmFpYWVkamNjZzhkQmZ3aEVmSWRGZmdhRWV3Y0FkaWhSZzBmSmRnZWNhY2hYZWxkd2I2ZEJoVGNvYnRnUmNGZ1VmcGJEZjJnQWhCaFJnM2VVYlZoR2JsZWhoT2VIYmlhNWFrYlFmaGR4Y0FjY2FsZUZhM2hWZTFoQWRXY2FkeWhkZkRoVmhpZlZoQWdMZHlja2h2YWNobGZWZXlkUmQwZmRiSmNSY0FnVWFYZE9heWgxZTZnSmd3Zmdnc2dBZGtnRWhYYkVmR2VKZEtlZGNqZklhWGZCZEZod2YyZ01leGN3YktnVmRRaGRlemVZZW5oSmh3ZGNmRmJkYURjRGVSZjhiemhNY1FmVWJ5Z2NjaGZJYXFnVmhSZUJjTGRZZ1NlRmFGY2JieGFFZVRhZGNVYmRheGNYaEFhVWVpY1VmQWdzaEViUmdSZUJnN2diZDFhWmNCZU1keWJJZVVoT2JCaEZnS2ZVYnpoRWR4ZldkVWNvY3lnUmEwZXhobWVZaFhkQmFWZmNiRmVwY1BlV2FFZ1VhRmVIYlNnWWUvY0toV2MwaDFhRWZpZ01nUGVUYnhkQWQyYVJhSGQ5ZC9iZWRFY0lhVmRlYkhiWWJJYVNoeGZBY1hlVmZ4Z29nS2RHZkhjQmhWZFFneGZ0ZVNkZmdIY0ZnUWhYZlNhZGFnaFhhd2YxYllmVWREaHNlSGhSYlNkbGZFZVhjU2R3Y1RiT2FsYXdnSmRhYUJoMWRCZlVjQmF3YzZoWmRuY0loRWVVY0RmNGVuZUFiemhsY1hnUWdsYkFiOGZMZTFhVmhNZ0xlMWFzZW9hWmRtaGtia2ZYaEdoOGRCaGJkUmEwYmRmVmdWYklkeWJQZ2plUWRnZ0dnU2JNZUVoUWhWYUpjQ2FiY0FmbGgvZ2RnZ2JsYW9lRmNYZWhlMmVFZWtjc2NZZUNoaGQ5Z2liZWZqZWthTGVEY1RoNWFBZldiaWVjZTlnSGN5aEllb2RKaDFlY2ZRY2FmMWF3ZVZoQmJRZUFjM2JRZFZid2U5ZUVmeWdBYkllYmVXZGdlVmNTaEZoQmNIZEViRGVBaHpoQmhCY1VhbGJjYWtmeGUzaFhld2FOY3RhTGRCZ3diV2VCYVdkWmhQZFpmaWQ5YTdnY2RCYUJlamVXZ2dhc2NIZ0hmVmVSYkRoZWdHaHNnL2VPYXhiMGZsYUdjVmNzZUJoQ2JtZVFmWGhLYzNjWWZQZVNjd2c1ZFNoZGJoYUpoTGdHYUVjTmFaaE1kRGJjZ2tmSmhSYW9mTmhTY1FiNGdPaFBkVGNaYTVnT2JTZmdhYmZGY1JjaGdXZlpla2E0YmRoUGMxaDVkQmdPY3hhUmMvZ0Vjd2RoaGtlRmNRY2RlZWdBY2tnZ2YyZlBjUWVSaEJlT2ZYYzVmUmFKZlZmNWFHY0ZlbWdFYnVjR2VGYlJnbWdDaFdmWmFuYmNkWGFsaFpkYmV4ZFZiSmdXYkVlVWNGYUhkU2ZZZC9oS2FYZGhlbmJhYmtoc2NQaFVla2MxZU9oVGNIZlpoMmVVZmhmUmRVZkthbmZaZWJnU2V3Y1ZkRGhBYWpiOWFwaFdibmVCYUliUWIwYmtiSWdNYkNid2dlaEpjVGJSYXBnWGQzaE1iUWJHaFdhZ2NMYVJhV2U4YVpoUWVXY0VkS2VjZHdiNWVIZVBnQmR4ZEVlZWJraGNiUWdaZ25mSmJXZEZoV2NJY2dnWGh6YVJkWGNWaHhiWWRnYmFjQmJvY3lkWmVoaFJkbWZaYm1mRmV3Z1hkVGcxYVVhQWR4aDBkQWRWZFJhUWRoYkphVGdrYjNmQmFDZlVmRmREYTFjcGNFYWFmRWR3Zi9kZWRsZ0llSGZIYkhiZ2Z0aE9iRWZzYVloUWUxZGxjaWhjZW5iQmV3Ykdoa2gwZEdkVWNpZkZoMGJTZ3phNWR6YWFhUWZzZkZlT2RoZ2xlb2dDYzBlVmF2YUVjUmROZnZlUmQzZU5mOGhCZFNhSmJRZENod2dSZkpnVmFDZ01jMGhIZzFjc2Z2YkFmZ2FNYTRnQmV3YTllRWFQYlRmZ2RlZlRjR2VvYVVmTGcyYnBiaGdLYjNhOWZ2ZFdna2JjaGRhSGhWYlZoU2VkY0dodGM2ZFlmMGgwYXBiQmNFZ0VkVWdXZlNiTWVaY0poRGhjYlFmRGRsYUJiaWVkY2hkTmVhYkZkR2RsZ1piWWFuZ0phd2JjZEVhaGFEZ1NiVmdwZDFlZWFFZnNieWVOYURhd2ZhaEhiRWNKZFllS2hrZWNoQWRkZFJiRWFTZWZoMGZ0YlpiRWIwZGRib2FGYVViaGNRY1JieGdCZm1iY2FsZVlmVmJMYlRlY2NGZ2JoVmVjaFBkR2drYU5kaGNGY2hoaGNtZkZlR2NaZW1jWWdYZkJjVmNNYWxkTmVjY05heGgxaFZoVWRuYlJncmFlaGphNWhFaFpnbWhFZFBjVWVoZUJna2dUaEhkWmQrZkFhRWZ4aGJnZWZHY3NhU2hEYlVkMGJOZkdiamZZYTdhUGZ6ZDViSWVTZ3hmMWhUZmRoU2ROZWhjZGIzYXBocGRWZTFia2hRaEdjV2ZoZ2RnQmJEZTBhUmRXZW1lOWNhZFdnUmROaEhjYWNCZ1ZiSWJVYkVlY2NRZ1pmbmdJZENmRmFXZnhoMGRVYlNoTmNaZ05hV2NraHNhTWJuYnRmWGdJY2tlRWZxYUlkMGV0Y3dmVmVXZTliYWRSYXhlMGRkYlZlVmZKYzBoYWUzZnBiOGNUZ1Nkd2FlZ1FhUmdGYUVhTGZRZU1iNGJkZmxicGhMZEZnU2JOYmNmRWNrY3NoWWNRYjFmbGRpZGNkbmJCYndnU2dFZ05kSmFXYW5lVmM0Z1NneWdVZC9iUGdRYUlnTGRYZGhja2M4YmNkRWhjZXJjVmFGZVVjdWJFYWpmOWVIZVJmUmFVaE9jWWZsZEJlSGRFYkdlWmF5ZVZiaGJWYXFkY2JsZ0ZlM2VWZDBob2RXaE5jRWVzY1dkR2ZHZFlkVWRaaG1nWmVoZGNkRmdWYnZnV2JrY2NkSGFIZ1JlTWZIY09naWFnYXVhS2hnYUlla2VTY3diZGhiaEViRGI5ZG1hZGFuZVpkU2RRaGhlVmg0YmRjaGNKZ0xiR2dFYk5oWmRZZ25kSmR3ZGNiQmVvZ0doSGdRYThnbmVOZWtlc2RqYVloVWVOZFhoV2NSZEFkWmFhZUFndGJGYWJneGdFZFRjYmMwZ2RmemJFZXhhcGR6ZlBiMGhoZ1FmUmd4aEJhbWhjYWxnWWhWYU9iRGdjY0ZjSWFnYVVjRWhGZGpjdGF2YVVnaGhBYnZkR2ZHZ1pma2NJZ0hkSmRaY2JkeGhOZU9iRWFSYTBmY2dTZFZjNWVyZ2VnbWdOZ05nYWNrZnRoU2NXZ3hheGZPaFRkSGZaZDJnVWNrY0liVmZjZkNnUWhjZEJoQmVoZmVmV2FTZFFjbmdQZmpkTWhjZ0NiZ2FZaFVoZGRYaEFiZmFlYzNkb2E3ZlhibGFsYkxlTWIyaGdjTGNSZFdnOGNSYkVlMmU5Y0hlSWZWZlllVGZQYlVlY2NHaFVnQ2FoaFNoTGhEaGNoVmZRZFdoUWdpaEFlemRnaERkQmFVZUlhd2dNaFZkTWdXYkxlbGhVZzFmQ2FUYVljK2FKY1RiMGJWaEZlMWdoZ1BnQWRRYXRkNmVLZURic2R2ZkFlV2RJZ2ZmQWYxYkpoQ2diZlZmZGRjY2RlbGhKZUNjRmJYYWhhMmZUZDBiSWVVZ2FiVmhsZWljY2RuYUJmd2ZTZ0Vjc2JiZVZlQ2FWZjRmVmduZ2RjNGFhYTFjNWJWZk9iaGdsY29lQ2EwZFZhdmVFYVVhRmNuaFRheWNFZmRiRmFHYmdnSWJTZkVlSmVPZEdkVWh4Y3lhVmdoY1ZicWNlaDBjcGNkaFZoMGZwZkxlWWJHY2xmdGVNZG1nWWdVYVpkbWNZY25oSmZSYXNmc2REZGdkNWVTZFVnMWhWYmFiSWhHaGRnNmhNaFVnRmJxZUFnZ2JaZlNjU2IwaDViTWhkZ25oWmRTZFFkaGVWYTZoSWcwZEVhT2RHY0JlQWdOZk1jRGFzYXpiSmdFZHBkWWFZZjFlcGQxaGVoRWh0ZjNkZWFtZEVmUmFEZkZlNWRhYVBiRWdJZktnSWNSYkVkYmNPaDBjNWV6YlNlR2ExYm9oRmNVYmhoUWdSaHhlQmZtZ2NkaGRCY0FmSmJEYUVmRmJQYWhnZ2VFZEZnaWd4Z3BnSGh4Y2dkOWVQaG1lWmZtZFloWGVCZlZiYmgxY3BlSGdIZFJhMGZCYkFiQ2gxY3JhSWZVZWxhTmVhZGtmc2dQZ1VkaGNCZ2tiVGNIZFpjMmRVZmtnSmVEZE9mU2NRZlNiSGZ4ZmhnZWJXaFNhd2UzZEphM2NBYzljQ2dnY2NiT2diZFJia2RaZEpkVGhzZndhWGIwZ2dkWmRBZmtmSWZMZVJoV2E4YVJoRWIyYTliSGJjYXhnTmdIYWFoQmFVY2FmRmFSZE5mRmFOY0RneGRXY0hmVWFCZnlmVWRYaGRiWGRTZWhoWmNwZFllUmVZYlloWmJoZVJnbWRaY21ha2FrZVdmeGFBY2xoRmQwYjlnU2JBY1JoMGZMY0ZmSGFwaCtjVGVUZEZhaGdEaDFlSWhRZVpoRWd4ZTJhZGFsZkpnQ2dGY1hhaGcyaEVma2ZzZFloUWJ5Z1liZGJJY2lnSWIvYkhiQWN3ZjJmSmFXZTlkNGNQY2piNGIwZVBlVWg4ZDRkUWZrZXNlcGFVZmtoc2gvZFFiMWh3ZTdkQ2ZDZ2RlS2ZGaHlnMGhaaFlmbGRCYkhoRWVHZFpneWFWZ2hnVmdxYWNjbGdGZjNlVmgwZm9jV2VhZFdiRmFRaFZneWNrZ09lWmRpY0FlMGZQZ2hjWWc3YUVod2VoaFRlSGRWYjFkYmJkZ0RkQmJRaFlnMGMxYXFoU2Z3ZzlhU2VFZkdiUmNNYmRobmJaaFNkUWNoZ1ZhNGNkZGhjSmJMYVNnZ2JZZU5oTmV5Z0FnK2FjYUZjeGVSYlVnbmNCYzFlZWRFZHRjM2hlYm1jbGdYaFdmUmdBY1plYWRBYnRkRmdiZ3hmRWZUZE1ha2Z0ZlplRWUwZWRob2hGZlVjaGdRYVJneGNCYm1jY2dsYVloVmRhZm5oSWNNZGZlbGV0Y2djRmdtZmxhaGFGZmhhaGFtYUZmR2NaYW1iWWZYZEJnVmNiYzFjcGZUYURjeGMxZUloVGcyZGxmcmZMZm1kMGhMZUpiUWRRYUhnV2h4YUJhaWhTY2xneGIyYlVia2hJZ1ZhZWRIZFloU2RTZHhnaGVEaFdnV2VKYXloY2JIYUJlSWFRZFFmOGZQZ09iemVzZ2ZiUGJqaFVmbmdWZFZma2ZOZUJlR2VoZmZnSGVEYzlnVWJYYkNlbGZIZkpheGUwYlViUGFWaGNoSmhBZWhnVmZSZ1BhM2NKYlFjRWIwYkJieWFVZVhnZGhYZFNnaGVaYXBkWWNSYlliWWdaaGhjUmVtZlpnbWFGYXdjUmNXZjloSGJXYWdmQWdkZUFlVmR3Zm5iUGZqaGdkaWhIYnpmZ2FLaFZnbGNvYkJnYWNFZXhnbmVmYjFmd2RBaFRoQ2J3ZHpiZmVnaDVnV2RCZUFjMGRxYVdjSGZCZXdoU2NFaE5kSmRXZG5oVmQ0ZVNoM2RkZjZmYWdWaDViQ2ZPZ2hkbGNvYkNmMGJWaHZhRWVSYk5idmRSZTNoTmJPZ1JmeWd0aFVoSGZCZ01iUGFFYkdoNGVnaFhneGVVZHhhV2FGZEZhM2NWaDBmb2FXZGFlV2NFZldiR2hHYlloVWRaZWpiUWVrYkpmQWhBZDllRmJFZWNnY2JEYUVkNWg0Y2RhR2d0YTZiWWQwYTFocWdTZ3dkOWFTaEVoRGRsY21jZGFuaFphU2ZRYmhnVmI0Z2RnaGRJZ1dkTWNrYU5mWmhZaG5mSmV3aGNkRWVoY0RlRGd3YjhkN2dPaHhjOGgrZ05jU2ZkZlhhRmVoZ2doUWZhZ0ZlQmV2ZWJieGhFYlRkYmgwZGRoemJFZDBiZGJvY0ZkUmhvZlZoRWEwZFVnMGJQY0ZnWmJiYVpmQWFZY29oQmd6YkljdWhhZ1FoZ2NUYVpnSGRrZGZoYWh4ZlVjVGZFY1FoQWU2aEhiU2g1Y0hiQWRoaDFiSGZRZzJmQmM4Z2JnbmR0YWVkZmNGYThlWWRVaGdicGRrZ1hjV2RaYWhlUWdWaFVjQmRhZFdhNGdBZldlQWhOY3BjV2hXY0pjeWNjaEhmQmdJZlFiMGVrZkhkWGQzYWhnTGhkaDNjcGJwYVZoMWFrZ1FjWGF6YzFhRmJCaGpjdGVZZVhhQ2RGZEhmT2R4YnNmVGVaZ0JjVWhhYVdoVWRkY0xlVGhIYUpmV2RGZVdicGh5ZlVkWGFkYVhmU2NoZlljZ2NKYnhlWWdRZktlUmN4ZHZkWmFuZzFkd2ZCYzJlWmdhYkVlMWJWZVBjR2hnYVZiMGJKZ1RhOGcwZ1RjUmFnZktoUWhSZVZiVmVBZlJlNGFrZU9kUWVCYUtoRmd4Z0ViNGRSY0FkcGZVaENmaGgxYWliSmJpZGtiZ2NEYlFlZGFKaEdleWNjYXFjQ2JpZjVkNmZKZFJkSWFYZFZkMGEwZWdiQ2VVZHhmMGhPZHhjTmN2aFJmM2NNZ1RkUmQyYmdiVmJTYkZjQWZWZFZmVGJJYW5iQmFGY3RocWJlYm5ldGYzZVZkMGVvZFdmYWFXZEVlV2JHZ0dlWWJVYlpjbWNZYnZhZmhpZEVoV2JLZ2loSmI1Y1liamdRZWdlQmVnZG9oRGZIZURiNGFmY09hM2U4YjllWWNoY0JhbWhkY25nWmZTZlFjaGFWZjRoZGdoaEpjTGdHY0VkTmRaYVlobmdKZXZlY2NFZEJnTGNIZFZncGhvZWVlQWdVYXllTGRXZmtiaWNFaEZmNWNOaGNnR2NvZlhoUGVWaEJmS2NaaHhkVmc2ZUdna2V0YW9oSGRSaHhoZWhPaEdiOGEyZEloQmFsZEJmSmdRZjBhdWJkZzBlcGZLaFdiR2JjZXhnUmdGYWNheWFXYXpjSWEvYU1oVGFWYmNlWmFuZUJiSGFIYlJjMWNWYVVnbmJSY3JlZWJtaE5lTmJhaGtic2FQZVViZ2VwZWtnUmREY2dmamVIZWdiNGJWZVplV2ZzYVBjU2gwZ3hkRGNYZTJkUmN5aGVmQ2NSZklmWGNraGtlVWJNYkNnOWJMZk9lWGZJZDdmWGRsZkFnY2RHaFdmQmVmZ1NleWVOZFVjWGVTZWdnVGZPYnhhTmRhZ2FoRWFkY0JmV2NVYnNhNmRaaG5jSmZXZUZnV2NwYnlmVWhYZWRlWGJTYmhlWmRwaE5kVGJ3Z1lhWmdoZlJjbWhaYm1lRmh3ZVZnV2g5YWFlVGFnZllmM2FWZFZiSmgwY2FiM2VwZGplVGRXaG9iV2hKYlZjSWNRZlpoRWZ4ZjJiZGVsZUpjQ2hVY3ljMGQ0ZFVoUmg5YlJmRGJCZ2RjaWVQZkhiZ2drZlJlRWVNZmJiVmRuZlVheGRRaG5mY2hoZVFiMWJkZ1pkRWdCYmxjb2RDZzBoVmV2YUVoUmFNY21iQWNYZk1hYmVSYm1kQmViZlJoaWRRYytnWWJBZ01jV2hLZ1hoUWdZYUFlRGVBYk9mS2NEZWxlamVHZFJoRmQ1Z2FiaGdJYlVlT2VqYXBnaGJKaEJjMGVtYkNhVWRkYVViVWJ3YllkR2ZOYVNhVWU1ZUpoZ2VJZ3NlU2IwYUZnYmhHaFVlNWJNZWRnbmZaYVNoUWZoZFZiNGVkaGhjSmNMZkdhRWNNaExoSmV5Y1llbGRJaGdmWmdEYUJneGQ4ZGlmZWVBZ1ZmL2dMYW1lVmZYZ0NheGJ3ZFpiSWFRYkpjZWNSZVJlRWRUZGJjMGdkYnphRWEwZGRob2RGZlVnZ2ZaZUFjUmZCYnVjY2dCZ2hkQWZKYnplQWFVZkpkVmFWYUtmQ2gzYlJjaGJRY2tjRWIyaFVkU2hraGdnWWNTZ1JmY2NiZ3dlRmh0ZUhkUmYxYlZkVWJuaFJhcmJlaG1oTmROZGFna2VzY1BmR2IxaFpha2VSaEhhUWVsZUJhaGFCY2NhTmZqaEVlUWNTaHdjVmhlYVdnVGhZYXJkSWdEZ1VmSGRCZlVma2NJYWZjRmVKZExmZGgzZ3BkcGZWZjFia2RRaEdkV2JnYkxmUmNXYThnUmZFaHpjc2dQYklmVmF3YlFkYWRGZnNhTmhCZjBoZGcxYk5nQ2hBYlphUmgyZEplWWFVZ1hjZGZYZlNkaGhaZHBnWWdSZVllWWdaYWhlUmhtYVpjbWdGY3djVmJXYjBjemdBYlJhMWdZYUdleGhFZDdiTGh6Yk1ldGdDYm1hb2RDZ1hoRmFKYkRmTmJBZmthMWdQZXhmUWVMZVVhRGJ4ZjJjUmFnZk5lZGNEZFZha2gyYU9lamRWZXdkRGZnY29mYmRDYlNlRmQ0Z0NiaWdVZzlkUGRCZG9jY2NYaGtlMWVvY1JoaGZBZDhnUmZSZk1hdGVBYW5iTmZTYlJnemN0ZUJkR2JoYWtmSmFWYzJlUmJZaFZoaGhWZnFiY2VsZkZhM2VWYTBnb2hXYmFiV2JFZFdlR2dHaFlhZGRmZVVkeGhoYWNlRmVWZXZnV2FrZGNhZGVIZFZiVmdTZ2RjR2dzY29lSmhoYWtnL2JHaFVkRmVTYlZhbWh3YllmUGFqZDhiQmhUYWhlVWdzYmZkd2FsaGhlR2ZFaE5jWmJZZW5mSmN3Y2NhRWZoZERjU2RRZ2RkZmJlZUVjdGMzZGVlbWFsZFhmV2ZSYkFjWmNhYUZia2JBZk9lMGhSZEJkSWVVaGNkZ2RHYnhnTWVnZlhmQmd0YmNjUmEwYlJncWVjY2diUWNaZWFmamR0aFlkYmRIZTFlS2dGZ21obGJoYkZlaGFoZ21iRmZEYXRmTWRZY1hoQmZWZWJkMWVwY0hlSGNSaDBhVGJCZ3pob2NvY0xkaWNvZENnSmhFZHRnY2NXZ2tjUmZvY1RiQ2FSZTZkVWdnZXNnWmVlY0RnTWdiZVNkMGJOZnBiV2NXZkpleWhjYUhnQmNJZlFnMGVsZmFhZGNUZkVoTmNkYjNnSmZyZ0djUWd4ZGRkV2h5ZjFmWmRSYTJiOGhNaERkbWU4YVRjS2VrZU1oQ2ZKYjFjTmFJYkFla2Q0ZTZlWmduYUpmV2hGZVdkcGh5ZVVkWGJkZ1hlU2NoZVpocGJOYlZnNWdLY0toVWdOYm1oS2NDYVFnbmRWZ1Joc2hEZkZnMWNoZjRmQmF3YUFmN2ZPaFhoSmVrZFRlemF3ZEtnUWF3Y2RkVmNaaGtid2IzYUphQmRVaFhiV2REZDBjNGdSY2todGZWZEZhZ2VvYTJiY2hqZjRiL2RIY0VnTWJMZEhhM2hVZDVjU2J6YWthdmJKYkJmVWRjZFFjaGc1YWhiRWRHZzljdmVFZFJoTmV2Y1JoM2ZNaFRnUmcyZmdmVmJHYmhiVWVUaFJkVGVRYThhVmRoYmNkL2ZQZkJlVWV5Z0VjUWJOZlloTGhDZFViVWNHY0djY2NKZVplamZJZDRlSWRCYkFlZ2ZIaEViZGc4ZlRhd2djZ1RiTGRRZ2tmdmJKZFFmc2d2Z0dnUWY5ZlVoRmRtZVFiZWJkZ2pmOGhjZ0VkVWNFaDViT2NGZ0ViT2hWZ3dmVmVaY0FoeWdBaGlhTWVSZ0VjaGNIZUJkd2J6ZVBlUmdsZ2RnZWdtYmxhWGFXZlJoQWRaZmFmQWd0ZkZoYmh4Z0VlVGZjZUVjY2dqZEdneGJOYWtnRmhSYnBkY2NSYjFmbGNxZGNnaGhNY2NmUWNIZUpnUmZkZjFiZGdLZEZibWNsZmhhRmhoY2hkbWhGYkhieGhtaFlheWJNY0JjUGhSYU1nSmhXaGhlOWRWYlRhMmRsZnJkTGFqY29lZGRMYndmUmhKaFVna2VKaE9nVGFIY1pjMmVVZmtiSWhWZWVjSGJZZVNhU2J4YWhmRGZSZ21hSWUrZmViQ2dSaEVmUWZ4YnRnV2ZkZlRkRmJDaFhjWGZwYXBjVmUxZ2tiUWNHZldiZ2FMZlJiV2E4aFJmRWczYVZmSGZQaGhlc2NUYVpiQmFVZGFoV2VWZHdhNmVaZG5jSmdXY0ZhV2NwYXllVWRYZGNiS2ZZZEJnWmJwZlljUmJZYllhWmdoY1JnbWRJZkRlUWgrZkZkamVzaFRmQ2FGZk1jZGdGZkZjb2RnY1libmRvZzRnWmIyaHBhTGhEaDFmSWVRY1phRWJ4ZTJmZGRsZEloTGVVYjNnaGErYkVoQWJWZE5kRGZoaHNhbmJJZUhmSmR3ZFNlVmM1aEpiRGZpY3dib2REYWpmZ2Q4Y2FnUWZOYVFjT2RoZ2xob2ZDZjBjVmh2YkVmUmhOZHZlUmUzZk1nVGNSZnpkeGNkZ0diaGE4Y1FjRWZDYmdnM2JBYlJjVWhlYktod2JFaHloTWVoZWhoRWFKY2pjTWFlZkhhMmFSZUhjTGJ6ZXdha2djZ2xmVWN1Y0NjQWFCYUlkVWJCY0FhY2JJYkdic2EzYU5oaGc0ZCthU2UwaDBnWGJFYkNnVmVNZ09oQ2hNaGZkQWJGZ0FjcWRjZ1JmdGFRY01la2dOZlpoWWhuaEpkd2djY0VmaGhEZlNkVmhvaDhiUGhrY3RiL2JhYm1hbGZKZ1dhVWdRZlFlUWVnZ3RjRmhiYXhhRWhUY2JlMGRkZ3pjRWEwYWRlb2NGZFJid2RZY0ZoVmc4ZXhhY2doYmhmUWRQYlhmSWZqZ05maGhraE5jVWN3aHdmemRSZEZlY2cwYkhoR2VGY2tiTWJqY2tlUGZLZ2xlaGdIZVhhRWQ4YVNoQmN6ZGtldWNOZURnZGROY0pneGE1ZGNlQmNoZ0FhcWFBZXlnSmEyaEVlQWFjZ1ZhTmRqYk5jVmVDZmtod2hLZ0RneWJkaDFlZWVXaHRjaWZRZTBlbGVhZmRhWGJoZ0xiZGEzZm9mMGZmYVZia2NRYkdlV2JnZUxlUmVXYThmUmNWZVRib2dKZU1oRWhjY09mSmUxZnRhSWVCYVVjOWdFY2FibmZJY0VhR2hXY29oN2RYYVhlY2JTY1FjeGRZY3lmU2R4Y1llWWZaYmhkUmFtYlpkbWJGYndiVmVXYjhmSWdBZGtjbGhJZEJkeGF4ZDBlWWcxaEJhamdUZFdjcGdMZURiMWJJYVFnWmVFZnhmMmJkZWxhSWZEZUhjU2ZwZy9lSGhtZUVjWWRRZTFmbGhpZmNobmJCZndmU2VFZ05jSmFXYm5kVmFvYlNhMmhsZW5mYWhRZFZoemVFZUJibGFvYUNoMGRWYnZjRWJSZU5hdmJSZjNlTWZUaFJnMmFnZEtiU2JCZ2hhUGZSY0dhcGR5ZUJmQmR4aEFlY2dsYUZlM2FWYTBib2NXZmFjV2FFYVdjR2RHYVlhVWVaYW1iWmM3ZWNmQWhNaGdkRWR3Z01jZGJEaFZkVmhUZ2FoWGhaYzZkS2VtaGRncWNTZHdlOWhTZUVhR2hSZU1nZGZuaFpkU2hRaGhoVmQ0aGRkZ2ExaExjR2VoYkFnTmhNYURlc2MrZk5lMGJwYURiVmZFYmRlMWNMY0JkSWZuZlBoeWNZZlJkV2VWY1VoemFhYkFndGJGZGJneGdFZ1RlYmgwaGRlemNFYTBiZGJvY0ZnVWdoYlFlUmF3YzllbWVPZWxlNWdCZ1plbmJJZURmZmJsaGtiTWdYaHllVWF0Z0hnbGVGY3FjRmRDYU5idmRTYTNoQmZWZ2JnMWJwZ0hmSGZSaDFiVmRVYm5kUmZyZ2VhbWZOZ05lYWFrZXNlVmZVY2xiaGFzYkdiSGJwZzJkQWJFZXNkYmJQZ2pkOWZlZkJleGhBY0tlVWdFYmhmeWVjYkhlQmRJZFFmMGhsYWFjZGdYY2hlTGJkYTNhcGFwY1ZnMGhNYVFnVWJXYUJoZmZTYldlOWhEY0dka2VWaEhhY2J4Y05oSGNhZUJoVmFJY1ViRWJjaFFlYmUyaGxjOGVGZldkcGF5ZFVkWGZkZ1hlU2RoZ1lhMGhTZHhmWWJZY1phaGZSaG1jWmFtZEZld2dFZ3pib2ZVZ0JnRWVsaFVnR2doYXhhMGVMaFhiSWUzZFFlV2FvZFpnQmFsZ0pjTGFUYWtleGEyaGRmbGNKYkNiRmZYYmhhMmVFZWtjdGZSZ0JkVmRsZnFnZWZqYUZoNGRHZmtjcGNGY1dhbmQwZnNlU2IyaHBlNmhJZ1ZjOGZOZkhiQmRsYTRoQ2IxY3RhdmhRZXhmTmR3Z1JkMmFNZlRhWGNXZmdnRmRTY0FneGVIY1NoV2M0Z2dkWGV4YnhmamZmZGxjRmQyZkdlVWhSZWliRWFCYUZhemhmYUJkbGgxYkZkQmVRY0FkQ2VTYW9hY2ZMYXpoZGZ0aGNnaWRjY21kZmZXZ0piUWFZZTBoMWNxYlNnd2Y5aFNmRWhHY1JjTWNkZm5nWmhTYUJhRmZvaHFoZGVoY29nZGZXYVJkRmNaY0tnM2hKYnRjY2RGYWhlWWZTaFFkaGExYVpja2FzZitmWWNXZ2xlY2VVZGxla2FRYWFmRmc4ZytkSmRtZ3diVGZjZWtlZGRqZUNhR2YxYm9jRmFVZ2hiUWNSZHhkQmNtZmNibGJZZVZmT2ZEaGNjRmRJaGdkVWFFYkZkamcxaDZoUGRCYWhmbWdGZEdmWmJtaFlnWGNCY1ZoTWJuZkJkSGRIZVJnMWFWYlVkbmJSZXJiZWVpaFVkWWNKYUFkaGViZUdoMWI4aHFiVGREaHBoK2dCZWtiNGVWZUtobmhvYlNnQWdoY0ZkRGdBYmtlaGN5YmNjSGNCZ0loUWgwaGxkYWFkZVhnaGNMaFBhamh4Z3BjWGQzaE1iUWdHaFdjZ2hMZ1JiV2E4aFJhRWIyZjllSGRjYXhiTmVQZ1lmQmJjZmJjQmJCZVZoWmVLZkRkVmFVZEZkV2N0ZHZhVWZTYU1nT2JHaGxmTWhtY0pjeGFaYlJnWmhrZGdlNmhaZm1nTmV5ZFZmWGRKYkhmV2hoYTFlVWJYY0ZjSmh5ZWJkWGdwaHJlQmhHZnBoV2FEZDFoQmRGZU1lQWRwZXVnZGRGYnRoT2RQYTNjaGcyYkVia2FzZFllUWUxYWxjaWhjZ25mQmh3ZVNkRWdJZ0hlVmJEaHdlcmNMZWpma2Q1ZEpjaGhNY1FmWGJsYTVjZ2JRYWtheGVtZU9ieGFOZXZoUmczYk1lVGZSZTJkZ2RWZlNmRmJCaE9hT2dtY1pjeWNWZWhjVmhxY2NjbGVGZjNmVmgwZm9iV2FhaFRoVmJlYlNoaWVsaERnWmhpYmdma2hKYzFoVWJiY0FheGdkZ1ljZWhBY2NjQWdPYnpobGd5ZFpmRWU4ZXZlQmVVYXdkZGhWYUNkMGVDZk1iWGFSZVNmRGIwZUFlcmNJYWhkSWVKZ1hhVWNNaFlhWWRpZlFleGNQZ0FjRWRIZFNnUWhrY2hoS2VnYkloNWdQZVdoa2ZTYkZmMWVOZldkTGhFZ0llTGJLYkJmWWFhZWRlR2YxYXpjRWIwYmRlb2RGY1VkaGdRZlJjeGJCZW1hSmFCY2RlSGNhYmpjZGJSZmFibGJkaGFkRmFqZFZjaGNVYWhkQWIwYkdlR2dZaHZiYWFHZ3RjL2RiYTFmcGNIZkhnUmMxY1ZoVWhuaFJlcmJlY2piZGFOZWRhMGJ0ZEhjV2RrZ1Job2NUZ0RnTmQvYVNiV2VnYVZkZWVIY1ljU2JTZHhmaGREZVdnV2NKY3lkSmRqZkVmYWhRZHdhWmRhZWFiSGVnY2ZhZWZTYTBjN2NIZGdiMWNWZUVoVGZvZUhlUmVTYllkWWJDYkVjVmVIZWNneGROY0hmYWRCY1ZnSWFVYUVhY2JRaE5mRGhjZUNiUWhEZmdjOGVVZ1RnaGhYZFNod2F0YjBlWWdWZU1iWWVZZ0JnSmJtYWJjamNWY3djU2VHYzhmT2VTZlVkNWFSaEhmQmVFY3hhWWIyZXBndmhUZVNoVmRDaEJjbGE0aFFnTWhGY2RoY2ZkYmxnSmhDZkZjWGdoZDJjRWFrZ3RmRmFhaFZjbGFpYWNnbmJCZndlU2VFZk5jSmhIYkNoQWEyZENkQ2ZNaHpjSmNoaGxmWmFVZHhmRWE4Z0JoMGVVZTlmR2RCaE1hMGZiZ1hmTWJUYVJoMmFnY1ZlU2dGZEJjSGJFY0dnWWNrY0ZiMGRkZXFoT2gxaEZhcWRWZ3hlZ2VZZkpoU2dSZ1loWGd6YkpiY2RaaG5jcGRoYVlkRmVWZ3dnV2VsYmNjZGdCZTFmVmZDY2RoRGVkYTZnT2drYVVhNGdSZ1VoTWNYYlhnaWZNZllhUGFuYzljSmdhYkJoVmU0ZGRhaGZKZExhR2ZFZk5hWmdZZ25kSWJrZmNlRmdWaERhQWdWYUlhaGhkZUVhc2crZWNnM2FKYTljV2dSY0FoWmJhZ0FjdGVGZ2JieGRFY1RjYmV3YkVoOGhRYlVjZGJnY1Fjd2drZUNhUmgxZ1ZmbWFiZzFmWWZGaGNoWGRJZlllZGEwYWxoS2RVYjNoSmRoY1VjeGZoZXRkQ2JXZVpkM2FhY0hoQWJCYUZiQmY4ZTZkSGFRZ0JmVmVRYkdlRmgrZGVhbWJWZE5kT2FEZEJmS2FMZ3dldGdPZlRhSGJaYzJnVWVrY0llVmhlZkhnWWhTZFNiMGFvYkdlRGhUY2NnZ2JQZm5nQWdjZldoR2hOZmFiZGhYZ2hhTGZkYzNhcGRwZ1Zhd2JRZDZlR2NXY2dmTGNSZVdoOGdSZ0VkMmc4YUJjSmdsZzBnRWVQY0Zkd2VIaEhka2hkZUFiYmhpYVpnYWdGZVRmaGcrZ1VjVGQ1Z2JjU2ZsZE5oZ2dZZVVmMGV5Z1piaGNSYW1kWmhtY0Zkd2FWY1diOWVhaFJjMWFSZWJoVmNWY3BoOGRPZ1hjUWZoYUZmRGM0Y09jWWF4ZGRhZWZJZHhlZ2IrYWVkbGVKY1NhRmRXZVpkMmJXYTBhdGNFZEhlMWFrYndkZmdEYklkcGhIaEFlWWJsY0hlemJzaC9mSGN6YzlhNmNkYlZkY2FRaEdiUmZCZENmQ2MwaFZhdmFFYVJnTmh2Y1JoM2ZNZlRlUmIyYmdlVmFIZkJhZ2JWaFhoemRGZHlnR2VGZEFjOWZjYWlmTWcyYkdiUWMxYVRlRGdEYU5kRWRWaHpmUWRjaFpiR2dFY3VlTmFoY01jOGJIZHhoTWVhZ0hiUmR3ZUJhZGVDY1FkdmROZTBhMGdsZURhUWU4ZlFlWGZ6Y0VhQ2hNaGloVmFRaFNmd2I1aFNoZGRoYkpkTGFHZEVoTmJaZ1lhbmJKZXdiY2JBaEVmRmNTZVZnSWNuZ2RmZ2RrZHVhTGJpZ3dlN2ZIY0ZiNWRlZVBiRWZOZEZlY2R4YUZoYWNiZDBneGh6Zkdld2VKZm9mU2JSZFJkUWZWYnhmbGF2YldiRmRZaFZhYWJuZ0pkUmNkZTFlZGZLZ0ZibWJsZGhnRmFrZHdodWdSZWlha2J4Z1lkVGQ0ZFFjT2ZGY29lMWZYY0ZhTWJTY0ZoeGJFYTViS2FDYndiZmhZaGtla2JJYkhkbGFVYnFoQ2Z5ZklnK2JWZVVjSmhjZ0tnM2JaYmRoSGVrZXhnRGNGaGlmUmR5Y01oamQ4YWRlRGNRYTBlSmZkaDNoRmNRYlhoWGRwYXBjVmIxZGtkUWRHZ1djZ2hMZFJiV2c5YURkVmJqZnNmU2RJZVZkMWRIZllhRGE5ZEljVWZFZmNkUWVaZm5kSmVXZEZlV2FwYXllVWNYY2RlZmdHZUJlWmcwaFNmeGhZYllnWmZoZlJkbWNaYW1nRmV3YlZhV2c5Y2FkUmh4ZTBiZGZBZnhhMGM5Z0xiM2RwYnpnVGNYYmRnV2JFZGxkSmZaZ1piRWJwZndhZGJnZVFoTmNYZERheGgyZ0Fka2NzZEZnWGdrZVJiaWVOYTFncGN3YVNmRWhOaEpoV2JuYlZkNGNTYTNlZGg2YWFkVmRkZ1poRWhCYWxib2FGZUVmVWFoZlZjRWRSZHZmTWJqYnBnZGhFYzNlQmMwY0diZ2NJY0dlU2hXYTRlZ2hYZHplOWVxYmNhbGJGYTNhVmYwYm9kV2ZhYVdjRWFXZUdnR2ZZZ1ViWmdtZ1poaGdhZGxiVWE1Y0ZkUWg1Y1pkSGNVY1ZiU2NhY1hmWmVuYVlnd2hoY0FkU2J3YzliU2RFaEdhUmhNYmRlbmJaZVNkUWVoZ1ZjNGdkY2hlSmJMZkdnRmd4ZVphTGREZ2NhbmdjYURhMGJLZ0Jhd2g1aHRkR2RSZmtlbGNPaHpnQmZmY0NjeGh3Z1phSWZRZkpndmRiY3hnRWZUYmJlMGJkZHpnRWYwZWRob2JGaFVjaGFRY1JneGVCYm1jY2drZndiVmVKZERlY2FHYWRoeWFJYkRlV2VEYTFjNWJkYTBmb2cwZlZkVGI5YXVkTWIzYnhiVmZKaGxjWmJIZVdoQmdSYmNiWGNsaDVocmhlZW1jTmROZGFma2JzY1BhVWRoYkJka2hUY0hlWWc0YlhkRGdaaHNkQ2VCYU5lMmNOYUhla2F4ZEtid2FNYUxkRGd3aE1hOWRNZ3pia2gxZkJkd2V4Y2hjZGQzZXBmcGhWZDFia2FRY0diV2dnZkxnUmFXZjhhUmJFZDJlOWhZZGNoeGZ0YVBmUGRCY1ZnVmVVYkJoVWJaY2FlbmFKaGVlUWRXYVFjTmZMaGljY2dGZkJlVWRJYm1kSGhtYWtnWWJlZXhiUWhvZmFkRGhFZmljR2RqY3NnVmhFZjBhUmNOYUVmRmZ0ZDloUWRYY3BjamFUYVdjcGVMYkRhMWFJYVFnWmNFZHhhMmRkZWxmSmVDYkRmM2FoZCtjUmhrYXNkRmJRY3hncGFxaEpobmN4ZndkR2NrZ3BnQWFWY2xnOWQ0Y1NjM2FkaDZoYWhWYmRhWmRFZEJobGNvZ0NmMGZVZzdkT2Z4YU5ndmRSZDNmTWVUY1JjMmJnZVZhU2RGY0JoT2ZDZDBkeGV5Y1ZhaGRWZ3FlY2JsZkZhM2VWYnhiY2Y4ZWFoV2ZFYldjR2FHYVlhVWNaaG1mWWJuY0pmUmJzYXNhRGZnZDVjU2hVYzFoVWRmY2ZoRGM5ZDJnWWh4ZTliamJTZjFhUmE0YUVoR2ZSZ01nZGhuaFphU2FRZWhjVmI0Z2RibGhzZU5lR2ZFYXNhWGhiZERmc2hqYUVmaGEwZEZhRGN4YzhibmdjY0JnbGcrYmNmMmZrYk1hY2h4Z0FoWmNhZkFhdGJGZ2JoeGJFZFRhYmQwZmRkemFFZnhiRWVwY1JhMGNnYVpmUmR3ZjFnbWNZaGxhWmRKYmFkaWF0ZVpnSmRWZ2tnR2RVZnllY2ZtZ1FlbGhCaHZiRGIwYnhmbWhZYVhhQmdWYWJkMWFwY0hlSGFSYTFjVmhVZ25nUWQ1aFBjemJjZ1lmT2RBY1VlUGhXZGtlUmhrZVVoWGZZYythV2RoY1lhWmVlYkRjOGFiZ1FjaGVSZERkU2ZXZkpodmFiYldiMWZJZkZoMGdjY1dlTWdEZVliTWVJYXpkSmNwY1NiRmdsZkViR2hYYUlkTGhUYlRjMGNmaFVoQ2FBZ1hkS2ZoZXNmVGZaaEJoVmRZZFhkRWJjYkFnYWRuZ0lkZmVIYkdlWmN5ZEJlWGg1Y01lWWVCZlplcGZZZFJlWWJZZVpjaGVSZ21mWmNtaEVjdGVmYzJmOWZhZFJieGIwaGRmVmhWZ0pjMGdhaDNmb2NxYkNjMmdwZERmWGVWYXNnUWFQaDJhWmgyYWRlbGhKZENnRmhYZmhoMmZFYWthc2JZZlFlMWJrY3JhTmRIYUJkNGNZY2tkTmZKYVdjbmFWYjRjU2EzZWRkNmhhZlZjZGNaZUVhQmRsZG9lQWIwZGNhNmdYZTFlY2RxY0FoVGVwYWRnQWZpY3doWGdTaEZjRmZhZkVnRGdJYnJhQmRsY0FjbGhOZUZnRWVXYUJiUmhoaFhmTWFBZE5nRGZYaGlhQmZSZk5kR2RaY25jZGFuZDljdmZXZWtoY2RkZ0hnVmRWaFNkZGNHYnRiNmZZZTBoMWVxYVNhd2U5YlNkUWhtYm9oT2JJZXpiQWdVY0JnMGFkZTRiUGExYXdoWWZUaEFoSWhYZElmVGNjaC9mTmRrZWdmaWJHYXdjZ2UwZElhU2NrYmlhUGdDZThjU2hDZHhma2VaY05kRmdkY3ZjYmJ4Y0VnVGRiZTBlZGV6ZEVhMGVkZG9oRmhVZmhhUWhSZ3hoQmhrZFBhaGFOY2JmTGJTZVloWmJkYlZkY2ZEY1doR2RraHpkUGZCYWhkbWhGYkdoWmJtZlljWGdCZ1ZnYmIxZ3BhSGRIY1JnUmMvaFVobmVSaHJkZWhtYk5hTmJhZGtkc2FQY1VkaGFCYWthVGJIZllla2FGZXhmWmdBaEtkamVnZFNlU2RWYlloV2hGZ0NmQWMzZEljbmJKY0loUWdsaFJmYWNJZVNlRWNiZE1lamVVZXZnVmR3YXNoZWRWZVNjMWZGaEFhamJ0YlpkRWd6YU1iYmZjZjNiaGdQaE9oaGNzaEVlRmhRYWxiWGRNYWpjcGFmZVBnMmVwaHlmVWVYZmRkWGhTYmhkWmRwZllkUmdZZFlmWmJoYlJlbWRaY21kRmZ2ZFZiU2NkaFNnRWF4ZUVjZGhSY1ZkdGRlZ2FnM2FwZ2pnVGFXZnBoTGREYjFlSWNRZFphRWd4YTJhZGdsZkphQ2ZGZVdhSmQyZFVoVWhOZ01kVGUxYWtod2VlaDJmdGRhZlNlRWZOYUpiV2ZuYVZiNGhTZDNjZGQ2aGFkVmhkY1poV2NWZzlob2FBYzBiY2dOaFJjRmNVZ3BiQWFpZEVhUmNSYTNhVWhJYVZlVmVBZ1ZnSGFqYUlkcmZCYWxhQmFxYWRhRmRkZTNjVWMwYjRkZWNPZjJjOWVTZFdkVGJKZVZoYmIyZDliaGRJaGhoQWM3Z0RkeGhWZFRlSGNSZ1phYWJJZUdnZGg2aE1oVWdNZXVhQ2FsaHNlVGJHZFhlOWZtZGRmbmhaZ1NoUWZoY1ZjNGZkZ2hjSmNMZkdnQmQ1ZHpiWWNuYkpjd2ZjY0ViaGhEYlNiVmhwYzFiZWhCaDhnL2ZLZUNiWWFBZldhVmg1ZGNjUGh3YXNmeGVOZ2tmRmRXZ0NnaGRVZ2hkWGJCaFZlZ2ZQZDBnaGdRY1JmeGdCZ21nY2VsZFlmVmRhZG5kSmFSYWRoMWRVYnNjWGZ6YXNkeWRRYmhnZ2NuZ1JkaWFFZ3pjTGdEZ1VmYmVPaDFob2NLZ1NkRWc0ZUJmVWNqYVlndWdlZGloSmROY09oUmQ5ZWRmR2QxZTRjamFRZkhoWWhVYUJhd2ZSYVRnUGJTY1FiZWNTZTNja2VSZkNoeWhNZXJoRWFpZFVkT2hCZ1Fjd2hJYWVoWGFnY3FjSmJTZmdkb2FEZmxkVWVRYlZoamhvZExkQmJEZDFiRGRVZWpoWmNLYlBkMWVvYk1kTGFSYlVjSGRFZmdlMWVWZUpkU2daYVlmRmEwZ0JneWdVYVhnZGJYaFNkaGdaaHBlWWFSZ1liWWJiYndhOWRNY1pkbWZGYXdoVmZXYzllYWZSZnhiMWNBZGZkMWVKZzBjYWIzZHBnamNUZldocGNMZVNiUWJkYWVoSmZ4aGdhL2FPYVJkeGJDZlRhSGVBZGlnR2MwaHRlRGVhZVZhbGhpaGNlbmRCZndmU2RFZk5hSmZXYW5iVWF4YkRmWGJkYnlmUGZWaGRmSGREYlJia2NuYUFlMGd4aG1oT2Z4YU5mdmZSZzNoTWZUZ1JkMmhnZ1ZoU2VGZkJlSGFFZ0RmSWQ2Z0JoRmJvZjliY2NoYjhheWdBZkVicGVrZEtnQ2g5ZVJiWGRRYU5oR2VOYUNma2V6YWVoSGg5ZHZiV2NrYWNiZGFIZVZhVmRTaGRhR2F0YzZiWWcwYzFhcWdTaHdmMGV6Z1JnRGJBaEpiT2R5Y1lhR2ZRaGtkRWEzYmRnbGFNY0hhVmZBZ3doYWVJZ3llWWExZWNiQ2NvY1doRGJ4YXdld2FLZmtjc2g3ZU9oemZzZlFoSGhFZklnWmVQZkVnTWFFZUliUmVGZmVjTGVoZDhlNmZYZ2hiSWVsaEZiUmFzZ1pjSGVWZVZkOGdjY2tnWmROZ2FlSGhKZWFhWGZWZGRjS2VGYm1kbGdoaEZkaGhoZG1oRmNHYVpkbWdZYVhkQmZWZ2JjMWFvZ0loRmVSaFJkYmJCZ2pic2RZaExlamFFZkVhSmdBZndlSGhRYXdhWmZ0YVRmSGExaGNlVWZrYklmVmhlZ0hoWWFTY1NjeGhoYURlV2dXZUpleWVjZUhoQmhJaFFjMGV0Y2FnTmJ5Z0VkZmJNZ2lkbGNyY2ZjVmRrY1FlR2dXYmdhTGNSaFdlOGZSY0VkMmM5ZUhmY2R4ZXBmY2RRZmhiVmhJZVVoRWFjZlFoWmduYUpjV2RGYldib2JnYkZjQ2JNYkNhR2ZGZWhocGRjY1JiWmVFZVpma2hCZDlmVGVHY0Znd2dWZFdoOWdhZ1JjeGIwY2RnQ2hIZmhiMGJhYjNkcGNqZFRjV2hwYkxlRGV4Z1JlRmFLYWdnOGRpZVBoeGQwZE1iRmFRY2RjK2ZSZmtlSWFZYUdoSGFOaGljY2JuZEJmd2dTZ0VkTmJKZFdjbmNWYTRlR2ZUYklodWZQZUFkVWNYYkVlQmNJYThiQ2gwZVJmeWZFYlVlZGd2aFFhWGVVZ1RkVGR6ZndjVmFWY1ZiQmZYYUdlV2NwZHloR2NCYnNocmVQZGhiMGc0ZUZhRWFJYWRhUGFXZWdhTmNNZG1lWWdVaFpkbWRaaGhhY2JGYVZidmRCZDJnMGFkZ0hoVmZWZlNkZGhHYnRjNmJZZHdjc2YvYUJiVWd3aEdjV2FTaHNjQ2hkYmpnSmZhaEZoaGNsZDRmSmVCaHRhTGNRZTJmbGRaYllnbmZKY3dkY2RFaGhlRGFTYVZjcGgxZ01nUWcxZzNiY2dpZWRmWmRFaEVnTmQ3YVBiVWcwZERhS2NraE1kYmZPYjBkNWQ2ZUVoeGZVZ3RkUWRSaDBnQ2VDYVJnQWF5ZmZlQmdwZVFkSmZEaFVnRmNQZDBkeGVnYUZlbWJsZmhhRmFoY2hibWdGaEdmWmhtaFlnVGJraFRhYmgxYUpndGNIYVJhMWNWZ1VibmJSYnJiZWVtaE5hTmJhaGtjc2ZQaFVoRWFVY3FhQ2FEaE1md2JHZ3dieGZRaFBmSGZRY1NkU2hnaFZjRGNEaFRkc2JpZU5hVGE4Yk9oUWd5Z2dkSWVKYnpla2hTZEZkU2U4ZXZlRWVSYnhlQ2NHZVdnNGZOYWJhMmc4Y1JlRWQyZTliSGRjYXhoTmZIY2FiQmhWZUloVWRFZVZmV2RNZ3phd2ZWaFFnU2hNYzlkSGgzZlZjWGFWaHdidGZwZE5hVWQ5Z0lnSWIxZnNhZ2daZ2dnQWdpZ0JheWE0ZERnSmJVaGhkYmNFZ3hjY2FtZ1phVGZNZ3dmT2J5Zk1mT2RXZEZiSWNXY1lkbWNaYTJjZGVsY0piQ2dGZFhkaGcyY0Vha2VzZlliUWQxYmxkcWVFYXllSWhpYkNjUmZvaHJnRGN6Y01lK2NEY2ljVmMwYUlhQWZRZnZlV2RWaHdjL2NBZHhiRmZtZ0ViVWc4aHpkUmZ5aGNlVGVEY2ljWmNHZUhnQmZFZkpoVWN5ZU1kOWRFaEJnVWdMZUljQWVNaDJiRGhpZ2hmRGJMZ3ljZGhUZ1NhbWQ4YSthWmdtY1plaGZjYUZmVmN2ZVdka2NjZmRjSGJWY3hhNGFkZEdmdGc2YlllMGMxZ3FiU2d3ZjlnU2VFZEdhUmNNZ0pnRGRNaEdlRmEwYWNiMmJkY2tlWmJGY1dmaGdvaE5jSmJ4YjRoMWdQYWdiOGJYZkFlVWVGYWZmZWZFZnRhM2dlYm1mbGVYZldkUmFBZFpjYWVBZ2tnV2JPZDBiTmZhY0llUWZCaHhnRWYwZlphMWJGZFJod2ZKZUZkMWZVYnBjTmZGZ1pmQmRhaG5mUmNYY2RoMWQ4YWVnRmZuZFJoaGhGZEJmcGVtYUhnMmdZZXllYWFHY3RhL2NiZzFicGZIY0hhUmcxY1ZhVWZuZ1JkcmNlYWphVWJNYU9nRWN0YkdoVWNnZDFna2VHZUhkZ2Q2YkZod2R4ZlNnTGZEaDRhSmRZaFJhaGhEY1dmV2FKaHliY2dIZUJoSWJRZzBla2dUZ01oM2FoY0RiWmUzY3BmMGFTZGtoUWZRY1VlR2FFZkxoRmd5ZnBjRmJSYWphMGhKZGNjd2FOZGNjUWVoY1ZoSWdVYkViY2RRZ1pibmVKYldmRmdXYm9kMGVIZGlkVmdYZFFha2dBY29lTWZ4YlpmZGVaYmdmbGJtYlpjM2JCZHJlVmdYYVJnYWVUZGpoY2FkaFZjVmZKYjBlYWQzZ3BmamVUZ1docGFMYkRlMWNKZURhTWJ3aFVlaWVOYlJocGRDZ0hnU2NwZy9kRWJoZEFieWZRZzFobGFpZWNjbmVCYXdlU2FFYk5lSmVXZm5jVmg0aFNoM2NjYTVhS2hBY1FiY2VFZ0Jhc2NwZVdhQWhZYm1oV2FCYkZkMWJiZ1hkTWJUZ1JjMmNnZlZmU2RGZEJjSGVFaEdnWmN5YVZoaGFWYnFjTWVSYUFoa2VFZ2tib2dVYUpiU2VCY0NmVWZTYmdjRmdaZkhmeGJMYmNnRmVWYnZoV2FrZWNiZGFIZVZhVmJTaGRjR2N0ZDZlWWMwYjBlcGVDYmxod2JYZEVkR2RZZU9nUGF6Y2dnVGRFYUVjeGQ2YWJmRGVoZUxmR2ZFZ05iWmRZZG5nSmd3YmNiRWdoZERkU2hWZXBnMWZlYUVldGIzYktmQ2Z3Z0RoRGFFaEphWGRhZkVoSmJlZFJoUmZFZlRiYmMwYmRmemJFYzBhZGFvYUZnVWNoZlFnUmZ4ZEJnbWZNYlJkZGNHYkxmM2VKZFRkSWRnZU1iTWVEYW1odGQ3YlBkQmRoYm1nRmZHaFphbWFZY1hmQmFWYmJlMWhwZUhnSGVSaDFlVmdFYVRjVWM0YVBmMmZOZVBmUGR4aDljSmZYZndmaGFtY1ZlbGJ4ZzJlVWZrZUlkVmFlYUhnWWFTZlNieGdoZ0RjV2hXY0pmeWhjYkRkTWFKZ0VkQWR4Y2FhSWZ6ZmNhQ2ZNYjNjcGY1Y1RmWGFNZVFjR2RXYWdhTGNSYVdoOGZSZUViMmY5YkhoY2N4aE5mSGhhYkJhVmdJZ0FkZ2NKY0VlTWF5ZUFmWWVGaFFmSmY2YkJoWGM1YVpjQmFsZE1mbmNKZWtnSmNRYWZmVGg1Y21mWmhtaEZjd2VWYldhOWFhZlJheGcwYWRjVmFWZkpoMGdhZHpla2FpY0hmaWY5aExjRGVRY2RjVGNOZzFlNWEwYWJiSGZoYkNiRmVYYmhoMmVFZmtic2hZZ1FiMWRsY2ljY2JuaEJkd2ZTYUFmQWVJZ0NiVGRCYzRnU2FTYUlkNWRPZmxocGZMZEVoZ2JOaENjQ2YwYVZjdmJFZFJmTmF2Z1JjM2VNYVRkUmgyYmdhVmJTYkZhQWRFZVVnVGNVZTNiVmZoY2NlL2VKZ2hoZGhtYlFnUWRaZFRnYWYzZXNhOGNHZUdmWWNVZVpobWhaZmhoY2JGZ1ZjdmhXYmtjY2NkYkhoVmhVY1JiTmhUZmdiL2ZZZzBhOGgvYkhnMGNsZGZjQWRYY0llQWFNYTNjUmhJZWFkQmVWaDRkZGhoYUphTGFHZ0VoTmJaZlllbmNKZXdlY2dFZ2hjRGRTYVZjb2JuYVBjUmQ4aGlhS2JDYWRnWGZTaHhlQWVUYWFhRWZKZWViUmVSZkVoVGRiaDBjZGV6YUVnMGFkaG9hRmFVY2hiUWdSYXhlQmhtYk1mUmdkZUdjTGgzYUpjVGhQaHhoSWNTYkZjSGJOY0xkRmJoZ2hjbWZGYkdnWmVtZ1lkWGJCZlZnYmUxYnBoSGRIZlJkMWVWZ1VmaWJZY3VnTGJqZFliZmhKYUVodGNHYlViZ2g1ZzZkVWZuZlpmbmJTZldmZ2hWaGVlSGNZZFNhU2F4aGhkRGNXZ1djSmR5Z2NjSGZCY0liUWJ3YW9oYmJKYmpkMWRMYmRnVGJnYm9jQmdCaHdhR2VEY1djb2VSaGJnMmE4Y1JoRWgyYzlkSGhjZnhmTmRIYWFoQmJWZklnVWFFYWNhUWVaZG5oSWRFaFVkRGU0Y25iQWR6ZGxoWGNNYkJoNGE5Y2FiQmRoZVVmSWMxZm9naGhNY2ljbGRyZWZoMmE5Y2FjUmh4YzBiZGNWZlZnSmYwYWFkM2RwY2poVGRXYnBkTGFTZ3hjZGNXZUpnUmJrZjZmSWFrY2hlb2FGaFhjaGgyZEVja2hzYlliUWgxZ2xkaWZjZm5kQmd3ZFNiRWROY0plV2RqZHdjK2dTaDNiOGgvYllhRmZjZkxmVmFVZDBhOWhXY1FkdGZ2YmVjUmJzZDdlVGhuZDFkZmhBYmloWmVTaEhmQmhoaGNhT2RtYlpjeWFWZWhnVmdxZ2NjbGZGYzNmVmQwYW9iV2FhZFdjRWRXZ0diR2hZZGNhTmNHZVpiOGFjY0ZnMWN0aFdmRWhjZFdoSGZRZmRhYmRlYmpjOGMxY0Rmd2NJaDlhRGFsZzBleGZVZVRiY2hKaGZkbmE5aGJnVGhoYlZld2RNZ3hnSmRXYUdiRWFKYUplYWQyYmxmYWZjZUVlaGVEZFNoVmZwYzFnZWJFaHRnM2ZlZm1ibGdYYkJnRGRvZ1plYWNBY3RjRmZiZ3hjRWJUYWJleGdwZ1piRWcwZWRnb2JGaFVnaGdRYlJneGNBZWdlSmN4YmhiV2FQZGpjc2hlY09iVmJjYU5hSGhqZDFkdGdGZGtkcGhxY0ZnQ2c5ZHZoWWdTaHRnL2NiZjFicGJIZkhmUmQxaFZhVWFuZFJhcmJlZGpmVWNNZE9kRWh0YktmVWJnZDFia2dUZFdhZGJ0YWVlRWNJaFZkZWZIaFljU2VTY3hhaGJEaFdjV2VJYTdlTmFuZUJlQWZTYjBkRWdNZU9iamJFZVBjZGIyZHBjcGJTZWtmUWFOZkdnVGVvYkxiR2NUY01oUmhBZzJoOWdaaGNlMGVGZU9nYWZCaE5jT2NVaEVjOWRDZlplbWU5ZFdmQmFXYU5hK2dVYVNhVmZYYVZhQmdZZjlkS2JWZTlhTGdhZkZkZ2FqYktkQ2NZY2tjSGhXYVpmVGVSYTBnOWVZZEFlUWdjZm1oSmFYZnBmaGdUYTNkRmZoZERnMWFJZVFmWmZFZXhmMmJkZ2xlSmJDYUZjVGRFYndjRWFrZE1iUWVTZndjOGJ0Yk9nemZSYndkV2FFZU5mVWNSZzJhaGU0ZEFobmhjaG1kTmZWY2NoUWNFZkFjZGVvZ1hmd2QwZm1kUWVoZjBlamdBZWpmMWNVYkVjeWRBYWNnU2NGY1poQmNFZEdnNGQ3aFZjZ2FoYnFjSmZoZWtiK2JCZUViUmdhaExkQ2U5YlJjVGFDZjRhZGFhZG1mWmV4ZGNoRWZ0YnliV2NnYTRkVWdGYUhnOWhTY2RlR2d0YzZhWWYwZDFkcWNTZndoOWNTYkVnR2dRaGVkTWJ5Y0loSGFFaEZhdGY0ZmRlQmZCaFFmTWZrZU5hWmFZZG5jSmN3Z2NnRWJoZkRkU2VWZG9jOGNQaGtjdGQvYmNobWdFY2ViV2hRaDRiSGFkZWhnWmFGZ2ZleGRnZ2ZkYmgwYThhaGNFZzFlbGMyZENlMWJWY1FhVmJ4ZWxncWNjZ2dmUWZWYWRoR2U5YlJlUGJsZzVlRGdGYWpkc2VrYlFia2EwZTBoV2dtZFpha2dZZTJhdGEvZ2JnMWNwYkhlSGVSaDFhVmhVaG5jUmNyZ2VnaWJVZENlT2VFYXNmSGZCYWhkQWQ0ZEVoSGVaYStmQmNraEliSWRlZkhoUmJIY0hlMWE1Y2JkV2gyZnRmcGFjYUdidGRJYlNobWNOZmFlZGdYZ2hhTGNkaDNocGNwY1ZkMWZrYlFkR2hXZGhlWWFFZ2lmWmJGaFVoQ2hkY0hkZWQwZGRlT2RhaEVjNWRpZFVkRWJjZ1FhWmFuY0pmV2dGaFdocGJ5ZlVjWGhkaFhlU2ZoZlljcWdJZ0VhVmhkZVphaGZZaHVlSWN6ZWxheWdUYjBnVmZhYlJkeGIwZWRoVmNWYkpnMGVhZDNmcGVqaFRiV2JwZ0xmRGYxZUllUWFOaGdia2VpY0lid2ZBY01hRmFTZEpkK2dSYWdnTmNSZEVmRmJWZ2loSWFIYnhmd2FBYVVocGFTZWNmSGRWYzRhU2YzZWRkNmZhZlZhZGZaZkVkQmNsZW9hQ2IwY1ZhdmVVZGxnSWU4ZUFnbmVNZFJoRWZqYnhjVGdVZ0ZoSmJkZU9hbWZaZnllVmRoaFZmcWFjZmxjRmMzZ1ZjMGVvZVdhYWZXZUVoV2NXaHljZGJIaEllMmdaZGpiSmVRZ0VhcGZWZzFoOGJmaEJlM2I5YlNnZGNHY3RnNmdZZDBnMWhxZ1Nod2U5YlNhRWZHZ1JlTWhkY25kWmVTZkVoRmVBZXNjSWYwY0FlRmZHaERmTmVSZk5oamRvZjVkSWgwYVJkRGFHZDFhWmgxY01iVWhKZHNkVWRHaGxnWGVXZVJlQWRaZWFhQWN0ZEZjYmN4Y0VlVGdiYjBhZGZ6YVVoQWdZZzdnVWNFY2hhU2dCZGtmTWhsZU9leGQ4Z1hlY2NGYWhhUmFkaDFoZGZLYUZhbWJsZ2hhRmVoaGhlbWJGZ0dmWmdtZFljWGdCYVZkUGZSZThhVGZTZUVnOGJiYlVmZ2RkZ2poTGJpZnNmRWdPYlVkY2RQZ0FjQmZ4aGtnQmRYZTlodGhlZ0VhSWNWaGVhSGdZZFNkU2J4ZmhmRGZXaFdiSmh5ZGNjSGNCaEllQWhBY2diSmhNZUhkaGRKZU9oemRzZjlkSGFoYmNjQmRHZzNmSWFoZVJnV2Y4ZlJhRWMyZTlnSGNjZHhmTmJIaGFmQmRWaEljVWZFZGRjVGdKYnllRWZUY0ZnV2dnYXdmR2REY2thV2FHZ0VlOWdyZWVmemZ3YVlmWmJoYVJhbWNaYW1hRmd3ZFZjV2M5ZmFmUmN4YTBlZGhWZFZhSmUwaE9lVGU4YzNlR2NEZWdkRmZEY3poc2JZZU1oQWJRYy9oSmRWZzVmQ2RSZzNhUmYyZldlMGNJZURlYWdWYmxmaWdjZG5nQmJ3Y1NjRWdOZUpjV2huZ1ZnNGVTYzNhZGY2Z0thaGhZZktnVmdSZWxicWdTZFFiUWI4Y1ZlQWJWYjdhUmNXaGtjNWFSZDJjZ2ZWYlNkRmZCY0hoRWNHY1pjeWRWZmhiVmFxYWNkbGdGZTNmVmV4aGhjVGJQZFRmUmZFYlZjbWNaaGdnYmZqaElncGZPY1FoWmZqaFdiaGJVY1JjSGNSZ3hhYmhiYjBmRmI2aFllMGYxZXFjU2R3YjliU2RFZUdkUmZNZmRhbmdaZlNnUWVsZVlnNWNKaFZiZGFMaEdmaGJZZGFlTWdXYkJneWJhZW1nSmdEaFNnVmdwZzFnZWNFY3RhM2dlYm1lbGZYY1dlUmRBZlphYWNFZWdoRWNQZkZhUWFUaGJiUmFJZ3dnUWhFY3BkNmhGYjFnSmQ2ZFJheGVCYm1kY2NsY1lhVmZhZW5mSmNSZWRjMWVkY0tnRmJtY2thaWZWYTBjc2RqaEZkR2JRY3piTmNUZ1pnRWdlZVJoWWNDYkhnd2hkYy9lVWhuYVJocmhlZm1jTmZOZGFna2ZzZFBnVWVoY0Jja2FUaEhhWWIxYUVmeGhGZ1FoZWdIYlJmSGRIaDFoNWRPZlNkSGhRYithTmVYZ0pmU2ZhYVVlbGZhYmRjWGNoZ0xoZGczY3BicGdWaDFma2FRYkdjV2NnaExhUmdXZjlmRGdWZ2pmc2VTYUlkVmIxZ0hhRWRSYjBoY2NHZ0FnNWhEYmFibmRJaEVlR2RXZm9oN2dXYkdkeGU5Y1NhaGJaY3BiWWVSYVllWWZaYmhhUmJtZVpobWdGaHdiVmJXZjhnZWFBYWxndGZjYUFhQmY0Y2diY2FWZkJmamNUZFdhcGRMYkRiMWNJZlFjWmhFZXhoMmdkYWxiSmVDZ0ZmWGVoZDJkV2d3ZTBjWWhTY3hmeGFyY2NmaWJRZTRmR2ZnYndoZWRXY2pkc2Q5YUhjSGNjYk9hTWNBaGNhY2FkYlVhc2Y2ZlJmQmFkYm5nRWEyaFlhaGREYURnMWZjZUVkQ2VZZFZiRGhSYjRlRWdYY3ljSWQ3YkdoRmFKZndiY2VsZE5hM2ZYZUVlcGJDaFllSGZvZDhhR2VHZ1lmVWhaZm1lWmFoaGNkRmZWZ3ZmV2JrZWNlZGZIZFZiVmdTYmRoR2dNZ3VmWWgxZUJncWVRaDFkdGNTYkdnMmdSZk9lZGRIYTloY2ZGZmxlb2dVZE9jVWdVZU9nU2JpaEFoWWVNZlRiZGY0aGVhVWZGY1BhU2RWaElmd2hlYUZkWmgzZmVhM2JsZ2VnUWZqYm9hWmFhaEFidGVGZmJieGZFZFRkYmMwZmRiemFFYTBlY2IxYlBkMGZoZVFmUmV4ZUJmbWNjaGxhWWRWYU5iMWVoaFJnZGcxaGRjS2hGZm1ibGRoY0ZibGY0Y3pmV2NpZ1VieWRLYURjOGRiaGJnd2YxY1BiU2RSYUZmVmdBZEhnaGVyY01nMmNwYk5jTWdXZ0VkUGdVZ2hnQmhrZVRoSGJaZjJiVWJraEllVmZMaGpiZGJBYVNlMWMxZERlUmFHYUlhbWhDYXlhSWExaFdiR2ROZ2FkZGFYZ2hlTGVkYTNkcGFwZFZkMWRrZVFmRWdUYXhhd2NGZHhmSWFSZ0RjbWE4YVRoQ2FGZm9mNmVZZVJobGNJZ1djQmVOZHJmTGF3ZTljV2hDZkdnb2QzZFdkR2d4ZzllU2doYVpmcGZZZFJoWWdZY1pnaGRRZzdhVGZHZkZod2VWaFdhOWVhZ1JoeGEwY2RoRWN3YWNjNmZLZUNnNGRxZ0FmaWFSYkxmV2JWZHBiRWdhZ0Vnd2hrZWVobGZJZkxnR2FYaGdmemdIY2thdGFYZVNhbGRraDVoV2FIYUJkd2RTZkVjTmdKY1dhbmJWYjRjU2MzYWNiemdMYjFjZGdSZEFkQmVsZTFkRmdsaGhidmdSYVJmMGFqYkFoamcxZ1VnRWJ5aEFjY2dTY0FkSWhDZ1JkRGRNYWdiR2NCYVZibmhZYjBlcGJkYVZjMGVvZVdiYWZXZ0VhV2ZHZEdkWWhVY1pnaWQ4Ym5lY2ZGaDFoRmVXZGtnY2NkYUhnVmZWYlNjZGFHY3RmNmJZYzBlMWNxYlFod2gwZEJlUmFEZlliRmJPZURoRmdRZFFhZ2ZoZmxkZGZrZVljU2NTZ0FmWWFXaEpmSGhJYzViV2ZrZWhkRGRTYlZjcGIxZWVoRWh0ZzNkZWZtY2xjWGRXY1JmQWhaZ2Rmd2h0ZE5kWmQxY1FhVGFjZGtlY2I2Y0dja2N0Zm9jSGZRYkZlUWdXYWhiQmIyZWVhMWU4YS9kYWJuZEplUmVkZjFnZGFLaEZhbWVsYWhjRmVoZGhkbWhGZ0doWmc4YVlmVGFsZVZnY2JWYXBlVmVEY0FjbGRDaFJnbWZ4ZDRkYmhIZGRhYWVRZEVkc2VQaFVjaGZCYmtoVGFIZFpoMmVVYWtkSWFWZmVhSGNZZlNhVmZCZGhiTGRFY0doSmZ2aGNmR2VKZFpjVmIxaDVkT2FiaFdjdGFkaFlkMmUxZ2dhZmZWZ2toUWZHZFdkZ2dMYlJlV2U4ZlJlRWUyZTliSGVjYnhmTmFIYWNiaGhWZUZnUWNsZVlnRWFjaFdjWmdPZEJnbmJ4ZW1kU2hYZ2RiSmdTYmxiOWNwZlpjeGNBZVllYmhsYTFkbWZlaDJkRmY5ZVJkM2g1Yk9lVWVBYWtlRmRSaGtlUmdnYmNnM2hOYnZjWmQyaHBhTGNEYzFnSWdRYVphRWJ4aDJiZGRsY0pnQ2dGZVhoQWQvaEVmbGFZZFliU2FCaEJmcmFmZ2xmcGh3ZFNkRWNOZkpoV2ZuZ1ZiNGRTZTNkZGU2YWFnVmdjY1FnUWgzZ2NicGNaZVVlMGdtZUdjQmZOY3BmUWJYZU1nYmFEaG1oZ2VJZFNjQmU5ZUhkRGEyZFpnaWNWZmdnOWhxZEpjbGQ4YTdnRWFnZlJhUmVQZlNka2VXYUZoV2hZZUZjYmEyZ3BiTGZjY0ZiVmd2YVdma2hjYmRiSGFWZVZnU2FkYkdndGI2Z2NmMGExZDBhU2QwY1plU2RGYm1jSmZNZGZjamQ5Y1NiWGJ4YlVnc2FlZUZmNGVPYlZlZ2FRY05jS2NuYkphN2ZjYkFmRmZLYlJiWGVCYzFmZWFFYnRhM2JlY21mbGJYZVdkUmNBYVpmYWhBYXNhTWRiY3dkOGNPYmJmeGZOYTloWGd3ZklhbWJVYWhid2ZZY1RmamFwZ21oY2FsZFlkVmFhYW5lSmhSZWRkMWVkZEthSGUyZWtlNmRQZUJkaGNtaEZmR2VaZW1iWWZYY0JmVmhiYTFmcGhIZEhkVmZRaFRkVWhuZHdja2VjZjJjTWRmYkxkeGc5ZGFlQWFGZjVoa2VRaFdiZGF0YmVkRWJJZ1ZiZWNIZ1llU2RTZnhjaGJEZ1dnV2hKZXlhY2NEZ2xhSWJYY2tla2FPYWVmemRRZ09jT2RUZzBoOWdIYjFna2ZkYUdlWGZrZ1FkYmYyYThmUmNFYzJmOWNIZmNmeGdOYUhlYWZCaFVlVmdVYUFoSmVjZE5hVGFkY1dmWGdDaHhmeWRXZ1dhZGNYZlZjQmdZZmdkYWNCZlphRGZUYkJiUmJtZlpkbWRGZHdkVmJXZDlmYWVSZ3hnMGdkYlZoUmVzZHloYWMzZUphaWdBZm1nTmVMZ1hhUmdkYkVjTWFSZDRjNGdkaGxlOWJUYkRhbGVKYzJoRWFrZXNoWWdRZzFjbGdpZmNkbmJCYndlU2JFZk1mQWRXZ21iaGc0YVdmMmh4YVFkYWFWaGRnWmZFYkJmbGRvZ0NmMGZWZ3ZkRWVVYjVhRmZSaDNkTWVUY1JkMmVnZ1ZiU2dGZEJjSGRFYUNiOGMwYVZmaGQxaGlhY2VBY0liamZCZFFkTmNZZUxobWRNaFdnQmhYZHNiVWRNZGpjOGR4Zk5kUmRvZXBhV2hoYVVlZGdHaDFiTmZTYmZmRGZsaDZoZmZrZzBna2dSZVVoa2VBYlhheWJsY0VmSmdIZnBjU2JCZXhleGV4YWVkaGFJYkZhRmJnYW9mS2FBYkNjY2QyYU5oZ2UwZVJkUWFRaGhlOGRjY1VnSmZkZWVmbWVsZ1hmV2hSY0FnWmJhaEFmdGhGZWJkeGJFaFRlUGdRaElibmNSYWhmVWVtZUZhVmhoZVFiV2FnZDFmN2VjaGdoUWhiYkphamRjZmZoTWZBZE1jQ2JGY25mWmFoYUdhd2JsYW1iRGVtZFlmSGZhZlNoUmNaY2Jhd2doZUxnSGdWYVJlWmZVZ2pmRmVuYWVnaWN4aEVkY2NXZUVnUGFVZ2hlQmFrYlRoSGFaZzJmVWFrY0lnVmZNYVRlQWdTZFFjeGVvZk5jRGRDYzhmd2ZOYlNkSmJLZlFhMWVSZkhkZGNTY3dhU2ZKZHpiOGJtYUVkVmFsZUNhRWZFYklkTGFSZFdoOGZSZUVnMmE5aEhlY2Z4ZE5kSGhhZUJjVWRhZ0ZjUmROY0ZoTmJEaHhmV2dIZVVmQmd5ZFVmWGJkYlhoU2NoZFpocGRZaFJkWWNZY1piaGZSaG1kWmRtZGtoaWhWZFhiSmdhZlZiUWJnY0lnVmVWYlJoMGFPY1hhTmR2YVpiMmZwYUxjRGIxYkliUWJaZUVoeGcyZmRhbGJKYUNkRmNYYWhnMmZYYUViVmhzYk9iaWNrY0hhRmZnYzhkUmhPZGpjRWJvaElkd2RvZUxkUGJnaGNiS2NCYmliVWh0ZkVoQmU5Y3VmSWhVZ1ZndmJFZVJmTmd2YVJlM2ZNZFRhUmMyZWdmVmZTaEZjQmhIYUVhaWFBZ25jR2hGZ1lhK2FPZHhlNGQ1Z1ZiVWhvZ0xlZGVHYkZmQ2ZRY1RlWmNSaEtmU2VCYWhoQmRSZXdnaGREYWxoOWI4ZVRhd2VjZlRkTGJXZFVocWhNZFFhSWYrYUJmRmFzYUxhUWZDYkZoQ2RQZXphZ2hXZEJjMGIwZ1hmTWZEZmhjTGRHaEVhTmNaaFljbmZKZXdmY2RFY2hnRGFTYlZlcGcxZ2VmRWR0YTNnWmNXZWtlWWJjZnhkQWJaYmFiQWZ0YUZlYmJ4Y0VjVGJiZjBlZGh6YkVlMGFkYW9lRmJVZWhjUWhSY3dlOWRtZUJmeGQ5YmJiUGhtY29md2VKZlFiVWJMZlRjMmZjZnhhUmNGYWNieWRXZXpkSWEvYk1hVGdWZGJmSmdoY1FhRGNXZEVlVWE2YUZjSGdvZW9hT2d5ZzhhQmRZYWhjOGVEaFVja2RKYW9iVGREZzlkL2ZlYkVoSWZWZWVkSGFZYlNiU2F4ZWhjRGVXYldnSmN5Z2NnSGZCZkloUWIwZGxkYWRkZldkSmVMZEFnamhNZ25oQWMwYkZjeGdTY3pncGRLaEhiR2ZGYkJiUWFTZUFkVGJQZEVkY2JlZE9lRmhCZUdnSGdBZVpkRGdNaGhoc2JZYlVoU2c4YXFmUGZqY0ZkWmdDYlZhY2NsZ0xoUmg1YU1mYWVoZ1FmMGdhYW1mRWU1ZVhnRWdWZGFmUmd4YjBkZGJWYlZmSmcwY2FmM2ZwZWpmVGVXYXBjTGREZDFoSWRRZmZia2F3Z1hkZmhnZVpiT2hGZFFnTWJrZmJhMGdjYVlmQ2VsY1ZkaWJOZzNneGJ3ZkJnMGVwZGpjV2ZuZlZoNGZTYzNiZGg2YWFjVmNkZVpjRWRCYmxib2JBZmxoNWdGZEVlUmFOaHZmUmQzaE1nVGNSYjJjZ2RWYlNkQWhRZlBlUWFpY2thbGhWYWxoc2V2ZkpnVmZFaERoRGNoaHBjVGNEaERhTmdFY1ZlemNRYmNmWmZEZEFmZ2dQY0ZjVWFpYkRleGRSaEpiSGNSY2NhWGJkZURhZ2F1aE1iUWVRZmtkRGVBZE5hU2dYaGplRWZCYU5lRGRNZEFjUWFsZ29hcWhkZ25oQWVlZ1hjZ2JVZ2NjTWNIZ0JmNWVhYzJoSmVEYlNlVmVwZTFhZWRFY3RlM2hlZ2pkUmE5Z1djUmRBYlpnYWVBZXRnRmJiZXhoRmVWZ09hZ2ZrYXdiUmN3YzRjbmhXaDBoZ2V4ZFRiMGRSY3FlY2FnZFFlWmNhZ2pldGRkZmRoeGNKZkdiRmJpYlpkb2NGZ2thTmJNZEZoR2RaaG1nWWVYZkJoVmViYjFncGZIZkhiVmdzYUFhSGFEY2NhL2NNY3lid2REZ2FnZ2ZNZ0hnQmFoYXhoa2NIY25nOWcyZUNiV2dnY1ZkZWNIYVliU2FTYXhkaGNEYldjV2VKY3liY2hIZkFnYWhCZmhkMGJQZ0pkemZaZUxjWmVuY3BlMGRTZmtmUWhRYlZnMmRnYlVmUmJUZ3RicWhRZ1JjSmFIYmFlUmJNZVRlWmRraGNiTmdFZFFmTmVsZERkemR3Z0NjQmdIYXdlUWZOZ0hoOGJGY1NkaGZ4Z3BjTGZ4YjhmRGVUZEJjUmRtZVplbWZGZXdmVmVXZjlhYWZSY3hoMWNBY2ZjMWhKZTBoYWMzYXBjamhUYVdncGdMY0RiMWFKYkdmSmNSZDVhMmRPZkZkSmJmY0ZmV2VsYjZkT2hFaHNiWWFRYjFhbGVpYmNlbmRCZ3doU2FFZU5mSmJXY2liWmQ0YVZlbmVjYnVjWmZ4ZnNnY2FYZ2xjNGI4YVFhMGNsZUZiRWVSZE5odmRSZjNmTWRUYlJjMmhnZVZoU2ZGY0JlSGZVaFdhWmh2YVZna2JkYWtnUGVoaFFkNWNFZUJoNWRlZmNja2hzZVdiR2VHZ1lnVWdaZW1lWmVoZGNhRmJWZ3ZlRWZ3ZUVhZGZGY1hmOWZTZmRiR2V0YjZlWWIwaDFmcWhTZXdkOWJTYUVoR2VRaGFlT2FUYzhhV2NRZGdhVmg0ZGRld2E5ZFdkR2JBY1pkWmVaaEhiUmhhZGNiRWdoZ0RhU2dWZnBhMWdlZkVidGYzYWVjbWNsY1hnVWdSZmhoY2JhYkJlWmhGZUhnRWVWYUJmSmVnaGtoMGFHaHdoSmJoZUdkeGZ3ZmZhS2MxYzhneGFOZHdiUmMyZ0theWFFZlVmZmUxYTVjRGZHYmtlTmRoZ0ZjaGhoYW1nRmhHZFphbWFZYlhlQmdWY2JnMWhwaEZhU2JGYzRiR2JRYUhjWmhyZFphM2M1ZFFhYWdnZzRjUGNEZWtoeGdPYVRnSGdaYTJjVWhrZkljVmdlaEhnWWVTZlNleGJoYkRjV2VXYkphd2dKZVRlTWhiYVRmbGJ0YlliZGhXaFZmV2NhZm5jb2hzYlZjd2RWZ01hTWcyYWdnTGRSaFdlOGVSaEVjMmc5Z0hiY2h4Yk5lSGRhZUJlVmZJYlVhaGRKZkVoSWZHZ05nQWdXYVNiOWh3Y1VoV2dwYktlVmh4aFlkc2VZZ1VhcGZFZFRoQmFSZm1hWmhtZ0Zid2FWZFdjOWRhZFJmeGEwY2RiVmJWY0pnMGVhZ1NhOGYzaENmMmdkYWFnR2dSYTVhVmhaYmtjeGdyaGFhMGI5Z0NiVWRIZUZnY2hFZGtnc2VZZ1FhMWdsZGliY2NuY0Jld2NTZUVhcGVKZEFoVmc5YjRnU2MzY2RkNmJhZ1ZiZGRaZUViQmZsZW9lQ2QwaFVkbWhWZHhjTmFuZUVhM2gxZmZiQWZpY1poU2ZIZUJjaGNIYkRnR2NaZGdhVmVrY2tlMmFjZWdmTmE1Ykdhd2Q5aFllTGRqY1ZnZWNHZ0hhb2dVaGRnR2c5ZWhkSWZoYkFnN2NEYXhkVmJUZEhiVmJoY0RmYmIwYUZlNmRZZDBiMWhxYVNkd2g5YlNiRWFHZ1JlTWdkZW5oWmhhZURmQmNWYmxmZGhnYkJmQ2dGZUVkTmFSYk1lWGdKZy9nYmFVYWhkUmJRY0ZkWmQxZmNhQWdwZzNjZGJYZlJhWGZTaHhha2NWaGFkQWdNYU1oYmR4ZDRiT2ViZjFhVmM2Z0NnR2IxZm9oRmVVZ2hjUWJSYnhoQmJtZ2NlbGdZYVZhTmIxY2hoUmhkZTFkZGRLZEZibWJsYmhnRmFoZGhobWFRaGlhY2YwZlliU2JWYk9iUmRWZHBoSGFIaFJnMWdWaFVlbmNSZ3JkZWVtZ01mRWNMZ0Vlc2RIZUhiUmdsZWtjRmMxZXhkMmVVZGtnSWhWZmVmSGdZYlNlU2F4YmhoRGFXY1djSWdrZ01hU2JKZ0loQmdVYmxkSGdkZVhhVmVhY2JlRmRCY3BoVmUxZmtlUWJHYVdkZ2VMYlJhV2Q4YVJlRWYyYzhiQmZQYkVkRmFIY1ljRWVCY0lkVGdVYmRhWmhmaFhhSWhGZkZoWGNSY3lhQmFHZnhlWGNIY3hlMWZpY2FkRGR3Y1lmWmNoYlJmbWZaYm1kRmR3ZlZiV2E5ZWFlUmd4ZzBjZGJWYVJic2h5Y2FhM2NJZXJhUmJUZjVkSGhEYXdiY2FaZlphRmZGZnJkYWQxaEliS2NIY1NjcGc2YkVja2FZZ0poUWQwZFJkL2FiZTNmQWIyZlNmRmR4YkplU2RuaFZlaWNTYXliSmQ2Y1phRmFjZ2ZiR2ZSZEJib2JVYUdmOWF2YkViUmdOZnZiUmIzYk1hVGVSYjJiZ2hWZlNnRmJCZkhkRWNHY1pneWNIZDFmTmZxZ2VnbGJsZDZmUmNrY29kTGVkZkhnd2JXYlhjbWdZYVNmWWRHaFpicGNOZ2xjVmF5ZldoaGdJaFVlRWVWZVVhSGJkY0djWmc2ZEplVWUxZmhhU2F4aDVkU2VEY1hobGZSZmRkamZkYWJoU2h4ZFVmcWFNZTBoWWNlZFNoZ2YxZlpoSmVIZUpnNmdjZEFjWmRZaFlmMWZwZTFnZWNFZ3RmM2VlY21obGVYZ1dkUmVBY1piYWZBYXRnRmVNaGhkRmdXZElheGdRYTJiRWEwZXBoNWJGZlVkbGZOYldmaGhBZGdhY2JsYkFmVGNhZ25mb2hFY2RlMWFwY1hnRmNqZXhhaGFHZXhnZ2NnZUhiV2VwY21hYWVUY1pnVmhjZ2xmcGhLZERmQmRSYU9oZWZIZFJjcmZlaG1oTmROYWFoa2FzYlBhVWNoZ0FiNWNUaERoTWU2aEFkUWdjYy9hZWFIaFloU2RTZHhnaGJEYldlV2ZKZ3liY2FIZUJoSWJCYVFkWWJJZ2RkWGZBaENmZGEzY0ZlcGJGZGxna2dPZ0dlVGRzZUxlUWQyYWtnUmdHaHlmWmhIY2JkaGJNaFVhYWRCZGhjSWNFZFVnNGNjZFphaWFkZldoQ2hHZW9jN2NTZm5hY2ZDZFNmZ2NoaDBkWWhRY1lhRGJaZmtoRmNyZWFnMmdoY3dkRGRrY1ZlYWFSYnhoMGFkZ1ZjVmRKZzBjYWEzYXBnamhUaFdlcGdMZkRheGVSY2ZjTmZrZHhoK2JJZ0JoTWZRY0ZoVGFSaDJoRGEwaHNjWmZVYzFiVmFpZk1lWGdCaHRnU2dGZ05mU2dXYmpiUmU0ZVZhWGJjYzVkY2RsYWNoYWVHZHhoSmZoZklhVWVWZXZlRWJSZk5jdmRSZzNnTWJUZFJhMmFnZFZoU2ZGaEJkSGRFZUdjWWY3aEVmQmZWY2lnT2RsYmtnamZXZDBhcGZEZ2FoV2hvZFdlV2UyZDhlVWdaZDNodGQ4aGNhQmExZm5nQ2ZFZnNhZGRYZ2xneGViZGRiRGNCZlFnWWUwZjFmcWhTZndjOWNTY0VkR2NSYU1kZGZuZ1plU2dRYWhoVmc0aGRoaGhKZ0xhVmVFYk5nRWZZY25hTmhoZ2FhMmNKY0RnU2NWYXBhMWZlY0VmdGMzZmVnbWZsZFhnV2FSZkFjWmdhaEFkdGNGYmJmeGZGYlJkUGdRZklkeWZXZkZheGVDZkZjVWNoYlFhUmJ4Y0JibWFjZGxkWWNWZmFmbmhKYVJmZGgxZmRkS2RGZ2pkUmJMZUZoaGZoY21oRmNHaFpobWdZZ1hjQmhWZ2JhMWVwaEhmSGJSZjBlY2RGZUhjUmJqaE5kbWNwZk5kT2RBYTVnYmVCaDBiSWRxZ1RmQ2NOZHRiZWRFZElmVmdlZkhlWWVTaFNoeGVoYkRjV2ZXaEpoeWVjYkNjMWhpY1FhMGZsaGFiZGVYZGhiTGNkYzNjcGdwY1Zmd2d0aFZnVGJUYjFlWmdDaDJmOGZjZ0FlbmJSY3RkY2F4ZE5kSGNhZUJoVmdJZVVjRWZkZE5oVGFIY0pmV2JGZ1dhcGF5YVVlWGdkYlhkRGJFZ01obmVJZGtoSmVSY0tkVmhwZG1kQmhXZGtoa2JXZVdjOGJJZlNoeGMxY1ViV2hWZElheGZZZm5hb2Q0aFpiMmdwY0xiRGcxYUljUWRaY0VieGcyZ2RnbGVJY0xnRmZXZlZiMmhmZ0JlNWRWZ0FhUmd3YndhZWdqY2xkNWJTaEJhOGRWZVdnbWhWYWpnWWdYZGRmNmNhZlZlZGJaZUVmQmZsZW9kQ2EwZ1VjNWZVZ0VnRmN2YUNlSGRNYk9nUmh6YXdiYmVCZ0JlVWNKaFZkemFJZzZjVmFoYmhjcWVPZjBkcGJkZ1ZmMGZvYldiYWZXZEVoV2JHZkdlWWhVZFpkaWFOY2hoYmQxZFZkbmVVZ2dnSWRkZUFhRmZVaDhjSWJTZ1lmNGVKY2hnOWhpY0RjZ2ZaYmJkSGRHYVFnSmZkZG1naGdTaERkUmNWZStiY2VCYkplRGRYZVVlTmFFY1lmamQxYjVnZWZVZmhjWmNTZFZlSWJ3ZWVlRmRaZjNiTmNXY0JmTWVjZ3hnQWJaZGFjQWJ0Y0ZkYmZ4YkVnVGViYzBhY2dsZVViaGdWZ29mWGdVZ2hiTmZSZDBiSmNvZFBjaGFOY2JiTGNTaFliWmJiZUhoMWNLYUZobWdsZGhjRmhoZmhhbWJGZkdkWmFtaEtnRGNaYlZlWmh4ZUpoSGFHYUJiMWhIZlVhbmVWaDJkWmMyYk5mZGZZZzBjdGNiYUdia2dJZHJhR2IzZFlnNGVGZHhnVWJWZERnQ2I5Y0NmRGFuYzBoUmRDZnlmMGVnZ2VmSGhJYmhkRGRSYjhnYmFPaFRiRWhQZGRmemFJZ3NiRGMxZmxhRGdUZ1RhcGhDZENoeWhnaFRiR2VuZlJldGhjaHhlTmFIZmFjQmVWZElkVWVFZGNnUWNaZ2pnZGhXZ0NmMmFvZzZkVWFYZGhjWGJXZkJoWmN2ZFpkeGJZZFFkSWd4ZlJnN2NaZmlnbGh3ZVdibWc5aEljVGVnZllnM2ZWZlZoSmMwaGFhM2NwZ2pmVGhXaHBlTGVEZnhhUmNmZ05ia2V4YitmSWFCZ01iUWNGZFRjWmQyZURoMGVzZkljV2dGaGtnbmNjZW1nNWN3Z0JibGRoYkpnVWNYZjRkMmhRZW5mY2RoZFFiMWJkY1pmRWJCZ2xob2hDZTBlVmV2Z0VmUmNOYXZkUmN5ZFZoU2ZGY1dnaGhHZFNhRWExZUhjUWZDY2NjZ2dCZVZjQWNEYlBnQWdWZC9hQmdVYVJhRmVQZENjTmJGYVRnRGdRYWNnZGVHZVpmcmhjZ0JkdGVqYVdjbGZVYlVhRWZWZVZiRGVZYm1nSmJoYlNlVWYxYnFlU2h3YjliU2FFaEdnUmRNZWRjbmhaZVNlUWRsZXdoK2RkZmhmb2ZDZFNoeWQwYVllRGZIYW9mamFlZ1VmRmFEZ0dmeGc4ZGhoTGdSYWtnNWhlZGlkZGVNY2NkeGRBZ1pjYWhBYnRkRmViZnhiRWRUaGJkMGZkZnpmRWF4ZU1nVGNYZ0VnaGdiaFJmMWc0aGJkY2NrZHNnVmdPZVdobGI3Z2RoMWRkaEtkRmZtY2xlaGNGZmhjaGJtY0ZjRGR0ZU1oWWVYZUJnVmNiZzFmcGJIY0hlUmUxZVZlVWJpYllmdWVMaGphWWhmZUpmRWh0ZEJjU2ZUYnBha2FUZEhkWmMyZ1Vna2RJYVZnZWNDYnNoNGhTaHhkaGREZldhV2ZKY3liY2VIZEFnT2VGZmdoY2NaYklkVGdFYUVoT2FYaG9jcmZYYndnMGdjYkdlVGhvYUhkUmdTZ1lnZGhFYXlncGVPZGNoMGVoZnRoYWdCZ1ZlSWFVZ0VjY2NRZFphbmRKZldhRmFUY2djM2dCY1NiSWRGY0JoQmZZaE9mYWNYZjRkUWFOYkJoaGJtZE1hbWY4YzhnRWJDZEVnZGFFZjFoVWhkYVdmRmVJZzlhWWJuY1pnamVHaFdnWmZMZFJlbGc0ZFFkSWZVZ1ZndGhYZkZiSmVDZEZnWGNoZDJkRWhrZHNjWWhIaG5lTmFpZmNhbmZCZXdmU2FFYk5oSmZXYWpnTWd0YUJlVGJRZnVjSWJCYmdiWGdFZEhleGhnY1hoMGRsZXZnUWJ4YjlidmhEYm5hOGhUaEFibWVFY1ZmRWMzZHBiSGFFZ0dlWmJ5aFZnaGRWYnFoY2VsZUZoM2RCY1FnOWJDYlBiRGFOYllnR2JBZEVjY2RFZkdiNGZ6YWVmVmJsaHZmRGhrZ3NiZGRWZ0ZobGRTZ01mV2RKZWhkU2JVaDFkcWZTYndmOWFTaEViR2RSYU1iS2cxZHhhU2dRZ2hhVmQ0ZmRiaGNKZkxkR2JBaFVhTWNMY0RkRWVrYk9jUWFjZ05lU2dTYmhnOWdMY0VnZGgzZktkR2JWZVhnRWdCZndjWmdMZ1FjSmJGY05kRGJzYVRkYmQwZGRmemhFYzBoZGNvaEZiVWJoZVFhRmNWZVVkeWdKZ3dkUmViaGFkaGVkZFpiSWExY3RoS2ZSZUdoVmRoYlhjeGdSZG1kVWJXYzljOWNTYTNlQmVWZGJhMWdwZkhnSGZSaDFoVmJEYjFoNWNyY2VkbWNOZk5kYWNrZHNnUGhVaGxmWWJ4Y0FkamRVZmlmR2R3YzFjYmRlYkNmNGJhaEhmeGdSaERoQ2YyZDVmeWhPZlhleGFJaEJla2JCZ2FiTGhsYUpkTGNkYTNocGZwZlZoMWZrZ1FlR2FXYWdhTGhGZ3licGRGY1JmamIwZEpoY2IzaFJkUGJFaGhiMGFhZldmVWNzZlFnTWhuZzVhV2VYZ0doWmh5YkZiSGU1Z01lWWNCZVphcGJZY1JmWWdZZlpiaGdSaG1hT2YwZnRid2dWZldoOWFhZVJleGcwaGRiVmNSYlFhaGVKYVRja2UzYkJjQ2FVY0ZjRGF6Y0FlWWVNYUVmQmUyZEplRmE1ZENjWGhIZVJjMmdWZzBhSWJZZEdkSGZOYWljY2JuZkJld2dTZ0VmTmRKZ1dnbmhWYTRhR2JUZUlodWhQaEFjVWdYY0VkSGU1aGdlWWNVYzBnOWdIZlJhTWg3Y1NkVGI5YVdmQ2JTZDllQmJBY0ZjQmdLaEVlQ2Q5ZzdoV2JoY1VkK2hmZWxkRWQrZVdoMGNwaFRjWWZIYm9kOGdHZ0diWWJVZ1pjbWhaZ2hnY2ZGZ1VoeWJjY0ViY2NkaEhmVmdWZVNiZGhHZHRkNmVKZ1JnZ2ZrY0NhRmRzZ2JmWGR5YXBmTWZBZm5kNGJHY1RmaGZVYXFkZWJoZUllQ2JFZVVoTWRDZFNhSGZKaHdoY2ZFZ2hjRGNTYVZncGExYWVjRWhzY2xmUGF6ZzBoQ2hDZTFoNGJaZEdlUWVVZkRiUGhWaDViZWFEYVJoNGZuY1ZlaWhZZzZiUmR3aGtmSmNUYXdmQmdtZWJlMGJzaEliYWFpaEJnUmJjaFZiRmFLYVhmMmdsZThlQ2h3ZFZlbWRRZUdhZ2hxZ0pmRGc0ZVNhT2Z4Y0plSGJBZmhiMGZCYlVobWU1Z3JoTGZtYTBoZWVKZWdhSmJNYUZmeGZnaDJjUWhIZlllL2FXYTBmc2VPZlVhbmdZZ1NjU2d4ZWhiRGhXZldmSmV5aExlVmJwY0lnUWIwY2xoYWNkYVhmaGFMZGRjemZ3aDhhR2NSZnBkRWJVaENlZGJGZFJiUmE4ZVplUmIyZ05kSGRJZ1JjOWhIaElmUmV4Y0loQ2YyYjBkUWRaY25kSmNXZUZlV2hwZ3lhVWFYYWRoWGJBYXhhWmUwY1loWGd0aFpjTWhsZHhmb2NLZXlhZ2QrZVhlVGd0ZVVmQ2IxZWhmVGNFYmdjWWU4Z1pmM2NvZ3FmUmJIYUZkaGREZDFmSWNRYlplRWR4ZTJnZGhsaEpoQ2ZGaFRoNGc1ZFFoRWdzZFFkRmhSZ2dkd2FjZmpmVmN3Z1ZoVWhNY3ljSmUzYmxkNGNCZEhmZGhuZmFhUWdWYUNnRWJGY0Jlb2ZGZFVnVWFnY0NoaGJOZm1iUmh5ZGdlNWVSYjJnZ2VWaFNhRmFCYUhiRWJHYVpjeWZWZGhiVmZxY0plQmdBYmxkVmJ3YkljV2FkY0doRmJDZVloeWhsZXBoYWFrZ3hhaGJjZkZmVmF2Zldla2NjYmRmSGNWZlZjU2FkaEdldGU2ZFlkd2hOZXFhVmRnZDhhY2hSY1NiZ2RBaGVnbGF4Y1NoUWdoZVZhNGRkZ2hmSmZMZUdlRWFOaFphWWRuY0pld2RjYUJkdGJEYlZjRmVvYjlnZWNGaFZhM2JhY0hicGhPZVdhUWY4aFpnZmdBZnRjZmRiZDFma2NUYmNoVWVkYmhmQWFWZ1Jhb2JDZGtoaGVEYVJkd2RwYm1lT2JsYlloTGFhZG1kTmdJYlpmbGRkZVZlRmRuYXRkaGNEZkJhaGgzZURnMGV4Y21hWWdYYkJhVmdiZTFncGhIZkhoUmMxY1ZjVWduZlFhaWVQYkdjTmRGZ0lnMGdzZlJnVGJ4ZkFkcmJUaEhjMWMyZEFjVWVzaFZiSWQxY3diU2FTZnhkaGNEaFdmV2JKZHllY2dIYkJiSWNRZzBjbGFhYmRiU2I0ZEtmSmVYZW9hb2FXZDFjbGNGaEZhV2NoYk5kU2hXZjlmZGZDZ0VmVmFIZ2NheGROZ0hkYWJCZVZnSWZVY0VnY2ZRYlpibmZKYldlRmVUZGtlbGZHZENnTWVVaEFkaGRaZ2hkTWJoYjhjWWFQZFRhNWRtYlphbWZGZndnVmJXYjlmYWZSY3hoMGZkYlZnVmdKYTBmYWYzZ3BoamREYWlkc2hZZFNlbGNJZkJjZmVtaFpkMmJkZWxlSmdDZkZoWGFoZDJhRWVrZnNhWWdRYTFjbGJpYmNnbmZCZHdmU2hFaE5iWWJTZ0diMWY0Z1ZkWGhjZXljYWZWaEZoZmNFZ0JhRWJtZ0NnMWZoaHZnV2ZSYnBnMGRiYlhlTWdUZVJnMmVnZ1ZiU2VGY0JhSGVFZ0dkWmh5ZlZlaGJWY3FiY2JsZEZhM2FWaHdnaGFFZ0xmQ2hCZ2RnQWIwZHdhVWZaaG1lWmRoZGNiRmRWZXZkV2FrZ2NhZGhIZlZlVmdTY2RlR2J0ZTZjSWVBYXdjNWNEYmdlOWVBY0Nia2E1Y01jZGduYlphU2RRaGhiVmY0ZWRjaGFKY0xhR2VFZk5iWmdZaG5lSmN3ZWNhRWdoY0xoQ2ZGZXBob2RlZ0JkOGNNZU5jV2ZsZ2NjV2dRaEZka2ZZZVFlZGZ2Z2JleGZFZ1RhYmMwaGRiemZFZjBlZGVvZ0ZoVWZoaFFiUmV4ZEJhbWJjZmxhWWRWZ2FjbmZKYkFkWmRVYTlnS2ZDZTNhUmE4ZkZjaGNCYjNnRGhYYVJlbWdaYzNhQWdVaFpjbGZwZEJkR2V6YmRjVmNVYm5hUmJyZ2VibWJOZU5iYWVrYnNlUGdVZmhkQmZraFRiSGhaZzJkVWhrZUllVmJlZEhjWWNTZ1FieGZBYlBhV2ZYYzljeWRlYkhhaGFiYlVna2FsZGNlZGdUYUJhQ2ZkYTJhWmMxYVZoMGc4YlplR2FUYlFjTGRUYlhla2dDY0VoMmFsZEhjTWRoYXBoT2haaEJoVWZFY1ViRmdrZVFlZGYyZ0JhQmhGY1dneGIwZlVkWGM4Z1pkU2RnZnRocGFMZFJhOGRSZ2ZkVGM1YW1lWmRtaEZnd2VWYldhOWZhaFJneGMwZGRoVmJWZUpiMGNhZzNhcGVqZlRjV2hvZEplWGRSY2RkUmVMZjFiZGRjYmRjbGFKaENkRmZYZGhjMmdFZWtoc2FZYVFoMWhsYWliY2huZEJhd2FTYkFoQWNJYkNhVGFCYzRiV2VHYTFjUWdhZVZmZGRaZ0VoQmFsZ29iQ2gwY1ZkdmZFZ1JmTmd2ZFJjM2NNZVRhUmcyZGdmVmNRZUJjRmZIYkRoV2JZZm1oTGRWZHBjcWZlZVZkRmhtZUtka2JNZWFmUWEyZEVjV2dHZEdnWWZVYlpmbWhaYWhiY2JGZ1ZhdmJXYWtnY2hkY0hmVmVWYlNoZGRHYnRnNmRhZ3hlaGJxZVZjZ2U4ZUdlYWN5Z3RhTWhmaFhjWmJBYlBoeGd4ZzBiWGRCYkpiTGNHY0VoTmdaZ1libmhKZndkY2hFY2hlRGZTY1ZhcGUxZWVmRWd0ZjNoZWJtaGxjWGVTZ0FmSWVCZ2FmQmdaaFlnY2hoZEViYmFmaGxkNWVoYUVlMGVGYm9lVmRFYUZnUWhRYlJjWmRNZGNjbGRZZFZjYWNuZEpiUmNkYzFmZGRLZEZkbWdsZmhiRmNoYmhmbWJGaEdnWmVtZFlhWGdCY1ZmYmYwaHRlVmFCZVJmMWdJZVRnMmhsZnJjY2RuY0piVWFlZEVlc2hKZVVna2RWY3RkVGJIZUJjd2RlZEVhSWNWY2VnSGVZaFNkU2F4ZmhhRGdXZldiSmh5ZGNlSGFCZEllUWEwYWxiYWdkaFhjaGZMaGRlM2RwZWhhWGZ4ZFVlUWJCYkdjZ2ZEZ1RiWGM0ZUVmRWEyYWxlSGdPY3hjcGhIZmRkQWFsZUlkUWZWaFVnWmZaY2liNWVXZEhiV2ZKYWtiUWNuaGRiUmZTZmxjZGhnaFliUWNvYUVjWmhnZkpmdmFaZ2pkMWF3ZVhiWGRsZEpmUmd4ZHNnZGVBYUZjdGU5ZFpiMWhCZ2plVGhXZHBoTGZEZDFiSWRRZFpjRWZ4aDJlZGRsZEplQ2dGZlhhaGUyZkVka2dzYlljUWIxYmxiaWRQaG5iQmV1YVNjRmZGZFpmVGhtY0piNGFUYVhlRmc2Z1lmVWNKZE1lQWNnYkJnK2hDaDFkdGh2ZFhlUmhNZHpiR2IzZE5iZmFSaDNlWWJWaFhoVWNkZFVhQmZIYlZhN2hWYWhjTmZzZ2NkbGRrZTVlVmcxZWNnV2VKZldjZ2RmaEFhMGd3aFVnWmdtYlpmaGhjZUZnVmJ2Y1dia2djaGRlSGdWZVZhU2JkYkdkdGE2aFlnMGIwYm9lR2ZVY29mVGVXZTNoOWJtZWRjbmJaY1NjUWhoYlZiNGRkZGhoSmFMYUdjRWVOaFplWWhuaEpkd2JjYUFnc2VDYUdkaGI5ZTFhYmRGYUZoZGFlZW1nbGFYZldkUmRBaFplYWNBZHRlRmZiaHhkRWdUYWJhMGZkYnphRWYwaGRlb2NIaFFkbGFRZFdhaGRBYXlhQ2VSZWtmVmdZZ1hoSmVBYUNkbGI1YUdlUGJHYWxhaGVGYWhhaGhtZ0ZkR2NaZ21hWWFYYkJmVmZiYzFlcGhIZUhkUmExYlZmVWNuZ1JocmdjZmpiWmFOaGRmMGR0YmJnS2VWYTloa2hSZjNlWmRraExkMGVzaFpoVWRuZlliU2dTZ3hnaGFEZldiV2hKZHlhY2dIaEJhSWJRYjBobGhhYWRjWGNoaExoZGEzaHBncGNYZHhkOGRRYkJmR2VoZ2ZlUGZpYUFmUmJHZEdhOWJVZERiaGVwY0xlUWJoYlZmSWhVYUVoY2ZRZ1pibmRKZldiRmdXaHBoeWVVZFhiZGNYaFNoaGVaaHBmWWJSYVlhWWVkZndoWmcrYlpibmF4YXRnU2dHZjlmU2ZWY2diUWdQaFZmVmdSaDBhS2RuZE5kamVTZDJieGNoZ0RnMWdJaFFiWmJFZ3hhMmhkZWxlSmhDZkZjWGhoZjJhRWRrZ3NmWWFRYzFjbGFpY2NibmVCYXdoU2RGaEphYmdRY25hVmRsZVZjbWRwZzZlWWJVYlpiQWVBZ2hmbGV1aENheGdCY21lRWZSY1ZicGFiZ1hlTWFUZVJiMmRnZVZjU2FGZEJkSGhFY0dhWmh5ZlZlaGhWZHFmY2JsZ0ZlM2FWaDBjb2NXYWFmV2VFY0hlQ2duZzRjVWZlZDNidGI4ZWNnRmgxZytjUWExaFVhZGNHYTFjVWZVYmZnV2h0ZDhnWmNXZGRocWFTYndjOWFTYUVmR2VSZ01lZGduZ1pjU2FRYWhlVmg0ZGRiaGZKaExnR2ZFaE5mWmdZYW5oSmZ3YmVjRWJBZFBhU2dVZmRoZmJlaEVodGIzYWVmbWRsY1hkV2NSZUFjWmdhYUFmdGdGYWJieGNFZ1RkYmYwYmRlemdFZjBjZGRvZkZkVWZoaFFoVGh4Y2hmM2daYzFkWWdUYWFmamJwY1liZGMwYnRhV2RGYm5maGg1Y0hneGhnYzZmUGZtZlplbWRZZ1hkQmFWZ2JmMWdwaEhlSGVSYzFnVmRVZm5nUmFyaGVlbWFOZ05hYWhrY3NiUGFVY2hhQmVrZFRmSGI1YStjUmhGY0VoVmFmYm5jWmRUYVFiaGNoZmZiUmhXY0pmamVZZW5nbGdJZEhjMmVOZGFkZGhYZmhjTGFkZjNocGdwYVZlMWFrZ1FlR2NXZmdjTGZSZldlOGZSY0VlMmQ5YUhlY2F4Y05mSGRhZUJmVmJBaFdnRmNFYURhWmNuZ1JkV2VRZ0doTmF5YlRlV2F0ZVhmWGJCZDljcGJQYlRld2ZZZlpmaGNSZm1mWmdtaEZjd2dWZVdiOWNhY1JheGEwZ2RhVmZWaEpmMGhhYTNocGZqZ1RkV2RwY0xmRGgxZUliWWhjaGxiOWcyYWNiRmhJaEVlSGdIZUZhNmFPZkVic2NZY1FmMWdsY2ljY2JuaEJhd2VTYkVlTmNKZldjbmFWZTRnU2gzZ2RmNmRhaFZjZGZaZ0VoQmNrZGtkQ2gxZ3RmdmNCZXdnWmg2Z1ZnR2VZZFRkUWJXYzRkVmFXaFViRmVXaEJjSGJkY2pnUmRCYVZhMGFjZmhiMWEzZFVhVWZ3YldoWWRTYThmV2VCZVdhWmFZYmJnMmc5YzZnV2dsYlZkdmdXYmtmY2ZkZ0hhVmZWZ1NnZGNHYnRkNmFZaDBoMWJxYkZjaWVWY1NnRWNHYVJoTWhkaG5iWmNTZlFnaGJWYzRhZGdoZ0lhV2JNZ2tnTmNaY1lobmVKZndoY2FFYWhlRGdTZ1ZncGQxZ2ViQWdVZmllTmFpaFZhWGJSZEFkMGNFaGFiRWFWZ3ZiYmR4YUViVGJiZDBoZGJ6ZUVlMGNkYW9oRmRVY2hnUWVSZnhkQmQ1Z2NkbGQ0Z2RhSmhIYUpiTWRkYTBjRmhmY0FoM2FwZXljSGd4YVJjbWJIZERiVmhtYWZhSGdCZ0VnWmZsZ05ldGNIZVJoMWNWZ1VibmhSZnJlZWNtYU5jTmNhY2tmc2VQY1VhaGRCYStnVGJEaGhjMmNUZ0VnSWdEZmJmV2hNYUJnWGNoYWhiRmJYaDBlaGF5Y2NnSGVCZ0lhUWYwYmxmYWVkY1hnaGZMY2RlM2dwZ3BkVmcxZWtiUWVFY1dnQmhGZ1JmV2VJaE1oRWUzZmxmU2RaYWdlQmNSYllnUmRsaGllVWJFY2NiUWNaZG5oSmZXZ0ZkV2JwZnloVWVYY2RhWGFTZ2hhWmNwY1lkVmZNZ1dlTmJrY0VjMWFMZW1jbGU0ZFhmU2RGZ2FiV2dRaE1jRGRWZVVmTmdrZVllbmVwYmxoVGdYZHRiYmVIZ1VhRWhaZ1pnQmRCYTJjWWIwYWRjUWhEY0djNWIvZkhibWFFaFlnUWQxZGxjaWRjZG5jQmZ3Y1NkRWROYUpjV2JuYVZkNGVTZTNlZGU2Y1lnUmRsZVpmRGdSYWxjOWhIZlZhWmY5Y0FiUmFNZHpmUmEzZHNhQ2hWYTNkb2NHZVNlRmJaZ0hmWGRtZDloN2JYZnhibGZBY2NibGFGYTNkVmYwZW9oV2RhZ1dhRWNXZEdkR2JZY1VlWmNtY1loa2VmaGdkVWg2ZENoUWg4Z1ZlVWcxYXhlZWZYZW1ldGI2aFlnMGQxZnFiU2F3ZDlnU2FFZkdmUmZNZGRhbmhaYlNnU2VsYnBoNGdmZlFmOWZMZVNkMGRwYUNhU2VIY0pid2hjZUVjaGNEYVNnVmVwZzFiZWdFZHNlcWJVZ0dhbGhYYldlUmVBZFpiYWdBZnRjRmdiZHhkRmNCYUtjaGdNZ21mUWVRYmxnb2JZYUVlQWhWYVRkZ2R0Z01lY2RsZFlhVmdhYm5kSmJSZGRlMWFjYlhnUGFHY2xhaGRGYmhjaGVtY0ZjR2FaZG1mSmV5ZlVoYmVMZkFiNGdPYlVjbGVOZlZnSmEzZXdkL2hjZzJmTWJXZVFnRWZzZlBhVWhoZUJoa2dUZ0hoWmQyZVVha2hKaERhT2ZTY1FmU2VHY1JmaGVlZldnVGRaYThjUGFEZFVhR2ZCYkJkMGdTZmJkbGNKZkxnZGgzZ3BkcGJWZDFka2hRZEdoV2FnZ0xnRGRDZGtiUmZHZnplc2FUYmNnd2gxZmFkYWNFYmRhQmdVaEJmVmRWYU1laWZjYUVhV2EyYW9oQmVCaFNnVWhlZ0JoRmJGZm5nSmgwY1JoWGRLZTNiY2R1ZkpmemhNY1RmR2ZpZXNhZmdTZ1ZkeGJOZUJnUmc0ZHRmWWd3YWtjM2hIY3lkTWdGYVNkRmc0YlFmTWhFZlZodGNYZEZlSmhDZEZhWGhoYzJjRWRrY3NmWWJRZTFia2hrZFBiU2RKZndmUWVCZlVnSWRDYkhlVWF4aFNnMmNwZjZkYWIxZ1ZhVmJFZUZheGhvZ0Zka2ZWYi9mQ2JoaE1mOWhSZTJjMGZUY0FhbmRNZVZmUWRYZ3BhSGFFYUdiWmZ5ZFZjaGZWZXFjY2hsZEZmM2RWYjBmcGJmYmFiV2hvZkxlR2FCY1ZoQWZOYUNkOGN2Zk5jMWdzZnBjQ2RBY2hhUWJmZmhiMGJUYUpmZ2dnYjFmSmh3Z2hma2hDYmxiOGhDZVhkRGgxZEVlQmFTZUlmQWdDYjFic2IvaGVnaGZJZ2ZlRmNoY0FhVmZLaHphRWIxZmVkQWgxYlBmU2NWZklid2NlaEVoQmdxYmVlamcwZURlVWJCYmtjUWRjZHllRmVGaGJmeGFFZlRmYmYwZWRhemJFYTBoZGRvZVJhd2gwYUVjRWRrZklmb2hjZmhiOGZPZlFhSGdKYlJhZGgxZ2RkS2FGaG1nbGhoZ1NmemVKY21hRmdHYVpnbWJZYVhnQmFWYmJneGh3ZlNmVWExZDRkQmJHZnpoc2VsZGViaGZCZUZoUGhrZmNnUGNBZUJoeGJraEJnWGQ5ZzJlQ2JXaGdkVmRlZUhiWWFTYVNneGdoZ0RjV2hXY0pieWhKZmplRWFhYlFjd2h4ZWFlYWVIZmhnSmRkZVdmRmREZFZiMWNrZFFoR2hXZ2dhTGVSY1dmOGRSYUVmeWVaZ0hlYmRoY01hcWhLZVVjRWFBaFhlZ2dwZVpoS2VIZ29mQ2ZHYXlnWWMzYUhjemhBZkRhQWhoaHBncGdLaEJlOGhEYlRlQmhSZm1nWmVtZ0Znd2hWY1dhOWRhZ1JneGgxY2JlR2NnZUJkMGRZYnlhd2VpYUhmMmRvY0VnRGMwZzhmUWVOY2xmZGYyYVBkMWFKYmNlRmRUY2RodGNFZmtoQWhUYkRiRmRCZ2llTmQzaEJoN2VWZ1VlTWE2YURjaWhjaHhlQmNUYUJlMGRMY3diVWFXZFhnWGhvYWdnU2hoZmNhTWVYYWxiY2FxY1RhMmZJYUJkVWJHYWdiVGVTZ0FoUWg4Z1hkeGR0ZjdnVGdUZDlkcWFjZWxkRmMzY1ZoMGFvYVdjYWhXZEVkV2NTZmlkTmJBYk1kemRRYXZoY2VCZ0JlMGRjZEVjY2ZkZEhoVmJWaFNjZGNHYnRnNmNQZG1kZGJxYVNhd2Q5YVNjRWhHYlJiTWZkZmpjQWJIZ0RoRmZZYXNmUGExZDBlRmNHZ0NlcGJSYU5mbmI1Z3dmSWFrZVJlRGJBY0ZnTmExZkllMmVGZDNoZWNtZWxkWGNXZFJlQWVaZGFjQWJ0Y0ZiT2hWZUJoQmJiY3diSmN6Z0Rja2dkZHFkRmQxY05jNmFSZXhmQmZtYWNibGJZaFZiYWduY0piUmZkY3hoNWNLaENoMmhrZ01jVmQwYndkdWZHZ2lhc2R2Z0xnM2RnZkJnWWJSZFlnQ2dVYTFkb2VCZEdjbmNoZHJnTWcyZHBlV2RRZEVlc2dQZ1VnaGdCZmtiVGdIYVpmMmNVaGtmSmFUYU5keWRRYVNhUWQwYjRiQ2hDYjJkSWI5ZGNiR2ExYkljRWVWZEpkYWJQZ0hmaGdWaGRjemJWY3loVmQxZElmYmFWZ21oRWhMZ0FhR2I4aGFjRGVtYThjMGFKZTBnRWJPaEphbGJKZ0dnRmNoYlZkZmhLY3hhRWdlZFZoRGhnZVJiSGJqZ01lU2hRY2tjSWVTYkxnbWNzY1JmZmdUYzVnbWJaZG1jRmZ3aFZiV2U5ZWFhUmZ4YjBmZGVCYnhjY2ZnZFBiaWJnZnRjVGRTZTliUWFKZVZkSWRRZVpnRWZ4YjJiZGdsYUpnQ2hTZUZlSmUyZUVja2VzaFlmUWUxZGxiaWRjZWplWWVsZEJiZ2VBZGRlRWZ6Ym9oMmVTYXlnMWJ5aFBhVmR0aFpmUWJoaFZjb2dRZWtoeGF2aFNoamdsZnZoUmgzZE1lVGVSYjJiZ2JWZVNiRmhCZEhjUmZpY2NkZ2VWZGxhQmVxYmJlMWFFaGpmV2VRZFpjVGdKaHllWmhDY1VmSGUwaCtmWmFtaFpoaGRjY0ZmVmN2Z1doa2RjZWRhSGJWZjFoVGFKYm1ic2dtYVBjMGYxZDZnU2J4aEZlU2NRaG1hMWZNZmNiSGJCYlNjU2JrZmRnNGJhZXhlSmJiYUViVWM5aFpkYWNuZU1jNWhjZEJjUWFmZlNiVWhwZzFkWmdrZHNjK2NlZGpmVWhMYVdmVmVrZVpoZGVnZHNjQWRaYmhkRWJWaGFmVWFkZDdmV2hraGRiMWRGZFFnMWRaZVhiRGZwYW1lY2RsaFllVmdhZm5mSmJSYmRoMWNkZ0toVWJDZVlhemhGY2hlQWN3ZFZiVGVSYm1nTGduZEJlSWFiZzFhaGFGZ0VmUmYwaGRlVWZtYmxjcmhLYUhkaGNOY0lkMGdzYlJhVWNsYWhmL2RUZUhmMWI5Z0dia2RzZlZjTmYzYVljWmVWZGhlZ2U3ZVVhVGRZZEplT2hBYjFjQmZXZ0dkTmhhZGRiWGNoZkxkZGEzZ3BlcGdWaDFla2VRYlNjeWIxZmZnRWREZTFnZmRFZnllQmZjYldkUmFOYkhnYWVCYVZkSWVVY0VjY2hRZE9jMWZoZ1dmRmFXY3BheWRVY1hiZGhYZ1NibGZBZDhhTGgxYVZjTWVMaDFhc2FvaFphaGdoZDRiQWJXZU5jYWVGZVJjRWVkZkhkRmV0ZjBkTWhGaEJkamJUYldlcGFMZURlMWVJZ1FhWmhFZXhjMmNNY0JiMGZRZ0ZjWGZBZmdmVWZ4ZmtoWWZCaGxmbGEvZWNoaWVSYitlR2V3ZDhiQWJHaFRoQmd3ZUdkWGZ0ZjZoSWhGZTVnVmVFZkZoWmZvZUZha2dWYnRkRWh4ZDlodmJEYzNnTWNPaFJkM2ZnYU9hU2RCZmhmSGFEZ0diWWEzZ1dlRmFraHZiUGNCZ1lkamRIZTFoRWFXaEliV2hFYmRlQmdXYVljR2NiYzBoeGZoZ2NmRmhWY3ZnV2JrYmNmZGdIYlZkVmNTZGRlR2hzYTFkWWUwZFphM2ZTYjNjd2RHZlFoaWQwY0NiTWdYaGdkVWVFYUZmb2YxYkZoVmZvYkthU2RpYkFkV2FKZGpnZGI0Z05nVGNNY0xkTmVGZXBnK2FlY0ZjbGJpY2JkR2dsYWRmV2VWYVZhaWFJZkFndGZPZGJhd2VCZ3VhWmVsZnhmWmhFYTBiZGRvYkZoVWJoZ1FlUmZ4ZkJibWVjaGdnUmRRZVBnaWdjZERkT2RWYWNnRmhEYlVlTmRoZEZhaGFoZm1nRmNHY1phbWVZYVNhMWIvZGJhMWFwZ0hmSGRSZTFnVmZVZm5mUWF0aExneWIwYU9hUGJnYUpnQWJIZkJnQWRKZ1JmQ2RKZDZoVWVoZEFhWmFlZ0RhOGdiY1NiMGROZ3BlV2NXY0pheWhjZEhlQmdJYVFiMGdsZmFhZGdUaEViTmVkYTNkSWU5Y1ZkMWd3ZlFoQ2hHZWdlS2NXYUhkSWRSYUFoMmU4aGJnTGh4aE5mWGhhaEFidGRJZkJlRWM0ZVFhTWJqaG9mRWZXaGpnMWF5aEhlemRJYUFiU2RtYVFhb2dMZDFjRmJkYUFmMGhZaDBmS2FUZE5mNGhWaHllQWFjY0FoVWQ1YllmQWdWaElmOWRPYUhhb2N0YUFoamQ1Z0xhV2FoZXRjZWRNYUVjNWEvYmJhWGhoZENkRmFYZWhhMmhFYWtjc2NZY1FmMWhsY2lhT2Z6Y1pod2ZRY0JnZGdKZ1VlWGNVZHFnU2UyZmxnNmVJYkZkNWh6ZkVoQmFsYm9jQ2IwaFZndmZFZ1JoTmV2aFJkM2NNaFRmRWZ5Z0JhSGhCZHdlZGFIaFhhaWhNZWxiVmVtZGNkcmNQZ0JlWWV5ZE1maGdoZ0VjSmVqZE1jZWdHaGhkSmhHYlBleWc4Y3ZnTmgxYlVmN2FGZFVoZGFjZlhhaGdZY1hhSmZ6YmhkNmJJZlFiZ2J6ZEJjRWFFYldoRWVDZVloWmJNY0RoQWFYZkVkQmVVZTBoTWIxZHdlTWVUYUFndGdiZ2FmMmJsYWFmY2RFZGhlRGZTY1ZkcGYxZWVoRWFzZHFoVWFHYmxoWGFXYVJoQWJaZ2FkQWJ0ZkZhS2FVaFJkZGhMZUJmTWI2aFhmQWZsaG9hZWZVZUFjRWRTZ3hmQWEwZ2ZmbGhaZmNmWmFuZUliVWZlYjFjY2VGZEdobWZrYXBoSGJ4ZmdiOWdQZG1hWmJtZ1llWGdCYlZnYmIxZHBmSGdIYVJjMGNjZkZjSGFSZ2pkZWV5ZzFnRGhJZ3hiaGN0aEJmMWJZYWllQ2VTZlJhK2JCY2thc2hjaFVjbmFZY1NmU2V4aGhiRGJXYVdjSmR5ZmNkSGNCY0lnUWN4aDBoU2JKZXphY2JjZmRkemZRaHNnQWVGZmxoa2dRZERjaGZPYUlmRGExY0RkWGdEYjFhUGJkZEJjRWhGZFBoVmVNZU9mRmdSY1VmU2FaZWpoTWZFZVVlamQ4YS9hRmREYWtlRGNTZ2xic2I4ZE1ja2VJaFljSmdGY0ZlbWJKYzJkRWJTZUFnQ2FrY2NoQWJraDhkZGFIYkJnd2NuaFBjemVzY3RjRGhpZjlkTWdCaGtia2U2ZFpnRWV4aDJnZGNsZkpjQ2FGYlhiaGgyZUVlZ2RKYWViUWgxY0Vnd2NjZ21kNWJ3YkJoMGFNY1ZlQmFuZlVod2ZTYTJjbGY2Zk9mMWM1ZXpnRWRCZ2xmb2ZDYTBiVmd2YkVnUmJOZHZlUmEzY01mVGZFZHljQmZIZ0Jod2VkZ0hlWGRpYk1jbGNWZ21nY2JyY1BnQmdZZHlhTWVoaGhkRWNKYWpnTWZlaEhlMmJSZkNjSmh5Z29kMGROZlZmZGh2YUdheGVWZ2FhU2FCZGdoWGVPY2pkOWU2Z0tiaGQ1Z3FnQmhGZW9mR2ZFZkNnc2FLY2RkamNRY2RnRmcxZnNlOGdKYVJmVmFDZUFjMmhsZFphWWFuaEpod2djZ0VkaGJEZVNnVmVwYTFjTWFRYzFlM2hjYmlnQmdYY1VmaGJCZWNiYWFCY1ZoRmFPZ3hjOWVmYktmZ2NrYTBhUmN3YzlmaGNGY1Jkd2ZZYkZjVmQ4YXhlY2hoYmhlUWFQYVhkSWZqYU5maGFrY05nVWZ3YXdiemJSZkZmY2EwZUhjR2FRZVBlTGN6ZVFlUWROYjFlb2ZJZlNoRWNsYlZiSGJUZUphcmVLZENoSWNEYkxkUWY0Zk5oV2Z3YnRoT2VUZ0hiWmQyaFVma2JJaFZoZWFIYlplUGRZZlJiaGZEZVdjV2RKY3loY2RIaEJkSWJCYVJnd2ZVYU5naWF3ZUNjT2FEYlJicGZPaEZoRmVFZEZiV2JoZlpkU2RXaDllWWhIZDJjOGJDaGVjaGRNZGNhUWJoZlZnSWhVZkVoY2VRY1pobmFKZldhRmZXYXBmaWVVYVdobGdYZkdkQmJaYnZoWmR4aFljUWNOZUJjUmM3aFphbmFkZ2xhUWVIZHhlUGVSZHhkWWJkZEJkMWVKYi9jYWUyZXRhcWdWYmtjQmNMZURoMWdJYlFkWmZFaHhhMmJkZ2xoSmhDZFVmemFjZ2tnRWZrZk5lT2NBYmdodGZpZVBjWGRCZnRmU2hGaE5mRmFXZ2pmMWI0YlZibmNjZ1hiS2hBYk1iUmdIZ2xhUWJoZFJjVWMwZjdhSGIxZzhicWJDYlRhUmdIZURnMmdnZVloU2NCZmxnTGRFYUhjUmQ3ZFRmUmJVZWljY2drYzloM2VHZkZiRWJXYVlobWFwZFpoRWhVaHdmVWdaY21nWmJoYmNmRmhWZXZoV2JraGNmZGNIY1ZkVWVHZ0RieWNKZjZjYWhFaDBnbGdOaGdhOWNQZE9hbWVSZk1lZGZuaFpnU2dRY2hiVmQ0Z2RmaGNKZUxnR2VFZU5jWmZhY2lhQmF3ZWRja2JoZ0xnV2cwYTlkZ2dlYkZhZGVyZGVibWRGZFBlV2hSZm9oWmhZYkVjNWFGY2NjQmZGaGNhYmUxZDFiemJBZmtmZGZsYkZkUWZkZVpjVGRoYWxhdmVjYWtiZ2hMZGRmSGhKYlphYmExZWRlQWZGZG1hRWdrY0ZjZ2ZkZW1iV2YyYlpmOGdZY1doRmJWZFlmbGdvZUloRmhCYVJoT2VlYUhoUmNyZGVhbWNOZk5lYWdrZXNlUGREZHpncGFrZFRlSGFaYjJlVWZrYklkVmFlYURmQmhIYkJoVmVzZFhkRWNDZTBkOGRjZkJiNWFBZUZjMGVWZWFkSmczaFJnTGNQZm5lWmZwaEVibGdBZ1FiUWRrZkliTGNSY1dnOGdSYkViMmU5Y0hkY2N4Zk5iSGJlYkJhVmVXYlVkQmRVZVFmWWVIZ1JnV2hIZFRiaGd5ZFRlSGhkYkRiV2NBYTloOWhlZEFjQWdQZGRhQWYxZHplWmJtYnBld2FCZDJiOWRSZVJmd2F3YlVjVGZuZWhlMGhhYjNlcGFqaFRmV2NwYkxoRGIxZ0lnUWZJZ2djTWJrZmRobGFvZVVkVmFDY3BoMmdYZFVhc2FGY1FlMGJsYXVkY2ZqaGhkd2FWZ1VlTWRrY0dkeWVFZ3doUmNUY29kemdKZzFjOGNOZ0hkbGNVY3RmUmZRaEloN2NXYlJlTmRpZFJnemFvY2ZhUmUzY3djY2JVZTFmQWFQYkVoSGVoY3loR2NRaDVlcWhlZ1Zlb2c0ZFhobWhBYldmYWdXZEVlV2NHZUdhWWZVZ1plbWNaZ2hoY2ZGZlVoN2FJZVFhNGdkaEZjbGJVZWRiQ2RXaHRibmhZZTBnVWM0YVNleGhGZE1kRGhtYVJiRWNiYm5mWmRZZFFkaGEwZDllZGVnZTFhTGhWZTBkTmJEZVlhbWFGaHdjZmVVY2dhTWNRYkZiTmI4aGVkRWMxYzNkYWdIZHhhQ2hRZ2pob2daYWFmQWd0Y0ZhYmN4YUVhVGFiaHhocGdaYkViMGNkaG9oRmZVZmhmUWRSZHhoQWJnZkpmeGZoZldnUGJqY3NmZWZPYlZhY2V1aEhjamExYnRmRmJrZ3BlcWhGZENmOWFxZFllVGZWY2NoYmN3Z0ZhdGRIaFJkMWVWZlVnbmVSZXJoZWVtYU5nTmJhYWdiSmRKY1VnaGRnZHRjVGVIZjFnMmZGZTBhSWdMY2VoQ2hJZGNjQmUxYTBlTmNIZGpkWWE2ZmVoWGhBZmNmQ2J4ZHNlVmdJYm5kZ2NGYU1iaWExZ3BiSmhSYWhhZWFYYmlnMWN1Z0ZiemYxZGVnUWhXZmRkRmhHZmxoMGFEYUxkVWgxY0lmSGR4Z0pkRWhaZ2pnMGFRYkZmVGNnaHpiSGh6YUFmU2FTYkJnOWJ5Z1NoeGJZYlloWmNoZFJkbWRaZW1mRmV3aFZlV2Q4ZlRjQWdSZjBmVmFSY1ZoSmhxZWFkemNOYnFjVGJUYzRlRGZYaFJoMWNIZFphQWNJZ3pnSWFWZElld2dWaERlWWJ4Z1ZieWg1aEtiRWJSYlljd2ZlYm5kSWJaYkJoZ2RjZE1jQWVuZFVlM2RIYmlhTmE2Z0pjaGhGZ1pjUWdsY2dibWNUY0FkQmR0ZkdhQWRoYkZjUmgzZ01lVGNSZTJlZ2hWZ1NoRmNBaGFjT2NtZ1pieWRWY2hnVmhxYWNlbGVGYTNiRWJSZzloWWZLY2poVmVmZVZjeWJnZlVlTGFXZjRhMWRmYUZkVWQ5Z1Zoa2hkYlVjRWVWZlVlWGZlYUdmc2IxYmFma2cwZnhnWWVRZDlmU2FFYUdkUmZNZGRnbmJaaFNjUWZoZlVkcWhNZjBiWWJlaFNkZ2UxYVpkYWZsZmhjd2hjZkVnaGNEZVNmVmFwYTFoZWZFYXRiM2VlZW1oa2JZZFdkVWd4ZEZmYWVHYTlnTmZPZXhkMGhUZVBlVWN0YXpoV2RrZnRnb2RBYVVjUmRRYVZiQmI1ZXliWWNrZFFmTmNlZEdoRmhGZFlkVWdGYVphRGFuZ3hiemREZmdiQmR3YlVmWGhWZitmYmNYYUJiWWNmZUZkUmVUY0RlUWI5Y05oUWNHY2RiL2diZUhjVmhlZGNobGU0ZWRmU2ZnYWhheWFDZVdiVmN1ZFdlMGc0ZS9oZWZIYllnU2dTZHhnaGhEZFdmV2dKZXllY2JIZ0JkSWdOZkViY2VOY0poemZFaGZlTWNuaElhOWVXZTFobGRDZUZoV2NoZ0NhU2VXZzljVWVIZjJhOWRWYlljQmQ5Y0hoZmJCZXhiRWNlYmtmY2dRY1pibmJKYldoRmJXY3BoeWVVZVhiZGJYZFNnbGg5ZnBnYWZoZFlkTWVUYUJiUmVtYVpnbWdGZXdkVmZXYTloYWZSZXhkMGNVYlRkbmNoZjBhYWczZXBmamVUaFdhcGhMY0Rid2Q4aDZhWmhFZHhhMmNkZGxnSmJDZUZhWGNnY3dhUmN3aFZnYmdGY3hmQWN0ZlBnSGdBZDZkUWNCaGRlRmRXaGlkZGUwZlNoemc1ZjJiYWdSYUpoVmhFZ0ZhWmRoZ0NleGE1YkZkRWNSZE5jdmJSZjNhTWJUZFJjMmNnaFZiU2ZBZUlmQ2dSZERhTWRnY0dhQmhWYmllV2NGZ0ZkM2VWaDBjb2ZXZ2FkV2JFYldnR2ZHZllhVWRaZ2llbGhoZExiQWRsYnZlUGZrZDljSmFFZ1ZoVWVBYmVoR2VzZXpkYmgwYjFneWVSZXdkOWFEZEhnbmFOZFZkWWZXZ0JlTGRVZFFjUmZyZFlkZ2hwZ2RoQ2ZsYkJoSWRkYTJiVWgxYllkMWRoY2JkUmNWY3BlNGJhY1VmVmhnY1lnM2c1ZkJhUWdBZk1iSWNlYnhiOWFkYmVlUWVNYUFjZmdsaEpla2FWZmxoUmc0ZERnVWFGY2NoYmFSZkJobWJjYmxlWWZWZGFibmZKY1JiZGExY2RlS2NGZmhoNWh2Y1FoVWNvYXZiUWVDZk5mdWNOZFhleGVWaFBjVmZaY0hjVmdCZEZjVmdGZzNmaGZyYWJnM2RGaEJiYWFsYU1kR2RYaGpjcGJrYVRiSGVaaDJkVWRraEllVmVlYUhhWWRTZFNleGRnZkthV2NXZ2xkeWhhZ0ZmcGVJaFFmMGFsZWFjZGhYY2hoTGdkYTNicGFwZ1hla2ZJaDZkR2VXaGdoTGJSZ1dmOGVSZEVlMmM4ZmFmV2dSY05lSGFhZ0JlVmdJZ1VhRWNjYVFnSWFDYWNjWWZWZGphNGE3ZEhhamFsZ1hnTGJCYzRiOWVhZUJoWmhEZFRnQmVSZW1iWmNtZEZld2dWYVdkOWNhYVJkeGgxZVVlRWYxYUpkOGRZYTNkSWIzaFRoWGNkZkxiWGZsZ3BkRWdiZFViSWVrY01nd2FJYU9kVmNEYXNnemRHZWhmbGdNZlRlMWdsaGdlY2NIaGxnNWNSZ0VhTWVkZVZoRGJrYzllQmZUZEFjdWJJZFZmZGZGZEViQWN0Z2hoQWNrZlVnOWFWY0VjY2g2ZEZoVGYwZVRkUmVXY29nT2JZYmxoQmhIZ0VjR2ZaYnllVmdoYlZicWJjY2xnRWF4ZEdiQmRnZVdoWWdYZW9kV2hUZEdjaGdZYUloeWVnYW1hSmRCYTFjdmFYYjBiY2RKZUhnVmZSZlBlYWRXZXRkcWZlZkVjMWVqZ1NoMWh0YlNkR2MzY2xiTWdkYUdhdGhRZ1djVGg5YzRnZGdoZUpoTGZHZEVhTmVaZVllbmFKY3dnSWJnYjBoWGRIZkFlZ2E3aGVjQmY5ZHNjVWRHYmxiWGdXZVJjQWFaY2FlQWR0YUZnTWJqYXNlVGViZzBiZGF6ZEVkMGNkZm9jRmNRaDRlRmhDaFZkTWd5Zk9neGZsY2JmYWVpZk5lWmJJYTFhNWZLZlRnVWVOYWhiRmhoY2hjbWdGYUdlWmRtZllkWGFCZlZoUGJSYThoVGNTY0VkOGViYlVoaWdCaGxhTGRqZUVnRWhKYjBhc2RRZlVma2ZSY3FoR2VDYlFkL2VIYTBmb2djZmVkR2R3Y1NkSGV4ZlljUmdIY0RoSWcraE1lVGVNYU5oU2UwZllka2hDaFNodGZBYktjd2ZZYTZhWGNGaDBiVWVGaGliOGNIY1JlV2IwZ1RjR2RuZ1JkdGhjZXhnTmFIZWFiQmFWZUlkVWNFZWRkTmhUY0hjSmNXYUZnV2NwZXlhVWhYZWRhWGNEYkViTWNuaElla2FKZVJlS2NWY3BmbWNIZG1oa2VrYVhhR2I4aEJoYmhSZTBlZGRWYVZjSmMwYmFhM2JwZGpmVGRXYW9hWmZTYmdjWmJGZU5iZ2hKZDJoWmQwY1JnQ2FDYjNnZ2hpZ0VkbGJRZ1loUWVVZWxmZ2FjZm5idGd3aEhoRWIwY2RjRmdRYllhc2FHY1RhNGcwYUxlbGU5ZEllQmVoYUJmb2RFYVVoVWU3ZEhhMGRjZ2dkTmFDYmRnQmVEZGlkWmJTZFFmRWZGZVJoR2NYYTFjWWRWaGhoVmhxY2NibGFGaDNhVmYwZnBkTGVRaDJjRWRXZEdiR2NZYlVkWmdtaFpoaGZOY2dhQWJoY0djUmhOYVVmVWRoaHRoU2NIaEdkTWZ1Y2JhMGUwZzRoUWJnZDhhSmdPZ21lUmRNY2RmbmhaZVNnUWZoZVZhNGVkZmhhSWJaZkdmRmY1YVpkTWNIZUloc2RMYUVoaGNTZ1NlVmhWYzFhYWRGZUJmZGFlZm1nbGJYZ1dmUmVBYlpoYWJBY3RiRmJiaDFnZGJjZFBoVWRkYTdkUmRRZFlkNmNGZlFkRmdjaFJoMWZWZm1lYmgxYlpkQmJaZURmNGdVZU9mUmVBZmVmWGNtZlZkaGFXY1JoaGE3aEZmQ2FnaHpoTGdUYXhiWmNiZnhlSmhIYkFhQmgwZnVnTGEzZmhicmJOZ0doTmFRY2FibGJzZlVmVWZsZFZma2hVZW5mWWg0ZlNmVWdJZmVkY2J6aGdjYmZTZzBhTmVwYVdjV2JKZXliY2VIYkJjSWVRYzBlbGRhZGRlWGRoaExoUGZqZ3hlcGdYaDFhRWFZYlVkR2NnZVdnUmZUYnNlZmRVZ0NoY2RHZUliWGdBZElhTGhGZEFlcGVCZ0VlOWNlZGJhM2N0YWFjRmNTY05oeWRUYjNiZGhDY1hod2NSYXdhZGRCYVllZWJZZEJjUmR6YmNoWGJKaGtkUWdXaDlmRWhSZjFjUWJVYVhoRmVJZHZhUWVYZXBiamNUYVdkcGZMYURoMWdJYlFjWmNFZnhlMmdkYWxmSmhDZFhiRGg1aDJiR2drZ3BnWGRTZGxja2g1YldlSGJCYXdkU2dFZ05oSmdXYW5iVmI0ZFNjM2RkZjZkYWZWZ2RmWmNFaEJna2hoYVRkVWVWYm5jV2JCY05jeGFSZzJoWWNGZlZhSGRrZ01hUWFWYkFhY2RPZW1lWmZ5Y1ZhaGhWZnFoY2ZsaEZmM2RWYjBjb2RXYWFkV2dFY1dmR2dHZlloVWRaZ21iNGJ6Z2NlRmVoZnlkV2FsZ1FiVWVIZFVjdGNTZGViWGVwYjZiWmFVZ3RjcWRBZndnRWFDZFJhVGZjZ0VlZmdtZVJnQmRXZXhibGU0ZFpld2Z0aGFiRmdFYU5mSWRlZm1mdGU1Z2FoMmhKaERnU2JWYXBnMWFlZUVodGQzZWVhbWFsYVhkV2JSZEFjWmVhY0FidGNGZGJheGFGZlFhSWJBZmtkbmZXZ2dia2I5ZFViRmdOZzZjUmV4ZkJlbWJjZWxiWWNWaGFnbmVKZFJnZGQxZGRkS2VGZW1ibGRoZ0Zha2NWYU1oRmdHZlpjbWdZYVhjQmJWY2JmMWJwZUhnSGJSaDFnVmRVZW5iUmNyZGViaWhvZUxlYWRraE5mQmJVZmhjdGVrY1hmWGhaZ3JhVGUxZThmVmZQaFhjOGhTZ0VoRGdKaERhV2dXaEpneWJjZUhiQmZJZFFjMGZsYWFoZGhYZmhoTGFkaDNkcGJwY1ZiMWFrZVlmU2QyZWdiR2VXZEdhOGNDZUdobWc5Y1pjY2Z4ZjVkV2FhYkJkTmZPY1VkQWQ4Y2VmTmNpYmNhRmhYYldjSmNnY1FlbWY1YmJjU2hnYmRhd2djZEJib2hZZmRld2Z4Zy9oYmYzaHBjYWRWYVdjOWVhZlJmeGIwYWRkVmZWY0plMGJhZDNjcGRqYlRlV2dwZUxjRGcxaEliUWRKZ3dkTWI0Y0liaGVzYU1jUWVEZzFkdGJPaEVjc2JZY1FhMWRsYmliY2duZUJod2NTaEVkTmFKZldlbmRWYzRkU2IzYWNobmFRYjFjZGZaY0VnQmVsZm9kQ2cwZVZidmNFZFJlTmN2ZFJlM2hNYlRoUmcyZWhlYWVTZkVhMWJIZ1dkWGQxYVlmVmhoaFZkcWhjZGxkRmczaFZoMGFvYldlYWJXZ0VoV2dHZEdkWWVVZ1pkaWZVYnVnUGNnZ0VibWNGYkJkSmVZYkJmbmY5YVNhZGVHZXRmNmhZYjBhMWZxYlNnd2Y5ZFNoRWNHY1JjTWFkYmlidGY0ZFFjaGVWZzRhZGRoYkpjTGdHaEVmTmhaZVllbmFKaHdoY2FFYWdiS2JEZDFncGU5ZmJmVmYxZWtiYWZIaGxoWGhSY3hlQmNRZVlkUWdzZGVhUmFSYkViVGhiZzBjZGF6YkVnMGFkZ29lRmdVZWhhUWNSZ3hoQmNtaGNibGhZZmRoT2dIYUpjY2NhYmxjZGdaYUhiMmNsYy9jRmZoZFZiM2FGY0djQmNnY1lmVGFoYWJiUGF3YjhjVWZWZVJiVmhIZlFkV2IxZ25lZWRuZEpjVWZlaDBjY2JQY1Fhd2hoaDliUmNYY3BhMmhXY2djMGRWYlplWGFaYWJiUWJnZk5kcGZXY1dnSmd5Z2NkSGdCZElhUWIwYmxkYWRkZFhiaGdMY2RoM2FwaHBhVmZ4Y3BoZmVWYnpieGZDZ0NhemRwYVVoQ2hFZFZoSGNjZHhhTmFIaGFmQmNWZEloVWFFZWNhUWNaZm5jSmhXZ0ZkVGJkY1ljVWhYZWRmWGhTZWhmWmFwZFliUmRZY1lkWmFoaFJnbWhaZ21nRWM1ZFZiWGhKZmFlVGR4Z1VnVmFHYmxnSmU1Y2FhMmg5YzJlWGgzaE5lZGVCZ2xmSWVNZWViRWN4Zm5lWmZsZnRoQ2dTaFhiaGIrZldiMGhzZVZoUWgwZ3hnMGJZZVdoSmJnZVFjVWhwZEpkVWdYZVZndWFYZW1lSmVwaGZmMGN4YnpkRWFCYmxob2NDYzBlVmJ2YUVkUmhOZnZhUmIzY01jVGdHZW1naGZRZUJkQWZNYkNjRWdDYWxleWFVZ0JhTmZxYmVjZ2dOYTNlV2ZsZGNlV2FlZW1lZ2ZXYkJlbWVZZFpoZGUyZlpjbmhkZ2xkVWRuYVZlQmRkZUliVGJoYjFjYWNaZW5haGJqZ2JiMGMxZDdjVWZoZjVmZWVFYkhlVmhVZGJlM2c5YUpnYWNCZFZoNGZkaGhnSmZMY0dmRWdOZ1piWWduZ0pnd2RjY0FmRWVGZVNlVmJKZzliY2hBZ1JoM2JaYTJla2daZkRoRmh4ZVZmWWNRZGRiRmNmYWdoTWFMYWJhMWZsYXplV2FrZjVkaGNGZ1JnTmI2ZVJoeGJCZG1kY2ZsZ1lkVmhhZW5oSmJSZ2RhMWdkZ0tnRmdtZGtob2ZVZEJjaGJ1YUhhRGRSZW1kYmZHZzFkVmFmaGxoTmFIaEFhUmYxY0ZjV2czZFFicGZLZ0NkWWFNY0loVmRBZmxnVWFoZEJia2NUZ0hlWmYyY1Via2JJZVZjZWdIZVlnU2hTZHhhZ2NMYlZiemRJZ25nSWh6ZGhmQWNDZGtjQmVCY1hmM2VoZExhZGUzZHBocGVWYzFja2JRZEdoV2NnZ0xoUmVUZ0llUmFWZmllTWhVYk5naGNNYk9mTGZoYVZlQWhRZWxkY2VFYmZnbmZKZUlnRmVTYk5iN2RVZ1NneGY5Y1NhaGVaZ3BkWWhSY1lnWWZaYmhkUmJtYVplbWdGYndoVmFXaDhmVGNBZVJlMGhWYVhlUWNCYjBlWmZtaGRjamJYaDJkTmNMZkVhMWZJZEFnYmZVZ3diMGVKZUJiY2REYlhibWZOYWNjRWhrY3NiWWVRYzFlbGNpZGNhbmRCZXdkU2VFYk5mSmNXYW5nVWd3YVJhU2JjZHZlT2JoZjliUmRHZ0ZhQmRvYkZnVmR0ZHZhQmR4YnBmdmdHZjNmTWVDZVhibmZvZVpnU2RGYWhiUmhBYzJoWmcwZFZibGh4aGpjY2ZnZDFkM2dSZWxnZ2VPYllhSGNvYzhnR2RHYllkVWVaaG1mWmdoZmNjRmdWaHZoV2NrY2NjZGJRYkZlVWVYY09hRGFnYi9hWWh3Y1Fjc2RTaHdoZGJFZEJhWGZGaGZjWWhIY1pkTWhRY2xneGJ4Y2Rla2hsYWhlR2dFZE5jWmJZY25iSmR3aGNiRWhoYURoU2hWZXBnMWhlZ0Vmc2UrYVBhR2JsaGZoVWRVZ0loWmhaYVJiWmhGZWZiQmFnYVRkY2YwZWRkamFHZmthY2RxYlJhd2EwZ1JoRGhBYnRiTWZjZGxhWWRWY2FlbmRKY1JjZGYxZGRoS2dGY21nbGdoZEZnaGhnZXVlR2hqYllmemJNY2pkaGRkZVpieGVOZ0hjQWN3Z05oVmNRYzJnWmJpYmVjamI5Y05mZWFGZGtoYmZYZWhoQmFzYVJmRGE5ZTJiVGhGZ3dnVmViZG5hOGFTZ1RoUmVoYVZkU2FtZnRkeWRMZkhoQmdaZlVkVmVGZldlZGRYYkJjZGhaY0hkcGh2Z1ZneGZBZFpmR2NUZ1FiTGNWZEhlMGhKYkdobmhSYnRoY2F4Z05mSGRhY0JnVmZJYVVlRWdjZVFnWmFuY0plV2NTZUdlb2EzYUhmU2ZRZlNhU2RrZTFnRGhZZFJhWWhZZlphaGNSZW1hWmNtaEZid2dWZFdjOWVhZVJneGUxaFVlRWUxYkpjOGhhZ25oSmN5ZlhhSGV0ZWZlSGZraE1nQ2haZkZoSmgyYVBlMWJ0aExiRmhTYndlK2hRZEFmUmZQZVFleGVjYW5lSmFYaEFoVmJHaGhnRWNHaENkSGQxYjZlSWFqaGtnc2ZLZEJnc2VRZVZkQmVrYXJjUmdBYkVmcWNFZFVhTWNnY0RkamgxYUhoUmdXaEViT2JZY2xjQmNIYUVkR2FaYnllVmRoaFZlcWRjZmxoRmMzY1ZjMGRvZldhSWNDZGNjV2RFYUdjNWdHZlpnbWd0ZzhnY2VFY0ZibWhXZGxic2hkaERjVmZ4aFNlTmZqYmthL2RJZWdlWmJ4Z1lmUWE5YlNoRWNHYVJhTWNkaG5kWmZTaFFnaGdWYTRiZGRoY0plTGdVZkVjMGJKYk5leWhFaDRoZWJHYUpoRGRTZVZjcGMxZ2VhRWN0aDNkZWdtZ2xiWGhXYlJlQWdaZ2FiQWJ0ZUZnWmMxZ2dkVGRjYlZmbGR6ZkFjbGI5ZGhjRmdSZFJiUWdWYVFnUmgyY2ZobmZ3YlZkYWVuZkplUmVkaDFhZGFLaEZmbWFsZGhoRmdoY2hobWFGZUdoWmJtaGFnWGdnZWNmYmEwZFJhWmFIZFFjeGdIZ1dkM2JSYnRmZWVuZVZjZWVZYzBodGZUZVViZ2FGZTJoVmJIZHBoY2NVaGtiSWdWZmVlSGFZaFNiU2d4ZmhiRGFXaFdjSmR5ZWNhSGJCY0loUWUwY0ZlU2NQZUhkaGdWYmFmWGJwZC9kWGZsZGtoV2hHZlhjNGdZZlRnR2E5Y05mRWczYTVlVmJhY3hiOWR0ZGFkQmJWZElkVWVFZGNnUWhaZW5nSmVXZUZlV2ZwZnliVWRYYWRkWGFTZ2hlNWgvZ2NlaGFZY2VmWmZsZDFldmdaYWpoMWh3ZlJhSGQxaENkYmdSaDBlZGdWZFZmSmUwaGFiM2NwZ2phVGdXYnBlTGhEaDFoSWVRYmJmVmRkYmNlZGZsZ0pkQ2ZGYlhnaGQyZ0Via2dzY1llUWExY2xhaWZMaDFkcGN3ZFNmRWFOZ0pjV2duY1ZmNGFTZTNhZGU2aE5oSGQxaFpmRWZCY2xkb2NDZTBiVmV2YkVlUmdOZnZnRmdUaFpkSGdFY2pocGJiZlNmQmFoYWNjT2dtZVpjeWVWZWhhVmRxZ2NmbGZGYzNjQ2VtZEFmV2hhYVdnRWJXZ0dlR2ZZaFViWmRpZEFiMGNQZWhjWWI3YUVid2ZoY1RmSGNTYk5kYWNJZkdjSmY2Yk9lR2NkaHFhU2N3YzllU2dFZEdhUmZNZ2RhbmdaZFNnQmhGZ29hcWFkYmhmb2VkaFdhUmRGZlpiTWFIaEpidGZjYURkTWIrZ1JmVmZvZzhlZWdGaFpjM2NhZG5hSmZYZUViQmVBYUZhYWdGZjljTGFJZzFiUmNkZ0tlQmNNYTdjQ2ZFYmRiamhIZGdjRmFaaGJnUmhCYW1nY2hsYVlnVmdhYW5jSmZSZGRoMWhkaEthRmRqZXRidmhSYWtnMGMxZFhnR2g1aDBnZGdHaFZoVmVhYlZmb2VUY0VhMWY0ZWRnRWV5YllmSWZOZ1NoY2VJaENmeGI4ZEhkR2V4aGxkdGZWYjFheGYyZ1Voa2NJZ1ZlZWRIZ1loU2FTZXhmaGFEaENjeWJjYm1hSmdTZkljR2dRZ3hodGFCYVhjM2NoY0xkZGczZnBncGRWYjFna2ZRaFJiRWhJYUxnUmVXZzhmUmVFYzJhOWJIYmNmMWNVZFNkSmRsZVlhY2JHZVFmaGdlZ1pjaGdoZWVhUWhXaFpieWJBYzNlNWVYYkViVGV4ZnBiWWRSZlljWWZaYmhnUmdtYlpobWJGY3dkRWJ5Z0FlSWJSZ3hmVmFMY0ZjQWdCZTBhSWduYVpnamZDaEdkWmdMaFFoRmU0Z1FhTGVFaHhhcmZkaGlla2gvYkdiWGJnYjRiRWVsZVlmWWFVYTBjSmhpYlBjSGFCZ3NlU2ZCZmRoSGdGZGphQWMyaERiQ2hNYnlmYWNWaEZjZmNFZkJhaGdnaEFleGVkZ3ZhSGNBZjVmdmVWYlhmb2JUZldiMmVnYkZkUWJVYnRkSGNHZTJnMGY4Y1hjemU5aHFkY2JsZkZhM2RWaDBob2JXYmFoV2FFaFdjR2dHYllhY2NMZTJnWmc4Z2NjQWhGZGhiR2dRZTlnY2NUZnpnWWJkZU1kQ2U0aGJhTmIwZFVja2FRZ2dnWmJlZ09hbWdSZk1mZGVuaFpjU2FRaGhlVmE0Y2RiaGFKYUxlR2RFYU5kWmJhZ2plZGZ3YWJmVWhnYUtjU2hVY1JhcmJlYkZkTmIrZmRha2NOZVhiV2dSYkFoWmVhY0FjdGNGZGJheGZFaFRhYmEwZmRnemJFaDBiOGduZUZoVmVWZlFjRGVoZ0JnamNjZ2thUWVBZmZnSGh0ZmRoWGJWZWRmS2ZGZm1obGdoZUZmaGFoYW1hRmNHZlpnbWZZY1hkQmdWZkpkMWVRZVhkU2JFaDRhZGZXZmpodGNpY2Rla2VsaE5oYWZrYXNoUGVVZWhmQmhrZ1RiSGdaZzJmVWRrY0lhVmNlaERhNGRjYkdkMGIwZ1FjRWJXYm9kM2hlZ1dkdGNpaFFjMGNsYWFjZGRYYWhkTGRkZzNocGFwZlZjd2Z0ZFZmVGRUYTFiWmVDYzJlOWhaZ0NnRWhWZkhjY2R4ZU5nSGZhYkJlVmFJYlVjQmJvZTZmWmVuZkpnV2FGZldncGR5Y1VoWGhjaFJjSGYxZGdmcWdOZVZiOWFYYktjQmRRZWNhYmhqYVZkNWhWZlRlUmJ3ZlJjeGYwYmRmVmNWYUpoMGhhZjNlcGJqYlRlVGhnZk9lV2h3aGRnQ2VLYmtid2ZIYWVkQWFZZk5mZGR5aEVhaWdWaHlmcGRLZkVmUmdnZzdlZWZoYlplNGdIZ0VlcGJBZ1FlVmc5ZzRlU2czZWRhNmVhaFZkZGdaZEVjRWdSZUNjQ2gwaFZodmZFY1JmTmh2ZlJoM2ROZ1ZoRWVpYVpkV2ZIYUJma2VJY1hjbWdZYlZiWGFrYkZlbWZjYmdhTmU3ZFZnd2VNZWFmYWNTZlFnZmVHZkRnMGYrYVpkbWFaaGhmY2ZGaFZidmhXZGtnY2dkYUhkUmdNYmRjSmZtaHRieWNOYVFmd2g0Z1NjMGJCYlNmRGRXYlJkY2ViZ1hhWWNYYlFiZ2Z0YzRjT2VSZUpnTmZIYmthTmhZaGFjamYxY3doZWgwZmdkS2hTaFVlUmFvZ2VkQmhsZjVlTmJpZXdhWmFIYWtlUmZSYmFoRmdjYVpiYmMxaDRhVGRjZ1ZjcGh6YlJkMGZrZGtiVWdBZFloWGVFYjFkaGd2ZWFhVmZZYWVjWWZUYzFmWWFYY1ZhZGdLZEZobWdsZGhoRmVoZGhnbWdGY0dhWmJtZ1liU2ZJZHVmSWNGaHBmTWVIZ1ZjUWhvaFVnbWFsaHJkTGdoZGdnQ2JGaDFjQWhsY1VoaGRCZWtlVGZIYlphMmZVZmtkSWdWZ2VlQ2dSZVhjSGQwZjBlUmJGZzJhSWg5Y2FoMWhwYklhUWYwYmxnYWJkYlhjaGNMZ2RleWJkZkRoVmcxaGtlUWJHYldkZ2dMZFJmV2E5YlhkUmRpYUVnRWJKYTFhb2dJaEpoaGZVZGpnV2VCY01mWmVaZGlnbGQ4ZEZmV2RwaHljVWFYZmRlWGRTYWhhWmFwYlllVWdSY2RkTWJrZUVoMGRLZEdiRWdrZFZmV2Q1Z0hiV2NoYTFnSmFUYm5kaGIwY2FoM2VwZ2pjVGdXZ3BoTGdEZHdmOGQ2Z1phRWd4ZjJhZGVsZ0pmQ2hGZFhiZ2VnYlVmeGVrZFlnTWRsaGxmL2ZjYWphbGU0Y1hkVWVwYkZiY2hIYlZjNGdTYzNmZGE2ZmFhVmhkZlpkRWVCY2tmZmNDZzFiaGR2ZFdiQmJ0YTVjVGJuYzhmNWZSYjJoZ2ZWZlNlRmhCYkhkRWRHY1pkeWJWYWhnRmZ1ZmNja2F4ZzNmSGhrY0llQmRZYkhjb2U4Y0diR2ZZYlVmWmVtZVpmaGRjZ0ZlVmNuZENoRWFsZC9oU2FCaE1hVWZNYlRkbGc2ZWZma2UwYWtnUWNnYU5iNGJFY0dhUmJNZGRlbmVaaFNnUWhoYVZnNGZkZWhjb2ZaYkZkamJBYVZmTGVTYVVnU2NKYVFkNGRGYURjQWRoYjFoWmFVaHNoSWRjZTJjVmE5ZFdkUmJBaFpoYWRBaHRkRmRiYXhoRWFUaGJjMGQ4YWhhSGhTYjRiR2RaZGpmZ2UxYUphR2dRYVplSGR6Y2RkdGRGaFJlQWVvZ0FjemFJYjViRmZuZFJlaGRBY3doaGN2ZkdlRWR4Z21mWWRYaEJhVmZiZzFocGhIYUhnUmIxYlZjV2hqZnBnbGFEY2hnb2U5ZERneWc5ZXdmTWYyYklnV2VMYVFkOGJKZklnVGhkYWxkQ2FCYWxoZ2ZQYXhmaGJlY2NoMmdKZnlkY2dIZ0JoSWhRZjBibGVhYmRkWGhoYkxlZGZ5ZndjbWZIZ2hjMGdRZ0NhV2ZnZ0tlV2VIYkliUmJSZjJiRWR6YkNkbWFNYmllRGVHZ29ncGdJY2pnVmF4Ykhnd2cwYWxmWWVCYW9iQ2NQaGdmVWFqZ1NlZ2JsaHBnTmJSZWhkc2hIaDJkUWdEYkFmaGQ0ZFJjSmR4aDBhN2ZQZW1kSmh1YklmQ2hJZUVlQmZBYWdmWGdUZ1hnQmhMYVNmbGFvZ1poYmJVZUJiY2FkYWxnSmNDZUZlWGZoaDJjRWFrYnNkWWhRZDFnRWF3aGZoRGhzaGRnQ2VSZHNhbGZIYXpnc2EvZUhjemY5aDZiZGNGZWNhV2NHaEJkQmRoZUJnMmU5aHZoRWRSZE5ldmdSYzNmTWhUZ1JlMmFnZ1ZlUWdCYTViSmNRaENla2Y5ZkdlbWFZYmpoS2RCZ1JkM2RTY2tjb2NPZGViSGVnZEVoRWhXaG9oK2JaY21nWmRoZGNkRmNWZHZoV2FrZ2NoZGRIYVZjMGhjY2VmaGZRYzdmTmFnZW9lbmVEYWtkRWZHYkVlSGZsY01oTWNDZk1hY2FBaFViRWR4Zk9iVmR4YkxmRWRCZWRiUWNZZWlmbGFhZWNiRWRoZ0RiU2hWaHBmMWJlZkVkdGczZGVnbWVsYlhhQ2UxZFZiTmRQZ1Zja2RMYmJieGNsZkhjWWNUYWdmTWFRZXhkVWJuY1FoUWhjY3ZjT2dCYUJiN2JjZWhnZ2ViZ09jaWJBaGVlSWV4Z2diZWNUaHpha2JrZEhheGJSZm1iUWFIZDFhTWJZZlhjQmZWZGJiMWdwYUhlSGhSZTFjVmRVY2ljbGVpaGRma2JsaE5jYWJrZ3NnUGJVaGhnQmdrYlRkSGNaaDJiV2ZnYXdlYmRQYmljUmVkZkJhaGNoZGVnV2hTZlFjbmVQYWpoTWRjZkNkZ2VZY1VoZGZYZUFhZmhlYjNob2E3Y1djMWJsZVpnRWRHZ2hkUWdiZTJjOGZSY0VlMmU5YUhhY2R4Y05kSGFhYUJlVmdJYVVnQmdWZVZjTWJpYmNkRWJXZDJkb2hoZVdoVGFrZUNoQmVsZ3BjbGFZYVVmSWFVZ1pna2daZnFnWmJpZ2hjNWdUZ2tmVmNhZVJjeGcwZ2RnVmZWY0piMGNhZzNhcGJqZ0VlR2VOY0hnSmNWY0lhUWVaZEVjeGgyZWRibGFKZ0NoRmNYYmdjNGhIZERhOWhoYU1iemd3ZkdiRGNSZkVjQ2NPZWloSWZ3ZkpoUWRZaE5mT2V3ZmNnVmhHZHlhTmNaZ0ZnaGc5YUNkQ2UwY1ZmdmhFYVJnTmN2ZlJhM2dNaFRkUmMyZWdhVmdRZ0ZmZ2hKYkhjamhZZWdhR2hVZkVnbGZKZ2dnZ2RuZUVoa2dSZHBnRmFqZEZiRWdWaHpjSmRiaEdiUmVsZGhlYmJWZFVhYWJFZHdobGVKZEJiVGdRZ0FjSmRpYm9jamdiaFJhMGM0Y0JjRmVzZmRhUmdEZTBkY2VNZTNoOWVlaGFjQmZWaDRnZGJoYUpiTGhHZUVnTmZaZFlhbmFKZXdlY2dFZEFoTmZSYnlnVWJLZEtjQmJrZzRhTGhpY1lob2dKZWhkQWhFZ2FmSGc0YU1hSWRVZVVkTGREZWhnVWJoZVVhaGU1Z2hlR2VXY0pmUWFSY3hiQmdtZWNmbGJZYVZjYWZuYUpiUmVkZzFjZGNJZ1FieWdjYWxnVWMxZDRodmhXY2llTWhpZVlkM2ZCYVVkY2VsZ29kVGJSY0VjMGRRY0hoVGRKYXJmQ2FUZW9kQWJLaEFmUmREY1VjaGVaaGliWmhuY1pnMmVVZmthSWFWYmVoSGFZaFNnU2J4ZmhmRGNXZldhSmd5ZkFjeWNrYUZoQWJRZ1lhV2VlZHlnc2FiZE1namZrYmdkRWRnZ29mUWdIZjJlNGJoZ1JnV2g4Y1JjRWIyYTlhSGFjaHhjTmRIYmFlQmRWZUloVWVFZmRnZWVIY1FmRWRQY1diQ2ZnaDllSGdYY2thRWJHYWxhTWJxZEtoRmhOZkxoR2d4aFJnN2JlYzNmeGV3ZUdkMmE5aGNkUWFUaGNlZGRWaFZjSmYwYmFjM2hwYWplVGZXY3BmTGhEZDFoSWVRYlphQ2ZNZjBjUGVCZWNlQmRRYlhlWWN5YVZld2cxZVJiRGVSZHdhU2RJZkRoOGdnZURiUmNFZWRlQWMzZTBjMmdSYTNnY2NKY01iQmdvZWJlWGcxZVZkbWdXZEJhVWVxZlVmbGVvY3FnRmVIZThiVGhIYUVlSWZWYlNmRmZCZkhnRWRHY1pheWdWY2hmVmdxZGNibGdGYTNoVmMwaG9jV2dQZnllQmZhYlRiU2JNaE9kWmhpY2dnMGNQZUJnbGNqaGNlRWdjZmRjSGRWYVZlU2hkZkdidGY2aFlhMGIxY3FmU2V3YjlhU2hFZEdlUWhQaE9hVGhnYVVjQ2gxY0lldGRKZkZoTWJKY1ZnQWdaYURlWWduaE5oZ2RmY0dhSmJEY1NmVmNwaDFnZWVFZ3RhM2NlZ21jbGJYZldmUmhBZ1pkYWdGaFplTWdaY2hlMGc1YmJnMGFkaHpoRWIwYWRjb2RGZVViaGZRYVJheGZnZ29oZmZCZmRoWmdKZWplMGVTZGRnMGdwYktmVWNEZXdodmVWZFVkd2R2ZldkeWJoaG1mYWhTZVJoWmdiYXdhaGRMZ0hkVmJSZGNoVWNpZDlnQmFlYm1kTmhOYWFka2RzZ1BmVWVoYUJoa2JUY0hiWmEyY0FkQWJkZUJmTGdTY1JlY2JTZTBnMWdMZUZhemhjZStkUGZIZnhkSWZGZDBlVmJhZEpkM2ZSZUxmUGduZk5neWJmZlZla2dRaEdkV2hnZUxhUmFXaDhkUmhFZTJiOGdhY2VjaGU5ZHRjYWVCaFZnSWFVYUVkY2JRYVphbmdKYldlRmhXYUlkOGRYZHplWWZiZUJobGhrZHFoRmNGYmhjTGZKZDFjSWhqZlpmbmN4ZXdhRWF6aG9mVWdCZEVkbGNVZkdjaGF4aDBnWWZ5ZjVlcWVUaFRlRmNoZURnMWhJZlFmWmRFYXhmMmVkaGxnSmdDY0ZjWGdoZTJlUWdBaDVhTWZGZ2dnc2JzZ2NjamRaZTRjQmdoZVlmRmFGYm5nbGQ0aEhjM2g1ZmhlUWYxYWRhWmVFZkJobGFvYkNhMGVWY3ZoRWdSZU1keWZUY25jOGY1ZFJkMmRnYVZhU2VGYUJmSGNFY0diWmN5YVZoaGQwZmtjZmZCZEFlN2ZHZHdlVmFWZEhkQ2M5aEZlV2FTZUJkUmdGY1Nmb2F1YUpjMWdWYXljV2dnZEZkSWFVZnhkWWNHZVBmU2VRZDBlWWEwaFVoK2hRZWdlOGJKZU9lbWVSZk1hZGhuZlphU2hRZGhoVmc0YWRhaGVKYkxjR2JCZ0VoY2NOYWloY2JpZ1Bka2NnZEZoUWJSZFFkZ2JOY0FnZGI3ZWVlamExZ2ViUWZqZm9nWmZhZUFhdGJGYmJmeGhFZlRhYmQwYmRiemZUZWtkNWFraFBmMGZoZFFoUmZ4ZUJnbWJjY2xnWWJWZGFibmhKaFpjT2VWZmtoRGNSZ1Fjc2EwZFVoRmg0Z2pkUmNtY1pnN2dZZlRmWWFBZkljUmVrZlRnVmVGZElnYmFVZm5ld2MvYWNhMmRNY1dnUWJFYXNlUGFVZmhlQmJrYVRhSGJaZzJlVWZrY0lnVmNlYkNmUmdYaEhkMGQwZVJhRmgyZUpnemRlaERnNGdkZURid2dWaGFiYWFHZVZiTGRJaDNkb2ExaENoMWVrYVJlVGFXZVpmMGREZkRleGF6ZFJjaWJrZEJmTmJraEZjT2ZjYnpkOWNJZVVkRWRjYlFoWmZuYkplV2dGZVdncGF5YURlSGM1Z2JoWWVCaFpkcGRZYlJiWWhZaFphaGRSaG1jWmdtY0ZhNGFHZzJiRWJaaENhRmVCZU5jRmZBZkFkeGNhZDJkZGdqY0NjemE4Z0ZlVGhBY1phWmNLZndlSmIyY2ZkZ2NaZE9mRmZTaHBjL2hFZmhjQWJ5ZVFkMWdsZGlkY2duY0Jld2VTYUVjTmZKZFdnbmNWYjRmQWdqYkZjNmNZYlZoWWJYY0hobGRBZDdlYWJSZkFhcGJWYzFoWWQ5ZVRleWNjZWFjUmR6ZFJkSmJTaEZlRWVKZUhnaWg4YWhkTmVFaEFic2ZOZkJlUWNsYlhjeGdnZGZmWWRFZXNkV2RHYUdmWWFVYlpnbWdaZ2hhY2NGZ1ZldmNXZGthY2dkZ0hoUWVFYmFjSmNpaFFhdGFZYndhTWJ2Z0hiQWE4aG1oU2hUY1FhSmNFaHliUWVBZkRoVWZkaHdiZGVIY01mWmVYY3hkWWNVZ0pmemF3YWtlSWMwaGdiT2hIZEFja2RoZWVkQWFrY3lkZWJnZHNiQ2dIaDFhWmFjYk9ibGVoYkhkWmNnYm9kNWhiZjBkZGh6ZEVnMGFkZm9hRmNVYmhmUWFSYnhoQmRtZU9leGRBaFZjWWdpYlphUmVhZWtjcGRYYkZjamJ0Zm9hRmhrY29jamFRYURkTWIwaExkM2ZCY0ZlZGNIZ0JnSGVIYlJjMWVWZFVlbmRSY3JoZWVtZE5kTmFhZWtkdGhKY0hiVWJKZWtoUmJGZXhlMmVVZGtoSWNWaGVlSGVZYlNmU2F4YWhjRGRXYVdoSmZ5ZGNlQ2RZYUpjRWVVZ2tjVGFkYldmVmVMZ0ljM2RRYmxhRWVoYWRjWGVUYVNjQWNIZFJnU2VvZFJoRGFtYjhoVmZmZVZkOGVDZEpobGhJZWNkR2JFZnNiUWdLZlhiSmdMYkZjWGJwYStiVWNUZDlmWGFWZXhjWWZFZkljRWhKYVFhYWdGY2tndmdLY0dia2Q1aFdhV2c4Z2ZmVGhnaFllM2dWY1ZiSmQwZ2FmM2ZwZWpjVGRXZHBoTGdEZDFhSWVRZVpmRWZ3ZStoZGhrZ3hlQ2hXZm1nTmJjY0Vna2hzZ1loUWYxYmxiaWRjZ25iQmd3ZlNoRWJOY0pkV2ZuYVZnemdRY0RnaGZRY2FkVmhkYVplRWdCYWxkb2ZDaDBjVmN2Y0VhUmJOY3ZmVGVsY2tjVGNSZTJmZ2ZWZFNlRmZCZkhmRWdHYVpneWZWZWhjVmNxYmNhaGdnZXhkVmUwYUpjQ2dFYmloNWZyZUdoR2ZjaEpnZWIyY1lhemJDZ3hib2hTZFVnMGFkaEdnTmQxYlZjU2ZkYUdmdGI2ZllhMGcxZnFhU2h3aDllU2NFY0dlUmZNYWRkbmdaZGFkQ2d4YlZhbGhkZ2tiWWN3Z1ZiemU1YlFoYmhuZUphNGJOY1ViaGhlY1NnUWhnZ09nTmd6aFphK2VZZFVlTmRYZ1doUmZBZ1pkYWJBYnRlRmdiYnhiRWFUZWJkMGhkaHpjRWgwYmRlb2dWZ3hlb2FWZ0JobGN0ZDloV2FGZlliVmFhaG5lSmhSZGRnMWdkaEtlRmRtYWxnaGhGY2hnaGNtY1NlVWN4ZG1mWWhYZUJoVmFiZTFjcGFIYkhkUmcxYlZmVWNuZFFnNWFQYnpjY2JZZE9jQWhVZVBoRmN4aEJnNmFUZ0RhOWUyZ1RoVWFJaFloYWRYZllhSWZTZDFmRmJEZlJjMmdJZzNhY2hHYTlkSWNVZGtibGhBYWRkV2doYVFlWGhYaHBkcGJWZDFna2NRZkdnV2VnaExoUmdXZjloTWFHZm1iTmJ0YWNjeGdOaEhjYWVCZVZnSWFVZUViY2hRY1pobmhvY1liR2J5Yk1jaGJOZ0Ria2JVYUJjVmVJZmdnTGYxaEVoWWRlZHhlUWNnYU1jeWY4ZnplQWRTaFlkVmZDaFJjMGhWZUFnVmN0YTBnTWNGZUJjamhUaFdjcGVMZ0RhMWdJZVFmWmFFZXhnMmVkaGxiSWdSZVFjamVFY2ljVWJRZk1mWWRTZ3lib2EyY0llRGZrYytkRGQwaHNhZGVVYzNhc2RzZEJkQmFzZzFkUGRoaEloTGZjZTFjZ2M3ZVRia2ExZG1jR2hCYU1lMGFiYVhiTWZUYVJoMmJnZ1ZkU2VGYUJnSGhFZ0dlWmZ5Z1ZmaGdWZ3FhTWNSZ0Fja2hFZGtkb2dVY0lhU2FSY09lR2RuZHdlK2FaZW1iWmFoaGNoRmdWZnZoV2NrZWNhZGJIYVZmVmZTZWRnR2NzYzVoSWhoZjRodmRTZ3diMGhIZVJnQ2NKaFVjZGFHYnhlNGFRZWhmVmQ0ZmRjaGRKaExkR2NFYU5oWmRZaG5lSmh3YWNiRWhnY0FhQ2VBY2thd2JlaEVoa2NpYkxmaWg5YWFkUWVSaEliRGNRZGdndGRGZmJheGhFZVRjYmYwaGRhemhFZjBiZGZvYUZhVWdoaFFjQmdGYkVoMWdOZzFmWWdYYUtoeWZFZVNjUGdoaDVmSWNEZUVlTmFoZkZkaGFoZm1hRmVHY1phbWVZY1hlQmZWY2JmMWFwaEhmSGVWZjRmVWJBZlRkRmhyaGVmQ2Q4Yk1lUGJnY0poQmRRZnhiSmcrZ1pjbmJaYzJjVWJrZUlmVmNlZUhhWWZTZVNieGhoZ0RnV2VXYkpleWZNZXpjRWRiYkJha2RsaFlnTmd6ZkVhRmNOaGlhZ2V3Z1ZhVWJNZzZjR2ZXZWdkTGZSZVdnOGdSZUVhMmM5aEhlY2F4aE5mSGhhZ0JhVWhMYkViUmRSZlZjWmNuZkFhVWVWYURka2UzY1JmMmZOYlZoVWJEZnhkcGdZYlJjWWFZYVphaGJSZm1oWmhtaEZkd2VWZFdmOWRhY1JlMWI1YmNlQmVoYmRnMGdhYVNlOGFnZ0hjbmVoZEplRmhYZWdmUWhaZUVkeGcyY2RkbGdKYkNoRmVYY2hhMmdFYWtoc2NZaFFneGZvZmpmSWhUZ1Zkd2ZTZGhmWWZLZkNlWGJoZXFkU2dXZjFnUWdhYlZmZGJaY0VoQmFsaG9hQ2IwYlZodmJFYlJiTmh2ZFJnM2ROZ1FlQmVqYXRjUWFTZkZmSWVTYlJiQ2dCZWpoUWhGZ2tjdmZjaEVidGZkZVZnMGZvZFdnYWdXYkVnV2FHYkdoWWZVZlpjbWhaYWhlY2hGZ1Vjc2NHZnhnUmVZZkhlVmVjYkhjSWZDYTFkM2VjY2xhc2FtaERiZ2YxZUlmT2RtZVJnTWZkZG5oWmhTY1FiaGRWZzRlZGFoY0phTGhHZEVkTmRaY1lobmdJYWloTmhSYndjV2dHZHhlUmYxaGVmVmV0aHNlVWRHZmxoWGJXZFJiQWhaZGFiQWN0ZUZlYmN4ZUVoVGRiYTBiZGd6ZFZid2dJYXVlVmRCYTBoY2ZFZ3docGhNYmNibGZZZlZkYWFuaEpmUmdkZDFkZGRLaEZobWdsZ2hoRmVoZmhibWFGZURjUWRqZE5lU2VVY0hiSWZWZ3BoR2VEaEFjWmQvZFVibmdSZXJjZWZtZU5jTmdhYWtlc2VQZlVkaGdCZmthRWVWZXhnMmdVYmtlSWFWZGVkSGNZYVNjU2R4YWhnRGRCYkdkdGgrYldibmRCYUliUWEwYWxjYWNkZVhiaGVMaGRkM2JwZmhnR2hWYmRjVGZWZWlmWmdJZ0JnRGdzYVJkRGZtZThjQmZKaGxkMGZFZFBmRmZ3YkhoSGFrYmNkWWhNYm5oNWNXaFJnMmhOZXlhQ2dsZDFiWGFTYmhlWmNwZFlnUmdZaFlkWmdoZFJibWNaYm1jRWE1YkVkMmU5YVNmUmFoZ2tjWmdYYlFlWmM5ZVljbGZCZ2pkVGRXZXBmTGZEaDFmSWRRZ1pjRWN4ZDJnZGdsaEpjQ2hGYVNjd2YrZVFoQWFSZ1BnUWd4Z2NibmNKZFhiQWVFZEVnUmRNZk1kUGF5aGNkcWhCaENnVmJ5Z1FjMWFkZVpoRWNCZmxnb2hDZTBkVmd2ZEVoUmJOY3ZoUmYzY01mVGRSYjJoZ2dTYlNnaGJ3aE9lUWV6Zkphd2JWYmxjUWM0Yk5kUWJRYjZmRWNnZFJoQ2NhY1NkeGFEZ1NnemVJYVVlSmhDY05maGNNYVJodGh2YU9oeGFWZ1BnWGFBYXhlU2dPZ3lhMWg2YUFiUmhnYnNjRGdVY29hQWdRZTJnTmJtZmRmbmJaZ1NjUWVoZ1ZnNGFkYWhnSmNMZ0dkRWZOY1plWWVuY0piNWZhZjJhSmFEYlNlVmRwaDFnZWZFZXRjM2NlZm1lbGZYYldiUmdCZ1FlTGFnZXRjTmZmY3hiRWJPZGNkbGFwaHphUmYwYmtia2dVY0FkWWZYZkVhMWNoZXZkY2FnZFJhUWRQZWlkY2REZ09lVmFjZEVjR2FDaGdkdGZXY2xiY2NsY0hjSGNaaHZiZWhsZHBnVmdiYjFmcGFIYUhmUmExY1ZmVWduZ1JncmVlZG1nTWNiY0tneGdraFBnR2R3ZHRnT2FUZEhiWmIyY1Via2dJaFZlZWdIY1loU2hTYnhhaGNEYkVmQ2dSaHlmZWhDYlliSGNDZWdkMWVhZ1phWGZoZVdkYWRtZmRmcGVCYVZkQWY2ZUdhV2hnZExhUmJXaDhiUmVFaDJjOWJIZmNmeGNOZkhoYWVCZVVhT2dIaHhoVWJRZ2JkaWNCZFdmQ2NHZ3BiaWNYZ1hkY2FlY1NlZ2N0ZHBiY2hRZDBiWWRMaHhjUmI2YlpoamJWZytmR2ZTaG9mVWVBYkVkbGNWYVRibGJKZC9oWWVEZ05ncWZUYVRkaGFMZ0JmRWc4ZFFoTWJEY2NoL2JDZzFhd2ZPY1VmRGZZZnhmUmZnYU1nRGJhZFZnbGFpZGNibmNCYXdkU2dFYk5iSmVXY25hVmY0aFNjeWdFYTdnT2MxaGNiY2hFZkFlUmhvZFJiVWFzaHVlWGVWZThlZ2VCZkFhWmRkZUZkQ2NsY1RiRGZWaGdkVmZHYVdmcGJZZlZhaGhWY3FkY2JsZ0ZoM2JWZjBlb2hXYWFnV2dFYldmR2JHZVpjYmhaZm5odGRoZ1llRWY1YUZhV2NrZGNiZGZIYlZoVmVTYWRjR2J0YTZkWWcwaDFocWREZ1VmQWZBaEVlR2F3aEZhZGNtZnRhU2FVZmdiNWY0Z1BmeGFKZ1hoR2dCYmRiWGFMYmphY2IrY05leGF3ZkxnVWJsYXBhK2JjZ3diSmQrZmVjamNKZzllV2RSZEFmWmJhZEFjdGFGZGJleGFFY1RjYmcwZmRjemRFYjBnY2grZFZlQmhwYlFlRGJ4YUJiN2djYWdlSmd1Y0ljd2E5ZEtiWGNWaGRmS2ZGYm1ibGRoY0ZmaGFoZW1oRmJHZFphbWJZZ1hnQmRWYkpkaGh4YkhmRmhSZXdoYmZYZERiMGU0aEdhRGRZYUxlTGJBZzVhZGRXYmxnaGh0Z1JnVmV4ZjJmVWVrY0lkVmdlZkhiWWJTYlNheGFoaERnV2VXaEpleWdjYkhlQmRJYkZod2NFZ0lmT2VpZTlmTGhPYVRkOGErZFZheWExZkpkU2dTYjFndWJGaHpjMWdlaFFoV2NkZnRoY2F4Y05nSGVhZUJoVmFJZVVoRWhjaFFkWmduYUplV2hGYldlcGV5Y1VmWGdkYlhnVGJSaFFkbGdLZUVlVmFNZlphQmFRYW5mTmVDY1lnbGdHZkNkb2JVZkVjeGcxaFFmQWRBY0VnZ2JhaHpnZ2ZtaFRiU2JzaEZoRGJ6ZE5hQ2NOaGdnMGR2YWRlaGIwZ0VhRmVSZm9mamNWZ0FlMWZkZkVlUWNwYWxkV2NIZEJnd2NTYUVhTmVKaFdjbmZWZDRlU2YzaGRhNmJhYVZjZGNaZUViQmhsY2hhRWhHZzlldmZFYlJiTmV2aFJiM2VNZFRhUmEyY2dnVmRTYUZoQmFIZEVmQ2I1ZThnRmVWZ29mNmdLZjFia2J5ZVdhMGRwYVpiWWRHZDBlV2VFY0Noa2ZVYmJiWGd0Z2hjT2JGZXNmamJIYXdobGFhY1NmUmgxZWJiYmgwYkZoNmJZZzBnMWJxZlNhd2g5YVNmRWFHZ1JkTWdkZm5hWWNQYmFhQmVWYTRkZGJoY0plTGhHaEViTmZaZVlkbmFKYndoY2dCY29lR2ZIYlFjOGhuY05ia2ZzZ3llWWNVaE5nWGFXZlJmQWdaZWFmQWh0Z0ZmYmR4ZkViVGFNY2tiNWcvZk9lVWVkY29mRmZVZ2hiUWZSYXhoQmdtZWNlbGZZZmRkSmhIZ3diVGRMZGdiTWhQYmVlaWN3ZnZiVWdVZ3dmdWdGaEhmdGVtZkpnWGhsZlpiUmRWY3BoSGJIYVJlMWhWZVVmbmRSaHJoZWdtZ05jRmJKZkVlVmZmZ0FmRmg4ZndkQWF5YklndmFBaGdoY2ViaEJjemM5Z0JoS2NVYzBjRmZIZ3loY2dnZmNhR2ExYkliUWNsZWxlVGRlZlZiSmVMZmRkM2VwY3BhVmExYWtmUWZHY1dmZ2JMY1RkU2FFZmZoUWN6aDBkSWJKZDFod2VUYk1nVWVVYU5lWGdoYlJiSGFKZ3ljSmJIYkFhMmFwZHZmVWFUZEViQ2FCZ0ZlVWE5ZUtnRmdsYVdlWmVoZHhodmZaaGpncGVhYlZlV2g5Z2FjUmd4ZDBhZGhWaFZhSmcwZ2FoM2hwYmpkR2V5ZXNlWmFEZHdkWWJRY2VkVWd3ZmliUGJoYnNiUmhHYXpjUWF6YVhoQWJ4Z01mQ2EwZUpiSWNjYW5iQmN3aFNmRWdOZ0plV2VuYVZoNGJTZzNjZGc2Y0ljQmFGaFpmR2JFZjFnb2REZ2tnVmY5YkVoUmdKaHljV2VuY01nRGZUZWtiSWZWZVNkRmhCZUhkRWNHZ1pmeWRWYWhiVmVxaGNjbGhGZDNkVmd4aDVmZWZPaHlnNWhCZUdlQ2FoZ1JjTWVXZllhVGVNY1Jlc2VvZUhkeWVKY1BoVGh4Z29kQWhmaEdia2RZYk5kZ2JzZHNjRGNsZTFiU2NRYnloMGdXZU1iM2VZY2ZoRmIwaFlmc2dkZmxnQWZPZEdnQWRKZlpoTGd5ZWNhOGVKZkFiRWZUYkJmUmQ5ZDFnTmN3ZjFkM2ZhaDNoOWZhZ0dmMWRsZ05oT2V3ZmxjTWJkYURhc2dUZGJjMGRkZnpkRWUwYWRob2dGaFVoaGNRYlJleGhBZWdmUGdRaFFkVmZZZGlnUWhRYUphVmJjaFlkRmNuYVJoaGRCZ2dnTmhtZlFjR2FaYjRoWWhTZkpiT2diZXdmaGJIY0ZmZ2FCY1ZiUWVIZTFocmhMZldlc2NaYUliZ2VKZWNoWGFoY0FoMmRRYUhiWWhrY1Voa2RrZVZiYWFYZzhoSmJZYlJnaGREZVdlV2RKZnlnY2hIYUJoSWdRZTBlbGJhYmRiU2ZvZE9nSWN5YThoN2dHZFZmbGJFaFVhU2ZGZlloWGJrYVVoUmJFYjJnOWNIaGNleGhOZ0hjYWFCYVZhSWNEYlVjNGNjZ1RlSGRKZldnRmFXZHBieWNVZFhmZGVYZ1NnaGNaZ2hhTGN4ZmhlSWNOaEZkc2d5YktmVGNVY3BjQmRTZXBlVWNGY0VocGdjZUJlVWdGYW1hYWYyaGRoamRDYnpnOGdGaFRkQWhaYVpjS2Z3ZEphMmRmZmxndGFDYVRhbGVKYzJlRWJrZ3NjWWhRZDFibGJpZWNlbmhCY3diU2RFYk1lZmRHZ3lnZGU0YkhhM2VkZm5iYWFRYU1oUmRXZVVicGFtZ1Jkd2hBYWhmVmFrYWNobmhYZkZoa2JUZVJhMmNnYlZkU2dGYUJiSGJFYUdhWmV5ZlZjaGhVZmpoTmNGaEZnL2VBaDBlb2JUYmFhWGNVZFdnR2ZYaHNlSmRaZ25lWmdvZ1dmbGdWZHZmV2hrYWNkZGVIY1ZlVmZTY2RkR2R0aDZiWWcwZDFicWdIZDBmY2JBZFhnemdOZ01iT2ZEZk1lRmJRY21nY2U1ZE9iRmVVZU9lZmVSY0VjTGVMZlNnQmU0YWNmaWRvZldmRGF4YXdhd2RLZ2tmc2NrYk1jemhNZFNoV2FWZjFnTWFPZjFmOWZGY0xmVmJRZlRjTGhrZ2NhK2NSY2dkc2U4Y1hnQmhnZ2NnQWRoZEFmcGJOZUZjWWZHY2VjSGU4ZFRnUGZnZU1kWmhGZUdoQmU2Y1BhQmVoZ21mRmNHZFpobWRZYlhhQmdWaGJkMWRwYUhlSGdWY3NlYWJBY0hmUmZqY0xiQ2NJZGZkYWdoYWtoUGhUaHhhQmIwZ1ZjM2RZYWloVWhsY3dnVmdLYm1jMGFTZ0diUmNoYUliUmJHZ0pibWZlYVZicGNJZ1FnMGdsYmFnZGJYZGhhTGVkYTNmcGRwZlZkMWNrZ1FnR2hUZDhiRGVFZlNlZGdZZVFoR2VOYUhnSWdSYjlkSGVPaGhnVmdEZVVhRmNRZ1plYWRuaEliQmZIZVRoNGc2Z0dhQ2JSYWJlU2FrZ1JocGhhYmhoWWZKZ2FiaGhRZzBlWmJtZHBjd2JSZzJlWmVCZGJjUmcwYWRhVmJWY0piMGVhZDNkcGRqYlRlV2NwYUxnRGZ3YUJoVmZNZUJna2VraE9jRmNJZVdiWGdUY0VibGJDYVdkRWZZZlFlMWhsZmlnY2RuZkJkd2FTaEVmTmNKY0JnM2Z4YjBmWWRYYWRoNmRhY1ZhZGVaY0VmQmhsY29hQ2IwYlZkbmRYZXhoMGcvYUZjVGF4aEhiQ2hEaHhmTWdHZEJiVmVKZFFmemJFZ3pnQmRnaE5oK2RjZmtoeGQzZkVkUmc5Y1lnS2VqZVZnZmdWYnlhZ2dVZmJjbWE5YWhiS2MzYzlhdmZXaGtmY2FkZEhhVmNWZFNjZGJHaHRiNmdZZzBjMGY4aENjbGIxZFNiUmZHZVJnUmhkZ2liSWNhaENoMGZaYjJnT2NsYWNhRmNYZXhhY2hSZmVoVmFoaHdlY2ZFZWhhRGhTZFZjcGgxZGVoRWN0YjNjZWNtY2tnZWRIYXhmQWVSZFBnQWN0aEFoYmh3ZmtkVGNiZmxmcGZ1YUVjMWhkZ2hkUGgwYWhnUWRSY3hjQmdtZ2NkbGdZY1ZkYWVuY0pmUmdkZzFkZGZLYVFlaWZFYnplV2RVaDlmbWNXaGlmTWN4ZFloUWdJZFVoSWJSZDBkQ2JlZ0ViOGhIYUhiU2RaYWplZWRBYUVhWWRMYUFlMWRLYUFlQmJBZjNlQmVTYndhemRVZGdkOWVBZEtheWNJaFNkQ2JWZzFoRGRHZkdjSWQvYkpmVGF3Z2NhQ2VoZ2tnV2RNYUhjZ2hFZE1kWGFwYS9iUWgxZ1JkU2JVY0RkeGZZZVJlMmRZaEtoT2NXZTllSGRjZXhjTmJIaGFnQmhWY0lhVWdFZmNlUWJaYWphUWZaaFJmMmZwZDZjQmJ6Z1lnRmRTY2tmUmZwYWZiQmdZZElkZmNSY1FheWRaY25jOWR3YUJhM2VSZ2FmRmVSZzBkV2dTYkZkSmJzZ1ljbGNCZmpoVGdXY3BiTGFEYzFjSWNRZ1pmRWF4YTJmZGJsZEpkQ2JGY1NkOWMrYVJjZ2dOYlJnRWhGZVZmaWVJZkhoeGJ3ZUdka2ZOYkNkV2htY0pheGFSYzFoMWU2aGFjVmNkYlphRWRCYWxhb2FDYjBmVmV2ZUVmUmdOZHZhUmMzZE1jVGZFYkdiQmhCYUFkQmZrYlVmSGFHZ1liZ2dWYWhnNWFxYVloMWcxaDNnQmJVYW9oZGZhYVhnY2RmYUZnRWJ3YlVlWmdtYVpjaGJjZ0ZhVmh2YVdha2VjaGRjSGJWZVZkU2NkZ0djdGY2YU5nRWhVYitmQWcwZFloQmJIZ0dnUWNlZ2RkbmIxYVNjVWFCZGxoNGdKZUJmSmFBYkdlRmNaYlFlYmJsY2hld2djaEVlaGREY1NmVmdwYjFjZWVFYnRkM2hlZG1lbGdYYldhUmRBZVplUGZ3Z01jUmhKZzFoaGNBaFljMGRjZmhkRWUwY3hkb2NCYmthUmJRY0ZmUmJCZnRiY2drYUljY2JjZlZjaGJSZGRiMWJkZUtmRmNtYmxnaGhGZmhmaGZtZUZkR2RZaDBjSmdDYlFoQWdQZlJkUmRIZ1NoVmFVYWNjQWNXYTllQmRlaG1iTmNOaGFia2dzZlBmVWFoZUJka2JUZ0NjdGcvZFhobWVnZlZoZWJIYlljU2hTZ3hlaGVEYldhV2JKaHlmZWhEYzVnR2NFYnhic2ZWZ0llVGJjZmZmTGdpaG9hc2VXZ1FnMWhmZmFiamJ4Y1plRGdDYUZlV2dFYjNkSmJIZE5mVWRZaEphS2QwY0VnQmJIYndna2ZRZWJlbmJ0YVdmVGNrYUJjeWFVZFhoZGFYZFNmaGZaZHBjWWFSZVloWWdaaGhhUWR3aEplemNOZ3diQWFXZDlkSGhSY3doMGZkYUNmVmVJZWdjSWd6Y01id2ZRY3lkWWdPY1FjUmhWYkVlTGNGYWRjY2NkYWxmSmdDaEZhWGRoaDJjRWNrYnNoWWhRYjFibGdpYklhRGNVZmthSGJSY0VjSGRXY21iVmE0ZlZmbWJwZm5mYWdRZU5nemhFZkJmbGJvaENiMGJWZHZnRWVSYk5mdmdSaDNnTWNUYlJiMmNnZ0tkU2dGZEpmRmVPZG1oWmJ5Z1ZkaGRWZHFnY2RsYkZlM2ZWZjBnb2JXYWFkV2NFZVdmQWZtZ1lnRWVaZm5ndGM4ZWJjVmJVaHVmQ2NBZ0JlSWRVZUJoQWZjZElhRGFoZTBjTGN3aGdna2REZkZkc2VhY09jbWRSYU1hZGVuYlplU2NRaGhhVmI0Y2RjaGNKYUxmR2dFaE5iWmFmZ1hmSWRBY2VmQmR3ZUxlQWFBZ2xmNWdlYkZhdGI3Y2VnamgxaGViY2V4ZEFjWmFhZEFkdGJGZWJjeGZFY1RkYmcwYmRnemFFZzBmZGdvYURnMGhnZFhnU2hWaEVhMmVJY2hocGZNaFljaWdZaFpmUGZnZ1JlR2NGZGllZ2J6YVVnVWQwZHJoVWhTZmdheWdNaG5ibGRPYVJoVmNwZUhlSGNSZzFoVmdVY25jUmJyZWVhbWRNZFFhWWMwZGNjbGZVZ2hlQmRrZFRjSGdaYTJjVWdrZUlmVmNlYkhnNWdjZlJkVWRnaFJhRmNqY1lnOWZKYkNha2VZZkJoa2NjaGZlSmNDZDBiS2dPZ3libGZwY1NjbGhsZFdkVGhDZFpnSWJFYlNoWmdlZ1hlV2c5YlBkSmN4aHBjSGFNZnpmOWJJaFVhRWJjY1FmWmhuYkpiV2hGZldjcGh5YVVkWGhjZGVjRGNCZVpjaGFZYkZlZ2FXZkxiMGVjZUVhTWV5ZGNnMmVFY0RmMWJTZkVkeGFRZlVlZmExYkplMGVhZjNicGRqZVRoV2NwZkxnRGUxaElhUWVaZUVkeGIyZUljaGVvYlFjV2JpaDlhMmRYaEFmNWNQZ1FieWEwZjdnSWNqYVVjVmdHY2hkRWJHZ0NkSGcxZTZoS2NpYVVhOWdQZUJmb2hjYVhja2UxYW9hUmNoZkFhOGVSZFJiTWJ0Y0FjbmNOZVNoUmV3ZHBiQWhEYWhhWWJDZ1FnbWNSZzdjVGVUZDlhcWFjZ2xnRmEzZVZhMGVvaFdmYWhXaEVlV2ZHYkdnWmZHY0ljemdJZzBhSWhoY3RjdmVEaGdlOWRVaFRobGFWY1BnYWhYZ1pjNmZOYTBjMWIxYlNld2g1aENnRWJIYjVhTWFaZW5kWmhQZlhjd2RoZTRhT2JCZXdjSWRWY3diNGhKY0lieWFBZDFjZWdCZXdmTGdBZ0FobGM1ZmVnQmI5YytnWWJVY05oWGVXYVJiQWNaZ2FoQWZ0ZkZnYmR4Z0VkVGZNYmtiNWUvZ09nVWFkYW9nRmdVY2hlUWRSZ3hmQmNtYWNhbGZZaGRkSmdIYXdhQmRKaFJoZ2RlZFdmVGIwZjRoUmdsZTFkb2dYZ1NlZ2cxZk1kVGdVYVdoT2MxYXBkYWVIZVZmc2VBY0hlRGNjYy9iTWd5ZXdoRGZhZGtmTWdHZlVha2J0Yk9jVGNIZVpjMmFVY2thSWRWaGViSGZZYlNhU2d4aGhhRGhEaHljTWdnYWNhQ2NSZUljWGdraGxlWWZkZzNnUmJoYmRiM2VwZ3BiVmQxYWtmUWZHZFdkZ2hMZlJoV2Y4ZVJiRWEyZDhnT2hjZndmNWFIZk9iaGZzYmhoUGVqZ1JnZ2NBaHhkRWNpZGFkZ2NjaFRhS2RRZmdlMWZNZTJhSWdNZkVnZ2gwZnljWmhoZ1JobWNaY21jRmN3YVZkV2M5ZGFmUmR4YTBlZGNCZ3hmY2hnaFBoaWdnZXRhVGdXaEpnaGREaDFiSWZRYlpoRWZ4ZTJlZGFsZUplQ2FGZ1hnaGEyZ0Voa2N0aE1lQ2F4Z0FneGVmZ0Rod2gxZUJjZ2FRZWRlRWNuYlZhbWFTYTJlZGE2Z2JjMWdGYXpmRWNCaGxhb2hDZzBnVmV2YkVoUmVOaHZjUmgzY01mVGNSZjJhZ2FWYVNhRmFoYlBoUmNHaFpndmJWY2tmRWNpY09hd2dKZDVmQWR3Y1ZhbGJQaFRkTmhmYlZjaWNFZ2NoWmRDZjRna2dLYkZiZGdqYVdnbGJjYVJoSGZSZ3hlYmFlaGlmWWg3YU5md2c0ZmloUWN3ZUJiY2ZTZzNmWWZSYWVjVGVGZmJjVGJGZzhmM2RQYzFleGJEZkdma2FOYmJkYWIzZ3RoOGhXZGtmaGdEaFNoVmFwYzFjZWVFZXRnM2ZlZW1lbGJYZFdiUmJBY1plYWZBY3NlUmhKaDFoaGRBZ1liUWFzYzJnWGhRZ0FkOGdYaFVhaGJPZ1JiMWRsZ21hZGhGYkFlVmFZY2llWmhSZWZhRWFwYkthRmVHaGxhdmZHY0JmWmFtY0ZnbWQ5Y3ZoYmJWaHBhVmRiZzFmcGFIYUhhUmIxY1ZkVWNuaFJjcmhlY21jTmdOZGFka2JrYVRkTWhFZVVoaWRDaGplTWRrZlVha2VBZlZoY2UzZlpnR2VTaHhmTmJEaFdnM2d4YXdhV2duYkJlSWhRYjBjbGdhZ2RnWGdoYUxhZGUzZnBjcGZWaDFmQWZMZ01hMmVnZExjUmhXYjhjUmJFZDJmOWNIZ2NheGFNYmFnWWVSY2xmaWJVZEVoY2NRZlpkbmJKY1dmRmdXaHBmeWFVZ1hiOGVaYVJjRWJZZjdmTGhrZkpoWGZNZmtmMGQyZkljMmY4ZXpmR2ZpYklhS2NCYWtiOWhZaFZoVWQ5ZDBmTGhTZThhdGdEaGpoNGNDY1FjQmF3ZFFiYmZCZGhnNmZkZmdoQmFPYkZjVGRGaDZnRWhnZDRhVWJRZnhkWmdyZmNiaWN0ZGFkU2ZFYk5lSmVXYm5lVmM0YVNhM2JkZTZnYWZWYWRjWmZXaFZnOWhvZkFjMGNRZWhkSGExZ29lOGZKYlNkWmNWYkFiU2UxZ0hoUWdBY1JlT2JHYlVleGR5ZlZjaGZWZHFoY2VsZEZkM2dWZjBlb2dXZ2FlV2NFY1djR2JEZEplY2hOaENoa2EyY2NnQmhzYnFhRGJVZWRncGFSY0FnVWVYZ0VkVGRrZG9oTGdCYTljaWVTYldlNGRBZFZiemJFZEJiTWZ6Y2dkR2FRZmxjZ2Z0aEpjVWZaY0xlV2FnYlpjWmZJYTNiSWVTZUpmUWc0ZEZnRGVBZ2hiM2VjaFZmQmJkZGVmbWZsY1hjV2hSZEFkWmVhaEFkdGVGZ2JneGNFYVRiSmZnYUZmemJHYzJhMWNvYkZiVWZoYVFoUmV4Z0JibWdjaGxlWWRWYWFhbmdKZ1JlZGgxYThnY2RXYlNmQWJsYUZhZ2RoYW1jQ2RYZXRkN2JZYVNlSmVWZmFoVmN4ZkhoRmRVZjljVmJUYTNhUmY3ZmNlMmQ5ZG5jYWZrYXNlUGhVYWhhQmZrZlRjSGhaYzJnVWRraElnVmZlY0hiWmVFZkJmRmhFaEhnV2NYaEpheWJiY1doMWNWY1Fkd2dCYmFjY2QzZjVjTGJmYXpiTmRwZVNmbGFsZ0VkR2VYYmNmTGZFZVdlRmRkYVZoaWdFaEFjSmIxaHRjSGNjYWhnVmFZYVdhVWhzZTZkWmduZEplV2dGY1djcGF5aFVjWGZkZFhlU2FoZFplcGZZZFJlWmFPYktmVmcwY2lkWmZuZkZld2dTYUhoSmRIZVJnMWhnYmRhVWIxZFJlMGdZaHplOWFqZlViR2FwYWJoQmFsYTRhNmNaY0VkeGIyaGRmbGdKZUNkRmFYZGhiMmNFZWtnc2NZZ1FkMWJrYTBhUGFUZmtkMGNTaEZnTmRKZFJmMmRoYmxnU2F6aGhnNmRiYTFkRmFaZkdkRmJaaG9jRmRrY1VkN2hXZ1Zhb2Q4Z1NnVGM5Y1dkQ2hTZTloQmRBZEZnbGFMY09mbWFaaHljVmFoZFZncWZjY2xoRmMzYVZnMGhvZldmYWFXaEVoV2NDZkdnWWRLY1piamVSZ2hlTGFBaGxldmRFZTBlY2dEYUhlUWNGZGNoT2dDYzRnMGFKZkJia2RpY1NkMWVNY09iRWdIYlJkTWhhZUhlWWVYZVFna2FraGtkZGRsZjFlTGdCZmthTWhOY0tlamZzY2pmZmNnYlFoR2VCZHhhMGhoYU1mRWZKZGRoZWVtYWxhWGZXZlJoQWhaYWFlQWd0ZEZkYmd4YUVlVGZaYm1mMWN6YkVkMGdkYW9kRmNVZmhlUWhSaHhnQmdtZmNhbGhZZVZlYWFpYlliWmJKYVJjZ2ZkY0ZoaWdjYmtiUWhSZ2dhVWZWZVNkZ2ZoZEpkQmVVaEhjUGNSY1VoVmFGZFJkOGNhZEJleWdCY3JnTmJTZFZnTmFPYkFlcGNCYUZoVmNWaGtkQmFUZ2doeWhGZ3hjb2RYZmNmV2YwZTRlU2R4ZGhoRGNXY1doSmh5Z2NmSGRCZkloUWEwY2xhYWVQY0RiNWRMYmZjemc5ZXBjU2NVY1FmUWRWaG1kZ2JOYVFjMmc5Z0RjRWQzY0ZlYWJjZDFlcGFPZGFiRWNjYU5jQmNCY0piQ2FLYkhlSmhHZERma2FCYXljVWVYZGRkWGFTYmhhWmNwZ1lhUmJZYllnWmRoZVFjdmZJYUdlRmU0ZkViR2E5Y0VlV2JoZDFoU2VYaEZjSWRtZkxlaWI0aDJnSGV5YVJjTGVBZmthTWVMZlRha2d4ZjJlZGhsYkpkQ2JGZ1hnaGUyZkVka2JzZFlkUWV4YUFna2FjYm5iZ2dpY1NlRmYxYVVkV2VqYnhneGdTZnljVWUvZ1BlUWRJZkxmWGdoZGxhNWJFZ0diOWF2Y0VnUmZOZHZoUmQzZU1lVGJSYTJmZ2hWaFNjRmZBaE9iVmZtYVplNmJYZGhnMGI0aGNma2I5ZnBkU2dWZ2NlV2VlZ1diZ2VhZkdoR2U1ZGRkWmVuZWhiL2ZiZmtmaGZ2aFNha2Y0ZlJhSGFWYzBlWGFkYUhiVmRrZmZoVmVCYnFnV2R3Z1pjZWhFZ0djd2VEaGRibWdoaE1lWGRBY2hlNGZaZGhhdGFIY0dlQmVjYVJkS2Z5aEZod2RiaFZkVmFlYVNoUWE1ZThoY2ZXY0ZnM2RlZ21mbGJYZ1dkUmJBY1pmYWFBZXRjRmViZXhmRWRUZmJneGVVZDJnUmF4aEljNmRXYzBlaGdBYlhlRGVwaG1jY2NsYllkVmFhYm5lSmFSZGRhMWdkZktiRmNtZWtobmRXY1VlcGFtYUhoRWh4aG1hWWhYZkJnVmZiYTFkcGVIZkhhUmExaFZiVWZuaFJicmJlaGpiVWdNY09oRWN0aEhkVWdnZDFna2FBYzNnWmc3ZFVmZ2djZFpjVWJuYllkU2dTZXhhaGZEaFdiV2JKZnljY2dIY0JhSWNRYjBjbGJhZ2RiWGVnY1lnZGMyYWRlcGRIZ2xka2RkYUdhVGJvZkhnYmEyYjhoUmhFYzJkOWFIaGNoeGdOZkhlYWhCZFZkSWVVaEViY2hRZFpobmdJYlhoRmFYaGRheWhQZkRkWWFEYkFkaGFnZ2tlS2VGZWdoUWRMZWhiaGhtZ05nV2ZoYThnZmcyZTlnYWRSYnhjMGFkZ1ZjVmRKZzBkYWYzZHBlamhUaFdkcGJMZkRiMWdKZ0ZoWmJGZkZnMmNJZmhjb2FMZlJnbmRZZGxhWGZnaEpoYmhCZWxlRWhuY2ZhbmNBZi9jUWRVaDljamdXaG5oVmY0Y1NlM2hkYjZmYWhWZ2RmWmRFZkJobGhvZ0NiMGVWZ3ZhRWNWZFZidmZXY25mTmhIYlNhVGJ0YlpmQWhSZU1hQ2VHaERiUmgrZlZibGF4ZGpnZmFuZnRmM2hWZTBob2JXZmFnV2JFZFdiR2ZHYVljVWRaYm1oWmhoZ2NhRmVWZHZlRmFrZ2NiQWNIZlVnVmNKZFhibWJ0aDZmWWIwYjFlcWdTaHdhOWJTZUVnR2RSZk1oZGRuZFpmU2RBZXhiVmFtYWRmbGU1aFFlTWFrZE5lWmFZaG5oSmh3YWNmRWVoZURhU2RWaHBnMWdlZkVkdGEzZGNjV2RJaGJkY2h4ZUFjWmNhYkFndGNGY2JkeGdFYVRoYmcwZmRlemFFZjBmNWVDaEZlVWNoZlFjUmh4Y0JlbWZjZWxoWWNWaGFjbmhKY1JlZGYxYWNjRGNVYkdkbGNwZFFiMmFNZHFjYWhXYVpnbmVmZEdiMWdWYktjU2FFYkxiWWVCYVJoVmFDYVZjNWRyYmVmbWROYU5mYWFrZXNhUGhVZ2hlQmdrZ1RlSGRaZDJnVWJrYUloVmdjYkRiNGJTaFZiaGVnZFdkSWhpYzRiUGRlZVhmeGVJY1NmeGZwYmFkYWdIaGdlTmZEY0RoWWhVZVhia2RJaDZjR2hXYWdoTGRSZldiOGFSZ0VmMmM5ZEhkY2h4Y05oSGhhZUJkVmFJaFVmQWVWZkNkSWd6YU1kZGVEZGtjQmF5ZlVkWGNkaFhhU2FoZ1picGhZZ1JlWWNZZ1phaGRSaG1jWmFqYXhoYWhWYldhOWRhaFJmeGQwY2RhVmdWY0plMGFhYTNicGRqZEhoeWM4ZGZlV2RnaEJnZWNaZ0JoOWQyZGFlRmZJY0tkRmhXYmRjMmRIZDFjb2VZZ1dlVmFrZnFlY2JtZTVmd2ZHaDBnTmRXaFdmbWRSZjRlVWVYZ2RicWVjY25jMWFaZ0VmQmhsZG9iQ2IwYlZodmdFZVJnTmZ2YUdkbmVvY2ZhYmNXYmdlVmhTaEZkQmRIYkVjR2NaZ3llVmdoYlZkaWJQY0ZiOGduY0JiUWRWYUNhSmVqaFZlUGhTZ0NiTWZhYkxneWdnYmlnUGJBZkFncmRIZHhoUWhkYUFnRmVVYVVnSWdTZFViNWhOZXdlUWJsYkJmUWU5YWFmUmdHZGhmTWRKY0hmcGNTZENmeGJ4YTRjTGZUZGhmTGNHZEViTmNaZ1lhbmJKY3dkY2JFYmhoRGJTZFZkb2NuZFBjUmE4Y2liS2ZDZGRkWGdWaEFiRWdaZGFoUmVaZVljYmQwZFZoYmNKZ2hiUmU5YldlZ2drZHNoVWVCZEFmL2dBY1JkZ2V5Z2ZibGhaYkhhWmduZUllWWNmZmtmeGVnYUZibWJsaGhiRmNoZ2hlbWVGYUdnWmNtZllnU2UxZGNnWWgzZ0JoSGNIaFJkMWNWZFVmbmhSaHJiZWJtY05oTmVZaGdhVWhCZUFla2ZJYnJlR2dEZ2tiaWVDYnhlSmZRZGRhamM5aGNlRGcxZTBmYmVOYmljUmh5Y2JhWGZBZ09hRmNnZGNkWmdJYlRoRWNFY09nWGVwaGhnQWcxYVVoUWdTZTJoUWVMZURiR2hZZFJjU2RFaFZhSGdjZnhiTmdIZmFoQmRWaElkVWdFY2NoUWJaZ25hSWZFYVVlRGY0aG5iQWJ6Z2xiWGJIZUJnNGg5YUtmVmg5ZExlYWZoZVFneWdhZG1kRWNpaFdoV2g4aFRmU2R4ZzBhY2hSYlZldGR2Y1FnWGdwYmpnVGhXaHBoTGdEZzFkSWNRYlphRWF3YnJjZmgxaDVhb2VGZFhoaGUyYUVoa2hzZlloUWgxZmxkaWhjY25jZ2ErZFJiaGRNZWJkRmNTZkViM2hIZXljNGdxZExmRmFrYlZlVWdVYm9lOGJZZGdkc2ZyZVZiRWNzZkFiQWFYZU1nT2FSZnloNWJBZEJiaGFNYlRnV2NTaGthOGdWZGhoMGIrZmZhbGRFYmxoV2MwaHBhZmJZZkdnRmROYU1nbWRZYlVmWmZtYlpkaGdjZUZhVmh2Y1dna2VjZ2RlSGFRYWNhWGFJZERiNGRvaExkVWIwYzhnUWgxZHNhYWdXYVRkZGhBZmRnaWNKYmVnUWNrZGRnMGFkZGxndGZIZEdmRWhKYUljYWIyY2xnYWdjYkVoaGNEYlNmVmFwaDFmZWVFZnRhM2JlZWpkUmJlZFZlVGVvZVpiYWRBYnRlRmdiZnhnRWVUZGJoMGdkZ3poR2V3Y2xkbWFSYVJlb2dmZ0VoMWc4Z3lkS2F3YlplUWJaZUNiVWJEZ1BhZ2dNZFBnRmduY1JnaGdVZEViMGZvZVZoemZJY3ZoTGVqYzVjVmJaY3dlNWNMZkhlVWY5Y1pmVWFqYzFjbmhlaGloWmhFYmFjaGVBYWxhVWNoZkJoa2ZUZUhiWmYyZ1Via2hJZFZhZWJIY1loU2RBYWxkNWREY1VhVGdRYzllT2FUYVJhSWFVZTBibGdIYWFnR2ZWZExkSmNYY05jcGRYZnhod2VRZ0JoR2dnZEphRWVEZXRlWGZDYjJhMWVPY2ZheGZOZFBjSWRSYlZiVmhVZEJnTmhZYUxleWdGYVlnV2JTYzhiOGFGY2ljTWJmYVFneGZwZ3BlYWRVY1FnWWFlZHhjUmcyY2JlM2NwY2FiVmZXZTloYWhSZ3hiMGFkY1ZiVmhKYjBoYWEzYnBiamFDY0NnWWRZYVNlbGRKYlpmSWNraHhhK2hJZkJnMGZMaFVoWGRoZG1jRWZsZ1lhRmVYYWxoa2hyY2NnbmZaYjJmU2hFYUVoYWZEZGllY2J4ZEJjVGhCYzRjYWJVYXBoRWJFZUVkMGV4Y1dod2RBYWdoVmJ4Z01jOWVUZGxoa2NUZ1JnMmdnYVZlU2JGZEJjSGhFYkdmWmR5ZlZoaGdWZHFkY2ZsZGtkeWNWYzFkY2JXYk9nMmNnYmFoR2RHYTVjZGJaY25jdGJoYkpoQmcwZm1oQ2ZVY2xlUmhXYkJjc2FWZ0lnQ2dOY3phYmIwYzFjaWVHY1FhOWFQYUViSGJSZUZlYmNWZ3hmU2VRZGhnVmM0ZGRmaGFKYUxkR2FFYU5jWmRZZ25nSWgxZ1BlQmRzZkdmU2JRY0ZiZmFlZUVjdGIzYWVobWZsZ1hhV2VSaEFmWmFhYkFjdGdGY2JkeGVGaGFkS2FVaGRhN2FFY2dkNGI3Z2Nkd2hFYWVmRGRrZlFkamFlZ2dnUWRjaFliMWJoaFJkZGIxZ2RjS2dGZW1mbGdoaEZiaGhoZG1jRmZHYVplbWVZZFhjQmRWZU9ieGhJY1ZoVWNrZnBkVmdIZkRmRWE4aGVnZ2NZYmZjT2dBY1JjZGdXYWpncGhrYVRlSGhaYTJnVWJrZklmVmRlZ0hkWWNTZ1NieGFoYURoV2ZXaEpmeWNjZEhhQmNLaEliUmR3ZGNjTWV6YjBhWmVlYVNhMGM3YUhkZ2gxZFZmRWNUZnRiZmJGZHlkWmZmZVZlR2dOYkhhTmFsaDBiRWNKZjFoRWhCYUhiZ2RBYWNlWmVqYjBlUWRVZXpha2EzaEJmUWN4ZWJhU2ZsZW9lc2dMYzFmRmNNZ0xnbWRsY3ZnWmRpZ2djamhWZlNiRWZWaFJhMWNGY1NlR2h4YVVneGFPZlhkb2F3ZkdkRGJvZWJlUWNBZEJhRWdJYlFnaGMwYlhkRmFKZUNkRmNYZ2hlMmJFaGthc2dZZlFjMWRsYmllY2ZuYkJhd2JTZkVhTmRBYVFlVmY5ZjRmU2gzYWRoNmZhZlZoZGNaYUVhQmZsYW9iQ2MwYVZldmNFYlJnc2g5YVJiMmM0YVRkVmUyaGhhSmVTaEFlSmZPZ0hiRWd4Z3liVmNoYVZhcWJjZWxiRmgzZlZiMGNvZFdiYWVXZEVhV2dHaEdjWWhVY0xhemZVZ0hlT2JSZXNibWNEZ2dmSWdWaFZlRmZ4ZTRnZGRHYnRkNmFZYjBoMWRxY1Nid2Q5Z1NjRWFHZVJmTWNkZm5jWmZTZFFkaGhWZjRjYWNSY0pmRGJFZEFhcGhaY2ZlM2RKZGdhY2JCYVJiRGVBYUZhTmY1YmVoQmEwZDRlTWR5YjFlWGVTZFJjQWRFZ2RnUmdaYkZnS2NoZUVnVmZhZFVhZGY3ZlZka2FkZjFhRmFVYm9jRmVFZjFhWmUraGNnRmU4ZmNlUWVIY0pkUmVkYTFkZGRLZkZmbWdsaGhhRmhoY2hjbWVGYkdjWmZtaFlkWGhCZFZhYmEwZEJmSGdGZlJkVWVRY1VjbWNsYXJhTWYyYnBoQmdhYmtnTmZHYVVkZ2IxYWtoR2FqZWtoL2RGYmtlSWNGZWNmWGc4Y0pnWWRSZmhhRGVXYVdmSmJ5ZWNmSGZCZ0llUWgwZGxlYWhkYVNoVmdoZWRkM2RwaHBoVmMxZ2thUWZHY1djZ2hMY1JiV2g4ZVJmUmFTZDRjVmdjaDFheGNIYmRiUmhVZWNoR2JBZTVhRGhhZkRnNGNUZVdmeWQwYm1iR2FYYWRiYWRTZ2thUmR5Y1NheGhZZFlnWmNoYlJhbWZaYW1lRmR3ZVZoV2M5ZmFlUmMxaFJlYmZWZVZkcGdlYWFjM2FwYmpjVGFXY3BkTGJEZjFjSWFRYVplRWd4YjJlZGRsZ0pkS2ZIZFNlNGg1Y1dod2Y4Z1lmVWMxYWxiL2ZiYTJiMWR3ZEFhVWdNZVZmQmVuY1VkeGVTYTJnbGM2YUpnbGM1aFpoRmNoaDlhb2NBZndieGF2aERoQmFNZmdhVGJuYThkNWhSZzJoZ2VWZFNnRmRCZ0hiRWdHZFpjeWFWZGhiVmZxZmNibGFGYy9hQWEwY1JhYWVMZ0NlOWdSaFRkQ2M0YVVhZWRHZFpmeGNjaEZjTmdwZFdma2Y4Zk5mSGVVY3RjU2dQZ1dnc2htYVBjMGgxZjZnU2J4Y0ZlU2NRY21lMWVGaGRhaWNvZE9kUWVrYmRlNGhhZEJkSWFmZFVoQWJvZ0tmYmFEYTRiMWZQY2dhOGFYaEFkVmVOZGZhZWdFaHRnM2dlYW1kbGNYY1dmUmdBZlpmYWVBZHRiRmFaZWpic2hUaGJiMGNkZXpoRWUwYmRmb2hGZFVmaGVRYVJleGNCZW1iY2JnaEpiZGNPZkRoMGhHYWRleGNrYlBjUWZXZWtjVGNWYzFnWWNoY1VoUWdNZTBiTWV6ZjhmSGNaZzFnZ2dtaFNlVWdrZ1FlSGZ5ZFFoL2dlZGphY2RDYWFmaGh4YmRkR2EwaFFiaGRUZ0Ria2JqaEJoaGVGYWNiUGREZU1hU2ZDZFVkMGJGZ0hoeWNjYWdhY2dEYUliSGNGZ2doY2VlZ0pobmZwYkNjYmdGYkJicGdWYzFja2RRY0dkV2hnaExnUmJXZDhlUmVFYTJnOGFDZ2NkMGU4aGJhYWJCZzBmTmRVaEZob2RRZFphQ2VjZ0NmVWQzZkpnd2ZXZUdkeGY5YVNkaGNaaHBnWWRSZFloWWhaZ2hiUmNtY1pnbWNGY3diRWJ5YUFkSWhSaHhnVmhMZkZkQWdCZjBjSWgzZHBlK2RUZldmdGFhZUZhRmdJZkxiWmJFZlZoY2dkYmxmSmRDY0ZkWGRoYjJoRWZrY3NmWWdRaDFkbGNpYWNkbmRBYWpjSGJ3Y29lZGFHZVRoMWE0ZFFmemVKZHpjYWJRYXhmemNFZ0JobGJvZkNmMGJWY3ZjRWFSZ05hdmRSYjNlTWZUYVJkMmJnZlZoU2FCZU1lR2VRYnlkTmZ5ZFZoRmQwZHZiS2hsYU5ndGJmZ1Vjb2FXZWFkV2RFaFdkR2JHYVloVWdaZW1mWmFoY2NiRmFWZHZoV2FrZmNoZGdIZ1FlY2ZYZUlnRGY0aG9hTGhVZzBoSmhRZjFic2hhYVdmVGdkaEFoZGZpZUpoZWdRZGtkZGMwZWRmbGR0Z0NhQWcyZWxmWmJZYm5mSmR3Y2NmRWRoY0RoU2VWYnBmMWNlZ0VndGIzZmVjbWFsZFhhR2VsYUZnS2dMZVFndGhIZE9ka2hWYlZmZGcwY1ZocGFPYVVjZGhvZUZmVWJoYVFmUmJ4Z0JhbWZjYmxkWWVWYWFobmFKZFJjZGgxYmNoSmNWZHpob2hrZEZoaGJvZHpiUWdDY0JncmJlZVhjSmFQZlJoVmZwaEhnSGJSZDFhVmRVYW5iUmhyYWVkbWhOY05oYWdrZXNiUGRVZWhiQmVrZ1RjQ2JRYXpjQmVoYmRkSGZOZm5oWmNRaFFmMGZ3YUxoRWdEZ0ZmK2ZjZ0NlUmZFYlFkeGh0Y1diZGFUY0ZjQ2diY0ZmQmVwYVZjMWRrY1FlR2JXZWdmTGdSZFdjOGdSaEVmMmU5aEhoY2h4ZE5oSGNLZzFoUWdiZkZoVWZjZVNoSmZ5YkViVmVYZkNkTmh3Y1NnMWMxZFhjU2doYVphcGZZZlJkWWhZYlpiaGVSZW1iWmRtY0Zld2JWZVdnOWRhaFJleGUxZlBoRWhBaFlkaGRPZVRjUmZqZUtnR2VJaGZiUmd4ZnRlRGJhYUVod2dpZGVhbGJJY1FkR2VYYWdnL2dHZjFmQWN5Y1FnMWhsaGljY2FuZEJnd2ZTZEVkTmNKZFdhbmJWaDRjU2IzZGRjNmRhZ1JmUWZZY1FoMWV4Z29kQ2NRZGtkdWNSZFZhb2JoYlZnbmdFZUpmYmVXaGdmVmJTZEZjQmNIYUViR2VaZnlnVmFoZlZicWVjYmxiRmUzaFZoMGVwZFZmS2hEYkpkVGdHZkdmUmRXZ0xheWJnZ2dnSWJnYXhodGZRZEdnMGhkY0hlVmVWZFNoZGhHZ3RoNmVZZTBoMWRxYlNhd2c5Z1NiRWdHZlJmTWFkYW5iWWdBZkJhMGNFYXRnSmVGaHhmTGRhYWtic2VOY0tiamdzY2pkZmJFZGdlWGRSY1Zjb2NuZGRlRWZzYStiY2IzY0phOWRXYlJnQWNaZGFkQWJ0ZkZmYmN4YkVhVGFiYTBmZGN6ZUVkMGVkYW9kRmhRaHNmUmVGZUZiVmdtYWNiQmVSY1ViT2RUY2RmSGNZZjFmVmRRZVBkR2hsYmhmRmZoaGhlbWhGY0doWmRtZVljWGRCZVZoYmcxaHBjSGRIZVJkMWRWYVVlaWZZZ3VjTGhqYVlkZmFKaEVidGdYZVdna2JRaHNoQmdTY1ZhNmdVY2hhWWFaZGVjQ2VRYWVoU2UxZ0ZhS2JRaGthaGh5aGNjSGFCZ0lmUWMwYmxhYWZkZ1hkaGFMZWRhM2JwY3BoVmcxZWtjUWZXaGlnbGJZY0FoR2I4Y1RnUmNpZHdmVWdZZlJnRmNkaFFkaGRWZ0lhVWVFZWNkUWFaZG5jSmFXZkZnV2ZwZ3loVWZYZmRoWGdTZWhhWWhxZ0llRWRWYmRjWmZoZ1lhemFKY1RoSmU5Z1JmMmQxZUFlYmdSaDBnZGhWYVZiSmgwYmFhM2hwZ2phVGJXZXBoTGREYzFoSWVRZlpnRWJ3ZTFoTmd3ZkVjSGRGYVhjb2ZqZFJhZ2gwY0pkVmRSZ1VobmNjaEdjcGNhYlNmRWZOZEphV2JuY1ZlNGhTZTNkZGY2ZGFnVmdkZ1pmRWhCZmxmb2FDZndmWWh1ZFFmbGFaZXZnUmhTYVpkSGJBZVdmVWNFZ1hiaGF3YUNnRWRuZXhhWWhWZGhiVmhxZGNnbGNGYTNlVmMwZG9kV2JhaFdiRWJXYkdnR2dZaFVjWmRtYVpnaGJJZGhiQWQ3aERieGZWZlRnSGRUYWRhYWRJZUNnTWN6aE1mRWRGZ3FjSGh3ZU5lU2JRaG1haGdNaFBkM2g5ZkpjYWVCYlZiNGFkYmhiSmhMY0diRWZOZlpmWWJuY0pod2FjZEVoaGJEYlNmVmdvZnhmUGFRYTBoMmFMZ3ljVWhEZlFjemFvZlphYWdBZnRlRmJiZnhkRWVUZ2JjMGFkY3pnRWEwaGRib2NGY1VjaGVRaFJkeGZBZHZmTmVGZFlmZGRJYm5jdGZSY0ljeGM4Y1lkV2VUYjViaGhXY0ZhMGh4YUZoQmZJZS9oTWZUZFVmd2VQYlFnZ2dJYVRheGhWZVhlSmV6aG9iZ2dOZUNhd2VhZ0poRWR0Z0tiSGdGZk1hcmJDZkRkOGI0YUZhVmZnYVZiZWZuZlloWmJTZDFoMWRLZlFha2NoYnloY2dIY0JoSWRRZDBibGJhYWRhWGVoZUxoZGEzZXBhcGNWZTFka2dRZEdoV2JnZERmQWNHZThnTWVFYTJhZGRGYmNkUmdOYk1jYWVGZUJnQmZYZGhmTmJmZ0NmamIwY0JlVWZEZWdjUmRFZENmUWdTY1FiaGU5ZGdkYmVSY1lnUWVMZ2hiUmU3Y1pmbWZCYmdnWGFIZVJld2JSZXhjMGJkZVZjVmVKZTBhYWEzaHBoamJUZFdkcGRMY0RmMWVKZ05oVGFrZnhoMmRkY2xkSmVDZkZmWGZoYjJoRWNrZnRnRmFTZGxnVmRJaGNkbmZCZndiU2hFZU5jSmdXaG5oVmc0Z1NmM2Q4YjBiWmd3Z2NkTGdYYjBoMGNuaFhleGJ3aC9oVmNCZTBmN2ZDaEJmbGFnZktlQWJZYVZnVmdWaEFhQmFSZlNjZ2F4Z0FkbGZ3Y2xjUGFGY0ZjL2ZYZmtocGROaFFhMmRFYldkR2NHZFlmVWhaY21iWmhoZWNoRmRWZXZhV2FoYlZnWWZTYVFhQWVBZU9hbWZzY2hkU2RVYjFlcWdTYXdkOWVTY0VnR2FSZU1iZGRuZlpoU2VRY2hhVmQ0Y0lna2hzZGJmWGdWY2xlWmRZZUJiQWZsZU5iZ2Y0ZkdnR2YxYWhoNWZVaGtjdGMzZWVkbWRsZVhlV2hSZ0FkWmRhYUFodGhGaGJmeGdFY1RkS2J3YllhbmhVYWxkMWZvZWRoQmNvZkNiQmhrYmxhb2ZJY2doUmZhZ1BiamQwaEZkTGFnZmNhUGFHZERlb2J0ZVhjMWhzYWpoR2NpYVVhbmhMY1RjeGNkYk9neGdJYU9kVGNoZE1lcWVFY3ljWWQ1ZWVlamI4aFJhYWJoZjlmSGhHYTBoTmdvYVRnR2ZaYS9kWGdtZGdmVmFlZ0hhWWFTZ1NoeGZoZ0RiV2RXYUpjeWhjZ0hkQWdWZFdnR2FOYWFoZGVYZmhiTGFkYTNicGdwYlZnMWdraFFjUmNHaEVhUWFiZzJlOGhSY0VjMmI5ZEhoY2d4Y05lSGdQZWxnUWFhYVVkQmFOZEVlWmZtZzliV2RBZVhhcGdyY1JjMmN4YjloU2RoY1plcGVZaFJiWWZZY1poaGhSZ3ViS2hHZjhhZ2dCYXlhQWNPaENiRWJsZkVoQmRSYmRjNmZPaERkWWFxY0RiaWg5ZExlRWVsZUpkV2hNYVFjSWQxYklhaGZzYU5jV2EzZGhlK2JSYmthY2NZYUVmVmdCYWlkS2VWYXBhd2dTZUViTmhKY1dlbmFWZjRjU2czYmRiNmRQZnhoWWhMZEVnRmNCZ29kRmhraFVlN2dXZlZhb2Y4YVNmVGY5Z1dkQ2RTZjljQmRBYkVhdGV0aEVmR2RaZ3lhVmRoZVZicWdjZ2xhRmEzZ1ZhMGFKZUNhYWdYZHdoV2VSY2piaGFBY2JnMmFwZUxnY2ZGZ1ZjdmNXZ2tmY2JkY0hmVmVWZVNkZGVHZnRoNmdhYXhmOWRxaFZoZ2Y4aEVhWGN5YTBjSWFkYm1kWmdTZ1hjd2JoZmxjZGJrZEJlTGRCZDBjTWRRZ1lhbWdoaHdhTGZoZ1lkUmJRZEZiWmRmaGVkRWh0YjNjZWVtYWxhWGhXZ1JkQWhaYWFkQWR0ZUZoZmh4YUVlTmdiaHhkTmZ6aERoRWNkZGdnSGdSYXhoUWJUZEFnMWRtZU9mMWU4ZFpoYWJtYkplUmVhZlZoY2FlaEZhbWI5ZW5mRmJoZUFkeWFGZUhhdGZtYmNnWGRsYmNjYmMwZkJhSGdTZ1JhMWVMZVVkamMxYnJnZmRHYlZmTmhZaGhmOGVQZFRneGVBYXRkUmZYZnBmY2RVY2tkSWVWaGVlSGhZZ1NlU2R4ZGhmRGdXYVdlSmd5ZFljSGNCZFdoUWh4YnRoYWRhaG5maGdEZmZmeWFoYnBiWGdFZVFkUWVVYUdkRWNIZ1JoWGM4YlJmRGdXYjhnVmJjZHhjVmNCZ2FjQmEwZWFoVWFGZ29hUWdkYm5odGVmYUZnWGVCZ3lhQWUzZ2RkSmNTYmxkOWVwZlpheGRBYVlnYmJrY1pibWVlZzJkRWI1Z1hkR2hOZndhUmJ4ZzBoZGhWZ1ZlSmYwZ2FnM2RwYWpmVGhXYnBmTGRXYTFmSWNPZVpmQmQ1YzJiY2FGaFJkQ2FIZFNncGgyZkRkMGd0Z01iU2draEplSWZjZG5lQmJ3ZVNhRWhOZkpiV2RuZFZhNGNTZHllRWc3aE9hMWVjYWNkQ2N6Z05kb2JDZzBiVmV2Y0ViUmhOZnZiUmEzZ01mVGdEYmloNGJWZ1FkQmc1YkpjWmdCZzhjQ2hNZDNmRWNWZUVkeWRNZEZiTmdqZE5lcGdHZ2hmUmJtYWFjQWRsZW1mRWZtaDlnTGZjZUZiVmN2Y1dha2JjaGRhSGFWZVZiU2dkZUdhdGE2YmFmd2FoYnFnVmVnZThoR2VXY0NjMGFmZGVoQ2VVZUhnQWNGZVFlcWhKZ0ZkTWhTZ0VjQmFkZ1ZiWWFpZEJmNWRlZVVmUmZEaFFmUmc5YjdoQmV6ZlFlbmZLaENkWWFEYkZjbWE5ZW1hYWFCZlphRmFJYlJhOWNEZlBhUWNnaG5mWGVCZU1meGdSYlFiMWVaY1hkRGRwYW1jY2ZsY1loVmRhaG5oSmFSZmRoMWJkYktmVWh5Z1VheWVVZHhjZ2U5YVBhbWRaZ21iWWhYY0JmVmRiaDFjcGVIZEhoUmQxZlZjVWdpYUlkcWZLYUdjTWRDZGFhbGNZZlBkQWVCZkJlcGVUZUNmSmJ0ZWVmRWJJZFZoZWhIYVljU2dTZ3hhaGVEZ1diV2RKaHljY2FEYVZjSWhYaGtma2ZVY01hQ2E5ZUxiT2dYY0lhbWdXYTFhbGRHZlZnaWJGZFBoUmFYZDhlWWhDZkVlVmFIZ2NoeGNOYUhkYWhCY1ZiSWdVZ0VmY2VRY1pjbmdJZVFjV2RqZGhleWdXY1NoRWRXZUdmQmdZYmhoWWVRZHNoWWhkZWdjOWJtZUtjV2JGY3VjVmhTZ2RmQmFSZ3hhWWVXZUhkVmN0ZTBmTGFnaEVhcmVNY0djcGVXaERid2JaaFlmTGhSZjhlTmhQYmxlSmdKZUZmU2Z3Y0xoQ2ZXZkVmWWhRaDFobGFpYWNobmZCYndnU2NFZE5hSmRCYTFnOWM0ZVNmM2VkYzZlYWFWY2RmWmVFY0JmbGNvZ1dhUWdBYjdjUmNFYUViaGFSZXpnWWJJZmJnV2ZnYVZhU2hGZ0JiSGVFZkdkWmd5YkNneGd4Z21iV2JGZkZkM2hWYTBmb2hXZGFkV2NFYVdmR2JHaFljY2ZLZEdlZ2J4aElnaGFvYTdjRmVSZk5hRWdUYlJlQmdjY0phaWY0YzdnSmF6Z2dnRGNCYVZkc2YrY2RkV2RSZVJmZGRqZUFkSGhEY0ZhWWVzYlBlMWMwZEZnR2FFYXNoTmJiZG5lSWFpY2ZhRWVnaEtmUWhGaG9ldWNVZ2tmdGgzYWVkbWdsY1hoV2NSZ0FhWmVhaEFjdGNGZmJieGJsY0hmYmgxYXBkemVBaDBjY2QwZkZiUmV4Z1pjU2N4Y0JldWhJZUZmWWNJZmFjbWdKYlJiS2gxZWNkWWZIZjJnVmRoZ1hmeGJnaDZjU2JHaFliTGRhZ1NjUmdaZGJmd2JoZUxoSGFVY2tlZGNHZHljZGdsY05laWVZaERmTGJSYjlmSGJXZ3djdGNPZFRjSGJaZjJmVWdraEllVmhlYkhjWWhTaFNjeGdoZ0RiSGd5ZDBkZ2djYUhjZ2VlZEFnaGV0ZmFjTWRIZWhjV2FkY3lmNGhoYUhkZ2FwaHJhVGdSZVVkSGVSYlNjQWFSZURlbWc5ZFdkZmJ4ZU1lUGFhZUFnaGJJY1FiRmF3ZFFkYmNYZWtmZWVGY1hkWmN5aEFnM2hkaFJkVGNCYlphaGFMZGhkWWZTYmVneGZSZzBhY2czYmRlNWVUaG1iOWRUZGJiUmIwaGRiVmZWZ0pjMGdhYjNncGRqYVRkV2RwZUxkRGIxZElkUWhJZVVmeGM5YmFmMWJJYVdhWGVUZEVobGZhYVJhOGhZZFNoRmdrY3FlRGczYUJkNmNTZkFleGFTZmNhSGZWaDRhU2IzZGRoNmVhZVZnZGNaY0VnQmNsZ29iQ2h4YWNocWZSaFVhWWg5Z0NlWGhOYldkWGhFZklmVmFTZ0ZoQmJIZ0VhR2JaY3lkVmhoYlZmcWVMYzFmaGQ3Y2ZnVWNvZldoYWJXaEVjV2VHaEdmWWdVYVpkbWZaZXBlUGZsZ3NlL2dDYUFlaGJKZ1VoZ2ZFZUxiSmFDYjVnMGZNYVFnZ2NyaERlM2JvYjdjWGdqZEFidWRFYTNoWmVQZVFnbGFNYnRjT2VGY0VjZmRVZlFod2hYaFlibmFvY2tjZmVFaGdlUmVSaFZmb2E4aGNkVWNzaHNmVWdHZ2xjWGNXY1JoQWJaaGFiQWh0ZkZjYmR4Y0VmVGdiYjBhOGFuZ0VmMWNwZW9kQmVVY2dkTWdSZjBnUmJ2Z2ZkbGRZZWRhT2FIZkpnTWhkZzBnZGJLZVNmbWZrYXpnSGR4Z1JhbWdYZldoWWM2YlBlWGdBYzRmWmJ3ZDVjTGNIYVVnOWVaZVVnaWdBaGplTWF6YkJnRGNKYWdlNWRCYkZnVWNRY3NlUmZXZTFjY2JVZGtlSWdWZmViSGFZaFNnU2J4YmhkRGFXaFdjSmR5ZU5iamY4aGFhUWMwY0VlTWNOZkNjcGZMZU1kbmhwZTBkVmV3ZzFoWWFVZURldGZ3Y0ViV2Q4ZmFlRWMyZUphS2NJZ1dmNWJMYWFhRmVwZUljVGVVZmNmQmJmaFhiSWNFY0ZoWGRSYnlkUWNYZGRhUmNUZkJhWmJoZ0xiaGNZZlNkZWV4YVJhMGVjYjNoZGI1aFRhbWY5ZFRkYmNSYTBjZGhWaFZkSmQwZGFkM2JwYmpoVGVXZXBnTGZEYjFiSWhRZUloVWF4YjlkYWQxY0lnV2JYZ1RnRWhsZ2FoUmM4ZllmU2FGY2xkdmJmZXlhSWVOaFNjRWhsZ0poRmdXZzVmU2JTZDNhZGc2ZmFjVmdkaFpmRWZCY2xhb2RDZzBiVmJ2YlFoMWdZYzdhRWZpaEZoZGVSYXlnMGRPZVljbGhCaEhhRWJHYVpkeWFWZGhmVmFxZ2NobGFFY3FmWGVrZFliOGJhZVdhRWRXZ0dkR2dZYVVkWmFtZFpkaGhjZUZhMGRoYlZoQmRkYVBiVWZnaEViZGRJYURmSWdxaEpha2RNZTRkRGRrZDRhV2daYVFoMGFDYkllbWc1YVNlWGR4ZlVlK2ZJYTFjd2dJaFRmQWFvZVdlTGdIZkpnNGRKYkVmUmFEZEdnMWhOZTFiSWYyYkZoM2NlYm1hbGVYY1dnUmRBZVpnYWZBYXRkRmJiZnhlRmdCaEtiaGdNYW1jUWVRZWxlb2dSZDBhZ2dNZUdoeGhBZUxnZWFnaElkWmdhZ21iTmRkZWRid2hNZUNjWGV6ZXBjdmRXYWxjMGNvZ1VlemJJYXViYWFIYXhnVmNPZnhiSWFPYVRobWdZaEJhTGgyaDlhQmJlZG1iTmZOaGFla2ZzY1BjVWVoZUJoa2dUZkNodGcvaFhobWNnaFZnZWJIY1lnU2VTZXhjaGREYVdoV2RKZXljZWNEYjVoR2ZFYnhmc2FWYklmVGZjYmZoTGVpZG9oc2ZXZVFjdGJWZ1dhQ2h4YitoTGJDYkZlRmRBY25ja2NyZkZlaGROaGFhYWFGZk1lZGZIZ2doUmJFaExjemYwaFlhRmhXYUljbWVYZlhmY2FGYVFjeGJZYnliU2R4Z1llWWZaaGhnUmdtYlplbWVGYndhVmNXYzlnYWhSZzBhOWZZZUFiUWhjYm1oSmdYZm9meGJUZVRhWWNYaERoemc4YVlnTWhFZUJhMmZaZ0ZmNWJDYVFiVGhBZC9mUWVVY1ZlVWhCZWhnY2dsZUplamRoYjVmUmZFYk1kZGdFZGpid2ZyZU1jQ2JNYUhoYWJRZ3RmWmFHaEVoMGZnYVFoaGdZZVVnUmNSZk5ka2hSZDJnSmZ1ZlJlM2FRYkpiU2ZFYmhkT2hDYjBieGV5aFZkaGVWZ3FoY2NsY0ZjM2ZWYzBhb2hXYk5nR2hnYWFoTWdtaFliVWFaZW1mWmRoY2NmRmhWaHZmV2RrZGNnVmNVZDFoc2hDaEplaWhRZXViTGFCZWthemRHZzBocGRjYlFiaWNFZk5iTWVnaE1hN2NEZkVlRmZwYVliSGVBZ3ViR2JGYzVmWmZKZkNkY2QrZE1ieGh3ZUtjQmVoZlJlMWVjYkJoOWE3ZWVkamN0YWVhV2RVZHNnemNhY0FldGdGYWJoeGhFZ1RmYmEwYmRhemRFaDBmZGVvZVJld2YwY0VjRWRraElnb2djYmdnUWhWYU5iaWI1Y1JjR2hsYThhZWRHaG1lbGZ6ZkdjaGRnZHlhWGFDZjhlMWRiZHpld2dRYUlnUmcwYVRhVmNSY1JmWmFVaG5md2QvY01haWNvZ2VmRWZSZzlleWVVZmdkeGM0aFRlR2E1YS9mVWJoaDRiVmhMYkRhNWNiZUdnR2NNZ1hlV2ZXZGxleWZZZlFjMWFUYWFhVWdsZ2FhZGFYY2hjTGZkZjNmcGdwZFZhMWhsZU5mRWdHZlFjaGFSYldiOGRSZkVmMmE5aEhkY2d4ZU5lSGRhYUJmMGdHZVhhaGVkaENlS2JTYlloWmhRYlRjTWVpZ0ZkSGNrY0ZmRGExZGNmdGZGZUhlOWRXZ01oZ2dkZzBhQ2ZnaFJhd2NTZEdiOGRjZ0VjbGVOZGVjQWNSY3NiN2RKZ1hncGNyZ0dnV2NaYkxlWGNWYXNkUWJQaDJhWmQyaGRmbGFKaENjRmdYZWhmMmdFZGtic2VZYVFlMWJrZ3dmTmh5ZFFlbGhHZ2dhMWNKZlVkbGM5aDRhU2EzYmRkNmdhYVZjZGNaZkVhQmVsZW9iQ2gwY1ZndmRFYVVlRmN2Y0dmeWI4ZVRnS2JtZUJnQmVSY0ZhQmJUYUhjR2dZZ21nSGFsZndlNWVmZUJmMGV5ZkdjUWcxY0NnSWRXYmdhYWhNYW1lWWdVZFplbWhaZmhkY2ZGYlZldmNXYmtnY2RkaEhoVmhWZVNkZmZEaDhheWZLZ2hjNGFSZEhlM2hKYVNjVGdHaFJkRWhJY2pjNGJiYkVnV2I0YnNhZGJoaGxmTGVDZlRhNWNaYmZkbWI1ZXdmYWRFZEZkRGhGZlZjcGM5Y0xoQWhNYStlS2dSaElkRGVXYVJkc2ZaZmVobmRaYkZkY2h3ZzBlVGNmY2xnRmI2Ykdoa2JkZWpoUGcwaGhiUWJSZHhoQmZtZGNibGRZZ1ZoYWFuaEplUmhkZzFhZGFLZkZjbWFsZ3dmQWdBYjlneGRBZzNoUmEzZ2RnM2hCZWZmYmZ3ZzRoUGVWaEVmNGF1aEJjbmZSZGdlZWVuZ0Fmd2dRY0Vkc2VQZlVoaGRCZ2thVGdIY1pjMmRVYWthSWRWZGVjSGY4ZEplWWJSZmhoRGdXZVdnSmF5aGNoSGZCaEllUWQwYWtkSGFmY0hmUmFoY2RmM2dwYnBlVmIxZWtjUWRHYldhZ2ZMZ1JkV2RkY2ZkSGNUZzhoVmhQaEVhY2NJaFBnRWZ3ZllhRmRVZmxjQ2RJYnplTWZTZFlkQWFNZzhkQmRXZ1JoRmNLZEhnTmFwZ2ZlQmRaZGVnTWgxZW9hbGVNZWllZ2UvYUdnMmU5Z1NoRWV4ZEVhZGhCYzFodGQwZU1hRmVCYmplVGJXYXBlTGhEYjFoSWZRZ1piRWV4YTJhZGFsYkliUWRVZUNjd2ZqZ1FhQWNVZlljU2YzZE5laWFjZm5mQmR3ZVNoRWNOZUplV2FuZ1ZmNGhTZzNkZGQ2aGFjUWdWaFpiVGZFZ1Zkb2JaZ2tmMGc3ZkhkUmZOYTdkU2MzZU5nSGFEZ3lnRmFHY1JhaGd3Z0NnWGVpYkVnbWJIaGhheGNtY1dmRmhGZDNkVmEwZG9oV2ZhYVdkRWdXYkdiR2dZY1VlWmFtZVpiaGNZZ1VhTmM0aFRjVmFBY1BlRGVFZ05jU2RmYW1oc2F1ZUtjd2FRZTVmTWRGZ3NndmhFZEdlOWRtZWRhbmFaYVNhUWNoZ1ZnNGNkaGhhSmdMZkdjRWZOZVpmWWhuYUpid2VjZkVlQmNMZ0hjUmZJZThhS2R6Y0FkamhlZG1mSmhYY1NhR2IwaFplZGVCZ2RhRmhmaGdkY2dhZGJheGV0aHphR2V4ZU1oZ2NYZ0Jkc2VyY0VoeGhCYXRoY2drZVJkb2FhZG1nNWdOaGRlMGQ5ZERhRmVqZ1ZmaGNRaGxhQWh2Z1JkeGQwYnljWWdYYXRoVmVmYkNhZGRPaE5meGgxYVZnVWVuZlJmcmJlZ21lTmJOZWFla2NzZVBhVWdoZWxlL2RaZ25jWmMyY1Vha2VJZVZlZWdIZVlkU2NTZXhhZ2hlZVViR2c1ZFlmY2RIYkJlSWJRYjBhbGNhY2RmWGhoZUxiZGEzZklobmRXYVFjbGhDYlZiamV4ZEVjRWdUZlpnQmNWYW1kRWNWZE5jbGZJY0RnQWFWYXNkY2JQZkNkSWVRYmVmM2JJZVFkUWRDZ1FieGRCY1RnNGZZYkJlQmRaYmhmTmdSZG9kWWNOaEJhaGhtZkxnMmFoZ3diRGdrYVZkYWhSY3hkMGNkZlZiVmdKYjBlYWczZHBiamhUaFdicGFEZVdkMWRJY05nWmFGYXhkMmJLaGxiSWdXZ0hhSGNSZTJkR2ZoYWtnWWhYZGxobGV5YmNjaWd4Y3djR2hrYXBnRmJXZmpmeGg0Z0ZneWN0ZjZmQmhGZjhoTmdIYkJna2E2ZEJiMGhVYzdhV2FWZG9oOGRTZFRhOWFXaENjU2Q5ZEJlQWdGZWxoY2NPZ21hWmN5ZFZoaGRWYXFkY2FsYkZhM2NWYjBlb2hXY2FjU2dkaFpnU2NtYVlmY2dNYUNoY2V6aGNlQmdCaHZkUmcwYWRmSmZWZVJkd2JCY0RkemU4YkhnYmgwZzBobGVTY3hhSmNTaEFnV2RoY01iUGZuYVpoUGJRZmdoVmZqZWRmaGJsY0FnVWRFYU5hRmhZYmlhQmV3ZWRna2c1ZURmUWRSZVZhMWJjY2xiWmYzY2FiSGZ4aEJlVWVBZXNoWmVZYlNhRmRGY2JmeGhFY1RiYmYwY2RkemZFYTBoZGdvZkZkVWNoZlFoUmgxaFZhbWNlYVVnc2NWZVBlamdvY1lnSmhDaHdkZWhGYW1hSmJoZFhobWdWaG1jSGNtYVlicGZlaGxocGZWYWJhMWZwaEhiSGRSZzFkVmdVY25kUmFyYWVobWhNY2ZiTGZ4YTloYWNBaEZnNWVrZlJkRGRsaDJnV2hGYThjVmZhZ1dhUWFLZ1FhaGdSZkRjSGZHYkpkc2FiZlhnQWZIaFFlMGQ5YWNlZGRYYUFmT2FkYzNnZGQwZVZiemdSYlJoVGZTYUFnRmJGYlNoQmZHZUdjM2UxZExhY2F3ZHRiSGdZYWhnVWhhYVdiVWc0ZWNiWmhqZWRlTmFQYjJjcGF5YVVjWGhkZlhhU2FoaFpmcGZZYlJmWmJGZ2JkeGZoZE1jWmZtZEZld2hWZVdjOWRhZFJleGYwYmRkVmZWZG9iNmVaYVNjb2d4ZUFlamQ0YUVnV2J3Z3RiQWFJZ1ViSWdrZk1ieGRNZkdhZmVEYllhaWhjYUNjNGdZaFhobGJrZGthSmF6ZDRoemJIZkFib2hHY0ZhSGJWYndhSGMzY3RhNmVPaDFidGJaZ1dhUmFCaG9hVWJHYzlmdmFFYVJoTmN2ZFJjM2JNY1RlUmgyYWdhVmVTZEZmQmdQZVJiR2NaaHZjVmNnZlZkcWZMZ2xlRWNqYVhna2ZZZ1doWWZUY01lV2VCZVdjWWNFYVpjamFwZ2hkSWRsYXhhamdXZmdnNGRkYVFnUWRsYVNiR2VXZk1jdWJiaDBmMGY0YlJld2M4ZkdhV2dDYTBoZmhlaERkb2ZYZERkRmZJZHNmUGNoaHRhUWNNYmtoTmhaZllobmZKYXdhY2RFYWhhRGdTZVZkcGMxZGVmQWYwYTRnS2dHZmxnZmREZTFjRmRMZmFmRWQ1ZEZmY2doY0ZhQmhZZTBoY2Y4Y0VhMWZwYW9hQmhFaFJhUWVEZXhhQmg3ZmNnZ2ZKY2RhSWN5ZEVhcWRJYzFkZGZCZkZlbWFSY3NoVWcyZ1ZkOWFGYUNjTmRtZGZjM2FCZkZlYmQxZXhnQmdIZlJoVWFhZVVhbmg1ZTJlZWFuZEZoWWNmZ0VlSWVVZFVmaGdsYU9iVGNIZFpmMmdVYmtjSWdWY2VhSGNZZFNlU2F4ZWhmRGRXZ1diSWY2Z2NmSGd0ZlZkUWN4YTBjU2VQYUNmc2d3ZkloM2ZwYWljVmYxZVFiZGNYYkJmVWhMaFRmMmg5ZGVkQ2dFZVZhSGNjYXhmTmFIZ2FhQmhWYkloVWhFZWNmUWRaZG5oSWZFaFVmRGQ0Zm5jQWZ6ZGxmWGhRYmxibGJwYWFkd2hzY1ljZGN3Z1pkK2diYTJoMWR3ZUhnV2Y5ZUVjV2VoZDFnU2hWaFZjUmF5Y2FkM2VJZXJjVGdXYmRnV2ZEZHpkOWZSZU1jQWVSYzRnSmVoYzBiVmJIZFdkcGE2Y0VkbGVNZVlhU2dWZGtnd2FlYjNhbGI4Z1NoQWF0YVNhY2ZIYVZmNGNTZTNhZGc2ZGFhVmVkaFpiRWhCYmtlMWRBY2tjbGJGY0VoUmhOaHZhUmgzaE1kVGRSaDJjZ2JWY1NlRmFnYkphSGdqZlloZ2dHZFVkRWVsZEpkZ2JnY25iRWhrZFJlRWdMZ0NnQmNTY2NkU2NoYkFmZmZtZFpoOGZjZEJmTWc2ZkZkQWZSZkpiVmRCZG9hY2FkY0dlTWZ1Z2JiMGEwZDRjUWdnYThmSmNPZ21kUmdNaGRnbmhaY1NhUWZoY1ZjNGdkZ2hmSmJMYkdlQmRFZ2NmTmNpYWNhaWNQZ2tiaGhMZFlhMWVwYTFiZWVFZHRiM2JlYW1kbGVYYldiUmFBZVpoYWdBYnRnRmNQaFJoRmNQZU1lMGhjZGVjR2R4YU5ha2hGZlZjbGdjZlJoMGFRZ3VjT2J3ZlVoYmFKYWpnY2ZmZk1nQWhNY0NoSGUyZFZmTGRGaGhjaGFtY0ZlR2JaZm1oWWRYZUJjVmJiZDFncGhIZEhkUmUxZEVlUWFHY3hocmFmaEdmTWhaaEljZ2hKZWNoS2ZVaFFoWmZUZUdlbGIyZ1hjMWhNZFZiY2VuZVloYWJXYlFlMWFXY1dkV2Y5ZHlhSmNEZ2dlQmhFZERkSWdPZkNiSGZoZkFmZGgyZ3RlZ2FWZTBnTWRRZVRmU2JCZ0NmRmhoYlJjRmJiZWthVmFIZWNoeGhOYUhiYWFCZlZlSWNVZEVmY2VRaFpkbmJKY2ZlRGRrYkJmeWJVYVhjZGZYYlNkaGJaY3BiWWhSYVljWWJPZ3hoMWhxY1RmR2NGZXdhVmdXZjlhYWhSY3hkMGNkZ1ZnVmhKaDhkSmhYZVFlemFIaHlnVWNmZVFjQWVaZUpkTmdBYmxkNGRKaEJoY2FEZ1VhUmdFZTRiUmRsZW9oT2RMYXpieGVpY2JjM2NBZDJiSGJRYzBkS2dEZmpjd2MzY0JjWGVkZHlmUGJWZnRmWmZRZGhhQmFvY1VkR2U5aHZhRWRSYU5odmNSYzNjTWhUZ1JlMmhnZVZoU2ZGY0FlVmRFaERnb2h1ZVZlbmNoaGlmSmZsYzFnM2FSZVVoWWFXYVBjU2hsZWZiU2IyZ2hkWWhJaHlkZ2ZtZEpiQmExZW1nUWdXYTBhZGhIZFZmVmNTZ2RjR2Z0YzZjWWEwZzFkcWRTY3dhOGhFZVVhVGhaZ01nUGYzY1pnUGRRZ2tmRWR3Z1BiMGFFYXdkVGNEZTVoWmdQYW5mSmc0YkplQWZBZEtoR2dpY0VlaGVlZUViQmQzZGFieGRSZlhkUmNRY3dmWmNjZ0FoSmhlaFJnUmdFZ1RnYmgwYWRjemdFZTBoZGZvaEZjVWhoY1FmUmcwY0lkamhKZWdhTmRIZ0phSGRKZUNoWmhVY0JhY2hEYW1hbGduY0ZnbGFGY21lQ2UyY1pmeWRjaDJjbGFCZGRka2ZwYldhQ2FnYnRnRmVVZmloaGZyY01nMmJOZFhjYWVnZUlnVWFlYkJhQmJrYVRnSGRaYzJiVWZrY0lmVmNlYUhiWmFQZFFkaGVSYXBmV2hXaEpmeWFjYUhkQmJJZ1FlMGJsY2FkZGNYY0FoRmhlZFNkb2c3YkdhQWExZ2ZnVGZUYkZkYmRBY0dhRmJEYVZhaWY0ZURoR2hsYTBnVGdlY1FjTWNxZk5oVWhjZk5hWmdqZFFoRGVXYXlna2VtYUdkRGdnZVpnU2JoZzRmOWhiY1JiWmhLZGJoeGVRZzloVGJHZEZmd2RWaFdjOWNhY1JheGYwaGRnVmNWaEpmMGRhaHliaGRqYkViVGJaZ0xmWWRsZXBjRWhhZEVmeGJrY2VkbGdJYVdlWGNUZ0VmbGhIY0FoZGdkZ0RmUmY0YjJiT2JuY2xjcmJZY2tnTmdKaFdibmhWYTRoU2YzYWRmNmJhYlZhZGdaZEVhRWU4ZHBmV2NVaFVjbWJFaFFkNWV2ZUVnemF0ZmFhRmFCZU5hQmZTY0ZndGFIZkFhUmR0YXlhQ2hoZVZlaWhKYWhoa2QraEJmRGhGZENhRmZHY0VhS2VCYUdjWWhNYmJhM2QxZUxoY2JGZlZhdmhXZ2tjY2ZkZUhlVmFWY1NlZGJHaHRkNmdNYVFiZ2YrZUhmbGUwY2NkRWhIYmRlZWNZZVdkQmhLZVFhaGROZjRoUGR4Z0phVWJHY0ZlZGFMZWVjMmZaZnBlWWFGZ2xhVWFYZzBhcGgxZEpiRWZzaCtnZWZuZU5jWGZFZEFhc2d6YWFnQWN0Z0ZlYmN4YkVjVGJiZTBoZGh6YkVleGVwYWhmR2FXaEpjUWhSaHhnQmJtY2NmbGdZZlZhYWJuaEphUmdmY3hnbGVFYVJhamhzZnVmUWJsZ2NkeWJUY1RnWWNqZWJieWJJY1FlTGVoYzRmdWRVYTBnbGRHYVFiQmdnaE9kZWZuZTVnTmZMZkJoNWhCYkVnVWdRZnRmQWR6Y2hkMmFXY2hkWWNaZ2VkQ2dRZGJmU2MwYU5ocGJXYldlSmJ5YmNhSGVCaEloUWEwZ2xmYWZkYVhkaGNMY0phVGc4ZTlhQWdnZHRmZWFHYVdiQWZoYlJhV2I4Z1JmRWMyYjljSGhjY3hiTmRIaGFnQmVWaEllVWhFZWRjQ2JaY2lhNGJLZEZnUWFkZzZlQmhYYnRhWGRYZmhjcGFwZU5nVmI1YlJnTmFSY29kcWRJZ3lnOGMzY0FlU2hkaFRkU2h6Z2NjZGZWZ1ZiSmUwY2FnM2VwYWpiVGZXZHBkTGZEZzFiSWNRYVpkQmFnYStjUGd3ZEVlNWNRZFFnVmUyZlRmbWVFZ1loUWMxZGxhaWZjZm5iQmN3aFNlRWFOZEpnV2FuY1ZmNGNTZzNiZGU2Z1lkUWRNYVJlV2ZVZW9jVGJYZDBlVmFrZkViUWZJYVNoUmIyYjhhUGRSYTNmQWdjaFNjQWV4Y3RnRWRHYVpoeWNWZmhoVmNxZ2NibGRGZDNlVmgwY29nV2hhaFdhRWFXaEdoR2I1Z0FjTGVpYjhmeWJDaHdiRmV2ZFVkVWFjZVBnWWdGY1ZmT2dhY0didGRyZWRkVWZSZnFmRmh5YVZiU2NFZ0dkUmFNZ2RnbmNaZ1NkUWVoY1ZhNGJkZGhmSmdMY0djRWhOY1phYWRpY1lmNGFPaFJkc2Y0ZkhnVmhwZCthZWhGY2djS2NlZW5jVmdMZldiUWRJZE5hWWVTZkZiRmhiZ3hkRWdUaGJjMGhkZHphRWIwZmRhb2JGZ1ViaGFaYlhnRGNwZW1oY2VsZFliVmhhZm5kSmdSZGRmMWVkYUtiU2EyYUJjdGZQZkJoaGNtZEZiR2JaZm1nWWRYZUJnVmNiZDFjcGFQZFVieGJNZkZoQWNEYnNhL2dOZ1RoY2RVZE9mZ2E0Z0JiQWRGaFVnbGdDYUJlOGI0YkJmbGhFZkhoR2FoaE1jU2ZWYWhiZ2FGYURhQ2h3Z3hnSmhEZmtkSGJEZVVjbGRTaEljWGdSZExjSmdYZU5kcGZEaEhoTWVRZkdjV2FnZkxoUmdXYzhoUmhFZTJjOWVIZmNoeGNNYVZoTGdVZ0VmZGFBYmdna2VRZmJkbGNoYVdhRmJXYnBkeWdVYlhmZGRYZ1NiaGFaZ3BhWWhSaFliWWdaY2thWmFtYU9lamMxY3djT2FHY2NkT2RTYXhmMGNKYVdjVmZJZmdmSWh6YU1od2JRZXlhWWJPZ1FiUmFWaEVjTGRFaFZoNmdYY0ZoSmRDZEZoWGJoaDJlRWZraHNnWWZRZzFibGFpYmNibmRCYXdhUWZCZWNiQmRFZXlnWWREZ0hod2VwYjZkZGNVaHRlWmNBZWdmMWFoaENheGZsY0ZnRWNSYU5odmNSaDNjTWFUY1JkMmFnZVZiU2NGaEJhSGNFZUdkWmh5YVZlaGYwYytoT2doYmdka2FMYkJnNGhXZ1lkbWZFZUhnWmJXYVljSWFlYW1lWmV3YlpnbGZ4aHZhQmFtZTBjZGVIaFZoVmVTZmRiR2J0ZDZnWWEwYzFkcWRTZHdiOWhTZkVkR2NSYk1hZmVpZkliYWdDYzBmWWhEZkloaGdKY0FoR2ZGaEVka2NZY21jNWhzYmNiRmhCZ0tjU2dRZFplZmdlZ0VhdGYzYWVnbWFsZFhmV2FSZUFiWmFhZkFjdGFGZ2JjeGJFYVRhYmd4YU1kN2hXYWhkUWFUZFFjVWhoZGJjUmV3YU1iYmZXZEZoWWZWZmFlbmZKaFJnZGUxYWRiS2FGZW1hbGhoaEZlaGZGZDlhUGhtZlpmbWhZY1hiQmhWZ2JmMWFwYkhiSGhSaDBkSWVXZTNiaGRCYmVkbWFOZk5kYWZrY3NnUGRVZWhjQmFrZlRiSGU0YjRnWGJCYkpoSGVOZnlkSmhkYkhjMGRFY1RoSGVHZHdnZ2ZOY1RlRWFNZEpiUWhVZlZlTmRDY3dmbmRFYm5lcGUwYlZmeGQ5YUZkVmh5Y3RkZmZEZkNjQmhmZkVnMmRjZFRkZmh4Yk1kVmFZZFJnVWVUZ2Vma2hjaFFjWmduYUpkV2RGZVdocGV5YlVmWGZkYVhnU2JrYlFnc2NOZVVlTmVLZ0tnQmFRYjBhWmhqZzBkc2FWZVFjSmRTZ0VjeGhFaGRnUWZWYjVkMGFQZnphSWVxZkhlbWZRZkhnU2JoYXhlWGdNYkFiUmUvZ2VobGhJZjFnR2h5Ym9jemZVZXdlOGZRYUZjeGJFZnJkSWNYZ3hhd2FIaEVnOWhKZVdhMmdWZzBiU2IyZlZocGJaZ1ZkZGJOZEdmUWZKZ0NhQ2QwZFZndmRFZVJnTmV2aFJjM2NNZ1RiUmJ6YVVnY2NSZkhncGRIaEVhR2daZHlkVmdoY1ZocWJjYWxjRmEzZFhod2dRY1lmT2VUZ05kWmZUY0NibGJBZ1BoemNZZGtmZmJnYWNkcWZHYXdiTmI3Y1VnUmNvYVRmSWhBZ2toZmJZZDFlQmFxYkRhVmNvZGNhVWF6YkFnRmFPZ1RnaGVTaFNoa2ZGaDBkZGFrZ0JmQ2ZHYUJoaGd6ZFlhbmFKZXdoY2JFYmhnRGZTYlZncGQxY2VkRWV0ZDNlS2NDYXdnRGVEYUVjSmNYYmFhRmdsYUZjTWcwZTBkVGVBYWtnOGNuY0hkMGdkZDhhR2ZVZ2diRWVEaDFla2gxY2ZhQmhwYVFnSmJEZVVlRmRQYzFlNWRHZEZnaGQ1YnZlUmNGZzBobmNVZEdoNGF5YktjVGNrZEdhWWQxZW9oVGdFaFJnMWJVZFFoM2FoaHJjYWFIYkJmQmFhY2xnOGhHZ1NmVGhwZWtkVGFIaFplMmRVZ2toSWZWZGViSGhZZVNoRmNoY0ZnUGVjZDJkSmF5YmNkSGhCYklhUWgwZ2xmYWJkYlhkaGREZU9iWGhRZTVoQmVSYlpkRWFWZGpjeGRTYUZhU2FvZ2ZlUWNTZG9hR2dOZTNkY2RJaFBlVmVjYkVmRmdTYnRiMWNaZ21mOWVXY1VnemQ4ZjhiRWNpZE1nZWFCaFZlaGZwZGFlVWVJY1VoWmVrY1pmdmZaYWpicGFhYVZiV2Y5ZWFlUmV4aDBjZGZWYVZhSmUwYWFhM2RwaGpmSGF5YzhhZmdXaGdnQmdlZFplQmE1YjJmS2JnZzVnQ2dlZEhnQWZpaEhma2RzYkFhVGIxYWtmMmhPaGpoa2ZqZlJhZ2g4Zk1nRmFEYkllc2FBZjNnNWEyZWFkU2VCY1hjUWNsaHdncGhUYzBhMGc3ZVdkVmZvYThhU2IzY05lSGFTZzJnZ2FVZldoRmV4ZEhnQmRYYlJoK2FWZmdnMWVqY2FoWGh0ZjNjVmUwZ29jV2NhZVdmRWRXYUdoR2VZY1VkT2gyZzlidGZXZGxnVmd2Y1dna2ZjaGRiSGdWZ1ZlU2ZkZ0dldGR5ZUxoVWJNYjZoR2ZVZkFnR2ZYZnpnQWZWZ0pmamFOYmNmRWFGY0FmNWFNY25kWWJFYVRlUWRFY1ZhSmh4aEFnVmRjYkZnVmNEY0Rod2g4ZjdjT2h4YThhK2hOYVNlZGFYZ1VkVWdRaFZlYWRGY2xlTWViYjBnb2I1ZmJkMGFkYnplRWgwYWRlb2dGZVVhaGJRYlJieGdCaG1iSWFCZk5lQmFQYnlnQWFmY2Rod2ZWY0tnU2ZqZFZmaGNlY3hkQWR5YUdoR2NaZCtnYmdYY0FmQmVKY3hnTWZVZkVoMWhFaFFhSGNEYU1oL2ZNYm1ncGRCZmFkamd3ZEJoQWJGY1VhbGhDYUhiNGRpYkdoZ2d0ZUdhZGRIZlpjR2hSZXhiaGVDYlNoR2Q1Y3ljWmRXYkphRWNRZTFiRmRUZmJmbGFKYkxkZGEzaHBjcGRWZjFoa2JRYkdlV2RnY0xlR2RHZFllZGFPYldjOWdIY2NoeGNOZ0hlYWJCY1ZiSWFVZEVhY2dZZEtoSGV3YkdkUmJ5ZVVnbWJIZ2ljTWJPaEdhbGROZW5nTmFrZFJiUmRNZWxoRWNUZERjeWY4ZmtlT2JRYnBoYWNXZGhhMWhiYkFmQmF3ZjNnUGN6aE1ic2hBZjJkcGJEZFdiMWM0aFFjTmdrZEJiMmNQZjFnNWFDYVVmSGdGYjJmU2dXYkVnWWFRYjFjbGJpZGNobmRCZHdmU2VFYk5jSmNXZm5kVWZ4aERnWGJkZHlhWWNWYjhnTmFFZkFjUmZvZ0FiQmNGZW1jSGFSZE5hbmdGZ1hmTWJPZVJnM2dnZlZiRmZGZEFoVmZHZ1dmcGd5ZFhkbGJ4Z3FmYmIxYkZlbmdWZXhmWWFXYkliR2VnZWFoR2hHYmRlUmRiYTJnOWZoYUtnM2g5ZXZiV2drYmNkZGhIZFZiVmFTYWRlR2F0ZTZoWWgwZjFlcWFTYjFia2RUZVFhbWhRY0RiZGZtaHRlU2ZMYjFkUWRzZ1BoaGJ3aGJnVmh4YVJnUmRjZEhlNWV3ZWFiRWhoYUplU2FSYU5iOGVlYUVhWmUzY2FlM2JKZTlkV2FSY0FmWmZhYUFndGdGaGJkeGdFYlRmYmUwYmRiemNFZjBmY2FFZEhnUmh3YVlhRGFrYU5mcWVjZ2dmSWFaZ2FiaWJCZWRlZGN4ZzVlR2dGYWljWmR0ZkZjZ2RoaHZhRGUwZ3hhbWFZYlhnQmRWYWJkMWZwZ0hjSGdSZjFlVmJVZm5kUWYyYlVmR2JOZE5lYWJrY3NoUGJVZGhlQmhrY1RiSGFaYzJiVWRoZFJmVWhLaG5hWmNhZVNjd2NWZkRoU2VHZzVjWWNjZEhkQmhJYlFiMGVsaGFmZGVYZGhkTGRkYjNhcGVwZVZlMWFsZGVjR2RYZ1VoTGNWYlhjUWY3ZUVjMmE5aEhkY2J4Y05iSGVhZUJjVmJJaFViRWNjYlFjSWREZzBkRWVGY1djSWVtY0dlVGc0ZEVkTWZVY1FjVWhZY1Fic2JZZWRmQWNGaHplWmhtZ2Rod2RBZVhkUmZhaFRnQmZaaFRhVmVVYTVkMGJJaG5icGJsZVNiMmNwZERlUmYxZUljYWdlZlVkeGNrZlllMGJSZ0xiRGVuY2hmL2NPYkVnc2RZY1FkMWNsZmllY2JuaEJkd2dTYUVkTmZKaFdjbmhWYzRlSGR6ZThiemZPYWlld2hMYUVjQmNKaG9jUmdUZ2hodmhEZUJjTmNuaEVoM2dNY2NhUmF5Z0FoY2hTYUZjWmhIZEFnbmZOY25mVGJUZDlicWRjZGxiRmEzZlZoMGJvZFdkYWZXZUViV2ZHZ0diWmZHY0lhemdJYzBnSWJoZ3RidmFDY0VjY2FXaEhoUmF4ZkpmWGVtZHRjNmdZZDBkMWhxY1Nmd2Y5YVNjRWJHaFFmUmZmYTNjcGc0YlFoaGFWZTRoZGFoY0pmTGNHYUVoTmNaYVlibmVvZythZmNoaGdkUmZCZGdkNGY2Z0xhQmFJYW5iUGEyYmNmQWNDaDFibGROZkxlWGY0aHNkSWdVZ1ZieGFDYWtkZGJ1aEVnd2ZFYjlkV2J3Y3NmRWVEZmxoOGRvY2NobGM1Y0JjWmJuYUllRGdlZDFjY2ZEZEdnbWJrZWtoSGV4ZGdlOWNQZW1mWmVtZVlnWGNCZFZlYmcxZXBiSGVIaFJoMWZWZ1VnamQwZXRoZWVtZXRhRmNZYmhiOGZQZVRoeGVCaHZkR2RIaDlkNmdVZGtocGFIYmVmR2NzaFNkV2Z4YWdlZmVXYVRhQmc3Y2ZjSGJCYUFhQ2drZ2xhSGRkY1dmaGFMZEthM2dvaGdoWGJsZlVlUWVHY0NmMGVDYlRkR2Q5aEthT2dXYTlhSGhjZ3hmTmZIYWFlQmdWYklmVWZFYWNlUWdaY25mSmhXZ1FoeWZzZWdmVWJUaGhhWGNWZnhiWWhFZ0lhRWJKZ1FjYWdFZVFncGhNY1dkbGVpYVdlV2I5Z0NmUmR4YWNjZGdIZUZhdGcwZFphbmVwZ3loVmNrYUJiTGVEZzFlSWVRaFpjRWZ4aDJiZGNsY0poQ2ZGaFhlaGcyY0VlaWFjZlFhRmd4YkVicmRJZVhmeGZ3Y0hmRWM5YkpjQ2NIZ2xoNGhBY25ndGc2YkpibGJ0ZFpjQWNCYkJmemRJY1ViVmR2Y0VmUmZOaHZoUmQzYU1mVGNSYjJlZ2hWZVNoQWgxZHRmRWhHYlpheWhWYWhoVmJxZWNobGZGYzNjVmEwZG9jV2FQZ3lmQmRFZEdjQ2E0aFViZWUyYllob2JjZkZmaGd2ZFNoMGJzYjNhSGhWYVZoU2RkY0dmdGc2Y1lkMGMxYXFnU2F3YjljU2RFZUdnUWZDYmRjbWZ0Y1NmVWd3ZDVnU2NkYWhhSmhMYkdjRWNOY1phWWFuYUpod2FjY0VhaGNEZURmeGFVYm5mZWVFaE1mamJNZGllQWdFaElja2FJZVpkWWR3Y3NkTmNFYmhiRWhPZWJjMWdWYm1jQmJrYWRodWZGaFJleGRMY1JneGcxZXJnT2NsZlloTGZkaDNoSmRCZGRnMWdGaE1lRmdtZEVkdmRGZmhoSmc3ZkZkSGNSaHplZGMzYmxnT2hiaDFmTmd0ZUhkUmgxY1ZjVWZuZ1JkcmVlZW1hTmJOZWFha2dzaFBlVWFoaEFod2JCZ0RkOGVsZEtnUmZBZFZoY2IzaFpmYWNOZWhhaGVlZldiV2VvZ21hY2hIYjliSWZEZFVjQmdhZWNmM2FoYVphWWNtYjlneWNmZVZoa2JRYkdjV2dnYUxnUmhXZjhjUmVFYTJhOWVIY2NjMGJFZkNmUGVFYkFmYWJIZmtlZGdDZlpmbmRsZldjWGNIYUZkWWNVZlhhZGRYaFNlaGVaZ3BlWWJSYVlmWWNaYWtobGV2Y2Fia2h0YndlVmhXYzliYWdSZ3hjMGVkZVZlVmJKYTBjWWd6YlJjdGJIZVRnZ2NFYVdoeGQxZ0VhUGJSZXdlemJlZkFmVWVRZVhoQ2R3ZHphWmR5YUpjV2FGZTBmRmhpZmJiM2hBYTJiSGNRYzBoS2JEZ2pkd2czYkJhWGFkYXljUGFWZHRmWmNRZ2hmVmFvZFFna2F4ZHZmU2NqaGxmdmRSZTNoTWJUZFJnMmNnZlZjU2dGZUJjSGVFZEdlWWhnZEVmMGFFZC9iSWJCYTloM2RYYTJoQWhXZmFiV2JFZ1doR2FHYllmVWZaZW1jWmNoZ2NmRmdWaHZhV2NrZzlmSmZIZlVhaGhTYmZkemg5Z3pkYmEyZ2RncWhTZHdiOWVTZEVoR2NSZk1nZGNuaFpmU2RRY2hmVmc0aGRkaGVvY1pjR2VGaDVmWmhjaG5nSWJzaGNjQmFwYktmUmhYY0JlMWhlZ0VjdGYzZWVibWNsYVhkV2RSZkFhWmZhYUFkdGZGYmJnMWJnZlRoTWV4YnRiemdmYzBhOGQ4ZFhlUWVFZ0RoU2N4YUFieWFmY2xjWmFIZlpobmdKaEFnZWIxaGRhWWFBZTNieGV0Y0ZhZ2VoYXZiR2VFaHhmbWhZZlhkQmJWZWJmMWVwY0hoSGVSZjFoVmVVZ25hUmVyYmVhaWgxZ0RlSGRqZkpoL2FOYzNnUWViY0xoUWhRYUVmTWR6Y3RocWNDZHdiTmZpY09mM2VjY3hiTGNXYklndWJMZ0hhQmZBZUZlMGdsZkhoZGdSZVVjS2NJaHplSmhuaEVnUmJWY2ZjVmJqY29lRGhFZVdjWWZZZUhnMGdWYkhiY2h4ZU5oSGZhaEJiVmhJZ1VoRWJjZVFkWmFuaEpnV2NGYldiSWFtaEdhVGM0ZkViTWRVZlFhVWdZaFFkc2NZZWRhQWNGZnplWmRtZGRod2JBZFdjWmdXaGJkUmUwaGRoVmhWY0phMGRhZjNhcGJqYlRiV2FwaExkRGMxY0ljUWJOZWtjeGc5aGRla2FOZ29hRmRYaGhnMmRFYWtjc2JZZ1FiMWNsZmlkY2RuZUJmd2FRZFZkaGdqZldhbmRWZjRiU2IzaGRkNmZhZ1ZkZGVaYUVmRWdSaGhnQmgyYzlhdmZFZ1JoTmJ2Y1JhM2RNZ1RkUmEyYWdhVmVRZEJiNWRKYlFiRGVRZTllQWZsaG9oK2JLY3dkRWN5YldjUmExYUVnSWhEYlZoVGdiZVFjOWNhYU1lbmNkYzNnSGdEZUJldmRSYzBnZGZiZVNkQmVzaFJhSWNDZ0lhMWJMY1VmMWRpZkhid2ZOZVNhUWFtZGhiTWJQZzNhOWVTZ0dkVGE5ZDRiZGhoaEpoTGhHYUVjTmZaZllnbmVKZndiY2JFZGdiUmNEZ0FkNGFnZ0tkZ2FWYzNnY2NrZE5lWGVXZFJnQWdaZmFnQWF0ZkZiYmd4YUVjVGNiaDBiZGN6Z0VjMGg4ZThhRmZWZFZlUWZUaEViUmJ2ZGZibmZ3Z1ZiYWduYUpmUmhkYzFhZGRLaEZobWdsYWhiRmFoaGhibWZGZ0dnNGUwY1lkV2cxZFZlZmUxZm9iYmRIZ1VkOWNjZlhjbGE1YXJhZWVtY05hTmhhZmtjc2RQYlVnaGhCZmtkVGhIZ1poMmNVYWdlc2hWYkpiQ2hvZlNkSmJ4Y0FmWGNFYlNjc2NoaGZkSGZBZWNkVGEwZGtjSWhlZlhiaGFaZGViM2NwYi9oUWJraHdiRGFEaEdmUWZMYlZlV2RZY2RhT2NXaDljSGVjYXhkTmVIZWFjQmVWY0llVWZFYWNlUWVaYm5oSmJXYVdoMmZRY0dhS2dBYWNmeWFMZm1ja2hJZEVhMmVSaDVlSGQyZHNhVmZFYXhhRWFBYU9kaGcwZHVmYmJSYzBmZGRWYVZlSmYwZWFmM2RwYWphVGVXaHBkTGZEYTFhSWRRZ1pkRWJ4Y3BjZGJsYXBmS2ZRZVRjQWYvaFFoVGNCZktnUGhsZGxnL2djYW1kSmFsZ1hmVWFOYVBoV2dpaEZjeGJSYjNoZGN5ZlBlUmQ4Z1FoUWQyZEljNmVDYzBoNWh2aEFhR2M1ZHZmV2RuYk5kSGRSYjNnWWRMYVZhbGZCZWZhR2FXZjlnWWRWZGhhVmhxY2NkbGVGZTNoVmQwZW9jV2NhY1diRWFXZkdiR2hZZ1VmWmNuYnhmaGhIZjFmMGU3aEVlZ2I1Z09nRWdWYlViR2FlZEdmc2hvZGJiMGIxZnJhV2J3Y1piZWFPZG1nUmdNYmRjbmdaaFNkUWJoZlZmNGRkaGhlSmRMZEdkRWROZlpkTWVIYUpiN2VjYkZkcGJwZ1NjVmFwYjFjZWhFYXRhM2hlaG1mbGJYYVdiUmRBZFpjWWFSYkJidmViZHhmRWRUZmJjMGRkY3pmRWYwYmRib2RGZFJhVmdaaFNhemFwZm1lY2JsYVllVmZhYm5hSmhSZGRnMWZkYUtnSGJpZ2RhdmJSaGthb2NwZlFlQ2FrZXlhT2JDZEFnUWhZYlFmMGZWZlZkRWZrZlFkSmd4ZzBlbGFMZ25jSmJiZUNoQ2I0Z1BmVGF4aEFoaWZHZVRnZ2gxZEJlZ2R0Z2FhTmJuYllnYWhIZ3hiUmNEZUNmMmg1ZnllT2NYaGxlSWNHZkdiTmhhYWRoWGJoYkxhZGMzZnBlcGdWaDFia2ZRaEdnV2VoY1pnQWNEYnRlRWFRZ1NjRmZIYmViemNsYUhlYWFCYVZoSWJVZ0VmY2VRYlpibmZKY1djRmJXaHBjeWhVaFhnOGREZVNoZ2d0ZXBlYWdrZUljUmNhYmpmNWJtZVpkbWdGZXdhVmZXaDlkYWNSZ3hkMGFkZFZlVmRKZzBkYWMzY0lmeGJUZlhiZGdMaEhnMWhKZU1jWmFCaDViL2hlZ25jaGdDZUZkWGJoYTJmRWNrZnNkWWZRZzFlbGNpaGNlbmJCaHdlU2JBYnBhSmFCZ2ljbGU0Y0pkM2g4ZHVjSWJSZTRhS2hIYkJka2Q4YUJjMGdVYjlnSGZSYk5oOWJTZTNkTWNGYlVjbmYwYkdjWGVWZ3hhSGJBYkdjOWcrZGZkQmhWZ3FmY2NsZEZoM2FWYjBnb2RXZ2FjV2RFaFdmR2dHZ1liVWJLaEdiZ2FWaENlU2VVaEtnUGJqZmhjOGFiYXloY2V6YURlUmRRYkpiRmhqYzBiYWZKY0hhMGJtZk9obWdSZE1jZGJuY1piU2NRZ2hlVmI0ZWRiaGRKYUxnR2VFZE5mWmFZZm5iSmh2ZmNoRWVCZUxhSGdSZkloOGdLZXphQWJsZ0JkMmdsZktkV2FVaFFiWmVkZmhlVmhiZGJnd2RraGFmWWIwaGRkN2JSaHdlOGNoaFJoamhNZ0NnUmZ4YnRibWFZY3lic2NWaGRjM2ZKYkRmWWdrZ0phS2ZFZEdna2IxaEhkeGhGYU1mRmdHaFplbWFZZFhiQmRWZGJhMWFwZ0hhSGZSaDFjVmZVZ25hUmRyYWVhbmdsY05iQmNVZE5lYmdHYWxoa2EzYVFnSGhZZGljWGRrY0pmSGRkaEhjWWRUaFdkaGJGaFBlY2gyY0poeWdjZUhhQmFJZVFjMGVsZGFoZGZYZ2hjTGdkYTNmcGZwaEJkVmVrZmJhR2ZYZm9iaGhSYldiOGhSaEVlMmI5YkhjY2d4Yk5oSGZhY0JhVmNJYldnVmZ3ZDZlWmVuYUpjV2RGaFdlcGd5aFVhWGFkaFhkU2drZHRmZ2JiYVRhd2ZZZFpkaGFSYm1oWmhtZ0Zkd2RWZVdjOWRhZ1RoMWVNZ1RhQmRRZkFoN2JQZXplVWQzY0ZnRGFvYk9jQWdRZ1ZlQ2ZMZFJkZ2V6Z0FmemNzZ01lUWhXZXRma2RmYmllNGJZZFhkbGNrY2tnSmN6YjRkemJIZEFkb2hHZ0ZnSGRWYndkSGEzY3RnNmFPZzFmdGJaYVdlUmNCZ29oVWJHZjljdmVFZFJmTmd2ZVJmM2VNaFRnUmUyYmdjVmVTYUZkQWFWZFZjVGdJY25nQmhGZ3RocWRlZG5jdGMzYVZhMGdvYldlYWNXYkVkV2NHZ0djWWJVZVphbWFaYWhjY2hGaDBjN2FXaGxkb2RkZUZhZ2dGYWJlZWNFY0ZiNmZZZzBnMWJxZVNkd2g5YVNkRWZHaFJnTWhkY25jWmNTZ1FlaGMwZHFkZGZnaDlmTGdDZ0VkTWZGZVlhaWNCZDVhZmNHY0phRGJTZlZlcGgxZ2VlRWR0ZjNjZWFtY2xhWGVXY1JjQWdaZGFoRWZKYkZkTWUwYzBmVGRBZDBoOGRuZ1dhd2I0YTdlR2NVZWdhRWNTZnhhQWEwaGZibGRZZEJiWmVuaEpjRmFaZFVhNWZlZERoM2Y5YTJkQmRBZEZhemdHaEdjWmIyYWFjSGN4Yi9iYmgxaHBhSGhIZVJiMWFWY1VobmZSZHJoZWNtZE5lTmJhaGtmdGVCY1hkR2RRZ2RlUGRCYU1jU2dMZlNjTmRuZkNhaGJkaHJhTmJHZHNjMmhLZlJmSWVkZEFhZ2NSZGliUWEwYmxnYWFkYlhlaGFMaGRmM2dwYnBoVmUxY2tiUWhHYVdnZ2JMZVJnWGhBZlJiR2YyZWNnVGhPYjFjb2JVZ0VmMGhkYUlnV2YwZGNiRGZHYTNjSmRMZUZjVGM1ZXlkVGYyZmxlSmdTZGdiUmQ5ZWFkQmdvZnljWmhoY1JmbWZaY21oRmR3ZFZoV2g5aGFjUmh4aDBoZGVWZlZnSmQwZmFoM2RwZWpoUmNUZzRlRGRSZmdhRmVyZE5ia2Z4aDlkZGdrZUFkL2VGYVdhVmgyYVJja2RzY0dhWGhVYWRoaWFZZDJlWmc1Y1JkR2ZsZkpnV2NuYVZoNGhTaDNjZGE2ZWFhVmRkZVpkRWZCZGxib2NDZTBhVmN2YkVlUmFOZ25kRWF6Y3RmYWdGZkJhTmRIZlNjRmZ0Z0hnQWNSYnRneWFTZXhoVWIrZWNha2c5ZnBnU2NVZm9oT2ZZZEdnMGY4YkdmR2ZZZ1VkWmZtaFphaGNjY0ZlVmR2ZFdoa2VjYWRoSGZWZlZhU2JkY0dndGU2Y2FheGJrYWliQWFsZXdjcGdRZWhlbGVNYmFoM2ZaYUFkVmZ3Z0JjNGFjYkJmSWFmaEVkVWhwYXphWWVuZUpld2RjZ0VhaGZEYlNjVmNwYzFjZWRFZ3RjM2hlYm1mbGVYZldjUWFvZ1poQmhnaE1jUmZKYTFmaGdBY1lnMGdjZ25lSGEwYWNnNmZHZlVmaGRSYlZmeGdsYXFhV2JGZlliVmVhY25nSmRSZGRmMWNkaEtkRmZtZGxlaGdGZ2hhaGFtYlJobWFaaHRhWWhXZVJmL2hiZzFjcGdIY0hnUmExZVZjVWhuY1JhcmJlZ21jTmFOY1lnMWZBZmxhVWNoZkJka2hUaEhnWmcyZ1Vna2FJZlZnZWhDY3NkYmhSYXpjSmFEZldlV2FKZXlnY2NIZUJjSWZRZjBhbGRhZGZhVGVaZ0ZiSmR5aGdjbWdBZ3hmWmhFYlFnRGZoY09kU2d6ZWhjRGZXYWphc2JDaEJobmVvZkplUGVBYlphYWFNZ2ljSWRRYmVhM2NJaFFhUWNDYVFieGRCYVRkNGJZZ0JnQmFaZ2hoTmRSYW9hWWVOaEJoaGRtY0xjMmNoY3dmRGJrZVZmYWJSZXhmMGVkZVZkVmhKYTBiYWIzZ3BoamVUZFdkb2daZlNhZ2haZUZhTmdnZEpiMmVmZW5kaGVDZUZkWGFoZDJlRWNrZHNiWWRRZjFhbGdpYmNlbmhCYXdmU2FFaHNhZGhXYm1maGc0ZFFiQ2ROYnpjWmFYYTFhWmhFY0JmbGVvaENmMGJWYXZiRWJSYU5idmZSZDNjTWVUaFJhMmdCYkhmU2ZFYzFoSGNBZUdiWWR1ZFZha2JkYmpoZmVuY3RlM2NWZjBjb2RXZmFjV2hFYldoR2JHYVliVWFaZm1lWmRoZmNnQmN4Y3ZiQmRoZHNoZGdjZVZmMGNHZVBiQ2VJZ3BhYmgwYTBnK2dSZXdkOGRBY0hjR2FSZFloZWVuZlphR2hVZEFjeGhzZWJmd2dSZGNjQ2VsZHBjTWJiZm5kSmFnaGVkVWdSYnBoU2JWYXBkMWJlY0VodGczZGVlbWJsY1hiV2VSYUFoWmVhZkFhc2dMYllnV2FWZnFoSGh5aElhWGFiZ0NiWWNhZlpjeWFrYXBoT2RHZE1mVGFBZmloWmM2YUdlQWZaZTdlZGgxZWRhS2JGYW1mbGRoZEZkaGhoYW1mRmJHY1phbWVZZ1hoQmhWYWJiMGhWaEhlRmJSZFVoQmNHZ2pnMGc0Y0FmVGVFZHdhYWFsZ1lnUGJCZmhiQmU2YVVibWJoZzJkUWNGY1lkY2dkZUZhd2JTZ1NjeGZoZ0RkV2JXYkpneWJjZ0hnQmRJZFFoMGhsY2FkZGNYZmhhTGJkYTNlcGNoZ0FleGJGYlpmU2doYk5nWmNSY1diUWNSZEFjaGJKZUhoYmdoZ01nVGVhZEFmdGJXZ1Rka2FjZkJiY2JIYnRlYWhQYjJlcGZ5ZlVkWGRkZFhhU2ZoZ1picGJZYVJhWWFZYlpnaGJSZm1mWmdtYUZhd2JWYldoY2RPYURmMWNSYU9jTGdnZUJkMGJZZUhkcGJ4ZU1iR2hwZ1diRGZ3YllnUWJlY2xoSmdvZmRia2ZwZUxkR2dWY0poMmNFaGtmc2NZaFFjMWFsY2lhY2JuaEJjd2ZTYUViTmVKZldjbmJWYzRhU2EzZGRkeWZQZVJhOGJRY1FhMmJJZzZhQ2cwZjVldmhBZm1hNWh2Z1dibmdNZEJhVWhuZDBkVmJUZ2xmQWhUY0djV2M5Z1llVmdoaFZicWVjaGxiRmgzZFZoMGhvYldkYWVXZ0VoV2ZHYkdlWWZVZVpjbmJ4ZGhjSGdsYjBmN2JFZWdoNWhPYkVoVmZVZkdlZWJHaHNkb2hiZjBiMWZyYVdiZ2haZGVmT2VtZFJnTWhkY25iWmRTZlFnaGZWYzRkZGhoZ0pnTGRHZEVlTmdaY01kSGZKYTdmY2dGZXhncGJTZlZkcGUxaGVoRWN0YzNjZWRtZmxlWGFXZ1JjQWNaZVllUmNCZ3ZkYmd4YkViVGhiZTBnZGd6ZUVnMGhkZm9oRmZSZ1ZiWmRTYXplcGZtZWNnbGdZYVZnYWZuYkpnUmNkZDFmZGJLZ0hkaWFkY3ZjUmRrYW9jcGNRaENma2F5aE9lQ2FBZVFlWWVRYjBiVmFWaEVha2JRZk9iemNvZC9kRmdnYlpjTmdkZDBidGJKYUJmMWM0Ym5kR2hEZDhoNWJIYkVlSWdkZ0xoSGFvZFNiR2dSY1JkRGhFZ0doNWZ5aE5lWGNsaEljR2dHZk5iYWdkYVhmaGhMZ2RmM2VwY3BiVmMxYWtoUWZHYVdnaGNDZUFmMmg4ZVpkR2cyZWNnVGJjY3dnNWdIZVlhMGVGZ0JoWGhFaGNmWWJOZ0hjSmNMYkZhWGZwZ3lhRGFYY2NhRmFRZHhlcGhwZVllRmZNZ1JjYmV4ZVFiOWFUZ0diRmJ3ZlZiV2E5YWFnUmR4ZjBmZGhWZlZmSmgwZGFjM2ZwZ2piR2V5ZnNnWmdEY3hkMGJRY2VoVWd3Z2JnTmV3aFljS2ZHaHliZ2Y1YlJnVWRNZ0tlVGMxYWxmNmRjZm5icGZ3YUFmVWhOZEVmV2FtYlJneGFVYkZmMWU2ZWFmVmNkY1pjRWdCYmxib2JDZDBmVmV2Y0VjUmNOZXZkUmN4ZjhlYmJFYXlkQmNjZUdkMWV4YkhjUmVHY3BjeWVCZ0JnbGFxZU9lMWIxYTNlR2FFaG9kYmhhYlhlQWhhYUdnR2h0Z2JkYmYzZzFkTGRjY0ZkVmN2Y1dka2JjYmRkSGNWZFZjU2dkY0dndGM2ZlBnbWRkZXFkU2N3YTloU2dFYkdlUmVNZWRkbmJaY1NhUWZoYlVndWROaDBkQmhMYVVjRWFOZkVoWWZtZ0piOGhXaGtmaGZEZ1NoVmhwYjFjZWFFYnRmM2dlZW1lbGRYZFdlUmVBZlplSmVnZHRlWWNiZ3dlQWZmY1JhVWFkY3poRWgwZWRmb2NGZ1VoaGNRZ1JieGJCY21iY2dsZFlnVmdPZ1hlSmFNZmRiMGdkZ1JlUGJHYWxhaGdGZmhmaGdtZ0ZjR2VaYm1nWWFYYUJjVmhiZ3hod2VJZVRmeGExY2RjQmdqYXdjaWVLZFJiZ2dmY0ZmMGZzZ1NmVWJnZEpneGRXY1hlWmN3Z1VoaGhZZU9jZWdIYTBlWmJBZ3hlaGZmYldjU2J0ZnlkZGNuZlplSWZTY3diZGFhZmZlMmVWZExkWmZXaDllL2JYZ2tkSWVRZEVmRWdJZkxnUmJXYzhkUmRFZDJhOWJIZmNheGdOZUhjYWFCZVZnSWhVaEZnY2hRZ2VnSGZJY0NlRmNXZnhmMGZVZVdjZGVYZlZod2Z0ZjBnWWRVYlVkWWFZY0JoSmRtZ2RkbWdGYXhmU2NIZkpnYWZFZzFlVmFVZ0JoaWNrYW1oYWEzZEZkamdCZVdlcGJHZ0RjMGNOaHRkWmdFZnBmd2hkZWxob2ZSaEZmV2dWZzJlQWUwZ0liVWVhZFZkbGhpYmNlbmJCYXdhU2ZFYU5iSmZXZG5nVmc0aFNkM2ZkZTZnYWZWYWRnUmhSZ0ZnRWRoZFdmRGM0YzlmRWFSZWhjdmVEYndiNGRUYVdibWhnYWRhUWdGZmdmVGFFaEdnbGJ5YkdiQmJ4Y3FnYmJFaDlmM2RSZzBmTWdXY1plR2VGYUZnRWdXZFlmU2ZaYW5kUmMwYlpjVmh4aDBoY2ZFYmNkZGJIaFZmVmVTaGRlR2J0YTZhWWYwaDFocWNTZzFlMGNYY1JlRGNFYmVoT2FIY1llQWdRY2hkNWI0Z1Bnd2VsY2hlR2FFYU5jWmJZZW5iSmh3ZmNiRWJoZ0RkU2RRaGRnOGVkZEdlRmMzYmVnbWVsZFhoV2NSY0FiWmFhZUFjdGJGZlplMWg4Y2RnUGZ4YVVkOGhSZXdjZ2g4Z1RjQmRnYlZiU2ZVZmNhMGJPY3doSmRRY0FjemN3aEZjRmFUY0pnS2ZDZzJma2huY1FjMWdZY2xhUWhDZjhocGJMYTNoQmNkY09kMWFaZ0hkVGN4aEZlVmVHZjNnaGVyZVBiMmVwYU5kTWNXZUVjUGVVZGhiQmdraFRhSGNaZzJlVWZrYUljVmVlZEhlWmdiZURkUmVoY0xjVWJXaG9mbWFjY0diMWFJYlNiQmUxZ1RlZWFYZWhmRGVKYVhmcGMwZVZlMGZrZVFmUmRXY2hjWmRUZUdoTWRSZUVhaWFwZ09hZWFoaE1iY2JRZWhkVmVJZFViRWFjYVFnWmRuZEpmV2JGZldkcGN5YlVoWGhkYVhnSGVGZ2NkN2NZZlZla2NZaGVmeGdRZUxoSmF6ZFVlNGNXaHphOGhWZEViQmFVaFBnV2VWZ0pic2NhZDNnQmFqZkJjR2VwY0dnRGIwaE1oWmhmZDJoWmUyZGRkbGhKY0NmRmZYY2hmMmVFZGtmc2dZY1FhMWNsaGlnY2FoZXhnNGRIaEFlc2RBZENoWGVsZDRkSGQzZXRlNmNPaDFjdGZaYldhUmdWZm9mUmRFYlZmaWZFZVFhSmZqYlJlM2U1Z2NkVGFuZ01nL2JTYUZhQmFIZkVjR2NaZHloVmRoaFZncWJjY2xmRmQzZENlbWNBY1dkYWRXZEVjV2VHY0djWWRVZ1pobWVaaGhoY2JGYVVmNWNHZXhkVWFkZlZlVmRWY1BiZGNDZ0pkNmNiZ2tlMWQ3ZFJneWVWaFNkRWRHYVJnTWVkZG5iWmRTZ1FkaGVWZjRjZGdoaEpoTGdHaEFnMWFaZmZjM2NKZ2hiZmNHZkplRGNTYVZhcGExYmVhRWJ0ZjNmZWZtZWxjWGJXZFJoQWhaZGFiRmdoZEZiY2hoYUVmRGZkYUdlMWJ6Z0VoMGdkZW9oRmFVZmhiUWZSZXhiQmdtZGNibGRaZFRmSmNTYUJnUmZmZndoTWNDaFhkemZvZWFhUmhCYmhidGFGZkNhNGdiY1ljV2gxZlZnZmFVYTloU2FIY1JmdGJWaEJlbWQ5YXJhZGQyaDRnRmVhZWxkVWhTYVVoZ2dCZ2tkU2duaEJnMmhXYWdid2ZWZGNnbWZzYlNkV2FRZjFiVmhVZUhmbGh5ZmVoVmRwaElhUWQwY2xjYWRkZVhjaGVMY2RkM2RwZHBoVmExZ2tiUWVHZlhoZ2ZMYldmMmY5aEZkRWYyZWxoQmNjZndlTmdIaGRoUWdoZFZlVWhCZFFhUWZZaEhiUmVXZUJjV2hwZHpmVGJHZ3BkWGFIZmxnNGdnY01mbWMxYUtnWmRoYjlobWNMYW1iRmY3ZlZiWGY0Zm5iUmZ4YXNhYmJWZVZhb2FuZWFjMmdkYmpiWGhHY05lSGZKYlZiSWJRZVpmRWN4ZDJjZGVsYUpmQ2hGY1hiaGUyaEVka2NzYVllUWgxYWxmcWdKZmpnZ2E1YUdiemhnZmJiV2ZuZjVhNGJBY3dmcGY2Z2RmRmVkYVJnR2hCYkVjOGJDZTBncGV2aFhkeGRwaHZkV2JXZDBnVGhWZjJiRWRWZlJjVmRBYVVjR2JXYVpkMGhWZ2diZGUvaFpmMWhoZnNjZmRVYW9lV2RhZldkRWFXZ0dnR2dZYlVoWmFtYVphaGFjY0FiY2dxaERnaGZKYlBoVWcxYVVlQWZkZEdnQmg2YUtjbGRaZkFhU2R3YjlkU2JFZEdlUmdNZ2RjbmFaYVNiUWVrZmhjeGFlZGpiaGNMZEdiRWdOZ1pnWWZuZUpid2JjaEVjaGFEZlFiUmNSYjdhS2RCYmtmNGJMYmliWWNEY0FoRWhCaGNiWmJsZXdmWGVKZ2tkVmRXaEJkZ2drZG5hQ2UwYWRjMWNGYlFoNGZGYUNhVmFNY3llT2d4ZGxiYmVhYW5kb2JGYWVkMWRjZ1lnR2RtZ2tob2RIZnhiZ2Y5ZlBnbWJaZW1lWWdYY0JhVmZiYjFkcGVIZEhlUmgxYVZlVWVpZFlidWZMZGpmWWRmZ0pjRWdzY0hoZWZCY0Jla2dUZEhoWmIyZ1Vka2hJZ1ZkZWNIaFlmU2RTZHhoaGZEYlVkVGVaZ3llYmZYYUJkRGRGYzBhQmRXZ1hiM2JoZkxmZGQzYXBjcGVWaDFka2VRZkdlV2ZnY0xlUmZXZDhhUmhHZXpnMWZIYmJlaGhOZVhkYWZFZWxiSWFBZGtiNGVjYVRhSGFKZ1dlRmVXYnBmeWZVY1hjZGFYZVNnaGNaY3BiWWRSaFlhWWNMZHhmUWE2YU9jbWVFY2NhWGdUaHNkU2JEZ2tiNGRSYVZoUWdaYzRjYWZ5Z2hjdmFUZVhhdGhIYkRmMGRNZENnY2gwZEJoMmhlZjBnTmZRYkRkWGVGYTZmT2ZFZXNiWWRRZDFmbGZpZWNjbmVCYndhU2NFZk5jSmFXZm5oVmM0Z0JhWGhrY09oRWRDZmNhOGZkYkdhWWVKYmVjVGZjZE9nYWRHaHdnY2JNY2diTmVqYktlQmNwYmhkU2RBY3dlYmVFZ0dmNGNtZFZlZ2JoZXFjSGV4Y0FlamNIZjBlUmJRZEpiU2Y1Z1poU2dtYjVnQWdiYjJjOWV0aFdmbGRWZXZoV2NrYmNmZGRIZFZiVmFTZmRoR2N0YzZkWWEwZTFncWdXZ3dkOWdNYUVmRGFCaE1nY2FIYUJoU2hTZ2tjRmQ0YmFmeGFKaFpiRGVWZ1pjWmFhYlhhSWFrYWNnRWJOYkRmV2ZGY05iNWRVZGtjdGgzaGVjbWNsZ1hjV2ZSaEFnWmhhZEFndGhGY2JjeGNFYVRnWmV4Z01oN2dXYWhlUWVUZVJnemRWZVFjV2FoZEJmMGRaZDBlTWhWY2JhSGNJYkZjZmFsZnRnZ2VGaG1hbGdoZ0ZiaGRoYm1jRmdHZVplbWRZaFhkQmhWaGJlMWdvZFZhSGdSaFpoVmNRaDFlNWVyYmVhbWJOZk5lYWFrZXNhUGJVZWhmQmFrYVRlSGJaaC9mU2NXZWdjVmFlZ0hlWWZTY1NmeGhoZERkV2NXZEpoeWZMZFhkbGNFZmFkVWZsZ2FmZGdYZmhoTGFkZTNncGhwZVZnMWJrZlloVmEyZVpoYmFGaHlhQmNGY1hoRGJzaGVmSWYxaFpoSmJQZTBoY2FCYUJiQWVKaDVoS2RDZ1phSGJBYXdmWWNYZFVhV2ZwYVhhRGRFYU1ibmJJYmtjSmVSZUtjVmZwZ21iYmZqY1ZjOGZWZ1RmMWJXZlJlMWFRZ1VhVmRRZmxlZWhhZzNicGZqZFRlV2dwZUxhRGIxZ0lhUWVaYUVmeGQyZ0pkQmNjYldmUWZDZm9nNGNFZmtoTWd5Z1FjMWhsZGloY2NuZEJhd2NTYkVoTmNKZVdmbmRWZDRjU2QzY2RneWJQaFZjZGVFZ0VmQmZJZThjQWZrZGxkRmdFZVJhTmN2aFJiM2RNZFRoUmEyY2doVmRTZ0ZlQmJIaEVjR2NaYjZhQmFCYlZkM2RjZGtjRmQzaENoMGNwYUVnWWdHYTBmOGJHYkdmWWhVYVplbWFaZmhoY2dGZFZldmFXYWtoY2NkZ0hmVmZVZ2JoZGVEZGNibWZZaHlhRmdpYkhnMGZjYmJkUWcyYmhhTWNJY25icGdTY0VoQmFsZDRiWmVCZTVnTGFDYzFhRmFPZ2RiR2FWYThjY2JFZFZkUWJXZTBnMWJqY1lhRWRKaDdhVWdHY2xlWGZXYlJkQWhaZWFkQWh0ZEZkYmF4ZUVkVGFiZzBlZGh6Y1hhVWNrY2NmYmFEZmdjMWdJZzJnOGdIYkFnQ2dSaDBlRWh3ZjBlaWRBZ2ljY2g2aGVlUmRzZFZlUGZCZmhobWVGZEdhWmdtZFlhWGFCYlZjYmMxZnBkSGZIZlJlMWZWaFVhbmNSYTBlZWRtYnRjRmJQYWdjTmZHZEFjV2JzYjJnTWFYYVpjcmFVZ2xnQWJBaGJoWGhZY1VjU2EwZXhoS2hWZVdoSmY2Z0phRGFnaEJoRWFEZklkSWFkaFhlTmFMaFplZ2hkZXBhU2VsZmxiRWRHaFhhWWJWY1dkMmg4aEpnR2ZtZlpmdGNjZXhjTmdIZmFlQmhWYklmVWhFZWNlUWFaYm5mSmhXZ0ZlV2FwaHlmVWZXZTFnWGZKaFJnNGU5YUtkVmM5Z0xlYWVoZlFleWRhY21iRWZpY1diV2M5ZGJnVmN4aFFkUmJmZjFiSmgwYmFhM2JwZmpoVGFXZnBmTGREaDFoSWRRaFpkRWJ4ZzJlSmRGYkpiSmJGY1dmcGhjYUVia2ZzYVljUWYxZ2xoaWFjZW5lQmN3aFNlRWFOZUpmVWYyZzVoU2hTYTNmZGU2YmFhVmhkaFpnRWFCZGxib2FDZ3hkaGhtY0hkVGVsZ3ZjUmIzY01lVGdSaDJnZ2VWYVNiRmNCZkhjR2FDZmhmOGZCZ2tkY2dsZUpjaGI0YWpnRGhoaHBnVGNaYXpiWmRFZFViVGZKZ1JoRGd5ZGdhMWFZY1VlTWNOaFBnMGdjZ0FjSGNSYk1iSGZPaGlnZ2h1Z0tjZ2VJYWtjU2R3aGNhR2hIZkdmUWJlZGVnbmFZYmJmU2V4Z1VjamhYaEJlSmNMZ0dhRWdOZFpnWWduY0pld2NjZEVoaGhEY1NjUWVnZndmTGdCZDRnbGNOYkdkbGhmYWNoeGZBaFphYWRBZXRmRmZiZXhjRWNUZWJhMGRkaHplRWUwYmRnb2FIZFJkeGRRZFdoaGVCYXRiSmFsYjhiWmJRZ0hiSmJSZWRjMWVkZUthRmhtZmxiaGJGZGhjaGRtZUZkR2daaG1kYWZTYUpmVmZjZmxjcGVYZUhnVWFGYVZoQWRIZjFhbmJVZ0doTmdOZWFka2dzaFBkVWNoYkJja2JUZEhoWmYyZlVia2ZJY1ZkTWZYaFphT2FGZnhjZ2h2aFViVGVZYTZhT2dTZU5kRWVRZHhmMWFXaGRiU2ZwZkhiZGIyZWhmbGhWZzBib2FDZERibmY0YmNhU2VXaDhhY2JBY0hlMWJRYlphUWJ0Y09hWmdEaDloSWVVZ0VkY2RRZlpobmNKYldjRmFXZ3BjeWhVYVhnZGhYZVNobGJoZ25nRmJXZDlnb2VBZzNmQWFaYUJoeGJNZkNhTmZCZFljbGZOZ0diaGF0YUpkVGEwZkdoSGExZUJkamFUZldhcGFMZ0RiMWhJY1FjWmFFYXhjMmZkZ2xkSmJDY0ZoWGZoZDJlRGJVY3NhUWhTZXdlMGNxaE9leWhNZ0xoR2dqZjVnSmdSYTNiVWZzYlNmMmRsYWtmZGIxZGRhQmZHY1JoVmhvaEFjeGZFYm5iV2FFZUFnVWJGY1hhTWRZZVJkM2FsZ29nU2FFZjFlSGdBZm5mTmduYVZkaGNOZXFkSmZsY2hoK2ZmYVVlb2dXZ2FhV2hFZ1dlR2ZHZVlhVWVaY21kWmJoZ2NoRmNWYnZnV2hrYmNjSGFIY1RmcGNhY0liQ2RNZ3poTWJFaEZkcWdIY3dmTmVTZFFkbWFoYU1jZGEyYWRiYmRUaGphOWM0aGRnaGdKYUxjR2hFY05mWmhZY25oSmJ3aGNmRWVoZURlU2NRY2hlMWhjYTBmdGVsaFVhR2FsZVhlV2RSZkFjWmdhZkFhdGNGZmJleGZFYlRjYmIwaDVhb2dPZVVnZGdvZUZoVWZoaFFkUmd4YkJmbWVjZmxiWmNJaFljM2c1ZzdnZGYxY2RmS2FGYm1nbGhoZ0ZlaGVoaG1mRmVHZzRjb2RiYnllQWZIZ0ljQWg0ZklmU2VVZFFlRmJGZDNlb2Q4Z0thQ2hvYlplTGZ5ZUpiQmhCZWdiTmgyY0ljQmVOaDJlVGUwY0phVGVMYVRhaGFSZkhiMWVFZU1oRmMyY0plNmRKZUhieGNJZUVhVWJWYWFkUGdIZkZoTGVMYkZlQmFwZFZnMWVrYVFjR2JXYWdoTGhSYVdoOGhSY0VnMmQ4Y1ZiTmFrYWNnU2ZPYWxldGZJaFdlR2gwY1FnWmRuZUpmV2hGZ1djcGJ5Y1VlWGRkZlhnU2NoYVpocGFZZFJoNWdNaFphZ2NsYm1jYmRUZlZhNWhXY1VhVmdhYlJneGYwYmRjVmZWZUpmMGRhYzNlcGZqZlRiV2hwZkxiRGcxaHBkQ2NaYUZiRmcyZ1pnbGNJY2VkRmdTaHBiL2ZIaG1lRWRZY1FnMWRsZWlkY2VuZUJid2FTZEVlTmhKY1dobmdWZDRhU2h6ZzVoNmdOaFFldGdaY2ZhQmFFZzhoUWF3ZndhOGNIYVJiTWI3Z1NhM2JOaEJmU2YyaGdiQmdSZkZhQmJWaEFkWGVKZmxjUWdnZTFiNWFaZEVmVmRnYVdiMGdvY2JiZWgzYUFiQ2ZEaDNiSWRNYWRkWGhCYjFoYWdGZ3hkamRjYUVhY2hkY0hjVmVWZFNjZGdHYXRlNmdZYjBjMWZxZ1Nhd2U5ZVNiWGFtZm9jNGJEYndhWWgzZkpmbWNvZVphQmJHZUFjcWVZZ1Rhd2ZxZ0Zkd2ZJYkFmSGN6aG9oM2FZZTFmcGQxYWVnRWV0ZzNlZWFtZGxlWGJXZ1JlQWNaZmFjQWd0ZUZiYmF4Z0VkTWdiZDBkOWQ3aFJld2c4YmhnUmhqYk1iQ2VPYWhiQmI3YWNla2dRZUFmZmgzZUpkWGNkZXdlTmVEYUdla2NOaGhnRmRoZ2hobWhGYUdlWmJtY1ljWGdCZFZoYmMxY3BjSGVIY1JlMWdWYlVnbmhSZ2pkTGVpaHNkRWNPZFRlQmVkYlViaGV0aGtoWGNRZ3RiMmhUZDBhSmhCYWVlR2dnYk1lVmZSY2hiYmZVYUdnNWJZZmNhSGdCaEllUWUwZ2xjYWRkZFhiaGNMY2RkM2ZwZHBnVmIxaGtnUWZHZVdlZ2VMZVRoVGJ0Y1pmV2RqZ3doOGFJZlJkTmVNaGFmQWFjZzFlVWRGZW9kUWJNZG5jSmdJZ0NlM2dSZnliUWRHZUZkZWNSYmpkeGNwaFlhUmRZZllmWmhoY1JibWRaZG1kRmF3YlZhV2M5ZmFmUmR4ZDBjZGRWY1ZjSmc4ZFBiemhJZHFoSGdoaEVjWmJEaDFja2FRY2RmemdGZDJkYWUxYUlnV2JGY1dkWmRvY0RiRWRzY0tmVmQxYUJkcmhXYUhnQmJ3Z1NmRWROZEpiV2duYlZoNGNTZjNlZGQ2Y2FhVmZkY1pnRWZCYmxjeWNDZnlmdGhuY1JlVmJzZm1oRmRIYjhiVGJFaDJjUWJWZkdkbGN4ZEhjRWRYZ1piN2hXY2pkOWNxY2NibGdGaDNiVmEwY29hV2FhZVdmRWVXZEdjR2JZZFVhWmRqZlJmaGJlZjFmVmY3Y2NiRWFjZGRlSGFWY1ZhU2dkZ0dmdGU2YlljMGIxaHFkU2V3ZVpiSmdPZW1oUmJNYmRobmVaY1NjUWVoZ1ZnNGhkZ2hkSWRXZUVjVWM5Z3piWWNuaEphd2hjY0VjaGREZFNlVmRwYTFoZWZFaE1hNWVkZURka2hGYkZma2RSZldhUGNGZkloVmdLYWhoOWVFY1BhUWg0Zm5kVmRpZzRlbWZRZVZjdGhDY0pkWGJWZG1oYmUxY1pkVGFQYXpkd2JTYUlmeGU0aEZiV2NHY2xocGFRYWhiUmRtYVJhbWJwY21iS2JIYmxlVmZOZkhiQmhIYUhiUmMxY1ZoVWFuZVJkcmJlYm1kTmZOZ2Fka2Z0aGRmRmUwYVFieGhIYWpkaGMyYVdnbWRnZ1ZoZWJIZFloU2ZTY3hkaGVEZ1dnV2FKYnlhY2JIaEJlSWRRZDBmRWRPZmRnV2ZWYUxhZmFDZjVmZ2NXYTNjTWZRZ0dnV2FnZkxnUmNXYThoUmJFZjJmOWFIY2NmeGJOYkhnYWNCYTBjYWNVYUZjb2JRZGRjbmFJZEtjRmRUZGhmN2FYZVZmMWRYYlNkaGdaYXBnWWNSYVlmWWRaYWhlUmZtY1pnbWZGaHdjVmdTZVplYWRHaDBkRWRkZE9mVmFvZmdiSWd6Zk1id2JRaFdjb2JmZEFoMWdKZkNoYWRFZXhmaWJlaGxnSmFRYkJjR2d4ZmhhQmJsaE1mTGJWaFVjMWExZ2ZobmdCYTllV2RsZ0poZGZUaFdnRmhnZldoR2RGZHVoY2RWYzVmVmdPZGhhbGVvYkNmMGJWY3ZkRWJSZE5ldmFSZTNhTWNUZFJiMmdnZlZkV2hGaEJoWmVFZkRkSmR5YVVhQmROZ3FoZWJnaFZhM2FTZWtmb2hDZmVkM2RnYkNoQWhYYUFnRGRkZkhnOWUwZWNnRmM1ZnZlRGZrZWNmV2dIYVViUmJiZmVjRWNGYzZhWWcwYTFlcWFTZXdoOWFTaEVkR2NSZ01lZGJuZlpnU2RRZWxldGcyZEFobWZzaDdoZmdTZWNnbWdBaHdlQWZDZ0VjVGZFZThhT2hpYzhoRmhDY0NiUWNGZERna2FOYlhjV2dSaEFmWmZhZUFjdGRGZWJleGNFY1RhYmYwZ2RmemNFZzBhZGhvaENna2VoY1ljVGcwYlFodWVPZHdjVmR1YU9mQWE5Z1JnYWNsZGNmZWRGY25hZGMvYUNkQmJoYzBiQWZHYzlmcWhTZDNkQmdWYWJlMWdwY0hkSGFSZjFnVmFVaG5hUmJyY2VjbWZOZU5jYWNrZ3NhUGJVYWhiZ2F3YkJoRGQ4YmxmS2VSYUFiVmFjZDNiWWNEZ05laGZoZmVnV2NUYlpleWdiZm1nNWFXZVFhMWFoZE1lZmNIZVJhaGNkaDNicGFwY1ZiMWZrZVFkR2FXZWdoTGZSY1djOGZSZEVjMmE5aEhhY2Z4ZU5lSGNZY0VjRWVBZUdlUmZSZHJmTmZIYkpoZGdGZFhhZ2RQZ1VlV2ZwZ1hjSGVoYlpjM2hmaHdoZ2hZYWZlaGMxZXFlVGJHaEZhd2NWYVdjOWVhZVJkeGUwZmRhVmFWaEpmMGRhYzNocGFqZlRiV2FwY0xnRGcxY3BnRWhMZkFlVWhsaERjUWdCY0NjSGhuZWhlbGNiYTBmc2RGZFFkMGN0ZTNhWmYzZ0JnMmZTY0JnZGdBZ1VhMWQ5ZDRlU2YzY2RlNmNhYlZiZGFaZEVjQmNsY29kQ2UwY1ZhdmVFYVJkTmV2ZFhkWGhOZTlmVGV6aHhkZGRBZ1FhTmdMaEVkRGdKZytlVmhrZ2RibWRjYmxjQmRtZVhka2hZZDhhYWRXZUVjV2dHY0dnWWJVY1pjbWVaZmhnY2VGZlZhdmVXaGtlZGhQZ0hlVmc1aFNkWWRFZ0ZiNmVZaDBhMWNxaFNhd2c5YVNkRWZHY1JjTWFkZ25jWmZiYVdnVGc5YzRjZGZoYUplTGVHY0ViTmdaZ1lobmhKYXdoTGdVZ0ZoUGVZYTFjcGgxZ2VhRWN0YTNlZWdtZWxlWGhXZ1JlQWRSYUpnZ2JVYVZiUGJWYTVmSGJJYUJhTWJxYlFkd2JKZm1lUWhoZW9jWmJFYTFnVWNBY1BhaGRsZlVoUGdoZTRlMGNkZDBncGJLZFVoRGF3ZXZiVmVVYndodmdXaHljaGdtZ2FnU2NSYlpiYmZ3YmhnTGNIZFZoUmhjZ1VnaWU5Z0JnZWRtZE5mTmRhYmtic2hQZFVoaGFCaGtjVGFIZlpnMmFBYkFhZGJCZ0xkU2VSaGNmU2QxYU5iTGVEaFNob2U3Z0lhM2Z4ZEliRmcwZ1ZmYWhKZjNoUmFMY2RmbWVwYmxhVmF4YUFoWmFBZ2tiSWFMZFJnV2Y4YVJnRWMyYzlkSGNjZ3hjTmdIZE5nUmZ4Z0VhZWhrYmNhUWZaYW5hSmRXaEZkV2FwZXlhVWNYZGRnZmRCYkJkZ2c1YU1iMWZsZE1mS2dVZ0FhL2VOZ2liUmUrY0FoamMwYVRnRWMxZGhnN2FHZVJiMGIxaFBneGJnZkdiVGVYZ2RhTGNTYVFjZGFlZ0pleGdnZy9lT2ZSYnhoQ2RIaFNneGI2ZkViaGRrZFVoUWd4Z0JjcmRjaGlkdGhhaFNmRWhOZkpiV2duZlZlNGhTYzNmZGY2Y2FkVmhkZVpkUWdsZHdmOGNYZWhjY2JoYUViVmZoZG5oRWV6ZXRjYWNGZ0dmUWZWaEhhRmR4Z0hmUWJtYnBkeWdWZndnUmRtZmNlaGJoaCthVGFHYkFoV2RhZldoRWRXaEdnR2NZZFVmWmJtYlphaGJMZ1ZkeGdqZWNhRWFjZmRnSGVWZFZoU2hkY0dmdGM2aFljMGYxaGlmQmhRZkVlQ2RRYmlnc2ZZYU9hU2VJYUxkRWRsY0JiMmZJaFVlQWJDZ1RjQWZZYTlkTGdTY2NleWNQYkFmMGR2aExnRmVwZW9nZWFBYjBnaWZOZkNib2VEYkVjRmY5Y1hlYWdBZ01lUmZZZHhoRmdCZVlkMGFjZjZoR2RrY2NiemhQYzBoaGhRZVJoeGJCY21mY2dsZFllVmNhYW5kSmNSaGRjd2NVZ1BlUWZqaHdoemRXZUJnZ2RzY0hiRGFJZXVoS2VDZE5kWmFiZXdoNWNMYUhkVWM5YVpkVWVuZFZhN2hkZ21oTWNFZVlnMWRBY2xkVWNoYkJja2NUZ0hlWmMyZlVoa2ZJY1ZnZWFDZ3NoYmJSY3plSmFEZVdmV2JKZnlnY2NIYUJjSWJRYjBkbGRhY2ZhVGJaZEZhSmZ5Y2dhbWVBZHhoWmJFZlFhRGZoZ09mU2N6aGhhRGVXZWplc2FDZUZlMWZ3ZlNoS2dsY2tlTmFNYWlkSWFRaGVnM2hJZVFjUWFDZVFmeGhCYVRoNGhZY0JhQmdaZ2hoTmVSZW9hWWhOZ0JlaGFtaExiMmZoZXdjRGFrZlZiYWNSZ3hhMGhkZVZnVmhKZjBnYWYzZ3BiamJUYVdob2haZVNnZ2JaZ0ZkTmFnZUpmMmNQYUZlb2VXZFhlVGdFYWxlSGVrZXRnTWJUZTFka2d3ZGZhbmJCYXhiV2VVYjlmSmVFZDNleGdqZ1lkWGhkZjZiYWhWZWRmWmdFaEJkbGdvY0NnMGFVaHlkR2hCZTljRmJSaDNlTWJUY1JlMmJnZFZkU2dGZ0JjSGJFYUdjNGE4ZVdhRWdVYTRiUGZRaFVkNGhBZHhoTmFHZExoR2E5ZVZhVmJ6ZFphTmFaY25ndGZoZU5iZ2dBYmhnR2dSZk5iVWNVYmhhdGRTZmZjRGc5ZTJnWWh4ZjlnbWRTZTBkWmZlZEVnQ2hGYkZjZGhpZzFlNGJRaGhoVmQ0Z2RjaGNKY0xhR2JFYk5hWmNZZ25mSmV3Y09kUWQ1Z0RiUWFYZUJjMWRlZEVkdGUzY2VobWRsaFhoV2hSZ0FkWmJhZkFmdGNGZWJneGJsZmFiYmZ4ZnNodmdFZjBhOGhoaEZiVmRWY1FoVmZ4Z2xmcWRXY0ZjWWhWaGFobmFKaFJhZGUxZmRmS2RGYW1kbGhoYUZhaGJoZm1mVWVXY1loNmhQZ1hkQmhGYmJkMGVkYWFkQWJCYjBjUWZVZmljZ2MzZ2VnbWRzZklmYWVsaFlkUGRCZWxkZ2Z0aEhoM2VnZTZjRmR3Z3hlU2VMY0RlNGRiY1JhemdKZ0RhV2VXYUpmeWhjY0hjQmhJZFFmMGhsaGFiZGNYZmhhTGhkZnliaGNwZFNiVWdRYVFhVGFXZlpiSGhBYUNhRmhXaFJleWJkZ0hoZGdSZVZoSGdZZEVmZGdJYlRjVWJkZUVnYWJEZTRhVGJXYnllMGRtaEdoWGE1YmJoWWZCZlphcGhZaFJiWWVZZFpoaGNSaG1kWmdtYkZnd2hWY1dmOWFhZkZiUmIxZEJhQ2JWaEpiOGJPaFhjcGgrYVRkWGZwZUNiQWMzY2dnUWdaYkVkeGQyYWRjbGNKYkNkRmdYaGhkMmdFYmtoc2FZZ1FleGV4YmlnYmdIZEJlZ2FTY0VlVmJQY1djamZ4ZjRlVmRYYmNnL2FhaFZlRmhmZ0VmQmJFYnRlQ2MxYmhkdmJXYkJmcGNqaGJmWGJNZFRnUmIyaGdhVmhTYUZoQmVIaEViR2JaY3loVmdoYVZhcWVOZjFlRmFxYVNnbGFjZldjSWdHZmdnOGRHZ0dhWWZVZFpibWFaaGhmY2JGYVZmdmhXZWtnY2RkZ0ZmSGg5aFNiZGNHY3RnNmRZYzBjMWNxZlNld2Q5ZlNoRWRHZFJnTWhkZmliUWVYZEZka2dBY3FnT2NCZ0plYmdBYzJnbGVaZVlobmJKYndnY2ZFZmhkRGZTY1ZicGIxZWVkRWNzYitmUGVHYmxjZmZTZ1JkQWhFY2RnUmFaYkZmT2V4ZjloZmVLaGdna2UwY1Jhd2U5aG9nU2NSYlJlUWJWaHhnQmc3ZGJoMGRzYlZkUGNqZ29mWWdKYkZka2RHYlVleWdjZW1jUWJsYkJjdmRGZERlUWdqZ05mU2ZVZUhiSWRWZXBmWGRCZWpoZGRWZVVkbmVSZ3JoZWFtZU5iTmNhaGtoc2VQYlVoaGhBY3RoQ2huZVpoK2ZRY2toSWVMY2ViQ2ZRZGJkU2UwZndlTGJDZ3lkMGNsYWNlRGc0ZU5jRmNFaGtkb2ROZ0RoWWZNZU1jaGc4ZjdkQmJSZFpiQ2hFaFdjcGVmZ0JoRGUxYVdlVmhqZXNmMGhKZTFlSWZWaFBjQmdVZEhmQmNSYk1kUWFLZlRnUmhXY1ZoeWZVYW5iSGh6ZE1nRWRTYkJoOWF5YVNieGhZZFlnWmRoYVJobWNaZW1oRmZ3YVZnV2Q5Y2FlUmExY1JkYmNWZlZkcGFrZ2FiMmhSZ2pnQmRHYm9oWGJVYjFlSmZaZ1pmRmhKZnJoZGZnYllmS2FYYUNidGQ0ZlhkZ2g1ZVdmQmFBZTBocWZlYzFlcGh3YVNjRWhOYUpmV2huZlZmNGFTYjNiZGI2aGFhVmZkY1piRWFFZjBjZ2NXZ1Fjb2U0YkVmVmQwZ3FoRWRIYU5kaGdCZGlkWmNTaERnVGRVaFZhUWRpYmtlZ2RYaGhjY2U1ZVBjUWFRY2xhRmZBYzlhbGJQYVNkQmJFYlRnR2VaZmJoTWV6ZEpmaGVQY3hiTmN2ZUdkQWJoaEloVWJ4aEVhQmhkY21mSmZoZlNjVWUxaHFiU2N3YjlhU2hFYkdoUmhNZGRkbmdaYVNlUWNsZXdiK2JkZ2hlcGhiZUdjRmUxZFpnSmgzYnRod2NKZUFoQWFSZEJkZ2YxZTFkTmVnaDRlZ2RlaGhnc2JXZkZmMWNkZWNmRGZWYWtjWGFJY0VkTWViYmJoUmVRZzhnUmZoZlVkcmdVYkNnMGNlZkFoeGNBZ3BhSmh3ZkljVmFKYVRoUmRSZk5iUmRnY2ZjV2dDYjBjeWRGYUJkRmI5ZVBkbWJaYW1lWWJYYUJnVmRiYTFmcGRIZUhoUmcxYVZoVWJqY0ZncmNaYUdhTWFaZ0lmZ2dKY2NjWGNGY3dlaGZBYmpiRWVpZkdla2dJYVRhZmZuYlljYWREaGhjaGZlZldkVGNZZjZmT2ZTZE5nR2VEZXdid2NVZk1oaWR3Y0RoZmhuZlpmRGRWYjFka2dRY0dnV2VnaExlUmZXYzhkUmRFZTJmOWZIZGNoeGdNYlRiWmhsZmtjTmdIY2diQmNFZ0xlbmRKaGJiRmhUZ2hmeWFUYVhnY2dTYlNlaGJ0Y3BiS2JCaFllZWZZaEJoUmd1ZUloMmFGYXRoVmNUYnRmVWdDZzFoaGVUZUVmZ2VZZDhoYWIzZGRjamNIaDJhcGFBaERieGdzYVpiZmQyYVpjMmZkYmxjSmFDZEZlWGhoZjJhRWRrZXNnWWJRZzFla2EwZU1meWJKY3diQmYwaDlnamRXaG5iVmM0aFNoM2JkZjZhYWVWZGRjWmdFZ0JhbGJvY0NiMGdVZ25kRWhRZjVodmhBZm5iTWVlY1JheWRFZ09lWWdsYkJnSGNFYkdoWmN5YlZmaGFWYXFjY2JsZkZiM2dWaHdjTmhRYWFnV2NsaENlVWZDZzlnSGJaYm5kdGg4ZmJiVmhVZTdkV2hrZEVnYmFIZVFmZGVTYmFlbWJzZXpkWWQwZ3Ric2NTaDBicGJTYURjbWFRYmVnZmUxYnhmU2ZRY2hkVmU0Y2RiaGNKY0xmR2ZFY05iWmhZY25iSmd3ZmNjQWc0ZE1hR2YxZ3BjOWROaDBjdGRxaGVlaWZGZ1hiVmNCY0FiSWRjZndoc2VLZGJmd2Y4Z09lYmExZmRib2RFYTBjcGFsaFdla2FGZ1FnRWUyZXNmcGRjZmxmMGNWaE9nQWE5YlJnYWVsYWNmZWZYZGllQWZ5YmJkVmRkYW1iSGcyZVlidmFIaEdmdGUvZGJoMWVwY0hiSGNSYjFiVmZVaG5mUmhyZ2VlbWdOYk5mTGN3YmRnY2JGYXhjQWJ0ZENibmdaYytnUWJ3aGNoR2FlZUdlZ2JTYUFkeGVnZGZhQmNXaEpmemNQZm5hNGI4ZE9lamRrYy9oRWdRYWNkcWNCY1FnZ2VJYUxnaWRaY2piYmhCZWhnN2RLZWhiMWhsZ0dna2JWaEhjY2F4ZE5mSGVhYkJhVmNJYVVhRWdjYVFkWmZuZUpiV2VGZFNnd2E5YkFhM2ZkZmZmQmNSZlpmMGdZZFFlWWJEaFpmbGd4ZG1mZWFHZEVkL2ZUZG1nOWJSY1RiRmJJYVVoVmhRYVlkUGVKaEhhcGNvZFRnVGNnZTJoRGEwYzhoUWRNZ0FnUWcvZUpkU2VraE5hRmJYZE5lMmFXY3plWWFEaGFhVmRsZmlnY2ZuY0Jkd2VTY0VlTmFKZldlbmhWYzRoU2V6Z0loMmFPY2hmSmFaY1piVmNBZW1hWGUxYjBjT2hRYTBlRWZ1ZEhlbmMxZkRlRmJTYWRlQmVCZXdoUWhlZVFnQ2ZOZThlQmFWZkFkK2VmZEJkSWEyYkdkd2FZZmVlUGNXYzBhV2RUY0NlNWdkZU5hV2VnZnljSmdSaGNhdWVDYUJjVmVjZlJjRmQwaGJiZWRHZnNjemhZZzBjWmZxZ0Fnd2NaZmViRWVEZlpmRmdiZlZoeGRTZVFjaGJWZzRlZGFoZUpjTGZHYUVkTmZaaFlkbmNJZ2loTmZSYndoV2dHZHhhUmYxZk1mRmdCaGRmZWhtZGxjWGNXZlJjQWRaY2FoQWd0aEZjYmYwZHdiYWJZZDJiMWd6YkVmMGNkaG9hRmhVYWhnUWFSY3hhQmZtZWVhaGZnZGJkT2VpaEFmZWVJZnhnZ2hlYVRmemZrYWthR2NGYTRodmRXYUNocGZtZWZjSGVBY1RnT2JoYVFnRWZTaFZlUWRhZ0hlSGZSYmpjTGhtYzliTmVPY0VjY2hQYkdieGd4YmtmQ2ZYaDloMmJDZVdkZ2JWaGVkSGNZYlNmU2R4aGhmRGhXZFdiSmd5YWNlSGhBYkJmQmJVYWxoU2hkaHlkc2VmYkphVGJNY25jRWhGaHNlUWdCZkhlVWdMY0VnVGRaZUJhVmVpZEFlQmFjYjBjZGFPZmFmRWc1YmliVWFFYWNoUWZaZG5hSmVXZUZlV2JwaHlmVWZYYmRjWGVTZGhmWWRnY0poeGNZYVFoVGdCYlJlbWhaZW1hRmJ3ZlZmV2g5ZGFnUmd4ZzBiZGZWYVZhSmIwZWFnM2FwZnJnVGJ6YmtnZmZYY1JhdGVlYUllMGg1ZzJmYWIwZDljQ2RRaFNjRWZtZVZkd2VSZWViUWF3Z3RnSWNjaG5jQmF3YVNhRWdOZkpnV2ZuYVZoNGRTZTNkZGE2Y2FlVmVkZVplRWVCYWxkb2JGaEVmVmZuY0dkVmZaY3ZiV2FuYk5lQmNUZW1kUWVWZlFhQWRKYkhhRGZXYVphaWNYaHhnbGZxaGVlaGNoZTNmU2FrZHBjQ2dJY1NnaGdGZEZnaWFwZVJhS2NDYkVmMWZPYUZjeGJtZ2NmRWFjY2RkSGhWY1ZlU2JkYkdmdGU2aFllMGMxZHFlU2h3YjloU2dFaEdmUmZNZWRkbWJ4YlNiUWdFYllic2RKYkZkc2FGZFhmMGRGYVpmZmEyYjlld2RKYUJjRWdUYkRkQmZVYXplZWdBZkpnM2hmZkdiOWFYYlVnUmdoYmNoYWJCZFpjRmJKaGhoZ2RmYWJiMGQ4YzZkRWQxZnBkb2JRYlFkQWZaY0ZnQmU0ZnFnTmh4Y2hoU2hQaGpocGJZYmZmbGZ0Z2dnRmdtY2xiaGZGZWhjaGZtZEZnR2haYm1lWWZYaEJjVmZiYTFncGRIYUhhUWJ4aFZkVGIyYmxlMmdlZmpiZGREYkpkZ2Q1Z0JkRmVVZlFjc2NSZVZieGYyZFVia2VJYlZjZWRIZVloU2NTYXhlaGdEZVdhV2hKYXlmY2dIZGxiSWVHYUdlTmJhYmRkWGZoZUxlZGEzaHBjcGdWYTFia2FRYkdlV2ZnY0xmUmVXZzhnUmdSaFNhNGJWZWNiMWh4ZUhkZGVSY1VlY2JYZWdmUmFZaEpmeWdBZjFmV2RpZjRiM2NNZENiTmRmZFdjaGM5Z3loU2h4aFloWWRaYmhmUmhtZlphbWFGZ3diVmdXZTllYWJSY3hiMGVkZFZlVmZKaG1nZmhtZHhhamJVZzJhb2JFaERmMWJRZ1doWmFFaFFkaWRkZWtkOWNDaFdnbmNGYnRmT2ZFZ3NhWWFRaDFhbGdpZGNnbmVCZ3djU2dFYU5lSmFXY25nVmg0YkZnbGQxZzZjYWVWaGRlWmhFYUJnbGNvY0NkMGZWYXZhRWVSaE5mdmJSYXpncGhWYlJlMmJCYkRmQmd4aGtmRGhFZkhjWmZ5Y1Znd2hoaDNiY2doZ1JnM2dVaFVjd2RXYWFoemZKZ0NoU2ZpaDljYWdJYVdkUmNoaGNmVWdoY3ZmRGdoaDVmTmZXZUJkb2dVZ2RiQ2M1Z3pmU2VVYzFmcWVTZ3dlOWFTYkVhR2ZSaE1mZGduYVplU2JRZGhlVmU0ZWRoaGNJaGZlVWNCZ0ViV2NOY1hlSWgrZk5lUmE5ZERjUGVRaE1hbGhQZVNhNGhsZktiQ2RZY0ZnVWVSZUpiY2ZKZmtoZ2FLZktjMWdoY2RmS2hFZmNjK2JSYWhoUWY4Z0ZnUWFvZlZhUmgxaEZlbWVJZ1FjSmJIZUliemJ3ZVdnZGNWaDVlUmNQYUdjbGZoaEZoaGFoZG1lRmJHY1pibWFZaFhiQmhWZWJmMWNwaEhlVmRGZXRjVmNXZW5hWWY0YkxhamdFaEVhSmdBZ3dhTmRVYWdkMWI1Z1RhQ2ZJZHZmQWFnZ2RkYWJQZW5lWmVYYlNoeGI1YUZmV2VXZE1jOGRmYWpma2RiaEplZ2djYVpmT2FqZndmQ2ZPYVRlMWNoZEVibGRBYVpoTWMyZGdkTGdSYldoOGVSZEVoMmU5aEhlY2Z4YU5nSGVhZUJoVmZJZVVoRWZkYUVmTGhpZ0FmWmNRYm1jb2E4aEZiQ2JCZlhkUGRrYzhnNWhKZEhjTmRLZU5oRmdzZjBoYmRtZk1kRmhHZ3lhUWdVYkNmRWRwZ1RjVmhSaGNoNmRLZERkVWJuYkJoQ2dRZk1iRmRWZ0lhU2RaYkVjZGUyYU1jMWJ0Y1piUGMzY2hhMmJFZGthc2NZYVFhMWFsZmljY2JuaEJhd2dTaEJlNWRKYkhiemdrYXJiRGJuY2RiNGVKY3dlSWVVZVVkbGZ3ZDZiQ2RVZ1ZoeWNEZUJoTWc3YUhnaWFOZFdoQ2FDZjRoVmZIZ0ZkQmJCZ0ZibWFaYjZiQWVoZFZnM2VjYWtjTmVpZ1Fma2VvZlFmYWJUYVVkZmZBaDBjd2FVZVpjbWhaZmhmY2FGaFZidmhXaGtlY2JkYUhiVmdVYWJoTWhtZHRneWVjYjBiMWgwZ1NnMWUxZVNlVGZEZmhlTWVJYWpnNGViZkVmUmFzYzBhTWIxYXdnTWJUY0FhdGNaZ2ZjbmFJYmlhY2ZCaFFnZmZTaFFmNGY5ZU1hUmhoYzVjTmJpYXdkWmVIYWtnUmVSZWFhQmJkY0ZlSmFoaGdnNWRiZTBlZGh6YkVnMGFkZm9mRmdVYWhiUWVSZ3hnQmFtYWNnbGJaYkJkSWhpZ0FnZWFJZEZhY2dFZVViemc1ZmhhWmRGYmtkb2FVZHlkTWNEZ01jeWZJaGFoUGJWYkpmRmJjZ2tnZ2JCY1VkamVzZXRhZWZqaEVlTWdKY0FheGhLZlVkbGVrZXFkQ2ZEY01ndWVVY0Vkc2dPYVVjbmRZZVNhU2d4Y2hlRGhXY1dmSmR5YmNhSGhCYUlhUWh3YUFoY2NkZFhhQWFaZWRmMmJSYzBmVmZ4ZUFkWmNHaFRmcGZPaEViVGhwYkRlWGhXZThmVGFPZDFib2NVY2Noemc5Z0lkVWZFaGNiUWNaZm5hSmhXaEZjV2RwYnlhVWNYY2RiZmRHYkJmWmIzZmZjd2dnYUZjWmZnZ1JldmFhZ2tmdGZ3YVZlV2Q5ZWFiUmV4ZTBoZGhWYVZjSmUwY2FjM2hwYmphVGJXZ0lkQ2JEZDBmOGdRZU1nZ2NNZi9oTWVsZ0pnU2NGZVdmVmhyZURkMGF0Y1JiUWgwY1plaWdKZGpiZ2Y1aEdnMGcwaEZlSGJ6YXNkL2JIYnpiOWI2ZWNkMWJjZ1FlRWFBZGRoMmhGZlVoVmcvZ0dkQmQ5ZEZhUmgzYk1jVGdSZDJjZ2RWY1NhRmRCZUhmRWJHZlpoeWFWY2hmVWIrZWNiZ2EwZHJoVmUwZUpoQ2RhZlhld2FXZ0NnR2I4YlBnVGNHaFpmaGdjaEZhVmN2ZFdla2RjZGRnSGZWYlZkU2ZkaERhMGQ3Zk1iVWQwYmlnVWhDY1ZlU2VFZUdoUmVNYWRlbmhaY1NkUWVoZlZnNGFkY2hjSWNDZ1hla2hOZ1JjWWNEZXdibGVQY1Fkb2RHZEdhMWdoZzFjWmZWZVpoM2JMZGpmQWFIYUhmRmY5YmZjYWJGYjljTWJiZzFnZGJjZFBkVWRkZDdlV2cwYmRnMWRGYlJmcGJMaFJkMWFsZW1mYmdGYlpoZGRjYVhiSmJhaGZmQmc5ZkRmRmJqZjBncGhYZTBmc2ZkYVhnQmd0aG1hZmFIYkFlQmhkZUhoQmZIaEhhUmMxYVZnVWNuZVJmcmRlY21mTmhOY2Fka2Z0ZEtmSGhrZE1maGdUYkNhMWFjZVVja2JJYlZmZWRIZlllU2JTYnhhaGhEY1dkV2NKY3lmY2hIZEFiZWhBZWhidGhhaEphbmNoaFdhZGV6ZVJjbmhIZ2dmcGV5Y1RjQ2g1ZU5kQWFEZDBjWmdSaDJkWmNIZ2JnQmNNZlRkYWZBZjliSWZPZ0VmOWVlZ0lleWVWZldiV2cyZUlmbWNYZlhkY2FTaFFheGVnZjlkTGhtZlZmTWFOZ0ZmMGhvY0lkV2NsZzVkWGVHaE5jd2VSZHhiMGRkZVZhVmVKZzBiYWMzZXBnamRUYVdkcGRMZERkMWZJZ1FiWmVBYTFoMmNhYzFnSWZSZkdjemNRZ3piWGdBYnhlTWJDYTBiSmRJZWNjbmVCZ3dmU2JFZU5kSmRXZG5oVmc0YlNoM2dkZDZjYWRWZGNmZmVYZDBmdGRvZUFnd2UxZ3ZkRGhCZ05kL2dYZUhmTmVhY1JnMmJVZlZnR2VsaEJlWmdFaENoNWZwaFZoaGY1ZWhiT2RsY2hiM2hBYXdiSmJmZE9naGVwYmVhR2dHYjBnVWVOZkJodGZoZWJnVmJVYThlSWZRZDhmZGdHYkZjVWRUaENnWGZCYlFoWWMwYjFmcWhTZ3diOWVTY0VjR2NSZE1iZGJuaFpiU2ZIZnpoOWM0ZWRiaGZKZkxnR2JFY05kWmVZYW5lSmV3YmNoRWFnZFJjRGZBZzRiZ2dLZWdkVmgzY0xjaWhFYmVkQ2FnY3NjemNhYUFmdGRGYmJjeGhFY1RjYmUwZ2RlemFFYXhlcGRoaERkbWFKYVFiUmF4YkJhbWFjYWxmWWFWYWFnaWZRYVFmSmRWYmNmWWdRaG1ibGI4Y0ZiaGFjZGRnYWFtYjBhYWNiZG1hQmdZaGRlamN0ZEtmWmMxYnhhWWhDYkhja2FVZUJnMmN3YktiY2JXaEVhUGZVY2hkQmRrZVRiSGFZaHJhWGVBaEZhVWNOZkRib2ZhYkdoUmVSZkRjRWNHYXBnbWFlYVhibGZCZldoR2VOZ2FjZGdYZWhlTGNLYm5oWmVEZFZkMWRraFFjR2dTYTVkZWZDYXlmeGdGZVdnaWFBaEphY2d4ZHNoVGRaYkJmVWJhZVhnRWhkY1pmYmUzYUlmTmdQYzJjcGd5ZFVkWGFkZFhlU2NoZjRmN2NiZjJkTmh4YkNjR2NCYzFoZGhHZEZodGNWYlNjWmJTY1hjeGNRZlVjV2RWYkpiOGJPZFhoUWFXZkpnQWFRZi9hR2VVZlliUWZlY1Vod2gvZWZoa2Z0ZUxiSGFHZ05lY2NFZmthc2VZY1Fjd2FSZnVlV2VIYkJhd2ZTYkVlTWdQYURhemZzYzdkSGN6ZjRkMWVKYTFiZGZSZ1JkQmdWYm9oV2hVZWxhdmRXYkJicGh2ZEhlRmRrZFRmUmIyZ2dmVmNTYkZoQWRUZkhkaWVNZXFnQmdsZG9jNGhKZGdnSmQzYVNha2FwZk5nYWNTYWtiRmVDYW5md2NVaExkMmE1Z3lnZWNWZ2xodmhFZGxmRWVKYUJiMWFVYmJkZmJIZHBocWVhY2toMGIzYlVmQ2VWZVNiRWJHYVJhTWhLYjNncGY0YlFoaGZWZDRoZGdsYVFmZWRWZGdnQWROYktiemYwZitjY2RFY0FlWGNSYVZmb2RuZWRnRWFzYytoY2cyZ2tmTWJjYnhmQWdaY2FoQWh0Z0ZkYmJ4aGxoVmJPY2dma2J3ZlJod2E0Z25jV2YwaGhjWWFGZVJhbGdtZ0tiWGR3YlZhYWFuZ0pkUmFkaDFhZGdLY0ZkaWE4ZDBiV2RGZnNmeWJYZ1Nia2RvZ1lhVGdWZWRjT2QxYk5lSGRSaGplZGFWZlVobmRSZ3JoZWFtZE5hTmJhaGtlc2ZQZEZhRmg4ZDJhVGVIaDRiZ2dFY3hlQWJWY0tnbmFZaFBlU2QyYU1jK2ZWYVdoSWM3ZmNmR2ExZUlmVWIwYVZmYWNNZEhmaGJXZGRneWU1YW5mR2Z4YnhiZWJYY2pieGJEZlhhbWg5ZVVkRWYzZUZmSGNPY2dkaGVIYkliUmg1ZkRmV2NVY2RoTGhUaEhjSmFXZUZnV2FwZ3ljVWhYZ2RkWGZTZmhiWmJwY1lhVWdCZlpoTmZCYVFlcGJaZ25meGh3YUFlV2FFYlpmRGcxY3hiUGJOZGhnMGd3ZExhaGdzYjNmUmdTZ05jQ2dGY0hjZ2RRaFpiRWV4aDJjZGVsZEpkQ2dGZVhhaGEyYUVna2dzYUpiVWdVZ0ZoaWViZ0hmQWQvZllja2JOY0piV2duZVZmNGdTZjNiZGc2ZWFmVmdkaFpmRWhCZWxmb2hGYkVmVWM5YkhhMGZNZzZhRmREZ3NnYmRDZ0dmRWIvY1NoRmZCZEhjRWVHY1pieWFWYmhnVmNxY2NjbGhGZTNnVmMwY29oTWRhZVhnTWVHYURmSGg0ZVVjZWNHZ1lhdWRXZmxlVmd2ZVdla2hjZWRlSGFWaFZjU2hkZUdhdGc2ZllkMGYxZHFlVmhBZjhlQWhIZWpnUWJaaEpnVGI1aGFhVWd3Z3hlcWZkZGtlNWRMZkVhQWd4ZlpmZmNHZHhkd2NaZGtkRmFQZ1NmVWh0Y25kWWhFZ3NlcmJlZ21kRmFCY1NlaGJBZ2ZoYWhFY1JjTWRaYmpoc2JUYWJnMGZkaHpkRWEwZmRlb2RGaFVmaGNRZ1JoeGZCYW1mY2hrZHdjVmZmYjJmZGJEYmJna2VGY0tlQ2ZHY2thdWhGZmtjUWQ2ZUZmQ2NsYm1hZmYyZDFjVmVlaGtlMWZVYUNjUWRsYy9mVWduYlJocmZlZW1mTmZOZWFha2NzZVBmVWNoYkJha2NUZ0hoWmNwY1VmaGZBYmJoS2JDZ05lQmNBZXhoQmJSYVNmM2ZaZ3lnTGdIZEJkQWdEYUVmbGZFYmFnM2ZoYWFhWmZYZU5obGZWZTBiZ2RDYkFhV2JoY1hiUmVXaGNoWmVYYUdoOWZaZmJjUmVOYVJjWWdSY1ZhT2ZVZkZlRWFEaGJlM2I1ZldjQmFIZmhicWNVYlNhdGRYYlFmZ2FCaDZmWWdSYkFlWWdLYlJoMWJ2YVRlR2FGYndnVmdXZjljYWhSZ3hiMGVkZVZiVmhKYzBlYWQzZnBkamZWZjJicGFEaFJmbGJraGJjYWVHYVpjMmhkYWxnSmJDY0ZhWGdoZzJnRWZrZXNmWWZRaDFlbGhpaGNjbmhCZXdnUWJBYXhhSmhSZDNhVmV1aFhlbWFKZnBhZmgxZWRhU2RFZ0JlRmZnZEFiMWNSYi9mQWN3ZkJldmFRZ1hhTmNjZ1RhbWhnZUpkVmFGZkJmV2NBaEdjOWZ5ZUNlaGNWYWliWWMwY0ZhbGNSZkVhb2ZRYmFmVGZVZ1lhV2J5YTVjVmVOZEFhVWF1Zk5jQmNBZk9iRGdrZTliVWVGZUZmeGhiYmZlV2FkYVFkWWgwYzFocWFTY3dhOWNTaEVoR2RSZ01mZGVuY1poU2ZRYWhmVmI0Z2Rja2VCZEZoU2RCYVljS2FLaG5icGhhYWNkRWhoYkRiU2JWaHBhMWhlaEVodGMzZ2VnbWRsZlhkV2VSZEFoWmRhYkFkdGFGY2ZmUWhVaERmYmV4ZnRoemZHaHdjaGJvYkNoMWNaY1FlVmdnZWhodmhmZm5od2NWYmFmbmRKY1JkZGQxZGRoS2ZGaG1obGRoYUZnaGJoY21mRmRHZlpnbWRZY1hkQmJFYWZiVWVKYUhoUWRSYzFoZGdXZ2pmdGJyZFpoSGMxZk5jZWUxY2tmR2VVZGhoWmdrYVdhbWFWZi9lWGRtZmdhVmFlZ0hkWWVTZ1NleGJoY0RoV2VXYkpmeWdjZ0hmQmhJZlFmMGhsZGFnZGRYZWhhYWFaZldkSmFwZUNkMWZrY1lhRWJTY2NlTGhXYTNoRWZSZ0JiV2FaY0hmZGVSZk5nUmJlYXhkeGRFY2Voa2djZ1FhWmFuY0poV2hGYVdkcGh5YVVkWGdkZFhhU2doaFpncGFZZFJlWWVZZlpkZ2RWZjBkZmJtYkVic2FWZFdmZGdNZlZnQmYwYWJoVmhSZjFnOWdRZ1hncGFqY1RjV2hwZUxjRGMxZUljUWJaYUVmeGgyaGRmbGZKZUNkRmhYYWhhL2JHZjFoQWR5Y1FoMWhsY2loY2FuY0Jhd2NTZ0VnTmJKZFdkaWFoZVNmU2MzZGRhNmdhYlZlZGRaaEVhQmNsZm9iQ2V4ZWNncWNSYVVnWWY5Y0NmWGZOZmRmQWRqYThnVmNQZVJoa2hKaFJoSGg0Y1RoQmhFZmNjcmZLZzFna2RsaFhnbGNFZzhnYWZXaEVkV2NHYUdoWWZVY1pibWRZZDhkV2ZsZlZkdmhXY2thY2FkZUhkVmVWZVNhTWhqaDRjMGFJaEJla2dqZUJmRWVGY1NjWGQyZnhnRmNkZGlhMWY0Y1FnaGdWYzRoZGRoYkphTGJHY0VmTmRaZlliaWFBYzFhSmRCZDBhUmhCZjFocGduZGVkRmFaZHFoZWNpZWdoRmVIY2tlVmJVZkxkVWJVZFJoUGdCZjliZmNLYWdna2EwYlJid2E5YUNhRmdVYmhkUWhSYnhjQmJtZ2NhbGZZZFZkYWFuYkpjUmZhY0ZoY2FFYVVhemc1Y2hoV2RSZ0FmbmdSZGlmRWR6Y0xmRGJVZ2JhT2d3ZmtiOGhEZkdhQmZjZVhoQ2hFYjdnUGNpaElmWmFMZzBnTmJPZkFhRmJjZ3hnQWNUaE1lNGdCYmhjRmJ1Z2FnQWdzYmJmUmhWYndmS2JIZWllY2FoY0pjSGRoZEJnYWZVZGxnYWNkY1hnaGhMYWRkM2RwZXBlVmgxZWtnUWRHZVhnSWhMZEVjU2FkZVlhUWhHaDhoT2dQYVVoQWhUZUthVmJzYUxiRmRRZ2hoV2VaYmphMWg4YUZhV2JwaHliVWZYYmRoWGZTYWhhWmVwZFllUmdZY1lnZWZSZ1Fhd2dLZFNoZ2EwY1ZmU2hkZlVkQmRGY3hiUmZHZlZib2RnaElkemNNZHdhUWZXY29lS2JYZFJkVmJGaEtoUWZrZjRiSWRnZUVkNWRCZ1FnVmYvaE9kRWRzZFlkUWExYWxoaWRjZm5hQmN3Y1NjRWhOaEpiV2FtaDlnNGJCY1RhSWJ0YmFkUmFoZVJkVWVVYnNkdmdYZ2dhZ2RxYlhjMGJjYjhnUGdHY05ldWdUZm5lTWEvaFNhRmJCZ0hiRWVHYVpieWhWYmhlVWUzaFdoRmZGZjNjVmQwY29iV2hhYldlRWZXYlhmamZOYWFiSmZUYUlnb2JQZHhodGF2YUVla2E5Z0plRmhGaFVoSmJYY21idGc2ZlljMGExYnFiU2Z3YjlnU2NFY0dmUWVlY01leWJJYkhoRWVGZXRoNGJmaGpoaGhMZEdoRWJOYVpnWWFuY0pjd2VjaEVoaGJEZFNiVmRwaDlkTGZBaE1iK2JLZ1doY2VFZEhiRmVWZWRkYWVCYlpiRmdPYnhjRmJhYUlmUmNRZW5iVWVnY2tkcmVVYkFkY2FXaFJkMWM1Zm1iYmNWZlpjQmVaZERoRWdkZ09jQmVrZlBjSGFtZUJhaGVEZ0JjZ2VvZkhoRGdKYXZjYWRIaHhlL2JiaDFmcGZIaEhlUmMxYlZnVWFuZ1JmcmRlYm1oTmdOZ1lhaGY5ZkhnR2MwYk5lcWFHaG1mZGQyYlRoMGZKZUJjTWhEZjllQmVSZlVlc2NHYkhlQ2RaYThnTWN6Y3dkSGhEZVFmeGNTYmZkSGZZYktmTWV6aDVoaGRCZUZjQWdlZVdhQ2R4ZVBlVGhTYTRiWWZHYW1nTmF0Z2NleGdOZkhjYWFCY1ZkSWJVZ0VnY2ZRY1pjbmhKZldjSGhUYjRkNmZHYkNnUmRaY0hmQWhSZXBhZmZCZ1pkTWFMYWxoMGExZ2FkRGRJZjFiRWNDYXRoVWFCY0ZiRmZTYkdkeGFkYjhlWWJuY1FiaWZDZFNlNWhEZlRmbGhzY1pnYWhHZlpkMmVkYWxkSmFDaEZoWGZoYTJoRWZrZXNkWWZRaDFobGJxZkphamNnYzVjR2YwZTBnZmVTYlhhVmhsYlNheWJNZnliSWJBYVJnWGhRZDFid2Z0ZVRoMGFzZHNoWGFWZXdhaGJBZm5lc2VhY1RlbWhRYy9iU2dGYkJlSGdFYkdiWmZ5ZFZhaGhWZnFoY2ZsZEZhM2NYZ3hmNWNlY0lnRGZJZ1lkVGFuY0ljVWJlZDJkWWExYU9iQmV3aDhiVmNCaFJhWWFXYUJmRmVjYk5heWRjZDFjTGVRYmhiaWdRaGdiRWFCZVJkU2NZZ1lnSmREZ2NoUmdGZ2hnMGNyY2ZneGV0aEhiTWRrY05jWmVZZW5lSmF3Z2NnRWVoY0RkU2JWYXBjMWVlYUVlTWNqY01maWhBY0VmVmYwZFJjV2JQaEVjb2VKZEVhRmIxZFdoSWVVZ2RjdWVFYTFhZGdoYUdmV2NKYVFnUmF4ZEJhbWFjZmxoWWVWZ2FlbmZKY1JnZGQxZWRhQ2hRYmllRWhvY1JkUmVZY3JiVWdTY3NmMWJLY0Nlb2FRY2JoMGFkY0hiRGVSZVJnWmVlZ0hjUmRyZWVlbWJOaE5hYWVrYnNjUGRVZGhiQmRrZVRkSGM0YmljR2NnZ3RhR2ZkZmpkdGRYYkJjbGhjaFJlQWNHZEpmdmVjYURoNGhkZERnd2RWYVRkZWdWZEpmTGRkYjNocGFwZVZlMWdrYVFjR2NXY2dkTGdSaFdoOWJGY1dieWNZZ1VnV2FSZE5mSGdhYUJhVmJJZVVhRWZjYVFnWmhuZEpiZmREYWtkQmd5ZFVnWGFkZ1hnU2ZoaFpncGRZYlVic2d5YVpjaGJSZG1mWmVtYkZkd2FWZVdhOGFNaEJla2Y4Y2RhR2QxZUplcGJhaHpoTmhyYVhoR2ROYkZjZWRqaHRlK2dFZ0ZlOWFraGJoWGJoZ0NkRmVYZ2hlMmRFZ2thc2ZZZlFmeGJkZHNhSWFpYUliL2NIZ0Fld2JkYkFkeWVVZjlnUmJTaDhlaWZJYlNlZ2dNZ1FiRmgwYXBnWGN3aEJodmhEYUJnTWhwYkVoamExZlFnRWJ5Y0ZnYWFCZmxiQmdQZVJnR2dwZnlkQmRCY3hjcWRLZFhhdGEzYVZnMGVvYldoYWhXY0VlV2RHZEdjWWhVZE1iQ2hjYXplY2VCaHhiamVjYkVnY2ZkY0hhVmdWYVNiZGZHZHRnNmhZZzBoMWdxYlNkMGdwY2VlT2JtZVJjTWZkaG5mWmZTYVFkaGFWYjRmZGFoZkpoTGFHZ0FoeGJaZmZoM2JJZnhoZmZqYWNmUGhCZWdnMWQ1YlVoa2J0ZDNlZWJtZ2xkWGRXYlJmQWJaY2FjQWh0YUZhYmUxZGtkVGZjZ2tkY2J5YUhoVGJnY2dmWGNBZDhmWWdYY0RhcGRtYmNkbGJZZVZlYWZuZUpoUmhkZzFkZGVLYkhlaWR4ZWhhQ2F4YmdheWhGaEdkeGJtYkxkbmZsZ1pjYmUxaElhT2NIZlFnQmJWYkZiM2dSaDFoWmJIZjFoTmhlZTFjMGNHY1hlaGNCY3NiQmFYZVpmOWJUYTBhSmZIZ2VoSGZ3aFNhQmNCZUZnUGZXZFdlb2Y3ZGNiSGZaZ1ZnUWYxZTllUGdZZEdjdGZlYWZkbmRaaHBoWGJ4ZkFlUWdFZm5mVWVMYkVkV2M4ZmJkRWF5ZWRiT2ZhYURibGNIYmFnQmJWYkljVWNFYmNoUWdaYW5mSmhXZ1FjeWdzYWdiVWhUZGxkWGhWY3hlWWQ5Y0thVmc5ZkxmYWRHaHNmcWZLYVRlWmR3Z1hobWc5YVNnVWNRYWdhSWZSZWtoZGQwZGJlWGZvYW1mUmJHYVpkaGNEZjFmSWVRYVpjRWV4ZTJnZGRsZEpkQ2NGYVhkaGYyY1JkMGRzaEZmUWJ4aGRhaWhiZkdkNWR1Z1NnRmFKZGZlUWhWaDloNGJTZTNmZGQ2YmFiVmNkYVpkRWRCZWxob2dYYmtjVmNrZkRjQmJNZTdlRGN6Z3BjQWVTZlJiZGVkZkFnUmhjZ1BkRWVHZTFheWJYYmdlTmEvYVpmMGJKZGlkVmIwYndnV2hJZUdmZ2hOZE1lbWNZZlVlWmRtYlpiaGZjYkZnVmd2Zldka2NkZUxjWGFBZmRkU2FNYW1odGJuY1lkMGhVZi9iU2N4Z05hT2NFZkhlVmJhaGZlM2dZZE9lUWZoYjFndWZZY3dnZGVZaERmVWVOZWZnWWVqZ3hmNWJhZzJhSmVEY1NiVmNwZzFiZWNFZnRoM2FlaG1mbGFYYVVlVmZZYVpiZGVRYXRjTmJLYlJlRWhQZmNnMGhkaGlhQWhFYTVlb2VTYlVlaGNZZkFkUmJCZDRhYmNFZmdkVmhlYTJldGdZZmZobGZ0Z2dmRmFtZGxiaGVGZ2hoaGZtZUZjR2JaZG1jWWdYYkJnVmZaZXhoUmJIZkFjQmUxYkRhUmEyZkZjNGFiZjJmTmRMZGFhZ2QwYUdjWGZqaHBka2RUZEhhWmgyYlVja2dJZVZnZWVIZFlhU2hTZ3hlaGhMYURjR2dKYXZkY2ZEY1phSWdYY1ZnZGdFZWRnV2RsYWRoZmRuZ1pnRGNWYTFha2VRY0dnV2hnY0xlUmJXZjhlUmRFZzJiOWhIaGVoMWh4ZUhjZGNSZlVhYmZYY2poaGdjZUtjU2ZWZ2ZkR2FVY0JjeWZVZFhiZGFYZlNmaGZaYnBlWWVSYlljWWNaZGhhUmR1ZUxmbWRGZ3RmVmFUYnhjVWhPYUZjVmhVZ0VoaGhwZjllWmMxZUJiamFUYldhcGZMZ0RmMWRJY1FjWmdFZnhkMmRkZ2xnSmRLZ1VkSGFoaHJkRWZnZ1VjWWhTZ1Zha2F0YmVmM2Z4YmFoU2VFZU5jSmZXZm5lVmI0YVNkM2ZkaDZhYWNWZGRmWmdHZUZoQmhvY0Zma2VVYnFoRWJRZzFoeGZXY1hmTWdDZ1VjV2FFZFphWWVsYkJnSGdFY0dmWmJ5Y1ZjaGhWZ3FnY2FsY0ZkM2dWZzBnSmFmYWFnV2JvY0xjR2VEZE1jVWRiYkdkWWZ1YmVkVmVsaEZoV2RraGNhZGhIY1ZnVmhTZWRmR2F0YzZmWWcwYjFmcWhRZjBoWmhTZUZjbmVsZ01iWWZHZU5jSGdVYlFiQmh4Z2ViamJoZUxhR2NFZ05mWmZZZW5oSmd3Y2NmRWFoYURlU2FWZnBoOWVNZ1VmdGQ4ZFpjMmNrZlpnV2dSYW9iWmdJaEFiSmhKYVJkUmhFY1RjYmUwY2RjemFFaDBlZGJvYUZhVWJoY1FhUmF4ZmdneWZPY2hmOWJHZ1pjQWcwaGRlT2dBZEJjS2FDZzJhbGIzZEFhd2UxYzFlQWhXZVphZ2VZZVRmVmFjYlljM2VCZ0hkSGJSZDFmVmhVaG5jUmFyYWVmbWFOZk5mYWZrZnNkSGhCY2xiZ2F0Z0hjM2JnZkpmR2RnZXRoU2FNZ0hnWWdQZlNjd2E1Z1dlVGdIY0ZhbmRjZkhlWmVJY0Nka2hCYkJmWGQzZ2hmTGhkZTNlcGVwYlZjMWJrYlFjUmhIZ01jaGJSaFdmOGFSZEVlMmg5YkhiY2J4Z01kUmdLZlVmZGFJaEFlMGVjY05oWmZqZXhoZWZGYzNjaGRrZVJlR2NOaERhV2NRZk5mK2JkZXdhY2NhYmJjeGVoYU1oWmRtYkZod2dWZVdmOWJhY1JjeGYwYmRmVmRSaE5oMGVkYW5kb2h0YlJoV2JoYVphSGRVYVllR2JmZ0ZoNWRrZFlmMGNOZWJiRmIzZkZmNmVPZkVoc2RZZVFkMWdsY2lkY2JuYUJld2hTZkViTWNjYldmbWVoZjRoQmNYaDlkNGhlY2tiVmJQY0JiZ2cxaHdkRWhsZXhmK2JCZ2hnRmhtZlNmMWVraFRoUmcyY2dkVmRTZEZnQmdIZEVmR2RaYXlnRWVCYVZkM2djZmhmOWUvaFZkVmN3YkFoY2VYZE1hQWREY1hjUWVDZ2RhV2hSYW9iZmJIZTlodmVXZ2tmY2JkZ0hhVmhWaFNjZGNHaHRkNmdMYzBlMWczYlNnMGdGZGFhRWhuaGRnYmNZZG1lRmhFaFVhd2VaZmhiWmhSY0JmQ2RBZTJmbGZaZllibmFKYXdkY2JFZmhoRGhTaFZiSWc2YWRhaGFzY2xkTmdUYzBoWWFEZFVobGZKZExnUWNVZE1jSWRWY2hjSGNiZDFmcGd6YVdlMGI1YmtoUGIwZ2hhUWVSY3hmQmdtZGNnbGRZZFZjYWhuYUpnWmRPY0Zoa2NhZVJhQ2dZZTFjV2hVZHdiL2FSZ0NlTmNvZk5lQ2JBZFJnTGZnYTRlQ2NIZlFjQmZWZUZiQ2RFZWxiT2FUaGNmRWdKZFFnVWFQYVdha2FSaHRjVGNDYjFkY2dVZ2tjSWdWYmVoSGNZZVNiU2J4YWhnRGVXYVdkSmV5ZUpiamJFYWFmUWV3ZkJiV2ZYYjNhaGZMaGRmM2VwZnBoVmIxY2tiUWZHYldhZ2FMZVJkV2I4aFJiWGNHZTljYWRjYXhjRWZVZlBjRWFjZkJiSGFnYkFjU2VaYW1oOWRMaEZkVGM0Z3JhQWRUZElnWWhEYkJiWWE5YWViamh3YlloWmFoY1JmbWdaY21mRmZ3ZlZnV2Q5ZmFnUmZ4ZjFkU2FWYlZnUmZ5ZWFjM2VKZXJhR2JXYnBlV2JEYXhlY2dZYU1kRWRWZy9mZWRsZ0pnS2hXYW5kaGFyZUVia2FvZEpoU2NsaFZoaWdlZWpobGd3ZVZkVWhOYkloU2NuYnhmeGFSYzFhMWI2aGFkVmdkYVpkRWRCYmxib2dDZjBlVmV2ZEVkUmZOZnZnUmczZEZkR2dDYVNheGJRaERjaGZrY0phVmdTYkpnd2VWaGhlUmczZGNhZ2VVYnVnQmZ3aDlkWmdMZDJnRmEzZlNiamZSY1ZoUGh3ZFFnMGJOY2hlTWNxZkNkRWdjZmJlR2QzZjllU2hkYkdmdGI2ZFloMGMxY3FnU2F3ZTlnU2VFY0dmUmJNYWRmbmdaaFNhRmdoZlVleGJPZUVlRWJmZFdjUWUwZGFlSmd6aDBiMmhjYUNla2NSY0dheGhzYXNkR2VoZDRleGFQaENhd2FGaFdhUmZZZGZnUWNnY3RnRmViZ3hoRWdUZWJjMGZkZHpoRWEwZmRmb2NGY1VmaGFRY1JheGNCZHVlZWdoZzhhVmdkZDNnSmdRYVpoMWU1aEdkRmhtZkVhMWdGYWdjVmZtZVdiaWZNaHhjWWRRYlVhY2RJZ1FoNWNmYWZjRWE4Y0hlRWR5aDFhamJMY21hcGNFaFllMWRBZWxiVWJoYkJla2hUZkhkWmEyY1Vla2RJZlZnZWJIaFlhU2dIZFZma2dSZ1dmU2FwZnlnYmJYaEJnWWNUYzJiTmJhaGRlWGVoYkxiZGYzYXBmcGZWYTFha2dRZkdjV2ZnZ0xlUmNTZkVhUmdEZm1lOGJUaGZlVmI4aENmSmJsY0lhY2ZHZkVic2Y2ZlpobmhKZFdoRmJXaHBieWZVYlhnZGFYZ1NnaGFaZXBlWWhSZFpjTGVaZ2dlbGFtZExibWJGZTdkVmZTYUZmQmdiZlJkMGRkZlZoVmFKZTBnYWYzZHBlamFUZVdmcGRMYkRkeGJ0YldoWmdFY1JnbWFkaGtnOWNmZEZlVGZaZS9iRWhoZWxkZGRGZHdnd2V3aFBoSGZBZGtjQWhBaG9jYWJRaFZiOWM0ZFNlM2dkZDZmYWVWZ2RoWmFFaEJmbGRvYUNjMGNVaG1hVmV4aE5hbmJiYlhmTWJUZVJhMmZnYVZnU2NGaEJlSGJFY0doWmR5ZFZlaGFWZ3FkZWNsaGthamVIZ3diTmNGZ1pjemhWaFpjVGhDYmRlWWFHYVNlb2ZrZ1BmbGJWZWtjUmUwYWRoVGFGZUZlbGE0YWRiR2F0aDZoWWMwZTFhcWNTY3dkOWJTYUVmR2VSZ01iZGNuZFplQ2RRYmdnaGhsZmRma2dZYkRoVWFSY0JlWGFMYnpnY2M5ZUlid2JFY1pmRGVGaHBkemVmZG1hRmQzaGVmbWFsYVhoV2VSZ0FoWmRhYUFjdGVGaGJjeGhFY1RiYmQwZWRhemZHZnhlTWFnZ1hjQmR0ZGVjQ2JsZlVjcmFQZFFkUmhNZGFmbWQ5ZlJnT2RGZGRhVmNGY21mdGFqY0ZoZ2FKaG1nWGhXaFpnNWVZaFRmNGRRZk9lRmJvYXlnVmVGZE1mQmRTaGhoVWE1ZktoQ2dJYVVkWWJsY29jWmNXZXhiQmcraFRiRGZnYnpmQmhVZ0phSGVjYUdhY2dFZFFjaGNGZFBhY2gyaEpieWFjZ0hnQmRJYVFiMGRsZ2FnZGVYY2hnTGRkaDNicGJwZkFoeGFGYVpoU2FtaFpjR2hBZkNmSmNDZVdnamVVaENiY2Z4Y2hiSGJKaGhiVmJVZVVoRmJZZ0doYmgxYWhmV2RGaFdkcGN5Y1VjWGhkZVhmU2doZlpocGRZZlJkWWZSZ1RoQmNSYW1kWmhtZ0Zid2FWZ1djOWZhZ1JneGIwZGRhVmhWY0pjMGZPZFRkOGEzaEdmRGNnZ0ZjRGQxZ29mNmZaZEVoeGgyYmRmbGNKZ0NlRmdYY2hnMmVFY2tlc2NZaFFhMWVsZWlhY2ZqZDllYWJTYUVjTmZKYldmbmVWYzRnU2UzaGRmNmdhZ1ZhZGRaY0ViQmZsYW9oQ2UwYVZidmREZWhhTmduZUVnemF0aGFhRmVHZ1poWWREY1JiMGJJaFFmamc5aHloWGhRY2hncWJKYmxiaGVkYlZhMGZvZ1dmYWFXYUVkV2RHY0dnWWhVaFpkbWRaY2hiY2hGZFZldmFXZWtoY2FkZUJiMWdVYWJnWGJtZHRnNmJZZTBiMWZxaFNnd2c5ZFNiRWFHZVJiTWhkYW5iWmdTYVFkaGhWYjRoZGZnZDFkTGFUYkFnc2VRZ01nWGZ3YzljTmFRZ1VkTWFHYXdhTmc3Z0tid2E0ZWpoY2dqYTFiWmdDYWtmVmViY0tiVmJraFhlTGNrZWdmYmJmZDBmdGZ6Z1hlVWE1YmtmRmFSaHdnWWhEZWtoTmNvY1BleGROZVljT2ZUYXNmTGhNYWxlNWZnY0ZibWNsY2hmRmNoZGhjbWRGZkdmWmJtZ1liWGhCZVZiYmMxaHBoSGVIZ1JiMWNWZVNkSGFRZC9nZGJDY0FoQ2NPYWhjSWZIZUJlbGJnZHRhSGUzY2dmN2dGYndlOWZhZEtkaWM4ZmVkU2QwaHdhTGZFY0RlRmM4YlBiVGRVY0ZmRWJBYUFkQWVNZ0hnUmFMZlplM2VaaHBiR2ZWZ0FhY2JNZjJnZ2ZMYVJjV2M4aFJkRWQyZzljSGZjYnhlTmdIZmFhQmVWZEljVWZFYWNmWWhNZGpib2RmYlJibWJRYi9nRmJEZW9mRWZBaDBnd2ZzY1lhUmUwYkZhWmFsYnBldmZhZmthdGV3Y1ZjV2E5Z2FhUmh4ZTBiZGVWZlZnSmgwZWFlM2FwZmphVGVXaHBhTGFXYXhncGJaZk5oMmZaYzJmZGVsY0pmQ2hGaFhoaGYyZEVka2hzZ1lkUWYxYmxjaWZjYm5hbGNyYllna2ROYUpkV2NuZVZiNGhTYjNoZGg2ZmFmVmZkYlplRWNGZUFhdWhDZzBiMGU3aFdoVmFvZjhkU2hUZDVkV2RDZmpndGdjYkVjaGNWZEhhRGRtY1phaWFYYnhlVWZ4YldoRmVGYTNiVmUwY29lV2NhYldlRWRXZUdhR2ZZZVViWmRtZlpnaGVQZzNnOWN2aFdla2RjY2RnSGZWZFZlU2FkYkdndGQ2Y1llMGgxZXFlU2h3YzljU2JEZzJlUmhFaElhamc0ZWJlRWdSZXNiMWNNYTFjOGVFZVNjaGVwZVpjYWZXZTlld2RKZEVkWWhRYUJoUmNNYTJjUGJVYk5kbmZkZm1hbGNHZFRmeGJBZ1ViYWRGZjhjTmZKZGthSWhkaElkZ2RJYitnUWNBYzRjeWRVY0ViRmFaZGJlUmZCZW1jY2RsYllnVmNhaG5nSmFSYWRmMWdkYUtmRmVtZGxnaGVGZWhjaGg4aEZjQ2I5Yk1jWWNYZkJoVmdiZDFhcGNIZUhlUmUxZ1ZhVWRuY1JncmVlZm1lTmZOZmFobGdRZVBnQmJsYmdmdGRIYzNkZ2I3ZkZkd2Q5Z2FiS2NpZjhjY2dHaEZlMGhYZFVhVWhoZXlhY2dIZEJmSWdRZzBlbGFhY2RlWGVoZ0xhZGMzYXBocGRWZTFja2dRYUdjV2JnYUxkUmdUYXNlZmZRZERmb2ZGZU1ka2ZFaFZmS2FVZ3hnQWNRYkVjc2JRYmRmMmhSZldoR2ZHYW9nbWdHYVRkNGVFZlJlRmRzaHNiTGhFZlZnUmVQY0ZlRmN2ZmFoa2h0ZXdhVmhXYzllYWFSYXhoMGZkYVZjVmRKZjBlYWUzaHBhamNUY1dncGZMZURiMWZJZFFhWmRCZGdhK2ZQaHdmRmFNZVdjRGcwYTdkUWRRYkpoQ2NCZW5mTmJpZ2NibmJCZXdoU2ZFaE5nSmVXZ25lVmE0ZlNiM2NkYjZnYWRWYWRlWmhFYUJibGRoaEloVWZWYXZjRWdSYk5ndmNSZzNlTWFUY1JiMmRnaFZmU2hGZkJiSGVFYUdlWmhvZVZma2FGYmtmTWdSYTRkbmNEZ2tiSmRDaElhU2VoaEZoRmdpaHRhUmhLY3lna2J6YUtoVmZsY3ZhRGFnYzlnVWdUY2xic2JmaE1lU2NZZ3BkS2VoZmNkdmRSZndhOWJDY0hjR2FSYmRmWWFIZlpkZmJRaGtiRWR3Z1BoMGJGYkZkVmVRY1lnVWRNZlRnc2FxY05oVWdGZllmWWExZnBlMWdlaEVndGIzY2VobWdsY1hmV2dSY0FiWmFhY0FidGdGZE9kVmdCY0JmYmJ3YlplemREZ2toZGQ0ZURnbWVKaFFnUmZ4ZEJnbWVjYWxkWWVWYWFmbmhKZVJjZGIxZmRlS2VGZGlmWmdMYkZmaGRoYm1kRmVHZ1phbWFZZFhoQmNWYWJhMWZwYUhkSGdSZjFhVmdVYm1hdGVyaGNhamhjZEZiSWV4ZmdhQmhCYUFmRmVxYkZiQ2E0YSthTGJSaGRkRmVQYURoZGhHZURoaGJCZ3BhV2hXYkpkeWhjYkhnQmZJZlFiMGFsZGFnZGRYZWhoTGVkZjNlcGNwZlZlMWRrZ1FhR2JXYmdnRGZFY1NhZGJZY1FkR2dFZ0tkTmNsZTRkSWNPYmtieGZHY0Vmd2Q5YVJnTmFCY0ViWmVVZFNlOGJUYkJhWGg4ZldkU2hoZzFncGVjZkJiOGZZZmVnZ2hoZ21nZmhtZWhjd2dDYVViVmRhYlJjeGEwZmRiVmNWYUpiMGVhZDNocGRqZlRoV2RwaExkRGIxZ0loUWhaZEVoeGUyZWRmbGVKYkNkUWNUZkFmL2FRY1VlVmNWaEJnaGhRZ3RnSWNDYWxhK2dDZ3djc2RJY0NlQmhZZzNhRGR6YUlnYmJQZFZkOGJZaEdoUmFWaENoQ2UwYlZndmhFY1JnTmJ2ZVJhM2FNaFRnUmMyYWdiVmZTYUZjQmJIZEVnR2haY3liVmRoZVZlaWNKZWhia2grZkJhRWFSZGJnTGZDZXhlWmFTY2pnOGhhaEphU2c0YmdoSWhqZVlhZ2JIY2dkSmQ4ZlNnVmYwZ1RhZGVHZUJiNmNjZEVoUmFxYVZheGFOZFNmQ2JHZTFiTWJLZWxleGdTaFFnaGVWaDRoZGVoZkpiTGRHZ0VjTmNaZllnbmdKZXdiY2hFZmhiRGZTYVZicGQxZmVoRWR0YjNjTGhpaEVoZWJDY2hkNWNVYkxkVWRZY0tjUGdVY2dhZGFMZkFoOGF5YlFjU2ZRY25iVWJRZjBmeGdFZHhlZ2ZuYmNmbGcwZlZhZWhIYXRjN2JkYjFlZGhLYkZlbWhsZGhoRmNoZ2hhbWhGZUdmWmFtY1loWGFCaFZlYmUxaHBmSGJGZ0JkRmcvYlVmbmJSZHJkZWNtaE5hTmhhZ2tkc2VQYlVmaGVCZGtiVGNIZVpnMmdVZ2thSWJWaGNnRGdjZlNlUWdBaFZhRGJUY1didGQrYldjbmVCZklhUWEwZWxnYWhkY1hnaGZMZmRoM2dwZnBmVmYxaGtnUWdHaFdlZ2ZMYVJoVGF0ZVpiV2RqZnhhSmhKZ1FmRmJKY01iRWQwZ0FiTGZ4aEplQWFJZ2phTWFDY1VnR2FKYVlnVWZYYWRlWGRTYWhhWmNwYVlmUmNZY1liWmRoY1JkbWFaZ21nRmd3aFZmV2g5YWFnUmZ4ZTBmVmNBY1Jhb2g5ZE9oSGRRYnVoQ2ZDZ2NhRWVYaFFhc2RlY0pmd2VRZTNjSmREaEVlTmZVZ1RlMGNYZ1Jma2FOZFpjUWgxaEpjaWZZZDNlbGR3Z1ZlRmE5aEphUWRuYXhkNGRGYjFoMWI2ZWFhVmVkZ1phRWFCY2xlb2VDZjBmVmJ2YkViUmNOZXZlUmMzZk1kVGFSZDJhZ2hWY1NkRmdCYkhkUmZDYjRkN2NCYlJic2FuaE5meGV3YzRkQmRSYU1iWWhLYWlhbGdYZVNnZ2VWZWJoSWJpZU1hQWNKY0ZnMGN1ZlVkMGFzYzNjSGVWaFZnU2dkY0dkdGU2ZVllMGMxZnFoU2d3ZzlnU2hFaEdhUmhNZGRobmJaYVNlUWVoYVZod2dJZmxmb2FDZFNjMGcwZVVlSmN6YThkL2VJY2hhRmJOYkNmaGNJYjBkS2ZpaGdlNGhQY2lkd2EyY0RmUmhoYllnYWJBZUJiRmJmZEJmZ2FUYWNmMWR0ZHpkQ2UwaDVhb2RTZ1doSmdRaFJjeGJCYW1hY2RsaFllVmFhYm5hSmNSYWRoMWRkYUtlRmNtaGxmaGhGaGhnaGdtYkZiR2FaZm1oTmNUZmdkY2NQZkZnUWNLYVdlRmFBaGFkQWFDaDFlbGNPZ1Nhc2dNaE9jQ2hoYUFkRmFsZlVnRmZHZ0hoNGUzaFVna2VrZVZkYWJuYThnNGNTY3hmaGdEZ1djV2ZKYXljY2VIYkJnSWNRaDBhbGRhYWRmWGJoY0xkZGEzYXBocGVYZmxkVWc2ZkdiV2NnZUxnUmRXZjhlUmRFaDJmOWFIYmNheGVOZkhoYWFCZVZnSWZVZUVhY2FRYmJjamZOZldmSGduZmRkeWVSZ1hjNWdiZllhQmVaZ3BhWWNSZFlnWWdaYmhkUmVtYVpibWNGY3dhVmFXZDlhYWNSY3hmMGdkZVZlUWRZYjhkSWVpZGxodGJHZjNmbGhGZlZkd2ZwZFloR2Z4ZWtmbWRNYmhlTWRXaFVlSGFCY2NjRWVrZHNkWWZRZjFlbGFpYmNkbmRCYndoU2RFYU5kSmdXZm5mVmg0Y1NkM2hkZjZiYWJWZWRmUmFSYUZjRWdoZVdnRWFzZWloVmhGYjRlZ2RGYlNkb2ZkZEJjQ2RCY1VnR2JqZk1nSWdWZ0NoTWVUYkFnaGcwZXJoY2hsaHBlM2dSY2tnTWJXaGRhWGUwY1djQWJHZDhjVWhPY2toeGdoZ2NiRmdWZXZkV2FrY2NiZGRIZVZhVmVTZmRnR2J0YjZjWWIwZzFicWZTZ3doOWJTZEVmR2FSZU1lSWFqYTRiYmRFZFJic2gxZE1jMWM4ZUVjU2JoZnBnWGRJZFRnb2Z4YUlkaWRzY01iRGNSZjhoVWZMZkVhTWIyaGNmMmdWYzllV2NSYUFiWmJhYkFndGhGYWJneGJFYlRhYmcwYmRnemFFYzBhZGdvYkZlVWZoYVFjUmN4YkJodWNKZmhjNWFjZk9mWGN3Y2NoTWRoZm9mRmNSZkRnQmF2YlZnVmZBaG5lUmhnZFVlcGhKZVRlVWUwYU9lMWZJY0dhSGZSZVpkVmFRYVhkMWZyaFpobmc5ZU5lY2JrZ0llUGNEYWpjcGJrYVRoSGVaYTJhVWdrYklmVmJlaEhnWWdTYlNoeGNoYkRiV2JXYUpieWZjZ0hnQmhJYVFjMGZsZGFmSWVUZEFhQ2FKYkhmUWFrYkVnaGRSZmZmU2h6Z0VkRmNCYmlkZGVRaFFlUWh3aElmTmgxZVlmbWJQY0JjMGJKZFVhRWF3YlFoZGdIYnRmOGZGYldjcGR5ZVVnWGhkYVhmU2hoY1pncGZZYlJnWWVZZlpjaGVSZW1jWmNtYUZod2FYYUdmTmJ3YVJjeGYwaGRiVmhWZ0phMGNhZzNmcGhqZVRnV2hwZExiRGExaElnUWhaZUVheGgyZ2ZhaGFOZUNjSGRtZlZmMmNCaGtlSWRVZGFjVmJsZ2liY2FuY0Jmd2FTaEViTmdKaFdmbmdWYTRoU2gzYmRmNmdhY1ZkZGNaYkVmRWEwZWdjUWdoZFpmaGJSYndkZGhoY0hoeWh0aGJiT2ZEYzFmRmdEYkJlRWJUZ1ZnV2c1ZlllVmZoYlZocWZjaGxiRmEzZlZmMGNvZldoYWVXYkVoV2dHaEdmWWhVaFpibWhaYWhlY2VGZFZhbmhEYmdlOWdVYlRnbGhzaGZnTWNTZFloMWJNZVJhUmhrZENkRWNjYlRjUWZnZGNkRGVNY2phTWh6YUZmaGQwaDVkZGhoZWxlTGRDYlVjcGRaZWZmbWY1YndmYWRFZ0ZlRGNGaFhiQmcxZmVkRWN0ZzNlZWdtYmxkWGVXYlJmQWVaZ2FnQWF0Y0ZnYmd4ZkViVGZiaDBmZGN6YUVnMGJkZG9jUWJRYkFlWmRGYUJhNGhyaE5heGJ0YWFoT2VDZHRkZmhOZ0JjOGdMZlJnQWdvYnVlVWhsYjBoSGZRYUdhNGZuYmFhSGZ4Yi9nYmUxZHBnSGRIYVJnMWJWZFVlbmhSZnJnZWdtZU5kTmhhZGtoc2VQZ1VkaGdCY2tkVGdIYVpjK2FCZWdocGFjZUtoM2JoZGZiRGFsZVVnTWhDaHpidGc4ZE1memhnaEplRWVTYW9jVmNNYlRoMGZxYkljM2hJY29kVmcxZElnUWhDZ21hRWJMaFdjWGFNZVJhQ2UyZ1poSGRMaHpnbGJIZWFnQmZWYUliVWhFZ2NjUWdaZG5nSmRXZEZhV2dwYXloVWZYaGRhWGRTZmhoWmZwZFlnUmZZYllhTWFsYndodmdOYldhOGg5YkVlQ2ZJZ1ZmRmJVZFFoVGFGZWhkb2UxYU9lUmZrZ3NmQ2ZTYThkcWdXYjFmcGJSZlpkRWVkYjJmWmNGaHRob2VGaFhoaGgyaEVha2VzaFliUWExZ2xnaWdjZm5oQmV3aFNhRWdOZkpjV2JuZFZmNGZRZm5iNWdRYmFiVmhkYlpkRWJCYmxkb2hDZjBkVmF2ZUVlUmNOYXZmUmQzYk1jVGhSYzNmSWVWZVFnQWVRYVBkV2dUZ1ZlOGZBYkFhUmdrYUtlZ2FrZC9mS2JCZzlnR2FMZVNhQmNDYVhkV2Q0YitnWmFtYVpnaGdjY0ZoVmh2aFdha2JjYmRlSGFWaFZjU2NkZEdldGc2Y1loMGQxZXFnU2h3ZzlnYWNSYkNod2RGZEplWGJnYWZhQmMxZ2doM2VKZkVlc2N3ZldkVWJOYVNiWWdtZU1lTmZjZEZnUmdmZFNhVWZKYzhhZWVCZmRiM2ZMZWlmRWJlZENoaGE1YlVmTGdVaFllS2ZQZ1VnaGdvZExiamJwYy9lT2hVZWRib2ZGYlVjaGJRYlJjeGFCZ21mY2NsYVlnVmNhYW5lSmNSZmRmMWVkY0thRmFtYWxoaGdIZGtmd2F1aFhnVGZWYW9iTGFEZVVlWWZJZUFoZ2hlYVpmbGd4aFZmV2dYaFJjNGRCZTJhTmNSZWRka2VzZlhiV2d4ZkFmNGFUYkNkSWQrY0dheGdFaGJlTmVUZE5iZmZCYkVmb2FhZ0lmaWhOYnllZWIzZ0JmYWhQY21jTmZhZGRmWGNoZ0xiZGQzYnBicGhWZjFoa2RRZEdlV2dnY0xjUmJXYjhnUmRFaDJhOWhPY2ZmemZsYkhjYWJCZVZoSWNVaEVnY2FRZVpkbmJKYVdiRmNXZXBieWRVYlhkZGRYaFNiaGFaYWhlSWZCZllhVGJlYnhjUmV5Y2JjMmcxZGFnVmZXYzllYWZSaHhnMGNkZ1ZnVmRKaDBhYWYzZXBhamVUZ1dncGNMaERkMWhJY1FoTWNBYVFhL2JKYVZld2VVaEJjM2hZYnVkU2ZnZU5mbmhGYWdia2NtY01keWhRYzFlUWdHZmxnSmVXYW5lVmU0Z1NhM2VkYTZmYWVWZGRlWmNFYkJnbGNvZUNoMGFWY3ZoRWFSYU5ldmRSZTNidGhIZURjeWZGYkdhUmJoZzBiQ2dYZVNoa2ZnZ0RhMmM0aHJjY2dsY3BnM2JSYWpnY2VXZ2RkWGMwYVdjQWRHZjhnVWZPZW1oWWcxYk9lQmJ3ZDhmVmhBaHBjWWZVYUJkb2RBYkxmUmVBYTdlSGFrZkZkQWJTZHdkOWVTZUVjR2NSaE1nZGhuZ1piU2VRYWhnVmU0Z2RiaGVKaExlR2FFZE5mWmdZaG5lSmU0ZEpiQWRBY0tiR2NsZlFiNGRQYVFhWWI0Y0tjRGZBaHNkR2VCZ0FlU2RhZUJkZ2E0Z2Jnd2EwZFBlYmgxYjlkNmNFYnhkdGVvZlFlUWRBZ1piRmJCZjRkcmJOY3hjdGVhZE9hQ2dzZnFoTmNsZmRmQmNGZG5mc2ZjZlBnQmVoYm1kRmJHYVpibWZZYlhhQmNWaGJnMWJwZUhkSGRSZzFoVmJVZ25oUmVyYmVibWNwYUJiUWFFYnNoUGRVYmhoQmFrZFRhSGNaZjJiVWNraEllVmJlZUhnWWFTaFNjeGZoY0RoV2VXY29hemVjYUhhdGZWYVFhMWgxaFRmZWNWZkpjTGJkZTNjcGVwYlZjMWRrZ1FlR2dXYWdhTGZSYVdiOGFSYUVjMmY5YUhmY2V4YU1lVGVJZkZld2NiZ1hiaGJFZERjYWFDYm9hT2ZYaFJmVWduYkFkVGdNaFdhSGhsYU5oaGNTZnhmWWJZY1piaGZSYW1mWmhtZEZhd2RWZldoOWdhYlJjeGUwYmRnVmFWZkplMGJhZDNocGJqZlJlVGE0ZERnUmRnYUVjZWdLYlFha2U3aE9lUWZBYWJoYmhqY2xjMmJHaFVoc2hKZFBibGhsYStiYmRuZkJmb2RRY1ViTWFWZFdnaWRFZndhQWRpZFJlMGJKZ0JkSWdVYlhhMGRzY3hnY2FBZlFhU2hIYVRobGZ2Y1JlM2RNZlRhUmEyZmdlVmVTZ0ZkQmZIZEViR2VaZ3ljVmZoZVZjcWJjZGxnRmgzZlZiMGFKZ0NjSWhTZmhmRmVGZWlidGhSZUtkeWRrYnpoS2FTYTRodWJXZWtld2hkY0RjaWNoaFNoYWZIYWRhNmFlYzBmUmFxaEZkd2U4YUdkV2ZDZjBhZmNlaERnc2RYZERmMWRvZHFoTGcyaGtjS2hHY0VlaGFaZ2NmQWQ5Z2FlY2VFZmhiRGNTZlZhcGgxZWViRWR0ZTNnZWJtZmxiWGhXYlJjQWhaaGFlQWZ0YUZhWmhoZTBkNWRiYzBiZGZ6ZUVkMGZkYm9mRmVVZGhoUWhSZnhiQmdtZ2NibGhZZFZjYWNuY0poUmVmY3hhWmhLYUhjWGNSaGhiQWJoY0ZocWRQYm1hWmhtaFllWGNCZVZlYmMxZnBkSGFIZ1JoMWZWaFVobmFSYnJmZWVtY05hTmdhY2hiOWZIZkdnMGVOaHFhR2ZtZ0plNGNDZWhmcGNkaEJjeWZOaENjRGcxZ2toWGFIaEdhcGFZZWNiSGNCaElnUWIwaGxhYWJkYVhoaGRMY2RlM2hwZXBhVmQxYWtlUWNHZ1dkZ2dMZFJiV2c4Y1pnUmN5ZGNkT2dJZEJmMGhLY0xhVmZnaEhkQWRoYTVlcmNKZTNiSmVkZUZoWGhzZlBiVWhXaHRiTGVTY2dnNWVnYVlmVWRvZFloTWhsZ3dkdmROZ1diOGg5aEVlQ2FJaFZjRmhVYlJjbWJGZkNhOWM0aFFkWGFwZmplVGhXaHBmTGNEZTFlSWFRZVpjRWh4YTJhZGFsZEpmQ2hGaFhhaGEyZEVha2FzZ1lnU2R3ZjBncWdPZ3lhTmcrYkJlUWdZYUVnRmRTYWNoaGNNYkRiWmU2YllkbGJkYUtiYmJSYWxkMGZGaDBoVmUzZkdlQmZNZ3pnUmV5YmRoYmFEZGplc2JiYUJnUmZVZUthWGN6Z1FkcmdMaFZoUmhxYmVoVmZGaGxkS2RtZ0FmV2VhYldjRWJXZEdhR2hZaFVoWmhtYlphaGhjZEZkVmh2Yldja2JjaGRoSGRWZFZlYmJmZldmZGRRZllnMGgxY3FmU2N3ZTllU2dFYUdhUmJNZWRjbmFaYlNjUWZoZVZoNGVkYWhkb2REYUdoRWRoZUViWWFtZE5lbWJjZ0VjVmhEZ0hnUmNJZThkS2UwY1VlNmNQZHlhUWhFZEVoRWdwZGNiWWFRZ2RkdmNiZXhlRWVUYWJjMGJkaHpkRWUwZ2Rjb2hGZlVoaGJRYVJkeGZCZm1jY2RsYjViQmJJZmpic2JDZWVnUmVvaFBmV2J6aG9kb2hUYkZjMWJtYUNoV2VaYTJnYWVIZnhlL2ZiZDFicGNIZUhlUmQxZlZhVWJuZlJmcmJlZ21nTmZOZGFka2dzZFBnVWhsZzlla2JTYW5mQmYyZFdkaGZaZWRmTWRTaFVlY2NCZWxlMGVPYkZhamJBYXJoY2FHZjFiSWZRaFVodGNUYWJobGVKYkxjZGMzaHBmcGhWZjFna2RRZEdmV2RnZExlUmRXYjliTWRPZ1dmOWNIZmNheGNOYUhkYWJCY1ZkSWJVY0VoY2NRZlpkamJzZlFiRmVXZElmaGFVaFhmcGFYaFdmd2FCZHBiZmd3ZHNlWWhMZGhoMWVtYVBkVWV0Y3doVmJXZDljYWFSZ3hmMGdkZlZoVmdKYjBjYWYzZHBnamVUZFRid2FLZVhiVmJKaEZoWmNGZ0ZnMmRKZVZnSmFQYkZiV2RsZmdlQ2RXZUViWWZRZTFhbGhpaGNobmFCZHdoU2FFZk5jSmRXZm5iVmU0YlNiemFNYTFoUWIxYmRhWmFFYUJkbGdvZkNoMGhWYnZlRWdSZ05odmJSYzNoTWhUYVJmMmRoYWFkWWNsaEJkSGNFZEdlWmd5aFZnaGFWZHFmY2ZsaEZhM2ZWZjBjb2VXYmFmV2JFZFdnR2VIZGtmVWRiY2pkSWNwY09jUWhaZ2hhRGFGZVlmVGNSYVFnMGdhYUNoemI0YnFoSmR3YndhK2REZWdnZGU0aEVkR2VSZU1oZGRuZFplU2dRZ2hiVmU0YWRoaGNKYUxlR2VFZ05iWmdZZW5hSmh3ZGNoRWhoZURmU2NWaEljaGNkZGdkZ2IvZ09iemFzZjBlRmNsZlJlY2dDaFZnOWVOZEpmeGJFZ1lnYmYxZVpkNmdFYjFodGgwYkZnVmVCZVphUmEwY3hnbWRKZ2xkaGJXZ0lmamNNaERmRmFCaGdlT2VVaHdoZ2ExYUhhbGVCZ3ZjR2JFaHhibWdZZlhlQmFWaGJlMWhwZUhhSGFSZDFkVmNVaG5nUmJyaGVnbWROZU5jYWJraHNmUGNVYWhoQmNrYlJiQ2RKZzRiRWNRYnBnVWdLZ2hmVmNkYURlMWcwYmlnRGRXZm9nNmRjZ0hkdGFJZ1VnRWFCYmFoYWZXZFJiTGhiZjNjTmZwZUNmMWdsaEVlRmR5YnRjRGZCaERhMWV5ZFhnQ2JzYkNmRWVrYmRkUGRJZUJlVmZEYlVkRmNVZFplVGJIY0plV2FGZVdkcGV5Y1VmWGFkZ1hhU2FoY1pocGdZY1JkWWRZY1pmaGdSZG1oWmVtZ0Zmd2RYaEdkTmV3Y1JjeGMwYWRnVmNWZUpnMGNhZTNocGVqZFRoV2JwZkxnRGIxZ0liUWVaYkVjeGUyY2RlbGdKY0thWGNYZ2hkOWNEaDBkc2NNZ1NhbGJWYkliY2VuY0Jkd2hTY0ViTmZKZldjbmFWYjRnU2UzZ2RkNmRhaFZjZGRaZ0ViQmVsZm9kQ2UwaFVlN2ZXZlZnb2c4aFNoU2RVY0JnU2ZUYUJmTmRBYkNiOGdTYlFmQ2NJaHpoQWNsZ0JmaWVXaEZiRmczaFZnMGRvZ1dmYWVXZEVlV2dHYkdjWWJVY1pobWNaZmhhY2VGZFZodmdXZWtlY2JkaEhiVmRWZmFnSWVHY1VoNWhLZHdkd2c0Y0tmRWRBY1dnVmdRZlVkWWJmaGphNWNTZFNhUmVWZXBjZmd4Z0poWGZCZUVoTmdCZWFmM2JJYnNjY2ZCZ3hiTmZDYWhkSWEwY0thaWVnZTRlUGhpYndjMmJEZ1JlaGFSYVlnUWFkaHZhYmJ4YUViVGRiYzBlZGZ6ZUVoMGZkZ29lRmJVZWhjUWJSYXhiQmNtZGNmbGhZZ1ZoYWhuaEphUmVkYTFiOGhlZEdlQ2FvZXBkVmEwaG9oRmJXYnlmSWFqZkFnQ2FSZWRhSmExYXBkTWdIaFFmNWRjZFVhbWhoZjNlZWhuY3RjRWFhZmhnY2ZQZkJiaGg0Ym5mQmNEYWNha2FNZFFhMWNSYVBjUmdkY0dnUWExaEJiRGZVZm1iSmNnZGVnVmJwaElkUWMwaGxoYWRkYlhhaGNMYmRnM2FwY3BkVmcxZGtnUWdHYVdmZ2JMYlJhV2I4Z1JkRWIyZlpkTGdXYVJoTmVIYmFoQmNWYUljVWhFZmNhUWFaaG5jSmNXY0ZnV2dwZXljVWZYYWRnWGdTYWhjWmNwZGFhVmg0ZVlnYmJRZGxjbWFjZG1kaGI4ZGZlMmQ5Y2FnUmh4YTBnZGRWaFZhSmQwZ2FjM2FwaGplVGdXYXBjTGhEZjFoSWJRaFpoRWd4YTJnSWJoY29kTGNSYW5mWWFnaEFkVWNWYkFhR2J4YkVmZGdKaHllQWEwZUNmUmdjaE1oVWdsZjllNGRTYjNiZGY2ZmFlVmRkYVpjRWhCZGxnb2ZDZzBoVmV2Z0VoUmZOY3ZiUmIzZ01lVGVSZjJoZ2JWY1FoQWZSZ0plVWh5ZDRjemZCYkhmWWFsZ05maGJRY1dmQWMwZ0poZWFhZldlb2VXaENjV2M4ZFVhZWZuZXBkaGVhYUZleGJ2ZUJja2dkZ0pkRWh4ZFlmYWhOZlRka2ZaZkxmQWVraHZoS2JsZXRnYWhXZEdkMWNBY1hkSGVaY1NjUWZoYlZnNGJkZGhnSmdMZEdjRWFOY1pmWWduYUpid2NjYUVlaGFEZ1NhVmZwaDFoZWdFZnRiL2VMZG1nY2VVZUVnVmRGZExkQ2UwZVFmQmdLaG5mQmhIZ1pnd2M5Z3phR2hFYWRmN2NIZUViaGhNZ1djeGZCZStoZWcxYlpkSmRhYmljWmhmZ05lQmU4ZExnUmVBaG9ndWdVaGxoMGFIZVFhR2M0ZXVkWWdYZXRhVmJmZVZnTmJ0YUhlUmQxZVZnVWhuYlJlcmJlZm1hTmdOYWFna2ZzYVBkVWJoaEJja2VUYkhiWmYyYlVja2RJYmNmZGFGZHdoU2RTZnhiaGZEZ1dnV2RKZHlmY2RIYUJmSWNRYTBlbGFhY2RkWGVoZkxnZGczZHBmcGRWZTFjRmFZZ0dkV2NNaFdhUmNYYXNhWWFIZjBiVmdIZ2NneGNOZkhmYWFCZFZlSWdVZkViY2dRZVpnbmZKY1diRmhXZHBmeWVVZlhmZGZYZlNoa2ZJY2hkS2FFZFVmV2hNY0FhQmJvYVBjamRraDRoS2RqaG9hS2VBYzFjeGdKYUVoRmdwYWVoYWMzZnBnamZUZldicGRMZkRoMWNJZVFnWmRFYXhlMmZkaGxkSmNDZ0ZjWGVoaDJiRWZrZ3NmWWdRZzFhRWcyYWZmRGhNYTRkQ2RSZkVmcWdGY1RkRWE5ZkthaWFOYnllSWNWZGRlU2ZFYkFmaGNoZUNjMWhsZHpjRWhRZHRkbWJSZ3liOGNUZkVoMmZaZFdnQWRCZ0VnVmhjZHlma2QyZUViM2NRYStnZWRoZWxjK2hXZTJlQWhXZWFlV2hFYVdjR2RHZllnVWFaY21mWmJoYmNnRmJWZ3ZlV2ZrYWNlZGhIYlZmVmhTY2RmR2V0YjZlYWJ4aGxia2NDZEVhY2NUZVFhZ2djYkRnTWZqaE1memNGZmhnMGR3Z2RjaGdsZ0xnQ2gwYnBmWmVmZW1oNWh3YWFjRWNGYURhRmRWYW9oaGhkZWdhZ2QvYk9jemZzYTBkRmVsZVJmY2hDYlZhOWJOYkpjeGJFY1liYmcxYlZnNmVPZFVjZGRvaEZkVWNoYVFlUmh4ZUJibWFjYmxlWWhWZGFmbmJKZFJiZGIxYWRjS2ZGZG1kbGZoYkhkeGZGZk1nRmRHaFpnbWhZZFhoQmJWZ2JkMWVwZkhnSGJSZTFiVmFVZm5jUmFyY2VjbWJOYU5oY2RFYXNkSGJCY2xmZ2d0ZEhjM2dnZmdjUWEwZXhnTmVJYURhNWJ0Z0hha2dnY0hiR2ZEZVlhM2FlaEZhcGNJZFFiMGdsYWFiZGRYYmhlTGNkYzNocGdwY1ZmMWFrZ1FkR2ZXZWdjTGRSYVdmOGNSYkVjMmU5ZEhjZWgwY2NiOGJJaEJoVmJEYlVnRmRaZ3RmWmJtYjVjS2JGaFhhSmg3YVVmU2h0ZlhkSGhtYzBiaGVIZEJib2h5ZlplaGFSZG1mWmVtY0Zkd2dWaFdhOWNhZFJjeGcwYmRhVmNWZ0pmMGNhZjNmcGhqYVRoV2JwYkxmRGIxZHBoRWdIZXdkUmYyaGZnVmZKYlJnYWVIZmhmcWhEYmtoc2hBYlNhbGRrYytjY2ZpaFFmTGRBY0VlTmVDYldmbWJjYUZhWWdYZGRlNmRhYlZkZGNaZUVnQmVsZm9kQ2EwY1ZodmVFYVJoTmR2YlJjM2FNYlRiUmgyZGdoVmFRZFZjeGd0ZkVhR2NaYnlhVmFoZ1ZmcWhjYWxmRmMzYlZnMGhvZ1dmYWZXaEVmV2hHZ0diWWhVZ1pibWZaYnBlT2ZGY1Zma2FSZTBiY2FKZkZhRmNsYzRnZGZHY3RjNmZZZzBlMWRxYVNid2E5ZFNkRWJHZ1JiTWdkZ25kWmVTZ1FnaGRWYzRkZGhoZElmZmFVZ0Fjb2RLYWJkQ2dSY2lmZmJoY0FnYmRBY1NmVWJnZUtkQWg4ZTJjTGZpY3hhZmJjaHhhQWRaY2FhQWF0YkZmYmZ4YUVjVGhiYTBiZGJ6YkVkMGRkZW9lRmZVZmhkUWVSZXhkQmNtZmNobGZZZWRnUGRnY2tlWmFkZjFieGRLYkJieGNSZWhiQ2NnaFJkbWZEZUdkOWVtZVBjWGZBZ0JnRmZCYklmNmhFYVRmZGJWY1VkbmZSZnJhZWdtaE5lTmZhaGtoc2hQZ1VhaGdCZWtmVGVIZVpjMmhVYWtiSWdWZmVlSGhZZ1NnUWEwZ3dkNGZFZFdjSmU1YmNkR2hNYTFlUWgxaFZjR2RkZ1dnQmNDY2RieWdaY3BjQWN5ZUpoWWZHYldlTWVMZ1ZmeGRJYjdhRWgyZjliSGhjZ3hnTmRIZ2FiQmVWYkljVWJFZmNjUWRaZG5mSmNXZkZhV2FwYnlhVWVYZmRkZWRSYWpoeGJwYVlmUmRZaFljWmRoZFJkbWFaYW1oRmN3Y1ZiV2I5Z2FmUmV4YjBmZGVWYlZnSmcwY2FkM2JJZ3JoVGRXZkZhV2JEYTBkWWdaZGFlR2haYzJlZGJsYkpmQ2JGY1hhaGMyYkVja2FzY1loUWcxZmxhaWdjZm5jQmN3Y1NnRWVOZEpjV2VpZ0Vid2VBZmlkUmcwYVBiMGdSZVhmU2NFZUVjZ2hkYUJjQWUvYlZhVmNJZDdnQWFuZXNnNWdSYjJhZ2hWYlNhRmRCZkhkRWFHY1pjeWdWZ2hoVmRxYmNlbGNGYTNjVmYwY29iV2FhZVdmRWdXaEdhR2I1ZUFjSGFTZzVmaGhlYTFoVmUrZkpoMGdjZkJlQWFWYlZjS2FmZFdic2htZ1lmeGdrZ1JnQWYzaEpoZWdPYm1lUmhNaGRkbmRaYlNjUWdoZFZoNGdkZWhmSmNMYkdjRWdOaFpiWWJuYkphd2FjZkVnaGJEaFNnVmFwZTlmTGFEZEFmL2RlYm1hSmJYYVNkbWcwYVpmZGFCZ2RmRmZkYnhkZ2NUZ01mMGhjYm5lYWVBYzlkb2JIYmtlaGhDY09jamRwaG1jY2RsY1lkVmJhaG5hSmFSYmRoMWVkYktoRmNtY2xnaGZGaGhhaGhtZUZhR2daZm1jWWZYaGxhWmRSYVZocGNIYkhjUmgxaFZkVWJuYlJjcmRlZG1iTmROZGFia2dzZlBjVWhoYkJja2hUZkhiWmYyYVdkZ2FvYlZiY2MyaHNlU2RYZXhkRmNQaGNkMmhKYXllY2VIZUJiSWVRZDBkbGFhZ2RlWGRoYkxjZGUzaHBmcGhWYTFia2hRZkdiV2NnZExoRWRTZ2RjWWVRZUdoRWRSZlpneGgwZ2ZlTWdGYTBoM2dCZ1JhZGhVYkpmeWVZYVRkSGNVZUJoeWRVZ1hnZGZYZFNmaGZaY3BhWWFSZ1lhWWVaY2hiUmVtY1phbWhGYndhVmRXYjljYWNSZ3hkMGdkZlhiUWdZZ1BkSWQzZ3Bob2JUZFhhc2cyaERiMGc0Zk1kWmhGYVJhL2hkYmdiNWJDaFFiUWZNYytlYmMwZmNleWRRZzFnbGZpaGNnbmZCZXdnU2hFZU5oSmhXYW5kVmY0ZFNmM2hkaDZjYWVWZWRjWmdFZ0JhbGhvYkNoMGcwYTdoYWJsaHRmdmFUZ0hkTWJBaE9obWhnYkpjVmVGYUJnZmFHZldoWWF1YVZia2FFYlJkT2NsYkZhOGVWZDFjaGFyYlFlMmNFZFdnR2dHY1loVWJaZG1kWmJoZWNlRmVWZXZmV2FrZWNkZGJIYVZiVmhTZWRhR2F0aDZmYWFrYVJlbWNZZVFoOWJTZkVjR2RSZ01hZGFuY1phU2hRZGhlVmg0Z2RnaGhKZkxjR2ZFaE5jWmZZYm5jb2g0Z2NlRWROZGViU2dVZDVmOGJZZTJiRmYzZ2VjbWhsZVhlV2VSYkFiWmhhZ0FkdGdGYmJmeGRFYVRoYmd4Y0FlN2NXYmdlc2F0YkZmVWRBaEZoUmR3ZjVmN2RjYWhmNGdjYWNmVmdoaFJjZGMxY2RmS2FGZm1nbGJoZEZnaGRoYW1iRmdHZVlmN2FTYTNmQmFWZmJnMWZwaEhmSGVSYjFmVmhVZW5kUmVyZGVnamFFZEloUGJoYzVnZGNIZ0JoQmVzZVphbmdaZzJlVWdrZklhVmZlY0hkWWRTZlNieGJoZURkV2RXYUpleWVJYzNoQmdXZlFld2ZGZWFoY2YzZTViaGZkYTNhcGhwZFZmMWhrZFFiR2RXYmdkTGNSY1djOGVSaEVnMmc5ZEhkY2V4Z3NnSWNRY2hnVmVJZlVhRWFjaFFjWmFuZUpmV2JGZVdkcGR5ZlViWGZkYlhjU2JoY1pmcGNZZ1Fja2FZZWJja2FBZnVkTGJ6Z0poK2dHZENkb2hYaENoRWU5ZEVkVmdWaGxlcGRhZXlnNWV0aEhkaWJZZkNkVGNCZ2NhWWNMZkVlVmQvYVhlRmFKYkNlRmFYYWhiMmVFaGtoc2ZZZ1FmMWZsYmljY2RuZkJmd2VTY0VnTmFKY1dkbWU5ZTRiQWJsZDFkNmZhZVZkZGRaZUVhQmRsaG9lQ2EwZlZjdmFFaFJkTmh2ZlJkM2hNYVRhUmEyZ2dnS2hTZkFnUWhQZVdiVGNWaDhnR2gxY0FjbmNQY1FhTWJ1aFdnUmNsZVRkUGhXZmxmQ2ZGY2pnVmJCZUpiQ2FjZXplSWhoY1FlMmZVYWdiOGZSZEhiUWRaZ2JlZWFHZ3NodWNLZndoUWc1ZVJlVWhJZVhnWGNUZ2NiRmhMZURoTmNiYWFnQmNWYzRhZGRoYUpmTGhHZkVjTmdaZFlmbmVKYXdnY2RFY2hkRGNTZ1ZjcGgxZ2VlRmZGYTNjTGNtYmNmVWJGYmtiQmJBYlljRmY4YU5lSmRrZklkZGJJYmdmSWUrYlhlQmNVY3hjR2hVZGdiRWVEZTFla2UxaGZlQmZ0ZVFmSmh5ZUVnWWJMYVJhSmNHYkZnaWNGaHRkRmJrZnRjdmVHYkVleGJtYlloWGdCZFZiYmIxaHBmSGVIZFJkMWRWY1VmbmNSZ3JnZWFtY05nTmZZY2hjOWJIYkdhMGhOZXFoQWhUZE1mN2VBZ1FmdGJQZFBiWGRZYVBjU2UwZ3RoRGhWZUdjSWc2ZmVoWGVsZUVkYWRVaGxjYWRkZ1hjaGZMYWRkM2VwaHBnVmYxaGtmUWVHZFdjZ2ZMYUViU2NkY1liUWhFY1ZjSGFjaHhmTmRIZmFlQmVWZklkVWVFZmNhUWJaZW5nSmZmYURna2dCZXlnVWNYZWRnWGZTaGhlWmJwYVlkUmdZZVloT2N4ZDFkcWJUaEdmRmR3YlZmV2Q5YWFkUmJ4ZTBlZGdWY1ZiSmg4ZkphSGFRZnpoSGN5YVVkZmhRYUFiWmdKZk5iQWFsaDRmTWZoZHNoRmdVYUNkc2JpYUVmbGJZZlllQmNRZ3dmc2NNaFNnUWM1ZUJhd2QxY0poVWJuZ3hiNGRFYUZnMWE2Z2FkVmNkZlpkRWVCaGxmb2FDZDBjVmF2YkVoUmJNZDVkQmhpZkVoVGNFZDJoUWIvZFNjRmJCZ0hiRWJHZFpieWFWZGhjVmdxaGNnbGRGYjNlVmEwYnBkRWNaYlVhc2dXYUdlR2FZaFVlWmhtYVpjaGVjY0ZiVmV2YVdna2RjZGRoSGJSY3hoU2hhZVdnc2Z1ZUtjd2dRZTVjUmNVZklkWGJYaFNkc2NlZ0xiM2JwZTRiUWJoZFZjNGhkY2hnSmNMZEdkRWhOZFpiWWhuZEpjd2NjYkVnZ2VHaFNnVWZkYjFhZWZoZGdhamVLYkNmQWRaZ0hlaGZJYlphZGJSZlpiRmNPZjBhaGZEZEtiZ2VnYTFoRWF3ZDVma2VQZTBoaGNRYVJjeGVCYW1iY2ZsZFlkVmRhZG5oSmRSZGRkMWFkaEtlV2VXYmxkOGZGZ2diaGVxYlBmbWZaZm1lWWdYZUJmVmViYjFjcGFIaEhiUmMxY1ZmVWVuZlJicmNNYm1lTmJRYWFlaGg5ZEhnR2MwY05kcWZBYVRhTWc3ZUFhUWZ0Z1BnUGVYY29oNGJTYXhoaGhEZldjV2NKaHllY2ZIZ0JnSWRRYTBjbGdhZmRlWGRnZUlkZGQyZWRhcGVHaFJoeGJIYUdjU2ZZYURiVGJIZ1FnN2NFYjJkOWhIYmNoeGZOYUhlYWNCZFZhSWRVZUVhY2hRYUlkRGMwZEViRmNXYUphWWVVYlhiZGhYYVNoaGhaZ3BoWWJSZFloWWdaY2hlUmhtZlpmbWhFZmthVmZYY0pid2NSY3hoMGJkaFZjVmVKaDBoYWQzYnBlamNUZldhcGhMZERhMWFJYVFhWmNCY2dkK2dQaHdoRmNNZVFkVGJjYmllVWF3aGRlbmVEYnhnd2RzZGNmbWc1Z3RnU2ZGZ0pnZmVjZEhiVmI0Y1NkM2FkZjZkYWRWYmRlWmdFZEJmbGVvZENiMGVWZXZnRWFSYU5odmRSZDJhd2RUY0VneWFCY2NlR2gxZjRnUmRBZVVjeGR5aFZiaGdWZnFhY2NsY0ZhM2hWaDBlb2VXYWFhV2VFZVdoR2NHZllmVWZaY21nWmFoaGNiRmhWY3ZkVmhCZlZoU2FTaFJhbGFhZVpiV2hKaFFmWWIwYzFncWdTZXdnOWJTaEVnR2dSYU1lZGJuaFpmU2JRYmhlVmM0Z2RlaGhKYUxnR2hFaE5mWmZZY25hd2N4ZU5oQWF4Y0xoWWUxZ3BnMWFlY0VmdGIzYmVibWNsZlhhV2hSZUFjWmNhaEFndGZGYWJneGVFYlRkYmUwZmRjemVFZjBoZGVvZEZjUmR3Y1ljRGdrZU5mb2RKZ0VmUWMvaGFmbmdKY1JiZGExZWRiS2FGZW1jbGFoaEZiaGVoY21nRmVHY1pmbWdZZlhmQmVWZWJlMWhwZUhlSGVSZjFjVmJVaG5jUmNsYktmQ2F3ZlpkSmNrZU1nWWFXZHpjcGRrYlRiSGVaZjJiVWJrZEloVmFlYkhiWWFTYVNleGdoaERiV2NXY0pleWNjZEhlQmJJZVFhMGdsZWFhZGRYZmhoTGZkYTNiUWZvY0VheGYwZFljVGFTaEJmQ2NGaG1nRmdIY0FiR2dFZFZlUGNFZWNoTGZZZEFlUmFhaFdlVWRsYlJlSWdqZVpkZWhRYVNjSWQ3YUFibmhrY0JoWGRoYmdiN2NMZGtjSmhVY2JoZ2ZWZitnYmMyZmhnNWFmZzJnOWJhZVJieGYwYWRmVmVWZUpmMGZhZzNncGdqYVRlV2RwY0xkRGYxaElhUWRaZUVheGYyZGRnbGFKZkxiUGczZ2hoMmhFZ2tkc2VZY1FoMWRsY2lkY2JuYkJhd2NTaEVhTmZKYVdnbmRWZTRlU2EyZTFoNmRQZFJjOGVRYVFleGdjZzdjVGFnY0FicmRIZjFhQWJqY0NlRGUxYVdnVGUyYUViYmJDZFJoUWJEY0dnQ2ZwZDdlV2NqYzlkcWhjZmxnRmczYVZoMGhvZ1dkYWFXZEVhV2FHZUdiWWhVZFpibWdaZWhmSmJGYnNmdWRIZWdkTWhWaFhjbGNzZ1VjSmFpYlFkM2JEY1JlZ2FuZ0NmVWVvZEFkR2REaEFkRWNQZHliVmNjZUZjbGZvaHNiTmExZDRjMGhWYkFoWWhYZmFoM2R0Y3JkV2VrYmhlRGRTaFZjcGQxZGViRWF0ZDNlZWFtYWxjWGhXZ1JkQWZaaEllQWR0ZkloYmJ3Z1VlVGNjZVZocGR6YVhoRmd4ZENhUGUwZ2hnUWFSYnhkQmVtYWNlbGFZZFZkYWJuZUpmUmhkZTFlNWVnaEZhbWFsaGhjRmRoZmhjbWhGYkdhWmZtY1loWGZCYVZoYmYxZm9lQ2FOZHhoMWJWYVVibmZSZ3JoZWNtYk5jTmJhaGtic2NQZ1VlaGVCYWthVGNIaFpmcGVVaGdhRWViaFBhaWVSYWRoQmhuY29kS2dEY1RkRmI2YldobmZCZUlhUWUwZWxjYWJkaFhmaGVMY2RlM2JwZHBnVmcxY2tjUWVHYVdkZ2FMYlJlV2E4Y1JmR2R5YlpiSmRNZEZkc2hHaE9obmFZZkhlRmZBZUpjeGVNY25jb2FaYkZiV2hGZHlkUWdIYTVoWGJWY2dicGVwY2VlUmc4ZVllT2VoZFFkdmZhZUNoSWI0Y0ZiRGMwZjVnQ2hGZ2xkWWJOZkFoWmc4ZkpnSGJOY3ZkWmEyZnBhTGVEaDFoSWdRY1pkRWZ4ZzJmZGVsZUpiQ2NGY1hhaGIyZEVoa2dzYllhUWQxZWxiaWJlZmpjbGIrZUNjd2ZzZUlhQ2hCYllnM2REYnpnSWNiY1BlVmg4aFdhRWVCZEpib2hHZEVleGF2Z0RnUWU5aHZhWGUzYW9lVGRHZzJnaGdjY1JhaGJNZlBkVWJUYVFnUmdHaFZkRWh2Y0Vhd2hWZy9iR2JFZm9iZGFhZFhlTWhmaE1mbWdZYlVkWmVtY1phaGhjYUZoVmN2Z1dia2NjYWRjSGNWYVZkU2JkZUdldGE2ZlllMGRSZ0FiU2N3ZjljU2RFY0djUmNNYWRlbmRaaFNnUWNoZ1ZoNGZkZ2hlSmVMZ0dnRmVsZlpmSWRYZ3doMmZJY2dkY2FPZEtmeGRNYWhkS2YwYk5iZGhlYm1ibGRYYVdnUmJBZVpkYWVBYXRjRmViaHhmRWFUaGJnMGJkYXpmRWcwZmRmb2NGZ1VlaGFZY0RkbWNzZXBlY2RsYzBiVmhlaHdhOWFSY2FnMGZ0ZEtjRGVtZUJoaGNTZmhoZ2J2Y2JmeWZrZmJoYmRWYXBoVmJiZjFicGJIZ0hhUmcxZ1ZjVWJuYlJocmZlZW1hTmJOZWFna2hzaFBjVWhoaEJia2hUZEhmNGcvZUthUWgwZVZmY2YzZllnQmROY2hiaGRmYlJnV2FKZXFkZWhYY0FoVWdRYXdhQWZoZ09hbmNoZEFoZGcyZmdoVWRmZFZka2ZRZkdhV2FnY0xiUmZXaDhlUmNFZDJiOWZIYmNoeGROY0hhYWZCZFZjSWNVZEVmNGRjYlRhSGZKZldiRmhXZHBjeWVVYVhkZGZYYVNiaGNaYXBoWWNSZlljWWRaZWhnUWh5ZWFoQ2RBZTBkRWdXYmNjWmZTZFZhQmNJY0djUWRZZjllT2N6YVlnNmdSY1RjOWFDZUJlbGV4Y0NnS2Z4aGdlNmVmZGtmTmRWaEhkSGRZYTdhUmF3Y2RlTWhDY2dma2d1ZktoM2RnYzJnUWZVZzlhamdXaG5iVmE0ZVNlM2VkZjZhYWJWZGRjWmJFYkJhbGFvYUNhMGNWZXZnRWVSZHNlZ2JSYTNlZ2FPZVJiM2d3ZGNkVWMzYXBnSGVFZkdiWmJ5Y1ZnaGVWZXFhY2RsZUZkM2JWZzBicGJRZUpnamNNZldnRWVIZDBmVWVMaG1jWmMvYWNjQmNwZzBhV2NrYTRjM2VIYlZlVmJTZWRkR2Z0ZTZlWWYwaDFhcWVTZ3dmOWNTYUVkR2RRaFBmZWJEZkFoQWREZVZlZ2JhaFBkMGVZaFloRWRBZlphWmFmYVhhSWI1Y2ZjZ2hzYUxkQ2FBZmdmV2hOaHdmOGN5aEdlemIxY2ZkRmRoZXNmU2FZZFFmdGZmZGJnMWNoZm9hSWRFZnhhNGViZWtldGVvYkJnVWJGYWNjYmRSZEJnbWNjY2xkWWZWY2FibmNKZlJiZGcxYWRmS2FGZm1obGJoZ0ZiaGdnZXlhR2RpZmNlaWNKZVhlZ2hXY1ljUmNjZFNoVWNVZGtoY2JBYmphZ2Z5ZWNhaWE5YUViWWIwY1ZiZGJIaFVmUWZvaFJkR2dkYm5lV2MwaHhlWWFMaFRlcGhHZUFna2hnZVBjQWZHYm9kaGZlZVdkdGNpZ1FmMGJsZWFkZGRYZ2hmTGdkYTNjcGJwaFZlMWJrZVFmU2Z5ZjFlZmVFZkRnMWRmZkVnMmNkYXRnY2F4ZU5oSGZhY0JjVmNJZFVhRWZjZVFlWmJuZUpnV2dGaFdlcGc2Y0FjM2hkaEtmU2ZrY0pjbmdJaGxlcGJYZEtnRmJGZHVlYmEyZzhjamVIZVNjWWZjZEVjMmY5ZlViRWhoZm9lZ2VZaDJmdGUyZVJoR2hOZkhnSmhWY0lnUWNaZkVieGQyZWRmbGVKYkNmRmJYZWhhMmRFYmtlc2RZY0ZjMWdjZDZlUGRTZ0pmNGZHaGtmcGhIZUZkeWNBZjBmSGN6aDRocWhKYlFkNWhSZ1VlUmFCY2tnSWNVZVZndmJFYVJmTmh2Z1JlM2hNYlRhUmcyZWdmVmdTZ0ZiQmZIYUdiRGFSaHlhU2Z4ZFVlK2VmYUJnSWU3ZEdoQWFSZFRkWWRXZGdhWWFTZHliNWVkZ0lkRGVJY1RjT2FSZUllbmVEZmtmOGFNZkRkbGJ4aGJmZWFFaEZjNmFZZDBkMWhxZ1Nmd2Q5YlNjRWhHZFJoTWRkZG5jWmNTZVFna2FGZjJjTGZsZDBkWmZFZEJhRmJRZWJhRGY4ZGxmUGFCZndkS2ZHZFJkWWVzYWNkQmE1ZytoZGhrZ05lWGNXYVJhQWZaZmFkQWN0ZkZlYmd4aEVmVGViYzBjZGR6ZkVhMGY4YTZoRmVWYlZhUWNFZXhoNGFsY1BiaGRsYWJhTGczZXBkWWRlZVFkUWhDZ1hieWY4aDFjWmFGZUVlaGRYaERnSmZ1ZWNoR2VaY2NkWmRsYVpkdGNIZ1JoMWJWY1VlbmhSaHJoZWRtZU5nTmdhZmtkc2dQY1ViaGhBY3doUWFpZDRnNWhBZUVjcGFIaGNhWGVvZTRkU2N4YWhhRGhXZFdmSmJ5YWNhSGVCaEloUWcwZ2xnYWJkY1hhZ2NmZ1BmemhNYzZiV2ZSYkJhZWRVYkRnd2FEYkVhU2NkZFloUWZHZ0VmVWVOZmxjWWVEZFljUmhsYmlhVWdFaGNoUWhaZW5kSmhXaEZnV2ZwZXllVWZYY2RnWGRTZmhkWWU5ZlNneGVZYllhWmhoZFJlbWFaZW1nRmN3aFZhV2c5YWFhUmJ4Y1FiR2ZmZzFkSmUwZGFmM2dwYmplVGRXZnBnTGVEaDFnSmROYWJlVWhCZmNkZGhsaEpmQ2NGaFhnaGcyYUVia2FzaFljUWcxaEViMmZmY0RkVWNvZkdkQWR3Z2JnRGJpZlphNGFWYm5lY2UxaFliRWN4ZnpiRWZCYmxib2NDYzBkVmV2ZlRjQmYwY3NoQmZqZzliZmRUZHpib2JaZ1NnQmFsYlBnQWFHZjlhOGVOZkVhQWNzaE5nQmNRaGxjWGZrY01lTmdRZjJmRWhXZ0doR2RaZkpiYWFrZXhlaGhjYUZlVmZ2ZkhkQmJKZlRlWGVnZkVoYmdPZnllVmY2aGFieGZsZmpkU2UxYlJlNGZFZkdjUmVNZGRhbmJaZlNkRmdGY1FicWJkZ2toQmdRaE1oa2ZOY1piWWVuY0pjd2NjZUJmcGNEZ1ZmRmdwYjlnUGhoZDRlNWRPZlRjMGdlZ0ZkbGQ0ZVpkWWZBYkpiRmNOaERic2RUZ2JnMGNkZXpjRWUwZWRkb2RGY1Jlb2JWYkVhMGdVYjBmUGdGY1plQmNJY2poc2dDZmJmSGgxZUtkRmdtYmxhaGRGZGhlZ2c3Z0hjV2I1ZnZlZWNsY3BlVmRiZzFjcGJIYkhjUmgwYUJiQWdDZjFicmhJZlVhbGhOYmFia2NzYlBmVWVoZUJna2FUZkNjUmMyZlRoMGhKaEhkZWJDaHBhT2NTaDNhNGNXYUZieWFFZW1nT2dUZzhjR2dTZDBmc2ZJZk1kQ2N3Y2VjSmJUZFJicGNBZnhmRmhaZVNibWRvYkNoVGRXZFloUmFUYnpjTmNIZ2Vod2dKY0xnYWFGZkFmZWVFaFFmc2haaGJobmZBZENnWGhTZU1maGJVZjNoNWJNY1ljQmRaY3BmWWVSZlloWWZaYWtobGFtZkpnU2hBZmthRmFpZGRkYWdUZjFkUWNVY1ZjUWFsZGVkYWEzZXBnamNUZldhcGVMY0RiMWZJZ1NkS2R3ZTRhOGZNZHhlRWVXYkZhM2doZnJmRGcwZ3RiTWZHZmdia2duY1BnVGJaYXdoSGF3Y29iSGJIY2pmb2F2Z1NiM2RGYThlYWNWYzhoTGdFYkFoUmVvZlhhQWV3ZmhlVmdWZXdkNGNUZW1lZ2M1ZlJiMmZnZVZnU2NGZkJjSGhUY1VleGZ5ZVZmaGZWZHFhY2JsYkVkamFXZFFkOWFPZ09hU2U1ZEVhVGhEYlVnVWJlZzJoWWJ6YWFjM2E5Y3ZlV2drZmNjZGVRaEZmbGE0Y2RkR2d0ZzZiWWV3ZnNjL2dCaFVld2FHZldkU2ZzaENlZGFuYjRkR2FUZmhiVWFxZ2ZmeGdJaFFkTWFrZU5lWmRZZ25hSmR3YmNhRWJvYVdnR2RoZTliMWJLZ3hoOGRsYk1meWZvYURiV2h3ZHNjemFhYkFkdGZGZmJoeGdFY1RjS2FSZUloOWJVZEJmTWhoY1djZ2daZVFoRGVoZ2doeWFlZjFkWmdPZFFoSGNKZ1JnZGQxYWRjS2dGZ21obGNoZ1FhRmFrYzBiRmREZFJjbWdmZUhhQWNCZlloUmhZZENlVWYxZ29jQmdHY21lOWJCZ2VlbWFOZE5hYWRrZ3NoUGdVZGhlQWV0ZUNmbmVaYytmQWhFZ0liUWhlZEdjSWZTZVZkUmRoZVRmVWdFZWhneWdjZkhjQmNJYlFiMGRsZmFkZGRYY2hnTGZJYnphSWQ3ZUdnQWM0Y1FoVmZ5YTFlY2RSY1FhcGREaFFmU2NBYVZjZWh4ZEVldWFKYWtnTWdKZ0hjQWQ1aFVkWmFpZkVnQ2FSZHllTWg4Z0ZibmZsYVhkSmVsY01obmdKYWtlSmdRZFpobGVraHpjTmdUZFZld2ZGYXlkcGhhZkJlaGIxaFFkQWJCZDRmZ2FJYmlob2N2aENkR2FvY0VhU2FWY0loRWVaYmthVmR0YlhhRmJKaENjRmdYY2hnMmRFZWtnc2VZZkVhUmF3YjJjSmN5YUljK2ZTZ0VmRmNVYVdkSGdWYmxlVmNtY3BmNmZQYVNnd2JMZEVjQmdSYm9hR2JUZmhidmhEYmhnTmY5aFJiMmZrZlRhUmVYZVVlWGJTYUViMWRhZURhV2JZZW1iTGNVZ2RncWFmZDFmRmdtYktka2ZvZ0pnYWJYZ0FoV2FBaG1oWWNFZ2ZjVWJ4YWhlY2NGZFZndmFXaGtmZGFBZU5lMWZWZlNjZGFHZHRlNmhZZHdhc2YvZUJkVWh3ZEdjV2RTZXNjQ2dkYWpiTmhhYUZoaGJ4ZjRjTGhUZ2hhTGdHZkVnTmRaZFlhbmFKZHdnY2RCZG9kR2ZIaFFhOGhuZE5na2V0Zi9lYWdXY2xjZGVXaFVoUWJYYkpoRWI0Z0xkS2RFY1ZiYmVaYmtjZGc4ZkVkMWhOYm9jR2FFZWdmWmZUZzBjUmJ2Y2FhWGF3aFZoYWhuY0pjUmNkZzFhY2VYYlBhR2NsYWhkRmNoY2hnbWhGY0NmQWV6Z0xlemhNZEJhSmJoaFVlSmNIaFZnSmdkZkJnbmYxZ3JnSWJVaGxmTmRhZWtnc2hQY1VhaGZCYWtiVGdDYkFlM2RBZkVoSmJIYmRnRmh3Z1NmU2d4ZWhjRGRXYVdlSmN5Z2NhSGVCZUllQmRrYVZod2RkYVhjaGRMYmRoM2VwY3BkVmcxYWtiUWdHYVNnY2JIYWJoMmg4aFJhRWMyYTlhSGRjZ3hhTmJIZGFoQmRVZ0FlWGVHYjBnUWZaY25kSmRXZUZkV2RwZ3liVWVYaGRhWGRCZUJmcGZEY1lnUmZZZFliWmVoYlJibWZaZm1hRmF3YlZjVGV4YmFkV2doZzFoSmVXaHhoNGN4ZEpoVGcwZDNoQmhYYUZmaGNEYTFoSWRRZ1piRWV4ZzJlZGVsY0pnS2JYaFhoaGZyZkVjZ2dJZ1FlRmIxZkJhcmhmZW5hQmE0aEJha2ZOZFVoV2hqZ3NmOWNIZEhnY2Y4aFlnVmE5ZktnRWJCY05hb2ZXYUVneGJ2Z0hjaGROaDdmUmYzYjRnVGFEZzJhRWZjY1JjRmFCY1BmVmJXYVpidmZWZmxiMWJxYWJoRmRGaG5hVmcxZlVhV2FPY21mRWViZEdhSGdJYlVmZmNHaFlheWZlZVVoNWRGY1dla2FjZGRoSGZWZFZkU2VkZUdic2dzZElhaGE5aHFkQ2RnZDlnUGJFYkhjUmRYZ1hiSGZaYVNiUWZoaFZiNGJkZmhmSmVMZVhnZ2R3YUxiWWVuZW9haWFjY0ZnVmFEZVdiVWVGYTFjUGFVYnRmcGFlZ2pjdGdNZFdjVWZJYlplWWd4YVpmRmRlZXhjZ2c1aGJoMGZkYnpiRWgwY2Rhb2RGYlVjaGVRaFJleGVnYXBoY2hrZXNmL2hhZG5hSmdSaGRhMWNkY0tmRmVtYmxiaGFGYmhlaGFtYkhoRGFNZ2RiTmdYZDRhV2hKZHhmc2NWZGZnbGhJZVJoRmV4aFVlL2JjY2pkRmRFZkZhMGdzZlRkVGZoZUJhMWdWZ0hlOWgyYURkbWNnZFZkZWhIZ1loU2JTZXhiaGdEYldnV2NKZXloY2ZIZ0JnQWdGY2pnSWdPaGVmemhzZERjTmFpY2dnS2NHaEJjMWhWYWVoRGN3Z0RnRmIyZThhYWRFZzNlNWZPZURkaGROZWJjZGZCYVZhWmhRYmtjNGRRaE9hbGNoZldoRmhXZXBneWRVY1hkZGRYYVNiaGRaYXBmWWJSZVlmUWJNZDJlOGN5YWFnQ2hJZjRjRmREZzBnNWRDZUZhbGRZZU5lQWNaZDhnT2FYY3Bhb2hUZlhnaGZDZGNlbGhJaE1hZWFFZXhjZ2hmZTFhSWZlaFBhM2VoZDJiRWdrYXNmWWJRZDFmbGdpZmNobmhCY3dhU2dCYVloeWVEZm5hc2M3ZkFnemhZaG9mQ2ZoZGdkZGRWYVhkZ2U4ZUFieGZkYXZhR2NoaE5oOGJUaGdjNGVhZ1NoMGNJZFZkU2FGYUJhSGRFYkdoWmZ5ZlZkaGZWYXFmY2VsZEZmL2NHYVRnRmhYYVljbWRwY3JhR2dIYnNjVWhiZWlkbGZoaGJla2V0ZXZhU2QxYkVkVWZIZlZlTmRTZlpibmM1Z3ZlYWVrZEZhQWdTZ3doOWdTZ0VjR2FSYk1lZGhuZlpmU2VRZ2hkVmU0aGZnbGF3YndoV2RVZmhkU2hIZjNmSmd0Y2NjRWVBYk1hU2ZVYVJncmVlZ0ZoTmcrZGVobWE5aFhhU2V3YVVoTWdZZVFiZGh2ZmJkeGNFaFRlYmYwYmRiemdFYjBjZGFvaEZnVWRoZVFjVGQxZTRlZGZNYTFoMGhlZkZiM2hKZ01iZGMwZFZlZmFBZzJnbGduZEZobGVkYnZkRGQwYXhkbWJZZFhhQmRWZWJlMWJwYkhkSGZVYThjUWFCZmliRWE1Yk5iR2ROZUZnUWhFaHNlUGRVZ2hkQmZrZlRmSGdaZjJlVWNraElmSGRlY0dkc2JQYVZmaGFnYkxkY2QyZUpjeWJjYkhmQmNJYlFmMGdsaGFjZGRYaGhhTGJkYTJiVmZwaFhiMWVGZmZjR2ZYZlViTGNUYlRhcGRxYVJhMmJFY0VjT2MxaEllVmRDYzFkb2JNaEZkU2VaYkVlYmdpZUJlZmRhYkdhcGN1Z1RiWGVkY0ZhUWF4ZlliMWJZZ1JiNWZOYkhoVWdCY29jSmdTY2theGNCZHdhd2JWZkFjMWJoZzhnQWRWZW9mbWNhYzNhRmZqZlhnR2dNYTJkRGUwZXdiT2VaYkZnaGcvZmZnMWY1ZG9jRmNYZmhmMmRFZmtmc2VZYlFhMWFsaGlhY2ZuYUJid2dTYUVjTmVCaEZoQWg0YzVlUWRIaHdiSGVhYVVmcGNaYUFjZ2F4ZzliQ2gwYU5jdmhYY2hocGVtaGJkWGJNZFRmUmUyaGdlVmRTZEZiQmNIY0VmR2VaY3ljVmFnZjllcWFZYTFhRmNxZ1NlbGRjYVdnSWRXZ0VkUWFIZmtod2RVaFpjbWNaZGhkY2ZGZlZldmRXZGtkY2FkZUhkVmVWaFNmZGVHYU5meWZMaEViMWYzYllnUWY5Y1NkRWVHaFJoTWdkaG5iWmFTYVFkaGVWYTRkZGFoZUplTGZHY0VlTmdSaE5md2FrYmtmZmRnZHNlTGNDYUFlZ2hXZ05nd2U4Z3lmR2Z6ZTFhZmVDYnhobGNrYmFoQmNkZVpiYmh3ZkFmRGVaYWthY2V2Yk9nVWJkZ29mRmVVZ2hlUWNSZHhoQmJtYWNmbGNZZVZnYWVuZUpmUmZkZTFkZGhDZlFmeGFJaDFkR2hGZ3NmdWVWYVRmUWRGZExjamdRZFFlRGFnYTViUGdUZnhlMWRlYlVibWRWZWlnQmIyZU5nUmZkZWtoc2ViZldieGRBYTRmWmduZVpnMmRVZ2tnSWZWZWVmSGZZaFNiU2F4Z2hhRGVXZFdhSmd5YmNhSGJCYkFlRmVqY0loT2RlZ3pkc2hEaE5maWdnZktnR2RCZDFoVmZlZkRkd2hEaEZlMmM4ZWFkRWYzYTFoT2dEZWhkTmJaYmRkaGNWZ2FnV2dVZzRhY2dUY0hmSmhXYUZoV2dwYXliVWNYZ2RjWGVTYmhlWmhwaFllUmVZZVljYmVsaG9hZGFKYzJicGc3ZUtnR2c5ZEhkUmJ4YVZiU2FWYVVjeGFxZWFiMmVKYXFkVGFXYnhnTGFIY1VjY2dGZmJmVWFCZmNmZGRsYkphQ2RGZlhoaGgyZEVma2ZzYVloUWExYWxkaWJjYW5nQmg0Z0JnamFnZ0loVWdYYzRnRmVTZDJhcGQ2ZmVnMGVKZE1hRWJCYjllb2FSZUVmeGNtYUhmVGdsaHZnUmczZE1kVGJSYjJmZ2JWZFNmRmdCYUhoWGRrZ3hieWdWZGhnVmFxYWNnbGJGaDNoVmUwY01nTmFRYjJoRWhXZUdkR2JZZlVoWmFqZnRmTGNjY0ZoVmF2YVdna2JjYWRjV2V3ZEFkY2FOZXpoOGR6ZUxiQWNOZnFjQWR3ZWNnR2RHaFdhUWdYZVhiSGZaY1NiUWFoZFZmNGZkZ2hoSmNMaFNnZ2JZYU5kTmN5Z0FkK2hjYUVkQmdwZFNjVmFwZTFkZWhFZ3RiM2NlY21hbGNYYVdhVmJGYWljWWZGZDloRmJjZFFhOGJUZ2ZobGg5YTZnRWIwYUZjb2dBZjFhc2N0Y1JjeGd0aG1nTWJ5ZjBnZGRQZm5kSmdQZmFnVmZkYmJlQmFHZEJnaGFFZEJjaGJ3YkJoeGJ0ZG1jYWNuZ0FjVWFGZEZmSWZUZ0hmUWNOZExmVWdtY0pkaWRlY21oVmVOZ2ZiRmRoZHlhVWhoZnRia2ZEZVFmMWNnaFFnVWVJYVRoZWVDZEpldmNZZVJhaGNEaFdoV2hKYnlnY2hIZEJmSWJTaGxkSmV3ZGRlWGNoYkxhZGYzZHBncGhDZG5jTWFRYkdmV2dnZkxkUmJXZDlmWGJSZWlkRWVFZ0pnMWhvY0llSmJoZ1ViR2dXaEJmTWFjZ1plaWFCZ2FlRmhTY05jN2VVaFNjeGM5YVNiaGVaYnBmWWRSY1loWWFaZWhjUWdnY0tjVGJOY3dhWGVUZmtmYmVGYVJjMWVZZFdlVmFJYTdlYWMyZWRiamROYmhjZGhIZ0RoeGR3ZFFnZWJVYXdka2ViaFZhSWVMYUZmV2FaYjJlWGVGZEFkWWNEY1ZjbGhwYmJlM2ZCZWpiUWFXY2xlSmFXZm5mVmc0ZVNhM2dkZTZoYWFWaGRhWmVHZ0ZmeGFvZEZia2JWY25oUmVXYWdhaGJPYW5kTWZQaFdhMmZnaEVhWGJsY2xlSGFHYjJkWmE2ZUFhbWM0Y2toY2hsY3BnM2NSaGpjY2NXZWRlWGcwY1doQWdHYThoVWZiZVdmWWMxYkNoeGN0YnZnVWFVZGNiUGdZZUZmeGNlZmRkQ2dSYzBlTWd4ZmdjNWRBZHdjY2FhZ0dhQ2NGZkZhZmYyaDFhNGdRZGhhVmE0ZmRoaGJKYkxnR2hFY01lTGNKZXljWWNsYklkZ2JaZERjQmRsZVFiL2ZOZXdmSWQ1aGNnbWh0ZVZiVWNBYXNoemZhaEFkdGZGY2JkeGZFZVRnTWRtaDFmemNFYTBkZGFvYkZhVWRnZ1dlRWVsZjRmbGVKYWhmOWJhZ0phSGFJYkNoZmh3ZU5kRGdGYmpjSmNMaEZhaGhoZW1lRmhHZVpnbWRZYlhjQWZUYklkQWNoaEhjRmNUaGRkVmFVYW5jUmZyZmVobWROZ05lYWJrYnNmUGJCZkZjRWMyZlRkQ2FSZjZjZWhFYklkVmdlYkhlWWZTZFNoeGhoY0RnV2JXYkpneWVjYURlbGVJYlhja2RrYk9lZWV6ZlFjT2ZPZVRkMGg5ZkhjMWJVZzZhR2dXZWdhTGdSZldoOGFSZUViMmY5Y0hhY2J4Z05jSGVMYVJnVmNWaFVhQWU0YlFlWWczYUplRmZHaFVlQmN5ZVVmWGZkYVhnU2JoZFpncGdZZ1JnWWJZZFpoaGdRYnBnWmZuZHhod2JWZTJhMWVXaGJkUmQwY2RiVmNWaEplMGVhZjNkcGdqZVRkV2FwZUxjRGJ4ZW9nUWdlZlVid2NOZkNhMWg1Y29oRmVYY2hjMmVFZmtnc2RZaFFkMWVsZGlmY2JuZ0Jhd2RHYjBlTmNVaFdlbWZSZ3VlV2JHZTljcGdaYVhlMWRaYUVhQmdsZm9oQ2cwZ1ZldmNFZlJmTmN2aFJhM2FOZEdhUmgzZFVkVmJXaEZkeGR0aEVkR2JaZHlmVmNoZlZocWZjZGxhRmEzZVZjMGNvYldiTGgyZ0VmTGdHZUNjOGdVYWFoMmdZZ2tiYWUzYjlndmJXY2tkY2NkYUhlVmVWZFNhZGFHYXRhNmVKYVVjMWcwZFNhMWFwYUpoT2VtYlJhTWdkZG5jWmVTYVFoaGZWZzRiZGFoYklkZWdHZUVmaGZFYVloaWdGZWFnY2dFaGhhRGJTY1ZjcGgxZWVjRWN0YStoVWVHZGxmWGdXaFJmQWNaZWFkQWN0ZkZnYmZ4YUZmYmJZYVJjY2FtZ1FlQWQ5Y2dnV2MwZEFjRWVTZnhjQWR6ZmZkbGNaaEFoYWFuY2xoUmRKZUZnZGdVaEZlaWQ5YmhhQ2ZSZWdiZ2dGYUhleGZtZ05jSGNCZ2VjYmF3ZGxkT2VGaEFkWmIvY1VkbmNSZ3JmZWVtZk5nTmFhY2tidGZkZUZiMGJRY3hiSGdqZmhnMmVXZG1kZ2RWaGVnSGVZYVNoU2R4Z2hlRGNXZFdoSmR5YllkWGVCaFZjWGhsY1JhYWdNYkZkSmJMZ2RmM2RwYXBiVmMxZGtmUWRHZldlZ2VMY1JlV2U4Z09mRWQyZGRkUGdJYlJjTmdhZGFjRWhFaHpnR2RVYWNmZGhaaG1hTWRyZ0hoR2RaYVljVWhYaGRnWGZTY2hoWmJwZllhUmdZZVlmWmdoYlJobWJaZW1lRmM0Z0dmbWE5ZVJlV2VoaDFoY2NMYWdmQmEwaGRhV2VSYWpiWGN4ZmRnQ2VBYjNiZ2ZRY1piRWV4YjJiZGdsYkpoQ2dGY1hnaGcyZkVla2JzZllhUWExaEVkdGFjZW5hdGd0ZlNjQWJJZ3llVWVpYWRoNGhWZjJhdGE2ZGZoVmI1ZVphRmVoaGxmK2VHZURlaGJtZUhiVGdsaHZkUmQzZU1nVGZSZTJhZ2VWYlNoRmFCZUhnRWFHYVpmeWZWYWhjMGVsZGNibGRwZ3FkVmEwYmdnTGNkZkdmTWZmYUVlVWh3YVVkWmRtZ1piaGNjaEZiVmh2ZVdoa2djYWRiSGRWZVZoSWZkZkhobGU2ZGZobGJCZDNhU2QwY3BiU2hGZG1kSmVtZGRkbmdaYlNnUWFoZFZlNGdkZGhhSmFMaEdiRWJOYVpnWWNuZEplNGNlY0JncGFEaFZmRmFwZjlkTGJEZUFhK2RlZW1oUmRYaFNlMmgwZFpnZGJCaGRjRmdkY3hmZ2hUZlpiRWZjZ25iYWhBZDVjb2RHY0VjaGFCY09laGZsZXFhV2VGY1llVmZhY25jSmdSaGRjMWRkZ0tiRmRtZmxoaGNGYmhmaGhtaEhkQ2VsZ21kYWRtYjFoVmNMZmlkRWdWZkhoUWFOaExmVWFtYVZkN2ZCYTJhcGFCZVFlRWFzYlBiVWFoZEJma2VUZEhhWmYyaFVla2ZJZ1ZlZWdIYlllU2RRYTFlZGVEZVVkbmU5ZnlhTWVRZ3RnQWRFZFVjbGNFZGFlM2NoZmZiZmNuZnBmdmRWZTBkOGZEaFphR2RFYkhmYmUyZjhmUmVFYTJmOWhIaGNieGZOaEhlYWFCZlZhSWJVZkVnY2JRaGJmamcxZldmSGFuYmRjeWJFYkFjeGZmY0dmQmVaYjFnZmNSYVlmS2JiaHhmUmRnZlpnbmhkZGpkS2JHZlphV2hiZ1JkMGFkZVZiVmZKZDBiYWYzZnBoamJUY1dmcGZMZURiMWdJZVFlYmZBZU5iMmFmZ1ViOWJDZkZmMmNWYjBhR2cwYkliVWRhZFZobGVpY2NnbmZCZXdiU2VFYk5kSmVXZ25kVWF3YlJmU2FjZnZnT2ZoZjlmUmZYZnhoQmdrYUllVWFWZnZmRWdSZE5jdmdSYjNlTWhUYlJmMmZoZ2RnUmRoZW9jSWhXaFNmaGM2ZlZmQmhkYWpoV2RGaEZlM2hWZDBlb2VXY2FhV2RFY1dkRWVYaDBlK2haaG1mWmVoYWNkRmRWY3ZiQmcyZjBlZGZIaFZmVmFTY2RoR2Z0Z3llTWZVYU1mb2VFYmxoc2VYZmZmQ2NFYUNoTWdTY0liYWdRYWdhaGc0ZE1jeGF0Y0hhR2NFZnNkTGRiaENjWWgvY0VlaGRFZVhoRGZEY3NlbmFLaGdkb2h1ZGVhbmRSZVhlRmFoZmtjVmdhZUFiTWZYYVliVmNkY0JkSWRBaG9mUmhTY2hjTWN0ZGRoQmVvZENlQmhrZGxlbWhiaDFnWmZHYVlhMmhsZjdoZGIxZGRlS2VGYm1hbGhoZlVhRmFjZzBiRmdHZTVmTWFZZVhlQmVWYWJoMWhwYUhjSGdSZTBoRGVFY3lhWmVyZ09mMmVOZlFnYWhqYkJkeWRYZ2pjcGdrY1RjSGNaYzJiVWRraEllVmhlaEhoWWRTZ0hlaGNoYWVnV2dSZmtkUGdmYkZocGZJY1FmMGZsZGFjZGhYZ2hiTGVkZjNhcGZwZEVlVmdrZE5oR2dXZXBjZWZDY3ljdGNVZVZkU2JZZEplTmZsZmRhRmNhZEJoUmFWY1VoQmZOZkphTmhqY2NiWmJVYjJlb2NIZEdjRGFrZkRkVWhuZ2NiN2FNZTFiZGVCY1pjZ2R0aG1mRWJ5YWdmK2JBZ1hhY2c3ZEZhVWE5Z2NnRGhGZEpmdWhhZXhmc2R4Y0hmeWRzYlNmQWUzZWdlUWVaYkVjeGQyZmRibGNKaENiRmdYZGhhMmRYZmtoc2JGYWFlVmNsaGlkY2RuZ0Jkd2RTZkVjTmVKZldibmNWZDRoU2IzZ1VlYmNDZXphUWY5Y2RoWGI4YVBnWWV5YXdoRmRlZW5mOGNDZ0toUmh4aGphTmdoY3BjbWZQZENiVWh4Z1pkeGQ0ZExoTGRGaFFkb2JNZlJoVWZ5YUVoUWYxZ2VmSWVDZXRnZGVWaENodGRhaEtiVGNZZHdlSWNnZ1lnN2FEZXhmRmRLZlJlUWJ3ZUlnWmdIZXBib2RjZ0ZhbGcvZlhmUmRoaEthQ2RXZzljRGhkZkhncGc0YVFoaGhWaDRjZGFoYUplTGZHZEViTmdaZFlnamJGaHdiYmNVYmhmVGdSZ1hmQmQxYmVmRWJ0YjNjZWZtaGxhWGZXZ1JnQWNaYU9kQWZ0Z1lnYmExZzBnZGVJYndlSWE5ZlZkQmNNYWdiRGJtZ0phUWZSZnhiQmRtY2NlbGRZYlZmYWZpZ0poUmdhaFZlY2NKZURnVWFOZ2hmRmhoZWhibWhGZEdiWmRtZFloWGV0YmVjTGFIYUJhSGhIZVJkMWRWaFVhbmhSZ2ljVWhHY05kTmNhZGtmc2JQYVVkaGVCZGtlUmdEZWNkTmdFYVRkOGFWZ1pmWGJaaGVnTWZGZnNhK2FVZUdnNWZ5Y2VhQ2JVaHpkRGEwZmNkWmZQYVRla2ZaaEZmRGNVZXRiRWFqZmhoRWdFZlNjc2FDZE9nR2I4Zk1oRWd5YnhmT2VhZERibGdIZmFlQmVWaElhVWhFZWNoWWdNZXdobGdVZUdoR2RoYjhnRWNqZDhjV2JHY0hlVWNtZ0pkVmNOYjVhTWJoYnhmMmNiYnhoeGJ3YVNnR2Y5ZE1nVmJSYlFhUmRWZFZnb2hoY0VmSGVnZmNnVGMyaFFlSWNSZXhoTmhDaEJld2ZNZXlkTWF6Y01nV2NIZFdjaGcvZ2JjMGVzZEZlUWcwYzljeGFlZzJidGdhZlNmRWFOYkphV2ZpYmhhMGJZYlhlZGg2YmFnVmVjZmZkUmVWYmNicmdYZndmd2VnZFhieGROZm5lRWYzZjhnVGdGZVdkRWNWY0ViM2RwYkhnRWRHZFpieWRWY2hmVmFpYUlhRmU4Z2xiRWhnYnRhU2JhZFhod2NXZ1hnamFOZWFhSmFUZUlib2dQYnhkdGR2Z1VkaGZNaFJiSGRRZmRhZWVkZENiSmUyZVlnd2FoZG1hU2UwY0JlYmFFZ0RkOWdtZmRibmdaZ1NoUWRoZFZnNGVkYWhmSWVkaFdnUmhGYlpiS2ZuZjVmYWFjZ0VmaGhEY1NnVmdwZjFkZWFFY3RkM2ZlaGloZGNiYWNheGFBYVpoYWFBZ3RiRmRiZ3hhRWRUYWJlMGdjY2dnRWQxaHBhb2REZFVmaGZhaFJlMWE5ZG1iZmMxYlpnUWRhZ25iOWFSY1pjbGV0ZGdlRmdtY2xlaGVGZmhjaGVtaEZnR2daY21iWWdUZkZhVmZjZ2xhcGFQYURmQmUxZEplVGVuaFFiNGdjZTJjTmJBZmFkbGdvY0RnZWRCYkJma2dUZUhnWmQyZ1Via2FJZFZkZWhIYlpmSGdTZ3dmVmZEYUdoR2hKZnNlYmJuZ0JkWmZUZjJnTmFhZmRjWGRoZExmZGgzZ3BjcGZWZTFoa2JRZFhmMmJnY1dmUmJXZklhR2ZIZjBmVmJIZGNieGZOZ0hjYWRCY1ZkSWJVZEVhY2dRYktmbmFKZ0xlRmNTY05ieWdUZG5hY2NZYlNiaGN0Z3BnY2ZCY1lnQ2haZWdlUmVxYlRlR2VGZndjVmRXYTlkYWNSY3hjMGRkY1ZiVmNJZDNnYWUyaGRlamJCaEdocGFVZURoMWU4ZEJjWmRGZ1poMmZaZTFiNWFvY0ZmWGJoYjJjRWFrZHNiWWNRYTFnbGNpZmNmaWZCZXdjVmRVYU1oZGFJZ1NiZGg0ZVFmSGVjZjJnRmdFYXhmemNFZEJjbGhvZENnMGhWZnZkRWZSYU1lcGdDZENmRWdUZlRlMGZJY1ZkU2ZGYUJnSGJFY0diWmN5ZVZjaGVWZnFkUGJsaEZmOGhTY2tncGdWZlpiV2RGY2ViR2hIZXNlVWVOZW1kWmRuZmNiRmExZm5nU2IwZWNmQmRBZlZoVmVmaE1kbWZKZDZjYmdrZTFiN2ZRZWdlTmNTZFFnR2FSZFNjYWhHZHRiU2NUaDFnTmMwaGRhbGVSZUxlRWYxZzViWmdNZ1dhbGNhZ2NkRWJoY0RmU2NWYnBhMWdlZ0VjdGEzaGVnaWg5YlhjUmZ4ZUFkSmFjZ3lhRmdGZGJmeGZFYlRkYmUwaGRlemdFZzBjZGZvZVhmVWdoYU5jUmR3Y0pjemhaY0ZiWWRmYWFiamZwZ1JmZmhGY2NjZWViYlRjdGJoYUhnUmZnZnFkYWZXY3BibWFMY1hiQmNlY2NibGhvY0VoRWRSaDBhVGVVZG5lbGQyY2VobmJ0Ym5nYWdraHNiUGRVY2hhQmdrY1RnSGNaYi9kU2hXYmdkVmNlYkhoWWJTZ1NleGFoY0RiV2ZTYVFlOWVJZm5nQmJBZWFlVWRsaGFhZGRYYmhlTGZkYTNmcGVwZFZoMWNsZWVmR2FYYVVhTGdEY1dhOGhYaEViMmRkY1BkWWFoZ05oYmRkZ0JoVmFGZEZoa2Q0YVFlYWgzZkpmSGRIZkdjWmR5YkdkWGVkY0pkVmFBZHRjcGNiZkZhQWVVYVpibGVKYm1hYmJYYXhjd2NFZUhiUmh3ZFJoeGMwZGRiVmFWZUpnMGFhZDNhcGhqaFRnU2d4ZExlRWhWYUlhQWFmYzJiWmcyaGRmbGJKYkNiRmFYaGhlMmZFY2tmc2FZZkRoVmdsYS9nY2JtZEpobGZYZmthTmdEY1doamd0ZTRhUWhIZGNhdWVFZGdlVmNaZ0dieGdrZmtoZGhrZWxldmVYZFJjTmZrZFdkbmFOZFFoU2UyZWhhVGFTaEZlMWVhZ0VmSGU1YVlnVmNoY1ZncWFjZ2xoRmQzZ1ZkMGdvZ2ZnY2VrY3NjV2RHZkdoWWVVaFpnbWFaZWhhY2NCYndocGdXZ2tkOGNOaEhhVWFoZVBkYWVXYnNoeWZhZGthMGhpZ1NheGhKYlNkQWRXZFJhQmZkZWlkTmFKZGFnQmFWaDRoZGFoZ0phTGNHaEVjTmNaZ0phemY0YWpiTmJVZ2dkWWZZZzFmcGYxZ2VjRWZ0ZDNmZWNtYmxoWGRXYlJmQmRRZUxmZ2J0YU5mSmF4ZkViT2FjZmxjcGh6ZFVja2g1ZG9iUmZ3ZjBhRWNFY2tlSWJvYmNnaGVnYVZjZGhYZEplQmZkYzFiaGJLZ0JnbWRsZjdiRmJoYUFlMmFGY0hlbGhtZGJlR2dGZFZnZGZWaHBlV2JGZ0JjMWRmYVVjbmN4YzZjZWVtaHhlTmdlZWtoSWVVYmVmQmZCY2tlVGNIYVplMmdVZGthSWNWZWVjSGVZZmFnQmZSZWhmSWdSY0dlSWdmZU1nU2ZRYUFnVGdSYmtnVmRJYW5kQmZaY2VlM2hvZXNlWGdsY0FkY2RHaFdkQmREZVJmV2RJZk1lRWV6Y3BlT2FhYURlbGJIYmFlQmRWaElkVWVFYmNoUWZaZ2llOWg4Y0ZhV2VwZnlkVWVYZmRkWGhTaGhiWWQ3YkpiRWJKZU5jTmFGYnBlbWZiZ2phRmZ3Z1NhbWQ5ZVhhVmhoZDBjSGhWZ1VlTmg5aGFnM2hCZGpoQWIyaHBjQmZEYXpmOWFSZk1kQWdSZDRoSmVoYTBjVmZIY1dncGU2aEVhZ2VNZFliVGVsaGthbmVlYjJldGNhaFNkRWFOYkphV2huYVZjNGdGYW5hNWgyYlFkMWdkZVpiRWRCYmxkb2JDaDBhVmF2YUdnVWNGZmhkRWZDZ0ZkYWhFYnlmMGZWZVZkVmJBYkJhUmJTYWdheGhBZWxhd2ZsYlBkRmZGYi9kQWYwY1ljV2ZPZTJnMGhXaFVhV2JvZFVkSWEyYnBoaGZQZzFobGN2aEVna2Q0YmRhUmRuZzlnU2VkYUdkdGc2ZVloMGExZnFjU2R3YzlnU2FSYmlmVWdlYmRlamNoZ2VlYWJCaFZoNGVkYWhkSmRMZUdkRWZOYVplWWhuaEpid2JjZUJndGNQY1llMWFwYjFlZWJFaHRkM2VlYW1kbGZYZVdnUmVBYlpjYWFFY3BhSmRSYlJjRWhUZ2JkMGhkYXpoRWcwY2Rmb2ZGYVVlaGFRYVJlMGFWYW1nYmUxZlllTmVhaG5oaGFSZ1BiMWJkZEhiRmdpZFpnaGhHY3hlaGczYkdjRWF4Z21jWWhYaEJoVmdiZzFncGhIZ0hnUmcxZFZoVWVuYVFldGhlZ25lNWdOYVlobGNvaFBlVGhnaHhna2hHZFhjOWMyZFhmMGNJY0VkZGFGZHdhU2RTaHhnaGVEY1dlV2FKYnlnY2RIaEJmSWZRZDBja2FXZmRnV2ZWZUxkTWNYY3BoM2NTaFZoa2JCY0ZoVWFJZkxlUmZXZzhoUmVFZzJjOWRIZGNieGhOZ0hnYWRCaFVoTGJVYUZob2VRaGRkR2hGYldmQ2NIZmRodmNVaFRhaGNYYVZkUmZZaEVkSWdFZkpiUWJhYkVjUWVwYU1kV2VsYWlhV2NXYTlnWGJWZVFka2NVZlZmVmQ5YjBkQmVqYnNnM2FCZldlUWJiYlFjQWZVYlljZGRrZUJoMmFlYzBoVmJWYUhjSGRoYnNhRWZsZnNoVWJhZ1ZmbGRpYWNlbmRCZndiU2NFZE5nSmFXYW5hVmI0ZVNieWZkZjZiZGNGZWNjY2NFZUFmWmNvY0dhMGNWYTFjRWVWYnRhdmhTZ25nTWZDZFNmMGZJZlZnU2VGYUJlSGVFZ0diWmV5ZVZiaGdWY3FmY2NsY0VnNmhWaDFnY2VXY0xhR2NFYkpiR2JIaGNlVWhmZ0dmWmNzY1lhVmZsaEZoV2NrZmNhZGNIZlZoVmhTZmRiR2V0aDZnWWQwZTFmcWJFZ2doOWNQZEVjSGhSaE1nYWZIaFliQWdRZ2tha2VrZWRkaGNwZ2JhR2dGYTVkRWhmZzNoSWVpY2NnRWU1aEZmU2RVZXBkMWRaZGtkdGJtZGVibWhaZ1hlQ2N4YmthWmJkZndndGdVYWJkd2hzZlRjZmgxYXhlWmhFZjBkZGFvZ0ZkVWJoaFFkUmV4ZUJibWRjYmhnQmdhaE9lSGRKZlpiWGNWYWRnS2hGYW1jbGZoZEZmaGFoZG1lRmVHYVpobWFZZlNjSmdWY2NjbGNvaHFmWGVFY2toZGJYYURiVWdwZUtoV2RzZ2ZoWWYwZGNmbGNVYmhoQmVrZlRkSGRaZzJoVWRrZkliVmhlZUhjWWdTZFNjeGJnZktoQ2VnZ3dlemRIZ25nZ2VhY1Nma2VrZ0diS2NYZWdjWmZkZjJhZGIwZlNibGRrZUJjR2RXZmNiTGVWZVVmVWJSY0VjMmM5ZUhkY2Z4Y05iSGRhYUJiVmNJZVVnRWJjYlFmWmRuZUphV2FDZ21icGY2Y1dmU2NSYlhmVmV4ZFlhZ2NNZW5kaGJaZENhQmh3ZTBiYmQyZUZkdmFWZFhlNWJhY1hjUmgwZU5lWGJGYzVjMGNZY3plUmhqZVVhR2JvYk5lQmdsYXNhNmhaYUVieGEyZmRnbGVKZENmRmVYY2hoMmVFZ2toc2VZZlFnMWZsYWlkY2htaHBid2FRZ0Voc2NIaFdhbWJoZTRhSmFqZVlldWdJZ1Zna2VmZlhnRmNZaG5hV2dVZTBmQ2NVZ0VmY2ZuYVNiVGY5ZGNlQWJHZ0JmSGVRY1ZnQmdJZkVmQWVzZHpmQWZsZzFma2NIZWpiOWVsYlhma2hNaGFiUWcyZ0VhV2FHZEdoWWVVZFpmbWhaZGhkY2VGaFZjdmdXZWtlY2dkYUhjVmFWaFNnZGVEYWxkNmJhaFVlMWNpZENmZ2Y5ZFBiRWVBZ2tiTmdJZ2pnNWJjYUVlbGZvZnZlZmhnY0JnSGVHYUVnNGNYYmFlM2R0YndoYmZFYmhhU2JTY1ZmeGd6YmVoRWZNZzVjZGMyZlJlYmdXZFJmaGNZaGFoQWRGZFlmYmd3Y01jYWNaZmtjdGZaYkVjMGFkZm9kRmhVZ2hkUWNSZHhkQmJtaGNhbGNZYlZoYWZuZEpnUmhkZDFoZGZLYUhkamR0ZGhiSGNRaFZlbWJXYm1oWmV0ZFllVGZ4Y1ZoY2VVZWRjSGdEYkJoMWRLZFVnamNkY3JoZGdXZk1kTWFhaGxiRWVQYUVlUmhCZnViVGdCYnNiM2ZCYmdjb2JiZktlRGVsZ0ZnUWN3ZXBjUGNXZVhoTmR5Z2ZkWGhBZ0VnU2hrZEJmV2FYZjNkaGJMYWRjM2hwYnBlVmMxY2tlUWVHZldjZ2hMY1JlV2M4aFJoRWIyYzllSGFjZzBhRmNIY1lnaGJVZ0pkVWFGY2tkTmNaZW1nQmdXYUVnMmh4ZHljV2JUY2xhY2ZRYlJlcGRwaGFoVmdjZFloYWdRZWxnbWhkY0dlaGI1Y1dnVWdWZmFjUmR4aDBjZGhWZ1ZkSmQwYmFoM2JwaGpkVGdXY3BiTGdEZjFlSWFRZ1phRWV3ZjRjZGZsaGxhQ2dXZ1hoaGNvZERoMGZ0YWVlYWZWYWxoaWdjYm5mQmR3Z1NmRWNOYkphV2FuZlZhNGJTZzNhZGI2Y2FhVmNkZlpmRWJCZmxob2JGYUVmVmJuYkdjVWFCZHZmV2VuaE1nRGRUZW1hUWJWZ1FoQmM1aEhjRGdXaFlnMGJYZ3hieGZBYWNjbGNGaDNmVmIwZ29iV2ZhZVdiRWhXY0dlR2NZZ1VnWmRtaFpiaGNjaEZiVmV2aFdja2NjZUhlSGNSZnRiU2dmYjJkc2EyYlloMWZOZTNlU2N4aDVjNGVFYUdmUmVNZ2RibmRaZVNkUWFoZVZiNGhkZWhnSmdMZEdnRWdOZlphWWRuZEpjd2hjaEVlaGNjYlNmVmNKZjloS2UwZnRmcWZlYW1kRWJGaFdjUmNvYlpkS2JRZXRkSWRiYndnQWNhaGJhMGQxZnpnZmFnYVlmOGRYZ1VhWWFBZkNnRWNkYXVoWWZGYW9oVmhKZVhkdGJZZGViMWJkZ0NhV2FHaGxlcWRDZHhkZ2RxZ0hmV2Q5YU1nWWNYZUJlVmhiZTFkcGJIZEhoUmcxY1ZjVWZuZ1JocmFlaG1nTmZOZmFna2FzZFBhVWRoYUJhK2VUZEhiNWUrZ0FoVWhJZkloZWNDYlFjU2dRYVJmZ2R1Y0dmRGdZZzZhZmFpaEFnSGFGY0ViRmJJZmVjWGZnYkhoZGQzZGRmcGRSZGxjQWZRY0VnMmFoaG1lQmREYnRhWmRIaFRjOGdJZUpoQmd0YlZmWmJCYlVlSGNXZFVlNGVjYlpnbmRvYllmRmdYZGRmeWRRaFhlNWJlZVFod2QxZURjWWVSYllnWWZaYWhkUmdtZFpnbWdGYXdkVmZXYTlnYWVDZUJmMGJEaFNkRmJKZnNlY2VGYUJhamRUZFdjcGRMZkRkMWVJY1FoWmZFZHhnMmJkYWxlSWdXYWJiamVGYjJoR2hVYnRhSWNQYmxjbGMvZGNhbWVKY2xhWGFVZk5mUGJXZmloWmUwYVNoeWVkYzZkWWJraHBlWmVYY1JmVmJvZldhRWFWZmdoRGNCaE5nOWVVZm1hVWJmZVJheWFjYlZnUmhVZDFoSGJDaEVneGF5Z1ZlaGJWYnFkY2dsZUZnM2NWaDBnb2FXY1llSGNvZzhhR2NHZ1ljVWFaZm1mWmJoYWNmRmRWZ3ZoV2JnZkZkU2VUYTFlVmNhYlhjbWN0YTZiWWgwYTFocWhTZXdiOWVTZ0VhR2FSYk1mZGNqZGhkU2dYZnhiVmZ3YU9oQmZKYlhnQmdFaE1jV2dhYjNmSWZzZmNhQmN0ZFBiU2NRaDliMWVjaDFhWmEzaE5jWGRKZjllV2FSaEFjWmJhY0FjdGdGY2JleGRFZ1RiYmQwZ2RoemJSaGtlZGYyYkZoVmhoZUxlYmJSZUJibWFjYWxoWWJWYWFlbmVKYVJkZGgxZ2RhS2dGYWphMGFhZFhjeGJoZnRjRmZEZVlmYmVZYVdnMWRWYmZhVWI5Y1NjSGVSY3RkVmFIYUhiaGhyYktobWROZkdkZGMwaHRkQ2hYaGhoQWJxZ1RjSGJsZnJmVWJsZkFlQWFiZG5kb2RTYUhkaGJoaE9jUmhHaEpocWZXZm5hQmhJZ1FmMGdsY2FiZGdYZ2hhTGFkZzNhcGhnZ1RoSGdNZVFkR2FXYWdnTGZSaFdiOGRSYkVhMmM5ZEhlSmIyZmdjT2NhYUJnNWFJZUFnRWZjZGRiWmJqYzhicmFGYVRkWmd2Y1VkV2FaaEZmVWRoY1phamhZYlVoOGhEZ1RhQmhSY21nWmdtZEZod2VWZ1dnOWRhaEdlaGZRZEdmZmYxaEpmMGNhaDNhb2QrZFFhVWdCYUxkRGUxYklmUWZJYmhka2c0YU5iUWZZYkxnV2VqZlpkMmdHZGhnOGVSYVFid2RKZUlhY2NuY0Jmd2RTZ0VnTmZKZkRoRGZRZXFjU2Z5ZFZoNmhkZUZiY2ZDYlRkUmNjYzhiUmNEYlljN2NRZTFhb2NoZkFmR2ZnYTVnUmYyZ2djVmFTaEZoQmdIZVJiR2ZnZjNhRGhrY1VnbGhJYkFjVWZraFZjMWJjZDhoYWhXZkVlV2FHZkdiWWhVY1pkbWFZYkFiSWZnYWNldWJBYjBjbGFVYlRjamFRZEFkSmhpZG9kamJZYXhlRWYyZFlmUWg5Z1NnRWhHYVJiTWNkZm5jWmVTYkJkRWJBaDJoTmhVY1lnQ2hWY3diMWFaY2FlaWVaZzVmY2FCZE5jcGhTYlZocGYxZmVhRWh0ZjNnZWZtaGxoWGFXZVVnSmNjZFBnRmM0ZVhlSWVSZ0VhUmRGYkFoZ2V4ZldmUWZJYnJiUWJVY2dleGhGZ1VnSWhuaEtleWNzY1hmYWNtYjljTWRkZndjVmNFYVZiU2FnZnRiV2JoZUFoeWJIY1hoMWdNZ1liWGNCZ1ZjYmQxaHBnSGJIZlJkMGdJaFNjVmg1Y3JjZWJtZk5jTmZOYzBjY2RsZFVmaGRCYmtmVGZEZkFhamNIaEFmRmFCZ01mVGhsaGNjU2N4aEFhWGZWZ1dmSWZnaGVhWGVBZVRkYWdVZGxkYWFkZ1hnaGdMZWRneWR3Z29iQmhWYWxhWmRGZldoaGRPZ1hoa2FVZFJhRWMyZzlhSGJjY3hjTmVHYVljRmhNZmRlSGdnZ1JhRWVMY3pjMGVZY0ZnV2RJYTlhV2ZIaGNnTWdZaEJnWmFwY1lhUmRZZFlmWmJoZ1JjbWJJZ0RhUWcrZEZnamZzZFRhQ2VGY01nZGFIYlZob2RnY1pjM2ZvaHhmUmhHY29oUWdKaFZhSWNRZlpjRWR4YTJjZGZsZEpnQ2ZGZVhiZ2RrZFZieGY5YU5kRWRSZWRkaWdKZ2phZ2g1ZEdiMGFNZUFhRmhDZVljc2VDZWpoa2Q1ZExkQmFnZGZhRWJGYkZjQ2ZDYTBjVmV2ZEVjUmdOY3ZlUmEzY01kVGhSZDJmZ2NWZVZhMWhCZlBkR2ZEZUloNmNIZzBnWmZrZURkUmUwZzRkQWFFYm9lTGVhaFhnRWhmZEZiRWJ3Y1ViWmZtZFpoaGZjYUZlVmJ2aFdma2VjaGRiSGJWaFZjU2VkZEdlTWF1Zktkd2VRYTVlUmFYYUFhYWJXYlNoTWhFZGRobWZ0YVNlVWFoZ3hmMGhYYUJoSmNMY0doRWhOYlphWWJuY0phd2RjaEVnaGREYVNnVmRwZDFmY2VCZDhjL2hNZHpmcGNaZENiMWZWZVVmS2ZVYUlmTGZLaDFkUmJCY2JhMWZwZ3piWGNSZElla2VXZVVhRmVjZ2JnUmhCZm1lY2NsZFllVmNhZG5oSmdSYmRhMWFkZktkRmNtZ2xhaGhGY0ViMGhvaFVjQ2hNZGdlS2VEZTRhUWVLZzFlaGRIYUFiQWJCaFZkQmFpZDBmN2dQaHlhd2VMZmFhaGhrZ2xjVWVoaEJla2FUZkhlWmgyZVVna2FJZFZnZWdIY1loU2VTZnhhaGhEZVdmWGYxYXllSWMzZzRhTGhBY2dlVWVXaGZhU2V3Z0RoUGhpYmxobGhWY3dhMGJaZE1kMmFnYkxlUmVXYzhoUmdFYjJkOWNIYmNheGROaEhiYWhCZ1ZmSWNVZEVmY2FLYlphbmhBZkZoUWhUZmdiN2FIY3pkQmVWZFNhZ2N0YjBnWWZVZUpiQmZOYmxkRWNwZ0lmR2hFZWtkZmIyZjliYWhSZnhhMGNkZlZnVmFKaDBkYWYzYnBlamFUZ1dmcGVMY0RjMWNJY1BhWmRBYjFmNGJOYVJiTWVPY1doWGdBZWloV2RnYkpnTGhUaDFja2cyZmZibmhBY2ljUWNXY2xkSmRXY25kVmQ0ZFNjM2NkYjZlYWNWZmRiWmhFZEJibGdvaENnMGhWZnZlQ2J4Zk1oNWVDYkRmcGdYYVJkeWZZY2JhQ2R4ZkVmTGhYYkdhNGJtYkhobGR3ZzVhZmVsZkVoamhXaDBicGRFZFlmR2VnZDhlR2NHY1loVWVaYW1nWmNoZWNiRmdWZnZjV2NraGNjZGhCZzFoVWRjYk1oVGh4ZDZjS2gwZ1VoK2NSYXdiOGZBYUdnWGU5Zm1lZGduY1pnU2JRaGhoVmc0ZWRmaGZJY1djTWhrZE5lWmdZZm5lSmN3ZGNmRWdoZkRnRGh3aDhkN2ZPY3hoOGErZ05mU2FkaFhmRmJ4Y2hlTmFaZEFhc2NYZlpnaGdGaEllUmRVY2RkemhFaDBjZGZvZ0ZlVWNoZ1FiUmZ4ZkFoMGJOYndnSmdBZU9mRGV4YlJnZmJ3aE1nQ2hYZXplcGV2Z2FkVmdRYnBhUWMyZVplN2hZY1dkQmZWY01jMWNvYlRjRmFCZ0ZmVmFXYWllQWVqaE1lemhCYkRoRmhRYk5kR2dGY1ZhaGFrZVVjWGhaY21nVWJoYjRoVmhLaG5kOGJlaFNiMGV3aExiRWZEaEZkcGVXZG5mQmJJZlFjMGdsaGFnZGRYZ2hnTGVLY2xnQmdwZVZmMWFraFFlR2hXZ2dlTGdSZlNjbGFFYlhjU2Z3YVRjT2JsZndhSmhhZUVkWmNBZUJjRWg0aFFiUGZWZmhoV2VGZFdjcGV5Y1ViWGRkaFhoU2NoZ1pncGNNaDFmTmFNY01iMGRZZ29kWmJtaGtoa2hIY1NiWWRKZVNoV2hKYVJmR2RnYVZkMGJkZW5mcGExYVdmSGM5ZlliR2VsYUlnV2RaYUJoaGgvZ2VobGdKYkthUWZUYUFnL2hRY1VjVmFuZ0NmeGRBYWxoT2FuZ0JodGVTZ0JkZGRKZ1JhR2F0Zm1kU2gyZVphc2JZZkZjdGhaaFJjRmFFYmhiV2hGYzVhRmJFYlJiTmh2aFJjM2hNYVRjUmIyZWhiSWFZZ2xoQmZIaEViR2JaY3lhVmZoZ1ZmcWVOYUFiUWc1Y0ZhQmc1ZGZkSmdpYjhjV2JXZldmNWdBZGFibWFZZnplZWdWZlVjMGdjY0ViY2JkY0hkVmhWZ1NnZGFHZ3RjNmZZZDBnMGY4aENkbGgxY1NiV2ZXZFJkUmRkZGlmWWNUYUVnRWRZZzlhSGQxY3dmZmhFYkJnZGVWaFlkaWJCYndoTGdCaFJiRGRXZUVlcGI4YVljMmhGZzNnZWJtZmxkWGRXY1JhQWRaZmFlQWR0YkZiUGdWY1JiSGJPZmhhVWI5YUVhMGQ4YjhkWGJRZEViRGRTY1diOGJxZ1BlUWNFZ1ZhZGczZkphSGFZZWtoSmJaZEFlMmRsZW5hRmhsZUZkdmRHaEdmWmF1YU5oVGhnaGNoUGZGZ1FiNGRWYlZhUWhTaEdmbmhSZjJnZWdpZHBoTmZkZkZmVWRSY1VlZ2dGaHlkUmNYY3BkMmdCYmdicGFjZUtoMmcwZTRoU2Z4ZmhoRGhXZFdiSmF5ZWNnSGZBY1ZhYWVVZWxkYWNkZVhjaGFMZWRhM2FwaHBnWGJ3ZklhNmNHZldlZ2FMY1JnV2U4aFJkRWMyaDloSGRjZXdjQmVSYmNlaGhVYUFkV2RDYnBoUmRNZGpjcGRZYlJnU2JVZGxlV2FXZ1JiQmVSYmhkWmE4Z2FkQmI4aFVjVGNCZ1JnbWdaaG1nRmN3ZVZlV2I5Y2FmUmd4ZTBlTWNRYzBnaGUwZUllM2VJZ09mRGFEZzRmRGVBZlFhSmhmYk1lMGRSYm5jWWRGZzVjQ2RBYm5lRmQvZEhmbWRFY1lmUWgxZWxkaWVjY25hQmh3aFNkRWFOYkpnU2YyZ1ZoaWNTY3piOWd5aEJmQmZZYk5lV2hCZ2NkNGVSY0JmSmRuaEFlQWdOY2pjUmQyZG9hYWZUZW1mUWcvY1NlRmhCZ0hmRWFHY1pleWNWY2hoVmRxZmNoa2JOZnRoVmF3YUlkZWZCZENlQmFDY1ViR2ZoaEVhS2RUZ0ZocGdZZGxkbGd2YVNoVmVjYVVlRmJGY2xkNGNkYUdidGI2Y1llMGIxZ3FhU2h3aDhjUGdIZUVkNWJNY2RibmFaY1NkUWNoYlZjNGhkZ2hhSmVMY1FjMGFOYUtnZGFHY2hmd2ZPZUVhQmJRaFhhMWJOYjVoZWZGZHBjaGVZYUdha2RmY1VlUWZFYlBiWWdRaGRoRmhmYWdlRWRKZmJod2U5ZjdiQWJsZWRiaGNHZFVjaGFDY1hkUmRBZHVhZWRrZlFoY2ZhZmloOWFZZWJhSGgxY0tiRmJtZGxlaGZGZmhhaGJtYUZkR2E0ZHVkYmZ5YkFlSGNJY0FlNGZJaFNnVWNRZEZkRmUzY29ldGRLY0Nid2VBZkNnQWFKZGJkQWdSaEJhNWFUYURoaGIvY1hibWZnZlZkZWNIZVlkU2JTZ3hoaGREZldjV2RKZ3lnZWREaGhkR2ZFZnhmc2dWZUlmVGRjYWZlTGdpaG9hc2NXaFJlOWhDaFZhaWhWYmxiRWFDaEpiVGdWaGpjMWFIZ2JiaGNNaFVmWWVSY2xhaWFVZkVkY2NRYVpibmZKaFdhRmhXYXBkeWZVYVhkOGFmYVJhRWRZZzdoTGFrZkpoWGJNYmtkMGIyYkloMmg4YzJjQmN5Y0FkWGdOZ0VlbGNQZkhoQmJ3Y3poYWMyY2RkamVEY0doTmJIY0pmVmFJYVFkWmFFZHhmMmZkaGxnSmFDYkZlWGdoaCtoV2VrY1ZoSWRFYlJlWWcyZFBjU2FRY3BiR2VBZ1poSGZEYWplb2hXZkhkamJvYTRmTGJBYlZoWmFEZlJka2V1ZVhjZ2RzYnNoUmRWYm9iZ2JDYlhjTWJiZ1RjbWFoZE9kWWFsY0JlSGRFZkdlWmJ5YlZiaGNWaHFnY2FsY0ZkM2dWZXhnaGFUZVBjVGNSZkVoVmRtZ1liQ2VjZTNnTmF5YlpkbGJWZ2xnV2FoYk5kVmJWZUFjWmZjZ0NleWJNZnpkSmhBY1ZhcWNRZ0FjOGVHZFdiQ2gwaGZoZWZBY2tkZWVEYlVkSmVqaFhoQmdKY0xoR2VFZ05lWmVZY25hSmd3YWNiRWNnYmVlUWVGYVpmZmRlZEVjdGMzZWVkbWJsaFhjV2hSZkFoWmhhZkFmTWNOY1lhVWFGYkJlSWhCYU1nOGNSY3hiNGM0ZFVlRWdZaEVhQ2ZHY01oeWdJZkJhOWZiYUxhWGhKYU1kZGJ4Z0VjZmFXYUNib2gxaFhlMWRjY29hRmNHYjRkeWVhYkhmQWFPYVJjVmFwZkhoSGdSYTFlVmhVZ25lUmhyZGVlbWdOZE5jYWNoYmxjS2VCY2tmVWUyZkFobmRZZ2liR2VnZXRiR2JkZWliSmVkY0piVWgwY09iR2Z5Y2NnZ2JlZkhhbGJHZ0Zmd2hZZ3BkSWhTYW9jQ2dPZFRlMWVoZ0FoMWVsZE1nUmZXZ2dkYWRWZVdoWWFLZ09oV2E5YUhoY2F4YU5nSGdhaEJlVmdJZVVlRWFkaE5nYmgzZjVhOGZGZVdlcGZ5ZVViWGNkZ1hkU2FoZVplcGhZYVJjNWdRZ2FiRWVRZTBhS2VUZFVlL2VBZ1RiWWFLYkFiaGJOZmNnRWdSY1pjMGdkY25ib2hsZEdoQ2dRYUlmV2N4Z3RiZmdLY2tmeGErY0lnbGZ0YkNkVGhsZ0pmMmZFZ2tlc2RZZVFhMWFsaGlkY2JuYkJkd2RTZ0VkTWZmZUdkeWFkZzRiR2FYZWRobmRhZ1FkTWJSZFdmVWJwaG1lZGZBaGtnZ2ZSaGhmTmVrZlJkeWVjZWRnT2dDZ1JoYWZIZzFheGJ0aEVnR2ZaZnlmVmdoZ1ZncWRjZmxkRmQzYlZoMGhvY1dmYWVXZkZoZmJHY0hhc2NVYU5iR2RaZC9iYmdrYXRmdmhTZjFmRWVHaE5kMWJWaFNoZGJHaHRmNmZZZDBnMWNxY1Nid2Q5ZVNhRWVEY1lnSmVJZmlmTWVBZURlQmVWZHdhWGVCZ0piTGJHZUVoTmFaY1lobmhKZndjY2dFZmhhRGNTZVZjcGMxZWNoQWNKYTNmY2hYYVJlWGREY1ZiaGVRZU9jd2NVYzZiSmMxZmhlVWRKYjBjZGQ0Y0VneGhOZW1jYWJnaEFlWmJBYUZlaGd2Y2Zmbmh3aFZnYWRuZUpnUmZkZzFhZGhLZEZlbWVsZ2hmRmdoYWhlbWhGZEdhNGZ5YUthVGJrYUdoWWdTYlVoTGZVYWthcGhWYlRhM2NSYjlhYmMzZlplZWdmYzBic2JKZFVka2hKZHRnUWRGYXhnMmNVZmthSWhWYmVmSGhZY1NiU2R4YmhjRGZXZVdlSmd5ZmNoSGJnaGNjQ2N3ZEFjSmRlYndmY2JEYlBkamIwYWhlVmcwY1FhUWREZTNnMGJlZFZibmVvZVJiRmFXYzhmT2JlYmhmOWh0Z2FkQmNWZkliVWNFZGNlUWdaY25oSmZXYkZnV2FwZnlmVWJYYmNnRGNBY2xlOGg2Z1NkeGNZaFliWmZoZVJhbWdaZ21nRmh3ZlZoV2I5YmFnUmd4Y1FiR2FmZjFiSmcwZ2FkM2NwYmplVGNXY3BlTGdEaDFmSmNOY2JiVWFCYWNkZGJsYUpnQ2ZGZ1hkaGEyZEVoa2ZzY1liUWUxY0VlcWNmZENjQWhpZEJheGFjZEdkRGZpZ3dlb2JEZG5ka2hwZVBkQmhVYU5iUWRsYmdmcmhYZDBhVmN5YkVlVmZVZDZkQ2dUY0JkSGVEaGlkZGJiYlNkRmJnY1RmR2VXaFlmcGNmYUJnVmJxZ2NlbGVGZDNnVmYwZG9jV2ZhZVdnRWNXZkdjRGFSZ1JmTWNqYU1kemVQZWxkVWg3Y0VnZ2c1ZU9nRWV4Y1FnV2dNZUdoTWR1ZWJoUWM0aG1nQmZFZEVlWGJHZ0dkMWZDYU9jRGNNaFZlQWgwZkVjOWNmY2hkdGhDYkFoMmNsZVpoWWZuZkpkd2hjaEVhaGNEaFNnVmJwZzFiSmdVZkphN2dVZkdobGFYY1dkUmFBYlpmYWhBaHRkRmViYnhkRWhiY0poMGRrYmphUWJRZ2dmOGdXZ2hld2RKZUZkMWdWZW9iUGh3Zk5jWmhQaGphc2RCYU9ld2g1YUtmQ2cyaGtkbmZRYjFoWWRsaFFmQ2M4Z3BoTGUzZUJhZGNPZTFkTmFIYlJlamhkZVZnVWhuZ1JmcmRlZG1nTmZOYmFla2NzZ1BjVWJoY0FneWREZ1NiUmgyYUFjRWM0Zy9hZWRIZlliU2dTY3hjaGhEYldjV2RKZ3liY2JIZ0JlSWJRYzBla2VUZ2VhVmdKYkxnZGMzYXBkcGhWZDFja2VRZkdnV2RnZUxkUmRXYzhmUmNFZnlmcGNIZ2JkaGFNY1RmSWFGZ3diYmNYY2plaGdZZkxjemRVYWVhR2FVY0JieWZVYlhiZGhYaFNhaGFaZXBoWWRSYlllWWJaaGhiUmVtYVpkaWU1YndoU2JHYzhnT2dEZzFlUmRPYVdneWQwZjRhSmVDYTFmdmdaZjJocGhMY0RhMWFJZ1FhWmhFYnhhMmdkZGxoSmVDaEZiWGRoZjJhV2hrYXNkRmdRYXdhMWNzaERmVGZnZjViRGJ3YnRmRmVjY0hkVmM0YlNlM2FkZzZiYWdWZGRmWmNFaEJlbGFvY0NjMGZWZHZhWGF4Zk5meWRSZXljY2NkZU9hQ2NSYWFjSGQwY3RidGFFY0doWmN5ZFZnaGZWZXFjY2FsYUZoM2VWYjBob2hXZU9keWNSZENnVGJUYlJhYWZaYW1nNWdMZmNoRmNWZXZhV2ZrZmNjZGZIYlZlVmFTY2RmR2J0YTZiWWgwaDFnaWdBYWdlOWVQaEVlQ2F0YU1hZmJIaFljY2FTZnhmbGFTYmRoaGNKZExjR2ZFYk5mWmVZYm5iSmV3ZWNlRWhoZERkU2hWZnBhOWhLZmtodGdxYmViaWhCZFhoUmV3aDRjSGdhYUJocGZUY1poaGgwZjVoYmIwYWRlemVFZzBjZGRvYkZkVWZoZVFiUmN4Z0JkbWJjZ2xjWWJkZ09lSGRKZ2FhYWNsZGNiUGNGaG1lTmVoaFdmQmdGZHFiUGRtZ1pjbWdZaFhkQmNWYmJiMWhwZUhnSGFSZDFlVmdVY25iUmVyY2NoamhGZE5nYmFGZlloUGVSZ0FiVmZ4YlhjMmVOYy9jWGhtYmdnVmhlaEhkWWRTYlNoeGNoZERhV2VXaEpieWJjZkhlQmhJaFFkMGRFZUlnZGNYZk5mV2VkZXplVmFwZFhkVmVsZllmRWRHZFFlaGJSZ1dkOGJSZ0VmMmQ5Y0hoY2N4aE5mSGVhZkJlVmFJYVVlRWdjYVlkTWRqZm9hZmdSaG1jUWhOZkhiVGhnZEFnU2dnYnRlcGFkZHdjTWVOYmRkUWdGZW1mWWFHZUVkNWRYYkdoTmd3YlJneGQwYWRnVmVWZkpiMGZhZjNjcGVqZlRnV2VwaExmRGQxYklmWWRNaEFjUWQvZ0pkVmR3YjlhWGdUZ0VmeGdXZ2toc2ZGYlFoMGQ5ZjNiWmUyYU5jbGZTaEVhVmJKZ0NnSGd4ZTBoWWNYZWRoNmdhYVZjZGVaZ0VjQmVsYm9mQ2YwZFZkdmNFY1JmTmd2ZkVkemF0aGFnRmdFZkloVmRTZ0ZjQmRIZUVmR2VaYnllVmVoZ1ZncWhjY2xoRmgrYlRlR2NBYldmYWVXY0VmV2NHZUdkWWNVaFplbWNaZWhiTGFWZHhoamhjY0VmY2JkY0hnVmFWY1NoZGRHZ3RoNmVZaDBkMWZpYkFid2JFYUNkUWFpZ3NiWWJPaFNhSWVMZEVkbGJCYTJiTWJsZ3NmZGRHaEZoNWJaZUphQ2RjZytoTWF4ZXdjS2FCZ2hkUmUxY2NlQmc5YytlZWRqZkphOWNXZFJnQWNaaGFhQWJ0ZEZnYmV4Y0VoVGViZDBmZGV6Y1dhZ2JGaG9iSGJWaGhhUWFXY2dnMWRtYUpjbGJoaHFjSmhqYTBkR2FkYTFlRmhNZEZhbmZsZWhhQ2N3ZVZkbWhRaEdoZ2haZ0tiVGFrYVNiSmcxY05hSGdTYlZkVWdIY0hnU2ZOZHJiSGJ6aEVhZmhKZ1Jha2NIYVVkRmhRZ3RnR2JqZDhlbGVHZndjMWNiaGVhRGRSZExhU2gwZUloR2hDaHlnMWR3Z2VnV2d0ZGloUWYwZGxkYWNkY1hnaGVMY2RkM2JwaHBiVmgxZ2tmUWJVYkNmNGhMYVRjWGE4ZlJmRGFuY0phSGRKaHhjMGc0YkliRmh3ZFBnR2dFZGNkV2RZZkhhSmJIY0ZmWGhkYXZlVWhTYU5mWmZOZlZmb2dtYk5kaGM4ZXlkWmNoZVJnbWNaZG1jRmR3aFZmV2I5ZWFjUmV4YTBnZGdWZlZjSWNtZExhaWU0YjJoSGh5Z1JlTGdCZ3dnWmFZaExnUmU5ZjRmSmJCZmNoUGFWZ0RiRWU0YVZlZ2U1YUtkUWEwaFJnaWFQYURlVWduZFNnQWJ0ZkJlU2NuaHhoeGNSZDNoY2Z1ZEllUmI0aEtoQ2d6YU5ib2NDZDBhVmh2aEVlUmVOaHZmUmIzZE1mVGFSZzJiaGZjY0RkbGFCZVBlUmdHYWdoMWZBZGhhMGIrY09kaGdnZWthWGdrZ01nOGNhZFdkRWRXY0djR2JZYVVmWmZtZVpmaGdjZ0ZmVmR2Yldma2VkZFBnV2FBZUVjSGNKYmlhVmg2YmFlMmNkY3FiU2N3YzlmU2ZFZ0djUmJNYWRibmJaZlNnUWZoYlZjNGJkYmhjSmhMZEVlQmhjaFJhS2J5ZkZkK2JJZWdiMGVPY0NmQmFNZTdjUGJBYzRjbGZlZW5hUmdYZURkVmVoZFFmT2J3ZFVhR2dJZTFmNWVkYktla2M5ZTZoR2VraHRoQ2ZGZ1VlaGZRYVJleGFCZG1hY2ZsZlllVmRhZ25lSmZSZ2RkMWRkY0tjRmNtYkVnMWRYZmxnRWYxYkdoaGVrZnFjTGRpaGRhVmVjZ2xicGhYYUZmQmZGZi9kVWFuYlJncmRlaG1kTmFOaGFja2JzYVBkVWRoYkJka2ZUZkhkWmEyYlVja2NwZ0JmTWREaDlmQmZSZ1diY2dMZUVkQ2FVaDZlY2NHYjFkSWZVYzBoQmFXZVhkM2JoZ0xjZGczZnBjcGRWZTFia2JRY0dlV2RnYkxmUmVXYjhhUmFFaDJjOGVUY09jMWVvZ1VoUWVoZ1ZnSWJVZkVoY2FRZlpibmNKY1dmRmdXZnBkeWdVYVhjZGhYZ1Fod2cxZkRkWWFSaFlnWWRaaGhjUmNtZVpobWZGZHdlVmRXZDllYWREYWxnc2NkYVhiUWFZYzhkSWdpZmxndGZDZERkdGFEYVdjMWRzZ1piVGZrZ3hnMmhkZ2xhSmRDYkZjWGFoZTJoRWRraHNnWWRRYjFjbGFpZUlmRGhVZmtmSGVSYkVmSGRXZG5nMWZTZVNiM2hkaDZhYWZWZ2RiWmRFZkJnbGVvZ0NnMGRWaHZoRWNSZE5odmJSZjNjdGhIZURneWZGZ0diUmhnZUlnQ2JYY1NkY2Y3YkdkRmNFaHZlSWVGZkZlcWhWZHdlUmRUYVBobWRGZGViRWJIYllhZGRiZjJicGdMYmNoRmFWZnZlV2NrYWNmZGFIZlZnVmZTZ2RiR2h0ZjZhWWIwYzFicWZTaHdjY2RHYVdlQ2QwYWZlZWVBZGthZWJEZ1VmSmM0ZGFieGFKYWFoRWhVaDlmemhZYm5iSmF3YmNoRWVoYURmU2FWY3BkMWZlYkVjdGQzZmVibWVsZlhkV2RSZWhnTmNJZkVhSWdXYlliV2Y1ZWJjSmNnZkFiN2RFZTFmcGJvZ0JiVWdGY2NjYmhSZUJlbWNjY2xnWWFWY2FnbmFKYlJnZGMxZmRhS2hGZW1jbGRoYkZjaGJnY3lmWGRDaDhoMWVTYzNlQmFWYWJhMWNwaEhiSGNSZTFmVmZVYm5iUmRyYmVhbWZOZE5kWWIxZUFibGRVYmhhQmRrZFRlSGNaYjJjVWRrZUllVmFlZEhmWWVTZkRhVmZjYlJkV2ZXZW9oa2dNaFNnSmZJZUVhVWVsY0hlZGJTZnhiRmNOY0RkWWJtZkdlUmF3ZlllRWdHZVFhTGREYkdhOGVNYkViMmJKYVdnYWZCZU5nR2FQZEZhMGJCZUFkMGJsYWNlTWduaG9kRWZIZEhjRmZ5Z1doRmgxYlhmU2ZoZFpicGJZaFJnWWVZaFpjaGRSZm1hWmFtZUZld2VWY1RmMWZVZ0ZkRmNWY1VoRWF3aFliWWVMZWpnd2YzaFJiWGF0ZEhiRGgxY01kQWNiYlViQmcyZFBiMWFsY0plRGZsaEpmMmRFaGthc2FZYVFhMWVsZWliY2VuZ0Jld2VTYkVnTWVQaEZlU2RkZTRoUWMxZTFlNmNhZ1ZhZGVaYUVjQmhsY29lQ2IwZlZjdmFFaFJjTmJ2Y1JieWRkZ2JhRGdqZnNmYmNHZmhlVWVLZFVhU2Q4ZThmRWVsY0FiNGVjZmtleGgzZkFmd2JKYmZnT2ZtYzlmVmhWYUNibGRhY0ljMmU1Z29jZmdGZVVkN2VFYWdkNWVPYkVjeWVvYWVkT2F6ZHhjNmhmZmtlMWY2Z1Jmd2I4ZkdnV2dDYTBkZmZlZkFna2ZhYUNhMWZJY3dnZGNnZTlmTGVDYkZjaGd6ZVljbmFKZ3djY2VFZWhkRGFTZ1ZocGQxaGVoRWF0ZzNnZWVtZWtkZWdXZ1FkNGFFY2FkQmF0Z2VoUmNSZ0VhVGNiaDBoZGd6ZkVlMGNkY29nRmRVZ2hjUWJSYnhjQmdtZ09kMWhzY1ljUWZIZEpoUmRkYjFnZGZLZEZmbWdsY2hiRmFoZ2hnbWFGZEdmOWJNZVlnWGRCYlZiYmQxZXBiSGFIYlJmMWVWZlVnbmhSYXJkZWZtZk1oZmVaZUJnaGhIaEdhMWdZYXdnUGNqaDhkeGRHYWhmWWJkZGFhWGg4ZWVnWWJSY2hoRGNXZldlSmh5ZWNkSGhCZkllUWEwYmxiYWNkZFhhaGZMY2RhM2hvYjlhSGd4aEJiRGJGZ3phcGZPYUNlQ2Q1aFlkWGRTY3NjQ2NJYVJhMGVMZlBnQmEwYWFjV2RVZGRhTWFPZ2xiaGNXZ0ZoV2FwZHllVWJYZWRoWGZTZ2hjWmRwY1liUmhZYVlmWmFoZFJmbWVaZG1hRmQ0Y0FjU2FjYlRkRmRCZk5mUGNFYUJoOGQxaElnamRRY25nQ2JEYmhmRmVYYkFkZGNTZU1mQmg0ZzNmTmhRY1pnS2FSaDNhRmQ2aE9oRWVzZFlkUWUxZmxjaWJjYm5iQmV3YlNmRWJOaEpiV2duZ1ZlNGhTaDNlZGg2aGFmUmE1aFplRGVnZFJnb2JHYmxoTmJGaEViUmVOZHZkUmMzZk1oVGhSZDJoZ2hWZFNlRmdCZEhmRWJHZ1pjeWRWY2hoVmFxZGNjbGVGYm9lVmMwYUpnQ2RJY1NjaGdGYkZoaGZsaGNmTGR5ZEVkcGdjZkFlbGJ5YldkbGZZY2RlQWZVZGxnU2VmaENiSmI2ZWJia2cxYjdmWGVRZVphYmhPZW1nUmZNaGRibmdaY1NiUWNoZlZnNGFkZWhiSmJMYkdmRWhOYVphWWhuZkpid2djZUVmaGhEYlVmMWZwZDlnTGJBZE1kK2dLZ1dnY2dvaEZiVmM5YU9oYWJGYmRnWWViZHdiQWRUZGNmMWF0ZHpiV2ZrYTVmaGREZ21nSmJRaFJjeGZCZm1lY2JsZVllVmRhY25iSmVSZ2RoMWJjZlljVWR6aDBnMGRSZkZiWmJtZlFhQ2M0Y3ZiTWVtZnRiL2RiYjFkcGhIZEhnUmcxZFZjVWZuYVJhcmVlYWpnNWdFZVpnbWdFZ1BmVWNoYUJma2VUZ0hoWmEyYVVoa2FJZlZmY2hEZzRkY2hHaDBlb2NNYURiU2UwaG1lS2NTZ0FiTmRUYlFhY2JmZE1mamZraGZhTWRuY3BhMGJWZnhkOWdGZlZjeWV0aGZhRGRDYkJmZmNFZTJkZGNPZmNhMGRoaHRmYWdCYVZhSWFVZUVoY2dRZ1pnbmRKY1dlRmhXZHBneWVCZ3plWWFGaFNka2VKYXBoZmdCZ1lmUWNjaEFoRmV6ZWRkWGdSZXdoVWYyZjhjRWhFZzFkVmFVY0JkbGZ3aExoSmR6aFVhMGNSZ0dicGZBZ0RkMGVNZExlVGFrY3hoMmVkZmxmSmFDZEZhWGRoYTJlRWhrYnNhWWJRZndnc2VuY0poaWdVYWliQmhrZk5lQmJjY0hnVmM0Y1NnM2VkZjZnYWNWZ2RhWmJFZkJobGdvZ0NhMGJWYnZoR2FVaGNlbmhEZWlmQWJkZU9lQ2hSZWFhSGcxZUJmYWJFZEhlQmZuZVFid2daZi9nY2dsZ2RmM2FBYTBiTWZhaFFmMmNFZldlR2ZHZllmVWNaZm1mWmNoZmNhRmhWaHZnV2JrZGNiZGRGZFFjRWhhY1BnVGVoZzBoSGRBZFVmamZEZEVkZGdTZ0RlV2VSYUViS2RDZ0loYWVDaDBlWmEyZkNiVmNvZkNlWGR3aHRjWmJhZlhmSmY0Y0piRWdoY2RjVmUwYlJiMWVhY1ZkMWIraGNhMmZsYlJmV2hRZVlhTWJmZ1JnaGRRYVpiaGgwZzVjYmcwZmRiemNFYjBoZGFvY0ZhVWNoZlFnUmF4YkJobWFjZWxoWmhCYklhamZzZUNmWGNWaGRiS2hGZW1hbGRoZUZjaGRoZW1mRmNHaFpmbWhZZlhibGJPaFJiVmdwYkhjSGJSZDFoVmJVZm5kUmhyZGVlbWVNZ1FnWWYwZ2NnbGNVYWhkQmZrZlRiSGFaYzJkVWFrZkllVmJlZUhlNWNhZ1JiVWZnZVJjRmVqY1loOWdKZkNja2RZY0Joa2RjY2ZkSmRDYjBiS2FPZXljbGdwZVNobGZsaFliRmF6Y2hkWmVDYWphdGZlYlJoemZZaFhoTmVoYTBjQ2FPZFJmVmNWZlVhQWJGYUZhS2NEaEVhQ2RYY0NmVWU4Y1ViWGg4ZERjUWR4YVlheWNTaHhhWWNZZFphaGVSY21lWmJtYUZid2NWYldoOWRhY1JjMGE5ZlljQWdRY2NibWVKZ1hib2UzZEJnU2JNY1lkQWZTZzFoY2dLZnhjdGQyZmFhMGY5ZkNjUWNYYVljSmVYZGdiUmhQZ1FmMWg5YWtmY2dpZ1FiNGFBY1JhQmhIZ0poVGcwZnhiRGVEYTliNmRkZEVocGRaaFJkQmFjYVhiUWd3ZXdnb2VXYlFmaGVGYVJjM2NNZlRoUmMyZWdiVmRTYUZmQmdIaEViRGR0ZzdjV2dqaDlicWdjZmxmRmQzYlZkMGNvY1diYWdXZkVjV2JFY0NoNGdhYk5oamRRZXVlSmZCZW9hN2VBY3hmZGVZaEVmeGFJYkFmTWJTYW9mdWdKY2hiOGdlYkFhMGQ0ZGNiRWFIZWxiTWZQZm5lZ2hDZ0VmRmdvYXNlT2FVaFlkU2dTZkFmWmFYZ0plU2VaYndjYmRVYmdkRmFIYUJnUWEyYkxlQWZJYjRiTmNHYWxlZmREZFJna2ZaYk1keWJGYUZiYmd4ZEViVGNiZTBiZGN6YUVoMGZkZW9lRmRVaGdlQ2RBY2tlUWh6ZElnQmRnYlZiUGdqZ29hWWZKYUZja2cxY1hiaWZBYW1kWGhoY2hlNGdGZERkSmZvaEhoamVnaGNjS2FCYkpmdGdIZ1JlMWNWaFVmbmNSYXJiZWFtZk5oTmdhY2tnc2hQZlViaGFCZjdoVGJIZGRmbWFlZkVoSWVWYmVoSGRZZFNjU2F4Z2hhRGNXZ1djSmJ5YWNkSGdCZklhV2NVYWtkT2FQaFRoRWJZZ2VjUWJVY2hiSGVoZzViWWRHZFhjUWRMaEVlV2NGYnVoV2d5Z1llQWVPZ3pkbGVIYWFhQmZWZEljVWFFYWNiUWVaY25kSmhXZkZlV2JwaHllVWVXYmhkWGZTYndkZGZEY1lnUmJZY1lkWmFoZlJkbWFaZm1iRmF3aFZkV2I5YmFkUmV4ZjBhSGNWaFFlWWM4Y0loaWdsaHRkTWZpaFlkRWVXZEZjSWFPYlpkQmZoaDRjQ2FSZjRnTmZRYm1hTmRjZEVna2VzZ1lmUWgxYmxjaWhjZm5lQmh3Y1NlQmE1Y0FjVmJsYjlhNGRTYjNjZGE2aGFlVmZkZ1pmRWJCZGxkb2RBZHdoMWdoZVFhVWZFaGdhRWd6aHhiSGFIaGpnaGdRaFJiaGN3ZkNiUWh6Y1VlR2JIZmxhUWdrYWNma2d4YjNkSGcwY1JlR2dPYXliNWJDY1ZhemhKZE5lTmVpZE5idmRQaEFmRmF2ZlJkMGVkY2JmU2dCY3NlUmNJYkNoSWQxZUxnVWgxZWljSGV3Z1phU2RTYzBhNWRNYWRlbmRaZlNjUWVoZ1ZhNGZkZmhmSmZMZUdlRWJNZ0xoSmN5Z1libGJJYmdhWmFEaEhkUmhJZzhjS2YwZlVhSWdNY2loQWFRYkVhUmRBZkZoYWhGaDllTGZFZkZobGFhZEtnQWI5ZVpmRWIwZmRkb2FGaFVoaGhRY1JoeGNCZm1jY2hsYllmVmNhZm5oSmNPZmRiMWJaZWFjUGRHY2xlaGdGZGhkaGhtYkZoR2daZG1kWWRYZkJmVmZiYzFocGFIY0JkeGMwZUJkR2FqZjBlNGVkYkJhd2RGYklmd2h4ZEhoVWdnYzVla2ZHZUhnZ2dKZEdmZ2R0ZlNjTWVGZXdiU2dTYXhkaGFEYldlV2FKZXliY2hIaEJiSWNRZDBmbGdhY2RjV2JkYkxiZGNtYXRmRGVWZDFha2FRZ0dhV2NnYUxoUmhXYzhiUmFFZDJoOWdIZ2NneGNOZWRkYWhFZEVlQWZHYVJmUWdlZkdlVGg0ZFpmUWdtZ3BkdWVVaFNhTmFaaE5oVmVvaG1oTmNnYzBjeWZaZWhoUmhtZ1pibWdGZHdhVmNXYTljYWZSZjBiQWhVYldiWGVoZzBjYWgzYXBhamNUaFdlcGdMYURiMWNJZlFkYmJBYVJiNGJKZGdjQWNOZVFhVGFjaGlhU2h4Z3RnZGdUZlJmWWF3YWNibWgxY3dhRGRoYVlhSGZHYVNiRWZ4ZEJmRGNsYzZhWWNRZ05nUWVFZ0VlSmhDZ0NiMGJWZ3ZnRWVSZU5idmNSZDNnTWJUYlJiMmVnZlZlR2FoZFVoVGJSZlRkUWU4Z1ZoaGgwYytoT2VoZGdia2VXZlRoVmFhYUplamdZZVdmUmdIZHNjVWFNZm1jZ2VlZFBoQmFvZDRnVWQwY3NnZGVGZ1FoRWZhZVBjVGZoYzBmSGhBZFVjamZEY0VnZGhTYlRhSGJsZ01iSWJuYmdjdGZDaGxod2YvZVBnaGZ0ZkhnR2NCYmNkUmRLYXlmRmNyYldja2RoY0RhU2dWZXBnMWdlZkVjdGMzZGVibWNrY0tkVWRCZ3dkemFhY0FjdGVGY2JneGFFZFRiYmYwYWRnemdFZDBoOGRnaEdoeGhnZ0NiQ2RFaFFmcGNKZmdmOWRGZ0xhM2d3ZVFoT2ZSY05lS2RDZjJha2ZuZ1FnMWZZYmxhUWdDYjhmcGRMYjNlQmZkaE9oMWZOYkhnUmNqYWRkVmRVYW5kUmhyZmVobWJOYk5kYWVrYXNiUGRVZ2hiQWcyZUNlU2ZJZmpoQWNBY3dlVmJjZENiSmdhYUFma2Z0Zk5hSmRpaDRnOWhKZTNoQmhPZ1hha2drY09nZWJ3YmNkSGZPY0NlMWNnY1djMWNrZFlnVGJTaEJmQ2ZGZW1hRmh1YVdleWFZYkFkT2F4Yk5hQmJkYlJjVWVjY1hnamNoYVloTGR6YlVmZWVIZEdnWmV5Y0JlVGE4YWVhR2FRZDFlRGdZZVJhWWdZZ1pmaGdSZ21oWmhtZ0Zkd2FWZFRhSmhUZ1NlemNjZ2RoVmZWZkpiMGhhYzNocGRqZ1RiV2dwYkxlQmN4ZG9hZWJOYUJkNGE1YUllaGcwYldhVGdDYmdjemJIY0FkVmZYZEZnMWNsZi9kY2RqZllobGhCY2djQWFkYUVkemNvYjJlU2UzZzlhemRhZFFkeGR6aEVhQmhsZG9iQ2IwYVZidmhFZlJlTmd2ZVJhM2ZNYVRnRmVTZDFiQmNIZ1FhSWdKZEVkR2Y1YVllVmRoYlZjcWdjZWxjRmQzY1ZlMGZvYVdoYWNXY0VhV2NHYUdhWWJjZ01haWQ0Ym9lSWIxZnNoUWNGZWdhaGdLZkhnVWdoYVNjWWduZzVldmdjaEZlaGRxZFRnUWQ4Zk1lUmZDaHdlRmJKZVhiZ2F0YkRmbGZvZnZnZmJ4ZTViaGFHaEVmTmFaYllnbmZKZndiY2FFZ2hlRGRTYlZicGYxZ2VkRWF0ZS9hTGdpYkVmZWNDY2hhNWFtZ0llRWZJaENjSmJ4ZEVoT2diYTFoRmJtZ0JobGdSaDlmRmdVZTViUWZHY1VhUWF1Y09id2dVY2JjRmZUZW9kWWVNZkJlOWVEYUdoa2hOZGhmRmNoZWhmbWJGaEdiWmRtZ1ljWGNCYlZnYmgxZXBiSGFIZlVia2dkaEdheWVkYUJkZWRtYk5jTmRhY2tmc2hQaFViaGVCaGthVGhIZFpoMmJXZjFma2MvYmVhSGFZZFNiU2h4ZmhkRGhXaFdnSmZ5ZmNjQ2IxYkJhVGgyYk5mYWFkY1hoaGRMY2RnM2RwZHBkVmIxaGtmUWJFaFNmQWNGaEZkVGgxZGVmUmN5YUFnVGFLZGthTWRDYVpoa2EwYUhoQWNrZmNjTmNaZmpiUWZEY1dkeWNrZG1mR2REYWdlWmJTY2hoNGU5ZWFjQmJaYkRmVGFCaFJkbWhaZ21mRmR3Y1ZhV2Q5YWFkUmd4YTBjZGhWZVFoQWN4ZlBleWM4ZXhkQWEyZXBlRGhXaHhmcGZaaE5nMGhJZkpmT2NoZTBlVmJGYVFlWmNyZEVjaGU4Y1diUGVCZFVodGdKY1hibGg4Y1NiRWFzYWRmRWdqZXdocmZSYVFiZ2R5Z0liQmRBY1JlRWVHY2RoMWhDaHhiRmRoaGJlbGRzZm1hQWVEYXNhYWNTZTJmaGRCZUFhQmRrZFVnQ2IwZnhieWJWZWhjVmFxY2NhbGZGYTNhVmYwY29kV2ROYkdlZ2JhYk1kbWhZZFVhWmZtaFpnaGRjZkZoVmd2Z1doa2JjZlZmVmVWZHNiQ2ZKYWlkUWd1ZkxhQmNrZHpkR2UwZHBnY2RRaHlid2hGZU1hQ2hJZ2dkQ2ExaElld2FJYmhjSmdXYUdmQWd0Z1hiTWdpY0FhL2ZKZUFiY2JYY0VjQWVvZndoZGFoY2dnL2dNYXloOGJEYkNmeGdBYUVlYWdFYjBoUWZJYlZlSmNIZkphZ2hnZTllRWQwYThnOGFIY0VoZ2VMZ2JnUmZCaG1iY2RsaFllVmhhZW5mSmNSaGRoMWRkZktjRmFqY3Nka2hRYWtoMGMwZFdkbWNaZ3VjU2YzYkJmVmNiYTFncGhIZUhiUmIxYVZjVWhuYVJocmFlZ21oTmhOZlBka2hzY1JmVWNnY0ZmeWhaYW5kWmgyZFVla2ZJY1ZnZWhIZVliU2JTZXhiaGJEYVdnV2ZKYnlhY2hIZEJmWGZRYTBmRmZTZkloVGdBZ0NoSmdIZFFmV2dHYnhlWmhIZ0dkWGRVYUxnRWFTY2RiWWRRYkdjRWE0Yk9jMWdvY0FiSWhCZVZkV2JUY2tmY2VZaE1obmhKZmJlRmdYZnRma2JXZEhlNWhiZVNkaGU0aDlhS2FWYTljTGhhYUdhc2R1Y0xmeWRZYTRkVmNYZ0piYWJWYnhmUWVVYWZhMWZKYjBlYWQzZHBnamdUZldkcGRMZURoMWhJZVFnWmFFaHhlMmJkYmxnSmdZY0ZmV2VsYmdjRWFsY1ljRmhRYndkMWdJY2NobmRCZHdlU2dFY05hSmZXZ25oVmE0ZVNjM2FkYjZmYWNWYmRiWmJFYUFoWmFvYkFjMGYwZjdkV2VWZm9mOGVTZlFheGZmZUNhRGc4YVZhVmRWYkFjVGRXZENiOGdoYVdoR2JvaGllT2V4ZFliL2NYaGtoWWhXaFliVGdWY2VnVWNUZ1VmYWFHZFNiNGJvYk5neGQxYnZnUmYwaGNjTmVGY0ZleGY0YWRoR2R0ZTZlWWMwaDFicWNTZHdkOWFTZUViR2FSZE1kZGZuZFpnU2ZRZGdiOWQ0Y2ZoaGZvZmZkVWFBY29jS2JiZ0FhMGI4Z1BneGg5YkRoVmZIZEJnMWZlY0VidGIzYWVobWNsZFhiV2JSYkFoWmhhYkFhdGhGZWJkeGVFZlRiYmMwYmRhemVFZzBlOGQ4ZVhnUWRFYURoU2ZXYjhncWRQZFFnRWdWY2RhR2h4YVJiSWIxZzVlS2NTZW1kbGRwY0hla2N3aHVkWGdUZVZhb2JIYmpiZ2ZjZEthQmRKZ0hmQWNRZEZnVmVXYW1mVmc5ZWVhbWg1Yk5lUGJrYUlkR2JVYWhnWmFrZVdkbWZOZmplUWhWYWNmY2VjYlhob2I0YVNkeGVoZERhV2ZXY0pleWFjZ0hhQmJJZFFkMGdsaGFoZGJYYWhnTGhkZTNicGZwZlhld2gxY1liVWVEaHNjRmFPZ2llZGhZY1ZmQ2FkaEhoYmhRYzFnYWVhY0VmRmNCYVdoVWVzZTZkWmFuYkpnV2FGZ1dkcGh5ZFVjWGNkZlhmU2NoY1plcGhZZ1JiWmhNZUxhbGgwZzFhVGdHY0Zid2dWZ1djOWFhZlJneGQwYWRkVmJWYkplMGRhZDNoTmM0ZlpnMmNwZExmRGgxZUlmUWVaY0VleGUyY2RibGRJYmZmSGhIYVJmY2dFZ2tmc2ZZZ1FhMWRsaGlkY2RuYkJkd2hTZ0Vic2hCZlZlQ2ZVYXFoQmNDYU1oMWZQaFFjNGdKYVZhUmRjYjdiUWh3aHdlcGhSZFhjOGNxYUFiU2hjZlRkV2htZWhnZGRSYmdhQWhWY1hkemFJYzljQWZrZ3dhNmZOZDFoOGFrZEhld2hOY1FlUGJTYzBiV2NCZldoWmdTaE1jeWJnZGlkSmRCY3dlZ2RGaEVlY2RWY1NhVmVsZVNhSmZtZUpoNmNPZ0dhZGJxZFNjd2U5ZlNnRWNHZFJiTWRkYW5kWmdTZ1FmaGRVYnFhTWcwZFloZWNTZGdhMWhaZWFkbGZoZndnY2JFZ2hoRGZTZFZlcGExYmVoRWR0YjNhZWNtZmxkWGZXYVViUWdaZWRjZ2V0YVVoZWVUZ3NmVGdiZDBhZGd6ZkVjMGNkZ29hRmZVZGhhUWJSaHhiQmNtaGNnbGJZYlZjZGhYZ0poWmFmaHdlTWZDY1hoemhwYnZoYWdWYkFodmdVaHlnNWZtYmZlSGJBaEJjSmR4Y01nVWVFZzJkSWRaY0hkU2FOaHJiWmNuZDlkTmZZYWhnOGhQZlhoeGdCZzFhV2huZjlhL2NYYW1jZ2FWYmVnSGhZZFNiU2J4aGhnRGdXZ1dkSmN5ZmNmSGVCZEliUWcwaGxiYWZkYlhnaGZEZElmemJJZmdmQmNGYWRmdmhWYlNhZGJjYlJjWGJJYlJmQWQyZVplTGFXYVJhTmhIaGFlQmJWZElkVWFFYWNnUWNaYW5oSmdXZEZhV2dwZnliVWZYZGRhWGFTY2toUmFwZlBiVWJvZFloYmNrY0FhdWJMYXphSmQrZUtkaWNjY1RhQWdGZlVjZGZVYTBjOWgwYWZoV2I5ZjJkWGJuZjliQ2FCZm5nZ2NRZFpjRWR4YTJkZGdsY0pnQ2RGY1hmaGUyYkVja2dzaFlhUWQxaGxmaWNhZEhoQmRoZFhla2NOYlVmUmYzZVVmc2dZYlhkZGY2ZWFiVmVkZ1poRWNCY2xob2JDZzBhVmN2YUVjUmZOZnZmUmgzZk1hTWVSYTJlQWFkZkhkQmNnZU9mUWEyZWdkTmVIZmxnd2h0Y09kbGVGYnFnVmZ4ZDViZWFJZERlSWNZYVpjeWFwY2JjTWVXYTlodGhjZkZjMGQ3ZUVkZ2g1Yk9lRWN5Y29jZWVPZnpieGU2YWZna2YxZzZkUWNnY1pmNGhFZUdmUmhNYWRlbmZaY1NjUWRoY1ZmNGRkYmhlSmdMZUdiRWhOYlplWWJtYWhod2hlY0VlQWNYZ0FnUmdNZG1kZGNqYVFmL2FNYXlhNGRmZ1dmUWEwYVpkWWNGYzhnTmZKY2tiSWNkZkVlQWQ4YzZjVmZBYjlib2JDZVZhUmFRaEVieGJsZW1kTGVsaFllZGFQZ2plb2ZZYkpiRmFrYjFjV2FpYVlmMmFGYmdlWmU0ZUZjR2c1ZzNjZGEzaEJmWWRiZXdmNWNPZ0ZmQmFSY1plZWNIaFJncmZlZ21hTmNOZGFoa2dzZlBiVWVoZUJka2ZUZUhoWmUyZ1Vja2RJZlZnZWFIZjVjR2VBZTFmRWRRZ1ZkeGgwZCthUGN5Y2RoSWVYaGtibGdTYUlnVGFBY0NjSmNIZlFjV2ZHYXhlWmZIY0djWGFRaFhlUmVUZXNnWWFFYzJobGFIYVpjUWhaYlNnZWd3ZEJoQmJYYkdjMGdRYVpobmdKaFdlRmZXaHBheWRVZlhiZGVYYlNoaGJaZXBjWWRSY1liWWVaaGhmUWMwYlpkamEwY3NnVmRXY2NhT2ZEYzFoUmdPYldleWMwaDhkSWdqZjBocmRUY1doeGFXaERkMGJRZUZmY2dWaDljamVmaDFjdGZPZ1BhM2FoYjJiRWZraHNoWWdRYzFobGFpYWNlbmRCYndkU2ZFY05oSmREY2plMGV4Z0dmRmgxYjZoYWFWZ2RlWmJFaEJhbGdvYkNjMGhWZnZmRWZSYU5nbWRYY0Zoa2dUY1JkMmJnYlZjU2JGaEJiSGFFZUdoWmd5YUNmeGh4Zm1nV2hGZkZiM2JWZDBob2FXYmFiV2RFZldiR2NHZFljY2NMZG1mZ2V4YUljaGNvYzdhRmVSZE5mRWNUZVJhQmZjZkpoaWZRZnVnSWNoaGtndmZKYTBhb2FVZFJkR2JSY1JjZGJqZzVlY2ZFY2thY2UzZEllbGYwYWZlUWJSZU1mY2ViZENiQWYvZEpmQWVSZURiVmNGZW9kemNMYlFoVWQwZUxjaWZBYVliRmV4Y0FmUmFQYkFnSmhGZE5nRGRzZlRoYmQwZWRnemFFZTBjZGNvYkZoVWFoZVFnUmR4YUFmd2dNY3dmUWVWaE9kSGZKY01oZGQxYjhiZWNYZGlnQWF5YkdkR2RjZHVkWGVTZUVhdWZZYVdleGFKYmJiMGJ0YlJjRmhCYzBhSmJVZGllQWRqZU1iemNCaERhRmJRYWRhQWNCY1FmdGdPZ1RhSGJaYzJmVWhrY0lnVmJlY0hjWWVTZ1NneGZoaERmQ2F5YmNlbWdKYVNiSWZHZ1FkMGNGY3diZGRYaGhnTGFkZTNjcGFwZlZmMWdraFFjR2hXZWdoTGFSZ1dhOGNaaFFnV2I5ZGFoY2F4Z3NnVmhhYkFjbGZVY1VlQmNNZ1pjWmJpZzVoV2VIYlRjaGF5YlRhMmVsZ0pnU2ZoZzVmNmJjZHhiWWVWY1pja2VCZ3ZmYmEyYmhlOGNmZDJkOWhhZlJheGEwYWRhVmFWYUpoMGdhZDNocGJqYVRoV2VwYkxlQmN3YVpmWWVMZ1JoOWQ0aENkUmU0YU5mUWNuY2hocmRFY2xoMGZOZFZha2hwaDNjY2VuY1pjd2VHaGtmcGNGaGNkSGNWYTRiU2QzZ2RlNmNhYVZkZGFaZkVoQmJsZG9lQ2EwaFZmdmNHZVVkY2JuYkRhaWZBYmRjT2FDYkJkY2FEZXhnaGhIaERoV2VZY2dmVmNnZnRkMGJiZ0ZmRmdtZ1FlVWJNYmFlUWcyYUVlV2FHY0djWWVVYVphbWdaZWhmY2dGYlZldmhXZmtlY2FkYVNkUmMwZ2JoSmMwY0ZlNmZZZDBkMWFxYVNld2U5ZlNlRWdHZ1JiTWVkaG5hWmhiaFdnVGI5ZzRlZGJoYkplTGVHZUVlTmJaaFllbmZKZHdiTGJVZEZjUGdZYTFmcGgxYWVoRWF0ZTNhZWVtZGxlWGZXYlJmQWFSZUliQWFVZlZmUGdWYzVkSGFJY0JmTWhxaFFjd2dKZ21hUmd3YWNjRWdCYmtoUWdqZEFiQmM5ZVNjSWZpZ1pmUmZhYmxiY2FDYUdiRGRrYnpoV2dVY3dicGhRY0RlOGMyZ0pkSGc0Z0hlSWFBZzRjVmNIaFFmQmRWaEZiQ2RFZWxnT2dUaGNnRWZKYlFoVWZQZldna2NSY3RhVGZDZzFiY2dVY2tlSWJWZ2VlSGJZZ1NnU2h4ZGhjRGhXZVdhSmZ5ZEpiamZFZGFnUWJ4Y3RhYWRhZ0hjaGVEZkliemVJYWdmQmRGZGRldmRVZFNmRmJNZkRlV2I4Yk5iRGYyYzloV2FaY1JicGFIYU5hQmhVZmNmR2NBYTVkRGFhYkFhMGNhZVdkamMxZXBoZWMzZGRlWGZTZGhjWmZwaFllUmVZYlliWmFoYlJmbWdaYWplTWExYUFoVGhvZkllQ2RSZTBiVmFmZzFkSmMwZ2FiM2ZwZGphVGNXaHBiTGVEZzFiSWJRZFpjRWR4YTJnZmZnaEJnQ2RDZkhlaGMrYVFlRWVzZkdoWGRVZGRlaWVKZW5ibGd3aEZmRWROYkJmQ2RIZlZla2VWaDNhZGd5ZmVia2RWYVpoSGVSZWtoOGFBZ2tieGRtaEhjVGRsZHZlUmEzaE1lVGFSYTJiZ2FWYVNhRmRCZUhnRWJHZ1pheWhWZ2hnMGYrZU9laGFnYmtmV2hUYlZkYWdKZmphWWhXYkJlV2RZZkNoY2YzY05ieWFaYlZhVmJwZldhaGdVZlVjRWRYZzloU2NkY0dndGE2YllnMGIxY3FhU2V3YjlmU2ZFY0dkUmRNZWRnbmU0Z0dhQ2ZsZXdlcmJlaEdlMGNEYVVjUWFRaFJiWWRtYjlid2FJYmtmaGJkZVZkMGNSaDFnYWJWYjFiK2hkZWtiTmdYYVdiUmNBaFpnYWRBYXRlRmNiZXhlRWFUZGJlMGRkZHphRWV4ZE1lZ2dYYUJldGQ2YVJmeGJCZ21oY2VsZ1lmVmZhZG5oSmRSaGRkMWdkZktoSGYzY0pmTGdGZWhlaGJtZ0ZjR2NaY21lWWNYZEJiVmZiZ3dnZGhPYUVlVGJkZFZmVWJuYlJkcmZlaG1jTmJOaGFia2JzYlBiV2FsZGhjcWFIZENjUWU1Y0JnZ2ExY0JhSWhTZVpmWGFSZ1Zlc2RQYUZkaWF3ZzNiY2FHYjFmSWNCY1Jmd2FVZk5haWF3YkNkT2ZEZFJkcGRYYjFnQWJRYlFja2VJZ0xlUmNXaDhhUmdFZzJlOWFIY2NheGdOZUhjYWFCZ1VlYWdGZ1JiTmFGZ05nRGJ4Y1dlV2R5ZDhmbGRVZlRkOWdmY0hobGU0Z2djTWdoZGhlbmVLY2xmc2J4ZWFjbWFFZGthSGRTZVlkSmJTZVdmSmNWYkhoQmNVZjhhWWhtYUZkSmRUYVdhcGFMYURmMWZJZVFkWmdFZ3hmMmRkYmdnOWJMZEdmVmNKZTJmRWNrYXNoWWZRZDFhbGNpYWNlbmNCY3dkUWRBYnBiSmVSaDNiVWdEZk5kbmE1YTJjUWQxZGRiWmNFZ0JkbGZvYUNiMGJWZXZnRWhSaE5mbmZBYW5hTWRPY1JheWM1Z0FhQmJoZ01mVGVXY1Nka2M4ZVZjaGcxZWpiY2JnYXBhZGdWZzBib2NXZGFnV2VFZFdkR2JHaFllVWFaaG1hWmZoZElhaGNBYjdlRGV4Y1ZnVGJIZ1JoMWVKYlhkbWV0aDZkWWEwZTFocWFTZ3dmOWJTYkVoR2JRZFJnZWNEZmNlQ2NFY2xma2RoYWZoa2FCY0hnR2hBZHBoUWRhYjNjNWdhY2NjRWJoY0RlU2VWZHBiMWdlY0VldGIzYmVkbWRoY2ZlRGIxZjliUWFMZ0FndGVWaGJleGNBZ09mY2draGNlMmhFYjBoRmZ1Z0ZjVWdBY0ViU2hWZ1VmK2hJZWhobGdIYVBnaWZGYVJmYWRsZWNiUGFIYzJjQmU2ZFBoQmVoYm1oRmhHZ1pnbWNZaFNlMWJjZ1pld2Y0ZVBiVmRFYTVnY2JTZlZnNWFyZmVobWJOYk5hTmIwaGNhbGFVaGhhQmNraFRoRGJBaGpmSGFBZkZiQmJNZFRjbGVjZ1NmeGdBZFhhVmNXaEllZ2JlZVhmQWhUZWFoVWVsY2FhZGVYZmhoTGVkaHlmd2FvZ0JiVmZsZVpoRmFXZ2hoT2dYYmtlVWRSYUVoMmY5Y0hjY2V4ZE5kR2VZZUZnTWZkY0hjZ2NSZEVkTGV6ZjBjWWFGZldmSWI5ZVdoSGhjY01jWWFCaFplcGNZZlJlWWRZZFplaGhSZG1kSWJEZlFmK2VGZWpnc2RUZ0NlRmhNZmRkSGJWYW9kZ2haZTNnb2J4ZlFhV2NvaENlQWcxaEpjVmJiaFVld2N0ZVhlRmdKZUNkRmJYaGhkMmJFZmtkc2NZYlFoMWZrYndnTmZ5ZFFkbGNHYmdjMWNKYURmamEwZXhnR2hIZmNoemVKZndoUWVOY1VoVmZjY3JmVGVnZG9jcGJFZ1ZjdGhGY1JoM2ZNZlRiUmUyY2doVmdTYUZjQmZIYUVkR2RaY3llU2JSZlZmaWdlY2dkVWEvZkhkaGdrYVlhT2V5ZFJmYmJXZ1NhOWFhYUllaWJNZ3piY2ZFYmhmdmVGZ0JjSmZSY1VkVmF4ZWVlWGZtZ3RhNmNZaDBmMWdxZFNjd2c5YVNiRWhHZVJmTWRkaG5jWmVTYlFnRWdZYXNmSmdGZnNkRmNYYTBhRmFaYmZkMmQ5ZXdkSmhCaEVoVGREY0JmVWd6Y2VlQmY5aGRiZWRtZmxmWGVXZ1JoQWhaZ2FoQWh0ZEZmYmR4ZEVjVGRiYTBhZGF6YkVlMWdoZm9mVmFFZ1loVGNCYmxid2RxZmVkZ2NKaGRoSWR5Z0ZkZGZkZ3dmTmdHYUZmamd0Zm9hUGZCYWhnbWhGZUdiWmJtZFliWGdCaFZhYmgxZnBlSGZIYlJkMWNWYVVhbmJSaHhnZWFtY0VlWWVKZEFkOWVLZ0ZkRmhraHFlQ2FUZkpmMGRVaGxjOGdJZGVmQ2FKYkxnR2QxaDBhTWNIaDJhSWFnZVdibmRCZUlmUWQwZmxnYWRkZ1hhaGFMZGRlM2FwZHBkVmMxZ2tmUWJHY1dhZ2NVYVJhVGF3ZmZnVWZDZzRoTGFQZ3hmc2NUZkljRmd3aGJkWGhFYmRoRWRiYzFmaGJXZkZkV2dwY3lkVWRYY2RnWGRTYWhoWmRwaFliUmZZY1ljWmdoaFJobWdmZkdoRWZtYkdoaWFZY2VoUmIxY01oVGZGZkFiSWhrZkpjeWFOZXJlR2FTZElmQ2VYZEZlNGdRZkpiUmU0ZHhmSWh4ZDhoSGNXZ3ljd2FsZkdjMGhJZ3lmUWExZWxlaWFjZG5mQmV3YVNkRWZOYUpiV2duZVZjNGhVaFhmY2MwYkxhQWJCZ1pmV2RCYUVkOGZCZTBmVWI5ZUhmUmZNY21nU2YzYU5jV2ZUZW5nTWcvaFNoRmVCaEhjRWRHZFpjeWdWYWhhVWczZldkRmNGYzNnVmUwaG9oV2VhZ1dhRWRXYVhhamdOZ2FoSmVUZUlnb2dQZXhldGh2aEZiRWQ5Y0pmRWJWZlVmQWJlYUdic2h6Z2JjMGgwaHZnUWJnYjhmSmVPY21hUmVNZmRjbmRaaFNhUWNoZFZjNGRkZ2hmSWdaY1hoUmJjZ01mTWJEaHhnd2NjY2hnMGNOY0RiUmE4YXpjTWhRYVVleWZQZ21kdGNYZFJmQWIwZlphUGVGZUljVmJLY2xhNWFWYmJod2E1ZlpiRWIwY2Rnb2hGYVVhaGRRY1JoeGFCZW1iY2JsaFlkVmJkZVhlSmZaZGZhd2FNYkNnWGF6aHBldmFhYlZmbGEyYkJiR2NaZDdiWWZXZlpoQWdlY2tmbGNTZEhnUmJ0YlZoQmhuZTFobmFVaEdiTmVOZGFla2VzYVBjVWhoZEJla2dUYkhhWmgyYlVia2NJZFZkY2VDY0pmYWFBZ2thdGJOYkphaWZOZ2pjWmNuY0JnVmJRaHhoMWRhZWFlMmJaZFZjZGUyZXRkL2VYZ2xhVWY2Y0dkV2ZnaExhUmdXYjhmUmFFZDJlOWZIYmNleGFOY0hnYWFCZVZoQWZCZUFnOWZaZE5jWGN3YXBkVmFIYmxhZ2RVaFdlcGVYZVhlQWROZDhiY2NnaE1mWWRZZkJkUWgwYmJhMmYxYWFjVmZXaDljYWJSZHhiMGVkZlZlVmNKZDBmYWYzYnBiamhUZldicGZEYldneGdwY1piTmMwaEliSmdOYTBhWmJhZEZhV2NWZTJoUWRFaHNnR2VYZlVkZGVpZ1loMmdaYzVjUmJHaGxhSmhXYm5mVmM0aFNkM2NkaDZhYWdWZmRmWmRFZEJmbGhvZUNheGFFaG5oV2NFYkJobWdiYlhoTWNUZlJiMmVnYVZoU2FGZEJiSGhFZkdiWmJ5Y1ZkZ2Y5Z3FkZWhsZmtoamFIYXdoTmVGY1pieGY1aFhlQ2ZIZFllVWJlYjJoWmN4ZWNoQWhsZHZlRGFraDRnUmVOYzFiVmZTY2RoR2h0ZTZjWWEwYzFjcWJTY3dkOWVTYkVhR2dSYk1nZmNpY0lmYWJDYjBnWmEyY0NlVmJOYWFhRGRraE5nRWdZY21nSmV3aExnRWdnZFJkUWdGY1phZmdlZkVldGgzYWVnbWFsYVhhV2ZSY0FjWmJhZ0FodGRGY2JleGFFaGJhT2d3ZzhhNmhRYUVma2VYZ1ZlRmR0YUNiUmZ3ZTFlbWNZYWxkWmZKZ2FnamF0YVloZWgzYzFhS2RGZW1nbGhoZUZkaGJoZW1nRmFHZlpkbWdZZFhmQmRWZmJiMWhJYlRkVmdWZlFhR2hYaEFnc2FxYmJhbmJ0aE5nZGgwZHNmZmRVaGtheGZrY0NhWGI5YjZiZWVFZkliVmVlZUhhWWRTZ1NkeGdoY0RjV2NXZEpieWRjZEhmQmNJZ0Zod2VFaFRlSmRuYkZlUWdYZVhmcGhwY1ZkMWhrZ1FnR2hXY2djTGdHYUVhVWNSY0VoMmQ5ZkhoY2h4Zk5mSGJhZEZiTWRkY0hlZ2FSYUVoTGd6YTBhWWZGY1RkbGg2ZEJnWGI1aFhmRWdUaHhhcGVZaFJoWWVZY1pmaGhSYW1oWmVtaEZhd2RCZ3lhb2dPYkVna2c5YlRiVmdWZXBjZWZhYjNmcGdqYVRhV2VwZUxjRGQxYUlmUWVaZkVieGcyY2ZoZ2ZZYktnWGZDZXRlNGZiYlFlb2NJYVVnMWNsaC9nY2FtZVplbGdYZ1ZnQmhjY1dlbmZOYzRnSGIzaDVkMmFRYzFlZGdaY0VmQmRsZG9mQ2MwZFZidmRFZFJnTmN2YVJjM2Z0Z0hoRGZ5ZkZmR2JSYWlmOGdHY0FhWGNCaHljU2J4Y1VhK2JjYmtnOWZwZ1NkVWNvZEhiZmYyZGdjYWdNZG1mWWRVZFpkbWdaZWhhY2ZGZ1ZidmNXZmthY2NkaEhiVmEwYUdmUGRDYklhcGhiZ1RnSWZyZ1doQmIxaFNnRGVXZlJkY2RmYzNmcGc0Z1FnaGZWYjRjZGRoY0piTGFHZkVmTmNaZlljbmZKZXdnZWJCZXdlTGZBY0FnbGQ3ZkJhd2NwYWpoWWhtY2xkS2VXZVFhQWRRYlpiQ2VGZ0ZjYmJ4Y0ViVGJiYzBoZGN6Z0VjMGhkaG9jRmZVZ2diRWNEYjFia2IxZFdoRmNZYlZmYWFuaEpkUmJkZjFkZGRLZUZmbWhsYW9kRGFUZkpibWFGZ0dmWmhtZ1lmWGdCaFZjYmJ3Y2RkdGFIZFJlMWNWYlVmbmNSZ3JnZWRtaE1nTGdQZXdlVmZNaEJnbGdraHJnQWRuY1lmM2dXZ2hnWWhaZWVkQ2dRYmJlU2YwaE5lcGJXY1dlSmF5ZWNnSGRCYkloUWEwYWxoYWZkYVhnQWFaY2RiMmNkaHBmQmJWaGxiTWVSZFdmZ2RhaFZiV2JZZGRlT2VXZzlnSGVjYXhjTmRIYWFmQmhWYUlmVWFFYmNiUWNaZW5ob2hDZVhoU2NNZGhjWGN3YWdmV2JXZGdiWmZwZWZlQmFZZEloYmZ4aGhoTWRaY21iRmV3ZlZiV2g5ZGFhUmR4ZzBlZGZWY1ZjSmQwY1loeWM0ZHJiQmREZWxiRmFjYUJiTWRCaGNla2d4Y3JlZGJrZEpjTGZHZlZkSmEyZ0Vna2FzYVloUWgxZmxjaWJjZW5nQmF3Z1NjRWFOYkJoRGdqZzBieGdHZUhha2VGZEtmRWhSZExlRWVBZVJib2RHYjBjeGJqZk9heGJOZHZiUmczY01mVGJSZzJjZ2RWY1NoRmhCZEhjRWZHZDRibWRIYWxld2g1ZmZiQ2E0YjJkUWYxZUliV2hkYUdnRWdHYkVnWGEwYytnWmhtZ1pkaGJjaEZnVmF2Zldja2djYmRiSGRSZE1iZGJKZW1hdGV5aFNlVWcxY3FnU2d3ZTljU2VFZEdmUmhNYWRlbmRaZ1NmUWRraE1nNWJKY0JoSWJDZEdmRmM1Y1pnTmV3ZGthaWFEZ1VmZ2RmY0ZlVmVvYjdkUGNSZnhnM2hNZW1lRWY2Y0dnRWJSZlJlWmJsYXNkS2ZPYUJlbGhCZFljMGFkYW1nR2NraDVia2dGYlFiMWVRYldoaGhCZTJiZmdsZFpnYWVhYm1oOWZSYklnMWFrZkdiVWF5aGNhbWZRZ2xiQmE5Z1BkbWRaYW1oWWNYZkJhVmdiYzFncGVIZ0hkUmMxZ1ZjVWVqZXRocmNaY0djTWVJaGNmV2NFZVBhVWNoYkJoa2hUZUhoWmUyZFVia2RJZVZlZWZIYVphWGNTZ3hhTmFlYVdjWGVkYVlkY2VIZ0JjSWFRaDBkbGNhZGRoWGhoZExnZGMzZk5kcGVEZkhjTWFRYkdmV2JnYUxjUmVXZjhmUmJFZjJoOWhIZmNneGhNZFJjS2dVYWRnSWRIYWtoY2NOaFplaGI4ZlhiUWhTaEpnOGFIZURhNGhaZlFmZ2ROYmxmWWFWYmtkWWZhZnhkUWNqZ2JnMmcxY2FhVmJXZjlkYWRSYXhnMGhkZFZhVmRKZDBlYWgzY3BjamJUZVdob2ZZaERnMGU4ZVFkTmNBZTBoa2hKY1JiY2ZyZFdkeWV4ZCtiUmdrY1ZmTGdEZHhnQWhoY05iM2VnYTFkUmRFY01mTWNXY25iNWU0Y0JlWGI1YzJkYWhRZlZlUWhDaHpmTmhvZ0NnMGZWZHZnRWJSYk5hdmZSZTNnTWVUYlJnMmRoZkJiQWJCZGthVWdIZ2loc2huYUdoa2VFYmpoSWNoaDBkdWVYaDFoOGJXYWRnMmZGZFliR2NIZ2tiVWNLY0NhTWcyY2NhQmgxaG5jTmZ3Z1pnSmdWYVZoc2JDaE9iemJ4Y3lkTWJVYkZhcWZCaFFhWmFiYUVmSGU1Yk1iUGIzYzljY2JBZzFkRWM4Z2ZlbGN3ZE9mVGMwZ01nUmdhYWllRmg1ZGVlVmhOZXBjU2hWYnBoMWFlaEVmdGMzYWVmbWRsYlhoV2dVYzBoemFhYkFldGJGZWJmeGhFZVRnYmYwZ2RhemdFY3hjVWh0Z1FlUmgwY0NnQ2VSZ0FleWVPZWhjOWFHYWNmVmVoYVJlZGgxZWRiS2dGZG1nbGNoaEZma2RWZ01kRmdHZlpjbWRZZVhoQmVWZWJkMWhvY1JnWGRFZzlnVmJCYzNmUmUyZGVkamJoZW5lYWRrZ3NhUGdVaGhiQmJrZVRoSGRaaDJnVWdrZkloVmdhZ1djQWZJZlNkMWFCYkxnTmZDY01lbWFPYUhmNGhZY0RiQmY1Y1NnWmdHZTViSGNkZTJlOWNnZ1hibGRVYzZiR2VXZGdiTGZSYVdjOGJSY0VlMmc5Y0hhY2N4ZU5hSGhlaFFoVmJTYlVnQWI4Z1liQ2F6Yk1kQ2RYYldlUWhpaEhnaWVCZmZoV2J3ZlpibGRZZlFoTWJSZWJheGFoY01oWmhtYkZkd2NWZFdhOWFhYlJmeGEwZmRjVmFWY0pkMGRlZFdmQmNqYUJjV2RJZG1hVGdnYVpkWWdhYWhhd2E1YkljVmdwYVFhR2VYZmhoamRHZDBiSWVVZ2FjVmNsZ2lnY2VuYkJnd2ZTaEVnTmFKZ1dkbmZVZGxnUmYxYzFlNmJhaFZnZGJaY0VoQmZsZm9oQ2QwZlZmdmhWZ3hhTmR5Z1JleWhnYlRiVmVuZDRoUGJTYkJiaGNQYkFkWGJCZDdlV2hoYlZmN2dZY2tkdGEzY0hnMGdJaEhmZWJXZmdnYWNHZUhkUWZPZ1piaWg1ZHBjWWVsY3hodmRCYjFnd2MzYUhkVmNWZlNkZGVHZ3RlNmJZYzBmMWNpZkFnd2FFaENlUWRpZ3NlWWJPZlNlSWRMY0VlbGJCZDJjTWZFY0FlRWhWYlNoRWhRYU5naWVGZndiYmNVZmdmTmJRZEZlWmFmYmVjRWJ0YTNjZWJtYmxkWGFXYlJkQWZaZWFkQWRNaE5lWWNVYkZmQmRJaEJlTWE4ZVJkeGc0ZDRmVWhFYllnV2ZGYlZoOGNyaEhiQWdOaFllS2dEZGNkRGNkZTBjcGNLZlJmV2hCYXRkUGVCZGhmbWZGY0dmWmRtaFloWGFCYVZiYmQxZHBkUGhWYlJiTWJGaEFkRGRzZi9nTmRUZGNlVWRPZGdoNGJCZEZmRWdJZnJoQWZRaFVmaWdBZkFjdGhiYlBiM2hZZVBhU2QxZWxlS2hWYlVkaGZ5aGNkSGVCY0lnUWUwaGxmYWhkY1hnaGhMaGZnemNKYW5hQmd3Z3RkZmJUYlNjZGRmY0hhRGE5ZFVlSGVUYnNlSWNIZlVmWWdLZkthbGhBYmFoVWdGY29kUWRJZUNmY2NZaFZlamI0ZTdhSGFqZWxlWGhRaGhjOWVwZE9lamF3ZVlkWmdoY1JibWVaaG1hRmV3ZVZhV2c5Y2FhUmJ4ZTFiUGhFZEFhWWFoZk9nVGdSZGplV2YzZTljZWZIZUVoUWdRY2Jia2R3Y2lkUGZoYXNnUmNHZHdnY2gzZEFoMWEwYVljU2VGZGtoMmRPZGpha2dqZVJkamF3ZEljU2FtZ1ZkamdZYlhjZGY2Z2FiVmRkaFpiRWRCY2xkb2RDYzBjVWR5aEdhQmY5YUZnUmYzZk1kVGJSZDJkZ2hWZFNoRmFCYkhnRWJHZTRlNmRXZUVmVWE0ZlBjUWJVZzRiQWR4Z05nR2hMaEdlOWhDZlZkeGRWZkFiTmVDZThodmZOZDFoVmZ5Y1djZ2hGZ0lkVWR4Z1lkR2dQY1NhUWUwaFlnMGZVZStmUWZnZThmSmNPZ21hUmVNZGRjbmNaYVNhUWdoZlZjNGRkYWhiSmFMY0dlQmhkZlpnZmczZ0lha2FjZkJjUWVmY1NmVWZ0YmxnWWEyZUZiM2RlaG1ibGRYZ1dnUmRBZ1plYWVBZHRkRmViYnhmRmVGZExkaGVWY3poUWVVZGRlMWZGYlFjNGhyY0VmMmQxaG1lTGFnZm9lVmdKZ0RnY2dHY2RkeGU5YUNiUWVtZkJlNmJQZkJhaGdtZUZkR2RaZ21oWWZYZEJkVmRiaDFjcGVIYkhlVmRRaFRkVWduZ3hlcWRMaGlhc2NFY09jVWdWY0lmQmJoZWdkMmNSZFhkOWIyZUFkQWVkZkJnTGhTaFJmY2VTYTBmd2JMY0VjRGVGZDhoSmNEYThjbWRGY2dkUWVZZU1nQ2FwZURhZmduZlFiOWVHaENmcGdFZFNkeWFGZkZoQWJtaGRjRmdHYW5hUmR0ZGNneGdOYUhlYWFCZVZiSWhVZ0VmY2JRZVplbmFKYldiVWV5Z1VjZ2dVYlhiOWE5YVNhaGhaZXBhWWVSZFlhWWZaZWhmUmFtYVpibWZGaHdjVmdXaDhhTWVCZGtiOGJkY0hjRmZKYnBjYWh5ZjRocmFCZURjbGJGZVRlQmg1Y2ZhS2ZnZGxlK2FmZzFoNWJDY1VmSGRoYXJhRWNnaFZmZGZGZkZka2dEZUllQ2hJaHhlRWFVZXRlZmRUZ25meGcwYlNnemJoYjZoZGVGYmRnUGVBZXdjSmNDY0NnMGFWY3ZnRWhSYk5hdmRSaDNhTWdUY1JjMmZnZFZlU2ZGZ0FjSWhFaEhoaGd2aFZoZ2VWZ3FjZGRGYmRlZGZWZTBjb2RXaGFhV2VFZVdlR2JHaFlhVWhaZ21nWmVoY2NnRmNWZG5nRWQwZmxmWmFWYUFoTmhhYUpobWZKYTJiWWMwY1VkdmdNZUVlQWR2ZUVnSGZsYU1hUGMzYWdnQWJCYTFmZ2U1Y1BlMWN3ZlBkWGRSY0ZoWGVOYmphMGZlY0pjUWVVZEJnRGdBYmhnOWVjZVVkVWhqaE5nUmdvZURlQ2IxZmxiWGFMZndlTWhSZ1pkaGdnZ2ZnYmh3ZjViOWdWaEJkTmJnZFJkMGdGZVpiWGNEaHBhbWJjY2xlWWVWY2FjbmZKaFJlZGExZmRiS2JGaG1nbGJoYUZmbGhkZ3JmR2hVZXhibWFZZVhiQmNWZGJmMWRwZUhhSGJSaDFmVmZVYW5nUmFpZVlkVWJsZE5kYWNrZXNhUGdVZWhjQmNrZ1RkSGNaYzJoVWRrZ0phSGFQY1NkSmdIZEdhVmJaYkRnVWJTZ2NjSmJQZTNhQmdGaFFiMWNnYW5jZGJXZFZhTGdQZG5kUWY5YUdiRGNkY0ZnVmdDZnBjT2FGYzJmY2hZZ0hjVGhzY0lkQWNFYWNiVmNJZlZkc2hQZldlQmRNZ1poYmUzZjVkV2VVZkdjUWI0YkhjamY0ZlpnUWRoaFJmcmZhaEFnMGZ5YVpnaGdSaG1iWmVtY0Zod2dWaFdlOWNhZFJmMGJBaFVlV2dYYWhmMGJhZDNmcGhqaFRmV2FwaExkRGIxZklmUWRiZEFjUmY0Z0phZ2JBYk5oUWdUZWNlaWVTaHhkdGVkY1RiUmNnZW1kTmhuZEJldGNTZ0FiVWVjZUZnRGJZYXNmQWdqYWdhMGdhZlZoOGdOYkdlUmVrZ3poSWRVZlZidmRFYVJhTmV2aFJoM2VNY1RkUmIyY2diVmVTaEFhWWNHaFFmbWdZZGdlVmVnZmhmcWJKYWhla2YraEJlRWNSZHBlS2dIZEViR2FHZEdiMGNVZE1jbWFnZGVkTWJVYVZoL2VWYm1mMGFkZ0hhVmZWY1NmZGhHY3RoNmZZYTBkMWNxYlNhd2E5ZlNjRWVDZjFjTWJhZzNoWWVBZFFmZ2F0ZW1hYWRCZkpnYWREYmxjaGV6ZlllbmdKZXdmY2VFZmhmRGJTaFZjcGcxaGVjRWV0ZDNhTWUyYmxlY2NSZ0JlQmdOZUlmRWNJZVdjWWdXaDVkU2NmYmxoRmJ6Y0dlRWRjZThkR2Z6aGNhUmhWYmdlWmg5aFdiRmVZZVZjYWRuY0pnUmZkaDFkZGNLaEZobWhsZGhhRmdrZjRmbmRSaG1oWWJqaFlmV2gxYVZhSmJsYnBmWmVBY3dlTmdWYlFlMmhKYndlVWNHaE5iTmRhYmtic2FQaFVkaGZCaGtkVGZIZlplMmZVYWdhY2dWZGNiMmFzZFNjSGUxZ0FmS2ZDZm1od2VOZE1hV2FOZWFhUWUwaEpjYWZJYlhhWWYwZ05hbWFsZzdlVGVIaE1hUWRHYldhZ2RMYlJoV2M4ZVJjRWQyYjllSGFjY3hkTWZSY0tmVWNkY0ljSGUwaGNhTmRaZWplZGVXZ0NlM2VSZHNiVWJXY1pnQmNVZlRheGdwYVlnUmRZZ1liWmJoZlJjbWFaZG1kRmZ3YVZhV2U4YkljQWZrZWxhSWRCZHhleGcwYlllMWJCZGpnVGhXYnBjTGNEZDFjSWhRZ1pjRWZ4ZTJhZGRsZ0pmQ2NGZ1hlQWE1Y0Via2RBZUZiUWZ3YTBncWhPaHlmTmYrYk5id2VKYWRiUWhuZlZmemZTYnlnTmQwY0ZnaGFaZ05jQ2VCZUJia2FJZlViVmJ2Y0VlUmZOY3ZjUmUzYk1jVGZSYzJnZ2NWZlNlRmhCZUhlR2REZUlnNmNIYjBhWmNrY0RkUmZCYW5kUmUwZ29oTGNhZFhlY2JEZkRnWGVVY0JjWmFtZUJlaGVJYmxoeGRqaGNmRWVjaGRkSGZWZlZhU2JkY0didGg2YllmMGIxaHFlU2F3ZDlkU2JHZERiQWhFZlBoeWRWZWNkUGNWYlJjcGJZZEJlSmZXYUdoRmJWYk1lZGgyZkZhbGdjZ0VjNWVEYUFmRmFOYjVkVWJrYXRoM2JlaG1nbGVYZVdlUmJBYVpmYWVBaHRiRmZiaHhnRWdUZFpkeGhNYTdoV2NoZFJibWZhZGdnbGZEZ1ZkUmRCZDdoY2JrYUFoQWRmaDJjRmZFZGRnMWZGZUtjVWgyYUJmdGRQYkJnaGRtYUZnR2ZaZm1nWWRYYUJoVmZiZDFmcGdIZkhiUmgxY1ZoV2JpZEFjamRNaHpkQmJEYUZmUWJvaGJkU2JoaEJhNWZUZ0dlQmVqZ1JoMWVFZkFkZWdIZUFlU2hCZUJkRmVQaGNiMmRKZHljY2RIZ0JoSWJRaDBkbGZhYmRlWGdoZkxnZGUzaHBhcGVBYnhoRmZaZlNha2ZJYUxlUmhXaDhhUmZFYTJiOWdIZmNjeGROYUhkYWdCZlZlQmdTYTJnMGZRZ1pjbmFKZldoRmFXZXBkeWhVZVhhZGdYZUZmeGM5Y2xnU2R4Z1lmWWNaaGhiUmRtZ1pibWdGZ3dnVmZXYjllU2hEaHhiTmJOYkJleGgwZmdnSmVDaDRhNmhIZVNlOWFGaFhoQWJkY1NjTWdCYzRlM2hOZ1FoWmhDZUNhSGVnZXdnUmJ3YlZoYmdGZHhoQWN0YVBhSGZCYjRjSGNFZXBiSmdBaFZjOWY0ZlNjM2dkZjZoYWhWYWRjWmRFZkJnbGNvYkNoMGZVZzllVmRFYmNjNmFGY1RmMGVUY0VneWNCY2NkR2YxYjRjR2dWZENlSmI2YkFiaGJzY3BhUGNoZjRoNWJFZGtiSWZmaFpkeWI5YVRlWGR5ZGRhQWFJaDJlNWVvZmViVWE1YkZjV2draGNjZGZIYVZjVmZTYWRmR2d0ZzZhWWF4YUJlamZSY3liVmZTZEVnR2hSZk1nZGVuZFpoU2RRZWhnVmc0ZWZhbGVwZEZoU2JCZkVkV2NOZmpoMGJrZ0tkUmhnYUdkUmZ4YWNiZ2hOYkJmOGErZUtlaWFVYU9hV2dRZzBlWmRMZmxmNGFMYUxmRWFWYmFhSWNBY2xiemdHY3hkTmNoZkZnUmdOZzZnUmR4YUJobWFjZWxiWWVWZWFlbmZKZlJmZGgxaGRhS2ZRZENjZ2R6Y0Zha2ZwZ21iQ2RXZVlkeWJLYlRha2FHZVliU2JVZ0dhRGFRYjFmWmhlZUhhUmNyZGVnbWhOaE5jYWJrZ3NnUGFVY2hhQmZraFRiSGFaZDJmR2YwZ0ljSWhlZkNiSmdhZEFma2F0Z05jSmVpZU5lamdaaG5leGVpZVFjMGdsYmFiZGVYY2hlTGVkaDNlcGRwZFZkMWhrZVFnR2VXZWhkT2hSYVhnSWNSZFJoeWZjYk9mSWZCZTBjNGFLaFFlWmdhY1hkR2UwY1FlWmFuaEpkV2ZGZ1dlcGd5ZVVnWGRkZVhiU2NoZlpmcGNZYlZka2RZYmVmeGVRZ3lmTGVpZmdhamNXYXhoQWhiY1Vid2hVYlJjZmcxZkpkMGJhaDNjcGVqZ1RhV2hwZUxhRGYxaEllUWhaYkVjeGYyZlBibGJKaGZlRmVTYXhiNGViaFFnb2ZJZVVkMWNWZkloY2JuaEJid2RTZEVjTmhKZ1dlbmRWZzRiU2QzaGRjNmZhYVZkY2dYZ0VlQWJSZm9hWGEwZHNjUWRVaEFmSmY1YVNjMWVrZlRhUmYyZGdjVmdTZ0ZlQmFIZkVjR2FaY3loVmVoZFZkcWVjYWdiSmMzZ1Noa2dwZ0NlWmJ4ZzVmWGZDYzNnUWRZZ1RnR2VaZ2hlY2FGaFZkdmdXZWtnY2hkZUhjVmFWYVNmZGFHZ3RmNmNJY2thMWgzY1NmMWZ0ZWNmYmN5ZVZmWWViaG5mcGQ0ZVFlaGZWZDRnZGFoZUpmTGVHZ0VlTmFaYVlmbmZKZndnY2FFZWdjV2VTZFVjZGYxaEtla2Z0YTlhZWNpZ0ZkYmJjY3hnQWVaZGFmQWF0YUZkYmN4ZUViVGdiYTBkZGR6YkVoMGRkYW9hVWQwYmhiTmFSZTBoVmJtZ2JoRWZnZExkYWFtYU5oSGhiZEhjMWRLZEZobWFsY2hjRmVoYWhjbWhGZUdhWmRtY1liWGZBY1RoYmMxZUZnYWVIZVVlOWhWY1djSGhRZWxmWWVVaGxoTmJhZ2tic2VQZFVkaGdCZmthVGFIY1pnMmVVYWtnSmNEYk9mU2JRZVNhQmV4Z2hlZWRXYlNhUmR5YWJhbWI1ZFdkUWIxZmhnTWJiYmxlSmdMZWRhM2RwaHBkVmgxaGtlUWRHZFdmZ2dMZFJmV2g4YVpjVmNXZzljQmhiY2hiTmhSY2ZlUWZCZmJnUmhVYTRiY2FaZG5ob2VRaEZkV2RGYXZjVWJUYzVoWGVRaEJlWWVoZ2FnQmFvYVlkYmdsYWhobWRiZFhjeGR3ZUVjMmM5YUViV2dRZ01jZGNSaEVoUmM5YlpjM2hwaHJlQWRXaHBnQWNFYmxkSmNDZFpjRWVaYzJhSmFWaHRmWmdQYTNoaGcyZUVma2ZzY1liUWQxYmxlaWJjZm5lQmh3ZVNmQmhVZElnQ2dIYlVmN2RTaDJicGg2ZkpoVmVkYUhhRGNnaGRjb2hHZWxlTmQwY09jeGROZHZkUmczaE1mVGFSZDJkZ2FWYVNjRmZCY0hnRWREYlFnM2hBaGthQWQ0YVBmRmhGYi9iZmZVY29lV2ZhZldkRWJXZEdhR2ZZZVVhWmhtZ1piaGFjZkZoVmJ2ZFVmZ2FzaGRoR2cwY2hnU2FZaG5hNWh2ZGNkRmdoZ2poUmZ5YlZnU2dFY0dlUmdNZ2RmbmVaY1NmUWJoZVZhNGhkZGhmSmFMZEdhRWVzZlZoWWJuZWxidGZjY0FlRmdEYlFhMWFvYTdhY2ZVZGRiZGdlY21hbGdYZVdoUmVBZlpnYWJBZnRhRmNiZnhnRWdUZ2JiMGFkZzdlVWdFYWRhamdDZ0VkZ2djY1Jhd2U1ZDRoYmRGZFllRWRmZUhmdGNkZlhiVmFkaEtmRmNtaGxmaGJGZmhhaGJtY0ZhR2daaG1jWWNYZkJnVmNaZ3hmWmFIY0dhd2JCaFZlUmZHaEZhK2FhaFhhWmJFaFpibWdFYVBiVWVoZUJha2dUZUhlWmYyZFVia2dJYlZhZWVIZFloU2hTZnhoQWFQYVdoV2FsaHZnY2FEZ1ZiSWFTZVVla2VTY2ZkSGZSZmhlZGUzYnBncGZWYjFka2VRYkdiV2JnYkxmUmdXZjhjUmdFYzJlOWFQZE1mQmJOZ01iZGFSaFVhRWdVZEZoa2hPYmVhSGRKZkhhQWMyZk5jK2hlZTNkZGFYYlNmaGhaYXBiWWNSYVllWWdaZWhmUmJtaFplbWZGYndoWGZTYXhkYWdUZ0FiQWJkYkJkMWRKZytmYWd6YXRjcWdRYlVoQmRMZkRiMWJJZlFlWmJFZ3hiMmNkYmxhSmdDY0ZkWGhoZDJmRWJraE5nYmRRYzFhOWgvZWNibWJaZWxkWGVWY0JnY2JVZzNkbGRTY1NnM2FkZDZjYWJWZGRiWmFFY0JkbGZvYUNiMGhWaHZmRWZSZk5kbmhCaEhjTWFZZVdhbWNoYWNkU2RGZnBoSGhRZzJnOWYrZGZmQmNWaHFmY2ZsaEZkM2FWZTBib2dXZGFlV2RFYVdjR2FHaFllVWdiYmliVmdoaGRna2doZnZmVGdGYUliSWREY2tjQmJiZ2ViRWdGZzZhWWIwYTFlcWVTaHdjOWZTYkVnR2ZSZk1hZGNuZlpoU2dRYWhkMGI3ZGRoaGJsZVdmR2hBaFpkWmRhZkhjSWYrZmVoVWhSYnBnU2JWZ3BoMWFlZEVhdGYzZmVjbWVsYVhlV2hSZkFnWmFhYUFndGdOaExmQmFFY1ZiY2RrZ2RhbGhCaGxjSmQ3Y0FjRWhGaGNmYmdSYUJlbWNjZGxlWWFWY2FnbmRKZ1JiZGgxZGRhS2ZGYW1nbGdoZkhnbGF0Z21lSGUzYXRobWdMaG5kQmhmZ2JmeGhKZE9hRWFUZGRoVmJVY25hUmhyaGVobWVOaE5hYWZrYXNiUGdVaGhjQmJrZ1RnSGM0aGliR2ZnZ3RmR2ZkY2dhbGZUZVdnd2FoZkRhUmNHY0pna2JaZFdoVmJiZVZoa2NsZ2NkZGFTYjFkQ2RlYzFkQmhwZlZiMWFrYVFlR2ZXYmdlTGZSZ1dnOGdSZ0VmMmY5Y0hlY2J4ZnNoVGhJYkZjd2RiaFhkamdoZ1JmZGYyY1JoV2hDZkdicGFrZ1JmR2VKYUVoWGN4YlpjdmRZZVZiQWhSZmFmamU1Y21lWmFtY0Zld2FWZFdlOWZhZlJleGMwZGRiVmZWZ0pkMGNhZzNoSWgzaEJlU2FNZ1lmQWdTYTFmUmNkYjFjNWMyY2FnMWNKaFVkQWdHYTFobGdCYTBnc2FlY1FmeGdWZ3JoZmZsY3Bkd2JTaEVnTmJKYldmbmNWaDRjU2MzZWRlNmVhYVZlZGZaaEVmQmRFZzhnUWh3ZHdhOGNIYzJid2h1Y1VlMmNzaFRkV2dtaGdiRGhYZFVjVmZVYkJmV2ZaZzBmVmRsZVpkamZmZm5hdGQzY1ZmMGZvZFdiYWRXZEVlV2FHZ0doWWJVY1phbWFaYWhlY2hBaEVibmFFZ3hhUWgzZEhnVmhWaFNkZGZHZXRjNmJZaDBjMWdxY1Nld2I5ZlNoR2dYZTlibWNkZm5hWmNTZVFmaGNWYjRiZGdoZUpkTGZHYUJnNWZRZGJjbGRoZXdiY2hFYmhmRGhTZlZjcGExZmVjRWZ0YjNhY2ZpZ0ZkWmFDZVVmSmJXY1BlRWRRaFJlTmhrZ0ZmV2NZY1FoTWE2Y1JoVWJkZTFhRmNRZTRlRmdDYlZjTWV5Yk9oeGVsYmJkYWZuYW9kRmFmYmxmY2NSYVBkR2NsY2hiRmhoZmhmbWdGY0dkWmJtY1llWGVCZVZjYmh4Yk1kQmVIZFJmVmRGY1VhbWNsZjJkZWdqZWRnRGZGaFFjb2ZlZVJhQmhCZGloU2huY1phbWZVZmxkOGJJZWVjQ2NJYmNnTmJGZGxkUWFTZDJlSmYwZWRmbmRCY1liUWgxZlJoSGVkYVNleGdGZ0NkRGd0ZjliVGUxZEFmUWFRaGthSWJMYlJjV2g4ZVJiRWEyaDlnSGVjY3hoTmJIZ2FnQmFWZ0lkVWdBZDVkV2haZm5lcGVHaEZoWGFkaHZoVWJTYk5iWmNOY1ZlZGE1Z2NoUmE4Y1loTWFsZHdnMGdLaFRiWmZ3Y01jRGMwYUljQ2hFZjhkVmdWZ3hmWWE5Z1BkVGFNYXdlQmVDYlViRmNEZHhoQmhKZ1pkQmRZZnphSmFCYjFkQWJIZkdoTmFjZUVoa2VzY1lmUWUxaGxmaWFjZm5jQmd3Y1NoRWROYUpmV2ZuZVVieGJEZ1hmZGZ5ZGVkRmdkYkVoRGNSYWtiOGVCZlRmb2R1Y0FjUWhOaG1jUmR5ZUZhV2FFaHpjMWhIYkJobGZCYlBlUmRDaDRlN2FCZVJmc2M0Yk5ieGh3aDJjSGNnZVJkU2FMYURlTWhXY0JjV2haZWFnSWh6aEZlaGhPYUZjMWQvY1VkMGE0ZlJnSGVRYUVnYWNQaFRoaGRoZFNjVWMxYXFiU2V3YjliU2NFZUdjUmVNZGRibmRaYlNnUWhrZ2hmU2FkY2hkSmFMYkdlRWJOYVpkWWNuY0pld2JjYkVjaGFEY0FhQmF4ZjFiY2ZCZjliNWRQYlRlMWdmZERmVmVoZ1FnT2h3Z0piTWVSZlJmRWFUZGJmMGhkZ3pnRWQwY2Rmb2RGZ1VmaGRRYlJieGRCY21mSWdCYk5nQmVQZXljQWRmZWRjMWI5Y2dhRmdtZ2xjaGRGYmhiaGJtYkZmR2ZaZ21lWWhYYUJjVmhiZDFmcGhIYkhoUmJVZkJmR2ZqYzBjNGhkYkRmRWNJYkpjd2ZwZUdhSGJGZFFhaGFIZG5iWmZyYlVoaGRaZ2RhTWFTYVVhY2ZDY0ZlUWJNZkZleWJkYjZiZWFYYWxjRWVhY1VlbGRhZGRlWGRoY0xhZGQzaHBncGZWYzFka2FRYUdiV2hnZUxmUmRXZDhlWmFSaHloY2ZPZkllQmgwYjRkS2hRaFZiWWRVYkZmb2RRZWRobmF0Y2FhUGgyZnBkeWRVY1hoZGdYY1NmaGFaZXBjWWJSYllkWWhaaGhhUmRtZlplbWVGZzRoQWdTYWNiVGdGYUJhTmZpaEZoRWZOZ2lhYWMyZmRkamNYZVdlTmFIYUpmVmNJY1FhWmJFZ3hiMmhkYmxjSmFDZ0ZjWGNoZzJkRWJrYXNiWWJRaDFibGNxaEpoamNnZjVjR2MwYTBiMmNHaDJlWmZxY1NnMmJwZjZnZWRWZzVnVmFPZmhobGRvYkNlMGZWY3ZjRWdSY05ldmZSZzNjTWhUZVJkMmRnZVZnU2NGY0JmUGdSZ0NmNGI3YkJnUmRzaFZmTWIwZ1ZldmdWZDFmY2NXZGVlV2NnaGFhTWZtY1liVWFaYW1iWmdoYWNnRmFWaHZjV2NrYmNoZGdIZVZhVmFTZGRnR2JzZHVoS2Z3YVFoNWdZZFFoOWFTZEVnR2RSYk1mZGZuZFpkU2hRYmhjVmU0ZmRoaGRKYUxnRWJWZWhhemNZaG5kSmJ3ZWNmRWFoYURhU2hWYnBlMWZlYkVkdGUzZU1leWI5Z1hmVWRVZ1JiUmNJZlZiaGVMZ0toa2RBZmJiT2YwYjVoNmRPYlViZGdvY0ZjVWZoaFFmUmJ4ZEJkbWZjY2xkWWZWY2FobmJKYlJmSmdSZElkZWhRY3pic2F2Y0ZlaGdCZk1mRmFHY1pobWdZY1hoQmVWaGJkMWRwYUhhSGJSYzFhVmZVZ25nUmdyZ2VibWdzZ1poSWNnZUpoY2hYZEVoSWFoZUFhVGFjYS9jSGhBZ1poUWhLZm5nWWFQZlNjMWJZZEdhRGZtYUlmNmRlZUdkQmFCaFNna2hWZ3doZGdYZWhmTGhkZjNmcGVwaFZiMWNrZ1FiR2dXZmdnTGJSY1djOGRSY0VmMmJjY1RiT2MxZG9lVWJaYW1kb2hKYlFkRmRjYVFnZWIzZkpmSGVIaEdoWmVZaFVhWGRkZ1hlU2NoaFpmcGZZYVJoWWdZZ1pkaGRSaG1mWmVtZEZmd2JWY1dhY2NPZkRmMWhSZE9kV2V5aDBhMWZlYm1meGhqYVVlR2FwZ2JmQmRsZTRoNmVaaEVheGgyYmRkbGNKYkNlRmdYZGhmMmNFZGtmc2ZZYlFjMWdsZWlkY2VuZGdja2dBZEFkb2VhYlZhQWJvZjVnV2dHZFZnNmJkYkZjZGZKaEdlUmNWZUNmQ2IwZFZhdmNFYVJkTmZ2YlJlM2VNZFRiUmMyZmdiVmhTYkZiQmZIY0ViR2I0Ym1jSGNsZndnNWdmY0NiNGMyZFFhMWhJaFdkZGNHZUVlR2NFZVdib2UrZVpobWhaYmhmY2ZGYVZndmRXaGtmY2RkY0hoVmFWYlNkZGhHZnRjNmFZYXhia2FpY0FkbGN4YzRoRWZHYlJnTWhkZ25jWmdTZFFiaGhWZDRoZGdoZkpkTGRHZ0VnTmZRZmVjVmRoZ3dhY2dFY2hoRGJTaFZmcGIxaGVnRWZ0aDNkZWRtaGtmUmVGZWtkSWZaZlloRmYwaEVhUGJSZUZiQmNiZjFmcGF6aFJjMGZrZXJiV2FRY2NnZWJBZWhnaGd2YmZnbGFaZWNnYWRtYjlkUmVlZmtkWmhSaEZkbWJnYzFhWGdsaEVmMWFHaGllb2R5Y2FoU2FKZ2NkZGRGYXBkT2dOY3hnMWZWZlVkbmZSZnJkZWdtZU5hTmJhYmtic2dQaFVkaGVCZGthSGduY2dmbGRHZGdjdGRUY0xmQmZwY1hkRGNVY3hiTGdTZ0dmNWJ5Z2NiV2dCZkJlVGMwZWtnVGNmY25kTmhRaFhmWGZwYXBiVmcxZWtnUWJHZFdkZ2ZMYVJlV2g4Y1JoRWh5ZWtiSWNJZlJhTmNQZ1FjaGNWZElkVWFFZGNkUWVaZ25jSmNXZkZmV2JwZXlkVWFYYmRhWGZIaGxjNGhnZ01jaGdoZ0toSWgxZGtjbmdMY3ljOGYwZUVhRGYxZGFhV2RoYzFjSmJIZlJmc2huYVphVGdrZHZlQWhpY1FhT2VCYzFnc2hjYlRia2N4aDJlZGVsaEpoQ2JGYVhiaGUyZkVna2dzaFloUWIxY2xnaWRjZm5lQWdrY0FmQWNvaGFoVmhBYW9oNWdXYzJhZGc2ZmRlRmRkZkpoSGFEZE5lb2ZDZTBhVmV2ZUVmUmZOYnZhUmYzZ01kVGZSYTJlZ2dWZFNnRmJCYUhhUmVDYzRjN2ZCZVJlc2dWYk1oMGJCZGhiVmMxYmNkV2NlZ1dhMGQ4YkdmR2FZYlVlWmZtY1pmaGJjZ0ZjVmR2ZVdma2djZ2RlSGNWZ1ZlU2hkZ0RnOGV5ZUtiaGM1YWthTmNFZDVlQmFBZm1mUmFSZmRobWRaY2VkYWZCZVZjNGZkY2hiSmRMZEdiRWFOZlpjWWFuZkpid2JjYkVhaGVEYVNjVmdvZGhoTWNBYklna2hkZkJkWWhXZVRiUWNnY1pmZGhRZHRiVmZkY0Rjc2JUZGJlMGNkaHplRWcwZGRnb2JGZVViaGhRaFJoeGJCYW1mY2FoYzhiVmdkYkdiOWNSZlpjMGF4aGdlRmNtY2xnaGVGYWhnaGNtaEZnR2daZG1nWWVYZkJiVmNiaDFmb2ZPY0VoQmRCYS9iVWRuZFJocmFlZm1iTmJOZGFia2hzYVBoVWhoZkJka2dSYVZleGMyZ1Vha2FJZ1ZnZWZIYlljU2dTYXhkaGhEZFdmV2NKZXliY2hDYkpiR2VFZEFiRWJUZE1ieWZ3ZTVjUGZqaDBiaGNBaDFlRWVCaEViR2FRZ2hmUmhXZThoUmZFZTJoOWNIaGNieGdOY0hoYWhCY1ZkSWFVZEVoY2hRZlpjaWRZYmVoWGZEZWxkOGNBZ3pmSWVhZkNlMWY4Ym5mSmdWZk5nS2FhZkZiZ2J5Y2JmamNOZzVkVmRUY01iR2hiZFJkMGFkaFZnVmRKZTBjYWIzYXBhamJUZldlcGhMZ0RhMWVJZVFiWmJFZnhoMmJkYWxhb2ZXZlhhVGZFZWxjSGJCaGxiZGREZ2hnZ2RyYlBoRGJRZjFkR2RrZzBkYWNEYnpmY2RzZUdmVGVZZDVnUGJWZThhTGhHZVJkVmNDZUNkMGdWZ3ZnRWVSY05idmFSYzNjTWRUZ1JjMmNnY1ZmU2RGaEJjSGZFYUdjWmJ5ZkhieGFWaDBlYmUxYkZlamNUYjJhQWVXZGFhV2VFZldiR2NHZFlnVWFaaG1jWmZoY2NkRmhWZXZlV2VrZmNiZGFIZlZoVmJTY2RoSGVSZDZnYWd4Y2thaWJBY2xheGFjZ2JoeWJWY1loYmNuZFlnT2RYZHhnVmdwZmRiZ2M1ZVhnR2NFYnNmUWVZYm5mOWZ3YlpnRmNCZEtnUWFIZkJlMWhlY0VidGQzYmVobWdsZFhhV2JSaEFlWmZhZkFmdGFGYmJoeGVFYlRjYmMwZ2RkemFFYzFjMWdvaFhiRWFoZU9kV2RoYkJjMWhZYUhjd2RWZ2FobmhKZ1JoZGIxZWRkS2dGZW1obGdoYkZlaGRoZW1nRmdHZFpmbWhZZVhmQmRWZ2JmMGNWYUhhRmVVZ2tnZGhHZnliZGJsZUJjU2ZKYmViZWdFZHRnVGhUZnhlQmUxY1RoR2JwYXFoVWJrZnBkY2FlYUhjc2NTY1dnQWFwYktoVWRFYWhneWdjZkhoQmdJYlFnMGVsYmFhZGhYZmhiTGFkYzNhcGVwYlZoMWJrY1FmR2hXZWdjTGZSYlhjVWZSYVdjbWg5YlphYmhoaE5jV2VmYWpiOWZJY1VmRWNjZVFjWmFuYkpoV2JGaFdmcGd5Y1VkWGJkZlhjU2JoZVpjcGJZZFJlWWhZZlpnZ2N0aG1jYmVqYlVjNGJIaERleGZVZ09jRmN3aE1kUWExYklkb2dkYm5kcGJ5Y1RjWGNaYVhhRGUxYXBnWmFaYkVkRmcyYlpnMGZSZExhSGhGY0pkMmhFZWtoc2FZZFFnMWVsY2lmY2RuZ0Jid2dTYkVlTmhKZVdkbmdWYzRkU2EzYmRoNmFhZlVjMWFaZ0dnRWEwYmdjUWJoZFphaGViYWxmSmEvZlZoM2FOY1BmV2ZtaGdmRWFTaEVneGhiZ0VnQ2I5YjdhWGR3ZDViQWJjZGxlRmYzYlZmMGRvaFdkYWJXaEVoV2hHZ0dlWWFVYU5mQ2FNYTFkSmdRZmNkaGVXZ2hlTmRWZlZlQWRaZ0pjWGhtYXRlNmhZZzBmMWdxaFNnd2Y5Z1NjRWJHYlFmUmFmaDNmcGM0YVFoaGRWYjRkZGNoYkpjTGZHYUVkTmRaYVlnbmJvZzRmZmhoZWdjUmhCY2dnNGg2ZUxlQmJJZW5kUGIyZmNjWmhIY0ZoZGNZZVBjRWg1Y0ZnY2NoZkZhVmZPZmdka2N3aFJid2I0ZW5oV2gwY2hjWWRUYWhmQWg5Y1diRmZZZlZnYWNuaEplUmNkZjFiZGRLZEZnbWRsZmhkRmVrZzRhbmdSYW1mWWR5ZllkV2QxZ1ZnWmcwZ3hoU2ZDY0FkNWZBZlVobmZKY3JjSmhEZmNiRmVJZ3hlZ2VCZUxoVmRGZDBlWGRIYTlkMmNXYlVhSWJFZFloMWh3ZVNjU2R4ZGhmRGVXY1dhSmR5aGNmSGRCZElhUWUwYWtiSWhNY0Nkd2VlZ0pkVGVSYXBnWGUzZ01iUWFHZFdiZ2NMYlJkV2g4ZFJoRWEyZjljSGFjZXhlTmVIaGFlQmYwY2NlR2NBYzVhRGRhZEFiMGFYZkJiWGRwZXllVGFIY2RiQmJYZXdiTmY2aGRlQmRZZGVmWmNrY0JodmRhYWtjdGF3Y1ZmV2c5YWFhUmJ4ZjBlZGdWYlZkSmUwY2FnM2ZwZGpjVGdXYUlnZmZEZjBjOGhRZmJhRmVwYWpjWWUwZUZjWGFGZFhmNWYyYVRmQmM5Y1FkQ2VnYXBlc2VEZVRoRmdoaFhla2VwY0pmVWhYZ1Zid2NIYzNmZGZrZGRjMGJsaFpnQWdRZDlnaGVBYWtjbGNGZkVmUmhOZ3ZmUmYzZk1kVGZSZjJmZ2hWYVNiRmNCZkhiRWJHYlpmNmNBZWxhMGRqaElhVmc4Y0lmRmZsZHNiQWVhZlhkd2FXZ0RjbmFNZ0JkZGdYY05kaGdkZWxoVWI3Z1VmMGZzYTNmSGJWY1ZhU2dkZEdldGQ2ZllnMGExaHFhU2V3YTljU2ZFYUdiUmJFY0lobmRaZFBoUWFoaDFmdWdZaHdlZGFZZ0RlVWROZ2ZiWWJpYXdna2NPaEFhRWhRZlJmeWFVYTBkYWcxYWxlK2JlZ21nSmZYZ1ViVWZRZ1pnZGVoZlZkYmhiZndlQWdGZ1pma2Q1Zy9iT2NVZGRob2hGZFVlaGdRY1JneGNCZW1kY2FsZllkVmZhZW5kSmRSZWZhd2NNZkNhWGR6ZXBkdmJhY1ZnbGExaEJlbWhaYjdoWWRXaFpkQWhlYWtjbGRTYUhiUmF0YVZiQmRuZjFibmNVY0dkTmhOYWFla2NzZFBiVWVoZ0Jia2hUZUhlWmYyY1Vma2NJYlZhY2ZDZkpiYWFBZGtndGZOaEphaWVOZW1mYWhIYUJoVmhRYjBmRWRFZkljVGNBZUNnSmFIZFFmV2JGZWtiMGdJZUdkV2FNaExhVGRUZXNkUmREaFhhRmhaaGNjd2VKYVJmWWFSaHhmSWFWY2tkY2FHZmNiMmJkZkZlQWFHZE5kK2FlYTNlZGdYYVNnaGJaZXBoWWhSYVlmWWFaZ2hiUmRtZ1pibWJGYndhQWdTYmNiVGZGY0RhY2ZkaFZmVmJKZzBkYWUzY3BnamNUaFdicGRMY0RkMWhJZlphZmcyZ1poMmRkZ2xjSmhDZUZlWGRoZDJiRWNrZHNhWWNIYWxoQmJ1ZVdoSGRCZ3doU2dFYU5kSmNXaG5lVmM0Y1NmM2VkYnloSWNWZGtoSmdRaGxjWWg4aFJoQmZFZTJnUWRWaFplaGhBYWloSmJHYkJlaWNSYUdoU2ZFZzFoSGRXYkdlZ2dpZ0JhRmhvYStlUGFRZlVkdWVCZXdoOGhZaExjRGFBZFdiQmFXZ1pjU2RNZnlmZ2JpZkpkQmR3ZGdmRmNFZGNoVmNTYVZjeGNTYUxnMGZGYjZmWWEwZTFicWJTZHdkOWhTYUViR2JSY01hZGhuaFlmQWdCYzBoRWJ0Z0pkRmR4YUxnRWRHZ2xmWmNZaG5lSmV3aGNkRWRoYkRnU2NWaHBoMWFlYkVodGIzZ2VkamUwYWZlRWZFZE1jWGVGZTBhcGZSZmRkeGJFYk9hY2ZrZmNhbmVIZFRhZ2VwY0FjVmVCYVFmUWJSYlpkTWhjYWxlWWVWZWFnbmJKYlJoZGQxaGRkS2JGZm1nbGRoYUZjaGNnaHlkWGNDZzhlMWNiZHdnOGdVYWZnMGNwY0hlQWJBZUJlVmZCZ25mb2VVaE9kM2FOZGRiYWhrZjBhSmZlZUJhQmJrZVRoSGFaYzJjVWZrZkloVmFlY0hiWWVTZVNoeGVoZ0RnRGhTZG9kN2NJZjNhNGczZ0FkbGZwaElmZGFXaFZmV2hkYXliNWhuaEtjQmVnYURmQ2QyZ2diTmVRYjBjVWRSYkVhMmU5aEhhY2N4Yk5oSGhhYkJiVmNJZVVkRWJjZVFkWmRpaFliZWdYYkRhbGY4Z0xnamVaaEdhWGdCY1pkMGNmYUJjWmZNY2FjR2NzZm5hZGYzZmRkYWVWaFdnOWVhZ1JleGEwZWRmVmhWZ0phMGVhaDNocGRqZVJjSGFGYWhnRGIxZkllUWJaZ0VieGQyaGRibGZKZkNnRmhTY1ZkL2ZIZ21oRWdZZFFnMWJsaGlmY2huZEJmd2hTaEViTmRKY1ViamYxYjJhR2R5Y1VjMWZQZFJjZ2ROZVNhVWVrZXRlQmVRZ0lkOWVWaEZiSWE3YUFoaWZGZW5nRGZ5YWxnYmVTZEViMWhIZ1dhR2dnZGlmQmVGYm9hK2RQY1FlVWd1YUJmd2Q4YVljTGRqYVVnV2hCY1djWmdTYU1ieWJnY2ljSmhCYXdiZ2VGZEVjY2VWYVNhVmV4aFNoTGEwYUZjNmNZYjBoMWZxYVNjd2Q5YVNjRWFHaFJiTWRkYm5mWWVBZEJmMGdFYnRkSmZGZHhlTGZUZkFic2dRYU1kWGh3ZFBoTWhWZ3hlYmRTZlVkUmYxZkxmRWdVaEllT2IzYjFmUGFjZ3hhQWZaYWFnQWR0ZEZiYmV4YkViVGJiYzBoZGZ6ZEVoMGhkZW9kQ2drYWhmUmdWY3pkcGRtaGNhbGJZYlZmYWVuY0pmUmZkYjFjZGFLZUZnbWhsZGhoRmZnZkpjbWFRZkNmNGV2aE1nbmU0Z3FoTGNrYTViZmFIY1FhRmNWZkJkbmdvZ1VmT2gzZ2RjVmRRZ0Voc2RQZFVjaGFCZmtmVGRIYlpjMmVVZWtlSWhWaGVlSGFZZlNoVmNCYmhoQ2NTZ0VmaGh5ZGNlSGVCYUliUWYwZWxiYWhkZlhjaGJMZGRlM2RwY3BoVmEwZU1jUWZUaFNlQmNDZ0ZibWdGZXVmVWNuZHhnVmRjZHdiMWZIZVBnQmZzaDNmRWNWaFFjQ2JUYUhnSmJXY0ZlV2JwZ3lkVWVYaGRhWGJTY2hmWmdwZFloUmRZZVloZWhSYVJkbmhkY2tmdGZ3ZFZlV2g5ZGFnUmJ4YzBmZGdWYlZjSmMwZmFhM2hwYmpjVGVYaEJlTGhXZnhjcGhaZ05oMGFJZ0phTmEwZ0ZoUWNGZVdkUmMyZFJka2NWYW5nQWZrZXBnd2FXYkhlQmJ3ZFNkRWFOY0pkV2NuZlZkNGNTZTNjZGE2ZWFmVmVkYVphRGZ4Z2xjcGNHYm1nOWh2aEVoUmNOZnZiUmEzZU1kVGRSZDJkZ2ZWZ1NlRmFCZ0hkRWZIY3hjeWZBaGxhMGNqZUlhVmY4Z0ljRmdsZ3NhQWZhZFhoOGJXaFRjR2RoZ3JjSmQzY2RhM2hXYWxnVmZ2Z1dka2VjaGRlSGNWYlZnU2FkYkdodGY2YVlmMGUxY3FjVmhBZjlhVGZBYkVkNWRNY2RhbmNaaFNlUWFoZ1ZoNGZkaGhnSmdMYUdjRWJOYVpjWWVtYmhkd2dKYUFiQWVLZEdhbGVRaEtiT2hWY3BnaGFlZ25oVmFYZ0RiUmY1Y21kS2hSZ3BhVGdSYVJiRWNUY2JkMGdkZHpmRWIwZWRjb2dGZFViaGRRZVJmeGRCYm1lYmFWY1lkVWdlZDFoaGFSY2RkMWNkY0thRmNtYWxhaGhGaGhnaGVtZkZiR2ZaYW1nWWJXYXBoVmRPZHhmSWZPY1RkaGhNZXFmRWQyZ1JmN2ZlZG5nMWhOY1Bia2ZWY3diRWV3YkJnMGJWZzFieGQyZFVma2NJZ1ZnZWdIYllkU2ZTYnhiaGdEZ0JiR2Z0ZCtnV2NuZ0JoSWZRYTBjbGdhYmRnWGZoZUxhZGQzZXBiaGdIYjFmZGRBZFNheWRkYmZlQ2VqZXRmSWJRaHlmcGZKZFBiMWdZZ1VlT2EyYkVnQWRFY1Fia2dRYWVhM2JJZ2VkR2d6ZG9lZ2dIYmljTWVZYUhha2E4ZzViSmFCY2hnVWZNZGhiUmM3aFpoaWVjYWxkR2J5Z3dkT2VEZmxkSmdUZVZiVmhvaGdlWWZuZG9jNGRaZDJjcGZMYURjMWRJZVFoWmZFY3hmMmFkZGxhSmZDZUZlU2NvZHpnUmFoZDVhS2dEYVZla2YyZk9namhrZmpjUmFqY3djSWFUY21oMWM0ZFZkM2FjZXVkWmZ5Y2djWWhCZEFjRmRDZ0NnMGdWY3ZnRWFSYU5jdmZSYzNjTWdUYVJmMmJnZ1ZmU2hGZEJkWWVFYkdkZGRpZWZmQmFWY3FiY2RsZEZkM2ZWZTBnb2dXaGFiV2dFY1dmR2RHaFlhVWdmYUdlWWYxZ09kQmV3YzhlVmNEZmhoY2JDaFVhMWVTZWFkbWdzZnVkYmJUZUlkcmNYY3hnZGE0ZkViR2VSYU1mZGduY1pkU2JRY2hlVmQ0YWRiaGdKYUxhR2hFZ05jR2JZZm5oTmdoZ1dia2FoZERnU2dWaHBmMWNlY0VldGIzZmVhbWRsZVhkV2hSZUFnWmhjZGdhc2NSYUpiMWRoY0FiWWdUYmdoeWNBZkZkVmZvYUNkVWZnZkVoU2VXYzhnbmNZY1VmUWIvYmFobmVKZlJjZGYxY2RlS2dGZ21kbGhoYkZkaGZoZW1mRmNHZVplNWRZZlhoRmZGY1JmVmZwZEhmSGNSZjFnVmRVZ25kUmVyaGVjbWJOYU5hYWRrZXNoUGVTYUJoQWd3ZUJnRGE4YWxmWGFEaDFlVWRhYTJlUWNTYVZhUmhnZlhlVmV4YzBmemJZYjJjSmhpaFFhMGRsYmFhZGFYYmhiTGFkYjNlcGRwZlZjMWJrZlFjR2JXZGdhVWRSZVdnNGRBY09hV2E5ZUhlY2F4Y05nSGNhZEJjVmdJaFVlRWhjZlFhWmRuYUpkV2NEZDJib2RtZUdjVGI0ZUVkUmZHYWtnb2FjZUFoQWRZZ2VkaGdRZ3lhYWJCZjRneGhSZ0hhbGJ3ZlJkeGUwY2RiVmRWYkpjMGhhYjNocGFqY1RoV2NwYUxoRGIxY0ljUGhaZUVlMWdtY1hkRmJKZENnRmRYYWhjMmhFZ2tmc2hZZ1FmMWJsYmloY2NuZ0Jid2JVZGtjTWZkYkVnamJ3YXJiUmJRZGdlN2dlaEVjRmhaY0RmaGdrYThjQmRUZm9hdWRBZkFkVmRGZFJlM2NNZlRnUmMyZGdjVmdTZkZoQmVIZ0VhR2haY3lhVmZoZFZjMWNjZmxjQmNtZ2ZjVWZvaFdiYWRXYUViV2FHYUdhWWhVZlpibWhaZGhlY2JGYlZidmNRYkVjZGZKaFZiUmZ3aEJoZWZoZ1FiN2JjZzFkMWFxZ1Zid2M4ZEdiSGZoYnNhTmNaZW1kWmVKZGFoQmhWYzRlZGFoYkpiTGVHY0ViTmRaYlllbmRJYnRkZWdVZ1JocGVTZlZhcGgxYmVkRWZ0ZjNlZWNtZWxhWGJXZVJnaGJSY1pjbGFzZVhjSWdFZlZmY2ZPaHhkNGFqZVZha2drZ25hUmgwaGhnTmVSZjFjWWN6Y1BmQmNWYkJmSWJ6ZjBlZmJkZTFjOGFlY0hmMmZraDZjUGNCZmhjbWFGZ0dkWmhtZ1liWGdCZVZnYmUxY3BoSGNIaFVoOGZRZUJkaWJFYjVlTmVHZE5oRmVRY0Vmc2NQY1VlaGRCY2tiVGJIZlpjMmNVZmthSWNWY2VjSGhZYVNoUWIwZndoTGdFZURhRmg4YURnemJGYVlnVWEwZmtnR2NhZ0hiZ2NmY2VhUWdVY29oUmcwYWtmWmVGaFViSWZMaFJoV2Q4aFJoRWMyYzlkSGFjZnhnTmNIZmFiQmhWaElkVWNFZTllRWNMZWpmc2FGaEdmeGZVYXpjUWFHZ0ZjWGhGZWdkdGZwaE5jUmVoYW5oSmF3Z1Zid2ViaDJlMWFhYlZiV2Q5ZGFjUmd4YjBmZGFWZVZlSmUwYWFkM2NwY2poVGVXZXBmRGRXZHhicGRaYU5oMGhJYkpiTmUwZ0ZlUWFGZVNoUmFyZUVlaGY4ZVdnUGhCZ2hleGZZZ0hibGQ4Z1lna2ZOZ0pnV2RuYVZoNGFTZTNlZGU2YmFmVmFkZ1piRWFCYWxib2hBY3hhRWZuYldnRWhCZmhoT2VEY0lhSGhYaDJnaGJKYVZmVmZBYVRoSGNoYmtlemFRaGdjMWhqYmZkbmR0ZjNjVmMwaG9mV2RhZFdiRWJXZ0dlR2FZaFVhWmdtZFpoaGNjZ0FiRWNuZEVmeGZRaDNhSGRWYVZmU2RkYkdmdGE2ZVlkMGQxYnFmU2N3ZjllU2NHZVhkOWVtZGRobmNaaFNhUWNoYlZjNGNkYWhkSmhMZEdlQmY1aFFlYmdsZ2hmd2RjYUViaGVEZFNlVmJwYzFjZWFFZHRnM2hjZWlmRmhaZUNiVWZKZldnUGFFZ1FlUmJOYWthRmVXZVlmUWRZZDlmVmgwaGRiMWhGYlFnNGVGYkNoVmRNY3liT2d4Y2xnYmRhZW5ib2VGZGZnbGZjZlJoUGhHZ2xhaGRGZ2hoaGZtYkZnR2JaYm1iWWNYaEJkVmViZXdkZ2VDaFNnVWZnZkhkSGRIYlJjamFVZUdnTmNOaGFna2dzY1BiVWNoZkJia2JUYkhiWmcyZVVha2RJZVZhY2FDaEpmYWVBY2todGdOZEpmaWJOZWlhWWZIY0JnT2FYaGtma2VPYWVjd2djYktiWmcyY3BoZ2RXYTNjTWhRZEdoV2ZnYkxnUmNXZzhoUmNFZzJkOWNIYmNneGZOZUhlYWhCYzBoY2ZHZUFkNWdEYmFoQWcwZ1hnQmdIZ3hieWdWZDJncGJYZEhmaGdnYVdnSWdBZGNlT2ViZ3hhaGNNZlpnbWZGZ3dlVmVXYTloYWhSY3hjMGdkY1ZiVmZKYzBiYWMzYnBjcmNHYVNoSWNDYVhhRmd4ZXZnSmdWYjloa2VkZ2xiUmFmYkZmU2N4YjRoYmJRaG9nTGFVZFZoQmN1ZVdhSGFCYXdoU2dFaE5iSmdXZW5oVmc0ZFNiM2NkYzZmYWZWY2RjWmRHZ0VkMGZnY1FmaGVaY2hnYmhsYUpjN2VYaDNjTWVWaFdmbWFoZkJmUmRpZjhnR2hCY0hoNWY3ZldmamI5ZnFiY2NsZUZjM2NWYzBnb2VXYWFmV2hFaFdiR2FHYVlhVWFaZGpoSWNwZE9lUWZaY0ZlV2drZmNhZGVIZlZlVmJTYmRkR2V0ZzZjWWQwZTFocWJRZGhkUmM0ZUVhR2hSZU1kZGRuZlpnU2RRZGhnVmM0Z2Rla2I5YkNjRmdHYWxkWmdZaG5iSmN3ZmNiRWZoYURmU2hWY3BlMWZjYkFjTmM1ZUtiamdzZFlhRGVWYjlmTmFNYlZjc2dBZFlhVWVsY2NjUGVVZmRjdWFFaHdkRWg5Y1djd2JzZ0VkRGZsZjhhb2VjY2xhNWNCYlljM2NJZ0tmWGFWaGRjS2FGZG1lbGhoYUZiaGZoY21mRmNHYVplbWNZY1NjSWVRZE9hd2M4Y1ZjVWJ4ZjFnZGdlZEhnUmVyY2VkbWVOZk5oYWhrZHNhUGVVZmhiQmNrZ1RnSGVaYzJmV2FoZ1piZGVNaFNiVWRjZ05nRmVsYlRiU2JXYklmTWFiaFhnQWJjZFRhVGRZZGJoWmRXaGhjQ2NlYTFlQmdwY1ZjMWRrYlFnR2NXY2dhTGRSYVdiOGRSaEVjMmU5ZEhmY2Z4YnNhVGVJYkZhd2RiZFhiamZoZFJoZGMyZFJlV2hhYzNnZGN5Y0JmWGVrYm9mQ2R3Z2RjL2JhaEJlb2N5YlpiaGZSZ21iWmVtZUZhd2ZWYldkOWJhYVJheGIwZ2RkVmVWZUphOGdQaHplSWhxZEhmbWNRYjBmVGJrZ0VlQ2daZURiSmNyY2RhZ2JaYk1nYWZqaGxlbGRBYUVmSWhVZWFoVmJsZGloY2duZEJnd2RTYUVoTmNKaFdmbmdWaDRjU2UzZGRkNmFZaFFlTWFSZFdmVWVwYm1mZGRBYlJoN2dDYVJkTWVSZldhbmhOYkhmU2JSaGRiVWFYaEVjaGhPZUhmRWh4Z3ljVmNoYlZlcWJjY2xhRmMzZlZiMGhvZldjYWFXZEVnV2dHYkRhSmFjZUxjemdWYkxlY2RGZlZldmVXY2tiY2VkY0hoVmJWZVNnZGJHYnRnNmhhZWxoWmFBYVNld2g5YVNkRWNHYVJiTWhkYW5mWmRTZlFma2ZoZ3hoZWJqZWhnTGdHZ0VnTmhaZllibmZKYXdlY2JFaGhnRGNRZFJmSmY3YUtjQmhrZTRhTGFpYVlmRGNBYkVoQmVjaFpma2hVYkthT2J4Z0VkT2hiZXdiRWRtZFhnUWdRYzhkWGRBaGNjZWNSYnhkaGZ2YmNhZ2EwYS9oYWVuZUpkUmFkYjFnZGFLZkZhbWNsZmhnRmdoY2hibWRSY2lmTWJ5ZU5mQ2hJY2JlYmMxZUpodGFIZ1JlMWNWZVVibmNSYXJmZWZtYk5oTmNhaGtmc2NQYlViaGhCYXNjR2ZEYjRmL2RBYVVieGZxY09nV2FZZENmU2R3ZlZiRGRUZzNnZGZuZlllMmdWZUljUmFVZmtiRWFJaFRkQWdDZ0plSGRRZ1dhRmhraGtmQWVFZkdiUWJoZVJiV2I4aFJiRWcyYTlnSGVjZ3hlTmZIaGFnQmNWZklmVWRFZ2NjWWFNaGpob2JmZlJnbWhRZ05oRWJHZlpkQmJTZGdidGhwY2Rod2ZNYU5hZGFRZ0ZibWZZZkdnRWJ1YkFjU2ZjaFRiRmFCY05kaWZGZ0VmTmJpZ1libmRaZEplVGdXYnBnTGFEaDFhSWRRZlpjRWF4ZjJmZGRsaEpiQ2dGYVhmaGQrZFJnZ2dOZlJnRWVGZWNlZGZNZzJlTmJpZFNjRmU1YUpmVGRHZkJndGFXYkdkSmM2Y2JnMWhjYUhnUmRGZUVmaGFXYUVnc2VRZlVjQWFCaDliVGZuZjhkNWdSZDJnZ2JWYVNlRmNCYkhkRWdHaFpoeWVWYWhhVmZxZ2NnbGNGZy9iQWN3Z0poZmNPYm1lOWNwaFdoWGhJYk1oWmZuYXRnaGRaYWtjQmY2ZlNkVmVJYmRkR2MxZlVjTWZJY0NhTWV6ZE1oRWdNZ1ZlQ2doaHRnS2FHZFdkaGVtZmRnbmNaZ1NlUWhoY1ZkNGVkYmhhSmFMYkdkRWVOZVpnWWVuZklla2RPZUFnRWZRZVliMWVwZDFiZWFFZ3RiM2ZlZ21mbGRYZ1diUmZBaFplYWJBYkpoZWFSZFJjRWNUZ2JoMGFkZnplRWQwZ2Rhb2VGZVVlZ2NOZVRlaGF4Yk1nY2FsZFlhVmJhY25jSmFSYmRhMWRkYktkRmFtY0VmcGFHZEVmZ2MwYldiemhJY3BkTmZTYWtoRmVLZmxoUWhVZFZhVmRRZFRmQmJnaFljaWJQYlNoc2NaYmFlbGNZZlBkR2ZoZzRoMGNIaGpja2ZpY0hnUmFaZU1jS2NEYk1nY2ZHZ0ZjQWJLYUhlemRZZGdlY2ZHaDFlSWVCZFJhd2VVaE5haWh3Y0NjT2JEZlJkcGJYYXdnMGNaY0dlVGNNZ2hoUmFXYzhiUmNFYTJhOWJIZGNleGROYUhmYWhCZlZhSWdBY2dnSmVFaE1leWZBY1lhRmRXZEplWWNVYlhiZGJYY1NiaGJaYnBjWWVSYVlnWWhaZWhhUmJtYVpkbWJGZDRmQWFXZzljZmVXZ2hmMGJMYlFiVmZ0aDRnUWZYYnBnamNUYldkcGZMZURmMWRJZ1FoWmJFY3hjMmdkYWxkSmRDZlFiWGdoZ29jRGMwaHNlTWZXYTNlTmJpZ2NobmRCZXdhU2JFZk5jSmFXYm5nVmc0ZlNmM2RkZjZiYWRWZGRmWmNEZnhlbGJnZ0FkeGhFZG5nV2ZFZEJmaGdPYURiSWhEaFZkMmhnYUllU2ZBZ1FnUGJXZVRhVmE4YUtjVmVSZCthYWhsZkZmcGRTZFVib2FlYVBlV2NFaGJoR2VIY0lmTWdiZTJhOWR0YldkbGdWaHZmV2VrZWNmZGZIYVZnVmRTYWRlR2Z0YTZkWWcwYTFlcWNTZ3dlOWRTaEVmR2N3YVlhUGNqZDhoQmJUZEdib2U1Y1phd2dSZUxkQmRVZ05nSmdhZDNiNWJhaGNjRWJoYkRmU2RWYXBmMWJlYUVjdGYzYWVkbWFsYlhmV2VSZEFiWmVhYkFidGNGaFphMGRWYmJnSmJoYVJmOWRiY0FiWmc3YUJmMGJoZE5lUmF3YkJndmJmZ25id2dWYmFobmJKY1JoZGgxYmRmS2dGZm1nbGRoZEZiaGNoZG1mRmJHZVpibWhZaFhmQmJkYk9neGFJZk9kVGRoY01ocWRFZDJhQmN6Y2Vkbmg1ZE5iZWZrZUllR2RlaEJiQmFrZVRhSGNaZjJmVWNrZklnVmNlY0hhWWFTaFNjeGhoYkRkV2NXZ0pob2NjY0NlUmdJZVhkVmNSY2FoWmZtY3BlaGNkYjNicGNwYlZoMWNrYlFmR2NXaGdhTGJSaFdjOGVSZUVhMmM5Z0hlY2J3aHhjSGFZYkJhMGdjY1VlRWVvZE5lWmFtZkZmRWRIY0djWmdZYVVkWGZkZFhiU2FoYVpkcGhZY1JjWWhZYVpiaGhSaG1nWmhtZ0Zid2VWZldhOWRhZlRkMGVsYlZiSGZBYkZiNmFGZURmdGR6ZlhlV2dwZldjSmVWYUliUWVaZUVjeGUyYWRjbGRKZUNmRmhYZGhnMmJFYWtnc2dZZlFnMWhsYmlkY2JuaEJnd2FYaGxjWmdjYlNhV2NCZjRlVGFYaGRoeWhZZFFmTWNSYldiVWZwZG1kZGhBY1JhOGhBY3hjTmd4aFdmWGdOY0hmVGNtZ2hmSmZTY0ZkZ2NUZFdhQ2Y4ZmhmV2FHZm9kcmZaZGtnbGIzZ1NkMWNZaFdlWWVYYkFnQWJHZ0dmc2hVZU1kbWg5ZW9oZWVWY3hiamRjYkVkY2JkZUhmVmJWZ1NiZGJHYnRjNmJZZTBoMWRxZFNid2g5ZVNkRWdHZlJhTWRkYW5jNGNHaENlbGZ3Z3JoZWJHYzBkS2dDZFZnVmNaYWZlM2hKaDRiSmFBZEFmS2dHZmxiUWJLYU9nVmM5ZHZnZWduZWRhSmhXZFViUWdRYmFoQWcxZUZjZWhRZVFoR2VmZEZlSmg2ZkhjMmMxZW9oRmZVZmhmUWVSZnhjQmZtZGNjbGdZZFZhYWJuYUphUmdkYzFkZGZLZ0ZhbWRsZnBjUWJsZ0FjdmFSZzJhZ2haZUllR2ROYkhmYmgwaGRiSGZEaFJhUmZaY2ViSGNSZ3JnZWRtYk5nTmdhYmtic2dQZVViaGNCaGtlVGJIZFpkMmRVY2tkSWFWYWViSGU1Z0doQWExZEVoUWdWZXhoMGd6Z1phR2doY0liWGJrZGxoS2dmZkhmRmJoYmRlM2hwYnBnVmMxYWtnUWZHZVdnZ2JMYlJlV2g4ZFJoRWMyYjloSGhjZ3djbGJIYlBhQmhWYldmVGFVY2NkQmJjYkZoaGRXaEZjV2NwZ3ljVWdYYmRmWGhTaGhoWmVwaFlkUmhZZVlmWmdoZ1JjbWJlaFdmRmc0YVhhVGh0YmFmU2NnYUFhZGhSZUVkUmY5YVpoMWJCZmpnVGhXZXBnTGhEZTFmSWRRZFpkRWV4YTJiZGhsY0phQ2VGY1hhaGIyYkVma2hzYVFlRmd4Z0VlcmFJaFhjNGFQZkNlVmZOZVpiV2RtYmhoU2VTYjNoZGU2ZGFiVmFkYlpnRWVCZWxkb2VDYTBoVmh2ZkVhUmhOZHZiUmgzYk1lVGdSZjJnZ2dEZVhjVWdWaFViQmRXZ1pmMGdWZ2hjMWhpaEplaGZrYitnQmhFZ1JncGFLZ0hjQWZBZ0dlSGZnZEtnWmNqZkphb2djYUFibGJ2Z1VlaGhOZlZlVmRBYlplY2hDYnlmcGJwZGNnVWMxZzJoVmN3ZDllYWJBZVhmSmVNaGVhM2hZaEdnU2J4Z3hleGhmYnhoNWRoZEdlRWVOYVplWWFuaEpid2NjYUVlaGNEZFNhVmVwZDFhZWZFYnRkM2FlYW1kbGRYY1ViVWNSZFJlSWRWZWhiTGVFYUZnQWVDZ2VlVWJkYnVjT2hVY2Rjb2VGYlVkaGRRYVJmeGJCYW1mY2VsZVlmVmZhZm5nSmNSY2RkMWhkaEtjRmdtYmxjaGJBZkFnMWd6ZkJnM2JOYW1kWmQzYkJkZGNaYndhNGNQYlZoRWg1Z2JnTGFUZlZmNGRhZkdiTmNUZmRkRWh0ZmJoV2V4aEFjNGJUZkhiNGJpZEdoZ2N0ZkdhZGhnZ2xiVGJYYndlQmNEYVJkWGU1Y3lkZWRHY0ZhZWNRaDBjUmhhZkliWGVGaENkZmNuZU5hbGdmZVZoa2FRY0dmV2ZnZkxhUmZXYThlUmdFYzJmOWNIZmNneGJOZEhiYWZCYlZmSWVVZEVnOWRFYkxiamNzZkZkR2R4ZVVmemNRY21lVmNYaFZmeGRaZmhiTmZWZTVlUmVOYVJmb2FaaEpoM2ZWZW9mVmNYYUZoRWFSZzBia2dVYlZoVmJSYzBjZmVXZzljMmVYZm5mOWFDZkFiM2RnY1FkWmNFZXhhMmVkZWxnSmZDZUZjWGRoZDJhRWhrZ3NiWWFRZzFlbGNpY2NjbmFCYjRkSGVBYXNmQWhDZlhic2ZIZkNhbWZOZWlkYWNVY3BlWmJBZEJnQmdoZUlmVWZWZnZoRWRSZE5jdmFSZDNkTWhUZFJnMmVnZVZoU2JGZ0JoSGZFZkdoWmNvYVZhaGQxZmloSmNoY2tkK2VCYkVoUmNwZUtiSGdFZUdkR2JIZHNhK2ZaaG1oWmdoY2NhRmdWZ3ZiV2ZrYmNlZGdIZFZkVmJTZGRoR2h0ZTZlWWMwaDFocWVTZndoOWhFZEJkWGFGZGZiWWUzZ1pmVWNRZGhoMWF3ZElkbGNvZUNjU2cwaDBlbWRJYjJnSmRnZGNlRmVaZ2RiU2RRZTVhOGNlYUJjZGUzY2NoamQwYWZjRWFFZ01iWGRGaDBkcGhVZWVlUmFFZ1BhY2gwZGRoN2JBY2xkRmRvaEdlRWhnaEVoVGVoYWxkdmRlYjFkb2cvaGFlbmFKZVJnZGExYmRiS2dGaG1nbGVoZEZlaGhoZG1iRmZHYlpjbWFZYVhlQmdWY1pnd2U0YlBkVmFFZTVhYmNMZlRlVmY2Z2JoR2hOY1FhUWhFZnNjUGJVZGhhQmZrYVRjSGZaZDJnVWFrZUlkVmJlYkhhWWZTZFNleGVoZ0RoV2VXaEpjeWFaYm1kVmhkZ1VoRmR4Y2FkY2czYWhhRGJmYXlmNGJoYkhkZ2dvYmVkWmNpaGtlYWdVZzJoOGNQY0RoV2E4ZlRmZWNoYk1oYmhhaEJjMGhjZUdkQWQ1Z0RoYWdBZzBnWGZCYm5kaGN5Z1RnV2F0Y1hoUWFnY2RhL2NZZVJkc2dZZU1laGYxaHZiYmEyZ2hiOGhmZDJoOWFhYlJmeGcwZmRmVmNWZ0pkMGVhZDNjcGJqZlRiV2ZwYUxiRGYxYklnUWRaYUVlUWNpZ1BiaGVzZFJiR2d3YmNlM2dBZ1Zna2ZZY1hlbmNOY2lnY2huYkJmd2JTYUViTmdKZ1dhbmdWZjRlU2gzYWRjNmFhYVZiZGRaZ0ViQmhsZm9oQ2YxYk5lNmFCZ0FnQmQ2Y1JjM2VVZFRkVGUyZEJiQmJBY0Jma2JVaEhnaGdrY3piUmdRYmRhcWJiZUVlOWUzYkFoMGJNaFdiTmZXYkVnZWNUZUNoNWVkYU5kV2dnZ2ViTWNVZEZhM2dXZ2xjc2JCZUhoVmExZkRkWWRtaHRkM2VZZHhhbGFqZ1FnZ2JaZWJhSGZFYTVlTWJkZW5hWmRTY1FkaGJWZjRnZGRoYkphTGJHZ0VkTmdaZllmbmZKZ3djY2VFZmhlTGhIYlJoSWM4Z0tnMGNVaEloT2MzZjFnUGNXZ1FoMGRaYVlmRmE4ZE5oSmFrZUlhZGFFZEFkWmhuZENkMGJkYzJnQ2YwZGdmRWdUZmhlQmhnYmNia2hBaEFoZmMyZkZmRWdmZmxiNWVHY1BkR2NsZGhoRmdoZ2hhbWZGZEdjWmFtZlljWGVCZlZlYmIxZ3BhSGhTZ1ZiVWFjZEFjVmU1Z3JhZWRtY05oTmFhYmtic2JQZlVhaGJCZWtkVGNIYlphL2NTYldhZ2FWZWViSGFZY1NnU2J4ZmhmRGdXaFdlSmd5YkxjWGNsYUVhYWJVZ2xjYWJkZVhmaGRMY2RoM2dwZnBhVmcxZmtnWWhVZFdiWmdiZ0ZkeWhCY0ZoWGJEaHNiZWZJZjFlWmJKZ09nMWgwaEJjRmZoZE5jOGdJYXphUWVDZ0ZjWGhkZnljR2NYY2tnSGNHZkZla2E5Ykxla2RKaEJnTmRsZEZjb2NOYVNia2E1ZEVhemJzYldiUmd3YUFlZGVFZXdlY2c2YktlQ2I0Z3FkQWRpZlJkTGdCaHdhWWNjZlpoQmg1Yi9hZGRnZWxmb2JGaFhjaGcyZ0Vna2FzZlliUWUxZmxjaWNjaG5jQmd3YkdnZ2RZaGRmRGJ5ZWNkMmJTYTNjOWdRaGFmVmNkZlpmRWJCZ2xib2ZDYjBkVmN2YkVlUmhOYXZhUmYzZk1jYmFFYzJlZ2NRYlZhVmdCZFJjQmFHYTlhK2VmZUJnVmJxaGNibGdGZTNoVmUwZG9lV2JhZ1dkRWhXYkdoR2ZZZVVlTWRtZVpkL2ViY1ZiVmU3Y1FhbWQwYWRjSGdWY1ZkU2ZkYUdjdGI2Z1lhMGIxZXFlU2d3YjlnU2VFZUdjUmNNYWFoWGNaYWFkU2hrZEVld2ZQZDBhRmNGY1pnd2VKY05lZWduZEpkdGdjZUJmd2FMZUFiQWRsYzdjQmN3YnBlbmVhZW1hbGdMZ1JmUmJBZFJkUGdBaHRiSWFiZHdlVWdMZVpna2E1ZS9mT2dVZWRmb2dGYlVmaGJRZlJoeGRCZW1lY2hsYVlkVmZhZG5kSmhSYmRnMWFkaEtjRmFtZ0VmMWRYZGxmRWUxYUdkaGFraG5kY2FtaEpkVmNjZmxhcGhYY0ZhQmNGZy9jVWduaFJncmZlY21lTmNOY2Fja2dzZVBlVWFoZ0Jla2ZUZ0hhWmEyZFVja2hJY1ZjY2VDYkplYWVBYWtjdGJOYUpoaWJOZGplWmRuZkJoVmRRZzFkbGFUYWVoVmhKZkxmZGUzZ3BkcGNWZzFoa2VRZkdkV2dnZkxjUmRXZDhiUmFFYjJkOWNIZWNjeGROZVBlUGVGYzBiQmFBYzBlbGZ2YUpnMmhKYkdiRmVYZ2RheWZRYlhnNWZlZFllQmNaYXBlWWNSZ1liWWNaYmhmUmhtZVpnbWFGZ3doVmJXaDlmYWJSY3hiMGJIZVZmUWNaYjBnZGdXY2RjamFYZG5iaGhoaERkMWhJY1FmWmVFZXhhMmhkZGxiSmVDZ0ZiWGVoYjJnRWNrZXNmWWZRaDBhWmFpYmVmbmFnaGtnU2JFYjVoVWRXYm1hWmRxZVFjbmV0Z1FmYWNWYWRhWmNFY0JkbGhvZ0NlMGRWZnZmRWRSZU5idmJSYTNlTWdUYVJjMmhnZlZkUWhBYVFoUGJXZlRnVmM4ZEtjVmRSaCtiYWJsZkZlcWNWaDBkSmVDZUloU2ZoYkZhRmJoYWxmVmRkYjNmQmJoY2JkRWRsY3ZoRGJrZDRhZGRRaFZoVmhhY0lhQ2NNYnpkTWFFYU1hVmdDaGhjOWdDYUVjSGJwYVNhZGZuZzVjRGJWZUJnVmMxZ2Rna2RaY0NnRWJVZnBkVmRTY0hnSmF3YmNnRWdoYkRhU2RWaHBmMWVlaEVidGUzY2VlbWdsYlhkV2VSZ0FlWmJhZUFmTWVSYkpmMWJoY0FmWWZUZGdneWVBYUZmVmdvaENjRWNoaFlhRWYxZ2djdmdJZ1ZoaGJxaEtmMmVKaEJnZGYwYXRjV2JGZ2pmMWZvZEZoaGY1Y21jQWRuY05jemJjY21hVmJjYlliM2JCaEhmSGhSZjFlVmdVZ25nUmVyZWVmbWFOZU5nYWdrYXNkUGhVY2hoQmRraFRnSGdaZythQmJnaHBkY2FLYTNjaGR0ZkNoZ2ZsZFZhV2RYZzlleWNZZUhibGJFYmFjVWNsZ2FoZGdYZGhjTGVkZTNkcGhwYVZlMWdrZVFnR2NXZGdnTGRSY1djOGNSY0VkMmdjYlRhT2UxZW9jVWRaZW1kb2ZKaFFlRmVjZVFlZWMzaEpkR2VIaEdoTmRZaFVhWGdkZlhjU2JoYlplcGhZYVJlWWhZYlpkaGZSaG1kWmVtY0Znd2RWYVhnVmhhYkVneGgwYkRjU2RGZkphbGhmY1ZmQmZqY1RiV2JwZUxhRGUxY0liUWZaYkVleGYyZ2RkbGhKYUNnRmRYZ2hiMmVEZFVlc2FRZ1Nkd2gxZWlkZmUyYzFnd2VXaFZiVmRBYVZkbGM5YjRmU2MzY2RhNmRhZ1ZkZGVaZEVoQmRsZW9jQ2MwZlZkdmRFZVJhTmR2ZVJlM2JNaGJiRWF5ZkJjY2RHZDFiNGY0ZlViWGVKYnFiVmFnZmhjcWdlZGdnVWcvaEhmaGVrZVlkRmRpZkFlRmFDZG1jWWdJZWVkbWVZaDFnZWZWZlViemhXZGtnOWJKZFZnUmZ3aEJnZWhoZlFhN2FjYWxidGZxaFZiUmhGZlNlR2hIZ1ZnYWdkZG5jdGFTZEZkaGN4YnhhZmd4aDViaGJHYkViTmdaY1lnbmJKZXdjY2dFZ2hhRGZTaFZicGExZ2VkRWF0YjNiZWdtYWxoWGRVZFVlUmFSY0liVmRoY0xkRWJGYUFoQWNmaFVhZGF1Z09mVWVkZ29kRmNVYmhlUWZSZHhnQmJtZmNlbGVZY1ZhYWZuZkpnUmRkZzFkZGdLZ0ZobWZsYmhiQWJBZTFjemNCYzNoTmdtaFphM2RCYmRlWmF3aDRiUGVWaEVlNWFiY0xoVGFWZDZnYmJHZ05hUmdkYmtkdGhiZ1doeGNBZTRmVGhIYzRmaWVHZWdldGJHZWRnZ2JsZ1RhV2d3ZGhnRGRSYjNheGZ5YWVlR2hGZGVjUWUwZlJkYWZJaFhiRmhDZ2ZhbmdOZGxlZmRWZmtoUWFHZldmZ2hMY1JmV2M4Y1JkRWYyZzlhSGRjZ3hmTmVIYmFjQmFWY0lhVWhFZjljRWhMZ2poc2hGZUdieGhVYXphUWdHY0ZkWGNWZnhoWmJoZk5hVmI1YVJhTmJSYW9iWmRKYzNmRmZnY1ZlWGVOYUdhUmIwaGtlVWRWZFZlUmYwaGZhV2U5ZjJhWGRuZjlhQ2VBYTNhZ2ZRYVphRWd4ZzJoZGZsY0plQ2RGYVhmaGEyY0Vla2ZzY1lnUWcxZGxoaWhjYm5mQmU0ZkhiQWhzZEFlQ2JYZnNoSGJDaG1hZGFxaGFjVWhwZ1pnQWFCZkJlaGJJZVVjVmF2YUVlUmVOZnZhUmIzZU1hVGNSaDJmZ2JWZ1NhRmRCY0hhRWJHZ1pob2dWYWhnMWRpZkpiaGVrYStiQmNFYlJncGVLZEhkVWhPY0dnSGFzaFVmYmZqZklmcGVPYVFlWmRoZ0phUWZZZUpiQmhWZ1ZnT2JhaEdic2J1YWFna2MwYjJkU2Z3Y2NiR2ZXZUNoMGhmZ2VhQWZrYVRlVWdRYWRlNGRhYUFmeGNMZkVhRmVKZFBoWWRuZzlod2FKYUVlRmZLZVFhRmRaaGZiZWVFYXRiM2NlYW1lbGVYaFdjUmVBY1phYWVBaHRnRmFiaHhmRWhUY2JhMGJkYXpjR2Z4ZE1iZ2RYZ0JkdGJlZk9oRmdGYjFlWWRGZllkSWhRaEhnSmRSZmRkMWFkYktkRmRtYWxiaGdGaGhiaGNtZ0ZoR2ZaaG1iWWhYY0JjVmNiZTFmcGNIaENhd2doZ0FhUWNXZUZjcmFmY0diTmJGZFllaGQ5YUhhR2QwZ05ncWdNZHpkZGFsZlFhRWFJYUpjWmVIZFpkR2ZRYmhiZ2FmZFdhV2RvZ21oT2VEY2toYmNUZ1RkWWdiZVpiR2Q1Z0xjYWVXZlJocGZYYzBnZ2dHZkdjV2JVaExoRWZXZ1llWWFHYm1nWmZMYldmUmJOZkhhYWJCZFZjSWFVZ0VkY2ZRZVphbmhKYVdiRmdXZnBmeWdVaFhlZGhYZVNiaGU0ZTljS2NWZzlmTGZhY0dic2duZ2RiM2FkY3dkU2NFZlZlYWVSY3hjMGdkY1ZkVmFKZzBnYWIzYnBkamdUYVdlcGFMZERnMWVJZFFmWmVFaHhiMmJkZWtlUmVYY0FjR2Z0YWpoRWZrYzBlWWRTZTFnRWcyZU9lamJrZmpoUmJqaHdiSWJTZjJnTmc0ZVZiMmN0ZzZjUGJWYjVhWmhUZkJhbGdnZlhjd2QwZm1hUWhoZDBjUWRCaG1iTWhEYlJhM2hZaExmU2JGZ2hmV2JCZW1hWmEvZFZoa2JGZmpiZWExY2hkK2JXYjJlQWFXY2FmV2VFZldnR2RHZ1loVWFaYm1jWmVoYmNkRmZWYnZoV2NrZWNhZGVIY1ZhVmZhY0llQ2FNZnpjTWNFZ01lVmZDaGhkOWFDZkVlSGFsZk1hZmNpYUlmYWZDYTBhWmIyZ0NhVmVOaGJhQ2RFY05kRmhmYW5kSWJrZmVoVWRoYkZoU2hVaHhkZ2RiZ1ZmaGdpYmNoMmZCZ2JmY2F4ZUFmWmFhZUFldGhGZmJneGVFZ1RjYmcwZmRnemdFaDBmZGJvY1JkMGJnY01lR2V4Y0JjdWdKaGhiNWZjYU9nWGN3ZnVmTmZrZE5iU2dGY21jOWI4aEZkZ2g1Y3pmQWVYYlZoemJhY0hmeGYvaGJjMWRwZEhnSGJSZjFoVmJVYm5nUmdyYmVobWdOYU5hYWNrZXRhYmRHZmxla2gzZlpmbmZaYzJnVWVrZUljVmdlZUhlWWhTY1NneGJoZERjV2dXY3RncGFXZG5nQmhJZVFhMGVsZWFmZGFYYWhlTGRkYjNlb2QwaFhobGhVYzZlR2FXYmdmTGdSZldnOGFSYUVlMmc5Y0hkY2d4ZHNlUGRaaGtlVWVhY0hoeGhOZmZiTWVpYnNmR2JVZ0dkUWhnZEhkaWNNZFdoSGdsZE1kRmFKZUZiQmJNZ1pkZ2dsYm1iTGJtYjhkZ2JCZnljQWdPY0NmRWFsZEVlQmZSZmRiNmdPZ1RnVWczZ0FoV2JwY1dlRGd4YVJhRmVLYWdlOGZpYlBoeGUwY01oRmVYYkFnaWZHZDBjdGdEZWFlVmFsY2lhY2NuZ0Jjd2VTZUVnTmVKaFdhbmhWZjRnU2d6ZTRlOGZhZVZkOWJSZUdnRWYxZG9kRGJsZGhldmZCaHdhZGZtYlNoM2dNYURiUmczaFVmSWJTZkFmUmFPZ0diV2ZZZmdhRWYwZ0VlL2NJZUJoOWEzY0Fnd2dKZ2ZlT2NuY29jOGZHZEdmWWdVYlpibWJaaGhmY2VGZ1ZhdmRXY2tiY2ZkY1ZkQmROY1NmZmREZDlnNmNmZlZnQmhxZVdjQmExZWJkRWNEaDlnbWdkaG5mWmRTZ1FoaGZWaDRoZGNoZkpkTGZHY0VmTmJaZVlobmVJZm1iTWNSZXBnRGhHZjFocGhvY2VhQmM4Zi9lTWN6ZHBmWmFKZ2xhRWZKZGVmQmhCYnZiYmV4Y0VmVGJiZzBiZGV6aEVnMGJkYm9kRmVVYWhoUWNSZnhnQWh2Yk5hRmhZZWRjUWNIZEpoUmNkZDFhZGZLY0ZkbWhsZWhkRmVoZmhjbWdGZUdnWmNtZVljWGFCYmRlWmd3YjRlUGdWZ0VkNWNiYkxkVGdWYjdiYWFtaE5iUWVhZWhhOWFIY0dmMGdOYnFiTWJ6ZWRkbGhRaEVhc2daY1VjbmRZYlNmU2R4YmhlRGVXYldlSmF5YWNiSGZCZkliUWMwaGxoYWNkZ1hhaGFEYklnemdJZWdhQmRGZmRidmdXYUhhc2RaZlJmWGhJZFJhUWRXYVpoTGRXY1JjTmZIZWFoQmdWZ0llVWFFYWNoUWFaZ25iSmNXZEZnV2JwaHlkVWFYZ2RjZmFHZ0JnWmEwaFlhVWdKZ1FjTGQwaGRjb2hHaFNkQmdrYVRnV2FaaFdkYmFSYTBiZGhWYVZmSmQwZ2FkM2VwZ2phVGFXaHBkTGVEaDFjSWNRYlphRWF4aCtnSWVoYW9lTGZSaG5hWWJKZlVmMWI4ZEFjUWcwZFJnaWRKZ2piZ2M1ZUdiMGEwYzJmR2YyY1JkdWJRZ25mdGRRZ2FjVmdkaFpjRWFCZGxmb2dDYzBjVmJ2YkVlUmVOaHZjUmEzaE1lVGhSaDJlQmFCY0FoQmdrZlViSGZoYmtkemFSY3djTmhxYmJoMWZFZmxmWGJraFljOGFhaFdmRWVXZkdhR2FZaFVkWmFtYVpiaGdjZ0ZjVmd2ZFdla2VjY2RnSGNVZlpnQWhkY0hmWmhuaFlleGhsYmpoWWdRZDlhU2hFZkdkUmJNYWRkbmRaZlNjUWhoaFZiNGFkaGhhSmdMZ0ViV2RsZFplWWhuY0pod2NjYUViaGVEY1NhVmJwYTFkZWVFZnRhM2RlYW1lbGhYY0NjMWVWZk5mUGhWZ2thTGJiZzBkVmZiZUpoaGVSYm9nT2FVYmRmb2JGYVViaGdRaFJjeGFCY21hY2hsYVloVmdhY25nSmVSZ0llMWVkaEhnQ2UyYWxneWRCYUFkTmFNZUZnR2ZaZW1nWWRYZ0JkVmdiZjFocGRIZEhoUmgxY1ZnRGcxZjVhcmhlYm1kTmJOZGFka2NzZlBiVWVoYkJja2JUZUhjWWhnYkVneGhBZlZhTWNYZVloUGVTaHhhQWJYZkVjU2FzaGhoZmJnZDhoSmRWZjFjRmhhZmFjV2NSYkxmWmJtYnhmZ2hWZHdhVWZRZlRlU2JCZkNiRmVtYUZkdWVVY25keGVWY2ZkemZsZEhnYWJCaFZhSWVVYkVnY2JRYlphbmRKZVdjRmZXYnBleWRVZ1RoSmRYZVZneGFaZGhmTmRWZTVhUmVOZ1Jkb2ZaY0pkM2NCZ21nVmdYZk5iR2ZSaHdid2VMZ1hoRmRJaG9iYWR5ZzRjcmNCZURmbGJGZGNkQmJNZUFnZGJFZ0JhY2dkZ2xjSmhDYkZiWGZoZDJmRWFrY3NmWWVRYzFlbGdpYmNlbmJBZi9oU2hGZTVlSmFVY2pneGY0ZlZjMmh0ZjZiUGZWYjVnWmVUYkJkbGJnaFRka2ZWYXhmRGh3YTFmdmRUYzJnQWVCZVJnMmhVY1ZnSGVGZWxlT2ZIY0VleGF5Y1ZkaGNWYXFhY2ZsZEZnM2hWZTBib2VXY2FlV2ZFZFdnR2JDZjRjVWhlZTJmWmdwYU5mVmNWaHpkUmRrZ2RmSmZGZUZlVWZPZmRoR2FNaHpkWWcxYU5oMGNWYVFkOWhhY0FoM2RaYk1iZWMzZllkR2VTZHhoeGdqYlhlQmdKZExhR2RFY05kWmFZZW5jSmJ3Z2NiRWhoZ0RkU2NRZ2dmd2VMZEJjNGRsaE5iR2FsZGZjY2h4ZEFnWmJhY0FldGVGZmJjeGFFZ1RjYmIwZWRhemZFYjBlZGVvYUhoUmJ3YlliRGNrZk5jb2VEZFJnY2ZGaGVhbmJKZU1iZGYwYkZoZmdBYjNhcGEwZkZlaGQ1ZW1iWGNHZTlocWJTZjNhQmVWYWJlMWRwZUhmSGJSZTFiVmFVZW5kUmRyaGVmbWROYU5jWWhoYjlnSGhHZDBiTmdxYk1kemVkYm5oUmZFZkllSWRlZERjNGZTZVZnUWRaZWRiV2ZYY05ia2hlYlhkeGNpaFFkMGZsZWFjZGVYZ2hnTGJkZTNhcGJwZ1ZoMWdraFFnR2FXZmdlRGZFZlNkZGRZY1FnR2ZFaDRhTWZnZUJjVmNhZ0FjaGdJZlJhbGJJYUZlZGhXYWRiV2hFYjJnb2U5ZldlSGJ0YzljU2JoaFplcGhZZFJoWWVZZVpkaGVSZW1hWmVtZ0Zld2JWYVdiOWZTY0VkMWhWYVVnQmhsZHdjTGNLYm1jNWI3YVRnWGRkYUxnUWVGYkloT2hlZGxoSmgyYlpoMGZSZExiR2hWY0poMmZFZ2tic2RZYVFkMWJsYWljY2NuaEJnd2dTZkVlTmNKY1diaWJFYndiQWRpZ1JiUWNhaFZjZGhaZ0VkQmdsZm9iQ2cwYVZndmFFaFJjTmh2YlRnbWNnZjVmUmYyZGdmVmZTZkZnQmFIY0VmR2haZHliVmhrY2hhamVmY25idGMzYlZnMGJvYldhYWRXZkVnV2hHYkdjWWNVY2JjaWI1ZHZjSWRBaGNmZ2FEY2dmaGJKZlJjQWVVYlhiZWJqYWtoMWFOZ3djd2crZURkbmMwZ2JiVmN5YndmWWZkY21mdGFTZUNmaGhzY29kSmJGZzBjZmhWYXhiY2ZBYU1kamZkZStlSWRnYWNkWGdHZDFicGZvaGVlQWMwZWljTmFDYW9jRGhFZ0ZjOWdYZ2FmQWdNaFJnWmRoZEZlSWFSZFVnZGN6YkVlMGdkZG9mRmZVZGhkUWdSaHhiQmVtYWNoaGQ5Z1RlYWduaHBiWmhmYndhTmFLZ0VoM2RSZWhiQWRBaHhkdmNHaEdhWmUyZlllV2MxZklhYmN3ZTVmT2hGYUJnMGhIZEZieWhBZStoS2hDZzFkTmJQZmdjTmZHaEFmUWd0aE9iVGhIYVpjMmdVZGtkSWZWZGVhSGNZZFNmU2R4YWhkRGZFZUNiUmZ5ZmVmQ2JSZUlnWGZWYlJhYWhaaG1icGZDZ2RieWZGY0RkVmYxZGtjUWRHYldnZ2hMYlJnV2Q4ZVJjRWgyZjljSGNjZXhjTWVSaEtnVWJkZUloQWNrZWNiTmVaYmlmWWZlZVhjRGNsYjhlTGFqZVpoSGRXYWdiMWJEYVlnUmdZZFllWmRoZVJkbWFaaG1lRmJ3ZFZjV2Y5YmFoUmR4YzFoVWZFYjFnSmE4YVFiWGhwZ2pjVGNXZXBlTGVEYjFoSWdRZVpjRWZ4aDJlZGNsZUpkQ2dGZlhjaGErYkdjaGQ5Z1FkQ2dnaHBhc2NEYlRiRmZnYldhRWJOY1VjV2RpYUVod2JBZmliUmgwZUZlaGFaZ0thQWVoZkJla2dJZ1VkVmV2ZkVnUmJOYnZnUmEzZU1jVGdSZzJnZ2RWZVNiRmJCY0hmRWdHZ1pjNmdBaGxiMGhqYkljVmI4ZEloRmRsY2tkRWhhaFhmd2RXZVNhbWY4ZlliVGhHaFplaGNjZ0ZoVmR2aFdha2NjaGRlSGNWYVZjU2dkZkdmdGM2YVlmMGExYWliR2dRZDliUGFFaERoQWNFY1BheWdWZmNjUGhWZFJhc2diZ2hkdGdIZ01la2ROZVphWWRuYkpld2djYUVkaGhEZ1NhVmVwZTFoZWdFZHRkM2FlZW1jbGJmYkRkVmZoZFFoT2Z3ZFVmNmNMZmdlVWRMZWJmMWdwYnpkUmZ3YThiaGdSZWtkWWh2Z0JmZ2NGY3dmZWIxZG9oL2JhZG5iSmhSYmRlMWRkZUtmRmJtYWxjaGRGaGhlaGJtZkZmR2FaZm1kWWZYaGdoQmJKaHhmTWhVZ0VmMmRJZ1VoUWEyaEpjcmJaZzJoTWhmYlloMGZjaGxiVWVoY0Joa2NUZUhkWmcyZlVia2NJZlZoZWhIY1loU2hTZ3hkaGZEZ1djWGJGY2doY2FHZjFhVmZRYXhiMWJUYVhiM2JoZ0xhZGEzZnBhcGZWYzFha2NRZ0dkV2RnYkxjUmFXYzhkUmJHZGtiVmhIaGNneGROYkhiYWhCaFZhSWZVaEVnY2FRYVpjbmJKZVdnRmZXZnBmeWFBZ3phSWVEZEhhMGhRYm5nWWVVZkpiUWVMZDBnZGQ5aFRjR2VGZ3dhVmVXaDlmYWVSZXhjMGVkY1ZlVmVKaDBlYWQzaHBlamJHaFdicGdHZUVhbGVJZkRjZGhsYWRjY2FkYmxlSmRDaEZiWGVoZjJlRWZrZ3NmWWhRYjFlbGJpZ0xjMWNwY3diU2FFYU5lSmdXZG5lVmQ0ZFNmM2VkZDZiYWFWZGNkUGZVZ1VhdGhvZlFna2dWYXljRWhSaHNmN2REaHpjcGFBYlNlUmJkZlVlWGZFYWhiSGdEYUhjcGh5Y1Jmd2FOZ2phY2NnZzFhM2FBaHdnSmNmZE9kbWI5YnBoV2RYYlVnR2RhY2tjeGVoZmNnRmdWaHZiV2RrZmNjZGRIZlZlVmZTZ2RhR2V0YjZkWWZ3YWhocWFWYWdiOWVhZlJoQ2h3aEZjSmFYY2dkdGRBY3dhUmh1YmRnZ2c1ZlhlR2VGZUpjUGZhZTNkSWJzZ2NiQmF3YkxkQWJBYmxmN2dCYXdhcGJuY2FmbWhWZzliV2NSY0FkWmhhYkFjdGRGZ2JjeGFFZFRoYmUwYmRhemdFZjBnY2ZuZkZoVmNWYVFnVGIxZWxkbWNiYUVoZ2JMZWFmaWNaaFllZGh3aHRiS2RIYWljeGFoYUNnZ2VSZ21oSGhIYlZhMGRZY1hjMWNWY09jMWVOZU9kRWFUZ2RhVmZVYm5jUmFyZ2VnbWROaE5iYWNrZHNnUGdVY2hmQmNrZVRmRGQ1aDJkVGQwZklkZGNQZVhiWWhNYVZoUWdaZkRnRGFXY3RheWRMaEhmQmNBZUNma2hsaEdjYWVYYmhmRGZaZEdlaGVwaFdnbGFsZ0VjRWRHZEViUWViZDJkOGRSZkVjMmM5ZEhhY2V4YU5jSGRhYkJnVmdJZlViQmVWZ1ZoTWFpZWNjRWNXaDJkcGY2ZmVnM2ZkYVhjU2FoZVplcGFZaFJiWWRZZ1pmaGhSZW1kWmNtZ0Zid2NYZlRlc2RTZkRna2Y0ZVRoS2FoY05ma2JlYTNhcGErYVRiWGV4Z2VnR2ZrZ0VlRmJaYUVhcGYyZFBkbGN0Zk9iUGMzZWhlMmRFYWtlc2JZZlFoMWVsaGlkY2VuYkJkd2dTZUVkTmZKZ1VnaWVFZHdnQWNpY1JmMGZGZGhmWmJJZ0JmaGVsYTFjQ2h3ZzFkdmVEaHdoMWh4ZVJjMmNJYkZkVGZtY1FoL2ZTYkZiQmNIZkVjR2VaZnlkVmZoY1ZlcWVjaGxiRmMzaFZlMGhvZGVmUGFTZWxiZmVTZjJnaGNyZkpmM2VWZHplY2dFZGhhdmRUY0ZoSWVJZ0Rla2RCYVNiY2FtZXNhMWJhYmthRmNBZFNjd2Y5ZFNhRWRHZ1JhTWdkYm5lWmFTaFFmaGhWZzRlZGNoYkpoRGJUZkFjc2hRY01mWGd3YVBnTWNWZnhiYmhTYlVlZGcxY05jMGN0ZXBjWmRIZGRhWGRTZ0FmWWNRZVplQ2ZGZkZoYmJ4YkVjVGFiZjBnZGd6YUViMGhkYm9jRmJVaGhiUWFSYjBiUWN1ZE9hd2dVZC9jYWFuZEpkUmNkZjFjZGhLYkZmbWhsYmhjRmFoZmhnbWFIaFhkMWRNY1ljWGJCZlZlYmExYnBjSGZIYlJkMWFWaFVkaWFsZ2lmZGRrZ2xnTmNhYWtkc2NQY1VmaGJCZGtjVGJIZ1pmMmhXZWdob2FiYUtnQ2hSZGRnSGUxZWNlWGdBY0RmSWMzaGZhamdNZUVjRGdBZmNjZmdkaFdlVmFMYU1kU2Q4Y25lRmZBaDFhWmdWZWlkWWRMYlRmV2NZZlJlU2dFZVZmSGFjY3hlTmJIZ2FkQmRWY0lnVWRFZWNnUWdaZ25hSWZFZVVnRGU0Zm5nQWN6aGxoWGhCZEZnTWYrYlllVmg0ZFFiTWFsYXdodmNOaFdnOGhQYkZjSGY5ZEthU2d4aDFmSmNIZ1Jic2huaFpoUWdVYWlnWGJIYXhnSGNEZHdlWmJZaExmUmM5ZDRlQ2dSZk5kUmdCYTNlUmYyZFJiZ2JOYVJjRWdGY2NhZGFNZzJjUmVvaFFnVmRoY2pmV2RuYlZkNGNTaDNmZGI2YWFhVmhkZlpoRWVFYlJoaGhCYzJhOWd2aEVkUmNOYnZhUmUzZE1hVGVSYTJoZ2RWZ1FhQmJsZEhhRGRXaFlnSmRLaHhieGhtZFdkRmZGYjNiVmQwZG9mV2FhZFdhRWNXZkdlR2NZaGNkSWIyYVpiOGRjYUJmTWE2ZEZkQWdSYUpjVmhCYm9mY2VkZEdlTmR6YVlkeGFaZkFoU2R3YTllU2ZFZ0djUmRNaGRmbmJaZlNjUWFoZFZhNGZKZUZkY2ZmaFRnUmJFY1hnWWhqYXBhcmdXZmtkaGNEZ1NkVmZwYzFnZWVFZHRhM2RlZW1ma2hLZFZhMWZGaEpmT2RFZmNnY2haZDBoTWdmY2Jld2g1ZjZlR2hraHRhQ2hGYVViaGJRZVJieGVCZm1hY2dsY1lnVmVhaG5oTmRaZUllUmVnaERlVWdtYWxleGNGaGhnbGU3Y0NmV2NZZ2phWWZYZlpoVGZiYzFkSWNUZUVhMWFnYU5iQWNqY3NiNWZMaGpkQmNOY2RiMGF0ZktoV2F4ZmxlL2JaY25lWmIyZVVha2VJYVZiZWFDY3NnYmhRZDBld2FMYUVoRGhGZDdlYWYxZHBkSWZRYTBjbGRhZktmSGdSaGhkZGQzYXBlcGJWY3hhOWRGY1ZoeWh0aGZiRGdDY0JoZmNFYzJnY2VUYWZheGhNYlZiWmRCY1ViQmFXZVVlZGFMZ1RkSGVKYldjRmhXZXBheWhVYVhnOGNSYkhjMWVnYnFoTmdWZjlkWGNLZkJmUmN1YU5nR2ZoZndiRGNrYlZmYWNSY3hiMGhkZ1ZjVmdKYjBnYWh6Y3dnMmZBY3lia2JmYlJnaGMxYWVmWmJBYWxiK2JJZ2xkdGRDaFRobGVKZjJlRWZrZHNiWWFRaDFnbGFpYWNlbmNCZndhRGhnZ3doYmZXZG5lMGR1YUNhaWRWZzZmT2cxYmRhRWdFaEdjSWFWYkJlMGhVY21mRWdRYzVidmFWZjNkOGFUYkFhbWNnYkliU2NBZlJnSmhYZENoTWU4YUVmVWRFY2lkYWJWYUVneWJWYTFoUWhXZUllSGFvY1dmVWNXaDBoZmViZTJmWWU2YVdkbGdWZ3ZlV2FrZGNjZGFIYlZjVmRTZGRhR2R0YzZkWWF4aHNicmJHZFFmOGdkZUViSGJsZk1mSWNuaGdoUmFDZWxkUWVxaEZkVmUwaFBnWGNTY0lnTmZhZGpkdGg1YWFlMmJKZ0RkU2VWY3BoMWZlZkVmdGQzZGVobWRsY1hmV2NSY0FiSWZlZ2hlTmhGZ2NlUmRGaGNmUmdVaGRjemNFYjBkZGRvY0ZiVWJoZ1FjUmd4ZUJmbWVjaGxmWWhWZGRhWGJJZERoZWVRZWNhZmdSZ1NhRmNwZFdoUmJGZE1iRmNHZVpjbWNZZ1hiQmFWYmJmMWJwYUhmSGZSZDFkVmhVZG5jUmV4Y2VlbmRGZWRmZmNsZU1iUGVUYUJmQWhyaFpkbmJaZzJhVWZrYklkVmFlZkhjWWNTZ1NneGZoY0RmV2JXYkpheWRiaDNlQWdhaFRnUmFrZ1BkSmdqZ0JiRGdaYm1iTmc3ZVZhd2FVZFFhRWNTYWNmTGVXZDNnRWZSZUJkV2haaExlY2N3YkpjVmVjZUJnVWdVYlVoRWc4aEdiZGRYY0pkUWVGZFNiVmI3ZVdoRmUxZFhlU2doYlphcGZZYlJhWWhZZFpnaGhSZ21hWmdtZ0Zid2hWY1hoVmZhZVVjZ2FnaFBnVGRFYVJnMGJkY1hmb2NzaFRlVGVZZ1hhRGd4ZzBhUWVlaGxlRmUyZ1lmMGhWZFJnQWdXZnhiY2VFaGtkc2VZYVFlMWZsYmljY2FuZkJod2VTZEVoTmRKZFdmbmZWZG5jU2R5Z1ZlMGVPZlFkSWhLY1djQmhGZjZmR2JWYUZkdmJUZ1JhTmJuZ0NnSGRNaE5hV2RXYWdoRWRXY2xkbGhMY0ViSGRkYWdkVGJoZlViMmRjY2xkbGUvYkdoRWVvYkloZGQyZEViQWdFaFdkWWNTZlpmbmJCaHliZWRWYmxidmVTZDFhVWZGZkhkUWVsZVNlZmdIYjFncGJZZDBidGJxZUJoQWFaZ2JlT2htZlJhTWJkYm5iWmJTYVFoaGhWaDRoZGdoYUpkTGhHYkVjTmFaZGVoSGhKYTRhT2ZVY05jSWRSZFhiQmMxaGVkRWJ0YzNhZWJtYWxmWGZXZFJhQWFaZWFkQWJ0ZEZkYmh4Z0VoVGVaZndnaGJ6Y0Rma2VkZCtoQWNGZjFoRGhVYlJiQmF0Y2NibGM0ZmRoWWhtZk5oQmZaZlVkUmNLZEVoR2ZrZXVnSGZ4Z2hnNmZDaEdoWmgzZ2NhWGdsYVZlTWYxZ3BnUGREZUFoMWdIYlFiWGdSYXRhZWVqY2RnRGdLaFFmTmFPZkFlSGFNYnJlQ2JEZE1jWGJCZ2tmcGRjYWNmWGY4YWJkUWNoYlJmcGNXYldoSmh5YWNoSGFCZkliUWcwYWxjYWdkYVhjaGNMaGRkM2ZwZnBhVmR3ZHNlZWFTaFRlMWNZYURmV2RjYjdlRWEyZDliSGdjZXhnTmZIaGFhQmdWYUloVWZFaGNiUWRaZ25lSmNXZ0ZhV2JwZXliUWcyZE5oSGJTZWtocGRwYmFmVmFrYVliZWRBYXBkbWJkZTNibGE1Y1dmVWJWaGFmUmN4ZTBjZGhWZFZmSmEwY2FoM2FwZWpiVGVXZ3BkTGNEYzFmSWNRY1poRWV4YW5kWmJFZXBmQ2RTZ1hnaGErZEdnZ2JRZllnWGZVaGRiaWVZaDJjSmM1YVNkRWZWaEpkVGRHZlpieGdSaDFiMWI2aGFoVmZkZ1plRWZCZ2xmb2JDYTBiVmZ2YUVhUmFOYnZkUmYzYk1kVGZSYTJkZ2NFZFdka2hoZkhmVGZHZFpiNmFYZWxjcGVxaGJkRWU5ZzNnUWVVZk1mV2JiZjJnRWVBY0NiMmI4YlloVGJHaFpjaGVjaEZnVmR2aFdla2RjaGRiSGhWYlZoU2JkZ0dldGY2YlloMGExZXFlU2d4ZjVoQWJDY0dmUWFRZ2RmbmI1ZEVnVWdSYVZmK2VkYmxnMWNDYU1ka2VOZ1pkWWRuaEpmd2NjYUViaGVEY1NkVmFwYjFlZWdFZHRmM2FlaG1kbGNlYlVnQWJzZXpmYWRBaHRiRmZiYnhoRWFUYmJhMGhkYnphRWZ4ZHBhQ2FGYlVhaGRRZVJoeGFCZG1mY2RsZFlnVmdhZmlhQWdVZklkd2ZJY1lmV2NHZGtidmFVYjBiOWFtZ1lmU2U4Y29oTmhXZGdnMGdQZ1FiZ2hHYVJoQmJVaEhnV2gyZjloQmJlYW1kTmZOZWFla2hzZ1BkVWZoYkFlNWVaZ25hWmEyZFVoa2NJaFZoZWFIaFlhU2dEZlVoMGVOZEdjamNZZDdjUGF6ZjVoSWVEZ0VhRmhUZWRmU2VOYmhkZGMzY3BicGZWZDFka2dRZkdmV2JnZkxlUmFUZTFnVWVSY3pkb2VWY1BmUmROZlZhYWRBZ2hoVmNVZkFnWmJDaElhU2FjYmJlVWhDYlFobWNBZm5ma2RiZERjMWJnYnVhTmNWZTRkeWJaY2hiUmRtZFpobWZGYXdjVmZXYzlmYWdSYnhjMGFkZlNnbGdJZjZnTGdpZjFlamZBZG1mSWRLZlhlUmNWZEZjS2FRYmtmNGdJY2dkRWE1YkJkQWVWaC9kSGZCZDViSWNCZXhmZ2IyYU5nM2RnZXhnR2RnZVFiY2NGaHpkQWYyYkhneWVRZkJlZWdTZnBlUWRIZGxiMGJoY1RhQWFBZzhlUmJSYnRibWJiY1hjTWdUZFJlMmhnZlZnU2VGZUJoSGFFZ0diWmd5YlZlZ2U5YnFhSmZoYmtkK2RCZ0VjcGVmYkplemFKYUNiV2hTZ2hmWGNJZ3lja2duZ2NnQmVwaEZhV2hraGNmZGJIY1ZkVmJTYmRkR2d0ZzZjWWMwZzFlcWFWZ0FkOGRFYlhneWMwY0llZGZqYjVlY2RBaFZiUWYwaE9laGNvYWZmVWRBY29jS2diYm5jSWV4YklhZ2Q4ZFdkQmhCZDhkN2FMZEJhZ2JNYWFhaGRSZWVnY2N4Y0FkWmdhYkFjdGJGaGJjeGhFYlRlYmgwZGRkemZFZTFhMWNvZ1dld2MwZUhkUmMxYzlndWJNYXdkUmNTZ1BhemI4ZlVlT2RRYk1iWmhiYlhna2djaEhmd2hOYk1iRmVHZVpjbWVZYVhhQmJWYmJjMWRvZmFlTmh4ZDFnVmhVZW5iUmVyZGVmbWVOYk5lTGFCZDVnQmdFZFVhUWR0aEFlemZoZTJmR2VrZ3BnQmRjZVhmWmhKZlliUmFoY0RmV2dXY0poeWhjYkhoQmVJZFFmMGFraElkTWhDZXdlZWNKYVRoUmZwaFhlM2hNZlFhR2dXaGdjTGZSZldhOGNSY0VnMmM5ZkhlY2Z4Z05iUGFQaEZhMGRCYkFnMGVsYURlSWN6ZWNkU2FGZFhoZGZ5aEJlWGNjY2VmQmhFaFVhOWJJZ0ZhaGFiZEloMWhzZmdoWmVpZjlhd2NTZG1lOGRPZVNmVmc1YVJoR2JoZHdheGFZZDNhTmhqY1ZlMmNvYkZkQmV3Z1loWmViYlVnQmdjaGRjbGNKY0NoRmVYZGhnMmFFaGtjc2FZaFFlMWFsZmlhZWdpY1FnNGNBZVJjQmFIY0RhR2RSZzRnVmNuZmNhdWFJZ1JkNGhLYUhla2NvYnRoVGdnZ0ZhaGVVZWxoOGFnY0NmVGhZY2JnVGFtYlpoVWhEYkJiUmRQYlFjMmg5ZjhkRmgxZkVndWRlZWhiQmYrZ1hja2ZZYThjYWhXZ0VkV2dHZEdiWWdVY1pnbWhaZWhlY2VGYlZodmhVZGhjTmJWaFZiQWNaZ2NnSWhuZ2xmNmhmaGtmMGErZ0FiMGJZZkJnSGJqZGNjSmhNYXpjSmhjaEFlVmVrZzNjT2NGaGRnRGFFYlVkMGZZYkpnamNaYjRjTWVVZ0ZhS2VSZFhhQmYxY2VoRWN0YzNmZWJtYWxnWGZXZlJlQWZaY2FhQWF0ZE5iT2IxZmxnYWJQZkVia2NsY0FnRWFkYzFhRmhSY3dnWWVEZ2toTmJvZ0llUmROZFFiTGhuZndnU2dPZ3hiZ2VFZVViMmFGZm9hSGF4aFJiTWJGYkdjWmZtZllhWGZCYVZnYmgxZXBlSGhIYlJkMWNWZFdmaWNBZWpmTWh6ZUJmRGRQYUZhOGNQZ1RheGFBZHdkQmdEZThkbGhYYUJhRmhRZVBlVGNJZGNhQ2hGaFFiTWVGY3llZGI2Z2ViWGc0ZWJoRmFnZnNiT2hKZXpoa2JJaEljM2NJZjZiWGRsYUFmY2JNaDJmZ2hMaFJmV2U4YVJoRWYyYTllSGJjY3hkTmVIaGFjQmMwY2NoR2ZBZjVlRGNhYkNiWWRaZlFjU2ZzZCtnTGRqY3NoU2RCZkJlWmMwZFlhUWRZZ1JkYWZqYTVobWhaYW1iRmV3Y1ZiV2E5ZWFjUmJ4YjBnZGJWY1ZjSmQ4Y1BoemFJYnFiSGdtaFFiR2hTYmhmOWNEaExmUmdZYXpoZGZraDllQ2hCZFhmRmE2Zk9nRWJzYVlnUWYxaGxlaWFjaG5nQmR3ZlNiRWJOZUpjV2RuZTBic2JBZ3plNGFwZVpkeGNvZmNoWGNWYVloNmRVZmtlVmZ5ZkVkVmUwZjZnQ2d6YjhmYWdTaDBnSWJWZVNnRmVCYUhkRWRHZ1poeWNWaGhkVmZxZ2NnbGFFY2phSGV3ZU5jRmhRZDJmRWNXYkdkR2dZZVVjWmNtZ1phaGRjY0ZhVmNtY1FlV2gwYWRoSGRWYVZoU2hkZ0dkdGI2YVloeGhCYUFoU2N3aDlkU2JFZEdjUmdNZmRlbmFZYkVkQWYwYmRhNGdPY0JmSmNXZkdoQWRwYlJnY2QzZ3RjK2dCY1NoRWF0ZlBiVWR4Y2hmZGVHaEZmM2ZlZm1jbGJYY1dnUmhBaFpiYWVBYnRlRmRQaEJhRWdPYWJkd2ZsZzdhRWRWYVplNWdBYlZiaGJBaFVjQWhGZHliWmRVZjRhQWZlZW1nVmRGZFljVWI1ZGVkQWRYYkJid2RGZEJlRmVxZFBjbWdaY21nWWhYYkJmVmJiYzFicGVIZkhiUmIwYlVmVWNtZGxhcmVOZ0didGJQYWViMWU4Z2ZnUWVBZmxjd2FXYm1lRmNsZFJhRmhRaE5hWWFXZ0VnQ2hXYWdoRmdVYVNlM2JWZndmZWdYYXhlaWRRaDBibGZhYmRoWGZoaExoZGgzZnBmcGdWZXdod2VRZUJoR2ZoZEZnVGZXZzBmQWVCaFhlOWJlYlplZ2V0YlFmY2RRYmRiUmNRYzFiNGJDYmZjbWVGYVBkQmdIY3hmamRVZTNiNWJiZVlhQmhaaHBjWWdSY1ljWWNaZmhjUmJtZlpmbWdFZjJmVmJYZUpnYWZDYVJoVWFmZVRoRWRSaGhjZWgyZXBheGZWZ0hhaGdmZEhoVWFBZklmY2UxZFJla2diaGtiZGhWZERiSGVwYS9kSGJtYUVnWWNRZTFobGJpYmNibmhCZXdmU2dFYk5mSmVGZW5iVmRsYVNjemFsYXlhYWEwZFZoQmFCaHdobGM1YUhnRmNKZDdmQmFBZU5lL2hWZG1kRWRGYVZoM2NnZ0hhWGJrYUZlRmFHY1hmMWhZZlZmaGdWYnFiY2hsYUZoM2VWYTBob2FlZEpmbWM5aEdiU2RpZGxnQWdLYVRoSWM0YkliQmRCaGhhRWZ3YmxkVWJTY1ZlVmZQZWRnQ2FOZnphYmUyZ2RhcWdTY3dmOWZTY0VmR2FSZk1hZGduZFpnU2hTY2xocGUyYUpoa2NBZUVnVGhBaHdmTmVPZHlkSWMxaGZoaGQwYVRlRGhSaHNoaGdQYlVhdGVxZmVhaWM4Y0NjRmIxaE5jTmVJYVVhUWNMZWJjeGhsY0hoWmNrYmNob2NPYVVkZGFvZkZhVWVoZlFhUmd4ZkJobWdjaGxlWWRWY2FnaWFRYlFhSmNWZ2NoRGZHZmtnTmhoYkZjaGNoaG1mRmZHZVplbWZZaFhhQmJWaGJkMWRwYkhlSGJWZEpmVmZUYzNiUmNwY0thVGZjZGZnSWZ3ZlZhSWRVZ0JlQmM1ZlViWGNZaGliQ2J4YkplUWROY3pmQWNTYUhnd2FOYnBmV2JXZkpheWJjYkhkQmdJYVFhMGJsaGFiZGJYZmhnTGVPZUhocGZ2Z1VnVmFrZVllRWVUZXdnTGNXZEdjOWJVZkdiemd0ZE9lZWJoZTlmSGdZZ0ZocGNJY1RjVWNjY1JiZGEzZHRkYWZGYVdkSWQ3ZlVjV2hwYVhjU2Z3YlpmZ2JhYUJlb2V5YVpiaGNSYW1kWmhtZkZjd2ZWZ1dhOWFhZ1JkeGgwZWRiVmJWZ0phMmRQY2pmUWhuY0NiQ2d3ZUNkUWNSZmRlVWRaZmtmeGgzZWFlMWRJZVdoVGhDaGdhemJYaFFmMGZZZ0ljZ2dzZHdoTWh5aGtiU2NIY1FhVWRQYkhleWJkZzRkVGhYZ0ZjUWdhZVZlZGdaYUVlQmZsZG9oQ2gwYVZhdmVFZ1JjTmV2YVJkM2dNZFRmUmd6ZndhVmRBYVJkNGVVZVJlQ2NjZjhlRmhWYUFibGhOZ0ZiRWJXZEJjUmVoZVhiTWFBYk5nRGRYZGliQmFSaE5mR2NaZG5oZGNuZTljdmdXZWthY2VkZkhmVmRWYlNiZGJHZ3RnNmhZYTBhMWZxZFNnd2U5ZVNmR2RHYndnRmZkZm1hdGNTZ1Fnd2ZWYnhoZWNoZUpjRGdUZkVjTmRFaFlkamh3YzFkSmMwZWdoMmZBYkJiUWVoZFliQ2FvZGxiS2JDYmdhT2RVaFVmUWRRYVloUWJKZWVnUmRSZEVjVGRiZDBiZGd6YUVjMGRkaG9kRmhVZWhlUWRSaDBhWWVuY0llRmdaYmRmYWZtYzljUmdaZjFhdGVnZEZkbWhsYmhjRmZoYWhjbWFGYkdhWmRtYVloWGdCZFZoYmMxY29nU2NIZ1FjQmRWaEJnbmRvYW5oUGF5ZzBnS2RQZmdjTWJEZGVmQmdCZWtiVGNIZ1plMmdVZmtoSWdWZmViSGhZYVNnU2d4ZWhkRGNIZDJoSmV2ZmNoRGVoY0liU2VFZ2tlUGdiYWxiSmNMZmRlM2NwYXBoVmgxZ2tmUWZHY1dhZ2dMY1JkV2E5ZFllVmZXYzljUGhZaHhkTmhhYmRjUmhVYmRhV2NVZWRoQ2JJY3lmWWhEY1JheWJSYnljQmhUYThkZWJHaFFiMWJEZlloUmRZaFlmWmZoZlJibWNaZm1kRmV3aFZiV2E5ZGFkRGNsZ3NkZGFYZ1hoaGgwaGFnM2NwYWpmVGJXaHBjTGVEYTFjSWRRZlpkRWV4aDJlZGhsYXBnS2VRY1RkQWgvaFFmVWVWZU1lRGNBZzBiamFQZ2dhOGM4Y0RlUWMxY0phVWZXZ2hhNGdIYW5hNWEyYVFhMWFkZFpkRWZCZGxkb2FDZDBiVmh2ZkVmUmhOZXZmUmczZU1iVGdWZjJnZ2VJY1ZoVmZBYlRmV2dDZThnaGhXYUZnZ2J2ZFBod2VJZCtjRGZRaDhnV2JiZDJoY2M4ZUdhR2FZYVVlWmZtZVplaGZjZEZkVmh2ZFdma2JjY2RiSGFWaFZlU2VkYUdnTWZ1Yktld2NRYzVmUmVVZ0lhWGVYZ1Nkc2hlZ0xoM2JaZlBiUWZsZnBhNGNhaFJhSmJKZkdka2JOY0RjWWdqZ3Rmd2NiZDBiZ2ROZ0RnQWExZTFlRGhRZUlmNWdMZ25mRWMyZUNkMGRKZ1loTWZRZE5oV2JmZFJlZ2VUYWRkVWZjZTloVmNoYkJkb2dSYTBlQmdEYlZlUmVsZnZmZmVuZndnVmNhZ25mSmZSZWRnMWFkZEtkRmFtYmxhaGZGZGhhaGNtZUZjRGFJZnVoS2NDYk5lYmFJZmhnOGdLYVRhbGJRZ1BmRmUzaFJhZ2VlZGpoWmdOZGRna2VzZGNmUWNCYmxlT2VUZkhmWmYyZ1Vna2RJZ1ZiZWhIZ1lnU2ZTZHhiaGREZ1VnRWFoZ3loY2VIY0JnSWVRYjBibGdhaGRiWGFoZ0xkZGIzZ3BjcGNWZHdkdGRWZlRnVGQxYVpkQ2YyZzhhWmFPYVdiOWdIaGNmeGhOYUhiYWZCZVZmSWhVZEVhY2RRZlplbmRKZFdlRmNXZm9iOWRlZDNnZGFYZVNkaGRaYXBlWWNSZlliWWJaY2hiUmNtYlpibWdGaHdmVmRXZTlnYWJSZHdoSWdkY1hjUWNZZThjSWNpaGxidGdBYkNmOGZHZFFkQWRCZkpoWmRFZWRicmdkZmdjWmZMYVBhM2FoZTJnRWRraHNoWWFRZDFibGJpZGNlbmhCZndjU2RFZU5hSmhXZ25nVmE0YlNjMmIxYTZiSWdIZzFhWmRFaEJmbGFvYUNnMGJWZ3ZlRWNSYk5odmJSZjNkTWZUZFJiMmRnZVZlU2ZGZEJnWWJFZURmSWM2ZEhkMGZaZWtoUGJ4ZFFiNmFHZ0JoaGdQZlpnemhKY1RhVGNHZDVoQWZhZkRiVWIwZE1haGFRaDlhQ2VBZlpoRWJGZFVmVmNlZmRiRGg1aHpnYmIwaDBnK2ZBZTBmWWNCYUhlaWdrYkpnT2N5ZVViYmZHZkZhQmh4ZFhkQmdKY0xhR2VFY05hWmJZZW5mSmd3Z2NjRWNoY0RhU2ZWaHBoMWZlZ0VidGYzY2VjbmdOZ1hnRGFSZjVlYWRKaDFhc2VjZFpiMGNWYWJmSmRoZVJoOWRYZGdlSWJsYVdmaGZvZUpjU2R4ZEFkeWRPZWhlOWhHaFpnRGQ4YVVjT2FnY1FmRGVUY0NoeGJ0ZEZlZ2doZXFhRmVEYk5ldmJiaFZhcGFWaGJiMWFwZkhmSGNSYjFhVmJVaG5iUmdyZ2VlbWZOZE5lYWhrZnNmUGJXZmtiUWRzY0JoU2VWZjRnSGJ3ZGRjWWhLZXplOWRJZkRjaGZoZkliUmdHY0ljbmZlYVhieGZpZFFlMGJsZGFhZGFYY2hlTGVkZjNlcGZwZlZlMWNraFFlR2hXZWdiTGZSYVRhdGJaY1dkamN4YnRhY2d4Y05jSGVhZUJkVmhJZ1VlRWNjYVFlWmhuZEpoV2RGZ1dmcGI3ZlNkbGcxZVhnU2VoZVpicGZZYVJmWWRZZFplaGhSZ21lWmFtZUVhNWFFYzJoOWRTY0ViMWVWY1VnQmFsZndhNWFMZmpoY2h3Y0JkRGdBZU9mRGcwY3djUWRkaEVlVmUyYUxnWGZoY0NlRmJYZWhlMmhFaGthc2ZZZVFmMWJsZ2loY2RuZkJhd2NTaEFjeGFqZldlbmZWaDRmU2QzYWRoNmdhZVZhZGFaZ0VkQmdsYW9jQ2YwYlZndmdFYlFieGN2ZVRkeWdkZWJiRGdqZXNnYmhCaFJnVWdLYVhjemZRYXJlVmFoZDVhM2FjZmdnVmY1ZkJmQWJaZmZnS2NpZ1FoZWRDYUdob2RVZGRmWGdSY2hjZmhWY1VlN2NFZmdhNWFPZkVheGRnaFhkT2ZUZGdkemZPZFFiaGJqY1FjaWJWY1NiRWRHZFJiTWRkZW5mWmNTaFFmaGNWZjRmZGNoZkpmTGJHZUVlTmRaZGViSGJJZjVmV2RrZ2hnRGhTY1ZicGgxZ2VkRWd0ZjNlZWFtYmxmWGNXaFJlQWFaZmFnQWF0Y2FnYmgwY1ZhYmhKZ2hhUmE5ZFhhZ2FJZ2xmV2hoY29hSmFTZFVoTWNqaEphbGQ0YS9nYWduYkpkUmJkaDFhZGhLY0ZhbWJsZmhoRmVoYWhobWVGZEdhWmhtYlljWGhCZ1ZiYmMxZG9oVGFFZTBkNGhBYkVkRGVVYjVoS2hDY0llVWFZYWxkc2VEYlVmZ2NOZTJkVGJIYXRmMmFCZGdicGJjZktkM2ZoZ2ZhRGRsYVViUWRFYURmZ2QzY2VjWGF4ZmliUWUwZWxnYWhkZ1hoaGNMZ2RkM2NwZHBoVmQxaGtnUWRHZldmZ2VMaFJnV2g4ZlJoRWIyYzhnVGRPYTFnb2NVaFplbGRnaE5kSGdSYlJnWmJQYURnZGQ4YkZnV2dwZXlhVWJYZGRiWGRTZWhkWmVwZVliUmJZZlllWmRoaFJibWdaZ21nRmF3ZVhoRWJWZGFkUmh4YTBkZGFWZFZoSmYwYmFiM2hwY2poVGNXYXBiTGZEYTFhSWVRYWZha2Z3ZmlnZWVCZUViTmZSYlNiRmQrYlJkZ2JOaFJoRWNGYmNidmFOYXpoMGgvYkdnaGZwZUZjV2NpZUVld2hBaGljUmQwZEpiQmNJYVVkUWExaEFleWRUYmtkbGF2ZkFoUmg5aHZkVmJHZEVhVGNTZ21oaGFCYUFnQmZrZFViSGNpZXNjM2dHZjBlWWZqYktiQmJSZCtlVGZHYkFkV2dhaFdoRWhXZkdjR2ZZZFVnWmNtYVpmaGFjY0ZjVmN2aFdhaGdGY2NmVGExZlVjZWJkY0hjWmI2YmNlMWNaYkFoU2R3YzlmU2VFZ0dkUmNNZWRjbmdaZFNhUWNoZlZjNGFkYWhlSWVDZVhia2ZOZFJjTGZYZ3Rhd2hLZjJlSmdEZ1NlVmVwZTFiZWNFYXRjM2hlYm1kbGdYaFdiUmNBZFplYWVBZHRhRmNPZlZkQmVCY2Jkd2RSY29lT2hVZGRkb2ZGY1VjaGRRYVJoeGhCYW1jY2FsZFlkVmJhaG5mSmVSZWRkMWZkZ0NnVmVXZ2xnOGhGYmxkWmd1ZlBhbWFaY21hWWJYYkJiVmRiZzFocGJIZkhhUmMxZVZkVWNuZFJhcmFlZm1nTmNOYmFoa2hOZ2JhR2RsZWtnM2NRYmphc2V6Z0hhd2cxY0hnSWNYZmhkUmZBZTFka2hSZk9haWEwYjJkTmVSYUVlY2dTZHdlVmJhZ2ZhbmNoYWFkZmhuZHBmMWJTYTFna2NJYkVoR2JoaFhnYmgyYzhmUmdFYzJoOWNIY2NheGVOZUhoYWRCY1ZnSWVVYkViY2JRZlpobmVKaFdnRmNXZnBheWFCYlRkOGFlZUdjUmZnZmtoSmRGZXRjWGROZkVoMWhvZkpmU2hrYnhhQmV3ZHdiVmRBZTFkaGg4ZUFjVmZvYzRoWWVuZlpmSmJUZFdhcGZMZkRkMWVJY1FhWmZFZXhoMmVkZWxkSmZDYkZiWGZoZDJmRWNrZXNjWWNTaHdiMGRxYU9ieWNOZitlQmJRYVloRWVGaFNmY2FoZVJmVGhRaHljS2NBYlVhNmZYYTFlMGN0ZWFiaGZGYW5nWGZSZE5la2dSZjJoQWZhY1JhM2VRZkpoU2FFZGhkT2FFZkRkcGJZYVZlaGVWZnFnY2ZsZkZmM2JWZjBob2dXYmFmV2VFZFdjR2dHZVlmVWRaYW1kWmNoZ2NoRmVVaDdmRWRnYTVlT2FFZ3hoZ2VYYU9oU2JRZ29iT2JrY01hcGFBZTBoNGFBYmNmeWdzZUlmTWN4YWNnR2dTaGxlbGY0aGZmUmVKZFphRWdVaDllemdZYW5oSmh3YWNlRWNoZERiU2FWZ3BiMWRlZ0VodGIzZGVibWRsZ1hhV2ZSY0FnWmNZZ0ZlOGNOaEpia2FJY2RnSWJnZ0lmK2JYYkJmVWF4Ykdjd2RzZVlnQmZrYUloRmFQaFJmSmFRaENoeWdaYVplT2IxY2RoQmFGZG5meGRvZkZkZ2VSZjZoRmZIYjVodmNZYVNleGUvZWJmMWRwYkhmSGRSZjFnVmJVZ25mUmFyY2VibWJOZE5iYWhrYnNlUGRVYWhkQmhrZlRlSGdZZmlnR2ZnYXRhR2hkYmpldGNYZUJjbGJjYVJkQWRHZHdieGdPY0RjRWVhY0lmQWZZYWVlTWVCYmtnZmRmZHplWmhwY1hiRmdrZkVnRWZHYlFoaGhSaFdoOGZSaEVoMmQ5ZEhlY2V4Yk5mSGRhaEJnVmVJZVVlRWdjZ1FnWmVuZEpjV2FIZ1RiNGc2Y0djQ2FSaFphQmQxZk1ma2NMZGtiUmZCYWFnRmFjYnVhSmV6YU1jVGRHZ2lic2JmZ0pma2VrZ1ZnR2ZWYkpkL2JhZzJiMWFxZVRjWGRaY1hiRGQwaG9mWmdaYkJhQmVjZGRhbGJKY0NlRmJYaGhmMmhFZmthc2NZaFFhMWFsZmlnY2duZUJkd2FTZUVjTmRKZ1djbmVVZXNjQWd6YjRlcGVaaHhjb2FjY1hkVmhZZzZoVWhrYXNjc2VXZVZnSWU5ZUpkRGF4Y1hjQWZnYmxkQmZRZkJheGdIaEdlMmdaYmtkWGV6YTlmcWhjZmxmRmQzY1ZkMGNvYVdlYWFXYkVjV2dHZkdlWWFVZ1plbWRaYWhoZWhWY3hhamhjY0ViY2NkZUhjVmVWZlNiZGZHZXRkNmFZZzBjMWhxY1Nhd2g5ZVNoRWdHZFJmTWVkZ2lnSWdhYUNmMGFaaDJnSWdBZU5iRmhXZVFjY2NkY2FiamNGaCtjUGNSYjBnUGRIZlJhTWVsZk5nQmZKYS9iT2YyZEJoZWVWZTBmSmFXZ1BjRWVkYk5kZmRBZ0FiYWdZZFFib2FtZlhheGVNZGhoUmFRZFFkSmFUZTBnTmV2Y2ZkbmF3ZVZkYWNuYUpiUmFkaDFlZGFLZ0ZmbWJsZWhhRmNoZmhobWZGYkdjWmRtZ1loWGNCaGRhSWQxZ3BlTWJBZEJlMWhOaFdlM2FoZUJhZWhtaE5oTmdhY2tjc2NQYVVhaGNCYmtnVGdIaFpkMmVVYmtjSWZWZWVkSGZZYVNiUWQxZ3RjRGdSY0djSWU4ZmVmRmVwYUlhUWgwZGxkYWdkZFhiaGdMZmRkM2dwaHBoVmMxZmtkUWZHaFdiZ2RMaFJiV2U4aFJnRWIyYWNmVGdPaDFhb2ZVYVpobGFnYU5iSGFRZmhjQ2dQYTNod2dWaFhkU2ZzZGdmTWJqZWdnVGdEaDNnY2E5YWFiVmFvZlloYmRSYVJnM2diZDJjRmhzZ1NiV2c5ZkNkVGNoZTFiQmRmaDFiSmYwZ2FhM2RwZmplVGNXZ3BkTGJEZjFiSWJRZ1pjRWR4ZTJoZGVsZ0pnQ2RGYVhkaGgyZEVia2Z0Yk1iQ2F4Z0FjeGRmZkRoMGcxZ0JlUWJ3YmJoQWczZHNoN2hBYnpkWWVvYkNlaGZnYWRjVmdYYWdkOGNBZXdjbGFtaEhjVGNsZnZkUmQzZE1lVGZSZDJjZ2NWY1NkRmJCZkhnRWVHZVpmeWhWYWhlVmJxZmNjbGZGYTNnVmMwZ0poQ2RJaFNnaGJGaEZkaWJ0Y1JiS2h5ZmtiemFLZ1Znc2NzZEVkZ2haYVBoZmdoaG9kV2NNZFFnb2d1Y2Fhd2ZGZnFkUWdBYjloQmVHZ1djUmFRYmFibmRaZ0tnU2Z4ZlVoa2dYYkJiSmFMaEdlRWROYlpkWWduZ0pid2hjYUVlaGNEZ1NhVmRwZjFiZWFFaHRoM2NlaG1mbGNYaFdkUmhCYk5lSWJFZElnV2NZaFZmeGNXY0llZ2hnY2hkU2FraGtocmFYZ1Fha2VDZUpiRmY4Y2lhTmd6Z2RnQmhZZ2pjNWZSYmZoRmhkZ1lnSGMyY1ZoTGJGZ2hnaGVtZEZnR2VaZ21lWWJYZ0JiVmZiZTFncGVIYUhkUmYxZFZnVWhuZVJicmRlYW1jTmFGZFBnZ2JOZ0dnQWNSZjRlcGJDZ1Ric2Y1ZEFkQmJzYWJmT2Z6aDVoVGFHYVhnc2dNZUhiU2VjZVRlSmFIYWdnRWVRZjBnSmRhYVlmSGhGaExmYWMyY1plcGRUYjFiQWJRZVJlVWJJZkxjUmVXYThiUmNFYTJoOWRIZGNoeGJOaEhiYWVCZ1ZoSWZVaEVkY2ZRZlpmbmdKY1djRmhXZXBoeWRCYlRmOGdlZUdmUmdnZGtiSmRGZXRkWGNOZkVlMWJvZEpmU2ZrZXhiQmh3ZXdkVmZBZjFlaGI4YkFkVmNvZzRjYWIzY0ZiamJXYVdoTmFIaEpkVmhJY1FnWmdFYnhkMmJkZ2xlSmdDZkZlWGdoYTJiRWZrY3NkWWNRYzFkbGZpZ2NibmhCZHdjUWJCaGNkQmRFZ3ljWmgyZkJlamRJZDNiSmhnYVViQWZIZmxnb2RnYVNnaGRjZU1jWGFsZWNncWZKaGljY2JiZUNkMmZnZWViU2JFZGRoT2FFYkhicGJ1ZlZmZ2MxY2pmY2ZnZjFmZGFWYTBjb2NXZ2FlV2NFZVdoR2VHaFlnVWVaYm1jWmZoZGNkRmdWY3ZjV2FrZ2NhZGJIaFZjVmJTY2RiRGE4YnlmS2NoaDVka2dCZ2tmb2ZmZlhkemZZY1ZoZWdEY1VhYWFBaDBhY2diZU9oVmdZZ09mZWVSYmRjUmdMZW5mSmY3ZmNiRmc1Z0toWWUxYnBnMWdlYkVldGczYmVibWRsYVhlV2FSZkFlWmdhZEFidGhGY2JmeGRFZFRmYmUwYjVhNmRIaDJoMWNvZ0ZkVWhoYlFmUmJ4YkJmbWNjYmxmWWRWYWFnbmNKYVJmZGUxZmRiS2dGZW1ma2cxZFhmbGNFYTFmR2ZqZUJjMGRiYnpnRWVSZ0tnMWdJZEVmRWcxZ0FnQWFIZmljQWZpYktmaWc4ZlVhWWhnYm9iR2hXY3hmNGEyZEFmeWhJYjZiV2RsYUVlRWhjZ1hkaGdmaEhkbGdRYlhhRWREYUlnK2RLZlhjZ2ViZVNha2JWYXdlZGZYZGhoTGVkZzNjcGdwZFZjMWdrYVFnR2dXZmdoTGFSZFdkOGNSZkViMmI5Z0hlZWIxYzloSGdZZndmaGJJZFNoRWE0ZWNhVGhIZ0pkV2NGZFdocGN5YlVnWGhkYVhiU2RoYVpocGFZaFJiWWRZZlpjaGVSaG1nWmJtaGtjemVWZFhoSmNhY0NoUmhVYjNhVmFWZEpjMGFhYzNhcGZqZVRlV2hwY0xmRGcxYkllUWVaZkVleGYyYWRkbGRKYUNiRmJYYWhmK2JSaGdoTmdSYkVhRmVjZ3ZkTmZ6YzBhL2hHZmhocGhIaEdnVGgwZzVjR2RSY1FkMWNMZVJlSWE0ZFJhQmVFYmtkQ2gwaDVndmRBYkJncGJ2Z1doMmY4ZVRkWGYyZkVmVmZGZEhncGVIY0VlR2VaZ3loVmFoZ1ZjcWhjY2xlRmEzY1ZhMGFvYVdmYWVXZ0VoV2RHZUdnWWJVYVpmbWdaaGhlSmVCZjBmbWdDYlVmbGhRaFdkQmJnYWRjSmdqZ0piMGNJaEFiVWdyaEdhV2h3ZWRiVmVDZ0VjdGdJYm5hNGZlaFNjeGJsYVNkZGRoYkpmTGdHZUViTmZaZVlnbmVKYndnY2hFYWhjRGRTYlZocGYxZWVoRWJ0ZDNiZWJtZ2xiZmREY1ZhaGNRZU9jd2JVZkloS2dsZnhmY2JQZ1JlNWc5ZlVlQWc4ZXBjUmJ5Y3NlZmZBZTFoVWdIY0phbGQ1Z1piYWhuY2xhUmJaY0ZjNWRLY0NjbmFWY2hiRGhoZ0ZkbWVTY0VleGFtYllmWGdCZ1ZmYmUxZXBlSGdIZlJiMWZWZlVmbmJSZXJmZWVtYU5lTmJhaGtkc2NQZVVoaGFCY2tkR2NEYTRhL2FBZFVoeGJZZ1BmVGh0aGRnR2RVY0ZoTmJHZWlib2R6ZUllaGdNZkhoQmN3ZndjN2RJY1hkQWFIZWRhM2dGZXBhUmJWZkFlY2VNZjJnZ2ZMZlJnV2M4YlJhRWcyYzljSGVjaHhjTmVIZ2FhQmVWY0lmVWhFZGNhUWZaY25iSmFXZkhhVGQ0ZjZhR2ZDZVJlWmhCYjFhTWNraExha2VSZ0JkYWNGYWNodWdKYXpmTWVUY0dmaWZzaGZlSmNrZGtlVmZHZVZoSmYvYmFjMmY5ZXFnVGJYaFpiWGREYzBmb2NaZ1poQmdCaGNiZGdsaEphQ2FGZlhhaGIyZUVha2JzZllmUWMxYmxhaWdjYW5iQmZ3Z1NoRWhOZ0poV2RuZFZoNGNTZnliTWJ5Y0ljQWFSZ1hnWGZWaHdmbGdSYkJnY2QyY0hmMWJBaG5iQmJpYkZkd2JDZUNneGhRZ0tnUWZSY1BjWGFHYVphNWdWZmdhRmhqZ2ZibmR0ZDNkVmIwYm9jV2dhYldhRWFXaEdlR2NZZlVoWmJtaFphaGVjY0ZkVmV2ZFdma2JjZGRoSGNWaDBnR2dQYkNjSWZwaGJkUWNBYnZhQmZrZkFlQWFTY1dhb2NQZFBhamZjZEFkSWhWaG9hOGFNZzNlTWNmY0VlQWE5Y1poYWhYYkpobmJlZ1VjaGNmZlZiVmFwZ3RmY2NVY3NhcmdVZ0djbGZYYVdnUmJBaFpiYWhBY3RiRmRiZnhiRWVUZGJlMGhkaHplRWYwYWRib2ZGZ1VmaGZRYlJneGRBYnloT2NoZzljR2JaZkRnOGZVaE9jaGVnZllkVGQyaGNjaWZYYmxha2MwaGRjeWRrYmliSmNCaEVnQmJaZXhiWmdIaEZlaGgxaERlV2YxYjVjcmFlYW1jTmROYmFia2ZzaFBoVWdoYkJha2FUaEhiWmMyZFVna2ZJY1ZkZWhIY1lnYmdRY2hjUmRwYVdkV2JKYnloY2dIZEJiSWdRZjBhbGNhZmRiWGFoZExnZGczZXBlcGVWZjFia2NRYlRmU2ZCZUNhRmFtYkZlSGRBZ0djRWFHZU5nMWRkaFBoS2N4YXNoRmFCZlFmdGRFYUxleWNJZWFkVGRHZEliemRXZEhnNWJaZUdjRmFraDlhTGNSYjRoTGZkYnhjMWZvZUtiemdRZjhoQWZTZVljS2FDZjBlUWFWZ0JjbGV0ZTRoUWVYZHBkamFUZFdmcGhMYURiMWhJZ1FkWmJFYnhlMmZkYWxlSmdDaEZkWGFoZTJkRWZrY05iVWRRZTFnSmYvY2NmbWFoaDVkUmNHZmxiSmhXZW5nVmc0ZVNnM2dkZjZlYWZWZGRhWmJFZEJlbGVvZkNhMGdWaHZlRWVSZ05ibmFCaEhiTWdPZ1JkeWRZYmRkWWhsZEJjSGRFYkdiWmV5ZFZhaGhWZ3FhY2VsZUZlM2FWZTBnb2VXYmFoV2NFZ1doR2VHaFljVWJiZ2pjSWJwZU9hUWRaZ2hoRmd3YkpiUWFVY2djY2dMZGVjaWJnaHljSWRoZjhhSmJCZ0Vnc2VYYWNjVGhCZ0VnT2FuZFplWmFRaGdoUmV4ZWRjZ2E1Y1hjR2NGZXRkUWZZYmlhNWJhYmNhRWZoZ0RkU2hWZnBmMWFlYkVmdGQzYmVjbWdsZ1hjV2NSYUFjWmdhY0FjdGVGZmJheGdFY1RhYmJ4aE1iN2VXYmhoUmdtZVdmQWQwZGRlQ2dFY0lkL2RmZ0JmVmJkZUtkeWNBaHlkT2ZCaE1nUGdkZ3pnMWVwZ1diaGdGZnFjUGZtaFphbWhZZVhoQmdWZmJnMWVwZkhhSGFSYTFlVmVVZW5lUmhyaGVhbWVOZk5nYWhrYXNkUGhXY2thUWRzZEJmU2FWYjRhSGd3ZGRlWWdOYnlmUmFMZVJkVmVzY0xkR2JEY0FmUmdQZXplUWJOY0ljaGMxZFNiT2NYYmhoQWRkYTJmbGVnZVZkMGdVYk1oR2FYZkFjQ2NSZFRlTWY3aEVjMmg5YkhlY2F4aE5iSGNhYkJiVmJJYVVlRWNjZFFoWmJuZEplV2NGY1dkcGF5aFViWGJkZVhiU2NrYkljaGVLYUVkVWdXY0tnMWhFYXJjS2ZUY01lcGdXYnlnd2NTY0Joa2E5ZCtoR2RoY1loeGdDZ2ljNWdyYkFnV2hwZ0FjRGQwaEFnWmhhYkdiWmYyYWRjbGNKY0NkRmRYZGhmMmFFYWtlc2NZZ1FoMWJsYWlkY2VuZ0Jjd2NTY0VnTmdKZ1dhbmMwYnNmQWJ6YTRmcGNaYXhhb2hjZlhiVmhZZTZnVWNrZXNkc2ZXZFZiSWU5ZkplRGZ4Y1hnQWdnZWxoQmZRYUJleGdIY0dhMmVaZW5iWGd4aFZlMmRiY2xkRmV2aFhla2JwYUtiUWYyZ0VnV2NHY0dmWWRVZVpjbWVaYWhoY2VGZ1ZldmZXY2tnY2VkY0hiVmhWY1NkZGRHY3RhNmVZZzBkMGErZUFmMGdZZUJiSGZpZGthSmNPZHpia2ZBY0dleGZzZzdiUGVsZ01iWmVlYndjd2ZkYkpjeGFNZGtlZWZBYlJnRGhRYmxocGdoZGNiVWRkYmRjZWFtZGxjWGFXYVJkQWZaYWFhQWN0Z0ZkYmF4Z0ViVGZiZDBnZGh6Y0VoMGJkYm9jRmdVZGhlWWRFZzFoZ2V2YklmVmJoZ1lhTGh6aDhjZWRKY1FnNWdFaFZhU2RFYWdmUmRIYnNlcGJVYkNmTWJIYk5lWGhnZlplYmUxZkZiSGRDYmhoUmRWZFRibWhoZHJjWWNtYXBkTmJOY21mRWVQZFVnaGVCY2tlVGNIZVphMmRVaGtlSWNWZ2VoSGdZZFNmU2F4aGhlRGNXZldlSmR5ZGNkSGNCY0lmRmJ3ZkVkVGdKYW5oWWZHY01jamhjY21iQmRRZEFoZWRXYWlmQmRLZ0Zmd2Z4Z2VmVmR5ZG9obWFKYnhjc2hMYmFkQmU1ZUlkUmRrZDRiNmdaZW5lSmdXY0ZmV2FwZXlhVWFYYmRlWGJTYmhiWmFwYVliUmJZZFlmWmRoY1JjbWViaDJnaGE4Y2ZiMmI5ZGFmUmN4aDBiZGRWZVZmSmUwY2FiM2VwYmphVGNXZHBoTGJEZTFhSWhRZ1pmQmhnZStkUGV3Y0ZoTWNRYzJneGg0Y1Vmd2Y5Y2NlU2V4ZXBic2RQZ3liVWQ4YkhnQWVvaFpiRmJpYXhod2dDZW5mNWd6YVpid2hVaFdkUmNGZFZkZ2hHZEZnUmZtZUhmMWE0YzZoQ2V5aGRnYWVGZHlmUmJNaFFkQWFOYk9nQ2IwZ3hheWJWYWhmVmVxaGNnbGdGaDNlVmIwZ29kV2FhY1dlRWZXYkdmRGNzYVVlSWF5Y29heWJOZ1ZlVWYwZmNnRWZjZGRiSGRWYVZjU2RkZ0dmdGE2ZFlnMGIxZHFkU2Z3YzlmU2ZFYkdlUWNhZ05keWFSZlNiQWNRZjVlU2hkaGhnSmhMY0djRWROZ1piWWNuZUpjd2djYkVlaGZEaFNkVmVwZDFkZWJFZk1iMGhlaG5hUmFYYkZkeGZnZXpnYWdBaHRiRmZiYnhnRWJUZGJiMGNkY3poRWcwYWRjb2dGZFVmaGZRYlJleGdCYm1jZWZnaEpmZGZJZXloRmNmYk9kaGNJZkhnV2NUZnNlNGZiZVZnUmNtZ0hmMmNaZDNlSGNIZUJkSmFjaDFicGhmZkZiQmMwZEpiVWJpZEFkamVNY3plQmREZkpod2g1aENjSGRVY0lnOWFOaHpkb2VMZlhobWhnYlZiZWhIZVljU2JTYXhhaGREYVdmV2hKYnllY2NIZ0JkSWdRYzBjbGRhYWRiWGZoZ0RnSWJ6YUlnZ2RCaEZmZGJkZ1hkQ2hWZUVhRmJ6ZVpjcWdYZzJlOWZNZWNkd2RBYTZkYWFBY2xkVWRVYkZjOGRaZlpjaWY1ZldhUWVTYklnN2NBZG5ma2NhZERmMWZzZm1lTWQwaDlkamJLY2hiUmN0ZlphbmJNaE5iV2hVZ1ZnYWdSZXhiMGJkZ1ZmVmhKZTBhYWYzYXBkamFUYldmcGdMaERnMWZJZ1FhWmFFY3hlK2dJY2hlb2NMZ1JjbmZZZDdjVmN3ZlpnWGVFZFFjQWVaZFBjbmdCYjdjU2dGZ1lkMGFXaG1jbGFraFNiMmM5ZXpjYWdRZXRkWmdSZUZkRWVoZldnRWZzZWlnVmNGYzRmZ2RGY1NhcGVvaENoMmVnaGVlU2dFYVFmNmZIYkVkeGZ5YlZkaGRWZnFkY2RsYkZiM2FWYTBob2ZXZmFiV2hFYldjR2FHY1loVWFaZ21mWmZwZEpnQmcwZ21kQ2JVaGxoUWJXYUJkZ2NkYUpnamdJYkJhTGIwZjFhaGZTYnhhZ2V2Z0VjSGNoYVFlZGNtYzVnYmJRZ2tjbGE0Z0lmbGZvZkNoU2EwaDBhVWFKaHplOGUvZ0lkaGFFYjRnQmhWY3BkK2dlZ0ZmMGhLZ1VkR2RsY1hiV2hSaEFoWmdhZEFodGRGZGJoeGRFZFRmYmIwaGRoemFFZTBoZGJoY0hhRWNSYjZhUmJ4aEJkbWZjZ2xlWWdWaGFobmdKZFJlZGYxZWRmS2NGYW1obGVoZEZkaGRoYm1nUWZDYzRhdmNNaG5oNGhEY2ZibGhRZEdiV2RWaGxiZGZFZVhmb2FtYUxkeWc4YVpiSWN4YnRiRGVDZXhmZ2VsZlJlWGI5ZzRhQWZBZzFiQmFOY0hlNGNCZldjaGJGZ05hRmJEZGNkK2ZKZERha2FZY0RheGJCZVNmSmZuY0ZjSGZYaFhicGdwYlZmMWZrY1FoR2NXZWdlTGNSYVdlOGJSZEVoMmY5YUhhY2h4aE5iSGZhZEJoMGFFYlVoRWF3Zk5nWmZtYXBhZmhHYVVkQmh5ZlVkWGVkYVhnU2FoY1pocGhZZlJkWWFZYlpmaGhSZW1kWmhtYUZmd2FWaFdlOWRTZ0JjQmUwYUFjVmZSZnhkOGRRZFhlcGZqZ1RmV2hwYUxmRGExZUloUWFaaEVoeGYyaGRobGVKaENiRmVYZWhnMmhFZWtlc2VZY1Nnd2MwaHFoT2N5Zk5hK2RCZ1FoWWFFYkZkU2djZWhkTWFEYnRnNmFZYmxhZGNJZWJnUmdsYjBoRmMwY1ZmM2hHYUJmTWZ6ZlJneWRkZ2JoRGdqYXNiYmJCZlJnVWFLY1hoemhRY3JmTGRWZWthWGVmZG5hdGQzaFZlMGdvZldlYWFXZ0VlV2dHZUdjWWhVaFpibWVaYmhhY2dGYVZldmdXYmtmY2dkZUhoVmQwZUdnUGdDY0llcGFiY1FkQWd2ZkJoa2ZBaEFhU2ZSYThjQWhkZ25hMWhTZFViV2JoZDRmYWFnaDVlTGVBZkVmcGZaY1BkbmNJZGtmT2hBYkVnUWNSY3hmY2d3YU5lUWdRY2xiSWJ4Z0lhYmdXZVJic2ZaaGVhbmJaZEpmUmVSY0VhVGRiYjBlZGd6YUVnMGRkZm9hRmFVY2hoUWhSYnhjQmRtZ2NkbGJZY1ZlYWZuYUpiUmhmaHdnTWNDaFhoemRwY3ZjV2YxYjBjcmRXY3piUWYvZ0diamd4Z1ZhWmFGZ3BkU2NZZEJkMWZKZVRkbmhSYnpjY2cyY01iUmdhZWhoOWVIaEdiMGROZHFnQWVUaE1kN2ZIZFJlQmhNYUFkemRvZ1NlUWVCZ2hlWGRKYUdoNWhZYmNnSGRCaEliUWUwYmxlYWJkaFhoaGVMZ2RmM2dwZHBoVmgxZ2tnUWZHZldkZ2RMZVJkV2Y4ZVplUmd5ZGNkT2RJY0JjMGNLYkxmVmdnYUhmQWdoYjVjcmJLZm5hSmVkZkZoWGYwaFBkVWNXZ3RhTGNTY2dnNWJnY1lhVWRvZllnTWNsYXdidmhOYVdkOGc5Z0VjQ2FJYVZkRmVVZVJkbWRHYlZmSmYvYmFjMmh3aGVoWmgyZXBhTGNEYjFhSWNRYlpkRWR4ZzJnZGNsZEpkQ2dGYVhoaGUyYkVja2dzY1lkUWYxaEJlcmJmYmxmcGJ3ZFNiRWhOZUpmV2ZuZVZjNGZTZjNnZGY2ZWFiVmdkYVpmRWJCYmxhb2VDYjBlVWY3aFdnVmNvYzhhU2JTYVVoQmJTZ1NhbGFSaERoRmhnYUVnSGNpaHNjbmVHYWtmRWJqY0llaGIwYXVmWGJ3ZXNnZmhZYUdkOWRFZlZkemJKZVlkYmhuYVZmd2NlZlZlc2JpaERhd2V0Z0pjVmZBaFViZWVMZldmTWhwZWFla2FGZ0FjU2Z3ZTloU2NFZEdiUmFNZWRnbmRaZ1NmUWNoZ1ZnNGJkYWhoSmNMZEdlRWROY1phYWJqYzVhd2JlYzFiVmREZ1ViVmZOYzVlVWNraHRhM2hlZm1jbGFYZldlUmNBZ1pnYWZBY3RnRmViZXhjRWZUZGJmMGJkZnpmRWgwYzhhcmZGZFZmVmdRZUNoUmFoZk1nY2hsYllhVmJhY25mSmhSZ2RhMWFkY0tnRmNtYmxjaGhGYWhmaGhtZ0ZmR2NaYm1hWWRYZUJlZGdPZnhmSWdPZVRmaGhNaFliRmF6Ymtla2RLY0Rob2UyZEpha2VzZ0VnVWNnYUVkWmdUYUdjcGVxZFVibGJvY2NjZWRDZm9hU2FIYTFmQWNLZ0NobWZ3aC9lTmFUYzBmSGRFZlJnQWRoYk9nUWRWZUhiWGRYZXBocGhWZzFja2VRZ0diV2NnY0xoUmVXZDhoUmJFYzJiOWhIYWNmeGFOYUhhYWdCYlZjSWRXYkJhTmZZYkxheWFGaFloV2NDYzhmL2NIY2lkVWVPY01oVmFwY3BnYWZoYllhTGZHaHhmUmM2Y2VobWdGZm9oWGhHZjhhR2FSZDBjbGJWZkhiQWNGZjZiSmZqYzhidWhBZGpnZ2NTYmRoQmg0ZFFnYmgwZ3hia2VDZzFmNWJvZUZiWGdoaDJmRWVrY3NkWWVRYTFhbGZpaGNibmdCZndjU2dFZk5oSmRXZG5jVmU0YlNiM2hkYXliUGdSZjhmUWJRZHhmY2NsZ1RnZ2hnZ2djUWIwY29oVWhDaDNnTWNZZlJlM2UxZG9mU2VFY3hhYmdFYkhkNWM3Z1Zla2dsY3FnSmdoY2tkK2VCYkVlUmJiZkxnQ2V4ZVplU2dqZzljdmNLYm1nWmZxZGNlRWVFZlNhVmNtYjBnZGZIZ1ZjVmhTaGRiR2Z0ZTZlWWQwYjFmcWJTZndoOWJTZ0VkR2JSYU1iZGFuYVphU2dRYmhoMGhzZVBhbGhzZFlnRmNnYTRnY2hMYXpkMGdpYktmVGNNY1BhU2VWY0ZnMWRiZXpjWmUzZVpibmFWZ1hkUWhSZGtoWmhOZEFhc2NSaEpnMWdoZEFoWWFRZm9mMmZYYmdnZ2Q2ZlRnRGZNaGNjUmR4aHRmbWhaZUNnc2UvY2FibmJKZlJnZGIxaGRlS2ZGZ21kbGVoY0ZhaGNoYm1kRmhHYVpmbWFZYlhiQmhWZ1pibGdOZkxhTmJ4YTFlVmZVZG5kUmhyZmVlbWVOY05kYWVrZ3NoUGZVZWhnQmJrYVRkSGJaZTJlVWdoZ1poZGNNYVNlVWVjY0hlUWN0ZE5iR2NDZllnMmdlZERlTmdHYkRjaGZ3Y1dkSWNUZEVhYmdPZnljTmhoaEZlbGhBZ1pnRmF6ZXBiRWdFZlNhTWhaZkFmSGY1Zk9oZmZWYjRnU2dKZ0VmRWVCZEFjQWJ0YkpoYmJpaEZmZmNHY1ViQmZ5YVVlWGdkYlhmU2doaFplcGJZaFJhWWNZZ1pkaGZSZG1iWmNtY0Zhd2ZWY1dmOWFTYUNmeGYwZldlU2dGaEpmc2ZZZW5kWmRKZFRiV2RwZ0xoRGQxYUlkUWdaaEVieGcyaGRnbGFKZkNlRmZYYmhlMmdFZWtkc2ZZYlNneGZwYWloYmIzZUFjK2hRYkdobGJKaFdibmFWYTRoU2MzY2RnNmhhY1ZlZGdaY0VoQmRsaG9iQ2QwZlZodmFFZlJiTmZ2ZVJhM2R0ZUhlRGN5aEZoR2FSY2hmMGVDZVhjU2JrZmdkRGUyZTRkbWZjaGxncGczYlJoamhjYldmZGhYZzBiV2RBYkdhOGJVZE9hbWJZZDFhT2JCZ3dlOGdWY0FicGJZYlViQmhvY0FmTGFSYkFnMmFIZmtnRmJBZ1Nid2Y5aFNnRWVHZ1JkTWRkZm5iWmdTYlFnaGJWZTRkZGFoZEpoTGVHaEVhTmFaZVlibmdKYTRmSmNBY0FjS2FHYmxkUWI0aFBmUWVZYTRiS2hEZkFlc2hGY1JkQWNTZmFmQmJnZjRiYmR3ZTBmUGZiZjFiOWc2Y0VoeGZ0ZW9oUWJRZkFoWmZGZkJhNGVyZE5meGh0YWFjT2VDZXNocWhPZjFiZGNCZEZnbmVzZWNnR2VqZ0pjbWVGY0dlWmFtZFljWGVCZVZkYmcxaHBlSGFIYlJnMWFWaFVnbmdSYXJnZWhtYU5hTmZhYmtlTmhiZUdibGJrZzNoUWRqaHNnemNIYndhMWNIYkloUWUxYWVnU2F4aE5lRGRUZEJkOWJ5ZmJjR2d4ZklhV2IwYkJoYWdLYVhnZ2FmYlBhemJNYTZmV2NSY1JjVmRWYUNjZGZaYUhiQmJSaGRhRWUyZFJiSGdaZTJnNWJMZVFoaGdWZEljVWhFaGNoUWRaaG5iSmRXZ0ZnV2ZwZXllVWRYY2RhWGhTYWhhWmJwZ1loUmRZZVlnYmJraEFkdWRMYnpkSmYrZkdkQ2ZvZ1hiQ2JFZjlhRWZMYWhnNWIwaFlnSGRwYTBlTWRHZnBoWGNFZzFnSWdJaGJkVWF3YnFlZGdnY1lkS2hYYkNkdGI0ZVhod2Y1Z1ZiRGJBZHNnN2JDYlRneGJ3ZFFlMGROZmZjSmgxYzljNGRTZDNoZGQ2ZGFhVmZkYlphRWVCZ2xjb2RDaDBnVmF2ZkVkUmVOZHZiUmQzZ01nYWZUY21jUWMvYVNnRmRCZ0hkRWdHaFpneWRWZ2hjVmFxYmNnbGdGYzNlVmIwY29iV2FhYVdjRWZXZFRmQ2I1ZWRkTmJXY2diM2daZkZic2d1YkhlZ2hNYlZmWGFsZ3NoZmJJZlNmY2Z1ZUtkaGYwY21jRWhnZWNnVGVHZ1dnMWFDZEphRGRrZ0djRGFoYzFncmhaZXhhdGVGZVZoUmNZYVZiTmVqaHNnZ2ZQaEJlRmZMYkdhbGZOYXVhVWNrZXRkM2VlY21jbGdYZFdjUmdBYVpkYWNBYXRmRmdiZXhiRWZUZE1jbWgxaHpkRWIwZ2Rib2ZGY1VkaGRRZlJkeGhCZ21kY2JsZFlnVmNhaG5mb2VaZGRiMWJ4ZVhoRmduYnBlemFGZWhhVmNtZVFiQ2M0ZXZoTWduZjRhWWVLYWhmY2hVYVZnRWhjZlFhV2MzaGhhQmZlZm1oTmhOZmFja2ZzY1BkVWVoYUJka2NUZkhhWmgyZVVma2FJYlZmZWVIaDVnR2FBaDFmRWZRYVZjeWI4ZTNoUGdTaE1iQmJHaFFneGRhYmFlSGVoZGJiZmduZlpjRGNWZzFma2ZRYUdmV2hnZExiUmhXaDhjUmZFaDJjOWFIYmNmeGROZkhhYWVGZXBoSWNWZWtjRWFRaGJoaWhZZmVoWGREY2xoOGhIZERiSWVhYUJmVWRRYndjWWJRZHNnWWNaYkJiWmZ2ZWZlVWR0YXdlVmJXYTloYWZSYnhmMGJkZVZlVmJKYTBlYWQzZG9mK2FaYjJkcGdMZ0RnMWhJY1FmWmhFZXhiMmFkYWxlSmNDZkZiVGVFZndkRWRrYU5iZWdRYjFnUmZpZ1lhV2NKZ3djVmZsaDVlSmdFZG5oeGM0YUVlRmUxZDZjYWdWY2RoWmFFaEJkbGJvYUNiMGNWZ3ZkRWNSYk5kdmVSZHloVmdTY0ZjV2VoZEZhU2FFYTFkSGdWaG1jWmYvZVZkZ2VaYzRkYWZYYXRiM2JWZDBib2FXYmFhV2NFZVdjR2JHZVljVWRaaG1oWmVoY2NmQmFFZWdiV2VoZHdmM2JIYVZhVmhTZmRjR2F0ZzZiWWYwYzFlcWdTY3diOWdTZkVoR2ZSY01nZGhqYzhoVWZRZGhhMGgzZGZkeGNJZlFlTWdrYk5jWmNZYW5mSmd3YmNlRWFoZkRhU2hWZHBjMWZlZUVjdGIzaGVnbWVsYlhhV2NVYVplWWNPaGdic2RHYWRjRGNzZVRkYmUwZmRlemNFaDBnZGhvYkZnVWJoZFFmUmF4ZUJnbWZjZmxiWWZWaGFmbmZKZlpiTmdGYmRhWGZGYWllZGNwY1BkQmVoZm1iRmRHYVplbWdZZVhnQmJWY2JhMWdwYUhhSGhSZTFmVmhVYm5oUmJyZmVmbWZOYU5oWWVoZDhlQmhFY1ZjZ2dsZEhkaGZVZjVoRmFnZGRjMGJMZEhlNWFhZFNoeGROZ0RnU2hHZXRieWViZ0dneGZJZ1dlMGNCZWFiS2FYY2dkZmZlY1Rka2doYUZkZ2V0YXphVmJpYXhjT2FKZ0Rlc2RaaFdnMmNaYUxjV2RSZ05nSGNhZ0JoVmRJaFVhRWFjYVFoWmhuZUpmV2JGZldlcGJ5ZlVkWGZkZVhhU2VoZlpncGNhZ1VjSWZXZUphVmd3Ym5hTmRBZ0liL2ZFYVNlb2Q3YkVheGJWYlZiVmdWaGxhMGFlZUhnTmdqaFVnWGNaY0xmRmYxZ3NjUWRPZEVjd2JpZGVmQmJFaEtnVmRDZm9kVmRYZFFoOWhkYklkZ2MxZXFjT2VuaEJkN2FTYUZhRmRBaFZhbGQ5YjRoU2QzYmRjNmFhY1ZhZGVaaEVjQmFsY29kQ2EwZlZjdmFFZlJkTmF2ZFJhM2JNY1RkUmEyYkJhQmNSYmhmTWVQYVVnVGZRYlJlR2dWY0VhdmVFZHdoVmEvYUhlMGZvYWRiYWdYZlFlZmVHZUhkb2dJZVpmbmE1YW9iY2VBY2xidmJEYWtibGhlZVZnUmhRaEFkRmR5ZVFmK2JKYWlld2MrZVFiMGdkZVNlR2IyaFJhWWZmaDNhcGU0ZVFiaGZWZzRoZGRoYUplTGFHY0VoTmZaYVllbmVKYXdiY2dFaGhoRGhTZ1ZocGcxaGVoRWF0Yy9nTGRtZ2NnVWJFYVZmRmRMZENiMGZRZEJjS2RuaEJiSGNaZXdlOWd6aEdoRWNkYy9iSGhFYWhmTWFXZXhlQmMrY2VkMWVaZUpkYWVpY1poZmZOZEJhOGhMYVJkQWRvYnVhVWFsaDBjSGhRZEdmNGR1ZllmWGZ0ZFZkZWRWYU5mdGVIYlJhMWRWZFVmbmNSZnJlZWRtYk5kTmFhaGtnc2FQZ1VlaGdCYWtiVGhIYVpnMmdXZjBic2FaZFVkbmRZYlNjU2V4YWhkRGNXZldnSmF5ZWNlSGZCZklkUWYwaGxlYWdkYlhkaGNMYWRhM2FwYXBnQWV4YkZjWmJTY21lWmdkY1ZnR2ZGYVFkVmJ5Z3RlUGZNYUJhMGhLaFBnVmZrZWNjR2RSYmRmY2RQZjNjb2dYaEhoR2ZOYzhlQWJ6aGdlRGdCY2hmNWU2ZmNlQmI4ZldjS2MwY0VjcWFNZ2lnZ2VnYkdjVGdaYVNhRmdCZlFhUmdmZDFlSmgwYWFoM2dwZWpiVGJXZnBlTGREZjFoSWVRZFpoRWJ4YzJoZGdsYUpmQ2ZGYVhmaGIyY0djZ2hNZ1llU2FFYVJhaWVhYW5mbGU4YVlka2hOYUpnV2NuZVZmNGJTZjNlZGQ2YmFjVmdkaFphRWJCZmxjb2VDYjBoVmF2ZEVoUmdOZ3ZnVGd6aEFiVGhXZW1kaGRiY1FmSGZwY0hnRWRHY1pheWZWYWhnVmRxaGNkbGdGYTNmVmEwZ29jV2JhZ1doRWJXYkdkR2RZZFVmWmZtZlpiaGhlY0FjRmVoaEdlUWE5ZGNoVGJ6Y1lnZGdNaENhNGFiaE5iMGFVY2lnU2d3ZVJiU2VBYVdjMWVNY2FhbWZwZlNlV2hoYnhmNGRLYmhmSWdmYkZhZ2RBYVJlSWd5ZUFjVGNQZ3dod2dHY0thQWI1YTljTWNFZUpkN2FVZEdnbGNYZFdmUmFBZVpmYWZBZ3RhRmhiYnhnRWZUYWJjMGJkaHpjRWUwYmRnb2RGZ1VmaGhRYlJjeGhCaHVkSmFsYWhhV2RJYWplTWJEYkZnQmhnZk9mVWh3ZWdiMWhIZ2xhQmVtZ0hiMmNaZzFnYWFIaEJlSmdjZzFicGJmZ0ZiQmUwZEpjVWFpZkJmbGZPYlNhc2FNZU9iQ2ZoY0FlRmFsZ1VnRmVHZUhnNGUrZ1Vha2drZFZnYWduZzhnZWVZY1JhaGdEZFdkV2RKZHlhY2hIZ0JoSWhRaDBhbGZhY2RjWGhoaExlZGgzZnBncGVWYzFia2VRZEdlV2RnZERkRWhXZ0ZmU2hXZnlnNGZWZEVhRmF3Y0RiTGZYY1FjY2NXZUFiOGNRZmJnWGZKZERnSGRHZnBndWNUaFhlZGVQZFFmeGFZYTFjWWFVZUliV2JKaFZkd2huYk5oQWVJZC9jRWNTZG9lN2VFaHhmVmVWZlZkVmFsYjBhZmQzYk5odmFaYTJhcGdMYkRnMWFJaFFjWmhFYXhkMmJkZWxjSmFDYUZlWGJoZDJhRWhraHNlWWhRZDFnbGdpZmNobmNCYzRkSGNFaDBlS2VFaGpjUWZxZ0tjRGVnZStiTGREaFlhTmdHaEZiRmVvY0FhRWRWYTRnR2NCZ05oemFXZzNnTWNMZ1RjbWNoZUpkU2ZBYVJiSmVVZ3lkNGh6aEJjSGFZY2xmTmRoZFFhV2RBaDBkSmFlZGFjV2RvYldiRGhtYThjK2JaZ21jWmVoZGNkRmNWYXZnV2JraGNnZGRIaFZhVmRTZ2RjR2F0ZTZmWWIwZTFlcWdTZXdmOWJiYkdkV2hoZG1iZGNuY1plU2FRZWhnVmc0Y2RjaGZKaExnR2RFY05oWmZZZG5lSmd3aGNmRWJoZURoU2JWY29haGFNZEFkSWFrY2RhRGg5ZUZmVmExYUZlZGFMZkFlTWhHZFliVmF4YkdiSWd4Yk1jNmVRaHdkc2d4Z0hhUWVsY1pjVGNoaDRhMGNQZlFhSmZaaFlmbWhGZEFnZmFsYmtnSGRRYXlmVWYxZlhoMGNnYnFhVGJXYzRoMWVhZkhleGQvaGJlMWZwaEhoSGNSYTFkVmhVZW5oUmZyYWVmbWVOZ05kYWFraHNhUGdVY2hhQmJrZFRjSGhaZStmR2drZklnZWVaYVhhWWJLY1FmaGFSYnBoV2RXY0pleWdjYUhmQmFJZVFmMGJsYWFmZGdYZmhoTGdkaDNlcGdwaFZmMWFrYlFhR2dXYWdhRGNCYW1jOGFNZEVkeWJGZVBkV2hSYU5jSGJhZ0JlVmZJaFVmRWdjYlFjWmZuZUplV2JGYVdkcGd5ZFVlWGJkZlhnU2RoZFpkcGNZYlJkWWNRaE1naGZvZ2xjTGdpZUFkaWdOYmliQWJlY0FkbmV4YkpkWGdSZ3BjMGNZY0hicGV5YVJhR2hwZ1hjRWcxZEliSWhiYlVld2dxY2RoZ2JaZ01kVmdqZUFiM2NRaENiaGRYZEJleGV3YkRjSmduZmdmNGFRYVVmOWhqZVdhbmFWaDRhU2MzZWRjNmNhY1ZhZGFaZUVjQmVsZG9iQ2EwaFZkdmVFaFJlTmh2Z1JlM2dNYlRiUmUyYUJlQmhSZmhmTWRQY1VhVGRRZVJkR2hWZkVjdmVFZndnVmIvYkhiMGRvZWRiYWdYZUlnZmJHZ0hnb2ZJZlpobmg1Zm9mY2ZBZmxndmFEZWtmbGJlYlZmUmRRY0FnRmF5ZFFjK2hKZGljd2IraFFoMGRkZVNoR2UyZlJnZWNmZjNhcGI0ZVFoaGFWYjRkZGFoZUpkTGZHZEViTmVaZllobmRKZXdiY2NFZmhlRGNTYVZicGMxYWVlRWJ0ZzNkZWVtYUVnRGJWZDFkTmJSYkthVmRrYm1jSWNGaFZnV2REY2hkTmg3aFdkMGNkYmpjRmdWZjFnWmdSZ3dleGQ2aGNja2Q0YWNmYWNpYjVoUmNJYjFma2VKaFhkaWhnZ3piZGFWZWNmaWdVYlFhY2N5YmFiVGJoZFZoWmFGZXBlVGRGZkJoRmEvZVVnbmhSYnJjZWhtYU5nTmZhYWtlc2FQYlVhaGdCZ2tkVGhIZFpnMmNVaGtlSWdWaGViSGFZYVNkU2F4aEFhWGRWYnlmRWc2Z01nU2hJYnJkRGNBZjBmZmFGaENoeGdEY1BiM2hwY2ljVmYwYzRkWmNHZVhjUWdYYVJkWGdjZ1lmRWR6ZU5lSGNKZ3hnMGNFZklnRmhRYmFnTWF3YWhiVWZJZ3hkTWRDZ0hkU2hKZnliV2RuZGRmQmVRZnpmeGNwaFlnUmNZZllhWmFoaFJkbWNaZG1nRmh3YlZiV2U5ZWFiUmh4ZTBjZGZWYVZkSmQwZ2FlM2hOZnFkUWFVZ0JoTGFEYTFkSWNRZVplRWd4ZTJhZGNsYUpjQ2JGYlhiaGEyYkVna2hzY1lhUWIxZWxiaWNjY2lkUWY0Z0FiUmVCYkhjRGRHZVphMmhDZGpmTWErYVllUmNSY1hlWGNVZHdla2JYY3dkd2cvZVhhVWVwaG5hQmduaG9nYWVTYlRncGFhZEhnQmN4Z1BiQWYzaGRlN2JXaEZmZ2IvZVBkZ2NVaCtkQmF3ZlpkUGhZZlRoSWhmZ0ZnRWJ3ZVVnWmdtYVplaGVjYkZiVmZ2ZFdoa2hjYWRmSGNWZ1ZkU2dkZ0dodGg2YlllMGQxZXFlU2d3ZmNlYWJFZ0dlOWFSYWRnbWE1ZmJnVGJqYTlhNGNkZWhkSmVMYkdkRWdOZ1poWWZuZkpkd2JjZ0ViaGNEZFNoVmVwYzFnZWdFZHRkM2JlY21kRWNVaFdhUWYwYVpiSmhnYk5odmViYXhkRWdUYWJiMGVkZnpkRWQwY2Rhb2dGaFVjaGVRYlJneGJCYm1oY2hsZ1llVmRhY25mSmhSZWRoMWQ4YmVjR2VDY29kcGhWaDBhb2JGZ1dleWZJaGpoQWJDZlJmZGVKZDFmcGhNY0hjUWN4Z2NnVWJtYWhlM2VlY25hdGRFZGFjaGZjZlBjQmNoZTRnbmJCZ0RhY2RrZU1kUWUxYlJlUGJSZ2RhR2NRYjFhQmRLZlZjVWdoY3liY2VIZ0JoSWZRaDBobGhhZWRhWGZoZ0xoZGczYXBhcGdWYTFha2ZRaEdkV2hnZ0xkUmVXZzhiUmZHZXpndGdKZE1kRmhzZ0diT2FuaFlnSGVGZUFnSmF4Y01jbmNvY2VhRmJXZ0ZmeWdRZW5mNWdYYVZjZ2NwZnBkZWhSaDhoWWNPZWhlUWN5YmFnQ2NJZzRoRmREaDBiNWJDY0ZmbGZZaE5jQWJaZjhnSWMzYnBhb2hUZlhiaGFDZEFlM2FnYVFnWmNFZHhlMmVkY2xmSmdDZ0ZnWGFoYTJkRWNrZ3NmWWFRZTFhbGZpY2NibmZCY3dmU2FFYU5jSmhVZWljRmgyaENlRGE4YzdjT2V6Y1FkV2JWZUZod2FKYVhjMGQwZW5lRWRSZmhidmhVYW5mb2ZUZVdiM2ZRZ1ZlVWRGYmxoSGdUZ0doWWFtZldnRmJZYWlmTWJ3Y01mVWhHYUFhNWRUYkNkRGZVY2ViVWFHZllnZmFaYm5mSmJvY2ZjSGc5ZXZiV2ZraGNlZGRIZFZmVmZTaGRoR2h0ZjZjWWMwZTFncWJTYXdoOWhTZUVjR2RSZk1mZGduZFpnU2NTYWthRmMyZU5lVmJvZ0tlU2FpaEFnV2NKZ2phY2FSZkpnRWZBZUxnU2dWZUZlMWJiZTBmSmMzZVpmbmhWYlhjUWRSY2thWmhOY0Flc2dSZ1lnVmZKYWJhTGNoY1ViUWFYZEFkTWd0aGRnQmR4YllhRGh4Z0JndGdjZmtoQWZjZFFlSGdKYVJhZGcxY2RkS2hGZm1jbGVoYkZkaGNoYW1kRmRHZ1pobWJZYlhmQmNWaGJjMWVwZkhmRmJCaFJoWmJlZ0hkUmJyY2VjbWdOZU5mYWVrYnNkUGJVaGhlQmdrZlRnSGVaZDJiVWVraEllVmJlYUhhWWJTY0hiMWRBYUtoQ2FtZndna2VaZ0hjNGhKaEJid2gxY1NmTmduYVloR2NJYmphWWM5Y0hhZ2dsYWNkUWdHZkJmS2ZUZEdnWWRmZVFjU2JBZFRmUGZ4ZnRnVWdlZFJleGNHYUhnUmhKZmNmTWhqY3NoR2ZXYlRhTmU2ZUFhbmI1Zk1lWWZCZlpkcGVZZFJoWWhZZ1plaGFSZW1hWmRtZEZnd2VWY1dlOWhhYVJheGYxY0FnVmdSY2NiNGJPYURoOWdqaEZla2NCZUxoRGMxZ0lmUWNaZkVjeGMyY2RlbGdKaENkRmRYZGhhMmVFYWtjc2RZaFFlMWFrYjBlTWN5ZEpjd2hDYTFiaGhqZVdnbmNWYzRjU2YzZGRhNmZhZVZlZGJaYUVoQmRsaG9nQ2IwZFZmdmJFZlJlTmh2Y1RnemJBYlRkV2htZmhlYmhRZEhmcGJIZUViR2FaZnlmVmhoZ1ZmcWZjY2xkRmYzYlZlMGNvYldiYWVXYUVnV2JHZ0dhWWNVYlplbWI0ZTFmQ2N4YjFkdmFVYlVoY2JNZVlkRmhWY09kYWFHY3RkaWJhY2toMGgyYlNmMWRzYnBlV2hCZmxjQWVYZkhoWmdTYlFoaGVWZDRkZGdoZkplTGNHY0VjTmFaZ1lnbmNKaHdmY2ZFYWhiRGRTYVZmcGYxaGNjQmY4Y01jTWJtZmxnY2JXaFFhTmhrYmFiQmJkYlpmYmd3aGthYWJiaHhmdGN6Z1JiemF3Y2dlRmNVZU5mUWNWZldiMWdxYVdoRmdZZlZkYWVuZEplUmVkZzFmZGFLaEZibWJsY2hnRmhoaGhnbWJGZEdkWmdtZFlmWGhCZFZiWmF3YzRhOGRWZFJiMWRlZVVhbWdFZFdhZWhuYTlhUmFhY2xoTWVHYlVoa2Z4aGtiR2NBZDBiK2hVZGtja2dWZWJmQWdzZWVkWWRSaGhjRGZXZVdoSmd5ZGNiSGRCZklhUWYwZGxmYWhkZVhkaGVMZmRmM2hwaHBnVmYxZWtoUWFFYlRjeGJ3Z0RiV2Q4aGFhRWEzY2djNmJjZ3dmOWZiZWFkQWQxZEJoVWRCZXNoUWNNZGdia2hlZEZoV2dGaHlkUmF3aHBmOWhTZGhiWmVwZFloUmNZY1lhWmhoYVJibWJaZ21hRmR3aFZiV2I5ZmFiUmV4ZzBhZGhYaEZmdGg0Y1FjWGNwYmpnVGVXYnBoTGFEYTFlSWJRZFpkRWR4ZjJmZGVsYkpkQ2FGYVhnaGUyZUVla2hzYlljRmN4ZEVkcmNJZ1hjNGFtY1dhVWEwZElnSGZqYUZmd2FDYkhoa2IzZFBoQmRzY05lV2NVY2tma2NVaGtjMGd1ZkdhQmhwZWhhRmRUZnhoSGNDZjJhQWVHaFdnVmZsYUpiWGJUZ01lK2JBaGxnd2c2Y1BmZ2VoYi9kQmRFY01iYWNRZzJiRWFXaEdiR2hZZlVmWmZtYlpnaGVjZUZmVmh2ZFdia2djaGRmSGhWYVZjU2RkZkdhdGg2YWFmd2ZWZXFkUWhCZUpnU2JDYUdlMWdBZlhoSGFaY1NjUWZoYVZnNGZkZGhlSmdMZEdiRWFOaFphWWRuYUphd2NjZUVlaGREZ1NmVmZwZDFnY2JBZWhjM2daaDJla2VaY1VmVGRvZ1poYWRBZ3RkRmFiZ3hiRWNUY2JmMGdkYnpnRWEwZ2Rob2RGZ1VoaGRRaFJleGdCaG1mY2RsZ1llVmFZZGlkWWFxZlBmMWNkZkJiRmZuZ2dmY2dGY2dmUmQ2ZUZhSGc1aHZjWWdTYXhnVmhPYXlnRWNQY1lkQmRGYS9nVWVuZlJocmFlaG1nTmJOYWFma2ZzaFBjVWdoaEJia2hUY0hnWmEyYVVja2ZJYVZhZWZIY1lnU2VTZnhoQWRYZkllaWdwYXlmZWUzZUJnYmZQYWtkbGVHZGFmWGRoYVRiZmZuYm9kMWRWYndmMWZyaFVoV2FnZUFhUmVYYzFkc2hIYTBiVmJIYWNoeGFOYkhnYWVCZ1ZhSWhVaEVhY2VRZlplbmNKY1dnRmJXZnBoeWRVZFhlZGFYYlNhaGhaYnBiYWRVaEpjamVMY2hnUmJ0ZlpjbmJRaE5mVmNYYk5mR2hSY3djVWFVY1ZoUWg1ZDBnUGJ3aEVjcmJUYldnRmdMZkdoeWU4Y2NmVGVrZXhiMmFkZGxmSmhDZUZkWGNoYTJnRWVrZXNjWWVRaDFhbGVpZGNmbmRCZHdiU2ZFYU5mSmZXY25lVmd3Ykhmd2Z3ZXloYWJWYnhlWmRCYjJiUmVvZkZoMWJsaHZkQ2JSY3BidmVHYTNiTmNIY1BoQ2JBZlZiUWYxYkJkUmdiaFVjeGR5Y1ZjaGRWY3FoY2VsYUZkM2hWZjBib2FXZmFhV2hFZ1dlR2RHZ1lmVWJaYW1nWmJoaGNkRmF4Y21lVmdtZTBjZGZIZ1ZlVmZTZGRmR2h0ZjZnWWcwZzFhcWdTY3diOWVTZEViR2RSZE1nZGhuZFpnU2dRZWthRWh3Z1BiMGdGaEZoVGRsZUZlWGNJYnpkWWcwaGVjQWF0Yk5kQmZBZDhlNWNMZ0FmSWJuY05iamJCZWZmR2hCZWtjUWhaZGxia2VLZ09oMWMwYmJiZmJGZFpnNmJIYVFkb2I5ZVdmUmR3ZFpkRmYxZ3doL2dlZWdmVWJjZFpjbGZoYVJkZGUxZWRkS2hGZ21lbGRoYkZnaGdoaG1iRmdHYVplbWVZY1hiQmVWZmJkMWFwaEhlSGFSZFVlZGJVZm5iOWEyZWVnbmd0YkVhWmdtYkVjUGRVY2hjQmNrYlRoSGNaZTJhVWFrYklnVmJlZUhkWWFTZVNieGZoZURjV2RXZEpkeWNjZkhnZ2JMY1FnMWdSZ2FhT2gzYUJoaGdkZDNkcGZwYlZhMWhrY1FhR2VXZGdoTGVSY1dkOGZSZkVhMmI5ZUhkY2N4ZE5iSGZhY0JhVmRJZlVnRWQ5Y0VnSGRUaHBiV2RIYm1lcGVqY0xmSGZkYkxhVmVoZlpoeGJhYUJmWmRFaFpla2JBZWRiTGRoZXhjOGVmZjJoOWdhZlJheGMwZWRlVmRWZEplMGhhYTNlcGNqZFRmV2NwaExmRGcxZklhUWNaZUVneGYyZmRnbGFKYUtlUWVRZ01lK2JFZmtmQWRZZlVkQ2hSZWljYmVtZHhld2ZVaEVjcGdKZEJlbmNVYnNlTWJEZzloNmhZZmxhZGhMZGJnUmNWZENlQ2YwZFZldmdFYlJhTmh2YVJhM2RNZFRiUmgyZGdlVmRTaEZnQmhIaEVhR2FaYXlhVmFoYlZkcWFjZmxka2ZqZUxoQWZJYVdlWWZtYUVkRGZaZ1dkWWhJZ2VibWFaZjVhZWRWZ1VoemJXZGhkTmFtY1ZjVmVWaFphZGJIZThmSGViZjJlZGJxaFNld2Q5ZlNkRWJHYlJkTWZkZm5kWmVTZ1FjaGZWYTRnZGRoYUpjTGRHYUVnTmZaZllhbmZKZndmZWVCY3dkNGJBaFZhcGgraGViRmV3Z0tnZWVuY1ZiTGhXYlFoZ2RRZmFlRmRkYkZjT2QyYnBlYmFiYjBkeGN6Y0JkVGdwZ0NiRmhVYWhlUWFSZnhoQmhtaGNjbGZZYlZnYWRuZ0piUmdkYTFjZGhLZkZmbWNsZGhhRmNoY2hmdmdIY1dhcGRNZllhWGFCY1ZnYmcxZnBmSGRIaFJmMWFWYVVobmFSZnJmZWJtZ05kTmRhYWtmc2RQYVVnaGhBYndiQmVEZjhibGhYYkJlUWhHYWRjamNkY1dkRGV4YUFkQWhWZHlmOGFuZ1BkQ2ZRZUJjRWJ3YlVkRGNmYlRlbGhDZWZmbmJRZjdjR2hBYzFoY2JFY1hlc2dhYVRjR2hGZ2NiUmhpZ01lVGdPY2tlTWFMYk1lUmMwYmJmV2RVZnNhNmZaYW5nSmdXZkZoV2ZwZXljVWhYY2RjWGVTaGhlWmVwZ1lmUmJZaFljWmZoY1JobWhaZ21jRmU0YkhlV2g5YlJjV2doZTBnRmFYZ0ZlNWhlYWFjM2dwYWplVGZXZHBjTGhEYTFmSWRRYlpkRWR4ZTJmZGFsZEpjQ2NGYlhiaGQyYUVha2ZzZFFmQWdGY2xoL2RjZ2pmNWM0ZVlka2dOYUphV2huY1ZoNGhTZDNnZGI2YWFkVmhkZ1plRWJCYmxnb2RDZDBiVmF2ZkVjUmVOZnZkUmgzZU1hYmdFZHhjTmJkZVNlRmh0Z0hnQWdSY3RleWZTYmdmbGFxYWFmbGRoZDNiQ2MwZnBhQ2NFZWljbGNyZkZiRWR3Y1VjWmRtY1pkaGNjYUZmVmN2Z1dma2djZWRlSGdWZ1ZiU2ZkYUdndGQ2ZFlnMGQxZXFlU2F3ZzlmU2FHY0RlQWczZFBobmFaYVpiUWRnZVlhRmVkYmdnNWVYaEdjRmd0aFFiWWFpZzVld2RKZ0RlTWdMZ1NlVmdGaDFiYWhqYlphN2ZVZEdnbGJYYVdiUmdBZFpjYWhBYXRoRmJiYXhlRWFUZWJnMGhkZXplRWgwY2Rjb2VGZ1ViaGNRY1JneGZCYnVnSmVpYTFhZGVhZG5hbGRSZFlhaWZwZEtoQ2VuYVZjaGZEZGhmRmJtYlNiR2ZZYnlkR2FqaGhlVmZaYkZicGZUZllmQmFGZS9lVWJuZFJmcmdlYW1kTmROZmFka2VzY1BlVWVoYkJma2JUZEhlWmYyYVVna2ZJYlZjZWVIZ1loU2hTYnhnQWJYZUlnaWRwY3lnZWMzZEJnZmNQZmtobGRHZmFjWGFoYVRoZmFuZm9jMWdWZHdoMWZyZ1VjV2ZnZEFlUmVYZGxoc2RPY1diOWNIZWNieGROY0hlYWRCZFZmSWVVZ0VnY2dRZ1phbmdKaFdlRmNXY3BheWZVYVhnZGRYZVFleGU5YmxjU2F4Z1lmWWdaYWhkUmdtZFpjbWFGZHdkVmNXZTloYWFSYXhoMGZkZVZkVmRKZTBjYWQzZnBmamZHZFNlSWNDYVhiRmN4Z0doY2dFYUljM2ZNY2hiWmZLZ1ZhbmFZYTdhUmd3YmRjTWVDZWdma2N1ZEtjM2RnYnhhUWVVYnBhSGRDaERmb2RzZ0JjM2U5ZHBnZWhGYjVjWGhYYlVkd2VrZlhjd2R3Zy9iWGhVYnBobmZGaEhkb2JJZWJnV2ZnZVZkU2RGZUJoSGVFaEdmWmZ5Y1ZlaGRWZHFiY2JsZEZhM2JWYTBocGFMYVFmMmNFYVdoR2hHaFllVWFaY21oWmFoYWNoRmFWZHZmV2JraGNnZGdIYlZnVWRhYmRiR2RCZW5nWWIxZFZoeGJZY1FhOWZTZ0VoR2hSaE1jZGFuYlpiU2ZRZmhiVmg0aGRlaGFKY0xjUmZVY01hT2VLaGplc2M4Y05iVWNoZkxkR2FWYXBncmZaYVVoc2UvYmNnM2ZKZDlnV2FSY0FmWmNhZUFldGFGYWJleGhFZFRiYmUwaGRkemNUZ21oMWNvZkZmVWNoY1FjUmV4aEJobWhjZWxmWWNWaGFkbmFJZERiTWFnZ01jZmNSZUNmZGRoY0hhamFKYW1oRmRHaFpobWRZZFhmQmRWY2JkMWdwZUhlSGFSYjFjVmRVYmpnSmZyYlpmR2VNZEZoYWNrZDBlSmJlZUJhQmVraFRjSGZaZzJjVWRrY0lmVmZlZUhhWWNTZVNjeGJoY0RjV2ZXY0pkNmJQZzFjcGhJZlFiMGZsZ2FjZGRYZWhlTGNkZTNncGRwYVZnMWZrZ1FjR2dXaGdmTGdSZ1diOGNPY0VnMmVjaFRmT2IxYW9kVWRaY2xnZ2ZOYkhoUWdoZkNjUGIzY0plZGRDYkdlb2dtYVhoeWZRaGJnQWgxZlVic2NhZ1ZmNGZSZ2Jhemc1Z21hWmFtY0Zjd2hWYVdoOWhhYlJheGMwYWRkVmdWY0phMGdhZzNhcGdqZFRhV2FwY1JlRGN4aHNkNmVaZkVkeGEyZ2RhbGVKZUNlRmNYY2hiMmFFZGthc2JZYVFnMWVsaGlmY2NuZ0Jid2dWYzBmTWZkZUVkamJ3Z3JnUmhUaG9kL2RKaEJnZ2dMZlNnUmVjZzdoVGhoY0ZnbmNSZ1JoMGc4ZkVoamNGZ1NmRmNUZnBlVWhFYVZnZ2FQZEhiR2dZZTBkWGN4YmxmcWZKZmhka2UraEJhRWVSZWJmTGVDaHhkRmdVY1RjeGVSYmJjMGh4aGhjY2NGYVZhdmVXZGtjY2ZkZ0hhVmdWY1NkZGhHZ3RkNmRZZDBmMWJxZVNkd2I5ZUliRWJEZ0JhQ2FOZVRja2dDZ0djeGQwZXNnUGZsYXNiWWJGYmdjNGZjZkxnemUwZmlhS2VVYlJjRGRIZVJoSWI4YUtkMGRVZDZjUGF5ZVFmRWhFZEVkcGhjZlpnQWVzYk5hWWJ4ZkZnVmRaZGthdGhaZ0VmMGVkZm9iRmdVZGhoUWNSYnhiQmRtY2NlbGNZaFZkYWNuZ0pnUmdkYjFjOGhlYVhmaWJBaHliR2hGYlViamZXZFRlVWR2Z09kemNWZlZhY2VsZ29nQmJIZ1JlQmhWZUdjbmgxYmlnZGNrYWxnTmFhYmtic2ZQZlVjaGZCZ2tnVGRIZ1piMmJVY2tiSWFWZGVoQ2dKY2FiQWRraHRncGJXZFdjSmJ5ZGNjSGRCZUljUWcwaGxjYWNkZ1hmaGFMY2ZobWhGZ0RiVmgxZmtmUWJHZFdjZ2hMaFJnV2U4ZVJoRWJ6ZUplT2VmY3pjbGNIZmFkQmhWZElkVWNFaGNoUWdaaG5kSmFXZ0hnU2RWYThoQWNTY1VlWWdIaGxna2E5Yk9lRWZaZmRjYWVGZkFndmJJZ1NiUWNqY0FjV2Q5ZUhjUmExZnRmSWZHY3hiRWJnZ0liamVVaHRiVGFXZUpiQ2hEZndka2Q2ZlphRWd4YzJoZGVsZEpoQ2VGZ1hhaGQyZkVna2ZzYllnRmZSY2dhd2FjYWllUmQ4Y1lia2JOZUpmV2RuaFZnNGFTaDNiZGc2ZWFmVmNkZFpkRWhCZ2xnb2hXY1VibGJGYUVmUmROZXZlUmczZU1hVGhSaDJjZ2FWYVNhRmJCYkhlRWdHZFloN2VWZGdjaGJxaEpjaGhrYStnQmdFYlJoYmNMZENoeGZaYVNoamQ4ZlliVGhHZFplaGJjZEZiVmJ2ZFdia2VjYWRmSGFWZVZlU2JkZkdodGE2ZUpoa2ExZDNmU2J3ZzBhQmFSZkRnWWdGY09iRGJGZ1FmUWFnYmhlbGRkYWthWWRTZVNmQWVZZFdoSmVIaEloNWRmZEdiSmNEYlNkVmJwaDFmZWRFYXRnM2dlY21nbGNYYVdnUmNBZ1poYWhFYlJjRmFjZ2hkRWNEY1loMmcxaHplRWgwYmRhb2JGYVVkaGVRYVJkeGVCY21jY2VsYlloVmVhaGpjcGNSaGFjbGVjYmVnWGdpZUFheWVHZ0ZiVWdqZVdnVGRVZXZiT2Z6ZVZkWmdSZlZmcGNIYUhhUmcxZFZiVWRuZFJkcmhlZG1jTmJOYWFia2FzY1BkRWFSaEJnNWVUZkRhZ2R6YkJmVWFKYmJhY2ZIYThkSmZZYlJoaGREYldiV2RKYXliY2FIaEJmSWJRZjBnbGdhYmRoVGY0Y0ViSmhYZ3BmaGFmaFZha2hRZkdiV2NnZUxnUmVXZjhnUmVFZTJoOWVIYmNoeGNOYkhnUGNGZjBlQmJBZTBnbGVFZktlU2FZZlhmV2NSaFVkK2RGY0RibGFYZ1ZhQWh0aHBiY2JnZVFkeWZaaGhjUmRtZVpibWZGY3doVmNXZjllYWFSY3hiMGRkYVZmVmZKYjBkYWUyaFZhamJSaFdlSWZmY0RhMGQ4ZVFhTWZBY1FkL2ZKaFZhd2FVY0JiSGNZZDFoWGhnY1JlV2RCZGxjRmNyZ2ZnQ2ZJYy9nSGFBYjljQmFTaDNieGR4ZlJoMWExaDZnYWdWZGRmWmFFYUJkbGNvaENiMGdWY3ZjRWVSYU5mdmdSYzNmTWVUZ1JoMmFoYUJkUmVoY0VoRGdWZUdnNGVtYUhibGV3YzVlZmhBaGRibGJXYlFhbGJhZkplaWQ5ZVRhRWJHZThkYWZOYkNha2YxZFBiRmQxYjRnVWUwYjRnUmVOZTFkVmJTY2RmR2h0YzZhWWEwaDFmcWRTYXdkOWZTZ0VmR2RSZk1lZGVuZVphU2JRY2tnRmgyZU5oMWVZZVBlRWJCaGNnUmVLZnljRmIrZUpnbGZ0Y05nQ2VoZllnNmdOZmdmNWgvaGNlMmRjY0ZhRmRrZFJmVmdZY0JncGdYZVpiaGFnaGZhUmZVY2RkemRFZDBlZGRvZkZiVWFoaFFjUmZ4ZkJjbWdjZWxiWWRWZmFnbmZKYlJnZGJ3Zk5iRWZWZ3lmMGVsZkhha2Z3YXVkWGZUZFZhb2dOYTJoUmViY0xiQmdZYUloVWQxaGhnZGhXZDNnb2M1Y05mVGRjZkJkWWJsaG9mWGRXaHhibGZvaFpnbmRaYTJnVWRrYklhVmNlZEhoWWNTY1NmeGZoaERlV2NXaEpjeWdjYUhnQmNJZ1FkeGIxZVVmTGhUaGNnWmFmZXllNGVoY0hlZ2VvZmVkVGczY2tlRmhDZkRhcGRkZVJjeWhZZlhiUGEwYnBoUGFLZlJjeGVHZ0FiZ2NoZEVkS2JuZ3BmRmhCZ0dhTmE4ZUhoQ2NJZGJnSGdsYzhhNWRMaFVlOGdRY05jUmgxZHZhYWdrZnRod2RWZldhOWFhZVJjeGQwZWRmVmFWZUpiMGZhaDNkcGNqY1RlV2hwZUxhRGcxZ0pmRWFhZmdmRWFqY09nZ2hZZUxlUmZUZ1FkdmZHYmhnZ2hSZFRkUmhnZW1lTmZuYmdkMmFRZFVnOWdqaFdobmFWZTRnU2gzZ2RlNmFhZFZnZGNaYUViQmFsZG9iQ2YwY1ZldmRFYlJhTmR2aEVkM2IxYUxlQ2VEYm9mZGVIYkJoZ2ZPZlFkMmhnZmtoUmVCZHNhbmFKYXhjMGhqaEhnaGVwZWFnTWJHY2xhWGdFYldjaGFHZ0tiVGNJYXRhZWNFZ1pmK2hVZDBnbGJRaFNoQmZrZEdoUGdUY3NiMmhPY2toVWc1ZVFkZ2daY2VlT2JtZVJmTWdkYW5iWmNTZFFlaGZWYzRmZGRoYUplTGhHZkVoTmRaZFlhbmhKZndjY2RCZHhkTmFCZEFmOGU1Z0xlQWVJY25jTmRqaEJnZmVDaGhia2hYZ0tjVWg4YUJiWmIxaGNlYWVZYjJkMWZ6YUVnMGZkYm9nRmNVaGhmUWZSaHhoQmJtYmNlbGFZYVZmYWNuaEpoUmRkZTFiY2JlZEdjRGJFZXViUmdCYUFneWhYYkNiOGYxZ2JneWRaY0doWWJSZmNnU2NVYVVoa2NjY0FkamJnYnliY2NpZkpjRWZaYkJkbGhBY0JkbGN4YnNmWGMyaGRhL2ZYY0FkOWVBYU5kQ2ZKaGJiR2QxaFFkYWJVZlRjRmg3YWVkWGR4YWliUWUwaGxjYWVkZVhjaGNMYWRnM2FwZXBjVmgxYmtmUWFHZldiZ2hMZVJlV2U4ZFJlUmEyZkVlS2NKZWxmOGhUYUloVWJVaEVkQ2hVYTlkRGNiZjNld2hYaFVlU2c1ZjZkRmYzZDVlYmJZZ0JoWmNwZVljUmFZY1lkWmVoZ1JkbWVaYm1mRmV3YVZkV2c5YmFiUmh4ZzBoZGhWaFFkWmI2YU1lemdVZnhiUmdUYzRmRGNSY2dhRWJlYU1nbGRoYjRiT2d3ZGNkT2VRY1RnRWZtYlhhaGRJZlFiQWdsZkJic2JJZERoOGZrY0JmRWJ0Z2FlU2YzY3hmMmdCY2llSWMyYVBnUmg0aEpjWGJFYkJhZ2VXZ0VleGVtZUhjVGNsZ3ZjUmMzZk1jVGJSZzJmZ2dWYVNhRmhCY0hkRWNHYVpoeWJWYWhjVmdxZmNjbGFFZ2plV2JRaGRhRGNKZlRjVmdmYVNiQ2ZwZ05kYmFqZ1Zhb2ZmZGhmUWRyYkhla2U5ZmJnRmZGaHhhNGNkZEdndGI2ZFlmMGUxYnFnU2F3YjloU2ZFZkdoUmhNYmRmbmFaaFNlUWJnaDljNGJmZGtnWmFMY0JmVWVNZU5hS2FqYnNhamZmYmhoc2hHY0RhQmM1ZDdkT2V3YWNiNGJOZkNieGRmYVVnQmY1YVloTGVFYTllTmRJYXhiZ2FhYllhMmMxYnpmRWMwZmRkb2RGZ1VjaGNRZVJkeGJCZW1hY2NsY1lkVmdhYm5kSmJSYUlhMWFrYUxhVWVpZDFocGVWYVJnWWhnYVJoaWhrYXJjRGF5ZlVlWWJMYVJiOGZWZ0ZhVWZrYmRoR2J5ZWRkbGVMZWlid2JaYUtnd2RkYXdhSGdsYlVocWRSZFhoOWd0Y2VjRWRJYlZkZWJIaFllU2NTaHhkaGFEYldkV2VKZnloY2VIY0JlSWJDaDBjbGdYZ2RnV2NCaExoYWJXYWRkcGFHZ0ViSWc2ZE1jMmJnZkxkUmVXYzhjUmZFYjJmOWFIZGNheGNOZEhoYWFCY3hiaWhVZUVmY2ZRZVphbmdKY1dlRmRXYnBheWJVY1hnZGNYZlNiaGdZZnNhU2F4ZFljWWNaaGhmUmRtZlphbWdGYXdiVmdXZjlnYWRSaHhjMGJkYVZlVmZKY3JiYWd6Z2xodGVDZXpoZ2FFYlFjamZCaFpkTWFCZTloK2ZYZ0ZjSmdDZUZjWGRoYTJkRWdrYnNhWWJRZDFhbGVpYWNnbmVCZXdoU2hFZE5mSmdXZG5hVmU0ZlFnemc1YjBlS2NoZjhhWWRRZW5nb2VuaFRnd2NBYU9kUmFSZnNiZ2VSYjNmZ2dUYlZjbWRFZVZjVmRFYnhjSGdDY0djOWJ5ZUNnaGZVZ2pmZmJCZUlkL2VGZ2hlaGcxY0poaWZWZVRjZWRUZ0loY2JLZFdjOWR0ZVdnbGVWZnZmV2FraGNlZGdIZlZmVmRTZmRnR2Z0ZDZiWWYwZTFocWJTZXdkOWdTZEViR2ZSYU1iZmJqaDlhY2NBY1ZkMGQ1YUpkSGFFaEVoWGJBYlljNGdOYW5ib2IvZWNoRWROZ0RnV2FsYk5lMWZaYUZkZGIzZVlmbWNCaFhoQmZSY0JjUWRaZmtmZ2FOZ0xoa2ROZXdlSWZBZ01nMmNjZGhhTmJnZ1dna2ZoZWJkUmh3Y0pndmRmYm5md2VWZ2FlbmRKaFJlZGYxZ2RnS2RGaG1hbGNoZEZlaGJoZ21jRmVHZlphbWhZYlhnQmdWZmJoMWJJZE9hRWQxYjRnZGVFYnlmWWNJY05hU2djZEljQ2N4YThjSGJIZ1JoQmh2Y1RkR2hOZi9jVWZsaDRhSmJlaEdkNGhiZlNlMGRSaERiRWhHaHdmeGNPYkRoRWFhZUlhQWdZZGVoTWFCY2tmZmFmZHpjVmRwZlhmRmNrZ0VlRWFHYVFjaGdSZVdiOGFSYkVlMmQ5YkhhY2R4Y05kSGZhZkJjVmNJYVVhRWRjYVFlWmJuYkpoV2VGY1docGU2aEdjSGJrZFVhQWJsZ2NkN2VBZGxlbGdjZ0llM2VVZ3lnYmFpZTVkd2NYZ21jOWZOY1RoaGUwY0JlU2hWZ0pnc2FZY25jb2EvYlRnU2dOZEZoVGdCY3BnUmNOaGlhOGY1Yk1jaGRjZ2poUWhYZUFlNWNFZ2tlQWJZZFZjVmZCZ0lnY2JuYUJmd2FTaEVmTmNKZVdhbmVWZzRhU2IzZ2RnNmJhaFZiZGFaYkVnQmRsYW9hQWNtaDlidmJFZVJnTmN2YVJiM2RNYlRkUmgyY2doVmFTZ0ZoQmJIZ0VhR2RaZHloVGNCZVVjcGZmZkJnY2JsZEdjQWVkZzBkSWNEZVZiRmNFaEVmd2RVYlpnbWJaZGhjY2dGYVZmdmJXZ2tmY2dkZ0hnVmZWZlNoZGhHZ3RmNmRZZjBlMWhxZVNod2VjaGJiYWR5ZXRkTWNmYVhiWmJEaFBkeGJWZ2tmYWdoYkpjVGFFZlVjTWVGZ1lmamRzZ0xiUGJ6Z1ZhUGJZYzFocGcxZWVkRWF0ZDNhZWVtZmxoWGFXYlJhQWRaYmFlQWd0YkZnYmR4ZEVoVGdiZTBkZGV6YUdod2Y0Z1RnV2RrYWhhYmRSaHdmTWFiaGNja2hvZkphYWNtZ3BnWWhkZHdmdGFLZ1hoeGNJYXVlRmhoaE5mbWJCaGhkdGRxZFNiM2dCZ1ZjYmYxZ3BjSGhIYlJlMWZWaFVnbmZSY3JjZWVtZ05iTmJhZWtkc2VQZFVoaGVCZWtmUmZEYzhiTmNIZ1VnSWZlaGVkR2hOY3ZlU2Z3Z1JiZmNXYlhmcGQ3Z2NiQ2F4Y0ljQ2FqZEllVmNkZ1hhTmhMZllkd2ZkYmxlZmVWaGthUWJHYldjZ2NMZVJlV2I4ZlJoRWQyYzllSGZjY3hnTmhIY2FmQmhWYUlnVWhFZGNiUWJiYmpjc2J0YldobWhwYjVoVWRXZEFncWJTY2dmcGExZ1lmUWY0ZFJkWmVrYmhjbWJMY3hlb2gvZ1ZhV2ZSYmFmVWJXY0FhM2FWYlZnSmgwaGFlM2dwaGpkVGdXZHBmTGFEZTFmSWZRZFpmRWJ4YzJoZGNsZ0plQ2RIaEhmUmVjYkVna2dzZFllUWUxYWxnaWVjYm5oQmF3ZlNlRWhOZ0pmV2JuYlZjNGhTaHpiUmYwZ0plQWZJaFZhUmNGZEFjNGRSY3hoeGduZVVoQmFwaGhhRmZUZXhjSGdDYjJjQWRHYVdiVmVsYUpjWGVUZk1nK2NBYmxjd2Q2Y1BnZ2VoYy9nQmhFZ01oYWJRZTJmRWFXZ0dmR2dZYlVmWmRtZVpmaGdjZkZoVmd2aFdma2VjZ2RjSGJWaFViR2dlaGpkTWYxZE1oVWZVYXBkUWhnYkVhQWdYYXphQWdBZWZibWhSYkZhU2R4aHNoMWhJYjFkNGVmZlViUmFNYVZlT2czaG9lamVlZVVhWWhDZURhUmc1aDlhUGZraEpnN2hVaEdkbGdYY1dmUmVBaFphYWZBZHRiRmNiZnhiRWNUYWJmMGJkZXpiRWIwaGRkZ2ZXZ2thaGZiZVdmaGRCYitjZWIwZDBhL2ZhYm5lSmdSZWRmMWhkYktoRmNtZGxjaGFGZ2hkaGFtZlVmaWNrZjBmWWdYZGhmL2diYTFlcGRIYkhmUmMxY1ZkVWJuZlJocmhlZm1oTmZOZGFoa2Z0aEhoVWNnZDVjNWdUZERmbGUyY1djVWNJZkJmZWhIZ0FhVWhZYlJjaGhEZ1dnV2FKYXljY2RIZkJhSWFRZDBjbGJhZGRhWGFoYkxlZmN6YTlkRGhWZzFla2dRZ0dhV2hnZ0xmUmVXYzhjUmVFZjJnOWFIZGNkeGROZ0hoYWVBYnBmSWVFZzBlbGZXZE5hRGgwZWJlZGR5Zk1jbWNBZm5mOWI5ZVNiaGJaY3BmWWNSZ1liWWNaZGhkUmNtZVpkbWRGYndmVmJXYTljYWJSYXhjMGdkYVZkVmRKYjhmSWRuY1FlZ2RCZFNkc2ZaY2JoQmMxZlVjSWJTYzBkaWRmZWhhMWdDaEhjbmhoaG5jR2UwY3NiRWFYZDFhbGY2ZGVkM2RBZ3NnU2VBYnBhSGFHZVRhMGc1ZkdmUmhRYjFoTGhSZEloNGJSZUJnRWNuZEFha2JsaEZoRWJSY05mdmZSZDNiTWRUZ1JlMmJnZVZoU2NGZ0JlSGZFZ0dnWmF5Z1ZlaGdWZnFkY2hsYUZhL2ZIZ2tiUmdWZkllU2dCaEVoZWR5Z2xiUWRJaHdjY2ExZmVjQmJwYnZhVWVVZWNiT2dGZEZmVmNPY2FnR2V0Y2lnYWVrZTBjMmZTZzBmWmJjY1VieWV3Yk5iSmVCaFViZGZCZ2xnQWFaZUlnaGdvaEVhR2hFY2hiWmRjZkhhdGg4ZFdka2VoZURoU2JWZ3BnMWVlYkVhdGEzZWVobWhsZFhjV2dSZkFiWmdhY0FjdGhGZWJkeGZFZlRnZmUwaHRiWmVFaDBkZGNvZEZjVWJoZlFoUmZ4ZEJibWhjY2xlWWdWYWFlbmRKZVJoZGYxZGRhS2dGZG1hbGN4YlBkQmZoZ21kRmJHY1pjbWJZY1hmQmZWY2JlMWZwY0hnSGVSYzFnVmFVYW5nUmdyZmVjbWVwZG5hYWdraHNhUGVVZGhiQmRrY1RjSGdaZTJoVWRrYkljVmFlZUhjWWdTZVNld2VKaERlR2NtaHdnMGNJZGplOGJGY0lmUWNBYk9jSmJuZ0JnaGVkYTNncGFwYVZkMWVrZVFmR2RXZ2dkTGVSZVdlOGZSaEVoMmM5Z0hjY2F4ZU5iSGNhZkJoVmRBYUdjVGh4aGZiWmNuZGxlV2JCYkJhZGV5YVRjV2V0YVhjVWZoZTlhcGhQYVJjWmZSY0hlVmJzZWJoYWJrYXRod2JWZldkOWRhaFJjeGcwZ2RkVmRWaEplMGVhZTNlcGRqaFRoV2JwZUxlRGUxZ0liUWZaZEVoUWEvYURmUmMxY0NmSGduaGhobGhiYjBoc2FFYVhnMWdsZjZnZWMzZUFkc2JTYkFkb2V5ZEZoWGNWYnpiU2QyZlViSGVaYVhiMWhaYkVhQmJsaG9kQ2MwYlZodmhFY1JlTmJ2Y1JmM2NNYlRoUmQyZWdnVmNTYkZlQmdIZ0VjSGZaZythZmVCZ1ZjcWVjaGxmRmgzYVZkMGFvY1dkYWJXZUVlV2hHYUdlWWdVYlpkbWdaZGhkY2FGYlZkdmFTZm1oMGNkZEhlVmJWaFNmZGJHaHRmNmhZYjBiMWRxZ1Nld2g5Y1NlRWNHZ1JkTWhkYm5mWmFiZ1RlamY5ZDRiZGdoY0pjTGNHaEVhTmFaZFljbmZKZndkY2NFZWhjRGNTZVFhNWc3YklhQWFRYWxjY2NpZnBkWmFGaEVnVmJWYVBhRWNJZFZnSWUwYmdlYmZQZkVjNWc2ZUhiUmNVZm5oUWZRZlJnWWFWaFFmTmh2ZmZiQmN0Y0FlSmZpZ1llWWJKZXhnc2hUZkhhaWFoZW9kR2VGZ2tlaWVVZ0dhNGV6Y2FiSGV4aC9jYmcxZ3BiSGdIZ1JjMWRWZFVobmhSaHJkZWhtZk5iTmhhY2toc2dIYkhjUmdCZ3ZhVWdYYlplaWFXYzBic2VPY1VnbmZZZlNkU2N4ZmhkRGNXZldjSmV5ZmNmSGZCYkliUWEwZmxnYWJQZ1hlaGdWZGRhemJWYXlmZmRYZk1lUWZHZldhZ2NMY1JlV2U4YlJoRWQyaDlhSGNjZ3hoTmNPZFFnaGNWaEllVWJFY2NiUWJaaG5hSmdXZUZiV2dwZ3llVWdYZmRkWGVDZFJjZ2h2Yk1lMWNsaFZlQmNGZjBoeWZOZ1dia2QxZlZnWGNCY2FhRGJoZk5lZWZIY1JjTWRtZkNlRGhVYW5iQ2RBaHNiZmVCYXhmMGJiZmJnMGhWYzJnYmhGZklhTGhiaGphZGU5ZEdmVGRZZ1VlUWEwYmxhdWJjYm1lQmY4ZlNoRmJOYUFjVmhsZDljNGVTZzNnZGE2Y2FiVmJkYVpiRWNCZWxob2JDYjBjVmh2Z0VkUmFOZXZkRWczZjFkTGVDZURkb2ZkYUNhMWY0YktlUmZTY29jbWhIZDBkVWFtZUtoMWZraDdmWGNrZE1lWWZPYXllNWhDYVZiR2g0ZEZmZGQyYjlkdmZQZFFoQWJqaERnZ2Q1Y05oVWNRY3hjYWJKZDJjSmVoY1NlVWExZ3FoU2V3ZjllU2NFYUdnUmFNZmRmbmFaZ1NmUWVraGNjOWdJZ2thY2VaZ1Zma2dOZlJjU2dIZUpjd2JjaEVjaGJEZlNoVmRwZTFjZWNFZHRhM2dlZm1kbGJYYlVhVWVJYlphZGJRZHNoUmNZY1ZiSmdmZklkQWRrYTJhR2cwZDVlbWdSZ2diQWJaYUFiVWZRYlVjT2J4Y0ZnZGNQaG5kcGhDaFpiRmQ1ZERiR2hrYU5maGhGZmhiaGhtYkZjR2JaZm1oWWZYZ0JoVmdiYzFmcGRIZ0hkVWVsaGJoQ2RqaHNkNWJjZGpjRmhFZ1pkQWNaZmFkSGFrZFFhdGFIZkRob2V2ZldhZ2NNZ2NoZGRGYndkU2FTYnhmaGZEZldlV2FKYXljY2VIZEJnSWdRZDBkbGFhZ2RnWGZBZ1plZGQyZmRocGFBZDFhZGJUZVZjU2RkYkZlQWVHZmNnWWJIYlRod2RQYU9obGNVZVRjR2NsaHdiUGRHZkJkTWFZZ2RlR2d0Z2ZiSGNHZVpnWWZVYlhoZGVYYlNhaGVaZnBnWWNSZVloWWdaYmhnUmNtaFpjbWRFaGtmV2Z6aGNlVmZGY1JiVmhQYVhlRmh3ZDVnUGFqZFloM2VCaERmb2JIZ1ZhbGNwZUZmYmRVYUJjY2VkY2xjSmJDZkZoWGJoaDJoRWNrZnNiWWRRZTFibGZpY2NibmJCaDRlR2JrZk5hVWZXY2ljRmEyZUNhRGFzZDFlSmF4Z0plUmFHZVJjY2Y3YlFnd2N3YnBmUmJXZ0VhbWFBZERodGFIZFRkM2FzY0hhUWZWZWxiTGFPZW1kWmN5YlZoaGdWZHFlY2NsZEZnM2FWZTBlb2ZXZGFoV2hFYldnVGJHYmhmTWFLZVRmUmJwY0lkbGN4YmpmY2hFY2NmZGZIYlZiVmZTYmRmR2d0ZTZnWWEwYTFmcWZTZHdhOWFTZlJlQ2h3ZEZmSmhYZmdnYmhEYkZmd2RzZGZha2RZZ0RlVWVSZUJhWGJNZ1RlY2IxY05kRWRGZlBjWWUxY3BlMWRlZUVkdGUzYWVnbWhsY1hmV2JSYkFnWmFhZ0FidGdGYU9lemhzYlRmYmMwYmRjemZFZDBmZGNvZkZlVWRoYlFiUmR4aEJkdmJhYlhod2VWZWFobmRKY1JhZGMxZGRnS2RGZG1mbGFoZFNkeGZGZXFoUGVtY1pibWNZZ1hnQmVWaGJkMWNwYUhiSGJSZTFlZGhCaG5hb2V1ZElhamVNY0NkT2RCZzlkY2ZVZ2djMWJrYkFhM2E5YXRiZWVFZUliVmRlaEhiWWZTaFNjMGhWZE5iR2hpaE1nK2hQZEhmZ2FhZVRoMGJrZlRkZmdXZGhkQ2ZlYVJkZ2E4Z0VhUmQ5ZlZnU2gyaEVnQ2ZYZmtmVWVSaEVkMmc5YUhmTGNoZzljdGNhY0JkVWgxZFdlVmh3YzZiT2gzY3RnTmVQZTBmQWIrZEZiQ2ROY1hjQWdsaGthNmVOZVZoaGNaZ0thMWFGZ21mZWgyZEZoM2hVaG5hUmh3ZERmbGZzZ2RlWGRRZ1lodGJPZ3pkOGdzYUNkMmdvY2NoUmVoZXhhVWVLZXhhdGQyZ2FnMGI5aGZhRmhYaDhjamhYZUFjOWJkYkJnUmNBYnNiTmZ6Z1JkM2ZTaEJiOGhWZVdoaWFzZzBnQmdEZ1FkN2VQZlJiNGhXaFhnaGFjZWdiV2JRYkFhcGdIZDFkb2VoZUFkemNaZUxnS2FDYjRjZGdTY2hhSWVMaFhoeWFSY29hVmhCZnhlamRjaGdicGJkYVZoMGJwaGVlSmZqYUpjQ2RWZWlhZGNaZkloMmdaZzhnY2RGZmNoNGhGaFJiVmZXZVdmQWNkZVFiYmIwZkVjbmNZZXdmZ2NtaEdoRWNwaFNmU2UwYjViTWhkaGlhSWhBY0dheGZVZ2plWGZCaEpkTGFHZ0ViTWVSYkxkU2ZFZmtnUGNnYWtkT2VEY0ZocGhvaGVhRWdNZDVhUGZ6ZDVmWGhMaEdoSmUxaFlnRWVjZUtnTGNGYkJlSGVKZWdlZ2Q5YkhoUWc4ZTZmVWJBZTVoWmhUZ2hhNGJ1aFBiUWJWY0JiSmZEYU1mY2FNZ2xjY2hXZFNobWdsYmphVmRGY2toaWdGZG5mMWVNY1ljWGRBYkllYmR4ZGtmR2VTZFZmNGRkYVVibmV3Y3ViY2gyZk1hV2hRZUVjc2NQY1VlaGJBYnNoQWh5YlVmaWZIZkFjTmVZY1BlWGdZZlBnU2V4Y29mVWRGYWpjQWc1Zk5kU2JKZUtiV2JHYU5jYWJkZFNoVmFoaEtmbGNCY0RmR2R4Z3hjRWhHY1RoeGFmZFJhWGVJZlJjRWVtYzRhQWZQYzFid2VGYktkVmhrYThiR2RBZDVoRGRhZURmY2VBY1ZkQ2VZZEphSWdpaE1iRmJBZDFmZ2V1Z2JmMWRCYktkS2hWYmtnRmdLZVNkVWMxYkpoU2dBaFRmQ2dVZ2tlVmhUYVVjTmd0ZmZjbmFNZWVmVGVYZFZlTGFTYkJmNWJmY0pnZ2UwYjZhQWNoZ29hTGVSZm5lWWNaaFlnQ2hsZW9mTWVUYllmZGdHY1JjVWZKZlNiQmg4ZFZnV2VqaDBnM2hHY0NmTWgwY0tiQmNvYWNhRWJBaE5hb2NBaHdkSWFqYlhmbGhFaHVmQ2F3Z2RjYmdEZGpic2NiZkpheWJJYmxoWWJCaFFiZGFLYlhiNGZQZ0NoMWVFaHJjQ2cwYXBhZWZKYmpnSmVDY1ZjaWhkZVpnSWYyZzllaGZlYTFlVmF0Y1dka2FVZ0dmTmd4ZVljZGRPZGpiZ2V1Z1lhd2FzZXNoU2Z4YkpjU2JWY3ljZ2FEZk5nRGJjZ2VjTmJsYzBmeGNKZVJod2VFZlNjQWhZY1hhSmJ5ZkJiK2JEZ3dib2ZXZkRleGV3aDliYWcxZmxjL2FhYW1kQmVaaERmRWJCY2RjS2hWYThjQWFaaDBhVmZIY1pja2RrZjNiV2hnZUFhdGhSZWhkeGhZaFRhaGc0YXllUGFTZlZoQmJPY0Ric2NmZU1oRmg5Y2JjQWZHYUJjdmZSZ2xna2NpYVpiemFJZm5iTWd5aFJiZGZmaGtmeGNMYUhiUWMxZWNmWGdDY0Fja2dGYWljd2FhZkxieGVsY3NhRWIwZk1oaGhSZUhoOWh0YmVoQWZWZlpiTmZ6YlJhVGRCZzJod2dMY0VmRGFGZzhjUGd5ZEFiTmhEZ1Fkd2dJaGRmV2ZWYUxmTWNEYVljbWNGZFJhaGFjYmJhU2hCZENlRmZtYUZndWdYYkRlOGVDZlBnVmJZaFZmY2V6ZDhiTWJGZFFidGhWY01namZkY1dlVWRpZ1lkOWZFYnpmWWdiZFBjbGU0YmdjTWZoZmhiZGJNZkZkVWVxYUhiUmhJY2tnQmJ5Y1loVWdBaEJiTmFiaEJjeGYwZTViQ2JEZFVhbmFDZUJlb2NFZFJlaGR4YUVnYmVGaFJobmRiZDBiZGZMZmFmR2hOYmNnR2VnYjFjTmJEZFJjb2UyZU9jemQ4YytkUWdEaHhmWmFBYm1oZGh2ZldiRGhRYjdiZmZWaHNkbWNBYUViRmM3ZEVhbGRGaCtiVWcxY1phbWVIYkNkVmJTZ0ZoV2RoZ3FkV2VBY2hiVmZWZWlkUmNtZlRkbGVCZzNmRGJVZkVjdmJSYWxla2ZFaGNlV2QxZHBhQ2dEZjRkQWZKZ0NnTWdsZU5nRWVCaHliSmFWY2RlRmNEYzBhSmdCZE5heWRwaHVoYWgwZFJkeGNIZ0VjY2JiZ1hmQ2NGYUVlZGEzZGNlcGdQYnhnd2hqaElia2ZBaFNlUWR4Y1VhWWNNZEhjSWFQY1lhQmNCZ1dmV2IwZTVka2RiZGxnaGVxY0tmaWdnY0ZiQ2NsZVZid2FKY2xlOWJOZEViQWRGZkxlZmRRZEVmeGhCZTFiOGd0Z0hmVmFnZkloVmhnZk5jMGVlZDFhOGdhaGViaWZwYkFjZmhWaDhnYWRWYXpnc2V5YlVmM2hFZm9kUWdHZDRnWmJjaFNiaGNIY0tjUmVoZ1RjQmRWZWhkZGVRYWlneGM2Y2FkQ2dCaEVhWWQwZlFhZmNDZWdmSmR0aFJieWhZZjNiQWNCYkZoUWFFY1RiaGRHZlFiMmRkZFRhQWVYaEFlMGJNYW1mUmNRZUJka2JGZUtjTGJXZ2xoWWdZYm5kTmZnYldoRWJsZEljQ2VtY0lkRGhTYURkOWNRYlFoVGV3ZUNoR2dsZzBnVGNZZkdncGhZaENjRmdWZldkSmZHaFphT2dVaEdnSmFpYkNmV2FaYkVhWGZoZTllZ2hiZmdlWmFBZmNnaGMxZnRiTmVpYUFhaWRCZGlhb2F6YkNoVWNrZFZkS2drZEloc2JlZVRnd2doZ1dnWGJJaE9nQmcwYkpkSWFkZlZlNGgwZmZnMWh0ZE5mQmNTZUJiamFHYUVnTmhJZkFlZ2hzZHhlTmF4ZGtlK2VIY0Vhc2YyYVNoaWUxZ3FkRGJUZFZmdWdjYlJhSmRSaEFkRWRGZDVnR2dGYkpkbWZHZEJneGIvZEhkMmFVYWFhVGZHZlZmRmJDYlFhSWhVaFZoUWM4ZDhnQWZoYjBnVmZZYmdmbGNsZUVmUWNnaENoY2FTY1FoZWhDZ0RhNGVGZ2RmQ2JOZW9hZWdWY3BnL2FBYmxlQWhXYUVlQWJVZlRoSmhqZmdkL2JDZGdhTWcrYVFlM2ZCYkNnU2RIZlliS2VOYkdkSmRLY0JieGUxZm9iTGNnY05kWWdDZTBjcGhRaGJiV2ZJY29mYWRFY01hVGNDYUFoZ2VtZ1BlU2RJYzVjTGNtZUVkb2JTZ1ViZ2NMYkxla2VsYVJjZGIxZFFmYmRmZXhkOWVpZEFoUWJOY2hoSGhFY2RkQWNIZXdjbGVzZGVhbGF0YUZjS2d5YUFmQ2JNZWplNGZFaFFibWhFYWVjQmhrZ0JiMGFVZGlkUmd5YWVmVGdWY2RkZmN3aEpkV2hEYjFjdGNjZ1dnM2h0ZzdlSWJpZ0poRWFZaFJodGFPaEFoRWFNZ2hiSmVUZGdiaWVXZGpnMGVGaElkR2dSZFVkQ2VRaHhoYmVIZEdlcGFpYktoR2FGYmJiVWVrY0JlVGZlYW1lZ2NUZ05jV2RFYmdnRWRWaEZodmZDYlRkQWdlYVZoM2VzYUFmQmZYZHhjYWRiYmdoNGU0YWVkRWcxaGJoU2hWZE1mQmVKZURkZGJmYlZjemZnZjNjRWZEZ3hlTWREYjFob2E2ZEplQmJaY25iZGNrYnhieWNKZENiUWMwYkVjWGJvZmhlUWZFYjFiSWRCaGhicGZ6ZEZmbmhJaGNhWGFUY0pkZmRUY1JiZGFVYkloRmVrYU5jY2NRZkVhS2FYZURjNGFpZkZoVGZZZVFlU2ZsYUJkNWNMY3piTWR4ZEhhQWVBZ0JnVWNnY3Blb2ZFZTJnUmF0Z2VjeGhNZVlmVWd4ZkFiemJkYkZnVWEzZ0JnVmdFZ3FiQWZ6Y2NjR2VQZkdoOWJGaEhhUWVNZFBmRmh4ZnRnNmVLYlFoVWF5ZVplaGhNaHliRWZ3YTRiRGVFZW1iWmFGY1VhQ2M5aFNkTWRtYkVlY2NlZkZjeGRtY1FmUmNwaEFiUWZGZjBkdGRaZURmTmh2ZElhVmJ4aHpmUmR4ZThoS2dBYWllVWZJZ1lnV2hKZGJiU2Z3YzRnK2FJaDFkd2ZJZlRiQWFvZldoTGZIZEllb2VLZ0JkQWRSYkNiQWVrZnhoUGJnYVZja2NjZm1lQWdNZkJkRmJaYU1oSmFrZmdnUmJKZmxiNWRkY2JjemZoY2plU2MxY0lncWVCaEZiRmhZZFRha2NzZHdiTWZ3aFFhVmdGZ1dhSWNKY01hMGVVZU9jQWhIZGxmemhDZDJlTmNoY0JmbmhKYS9oZGhtZUZnTmhlZHloQWMxYWRjbWdRZW1jRmVuY05ibmVmYlhjQmJVYmZiRmJOYmlnSGVuY3NkbGVDY2dkOWN4aFhia2FVZEhjYmYyaFZmYmVNZVVnb2JraEtiU2h4ZzFnZmJIYWNlZ2dCZWdnVWFXZk9jZ2RRZFRjWmZXZW9lZWZHYkFmdGdjY1hoV2hrYk1iU2JXYmdhQ2RBYW5nY2drZE1lRmVrZUNkR2IyZ1ZnUGNYZ0VnQWJDZWNoMmhKZEFmQmJRYTBja2dJZFJoVWVFY0RjUmRGZ2xmWmFnYWNiS2dkaFFkSWZsYkVieGdJYWdkSWZnYk5nZGJTZHhhb2FKaFFkVWJSYXRlZmV4YzhlcmFIZ2hkZ2ZOZGFkMWRVY2NjWWcxaDVobWJaY0VicGdhZUJiMmN3YWNmV2h6YXRjV2FGY0FodGFsY2ZnbmdkY2lkWGRsYU1lemhFYkFlRWF1aE1oUmdWZjlnWmdWZ0FmVmRYZjFnNWh2YkJhMGZKZjRiQ2dBZ1poN2VYZ21hSWZIYkNmQmRCZTljTGREZU1jZWFGZDJicGQxYlJid2JZZVpoR2JoZVViVmVQZWljWWNSZ0ZlSGNwZHBkQ2VEYTRlQmZKYkhkZGE0Z2JjUmJNZjZiRmZBZlJkSmZWY0Jlb2ZjYWZnR2VJZmhnTWZRYWdmK2FIZmxkMGRjZ0VlQmZ0YWNjTGhqY0pjQWJCZGdkTmVvYVpoQWNrZFdkQWd4YkVlY2ROZWlkY2VpZ1Bja2RnZjhkV2ZRaEpkZ2VPZGxhcGh1YmNobWVCaE1kQmhGYlplTWhKY2thZ2RSZEpnbGE1ZWRhYmJ6ZGhnamVTZDFnWmQ3Y0JoMWRCZ1llT2hBY0FjK2FZYlVmVWhDZmNnMmdjaFNkZWF5YmhmYWRUaG5nd2JsYkFiVmUxaDNjQmJHZDhjOWFOYnpmRWZIZGJieWFWYVhnUmhRZGdoWGFRZTJkMGV2ZFBoSGU0aHlhZWJoaE1hYWdFY0FoRmE5ZVJjSGc5ZXRiQWhBZ2RkQmJMZVNjUmhjZVNjMmhkZ1RnQWRYZU5maGhZZW1iaGFWYUJjUmZ3ZFViTmVpZ3dmQ2FPZ0RkUmNoYUtmRWJsY0liQ2dIZ3NoWmRYZ1hjY2JCZ0hjeGZCaFhlS2R3YlpjV2hmZkZoRWNPY1JoRWM1ZkxmR2RXaElnT2FCZUhhbGFnYlNkV2E5Y0hnVmgyZ2xmNWhPZVFnY2RMaGRiQWV4aCtjZGZtY3hhZ2dEZlhkNWdJYkJnUWZaYUxiRmFBYkJiMGFGYUdob2U3Z1hhM2NJZk5kR2hVYWNkRWRlYlRhTmRtZUxja2ZjZEFmQmNHZEVheWhWZ0RoQmJuZVVnd2RGYnpoWWhXZ0pib2FVYUZhTWcwY1FjU2djYzliSGN5Ykllb2ZKZTFmY2htY0FjRWRGZzZmRWh3Y05jNWhCZEFmZGcwZUdmbmQ5ZHNoVmZ6YkFiRWFXYTBiSmFmZEdhQmVsZ2lmRGZnYlpkNWJaaFVhaGhpYUZmRWZaaHBkZWVUZmtnRGRYaEhlRmVSY2RoM2NaZG9lYWd3YWdoM2VBZWhjOWJQZVhoQWZZYVdnTWVpY1ZicGZhZjBkUmJ4YllmVWNFZVhkUmIyZlFkdGFKZUNnUWdUYUdieGExYnVoWWhoZXRiRmRVZ2dod2FRZkxkSGRvZzJlTmNrZkZlWWRTZVZhcGY2YmRmMGdzZkRmTWNpYUFiRWVXYlVlZGZRZkpkRWNkYkZoTGNWaFFlVGVPZHdnOGUyZ0VoeGVFZnBjV2NSZTBiVmdSZTBhSWZqY0plZ2FOYkhkSmNEaGNmVmhkZ3hmVWNUZ0ZjaWZ3ZjNmVmMxY1JkTWRQZmdmPWc9AHVyVEtaQ21Kay9yMERsVlZyYjVYVjJrOGN5QlJQUGhjaXpVWGtXWkl3eTA5SCtlTzEzT2dTM2dINWhwZzBGUnY1SlJxV3dqNklBNjhGNEZGQVB1T3pnPT0AMDEyMzQ1Njc4OQBDLlVURi04AEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaYWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXowMTIzNDU2Nzg5Ky8ALgAobnVsbCkAUHVyZSB2aXJ0dWFsIGZ1bmN0aW9uIGNhbGxlZCEAbGliYysrYWJpOiAAAAAAAAAAnLMEAGUAAAAyNlByb3BhZ2F0ZWRQb3NpdGlvblByb3BlcnR5AAAAAGz9BAB8swQA2LYEAFAyNlByb3BhZ2F0ZWRQb3NpdGlvblByb3BlcnR5AAAANPwEAKizBAAAAAAAnLMEAFBLMjZQcm9wYWdhdGVkUG9zaXRpb25Qcm9wZXJ0eQAANPwEANizBAABAAAAnLMEAMizBAAw+wQAyLMEAKS4BABpaWlpAGRpaQB2aWlkAFAxNkVudGl0eUNvbGxlY3Rpb24AAAA0/AQAJrQEAAAAAADotQQAUEsxNkVudGl0eUNvbGxlY3Rpb24AAAAANPwEAEy0BAABAAAA6LUEADy0BABgtwQAAAAAANi2BABmAAAAMTZQb3NpdGlvblByb3BlcnR5AFBLMTZQb3NpdGlvblByb3BlcnR5ADT8BACbtAQAAQAAANi2BADgtgQAZPsEAOC2BACU+wQANEJhc2UAAAAs/QQA0LQEAFA0QmFzZQAANPwEAOC0BAAAAAAA2LQEAFBLNEJhc2UANPwEAPi0BAABAAAA2LQEAHYAAADotAQAAAAAANi0BABnAAAAaAAAAGkAAABgtwQAALUEADhTdWJjbGFzcwAAAGz9BAA0tQQA2LQEAFA4U3ViY2xhc3MAADT8BABMtQQAAAAAAEC1BABQSzhTdWJjbGFzcwA0/AQAaLUEAAEAAABAtQQAWLUEADD7BAAAAAAAQLUEAGcAAABqAAAAawAAAGC3BAB0tQQA0PoEANi0BAAAAAAA8LUEAGwAAABtAAAAaQAxNlBvc2l0aW9uUmVnaXN0cnkAMTZFbnRpdHlDb2xsZWN0aW9uACz9BADVtQQAbP0EAMK1BADotQQAAAAAAOi1BABuAAAAbwAAAFAxNlBvc2l0aW9uUmVnaXN0cnkANPwEAAy2BAAAAAAA8LUEAFBLMTZQb3NpdGlvblJlZ2lzdHJ5AAAAADT8BAAwtgQAAQAAAPC1BABpaQB2aQAAACC2BABgtwQAaWlpAGT7BABItgQA0PoEACC2BABQ+wQAdmlpaQAAAADQ+gQAILYEAHZpaQBk+wQAILYEAJT7BABpaWlkAEGw7RILgwhk+wQAILYEAOC2BACU+wQA6PoEAFAxNlBvc2l0aW9uUHJvcGVydHkALP0EAIi0BAA0/AQAxLYEAAAAAADYtgQAaWlpaWRpAABk+wQAILYEAND6BAAw+wQAMPsEAJT7BAAw+wQAMPsEAHZpaWlkaWkATlN0M19fMjEyYmFzaWNfc3RyaW5nSWNOU18xMWNoYXJfdHJhaXRzSWNFRU5TXzlhbGxvY2F0b3JJY0VFRUUAACz9BAAgtwQATlN0M19fMjEyYmFzaWNfc3RyaW5nSWhOU18xMWNoYXJfdHJhaXRzSWhFRU5TXzlhbGxvY2F0b3JJaEVFRUUAACz9BABotwQATlN0M19fMjEyYmFzaWNfc3RyaW5nSXdOU18xMWNoYXJfdHJhaXRzSXdFRU5TXzlhbGxvY2F0b3JJd0VFRUUAACz9BACwtwQATlN0M19fMjEyYmFzaWNfc3RyaW5nSURzTlNfMTFjaGFyX3RyYWl0c0lEc0VFTlNfOWFsbG9jYXRvcklEc0VFRUUAAAAs/QQA+LcEAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0lEaU5TXzExY2hhcl90cmFpdHNJRGlFRU5TXzlhbGxvY2F0b3JJRGlFRUVFAAAALP0EAES4BABOMTBlbXNjcmlwdGVuM3ZhbEUAACz9BACQuAQATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJY0VFAAAs/QQArLgEAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SWFFRQAALP0EANS4BABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0loRUUAACz9BAD8uAQATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJc0VFAAAs/QQAJLkEAE4xMGVtc2Ny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FABBjZATCwEWAEGZkBML/wIVAAAAABUAAAAACRYAAAAAABYAABYAADAxMjM0NTY3ODlBQkNERUb/////////////////////////////////////////////////////////////////AAECAwQFBgcICf////////8KCwwNDg8QERITFBUWFxgZGhscHR4fICEiI////////woLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIj/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////wABAgQHAwYFAAAAAAAAANF0ngBXnb0qgHBSD///PicKAAAAZAAAAOgDAAAQJwAAoIYBAEBCDwCAlpgAAOH1BRgAAAA1AAAAcQAAAGv////O+///kr///wBBvJMTCwFSAEHkkxMLCP//////////AEGslBML+AmEzAQAdgAAAHcAAAB4AAAAeQAAAHoAAAB7AAAAfAAAAH0AAAB+AAAAfwAAAIAAAACBAAAAggAAAIMAAAAAAAAADM4EAIQAAACFAAAAhgAAAIcAAACIAAAAiQAAAIoAAACLAAAAjAAAAI0AAACOAAAAjwAAAJAAAACRAAAATlN0M19fMjliYXNpY19pb3NJY05TXzExY2hhcl90cmFpdHNJY0VFRUUATlN0M19fMjE1YmFzaWNfc3RyZWFtYnVmSWNOU18xMWNoYXJfdHJhaXRzSWNFRUVFAE5TdDNfXzIxM2Jhc2ljX2lzdHJlYW1JY05TXzExY2hhcl90cmFpdHNJY0VFRUUATlN0M19fMjEzYmFzaWNfb3N0cmVhbUljTlNfMTFjaGFyX3RyYWl0c0ljRUVFRQBOU3QzX18yOWJhc2ljX2lvc0l3TlNfMTFjaGFyX3RyYWl0c0l3RUVFRQBOU3QzX18yMTViYXNpY19zdHJlYW1idWZJd05TXzExY2hhcl90cmFpdHNJd0VFRUUATlN0M19fMjEzYmFzaWNfaXN0cmVhbUl3TlNfMTFjaGFyX3RyYWl0c0l3RUVFRQBOU3QzX18yMTNiYXNpY19vc3RyZWFtSXdOU18xMWNoYXJfdHJhaXRzSXdFRUVFAE5TdDNfXzI4aW9zX2Jhc2VFAAAAAACMzAQAdgAAAJIAAACTAAAAeQAAAHoAAAB7AAAAfAAAAH0AAAB+AAAAlAAAAJUAAACWAAAAggAAAIMAAABOU3QzX18yMTBfX3N0ZGluYnVmSWNFRQAs/QQA0soEAGz9BABszAQAhMwEAAgAAAAAAAAAwMwEAJcAAACYAAAA+P////j////AzAQAmQAAAJoAAADY+wQAA8sEAAAAAAABAAAA6MwEAAP0//8AAAAA6MwEAJsAAACcAAAAbP0EAKjKBAAEzQQAAAAAAATNBACdAAAAngAAACz9BAAazAQAAAAAAGjNBAB2AAAAnwAAAKAAAAB5AAAAegAAAHsAAAChAAAAfQAAAH4AAAB/AAAAgAAAAIEAAACiAAAAowAAAE5TdDNfXzIxMV9fc3Rkb3V0YnVmSWNFRQAAAABs/QQATM0EAITMBAAEAAAAAAAAAJzNBACkAAAApQAAAPz////8////nM0EAKYAAACnAAAA2PsEADLLBAAAAAAAAQAAAOjMBAAD9P//AAAAABTOBACEAAAAqAAAAKkAAACHAAAAiAAAAIkAAACKAAAAiwAAAIwAAACqAAAAqwAAAKwAAACQAAAAkQAAAE5TdDNfXzIxMF9fc3RkaW5idWZJd0VFACz9BACLywQAbP0EAPTNBAAMzgQACAAAAAAAAABIzgQArQAAAK4AAAD4////+P///0jOBACvAAAAsAAAANj7BAC8ywQAAAAAAAEAAABwzgQAA/T//wAAAABwzgQAsQAAALIAAABs/QQAYcsEAATNBAAAAAAA2M4EAIQAAACzAAAAtAAAAIcAAACIAAAAiQAAALUAAACLAAAAjAAAAI0AAACOAAAAjwAAALYAAAC3AAAATlN0M19fMjExX19zdGRvdXRidWZJd0VFAAAAAGz9BAC8zgQADM4EAAQAAAAAAAAADM8EALgAAAC5AAAA/P////z///8MzwQAugAAALsAAADY+wQA68sEAAAAAAABAAAAcM4EAAP0//8AQbCeEwsU3hIElQAAAAD///////////////8AQdCeEwtXTENfQ1RZUEUAAAAATENfTlVNRVJJQwAATENfVElNRQAAAAAATENfQ09MTEFURQAATENfTU9ORVRBUlkATENf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",Ct(xe)||(xe=u(xe));function oo(x){if(x==xe&&C)return new Uint8Array(C);var D=pm(x);if(D)return D;if(G)return G(x);throw"both async and sync fetching of the wasm failed"}function ea(x){return Promise.resolve().then(()=>oo(x))}function gs(x,D,j){return ea(x).then(lt=>WebAssembly.instantiate(lt,D)).then(lt=>lt).then(j,lt=>{g("failed to asynchronously prepare wasm: "+lt),_t(xe)&&g("warning: Loading from a file URI ("+xe+") is not supported in most browsers. See https://emscripten.org/docs/getting_started/FAQ.html#how-do-i-run-a-local-webserver-for-testing-why-does-my-program-stall-in-downloading-or-preparing"),We(lt)})}function is(x,D,j,lt){return gs(D,j,lt)}function ja(){var x={env:XN,wasi_snapshot_preview1:XN};function D(Zt,yt){var Yt=Zt.exports;return Q=Yt,Y=Q.memory,V(Y,"memory not found in wasm exports"),H(),nt=Q.__indirect_function_table,V(nt,"table not found in wasm exports"),qt(Q.__wasm_call_ctors),ue("wasm-instantiate"),Yt}ke("wasm-instantiate");var j=n;function lt(Zt){V(n===j,"the Module object should not be replaced during async compilation - perhaps the order of HTML elements is wrong?"),j=null,D(Zt.instance)}if(n.instantiateWasm)try{return n.instantiateWasm(x,D)}catch(Zt){g("Module.instantiateWasm callback failed with error: "+Zt),o(Zt)}return is(C,xe,x,lt).catch(o),{}}var qn,ae;function fe(x,D,j=!0){Object.getOwnPropertyDescriptor(n,x)||Object.defineProperty(n,x,{configurable:!0,get(){let lt=j?" (the initial value can be provided on Module, but after startup the value is only looked for on a local variable of that name)":"";We(`\`Module.${x}\` has been replaced by \`${D}\``+lt)}})}function ge(x){Object.getOwnPropertyDescriptor(n,x)&&We(`\`Module.${x}\` was supplied but \`${x}\` not included in INCOMING_MODULE_JS_API`)}function Ze(x){return x==="FS_createPath"||x==="FS_createDataFile"||x==="FS_createPreloadedFile"||x==="FS_unlink"||x==="addRunDependency"||x==="FS_createLazyFile"||x==="FS_createDevice"||x==="removeRunDependency"}function Ke(x,D){typeof globalThis<"u"&&Object.defineProperty(globalThis,x,{configurable:!0,get(){Go("`"+x+"` is not longer defined by emscripten. "+D)}})}Ke("buffer","Please use HEAP8.buffer or wasmMemory.buffer");function An(x){typeof globalThis<"u"&&!Object.getOwnPropertyDescriptor(globalThis,x)&&Object.defineProperty(globalThis,x,{configurable:!0,get(){var D="`"+x+"` is a library symbol and not included by default; add it to your library.js __deps or to DEFAULT_LIBRARY_FUNCS_TO_INCLUDE on the command line",j=x;j.startsWith("_")||(j="$"+x),D+=" (e.g. -sDEFAULT_LIBRARY_FUNCS_TO_INCLUDE='"+j+"')",Ze(x)&&(D+=". Alternatively, forcing filesystem support (-sFORCE_FILESYSTEM) can export this for you"),Go(D)}}),si(x)}function si(x){Object.getOwnPropertyDescriptor(n,x)||Object.defineProperty(n,x,{configurable:!0,get(){var D="'"+x+"' was not exported. add it to EXPORTED_RUNTIME_METHODS (see the Emscripten FAQ)";Ze(x)&&(D+=". Alternatively, forcing filesystem support (-sFORCE_FILESYSTEM) can export this for you"),We(D)}})}var da={327548:()=>{console.log("no show")}};function _a(x){this.name="ExitStatus",this.message=`Program terminated with exit(${x})`,this.status=x}var bl=x=>{for(;x.length>0;)x.shift()(n)},na=x=>(V(typeof x=="number"),x>>>=0,"0x"+x.toString(16).padStart(8,"0")),Go=x=>{Go.shown||(Go.shown={}),Go.shown[x]||(Go.shown[x]=1,g(x))};function Ao(x){this.excPtr=x,this.ptr=x-24,this.set_type=function(D){P[this.ptr+4>>2]=D},this.get_type=function(){return P[this.ptr+4>>2]},this.set_destructor=function(D){P[this.ptr+8>>2]=D},this.get_destructor=function(){return P[this.ptr+8>>2]},this.set_caught=function(D){D=D?1:0,E[this.ptr+12>>0]=D},this.get_caught=function(){return E[this.ptr+12>>0]!=0},this.set_rethrown=function(D){D=D?1:0,E[this.ptr+13>>0]=D},this.get_rethrown=function(){return E[this.ptr+13>>0]!=0},this.init=function(D,j){this.set_adjusted_ptr(0),this.set_type(D),this.set_destructor(j)},this.set_adjusted_ptr=function(D){P[this.ptr+16>>2]=D},this.get_adjusted_ptr=function(){return P[this.ptr+16>>2]},this.get_exception_ptr=function(){var D=s8(this.get_type());if(D)return P[this.excPtr>>2];var j=this.get_adjusted_ptr();return j!==0?j:this.excPtr}}var Xs=0,Es=0;function wl(x,D,j){var lt=new Ao(x);lt.init(D,j),Xs=x,Es++,V(!1,"Exception thrown, but exception catching is not enabled. Compile with -sNO_DISABLE_EXCEPTION_CATCHING or -sEXCEPTION_CATCHING_ALLOWED=[..] to catch.")}function ka(x,D,j,lt,Zt){}function Wa(x){switch(x){case 1:return 0;case 2:return 1;case 4:return 2;case 8:return 3;default:throw new TypeError(`Unknown type size: ${x}`)}}function Ju(){for(var x=new Array(256),D=0;D<256;++D)x[D]=String.fromCharCode(D);yl=x}var yl=void 0;function Bi(x){for(var D="",j=x;I[j];)D+=yl[I[j++]];return D}var sd={},zi={},js={},ca=void 0;function $n(x){throw new ca(x)}var mr=void 0;function hr(x){throw new mr(x)}function pr(x,D,j){x.forEach(function(Dt){js[Dt]=D});function lt(Dt){var pe=j(Dt);pe.length!==x.length&&hr("Mismatched type converter count");for(var Se=0;Se{zi.hasOwnProperty(Dt)?Zt[pe]=zi[Dt]:(yt.push(Dt),sd.hasOwnProperty(Dt)||(sd[Dt]=[]),sd[Dt].push(()=>{Zt[pe]=zi[Dt],++Yt,Yt===yt.length&<(Zt)}))}),yt.length===0&<(Zt)}function hs(x,D,j={}){var lt=D.name;if(x||$n(`type "${lt}" must have a positive integer typeid pointer`),zi.hasOwnProperty(x)){if(j.ignoreDuplicateRegistrations)return;$n(`Cannot register type '${lt}' twice`)}if(zi[x]=D,delete js[x],sd.hasOwnProperty(x)){var Zt=sd[x];delete sd[x],Zt.forEach(yt=>yt())}}function ma(x,D,j={}){if(!("argPackAdvance"in D))throw new TypeError("registerType registeredInstance requires argPackAdvance");return hs(x,D,j)}function Ed(x,D,j,lt,Zt){var yt=Wa(j);D=Bi(D),ma(x,{name:D,fromWireType:function(Yt){return!!Yt},toWireType:function(Yt,Dt){return Dt?lt:Zt},argPackAdvance:8,readValueFromPointer:function(Yt){var Dt;if(j===1)Dt=E;else if(j===2)Dt=B;else if(j===4)Dt=_;else throw new TypeError("Unknown boolean type size: "+D);return this.fromWireType(Dt[Yt>>yt])},destructorFunction:null})}function BW(x){if(!(this instanceof rh)||!(x instanceof rh))return!1;for(var D=this.$$.ptrType.registeredClass,j=this.$$.ptr,lt=x.$$.ptrType.registeredClass,Zt=x.$$.ptr;D.baseClass;)j=D.upcast(j),D=D.baseClass;for(;lt.baseClass;)Zt=lt.upcast(Zt),lt=lt.baseClass;return D===lt&&j===Zt}function Rc(x){return{count:x.count,deleteScheduled:x.deleteScheduled,preservePointerOnDelete:x.preservePointerOnDelete,ptr:x.ptr,ptrType:x.ptrType,smartPtr:x.smartPtr,smartPtrType:x.smartPtrType}}function $b(x){function D(j){return j.$$.ptrType.registeredClass.name}$n(D(x)+" instance already deleted")}var Zp=!1;function Lu(x){}function QW(x){x.smartPtr?x.smartPtrType.rawDestructor(x.smartPtr):x.ptrType.registeredClass.rawDestructor(x.ptr)}function tR(x){x.count.value-=1;var D=x.count.value===0;D&&QW(x)}function kW(x,D,j){if(D===j)return x;if(j.baseClass===void 0)return null;var lt=kW(x,D,j.baseClass);return lt===null?null:j.downcast(lt)}var YW={};function pg(){return Object.keys(Mu).length}function MU(){var x=[];for(var D in Mu)Mu.hasOwnProperty(D)&&x.push(Mu[D]);return x}var lh=[];function Vp(){for(;lh.length;){var x=lh.pop();x.$$.deleteScheduled=!1,x.delete()}}var lm=void 0;function _U(x){lm=x,lh.length&&lm&&lm(Vp)}function DU(){n.getInheritedInstanceCount=pg,n.getLiveInheritedInstances=MU,n.flushPendingDeletes=Vp,n.setDelayFunction=_U}var Mu={};function eR(x,D){for(D===void 0&&$n("ptr should not be undefined");x.baseClass;)D=x.upcast(D),x=x.baseClass;return D}function ug(x,D){return D=eR(x,D),Mu[D]}function bp(x,D){(!D.ptrType||!D.ptr)&&hr("makeClassHandle requires ptr and ptrType");var j=!!D.smartPtrType,lt=!!D.smartPtr;return j!==lt&&hr("Both smartPtrType and smartPtr must be specified"),D.count={value:1},kr(Object.create(x,{$$:{value:D}}))}function Rp(x){var D=this.getPointee(x);if(!D)return this.destructor(x),null;var j=ug(this.registeredClass,D);if(j!==void 0){if(j.$$.count.value===0)return j.$$.ptr=D,j.$$.smartPtr=x,j.clone();var lt=j.clone();return this.destructor(x),lt}function Zt(){return this.isSmartPointer?bp(this.registeredClass.instancePrototype,{ptrType:this.pointeeType,ptr:D,smartPtrType:this,smartPtr:x}):bp(this.registeredClass.instancePrototype,{ptrType:this,ptr:x})}var yt=this.registeredClass.getActualType(D),Yt=YW[yt];if(!Yt)return Zt.call(this);var Dt;this.isConst?Dt=Yt.constPointerType:Dt=Yt.pointerType;var pe=kW(D,this.registeredClass,Dt.registeredClass);return pe===null?Zt.call(this):this.isSmartPointer?bp(Dt.registeredClass.instancePrototype,{ptrType:Dt,ptr:pe,smartPtrType:this,smartPtr:x}):bp(Dt.registeredClass.instancePrototype,{ptrType:Dt,ptr:pe})}var kr=function(x){return typeof FinalizationRegistry>"u"?(kr=D=>D,x):(Zp=new FinalizationRegistry(D=>{console.warn(D.leakWarning.stack.replace(/^Error: /,"")),tR(D.$$)}),kr=D=>{var j=D.$$,lt=!!j.smartPtr;if(lt){var Zt={$$:j},yt=j.ptrType.registeredClass;Zt.leakWarning=new Error(`Embind found a leaked C++ instance ${yt.name} <${na(j.ptr)}>. +`;var Ppe=Er.SHOW_INDEX,set=Er.POSITION_INDEX,CUt=Er.COLOR_INDEX,vpe=Er.OUTLINE_COLOR_INDEX,Kpe=Er.OUTLINE_WIDTH_INDEX,zpe=Er.PIXEL_SIZE_INDEX,IUt=Er.SCALE_BY_DISTANCE_INDEX,NUt=Er.TRANSLUCENCY_BY_DISTANCE_INDEX,yUt=Er.DISTANCE_DISPLAY_CONDITION_INDEX,jpe=Er.DISABLE_DEPTH_DISTANCE_INDEX,ret=Er.NUMBER_OF_PROPERTIES,nc={positionHighAndSize:0,positionLowAndOutline:1,compressedAttribute0:2,compressedAttribute1:3,scaleByDistance:4,distanceDisplayConditionAndDisableDepth:5};function lV(t){t=f(t,f.EMPTY_OBJECT),this._sp=void 0,this._spTranslucent=void 0,this._rsOpaque=void 0,this._rsTranslucent=void 0,this._vaf=void 0,this._pointPrimitives=[],this._pointPrimitivesToUpdate=[],this._pointPrimitivesToUpdateIndex=0,this._pointPrimitivesRemoved=!1,this._createVertexArray=!1,this._shaderScaleByDistance=!1,this._compiledShaderScaleByDistance=!1,this._shaderTranslucencyByDistance=!1,this._compiledShaderTranslucencyByDistance=!1,this._shaderDistanceDisplayCondition=!1,this._compiledShaderDistanceDisplayCondition=!1,this._shaderDisableDepthDistance=!1,this._compiledShaderDisableDepthDistance=!1,this._propertiesChanged=new Uint32Array(ret),this._maxPixelSize=1,this._baseVolume=new Ft,this._baseVolumeWC=new Ft,this._baseVolume2D=new Ft,this._boundingVolume=new Ft,this._boundingVolumeDirty=!1,this._colorCommands=[],this.show=f(t.show,!0),this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._modelMatrix=L.clone(L.IDENTITY),this.debugShowBoundingVolume=f(t.debugShowBoundingVolume,!1),this.blendOption=f(t.blendOption,wa.OPAQUE_AND_TRANSLUCENT),this._blendOption=void 0,this._mode=Vt.SCENE3D,this._maxTotalPointSize=1,this._buffersUsage=[ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW,ce.STATIC_DRAW];let e=this;this._uniforms={u_maxTotalPointSize:function(){return e._maxTotalPointSize}}}Object.defineProperties(lV.prototype,{length:{get:function(){return det(this),this._pointPrimitives.length}}});function BUt(t){let e=t.length;for(let n=0;n0&&(t._shaderDisableDepthDistance=!0,d===Number.POSITIVE_INFINITY&&(d=-1)),a(o,s,l,d)}function $pe(t,e,n,i){QUt(t,e,n,i),kUt(t,e,n,i),YUt(t,e,n,i),xUt(t,e,n,i),XUt(t,e,n,i)}function aet(t,e,n,i,o,a){let s;i.mode===Vt.SCENE3D?(s=t._baseVolume,t._boundingVolumeDirty=!0):s=t._baseVolume2D;let l=[];for(let r=0;r0){this._vaf=qpe(r,n,this._buffersUsage),l=this._vaf.writers;for(let C=0;C0){let C=nVe;C.length=0,(a[set]||a[Kpe]||a[zpe])&&C.push(QUt),(a[CUt]||a[vpe])&&C.push(kUt),(a[Ppe]||a[NUt])&&C.push(YUt),a[IUt]&&C.push(xUt),(a[yUt]||a[jpe])&&C.push(XUt);let y=C.length;if(l=this._vaf.writers,o/n>.1){for(let Y=0;Yn*1.5&&(i.length=n),!c(this._vaf)||!c(this._vaf.va))return;this._boundingVolumeDirty&&(this._boundingVolumeDirty=!1,Ft.transform(this._baseVolume,this.modelMatrix,this._baseVolumeWC));let h,u=L.IDENTITY;t.mode===Vt.SCENE3D?(u=this.modelMatrix,h=Ft.clone(this._baseVolumeWC,this._boundingVolume)):h=Ft.clone(this._baseVolume2D,this._boundingVolume),eVe(this,t,h);let R=this._blendOption!==this.blendOption;this._blendOption=this.blendOption,R&&(this._blendOption===wa.OPAQUE||this._blendOption===wa.OPAQUE_AND_TRANSLUCENT?this._rsOpaque=he.fromCache({depthTest:{enabled:!0,func:pt.LEQUAL},depthMask:!0}):this._rsOpaque=void 0,this._blendOption===wa.TRANSLUCENT||this._blendOption===wa.OPAQUE_AND_TRANSLUCENT?this._rsTranslucent=he.fromCache({depthTest:{enabled:!0,func:pt.LEQUAL},depthMask:!1,blending:Pn.ALPHA_BLEND}):this._rsTranslucent=void 0),this._shaderDisableDepthDistance=this._shaderDisableDepthDistance||t.minimumDisableDepthTestDistance!==0;let V,F;(R||this._shaderScaleByDistance&&!this._compiledShaderScaleByDistance||this._shaderTranslucencyByDistance&&!this._compiledShaderTranslucencyByDistance||this._shaderDistanceDisplayCondition&&!this._compiledShaderDistanceDisplayCondition||this._shaderDisableDepthDistance!==this._compiledShaderDisableDepthDistance)&&(V=new Ze({sources:[FJ]}),this._shaderScaleByDistance&&V.defines.push("EYE_DISTANCE_SCALING"),this._shaderTranslucencyByDistance&&V.defines.push("EYE_DISTANCE_TRANSLUCENCY"),this._shaderDistanceDisplayCondition&&V.defines.push("DISTANCE_DISPLAY_CONDITION"),this._shaderDisableDepthDistance&&V.defines.push("DISABLE_DEPTH_DISTANCE"),this._blendOption===wa.OPAQUE_AND_TRANSLUCENT&&(F=new Ze({defines:["OPAQUE"],sources:[GF]}),this._sp=xn.replaceCache({context:r,shaderProgram:this._sp,vertexShaderSource:V,fragmentShaderSource:F,attributeLocations:nc}),F=new Ze({defines:["TRANSLUCENT"],sources:[GF]}),this._spTranslucent=xn.replaceCache({context:r,shaderProgram:this._spTranslucent,vertexShaderSource:V,fragmentShaderSource:F,attributeLocations:nc})),this._blendOption===wa.OPAQUE&&(F=new Ze({sources:[GF]}),this._sp=xn.replaceCache({context:r,shaderProgram:this._sp,vertexShaderSource:V,fragmentShaderSource:F,attributeLocations:nc})),this._blendOption===wa.TRANSLUCENT&&(F=new Ze({sources:[GF]}),this._spTranslucent=xn.replaceCache({context:r,shaderProgram:this._spTranslucent,vertexShaderSource:V,fragmentShaderSource:F,attributeLocations:nc})),this._compiledShaderScaleByDistance=this._shaderScaleByDistance,this._compiledShaderTranslucencyByDistance=this._shaderTranslucencyByDistance,this._compiledShaderDistanceDisplayCondition=this._shaderDistanceDisplayCondition,this._compiledShaderDisableDepthDistance=this._shaderDisableDepthDistance);let U,G,A,S,g=t.commandList;if(d.render||m){let C=this._colorCommands,y=this._blendOption===wa.OPAQUE,Y=this._blendOption===wa.OPAQUE_AND_TRANSLUCENT;U=this._vaf.va,G=U.length,C.length=G;let Q=Y?G*2:G;for(S=0;S>4;if(o!==cet)throw new Error(`Got v${o} data when expected v${cet}.`);let a=JUt[i&15];if(!a)throw new Error("Unrecognized array type.");let[s]=new Uint16Array(e,2,1),[l]=new Uint32Array(e,4,1);return new t(l,s,a,e)}constructor(e,n=64,i=Float64Array,o){if(isNaN(e)||e<0)throw new Error(`Unpexpected numItems value: ${e}.`);this.numItems=+e,this.nodeSize=Math.min(Math.max(+n,2),65535),this.ArrayType=i,this.IndexArrayType=e<65536?Uint16Array:Uint32Array;let a=JUt.indexOf(this.ArrayType),s=e*2*this.ArrayType.BYTES_PER_ELEMENT,l=e*this.IndexArrayType.BYTES_PER_ELEMENT,r=(8-l%8)%8;if(a<0)throw new Error(`Unexpected typed array class: ${i}.`);o&&o instanceof ArrayBuffer?(this.data=o,this.ids=new this.IndexArrayType(this.data,GJ,e),this.coords=new this.ArrayType(this.data,GJ+l+r,e*2),this._pos=e*2,this._finished=!0):(this.data=new ArrayBuffer(GJ+s+l+r),this.ids=new this.IndexArrayType(this.data,GJ,e),this.coords=new this.ArrayType(this.data,GJ+l+r,e*2),this._pos=0,this._finished=!1,new Uint8Array(this.data,0,2).set([219,(cet<<4)+a]),new Uint16Array(this.data,2,1)[0]=n,new Uint32Array(this.data,4,1)[0]=e)}add(e,n){let i=this._pos>>1;return this.ids[i]=i,this.coords[this._pos++]=e,this.coords[this._pos++]=n,i}finish(){let e=this._pos>>1;if(e!==this.numItems)throw new Error(`Added ${e} items when expected ${this.numItems}.`);return het(this.ids,this.coords,this.nodeSize,0,this.numItems-1,0),this._finished=!0,this}range(e,n,i,o){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");let{ids:a,coords:s,nodeSize:l}=this,r=[0,a.length-1,0],d=[];for(;r.length;){let m=r.pop()||0,h=r.pop()||0,u=r.pop()||0;if(h-u<=l){for(let U=u;U<=h;U++){let G=s[2*U],A=s[2*U+1];G>=e&&G<=i&&A>=n&&A<=o&&d.push(a[U])}continue}let R=u+h>>1,V=s[2*R],F=s[2*R+1];V>=e&&V<=i&&F>=n&&F<=o&&d.push(a[R]),(m===0?e<=V:n<=F)&&(r.push(u),r.push(R-1),r.push(1-m)),(m===0?i>=V:o>=F)&&(r.push(R+1),r.push(h),r.push(1-m))}return d}within(e,n,i){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");let{ids:o,coords:a,nodeSize:s}=this,l=[0,o.length-1,0],r=[],d=i*i;for(;l.length;){let m=l.pop()||0,h=l.pop()||0,u=l.pop()||0;if(h-u<=s){for(let U=u;U<=h;U++)LUt(a[2*U],a[2*U+1],e,n)<=d&&r.push(o[U]);continue}let R=u+h>>1,V=a[2*R],F=a[2*R+1];LUt(V,F,e,n)<=d&&r.push(o[R]),(m===0?e-i<=V:n-i<=F)&&(l.push(u),l.push(R-1),l.push(1-m)),(m===0?e+i>=V:n+i>=F)&&(l.push(R+1),l.push(h),l.push(1-m))}return r}};function het(t,e,n,i,o,a){if(o-i<=n)return;let s=i+o>>1;MUt(t,e,s,i,o,a),het(t,e,n,i,s-1,1-a),het(t,e,n,s+1,o,1-a)}function MUt(t,e,n,i,o,a){for(;o>i;){if(o-i>600){let d=o-i+1,m=n-i+1,h=Math.log(d),u=.5*Math.exp(2*h/3),R=.5*Math.sqrt(h*u*(d-u)/d)*(m-d/2<0?-1:1),V=Math.max(i,Math.floor(n-m*u/d+R)),F=Math.min(o,Math.floor(n+(d-m)*u/d+R));MUt(t,e,n,V,F,a)}let s=e[2*n+a],l=i,r=o;for(AJ(t,e,i,n),e[2*o+a]>s&&AJ(t,e,i,o);ls;)r--}e[2*i+a]===s?AJ(t,e,i,r):(r++,AJ(t,e,r,o)),r<=n&&(i=r+1),n<=r&&(o=r-1)}}function AJ(t,e,n,i){met(t,n,i),met(e,2*n,2*i),met(e,2*n+1,2*i+1)}function met(t,e,n){let i=t[e];t[e]=t[n],t[n]=i}function LUt(t,e,n,i){let o=t-n,a=e-i;return o*o+a*a}function Qu(t){t=f(t,f.EMPTY_OBJECT),this._enabled=f(t.enabled,!1),this._pixelRange=f(t.pixelRange,80),this._minimumClusterSize=f(t.minimumClusterSize,2),this._clusterBillboards=f(t.clusterBillboards,!0),this._clusterLabels=f(t.clusterLabels,!0),this._clusterPoints=f(t.clusterPoints,!0),this._labelCollection=void 0,this._billboardCollection=void 0,this._pointCollection=void 0,this._clusterBillboardCollection=void 0,this._clusterLabelCollection=void 0,this._clusterPointCollection=void 0,this._collectionIndicesByEntity={},this._unusedLabelIndices=[],this._unusedBillboardIndices=[],this._unusedPointIndices=[],this._previousClusters=[],this._previousHeight=void 0,this._enabledDirty=!1,this._clusterDirty=!1,this._cluster=void 0,this._removeEventListener=void 0,this._clusterEvent=new It,this.show=f(t.show,!0)}function _Ut(t,e){t.x-=e,t.y-=e,t.width+=e*2,t.height+=e*2}var iVe=new Fe;function DUt(t,e,n,i,o){if(c(t._labelCollection)&&i._clusterLabels?o=cF.getScreenSpaceBoundingBox(t,e,o):c(t._billboardCollection)&&i._clusterBillboards?o=Na.getScreenSpaceBoundingBox(t,e,o):c(t._pointPrimitiveCollection)&&i._clusterPoints&&(o=Er.getScreenSpaceBoundingBox(t,e,o)),_Ut(o,n),i._clusterLabels&&!c(t._labelCollection)&&c(t.id)&&HUt(i,t.id.id)&&c(t.id._label)){let a=i._collectionIndicesByEntity[t.id.id].labelIndex,s=i._labelCollection.get(a),l=cF.getScreenSpaceBoundingBox(s,e,iVe);_Ut(l,n),o=Fe.union(o,l,o)}return o}function oVe(t,e){if(t.clusterShow=!0,!c(t._labelCollection)&&c(t.id)&&HUt(e,t.id.id)&&c(t.id._label)){let n=e._collectionIndicesByEntity[t.id.id].labelIndex,i=e._labelCollection.get(n);i.clusterShow=!0}}function OUt(t,e,n,i){let o={billboard:i._clusterBillboardCollection.add(),label:i._clusterLabelCollection.add(),point:i._clusterPointCollection.add()};o.billboard.show=!1,o.point.show=!1,o.label.show=!0,o.label.text=e.toLocaleString(),o.label.id=n,o.billboard.position=o.label.position=o.point.position=t,i._clusterEvent.raiseEvent(n,o)}function HUt(t,e){return c(t)&&c(t._collectionIndicesByEntity[e])&&c(t._collectionIndicesByEntity[e].labelIndex)}function pet(t,e,n,i,o){if(!c(t))return;let a=t.length;for(let s=0;s0){let X=new SJ(A.length,64,Uint32Array);for(let _=0;_=m)for(OUt(_.position,E,Z,t),u.push(_),g=0;g=m){let H=p.multiplyByScalar(z,1/E,z);for(OUt(H,E,Z,t),u.push({position:H,width:w.width,height:w.height,minimumWidth:y.width,minimumHeight:y.height}),g=0;g0?(l=d.shift(),r=a.get(l)):(r=a.add(),l=a.length-1),s[i]=l;let m=this;return Promise.resolve().then(function(){m._clusterDirty=!0}),r}}function Zet(t,e){let n=t._collectionIndicesByEntity[e];!c(n.billboardIndex)&&!c(n.labelIndex)&&!c(n.pointIndex)&&delete t._collectionIndicesByEntity[e]}Qu.prototype.getLabel=uet("_labelCollection",sR,"_unusedLabelIndices","labelIndex");Qu.prototype.removeLabel=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!c(this._labelCollection)||!c(e)||!c(e.labelIndex))return;let n=e.labelIndex;e.labelIndex=void 0,Zet(this,t.id);let i=this._labelCollection.get(n);i.show=!1,i.text="",i.id=void 0,this._unusedLabelIndices.push(n),this._clusterDirty=!0};Qu.prototype.getBillboard=uet("_billboardCollection",yh,"_unusedBillboardIndices","billboardIndex");Qu.prototype.removeBillboard=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!c(this._billboardCollection)||!c(e)||!c(e.billboardIndex))return;let n=e.billboardIndex;e.billboardIndex=void 0,Zet(this,t.id);let i=this._billboardCollection.get(n);i.id=void 0,i.show=!1,i.image=void 0,this._unusedBillboardIndices.push(n),this._clusterDirty=!0};Qu.prototype.getPoint=uet("_pointCollection",JC,"_unusedPointIndices","pointIndex");Qu.prototype.removePoint=function(t){let e=this._collectionIndicesByEntity&&this._collectionIndicesByEntity[t.id];if(!c(this._pointCollection)||!c(e)||!c(e.pointIndex))return;let n=e.pointIndex;e.pointIndex=void 0,Zet(this,t.id);let i=this._pointCollection.get(n);i.show=!1,i.id=void 0,this._unusedPointIndices.push(n),this._clusterDirty=!0};function Vet(t){if(!c(t))return;let e=t.length;for(let n=0;n0&&this._labelCollection.get(0)._glyphs.length===0&&(e=t.commandList,t.commandList=[],this._labelCollection.update(t),t.commandList=e),c(this._billboardCollection)&&this._billboardCollection.length>0&&!c(this._billboardCollection.get(0).width)&&(e=t.commandList,t.commandList=[],this._billboardCollection.update(t),t.commandList=e),this._enabledDirty&&(this._enabledDirty=!1,dVe(this),this._clusterDirty=!0),this._clusterDirty&&(this._clusterDirty=!1,this._cluster()),c(this._clusterLabelCollection)&&this._clusterLabelCollection.update(t),c(this._clusterBillboardCollection)&&this._clusterBillboardCollection.update(t),c(this._clusterPointCollection)&&this._clusterPointCollection.update(t),c(this._labelCollection)&&this._labelCollection.update(t),c(this._billboardCollection)&&this._billboardCollection.update(t),c(this._pointCollection)&&this._pointCollection.update(t)};Qu.prototype.destroy=function(){this._labelCollection=this._labelCollection&&this._labelCollection.destroy(),this._billboardCollection=this._billboardCollection&&this._billboardCollection.destroy(),this._pointCollection=this._pointCollection&&this._pointCollection.destroy(),this._clusterLabelCollection=this._clusterLabelCollection&&this._clusterLabelCollection.destroy(),this._clusterBillboardCollection=this._clusterBillboardCollection&&this._clusterBillboardCollection.destroy(),this._clusterPointCollection=this._clusterPointCollection&&this._clusterPointCollection.destroy(),c(this._removeEventListener)&&(this._removeEventListener(),this._removeEventListener=void 0),this._labelCollection=void 0,this._billboardCollection=void 0,this._pointCollection=void 0,this._clusterBillboardCollection=void 0,this._clusterLabelCollection=void 0,this._clusterPointCollection=void 0,this._collectionIndicesByEntity=void 0,this._unusedLabelIndices=[],this._unusedBillboardIndices=[],this._unusedPointIndices=[],this._previousClusters=[],this._previousHeight=void 0,this._enabledDirty=!1,this._pixelRangeDirty=!1,this._minimumClusterSizeDirty=!1};var Yh=Qu;function Ret(t){this._name=t,this._clock=void 0,this._changed=new It,this._error=new It,this._isLoading=!1,this._loading=new It,this._entityCollection=new gr(this),this._entityCluster=new Yh}Object.defineProperties(Ret.prototype,{name:{get:function(){return this._name},set:function(t){this._name!==t&&(this._name=t,this._changed.raiseEvent(this))}},clock:{get:function(){return this._clock},set:function(t){this._clock!==t&&(this._clock=t,this._changed.raiseEvent(this))}},entities:{get:function(){return this._entityCollection}},isLoading:{get:function(){return this._isLoading},set:function(t){ml.setLoading(this,t)}},changedEvent:{get:function(){return this._changed}},errorEvent:{get:function(){return this._error}},loadingEvent:{get:function(){return this._loading}},show:{get:function(){return this._entityCollection.show},set:function(t){this._entityCollection.show=t}},clustering:{get:function(){return this._entityCluster},set:function(t){this._entityCluster=t}}});Ret.prototype.update=function(t){return!0};var hR=Ret;var bet=class extends hR{constructor(e){if(!(e.sdc instanceof hR)||!e.sdc._wasmModule)throw new Ut("Invalid SpaceCatalogDataSource");super(`${e.sdc.name}_coverageGroup`),this.objectList=[],this.sdc=e.sdc,this.sdc.entities.collectionChanged.addEventListener((n,i,o,a)=>{for(let s=0;s{this.ph.positionsArray=[],this.ph.positions=[];for(let o=0;o!0,set:()=>{}}})}}getById(e){return this.objectList.filter(n=>n.id===e)}push(e){this.objectList.filter(n=>n.id===e.id).length||(this.objectList.push(e),this.createGeometry())}remove(e){this.objectList=this.objectList.filter(n=>n.id!==e.id),Object.defineProperties(e,{show:{configurable:!0,get:()=>e._show,set:n=>{e._show=n}}}),this.createGeometry()}},TJ=bet;var HVi=b(W(),1);var rVi=b(W(),1);var Hpi=b(W(),1);var wUt={};wUt.computePositions=function(t,e,n,i,o){let a=t*.5,s=-a,l=i+i,r=o?2*l:l,d=new Float64Array(r*3),m,h=0,u=0,R=o?l*3:0,V=o?(l+i)*3:i*3;for(m=0;m0){let F=Math.min(a,o);d=Math.round(o/F),r+=F}let m=re.createTypedArray(s,r*2),h=0,u;for(u=0;u0)for(u=0;u0){for(r=0;r=3e4)e=rt.now(e),this._lastSystemClockUpdate=t;else{let i=this._multiplier;if(n===ya.TICK_DEPENDENT)e=rt.addSeconds(e,i,e);else{let l=t-this._lastSystemTime;e=rt.addSeconds(e,i*(l/1e3),e)}let o=this.clockRange,a=this.startTime,s=this.stopTime;if(o===pl.CLAMPED)rt.lessThan(e,a)?e=rt.clone(a,e):rt.greaterThan(e,s)&&(e=rt.clone(s,e),this.onStop.raiseEvent(this));else if(o===pl.LOOP_STOP)for(rt.lessThan(e,a)&&(e=rt.clone(a,e));rt.greaterThan(e,s);)e=rt.addSeconds(a,rt.secondsDifference(e,s),e),this.onStop.raiseEvent(this)}}return this._currentTime=e,this._lastSystemTime=t,this.onTick.raiseEvent(this),e};var ku=Tet;function cS(){this._definitionChanged=new It,this._startTime=void 0,this._stopTime=void 0,this._currentTime=void 0,this._clockRange=void 0,this._clockStep=void 0,this._multiplier=void 0}Object.defineProperties(cS.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},startTime:gm("startTime"),stopTime:gm("stopTime"),currentTime:gm("currentTime"),clockRange:gm("clockRange"),clockStep:gm("clockStep"),multiplier:gm("multiplier")});cS.prototype.clone=function(t){return c(t)||(t=new cS),t.startTime=this.startTime,t.stopTime=this.stopTime,t.currentTime=this.currentTime,t.clockRange=this.clockRange,t.clockStep=this.clockStep,t.multiplier=this.multiplier,t};cS.prototype.equals=function(t){return this===t||c(t)&&rt.equals(this.startTime,t.startTime)&&rt.equals(this.stopTime,t.stopTime)&&rt.equals(this.currentTime,t.currentTime)&&this.clockRange===t.clockRange&&this.clockStep===t.clockStep&&this.multiplier===t.multiplier};cS.prototype.merge=function(t){this.startTime=f(this.startTime,t.startTime),this.stopTime=f(this.stopTime,t.stopTime),this.currentTime=f(this.currentTime,t.currentTime),this.clockRange=f(this.clockRange,t.clockRange),this.clockStep=f(this.clockStep,t.clockStep),this.multiplier=f(this.multiplier,t.multiplier)};cS.prototype.getValue=function(t){return c(t)||(t=new ku),t.startTime=f(this.startTime,t.startTime),t.stopTime=f(this.stopTime,t.stopTime),t.currentTime=f(this.currentTime,t.currentTime),t.clockRange=f(this.clockRange,t.clockRange),t.multiplier=f(this.multiplier,t.multiplier),t.clockStep=f(this.clockStep,t.clockStep),t};var Yu=cS;var xui=b(W(),1);var UVe=v.WHITE,GVe=.1,AVe=new K(8,8),SVe=new K(0,0),TVe=new K(1,1);function DC(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this._cellAlpha=void 0,this._cellAlphaSubscription=void 0,this._lineCount=void 0,this._lineCountSubscription=void 0,this._lineThickness=void 0,this._lineThicknessSubscription=void 0,this._lineOffset=void 0,this._lineOffsetSubscription=void 0,this.color=t.color,this.cellAlpha=t.cellAlpha,this.lineCount=t.lineCount,this.lineThickness=t.lineThickness,this.lineOffset=t.lineOffset}Object.defineProperties(DC.prototype,{isConstant:{get:function(){return et.isConstant(this._color)&&et.isConstant(this._cellAlpha)&&et.isConstant(this._lineCount)&&et.isConstant(this._lineThickness)&&et.isConstant(this._lineOffset)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color"),cellAlpha:ft("cellAlpha"),lineCount:ft("lineCount"),lineThickness:ft("lineThickness"),lineOffset:ft("lineOffset")});DC.prototype.getType=function(t){return"Grid"};DC.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,UVe,e.color),e.cellAlpha=et.getValueOrDefault(this._cellAlpha,t,GVe),e.lineCount=et.getValueOrClonedDefault(this._lineCount,t,AVe,e.lineCount),e.lineThickness=et.getValueOrClonedDefault(this._lineThickness,t,TVe,e.lineThickness),e.lineOffset=et.getValueOrClonedDefault(this._lineOffset,t,SVe,e.lineOffset),e};DC.prototype.equals=function(t){return this===t||t instanceof DC&&et.equals(this._color,t._color)&&et.equals(this._cellAlpha,t._cellAlpha)&&et.equals(this._lineCount,t._lineCount)&&et.equals(this._lineThickness,t._lineThickness)&&et.equals(this._lineOffset,t._lineOffset)};var OC=DC;var Oui=b(W(),1);function HC(t){this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this.color=t}Object.defineProperties(HC.prototype,{isConstant:{get:function(){return et.isConstant(this._color)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color")});HC.prototype.getType=function(t){return"PolylineArrow"};HC.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,v.WHITE,e.color),e};HC.prototype.equals=function(t){return this===t||t instanceof HC&&et.equals(this._color,t._color)};var wC=HC;var qui=b(W(),1);var gVe=v.WHITE,EVe=v.TRANSPARENT,CVe=16,IVe=255;function PC(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this._gapColor=void 0,this._gapColorSubscription=void 0,this._dashLength=void 0,this._dashLengthSubscription=void 0,this._dashPattern=void 0,this._dashPatternSubscription=void 0,this.color=t.color,this.gapColor=t.gapColor,this.dashLength=t.dashLength,this.dashPattern=t.dashPattern}Object.defineProperties(PC.prototype,{isConstant:{get:function(){return et.isConstant(this._color)&&et.isConstant(this._gapColor)&&et.isConstant(this._dashLength)&&et.isConstant(this._dashPattern)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color"),gapColor:ft("gapColor"),dashLength:ft("dashLength"),dashPattern:ft("dashPattern")});PC.prototype.getType=function(t){return"PolylineDash"};PC.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,gVe,e.color),e.gapColor=et.getValueOrClonedDefault(this._gapColor,t,EVe,e.gapColor),e.dashLength=et.getValueOrDefault(this._dashLength,t,CVe,e.dashLength),e.dashPattern=et.getValueOrDefault(this._dashPattern,t,IVe,e.dashPattern),e};PC.prototype.equals=function(t){return this===t||t instanceof PC&&et.equals(this._color,t._color)&&et.equals(this._gapColor,t._gapColor)&&et.equals(this._dashLength,t._dashLength)&&et.equals(this._dashPattern,t._dashPattern)};var vC=PC;var sZi=b(W(),1);var NVe=v.WHITE,yVe=.25,BVe=1;function KC(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this._glowPower=void 0,this._glowPowerSubscription=void 0,this._taperPower=void 0,this._taperPowerSubscription=void 0,this.color=t.color,this.glowPower=t.glowPower,this.taperPower=t.taperPower}Object.defineProperties(KC.prototype,{isConstant:{get:function(){return et.isConstant(this._color)&&et.isConstant(this._glow)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color"),glowPower:ft("glowPower"),taperPower:ft("taperPower")});KC.prototype.getType=function(t){return"PolylineGlow"};KC.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,NVe,e.color),e.glowPower=et.getValueOrDefault(this._glowPower,t,yVe,e.glowPower),e.taperPower=et.getValueOrDefault(this._taperPower,t,BVe,e.taperPower),e};KC.prototype.equals=function(t){return this===t||t instanceof KC&&et.equals(this._color,t._color)&&et.equals(this._glowPower,t._glowPower)&&et.equals(this._taperPower,t._taperPower)};var zC=KC;var VZi=b(W(),1);var QVe=v.WHITE,kVe=v.BLACK,YVe=1;function jC(t){t=f(t,f.EMPTY_OBJECT),this._definitionChanged=new It,this._color=void 0,this._colorSubscription=void 0,this._outlineColor=void 0,this._outlineColorSubscription=void 0,this._outlineWidth=void 0,this._outlineWidthSubscription=void 0,this.color=t.color,this.outlineColor=t.outlineColor,this.outlineWidth=t.outlineWidth}Object.defineProperties(jC.prototype,{isConstant:{get:function(){return et.isConstant(this._color)&&et.isConstant(this._outlineColor)&&et.isConstant(this._outlineWidth)}},definitionChanged:{get:function(){return this._definitionChanged}},color:ft("color"),outlineColor:ft("outlineColor"),outlineWidth:ft("outlineWidth")});jC.prototype.getType=function(t){return"PolylineOutline"};jC.prototype.getValue=function(t,e){return c(e)||(e={}),e.color=et.getValueOrClonedDefault(this._color,t,QVe,e.color),e.outlineColor=et.getValueOrClonedDefault(this._outlineColor,t,kVe,e.outlineColor),e.outlineWidth=et.getValueOrDefault(this._outlineWidth,t,YVe),e};jC.prototype.equals=function(t){return this===t||t instanceof jC&&et.equals(this._color,t._color)&&et.equals(this._outlineColor,t._outlineColor)&&et.equals(this._outlineWidth,t._outlineWidth)};var AF=jC;var UZi=b(W(),1);function J0(t,e){this._value=void 0,this._definitionChanged=new It,this._eventHelper=new rl,this._referenceFrame=f(e,ri.FIXED),this.setValue(t)}Object.defineProperties(J0.prototype,{isConstant:{get:function(){let t=this._value;if(!c(t))return!0;let e=t.length;for(let n=0;n0){n=new Array(e);for(let i=0;ir&&t!==Object}let V=typeof t.unpack=="function"&&t!==rV;if(!R&&!u){h?e[n]=new Ii(V?t.unpack(d,0):d):e[n]=nGt(t,s,i);return}let F=e[n],U,G=i.epoch;if(c(G)&&(U=rt.fromIso8601(G)),R&&!u){F instanceof ql||(e[n]=F=new ql(t)),F.addSamplesPackedArray(d,U),XP(i,F);return}let A;if(!R&&u){l=l.clone(),h?l.data=V?t.unpack(d,0):d:l.data=nGt(t,s,i),c(F)||(e[n]=F=h?new _m:new ec),h&&F instanceof _m?F.intervals.addInterval(l):F instanceof ec?(h&&(l.data=new Ii(l.data)),F.intervals.addInterval(l)):(e[n]=F=rGt(F),h&&(l.data=new Ii(l.data)),F.intervals.addInterval(l));return}c(F)||(e[n]=F=new ec),F instanceof ec||(e[n]=F=rGt(F));let S=F.intervals;A=S.findInterval(l),(!c(A)||!(A.data instanceof ql))&&(A=l.clone(),A.data=new ql(t),S.addInterval(A)),A.data.addSamplesPackedArray(d,U),XP(i,A.data)}function fGt(t,e){if(t instanceof ql){t.removeSamples(e);return}else if(t instanceof _m){t.intervals.removeInterval(e);return}else if(t instanceof ec){let n=t.intervals;for(let i=0;ir),!V&&!u){h?t[e]=new jl(p.unpack(d),R):t[e]=yJ(a,n.reference);return}let F=t[e],U,G=n.epoch;if(c(G)&&(U=rt.fromIso8601(G)),V&&!u){(!(F instanceof Bs)||c(R)&&F.referenceFrame!==R)&&(t[e]=F=new Bs(R,l)),F.addSamplesPackedArray(d,U),XP(n,F);return}let A;if(!V&&u){s=s.clone(),h?s.data=p.unpack(d):s.data=yJ(a,n.reference),c(F)||(h?F=new _0(R):F=new cl(R),t[e]=F),h&&F instanceof _0&&c(R)&&F.referenceFrame===R?F.intervals.addInterval(s):F instanceof cl?(h&&(s.data=new jl(s.data,R)),F.intervals.addInterval(s)):(t[e]=F=dGt(F),h&&(s.data=new jl(s.data,R)),F.intervals.addInterval(s));return}c(F)?F instanceof cl||(t[e]=F=dGt(F)):t[e]=F=new cl(R);let S=F.intervals;A=S.findInterval(s),(!c(A)||!(A.data instanceof Bs)||c(R)&&A.data.referenceFrame!==R)&&(A=s.clone(),A.data=new Bs(R,l),S.addInterval(A)),A.data.addSamplesPackedArray(d,U),XP(n,A.data)}function FGt(t,e){if(t instanceof Bs){t.removeSamples(e);return}else if(t instanceof _0){t.intervals.removeInterval(e);return}else if(t instanceof cl){let n=t.intervals;for(let i=0;i. version format.");let i=e._documentPacket;c(t.name)&&(i.name=t.name);let o=t.clock;if(c(o)){let a=i.clock;c(a)?(a.interval=f(o.interval,a.interval),a.currentTime=f(o.currentTime,a.currentTime),a.range=f(o.range,a.range),a.step=f(o.step,a.step),a.multiplier=f(o.multiplier,a.multiplier)):i.clock={interval:o.interval,currentTime:o.currentTime,range:o.range,step:o.step,multiplier:o.multiplier}}}function Fue(t,e,n,i){let o=e.ellipse;if(!c(o))return;let a=Qs(o.interval),s=t.ellipse;c(s)||(t.ellipse=s=new jG),Bt(Boolean,s,"show",o.show,a,i,n),Bt(Number,s,"semiMajorAxis",o.semiMajorAxis,a,i,n),Bt(Number,s,"semiMinorAxis",o.semiMinorAxis,a,i,n),Bt(Number,s,"height",o.height,a,i,n),Bt(Ge,s,"heightReference",o.heightReference,a,i,n),Bt(Number,s,"extrudedHeight",o.extrudedHeight,a,i,n),Bt(Ge,s,"extrudedHeightReference",o.extrudedHeightReference,a,i,n),Bt(rV,s,"rotation",o.rotation,a,i,n),Bt(rV,s,"stRotation",o.stRotation,a,i,n),Bt(Number,s,"granularity",o.granularity,a,i,n),Bt(Boolean,s,"fill",o.fill,a,i,n),Jh(s,"material",o.material,a,i,n),Bt(Boolean,s,"outline",o.outline,a,i,n),Bt(v,s,"outlineColor",o.outlineColor,a,i,n),Bt(Number,s,"outlineWidth",o.outlineWidth,a,i,n),Bt(Number,s,"numberOfVerticalLines",o.numberOfVerticalLines,a,i,n),Bt(Vi,s,"shadows",o.shadows,a,i,n),Bt(Wn,s,"distanceDisplayCondition",o.distanceDisplayCondition,a,i,n),Bt(Ji,s,"classificationType",o.classificationType,a,i,n),Bt(Number,s,"zIndex",o.zIndex,a,i,n)}function Uue(t,e,n,i){let o=e.ellipsoid;if(!c(o))return;let a=Qs(o.interval),s=t.ellipsoid;c(s)||(t.ellipsoid=s=new qG),Bt(Boolean,s,"show",o.show,a,i,n),Bt(p,s,"radii",o.radii,a,i,n),Bt(p,s,"innerRadii",o.innerRadii,a,i,n),Bt(Number,s,"minimumClock",o.minimumClock,a,i,n),Bt(Number,s,"maximumClock",o.maximumClock,a,i,n),Bt(Number,s,"minimumCone",o.minimumCone,a,i,n),Bt(Number,s,"maximumCone",o.maximumCone,a,i,n),Bt(Ge,s,"heightReference",o.heightReference,a,i,n),Bt(Boolean,s,"fill",o.fill,a,i,n),Jh(s,"material",o.material,a,i,n),Bt(Boolean,s,"outline",o.outline,a,i,n),Bt(v,s,"outlineColor",o.outlineColor,a,i,n),Bt(Number,s,"outlineWidth",o.outlineWidth,a,i,n),Bt(Number,s,"stackPartitions",o.stackPartitions,a,i,n),Bt(Number,s,"slicePartitions",o.slicePartitions,a,i,n),Bt(Number,s,"subdivisions",o.subdivisions,a,i,n),Bt(Vi,s,"shadows",o.shadows,a,i,n),Bt(Wn,s,"distanceDisplayCondition",o.distanceDisplayCondition,a,i,n)}function Gue(t,e,n,i){let o=e.label;if(!c(o))return;let a=Qs(o.interval),s=t.label;c(s)||(t.label=s=new au),Bt(Boolean,s,"show",o.show,a,i,n),Bt(String,s,"text",o.text,a,i,n),Bt(String,s,"font",o.font,a,i,n),Bt(Pa,s,"style",o.style,a,i,n),Bt(Number,s,"scale",o.scale,a,i,n),Bt(Boolean,s,"showBackground",o.showBackground,a,i,n),Bt(v,s,"backgroundColor",o.backgroundColor,a,i,n),Bt(K,s,"backgroundPadding",o.backgroundPadding,a,i,n),Bt(K,s,"pixelOffset",o.pixelOffset,a,i,n),Bt(p,s,"eyeOffset",o.eyeOffset,a,i,n),Bt(to,s,"horizontalOrigin",o.horizontalOrigin,a,i,n),Bt(hi,s,"verticalOrigin",o.verticalOrigin,a,i,n),Bt(Ge,s,"heightReference",o.heightReference,a,i,n),Bt(v,s,"fillColor",o.fillColor,a,i,n),Bt(v,s,"outlineColor",o.outlineColor,a,i,n),Bt(Number,s,"outlineWidth",o.outlineWidth,a,i,n),Bt(ln,s,"translucencyByDistance",o.translucencyByDistance,a,i,n),Bt(ln,s,"pixelOffsetScaleByDistance",o.pixelOffsetScaleByDistance,a,i,n),Bt(ln,s,"scaleByDistance",o.scaleByDistance,a,i,n),Bt(Wn,s,"distanceDisplayCondition",o.distanceDisplayCondition,a,i,n),Bt(Number,s,"disableDepthTestDistance",o.disableDepthTestDistance,a,i,n)}function Aue(t,e,n,i){let o=e.model;if(!c(o))return;let a=Qs(o.interval),s=t.model;c(s)||(t.model=s=new Jb),Bt(Boolean,s,"show",o.show,a,i,n),Bt(QJ.default,s,"uri",o.gltf,a,i,n),Bt(Number,s,"scale",o.scale,a,i,n),Bt(Number,s,"minimumPixelSize",o.minimumPixelSize,a,i,n),Bt(Number,s,"maximumScale",o.maximumScale,a,i,n),Bt(Boolean,s,"incrementallyLoadTextures",o.incrementallyLoadTextures,a,i,n),Bt(Boolean,s,"runAnimations",o.runAnimations,a,i,n),Bt(Boolean,s,"clampAnimations",o.clampAnimations,a,i,n),Bt(Vi,s,"shadows",o.shadows,a,i,n),Bt(Ge,s,"heightReference",o.heightReference,a,i,n),Bt(v,s,"silhouetteColor",o.silhouetteColor,a,i,n),Bt(Number,s,"silhouetteSize",o.silhouetteSize,a,i,n),Bt(v,s,"color",o.color,a,i,n),Bt(Kd,s,"colorBlendMode",o.colorBlendMode,a,i,n),Bt(Number,s,"colorBlendAmount",o.colorBlendAmount,a,i,n),Bt(Wn,s,"distanceDisplayCondition",o.distanceDisplayCondition,a,i,n);let l,r,d=o.nodeTransformations;if(c(d))if(Array.isArray(d))for(l=0,r=d.length;l-1;r--)n[r](s,t,e,i)}Eet=void 0}function Que(t){let e,n=t._documentPacket.clock;if(!c(n)){if(!c(t._clock)){let o=t._entityCollection.computeAvailability();if(!o.start.equals(be.MINIMUM_VALUE)){let a=o.start,s=o.stop,l=rt.secondsDifference(s,a),r=Math.round(l/120);return e=new Yu,e.startTime=rt.clone(a),e.stopTime=rt.clone(s),e.clockRange=pl.LOOP_STOP,e.multiplier=r,e.currentTime=rt.clone(a),e.clockStep=ya.SYSTEM_CLOCK_MULTIPLIER,t._clock=e,!0}}return!1}c(t._clock)?e=t._clock.clone():(e=new Yu,e.startTime=be.MINIMUM_VALUE.clone(),e.stopTime=be.MAXIMUM_VALUE.clone(),e.currentTime=be.MINIMUM_VALUE.clone(),e.clockRange=pl.LOOP_STOP,e.clockStep=ya.SYSTEM_CLOCK_MULTIPLIER,e.multiplier=1);let i=Qs(n.interval);return c(i)&&(e.startTime=i.start,e.stopTime=i.stop),c(n.currentTime)&&(e.currentTime=rt.fromIso8601(n.currentTime)),c(n.range)&&(e.clockRange=f(pl[n.range],pl.LOOP_STOP)),c(n.step)&&(e.clockStep=f(ya[n.step],ya.SYSTEM_CLOCK_MULTIPLIER)),c(n.multiplier)&&(e.multiplier=n.multiplier),e.equals(t._clock)?!1:(t._clock=e.clone(t._clock),!0)}function GGt(t,e,n,i){n=f(n,f.EMPTY_OBJECT);let o=e,a=n.sourceUri,s=n.credit;if(typeof s=="string"&&(s=new on(s)),t._credit=s,typeof e=="string"||e instanceof te){e=te.createIfNeeded(e),o=e.fetchJson(),a=f(a,e.clone());let l=t._resourceCredits,r=e.credits;if(c(r)){let d=r.length;for(let m=0;m1;--Z){if(G=k.PI_OVER_TWO-(Z-1)*U,C=oI(-G,a,V,R,r,m,d,h,u,C),y=oI(G+Math.PI,a,V,R,r,m,d,h,u,y),e){for(S[g++]=C.x,S[g++]=C.y,S[g++]=C.z,I=2*(Z-1)+2,E=1;E1;--s){for(e[n++]=i++,e[n++]=i,e[n++]=a,o=2*s,l=0;lk.PI&&(h.north=h.north>0?k.PI_OVER_TWO-k.EPSILON7:h.north,h.south=h.south<0?k.EPSILON7-k.PI_OVER_TWO:h.south,h.east=k.PI,h.west=-k.PI),h}function uR(t){t=f(t,f.EMPTY_OBJECT);let e=t.center,n=f(t.ellipsoid,mt.WGS84),i=t.semiMajorAxis,o=t.semiMinorAxis,a=f(t.granularity,k.RADIANS_PER_DEGREE),s=f(t.vertexFormat,ee.DEFAULT),l=f(t.height,0),r=f(t.extrudedHeight,l);this._center=p.clone(e),this._semiMajorAxis=i,this._semiMinorAxis=o,this._ellipsoid=mt.clone(n),this._rotation=f(t.rotation,0),this._stRotation=f(t.stRotation,0),this._height=Math.max(r,l),this._granularity=a,this._vertexFormat=ee.clone(s),this._extrudedHeight=Math.min(r,l),this._shadowVolume=f(t.shadowVolume,!1),this._workerName="createEllipseGeometry",this._offsetAttribute=t.offsetAttribute,this._rectangle=void 0,this._textureCoordinateRotationPoints=void 0}uR.packedLength=p.packedLength+mt.packedLength+ee.packedLength+9;uR.pack=function(t,e,n){return n=f(n,0),p.pack(t._center,e,n),n+=p.packedLength,mt.pack(t._ellipsoid,e,n),n+=mt.packedLength,ee.pack(t._vertexFormat,e,n),n+=ee.packedLength,e[n++]=t._semiMajorAxis,e[n++]=t._semiMinorAxis,e[n++]=t._rotation,e[n++]=t._stRotation,e[n++]=t._height,e[n++]=t._granularity,e[n++]=t._extrudedHeight,e[n++]=t._shadowVolume?1:0,e[n]=f(t._offsetAttribute,-1),e};var _Gt=new p,DGt=new mt,OGt=new ee,VR={center:_Gt,ellipsoid:DGt,vertexFormat:OGt,semiMajorAxis:void 0,semiMinorAxis:void 0,rotation:void 0,stRotation:void 0,height:void 0,granularity:void 0,extrudedHeight:void 0,shadowVolume:void 0,offsetAttribute:void 0};uR.unpack=function(t,e,n){e=f(e,0);let i=p.unpack(t,e,_Gt);e+=p.packedLength;let o=mt.unpack(t,e,DGt);e+=mt.packedLength;let a=ee.unpack(t,e,OGt);e+=ee.packedLength;let s=t[e++],l=t[e++],r=t[e++],d=t[e++],m=t[e++],h=t[e++],u=t[e++],R=t[e++]===1,V=t[e];return c(n)?(n._center=p.clone(i,n._center),n._ellipsoid=mt.clone(o,n._ellipsoid),n._vertexFormat=ee.clone(a,n._vertexFormat),n._semiMajorAxis=s,n._semiMinorAxis=l,n._rotation=r,n._stRotation=d,n._height=m,n._granularity=h,n._extrudedHeight=u,n._shadowVolume=R,n._offsetAttribute=V===-1?void 0:V,n):(VR.height=m,VR.extrudedHeight=u,VR.granularity=h,VR.stRotation=d,VR.rotation=r,VR.semiMajorAxis=s,VR.semiMinorAxis=l,VR.shadowVolume=R,VR.offsetAttribute=V===-1?void 0:V,new uR(VR))};uR.computeRectangle=function(t,e){t=f(t,f.EMPTY_OBJECT);let n=t.center,i=f(t.ellipsoid,mt.WGS84),o=t.semiMajorAxis,a=t.semiMinorAxis,s=f(t.granularity,k.RADIANS_PER_DEGREE),l=f(t.rotation,0);return MGt(n,o,a,l,s,i,e)};uR.createGeometry=function(t){if(t._semiMajorAxis<=0||t._semiMinorAxis<=0)return;let e=t._height,n=t._extrudedHeight,i=!k.equalsEpsilon(e,n,0,k.EPSILON2);t._center=t._ellipsoid.scaleToGeodeticSurface(t._center,t._center);let o={center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,ellipsoid:t._ellipsoid,rotation:t._rotation,height:e,granularity:t._granularity,vertexFormat:t._vertexFormat,stRotation:t._stRotation},a;if(i)o.extrudedHeight=n,o.shadowVolume=t._shadowVolume,o.offsetAttribute=t._offsetAttribute,a=Oue(o);else if(a=Mue(o),c(t._offsetAttribute)){let s=a.attributes.position.values.length,l=t._offsetAttribute===zn.NONE?0:1,r=new Uint8Array(s/3).fill(l);a.attributes.applyOffset=new jt({componentDatatype:it.UNSIGNED_BYTE,componentsPerAttribute:1,values:r})}return new _e({attributes:a.attributes,indices:a.indices,primitiveType:le.TRIANGLES,boundingSphere:a.boundingSphere,offsetAttribute:t._offsetAttribute})};uR.createShadowVolume=function(t,e,n){let i=t._granularity,o=t._ellipsoid,a=e(i,o),s=n(i,o);return new uR({center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,ellipsoid:o,rotation:t._rotation,stRotation:t._stRotation,granularity:i,extrudedHeight:a,height:s,vertexFormat:ee.POSITION_ONLY,shadowVolume:!0})};function Hue(t){let e=-t._stRotation;if(e===0)return[0,0,0,1,1,0];let i=Om.computeEllipsePositions({center:t._center,semiMajorAxis:t._semiMajorAxis,semiMinorAxis:t._semiMinorAxis,rotation:t._rotation,granularity:t._granularity},!1,!0).outerPositions,o=i.length/3,a=new Array(o);for(let r=0;r0){let V=Math.min(d,r);R=Math.round(r/V);let F=Math.min(R*d,r);for(u=0;u0&&(g=!0,G+=r-1),s0&&m!==F-1&&h!==0&&h!==U-1&&(M[$]=!0),$++;u=0;let dt,q;for(m=1;m=zt&&m1||C>1))for(let E=0;E0;m-=d)kt=m*3,nt=uI(nt,st,kt,u,U),st+=6,o.st&&(q=ZI(q,Et,m*2,C),Et+=4),n&&(Qt+=3,$[Qt++]=y[kt],$[Qt++]=y[kt+1],$[Qt++]=y[kt+2]),at&&(dt[Wt++]=1,Wt+=1);if(I){let zt=Nt;for(kt=zt*3,m=0;m<2;m++)nt=uI(nt,st,kt,u,U),st+=6,o.st&&(q=ZI(q,Et,zt*2,C),Et+=4),n&&(Qt+=3,$[Qt++]=y[kt],$[Qt++]=y[kt+1],$[Qt++]=y[kt+2]),at&&(dt[Wt++]=1,Wt+=1)}else for(m=d-1;m>=0;m--)kt=m*3,nt=uI(nt,st,kt,u,U),st+=6,o.st&&(q=ZI(q,Et,m*2,C),Et+=4),n&&(Qt+=3,$[Qt++]=y[kt],$[Qt++]=y[kt+1],$[Qt++]=y[kt+2]),at&&(dt[Wt++]=1,Wt+=1);let Mt=mRe(nt,o,l);o.st&&(Mt.attributes.st=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:q})),n&&(Mt.attributes.extrudeDirection=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:$})),Q&&(Mt.attributes.applyOffset=new jt({componentDatatype:it.UNSIGNED_BYTE,componentsPerAttribute:1,values:dt}));let qt=re.createTypedArray(H,P*6),ie,oe,He,rn;R=nt.length/3;let de=0;for(m=0;m0)for(s=new Array(o),i=0;i0)for(l=new Array(o),i=0;i0)for(s=new Array(o),i=0;i0)for(l=new Array(o),i=0;i{i.raiseEvent(l)}),n[a]=s}this.updaters=n,this.geometryChanged=i,this.eventHelper=o,this._removeEntitySubscription=t.definitionChanged.addEventListener(TS.prototype._onEntityPropertyChanged,this)}TS.prototype._onEntityPropertyChanged=function(t,e,n,i){let o=this.updaters;for(let a=0;a0){c(i)&&(c(this.oldPrimitive)?o.remove(i):this.oldPrimitive=i);let r;c(this.depthFailAppearanceType)&&(c(this.depthFailMaterialProperty)&&(this.depthFailMaterial=Ua.getValue(t,this.depthFailMaterialProperty,this.depthFailMaterial)),r=new this.depthFailAppearanceType({material:this.depthFailMaterial,translucent:this.translucent,closed:this.closed})),i=new Wi({show:!1,asynchronous:!0,geometryInstances:s.slice(),appearance:new this.appearanceType({translucent:this.translucent,closed:this.closed}),depthFailAppearance:r,shadows:this.shadows}),o.add(i),e=!1}else{c(i)&&(o.remove(i),i=void 0);let r=this.oldPrimitive;c(r)&&(o.remove(r),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=i,this.createPrimitive=!1,this.waitingOnCreate=!0}else if(c(i)&&i.ready){i.show=!0,c(this.oldPrimitive)&&(o.remove(this.oldPrimitive),this.oldPrimitive=void 0),c(this.depthFailAppearanceType)&&!(this.depthFailMaterialProperty instanceof Cn)&&(this.depthFailMaterial=Ua.getValue(t,this.depthFailMaterialProperty,this.depthFailMaterial),this.primitive.depthFailAppearance.material=this.depthFailMaterial);let s=this.updatersWithAttributes.values,l=s.length,r=this.waitingOnCreate;for(a=0;a=0;i--){let o=t[i];if(o.remove(e))return o.updaters.length===0&&(t.splice(i,1),o.destroy()),!0}return!1}WI.prototype.remove=function(t){vAt(this._solidItems,t)||vAt(this._translucentItems,t)};function KAt(t,e,n){let i=!1,o=e.length;for(let a=0;a0)for(a=0;a=0;a--){let s=e[a];if(s.invalidated){e.splice(a,1);let l=s.updaters.values,r=l.length;for(let d=0;d0){c(n)&&(c(this.oldPrimitive)?i.remove(n):this.oldPrimitive=n),this.material=Ua.getValue(t,this.materialProperty,this.material);let l;c(this.depthFailMaterialProperty)&&(this.depthFailMaterial=Ua.getValue(t,this.depthFailMaterialProperty,this.depthFailMaterial),l=new this.depthFailAppearanceType({material:this.depthFailMaterial,translucent:this.depthFailMaterial.isTranslucent(),closed:this.closed})),n=new Wi({show:!1,asynchronous:!0,geometryInstances:o.slice(),appearance:new this.appearanceType({material:this.material,translucent:this.material.isTranslucent(),closed:this.closed}),depthFailAppearance:l,shadows:this.shadows}),i.add(n),e=!1}else{c(n)&&(i.remove(n),n=void 0);let l=this.oldPrimitive;c(l)&&(i.remove(l),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=n,this.createPrimitive=!1}else if(c(n)&&n.ready){n.show=!0,c(this.oldPrimitive)&&(i.remove(this.oldPrimitive),this.oldPrimitive=void 0),this.material=Ua.getValue(t,this.materialProperty,this.material),this.primitive.appearance.material=this.material,c(this.depthFailAppearanceType)&&!(this.depthFailMaterialProperty instanceof Cn)&&(this.depthFailMaterial=Ua.getValue(t,this.depthFailMaterialProperty,this.depthFailMaterial),this.primitive.depthFailAppearance.material=this.depthFailMaterial);let s=this.updatersWithAttributes.values,l=s.length;for(a=0;a=0;i--){let o=e[i];if(o.remove(t)){o.updaters.length===0&&(e.splice(i,1),o.destroy());break}}};fI.prototype.update=function(t){let e,n=this._items,i=n.length;for(e=i-1;e>=0;e--){let a=n[e];if(a.invalidated){n.splice(e,1);let s=a.updaters.values,l=s.length;for(let r=0;r0)c(i)&&(c(this.oldPrimitive)?o.remove(i):this.oldPrimitive=i),i=new Nc({show:!1,asynchronous:!0,geometryInstances:s.slice(),classificationType:this.classificationType}),o.add(i,this.zIndex),e=!1;else{c(i)&&(o.remove(i),i=void 0);let r=this.oldPrimitive;c(r)&&(o.remove(r),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=i,this.createPrimitive=!1,this.waitingOnCreate=!0}else if(c(i)&&i.ready){i.show=!0,c(this.oldPrimitive)&&(o.remove(this.oldPrimitive),this.oldPrimitive=void 0);let s=this.updatersWithAttributes.values,l=s.length,r=this.waitingOnCreate;for(a=0;a=0;--e){let s=o[e];s.isDirty&&(i=o[e].update(t)&&i,s.isDirty=!1),s.geometry.length===0&&o.splice(e,1)}return i};FI.prototype.getBoundingSphere=function(t,e){let n=this._batches,i=n.length;for(let o=0;o0)c(n)&&(c(this.oldPrimitive)?i.remove(n):this.oldPrimitive=n),this.material=Ua.getValue(t,this.materialProperty,this.material),n=new Nc({show:!1,asynchronous:!0,geometryInstances:o.slice(),appearance:new this.appearanceType({material:this.material}),classificationType:this.classificationType}),i.add(n,this.zIndex),e=!1;else{c(n)&&(i.remove(n),n=void 0);let l=this.oldPrimitive;c(l)&&(i.remove(l),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=n,this.createPrimitive=!1}else if(c(n)&&n.ready){n.show=!0,c(this.oldPrimitive)&&(i.remove(this.oldPrimitive),this.oldPrimitive=void 0),this.material=Ua.getValue(t,this.materialProperty,this.material),this.primitive.appearance.material=this.material;let s=this.updatersWithAttributes.values,l=s.length;for(a=0;a=0;i--){let o=e[i];if(o.remove(t)){o.updaters.length===0&&(e.splice(i,1),o.destroy());break}}};GI.prototype.update=function(t){let e,n=this._items,i=n.length;for(e=i-1;e>=0;e--){let a=n[e];if(a.invalidated){n.splice(e,1);let s=a.updaters.values,l=s.length;for(let r=0;r0)c(i)&&(c(this.oldPrimitive)?o.remove(i):this.oldPrimitive=i),i=new Wi({show:!1,asynchronous:!0,geometryInstances:s.slice(),appearance:new jn({flat:!0,translucent:this.translucent,renderState:{lineWidth:this.width}}),shadows:this.shadows}),o.add(i),e=!1;else{c(i)&&(o.remove(i),i=void 0);let r=this.oldPrimitive;c(r)&&(o.remove(r),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=i,this.createPrimitive=!1,this.waitingOnCreate=!0}else if(c(i)&&i.ready){i.show=!0,c(this.oldPrimitive)&&(o.remove(this.oldPrimitive),this.oldPrimitive=void 0);let s=this.updatersWithAttributes.values,l=s.length,r=this.waitingOnCreate;for(a=0;a0)for(h=!0,e=0;e0)for(h=!0,e=0;e-1;l--)r=s[l],d=r.id,m=this._updaterSets.get(d),m.entity===r?m.forEach(function(F){h._removeUpdater(F),h._insertUpdaterIntoBatch(t,F)}):(o.push(r),n.push(r));for(l=o.length-1;l>-1;l--)r=o[l],d=r.id,m=this._updaterSets.get(d),m.forEach(this._removeUpdater.bind(this)),m.destroy(),this._updaterSets.remove(d),this._subscriptions.get(d)(),this._subscriptions.remove(d);for(l=n.length-1;l>-1;l--)r=n[l],d=r.id,m=new gS(r,this._scene),this._updaterSets.set(d,m),m.forEach(function(F){h._insertUpdaterIntoBatch(t,F)}),this._subscriptions.set(d,m.geometryChanged.addEventListener(Hm._onGeometryChanged,this));e.removeAll(),i.removeAll(),a.removeAll();let u=!0,R=this._batches,V=R.length;for(l=0;l-1;s--)r=n[s],l=r.id,i.remove(l)||(o.set(l,r),a.remove(l));for(s=e.length-1;s>-1;s--)r=e[s],l=r.id,o.remove(l)?a.set(l,r):i.set(l,r)};var dL=Hm;var gCi=b(W(),1);var lbe=1,rbe="30px sans-serif",dbe=Pa.FILL,cbe=v.WHITE,mbe=v.BLACK,hbe=1,pbe=!1,Vbe=new v(.165,.165,.165,.8),ube=new K(7,5),Zbe=K.ZERO,Rbe=p.ZERO,bbe=Ge.NONE,Wbe=to.CENTER,fbe=hi.CENTER,Fbe=new p,Ube=new v,Gbe=new v,Abe=new v,Sbe=new K,Tbe=new p,gbe=new K,Ebe=new ln,Cbe=new ln,Ibe=new ln,Nbe=new Wn;function tSt(t){this.entity=t,this.label=void 0,this.index=void 0}function NF(t,e){e.collectionChanged.addEventListener(NF.prototype._onCollectionChanged,this),this._cluster=t,this._entityCollection=e,this._items=new qe,this._toRemove=[],this._onCollectionChanged(e,e.values,[],[])}NF.prototype.update=function(t){let e=this._items.values,n=this._cluster;for(let i=0,o=e.length;i-1;o--)a=e[o],c(a._label)&&c(a._position)&&s.set(a.id,new tSt(a));for(o=i.length-1;o>-1;o--)a=i[o],c(a._label)&&c(a._position)?s.contains(a.id)||s.set(a.id,new tSt(a)):(vet(s.get(a.id),a,l),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],vet(s.get(a.id),a,l),s.remove(a.id)};function vet(t,e,n){c(t)&&(t.label=void 0,n.removeLabel(e))}var cL=NF;var KCi=b(W(),1);var ybe=1,Bbe=0,Qbe=!0,kbe=!0,Ybe=Vi.ENABLED,xbe=Ge.NONE,Xbe=v.RED,Jbe=0,Lbe=v.WHITE,Mbe=Kd.HIGHLIGHT,_be=.5,Dbe=new K(1,1),Obe=new L,Hbe=new L,eSt=new v,nSt=new Array(4),wbe=new p;function yF(t,e){e.collectionChanged.addEventListener(yF.prototype._onCollectionChanged,this),this._scene=t,this._primitives=t.primitives,this._entityCollection=e,this._modelHash={},this._entitiesToVisualize=new qe,this._onCollectionChanged(e,e.values,[],[])}async function Pbe(t,e,n,i){let o=t._primitives,a=t._modelHash;try{let s=await Au.fromGltfAsync({url:n,incrementallyLoadTextures:i,scene:t._scene});if(t.isDestroyed()||!c(a[e.id]))return;s.id=e,o.add(s),a[e.id].modelPrimitive=s,s.errorEvent.addEventListener(l=>{c(a[e.id])&&(console.log(l),l.name!=="TextureError"&&s.incrementallyLoadTextures&&(a[e.id].loadFailed=!0))})}catch(s){if(t.isDestroyed()||!c(a[e.id]))return;console.log(s),a[e.id].loadFailed=!0}}yF.prototype.update=function(t){let e=this._entitiesToVisualize.values,n=this._modelHash,i=this._primitives;for(let o=0,a=e.length;o-1;i--)Ket(this,t[i],e,n);return At(this)};var iv=new p,vbe=new gt;yF.prototype.getBoundingSphere=function(t,e){let n=this._modelHash[t.id];if(!c(n))return ve.FAILED;if(n.loadFailed)return ve.FAILED;let i=n.modelPrimitive;if(!c(i)||!i.show)return ve.PENDING;if(!i.ready||!n.modelUpdated)return ve.PENDING;let o=this._scene,a=o.globe,s=f(a?.ellipsoid,mt.WGS84);if(i.heightReference!==Ge.NONE){let r=i.modelMatrix;iv.x=r[12],iv.y=r[13],iv.z=r[14];let d=s.cartesianToCartographic(iv,vbe),m=o.getHeight(d,i.heightReference);return c(m)&&(Np(i.heightReference)?d.height=m:d.height+=m),Ft.clone(i.boundingSphere,e),e.center=s.cartographicToCartesian(d),ve.DONE}return Ft.clone(i.boundingSphere,e),ve.DONE};yF.prototype._onCollectionChanged=function(t,e,n,i){let o,a,s=this._entitiesToVisualize,l=this._modelHash,r=this._primitives;for(o=e.length-1;o>-1;o--)a=e[o],c(a._model)&&c(a._position)&&s.set(a.id,a);for(o=i.length-1;o>-1;o--)a=i[o],c(a._model)&&c(a._position)?(Kbe(a,l),s.set(a.id,a)):(Ket(this,a,l,r),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],Ket(this,a,l,r),s.remove(a.id)};function Ket(t,e,n,i){let o=n[e.id];c(o)&&(i.removeAndDestroy(o.modelPrimitive),delete n[e.id])}function Kbe(t,e){let n=e[t.id];c(n)&&(n.nodeTransformationsScratch={},n.articulationsScratch={})}var mL=yF;var gIi=b(W(),1);var nIi=b(W(),1);function BF(t){this._definitionChanged=new It,this._value=void 0,this._removeSubscription=void 0,this.setValue(t)}Object.defineProperties(BF.prototype,{isConstant:{get:function(){return et.isConstant(this._value)}},definitionChanged:{get:function(){return this._definitionChanged}},referenceFrame:{get:function(){return c(this._value)?this._value.referenceFrame:ri.FIXED}}});BF.prototype.getValue=function(t,e){return this.getValueInReferenceFrame(t,ri.FIXED,e)};BF.prototype.setValue=function(t){this._value!==t&&(this._value=t,c(this._removeSubscription)&&(this._removeSubscription(),this._removeSubscription=void 0),c(t)&&(this._removeSubscription=t.definitionChanged.addEventListener(this._raiseDefinitionChanged,this)),this._definitionChanged.raiseEvent(this))};BF.prototype.getValueInReferenceFrame=function(t,e,n){if(c(this._value))return n=this._value.getValueInReferenceFrame(t,e,n),c(n)?mt.WGS84.scaleToGeodeticSurface(n,n):void 0};BF.prototype.equals=function(t){return this===t||t instanceof BF&&this._value===t._value};BF.prototype._raiseDefinitionChanged=function(){this._definitionChanged.raiseEvent(this)};var vc=BF;var zbe=60,jbe=1,sSt=new ai,zet=new ai,jet=new ai;function iSt(t){this.entity=t,this.polyline=void 0,this.index=void 0,this.updater=void 0}function oSt(t,e){let n=Math.sin(t)*Math.sqrt(1-Math.pow(e,2))/(1+e*Math.cos(t)),i=(e+Math.cos(t))/(1+e*Math.cos(t)),o=Math.atan2(n,i),a=o-e*Math.sin(o);return a<0&&(a=a+2*Math.PI),a}function qbe(t){t._timeSegments={segments:[],globalIndex:null,splitInterval:null,settings:null}}function lSt(t){t._timeSegments.segments.length=0}function $be(t,e,n,i,o,a,s,l,r){let d=l,m;m=t.getValueInReferenceFrame(e,a,r[d]),c(m)&&(r[d++]=m);let h=!c(o)||rt.lessThanOrEquals(o,e)||rt.greaterThanOrEquals(o,n),u=!1;if(s.method){let C=rt.secondsDifference(n,e);if(i.length0&&!G){let C=i[R+1],y=rt.secondsDifference(C,F);G=y>s,G&&(A=Math.ceil(y/s),S=0,g=y/Math.max(A,2),A=Math.max(A-1,1))}if(G&&S1&&(F=1);let U;if(r._timeSegments.splitInterval)U=r._timeSegments.splitInterval;else{let q;for(q=0;q=I)lSt(r);else if(_>0)r._timeSegments.segments.splice(0,_);else if(_<0){r._timeSegments.segments.splice(_,-_);for(let q=0;qz&&(d=av(t,nt,$,i,o,m,d-1,l,r,h),dt=!0),l.splice(d-1,r._timeSegments.segments[at].length,...r._timeSegments.segments[at]),d+=r._timeSegments.segments[at].length-1}return P.length&&(l.splice(d-1,P.length,...P),d+=P.length-1),t._property._refFrame!==o&&(t._property._refFrame=o),l.length=d,u&&(t._property._samples=l.length),l.length}function av(t,e,n,i,o,a,s,l,r,d){let m=a.method==="trueAnomaly",h=s;return m&&m!=="constant condition"?h=n0e(t,e,n,i,o,a,s,l,d):h=t0e(t,e,n,i,o,a,s,l,d),h}var Dh=new p,TI=new p,hL=new p,sv=new p,IS=new p;function n0e(t,e,n,i,o,a,s,l,r){let d=rt.lessThanOrEquals(n,e),m,h=s,u=e,R=a.samplesPerPeriod||360,V=a.period||rt.secondsDifference(n,e),F=a.extraEpochSamples||0,U=a.resolutionAtEpoch||1,G=a.extraSamples||3,A=rt.addSeconds(i,-(Math.floor(F/2)*U),new rt),S=!1,g=rt.clone(e),C=t._property._samples||void 0,y=null;for(;!d;){m=t.getValueInReferenceFrame(u,o,Dh,!0),rt.greaterThanOrEquals(u,g)&&(l[h++]=p.clone(m)),IS=t.getValueInReferenceFrame(u,ri.TEME),sv=t._velocity.getValueInReferenceFrame(u,ri.TEME),Dh=p.cross(IS,sv,Dh),TI=p.cross(sv,Dh,TI),Dh=p.divideByScalar(TI,k.GRAVITATIONALPARAMETER,Dh),TI=p.divideByScalar(IS,p.magnitude(IS),TI),hL=p.subtract(Dh,TI,hL);let Q=p.magnitude(hL),J=p.dot(hL,IS)/(p.magnitude(hL)*p.magnitude(IS)),M=p.dot(IS,sv),Z=Math.acos(J);M<0&&(Z=2*Math.PI-Z);let E=2*Math.PI/R;y!==null&&(E=2*E-Math.abs(Z-y));let I=Z+E;I>2*Math.PI&&(I-=2*Math.PI),y=Z;let B=oSt(Z,Q),X=oSt(I,Q),_=Math.abs(X-B);_>Math.PI&&(_=2*Math.PI-_);let P=V*(_/(2*Math.PI));if(u=rt.addSeconds(u,P,new rt),!S&&rt.greaterThanOrEquals(u,A)){for(let w=0;w0){let V=u.pop();r=this._polylineCollection.get(V),e.index=V}else e.index=this._polylineCollection.length,r=this._polylineCollection.add();r.id=n,e.polyline=r,qbe(e.polyline)}let m=et.getValueOrDefault(i._resolution,t,zbe);r.show=!0;let h=[];if(c(n._localReferenceEntity)){let u=l0e(a,s,m),R=n._localReferenceEntity;for(let V=0;V=1/this._maxFPS))return!0;this._lastUpdate=i}let e=this._updaters;for(let i in e)e.hasOwnProperty(i)&&e[i].update(t);let n=this._items.values;if(!n.length&&c(this._updaters)&&Object.values(this._updaters).length){for(let i in this._updaters)this._updaters[i]&&this._scene.primitives.removeAndDestroy(this._updaters[i]._polylineCollection);this._updaters={}}for(let i=0,o=n.length;i-1;o--)a=e[o],c(a._path)&&c(a._position)&&l.set(a.id,new iSt(a));for(o=i.length-1;o>-1;o--)a=i[o],c(a._path)&&c(a._position)?l.contains(a.id)||l.set(a.id,new iSt(a)):(s=l.get(a.id),c(s)&&(c(s.updater)&&s.updater.removeObject(s),l.remove(a.id)));for(o=n.length-1;o>-1;o--)a=n[o],s=l.get(a.id),c(s)&&(c(s.updater)&&s.updater.removeObject(s),l.remove(a.id))};QF._subSample=dSt;var VL=QF;var i1i=b(W(),1);var MIi=b(W(),1);var kIi=b(W(),1);var NIi=b(W(),1),d0e={};var r0e=(()=>{var t=d0e.url;return function(e={}){var n=e,i,o;n.ready=new Promise((x,D)=>{i=x,o=D}),["_getCoveragePositions","_inflateEllipsoid","_malloc","_free","_memory","_fflush","__embind_initialize_bindings","___indirect_function_table","___start_em_asm","___stop_em_asm","onRuntimeInitialized"].forEach(x=>{Object.getOwnPropertyDescriptor(n.ready,x)||Object.defineProperty(n.ready,x,{get:()=>We("You are getting "+x+" on the Promise object, instead of the instance. Use .then() to get called back with the instance, see the MODULARIZE docs in src/settings.js"),set:()=>We("You are setting "+x+" on the Promise object, instead of the instance. Use .then() to get called back with the instance, see the MODULARIZE docs in src/settings.js")})}),globalThis.__dirname=globalThis.__dirname||"";var a=Object.assign({},n),s=[],l="./this.program",r=(x,D)=>{throw D},d=!0,m=!1,h=!1,u=!1;if(n.ENVIRONMENT)throw new Error("Module.ENVIRONMENT has been deprecated. To force the environment, use the ENVIRONMENT compile-time option (for example, -sENVIRONMENT=web or -sENVIRONMENT=node)");var R="";function V(x){return n.locateFile?n.locateFile(x,R):R+x}var F,U,G,A;if(u){if(typeof process=="object"&&typeof Og=="function"||typeof window=="object"||typeof importScripts=="function")throw new Error("not compiled for this environment (did you build to HTML and try to run it not on the web, or set ENVIRONMENT to something - like node - and run it someplace else - like on the web?)");typeof read<"u"&&(F=read),G=x=>{if(typeof readbuffer=="function")return new Uint8Array(readbuffer(x));let D=read(x,"binary");return Z(typeof D=="object"),D},U=(x,D,j)=>{setTimeout(()=>D(G(x)))},typeof clearTimeout>"u"&&(globalThis.clearTimeout=x=>{}),typeof setTimeout>"u"&&(globalThis.setTimeout=x=>typeof x=="function"?x():We()),typeof scriptArgs<"u"?s=scriptArgs:typeof arguments<"u"&&(s=arguments),typeof quit=="function"&&(r=(x,D)=>{throw setTimeout(()=>{if(!(D instanceof _a)){let j=D;D&&typeof D=="object"&&D.stack&&(j=[D,D.stack]),g(`exiting due to exception: ${j}`)}quit(x)}),D}),typeof print<"u"&&(typeof console>"u"&&(console={}),console.log=print,console.warn=console.error=typeof printErr<"u"?printErr:print)}else if(d||m){if(m?R=self.location.href:typeof document<"u"&&document.currentScript&&(R=document.currentScript.src),t&&(R=t),R.indexOf("blob:")!==0?R=R.substr(0,R.replace(/[?#].*/,"").lastIndexOf("/")+1):R="",!(typeof window=="object"||typeof importScripts=="function"))throw new Error("not compiled for this environment (did you build to HTML and try to run it not on the web, or set ENVIRONMENT to something - like node - and run it someplace else - like on the web?)");F=x=>{var D=new XMLHttpRequest;return D.open("GET",x,!1),D.send(null),D.responseText},m&&(G=x=>{var D=new XMLHttpRequest;return D.open("GET",x,!1),D.responseType="arraybuffer",D.send(null),new Uint8Array(D.response)}),U=(x,D,j)=>{var lt=new XMLHttpRequest;lt.open("GET",x,!0),lt.responseType="arraybuffer",lt.onload=()=>{if(lt.status==200||lt.status==0&<.response){D(lt.response);return}j()},lt.onerror=j,lt.send(null)},A=x=>document.title=x}else throw new Error("environment detection error");var S=n.print||console.log.bind(console),g=n.printErr||console.error.bind(console);Object.assign(n,a),a=null,n8(),n.arguments&&(s=n.arguments),fe("arguments","arguments_"),n.thisProgram&&(l=n.thisProgram),fe("thisProgram","thisProgram"),n.quit&&(r=n.quit),fe("quit","quit_"),Z(typeof n.memoryInitializerPrefixURL>"u","Module.memoryInitializerPrefixURL option was removed, use Module.locateFile instead"),Z(typeof n.pthreadMainPrefixURL>"u","Module.pthreadMainPrefixURL option was removed, use Module.locateFile instead"),Z(typeof n.cdInitializerPrefixURL>"u","Module.cdInitializerPrefixURL option was removed, use Module.locateFile instead"),Z(typeof n.filePackagePrefixURL>"u","Module.filePackagePrefixURL option was removed, use Module.locateFile instead"),Z(typeof n.read>"u","Module.read option was removed (modify read_ in JS)"),Z(typeof n.readAsync>"u","Module.readAsync option was removed (modify readAsync in JS)"),Z(typeof n.readBinary>"u","Module.readBinary option was removed (modify readBinary in JS)"),Z(typeof n.setWindowTitle>"u","Module.setWindowTitle option was removed (modify setWindowTitle in JS)"),Z(typeof n.TOTAL_MEMORY>"u","Module.TOTAL_MEMORY has been renamed Module.INITIAL_MEMORY"),fe("asm","wasmExports"),fe("read","read_"),fe("readAsync","readAsync"),fe("readBinary","readBinary"),fe("setWindowTitle","setWindowTitle"),Z(!m,"worker environment detected but not enabled at build time. Add 'worker' to `-sENVIRONMENT` to enable."),Z(!h,"node environment detected but not enabled at build time. Add 'node' to `-sENVIRONMENT` to enable."),Z(!u,"shell environment detected but not enabled at build time. Add 'shell' to `-sENVIRONMENT` to enable.");var C;n.wasmBinary&&(C=n.wasmBinary),fe("wasmBinary","wasmBinary");var y=n.noExitRuntime||!0;fe("noExitRuntime","noExitRuntime"),typeof WebAssembly!="object"&&We("no native wasm support detected");var Y,Q,J=!1,M;function Z(x,D){x||We("Assertion failed"+(D?": "+D:""))}var E,I,B,X,_,P,w,z;function H(){var x=Y.buffer;n.HEAP8=E=new Int8Array(x),n.HEAP16=B=new Int16Array(x),n.HEAP32=_=new Int32Array(x),n.HEAPU8=I=new Uint8Array(x),n.HEAPU16=X=new Uint16Array(x),n.HEAPU32=P=new Uint32Array(x),n.HEAPF32=w=new Float32Array(x),n.HEAPF64=z=new Float64Array(x)}Z(!n.STACK_SIZE,"STACK_SIZE can no longer be set at runtime. Use -sSTACK_SIZE at link time"),Z(typeof Int32Array<"u"&&typeof Float64Array<"u"&&Int32Array.prototype.subarray!=null&&Int32Array.prototype.set!=null,"JS engine does not provide full typed array support"),Z(!n.wasmMemory,"Use of `wasmMemory` detected. Use -sIMPORTED_MEMORY to define wasmMemory externally"),Z(!n.INITIAL_MEMORY,"Detected runtime INITIAL_MEMORY setting. Use -sIMPORTED_MEMORY to define wasmMemory dynamically");var nt;function $(){var x=qW();Z((x&3)==0),x==0&&(x+=4),P[x>>2]=34821223,P[x+4>>2]=2310721022,P[0]=1668509029}function dt(){if(!J){var x=qW();x==0&&(x+=4);var D=P[x>>2],j=P[x+4>>2];(D!=34821223||j!=2310721022)&&We(`Stack overflow! Stack cookie has been overwritten at ${na(x)}, expected hex dwords 0x89BACDFE and 0x2135467, but received ${na(j)} ${na(D)}`),P[0]!=1668509029&&We("Runtime error: The application has corrupted its heap memory area (address zero)!")}}(function(){var x=new Int16Array(1),D=new Int8Array(x.buffer);if(x[0]=25459,D[0]!==115||D[1]!==99)throw"Runtime error: expected the system to be little-endian! (Run with -sSUPPORT_BIG_ENDIAN to bypass)"})();var q=[],at=[],st=[],Et=!1,Qt=0;function Wt(){if(n.preRun)for(typeof n.preRun=="function"&&(n.preRun=[n.preRun]);n.preRun.length;)Mt(n.preRun.shift());Rl(q)}function Nt(){Z(!Et),Et=!0,dt(),!n.noFSInit&&!ht.init.initialized&&ht.init(),ht.ignorePermissions=!1,Ai.init(),Rl(at)}function kt(){if(dt(),n.postRun)for(typeof n.postRun=="function"&&(n.postRun=[n.postRun]);n.postRun.length;)ie(n.postRun.shift());Rl(st)}function Mt(x){q.unshift(x)}function qt(x){at.unshift(x)}function ie(x){st.unshift(x)}Z(Math.imul,"This browser does not support Math.imul(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),Z(Math.fround,"This browser does not support Math.fround(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),Z(Math.clz32,"This browser does not support Math.clz32(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill"),Z(Math.trunc,"This browser does not support Math.trunc(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill");var oe=0,He=null,rn=null,de={};function zt(x){for(var D=x;;){if(!de[x])return x;x=D+Math.random()}}function ke(x){oe++,n.monitorRunDependencies&&n.monitorRunDependencies(oe),x?(Z(!de[x]),de[x]=1,He===null&&typeof setInterval<"u"&&(He=setInterval(()=>{if(J){clearInterval(He),He=null;return}var D=!1;for(var j in de)D||(D=!0,g("still waiting on run dependencies:")),g("dependency: "+j);D&&g("(end of list)")},1e4))):g("warning: run dependency added without ID")}function Ve(x){if(oe--,n.monitorRunDependencies&&n.monitorRunDependencies(oe),x?(Z(de[x]),delete de[x]):g("warning: run dependency removed without ID"),oe==0&&(He!==null&&(clearInterval(He),He=null),rn)){var D=rn;rn=null,D()}}function We(x){n.onAbort&&n.onAbort(x),x="Aborted("+x+")",g(x),J=!0,M=1;var D=new WebAssembly.RuntimeError(x);throw o(D),D}var Vn="data:application/octet-stream;base64,";function Ct(x){return x.startsWith(Vn)}function _t(x){return x.startsWith("file://")}function Je(x){return function(){Z(Et,`native function \`${x}\` called before runtime initialization`);var D=Q[x];return Z(D,`exported native function \`${x}\` not found`),D.apply(null,arguments)}}var xe;xe="data:application/octet-stream;base64,AGFzbQEAAAABtgRHYAF/AX9gAX8AYAJ/fwBgAn9/AX9gA39/fwF/YAZ/f39/f38Bf2AEf39/fwF/YAV/f39/fwF/YAN/f38AYAAAYAR/f39/AGAIf39/f39/f38Bf2AGf39/f39/AGAFf39/f38AYAABf2AHf39/f39/fwF/YAd/f39/f39/AGAFf35+fn4AYAF8AXxgBH98f38Bf2AFf39/f34Bf2ACfHwBfGADf35/AX5gC39/f39/f39/f39/AX9gCn9/f39/f39/f38AYAR/fn5/AGAFf39/f3wBf2ACf3wBf2AEf398fwF/YAZ/f39/fn4Bf2AHf39/f39+fgF/YAN/f38BfGACfH8BfGABfABgBX9/fH9/AGADfHx/AXxgBn98f39/fwF/YAV/f35/fwBgA39/fwF+YAR/f39/AX5gDH9/f39/f39/f39/fwF/YA9/f39/f39/f39/f39/f38AYAh/f39/f39/fwBgDX9/f39/f39/f39/f38AYAl/f39/f39/f38AYAABfGAEfn5+fgF/YAN+fn4Bf2ABfgF/YAJ+fgF8YAJ/fABgAn5+AX1gAn9/AXxgA39/fABgBH98f38AYAR/f3x8AGADf398AX9gAX4BfmAFf39/fH8Bf2AGf39/fH9/AGACfH8Bf2ACfn8Bf2ACf34AYAJ/fwF+YAN/f34AYAJ/fgF/YAR/f39+AX5gA39/fwF9YAl/f39/f39/f38Bf2AKf39/f39/f39/fwF/YAR/f35+AAKxCCUDZW52HGVtc2NyaXB0ZW5fcnVuX3NjcmlwdF9zdHJpbmcAAANlbnYLX19jeGFfdGhyb3cACANlbnYNX2VtdmFsX2RlY3JlZgABA2VudhZfZW1iaW5kX3JlZ2lzdGVyX2NsYXNzACsDZW52Il9lbWJpbmRfcmVnaXN0ZXJfY2xhc3NfY29uc3RydWN0b3IADANlbnYfX2VtYmluZF9yZWdpc3Rlcl9jbGFzc19mdW5jdGlvbgAsA2Vudh9fZW1iaW5kX3JlZ2lzdGVyX2NsYXNzX3Byb3BlcnR5ABgDZW52E19lbXZhbF9nZXRfcHJvcGVydHkAAwNlbnYSX2VtdmFsX25ld19jc3RyaW5nAAADZW52CV9lbXZhbF9hcwAfA2VudhZfZW12YWxfcnVuX2Rlc3RydWN0b3JzAAEDZW52GV9lbWJpbmRfcmVnaXN0ZXJfZnVuY3Rpb24AEANlbnYYZW1zY3JpcHRlbl9hc21fY29uc3RfaW50AAQDZW52FV9lbWJpbmRfcmVnaXN0ZXJfdm9pZAACA2VudhVfZW1iaW5kX3JlZ2lzdGVyX2Jvb2wADQNlbnYbX2VtYmluZF9yZWdpc3Rlcl9zdGRfc3RyaW5nAAIDZW52HF9lbWJpbmRfcmVnaXN0ZXJfc3RkX3dzdHJpbmcACANlbnYWX2VtYmluZF9yZWdpc3Rlcl9lbXZhbAACA2VudhhfZW1iaW5kX3JlZ2lzdGVyX2ludGVnZXIADQNlbnYWX2VtYmluZF9yZWdpc3Rlcl9mbG9hdAAIA2VudhxfZW1iaW5kX3JlZ2lzdGVyX21lbW9yeV92aWV3AAgDZW52E2Vtc2NyaXB0ZW5fZGF0ZV9ub3cALQNlbnYgX2Vtc2NyaXB0ZW5fZ2V0X25vd19pc19tb25vdG9uaWMADhZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxB2ZkX3JlYWQABhZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxCGZkX3dyaXRlAAYWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MQhmZF9jbG9zZQAAA2VudhVlbXNjcmlwdGVuX21lbWNweV9iaWcACANlbnYJX3R6c2V0X2pzAAgDZW52FmVtc2NyaXB0ZW5fcmVzaXplX2hlYXAAAANlbnYFYWJvcnQACRZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxEWVudmlyb25fc2l6ZXNfZ2V0AAMWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MQtlbnZpcm9uX2dldAADA2VudgpzdHJmdGltZV9sAAcDZW52F19lbWJpbmRfcmVnaXN0ZXJfYmlnaW50ABAWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MQdmZF9zZWVrAAcDZW52Cl9ta3RpbWVfanMAAANlbnYKX2dtdGltZV9qcwAIA84EzAQJDgABBAAEBAYJACARAAABAwIuLxkRGRERAAEJDg4ODgEAEREVMAQVMQIyAjMBAgAJAQkBAAACCQAAAQAOAwQ0NQMIAQQSEhU2AhMCIQMBATcDBQIBCQEDAAMICAABCQEOAwgbOAACAwgTOQIEBAEJDgMDAAIBAQICCQAAAgECGxw6HAABAAk7IgkSEhIhCQAJEgAEBBYACQQAFgMjPCAHDwgACj0NAwQkAggAAD4ABhEZCj9ABgQEAwlBAAABAAECBCUKBAQAAAMEBAoKAwABAAEAAQICAAMAAAAAAQABAAADAAEEBAAEAAEBAAMAAAACAgQCAggEAAMBCAIIAgIAAgAEAwIAAwADAgQDAgADAAMDAAMBBkIKBwoEBwoEAgAEBQAPAAABBQAIFwYKBA4mAgUnBQYmBQYFJwUNKEMFHwUKBQQDBQAPAAUDCBcEBQUFBQUNKAUFBQcAAAcKBwQQAhQHFBoEBhAdBwcABxAFBBQHFBoQHQcLAAUFBQwFDAUNBwsLBQUFDAUMBQ0HCw8MDwACAgIAAgIPFwIICAAAAwMPDQ8XAgIAAgADDw0eGCkEBR4YKQQFBAwMAgEIAg4ICAEBAAEAAAAAAgEAAQABAAEAAQIBAQAAAAABAAEAAQABAQIBAQEAAAACAgIBAAAAAgICCwsHBwALCwcBAAsECwcHAAAHAAsHBAYGBgMEAwQGBAcBAAMEAwQGBAcBAAEqKgMDAwMDAQkBCQQEBAMMCg0KCAoNCgQDDRAMDQwMAAAAAAEAIxUHEA9ERUYEBwFwAc4DzgMFBwEBgAyAgAIGFwR/AUGAuRgLfwFBAAt/AUEAC38BQQALB50EGwZtZW1vcnkCABFfX3dhc21fY2FsbF9jdG9ycwAlBm1hbGxvYwAzBGZyZWUANBBpbmZsYXRlRWxsaXBzb2lkALIBFGdldENvdmVyYWdlUG9zaXRpb25zAK0BBmZmbHVzaAC3AQ1fX2dldFR5cGVOYW1lALQBG19lbWJpbmRfaW5pdGlhbGl6ZV9iaW5kaW5ncwC1ARBfX2Vycm5vX2xvY2F0aW9uACYZX19pbmRpcmVjdF9mdW5jdGlvbl90YWJsZQEAC3NldFRlbXBSZXQwAD8VZW1zY3JpcHRlbl9zdGFja19pbml0AEAZZW1zY3JpcHRlbl9zdGFja19nZXRfZnJlZQBBGWVtc2NyaXB0ZW5fc3RhY2tfZ2V0X2Jhc2UAQhhlbXNjcmlwdGVuX3N0YWNrX2dldF9lbmQAQwlzdGFja1NhdmUARAxzdGFja1Jlc3RvcmUARQpzdGFja0FsbG9jAEYcZW1zY3JpcHRlbl9zdGFja19nZXRfY3VycmVudABEIl9fY3hhX2luY3JlbWVudF9leGNlcHRpb25fcmVmY291bnQAzQQVX19jeGFfaXNfcG9pbnRlcl90eXBlAOMEDGR5bkNhbGxfamlqaQDrBA5keW5DYWxsX3ZpaWppaQDsBA5keW5DYWxsX2lpaWlpagDtBA9keW5DYWxsX2lpaWlpamoA7gQQZHluQ2FsbF9paWlpaWlqagDvBAnrBgEAQQELzQNSWlxdXl5fYGFiY2RlZmd6XXt8fX5/gwFdhAFghQGGAYcBiAGJAYoBiwGMAY0BVpMBlAFde2CVAZYBXV5ee5cBmAGWAZkBmgGeAV1eXnt8nwGgAYwBoQGNAaIBowGkAYkBpQGmAaUBpwGoAYwBqwGsAa0BXrMB3AHNAc4B2wGeAjTLAij6A/kD9wPvA/ED8wP1A4kEiASGBP8DgQSDBIUEb44BXpsBnQGbAZwBqgGpAYEBggG7AbkBugG+Ab8BuAHjAeQB5QHmAecB6AG+Ab4B6QHrAewB7QHuAe0BhwKIAuUB5gHnAegBvgG+AYkC6wGLAu0BjALtAeQBsQKyArQCtQL1AfYB9wH4AeAB4gHhAeIB5AGuAqYCrwKwAoACgQKCAoMCiAKpAqoCrAKtAvUB9gH3AfgB4AHiAYgCpQKmAqcCqAKAAoECggKDAsIEwQTmA7kEuAS6BLsEvAS9BPIBvgS/BMAEoQSgBKIEpASmBKcEvgGpBKoEkgSRBJMElASVBJYElwSLBIoEjASNBI4EjwSQBF6bAZsBrQSuBK8EsASxBLIEswS0BPIBtQS2BLcEmwGrBKsEmgQnJ6wEJ5sBnQSeBJoEvgG+AZ8EnASbAZ0EngSaBL4BvgGfBJwEmwGYBJkEmgS+Ab4BmwScBJsBmASZBJoEvgG+AZsEnARemwG9Ar4CvwJemwHAAsECxQKbAcYCzALWAtgC2wLbAt0C3wLjAuUC5wKbAeoC7gLzAvQC9QL1AvYC9wL6AvsC/AKbAf0CgAOGA4cDiAOJA40DjgObAY8DkQOVA5YDlwOYA5oDmwNemwGdA54DnwOgA6IDpAOnA/sD/AP9A/4DgASCBIQEXpsBnQOpA6oDqwOtA68DsgPqA+sD7APtA/AD8gP0A+gD6QOzA+gD6QO1A5sBtgO2A7cDtwO3A7gDvgG5A7kDmwG2A7YDtwO3A7cDuAO+AbkDuQObAboDugO3A7cDtwO7A74BuQO5A5sBugO6A7cDtwO3A7sDvgG5A7kDmwG9A8YDmwHIA9ADmwHSA9YDmwHXA9sDmwHcA90D5QGbAdwD3gPlAV7DBM4EzARemwEoKM8EmwHRBOEE3QTaBJsB2wSbAeUEmwHmBOcE6ATnBJsB4gTgBNgEmwHTBNUE1gSbAeQECpSrCswEwSEDEX8DfgJ8QYC5GCQDQYC5FCQCQbyoFC0AAEUEQCMAQRBrIgIkAEHcpRQQ8wEaQYymFEF/NgIAQYSmFEGUphQ2AgBB/KUUQfiEFDYCAEHcpRRBxJ8TNgIAQZCmFEEAOgAAIAJBDGoiAEHgpRQoAgAiATYCACABIAEoAgRBAWo2AgRB3KUUIABB3KUUKAIAKAIIEQIAIAAoAgAiACAAKAIEQQFrIgE2AgQgAUF/RgRAIAAgACgCACgCCBEBAAsgAkEQaiQAQbygFEGMoRM2AgBBvKAUQfCgEzYCAEG8oBRByKATNgIAQbSgFEG0oBM2AgBBuKAUQQA2AgBBvKAUQdylFBCjAkGcphRB4IMUQcymFBCfAkHkoRRBnKYUEKACQdSmFEHIghRBhKcUEJ8CQYyjFEHUphQQoAJBtKQUQYyjFCgCAEEMaygCAEGkoxRqKAIAEKACQbSgFCgCAEEMaygCAEG0oBRqQeShFDYCSEGMoxQoAgBBDGsoAgBBjKMUaiIBIAEoAgRBgMAAcjYCBEGMoxQoAgBBDGsoAgBBjKMUakHkoRQ2AkgjAEEQayICJABBjKcUEI0CGkG8pxRBfzYCAEG0pxRBxKcUNgIAQaynFEH4hBQ2AgBBjKcUQcyiEzYCAEHApxRBADoAACACQQxqIgBBkKcUKAIAIgE2AgAgASABKAIEQQFqNgIEQYynFCAAQYynFCgCACgCCBECACAAKAIAIgAgACgCBEEBayIBNgIEIAFBf0YEQCAAIAAoAgAoAggRAQALIAJBEGokAEGUoRRBjKETNgIAQZShFEH4oxM2AgBBlKEUQdCjEzYCAEGMoRRBvKMTNgIAQZChFEEANgIAQZShFEGMpxQQowJBzKcUQeCDFEH8pxQQoQJBuKIUQcynFBCiAkGEqBRByIIUQbSoFBChAkHgoxRBhKgUEKICQYilFEHgoxQoAgBBDGsoAgBB+KMUaigCABCiAkGMoRQoAgBBDGsoAgBBjKEUakG4ohQ2AkhB4KMUKAIAQQxrKAIAQeCjFGoiASABKAIEQYDAAHI2AgRB4KMUKAIAQQxrKAIAQeCjFGpBuKIUNgJIQbyoFEEBOgAACyMAQRBrIgIkAAJAIAJBDGogAkEIahAeDQBBwKgUIAIoAgxBAnRBBGoQMyIBNgIAIAFFDQAgAigCCBAzIgAEQEHAqBQoAgAiASACKAIMQQJ0akEANgIAIAEgABAfRQ0BC0HAqBRBADYCAAsgAkEQaiQAQbSKFEIANwIAQbyKFEEANgIAEBUaQcSKFEEDNgIAQciKFEEANgIAEFxByIoUQbCOFCgCADYCAEGwjhRBxIoUNgIAQcyKFEEQNgIAQdCKFEEANgIAQfjyEkHM7xJB9O8SQQBB6PMSQRFBoPESQQBBoPESQQBB+z1B6/MSQRIQA0H48hJBAkGE8BJB+PMSQRNBFBAEQQQQVCIAQQQ2AgBBBBBUIgFBBDYCAEH48hJBhsEAQfD1EkH48xJBFSAAQfD1EkGQ9BJBFiABEAZB0IoUQbCOFCgCADYCAEGwjhRBzIoUNgIAQdSKFEEXNgIAQdiKFEEANgIAEIMBQdiKFEGwjhQoAgA2AgBBsI4UQdSKFDYCACMAQdAAayIDJABCwOKosAYQjwFCgIDf7afiAXwhEiMAQRBrIgEkACABIBJCwIQ9fzcDCCABKQMIIRIgAUEQaiQAIAMgEjcDSBC8ASADKQNIIhGnIBFCIIinQcCOFBAkQeiOFEGywgA2AgBB4I4UQgA3AgBBwI4UQgA3AgBByI4UQQA2AgAQvAFBwI4UECOtIwGtQiCGhELoB34hESMAQTBrIgckAAJAIAdBEGoiCCIBIAdBJGoiBUYNACARQgBZDQAgAUEtOgAAIAFBAWohAUIAIBF9IRELIAcCfyAFIAFrIgJBE0wEQEE9IAJBwAAgEUIBhHmna0HRCWxBDHYiACAAQQN0QaD4E2opAwAgEVhqSA0BGgsCfyARQv////8PWARAIAEgEacQxgQMAQsgEUKAyK+gJVoEfyARQoDIr6AlgCITQoC40N9afiARfCERIAEgE6cQxgQFIAELIBFCgMLXL4AiE6cQxwQgE0KAvqjQD34gEXynEMoECyEFQQALNgIMIAcgBTYCCCADQTBqIgEgCCAHKAIIEJcCGiAHQTBqJAAgA0E8aiABEFsgAywAO0EASARAIAMoAjAQNAsCQAJAAkBBwIoULQAARQRAQeCgEhBUQZ3JAEHXoBIQKyIQQQA6ANegEiADQQA2AjggA0IANwMwA0AgBEEBcUUEQCADQTBqIAQgEGosAAAQkAELIARBAWoiBEHXoBJHDQALQQAhBEGwihQtAABFBEBBpIoUQdAAEFQiATYCAEGoihRCwICAgICKgICAfzcCACABQZrtEikAADcAOCABQZLtEikAADcAMCABQYrtEikAADcAKCABQYLtEikAADcAICABQfrsEikAADcAGCABQfLsEikAADcAECABQersEikAADcACCABQeLsEikAADcAACABQQA6AEBBsIoUQQE6AAALQYAIEFRB/wFBgAgQKSEKQaSKFEGkihQoAgBBr4oULAAAQQBOGyEAA0AgCiAAIARqLAAAQQJ0aiAENgIAIAogACAEQQFyIgFqLAAAQQJ0aiABNgIAIAogACAEQQJyIgFqLAAAQQJ0aiABNgIAIAogACAEQQNyIgFqLAAAQQJ0aiABNgIAIARBBGoiBEHAAEcNAAsCQCADKAI0IAMtADsiASABwEEASCIAGyIBRQRAQQAhBEEAIQEMAQsgAygCMCADQTBqIAAbIg4gAWohB0F4IQtBACEEQQAhAQNAIAogDi0AAEECdGooAgAiAEF/Rg0BIAAgCUEGdGohCQJ/IAtBBmoiACALQXpIDQAaIAkgAHUhCCAEIAZJBEAgBCAIOgAAIARBAWohBCALQQJrDAELIAQgAWsiDEEBaiIFQQBIDQRB/////wcgBiABayICQQF0IgAgBSAAIAVLGyACQf////8DTxsiDQR/IA0QVAVBAAsiDyAMaiICIAg6AAACfyACIAEgBEYNABogAUF/cyAEaiEIQQAhBiACIQUgDEEDcSIABEADQCAFQQFrIgUgBEEBayIELQAAOgAAIAZBAWoiBiAARw0ACwsgDyAIQQNJDQAaA0AgBUEBayAEQQFrLQAAOgAAIAVBAmsgBEECay0AADoAACAFQQNrIARBA2stAAA6AAAgBUEEayIFIARBBGsiBC0AADoAACABIARHDQALIA8LIQAgAQRAIAEQNAsgDSAPaiEGIAJBAWohBCAAIQEgC0ECawshCyAOQQFqIg4gB0cNAAsLIAoQNCADLAA7QQBIBEAgAygCMBA0CyAQEDQgBCABayICQfD///8HTw0CAkAgAkEKTQRAIAMgAjoAOyADQTBqIQUMAQsg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BEL///////////8AgyIJEDdBAEwEQCABIAogAyAJEDcEQCABIQQMAgsgBUHwAGogASACQgBCABA8IAUpA3ghAiAFKQNwIQQMAQsgBEIwiKdB//8BcSEGIAcEfiABBSAFQeAAaiABIApCAEKAgICAgIDAu8AAEDwgBSkDaCIKQjCIp0H4AGshByAFKQNgCyEEIAZFBEAgBUHQAGogAyAJQgBCgICAgICAwLvAABA8IAUpA1giCUIwiKdB+ABrIQYgBSkDUCEDCyAJQv///////z+DQoCAgICAgMAAhCELIApC////////P4NCgICAgICAwACEIQogBiAHSARAA0ACfiAKIAt9IAMgBFatfSIJQgBZBEAgCSAEIAN9IgSEUARAIAVBIGogASACQgBCABA8IAUpAyghAiAFKQMgIQQMBQsgCUIBhiAEQj+IhAwBCyAKQgGGIARCP4iECyEKIARCAYYhBCAHQQFrIgcgBkoNAAsgBiEHCwJAIAogC30gAyAEVq19IglCAFMEQCAKIQkMAQsgCSAEIAN9IgSEQgBSDQAgBUEwaiABIAJCAEIAEDwgBSkDOCECIAUpAzAhBAwBCyAJQv///////z9YBEADQCAEQj+IIQEgB0EBayEHIARCAYYhBCABIAlCAYaEIglCgICAgICAwABUDQALCyAIQYCAAnEhBiAHQQBMBEAgBUFAayAEIAlC////////P4MgB0H4AGogBnKtQjCGhEIAQoCAgICAgMDDPxA8IAUpA0ghAiAFKQNAIQQMAQsgCUL///////8/gyAGIAdyrUIwhoQhAgsgACAENwMAIAAgAjcDCCAFQYABaiQAC1IBAn9BuIIUKAIAIgEgAEEHakF4cSICaiEAAkAgAkEAIAAgAU0bDQAgAD8AQRB0SwRAIAAQHEUNAQtBuIIUIAA2AgAgAQ8LQbCGFEEwNgIAQX8LyCgBC38jAEEQayIKJAACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAIABB9AFNBEBBtIYUKAIAIgZBECAAQQtqQXhxIABBC0kbIgVBA3YiAHYiAUEDcQRAAkAgAUF/c0EBcSAAaiICQQN0IgFB3IYUaiIAIAFB5IYUaigCACIBKAIIIgRGBEBBtIYUIAZBfiACd3E2AgAMAQsgBCAANgIMIAAgBDYCCAsgAUEIaiEAIAEgAkED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ASAANgIMIAQgADYCCCAAQQA2AhggACAENgIMIAAgATYCCAsL2wECAX8CfkEBIQQCQCAAQgBSIAFC////////////AIMiBUKAgICAgIDA//8AViAFQoCAgICAgMD//wBRGw0AIAJCAFIgA0L///////////8AgyIGQoCAgICAgMD//wBWIAZCgICAgICAwP//AFEbDQAgACAChCAFIAaEhFAEQEEADwsgASADg0IAWQRAQX8hBCAAIAJUIAEgA1MgASADURsNASAAIAKFIAEgA4WEQgBSDwtBfyEEIAAgAlYgASADVSABIANRGw0AIAAgAoUgASADhYRCAFIhBAsgBAvAAQIBfwJ+QX8hAwJAIABCAFIgAUL///////////8AgyIEQoCAgICAgMD//wBWIARCgICAgICAwP//AFEbDQAgAkL///////////8AgyIFQoCAgICAgMD//wBWIAVCgICAgICAwP//AFJxDQAgACAEIAWEhFAEQEEADwsgASACg0IAWQRAIAEgAlIgASACU3ENASAAIAEgAoWEQgBSDwsgAEIAUiABIAJVIAEgAlEbDQAgACABIAKFhEIAUiEDCyADC1ABAX4CQCADQcAAcQRAIAEgA0FAaq2GIQJCACEBDAELIANFDQAgAiADrSIEhiABQcAAIANrrYiEIQIgASAEhiEBCyAAIAE3AwAgACACNwMIC6kPAgV/D34jAEHQAmsiBSQAIARC////////P4MhCyACQv///////z+DIQogAiAEhUKAgICAgICAgIB/gyENIARCMIinQf//AXEhCAJAAkAgAkIwiKdB//8BcSIJQf//AWtBgoB+TwRAIAhB//8Ba0GBgH5LDQELIAFQIAJC////////////AIMiDEKAgICAgIDA//8AVCAMQoCAgICAgMD//wBRG0UEQCACQoCAgICAgCCEIQ0MAgsgA1AgBEL///////////8AgyICQoCAgICAgMD//wBUIAJCgICAgICAwP//AFEbRQRAIARCgICAgICAIIQhDSADIQEMAgsgASAMQoCAgICAgMD//wCFhFAEQCADIAJCgICAgICAwP//AIWEUARAQgAhAUKAgICAgIDg//8AIQ0MAwsgDUKAgICAgIDA//8AhCENQgAhAQwCCyADIAJCgICAgICAwP//AIWEUARAQgAhAQwCCyABIAyE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IAFQIAJC////////////AIMiC0KAgICAgIDA//8AVCALQoCAgICAgMD//wBRG0UEQCACQoCAgICAgCCEIQoMAgsgA1AgBEL///////////8AgyICQoCAgICAgMD//wBUIAJCgICAgICAwP//AFEbRQRAIARCgICAgICAIIQhCiADIQEMAgsgASALQoCAgICAgMD//wCFhFAEQCACIAOEUARAQoCAgICAgOD//wAhCkIAIQEMAwsgCkKAgICAgIDA//8AhCEKQgAhAQwCCyADIAJCgICAgICAwP//AIWEUARAIAEgC4QhAkIAIQEgAlAEQEKAgICAgIDg//8AIQoMAwsgCkKAgICAgIDA//8AhCEKDAILIAEgC4RQBEBCACEBDAILIAIgA4RQBEBCACEBDAILIAtC////////P1gEQCAFQdAAaiABIA0gASANIA1QIgYbeSAGQQZ0rXynIgZBD2sQOUEQIAZrIQYgBSkDWCINQiCIIQ4gBSkDUCEBCyACQv///////z9WDQAgBUFAayADIAwgAyAMIAxQIggbeSAIQQZ0rXynIghBD2sQOSAGIAhrQRBqIQYgBSkDSCEMIAUpA0AhAwsgA0IPhiILQoCA/v8PgyICIAFCIIgiBH4iECALQiCIIhMgAUL/////D4MiAX58Ig9CIIYiESABIAJ+fCILIBFUrSACIA1C/////w+DIg1+IhUgBCATfnwiESAMQg+GIhIgA0IxiIRC/////w+DIgMgAX58IhQgDyAQVK1CIIYgD0IgiIR8Ig8gAiAOQoCABIQiDH4iFiANIBN+fCIOIBJCIIhCgICAgAiEIgIgAX58IhAgAyAEfnwiEkIghnwiF3whASAHIAlqIAZqQf//AGshBgJAIAIgBH4iGCAMIBN+fCIEIBhUrSAEIAQgAyANfnwiBFatfCACIAx+fCAEIAQgESAVVK0gESAUVq18fCIEVq18IAMgDH4iAyACIA1+fCICIANUrUIghiACQiCIhHwgBCACQiCGfCICIARUrXwgAiACIBAgElatIA4gFlStIA4gEFatfHxCIIYgEkIgiIR8IgJWrXwgAiACIA8gFFStIA8gF1atfHwiAlatfCIEQoCAgICAgMAAg0IAUgRAIAZBAWohBgwBCyALQj+IIQMgBEIBhiACQj+IhCEEIAJCAYYgAUI/iIQhAiALQgGGIQsgAyABQgGGhCEBCyAGQf//AU4EQCAKQoCAgICAgMD//wCEIQpCACEBDAELAn4gBkEATARAQQEgBmsiB0H/AE0EQCAFQTBqIAsgASAGQf8AaiIGEDkgBUEgaiACIAQgBhA5IAVBEGogCyABIAcQOyAFIAIgBCAHEDsgBSkDMCAFKQM4hEIAUq0gBSkDICAFKQMQhIQhCyAFKQMoIAUpAxiEIQEgBSkDACECIAUpAwgMAgtCACEBDAILIARC////////P4MgBq1CMIaECyAKhCEKIAtQIAFCAFkgAUKAgICAgICAgIB/URtFBEAgCiACQgF8IgFQrXwhCgwBCyALIAFCgICAgICAgICAf4WEQgBSBEAgAiEBDAELIAogAiACQgGDfCIBIAJUrXwhCgsgACABNwMAIAAgCjcDCCAFQeAAaiQAC3UBAX4gACABIAR+IAIgA358IANCIIgiAiABQiCIIgR+fCADQv////8PgyIDIAFC/////w+DIgF+IgVCIIggAyAEfnwiA0IgiHwgASACfiADQv////8Pg3wiAUIgiHw3AwggACAFQv////8PgyABQiCGhDcDAAumAQEBfwJ/AkAgACgCTCIBQQBOBEAgAUUNAUHEnxQoAgAgAUH/////e3FHDQELIAAoAgQiASAAKAIIRwRAIAAgAUEBajYCBCABLQAADAILIAAQ0QEMAQsgACAAKAJMIgFB/////wMgARs2AkwCfyAAKAIEIgEgACgCCEcEQCAAIAFBAWo2AgQgAS0AAAwBCyAAENEBCyEBIAAoAkwaIABBADYCTCABCwsGACAAJAELDgBBgLkYJANBgLkUJAILBwAjACMCawsEACMDCwQAIwILBAAjAAsGACAAJAALEAAjACAAa0FwcSIAJAAgAAvFCQIEfwV+IwBB8ABrIgYkACAEQv///////////wCDIQkCQAJAIAFQIgUgAkL///////////8AgyIKQoCAgICAgMD//wB9QoCAgICAgMCAgH9UIApQG0UEQCADQgBSIAlCgICAgICAwP//AH0iC0KAgICAgIDAgIB/ViALQoCAgICAgMCAgH9RGw0BCyAFIApCgICAgICAwP//AFQgCkKAgICAgIDA//8AURtFBEAgAkKAgICAgIAghCEEIAEhAwwCCyADUCAJQoCAgICAgMD//wBUIAlCgICAgICA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AUYNACABIAAgAmoiBGtBACACQQF0a00EQCAAIAEgAhArDwsgACABc0EDcSEDAkACQCAAIAFJBEAgAwRAIAAhAwwDCyAAQQNxRQRAIAAhAwwCCyAAIQMDQCACRQ0EIAMgAS0AADoAACABQQFqIQEgAkEBayECIANBAWoiA0EDcQ0ACwwBCwJAIAMNACAEQQNxBEADQCACRQ0FIAAgAkEBayICaiIDIAEgAmotAAA6AAAgA0EDcQ0ACwsgAkEDTQ0AA0AgACACQQRrIgJqIAEgAmooAgA2AgAgAkEDSw0ACwsgAkUNAgNAIAAgAkEBayICaiABIAJqLQAAOgAAIAINAAsMAgsgAkEDTQ0AA0AgAyABKAIANgIAIAFBBGohASADQQRqIQMgAkEEayICQQNLDQALCyACRQ0AA0AgAyABLQAAOgAAIANBAWohAyABQQFqIQEgAkEBayICDQALCyAAC5AEAgR+An8CQAJAIAG9IgRCAYYiA1ANACABvSECIAC9IgVCNIinQf8PcSIGQf8PRg0AIAJC////////////AINCgYCAgICAgPj/AFQNAQsgACABoiIAIACjDwsgAyAFQgGGIgJaBEAgAEQAAAAAAAAAAKIgACACIANRGw8LIARCNIinQf8PcSEHAn4gBkUEQEEAIQYgBUIMhiICQgBZBEADQCAGQQFrIQYgAkIBhiICQgBZDQALCyAFQQEgBmuthgwBCyAFQv////////8Hg0KAgICAgICACIQLIQICfiAHRQRAQQAhByAEQgyGIgNCAFkEQANAIAdBAWshByADQgGGIgNCAFkNAAsLIARBASAHa62GDAELIARC/////////weDQoCAgICAgIAIhAshBCAGIAdKBEADQAJAIAIgBH0iA0IAUw0AIAMiAkIAUg0AIABEAAAAAAAAAACiDwsgAkIBhiECIAZBAWsiBiAHSg0ACyAHIQYLAkAgAiAEfSIDQgBTDQAgAyICQgBSDQAgAEQAAAAAAAAAAKIPCwJAIAJC/////////wdWBEAgAiEDDAELA0AgBkEBayEGIAJCgICAgICAgARUIQcgAkIBhiIDIQIgBw0ACwsgBUKAgICAgICAgIB/gyECIAZBAEoEfiADQoCAgICAgIAIfSAGrUI0hoQFIANBASAGa62ICyAChL8L0QMCAn4CfyMAQSBrIgQkAAJAIAFC////////////AIMiA0KAgICAgIDAgDx9IANCgICAgICAwP/DAH1UBEAgAUIEhiAAQjyIhCEDIABC//////////8PgyIAQoGAgICAgICACFoEQCADQoGAgICAgICAwAB8IQIMAgsgA0KAgICAgICAgEB9IQIgAEKAgICAgICAgAhSDQEgAiADQgGDfCECDAELIABQIANCgICAgICAwP//AFQgA0KAgICAgIDA//8AURtFBEAgAUIEhiAAQjyIhEL/////////A4NCgICAgICAgPz/AIQhAgwBC0KAgICAgICA+P8AIQIgA0L///////+//8MAVg0AQgAhAiADQjCIpyIFQZH3AEkNACAEQRBqIAAgAUL///////8/g0KAgICAgIDAAIQiAiAFQYH3AGsQOSAEIAAgAkGB+AAgBWsQOyAEKQMIQgSGIAQpAwAiAEI8iIQhAiAEKQMQIAQpAxiEQgBSrSAAQv//////////D4OEIgBCgYCAgICAgIAIWgRAIAJCAXwhAgwBCyAAQoCAgICAgICACFINACACQgGDIAJ8IQILIARBIGokACACIAFCgICAgICAgICAf4OEvwt+AgJ/AX4jAEEQayIDJAAgAAJ+IAFFBEBCAAwBCyADIAEgAUEfdSICcyACayICrUIAIAJnIgJB0QBqEDkgAykDCEKAgICAgIDAAIVBnoABIAJrrUIwhnwgAUGAgICAeHGtQiCGhCEEIAMpAwALNwMAIAAgBDcDCCADQRBqJAAL+QECA34CfyMAQRBrIgUkAAJ+IAG9IgNC////////////AIMiAkKAgICAgICACH1C/////////+//AFgEQCACQjyGIQQgAkIEiEKAgICAgICAgDx8DAELIAJCgICAgICAgPj/AFoEQCADQjyGIQQgA0IEiEKAgICAgIDA//8AhAwBCyACUARAQgAMAQsgBSACQgAgA6dnQSBqIAJCIIinZyACQoCAgIAQVBsiBkExahA5IAUpAwAhBCAFKQMIQoCAgICAgMAAhUGM+AAgBmutQjCGhAshAiAAIAQ3AwAgACACIANCgICAgICAgICAf4OENwMIIAVBEGokAAtjAgF/AX4jAEEQayICJAAgAAJ+IAFFBEBCAAwBCyACIAGtQgAgAWciAUHRAGoQOSACKQMIQoCAgICAgMAAhUGegAEgAWutQjCGfCEDIAIpAwALNwMAIAAgAzcDCCACQRBqJAALtAMCA38BfiMAQSBrIgMkAAJAIAFC////////////AIMiBUKAgICAgIDAwD99IAVCgICAgICAwL/AAH1UBEAgAUIZiKchBCAAUCABQv///w+DIgVCgICACFQgBUKAgIAIURtFBEAgBEGBgICABGohAgwCCyAEQYCAgIAEaiECIAAgBUKAgIAIhYRCAFINASACIARBAXFqIQIMAQsgAFAgBUKAgICAgIDA//8AVCAFQoCAgICAgMD//wBRG0UEQCABQhmIp0H///8BcUGAgID+B3IhAgwBC0GAgID8ByECIAVC////////v7/AAFYNAEEAIQIgBUIwiKciBEGR/gBJDQAgA0EQaiAAIAFC////////P4NCgICAgICAwACEIgUgBEGB/gBrEDkgAyAAIAVBgf8AIARrEDsgAykDCCIAQhmIpyECIAMpAwAgAykDECADKQMYhEIAUq2EIgVQIABC////D4MiAEKAgIAIVCAAQoCAgAhRG0UEQCACQQFqIQIMAQsgBSAAQoCAgAiFhEIAUg0AIAJBAXEgAmohAgsgA0EgaiQAIAIgAUIgiKdBgICAgHhxcr4LGABBv4oULAAAQQBIBEBBtIoUKAIAEDQLC2oBA38gARAvIgJB8P///wdJBEACQCACQQpNBEAgACACOgALIAAhAwwBCyACQQ9yQQFqIgQQVCEDIAAgBEGAgICAeHI2AgggACADNgIAIAAgAjYCBAsgAyABIAIQSyACakEAOgAADwsQVQALNgEBf0EBIAAgAEEBTRshAAJAA0AgABAzIgENAUHwuBQoAgAiAQRAIAERCQAMAQsLEB0ACyABCwgAQag/EFgACxgAQa+KFCwAAEEASARAQaSKFCgCABA0CwsIAEG7PBBYAAthAQN/QQgQWSIBQayCFDYCACABQdiAFDYCACAAEC8iAkENahBUIgNBADYCCCADIAI2AgQgAyACNgIAIAEgA0EMaiAAIAJBAWoQKzYCBCABQYiBFDYCACABQaiBFEECEAEACw4AIABB0ABqEDNB0ABqCzIBAn8gAEHYgBQ2AgAgACgCBEEMayIBIAEoAghBAWsiAjYCCCACQQBIBEAgARA0CyAAC/QLAgV/BX4jAEEwayIFJAACQEHYABAzIgRFDQAgBEEEay0AAEEDcUUN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OQOIASAAQRhqIgQhAQJAAkAgACgCGCIDRQ0AA0AgAyIBKwMQIgsgKmQEQCABIgQoAgAiAw0BDAILIAsgKmNFDQIgASgCBCIDDQALIAFBBGohBAtB8AcQVCIDICo5AxAgA0EYakEAQdgHECkaIAMgATYCCCADQgA3AgAgBCADNgIAIAMhASAAKAIUKAIAIgUEQCAAIAU2AhQgBCgCACEBCyAAKAIYIAEQbiAAIAAoAhxBAWo2AhwLIANBGGogAkEYaiIBQdgHECsaIABBoAFqIAFB2AcQKxogAiwA+wdBAEgEQCACKALwBxA0CyACLACHCEEASARAIAIoAvwHEDQLIAIsAJMIQQBIBEAgAigCiAgQNAsgAkHwCGokAEEADwsQVQALXQECfyMAQRBrIgMkACABIAAoAgQiBEEBdWohASAAKAIAIQAgBEEBcQRAIAEoAgAgAGooAgAhAAsgAyACNgIMIAEgA0EMaiAAEQMAIQAgAygCDBACIANBEGokACAACw0AIAEgACgCAGorAwALDwAgASAAKAIAaiACOQMACw0AIAEgACgCAGooAgALDwAgASAAKAIAaiACNgIACxkAIAAEQCAAKAIAEGggACgCBBBoIAAQNAsLKAEBfyMAQRBrIgMkACADIAI2AgwgACABIAIQvQEhACADQRBqJAAgAAvHAQECfyMAQRBrIgEkAAJ8IAC9QiCIp0H/////B3EiAkH7w6T/A00EQEQAAAAAAADwPyACQZ7BmvIDSQ0BGiAARAAAAAAAAAAAEOoEDAELIAAgAKEgAkGAgMD/B08NABoCQAJAAkACQCAAIAEQwgFBA3EOAwABAgMLIAErAwAgASsDCBDqBAwDCyABKwMAIAErAwhBARDpBJoMAgsgASsDACABKwMIEOoEmgwBCyABKwMAIAErAwhBARDpBAshACABQRBqJAAgAAvLAQECfyMAQRBrIgEkAAJAIAC9QiCIp0H/////B3EiAkH7w6T/A00EQCACQYCAwPIDSQ0BIABEAAAAAAAAAABBABDpBCEADAELIAJBgIDA/wdPBEAgACAAoSEADAELAkACQAJAAkAgACABEMIBQQNxDgMAAQIDCyABKwMAIAErAwhBARDpBCEADAMLIAErAwAgASsDCBDqBCEADAILIAErAwAgASsDCEEBEOkEmiEADAELIAErAwAgASsD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QR8gAEEAQQAQBUEIEFQiAEEANgIEIABBIDYCAEEIEFQiAUEANgIEIAFBITYCAEHo9BJB6jpBwP0TQfjzEkEiIABBwP0TQZD0EkEjIAEQBgvAAQEDfyAABEAgAEGU8BI2AgACQEHoixQoAgAiAkHkixRGDQAgAiEBAkADQAJAIAEoAgQhAyABKAIIIABGDQAgAyIBQeSLFEcNAQwCCwsgASgCACICIAM2AgQgASgCBCACNgIAQeyLFEHsixQoAgBBAWs2AgAgARA0QeiLFCgCACECCyACQeSLFEYNAEEAIQEDQCACKAIIIAE2AhAgAUEBaiEBIAIoAgQiAkHkixRHDQALC0HwixRBAToAACAAEDQLC28BA39BFBBUIgFBAToABCABQZTwEjYCAEEMEFQiAEHkixQ2AgQgACABNgIIIABB5IsUKAIAIgI2AgAgAiAANgIEQeSLFCAANgIAQeyLFEHsixQoAgAiAEEBajYCACABIAA2AhBB8IsUQQE6AAAgAQsNACABIAAoAgBqLQAACw8AIAEgACgCAGogAjoAAAseACAAIAEgACgCCEEAIAAoAgAoAgAREwAaIAAoAggLNwEBfyABIAAoAgQiA0EBdWohASAAKAIAIQAgASACIANBAXEEfyABKAIAIABqKAIABSAACxEbAAsHACAAKAIQCwkAIAAgATYCEAs1AQF/IAEgACgCBCICQQF1aiEBIAAoAgAhACABIAJBAXEEfyABKAIAIABqKAIABSAACxEAAAs3AQF/IAEgACgCBCIDQQF1aiEBIAAoAgAhACABIAIgA0EBcQR/IAEoAgAgAGooAgAFIAALEQIACwQAQQALQwEDfyMAQSBrIgEkACABQQhqIgMgADcDACABQRhqIgIgAUEQaiADKQMAEN8BKQMANwMAIAIpAwAhACABQSBqJAAgAAuUAQECfwJAAkACQAJAIAAtAAsiA0GAAXFBB3YEQCAAKAIEIgMgACgCCEH/////B3FBAWsiAkYNAQwCC0EKIQIgA0H/AHEiA0EKRw0CCyAAIAJBASACIAIQxwMgAiEDCyAAKAIAIQIgACADQQFqNgIEDAELIAAgA0EBajoACyAAIQILIAIgA2oiACABOgAAIABBADoAAQvjAQECfyACQQBHIQMCQAJAAkAgAEEDcUUNACACRQ0AIAFB/wFxIQQDQCAALQAA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DCABRg0ADAELIAZC/////3dXBEAgAkEENgIADAMLIAZCgICAgAhZBEAgAkEENgIAQf////8HDAQLIAanDAMLCyACQQQ2AgBBAAwBC0GAgICAeAshACAEQRBqJAAgAAvaAQEDfyAAKAIEIAAtAAsiBEH/AHEgBEGAAXFBB3YbIQQCQCACIAFrQQVIDQAgBEUNACABIAIQ1QIgAkEEayEEIAAoAgQgAC0ACyICQf8AcSACQYABcUEHdhsgACgCACAAIAJBgAFxQQd2GyICaiEGAkADQAJAIAIsAAAiAEH/AGshBSABIARPDQAgBUH/AXFBggFPBEAgASgCACAARw0DCyABQQRqIQEgAiAGIAJrQQFKaiECDAELCyAFQf8BcUGCAUkNASAEKAIAQQFrIABJDQELIANBBDYCAAsLMgAgAkH/AXEhAgNAAkAgACABRwR/IAAtAAAgAkcNASAABSABCw8LIABBAWohAAwACwAL1AIBA39B3KoULQAABEBB2KoUKAIADwsjAEEgayIBJAACQAJAA0AgAUEIaiAAQQJ0aiAAQfjDAEH87RJBASAAdEH/////B3EbELgCIgI2AgAgAkF/Rg0BIABBAWoiAEEGRw0AC0Gc9hMhACABQQhqQZz2E0EYEJIBRQ0BQbT2EyEAIAFBCGpBtPYTQRgQkgFFDQFBACEAQfioFC0AAEUEQANAIABBAnRByKgUaiAAQfztEhC4AjYCACAAQQFqIgBBBkcNAAtB+KgUQQE6AABB4KgUQcioFCgCADYCAAtByKgUIQAgAUEIakHIqBRBGBCSAUUNAUHgqBQhACABQQhqQeCoFEEYEJIBRQ0BQRgQMyIARQ0AIAAgASkCCDcCACAAIAEpAhg3AhAgACABKQIQNwIIDAELQQAhAAsgAUEgaiQAQdyqFEEBOgAAQdiqFCAANgIAIAALFgAgACABIAJCgICAgICAgICAfxC7Ags/AQF/AkAgACABRg0AA0AgACABQQRrIgFPDQEgACgCACECIAAgASgCADYCACABIAI2AgAgAEEEaiEADAALAAsL5QQBAn8gAygCBCEAIAMoAhwhBiMAQeABayIDJAAgAyACNgLYASADIAE2AtwBIAAQzQIhByADQcgBaiAGIANB1wFqEM4CIANBvAFqIgJCADcCACACQQA2AgggAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCZAiADIAIoAgAgAiACLQALQYABcUEHdhsiBjYCuAEgAyADQRBqNgIMIANBADYCCANAAkAgA0HcAWogA0HYAWoQ/AENACADKAK4ASAGIAIoAgQgAi0ACyIAQf8AcSAAQYABcUEHdhsiAGpGBEAgAiAAQQF0EJkCIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQmQIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgYgAGo2ArgBCwJ/IAMoAtwBIgAoAgwiASAAKAIQRgRAIAAgACgCACgCJBEAAAwBCyABLQAAC8AgByAGIANBuAFqIANBCGogAywA1wEgAygCzAEgAy0A0wEgA0EQaiADQQxqQaDAExDPAg0AIANB3AFqEP4BGgwBCwsgAygCDCEAAkACQCADKALMASADLQDTASIBQf8AcSABQYABcUEHdhtFDQAgACADQRBqa0GfAUoNACADIABBBGoiATYCDCAAIAMoAgg2AgAMAQsgACEBCyAFIAYgAygCuAEgBCAHENcCNwMAIANByAFqIANBEGogASAEENECIANB3AFqIANB2AFqEPwBBEAgBCAEKAIAQQJyNgIACyADKALcASEAIAIQyQIaIANByAFqEMkCGiADQeABaiQAIAALrQECAn8BfiMAQRBrIgQkAAJAIAAgAUcEQEGwhhQoAgAhBUGwhhRBADYCABDTAhogACAEQQxqIAMQ1AIhBgJAQbCGFCgCACIABEAgBCgCDCABRw0BIABBxABHDQMgAkEENgIAQv///////////wBCgICAgICAgICAfyAGQgBVGyEGDAMLQbCGFCAFNgIAIAQoAgwgAUYNAgsLIAJBBDYCAEIAIQYLIARBEGokACAGC+UEAQJ/IAMoAgQhACADKAIcIQYjAEHgAWsiAyQAIAMgAjYC2AEgAyABNgLcASAAEM0CIQcgA0HIAWogBiADQdcBahDOAiADQbwBaiICQgA3AgAgAkEANgIIIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQmQIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgY2ArgBIAMgA0EQajYCDCADQQA2AggDQAJAIANB3AFqIANB2AFqEPwBDQAgAygCuAEgBiACKAIEIAItAAsiAEH/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KAL8ASEAIAIQyQIaIANBwAFqEMkCGiADQYACaiQAIAALtgECA38CfCMAQRBrIgMkAAJAAkACQCAAIAFHBEBBsIYUKAIAIQVBsIYUQQA2AgAQ0wIaIwBBEGsiBCQAIAQgACADQQxqQQEQvAIgBCkDACAEKQMIEE0hBiAEQRBqJABBsIYUKAIAIgBFDQEgAygCDCABRw0CIAYhByAAQcQARw0DDAILIAJBBDYCAAwCC0GwhhQgBTYCACADKAIMIAFGDQELIAJBBDYCACAHIQYLIANBEGokACAGC6MFAgN/AX4gAygCHCEAIwBBkAJrIgMkACADIAI2AogCIAMgATYCjAIgA0HQAWogACADQeABaiADQd8BaiADQd4BahDgAiADQcQBaiICQgA3AgAgAkEANgIIIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQmQIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgY2AsABIAMgA0EgajYCHCADQQA2AhggA0EBOgAXIANBxQA6ABYgAy0A3gHAIQEgAy0A3wHAIQcDQAJAIANBjAJqIANBiAJqEPwBDQAgAygCwAEgBiACKAIEIAItAAsiAEH/AHEgAEGAAXFBB3YbIgBqRgRAIAIgAEEBdBCZAiACIAItAAtBgAFxQQd2BH8gAigCCEH/////B3FBAWsFQQoLEJkCIAMgAigCACACIAItAAtBgAFxQQd2GyIGIABqNgLAAQsCfyADKAKMAiIAKAIMIgggACgCEEYEQCAAIAAoAgAoAiQRAAAMAQsgCC0AAAvAIANBF2ogA0EWaiAGIANBwAFqIAcgASADQdABaiADQSBqIANBHGogA0EYaiADQeABahDhAg0AIANBjAJqEP4BGgwBCwsgAygCHCEAAkACQCADKALUASADLQDbASIBQf8AcSABQYABcUEHdhtFDQAgAy0AF0UNACAAIANBIGprQZ8BSg0AIAMgAEEEaiIBNgIcIAAgAygCGDYCAAwBCyAAIQELIAMgBiADKALAASAEEOYCIAMpAwAhCSAFIAMpAwg3AwggBSAJNwMAIANB0AFqIANBIGogASAEENECIANBjAJqIANBiAJqEPwBBEAgBCAEKAIAQQJyNgIACyADKAKMAiEAIAIQyQIaIANB0AFqEMkCGiADQZACaiQAIAALsgICBH4F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ACADIAI2AvgCIAMgATYC/AIgA0HcAWogACADQfABaiADQewBaiADQegBahD4AiADQdABaiICQgA3AgAgAkEANgIIIAIgAi0AC0GAAXFBB3YEfyACKAIIQf////8HcUEBawVBCgsQmQIgAyACKAIAIAIgAi0AC0GAAXFBB3YbIgY2AswBIAMgA0EgajYCHCADQQA2AhggA0EBOgAXIANBxQA6ABYgAygC6AEhASADKALsASEHA0ACQCADQfwCaiADQfgCahCRAg0AIAMoAswBIAYgAigCBCACLQALIgBB/wBxIABBgAFxQQd2GyIAakYEQCACIABBAXQQmQIgAiACLQALQYABcUEHdgR/IAIoAghB/////wdxQQFrBUEKCxCZAiADIAIoAgAgAiACLQALQYABcUEHdhsiBiAAajYCzAELAn8gAygC/AIiACgCDCIIIAAoAhBGBEAgACAAKAIAKAIkEQAADAELIAgoAgALIANBF2ogA0EWaiAGIANBzAFqIAcgASADQdwBaiADQSBqIANBHGogA0EYaiADQfABahD5Ag0AIANB/AJqEJMCGgwBCwsgAygCHCEAAkACQCADKALgASADLQDnASIBQf8AcSABQYABcUEHdhtFDQAgAy0AF0UNACAAIANBIGprQZ8BSg0AIAMgAEEEaiIBNgIcIAAgAygCGDYCAAwBCyAAIQELIAMgBiADKALMASAEEOYCIAMpAwAhCSAFIAMpAwg3AwggBSAJNwMAIANB3AFqIANBIGogASAEENECIANB/AJqIANB+AJqEJECBEAgBCAEKAIAQQJyNgIACyADKAL8AiEAIAIQyQIaIANB3AFqEMkCGiADQYADaiQAIAALiwUBAn8jAEHAAmsiACQAIAAgAjYCuAIgACABNgK8AiAAQcQBaiIHQgA3AgAgB0EANgIIIABBEGoiBiADKAIcIgE2AgAgASABKAIEQQFqNgIEIAAoAhAQkAIiAUGgwBNBusATIABB0AFqIAEoAgAoAjARBgAaIAAoAhAiASABKAIEQQFrIgI2AgQgAkF/RgRAIAEgASgCACgCCBEBAAsgAEG4AWoiAkIANwIAIAJBADYCCCACIAItAAtBgAFxQQd2BH8gAigCCEH/////B3FBAWsFQQoLEJkCIAAgAigCACACIAItAAtBgAFxQQd2GyIDNgK0ASAAIAY2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QZABaiIIIAQoAhwiATYCACABIAEoAgRBAWo2AgQgACgCkAEQ+wEhASAAQQA6AI8BAkAgAEGMAmogAiADIAggBCgCBCAFIABBjwFqIAEgByAAQZQBaiAAQYQCahC+A0UNACAAQdXqEigAADYAhwEgAEHO6hIpAAA3A4ABIAEgAEGAAWogAEGKAWogAEH2AGogASgCACgCIBEGABogAEHUADYCECAAQQhqIgNBADYCACADIABBEGoiBCgCADYCBAJAIAAoApQBIgEgBygCAGsiAkHjAE4EQCACQQJqEDMhBCADKAIAIQIgAyAENgIAIAIEQCACIAMoAgQRAQALIAMoAgAiBEUNAQsgAC0AjwEEQCAEQS06AAAgBEEBaiEECyAHKAIAIQIDQCABIAJNBEACQCAEQQA6AAAgACAGNgIAIABBEGpBgcAAIAAQaUEBRw0AIAMoAgAhASADQQA2AgAgAQRAIAEgAygCBBEBAAsMBAsFIAQgAEH2AGoiASABQQpqIAItAAAQ0gIgAGsgAGotAAo6AAAgBEEBaiEEIAJBAWohAiAAKAKUASEBDAELCxDeAQALEN4BAAsgAEGMAmogAEGIAmoQ/AEEQCAFIAUoAgBBAnI2AgALIAAoAowCIQIgACgCkAEiASABKAIEQQFrIgM2AgQgA0F/RgRAIAEgASgCACgCCBEBAAsgBygCACEBIAdBADYCACABBEAgASAHKAIEEQEACyAAQZACaiQAIAILhhgBD38jAEGQBGsiCyQAIAsgCjYCiAQgCyABNgKMBAJAIAAgC0GMBGoQ/AEEQCAFIAUoAgBBBHI2AgBBACEADAELIAtB1gA2AkwgC0HoAGoiASALQfAAajYCACABIAtBzABqIhEoAgA2AgQgCyABIhMoAgAiDjYCZCALIA5BkANqNgJgIBFCADcCACARQQA2AgggC0FAayIPQgA3AgAgD0EANgIIIAtBNGoiDEIANwIAIAxBADYCCCALQShqIg1CADcCACANQQA2AgggC0EcaiISQgA3AgAgEkEANgIIIAMoAgAhASMAQRBrIgMkACALAn8gAgRAIANBBGoiAiABEMIDIgEgASgCACgCLBECACALIAMoAgQ2AFwgAiABIAEoAgAoAiARAgAgDSACEJYCIAIQyQIaIAIgASABKAIAKAIcEQIAIAwgAhCWAiACEMkCGiAL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aiEMIABB0AJqIQgMAQsQ0wIhCiAAIAU3AwAgACAGNwMIIABBzAJqIApB+z8gABCLAyIKQX9GDQEgCygCACEHIAsgACgCzAIiCDYCACAHBEAgByALKAIEEQEACyAKEDMhDCAAKALQASEHIAAgDDYC0AEgBwRAIAcgACgC1AERAQALIAAoAtABIgxFDQELIAAgAygCHCIHNgLMASAHIAcoAgRBAWo2AgQgACgCzAEQ+wEiECIHIAggCCAKaiAMIAcoAgAoAiARBgAaIApBAEoEQCAILQAAQS1GIQ4LIABBuAFqIg1CADcCACANQQA2AgggAEGsAWoiCEIANwIAIAhBADYCCCAAQaABaiIHQgA3AgAgB0EANgIIIAIgDiAAKALMASAAQcgBaiAAQccBaiAAQcYBaiANIAggByAAQZwBahDTAyAAQdQANgIwIABBADYCKCAAIABBMGoiAigCADYCLAJ/IAAoApwBIg8gCkgEQCAKIA9rQQF0IAcoAgQgBy0ACyIJQf8AcSAJQYABcUEHdhtqIAgoAgQgCC0ACyIJQf8AcSAJQYABcUEHdhtqQQFqDAELIAcoAgQgBy0ACyIJQf8AcSAJQYABcUEHdhsgCCgCBCAILQALIglB/wBxIAlBgAFxQQd2G2pBAmoLIA9qIglB5QBPBEAgCRAzIQkgACgCKCECIAAgCTYCKCACBEAgAiAAKAIsEQEACyAAKAIoIgJFDQELIAIgAEEkaiAAQSBqIAMoAgQgDCAKIAxqIBAgDiAAQcgBaiAALADHASAALADGASANIAggByAPENQDIAEgAiAAKAIkIAAoAiAgAyAEEHchAiAAKAIoIQEgAEEANgIoIAEEQCABIAAoAiwRAQALIAcQyQIaIAgQyQIaIA0QyQIaIAAoAswBIgEgASgCBEEBayIDNgIEIANBf0YEQCABIAEoAgAoAggRAQALIAAoAtABIQEgAEEANgLQASABBEAgASAAKALUAREBAAsgCygCACEBIAtBADYCACABBEAgASALKAIEEQEACyAAQcADaiQAIAIPCxDeAQAL7wMBAX8jAEEQayIKJAAgCQJ/IAAEQCACEMIDIQACQCABBEAgCkEEaiIBIAAgACgCACgCLBECACADIAooAgQ2AAAgASAAIAAoAgAoAiARAgAMAQsgCkEEaiIBIAAgACgCACgCKBECACAD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eQBTYXR1cmRheQBTdW5kYXkATW9uZGF5AEZyaWRheQBNYXkAJW0vJWQvJXkAJTAxNmxseABhcnJheV9pbmRleABlcGhlbWVyaXNfc3RhcnRfaWR4AC0rICAgMFgweAAtMFgrMFggMFgtMHgrMHggMHgATm92AFRodQBBdWd1c3QAdW5zaWduZWQgc2hvcnQAZXBoZW1lcmlzX3N0YXJ0AHVuc2lnbmVkIGludABPY3QAZmxvYXQAU2F0AHVpbnQ2NF90AFN1YmNsYXNzAGdldENvdmVyYWdlUG9zaXRpb25zAHNlbWlfbWlub3JfYXhpcwBzZW1pX21ham9yX2F4aXMAQXByAHZlY3RvcgBnZXRWZWxvY2l0eVBvaW50ZXIAT2N0b2JlcgBOb3ZlbWJlcgBTZXB0ZW1iZXIARGVjZW1iZXIAdW5zaWduZWQgY2hhcgBNYXIAYWx0cABlcGhlbWVyaXNfc3RvcAB1bml4X3RpbWVzdGFtcABlcGhlbWVyaXNfc3RlcABTZXAAJUk6JU06JVMgJXAAaW5jbG8AZWNjbwBTdW4ASnVuAHN0ZDo6ZXhjZXB0aW9uAGdldFBvc2l0aW9uAEVudGl0eUNvbGxlY3Rpb24ATW9uAG5hbgBKYW4AUmVjZWl2ZWQ6ICVzXG4AcmFkaXVzZWFydGhrbQBKdWwAYm9vbAByZW1vdmVBbGwAQXByaWwAZW1zY3JpcHRlbjo6dmFsAEZyaQBiYWRfYXJyYXlfbmV3X2xlbmd0aABNYXJjaABBdWcAdW5zaWduZWQgbG9uZwB0ZXJtaW5hdGluZwBzdGQ6OndzdHJpbmcAYmFzaWNfc3RyaW5nAHN0ZDo6c3RyaW5nAHN0ZDo6dTE2c3RyaW5nAHN0ZDo6dTMyc3RyaW5nAGluZgAlNGQtJTJkLSUyZFQlMmQ6JTJkOiVsZgAlLjBMZgAlTGYAc2l6ZQB0cnVlAFR1ZQB1cGRhdGUAZmFsc2UAdGFrZUJhc2UASnVuZQBnZXRQb3NpdGlvbkluUmVmZXJlbmNlRnJhbWUAZ2V0TmFtZQBkb3VibGUAdmlzaWJsZQBhcG9nZWUAcGVyaWdlZQBwZXJpb2QAdm9pZABub3JhZF9jYXRfaWQAdGVybWluYXRlX2hhbmRsZXIgdW5leHBlY3RlZGx5IHJldHVybmVkAFdlZABzdGQ6OmJhZF9hbGxvYwBwZXJpb2Rfc2VjAERlYwBGZWIAYWx0YQBFQ0NFTlRSSUNJVFkATUVBTl9BTk9NQUxZACVhICViICVkICVIOiVNOiVTICVZAFBPU0lYAE1FQU5fTU9USU9OX0RPVABNRUFOX01PVElPTl9ERE9UAEdNVAAlSDolTTolUwBBUkdfT0ZfUEVSSUNFTlRFUgBCU1RBUgBFTEVNRU5UX1NFVF9OTwBNRUFOX01PVElPTgBJTkNMSU5BVElPTgBOQU4AUE0AYWRkT01NAEdNAEFNAExDX0FMTABSRVZfQVRfRVBPQ0gATEFORwBJTkYARVBIRU1FUklTX1RZUEUAQ0xBU1NJRklDQVRJT05fVFlQRQBSQV9PRl9BU0NfTk9ERQBPQkpFQ1RfSUQATk9SQURfQ0FUX0lEAEMAZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8c2hvcnQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIHNob3J0PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxpbnQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIGludD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8ZmxvYXQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVpbnQ4X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludDhfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dWludDE2X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludDE2X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVpbnQ2NF90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxpbnQ2NF90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzx1aW50MzJfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8aW50MzJfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8Y2hhcj4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgY2hhcj4Ac3RkOjpiYXNpY19zdHJpbmc8dW5zaWduZWQgY2hhcj4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8c2lnbmVkIGNoYXI+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGxvbmc+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVuc2lnbmVkIGxvbmc+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGRvdWJsZT4ARGVsY1lhWWVKZ3plcGcyZ05iaWJFY0ZiTmVVZzlmQ2NHY0Rkd2ZGYVhnamJrYUJlVWZtYjFjWWNBaHlna2ZqY0lnQ2ZoZ1NmTWN3aGdjeWFWZ2dhMGVMZkVmQWg5ZlVmQ2VDaGdneWJXZlRhWWNBYk1oaGNBaE1mRGN6Zk5hUWNOZlFoMGdYaE9kVGdZZlhjTWhrYTRhdGFFZDFjSWR3Z0FlRmFJYytnRWRnZmtmbGNMY0JjSmZmZVVhamRaZ0tiSGJ4ZmRiVWJPZXdiRWVsaEJjeWM4Yk1hSmhUYThhS2FVaGphQmdiZVhoQWN0Y1ljRWdEYlVib2FOZnplVWJ1aEFjQ2NaY1FiVWh3ZG9jMGJEZkZhRWRVZUJkVWQwZ3hnSGFBZE1kcGNJZXlmQWhvY1ViamJNZElmTWhsYllhTmRDZ3hlQWRQYlZoQWZnYW9oTWVsaGtoMmJBaERnSWJRaERjQWc4Z3phVWhEaFVkTmhGZHpka2QyYkZiemFKY09kTGZSaE5hU2NNY0FmQmVTZlBhaGRJaEphSmRTYndmU2FYZTFlSWgyaFNiaGM4YlhmVmVEYnNnQmZKZFFjY2h2Y0RjQ2ZVZS9jQ2hsYklmd2dXYjFid2FMYldkQmNBZzFlS2REZWNmMWFMaGdnQWVtZFVlRmNNZUtjTmZBYnhjUmVGZUFjVmJOYk1oUmV3Z0RoS2NTaE1lZ2VLZEZoSWN6ZENlRGhKZFdnRGZRZnNlUWFEYzFoUWhJZktoRGdKZFplTmFnYkFoeWJFaEFid2dQY01mMWFBYTFhRGNSYWNiNWhOaGhoY2N5YVRmaWQwZ1RjVWdqY0FlQWNVaGpkNGJTZUNiU2NVZnNjRWhsZjlhU2FOZmtib2JmaEZoMWZRaDdhQWRTYlVjSGFMZXdjd2hsZ1Bld2VwZlNiTWRGaHRnY2ZDZDFhZ2RRZk5jU2hnaDNjTmVTZTRlQWRKaGxoQmZUYUNiamFRYk1hVWdSZVFiRmhUZFRoRWJjaEFkeWJrZ2pnSWNDYmhnU2ZNZHdnZ2V5aFZkZ2cwY0xoRWFBYzlhVWRDZUNoZ2N5ZldhVGRZY0FlTWZoZEFlTWREZHpjTmdRZ05jUWQwY1hhT2hUaFlnWGZNYmtmNGR0YUVnMWhJYXdnQWJGaEljK2JFaGdha2ZsZExoQmVKZWZhVWNqYlpnS2VIYXhnZGJVaE9hd2NFZWxoQmR5YjhhTWdKY1RnOGNLYVVoamRCZmJnWGFBYXRoWWFFaERoVWVvZU5oemRVaHVkQWJDYVpkUWJVY3dob2YwY0RkRmFFZlVkQmdVZzBoeGVIaEFiTWhwZ0lkeWFBZm9jVWZqY01lSWJNZmxoWWZOZENkeGhBZlBjVmdBYmdhb2dNZmxoa2UyZ0FoRGJJZlFjRGVBZDhlemVVY0RmVWdOZ0ZmemRrYTJjRmh6ZUphT2FMZVJoTmJTZ01kQWVCZFNjUGZoZUllSmZKaFNmd2ZTYlhkMWZJZjJiU2VoYThjWGhWZ0Rmc2RCY0poUWRjZXZkRGdDY1VhL2FDYWxkSWN3YldnMWR3YUxiV2NCYkFmMWFLYURnY2cxYUxoZ2NBZ21oVWFGZE1iS2hOZkFheGFSZkZlQWZWZk5iTWFSY3dnRGhLZ1NlTWhnZ0tjRmdJaHpkQ2VEZUpoV2ZEaFFkc2FRZERnMWhRY0lkS2ZEYUphWmZOZWdlQWh5YkVoQWd3ZlBhTWIxaEFnMWZEZVJkY2Q1Y05oaGhjYnlhVGhpYjBkVGFVZmpkQWVBYVVmamQ0ZlNiQ2NTYlVoc2NFZmxkOWdTYk5ia2NvZmZnRmExZlFlN2hBYVNhVWVIYkxmd2J3Y2xlUGV3YnBjU2RNZkZldGZjZkNjMWVnZ1FlTmFTZGdjM2hOY1NiNGhBaEpibGdCY1RiQ2dqZVFmTWJVYVJlUWRGYlRjVGFFYWNiQWV5ZGtmamFJaENlaGNTZU1kd2JnZXloVmdnYzBlTGZFZUFnOWFVZENjQ2ZnaHliV2hUZVloQWJNZWhlQWJNYkRhemZOZVFoTmJRaDBkWGFPZVRmWWFYYk1ka2g0YXRoRWExZElkd2NBZ0ZnSWgrZ0VhZ2hrYWxhTGJCYkpmZmJVYmphWmdLY0hoeGFkYlVmT2F3ZUVnbGFCYnlhOGVNaEpjVGE4YktjVWVqZkJjYmdYZkFldGhZZkVhRGJVZW9iTmR6Z1VidWJBaENkWmZRYVVld2dvZDBnRGRGYkVnVWdCZVVhMGJ4YkhhQWVNZnBkSWd5Z0Fob2ZVYmpnTWZJZE1obGZZZ05kQ2F4ZUFjUGNWZkFiZ2VvZU1mbGFrYzJoQWZEYUlhUWJEYkFiOGZ6aFVkRGhVZU5hRmd6ZWtoMmZGYXpjSmJPYkxmUmZOZVNoTWRBZUJlU2FQZWhlSWNKZEpjU2Z3ZFNmWGMxY0liMmdTYmhmOGdYYVZhRGVzZUJjSmhRZmNndmJEYkNlVWMvaENkbGRJY3diV2QxYndnTGRXY0JhQWgxYktjRGRjYzFnTGhnYUFnbWNVYkZhTWJLZk5iQWN4ZFJkRmZBaFZjTmJNaFJod2JEZ0tlU2RNZmdiS2RGYUljemZDZERiSmdXaERmUWdzaFFlRGQxZVFiSWhLYURlSmdaZk5nZ2JBZnlmRWJBZ3doUGVNZjFnQWYxY0RmUmFjZjViTmRoZWNkeWZUYmloMGFUZVViamRBYkFhVWdqZzRiU2ZDZVNlVWdzYUVmbGE5ZlNoTmVrZ29hZmVGYTFiUWU3ZEFkU2ZVaEhiTGR3ZndlbGZQYndjcGJTYU1iRmJ0ZmNmQ2UxYmdkUWFOZ1NlZ2czZk5iU2Q0aEFoSmVsYUJiVGRDaGplUWNNZlVnUmFRY0ZlVGVUZ0VnY2RBaHlma2JqZUljQ2NoZ1NlTWZ3YWdieWJWYmdmMGdMaEVlQWg5Y1VlQ2RDZWdjeWJXYlRnWWNBaE1kaGhBaE1jRGJ6aE5kUWhOZVFiMGNYZk9iVGRZaFhnTWJrZjRjdGFFYzFiSWZ3aEFhRmdJZCtjRWVnZmtnbGVMZUJnSmRmYlVmamhaY0tlSGF4ZmRnVWdPZXdiRWJsaEJneWg4Z01mSmJUYzhmS2JVYWphQmdiaFhiQWF0YVliRWdEZFVhb2NOaHpiVWJ1YUFjQ2JaY1FnVWR3Y29jMGVEYkZmRWdVZEJnVWEwZHhoSGJBaE1mcGZJZXliQWhvZFVnamRNY0llTWZsaFlmTmZDZXhoQWdQY1ZjQWFnZW9jTWhsZGtmMmZBZURlSWhRYkRlQWE4Z3phVWdEYVViTmVGYnpha2EyZkZlemFKZU9lTGhSZ05mU2ZNZUFlQmhTYVBkaGdJYUpkSmhTY3dlU2dYZzFkSWYyZlNjaGU4Z1hoVmREYXNhQmFKZlFjY2d2Y0RjQ2RVaC9jQ2FsZElld2ZXZTFnd2VMZ1doQmhBZDFkS2VEZWNhMWJMZmdlQWVtZlVoRmFNaEtjTmdBZHhoUmJGYUFiVmROZ01jUmV3Y0RjS2ZTZE1iZ2NLZUZmSWV6ZENkRGRKZVdiRGNRYXNiUWVEZjFnUWVJYktjRGZKYlpmTmZnZEFoeWZFZUFmd2hQZk1lMWNBYjFnRGFSaGNkNWJOY2hjY2N5ZFRkaWEwY1RiVWVqZkFlQWJVZGpjNGFTaENhU2VVaHNiRWJsZjljU2dOZGthb2dmZkZhMWFRZjdkQWhTY1VkSGJMYndjd2RsZVBhd2FwYVNmTWRGZXRoY2JDZzFnZ2RRZU5nU2JnYjNkTmZTYjRlQWVKZWxiQmJUZUNiamFRZ01mVWFSYlFhRmZUZVRiRWRjZ0FjeWJrZ2piSWJDZWhmU2JNZXdjZ2Z5ZFZjZ2IwYkxoRWFBZDloVWJDZUNlZ2h5YVdjVGZZaEFjTWNoZEFjTWVEZ3pkTmVRYU5mUWEwZlhoT2FUZFlnWGJNZWtmNGZ0YkVlMWZJZXdoQWdGZklmK2dFZmdha2JsZUxmQmNKY2ZmVWNqYlpiS2hIaHhhZGZVZE9ld2JFaGxlQmF5ZzhiTWJKY1RlOGVLZlVhamhCZGJnWGVBZHRmWWVFY0RlVWVvYU5jemVVY3VhQWFDZFpkUWFVY3dlb2IwZ0RmRmRFZlVoQmhVZzBmeGNIYkFmTWZwZklheWJBZm9lVWhqZE1iSWZNYmxlWWhOYUNoeGVBZFBjVmdBZ2dkb2hNY2xoa2cyYkFnRGNJZVFkRGZBYjhiemZVYkRmVWROYUZlemFrZDJmRmV6aEphT2VMZFJmTmRTZ01nQWNCaFNoUGVoZklnSmJKYlNkd2NTYVhmMWdJYTJjU2ZoYjhjWGFWaERlc2NCZkpoUWVjYXZjRGNDZFVjL2JDZmxmSWR3Y1dhMWR3ZExoV2ZCY0FhMWdLY0RhY2IxZ0xjZ2ZBZG1nVWhGZk1hS2FOYUFieGRSYkZmQWVWY05lTWRSaHdjRGVLZlNlTWJnaEthRmFJY3pjQ2hEZ0piV2FEZFFkc2FRZ0RkMWJRZUlnS2VEZUpkWmFOYWdnQWV5aEVhQWN3Z1BoTWgxZUFlMWJEaFJjY2Q1aE5maGhjY3ljVGZpYTBhVGJVYWpjQWRBZVVmamU0Y1NkQ2hTYVVhc2hFYWxhOWVTZk5ha2hvZGZjRmExZlFmN2ZBZlNjVWdIY0xkd2Z3YmxiUGR3Y3BmU2FNY0ZkdGVjZUNoMWVnYVFhTmVTZmdmM2FOYVNmNGJBY0phbGZCZVRmQ2hqY1FkTWRVZlJkUWRGYVRnVGJFZ2NoQWh5ZGthamZJaENkaGhTZU1id2RnY3lnVmVnZTBlTGNFYkFnOWVVZ0NiQ2RnYXllV2FUYllkQWVNYmhjQWdNZURhemFOZFFkTmhRZTBhWGhPZ1RiWWdYZE1ja2Q0Z3RiRWQxYklod2VBZUZnSWYrYkVnZ2FrY2xnTGJCYUpoZmRVZmpmWmdLYUhheGVkYlViT2Z3ZkVlbGZCZnlnOGZNZ0poVGU4ZEtlVWZqYUJkYmVYZUFodGRZYkVnRGNVaG9jTmZ6ZlVndWVBYUNlWmVRZFVld2ZvaDBoRGVGYkVjVWNCZ1VhMGJ4ZkhlQWRNZHBmSWV5ZEFib2JVYmplTWNJZE1obGVZZ05iQ2Z4ZkFoUGdWZ0FhZ2ZvY01nbGNrZDJjQWVEY0lkUWdEYkFhOGJ6aFVjRGZVaE5jRmR6ZWtmMmJGY3poSmZPYUxkUmJOaFNlTWNBZUJoU2JQaGhiSWJKYkpiU2J3YlNiWGYxZElmMmZTZ2hoOGVYYVZjRGZzZkJlSmZRZGNkdmREZENmVWMvY0NhbGVJZHdhV2IxZ3dkTGVXZEJoQWExYktkRGZjZDFkTGFnZ0FnbWNVZEZnTWRLZU5nQWR4ZVJkRmZBYlZlTmRNY1Jmd2dEZEtjU2dNZGdmS2dGZElmemhDY0RkSmZXY0RiUWhzY1FiRGExZlFnSWZLZURmSmZaZE5lZ2FBYnljRWVBZHdmUGdNYzFjQWUxYURjUmhjZjVjTmZoZ2NoeWVUZWlnMGNUY1VnamRBZUFmVWNqYjRjU2ZDY1NkVWJzZ0VmbGM5YVNhTmNrZ29oZmJGZjFjUWM3aEFoU2NVYkhiTGd3ZndobGZQZ3dicGdTZ01lRmJ0ZWNoQ2IxY2doUWVOZlNnZ2QzZE5kU2Y0YUFjSmhsaEJhVGRDZGplUWdNYVVmUmNRYkZoVGZUZEVkY2VBYXlka2hqaEloQ2NoYlNkTWh3YWdkeWdWZ2dnMGNMZkVmQWc5ZFViQ2ZDYmdoeWFXYVRjWWhBYk1haGNBZU1mRGh6Yk5hUWNOZFFhMGdYYk9hVGRZY1hmTWRrZjRidGdFZTFlSWh3Z0FkRmRJYitkRWJnZWtibGdMYkJoSmJmZVVkamFaaEtjSGF4Z2RkVWhPZ3dlRWdsYUJheWE4aE1oSmFUZjhoS2VVaGpmQmNiYlhmQWR0Y1lnRWdEZVVib2FOZXphVWR1ZkFmQ2haZVFnVWV3YW9mMGREZ0ZkRWNVYkJiVWQwZnhlSGdBZ01mcGNJZ3ljQWhvY1VmamRNZ0ljTWhsYVlmTmJDYXhhQWJQZVZlQWFnZG9hTWhsYWtkMmdBZURnSWhRZURmQWc4YXpnVWdEZlVkTmVGZHpka2MyaEZlemZKZU9lTGZSZk5oU2FNZ0FjQmhTYlBjaGJJZ0pjSmFTZndjU2JYZDFjSWUyYVNlaGc4YlhkVmJEY3NnQmRKY1FhY2R2Z0RoQ2JVYy9nQ2JsZklid2ZXYzFld2VMYldkQmJBYzFjS2FEZWNiMWFMY2dmQWNtZVVjRmVNaEtmTmFBYnhlUmFGY0FkVmNOZU1mUmF3ZkRhS2VTZ01kZ2FLZkZhSWN6aENkRGNKYldmRGFRZ3NiUWNEYjFoUWhJYUtmRGFKZFpkTmVnaEFoeWJFYkFod2RQYU1hMWFBYjFiRGdSZ2NkNWdOZWhhY2h5ZVRoaWcwZ1RkVWZqZUFnQWhVZmplNGJTZkNoU2FVYXNkRWRsZzllU2ROY2tjb2hmZEZhMWZRYTdmQWFTY1VhSGFMZ3dod2dsYlBld2FwYVNnTWVGY3RmY2NDZTFnZ2NRYk5nU2JnYTNjTmNTZDRmQWJKYmxjQmhUYUNoamZRaE1lVWRSY1FkRmVUY1RhRWdjYkFieWVraGpoSWVDZmhjU2dNYndlZ2R5Z1ZlZ2MwY0xmRWFBZjliVWdDaENlZ2Z5ZFdhVGdZYUFiTWdoZUFiTWFEaHpiTmZRZU5jUWgwZVhoT2NUY1lhWGJNZGtiNGZ0aEVmMWZJZHdkQWZGZUlkK2RFZmdha2hsZUxmQmVKZWZiVWZqaFpnS2ZIYXhlZGJVZ09od2hFYmxiQmZ5ZDhoTWZKaFRmOGFLZVVmamNCZ2JmWGFBZXRhWWJFYkRlVWVvZ05jemNVY3VnQWZDY1pjUWVVYndob2cwYURiRmJFZFVmQmhVYzBleGRIZ0FoTWdwZEljeWhBZ29hVWVqaE1mSWJNZGxlWWJOZUNoeGVBYlBmVmRBZ2dib2VNZ2xna2gyZkFoRGdJZFFmRGVBYThjemJVaERlVWROYUZiemVrZzJnRmJ6Z0pjT2RMZ1JlTmJTYU1kQWNCaFNmUGhoaElhSmZKYlNkd2hTYlhhMWRJYjJhU2NoYjhoWGJWZURhc2ZCY0phUWhjZ3ZhRGhDYVVmL2ZDaGxhSWJ3Z1doMWR3YkxiV2NCZ0FiMWhLY0RnY2UxZ0xoZ2dBY21oVWRGYk1nS2JOYkFneGJSYUZjQWRWaE5jTWJSZHdmRGFLY1NhTWFnY0tiRmVJYXpoQ2VEZUpiV2ZEZVFhc2RRYkRoMWhRZ0llS2dEZ0plWmdOaGdiQWZ5aEVjQWJ3YlBhTWUxaEFjMWNEaFJiY2I1aE5naGZjYnlmVGJpYzBmVGdVYWpkQWVBZ1VjamQ0Z1NnQ2NTZVVjc2hFZmxjOWdTZE5oa2JvZGZhRmUxZlFhN2RBZVNhVWNIYUxid2h3aGxhUGZ3ZHBlU2FNY0ZndGZjYkNmMWRnZ1FkTmVTZmdjM2JOYVNhNGJBYkpkbGRCZlRjQ2ZqaFFnTWJVYlJmUWFGZVRoVGNFY2NnQWJ5Z2thamNJYkNoaGdTZk1ld2hnZHljVmRnYjBmTGNFaEFkOWJVZUNlQ2hnaHlmV2JUY1lmQWZNZGhjQWFNaERmemFOYlFhTmVRYTBmWGJPZlRlWWZYY01na2c0YnRjRWgxZUlid2FBZEZlSWgrYUVnZ2drY2xhTGFCaEpoZmdVZmpjWmFLZ0hheGdkYVViT2F3Z0VlbGZCY3lhOGZNZEpoVGc4ZEtlVWhqZEJlYmFYYUFjdGNZZ0VhRGdVZG9kTmF6Z1VodWJBZENhWmFRZVVhd2NvYjBlRGFGZUVmVWJCZlVhMGZ4Y0hkQWNNY3BoSWd5ZkFjb2VVZmpkTWZJaE1jbGVZYU5lQ2d4YkFlUGdWZkFiZ2dvZU1obGNrZTJhQWVEZklhUWhEZkFmOGR6Y1VhRGJVY05oRmh6ZmthMmZGaHpmSmVPZ0xiUmZOaFNiTWFBYUJiU2VQYWhkSWFKYkpiU2F3ZFNnWGExY0lkMmhTYmhiOGZYZVZmRGhzZkJlSmVRZmNkdmJEaENhVWIvYUNlbGFJaHdmV2UxY3dlTGVXaEJoQWQxZEtmRGdjYzFoTGhnZkFibWNVaEZjTWFLaE5iQWZ4aFJnRmFBYVZkTmNNYlJhd2VEYktoU2RNZmdmS2RGZElhemhDZURkSmNXaERnUWRzZlFnRGgxZ1FkSWhLZ0RmSmRaaE5oZ2dBaHlkRWJBYndnUGhNaDFoQWcxZ0RkUmFjYTViTmVoZWNleWVUYmlhMGFUZ1ViamhBZ0FhVWNqYjRmU2VDZFNnVWZzYkVkbGY5aFNjTmJrYW9oZmhGZTFlUWM3YkFmU2VVYUhhTGF3Z3djbGVQY3dncGNTZU1iRmZ0aGNkQ2QxZWdkUWZOZVNnZ2gzZU5kU2Y0Y0FmSmdsYUJnVGFDZWpjUWNNaFVkUmNRZkZmVGdUZ0VmY2hBY3lma2JqZklhQ2RoaFNjTWJ3Y2dleWVWZGdmMGNMZ0VmQWc5ZFVlQ2RDaGdheWFXaFRmWWdBZU1kaGRBZ01lRGZ6Z05jUWFOZVFjMGFYYU9kVGhZYlhkTWVrYzRmdGZFZjFmSWV3YUFnRmdJYStoRWRnYWtnbGZMYkJiSmFmZFVlamNaaEtiSGZ4ZmRiVWdPZndjRWdsaEJheWE4Z01jSmJUaDhjS2VVYWpkQmhiZFhmQWR0Y1lhRWVEYVVjb2JOaHpjVWN1Y0FmQ2VaY1FmVWJ3aG9lMGhEZEZnRWNVZ0JlVWgwZXhoSGJBZE1kcGZJY3loQWFvZVVkamdNY0lnTWhsZFloTmdDZHhkQWJQYVZoQWVnYW9kTWVsZ2thMmRBZ0RlSWhRZERmQWE4Z3pmVWdEY1VnTmJGZHpla2UyZUZkemRKaE9iTGFSZk5lU2FNYUFhQmdTYVBmaGJJY0phSmZTaHdmU2dYYTFmSWcyZFNiaGY4Z1hmVmhEYXNjQmhKYVFnY2J2Z0RjQ2RVYy9hQ2RsYklnd2RXaDFmd2VMZVdjQmRBYTFoS2NEZWNlMWJMZGdlQWJtZ1VlRmZNaEtkTmZBYnhmUmJGYkFhVmhOYk1oUmd3Y0RlS2hTaE1lZ2RLZkZoSWd6ZkNiRGFKZ1dnRGZRY3NhUWhEZDFiUWdJZktkRGFKZlpjTmZnZ0FoeWFFZkFod2dQYU1nMWJBYjFiRGFSYWNiNWJOZWhlY2h5YVRhaWQwZlRjVWZqYUFiQWRVZ2poNGNTZENlU2RVYXNmRWJsZjlhU2hOZWtib2RmYUZlMWdRYzdjQWZTZ1VnSGZMaHdjd2RsaFBhd2VwYlNjTWhGYXRjY2RDZjFnZ2VRYU5hU2dnYTNjTmFTYjRlQWhKYmxhQmZUaENiamNRY01mVWZSZVFiRmFUZ1RiRWJjYUFkeWJraGpiSWRDaGhjU2JNaHdlZ2R5Z1ZhZ2EwYUxoRWZBaDlnVWZDY0NjZ2V5ZldmVGhZYkFoTWNoYkFiTWJEZHpoTmNRZU5mUWYwYlhhT2dUZFlmWGFNYmtkNGh0Z0VlMWRJYXdjQWJGZkljK2hFYmdja2FsZkxiQmhKZGZkVWhqY1pnS2dIZHhnZGdVYU9hd2VFYmxkQmR5YzhlTWRKZFRhOGJLZVVjamRCYWJmWGZBZXRlWWFFaERkVWdvZE5nemdVZHVoQWJDZlpiUWNVYndjb2QwY0RmRmZFY1VlQmdVZTBoeGZIYkFkTWhwYklkeWhBY29hVWRqZk1kSWNNZmxiWWVOZUNieGNBZ1BhVmRBZWdjb2FNY2xia2IyZ0FiRGFJY1FoRGJBYThlemFVZURlVWROZkZiemdrZTJkRmV6ZUpkT2hMYVJmTmFTY01mQWJCY1NlUGJoZklhSmdKZ1Nod2JTZFhhMWdJYzJjU2ZoYzhiWGRWaERkc2FCaEplUWVjYnZiRGdDZ1VnL2FDZGxkSWR3Z1dkMWV3YUxkV2FCYkFnMWJLaERiY2MxZUxlZ2RBZ21jVWhGZk1nS2ZOYUFheGJSYkZkQWNWZE5oTWdSZ3djRGFLYlNoTWhnYktoRmhJaHpmQ2dEYUphV2ZEYlFic2FRYkRmMWRRZkljS2NEZ0plWmFOZWdjQWR5Z0VkQWF3Z1BhTWUxYUFlMWVEYVJoY2I1Yk5haGFjaHliVGFpYjBhVGVVZGpoQWdBZFVnamg0Y1NoQ2dTaFVmc2FFYWxiOWJTaE5ka2dvY2ZkRmUxY1FjN2ZBZlNnVWRIaExid2N3YWxhUGF3Z3BkU2JNZUZldGhjY0NmMWVnZVFnTmNTYWdlM2VOZ1NnNGFBZ0phbGFCYVRjQ2hqZFFiTWZVYlJlUWZGZlRoVGZFZWNjQWh5YWthamNJZkNiaGFTZU1hd2VnZnlhVmdnZzBlTGJFZkFkOWFVYUNjQ2dnY3lkV2dUZFlnQWJNZWhoQWRNY0RlemJOYVFkTmFRYjBjWGFPYVRkWWFYY01ma2c0aHRoRWUxZklld2hBY0ZiSWMrZ0VmZ2ZrZWxoTGdCYkpjZmVVZWpnWmRLZ0hmeGVkZVVjT2V3aEVlbGNCYnlmOGFNZkpiVGM4YUtoVWhqaEJjYmRYZUFjdGdZYkVmRGFVZm9kTmF6YlVndWFBZkNiWmRRY1Vid2ZvYzBhRGhGaEVnVWhCZ1VoMGV4YUhmQWhNZXBoSWR5aEFkb2JVY2phTWNJZk1jbGRZZU5iQ2N4ZkFkUGNWYkFjZ2FvZE1kbGJrZDJlQWVEaEloUWhEYkFjOGJ6ZFVoRGVVZk5nRmh6Z2tjMmRGYnplSmVPY0xmUmFOZlNlTWZBZEJjU2VQaGhiSWJKZkpkU2N3Y1NkWGcxYUljMmRTaGhlOGFYZlZiRGhzZUJnSmNRYWNodmNEZENnVWUvYkNmbGNJZndnV2IxYXdlTGhXZkJiQWExYktiRGdjYzFjTGNnYUFibWRVYUZkTWhLaE5hQWN4ZlJiRmhBZVZjTmZNY1Jld2JEYktjU2RNZ2doS2JGY0llemZDYURhSmZXZ0RlUWRzY1FmRGYxZFFkSWhLYkRhSmdaZ05mZ2JBY3lhRWRBZHdnUGRNZDFmQWYxZURmUmdjaDVkTmhoZ2NjeWRUY2ljMGhUY1VmamhBaEFkVWNqYjRoU2NDZlNnVWdzZ0VkbGc5Z1NiTmJrZm9jZmVGZTFnUWg3aEFmU2RVaEhiTGN3Z3dlbGRQZXdocGZTY01iRmJ0ZGNlQ2MxZWdjUWZOYVNoZ2QzZ05iU2I0ZkFmSmNsZ0JkVGNDZmpkUWRNZVVjUmRRYUZlVGZUY0ViY2JBZHlja2JqZEliQ2NoZFNnTWF3Y2dheWNWY2dkMGhMZkVhQWM5ZlVmQ2RDZ2dleWhXZVRmWWNBYk1maGhBZU1jRGd6Yk5kUWNOZVFoMGNYZ09nVGFZYVhkTWRrZzRjdGFFYzFlSWJ3Z0FlRmJJZCtmRWhnY2tkbGVMZEJhSmRmZVVhamVaY0toSGN4Y2RmVWJPZHdkRWFsYUJheWg4Z01kSmRUZjhoS2hVZmpoQmRiZFhnQWN0Z1ljRWVEZ1Vjb2JOYXpnVWd1Z0FlQ2RaZVFnVWZ3Y29kMGhEZkZkRWhVZ0JoVWcwaHhjSGFBZE1lcGZJZ3lnQWNvZFViamZNY0loTWZsaFllTmZDZHhjQWNQZVZlQWhnZW9jTWdsZmtoMmNBYkRlSWdRZURjQWg4Z3pkVWVEZVViTmhGZnpha2cyZkZjemhKZE9nTGNSYU5oU2ZNZkFoQmhTZVBoaGNJY0pkSmFTYXdlU2FYZzFoSWIyYlNlaGc4YVhhVmVEZnNjQmRKZVFiY2Z2YURoQ2NVZi9mQ2dsZklld2RXZTFod2hMaFdoQmRBZjFlS2dEaGNjMWJMYWdjQWRtYlVoRmNNZktlTmRBZ3hiUmZGaEFmVmdOaE1jUmF3ZkRlS2RTZk1kZ2hLY0ZkSWR6ZkNnRGJKZVdnRGFRZnNlUWZEZDFiUWdJZkthRGRKYlpkTmVnaEFoeWdFYUFhd2RQZU1oMWFBYjFiRGZSYWNhNWNOYWhhY2h5ZFRiaWYwZ1RmVWJqaEFoQWRVZmpiNGFTZ0NlU2FVZnNhRWVsaDliU2ZOZmtob2ZmYUZiMWVRYTdiQWhTY1VkSGRMZHdod2NsZ1Bkd2dwZ1NkTWNGZ3RnY2ZDaDFjZ2ZRZE5lU2NnYjNnTmNTZjRhQWJKZmxjQmdUYkNmamdRZ01lVWJSZlFiRmVUYlRnRWNjZ0FneWFrYWpnSWdDY2hkU2VNY3dhZ2R5Y1ZkZ2UwZ0xnRWJBYzllVWJDY0NnZ2h5ZVdmVGVZZkFkTWNoZEFiTWdEZnphTmNRZE5iUWYwZ1hoT2hUZFlhWGVNZGtmNGF0Z0VhMWJJZHdmQWhGZUliK2NFZ2dja2NsZExlQmVKY2ZlVWZqYVpkS2RIZnhkZGdVZU9id2FFaGxoQmV5aDhjTWVKYVRnOGNLYlVnamFCZmJnWGNBZnRmWWVFZERhVWNvZU5lemdVYnVjQWJDY1poUWhVY3dmb2UwaERiRmdFaFVmQmFVZDBheGZIZUFiTWNwaEloeWhBZ29oVWhqYk1oSWhNYmxlWWdOaENleGdBZVBmVmhBY2dlb2dNZGxla2YyY0FmRGNJYVFkRGhBZjhkemZVY0RhVWJOZkZmemFrZDJlRmJ6ZEpiT2hMZVJkTmZTZU1iQWJCYlNiUGVoaElnSmVKZlNkd2NTYVhhMWFJZzJnU2FoZDhnWGVWZkRkc2JCZEpkUWJjZ3ZiRGRDZVVnL2JDY2xjSWV3YldjMWZ3YkxmV2NCaEFoMWZLaERiY2cxYkxiZ2NBZW1kVWVGaE1hS2hOZkFoeGdSYkZiQWZWZk5hTWFSZ3dkRGFLZ1NmTWZnZEtmRmdJY3piQ2dEYkpoV2FEYlFhc2hRYURkMWZRZElkS2REY0plWmNOY2dkQWd5ZkVhQWd3ZlBjTWMxYkFkMWhEYlJlY2Q1YU5kaGVjZ3lnVGFpYTBlVGZVZGpjQWRBZ1VjamI0Y1NoQ2VTY1Vkc2JFZmxnOWNTYU5ha2hvYWZoRmIxZFFoN2VBYVNoVWVIaExid2h3aGxlUGJ3ZnBiU2NNaEZldGRjYkNlMWZnYVFiTmhTZGdjM2dOZ1NhNGhBZUpnbGFCYVRmQ2JqZ1FlTWNVZ1JoUWhGZ1RnVGVFZ2NhQWh5Z2tnamRJYUNkaGJTZ01md2dnZ3ljVmRnZDBiTGdFZEFoOWJVZUNjQ2ZnaHloV2hUZVllQWRNYmhlQWFNYURkemNOZVFkTmVRYzBlWGdPZFRhWWFYZE1ha2I0ZHRnRWgxaElid2ZBZUZkSWErZUVhZ2RraGxmTGhCZEplZmRVYWplWmRLYkhneGhkYlVhT2N3Z0VnbGhCZHlmOGhNY0pnVGY4YUtnVWJqZkJnYmFYYkFodGJZZUVlRGFVaG9jTmZ6ZVVkdWNBYkNlWmJRaFVid2JvYTBoRGJGZkVnVWRCZVVlMGR4aEhlQWhNYnBkSWd5ZUFhb2JVZ2pnTWhJZk1hbGRZaE5lQ2h4aEFkUGhWZUFhZ2hvZE1ibGRrYTJkQWdEaElnUWhEZEFnOGR6Z1VlRGNVZE5mRmR6YmthMmVGZXpkSmVPZkxiUmNOZ1NmTWNBYUJkU2hQY2hkSWZKZ0pmU2V3Y1NoWGQxZElnMmhTaGhjOGFYZVZhRGNzYUJmSmJRaGNodmFEY0NoVWYvZ0NlbGVJZXdmV2cxZ3dlTGNXZUJmQWQxZktlRGhjaDFkTGFnZEFobWhVYkZjTWFLZU5iQWZ4aFJmRmJBaFZnTmhNZ1Jld2REYUtoU2NNYmdkS2NGZklkemFDZERnSmNXZURhUWZzZVFnRGYxZFFoSWNLZ0RkSmZaZE5oZ2VBaHllRWFBYXdnUGdNZjFnQWQxZERmUmVjaDVnTmhoZmNoeWVUYmljMGVUZlVmamVBZEFkVWFqYjRoU2RDY1NiVWJzZEVlbGM5YVNhTmhrYm9iZmFGaDFiUWc3YUFiU2hVaEhlTGF3Z3dlbGNQZHdlcGdTZE1jRmJ0YmNiQ2YxZGdoUWROaFNjZ2gzYU5nU2Y0YUFkSmVsYUJkVGZDZmpoUWNNZFViUmZRZkZmVGVUZEVkY2FBZnlja2hqZkljQ2ZoY1NjTWF3aGdneWdWZ2diMGNMZUViQWg5ZlVmQ2ZDaGdieWNXZlRjWWhBZU1iaGJBZk1oRGR6Z05nUWJOYlFkMGZYYk9hVGZZZlhhTWdrYTRjdGNFZzFiSWZ3ZUFnRmhJZytkRWhnYWtnbGhMZEJiSmRmYlViamJaZUtoSGV4aGRhVWZPYXdnRWNsZkJieWY4ZU1iSmNUYjhiS2ZVZmphQmJiZVhlQWJ0aFloRWhEY1Vhb2ROZHpjVWR1Z0FiQ2FaZVFlVWV3Z29nMGFEZ0ZlRWFVZkJiVWgwZXhmSGFBYk1kcGNJYXliQWRvZ1VoamNNYUlmTWFsZ1liTmFDYXhhQWJQYlZhQWhnZW9nTWhsaGtmMmFBYURkSWVRZERoQWQ4ZnpkVWREZFVoTmJGaHpka2YyYUZmemdKY09nTGJSZ05hU2JNZkFoQmRTZlBoaGJJY0poSmFTZ3dmU2NYYTFkSWQyZ1NhaGU4ZFhnVmREZXNiQmdKaFFkY2F2YkRoQ2JVZi9nQ2JsY0lid2ZXZzFkd2ZMZFdnQmFBYzFhS2JEZ2NoMWZMZmdkQWdtZFVmRmZNZktmTmRBZnhhUmVGZkFnVmROY01nUmV3Y0RoS2FTY01lZ2dLZEZlSWh6YkNiRGhKZFdiRGZRY3NhUWVEZzFmUWhJYUtoRGhKZFpjTmFnZkFneWFFZ0Fnd2NQZ01kMWhBZTFlRGdSaGNnNWJOZmhjY2R5aFRoaWEwZFRlVWhqZUFnQWNVaGphNGZTZkNoU2RVYnNjRWFsYTloU2hOZ2thb2JmaEZoMWNRYTdhQWVTZlVoSGVMZHdhd2NsZ1Bhd2JwYVNlTWJGYXRkY2JDYzFkZ2hRZ05iU2RnZDNiTmhTYTRoQWhKZWxmQmRUZ0NjamNRZE1hVWFSZlFoRmFUYVRmRWdjZUFoeWRrZWpmSWRDZmhjU2VNYndiZ2F5ZVZhZ2gwaExmRWVBYjloVWJDZkNmZ2Z5aFdlVGVZY0FnTWZoaEFoTWREY3pnTmNRYk5nUWgwZlhoT2JUZVljWGhNYmthNGF0YUVnMWhJaHdhQWZGZ0liK2dFZmdla2RsZUxlQmNKZ2ZoVWdqZVplS2hIZnhhZGZVZE9md2dFaGxnQmZ5YThkTWhKYlRkOGNLYVVmamRCZ2JmWGZBZHRiWWZFaERnVWdvZU5hemRVZXVnQWRDYlpoUWdVZXdmb2cwZURoRmNFYlVlQmFVZDBheGRIY0FhTWVwY0lheWVBaG9jVWhqY01lSWJNZGxhWWJOYkNoeGJBYlBnVmZBZmdib2FNZ2xna2EyZUFnRGJJaFFoRGdBYzhiemRVZkRnVWROaEZiemhrYjJiRmJ6ZkpoT2ZMY1JhTmdTYk1mQWdCZlNmUGVoZUlnSmRKZlNjd2JTZ1hlMWZJZzJmU2VoYzhhWGdWYURoc2JCYUpoUWZjZHZiRGNDZVVlL2RDYmxhSWR3ZldjMWR3ZExoV2hCaEFjMWdLYURmY2IxZUxjZ2FBZG1lVWdGYk1mS2FOYUFkeGhSY0ZhQWNWZ05kTWFSY3doRGVLaFNnTWNnYktlRmNJYXpoQ2ZEZEpjV2ZEY1Foc2dRZERkMWVRaElhS2ZEZEplWmZOaGdkQWF5Y0VoQWR3ZlBhTWgxY0FmMWZEZ1JmY2E1YU5laGdjYXlnVGJpYzBlVGZVaGphQWJBZFVoamU0ZFNlQ2NTZVVkc2JFZWxkOWdTaE5ma2NvYmZkRmQxYVFnN2hBaFNoVWJIaExld2R3YmxjUGR3ZXBlU2RNZ0ZmdGdjZkNnMWdnZlFiTmNTZGdiM2NOYVNnNGVBZ0pnbGhCaFRkQ2VqY1FlTWRVaFJoUWdGZ1RiVGZFZ2NmQWR5Z2tlamZJY0NnaGdTaE1nd2ZnZHlmVmVnYzBhTGhFZkFkOWVVZENiQ2VnYnliV2FUYllhQWZNaGhhQWJNaERmemdOYlFjTmFRaDBjWGNPZlRnWWdYZ01oa2I0YXRlRWQxZklhd2RBZUZlSWIrZkVkZ2ZrY2xmTGNCYUpjZmRVZWpoWmJLYUhleGVkYlViT2F3ZEVhbGRCaHloOGNNZUpiVGU4YktlVWFqY0JiYmJYZUFhdGJZZUVhRGhVaG9jTmd6Z1VldWNBZkNlWmRRY1Vod2JvZTBiRGJGYUVnVWNCY1VkMGd4ZUhiQWRNY3BnSWd5Z0Fib2NVZWpnTWRJYU1ibGVZaE5hQ2Z4ZkFmUGNWYkFnZ2dvZ01hbGVrZDJjQWhEZ0llUWJEYkFmOGZ6ZVVjRGFVZE5hRmh6ZmtiMmhGZHphSmhPYkxoUmdOZlNmTWFBYkJiU2dQZWhoSWdKZ0poU2J3ZlNoWGExY0loMmdTZ2hnOGZYZVZjRGFzZEJiSmVRZWNhdmFEYUNhVWIvZ0NibGZJZHdoV2UxYXdjTGFXZ0JoQWExYUtjRGVjYzFiTGhnZEFjbWJVZEZnTWVLYU5lQWN4ZlJlRmdBYlZiTmJNZVJkd2NEZktmU2NNZGdmS2RGY0llemhDZkRnSmJXZkRnUWVzZlFnRGIxZVFmSWFLYURoSmFaYU5kZ2NBaHljRWhBZXdkUGZNaDFkQWMxZkRjUmVjaDVoTmRoZWNoeWFUYWlhMGVUZ1VjamNBZ0FlVWhqYzRkU2dDaFNiVWdzZEVjbGY5aFNhTmVrYm9iZmRGaDFiUWQ3Y0FiU2RVZkhmTGd3ZndlbGVQZXdjcGVTZU1oRmZ0ZWNkQ2ExZGdhUWdOaFNkZ2YzZk5jU2g0ZkFjSmRsaEJmVGVDZmpmUWFNYVVmUmJRZEZnVGFUYUVnY2RBZnlia2ZqaEljQ2hoZFNlTWZ3aGdjeWRWY2dkMGZMYUVlQWY5aFVlQ2FDZWdkeWVXY1RlWWJBaE1maGFBZE1iRGZ6Yk5jUWFOZ1FoMGFYZ09hVGNZZ1hoTWJrYzRhdGVFZTFmSWZ3ZUFmRmVJYitlRWVnYWtkbGdMZEJjSmhmYVVkamdaaEtkSGV4ZmRmVWNPZHdjRWNsZEJoeWU4ZE1iSmZUaDhjS2JVZmpmQmFiYVhiQWV0ZFloRWdEZVVib2dOYXpnVWR1aEFiQ2JaZFFiVWh3YW9lMGJEZUZiRWhVZkJhVWMwZXhiSGdBZE1hcGNJZXlhQWJvYlVmamdNZ0lmTWVsaFliTmVDZHhoQWNQaFZhQWdnaG9oTWJsaGtnMmFBYURoSWNRaERnQWY4aHpjVWJEZFVkTmRGZ3pia2YyZ0ZmemZKaE9kTGNSZU5oU2NNZkFkQmJTZlBiaGZJZEpkSmhTYXdmU2NYZTFiSWEyY1NnaGQ4Y1hnVmNEZXNhQmdKZlFmY2N2Y0RhQ2FVYS9kQ2NsZUlhd2VXZTFid2dMYVdoQmZBZzFkS2JEYmNkMWhMZWdhQWVtZ1VnRmJNZUtlTmNBYnhlUmVGZEFoVmFOY01lUmZ3YURiS2NTY01hZ2JLYUZmSWN6aENkRGZKYldnRGhRZHNoUWVEYjFnUWZJZUtlRGRKYlpmTmhnaEFmeWRFZkFld2dQZk1jMWRBZjFmRGZSZGNkNWVOaGhlY2d5ZlRmaWgwZFRoVWhqY0FhQWFVZ2pnNGZTZ0NiU2hVYnNlRWdsZTlkU2FOYWtmb2FmZkZlMWZRYjdmQWhTaFVnSGdMZHdmd2FsZlBkd2JwZlNnTWVGaHRmY2NDZTFkZ2hRZk5jU2RnYTNhTmVTZDRjQWFKY2xkQmNUZkNmamRRZk1iVWVSaFFnRmJUYVRiRWRjY0FjeWhrZ2pmSWVDY2hkU2VNYXdiZ2h5aFZiZ2IwZkxlRWJBZjlnVWRDZ0NkZ2R5ZldhVGRZZ0FhTWdoaEFjTWZEY3plTmdRZ05jUWMwZVhmT2hUY1liWGRNZWtmNGh0ZEViMWRJZndlQWFGY0loK2FFY2dha2VsZUxlQmFKYWZhVWNqZ1pjS2VIZ3hhZGZVZk9ld2RFY2xhQmF5YThlTWdKaFRkOGhLZlVhamdCZ2JhWGJBaHRjWWFFY0RmVWRvY05lemJVY3VhQWdDZVpkUWNVZHdhb2QwaERhRmVFaFVjQmJVYjBoeGZIZ0FoTWRwZUljeWRBZm9iVWJqZ01nSWhNYWxoWWVOYkNleGNBZFBkVmdBY2dib2RNYmxma2QyY0FhRGdJZFFoRGNBZDhnemdVYURnVWFOYkZmemFrYzJhRmZ6ZUplT2dMaFJlTmhTYU1jQWhCaFNiUGhoZElkSmdKYlNld2FTZVhkMWRJYjJiU2doZzhiWGVWYURlc2VCYUpjUWVjZ3ZmRGRDZVVkL2NDY2xiSWJ3ZVdjMWd3Z0xnV2VCZEFmMWJLYkRlY2MxYUxjZ2FBYW1oVWVGZU1jS2dOZ0FoeGhSZUZiQWZWY05iTWVSZ3djRGVLZlNkTWVnYUthRmZJZ3pmQ2VEY0piV2dEZlFic2FRYURiMWJRZEliS2REZkphWmdOZGdiQWZ5Y0ViQWd3Z1BiTWIxZEFmMWFEZFJlY2c1Zk5jaGVjZXloVGVpYTBhVGVVaGplQWhBaFVjamI0YVNnQ2ZTaFVlc2NFaGxjOWJTZE5ia2JvY2ZnRmUxYVFhN2RBaFNjVWdIZExid2h3aGxoUGJ3ZXBmU2ZNY0ZkdGdjZ0NnMWJnY1FoTmZTaGdoM2dOaFNiNGJBY0pmbGJCYlRkQ2ZqaFFkTWVVZFJjUWdGZlRkVGdFY2NiQWd5Z2toamFJYkNkaGJTZk1kd2VnZXlnVmJnZjBkTGRFaEFmOWdVY0NnQ2RnYnloV2FUZFljQWVNYWhnQWNNZ0RiemhOZlFkTmJRZjBnWGRPYlRhWWdYZ01oa2c0ZXRiRWgxaElmd2RBYUZoSWUrYkVmZ2ZrZmxmTGNCYUpjZmdVZWpiWmhLZUhneGNkYlVnT2R3ZUVjbGNCaHllOGNNZ0pjVGQ4ZEtlVWFqYkJlYmZYYUFjdGNZaEVhRGJVY29oTmN6ZVVhdWhBZ0NmWmNRZVVld2JvYTBnRGRGYUVnVWVCaFVlMGJ4ZkhiQWFNZXBoSWZ5aEFnb2RVYWpiTWhJZE1mbGZZYk5hQ2Z4ZkFkUGhWZUFlZ2VvZE1kbGZrYTJhQWREZEloUWhEYkFiOGh6YVVjRGVVYk5jRmd6Y2tnMmZGZHplSmVPZ0xmUmFOZVNnTWdBZEJoU2NQYWhjSWRKZEpjU2Z3ZFNmWGExYklnMmZTYWhoOGVYZFZoRGhzaEJiSmZRY2NndmZEZ0NnVWYvY0NlbGNJZ3dmV2IxYndiTGhXYkJlQWIxYUtmRGhjZDFhTGNnZkFmbWhVYUZiTWhLYk5lQWN4ZFJnRmJBZlZkTmFNYVJnd2ZEaEtkU2RNZWdnS2hGaEliemVDYURiSmRXYkRkUWNzZVFnRGExY1FkSWhLZkRkSmdaZE5nZ2NBZXlkRWVBZXdlUGFNYzFnQWgxZURkUmVjZjVlTmhoYmNmeWVUZ2lkMGZUZVVjamNBZEFoVWRqYTRoU2RDZ1NhVWRzZkVnbGQ5aFNjTmFrYm9lZmdGZzFkUWE3Z0FnU2dVYUhkTGV3Z3djbGFQZ3dkcGVTYU1hRmh0aGNhQ2IxYWdjUWhOY1NnZ2YzZU5oU2I0ZEFlSmJsY0JmVGNDZ2piUWFNY1VkUmRRY0ZnVGdUaEVnY2NBYXlja2RqZEllQ2ZoZVNjTWh3ZWdkeWVWZ2dmMGVMYUVhQWc5Y1VmQ2dDZ2dneWNXZ1RlWWFBaE1oaGRBZk1kRGZ6aE5hUWVOaFFlMGZYZU9nVGNZYVhjTWVrYTRjdGRFZDFhSWN3Z0FmRmhJYStjRWVnYmthbGJMaEJmSmJmaFVmamRaZUtmSGR4ZWRkVWVPYXdkRWZsYkJneWc4ZU1jSmJUZjhmS2hVaGpkQmFiZFhlQWZ0YVloRWNEZFVhb2ZOZHpkVWJ1ZUFlQ2VaYlFoVWF3Ym9hMGJEYUZoRWVVYUJlVWQwaHhjSGNBZ01mcGhJZHlnQWdvYVVnamhNY0lhTWdsYlliTmVDZnhmQWFQY1ZjQWNnZG9iTWNsY2thMmJBYURjSWFRYkRlQWU4Z3plVWNEYVVmTmZGYXpna2MyYUZmemRKY09kTGRSZ05hU2JNZkFjQmhTaFBiaGJJaEpmSmFTZndhU2JYZjFhSWIyaFNlaGE4Y1hnVmFEYnNoQmRKZ1FjY2Z2ZkRjQ2VVYS9jQ2RsZElid2ZXaDFkd2hMZldkQmFBZjFhS2VEZWNiMWVMY2dlQWNtY1VmRmdNaEthTmdBaHhhUmVGYUFkVmhOZk1kUmR3Y0RoS2dTZU1nZ2hLZ0ZlSWJ6aENmRGdKYVdjRGNRZ3NlUWVEZTFiUWNJZEtlRGJKZVpoTmFnZUFieWdFZEFnd2NQZk1jMWFBYTFiRGdSZWNjNWdOZ2hjY2V5YlRlaWQwZVRiVWZqYkFkQWFVYmpmNGJTZUNlU2RVZnNjRWdsZDlmU2hOZ2tib2VmZUZjMWJRYTdiQWNTaFVoSGNMY3dkd2dsYVBnd2JwZFNlTWdGZXRjY2JDZzFlZ2JRZ05mU2FnYjNiTmFTZzRoQWJKZGxjQmJUZkNjamFRaE1lVWVSZFFjRmFUYlRoRWhjZkFieWVraGpnSWdDZGhiU2hNY3doZ2d5YVZiZ2QwY0xjRWZBYzljVWhDZENiZ2h5YldkVGVZZ0FhTWFoaEFnTWJEZnpiTmNRYU5nUWUwZlhhT2NUZllnWGdNYmtmNGh0Y0VlMWZJYndmQWJGZ0liK2RFZWdoa2NsYUxoQmZKZGZkVWhqZFphS2NIYnhjZGdVZk9nd2dFZWxiQmR5ZDhhTWZKY1RhOGRLZ1VmamJCYWJiWGNBZHRmWWdFZkRiVWNvYU5kemdVaHVoQWRDZlpnUWRVZ3dkb2gwZkRkRmJFaFVoQmZVYTBleGRIZEFmTWVwZUlneWdBZm9lVWdqYk1mSWdNZmxkWWZOZkNleGhBYlBnVmhBaGdnb2VNaGxla2YyYUFkRGNJYVFoRGRBYThmemRVYURmVWhOYUZkemRrZzJoRmR6ZkphT2dMaFJkTmRTYU1hQWFCZ1NiUGFoYUloSmVKZ1Nld2hTZVhnMWdJZjJjU2RoYjhnWGFWZkRkc2VCaEplUWdjaHZoRGZDZlVhL2VDaGxoSWN3Y1dlMWN3ZExlV2RCYkFhMWNLYkRmY2YxYUxoZ2dBYW1jVWVGY01oS2dOZ0FjeGNSY0ZlQWNWZU5iTWNSZndkRGRLZlNnTWNnYkthRmVJZHphQ2hEZ0plV2FEZ1Fnc2ZRY0RoMWNRYUliS2NEYkpkWmROZWdhQWR5Y0VlQWN3ZFBjTWMxaEFmMWFEYVJoY2I1YU5kaGJjZnlhVGJpYzBhVGRVYmphQWdBYlVjamg0Z1NlQ2NTY1Vhc2ZFZmxnOWRTYk5oa2FvaGZmRmMxZVFmN2JBYlNmVWFIZkxod2N3Z2xlUGV3YnBoU2VNY0ZjdGdjYkNoMWJnZlFoTmFTZGdiM2hOZlNnNGdBYkpjbGZCaFRhQ2ZqYlFiTWRVYlJiUWdGY1RiVGZFY2NhQWF5ZmtoamZJYkNhaGNTaE1kd2FnZXlmVmRnaDBnTGdFY0FiOWJVZ0NhQ2ZnZ3lnV2JUY1lnQWFNZGhhQWNNYURoemhOY1FkTmhRZTBiWGFPZFRnWWZYZE1ma2U0Z3RlRWUxZklnd2NBZ0ZlSWIrZ0VkZ2FrZWxnTGNCYkplZmVVYWpoWmNLZkhneGVkaFVoT2J3Y0VlbGJCZnllOGFNZUpoVGM4YUthVWZqaEJlYmJYaEFldGZZZEVkRGZVYm9lTmd6ZlVldWdBYUNnWmVRaFVid2hvZTBoRGZGZ0VmVWJCY1VoMGZ4Z0hlQWNNaHBhSWV5Z0Fhb2hVYmpjTWFJZE1ibGJZY05nQ2h4ZUFoUGRWYkFiZ2FvZ01mbGhrZDJkQWJEYUloUWhEZEFnOGd6Y1VhRGFVZk5lRmJ6aGtkMmVGZXpkSmFPZ0xjUmNOaFNjTWZBZEJhU2FQZ2hlSWZKY0plU2N3Y1NhWGQxYUljMmJTZmhnOGdYZlZhRGNzaEJnSmhRZGNmdmJEZkNlVWYvY0NobGVJZXdjV2IxY3dhTGFXZEJlQWMxZEtoRGNjZDFmTGRnYUFobWdVYUZkTWdLYU5oQWZ4ZVJiRmNBaFZoTmVNYlJod2FEZktmU2ZNZGdnS2RGZ0loemVDZkRoSmFXaERjUWJzYVFhRGQxaFFlSWFLZkRnSmJaaE5kZ2JBY3lnRWRBZXdoUGNNZDFjQWcxY0RnUmVjZjViTmFoZ2NoeWhUZmlnMGJUZ1VhamhBYUFjVWhqYzRnU2ZDZ1NkVWVzaEVhbGY5Z1NhTmRrY29hZmVGZzFkUWc3ZUFhU2NVZ0hlTGV3ZXdobGJQZXdhcGhTY01nRmd0ZGNlQ2QxYmdhUWdOYlNlZ2UzYk5lU2M0YUFjSmVsZkJnVGJDZWpnUWFNZFViUmVRY0ZiVGVUaEVnY2FBZHlia2VqZUllQ2hoYlNkTWV3ZWdneWJWZ2dmMGZMZ0VkQWI5aFVlQ2hDYWdheWRXaFRmWWRBY01maGJBY01iRGJ6ZE5lUWNOYlFkMGVYZk9kVGFZZlhoTWRrYTRndGRFaDFnSWV3ZUFhRmNJZSthRWhnZ2tkbGRMaEJmSmZmaFVoamJaZUtnSGd4YWRnVWZPYndnRWhsZUJmeWQ4Zk1nSmFUYzhkS2NVYmpjQmRiZVhlQWV0Z1loRWREZlVnb2JOYnpnVWd1aEFjQ2daZFFnVWF3Ym9hMGNEaEZkRWVVYUJlVWIwZHhiSGhBZk1ocGZJaHllQWFvYVVoamdNY0lmTWRsZVlmTmdDZ3hoQWNQZlZoQWZnZm9kTWFsZGthMmhBYkRnSWFRaERhQWc4ZnplVWZEZVVmTmFGZ3pma2QyZUZmemVKZ09kTGNSaE5nU2NNZEFnQmNTYlBhaGZJY0piSmVTYndlU2JYYzFjSWMyY1NoaGM4Y1hiVmNEZ3NjQmhKY1FlY2Z2YURhQ2ZVZC9oQ2ZsY0ljd2JXZDFmd2ZMaFdmQmRBYTFmS2VEYmNoMWRMZGdnQWVtZlVlRmNNZEtoTmJBZnhhUmRGZEFiVmVOYU1kUmh3aERkS2hTZU1iZ2dLYUZnSWN6ZUNhRGdKZ1diRGNRZnNnUWdEZzFmUWJJY0tkRGdKZFpnTmRnaEFheWJFZEFhd2hQYU1lMWZBZjFoRGhSZmNhNWNOZGhiY2h5aFRnaWYwZlRhVWNqYkFmQWNVaGphNGNTZkNhU2VVZ3NnRWVsZjlkU2dOZWtjb2hmZUZnMWJRZTdlQWdTYlVhSGdMaHdjd2RsaFBhd2RwaFNoTWdGYXRnY2RDYTFlZ2ZRZk5jU2FnZjNnTmhTYTRlQWdKY2xmQmFUY0NnamhRY01nVWJSYlFiRmNUaFRjRWZjZkFneWVrZ2pnSWVDZWhmU2dNY3dmZ2d5Z1ZjZ2cwY0xmRWFBZTlnVWNDY0NjZ2h5Z1diVGFZZUFmTWFoaEFoTWREZ3plTmJRY05jUWgwaFhiT2JUZVlmWGRNZmtnNGV0ZEViMWJJYXdnQWJGYkllK2NFYWdoa2ZsZExiQmZKZ2ZnVWhqaFpiS2NIZnhkZGdVZ09od2dFZmxlQmN5YThlTWFKaFRmOGNLaFVkamZCY2JnWGNBZnRnWWhFY0RlVWVvYk5kemdVZ3VnQWRDY1pjUWVVYXdkb2gwY0RoRmZFaFViQmhVaDBleGdIZkFlTWRwYklkeWRBZW9iVWdqYk1iSWdNYmxhWWhOZUNheGVBYlBlVmVBYmdlb2RNYmxma2YyZUFjRGZJZ1FnRGdBZzhhemhVZURkVWNOZkZkemVrZzJnRmV6ZEpnT2NMYlJlTmZTYU1oQWRCZFNoUGRoZUliSmNKYlNid2VTYlhmMWRJYjJhU2FoYzhlWGJWZERmc2NCZUpiUWVjY3ZhRGNDY1VhL2NDYWxnSWJ3ZFdnMWJ3ZkxoV2NCZ0FkMWVLYkRoY2cxZExiZ2VBY21nVWJGZk1nS2VOZUFneGNSaEZnQWdWZU5kTWdSZXdoRGNLaFNjTWVnYktiRmNJYnphQ2hEYUpjV2ZEY1Flc2ZRaERiMWJRZEllS2dEZkphWmROYmdnQWF5Z0VkQWZ3ZFBlTWcxZ0FlMWVEZVJmY2g1Y05laGNjY3liVGdpZjBhVGNVZGpjQWNBYlVjamg0ZlNoQ2NTZlVnc2RFZmxiOWFTZE5ha2JvZ2ZmRmQxZFFhN2NBYlNiVWRIYkxid2d3YWxiUGJ3ZXBmU2hNYkZndGdjYUNlMWZnaFFhTmRTZmdiM2ROZlNoNGFBZUpmbGFCYlRhQ2FqYVFjTWFVYlJmUWNGYlRhVGRFY2NlQWh5Y2tmamRJYUNoaGVTYU1kd2FnYXlhVmdnZjBoTGdFZUFhOWZVYUNiQ2FnY3lmV2NUYVljQWNNaGhlQWFNZkRlemNOZFFoTmVRYjBlWGRPZVRhWWJYZ01ia2E0ZXRoRWMxaElkd2FBY0ZmSWMrZkVnZ2RrZmxiTGhCYUpnZmdVZGpmWmhLZ0hoeGdkZlVhT2R3ZEVmbGZCZ3lkOGNNY0poVGE4ZktiVWdqaEJoYmdYZEFkdGhZaEVnRGJVYm9kTmZ6Z1VidWVBYkNhWmdRYlVkd2ZvYzBiRGRGaEVmVWhCYVViMGN4ZUhiQWhNY3BoSWZ5YUFhb2RVZWpnTWNJZk1obGdZaE5mQ2F4aEFlUGNWZkFmZ2ZvaE1hbGRrZzJlQWdEY0loUWJEZ0FlOGJ6ZlViRGVVYk5nRmV6ZmtoMmRGY3poSmJPY0xkUmROY1NhTWhBaEJmU2FQZGhoSWZKY0phU2J3ZFNhWGMxYkloMmdTYmhjOGRYYlZnRGFzaEJlSmZRY2NjdmZEYkNiVWUvY0NibGhJZXdhV2gxYXdlTGRXZkJhQWQxZUtnRGVjZzFlTGZnZkFhbWdVZ0ZnTWRLZ05oQWN4YlJjRmNBaFZnTmJNYVJmd2NEYUtmU2RNaGdkS2JGZkllemFDZERlSmZXZURmUWVzZVFlRGgxZVFkSWdLaERlSmZaY05kZ2ZBYnllRWZBYXdkUGRNZDFkQWYxY0RkUmJjZzVlTmdoYmNieWFUYWllMGVUZVVmamNBY0FoVWdqYjRkU2JDYVNjVWhzZUVlbGE5ZVNjTmdrZG9kZmRGZjFnUWM3Z0FhU2NVaEhhTGV3ZHdjbGVQZ3docGdTYU1mRmR0ZWNnQ2cxZmdiUWdOYVNjZ2QzYU5nU2Y0ZkFiSmNsYUJoVGRDZmphUWNNaFVhUmdRaEZoVGdUY0VmY2FBYXloa2dqZ0ljQ2NoZFNkTWF3YWdkeWRWZWdnMGNMZEVoQWM5YlVnQ2hDZmdoeWNXZVRiWWVBZk1maGVBZU1lRGJ6Yk5jUWdOZlFnMGJYZE9mVGhZZFhiTWhrZzRodGNFaDFjSWR3ZkFlRmZJZCtlRWNnZGtkbGRMYUJjSmZmZFViamRaZktkSGV4Y2RiVWRPYXdoRWFsaEJieWU4ZE1mSmVUYjhjS2VVaGpiQmViaFhmQWZ0aFlkRWdEZlVob2ROYnplVWF1ZkFoQ2JaZ1FjVWZ3Z29iMGJEYkZlRWJVaEJiVWcwY3hoSGRBZk1mcGdJYXlnQWNvZ1VmamJNZ0liTWFsY1lkTmVDZ3hjQWRQaFZiQWdnZG9oTWRsZGtjMmdBY0RnSWFRYURoQWc4YnplVWVEZ1VhTmNGZnpoa2UyY0ZkemFKZU9kTGRSY05oU2dNZkFnQmJTYVBnaGFJZUpkSmhTZHdmU2JYZDFoSWMyYlNmaGY4ZFhiVmFEY3NlQmdKaFFmY2R2aERhQ2JVZS9oQ2FsZklhd2RXZTFhd2FMY1dlQmdBZzFkS2hEYWNmMWhMYWdnQWVtYVVmRmZNYktmTmVBY3hoUmRGaEFkVmJOYk1kUmd3ZURkS2JTaE1jZ2NLYkZoSWh6ZUNhRGNKZVdjRGJRYnNlUWREZDFmUWdJYktlRGFKaFpkTmNnYUFleWVFYkFid2ZQZU1lMWhBYTFnRGJSZ2NhNWNOZWhlY2R5YlRnaWEwZ1RhVWFqY0FiQWRVY2poNGhTYUNkU2RVYXNlRWhsYzlhU2FOZmtkb2dmZ0ZlMWhRYzdoQWNTY1VoSGRMYndnd2JsYVBld2VwZVNmTWZGZXRjY2FDYTFnZ2RRZ05hU2JnYTNiTmFTaDRnQWhKaGxkQmVUYkNhamNRZU1nVWZSYlFiRmFUYVRhRWdjYUFheWZrZGplSWZDYWhjU2JNYXdiZ2Z5Y1ZkZ2gwZExhRWRBYzljVWFDZ0NlZ2F5aFdlVGZZZEFjTWRoZ0FjTWFEYXpmTmhRaE5iUWMwZFhiT2RUZ1liWGNNaGtmNGh0YUVlMWJJYXdjQWNGY0lmK2hFZ2dla2RsaExhQmNKZmZmVWFqZFphS2dIZ3hoZGVVZ09jd2VFZGxlQmh5ZDhmTWJKZFRmOGVLaFVhamZCZGJjWGRBYnRjWWhFZ0RnVWZvZE5memJVZHVjQWJDZ1pjUWJVZXdib2UwaERjRmNFYlVlQmZVYjBheGNIZkFhTWdwZElkeWRBZG9nVWRqZk1lSWNNaGxhWWdOY0NjeGdBY1BmVmhBYWdjb2VNZWxia2QyZEFiRGhJZFFjRGhBZThiemdVZURhVWFOZUZoemNrYzJmRmN6Y0pjT2RMZlJlTmVTY01lQWVCYlNmUGZoaElnSmVKZFNjd2FTY1hmMWFJYzJiU2NoYzhhWGdWYkRnc2FCYkphUWNjZnZoRGFDZVVnL2hDZ2xnSWZ3ZldlMWd3ZkxkV2NCZ0FhMWJLZkRoY2ExZkxnZ2hBZm1iVWZGZU1kS2ROaEFneGdSZUZjQWdWZU5iTWdSZHdiRGZLaFNiTWVnYktnRmNJY3pkQ2NEZ0pkV2VEZ1Fkc2FRY0RhMWFRZklhS2hEYkpmWmFOZmdiQWJ5YkVhQWh3ZFBjTWQxZUFlMWhEZFJmY2E1YU5iaGNjY3liVGdpaDBkVGNVZWpoQWVBZlVkamQ0ZFNoQ2JTY1Vkc2VFZmxmOWdTZ05ka2VvZGZjRmgxZ1FiN2dBaFNlVWFIYUxjd2N3ZGxjUGF3Z3BiU2VNYUZkdGFjaENjMWhnZlFoTmZTaGdhM2hOY1NnNGRBZ0pmbGFCYVRmQ2ZqZ1FoTWdVZFJjUWdGZ1RmVGhFY2NkQWh5ZGtkamZJYkNkaGRTY01jd2dnZXlnVmJnYzBnTGNFZkFlOWVVZENmQ2dnYnloV2NUYlllQWJNZ2hkQWZNZURnemROZ1FnTmdRYjBkWGJPaFRnWWRYYk1ma2g0aHRnRWUxY0ljd2FBYUZjSWErZUViZ2VrYmxiTGRCaEpjZmhVZmpkWmhLZEhmeGZkYlVmT2R3ZEVlbGZCZ3lmOGRNYkpoVGY4YktiVWdqZkJjYmZYaEFndGFZaEVjRGRVY29nTmV6ZVVhdWhBYUNnWmNRaFVmd2RvZTBmRGZGZEVhVWdCaFViMGF4YkhlQWhNZ3BlSWJ5ZUFib2hVZmpmTWdJZk1hbGdZZU5jQ2N4YUFoUGVWZkFjZ2NvZk1kbGZrZTJlQWVEaElhUWREYUFmOGV6ZlVoRGZVaE5iRmd6ZWtlMmVGaHphSmJPZ0xhUmROY1NmTWZBYUJkU2FQaGhoSWFKY0piU2F3ZFNiWGQxZUliMmdTYmhjOGJYYlZnRGRzZ0JoSmRRaGNmdmNEYUNmVWEvY0NhbGVJaHdnV2cxZ3dmTGRXZkJkQWcxZUtiRGNjZDFkTGRnYkFnbWRVZEZnTWFLY05lQWh4ZFJlRmZBZlZiTmJNZFJod2hEZktiU2VNZWdjS2JGYkloemdDYURjSmJXZkRhUWRzZVFoRGIxY1FjSWVLZ0RnSmdaZE5mZ2NBZHliRWZBZHdmUGdNZjFiQWQxZURjUmVjZjVhTmJoaGNleWVUZ2ljMGVUZVVlamZBYkFhVWJqZDRkU2VDZFNmVWhzY0VobGI5ZFNiTmhrYW9jZmZGYzFjUWQ3Y0FlU2VVY0hiTGV3ZndmbGFQZXdlcGdTYk1lRmh0Y2NkQ2QxY2dlUWVOY1NiZ2gzY05lU2c0ZkFjSmRsZkJmVGZDYmpiUWVNaFVkUmdRZUZhVGdUaEVoY2RBZXlka2ZqY0lmQ2JoZ1NmTWV3aGdheWJWZGdlMGFMZkVoQWY5YlVnQ2ZDYWdmeWdXZlRkWWZBYU1iaGJBYU1nRGF6Z05jUWZOYVFlMGhYYk9oVGFZaFhmTWVrYzRkdGJFZTFiSWN3aEFhRmFJZitlRWRnaGtobGVMZUJoSmZmZVViamFaaEtnSGJ4aGRmVWFPZ3dlRWJsZEJleWY4ZU1kSmRUZDhnS2JVZWpmQmViaFhkQWZ0ZFlmRWNEYlVob2dOaHpjVWh1ZEFlQ2JaZFFmVWF3Ym9oMGZEZkZlRWVVYkJiVWYwZHhhSGdBYk1mcGVJYXljQWNvZlVjamdNYUliTWhsY1lhTmRDZHhlQWhQZFZnQWNnaG9mTWhsZ2tmMmVBZkRjSWRRZURkQWg4ZHplVWdEYVViTmRGY3pna2UyZ0ZjemVKZ09oTGZSZE5oU2RNZkFkQmJTZlBmaGNJY0pjSmFTYXdoU2FYaDFmSWgyaFNkaGY4ZVhiVmVEYXNhQmFKYlFjY2Z2Y0RjQ2dVYS9iQ2RsY0lkd2hXYzFkd2RMYVdnQmNBZjFmS2dEZ2NiMWhMYWdjQWRtYVViRmNNZEtlTmVBZnhhUmNGYUFjVmhOZU1iUmR3Y0RnS2hTYU1lZ2FLZkZhSWJ6ZENoRGJKaFdnRGFRYnNoUWNEZzFoUWhJZUthRGVKZFplTmhnZEFjeWNFZEFid2VQZU1kMWVBaDFlRGZSZmNmNWhOYWhmY2N5ZVRmaWQwZVRlVWJqYkFiQWVVZGplNGNTZUNhU2RVaHNhRWNsYTlkU2ROZmtjb2VmZkZiMWhRZTdnQWhTZlVlSGRMYXdkd2FsZ1Bkd2ZwYVNmTWhGZHRoY2NDZDFjZ2NRZ05lU2JnYzNlTmNTYTRkQWVKYWxhQmNUY0NlamdRZ01iVWZSY1FjRmNUZFRjRWdjZUFoeWRraGpkSWVDZWhiU2VNZHdnZ2R5ZlZkZ2gwY0xnRWRBZjlmVWJDaENoZ2F5ZVdoVGNZYUFiTWFoZEFhTWhEYnpnTmFRZU5mUWEwYlhnT2hUaFloWGRNZWtmNGh0ZUVnMWhJZ3dnQWNGYklkK2RFZ2dha2RsZ0xmQmZKZGZnVWRqZVplS2JIZXhmZGdVZE9od2JFYWxmQmV5aDhoTWhKYlRkOGhLZ1VjamVCYmJjWGRBZ3RlWWZFY0RlVWVvZk5hemhVZnVmQWhDYlpoUWNVYXdlb2YwZURoRmdFYlVmQmZVYjBneGdIZUFlTWNwZUlkeWFBYm9oVWhqYU1oSWdNZ2xiWWZOZUNieGVBZFBoVmhBY2dmb2JNZmxka2MyZEFiRGVJYVFhRGVBYzhmemRVZ0RhVWFOZ0ZmemJrYzJkRmd6YUpjT2hMYlJkTmhTYU1oQWFCZVNkUGdoZElmSmZKZVNnd2VTaFhnMWZJYjJnU2FoZzhoWGdWZURnc2RCaEphUWFjaHZmRGVDZlVjL2VDZGxiSWJ3ZVdjMWZ3Y0xjV2VCY0FiMWRLaERlY2IxYkxjZ2JBY21hVWVGYk1jS2hOaEFjeGZSZ0ZkQWZWZU5lTWNSYXdjRGJLYlNlTWJnYUtjRmNJaHpoQ2dEZ0plV2FEZFFnc2hRYURlMWVRaEljS2hEYUplWmROY2dmQWN5YUVnQWd3YlBnTWYxZkFmMWNEZlJkY2g1ZE5iaGNjY3llVGNpZzBlVGNVZ2plQWZBaFVnamU0Y1NkQ2NTY1Vic2dFZmxjOWhTY05na2ZvZmZmRmMxZ1FoN2JBZFNiVWRIaExkd2h3YWxlUGh3Y3BhU2FNaEZmdGFjZ0NjMWdnaFFkTmVTaGdoM2hOZlNjNGFBZ0pibGJCYVRjQ2NqYVFiTWdVYVJmUWVGYlRoVGRFY2NkQWN5ZGthamFJYkNiaGVTYU1nd2dnZnljVmNnaDBjTGFFYkFjOWFVZkNlQ2JnY3lhV2hUZ1loQWFNYmhkQWhNYkRlemJOZlFhTmFRZzBlWGVPZVRiWWNYZ01ja2g0ZnRmRWExY0lnd2RBZEZlSWYrYUVhZ2hrZmxlTGRCaEpkZmVVYmpmWmNLZUhheGdkZ1VjT2J3ZEVlbGNCaHliOGRNYkphVGE4ZEtjVWZqZ0JjYmNYZEFldGdZY0VmRGRVZG9kTmV6Y1VndWdBZkNlWmJRZVVid2NvYzBjRGJGYUVoVWFCaFVkMGN4Y0hnQWNNZnBiSWh5YkFhb2RVYWphTWNJZ01ibGhZY05nQ2d4ZUFlUGVWYkFhZ2NvZU1hbGZrZTJlQWVEZUloUWhEaEFoOGJ6ZlVlRGdVZU5iRmZ6Z2tlMmdGY3pmSmRPZUxkUmFOZFNmTWJBZkJhU2NQYmhnSWFKaEpjU2J3YlNnWGQxYUloMmJTZmhhOGFYZFZjRGZzZkJmSmZRZWNmdmZEYkNlVWMvZ0NhbGZJZndnV2QxYndiTGZXYkJhQWExYktjRGhjZzFnTGRnZkFjbWJVY0ZjTWRLYU5lQWh4ZFJnRmNBZVZhTmJNYlJjd2REYktmU2hNZWdjS2ZGZUlkemFDZkRoSmFXZ0RiUWJzZFFiRGQxY1FiSWNLZkRmSmdaZE5hZ2VBZHllRWdBaHdkUGZNaDFoQWcxZERoUmZjZTVjTmdoY2NheWRUZGlhMGdUYVVnamNBYkFjVWJqZjRkU2NDZ1NkVWZzYkVobGc5ZFNmTmRrYm9kZmNGaDFjUWU3ZkFnU2FVYUhlTGh3Y3dkbGJQYXdncGJTZ01lRmd0ZGNmQ2ExY2dnUWJOZFNnZ2QzZU5jU2I0YkFiSmdsZ0JoVGFDY2phUWZNZFVoUmNRaEZkVGhUZUViY2hBZHlha2dqZUljQ2FoZVNoTWZ3ZmdieWJWZmdnMGZMY0VnQWc5aFVnQ2JDZGdheWZXZ1RoWWZBZU1naGJBY01jRGJ6Yk5kUWVOZ1FoMGRYY09lVGdZZFhlTWdrYjRhdGRFYTFiSWZ3ZEFiRmhJZitjRWZnYWthbGJMYUJjSmRmYVVlamhaY0toSGZ4Z2RkVWZPaHdkRWRsYUJheWQ4Z01kSmRUZzhhS2hVZGpiQmNiZVhlQWZ0ZVllRWJEZVVlb2ROZ3phVWh1Z0FoQ2JaZ1FhVWN3aG9mMGZEYUZmRWNVZkJjVWUwZnhhSGNBZU1ncGFJZnlmQWVvYlVoamJNYklnTWRsaFlkTmZDZnhiQWJQZlZiQWJnZm9mTWRsYWtmMmVBY0RhSWVRZkRlQWE4Y3pkVWZEYlVnTmdGZHpka2cyYkZmemZKZE9hTGNSY05hU2VNZ0FlQmZTZVBmaGFJaEphSmdTY3doU2VYZjFjSWYyaFNkaGU4ZFhlVmNEaHNnQmNKZVFmY2Z2YkRlQ2dVaC9oQ2ZsY0lhd2dXYzFjd2dMYldoQmNBZTFhS2NEZ2NjMWZMYWdmQWVtaFVjRmZNZktmTmZBYnhjUmZGYUFlVmdOYk1iUmJ3ZkRiS2FTZU1mZ2FLYkZhSWV6ZUNhRGhKZFdiRGRRY3NoUWREZDFmUWVJYktnRGZKaFphTmdnY0FleWVFZ0Fnd2JQZE1lMWZBZzFnRGRSZmNjNWhOY2hiY2Z5ZlRoaWgwZVRnVWJqZ0FoQWFVYWphNGhTY0NiU2ZVYXNkRWZsZzliU2ROZ2tmb2NmZUZiMWVRZTdkQWZTZ1VmSGNMYXdmd2dsZVBod2ZwYlNnTWZGY3RjY2JDZzFoZ2dRY05kU2JnYzNoTmJTYTRnQWJKY2xhQmZUaENnamJRZk1hVWJSYVFhRmZUZlRnRWRjaEFkeWZrYmpmSWVDYmhoU2ZNZndoZ2d5ZFZiZ2gwZUxlRWFBYjlkVWhDY0NlZ2J5Z1dnVGNZYUFjTWhoZEFkTWVEZHpmTmdRaE5oUWYwY1hkT2JUYVlhWGdNZWtkNGV0ZEVjMWdJYndjQWRGYUlnK2JFZmdha2RsZUxhQmhKY2ZnVWVqY1phS2ZIaHhiZGRVZk9kd2RFaGxkQmV5ZDhjTWNKZlRoOGdLZ1VlamVCZ2JiWGZBZHRhWWhFZkRlVWVvaE5oemVVZXVhQWNDY1pjUWNVYXdob2gwZERjRmZFY1VjQmVVZjBheGFIY0FmTWVwZElleWFBZG9iVWFqZ01lSWhNZmxoWWZOaENieGdBZVBkVmNBaGdjb2VNZGxma2EyYUFhRGNJY1FmRGJBZjhiemNVZkRjVWdOaEZlemhrYTJoRmJ6aEpkT2hMY1JmTmJTZ01jQWJCZVNnUGFoYklnSmVKZVNnd2ZTYlhoMWdJZjJlU2hoZDhiWGFWZ0Rmc2FCZkpmUWVjZHZjRGZDZlVkL2JDZWxjSWZ3YVdkMWR3ZkxjV2JCZkFkMWhLZkRjY2IxaExkZ2FBYW1hVWdGZE1kS2ZOYUFneGRSYUZjQWhWY05lTWFSZndkRGNLZVNmTWZnYUthRmhJaHpiQ2hEZ0poV2JEZ1Fkc2VRaERlMWZRZkllS2ZEYUphWmdOYWdmQWd5Z0VkQWN3ZVBjTWIxYkFjMWZEZVJhY2Y1YU5naGRjYXliVGNpZjBiVGZVZGpkQWZBaFVmamc0Y1NjQ2RTZ1Vhc2hFZWxhOWFTZU5ja2FvZmZnRmQxYlFlN2NBYlNiVWVIZUxod2R3YmxhUGd3ZnBkU2hNZkZjdGNjYkNoMWNnZ1FhTmJTYWdkM2NOZlNkNGZBYkplbGhCZlRkQ2NqZ1FlTWZVZFJkUWdGZVRiVGRFY2NoQWd5ZmtjamhJaENjaGhTZ01nd2ZnY3lmVmhnYzBjTGZFY0FoOWZVZkNlQ2NnYXlmV2RUZFllQWFNZ2hmQWRNY0RiemVOYlFoTmNRYzBjWGhPaFRhWWVYZU1na2E0aHRlRWYxZ0lmd2NBZUZmSWgrZkVlZ2drZWxiTGVCYkphZmJVYWphWmRLY0hleGVkaFVkT2V3Y0VkbGRCaHllOGhNZkplVGY4ZEtjVWFqZUJlYmZYZkFjdGhZYUVkRGNVZG9iTmh6ZVVndWdBZkNjWmJRZFVld2JvZDBnRGZGZkVjVWZCZFVhMGh4aEhmQWdNYnBiSWN5ZUFlb2hVZmpiTWFJaE1ibGJZYU5nQ2F4Z0FhUGJWYUFnZ2FvY01kbGhrYjJnQWJEYklkUWZEZ0FmOGZ6aFVoRGJVYk5mRmN6ZWtoMmhGZHplSmNPaExkUmNOZ1NkTWZBZkJlU2dQZmhjSWRKZkpnU2J3ZFNnWGMxZklkMmJTYmhmOGFYaFZoRGRzaEJiSmdRY2NldmhEYUNmVWEvZENlbGFJZHdoV2IxaHdiTGFXZUJiQWIxZ0tnRGdjZDFiTGRnZUFkbWhVZUZjTWVLaE5oQWd4YlJhRmhBZ1ZiTmZNZlJod2ZEY0tlU2dNYmdnS2JGZ0liemVDZkRoSmZXZ0RjUWJzZ1FnRGQxZ1FlSWZLY0RhSmdaZE5nZ2JBZXljRWhBZ3dkUGZNYjFkQWIxZkRlUmFjaDVjTmZoY2NieWdUYWljMGZUZFVnamRBYUFjVWRqaDRkU2RDaFNmVWFzYUVobGU5Z1NnTmhrZW9hZmFGZDFlUWg3ZkFlU2NVZ0hkTGN3YndmbGZQZXdlcGJTYU1nRmN0YmNoQ2UxYWdhUWVOY1NjZ2MzYU5kU2M0Z0FiSmZsZUJhVGdDYmpnUWVNZFVoUmhRaEZjVGVUY0VhY2ZBZXlla2dqZElhQ2VoZVNiTWh3ZGdleWZWZWdjMGJMYUVoQWU5Z1ViQ2NDYmdoeWRXYVRiWWVBY01haGNBZ01jRGd6Yk5iUWVOYVFjMGhYZE9hVGhZYVhhTWVrYzRndGFFYzFiSWR3ZUFjRmhJZCtiRWFnYmtibGZMZkJhSmdmZ1VnamRaY0tlSGd4ZmRiVWdPZHdjRWZsZkJneWc4Yk1iSmVUZjhoS2FVYmpnQmZiY1hmQWd0YllnRWdEYVVnb2dOZXpkVWN1Z0FoQ2RaZVFiVWh3Y29hMGJEZUZkRWhVaEJjVWgwZ3hmSGRBZU1mcGJJYnlmQWVvZVVoamhNY0lnTWFsZ1lhTmFDZXhiQWVQZlZoQWhnZG9jTWFsYWtiMmVBZERmSWNRaERlQWc4aHpmVWJEY1VoTmJGY3pka2EyYkZnemdKYU9lTGFSZE5jU2dNZ0FkQmNTZFBkaGJJZEpiSmdTZ3dhU2FYZzFnSWEyY1NhaGE4YVhjVmZEYnNhQmVKYVFmY2Z2Y0RlQ2dVZS9jQ2hsYUlod2hXYjFjd2RMYVdkQmZBZzFlS2JEZ2NoMWVMaGdmQWNtaFVmRmVNZEtjTmNBZHhlUmFGZUFkVmROZU1hUmZ3ZERlS2dTYk1kZ2hLYUZiSWR6ZUNjRGRKY1djRGVRZ3NoUWNEYjFjUWNJZ0thRGZKZFpnTmdnYUFmeWhFZUFnd2VQY01kMWdBZjFkRGVSaGNoNWROZ2hiY2R5Z1RjaWMwaFRoVWhqZUFkQWJVZmpiNGVTZENkU2VVYnNkRWdsYTlhU2ROYWtnb2VmYkZnMWVRZDdjQWdTaFViSGhMZndmd2JsaFBid2dwaFNkTWdGZHRnY2dDZDFlZ2ZRZk5jU2FnZjNhTmdTYTRmQWdKYWxmQmdUYkNnamhRaE1nVWNSZlFiRmNUYlRjRWhjZEFheWVrZmpmSWdDYWhoU2ZNYndoZ2V5Z1ZjZ2gwZExlRWRBYjliVWhDYkNmZ2F5YldlVGJZZkFlTWVoZUFlTWNEYXpiTmJRZE5mUWEwYlhhT2hUaFlkWGJNZmtiNGh0Z0VoMWJJZXdhQWJGZEllK2VFYmdoa2JsZUxmQmhKY2ZkVWRqZVpoS2ZIZHhoZGJVZU9jd2RFYWxjQmN5aDhlTWFKYVRnOGJLZ1VnamJCYmJoWGNBYXRjWWNFZERjVWZvYk5hemFVZXVlQWJDYlpjUWFVZndhb2MwZURoRmJFZVVnQmJVYjBoeGhIaEFhTWJwZ0lmeWZBZG9hVWVqYU1mSWNNYmxiWWVOY0NkeGFBYlBnVmVBaGdkb2NNY2xja2UyYkFhRGFJY1FnRGZBZzhkemRVaERkVWdOZ0ZnemRrYTJnRmd6ZEpmT2dMZFJoTmVTZU1mQWZCaFNmUGFoZ0lkSmFKY1Nid2FTZVhhMWNJZzJoU2RoZDhkWGFWZ0Roc2JCZEphUWVjZnZoRGdDYVVnL2JDZWxlSWN3Z1doMWV3YkxjV2ZCZ0FmMWdLZ0RhY2MxYUxjZ2NBZG1hVWdGYU1mS2NOaEFieGNSYkZiQWVWY05iTWJSZHdiRGZLZ1NjTWZnZktkRmVJZnpmQ2VEYkpmV2hEaFFmc2dRYURhMWZRY0lmS2hEYkplWmZOZ2doQWR5Y0VkQWN3ZFBoTWIxYUFoMWdEZVJlY2I1Zk5haGFjYnljVGRpYTBjVGZVaGpiQWhBaFVmamE0Y1NnQ2dTZlVic2hFZGxlOWNTY05na2hvZmZhRmcxYlFmN2RBZVNlVWRIZUxnd2h3Z2xmUGR3YnBnU2dNYkZodGhjY0NkMWdnZ1FjTmZTYWdnM2FOZFNiNGRBZEpkbGVCZFRoQ2FqaFFnTWdVYVJnUWNGYVRlVGNFaGNhQWJ5aGtnamRJYkNhaGhTYk1ld2NnZnliVmhnZTBmTGRFYkFlOWFVY0NlQ2VnYnljV2ZUZlliQWVNZGhhQWZNZkRoemJOYVFhTmhRaDBnWGdPZVRiWWFYZ01la2M0Y3RoRWMxY0lmd2RBZkZiSWErZEVoZ2VrYWxlTGJCZEplZmVVYmpnWmVLYUhieGJkaFVjT2Z3Y0VkbGRCZXloOGhNZ0plVGQ4aEtmVWFqYUJhYmdYZ0FidGJZaEVmRGFVY29kTmd6ZVVndWJBZ0NhWmFRZFVnd2JvZzBkRGdGZEVhVWdCZFVjMGF4Z0hlQWdNZXBoSWV5YUFib2RVYmpkTWJJYU1mbGdZZU5mQ2V4Z0FlUGRWY0FoZ2JvaE1nbGFrZDJhQWNEZkllUWREY0FlOGJ6Y1VhRGZVYU5hRmh6ZWtmMmhGZ3poSmZPZkxiUmROYVNlTWFBY0JmU2RQYmhmSWRKZkpjU2J3YlNhWGYxYUloMmdTZ2hlOGZYZlZjRGdzYUJmSmVRZ2NkdmhEYUNlVWgvZkNkbGNJZndhV2cxYXdnTGJXZkJnQWgxZktkRGhjYzFhTGJnYUFmbWdVaEZoTWZLZk5mQWJ4Y1JiRmhBZFZlTmdNY1Jnd2JEYktlU2dNaGdhS2JGaEljemFDZERiSmdXYkRiUWJzaFFjRGMxYlFkSWZLY0RmSmRaZU5nZ2JBYnloRWdBYXdjUGhNYTFlQWUxaERnUmVjaDViTmVoZWNleWJUYWloMGFUZFVlamZBZ0FnVWFqZzRlU2NDY1NiVWZzZ0VnbGQ5aFNlTmdraG9oZmJGYTFnUWM3ZUFjU2NVZUhhTGV3ZXdhbGZQY3dlcGhTYk1kRmV0Y2NmQ2cxYWdlUWhOZVNlZ2gzZ05lU2M0YkFhSmNsZUJhVGJDZ2plUWFNZVViUmhRY0ZnVGdUaEVlY2dBZXlma2hqYUlhQ2NoYVNlTWZ3aGdheWhWYWdkMGVMYkVkQWQ5YVViQ2RDZmdieWFXZlRiWWRBY01jaGJBaE1mRGV6Yk5iUWZOZFFiMGVYZU9iVGNZY1hhTWNrYzRldGJFYzFmSWJ3Y0FkRmRJYythRWdnY2tlbGRMaEJoSmRmYlVlamdaZUtkSGN4ZmRlVWhPZHdoRWZsZ0JleWE4aE1nSmdUYjhkS2RVZ2piQmJiZ1hmQWh0YVlkRWdEaFVib2dOZ3poVWd1YUFlQ2haZFFmVWh3Y29mMGVEaEZoRWhVYkJjVWMwYXhmSGNBZE1hcGZJYXliQWhvY1VkamVNYklhTWVsY1lnTmhDYnhoQWRQY1ZnQWhnY29iTWNsYmtiMmhBaERkSWZRZ0RkQWY4ZHphVWNEZlVmTmVGY3pha2QyZkZhemdKZU9lTGdSZk5mU2dNY0FnQmFTZ1BjaGZJYUpoSmNTY3diU2FYYjFnSWQyZFNjaGE4ZFhjVmdEYXNnQmVKZ1FoY2N2aERhQ2hVZC9jQ2NsY0ljd2VXZTFid2RMY1djQmJBYzFmS2dEYmNkMWZMZGdhQWZtYlVlRmdNZUtjTmJBZXhnUmFGZEFjVmVOY01iUmV3YkRnS2VTYU1mZ2RLY0ZhSWV6Z0NmRGRKZ1dhRGZRYXNoUWNEZjFoUWdJZUtmRGJKZ1poTmdnYUFheWJFZUFkd2hQZ01oMWFBZTFnRGRSZ2NkNWFOZmhlY2d5Z1RnaWgwZVRkVWNqZkFoQWdVZWpkNGhTZ0NoU2dVZnNnRWdsYzlmU2ROZmtkb2JmYkZlMWVRZTdkQWdTZVVmSGZMZndod2NsYVBod2hwZVNmTWNGY3RnY2JDYTFhZ2NRYk5lU2dnYzNlTmRTaDRhQWhKZ2xiQmNUZENiamhRYk1hVWRSY1FhRmRUaFRnRWJjY0FneWZrY2piSWdDZGhjU2dNYXdmZ2F5Y1ZkZ2MwYkxkRWhBZjlmVWVDYkNoZ2V5YVdkVGJZZUFhTWJoYkFoTWFEYXpjTmNRZE5jUWYwZFhnT2VUZllmWGJNYWtmNGh0ZUVlMWVJZ3dhQWJGZUllK2ZFaGdja2VsYUxoQmVKYWZjVWdqYVpnS2RIZHhnZGFVZE9nd2VFYmxlQmN5YjhnTWZKY1RjOGFLZ1ViamZCZmJjWGJBaHRnWWdFZkRkVWJvZE5hemdVZ3VoQWJDZ1phUWRVYndib2UwZERmRmdFYlVmQmFVZzBheGdIY0FhTWNwY0lneWNBaG9kVWJqY01lSWRNaGxoWWROZ0NoeGNBZFBnVmJBZmdhb2FNYWxla2EyZ0FmRGdJaFFjRGFBZzhjemZVZERnVWVOZEZiemFrZTJiRmR6aEpmT2hMaFJhTmdTZ01nQWhCYlNlUGZoZkllSmJKYlNkd2JTZ1hkMWFJYzJoU2hoYzhjWGZWYkRoc2NCZ0pkUWdjZHZiRGNDYVVnL2ZDYWxnSWd3YVdoMWN3ZExoV2RCYUFkMWNLY0RjY2QxYkxnZ2RBY21oVWJGZE1lS2ZOaEFleGdSZEZiQWJWaE5mTWhSZ3doRGZLYVNiTWNnaEtmRmJJYXpjQ2VEZkpnV2dEZVFkc2VRZkRhMWZRZElnS2hEZkpoWmZOZ2dhQWN5YUVoQWV3ZlBlTWIxZEFkMWNEY1JiY2E1aE5kaGVjYXlkVGhpZTBiVGRVYWpjQWRBZFVhamE0YlNkQ2hTZlVoc2ZFZmxhOWJTYk5ma2hvZGZiRmcxZVFhN2FBZ1NmVWVIZExnd2J3Z2xkUGJ3YnBmU2JNZkZldGNjZ0NjMWFnY1FoTmhTY2dhM2hOZVNiNGZBaEphbGhCZlRoQ2RqZ1FnTWFVZVJmUWhGaFRoVGNFZmNjQWF5YWtnamRJaENmaGJTaE1md2ZnYnlmVmVnZjBnTGZFZUFjOWRVaENlQ2RnZ3liV2dUZ1lnQWZNZmhkQWNNZURkemVOZlFjTmFRaDBnWGZPYlRnWWFYaE1oa2M0YXRnRWMxZUlhd2dBZUZnSWcrYUViZ2drY2xjTGRCYUplZmRVY2phWmFLYkhjeGZkZlVkT2F3Y0VnbGdCYnlmOGhNYkpjVGM4Z0toVWVqYkJiYmRYZkFhdGFZZUVlRGNVZG9oTmN6aFVjdWZBZkNlWmFRZlVjd2dvYzBoRGJGZkViVWRCY1ViMGh4ZUhhQWdNZnBhSWd5ZEFhb2ZVZ2pjTWJJYU1kbGVZYU5oQ2Z4ZUFhUGRWZUFoZ2hvZk1jbGNrZTJjQWNEYUlkUWJEZEFiOGZ6aFVjRGVVZE5mRmJ6ZGtiMmZGZHpoSmZPYUxnUmZOZ1NoTWZBaEJnU2hQZ2hkSWdKZEpjU2Z3ZFNlWGExYklmMmdTYmhiOGRYYVZlRGVzYkJjSmFRY2NjdmdEaENiVWgvYUNobGFJYndkV2cxaHdjTGVXZ0JlQWMxZktnRGhjYzFmTGVnZUFmbWhVYkZmTWJLYk5nQWZ4ZFJhRmRBYlZoTmdNYVJjd2REZ0tjU2dNZGdmS2hGZkllemZDY0RjSmdXYkRhUWdzYlFlRGUxZFFkSWRLaERoSmNaYk5jZ2VBZnljRWhBY3dlUGNNYjFnQWExYURlUmNjYzVhTmJoZmNieWVUY2lmMGdUZlVmamhBaEFoVWFqZDRmU2VDYVNnVWhzYkVhbGY5Y1NoTmNrZ29lZmhGYjFoUWY3YUFnU2FVZUhiTGd3aHdjbGNQY3dlcGNTZ01mRmV0YWNlQ2UxY2diUWdOZFNmZ2YzZE5mU2M0aEFiSmhsZUJnVGVDYmpoUWRNZlViUmFRYkZkVGdUYkVkY2VBYnlna2ZqZ0lnQ2ZoZ1NoTWh3aGdheWRWZmdhMGFMZ0VhQWY5aFVhQ2dDYWdkeWhXZlRoWWdBZk1naGNBY01jRGF6Yk5mUWVOY1FlMGdYYU9lVGFZZlhoTWRrYzRhdGdFZTFmSWN3aEFjRmNJaCtiRWZnYWthbGhMZ0JoSmhmY1ViamNaYUtmSGJ4YWRkVWdPYndnRWNsZEJkeWM4Yk1mSmhUYjhjS2JVaGpmQmRiZVhiQWJ0Y1ljRWdEZ1Vob2ZOZ3phVWJ1Z0FhQ2RaaFFkVWh3ZG9oMGVEZkZlRWVVY0JoVWIwZXhmSGRBaE1kcGFJZ3liQWhvYVVkamJNYkllTWFsY1loTmVDZXhmQWhQZFZkQWZnaG9mTWdsaGtkMmhBYURlSWFRZ0RmQWM4aHpoVWJEZVVlTmNGaHpoa2IyZkZoemJKaE9hTGFSYk5iU2ZNZ0FmQmJTZFBmaGdJZUpjSmNTZndjU2ZYZDFhSWMyYlNmaGQ4Y1hlVmVEZHNjQmdKYVFmY2R2ZURiQ2JVYy9hQ2JsZElkd2NXZTFkd2RMaFdmQmhBYTFnS2ZEYWNkMWFMZWdiQWNtZlVhRmRNYUtkTmdBYnhnUmVGZ0FkVmNOZk1mUmN3ZkRnS2hTYk1nZ2JLZkZhSWh6ZkNjRGdKZFdiRGFRY3NhUWVEYzFnUWVJZ0tmRGdKZlpoTmRnY0FieWhFYkFmd2FQaE1kMWVBZjFhRGdSYWNkNWJOYmhmY2Z5YVRlaWEwZVRlVWJqYkFiQWdVaGpkNGhTY0NmU2JVaHNlRWZsYjlmU2ROY2tlb2hmZkZmMWJRaDdnQWZTZFVhSGJMZHdjd2dsaFBkd2dwZ1NhTWhGYnRiY2dDZTFiZ2hRZU5jU2hnYTNjTmVTYzRhQWNKZmxjQmZUY0NiamRRZk1nVWZSaFFjRmJUaFRnRWRjYUFjeWNrZWplSWhDZmhiU2JNZHdlZ2h5Y1ZhZ2gwZ0xhRWhBZDlhVWVDaENiZ2J5aFdhVGJZY0FlTWNoYkFjTWJEYnpiTmRRZ05nUWMwZlhiT2ZUZVlmWGJNZ2tjNGd0ZkVnMWNJZHdkQWNGZ0loK2ZFaGdla2dsYUxlQmdKZWZnVWFqZlpmS2dIaHhjZGRVYk9od2dFZmxlQmJ5ZzhiTWFKZFRnOGFLY1VhamVCYmJjWGRBYXRmWWZFZ0RkVWJvZ05lemVVYnVkQWNDZlpiUWNVYndjb2EwZ0RlRmRFZVVkQmZVaDBoeGNIZEFoTWdwZkljeWFBY29nVWVqZE1lSWJNYmxlWWJOZUNheGRBZVBkVmdBZmdmb2VNYmxna2YyZEFiRGJJZFFoRGZBaDhlemdVZURnVWROZEZjemVrYTJkRmV6aEpoT2hMZVJmTmdTZU1lQWNCZVNlUGhoY0lkSmZKYVNjd2RTaFhlMWFJYjJmU2NoYThjWGNWZkRlc2dCYUpjUWJjZnZjRGNDZlVlL2NDZ2xjSWV3ZFdlMWN3ZkxiV2hCYUFoMWdLYkRnY2cxZkxmZ2NBZm1kVWVGY01hS2VOZkFheGFSYUZmQWFWYU5iTWdSZXdoRGJLaFNiTWhnZUtjRmhJZHpnQ2hEZUpkV2dEZlFlc2JRYkRlMWhRZUlmS2hEZkpoWmNOY2dkQWJ5YUVmQWV3aFBoTWUxZEFlMWNEYVJmY2M1YU5naGZjaHllVGdpZDBoVGRVZmpmQWJBZ1Voamg0aFNjQ2hTYlVic2NFZGxjOWdTZU5la2dvZGZoRmIxYVFkN2hBaFNjVWRIZUxhd2J3aGxhUGJ3aHBjU2NNaEZjdGRjY0NkMWdnaFFhTmVTZ2dmM2NOY1NnNGVBaEpnbGFCaFRlQ2ZqaFFhTWFVY1JkUWRGYlRnVGJFY2NnQWd5YWtnamNJYkNkaGJTaE1od2JnYnllVmNnYjBnTGJFZEFhOWdVYkNnQ2VnYXlkV2ZUZlliQWhNaGhmQWFNaERmemVOYlFnTmJRYzBhWGNPZ1RoWWNYZ01la2I0ZnRhRWcxYklod2JBaEZiSWMrZUVmZ2NraGxoTGNCY0plZmRVZ2pjWmhLZ0hleGJkZ1VmT2V3ZkVjbGdCYXljOGhNZUphVGE4YktoVWNqZUJiYmhYYUFkdGVZaEVoRGZVaG9oTmZ6ZlVhdWFBZUNiWmVRYlVod2JvYTBhRGZGaEViVWFCY1VnMGh4ZkhoQWJNZHBiSWZ5Y0Fjb2VVY2piTWVJaE1ibGZZY05lQ2h4ZkFlUGhWZkFmZ2JvZU1mbGNrYzJnQWVEYUlmUWZEZEFhOGF6YVVkRGFVZk5kRmN6YmtiMmNGYnplSmZPZkxiUmVOZlNjTWNBZEJnU2hQaGhnSWFKYkplU2F3YlNoWGUxYkliMmNTY2hkOGRYZ1ZjRGRzY0JhSmdRZGNidmdEYkNiVWUvZUNmbGZJZ3dmV2YxZ3doTGVXYUJmQWExaEtlRGdjZTFkTGJnaEFhbWNVaEZoTWhLY05kQWJ4Y1JiRmJBaFZoTmNNZVJjd2REZEtjU2NNYWdlS2NGZUliemFDaERoSmRXaERhUWhzZVFkRGcxYlFoSWdLYkRjSmNaZ05hZ2RBZnloRWhBZHdlUGZNYjFnQWcxY0RmUmJjZTVjTmhoZ2NmeWJUY2loMGNUY1VjamVBYUFlVWVqYjRjU2FDY1NmVWhzZUVmbGI5Z1NhTmdrZG9nZmFGYjFmUWc3Y0FjU2NVZ0hoTGh3ZHdkbGdQaHdkcGhTaE1iRmh0Z2NhQ2gxaGdhUWFOZlNmZ2EzYk5nU2Y0aEFmSmNsZ0JkVGVDYmpkUWFNZlVnUmdRYUZmVGRUY0VkY2ZBZHloa2NqZklnQ2doaFNkTWV3YmdoeWNWZ2dmMGdMZkVnQWE5YlVlQ2hDaGdjeWdXaFRlWWNBYU1naGJBaE1mRGN6aE5hUWVOY1FjMGNYYU9jVGRZZlhlTWNrYTRmdGNFYjFiSWh3ZkFnRmhJZytlRWRnZWtjbGFMY0JlSmdmYlVlamJaZEtoSGV4ZGRiVWZPY3dmRWVsZUJheWg4ZU1lSmRUZzhoS2hVZmpkQmFiZVhiQWZ0aFljRWdEZVVkb2NOaHpjVWV1Z0FoQ2haZFFmVWN3Y29oMGREYUZhRWJVZkJmVWMwaHhiSGdBZ01icGRJZ3liQWZvaFVnamJNZElhTWNsZVlhTmNDZ3hmQWVQZlZkQWZnYm9kTWdsZWtoMmNBY0RlSWJRZkRiQWE4YnpnVWFEZVVlTmFGZnpoa2gyZ0ZjemVKYk9lTGNSY05nU2VNZEFiQmFTYlBiaGJJYkpmSmhTaHdmU2ZYZDFjSWQyYVNlaGU4YVhhVmhEaHNnQmVKZlFkY2Z2YURlQ2VVZy9jQ2RsZUlod2ZXYzFid2NMaFdoQmJBYjFhS2JEZGNjMWZMYmdiQWNtZFVoRmVNaEtmTmRBZHhiUmFGYkFlVmZOZ01jUmZ3ZERkS2NTYk1nZ2VLY0ZiSWJ6ZENiRGFKY1dhRGJRZ3NnUWNEZjFoUWZJYUtkRGRKYlpmTmJnYkFleWRFZkFnd2JQYU1iMWFBYjFjRGNSYmNiNWROaGhnY2V5ZlRnaWYwZVRhVWhqYUFjQWRVYmphNGJTZ0NhU2dVY3NoRWNsYTlhU2ZOY2tib2ZmZkZoMWNRYTdlQWhTZVVoSGJMZHdid2dsZFBod2VwY1NlTWVGZXRoY2RDaDFoZ2FRZU5iU2FnaDNmTmNTZTRmQWVKYWxmQmdUYkNkamZRY01jVWdSaFFmRmJUZlRmRWFjYUFkeWNrY2pjSWFDY2hhU2hNYndjZ2F5Z1ZjZ2QwaExmRWhBZjlkVWJDaENoZ2V5ZldnVGJZZUFmTWNoY0FjTWhEZ3poTmNRaE5oUWEwZVhoT2FUZlljWGJNZ2tnNGN0ZEVjMWdJZHdhQWFGaElhK2RFaGdja2JsZ0xoQmZKYWZlVWVqY1pnS2FIZHhmZGZVY09md2JFZGxnQmd5ZjhkTWRKYlRjOGhLZVVjamhCaGJnWGdBZ3RhWWVFZkRiVWRvYk5jemhVZ3VhQWhDaFpoUWRVZndib2gwZkRhRmNFaFVnQmJVYTBoeGhIaEFkTWhwY0lheWJBZW9hVWhqYk1nSWFNYWxhWWNOZENoeGZBY1BnVmZBY2djb2hNYmxia2gyZUFkRGVJZlFjRGFBZjhiemdVZERnVWVOYUZlemVrYTJjRmV6aEpiT2ZMaFJmTmdTZk1nQWJCZVNmUGdoZUllSmVKYVNod2ZTZ1hmMWVJZjJlU2NoZjhnWGNWZ0Rkc2NCZUpnUWJjYXZlRGNDZlVoL2FDaGxoSWh3Y1doMWJ3ZExiV2dCZ0FnMWVLZERlY2gxYUxhZ2hBYm1hVWNGYU1kS2ROZ0FmeGhSZEZmQWZWZ05nTWRSZHdmRGdLZFNiTWJnaEtlRmRJaHphQ2ZEYkplV2NEZlFjc2dRYkRlMWNRY0lnS2ZEYkpoWmZOZ2diQWJ5aEVnQWN3YlBmTWExaEFlMWZEaFJmY2Q1Z05laGdjaHloVGZpaDBhVGFVZ2pmQWRBZVVhamE0YVNjQ2RTZFVhc2dFY2xjOWJTYk5oa2JvZmZoRmMxZFFiN2ZBYlNhVWVIYUxod2R3YmxlUGZ3Z3BiU2dNZkZkdGRjY0NkMWFnaFFkTmJTYmdkM2JOaFNoNGhBZUpnbGJCYlRiQ2dqYVFjTWJVYVJkUWNGY1RiVGNFZ2NjQWF5aGtmamFJaENkaGhTZE1hd2RnZXljVmRnZDBoTGhFZ0FmOWdVZENnQ2RnZnlnV2JUZlliQWdNY2hoQWFNZ0RjemhOZ1FnTmZRZDBmWGhPZVRlWWhYYk1na2E0ZHRnRWcxYUlkd2dBZ0ZoSWQrY0VjZ2FrZWxhTGdCZkplZmNVYmpiWmJLaEhheGdkZ1VlT2J3aEVhbGdCZ3lhOGRNZUpjVGE4ZEtjVWNqYkJnYmRYZkFmdGZZZ0VmRGVVY29oTmV6Z1VmdWRBYUNoWmRRZ1Vid2FvYjBiRGNGYkVoVWVCZlVkMGh4ZkhjQWFNYnBmSWd5Y0Fnb2ZVZGpkTWNJYk1ibGNZYU5jQ2V4ZUFlUGFWZ0FnZ2RvZE1hbGNrYTJmQWZEYklhUWVEaEFnOGJ6ZFVmRGdVZU5kRmF6aGtiMmhGZnplSmNPZUxoUmZOZ1NkTWRBZEJhU2JQZGhiSWdKZUpkU2d3aFNlWGIxY0llMmFTY2hjOGdYYlZnRGNzZkJoSmZRZGNkdmREZkNoVWIvY0NkbGRJZHdlV2gxZ3dnTGFXYkJkQWMxZ0tnRGZjYjFkTGZnY0FobWRVZ0ZiTWVLZ05hQWN4Z1JkRmRBY1ZnTmFNY1Jhd2FEY0tlU2VNaGdkS2ZGY0llemRDZURjSmFXZkRnUWdzYlFnRGcxYlFnSWhLZURmSmVaYU5hZ2ZBZ3lhRWRBaHdnUGZNYzFhQWUxaERnUmhjZDVlTmJoYmNieWhUZ2lmMGdUZ1VmamNBaEFiVWNqYzRmU2dDZlNjVWRzZkVnbGg5Z1NlTmFrYm9oZmhGYzFkUWM3ZUFhU2ZVZ0hiTGJ3ZXdmbGNQZ3dlcGRTZ01kRmZ0Z2NhQ2MxZmdoUWJOYlNnZ2MzaE5jU2Q0YkFlSmhsZEJjVGdDZmpoUWFNYlVnUmZRaEZnVGhUZEVhY2JBZHlla2dqaElnQ2JoYlNiTWh3ZmdieWhWYWdoMGJMZkVmQWE5ZVVlQ2FDYWdoeWVXZVRoWWRBZ01oaGJBZU1nRGJ6Zk5lUWROZlFlMGFYY09mVGFZaFhlTWRrYzRhdGdFZTFiSWF3aEFmRmRJaCtlRWRnY2tlbGJMZEJnSmNmY1ViamFaZ0toSGh4Y2RlVWRPYXdlRWhsZ0JmeWQ4Yk1hSmdUYzhjS2VVYmphQmViYVhhQWd0YVllRWNEYVVmb2ROYnplVWV1aEFoQ2ZaZlFiVWd3Zm9oMGREYkZmRWJVYUJlVWEwZnhjSGVBZk1hcGhJZXliQWhvY1VjamhNZUlnTWFsZ1loTmZDZnhoQWFQYlZlQWJnaG9kTWVsZ2tmMmhBZkRlSWVRZURlQWY4aHpoVWZEY1VnTmNGaHpna2UyYUZmemRKZE9lTGFSZk5hU2JNY0FnQmRTZ1BlaGhJY0pjSmNTYXdlU2RYYTFoSWMyYVNkaGM4ZlhnVmNEaHNlQmRKZVFiY2Z2ZkRoQ2ZVZS9oQ2hsZElmd2JXZTFkd2dMY1diQmFBZjFiS2REZWNmMWhMaGdiQWVtYlVjRmRNZktnTmFBYXhhUmdGaEFiVmROZ01mUmR3YkRjS2ZTYk1kZ2VLaEZoSWN6YUNiRGRKY1dkRGZRZXNjUWdEZzFkUWdJZUtiRGNKY1plTmZnZEFheWZFY0Fhd2JQZk1kMWZBaDFiRGRSY2NoNWFOY2hmY2Z5YlRoaWYwZFRkVWZqY0FkQWFVZmphNGNTY0NiU2NVYXNkRWVsZDloU2ROZGtmb2JmZkZnMWJRaDdhQWdTaFVmSGJMY3dkd2JsYlBnd2VwYlNkTWRGZXRiY2hDZDFoZ2JRYU5nU2VnYzNlTmhTZjRiQWNKZmxmQmJUZENjamNRYU1lVWZSZ1FnRmFUZVRnRWdjYkFleWZrYWpmSWZDYWhmU2RNZHdnZ2d5aFZoZ2EwZkxkRWJBZTliVWhDYUNoZ2Z5ZVdnVGNZY0FlTWRoZ0FjTWFEaHpmTmhRZU5mUWQwZVhlT2dUY1lkWGZNYWtnNGR0Y0VmMWhJZndjQWRGaElkK2FFaGdja2NsZUxjQmFKaGZmVWdqZ1plS2dIZXhmZGRVaE9kd2NFY2xlQmh5YThjTWdKZ1RjOGhLZ1VkamVCZ2JnWGNBY3RkWWhFaERmVWhvZU5kemFVZ3VhQWFDZVphUWJVY3dob2QwY0RoRmJFY1VkQmhVZDBjeGRIY0FnTWRwYklieWdBYW9mVWRqYk1mSWJNaGxoWWhOZENieGJBZVBiVmVBZmdlb2ZNYWxja2IyZkFkRGVJaFFoRGZBZThnemJVZURoVWROZEZhemNrZjJoRmR6aEpiT2ZMYVJhTmhTY01kQWZCYlNlUGJoYklkSmhKY1Nid2RTZlhhMWhJYzJmU2NoZThhWGdWYURhc2NCaEplUWJjZXZhRGVDYlVnL2FDY2xoSWd3YVdnMWR3YkxmV2hCaEFkMWdLY0RmY2IxaExoZ2hBYm1hVWZGZU1lS2NOZUFoeGZSYkZjQWZWZ05iTWNSZndhRGdLaFNhTWJnZkthRmRJZnpkQ2JEZUpnV2JEYVFmc2ZRZERoMWRRZ0loS2ZEYkphWmFOZmdiQWN5YkViQWd3YVBlTWIxZkFiMWFEZFJmY2c1aE5laGFjZnljVGhpZTBiVGZVZGpjQWFBYlVoamc0YVNkQ2FTY1Vkc2ZFaGxkOWNTYk5la2RvY2ZkRmYxY1FiN2JBZVNoVWVIZkxid2N3ZmxhUGh3Y3BhU2JNZEZndGhjYUNoMWVnYlFoTmFTZWdlM2VOY1NjNGhBZEpobGRCZVRkQ2ZqY1FiTWZVYVJhUWhGZ1RhVGNFY2NmQWR5YmtlamhJZENiaGRTZk1od2RnaHljVmVnZDBiTGZFZEFhOWNVZ0NkQ2RnZHlnV2RUYVlhQWhNZGhhQWFNZ0RhemdOY1FlTmRRYjBmWGhPYlRjWWVYYU1oa2M0ZnRhRWgxZ0lhd2JBZEZkSWMrY0VoZ2hrZmxkTGdCZUphZmRVYWpmWmdLZ0hkeGZkY1VoT2Z3Z0VnbGNCZ3lnOGZNZ0pnVGE4ZEtnVWZqYkJkYmNYaEFidGFZZUVlRGRVYm9nTmJ6aFVidWhBYkNlWmZRZFVid2JvZjBlRGNGaEVjVWFCZ1VjMGZ4Z0hnQWhNZ3BlSWh5ZUFib2FVZWplTWVJZ01kbGNZaE5mQ2Z4aEFnUGhWZ0FkZ2FvYk1mbGFraDJmQWNEZklnUWZEZEFlOGZ6Z1ViRGZVYk5hRmR6ZmtjMmhGYnpiSmdPYUxmUmdOZFNkTWNBYUJoU2ZQYWhmSWdKaEpoU2V3Y1NnWGQxZElmMmRTZ2hiOGhYaFZoRGdzY0JmSmZRZmNldmVEYUNlVWQvZUNnbGRJZHdkV2cxYndmTGNXZkJmQWMxY0tkRGFjZzFlTGVnZkFobWFVZ0ZjTWVLZk5lQWJ4ZVJnRmhBZ1ZnTmNNYVJhd2JEZkthU2FNaGdhS2RGYklhemFDZURnSmdXZ0RmUWFzZVFmRGgxZlFlSWJLZ0RiSmdaYU5oZ2NBZnljRWFBZndnUGVNZTFhQWgxYURiUmVjaDViTmNoZGNneWJUZGljMGZUZVVoamJBYUFkVWdqZTRnU2VDZFNjVWdzZEVjbGY5YVNhTmRrY29iZmJGZzFmUWY3Y0FlU2NVZkhmTGF3Y3dibGNQZndhcGJTZk1nRmh0ZGNoQ2UxZWdiUWZOZFNkZ2IzZU5iU2c0YUFoSmhsY0JoVGJDY2pjUWVNZ1VnUmVRYUZlVGhUZEVnY2JBZHlha2FqYUlmQ2JoaFNiTWJ3ZWdneWJWZWdoMGRMZUVkQWY5YlVmQ2JDZmdkeWNXYVRmWWdBZE1maGdBaE1hRGN6Zk5iUWNOaFFmMGNYYk9mVGNZaFhhTWFrZjRhdGdFZTFhSWd3Z0FnRmhJZitkRWZnZ2tlbGZMZkJjSmRmZVVoamZaZktnSGV4aGRhVWhPaHdhRWZsZUJneWQ4Yk1mSmRUZjhiS2ZVZWpkQmFiYVhjQWd0YVlnRWdEY1Vhb2ROZnpmVWd1Z0FhQ2FaYVFiVWJ3aG9kMGNEY0ZoRWFVaEJiVWQwY3hlSGhBZE1kcGNJZXlkQWVvZlViamJNYUlnTWVsZllmTmFDaHhmQWdQZlZlQWNnZG9iTWhsZWtoMmFBZURkSWhRYkRjQWQ4YnpjVWJEY1ViTmdGaHpma2MyYUZnemhKY09jTGZSY05iU2ZNYUFjQmNTZ1BjaGdJYkpnSmhTYndnU2dYaDFiSWIyZVNhaGE4YlhkVmJEYnNjQmRKY1FhY2N2YURmQ2NVYy9mQ2hsZ0lmd2dXYzFhd2NMZ1dmQmhBZDFoS2ZEZGNlMWdMZ2dhQWhtYlVnRmdNaEthTmdBYnhhUmFGYkFmVmROaE1nUmF3ZkRlS2ZTZk1iZ2ZLY0ZmSWZ6YUNlRGFKYldmRGNRYnNiUWhEaDFjUWhJZktlRGJKZFphTmNnY0FjeWJFYkFid2VQYU1nMWVBaDFoRGdSZWNjNWdOZ2hlY2J5Z1RjaWYwZ1RkVWZqaEFiQWNVZWphNGVTZ0NlU2RVZ3NlRWNsZDlmU2hOZWtjb2dmZ0ZnMWhRZjdlQWNTZFVnSGRMZ3dmd2JsZlBod2JwZlNnTWdGZ3RmY2hDYTFlZ2hRYk5jU2dnaDNoTmFTZTRlQWVKZGxnQmZUYUNiamVRZE1mVWJSZ1FmRmZUZFRkRWdjZkFneWdrZWpkSWFDaGhoU2JNYndkZ2R5aFZmZ2EwY0xjRWZBYjliVWdDaENjZ2V5ZVdmVGhZYkFhTWdoYkFkTWFEY3pkTmdRY05mUWQwZVhkT2ZUaFlkWGdNYWtnNGd0YUVjMWFJY3diQWVGZUlmK2NFZ2dia2RsaExlQmhKYWZnVWRqYlpnS2dIY3hoZGJVaE9id2NFY2xjQmZ5YjhnTWJKY1RkOGhLaFVmamhCYmJmWGJBZXRkWWFFaERhVWRvZ05oemVVZHVnQWRDZVpnUWZVZndlb2UwYURlRmFFaFVoQmNVYjBoeGVIYUFoTWZwZElleWVBaG9hVWVqZk1hSWRNYWxlWWJOZENmeGJBZ1BkVmJBYmdkb2NNY2xka2EyZ0FiRGNJY1FjRGNBYThhemdVZURkVWVOYUZjemVraDJlRmZ6Y0pmT2ZMYlJmTmJTYU1oQWVCYlNiUGRoYklhSmZKYlNld2JTZ1hoMWFJZDJmU2RoZThkWGJWYkRmc2ZCYkplUWJjZHZiRGVDYVViL2VDYWxhSWZ3YVdkMWh3ZUxjV2hCZUFiMWFLZkRhY2MxY0xlZ2NBaG1nVWVGYk1mS2FOY0FjeGNSaEZkQWFWZU5hTWVSYndlRGVLYlNjTWVnYkthRmJJZnpoQ2NEZ0piV2FEYVFoc2RRZkRhMWRRZElkS2FEZkpoWmROY2dhQWF5ZUVnQWN3ZFBkTWYxaEFlMWdEZVJiY2U1ZE5kaGZjYnloVGdpaDBlVGJVY2poQWJBZFVhamU0ZVNoQ2dTZ1Vnc2NFZGxmOWJTZU5na2RvZGZoRmUxZFFmN2VBYVNiVWJIYUxod2V3ZmxnUGZ3Z3BjU2JNaEZkdGJjZ0NhMWhnaFFhTmNTZ2dnM2NOZlNlNGFBaEpmbGRCaFRoQ2dqZlFmTWhVYVJiUWNGZlRmVGNFaGNhQWJ5Y2tjamZJZUNmaGVTYk1md2ZnZnllVmZnZTBhTGVFY0FjOWdVYkNhQ2RnZ3lhV2VUZFlnQWNNYWhhQWVNZ0RoemNOYlFlTmRRYzBnWGdPaFRmWWRYZ01ma2I0ZnRjRWcxZElhd2NBYkZlSWYrZUVoZ2drZWxnTGJCZUpnZmRVZGpoWmhLZkhmeGRkaFVjT2N3ZUVkbGZCY3ljOGVNaEpjVGc4aEthVWNqYkJiYmFYZ0FidGRZZUVkRGhVZW9jTmh6YVVhdWZBZENmWmNRZ1Vod2NvZTBiRGRGYUVoVWdCZ1VnMGN4Z0hhQWVNZnBoSWN5ZEFmb2FVYmpiTWZJYU1nbGZZY05hQ2F4ZUFkUGhWZUFmZ2FvZ01jbGJrZTJkQWJEZUlkUWJEY0FnOGN6aFVoRGZVZE5kRmV6Z2toMmJGZnphSmRPaExmUmVOYlNoTWRBY0JkU2RQYmhjSWJKZUpoU2N3YlNnWGMxY0liMmdTZGhiOGRYYlZmRGVzaEJkSmNRZGNndmVEYkNjVWIvaENmbGNJYXdiV2YxaHdoTGNXYkJoQWQxaEtkRGhjYjFjTGdnYkFkbWhVZkZlTWFLZE5mQWR4ZVJiRmVBZlZhTmhNYVJid2dEYUtjU2RNYWdmS2ZGZklkemFDZURjSmFXZkRiUWJzYVFhRGExZVFoSWVLZkRhSmhaZk5nZ2JBZ3lkRWJBYndiUGFNZjFhQWIxZURnUmdjZjViTmRoZGNoeWNUaGlmMGRUY1VmamJBYkFhVWRqZDRjU2FDaFNmVWdzYkVkbGg5Y1NhTmJrZG9jZmNGZjFlUWg3YUFhU2ZVYkhiTGJ3Y3dlbGdQaHdmcGNTZE1nRmh0ZmNoQ2cxYWdhUWZOZ1NkZ2EzY05iU2U0YUFlSmRsZUJkVGVDZGpoUWRNYVViUmRRZEZlVGdUYUVhY2RBY3lma2FqYUliQ2hoYVNmTWR3ZmdheWVWZWdmMGJMYUVhQWM5ZVVoQ2RDZ2dheWRXZVRmWWFBY01laGdBZU1lRGZ6ZE5oUWJOYlFhMGdYZU9hVGNZYVhhTWVrZzRodGJFZjFmSWN3YUFmRmFJZitjRWdnZ2tjbGNMZkJlSmVmYlVjamZaYktmSGV4Y2RkVWVPZndhRWhsaEJieWI4YU1lSmdUZThhS2RVZWpoQmViYlhnQWV0YVljRWdEYVVib2ZOYXpiVWJ1ZEFmQ2ZaZ1FoVWd3Y29iMGNEZUZnRWVVYUJmVWcwZnhjSGZBZU1ncGdJZHllQWNvZFVjamVNYUlmTWNsaFlkTmJDaHhmQWVQZFZiQWFnY29lTWhsY2tnMmhBY0RoSWZRZ0RlQWI4YnplVWVEZFVhTmZGYnpma2UyaEZhemdKZ09kTGZSY05nU2RNaEFlQmNTZlBnaGFJZ0pmSmNTZXdiU2NYZjFkSWIyYVNmaGQ4Y1hiVmhEZXNjQmVKYlFnY2R2Z0RmQ2dVZS9mQ2FsZklhd2FXYTFmd2dMZVdoQmVBZDFhS2hEYWNoMWNMY2dkQWdtY1VkRmRNYUtiTmNBZ3hiUmFGY0FkVmdOZ01kUmd3ZERoS2ZTY01nZ2ZLaEZlSWJ6ZUNkRGJKZVdnRGZRZHNiUWZEYzFkUWVJY0tkRGVKZVpnTmFnaEFjeWNFYkFod2JQZU1jMWFBYTFlRGdSYmNiNWVOY2hnY2d5YlRnaWQwYVRlVWVqYUFlQWRVZWplNGVTYUNmU2hVY3NnRWJsYjlmU2VOYmtib2ZmZUZlMWJRZjdlQWdTZVVjSGFMY3dnd2FsYlBmd2FwaFNnTWZGZ3RjY2NDZDFoZ2JRYk5mU2JnYTNkTmRTaDRiQWZKZ2xkQmdUaENmamFRZE1jVWRSZlFjRmFUaFRmRWJjY0FmeWRrYmphSWRDZWhhU2VNZHdkZ2J5YlZkZ2YwZExhRWNBYjllVWNDY0NlZ2V5Y1dmVGVZYUFnTWFoZ0FoTWREZXpiTmNRZk5nUWQwZFhnT2JUY1lkWGhNYmtkNGZ0YUVmMWJJYXdlQWJGYklhK2VFYmdja2JsYkxnQmVKZGZnVWJqYlpnS2dIYnhhZGZVZU9hd2dFaGxiQmR5ZThoTWZKYlRjOGZLZ1VlamJCYWJjWGJBZ3RiWWRFZERkVWNvY05nemRVZHVlQWZDYVpiUWhVZHdob2UwZkRiRmRFYlViQmVVYTBoeGdIZkFhTWdwZUlmeWRBaG9lVWFqYk1hSWVNY2xnWWdOaENneGNBZFBiVmdBZGdmb2FNYWxoa2YyZkFhRGVJaFFhRGhBZzhlemhVaERjVWhOZEZiemNrZjJhRmh6YUpnT2FMYVJnTmNTYk1lQWhCaFNhUGZoZklhSmZKYlNnd2JTZ1hoMWJJYzJoU2VoYjhoWGVWZkRic2NCZEpjUWRjYnZjRGhDZVVjL2ZDZWxoSWd3YldkMWd3ZExiV2dCZEFnMWNLYkRlY2UxZ0xmZ2RBZG1nVWFGYk1jS2hOYUFoeGRSZEZjQWJWYU5nTWNSZHdlRGNLaFNiTWVnY0tkRmdJaHpiQ2hEYUpkV2ZEaFFic2RRYURhMWJRY0loS2VEY0pmWmFOaGdoQWV5aEVlQWd3ZlBhTWgxZkFkMWJEZlJlY2Q1YU5haGhjY3liVGFpZjBhVGNVYWpoQWFBYVVmamI0ZFNmQ2RTYlVmc2RFY2xoOWdTZ05la2VvaGZkRmYxaFFhN2FBZlNhVWhIZUxnd2d3ZmxlUGZ3ZHBlU2hNZUZhdGNjZkNiMWFnZFFoTmZTZGdoM2ZOZFNoNGFBYUpjbGFCY1RnQ2FqZVFiTWRVY1JkUWVGYlRmVGdFZ2NoQWV5ZWtoamZJZENiaGZTZ01od2FnZXlhVmFnYTBnTGVFZ0FkOWVVZENnQ2dnY3liV2VUZFlmQWFNYWhiQWZNY0RoemROYVFiTmRRZTBnWGNPYlRiWWRYZE1la2I0Z3RkRWExYUlld2NBYUZlSWIrY0VhZ2JrZGxiTGVCYUplZmRVYmpoWmZLY0hleGJkZVVoT2N3ZUVjbGVCYnlhOGRNZUpiVGQ4YktiVWJqZ0JiYmZYYkFodGJZaEVhRGhVaG9hTmN6Z1VjdWJBZUNlWmVRZFVld2NvZTBnRGRGZUViVWFCZVVjMGh4ZEhnQWhNYXBjSWR5ZEFnb2NVZGpiTWhJZU1obGJZZ05hQ2Z4Z0FjUGRWYUFkZ2NvYU1jbGdrZjJkQWNEZElhUWFEYUFmOGZ6ZFVhRGdVZU5oRmd6ZmtjMmJGaHphSmVPaExkUmROZlNlTWVBYkJhU2NQaGhoSWhKZUpoU2R3aFNmWGQxZElmMmNTZGhnOGVYaFZjRGVzZUJjSmZRYWNidmZEY0NoVWMvZkNhbGVJZndnV2cxYXdhTGNXY0JiQWYxZktmRGRjYzFnTGVnZEFobWNVaEZoTWdLZ05kQWF4ZVJoRmJBaFZhTmdNY1Jid2hEaEtmU2dNZGdmS2VGZUlhemVDZURoSmdXZURjUWZzZVFoRGExYlFoSWdLYkRiSmRaZU5iZ2RBZ3lmRWFBZXdkUGFNZDFlQWgxZ0RjUmNjYTVjTmRoaGNieWJUZWlnMGRUYlVkamFBZ0FiVWVqZDRhU2hDYVNiVWdzZkVkbGE5ZlNkTmVrY29hZmdGYTFiUWY3YkFiU2dVZ0hoTGN3YndlbGNQaHdncGNTZU1oRmh0ZGNmQ2gxZGdnUWNOZVNnZ2QzYk5iU2M0aEFlSmZsY0JjVGRDYWpnUWZNZ1VmUmFRZUZmVGVUYUVoY2VBZ3lna2RqZklmQ2RoZFNhTWF3ZWdjeWVWZmdkMGVMY0VlQWQ5aFVhQ2VDZGdkeWRXYVRmWWZBZ01oaGNBZk1hRGJ6ZU5hUWNOYVFlMGJYYU9lVGdZZlhkTWNrZDRodGJFYjFiSWd3ZUFhRmFJYStkRWdnaGtibGFMZUJkSmJmYlVkamdaZEtiSGd4Z2RnVWdPZXdjRWhsYUJleWg4aE1oSmNUZzhmS2JVZmpoQmViYVhhQWJ0aFllRWNEZlVlb2hOZXplVWd1Y0FkQ2ZaaFFhVWZ3YW9lMGhEZEZmRWFVZ0JhVWIwYXhiSGJBZ01kcGNJYXllQWhvZlVoamNNY0loTWZsY1lnTmZDZnhkQWRQZVZoQWNnYW9jTWFsZmtoMmdBZkRiSWRRZ0RkQWQ4YXplVWdEZFVlTmZGaHpia2QyZkZnemZKZ09iTGFSZE5hU2hNZ0FlQmhTaFBjaGFJZ0pmSmFTaHdoU2VYaDFoSWUyZVNhaGg4ZVhnVmNEaHNjQmZKYVFhY2h2Z0RnQ2FVYi9hQ2RsZ0lnd2hXYTFod2hMZFdjQmdBZzFiS2NEZmNlMWRMZmdnQWhtYlVlRmdNZEtoTmZBYXhoUmRGZ0FmVmZOZk1hUmJ3ZkRlS2FTaE1iZ2VLZEZlSWZ6aENkRGZKaFdoRGhRaHNlUWZEZjFmUWJJYktlRGRKY1phTmVnZEFneWdFYkFhd2ZQYU1nMWhBaDFkRGdSZWNmNWFOYmhlY2J5ZFRnaWMwZ1RmVWhqaEFjQWhVZ2pkNGdTY0NoU2VVZHNoRWhsYjllU2ROYmthb2RmYkZmMWVRYjdjQWFTZlVoSGFMY3dhd2VsZlBod2dwZFNkTWVGZHRmY2ZDYjFlZ2NRZU5oU2FnZDNlTmdTYTRlQWVKYWxlQmRUZ0NmamFRZk1oVWRSZVFlRmhUZ1RiRWJjY0FneWZrZ2piSWhDaGhnU2hNaHdkZ2V5Z1ZhZ2YwZExjRWJBZDlnVWZDZkNkZ2F5ZFdnVGZZY0FhTWhoZkFhTWdEZnphTmRRZE5oUWEwZVhnT2FUYllnWGZNZWtkNGh0Y0VmMWhJZ3dnQWhGZklmK2FFZmdja2hsZExmQmJKZ2ZjVWJqZlpkS2FIYXhjZGNVZ09jd2NFZGxjQmJ5YjhlTWhKZ1RnOGFLY1VhamdCYmJmWGZBZnRjWWNFZERlVWhvYk5hemFVaHVhQWVDZlpjUWZVZ3dob2MwZURkRmhFaFVjQmJVZzBneGdIYUFnTWZwY0ljeWZBYm9lVWdqYk1kSWZNZWxiWWdOZENkeGJBZVBkVmhBaGdmb2NNY2xja2gyZkFhRGJJaFFoRGFBaDhjemhVaERjVWhOYkZhemhraDJkRmF6Y0poT2dMZlJiTmNTZE1jQWVCaFNiUGJoZElkSmRKYlNkd2FTZ1hjMWZJZjJjU2NoaDhlWGRWYURhc2RCY0piUWZjYXZnRGZDaFVmL2ZDY2xmSWh3aFdmMWR3ZUxiV2FCaEFnMWJLZERkY2IxYUxnZ2VBaG1oVWdGYk1lS2hOZkFkeGJSZEZkQWFWZE5jTWVSY3doRGFLZlNjTWNnYUtlRmRJZXpiQ2dEaEpmV2FEYlFmc2JRZkRhMWNRaEllS2hEZUpoWmVOY2dhQWN5YUVmQWd3ZlBkTWExYkFlMWFEZVJnY2Y1ZU5naGVjZHljVGJpZDBkVGJVZGpoQWZBZVVoamU0ZVNiQ2dTYlVlc2hFZGxjOWVTZ05ja2dvYWZnRmUxZlFkN2RBYlNlVWVIZUxhd2J3aGxlUGJ3aHBnU2dNZEZmdGFjZ0NmMWVnZFFiTmVTaGdhM2FOZVNlNGFBYkpobGdCYVRiQ2JqZ1FoTWdVYVJjUWVGZ1RoVGJFaGNoQWV5YmtlamdJZUNoaGhTY01od2NnY3ljVmRnaDBhTGNFYkFhOWNVYkNoQ2FnYnljV2VUZlllQWNNZmhoQWRNaERhemdOY1FmTmZRZTBmWGFPZVRnWWVYYU1la2c0ZXRnRWgxY0lnd2hBZUZlSWIrZEVjZ2drYmxmTGdCY0phZmVVYmpkWmhLYUhheGZkZlVjT2N3Z0VobGNCZnlmOGhNZ0phVGg4ZEtkVWZqZkJhYmZYZ0FhdGFZYkVmRGJVZW9mTmV6Z1VndWFBYUNlWmhRY1Vid2JvYTBoRGFGaEVlVWhCY1VlMGN4aEhlQWJNZnBjSWN5Z0Fnb2JVYWpjTWhJYU1jbGJZZU5lQ2N4YkFiUGZWY0FoZ2NvZU1jbGZrZjJjQWJEZEloUWJEaEFoOGd6ZlVkRGZVY05mRmN6ZmtlMmdGaHpmSmFPYUxkUmVOZVNoTWdBZUJlU2FQZWhoSWZKaEpmU2R3Y1NkWGExYkljMmdTYWhnOGFYZFZmRGVzZ0JkSmJRaGNndmZEZUNkVWMvYUNlbGJJZ3dmV2MxaHdoTGJXZ0JmQWUxZEtoRGFjYzFhTGNnZUFjbWdVZEZjTWNLZE5jQWJ4Z1JiRmRBYVZoTmJNZFJod2VEZ0tjU2ZNZmdkS2ZGZ0lkemNDZkRjSmFXZURiUWVzZFFnRGUxZlFhSWRLYkRhSmZaYk5mZ2FBZXlmRWdBaHdiUGhNaDFkQWMxaERkUmFjZzVmTmFoYWNmeWdUZ2ljMGRUaFVhamdBZ0FiVWRqYjRlU2JDZVNmVWhzY0VjbGI5ZFNiTmhrZG9oZmRGaDFmUWY3aEFmU2RVZ0hiTGF3YXdmbGVQYXdmcGhTaE1mRmh0Y2NiQ2UxZ2diUWhOZVNjZ2UzZk5jU2Q0YkFlSmFsYkJiVGVDZ2pjUWRNaFVkUmZRZUZlVGVUZkVhY2NBZ3lia2NqZkllQ2VoZFNlTWV3aGdieWNWZmdlMGZMYkVjQWg5ZlViQ2RDZWdleWJXZFRjWWVBZU1naGNBZE1kRGN6YU5oUWVOaFFlMGhYZE9kVGJZYlhoTWNrZTRjdGdFZjFiSWJ3YkFoRmVJZythRWZnYWtmbGFMZ0JlSmhmZVVjamJaYUtoSGF4ZGRoVWhPZXdhRWJsaEJieWY4Yk1kSmRUZjhjS2RVZmphQmFiYVhkQWF0ZVlmRWNEZ1Vhb2FOaHphVWd1Z0FjQ2RaZFFmVWV3Ym9nMGVEYkZhRWJVaEJkVWgwYXhhSGNBaE1hcGJJZ3liQWhvZlVhamZNZ0liTWJsZFloTmNDYXhjQWFQZVZnQWFnZm9oTWVsZGtjMmhBaERkSWhRYkRhQWI4Z3pnVWdEZ1VmTmJGYXpha2cyYUZjemZKZ09iTGFSYk5hU2JNYUFlQmRTaFBlaGJJYkphSmhTZXdkU2RYaDFnSWcyZ1NmaGU4Y1hoVmREZXNjQmJKZVFlY2d2Y0RnQ2ZVYS9lQ2JsaElld2NXYzFld2dMaFdjQmhBYTFnS2ZEZWNhMWdMZ2diQWJtZVVkRmRNaEtiTmZBYnhnUmNGY0FjVmdOY01mUmV3YkRmS2NTZk1oZ2RLZkZhSWR6YkNkRGVKYldjRGNRaHNjUWJEYjFhUWJJZ0tkRGdKYVpkTmdnZkFleWVFY0Fod2hQZU1oMWZBYzFnRGdSZGNoNWNOZmhnY2Z5aFRiaWMwZVRkVWRqZkFnQWNVZ2plNGZTZkNmU2RVZ3NhRWJsZTlnU2JOaGtmb2ZmaEZkMWhRYjdiQWZTZVVoSGNMZHdld2NsYVBkd2ZwZVNkTWJGZXRmY2ZDZTFoZ2hRZk5oU2VnZzNnTmFTaDRoQWNKZWxnQmJUZkNiamRRaE1iVWFSZFFoRmJUZ1RkRWFjZUFkeWVrYmpmSWJDY2hoU2RNZXdjZ2J5ZVZnZ2MwZExhRWFBYjlkVWZDaENkZ2F5Y1dhVGRZZ0FlTWRoY0FjTWNEZHpnTmdRZU5lUWYwaFhjT2NUZFlkWGFNZ2tnNGJ0YUVlMWdJaHdkQWFGZUlhK2dFZ2dna2FsY0xmQmFKYmZiVWVqZ1pnS2ZIYXhjZGdVY09id2RFYmxkQmJ5ZDhoTWhKZ1RoOGhLYVVnamdCZGJnWGNBaHRjWWFFYURmVWRvZE5iemFVZXVlQWdDY1pjUWFVZHdjb2IwZERjRmNFYlVkQmZVaDBjeGJIZUFmTWZwZEloeWNBZG9nVWdqYU1iSWRNaGxjWWdOYUNmeGVBY1BnVmJBYWdib2dNYWxma2MyYUFmRGVJY1FjRGRBYThmemVVZkRlVWNOZkZnemVrZDJiRmZ6Z0piT2FMZVJhTmRTYU1mQWVCYlNoUGJoZUliSmJKYlNnd2RTZVhhMWhJaDJiU2RoYjhlWGNWZURlc2JCZ0phUWdjZ3ZhRGZDaFVoL2VDY2xlSWh3Z1dkMWJ3Z0xjV2JCZkFkMWdLYURjY2IxZExnZ2RBYm1kVWdGaE1jS2ZOaEFneGRSYkZlQWdWZU5kTWVSaHdnRGJLYlNlTWJnYkthRmhJYnpjQ2VEYkpkV2NEYlFlc2FRaERjMWNRY0lnS2ZEZkpoWmROY2diQWN5ZUVmQWJ3Z1BlTWQxZUFoMWZEZFJnY2I1Yk5iaGRjYnliVGRpZzBnVGZVZWphQWdBY1VjamQ0ZlNlQ2JTaFVkc2ZFY2xmOWVTY05ja2FvYWZnRmgxZ1FnN2FBaFNmVWVIYUxod2h3aGxoUGN3ZnBhU2hNYUZjdGNjZENhMWZnaFFmTmNTZGdjM2dOZlNlNGJBaEplbGNCaFRlQ2VqaFFhTWdVZlJnUWRGaFRkVGNFYmNnQWF5Z2tmamdJYUNlaGZTY01nd2VnYXlnVmVnYzBjTGhFYUFmOWFVZkNjQ2NnZ3llV2hUZVlhQWdNZ2hiQWJNYURmemdOZ1FhTmdRYzBhWGdPY1RjWWJYYk1na2g0ZXRhRWExaElkd2JBZEZnSWgrZEVjZ2FrYWxhTGRCYkpmZmJVZWpjWmZLY0hkeGFkZ1ViT2d3aEVnbGRCZXlkOGJNaEplVGg4YktoVWRqY0JmYmhYYUFhdGZZY0VoRGhVZG9mTmd6Z1VidWZBY0NkWmRRaFVhd2VvYTBoRGVGYUVlVWRCZlVlMGJ4Z0hhQWVNZXBjSWR5ZUFob2FVZmpkTWFJZk1mbGdZZU5hQ2Z4aEFhUGdWYkFnZ2VvZU1mbGVrZjJoQWJEYkliUWREZ0FlOGJ6Z1VkRGFVZU5kRmh6Y2tnMmVGY3pjSmZPZUxhUmZOYVNnTWFBZkJoU2hQY2hlSWFKZkplU2V3YlNlWGIxZklkMmRTZWhjOGZYaFZmRGJzZEJjSmVRZGNidmdEYUNoVWMvZkNmbGZJZHdhV2gxZHdmTGZXZEJiQWYxZUtnRGZjYTFmTGFnZUFobWFVY0ZoTWRLYU5jQWN4Z1JhRmZBZFZoTmdNY1Jnd2hEZ0toU2hNYmdoS2dGYUllemdDY0RmSmhXaERjUWJzZFFkRGIxYlFlSWdLZERmSmhaY05nZ2ZBZnljRWVBZXdiUGdNZzFjQWcxYURhUmVjZDVjTmZoZ2NkeWdUYmllMGhUZFViamdBY0FhVWVqZzRoU2dDaFNmVWVzYkVmbGE5ZVNoTmhrZ29hZmJGZDFhUWc3YUFlU2dVZEhlTGR3Z3dmbGdQY3dkcGdTZk1jRmh0ZGNoQ2UxY2dmUWFOZlNiZ2QzY05iU2Q0ZEFhSmNsaEJjVGVDYmpkUWFNZ1VhUmhRZUZjVGRUZUVnY2JBYXlna2dqZ0loQ2RoZ1NlTWN3ZmdleWNWYmdoMGFMZEVlQWI5YlVjQ2JDZGdneWFXY1RhWWVBYk1maGhBZE1iRGd6Y05lUWZOYVFmMGFYZ09kVGNZZlhnTWhrYzRjdGdFYzFnSWh3YUFlRmFJZCthRWNnZGtkbGdMY0JjSmVmaFVhamVaYktlSGh4Z2RnVWdPZ3dmRWJsYUJmeWI4Zk1iSmJUYThmS2hVZWpjQmZiZVhhQWV0ZlloRWVEYVVmb2FOYnpoVWJ1aEFmQ2haaFFjVWN3Y29jMGREY0ZnRWdVZUJhVWEwY3hkSGFBZ01ncGhJZnlkQWNvZFViamFNZElkTWdsZ1lmTmZDZHhiQWFQY1ZkQWdnYW9lTWJsaGtjMmRBZURiSWFRYURoQWU4aHpiVWdEaFVoTmZGY3pha2YyZ0ZjemJKZ09hTGNSZU5mU2VNZ0FlQmZTZlBlaGVJZUphSmVTZHdmU2FYZTFjSWgyYVNiaGI4Y1hhVmdEYnNnQmVKZ1FiY2N2aERlQ2RVaC9jQ2ZsZklmd2NXZTFid2NMY1dhQmVBZTFhS2JEYWNjMWdMYWdlQWNtZVVhRmRNYktmTmFBYnhoUmhGZkFnVmROYU1hUmR3ZURkS2dTZU1mZ2hLZkZjSWd6aENhRGhKY1dnRGZRaHNlUWJEaDFkUWNJYktnRGFKYlphTmRnZUFmeWZFaEFod2JQaE1nMWNBYTFhRGhSZmNkNWZOYWhkY2Z5ZlRkaWQwaFRiVWRqY0FkQWVVYWpnNGRTZENjU2ZVZ3NlRWVsYTlkU2NOZ2tmb2ZmYkZiMWNRaDdlQWNTZFVmSGVMY3dod2hsYVBkd2dwY1NoTWJGZHRnY2FDYTFoZ2JRYU5kU2FnYzNoTmFTYjRjQWhKZWxoQmdUZENnamZRZE1hVWdSZFFmRmNUYVRlRWFjZ0FieWFrYWpiSWVDYWhnU2dNZXdnZ2R5Z1ZjZ2cwZkxlRWhBZDlkVWFDZENmZ2d5ZFdiVGFZZEFiTWhoZUFjTWVEaHpnTmdRZU5jUWIwZ1hlT2ZUYllkWGFNZGtkNGh0aEVoMWhJYXdnQWFGZklhK2dFYmdma2ZsZkxnQmFKZmZnVWdqZFplS2VIZnhoZGFVZ09hd2VFaGxmQmh5YjhnTWdKaFRkOGhLZ1VmamRCZmJjWGNBYXRkWWFFZURlVWJvaE5jemZVYnVjQWdDZVpkUWJVY3dhb2EwZkRiRmdFZFVoQmZVZzBkeGRIZ0FnTWVwYklkeWhBZG9nVWhqZk1kSWdNYmxhWWROZkNjeGRBYVBjVmVBZWdlb2FNZWxna2cyYUFnRGFJaFFoRGVBZjhiemRVZERkVWdOZkZoemVrZjJmRmZ6Y0plT2ZMZ1JhTmdTZk1jQWZCZFNhUGNoYUllSmNKZlNjd2NTY1hlMWZJZTJhU2doZjhoWGFWZkRmc2VCZ0phUWNjZnZnRGZDaFViL2NDaGxhSWJ3YldmMWJ3ZExkV2RCaEFhMWJLY0RhY2gxZExmZ2VBZW1hVWJGZE1nS2dOaEFoeGhSZkZkQWRWYU5iTWNSZndjRGZLZFNmTWZnYktjRmNJZ3pmQ2dEYkpoV2ZEYlFmc2JRYkRiMWRRYkljS2hEZUpiWmNOaGdjQWR5ZkVkQWd3Y1BiTWcxZUFjMWREYlJjY2E1Yk5haGNjY3loVGVpZTBmVGZVYmpiQWRBYlViamg0Y1NlQ2RTZlVkc2FFZWxmOWJTY05ha2ZvYWZhRmUxYlFiN2VBZlNlVWFIZUxmd2h3aGxkUGd3ZXBiU2ZNZUZidGZjY0NjMWFnY1FkTmhTY2diM2hOY1NoNGFBYUpjbGJCZlRoQ2FqY1FoTWVVZVJkUWJGZ1RnVGNFYWNnQWR5YWthamJJaENoaGdTZE1nd2RnZXllVmhnYjBjTGVFYUFlOWhVZENhQ2dnYXliV2dUZllhQWRNZ2hnQWFNZkRmemNOZVFiTmhRYTBnWGdPZVRhWWdYYk1ia2c0ZHRkRWcxZklhd2hBY0ZoSWMrZkVhZ2hrZGxkTGZCZUpmZmRVZWpoWmRLYkhneGJkZVVhT2h3ZUVkbGdCZXlkOGZNZ0poVGI4aEtiVWVqZ0JhYmVYZEFndGNZaEViRGhVYW9oTmF6ZVVhdWFBZUNmWmRRaFVid2FvZTBiRGdGaEVhVWhCYVVnMGZ4Y0hiQWFNYnBmSWd5ZkFkb2NVZWpmTWhJZU1ibGdZYU5jQ2Z4Z0FoUGVWZ0FmZ2VvZ01mbGFrYzJhQWVEZ0lhUWNEYkFlOGN6YlVoRGFVYU5mRmN6Y2toMmNGZXpmSmZPZkxnUmNOYlNoTWdBZEJlU2FQYWhnSWRKaEpkU2J3aFNkWGQxaEljMmRTY2hoOGNYZ1ZjRGFzY0JhSmFRZWNhdmhEYUNhVWMvZ0NkbGFJZXdiV2ExZHdiTGFXZkJiQWgxZUtkRGVjYjFoTGZnZUFlbWhVYkZhTWVLZ05kQWd4ZFJoRmRBYlZiTmFNZFJod2ZEZktkU2NNZGdjS2JGYkllemVDZURnSmRXZ0RkUWdzYVFkRGcxZ1FoSWRLYkRlSmFaZE5lZ2VBYXloRWVBZHdiUGdNZDFiQWIxaERnUmdjYTVoTmNoYWNleWZUaGliMGRUYlVhamRBYkFmVWJqZjRnU2ZDY1NoVWdzYUVkbGY5Z1NmTmJrZW9lZmZGZjFiUWU3Y0FjU2RVY0hnTGR3aHdjbGJQY3dhcGFTaE1jRmZ0YmNoQ2cxZmdhUWZOZ1NoZ2IzZU5lU2M0ZEFoSmZsZUJoVGVDaGpnUWVNZVVmUmRRZ0ZhVGdUYUVlY2NBYnlha2NqZ0ljQ2hoZ1NnTWV3aGdjeWRWZGdkMGJMZ0VlQWU5YVVjQ2dDZ2doeWVXZlRiWWVBZk1laGVBZk1hRGF6ZU5nUWJOY1FkMGVYZk9hVGhZZ1hoTWZrZjRodGRFaDFlSWh3ZkFjRmFJaCtkRWFnZGthbGVMZEJoSmZmY1ViamRaZUtmSGF4ZGRmVWZPZ3dhRWFsZkJleWc4ZE1iSmNUZjhiS2ZVZWphQmNiY1hmQWF0Z1lnRWFEYlVlb2JOaHpiVWV1aEFkQ2daaFFnVWZ3aG9oMGdEZUZjRWVVZUJjVWgwZXhoSGdBZk1icGVJZ3llQWVvaFVnamNNZ0llTWVsZVliTmZDZ3hmQWNQZFZnQWRnZG9hTWhsZWtjMmNBaERnSWdRYkRjQWE4aHpkVWFEZVVjTmNGZ3pha2MyZ0ZkemFKYU9oTGVSZk5nU2dNZkFnQmhTZVBmaGJJaEpnSmNTaHdoU2hYZjFmSWEyY1NlaGI4YVhoVmREZnNoQmNKZlFnY2Z2ZURiQ2JVaC9jQ2JsZElkd2hXZTFod2VMZ1dmQmZBZDFmS2VEZ2NnMWhMYWdlQWdtZVVhRmFNaEtlTmZBZ3hoUmdGYkFjVmJOZE1oUmR3Y0RoS2RTZE1hZ2NLZkZjSWN6ZENiRGNKZVdhRGRRY3NiUWhEZDFlUWNJZ0toRGRKYVpnTmhnYkFheWJFYUFkd2hQYk1lMWZBZzFkRGRSY2NjNWNOZ2hjY2N5aFRjaWYwZ1RkVWFqZ0FlQWFVZmphNGZTY0NlU2JVZnNlRWdsZzllU2JOYmtmb2hmaEZiMWdRYTdnQWhTaFVjSGdMaHdnd2RsZFBid2FwZlNiTWVGZXRkY2hDaDFkZ2VRYk5iU2FnYjNmTmRTZjRkQWJKZ2xiQmVUY0NjamJRZk1kVWNSZ1FhRmhUY1RmRWZjZEFjeWhrZGpiSWdDZ2hlU2hNaHdnZ2Z5ZVZjZ2gwaExnRWdBZDlkVWFDZUNjZ2V5YVdjVGZZaEFmTWhoYkFiTWFEY3pnTmdRZk5mUWIwZ1hjT2dUZlljWGFNZGtmNGd0ZkVmMWFJZndkQWVGYkliK2VFZWdla2dsaExmQmVKZ2ZnVWRqaFpnS2VIZXhmZGhVZU9nd2hFYWxlQmZ5YThhTWZKYlRoOGFLaFVlamhCZ2JiWGFBZHRlWWJFZkRlVWZvaE5iemdVZXVnQWZDZ1pjUWFVYXdjb2YwaERnRmFFZFVnQmVVZTBheGVIZ0FlTWZwY0lheWRBYm9lVWVqZ01lSWdNZGxnWWdOZ0NleGhBaFBjVmZBZmdjb2ZNZmxma2UyY0FnRGRJY1FkRGNBaDhoemFVZERmVWVOZEZhemVrZzJlRmV6Y0pkT2FMZ1JkTmFTYU1mQWdCYVNjUGdoZEllSmRKZVNnd2NTZVhjMWJJaDJhU2JoYzhjWGZWZ0Rjc2ZCZUpkUWVjZ3ZnRGRDZVVlL2hDaGxjSWF3YldiMWJ3ZUxjV2JCY0FnMWVLZkRiY2gxZ0xkZ2FBYW1nVWNGYU1nS2JOZ0FneGFSZkZoQWVWYk5iTWRSYndmRGdLZVNkTWhnYktiRmJJYnpjQ2NEZ0phV2hEZ1Foc2RRZkRoMWJRYklhS2hEYkpmWmJOZ2dkQWN5ZUVnQWJ3aFBlTWMxYUFoMWREYVJmY2Y1Yk5kaGhjaHliVGZpYjBnVGFVZGplQWFBYlVmamE0Z1NoQ2RTZVVic2dFZ2xnOWNTY05oa2ZvZGZlRmUxYVFnN2NBYlNmVWZIYUxjd2V3Z2xlUGV3Z3BnU2ZNaEZodGVjZ0NhMWJnYlFnTmVTaGdoM2ZOZ1NiNGZBZkpkbGdCYlRjQ2FqY1FhTWNVaFJoUWVGYVRjVGNFZWNoQWZ5ZGtnamhJZkNjaGdTY01md2VnYXljVmRnZTBkTGdFZUFnOWNVZENhQ2JnZnljV2RUZ1ljQWVNZmhhQWVNY0RkemdOY1FjTmJRYzBhWGdPZFRoWWFYZ01ja2U0Y3RnRWgxZUlod2ZBY0ZkSWgrZUVmZ2RrZmxnTGJCY0pkZmRVZGpnWmFLaEhheGhkZlVnT2J3ZEVnbGRCZ3liOGhNYUpiVGI4YktmVWdqY0JoYmNYY0FjdGNZZ0VjRGhVZ29iTmJ6YVVldWdBYUNkWmhRYlVhd2ZvZTBoRGVGZkVmVWVCZFVmMGR4YUhmQWFNZXBlSWZ5ZkFob2NVYWpiTWRJZk1obGJZZU5oQ2J4YUFiUGZWY0FlZ2VvZE1ibGRrZDJoQWNEZ0lnUWZEY0FlOGJ6aFVnRGRVZU5lRmF6Z2thMmVGZXpjSmFPZExmUmhOZVNoTWRBZ0JjU2JQZWhjSWRKZEpnU2V3YVNoWGYxaEljMmVTZmhiOGFYZlZmRGZzZEJjSmVRaGNldmVEY0NjVWYvZkNhbGRJZndkV2YxaHdiTGRXaEJoQWYxYkthRGNjZTFnTGFnYkFhbWFVaEZhTWFLZ05kQWJ4ZFJmRmhBY1ZmTmVNZFJhd2VEaEtjU2RNYmdjS2JGaEljemdDZ0RmSmhXZkRnUWdzZFFhRGUxYVFnSWNLZERhSmhaZU5hZ2FBYXlhRWNBZHdiUGJNYTFiQWIxaERhUmZjZzVnTmJoZ2NneWVUZmlmMGhUZVVmamRBZUFoVWZqZjRiU2NDYVNlVWRzY0VhbGY5ZFNkTmFraG9iZmFGYTFoUWY3aEFmU2JVZ0hoTGV3YXdobGVQaHdmcGNTYU1iRmN0Z2NhQ2IxY2diUWhOYVNoZ2gzZE5kU2E0YUFmSmdsZUJoVGdDZGpoUWVNZ1VlUmRRZUZnVGJUZUVmY2VBZHlha2ZqZklkQ2FoZFNiTWZ3YmdieWhWY2diMGJMaEVmQWI5aFVmQ2FDZGdheWVXYlRiWWdBY01haGdBaE1nRGZ6YU5mUWhOZFFoMGZYZU9hVGVZZlhhTWdrZjRidGFFaDFnSWN3aEFmRmNJZStoRWFnYWtobGRMYUJiSmJmZ1VhamRaYUtmSGF4Z2RoVWZPaHdkRWRsZ0JjeWU4ZE1lSmFUYThnS2hVYWpiQmFiZ1hlQWZ0YlljRWVEYVVhb2FOZHplVWN1aEFmQ2JaYlFjVWJ3YW9oMGNEYkZoRWdVY0JoVWEwZHhhSGRBZ01jcGRJYnlmQWdvY1VkamZNZklkTWZsaFlnTmJDZnhmQWJQYVZiQWVnZ29mTWJsZGtoMmJBZ0RlSWhRZkRjQWI4Y3phVWdEYlVkTmZGYnpja2EyYkZjemFKY09hTGhSZE5lU2JNZEFhQmdTZlBlaGZJYkpnSmJTZXdnU2NYZjFoSWEyZlNjaGU4ZlhiVmVEaHNoQmNKYlFmY2J2Z0RhQ2NVZC9kQ2RsYklnd2NXYzFod2NMYVdiQmVBYTFnS2FEYmNiMWRMY2dmQWJtZlVhRmdNaEtkTmNBZHhhUmVGY0FiVmVOY01nUmJ3YkRiS2ZTYU1mZ2NLZ0ZiSWd6Y0NhRGVKZldoRGZRZ3NkUWNEZDFkUWFJZUtnRGdKZ1pkTmNnZkFmeWdFY0Fid2JQaE1kMWRBYzFlRGVSZmNjNWFOYWhnY2F5YlRhaWQwYVRkVWNqZEFnQWZVZWpmNGhTYkNmU2VVYXNiRWZsYzlnU2NOZmtmb2JmYUZjMWNRYjdmQWhTYVViSGRMaHdid2hsZFBid2VwYVNiTWVGZHRkY2NDZjFkZ2dRYU5hU2NnYTNmTmJTYzRkQWFKZGxhQmZUY0NkamdRZE1mVWZSZFFlRmNUZ1RoRWZjaEFoeWZrZGpmSWRDZGhlU2FNYndoZ2F5Y1ZiZ2YwaExmRWFBYTlnVWdDaENjZ2V5ZldlVGhZY0FkTWVoYUFoTWVEZnplTmVRZk5oUWUwZlhjT2JUY1lhWGdNY2tlNGJ0Z0ViMWdJY3dlQWZGaElnK2RFYmdja2FsZUxoQmNKZWZoVWFqY1pmS2dIZnhoZGFVZ09nd2JFZGxmQmR5aDhoTWVKYVRnOGhLZlVmamRCZGJoWGRBY3RoWWNFZ0RmVWFvYk5kemhVZHVnQWVDaFplUWJVZXdlb2MwY0RoRmNFZ1VkQmhVYjBieGNIYUFhTWFwZklneWdBaG9hVWFqZ01oSWRNY2xnWWhOY0NmeGFBZFBlVmhBZWdmb2NNZmxja2EyYUFkRGhJYVFkRGdBZDhmemZVY0RlVWNOaEZiemJrZTJnRmd6YUphT2FMYlJmTmJTYU1hQWRCaFNlUGVoZEllSmhKZVNid2dTZVhmMWdJYzJlU2doYzhiWGNWaERkc2FCY0pjUWJjY3ZkRGZDZ1VlL2FDZ2xkSWF3ZVdlMWV3YUxhV2hCYkFnMWFLZURiY2IxY0xkZ2hBZW1jVWRGaE1oS2JOZkFleGdSZEZiQWZWYk5hTWNSZHdiRGVLZlNjTWNnYUtkRmdJZ3phQ2ZEZ0phV2REZ1Fhc2JRZkRiMWRRYklhS2hEYkpkWmNOY2dmQWN5YUVmQWJ3YlBiTWIxYkFlMWJEZlJkY2Q1Z05naGhjaHlmVGJpYTBiVGRVZWpmQWNBaFViamc0ZlNmQ2JTaFVoc2VFY2xoOWdTZE5oa2NvaGZnRmExZVFoN2hBYlNlVWdIZExnd2R3YmxlUGd3ZHBlU2VNZUZkdGRjZENiMWVnZFFoTmhTZWdjM2NOZVNhNGVBYkpjbGdCaFRiQ2JqYVFlTWdVYlJhUWJGaFRmVGJFZ2NmQWF5aGtkamhJYUNjaGVTZ01id2dnY3loVmZnYzBnTGNFZ0FjOWVVZkNoQ2hnYnlmV2RUYVliQWhNYmhnQWdNaERiemdOYlFlTmFRYTBnWGJPYlRoWWFYZk1oa2I0ZnRiRWUxYklmd2NBYkZlSWMrZEVjZ2hrYWxhTGJCYUplZmRVZGpoWmFLaEhjeGFkY1VmT2N3Y0VlbGNCYXloOGVNYkpmVGU4ZkthVWJqYkJlYmVYY0FjdGVZZkVnRGVVZ29jTmF6YlVjdWRBYkNmWmdRYVVod2hvYjBoRGVGYkVjVWRCYlVhMGV4YkhjQWRNY3BiSWh5Z0Fnb2hVZmpnTWFJaE1lbGVZZk5nQ2V4ZkFiUGVWZUFkZ2dvYU1mbGFrYzJlQWdEYUliUWNEZ0FnOGN6Z1ViRGhVZ05kRmJ6ZWtmMmhGaHplSmVPYkxkUmROZFNkTWFBZEJmU2FQZmhhSWVKaEpkU2R3YVNhWGYxZElkMmJTYmhoOGVYZ1ZlRGNzZkJhSmNRYmNndmFEZ0NlVWEvaENnbGRJY3djV2gxYndhTGNXaEJiQWgxZ0tiRGNjYTFmTGJnY0FnbWhVYUZiTWJLZ05nQWZ4Y1JnRmFBZ1ZmTmdNYVJjd2VEZUtkU2NNZ2dkS2VGZUlmemVDYURlSmNXZERlUWNzZ1FnRGIxY1FmSWNLY0RlSmdaZE5kZ2VBaHllRWZBZXdlUGZNYzFiQWcxY0RmUmhjYjVnTmhoZmNoeWVUYmljMGFUYVVoamRBZ0FjVWNqZzRhU2FDZFNhVWVzY0VmbGM5Z1NoTmVraG9lZmhGaDFlUWI3ZkFkU2ZVYkhlTGF3YndjbGFQYndhcGZTYk1lRmR0ZWNjQ2gxZWdkUWhOYVNhZ2MzY05lU2Q0YkFoSmhsYUJnVGVDZ2pmUWNNYVVnUmFRZ0ZlVGRUZkVnY2hBZXlka2VqZklkQ2RoYVNkTWV3ZWdieWdWYWdlMGNMZ0VkQWI5YVVkQ2hDaGdieWhXaFRiWWFBaE1laGRBaE1iRGF6ZE5oUWROZlFkMGdYYk9hVGdZY1hnTWdrZTRodGRFYTFnSWN3Y0FnRmVJZitoRWdnYmtlbGNMY0JnSmZmZFVhamhaZ0tiSGV4Y2RoVWNPY3diRWhsY0JkeWM4Yk1oSmVUZzhoS2NVaGphQmZiZlhiQWZ0ZFloRWdEaFVjb2JOZ3pkVWJ1ZEFjQ2JaZFFlVWN3Zm9nMGdEYkZmRWFVZEJiVWcwZnhjSGVBYU1jcGRJYnllQWFvYlVnamRNZUlkTWJsaFljTmNDZXhoQWVQZFZiQWNnZm9hTWRsYmtlMmFBY0RmSWhRaERkQWM4ZXpkVWVEYVVlTmFGZXpoa2gyZUZlemFKZE9mTGRSZE5nU2RNZkFiQmVTYVBnaGFJZUpoSmZTY3dnU2VYYTFlSWUyZlNkaGM4ZlhmVmFEZnNiQmJKY1FkY2F2ZERhQ2dVaC9lQ2FsY0lmd2RXZDFmd2dMZldlQmVBaDFoS2ZEaGNnMWRMZ2dnQWNtYlVmRmFNYktlTmZBYXhlUmNGZkFiVmROZk1hUmF3Z0RiS2hTZE1oZ2dLZ0ZmSWZ6aENhRGhKZFdmRGVRZXNiUWdEZjFkUWdJZ0tlRGZKZ1plTmFnZ0FheWJFYUFkd2dQZ01jMWdBYjFiRGhSaGNiNWdOaGhlY2J5YlRnaWQwaFRiVWhqY0FnQWZVYmpoNGdTZENoU2JVY3NoRWdsZDlmU2dOZWthb2FmaEZjMWRRaDdoQWFTZVVoSGNMZXdhd2NsZ1Bkd2ZwYlNnTWFGYXRlY2RDYzFkZ2NRaE5jU2dnYTNmTmZTZzRmQWFKZmxlQmVUZ0NkamhRZU1iVWVSaFFlRmdUY1RoRWRjaEFjeWNraGpnSWZDZmhkU2JNY3dkZ2d5ZlZoZ2QwZ0xiRWRBZTloVWZDY0NiZ2J5Z1dkVGNZZ0FhTWVoZUFkTWZEZnpjTmVRZ05mUWYwZVhkT2FUZFllWGZNaGthNGh0ZUVkMWhJaHdiQWVGY0ljK2FFZmdoa2dsZ0xmQmhKZWZnVWFqYVpnS2hIZnhoZGFVaE9ld2NFZGxlQmZ5ZzhhTWZKaFRmOGVLYlVoamZCZ2JoWGJBYnRnWWdFYURkVWJvaE5nemFVZnVhQWFDY1piUWNVaHdib2gwZURlRmRFY1VjQmVVYjBkeGZIY0FoTWhwZ0lneWVBY29iVWRqYk1iSWZNZmxlWWJOZUNoeGVBZFBkVmdBZ2dob2hNZGxia2UyaEFnRGhJYVFnRGdBZjhiemhVZkRoVWZOZkZlemVrYTJhRmF6Z0pjT2FMZFJiTmdTZE1nQWdCZFNmUGdoZklnSmJKZVNmd2FTZlhoMWVJZjJiU2doYThhWGJWY0Rkc2JCY0pmUWJjYXZhRGNDYlVkL2RDaGxlSWN3ZVdoMWd3aExlV2FCZ0FnMWJLZ0RoY2QxZExiZ2hBY21iVWRGYk1hS2JOYkFjeGRSaEZhQWdWZE5mTWdSZ3doRGhLYVNiTWVnZktjRmdJZ3pkQ2ZEZUpjV2NEaFFjc2VRaERiMWZRY0liS2NEaEpoWmFOZGdhQWd5ZkVoQWR3Z1BjTWMxZEFkMWJEZlJiY2Q1Z05oaGNjZHlnVGJpYjBiVGhVYmpjQWJBZ1VnamY0ZlNjQ2JTZVVnc2dFZGxlOWRTY05na2JvZmZhRmQxZlFoN2dBZlNoVWVIYkxjd2N3ZWxjUGJ3ZXBkU2NNZEZldGZjZUNhMWVnY1FnTmVTaGdiM2ROYVNjNGZBZEplbGRCY1RiQ2ZqZVFjTWZVYlJoUWdGaFRkVGJFZmNjQWh5ZWthamVJYkNiaGRTZk1ld2JnZXlkVmJnaDBiTGNFYkFmOWNVaENlQ2RnZnlkV2VUZVlmQWNNZmhmQWFNZ0RlemhOZ1FjTmhRYjBoWGdPaFRnWWJYZ01ia2M0ZnRlRWExZ0lkd2JBYkZnSWQrYkVoZ2JrYWxmTGRCY0pkZmJVZmpjWmNLZ0hjeGFkaFViT2J3YkVibGRCZXloOGdNZEphVGE4aEtnVWhqZkJmYmNYaEFkdGdZZEVnRGJVZG9hTmV6ZlVmdWhBaENlWmFRZlVld2JvZTBhRGJGZUVlVWRCYlVmMGd4YUhjQWJNZXBmSWh5YkFib2dVY2pmTWdJZE1ibGVZYU5kQ2h4ZEFnUGhWYUFoZ2VvZk1nbGJrZDJiQWJEZUliUWFEZUFnOGd6ZVViRGJVY05jRmJ6Z2tkMmJGaHpjSmVPZExlUmZOZ1NkTWJBY0JoU2JQZWhlSWNKZEphU2R3Z1NlWGYxZ0ljMmdTZGhoOGhYZFZmRGJzZ0JoSmJRY2NjdmZEZ0NnVWcvZ0NkbGZJYXdkV2UxZXdlTGVXY0JlQWExY0thRGVjaDFkTGFnYkFjbWZVY0ZlTWVLZ05hQWF4aFJiRmVBYVZmTmdNZlJkd2REZ0thU2RNZmdoS2hGYklhemJDaERiSmhXZkRkUWhzYVFhRGIxaFFoSWJLZERlSmRaZU5nZ2FBZnliRWhBYXdnUGhNYjFnQWIxaERoUmdjYzVlTmNoYmNoeWJUZ2llMGJUZVVlamRBZEFiVWZqYTRmU2FDYVNoVWZzZUVmbGI5Z1NoTmVrZG9kZmZGZzFjUWE3ZEFjU2ZVZkhjTGd3ZndlbGFQZXdlcGVTaE1oRmZ0aGNlQ2gxZ2dmUWdOaFNnZ2IzZk5nU2M0ZEFnSmNsZUJoVGRDYmpnUWFNZ1VjUmRRYkZoVGJUaEVkY2JBYnlna2FqYkllQ2JoaFNlTWN3ZWdoeWNWaGdoMGdMZEVnQWQ5ZVVlQ2hDaGdjeWFXYlRmWWZBYk1kaGdBZk1jRGR6Zk5nUWhOZ1FnMGRYY09oVGdZZlhhTWhrYzRjdGJFYjFkSWR3ZEFmRmdJaCtnRWFnZ2tmbGVMaEJnSmNmZlVnamVaaEtnSGR4Y2RlVWhPaHdmRWNsZUJmeWU4Yk1nSmFUZThkS2FVY2pnQmNiaFhiQWF0aFliRWJEY1Vmb2hOYXpoVWV1ZkFkQ2haZlFkVWF3aG9kMGdEZ0ZoRWRVaEJjVWgwZXhlSGhBZk1jcGZJY3liQWNvYlVjamdNZ0lmTWZsZVliTmhDYXhjQWdQZVZjQWVnZG9kTWRsaGtoMmdBZ0RjSWRRZkRkQWc4Z3plVWJEZFVkTmZGZnpia2gyZUZkemZKY09lTGhSZE5oU2JNY0FmQmhTZ1BnaGVJZUphSmFTZXdiU2dYZDFnSWcyYVNoaGE4YVhlVmhEZ3NnQmhKY1FiY2V2ZkRkQ2hVYS9nQ2dsaElhd2ZXYjFnd2VMZVdkQmRBZTFoS2ZEYWNoMWdMZGdjQWVtZlVmRmRNaEthTmRBYXhoUmZGZUFkVmJOYk1jUmV3Z0RjS2JTZU1mZ2dLZUZjSWF6Z0NkRGFKYVdoRGZRYXNnUWVEZjFkUWVJZEthRGZKZlphTmZnY0FieWFFY0Fhd2FQZE1hMWNBYjFhRGhSZWNjNWJOZWhoY2F5ZVRkaWMwaFRjVWFqZ0FlQWdVYmpmNGZTYkNoU2FVYnNjRWVsaDlmU2dOaGtlb2NmYUZiMWdRaDdjQWJTZFVmSGdMYndnd2RsY1BiMGRrZlBhTmNsYkZoU2FEZjFhZ2FhZ0FkQ2hZYi9lSWdHaEVhNWFLZUVlWmNYY0FjamFBZ1lmRWdFYjlnRWhUYkRhd2VWYkFmQ2c0YXVmRWRpZEZoZGhJZVVlQWc4ZFFhQWdrYURnRmhCZXNkT2daZUNoNGU0aFZoemRJZEFmT2RDZFVhQ2hCYnlhWWhmYlBnQmZ3ZFVmTmZqY1VjRWhkYUJhSmdyZENiVWJsZHFjYmZEZWtkN2VIYkFhRWMzYlBlbGdOYU5kWGdCaDFnU2FQZ3hkZGFjZktkVWVkZTVnUWZTZDVjRmRiYW5jTmFoaEZoSGZzaGRnZGdBZ3NoWmJEaHplc2I3YWRiamZzZ3VhRWRDZ0loV2dWZVFmTWNoZEhobGJVZ2NiUmZGZDhjNGRFZ3hlRmJ2ZEpjQ2NjaDdlR2hIZUlkRmdQZFZjOGNiaFRlUWZVaGVkV2draDRnOWhQZkZkRWMrZUJlaWJkaExmWWhFZzVoL2JPZDNkTmRHaFVkV2NsZCtmVmJuZVJobWJiaEJmOGdVZ09oQWd0ZURmS2doZ1lnY2NOY3liOGJYY0ZoemVsZHdmQWdWYWxiRWRIYUhkcGRIaEVjd2NrZHZiSGNpaEVkdmNEaGtnWmh4Y1JiRmFJaFljU2MxZ1lja2dJY2pjY2M5YVBiRWJZY21iUmhGZ2RlQWhkZVFhTmVFZFZoUmJjYkxnUGFoYVVkV2diZ3pjVWFwZE9oMGhBZTZhVGhqZXBiRWVRZm1oZGhSZFFiemE5Yk9lWWIzZHRlWWFhZDJodGhlZlhma2ZVZkdhSWVVZlVlamVIZDBkdGgzYWZkeGNFaDlkV2J5ZE1jSGhWY25oOGRGYVhnRGJWY2NmSGh5YTBidmZBaFVndGZXZE1ld2RRYVRlQmZSaDhoaWdIZXlod2RBZlBmUWZKYk9lZWVFZk5iU2hKYkZoTmVlY0dhVmdBZlpkT2JtZzViK2JKZzJhTmhHZE5nUmQ4Z1NhRmMxZjlmS2FFZUFiWWNXYVhiamdWY3dnUWdtaDloaWFaZG5nWWhVZ2VlZ2drZC9oWGF3YzRhTWRIZFRhMWVkY0JhemRwaDZhVmR5YUFhRWZPYmhhUWFZaFFkQWhwZVRkSmZnZm9jWGhNY0dnTmdFYmRmQmNKYnJoQWVCaHhiNGhTZ0ZkdGF1Z1JmMGFaZE9jYWdsaE1oWmJFZTJjb2hMYVdkeGJCaEhkTmNBY1Fjd2ZDYkNiRWNFZ1pkbmRsaFdkQ2FYZ0ZiSmRSY0JoMWJjZUdnVGdKY3VlTWFqYllhcGhEaHlkbGNUZEVoa2dwZnpkU2RsaFFkWGVBZGtnSWIrZUhmMGV3aHVkTGZ5ZUpiRGdGZUhnSmVPZmNhd2Y5aE1mQ2RSZ1FlUGdYYkFlQWZzYmZlR2ZNYU5iVGRYYVFkRGdRaDJoUmgxZUVmWGFOY01oU2czY2hleWRHZlRnWmFGYUxmaGZGYkFoY2gwY1ljT2haZlZoTWdiYlBjVGRvZldoVmhsZlZjd2dUZ2dlRWdHaFhkU2ZnZlRjTmMyaHRldWVTZm1oUmg1ZVZkQmVSaDVkV2VFZlVjZGRWaGdlUWhnZVBmWGRnY0xiRmJ5YjVkbmNDaHhlSWNlZWZnVWVNZFpoZWdFYVFhTGZjZEZkcGRZZ2JnMmhvZHlkWmUyZ3dlS2hKaG5mTWZOZ1RlQmc5ZlpiUWRCZXhlVmhRZHlia2hSZmVmQmNVZThjR2dCYmxkQ2FkY1ZnY2NtZkFhaGJJZ3NhT2RSYWthNmZEZzJoTmdiZkZnQ2VwZnNmRWgzYmdiQmdDZWpmQWcvZEFiVmNjZ1RjZWhFaDBhTWdHY0ZmRWZ1YURjaWJzaFBkYmNrZUlod2JjY0VkdGZQZFdkeGIwY2RkVGFSZWtlUWVJZlNiQWUxYUpneWZZZkphS2NSZFplQWZSZERhQmJEZkVmQWNsaHVjQ2UzaEJlYWRRaG1iOWdpZkxoeWE4Y1VoZWRnYmNkSWZWaFRoRmRFZ1VhUmZ0aFFjR2ZqaHdhbWdWZW5oQWhJY0RoeGhRYjNoUWVEYkJnSmhJYndhTWFEaExjQ2FOZ05mWGhnYTlocmFVZWhhUmZ4YVJha2JVZTVjQWhVYjhhcmJhY2tnNGNaZ0diemJsaHdnSGFDYnNhU2NaYTBiY2IvZVFhU2NkYVFkWmVEYXhoSGJGY0RiMGhIYkhkVWN3ZElhV2NuZFFmcmdMY2loTWJnY0ZlRGVOZUZlQ2VFY3djdWVGYXhoQWVQaFRoUmhCYWFkV2ZrYkphdmFZZ21kWmJwaFJoamRjZmFmSmNrZElmQ2NUZ1FmVWJ5Z1VmRGdOYW5jTmcxZWtoOGVEZlhjd2FlZFJmQWRzZ3RjUWVUZ3diZWNCYVNkdGI4Y1ZoamNzY0RnYWN4ZTBhYWZOaEJhNWNEZE5md2VFaGJiTmcyZFpkVGZTYnhkcGY4Y0NiMWRFaFpoSGdEY1piSGhlaFViRmh2ZVdmbWQxYzFiU2MxaHRoL2ZXZEVkVWhkY1ZmZ2NRaGdmUGFXaDFhWmJiZjBhWmFuZUZia2Q5Zm1kZGJVY29nUWZVZ2hmSmZLZklnbGhvZExlYmYzYjlmbWhNZGtkbGNwZ1piSGRNYVFoVGFFYjBhRGJEaEVlRWJiaE9memVvY1lnZWJHaHRiMGZVYlVocGNPYmRhUmdGYzdoSGhsYThjMWdjZUVkdGUwZldhMmNKYmVhUGZuYUZhR2hFYjNhaGhUYVRlMmJ3ZTRkWGdWZW9jVGZiZFFlc2JRaFhkeGI1YlFiUmMyZ1JlQmZiZmthcGhraGNoUmRrZGFjTmdSYTBmQWFUZlZnOGZEYk9oaWcwZWlhT2dpZEFoSWNaZXhoNWhHYlFhSGNVZERmSGdGZklmQmZBYW5lQWdCYmFmR2c5ZGloWmJtaGtjVWVjZ2tiNWZ6aFFja2FJaENjV2RSYzBlWmFUZ2lhQmM5ZkdkQ2V3ZGRkWGNsYkZhS2FUYm5iVWFSYmNnMGh4ZFJiZWhIZ0FjNWVOY2thVWd1Y0VkVWFCYi9lQWVsZFloK2JHYWdkRWhoZ0djZ2ZGaFdkUWN6Z1ZkWmNEZ1FjOGRhZ0xia2J0ZmtlQ2hHYUpoS2FQaDFmTmVMY0ZnSGJFZ2RkSGNVYzBkWmRWY25kUmZ1ZGRhbmVNYXNiQ2JTYWxoUWRXYXdic2RnZUdiRmFFZVFoQ2FFZjVlcWJXY2tmTmIrY2Jja2N4Z3BnRmdIYkpmT2djZXhlQmRNZlRjVmZGaEplRmdVZzRhc2RPY2thMGI5ZkJmQ2ZZZVFhQ2FBY0lnd2dDZTNkTmhOY1FjWGFSaGFlVmVuZlFjUGZhYjFiSWhVZWNlVWRZZlRiZWJGZ05iUGhJaHliOGVIYkFieGRNZTFkQmMzZE5nV2NFYm5kcGVIZ1piRWhGYnVhU2ZtZlJiNWNGaGhoMWFxZk5ieGExYU5mR2VWY1plMGNiYWljdGQ2YVllMmN4ZG5iRmJoZkpkTWJkZVVjb2dZYkFlRWRwaEZlY2ZFZ2RjQ2ZLY1RoY2VvaEtma2ZBZDdjQWhUZjBhUWRSZUJibGJZYlNlVWM1YWthYWFYYlFlWWVjYkVnRmgwYlVmVWJvZ1loTmVFYU5jemhCZ1ZiRmRsY1dmbGVaYTBiRGEyYXRoU2VGZkhkRmVHY0VmM2hnZ0hmVGgyYkplc2RVYzBmMGFkZkRiM2ZRZWNlQmRYZjhiMWhBYnpmRWZOYktkMmNCZ2tkZWVVZ3NhVWRjZFJhMGVkZlRnUmNsZFdnZGZHZzVlcGZjYXlja2dUY0tiVmFWYUdlQmNUY29jRWNFYkZjcGNOaENkeWZ0ZndiUWNtZjljaWVaY21ka2VVY2Nia2c1ZHpkRWhFYnhkTmZVZ1Vha2RWZFRmamFzY3hiVGdDZlVnVGRPYWxoRWRlaE5iWGdkYVZoTmNnYW9mUWNMY1Rhd2RDZWRkbmdKZndlZWJCaFJleGFSaGhnTmM0YlVjMGg5Z2tnYWFsYU1oWmZFYjNoQWVMY0JnSGh3ZlNoZWdrZGRha2FRYVdkNWFLZlpjSGJsZkxoRmNIZEVlSGNIYVFhdGJNYkdmRGJjZTZlUGd6ZHdiaGRSaG1hOGJmZkVoaGhkZGZjU2RoYUJkU2dSYkFhdGR3Y1dia2JKY3ZjWWVtZlpicGhGYUhhSmRPY2NiMGdJYUpnR2ZRZ1FoYmhXZTBhNGM5aGJhemJKZndoUWVYYlJhUmVTZGtkNWMxaEVnWGhOZE1lVWFYZmhkd2RWYWlka2JVYVFiVmhJZ1VjY2FVZVlhVGFlY0ZmTmZQY05iaWg4YkhnVGRFYUVoK2dDYndjdGFZZVZnbmNJaE9kYWNFY0Znc2hDaDJmWmIxZlNhMWYxZTRoRWVSYTBmRWNBaG5meGcwaGJlbmJaZ3pmYmcwZFlhNmJIYnhiNWFtZWRiVWJvZ1FmVWRrYVFnTGVlZ0FiaGVNZkloR2hKYTdjYWhWZEllbmFBZ0RhQmZFZEJiUWZJYWZkU2VSZDBlYWJaZlhlUmJLY2VmVWVFaHZhZWYwZnBhT2hkaFJjRmJ6ZVRmRmNGZTRiSWFoYU1mZ2VXZ2poa2VjY0ZmQmQ0Y0VkV2FUZDBhUWdHYTJib2M2YkFnVmhaZEhiUGQxYzhmQWRCZmxlZGUwaERkeWhVaFNhQWZSZTBncWRDY1JnbGhiZUlkVmFoZFBhR2hVZUJiWWROaHliOGU2YlBiMmhjZlNoYWZ4YVplQWRSZldkNWZnZUVjRmhKZUVmQ2gzaEJkYWhIZjJhWmF1Y1RmR2ZrZVVkY2FraDVjemZFZkVoUWFmZlhneGFrZFZjVWUyYmxnMmNHYW5ibGROYlhibGNGYUtjVGVuYVVlUmJjZHhhNWZaZmNkQ2VKZFloSmR3aDlkMmRVaGdkWmc0YVRhemJsaDRmVWcwaDlma2FZZDBlZ2N6ZkVjM2hCYVdhVWNGYjVjcGZVZEViZGJrZ1FjV2E0Zk1kTWhUZWNkSWdRYURnaGRTY1ViMGIwY1JkQWduYWhndWhKZkhiOWV2ZkRkMmU0YVdhU2dXaFpmMWVTY2hiQmFTZ1JoQWh0YXlhRGJ4ZkVocWFZYWphVWM5YlJkamJzYU5mSmZ4YkphWGNaYzFnRmVKZkZhVWE1ZHBkZGhCaEFmMmVGZ0Rob2JTZEhlZ2FjYzZlWGIzYU5kRWdCZFhnRmN3ZURlVmg0YVBiYWMxaElnVWVjaFVhWWNUY2VlQmdVYWFjS2NpYWtjSGZVaEZnd2IrYUNjeGV4ZWVnR2UzYW9jY2hUZGthRmh1ZlNhbWZSaDViU2R4ZlJkeGdIZ1JmMGRaYlNld2E5aDBjTmdWZ3hiemhiYzBhWmFuZUZlaGRKaE1nZGFVaG9lUWFVZmtkUmVkZk1oUWhoZENiT2UyZUphN2dhZVZhb2QzZkdkWGVOZWxlQmRRY01hRmNVYVhkUWZjYU9lemZWYkJkZWJGZkJmOWNTY21jQmRPY2RkUmNGaHpnVGFGZ0ZjNGRjY0ZkWmMwZERjMmNzYkFhVWRTZ1VjVGJRZ1RlWmFUZlJhMGQ1aHFjVWh4ZWtkVGFjYUFidGRaYlZhaGFKZTZlUmYyZ1JiQmhiZ2thSWZ3ZWRhemVSZ3JhSWZVZzloU2VHaFZlWWVwYUNlMmg1ZXJoY2R6ZFJjc2RaY3hjWWdTY1RkSGZWZUtkRWJGZUpoRWZDZzNjQmNhZlFnbWc5ZGlnWmhoZ1pkcmFJYmhjd2g4YlJiQWJNZnlnTGVsaE1lVmJPYnloQWg2Z1RiR2FnZmdiSmNnZU1lTGRGYjNidGJCZUllUWNNaEZhTmN5Y1FiUGdKY0VkcGhuYmVjQmFSZHhiUmFoaE5iNGZVYzBoOWFrYmFnbGFNZVpkRWYzZkFlTGFXY1ZlWmhVZE5mUWJoZytoUWNTZmdoZmVLaGpob2FmZFhoVGM1ZFRkSGFVZ1VmUWRWY2lhOWFFY2RhbmZOaHZmUmNtY2NoV2FFY2toeGIxZ1NjaGRCZlNiUmVBZ3Rid2FXZ2thSmV2YU1jQ2FNZzlnUWJTZkFlQWJjYXdnUmdlZlZobmJ0YkpjRmFVZDVkcGdkZkJmaGJ3ZFFhWGVSZVJnU2RrZzVkMWFFY1hjTmNNY0RkSGhSZGFmVmNuZFFkUGZhYzFhSWZVZGNnVWFZYlRlZWFGYk5mUGVaY0dhb2dPZUVnQmc5Y2FiQ2cxYmxlV2dFY25ncGdIZVplRWFGaHViU2VtZ1JlNWVTZ3hjUmZsZkRheGcxZVFhQmRFZ3RiMGFPYm5mZ2UxYklnQWNsZHZkSGh4ZUpkS2RjZzJjQWVRZlVoa2FRYUxnY2VGaHBoQ2RiaDJlSmhtZGFiUmFSZnlhVGVuYU1kUWdUY2dhc2ZFYUJoMWFZZmFmSWNEY3RoV2JjZmthRmVwaFRiRWNvaGFjTGRFY0ViMmJBYXhiZGM0aEpmRmRnZm5iV2VpaGtiVGJSYWlkTWFIZ1NhbmVoZ1ZoU2RVaDVncWVVZHhla2FUYWNlQWV0YVphVmZoZkpoNmFSYTJkUmJCZmJja2ZwY2tnYWJVZnNhSmViYUFoQWRkaEdmUmZjZ0ZnSWZTZHdnM2ZJYlRjMGRIY1BjaGY0ZkRkUWZIaFZoYmdHZVZmd2FHYVVhaWdRZmZmTGdpZm9lc2dJZFRoMWJjaFdhRWc1Z3pjRWFFYnhmTmdVZlVia2NWYlRobWdsZDBmR2ZIY2xjYWRYZWxhRmdLYVRnbmVVYVJmY2IwaHhmUmNlZUhlQWFMYmRlRWh3ZHFhQmdsY2NlNWFSZGhkc2RxaFdha2Q4Zy9lUWdGYk1hWmFFaDNkQWVMYVdjVmZZYlNlZWNrZWRna2dRZVRjd2hQZE1kQ2F3ZVpnV2VuYkVhY2VEYkZlWWR6ZlZkbmVSYnVnZGNuaE5idmVSZW1nY2JXZUVnaGVGaGZkU2ZoZkJkU2hSZUFndGZ3Zldka2NJZnljU2RHYlphcGJGYkhiSmZPZmNheGJCZk1oQ2F3ZFFlSGRWYWhnb2dnZE9lMWZaYndjRGJuZHhiWWJTYmhkVmRmaEVjWGNOYU1oVWNYZmhid2NWZm5lUWZQYmFkd2RCZFJiSmhSaE5iQmdOY2xkTWFCY2FmaGY0ZXFnYWdYYVlmVWVkY0RmZ2drZVllQmJzYitkR2V6ZUljYmNPYWhoUWJXaE9oV2dCZnhlQWVoYTFkZmNDZUVhSmNqY2VkbWc1aGdkZWdWZ0pkd2hGYmdnaGFNZFphRmZvZUhhUWJWZ01kZmdZaFVlSmRRZmZoSGFsZE1jYWJSZVJieWVUYm5nTWZRaFRmRWEwZ01kWWh4ZFZoT2JhYlhnUWJZZ2NkRWdGZzBoRmN4ZThhQWJOZGtjVWM2Y0FjeGU5ZDRnT2NGZTRlZ2dBZzJoc2NBZ0hnWGFFZmRjT2ZYZWhkVGJUZjJmUmFxZFVheGRrY1RnY2RBZ3NmUWRFZkJhSmd5aENjR2d4YUloYmNsZFpka2ZLZTBoSWNVYUpjVmdWZFBhQWdrYTVkV2RPZGljc2VoYmNheGQwY0hiS2ZWZEZjWGNLZlNiY2RZY1hkd2RCYU1lQ2NSZGthVWVGYkNjNGV1YkxmeWQwZFVoSmJoYWNmamNWYlFoaGZOZEViQmR0ZEhjRGN6Y0JlMGJWYkRjVWNQY01nd2JVY0NkVGJIYndhS2NXZFVneGJSZWVnSGJCaFdiZGJBaDllcmZVaGhnUWhqaEFmMGJjZXRhQWRRY0Zia2FZZG5ha2JaZUVkM2RBYkxkV2dWZ1lnU2VlYWthZGJrZFFlV2c0YUVkYWNnZzBheWdaaEJjUmg1aFliaWJ4YXJoSmdCZFVhWGdDY1FhQWNhZU5iaGdkZjVkWWFEZWhlZmVTaGhnQmdTZlJkQWF0ZHdhV2hrZUpjdmRZZ21oWmZwY0ZjSGhKY1JoY2V4ZGhlRWVHYlZlRmJVZEZnUWdBYnNjSWZ4ZmdkRmhDaERnb2FGZFVoaWQ4Ym5iUWN6ZUlnVmZXZlNhcGE1ZVhmM2hnZ1BhWWN3YVlkYWZEZmpibGFEY0tlaGZ3YWJkS2R4ZlVhc2JHZVFhNWN3aFJoVmNjZEdlUWhEYVVnVGhLZHhiVWIzZ0dnaWRGZHdnUWFqZjVkeGFIZVJjMWZOZUdlVmVaZTBiYmFuZFpiemRiZzBoWmduZkZlZ2RoaE1jZmJRY1JjRmJIZGdmZ2VMZmJiVWVkZmZoYmZ6YVpjbWhiZXhmSmd5ZVJkaWhjYVFjVWVVZjBjZmFEYkVnSmVPYkpiM2J4Z0toZWRVY2hoNGZVaFVlSWNhYWVmMWgwYTJoQWVoZVloc2FPY0ZkWmVwYkRlemVsYWJhSGJYZzFkc2RFYjNlaGhUYVRoMmhSY3FkVWh4ZWtjVGFjZUFidGRaZEFoamNoZjZnUmcyZFJlQmRiYWthcGdrZmVnVWhzZlVlZWFBYVlmM2ZUYVJobGdXZGRjR2E1ZDJlY2gyZDhnYmZUYVJlWWVTZ1RiSGNWYktoRWVGZUpnRWhUZlNoVWZVaEFnVGZzZ3JoS2NTY2NnVWhQZkVnWWduZ0hnRWV3YWZlWGJVZ2xlY2dSaDJia2R2Y01ibmVCZ0JlZGRGZkZjS2hUaG5nVWNSZ2NmMGJ3ZFlmUGZuYkJiZWRkYVFnY2hsZlhoR2RBYUlmTmFuY1llY2JMZ0NjNGRXZUdnRGNKYWdhYmdBYU5oK2ZLYVNoWmI5aENhRGhOYmtlSGZUY0pnS2FNYkRhRWJDZVJiM2FGaFVjVWR4YzVnTmRGZXpjb2V0Z01kemN3ZXBmUmNpYWthZmNHZjJkWmcxYVNhaGRCZlNiUmZBYXRod2JXZGtjSmJ2Z1libWdZZjdnVWhTYVljYmRJYlZnNWRNY0FleGNRZmVlRmVRZ0JhaGdJY0JiUmN3YUVkM2VoYlJmQWcwZ2RjdWRPaDNmTmJNaFVmWGhoZXdhVmhuZlFmUGdhYTFhSmFkYk5jMGJZZmJhZWZoZDBoYWZLZlNnZ2VXZVNoeGVGZ3djRmFrYVJlV2NSYmlmTWVYaEllUWI0YW9kU2JqZEJld2RTYzBnOWZiYkhmUmMxZk5lR2NWY1phMGhiZ25oWmJ6Z2JlMGJaYm5iWGIxZVJiTWhmY1VmaGNEY0JoaGZaYkNmUGNoZTFlQWZiYzNnOWQ3Z2FiVWVBY3JnSGVqZVpiZmVDYmtnMGJEZVFkRGQ5YU9nYWFYaFFnWWhjaEVhRmYwYlVjVWJwZU9mZGNSYkZjemVUY0FmVWF3Z0lnaGJrZ2plRGV5YVVkWGNRYTNmRWJqZVFmU2FvY2NjSGhXaHhkQWNVaHhja2hUYWNnQWh0YVpoVmZoaEphNmRSaDJjUmVCZWJoa2hwZWtmZWJVZmxoOWhOYnhjMWNZY0FjMWhvY1pkTWRDaGNnNGNOZ0dmOGhQZk5oQmNaaEJmSGVEZ0FkSmhXZFJoUWVOZFRjamRSZWFhRmdpZ2NobmVLZ0djbGZBZk9nZ2J0ZHpnVmVnZlVoZmVBZWhjMGZWYkRmemJzaHpmVGVUZTBiRWdPY2dlVmRLaEFkeWJCZUNmSmUwY3dmVGFQY1hlQWVYZWRlRmN3YS9hQWVGaDBkL2NBZ1JhRmRTZlViMGU5aGtjYWFsZU1mWmFFZTNjQWhMY1djVmZZZlNnZWhraGRldGVXY2tlUmhLYlphSGZsaExkRmNIYUVlZGNIYlVoMGFaYlZobmdRYjhoTWN5Z2NoNmNGZENha2JXaFZnRWRRZ2hiQWVsYWtmQmdTZ0Flc2JrYVVlMWhsZkZkWWdtY1pmcGJGZkhjSmFPZ2NheGdCYk1oVGdRZXhjamNGYlVhNWZwaGRoQmZoZndnUWRYY1JoUmhTZWhhd2N3Z1JlU2RZY2VjSGEzZ2dmamVYZ2ljQmJIaElmZ2RFZllnY2JSY0lkZmhlYkFnRmJEZlpoQ2ROaGFjQWZqYWxhd2ZDYzFmbGZXYUVkbmJwZEhkWmZCYXhhRWJTZm1nUmc1ZlNkeGRSaHhoSGVSZDBmTGFUZkJlZ2EzaE9hamI4ZjhiSWFVYlloMGJIY2tmWmFBZ2RkUmVnZWNiVWJnZzBnSGRjYUJhOWVMaGJhemZsZE1iYWJSZVJleWZUZW5lTWFRZlRhRWcxZVJoU2FWZXdnSWRhZ1hid2VhYlBkaGJRYTVhRWN3YjhjY2dkZXhiRmJ1ZVVoVmVFZnNoS2NRY1lmeGhRY0NiMWZTYVJlbmhoZXNlRWUzYmhkVGRUZjJnUmdxZlVheGZrZ1RkY2hBZHRkWmNBZWxlb2dvZENmRGdOZUJiSWVBaDhmemJlZVRkOWVOYUliVmNoZDRkSGQwaHNkWmFKYm1mWmJ4ZGNlVGJrZEhiS2MwZE5nWGZUZW5iVWFMZFFiaGhVY1JjUmNqYVVoVWZGYm1hOGJ2YU1oemZwYkFlY2JnZ0FlOGNSaEVmd2RQYkZjRWNsYlVjVGVpZ2NnaGdWaFRoSWNFZkpobGRaYkRoVmRWZThoUmJjYjBjeGJSZ2VjSGVCZFdkZGFBZDlkcmhBZEZlRWdsZkVoMGhFYjJmVWYwYzBmeGFKYUJoZGdjYVZkVGZsY0ZnSGJCZklnUWJlY2tnWmg1aFFoVGZvYlRiTmdEZHdnRWZVYW5oRmE4Y1RkeGY5YVlnRGF4Y1ljN2NNYURiVWZxZkZhR2RjYlFjRmVFY3dobmZTY2xna2VjZEZjMWI4aHhlRmRBZEVicWJMY1NoQmJwaGRlU2dBZGNkTWhrZWtldWhHYUJoY2VQZlVjQmF4YURnZGFCZmhod2JRZlhiUmFSZVNna2Q1ZTFhRWhYYU5iTWVUZG5hZ2FnYlhoaWRBZ0RjYWN3aEFiWWdjY1FhOGRmZmVlQmdaYUdnVGRtaHBkVGdHZVJkTmJ3ZENmMWJsZVdmRWduZ3BnSGVaaEZodGd1YVNnRGJjZnRnR2dWYzBiL2RXZmhmOWVOY0JlRWd0YjBnT2hpaDhnamdLZ2dma2FoZUZha2NCY21kZGFVZ29jUWdVZGtmUWJMYmNiRmZwZENoYmUyZkpmbWJkYWhjUWIrZlJkaWVjY2NmVGhCZTljZGdTZVZleGdIaFFhM2ZRaFloY2dFZkZlMGhVY1VlcGVPZGRnUmZGZHplVGhFaHRlNGJQYlZlNGhnYkFjMmJzZ0FlSGZXZHBkc2NFZzNjaGdUZFRnMmVSZXFoVWF4ZGxiT2ZXaGdidGdaZ1ZiaGdKYTZnUmYyZFJiQmZLZEJkOGdxZE9haGM5Z2RjUGFsZU1oZGFEYUJmRWRDYmZmV2I0ZHRlV2NXZzljR2FaYXhjWWRTZ1RmSGdWaEtjRWNGZ0liTmVUZVhiQmVTZVFoQ2NFYzNiS2d5aHRkUmVJaEVmeGh6YkVoVmRGZU5jQmJSZUJjRmRDZHloWWJ5Z0dkQ2NSZ0liWGdsZUZlS2VUZW5lVWFSZWNhMGV4YVJhZWRIY0JiV2FkZUZlc2hqZUFiRmVzaG1kUmJsZzBjOWVCZkVoOGhRYU1kd2ZOZWNiZGdpZkpnWmVGY2doUWFhY2ZiVWVVYTNnQ2JEY1FnUGFaYm5ha2RLaFJhamFaZUlhVWFBYmhjWGhBZG5hUWZqZEljeWNBYTdkUmRpZFZjVGFFY2dhMWYxZkJkRWdVY2ZmQmVraDRhaWNYZFVodGEwYVNoR2ZaY3BiRmFIaEphT2JjZ3hnQmVNY1RkVmNFZEFoVWUwZjVmaGVaZUJoaGR1ZVFkU2dCZllnWWFFYzVnMWVFYlhoTmdNZ1VjWGdoY3dlVmJuYVFkUGRhY3dhWmhjYUljd2FsY0VmZWdCYjBjS2NNYjJhb2NoZldhRmgwYjNoVGRqZXdnRWJRY0RoVWRWYWJiRWZaY3NnR2NTYzBjamdEZ2hnWmF4YlhjRWU4aEtjVGJCZHNieGhJZUNlSmR6ZUloaGJNZTBlUWdoaEloQ2dPZ2hhNGJRYUVlQWNFY0xmUGVoaDhkRmVMY2phWWF2YlBkMWRGZDFlUmEyYmdhNmFUZ0VkMWFSY1NoUmhWZE9jYWhYY1JkRmRXYmtoRmQwZVVkVWFwYU9lZGRSYkZhemFDYmdmUWcyZU1nd2FJZzloUWZDaFZlU2JRY1hja2RTYUhlM2FnYUJjUWYyZlFnamhYYnhobGZXYWVmUWZzY0NoZmRCY0plNmNSZjJnUmFCaGJla2VwY2tmZWhVZXRhR2ROZUVjbGdJaEhiMWJkYldiZmNFZ1JoMmFjZDJjOWRHZVpleGdZY1NnVGdIZlZjS2dFYkZnSWhGZkFneWNKZlRlVGRrZFZmaWNaYm1ma2hVaGNma2Y1ZnpnRWdFZHhjTmVVY1Vka2ZGYlRkbmNkZnBjR2JDZkplcmFkYUZhRmNLZlRmbmRVZFJkY2YwZXhiUmNlZEhiQmhXYWRlQWU5YzBkVWNsZXhhNWdFYmhhOWY0YkFkVWFaZk9nYWVsZE1iWmVFZzNhQWFMZVdoVmRZZ1NnZWVrZmRoa2ZRZVdiNWRRZ1plQ2g4ZEVkWGJUYlViZGhEZ1VmMGVZZ1NjMmZsZnVkUGgxYmxmdmVSaG1mY2dXYkVia2d4ZDFkU2NoZEJmU2ZSY0FidGd3ZFdmbGMxYnZoWWJEZ1VoOWNSYmphc2VBYU5oQmFKYk1oVWJFZXhkSmRRYVJkY2I1Y01oVmJjZTJlUWZUZEZlN2VTYmtnNWUxYUVjWGZOZ01jVWJYZGhmd2hWYW5mUWNQZmFoMWJJY1VmY2RWYmtjVGFNaEZjc2ZiY2FiR2dvYkJoRWdCZzBmMmZRaGhmVWJhZ0dnamhOZUxnWmhBZ1JibmJZZEdoUmY1ZFNheGdSZ3hkSGdSZjFmTmJHaFZoWmEwZ2JjbmNaYnpoYmUwZlphOWVGZWxmcGJFZ0liVWNZZlFhQWVFYzBnRmJOZ2hnTWZPZ0lnMmZvYnZjWWREYTVleWRUZG5hTWNRZVRiRWYxZlJnU2ZSZ1ZlT2NhZFhnUWJZaGNlRmN0aDBhR2dVZkljYWFlZVJhRWRoY1JoWGR0YTRhY2hGZlplMGFEZTJkdGFTYUZmSGJGaEdoR2htZ05kNWVUaDJlUmFxZVVjeGFrY1RjY2NBYnNiRWJmYUJjSmg2aFJkMmRSY0JmYmNrYXBna2FQZXhlNWdhZk1ka2RsYVVoQWNsZGRoV2NNaG1mWWFpZGZhMmU4YlVkYmRoYVpkSmJaaG5jVmdLZUViRmhKZEVoQ2EzY0JkYWZRaG1jOGRyaEliR2FrYmNiZWZnZzlkN2VRZ2tlVmRCYlViVWRGZ0JkVGJuYVJmMGNVZkhmZ2RWZmVoRmNGY2FjVGRtZXNhUmZJaFVneGNPY2ViR2ZCYVdoYmZnYTliN2hVaGtiaGZ4aEhleGJzZnFlV2FraFpidGNaZGxjTWZZYlhoWGU1Zy9hSWFDZVpnM2hIaGpjZ2hGYU1heGJ3YnJlSGFRZllhNGdZZFFmRmd0ZWNjamc5YnRoWGgzZzFmRWZkYW5kTmN2Y1JhbWZjZ1dlRWJrZXhoMWRTZGhiQmZTZUFna2RRYWljV2NrZ29jNWJJZHplUmNwYlhmWGRKY1RmY2V3ZkJjWGNUZ1FlTmJKaENiMGY0Z2dmYmZ4ZmhkN2hTZmpmMWNZYVNoaGhvZ09kV2JBYzVnTWVUZkhnaGJnZlRmVmU0ZlBkYWUxYklmVWdjZlVoWWZUZ2VlRmROYVBjTmZpZDhnSGVUZkVlRWMrY0Nid2QxY05hT2ZIZ3BiSGNaYUVlRmN1Y1NibWJSYjVhRmFqYzVneGNIZ1JnMWhOYkdoVmdaZzBkYmZqZEFkbWdJYlFoVWJ6Z1hkMWYwZENmZGFRZ1liWWZCZWtkZ2FMaEllbGVaaENjSmNtYnRmbWNNZGpoNWV5ZlRmbmRNYlFiVGRFZDFlUmFTYVJoVmJPZkljRGRJZFlkZWFHZHRhMGhVaFVjcGJPZ2RjUmRGYXphVGRGYUZhNGdjZkZoWmc4YUJnMmJrZUJnUWJDYU1iUGJYYVRmOWhSY1RiMmNWYzNnVWUwaDFoS2dJY0VnNGRXZ0VhQmVJZXpjUmZ6ZmdnZGRiYmtjaGRtZ2VlVmRZaEphYmZCYzFjVWdSYUJkbGZRZWNibWE1ZytkT2ZtYjlhYmdaZ3hoUmRIZkdkRGdOZVNiRWNsZHRhSWFJaFhlQmhhaFFhbWc5YWllWmZtZWtmVWdjYmthNWd6aEVhRWYwYkRoWGJ3Y0JiR2VLY3lnY2IzZ1ZjemFRZElnT2hoZlpnQ2hCaDNjd2dZZ1dkVWd4Y1JhZWhIZEJlV2JkY0FhOWdyYVVjaGZSaDRlYmVCaE5kNGJVZzBoOWdrYmFhbGhNY1phRWMzaEFmTGVXYVFnSmFhZEtiQWVnZXplUWNTaEFnUGFNZjNla2cvYVRmU2hGYVllZWdCZTljTGhHZVNlWmZtZGNjWGVFY3FmQ2ZDYVJoWmVWYWdmVWE3Z0RhUmdKZlNoQ2RWaDRjamVEZWtnSWd0ZEphMmhZZm9nRmZDZFFlUGZQYjFha2dJZ1RiUWdJYWRmUmN3YWNobmFNZ3hnZ2gxY0RmemRjYWVoRGdnaGNhN2NWZ25jUmJGYVNmbGVKYXdiVmhuaFFkUGVhYzFmSWJVaGNmVWZZY1RmTGJoaEliZGZaaENmOWZUY0JhQmFOZGdiQ2J3YVZkV2ZWYm5iSWRWZGFlRWRFaG5hUWQzYjloVGdTZHhoUmR4YkhiUmMxZU5hR2NWZ1plMGZiYmlkSmR6Y2Nma2VZYXZoSGVrZlpoQWJkYVFoOGdaZVNlV2M0ZExiY2RGZXBkQ2ZiZzJiSmJtZ2FoUmhSZXliR2NEZUplQ2FUY0FjSmRSZVZhQmdVZmFlWmZ5Yk5iS2dPZ1JnVWJ4Y1doUmFoZ0NnZGhWaGhnNmVWYTNkdGU0ZmNkRmFaYjBjRGMyZXRjU2hGZUhiRmJHZlFiVGgwZ0hjR2RqZllja2JVZjFnWWhUaGNhUmZaZUVlVmdsZ2RlNmZRZ1dnSmZCY1pnaGQ1YWtkWmNFZ3RmQWVmZzBhNWZSZUJoRmVvZVRoZmFIZDVhNmFjZHlkQmFQZ2JmaGdvaFNiR2RHZDVlZ2NFZ0ZmSmZFYUNoM2RCYWFhUWVtZzhmL2VUaEdia2VVZmNma2E1ZXpiRWRFZXhnTmRGZnhjeGFiZ0RhVGYwZzljVmZ6YzVhQmVOaDFoa2FlaFFnbmVWaERoZWhrYndmS2JVZW5lQmZXaGRhQWU5YXJoVWhoZlJieGRSY2hkTWd1ZkVhaGIxZmtoSWUxZU1nRWVFY3liSWRGaEZjUmROYmNjUGdSYk1lc2dRYlhlSmJLY2RnSGNsZlVkRmdHZkVhZGVCaDBiMGJKZlZhaWNoZXVkTGUzYXNoOWhTZENjdGdUZlhlQWZzYmhjQWRoZGxmSmdiYWdodGh3Yldja2dKYXZjWWNtY1pmcGVGY0hmSWZhaGNmd2YxZU1iQmhWZ2tkZGRHYlVoNGJnY2ZnUWROZGFmUWZYZFJhUmFTZGtnNWIxZUVhWGFOZk1mVWdUYjRlL2VCYUhlUWJIZ1BlUmJOaEdkY2FRZ01hVGJaZlZiTmRmaGZhMmhvZ2FoR2dRZjFkd2hUZWtkSmRXZFZlM2dwaE1kZWRVaEZlL2RRZDJkUWd0YU1nRmhFZ01lSGVRaEJmTmhDYjBnTmRoYWJhbmdCYXpjUGJUYjBmaWZhZ3dnbGRtZ2RhVWFvZlFoVWFrZ1FlTGJjZEZlcGZDZmJkemZBZ2piUGZVZ0VhZ2dBZ0hkTmJFaFZkMmFkYlJnU2JSY1ZmT2dhY1hoUWFZaGNjQmd4YmVkVWZVZXBhT2ZkYlJmRmF6YVRkRmNFZCtoSmdSaGdlM2ZXZXlmSWNkZFdhbmhFZ1dmR2h5YXhmZmNUYXpkWmFtZ1VoMWdBYWZmY2NFYzVkUWRWZ2tmbGRRY1JoMmZSZEJkYmhrYXBha2JlZlVnc2NVZmNmVmdSaGJiVGRSZEZmZWJKYW1hQWYwZ0thamdzYURlQ2IxZk5kY2JDZnloRWJDZ0hnRmdKZlVkQ2MyYjVlYWJDZjJhOGIrY09obWJsZEdmZmNBaHdocWRSYkFla2NoaEZlQWFkZ1NhR2NpZkZkMGZCaEhlQWRJY2ZnVmRoYWdkVGJuZFVjUmhjYTBkeGdSaGVlSGJCYldjZGRBZjlkcmVCZ2xjd2FqZ0NlVWVSZTRkSGRRYm9oemVhYWlmRmRZZVhmVGZkY09jUGVBZ1JoQWNOZ1JiVmJzaFFnMmhrZUZhSWZqYThmWWRVZFNoVWdhZkhjUWVSYUtmVmhqZ3NnN2JJaG5hTWNnYkFiR2FkZ1VkWGFSZGthN2dEYmtlTmZRYVRiUmdCYWFiV2drYkpldmJZY21mWmFwZkZnSGFKYk9hY2IxZWtnS2JUaFZma2FiZUdod2N3YXdmSWhGYjBkY2NCZURlb2dXZkhnZ2NaYzFnRGZYYU1jRmdVZlhoTmV3Y1hoamRFZ1BmTmJ3YTRlVWhZZlVhOGRhZVVlbGJOYVBnWmdHY3BkVGFHZ1JoTmJ3aENnMWdsZFdoRWFpZjRnUGdOZGdmNGI1aFNlaWNvYjhmSGZCZ1FoRGVYZEZnTWZLZVhlRGdNZm1jUGREY2tmaGJaZTBlUmhnZVdnbGZjZUNkTWZoYjVhWWVWZVVnUmFDY0lmMWdvZk5iT2RqZFpobWVKZmxiSmh5YkRlRGh4YkZiQWhnZGtiQ2JTaHhkeGJWZ1FnM2ZRZVlnY2FFYUZiMGJVaFVkcGJPYmRhUmZFZ2hmQ2hRZ1VjdGZJZ2hnaGgwZkJhMGJGZ1NhRmdIaEZoR2JFZjNoaGJUZVRkMmNSZHFmVWZ4Z2tmYmZJZ2dkdGJFYmZlQmVKYTZoUmcyZ1JjQmFiZmtocGhrZ2ViVWdzYlVkY2JSZzBiZGFHYjFkWWJmZ01oR2Q1Z21jY2YzZUphYmZlZmhmWmViYlRnSGZOYk1mRWVBYVFkTGJRaGpkUmVhY1VobWU5Zy9mZWQzZ1FiVWFOYzJoUmR6Y0VoRWJ4ZE5oVWNVYWtiVmJUY21lbGMwZEdkSGZCZkJmZGdGYUZlS2JVYVhhVmdmZU5kaGF0Y1JmRGZUZmthWWVJZEJkY2NLaEFmRWRZZndnSGR4ZnNncWRXYm1iVmNrZGFmbGVNZlpoRWczYUFkTGFXYlZjWWNTYmVma2hkaGtkUWRXYTVmS2JmZ25ha2VkZFdjemZoaFpjSGNWZjBnWmZTZjJjbGF6ZWRhamVaYkZlUmNtZWNnV2ZFYmtkeGQxaFNlaGNCaFNkUmRBZnRhd2NXZmthSmN2ZFlibmhsZHBlV2dqYWNiWmdjYzJlVWFGZ0Fkd2dWZFJiZGJCZXdoN2JOZlVjRmU0Z0VhM2FoZlJlQWEwYmRlZmJFY1hmTmJNYVVlWGNoYXdmVmVuaFFlUGVhZTFmSWdVZWNkVWNZYVRkZWFFZWxlUGJLYmloOGZFY0dlV2RZZDVnUmdRaDFhT2JjZHloZ2dWZ0phUmhoYm1oR2RHYWhiNWRBaGhnaGN4aFdoQmNSYUVkRmZYZnhkMGJiZ25oWmZ6YmJhMGNaZ25mRmZoZ0pkTWdkZ1VicGNlYVhkRGFCYXlnQWZEaDhjbWVFYkFmTWNVZUdmM2RVaExoTWJRZUJhbGJQZERlMGMrZk9oMmdGZmtjYWFYZVFjWWhjaEVkRmYwZFVmVWJwYU9kZGhSY0ZmemhUZUZjRmZuZGNkRmM1ZjhlV2cyZHRiUGFGZENlTmdQaEhkM2hoZWJiR2EyZm9iVmFMZEVibGVCZlBjMWg4ZVdjS2JXaDFmNmZXZW1hUWZQYVliQmJvaDJoTmZoYjlmYmVKZ1VmUmVOY0NlQmdCaGZmWGFtZzVlMmRjZjJlOWNHZlpheGFZZ1NhVGdIaFZlS2hFZ0ZoSmVFZEVmWGhCZVNkRmVtaDliL2JaYWlnb2ZjaEpka2VKZHplUWRraFZhRWJYZ1dhTWFWYlRobWZsYzBnR2hIZUJjQmVkYUZiRmJLZVRjbmFWY0ZiV2hVaHhhUmJlZ0hnQmRXYWRiQWg5ZXJhVWdoYlJkNGdYYlRkbGE0ZVViMGY5Z2tnYWhsYU1oWmdFZHlkMGNoYVdlVmVZZFNoZWVrZmRna2dRYVdnNGVNZE1oVGZjZ0lmUWVEaGhkU2RVYjBhMWdVZVhlaWhCY2lmZGNpZkZjbWhSZ2pnd2Q4YUVna2h4ZjFjU2ZoZEJhU2FSZUFmdGV3Z1dnZ2dzZXBlWWNtYTRkbmFHZ2pnc2ZkY0VjVWNVYktjQ2N4aFFlYmZIYlJmeGhnZ2ZoUmJnZnJjYWczZlJnUmRTYWtlNWQxaEVlWGVOZU1iVWdYZGhjd2NWZWlnSmhPYU9hVmFKZmRoY2RWYnNoVGdhZ0ZhTWZUZVpmRGhOYmJnU2R4YTBhOGhUaGhmY2NSY1JmamRKZ09jZmUyZnRndWZTZG1nUmQ1Z1NoeGZSZXhnSGdSZzFlTmdHZlZlWWFtZ0theWhJZW1iUGRRYmhhbmFIYWtoWmZNYWFmRWJwaFlhV2doY0FjSGdjZkJoTmdMZ1pnbWU1Z21nZWhSYlJjdmNVaDJiNGVRYkdnRWVNZGRnRGhGZnNkSmhQZ1Rld2VZZmJnMGdFYmdjVWdWYkJiT2JmYVVjTmQ5YkRmeGY0ZG9mS2RWaDRmZ2JBZjJidGhDYUdkSGZGZldoSGMzY2dlYWhSY21jaGdxZkJkeGNBY0ljV2ZnY3RhWmdWZmhnSmI2aFJhMmNSYUJnYmFrYm9kNWFVaDBkc2hVZ2NlUmcwYWRhVGVSZGxjV2ZkY0doNGcvZU5jV2Q5Yk9iTmRSZThlU2dGYzFiOWVLZUVmRmFKZUViQ2EzZEJkYWhRZW1kOWJpYVphbWhsZ2RiTmJFYTVhN2NPaGtleGhOaFVnVWRrZlZoVGFtZGxjMGJHZkhkQmRCZWRiRmVGYktiUmVuaGRkRWhQaFFlZ2NVZlBlamhrY1ljTWNVZHRlcGhVZmhiVmZzZlJla2NjYmhkQWZ3Zm9hcmdMYUZnTmU0YVFjU2JKYUtoQWFEZFJkSGFQZkFiRWJoZ0VoMmI1ZU1mWWVsYk5iTGJGYkhhRWFkYkhoVWIwY1pkVmRuaFJidWJkYW5mTmF2Y1JibWVjZVdjUWZFaEllM2RIaDFlWWhVYkFnVmdsZXdlRWd3YXdnOGZOaGljY2JuZVZjemhjY0JkTmdSaEFndGhIZndoTWdJZFRoQ2V3YThoTWdsZDRmMWNFYzNoMWVSY0ZiaGhKZGZnRWNYZE5iTWZVYlhnaGh3YVZobmRRZlBlYWcxZ0lnVWJjZVVjWWVSZU5kQmNZZEJmSWR6ZTRnYmFHZHhkTWQ1aFJhVmhrZUVhT2JIZHBkSGJaaEVhRmJ1Z1NibWRSYzVhU2V4ZVJleGVIZ1JkUmVuYkdnVmJaZTBkYmZuaFpmemFiYjBnWmVuZEZnaGhKYk1oZGhVYXBnQ2ZGZnhjQmdlZEllaGFSYUNlYmhTZXdkemNKZ0ZkWWYzaEhhSGZFZVFmVGdWZ0JnUmVIaFVnd2NlZ0xoRGV0YmVmY2dCYk5iNmRIZlFhOGVBZE1ha2RVZjdlVGZBYTBoa2djYkRjMWU4Z1hmV2JVZmVkVWJUYThnQmNSYXpiQmZhZVphV2hSZXFnVWZ4YmtmVGZjZEFidGFaZFZmaGhKYzZoUmEyZFJiQmhiYmtlcGI3aGVmUWRNZmNlSmhSZkVhZGdYY1JoQmc4Z2RoR2U1YjJoY2cyYjljR2JaZXhjWWJTZFRjSGRWaEtjRWFGYkphRWNDZDJocGVhZ0FhV2hjZTJkYWVtYWxnR2NlYzFhVmNaZEVhRWF4Zk5hVWdVYmtiVmdUYm1lbGEwaEdhSGFCY0JnUGVSZWRlS2JSZW5jZGh6YUpmZ2hvZ1hnUGNTaEplVWdkaEJlSmEyZ1RneGdRY2plU2VFYmNjaGZBYndhcGNrZGJiRmNVY1pnRmMzYVFlRGJDZTFkaGZXYU9ieGNNZGxiU2VHY2RlS2JOYWpmd2ZmY1FlU2NOZlRhSGZRZzRmUmdBZ25kaGV1YkplSGgwY3JoQmd6aE5oWGNHZTFoZGhmZlNiaGJCZFNkUmZBZ3Rnd2VXZWtoSmJ2ZVljamN0ZERmRmFIYkpkT2NjZnhjQmJNZFRnVmZGZUpjRmJSYW9iaGJKaGxnY2huZ1FhVGVvZ1VmSGNVZzRlQmdTZENnTWRKYk5jQ2VvaGlnR2VTZFlhSGhRY1ZhSWJVY2NoVWVZY1RlZWVGY05iUGFaZ0dhcGVUZUdoUmZFYVdnUWZnZ3NjRmJSZ25kb2ZHYU5lZ2FZZDdkQmV5ZkVjM2NIY3hhUWY4ZVNjRWY0ZlpkR2hSZFFoeGNiYWpoZGh6ZVBnQmFJZzFnWGYxZndhTGhlZVVkcGh5ZkJmd2FKZU5nTmNRYmhlT2RiY3dlTWIwY09jMWNVYXJiTGhDZ1piV2FDY2diZ2REYlJmUmNVZHZlT2V5ZVpkWmFLZVVkMWIwZ0hjaGhoZU9iTmFFYk1kaGVEY1FoaGcxY1BhQmU4Zi9jU2RtZXNoZGhWY2phc2hEYVViQ2h4ZmRnVGJVZzVmcWJVZnhma2VUaGNlQWh0YVpnVmdoZ0poNmZUYW5nOWdyZmJia2FwZWtlZWJVZXNlVWhjZlJjMWdBZFpmeGRsY1doZGZHYjVnMmJjYjJoOWFHZkllVWVOYmNiRGV5Z0VjRGJYY3hmeGNFZlVobmFnYU9jU2UyZjhhNWRUZ0dna2VVZGNia2M1ZXpnRWdFY3hjTmNVZFVlbGRjYUNhR2dsYjhhVGNIYkJnZmFhYVZoRWFGZVJkbmJ3YVljV2ZVaHhlUmFlYkhjQmVXZWRoQWQ5YXJmVWRoYlJkeGJSaGtmY2Z3ZEFnUWZBZHpkYWJoZjFkY2JSaEhhQmY1YkdnQmVoaFZjUGR5Z0lkMmVFYnljRWZZZ2JjRmJOaExlRmRIY0VjZGFIY1VlMGFaYlZlbmdSZXVkZGNuYU5ndmhSZG1hVmczY1JoaGNnZHdnQmIwZkFkR2FSaEZoOGgvY1dnZ2VNYWphTGdpZWthcWNWZ1NoWWdMZGNhM2hJZVpmQ2h4YWNkTWNSZjBnNGNsZE5mVWJvZzNjQmJDZlpiUmJIaGdhWWMwZ1hhM2VNYkJhRWFDZUFnNWZHZXljRmJDZ2Fnd2FGZ2RhS2V3Zk1iSmZlZEVhTWFYYlpibWJwaFlnTWZ4Y05md2FDZzFkbGZXZEVibmVwaEhjWmZFZEZidWhTYW1iUmQ1YVNoeGRRZytoRmhSY1JoRGNUYlJoa2FIZE9oaWFRYjZhSWNRaEZldmZCYXdhUmdGZ2RhVWFFZDZlVWdrZVFoTGRjYkZocGFDZmJmMmNKZG1iYWVSY1JoeWFUYW5lTWJRaFRiRWc5aFJjQ2gwY3dkYWVMZkNhY2RhZ1dka2VGZDBnVWZVZXBhT2hkZVJkRmd6ZFRiRmhGZzRhY2NGZTlldmdKYldldGFTY0ZmSGVGZUdiRWIzZGhmVGdUZjJjUWI0YUZma2MxZUdkSWFrY1ZlWmNSY2hoSWhtYlJmemhCZ2FmUmdFYnBla2NlYlVoc2VVZmNmUmMwYWRjRWFEY05jV2hkZEdhNWcyY2NkMmI5YkdiWmUxZUJmSGJBYWplWWVlZVdhUmcwZEtlQ2V3aDlnU2JGYm1nWmhpZ1BoVWJNY1VoY2NrYTViemJFZUVheGFOZlVnVWVrZFZkSGNDZHdoZ2hUaFNhSWJQYmRjRmNvYmVoVGFuYlFlTWRjZ3hlaGdSZWZobmVaZldhZmZGZXRncmFUYXhhUmJoZVRjeGI5ZjRoSGRVY0VmbGZKZmhhOWJXaFVjSGJnY0FiRGRWYjhoSmZVYkVoZGdrYlFjV2c1YktlWmRIaGxhTGFTYlZnc2VkZUhnVWcwaFpkVmhuYlJjdWZkZmplVWI2aENoQ2JSaENkV2N3Z01jN2RTY2xhUmJhZUViQWdkZXdoQ2RFZ3RhdmVPZlVoeGRwaEZhSGZKY09jY2F4YkJmTWVUaFZoRmFKZ1hoQWZoYXBlZmNGZ1plK2FDZENiY2J6aEhjd2RnZXpoVmNDYUZkRWdCYVhnRmI1Y1ZoaWdaZUtiUGV3ZmRoR2VQYzBkWmhIYmRmaGc4ZUthS2ZpYTBhSGdVYVFoaGRhZENjMWFsZldlRWZuaHBkSGhaZEVjRmF1ZlNiaWcwZy9nU2h4ZnhmYmRIYVJmMWdOZ0dkVmRaYzBhYmhuZVpiemdiYzBiWmRuZkZkRWFjYkNnTWRRZjlkV2VHaHdjcGhPYU5mRmdoZ0NiYmRuYzlkbWdQZ1VoMGZpY0Nhemd4Y1dhVGhDaHdlRGJHZDFiUWFYY0NneWNGYmVmTmZnYVFjbWFVZVVkeGhJZlhoeGFGYnpiVGdGZEZkNGVjZUZnWmYwaERjMmF0ZFNmRmNIYU1nQWNSZ2phWWZRZ0dleWgwZWxnSGRSZnNoVGZiZVJnWmdaaEFia2RzZ3FiQWJpY3NjSGNiZmloc2QyZEtid2VwY05hRWgwZWhjYmhDZzFld2NFZ2VjaWFjaGxmQmJTYVljRGZNaEJnWWVVYVNobGg5aEtlRWJGaEpiRWFDZTNnQmFhYVFhbWI5Y2lmWmdtY2toY2NFY3hld2NoYVVmUmNVZ3ZlQmNBZTlhVGhDZnpmdGQ2Y1ViU2JNZDNlUGFSYVFoZGJSYmllRWZZZWNleGRBZ05oZWFDaFJiV2ZQZFViRWc0aEJmbGFVZy9nQmZWZlliM2FGYVVnOGFGYU9nQWZGZFlmU2FoYUpjZWVIY3hlQmJYZ0tiRWE1ZU9kUWdXaDViS2JaY0hibGFMZkZmSGFFYWRiSGRVZFFmemNWZm5jUmR1Y2RmbmhOYXZoUmRtZ2NjV2RFZGtoeGUxY0doRmZVZkdkRWdWYmthK2dXaGhjWmVoZkljRGQ4ZTloVWNSZTRkTGZQYlZoY2FZZ0JkVWdwY2piRmZVZjVocGRkY0JiaGZ3YVFoWGZSZ1JhU2JrZHdlbWFSZFNjRWdGY0hjemY5YXlnVmNuYlVkU2ZhZndhWmdOY0llUWZOY2NoUGFsY01lYmVaZUdkeGhWYUdlUmdzZmtkQ2YwZ1JkV2hFaEhlaGZIY2JlMGRFZzZhUWIzZjllVGNTZHhnUmh4ZEhoUmExZE5kR2FWZVpjMGdiZGlkQWh5Z1BiVWFZaHVhRmVnZzlhTWZJYVVmUmdjZ0Zjd2ZwZU1oSmNCYkpoWmNSZFdnSmVtYmFlUmJSZXlnVGFuZ01lUWhUaEViMGdZYURieGZWZUdiZWRYZ1FnRmNiaFZleGcwYkdkRWJOaE9mSmcxYlFnbmNHZlFkTWIyZWNiRWVaaHZnSmJXZ3RnU2RGZkhnRmZHYkVoM2VoZFRmVGIyY1Foc2dIZEVmc2hUZGVjRmIwZlljQmNCZklhL2FSZDNmbGdCYmJoMWN0Zi9iZWZWZUFjVWRlYURmY2VkZ1RkUmhsYldiZGNHYzVoMmFjYTJiOWhHaFpoeGJaZkJiR2Z6ZHdkZWhVZXhlcGRFaEFneWdKYVRlUWJqZFJnSWJaaG1ia2NVZmNha2g1ZHpnRWNFaHhlTmNVZFVma2dWaFRkbWVrYjNoV2hTZE1hRWNkY0ZiTWZMY0hhVGFaZFlkT2VrYjVlTGFVZG5oQmhXYWRoQWQ5Z3JlVWVoZ1JneGRSZGhkTmE0ZVViMGM5YmtmS2VSY0piS2dWaG5jQWhKZkZiUmhkYkdjTWF3YWxoMWNRaDNiUmFnZFpiSGFsYUxiRmNIZUVhZGVIZlVnMGdaY1ZhbmZSZnVkZGVuYU1hc2dCY3pmUmVUZkVoa2Q0YjNlQWgxZTRlVGJGaGxiSmh5YlFhR2VoZnZjWWFtZVpicGZGZkhmSmhPYmNheGZCZU1hVGFWaEZmSmdGZFVlNWNwZkpobGEwYWtmRmZDYVljZmFTZWdhZGR1ZU9mM2dOYk1oVWZYYWhld2ZWZ25iUWFQYWFoMWFJZVVoY2RVaFlmVGJPYXhhSWZjY0lnV2VwYlJhVGhFZWNmMmRFaDFndGJNY09mSGJwY0hnWmFFZkZkdWhTaG1hUmE1YlNleGRSYnhoSGVSZTFmTmhXaGhjY2ZuZ0thM2FaZXhoT2NoYUljaGhHZXdicGZPY2JlMmRBaFFlVWRrZVFjTGVjaEZncGRDZ2JiMmZKZG1hYWJSY1JjeWVUYWpnQmhSY0hod2RoaFJkSGgxaG9jSGdMaFhlUWNJZGFkbWd0YTBhVWFVZHBnT2FkaFJkRmJ6ZVRiRmNGZjRkY2hGYVpiMGNEZzJhdGdTZVJiamNRYlNhUmVpZm9oZGVUaHdieGFpYUJleGFBZWRlUGhFZDRmWGJFaFVmWWZ5YVhlRWE1ZkJhYmVrZXBia2NlZFVoc2hVYmNkUmMwZmRnVGFSYmxoV2JkYkNkMGYzZUllQ2ZwZ0dkWmZVZE5lUmFIaDJoZGZJYkNnbmdoaEViQ2UzZUJiYWFRZ21nOWZpYlpmbWJrZFVjY2RrYjVjemZFZ0FnOGVNZ0FjZ2V3Y1ZhVGdEZHdiM2hTYjNkMWJUZGRka2R0ZWdkVGFuYlVlUmRjYzBneGJSYmViSGhCZFdkZGFBZDlicmRVZmhiUWZ5Z0JnMGNBZzlnVWYwZjBjeGFQaGhkVWRJZkJkVGN4ZU9mV2QwZHdnNGVlZWtnZGhraFFlV2M1ZktjWmJIZWxjTGJGYUhlRWRkY0hkVWMxYWFoRmZ5aGNncmdkaG5nRWE2YUVmaWRFZGJoQWUxY29nNWhEZHhoSmdJZGJiZ2N0ZHdkV2hraEpndmFZZ21oWmZwZEZjSGdKZk9nY2J4ZkJkTWRUYVZlRWhiY1VnQmNvYjhmSmVsZFpld2JVZzNjUmZiZVNhZ2JkZXVjT2czY05mTWhVYVhkaGJ3aFZlbmVRZlBhYWQxaElmVWdjYlVkWWFUZU9keGRJZWNnSWVXZXBkUmZVY1ZjWWVvYUNlVWJOYThiRWNuZXBiSGNaZ0VmRmd1ZVNibWhSaDVlU2h4YlJjeGhIZlJkMWROY0dkUWZRZnhhT2ZpZk1kaGVJYVVjWWh1YkZlZ2R4Z1NlYWQwaG9nQmNTY1diNGZMYmNmRmhwZENkYmgyZkphbWRhZ1JoUmF5Z1RibmNNZVFiVGVBZTRlUWJHYWxhQmVPZ2FoemJaZFpkSWd3aFJhaWhSZ1VjaGFVZ1hieGJGaHpkVGNGZEZhNGhjYUZjWmcwaERiMmd0aFNoRmVIZUZlR2dFZjNjZ2FCY0NiamhBZC9jQWdWZWNiVGVDYmdjTWVOY1hoeGF3YTJlQWhpZ29iR2VPaGdiSmEvYlVhMGdzYVVhY2dSaDBiZGRUZ1JibGFXZmRoR2c1ZTJnY2cyZzlhR2JJZjFoTmdVZkRoU2JBYUdjUmZFZGhkdWFDZTNoQmZhYlFlbWM5ZmlhWmJtY2tlVWRjYmtkNWN6YUVmRWR4ZE5kVWFRZUJiVGJUY21hRWJ4aEVlWGJBaFRhTWVRZVViZmdIY0Roc2RSY0doMGFRZEZnY2FYaDRkYWRNY1VhRWVzZ0JlbGh4YnFmYmhCYk5kNGVVaDBmOWFrZ2FhbGJNaFpjRWUzZEFlTGdXZlZhWWNTYmVla2hkZHNkRWYyZjVjWGhaZEhnRmNKaEZkbmhFYVdmSGhSZjhiUWdXZkNkQWRoZkdlamR3YzRoQWh6aFZjMWRVY3hhOGZ3YVFmaGZsZGJjU2dBYnRoNGNIYzBmSmR5ZFlobWZkZjVmSGhXZWxka2JjY3hlQmVNZVRnVmhGaEpnRmdVZjVmcGNkaEJoaGh3ZUhhRmc1Y1JoU2RrYTVjMWNFZlhjTmdNYVVmU2VWZmFkVmhuYlFiUGhhaDFhSWNVY2NkVWJaZFZlTGNSYzBkTWVNZkNjTWNjY1ZieGdNYjNiQWF3YTFkYWNFYmlkaGVMYVpmQWFoZW5nU2JqZTlmVGhTY3hnUmd4aEhhUmgxZU5lR2FWaFpiMGdiY2lhQWd5ZlBmVWVZYmlnRmhnZjllTWJkaEZlc2VMZGVnRWFRaExnY2ZGZXBjQ2ViaDJoSmRtZmFiUmVRZTdhQ2VIYU1jWWFSZEVhVWZIY0JnbGV3aEtkYWZXZFFiWWFiY1ZleGVwZFVnUmdoYU9nS2hVYzFhemZYaEZnRmZtYWNmQWRSZzlmRGgyYjFnVWVGZEhma2FVZUViMmFWYlRiWGMyZjFlbWFVYjBoc2FUY2JlZ2NzY05mSGdsYnNicGdTY1NmZ2VFaEllQWIwZ3dlTWNVaElnZGRjZVViOWFZZkdkVWF3ZkVlT2JtYzVhMGVjaFhhUmFzZ1pieGhZYlNiVGhIZ1ZhS2dFYUZoSmZFY0NlemFrYWNlUWhtZmRocWZiZGpoOWhiZ09od2FwZXphQWJFYXhoUWRUY0ZkUWhWZUJjMmFraG9jUmFIaEFlSWJkYkVlOWJLZkdmamYxZ1ljSWdFZ0lmZGJQZFRjNGdSYklnRWNkZGlnVWFoaEpjM2FSZmhic2F4aFVoMWdKZGtoUGVoZHRnUWhRYkhnNWNIYUhoQmNoZ1ZhTGVnZDljdGFUYldiNWJhZ1pkR2NkZFdkRmJEYmdjVWhGZkdoY2VaZlZkbmVSZXVnZGVuYU5ldmRSZG1mY2FXYkVja2Z3YW5jRGcwZ1FhSGJGZmtkVmZ3Z1dhRWZCZzBlU2RHZ1pocGNGYkhnSmhPaGNieGhCZU1kVGVWY0VlQWNVYjBiNWJoZ2ZoQmRBYzVjUWJXaHBiUGhWZkZnTmYxY0FlWGFwZUFhVWNYZUFkaWFWZm1ob2JSZ2RhVWY4ZFVkWWNVZzhlZmRlY0FiRmRQZWVnbmdkYVRlVWNCYXBjNWVDZHdoc2ZUZ1JmaWg4YlZoS2NrYkZlc2RTZEhoOWRUZFNjeGZSZHhlSGJSZjFiTmRHYlZlWmMwZWJlamhBZjhmUGFVZlphdmhRY2hoSWZRZEtmVWdvY1lmQmZrZ1FhV2NjYkZhZ2VYYU9oeWZSYitjYWd4YzFhcGFUZm1lZ2RRaFJnV2FkaFJmU2JSYVZmT2dhaFhhUWVZaGNlRWRGZjBhVWJVZG9nZGVJZmxiZ2RuY0RleGJsYzRiZWFBZUphOWdEZnpoQmE0Z0ZlSGNGZUdmRWczZGhkVGhUYzJlUmVxZlVieGJrY1RhY2dBZHNkYWdGZzBmRWgvZlJmMmVZZUplS2V4Z0plbWFZaDJlRWJVYWNoUmEwYWRhVGdSZWxiV2RkZkdjNWcyYmNjMmY5Y0doWmN4ZFlmU2ZIYmpoQWFlZlJmUWdBZEthQ2V5Z3BnU2dGZmllY2ZyZk5nV2dVaFVjSWdFaEpoemdXZFVhVmFXZGVoMGFrYVZnVGJtZWxjMGhHaEhnQmVCZmRmRmZGZktnVGVuY1ViUmZNaEFoMGNDY1BhWGFCZFVjSWdWYXNhdGFTaGhlWmVyYmJhQmROZTRmVWcwZTlma2hhZWxmTWZaaEViM2NBYUxiV2VWaFlkU2dPaFFnWWczZ0JiR2c1ZUlnTWNTaDBkTmJHYldna2ZmY0JnMmZjY1poVmVuY1JodWRkaG5nTmR2Z1JjbWJjYldnRWJraHhiMWdTaGhoQmZTZUZoa2I0ZmthRGJ4Z0FhaGVZYWhoWmhoZVFjRGVvYUhhSWhCYnhhTWNIZTFmMWJKYlhnRWNkYnlmWGhoYmhkd2FRYVhjUmRSZFNja2Q1YTFkRWVYaE5nTWZVYlhmaGd3aEZoVGVWZWNlTGJsZUliV2RNYUJlVmVRYU1nUmVwZ05jZmRrZEJmVGdHY1JjTmh3Z0NnMWZsYldhRWJuZ3BjSGNaaEViRmh1Z1NkbWVSZTVjR2JWZUVmbGFTYUVoOGJEaEdjU2FWYzhjT2NqZDRiNmJQYUVjcGFuZlJiQmU1Y01kUGVFZk1lTGFlaEVhUWFMYWNhRmRwZENjYmMyY0plbWNhaFJiUmF5YVRibmNNZVFjRGV3YndmQ2dEZUJnVmZNYkpjVGVWZ01jT2hRYTlhbGFVaDFnQmdrZWRhUmdGYnpkVGRGYkZoNGZjZEZnWmEwYkRkMmR0ZFNoRmNIYUVhRmNVZmlhc2VXZFRkMmdZZW9oR2NsYmRoU2ZJYmxiSmhiZVRiRGhoYTZmUmQyYVJmQmRiZ2tmcGJrYWVjVWFzYVVlY2NSaDBnZGdUYlJkbGZXZkpiaWVzY2lmSmhqYzBnSWhaZzNmOGhhZEdnRGUwZ0RoUWMxZzVhRWVXZlhjeGZhZkNlMmFaYzVoVGJHaGtkVWFjaGtlNWV6Z0VkRWZ4Y05kVWVVYWthVmVUZW1ibGMwZFdlemJFZlNiTWZWY0ZoSWhEYkRiUmJDZU5obGNwZkZkZWZtYXBiOGNkaEFhOWZyY1VmaGFSYnhhUmJoZE5lNGRVZTBnOWhrZWFjbGJNZVpjRWJ5aEplT2REY1FmTmhBZU5oRWFjZVFkU2dUaG9hQ2dMYVNmcGFIZUZoQ2RNYlJoSGZRYVFoUWZUZ1ZjNWZ1YmRobmROZXZnUmJtZWNiV2JFZmtieGQxZVNjaGRCYVNiUmJFZWdoeGdDaFFnZGh2ZllkRGRNZHFmUmIyY0JnTWdhY1RncGZNYVRjVmVGYkpjRmhVYjVncGNkZUJiaGd3ZFFhWGdSZVJkU2hnYjBmMGhRYWpnWmJNZlVmeWIwY3poQmNYY2thZGFhYVVoZ2grZWNjVWJZYVRhZWVGZ05nUGRaaEdicGhUZ0dnUmNOZndoQ2UxaGtoVmNVYnlna2JDYlpkRWNNZDdlSGNpY0pkb2RYZVZjZ2cwZ0hod2VkZG5oR2RWZFpkMGdiaG5lWmR6ZWJkMGNaZW5kRmNoZ0pnTWRkZVVhcGhUY0VmeGFkZE9hY2JGYWdoWGVPZnlhUmRyZ2ViQWRJZStjQ2UzZEViS2RaZ2tjMWRSYlNoUmNWZk9mYWVYZFFjWWhjZ0ViRmQwZFVhVWdwZk9iZGVSY0VlaGJDaFFoVWh0YkliaGRoYjBlZGFtYU1nR2dYZURoZ2dWYUhoM2dnaEJnUWEyZlFmamhXaGdkSWg1Z2NnQWR0ZlphVmJoZUpiNmdSYTJjUmJCY2Jma2FwaGtiZWRVZnRiUWZOaEZmdGNjZkdkRmhVYkNnYmZrY1JmMmhjZjJlOWVHYVpneGVZY1NlVGdIaFZlS2ZFZkZiSmZFYkNjM2dCY2FiQ2J5ZWxnaWRiZGlnd2VkYWNhaGdvYTdlUWNnZ01lYWdVaFFjZGhRZEdmV2RrZ0FnUWdTZkFiRWNFaFFoTWNZYUFiU2ZjZVpoY2RUYmtlZmNNZnpkNGZaYUljMGNGaHJhRmQxZW9oeWJDZVZkY2Z4ZEhmUWVoYStjYWZsYUVjWmRHY0hjQmdmZVVjRWIwZzRhZWNrY2Rha2NRZVdkNWhLYVpnSGdsZExjRmRIY0VlZGhIY1ViMGVaY1Zibmh3ZzZoZGZtYjVidmFUZGplTWNXY0djVWZ4ZzNjU2NCZWxjY2hFZUVjUWRjaEZmUmZVYnFiTWVBZFVhb2RSYXpiZGFHZGVmaGZsYUFnVGNWYWtoTWZGZ1ZoTmdwaGRhUWdoYzVoV2FsYTViUmJTZ2tjNWYxYkVhWGROYU1nVWZYZ2hod2VWZG5oUmhTY1FhVmJJaFVhY2RVYVllVGRlYUZjTmdQZk9iVWdCZVRjR2FSZE5jd2RDZTFhbGJXaEVhamJ3ZFNhS2NnYkljNmdBaHlnc2QzYVNjMGFOZjVmU2RSYkZjTmJTaDFocGMwaEpmM2Q5ZnpjTmFHZ3hjbmhGZGhkSmJNZ2RkVWdvYVFjVWNrZVFmTGFKZWhmc2NRaGJleWZkYW1oZGVCY1FjbWhOY1NnRmR0aFZoMmJkZlJlU2FSZlZhT2dhZ1hkUWdZaGNhRWRGZjBhV2RSYTRkMWRKYzJieGJ6ZVVjVmZFaHNkQ2F4ZjhkSmFCaG1hZGhTY0hlQ2dVYzlkV2NnZlZnVGJVZG1kUWJ2ZldjZ2ZJZTVjY2FBYnRoWmJWZmhkSmY2YlJnMmFRYWNiUmJFZHBja2VlZ1Voc2NVaGNjUmgwaGRmQ2EwZXdhWWROYnpkb2MvZFBiQ2dGY0dlTWRSZjVkR2VRY0hnVWVZZkhjRmdJYU5hQmUzY0FiZmRUZW1jOGZ0ZWJhMmFsaFBmV2ZFZzVoemRFZkVmeGJOZVVmVWFrZVZnVGRtZWtoOWFYZm5nQmZKY1plRmJGZVhlVWYyYWdlUmFKaDBiSWZkaFBoVGQ0Z1JjSWRFZGRmaWNVZGtjWWEwZEVja2dZZ3FoSGNVYzllcGVlaDBiZ2J6ZkViM2ZBYUxlV2JWYlloU2RlYWtnZGZraFFnU2hjaE1kWmJIY0ZlaGNGZkhnRWFkZ0hhVWEwZlpmVmduZVJhdWJkYW5jTmd2YlRjbWdWZEZnUmhoYTRnOGdCZkZlZGJRY1JhQmVaZXRlV2ZoaFllMmNNaGljTWdtZVVhbmhJZEhoV2VSaEJmTWNUaFZhRmFKZkZlVWU1Z3BkZGJCYmhod2RRaFhiUmFSZFZlVWE1YjllR2NUY1phTWZUZEhlZ2U1aFhmM2VnaFBiWWV4ZHNmVWViYkVhWWNEZ2NkVmRwZWxlWmRHYnBoVGZHZlJoTmV3ZUNkMWRsY1dmRWJuZnBhSGdaZ0VoRmgwZ1NnaWMxYzVhVmVSYlJmamNEZkFjbGJhY0RiVWc1YW5kZWRHZkpja2ZSY1VhWmhuY0ZoaGNKYk1mZGJVYW9oUWFVZWtmUWRMY2NiRmJwaENmY2hHZUpmdWdJZUJhUmF2ZFRlbWhFZUJnV2NGaHBkRmVVZ1FnWmZZYmZiV2VNZFJhV2ZrZUZkMGZVY1VncGZPYWRnUmZGaHpiVGZGYkZmNGVjZEZjWmUwZ0ZkV2R0aGZiQmdtZ0JoU2NCaEdjeGVMaFhiSGRKZStnU2R4Y2toTmNjaEVjSmNaaFVjQmRSZTZmVGJ5YjFiQmRjYjBicGFwaGFkMWJvZEFnWmZnZ2tiRmNYZGdkOWhDY2JnR2ZkZjZnV2dXZTlnR2NaY3hkWWRTZFRlSGZWYUthRWNGZUpjRWRDaDNjZ2ZUaFFibmZKZGllYmdTZUFiZGFmZG1iUmF6aEVjRWJ4aE5nVWFVYmtnVmVUZW1nbGcwY0dmSGVBZElhSmJ6ZjhhTGFJYUhoMWFZZ2Vka2J4ZVhmZmhuYUJjZWRQYVFjOWgyZ1VmbGJ0YXhmV2hSZk5jb2VVZTFoVmRrZFBhbGYxY1ZiVmZqZjVjTWJEY1JjNGhTZWRmMGVkYTFoU2hHY0phZ2RaZ0hobGVMZEZlSGNFZGRjSGNVZjBkWmhWZW5kUmR1YVpmbmFOZXhjUmNpZjRlV2RGZEVocGIxY1FnbGFsZVNjV2NRZXNia2RWZEFnNGRxYUxiQ2hFZTllWGVIY0pkRmRjZTFibGJGYlFiWGV0Z0phRmJVZDVhcGdkYUJlaGd3Z1FkWGJSZlJlU2hraDRnOGRFYVdiMWVSY1VnU2F4ZCthR2RqaEZjQmFMZ0FkWmFjZGVmR2R3ZFRnZWVGaE5iUGNaY0djcGFUZUdiUmVOYXdoQWRsZGtnTmRPZ0hmcGVIZVpkRWdGZHViU2RtZFJjNWJTYXhjUmV4Z0hkVmZRZExjR2hWYTRkN2RaaDNlWWhoYktjaGNJYnlnUmRGZXhoTWRlY0Znc2JMaGVnRWVRYkxjY2FGY3BnQ2NiZjJoSmZtZmFjUmNSaHloVGZqaG9jUWRVZVViMGFGZFJlMWVrZExnSmJ6Z05lTWhPYUVjRmE1Z1VlVmR0YVZlWGR4ZEZkemdUZkZiRmU0ZWNmRmhaYzBhRGEyY3NoUGZGY0RjUWFLZlFjRGYxaFRhQmRpZUpkcWRXZ3dja2hUZmJhZ2FzZ1FlWGF4ZUljaGFiY1diUmZCaGJka2hwY2toZWFVZXNiVWdjZ1JjMGJkaFRkVmdBY1FjZGFHZ1poM2FQZ0dnWmZHaE5oVmVOZUdkR2JTYWNhRWhFZ0ZoOWNWY0VmRmNwZ2FlUWJtYjllaWRaY21oa2hVZWNja2I1aHpjRWhFYXdnRWJVZFZjUWhWZlhmbmFKYWVoR2RIYkJmQmRkYUZhRmVLY1RkbmNVZ1JnY2R4aEZkN2dlZEhiQmhXZ2RiQWY5Z3JiVWNoZVJieGFSZGxkb2craFVmMGJkZnNlYWdBZkJoTmFRZVRmbGhGY0hibGFRYlNiWmYxYXBia2dGZFRoY2FhY0lhVGJZZU5lRmZDZE1iZGZHZzBnc2JaZlhnaWRaZnVkYWgzZE1laGNTZUNhRmdFZ1hkUWRGZTlhR2FCaHhlU2NBZ1FlSmg1Y1Zka2FJZ2hoYmJDZjhiNmNkZ2lnY2NJYk5lVmFVaGVmUmFRY05lQWFIZ0VnZGhEZ2RnQmJoZHdkUWdYYVJjUmJTZmtoNWgxY0VhWGROYU1lQWh6ZzBma2RBYXlhWmdCZGFjMGNJZFVjYmVGYXNlT2FlZ0FjRmJCZUthQ2c4ZWRkWGdrZGNmNGVDZzBmWmNXZkhoMmR0YUhhZmFrZkVjUGhRYWpmQmcxYVNhMGVaYTljSGJWYVJiQmhHZVJnTmQ0aGJmamdsaDZhZGdHZHhhbmhGYWhnSmdNYmRkVWVvY1FiVWJrY1FoTGhPYlJmeGFDYlpiMmFBZm9oUGhGYWtmd2ZDYnljRWFTY1RnRmVCYk1jU2NVY0VhWGFPZFRnRmRYZU5ja2ZFYm1oV2NHYUJmT2ZkY1JmRmJ6Y1RoRmNGaDRnY2NGaFplMGZEZjJlc2JBY1VnU2VVZlRiUWRUZlplVGVSZTBkNWVxZVVjeGVrYVRnY2FBaHRkWmdWZmhnSmU2ZVJlMmZSY0JoYmFrZkliMmFlYVZoWWdVZ1lhd2JnaEliVGhSZzlnV2JKYW1jZGM2YVdmV2I5aEdlWmF4Z1liU2FUYkhnVmVLZEVhRmVKZkVjQ2IzZ0JoYWFEYkdlRWNXYkhneGhsY3hkRmZqZUVlU2VZZWpjNGRzaEthRGZaZm1jT2V4ZmtmRWFkYndlSWUxY2RoRmhkYU1hWmNIZlVmUmFjaDBieGFSY2VmSGNCY1dmZGFBZDlicmRVYmhjUmh4aFJkRmhVZXRhSGdRaHdkd2FJZHhjeGdYZ0ViWGVBYldnUmVGYlpiR2hJZnhoY2NoYkRmaWdoZ0tiRWdUZEFmRmRRZ0dibGI4Z1RieGI5Z1ljRGMzZm9lK2FKYkRld2g3ZUNjVGhOY1BiUWJnaGxlN2VBZDFnNGhXZkFkVmNNZGZjSGJHaGhndmFZZW1mWmNwZUZkSGdKZE9hY2J4ZkJiTWJUZVZhRmJKYkZiVWc1ZHBlYWF4Y2dmL2dhZDNkUmZSZVNja2g1YjFhRWRYYU5iTWRVZ1hkaGJ3YlZibmdRaFBlYWUxaEljVWdjZVZha2NUZkRmUmdvZ0JmTWFIaElieWVTZzBkRWR4aFVlbGdjZkdlUWZEY1VnVGNLZ3hkVWUzZ0dnaWdGZzNmQWRsYW9oMWhXYUVjVWdpZlhjMWhnZzNiTGN6ZG9nL2haZnhoSmFyYkZoa2VCZkFiZGVRYk1kWmZlZEViUWhMZGNlRmVwZUNjYmgyZUpkbWdhZlJoUmh5aFRmbmFNaFFnVGZFZjFoUmdTYlFkOWVPZkhnRGUxZldjSmFGYWtmVmRBZ3hjZ2dQYkxiQmY4Z2poSGZoYzRjc2NQYXdhSWV0ZlhleWg1ZmNlV2NEYkFmVmVSZHhjRWZkYUNmeWNFZ3lkUGZGYThkZGRNYzBlb2ZWZEdmaGdvaHVjU2gyZ1FhVGNZZ2thb2F0ZmNiR2VFZ1VhY2VSYzBhZGRUYVJibGhXYmRlR2Y1ZDJnY2IyYzljR2haaHhmWWRTZFZnbmdVZnJoR2ZBaFplSWZDaHdoc2FJZlBnMmdOYWljTGgyYVViVWZOYjBiSmN6YVhmMGRWZW5kVWFVZWtlVmZUYm1lbGQwY0dlSGVCYkJhZGNGZUZiS2dSZDJoNGM3YWNkMGJ4Y1JkZWdIZ0JoV2NkYUFmOWFyZ1Vha2dBYjVoRmVGZ3dodmJVZndiRWVoYlBmVmFOY3RkU2JpZUJoT2hQY0FiUmJBZE5jUmhWZ3NlUWd6ZmdmTGJLaEhia2FHZVFlU2hKaEpmSGZRZDlhY2RWZ2liY2Q2aEplRGRvZ2hiQWNXaHNmV2NYY0Jja2I0ZkNlRmJVZEFhUmRFZlFnaWJXYWlkQWg2Y0piQ2ZBaHNoUmVuZUJnSGNhY0RncGJNZVRhVmdGYkplRmVVZzVncGFkZkVkVmJhZVFhWGFSYlJlU2FrZTVmMWRFZFhnTWZLZEJiRGNZY3pjQWVqZzFjQWZKZVZnSmQxZWVkUmJJZWZnZWRBZ0ZnRGFaY0NoTmVmZUdiVmFaZzhoQ2R4YlpmZmFFZWlnRmd0YVpjRWNGYnVlU2ZtYVJhNWFTYXhlUmR4aEhoVmhzYllkVmR4aFVlZ2hKaHpla2Y5ZmJld2g1ZHZmUWJoZTVjTWVKZDBnTWJRYkNhV2M0ZkxiY2RGZ3BkQ2FiaDJnSmFtZ2FoUmhSZHlhVGNuaE5oQ2NDY1Jka2dFY0diMWN0YU9nZWFIZVFiRmViYVZjeGgwZEhjMGJwYlJkZGNVYlVoSWFIZ2lkeGg0ZGFhbGVZZWdnQWFUYmtlWGVWYlRiVWd6ZGVnamJZY0hkWGRuaElnSWFOaGhoRmZCY2NhQWJGZFpiR2RCaHRkaGViY1dkUmRCYWJna2hwYWtoZWNVZ3NmVWdjY1JlMWZBYlpkeGhsZ1djZGVHZjVkMmFjZTJiOWFHZ1pieGJaaEViRGVTZmRiS2VYY2xkSmhaZ0NoMmJGZldjYWRHZDliaWVaZm1ka2JVZWNla2M1Y3plRWVFYXhnTmJVZFJob2hWYlVmMmNrZ2dlRmRqZndmRWJPYmhmWWFlaEJlbmZrYzdlY2UwaHhlUmZlYUhnQmNXY2RlQWg5ZXJlVWFoY1JheGZCZXhiTmhsYVVjeGcxaHFjSmZoY1pnWGRWZUNmUmhEY1FkbmR3Y1NmZWVrZGRha2JRYldmNWVLaFpkSGVsYUxiWGZUYWNiZGhGZ1doY2haaFZjbmdSYnVhZGhuZE5jdmdSZm1nY2FXZUVoa2V3ZWpmQmRWY2toV2hSYUJidGN3YldnMWg5ZXlmWWhpYk5hcGZFZG5hUmRrZGNkeGFCYU1hVGVWYkZhSmNGZFVkNWNwY2RmQmhoaHdmU2NYYndiVWFTYWxjTmcxZFloaWJjYmVoR2VEZ1llM2JYYWpkRWJHaFpoUWFaZWJoSGVRZGxnRWNQYVFoRWhzZkplVGNrZldhRWJSZnBkNWVCZzNnTmhXYUVibmNwYUhjWmZFZ0ZodWFTZm1nUmY1aFNoeGVSZHplU2ZGZjRiZWNDaDFhUmYwZmNlMmh0Z3ViYmZ3Zk5kbmZTYmtnNWZtZmRlVWdvZVFnVWRraFFnTGRjZEZkcGNDZGJnMmFKZm1lYWdSZlJkd2hHYXpkQmREaFFkVmU5ZFRjU2VRaGhiVGJkZUhnUmNkZmNiQmEwYm9lZWUwYnBmT2RkZVJiRmZ6ZlRiRmVGZjRlY2dGZFpiMGREZzJhdGNTZkZmaWZRaFNjVmVXZ2xiRmdBZ3lmRmhvYlVld2ZRYk9iYmFRZ3NhY2RWYWthNGhtZGJlV2FSZUJlYmNrY3Bha2FlZVVjc2ZVZ2NoUmUwZGRoVGJSY2xhV2dkaGpoc2RpaE5lV2ZKaFhhY2NWZHBiWGNUaG5hVmZYZERmVWQ5ZUVhVGRuZWxod2VRZG1nOWdpZFpnbWRrZFViY2FrYzVhemJFZUVnVmJOZUNobWFNZFZiVGdtYWxhMGFHYUhjQmVCY2RmRmdGY0tnVGZuZlZiWWZOZlVjeGJaYkxkSGU0ZGFhTWNVZ0Vic2RCZGxheGZ4ZldlaGROaHFkVWR4aE1hNGhhYmdnRWRYZ1hkemRWZEZiSGVnZ0pkYWhlZGxldGNrZFVjMmRkYUtjTmFqYXdmZmhRZVNkTmZUY0hlVWJBY0liVGRWZjVhdWRkYm5jTmJ2YVJlbWhjYVdjRWVrZHhhMWNTZGhhQmZhZ0NmZ2J0YnRnV2RsY0JhbWViZ21nWmhoaFJkM2hKYUJiYmNoZUJmZWhSZUZoMWRKY0hkUWI5ZnBkZWR3Y1Zld2ZVYjNhMWNkZlNla2dZZjhjRWhYY3hjUmJVZFdncGU1Y1RhVmI0YVBoYWcxYkllVWVjaFVlWWRUZ2VhRmhOY1BmT2JVZkJiVGdHZFJjTmR3aENkMWVsY1diRWFuYnBmSGZNZGdmQWE4aFNkamVGYmllWWdSY1JheGRIZVJlMWROYUdlVmhaYzBoYmhuaFlmNmFLY1VjWmZ2Z1dnUmF0aE1jTGRtZkFiUWhVZGtmUWVMaGNmRmFwZUNnYmMyZUphbWFhZ1JlUWFrYkRjeWVFYVFoQ2RrZjFoTWFTZVJiaGhmZ2NkbGg0ZllhY2JFY0ZjMGVVaFVlcGVPaGRiUmJGY3pjVGFGYUVmK2NQZ3dlUmEwZUJkemg1aFNoQ2JYZ0ViUGNDaEhjZ2dBZFRnM2NwaHFmQmhnYkllVGJKZ1FiQmhTYVhkemZoYTZhUmMyaFJlQmhiaGtmcGRrZmVnVWFzaFVnY2NSYTBkZGFUZ1ZkQWRRYWRhR2ZZaCtlZWF6ZnRmS2VaZzBiTWJiY1RhR2FoZlhhRGNWZklmTWJBaHlkSmRXY1FkbWNKY3pmWmNuZ1FnSmJiYTBmNGcxZUVhRmFOZU5nUWZVZmtoUGJUZGpkeGIwYUZiWGZBaEhjZmRWZ2hnS2JGY1ZmOGdSaGNiMGR4YVJjZWRIYkJjV2NkZ0FnOWJyZFVjaGNSZ3hmUmFoZE5nNGNHYmdnbGJrYllibGdzYlVjQWhuZUFkV2VSY0Vic2JTY1BoRWZkYmliUmYyZjVkQ2FJZ25kbGFXaEZoQ2RRZVVlRWVVZTFjTWNWYm5mbGV1aE1jSGZOZmtkUmhuYllmV2FEYTFiRmhvYlNnbGJGZ2JnVGZRYnNjaWhIZ3hjWWU2aE1jQ2doaHBlVWVuZUpjRWNjZjFoNWZYZlpoMWVGZEpmRmhVYTVhcGdkZkJmaGN3Z1FhWGhSZ1JkU2FrZjVhMWVUY0hlTWRKaEhiU2NzZTFmVmduZGtiZWhhaDFhTWJKaGJjRWdaZlZjZWVGY1ZoSmZaYkdjSWVHYkdjUmU1ZnRlQ2h3ZnhiV2FIaDNlb2NCYmJlVWMxZ3VkUWdpYkpnNWFWaGhkUmY4ZURlQmNSZFdoTWcxYlphMGViY25mWmF6ZGJlMGFaZG5mRmVoaElkUmVkY1FiOWVjYUFhUWdFZWhlY2JGaHBnQ2ZiZTJnSmJtYWFoUmZSYXloVGZuY01nUWRDYWdhSWJEZlNmUmcwZ0hiYWdYZDhnWWJNZ1VhRmJxYVVjUmFsZk9kY2N4YWRmemRSYUJnaGI0aGJhVmZZZG5jRGQyYlpjU2FWZ1hjaGNLY0VoeWExaFRiVWZtYVFiamdTYkJobGVHY2NiQmVWYkViVmJnZkphaGFSaHpnRmFNYllmMGROYWtiSWZtZkVmVWdjYVJjMGVkZVRlUmJsZ1doZGRHZTVnMmNjZTJiOWdHY1phMWZCZmRlSGhuY1ZmQ2FSZGhkTWFXZENkemJ4Z2FoWGcyYzlhamdkZ21mVWNVaE1hVWU1Z3VoRWJGYnhlV2hVY1FmZ2FWYVVkR2hrYjNoQWUzYUFnQ2RmYTFicGZEZFpmSGFVZ1JiY2gwaHhnUmhlZ0hoQmFXYmRoQWE5YnJnVWZoYlJoeGZSZ2hlTWh4Z0ZnVWY5Y3NoSWVsZnRkTmNIZTNoQmdlZVdnVmUwZVNmT2RVZTVma2JRZkhoTmNYYVplRGRGY0RmUmFuYzBjZGFYZ2tkUWhRZFZjaWM5Y0ViZGhuYU5kdmZSZm1kY2NXaEVia2d4YzFiU2hoZ0JkU2JSYkFmdGN3ZVdia2dKZHZhTGVtaFpiMGhGZkhoTmdmZ2FoRGdwY01jVGNWYkZlSmhGY1VoNWVwZmRiQmRoYndjUWdYaFJiUmRTY2tkNWMxaEVjWGhNYU9mQWF6YTBieGZIYldoOGVsYWFmMWRJZlVoY2VVZFlmVGVlY0ZnTmdQY1pmR2ZwZ1RoR2RSZk5hd2FDYndmUmU4aEVlbmFwYkhmWmdFZ0ZidWNTZG1nUmI1ZVNmeGNSZnhnSGhSYTBjRWVYZzFnWmI4Z0llbmc5ZnplUGVRZE1hemRRZTBnQWFDYWRjUmM4aExjZWJFZlFjTGFjZUZicGZDZWJkMmNKZW1nYWVSZlJleWdUZ2ljNGQ2ZVRiRWIxZFJhU2ZSYlZoT2NhY1hkUWRZaGNmQmFNaHhmQmFSaDhkY2NPaHhlRmEraFhlVWhwaFNiY2dGYVpiMGNEYjJmdGZTY0ZmSGJFYWJnT2VYY2hmVGhUZDJiUmZxY1VkeGFrYVRiTmdsZDRlWGVGZlVlWWh6aENiQ2dwaEJlRGNVZ0lhd2JkYlVidGFHYWZmUmcxZ1ViUWFSaGtiVGFmYVdjNGN0Z1dnV2I5ZEdoWmR4aFlmU2ZUYkhjVmhLZ0VhRmJJYk5hQ2IyYzFoYWdMZERnb2R2YkpkQ2d4aEdhZWNnY2RnNmVFZ0JhQWhSZVVoVmNrZE9nWmZHZ2xhMGNHaEhnQmRCZmRhRmJGZUtmVGJuYVZoSGFNY2hoNWVSYU5kM2JCYUxiZGhGYnRibGFIZGxiRWEvaEFiVWRjZndnVWYwYUpja2FJYzBkZ2J6Z0VjM2ZBZUxnV2VWZlliU2JlZGtiZGFrYVFjU2V0ZUtmZWUzYWxjRGRIZkRmUWFkYUFjRWYxYzNnQWZ6Y2tnc2ZNZHljRmFuZUFoMmI0YmZlSGZrYndjd2JTZ2diNWhTaENld2Z0ZTJhWGFFaEplbmJKZTJkWmUwZ0ZnRGYxZkhlZWNoYkJjV2dUYVZma2dNaEZkVmVOYnBjT2F4aEZkcmFhYTNlUmhSYVNia2U1YjFiRWJYZU5oTWFVZFhmZ2NtZ0ZheWFZZ1BnSWExZUlkSmhjaFJlUWhkYk5nQmNZY0JhSWV6aDRlYmNBYWpibGV3YUNnMWhsZldlRWhuYnBmSGNaZEViRmR1aEFneWVKYzVoUWUxZHhoeGJHZ0JkMWFmZ0dlVmVkZ3BiY2gzZVpnamJaZ2tiWWV6Ylhma2NBYURkSWZrZHBiZWNGZ3hkTWRMYUJjQWFNYVNoS2RnaGNlMGZPYjFmc2NnY1JjbmhGYjVoQWFoYnNoUWZCaFZod2RLaGFmVGZ4Z2RjS2NFZkVmbmFCaFJlZ2dIY09nMWJaZ3hoUmVVYnBoU2FjaEZmWmcwZURoMmZ0ZlNlRmNIaEZkR2RFZ3pnMWZUZFVkV2RRZ2lnVWF4aFljVGJZZWdkdGRmZFViQmRKZnlkQWRtZVJmY2ZiYWdkSmVraGRia2ZzZUdnZWFBaFlkM2FUaFJmbGZXZ2RoR2g1ZzJiY2EyZDloR2daZjFnQmFkYkhkbmRWZUNhUmNoaE1jV2NDZXpjNWVhY1hnMmE5ZnllZmdXZ2xjUmZjYmxkQmh6YVhobGhkZk5kV2RrYUpjYmdSZjJha2F2Y01mbmRCZ0JnZGFGYUZiS2JUZG5jVWRSZ2NhMGJ4ZVJkZWNDY1ljWGZKZWdjOGM0YVVmZ2VsZXhiRmJsY0lmcWRBaEFkb2ZOYUpmQWhjZFJjUWFYZTVmWWdEZEJkUmNCaExjaGdWYnNiVWEyZTVlQWFaZ0RoZGFIY0ZnR2hNaFVoRWNVZzBoSWZRZEhkMWgxYlhnSGJOZXZnUmNtZmNhV2NFYWtieGExYlNkaGZCYVNlUmJFZUloMmFXZGtib2ZtY01lUWdnZG9mZWhuaG9nZGdlYWhlbGFNaEhmeGFRZGRoUWRCYndlbmNkZEZkWmVyaGFiM2NSY1JnU2JrZDVlMWZFYlhkTmJNZ1VnWGRoaHdoVmNpaEJnMGJJZWxlSWRmZmNlUWFoYnVkZWJFZzVnUGFOZDNnRmE1ZUdmUmdOYndmQ2YxZmxiV2FFaG5kcGhIY1pjQmN4ZEViU2dtZVJiNWNTZ3hnUmd4ZkhnUmMxaE5nR2ZRZVFheGRPZmlkTWFoZ0lhVWFZaHBoRGVUZ2hoTWJkY1Vlb2FRZ1Vna2ZRZ0xjY2FBY2Rmb2NiZjJjSmhtYmFlUmhSZnljVGZuY05hV2NHZlFnTWNTZEhjVmR3ZUJlSmUzZlJoYWJlZkJmVmE0ZFVhUmZoYkNhZGJWZWhlL2VUYUJlUmN4Y2NkQWcxZmVmRGYyZHRmU2NGYUhkRmNHY0VhM2FoYlRjVGF6ZFlhdmFCYTBieGRCZ1BnZ2VzaCtoWGJuZ3BmeWVGZldoaGZCZk9ka2ZRZG9nUGRBYVZjVGVKY1ZnVWRkY1FnQmhrY2ZjZmFXZUpoMmVKZTJmTmJHZ0xhaGRvYVNhQ2dYYnhiUmdPYmxmSmFFZENjM2VCYmFhUWRtZDllaWNPZjBoTWdVY2Nia2c1ZHphRWVFZnhoTmZVZlFkOWZBYkFiQ2ZvZ2doVWNUaDhlUGNkZkRlUmZDYkdibmJrZlJiSWhVZUJmUmRNY1hmeGNXYU1hUWRaYXJkQ2VUYjVneGZSYWhoTmc0aFVjMGc5ZWtnYWZsYU1nWmRRY1RmVmhmY0RmQWJSZGNmZWJpZUJoc2hOYjJmWWNZZmJmWGhWZ0xkUWNIYzBnZGNWaEVnRWRaZ0VkM2UxZTFmWGZIaE5mdmNSY21hY2VXaEVla2R4ZjFhRmh6aHBoU2JSYUFndGV3aFdoa2RKZ3ZlWWhpZEFmOGdXaGpmRWFhaE9nbGE4ZENnVGNTY05oQmhRZVVjSmFwYkpmaGhSaHdmQ2VIYmhnUmhEYzBhZGcxaFNobGdsaE1jVWVYZ2hid2VWY25iUWdQZmFlMWdJY1VjSWd3aE5oSGFMYVFmRWdCYlplQWc5YWJjVGRSYTlhd2VXY1ZlVmJXY1dmM2ZaZkhiSWJVZ2hiMWhZZkdoUmg1ZVNkeGdSYXhhSGRSYjFlTmRSZ0hieGIwY2JibmNaZHphYmIwZ1plbmdGZ2xoUWJaY09od2dsY0VkR2N3Y3RnRmJjZ0FjSmJLYU9hMmg1YW1lT2h4ZmhjeWZCZDNoOGZRYkNhVWVSZFJnRWFqYTliT2FhY1hhUWNZYWNhRWZGYjBoVWdVZXBiT2FKYzFnUWNuaEdiUWFNZjJlY2VEYUZjOGJkZFdlTWNBaEhhWGYxaEdkUmUzYlJjVGZCaG1maGFxZkZoaGVBZUllV2RnaHRiWmJWaGhiSmg2ZlJkMmRSYUJiTWgyZ0Jka2RlY1Vmc2hVZGNjUmgwYWRhVGdWYjhoRGVPaGliMGZpZk9maWZBaElmWmIzZ1FlYWZHY0hjbGhLYVFkbGY1YUVlUWZuZnhnYWJCZzJlWmNpaFBlVWJNZlVjY2RrZTVlemVFZUVneGdOY1VkVWNrZFZiSGhDZ3dhZ2ZUYVNmSWFQZ2RiRGNaaENjSmJIZzFkRGNmZjBld2NGZGRoamh3Z1RnT2RrZmdlL2FHaGhiUmM4Z1JnbGdwYnhkWGcwZDhmd2haYWxlTmJRYkhhM2JCZU9oVWRFYjBkNGFlZGtjZGFrZFFlV2Y1YktnWmVIY2tlV2RQY25mRWhkZkhiVWEwaFpkVmRuYVJldWhNaENlWWZoZUJmVGJOaGZjWGFRZkpjMWVQZGhmZ2FHYlNmQWVzY2lnVmRraElhbWhhYTJnWWN5Z1BlbmFKaE9hY2R4ZUJmTWFUY1ZnRmhKYkZnVWE0YzdkTWhVYXdobGZFZnpmcGNSZk9oMGhBYnpmUWV6ZndhQmJNYnllRWdraEVieGVWZ2RoT2FSaE5oTmFlY1ZmWWVUZ1piVWE1ZFNnWmFEZ2hoVGFIZnhjVmR3ZFFmbGZsZExkRGEyZWRjSGdNZEVkOGJpZkRleWRvaCtmSGgxZ3hjeGdBZWhjMGJaYUdiVWZ4ZzBoT2huZ2dnZ2ZJZ3dhOGZrY1VheGFvZ2VkZWFVaHBkWmFXZDBjMGNRZldkbGdwY0NhYmQyYUphbWRhYlJjUmd5ZkVmMWJrZ1FmVGFFZzFnUmJTZVJnVmNPZ2FlVGFKZE5mUGFnYUlnZ2VHZ0FmVWdBaGRiV2dGYTdkR2FGYzFoNGZJaGxlcGUwZ1JkbWdKZVNnVGQxZ3RkR2VFZjNlaGhUaFRlMmFSZnFnVWN4ZmtnVGFPY1FhdGZFaFZibmc4ZzdhRWJ5Y3hlUGdJaHdiTWVxZ2NmUmM4aGFiUGRWYmhoVGVDYWtnMGVlZWVmR2c0ZC9lZWNuY1Jlc2FaaHhlWWdTYVRmSGNWZktjRWVGYkpmRWVDYnplWWNWYkVmR2g5ZnFiTWhDY2hjR2djaGdidGZ6YkRmVWN3aDJkTGJFYlViVmhBZldibGNwYkdjQ2hKaGFlZGVCZGhnS2dVYkhkVmRlYmFhRWR4ZVloZWNDZXRjOGRkY0FhOWhyZlVkaGNSaHhhUmhoYk5nNGFVYjBlOWVrYlBlQmhKY0xjRWR6ZmdhTGhSY0ZlWmdHYUFnUWZnaFpkVGdVZVJjS2JaYkhibGRMaEZjSGFFZGRlSGVVZDBjWmhWY25iUmd1ZmRhamcxZHZkV2QyYmRjWWZSY3dhQWE1YVJhamNwZlNjUmVBZHRod2FXZWtiSmh2ZVlmbWRaZ3BoRmJIZUpoT2ZjYjBhTmJNZlVnRmVFZEJjRmhWYUJjcGhaY2didGNwZVFnV2d0ZlJkWGVrYTVhdmdFZ1RjdGVNYlRoM2JoZ2lnUmRHYmNlUGdkY0ZkSWdIYWNnVmh3YlRjTWFGYU5iUmdaZ0hhdGdLZ0NhQmhOZnZlQ2UwZXRjV2hDZ0hocGZXYWZoMmR0aHVlU2ZtYlJkNWZTZnhiUmR4ZkhjUmIxZU5hR2dWZFlhOWVLZ0hoWmg3ZUpka2daYTVlQ2R4YkljRGVkYVVlRWNRYkFmVWQwYUxiS2czaEJoQ2NiZTJkSmNtZWFmUmJSZXlkVGduZE1mUWhUZUVoMWNSZFNkVWZNYlBnT2MzZFJlWmFmYkVjRWVoZ1hnVWJvYUloZWdSZ0VhL2VWYjNidGE0aGNnRmdaYzBnRGUyaHRhU2RGZUhmRmVHY0VnM2ZoZVRlVGd6YWNjOWZHZ2thMWZRYk9iQWZ0YlJjQmdSZnRiNmFIZEVoNWRCZ2Jma2dwYmtlZWNVaHNnVWJjYVJmMGZkZVRlUmVsY1djZGFHYzVoMmNNY0NiNGdWY0loaGRZYkRiVmNsYjlhS2NFZUZhSmdFZENmM2FCZGFhUWFtYjlhaWZaaG1ia2dVZ2Noa2M1Y3pnRWRFZHhlY2dRZzFmRWZWZVVlR2ZrZjhlR2JIYlpmSGFkZUZia2ZFZFRnbWdnYVJjT2EwYVZlS2ZVYW5jQmNXYmRoQWY5aHJjVWVoZlJneGNSZGhkTmY0ZFVlMGg5ZWtmYWhsY01mWmVFZXpjSmFaaEhnQmVkaFpnWWdXYTFla2hRZldjNWhLZFpoSGNsZExoRmdIZUVhZGhIaFVlMGRaaFZmbmNSY3VmTmdUYUloOGhBZDJmY2FFZUNhR2ZaYzFiU2FoZkJhU2FSYkFldGZ3ZVdma2JKZnZlWWJtZFpncGFGZEhoSmJPZGNmeGFCaEViRGdGYUZnVWJGZ1Jmb2NTZ09ieGVoYjdoUWJXZVVlc2dRZTBhSmhmYkVhWGdOY01kVWNYY2hod2VWaG5oUWJQaGFoMWNJZFViY2dVZ1ljVGZlY0ZlTmhQaFpnR2VwZkNlQ2R3YXRid2FGZWtiUmZMY0VkbmNKaFdlZmZWZk5jdWZUYkdhUWg0Y1FmaGFSYjNmR2h6YmRkTmJHZFZhWmEwYmJjbmRaaHpkYmMwYVpjbmNGZ2hiSmNNY2RmVWdvYlFlVWVrZlFnTGdjaEZocGJDZVplMmhvYnFiYWZRYWxheWFSZm5jc2NEaFhlVWcxZVhjU2RWZDFlSGZhaFdmZ2NFZGNlRmZkYjlkVWhSZFpoT2NmYVFkZGZnZ1RjRmFkZTRlTWNWZTlkOWdBZjJic2RlaEZmR2Q5Z0dlQWVtZHBkRWFUYTJmSmNzYVVheGNGZWRkY2dCZFpiWmRHZ2hmdGd6Z1hmRWQ1Z0JmYmJrZXBna2FlYVVjc2ZVZGNjUmcwY2RoVGhSZWxkV2FkZEdhNWgyZGNlMmE4Z0VnTmhWY05hVGNCZzJlNWFnYkVjRmZKaEVmQ2EzZ0JnYWFRY21nOWNpZlpibWVrZ1VjY2hrYzViemVFZEFnOGJNZEFmZ2h3YlZnWGNYYU5hZWNHYUhhQmJCZWRjRmhGZktiVGJuYlVmUmFjYjBieGdSZmVlSGZCY1doZGJBYTlmcmFXZ2xlVmR4Z1dleGFNYXNoS2RBaEJma2VZY1ZoTWZJZWJobmhrZUhhY2cxZFllU2VlZ2tjZGRrZVFnV2M1YUtjWmJIYWxnTGdGaEhnRWVkZUhiVWgwZlpoVmduZVJldWVmYWliWmF2YldoMmhkY0NjYWdRZU5nMWhRZlJlQmFBYU9jUWdKYThiY2RFYkpmdmhZZG1nWmJwYUZjSGNKaE9oY2J4ZEJiTWFUY1ZhRmdKZkZiVWM1Y3BhZGhCY2hhd2JVYkdjWmFKZFNhbGJOYW9hRGRIaE5oRWdRZEdiRmRpYlZjbmhJZVBmS2RsYnNiVWZkZzBmQWM1YWVoRmROZFBjWmFHZXBkVGdHZ1JlTmh3YUNnMWRsY1dlRWJuZnBkSGhaYUVkRmF1ZVNhbWdSZDVlU2h3YVZoamhCZVJlMWVRZkJhRWJ0aDBlWmdtZmRkcWZmZ1VjWmRoZUZka2FkZEZjZGRVY3dhV2JlZEVjUWRMZGNhRmFwZUNjYmEyYkpnbWFhaFJmUmN5Z1RjbmRNYlFlVGZFYzFjUmRTYVJhVmZPZmFoWGFRZVFiZWJBZTFjMGZUYUVmcGJHY2ZoUWZCZG1mVGNGYmRoNGVPZEZoOWQwZEVnM2JkaFNiQmRXY05hUGNFZHlmUmRUY1JlMmh4YThmUWhCZ2tjVmRjZUVncGRRZlZlZ2c1Z21nUmQzZkpiSWFiZWhhWmRraGNmVmIwY0hlY2NSZXNlZGdHZkJmQmZmaGVlRWRSZTJmY2YyYzljR2daYnhjWWFTZlRmSGNWYktkRWZGZEpnRWRDYzNmQmJhZ1FlbWg5Z2lnWmFtY2thVWRQaGthNWd0YUVnRmU1aGRnUmFWaDRiVmVTZ0diOWMwZEViR2hWYlVnWmVrZWhjY2hUY21jc2FSZ1BkMGJ3ZE5jSmRIY0FoYWZkZ0JmRmhyZFJkd2JOYmlhVWFnaEJieGZVZTBkbGVpZmFjbGV0aFhnRWcyZjBoTGVGY1ZjOGZiZFljV2gxYWtiUWJXYTVlS2ZaaEhjbGdMYkZnSGFFZ2RhSGdVYjBoWmNWZm5oUmF1YmRibmZNaHRjRmhDYUpoWGJXYVZmZGdmY1NhaGdCYlNkUmFBZXRjd2ZXZ2tiSmd2ZVlibWNaYnBkRmVIaEpnT2NjZzFnTWZOZEhoaGVSZUpiQWdWZVJmRGdkZUJnaGR3Y1FoWGFSaFJnU2drZjVlMWJFaFhkTmJNZ1VjWGJoZ3dhVmNuYVFmUGFZYXhkTWhVZWJjRWhaaEhiQWh4ZnhmUGZiZjJkcGFDYVpkQmNwZDhiSWFWZ2xoV2JFYm5ocGFIZFpjRWdGZHVnU2VtZFJmNWJTY3hhUmF4Z0hiUmExYU5oR2JWZlpkMGJaYWllTmV6ZmNma2FZY3poYmRWZzFjTWNmZWtob2FDYkxiMGIwYkhlV2RsYXBlQ2ViYTJhSmJtY2FmUmJSaHliVGRuaE1oUWNUZ0VoMWhSY1NlUmdWZU9hYWZYZVFjWWNlZ0FmZGUwY1RmRWhvZmFiRGhsYzVlemRSZjFlRmdyZkRkVmI5YTRoSmhXZnRkU2FGaEhiRmZHYUVjM2JoZFRlVGcyZVJkcWRVZ3hla2hUZGNmQWF0ZVplVmFoY0plNmdWZ25mWmdaZWJobGFkZzVhWmJFYnNlY2RZY0FnUWVQZlRlUmE5Y1diTmhXYWRkMmNkaFdibGdzZVpjeGNZaFNnVGdIZ1ZoS2VFZ0ZiSmRFZENnM2JCYWFhUWNtYjljaWJaZ21ia2VVZGNna2c1ZXpnRWNGZjFlZmZTZVVha2RJZVViM2VSZzBnRWdHY0ZhWWRaZmxkRmVNYVRlaWVBZ1liY2EwaHBiWGVVYW5lQmZXZmRoQWg5Z3JjVWJoZlJneGVSZWhlTmI0YlVmMGg5Y2toYWRsZk1oWmhFaDNmQWRMZFdoVmVZYURiYWZGYjlha2NYYUhmTmRYZ1poSGNGY2FnRGNXZE1lZGRHaDBhMWRmYlhiM2NSaG9iY2VGZGxhdmFSYW1nY2JXZkVna2d4YzFmU2hoZUJoU2NSZkFkdGh3ZVdoa2FKYXZoWWVtY1picGRGYUhkSmZPaGVmeGZnY0FlVGNVZHhkamhGZFVmNWFwYmRkQmZoYndmUWNYZlJlUmdTYWtnNWcxYkViWGNOZ01lVWNYYWhld2hWZ25oUWZQZmFjMWNJZFVmZWdVYjRhQ2NiYVZoTmVKZlpjQ2ZKYWFkR2RRYjloc2JDYzBhaGNPY0dnM2FvYWJiVGRrZkZkdWVTaG1hUmY1YVNjeGVSYnhnSGZSZjFiTmZHZ1ZoWmYwZ2JkbmhaYXplYmcwaFplbmRGaGhnSmZNZGRoVWRJY1ljUmNGZWNkTGNkYmxhb2hEZlpnbWdKZzZhZGRSZlJlamNYZkhhb2NRZUVoR2VkZFJhU2JSZ1ZkT2NhY1hiUWhZZ2NhRWNGYzBlVWdVZHBiT2ZkaFJkRmV6ZFRhRmZGaDRhY2JGZVpiMGhEaDJmdGVhZkhiR2RkZ1ZmRWczZDVoVGNHZ21lMWFxZ1Rjd2NVZVRkWmFnYkpoWmhDYmpkaGM2Z1JjMmZSZkJhYmFrZnBna2ZlYVVlc2ZVZ2NiUmYwYmRjVGZSY2xmV2FkaEdoNWcyZ2NlMmY5ZkdjWmR4Y1lnYWVXY21nWmRLaEZobGRJZ0NiQWJuZGxoV2NhYkdhOWVpZlpobWFrYlVmY2FrZjViemRFaEVjeGZOZFVkVWVraFZkVGdtZ2xjMGVHZkhoQmRCYWRiRmNFaEdlVGdtZnNhUmVaZVZnbGNFYmFkMmdWZFdlY2VnZWxjcmRRYXdmVmFnZlVlZ2ZKYXBiUWRVZDloNmhhZGhlOGVaaEZnWGdZYkxkVWZSZGdmU2VaYTBhY2hvZlNkR2VkZlJoVGJuZmxhTGdGY0hnRWFkZkhlVWEwZFphVmRuYVJmdWVkZm5iTmJ2YkdoMGcwZFdhRWRrZ3hjMWVTZ2hoQmRTZlJlQWF0YndhV2RrZklleWVTZUdhWmdwYUZjSGNKZE9lY2h4YkJjTWZUZlZlRmRKZUZhUWRBYzhhT2RGZ1Jhd2RYZkdibGFNZFNlZ2ZCYmZmRWRYZE5mTWdVYVhoaGZ3ZVZmbmRRZlBlYWYxYUlmVWJjY1VnWWFNZ2VnRmZ0ZkhiS2ZtYXBlT2JHZFFjVmZsYkhma2RwYkZiR2czYlpoSGZiZUJnSmd1aFZnMmdSZG9hUWNoZjFoYmhIZVJkMWhOYUdiVmJaZjBmYmRuZFphemZiYjBlWmVuZ0ZiaGVKYVdoZGdRYVFoUWdUZ0VlUWFkYVpmVWU5Z1JkZWNtY0pkZ2RiZnpjNWR5YlRobmRNZVFlVGdFYTFnUmJTYVJkVmJPZGFoWGNRZFlhY2JFaEZhMGJXZVVlSWhBZmRjUmF4ZXVmVGhFYWRodGNaYlViVmdpZkJjbWdkZzRlRmhIY0ZiR2JFaDNiaGFUY1RkMmRSZ3FnVWN4YmtoVGdjZEFjdGZaZ1ZjbGNkYjBhRmF6Z0ViU2FKY2tlSmFzYmNnUWhVZFVhYmZ3YU1mRGFUZlFlaGhHZWZhV2Q1aHdhY2EzZDVhV2FkZlFlVWhiY1RiQ2ZsaEtmQmJVZ2RjV2RFYm1iWmZUZVRla2hWZGllWmdtaGtiVWRjYmthNWd6aEVoRWh4Zk5kVWZVaGtmVmhUZ21obGYwYUVnRGI1Y0JoYWNWY0ZhZmdXYkdjWWJEZVllMGd3Zk5iZWdIYmhiSGJaZkJjMWQ0aFVmaGdKZ3hhQ2hCZnBoeGJXZWtmTmhPZmFmbGJNZlphRWgzYUFoTGdXY1ZhWWRTYWVka2hkY2tlUWFXZTRlUGdhYWlna2ZlY1JoemFraFZjVWMwZlFiVmFmZkhkUmR1YmRjbmROYXZmUmhtY2NiV2RFYWtheGIxYlNjaGdCY1NjVGVFZFJld2hVYlZmOWh2YU1nV2c5ZXliUGFuZEpmT2VjYnhlQmNNZFRmVmRGY0pnRmJVYzRkMGVYZmhnaGR3ZFFkWGdSYlJkU2FrZTVhMWJFYVhoTWZlY0ZhQ2F3YmxhQmZEZm9nUGRIYmxncGZSZ2VlRmgwZjVlZWhGZE5jUGZaZkdncGdUYkdjUmFNYnRhSWdWYmxoV2ZFYm5ocGdIYlpiRWJGZHVnRGREZ0VjM2RDYkVkQWU0YVVmbGdOY05lYmFGaDRhZ2JaZDNoWWVvYlJiVWVaaG5kRmVoZkplTWRkZVVkb2hRZlVka2RSYmRmTWhRYmhoQ2hQYVdmSmI3Y2FnVWJCYzhkQWFqZVplZWdDZnhna2NaZFVlamE5Yk9hYWFYaFFkWWdjZ0ViRmEwY1VhVWFwaE9iUGZGYWRmemFSZ0FkVWRzYWNlRWJoZHBhRGh6Y2xkYmhGY0NkTWJEYVJieWgwZ0JnQWVXaFFhWmZCZzBidGJhYlBja2J4aFhjRWNFZ0FoMWJDaGdhY2FKZExleGZnZUhiTmZnZTliUmZmZDFneGJOYkhiVmRVZVBjZmNCZDBoaWRJZ1NlWWNJaEliQmdvZlNoR2hIZHhnUmVPaGxkSmNFYkNiM2NCZ2FlUWJtZjlmaWFaaG1jbGZTZVBnUmZ4Y3pnR2ZCY29jTWZBaDBhbGNjZFRlbmdSZzBiR2FuZEpnTmJkZ0JkUmJLZVViM2ZVZkJiYWdFYXdnRGNlZkdnNWhXZU1iUmFSYXJjV2F6ZTVneGFSZWhjTmE0Z1VjMGM5Y2tlYWNsaE1nWmZFZzNoQmdDZldiVmEwaFBhZWdqZFFld2NFZnliY2NFZkllM2djZE5iUmRqZzVnUWRmYWdmVmFZY0JoQmJjZGhhTWVqYVpjaGZCY3pjZGFHYlhjaGZWaDloT2FVY1FjQWhEaFVlVWQzZFZja2RJZzdiYmhEZVVnbGNYYlRnRWdMZmVoMWVWYUFmVGZWY2tjTWdGZVVlVmUwZ2RlRWJ3Y2tiU2RIZDFhWWNVaFdoUmQxZ0VkWGVOYk1kVWFYZWhid2VWZm5iUWdQYk9jUmFkY0FhSmJCYlJmZGNlYkJmcGdVZFRhbWRwYVRjR2ZSZE5id2RDYzFnbGNXaFRoMWVCY0hoWmJFZEZndWNTYm1lUmc1ZFNmMWVJZmtiVWExYTRmWmhVZ0Jja2Y2ZmJiZ2dWYzdiT2IwZnBibmRSaEJiNWRNaFBjRWNNZFFhQ2VXYTRiTGhjZUZncGFDZ2JjMmVKZG1hYWhSYlJheWVHYURjSmFDYlRkQWRoZVJnVmFCZ1ZoTWdhZjJkOGZ5ZmNiRWhGYzBnVWVVYXBnT2NkZFJkRmJ6ZVRoQmRoZDRhYmdWYVlnWmJUYmpoOGdhZ0doamZ3ZVBkWGVYYUFlSGhRY1NkZ2V2YkhkVmg1YUhhT2ZBZGRhWmRIZ3hmdGNoZGJlV2NSYUJnYmFrY3Bla2ZlYlVmc2RVYmNjUmIxZGJlQWdraHRlV2NmYURiZ2UzYUlnV2Q4Y0poWmF3Z3NlU2hIZ21oNWdLZVdjVmJKZGFhQ2R6YTlkQmZRZ21kUmVwYUthV2ZBaFVoTmgwYzVoNGFEZlVld2YrYUJkUmR0ZGNjQWVDaDVoNmVYYWlnSWdPZU9kVGdJZkNmRGN5Y2RieWFQZkFlZ2JVaGNiR2VGY0VnWWh3YTlmdGJVZGtkQWhLZ0NoV2Y1YnhnU2RHZVZna2ZhZmxjTWdaaEVkM2RBZUxhV2VWZVliU2RLY0FjSWR3YkZkRGd3ZUVlWmdEY3hjUWNQY25mRWRkZEhnVWgwZVpnVmJuZVJjdWJLaDFlbGV2ZFJlbWdjZ1dmRWZrZnhmMWVTZGxmWWVIYUNka2ZnYWtlRWJ3aDBoaGFZYWdhOWVoZFFhSGE1Zk9hSWNSYXhoTWdCZkZiaGJKY1RibWhSYXBlZGFCZmhld2NRZ1hlUmRSZlNoa2U1ZDFjUmN6ZElkZWVVZFRnMWF3YlNhM2FRZU5nYWNVaGtjK2RjZFViWWdUaGVoRmVOaFBiWmNHaHBkVGNHZVZhcGJ3ZUZlbGJrZjdoVWd5YjRjUGFhZWdhd2JuZ0JiR2R3ZHRnUmNWYWdmMGZVZTFib2ZaaFVoVmdwYjBjSmQzZDljb2NSaFVjWmFuZEZmaGVKYk1kZGRVZm9lUWhVYmtiUmdOY1Bid2NoaENhWmJ6ZFFjbmVPZnhhUWc5YVRmbWQ0aFFiSGRsZlpoUmJBYkJkVmJRZmFoVGVzY0RmY2NFZXBhL2NIaGtlTmVPYk1nQmFGZzRlVWdWZ0ViTGhKZUFoUWI5ZFFkU2Z4ZGNkVWVpZ01kSmJYYWhhc2NiaERnamhZZ0pjSGRGaDFiV2hlZUZoOGZpYUdmV2U5YnpnWGVFZDVhQmhiZGtlcGZrYWVkVWZzZlViY2ZSYTBhZGJIYzFnd2dDZUlkVGh3YzRoY2J5ZnBkZGVUZVJkWWFTZ1RoSGRWZUthRWVGZEpkRWVWZmxkcGVhY1FobWg5Y2lkWmhtZGtiVWJjYWdnZ2VtY1hhZ2U4Y1pkR2FBaFpmYmhUZGpiTmY4aFRnSGV4YkJnSmdsZTFoS2hCaDNod2NSYktlR2NaZVJoZWJIYUJjV2JkZUFoOWJyZFVoaGZSY3hnRWZGYklocWFVZHdncGFrZmRoMWVOY05oSGNUYXhnT2dGYXhoRmhHYk1mbGV4Zk9lUWNXYTVnS2FaZUhkbGJMY0ZkSGNFZmRlSGJVYlVhWWNCY0hhUWd5YUtnbmFOYi9oUmFuZWtkV2RRYUVnVmUxZVRoQmVaZlNoVGZGYWxhd2VSZjBjSmEvYmFiMmRwZnBoSGZIZk1lSGFjZDBjd2RRZFRkVWRGYUpjQ2MwYTRmZ2NkZ0VmUWVzaFFoVGcxYVJoVmRFZzRld2FHYUhhTmRLZlZkM2hoYTRlSGYzZ1FlU2dhYXhlY2hkZGFhbWF3ZVRjZWZGaE5oUGNaZ0dicGhUZ0dmUmVOY3dmVGJSYVljRWNFY25iSWZSZ0poUmROZXVhQmhXYVJia2ZTYnhmWmV6ZEVoUmgwYUZnR2hVY3RiMGZQYUdnMWZ6aEpma2VaZjVoRmJsY3BmWGVkYVVlRWNiY0dia2MwYkxlUGgxZ3BoSmJjY21kSWdlYVlnVWVBZ0plQmNnZjRjWmNWYzJoZGhSZlNjUmRWY09hYWZYYlFkWWdjZkVoRmgwZUFmd2g4ZGFmSWZFY01kOWFUZUJiNWFqY1djbGhaZTBkRGgyY3RjU2ZGY0hhRmJHZFRkbGRKYVRlVGcyaFJkcWhVZnhia2VUY2NoRWYwZ01hR2FGZkVodWVEZWlmc2VQYmJoamFOYnNoTGZVZmNkVWNJZHhhRWhkYUJhQmZCZ1diTGUwY1JmMmZjZDJjOWhHZ1pheGRZZlNjVGRIZlZlS2RWY2hoMGhXZ0NmM2hnY01nQWN6ZjFkaWhJYTJia2VKYWNlaGJwYzljUWJ3ZEFjRWRFaGdnd2RkZEhoR2dWYjBmVWhYZ2xnTmVkYkJiNWVLZFVoM2NVYVRnY2VVZkJmUmFNZkhhQmFMYWRlQmE5ZXdlVWVsYnhjeGdXZ2hkTWY5aFhiUWVNZGhkSmZCYlJjTmFXZjJnc2ZMZkVlVmZZZ1phWmMwaGRiMmZTY0VnUmhLZVpoSGhsYUxmRmFIaEVnZGRIZFVlMGhaZ1ZibmNRZWhmZGVuZGhleWNSYmhnUmRDZ1FhQWJVaDdoRGZSaDRoVWRGYWthUWI5Yk9kUWRvaHVoTWdBZVVlbWdVYkRkZGFHZ05jbWZzZ0VnTWVGZkZoQ2NGYVZleGY4aFlhaGJoYTZjUWJUZEVjcWdBZ2tkNWMrYUVkV2NJYXhjV2FHY05nYWFWZG5iUWVQZ2FhMWJJZlVhY2VVZFlhVGRlZkFnRWVLYU1hRGE4ZkJhVmF4ZU1hL2dFZkhhTmVXZEVkbmVwaEhlWmhFYUZkdWJTZ2pkbGFUZlNjeGNSaHhkSGdSZzFjTmdHZlZlWWh5ZU9memFnZ3dlT2N3YThnb2NXZ0JlSWhoaGZkUmM0YmNhVWZoZVliSGhjYUJmTmFMYWJiemRsZ01oYWFSZlJjeWJUZW5iTWdRZ1RiRWMxYlJiU2ZWYXdnSWFhZlhleGVNZGNlRWRSaDBlUWNFZ3BoUGNhZ0FkeGZ6ZVhhRmZFZWtiTGZGaFpia2REYTNhVmhTY1FjSGZoaEdkUmd6Z0FnQmdBZ0RkTmFxYUhhVmV4ZUVoY2VIY2tnWWJHYkZhVWUvY0loamFZZVRmSWFSYmhic2dlaHdmUmRTZE5jMGE1ZlljR2FSZmtnZmFKaDJkNGg0ZFBiRGV0Y0djTWRsYzlhY2hHYkhnZGdEZENmM2hoZ0VjQ2QzZEJmYWJRaG1iOWNpYlplbWhrZlVmT2d3aGhkemRHZ0JjaGJOYVdna2JsZUhhVGJuaGRlMGVVYVhibGJyYmRoRmJGY0tiVGRuY1VmUmZjZDBmeGJSY2VlSGNCYVdhSWhFZmNjNWFIZFVkTmR4Z0NiRmFZaHZiVWZ6aDBnbGhKYUJnUmNjYmRiaWdKY1pkRmJnZlFoYWdlaERnTWEyZUdmQ2ZjYUVoSWEzZmtmZmRXYTNmRmZjaFhiZ2c1ZmNhQmJTZ2RndWJOZURjWWcyZkNnU2JsYVNlRWVnYjRmZ2dEYkZhWWZYZUZoZ2hzYThnSGV3aHdkb2dOZGlkNWNyZkhkV2FsZGtmY2d4YkJkTWNUaFZjRmZKZkZkVWg0ZTBjWGhoaGhjd2ZRZFhoUmJSYlNja2Q1ZzFjVmV5Z1ljQ2dFaGlkd2U1Y0diVGRvaFBjQmIxZHBjQWJmaFVmWmZCZGRhRmRNZ0dhYWVHYW9nV2FGZFJnTWMvZkJoMWhrY2VjR2EzZm9kY2hUaGtjRmN1ZVNibWFSZjVhU2J4ZVJkeGJIZFJoMGdFaFhoMWNaYzhhYmR6ZWhoOWdKYWhmVWdGZVFmMWZRZEtoTWRCY2dnWWdCaGtmMGdDYldmbGZwYkNnYmIyaEpkbWZhY1JnUmN5ZlRibmdNZlFnVGdCZGtmWmZHYzFmb2haY2FlVGZwZ2RoSmIwYUVmQWRDZUJnb2ZMY0ViRWdNZmhhQWJ3YU5ld2VkZDFmUWQyZVdlaWMwZVVkVWJTYk5oRWhFaHpha2ZCYUNkRGNFYm5lRmRsZWRoSGZjZ0VhWWdNaEJiVWdaYzZmQmhTY0ZlQmFMZDBmb2FHY0xhQWcxY1NmTmJFZjhiZGdCYkZhY2dGaElhQ2g4YTRlTWNDZHBhQmJiYmdiMGQ0Z1RhSGZWZktkRWFGYUpjRWdDYzNjQmRhZFFhaWdZYWtkWmVtY0ZlR2RjY2xoQmd6Y1hnMGJ3ZFJjRGNVY2xlZGZUZW5kZGUwY1NobmFsZHJkZGNGZkZlS2JUY25lVWFSYmNlMGd4aFJhZWhIZ0JiV2ZJaEVkY2E1YkhiVWFOZHhkQ2VGZFlodmVVZ3poMGZsYkpkQmVSYmNkZGRpZEpjWmVGYmdmUWFhZ2ZlVWFVYXlhQWFDZkliZmFJZ1hkdGdMZFZjU2ZOaGFnU2VBZUJnY2ZHZ0NhQmF1YVBheWNCY3ZhQ2NUZEpiQ2ZFYWdlTWF6Z1NhbGJJYmRkRWRVZVVmMGJDYVVmVmZtY2VkVWZ4YnBjRmhIY0phT2NjYnhkQmRNY1RoVmFGZEpoWGhBZWhhcGNmZEZlRmJ3Z1NmbmhRZVVoU2RsZUJoMWRSZlhlMGVBaEZlRGRZZDNiQWVqZHdoR2hhYXdmWmhjZElkd2NsZ0VjZWJCaDBoS2dNYTJlb2RoZldiRmgwYzNmVGZqZHdoRWFRZURoVWRWYmJjRWdNYkhoQmRDYUFlOGJFZXhlUWcrYVNhRWVsaE5mVmRoYkJkMGVQY0RnY2Y5YUtlQWROYWxhSGh3ZGxjbWZkYlVmb2RRYVVla2RRaExkY2JGZm9nZmFSZldmSmNtY2FoUmZSYnllVGhuYk1hUWRDaGhlZ2NmZUNma2FFZEhmSmFqZW9hWWRIYzBja2JnZ1hlVWZvZmNlZWFSYUVoNmZRZ0ZlRWg5ZmVnVmRZYXZkSmhXZXRnU2JGZ0hmRmNHZ0ViM2FoZFRkVGgyaFJoNmVVZ3doY2RUZklkZ2F0ZWZiVWhCZEpoeWRGZVdjUmhjYWJkbGR4YXhnYmhGZWdkQmdjZFJlWWhkYkhheGVsZGRiZGRIaDloL2hhZkVkVmZHYlpkeGNZY1NnVGhIZ1ZjS2ZFYkZjSmJFY1RnVGM4ZklmUWZtZ2NlMGRKYXphc2FVY1BkVWg1ZHVhRWVGZ3hiQmNVZFFjRWVWZVVmMmNrY1poV2RTZlFnSmVlYmhhd2dEaEFkSGQxZ0ZoZmNRYUFiVWdOZGpoY2dDZlBlQWU5Y21lVWJsZTFhOWFSZ2diRmJ4YVNmRWg4ZHNnYWZrYjBiWmFYYkdhc2JMYVVkbGExYmRhY2QyZjFha2RRYVdmNWJLY1pnSGZsaExmRmZIZ0VjZGFIYlVnMWhOZ0xhVGExaHVkZmVYYk1mZ2hPZjJiY2NMYU9oRWZ4ZjFnU2doZEJnU2hSYUFkdGJ3YVdla2RKZ3ZlWWZtZlpocGVIZkNkQmhPZWRoUmVCZUVjWGYwYVJmY2VGZ1ZiSmQxY2RhQmVCZG9jUWZYYzVkUmdRZGdhdGYxYURibmNNZkRoVWhXYUpnd2dSZDNlUWZDZ2FjeGEwZGRiZWNFZDhjYWhlZEVlMWJSY2VjbWFwYmJjQWNSZ05oNmJDZjFlRWRUY0VnbWRWZkhkS2cwYkZnMGJTZm5nVmY1ZFJmaGVRZStmRmNCYlJiV2hNaDFhWmgwYWJhbmdaZXpmYmgwZ1phbmJTZnpoaGdNYWRlVWRvYVFiVWRrZFFjTGVjaEJid2hYZklhU2NFZnljSWhGYXNnOGJUZWhiMGhZZ0dmRWVGZlJnR2F4YmxjT2NJZ0hlZ2ZZaE5mVWZoZzBkQ2ZtZkJjT2FkY1JiRmh6aFRnRmhGZTRlY2FGZVpmMGdIYzJhdGRNZEZlQ2dOZEdoRmFYZDVnVGVSYXpkWmZxYVRkaGVrZkhiWWVoYkpoTmdUaHdkUmh0aFZmWGExaFVmYmFrY0Zla2VLaDBhc2VmZGNlUWd3Y1VkVmRqZk5iV2RkaEdlNWMyaGNnMmY5aEdkWmd4aFloU2RDYmpmb2JZZEVjRmJvYlNnU2JpZ0pmYWZEYldhOWIvZFpmbmZrZVllY2NnZlphemZEZlVhd2VnYkVoQmcxZ2RmUWNDYlFoOWZWaG5kZ2VWZWVoaGYwaFBmQWdEZEplRmhPZjBleGhjaGVnRGJsaGFhZGhCZ3RhaWFTYVJoUWc1Z1JoZ2UxaDRlSGRGaFJna2ZZaFZjaGdXYUdnbGFvZ0xmV2VWYlllU2hlY2tiZGRrZFFkV2I1YUtiWmZIZmthZmZiZXpmZ2JkZUZka2cxY1dhS2QzZlJjemRkZ25ic2c5YlJjbmVrZElhRGhFZHhkOWFVY2hhQmJZY1JlQWRNYzFkV2JsZzFkdmVMaFdkWmV6YUZjR2VGZE9mZmhoYUFlRGZSZkZlaGZBY0ZiVWhoZ3BiWmJnZTFibGFXYmxoNWhSYVNka2g1ZTFoRWJYZE5kTWFVZFNmVmdhaFZobmZRZ1BhYWgxZkljVWNjZ1ViWmRWaExjUmEwYk1oTWNDaE1jY2NWaHhmTWZVYkFjd2UxZmFmRWZpZ2hjTGRaZUFiaGdpaFNjaWNGZXdnU2EwYzllYmRIYVJkMWhOYUdiVmVaYjBjYmJuaFpiemNiYXdnOGNoZUZnaGZvYkZmZGhVYkVoUWJGYTBnUWZWZWNkQWc1ZU1hSWN5ZGNob2ZMY2tiQWE2YlJiM2VOZUVjQmFCZjhmZWVIY2hlVWZBZkxhQ2JNZVliQWVnZ0FjNmhGZmdjOGdyZUpmMGdNZjhmSGVsZWxiNmJHZ1JjZ2F3Z1NiamFOYlNnV2N5ZVFkU2JFZHplY2dWY1RjemRZY3JkSGNWZzVmV2NjYWdlSmhDaGZnQmFKYjZnUmYyY1JhQmViZWtocGFraGVnVWV0aGRoTmZ4ZjBlVmhYZVJmbGNJZmRjQ2RkaC9mY2F6aHNjT2ROZFZhbGJGZFRiRGZzZlBjUmMxZklmMmFTZmpoNGdkZkJkd2ZvZXdnTmZDaFpoR2ZlZ2tld2VhYlhkZ2ZnYklnQ2dVYWxlYWZHZHpoMWYwYVZjemNaYUJiSmFoZ0FiRWRDY1RnQWVUaGVkbGVkZzdnZWZIZUJiV2FkZEFoOWJyY1VjaGNRZnNjYmRCZ05nNGZVaDBiOWZrYWFlbGNNZFpkVmdTY1ZiRmZHY2djSmNiaE5kUWRsY2tmQ2VtYlljZWhhaEhka2RaZEdhSGZGYVVjRWVVZzFnY2RXZ25oUWZoZmZiM2dNYjBhYmRHZ2NiV2JFYmtjeGIxY1NoaGJCZVNkUmNBaHNhaWFIaHhhWWU2Yk1oQ2NoZnBmSGhGYWhoT2RjZ3hnQmZNYVRnVmJGY0pmRmRVYTVlcGhkZ0JmZ2UvYlFoU2VnZU5hU2JpYnBjOWhSaFhjOWJNYUFmM2ZSYndoSGMzZ2dhUGFmYzFlNGdVYVlka2ZnaEhlYWdFZkZoWGJkYW5jbGJIZ0Rjd2dWaGplRWYwZXhmRWFDZG1iSmdSZUlhVmhKZjJhUmNtZVJiMGFXZEJmcGJsYkRkUWg5aFZjQ2QwZ1ZmZ2FlYUdiQmRnZmRnMWVOZjFoRGZnY3BjYWVNZ0Zoa2dJZldmMGNnZ2hjY2VGYnBmQ2NiYjJjSmRtY2FkUmZSYXliVGJuY01jUWRPYTBiTWJHZkdhMWV3Y2FmTGZIZHhjTWdmaEVmRWVtZVhnVWRvYUhnZWRSY0ViMmdRYUZiRmhxZVloMWZwZzBkR2QyaEpnZWdQYW5hRmVHY0VjM2VoYVRiVGIyZlJhcWVVYXhja2ZUaGNiRWhKaFpmWGhSZUpidWdiZVdlUmdCaGJia2ZwY2tjZWdVYnNlVWdjYlJjMGNVaFZiamNOZ1dlZGhHYTVlMmVjYjJmOWdHYVpmMGZzYjRoVGZIY1ZoS2RFZkZlSmFFYUNkM2NBYmNnRmh5aEVoaGJNZWlhQmViZlBiRWQ0aDVmR2NCYmhhQmJVYlJoc2RaZFRmaWVCZzRjR2NEZFZoTmRkYUJkNWFEYlRiaWg0ZDdoY2IwaHhnUmhlYUhnQmhXZmRoQWc5ZHJoVWVrZFlkMGZFY2tnWWdxZEhoVWI5YnNoUWhGZk1mWmNFYTNoQWZMYldmVmJZZVNjZWZrZGRka2ZRYlNiRmFLaE9iQ2NWZkxlY2JIYmxiSmVFZ1VhMWFMZFdhbmJRZG5jZWFuZU5hM2dTYm1jY2NIZEhjRmN0YXNjWGNRYlphTGVWY3hkcGFqYVRhbGRwZDVhY2VIYlZlNGVBZFdmVWRMZFliQWFCZFVjUWhWYkZkRWNCZEVoQmYrYWJnUWQ5ZW1oV2dHZmRoQWZXYVZjcGN0YkJjMmdGZGZoUWRHZDFlbmdFYjJmY2ZmYmNhMWRzZlljV2IwZ1liVGJlZ0ZoTmJQYlpiR2JwZlRoR2ZSZU5od2JDZHlkNWRZYVJlU2FnYk9mTWhBZVJobWdIZ21oaGI1ZkdnUmJoYXhoVmNCY0ZoTmNYZkZmcGIwY2VnMmFSYy9nYmQxYTVidWNHZ2pkaGNNYmRmVWZvYlFjVWJrYlFoTGVjaEZlcGhDYmJoMmRJZ3ZnYWhSYjloeWdWaGxia2hRZFRmRWMxY1JnU2RSZlZlT2JhYVhiUWFZZmVlVmVwZWViVWFVZHBhT2FkZVJmRmd6YlRoRmhFaGxiV2hsYVpoMGJEZzJndGZTZ0ZmSGVGZ0doVmNTZDBmZGNEZ0RjQWRqaEhnRmZjYlRhRmRnaE1lTmVYZXhiSWdoaGJjV2FSZEJmYmVrZ3Bla2RlZlVic2NVYmNkUmcxaFVnQ2Z4Y2xiZWJmZkdkWWZpZmNoM2ZKaEdkTmZoYzVkR2dSaFhjc2dZZlZkUWJJYkllU2JqZ01oZmVTaGplMGcyZmFhbWFrZ1dnY2JFYWRkNmhIZUVhd2daZVhkd2dWYlFmQWJDZzRmZ2VVYkhjQmZkZmRhRWFOYURiUmgzY1ZoRGhOZ2hlZ2RFYktkamg1YVdnZGVnYjFmd2ZlZkJkUmJ4YVJiaGROZDRjVWUwZDlha2VhZmxkTmFmZ1hhQ2NJYkxmVWJVaDBoU2RMZmtja2ZvZkJnQ2RBYk5iTWNEaEZhTGFFYlhoRWhKY0hoVWd3YkVoU2YzZlJmK2NiaFhhTmNtYlJmamRNYldoR2VWZUZmMWNTY0FjMWNRY1hheWZGaHdoV2FrZEpidmFZY21lWmdwZ0ZiSGVKZ09mSWJWY1VhWWZHY0FlTWZIY0ZiUmFwY3lmWGNoYmhhd2hRYlhmUmJSZVNka2c1YjFoVGVGY2xhTWZVYlhiaGF3YVZkbmFRZ1BnYWN4ZlJkQmZQY3dmVmdIYk1mUmR3YkJhWmFEYnRmYmNUZVJlcGJ3ZVVkSGZOZldiRWRuZnBkSGdaZ0VkRmh1ZVNmbWZSYTVhR2hWZ0VibGRTZUVoOGVEYkdmUWRKZjZkT2JpZlFlNmFJYmtnWmY0aEZja2daZUNkSWJSZmhnWmRIYzBnd2RDZGNiRWRCZkNnT2MyaHdkMGhMYUViUWQrZERhemhCZFZkUmRFZElldmNOY1VkWmdGYU5nUWJoYkxnZWMwYlZkd2dYZmdiMWhDY2RlUmNOZHhoUmhVZHBiU2RjYUZmWmYwZURnMmJ0YlNmRmZIZEVlYmdPZlhoaGZUYlRnMmVSZ3FjVWd4Z2toVGNOZmxnNGdYY0ZhVWZZZXpnQ2JDZHBmQmdGZWtoSWd3ZmNmRWN0YlBmV2Z4ZTBmZGNUYlJmbGhXYWRiR2M1ZTJkY2IyYjhjVWNJY2thSmVIaEhiamd0Y0tnQWdVYVJmRWRGaFhoQWFPZFFhbmRCZWloWmJIZGtjV2ZjaGtlVmh6Z1JoRWZJaFpkSGVqYXBjQmdIYkNjQWY2ZVhnM2VoZlFlWWNsYWhjS2JWZEhhVmdGZGZhUmJnY2VlQ2J5Z1FnRWdQZ1VnRWRzZVdmZ2ZWYW5hVGR3ZWhnU2dVZDBjOWdrYWFmbGNNYlpoRWMzZkJkV2FjZDFlWWNTZGVla2NkY2tmUWNXZzVlS2VJYmlmd2ZGY1ZoeWJWZFVoVWdnZU1nWmZQZW5md2g2Z2VlbmRNaDliVGEyaGRiTmVPZ0VkeGUxYVNhaGFCaFNiUmdBYXRid2NXZmtnSWE5Yllobmh0YnBlUmNuZ0liU2dMZ3hlQmhkYVRnVmQ1YkphQmFWYlZmRGNkYkJjaGZ3Z1FmWGhSZ1JhU2NrZDVjMWFFaFRnVWNEYUFjM2FoZDRjQWVEZ1ZjZGFhY3hmc2VZZ2NhUWNNYVRjWmZWZU1kYmZhaGliWWNXYlZjMWhRZ2thUWUxYlZlV2dYYVhlcGJhZlphQWE4YTdkQmVpY2hkMWNTZTFjeGF4YUFoQmQwZjJjWmVGZ3BjMGZJZUhnWmd1Z2JjMWFaaDhkRmNsZGRmTWNhYjBlcGZlZVNnVWdRZ0FiZWd4YVJhTGdiYXplbGZNaGFmUmdSaHlnVGZuY01lUWNUYkVkMWFSZFNlUmJWZ09lSWNEaEllWWVlYkVlbGI4ZkdoRWRwZlRjZGNVYlZnOWVEY3hja2I1YUlhamFVZzdkU2V5ZjRhemhRaEhja2dJZ0dibmNGY2ZlVGN5YTFmcWdUZlJja2ZHaFpiUmRsZUFmUWh4Z0pnOGVRYldnUmFVaGViVmdsZHdkYmhVaHNoS2hjZFZjUWZVZVJnQmRrZU5oWGJtYzVkMmFjYjJoOWRHZ1pkeGNZZFNhVGJIZ1ZhS2ZFaEZiSmRFZFFhamRaZmFoU2JtZDRndGdiZzJobGZQY1dhRWE1Z3pjRWVFZXhiTmFVZFVoa2FWYVRhbWRsYjBnR2FIZkJoQmdkaEZjRWdEYkNlSGFVZFpnT2hrZHhlUGhlY0dmVmdBYVpleGM1ZHllV2V4Y1FmcWRiZEJlTmc0aFVoMGI5ZWtmYWdsYU1kWmRFZzNkQWJMZldiVmFZZlNiZWRrZWRma2JRZldiWWRZZVpiSGVSYldjRmVHYUlkVWdIZ1ZoTWFaZldkMmdWZHVmY2VIY1ZidmFEZW1hbGVHZVJkeGg4YTlmUWhnYkpiQmdYZFFmZGd3YlNoMWN0ZithYmFtY1poNGFEZ0didGRIaGFnRGRwYk1nVGdWZEZnSmVGaFVlNWZwY2RkQmVoYXdoUWdYZlJmUmdTaGtlNWcxZ0VkWGJNZFBmSGZqZVlla2FIYXphcGVhZ0xha2RrZStlY2ZVYllkVGdlZEZlTmRQaFpkR2JwaFRjR2ZSZE5hd2JDYzFibGZXaEVkaWRkZ3RkWmRFYUZodWRTZW1lUmY1ZVNmeGNSY3hoSGVSYjFlTmJHYlZmWmcwZWJoamU4YzFkYmcwYzRlcGNGYWhmbGRNZ1pmRWVvZE5jVGQxYmtnTGdOZlZmTmFDZk5kRWhoZ21jYWhSZVJkeWJUZW5iTWZRYVRiRWExZVJoU2hSY1ZlT2ZhZVhkUWdZZmNmRWNGYzhjQWYwZHBhRGFhYkJhRmNnYlJlVmVGZW1lY2NGaHRjbGhEZTJoMWJVZkZhRGdsaEliUWh5YzBmQWJCYjJkeGQ0ZlFmQWdBZGZhY2hCZXBoQWVSYXhlNWc2aFZmbmd4Z1lnWmQxYUZnT2ZlYVVnc2dVaGNlUmUwaGRjVGRSZWxmV2ZkYUdmNWcyaGNlMmE5aEdiWmF4aFljU2NEYnpob2ZFZlJlQmNzZEtiWGNqZ1ZjQmVhaEdjOWJpZFpibWZrYVVhY2ZrZDVmemZFY0VmeGdOYlVjVWhrZVZiVGNtZGthcGdNZm5hQmNCY2RkRmhGaEtoVGFuaFVkUmFjZzBmeGNSYWVoSGVCZVdnZGRBYzhka2dVZmdkbGV4ZERkd2ZoYlNlVWgwYzlna2ZhaGxlTWFaYUVmM2FBZ0xiV2NWZVloU2dlZWtkZGRrZ1FjU2MwZUZoS2JpZzBiQ2NXYmlnUmVZZEJobWNjaFpjVmNuaFJidWNkZW5oTmV2aFJhbWZjZVdlRWZrZnhoMWZTY2thMWY0ZlJjQWJ0Z3diV2RrZ0pjdmZZYW1oWmJwZEZhSGRKYk9kY2J4Z0FmRmdDZTFjRmhCY0FlRmRoZDZlWmhnYmhid2hYZTNmUWhZZlFkMGg0YXVnT2czZk5oTWNVYlhlaGN3YlZlbmJRaFBmYWIxZ0liVWZjYVVnWWNUZ2VlRmVOaEhjTmNtY3BmZWJCaEJmTmFqZ0FlbGdsY0lkRWduY2RiV2ZaZkVjZGZvaFNiaWF4YjNhR2YwY0VlaWdWaFJoVmJmY0Nma2E5YzRmYmRtYmRicWJmZWticGVuZUJld2NwY1ZmZmNFZllkUWhXZ2dlc2RMZmJlVmNvYkxiWmNuZGxjTWVhYlJjUmN5ZFRnbmVNZFFmVGFFYzFjUmdTaFJoVmJPY2FkWGZRZVllY2hBZ0ljN2NIZHhkNGhIZk9nMGNRZTJoVmMzY3RnNGFjZ0ZhWmYwY0RjMmJ0Z1NiRmdIYkZlR2RFZTNmaGFUaFRoemdsYUFiVWV4ZWtjVGZjY0FkdGJaZVZiaGJKZzZjUmQyZ1JmQmFiZWtlb2F0aGVhVmNZYVVoZWVSZFVlVmJBYmhnbGJiZWRmSGJ0ZWplWWNYYVphUWViZmhhWWRPaFVjSGhWZmJiQWJGZnRjRWNWaDNiQmZTYkNiMmU5Z3ZmWmNuYXdkQ2dZZVZneGRqZkdlVWRWZE5mV2VrZWtoRGJXYzNleGduY0RjbWd0aHJoZGZGZEZnS2RUZG5kVWFSZmNlMGR4YVJiZWNIY0JhV2ZLYVFoOGd1ZUhha2NjZzBlUmJsY3hhNGFWZVVibGdrZFliZ2ZFaFpnSGhtaDBjTGdTYmxhOGRTYVpmRWNkaHBmVWZHZzVmTWVZZG5ka2hEZ0djaWhGYUliVGFnYlVjUmZSZUdhZGgzYmVkbmZOYStjWGIzYllmYWFFY2xnMWd0YlVieGhsaEpkYmNnZHRid2hXY2tnSmZ2ZVlkbWdaYXBjRmJIZUpoT2NjZDFja2VLZ1RiVmNsZkJhSGJRZEZncGJhZVJmZ2MrZkZiRGdnYWRkUWgwaEpmMWVBZ0djRmFVZ1VmV2FaZndhSGQzZzBhR2JhaHdja2UrZmNhVWhZYlRmZWFGZE5nUGhaZEdocGhUY0diUmFOZndiQ2YxZWtkZmZWZ0hhcGdQYWJiQmhOYXVmUmUzYmxiNWRXZmhmMWd4aEFlUmQxZmRmRWVGZ1lhMmZQZERjTWN5ZUpoRmQxaE5nRmNoZ0plTWNkYVVhb2dRZ1Vja2FRZUxjY2NGZHBoQ2NiYTJlSWh1ZlpkMGVRYW5jSGNUY3NjWWZCYVVkUmRLY1lneGhWYU9kYWZYZ1FkWWRjaEVhRmMwZlVmVWhwZk9mZGhVZXhlemVDZVJnMGFyYU5lVmhZZzliU2VXZHRkYWFCYm1hRmhTYUNkM2doaE5nVGR5ZDFnamZVZzBjSWg1aGNjQWZ0Z1poVmRoZ0poNmNSYzJkUmVCZ2Joa2VwY2tmZWdVZ3RnZGJOYXhhMGFWZlJjVWN0ZVdoZWJYY05lMmdZY1dmWmFHaGVmeGVZY0NiUmZYYlVlSWZRYWhmY2JGZlFnR2Z0ZXdjUWVtZDloaWFaZ21la2JVZmNna2U1Y3piRWNFYXhhTmRVYlVmbGhkYVFiRGZrY2hiU2F6ZGhiSmVmYkJiaGFLYVVnR2NzZlJjWmJVYVZoUmNKZEhlQmFIZmJiUmMxZ25mVWFoYnhkbmNWaFJiTmcrZVVmd2VaZXRkYWFnZThjWmJBYm1mSWJUY1VlRWUwZjRmZWFrZmRha2FRaFdoNWFLZlpoSGFsYkxhRmVIYUVoZGRRZ0VhMWRjZkdhaWhjYnJmZGNqZm9ncGZSY21hOGRBZUJlMWFsY21mWGJCY0JlTWJSZEVkSmI1ZldjaGRsY0ZiWWVtZFpkcGRGZkhjSmZPZGNmeGJCY01mVGZWYUZiSmhGY1VnNGhnZE1jaGRoaDRlU2hTaFpmUmFSYjFhTmcxaEFjbmVwZE1hVGdYZGhiZ2NYZTNlUmVOZE9jUmJkY1ZoT2hsZjBkNWRlYkZoTmhQZFpkR2RwZVRnR2dSZ05md2ZDYTFjbGZXaEVobmVvYVBiYWRoZEVlN2FHaFNneGV4YVFiMWQxZnhhQWd3YU5kTmZDZkViUmI5ZWJjaWVwZ3phZmZWYlJmemdHZmhnSmNFYmZiUWVNZlFoVGhGZm9lTGFaYmxmTmhDY2FlV2VKZXdnZWFoaDFheWhFaG5iTWJCZVhmbGNWaGRoU2hSZzFoWWRlaG5kUWhlaGNjQWhoZTllVWhSZFpoT2NaZkFlTmRyYVJnVWZwZ1NnY2VGaFpnMGREYjJhdGFTZ0ZjSGFGZUdnRWgzYmhnVGFFYm1kUWR2YkhjMGFwZVdmY2JGZ0JhemVWZGhnSmU2ZVJnMmFSZEJjYmdrY3Bla2hlaFVlc2VVaGNnUmUxaFVjQ2N4aGxjZWhkYldlWmZuYVlkbmI1aFNhZGJnY2NoQWVUY0didGJLZldnVmZ0Y05mQ2J5Y1FkU2FFZUNhQWIxY1pmaWJkZlJiSmhVYzRkV2JRZmhkNGRDYUFkMGNFZ1hhSmh5YWNmaWVXZVRkd2JJZk1lRmdFZkpkQWJUY0ZlVWRjZ3hod2FlaE1nVGU0aENnZGhnYlpmd2VlY0JjUmd4aFJhaGFOZDRoVWMwZDlla2NhaGxmTWJaZ0VoM2FBaExlRWFCY0FhU2ZjZ2tnOGQyYlFiV2VOYlhjWmNHYTFmQ2dGZ0dkMGdkYkRkVWRRZFpoRmZDZlllcmZOZ3plaGYwYmJlR2FjZldhRWZraHhjMWFTYmhlQmVTZ1JhQWF0YndhV2VrYkpodmFLYW1jZ2Y1Y1FhU2VFYUdnZWd6aHBlTWFUZFZiRmVKZ0ZkVWY1Y3BlZGZCYmhod2FRaFhmUmNSY1Noa2U1YTFjR2hUYnBmTWhUaDJiWmN3Y1JjMmJ3Z0dlYWR3YzRnVWZZZzFkSWZEY2RmSGJsY1BhWmJHZXBiVGJHYVJoTmJ3YkNmMWFsaFdoRWhuaHBmSGhaZkVjRmV1Y1FlbWd3ZndiU2R3ZXBldmdIaFFheGVmYkViRmVaYnliYmhtZUJoZ2NaZGthWWM3YUZnZ2hOZGViYmVVZ1lmNmhVZmtmUWNMY2NhRmJwY0NhYmgyZkpnbWhhZ1JjUmh5ZlRnbmVNY1FkVGJFYVZkWmRBZkJnVmVRYmRmM2FRZ09nZWVVYkZleWVVYVZheGJkZGZjQmFFZXZhVGZFZEJicWJhYkZocGJlYkRnMmh0YVNoRmhIY0ZmR2JFYTNlaGVUaFRnMmNSZnFlVWJ4YmthVGZjZ0FhTmhQYlJlUmVKZThjUmN5ZDFlSWViZWhnWmNrZGFkRmNrZk1kV2d4YzBnZGZUZ1JkbGNXZGRmR2E1aDJnY2EyZDloR2FaZnhhWWRTY1JjV2c1Y2dmRWVGYkplRWRDYTNlQmdhZFFkbWU5ZmlnWmNtZ2tnVWJMYjJmUmJ6YUVlRWJ4Z05jVWhVYWtkVmVUZ21ibGcwZFJkVmJwYUJoZGdGYUZjS2FUZm5jVWhSZmNmMGd4ZlJnS2NqYVViQ2ZJZVZnMGJsZ1VlbGJ4ZXFiYmRCaE5kNGJVZzBhOWdrYWFmbGVNZlpiVGNsZ29nTGdXZVZjWWhTZmVna2hkYWtmUWhTZmdoZmdLaGpob2FmYlhjVGU1aFRoSGFUZnNiUmJBZm5nMWZ1ZkxmVmdsaHZiUmhtaGNiV2NFaGtjeGYxZ1NnaGZCaFNnQWdrZ1FhaWZXYmtmb2I1YkliemRSZnBoUmNuY0poVGRjZTJkc2h4aFFhVmNFZUFiRmhWaE5ncGRaY0FnTmd3YUNjSGhSZk5mU2doZnBhN2hYYVRkWWVDaEZiaWh3ZTRoVGVYY1FnRWJZZUJlc2dkZldkMGZZaFRkZWdGZU5jUGdaYUdicGNUZEdnUmdOYndnQ2d3ZnRhWWJRZGliOGVVZkxlRWVsaDhiWGEzY0ZmNWZUZVJjUWRsYkVlMWY0Z0ZnV2JBYlFnWGJJaFRiSWMyYkRjaGJKYnZoWGR4ZnRkRmNiZG1nQWFRYlVna2FRZkxhY2dGZXBjQ2ViZzJhSmJtZU9kMWJFY21nR2J5ZkZnZWVUYUJnOWRLY1lkeGVWY09kYWZYYlFlWWJjY0VkRmQwZURoR2FCYk9iZGhSZEZoemhUY0ZoRmE0YWNlQmJBZ2hiUWNTY2dmR2ZYZ1RkNGhJYkVkeGZKYmJlR2YyYWhjcWdBZlJmQWJUYUtjeWNGaFphVmVoZEpiNmRSYTJoUmFCZGJia2JwYmtjUGN3aFJkR2hjZVJhVmhMZURiRWV0ZldlUGVXZUpjMmZOaG1kTmNHZEtiQmNvYlNnQmJIZFZkWGFFYkNia2M1Z0JiM2FBZ1VnUWJuYUpkaWVkYm5jSWJVZ1BmRWg1aHZiRWZCZWhnRGhIaFFheGViY0NnVGQwYzhkR2ZIZ1plSGJkZUZiQmJDZFJhaWFjZlJlZmVsYUZjUmRhY25jbGZXaGFlQWg5YTdhV2F3YjlleGhUYVJiZ2gyZFdjbWJWZWtjYWJsZU1iWmRFZzNiQWZMZldlVmVZZlNiZWFrY2Roc2JDZkdnNWNYYlpkQ2MxYUZnVmh6ZWxoY2hUYXllNWRXY0VjamJFZ1BoSWduZ3NoaGRUZTJiNGdhaE9iRWd4ZjFlU2RoZUJoU2ZSY0FodGZ3Z1dja2RKY3ZlWWFtZlpkcGZIaERmZGZPYmJmaGRBY0ZhVGZVYzlkWGZGYlZhWmhnZ2VlRGhKYXdmUWhYZlJhUmRTYWtlNWgxZEVhWGVOYU1oVWdYZGhod2FWZW5leGVBZWFhMGE4YVVmT2VFYVlmV2dlYUViRmZhZWNkbWdOaGZhTWJ4YU5kd2RDZDFobGVXZEVlbmNwYUhjWmdFYkZidWZTYW1hUmY1ZkFleGVvZWhkU2JFZTRmRmFFZVJhbGY5ZlljbGF4ZXplYmEwaFpobmJGYWhnSmVNYWRlVWVvZFFnVWRrZ1FhTGFjZUJnSmdNYVBjemNjZTFnSWVSY3djM2RSZTJnZ2Q2ZVRmRWgxZFJkU2RSZFZlT2hhZlhnUWhZZWNhQmVNYXhoQmNSZzhoY2NPZ3hkRWU3YVZiM2Z0aDRmY2dGYlpoMGFEYTJidGNTYUZoQ2Z4Z3NjRWUzY2hmVGRUZzJoUmNxZVVjeGRsY1ZoSmhVaFVmYWRBY2xjc2ExY0NiV2RRYzdnWmNoYzVndGNlZFJoQWgrZmNnUmUwaGRoVGdSYmxjV2VkZ0djNWIyZmNmemIwZ0RmTWYwYk5iQWNBZm5mVWY3YkhmZ2FZaExlYWRTZmtkT2FCZndhNGZ3Y05hQ2NoZ05oZWZpZmhkN2hSYUVlVmhFYVNjbWRNYlZoVGhtY2xmMGNHZUhoQmdCaGRiQWN4ZGdkVGduYVVkUmdjYTBmeGFSZ2VkSGJBY1FiSWdVZkVkb2NCZ2xlMGMraENoQmdNZWZkV2R4YXRib2FhZWdlRWhWYUVjemNrZ0hhV2FSaE1mYmZlYmhleGhPZVFkV2g1ZkthWmVIaGxoTGVGZ0hoRWVkYkhnUWR0ZFdnQmJIZVJhbWRJaERhSWc5Z1JnaWdnZ1dnRGgwaHhmbGhVZFJjQWJYaFJnQmRWaHdlRmdVZEphcGNaZ0dmWmZvZ0hjRGgxZk9lZWhCZEFjRmRUZVVlOWRVZkZlUmN4Z25mT2VGYTBjK2JCZGlkQWNaZVNlaGhJYnBlRWNUaHhjTWhUYzJnVmN3ZUFkbmNwZURjTGdoYXhkVGZKZVFjNGFhZFlkMWFOaEVnYmR5YlZiYWVNZXhjTmF3Y0NjMWVsZFdmRWduYXBjSGFaZUVkRmR1YlNnamRZYkNlQmFCYlJjNmdIZ1ZnUWJ3aEdhVWR0YjBhT2hnaDBiOGFFZWxjMWJOY0ZnaGVKZk1mZGdVZm9kUWdVZGtjUWJMZWNlQWdnYkhkT2N6ZWNlMGNKZnhhUWU5YlZoVmVrYVFhVGJFZjFoUmFTZVJmVmNPZGFjU2FrZnliY2hFZEZnMGFVaFVocGNPZ2RiUmhFYjFjR2hSZDhkN2hKYUJoOGQ3ZFFhV2hzYzVkSGhDZFZhUGhFYXlhTmQ1ZVRjMmFSZnFiVWJ4Y2tkVGRjYkFhdGRaYVZoa2hBZi9nRWR6ZkVlVGhJYkVkb2d3Z2VjVWhvZ0piYmZCZDFkSmVWZGpiTmRXaGRnR2E1YjJjY2IyaDlkR2daZTBhc2U0Z1RhSGFWY0tnRWNGY0piRWRDaDNkQWNNY0FiemMxZGljRmUyZWtoSmdjZGdjZGc3ZUJkVWZWZEJiZWYwZGtlVmNUYm1jbGgwaEdhSGVCYkJoZGNGZEVjOWNUZm1jZ2NSZE9ma2dSZEhhY2FYY3hoOGZkYUFoOWFyZlViaGRSZXhhUmhoZE5oNGZVZTBodGNnaGFia2c0ZFpmV2RuZ2dkY2FVY0VjMGY0YWVja2VkZmtlUWJXZDVoS2daZUhjbGFEZFJkbmQ5Yi9iU2NBYnRoZmRFaHliWmZ1aGFiM2RNYWhiVGYyZXNhOGJFZmtmeGExYlNmaGhCY1NnUmFBZXRld2hXZ2thb2c5ZWJjQmNVZWxoV2F5ZlVnc2hKYmxnWWZLZUNmQWNOZUpjQ2FFaDRmV2hmaFJiUmdhZlFhWGFSZFJiU2VrZjVjMWZFZFhiTmRNaFVkWGJBZ2lmV2FCYTFhaGJHaENjSmR4aEVhamVKaHNmRmJUZ0lmM2JHZHdhZ2NxY2JjWGRZZkRlQ2QwZlJoV2RCZTJjcGJPYWFmR2F0ZHVlU2FtZ1JmNWhTYnhjUmJ4ZUhlUmQxY05lRWZSaGhlNmRHYWdoOGVEZkNiaWZJY1lkZGIyaEFiK2FGZURjTmN2aEllVGRGZzdkQWhEYVVkd2FHYjJlSmI3ZVFheGVSZ3lmVGJuZU1lUWhUZEVlMWhSZ1NnUmFWZk9oYWhTZEpmWGNPYVFmVmgwZ1FjVWFwY1BiYWNBZ3hnemVHZkZiOGVNZENnU2VZaFJlYWN4ZFFnemhaZ2dkTWZuZmFkZ2VjZ2dlT2RoZ1FkYWdQZ0dmdGhuYmNiQmVSZlpmQWdoZndiT2hQYWhoUWdrYUNlamVVYUZoQ2h6ZGxjMWhDYkdmSmN1aE9hR2drY21nR2V4YXdiQ2VjZjNiVmRHY0lhaGU0YWJkUmZYZWxnZ2dFZkZlSmhFZkNlM2RCZmFlUWFtYTllaWhaYW1nRmhHZmZnQWZVZWVkVWhSY1FiaGRGYUFjZGRTZUdmaWVGZTBnQmZYZkFnT2ZmY0ZnaGhEZVFkbGQ4Z1JmY2UwZnhiUmhlZ0hkQmFXY2RlQWE5YXJnV2FsYXBlL2VGZWxid2czaEhlemF3ZHRmTWZCZllmWmREYm5lQWNUY1NnRWY4aEFoY2UwZnRlT2JRY1dlNWRLZFplSGZsZUxkRmhIZkVoZGVIZlVhVmRYZVdoQWJzY3ZlSWV6YlFhaWVBZnlibGdDYUVkbGhGYTFkRGZFYVVhY2FCZTFoOGM1ZkZhUWV4YnZjYWdqYUpoZ2VGZ0NobGFrZWNleGVCYk1lVGJWZEZkSmhGZ1VjNWVwZGRhQmVoYndhRWN6Z0VjRmFIaHhjd2U3ZkVnWGdzZ1lmWGN3ZmNnUGRCYWllWmFBYVBkeGIxZnJmRGVrY1lmT2FlZ0JjMWVCZk5oRGdnZGNmVGNWYXdja2hVZ2doa2VUYUdlM2daZ0hhTWVGY3BoRWJTYm1nUmI1ZFNjeGRSYXhkSGFSYjFlTmRHYlFhdGI5YllobGd4aHpiYmEwZVpobmRGZWhkSmJNaGRhVWFvZlFnV2ZnY29kRmVOZGdhZ2NOYUlkbWJKYTdnYWJWY0libmVBY0RlQmRFYkJiUWdJY2ZlU2JSZTBoYWNaZ1hkUmdLZ2ZkRWFFZTloV2RFZG9jVmVYZXhkRmV6ZFRiRmRGZDRoY2FGYVpmMGZEYjJldGFTYkZnQ2VNaERiUmF5ZDBnQmdBaFdmUWY1Y1dkMWVkZUdlUGJFY2RmVmVWaGtiWmcyaFJlemhaZk5kYmJnYk5hdGVZZW1iRWJVZ2NiUmIwZWRlVGFSZ2xlV2FkYkdlNWcyZ0xmbWJaZktmVGZSZllhU2NUZEhhVmhLZkViRmFKZEVoQ2IzYUFlVWFUaEJoc2diZEZnZ2h4YndiRGZTZDhnQmRZY2lkMGMwZ0xiamZwaGdlUGVoYWthYmZhZWdjUmJCZWNhbGVkY2dmVGNuaFViUmhjYjBheGNSYmVhSGNCZVdoZGdBYzljcmRXZmhhd2EvaFNiRWRNZXFiSGhCY3NicmRQZ2dlcGNKZFZmbmY1YjBiSmhnZ1pjQWhOZlJjTWhyZVBkaGZGZEtiZWVYZmtjK2FYZFRmOWFKaEJhU2Z4YkxhQmREY1VlM2hlYkNnTWY5ZENlVGdOZlpiUmFoY1VjbGREZHhjbGJlZ2JnZ2F0Z3dmV2ZrZ0pmdmJZZm1nWmJwYkZoSGVKZE9oY2Z4Z2doQ2ZRY3lhNGEyZ1JiUmR3Z21hSWFGaGNoUGhQYm5mUmFNYlNjamdzZThjWGJ5Z2RjVWJNZ0Njb2JpYUZneWQwYUdmWmgzZmdoVWhjZFVnWWRUZGVjRmNOZ1BjWmVHaHBmVGVHZVJoTmd5ZlhoaGZjZ1NoVmR6Z3doT2hLaGdhUWdxY1NkR2hSYjRkVmFoZFFhbGFSYUVkMGNJZlZlaGJCZDBkSGFTYzhjK2dMaFFia2FyaEZlaGVSZktkWGIwZW9jUWFVZ2tiUWJMY2NkRmJwZkNoYmUyZ0pobWFhaFJjUmJ5YVBhU2VwaGRjRGVnZUloZGRSYjBiWWFlZExoRGVkZ1JiTmFSYUphMGNWYTBheGhrZ2RmUmFGYnpnVGVGYUZhNGhjZEZnWmgwYURmMmV0Y1NoRmFIZ0VoSWVhZkFhc2dLZUFkaWZZY2xnSGh4ZGRkQWZJZkVkNGNhZUhnMWdjZHBlT2RtaFJlY2RjZjFmZGZrYk5mMGJzY1NnZGN6ZGNkZGhUYlJnbGdXYmRlR2M1YzJmY2QyZzloR2VaZnhiWWFTZ1RhQmZvZEloV2NoZWNkSGNYZDNkNGNlYkJieWJraHJjS2FDYnhna2FJZUFnRWhqZVZlUmI0Y1poQ2VFY0ZoYmdRZ21la2VIZFFhVGMwYURiT2J4YjFhRWVIZFNjVmZVYU1jQWdVYlViS2gzZXhoV2dMYnloVmFyZFVnaGJSZnhiUmFoZk5lNGFVZDBjOWdrZ2FnbGRNaFpkRWgzZUFmTGJEYXhjZGZlZ0xjd2NKYitjUWJTY0FjZmNLZ0RmVmFIY1BjbmdFaGRjSGRVYzBjWmhWZ25mUmd1aGRibmVOZHZhUmhtZ2NnV2dFY2tid2IyZUJmVmg0Y1VkRGhVaHdmbGFDZ0FmTWd0ZkxoaWROaHpoRmNIZU5lZWhmYXphcGZNZFRiVmFGYkphRmFVZDVhcGZkaEJmaGR3ZlFiWGNSaFJnU2FoZ05jOGFHYkhoOWZtZlVmWGVoZ3dnVmRuZ1FhUGJhZzFiSWFVZ2NkVWQ1Y2RkZGdoY0ljRGhLaENkVWRRZ0dkUWg1ZXdlVGRRZndkWWdVZVNmNGdPZEtmd2g5Y3VlUWFqaEJlMWJTZDBiWmM5ZUhnVmRSZ0VkR2VRZjFoZWFiZ25oWmJ6ZmJoMGRaZ25kRmVoZEpoTWVkY1Vmb2NRZUFiQWFGZ2ZmSmFRZ2diTWdiZHpoZGJ1Z0plMGJFYStlQWduZThoUWVHY0VhRmhSZ0dmeGRsZU9iSWNIaDBmRGNXYmtnRmcwYVVmVWJwaE9hZGZSYUZlemdUY0ZjRWVsYmVnVmdwZGVmRGEyYnRoU2JGaEhlRmJHZ0ViM2ZoZVRhVGIyZndla2JYZVZlaGhmYVBhRWFRYWFhSWcxZXdhcGVCaGloSWJFY2JobGVkY2thUGd4ZjViYWVNYWtkbGhVZkFnbGZkaFdiZmVEZnBiL2hjZnpjUmZzZlpmeGdZYlNhVGVIYVZlS2dFZUZnSmhFZkNjM2ZCYWFoRWNDaG9jMmhNY3podGVhaGNlZ2NoYzdiWGdoZWtjQmVIZ1VnVWNWZkdobWFCZHZmTWduZUJlQmNkaEZnRmZLZFRobmRVYVJiY2UwZHdjTWNjaFhjeGU4Z2RlQWI5YnJiVWFoZlJieGFSZ2hkTmM0aFVmMGRjYnFnWmhCZ0pnVmhYYXplOWhJY0xkQmhoaEJhT2R3ZUVjaGNNZmlkSWdGZ01hM2NsZFdoRmVEaGRnSWJVZXdoNWZOYkhiemZzZGdiZGZuZ3NmN2JUZTJlZGdOaE9hRWZ4ZjFjU2FoYUJmU2NSZUFhdGh3Z1dja2hKZXZhWWFqZ1Flc2ZRYkNmY2VjY1BoUmNBZ0toUmRSZDhnY2dXZlFhSmVsYmRhRWJ4ZTVkV2JsZDVjUmJTYmtlNWgxYUVoWGNOZk1lVWhYZGhjd2VDZTNjMGNEZ1FkVmRJYlVnY2VVYlllVGVlYUZoTmJQYlpkR2VwZ2JiVmN4YjBkNWVXZkRnc2JEaFZoRGd3YkNkTmZrYUZiemdTZmliSWNzZkJjVmdjZ2xiVmdGZklkRGdHZ1ZmNGJnYVpoM2FZY29nUmhVYVpmbmhGZ2hoSmdNZmRjVWRvaFFmVWdrZVFlTGZjaEFlZ2FIZU9kemZjaDBjSmZ4ZlJjemRSYmpmMWNGaEFnQWRGZVJiVmZBaGhnT2hQaFhjUmJFZkxjRWJGZjFiQmVVZVFneGhQYUVlSWZSZkdlUmRjZytjTmRRYlJjOWRGYUVjRmRTZEZjSGdGY0djRWczZGhhVGJUYTJnUmdxZERmaGVBYmZjV2VnYXRhWmRWZGhnSmQ2ZVJjMmhSYUJnYmdrZnBoc2hOZDBoVmVYZ1BkbGRCZ05jRGJFZXNoVGJkYkhnTmUyYk5nVGFvZ0lkSmdFZ0poYmJBZ3pmdGVLZ0dnQWNaYUlnQ2R5ZkpjVGFRZ2pjUmFJYVphbWVrYVVjY2JrYTVoemVFYUVkeGhOaFVoVWRrZlZnQmZ5ZzlnMGhFYUhkRWRQZmVlaGdnZVpmTGdDYkJnWGdOZVFka2REZmNmQ2NSZmZmZGNGZE1kM2VVY2hhVWYvYlNnRmFvZHJkTWZSZm9naWZMZEJlWmVMaEdheWZJZENmVWRIZndoU2NlYmthZGFrYVFiV2M1YktjWmJIZmxnTGVGZEhiRWFkZ0hlUmJsaFJiQmZEZ3NiNWZkZGphMGRxZUVhV2hkZ2ljU2d4ZXdod2JMYzBhSWRBZUNnMWJsYjRlV2NDY01kOWFKZlRjTWhraFVlVGd3Z2FmSWNCYkFjQmhHY0FhSWNkY0ZmUWd3YXNhZGZIYW9nbGJCYXpnSWNVYkdnQmIxYTNkR2dHZWhlbWRVZFhnaGd3ZVZmbmJRYlBlYWgxZ0llVWNjZFViWWJUZ01kUmVWZVBnYmdEZjViVGNCY0FkNWN0ZUNid2J0YWZhRWNpZmdmQ2NNZ0JoUWY4ZUJkR2ZSZnBnVWFEYzVoeGRIaFJnMWhOZkdkVmdaYTBlYmFuYlphemZiZDBjWWJoaFdiVWRCaE1kZmZXZUFiUWFVY2tiUWNMZ2NmRmZwYUNhYmIyYkpnbWVhYVJmUmF5ZlRiaWNWZ1JiSGFrYzBhWWZTZVFhaGFPY1BoWGVwYVVnTmRRaDhhemJCYVFmSmZDaGRmVmZSZHpnVWdWYkVncWdmZ2hjb2N4ZFFiU2h3Y0diWGZIZzFiR2hYY0hoaGhPYVRlM2dSaG1kVWQxZEVmVGZiZVFkc2MwZ0ZmMGFZZ3lhU2dTaGtlSWVJZ0ViSWN0Z2RmVWR0ZVJnZWdBY1lmM2RUaFJmbGJXaGRoR2U1ZDJhY2cyYTljR2ZaYXhhWWVTZlRjSGFVZUNjRWNFY3hlRWVSY0didGF3Y1FhbWY5ZGloWmFtaGtlVWdjZmthNWh6YkVkRWh4Z05lVWNVYmtiZWRSZ1NhWmFlYUdnSGJCZkJiZGZGZEZlS2VUaG5iVWZSZ2NkMGR4ZFJmY2VWZnBoV2dkZ0FoOWJyZlVlaGRSYnhoUmFoZE5iNGdVaDBiOWFrY2FiaGJwaGZnRWIzZ2hnZmVJZ2hobGd2aGVoa2FaZzVkWGVHZDRoWWVIZHpkWWUyY0hnWGdGYkdiTmUwYjBlWmJWZG5mUmZ1ZmRmbmJOYnZhUmVtYWNkV2hFYmtieGgxZlNjaGdCYmFkRGFRaHRjdGNXYWhhWWZVZ0xmUmV0YmdjR2dIY0plR2VOYWhiQmVSZVRmUWNNYXlkV2JqZU5kZ2diZ3pnSmd3ZlFmWGNSY1JmU2ZrYzVmMWRFZVhoTmRNZFVjWGhoY3dlVmZuZVFjUGRLYVFjQmdSZU1oQWMwZkljVWVsZU5lUGNaZUdlcGhUZkdoUmNOYXdiQ2UxY2xmV2hFZW5icGJIaE9iV2Z0ZHVmU2ZtaFJoNWJTaHhmUmF4YUhlUmYxZU5lR2ZWYllibWZLY3loSWJtaFBoUWVoZm5nVWd4ZkpiU2NkYVFmTWZRY1RoVWZRYUdmWWhWZHBkWWhiZHlkdGhtYmRneGZRZTNjVGRtYXdoUWRYZ1VjMWZMY1NjUWZWZVZjUWIzZFFkWWJjaEVjRmIwZlVmVWZwYk9iZGRSZkVhdWZSZlZoMWhTYWNkRmRaZzBjRGEyZXRoU2ZGZEhhRmNHaEVoM2hBYWRhUWJTZDBlNWJOaGxkZGFRZVBoMGc4ZFFmR2NGZFZoNmZXY21oUWVIZ09kd2JRZm5oTGVRaEpnYmhQYnhlMGdWaEdnUmNCaFdkTGgwYVJnMmhjaDJhOWFHZ1pjeGVZZ1NjVGRIZVZnS2hFYkZkSWhYZVhkRGNrZU9jQWFTZmRmaWRiZGhkcGdBZ0lhQWFjZTlkVmQwYVFiWmRXY0ViZGZCZ0FlUWVVZjdnVGh6YlVmVGhGY3hjQWFaZkNkM2IwZFlkZWFrZndiS2ZVZG5hQmZXZ2RoQWM5YnJkVWJoYVJleGFSZWhlTmg0aFVjMGU5YWtmS2hSZ0pnS2hWYW5kQWVKYUVlUmJOaEtjZWhGYTFnT2JRYldlNWZLYVpmSGdsZkxiRmZIYkVhZGJIY1VhMGhaYlZmbmNRY3RmTmF5Y0FjcWFSZW1kVmNEYlJiZ2ZwZ3RlU2VBZHBiNGhSaEFhdGF3Z1dia2JKZXZiWWZtYlpicGVGYkhmSmhPZWNmeGdBYVBmRGNBZ0lhTWRGYVVmd2U4YkloRmE1ZjllV2JYY1poTGZZZEVoNWUxZkVjWGNOaE1oVWNYZWhjd2RWZm5kUWFQYWFjMWRJZlVnTWdnZGRjQWdQZ1ZhTmROaEpmVGFrZFFoVWJGY3BkeWNFY1hkTmRXZkVnbmdwZ0hmWmdFaEZkdWdTYm1kUmU1YVNmeGVSaHhmSGNWYjRjTWdTZ2hiTmEwZ2JkRGZvZHlkT2R3ZjhmcGhCYXhhQmVXZFhkMGNvYVFmVWVrY1FiTGdjY0ZjcGNDYWJnMmZKYm1jYWVSZlJjeWJEZ1RjSmREYkNoVWExZVRkQ2QxZHdoQWJLaENhWmFCaGNlbGZ0Z2VjVWRVZnBjT2NkZlJkRmF6ZlRmRmRGZzRkY2FGY1pkMGREZDJjc2JSYVZoU2RJY0RkRWYzZ29kUmFEZ2pjY2h2aFJlUWEwYVJlYWNpZUZmWmVWZWhhSmg2YlJnMmZSY0JoYmFrY3Bla2FlaFVjc2FVZGNjVmc1ZWNmSGNsZnhhV2dkZGpnc2QxYUlnSGIxaEVkZmVUZndiU2FUZEhlVmRLY0VkRmJKYUVkQ2gzY0JoYWZRYm1lOWhpYVplaWdwZFZmSWZRZHRoemdFYWhoa2dPYUFla2NRZkhiVGNIYU5nZWVHZEhiQmhCYWRiRmNGZ0tnVGhuZlVoUmNjYjBneGNSZGVoSGVBaFZmTmFWY3djdWRVZWhhWWhrYkVnbGdWZ3BiUmVRaE1kaGVhZkVoa2V6ZEVoM2FBYUxlV2RWZVllU2ZlYWtlZGVrYlFlV2Q1ZUtjWmJIYmtnSWNWZ1NnSmFZaEhkVWU5Z01jQWdqYkpjamVaZTJmVWVqZEFlMmFVaE1iT2hFaHhoMWdTYWhkQmdTZ1JhQWh0ZXdnV2RrZ0pldmNZZm1oWmZwY0ZjSGNJZmNmTmVrZVFiWmNIaHhkOWFKY0ZmRmU1ZnlnWGNoYmhhd2ZRY1hhUmhSZ1Nka2c1ZzFjRWdYZU5lTWNVaFhkaGF3YkVjamdGZUpnS2FnYWRoWWdKZ1Zhd2c1aGVmRmdOY1BhWmFHYXBjVGhHZVJkTmN3YUNjMWZsZldoRWNuYnBlSGVaaEJiTWRyZUhnamVFZ3JiQmVSYVJid2JEZ0FkWmduZkdoVmdaZTBnYmFuZ1plemRiaDBkWmZuZ0ZhaGdKZk1mS2VHZUFoUWRVZWtmUWhMY2NnRmNwY0NlYmQyY0phbWdOYkJkMWgrZ1pnSGNNYVFiVGJFZDFjUmRTY1JjVmZPYmFiWGdRZ1FiUGFrYzhlM2ZIY2dkUWROY05mRWZWYXpoVWJWZEVmK2FKY1JiZ2QzZVdleWZJZ2RiV2FuYkZlT2dSYzNmUmdUYUhkV2QxY3FhQ2VEY01iVGZjY0FldGNaZ1ZmaGdKaDZmUmEyZFJkQmNiaGtlb2V0YVBlMGRzZWNoY2JCZGthWmRSY1VjMWZmZ2ZlVWVSZTJnY2EyZTlnR2daY3hoWWJTYVRhSGdWZUtjRWNGZUpiRWRDZ3llUWFTZ0VoQ2dBYTFlWmhpaGRjUmFKaFVlNGhIZVNnUmR3YkllTmhCZHRiSGZBY1RldGM4aE1ibmJCaEJoZGFGaEZiS2dUZG5iVWhSaGNkMGV4Y1JlZWVIY0JoV2RkZ0FkOWdzZlVnRmVnYjRmRmRVaGRiNmFVZHdlNGYyaExnUWhaYlViVmRqYzVlZmJXYlJidGdIZ0thUmROaGtnQWF5YXRiS2JKYlRiZGFMZ2RmU2ROZVBmWGFCZlFiWmFHZFRhSmN1ZkZkQ2JZZHBnQWFDYUpoRWdRZ1VkdGNmZVNkaGJCZlNmUmVBZHRld2hXYWtlSmR2Z1libWdaZXBoRmFIZUplSGNhZURicGJNY1RiVmZGZkpkRmhVZTVncGRkaEJkaGN3YlFnWGNRYlljRGFFZDVlOWdBYVhlTmZSYlRlR2JWZXdmQWZuYXBlRGRMZmhoeGdUZEpmUWI0YWFjZWhBZEVlS2NNZERhOGdCaFZneGJNZytnQmVSYWdoYWRYYWpkVWFFZ2JmRmVGaG5kVWhVZjViNWhTY3hjUmd4aEhnUmIxYU5mR2VWaFpkMGdiZG5iWWNsYUxkaGdSY25mWGF3Y2xkbWdkZVVnb2VRYlVia2ZRYkxmY2NGYnBlQ2JiZjJiSmJtZUlmRmNKZ3lkUmRpYVZkZmVCYVFhbGNSYldoUmZWY1RhZGRHYWtoWWVJaGthaGFlY1VoVWZwZE9hZGhSZEZoemVUY0ZhRmg0aGNnRmVaYzBmRGYyYnNnVWFXaHljTmhHaEdneWFwZFRjVWVtY1JnNmdYY3hjbGhhYmNiQmZaYlplUmRnY2xoNmJEaG1jUmVkYmJkaGg1Y3FoTmRRZTVhYWdOY2tobGFWZVZnaGVsZWRoZmN5Y2RkL2djYnpnMWNHYmJmQWJzY1NjR2hBaDRhRGFiaFZkd2NJZlRmamY0aGRjRmVpYmRjNWVUYUdma2JVYmNoa2Y1ZHpjRWRFZHhoTmJVaFVha2VWZ1RnamQ4aDFiU2JuaEFoRWRkYkVjeGNLaEFiSGJ0Z1FlUGV3YkFjZWZPZ3dnVWFZZkpiMGY0aHRhRmh4YndiamRUZnhlOWdTZlVjMGE5YWtlYWdsZE1kWmNFYjNnQWdMZldmVmZZZlNjZWdrY2NjcmhRZFhlTmhLY2RhR2NKaGhoRmVIZEVlZGdIYlViMGdaZFZibmJSZ3ViZGZuYk5odmJBZENnaGVFZkVna2FRYzhnU2hnYTFjU2ZWZ0JmQmR3ZkViMGRKZHphWWJqZ0phbmVXaERkY2VBY05kRWFRZUVlVmJsZ0ZlQ2FIZmdhZGFnaGRiRWJOZGFhUWNYZVJnUmVTYmtiNWcxYUVjWGROYk1mVWhYZGhnd2RWZ25oUmhaZEtlZ2NBYVVhT2NVZ1ljT2NlZ0FhY2MwZExhUmVkYkljTWZ4Y05kd2RDZDFlbGJXYkVlbmVwZEhhWmNFYUZjdWFTZ21oUmY1ZEFibGVKY3hkRmdSY3diRGZGaHhkOGJuZURiQ2JNYTFiS2FRZE1mMWRIZ2xmcGFGZ2ZnR2NBZFFiVWJraFFhTGFjYUZicGNDYmJkMmNKYm1lYWFSZVJjeWJUYW5mTWNRaEdiQWFVaERhQmhrYUpkT2ZKYnplRmJQYmNiRGNVZ3RkQWJRZThjcmhKYzBkTWM4Y0hlbGhsY1NjY2dGaFpoMGREZzJhdGRTaEZoSGdGZEdiRWgzZGhoVGRUYjJlUmdxZlVmeGZrY1RoZGZ3Z2tlVmZIaDBiRWV1YVJlV2ZRYkFmUGRBYzBoeGJOYUFiNWVhZ0plUmcxZ1FoR2dFZ29mQ2NkYkNld2Z6ZWNkeWc0ZUloWmYzaGRnQWJIZ2pnUWVUY0VnQmQwaENmQ2F4YUlmUGVCZkNna2VuZU5hRGNvYVRkV2NFZDVoemVFaEVkeGhOZlVjVWNrZlZkVGRtY2xmMGJHYUhkQmhCZmRhRmRGZkRiVmRWYzhiUmVjZjBheGVSZ2VjSGZCZFdjZGdBZjljcmJVZmhiUmV4ZVJjbGh0aDJnRWZBZEFhMGNNZzFkdGFjZEhkM2JCYkVoVWFGZ29hU2VjYmdnaGFrZVNmbmFOZ0toTGNIZ2NiSGhVY1RoOWNhYlNlUWRVZ1FmVGVWZTVodWNkZG5lTmd2ZVJjbWJjZ1dlRWRrZXhmMWFTZWhjQWdQY2JiZ2V0YndnV2FrYkpldmJZaG1iWmhwaEZhSGFKYU9oY2EwZ0lnSmZHZFFiUWhiZVdmMGc0ZXNoYmJ6ZEpid2NRZlhjUmVSYlNha2Y1YTFiRWNYYk5lTWhEZ0hmRmY4aGZkSGdRaFBiYWIxZkloVWdjZlVnWWNUZmVoRmdOY0hlS2RtZlFjUmVRYkVlY2ExZlpmeGJ3ZFlmVmFTZTRmUGZaYUZoeGR1YURibWgxZzFnWWFSYlJleGVIYVJmMWhOZEdlVmZaZzBiYmhuZ1pmN2RJYVVhZ2gzY1JkRmQwY1lnT2ZoaDVjSmZBYWdkRWJGaERleGdNZlJoRGNUZ2NiZ2NMYTFlRWNnZVRhbWg0ZlFoVGJWYzFjWWZSZFRhOWRPaGFiWGZRZVlnY2JFZ0ZjMGJVYlVlcGFPZ2ZjVmI5ZjlkSGRBZE1mM2hKZUJoa2dnZFZjamZzY1hiR2JpaElhUmRVZ2lkaGhDaFdjV2NSaDNnVWcxZjlhR2FQYWtjZ2hOZkhnMWIwZjBhUmUyYXhkSWJiaGhoRmNPZ2VlVWdzZVVnY2VSZzBnZGJUZ1JjbGVXZGRlR2g1YTJkSmRTaDRkVWJaYzBoSWJTZlVhWGRVZmVhV2ZCYXNiWGZCZVRld2JmaERkQ2JnYjJjTGhuaEloK2FjZGtlNWd6YUVkRWF4Y05jVWFVYmtmVmVUYW1mbGgwY1VmVGhaZEJnZmJBZlZmS2NTZDNkVWJEZGNiMGcxZk1jWmNYY0JlR2FmZlNmVmdyZFVlaGFSZnhhUmdoaE5jNGRVYTBoOWdrZmFlbGZNYVpjRWN5ZFJhRGhDZXhnbGZGYmVhZ2FrYmhoRmZtZDRkNGFKZlRnY2RNZVVmUmhSaFBmVGJ3Z0pkTGJYYW5hWWVNZUlkemFVZnBkQWd6Z1VmV2ZRYlFiVWJ2ZkRieGJBY2ZhRWRWZ2dja2dXaGdiQWRxZFljaWZkZXBmV2JTaGNoQ2RKaDFha2NjZEFjUmVSZ0pnV2NnY2hhcGRaYlFhNWU5YUFlemEwZkZjR2JVZ3hhOGhDZWxjbGNNZVVmWGdoYXdkVmFuY1FlUGRhZDFoSWRVZGNiVWhaYlZiTmR3ZEZmUGZiYURjd2JTZ1NmeGhNZmloQ2cwZ1JmV2hBYm1hRmRIZU1hRWdGZHdjU2ZqYlpmaWNTYzBmWmN4ZUZnZ2ZCZk5jQ2QxZjlkMGJPYVhhNGduY0pid2M4YTBmR2VoY0llZWVlaFVocGJDYlVha2U4YUxjWWZWYU5hWmZSZFdoSmRtZmFlUmNSZHllVGRuYU1iUWZUY0VkMWVSYlNlVWZjZUxhUGZTYUZiS2VQYmtoRWZnZkdkUWZNZ2RoYmVqYnRlemJUaEZkRmE0ZWNhRmdaYjBoRGYyZXRlU2NTZ1hnaGFLZk9jWGZoY1RkVGcyZlJkcWZVZnhna2dUY2NhQWN0ZlJnR2RCaHdmcWhGaFNkc2JWYUlhUmE0ZzlmS2VRYjRkYWZJY2tkcGRjYkhkUWdwYkVhZGNIY05kMmJOaFRlb2RJY0pnRWZKZGJnQWV6ZXRhS2NHZ0ZodGNFZFVjRmRwaGFoUWFtZDliaWVaZm1ia2VVZGNla2c1aHpnRWVFZHdkYmRFaEJoc2ZWaEdkbWdsYXBkR2RDZFFiSmNQZ1FlSmJFZkFhamhCaGZoTmhCY2dlWmZZZTFicGRXZGRkQWY5ZXJlVWdoYlJkeGZSZ2hlTmM0Y1VlMGg4YnRnTGJGZ01lUmRSZzNlQWZPYldmVWFJZFNhZWIxY3BlNWRRYVhlNWJEYVRmbmFsY0xiRmdIZUVjZGVIY1VjMGhaYVZhbmVSY3ViZGNuZE5ndmdFaGlkOWJFZlhmUmR0ZTFkQmVGZVViRmNSYUhha2R4YkZmQWFVaHFiQmN6ZVFnN2ZXZnljQmVHZWNoWGZJYlpmQ2N4ZmNlTWJSZDBkNGQ2YlBjVWdJYzFnUWRUZWtlRWFHYVJjcGcxZ1VoemhaZ01iRWJIY2djOWJBZXpnaGJiZElmZ2VKY1loTmhFZ1poY2ZQaGxkTmFjZWRnbWJjZlJhVWRFYmNmamdDZlZmQmJOZU9nSGRwZUhlWmNFY0ZjdWZTYW1nUmU1ZVNmeGhSZXhlSGFWZnNiQ2hTYTFkWmM4Y09mRGJjaGhiYmR4Z1JjbmhDZXhkSmhjZWJoa2dwZkVoVWFsZ29nTGFJZ2tlRmRDaFBhV2NKZXRmZGJCaFJlbWFSaDFia2RRaFRlRWYxZ1JkU2JSZlZhT2VhZ1hhUWdZZ2NiRWZGZzBhVWVSYTFiR2FJaFZja2Q2ZEhmMWQxYjRkSWNsYXBnMGJYZVdldGRaYkZiR2ZKZFBiSGUzZmdkRWRSZ3pnQWJpaEdma2hvYWZnY2dGZGxoWmVYaFJjSmNyaFNoMmhRYVRlYmNrZEZoa2VhYjBmSWhQZ1dkeGEwY2RlVGFSZmxiV2VkY0doNWcyZGNhMmc5aEdkWmMwZlJmWGJHZUNmQWNZZ1hnbGRJYVFoUWd6YWtiSmNXZFVmVmFpZ1plbWJraFVkY2JraDVoemdFYUVkeGVOZURhRWhBaFpjWmRHaGxnMGJHZEhnQmJCaGRnRmVGZEtmVGduY1VhWmdQYlViSWJCZEtnamM4ZUNoT2IxZ3NkeWNBZmxoRmUvZUZjVWNRYTVnQWExY2xhd2FhZ2tmNGVaY1ZlU2FWZEZnR2ZnZEpjYmFOZVFlbGhrY1NiV2FkZktjUGUxYk5hTGFGaEhhRWdkYUhmVWgwY1phVmVuZlJmdWNkY25nTWQ1ZkJlemFVYldjUmJrZ3hjb2VTZ2tjUWFhY0RhVmRoZStiRmNnY2NkaGhKYVRlSWNoaERmMWdoYk9jY2J4ZUJiTWFUaFZhRmVKaEZjVWU1aHBkZGRCZ2doNWdCYzNkUmRaYkhna2Q1ZXdiRWdXYXRmTWZVaEdnVmh0Y1ZibWRRY0dkUWhWY0llVWhjZFVkWWdUZWVhRmVOZFBmWmNHZXBhVGRHYVJiTmF3ZlhneGNFZUVnWGFTYzFnSGhLZWdiUWU1ZVNkaGFZZzRiQmVWYk1hMGZlYUVhOGNmaFZnZ2FSZDhiYmJCYlFkbWhLY1FoQWZpaFJlQmVJZmZmUGJCZ0JkVmVVYmdnbGFlZElmd2E1ZkNnTGJTZWRkbWVLZ0JhUWIvYUdmemI5ZEViQmZSYzBmZGVEZkJhVWNCaExoM2NRaE9mWmdFaHdlMmZHY0JnNGNkYmRmeGFoYm9iWmJsY0ZnNGVjZkZmWmQwaERmMmF0Z1NkRmRIaEZhR2RFY3pnNGRjaEhiV2JSYmlnQmNWZWhnQmRjZkZlbGRaZ1NieGRKY3FhWGFHYVFoVmNiY2xnUmFrYUtnMWFBY1VkSWh4aDBmV2JVaEJkbGRPYmZnVWhSZTJkY2MyZTlnR2JaZHhhWWNTYVRnSGZWZUtkRWJGZUpjRWJDZXlkZGNTYkZoaWNjY3JnTmRXZ1VkVWJJY0VkSmZ6Z1Foa2F4ZEdoVWdWZDRhY2FRZGthTmcwZEdmSGVCZkJoZGdGZkZnS2VUaG5kVWJSYWNiMGZ4ZFJnZWZIYkJlV2VJZHdkY2YvaEdlbGIwY2llU2NoYU1mcWRVYzBnUmZrZGVmMWg4Z1pnUWRYZkFhQWJXYlVnQWZiZWRjbWIxYWtkUWhXZjVkS2NaaEhibGdMZEZjSGNFaGRjSGZVaDBnWmRWYW5hUmV1ZklnWGVzYjdoRGFpZDViRmRIZGtkd2VuZVNoaGR0YlNoVmNnZ2Rjd2RDY0VnSmhrZ1ljbmVOZGdmR2JGZ2hlT2djZnhoQmhNYVRlVmFGZUpjRmNVZTVjcGFkZUJnaGN3ZlFmWGZSZ1JjSGRVZVlmaGFXZFRkb2NmYVhkWGRnYmllVmJuYThnUGFlYkZhNGhVZUlhMGFZZFllZWdFZGRnR2hmZjBoQmdUZ0dkUmVOY3dmQ2MxaGxjV2VFZW5ocGJIYlpoRWZFaDhkRGN6YkFoc2NHYlZkcGF4aFNhVmVVZkVhU2JrZDFnZWRiaG5mWmd6ZWJhMGJaY25iRmRoZEphTWdkYVJnY2RaZVhkbWQ0ZkxiY2RGZXBmQ2ZiZjJkSmRtYmFhUmJSZXljUmhqYTBnZWhIZkJoOGdlZEhjVmNvZWFjTWNDZlJhZGdmYmhiVWM3aElnaGI0ZmNlUGFGZDhjMGFUYUVleGI0ZE5iZ2RNZzZnVGFEaDhnYmhXZ3pkOWdHZUdjM2JGZ1RhRmJFZDVocWNVaHhma2JUYWNmQWh0ZVphVmRoYUplNmJSZTJjUWdYZExheGdoYWtiTGJVZXNoSmJjZVFjMGNkYUVmUmRrY0NhUGNDaGNlbGJmZ1NjTWNEY0tiVmNGYUdkQmhHYjVlZ2RFYUZnSmZFaENiM2JCYWFiUWZtaDlkaWVaaG1ka2JVZUljQWFzZ25mUmRSZTRmRGRVYlZla2hWYlVnM2ZSZXBiR2NDZlJncmhkY0ZjRmdLY1RnbmFVZ1JiY2YwaHhnUmdlZkhkQmZXaGRnQWg5aDBkVWVoZ1pmemdiZUJjTmQ0aFViMGQ5Y2toYWFsYk1nWmNFaDNmQWhMZ1dkVmFZZVNkWWdFZ2RlMGhRYVhkTmhYYmVmWGJrZ0thUmZqaFpoSWNVZUFmaGRYaEFhaWdkZ2dkT2JqY1loaGhBaFRnTmVlZU9jRWV4ZDFiU2RoZkJjU2VSZ0FidGR3ZVdna2RKY3ZhWWFtYlpkcGFDYjNhSWUrZWVlMGVRZEVoQmJBZ0poRmFGYlZmNWhsZWRjRWd4YjVjYWIzZ1JoUmJTYmtnNWcxZEVmWGFOaE1hVWVYZ2hmd2FWZW5mUWNQY2NoVmJKZlRoZmJ3Z2RjRGNLZUJlOGdXZGJjRGQ0YmJkVWJFaEJoOGJDZHhlZ2FFZ1ZlU2Y4aEtjSWZRYzhiNmRHYldmMWhpZllnUmdSZXhjSGdSYjFnTmZHYVZhWmYwZGJjbmNZYnVmWmJrZ3BhTmRGZ2hiSmFNZmRoVWVvYlFlVWZrZlFnTGFjYUZhSWFNZVljVGFJZjBoSmZrY0FjOWFHZWlkcGdBZ0NkVWVNZ1VjR2RFZEFiUGFKZlNhY2FZY2JmVWFFYXlhQmZBYlFiTmhJZlZlZ2U4ZkFlbGhGZndkSmFGZDljMGJWYUVnRmVTZkZhSGdGaEdjRWQzYWhnVGNUYzJiUmhxaFVjeGJsZmFiTmRnYnRjUmdWZzFneGUwZURkamVjaGpmT2N3Z3dnaWRQZUJja2ZjYUpiUmRRaFVoWmR4ZWxkV2dkYkdmNWEyaGNiMmY5YUdnWmV4Y1loU2RUZEhoVmhLZFJhQmVvaFdhUmVDZGRiYWNEaENob2UxaFpkaGYxYU5kSWJnYnNlV2VRYWhmNGhDYkFnMGNFZ1hnTGR6ZHNkemdUYVRhMGRFYk9oZ2dWZUtnQWJ5YkJiQ2hKaDBkd2FUYVBjWGFBZ1hiZGRHYzBiK2RGZkZmSWMwZkZjQmVGZ3hjU2dHZVZja2hhZWxmTWRaYUVjM2FBZ0xhV2NWZlllU2FlY2tmY2MyYUJlRGZvZGZiTmNqZ2RnTGRRZURhbGZVY1Rja2UwYkVnU2EyZmxndWhJYm5hTmV3Y1JobWNZYUdoRWVsZlpiMWJXZmhoQmdQaFdmUmNaaHdlRmRFYndkc2VMZ1Nic2g1Z1ZkU2ZBZExjZWYwZlFlRWFCYkFhSmFGYUZnUmhwZmdnYmN6Zkpmd2NRYlhjUmhSY1Nla2c1YzFhRWJYZE5iTWdEaEhoRmE4YWZjSGdRaFBnYWQxY0ljVWRjZFVmWWNUZ2VjRmdOY0hiS2dtZ1FiRGZTZDFhd2drY1JkQWYwZVBnUWVqZjlnSmRMZVFhOGc5ZkdnaWVFZzZjSGd4YVJoc2FIYlZic2FZaFZkeGNVaGdnSmF6ZGthOWZiZDBhNWh1YUZna2NsYm1jZGFVZG9nUWVVY2tlUWFMYWNmRmNwZkNlYmYyY0pkbWVQaDFkVWFnYVRoaWVjaFFhVWdVYjFlVGJTYnhmbGNrY2FlWGVRZllhY2JFYUZkMGNVYlVmcGdPaGRlUmFGZ3pjVGZGYUVmeGFjZUVndGQwYlhlV2NVYTdlZWJnZUliMmFkZWhnc2duYk1hQWdrZkxmS2cyZFpmeGZDZFhlOGM4Y0pnUWhsZ1FlUmYyZ1JnQmdiZGtkcGJrZ2VmVWhzZVVjY2JSYTBjZGZIaDFid2hDZkliVGN3ZTRkY2gyYmRhc2ZaY3hhWWJTZ1RoSGdWZ0tjRWRGYUpiRWZDZTNkQmNhZVFlbWQ4YTJlTGJpZkJiSGRmY0FmSWMyZlhlZ2VzZlpiR2JVZmtkTGJUZW5hbGIwYUhjbmNaZHJjZGhGZEZjS2FUZW5mVWZSaGNmMGJ4Z1JnZWVIaEJmV2RkYUFnOWZyZlVoaGZ4ZTVhRWFoYU5obGhVY3hic2JzZ0lid2ZBaFhjUmJ6ZTllNGREaFFlUmhiZk5iQWJCYnNjUWN5YVliUGhQYUhjdGRIZ0ZiR2dFZVJjSGNRZ1FlUWRXZURka2h2aElmamhBZm5oVGNtY2doWWJTY1ZiNGdvY1JjVmhkZWJiU2drY0VhL2NFZHdleGFuZ1lnR2RaZHJhSGhYYXRmQ2dXZ1JjQmJNY1RhVmhGZ0pjRmdVZTVmcGZkZ0JlaGZ3YlFmWGRSY1JiU2NrYzRkaGdXY1Rmb2ZmZVhiemdRZDFoR2ZEZk5nYmdJZTFoSWNLYmNiUWE4YVRhZmVsY1ZjUGhiZERnNWFUZkViZ2g1Y3dhQ2hWZWxoWWZIZUhkUmZIY1pka2doZW5iUmRrZjVhNWZTaHhjUmV4ZUhnUmExYk5kR2FWYVplMGZiaG5hWmV6aGJmMGVSYTdnZGhFZmNkS2JNZXdjOWRDZ1Via2NZY0xnZWIxZ29hV2RiZzJlbGZtZmFjd2RwZndnWmdIZU1nUWdUZEVkMWhSYVNkUmJWZk9nYWRYZ1FlWWZjYkVkaGF2YWVmMGNwYU9kZGJSYkZlemJUZ0ZoRmU0aGNkRmZZY3BlQmJtYWRhNGdGaEhjRmZHYkVmM2NoZ1RmVGUyZlJhcWZVY3hmRmZkZGZnbGZzYUxlR2dVZFlnMWJFYnpnMGRSY0tkMGdRZm5jTmVnY1phRWJNYkVmOWNZY1RoUWhSZldlTWFqZHNoNGRNYURlc2JQY0tkRmdnZFNnUmRDYUZlR2hFaEFhQmFJY0NjemhsaFdhUWFpY3BidWVaYWloWWNkZWNnaGRWZFpoRWZFZXhlTmVVYVVia2RWZ1RjbWRsYzBiR2RIYkJiQmRQYVJjZGFLYlJkbmJSYmZkZmFRY1VkQ2RHZGlkVWRRY01na2hvYjViV2VrY0JoNGZUZ3plbGU0Y1VoMGg5ZmtlYWJsZk1hWmRFYjNoQWZMZldhVmZZYlNjZWFoYk1hc2JFZHljRWFkZVplRGJjYU9lUWEzaEZicGZSY0JjMWhjZE1heWhZaDhkT2RTZEZmbmZSaEFmWmZFY1ZjUmNraDRjRGcxZjRnR2RSZUVjWWJsaENjUmdaZ3ZnSWZDYU5lcGFWY1hnSWZzaEpibGJZYktmQ2dBZU5kTGdIZ0ZiVmREZ2RoQmRoYndoUWNYY1JhUmZTZmtnNWIxYkVhWGdOY01kR2VEYzVkd2hYZmxoNGhQZGFkMWdJZFVkY2FVYlllVGNlaEZkTmRQaFpkR2FwZVRkR2JSZnNibWRSZ0JjQWdTZkVhbWVwZUhjZWFWY3hhemRTY2pjWmU1aFRjUmNKYXhmRmRVYTlnTmNCYkZiWmRrYVplM2NwY1piYmQwZVpmbmFGY2hjSmRNYmRjVWdvaFFiVWhrY1FlTGRjZkZnb2FVaEllQ2ZzYmliYWNRZlJheWVVYjJkNGdOaFRoQWNSZlJjVGN4ZE5jT2JZYVRkMGVZaGJkVWJFZWdlVWdWYVZnT2dJZFJmOGEvZUNnUmM4Zy9iSmZCZjVhMGVGZFdidGZDZkhiWGgxZXNhRWczaGhmVGhUZjJlUmdxZVVoeGJrZVRjY2VBZ3RkWmNWY2hlSWJzZUNlQ2IwZkZjYmVsaHBka2daZ0ZnWWFKZGNmVmZnYmRmU2h4aDljV2NmaENidGMyZmJhbWc5ZldoYmdoZW9kNGdUY0hnVmJLZEVjRmVKZkVoQ2UzaEJjYWhRZG1kOWZpY1pibWFsZENhUGNRZGNjM2JFaEZheGROZFRhRmdRYkloVGdpZVphMGVIaG5oWmFCaGZnQmI1Y0tnVWQzZVZkRmJPZHdhVWFDYWRkamF3Y1RhT2VrZWdoL2VHY2hhMWc5aGJoQmZOZDRlVWcwYTlja2hhYWxkTWdaY0VoM2FBZUxnV2ZWYlliU2dhZWtlZGE2YlFnVGF4aEtjT2RDZ1ZoTGRYYVhhRWREY0hoUmhraFhhR2ZqZUVlZ2VNZVNiY2NuZlJiamV0YktkRWRsZHhhMWRWYUJnQWZYYlJlRmFjYXNjV2RnZDFkdmRmZ0dkWWI5Y1hhRGVzYWRnZmZWZHdhSmdBZnhmWWJkZlhkVWNkZERkZGRCY2hld2dRZVhnUmFSY1Nja2M1ZjFjRWNYY05lTWNXZ0ZoSmV3aFZlbmNRZlBjYWYxYklhVWhjZ1VjWWhUYmViRmhOZFBlWmNEZjRhYmhTZDFnd2huZUNleGFjZ1RiUmhYYW9jMWVKYlFkOGFwY0Rhd2FFZHJjR2JWZ3NmamRGZ1JhOGJDY1RmQWFKYzBmSWVUYkJmemJQZ1FnY2ZwZ1VlVmhkZE1iUGZBZlJiVWZGZXhnd2hKZmVmVWRGZ29nYmIyYUpnbWVhZ1JoUmZ5YlRibmZNZVFjVGZFYjFnUmFBaEZmTmFPZVljVGVFZ1lhYmVsZ3hlMGRIZWtmcGJJaGNkeGZFYmhnVGdFYTllbGVjYUJhOWU5ZkRmemJrZVhkUWRDaFFlVWNYZlhoaGJEZFZlRWM1ZXFjVWN4YWtlVGVjZUFodGVaaFZlaGRKZzZnUmgyZFFnSWdLZUVjcGFzZlBoRWNzY0thYmVCYjFnU2ZSYUJma2RFaE1iVGdvZGpjSWZTZkZkR2hhZ2dhY2ZKZVpmbmFWYUtjRWVGZkpoRWJDYjNjQmJhZVFjbWQ5Z2loWmhpaEJoU2hjZWtjWWJoZ0VkRmRKZlFkVWRRZkFkY2VUZGpkc2d4YlRnQ2ZVZFRjT2NsZEZnYmNWZVZmOGhSZmNhMGN4YVJkZWFIZEJiV2dkZ0FlOWFyaFVhaGNRYzRlQWVCZE5kd2NXZjBnY2MyZmFla2QwZ0hnRGdXZDBnTGFTaFZkOGVlYWVja2g4YnRhUWdYYUJoVWRlaG1oUmVMZkJmSGJnZ1JmSGZVZVZhY2VWY21kcGZ3YWFiR2U1Y3ZoVmNtZjRlYWNFYmtiUWU2Y1NlZ2E1YU1nV2FoY1pld2RTZ2tjdGRqaFliamZJYWhkWGdTYUZnT2hiZGdmMWFSZ1RlUWVWaEFmSGdHZVJjcGRkZ0JnaGJ3Z1FnWGRSZVJkU2JrYzVhMWdFZ1hmTmhNYlVmU2RvZjFhQWZpZkZiZGNKY1ZoSWZFYmFhbWF3ZlRnZWNGYk5lUGNaYUdhcGJUZkdhUmFOaHdjQ2gxY2tlUWVYZVNlaGVIYWJlR2F0ZXVnU2htZ1JiNWRTZXhjUmR4ZEhjUmcxZU5iR2ZWZlpoMGdiZ2ljQWh5Y1BlVWdZaHZhRmVnaDlnTWZPYWthb2dkYlVmZ2dFYUhhV2RsYnBiQ2RiZjJlSmJtZWFnUmFSaHloVGVuZU1iUWhUZkVoMWFSZlNjUmNVZmRnYWRXYmthWWVPYVVnRmU1aFVmUmdoZkNhWGV4Y0ZhemVUZ0ZhRmE0ZWNnRmZaYjBhRGEyYnRhU2VGZEhoRmRHaEVmM2ZnZVNjVGMzZWxocWhQZWxnaGNIZE9mQWVVYlVjSGQxZHhjeWVEYTJoaGFCY1BiVWFOZG9mVWEwaHNjVWNjZVJiMGFkZlRiUmJsaFdhZGNHZzVkMmFjYjJlOWNHZVpmeGdaaEhjVGRHaGhiS2ZSZ0Jlb2VOY1djSGQ0YUpmRGRpZFloaGVJZzJmRmVSaGZma2g0YjhnR2JVY0JmbmhVY1Vja2RWZVRobWFsZDBlR2ZIZUJjQmdkYkZlRmVLZlRibmhVZFJhY2J3Y3BnUmJaZlhlQWRDY2VibGN3aG5oR2gxY2NhMGVUZ2tlRmgwYlVnd2JaaHRmWmduZGtmWmZFaDNmQWJMZVdiVmRZZ1NmZWRrY2Rma2JRZ1dkNWdLZVpkSGdsY0xkV2VIYkVhQWNIYVZkMGRDYmZiSGFSYnVjZGVuZU5ldmRSYW1nY2JXYUVka2R4YzFjU2RoZEJiU2dCY1FidGJ1ZFdkZ2Q1YjBlU2ZHY1pmcGhGZEhlSmdPaGNieGJCYk1kVGVWZkZmSmRGZVVkNWVwZWZheGhNZjhnYWczaFJoUmFTaGthNWUxZEVlWGVOYU1kVWJYYWhjd2NWZm5lMGNsZ2FjMWVJZlVhY2NVYVlnVGRlZ0ZmTmNQaFphR2RwYVRmR2NSYU1nNWZUYVZmbGZlZ1Jld2NFYUxnR2JVYUZndmdWZzNkbGI1ZURoV2g4YTljWWNCZ1JoTmJRZm5leGgwZWJlbmNaZXphYmQwYVpmbmdGZWhiSmJNZ2RjVWRvZ1FhVWRrZVFkTGRlZEJmSmNDZWNmbWFJYXplRWVsZGdkUGFSYTNjOGdRY1JjQmQ1Z1JhVmRCYVVoSWhFaGpmaGJsZmVkVmNwZGVhVWVVZnBhT2FkaFJlRmh6Y1RkRmJGZzRoY2VGZlphMGNEZjJidGFTZkZoRGZNZVVkVmZqZWtnWWNWY0VnNWhxYlVjeGRrZlRiY2ZBY3RiWmdWY2hnSmU2ZFJnMmNSYUJkYmdoZ2RnT2dlZVVmc2dVZWNlUmIwY2RhVGRSZmxiV2dkaEdiNWgyYUlnU2hvZlNoTWVrYlJoY2NUY0NkWmJLaERnbGRJZU1oQ2UyZDljYWNUYzNnNWVpZ2ZnR2JsZ2NkY2VsZUJjemdRYTBoeGZTZlVkVmJnZVZhVmFHZmxka2VBZjFncGVCYmRkRmJGaEtoVGhuYlVhUmFjYzBieGRSZkplWGVsZGFoWGNnZjllcmZVYmhiUmN4YlJoaGZOYzRhVWUwZzloc2JKZEZoMWNKaFFlVGQ5aGZkRmNnZUpjTGVLZWdjSmZxZkNnQ2ZBYUphS2JDZXdkUGZVYlNnSWRkY0FmRWUxZ2ZoQWd6ZG9odGhJaGplb2FnYkNoR2djZ2VnUmZrZ0JmMWdHZ0JmeGJTZURkUWNKZHdnQWNXY2hidmNZZW1nWmNwZEZkSGFKZ09mY2V4aEJnTWdUZlZnRWRiZVVkQmJvZThnSmdsaFpod2VUZ0diVmVSZlNoMWJOZ29hRWRTYWNnRWVHY0NidGIrZEhkemZwYUxjTGVnZXBhN2ROZDBjNWRIY2RoRmhNZ2RjYWVHZm9oYWZFZUFjaGJhZ0NkMWZsaFdkRWhuY3BlSGdaaEVhRmF1YVNnamRsZndmUmF6YzVheGhIYVJlMWhOY0dhVmNaYTBmYmFuY1pnemZaYXdoaGVwY1Jja2JBaERkSWhRZ1ZnRWNDY3hkUmVPZWZkaGNNYk1kS2R5ZGNmK2NCZWxiSmR5YlVmM2VOYldhR2FRYk1jU2JIYVZmd2RCZUpnM2RRZVFjSmhFZTFnMGJBYTBnWmRPZFBiQmVoZHpmRmQzZHRoNGdjZEZnWmUwZ0RjMmF0ZFNlRmNIaEZjR2JFZjNoZ2RCZUNhamVBaC9jQWNWZmNlVGVKY2dkTWFOYUhlbGJzZ3BnU2YyZlFoVmJZZmtnb2cyZGRjVWR0ZmRmZmNSZzBoY2FYZFJoQmJOYlhlbWY1ZjJhY2YyYzlnR2VaY3hiWWZTaFRjSGRVY1hlR2RWZDVndWFDYTNoQmVhaFFjbWM5ZGljWmhtZGtlVWJjZWthWWE5ZUhoaGF3aGZkSGZoaDFjYWRHZGpnQWRrZlhkWGg0Yk5jTmVRY0lkZWZKZ3pkdGVWaE5laGRRaCtkUGJuaEJlTGdkYUVoa2crYUhnRmJjZGxiRGIxZHdhMmRVZjBkY2h3ZVpmbGFOYUxnSGgzYkJoQ2NVZUZkWmdKZlVmRWRkYmthUWZXZDVnS2FaY0hobGRMYkZhSGNFY2RjSGVSYjllY2VBZmlkRWM4ZE9hSGJNYTVoVGFqZU5oZWhXYXhhOWM1ZVNka2VSZGVlUmNGZGxnOGRXYmdidGRqZVlkbWdkYTRiSGZXYWxma2VjZHhmQmJNZVRiVmhGaEpnRmNVYzVncGFkZ0VoVmc1ZFRlVmM1aFJhU2drZzVnMWFFYlhmTmFNYVViWGRoZ3dkWGNqY29nQmJPaHdlQmViYUphUWVsYUhlSWdRaE1nS2dhZmpjMGFCZ1ViRWFjYjFiQ2EwZFJjV2NWYUNoOGNKaEpmeGRVZm5nQmRTZXBjNWJRZjBmQmI5YkhnVWM5aEJnR2FSZDloNGhiY2plTmQ2ZGJleGQxYk5mRmhoYUpkTWNkZlVlb2JRZlVka2FRYUxkY2ZGaHBiQ2ZKZmlkUmVtYVlmVWZJYTlnQmN6Y2NjUWVYYkVkMWZNaFZmQWRoY09oT2IzYzBoWWZlYkFiUmYwZlRjRWhwaE1nSWJFaFVmMWVWYUZnTmZ4Y2ZhRmRaZzhhUmNtZ3RnUGJGaENiVWNPYldhaWV0ZGRoQWR5YkVla2JGZUViMWFiYWVhUWFkYVpkWGJrYUJhNmFXZ21hUmNSZFplMWFGY09jZWVVY3NjVWhjZFJkMGhkYVRiUmVsZFdkZGdHZDVhMmJOYWlkTWVWZUllaGRaZmJnQ2NuaFZiQ2RSYWhjMGNOZFRnM2VCZUtnUWNuZUpoL2NlYzJhbGFkY2Nla2hoZDFhRWhFZDRmZWhCYVJmdGNjZkFiQ2c1aDJmR2hHaDFnY2dkZUFkVWJUYUhnamFCaGVlTmZVYndiRGNjZ1ZlcGRXZWRmQWI5ZHJiVWZoZlJieGRSY2hoTmI0ZlViMGY5aGthYWhsY3RjY2hFZjJhMGFMYUNmMWU4YWVlZWhrYzhmdGVRZVhhTmhLYk1nRGhFZENnUmIzYTllUmNXYkFkTmNlZkFlamR4Ym5oZWhuYk5lbmVGZUdmY2RMZ0VnbGd4ZDhnVWVUY3BmU2NSZkFmdGN3ZFdna2NKZ3ZiWWRtY1pkcGFGZEhoSWRMZ1BiMGZNZEphVGdRZXBlamJGZFVkNWZwY2RnQmhoaHdmUWhYZVJlUmVTY2toNWMxZkVlWGFNY0ZnRmczYWhiNGdWaHpnMWRjZkRmUmF0ZmFlT2FCZ0phV2RjaEFiRmdHZGJmVWZCYVRlR2hSZ05md2hDYjFjbGRXYkVobmdwYUhoWmJFZ0ZmdWdTZG1kUmU1ZEhhMWN3YmplVWFrZnBlTmVWZHhoTWZqZGJnaGhNY2hnUGRRY2tiMWdIaGpkaGNNaGRjVWdvaFFhVWFrZ1FhTGNjYkZhcGZDYmJhMmZKYW1mYWNSZ1JjeWRUZW5mTWJTYkxlaGdnY1hnRGgxZ0FlY2ZaYnllTmdLZU9lUmNVZ3hoV2hSZmtlYWNKYzFiZ2E5YUNoMWgxYzRnTmFSZ2doM2ZRaENiOGViZldoamVaZEtmRWd6Z2NkVmNDYVRoY2V2ZEJmMmdJZGZoY2VFY2NnY2hHZkZkVWR1ZkRieGVsZklhYmFnYU1oM2RlYVFkVmZiZmNjVmRGZlNhQWIxYzRoVGhKYm1iNGRsaEpjamI4ZVdhS2NFZFJmR2JDZVRlRmRJZE9obGdKZUVkQ2EzY0JmYWNRZG1mOWJpZVpmbWdrZFVhY2ZrZjVkemRFZEVieGRFY1NkbWJNZFZnVGZtYmxnMGdHZUhiQmVCZWRnRmVGYUtiVGRuaFVnUmNjYTBkUWREYmVjR2UxZFdmWmJBZThoM2FVZGtlWmQ0Y1NmamdsZjRiVWEwYjlia2hhY2xhTWZaZ0VnM2VBZ0xhV2RWZFlmU2FlZWthZGZrZUNoRGEwZHNkTGFUZWNkQ2JRZERjUWRWZ1ZmRWJRZnpiVmVuZVJkdWRkZm5oTmN2YlJobWZjaFdjRWRrZ3hlMWRTZGhiQmJTZVJoQWh0Z3djUmhVYkpkbmRhYWlkOWZwZUNhWGVKZmVoY2UwZ3hhTWVCYUZiaGVGZ0ZmUmFnYm1mUGdWYXhid2dVZFhkUmhNYVZoMWJOZDFlVmZIaE5hS2VWYTNkaGQ0ZEVhM2ZRYlNnYWcxZEJlQmZKZlFlQWRMZGVkbGRwZkdkVGVtY3BkVGVHYVJhTmZ3Z0NjMWFsZldlRWVuYnBkSGhaYUVnRmZ1YlNkbWJSZzVhU2V3ZjVheGZGaFJhVWVJZkdnVWd0aDBjSmEzYzlkL2JiZjBoNGJ1ZUZiZ2U5Zk1lSWd3ZlZiWmdGZ2tmUWFiYWVnVmZOZlpmUmNXYUplbWFhZFJjUmZ5YVRkbmNNZFFoVGNFYzFmUmFTaFVoaGRrZ2FoWGZRYVlnY2FFY0ZjMGZVYVVicGNPYWRlUmFGYXpnR2NoZkFmcWRjZEJnbGIwZUVhbWNzaEdmWGVEYmdiVmZIZVRkUWFXZkFnU2NNYytkR2R4Y2tmZWFjZUZhbGJDaGZiQmVKYzZlUmYyZFJhQmZiYmthcGVrZ2ViVWdzZ1VmY2dWY1JhYmZUY1JmRmE4ZGRkR2Y1YTJoY2cyZzlmR2RaZnhnWWdTZlRnSGRWZUtmRWJGZUpoTWdBZ3lnWWRWYkNmeWh0Y2lhZGFtZWtjSmRiYTFmTmd6aFdiVWV3YlJkRGFVY2xnY2JUY25lZGYwZlZiM2ZsZUJnY2FsZWRkS2ZSYmpld2JSaGJka2V3YmVmY2VYYXhjOGJkYkFnOWFyaFVoaGZSZnhhUmZoZ05nNGNVZjBkOWVraGFhbGZNYVJkUmMzZTVoSGJIZUJoaGdWZkxiZ2E5ZmtoWGEyYjVnYWFaZ0hiOWdOZkZnSGZrZU5nSGFWaE1oWmJIYzNmUWh5ZEtjbmFOZS9iUmZuZWtmV2ZRZEVjVmE4Y1Nna2Z3Yk9mUmRGZGxkd2dSYkVjSWU3ZEtoaWM4YTZnR2FqYjRiTGNQY1ZkY2FZZkJhVmNoZGphRmFVZTVicGVkZEJmaGJ3ZFFjWGVSYVJlU2ZrZTVoMWVHYkZnbGdNYVVmWGFoaHdmVmJuYVFiUGZhZjFkSWJVY2NiVWNZYlRhZWVBYmNhSGNOYmlnVWVFY0dmVmEwYzFkWGdGaGtoa2FVZnphUWRBZkllU2hRYzhmR2RDYXNmcmdRYnhmWWJRYVNiVWZraEllVmJBYVlkZ2RiYWlhSWM4YmJieGFFZTFiWGgwZFlhSmhkZFFiVmRGYkJiaGNkZENkTmNCZTliQ2JMaFRhY2FnZUxhMWhFaGdmVGVqYkZmZmVHYlFkTWZWY0dnaGJkZkhkY2dsZzRmWWJjYkVoRmEwaFVjVWVwY09hZGJSYkZmemNUYUZmRWY5ZGNhQWVvYm9nRGMyY01hWGJGYkdheGNHYkVjU2cwYkhkQ2FYZ3hmb2dXY2diSWg1YWNnQWV0aFpjVmJoY0pjNmdSYzJlUmVCYmJna2ZwYmtjUGR3Y1JmR2djaFJlVmNMaERoRWF0YldnUGNHYzVicmRjZDJkNWFYYWZkQmVZZUpnVGJIYXhhZ2NFZEZlSmVFYkNhM2dCY2FlUWRtZTlmaWVaZm1la2RVaGNna2E0Z2diUmh3ZlViWmJFZmdjRWJWZVJmaWd4ZTlhR2FDZXRncmRkZ0ZmRmhLYlRlbmVVZFJjY2EwZHhlUmhlYkhjQmhXY2RjQWM5YXJhVWVsYmNhd2FGZVZkWmQ0YVVhUWRjYmhhTWRsYUVoRGNPYlhiQWFMaFdmVmVZYVNmZWVrZ2Roa2RRYldmNWhLZFpnSGhsYUxiRmRIZEVlZGFIZFJjOWdjZUFlaWhFYjhoT2dIYk1jTWFUYWphTmhlaFdoeGc5YTVlU2NrYlJmZWJSYUZlbGY4aFdhZ2N0aG1oZWZVZnhkcGZGYUhnSmdPZWNleGZCZU1lVGJWaEZkSmdGY1VoNWJwZGRoQmFoY3diQWFqZlVkQ2FEZjBoNWgzY1JmQ2ZjY0tjU2RYZ3BocWdmZkhhUWJQYmFiMWVJaFVjY2FVZVlkVGZlZkZnTmJQZFpiR2FwZFRiR2RSZk1jemdTaGdkb2dUZ0VobmhnZFNkTWVBaGRkamdVY21jWmRqYVljUmVSY3hjSGNSZzFkTmJHZVZoWmMwZ2JnbmFaY3piYmgwZFphbmRGY2hmSmZNY2RoUmRoYlZmQmJoZEZlWmNQYWxob2FBYVpoemVZZnViSWJFaGRlK2hUaGllY2RjZlRoQmE5Z2RmU2dWY3hhSGNjZGxhNGRZZWNlRWdGaDBjVWZVZXBjT2dkYlJoRmh6ZlRhRmJGYzRnY2ZGYlpmMGZUZkNob2dCZ1VhWGJGZkViVWFpZnNlUWhCaGllMWNvZ1NoVGRNaFRkY2JBYXRkWmNWZ2hkSmM2YVJjMmRSYUJjYmNrYnBia2RlYVVjc2hVZGNnUmExYVBhQ2ZFZjBlRGJKZ2liQmUyaEZjbWRjZFNlTGUxYzlkQmNRZkhmVWFlYkhhRmZJaFdhQmQzZ0FjVGZTYTNlUmhJZFplbWZrZlVnY2hrZTVlemhFY0VieGFOZFVoVWFraFZiVGdtY2xlMGVHY0RhTWNBZUpieGFSZktkVGJEaGxnUWZKY3djVWJmYmFkWGhKZ01lWGFnYjlhcmhVZmhnUmh4ZlJoaGdOZTRlVWYwYjlma2RhZmxmTWdaZ0VhM2ZCZUlmR2hBZlZjWGNlYWtnVWVtZ0NlQ2hBZUxiTmZpZUJoSmVEZGxoc2dkZUhnVWgwZlphVmhuZ1JhdWRkYW5hTmF2ZVJhbWVjZldiRWZrZXhhMWdTZWhmQWVBZUFiVmY4ZGxkQ2RBY3hmdmFFaEdhNGg5ZFhlRGZzaGRiZmd4Y0FmWWdRY1ZmRWViaEdjVWQ0ZGdkZmFRZk5lYWFRaFhnUmZSYVNka2g1YTFmRWdYY05hTWdVZVhnaGJ3Y1ZmbmFRYlBjYWh4Y0ZlVmVJZWdoTWFUZWVhaGZFZk9mTmJ5ZzlhRmFEYVJiRmJxZ0lmVmFsaFdjRWVuaHBlSGdaZ0VkRmV1Z1NhbWRSaDVnU2R4aFJleGdIaFJiMWFOYkdlUWVRZnhkT2ZpYk1iaGVJYVVnWWYvYUhia2JZaEVjUGdCaGtiY2RVY2hlQWZIYmNoQWNoZk9mYmV5Z3RldmRjYWpoNWJ5ZlRjbmNNYlFiVGRFZDFmUmJTYlJkVmZPZWFiWGRRYlliY2hFZkZiMGNFaGdlc2VkZk1iQmNGZnhiR2ZSYklmcmJZZGxlUmZ1Z0piV2Z0YVNjRmRIZ0ZnR2hFZzNiaGhUYlRoMmdSY3FjVWh4YWtiVGhjYkFjc2NhZUZnMGNFZi9hUmUyYVlnVWRMYVJnbGJwZWFnMGZrZU9jV2d4YjBjZGJUZlJmbGRXZmRkR2c1ZzJjY2MyZTljR2RaaHhlWWFTZ1RiSGNVZ0phVWdRZEVnQmdDYTNhSWJQZ0ZnaWhsZnpoY2FDYlZoUmVjZ0ZjUmhaY0VlRWd4ZU5oVWJVaGtlVmZUYm1hbGgwaEdnSGZCZUJoZGRGZEZiS2FUZmpjWmhRaElkQWNsZlJiZWZpaFVnQ2dNaGdmSmM2ZlJjRmNnZzBjUmhBYWxmU2FVaDBkOWVrYmFjbGNNZVpoRWczZkFhTGJXZFZoWWZTZWVma2FkY2tiUWNXZTViS2ZOZmpkd2dmY1FnU2FOZVRiSGhTZThlUmVBaGpnd2huYUplWGM5YnZlRWdtZXNjV2RRY0VhQmIxZkFoeGNsZUpjYmhnZHRld2FXZGtmSmV2Z1lnbWNaY3BoRmNIaEpkT2RjZnhkQmFNZFRjVmZFYk5jVWdBZWdlb2VJYlZoUWJrZ1diMWE1ZFJjU2drYzVmMWRFY1hiTmVNZlVjWGRoYXdhVmNuaFFiUGNhZjFiSWdVZmNmVWVaZmFmUGRsYU5lSGFMZ0djTmJUYlRhVmdzaGlkUmhBZDVoV2VYaERhOGJRYlpjRGJVYTNjR2JpYUVjY2VHYVVoWWQrYVRkeGhWYVBlYmJCZWdoL2RJYURma2NrYUlnVWRZZWlmV2hGZUVlRGhNZlFiTmdlY0ZiVmM0ZkxiY2NsZnBmSmNiZXlhZGd2ZWNlamM1ZnlhVGduZE1hUWZUYkViMWJSYlNnUmhWY09mYWFYZVFkWWhjZEVmRmUwZFVmVWRwYUdlTWdCZUZndWJUZEZjbGE2ZGNmbGhaYi9iRGZ5ZTVoYmRHZWliVWVKYWZkemJjYUVoQ2dqZFllSmJFZWticGRXZ2ViQWVKZ1FhV2VoaEpleWFEaDJnUmdjY2Jha2J0YjBoY2hGZUFmK2RjY1JnMGZkaFRnUmdsY1dnZGNHZzVmMmVjZjJmOWJHaFpkeGZaY1BjWmNuYVZiS2NFYkZjSmFFaENjM2FCYWFhUWdtYjhoL2ZiZzJlVWErZmNoa2Y1ZXpkRWNFYXhiTmhVYVVla2ZWaFRnbWRFYzZiRmZpaEFlVGhPY3djVWFGaEdkaWR4YkJhTmRrY0lhRmhOZXhib2FsZ0dhMmNGZ3JiVGJ4YlFjM2JFYTFjMGM3Z0Jod2hZZXJjSmVGaE1oUmNHZW5mQmFRZWNhMWhZYVNkZWhrY2Rma2NRYVdjNWdLY1pjSGNsaExjRmFDZE5iWWRTYlJjaGRMaEdmSGVRZjFnWGJIZE5kdmZSYm1mY2hXYUVla2V4ZTFmU2NoZEJhU2NSZEFldGF3aERjaGVzYi9lSmczZnhmcGdGZGhkQWdiYU5iVmJZYUpnSGYxZE5jRmNQYzBhNWdwYWRkQmhoaHdnUWRYaFJjUmFTYWtmNWUxZkViWGJOZU1oRmRUY2tma2FGYjJlNGdQY0NnZ2NCaEdjTWVCYzhoZGhLYUFkRWFBZE1iQ2NVYkhjUWJFZk1hMWJCY1Fkb2NhYVdmemJrY0NnYWdnYklndmZCZGljaGZ4Y0hmMWd3ZzRjVGRoYU1ieWdXaEFhUWZtYmJnaWRvYnZkYmh4ZkljdmNYYzBiRmRBY2RkVmRvaFpjWGhtYjRmTGVjY0ZjcGJDZWJiMmZKZG1jYWhSZlJkeWRUZG5mTmVOZ1ZnMmNkZlJoU2ZSZVZjT2hhYVhmUWNZZ2NoRWdGZTBoRGRFZE5nVmZYZXhiRmN6YlRnRmhGZjRkY2RGZFplMGhXYlNhb2VBaEZmQ2hVZ1NoRWQyY1ZlVGZXZzNiUmd6YlJhUWJJZjVhY2VBY3RmWmVWZGhmSmg2Z1JmMmFSYUpjSWFFZlFmMGhLZXdnUmFBZVBma2JsYkViSGhWaHhoWWJKY3lmSWYvaE1hQ2NwYkdhZWdoYVplVWNHZFRic2RKZFJkQmFzZkxhUmJYZEJkU2NGaG1jTmFpYU5iR2FBZFVoS2ZXZ1JlemRFZkVoeGROYlVlVWdrZ1ZhVGFtYmxmMGdUZ2poRWZUZWRlQmZoZEtmVWQzY1ZoRmRPaHdjVWFDY2RjamJ3Z1RlT2NrZ2dhL2ZHZmdkOWdiaFJmaGJOZzRoVWgwYTloa2dhYmxnTWhaZUVoM2hoZmZoV2dVZnNmU2JKZ0Jna2F3ZVNiR2JKaGdjWmFIaGxlTGhGY0hkRWZkZEhmVWcwZVphVmduZ1JidWhmYmloRmZ2YVdmMmhkYUFnWGFRY1VoeGFTZ2dnQmZTYldjUmdaZXRiV2ZoZUJldmZmZFdhWWFnaEZiR2hoZ09mTGNVYjRmZWVSYUZoMWJqZ0ZnVWc1YnBlZGZCZWhod2FRYlhoUmRSY1Nia2M1YzFnQWhYZk5hU2hVYlNmeGR3aFNoWGhRYkhnWWR3Z1ljVWhlY2xoc2ZUZE1kVmZwZkRhWmhIaHBnVGdCYXhhTWNrZ0NjMWQ5ZlFhRWRuYkllVGNaZkZkeGJ1Y1dkbWcxZ3dkU2Z3YjVneGhTZlJlMWhUaEdlUmM5ZTBlYWJIYkJhemdaYnhlSmZuY0NjeGhJZ0ZhZmZFZ1llNmRVaGtjUWFMYWNkRmNwZENkYmgyYUphbWhhZVJnUmJ5Z1hjbmFNYk9nVGNCZDlmUmJWYmhnVmFHYlliU2dZZVlmZWExZnhiMGNHYUVnTmJDYWRnUWNGZnpiVWdsZ0VmcWhjYUZkQmh5YURmMmhNZ0FmRmRHZHhjR2VBZzNhRmRhZ1RmM2g1Z3FmQWdSZGtkTmRjZEVhSmVaZlVmQmJSYzZoVGF6ZlpiQmhjZTBob2Z0YmNnRWZjYytmY2NSZzBjZGdUZ1JhbGNXZmRoR2U1ZjJnY2UyZjlmR2RNaHhnWWNNYVRnQ2RkZ0tiRmJsY1JhRWVBZHloSmRhZFhjMmI4aDJoYmgzYkljK2djZ2tmNWJ6aEVnRWh4Zk5oVWZVYmtnVmVUYmplOGQxZFNjbmNBYkViYmEzZHRhS2dUYm5hVWVSZWNnMGV4YVJnZWFIYkJiV2dQZlVkbGFyY1dobGFwYS9hTWVtZG9jSWROZ2lnc2ZiaENneWNGZXJoY2RnZGxjMGVLaGllTmJpZkNmaWZnZFdoTmRXZGRlZ2FaZ0hibGVMYUZkSGZFZGRiSGdVZTBhWmVWZ25lUmF1Z2ZoamhaYXZhV2YyZGRhQ2JXYWdiVWNtYlJkRWdNZEhnQmRrZ29oaWVDY0FoTWMyY2FlamJKYWxkRmVDYUJnSGRlY2hjeGNNYlJoUmNSZ0hnYWFqZ0VhNWhKY2xiY2hrYkRlZ2ZzZXVhU2RsZ05mMWVYZDNjMGJjY0FnemVjZGtmR2FTZ0JhV2dPY3hmY2VkZ2FjbWd3Y1RkZWhGYU5oUGVaZkdkcGNUZUdhUmNOZndiVGVoaFVkRmdWZTNlb2JjY1Rka2ZGaHVmU2NtZVJkNWdTZnhjUmh4Z0hoUmgxZE5lR2RRZUFmMWJQZEhiWWg4Z2JlMWR0Ym5jUmJCZ0poQmZkY1JkNGZMZGVhRWdRZkxiY2RGYXBmQ2diYzJkSmhtZWFlUmRSZXlnVGZqZVljUWZVZlVkMGNmZURlRWZKY09iSmMzYnhlWGdmaEVkRWJpZ0hjZ2JNYktoZGZRYkZhNmFWZDNjdGU0ZGNjRmFaZzBnRGQyYnRoU2FGZUhoRmNHZEVjM2RnYVZnQWhEZVpicWRXZTBmOWJTYkliZ2ZzZ1JiVmZnZjlnNmJWYzNiOWhCYUlnVWFwYTZmZWNRYU1lUGhjZVJmWWNXYkJhUmJCZ1dkTWVSZ1ViK2ZEZW1nOWFiZFphMGhKZ2FjQmVTYVlmeGFXZEZjSmVQaENjeWdRYm5iV2JVZ1ZjaWVaZG1ma2FVZmNna2I1ZXpoRWdFZHhjTmdEZ0dkTWZWaFRibWdsZjBiR2hIY0JmQmZkZ0ZjRmNLY0hlRGRCY0ZhSmVoaDRhZmNlZURlVmNOZFhkZ2U5aHJmVWdoZFJmeGVSZWhjTmc0ZURia2haZW9nUWRGYU1hWmhFaDNmQWZMZ1dhVmFZY1NnZWZrY2Rnc2NEaDJiQWJhZU5mamZZZ2ZjV2h5ZFZmRWFUaFFhZ2VYZ0JnRGJFZXZkTWJnZlloR2ZDYURjTmE2ZWRhMGF4ZW9mU2JsZ1liSGdDZ2thZ2ZrZ0Vod2UwZWhmWWRtZDRmOWRHZEhoSWNjaGZleGdBZEZlUmNGZ0VhU2JQYzBhNWZwZGRlQmNoaHdlUWFYZ1JmUmFTZGtoNWIxY0VoWGVzaFlhVWRXYlZhd2ZSZm5jUmFUZGFnd2hZZWRkZmFVaFliYmdLYWxiTmhTYlpiSGVwZlRkUmNSY01laWFBZ2xkVmJXY1diM2RvYmJnT2ZFYUVkRGJRYmphQmQxZVNnMGNaYjloSGJVY2thRmVVZ0FiVmI2ZUljamVNYjliS2hCZUlldmNIY3dibGZtZmRlVWZvZVFmVWJrYlFnTGRjYkZkcGFDaGJnMmVKZW1oTGUxYnNhZ2NUaG5ndGZHZURjUmY5ZlJmRGdCZ1ZiVGNhZ1NlQmhRZE9hUmdJYVBlQmZUZmRhQ2NkZ1ZkNWd6Z1VjVmRGaHBmZmRGaFloOGZEYjNkWmRTZUJhR2hwZ0dmR2NIZ01mYmZUYzNoaGVxYUFhUmRrZFZiZGFnY3RkUmZHYVJhSmF3ZldobWdSZlRiZWIxZXhhdGFZYWtkc2FkZ1djeGYwZmRjVGJSYmxkV2dkZEdoNWEyZGNjMmQ5YkdoWmF4ZFloU2FDY1hlVmRCYkRnVmdJZVFmUWV6aGtoSmFPZVRjdGVpY2JoV2NsYmNiRGMwZDVlNWdFYUFnTmVXaGVmMGFrZlZjVGJtYmxjMGhHYkhnQmhCZmRlRmZGY0tkVGFpZ2RlVWFKY3hka2JEZU5hbmdBYlRiYmN5ZlZhcmdVZ2hhUmZ4YVJlaGFOYjRjVWYwZTlla2ROZjFkb2NWZ09mWGZBY0xiV2dWZ1liU2RlZGtjZGJrYlFnV2c1ZUNlS2RuZWNhYmhSZmpmNWVKaFVoaGNsZ0FjQmdqYUZmZ2JKaERiWWZ1ZkFjaGNKZy9iWGFCZGdkWGRMaHhoQmVQYlJkRWIwZ2xkRmhBYkVoN2NLZXlla2RuZ0ZmSGVvZWFjZmV4Y0FkZWNRZ1ZiRWNBY0hjRWI0ZXljWGFoZmhod2ZRZlhiUmJSZVNka2c1ZjFlRWJYYU5mTWJVY1hoQWZraFZmbWZrZ1BiZWgxYUpnSWFjYlJkSWNhY2RlRmhOZ0hiTmdtYXBhT2ZHYlFhTmV3Y1ZoMWhrZ0ViR2YzZ1pmSGhMZ1VjRWh5ZUZjbWZRaFVmUWQwYkJlOWJIZlVnOWdCaEdoUWhJZDhiSmJ5ZlZjOWZJY3djTWRwZlVmVWJZZ0VoZmRGYUViNmFVY2tnUWZMZ2NoRmVwZENhYmYyYUpkbWVhZVJlUmJ5aENnRGR4ZENoVGhFYVVmSGNDZEVnZGhPYkxoSGhRaEZmY2ZCZFVlOGVHaEJna2IxZUliUmhGZDRiVGJGZnhnMWNJaGljdGE0aERkeWJSYlNlQ2JYZEZoWGRDZkhlZ2VCaFRnM2hwZXFoUWF4ZWtoVmNkZ2dmdGVSZ0dhUmRKZ3djV2JtZVJlVGZlZzFleGd0ZVlka2VzY2RlV2J4ZjBkZGNUYlJnbGhXYmRlR2U1ZDJjY2YyYTlnR2daZnhhWWhTZUNmWGhWaEJjRGFWaElnUWRRY3pna2NKYk9nVGV0Y2ljYmhXZGtoWmhmYnhid2VPZEVkRWFaYU5hSGRsZUlnL2FUZm1jbGUwZUdiSGVCaEJlZGVGZUZmS2JUYW5nVWdSaElhUWNrYUZlTGdTaEliWWJkaEVhcGd3ZWVnQmZSY3hmUmdoYk5oNGNVZDBlOWFrZGFhbGNOZUVjR2NuaHdkaGNXZFZlWWNTZ2Vma2hkZWtoUWJXZDVoS2VaZ0hjRWVGYkdnaWNGZlBoVWNoY2xiV2FBY2llMGIraE1hM2gwZjlnQWJ5Z1piU2ZaYnljVWc3ZkhjZ2ZoYVNnV2FRZHNnMmFEZndjd2hzYU5kaWQ4Zm1lV2FuZUpmR2VKZ3hheGhNZUhjMWhoYkpiVGNtYVJncGhkZUJmaGd3Z1FoWGhSZFJlU2JrZjVoMWdFZ1hnTWJlZ0ZoQ2d3YWxoQmFEZG9kUGJPY1ZlSmJJYUxiVWZaYytmY2FBZWRmRGJaYkhhdGVmZUdmVWdjZDRmUWhnYnBlWWZYYmpkOGVKYUlheGNVYm1mUWMyaGhmNWJIaDFnd2U0ZVRnbWJZYVpkWmJFZzFoZWViaG5hWmh6YWJiMGhaYW5kRmRoYUpjTWNkZ1JmY2VaZVhnbWE0YkxoY2hGZnBnQ2JiZzJnSmFtZ2FkUmVSZnllUmVqZTBmZWNIZUJmOGVlYUhlVmZvZmFjTWJDZVJmZGVmZmhiTWJ4YkVjQWQ0ZzdmSGJGZzhhbmhYYlVnY2dVZkZlVmVaaHBkRGd5ZDBhSGVXZmphSWJTZFdoamhjZWRmVGIyZHdjK2NYZHhobGVCZWVjUWZzYkNnZmZCZkpjNmJSZzJmUmdCZmJla2FwZ2thZWRVaHNlVWJjZ1VoOWJZZUdmVWV3YkVoT2htZTRka2NjZXplTWNhYVpjM2RzYWFoR2JIZGxjS2dBY2xlNWhFZVhjemdnZlRoRWZXZEVldWZJY3loZGJUYUpoZ2ZaYzZiSGFFYndiWmhHYVFlQmJHYU5iVGcwYkpoR2NDZnhjQmZmZ0FkVWhDaEJieWVaZ3FhSmQwZXhjYWVlZEdkRWJyY2RiQmROYTNmVWVnZHhkNGNYYlRjbGU0YlVhMGY5ZWtnYWVsZE1hWmRFZDNoQWZMZ0JjRmI4ZGVnVWRFZmRna2ZRYldhNWZLYVpiSGVsZExhRmVIaEViVmJVYzBjTmdKZ0JnRGhzZzZjT2hTZGNkMmFGZWlmSWJZZ1FkQWFrYjBoRGdtaFViN2RDZWxjOWJoZFRkQ2FBYUtmWWRuZ3RjcGdVZWlnY2hBYk1oRWRRYkZmQWZoZTliSmNIaFJlcGdsYWRoRWRwZDViUWZTZDloN2ZTZWtiNWgxZkVhWGdOaE1jVWVYZWhld2JWZG5iUWRQYU9oUmdkZkFoSmNCZlJoZGJlZUFmRmZQZE9kRGNaZVRiZGVCYXNoa2ZCZTFmbGFFY0hjbmVvaFRiTGZBYWdhOWNSYkNnZ2c4Y0JmVmNNYmxmVmhSZlJmQmZHZFZmNGdnYkpkamg4ZGdmRmNCZ0ljYWdGaGdjNWNRZWRnVmZJZVpiVWdoaGdiTGRKZEJoSWFMZVBnQmRrZnlmYWJSZjlieWRYZndmNGFMY1pia2ExZ1JmU2dSaFZkT2FhZlhlUWRZaGNkRWJFZXBnV2ZFYVpha2VkaFJkRmN6aFRhRmhGaDRkY2ZGZ1pmMGREaDJlTWRjaEdjaWVFYVVmWGNDaHdnY2hHZ3pjMGI2Z0ZhaGdkY0JlTmVVYW9mZGJJYjNic2UwZ0VjM2dkZVRnQWdpZjlia2JaZUVodGJTaEphRmFOYWVhR2ZWZkFiWmVPaG1iNWUrYUpmMmNOYUdmTmRSYzhhU2VGZTFiOWZLZEVnRmJKYkVhQ2EzZkJmYWRRY21jOWNpYVphbWJsZEdlTmh4ZW9nbWZRZWdlSmdOZ1dhV2RNY1ZkVGdtaGxlMGRHZEhoQmFCY2RmRmZGZktjVGVuYlViUmNjZHhjNWZSYkpoQ2F4aFdlR2VRZ2NkL2hYaGhoUmhsYVNkaGRNaHNkR2R3Y1ljM2RaYUJiOWZjY1hiVGNkYWZjRWJWYThmZWRVZEVlZGNrZ1FlV2U1Y0tiWmNIZGxiTGRGZkhlRWJkaEhoVWIwY1pkWGVpZ0FkbWJQYXlmQWdVZ0VlaGZvYVdiVGFrY3hkOWZIYWxoZ2diYkZjM2JBZmthV2JrY2xldmRjZ3hodGFwZ0NjR2I1Zk9hYWF4ZmxmTWZFY1ZjRmZCY1FoUWJZaGdoSmcyZU1ka2FRZ1hkOWhSY1doRGROYjFjRGhXYzllTWJRZEdmNWQ1Y1hjM2FRYUVmUWZWZElnVWVjYVVlWWhUZ2VoRmFOaFBoWmJHYXBlVGJHYVJlTmd3Z0NjMWFsY0hnQmJHYzFjUWZjZjFhTmMvZ1hnR2ZSZXpjU2gwZUFnNWNWYUVnNGYyY1RiVmZaYi9mYmZtYVVlT2JSZ1ViWmFuYkZlaGZKYk1hZGZVY29hUWFVYmtjUWRMYWNnRmJOZFphUmZXZEpkbWFhYlJlUmd5YVRmbmVNYVFkVGhFYTBjTWdRYkJkbGdrY2FnWGhRZllhY2hFZ0ZiMGNVYVVjcGFPYmRjUmZraDlnUWVnYUVncWZQZ3diSWQ3YVdmemJJZUNjVWNYZDhlVWFWY2pha2JYZE9jZ2EwZmtjQmZ3Zm9oQmhFZm1hNWZaYVNkeGhJZDhoRWhpZG9mQ2VPZGdkTWRyZk5kMGhzYWNoSmRSYkViZGVIZ3hlQmZXZExjMGVSYjJkY2gyYTloR2VaZXhkWWdTZ1RoSGFWY0toRWRGY0lmV2JUY2lkUWhQZ0VhQ2ZGaGlnYmdraE1jVWZjYmtmNWV6YUVlRWd4Z05mVWFVZ2tjVmFUYW1mbGcwaEdmQ2VKYUJiS2VBZzFlS2ZJYjNjMWRGZ2ZlMGd4YkZhZGhIYUFjQ2NQZkVnWWU0ZVhhRmRnZzBmQ2dGYVFhc2ZHZjBiWmNvZVFoRmJNaFplRWIzZEFnTGZXaFZoWWZTZ2Vka2JkZWtiUWFXZjVnS2VkZ1diOWNjY0FjMmVZZ1BjRGRGY3NiWmJYZUhjUWY2Z1BoamhvaDhjUGFUZ05kcmNFYWthZGVmZ1NmaGFCaFNjUmFBZnRid2NXZWtkSmh2ZVllbWFaY3BiRmVIaEplT2hjaHhiaGJFZUdjUmZrZEFmUmRqYlVnOWFkY0JlTmF3Y1VkQWVsZFJoVmhsYkpmMWZBZUdoVmdGY1ViU2hSYndkWGNpYUJoSGVJZ2doRmZ2Y0poVWhZZllmZWRFYkVmeWJaaEhmWmNQY0djUWZ0aDVmQ2J3YVZjV2hSYmplSWVPZk5jemJvaDZoU2VtaDlmNWhXZ0dlbGQ0aE5meGExZU5mR2RWZlpmMGdiZm5jWmJ6ZmJlMGdaY25lRmhoZXRiWGJYYTBlb2RRYlVia2NRYkxoY2ZGaHBlQ2ZiYjJlSWg3ZFlhQmNoZ1loVGVuZk1hUWZUZ0VmMWNSYlNiUmhWYk9hYWNYY3hlV2NmZmhiRWdtYkhjaGE0YUJhSWNVYmdjamNDZVZlOGFxYk5lUmFjZ3dnWmNpZlVkR2NlZ0JnUmZHY0RkbmhnaFZlR2JpZW9ocGhCZTFmQmdjZVBlZ2R0Z1JoQWZoYzVkNmdGZldlaGRCZEpmMGROYmtmSWJtaEVlVWhjZlJkMGNkZlRkUmVsYVdmZGFHZjVlMmJjZzJkOWdPZU1ieGRZYlBnVGNHYlZmS2RUaEZnSWhRZUFlbmF4ZmFiU2JqZTFhaWFlYzJla2FFYWNmaGJKZ3piUWRraFZkQmJVYVFmQWZWYUVmamdWYTBnZGRYY2dkVmVlZ0ZiRWFZaFFmbmVWZEZlT2N3Z1ViQ2ZkZmpjd2hUYk9oa2dnZC9hR2ZoZjFkcWZiZkJhTmY0Y1VjMGI5ZGtjYWFsZU1hWmNFYjNkQWJMYldlUmFCYWRnS2ZFZ2Rjc2NGaHllOGVZY1poRGJ4YUxmQ2RYYUZhSmdWZlFlUmFLZExhU2RBYVRlZWJuZE1mZ2FSZW5ob2dXZUFkMGRCYTFhQWFoZ0JhUGdSZEJhdGNyZFdna2RsZWtmS2dtYVpkMWFGZUNjQmhPY2RkUmdaZE1nUmZSZzVmSmVIZTFhTmRwZlpjZ2MxYW1oU2JHYjlhUmRRZzJnUmcxZUViWGROZk1kVWRYZWhhd2JWaG5oUWJQZGFnMWdJZlVhY2dRaE1hVGdjYzBiNWdQYU1jQ2VJZGFnU2ZtZWdna2VDYTFoSmRXYldiZ2hkZEhjYmZraEViaGdVZlVnNWQ1ZVNheGFSZXhmSGZSYTFlTmdHY1ZlWmMwZmJlbmhZYWhmS2ZoaElneWNSYUZheGhNZ2ZkUWdVZFFjV2hGZmtiTGdZZlViaGFhZ1pobWI1YW1mTGJCZFJnc2FVZTNkTmNmYVRjRWR0ZFhhU2VSaDBoTGVhYlhna2JGYWNlQ2N3ZDFmQmFRY0poQWFKY1ZoNGJrZlJlRWFOZjBmY2VFYzVnMGhCZ1dmc2JBZEhkWGFoZktiRWR6YzFjSWJaZldlUmNxYVVmeGJrYVRlY2ZBZXRnWmdWZGhiSWhuaFRjbWVoZnJoYmhrZXBla2JlZFVlc2FVaGNhUmMwYmRkVGdSZUVoWWRlZWphNGRraFBkRGNzZEpjTWEwYjloQ2JDZlhic2dZZFZhUmZNZEFoWWJqZjRnT2dJZUFicGdpZ2VhMmJsYVNkSmJ3ZEFld2FSYUFiVWZDaEhlMGFrYWRmR2NtYVZlMGhTZW5keGVCZFBhVmNoYkthRmJWaDhlUmhjYzBoeGZSZ2VjSGRCYldoZGVBYjlmcmhVZmhhUmQ1YkVkaGZOZWxiVWExZjlma2JOaGxmTmROZkdkbmF3YkxhVWZRaFFlU2ZaZDBjZGcwaFFoVGNKZkthTmduaEJhSGRGY0RoZ2VkZVFhUmdFY1plT2QzYndnNmdlYW5iTWM5Z1NibWVkYkNkV2VnZlVobWVSYUZjd2JYYkNka2F3Y2tmRWdrZXRmMGVTY0dnWmNwY0ZmSGdKYk9lY2J4YUJjTWdUZVZlRmFKY0ZlUWRnaG1hSmhoZWhiNGdGYXphVWJEaFNiZ2N0ZjFnRGFIY01jZWNYZFhoZ2MvZFZmbWhrZlBkZWFsZjRnVWRPYVVlWWFPY2VkQWdjYUhnTGhUZGtkb2RUZVJmTmc3ZUNoMWNSZmJoVmh3Z2RmY2RaZEFkUmh1ZFZiR2JSYXBjU2R4Y0piM2hIZlJhVWZDZkdnVmV4aHBkYmFtYVJibWRlZlVkOWc4Z0ZnaGd0ZW1lZGVVYm9jUWhVZWtiUWVMYWNnRmRwYUNmYmUyYkplbWhhaFJmUWg2Y1RlbmNnYk5jVGFCaGtmWmZBaEVlWWYxZlBjWGNRYVRmY2NFYXhmNWdGY0RkZGVPZmZheGVFZjhoVmczZnRiNGhjY0ZhWmIwaERnMmR0ZlNiRmFIZ0ZmR2JFZjNhZ2RCYUNiamRBYS9nQWdWZ2NiVGdlZkVhUmdaYVhjQWc5YjZoVmJuZ1poWmdaZzBnWmZrYk1hVWNzZ0tnYmJCZzFjU2ZUZFJjOWdRYWRjR2RZYythY2MyZkphYmdaZTNodGZUYkdhRGQxZ0VjUWJCZzBlVGdBZTJiSmZXZlFkbmVkZmloYmFHZGxhR2ZlYjBjZGMvZUVhQWZSZFdoZWMwZWtoVmFUZ21hbGQwZUdhSGRCZ0JiZGVGYUVkWGZSYjNha2E3ZmNjMGd4Z1JkZWNIZkJiV2RkZUFjOWhyY1VmaGd3Yi9lU2FFZE1hcWZIZEJoc2VyYVBkZ2FwZUpiVmRuZzVkWmFIY0JiZGNXZ0Vid2FrZndkV2VXaDVjWGNaZERiOGdlYldlamNKYUpnVmVBY0poWGZWZG5ld2M2aGVmbmFNZTlnVGQyZ2RiTmFPZEVjeGYxZlNmaGJCZ1NnUmVBY3Rkd2hXaGthSmh2aFliamRRZnNnUWNDZGNkY2VQYVJjQmJFYlplMWRGYUpjRmFVZjVlcGRkaEJnaGF3ZFFnWGNSZlJlU2VrYTVhMWFRZjNnTWVRYkRjWGhnZ2RlWGdpaEFkRGhhZjBoTWVZZ2NoUmRKY2JlTWNRY0JjQmJLZUNjOGVkZlhja2djYjRmQWJsZlZoOGRFZm5ncGRIYVpnRWNGZHVkU2NtYlJnNWZTZnhhUmR4YkhjUmYxZmNoQ2YwZzVlMGVhZUhmWWRuYUpjd2E4ZTBkYmFVaFlkeGVkZlZkVWdRZlhjMWNVZ0xjZWZsYnBlS2RmYVhmZGZ6Y2FlUmNsYXljR2VqYXRoWmNIZ3pmWWNGZ05lQmFWY0ZmYWJXYlVmUmNjYUZidGUwZkJjUWdJaEhnSmNtYW9ibmJNZ1hidGY0ZGNhRmFaZzBkRGgyZHRhU2dGYkhhRmVHaEVjM2doYmFnVmNFZjVmcWZVYXhna2JUZGNoQWh0YlpjVmJoZkpkNmdHZm1kMWhOYlJiRWVwZ2tmZWdVZXNoVWRjZ1JhMGFkZFRlUmRsaGVmT2htZkFlbWFJZ1NoQWVTaEtlRWdKZkxiSGFEY0JoRWNRaGhmY2dGYVRneGVrZ1VlRmFuYzVlMGdDZmdld2VVZmJoMGQ0YTFoUmVRZkllT2RCY1FlQmJhYkFhR2VsYThhVGhIaHhhQmVKaGxoaGNLZkZhVmI4ZFJlY2cwZXhjUmVlZEhnQmFXZWRoQWQ5YnJhVWFoZ1FmamJSYmtnOGJrYlVheWhKZHNjUGhsZjhiWmdBYVhkd2hMaERlUmY1ZWJnS2NVZGthb2dCZkNiQWVOYk1kRGdGYUNkRGMxYnNlZGdIZlVkMGVaYlZibmdSZXVoZGFuZ05ndmFSY21iZGhBYlVneGY1ZzFnQWF4YUJnUGZSaEZkOGM0Y0VoeGJFZVVoTmNoZHRlcGFTY0hkSmJHY0pkMWhnZEZhSGRpaG9kZGhGZlVkVmJwZVpnV2NWZXdjWGZXaGhkUmdVZ2toZGN1Z09mM2ROZU1mVWRYZGhnd2FWZW5oUWVQYWFoMWVJZVVjY2NSYVJiV2RMZEFnWWVkY0tibWNwYUFoQ2Z3YlJnbWNFZjFjbGNRZ0VmamhOZ0hmZWUwY0ZnNmFXZUhmMWh0Y1VoZ2ZSYWdoQ2VnY3RjZGJHZlFocGMwYUphM2RaZ3BmYmd3YzljOGhQZUJhSmhNZWRkVWRvY1FhVWhrZFFmTGZjY0Zjb2dmZlpmbWc1aE1lYWJSYVJheWVUYm5mTWhRZlRoRWgxYVJnU2dSZzBiQWRaY3ljUmZLZFBieGFVYzdmQmhSZE1iZWVNYkJmOGRoZ0NjUmJBYThmR2VSZWdoZ2JIYm5kMGJ3YWNjWGRGaGJoRWF6YjRkR2ZBZFNmY2MrZ0dobGZaYmRjY2dBY01iTmVXZWhoSWZvYlRmbWJRZ2FlUmFFY3Boa2RlYlVmc2NVaGNjUmcwZWRiVGhSZGxnV2dkaERjeGQyZExjemROZ0dnQ2NoZzVnR2hRZkhmVmFZYkhjRmFJYlFoUWR6ZWtkSmRUaENmTWFuYktjQ2U1Y0FnT2RrZWRob2FPYWtkeGVOZVVoVWRrYVZiVGdtZWxnMGZHZEhnQmdCZ2RhQWJjY0xlSGZIaFZmWWFjZTFnRmVSZUxiRGJnYmZoSmczaFFjL2dVYWhoOWJ4YlZlMmQ1ZjRjRGUwYTlnc2ZQY2hldGZRaFFhQWV0ZmZmSmVGYVlhT2ZaY2tmZGc4ZVNlSGNWYmdlWmdIZGxkTGVGZkhmRWNkY0hhVWEwZVphVmNuYlJodWhKY0RlWWU3Y0VnemdWYVlkRWJsZzlmbmZYY1FlWmZLZ1JmQWMxaHdoRWYwZkpmd2RZZm5iSmg3Y0RjV2FaZFhiWWV3Y0ZiYmdXZTBlRmRKZFNkVWM0ZWdoZGZBYkpmd2ZDY0diOWc3YlNla2c1YzFhRWZYY05kTWhVaFhjaGh3Z1ZiaWVrZ0djWmEzZ2dkVWhjZ1VnWWFUYWVnRmZOZlBjWmRHZ3BlVGdFYVZlMWgrZVdnd2JzZFphUmZqY1VlVGFQY1JoRWZyYlJnRGRZZzhhQ2FsYkFnWWhVZzBibGJlYUNhemJvZVJiYmZtY3RjemVLY1JiTWdwYlZiVWJZYUZoT2NnZlFnUWNXYWhkQWVIZmNjQWZoYUxkYmF6aGxkTWRhZ1JlUmZ5ZlRlbmJNY1FiVGJFZjFmUmdTZ1JiVmFPY09nemVGZE1iSmNSYU1hNmNVYlViSmZraGRoUmhGZnplVGRGYUZlNGFjaEZoWmUwZERkMmZ0ZVNoRmNIY0VkVWZFYXljUWdQY1Rnd2JsZWliQmJ4YVViVGRaYkFjZGFaZkFnbGJvYXpiRmdHYW9jTmhLZndiUWJqYUxjUWNNY2RiZmhUZ2NiZGFUaFJobGdXYmRoR2E1YjJnY2IyYzlkR2NaYXhlWWRTaFRiQ2ZFZ0NoV2JRYkViL2RYZ3doMWNhZ0hma2NWZGlkWmRtYWtmVWFjYWtkNWd6ZkVjRWF4Yk5nVWhVZWthVmhUZ21lbGUwZEVhQ2NRYUpnUGRRZ0lheGNHZG5kVWJhZ2NhMWIwY3NjZWVHYnhmS2ZkZ0JnZGRpZFVma2NoaGJnUmdoaE5oNGhVaDBkOWJrZmFjbGhNZVpmRWIzZUFoTGdXY1ZlWWRTaGVna2E4YndmQ2JTYmNoWmRIZXloMWJMZkhjM2hFYlBkWWdFYjBjRmNTaG5jUmUvZFljSGVwaHZkR2ZrZDBnV2hFYmtmeGExZ1NlaGJCY1NnUmRBZHRjd2hXZWtjSmd2ZVlnbWdaZXBoSGVDZ1lkR2FPZmtiTWUzZUdmVmRGZkNhRmZWZTBnVWNkaEFoUmFzaFFoV2VaY0ZoUWcyY1JnMWFFaFhhTmZNZlVoWGRoZndlVmRuYlFjUGNhYzFlSWFkZGFjbWN3ZFRjZWZGaE5jUGRaaEdhcGFUY0dnUmNOY3diVmRsZ0JhYWNPYUhhcGRIYlpmRWNGZHVhU2FtZFJlNWZTYnhkUmI1YlVheGRNZmRoU2h4ZmtkZ2hJYVNnSWRxZ1Bhd2FOY3BmUmZGZmNiTmVNY1NjTmdlYkJnbGNjZ1poRWNqaDliQ2VjZW1kSWJnZlBnRmVvZXhnR2hqZ3BjZmNBZGtkMWNaYkhkUmNsaE9nT2QzZDBmWWJLaDJldGgwaFVoVWhwZ09mZGJSYkZoemJUYUZoRmg0Z2NhRmJZYm1kU2JqYThhSGJSY2phOWFHZ0doMWdKZFRoVGgyZFJlcWFVaHhla2NUZ2NiQWJ0aFpmVmdoYUpkNmZSY3pkWmRCaE1iaGdaY2thRmdFY05nQWJmZlJoMGdKYVFiUmhrZUNkUGhDZWNibGhmZlNkTWVEYktjVmRGZkdmQmFIZXhmR2JPaGxmSmJFZkNnM2ZCYmFmUWRtYTliaWJaZ21ia2VVYWNha2M1Z3pkR2VCaGdoRmJHZkJhcGV1Z0dhaGhSZzBoQmRHZ3hnQmVaZmtoVmNEZlRjaWZrYjdnY2UwY3hjUmRlYkhmQmZXZmRhQWM5ZHJnVWFoZlJoeGVSZ2hhTmY0YlVnMGhjYndnSWRoaHBnS2ZhZ0NkUWVMZlVkbGRZZURkQmMwZ2RjNGFYZ1doNWdiZ2NjbmNCZkxjU2VGZXNhZGZIZVVjMGJaY1ZnbmVSY3VnZGduYk5ldmFSZW1kY2ZXZkVka2V4ZzFnUWhrYVFoYWdEZ1ZhZ2hMaERja2NKZ2tjWWhuZlFiVWhGYUdkNWVTYmNid2RoZkZmVGVRaDFhamFGZ1VnNWhwZ2RlQmZoYndhUWJYZVJhUmFTYWtnNWgxYkVjWGROZk1nVWNTZ3diNGdIaHlkZGIwY1BiMWRJZ2ZoY2dWZVZkdWZVZ2xoTmFQZ1piR2ZwY1RjR2RSYU5kd2dDYTFobGFXYkVibmJOZ2NhVGZrZUZhdWZTY21oUmc1ZlNjeGhSY3hhSGRSZjBjUWhFYkZjcGNlYmJibmVaZHpiYmEwaFpkbmZGZGhnSmhNYWRmVWVKZ2ViWGVCaFJnWmdQY3djNGdOYk9memJzYTJjTGJCZW9jZ2VDZ3piSmVVYUtmZ2dFYWVhQ2VFZ0VjaWNEYkhoUWVGZWNiQWhjZWhlSGR3ZWtlYWFQZ0ZhNGI5YlRlRmhrZ3NlZmZGaFlmbWJCZG1hc2FKZFBlbmJGZ0dnRWczYWhlVGVUYzJiUmJxYlVoeGRrZ1RiY2ZGZmtkY2JBY2thY2NvYkNkV2FRY1RhYmRoYVloNGRlZVNmWWhjZkpkUmZFZWRiV2VSZ1ZlV2JJaENjWWUvY0llR2FFY0tnSWhsaGhoVmdHZURhMWVEZUhmRmRJZnpkQmFTZ0lmZmJBZ3lndGRxZU1naWFGYmRmSWFVZ0plemRSYUVkQmhOYlVlRmZrZFpiVGRuYnRkbmRGYkhjQmFWZ2ZkVWhwZWdoVGhuZlVkUmJjZTBjeGNSYmVoSGRCZVdkZGRGZ0pjaWFYY2pnNWZ4YVJhaGJOYTRlVWgwYjlma2dhZWxiTWRaZUdkemI0ZEZkQ2hRYVJmZGhMaGdiZ2F3Y0dkRGM0ZVBiYWRpaHNlT2dWYVRoVmc3YlVhUWJKZVloQWdoZ1ljTGZkaG1jNWd2Z0FjRGVKZFlnVWNSZWdlOGVCaFZnNWFTZ1RoRmY5YThhV2FoYkJobWdZYmphMWJEaEZjSGFKaE9mY2Z4ZEJoTWZUZ1ZlRmZKYUZoVWU1YXBjSmdsZzBha2dGY0NoWWdmYlNoaGJ4YzFhVGhTZTlmTWVQYUhhQWZrZVdhbmdRZ2JjWmgxY0poQWNPYlFiOWZBZGRnaGc4ZUtjS2RpZjBoSGRVYlJkcGc4Y0NheWE1Y1liUWREaDhhR2JJZ0Vha2g2YUFnaWMwYnFhUmV4ZFFnbGhFY1JlMWNNYUNnRmRwaDBhZmdHYlZiL2JiZzFhSmN1Y0RmVGFoYk1mZGhVYW9lUWRVYWtiUWJMYWNjRmFwZkNnTWdtZXRkcWFRYnhmUmN5aFRlbmVNZFFkVGZFZTFjUmhTYVJiVmdHZ0pjM2RwZEloSWJnZTRlZ2NIZmhnNGFYZkpiVmNSZDljSGVoaFFjNWhOYURlSWg3YldmaWhrY2VnVWFSZzBjamZFZzJoVmRUaENoVGFFZ2tjRWhFaDFiYWNQYTBnVmFaYVhoa2FaZzJiUmJ6Y1pjSWRiaGhhRmVPZmVhVWFzZFVkY2NSaDBnZGdUaFJnbGFXYmRmR2g1YzJmSWdTZW9oU2hNZGtnUmVjZFRoQ2VkY0tmVGZBYzVoRWNaYm5lZ2dPZlRjbWY5YzZlYWhtZmxiQWVPY2dlY2dnZEhmZ2VBZUlkSGF3YTVoQmhCYW1jQmY0ZUdiQWNkZ1BnSmZoZVFlTGhDZm5mMWRGZk9kd2FVZ0NnZGdIYUFiQ2NlZkFoOWRxZlFnaGJoaHhkVWZ3Z0ZoMGJVYTFiZGZ0ZGNiWGJrY1pkRWgzZUFnTGVXZFZjWWZTZWVja2ZkZWtmSGdHZmRkR2ZUZm5lbGNMaEZnSGJFYmRoSGdVZDBjWmRWYW5nUmdtZE9iSGgwYS9jRmVDYmhnQ2FYZVJmZ2RzYkdmbGFWYmNnRmZrYjRleGZIZ2liWWhnZ05heWRRaGxjVWRSYUFocmNjYndkMWZNaENid2FRYUhhVmNoZW9mZ2dPYzFkWmN3ZVNoU2RCZGRkU2FoZHhkOGRFZ1NkaGVtYVVlWGNoZXdjVmhuYlFjUGJhYjFlSWRVZ2NjVWFZZ1RlS2doaFlmYmdNZFRoZ2FkYUdoVWJGY3djVmF3ZVZmV2NmYjNnSWFUY2FhRWdGZDJjUmNtZVFldGFBYzFkMGRpYkViMWRFYUliVmR4ZkViZ2FKZ25hOWMvZ2JhemdGZ3BhUmhGZ2NmTmNNY1VhSmhFZUdhZ2gxYVlmZmhGaG9jV2VZYzJhSmJuaGVmQmVoYXlnV2UyaEVhY2NUZEZiVmdZaFViamM5aE9kYWhYZVFhWWhjYkVmRmIwY1VlVWVwY09lS2ZCYmhiL2daZmxjRmM0Z2NnRmFaZDBnRGMyZXRmU2RGYkhlRmdPZVhkWGNZaERmSGJTY3NmK2hIZ0VmMWVLYklmRWY1ZlhmQWVVY0FhemRFYnljRWgwaEJkd2FRY3dlRmNTYjRnVWViYUJmMWNiZEdmRmRjZVZhSWNDZmNkNWFQZFdmOWNPaE1meGNvYVNiSGRuZmxhS2RXaFZkNWNFaFRobmFsaGFmR2RVZFZkaWFaY21ma2ZVZmNma2I1ZHpjRWhFZXhnTmdVZFVibGFjYUNjR2VsYzhkRWRIaGdjVmFkZUVjeGVLZ1JiU2NFYlllZmUwYnhlWmRLZm5nQmVMYmRnQmQ5YnJlRGZoYlFkamJUZnhjOWI0ZFdnd2haYWtiZGQxZE1mSmhFZnlhd2ZMYUVkRmI4ZWVhZWVrZ1lkaGFTZ0diZGZLaFBoMWhOZExiRmhIZ0VlZGVIZVVmMGJaZFZjbmVSYXVlZGZuZ05kdmZSZmplRmRYaFFoRWh3ZjZhU2FnZzFlU2dLZVVnb2hrYUVoa2h3aC9lTGRUY0ZmaGhCZG5jNWhPYmFleGNCZkdmVGZSZmhmQWhGYlVmTmNwaFpjUWJOZ2FmUWVYZFJoUmJTZmtnNWgxZEVkWGZOZU1nVWJYY2hhd2RWZW5oUmJqaFljd2ZaZWNlT2FCZ1VoZmFlZkFkZGJEZ1poRGhoZWZhR2VWYnBkOGhDYXhlWmJhZEVmbWRwZ09jZmcyZHRodWVTaG1mUmc1aFNieGVSZ3hhSGNSYTFjTmFHZlZoWWZwY1JoSGhaZ3pmYmIwZlpnbmRGYmhlSmFNZWRlVWJvYVFkVWJoYkpkS2JJZ2xhb2RLZWJoM2U5Y21hZWVCZmhhWWFUYW5oTWhRYVRlRWIxYlJoU2RSY1ZhT2hhZlhjUWFZZmNlRWhFZzZnVWZWYmRhT2ZaZ1FhcGZaYVRkRmFGZjRkY2dGZlplMGZEZzJndGNTY0ZkSGJGY0dlVmFUaGNmQmVUYjJld2QrZ0dlMWVCYkFmQ2ExY2tia2dWY2dmOWI2ZVZoWGJGY1ViYmhraHhja2dMY1ZoQWFVYmVhaGhaYlRhVGVRZFZnV2JQZFdjNWd3Z2RnV2U5Z09jTGd4Y1lhWWZVaFhjVmdZZEJmVWNSYk5iRWFIZEJjVGZhZkdkOWdpaFpjbWZrYlVjY2RrZjVmemhFaEVheGJOZ1VjVWhrZVZlR2RpYUVmOWRTZndic2hUY2RiRmFwZEtjQWRBZWdoUmViYWtkeGNaZExjSGhCZFplZGVFYWRkaWFVYWhoSmh4Z1ZoQWFaZnRjU2dHZ1Zna2NhYWxiTWNaaEViM2RBYUxhV2hWZVlnU2NlZWtlY2gyZUJiRGZvZmZiTmFqYmRkTGdSZG5lRWFXYkhmUWdRZENhZmRIYlJldWdkYm5jTmN2YlJmbWJjZ1dhRWRrYndnb2FRYnhneGQ0ZlJlQWZ0YXdlV2VrZ0pmdmFZZW1jWmRwZkZiSGVvaEFkZmNVaEFmZWhBYWdiVWFHYlFjUmdjZzVmTWZSZ1libmVFaHplMGFGZURjemJzaGNoWGF5YmNidWNOZUhlaGJ0ZVZmamhKZmFhSmdSZkZjQWRPaEFnbGhkaGVmRmRzZWJjYWVHYm9jQmNGZVJnTWU1ZEJhMWNrY1RnR2gzZ29hY2FUYWtnRmN1ZFNobWZSZTVlU2J4aFJoeGJIaFJiMWVOYUdkUmE4Y3llYmduaDVnN2ZaYnhnSmFuZUNieGdKaEhmSWZVZE1hY2NVZ2tneGRaYWNiRWJkY0NmZmIyaEloNmNhZ1VjWmU3aFFkbmRNZFloQmNVYTFlTWNTZlFkVmNPY05nWGJSY1JhZWNVYzFjMGdVY0FkOWNIY2ZlQmhFZG9oWmdsZ0ZlNGVjZUZjWmgwY0RjMmN0ZlNmRmhIaEZnR2ZFZTNnaGRUZEdmU2VVZTRjVWUxY1liVGViZlFic2QwaEZnMGVZYXljU2NUZ1FmT2dPZlVhSmEyZWRkVWJzYU1iY2VSaGNoZGNCZEJiQmFXZWVhV2Y1Y25hYWJFYlZkR2daZnhmWWNTZVRmSGhWYUtnRWNGZEpnRWZDaDNkQmNhYlFnZ2FOaHFiTWNpZEZoZGhJZ1VmSmN6YlJiRWhCYk5jQWQwY1VlVmFCZzJkVmQwZ1ZoM2d4YUJhWmZGYmhkUmdaZkhkVWJSZWNmMGF4aFJiZWFIZUJmV2FkY0FnOWhyZlVka2hsZGJmUmNoZ05hNGZVYzBhOWJrYmFlbGhNY1pmRWEzZUFjTGJEaHhnZGhBYmVlZ2M5ZGthWGZHZjRmRGVaZUhoUmRMaEJkWGIwYTNlSGdVYTBnWmVWYm5kUmd1Z2RjbmJOZHZlUmVtaGNkV2dFYmtod2I3Y1NkZ2ExYlNjVmRSaEJhYWFXZ2tkSmF2YllmbWZaaHBiRmFIZUplT2hjZnhlQmZNZENheGc0aGJkRmdVZFlmOWJQYUZjRWFqYk9laWhaaFJiUWZVZzRkOWFiZ0hjTmFSZFViV2dwYWxjUWUzYVFlSmdhYndjWWhQZGNmVWVzZWVmTWNGaE5lUmFlZldjcGNEY0dmUmFWZzJhQ2IxY0VnWWFFY25iQmFhYlpmRmFOZjdiWGZHZDFnaWRTZXhoMWFiZ0hnUmcxZk5iR2ZWZVpiMGJiZW5mWmF6YmJiMGFaZ25nRmdoZElmWWJQZlFmTmJEZ0toUmdZZ0xjZWYxZW9jS2FFZG1nSmQ3Z2FjUmZ3Ym1kVGVuaHdnUWhBZmthUmRSZ1RieGhWZ2NmZmRHZkVoRGVXZmtnRmYwY1VnVWZwYU9hZGJSZkZkemJUYkZjRmg0ZGNkQWhRYnhmV2J6YjRlQWJXYW5jRWFVZkVlM2NOYlRnQmFuaDljQWhVYnhoa2RUZGNkQWJ0ZVpiVmhoaEpoNmVSaHphbGNJY1lnbWdCZWtjZWRVZnNjVWFjZlJkMGNkZ1RlUmhsZ1dmZmhDZ0JoNGFJZnpiMGhKYU1nMWRsY0djRmdTZFVlUGVIYmdoVWFXZ1FoaWhRY2ZjTmN3aFljc2hNZW5nRWRVY2JhMGE0ZTFnUmVRYUlnT2dCZFFnQmVhZUFkR2ZsYjhkVGdIYXhnQmNKYWxnMWZLYkJmM2h3ZVJnS2ZHZlplUmVlZEhkQmVXYWRjQWE5aHJmVWVoYlJneGZSYWhjTWZxYUZiaGJzYnhoT2JCZjBkWmVHYzFnb2dMYldoVmZZZVNiZWZrY2Rha2JRZVdnNWVLZlpjSGZsYUxlRmNIYWxmSmVIaFZjQWZaZ1hoU2NCZG5nZWhsZ2xmdmhSaG1kY2VXZEVia2Z4ZTFjU2NoYkJmU2ZSY0FjdGh3Y1dna2FvYjlhWWFuZnRkcGRCY0hlSWVTZGNoMGVKYkZoUWRYYXRiSmhGZlVkNWJwaGRlQmJoZ3dhUWVYYVJmUmNTZGtlNWExaEVjVGdwZk1nRGFTZ1Jkd2RPYm5ieGhiYkloeGZ0YUhjZmFVYlpoSGFkZUZlTWVkZGFnR2ZwZkNmRmJSZE5iaWhIZGtoeGNhY0VhbWVwZk9iYWFHY3RmdWRTY21oUmQ1Y1NjeGFSZXhnSGdSYzFhTmFHZ1ZoWmMwYmJkamFoZTljR2d6ZDhlWGFjYjNmWWV6YkZhRGFoZ2lmTWV6YzFoMGhBYXllOGR5Ykhld2QwYVVkSGZSY1FldWFFYW5hTWdZZkdiRWIxaE1kU2dYaGdnUGZQaFRhd2JXYk5hZ2EwaDdiSGdoZ2hjR2dJYVJnaGY2Y1FjSGV0ZzRkY2JGYVpnMGhEZTJldGdTYkZjSGhGZ0dnRWYzZGhoVGhUZDJmd2IrYkdjMWZCYkFkQ2UxYWtma2JWZmdhOWc2YlZiWGZGaFVlYmdrZHhja2FMYlVhSWdZYVdmeGMwZ2RmVGNSaGxlV2VkYkdiNWgyZ2NiMmg5YkdiWmN4aFljU2NIZW5hVmZCZUVjRWFOZ3VlQ2YzZ0JkYWFRYm1nOWdpZ1pmbWhrZVVoY2drYTVnemJHZlZjZGNuaFVoVWdrZFZhVGhtYWxkMGVHYkhoQmNCZWRiQWZ4Z0RjUWVsZzhnUmJjaDBheGdSZGViSGZCZVdoZGdBYzllcmJXZ2xlcGgvY0Zia2VFZTNnQmF3ZEFld2JNZ3dhTmFjZEhhU2RkY1pnRWRBZ0pnWGhEY3llNGdxaEZkWGg5YmNjQ2VCZXhnTGNDZVhmRmdiaFNmQWROaGFoQWFqZDBjaGFPZUhjTmduaEVnbWVzYldmUWVFZEJiMWNBZHhnbGZTZUhneWFGY3dnV2NrY0pkdmhZYW1hWmZwZkZoSGNKaE9lY2F4YkFiZWRDZ0FiVWhjZ1Jld2VCaHBjZmVEY0pod2dRYVhmUmdSYVNna2Y1YTFmRWRYaE5hTWVVZ1hnaGN3YVZnbmh4ZGJmYWUwYzhjVWRlZWhkSWJhZWRhSGJsY1BlWmdHYnBjVGFHZ1JkTmV3Z0NmMWRsY1doRWRuZ3BhSGdaZkVma2Y4ZFNjbmdsYTViV2V4ZVFhdGJIYlViOWRFYUZjWGd4ZzBoYmVuZVpiemRiaDBhWmRuZkZkaGNKY01kZGdVaG9hUWVVYWdiMGVMZExmQWRaaENmQWQyZm9neWNJZlZmMGJoZ1FkbmFOZUVlUWJFZzBiRGZSaFJnVmJjYlpkWGFRYU9hWmZWY1JlbmJSZUVhWmFPYVpiUmNoZi9nWmNsaEZnNGZjZ0ZhWmUwZkRkMmh0Z1NmRmRIZkZjR2dFYzNiaGZUY0FhV2ZvZ2ViS2FtYmxlMmVGZUhiUWg0aEpoR2JBYmJnUGdoZHNmeWdHYXpnb2VVZ0ZoamFsaGdmV2N4YjBnZGRUZlJhbGFXZGRiR2M1aDJiY2cyZTlhR2FaYXhoWWhTZVRlSGNWZ1ZmRWZGYnBjTWdYYnpiZ2JUZUVnUmVRZXdnR2IyYWtiSmdjZ2xoeGhtYUJoVWV4YkxjVWNSYTBnY2ZRZm1nbGI4YlRmRGhnYkliSmN5Ym9oWWZUYm5jNGZSYllnamNGZ1JhWmZYYUFmQ2VkZUJoRmIxYVRoQmVSYXBnVGh4ZHBiU2RVZjBlOWJrYWFjbGFNZlpnRWEzYUFiTGJXZVZhWWRTZGVna2ZkaGtlUWNYZ1JkS2RDZTNkRWJmZlhnRGZoY09lRWNVYTFnTmFXY25oUWE4aGVkbmhOY3VlVmNtZzRiYWhPZEVieGUxZlNoaGhCY1NmUmZBYnRod2dXZGthSmd2Z1ljbWZaaHBiUmRuYkpmRmNjY3dkSmFtZ1RnVmZGaEpiRmNVYzVocGNkZ0JoaGh3Z1FiWGhSYVJmUWIxZ1ZnZmRFYVhnTmFNZVVnWGNoYndlVmduY1FjUGJhZ3diOGRkZmZlV2F3aFRkZWdGZk5jUGhaZEdncGhUY0doUmVOZndkQWZ4Z2RoWWJRYmljZ2NJaE1hQWQ0ZzZoRWR6YVFlOGhSaFVoTWNqZVZkRWVrYkljYmREYjhnNmdPYW1lZGNsZ0RkU2FOYW5lQ2R4YUlhS2NJY0FlUmFUZUJmZ2UxZUViUGRsYnBmS2hPYTJiNWRtZE9jeGhoZ3ljQmUzYm9jUWRGZDJjZGhSZ1NkUmJWZU9iYWZYZFFnWWNjZkVoRmgwYVVhVWJvZ2NlTWZFZFVmbWdIYmhhOWI0ZmVnSGN4aDBkRGEyY3RhU2hGZUhhRmNHZUVhM2ZoYVRoVGMyZlJjcWhVYnhoRmhIZmNnQmJaZ1pjWGJVZFpjemdTZTBmNWdCZ2Jha2RwaGtjZWRVYXNoVWdjZ1JkMGRkYVRmUmFsZVdnZGZHaFloa2JjYzNlSmNHYmRleGhaZE9kVGNDZGRiRGFIaEhnaGdFaENoM2hCaGFoUWVtZzlmaWdaZW1ma2hVaGNma2Y1aHpkRWFBZFZmTmREYVJnVWdWZUlnbWVFZWdlVWNEY2toU2JlZUZlRWZlZFFibmRWZ0RiZmEwaHhoRGFkY0hmQmJBYlloUmFwZzRiUmJ4Y2hkeGdWYmhlcGQwY2VjVWg5ZmtmYWVsZk1kWmFFZzNnQWhMZFdjVmhZZVNhZWhrZWRia2dEaDJhQWIrZ0hmUWZrZXVoY2JBYzVhOGhiZnpnOWE0Ykxmd2hzYWRnQWV3Yk1mZmJLZFJkVmRpZE9nRWJ4YzFiU2hoZ0JkU2dSYUFndGV3Zldma2JKZnZlWWFtZlpmcGdGZUhiSmNSZmNheGVoaEVoR2NSY2toQWJSZGpjVWM3ZUNmUmJoZ3RlUWZTY0JiUmJWZ0ZoQmhyaEVhV2h0Z0ZhWGFYaGhnNGVBY2poeGNHYU9iQ2RsaEdkY2RVYjBiVGdhZlNkNWJQaGVhV2ZwYUJlRGVBZFpld2VEZVZna2ZDZkdjM2hOY3RhWmRFZUZldWRTZG1iUmE1YVNjeGdSYnhlSGFSZTFmTmdHZlZjWmgwYWJhbWN4ZnpoQWRFZzRkemFYZ2xlc2RmZmVkVWZwYkVnWGdrY1JmWmJmZUZjcGFEZWZlbWZ0YXFiUWh4ZVJjeWZUYW5hTWVRYVRoRWExZVJlU2NSZVZhT2VhY1hoUWVZY0lka2hGYS9nVWVWY2hna2RkY1JnRmF6ZVRnRmJGYzRjY2JGZVpjMGFEYTJhdGJTYkhhV2VwZ3NjRWgzZmhmVGdUZTJlUmFxZFVoeGZrZ1RoY2VGZVplUWNXZWpjaGI2ZlJmMmZSYUJiYmNrY3Bma2hlZVVkc2JVZWVlVmVNYlRjSGZVZXNnWmNJZ0NnRWNpY0tkamI4YkRiYWdVZkZjQWNCYVNmRWNQYlplVGJzYktnWGMyZk5nSWFMYmdmcGNpZGVkMmdsZ1NhSmJ3ZUFld2dSZUFmVWNDYUhlMGFrZmRjR2VtZlZnMGVTaG5leGZCY1BnVmRoYUtkRmdWYzhiUmVjZDBkeGFSZ2VoSGZCZldhZGVBYjllcmFVYWhnUWFqZUFoMGRjZXRiQWRRZkZia2dZaG5oa2JaY0VhM2FBaExmV2ZWYlllU2VlY2thZGJrYlFhV2M1ZEtoWmVIZEVjZmFGY0did2VkZUZjaGVrZVFhV2VsZDVjdWdkZ25hTmZ2ZVJlbWNjaFdjRWJrZXhmMWhTZWhiQmZTYlJjQWdNZmljV2JsZzlkdmZjYW1kWWExYkZkQ2FCYkhnZmZ6ZnBmTWVUZVZmRmVKYkZjVWY1ZnBoZGhCYmhkd2hRZlhkUmJSYlNiZ2ZkZDFhVGhTYjlnTWRQY1hkQWJrZ0hnamMxZmNoWmMxYUpmQWJmZlVhWmFCZGRoRmJOYmJhYWZHZXBlSGZDY3dncGFrZUVja2Q5Y0JnQWVHYU5hU2JhZ0ViRmcrZlFnMmFoYVRnU2N4YVJheGhIZlJnMWJOZ0dhVmNaYTBjYmJuZlpiemdiYjBnWWVwZ0doR2FZaDFlQmVTYTljMGJMaFNiVmU1aEFiamNzZjdmRWRCY0VnVGVHZVdjUWJkaFBlQWVjaDZiVGVFYzFmUmVTaFJjVmZPZ2FjWGFRZ1liY2JFY0ZlMGdVZFVhcGJPYmRjUWQ1Z3pmUmdGaGtoc2dPZUJmOGJuZGRhRGFsYVNmSGQzaEZjVmhiYm5oaGZPYlRoemZCYnFiVGFRZWNnTmRjY0JnbGdOaFhieGQ1ZVFiUmMyZVJiQmNiZWtocGdrZmVoVWJzaFVmY2FSZTBhZGNUYVJkbGVXZGRmR2M1YzJlZWd6ZHNmT2RMZGtmVmRwZ0hibmRWYUJiRWVFZ0FmNWJDZjJiMWdhaEZnbWU5ZzhlZWJIZ2NhVWhZYjFiaGY2ZkhiR2JaYU5hVWVVYmtmVmRUZG1kbGMwZ0dlSGhCY0JoZGhGZUZiS2dUZm5jVWNSZGNiMGR4YVpjTGJEZWdoZmhKaDNoUWY1YlViaGU5aHhmVmMyZDVnNGVUZGtjOGV3Y2Fka2MwYkhjRGFYYkFmVGJVYkZjb2U0Z2Vja2NkYWtlUWJXZDVhS2RaY0hjbGNMYkZjSGFFYmRoSGFVZDBlWmhWZW5kUmV1ZGZlaWVjZG5iRGh6ZVJjdGhRZkRkRmYxYVZjeGFCY0FjVWVSYzVkd2FYZkVmSWI3YWFhMmE5ZERmRmhIYkpnT2NjZXhkQmRNZlRjVmJGYUpmRmZVYzVjcGdkYUJnaGV3Y1FnV2I1Z1JmSmZFaFlhaGZXYlRnb2ZmY1hkWGNnZmtmV2duZ1JkZGFaZDFjSWRWZ1lhVWM4Z2ZhVWJsY05lUGVaY0docGdUaEdmUmhOZ3djQ2gxZGxnV2RFYW5jcGdIY05ka2VGZ2xlU2FuZUJkVGJTaHhiUmV4aEhmUmIxZ05kR2VWZVpoMGNiZm5hWmJ6Y1pnbGIxZ05hRmhoZUplTWNkZFVob2NRaFVka2ZRY0xlY2RBYmRmTGRZZTBhaGRtZGFnUmhSZ3lmVGVuYU1hUWhUaEVoMWdSZFFoVmF0ZEFhT2FTZ1pnWGJKZkFhNGhnY0NlQmJvZ0xlZWcwZVlkaGhCZ1FkVWI5ZkJlVGM4ZzZhV2gzY2hnQWdkZGhoUmFHZURmbmJnY1ZjR2hpYm9lcGFCZjFlQmZjZlBoZ2h0YVJiQWRoZTVoNmRGZldmaGRCZkpmMGZOZWtlSWhtaEVjVWVjYlJlMGZkY1RkUmJsaFdmZGNHZDVkMmJjYjJkOGZVaElna2JKYkhnSGJqZXRoS2FHYkhnaGFFYUNhM2FCaGFjUWdtZzlnaWdaaG1ma2NVaGNha2c1ZXpiRWhFY1FiWmhVY1ZkUWdWYlJlVGgxZDlhRmFGaHBmQmRkYkZmRmNLYlRlbmVVZVJmY2UwZHhmUmdlZ0hnQmVXYWRiQWFjYzVhVWZnZGxneGRWZ2hiTWZrYlVoeGMxZXRhWmNuZGtlWmdFZDNlQWRMYldlVmhZYVNmZWFrYmRja2VRYVdnNWdLZ1pmRGZCY0xlU2NDZzBoZGJjYlVjVmVOZUhhamUwYTliZWZuZE1lN2RTYm1kZGNFYkhma2Z4ZWhlUmNoYkJjR2NWYWhjSmRrZlFmMWhSZTRiY2ZIYzllOGdHZEhmSmZlZmVnaGR4YW1iVGZWZkZlSmVGZFVlNWhwZ2RiQmZoYndkUWdYZlJkUmRTYWtiNGc3aEhod2ZjZTFjSWNSZjBlVWZLaFJmVmM5YkdkVGdOZHRmRGhqZ1ZhbWFDZ0NmTWRnaEZlaGE1YTVnR2hSZ05id2dDZzFkbGdXZ0VlbmhwZEhiWmhFYkZjdWZTZW1hUmQ1ZVNjd2J0YnhhRmhSZVVmWmJVZFJhOGJuaEZlU2dRZE9nYmUxZ3RmbmJRaGhlSmFTZ2FkMWVRYlFoUWVGY0FnQ2RmZ0hhQmhDYmJhMmdKYW1mYWVSZ1JoeWNUYm5hTWhRZVRiRWgxZ1JiU2hSYlZoT2ZhaFhjUWZRZEpoQWFrYTlmQWhqZ0VjY2hkY1JlcGZ6YVhkU2h4YjRhYmFWZFlnZ2REZjNoVmdNY0NnbmNGaFhnQmNYaEZkZmFaZ1doUmJxYlVmeGhrZVRiY2ZBZnRjWmRWZGhkSmE2ZFJlMmZSYUJhYmZrZXBja2hlYlVnTmFBYk9oVmVSYk9iTmJraHRiV2dmZzJmNWdrY0RibWI5aGJhWmQwZ0lkU2RVZG1odGVVZEVjRWRwZE5mQmYxaHBlYWNRZ21mOWRpYVplbWRrZ1ViY2ZrZzViemhFaEVkeGZOZVVhVWRraFZoVGJtZ2xhOGRUZ0RmZ2JJY0pjeWZvZllhVGJuYjRiUmJZYkRnRmZSY1poWGZCaEVhWWdSYnBkcmhWZEJmUWVsZFRmeGdwYVNkVWYwYzlla2ZhYmxhTWdaZEVjM2dBaExiV2RWYVlhU2RlZ2thZGhrZ1FoWGFSZkthQ2huY0VkZmNYZURmaGVPZEVhVWgxZU5oV2JuZVFoOGFlZ25jTmd1YVZhMmE0aGFhT2ZFYnhkMWdTYWhnQmNTaFJmQWZ0aHdoV2VrZUpodmRZYm1hWmRwYVJnbmNKZkZhY2V3Z1JlbWVUaFZmRmRKYUZmVWQ1YXBiZGZCZ2hjd2RRZ1hmUmRSaFFiMWhWYmZjRWNYZE5jTWNVZVhnaGR3Y1ZibmhRaFBmYWJ3YzhmZGdmaFdjd2NUY2VoRmhOZVBkWmVHYXBmVGhHYVJjTmd3YUFieGJkZ1lkUWVpZWdhSWNNZUFiNGc2ZUVjemVRZDhoUmFVZk1iamZWZEVla2hJZmNlQmJnaGdmQWRoZU5jemJjYmtjWWFoYlFhMWR3ZlBjSWVRZE5kZmFIZUVkUWREYUplRmhaZENhUGVXZjVibWJJaEJiaGF5ZENnM2dvZlFjRmMyY2RoUmNTYVJlVmJPZWFkWGZRZFlhY2dFZ0ZoMGdVaFVhb2NIZ01jeGhGZjdkUmNGY2toc2ZjZkVidGQwYkJnRGU5ZmJmR2ZIZ0ZhT2dRZ1hlaGdPYVRjM2hSYXFiRGR4YWxkQmZlY1FkZGdaZVZiMWJkZXplVGFtYVFiYWhSY0VkcGFrZGVoVWJzZ1ViY2ZSaDBoZGhUZlJhbGRXZWRnR2U1YTJhSmJTZzRmVWFaZjFna2JTZFViWGFVZG5hVWZRZllnTWNCYVNhQWNWaEZiV2hkZ3doYWVtaGtiTWhjZWthUmZ6ZldhVWN4ZUFiVWhWaGdmY2ZWYVVhTmMwZUdoSGFCaEJmZGdGZkZiS2FUZm5mVWdSZ2NnMGR4YVJhZWdCaHhoZWhJZUVhY2NpYkFjUmNoY3hiRWRoZjljNGFBYlVhTmNrZEloMWE4ZVpkWGZIYkFhR2ZXZlVmY2JlaGVoa2hvZnJhU2JIYlZhZ2JaYUhhbGdMaEZkSGNFaGRnSGVVYTBhWmFWZW5kUmN1Y0tlMWFsYnZmUmJtaGNmV2FFYmtneGIxYVNhaGFCY1NhUmdBZHNibWhHY3hiQmh2ZUtmbWNaZDBiRmNHZUpoQ2FXZVJmQmNNZ1RjVmZGZEpnRmhVYzVicGJkZ0JhaGF3ZFFjWGNSaFJkQmZFYTVkb2FFYVdnSmFBZ2VhM2VoYndjVmVuZFFoUGJhYjFnSWhVYmNkVWdZYVRnZWhGZU5jUGROaDJmcGVPaEdjUWhOYXJiSWFWZGxiV2FFY25jcGFIZFpkRWJGYnVoU2JtZ1JjNWhTYzFnSWcrZlRieGMxY0ZnVGdSYzRjOWZQZ1FkMGNoY0Vka2daaDZlRmVnaEJjWmVZZkVib2VXZlVlaGNBZ1FiY2VGZEZhSmFKYzJlSmQ2Z2FnVmIxZ3lhU2NIY1VjUWVSZkFjTmFSYlFid2hoYU9nZWcyZkVnT2VlZ1ZkcGUwYldkR2FCZk9hZGJSaEZhemNUZ0ZoRmE0YmNhRmJaZzBkRGQyY3RjU2RGZUdnRmJHaERlWGFnZUhnVGUyZEpoc2hVY3dka2ZUYWJoUmdaYUVnVmJrYUZiNmhRY1djSmVCYmZia2hwYWxlWmdGZllkVWNKZ1ZoVmJVZUhkbWVJZUVkZGJHYVZmMmJPZTJkOWFMZlpid2FkY3ZjVGRIaE5jTWdFZUZkb2dYZ0NmMmIxaGFnVWcyYlpmdWVUY0dia2dVaGNha2I1YXplRWhFZ3hoTmVVY1Vja2RWYlRobWNsZjBjR2JIZ0JjSmJJZEJka2VEaEhoUWI1Z0RiY2cwZmRmUmFNZEFoMWhXYmFlUWE5ZGphV2doZHdmbGdSZ2hkeGc0YkhnVWNaZmtlZGNFYTBnWmNBZTNma2NMYVZkRmFaZ0JlY2UwYmRhaWhRZFhmeGNmYmNnWGRCYlFlUGZuZEVnZGNIaFVnMGFaaFZkbmZSZ3VhZGhuYk5mdmVSZ2pmVmVUYlJkaGZrZm5jQmRCZ0FnQWZSZUFkQmh3ZUViMWJsYkZkWWZtaFpocGdGY0hnSmNPZWNleGJCY01mVGFRYnhhQWZHZldiUmdwZWRhQmFoaHdnUWVYZ1JkUmhTZGthNWMxYkdlVGExZ0NjQWdTZW9mL2hBY2podGFiZ01hZ2JKZ1JkZmd4Y0ZlQmZNYVFmY2FLZ0RlU2JRZkhhZWIzZFpjd2JGZmxha2hRaFJjemVRZUViTWVBYmdoaGJCZEdlUmN4YUhieGhoaHhnVGV4ZkZhTmNVZkZicGUwYktoM2E5Y3plTmhHZ3hhbmRGZmhmSmZNYmRhVWhvaFFoVWFrY1FjTGFjY0Zmb2hMZEtlV2RKaHVnWWJSYXdkbWFUY21nNGRRZVJjeGdsZVloUmJSaFZmR2hPaDNlUWFGY2NkRmJGYTBlRGdVaG9hY2hmYUJkMWh6ZlRjUmJSZHhiZWJWZFlmdmJKYldmdGVTZEZoSGVGaEdhRWYzZGhjVGRUYzJiUmZxZFVneGVrZFRoSmdrZ29lTGRWYWxjMWI2ZFdkbWZRZ3NhTGN4ZDRjc2hkZnhldGdiaEpnaGZVZlBhUWFSYmxlT2dkZ0dhUmQyZk9ibWg5ZExjWmV3ZGNiYmVWZjFhOWdLYUVnRmNKY0VhQ2gzZkJlYWJRYW1lOWdpYlplbWdraFVnY2hpZUpjN2dSZEFhUWNFZ0Fla2VVZVZoR2htYlZmMGRTZG5jeGZCZ1BoVmExZUtjQWZYZlVjY2VjZTFnMWdkaGVkSGEwYlpiZmdSYlJhQmFVZGhkUmV4ZFJmaGVOZDRnVWIwYjlla2JhYmxiTWZaZlRnbGNvY0xkV2ZWZlljU2dlaGtiZGJrZ1FjV2g1Y0tjWmZIYWtoZGRWYlNiTWdkZFZkVWMwZUVjVmRqZjFndWNlZjNnTmQrZVNha2IwYldhRWhrYnhjMWdTZmhoQmJTYlJjQWZ0aHdhV2drZEpmdmNZZ2lmaGJwZkNnWGVKZWZmZmF6ZHBnTWhUZVZlRmhKZkZlVWc1YnBoZGVCZmhod2dRZVhkUmVSZ1NhaGMxZDFmRGFIZk5nY2hTaGxnSmZ3Z1ZkbmRRZ1BiYWQxYkljVWFjZFVlWWZUYmVnRmNNY0plS2V6ZmhiVGJFYlVhY2c0ZFFoZ2NvZXRlUWdIaHBiTWRaZEFna2NUZFNlbmFsaDVoV2dRaEZma2FIYlJldGROZVRiVWYxYzBmWWQzZXNlN2FiZTFiaGU2YUZkZ2ZKYU1lY2YwaHdkUWNXZGdmb2ZMZ2Voa2RkZENhZmhYZ2Rid2FZYUFoOWR5ZVJnMWNrZlFiVGVFYzFlUmRTZ1JhVmFPZGFlWGFRZ1lkY2ZFZkZhMGJVZVZhcGJPZWFieGVFaG5kVGhGZWRnK2VjaEVkWmYwYkVlbmhaZFBhRmZDaEpnR2ZGaFhoNWVUZlhhMmhSY3JkVGRnZVFlVGJKYkViTWRRZEJoV2hrYW9lUmIyZTlnQmhKZmthcGd2Z2VlVmFwYnBjY2NSY3NoYmhUZlJmRWNGY2RlSGZOYTJnWWhtZ1pkS2FUaFJkWWFTZFRkSGFWZktoRWRGZEpiRWZDYTNkQmNhZVFnbWQ5YmljWmFtZ2tiY2FKaGdjWWc2ZVFnemdjY2ZnVWRVZEliVmVCYWhlUmUwYUJnWGhCZ0pnZmJGZWtnZWNUY25kb2JSZFBlVWRWYlJoWmFtZTViV2RaYkFiWmRyaFhmeGVRZmllVGh4aE5kK2ZVaDFmMWh4YWZlMWVvZkNkT2NYZEFiTGVXY1ZhWWZTaGVha2NkZ2tmUWZXYzVhS2haYUNnc2VPY1FnQ2FSZVBoVWMwZTFkTGJWZ25lOWV1ZVBhMmhoZ0ZmUmNtaGNlV2ZFZ2toeGExZlNnaGJCY1NmUmFGZ1plNWJWaG1maGR2aFlhbWdaZHBmRmhIZkpnT2FjZnhmQmRNZ1JnUmU5Z0hjUmJSaHdnbWdJZkZmY2drZkdoQ2ZRZVVkUmJCY2tmbmRXYUNnY2FKaE9mRGZZYmtlVGZuaFFkU2JhYXhkUmVCYVBhd2ZWY0hkTWJSZ3dlQmZaaEdlSWVIZ0ZjUmFNZ2lhQmIxZGtkZmZHYzNkb2RjYlRka2NGaHVoU2FtZVJnNWJTZnhkUmd4YUhhUmMxYk5iR2VRaFFieGRPY2lkTWdoaEliVWNaY3ZmUGNCYkphTWhkZFVkb2RRY1Vka2VRYkxnY2VGZXBjQ2hiZjJnSmJtYlllVWhCZXloVWMzZE1lYmFHZUVnUmVkaFljeGZWZU9kYWZYYVFoWWVjYUVjRmcwYVVjVWZwZU9mZGNSZkZoemFSaEFnTmg0Y2JkVmVaYWtiRGV6Z2RjU2ZSZW5naGRLYk9oWGFoZFRiVGgyaFJicWhVYnhia2NUZWNnQWd0Z1pnVmFoYkpnNmVEZG1iUWJkZk1ia2JvaElmY2hSYTlhY2dPZkVmNGNSYlRmVWIxZmFhZGdEZXhlNmJjZDNkNWhLZFpjd2VjYkFoV2czZmxnS2hIaFVhTmNXZUVnM2JsYldhYWFHZjliaWdaZ21ka2NVYWNia2U1YnpjRWdFZHhmTmRVY1Vla2ZWZ0FhR2ZjYkFoWWVRY0Fka2FFaENmNGVyaFBnQWdkZ3dlQ2hqaE1haWREYlFoQWJtYUdmM2cwZ2ZiVWVrYWdldGNSZWhlc2dzZVVjMWZKYWtmQmJ4aEpmTmVXZTNkNWNOYkZiUmFsZWRhS2ZFYjhid2RTZ0dkZGJHZlRlbmJsY0xkRmNIZEVnZGhIaFVoMGZaZVZmbmVSZ3ViZGduZE5hdmdWYW1lY2dJZ0VmaGdoYzFkVGhCY1pnU2hUZkZoOWV3Y1JlMGVKZjlmZGUzaE5ocGFIaDNjSWVhZWNieGh0ZU1iWGNGZGhiRmZQZDBlNWdwZmRiQmdoZ3diUWJYZVJiUmdTZWtkNWgxZ0VhWGZOZ01jV2RTaHdlNGJIYnlhZGcwYU9hU2g4YVVoYmVFZ1llQmNiZVVlWmdQaFlobWhvYUhhRWFCZjlkYWhDZTFlbGVXYUVobmRwYUhiWmVFYkZidWFTZm1lUmQ1Z1NieGdRY2piSGdSYlpjTmRDZ0hieGIwZGJlbmJaY3pnYmcwY1pjbmNGY2hjSmhNZGRoVWJvYlpoU2VXYjRlTGNjZEZlcGFDZWJmMmJKZm1jYWRSY1JneWRFYzNkb2ZjYlpia2MxaFJmU2JSZlZkT2JhZVhjUWFZaGNnRWhGYjhlSGcwZVFiZWdKZzFnNGFuZUFkd2NVYmhnSWVCYU5oNmRXZURoa2JiaFFnRGRRZXZiWGVTYnhhQ2FXZlFkZ2NQYVVid2RRZFRkTmJsZTRmWGJGZVVjWWV6Z0NiQ2VwZ0JjWmdoZTVnb2dlZVJma2NZYmNlVmRRZlVoVGNVYkpoOGRkYUdnNWMyZmNkMmg5YkdmWmF4Z1lhU2FUaEhjVmNLZFFnaGdjY1FlWGRpZkllVWFRZG1iZGNJZ1pjbWNrYVVmY2JrZjViemVFYUVieGhOYlVmVWZrY1ZkVGFtYWxkOGZUYkhnQmhjZWRjRmVvZmVoUmMzZGtlN2ZjaDBieGFSZGVhSGNCYVdmZGNBZzlicmRVZmhoUmd4Y1JmaGNOY3doQWJVZTljNWVhYmthTWhaY1RhM2NCZlpjVWhGZG9mNGhlaGtnZGNrZ1FjV2E1Z0tjWmNIYmxlTGhGY0hkRWJkZ0hjVWExZ1FmVmZpaGdieWRkYmhhOWRuYkVmaWU5ZWZmUWFVaEJmMWdIZWhkeGVTYUZhZ2hkYXdkU2dFZDVkdmVjZlhnUmErZUFnbWNWYUNoY2Z4aDFoZmZYZzBjWmRmZkRmVWVkZWxnWGNoZGhjd2ZRYlhkUmRSYVNma2c1ZjFhRWVYYk5oTWNVZFhjaGJ3Y0djSGJwYTdmRWRpYkpkeGJGYVRjbGh5Y0NhaWZFZ3ViSGFSZFVjZ2ViYUdkTWNBZ1pmQ2RzZmliT2VIY3BoSGJaY0VmRmR1Y1NmbWdSZTVnU2d4ZFJkeGFIaFJhMWNOZkdhVmhaZXJoYmJuZzViN2RPYXdjNGV1YlJiV2NrZmVjQ2NFZ29kTmZVZ2xnWWFlYVpkVmNwYkVjYmJ6YVphdmVaaFJiUmU2aEdnamh0ZlpnSGh6YVllRGhTaFJlNWFPYWViQWNrYVlnYmNVaEViZ2JVZlZiUmVRY2FieGNGZHJhUmZWZWhkU2hjY0ZkWmMwYURhMmJ0Z1NhRmVIaEZmR2VFYzNlaGZUZlRoMmhSZHFlVWR3Y01oVGZIYXdkTWZOY0hibGdzYXBoU2QyYVFjVmVZYmtib2IyY2RlVWFzY1ZjWWhSZVFiUmhaYXhjbGVXZGRkR2c1YzJlY2cyYTllR2RaZ3hlWWNTZFRoSGVWY0toUWZsYkpoUGdDYzJlSmJ3ZVFnbWY5ZGljWmVtZmtkVWRjZGtkNWF6ZEViRWZ4Zk5kV2FGZUlhL2FUZW1lbGQwZUdjSGRCZUJkZGNGZUZiS2FUZWlhZ2RZaGZlMmFaZFJhZWZIYUJmV2VkY0FiOWdyY1ViaGhSY3hhVGFsYjFoMmRBZXhlMGhyaFBoaGh4Y05mU2hpYkJkT2ZWaHdjRmFBaE1neGRNYmhiS2NDYkFoZWFkaFdoOGZwZWNhWGFFZkFkSGhRYnRnTWFHaERnY2Q2YVBkemV3Y2hjUmVtaDlkQ2ZIYWtnd2ZuZVJiaGVBZGJnVGJRZnNkcmNjY0VlSmR2YllmbWVaZ3BlRmFIYkpiT2VjYXhkQmdNZVRkUWdNZU1lUWJSY3NhN2NPZmhiaGc0ZGFnM2FSZ1JiU2NrZTVjMWFFY1hlTmVNYlVlWGVoZndkVmduZ1FoUGRZaHdoWWRVYWJmRWFZaFlkTGVGZXBmRGdUZW1icGZUZUdjUmFOaHdmQ2QxZ2xiV2hFZ25icGdIYVplRWRGaHVkUWhqZVpmNWRWZ2hoUmdoZUhiVWhGZk5oU2UxYjljNGFSYUhjWmd6aGJmMGZaYm5oRmJoYkpmTWRkZ1Vob2JRZlVka2hRYkxnT2dWZm9oZWJNZzJkSWJLZ1lhVWhBZzZlQmF5YkFnY2hUaEJjbGVkaFNhVWZkZkNhYWZXYVlhVWFjZUZiSmRtZFJlbGN4Y1pnZWhSaEZlK2FYZjBmTmR2Zlpka2M1ZTliQWQwZkZjU2FGZ0hiRmdHYUVnM2JoYlRiVGQyZFJncWFVZ3hna2dUZWNnRWhWZlhlSWRtZ3NoS2ZJZ2dmQWYraERnemhnY1dnR2ZEY0pocmVBZ21laGV0ZVBjWGdZZmtoQWFFaFJmMmFjZDJhOWZHZlpieGVZaFNlVGJIYVZhS2RFY0ZhSmFFY0NkM2VCZ2FhWGFXZzlmcWRiYWpnMWdjY09ieGEwaEliUWdqZEZnTmJUZ0VhbGhCY1RmbmhkZnFnQmZuY0JlWmNmZFZhMWZLYlJmaWNGZFpiT2ZoYzhmcWFLZG5nQmZkZmRhQmU0Z1doVWdnZWxleGZWYkFnWmF0Y1VhMGVsYmtiUGNsY29lUWRPZFhnQWhMZ1djVmdZZ1NnZWhrYWRna2NRaFdoNWhLZ1pnSGZsZkxkRmFIZEVhSGFIaFNmSWdSZ0FjamZ3Y25mSmRYYzlmdmRFZG1jc2dXYlFmRWZCZjFoU2V3YUZlYmVTZUNkRmJ3ZVdja2FKaHZlWWNtaFpocGdGZEhnSmZPZ2NmeGRCZE1oVGFRaE5kSmRIZGtjNWc3YlhjaGNoZndkUWJYYlJnUmRTY2tiNWcxZkVhWGROY01oVWJYZEZicmhmY0hiUWNQYmFlMWNJY1VnY2dVZFloVGVlYUZnTWhTYmJlV2daZzViR2RSY05ld2NDYTFjbGRXY0VnbmhwZkhiWmFFZWtlZ2JSYkRnUWJyY0JhRWdBZytkU2NVZlFhZGJYYkZjZ2ZqZlBmRGM4aG5oS2FpZThocGFRZmdoRmJlZkdjU2E4YVFjVGYwYVJmTmRKZVJiUWJCYk9neWVzZnBjSmR4Z1JnNmdHYW5hOGFRZkhka2dGYlJoQWZCYnhhT2ZNY2xiNGhZZWNlRWhGZzBhVWNVZXBkT2FkYVJjRmh6YlRmRmNFZHFnTmFRaEllaGFYYlNkVmFTYkhhRmN0YUdjRWUzYWhoVGZUYjJnUmNxYlVoeGFrZVRjY2NBYXRnWmZWZWhkb2N1aFJjM2ZsYkJlWmdSYjVkdGdkZldlRWZVZ2NoUmQwZWRjVGNSaGxmV2ZkYkdlNWcyYWNhMmI5Y0dkWmV4YTViQWVUY0djaGZLZkFjRmVJYVloQ2h5Y0poVGRUZGtlVmdpYVpibWdrYlVmY2RraDVkemNFZEVkeGhOZVVnVWhrYlZlVGNpY0JjMGRSZUNkeGNCZUdkRmNrZWVnQmdqZ3hjQ2ZmZDBod2JGaGRkSGhBZEVnZWhBZjloL2RYaGhlUmZqY1Zhd2ZkZXZoUmMxYWRjM2NmaEVkY2hPY0hhM2NBZUdoU2IwaGNoR2ViYVZkTmI4ZlVhbmZoYmVmZmZIZUJmSGRQZG5nRWdkZEhhVWYwZlpjVmNuZVJldWhkaG5nTmF2YVJkbWRjZVdmWGdFZUliQmJNYTJnQWQzaEloSGVRaFJlS2REZkFiT2ZHYXhna2ZhYlllUWdJZCthSGFHYkliNGJaYTFlRmFKaEZjVWQ1ZHBnZGRCZ2hld2FRZVhiUmNSZ1Nia2c1ZDFlRWRYZU5lVGNVZFhkQmQ0Z0FlamR4YUdkT2NDZ2xnR2hEZkVkWWVPYWVlRWdGY2FjY2RXZHBoVmZHZVVhZGc1ZkJhM2JOZldmRWJuZHBjSGVaZkVjRmd1YlNjbWNSZzVlU2d4YlJmeGNIYlJlMWNOYUdhVmhaZzhmT2dqYzRlNmVQaERmMGMxYkZmaGFsZ01nWmdEaGNnUWdUYjBkUmNmaGNkRWdSZGNlY2NXZUphK2RZY0JjaGdZY1RmbmVNZVFlVGZFaDFjUmFTY1JnVmRPZGFkWGFRYlliY2ZFZkZmMGdVYlVmcGFPZWZmVWhVYTdjQmZRZElhRGFJZGxoWmQvYURlM2VrY3ZnRmFHZHhnR2NSaDNiaGVOYlVkWGhwZHFiUWhnYzhjYWVmY0NiRmVaZVZnaGZKZzZiUmgyY1JnQmdiZGtlcGNraGVjVWRzaFVhY2VSZDBkZGJUZ1JlbGJlYkliQ2NZZS9mSWNCZlFoVWJaYXhoMGRTY1hjd2JoZEtlRGJWZklhUWNDZTJoNWZFZlhoR2M5ZHdkY2htY0FhZGhXZUVhNWh6ZEVmRWd4ZU5jVWVVaGtmVmhUZG1obGQwY0diSGJCZUJmZGFGY0ZhUWhUZGhmc2NaaEpmd2VRZlljS2YzY3hiV2VJZkFoTmdyZEFlQmZoZHhjUmh3ZU5oeGJYYTJnVmZrY2FhbGdNZ1pkRWUzaEFnTGdXYlZkWWFTZ2Vla2ZkZmtjUWVUYXhiS2RiYTNibGFmY1BjbmZFZGRiSGJVZzBjWmJWYm5kUmd1YmRhbmFOY3ZmUmJtYzRnTmRPZUVkeGUxZFNkaGRCZFNnUmFBZnRnd2JXY2tlSWd5ZmFnMmZwZURkRmZIZEpnT2VjZ3hhQmVNaFRnVmdGZEpmRmNVY1libmNlYmthZ2JpYURnaWZBaGVnSGFoZGNnbGZWYkhhMGFiY0FjemJFY2tiRWZ4aDFlQmZQYzBhRWRHaEVheWFNYlRiWmZWZE1kSmFNYVNmUWFRYlRnVmVvYS9jUmdWZWxoZWdSZ25kWmZIZ05la2YxY3VjQWIyYTFkNWZFZ0RlNWV4YkhiUmMxZk5jR2NWYVpnMGNiZm5kWmh6ZmJjMGJZYjFhVWQwaFljWmFKZndnUWhRZ1dibWU0ZUxhY2RGZHBnQ2RiYjJnSmFtZWFmUmZSY3lkVGNuZk1mUWNUZUVnVWJGZFNhUWFoYk9kWWZpZEFhUmJmaEdldGIwY1VnVWRwYU9nZGFSZ0ZnemRUZUZiRmY0ZmNoRmRaZjBhRGQyZk1kQWhGYUdoeGRHZkFoM2VnZlBkVGR6YVpjamZYYnpkTWhUaGNkQWF0ZVplVmdoZkpiNmFSYjJnUmVCYmJla2dwaGtjZWFRZUlkVWVMZlVkRWdkYklkUmhFYUNmUGNDZ2NkbGVmYTJoOGdTZ2FheGhaYUFjUWdIZVZhZWFIZ0ZnSmFXYkdkbWRSYk5oVmhuYWRkeGFjZ0hnMGhEZGZja2E1YytlQWRsaDFnWmFSZGxnMGhOZlhoWGE5YmdhQWRIaGxoTmdYZ2xkRmRLZVRobmJVZ1JnY2IwZHhjUmVlYUhoQmRXZWRmQWg5YnJhUWJoYlJodmJSZ2tlZGY0YlZoVWFsaGtkWWdnZ2NjWmJEY25nQWJmYVNiMGg4Y0djWWQxYUZkemRVYTNmZGRmZlphSGNKYUxiUWhIZkVnV2hIYlZid2dRZVdibGM1Y3VlZGFuZ05mdmVSYW1jY2JXY0Vna2J4YjFhU2VoaEJmU2hSYUVoVmQrY0xhamJzZmZlQmV3ZklhV2hkY1FmQWI4ZkVhbWVraHphUGJpYVFkNWFaYVNmRWJiZkFiRGZKZ3diUWhYYVJjUmJTYmtkNWgxZEVmWGVOZk1kVWRYZWhmd2RWZm5lUWRQZ2RjRmJJYWNkZWdSZUpmYmVNZFFiQWgwaE5iaGJkZFRmQmhCYk1ka2JDZjBiZGVJYkRiSGNwZFZmY2ZFZGhmaWFZZkdhUmQ1Y1NmeGdSZ3hnSGJSZTFmTmNHYlZoWmEwZ2JhbmZaaHphYmUwaFpobmdGaGhlb2JZZVBnUWJOZERkS2NSYlliTGFlZDFncGdUY0VibWFKYzdoYWFVaEJkeWdVYUdlMGJPZFRlRmV4aEhjUWVCYWxoa2dhaFhmUWVZZWNjRWJGYjBoVWFVaHBnT2hkaFJmRmN6YlRiRmFGZTRjY2NGYVpoMGJCaHpoOGNhZlhkU2ZJZjlmUWhYaGhiWWhUZTNkWWRYYVVod2ZRY1RlSmRBZHRjSGhTZUFleGc2YVhhMmIxaE5nUmJFYXBna2dlaFVkc2NVY2NjUmMwYWRnVGNSZWxiV2RkZUdoNWUyYWNjMmc5ZEdlWmR4aDVhR2NCZERod2VaZGFld2FCZEVlQWNIYkJmSmZQZzJiOWUvZFpjbmRzZ0JiWmgwZzVnMWZFZ0JmaGRFZVdkR2RNZlZhVGVtZGxoMGdHYkhnQmZCY2RmRmRGZ0tlVGRuZVVlUmVjZzBheGhSYllibmhBaDRlZmVGZXNmamFHZDBhZGc5Y1Jha2dkZDBnVWJ4YjFib2dhaGxkSWdJYUdnbmN3Y2hhV2FWaFlhU2NlY2thZGZrZFFlV2Y1YktmWmFIZGxoTGRGY0hiRmNQZ0hiVWZZY1pjUWRsZDVjdWFkYW5iTmJ2ZFJjbWdjZ1djRWFrZ3hkMWFTaGhiQmJiZFhneWVGZXdiV2FrZ0pidmNZYW1iWmFwYkZhSGFKZE9nTGZoYWxjQWVaZzFmRmhKZEZmVWE1YXBoZGZCY2hod2FRaFhkUmNaYkJjRWJBYWxjUWh6Y3diWWhIaGlhd2JwZkJnamJFZUJiUGdBY0JkZGNKZ1FiTmYxZU5nQmh3Y09nTWVBZllkMmFHY1FmNWV3Z1RnUWZ3ZFliVWhTZDRmT2FLY3dmOWN1Z1FnamVCYzFoU2MwaFpjOWdIZVZhUmhFZUdkUWcxYmVjYmZuY1pkemdiYjBoWmhuZ0ZoaGNKZU1jZGNVZ29mUWNBaEFoRmNmaEpnUWVnZ01jYmJ5Y2xidWRQY1Zhd2E3ZUhjWGE4Z1FnR2NFaEZjUmVHZXhlbGdPaGFnR2dRZlVhY2NBYmhkOWVTaG1iQmJPaGRiUmRGaHplVGZGZEZnNGJjZEZnWmgwZlVnbWVKY2VmUGFuYUZnR2hFZDNiaGJUZVRnMmRSZ3FnVWN4ZWtjYmZQZGdmVWJKZUJhRmcwYXViQ2NEZkFhWWdQaGdiOWRxZkxkaGRsZmRmSmZWZWhjN2hBZ1ZhWWJYYUlhQWR3Y1RnY2IzZEpnR2VJZ1VhTmVjYkRoeWZFaERmWGR4ZXhnRWdBZ3lhUmJXYlFmamYxY3VmWmZpZUFiZGZjYmhlVmFaY0VhRWh4YU5iVWhVYmthVmFUaG1hbGIwaEdiSGRCaEJkSmNoZlFmZWNHaHljZGZmY2Nod2FkYlpkTGhEaGdkZmVKaHdoTmdyaEJnaGVoZnhhRmJCZjlmNGFVYmxnNWdvY2FjaGVvYVFkQ2ZGZW9mTGRXYlZlWWhTZ2Vja2VkZmtmUWFXYzVoS2hPZVhjQmZIZFBmbmVFZmRhSGVVZTBnWmNWZG5nUmV1ZmRibmhOZ25iQ2hHaGxnR2VRZkFoTWdoY0JkVWhRY0xiRmFFYzVhK2NEZFJlQWZtYk5haWJNZE5hV2Z5Y2NiTWRQZzFnVWdnZEtkRmRGZlVlRmRRY2dkOGVPYWxnc2ZrYkNjRGJzZmZnU2VrZ1lnaGNIaFhmTWVlYVhiWGFnYzVkWGczYlJhVWJRZFZnSWhVYWNkVWNZaFRhZWRGY05nUGRaYUdmcGdUYkdnVWJFZjFoWGh3aHdmRWVYaEhkb2JOYWJoQmhVYW1oQWJ6ZmRmMWhTYTBmQmI5Y0hjVWg5ZEJnR2JWZWRia2RZaG5oWWE2ZFpibGcxZU5jRmJoZkphTWhkZFVib2FRZlVha2VRZ0xmY2VBZWRoTGdZZjBlaGhtYWFiUmZSZ3lkVGNuZE1oUWNUZUVhMWZSZFFnVmV0YkFmT2ZTZFpnWGVKZ0FmNGVnaENkQmFvZUxlZWcwZ1lnaGhCZFFoVWI5Y0ZkQmNrYmhlVGZTZmNmWGRkY2hlUmZHZERhbmNnZlZhR2RpZ29ncGVCYzFnQmZjZlBkZ2N0aFJkQWdoZDViNmFGYVdnaGFCZEpkMGROZGtiSWNtZ0VhVWNjYVJhMGFkZ1RoUmZsY1diZGRHZjVoMmRjZDJmOGZVZUlja2dKZkhoSGFqZ3RnS2FXZGxmb2FRYlFmemdrZEpnVGRtZDhhMmJhY21lbGNHaGZha2g1aHlkQWhVaEJoTmNHYUVjQWZPZFpoR2dsYzBiR2NIaEJiQmNkYkZnRmFLYlRnbmFWZE1mZWFraEJjN2RlaEhnQmFXZmRhQWM5Z3JjVWhoZVJheGhSZ2hjc2MyZVhnUmQ4aDJlSmZRZ2RmV2JSYnljbGZiZEhkRmhoY1JnTmJSZGNoOWhRY1hnTmhLYklmaWR3ZEZkVmF5aFZmVWRVYWdmTWhaaFhnaWZCZmlhZGJpYUZjamRSYmliNGZhYUVoZ2VsYjhmU2hrZnRoNGVSZUFldGF3YVdka2RKZHZkWWNtYlphcGFGZEhlSmNPZ09hbGVaZ01kUmhYYnRoSmFGYVVjNWJwZWRiQmdoY3dmUWNYYlJjUmZTZWtnNWMxaEVoWGNzYUZjVWRTZlFjc2JWZm5jeGZHYmFjMGE4YlViWWJVZThjZmZVZGxjTmFQYlpnR2VwY1RkR2NSYU5od2JDZTFjbGdXZ0VhbmVwYUhlSWNVY0VleWFGaG1hUmNwZVNid2FsaHNlQWVCZjBoSWZHY1Fnb2VvZWJjbmU0YjJhYmYxaHRhbmVRZGxhb2FGYkpna2hSYWNmRmZ3ZXBjTWNKZkJlSmhMYllnMGhoYW1iYWJSZlJoeWZUY25mTWRRZFRjRWIxZlJmU2dSYVZhT2FhZFNoWWVZZWJhbGZ4aDBnQmhVYlFiQ2ZNZEZmOGYwZkdjQmVsZzRjZGVsZEJkMGhCZHpobGZTY0NnWGRFYVNjSGRUaFFjV2RBZ1NlTWErYkdkeGhBYWZlV2ZnZ3RnWmNWY2hkSmI2ZlJmMmNSZEJnYmhraHBma2FlZVVhc2JVYUlieGIxZEJkRWdSZGxnZWVKYm1hNWNyYWNoM2Y5ZlBmYWR6Y3doU2VUY0hkVmNLZkVjRmZKaEViQ2EzaEJkYWdRZm1jOWNpaFplaWZ3Y1VkYmRFaDVoamdFZkVicGJMZ1VjUWJBaFZjVWNHZ2toeGRHYUhkWmdIYmRiRmhrZFBnVGhtaGdjUmJPYmtmVmJkZlVjbmVCYldkZGdBaDlocmRVZGhkUmN4YlJnaGVOaDRkVWcwYjlja2hMYzFkTWJFZURkbWMwYkxhRWFGZzhhNGJlYWtiZGFrZFFkV2I1ZEthWmhIaGxlTGdGYkhjRWhkZkZlR2djYVpjVmJuY1JodWJkZG5jTmZ2ZVJnbWRjZ1dnRWhrZHhlMWZTZWtlSWVYY0VnRmc0Y2ljRmdFYUpiL2NlZ1VleGhwY0ZoSGNKaE9jY2J4ZkJhTWZUYlZkRmRKY0ZoVWQ0Y2dkTWVoaGhnNGhVYVhnUmFNZlZoMWVOZDFjUmJYYTBjQWJGYURmWWEzZUFoamh3aFBlTmR3ZTRmVWZZYVVoWWVPZlpoVWI1ZFBoTWhDY0lnYWdTY2hhMGU4ZFRiaGJjZFJlUmhqYUpkT2haZUJjTWJyaEhkamhFZnJjQmFSZlJlaGRCYWplZGdOZ0dlVmhaYzBhYmRuZlpmemFiYTBnWmduZ0ZmaGdJYkZlTWEwaG9jWWFRYmtkUWdWZ2NnQWRoZkxjYmd6YllidWZPZTFmc2NsZlRiamIxZVZoR2MwYzBhamFDY0Zmc2RKYUxoQmNGYUtiSWVnYjRobWRXYVVhZ2JhZU5mRWZNZDBkQ2JRZlVhTGdKaEJiY2FtZ1djMmhzYWRmUWNTYVZmR2dYY0RmNWhUY0RnU2JzZS9lSGNWYTFnQWVjYmdnSmRDY2ZhQmFKaDZlUmgyZ1JlQmdiZ2tocGZrZmVhVWFzZ1VmY2VWYVJjYmRUYlJhRmhHYmRmSGZCaDJhT2ZtZDhnYWhPYnhjWmViaFRnR2Z0ZVhkRWJBZ1liTWVRZWloTmNVYkRnaWhvZHNnSWVUYzFjY2RlYTJjUmN6Z0VkRWF4Y05kVWRVY2toVmZUY21kbGgwYUdkSGVCZEJnZGZBaFVhQ2dIZ0RjcGdHZ2Nmd2FJZ1VnTGEzaEFka2JOZFViRWZzaEZhM2JFYWpmRmJGZXdhcWJXYzBhMGMzZEphUWJaZkxhVWNEYlZnNGZEZFJhZGdBZExka2djZHJoRmJEZ3BnS2JLZXpnOWNMYVZjamU1ZklnVWJ3YmxhS2JWYUhhMWUxZlhoSGROZ3ZhUmdtYmNnV2hFZWtneGQxZFNiaGJCaFNoUmFFZ0lkMmFXZGtncGIvYlllbmNoY3BlVWNYYnRkT2dKZDFoZ2RlZEFjZ2RaaEpkV2V3ZHNmK2hkaEdmb2d4ZERjemZNY1VoTGV4ZHdibmRYYmloRmRFYVVleWdzZS9kQWN5ZVpmTWFMZGpmZGZhZE5mVWhaYWNhTGZRZGRoUGFLY3ljeGRUYVdoMWZ3Y2xlUmhSYTBhRmhFZEhoTmVjZ1Rja2JGYXVmU2RtYlJnNWdTZXhhUmF4ZkhkUmExZ05iR2ZSZE5kMGZjZkhhWWhuY0pmd2c4ZzBmR2JGZDRjSmVPZndhMWZFZ0dia2NRZU5kZGVsZ3BiS2JLY21mSmQ3ZmFlVWJBZTZoQmR5Y0FjZWFBZEFkZ2dmZERoa2JFZEdoWWVIZ2djeWdjaEVmRmgwZVVjVWdwYk9nZGhSZEZlemFUZEZhRmI0Y2NjRmJZaGdiQWZTZGNlWGVXY2poWWJTY1dhM2VoaGVmVGV6ZFpmcWRUY3hnbGhXZWNmQWFaYVplSGh4Z0pmOGdRZ1dkUmNKY0tnMGhwYzVlZWVSYjhmYWdQYVZiaGJUZENka2QwYmVoZGRHYU5hMmRJZVdnOWVOaFpjMWU4ZmJnVmgxaDlmS2NFZUZoSmZFYkNmM2FCaGFjUWJtZTlkaWVaYm1hbGVDY01keGV4YnpkWGcwaEJhbmJVY1Vja2VWZ1RhbWNsYzBlR2hIY0JkQmZkZ0ZkRmhLaFRobmhWYVpiY2QxaEZoUmRQZ1hmQmhiYWRkRWFaYXdiZWRCY1JleGZSY2hmTmI0ZVViMGQ5YmtkYWhsaE1oWmdFZHpibGZOYldhVmU1YkdnTWdnZDRiM2NRYlhjTmdYYmVoWGFrZWZnRmhIZmNoYmRIaFJlOGNaaFNhSGZRaG5nZGNuZ1ZncGNSaGllSWZXYURnRWh3Zm5hUWV6Z3BiU2hSYkFidGJ3ZFdoa2RKZHZoWWFtaFplcGNGZEhkSmJPYWNoMWdZY0RhSGIxZUZnQmJXY2tmNWQwYWRnRmhCY3dlVGFIZlJlQWJVZ1VkNGQ2Y0VlV2IxZlJmVWdXZ2hicmNWaG5ka2hDZUpkRmFzZlVhSmZUZDFjY2NlZEZiaGdQaE5oaGNkZ1RiQmRCY01na2dRZXhlQWRGZGFkVGZWZEhkYmMwYUVibmROZDNkOWFUYVNoeGdSY3hmSGJSZzFoTmdHZ1ZlWmcwaGJhbmhaZHpoS2JnY29mMGNVY3hjSWVGaE1lMGNvZ1lnUWh3Y0VoWWNjZkVoUmhDZ0plMmJJZzZkTmhSZVJjemdBaEhiMWVraE5hVGcwZDBnTGVXYW9mdmFHY3dhWmM1YUNkVGc0aEhiSmVEZW9iK2hHZG1iTWFIZlJlWGZ0ZDRmY2NGaFphMGhEZjJmdGhTYkZnSGNGYkdiRWUzYWhnVGRUYnloSWdsYkFkUmNrYmJmUGV3YnRnRWFWYWdoSmhoY1JneWN4YkJlY2VFaG9jcmRZY2thc2hmZGVkbGVJZ1VlVGJVaDBjdGFPYzJoNWY5aGNlemcwYjdoWmV3YnNmU2hHY0RjMGFEZlFleWVrYkxlQ2YzY3RoYWNDZHhoSmg1ZVRkR2hrZ1VhY2ZrYTVoemZFZkVjeGROY1VoVWdrY1ZlVGZpYndmNGVTZHphVmNCY0FiUmZnaEVjR2htZDFhd2hJYVJjNGVRZklnWGg0ZEdhSmJrZ0FjL2ZIYlVoQWZvaEZkbGhaYzJhQWFBZ29id2NaZkJmQmFZY1hnemF3ZkRkRGNWZG9hU2RMY2dkOGF0Y0VkbWVBZFpnTWJUZnNhS2JSZGliTmdjY1JiRWZWZlFnV2VuYlFlbmhkZW5laGN2Y0RmbWQ0ZmFkRWZoZDViOGhVaFRicGZTYVJhQWd0Z3dhV2drYUpodmZZYm1oWmJwZEZnSGJJYWNkTmVrYVFoWmZIYXhnOWdKYVhlVmZWaERmZGhCY2hjd2ZRZlhlUmZSZ1Noa2E1ZTFmRWNTYTVoRmRYZ1ZkSmJ3Y1ZibmNRZVBiYWMxYklnVWJjYlVhWWVUYmNiQmcxY0JiTmJEZ2dnY2FUaFZkd2JraFVnZ2VraFRmSGNEZHdoT2hLZEFkMWJ1Z1ZiMmdRZC9jSGdsYm9heWhTZlZmUWZDYlZmMWdaYzhhT2JuZ3BmemZQZ1VmcGJuaFhjeGM1ZE1jTWJFYk1oUWVDZldkNGJMYmNnRmZwZENlYmYyZ0pibWhhZVJlUmh5Z1RmbmVOZlpkQ2VrZDFjWmRTYjBiWWVhYU9hemExZVdnTmUwZE5hMGRUZUZiZGJPY0lnVWdnZWpmQ2FSYTRjK2JjY0FiSmQ5ZkRhemRCaDRnRmVIZEZiR2RFZDNoaGhUaFRmMmdSZ3FmVWh4Y2tiVGNjYkFic2ZRZ0VjQmVKYnljYmdXaFJjQmNiaGthcGJrZGVlVWZzZVVjY2FSZzBnZGZUZ1JhbGhXYmRoR2Q1ZCtiY2ZUYndhU2ZOYVZnOWJjZENhM2JkaEtmRGNVaDlnRWhYYnlja2dLZEJieWFBZGtkWmdqZXNkK2NjY2thNWV6YUVjRWR4Zk5mVWhVaGtkVmVUZW1ibGEwYUdnSGhCaEJnZGZGZkZhS2ZVZVhoVWJaZWVld2NsZFJmWmVYZkFjRWdmYlFlTmJyY1dma2RaYXhnV2F4Yk5lb2VXZGtoTmhrYVlmaGVvZVpiRGFuY0JnZmVFaFJjOWVCaGRlQWhzYWhjRGZ5Z2tnZWNMZUhkQmJDZFBibmZFYmRlSGFVYTBkWmdWY25nUmF1ZGRkbmhOYXZkUmZtZ2NkV2FFZWtneGExY1NkZ2NwY1NlUmFsZmdma2hDZ0Fkc2FoZkpkV2NSY3BjQ2FXYTlkT2NKZzBia2djYUNkQmE0YVBiRmJRZWRlcGRjZWhjNWV3Y1NnWGN3Z1VmU2JsZk5iMWZXaEhkcGJBYlVkWGFBYzVoVmdtY2tiUGRQY3hmcGdkYUlja2RoZmZjUGhSZzBmSWhNYkNhSmdhaEVoQmI5ZWFhQ2QxZmxkV2ZFYm5ocGhIZVplRWVGZ3VkU2VtZ1JiNWhTZ3hjUmN4ZEhkUWd4Z05oQmRFYXRhcGdiZ2lhSmQ5ZUlmd2dNZnBjVWZVZlliRWRmZ0dhQWJRZVVna2JRYUxlY2RGZ3BmQ2FiYTJkSmNtY2FkUmFSZnllVGZuZW9nUWhGZzJkZGFSYVNhUmJWYk9hYWdYZlFmWWRjZEVlRmEwZVViVWNwaE9nZGhSZEZkemJHZmhiQWRxaGNnQmNsZDBmRWJtZ3NnR2dHZGpmSWdPZFVlaWdvZndhQWRDYkFidmVNY2thMGNiZFliQWJKZUNhZmRCZ0pjNmFSZDJiUmNCYWJna2NwZmtmZWRVZnNnVWZjY1JkMGJkZVRiUmNsYUVkWWhYZmhlMmJiZFdhOGNKaFpmeGJBZVVjVGZIYTBiZWRFZUVoOWNFZ1JiSGVsZEJlYWZHZjloaWdaZW1ha2RVYWNha2c1ZHpkRWNFYXhjTmdVZ1Via2NWaEVkMGVOZjBnR2ZIYUJkQmJkYkZmRmhLZFRmbmZVZlJnY2MwZnhlUmVlZkRna2VRYmRhQWhjZTlhSGZWYTBnMWJSYWdoTmM0ZVVibGJKaDVkYWVoZlllWmFGYlhhWWFMaFdkd2RWYUdoS2dBZDRicWZCZ21neGRLYlplV2FSZ0xjUWhDaGhjTmhXYkFjSmFmZVZjamhGZm5hWGFIZU5kdmRSYW1jY2hXY0Vja2d4YTFoU2ZoY0JlU2RSaEFhdGd3aFdka2FJZjdnS2dqYlFkbWFRYTNlSWhBZE5ja2dkZU1nT2NRZWdkWmJVYkNic2g3ZkphbGJjZ2lhU2NYY1lkVWdCYUFnMGQ2ZlZoVGdvYUNkRmhuYWdnOWhBY3lkZGFiZGFleGNCZFJkY2ZRZWNlVGRLYndlY2NkaExmU2hRZlVmR2d4Z3BlcmhJZVZibGRXYkVkbmVwYUhkWmVFZ0ZidWFTZG1nUmU1ZVNieGhSZ3hhVmFGY3RkTmNFZ1ZjUWhuZU9kaWNRYjZnSWFRZkZhbGhGZ2diOWFSYmRjUmI1Z0phQWRnYUZhRWJOYmxlb2RIYmJlMmZSYWdlYWJSYVVmOGdRaERhcGdEZktjUWVNZlNjQmJsY0VnSGdKY3pmTWdRaE5hVWdoZzljZWUwYXBoT2NkZ1JoRmd6YlRlRmZGaDRkY2dGYVplMGVEZDJidGJTZEZkSGdFZ1NmV2d5YW9kY2dHaEdkUWNrZ0Zla2g0YlRjQmVGZUljSmVFZDNkY2ZvYkZhU2VzaFRjWmZrZ2dlUmJOYndnQmZhZFBka2FwZFRhVGVWZHdhWWdOZnljRWV5Z09iaWhFYUJmZmNSZFloUWZUZEhmNWRLZFZmVmh0aGZnSWVYYkJmYWJRaG1kOWhpaFpnbWNrZlVjY2hrYTViemdFZkJjRmZOZ0ZoQWVWYkdlQ2IyZGxhMmdWZGloVWFNYk5naGJRZFloVGdIYVVmTWRiYWtnd2ZGYUljU2FBZFRnT2UwZ2xocmRCZmhiUmgzZFFoQmNOaHdlQmUwZzlhNWhhZmthRWhNZkJobmJBYk5oV2FRYUliYmVZZFdhMWZrYlFhV2Q1Z0tnWmFIZ2xnTGVGYUhoRWRkYUhmVWcxY1FlRWVIZFJobWJaYW5hTmN4YVJhamRVZldjVGZoaEJkMWVIYWxjZ2NiYUZhd2dVZThoSGV3Y3dib2VOZGliNWFwY0NoSGRJYWNoY2MwZndnUWdUZlFhVWVCZVhnQmQxZm5lT2VGYTBmK2ZCYWliQWJaY1NhbGdKaDFlV2hIY3BibWZVYlhkaGd3Z1ZnbmVRaFBnYWExYkliVWFjZFVhWWhUZWVlRmFNZGJoTGdEY2dhY2JUY2hoTWQraFRlZ2I1Y1dmWWJEZHNmSmZJZ3doUWZMZkdoRGhZaDJiR2hSZnhnemJjZ2tjZ2ZaYUdiUmhrZ3lmYmhpaFFleWhJaFFmRWhpaEZobGNzZUNmTWhRZjloSWZVZ0VjMGFRZFdlbGZwY0NiYmEyaEpnbWZhYVJmUmZ5aFRobmdNZlFoVGVBZlFkWGVTZ1JiMGJjYmFiV2ZvaEZkY2FBY2hjOWZVZVJnZ2RMZUlnVWJRYWhmQWVsZ0Vic2ZPaEJmOGFuZEZlRWdGZ1NiRmVIZ0ZjR2dFaDNoaGFUYlRiMmVSYXFhVWF4ZGtkYmhJZGdndGVIaFNkQWd4ZW5jUmYzYlJjSWZZaG1nQmhrZGVnVWdzYVVlY2hSZzBmZGNUaFJhbGFXYWRhR2g1ZDJoY2gyZWNiUGNaaHdmc2RTZEdnamFvY0RlVmhGaEpmVWFDYjJnMWVIZVhlMmY4Y3JnWmRuYVlnVWJKaGdnWWQ2Z1FoMGVJZEJmRmhBaGRkU2RHYmloRmIwaEFjbmhBYkloZGFFYzljVWdVZUhiVWJCZ2Vka2hCYTdoZWFIaEJoV2RkaEFjOWdyZFVlaGNSZ3hoUmNoYU5nNGZVZDBhOGV3Y2FmZ2Q5Z0ZiRWczY2hhZmFXaFVlc2hTZmFla2Y1Yi9oYWYyZTViS2NaZkhlbGZMZEZlSGhFYWRmSGRVYzBhWmNWYWlhSWZ2YUpiSGRNYW5kWGhVYTBjV2dFZmtoeGIxY1NlaGdCYlNhUmNBZ3Rod2JXZ2tkSWdtZkpjR2NaYWhiRmZqYndiYmNQaGxnSWNKZ0hmMWJOYkpnQ2JGYk5lcGJJZUViRWVnZEJlRGNzYVhmU2RoY3BlOGNFY1RkVWFEY0FjM2doZTRoSGJuY1FkU2ZhZndkQWNQYmNnUWc4YlRiWmdsZU1iSGJmYzJjcGFZZUVmbGV0ZzVjQ2N3YTBnZWNXaHlja2Y4ZExjRGJ4ZHVhVmMyY1FidGdVY0RkNWF4YUhmUmcxZU5kR2FWY1pkMGJiY25lWmF6ZmJoMGVZYmllV2VrY0ViSmRkYlJhRWM2aFVma2dRaExhY2hGaHBhQ2RiaDJhSmJtYmFmUmVSZ3lnVGZuZ05iR2hEYVJkOWhSZ0dlaGRWZlRmYWhUYm9kV2NPZVJoSWZXZ0JiQWZ3ZElkTWdFYk5iN2ZHY0ZhaGc0ZGJnMWJZZGdoRGYzY0ZoU2RmY0hna2JJZFZoaWM5YlRoQWhXaHdiK2RYZXhibGFXZmVlUWVVZ05iR2hXYkVjdWJGaFNoMGNQZ0tmVWdKY3RjY2JFZmNjK2hjY1JjMGRkZlRmUmJsZ1diZGZHaDVjMmhjZTJjOWFHZFpleGdZYVNiVGdEY1JnS2hEYVZmSWRYYUJkVGN3Z2ZmRGhDYmdoMmJMY25kSWYraGNma2U1ZHpoRWZFZHhjTmNVZlVha2JWZlRkbWZsZDBnR2ZIYUFiSGVPYndjTmFLZVJmamEwZlJoYmRrYnhjQmNZZjNkQWJmZ2RnQWdKZnJoQWdCZlJidmRSZGxndGVqYVVmMGdSZXZjSWVsZG9oWmRSaHpmaGVDZUNnaWMxZGFhZWZrZnhia2dFZXhhTmJLY2ViWGhrZ1liYmZ6ZGtmZGZHYkVkMWVZZUtoMmQ5Z0VhZGVuZU5mdmhSZ21nY2ZXYkVja2V4aDFiU2RoZEJmU2FHZVNlRmR3Y1dka2JKYnZjWWZtaFplcGZGaEhiSmZPY2NneGRBaGVmQ2dBZVVjY2hSYXdoQmZwY0loRmZBZzVnRWFtZTlkN2JTZmtkNWQxZUViWGJOY01oVWVYZ2hld2dWZmlka2NHZmNjSGRnZlVkY2ZVYlljVGJlYkZmTmJQYlplRGJ3YVNiU2V4Z01naWFYZzFlbGNMZUVibmZVYjhhR2drY29jU2RSaFhoUmYwY1VhbmNWYThhWmIxZHhjQWFRaDFnc2hMaEVhM2NrZjBoZGJHYnhibmFGYWhnSmVNZ2RnVWZwY05nWGNBYmRmS2dQYkJhWmdLZVBiV2E1Ym1kSWVCZHhobWRSYTNmb2daYlZjMmNkZFJmU2ZSZ1ZmT2ROYkhnZ2R5YmNjRWZGZTBiVWRRZ3doYmRPaDFmSWduZ0JjUmY0ZzJhY2NGYTRmZ2FBYTJmc2hBZ0dnSGFFY1BiR2ZuYmdmSWZaZ1diUmNxYlVjeGNrY1RhY2RBY01oTGNXZkdkY2dUY0thUmRCYlNnZmhFZnBjNWZlZFFoSWZjZWFoUmRRZVViUWVSaGxlZWZKYW1iQWhEYUdkZ2NFZnlkY2RRZEloU2NVZVhkVWREaEdkRWJ0ZU5kQWRtZnRkd2hRZW1iOWNpYVpkamNRZFllV2hFZTVhemFFYUVid2hMYkJjQWJkZ1dmR2ZpZkFlN2RWYm5mQmhKZElnRmgxZEtkSGNIYmtiUmZPZ2tlVmVSaEliMWdwY1dhZGRBYjlhcmVVZ2hlUWhsZFNiRmVZZGdlQWN3YUFhMmFQaGdiQWVaZ0RjbmJCY1FnV2ZSaDRoQmNhYUZjMWdrZkNoR2daZ1plYmJYY1ZkTGhYY0djY2FKZ0JiMGIxYlFjWGRtY1ZlK2RmZTNnTWV5ZlhkVWIwZldoRWhrZ3hlMWdGYXhjeGQ0Z1JhQWd0ZXdoV2dnYlFhNmNMYkNmVWI5ZVhjVGUwYUFmY2h4aGdlWWRRZlZiRWFiZ0dkVWg0Z2djZmdSaGdmcmhhZTNkUmVSaFNha2c1ZzFnRWhYZ3NiS2NCZkRlWWR6YUFjamcxYUFhSmFWY0lhY2NJYjBhOGNUYUlnM2JsZ1BnWmZHZHBoVGNHZ1JmTmV3YUNjeGY4Y0RoWGJEYmtiVGJMZ1FnNGRnZVNjaWZGaHhjSGZ4YjFjeGhSaGpmZGJOZEdkVmRaZjBmYmNuY1pjemhiaDBmWmJuZ1VhRmUwaGVoZGdVY0pmR2hFYXhjWWdMaElhbGZwYWZiYmF4YmtlYmFaZVJkUWM3ZlRobWI0YVFoWGZFYkZnUmdEZUJmVmFUZWFiU2hBYVdhUGRBZ1FkNmdGZ2hhNGJHY2JiaGdFYzJmVGNFZDljNGhPZVViMWYwaFJkbWJCZ1plSGhYY0VhZGNPZ1hoaGRUY1RjMmVSYnFnVWR4Y2tnVGJjZUFmdGJaY1Zna2NRYjdlRmZXYVFnT2NiYmxhZGhrZExjVWVWZFhlT2RWYnhiUGRMZ2xiWWNTYk1kUWM4ZGlhZWV5Z1pnUGVmZkRmd2hTZVRkSGVWZUtiRWVGYkpiRWJDZDNmQmZhYVFlbWQ5YXpnZGNIaEVoVWNiZEViNGY4Yk9ja2F4aE5kVWdVZmtoVmNUY21kbGIwZUdjSGRCYUJlZGFGYUZlS2dVZlhkVmJEaGZiUmh3YUVhS2Z6Z2hhZWVPZ3dhWmhCY1VlaGRSZ3hiUmJoaE5hNGFVZjBkOWJrYWFlbGRNYlpnRWgzY0FiUmhXaFViUWZDZWJnbGI5ZmthWGUyZTRiRmdUZG5hbGVMaEZhSGVFZWRmSGFVZzBlWmFWaG5oUmR1ZWRmbmNOZ3ZoV2JXZWRmRWNIZkJnd2RnaEdkVmNoYmFnVmJSaEpnaWJXZmhhNWR2ZmFnaWZsYXBlQ2FtZ3hhT2daYlJhbGFBZVRjVWFCaGJkRGdVaDRhMWRkaEJjQmNtaFVhbmdSYlhnU2FnZ0ZhOGNHZUZlbGdNY1VjWGdoYndkVmVuY1FjUGVhYjFkSWVVZWNoVWZZZVRnZWZFYWxjUGhjZlhhOWNCaEFjQWNWYndmRmNWZmtkWmdFaGloWWdiY1poQWY1ZXVkVmZIZWxoNWJYZGdoTmJpYkNjUWNsY25mR2FWY1piMGhiZW5iWmF6aGJlMGVaZm5hRmVoYUpmTWJkY1Vnb2hQZFViaGhZZkZnSWNBZzhoUmNKYzJkcGUwZ2Vkd2JCZXliRWduZk1kWWJBZDBlMWNQYVZleGhWYWZlZWUzYTBoVWJjYkZmQmVtYlNlVWZvYVNnZGhSYmxiN2VBZzFoRmdtZWJibGVaZWlnQmVtaHRhVWNGZkdkZGZWZEdjbmVSYVRnWGJuZFpneWRVZjBkVWFUY2VjQmUxY0toVmVoYVJoNmFDY0doMWJJY1JjRWVwYmtjZWdVY3NjVWNjYlJhMGhkZVRiUmJsY1doZGhHYzVjMmZhZldnOWNPZUxkaGYwZVpoUWVGZzllS2FFY0ZnSmNFZ0NjM2ZCZGFjUWVtZjlnaWRaY21ja2NVY2Nka2Q1ZXpkR2dBZk5hTmRUZUVka2REZldhM2F4ZW5iRGRuYUJjS2FkZkZibGVDZlJnbWdRZUJjWWZWZjlhUmhmYW5oQWNaY2ZjUWE5aDNnVGNoZVJiZ2ZWY2hocGQ0aERhMGM5Y3NlZWcwZk1oTGJBYUhlQWJOY1dnUWJJZGNiT2FRYjhkbGhFZHdoMGhGaElkRGF3Z3FlUWZIZmxoVWNGY0VnUWFRZVhiM2hoYUVmZGJuaE5mdmVSYW1jY2RXY0Vka2V4YjFmU2FoYUJnU2RSY0FmdGZ3ZVdhaGZCaGhlTWVqYU1nNmVYZ0hlcGJraGNneGJCYk1lVGNWYkZmSmFGZFVjNWNwZmRlQmhoY3dmUWRYaFJjUmZTZGtnNWQxYkFkMmVkZGNlVWJTZVJmd2FYZWpic2ZQY2RjVWV3aFVlWWZGYjRnYWZkZ0hmbGJQY1pnR2hwYVRlR2NSY05od2ZDYTFhbGZXaEVmbmdwZ0hlWmNFYUZidWhTYm1mUmJvaFdkUWN4ZnhjUWZSZjFiRmNFZFJjbGMwZGNoR2JoaHpoZmRsY1JldWNGY2hnUmZNZ1loMWRrYVpkWGFtZTRjTGFjY0ZmcGNDaGJmMmNKaG1hYWdSYlJoeWhUYW5hTWFRZFRkRWIxZlJkU2VSYlZjZmNlYjJjd2JZYUxiRWdGYThoV2NRZ1ZoT2hhYndlOWd6aFdnbGJoZDRiZGdsZVpmaWdIYkdjSmhlZlBhbmdGY0diRWYzZGhnVGhUZDJiUmRxYlVieGJrZFRoY2dBZnRjWmRWZmhnSmc2YVJjM2VWZFRiZGhrZG9mNGVlaFVoTWNDZ1lmaGMwY2JhVGFWZFpkZmdYZW1jNWEyY2NjMmY5YUdhWmF4aFllU2RUZEhkVmFLYUViRmZKYkVmQ2EzY0JjVGdTaDNkUmdJY1pkbWVrY1VjY2VrYTVlemFFYkVmeGhOaFVmUmJRZy9mVGVtZ2xoMGRHZkhlQmFCZGRkRmZGZ0tlVGVpaGRlVWVKZHhoa2VEY05nbmRBY1llTWFWZWhncmNKYTFmMGIvYkVlZ2hzY1phQWRSZzBnbGZNZDFjdGNMZUdmbWNzZGhiV2hWaFlnU2dlY2tkZGFrYlFmV2g0ZFhhVGhuZGxiTGZGYkhmRWNkZkhhVWgwY1plRWdDaEVjZ2ROZVNlY2NtZUNoU2NrZ1dkWGRVYlJhOGdTYmtkdGI0aFJiQWd0ZXdiV2draEpmdmZZYm1lWmRwZUZoQ2RBZExlSmUwZVVlZWZBZzFkRmFiZUZnVmNOZzBkZGZGaGthaWVCYWllRWZjYkRjd2ZBYmhoUWduYzBiQWNGZURmWWgzYkFlamZ3aGxhYWMxZklhVWNjY1ViWWNUZGVmRmNOaFBlWmFHYXBhVGNCY2hoTWMrZlRkZ2g1ZldoWGFYaElhR2hOZmdhWWg3aEJjeWJFYzNiSGcwY2NnS2hEY0dhQmVFYUZmd2FNYmtnS2RqaGNlbmVLYWtjNGFtYVJhRmdVZlplT2dBYTljZWNCYmhkZGd3ZVloQ2FkYUxoWWdTZVlodmZMY2xlRWhoZEdobmdzYVpiWmdrYjFjUmNTYlJhVmVPZWFjWGNRYVlkY2hFYkZoMGVVZFZiQmdPZkljVmFraDZlSGExYUVmeGNQYmdjVWRnY1RiaWhVZVJhVWZUZDRkQWRFZ3plZGc1Y1RnMmZSYnFkVWN4aGtnVGNjYUFmdGdaYlZoaGVKZTZkV2JHZVFlWGFJYlFhTWVnYWVnUWZNZ2FkTWNsZHhmUmNBZVJoRWZDaFBlQ2JjYmxnZmQyZThoSGdOYlZjRmJIaEFiVGJBY0VoUmdBY0VkL2NHZndoMWVUZmFkR2Y5Y2lkWmRtZWtjVWFjYWtoNWV6ZEVoRWR4ZU5kVWFWZE1nVmRBZkNkd2dqZUdoRGg5YUplTmVRZU1iTmVHY3poaGZVZlBoUmVnY0NkQWcyYkFocmVmZVJoUmJCYVVkaGNSZ3hjUmZoaE5lNGNVYzBkOGE1ZlFlRmRNZlphRWczZUFhTGFXZlZnWWFTY1BlQmdJZ3FjQWJqZG9hRGhLaHpmZGdMZlhhSGJsZUpiRmRFYTFoQ2dmZkhjUmF1Y2RhbmJOZHZlUmNtZGNjV2dFZmtmd2FuZ0RjMGZRYUhoRmRrYVZid2hVZm1naGh2aFlobWhaYXBjRmFIYUphT2JjZXhkQmNNZ1RlVmNGZUJhUWFRYlljZ2dKZnhkWWdqZkJkRGRFZlZoU2RsYU5kMWFSaFhoTWJGYkhmeWFzY2tnRmN6YnBlTWRMYWhlMWVTZGNoUWNnZlRoWmUxaE1lYmRhYmlha2RmYVZjbGcwZDFnQWcxZkJlV2NDYUhmb2hKZ2JmQmhWZW5nUWIyY2hjVGVTYXhiUmh4ZkhhUmExY05nR2RWZ1phMGdiYm5mWmV6Z1pleGRJYXZhWGMwZUZlQ2dJYTFkc2RRZlRmMGNSZGZkT2dCZ01mUmVZZ1RlRWRqYkxmRmFCYThlRGdUZjllZmZBaGdhaGdaY1FkQmVzZFBkTGNUaEFmUWRJYjBiaGE2aEVjQWE0ZEtiZmVWZUJkNmRSY1ZiMWdTZ2NnRmRaYzBoRGUyYnRoU2dGZEhmRmFHYUVmM2doZVRlUmV6Y0FmaWJHYmtnb2dkZUphaGVsZlpkU2h4YklmdWREYXliMGVTZFloQmNrZWhhUGJBYThmYWNNZmxhRmNTZkFjMWh4ZWVmZmFXZ0FiM2ROY3lodGhPaEphaGc4YmJnUWhGYjljS2hFZEZmSmJFZkNhM2RCY2FiUWNtaDlhaWhaZW1na2djYUphZ2JZZjZoUWYwY0ljYmdRZmtoa2NJZVRhamEwZzhhVWJTYU5lUGFKY3hlUWNQZ0NobmJ0YVNjUGF3ZE1oZmJQZlhiaGRmZmZiUWdOZ0JiVWJoY1JjeGdSYmhjTmU0YlVkMGI5Y2tlYWRsZU1iWmVHZ3llUmVEZEVnQWFVYWNmTGJGZ05ia2RYZEdnNGhlYkxkRGZBZlljR2JpZUpoWWZXZkFoa2FYZkZlVGVnYmhoT2REYVpibmVUaDJnbGNGaFJkd2U0Z2hiR2VGZ0VhUmRFZkFmTWVqZVVjMGR0ZmpiU2hHZFphcGJGaEhhSmVPZWNjeGVCZk1oVGRWZUZnSmJGYlVkWWY5ZlBkRmhFZ2pjVGd5ZkFkZWRIaGdkOGc1ZWJjamQ4ZEplSGUzaGhldGhWY21mUWVHZVplM2hnZlVjY2JVYllmVGFlZ0ZlTmdQYVpkR2JwZFRkR2ZSY05lNGVYY3hkRWdmYlFjWGdRZktnSWNRZ3dkOWJBaHpnNGM4YVNnd2NsZ3hnRGRSY1JjQmFNZTFlWmIwaGJkbmJaYnpnYmMwZ1pjbmhGZGhoSmZNYmRmVWFKYkVjR2hnYzFiWWZmZWhmY2VIYUllaWMwZTBhTWNCZlJjdmZUYmpmMWVGZ0FhQWRGZlloUmNUYzlhT2FhZVhlUWVZZmNhRWhGZTBoVWVVY3BnT2VkZ1JkRWJuY0JkQmZnY3JmV2NsZ1plMGZEZTJndGdTaEZkSGFGZEdoRWYzZmhlYWZWZ0VmNWFxZVVkeGVrY1RoY2dBY3RhWmVWYmtkOWZRYlJnMmZSZEJkYmZrYXBla2hlZFVjdGZDZE1nRWQ4YmRoQWJ4ZGxoTGRkZkNoZGMrY1lhbWZaZ0lnRWVuYTliOGFPZ0dnWmhZZkNlM2NoZ0ViQ2IzYUJjYWJRYm1oOWZpZ1plaWdjYWFlSWdoZ3doOGhSYUFhTWNaZUNlQmRsY1FoUWJEZ0Vnc2VVYUFkOGNVZUplQmJVYkxkR2FqZ0FlUmFiY2tid2RYZ0xhVGE0ZVZjSWFFZFlia2NIZUJhUmE1ZUVlaGU5YzRhQWZVZVpka2dNZ1hma2VaY0VlM2dBaExlV2FWYVlkU2RlY2thZGZrZUZkeWI4ZVllWmNEZ0JkSGZQZG5jRWhkZ0hkVWYwaFphVmhuaFJidWVkZ25lTmR2Y1JlaWNJYmFiT2RFYnhmMWJTZGhlQmdTY1JmQWZ0Y3dmV2drZ0pjdmNZZGlobGdwZkNkWGJJZFBmZmFXZThlQWdBYWdhWmFGY1BkMGU1aHBoZGVCY2hmd2FRaFhkUmVSaFNla2I1ZzFnRWdUYXRiTWFUaEhoZ2V4ZldnQWh0ZEhnSWVoYVZkY2FhYW1jd2JUZWVnRmVOZFBiWmNHaHBhVGFHYlJiTmh3ZkFneGZ4ZFdhRGYzYm9iVGNaZEVidGd1Y0JiV2MxaDFiU2J4Y3dnNGhIYlFnQmdOZVhoRmZaYXFmY2RHZGhmemFmZ2xjQmh1ZUdkaGJKZUVlUGZFYW9mYmRUYzBiUmFaZWNmRmNCYUNmSWJHZXRncWZhYVJmd2g3ZVRhbmhVYU5jVGNGY3RoRWJYZkFiWmdiZllmSGVnZ1ljZWVBY2hjMGNXYmxmZGJPZUljUmdGZjVmVGhCYWxieGRhYjNneGUwYkRoMmJ0ZVNkRmVIY0ZjR2JFaDNmaGZUYkdnU2VVZzRkVWgxaGNhVGViaFFlc2JOZ0hlbGhzYnBiU2dSZnNnTmZJYlJoMWdraGNna2dzY2NjWmF3ZmdmSWFYYmdieGhXY2NibWM0ZnpnZWNtZ05lc2VaYnhnWWJTY1RlSGhWZEtoRWZGZUpoRWhDYjNmQmFhZEZkMmE5YS9oWmVpZmNoVWRiYkZlQmZ0ZEVhRmIxZGJoU2ZtZk1hVmZUZG1ibGQwZ0dkSGVCYkJjZGhGZkZoS2VHZjNhVWJhZ2Jja2Z3YUZkTWREY2tkRmVlYm5nQWJqZUdhMWVNZDVhUmZoYWhiNGdXZjFibGZ4Z2ZkMGNBZk1mRWQzZllmTGdFZ0ZhOGFKZ1VjRWhkYmtiUWdXZTVnS2ZaYkhlbGZMZkZoSGhGZ0xkWGJCZzhlWmhFY0hoUmd6ZmRmbmZzZzZnUmFuaHNlS2FFZWxkMWdqZlFleGRBYU9lUmVBY05ibWVUYjFhZGg4ZGRjMmVaY3ZhRmhEZnhnSGFhZERkcGFNZVRnVmFGY0plRmNVYTVjcGdkY0JmaGh3ZlNhVGNKYVJiVmUwZDVjOWdWYjNoTmZRZlRlWGhoYWhkUmZYaDBoUGZOYjFlSWhjYk5iMGdZZk5mWmFrZjFjUGJkYVhiTmJhY0ViQmg5Z2FkQ2gxZ2xoV2NFY25kcGNIZVpmRWZGaHVlU2dtY1JlNWZRZzFjcGN4ZUFlQmgxZmJoRGhFYk5kbmhlZDNmWmUxaGJod2FCZ3VjR2VqZ2hhTWZkYVVhb2dRZFVka2RRZ0xiY2RGZnBiQ2ZiZTJoSmh1Y1BiQmNSZ3ZjVGhqZFVjUWFVZ2xhTmVQZVNoUWFSaFlnWWdIY2dneWZjYUVkRmQwZFVkVWFwYU9kZGRSZkZmemVUZ0ZjRmI0Y2VlQmdsYjBmRWJtZHNoQmVHaGdjNGJLZlhiQ2g5ZmFjUWEwaDVocWRVY3hia2ZUY2NjQWd0ZFpjVmJoY0phNmRSZTJoUmhKZUpia2RwZjVnZWJSY2diYWFEYWxoVmVVZENjbGhGZmZlZWRFZFJjMmNjZTJhOWdHYlpneGZZY1NkVGhIaFZjS2RFZUZjSmZNZ1RibmJCYkhkUWVpaEZmaWViY0dkbGdiZWVhMGJKYVpnRWhFY3hoTmZVZlVka2RWZ1RhbWNsZjBkR2RIZkJiQmJmYkJiaGRLY1VnM2RWZFVoY2YxZEpoUGJaY25hQmRIY1llZ2JaYm5mZWRCZlJjeGVSYWhjTmc0YlVmMGg5ZmtkYWdsYk1hWmdFZzNhaGZDZVdnVmEwZlBjZWZoY0pha2RTZTJnNGhGZWJkWGNWZ2hnRmdIYUVnZGJIZVVlMGZaaFZjbmdSY3VkZGhuZk5idmZUYmlmNGZXY0ZlRmhGZjFjWGhBYVZhSGJWYXhiNWU1Y1ZlbWdoZHZiWWdtZVpmcGZGZUhoSmJPZ2NieGFCZk1hVGdWZUZiQmJYYkVnNWRpZWFoUmVnZCtjUWFYYTVjUmFBZ2toZGg1Z09nM2VOYU1oVWRYYWhkd2RWZG5lUWVQYWFjMWRJZFVhY2VVZTVnSGJNZUJjb2hjZmFkaGhVaGZlVmJrYlJid2dGZWxmbGhBZEJmMmc5YVVoY2ZVYkZib2FTYmlmRmJ3YVJiemQ1YnhlSGFSYjFhTmJHYVZnWmEwaGJkbmZaZnpoYmUwYVpkdmFRZGxkb2ZGZEpla2dSZnZkR2hnZTFnTWdPYUZjcGJmZGJhM2JSaHpkZmNBYWRnbmJUZm5hVWZRZ0JkVWdSYUtmWWN4ZFZnT2VhZVhkUWNZY2NhRWRGZDBmRGRGYUZka2VkY1JhRmh6Z1RmRmNGYzRnY2NGZFlnaWRUZ2pmbGJTZ1JhM2VGY2JjRWJ6Z1pnYmFUZFhnWmE4Y1JkZ2IwYkhnWWh4ZzVnT2dRYUFiTmI0ZFRmbWJoZnJhYmFrYnBoa2JlZ1Vhc2dVaGNiUmYwZ2RlVGVWY2hoV2ZhZVdjNGY0ZGVhMmYxYVVjZGZRZklhRWdWaEdkZGFZY0JoVWROYmRlQ2hYZmxiV2VhYUdlOWRpZVpjbWdrZ1VlY2NrZDViemVFZ0Vld2JZZlVhVmNRYVZiQWRHYkZmMmNDZDJhSmJYY1lna2VWZFNnVmEyZ3dhQWZaY0ViNWhZZWRlRmJwYldiZGZBYTlmcmJVZWhjUmZ4ZlJmaGROYzRkRmVVYjliNWhhYWhiMGhSY0VmV2VZYWRoUWNVY1FlRWFiaDFoVmZ5YlVlbWF4aERnYWZGZU5oTGJGZ0hoRWJkYUhiVWQwYVpoVmVuY1JodWVPZm5kTmR5YVJjaWFrZmVkRWZGZzlnaWRYaGdnZGRFZVZlUmRoY3BhU2NVaEJkbWFlZVVleGNwY0ZjSGFKYk9kY2R4aEJoTWVUZVZma2hHZ0dkeGg0ZTdnT2EwZXdhL2hGZlNhMGhCZURjMGhBaDhlWGV6ZW9kWWhVaFdnVmd3ZUhibmIwaERoUWdWZUllVWFjYlVhWWZUYmVhRmVOZVBjWmZHZnBiYmZWZ2hiMGVnYVdoUmJZZENkWGFTYzRkZWROZ0FmUmFnZkhlemhRZzliQ2JrZkFiMGNIZFFjQmhOYVhkd2JNYjZkTGFTYkliNmNJZEFiaGRuY0hja2ZaZUZkZGFSYUVkNmFVZWtjUWZMY2NjRmZwY0NnYmYyZEpobWdhZVJkUmJ5ZUdoRGdKYkNmVGNBYlJmZGJZZXhkVmNPZGFnWGJRZ1llY2VFZEZnMGFVYVVlcGRPZ2RkUmNGYXpnQWIxZkZobGNjZkZmUWFuYVdnemdraGJlV2NqYlpjRWdFZDJlVmZPaFRlemNBZXpoQWYxYXhhY2dOZWdic2JOY1RhVGRoZjZkUmIyZ1JiQmdiZWtkcGJrZGVmVWhzYVVkY2hSZDFoU2FUZ1JjOWRRZ2RnR2FaYytmSmMyZzloYmRaYzFhTWRhZ0diSGh4YkRkSGhGaEpiTWhSZkhlQmdIY1FnbWY1ZnplYmQyaFVoVWVlYWdoZGN6Y0RiVWh4YU1iUWZVZEFjY2hRYWtkTmMwZUdjSGFCaEJkZGVGY0ZmS2FUY25hVWJSZWNkMGR4YlJlZWVIZ0liRGhPYWtlc2V1YkZnRmQwZS9kQWcxZWRiNmhVZDBhNWQ1YWFlZ2hkY0FhUWh6Y1ZnRWVIZzFkWmd6aEtoQmVVaGxjR2FBaHdkZmJJaGpiOGRPZFJobmNFY2JnR2MyY2NmWmRWYm5mUmV1ZGRobmZOYnZoUmdtYWNmV2dFZGtoeGIxZFNlaGNCZ1NmRWNBYnNnNWJGZkJhRWY3YUloeWhnY3FkVWJUZTBhSWhjYzNhRWJlYUhneGFBYlFkZGN4Y3NidmJNYWxhMGVpYVFmWGNKYlhlWWZFZTVnMWVFYVhnTmdNY1VjWGhoaHdlVmhuZlFoUGVhZzFnSWFVZWNhVWNZY2JhY2NCY3BjUGJlYVdhcGFTZkNmUmNwaDhhQ2UxYkVlQ2NFZm1mZGVIZ0tiZ2NRZjVhU2RoZUVnd2ZCY1VlQmZwYWZiRWM4Y2ZlV2dBZDliOGNPZW5nOWc2ZVpjbGMxY05hRmZoZEpiTWdkYVVib2VRZFVha2hRZExjY2FGYnBnQ2VPZ1NlTWQwaGFmVmd4ZnlnVWczYk1lQWRRaEdlZGhSYVNiUmFWZE9mYWdYYVFnWWVjYUViRmQwZVVmVWNwZk9iZGFWYTliemZVZlZlRWRzaGZiaGRvZ3hoUWFTZHdjR2hYZkhmMWZzZ0VlM2VoaFRoVGgyaFJlcWRVaHhha2NUYWNlQWN0YlplVmhoYklmcGhSZDNobGRCYUpla2JwZ3ZnZWNRY1VjUGdXYnhnMGNkYVRkUmZsaFdkZGFHZzVoMmFjZjJmOWZHY1piMWE5YlVmVGNIZDFlYWdFZEViOWNaaENmemQ1YlRmUWJqYzBhbmhNYmpleGZHZFBlRWc0Y25iV2RBaFVjZWNTZ21nTWdWZ1RobWRsZTBhR2hIZkJhQmJkY0ZnRmhLZlRkbmFWZ1lhTmhVZHhoWmNVY25nQmdXaGRlQWg5Y3JiVWVoZlJoeGdSZWhnTmU0YVVoMGQ5ZGtlWWJsZ3RiTmFXZnpnbGNZZ1Zld2ZKYmRkTGZnZllmb2FQZWlhSWNQZUthbmRsYkFhQ2FYZEZlVGdGZ0VjRWZ6ZVZnbmZSYXViZGduZU5idmhSYW1nY2hXZ0Vja2d4ZTFjU2ZoZUJoQ2FSaEJoWmh0ZVdjaGJZZm5jS2V6Y1ZlbmRXYVRjY2FEZUlnRmhrYldlQ2FGYkZjUGJFaDJoUmJwY2RiQmJoaHdnUWdYZFJjUmJTaGtkNWUxYkVmWGdOZ01kVWhYYmhod2JYYmljQmFIYkllZ2dFYWFhUGJBZk5jZWZOZXdiRWdXYVphSGNkZ1RkVmZoY05ndmdDYjFodGhVZkVkbWVCZ0hjTGRVZ0ZheGRTY2lnb2Q4YkhkQmhRZEViVmdGYk1jWmdBZFRjY2NtY1BmRGNjYXFiWmIxY2RkeGRIZXhlSmRXZmRmUWhSYlZoQmhVYlJkWmFlaEVkdGZVZVpmbWR0Z3FoUWR4ZVJieWVUYm5oTWNRZ1RhRWcxYlJiU2FSY1ZjT2VhZ1hnUWhZZ0phQWFraDliQWhrZVFoRGVNZkZmd2hnZkJlUWZzYTlnY2NGYzFhMGRRYVdjdGZPZEZlR2VCZ1FjR2FsZEpjVGhUaDJlUmFxZFVneGRrZlRnY2RBZ3RjWmRWaGhnSmN6ZWJiV2hSZUJnYmNraHBja2VlYVVnc2NVZ2NkUmcwZWRkVGNSZGxmV2ZKZGlkc2NpY0pnamcwYklkWmN4YjRiNGhUZEhjVmdLY0VmRmdKYUVhQ2QzY0JhYWFRZ21nOWRpYVplbWFrZ1VhY2JnYUZjWmdFY0VoeGNOZlVlVWdrZlZjVGJtZWxiMGVHZkhnQmNCaGRlRmJGYUtkVGFuYlVhUmRiZEVjeGRaYUxhRGVnYmZkSmh3YUVibWhGZzFha2QrZkZoRWRwZzRkV2dGY0pla2dQaGxkb2V6ZkVjM2NBY0xjV2RWZVlkU2hlY2thZGJrZlFhV2U1Z0tnWmZIaGxoTGRGZ0hiRWNkZ0JiMGMxZFFiZmNIZ1JidWhkYm5hTmR2YVJibWZjZFdoRWVraHhjMWRTYmhjQmJTaFJhQWd0ZHdmV2NsYzFndmFOZGlhNGRnYlJjM2Z3YkRmTmNsYzBhRGJIYndoaGJIaFJnZ2JzZzlmZmJFZ3hnK2hFY2llRWVUY0NjeGF3aG5oVWVDYXBkRWZRZ1hiUmd3YkdlSGcwYkRoYWR3YlplY2ZPZEJkVWhkY05lUmNZZkNhTmJ5ZU1kSmhYYUJmcGNhZUNjMWdsaFdlRWJuaHBkSGRaYUVnRmd1YVNkbWFSYzVnU2d4ZVJleGFIY1JjMWROYkFjMWVZYmdnWWNEZlVkOGdQY3hmOWZ2YlFhbGJvZkZhSmhrZ1JoZGFGZ3dibGVFY0llZ2ZOZk9iYmZ6ZVlhdWhJZEVoZGE4ZkFhemhaZmRoSGd3Z1FmTGdEY0JjbGhPZGVoWGRnZFllUGVraGhhNGJlaDBlcGFPZWRnUmFGY3piVGFGZkZhNGdjZEZlWmYwZERhMmV0ZlNlRmVIZUZkT2ZSYnphQWJhZkhnR2hvYm5nRmJsY1JkQWFPY1ZhRWNjZlZnaGZsYW5oUmV5YnBhSWhZZW1kQmVrYmVjVWVzZ1VlY2NSYjBmZGhUZ1JobGRXZGRlR2Y1YzJlY2IyYjljR2NNYTFiNWFiaEhhMWU5ZktoRWhGZUpmRWdDaDNlQmhhZ1FnbWI5ZGlnWmRtZGthVWRjZWtjZGJvZ09ha2J4ZU5kVWFVYWtoVmVUZm1jbGMwZkdkSGdCZEJoZGhCZmdjTWdUaG5mMWFGZ09jd2ZVZENoZGFqYzBiVGZPZVZid2RpY0NiRmJGZXhhV2ZCZk5ib2NXYWtjOGYvZlFlRmFNZlpkRWYzZEFiTGFXZFZkWWdTZ2Vma2VkZ2tkUWZXYTVlS2FLZjFnTmRMY0ZhSGRFZmRoSGJVYTBhWmhWZW5iUmV1ZmRibmVOZ3ZoUmdtYmNlV2VEYlVieGc5Y0hibGdnZ2JnRmF3aFVlOWRIZXdnOGFnYk1jRGU5ZXBkSGMyYzlmT2ZKZnhlNGRmZkFnUmFnZUtlVWhFaFplNWRlaEJiaGNoZVZmM2RSYWNhU2NoYW9kOWNXaENhQmhDZUhmRGMwYTlnQmJUZDFhVmFMYWxnc2VkZVdkMGJZZlRmZWFGYU5kUGFaZEdmcGZUZEdoUmJOZXdhQ2MxZGxiV2ZFYm5icGFkYlplQWdoZUVkU2dtY1JjNWdTZnhkUmF4YkhlUmIxaE5oR2VWYVpjMGhiY25nWmZ6Z2JjMWFsY25jUWdsZW9kRmFKYmtiUmFkaEZkd2FsZ0VmSWVnY05jTWFQZUNjY2J5YllnVGQ1ZnlmVGFuZE1jUWdUYUVjMWhSZVNoUmZWaE9jYWVYZVFnWWhjaEVnRmUwYVVhVWRwYk9hZGhVY1ZkOWdIY3doUWU2YU1iUWJRZ21oVGFqZ0phYWhCZUhnMWJHY0FkbWI1Y1RnUWhtZVFmK2hHYzFlQmRBaGZia2VZY2NhR2EwZ0VhemVIaFNmRmdJYVlobWdCZWthZWhVYXNkVWVjaFJiMGFkZ1RlUmRsZVdnZGRHYzViMmdjYjJmOWRHYlpmeGdZZFNnVGhDZkVoQ2hXYlFkRmVLZ1JiamJVY1hkRWFTZ1lkNGFJaDBjTWhVaGNia2U1YnpkRWFFZnhnTmRVYVVka2FWYVRkbWRsYTBmR2NIZkJnQmVkYUZhRmdEY1plSGhVZFJkY2UwY3hkUmhlY0hhQmJXYmRlQWg5ZXJhVWJoYlJheGhSYWhmTmFpYlVmeGh0Y3FnS2VSYXhmSmFTaG5jaGNmaEVmUmQ5Z0JhZGJBZW9haGhEZENlRWNZY1BlWGNWaExjUWVEYWxlVWFUZWthTmZVYkVnemRrZjlkUGN5aGtjcWRTZW1hY2NHZkhia2N4ZGtkWGRCYUJoZmdSY0ZmOGI0YUVheGRGYmhoTGV5Zk1na2FSaHplc2VVZU5oaGFsZVhmWmExZ0ZkSmZGaFViNWJwZmRoQmFoZ3diUWVYY1JkUmJTYWtoNWUxYlJjemhJYWVjVWdUZGxmd2FTZjNjUWhmZmNmSGdnaFVmY2ZVZlliVGRlYUZmTmZQZ1poR2NwYVRnR2ZSZ05kd2NDYnhnWmc4YkVnbmZwZ0hnWmZFaEZidWNTYm1kUmY1Y1NieGJSZnhkSGNSYjFkTmVHYVVkbGUwZlpmaWdJZjdiSmVoYlZlcGhRYkFhTmJDZExjUmZKZ1liTGJSZEZiYmdOYUJic2ZXYUtnbWNwY01lYWFSZlJneWVUYW5mTWRRYVRnRWUxZVJjU2hSYlZjT2hhYlhlUWJZZGNiRWNGYTBlVWdVZXBjR2VJYVZla2I2YUhoMWE4aDFiTmFSaHNlN2JYZlRmSmJjZVZkemdraEhlUWRSYnNkY2JDaHlhRWNMaEJmeGRGYlNhY2VBZkJmWmRSZ3hldGg2ZFdnM2JoYUJhZGVrZk5ma2VKZVdhRWhVY2NhUmgwYmRmVGJSYmxmV2hkZEdhNWgyaGNoMmc5ZkdiWmV4Z1lnU2ZUYkhmVmNLZkVkRmRKZEVhWGJ6ZWdhVGRFZVdkRWJ2aElkeWdSaGJoSWJCZWRkOWhVZXdjUWNNZEFneWZwZGFkQ2dpZXdiVmJUZkhkZ2NBYWZlVmUxZWdmVGVuY1VlUmNjaDBkeGhSY2VnSGdCZldiZGZBZzlncmFVZ2hnUmh4ZVJnaGhOYTRkVWMwZTllc2ZQYmhodGdRYlFmSGE1ZkdiSGFCYnRiZGRLZUJoNWRxZEFhaWZZZUxiTmRoYm9iRWVVYkRlUmI4Z1NiVWZWZVljVmZuZDlidWZaaFhicGN2aFdjbmRzaFdkQ2VraFZjMWZGaGpncGJTZlJhQWh0ZndkV2RrZkpidmZZYW1kWmFwYUZhSGRKZE9lY2d4ZkJiTWVUaFZjRmZKZUZhVWE1aHBnSWNGZkFlNWRFZ25hb2ZjZURnd2ZNZjZhUWZ5Z3BoQ2VFY2pkQWV4Y0JnQmhkZUFjTGN4ZWRiMWhKaFVnNWhTZmVlRmVoY1BlZGFtZE5mNWZHYlJkTmZ3YkNjMWRsY1djRWZuYXBoSGJaY0VjRmR1Y1NjbWRSZjVoU2V4YlJleGZGZkJiRmVuaEdnVmRaYTBnYmRuYVpjemNiYzBmWmZuZUZoaGZKZ01kZGFVYm9mUWJVZ2tnUWJMZ2VjQmd0ZUNjWmdIYjlnbWRmaFJhMWErYVpkSGFNYVFiVGdFZDFmUmNTZlJoVmJPYmFoWGFRYVllY2FFY0ZoMGVVZ1VjcGVPaGRlVWRVZDdmQmFRYkpnMmdKY2tiUmE2YVZjemNNY2FkYWJ5ZVFiV2ZWYnpja2RIZkNibWR4Y0FjVWh4YWthVGRjaEFjdGJaYVZoaGFKYTZlUmMyYlJoQmhiZGtkcGdrZGVoVWFzZFVkY2dSZzBlVmVHZVZlRWZmaEpjMmRBZDdjTmNpYUliSmVOaFVjOGZjZ0RhemIwYUxjUWFqZ0VnTGFUZ3pjVWU3YUZmbWFjY2pmWmVtZUlkVWNZZDBoZGd6aERiRmVCZU5mU2dVYUFlVmVFY2toTmMwZEdiSGhCZUJhZGRGZUZlS2VUaG5iVWNSZmNlMGZ4YVJhZWNIZkJmV2FkZ0FnOWNyYVVlaGNSZ3hnRWNsYXNjeGhBaEVnRWZwZ0xjeGE1YldhUWJTZWtmRmFHZmhmNWRUYktkQ2RRZnJmQmdTY3NhcmhNaEhlRWZLZkhoWGQwYTNnSGNVZzBmWmdWYm5iUmJ1YmRobmhOZXZmUmZtZGNkV2JFYWtoeGQxZVNhaGNCZ1NoUmJBZ3RjNGZEYmdjb2RtYk1nV2RnZGtiVWJUYThlQmRJZ1VibGdDZURmaGFrZUlhUmF5ZzBobWNNaEZlMGhSYkZlWGN3YVFkU2VrZlZjMWNBYm5ncGRNZ1RmV2RSY3dlVGZuZTBiUGFOaDNnZ2hVYmNoVWNZaFRnZWJGZ05iUGRaZEdicGZUZUdoUmdOaHdmQ2ExYWxlV2VFZG5kcGhIYVpjRWZGYXVkSGJpYXdod2FHZUJjb2Q4ZVdoRmhBaENnU2R3YTlhNmdMY1RiNGN5aFBoU2dVYm9hVWVsYWNidGhJZVVoSmFSYlVka2Y4ZkxmWWJsZ05kb2diZzJoSmNtYWFkUmNSYXllVGRuZU1lUWdUYUVoMWRSYlNlUmJWY09hYWJYYVFoWWRlZ1VhMWhlZlVhVWhwY09jZGRSYUZiemZUaEZiRmc0ZWNiRmdaYjBlRGQyZ3RnU2hGZ0hlRmZHZEdkemFsY1RmUmRIZmxlcWhSZXhoQWZmZ1diZ2d0ZFpmVmNoaEpmNmFSYzJkUmNCYWJna2JwZ2toZWdVZnNiVWVjYlJnMGJkY1RhVWEwYWVoUGhUZzFiNGZKZVhheGZJaFBnMGY1ZWFoTWh5ZkFlYWFWaEJmTWNRZlRobmhoYndlUWFtZzllaWZaZG1na2VVZ2Nla2I1YXphRWhFZ3hjTmJVZ1Vha2dWYVRibWRsZTBlR2JIYUJmSmZJY0Joa2NEYkhnWGF0ZGNoTmJnZUVlZWVLaGlobGFZY05nMGFjYnFkQWNIYWNoK2hBYmxjWWhaZ0JkMGFjY2xiYWVsZ2diWmdBY25ma2ZMZlJhVWNvZ1NnWWNrZTVla2hIZFVoUmJLaFplSGFsZExnRmRIY0VjZGJIaFVlMGJaYVZkbmNSZHVoZGduZE5jdmRSYm1lY2VXYkVia2Z4YzFnSGFsZGdiYmhGYXdoVWU5YUhod2Y4Z2djTWZEYjlnbmNWZHpib2RQY0lkWGdNYkRmQ2FSYVFhb2NRYVVoWWVvZGZiUmhSaGFlUWRYZVJiUmFTY2tkNWIxZ0VmWGVOZk1nVWJYYWhld2FWZW5kUWZQYWFlMWVJYVVjY2ZVYllkYmNMaEJnc2JHYU5mMmFRZGVkWGZGZDRnL2VXYlFlQmhZZVVnVGdJY0dmTmhpYklkaGdEYmlkRWNZZkhneGN3ZndmSGdSYlplTmFDYWxjOWMwZWNjbWNwZXpoZGYwYTlmbmdTZmpjaGRNYWRnVWFvZ1FhVWNrYVFoTGRjZUZjcGZDZGJmMmNKZW1kYWNSaFJheWRUZG5lTWhRY1RhRWUxZVJlSGRWZDBhSGdPZG5icGVWZE5iUWF3ZzdmQWZ4Y05hQWJOYWxma2N5ZkhmamVJZzNlTmJCZE1oVmRXYTJmTWJUaEZiSGZwYkdnQWNYZUZkNWZUZTJjUmJxZlVleGFrY1RnY2JBZnRjWmVWZWhjSmc2Z1JoMmZSZ0JkYmdrZHBha2FjYkVhY2graGNkUmYwZ2RiVGVSZWxlV2NkaEdnNWUyZGNlMmg5Z0dnWmR4ZlliU2RUZEhoVmhLZUdhQmZOZkViQWRHZzFiYWJWZm1lWmh1YlRmR2FrZFVlY2NrYjVoemNFZEVheGhOY1VjVWNrZVZmVGJtZGxlMGRHZEhmQmFCZmRmQWdVaENjQmd5ZFlkZmhKZVZjaGZmZ0lkQ2RnY2VjQ2QxY29oN2JGZ2xmVWFsaEFneGd0Z1NlVWMwaDlja2ZhYWxmTWZaYkVlM2hBZExiV2FWY1llU2ZlZWtjZGRrZFFmV2E1ZktoWmFIY2xjRGNRZERhbGNVZ1Ria2FOZ1ViRWN6YWthaGVKYUNlcGRoZUJhU2U5ZlhiUWZDaDhiNmJEZmxkVWZ6YUViQWFNYXhlV2FrZ2xjdmFjZzJjOWRwZENmR2g1Yk9nYWF4Z2xnTWNFZVhldGRKY0ZlVWc1Y3BnZGNCaGhnd2VRZlhlUmJSZFNma2Y1ZjFkRWZYYk5iTWhVY1hoaGR3ZFZlbmNRZVBmUGh4ZXBhZGVJY2tiaGZlY1BiUmc0Z0FhTmVqYU5hZGNXY2xoc2N4YVdlVGhvZFpjVmNqYzhnbWFNY0Vha2V2YVFhMmFoZFRnU2d4ZVJneGJIZVJiMWZOY0dmVmhaZzBoYmFuZVpmemZiYzBlWmduZ0ZhaGVKYk1hZGRVZ29nWWNCZmdkeGNDYUlnMWhRZVBhS2FpZjhhcGRPZzBkMWI4ZkRhVGF0Y1JjSGNpYjRlZWVEYVZhQWh2Z1BlWGR4YlpkY2NFY3BlMGZRYmtkTmFPZmFiUWUxY3pmVmJGZGhkNGNMYUhleGYwZ0RnMmh0Y1NkRmZIYUZiR2RFYTNlaGZUY1RhMmNSZXFkVWV4ZWtlVGRjZkFodGhaZlZhaGhKYTZoRWd5Z3doSWRQY1VoUWRwY1BjQWVaZWJoSWgwYlFlVGFEZGxjRWRYZkpkZ2YwZjVmTmd5YW9jbmRNZHhjNWFUZlRiSGQ1Y0tiQWJsZXRndWdDYzNoQmVhaFFmbWQ5ZmlhWmVtZWtkVWVjYWthNWV6Y0VmRWV4ZU5kVWZVY2tlVmhSZDJkQmZlZUdoSGJCZEJhZGNGZkZoS2ZUYW5hVWFSY2NhMGh4Y1JiZWJIaEJjV2hkaEJhVmZyYldma2VBYjVkRGQwaEJiMmNCZlZmNWVxZU1kZ2h0Z1JhYmZDZ1ZhYmVIaFJmZGFHZ1BnMGU5Yk9iUWFXZjVkS2ZaZEhlbGRMYUZoSGhFZ2RjSGNVZTBmWmRWYW5hUmh1ZGRkbmdOZHZoUmFtZ2NhZWVSYmdoUWU4ZkdhUmc0Y2ZhQWNVYllkL2hDaEJlc2ZVYUlkMmVaZmloRmVHZk1jemJjYXdmeGJRZVRjVWVsaEFkRmJSYkplcGVJYkZmQWQ1YkVkbmdvZmNkRGN3Z01jNmdRZXlib2QzZEVoQWJWZjhhZmJIZlFjUGVhZjFiSWRVZmNjVWhZYlRkZWhGY05lUGhaY0dlcGdUaEdoUmdOaHdkQ2UxYWxmV2ZHZWlhNGdQZExmUmhKZmdnQmF5ZUVoMGVCZEViWWhvY1pobGJ4Y05kRWFsaFpmbmhFYTNiWmd2ZWNoMGZaZC9kSGh4Y0lmUWdkaFJkNWZZY0dkeGVjaEZhUGdSZzhiUGJJZ0RmQWcvZUVhbGRWZ3lhUmZYY01lQ2dNaFdlZGdSZFNlUmZWYk9lYWdYYVFlWWZjaEVjRmIwZFViVWZwY09oZGJSaEZoemJUZ0ZoRmJ4Y2ZiSGV4aDBlRGUyaHRlU2NGY0hnRmFHZkVhM2NoY1RkVGgyY1JjcWdVYnhja2dUYmNlQWF0YlJoRmh4YUpoeGNXZm1jUmhWZFpmMGNaZk9hZWZVY3NjVWZjZFJlMGhkZ1RjUmdsZFdlZGVHYjVkMmFjYjJnOWZHZVpieGNZYlNjR2FEZTBoRGZRYTFid2FTY0dmWGg0ZENhR2VpY2NiZGhNaHplbGRRZ01heGFvZTJkR2dHZ1plTmJVYVVma2FWZFRibWVsZTBkR2ZIYUJoQmJkZUZkRmFLZ1RmbmJVZlJhY2YwY3hlUmhlZ0hhZ2hDYVBoRWdZZjRiWGhGZmtkMGRDZDFhd2RxY0NoamdRZmxjYWhsZ2doWmhBYmdiMGdMZ1JmVWVvYVNlWWdrZzVoa2NIZVdoNGdlZ0xhRGNBZ1lmR2hqY3hjWWNVZEFoSmhMY0Rid2c4Y3ZnQ2czYzlkRmhSZW1kY2dXZUVja2d4ZjFnU2FoZUJmU2ZSZkFjdGd3Z1dma2hKYXZoWWZtY1pkcGJGY0hmSmhHY0poMWNnZEZmSGdsYzhhRWJVZkFiTWJtZkpma2dFZUxnQWJIZ1JmYWZTYWxhMGZJYUVmV2c5Y1FiVWRXZUJiNWJWYmlkZ2VQZlBneGZwZGRjSWJraGhoZWhQZlJlNGRBY05hamRNY29jV2dCZU5iN2JDZjBnc2dyYk9mSGJwZUhiWmFFZUZjdWhTaG1lUmc1YlNneGRSZ3hiSGJSZTFmTmVHZFZnWmUwY2Jjbmc5Zi9kUmFVZFpnbmFGY2hnSmhNY2RlVWZvZVFiVWVrZ1FkTGVjZUZlcGNDZmJiMmNKZm1nYWhSY3diemNUZ25iZ2VOY1RlRmNsY1lkUmNUZjllT2ZhYVhjUWhZZmNkRWFGZjBmVWdVZnBlT2FkZFJjRmJ6aFRkRmhGZDRhY2NGY1lnZ2JSZHllSWdCZ0dlaWNkZlZiSGNTZUFkTGhCZnhoc2EvZEFkMWcxZlNiSmFFYTVkUmVmZEJnSmM2aFJoMmJSYUJiYmdrYnBoa2hlY1Vlc2NVYWNjUmQwZWRkVGRSY2xiV2FkZ0dmNWgyZ2VjemNzZk9jTGhrYlVhY2RBYVRmQWVIZVhod2RBYmRjY2ZEY0ZjYWFTaFdjOWh6YUdoMmFrZUlkYmRrZTVlcmVHYVVjd2FSZFVlUmcxZWRnQmZ6Z3BoNmdWZ1RnVWNNYk9nd2hNZVRlTmNUZFJlc2ZmYTJiWmFSaGViSGVCZVdmZGdBYTllcmZVYWhkUmV4ZlJlaGFOYzRnVWQwYzlja2dhZWxjTWdaYkVlM2doZGZoRWRSZzlhQmVkYkFib2ZoZ0RmQ2ZFYVlmUGFRZklhS2NGZkhlb2NkZERiamhBYlphU2VtZ2hndWZiaG5lcGd2YkdnbWVkY0NkV2RnYVVjbWJSYkZlMGNYZkNmVWRRYmlnQWZ6ZGthdWhZY21mMWZwZ0JkZ2I5aGtlY2h4ZEJiTWdUZVZjRmNKY0ZmVWY1ZnBkZGVCYWhnd2NRYlhjUmNSZ1Nla2g1aDFlR2hIaDlibWNVZlhoaGR3aFZnbmNRYlBiYWQxY0lhVWdjYlVmWWNUZGVhRmNOaFBoWmNHZ3BnVGdFY1ZnSmF3YUFnRWRSYldnQmZuYU5hTGhUZmtoRmN1Y1NibWZSZjVhU2d4Z1JneGVIZFJnMWhOZEdlVmdaZTBmYmJuYVphemViZnhkSWd2aFhhMGRGZENlSWYxYzRlZWJDZGhoeGhEaERod2Y4Y1NjS2R5ZU1keWVMY0JoeGRZZ1RobmdNZ1FoVGdFYzFhUmNTaFJmVmJPZWFjWGhRaFlkY2hFaEZiMGRVYlVocGhPYmRiUmFGZTdmR2RCZ2toeGFJZTFjZ2Q1Z1NjaWZZYmRiUmFpZWdoOWRVZW5iaGZZYlRkM2FVZFhoVWd3Z1ViUGRjYUJiTmVRZVZoa2U1ZjZhRWV5YndmSWVQY1VkUWJwZlBiQWRaZGJjSWgwYlJlbWFEYkdiUmNhZ1hnbWU1ZDJhY2gyZTllR2haZXhiWWJTZFRmSGZWZktkRWJGZ0pjRWhDYTNhQmhhaFFmbWY5ZmlnYmFqZzFhY2VPZXhjMWY5Z1hhUWdrZUFkSGNoZXRhTWVOY1NjaGcwYkVmM2JCZFNkQ2RWYkZnV2RVZG5hVWRKZGVma2Z3ZU5hZWhDYlFkZWhQZlZjeGhsZUhlMWFFZDhlQ2dVYUVkaGVLZEFiNWdrY1llVmRNaExhYmdsZW9mTGNXZVZjWWZTY2Voa2RkYWtjUWVXZjVjS2NaaEhnbGhMYkZmSGFFYmRnSGVVZDBlUWJYZTNiaGRFZGRibmVOY3ZnUmhtYmNmV2ZFZWtleGMxZlNkaGhCZlNnUmVBYnRhd2JXZmthb2huZVlhbWQxaDBlRmJHYk5hWWZjY3hiMWRNZUdiUmRrZ0FmUmZrZEFia2RNY1ZlVWVqY0NjQ2I0ZlViUWYwZEpkZmdFYVhlTmNNZVVjWGJoZHdjVmduZFFhUGJhZzFjSWdVZmNlVWJZZVRhZWdGZnNhYmRMZENjTWRBaEZnMWY0ZjFmUmZnY29oZmhTY0RiOWNIY2VnVWNGYitlUWQyZmhmVGRTY3hiUmd4ZkhnUmMxaE5hR2ZWZFpkMGFiZm5hWmd6ZWJoMGhaYW5lRmNsZDFhTWJjYTBkd2VRYldlaGRCaERoT2VRZ2xkTWNJZmllY2dyZUpha2VZaHJnVGhtZDRiUWdUZmtiOWFZYVVjamc5Yk9hYWZYZVFjWWdjZUVoRmgwYlVkVWZwZk9nZGZSZkVmdWRaZWxiRmY0ZmNjRmhaZjBkRGgyY3RmU2hGYUhmRmNHaEVhemhFYVZkVGgyYXdkNWRVZXhnUWJUZ1loUmQxZlpjU2FBZDlmNmZEYzJmMWhCYU5jV2dCZWthZWRVZnNjVWJjZFJmMGdkaFRnUmFsZVdnZGNHZjVlMmFjaHpoa2ZIYk5oUmhaYUhnVGhHYWhmS2JRZjFoSmNKYUNmMmdGZ01iV2VVZlZjaWJaZ21la2hVZmNma2M1ZHpmRWNFYnhhTmNVZVVoa2VWZVRlaWgwaDdjTWJuYkJiQmFkZ0ZjRmRLYlRkbmJVYlJjY2UwZnhoUmJlaEhhQmJXZGRiQWU4aGthZWdCaFJneGdSZWhmTmM0aFVjMGI5ZWtiYWZsYU1lWmRFYTNjQWVMZFdjVmVZZFNiZWVsZ2hja2VTZlRob2VDZUxhU2JwZkZiUWVtZEFnVGhSZlJlVmNSZUtiU2VFYytkTWRqYklnN2JBaDJoOGU4Y0Vma2Z4ZzFjU2RoYUJkU2FSaEFhdGR3YVdka2VKY3ZiWWhtZlplcGZGYkhkSmhPZmNoeGVCaE1lVGNWZWtiZGZHZ3dnMGRoYU5jVWJvZlRlRGRqZ0FhVWRLZXhncGc5aFdlWGFOYUhhVWJXaGxlNWNWYm1lZ2NUaGFkMGRvYWRlY2JSZW9jVGJMZEZiMGhNYkxoQ2ZzYUJkZWRsZHdkMGJUYWphZ2NDYkdmamRKZU9iYWRHY3RldWVTYW1nUmM1Y1NjeGZSYnhjSGNSZzFlTmFHZVZlWmMwaGJmbmFaZXpjYmgwYVpmbmdGY2hjSmZNYWZhUmg0ZWVlRWFRaHhmS2JJZWpja2ROZEtieWRjYkhoUGJSaHdnNmdUaG5hZ2VRYlhnMGdSYlJoVmRRYWxjT2FjaFhiMGFZZ0xjRWRFYWdmWGd3Z2tlR2dOY0VnTWJRaEFleGFVYjlhRWZRZEpmOGNSYzJodGVaaEZlR2hOYlBkT2dYY2hmVGVUYzJjUmdxYlVmeGdrZlRmY2VBZXRiWmhWZmhhSmc2ZVJlMmJSZEJlYmNrZHBoa2NjYUVnY2crYWNnUmYwY2RkVGFSZWxnV2dkZkdiNWEyZGNjMmI5Z0dmWmF4YlliU2hUZkhkVmVLYUVlRmVKZk1oUWMzZkJkUmRYZTJhOWQyYWJoMmNVYythY2ZrZTVhemZFYUVjeGZOZFVmVWNrYVZlVGZtaGxhMGFHYkhhQmRCZGRiRmhGY0toVGNuZVZlRmVPZndnVWNDZWRnaWZaYkVlZWRsZ2NjemdHZm1kc2drYUZobGZjYjVhQmZ3ZHBjc2FRYUZoTWZaZUVhM2dBZ0xhV2JWaFloU2RlYmtoZGVrYlFmV2E1YUtjWmdIYWxnTGFGZkhoRWNkYUhmVWgwZVJhQWNuYm9ldGdQZWphSWg5Z0poU2JoZFNmVmF5YjBnaGFRZWxnaGhTYVRid2F0YWhiVWIwZkpmemVmZW1iWmV4Y0hjWGFJZlNkY2gwY1JhQ2NEZWhoa2VJZFJheWQwY21iTWVGYTBnUmFGZFhjd2VaZFFjMGZKYWZkRWZYY05iTWFVZlhlaGV3YVZhbmJRYlBkYWgxY0loVWJjYlVlWWhUYmVlRmdOaFBhWmNHaHBoVGVHZFJnc2hrY0JhUmZvZ2ViVWd5aGdha2RLZ3dmVWhyZktjemVCZHhhQWV4YlJmNmVIZFFnNWNFZkdhVWVwZW9lYmdtZzVkNmhiZ3hmcGFuZFFhaGN3Y1BnUGJRY3RoQ2FNZVFndGFQaE5mVGJzZ1dlWmZ5YnBobWNZZGhiUmFnZVJjMWhrYlFlVGJFaDFkUmJTZFJhVmZPY2FhWGVRYVlhY2NFZkZiMGFVY1VncGhPZmRiUmRGZ3plVGdGZ2hlMGRXYmxoWmUwYkRjMmF0Y1NnRmRIZUZjR2VFZzNnaGZUYVRjMmZSZHFoVWZ4Y2tkVGNjYkFidGdaZ1hobGhwZjZoVGFIZmxiQmdlaGtmTmhvYlVmMGhzZ1VoY2JSZzBmZGZUYlJhbGVXZGRnR2Y1aDJiY2IyYzliR2VaaHhmWWhTZ1RoSGJWZ0tlUmJCZ29kTmNXZUhoNGJNY1ViV2JFZTZmUGVpZ0ZicmRKZHhkNGEzZ1VoUmZnZUlnV2RXZE1jVmhUYm1kbGcwZEdkSGNCYUJhZGZGZEZhS2RUY25lVWJSYWNiMGN4YVJoZWhIY0JjV2ZkYUFoOWNyZ1dja2NCYS9jQmdWZXNmNWNBZVNld2JyYUxoaGhaZjRmUmgzYmhoRGNXYVZiMGdTYWFjMGM1Z2tiWGRYY0piS2JmZkhkQmRMZVNiSGNGZUplRWZ3YTViUmJGZ3lmWWJOZk9kVGNjZnFkSmR6Yk1iZWRXZWtkVmg1Y1lmQmFCZVNkUmVBZXRld2dXY2tiSmh2Y1lobWFaYnBnRmFIYkpmT2NjZ3hjQmVNZ1RjVmJGY0pmRmNVYzVnaGdJY0JlWWd6YkNhVGJVZkRiS2ZRYkVjeGRWZEJlSWJZZ1dkVGFCYndmWGdYYlFiY2JZZ2xhSWJJZGJiVWRZZExiY2VWZ01kVGVaZERiNWhkZFdobGhzZXhkV2ZUYm9jWmhWZmpnOGNtY01lRWVrYm1nU2dtaDllNWhXZlJiMWViZEhjUmcxY05hR2RWYVpiMGJiYW5oWmV6ZWJnMGNaZm5kRmNoZkpnTWNkZVVnb2FRZVVha2JRZ0NoZmRIYUJhQ2ZiZjJlSmNtY2FlUmZSZ3lkVGRuY01iUWhUaEVnMWZSY1NlUmJWZ09hYWZYaFFkWWZjY0Vha2E4Z1ViVWFGZ1RmZGVRYlZoNmhRYkhidGI0YmNkRmZaZDBjRGIyZ3RoU2hGZUhmRmdHZ0ViM2FoZlRmVGUyYlJncWFVZ3hia2ZUZmNiRmU4YlJoSGYwYkZlMGNFZFhlQmdQaE5oaGRJZnNiQmRoZTVjRWFOZlZleGhKY0NoQmNGZDhiZGZHaDVhMmNjaDJhOWFHYVpjeGVZYlNlVGVIYVZnS2RFYkZlSmRFYUNoM2RCZ2FmUWZtZTloaWhaZm1kRmdBYWZoQWMwYzdiVWRSYjRldWVIYmdlMWNRYUxlemIxYjhjVWNIZ0JiS2NkZUVjQmNEYlRjbWRrZU5kY2QxZ1JoWWZlY0NmeGdXZklhQWRFZW9mR2NsY1VmamNKZ1Zmd2U4Z0ZhaWU0Z3djWWRoZ3NkUWJIYzFjb2dMY1dkVmRZZFNlZWJraGRha2JRaFdjNWZLZFphSGdsYUxiRmRIYkVhZGNIZFVjMGhaZFZibmRSZHVmZmNpYmRkaGRCY1NjOWJYZVFnQ2c4YTZkRGRsaFVkemFFZUFhTWc0aFdka2NsYXZoY2NXYjljcGNDZEdmNWNPYWFieGFsYk1hRWNWZEVkZGVHaHdoMGRoY05jVWFvZFRiRGhqZEFlVWZLYXhmcGM5ZFdiWGJOYkhkVWZXY3BoNWhmYkhkUWVQZ2FmMWJJZlVhY2ZVY1lhVGhlYkZiTmdQYlpkR2dwZ1RkR2dSZ05od2dDYjFhbGhXYUdiM2dOZXRiWmJFYUZjdWNTYm1lUmc1YlNieGJSY3hoSGhSYzFnTmVHaFZhWmYwZGJhbmNaYXpnZGZVYlpjdmFRZGxib2hGYUpla2NSYUdmUWQwaHBhVGRLYkJmSWg5ZU9mamhJYmliS2JFaEFoM2VSZmxma2JRaFRiRWExaFJkU2ZSYVZoT2RhZ1hoUWRZYmNhRWFGZTBnVWVVYnBkT2VkZlJhRmJ6YlRnRmVGYTRmZWNBZklmUGNSZTJjdGVaaEZkR2VBZzdkRWcyZ1JlUGRUaDNleGJqZFVhMGJVZlRiSmJIZUFjUmZLZXhjNWNRY1JkMmFSZUJhYmFrZXBla2NlZ1Vnc2ZVZGNhUmQwYmRoVGhSZWxiV2FkZUdkNWQyZGNhMmc5YkdiWmF4ZjViR2ZOY3poMWVLZ0dmMWRKaFhnZGFuYUJjR2RYaG1iOWg2ZmJjMmFsYUllY2JoYW9oSWJXZUVleGdHZFVmVmR0YW9jWmhHYWxlMGFHY0hlQmNCY2RmRmZGZ0tlVGhuYVVhUmFjZzBneGJSZmVnSGJCZldhZGRBZTlicmJXYnhnaGZiaFJhaGROZTRnVWMwYjlla2JhaGxoTWFaaEVjM2RBaExmV2RWaFlkU2VlYWtmZGVrZlFjV2U1YkNhTGFIZmxnQWdDYlhnRWNKaEZhRWRFYXpnVmduZlJhdWhkZW5kTmF2Z1JnbWNjYldnRWdrYXhjMWRTY2hjQmFTaFJhQWh0YXdkV2FrZUlkN2ZLZWlnOGM2ZkdmaWdSZmNjZmFVY2dnVWhCZFNnNGdjaFJlUWZvYW9lSWRGYzFoNGNhYTNnUmdSY1Nia2g1ZTFnRWZYZ05lTWJVYVhnaGR3Y1ZlbmNRZVBjYWMxZ0lhVWhjZVVhWWRUZGVhRmFOZUhjTWFCZEVlYmJHYVJjaGR3YkdjaWdSZVdjRGZtY1poSGVmZEVjaGN1YUZlbWhRZnRkTWZGZ3dmTWNFZlRhZGFOY0dkVmdaYjBkYmFuYlplemZiYzBkWmduZUZhaGVKZU1jZGdVaG9oUWJVZWtlUWRMYWNnRmRwZkNmWmZ6ZlloZGdJZlJnUmg1Y1RibWZCZXRhVGZGZUZmTmhTZFFjMWVIY2FkU2ZnZ1lhSmVEY29jOGZVZ1VmRmdPY1piMmh4YVpoVGdGZ0ZlNGdjZ0ZnWmIwYkRjMmN0YVNjRmZIZkZkR2FFZzNjaGVUYlRkMmVSYXFnVWN4aGtiYWRmYUNoRmZaZ1ZlaGJKYTZlUmQyYVJjQmRiaGtmcGFrYWViVWRzZFVkY2ZSYzBhZGVUYlJlbGNXZ2RoR2JZaCtiY2EyaFJmYmdaYndoSWhiZVFlRmE5ZEtnRWdGZkpkRWNDaDNoQmZhYVFhbWU5YWljWmNtYWtnVWRjZ2tjNWV6YUVnRWJ4ZE5oVWdSZTFhZGRCZXpicGU2ZVRnbWFOZFBiTGJBYWtmQ2RNZ1NiQmdCZE5id2EwaEZnUGVYZmhmOGdkYUFhOWVyZlVkaGFSYnhnUmJoaE5kNGFVZTBoOWhrZ2FjbGJNZVphRWczY0FnTGZXYVZmWWVTY2Voa2Y4YXdjT2hpY1pmS2FiYTNlbGFhaGFoWGdFY0JiQWZVYzBoQmVYZzNoUWh5ZWRkaWJjYVVlRGJoZm9kYWNPZEVneGYxYVNlaGRCYVNoUmhBYXRkd2hXYmtlSmd2ZVlobWZaZHBoRmVIZkpiT2JjYXhkQmhNZVRiVmdGZUJkUWZUZlVmaGJkZEJkTmF3ZFVlZ2JsYVJoVmVsZkphMWhDZVhkcGhNZkRiWGZnaGtiTGNUY3diUGFZZ0ZmSWdHYURmR2F3YlRjZWhGY05mUGNaaEdocGVUY0doUmJOaHdhQ2cxaGxhV2VFYm5jcGFIYlpiRWNGZ3VoU2NtZTFhMWJZZ1JmUmZ4YkhjUmQxYk5kR2NWZVpnMGRiZG5nWmd6ZWJlMGNaZ25lRmJoYkpkTWFkZFVjb2dRYVdnZ2R3YUxoZWYwZWRnQ2hlYzJldGNxY1FleGRSZXljVGJuZU1kUWdUZ0VlMWZSZVNnUmJWZk9oYWhYYVFhWWdjaEVkRmEwZVVhVWhwZE9lSWNWZ2tkNmRIZTFmOGh1Z1plRmdnaHNnVmh5YU1ldGhRZFNjRWFDaFVlaWZ3ZldoUmIwZjVlcWNVZXhja2VUZWNmQWZ0Z1pkVmVoaEpiNmJSYTJlUmZCYmJha2NwaGtkZWhVZnNoVWRjYVJjMGNkY1JoVWcwYXRmUGNHZzVkOWFjZjNjNGc3ZFpkd2JvZk9kVGNHZzFoRGRFYUFlNWRFZVhmd2dzY1NiUGUyaE5lSWJaZm1ha2hVZGNoa2I1Z3pkRWJFY3hoTmNVYlVna2hWZVRkbWdsZjBjR2JIY0JlQmFkY0ZhRmFLYVRmbmExaEZkQ2hBZVJhUmNjYjNmQmZGZENlUWU5ZTNkVGRoZVJicGJUZHhoTWJrZVVjeGNzZ2ZmSWRsZ01iU2ZFZTJoSmMyYWNkMWhZYVNkZWdrYWRha2ZRZ1dlNWVLZ1pkSGFsZExiRmFIYUViZGFIY1VkMGRaYlZnbmhSZHVjZmUzYnBjamJiYkdoY2hXZ0Vha2h4ZTFmU2hoZUJlU2VSZkFndGd3ZFdka2FKY3ZiWWdtZlpicGFGYkhlb2RHY2NjeGd0YVJiVGZVYVZkQWREZG1jUmZwYmRnQmFoY3djUWFYZlJoUmVTaGtlNWcxYUVjWGhOZ01jVWVTZjhlNGVIYnpjaGVLZ2FkMWhwZUJkY2NWaGdoT2JlZUJidGZHZ2ZoMGZCZFRjR2JSaE5hd2VDZDFjbGJXZUVmbmZwZEhoWmdFYkVjemVZYkdnUmg1YlNoeGhSZ3hiSGhSZDFnTmNHZ1ZmWmMwZWJnaWNRYzJnT2h4aE1kMWZXYkJhSmFFaFhkMGFvYVFiVWNraFFnTGVjZEZicGhDY2JhMmhKYW1mYWJSYlJleWRIZFhlTWFPYVRnQWJWaFJhVGh4YU5oa2RhYVhoUWVZZmNmRWVGZjBoVWhVZHBmT2dkZFJoRmZ6YlRiRmVGZzRiY2FGYjRlN2RKZ1dldGFTaEZoSGhGY0dmRWEzZ2hnVGFUYzJjUmVxY1VleGdrZ1RiY2ZBY3RlWmdWYWdmMWI2Z1RlemJBZ0phSmV4ZGxicWJOZkFoNWJaZVBja2c5ZUVkVGNSaEpoTGdkaERkcGg0ZElhQ2FNYlBiSmJGY01kYWNCaEhneGVEZE9lbGJKZ0ViQ2MzZEJiYWVRZm1nOWFpZVphbWVrZFVmY2FrZTVmemJFZEVleGVOZFViVmVNZlZjQmUwY05kMGNHYkhiQmVCYmRhRmFGZUtiVGFuZlVkUmJjYzBoeGhSY2VlSGdCYVdkZGRBZTlkMGhVZWtoQWc1Z0RmMGNCZTJnSGZnZm9icGFKZ1FoRmZBY0hkU2FOY09mRGVWYzVlR2ZkYkJmUWF4Y0FoeWU4YlliTmJqZGdlU2ZIZ0Rha2JSY0hjUmI0ZVFhV2duYVFiNmFQZWphb2E4Z1NiQ2RwZlRlWGh4ZzhnOGRFaEZjVmJiY2JoZ2Z0YXdnV2JrZEpodmZZY21hWmJwZEZiSGdKY09nY2J4YUJlTWZUZlZoRmZKaEZiVmRSZXBkSWRCaFlkemZEaGlhUWRJZlFkaGRvZjlnV2JDZkJlQ2JIZ0RiMGg5ZUdjU2JaaFdhWmIxY0plQWJPY1FiOWZBY2RhaGY0ZEtkS2NUZmtiYWRRYTFhWmI4ZENmeGRGZ2FlRWVpZWxjT2VhZEdhdGd1Z1NnbWJSYjVnU2J4ZlJjeGRIYlJkMWNOZUdkVmNaYTBnYmNuZ1pmemhaYXhnSWN2ZlhoMGJGZkNmT2RBZDliZGVBZlFkMWRSZU5mVmZwZ2ZkYmJ6ZUZmbWZaYUJhUWg2ZVJhM2ZvZGNlWmJraDFkUmdTZ1JlVmdPZmFnWGJRZVlkY2VFYUZiMGVVZ1VicGNPZElnVmJraDZoSGQzZ3RnNGhjY0ZmWmcwaERlMmF0Z1NlRmJIZUZoR2ZFZjNkaGhhY1ZkRWI1aHFnVWZ4ZWtlVGVjY0FmdGZaZFZkaGFKaDZiR2htZDFlTmNSZUVocGZrZWVoVWFzZFVhY2JSZDBiZGhUaFJkbGVlYU9lMmVBYm1oSWNTaEFkU2RLZ0ViSmZMY0hmRGRCZEVoVmhCYnNhRGNUZGloTWhPZVFnbmNKYWlmSWZEZnhkYWVNZlJib2I2Ylhod2ZKZ05oV2FVZ0FiVmZGYVVhTmIwZkdiSGFCYkJhZGhGYkZjS2VUaG5lVWVSY2NlMGN3ZUhnT2dTYkpnV2JJaEFlTmFCYVViaGNSaHhoUmhoaE5mNGFVZDBmOWFrZWFkbGhNZFpoRWUzZkJnWmVWZlhod2FTYWVia2RkZmtoUWJXZDVoS2NaZEhobGNMYkZhSGJFYWRkSGdRZVFmWmZTZTNiUWY2Z1BlamJvZDhlU2FDYXBnVGdYYndlTWduZ0VjeGh4YzRkUmNBZ3Rjd2dXZWtkSmJ2aFlkbWNaZnBoRmZIY0phT2VjZnhnQWNKZFRnVWZ4Y0piRmF4YjBjOWZKaGxlRWgrYkJkbmNaY1JjVmQxYU5kMWZSZFNib2djZUZmRGJjZjJlVmZqZzBjRGFRYlZjSWhVZmNnVWdZZVRmZWdGZE5jUGZaY0dlcGNUaEdhUmJOYndhUmdGY2xoTGVFZW1hcGNMYlRha2RGYXVjU2RtZVJnNWRTaHhiUmF4Y0hlUmExYU5kR2FWaFplMGdKY25oWmN1YWJieGhJZXZiWGgwY0ZoQ2JPZkFnOWJkZUFkUWMxZlJoTmJWZlpmb2ZiZTJlSmJtYmFlUmRSZHllVGFuaE1nUWJUZ0VjMWNSY1NhUmRVYU5kYWhXZWtlWWNQY2djUWVqZFVlUWJSZkdiZmdBY3BjWmRUYUZmRmQ0Z2NnRmRaZDBjRGYyaHRmU2dGZkhiRmhHY1ZjVGVjZ0JhVGUyYnhlQWdVZ3hma2NUZWNhQWN0YlpnVmRoYUpmNmRSaDJjUmhCZmJka2hvZ3dmZWJWZ1lkK2FjaFJiMGZkYVRjUmFsZVdiZGhHZDVoMmdjYzJoOWFHZVpieGNZZVNjVGhDZkVmQ2ZXaFFiRmRLZVhjemg4Zk9mQWd5Z01mZGhLYmlmeGFhYmNmbGJCZHVhRWFGZDFiYmFlaDBla2RWZlRobWdsYzBiR2hIZUJjQmVkZUZiRmRLZFRibmJVZlJnY2UwaHhoUmFlZkdlOWdXY0liRWRjY2lmQWFSZm9jbmRWaHphbGE0ZFVjMGc5ZGtiYWdsZE1lWmdFZTNkQWNMaFdoVmVZZ1NlZWZrY2Rja2FRZ1djNWVLYVpmSGNsZkxoR2NpYU5hU2hTZVFmRWFSYlJlM2QxZUVlZGRuaE5idmhSZG1lY2RXY0Voa2F4ZDFkU2FoaEJlU2hSZkFidGZ3Yldla2VKZXZnWWZtY1pocGdGY0hjd2RQZk5nMWRSaEViWmQxYUZnSmZGYVVhNWRwZWRoQmhoZ3djUWVYZVJlUmNTZmtkNWQxYUVhWGVOZk1iVWRYYmhnd2JWaG5nUWRQZ2Fjd2ZaZ2NlT2ZCYVVoZGhMZ2toRmNsYlpmR2hwYVRjR2ZSZU5od2FDYzFkbGFXZEVjbmRwZEhmWmhFY0ZldWhTaG1lUmE1aFNheGdSZHhnSGZSaDFoTmVHZVZkWmQ2ZVBkRGZraG5mSWEwZTVhd2VIY3pmaGFNYmRlVWVvaFFiVWZrZVFnTGdjZ0ZicGdDZWJoMmFKYm1mYWFSZlJneWJUZG5nTWhRZFRmRWYxZFJlU2NSZVZmT2VhYlhmcGFaZE5oQWZWaDhiQmhRZkljSGdKZWhoOGdsZFhkMWM4Y3FmUGh3ZUlkNGZCYTNocGFBaEhjWGg4YkhnVmZ6Z3hmYmdHZXlld2VqZUFiQmVkYUZoWmdBZ1VkTGVHZVViWWMyaFRkM2ZWZlplWmYwYk5ldGJVaDBkc2dVZmNiUmcwaGRkVGNSZ2xlV2dkZUdhNWUyaGNkMmU5Y0dhWmh4Y1lmU2NUaEhlVmdLY0VkRmdKaE5jSWZYY0JjYWJRZ21iOWVpY1pnbWZrZFVoY2ZrYjVoemhFYUVkeGFOZVVnVWRrZlZjVGNuY05jMGdUYURmZ2JJZUpnMWY4aFpnQ2d6aEJnVmhmZVFoOGVkZE5hemE0aFRoZmJBZlpmbGdFYzFmQWYxYVRobGg5ZHhnWGQyZFZoa2RhaGxhTWFaaEVnM2hBYkxlV2RWYVlnU2NlYWtiZGNrZ1FjV2g1ZEtoTWJIaGNiS2JVYURkVWFWZVhma2NOZmZnQmJEZXNkamFHYUNlWWNpaEJiQ2hKZUVlR2NoYWdiOWNBZzBhTmFjZ0VoRWJRaGtnR2h3ZDRnUWZMZGliTWVuZkhiWGJ0YVZkV2VSYUJhTWdUaFZoRmdKZEZjVWg1Z3BkZGFCZGhkd2dRaFhkUmNSZEFka2E1ZDRkRWdXZ2RoTWhUZDJjVmh3ZkdoV2c4ZGxoUWJWZEliVWRjY1VkWWdUZmVoRmNOYVBjWmhHYXBiVGVHZVJjcGJhZ0NmMWNsYldlRWduZXBmSGFaYUVjRmh1YlNnbWRSZjVlU2R4aFFkMGhOYXhoMWNOaEdlVmRaZjBiYmFuY1phemFiZDBlWmNuZ0ZmaGhKYk1kZGJVY29kUGNVZGdkY2ZGZU5lZ2dnZk5nSWNnYUFldmVQZlViZGQ2Y1pmSGZNYVFiVGZFZDFmUmZTZFJkVmZPZmFjWGZRZlliY2ZFY0ZjMGdVY1VkcGVPZWRiUmhGaHphUmhCZGhiMmhNZHhlNGMxZ1hlUWdnYmRlVWJEYlFlbmVSZzNjQWNjYVRnMmQ5ZnFkUWVoZkFoVGhiZkJlZGhaY1RlaGJ0YzZhR2YyYlFoSWJZZkFla2JzZk9oQmFsZjNmUGNsZGxjWWdMZEVoMWNlZE9nMmJkYTZhV2ZXYjliR2VaZ3hnWWhTZVRoSGdWZ0tjRWZGZkpoRWZDZjNnQmFhY1FkbWY5ZmliWmFtYmtmVWVlaGdnZGU5aFVmd2VRY01oQWd5aHBhYWNDY2lkd2hWaFRhSGRnZE9jZGRGZ3BoS2dYYlhjd2ZSZmJoMWhCYlJnWWhIYWxjV2VLZUFjOGJpZ1hmRmZjYzVmQmYwZEVkYmhIYUFlc2NoYkNod2hjYlJmWGZIYkFlQWNXYVVkUWZiZFVoRWdkYWtlUWNXYjViS2RaaEhobGJMZUZmSGVFYWRkSGVVYTBhWmdWZW5hUmN1Z2RkbmZwZEZhUmZtY2NoV2FFY2toeGgxZFNkaGdCZ1NhUmFBYXRkd2RXYmtlSmN2YVlmbmh4Z3BjVmYzYXdjSWNJYlZoOGJCYkxneGhnY2RnUmNrYlpiRGFkYkJjaGV3Y1FlWGVSY1JlU2RrYjVlMWJFYlhkTmRNYVVoWGNoZHdlVmFuZ1FnUGFhZjFnSWRjZE9jRGgxYmNjZWhGZGhnUGNkY1JkZGdUZkJmUWY5aHdkRWIxaEJlV2VUZW5jb2ZPZkhmd2M0ZFRjUmRrZDVjNWVTZHhmUmh4ZUhmUmQxYk5jR2ZWZFphMGRiZm5oWmR6ZWJiMGVaYm5hRmJoZkpoTWVkZVVoSmJaZUtnUWRzZkxmZWExZXBhUmZFZW1nSmE2ZWRjUmZSYXFmUmgzZk5lTWRUZEFnUWdxZkJjaGhWYUZhYWFXZlpkbGJXZmtlRmYwYlViVWRwZk9lZGJSY0ZkemRUZEZiRmc0aGNnRmhaZTBnRGYyYnRmU2RGY0hnaGZLYk9mWGNoZFRoVGcyZFJjcWhVYXhoa2RUYmNkQWR0ZlplVmJoZEpkNmZSZzJlUWNWaFlnQWZzZWdlUGhVZ05hWGZmZDFoQmhJaEFnVWIwaGZlSmVDZElhdmRlYnpocGdQZmJoaGNoaEFlQWd5YkVlR2dHZUVhTmhUY0FhbmE0Z1hlRmJ5ZU1iMmNMY3plbGhZZ0tlMGFZZTFhR2NVZEJobmVVZ1Vja2VWaFRobWZsYzBnR2dIZUJjQmZkYkZmRmdLYlRobmNVYVJlY2YwY1FmZWFlZEhndGRMZWRnQmV0Y2llU2dUZzVjeGZSZWhhTmU0aFVoMGc5ZWtmYWRsYk1iWmFFYTNlQmZOZEZhZ2NRZVNiY2dsYXhja2NDZ1dmNWNVYlpiRGJaZ1FkRmJIY2dnM2RIZ1VhMGhaZFZhbmRSY3VkZGFuaE5mdmVSaG1mY2hXZ0Vla2d3YzJnUmZGYlloQWhDZTBnWWJTYkVieGRZZzhnYWZpYU5ocGdDYTNhSWRIaGZmVmdNZEVhRGdBZE1ocWRXaGdob2ZzY0ZhVWd4aDRoRGhuYzlmYWJRZTBnNWV2Z0VmVGRvZjNkSGZuZU5iN2FLZTNnZ2NQZWViMWNzaFlkV2gwYVllVGdlZUZkTmNQZlpjR2dwZFRjR2VSY05kd2RDaDFnbGZXZUVkbmVvYVRiYWRnY0FocWdEZW1jd2U2ZlJjVmhrYWtoVWJVaGtnRWJTYlJmb2V0ZFpkamRwYzZnWmFrYmdoMWJXYlVmWWVBYWZlVmhzYkJhV2EwaHBhR2NKZFJnWWJXZEplamZJZnFlTWhCY3djaGRSYjJoZ2g2YVRkRWUxYlJiU2NSZlZmT2JhZlhhUWRZZ2NnRWdGZTBkQWF3aDhhYWhJYkVnTWY5YVRmRmhsZlNoY2RGZ1pmMGFEaDJidGJTY0ZhSGFGYUdiRWUzaGhkVGVUZjJmUmhpZkFjUmRrZU9lY2JGZjljWGhGZ1ZjNGMxY0NjU2FGYUpnWmUwZlFiM2dNZlFiSmRTZ0pkV2U5Z1VnQ2ZsY0VoQ2JmYkhiOWdqZ2VhbWJaZEtiVGZSZFlmU2dUZ0hoVmhLYUVhRmRKY0VoQ2gzZEJmYWJRZm1nOWJpYk1hbWdkZ01lUGVSZnhiN2FRYmthVmVEZEhnQmh4ZlplR2JpY0Fia2VWYkNkbGFKZk5nVmJoYUdnWmNIZVVmUmZjZDBneGdSYWVoSGRCZVdmZGRBaDlicmZVZmhoUmF4YVRla2hGZTRjVGFrZThld2NaZUJmQmRWZlhhRGY1YU9kVWhWZThhY2NLYVFnOGJ0ZUJhemhvYzRkTGRUZzRkRGJRZ0hha2VNZkRia2NRY1FoV2dsYzVldWVkZG5iTmN2ZVJibWdjaFdnRWFrZnhkMWVTYmhmQmVTZVJnRmU5aCtlQWVnZTBnOWRhY2poUmNnYkdiamY4ZmJnUGgwZFFiRmVIYVJkMGFRaEhkUmd0YmdoZWVEZEpid2RRZVhlUmdSYVNla2U1ZTFhRWRYYk5lTWdVYVhjaGd3ZVZlbmd4Y2RnYWEwYThoVWRKZVVnaGRRZk5nQmh3Z0JjSWRXZ0pkYWRGYjBoQWU0ZVFkaGc4ZkNhWWVEaE1iQWZMY0JlVmJtZ1diM2VKZndlUWhoYWhlYmVIZVJkMWhOZEdkVmhaZzBlYmhuZVpkemViZzBhWmVuZ0ZjaGJJZllmZWZ4YkphZmFBZUVheGVaZ2VhVmZaY29oYmgyYUplbWJhYlJkUmN5ZFRlbmhNZlFhVGhFYjFnUmJTZ1JjVWVhY0ljVGMxZ0xmZmdnZmdoNmFHY0JiNWhHZkliVmJrYzZjSGYxYjhkcmJOYVJhTWR3YUJmbWJkZjRkRmdIZEZnR2NFZjNkaGNUZlRnMmRSaHFlVWZ4Y2tlVGRjYUFnc2hOYmZmQmVKYzZnUmMyaFJlQmhiY2ticGhrYWVoVWZzZVVhY2JSaFFhR2JaZXhkbGdXaGRiR2c1YzJlY2EyZTlnR2haZHhjWmVQZVJhWGZsZWdkRWhGZkplRWFDYzNiQmVhZlFjbWY5aGlhWmVtZEZkQWhmZEFjc2NyYlFnQWdNY2ZiQmRSZG9mVmdVYzJka2M3YkVjV2h0YXJiZGZGZEZoS2VUZ25nVWZSY0xla2VJY1NnT2FUZXdoYWFmYUZjMWJuZVVhbGQxYjVmVmNoZnBoMmFNYVJhb2dpYkxlQmhaZUxoR2NuY2tiUWVjYjFjWWhTZmVha2NjaDVkVGFVZFJjS2ZaYkhmbGRMaFViaWZSZFRkWGdoZmxhUWJHZ1RncGh1Y2ZhaWNkZ21mUmJqYXdkOGNFYWtheGYxZVNkaGJCZVNhRWFrYW9naWdXY2hoQmgwZlNlR2FaZnBoRmZIZEpiT2JjYjBhSmFNZlVjRmJGZ0JhVWh4Y3NnbmZOYzBnd2Q1ZERhamJwZ1JmUWJrYmRjMWdTY2xmbGNNaFVkWGNoY3djVmFuYlFoUGFhZ3dnQmFSZkphUmJOZUJmTmJsY01nYmZMZ0NjTWVBYUFjamhsZndnQ2UxYWxkV2NFZ25jb2RhYmJiVWJsZ25kVWJVZzViNWNTY3hoUmF4ZEhjUmUwYlpiU2J3ZzlhMGZOZFZleGV6ZmJoMGNaZ25iRmdoZUpiTWJkaFJkZ2NRZFRkMGFSYlpoY2dBZVljZWRiYndoUWN6Z0phMWhjZ21oQmV6aHhjZWNSYUVmOGdEZ0RhRWhFZ2JjT2F6ZG9kWWRKYUFia2c5Z0Fia2JoY0hnZmRSY2hkemFFaEFnMWc0ZmVmRWFkYTRoRGh5YzRjRWZWZ1RhMWZQZUdnM2RvYUhkQmR5ZDBhNWRVY1JjQWRJY1dkZ2F0Y1pkVmZoZ0pnNmVSaHpibGhCZkxhUWdzZ3doT2hnaE1hVWZlYVZhUWZVZ1RkVWVKYThlZGdHaDVlMmNjYjJlOWFHYlpneGhZaFFoQWd6ZWNkQWFWZlJhRWRRZUNkWGVCZ0hiWGEyZThkMmhQYnplbGRSZFBhUWNoYXpjUmF3YlVhRGRGZlFoWmZDaFRmbWQ5Y3lnR2RIZGdiVGVkZ0VmeGVLYkdiVGd4YWZkTmZ3ZE1mR2VjZldodGc4Z2RoQWE5ZHJiVWVoYVJoeGJHYXpjbGg0YlVkMGY5aGtmYWJsYk5hTmJIZlRmVmhUYUNoUmVsZEFnTGhoY1Jna2JYZEdlNGRZYmZkMWNOZ0xmRmhIYkVjZGNRaEVoRWd6ZlZibmZSaHVlZGdqZ1ViNmVDYkNjUmNDZVdkd2hNZzdoU2JoZ2dkR2NTZUFnc2RpYlVnMGRJaDBkU2FHZVphcGJGY0hiSmVPYmNoeGNJZ1pkSGZoY1JiSmVSY2hib2c3Z1BoVmFzZWtjUWQyZTlhN2JTaGthNWUxZEVlWGdOZ01lRmN5ZzBlK2RGZVNmQmZHZ0pnQmJ3YlVjT2RFYTVmSGNjZlZhTWVVZFRnbWhwZ1RhR2ZSZE5ld2hDZzFmbGhXZVJiRGhzZVZkWmVCY05idWdWZTJnUWZ0YlJjVmVnZTBmVWcxZW9kWmdVZFVmMWdlYWJkbmFaYXpiYmEwZlpjbmVGZ2hiSWhGZ01jMGdvYVlkQWFFZlFoT2FjZkVjNWRDYWNiV2FKaDJkWWJEZzVmeWRUZW5iTWdRY1RnRWIxYVJhU2ZSaFZoT2RQY1RneGZLZlBleGVaZjBkSGF3aDhjWmVkZVhlUWJoY0hlaGg0aHFiZWNGaFFmZGhRZFRoMGZUaFdhRGNnZkNmRWJ5YnNmSGJIZlNiMGFrYUZnQmNjYlRoSGRFZTRhWGdFaFVnWWh5ZlJheWVrYVVkUGRSZDVka2ZPZ3dmNGNVZE1nQmQxZFFoR2FGY1VoQ2VQYVRmNGY2Z05lbWI4ZkpoSWVSY1lhR2dUYW5jeGRSYU9hbGNKZEVlQ2MzYUJnYWRRaG1nOWNpZU5iQ2N4YkFhSmN4aHdhOWVFYkVkNWNRYlVlMGZraEloVWYzYVJkMGRUZkFmc2JUYmRjRmV4Z0tiWGRBYmdiUmdiZ0VieGVEYmVlR2VwZldiZGZoY0pocGVVZ2dobGNzZVdleGFNY3NmS2dCZzFka2haYjFhTWNJZ2JobmdBZFVnV2dVYmNoU2JZZ0VlZGUwYldia2NSZktnWmZIaGxoTGZGZUhiRmdBYk5kMGYwZlpjVmRuZlJodWdkZGplVWg2YUNkQ2RSZ0NmV2N3ZE1oN2RTZmxnVmRhZUViQWRKZHdiQWJXYWhkdmVZZW1nWmZwZkZhSGFKYU9kY2gwYUliSmdHZVFhUWdiY1dhMGY1ZGhkWmd4YmhlNmZRaFNjQmRmaEJoZ2FzYzdjVmhpZmNjRWhXZEhmaGIvaFZkbWNBY1BkWmZsZEpoZGhlY1JkSWRhaFlkM2hsZlBjWmRHZXBoVGRHZVJkTWJ0Z0ljVmFsZldkRWRuZ3BoSGZaZ0FiY2Q3ZUJjQ2ZjY3RiQWVsaHNmL2ZIZVZmSmJGZVRiVmY5ZDBkTmJWaHhmemdiaDBmWmFuaEZlaGdKZE1oZGdSZ3hnUmFBZUVnUmdaYWZlSGhCYUNoYmEyZkpmbWRhY1JmUmd5aFRkbmRNYlFiQ2ZVZ0ZjN2JTZlJnVmNPaGFmWGRRYVlmY2hFYkZjMGZVYVFnVmRDZlhjeGVGYXpoVGNGZEZmNGhjZEZmWmcwYkRoMmhzZ2FnR2VGY3RlR2JFYTNjaGdUZlRkMmRSZXFlVWF4aGtnVGVQZmdiZGV6Y1ZhaGVKaDZjUmgyY1JkQmJiZ2tkcGRrZWVkUmFnYVVjYmNCZjFiSmJRYTFmVWNUZk9oaWdrY2lnT2czZFJnc2haYnhoWWdTZFRiSGVWaEtjRWdGZEpoTWRRYjNkQmNIaFFiaWdaaHFjTWZtYkFhZGNmZWtkNWg3YVhia2V4ZVFiVWhRZ2RmUWdHZ1dla2V5ZEVhSGFoZ1NhZGJGZnRlS2VIZVhod2JSZGZkRWV4YUZhZWhIaDFjV2FQZEFlWmNpZlhmaGNSZzVnQWN4Zk5hbGJVZndjZGRrZ2RiRmhNYkpjRWEyaDhkTGhDY2xjWWRmZ2VlbGJOYWtiV2IyZjRiWmJiZldmSmFoZ0ZnSGZFYmRjSGJVYzBmWmhWYm5lUWc0ZE5meWFGYXZlQmEyYmNjTGRFZmxheGZ1ZFljQmRCY1NhUmhBY3Rod2JXY2toSmh2YkpnQ2hrYjdoRmVIZ29kY2ZjY3dlMWRNYVhjVWRwYUpoVWZFYTVnM2VkZkVocGNyYVFiU2FaZ1JkUWFWYk5hMWdCYVhmcGZtY1VmWGZoZXdhVmFuY1FmUGdhZzFiSWRVYmNjVWc1aGNlZWNFYzVmbGNaY0dkcGdUaEdmUmhOaHdkQ2YxY2xjV2NFZm5jcGZIY2JjQmJRY1ZhSGJtY29oNmFBZTFjVWZqZGZjbGFJZEpoWGREZ2NkZ2JaYmlmUmQ2ZkVja2haZDdnQ2FoYUpnZGViYlVhTWdRY0RobWY0Y0xjY2VGZnBjQ2FiZTJnSmZtZWFmUmFSYXlkVGZuZE1oWWNHYlRhWWNGZVJnMWRZZkdkS2hDZlpoN2ZQY3diVWR4ZE1hQmg1YUdoSmR4YkZkNGFUYUVmQmJ4ZERhVmZaZW9jRWQyZHRoRGhCYm5jaGdHYlRlMWZKZFRkVGEyZVJocWZVYnhoa2dUYmNjQWF0ZVpiVmJoaEpneWVFZmhjOGVWZ1lnQWdraHNjT2hCYmxlM2RQYWxmbGZZZExhRWQxYmVkSmZtYTVhOWRjYzNmMWdQY0diaGJZZU9kVWZIYlZnY2dHYVZkSWNZaElhWGZCaGFiUWZtYjlkaWNaYm1ia2VVZmNka2U1aHpiRWhCZmtmMmhCYlVkZGdXZkJiaWFnZW1nZWJ6ZjhhRmRNZVRmQWJlZVJhaWNjYlJlZWVFZHhiQ2FjZFFhMWNmYWVoQ2FWYnJjVWdoY1JmeGVSZWhjTmQ0YVVnMGY5YmthYWFsZk1oUmFYZlFjdGJLY1VibGcxYnZmZWFsaHBna2JTYVNiRmZLYWVhbWJkZkxmQmVXaGNhVWhIZVVlc2daZFJiR2JGYzdmZmMzZDliRmNSZG1kY2NXZ0Vja2J4YTFnU2NoZUJkU2ZSZkFidGN3ZVVhZ2R3ZlVkSWUyZDFhaWVhYVhkSmFUZmNkeGRnZ0RiVGJVYzljWGVGZFZmWmdnZWRmQmE1ZXdhVWUyZUZoRWFRZjBiSmhmZEVkWGJOZk1kVWNYYWhod2JWYW5hUWZQYWFkMWRJZ1VkZWZRZ2hnb2FPaFZiaGRFZ0dhV2RwY09oR2VRYUZibGJIaGxhbGRRZ0VjamhWZU9hZmMyaHRldWZTY21jUmM1Z1NmeGJSZ3hjSGJVYThoSWZUZlFiTWhtZ0llSGZaZTdjUmdVZVphbmRGYmhlSmRNaGRoVWZvZFFnVWJrYlFjWmNjYkVhZGdmYWNhbWZJZXVjUWJ4ZFJkeWNUZW5kTWdRYVRlRWgxZ1JmU2FSYlZiT2RhZVdjc2hZZGVmRWdraDdhVWNWaGRhT2dmaFViUWNJaEdnRmE4aDdmT2FCaGNjbWViYUNjUWZXZVVhUmZBYVNoR2R5ZXBoYWZNYm1oUmUyZlRjeGhraEJhZWZRZXNhRmJWZWhib2h2Y1BlRGJCZ1BnTGJRYUlibGFLaHloaGFiaE5mVmRoYjhmR2VSaEVjRWNkYUdiVmMyYllkbWRZYjdmWmN3ZWdiTWJUaEdlRmhEZEdkVmg1YnVmQ2UzaEJkYWRRZm1hOWZpZFpibWVraFViY2hrZzVjemNFZEVkeGVGaEhkemFKY1VmUmdXYkliSmVHZEdiMWZCaFpla2FSZWZhVGVuY01kUmdQZEViVmFZZVVkbmZCaFdlZGFBYjllcmVVZmhlUmV4ZFJiaGJOZTRkVWYxZlZka2VlYTFoTWdFZkRibWEwZkxiRWJWaFljVWRmZ0diMWFrZFFmV2Y1Y0tnWmZIZ2xmTGVGaEhkRWhkZUhmVWIwYVpkVmVuaHhnbWNPY1hkTmR5aGJoR2NjZFdmRWhrYnhmMWJTY2hlQmVTZFJiQWJ0YndoV2FraEpldmdZYW1mWmJoY1FlUWFrZ2FhZmhWZU1kRWZEZ0FiTWVxZVdoZ2FvaHNjRmVVZ3hoNGRFZzNnMGRzaFNibGZKZXBhRWZXZ0pnY2ZXZUhkZ2dzYWZlSGJRY1BnYWExaElmVWJjYVVnWWVUaGVkRmFOZFBhWmFHZ3BjVGdHZFJiTmc0ZlhlaWhJYkNmSGREYmtmUGZKYlJoTWhOaEJnU2VBZjhiS2JrYUJkNWNUZHhlMWRHZkdoVWZkYzllRWgzZFpidmRjZzBnWmN6Y0hieGdJaFFiWGUwYW9hUWdVZGtmUWVMZGNhRmdwZUNlYmYyYkpkbWRhZlJmUmN5Z1RhbmVNYVlhR2RUZllmRmFSZTFmWWRHY0tnQ2haZzdmUGF3YlVmeGVNZUJoNWZHZUpkeGRGZTRmVGVFZk5neGVEYVZnWmVxZEVkV2R0Y0FkSGJYY2hmS2JPZFhjaGdUaFRmMmVSZnFkVWN4Y2tmVGFjaEFldGZaYVZoaGVKYTZlVGh5Y29mNmhMaDBhRmV2ZkJnRWNzaEpnY2ZSYlZmU2RUZlFjZGZJYmRjSGJaZi9iY2UyYmxhR2JkYVFoTWdIZFJnWGJsaGdhRWhGZkpiRWdDZjNnQmFhZFFjbWE5aGlkWmFtaGtmVWJjZ2tmNWQ3aFhmamVjZ01lV2FrYUpmb2dUZ25oUmQwYkNibWJWYlVoZGhGZGRjS2NBZ1hjd2ZZZGZiMmVaZFJkZWRIZUJkV2RkZUFlOWZyYlVnaGhSaHhkQ2hEZGxoNGRVYjBkOWZrYmFhbGhNYlpmRWczY2tjUWJjaDFoWWZTZ2Vha2dkZWtnUWJUYk5oZ2JaZUhnbGJMZUZnSGFFZGRiV2F4ZmhoWGVGYVNiQWJuYk9jVGUxZXZmRGhtZTlnQ2NHZzBod2d1YllhQmhCYVNiUmRBZ3Rnd2hXZGtkSmJ2ZE1jQ2FNaDlkUWFTZUFoQWFjaHhhaGRtYlRiVmNGZ0pkRmhVZjVicGVkYkJlaGJ3Y1FoVGhVZ3FkUWJoY3BkMWFEZTJlMWdNY1FkR2RCYTVoVmRuYklhUGJmYlVhRmhwaGNmVWMwZFRmT2RTZ2hiSGhNYUdocGhOaEJjeGFOZ2hoR2dWZEJjV2VGYkhkcGNSZmRkemZ4ZHVmUWZXZVFkNGdNY0Jld2RsZkhjUWVOZVRlR2FVYkJnOWZiZ25oQmN6Z2VnVmJVZGFnRmFoZGxiTWNOYURhRWNHYVFkVWNRY05iY2FBZDRmL2VSZFdoSmFtZWFoUmdSYnlkVGVuZE1kUWJSZ1ZlWmI3ZVNhUmNWYk9iYWNYYlFjWWdMZldldGYwZ1VjVWFwZU9lZGVSYUVmMWdHZFJnOGg3ZEphQmc4ZTdnUWFXYnNnY2FIZkNlVmRLY0VneWJwaGZlVGV5ZjFnamFVZjBkSWY1YmNmQWZ0ZlpkVmRoZEpoNmNSaDJoUWRIYUliUmFoYmtnY2dSaDFiVmVJY3hjMWFZaFFnUmNrY1pjZGJIZk5hMmZDZUJnSmNLZFpmMWVnZlNoVWdYZlVmWWFDZzFkSWNOZUNjMmY1ZGFmRGZIYlJhaWJLZUdha2dmZGJmMGM1ZmdmR2JXYlpoTmJVaFVha2hWZlRnbWdsZTBjR2RIaEJjQmVmZUJmUmVLYlVoM2VVZlpnSmd6YmNjZmNCYlhnQmVLZWFoQWU5ZTZkUmRCZDFmeGFUZFJjTmR3ZEJnemRRaHFjYWFsZGdlWmRBaGdnMGhMZ1JnVWhvZlNnWWJraDVla2dTYm1mNGFlY0hnemFkaExiSGIzZEVkUGhZY0VjUWVWZ1Znamh0ZGdhSmVpYVlhOGZEYW1kOWdlYUdmZ2hsZzhnUWh3ZHRnNGJSYUFidGd3Zldna2ZKZnZnWWdtaFlkN2ZVYVNhWWNiY0lhVmg1Y01kQWJsZDhjRGZXYmdoY2huZGZkQmRwZnlhU2dHZzllN2dTZ2tkNWUxZkVnWGVOaE1jRGZGYUphd2ZWZW5lUWNQZWFoMWVKZ1NoSmdBZ2hkUWdMZUJob2dBYUtobWRvY0FlRWNVY2RkNWJDaHdlSmY4Z0VobmhwYkhiWmhFZkZodWhTYW1iUWQvZUJnRWhaZHhoRmZUZmRhTmNHZFZlWmIwZGJlbmdaZnplYmEwZFphbmhRZEZjTWZlZmRiUmRnZWNjZWhFYVFkTGhjYkZocGNDZmJmMmJKYW1oYWFSYlJjeWFUZWplb2NRZVVjVWMwZ0ZiUmgxZmtoTGdKZnpiTmNNZk9kRWIxZ2VjVWdVaHBnT2JkY1JmRmV6Z1RnRmdGZDRnY2FGZVpjMGhTZW1ndGhQY0ZkRGRoZ0doRmVuYmhnQWZRaDBnNWFxaFVleGdrYVRmY2JBaHRhWmNWYWhiSmU2YVJlMmdRZU9hYmdsaGRla2JlYTBna2RZaFdheGQwY2RiVGhSY2xhV2RkaEdlNWgyZ2NiMmY5Z0dmWmYxYjRkU2VVYlhkVWV4aGJhVmM1YXVoQ2IzZ0JkYWZRYm1lOWVpZFpibWdrZlVlY2drYzVhemJRZjBneGRRZVViVmRnZkRhWGdYZEZjbmNGZUZjcGVCY2RlRmhGYktiVGhuZVVjUmFjYjBkeGRSZWVjSGRBY0RkZGNCY0pjcmNRYmhiaGNiYVJmaGZOZzRkVWQwZjlia2NhYWxhTWNaaEViM2dBZkxnSGUxZVlmUGhlY2dmNWVrYlRnR2g0Z1BlZmUxaE5kTGVGYUhhRWVkZEhjVWcwY1phVmRuaFJidWZNZEhoTmF4YlJkamJJYk5nT2NFYnhkMWNTZWhoQmJTY1JmQWZ0Z3dlV2VrZElhNmNZYW1oMWMwaEZnQ2FGYWtlY2J4YkJlTWZUYVZjRmRKYUZjVWQ1YmdiWGFoaGhkd2NRZlhiUmhSZVNka2I1ZjFnRWhYaE1jRWZYZHlkZ2NsaEJjVGF3aEhkSmdWZXBlQWFmZFVoWmhHZmRmRmZNZ2FlWmZHZkZjVGNTZWhiTmN1YUNjeGQ5ZVdkRGZYZW9mQmNaZUZjdGJ1aEhmMmJSYXlhU2UwaGRhNGVGaEFoWmNuYUdhVmJaYTBjYmNuYlpmemFiYTBlWWYxY1VkMGZZY1pkSmV3ZFFoUWZXYW1hNGVMZmNiRmhwZUNmYmUyaEpmbWVhZFJkUmF5ZVhkM2VNZ05hVWhWZEJhUmFEZERmOWZPZ2FkWGdRZlloY2JFZ0ZoMGZVZlVlcGhPYmRmUmFGYXNnVGVGY2xjd2FJZ2xnWmFwaERjemM4Y3BoWGVYZUZlTGFFZzJma2R1Y1JnbWVoYUFoVWV4YWtjVGVjY0FmdGFaYlZkaGdKYzZnUmQyYVJiQmZiZ2tocGFzYk5na2NzZ2ZiYmNCYTFmY2JOZmtndGJXZ2FnbmhCaDJjWWRSZ0plUGNhZ3pid2FTY1RlSGVWYktnRWVGZ0plRWFDaDNlQmdhYVFnbWI5ZmloWmhtZkZjYmNjZ2tnVmV1YUVoQWcwZDJiV2RSY3NnVmJVZW5mVmYwZURoSGdsZkJkY2dsYUZnY2NYY1FjZ2ZZYWZjMmhaZlJmZWRIZkJnV2dkZUFoOWRyYVVmaGFSYnhmUmhoYU5kNGhVZDBmY2FyYmFjbGVnZEVoRWUzY0liV2JSZUZjUWViaGNhMmcxYmtlUWVXZDViS2JaY0hhbGNMZkZhSGdFaGRmSGRVZjBlRGVWZG1oWmZ1Y2FjMmQ1ZXlnUmVpZkllV2VGZUVicGZmY1NlaGhCZFNiUmFBY3Rhd2ZXYWtiSmJ2aFlobWJaZ3BkRmVIYkpjR2NlYjBhSmVNYVVoRmVGYkJlUWVUZlVjZ2VkZUJiVmR3ZVVkd2FsYlJlVmVsZkpnMWVDYVhkcGFNYldhbmVnY2tiTGJUZDBiUGZaYWxlSWFGaERhRWE4YWZlVWJsYU5iUGRaZUdmcGRUYUdnUmVOZndhQ2ExZ2xjV2dFZG5mcGNIaGJnQWQ1aHVhUWdYZmxmNWRDZW1mOGFqYkhkUWdOY1RhR2ZVZ2Rla2VFZTNhOWUvZVJhVWJaZW5oRmNoYkpmTWdkYlVhb2hRaFVia2dRYkxiY2dGaHBiQ2RaYnljMWdtYVlmZ2RsaHlhRGh3Z2dmWWdIYWtkMWdQYlZieGJWZWFhWWFIYVFmZWdjZkZiZGVuaExoRWdOZUNjWGN4ZkZhemRUaEZkRmg0ZGNnRmRaZzBhRGcyYXRiU2ZGY0hiRmFHYUdkemRkY1RkUmVIY2xmcWNFaG1lSWNiaEloZ2Z0ZEZhU2FoaEplb2NUYm1mUmFIZWJlbGN4aDNhQmhFaEljWWNXZnhnMGJkY1RnUmhsZldoZGdHaDViMmVjZDJjOWNHZFpieGJZZVNlUmhEZHBlS2NHYzBhOWdFZ0NnV2ExZVllU2gyYVpidWVUYUdia2dVZGNma2E1Y3phRWVFZ3hnTmVVZlVibGJkYlFiRGFrYmhlU2d6Y2hiSmJPZTFoaGJHZlpoSGNVZVJnY2IwYnhiUmRlZkhjQmhXYWRjQWU4ZGpnWGNGZzRiK2dEYjFmMWF3YlVjVWMxZHRhUWhGZ01kWmRFaDNlQWdMZ1dkVmdZZlNmY2ExZHhnT2VRZFdjNWdLZVphSGRsZUxnU2RWZHNoZGJIZlVhMGJaZVZibmJSZ21jSmVIYzBkdGhIZXpkTmFUaGZkZ2ZrZzdkRGNVZlFjYWhSZUJoWmZ3Z0hkMGh0aGpmWWNtYjRmN2RHZWliWWdCYkVhVWRrYlllQ2JEYkFhYmZSZndmOGJ3ZmRoQWFWaHdmRGhuYjFiZGJTY2tlWWJuY0hlemFVZmVmSGNqZVVhU2VEZXllQmNLZENlZ2NCYUdnTWFCZDhhVGNaZFZlTWdjZmJiWGNGaDVhR2RSY05od2ZDZTFkbGhXZ1ZlRGdVYVZhWmhFYmxkRWJTZ21oUmc1ZlNoeGRSYXhmSGNSYzBhYmRXYUFhUmgwZExiM2RaZ3VkYmZ6ZDBjYWhHaGpjaGRNYWRmVWZvYlFnVWJrY1FlTGRjYkZhcGRDYU9nbWNKYzdhYWZXZDhlUGJRYmxha2FRYlRnRWExZVJlU2dSZFZiT2RhZ1hnUWNZZk5na2ZGY3BkVWRVY2dlYmZPZzFkVWIyYkNnaGhnYzJmTmJSYkplMmJEYzJocGRQZ0ZjQ2hVZmZiUWR6ZTBkY2JDYVdiUWVmZkdlbGRkYkhoYWFHZW9lTGFCaEZjTWhqYlJmM2d0ZkJnR2d3ZU1lcWZMZlZnTmQxaEllMGM5Y2NlRmdCZ2xjTWZkZUFkOGhraElkU2I0Z2ZiYWN6Y3doU2NUYkhkVmNLYkVjRmdKaEVoQ2QzZUJoYWREZ21kOWEvZ1RjR2hrZFVmY2JrYjVmemhFYUVoeGdOZ1ViVWZrZlZhVGFtY3NkVmZlY2hnTWhsZUVoVGRjY3RnSmhoZXhmN2NHZkNhQWM4YUZkaGI4aG1oQmhYZjBnWWJKaG1iRWRIaE1iV2ZzZ0JlS2FRZjRjbWFLYlJoZGZjZFZoVGJkZkRkRWVCYnhiWmhOZWdob2JxYURoamU0Y2JiTmJpZ29nZmVRZ1NnZGNLaFJlUmFSY0RiUmhtY1ZoOGZaaFdjZGg2YlVlSGhBY09jQ2gwYmRhNmFTY0JneGE0Z1JiQWd0Y3dlV2VrYkpodmJZZ21hWmhwYkZjRGNGZU9iYmFoZUJiY2NRZFhndGNKZEZjVWc1Y3BhZGZCYWhmd2dRYlhlUmJSYkdna2Y1ZG9kRWVUYTljQ2FIZ1RkMGUrYkVjU2ZCZkhjY2FIZ2dmVWFjZlVhWWhUZ2VjRmVOZlBkWmVEZHBiVGZCZ3hnTWh6aEVjSGVOZ1dmRWNuZnBmSGFaZkVnRmh1aFNobWI5YXlhQ2ZEZTVheGNIYVJiMWhOZ0dnVmRaaDllUmRIYlpmemhiZDBlWmZuZkZlaGJKZk1iZmFRYnRlcmZFaFRja2NMZWJhVmdvZ09oRmRDZkVkYmNZZkJjaGJ5aFJnaWZaZ3JhQWJFZU1jU2VBY1ZmUWNjZENiamd0Z2NkTmFTYkFkZ2ZXZVFlbGZIYkNmQmRGZHVoVGVCYUpmeGNhZTNjeGYwYkRmMmZ0Y1NjRmdIYUZlT2hSYmdmTmZSZlFobWdaaGtlRWVGYkZnU2NJY21jZ2NXY0VlbGdjYWJlRWIyYXhkUmVaZ3phZGZrZlphRWZzZENiWWV4ZFFmUmhUY1JhRWhEaERkMmh3YUpjY2RXZ0VkRmdMZzFnZGdBZExmemRvZ09mVmJUY01kUWFBZzJlQmJUZVBkMmE5Zy9hWmJuYThiSGVlZjFhVmhaYUVoRWZ4Y05lVWdSZVFkWmFaZEdkbGUwYUdhSGFBYkhiSWZSYjhmSmJHaGpoeGhlaFBoVWV4YlpjTGZIY3hnV2JKYWdjWmFyZUNkVGg1YnhmUmRoZk5mNGdVYTBlOWFzYU9kRmExZExlVmVqaEZkUGZXYlVlc2RTYVBkQmJJZ3FjQWVqaG9mRGZLZ3piZGhMZUhhQ2hVYVJoSGFSaDhlVmdWYmpmMWRpaGRiamNaYWplUmFpYWdhZmZFZWhhZGhmZlNkaGhCZVNjUmVBZXRjd2dXYmtlSWE1aEliemZSZ3BkWGRIYTVka2VjYnhhQmZNYlRjVmRGZ0pjRmNVaDVmcGdkZ0ZhWmc4YmFjM2FSY1JoU2RrZjVjMWdFZVhiTmRNaFVoWGRnY2pjVmhtaGtiUGZjZzFlSWZlZmNjUWRrZlRiZGJWZk1lS2NaZEdoZGZUZENhQmQ5Y2FmQ2IxZ2xiV2hFY25ocGJIZFpoRWRGZnVnU2RpZFZkNWNWZWhhUmU1aERnQmIxaFJkQmhWaFlobmNaYTNhWmUraGJiMWFkYXJkUGZCYkpjTWNkZlVkb2NRZVVma2dRY0xhY2RGaG9lWGZiaDNiOWJtZEtmQmZSY3NhVWVIZk1hQmNRZ0djZGRSY1NhUmRWYk9jYWFYZlFkWWRjaEVoRmQwYkZnMGdwZlRlZGJSZHhka2NRY0hodGE0ZWNmRmhaZjBkRGYyY3RiU2hGZEhoRmdHYVhkM2hoaE9oVGR5ZzFhcWVUY0JibGhjZmNiQWdaZFpmUmJ4Z0pnZ2hSZzNhUmdOZFJnRWNwYmtmZWJVY3NnVWdjY1JoMGRkZ1RjUmVrZFZkZGVIZ05kMmVPZG1iOWNaY1pjeGdzYkRjVGJHZjllS2ZBZFZjNWF1Y0NhM2dCZWFmUWJtaDliaWdaYm1ka2hVZ2NjaGE1YnplRGJVZHdhWmVLZWhmc2RWYVJlV2FrZjRnWmFXZHRocmhkY0ZmRmJLYlRnbmZVaFJlY2IwZ3dlWGhOZnlmSmVXYWZoQ2ZWY3JiVWhoY1JjeGhSY2hoTmY0Y1ViMGI5Z2tlSmdsZU1oU2VEYW5oQmJJZlZlVmdaZ2FoZWhsY3Bia2NFZ1dkNWJNZlpiSGdGZ0RhQmdYZUVnQmZBZVVjMGdVY0VkSGYxY3VjZWczZE5jK2hUYTJjc2NXaFFla2h4ZnJiVmdBYTFnU2RTZVVlMWY4ZVdjZ2FSZHZlYWdYYXRlcGZSZjJmbGJrZWNheGFCaE1kVGZWYkZmSmhGZVVkNWhwYWRnRmU1ZndmWGMzZ1JmQmFVZVdiUmIxYUVoWGNOYU1nVWRYaGhhd2hWZG5kUWNQY0llMWZJY0pmY2hWZFFjR2JiZGxnTmZGYVphQ2ZKZFRmRWhoYk1ia2FjZEFjdGdXZ0dkWGRvY0xhR2dVYzFldWVCZG1lUmN5ZVZmaGhRY3liRWVSZDBkTGhHZVZjdGJwaGJhbWU1YVpnYmYwZlphbmZGZmhoSmhNY2RhVWJvYlpnU2RXZzRiTGNjYkZncGdDYmJjMmdKZ21iYWRWY0ljOWRIY0hjTWFZZVpha2IxZFJnU2ZSYVZoT2JhZVhkUWhZZWNmRWZFaDZhVWRWYmRkT2hQYVJmRmIxYVRoRmhsZHdkWWZWaFpjb2RFZjJmdGZmYlVibmFoYkdjSGhuZmhnQ2hSZG1naGNxZUdheGJraE5oYmFoZlplWmZXYzFoUmQyZFJieWRKYkJiWmRWZmRia2dQZEZnQWgrZGNhUmIwZ2RjVGRSYWxlV2hkaEdlNWEyZGNoeWdsZ0doZWVSYVliQ2RWYTFjOWFLZkVmRmdKY0VmQ2EzZ0JnYWFRZ21iOWRpaEtnR2VrYkpmY2ZsaHhkbWNCYWtmeGhIZ1VoUWRjYlZjUmNXZWthZ2NZaHllSmZCZWZlMWhFYkdhTWIzZWtmUmJQaDBkeGdhYlpnWGhBZVZhZWJBZjhhdGVVY2hhbGVzZVJoZ2Z0aFNjVWMwaDlla2hhaGxnTWVaYUVmM2VBZkNnUWduYXdjU2ZlYWtjZGFrY1FhV2Q1YUtlWmJEYUFlTmJGYUhja2NOY0hjVmJBYUVmU2IzZ1FkbWFmYTNkTWNuZlJnbmNvaFdnQWYwZ3hhNGJTZmthVmNKZmJiZ2J0YXdjV2JrZEpndmJZZG1kWmZwY1VjVGY0ZmRnTmFoaEFmWGdaZDFnRmFKaEZlVWg1YXBhZGRCZ2hnd2VRZlhjUWZZZkRmRWY1aDliV2RYY05iUmVUZ0dnVmV3YUZoM2cwZ1BlT2ZSZ2RmQWRKZEJmUmZkZGVkQmgxZ1BnZWQyYnBhRGRHYlJneGZ3YUdhMWRsZk1lRWhuZklkWGJaZkZkNWV1ZVJjM2JWZzViVWZSaFJlZ2FGYkJjMWJIYUdjVmQ1YmxoYmZuZmxjemZmaDBkOWI4Z1BiQmVKZ01mZGhVZG9mUWNVZmtoUWhMZWNlRmNwYktlSWJXaEpldGhkY0JhUWhmZURieWVkZllnUWFoZTBmZWJIYmhoMWZjY1piWGVSYmRiZWVVZWhiNGFVY1VnSWNHZGRkUmd4ZHVjVGVBZlJjeGVhYjNoeGMwYkRjMmN0YVNkRmJIYkZoR2hFZ3lhVmQ1ZlRmMmhSZHFmVWd4ZGtlVGVjY0Flc2JMYkVmMGJZYXZjRmdTY3BnQmhaaGhncGdrZVpia2VzYlpmWWhCYTBkSGhUZFFnaGJmZ2RjR2JSZzJhUGJXYjliTWNaYTNjdGNUZkdnRGYxZ0VjUWZCYjBlVGJBaDJmSmNXYVFlaWRkZmlkYWUyaGxjUmNlaDFiVmVaY0VjRWZ4ZE5hVWFVY2tlVmVFZjJnQmI0YU1ibmRCY0JhZGFGY0ZjS2FUYm5jVWVSZ2VheGE1aGZmTGN5aElhZmZJYkVmcGRyYVRieGJRZjNoRWMxZDBjN2JCZndhWWZyZUpjRmZNY1JnUmEzY3dmTGZDYjFlb2ZTZE1kMGV0ZWtiQmhHZkpiS2NLZTNjVmJMY1hiSGVnZWRhUmdtZGNjWmdWYW5hUmR1YmRmbmJOYnZiUmVtZWNjV2JSY0FnMGduZFNobGQ1aGVoYmVnZ3Rjd2RXY2thSmh2ZFljbWhaZHBlRmhIZUplT2NjZDBhTmdBYlpoMWhGZUpiRmNVZTVhcGJkZEJnaGJ3Y1FkWGFSYVJiU2dnYzloNWJPZTNjTmVNYlVkWGdoYndkVmFuaFFjUGNhYTFhSWNVYmNnUmhNYlRjWmJWZk5nWGJaZkdkQmdUYVVoUmFOZTllQ2Z4aFpjV2FIZjNhcGhXaGFlR2Z0Y3VlU2NtZlJjNWFTaHhkUmJ4ZkhiUmcxZk5lR2RWYVlkeWRiY21hdGV6ZFpoMWJkZm5oQ2hnZzVjTWdJZUVjTWVRaFhmMGRRYmFjZmhIZ0JiQ2RiZjJiSmJtaGFiUmZSY3lmVGduZ01oUWdUZUVnMGRkZFNjUWJoZU9mTGQzaFFoR2hiZGtlRmVsY1hjV2RCYU9kZGVSYkZhemVUZUZlRmY0ZmNoRmRaYTBhRGcyZnNhUmJGZUdieGZHYkFkV2d0Z1RnVWFuZWxjM2FVZDFiWWhUYmJod2RzaDBnRmEwZllheWhTYVRkUWdPZE9mVWFKYjJjZGZVYnNoWmRZZHdoa2ZVZFRiUmVSaFdmR2NTYjhkaWRPYTJiRWZXY0tlRWhFZ2FlWGRuYWxhS2RIZVVhVmJUZUFnbmZCaEFkUWNuYTlidWZUaEdoa2hVZWNha2c1aHplRWhFZ3hoTmVVZFVma2hWZFRkamdsYzBnQmRYZEFkRWFkY0VnNWJLYlhhbmRVY0xmY2V3YVJlUmJkYVhlQmRIY2VoQ2ZWZXJkVWRoY1JjeGFSY2hnTmI0Y1VkMGM5YWtlYWdsZE5hVWJFYjJoMGNMaEhmRmNZaE5mZWZsZ1pla2ZXYjJhNWFIYWRoWGZWZGhiRmRIZUVmZGNIZFVjMGdaaFZnbmVSZnVnZGNuZE5jdmJIaDJjY2NMZEVnbGd4YTFnVmdCZ0FjQWhSZ0ZlY2RzZVdha2ZwZy9oWWduYXRiMGJDZlhiSWRjZ2NkeGZaY0tiVGZVZUZiSmRDZDBmNWg0ZGRmQmJkaHdnRWUzYjFhUmFWYlVoNWVrZ0ViV2JsYU1lUWhXZk5oYWVWY25kUWZQZWFmMWVJaFVlY2hVYVljVGZlYUJkVWRBYk5nbWdwY2JhTWF4Z05md2dDYzFlbGNXZkVibmNwYkhnWmFFYkZjdWhTY2pkWmM1YVZjaGVRZGNhWGFFZGtlRmFGYnhlY2QyaFBnWGM0Z2hiWmZrZ3BhTmhGY2hjSmdNY2RkVWVvZlFmVWFrZVFnTGNjZ0ZkcGNDZWJoMmZJY3ZlT2RuYW9oemZJZUhidGVDZ1JjVWYwYk5hRmJSZlVjY2JhYVdoa2FGZGJoVWZGZ2xoVWdVZVZmT2VaZFRmdGF6YlRmRmNGYjRhY2JGY1poMGFEYzJodGNTY0ZkSGRGYkdhRWUzYWhjVGFVaEdmUmhpYVdnMGJvZlRjYmZRaHNlUWJCZlhid2Q3ZEtjV2F3ZFRkWmMwY3BlN2FlYlZkb2hVYmFkeGQwZk5kUmVCZFZoV2FmZENoQmYyYmJnbWI4Z0FjYmhoYThkNGJUZEhkVmFLZkVmRmRKY0VlQ2gzZEJiYWhRaG1oOWJpZFpkbWJrZ1VmY2NsYVJmemNHZ0VoUWVEZlVnVmVRZFZjSWd5Y2djZ2FVY0hkNGNIY09kQmQ0Z0ZnSGdIYjFkOGdNYWhkZ2VaY2RiamJ3Y1pmTWJ3aGNlNWVXZ3hlUmcrZVJobmg0aDVkQmV3ZGRhcWRCYmpiMGJMZUdkbmFrY0hhY2YxaFlkU2ZlZ2tlZGFrYlFjV2Y1aEtjWmFIYmxoTGVGZ0hlRWhkZUhkVWcwYVphVmdpZlpidWhmaEhmTmRuY0JlMmdjZUxnRWdpZUVjMGRIY2xiaGJjYUZnRWZRY25jVWdsZUJhamVZYm1kc2duaEhjWGd0Z09kYmh4ZUJiZGFUYVZjZGFQZUZmVWNZZ25kZWNSZVZoOGZRZVhkd2VRY1Nma2JSYW9hRWdXZEZkRmNXZUhlUmdhaFZjbmNRZVBoYWgxYkljVWVjY1VjWWVUZWVnRmFOZVBnWmZHZnBoVGhHYVJkTmN3ZkFld2R0ZldjR2JXZmRkSGZLZGtoRmZsZlNjaWVoYzVhVmVRaGxoeGdEYUJiMWJTY0dlUmRWZTBiWWZYaFlheWJiYzFkeGhuaFZkUmRKaEdhZGNTaGRoUmNCaGdid2VGZUlhQmVVY1ZkWmYzY0JocWFhYlFoVmh5aFFoM2ZOaGNnUmVVZ1JkZGZZZ3hnVmNPaGFoWGhRZ1lnY2NFZEZmMGhVYlVjcGNPZWRjUmVGZHpiVGdGaEZoNGZjZEFhUmgwYUJjV2RzYVRiRmZHZDloYmVFZjJhcGRUaFNnV2VKZHFiV2MxZmNhWWdlZndkZGNaY1hnbGVOZDZnU2dIZGxiQmRmY0VkTmd0ZWRiV2hFZlVjY2JSZzBoZGdUZFJlbGFXYWRoR2U1YTJlY2MyZTljR2haY3hoWWdTZlRhSGRVaEVhRWdGaGxoRWVSZjNhQmdFYlhjMmc4ZWthVGJHZ2tlVWZjaGtoNWd6Z0VnRWh4Z05nVWhVY2tlVmJUY21jbGMwZEdiSGRCY0JjZGhGZUZhS2NVZFhoVWhaaGVkeGc5Z1JlWmJYZkJmR2ZmZ1FkTmhyZVdibGdwZ3hoV2J4YU1mK2FXYWthWmFPZ2FlbGFNZlpjRWUzZUFnTGVXZFZkWWRTZWVma2FkZ2toUWFXYzVlS2ZaY0hkbGFMaEZkSGZFZUhkSGZRYk1jWmNYYlhiUWJpaGRnbWQxZXlmUmFuZVliOGRFZmtjeGMxZ1NjaGVCaFNnUmFBZXRnd2VXYWthSmZ2ZVljbWdaYXBkRmNIYkpjT2RjZ3hjQmVUaFRiVmJsaEJlUmRrZjViMGJkZ0JjQWhpZ1FoWGE1ZFJnQ2MwZzVkNGZFaFdlSmZGYVViWGhKaHdoT2F6ZVZjYmFJYjFieGRFYlBkaGhFZ2JnYWFsYzlkUGRLZzJmTmJhZEZoUmdOYjRjUmJWYWxlZGREZTNlb2JMYWJlVWVoZ0VmU2VtYVJjNWJTaHhlUmN4Y0hnUmMxZk5lR2NWZVplMGZiYW5iWmN6YmJlMGZaZG5mRmRoYkpiV2FkYVVnSWJZZkFoVWZRYVdkY2hBZGhnQ2RaZVdnSWdMZUtlRWRBZDZlUWJDYU5oZmFHYjBiVmZEZVJlUmFVY0NkYWFYaGtnWWFZZVVmaGQwZVdoMGFvaGphTmhFZlVjN2ZRYWdmRWEzaEpmMWI1ZG1oQWgyZnNhZGFIZlhkaGRLY0VnM2NBaGRkVGIzY2xicWhRY3hjQWhhY2VhUmJCZ3pjVmFoYUpkNmhSZDJoUmdCZGJla2ZwZ2tjZWJVYXNiVWFQZmhnMGZEZVVkQmNsY09lYmEwY1JlMmNjZjJkOWJHZVpjeGZZY1NjVGZIZVZmS2NFYUZkSWRRZmNoRGVsYWFjU2dXYThleWJHZDJna2NKaGNjbGR4Ym1oQmZVZnhmTGJVZVJmb2ZaYlRkamRsYTBmRWYyZzFhQmVPY1ZnMWJLYUhjWGhVZWVhYmhrYXhjRGhiZldiWmRhY2RjRWNCY3JhWGR3YmxkeGFYYmpmbGY0Y1VkMGU5ZmtkYWdsZE1oWmhFZjNoQWhMaFVoRWgwYzRoZWhrZWRha2NRZVdiNWNLYlplSGdsZkxlRmhEaGRjU2hUYjBkMGJSZWZiSGVSZXViZGNuZk5idmdSYm1lY2hXZ0Vja2d4ZjFnU2JsYTVoU2NXY1FhdGg0Z0ZkRWVKZ3pnZmJtZVljbWFIZlhmSWhTaGNkMGhOYUFjVGJRY1JkSmZIZ2xiTmRwZ09kd2dOaGFlUWJYZlJmUmFTaGtmNWYxY0VlWGFOZk1lVWZYYWhjd2JBYTNoUWdSY2FlMGVJZlBmV2MwaFlnVGNlZEZmTmFQZVpnR2RwZFRhR2RSZE5kd2hDY3dlMGR0YldhM2RwZE1lWmVCYkVkVGhTZ25kbGE1ZldkUWZGZ2thSGVSZXRjTmJWZTFjcGUwYlBjbmVaaDRhY2JrY1locWZHYmhjSWZDY2RoVWFVZE5kVWZsaFllZWNaZmxkWmRDYk9hbWVKZHJlZGVCYVJlcWNaZUhmTWZRZFRmRWcxZ1JnU2ZSZFZnT2JhYVhmUWJSZGFhMmd0aDBnVWFVZnBkT2RkaFJmRmR6aFRiRmdGYTRkSmFDaDBhOWJEYzJlQmZTYlJlSGVGY0xiRWh6aFVmdWhUZnpnaGQzZ1Vod2ZnYUJmYWdBYXRjVGRWY2tndGdoZWJjV2VSY0JhYmZrY3Bka2NlY1Vlc2JVYkxiQmVRYkdiWmR4ZmxnV2VkaEdmNGNyZGZjMGhWZkdlWmF4ZllhU2FDZmlhQWZFY1Vkd2VZZE5oUmJEZDVkYWRTaGpkdGFyY1pnamdJYStnY2RraDVhemdFZ0VieGdOaEJld2ZoYkhiVGFqYXRlMGFCaFhmQWFhYUtjVmE4ZWVhQWFRZFpjRmJJY1FlVWJmZ1BkMmd0ZjhoZGFBZjllcmRVZWhoUmh4Y0VoaGMwYTliQ2Z4YjhhcmhPYkFmZGNLZ0VkMmYwZGhhV2ZWaFlhU2RlZ2thZGZrZFFiV2U0YnJmTmNpYXNiS2hUZVhjOWhVYVRjaWF4ZkxnQmREYlVhM2hkaGljOGR6ZWJmR2NjYVdnRWhrZ3hjMWRTYWhkQmJTZUFibGE0ZCtoR2hSaFljbWVMZFNnaGZwYkhlQ2NaZUhmY2YwYXRjbWRUaFZoRmJKZ0ZiVWQ1aHBlZGFCY2hod2hRZ1NkWWJVZkhjaGZzZW5oWGEzYU5hT2ZLY2plY2Z5YkhlRGhGZU1mUGQxZ0pkMWVJYXhiUmFTYklmU2E1Z05lWmdIYmRiT2NHYVVoRmQraFNhQmFnZWFkWGVuaElhVGZiZFZicGZFZFNobWJSaDVnU2Z4Z1JoeGFIZVJmMGdRZkFobmR4aDBoYmduYVpjemZNZGticGVOZ0ZmaGhKaE1lZGdRZHhlRmFIaEFoZGhmY09lUmRVZU1oYmcyZW9meWRaaFJoUWVnZlJjM2ROaExmWmNrYzFnUmZTZFJmVmhPYmFiU2FKZFplSWRrYkVlOWNYYVVnb2NMZmJiamN0ZnpkVGdGZ0ZkNGRjZEZjWmYxZkJjeWIwZ0hhV2JqaElmU2RXZWphY2NkaFRjMmZ3ZGxmV2doZ2xhSWZXYWdodGhaZlZmaGFKYTZoUmYyZVJnQmZLYkJjOGNxZ09maGg5ZWRmUGRsZE1nZGRCZFJnRWNDaGViR2c0Z2tiZWVtZDhjZGhUZ1JmWWhTaFRmSGdWZktjRWdGY0pmRWRDZTNnQWdJYUJnemRzZjNiTmRDYmNhVWFKYmdkWWY2ZlFhMGJ3ZkVkSGN4ZnBnQmhEYnliY2YzYlhhVGg4YkhhZGhCaGxoZ2FUZ25lVWFSZmNiMGN4Z1JmZWFIY0JoV2FkZEFmOWhyZVRhUmdSZTViVGhrY2Nid2hHZmhneGFxZEZjUmY5ZldlUmhIaEFiV2JXYlVmWWViY2RhbWMxZmthUWVXaDViS2daZ0hnbGRMYUZmSGZFZWRlSGFVZjBiWmdWaG5md2U2Z1BnamRvaDhmU2dCYWhjZWZXZXdhc2U5Z1NnZ2QxZVNkVmNBYkpjOGNjYkVjSmV2ZllobWRaZHBoRmhIaEpmT2hjZXhlQmdNZVRhVmZGY0poSGhSaG9naGhQZlVldGIrZkVnemNFY2NjQ2R3ZGNlN2VWZVRmWWNlaFViV2NWYXdlR2dDYkZoRGZKYzFoc2dZZFdiMGJZYlRlZWNGZE5iUGdaZ0dlcGdUY0djUmJOaHdlQ2ExY2xkV2dFYkNhOGFKaEloQWFRZW9oQWZ5Zm9nOGdEYXhmWmh4ZEFjQWhCYU5oVGFRYThha2NLYXpha2ExZ2JheGVSYU5iRmNoZEpiTWdkY1Vlb2FRZFVla2dRZkxmY2VGZ3BiQ2hiYTJkSmFtY2FoUWJ0aHlkSGdYaDFnVGFEYVFmRWFkY1FlVWVFY0dkSWFDZ2NjVWRjZkJmVmM5YWVoMGRwYU9hZGRSZUZmemRUZkZlRmQ0ZGNkRmNaYzBlRGUyYXRiU2ZGZkhlRmZjZEVkM2hvYkFhR2N6Z1liamVIZVZlNGdSZGNmQmZaZEViVmNrYllkamhGZHliRWRPZEtkRWhvaHdhVWcwaHNoVWJjaFJmMGRkaFRiUmdsYVdoZGFHYjVoMmJjYzJhOWRHZ1poeGRZY05kVGREY1JiRWhVYXhkTWZJY1JnM2ZnY09mQ2RpZVloeGJhYm1mbGVBZmZja2g0ZmhoR2hXZ1pjTmdVZFVia2JWYlRkbWRsYjBhR2ZIZEJkQmNkYkZlRmRLaFRkbmNVZVJnYWdVZndkSGJOZnpoa2FTZmRhRWhGZ2xjRWdWYlVhOWhDY2hnc2dzY0dod2dZYTNnWmVsYk5lTmdIYTNoQmFaY1VnRmY4YjRiZWZrZGRja2VRaFdkNWFLZlpkSGVsZkxhRmVIY0VhZGhCZzBkMWNYZEVleWZOZXVjUGVuaHNhN2dTZm1kZGNFYkdkMWVkZWZmU2hoZ0JlU2VSZ0FkdGN3Yldia2ZJZ3loU2RHYVpjcGNGY0hlSmJPYWNheGFCYU1hQ2R3ZVFiSGFWYmhjb2ZnZ09mMWVaZndoRGczYndhRmNSY2tjNGFuYUdoSGFNZVhiZWYzZmhjd2ZWZW5kUWVQZ2FmMWRJZlViY2JVZlpmQmhQZFFjY2hhaE5jaWdSYlRmRWVVYmNjNGRRY2dmcGNZYWJnVGFZYUloTWUwZ0ZlemVTaG5kUmQ1YkZkeGVRZWxjRmhCZkZkTmhFYlFmSWU4Z0pneWJWaDlhRWhBZjRmdWZVY1ZocGhNZ2FmRWZvaEFhVWZoZWdkTGhJYWxhTmZPZGJhemVZaHViSWNFZ2RmcGhaZEhjTWdRY1RmRWIxZVJoU2FSZlZjT2NOYUZoNGdZaGNhRWNGYzBmVWFVYXBhT2RkY1ZlY2VtYkFoaGRJYXNjT2ZSZ2tnNmhEZXpnaGFhZ1FhSGhoaEdoU2FGaEpkVGZUZDJjUmVxZ1VmeGJrZlRnY2dBY3RjWmRCY0ZmY2J1YUViamVZZlBoYmNrY0lnd2dNYVFoSmVIYmZmMmdKZ1JnQWZrZjVnV2dhaFdjNWVnZ1phbmVwZlZmY2NoaFlmVWdUZkNoRmVEaEhkRmFKZE1nWGZ6ZmdiVGJFZ1dkRWRkZExjaWhCYVRhT2FrYjVodWRFYUJmaGdOY1RkMWRjYkxhVGRuZ2hiaWdFYlhmeGVCYUloQmRrZURmSGZXZzRlN2JjaDBmeGJSYWVlSGZCYldhZGZBaDhkMmZlZ0JkUmJ4Y1JnaGZOZjRkVWQwZDloa2RMZEFoWmhYZ1ViQ2RSZUNhRmVoYmdiU2NPYzBoOGV3ZFRhV2M0YVljYmJYYWtmUWRQaG5kRWZkZUhoVWMwZFpiVmduYVJldWFkYm5kTWU1YkJjemRVY1djV2EwY3hhb2RTYmtnQWJUZ0ZlbGNnZzFkTWJ3aHdjN2FhZWphSmJsYUZoQ2NCZU9nTGEwZHhhTWRYY0VhRmZBZERnbWhSZnBnZGFCZGhhd2NRZlhoUmVSZ1Nma2g1aDFjUWN6Y1llWWVCY0Nhb2crYVZobmR4Z2JkSWF4aHRiSGVmZXpkbGhmZ05nd2NSZ1BnZWhXY3BlRmREZ0FoWmZqZUhhbGFsZVFoRWZqYU5hT2VhZkVjRmdtZUhiaWJ3YndiR2hCYW9jT2dWYVZkUWFLYVVjVmZaZHBmYmVqYjloemZjYlZnaGE1ZUZiZ2FOZWFiZmJFZVlnUWRCZGdheGRDaElmMGRGYm9mYmYyYkpmbWRhYlJoUmd5Z1RjbmhOY05kWmFrYzFmUmdTZVJoVmVPYmFmWGRRYlloZWVCZXBoZWNVYVVicGNPZGRnUmJGZXpoVGFGYUZkNGNjYkVlVmdpZ0ZjV2NzaGFjSGZCaHdoSGZSaHpoQmZkZEhkeWNzZTlmV2d3YW9lRmdmZEFhdGdNZFhkeGF0ZDJoYmFXaFJoQmViYWtjcGdraGVoVWRzaFVkY2dSYjBmTWFXZXdhTmJXZ1BlR2VZZ2JhTWFqZHNhT2ZhaFViWmhkZkdoM2MxY2JmQmdsZDVhRWRIYUhkbGZUZVRha2FWaGljWmJtYmtnVWJjYmtjNWR6ZEVkRWZ4Z05nUWVGYmthUGFUZWlmRmQ4aGRhVGRFYVZkUGZGZjhiYWJBZ1NjSWhaZ1libGR4ZWRjZWdHZ2xmZmRmZFFlTmZCZFVnaGNSZ3hjUmZoYU5iNGJVaDBhOWdrZ2Fja2RFYURoRWF6ZGdmRGJOZkJjZGVHZk1ha2RrYjBmRGNqaGxiQ2ZkZW5nVmRMZ0JlMmFFZlVhRmdFYUVhemNWZ25iUmN1YWRkbmhOZXZlUmFtZGRlTGJIaG1kWmcxZVNjaGFCZVNiUmJBY3Rnd2ZXYmthSmd2Y09nV2RaYTZoQWdtYmhmT2dPZHhmaGNmZldoMWVoZUZlRmNWaDloL2JiYWhlZ2M0ZVNlV2ZWaEhjUWQwZkplMWJBZEdiTmdXY1VlVGRCYzRiUmMyZVFoR2RaaDFjSWhHZGFhMGJaZWJnY2JFZ0ZmR2daYURoZGJhY0FiamJsYXdiQ2QxZ2xhV2RFZW5lcGJIYlphRWJrZm1iUmVEYVFocmRCZUViQWUrY1NoVWFRaGRkWGZGZGdmeWNQYURja2EraERoUWc4Y3pkUmhSZUpoUmhkZFFlUWNaaFhmbWU0ZExjY2VGZHBnQ2diZDJiSmZtYmFjUmZSZHljUmRqZ3NlZWRIYUJhOGVlZ0hiVmJvYmFhTWZDZVJoZGZmYWdmY2ZtZEhlZ2VjYmdoSWNGZ3dheGRDZVFlTmg0YWJjVmZZaG5jQmhtZmRkNGFGYUhnRmFHYUViM2VoZFRkVGcyZ1JhcWRVYnhkRmFiYmZmbGRzZ0xhR2FVZlliMWVFYnpjMGRSZktjMGNRZWljS2Z3ZlJnWmRBZ2tibGVQY0JoRmRjYVJoZGhIZ05iMmhNYW1kWmdLaFRjUmJZYVNoVGVIYlZlS2hFZEZhSmhFZENjM2NCZFNkQ2JtZEVieWdOZUNnWmhBY1BnUmZvZnFoUWZBZmxlRGJCY1FmWmc3ZUdheWhRZDJiWGJTYkplQmZhY1ZhRWhNaEdhemh0ZFNjSmR3aFVhZWFOZ25kQmVlY2ZmUWU4YXdkZWFCaFJleGJSYmhjTmc0ZlVjMGY5aGthYWJsYk1nWmRFYnlhSmFPZERmUWNOYUFlTmJFZ2RoeWNWYUhkdGRaZGNnbmRsZUJnRmhDYVZkVmVWZUJlNGRYYkthVGh3Y25nTWhUZ3RkdmhUZVdjZGdDZ1dkZ2NVaG1iUmhHZThhZWZDaDFmeGhyZmNkRWJKYXZhWWdtaFpjcGVGZkhhSmVPZGNjeGFBZVJkUmZGZTFiamJGZFVoNWJwYmRlQmFoYXdlUWFYZFJoUmhTZ2tnWWc5ZkhjeWFNYWVmSGJpZHdoL2FBYWliMWFmZExibGV4Y0FhUGVqZVZkSGFLYWhmb2JCYUlnMmNwY09kR2RWZlVmbGJSY1Jmb2hDZldjemFVaEpjWmdFZ2tkNmNRYjJlUWVpZ1lnUmZSYXhjSGhSYzFmTmhHZ1ZjWmIwZ2JhbmJaaHpkYmN4Z1FoaWNRZ2tmY2JlZU9hMGZwYUVlR2hnZjFiWWJmZmdkNGNOY0FkVGZjaHJhS2YxZ0VlZ2NSZ25mb2ZlZEdlQWVJaGljSGRVYmNiSGJKZHpnTWRRY0pmRWVFY29lRGVVZXBnZmZaZVJnaGdvaFpnbGZGYzRiY2dGYlpiMGFEZjJidGRTZEZlSGdFY2JhR2FuYVJhNWRUYTJkUmRxY1VkeGVrYlRiY2ZBZ3RhWmdWZWhib2V5Z1NnVGhRZlRkSWZSaDRjcmRMZlJlSmhFaE5mQmZOZ2NoQ2dWZzFjV2FhZldnNGJ3ZUpmaWRFY0ZjTWgxZjlhZGVBYW5iVmNDZVJlRmJ0YUVmVWJGZ3BlYWdRYW1mOWdpZVpmbWJraFVhY2FrZjVhemdFZkVnd2RiZ0VnQmRzaFZnSGdHZ2xlcGZHZ0NjUWFKYVBkUWRKZ0VjTWJUZmxiZWJKYUVoeGVhZmVmQ2JSZVljQ2gwYU1ia2dCZlJiaGhiaFJlaGNOYjRlVWEwZDlka2FhYWxiTWJaYkVlM2dBY0xjV2NWZlphYmNlZ2xncGdrYUVmMmQ1Y1ViZWRtYWRmTGFCYldiY2hHZU5oMGgwYVphVmJuZFJkdWNkZ25hTmJ2ZVJobWRjY1dnRWNoZTRhd2VIY2tmVWVBZkNoZ2N0ZDRkY2ZFaEpmdmJZZ21iWmFwYkZhSGJKZU9lY2h4Y0JlTWJUYVZkRmZKY0hmUWJkYnBiZmd3YlZkd2hGZFRid2hZZkdlVWhBZEtoV2FUZW9iTGNHYVhnaGI3YVZoaWVBZ0JiRmZCZ3BiZGNOYWdmNGVhYWRiSGZsYlBhWmJHZHBjVGdHZFJiTmR3Y0NmMWZsZldoRWZuY3BiSGhaZUVna2E2Y0FoaWgwYnFoUmZXZHNlOWdVYmtkcGJOZEJkRmdaZGlnZWIyaE5lZ2JlZGtlWmRoZUZha2JCYkZjZWJXZEFiUWhVZ2tiUWdMYWNjRmZwY0NnYmEyZUpjbWVhZFJiUmF5Y1RlbmF0ZEVnQmFBZlFkQ2ZSZjJjb2RHZEllRGJOaFFkY2VGYXhhMGVSZTFoOWZiZFpoZ2RSaHpjU2dsYkVkeGNlZlZicGVlZ0RlMmV0YlNjRmVIZEZkR2RFZTNmaGZUZlRiMmZSZHFhVWN4YWxkSGhPZEVmSWVLZGZlQmJKYzZlUmgyYVJoQmViYmtmcGRrY2ViVWVzY1VhY2hSZVFmR2VaZXhnbGZXZmRjR2M1ZTJnY2IyYzljR2haYXhhWmRQZVJmWGFsY2dmRWRGZEpjRWRDYjNmQmVhYlFhbWg5YmlkWmhtZkZiY2FmZkJhNGVoZFhoeGJnZENnQmZSZ0JjRmRDYjJmY2JuZ1RjVGFJZlZnSmFoZEFlSmRHZG5hVWRNZmNld2dvaEVlTmZqZk1kQ2ZQZVVnQWdsaFVoaGh3YWxkVGd4Yk1iamdlaFVkOWFraGFkbGZNZVphRWQzYkFoTGZXZVZjWWJTaGVlaGJVY2hiRmdUY3NnWWVLYW5ja2VmY1hoRGJoYk9lRWd3ZnhlZGJFZm5kd2M2YWVjRGNBYmpoQ2ZTZGxoVGhHZWtoVmU3ZUJoRmRVZFZiQmhWZDhmMWZVYmthdGVtYmVhVWV4YnBmRmFIZUphT2FjZXhoQmdNY1RlVmJGaEpnU2FFZWRlbGNYZGhkaGV3ZlFkWGJSYlJiU2drZjVnMWdFYlhmTmJFaEdnWGJZZmdjQmREZ3RnYmhKZEFmWmFOZ0ljUWVNZ2RnTmJRY1lmRGZNZ0NmTWJEZ1ZoVWZwY3dnRmZsYmtjUWZSYnpnUWVFZk1mQWNnZ2hoQmhHYVJheGFIY3hhMWF4ZlJjamhkYU5kR2JWZlpjMGNiZG5iWmZ6ZWJmMGdaZ25kRmRoYklnYWhOYUJkZ2VRYkFmRWNnZWhhY2hGZnBhQ2JiZzJmSmJtZmFoUmRSZXlhVGduZ01nUWdUZUVlMGdZYlJjVGU5aE9nYWNYZ1FiWWdjaEVnRmcwYlVjVWdwZ09nZGNSZEZoemVUZEJmUmY0aGJnVmFZYWdoUmV5Z0ljQmZHZmdhNGFPYVdmamc4Y2JlUWIwZzVncWZVZXhla2NUaGNmQWF0aFplVmRoZ0phNmZSZDJiUmNCYWJhZ2ZWZGtoWmdFZ3RmQWhPZ1ZiUmVPZVFnMmNZYmFoT2N6aGxlNmZXZldjOWZHYVpjeGdZYlNmVGJIY1ZkS2ZFZUZjSmFFaENnM2dCZmFmQ2VtZDlnL2JaYmpkMGhhZURkUWhZYjZhVmV3ZVJlQmRlYjBha2ZWZ1RkbWNsZjBhR2FIZEJoQmNkZUZmRmNLZlRnbmNVZlJnUGJVaHhmTWRlZUNoUmdZZUNkMGVNY2tkQmJRZDliYmhSYmhjTmU0Y1VnMGE5aGtjYWhsZk1jWmFFZDNlQWVMaENkeGdOY0dmTGN4YVVncWJRY1dkWmJnY1pnSGZsY0xoRmhIaEVhZGVIYVVkMGhaZFZjbmdSZXVmZGRuZk5lbmhEZjJmY2JMZkVjZ2dOaDFnUWJCZUFjY2RUY1FjZGhhZFdoa2RKY3ZiWWFtZVpicGZGaEhlSmdPY2NjeGNCZ01kVGNWaEZlQmdSYjBjNWIwZ2RiRmdGZHdhWGQyYnBoUGdTYmxhOWZqY0dkSGE5Ym1mVWdYZGhod2ZWY25lUWdQZmFiMWhJY1VmY2NVZFloVGFlZUZmTmVIYk5mbWRwYlloQmFCYk1iMWdDZDFlTmdXZFhmSGNOYUxiVGRraEZkdWhTZW1iUmU1Y1NieGhSZXhoSGJSZjFmTmJHZFZnWmIwZFplaWZSYnpkYWdWZXRibmJBYUFlZGNaZlphbGc4YlpiWGVtZzRiTGdjaEZjcGhDZWJjMmdKYm1kYWVSYlJjeWJUZ25hTWFRY1RmRWVVZkRmU2FSaDVlVGdhZVRjc2hZYWVla2FFYjhmV2FFYVpma2JkZlJoRmV6ZVRjRmhGZTRiY2FGY1poMGFEYjJidGFTYUZiSGdGZ09kUmd6aEFoYWVIY0dib2JWYUhmMWRaZEVmY2RCZFplWmdRZkFkZGJ2ZVZnSGVGY0JlYWVFYW9ldGVjY0VnY2ErZWNkUmQwZGRkVGFSYmxlV2JkaEdjNWUyZGNnMmQ5ZUdjWmJ4ZFlnYWhHZkRoMGFEZFFkMWN3ZzdkUWh6Z2thZGRDYm1mOWcvYlpmbmQ4YUJmWmUxZjFmbWFFZEVlcGVOZEFiMGJBZlplWmZHYmxlMGVHaEhnQmhCY2RhRmNGYUtnVGhuY1VlUmFjZzBjeGJSZExiRGRnYWZhSmF5Z1ZhcmZVZWhmUmV4ZlJkaGFOYTRoVWMwYzlla2VhZWxkTWZRYkNlRmJvZExlV2JWZVlkU2ZlZmthZGFrYVFiV2M1ZUtlT2FYZ0JiSGhQYm5nRWVkZEhoVWIwZFpoVmNuaFJodWhkaG5mTmNuaERibWRsY0diUWhBZE1maGJCZFVmUWRMZ0ZiRWM1YytlSGdnYXNmNWFZYm5kdGFwZ1VjaWZjZEFjTWJFZ1FlRmNBZGhoOWJKYkhmUmJwY2dlZGNFYU5hYWhRYlhhUmRSZFNma2E1aDFnRWFYaE5jTWdVZFhoaGd3Y0hiemJJY1BjWWYwZ0lkVWdiYkZhc2JUYUxkRmgwYndnS2NDZlVhRWJHYVJhVmEyYUNoMGJsaFdjRGcyZ2RiSGdNYUVlOGFSaEFlaWIwZythQWJ4ZzFmeGFTZVZmVWZmZVZiZ2NGZjBoQ2h5ZlFkaGhJYkJnUmJ2aEZmRmhZY0ZhSWF3Zk5oRGJHaHdhdGJGZ2NhQmVnZGJjYmN6Z2dhamdPZjFidGZ3Y1JlMmZnZjZnVGdFZDFjUmhTaFJlVmhPaGFmWGFRYVlhY2FFaEZlMGdHZ0FmeGJPZmZhUWRGYnpiVWJVZnhiNGVKaEZkZ2ZMZVJheWdJYlZnWGVIYUZlQWhGaFhlaGJDYVRmM2VsYTNmVWQwZzBkZGREZDBmY2hXZEFlUmZ0YVFjUmgyYlJlQmRiZmtocGRrY2VnVWVzY1VmY2JSaDBhZGNUYVJja2JFYk1jVGRvZGpoSWVTaEZhR2hiZTBlSmNhZ0JiU2JaZUVlUWJoY2NjSmFTY2pja2hVYkJhaWFvaHdnWmhuZVFoVWdQZkFlc2RrYkVnQWdSZ0ZlUWJVZUFlY2JRZm1ja2VnY1VhRGdrYlNmYmMzaHRoS2VUYW5kVWRSaGNnMGd4YVJnZWVIYkJnV2dkYUFmOGhpZkZkQmZSYzVjRWhoYzBhL2hCYTBkY2F3YUlmaGdwYktjR2ZuZ2tiaGhXZVZoWWRTZmVia2VkZ2tkUWdXZjVmS2haYkhmbGJMZUZlSGRGaFBnV2ZCaGxkTWRCZ0RncGJ1YmZkbGVsZHZkUmNtZmNnV2RFZmtoeGgxZlNnaGNCYVNkUmFBZHRkd2FXaGtkSmh2Y2FoamhJY2hoWGhTYkZjQWVJZlZnVWZCYkRhQmZnZkhiVWRRaHNhN2hkZEFjVmV3ZUZkVGR3YlliR2FVYkFjMmVYZFRid2ZDZ0ZmSGRCYzVjWGczYmdnbGVhYjFlSWZVZGNnVWdZaFRlZWVGY05hUGVaYkdhcGNUZ0djUmJOZ3dlQ2QxaEVjQ2ZXZmpkTWZVaGFiamI0YWlhQmJUZU5iNWNWYWhjUmRoZEZhQmRGaG5nR2JWYlplMGJiaG5hWmN6YmJnMGdaY25oRmZoYkpjTWhkZlVmb2dRZVVka2N4Y2ZnT2FCZU1mUmJZZlJhMGV1YUlkRmRNZjZhVGRtaDRhUWNYZ0VhUmNkZllkeGVWYU9hYWRYYVFmWWdjaEVnRmMwaFVkVWVwZU9lZGJSZEZnemZUYUZoRWNzZ09lQmM4Zm5iSmJXZ3RnU2hGaEhlRmJHZEVmM2ZoZVRjVGgyY1JjcWRVYnhma2VUZ2VlUmZCY3phVmFoZUpmNmRSYzJoUmFCZGJoa2ZwaGtjZWFVZ3NoVWJPYUZoc2FkZ1JnVWEwaGViUGJUZzFnNGNOY2pmNWNPYk1ieGg4YWJkWmVuZlZjS2dFZkZmSmNFY0NhM2ZCZGFkUWRtZjloaWhaZ21na2dVZEllQWZzYm5lUmNSZjRmRGJVYVVoRWMvZVRobWRsZzBjR2ZIZkJlQmZkZUZmRmFLYlRhbmJVZlJkY2QwZnhnUmRlaEhoZ2JDZlBjRWZZaDRoWGRFY1ljMGNDZTFoSWV4Y0hoUWdzYmhlT2JGaE1nRWFFZnplNWJPaERibGVaZmFkY2ZsaGRmdGZTZ0dlSmZnY1phSGJsY0xkRmFIZkVhZGJIZFVjMGVaZVZmbmVSZ3ViZGJuY05ldmVSYW1iOWZDYVdlZ2ZVYW1iUmdHZzhkZWdDZTFleGd3ZVJoMGhKZitjYWEyaHBmRGFGZkhiSmdPYWNheGdCaE1oVGhWZUZkSmFGY1VkNWhwYWRoQmFoZ3dhUWNYaHdoRmFBZ2dkY2ZtY0hod2Z3ZUVjR2NEZThiNGdWaG1ma2RQY2VhMWhzZFllV2EwZ1llVGNlaEZhTmdQZlpmR2NwZVRjR2RSaE5ld2NDYTFnbGVXZkVhbmhvZlRiTGdBZWdiOWRZZUdjUmE1YlNneGFSZXhnSGJSZTFhTmhHZFZlWmMwZWJlbmZaZnpkWmFsZTFnTmVGZmhoSmZNYmRhVWZvZ1FjVWVrZVFjTGZjZkZhcGdDaEtiU2gwaDBnYWdSYXdna2JEZnlnRWhRZUhoa2ExZU1hU2RVZUZjQWRLZ2pnaGZYY1BhZ2ZSZzhkV2NFY1pkT2FQZkJoRmF1ZFRiRmZ4Y3BnYWUxZlplMWJXZHljTWhiYlJiM2E4YktmUmUzY0FnQmFSYm5kOWhxZFdoamRNZFRnY2VBZHRlWmNWYmhnSmg2aFJjMmdSZEJoYmNrZXBia2NlZlJja2JhZElkbGZWZ1VoQ2EwZjBoNmRNZ1NhZ2JpaGVnM2I1YktiWmh4ZGNkQ2NSZ1hnbGhLYVdhVmNsZlBhRWVGZnBoYWFRY21jOWhpY1phbWNrYlVkY2RrYzVoemRFYUVmd2VMZ0hiaGVzYVZhUmhrZE5kMGFHZEhjQmZCYWRoRmVGYUtlVGZuYlVkUmdjZTBoeGZSZGVkQ2VRaGVkUGNWZnhmbGJBZkZlRWM4ZEJlMWVvYTJmRmh3ZW9kMmVhaGtmNGRaZVJhemhoZkNkQ2NsZWhnUmdOaGdkZ2FxZ0JnR2VaZkRkYWVIY2toZmVYYkRoaGRPZ0VmemRKY1ZiR2JTZ05kdWJhYTNkTmMvYlNhbWdkZENiV2FnYlVibWRSZUdmOGRhaERoVWd3ZTRlV2hsZTlldmVjaG5lMWREYUZjSGFKYU9oY2V4YkJjTWNUZlZiRmNKZkZhVWM1ZXBnZGZCZ2dnNWVRYldlcGVNZFNlbGY1ZHViT2YzZ05nTWVVZFhnaGJ3YlZnbmhRaFBlYWIxZkliVWNjY1VkWWhUY01hVmM1Y0NoVGZtYXBiVGFHaFJoTmN3Y0NnMWdsZ1dnRWFuZnBlSGhaZUVjaGRFYVNlbWRSZTVkU2J4YVJieGZIZ1JlMWdOY0doVmRaYzBhYmRuZllmaGNZZlJlVWV2ZVhkMWNRZ1lkQmh3Yk5lWGdHZWhmQWNEZFlmVmJOZk9oUmZXY0pkbWZhaFJhUmR5YlRnbmZNZFFlVGFFaDFlUmRTZFJmVmVPZ2FjWGFSZ01kT2ZBYWdlbmNYYnhmZ2FMY09kRmVBYjZiQWVoZlVkOWZJZmxnZ2I0YVdiMmhNaEFkSGFYZkVkYWZUaDFjSmVUYlRoMmJSZXFlVWV4ZmtlVGhjY0FndGRaY1ZoaGFKYjZnUmYyZlJkQmNiZmticGJzYUxiUWhOYmRkSWJoZU5hUGJDYkZjUWhYZVBkU2dBaHliTmRqZjFhSWhOZUVlTmdRZkdnQ2RjZUxiVWV3Z1piTWVXYlhibGNXZGFoR2I5ZWlkWmZtZ2tnVWJjZWtmNWR6Y0ViRWR4aE5jVWFVZmtmVmdUYm1lbGIwZUdmRGRsZEJoYWJrYXhkS2NYZDJkTWU3Y2NmMGN4ZVJjZWdIaEJhV2JkZEFoOWJyY1VkaGdSZ3hkUmdoaE5iNGNVZjBmOWZrZmFhbGJNYUdmRWUzaGhnZmVFZFJiOWVCaGRiRGFnZHNkQ2dDZWtkQ2ZaZUNhVmhXaEZmR2FBZmRoQWZWYkVoWmNYaGphMWR1ZWViM2ZOaCtiVWJHYTRkZmZPY0VkeGYxZFNlaGNCZ1NnUmdBYnRjd2hXaGtlSmN2YlljbWJaZHBoRmJIZEphT2VjZnhiQmZNZFZnMWVGaEJlUWZRZVljZ2JKYnhnWWdQYURjVGNzZ0dhU2hoZEpob2dFYldlSmJNaFRkV2ZSZndhSGEzYjBmR2JjYkhiZ2ZVZmNjVWNZYlRmZWNGY05mUGZaZUdkcGhUaEdnUmNNYmlkVGRnZDBnRGZRaERkUmdIZk1lQWJrYm5hR2VYZDlkVGJTZ3hnUmV4Y0hiUmcxZU5mR2RWZVphMGhiYWlodGU2Z1lkMmJ4Z25lRmdoZkpkTWhkZFVlb2RRZVVma2hRZkxnZWhCZEplTWRQZXpjQWhwYVBlVmNzY21mRmV5Y05lVmNRYmdoTWhVZkRnbGdRaGFkTGZIZVFkRmRjZEFlY2JoZkhld2RrY2FlUGZGYjRlOWRUYUZobGh4ZmNoQWgxY2VoRGIyZHRjU2dGY0hmRmhHYkViM2hoZ1RoVGEyYlJhcWNCYVZiaGRCZGNlRmc5Y1piU2J4aEpmeWJVZFhhRmJVYWZlVmQ5ZWtoZmQwaHRmS2RKYVZnVmJVZkhhaGZjZnBiT2hDaEViaGJlY21mOWhOZ1pkd2VjYUpnWmVuaFZkS2JFYkZiSmhFZUNjM2hCYWFnUWhtYTloaWFaaGphdGJSZkpjaGFzZ2hjWGVraHhiRmVlZjBla2FWY1RhbWVsYzBnR2ZIZEJjQmFkZUZoRmVLZVRmbmVVYlJjZWF4Z2dhWmdNZ1NmTmdZYkNjMGJNYmtlQmVSYlJoc2FSaGdmVmJ0aFJobGZ4aHhlYWNsYVVoWmZSZzNha2JIY2NkMWNZYVNjZWVrYWRka2dRYldjNWVLZ1pkSGZsaExlRmRIZUVkZGVGYVJobGFSaEhleWZkZ2dmQ2NUZHNnbWhBZ1NnOGNXaERjMGN4ZDlnRmNFZlFoYWFEZVZnaGgrZEpjUWhvZm1lSmNTZzVicGFIZTNkSmVHYkpneGZCaFNnVWEwYzllSmZCYkZlaGRnZ2ZmUmZoZTJnUWJXZkphRWFYYzFhMWFnYkdiSGY5aG1jVWhYZmhnd2ZWZ25lUWVQYmFiMWJJaFVoY2hVZVlkVGhlY0ZoTWZiYkxjQ2FNaEFkTWh4YU5ld2VDZDFibGRXaEVhbmdwZEhoWmRFZkZhdWVTZW1nMWRpZ1lhUmhSYnhiSGJSYTFmTmZHZVZkWmMwY2JmbmZZZnVlWmRrZ3BlTmRGYWhkSmNNZmRlVWdvZlFkVWhrZlFmTGZjaEZjSWhLZ1llVGNJZzBjSmdrYkFoOWFHYWljcGNBZkNhVWZNZVVmR2RFZEFoUGVKYlNoY2hZYWJnVWhFaDhnWGd4Y29oY2dPZWtlVWQ4ZEdlQWFnZW9jTmhWZ2dmeGRYZ21idGdQZkZlRGNjYlRjWGVUaHNhSGhCY2lnc2JrZFVheGZGZkhjZWRRY3NlQ2RmZUJmSmE2Y1JmMmRSY0JlYmJrZXBka2NlYlVkc2JVZGNjVWg5aFlhR2ZVZHdoRWJPZW1jNGNpZ09oeWJZaFZoYWFXZWxkZWVBaHlmSmJLZURiVWY5aEVhWGYzZzRkbGhEZWljQWgxZlpkbWE4Y1NlY2NoYm9oN2ZXZlJhOWFEZExoZ2hGZmNoQ2JTZkZjMGFCaFdiMWVCaElkRmc4YTFkQmVqYnhlV2ZPZDFjZGI3YWVnSGdCZVdmZGdBYTljcmJVZGhkUmh4Y1Jia2E1ZXhnWGgyZVZna2VhYmxnTWNaZ0VhM2hBZ0xkV2VWZFljU2VjZ2dlOWVxZUVjVGR3ZkZjTWVEaFliZmhUZFNlRmFZZEVhd2FwZ0xiRWR6Y1VkNmdNaHloRWRiY0RiaWNaZFliRWJsYkZiMWhBZmhkNGRDY0Zna2dRYmtlRmRSZVllMmFNYmlhTmJuYlVmeWJaZ09lYmVoYUFoS2NHaEJnOGdLYVFmUWJjY21nT2ZoY2hiNGhGZVhoMWdSZEVoV2VSYjFoRWdYYk5jTWdVZlhlaGJ3ZVZlbmFRaFBkYWMxYkplR2NOZEJkSmRHZ0tjaGMxZlBmTWhDY0lmYWVTZWhnMGJQaFFheGdBZlJhV2duZHBkWmJaZEJiVmFnZE5kU2d3YndhRGJGZ3hiYmFIY1JnMWZOaEdnVmVaZDBmYmFuY1pnemRiZjBiWmNuZ0ZoaGVKZVRmZGZVY3NmQWFlY0VjUWVMZGNjRmVwaENiYmQyZ0pnbWNhYlJmUmN5Z1RjbmdNZVFiVmVrYjBkRmRBYVZkd2ZkZ1pmd2Z0Y1FlT2VRZFlmOGhVZlZjWmZPZkljUmY4aE1kQmVCZWdmL2RPZUhjeGMwZkRnMmZ0ZlNoRmJIY0ZhR2hFaDNjaGJUZVRmMmdSYXFjVWZ3YVliVGJjYVJocGR6YVZjaGhKZjZkUmQyY1JmQmViZ2tkcGdrZGViVWhzY1VoY2NSYTBlSGVUZFVlMGNlZFBnVGQxZDRhRGZDZk1jSmZNY0JoWWhNZVRoQ2FGZEVhYmN4ZjRkTGNYYUdjdGF3YVFibWI5ZmloWmRtZWtmVWVjZWtiNWN6YkVjQmhGY0VlWGRXYk1nVmFUaG1kbGYwYkdmSGdCY0JjZGhGZEZnS2NSYWphMGNmYkljeGQ0YWVkTGdEYThhQ2RMZFZlOGV1YlhkRmdnYjBjRmhVaEFnTWJHZHdlNGVxaGFla2g0ZlphV2UzZzVhYmdDZXhjbGhHZE5lUmRNZDlhRWRTZHRmRWdLZENhMWRMZkNjWGZGYmJoU2VBZE5iYWhBZ2pkMGdoZk9hSGROZW5nRWFtZDRjV2hTZFdlWmExYVNiaGRCZ1NnUmRBZnRnd2FXYmtkSmV2ZllnbWVZYjdmVWFTY1ljYmhJZVZiNWRNZkdkUmRrZkFjUmVrZEFmV2FQYUZoRWgzYkNkWGFSY05jU2VoY3BlN2hiYWpic2JGZkZmamdCZ2FjVmNuYVFhUGhhYzFnSWhVZWNkVWJZY1RnZWNGYU5hUGZaaEdocGNNY0diUmVKZ2dkSWdWZGxhV2RFZG5jcGZIZlpnRWNGZnVnU2NtZVJiNWRTYnhjUmZ4aEJmeGYwY1pnVWVSZzhkbmVZZEFja2g3ZUplZ2hFaHZoRmVnY3hiTWdJYVVjUmN2ZkdjZ2cxYk1kT2VIZ0JhQ2FiaDJiSmZtYWFoUmdSZXlnVGVuZ01hUWRUZEVlMWFSZVNlUWJwY09lYWdHYVVmeWdjZEViRmMwaFVkVWJwaE9nZGNSZkZnemhUYUZhRmI0ZWNiRmRaYnViRGR6YjhnYWJYY1NkSmVJYWJoRGNRZmNnR2NHZFJoMmVVYTBnMGNkZERmMGdjYldiQWFRZmxjUWVSYzJhUmNCYWJla2NwZWthZWZVZXNlVWRjY1VkQWdVYVFmVGFOZFdiZGhHYzVjMmNjZjJhOWdHY1pheGJZZFNkUmJEZzFjRWZRYkFoQWNMZ1hkemE4aE9jR2d6YzhjbmFhZUNiWmVHZWNmbGZOZHpmVmhoZ2tjRGVFZ2hnMWZjZkFnU2JkZzBmRWRDYVJkSWVkYkFkcGdnZFRkbmNVZ1JnY2IwYnhlUmdlYUhmQmRXYWRoQWc5YXJnQWJGaEVibGFFYzBnRWIyZ1VjMGNjZXdlSWdoY3BkS2ZIYVFkOWJIZkZhZ2NFYVNhSmNsYXBna2hGZ1doQWgxZUthRGFZYWNmSGFYYTBkZGhGZlJkbGRSY0hieWFkZmdnQ2dUYXNlbWVBZ1NjOGVXZ1RibGJGZDFnSGJoaDRkdGhEY0VlSWEzYkVka2d0Y2phWWRqZ0lhaGFYZFNmRmNWZFdmUmRCZk1kVGdWYUZnSmhGZ1VnNWhwZGRjQmhnaHRiU2dIZ2hhN2hTYmtiNWIxYUVmWGZOYk1nVWNYZ2hid2FWZ25ieGZIY1pjUWZKZEdnUGNoZEpnY2JMZ0Fob2FmY0llV2JRaFNoVmQxYmRid2JGYWxla2hRZFJmemZRY0VoTWJBYmdhaGJCZEdnUmN4ZEhjeGgxZnhmUmFqY2RmTmRHZVZoWmYwZmJmbmVaZHpmYmgwaFpnbmNGY2hoSWJlaE1mQmY1YkZnQWZBZ29hTGRlZkFjNGNLZEpnamhGaG9mRmRsZ2dnOWRHZ1hhTWZXZVVmVWUwZUZiUmYyZG9mQ2NKZWlnTWZSYWZoRWNGZjhjQmNRaElmSGFKZWhlOGFNZ0JoQmdnYS9hT2VGZFpmeWFFY21hc2ZHaEdhZ2I0Zk9oV2JqZDhnYmhSZW1haGhxYkJnMWVGZmFoSWh4ZUJnemVWYWhmSmQ2aFJjMmFSZkJhYmNrZHBka2hlYVJjWWVkY2ZkVGVjZWRjVGFSaGxkV2NkZ0dmNWUyYmNnMmM5ZUdkYmcxYTRhY2hIZ0NhY2JGYlJjQmcwZlFlVWVpaEFiZmRUZ0NhRWJ0ZE1nbWRrZ0phY2VnY2dnbWJYYmdlOGJaZUdkQWNaZGJmVGRtaEZoOWZHZ0NodGNyY2RkRmVGY0tjVGduZFVnUmZjZDBjeGFSYWVnSGdCZ1dmSmdraG9mL2VCYjBoWWEvY1JhaGd0Z1NjVWcwaDloa2ZhYWxoTWdaZUVoM2JBZExkV2RWZ1lnU2JlZGtmZGFzY0ZmU2dZZURkTmQzZWNiMGRXaERhNWZLY0hoVmRBY1pmUWZHYUZhN2daZVdjWmR2ZlFnR2RkZkljUmNnZ1FiOGdHZ1JiNGR0ZENjRWRRZW5jVWgwZTVoRmNZZ21hWmRwY0ZjSGVKZk9nY2V4YUJjTWRUZFZjRmFKYkZoVWI1ZmhhSWhGYUFlNWVFZ25hb2Z1ZUFiZ2ZjZXljV2dYYk5jUmJVZldjNWVsaFFiMmVjY2FlYWYxZVFlVWhMY3hjSmRiYk1mUWhCZ0JhR2h5ZElmYWRYaGxodGM1Z0JlM2JOY1dnRWVuZXBhSGdaY0VmRmZ1ZVNobWJSYzVjU2F4ZVJieGVIZVVja2ZGZlViQWVWYmVoYmJuZ1poemdiaDBhWmhuZEZjaGhKZ01hZGJVY29hUWdXZDFmOGhoY2NmRmJwZ0NoYmcyYUpibWVhZlJnUmR5aFRnaWU0aFphUWhHY2RmUmFTYVJiVmNPY2FoWGZRZFlmY2VFYUZhMGhXYlFjSmJBaEpnVWZNaDhoR2NCZDRnc2hLaFFoWWR4YUFmVGJNZWRnUmVuZ0ZiYmhFYXpoNGZHZkFjU2ZjaCtmR2ZsaFphZGNjaEFmTWdOZ1hkeGZJYmhiYmNXYlJoQmJiY2tncGJrZGVkVWFzZ1VmY2RSZjBlZGFUYVVlc2ZUZklmRGZzZGthUGVXYzllT2VNZTFkNWJiZkhlM2NzZTFnWGhCZTBiVGJDZXdjNWFIYlFhamd0ZnNmR2VTYVZkYmFKZVVlZGUvZUVoRWhRZ1poR2dRY0JhR2NRYUJlWWg4YlVjVGJjZkpkZGZDZzliWGFUYWlhRWhmaERoQWNRYlloUGd6Z2hhZmZlZUFjOGMvYUdjbGcwZ2ljWGdUaGxhNGJVZDBhOWVrZ2FjbGFNYlpnRWYzYUFmTGZCZ0ZlOGNlZFVmRWNkZmthUWVXZDVnS2VaYUhmbGFMYkZhSGhFZFZnVmRVZk5jSmNCY0Rkc2I2aE9hU2VjZDJiRmdpaElhWWRRZFFlUWM4YkRmRWNRY2dmRGJVZXdiNGVEY2tjSmJ5Y1lkaWg1ZG5nUmdDZ0FiQmZKZjFhOGdZYUZlQWdFZ01nR2h4ZTBhaGFQY1ZnNGFrZEVmM2ZSZU1oU2FnYWdiZ2dYaHpoQWVZYUdkRGVjYStnVmFuZXhnYmRZaGxlSmZQZFdoMGVZZ1RmZWFGY05mUGJaYkdkcGNUaEdlUmVOaHdiQ2d3ZXNhVGRSZGljOGZWaEtma2dGZm1hWWJHZ1JkNWRTZHhlUmZ4ZkhhUmcxYU5oR2VWYVphMGJiY25jWmF6ZE9kMGdaaDVlRmFnYU5jYWdYZTBob2FRZVVha2dRZUxjY2dGY3BkQ2JiYjJkSmRtYmFjUmZSZHlmVGFuZk1kUGhUZEVnVmJaZEhjVmIwZ0hoT2ZuaHBnbmZQZUFoNGdqZ1VnVmVkZE9lSWhWZGthNmJIYzFiOGVIYk9mQmQ4ZXpjUmYyY3RkTWRDYm5oRmFPYVJlM2doYWVkVGYzZlZnOGNXZWhjQWhmZGNiQWdNY05nSGZsYXNicGZTZlJjc2hKZkpmd2cwZHNkZWNWY1ljVWRZYVJoUWVVaFpieGNsZ1dmZGZHYzVjMmNjZzJhOWFHZFpjeGdZZVNoVGFIaFZmS2JFZUZnSmFlaENiMmNGYU1nUWVuY0pkL2FaZGpoMGQraGNia2M1ZnpiRWZFYnhmTmFVYlVma2JWZlRlbWRsZjBlR2hIY0JnQmJkZkVjNWZLaFJjbmUxZkZiT2J3Y1ViQ2NkaGdkOGFhZk9mMWZoYnJhVGN4Z1FobGhEYmxmb2ZyaFhkVGNBZnNnSWF4ZlJiUmhHY25kd2NMYVVkUWJKZWFlTWV4Z1JkcWRQZWliWWVEY0llemZGYkxhQ2FYZEVmTmhGYkVoUWR6ZFZkbmJSZ3VkZGVuaE5kdmFSY21lY2RXaEVla2F4ZTFnU2RoZkJoU2hSZEJjRmF3Y1Voa2hvZzdiS2JpaDhiNmVHZ2dlMGhDaFBiRWNkYk1oVWdIaHRhSmRGZ1VoNWJwZGRiQmNoYXdjUWFYY1JmUmhTaGtiNWMxZkVjWGNOYU1nVWJYYmhmd2dWZW5jeGFiaElieGJ0Y0hhZmd6YmxjZmJOZXdlUmhQZWVlbmNSYlRjVGRSY3Bod2ZWYTFhbGZlYkdoaWE0aFBkTGhSZEpnZ2NOZFNnd2J3ZkRoRmZ4Y3hiQWVRZEZoTmVFY1VkZGZpYmJibmd0Z3plT2EwZzlmdWFGZmhhUmdNZVlmMWE4YkZjUWRWaEVjQ2dlYlZhWmRvZWJiMmdKY21kYWJSY1JjeWRUaG5kTWVRY1RhRWExY1JkU2JSYVZiT2NhZFhkUWVZYWVoQmFVYjhjR2VCYWxkQWRDZ2xla2M2YkNleGJsYzRnYmRraGhlcGdEZHphOWNiaEhoWGYxYXNhRWgzY2hjVGFUZTJjUmRxaFVheGNrZVRhY2JBaHRoWmZWZmhmSWd1aERmeWEwZVNjUmdFZ3Boa2RlYlVnc2hVZmNjUmUwZmRkVGdSYmxjV2JkYkdkZGZ0ZVdiV2g5ZUdnWmF4Z1lhU2NUYUhlVmFLYkVhRmZJaFpmQWZuYXhod2RRZ21nOWZpZVpnbWhraFVoY2ZrYTVoemZFZUVkUWFGYlhmeGVsYUhoQWZUYTBmN2hUY0Nla2RSZ01mVmc4YVpkQmFqaHhoWGdKZnlkQWZVaFBiaWJSYVdmYWVRZjhnamNYYUVnUWdqYUNmVWZjYTNnQmh4ZFlmMGNMZzFmMWFLZldkemJsZE5jRGdSZ29lU2JaZjBhY2hpZ0ZiQ2ZBZ0piTWVEZEFhRWJXZ25oRWRWY1NhVWFFZlpjQmVIZTFkdWJMY1ZobGh2ZVJobWNjZVdhRWJrZHhoMWhTZGhjQmRTZlJkQWhzZ2ljSGJ4Z1ljNmZNY0NiaGNwZ0hmRmhoZU9oY2J4Z0JoTWNUZFZlRmFKZEZlVWE1Z3BkZGdCYWhld2VRY1NmQmFSZFZhRWc1ZGtkQmMxaGxiTWZVZFhnaGF3ZFZnbmZRYlBhYWYxZEloVWVjZ1VnWWdUY2ViRmVOZ1BhZWgyZ3BoYmRFYlVjY2g0ZVFnZ2ZwY1ljYmRUaEljT2FJZ3dlbGR1YVZlMmJRZnRoQWcxYTBhaWRFZTJhSWNCZlZkZ2ZGYjBlY2htZXBnemdaYnhnSmhuZ0djeGZKZ2RjWWUwYU1hWmJYYW1mNGVMY2NjRmZwYkNmYmYyZEphbWNhZFJoUmV5Z1RobmJNZVFmVGFFYTFjUmdTZFJlVmZHaFBjVGF4ZlJjSWIwYThiTGdIYVFlVWNaYmRiUWN4ZHplWGJGYWhlMGJXYmxoWmMwZURkMmF0YlNnRmFIZUZlR2RFYjNhaGVUY1RkMmRSZXFjVWd4Z2toVGFjZ0ZjbGNaY0Nja2c1aDZjVGR6ZkFlSmhKZXhobGdxZkJoZ2NOZGRjTmZsY1VkZGFTYndnUmVXZFlobmR0YWphWWFIY3BlUGJiZWpld2FTYVRoSGZWZ0tjRWVGY0pmRWZDZTNiQmdhaFFlbWU5ZmlmWmFtY2tkVWZhZ0ViNWhpYUJka2R4ZlFjVGZFYWxnQmZaZUdlbGMwZUdnSGVCZkJnZGNGYUZiS2hUZW5kVWNSZmNnMGF4ZFJlZWNIZUJnSmFkZEFmZGNqZkJjbGZ3YzRlRmdSZTBlSGRHZ3dhWWhqYklhbGVNaEVjRWJ5Z1JoRGVFZkFiVWdjZkJmUWVzZnJhRmZtZmRkR2VaZ0hiRWNmZlhlRGZoYk9oRWZ6YkphVmhHZlNkTmN1Z2FoM2VOZy9iVGEyZzRlOGRFaGtkeGMxYVNoaGFCaFNiUmNBZXRid2RXYmtlSmZ2Y1lhbWFaY3BlRmVHY2hjT2FlZHhmZ2JZZkJkUmhnYWFmR2h6ZEVoaGJQY1ZoOGM0aFFjV2hsZVJhUWNoZm9mOWJXY0NiQmdDZUxnamNBZTViRWNUaHdjUGhkZzBmNGhVYUpjVWM4aFRiSmVGYk5mSGhNZkNnSWNhYVNiaGYwYlBmUmF4ZlljQmRFYm1nUmRaZlpoRWFsZC9iWGFHZ1JkMGNTYjBmQmc0YkZjQmhSZ0JmTWIxZlphMGFiY25jWmV6ZmJoMGZaY25mRmhoZkpmTWJkZ1Vnb2RRYVVja2JRZ0xmY2FGYUljV2NKaHlnc2QxZ1plMmdzZitlQWJTYVFhUWdVZ1ViMWJaZkhjVmYwaEhlT2duZHBmbmJQYkFmNGRqYVVkVmFaZFNkZGJVaFZhNmVUaEZoZGM0Z1poa2ZOaGhlSGVIYjVmYmZHZkZidGRHY0VjM2JoZVRkVGcyaFJhcWFVY3hna2ZUZmNoQWR0ZFpiVmVoY0pmNmZSaDJmUWVUZmJkaGRZYjRkZWZVYk5nQWNPYlZhUmVPaFFkMmRZY2ViUGRTaGtiK2hjaDJkbGRiaFpod2RBZkhnV2ZXZVpkZmhHYlZmdGNJYklmWGZCZmFjUWVtYTlmaWdaYW1ja2JVYWNja2Q1Y3pkRWhFaHhhTmNCY1FmRmZjYUhoVWVOYTBoR2FIYkJlQmJkZEZiRmdLZlRmbmhVZVJoY2cwYnhhWWNZZzFlcGhXYmRkQWI5aHJiVWFoYlJmeGhSZGhjTmg0Z0Rja2FaYm9kUWdGZU1kWmJFZDNhQWFMZldiVmZZZlNnZWhraGRjc2dDYVdlQWRhZU5oamZZaGZlV2d5ZFZjRWVUYVFkZ2NYYkJkRGNzaDZkTmd5ZWNjcWdLYmliSmRRYlJha2J4Y29lU2NsZmhmY2ZGaEZoa2EvaERkZ2cwaDdlT2F6YVlnc2NHYWljQWRCYkpnMWJ4Yk1hVWdGZEVhUGRRZUFiQWdxZUljRmZFZy9nRGgzYlJmWmZIY2tmZGMxYVNnbGRsZ01mVWNYY2hod2FWYW5nUWhQYmFhMWFJYlVnY2JVZlplRmNPZ1FhRmdQZk5ibWNwaE9mR2VSaHNoa2RRZ3hjQWhGZ0hnQWNVZ1BjTGhRZFlhbWRTZ25kaGZsZlNhd2JWZm5jRmJCYzBjUmZHY1FiSWM4ZUpieWRWZDloRWJBZm9lb2FRYVFibGVtYWRnVWZvZVFhVWVrY1FnTGFjZkZncGZDaGJlMmVKZ21oT2cxYkVnbWNHZXlkRmJlY1RnRWFWYTdoU2FSYlZlT2dhZFhhUWNZYmNjRWNGZzBoVWVVaHBlT2NkZVJoRmM3Z0hmbGdGZGxlY2RGZzRjbWFEYjNlZGFPZkZhQ2NWZFBjRWZ5ZlJnVGhSZXpoWmFxZlRiUWhjY05iY2hBYU5jS2FSZEJlSmUzYVJnemFCaEljWmMwZ05ib2VVaDBlc2NVZGNmUmEwaGRjVGJSZGxkV2hkZUdkNWMyZGNoMmc5ZkdlYmMwZ0plYWRCZlNjWmJFYWJoeGM0Y0xkWGdIYUJmSGhRZ25nbGEzaGNoM2dvZkJnY2JrZ2hnemhRYWtkVmdCYWVnMGZrZlZlVGZtYmxlMGJHZkhjQmdCYWRiRmZGY0thVGZuYVVoUmdlaHhnZ2VaZU1nU2ROYVlkQ2YwYWNhaWdGYVZleGV4aFdmeGFNaHFlVWMxZkZiNmdkZ0ZkTWNJZkJlWGJrZEhlY2gxYllhU2dlaGtoZGhraFFnV2c1Y0tkWmVIYWxnTGVGZkhnRWZkYlNhUWFWZVFkQmdWYTVndWZkZ25oTmF2YlJobWFjYVdnRWRrYnhhMWFTYWhhQmFiZFhjeWJGaHdnV2hrZEpndmFZZG1kWmFwY0ZoSGFKZ09lTGNoYmxmQWJaYjFoRmNKZEZoVWE1YnBiZGVCYWhkd2FRZVhnUmJaY0Fia2ZBYWxhUWV6Y3dlWWVIY2lhd2ZwZ0JmamRFY0JmT2RSZzFoQWZNY0JmSmhXYUNmaGhvZEljTGNEZzVkVGVCYkJmTWI0Y0JiUWJrZEVlWGFTYTRmSWNNZ0JhZ2craERlMmJvaHJoQmNFYkFnamdIZFFkQmdOYlhhd2NNYjZnTGZTY0lhNmhJZ0FjaGRuYUhma2FaYUZlZGdSYUViNmdVYWtjUWdMaGNjRmNwY0NoYmYyYkpkbWFhZFJoUmh5Y0dkRGNKYkNoVGRCZjliUmhWZkJjVmNHaFBlVGN4ZlJjSWMwZzhkTGNHY1FiTWVKYlBkUmZGZ3ZnVWNGZUZlcGRaZWxoOWQwZlVmMmZzaEdiWGFEaGdlVmdIYVFnY2FmY0FoRGZOZXhmZWZSaGtkVGRjYUFkdGVaYlZiaGhKZzZmUmEyZFJhQmdiZWhjZ2doYkxmUmM1aEdkUGZ4ZzBiVmdaaHhlbGZXZGRmR2I1YzJjY2gyYjloR2NaYnhnWWdTYlRmSGhWYktjR2ZBaEJhRWVGZm5hQmNTaEViR2c5aDhhZWFIZWNiVWJKaGtoZGN6ZlRoRWN4YUZoQWcwZWtjSmJVaG1ibGU4ZENhMmNKZEJhZWJWY0VlZWFSZDNhd2FZY2ZnMmdaZ1JmZWdIZkJjV2VkZEFjOWZyZVViaGRSZnhiUmdoZk5jNGZVZTBkY2F3Z0liaGhwZktoSGNRZDloSGZGYWdmRWdTY1pnMGZkYnllVmNIZnRiWmdjZlhkbGFOaEZiQ2ZNY1VlRWJXZmNlWmNWYm5kUmN1Z2RkbmNOZ3ZmUmNtaGNkV2ZFZGtheGUxZ1NoaGNnZEdiRGVFZ0llamdWY0RlMGduY0tmeWNFZ2hkRmNHYTljT2dJY1JiQmJTZFVmMGI5Y0piQmhGZ2hlZ2hlYURnSmJ3aFFlWGVSZ1JhU2NrZjVhMWNFYlhnTmFNZVViWGNoYXdiVmVpaEJmSGRJaGdlRWUrZ2NlVWZZZ1RjZWRGYU5lUGFaZUdncGVUZEdkUmdOYXdnQWhrY0plOGJFaG5mcGdIYlphRWNGYXVjU2RtY1JiNWhTZzBibGQ0YUVnVGdkaE5hR2hWZFpmMGRiZ25hWmR6Z2JnMGRaZ25nSGFsaHBiQ2JKZVJkaGFmYkJmZ2h0ZGZlS2dRZ29oSGRZZFNiRWVxZkpnbGdvaDNkVGVtYTRiUWNDZmhlZ2hmaENna2FFZkhoSmNqZm9mWWZlZUViaGcwZ0NhbWJCZU9lZGZSY0ZhemdUYkZiRmc0YmNhRmFaZzBjRGUyY3NlQWFVZVNjVWZUZVFiVGFaZFRnQWFTaEVhOWVVZzFjRWJiZUpmRWFNaFFmQmFSYXdlRmFDZnllc2hXaFlna2JvYXdmTWFRZkphSGdmYjJlSmJWYkJmRmU0aGVlZmdYYVZmY2ZjZDJhOWdHZ1pmeGZZZlNlVGNIaFZkS2JFYkFhOWdOY0JoMWRwZGFmUWZtZDlhaWhaYW1na2NVZWNla2E1YnpjR2hBZVZhTmJUZkVnbGF1Zk1kMmJCZDRhTWRuYkJoQmNkZUZoRmNLY1RhbmFVaFJlY2MwY3hkWmRQY1hkQmNMaGRjRWRrYStnSGZGZWNmbGdEZTFnd2EyZVVhMGJkYXRnYWhnY2djemhFYjNmQWFMZFdlVmhZaFNhZWNrYWRja2hRaFdhNWVLZE5lamV3aGZhUWJTZk5mVGJIYVFiVWhDY2ZjSGZSYnVnZGhuY05odmJSYW1iY2JXZUVma2J3ZG9oUmVGY0VjQ2RGZUVnY2RwYVVnaGRCYmphWWNpZzljZ2VIYVhjNWZrZWNieGdCZE1oVGVWZUZmSmRGYlVjNWZwZ2RnQmJsYTRnRmh6ZXNmWWNEY2tnNWFsZ0VmWGRKYVJiVGNIY2dkMWNWZG5iSWRKZWFmMWRwYkFnZmh3Yk5jTGZLZUJkd2ZkZE1iRGVsZVRkQmNCZ01kMWNBaGxkQmJOaE9oSGdwY0hhWmhFZUZhdWJTZmplbGF3Z1FhMGFBZzVlVmJFYjVoRWVBYm5neGIwaGJobmZaZHpjTWRrZnBhTmFGYWhjSmNNZ2RjUWR4aEZmSGNBYWRmZmJPZVJhVWFNZmJjMmVvYXloWmZSZ1FiZ2hSZzNhTmRMZ1pla2cxZlJmU2dSYVZnT2JhYlNkSmRaaElia2NFZjliWGdVY29jTGViY2pmdGV6YVRjRmZGZDRkY2ZGZlpiMWdCZnliMGFIZ1dkamVJZFNjV2NqZ2NmZGNUYzJhd2dsZFdhaGhsaElhV2NnZHRlWmVWZ2hiSmI2Y1JjMmVSZUJhS2hCaDhicWdPZGhhOWZkZFBmbGFNZGRkQmdSZkViQ2hlZ0dkNGRrZ2ZmMmE4Z1BjYWF4ZlpkWGJSYVhhVWZSZ09hbGRKZ0VkQ2czY0JoYWdRZm1mOWRpZVpkbWVsYUdiTmV4YW9nbWVRZ2doSmhOaEJkUWhGZGNjSGNXYWtlOWFWYWlmTWVWaE5oUmM4Y0pjQ2J6Y3BoWGhjZHdkUmY3YWVnSGFCZFdjZGJBZDlncmVVZ2hmUmN4YlJhaGNOZDRhVGJFYzlhc2NZZGdmZGNSZFdkaWFNZ0ZhQ2F4YU5jZmVPaHdnNGVxZkJlU2hzaFljWmZHY1JmTGRXZmllUmhSYVVnVWFRZFZmZmdIZVJmdWhkY25oTmd2YlJjbWVjZ1diRWJrYnhkMWhTaGhnQmJTY1JnbGFnZmthQ2JBYXNlaGFKYldoUmhwY0NnV2I5Yk9hSmcwZ2tnY2ZDaEJhNGFQZ0ZoUmRwaERmZGRCaGhmd2JRY1hlUmhSZVNoa2I1ZTFoRWhYZ05jTWNVYVhkaGh3Y1ZlbWdzZ1BhS2ZsaHhnWGhNZUFmcGNmY2NhQWJjZkhkTGFUYmxmZmhHZVVkZGY4Z0Njd2R0ZmZjT2hIYnBlSGZaZ0VmRmF1Y1NhbWNSYzVoU2V4YVJjeGNIZVJoMWZOYkdlVmhaYXVoYmFuZVFlbWZJZFFmSWdpY1VjRmNzZkNhTWJBZDRlU2FVaGxma2VXZmNiQWI0YmJhUGd5YWNhcGFMYnhmUWJnZ1pnSGhNZFFiVGNFYjFiUmJTZVJhVmFPYWFnWGZRZFlmY2FFY0ZjMGFVY1VicGVSaGRhVWVKYjlhRGJ4ZUFiMGVQY0ZlNGJnZlJneWRJYkJkR2NIY0VnU2JHZGxmSmZUYlRkMmNSZXFoVWR4ZmtmVGJjY0FldGdaZ1ZjaGJKZjZlUmUyZ1JhQmFkZkVib2R5ZE5lZ2JKYVFkY2dWZk1nVGdEZ0Vna2hHZk9iRGZkZytmSmN5Y2NhUGFOaEJjb2FTZ0RhU2RjaE5jUmJSaDhoQmRSZlNjUWdKZVNnMmdaY0lmWmdtY2tnVWVjZGtmNWR6Y0VhRWF4YU5oVWFVZ2thVmZWZ0dka2U2aFhoU2JkYkJoUGFGZmtnZWhRZG5iVmFEY2ZoMGd3aFliZGVIYUFiVGZmZlJlUmdCZFVlaGhSZHhoUmJoZ05kNGJVZTBlOGg1ZlFlRmNNZ1piRWQzYkFhTGdXZVZlWWJTZlBkQmZJYXFhQWFqaG9lRGVLYnpoZGRMY1dobmFsZ0pnRWVVYjFmTGhXY25iUWNuaGVibmJNZnFiVGcyZ2RiTmNPaEVjeGUxY1NnaGFCZVNnUmNBYXRhd2FXaGtjSWU5ZkpoemhJZDhnUmRqYnhoT2NjaFVjVWNDZkNhUmNRaFBkWGJBYkFlc2RNYkJlcGN3ZlhmR2NsaFJhSGVoYWNjbGFWZURjd2FLaFVnVGNGZWFkVmduZlFmUGJhZTFhSWFVYmNkVWNZYVRjZWRGY05nUGdlZDJocGFiYUVnVWhjaDRoUWNnaHBkWWFiY1RndGVYZmRkRWNGaHpoU2JuZ0pic2dYY2doZGRrZkhmUmR0Y05jVGNWYzloNGRSYUhnWmF6Y2JiMGNaYW5iRmdoaEpiTWRkZ1Vnb2NRZFVma2RRZUxoZWVBYTRoS2FKYmpkRmFvZUZobGhWaGpjV2JIZE1lTmNUZkJkbGNSYVZod2d0Y1FnYWhXY1VlT2NlZlVhMWhlZVVmVWdwY09hZGRSZEZnemRUZ0ZnRmU0Y2NmRmJaYzBhRGUyYnRiYWZRZ0Rka2FQY1FiSGVZZXNhRGZuYmRlNGhVYXdkUWRUZVphaGg1Yk1lUmVRYmRiNmNRaFdkUWZUaFpiMGZaZU9oZWVVZ3NiVWFjZVJkMGFkZ1RiUmNsY1dnZGRHZzVnMmZjZDJiOWhPYU1lMWQ1YmJoSGQzYXNkMWZVYVVjWmJjYkNhMmgxaGFhRWhHZjlhOGJlZEhmY2JVY1loMWNoZzZlSGdHZVplTmRVZFVla2JWYVRibWZsZDBoR2VIZEJiQmFkZUZlRmVLZlRlaWhGZFpoT2ZoaDlhWWNVYm5mQmFXY2RkQWM5ZXJiVWVoY1JneGJSY2hhTmc0ZVVjMWRWZmtiWWRsYXRnTmJXYnpkbGFZYVZneWNsaFRmYWFsYmRia2JYZkdlNWJhZ1plQ2FWY0xjUWRIZWdmUmVOYjBhMGJaYVZibmRSaHVjZGNuZE5ndmVSYW1hY2NXZUVoa2Z4ZjFmUWNrYVFiYWhEZ1ZmaGYrZEpnUWROZCtoZGhHZlphMGRGZEdmSmJPaExheGNBYmVjUmRGYTFlamJGZlViNWJwY2RkQmNoYndmUWVYaFJlUmVTZGtoNWUxaEVlWGZOZ0VhQmdUY0FhNWFCY1hlcGN3Yktka2JFZEdhY2ZWZXNjVGFhY0ZhTWFUYVpoQ2hOZGFjRmFUY2xmd2ZDaDFnbGVXZEVlbmZwYkhoWmhFYkZhdWFTZG1lUmQ1YlNheGN3YmxkVmRWYVFlZWhGZ3lka2MxY2VnbWE1ZHplY2JrYlplM2RGaGtmNWVNZ01lRWhNYWNmZWZFaFFjTGJjZUZkcGVDY2JkMmFKZG1lYWJSY1JneWFUZW5kTWRRZUdhQWJVZ1ljR2hoYnhiVmJRYjNkUWZZZmNmRWRGYzBkVWFVYnBkT2FLZERhdGV6Y1RiRmVGZzRoY2ZGYlpiMGJEYnliMGhIZVdkamhJZVNjV2hqYWNlZGdUZnpiZGRpZkJjeGZBYVRiS2Z5Y0ZoWmNWZGhkSmE2ZlJmMmNSZUJkYmNrZHBna2VLY3dkNWRBZkpnRWQ5YVRlVGdSZ0ZlOGNkZUdiNWYyZGNhMmc5YkdiWmN4ZVlnU2ZUZUhlVmRLZ0djQWNZYU1lUWRpYk5jVWJQY1NoNWF5YWRhbWRrZEphY2dsZmhmbWVCY1ZiOWdZYlVnVWI4ZVZhR2dtZUJhNGFNZm5hQmFCaGRhRmZGZUtjVGNuYlVmUmNjZzBneGZSaGVjSGRnZ0NkUGJFY1lmNGRYZEdic2J3aFZmd2NWYjRnVGRrZThhd2NhY2tnMGZIZ0RkWGNBaGFjVGExYjhoZWVVYUVoZGZrY1FnV2E1YUtkWmFIZ2xhTGhGZkhiRWhkZkhhVWFWY05mSGRqaDBmOWFlZ0Fid2F1YlZoWGNVYVdiRGIwYXhobGJRZXhmeGM0ZFJhQWV0Z3dnV2ZrZEpodmJZaG1oWmhwY0ZmSGhKY09hZWMwY1FjRWdCY0FnSmJIaGFmZ2I5YzllYmVCYWhndGJRY1dnUmdZYVJhbWJSYTFhRWFYZE5hTWVVYlhkaGZ3YVZhbmZRZlBoYWgxZkpjQWdPZVFlOWRBYVVhbGFOZlBnWmNHYXBlVGFHYlJiTmJ3ZENmMWdsZ2ZmQ2hWYkJoSGZaZkVjRmJ1YVNlbWNSZzVlU2YwY2xhYmdIZVJmMWJOY0dnVmhaYTBiYmhuaFlnMWdPaGdoZ2NrYlFkbGVzZkRkT2YwaHBhUmJXYmhlQWNIZGNmQWFoaExlYmR6Y2xhTWVhYVJkUmJ5ZFRnbmdNZ1FhVGhFZDFkUmZTY1JnMGFjYmFoV2JrZ1liSWdrZUVob2VEY1VlcGFmYVpkUmdoZy9iWmVsYUZoNGVjZUZmWmgwYkRjMmR0aFNhRmVIYUZkR2NFYjNiQWdIZ0JieWQwZzViWGdXY1pjU2NZZEJkdGRaZVNkeGVKZXFnVGdtZmhjcmRiZmtkcGRrZ2VlVWJzYlVnY2VSaDBmZGJUZFJhbGhXY2ZmRGdvYytjT2ZqY3hhSWVHZkZmY2FEYVdobmhWYlhnRWJFZEpmTmVCZDFjcGJhYVFjbWU5Z2loWmFtZGtmVWVjZGtnNWR6ZUVkRWR4Y0ZiQmJRY0ZoY2hIaFdmY2RMZVdjV2dOZ1RiZGRFZ3hiS2ZYZm5kd2VkY1dlVWJ4Y1JlZWFIY0JhV2RkYkFiOWJyZFVlaGVSaHhmUmZoZHNnc2dHYndiWWIzZVpmQ2V4ZVloQmMyZWdhTGhSYUZiWWdDYmNnMWR4Yk9jUWVXZjVoS2NaYkhhbGZMYkZlSGNFZGRiSGhRaHRoV2JCZUhoUmZtaFhmSGVOZ3ZjUmRtZWNjV2NFZ2tmeGIxZVNlaGZCZFNjUmJGZzBleGJDaEVhSWVtZVlnbmN0ZHBoUWNRZ2toY2NEZGhoQWhRZUVmVmdFZ0hmVWJCYmxlcGNQZkJjQWJkYkFnQ2VBYlplUmZCZjRlNmNSYm5oc2dlYlhmWGdoZWxlWGczZDBoRGdhZHhkY2JVZ2JiRWdZYkRhZGZGYU1hQWhaZ0hnZGFUaFRlUmUwZjhjVGJoZ2NoUmNSYmpoSmZjZFRoa2VGY3VlU2htYlJjNWhTZHhkUmV4aEhhUmUxZU5oR2hSYWxhMGhjYkhlWWEyZGRmR2N4aG5hRmZoZEpmTWNkYlVob2RRZ1Vja2hRZkxhY2dGYW9oSGhiYzJlbGE3aGFhUWJGZVlhVGNuYk1iUWhUZUVkMWVSYVNoUmJWYk9mYWRYYTBhWWdLZjJkdGMwZFViVWVwaE9kZGhSYUZkemVUZUZnRmQ0YmNlRmNZZGlmVGJqaGxlU2NXZ25mRmFiYkVkeGJVZ1NlR2h5aHhna2RIYmxnQmZkaGVhQmY1Y1ZoVmhsaDFiNmJTZG1jUWJFYlpnMGZaZE9jZWFVYnNhVWVjYVJnMGZkZ1RhUmRsYldhZGVHaDViMmhjZjJlOGdWZFpod2VzZVNiSGhEYlFiWWZRZHhhY2V0ZVJjU2hSYlNnRmhtZ0VneGRLYmllQmJYYk5nMGFZaDJlSGdFY3diSWhVaFVjSWVWZkFnR2RCYjRjR2hDZEpjSWNiZTNkdGZLYlRlbmRVYVJiY2gwZXhjUmJlZkhnQmZXZWRiQWY4aC9jR2ZsYzBoaWJTYkZiNGZ0YUhleGVzYXRmT2VoZzllQWdHZzJiVWVMY1JmMWdaZ2NnZWZsY2hoa2JEY3lic2VkZVpkRGFGZURlZWdUYUJhSmdWZlVhTmNKYUdmU2hOZm1nSmdIYjljdmJDYkdlNGFmY0VibGNaZzFlQWF4ZGxnY2FCYVViOGcwYlVmZ2V3aHFoTmJXZFljaGhIZ0NlRmJIZmVjZ2Z0Y21hVGdWZ0ZnSmhGYVVhNWZwY2RoQmFoY3dkUWJTYmxlN2RTYmtkNWYxZkVhWGJOYk1nVWhYY2hld2FWY2lmWmFLZFBkd2ZkY0dlUGgwZ1pjSGJNZEJib2djZGZiMGhCZ1RiR2FSZ05hd2dDZDFjbGZXZ0VmaWFkYXRmWmJFYUZidWRTZm1oUmQ1Z1NieGRRZG5oWGFFaDllTmNUZkZkWmVwZmJkaWQxZFphYmgwYlpmbmhGZGhjSmNNZGRkVWJvZFFlVWZrYlFkTGRZZlVneGNZYmJkeWZwaHViQmJGYlVibWZCaG5hMWdBYkFieGVwZFpnV2dBZ05mQ2FhZVdkRWdSYWVnVWIxYWViVWVVYXBmT2JkYlJhRmR6ZFRmRmNGZDRmY2ZGZ1pmMGdIYW5jdGZJZEZkRGJsZU9oZmRqaGtlSGNCZTJhb2E2ZkhmRWc0ZGJhWWVSYnRnVmNWY2dlZGR6YlRobWZoYXJoYmdrZHBka2hlYVVmc2RVZ2NhUmEwY2RnVGZSZWxiV2NaZW5jUmYyaE9lMmVjZnJiSmVrZUpoYWdRY2llVWZGYlJmMWJwYVdjQmQzaEJmUGhTZTJnWmd1Y1RkR2drYVVnY2RrYTVoemVFYkVkeGROYVVmVWNsaEllUWNrZU5hMGdHZ0hmQmdCZ2RiRmVGZUtnVGhuY1VoUmJOZFVheGhNYmVjQ2h0YVdkWmFSY2xheGhVZ2xneGE1YlZjd2ZWZXhiWGcwaDlhMWRlZGtma2daZldhM2FnYmFmU2FWYThmZWhlZWxlVmUrYVFkU2ZaZ0NjZGRuY0JnTGhTZldhb2gzZkhlVWYwZFpiVmduY1JkdWdkZG5jTmduZERkbWNsaEdmUWJBZU1naGJCYlVnUWVMZUZlRWc1aCtlSGNCZUFnZ2ZMZHdmUWRnZFFmQ2FGYk9kYmdoYkFlQ2ZSYkZmMWJqZEZmVWU1ZXBlZGNCZWhod2NRZ1hmUmhSZlNka2ZZYzlhSGV5YU1oZWhIYWlid2IvaEFoaWMxZWZmTGhsZHhoU2dJYndjbGNlZEZlZ2NZYUNoSmZpYzhiQmVHZFFhNWJ3Y1dnRmFCY2FiT2JIYXBnSGhaYUVnRmR1Y1NhbWJSaDVoU2N4ZVJjNWhWaFJiTWJkZFNleGNrZWdnSWhTYUlocWZQYXdlTmJwZ1ViRWNBZ0RnT2REZmxhRWRBY0FlMWdGaE5mMWhwZmZoYmN5Y05jdmVaZlRnNWd5ZVRobmhNYVFnVGFFaDFoUmVTZlJlVmFPaFlkVGZ3aFdiSWJCYU1iN2ZCZ1FhVWNhZ0xkRWRFYTJiUWdnZ1VjM2VIYWdlTWQ1aFRnU2Q0ZEFkRmhHZXhoR2NWYVNoMGRkZ0RkRGRBZ2pjSGhGY2NoVGZlZkFhSmNaZERiVGVoaDZoUmIyY1JnQmRiZ2tkcGJrZWVmVWhzY1VmY2NSZzFjUGJDZEVlMGNEYUpoaWdCYTJlWmRYZnBjVGhkZUFkQWNTZVJnbmZVaGVoV2NCZnNkWGZCYlFnOGViaFVlM2VsZ2loYmhXaGxlQWRPYmdiY2JnYUhnamNNaE1lUWRWY2tkT2VaZEdobGIwZkdhSGRCYkJkZGFGY0ZlS2VUZ25mVmVNZWVha2FCYTdhZWJIZEJlV2VkYUFkOWhyaFVlaGdSYnhkUmVoYnNld2ZYYVJlOGIyYUphUWNkZVdjUmd5Z2xoYmNIZUZjaGZHZk5nVGJRaHdiRWN5ZWNkRWNJZzNmbGNXY0ZmRGhkZ0lnVWF3YjVlTmJIZHphc2ZnZ2RobmFzZjdjVGMyZWRoTmFPYUVieGcxZ1NoaGNCYVNhUmFBZHRmd2hXY2tmSmR2ZlliamVKaHBmQ2NYaEllYWhjYzBjd2VRY1RnVWJCY1pkRGJtYlJicGhkY0JiaGZ3YlFhWGdSaFJkU2FrYTVjMWNFZVhnTWZhYUVmQ2FwZXdjQmFIY1FmU2JhZnhnUmN2YUpiVGRzYVRoSmZBZzllUGJLZWlkOGRFY0dkVmN0ZTRlWGcxY0JlTmZPZUhlcGRIZFpnRWVGYnVlU2JtZFJhNWdTYXhkUmR4ZUhjVmFRaExiR2ZWaDVhMWhPY2pkNGU2Y1BnRWVnZ2dnUWRoZW9oZWRmaEVoTWNRaEFhQWhGZGZhSmJRZGdmTWJiZnphWWd1ZUlnRWNkYjhkR2NqYXhlK2JHaFFiQWdUYURoRWNkZEdjWWdIY3BhTWFQZnpjSWNnZ0Fod2RNYkFnTWVoZWtlbmRSZ1VncGNTZmNkRmZaYjBoRGcyYnRiU2JGYUhiRmNHZEVoM2doaFRmQ2NTZnNnNGFVaHhmRWQ1Z2NhQWF0ZlpjVmdoYkphNmhSYzJlUmNCZGJka2JwZWtkZWZVYXRoQ2ZNZkVoOGZkZEJkQmJsYUxmZGhEaG9lK2RPZ2pkeGJJaEpjRmVwYmRmQWdqZUJkQ2RHY1ZhNWVFY1RkbmNCY0hhUWZpZkVlbmJNYldjbGIxZUlnQmd3aHljU2dVY1JjYmhSYlVlQWRaZlRlaWNaZjBoQmFYZEJkWGdaYTBjcGhnZVRlbmFVZVJnY2cwZ3hoUmZlY0hiQmdXZ2RnQWc5Y3JiVWJoZVFmK2JSYWdnMWRsZVVoMWE5YmtnYmFGY1VjemJFZjNoQWFMZldiVmRZYVNoZWJraGRka2RRZldhNWVLYVphSGZsaERlWGFYYTloWmdWZ0Jlc2JSY0JjSGQxYWloZGhuZ3NhcWNQYlNnaGNyY0VnbGRGZzFmQWR4YjRjQWZBZlVlWWV4YkVkd2J3YnJlSmR6Z1JkbmJRaERkMGZnZUpjbGIwZ09lQ2FBZE5jQmZIZkVnQWM5ZU9jMmhzZGtmRWZ6YzBlZmZEZVVjWWdoZkdoSGdwZ0FmVWRUZkZhK2RFYVNjQWNIaE9hVmNzYWRmYWRtZ3dkVGJlYUZnTmRQYVpkR2VwY1RnR2hSZ05jd2FDZDFnbGFXYkVnamRWZEtoYWFXYXRmdWhTY21oUmg1YVNheGFSY3hhSGNSZTFjTmRHZlZnWmg5Y2RhVmF4ZnpoYmQwZlpmbmFGZ2hiSmRNZGRiVWhvZVFjVWVrYlJmWmVOZFFmNGNYZ1BiU2N4YW1kWWNWZkVnSmNBZFhjTWFkY1RkRmR3YXNlU2VRYWhkT2JJYkhkcGdNYVBheWQ4ZWhmSGRBY2djTGZKY3hnbGI2ZVFlZ2RVZjNnQWd3ZUllbWFSY2lmVWdWZkhkQ2JWYlBiR2FuYlJjVGdDZm1nb2ZnYkhoRmNCZmRmZWhBZ2xkYmNYZndhbGJRaFJjMmJSYkJnYmRrZXBka2JlYVVnc2VVZ2NnVWhBaFVmUWFUYU5lV2hkZ0dnNWMyZGNlMmM5ZUdmWmh4YVllU2RSZ0RmMWZFY1FkQWJBYkxkWGF6ZzhjT2VHZnpiOGhuZ2FlQ2NoZVFoTmNrYTVkdWNFY0Fob2FZYUhhd2FwZ0JhQmR5YVliNmdHY0hnZ2FWYmZmVmJFZFJiWmVIY1VmUmdjYjBoeGRSZmVkSGRCZ1diZGFBYjllcmdVZmtlSWR3Y0ZhQmRNZHFlVWIxZ0poa2NQZ2hhdGZRZVFoSGc1ZTBnR2dFZ1loQ2hlZ2tkeGRrZ0ZkV2hBaDFmSmhXZmxjYmZHZkZic2NkZEhiVWcwZ1plVmFuYlJidWVkaG5kTmV2aFJkbWdjZVdhRWVnYVZjMWJWZXhhQWdBZlJkQmFWaHVjUmVFY0pnK2VkZUhoMWVEY0ZjSGhKZU9mY2V4aEJlTWZUZ1ZnRmNKZ0ZoVWg1ZXBkUGFSYmhjN2VYZ0hjUWFGZ0FoZ2JjYm1jSGR3ZndlTmVRaEdoNWh3ZVhoWGJSZWJmWmJTZTFhVmhZZkZiQWZJZFVmbGFOZVBoWmNHZHBhVGVHZFJlTmd3Z0NnMWZsYVdlRWJpZHdkR2dOZGtjRWRyYVNibmZsYzVkQWRoZlJodmhBZ3dhTmhOY0NlRWNCZHZmUmFIZ1pmemRiYzBjWmVuZEZiaGJKYk1mZGVVYm9lUWNVaGdnRWZMZ2VhMGFkYkNjT2V5ZW9kdmVPYmhob2ROaERkMmVBZkNoVGVFZVpiUmdIZ1Jkc2d4Y0tnR2JjYktjYWIyaHRkMGhVY1VlcGNPYWRoUmZGZHpiVGhGZkZnNGNjaEZoWWZpZFRmamJsYlNkV2EzY0ZmYmRFZHpnMWNUY1VmWGJwYTBlVWZ3Z2dhRmJhYnliRmRaZ1ZkaGRKZTZnUmcyZFJkQmJiYmthcGJraGVmVWd0YUdiTmNFZWxiSWNIYzFmZGFXYWZkRWVSZjJoY2EyZDloR2FaaHhoWWFTZlRiSGJWZEtlRWJGZkpkRWFDaDNlZ2hWZVFkbWNSZi9iWmRqZzFmY2FPZHhjMWY5aGJjd2gxYlplU2ZVY2tkZWRUZ2plMWU2ZVpkemNGYVZmYmRGZ2hmR2FaYUhiVWhSY2NmMGV4Z1JiZWRIYUJlV2VkZkFmOWFyYlVkaGdSZ3hlVGFrZ2Nnd2RHZGhjeGhxYUZkUmRJZkpjQWMzY0FkV2RXZVVjQWhIZ2JoMWFSZXhhUWVXYWhjS2dOYW5lQmZIaFBhbmNFY2RkSGRVYTBnWmRWZG5iUmR1aGRobmZOZnZkUmJtY2NjV2JHYWhlZ2Y5ZUFmMGROaGNiT2gwYXBoaGNUZkVmSmh5YllibmRCZjhmQWRXYUZiYmdjaHhjWmhNY0JiRmhoZEZkUGQwaDVlcGhkZUJmaGJ3YVFoWGJSZlJmU2JrZjVjMWFFZVhnTmJNYldnU2Z3ZTRmSGh5aGNlQmVGaEJlTWNIZFljMGRZZU9hZWFFYVZnYWNjYVhhbGJHZEdnUmJWYndhVGFsaEJjYWZPZkhicGRIYlpoRWhGZXVmU2ZtY1JoNWFTZHhmUmR4YkhhUmIxYU5jRWJRYklkOGJKZnljVmI5Y0VmQWhkYnpoRGJoZ0pjUmVkZFZmd2VGYVJkMWhjaGVnY2RGaHhkQ2FJZkdndGFxZ1FneGFSZ3loVGduZE1mUWhUY0VmMWhSZ1NoUmNWYU9mYWFYYlFiWWZKZUFla2U5Z0FibWFCaE9lZGNSaEZkemNUYUZiRmI0ZWNlRmdaYzBiRGQyYXRlYmNEaDFkdGRHYkVkM2FoYVRjVGUyYVJmcWdVZnhla2ZUaExnUWFKY1ZmZmFCaEphNmRSYjJoUmJCZ2Joa2NwZmtnZWRVY3NnY2FPZVJoTmJOYUhlMWhZYUNoT2R6Y29odmJJZnllcGJJZk5lRWVOZFFlR2ZDZmNkTGNVY3djWmZFZ0ZhbmZBYWNkRmN5YkVhaGNNY2liQmViZFBoRWY1aDdlUmJFZ1ZkTmRDZG1jTWJWZ1RmbWZsaDBmR2ZIY0JjQmVkZUZoRmFLYVRmbmFWY0RmTmZoY2dlRWNLZ2phNWdXYUliRWFjZWljQWJSZm9od2ZBZGxoZGF3YkJmMGZFZm5lSmFoYXhmWGVWZm5iZ2JDY1ZkeGhoZlhiUGdRYVlmd2RCYUdhWmNEY2JmV2dKY2hlRmFIZUVoZGNIZFVhMGJaYlZibmRSZXViZGJpZDVobWRTZWtkMGRXZ0Vja2Z4YzFnU2VoaEJmU2NSYUFldGR3ZlVjZ2RwaGhkTWhqaFFkbWhRZ0RnMGZhYUtia2NBaEpjUWF4YndjY2JXY1Jlb2FnZUpkRmZRZXBhUWNXZGxlUmREYkJkc2U3Z1VjaWVjZkZoSGRqZ1pod2FYZGlnQWVHZWFod2NrZithY2dVYVlkVGRlY0ZkTmFQZVpnR2FwZlRhR2FSY05kd2NYZVJkZ2hFZkVnaWVoYUhoZWdVZEVoNmhBZWliMGFxaFJhV2VzZ3diRGJRZTFoQmVNaDFjWmgwZWJlbmZaYnpjYmYwaFpjbmVGZmhmSmRNZWRhVWRvYVFhR2gwZ1FmV2NjaEFjNGZLZkpoamRGY29nRmVsZlZoamVXZEhmOGY2Y1RnRWMxZ1JhU2NSYlZmT2RhZVhlUWRZaGNjRWhGZTBoVWZVZG9lTGJkZVFoeGd6YUdlQmRrZnhlSWExZWdiTGNUYW5oaGFBZkdmRmJ0YkdmRWEzYWhoVGdUYjJnUmRxY1VheGdrYlRhY2NBY3RhWmVWYmxhMWg2Z1dnbWJRY1ZoSmZnYk1iM2JkZXpjUmZWY1pjUWZVYVJnWmJ4ZWxlV2VkY0dnNWMyZGNlMmg5Z0doWmR4Z1lnU2NUYkhmVmRLZldjRmZKZFpoQ2R5YlJlVWJQY1NiNWd5Z2RjbWdVaCtnY2RrZDVjemFFaEVneGdOYVVmVWhrY1ZjVGFtYWxjMGVHZkhiQWZQaGRiRWJ4YUtlR2VuZHRldWRNYWxnMWFIaGRhRmVwZ1doZGhBZTlhcmRVZWhkUmR4ZlJiaGNOZjRmVWUwaDloa2FhYWdoQWJaaERibmJCZ2ZlVmN5ZWxlVGdhaFZoVmZvZWFnMmQ1ZUtmWmNIZmxoTGVGZkhjRWRkZkhiVWMwYVpjVmZuaFJndWFOZTNjTmR5YlJlamNNYVlmYmVRYzFjaGVVYWhheGM0YlJnQWd0aHdkV2RrZEpndmJZZ21nWmZwYUZnSGdKYU9hY2N4ZkFjWmRUYlVkeGVKY1JoMGc1YmpjZGFGaEJoOGVhZjNmUmJSYVNoa2Y1YTFhRWhYZ05kTWdVaFhoaGF3ZFZlbmZRYVBnTGhWaElkSmZjZVJjTWJUaFpoa2MxZFJhWmFIZHRhRmhBYWpkbGh3Z0NjMWFsZ1diRWZuY3BoSGNaaEVmRmF1Y1NhbWdRYi9jU2d4ZTlic2NIZVVjOWJOZ0VlMWJZZDZlZGNWZ3hnemNiYjBlWmFuZUZhaGRKZE1hZGVVZW9hUWFVYmtnUmZkZ01kUWRoYkNhSWgyaEpnN2JhaFZoSmZ5aFViR2cwY09mVGJGZnhmSGRVY2plOWJPYWFlWGFRaFloY2hFYUZoMGFVZVVhcGdPaGRkUmZGYTdnQ2dsYUZlK2RiZFZkWmNpZkdjbmM1ZkJlQWZYY2hoS2NFYzNiQWRWYVRoMmg5YjNlVWMxaEFiVGFlY2dmc2NSYlhneGM1ZDZhVGN5Z2hjQmdaYVZkZGZrYlBoMGJzZktmYmd3YU1oZGNYaEFlOWZmYmVhR2c1ZStnUGQyZzliTmZlZGhiWmdBZFRlSGI5YUtlUWgxZ3RmZmdJaFhhQmVhZFFjbWc5aGljWmZtYmtoVWNjZ2tnNWh6Y0VkQmNvZU1lQWgwZGxhV2VUYW5nUmYwZ1ZlSGhCZWZoYWNrZjliS2FYYTJmTWRLYldoVWZ4aFJhZWhIaEJlV2JkaEFiOWFyZVVhaGNSZnhiUmNrYkVlOWFCZ3hlb2cyZ0plRmRNaFJkT2hYYkFkTGNXZFZhWWNTZ2Via2JkZWthUWFXZTVoS2RaYkhhbGJMYUhoRGgwZWRiR2UxYkFkWmJRZUdiRmc3ZVpiV2haYm1oU2RrZDBoV2hFZ2tmeGQxZVNnaGJCYVNjUmdBZHRld2JXZ2tmSmF2aFlkbWQ0YWxjRmdIZ2xmVGZjZjFjbGFNY1JnMWhFYkhlSGdFYkpmRGFkZEJhaGh3aFFhWGhSYlJjU2NrZzVkMWZFY1hoTmVNZ1VoWGVoYjRjRmdYZ1FnRWRkY2xjSmNZY2NnVmhnYU5iWmdsZ05iZWNjaG1lTmdmYU1neGhOZndmQ2QxZmxiV2ZFYm5icGdIYlpnRWRGZnVjU2htYlJiNWJRYjFnaGJ4Z0did2ZCYU5lRGgwYk5iaGJmY1dhTmc2ZVljMmF4aG5iRmFoZ0pnTWVkYVVhb2NRYlVia2FRZExnY2JGZHBlQ2diZDJkb2RxY2FmUmg5aHZkVGFqYllmUWJSYmtmMGhaZVFjQmNsYWthYWdYYVFiWWNjY0VhRmUwZlVhVWVwZE9iZGZSY0ZiemJUZ0ZoRmJ3aE1oMWZaZy9nRWZtYnNkZWZGYUdkOWhZYURiWGdoYUNhV2JXaDFibWdlYVJha2dUZmNnQWF0ZFpkVmZoaEpjNmRSZjJlUmRCZWJma2VwaGtoY2hRY2dkVWZlZGdiQWdkYkhneGRsZGNjZGRDaDlnL2RmYzBkVmhHZVpjeGZZZ1NnVGFIZlZlS2ZFZkZnSmVFZ0NnM2NCYmFlUWFtYWNjaGdaZW1mOGhKY2NjbGhoZm1iQmVWaDllWWdXZ0VmVWEvY1RjbWNsZjBoR2hIY0JhQmNkYUZkRmZLY1RnbmZVZ1JnY2cwZHhoWmJPYjNjQmZkZGFhUWI4Z2llVWNoZzVleGJGaFJncGMwZmVnVWU5YmthYWVsZ01oWmNFZzNlQWFMZVdoVmVZZVNhZWRrZGRma2hTY1NlMWVLYVlkbWdSZExnQWdtY1FnSWZEY2xnZ2hRZVdmbGI1aHVoZGJuYk5kdmRSZG1jY2hXZEVna2V4YzFkU2doY0JoU2JSaEFmTWZ6ZFdia2NsY3ljWWRpYU5ocGJIY25iSWVBZ2VjaGF4Zm1kVGNWaEZnSmRGZVVoNWRwZGRnQmVoZHdnUWRYZVJnUmJTZmtnNWI5ZVVobmROZEtiVGdIZGhjbWhRZDJmRWdjYWZnbGFzaFlkV2IwZlljVGdlZUZhTmhQZVpjR2JwZVRnR2JSZ05md2RDaDFjbGJXZ0doamFsYkhoYmIxYXhjdWJCY1djUmV6aFNlMWN4ZDRnRWZUY2RiTmhHYlZhWmEwY2JjbmRaZHpnYmEwZFpobmRGY2hoSmFNZWRjVWRKZ0VlR2FnZTFjWWZmYWlnVWdEZGZhM2NKYm1nZGRCZlJla2RXZjJlWWdEZFdiVWMxZFhhU2FVZUJmSGVaYlZjNGhZYWNjRWVGaDBiVWVVaHBkT2VkZVJiRmF6Z1RlRmdGZTRoY2dGYjRkZ2JSZHlkSWVCZkdmZ2U0ZEhmQWJtYjVkVGRVZm1mUmM4YVJjZ2h3ZkFhWmNRZXRjZmZWZ2xjUmF6ZVNjMGg1ZkJkYmRrYnBja2hlZlVlc2VVZmNoUmUwZWRkVGFSZWxkV2dkaEdnWWNpZU9ieWVZZVZnYWhXZmxoVGdYZjJhZGhLYURkVmFKaFNjSGNtYVZmSmdWZjJlOWZrZlpkaWFVZWRiZmhtYlJoemNFZkVieGFOZVViVWVrZFZjVGZtZ2xjMGVHZEhkQmRCZmRiRmFrZGVmQmFqZHhmQ2JmZ1RkTWZRZ2JlR2VoZFdhYWJRZTlkOWNSZXdlRmdpZFVheGFOYSthVWh3YnhhdGhaaG5ha2FaZUViM2dBZkxiV2dWZ1lkU2ZlZmtiZGJrZlFnV2Q1ZUtnWmRDZjBlRGJYaFNnSWMzaEhhVWYwYlpiVmJuZlJkdWdkaG5kTmR2YlJlbWJjZVdhR2QxZ2RiZmRTZ2hjQmVTZ1JiQWR0Y3djV2hrZUphdmVZYmpidGRnYUdmRmJoaE9hY2Z4YUJkTWVUZ1ZhRmNKYUZkVWI1ZXBhZmJGZ0JiK2hFZlNiWWVlaEhnZ2FFaGhhU2dDZ01iSmVYYnpnd2E1Y0FkSGVRaFNnYWh4ZlJkQmJQZHdkVmVIY01lUmN3YkJiWmhHZUlnSGNFZ0JhTWNyY0llVmZsY1doRWVuZHBhSGZaZUVhRmJ1YlNkbWJSYTViU2gxYjBlM2dIZFJiVmRkYUdhVWN0YnBoYmFpYkphOWVFZkFiZGIyZ0FoQmdKZktkY2gwYW9mQWZVZ2xha2hXZWNkQWE1ZU1lRWJDZU5lMWVlZHhlUmIwZFNnSGhNYUFkVGVGZUJlTWVTZ1VmRmNBZEZoamZVYk1hYWVFaGhoMGhDZG1kQmhPZmRiUmNGY3poVGRGY0ZjNGNjZUZlWmYwZkRjMmV0Z1NkRmZEZmdoQWhFaDNiQmdEYlRlM2JsZTNkVWMwYTBhZGZEYTBlcGFKYlJkaGJ0YTZoRWZ5YndlVGdJY1JjMWNrZEhiQmdsYkdnUGdrZjhlVmFUZTFlMGVmaEloaWNjY2xmT2ZpYUFoSWJaZjFmUmZMaFRhQ2U4ZVBkUWZoYjFhR2hBZW1ldGF3ZFFhbWQ5YmlhWmRtY2tkVWZjYWtiNWF6Z0VnRWF4ZE5lVWFVZmxhY2RDYkdjbGI4YkNnWGVCaGNmYWJWYUViZWZRZEFkcGVRZVlnMWF4YVljZWhDYUlhVGJJYUZnb2E1Y0hjQmZSZTViRWVsZ3NneGZBaEVmRWYyZExleGc1aFlnV2ZqYzVnUGJIZUFlUWZTY1pnMGRjaHFmQmJEZGxiS2NMZEhkRmNiaEhkWGZnY1JmSGNSZGxjUmNIZHlmZGMxYVhmSGVOZHZlUmNtY2NkV2NFaGtoeGQxZlNjaGRCY1NmUmhGZ1pjYWhXZ2tiSmZ2aFlnbWNaY3BnRmJIYUpoT2JjZHhlQmJNZUJkQmZkY0piSGNSY3BnbmNNZzBjeGE0YUZkVGJ3Y1lhR2FVZmRmOGdPZjNjTmZNY1VjWGVoYndhVmNuYVFlUGFhZjFkSWhVZWNmVWNZYlRoS2VoZFliYmhNZ1RjZ2VkZ0dmUmJ0Y2FiQ2ExZWxlV2hFYm5kcGFIZFpiRWZGZnVnU2FtaFJnNWJTZ3hnUmV4YkhnUmdVY1plVWhSZDhibmhZaENoUWEyY0lnZ2hjYXVoV2RGZ1ljSmhKZTBob2ROaFVoaGZCZURkT2VRZ2xiTWRMZ0NnNGRwZEpnMWRGZzZhUmczZW9nY2ZaY2thMWNSZVNjUmVWaE9mYWhYZFFoWWhjYkViRmEwZVVkVWFwYk9jZGVSZkZiN2ZHZkJia2Z4Y0ljMWdnZExiVGRuYXRkQ2JGY0dneGFHaEFhM2dGaGZhWmdXY1JncWhVZ3hja2ZUYWNoQWJ0Z1pjVmNoZEpjNmVSZzJoUmFCaGJha2dwaHNiTGdRZE5nZGdJYWhjTmVpY0RlQWNoZ0FmZGZIZ05jMmJZaDJkWmhLYVRmUmRZZ1NjVGFIYVZjS2hFZUZjSmFFaENiM2FCZ2FkUWNtYzlnaWJaZ21ha2VjY0pjZ2ZZYzZnUWQwY0lneWZFYkZnb2NIZ1RkbmNSZjBkQ2VIZWxhTmNYYWxhRmNLZFRnbmFVZFJnY2YwaHhoUmFlYUhiQmdXY2RlQWQ5Y3JoVWFoYVJiNWVFZWxic2J4ZUFlRWJFZ2JkS2YwYWNiQmZFZzJnMGdMZlNiVmc4YmVhVWFFYmRia2RRZ1dkNWZLY1poSGFsY0xoRmJIZkVmZGJIaFVlMGdaZlZhbmNRYjZiUGZqZW9lOGNiZ0dhY2NXZ0Via2J4YjFnU2RoZEJjU2VSZUFmdGJ3Y1dka2JKZHZkYWQzYzFlRGZGYkhkSmRPZ2NleGNCZE1oVGdWYkZmSmNGZFVlNWVwYVBhVmc1ZXdhU2VTYkFkWmNBZnhmMWE3ZFZkQ2NKZkVnQmNYZkZoNWJmZ0hjUWJQZGFiMWJJYlVhY2dVZ1liVGZlZkZiTmJQZlpkR2FwZVRnU2MxYVlna2JYaGdkc2RZZkVibmVKYXRhWmNFZ0ZhdWJTY21mUmY1ZlNjeGdSY3hjSGVSZjFoTmZHY1ZmWmQwYmJobmI0Z25oSmd3aDhjMGVHaEVhQWZKZU9nQWR0ZVpnSGJBYUJiT2FJaGxncGJmY2JneWR3aGpoUGZoYVFlNmhSYm1mTWFaZlJnVWFGYzdkU2NSYlZjT2dhYVhkUWVZZmNlRWVGYzBkVWZVZHBmT2JkZVJmRmd6ZVRiRmNrZHNnT2JCZThnbmFBZFJnUWJUYUJkR2hGaEdjRGduZGhkQ2ZSZ21naGRBZFVjeGRrZVRkY2dBZXRhWmVWZWhnSmQ2Y1JlMmhSZEJkYmVrY3Boa2VlYVVjTmhBaE9nVmNSYU9lUWcyY1lnWGRaZVhkaGIyYmJibWg5ZVdiYmJoYW9hNGFUYUhiVmRLZUVhRmJKaEVhQ2gzY0JhYWdRY21jOWhpaFplbWNrYlVhY2NraFlobmVXaEFhVWJlZVhjemZaZlViWGdYYnRnMGNCYlhnQmVSZ2ZiVmIxYWdmVGduZ1VmUmNjZTBkeGhSZWVkSGhCYldhZGhBYjljcmFVYmhmUmd4ZFJkaGNzZnNjR2Z3YVlnM2RaaENoeGdZYUJmMmZnaExmUmdGY1loQ2FjYTBmdGhPYlFnV2I1aEtiWmhIZmxmTGRGY0hoRWhkZUhlVWIwaFphVmJuaFJndWhkZmlkY2VuYURnemZRYzhhRWZrZHhoMWZTYWhmQmZTZlJoQWF0ZHdiV2ZrYkpkdmJZZG1oWmZnZERlMWVoZ09kY2d4YUJjTWRUY1ZkRmRKaEZnVWQ1ZnBiZGhCZGdhMmFEZWlmWmNSYlFmaGNnZjBlUWQzY01kZWNVY1dlVmN3Y0FmbmNwYU1mSmF4YzFoYWZOZUVlNGVhaGRiRmFNYUdhWmZIYmRhVGVGZEFhSmNyYkNkMWFnZkNjV2JqY01jVWNhZGdjMGE2ZFFmamFaYndjVWVCZFJlNGROZ3hlMWhOYkdmVmVaZjBnYmduaFphemhiYjBnWmJuZ0ZnaGRKZE1kSmgwZFJlRGFHZWdlMWZOYkphRGNZYkhlS2VUZ1pndWVlZEJlaGF5YVRhMmJNY1piUWRFZDBnWWZRZWhlNWNWZlFiM2RRZVlmY2NFZ0ZmMGVVYVVhcGRPZmRkUmNGYnpnVGNCY2NoM2hJZ2xmWmY4YUpmV2d0aFNlRmVIY0ZjR2VFYzNlaGZUZFRjMmJSZHFmVWJ4ZWtkVGZKZEVmTWJRY0JnUmh3Z29jQWRpZ2tlQWVKZHdmUWFnZFBmQmhrY1VnYmNCYTFnSmVCYlZjQWRGZGVhaWEwYTZoUGNDaEViRGJiYXhoOGJlZFpnbmFWZUtkRWZGY0piRWVDZDNhQmJhYVFlbWg5aGllWmhtZmthVWRjYmthNGRuZVdoQWNVYmVjWGN6YVpiVWhYYW5kbGEwZUJmWGZCZVJnZWZIaHRnS2dUYW5oVWhSY2NoMGV4Z1JmZWVIYkJjV2FkY0FlOWJyZlVlaGNSaHhiRWJsYnNleGVBYkViRWhiYUtoMGdJZlBlRWcyYjBhTGNTYlZob2c0ZWVha2ZkZWthUWZXaDVhS2RaZUhlbGdMZkZnSGdFY2RhSGJVZDBjWmJWZWlnQWdtY1BkeWhCYWhjT2FTZVlhRmJBaEVmeGZvZ1NnZ2RCZWVlYmdnZXRjd2FXYmtkSmV2ZFllbWFaZ3BoRmZIYkphT2NjYXhiQmRNYlRlVmZFaGRmWGFRZmNoNmRlaG1iY2V4YVZiV2R4Z1JlVmUwZzVkbGdDYWxjbGFNZ1VmWGhoY3djVmFuZVFhUGFhZTFmSWdVZGNhVWdZZVRhZWZCZ3BmUGdlZm5oZGVUZkNnUWNoY2FmQ2MxZWxmV2FFZ25mcGVIaFpiRWZGZXVnU2VtZVJhNWJTZHhmUWI0YkVhQmVCY25iR2RWZlpoMGFiZm5oWmd6ZmJhMGJaaG5kRmhoZUpkTWhmaEdoQWFRZlVia2FRaExkY2dGZHBjQ2ZiYjJjSmFtZmFjUmFSY3lkVGFpZkVhZWZIZ3doVWRZZkRhMGdFZzhhSWJEZU5mUWVKZ0VibGdsYVdmRWZaZ2tnZGRSYkZjemNUY0ZoRmY0Z2NoRmNaZTBnRGcyZnRnU2RGZkhiRmdHY0VmeWZ3ZGJjQmNqYmRka2hBaFZoeGZlZE1lVWhJZVhlRWVsYWNkb2FTY1NmZ2NWZVpnaGdoY3RhZWNSYmRkSWZXZXhmMGdkY1RoUmJsYVdhZGdHaDVlMmVjZTJkOWVHaFpheGFZYlNoVGdIZVZmS2dFY0Znb2ZRZlFlemNrZ0pnVGREYzBhbmNLZ3lkaGRkYlBnQWFvaDJhUWRraElnZWZCY0FidGhCYkhnQ2RnZDNlVGNIZ2dnVGdmZlZoMWZnYlRmbmJVZVJjY2MwYnhoUmRlZEhkQmRXYWRkQWM5aHJkVWJoaFJkeGdSaGhlTmY0Y0dha2c5ZzZoZGQxYU1lTmVDaDFob2JMYVdiVmdZYVNoZWdrYmRma2dRaFdhNWNLYVpjSGFsZ0xlRmNIZkVjZGdIZlVlMGdaYlZlbWJ0ZXVmZmhpaGNmbmNEZ3pkUWZZZWJjUWcxYWhhVWhoYUFiT2dXaFFldGFoYldjbGM1aHplWWFtZTRmZ2hGaEhnOWhPaFpld2FoZUZmUmZIZHRjSmFGZ1VoNWdwZGRlQmhoYXdkUWVYZ1JlUmZTY2tlNWcxY0VjWGFOZ01kVWRYY2hkd2NWY21nNGdQY0llbGhJZEthYmRFaFloQWhhaG5obGhQZFpmR2JwYVRoR2RSZE5jd2ZDZjFkbGNXZEVnbmhwYUhhWmhFYUZjdWdTYW1hUmY1ZFNhd2F0Y3hkRmhVZWtoRmRVZ0FnVmg2aEVlVGFkZ2djZmZVZVlkN2VDZHhnSmdkZWRkVmZZaE1mVWZrY3hjQ2hjYUZlZGJDYmZoSGNCY3ZmWWVEZzVmeWFUY25kTWFRZ1RoRWgxY1JhU2hSZFZmT2NhYlhlUWZZYmNnRWVGYjBmVWNVZXBkT2ZkZFFndGh6YkJkVmVGZm1nYmNWZFphbGZHaFVmRmJTY0ZnSGFGaEdiRWIzZWhhVGNUZTJmUmNxYVVleGJrZVRkY2dBZ3RiWmNWYmhkSmg2YVJhM2h0ZEJnWmFoZzRmc2hNZ0JoZ2FhYURnbGN3Y01iV2V4ZGtnS2dhZFdoNWNuaGNhM2NOZ2FiWmR4ZzVmYmFUZ0hiaGJLYUFmVWVSZk5nQWhsZXBoYWJRYm1kOWdpaFpjbWZrZlVnY2hrZDVkemFFaEVoeGROZlVjVWhrYVZkVGJtZmxjMGdHZUdmcGJCZWZiQWVVZENjQmJ5ZVlhZmdEZUFlMWZCZWFnSGFBaEtmYWRRYTloNmFVYWdhaGJ0YVJjbGJwaHhjV2VsZlJhT2JhYWxhTWZaaEVlM2FBYkxhV2FWZ1lnU2RlY2tlZGdraEVleWVzZGViTWNTZXNjRmJGYkNoVmFWZVZhQmI0Y0NhZmNIZFJidWFkaG5oTmJ2aFJjbWZjaFdmRWNrY3dhb2FRY3hmeGc0ZFJmQWd0Z3dhV2drY0pldmRZaG1kWmNwYUZiSGJvY0dhZmJVZ0FmZWZBZGdnVWZHZVFkUmVjaDVmTWZSZFliK2RCZ0RoTWRRYkhnZ2d0YzFoRGNIaE1jS2VCY0RjWWF6aEFiamUxYUFnSmNWZElmY2JlZkVnWmZJZ1VmbGdOZFBkWmNHYnBiVGNHZVJmTmZ3YkNkMWhsaFdjRWhpYXdnR2ROYmtiRWU2ZFNjbmJsZzVkUWd3Y0pia2dDZkFmNWFZZUdhVmdCaDBkTWZDaEllN2NKYWhkVmdwYWFnVmROZmNnWmRVY01mUWVXZlVnUWVhZmFlM2JCY0NjYmQyZUpobWRhaFJlUmR5aFRhbmRNZFFoVGJFZjBmRGNEZ0ViRWJiZ09iemZvZFliZWFHZ3RhMGhVYVVncGFPZmRiUmVGYnphVGVGZkZnNGJjZ0ZmWmQwYkRjMmhNZUdlWGZEYmdhVmZIY1FoY2JTZlhmM2FSZHFjVGRoaGtkRmJaZ1JoNWJLZFFkeGdKZDhoUmJ6aEJjSWZZYm1hQmZrZ2VkVWVzaFVjY2NSYTBhZGdUY1JmbGJXY2RoR2Q1ZzJiY2IyaGNoU2daYndnc2ZTZlJlR2FOZ2ZnQmFVY0ZkUmRDYjNhWmJhY0hjRGVzZHFmTGR6ZW9iYWVEYlFoOWhpZUJha2JWZk5jV2FraGtnZGRHaG1mbGhxY0JjbWg1ZUJkWmVVZ2RhRGRSaDNha2Q3aGNlMGN4ZVJjZWdIYkJiV2FkZ0FjOWRyYlVoaGVSZ3hoUmVoYk5nd2VCZXdlY2V0ZE9kVmgxZG1iVWNtZkVhZGFXZFVnc2hTZGJiRmRKZ3hjVWNuZXRlS2RZZG5ia2RmYUhkWGMwZjNiSGZVZzBnWmRWZG5lUmd1YmRmbmhOYnZoUmFtZmNmV2ZFZGtneGU5Z0hmaGdCaFBoUmZBZU5jbWRUZDFmZGE4YmRnMmNaY3ZmRmRDY3dmYWRPYjFha2NmaFFkeWM0ZklnQmdsY3hmZ2JkaEJiTmR3Y1NhU2VCZVJiVmdGZ0JjcmZFYVdnSmFhZVdoSGNGZzhiZmRIZFFjUGhhYTFnSWZVaGNkVWhZZVRjZWFGZE5kUGdaZUdmcGNUYkViVWVjaDRnUWFnYXBkWWhiaFRldGNVZWRma2hGZHpiU2FuZkpoc2FYYWdiZGZraEhhUmh0Z05oVGhWaDllNGZSY0hlWmF6ZmJkMGdaZ25iRmNoZkpoTWRkYVVib2ZRZVVja2NRYUxjZWVBYjRhS2hKYWpnRmVvZ0ZkbGhWYm1oVmZuZk1oTmdUZEVhVWNQZUhmVmYwZUhoT2RuYXBhbmNNZ1ZnVmJzYVVhVWFGZ09iZmJVYVZjemFVZ2tnOWJtYmNjRWRkY2ljQmhtZkpnU2NFZ25iRmVRZ0JhbWQxZUFkV2ZtYTFnbWJlZVJna2ZUYmNnQWR0ZlpmVmNoZEpiNmhSYTJlUmVCaGJna2dwYmthTGJRaE5lZGFJaGphY2dkZlRnUmhsZldmZGFHYjVmMmhjaDJkOWFHZ1pkeGNZYWJoVmcxaDlmS2hFZkZiSmNFZkNlM2VCY2FiUWNtZzlnaWhPYjJkQWNZZVdnRWQ1ZHplRWJFYXhnTmhVYlVha2VWZ1RjbWJsZjhhVWNIZTRoUmdKZGhoNGhlYUFoU2NGaEljSWF3Y2xkZmFQYVNmRWREYU5mVWhNYTRjVWVnYmxmeGZEYmhhMGZvaEFkUWhBYXdmSmJRY2RiQWFRZHplVWJGYUhjQWZjaFNkWmYwZGNmaWNGZUNjQWhKZk1iRGdBYkVoV2JuZUVoVmVTZ1VlUWVaY0RmVmc1aHVlZGVuZE5ldmJSZm1nY2RXY0Vma2J4ZzFiU2RoZkFkQWhBZFZnOGdsYkNoQWV4ZHZiYWhrZ3hkcGVGZ0hmSmhPZ2NmeGNCZk1lVGJWYUZmSmRGaFVjNWRwZ2RlRWZ3ZDRnQ2JDZGRjZmZOYVFmOWNoZ0NhWGhOYlJlVGJIZmdia2RXZUFjdGZPYmZkMGVvY1ViZGIwZUFiNWFlZ0ZiTmZQZ1poR2ZwZ1RiR2RSZk5ld2hDYjFjbGNXZUVjbmNvZFRhTGVBZGdlOWJSZEJoc2g0ZVdod2dSY3hhQWJBZkJjTmVUYVZiZ2hMYkxlMmJaaGphYmQwZ0JiaGVQZ0JkSmFNZmRkVWRvY1FiVWFrZVFnTGRjYkZkcGhDZGJiMmdKZW1kUGJWY3djN2RIY1hnMWV2ZkRlVmI1YkRoU2ZRZmhmVGRhZFNjQWFXY0Rmd2JCY25lUWIwZHBkSWRjaHpidGd6ZVRkRmFGZzRiY2hGZFplMGNEZTJidGFTZkZmSGdGY0diRWR5ZHdjYmVCZmpiZGRrYkxoRmNnZENnWmNnaHRjRWZTZ3hoSWR1Y1NhUmRzY0FlZmgxZHhnT2FlZVVic2VVZ2NkUmMwZmRjVGRSZmxlV2FkYkdhNWgyZWVlbmJSZXNoWmF4ZFljU2ZUYUhkVmJLZEVnRmFKYkVmQ2h5YTFmVGJUZGtnVmZpYlphbWRrZFVhY2NraDVhemdFZ0VleGdOZ1diUWZFZGJjSGdqYXNoN2dUZ0RiOGVWY0xhUWZFY1BmUWJEZUphRGZOYWdoMGNGZFBnU2hJZmloUGFFYzRibGRVYWdlbGV4ZkRmaGcwYm9kQWhRZ0Fod2FKY1FoZGVBZ1FlemdVY0ZmSGRnZElhU2haYzBhY2VpZEZkQ2NBYUplTWFEZEFmRWRXZG5mRWdWZFNiVWNRaFpkRGJWZDVldWJkZ25iTmZ2YVJobWhjaFdlRWRrZnhkMWhTZ2hmQWJBY0FmVmM4Y2xoQ2hBZXhmdmJOZWloNGhnY1JiM2N3aHhhTWNnaFJjVWZUZFVkOWFKY1FkVWNBZ1dnTmJRYnhjb2RhZTNoUmVSZVNha2g1ZDFnRWhYaE5iTWhVYlhjaGV3YlZnbmJRZFBiZGRGYkloVmFZZFdod2FUY2ViRmNOYlBlWmdHZHBnVGhHY1JjTmh3ZUNjMWZsZldmRWhtY0JiSGhNY0Fna2FuZkdiV2hvZ0dmQ2RnY0JocGJIZFFhRmJOY1RoVmFnZkxhTGUyaEplcmhSZFVmWmRuYUZhaGJKYU1iZGRVZm9nUWJVZWtlUWNMZmNiRmZwZENiY2VHZUplbmZlYkRiNWV5ZlRlbmhNZlFmVGdFYzFkUmZTYVJoVmFPYWFlWGFRZ1lnY2VGZnRhMGNCZ1FoSWJIZkphaGM4ZE1kRGRVZUplcWJjYkVjaGUwZVdmMmFVZnRjVmVXYkpkVWNPYlhhaGRUZVRmMmVSY3FnVWd4YWtmVGNjYUFidGRaZFZmaGZKYzZlV2FHYlJhQWFmZW1oQmhrZmVoVWVzYVVmY2VSYzBiZGZUY1JhbGdXZWRlR2E1ZDJhY2QzYlZkR2RNYTFkNWRiZkhhM2FzaDFkVWRVZUZiV2VDYzJheGdhZ0ZjbWhFZmRjSmQzZG9oR2dXZUVkNWV6Y0VmRWR4Yk5lVWZVZ2tiVmVUZm1jbGIwaEdiSGFCYUJjYWUxZkZiTGZYZDFlOGZSY2NnMGR4aFJkZWdIZkJnV2hkZUFlOWJyZVVhaGRSZHhhUmJnZWxkNGFCaHdjY2N0ZE9hVmIxZG1lVWZtaEVkZGZXYlVkZ2NTY0xka2NrZmJlQWhIYzllY2NUaG5mbGZMYUZiSGJFZmRhSGNVZjBkWmZWZm5mUmR1ZmRmbmFOYnZjV2VXZmNoWGdBaG1jWmExZFNjaGRCZVNkUmhBZXRid2JXY2tkSmR2ZVlnbWNaYXBnRmJHZ2hiT2FKZzFkZ2ZGZEhhbGE4YzJhVmFGaDliL2NkZUFoUmJ3YkZhWGNvZHVkQ2IxYzliamRPaDNnTmRNZVVhWGhoYXdmVmFuY1FjUGVhZTFlSWFVYmNmVWVZZ1RjWmUxaE5oT2NkaFVmQmJUZ0dnUmJOZXdkQ2IxZmxjV2ZFZm5ncGRIYlpjRWdGaHViU2JuYzVkNWRIZTFmd2I0Z1RlaGdNZHlmV2RFZVpia2FiY21maGR6Z09iMGJnaFlkVmd3aEpoY2hiZm1mQWRRYVVha2FRZUxkY2FGaHBnQ2FiYTJnSmdtYk5lQmIxZCthWmdIYU1kUWNUZ0VjMWRSYVNjUmdWYU9kYWhYZFFjUWhPZEVlOGVrY0Fhd2ZVZGFmT2FrZFVkcWdIZEJiUmUyY1BkQmFNaG5mWGhCYThlYWFWZVRoOWdHZURmbmdnZGJoUWRUZFFkNGFIZUVhMWhjY0poRmZJY0pjRWR4Y3doMmFFYjJnUmhjYWJhZ2R3YXhhTmZ3aGhlQWJPYUZmSmFUY1RmUmZFZENlZmZXYzRndGhXZFdoOWFHZFpheGVZZlNjVGFIZlZnS2hFZkZoSmhFZENkeWNJYWZhRmJqY29kd2RLaEdnbGRBYk9lZ2djYmdkSGJqY01oTWhSZlZiRWVWaFVkbWZrZmdhRmFnZjhlQWRZYkVkbGdnYlRmbmdVaFJmY2QwZHhhUmRlY0hoQmJXZWRmQWQ5Y3JjVWJoZ1JndWZSaGhhSmRvZGVjVWI5YWthYWJsZU1kWmFFaDNkQWFMYVdjVmRZaFNmZWdrYmRna2hXZTJjNGNlaExjRGJBZ1llR2JnZTVjY2dDYlZkVWFaZ1NkSGJRYTZiZWVBaHdndWdVYm5hOGE4ZkVha2F4aDFmU2ZoZ0JmU2VSZEFldGZ3ZFdma2FKY3ZiWWJtZ1pmMmNGY0hoTmVmaFdjUmFCYU1mVGdWYkZiSmNGaFVkNWFwZWRiQmdoaHdkUWVYZ1JlUmZVYkVlNGNoZVdmVGVvYmZnWGF3ZmNjeGRSZFdmWWhQY2RlMWVKZ0FjZmh6aGxoU2dhaDBjRmFsZVpjR2RwY1RkR2VSYk5ld2JDYTFibGVXYUVhbmNwZkhjWmhFZEZjeGdTZ21mVmVwY1llUmVSY3hiSGVSaDFnTmFHZFZjWmgwZGJjbmdaZ3pmYmEwYVpnbmJEYUJhSWFZZlBkUWZOaERkWGJEY3RiS2NZZjBmaGZDaGNhV2NJZnllWmYyZHNkemJYZVdhRWc2Y1RjRWIxYVJlU2VSaFZoT2FhYVhoUWFZY2NnRWNGaDBhVWhVZHBkUmFkZlJoQmNpaFphbGJGaDRnY2hGYVphMGFEZzJidGZTaEZnSGhGZ0diRWgzZWhlVGFWZVdiUWIrZUdlMWNCYUFnZmduZVFlWWNSY3doUmE2aFdkMmhRY1ZjWWFEZFVhbGZhZ0ZmMGMrYmNoUmIwYmRiVGZSZ2xhV2JkZkdjNWcyYWNlMmQ5YUdnWmN4Y1lkTmJUaEhmUmNhZ09jbGZKYUVjQ2EzYUJnYWZRYW1nOWRpaFplbWRrYVVnY2VrZjVmemJDYWthd2NaY0djUWhCZ0dnUWFCYVliMWhDY1djWmFCZGFnbGhFZGVlUWFBZnBnUWJZZmxlcGY3YmVlSGdCZVdiZGJBZDlicmFVY2hnUmZ4Z1JlaGJOZDRhVWUwZDlkN2JhZGxnSWVJZU9hWGhBYUxiV2JWZFllU2NlZmtmZGdrYlFlV2Q1YUthWmRIZGxoTGdEZG5kRmFKYVZkUWZSZEtnV2RBZXNhdmZaZG1lTmR2Z1dobWFkZ0NnSGREYU1jMGNXaGdjQmNKaGJiZ2Z0ZndiV2JrYkphdmRZZm1iWmVwZEZiSGRJY1RhZWFoY3hobWRUY1ZlRmVKZEZoVWg1Z3BmZGdCYWhkd2RRZlhnd2daZ1JoQmc0ZG5kWGdpZWNmRGdCYVNkRWJnaEViM2RwZUFkT2NWaElnSmFjZVFkQmdHaE5haGVBZWJmTGNTZFVjZGJHZ1Joc2hraEFobGhrYU5lT2FIZXBoSGRaYUVlRmZ1ZlNibWVSaDVlU2h4ZFJheGRIZlVoOGRJaFRoUWRNYW1lSWZIYlpkN2RSYVVmWmNuYkZhaGFKYU1mZGdVZm9kUWRVYmtjUWhMZGNoRmdwZ0NiWmh6YllndWNJZkVjZGQ4aE1kVGNJYkFjWGZFYTBmTmNWaEJhVWZhaFpnd2h0Y1pkWWRGY0ZjOWNYZFdlQmdPZ2RiUmhGZ3pjVGNGZ0ZlNGRjZUZjWmgwZ0RmMmd0YVNiRmVIYWtoU2hXZHpmRWZBZ1FiUmRzY3JjUWJnZjhkVGdMaEJjWmJaYkFkaGF3YkZlQmduZFZnWGhaZTBkWmNPYmViVWZzaFViY2ZSZzBhZGFUZ1JmbGFXZmRjR2E1ZjJnY2EyZDlmT2FNYjFjNWFiY0hiM2VzZzFjVWRVYkZjV2JDZ3ljeGZIYlFhamZ0ZXNnR2JTY2dkSGNZZEVmZGMvZE9ja2h4Z05kVWdVYmthVmNUYm1hbGEwYkdkSGNCZkJkZGJGZUZkS2ZSaGlhRmJaYk9oaGQ5ZmZmQmV6Y0ZnQ2ZiYUFlOGYzZlRneGVRY2xoU2dHZ3dlNWFSZTFiZGR0Y1pibmVrYlpjRWgzY0FhTGRXYVZiWWVTZmVoa2VkZmtnUWJXYjVlS2NaZUNmMGZEYlhmU2hJZDNoSGRVZTBkWmNWaG5jUmJ1Z2RlbmROY3ZkUmhtY2NnV2VHZDFhZGZmYVNhaGNCaFNoUmNBY3Rkd2VXaGtiSmd2ZFljamV0YmdoR2hGZGhmT2djY3hmQmVNYlRoVmNGaEpnRmVVYzVkcGVmY0ZmQmcrZkViU2ZZZmVmSGFnaEVlaGZTZENhTWZKaFhhemRrYythRWVuZ1FlU2JhYnhjUmNCZlBid2dWZUhoTWNSZndhQmRaZEdkSWhIYkVoQmRNZHJnSWFWY2xoV2FFYW5jcGJIZlpiRWdGZXVlU2NtZlJlNWRTZjBhWWcwZFNlVWJnZmZnVmIxZlpiOGZSZEhoWmR6aGJmMGhaZG5kRmhoZkpjTWhkZVVhb2NRYVVja2hRYkxmZWZBZzRoS2ZKZWpoRmFvZEZobGhWYmljWGRuZE1hV2hVaFVoMGJGZ1JjMmVvY1BoZWRXZVFnUmRmaEdmdGQwZlVnVWJwYU9iZGhSZkZiemRUY0ZlRmI0YWNlRmJaYjBhRGUyZk1mR2hYY0RmZ2JWaEhmUWVjZlNiWGZuY0phcWhWYVFnUWFUZ0phQWRVYm1jRmJ3aE5ic2ZUYW1iaGFyZGJoa2hwZGtkZWRVZ3NlVWZjZlJiMGVkZFRmUmdsY1dkZGZHZDVlK2dKaHljY2dQYk5jQmhoZHRkRGRXYVpkWWFFZUZjUmNaYUNkeWRSZVVlUGdTZTVieGNkZ0doQWVZZldjRWE1YXpkRWNFYXhjTmFVY1Via2hWYlRjbWVsYjBoR2ZIYUJjQmRmZ0FoVWZDYkJkeWNZZ2ZoRGFBZTFiRmhZaEhkQmdRYmFoUWQ4ZS9kWGhHZ3Njd2hVYmdmdGh4Y1hmMmdWZmthYWZsaE1kWmNFZDNlQWVMZVdoVmNZZFNoZWhrY2Rja2VRZFRnb2VDY0xjU2FwZmhnRmhIYUVlZGRIZlVmMGFaY1ZibmVSZnVkZGZuaE5kdmNUYTNmd2U4YkVja2J4YjFiU2hoaEJiU2VSaEFkdGh3Y1dlaGM5ZW1jYmVrYXhlcGZGZUhhSmRPY2NneGRCZk1kVGJWZkZkSmJIYlFjWmVuYUpoRWZvZS9jRmFUZnNiRmNFZHhhNGN3YkhneWZzYkRhQWYzYmhodGdWY2phSmZhZUpnUmhGY0FnT2JBZGxmZGVlaEZic2RiZGJoV2ZvYkloTWh4Yk5od2FDZzFjbGhXYUVmbmJwYkhmWmNFY0ZjdWdTZGphWWM4YUhjMGVFZ2pjVWJ4ZTFjRmdNYjFiWmQwZWJjbmhaZ3plYmcwYlphbmFGZmhjSmFNaGRmVWRvY1FhV2RoY0JlRGJPYlFlbGNNZEVlQ2ZOaDJhZWVSZVFnTWFVYzNkTmVFYVFkamFJZVFhV2NRZFZiSGZaY1ZnNGRZZ2NiRWFGYzBjVWZVZnBhT2JkYlJhRmN6YlRoRmJGYzRnY2FGZDRmZ2hSZHlmSWNCZ0dnZ2Q0YkhmQWdtZjVmVGdNYlhhbGNxYkJoeGVkaHNnTWZSaHBnUGJYYXhnNWZRZVJnMmhSYUJnYmhraHBna2ZlZFVnc2JVYmNkUmQwYmRlVGVSaGxhZWNJZ0NnWWQvZ0lkR2RFZzViSmdnZVVnQWZUaEFhdGhYYUVnQWFaYktlZGVEZkZoSmJVZkdkWmJ1ZVRhR2FrY1VhY2NrZDVmemFFZkVoeGFOY1VjVWFrZFZmVGhtZmxlMGJFYkNhUWFKYlBiUWJKaEVhTWdUZlFhRmRhYjBkd2Z2aFpoWGdBZ0NnZWduZkFjcWJSY2dleGE0ZFNnamFsYzRjVWQwZDlja2ZhZWxhTWNaY0VnM2NBYkxkV2FWaFlhU2dlZWhnTWVzZENiRGExYWdnWmNIZGxiTGVGYkhmRWJkY0hkVWIwZ1phVmRuY1JidWVmYjJnaGNGZ1JibWRjZ1dhRWFrYXhlMWNTZGhkQmJTZVJkRmJaYzVjVmFtaGhjdmZZYW1jWmJwZkZjSGRKZ09nY2V4Z0JlTWZSZ1JlbGRIZlJlUmV3Y21jSWhGZ2Nja2dHZENlUWhVZ1JmQWVBZDZhUmFYaE5lUmVVaFRhNGhsZ0doRGdkZ2JmSWNoYzFkYWNjaFVlNGhhZmVoQWFoZGxkWmJHaHBlVGNHYlJlTmh3YkNjMWZsYldmRWhuZHBhSGdOaGdjUWY2ZkhoemNZZTNjU2N4ZnhlYmhIaFJkMWVOaEdjVmVaYjBiYmFuY1poemhiYjBmWmRuZkZhaGJKZUVhSWFRZ0pkWmRBYlVjcGUwZE1lVWFwZlNhYmczYTlobWRmaHdoRmVuZ1hlV2hZZ1FhU2RrZzBhUGVIZlZmMGZIZE9obmZwZ25mTWhWZkZka2FXZEViWmVrZmRkUmNGYXplVGFGYkZoNGJjYkZlWmYwY0RhMmV0ZFNjRmJIY0ZnT2ZSY3pjQWNhZEhkR2dvZ1ZoRWhnYWdnRmJjYkJlWmdaZ1FoQWNkZXZnVmZIYUZjQmVhZ0Vob2U2ZUxmUWFOY2RmSWhoYk5kaWREYkFkaGVBYmZlV2RKZmNoY2cyZzlnR2RaaHhjWWFTYVRhSGFWaEtlRWhGaEpkRWdDZjNhQmJTYUZnaWdjYnJmTmVXZWRicmRNZzFhMWdoZEVkRmRGYk5mUmExZXdmQWdYZ1hoeGQwY0hmbmVBYmZmSWhCY2tiRGFIYVhjdGN1YU1ibGE5YkRoY2hYZ3hkOGJkY0FiOWJyZVVoaGRSZnhmUmNoY05nNGFVYjBiOWVrZ2FibGJNZ1JmUmR6ZmhkQ2JDZGxnaGV0YU9iMWdOZThoUWVYZE5jS2FjYm1heGhlZkJnMmFRaGRiR2IwYjFoSGJBaGpid2JuY0phWGEwZ1FkQmgzaE1oT2ZHYzBkQmVmaFNiaGFCZ1NlUmRBZ3Rid2ZXaGtoSmd2YllobWNaZnBmRmJIZEljYWFPYTFma2JmZVpjMWFGZkpoRmJVYTVocGhkZ0JlaGF3YlFlWGRSZlJnU2JrZWRldWRPZjNlTmJNYlVnWGhoYndmVmJuY1FiUGZhZjFhSmhKYmVoRWNvZTVjZWdGYk5lUGhaZEdlcGRUYUdkUmhOZXdhQ2UxYkVkZWVIaENlb2VWZEtneGhVYWhlSGNqaDBocGdEaGhjb2RpY1ZjVmJRZ0xoVGFTYVFkOWZLY1RoNGJuZ2JoMWZ0ZW5kWGNoZ3djY2dKZXdiVmNFYkhiUmJCZ1NnSWZCYTlmTWZQZUNib2V2Y0xiMGdBZWdnVGRtYTRmUWhDZ2hjZ2FmY0Nha2RFaEhlSmVqaG9kWWhlYUJhVmg5ZlVkUmNGYmtkZGhSYUZmemhUZkZhRmY0ZWNmRmRaZjBhRGEyZHRoU2VSZWpkUWRTZlJkaWdvaGRoVGUyZnhjQWhVZnhma2RUZ2NhQWZ0aFphVmdoZUphNmNSZjJmUmNCaGJoa2hwZXNiTGNVY3NjUmFiZUJhMGNMZ1dnUmRCZmFhWGJtYjVnMmNjaDJlOWVHYlpieGdZY1NlVGFIZVZmS2hFY0ZkSmhFY1hnM2JCaEVoWGcyZTlkMmVmZWtmTWFVZ2Noa2g1Y3piRWVFY3hmTmNVZVVja2FWZFRibWZsZDBlR2VIaEJoQmZhZzFkRmJDZFJlaWdGYlpjT2hoZDloZmhCZXpjRmVHY1plQWE5ZTJiVWFraEFiNWREZDBnQmMyZExnQWU1YndmY2JsZk1oSGFEY1hnQWZEZkRjVmRZaGZlZWhsYU5kOGNTZEdiZGhHZFRibmRsZkxlRmdIY0VnZGNIZ1VmMGdaZ1ZhbmdSZ3VnZGhuY05mdmZSYW1iY2FXZ0Vna2dRZmhnQWdsYWthQmZTZ25nUWh4ZVNkMWNSaHZjZmYyY1poNWNIZ1hlNWhrZWNoeGZCZU1nVGFWZkZhSmdGZlVmNWZwY2RoQmFoZXdjUWVYZVJlUmJTZWtiNWgxZ0dhU2hjZkVjR2JDYXRmK2FLYlRiVWFjYmVkVmdJY0pkY2dWZ1liYWFkZEhjbGJQZVpoR2NwYVRiR2ZSY05od2ZDZDFhbGhXZ0VlbmNwZ0hmWmFFZEZmdWRTZ21hUmV4ZUhhMWh3ZzRjVGhoZk1heWZXYUVhSmVzYWJobWF0YXplZmQwZTlidWdQZEJnSmhNYWRlVWZvaFFkVWVrZFFoTGdjYUZocGFDZ2JiMmdKZW1nYWRSZVJnb2RUZGlnY2JRY1VobGRCYVJhV2NnZWRha2FhZFhhUWNZY2NhRWNGZDBlVWdVZHBnT2FkZVJoRmd6YVRmRmJGYzRlY2NFZ2xoMGVCYjJkTWVHZEZnSGV4Y2JiRWEyaHRjQmdSY21haGFBY1VieGhrYlRjY2VBaHRmWmJWY2hiSmY2ZFJmMmZSYUJnYmdrZHBna2JlZVVmc2FVZGVkVWVsYVZiQmRFaHBjWWhDaHlhOWZtZFlkMmc5Z2JnVGJSZllhU2RUY0hnVmdLYUVkRmhKY0ViQ2MzZkJjYWRRaG1kOWhpZFpibWhrZFVlY2hrYTVkemRCYWxkbGNZZ1FmbGZ3ZVZjU2RHYmxlOGZFZENlUWFKZlBkUWRKaEVkTWdUZ1FmQ2ZZY1VkeGNQZ1pibmVBYUNnZmJRZThmM2JVZWhjd2hsZkRmbGFvZnJhWGJUaEFjbGFmY2tnc2daaERoMmZ3YUxmVWFVZWNjRWNlaGtjcGNrZ0ZiV2ZkZkRjYmZYaEJoSGRQY25jRWJkZEhkVWgwZVphVmZuZ1JkdWhkYm5mTmh2Z1JkbWJjaFdhRWZrZXhoMWhTZGhiZ2RHZURiRWJJZGplVmZEYjBkdWZjZjNjQmJwZUNoWGVKZkdhSmUxaGdiRmVIaGxmOGMyZVZlRmZwYnhjZGZBZVpmdWhRaFNiQmJZZVNoa2RoaDFoQmIyZlpnWmJRZG1hMWc1YldhbGI0aFBmYWcxZkljVWRjaFVnWWRUZmVnRmFOY1BmWmNHZXBnVGdHY1JhTmJ3ZENoMWFsY2VhUmdqZEliT2NOZTBnOGJSZ0NjM2RkYnJmU2R3ZWxheGFEaFJjUmZCZE1jMWZaZTBkYmFuYVpjemZiZzBhWmduaEZmaGZKaE1mZGhVZG9lUWNVZ2tkUWVMZWNiRmhJYldnSmJ5ZXNhMWRaYjJmc2Z6aFdnbWhzYVFlVWRVZTFmQmZRZEJneGJrYmFoWGhRYllmY2hFZEZoMGRVZ1VkcGZPZmRjUmZGZXpkVGZGZEZlNGFjZEVoeGgwaFdlMmV0Y01mQ2JYYkZoWGVCYVZoSmVUY1RnMmJSZXFhVWF4Z2thVGRjYkFkdGRaZVZnaGNKYTZmUmcyaFJkQmJjYlVicGVzZGNoUmc4Y1VoZmFBY0FhZGNYZkFmOWNmaGVmRWVSYjJlY2MyYzljR2JaYnhhWWVTZFRmSGNWZUtmRWRGZEpmRWFDYTNjQmhhZFFobWI5ZnFjTWRpYkZhZGJJZVVhQWFNZ1VnVmd4YWRoVWJWZVFjL2JUZm1lbGQwYkdmSGFCYUJhZGRGYkZmS2NUYm5hVWFSYmNiMGF4aFJmZWdIYUJlV2hkZUFiOWg5YlJnd2FGZ2loVWV4Yk5lK2hVYTBhZGVzZVBiaGJ0ZFFnUWFIZTVoMGFHZ0VmY2dFaGVlbGJsYTZnUWFUZXBlRGNaYkNnVmNMZkhkQ2FWY1ZmVmJCZTRhWGFLY1RmVmY5YVphSGJOZnpoV2htaGNmZWdBYjFncGExYlJneGZBZUdnVGJRaEpjNWhVZDBhNWRGZllibWRaYXBmRmNIaEpkT2hjZHhmQmhNaFRlVmJGZUpmRmZVaDVjcGRkYkJhaGV3ZlNlU2hBYlpmQWd4ZzFjN2NiZGphSmJkZ1JkM2NoaHRhZmNIaFFoUGFhZjFoSWRVaGNoVWhZZlRkZWVGYU5kUGJaZkdncGNUZUdoUmNOZndjQ2IxYmxkV2VCZEdhOWJTYmRlMWJSYnVlVGFHYVJieGRRYjBlQWE1ZFZiRWM1YURiWmhoaGRnbmNmZEhhWmR0ZGNoVWFZZXpnSGN4ZEloUWRkZlVnSmJFZ0dkZ2YxZVljZmFpZ1VkRGdlYjNhcGZtZWRkUWRoaHljUmNtYklhR2ZUYUVmQmRSYUhoUmN4Y0hnWWhIZjBhVWNXYWthRmIwaFViVWZwYk9jZGhSYUZjemNUaEZhRmc0ZWNhRmNaaDBnRGQyZHRjU2FGZkhka2RTYldoemNFYUFhUWFSY3NocmZRY0Fic2dUZWJlUWZ0ZVJkQWFsZG9oemVGZkdkb2QrZ0xjMWc1ZzhoZWVWZFViS2JjYlVia2NVZFRlUmM5ZFdmWWFuYnRjamhZYkhlcGhQZmFhemZ3aFNjVGdIYlZlS2FFZ0ZiSmJFY0NmM2RCZWFjUWFtZTlmaWhaZW1ma2dVY2Nka2Y1YTdkUmNBZFFkRWhBYmtlZGFxZURhM2ExYXNiR2NHZDFoQmhaZEZkaGVEZlpiSGFVYVJmY2MwY3hiUmdlZ0hjQmdXZ2RnQWI5YnJhVWVoZFJoeGVSZmhnTmJpYVViMGhkY3NoUGZoYnRiUWNRZUhiNWIwZUdnRWhZY0NnZWhsZnBnT2FRZFdmNWJLY1piSGhsZExmRmRIaEVlZGNIYVViMGFaaFZnbmJSY3VlZGVuZE5kdmRSZ21nY2dBZ0JlMWNsYW1mWGd4ZUJjVWVSZ0FjTmQ0YkRiZ2NvZ21lTWFXY2diV2JWZFdoSmFlZmNid2I1aFNhVGJRZlZlQWdGaFJoSmhwaGZoRWF3aDRnQ2VDZWRiZmdOaFFiOWRrYkJiM2VOaFFkVGNYZWhiNGRSaDJkSWhQZFphbGFKaEFkZWdFYThjYWhjYVZhOWhsYlpoR2RwYVRoR2dSZU5hd2VDYzFkbGZXZkVnbmFwYUhiWmFFY0ZodWJTaG1iUmM1ZFFkMGhBZTVlVmFFZzViRGhaZGhkZGZsZmViSGhaZHVkUmJVY1plbmFGYmhiSmZNZ2RmVWhvY1FkVWVrYVFjTGJjY0ZicGNDY2JkMmRKaG1mYWFSYlJmeWJXZEdjWWNGaFhkMWRoZlJoVGh4aFZiR2JZZ1NhQmRRY09mUmVKYTZnTGdnYXRjZmJZY3hkRmh0Y1VhbGVFaHNnZWVWYllkb2JEZzJlTWFHYVhiRGFnYVZnSGJRZmNiU2dYZ0hkWmFxYlRod2hVZFRhZWVCZnBmUGFWY2hoOWY2YUVnMmExYkloWmMwZ05kb2RVZDBoc2JVY2NnUmcwYmRmVGFSaGxmV2dkYUdjNWYyYmNkMmY5ZEdjWmJ4Z1ljU2FUZEhnMGFlZ1dhQmFzZFhiQmVRYThhYmhVY1hlMWJpZGVoMGZNYVVlY2NrZjVhemRFY0VjeGNOZlVhVWVrY1ZhVGRtZWxmMGdHZ0hoQmVCZGRoRmhGYktlVGdtZ01oRWhaZGxjOWVFaGVlSGFaYVdiZmdBYWNiL2VHY2xhMGVpZ1NlR2R3ZjVkUWVGZjFla2NkZ0VnMGNaZlJjM2JrYkxlQmRWZFlmYWVMY2doOGZ0Y0VibWZBZTFmSmdXYTFkVGdGYkdlMGdCaEhmVWhVZkljUWZIaFJoamdkYmlmZGZtYlRhMmI0Z2ZoSGFtY1phMWhTY2hoQmhTZlJjQWJ0ZndjV2VrZkpodmVZZG1jWmhwZ0ZoSGFKZU9lY2V4Z0JnRWFHZlJja2VBZVJoa2ZBZVdmTmhRaHhib2FRY1dhbGVSaFFjaGZvZzljV2hDYkJiQ2hMZWpjbGhrZFRibmNRZlJjZGJWZkpiQWhlYUVmWWRWZ2ViRWVWZGFmY2dYZmxkR2dFYUJocGI4Y0lkVmFsYldjRWVuZnBnSGVaZ0VkRmd1YVNmbWdSYzVnU2h4ZFJheGhTYVZlVWRFaFNnbmZ4YzBoYmJuYVpjemhiZDBmWmNuYUZlaGNKZ01lZGhVZ29hWmhTZVdiNGVMZWNlRmdwYUNiYmMyZUpibWNhYVJkUmN5ZUVhM2dvZWNiWmJrYjFlUmdTYVJiVmRPY2FnWGhRaFljY2RFZEZmOGdHZ1VoUWRlZUpiMWE0ZG5oQWJ3ZVVhaGVJYUJmTmE2YVhoQ2ZNaGJhVWdpYVVmcWdWZGpiNGZIZFRjM2VsY3FnR2V4Y2RkRGNJZ2tiUWdOZEdnVWhZY2pjRmZ5ZUZnUGJQYVFjSWJ0YVBjeGU5YlllY2dRZUFmZGRDZDBod2ZZYk5nemRvYy9jUGNDZ0ZhR2diYTBmSWNlYlRhQ2hkZkRlRWRBYmxhdWFDZTNoQmhhZVFjbWc5aGliWmhtaGtnVWJjaGtkNWV6ZFFmZ2JrZlpmQmNCZHRnYmRUZm1lRmZlaEdoSGhCZkJlZGFGZUZiS2VUZm5hVWdSZmNhMGF4ZlJiZWhIY0JnZWhJZUFnOWZ1Y1RmeGFSZ25oVWRoZ3BnMGVlZVVnOWdrZGFlbGdNZVpkRWMzZEFmTGNXZ1ZjWWZTYWVla2JkY2tmRmNXYTVoVWJlZ1hjbGhmYURkRmVzYWRlSGFVZjBhWmhWaG5nUmV1aGRlbmZOZnZjUmRtYmNlV2dFaGtjeGQxY1ZmUmJCZGFmVGFGZDhjNGdFaHhkRmVoY0hhU2dkYzliRGJIaEplVGhjYzBoUWJFZEJmQWJKZUhoYWFnYjliNWdaZUJlaGhzZFhiWGFSZlpiSGJrZjVhNGFFYVdiZGVVYVdkSGVGZThkZmdIYVFoUGhhZzFoSWJVZmNjVWJZZFRiZWNGYU5hUGFaYUdlcGVUZEdhUmhOY3dnQ2gxYkVjQ2VXaGpmTWhVYmFlamY0YnZlV2RYYVpkNWdWZGhmUmJoZkZhQmFGZG5hR2dWYVplMGJiaG5jWmF6ZGJkMGRaYm5lRmFoYUplTWhkYlVob2FRY1Vla2NRZ0xmZWNBYjRlS2hKYWpiRmNvZUZjbGhWY2pkV2hIZU1iTmNUZkZjMWhZZlJiVGE5aE9mYWZYZlFjWWJjYkVmRmcwYVVmVWVwZ09lZGJSZ0ZkemFUY0ZkRmU0YWNoRmRaZThkV2N5Z01iYmZSZDNmOGI1YlVlbWJoYkRjVGYzZWxkcWRRZ3hnQWdhZ1dnZ2h0Z1pkVmNoZUpkNmdSZDJlUmhCYmJja2VwY2tmZWJVY3NjVWVjYlJnMGNIZlRhVWgxY1dhYWhuYk5hMmVZZ0hlMWFzYlpneGdZaFNjVGNIZ1ZnS2VFYkZmSmVFYkNjM2dCZmFiUWFtZzloaWRaZG5mWWJVYmVna2RZaG5oRWRFYkZkUWRVZ1Zkb2ZIZVJkMmdWY2VoR2JIaEJjQmhkaEZlRmdLZVRibmVVZFJmY2cwZnhjUmhlY0hjQmVXY2RnQWI5Y3JhV2hrZEFjNWFEZDBlQmEyaExlQWc1aHdiY2RsYU1jRWFFZDNoaGVmYUViUmQ5ZkJiZGNEZ2dkbGhVYkhhaGFLYmVmR2RWYUxkUWVIZGdkZGNRYlVkMGhSZUFiamJ3aG5mSmdYZzBjUWZCYjNjY2NHZkVjbGZKY3JlU2JoZGhmRGFVZmdkdGc5aFdjaGJaZG1oYWMyYTljbGNQZ25kSmhPYmNleGFCZU1kVGFWZ0ZkSmNGZ1VoNWRwZmRlQmNoYndmUWdYZVJnUmhTZ2tmWWhoaFdoVGZvY2ZoWGV3ZmNleGVSZVdmWWFQYmRlbGNJYWNkSmRRYjVnYWZLZTFnMGR3ZEpoWGhwY0RoR2hRaDlic2JDY3doMWZmZEVobmF4aEhmY2FsZlJmN2hXY1hiRmR3YVJnemY1Y3hoSGdSZTFiTmVHYlZhWmMwY2JhbmhaZnpkYmUwaFpjbmdGZ2hhSmJNZmRoVWJvZ1llQmFnYnhnQ2JJYzFhUWE5ZUxhbmROYndiYWVRZWxheWVYZm5kb2hjaFpha2IxYVJiU2RSY1ZiT2NhZFhjUWVZZ2NmRWJGZDBkVWVVYXBlT2dkaFJjRmd6ZlRhRmhrZXNoT2RCYjhmbmFBZ1JjUWFUY0JnR2JGaEdhRGVuY2hjRGVSYm1jMWdBYVVneGJrZ1RhY2VBZHRiWmRWY2hkSmQ2Y1JlMmRSZ0JjYmdrZXBha2hlYlZjRWNVZ0pnUmMwZERnVWJCZ2xoSGJZZmtoUmMyZWNoMmg5ZEdjWmR4ZFlhU2VUZEhmVmZLY0VmRmFKY0VkQ2gzYUJhYWZYY1djOWRxYmJlamYwYlVjZmMxYk5kemVBaFZocGVFZ1hlV2VNYVZoVGdtYWxnMGhHYkhjQmZCZ2RmRmJGY0toVGVuZFViUmdjYzBneGVSZWVkSGFCZWVmSWVFZmNnaWZBZlJib2VPZkJkd2dkZWdnVWIxYkpka2dZZGdiZGhSZldnaWJNZkZlSmdoaGNlQmRhYkVmZGc0ZlhnV2Y0ZGVoYmhYYmtkWGhGY0hhbGdKaFZmUWFSZEtiV2RBZ3NodmFaZjJhVmd2Y1diSGdrZFdiR2VsYjFhamFTZGhiMWFTYUVkQWNKZTVmVWYwZDVmRmNZZm1kWmZwaEZiSGhKZE9oY2F4YUJmTWVUYVZnRmRKY0ZiVWE1ZnBkZGNCZGhld2JTZ1NhQWJaZkFleGQxZTdkYmNqZ0pkZmRRZDNkaGh0aGZlSGRRY1BiYWQxZUlmVWFjZFVjWWJUZmVoRmROYlBmWmZHY3BjVGZHZFJiTmh3ZkNjMWJsYldiQmZHZzliU2VkYzFkUmd1Y1RkR2VSZ3hjUWcwZ0FmNWhWY0VlNWVEYlpmaGhkaGxiZWZIZ1pidmVjZDBoWWZ6YUhoeGNJYVFhZGFVZkplRWFHY2dkMWVZY2ZoaWZVYURlZmQzY0pmbWVkYndhcGF5Y1JobWJJZkdiVGZFZUJnUmJIZlJleGVIaFliSGUwY1VhV2hrZkZiMGRVaFVlcGVPZGRhUmdGZHpnVGJGZ0ZiNGRjZ0ZkWmIwaERkMmd0Y1NmRmRIZ2tlU2JXZnpoRWNBaFFiUmJzaHJlUWVnYzhlVGJiZVFmdGJSZkFobGNvaHphRmFHZG9mK2RMZDFmcGEwYmVhVmRjYUlnY2dVZmthVWhUYlJhOWFXZVlhbmJ0YmplWWJIYXBhUGJhYnpjd2RTYlRnSGVWZUtmRWZGZEphRWNDYjNjQmVhZ1FibWI5Y2llWmVtZGthVWJjZmtmNWE3Y1JnQWZRZ0VlQWFrZmRocWdEYzNobGdraEdoR2YxZUJhWmJGZmhhRGhaYUhmVWdSaGNiMGF4YVJmZWhIY0JkV2JkZkFoOWZyZlVoaGdSZXhhUmVoYU5haWFVZzBkZGFzY1BnaGh0Y1FkUWFIYTViMGJHYkVhSWJLZmVjbGJwaGtjU2ZUZm9lQ2ZMZlNjcGhGYWFhemNBZkplQmhVZTBjRmJTY25iUWE2aGZoM2hNZHpkUmNtYjlmQ2FXZmdiVWdtZVJkR2E4YlRjVmJ4ZGxod2NSaEZleGJ2Y2FobmVkYS9nRmNIYzljT2JKZ3hnbGhGZlJhRmYxY2piRmJVZTVhcGFkYkJnaGF3Y1FiWGdSYVJnU2FrZzVjMWNFZlhnTmNNZVVkWGRoZndmWGhpYkJmSGJJZWdjRWNhZ0RlZ2hjYkFoYWRsZk5jU2ZUZG1lcGJUaEdoUmhOaHdmQ2IxaGxnV2FFY25jcGNIZVphRWFGZXVmU2RtZlJlNWRTZnhoUmN4Z0Nid2NoZVllQ2drZU5kMGZhZEhiWmE3Z1poeGRJYnZkWGYwY0ZhQ2hDZWdic2JEZVFoRWVRaFhnYmVGaG9hV2NaaG1kSWQ2ZWFjUmJ3Y21nQmZqaHBlRGNRZ2poSWVRZ1dkQWFOZk9nZGIyZG9kWWVlZEZhQmZpaFVkVWNkY09mSWJSY2hiNmhSZ1ZlaGMwZ1dibGVaZzBiRGYyZXRiU2dGaEhmRmhHZEVhM2FoZVRoVGIyYlJocWJVaHhha2dUYWNmQWJNZk5lSGdsZnNjcGZTZFJhc2dBYmZlMWd4YmthWmNHYUVhVWdjaFJiMGNkZVRmUmFsYVdjZGNHYTViMmJjYTJjOWZHaFpleGJZZVNiVGNIYlZiS2RFZEVmUmJSZEhnbWdOYVBiUWFtZmxhaWFiZm1mRmJBYk9oZ2hjZ2doSGJqZ01oTWJRZUZiOGNWZVVnbmNWZDBhVGNIYWxhQmhLYUZmRmVDZ0dkamgxZFlkSWhFZklmdWZPZldkQmNHaGRlQmVGZDFlVWZoaHhiZ2VVYkJkTmQxaFVmeGJ0aHRoWWcxZ29nUWZIYjFkb2NMZVdoVmRZZVNhZWRrZ2Rha2VRYVdiNWFLY1piSGNsaExmRmRIZ0VhZGRIYlVnMGZSZkFjamN3YW5oSmZYaDBjUWhCYzNoY2FHZEVobGVGYjFnUWJraFFiYWJEaFZoaGQraEpoUWhOYS9iY2htaFplMWRDZUhhSWZhYmVmaGhCZktnVGNVZ2RkY2NBZkZkMWY4ZmZhUmZGZThjYWgzZVJoUmVTYmtkNWMxYkVoWGNOY01mVWRYYmhjd2RWaG5nUWNQZk9oVmdKaEllTGFVYllkYmZMaEJhc2FHZk5nMmVRZHNoV2dBaGRob2JDYjFoOWJMYkVnbWN4aFNlY2FWaEpiN2VRZDJhaGJUaFNheGFSaHhiSGFSaDFmTmFHZlZmWmQwY2JnbmNaYXpoYmMwYllmemNYYWxkc2dmY1hkMGVvYlFhVWFrYVFnTGhjZUZicGVDaGJjMmZKaG1iYWhSZTFjcGdaYkhhTWNRaFRiRWMxZlJhU2VSZ1ZoT2hhYVhkUmhGaGVjVWcxZGVoVWNVaHBjT2RkZVJlRmN6YlRkRmZGaDRjY2dGZDRhOGFBYVRkc2RBZldleWdVZEphUmh5ZEViRGFDYm1ib2M0YUhlRWUxYlNoSmhFZjRlMWJFYzFiUWN1Z1JoM2ZsY0JjSmZrZ1FiMGdLZHdjUmVBZlBoa2NsaEVnSGNWY3hoWWFKZGljRWRpZFBnMmg5Z2JnWmcxZ0JmSGVBZmpkWWRlY1djUmMwaEtlQ2QzYmdhT2VTZzJkOGI1YlRiR2FrZFVhY2NrYjVkemhFY0VheGROYlVhVWZraFZhVGhpY0FieWJHYUhjaGJKZmZmQWNWYktnU2YyY2dhUmhaYVZjaGNZYWRmSGhCZkdlZGZCYUphMmZVaGtjQmU0aFRjeGVNYnFmRmVoZHNneGNPY0JlMGRaZFJnemFoaENiQ2VrYzBhNGhlYmtnZGdrY1FlV2E1YUtnWmFIY2xnTGdGYUhhRWRkYlZnQWVzY1plWGhpZUJndWJhZ0dmNWd2YlZkWGJVZWZjRWNoZ2RmZmNTZ2hnQmhTZVJnQWV0ZXdmV2FrZUpndmhZZm1jWmdwYkZmSGJJZFlkTWVrYUpkTWdIZjFlRmVVaEZoUmVvZWhhUGdVYXRnK2NQY2pjVmFCZFdobGVWZGZmRWZYaE5jTWZVYVhkaGN3Z1ZnbmhRZ1BlYWIxYkliVWVjYVVnWmVhaFBmbGVOYUhlVGVtaHBlVGdHYlJnTmN3ZkNjMWJsZldnRWduY3BlSGhaZUVmRmJ1Y1NkbWdSZHhnUWIwZUFiNWVWY0VhNWdEZ1piaGVkYWtoZmRuaFpjdWZiZnhlSWN2YlhnMGFGZkNiQ2ZnY3NiRGNRYkVkMGRIZVdjbGZwZENnYmIyYkplbWZhY1JlUmF5ZFRjbmRNZ1FmVGRFZDFoUmhTZFJmVmdHYlBlVGF4YVJiSWgwaDhmTGFFZEZnbGhjZWRnUWR4YXpiSGRsY2hkMGdXaGxlWmEwYURmMmd0Y1NnRmFIZEZnR2hFYjNkaGZUZ1RhMmJSZHFlVWN4aGtlYmZJZGdodGFFY1Zna2ZZZXloRGVqY2RjUGNFZVFndGh3Z1lhVWNJYVljV2V4ZTBmZGJUZlJnbGFXZmRhR2Q1aDJjY2EyZDllR2daYnhhWWZTY1RmSGNWaENiUmhCZ29kTmdXY0hjNGVsZkFhM2F0ZjZjWmZuZlFnVWZKYmdhWWE2YVFmMGNJaHlmRWZGZWdiRGJSYjJjVmZlY0dnSGVCY0JoZGhGZUZhS2hUYW5mVWZSZmNiMGV4ZFJlZWZIY0JjV2VkZEFkY2UvZEdmbGUwaGlkU2ZHYndmNWZRZWxmbGRrZWRhMWZOZExmR2ZuZndhaGVXYlZmWWhTZmVla2dkYWthUWZXYjVkS2FaZUhibGhMYkZlSGVFYmRkSGNWYjRhTGNWaG1kbGh6YmRlaWNkZG1hYmVHZGNlV2FFZmtoeGgxZ1NmaGNCZ1NjUmJBaHRod2FXYmthSmJ2YWFlMGJ4Y3BlRmRIYkpiT2FjZHhkQmRNaFRkVmJGaEpoRmZVZDVhcGZkZEJjaGF3Y0VmemNFZ0ZoSGJ4Y3dlN2RFYlNkY2RFZkdhQ2Z0ZXJoZmdIZlFjUGVhYzFkSWdVY2NhVWhZY1RnZWZGYk5mUGZaZkdlcGZUaFRnUmZOYzllRmNsZ2xkRmFBZ0dmRmN0Y1poRWZGYXVhU2htZVJhNWJTYnhhUmh4Y0hnUmgxZk5oUmJIaHhjMGViYW5jWmd6YWJjMGdaY25iRmFoYUpkTWJkZ1VhcGhHZkVmeGhZZExmT2JWaHBjZmFiZDJnb2J5YUljVmIwaGhiUWhBY3hnUmhXYUZlVmdSZ1ZkUWNsY09jZWdHZElmUmhjYUJlMWIwaEJoUWNJaEhhSmVoZzhjTWNEZVVkSmVxYWZoSGh4ZzBiRGUyZHRkU2JGZkhkRmZHYkVkM2ZoZ1RjVGcyYlJicWhVaDFhd2VUZmJhUWd0ZFJhQWVsYW9hemNGZUdmb2YrZ0xmMWF0aHljZWFWYWNiSWNjZVFjd2RMY1JkQmJrYktiZGFEZW9jK2dPZWpjeGhJZUdjRmdjaENiWGZIZWxiZ2hFaEZiSmhFZ0NiM2RCYmFjUWJtYzlmaWJaYm1ia2hVYWNla2c0ZDhmRWFGaEZmTmNXaFFnQWRWYlVjbmJWZjBlVGVIZWxhQmZLY0ZoRmFDYkNkM2VVZlBmYmFWZkpoUmRjZkdmTmJFYWRkQWFKaHJmQmVoZjFoNGRTYWpkbGY0Y1VlMGU5ZGtiYWZsYk1jWmNFZDNkQWJMZldoVmdZYVNjZWFnZTlla2ZYYUdiNWVDYUliWGZsYVhjQ2FIY0ZhSmdGZ0VjMWhGZVZlbmZ3Zm5nZGJtZTFoeGNXZUdlY2FlZkFlVmY1ZjFnUmR4Y0FnR2JUYVFkSmRyZGNoRWdKYXZoWWNtaFpocGJGZEhjSmdPYmNieGJCZk1jVGJRY01hTWRRaFJhc2Y3Zk9kaGhoZDRhYWUzaFJmUmdTZGtiNWgxZ0VoWGJOZE1nVWRYaGhid2hWY25kUWNQZllld2JaYWNoT2JCYlVjZGFCZXhhSmZmaGRiR2RwY09jR2FRaFZnbGZIZ2thcGZEZkVjbmF4ZEhlTGVFYmhnaWVZZEdkUmU1ZVNkeGdSaHhiSGVSYTFnTmFHaFZkWmUwYmJmbmNaZXpnWmZ4YUlidmNYYzBnRmNDYkNlZ2NzaEJoUmNFZVFiV2hjZUJoSmNDZGNjWGV4YzRnYWFRZVZka2dSZDNmOGU2YlRkRWExY1JmU2RSaFZoT2VhYVhlUWVZZGNhRWdGZzBmVWJVYnBmR2FJZFZha2M2aEhnMWQ4Y0hoTWFVYVZhbWhEZDNjWmdTZEFmbWRSZVRoQWhHZzFnVGZTZFdnUWdsZldmaGJVYjVjY2FBY3RhWmJWaGhnSmU2aFJoMmJSZ0JiYmVrZnBoa2hlZVVlc2hjZUpmVmdWaFVoSGRoY2NmcGNOZVhmcGh1Y2NiM2FKYkdlS2hCZVliTWRVZ21idGZLZUFnVWhSaE5nQmgxYXBmYWhRZG1kOWJpZVpibWhrZlVmY2ZrZDVoemdFZEVieGJOZFVjUmUxYmRmQmd6ZXBhZWRHY0hkQmZCZWRiRmNGY0tiVGduYVVkUmVjYzBheGRSYmNoV2d0aDhhZGNBYzlkcmdVZ2hjUmF4Z1JoaGdOYzRkVWJ4YkpjdGhaZ25na2FaYkVjM2ZBYkxjV2hWY1llU2NlaGtjZGRrZFNnU2NaYkVkTmRDZ3NiRWRRZERoNWVKZlJjQmIxaGNlV2NDaFlnaGNJYWpnSWg3ZUFleGZWYWZiVmhRZlFnaGNTZWdkMWJTY0RnQWNVZ2dnQ2RBZzBoN2NMY1RnSWh3ZVJmRGZkZkFoSWJWaDhiWWVIYTFhRmVVZEZlUWRnZDhiT2VsZ3Nha2FDYURic2VmaFNna2ZZYmhkR2dIYk1lWGZlYTNkaGF3YVZlbmdRaFBmYWMxYUlnVWFjYlVnWWdUZWVkQmNvZkpiWmVHY0pjYmdFaFVjZGR3YURna2hSYldhQmFHZTVjT2JhZ0VhRmYrZ1NkbmhsZ2tmU2gwZ0JiNGRGZkJiMGdmZ1hmQWNJZ2hkUGFEYmhhemNPZXdhNGJ1Y1JjUWVsZ21lZGRVZ29hUWZVZ2tjUWdMZmNmRmdwYUNlYmYyZEpjbWNJY0ZnSmF5Z1JkaWhjZFFjVWZsYkJoUmdXYWdmZGVIaGFkU2U4Y3llY2RFZUZjMGZVYlVhcGhPZmRmUmdGZ3pkVGNGaEZnNGJjaEZmWWNpZFRoamRsYVNjUmRuZUZmYmRFZnlhd2NiYkJoamFkYmtkTGdGZ2dmRGFZZkJlQmR6ZVZnaGRKYjZiUmgyaFJmQmRiYWtocGhrZmVhVWNzY1VjY2VSZzFhVWZDZHhnbGVlYVhibWQ1YTJnY2YyZDlkR2ZaaHhhWWdTZlRhSGFWYUtkRWRGY0pjRWNDZjNnQmRTYVNmamJzaHFjTGd6YW9oYWFEZVFkOWVqZEFoRWN4ZlFnVWNSZzFoZGFCYnpkcGQ2YVpjemhGZVNoWmFsYmhkR2NaYUhmVWFSZmNoMGd4ZFJkZWdIY0JmV2JkYUFmOWVyaFVnaGZSZXhmUmVoZU5od2RCYXdjY2R0Yk9iVmUxYW1oVWFtZ01oWmhXYlVjc2ZTaEtjRWc1Ym9nYWYyYzVnS2daZkhhbGFMaEZoSGFFY2RmSGRVYTBkWmRWYW5mUmZ1aGRobmZOYW5kRmhHZmNkTGFFZmhiZ2I5ZEFnMGhOYWNjT2MwZXBla2ZRZmthdGdqYlNkR2JaY3BnRmZIZ0pkT2djaHhmQmRNYlRmVmNGZkpnRmhVYjVjcGNkZ0JnaGQ0YkZoVGF3ZFljR2hVZUFjS2FVZEdoZGhVZVVoV2hWaHdkQWRqY3hkR2RPZUZheGJyZU1lRmFjZ0ZiY2JWYzllbGZaaEdlcGdUZUdhUmJOYXdnQ2IxZ2xmV2NFaG5jcGJIZlpnRWNGZHVnU2ZtYndhdGNBYTFmMGhpaEViMmFJYU1hQ2JFZkJmMGdjZDNoWWVoaFpna2JwZk5kRmJoaEpjTWVkYVVob2NRZVVma2JRaExjY2hGZ3BhQ2NiYTJnSmNtaGFiUWFkY2dlVGVtZTRoTmhUZ0JhbGZZZVlieGNWYk9nYWZYZVFlWWJjY0VjRmcwYVVkVWRwYk9oZGFSYUZnemhSZ1hodGQ0Y2NiRmhaYjBiRGUyZHRnU2NGZ0hoRmZHY0VmM2hoYlRlVGQyYlJmcWZBaFZneGRIZ0piVmZrZVhnVmdrY1ljeWJEZ2pjZGVhZ1JlRWZwZ2tmZWNVYnNjVWhjZFJjMGFkZFRhUmNsZldmZGdHaDVjMmhKZzJiOWhMY2ViaGFZY0JhWGhtZDVjZ2dFaEZnSmVFZENoM2VCaGFjUWFtYjlhaWFaaG1oa2NVYkxkMmZSaHpjRWZFZnhoTmFVZlVma2FWZVRlbWZsYzBmR2ZIZEFoWGVOY1FkTmFLYUJmM2RVY01hY2YwaFFhRmdNaERoa2FGZWVobmRBaHFjUmdnZ3hmeGFXY2dhOWU0Y1FmbGNsZHRoYWZnZDhiWmRSZ3pmaGZDZENhbGhoYXRhT2QxZlJlMmZUZFVkUmJLZlpmSGhsY0xkRmNIZ0ViZGJIYVVjMGhaYVZnbmNSY3VnZGhqZlpkdmJXYjJnY2hlaFJlZ2VRaDhjR2FSYTRodGhCZFJocGRtY1dkbGI1ZXplWWVuY2RjL2dIZVhiSWJTYWNiMGRRZkVjQmVBYUpiSGFhYWdlOWQ1Y1pkQmdSZmFnUWZYaFJoUmFTYWtmNWExaEVhWGZOY01hVWFYZ2hmd2JWZG5oUmFBZmFhMGQ4ZVVjZWVRZThoVGhaYmtoMWVSZVpjRGU1ZGFjR2RVYjlnd2RBYnhheGJXZERnbWdaZEhhYmVGaEpiOGJTaG1jbGU1ZUhleGUxZjRlRWdUYmRjTmJHYlZnWmYwZ2JobmNaZXpmYmcwYVpibmVGZ2hmSmFNYmRkUWVJYVFnVGYwZFFkRGhOaFZjcGRjYmNiWGh4ZG1lUGJSYjFheWZFZ25jTWRZYkJjVWQxY05oVmZSY1ZmR2FlZW1nWWhZZGZiVWJFYWdhV2VFY05mVmdYZ3hlRmF6YlRmRmZGZTRlY2hGZFpmMGJEYjJodGZTZUZoQ2ZNZURlUmN5YTBjQmZBZldnUmhpYmVkUmNrZFRoY2FBZ3RlWmNWZWhlSmM2aFJkMmVSaEJiYmNrZ3Bka2JjYVJnOWJjYk9nRWQ0Y1RjTWNsZGhnR2VaZEdoNWdyZmNmM2dsZVRjY2hnaFVoSGdUZkhlTmFLY1diRmJ0ZUljSWNYZ0JiYWVRZW1mOWZpZlplbWNrYVVhY2draDViemNFaEVjeGJOaFdjUmgxZmRoQmZ6Z3BlNmFaYnpjRmZRZVlibGJGZVhlVGhqYzBjUmJiZFZmSmhQY2VoR2dGZkFmZmNRYU5mQmVVZWhiUmR4YVJmaGROYzRjVWMwYzlka2ZhZ2xkTWVaZkVlM2JBY0RkRGZSZzVhYmRLYVVja2ViY0FlSGQxZFlmWmJHaFJnTGdBZ21oUWdJZkRibGFnaFpoVWFIaFFkaGRmZjNiOWdGZ1JmbWVjaFdnRWhrZHhnMWJTYWhiQmRTY1JlQWR0ZndhV2VrZEpibmNOYmljNGhnZFJiM2J3ZnhnTWJnZ1JhVWhUZVVkeGhKYldma2U1YzNiYWFnY1pid2JVaEdkSmVZYVJhbWhSZTFiRWNYYk5iTWZVZFhoaGJ3ZlZmbmFRYVBlYWYxYkllVWVjYVJiSmdiZU1oUWVCZGxoWmRHZXBhVGZHZlJnTmV3Y0NiMWhsaFdnRWFuaHBnSGhiaFZncGJFaFNibWdSZzVkU2Z4YlJkeGZIZFJnMWFOaEdnUWV0YjloWWFsYXhlemhiYzBmWmVuaEZmaGJKZE1nZGJVYm9kUWFXY2dmd2RGaElmQWFnZE5nT2N5ZjBkeWVNYUVoUWczZFFoRGJCY2NmQWN3Y01kVWFTYlFjaGFPYkxkeWJGZVdkTWZ4aFVoOWhIZWdnUmNPZWZlUmJoYnpiRmQzZ3RhNGRjaEZhWmUwY0RhMmh0ZlNmRmRIaEZnR2NFZjNhZ2JCZENoamVBaC9oQWNWZGNhVGVQY2thNGNPZ1ZhbGZwZXlkRWd5YndoSWhQaFVlUWJiZE9hRmJzYUVkZmZSZzFhSmhCZ1ZlQWFGYmVkaGdFZzNlWWNuY2xkS2NaYTBkSmNhYUJoU2RaZkVkYmh4Zk5nWGJHYVhkeGJhZkZmaWFjaHJhTmdXY2RkcmNNaDFicGNyYkdiVmRkY25lVWdVaGtnVmdUaG1jbGIwZEdmSGFCZEJhZGNBYnhmRGFRZGxhOGVSZGNmMGh4ZVJoZWVIZkJkV2VkZkFkOWRyZldmbGIxZHhnV2J4Yk1kRGRMZ2tlWmhvZlFoRmZNZVpnRWMzZEFjTGhXYVZiWWVTYWVla2FkZXNoQmdHZDVkWGJaZkRoOGdlaFdlamhKZUpoVmdBYUpmWGdWZW5neGhuZGRmaWRoZkZiUmVtZWNlV2JFZmtjeGgxZVNmaGJCZlNmUmVBZnRkd2NDZEFnY2g3Y05nemhRaG5oRmhEYnBiVmVXZVJhQmhNYVRnVmRGZEphRmJVYjVicGhkYkJhZ2N0aFRmemZVZUJlR2RnZUlnc2RHYlNkRmJBZ1VnVGdGZzVlWGgzYmdlbGJhZjFjSWhVZmNhVWdZZVRjZWRGZk5jUGFaYkdndGhiZVRjMWZ3aDVmVGgxaGxiR2RFYm5hdGdhZmViVWdFYnJmU2ZtZUpkL2JTZ3hid2FsaEVhMWVnYVZmU2FSaGtobWRPYmlhVmR6aGNia2NZYmlmSGR4aHRmWGNYaDBjb2RRYlVna2ZRZkxoY2hBZWRkTGhaY3pkWWV1Z0llRWRkYjdoVmFWY2tiUWNUaEViMWdSY0ZhQmFsZmtiYWhYZlFlWWhjZUFiY2JoaEhkd2ZrY2FiUGVGaDRhOWRUZkZja2dzYWZnRmJZaG1jQWcyZ3NkYmRIYVhjRWVkZk9mWGFoYVRlVGMyYVJlcWZVZnhiRmVWaEphVWVVZGFnQWNsYXNhMWVDY1dlUmFKZVBnRWNOZGtkSWFtaEVmVWVjYlJjMGRkZVRiUmJsYldiZGJDZWdhamZQYlNld2FTZExnbGdsY2NkVGZEY0JlQ2dSYUZldGZFZVVnRmZwZ2FjUWdtZjllaWVaZm1la2FVY2Nha2M1aHpmVmRnZk1kZmVVY1ViRmREY0RhemF0ZDBkU2NuaEJiY2FkZUNjb2QzY1FjbmdWYllhY2QxZ0ZlUmFhaEhleGVXZU1kUWI5YzJoVWRrYkJjL2VDZmxlWWIyaEZkQmNzZ3NmY2hWZk5oY2FFYTJnNGVMZkVnRWMwaFNmTWQwZXhjdmFTZ0dlNGRSZFRjbmZsZ0xoRmhIZkVoZGJIZFVoMGZaaFZnbmNSZHVhZGJpY1VndWZGYkdkZGdaY0VibGVGaDFkSGNoZTRhUmhEYUVkb2FpY09hUWEwZ3JjSmR3YWNmOWJIZERjdGdIYWFoRGJwZ01iVGRWY0ZkSmZGYVVjNWFwZWRkQmRoaHdmUWFYY1JkQWRXY0ZhWmIxZkRjM2RNYkRhZWIzY2hhd2hWZm5lUWNQZ2FiMWJJY1VnY2VVY1liVGNlZkZnTmFQZWVjMmhvZUJlRmcwZE1kbGhXYkJoRmNlZlhmWGFOaHRmWmRFY0ZhdWNTZW1lUmQ1aFNneGdSZnhiSGRSZDFmTmJHaFZhWmJ1ZGJhbWNSY2plZWExYzVibmFDZEJmSWZEZVhmMGFvY1FoVWZrZ1FiTGhjaEZncGJDYWJmMmZKaG1hYWRSZFJieWRVY1hkTmhDYVFiaGUwZUVnR2NsZzFlR2JlaEdkMGVLaGNkQmUxYTBmV2RRZlZoT2VhaHdjOWd6aFdlbGJoZDBkY2VFYWRkbWhGYTJmc2VPZ0ZoSGJsZlFiQWNIZGhkVmNUZXljdGNqZFdlamZNZlRoY2RBZXRiWmJWZGhnSmg2ZlJjMmRSZkJmYmJrZXBka2hlaFZmRWNVaFpiQWVnaFBoVmJBYjllV2ZhaG1mNGg1YmNoemVNZWFlWmQxYWthU2JVZW1jaGNLYUJlVWZWYlhnSGIyY1Jmd2NRZm1iOWNpZFpmbWdrZVVlY2RrZDVkemFFY0VkeGhOYlVhVWZrY0thVGhqY3RjNmJTYkNiVWVTY1BkRmFsY1lnWGhHYkVmUmZMYzBoeGhaYU5nM2NCY0liYWdnZTliNmVRYUJnMWQ5ZFJjZ2RKZHFlU2QwZzhkNGNhZ2xkc2ZSZlhlSGZBYlZmUmIxZVlkRWFjZDBmZGRpYlFnWGNoYVpmYmdYZlZoTGJCaFdoTWNGaEhjUmRFYVpmWGJtYkphOWJkZG5lVmV2Z0NlV2g0Y2ZoT2ZFZ3hjMWVTZ2hjQmJTZ1JkQWd0YXdjV2VrZUpmdmNZY21iWmdwYkRmbmNKZ0dnT2VoZHRjSGRRY1hidGVKZEZlVWY1ZnBnZGRCZmhjd2hRYVhiUmFSY1Nla2E1YzFoRWNYYU5iTWRXaFRlZGJ3YVNjM2VRZVpjZmhraGNkSGhaYjBnWWZZY2VhRmJ0Y0hiYmdIZHRmRGVDY3djQmJ3ZERmVmdrYVphR2gzZnBnYmdlZEVmRmIvaFdhbWUxYzVkRmV4Z1JoNWNEYkFiMWRmYkNmbGRaY3liYmJpY0piOWVMZUFnNGdtYVJhSGNFZkRiTWVRZDlleGVCZWtheGVDYWVhVmVOZUxoWmFtaDVmTWVhYlJjUmZ5Y1RjbmNNZFFiVGJFZTFnUmFTZVJmVmRPYmFjWGZRZFlnY2VCYk5oNmNBZlJlOGVkaFBkUmJsZVphVGdGYUZmNGJjZ0ZjWmcwY0RlMmV0aFNiRmZIZ0ZjR2dFYTNlaGdUYlRiMmdSYnFlUWhRZTBoRGhjYkZkZGhaZ1hmbGgxZDZjV2FYZ3BkQmNmYzFiSmV0Y2RiV2NFYlVhY2ZSaDBoZGNUZlJjbGdXaGRjR2Y1YTJoY2YyZDlhR2daZnhkWWFTZFRhSGRWZWJlQWdrZnBjRWhWYTNoQmJTYlNiaWVCZWljZWJIYWNnVWdZZDFjeGQ2YUVkRWVwYk5hUmcxZW9hY2VRZWtlTmUwZkdoSGFCYkJkZGVGY0ZmS2ZUZ25oVWhSY2NlMGh4Z1JhZWhIZ0JlV2VkZUFiOWI2Y1FjQWZ4ZnhkR2VoZE5od2NXYndhQmFrZGRiRWgwYlpoQmNYaGtiTGJYZjFkWWFFZWFoVWc1Zm9nYWgyaDVnS2haYUhobGZMZEZhSGRFZmRiSGhVZzBkWmJWaG5oUmJ1Z2RnbmdOaHZlUmVuY1ljRWFDZGtid2ZwZ1NhaGJoZ0VhVmJ3ZXRhMmVXYmdnMWZtYlNmR2JaY3BiRmhIZkpjT2VjY3hoQmJNYlRjVmZGZ0pnRmhVZDVjcGhkZEJlaGY1ZlNnR2M5ZzdnU2FraDVnMWJFZlhoTmhNZ1VmWGFoaHdnVmJpYWtjbGZhZDFoSWZVaGNlVWdZZlRjZWRGZ05nUGZaZkRjZ2ZXZFRiVWdZZGljUmdWZmtjWWhWZ3liMWVIZUVlUWJnZWdoSGNuZXdiWWVHaFVnWWZ3YVJmQmNVZGZoRWhFZzFoZWhiZ25mWmR6YmJkMGNaYW5mRmFoZ0lkUmVYZDBkb2RRYVVma2JRZ0xoY2hGZnBlQ2FLaFRnY2dvYktia2ZBYTdmQWNUYTBhUWdBZDBlVmNZY1NkVWI1ZmtlYWJYYVFiWWdjYkViRmcwZVVmVWNwaE9lZGZVZk1iMmZHZUFiUWJxZlBkbGRaZG1lRGEzY1pmUGhGZURlQWRVZVZoQ2gwYmViQ2ZpZW9nK2hBZUJlZGRmZk5lVWFVZWVmQWZsaHBhUWZSYzJmUmFCZWJoa2NwYWtkZWJVaHNlVWFjZVJlMGJkY1ViaGhrZFllTWZUYWxkMmRQaEdmY2RIYk5lVmdGZEhmQWJUYUFnRWZSaEFhRWcvYUdjZ2cxYlRkVGNEZW9meWhJZWlhaGRBZE5kMGVZZnlmUWJnZXNhWWhIYkFkeGViZUdlamVvZlBlQ2hBYzFlSWRlZWhiVWREZUNlVGVCYUNkSmUwZ1JjWWZVZW5lQmJXZ2RmQWU5aHJoVWRoYVJleGhSaGhkTmQ0ZFVlMWVWZ2tjUGhoY3RiUWhRZ0hjQmFDZEZid2RWZUdkT2F3aGtmbmRCZUNjRWZNZVpkRGdaZWhoRmJIZEVlZGZIYlVkMGhaZFZnbmZSZnViZGRuZ05jdmJXZVdhZGhBZlhoUWdVYnhiU2RsZ2hoY2RCZDBnb2U4aEZha2FvYTdnS2hpYjhmNmFHZEhnSWhQaEllVmhjY1plQWhCZFFkSGdRZVJhMGhTZlpmR2FWZzVhYWEzZVJiUmRTY2tnNWcxZEViWGVOY01iVWJYY2hld2hWZW1kNGhQZkpnUmhkYkRlY2VRYWtmYmNPaFFmRWVJYk1jU2VjY1diVmMwaGNlamVjYkVha2dyYUdoMmFGZ3RiWmhFZEZmdWJTZW1mUmI1YVNmeGJRZXNlTmd4YzFnTmFHZlZoWmgwZ2JjbmJaaHpiS2FSaE1kcGFWZ1VlWWdGZE9lZ2ZRaFFjR2drZnhoZmRlYlZlb2NaZFJmV2dKaG1iYWRSZ1JkeWhUZ25nTWFRZ1RlRWcwYkRkRGFFZUVhYmFPZ3phb2ZZYmVhR2N0ZjBkVWJVZ3BmT2hkZFJnRmZ6Z1RnRmVGYTRlY2FGYlpnOGVXYXloTWRiZFJkM2U4YlZoVmdqaDBhWGhUYTNhbGNxZkJmeGVsZWFkUGNsZGdmTmhGZTFkd2g1YUFnaWhzYkhjYmJnZVJia2RaZmtldGZBY2ZjMWg1ZVJjQWhsZGNlVGJmYUdkZGQyYmFoV2Q4ZUlmYmUwZUlmYmRSaFhlbGFnZ0VhRmdKYUVmQ2QzZ0JjYWVRY21mOWJpZ1pjbWJrYlVhZWFoYW9nN2ZXZ1JjOWhEYUJnMWdnY1ZkVWUyYWtoZ2dVZERha2hTYmVmZ2hJYlBlQ2V6aEVkZmRNZUFkQWhlZ05iamVWaGVhZmVRZUVjcWhGZWxoQmY1ZUZkUmRwYTJjRWZnZ3NoZ2FZZWhmSWFRYUdibmN3Y2hiV2FWZFlkU2hlZWtjZGZraFFhV2g1Y0thWmZIaGxjTGRIZENkVmNWZVZkQmM0Z1hjQWhHZVpkdWRhZzNmTWU3ZURjaWg1YkZnSGhCZThld2ZEYTFiUmZjZkJlMGJjZi9jRmFBaGRmbmJhZDJjZ2hvZFVoRGZaYkdiTWFoZWxoRmZRYlhldGJKZkZlVWE1ZHBjZGhCYWhnd2ZRYlhiUmNSZlNla2g1YjliUmZUYnNhRmdBYW5iWWJtYVJmWGZRZlNlYWJ3ZVpmY2FPZ0JlVWZkZktheGhZaEtoSWVHaFFkUWdWY1Znd2ErZlRlbGZGYWZnR2MzZFpmdGNaaEVjRmZ1ZlNhbWNSZTVoU2h4ZFJleGFIZVJkMWNOZkVnUWNJZDhkSmN5YVZiOWRPaFZkSmNuZENheGJJZFlhUGFRZk5oRGNYZ0JlZGdPZk5mUmI1YU1iTGhDYTRjcGFKZzFiRmg2Z1JjM2UxaERkR2RRYThmRmdHZDFhUWZOYVBlWGZ4Z0xiZWVVYmhoNGJlaDBkcGFPZmRjUmdGZnpkVGVGaEZjNGhjY0ZiWmEwZkRjMmJNYUdmWGJEY2diVmRIY1Nod2djYUdjeWFVaG1jTGdGYVZhV2ZQZ2dldGNFY1ZlZ2hKZXpiU2cwZzVoQmJiYmthcGZrYmVlVWVzYlVjY2JSZjBhZGJUZlJnbGhlaEllQ2hZYi9oSWdHY0ViTGZJZ2xkdGRCYkJiU2Q4Z1BkRWNFYjlmRWJHZzNobGJXZmFhR2Q5ZmlhWmdtaGtmVWFjYWthNWF6ZkVnRWV4ZE5mVWJVZkZlQmNCZ2loQWRuY0ZjamgwZUVnT2dSZzRkWWVGZjNkVWFNZWNld2ZJZkVmTmVEZ3hmZmhlZ0NlVmRyZlVjaGVSZHhhUmRoY05jNGFVZjBlOWdrZGFlbGJOYk5jV2V6ZGxjWWVjaDFlWWhTZmVha2hkaGtiUWNXZTVmS2FaZUhlbGdDZ0RjMWZzYmRiSGVVYzBnWmVWY25hUmN1YmRnaWI1Y0ZlUmhtZ2NkV2FFZmtjeGYxZVNjaGNBZUVhQmZWYmxld2RGZkVoSmN5ZVlkaWM5ZWhnQmRYYnRjQWVCY25ka2NpZk9hVWhkaGRjR2RXZFJocGZkZEJkaGF3ZVFoWGVSZ1JlU2RrYjVmMWRRaG5iTmJSaFVlVGNaZjRlVmhHZ1VjZWNmZzBnSWZFaFpibGNjaEhhYmcwZ3RkYWhkYUhmMWhIZ0Rjd2FwYWtmSGJFZkJjSGRFYUhlTmVMZFRka2JGY3VkU2VtYVJhNWFTY3hhUmF4ZUhiUmYwZk1oR2NVZXRoMGdJZEhjNWN4YmZhbGVKZDNnQmRBYnRjWWNZZjFkMGhEaFJoRmFJZVRmYWJVZDFjU2hmY25hdGF4ZmVod2VOYndlUmgzZzhoNmRUYUVoMWVSZ1NoUmNWZ09jYWJYaFFoWWNjYkJoUmMwZlRmRWVvYUFiZmRSY05iaWZXYmtjRmdoYlplVWg1aGpoRmRuZGxlTGNCYjJnaGdVZ0NjMmN0ZkthWGhuZ0pkN2VVZ1JoQWRmZldjZ2d0Y1pnVmFoYUplNmhSZzJkUmFCYWJka2ZvYmliZWJWZ1llVWZQY3hnVWRmYlZlQWI5YURoWmdIZzVia2RhYm5iMWFTZGRjUWNRZ0toV2YyZDFiWWRDYUVlZGhUZ0VhbmdKYVRhVGJrYlZlaWVaZG1ia2JVYmNja2Y1YnplRWNFZXhnTmVIZlVia2hJaFRnaWFkZzhoR2RtZUpmWmZZaDBiRmNiaFdnV2JJaEZnWmJsZnhhQmdhZldlSmZBZVpiQmM5YTVmUmNBZVZnemJUYXdnaGRTaFVhMGQ5Y2tiYWdsZ01jWmZFZTNhQWJEYkZlbGNoZENnS2FBaGdjd2dEYWpkb2NUY05iRGF4ZkZkWGNUZjlkVWdTZ1VjMGRFZVZmamN4Zm5mZWdsYWxjdmFSYW1oY2JXZEVla2F4ZTFmU2NoaEJnU2JUY0VhUmYrZENkaGJBY2diTmZpZ2tlOWZUZ1NmSWdMaGZmVWdVZ2NnQ2JSZ0FkZGJVaEVnNWEwZGRnRmg0aGxkRGV6Z2NkRmJBZndiRWI3ZUVoWGJzY1llV2ZIaGdocmRmYUhoUWZQY2FjMWNJZVVmY2dVaFlnVGhlYUZlTmJQYlpiRGR3YVNoU2R4aE1kNWNCYTNlTmZXYUVmbmFwZ0hlWmZFZEZmdWJTaG1lUmY1YVNieGZSYXhnSGJWYUpjTmRCZkZnWmQyaFBjU2hJYWhlSmRnZWdkZ2ZGY0JlSmRSY2FjRWNwZ0VlQ2d4Z1JhT2dQYnhheGJDZk9hM2ZsYk1lYWNSZ1JheWZUYm5kTWVRY1RnRWgxZ1JlU2ZSYVZnT2ZKZ25jUWFlZWRna2RGZzhkV2VSYzViT2FhaEJoRWIyZ1JnQWVWZ3hoZWhWZnBiMGRCZ3lnUmdTZUNmWGJGYkhhQWFuZkZjZmFUYTJhd2RqZlVld2NRYlRhY2VSaHRnUWdYZXhmNWRRZlJlMmFSZUJmYmVrZ3Bna2ZlZVVlc2FVYmNiUmEwaGRmVGVSZ2xoVWNJZ1NjQWR5Z05jaWJrYlBlS2dWZU5hV2dUZm5oVmJMaERmVmZJYlFoVWNpY0FlZmdEY1NkbGVpZEJiemh0Y0dlTWF4aGNkUmJSaFFkb2FMZ0ZhQmZzYVZiU2VHaDljZWZHZ0hmQmdCaGRiRmdGYUtjVGJuY1ViUmNjaDBkeGVSYmVlSGNCZ1dnZGZGZXRlcmVHZTFkb2ZpYUVmbGNJYjJiRWVBYm9lcmJMZ0ZlTmU0Y1FkU2RKYUtiQWdEZlJjSGhQY0FjRWRoZ0VmMmU1YU1kWWVsZE5jTGRGY0hkRWdkZkhhVWYwZFpjVmRuZ1JidWhkaG5mTmJ2ZFJibWVjaFdnR2RrZFFoOGVTaGdiMWZTYlJkUmd0aDVnVmhrYUplbmFOY21nWmIwYUZjRGh3Y0xmSmZCZ0FkNWNCYUJjOGNkZERmU2U4ZDdmSmdsZmtmcGNTZVNhQmhZYVFjMGJkZnVlT2UzaE5hTWRVY1hoaGN3Y1ZhbmRRZ1BlYWMxZklnVWRjY1JkQmFTZUtnbGRNYkhiWmFIZmRjVGdDZlJnOWJhZENmMWNsaFdkRWhuZnBhSGRaZkViRmd1ZFNmbWNSZDVjU2R4YlFha2ZIYVFlQmZOZVRoVmRnYTRoS2V6ZWdkMGVPYndjNWNyYVBiQmhKZE1hZGRVYW9jUWFVY2tlUWFMYWNnRmNwZkNhYmgyYkpnbWZMZnhhUmZ2ZlRkamFzZFFlUmcwYjBkRWJVZWpmOWVPZ2FlWGZRaFloY2dFZEZjMGVVaFVncGdPYWRiUmdFYTZmQ2RsYkZld2NZY0ZoWmRwY0VobWJzYkhiSGZYZUVoVWRWaGlld2ZHZ0hoU2NwZHFlQmgxZEZkYWhJZnhkQmd6ZVZhaGdKZzZmUmgyZVJjQmdiZmtjcGdrYWVnVWZzZVViT2VGYnNoZGhSZFRkTmFXYWRhR2I1ZDJiY2EyYTlhR2FaZnhlWWRTY1RmSGhWYUtiRWhGYXBmTWNYaHpkZ2dUY0VhV2FFYzJlS2RUZjFmVmVQZGplRWUvZ1ZlUWRKZ05kV2RsZFFjVmJHYjJnQmU0Y01jbmVCYkJjZGRGYUZkS2hUaG5jVWZSYmNnMGR4YlJoZWdIY0JhV2NaYUFlOWcyZVRoeGJRZWxjRGdsZm9icmRYYVFnSWNoZUpld2dCaFFmU2RUZ1VjTGZYZjFiQWc0ZWVha2NkaGtkUWZXZDVhS2NaZEhibGZMY0ZjSGRFYWRjSGJVYzBnWmRWYW5ld2Q2YVBnamZvaDhmU2JDZXBoVGJYZndhTWduZ0VoeGFCZVBjUmZFYlJod2FSZFVmSmN0ZVlmR2ZaZ3pmRmhEZHRkT2ViaEJkQWVDZENoQWdaaEphWWRBaGNjbmNJZEFkQWVSYUVneWNZZFFhRWgwZ1pibWNBYTNkcGJNaFNoM2FnYytnRWR5ZU1mUGNPZFZjb2ZIY1lhMGE4Z2FmZGRIZ2xoUGVaZUdlcGVUZEdhUmhOZ3doQ2IxYmxnV2JFY25jcGJIZ1pkQmJVZ21nQWF6ZWRoM2JCaGxlRWc4Y1RhbGRRYlhiWGZGZFpoL2NiYmliTmN6YWNlMGVaZDBmQmRCZXRobWhkZ1Vmb2FRZlVha2RRZUxnY2JGZ3BmQ2FiZjJkSmdtaFljRGM1YXljVGJuaE1jUWhUYUViMWZSYlNoUmJWY09iYWJYYlFlWWhjaEJoTWd4Z0JmUmE4ZGNoT2Z4YkZhN2FaZWxjRmc0ZmNjRmhaYTBhRGQyZ3RiU2NGZEhlRmJHZ0VnM2ZoYVRkVGYyYVFkbGZlYlJna2ZUZWNoQWN0aFpnVmRoZ0poNmNSYzJjUmJCZGJoa2ZwY2tmZWJVYXNoVWhjZVFnSWVkYVJmVWUwaGViUGVUZzFiNGhQYmlib2JMYktmRWJSYkxhVGhIaDVlWGhFZUFlWmhOYUlmWGJCY2FoUWJtZDlkaWNaaG1ha2ZVaGNia2Y1YnphRWdFZHhjTmdVYlVna2hWZVRlbmdOYTBnVWZWZHBmQmhkZEZjRmNLZVRibmVVYVJiY2YwZ3hnUmhlZkhlQmdXYWRnQWU5Y3JiVWhoZlJndWdSZGtlY2F3ZUdkaGd4aHFkSmZ4YlpiVWNYYUNkSmJTYVZld2NWZlhmTGFrZDhod2RUYXphMGVmZEpiamRnZVpmUmdqYUJnRWJGZFZkMGZWYVZlaWRGYm5hZWZuYU1oN2FEaGllNWRGY0hlQWdFZndmQmQwZk1iYmdIZ2tmNWQ1ZGNiRWdKZXZmWWZtZVpjcGhGZEhhSmdPZGNkeGFCZ01kVGhWZUZnSmZGZlVnNWdwYmRhQWJKYXdoRmFYYm9nU2dCZFJkNGFzZkdhU2VjaEVlR2FDYnRnK2ZHY3piRmFDY0pkQWRCYk5kZmdVZlpiSGZNaEJob2NjZmFjaWNjZldlVmFFZUFnNWdVYlJoeGVhZEVobWNwYkxnWmhCZ1JjbmFSY2tkNWQ1YlNmeGhSYXhoSGFSaDFmTmRHYVZnWmYwY2JobmRaZnphYmEwZFpobmdIZWtlWWZFaFBoQmJrZmViSGh3ZEZlR2ZJaHhnTWVZY0tkbWZKaHRkZGZCYlFmbmJSYzNhOGg2YlRiRWcxZ1JiU2VSYlZmT2ZhZFhlUWhZZGNiRWFGZjBlVWhVY3BjT2VkYlVlVWE3YUJhUWFKYVNlY2FGaFpiMGJEZTJldGNTYUZiSGNGaEdjRWgzY2hlVGNUZDJlUmVqaFNnRGRNZlRjY2ZBZXRmWmFWYmhlSmE2ZFJhMmdSaEJkYmVrZm9ndGNQZzBoc2djZ0poVmZWZ1VnSGhoY2NnYmZNYlNmTWNsY09oamNVY0RkWmJ3YWdnU2ZYYUhheGRLZVNoM2FoYkVoQ2MzZEJlYWJRaG1mOWVpZFpobWVrZFVhY2JrZzViemFFZUFiTmFuZlViVWVraFZiVGFtZWxhMGFHYUhmQmFCZmRkRmdGYUtlVGVuZ1VoUmNjZTFkTmJSYWNoQ2ZRYmVjUGZWYXhnbGNIYTFhRWY4YkNoVWVFY2hkVWYwZ1JlNWhhYmdjY2JYZlFiRGR4ZkNlR2JoaE1oYWZhZWtodGdrZ1Vibmd4ZEtoYWJYYWtoZmRYZkRhaGFPYkVod2ZCZmNjR2Z5YWNlbmFMYURkWmhtZ1RiMGEwaFdmRWNrYXhiMWdTYWhoQmZTZVJhQWh0YndiV2drYkphdmVZZ21iWmJwaERnbmFJYkhoV2NSZEJhTWNUY1ZjRmRKZkZlVWQ1ZXBlZGJCZWhld2ZRaFhoUmdSYlNha2Y1aHFkRWVTaGNoRWZHYkNldGMrZkdlemVGY0NiSmFBYkJkTmNmaHhhVmVXZ0xoRmJ0ZWxhWmFHaHBmVGVHY1JoTmN3Y0NlMWdsZFdoRWhuYXBiSGdaYUVnRmZ1ZlNmbWdSZzVlU2F4ZVFjbGFFYzBnNGRZZldleGRjYm1lUGFEZGNhcWJaZjFnWmJyZkZmZ2JGZGVhZGdVZmNjUWVCZGdleGdDY0lhMWVRZFBhS2JpaDhlMWdJZEVkNGczZVJkM2E4ZDZiVGdFYzFkUmhTZVJkVmhPaGFhWGJRY1lmY2dFYkZhMGhVYVVicGhPYWRjUmdGY3pjVGdGZEVlc2VPZUJkOGFuZkFkU2FZY1hkV2RTY0lmUGFTaFRlMWQ1Z1RmMmVSYnFkVWZ4aGtnVGFjZkFodGRaZFZlaGRKZzZnUmQyY1JiQmJiaGtlcGRrYWNiR2hFZFVnY2dSZjBlZGJUYlJibGhXY2RhR2U1ZzJoY2EyaDliR2NaYXhiWWdTY1ZibmhVZ2VkSGZoZkViTGhXZnllbGFTYkZlaWFjZHJoTmZXaGRoWmVOY3djTWg4aFFmaGZWY0JhVWFSZzFmZGVCZnpicGI2YVZhVGZVaE1lSmV4ZGdkUWFDaDNka2VSZlliMGZCZFJkYWUyZUpkV2FlYlFoOGUvY0djbGIwZ2llU2JGZzRoOWRIZWhid2V0aE1oQmdZZVFkQ2FGZm9lTGhXYVZkWWJTaGVha2hkY2toUWNXYTVjS2haZEhmbGhMY0ZkQ2RkYWNoVGEwZzFlVmJWaG1jbGV1ZFphbWJoZ0ZnUmNtYmNjV2NFZmtmeGgxZ1NhaGdCZFNiUmJBZ3Rkd2ZXZmtnSWhtZkplR2VaYmhnV2YzY3RnT2JLY0RmcGZNZVRkVmhGZEpkRmJVaDVlcGRkYUJhaGV3YVFhWGZSYVJiU2RrYzVkMWdSZXphSWRlZlVkVGh0ZHJhZmZIaFFkUGdhYTFnSWNVZGNkVWNZY1RkZWNGaE5kUGRaZEdmcGVUYUdmUmFOaDRnU2NGZ2xiTGdFYWpiUmdQZ1Rha2hGZnVnU2VtZ1JiNWhTZXhnUmR4ZkhhUmMxZE5lR2RWaFpoMGJiZG5jWmZ6ZGJkMGc0Z3pjWGhsZXNmZmhlYndlZGVWYkhld2V0aFpkS2NWZVFhQmFKZXloTWUwZENnbGZzZzJiQ2d4YkplRWZSaEFjRmVSZFFjaGFWaGZoWWJIZ1FjRWFiZ0VmRmVzY1diRWVvZlNnWGh4aEZjemhUZ0ZiRmc0ZmNnRmNaZDBiRGEyZXRoU2NGaEhhRmRHZ0VmM2JoY1RoVGUyYVJocWFCYzFjRmhhYUljd2VVZVVhRWYxaDhmMWRGZVRkMWhQYUxhUWdJZ2xiS2N5YmhjYmdOZVZmaGI4ZkdkUmhFZ2FkZmhXZUpkY2RjYzJlOWdHZVpmeGdZaFNmVGFIYlZlS2dFYUZkSmFFYkNnM2FCY2FiUWFtYjllaWViZmpoMWdjaE9ieGExYzllWGZRZGtkQWNIaGhkdGVNZ1FjQ2ZvYzhnV2FTZklhaWhPaHhhVWhQZUxneWRFZ1pmUGEwZXhoYWdlY0dlTmJmZGRhQmdOZzNiVWNnaHhjNGNSZWtoOWRTZVVoMGY5Z2tkYWNsZE1hWmhFZjNjQWNMYVdoVmRZaFNmZWhrYmRla2ZRY1dnNWRLZlpoSGZrYWZmWGJEZmhmT2NFY3doQmFjZUdnemRzZjhhTGIzYzBic2hEZWlnWmFFZWNiUWhNY3hjRGIzaEVmR2dUZEVkZGd3Y1VhVWZKYTljYWEyaHBjRGRGYkhhSmRPY2NkeGhCZE1jVGdWYUZmSmRGYlVmNWhwaGRnQmVoZXdiUWFYZVJlUmZRY2hkb2E5ZVdhQ2NCYkNoSGNEYTBjOWFHY1NjWmFXaFphUmhGaGNkTWVCZlJod2ZOYnhjY2dLYUJhVGI1ZWJmVmZSYU5iN2FDZDBkeGVmZ0VkbWdaZGJnWmRGYWxhbmZTZGpmaGVUYlNoeGJSZnhjSGhSZjFoTmFHY1ZiWmYwZ2JobmNaZHphYmgwaFplbmFGY2hoSmdNYmRmVWZwYUVnR2NnZjFlWWJmY2hiY2NIZklkaWgwZDBlTWVCYm9leGRCZWpoSmZDZ0xod2RJaFZmRGFIY1FkYWRZZlRnZ2JZY2VnMGNGY2diV2ZFYVpoa2JkZVJlRmV6ZVRlRmRGZTRoY2FGaFplMGhEZjJjdGVTYkZkSGJGY0dmRWIzZGhjVGVSaHplQWVpaEdha2RvZ2RiUGhVYTRoVWdHZVVoQWNqZVNiU2ZjZUpjTGd4ZWdlSGVOZmdjOWFSZEViRWVrZVZjQWVSZ2xhZGVkZUhjbGYvYmNoM2ZOZ2FoWmd3ZzRoYmNUZ0NjbGZnZ0VmRmFKZEVkQ2czZEJhYWdRYW1jOWhpYlplbWZrY1VoY2ZrZTVmemdFZEVieGROYlVnVWhsYkJlQmZpYUFobmJGZWplMGFFZU9oUmM0ZlloRmQzaHRoU2hPaHdjMGZEZ0dnemE4YlNhTWRXZTRlL2hXZmxnaGZ4ZFRhUmROZHVhV2RtZFZia2NhZmxiTWhaYkVhM2JBY0xhV2dWZllkU2dlY2tiZGRrYlFnV2c1ZktlYmVYYkJnSGhQZm5kRWhkYkhiVWMwaFpmVmJuZFJidWFkZm5hTmF2ZlJobWhjZFdoRWhrZHhjMWVTaGtnUWNhaERjVmRoYitjRGFGaE5haGZJZXljSWR0Y0hnRGdGZEFnUGdrYlVhQWJHYlJnZ2FaYldlUmhkY2hoTmNSY0ZiNWZUYnljWWhlYkhhZ2VKYzloQWFtZkpnRmZYY3pkVWdsYkdmaWNCaEdmT2J4YTVoTmVlZ1JoVWRhZGRoSGZsYVBkWmRHZHBkVGdHZVJjTmN3YkNnMWRsaFdoRWFuZnBoSGNaY0VjRmZ1ZlNhbWNSYnhjQmN4Y1JhNmFBZEJkMWVWYkVoRmZwZWVnYmRuYlpkemRiaDBmWmFuYUZiaGVKZk1hZGZVZm9mUWRVaGtiUWdMYWNmRmRwZ0NjWmV5ZEZkbWNkZUJnUWg4YVJobGNrY1FjVGRFZjFkUmhTYVJkVmNPZWFhWGZRZ1lkY2FFZkZlMGhVaFVocGJPY2RmUmNGZHplVGFGY2tlc2NPZ0JoOGFuZEFnU2JZZFhjV2ZUYjRiVWdTZ25kWWZRZUJneWFVZjRjTWZGZFpoWGVOY1dnb2ROZlhibGU1ZjZoVGNHYVJoUWRaZjBocGc0aFphVWFzZU1oZWhCYTFhQmJaY3hkbGRXZ2RoR2E1aDJiY2EyYjlhR2NaZHhlWWhTZVRjSGhWZ0tlRWVGZ0plRWhDZDNkQmhhZVFibWI4ZTJnTGNpY0JiSGVmaEFkTWQyYVhmUWVNZWZnQ2NFZWRjV2dCaGloZ2NtZWVhemE4Y0ZoTWJUZUFhZWZSY2pma2FZYWZkMmFaZFJmZWJIaEJjV2RkZUFlOWdyZ1VlaGJSZHhoUmRoZE5jNGFVYjBjOWJrZWFmbGhNYlphRWQzZ2hmZmFFZlJlOWVCZGRoQWVvY2hhRGdDZkVjWWVQYVhoY2FJY1hlRGdCZlBlZmdnZEphZGVFZnhjVWU2ZWZkamI5ZXZjVGJXaGNoRmJHaDBheGVwYVZlaGFCYUtnVGNRYnNkc2FjZUVjSmh2YVlibWFaYnBkRmhIaEpkT2VjY3hhQmhNZVRiVmZGZUpiRmJVZTVjcGJkZkJkaGZ3ZlFkWGNRaEZjQWRnZGNlbWFIY3pjNGFKZUhjRGFjaGlnRGMzZ3BlTWhJZnhmTmVHZEVoZ2FsY1hjUGVUaElhYmFiY0NiWmNUaEVhaGNOZGllQWVsYVZmOGFFYm5jcGZIYVpnRWJGZHVoU2dtY1JoNWVTZ3hkUmd4ZEhkUmcxZk5oR2ZWaFpnMGZiYW5oWmU3Z09jd2U0YnVkUmNSYXdiQmhNZEFnZGFmaEFhQmEwZ0ZjTWZ4Y0lkRGhQZlFnRWFwZUxlVmZFaFRnR2RuZ3RjY2NUYkVjWmJSZ1hlQmd4YU9hZGhXZ2diWWhhYUVnaGMwZkRkV2ZCZ09lZGdSZEZiemJUZEZlRmc0aGNiRmhaZzBiRGQyaHRmU2VGZEhhRmNHZ0VjM2JoZlRnVGYyYlJicWdCZTFmRmZhYUlmd2JVZ1VnRWIxZjhhMWJGY1RmMWFQYkxoUWJJZGxiS2d5ZWhjYmFOZFZnaGg4ZkdjUmhFaGFmZGFHaFZlMmVaZDJlWmdLYlRhUmZZYlNoVGRIZ1ZiS2VFZ0ZjSmhFYUNhM2hCY2FiUWZtZTlkaWZaZG1na2JVYmNma2I1ZXpkR2FCZGdhRmFHYkJhb2hiY0FkeWh3ZDVnVmJ5Y0llWWdlYmhjSWNDZURneWFkZnllUGNBYmdlVWRHaFNhUmZlYU9lQWc5ZWdmVWhnZE5kNGFSY2dmOWZrYlVoMWZkZXRjYWNnZzhoemZFZzNjQWNMZFdhVmRZZ1NhZWJrYWRia2RRZ1dlNWdLZFpmSGdsaExkRmVIZEVoZGFIaFVlMGZaZ1ZiaWFBY21hUGh5ZEJmaGZDZXlmSmViZ1hiUmM0aHNlUmVGYU1jYWFCY1Zka2ZUYkZmUWZZaHFkQWJ6aEplaGNXZEhlSmJGZWNmd2JaaEZnWmgxZkZkSmJGZ1VoNWZwZWRlQmRoZHdnUWFYZ1JiUmJTZ2tmNWcxZkVkWGJOZE1oVWVYZkZhNWFXZ2xiNGdQZmFnMWdJZFViY2dVZ1lkVGhlY0ZhTmRQZlpmR2RwZlRiR2dSZk5od2VDZjFoa2FDZldjamJNYVVnYWVoZGRiOGRSYUNkVWE5aERmeGN3ZHlnRWUxY0FkWWFWZ1FmSWQ5ZlBlamNvYXFlWmd3ZGRldWRIYXhmd2RlZ09iaGg1ZGNoV2VsZ2NiYWFlY1ZhUWJQZ09laWc0ZXllSWFFZlFjK2JGZTNmdGJEYVJiVWVGZTdoU2NSYlZhT2hhZFhhUWNZZGNlRWVGYjBmVWFVaHBoT2JkZFJhRmJ6Y1RoRmhGYzRiZWNCZ3BiMGZCY0hhWmJTYURkSGRoY0tnT2NYaGhiVGZUYzJjUmdxaFVheGJrZFRoY2ZBZHRiWmhWZWhlSmg2aFJiMmVSZkJmYmdrYUlibmJlY1ZiWWVVZlBkeGNVZTNiVGZSZmxnV2NkYUdkNWIyZGNnMmg5Z0dlWmR4Y1lnU2FUYUhjVmhLZkViRmdKZEVoQ2QzYUJhU2ZGZmllY2dyZk5iV2NkY1pkTmh3Y01lOGFRY2hoVmZEYkVlZ2VGZ1VhSGRBYm9iN2dYZURiVWNnZkllRmZrZkdhVGFuZzRoUmhZZ2tmVmRSY1phR2V4ZFdoYmhBY1pmcmZEZWphNWd4Y1JnaGFOZjRoVWgwYjlja2NhZGxkTWJaaEVhM2FBY0xkV2JWYlloU2FlYWtjZGFraFFlV2Y1aEtoTWNEZUVhQ2FSaDNnOWdRZFdhQWJCaFdnQmFDYTFmZ2dOYlRlc2J1YkZmQWRSZVpjVmZnZmtmVWJIZ2hhZ2dlaFRhUWVkYmFmV2NrY0pndmZZZ21mWmVwYUZhSGJKaE9kY2d4ZEJmTWFUYVZmRmVKZUZoVWE1ZXBiZGFCaGhnNGhGYVRmd2dZZkdoVWJBZzRhVmZEYjRnRGFBYnllRmcraEZiVGd4aE9kT2JUZUZnYmJOYVFlTmF5ZkxiRmJzZkRoWmNHYUZiVGRDYWhmcGF3ZEZoMGhWZFdnQ2VuaE5oSGZPZUdhdGZ1Z1NlbWFSZzViU2d4YlJoeGZIZVJlMWdOYkdoVmdaZDBhYmNuZVpoemZiYjBiWmZuZEZhaGRKZk1jSWRRaEpjWmFBY1VocGNHZ05nUmVjZ05nUGVUZHRjb2VLZGxnd2h6Y0hmQmdCZ2ZmQ2VBZGdhd2VIZVJmMGZDYmFmWGc4Z1lhWWFrZGhnNGJlYjBicGdPZGRiUmRGaHpkVGFGZEZoNGJjaEZoWmgwZERlMmZ0YlNoRmdIZUZjR2dFZjNkaGNUYlJlemRBY2liR2drZ29mZGNQaFVmNGVVYUdlVWJBYmpkU2RTYmNlSmhMYXhiZ2ZIZE5jZ2g5Z1JoRWdFZ2tlVmNBaFJnbGVkZ2RnSGV0Zy9hY2UzYk5oYWNaYXdiNGViaFRkQ2FsYWdjRWhGYkpmRWJDYjNoQmFhYlFibWU5Z2lnWmdtY2toVWdjYWtiNWV6Z0VlRWZ4Zk5jVWNVZmtiVmNUZ2poMGY4YVVlU2NOZlBlT2ZSZVFlSGZBZFNkZGZJZGZkUWQ4Z1pkT2ZTZ0llMWdPZTBmc2J1Yk1kMGJCYzViQ2JoY05lemFVYzFndGh0ZlpobmhrY1pkRWYzZ0FnTGFXZFZhWWdTZmVla2NkYmtiUWhXZTVnS2JaZ0hmbGNMZEZmSGVFY2RoSGNVZFZjTmVIYmpmMGM5aGVmRGQ0ZnFmQ2Z5YmhnRWVTZjBjSWUyZkFkbGNFZUFhSmMwYlFkMGNIYnloTWI3aGFmaWFwYXBlSGYzY0pkWmNlZ2hjQmhRaFVoVmdGZVJiSGhFZjRmMWRYZGhiaGh3Z1FmWGZSYVJjU2ZrZzVhMWFFZlhoTmVNZFVjWGRoYndiVmduYlFjUGJhYzFlSWhVY2NmVWhaZUhhTWdCZ29mY2hhYWllY2ZXZ1ZoRmh3aGllVWJsZ2NhVmJXYWphc2FWYUJhd2M0ZnFnRGR3YVVodGZRZzFmaGR4ZUZoaGQxYWJhRWJIZXhlMGViZm5oWmh6Y2JhMGdaZW5oRmdoZEpkTWJkY1Vjb2JRZVVia2hRY0xkY2ZGZ3BnTGFaaG1nNWZNZ2FkUmVSZXliVGFuZ01nUWdUZ0VjMWFSYVNnUmJWZU9nYWdYYlFlWWdjZkVmRmUwY0JoUWRJZkhlSmhoZDhhbGhYYzFoOGU1YU5oQmhKZThhVGZHZFViZmRRYVRnMGhTY1dhaWhnZWZlRmFtY3dhcmJXZWhmQWVkYklla2JRZU5jR2doYnBicGhWZG1mMWNQYUlieGU4YW9kTGdRYkpiRWZQYlViUWFWaEhmaGZCZmFiWGVtZTVoMmhjaDJmOWdHYlpleGVZZVNnVGRIaFZmS2hFZEZiSmRFZ0NmM2dCaGFiUWFtZ2NndWJaY21mSWNKZmNmbGZaYjZmSGZHYVpjTmVVY1Vla2VWZVRobWFsZjBhR2JIY0JjQmRkaEZhRmZLZVRlbmNVaFJmY2gwYnhlWmZPYTNlQmZMZmRiRWdGZGpiZWNCZ1JleGhSY2hiTmY0Y1VlMGg5ZmthYWVsYk1kWmdFZDNkQWdMZldnVmVZZ1NjZWNrYmRia2NTZFRlb2NDZUxkU2RwYUZkV2FUZ1JjUWRVYWhlOWFBZFdnRGdjZW1hTmh5ZkVnTWVDY1NoTmNUaGNieGVoYTlkQmFoYUJjWmJSaEJkcGE1Y1dobGg1Y3pmWWJuZTVoZ2NGZUNjNWVrZGNneGZCZE1hVGJWZkZlSmFGZVVnNWhwZWRoQmZoZ3dmUWRYYlJmUmFTZmtiNWIxZUVhWGVOZU1jVWhTZXdoNGRIZnlmY2JCZUplaGhkYVphUGNoZVJkS2dkZ2hnQWdIZUpiVGVnY3dlVmdsaGNkMWVhaGdhMWZlY1hobmVOYkxnVGZrZ0ZjdWdTZm1iUmc1Y1NkeGdSZ3hhSGNSYTFoTmFHZlZiWmUwZWJlbmRaZXpiYmEwYVphbmJIYmtnWWJFY1BlQmhrY2VoSGR3ZEZiR2dQZXdoZ2ViYllnU2NFZXVnS2dFaFlnUmZBYlRnZGRWZkxhUmJsYVpkQmdSZlZiRmVhaFdiY2RSY2NiRmUxY29oVWFWYkpjSGFkZVViMWNaZlRhRmRGaDRhY2VGY1pmMGVEYzJodGVTZEZoSGdGZEdoRWEzaGhiVGJUaDJkUmJxY1VoeGhrYVRoY2FGZjhjUmZIZzBlRmUwZENnaWdFY01lSWJSZWdjOWJkZ3dnaGhjYk1kRWE5ZStoQWdsZDBoVGZGY1RlcGgrZFBkMmc5Yk5iWmF3ZlFiYmRRY0ZjOWRLZEVkRmRKZ0VlQ2czY0JjYWhRZ21lOWNpZlpjbWhrZFViY2hrYTVhemNFYkVmeGNOZlVnVWJGZUJoQmNpYkFobmFGZGpmMGNFYk9hUmM0aFllRmQzYnRjU2FPZ3dhMGZEY0doemQ4ZFNmTWRXaDRnL2ZXYWxhaGZ4YlRnUmROZ3RoV2NrZTlmNGdkYWxnTWFCZkdobmNCYlhjY2IxaFllU2FlZWtjZGNrZFFnV2Y1aEtiWmVIYmxjTGFGZEhiRWVkZkhnVWUwZVpnVmhuZVJkdWhkZ25kTWc3ZURhaWM1YUZiSGhBaEVld2ZCaDFlOGFBY0hlUWNVY3pjRWJnZE1nOWZBZVNoa2J0ZFVlUmdNZmFjZWcxZHhjTWRSZmxkRmVkY0hlRWRKZkRhZGVCZWhld2RRaFhlUmhSZlNja2Q1ZzFhRWZYZE5iTWFVY1hkaGR3aFZibmVRZVBnYWUxYklmY2ZKYVFoNWJhZktiMWQwYUNlSWZTZWNnY2NTYjBicGIrZ1NjQmdFaFhjUWVCY2toSWRJYUFlUWdQaEhibWN3YzFlU2N4aDloeGJDZmhnUmdOZUJjVWdwZjBhZGVuZzlkemNNaDJoeGhuZUZoaGNKY01iZGZVYm9lUWhVYWtiUWhMZmNiRmJwZ0NkYmIyYUpjbWJhZlJlUmV5aFRnbmVNY1FhR2FBYVVoWWVHaGhkc2dEZ0xlRGFsYlhkSWRoY2hlNmZFYmdmSWRQYUpoM2ZJZDhoQ2hCaFFjWmRKY0ZiNGI0Y0RiMmdCZFNoQWRuYmhic2NFaDNmaGVUaFRnMmNSYnFnVWZ4ZGtiVGhjZkFjdGRaY1ZkaGRKZTZoUmYyYlJkQmNaZTBlTmRvZ1VkMGFzYlVlY2ZSYjBlZGdUY1JnbGVXZ2RmR2c1ZTJlY2cyZzlmR2ZaZHhoWWdTYVRlQ2FFZkNhV2dRY0ZjS2dYZFdhUmdVY0FheWNzZG1oYmhpaG9mYWFQYnhmc2IvYlJoQWZVaGRnSGFSYkFoZGJEYzJoQmU5ZUZkaWhJZ09oSWhCZDFmQ2RYY1djUWRZaGZnUWVFZEVmTmFDZlFnZmFKZEVhTWJ5Y1dka2RkYzRjWGdUZWxlNGVVZTBhOWJrY2FhbGZNY1pnRWYzZ0FnTGFXZVZnWWZTYmVmaGdwY2toQmhDZ0lnWmdJZVhia2VRZ1BjbmdFYmRiSGRVZDBhWmZWaG5iUmZ1Z2RmbmFOZnZjUmFtYWNnV2ZFZWtmd2NqZENmMGhKYVNkQmN4YUJkYWVXZmtjSmZ2ZVlmbWNaZ3BnRmRIZEplT2FjYXhlQmJNYlRoVmJGZUphRmRVZllkcWVkZkFiVmd3Y0RjM2d4ZjdlU2RrZjVjMWNFYVhkTmFNaFVjWGRoY3dkVmVuZ1FoUGNhaDFoSWdVZWNiVWFZYVRiY2VBYWNhSGVMY1RnbGhkZVZhRmdZYTliUmdBY3NnUGhhZVRhWmVIYWJnMGdGZC9nTmcyZFJibGRWYnhkUmhwYkZiQmEwZVJiR2NRZklnOGdKYnloVmQ5YklhZ2NNZ3FkV2hVaEFoVmFEY2dhWmJ0ZVhhbWc0Y0xoY2hGZHBiQ2diZDJkSmRtZmFhUmRSZHljVGVuZ01iUWVUZEVmMWFSZFNmUmhWZkdhUGVUZHhoUmVJZDBnOGQ1YUZkQWZjZ0JiSmgwZ2dmSWJBaEZoRmV6ZGNlRWFVY0pmRGEzZmRiT2ZGaEdmbGRQZ0VheWhSZFRjR2V5YXdkamZBZ0JhZGFlZk5kVWVZZFdkQmhFZ3NmQmdDZTJoUmRLZWJkbGdnZVpkZGVXY0VhVWFjZlJjMGRkY1RiUmdsYldiZGNHYTVhMmNjZTJkOWNHZlpleGNZZlNkVGhIZFZoQ2RSYkJob2dOYVdnSGY0ZVhhQmh5aElmdGdOaERhQmh2ZlBka2Q1ZDRjRWdGYmtld2VVaFZlVWNKZ1RlbmRGZDliR2ZDaHhhQmZJYUJha2NEZUhjWGJ0Z2NjTmVnY0VkZWFLaGlja2V0Yk9mQWI5Z2dhVWhnZ0FnTWZTZWpmbGU0ZVVlMGY5ZmtlYWdsaE1jWmFFYjNjQWdMZldmVmFZYlNoZWJrZmRha2VRZFdnNWhDY01jRGRFZkNkUmczZzllUWZXZUFjQmVXZUJnQ2EwY1ZiT2ZuZ05ka2NSaG5oQmVyY0VjbGZCYnBoU2JnYmhmYmFSY0ZlZGd3Y0RhZ2NvZW1jTWNXZWdla2JVaFRhOGVCY0lhVWNrZTNiQWZWaEZjQ2NGaFZkZ2JVaFhkaGJoaHdjUWdYY1JoUmJTYWtlNWMxaEVlWGhOZk1mVWZYZ2hid2FWZG5lUWhHYVllbGc0YitmY2NVaFljVGhlY0ZoTmJQZFphR2RwaFRoR2VSYk5kd2dDYzFobGJXZkVhbmZwYUhkTWVBZWthbmJHaFdib2F2YVdiaGZvZndoV2dWYWxiRmZXaGxmZ2U1Zk9nemVvYW5oSmRoaFlmcmJUZnhob2dOYWZoRWFNYWVkQWNBY3RkZmhQY0ZkSmZSYmZlbWJ0YW9nSmFFYUVnK2dHY2plcGhBZEFjQmhSZlpmR2JoZXhlQ2VRYjNkUWhZZWNkRWRGYTBjVWdVZHBhT2ZkaFJkRmF6ZVRmRmdGZTRnY2ZGZlpoMGZEZTJkTWZlZ0ZjSGhwYWJiRWgyYUJmYWRRZTBkNWdxaFVneGVrYlRkY2ZBYnRnWmNWYmhkSmI2YlJlMmZSZkJkYmVrYnBoa2hlZVVoc2ZjZU1jaGgwZEFnVGJWY2RmZWhYZG1iNWMyYmNjMmU5YUdjWmh4Y1loU2NUY0hiVmJLYkVnRmFKaEVlQ2UzZEJnYWNRYm1iOWRpZ2JiamYxZmNmT2J4aDFkOWJYZFFna2NBYUhnaGV0ZE1lTmVTY1ZlMGdFZzNkQmVRY0NkVmdGYldlVWZuZFVhSmFlZmtod2hOY2ViQ2NRZGVhUGhWZXhobGJIYjFlRWc4YkNkVWNFZWhnS2JBZ01nWmRaY25oa2JaY0VoM2NBZ0xhV2JWaFlmU2NlZGthZGNrYVFkV2I1YktoWmZIZ2xlTGRGZ0hmRWFkZEhhVWZWY05nSGhqZzBoOWhlZkRlNGdxZENoeWVoZkVjU2F6YmNjNWhTaGhndGVTY1ZkM2ZaaHdnUmVsYjVidmdlZG1nOWdwZ1NmSGRJZmFoT2gxYmtnZmhRZ3hod2JNZVdhQWdFZTdkTGRXY01oOGFRaFhjOWNSZFdkRGNOZzViT2gzZ05mTWRVZVhkaGV3aFZjbmJRZ1BnYWExaEliVWFjZlVlWWZUZGVjRmROZ1BlWmZHYXBjVGdFZ1VlY2I0ZFFnZ2dwY1lkWGF6ZjhkS2NLYnhiTWYzZk1mU2JoYjVjUWNCZ1Jha2dZZkJnMWNSYUJiVmZaaHNjWmUzZ1lkdmdiY3hkSWd2ZlhiMGJGY0NkT2hBZTlkZGRIaFJnWmVTZkNjeGFaaENiWmFHZ0pneWRGZUJmaGNZZVRkbmdNZFFnVGZFZzFmUmVTY1JoVmdPYmFlWGJRZVliY2FFZkZjMGdVYVVlcGFPYWRmUmhGZTdnR2FCZWtieGZJYzFoZ2Y1ZFNhaWVZYmRlUmhpZmdoOWFYYzNhaGdZZFRkM2RNZVhkVWN3YlVkUGFjZ0JkTmNRZlZoa2E1ZDZjRWZ5aHdmSWJQaFVjUWhwaFBkQWhaZGJoSWgwaFJibWFBZFJkbGNkYmRiSGdnY0xkV2VXZjlhR2haZHhlWWhTZlRjSGRWY0tkRWZGY0phRWRDYTNhQmNhZlFmbWE5ZWllWmVtZUFjZGFmYm1hUmZ6YkVmRWF4Z05kVWFVZ2tkVmdUaG1obGIwYkdoSGZCZ0JkZGJGZUZmS2dUZ25lVmdGZE9hd2VVZENoZGRpZ1pjRWZlaGtoNGh2ZUZjaGN3ZHliU2hGZzRjdGJIZHhlc2d0YU9maGY5Z0FoR2F6YkVkQ2NVZ0ZoaGJBZ05mUmZNZm9nU2FYYjFnYmFiaFhhY2JHZVFjVGUxY0phVmJCZzFoVmZEZDNkd2c5aGZkM2c5YkZoUmJtYWNiV2dFaGtjeGgxZ1NoaGRCZlNmUmJBYnRjd2VXaGtkSmV2YllhbWZaZnBkSGhEZDVjT2JlZUFmMWJNZFZnVmFoZEZiUGUwaDVncGVkZEJjaGd3YVFkWGVSaFJmU2RrZTVnMWFFaFhiTmhNY1ViWGNoZ3dhVmduaHhhTWFhYTBnOGhVZ1BmMGY0YzVlZWNGZk5mUGRaYUdicGhUYkdmUmZOZ3dkQ2IxZmxjV2NFZ25jcGdIYlpkRWFGY3VkU2dtaFJheGRIZjFld2Q0ZlRmaGRNYUFiWGFCYXNhN2NQaENhOGdJZEllMGJaYnNiRmhnZ01ieGhkY1ZlWWRNYVVhbGZ3YkNkY2JBYlphQ2VPZHlmb2N2ZE9laGFvZi9lQ2h6ZzVkZmZIYmhoUWZxYUJhV2JoZkNoUWczYVFoWWhjZEVoRmQwZVVoVWJwZk9nZGdSZUZmemFUYkZmRmE0Y2NmRmZaZTBhRGgyY3RjU2hIY0NlVWdPYVdjaWF0Z2RhQWVpZEVobmJIZkVhdGJLYkNnMGNkZlpmWGRSaEpmcGNPY21hUmhkY2Nma2ZwYzhnY2dFZ3RhSWZjZ1VkbGhWZUJiRWJwZlloT2VTZnNiN2JQYURnMGdmZkhlRmVvZlNmUmQzYlZlWWNiZ1ZmNWd1YkNmM2RCZ2FiUWdtYTlhaWdaZ21ka2NVZ2Noa2Q1ZXplRWRFZHhiTmhVaFVna2JWZ1RibWVsZjhjVGdEZGdkSWdKaDFlOGFIZENlemdoY2VoSWRSZlVhcWVOYkhmQmFkYmRmQmJvZFdjVWdnZWhkdGZSZ2dhdGZ4ZlVheGhOYWtnUGhoYnRoUWNRYkhhNWhHYUhmQmh0aGRlS2dCZDRoZmZEZVdnNWhCZFplR2IwYjJhR2JGY3NmZGJIYlVjMGhaZ1ZibmZSZ3VoZGZuZU5hdmNSYm1nY2VXY0Vka2Z4YjFmU2RoZEJlU2ZSY0FoTWdrZkViZ2hzYThmYmdDZXNjc2ZXZ1RjMGNjY0tjbWdzaEFoVGdWYnBoSmdBZGpjTmRwY2FiQWNSY3dhV2dYZDFiUmVGYWtjNGNoY1dhVGhvYWZhWGh6aFVkMWhHZ3pjdGNkZk1kaWJsaFljY2FVYzBoVGdiZGlmNWhsYlpoR2FwZVRiR2VSZE5jd2JDZzFlbGdXZ0VibmhwZEhjWmZFY0ZjdWdTZW1oUmg1ZVFlaGgxZDlhTmh4ZjFjTmVHY1ZmWmUwZmJibmJaYnpkYmYwY1plbmFGaGhhSmVNZ2RjVWNvY1FnVWFoYkJoRGNPaFFobGZNZk9nWGVGYm9mS2JGZEFlMmVSYmpnQWNlYkFhUmFnaGRoSGJWZHdoZWFKZlNjMGhRZ01nVWhoZjlkWGN4YWdlQmRJZ1ZnMWc3YlhoMGRCaHhjZmRoY3NnaGRRY3pnOGdiZlJmRGIwZ2ZiR2V5YnRjYWhRYzBnNWZxZVVkeGFrYVRnY2JBYnRnWmVWZmhhSmE2YlJkMmhSZkJiYmRrYnBla2JlZ1Vnc2NjYVBmUmUwZ1doVWdCZWxjT2JmZ1dhSmVjZWNiMmU5YUdhWmN4ZVlkU2RUZUhlVmJLZEVlRmVKYkVkQ2UzZkJjYWhRZW1hOWRpZ2JmaWJvaFVkYmgwZTRkOWRHZUdhWmNOZ1VhVWVrYlZmVGVtZGxlMGFHY0hlQmdCZ2RmRmZGZEtiVGFuZlVlUmFjZTBheGRSZWVkSGdnZUNoUGRFZVlhNGVYYUZia2YwZkNhMWR3aHFoQ2VqZlFkb2dhZGxmZ2VaZ0FjZ2EwYUxmUmdVZG9jU2ZZZ2tjNWNrZ0hhV2Y0YWVjTGZEZUFlWWdHZWpoeGNZaFVhQWhKYkxlRGJ3YjhjaWhDZDNkOWZGY1JibWdjZldjRWNrY3hmMWZTYmhmQmZTY1JlQWd0ZXdnV2NraEphdmJZY21jWmFwZEZmSGJKYUdlSmgxZmdoRmhIZmxlOGFFZFViQWVNY21jSmdrZUViTGNEYVhhUmhhZlNlbGgwZkloRWNXZTlhUWhVZldkQmE1ZlZnaWZnZVBkUGV4aHBhZGJJaGtoaGhlZlBhUmc0YkFmTmFqZ01lb2hWaFJiTmY3YUNjMGRzZ3JlSGdsYUJoSGZaYkViRmF1ZlNobWNSYzVmU2R4ZlJheGRIY1JlMWZOZ0dkVmZaYTBkYmhuZ1pjemViYzBhNGd6YlhnbGNzYWZhZWF3YmRoVmdIYXdmdGhaaEtlU2VFY09jYmUyY2xibWJmaEdobGd5Y1VnbWc4ZFFnVmZFaFJoUmFGY1JjVWVhYUlhVGUxY0xmZmVnZXdmeGFIZUFmVWRjY0xoR2JvYy9jVGJGaHBhNGZaaENhdGU0YUpjV2h0Y1NkRmZIZUZjR2dFYzNkaGFUY1RkMmRSZnFnVWF4YmtnVGdjZ0FjdGJaZFZmaGhKZzZjVGR6Z0FlSmZKZXhnbGdxZU5hQWI1Y1pkUGNrZjllRWhOZmxnVmhXY2ZhMmE1ZmhnRGFtZzlkYWhlaHhlWWdLZ1JoWGRVZVdiRWNBZ1lkTWNRaGloTmZVZERjeWFvZHZoS2hUYnRiTmhDZFFmSmN6aEdlMGV4ZmJhTGFHZ01hVmRUY21jbGUwZUdiSGdCZUJmZGZGYkZkS2dUZm5iVWhSYmNiMGF4Y1JhZWRIZ0JlZmZmZ1FhTmFCZlVhaGNSZHhjUmhoYk5iNGNVZjBmOWJrY2FnbGRNZ1pnRWEzZUFlTGVXZFZiWWVTY0xkZ2c4YnRjRWJtYUFhY2RjZ0hlY2RLaFVhRGJVZFZkWGVrY05jVWFBY3pjZ2I2ZFBneWVNY2pmSGgyZDloWGdHZzBmVmY3ZEdlRmM4ZUdhQ2hBZE5iamRTYzBidGJoZ0xiemZNZ2xmUWZEYnNnZWFQZzBnbGhFZEhkbGRoY1NjUGUwZTVjcGdkZkJmaGZ3ZVFlWGJSYlJiU2hrZDVlMWRFY1hoTmdNZ0RnRmNKYXdnVmJuZ1FoUGRhZzFkSWRVZWNiVWhZZlRlZWdGY05iUGJaZEdiSWRiZEdmUmFoZnRjQ2cwYnBlRWZFYW5oZGNIaE1jQWZrZ25oR2JXZ29mMGFEaGxna2ZpYlZnRWdjZklhRWRGZnBmZWNiZW5oWmR6ZGJmMGFaY25nRmNoZUphTWJkY1Vob2ZRZ1Vha2RRZExiY2VGYUlhV2VKYnllc2YxZFpiMWdraDNlQWJ5Y0JnWmFGZmdlaGJSY1ZiQmZWYWViWWZIZmdoeWVjYUVhRmIwYlVjVWRwZ09jZGJSYkZkemFUYkZjRmE0ZmNoRmhaYjBhRGR5aFJhU2RFZG5jZGhHY0dmeWJ3Z2JkQmdqZ2Rha2RIYWxjeGVlZlBiMWVrZEFoVmFnZzljNmRSZldiWmRJYmRkV2dCZGthZWhVYnNkVWJjaFJjMGRkZVRnUmZsZVdlZGJHZjRhcmRXYldlOWNHZlpkeGRZZVNoVGFIZVZlS2hFZ0ZlSmZFaENmemFraGNmUWVtZmNka2NaaG1hUWVVaFlkVmJ4YnpnRGVsYkZjTmNHZFViQWNWZEZiVWhOZjBnR2VIZ0JkQmhkZ0ZkRmdLZVRhbmRVY1JnY2MwYXhlUmhlZENhWWVYaEplZ2c4ZzdhVWdnZGxkeGdBZEJlTmExYVVmMWV4YjJiY2FYZWtoWmdFYzNiQWNMZldiVmNZY1NkZWVrYWRoa2dRaFdnNWVLY1phRGYwZUVlRmRDYW9lM2FIZVVmMGZaYlZlbmhSZnVkZGJuZE5odmhSZG1iY2VXZUVna2Z4ZjFoU2hsZWtmVWhSZEFhTWYvaFVnMGJJZDBmU2NHZlpkcGVGZUhhSmNPaGNkeGJCYk1hVGNWY0ZhSmdGZFVhNWhwZmRoQmZoYXdmUWZTZEljUWJHaEVjNGgyZ0NkbGJsY01oVWVYY2hmd2hWaG5hUWVQZmFiMWZJZ1VnY2VVZFlmVGZlZEZlTmNQZ1pnR2dwZGJkV2hoYU5ldGdDZHhoZGVlaE9kSGJwZkhoWmNFYUZjdWhTY21lUmc1YVNheGJSYXhoSGVSYzFjTmZHYlZiWmcwYmJhbmNaYXpoWmN4Z0pmcGdWZlZhb2ZOYkpleWVsZmZmRmdnY0ZncWRKYUZhSWRLZWJjMmdsZm1mZWhCZDFleWJVZ21jOGNRYlZhRWRSZlJnRmFSZVViYWNaZ3pjZGhRZ01oUmFNZ1hiSGVnYjRkTGJGYkVnVmM3ZEJiRmJoZDBoV2JsYlphMGNEZTJjdGNTYUZlSGhGaEdiRWczaGhnVGJUZDJhUmRxaFVleGdrZ1RjY2JBZ3RiWmJYZmtjWmcwZkJkQ2J3YUFkUGdDZWtncmdQZVFjNWExY0phUmFWYVZmVGJSYUphV2ZaZzJlZGEyZWJiM2FOZUdjZmN4ZThkU2dFYkhlVWFlYUhmaGhFZE1iU2dpaEllNWhEZVNjc2NuZEJnemcwZWNlT2JrYTVoNGdFaEZjNWVFZFhoV2hNZlZoVGVtYWxnMGJHYUhoQmNCZWRiRmdGZktiVGhuZ1VkUmJjaDBoeGNSZ2VjSGVCYVdkZGVBaGNhL2ZYaEZnY2c1Z0JiMGJFaGJoSGVBZXNhaGdDYndnY2ZSYVdkM2ZBYUFmV2ZVZk1lYmJlY2xhdGU0ZlFmWGNaYkRnWmNDY1ZiTGVRZEhhOWJlYlZmUWR4Y0xlTmdUYXNkcWNNZHhmSWc3YlRkaWU4Y1dkR2VVZXhmaGRRZXhleGE0Y1JhQWZ0ZXdkV2RrYUpldmJZZm1nWmNwZ0ZkSGZKZU9mY2F4ZkJlTWhUZFZhRmhKYUZlVWQ1ZWhnSWdCYVloemJDY1RnVWhEZUtkUWJFYXhmVmVCZUliWWFXaFRoQmZ3ZVhhWGVRY1lmWWZsZ0lkSWFiaFVnWWhMY2NhVmFNaFRhWmVEZDVoZGVXY2xic2V4YVdoVGNvZFpkVmRqZDhibWVNZkVka2dtZlNhbWY5ZzVmWGJSZDFkYmJIZ1JoMWNOY0dhVmdaYjBhYmVuZlpjemFiZTBoWmhuZEZhaGhKY01hZGdVYW9nUWJXZjBhMGZIY1dhbGFwaENiYmEyZ0phbWdhZlJjUmJ5aFRlbmFNZlFiVGZFYjFhUmJTY1JkVmVPZWFmWGRRZVlhSmVBYmtnOWRBZ2tmUWdZZlpnQmE4YXlhQ2hCY1Zmd2VNZjFnZ2E1aFdiaWRjZEdoWGJTYkVoS2RTYm5oQWFTZlJobWMxYmtiQWRWYVpkSGdQZ0FkTmFLZ1JleGZ0YTBnQ2FqYkVjTmFPZ2diTWMwZ05nUmZJZ2NnSWVoZVFoUmRaY3hnbGJXZWRjR2Q1ZTJkY2IyZDllR2FaZnhoWWRTYlRoSGdWZEtmRWZGY0pjRWZDZzNoQmhhZVNmaWNkZ2ljYmdYZlFoVWhhYmtkZGcvZ09ja2N4Y05hVWhVZmtoVmdUY21ibGIwZUdkSGRCYUJiZGdGYUZlS2VUZm5nVWFSZWNoMGh4ZlJjY2FEY05iV2hhaFFjOGFsY1dhamI1ZnhnUmdoYU5mNGZVZzBnOWFrZGFnbGNNY1pkRWgzZEFmTGFXZlZnWWZTZGVoa2ZkaGtoUWJXZDVjS2ViY0NmMWZGZFZoemdsZWNmVGN5YzVlV2JFY2pkRWdQYklmbmNzZG5mUmhtYndjV2VBZjBlVmYxYVZhZ2R4YVNoWGNBZUpmd2NCZGtkSWg3ZWJlQ2VVYmhnVmFTYUFhdGNQYUZoUWNKZUxhQWFWaEJkWGhVaGRibGRYZ2hmaGd3YlFmWGFSY1JoU2hrYjVjMWJFZlhlTmhNZFVoWGVoYXdkVmNuaFFkUGFhYzFlSWNVY2NkVWdZZmJlTGhGYjBmTWhMZUNjc2NCYWVlbGh3aDBmVGZqaGdmQ2VHZWpjSmhIZ2JhMGhGZDlnUWMyZlJhbGRWZ3hlUmNwYUZjQmcwZFJkR2ZRYkpjNmdMZ1RiNGR5ZVBhU2FVZm9mVWRsY2NmdGRJZVVhSmNZYlVma2M4ZUxkWWhsZk5mT2hSZVdmSmdtY2FiUmhSZHlhVGFuZU1iUWhUaEVhMWZSYVNhUmRWZE9mYWVYZlFiWWdjZEViRmcwZFVhVWVwY0dnSWJSaDhmd2ZCYUJiQWdxZEVleGNrY3dmU2FnY29iR2ZIZkRmbGJHZEdiSGRoY0diUmRtYlJmMmhUZ3hha2NMY2VmUWdzaEZmVmRrZ1poMGRCYUNod2RBYVBlQ2drYnJjUGdRaDVoMWJKZVJlVmJWZlRoUmFKZFdjWWRHZ2RoNmdXZldoOWZHYlpheGNZZlNlVGZIZFZlS2NFY0ZiSmRFZ0NjM2ZCZ2FmUWFtYzloaWFaZm1na2VVZWNia2g1YzdhUmFFZkljT2VHaFFjaGdIY0xjU2JZY3dhWGhSY0VoVmJmY0JmbGdLZVJoWGhVZEdmZWJrZXhoTmJaZkhlQmdPY2ZoUWg4ZTNhVWNrZkJiL2RCZVZjc2E1Y0FhU2d3YXJmTGVoY1piNGdSaDNiaGJEYldmVmMwY1NhYmdFZDVjT2RRY1dnNWRLZ1piSGRsZkxnRmRIZ0VoZGFIZ1VnMGRaZlZibmNSZXVkZGduZ05idmZSZG1hY2ZmZUdjMGhCYmZiU2hoYUJoU2VSYUFkdGh3Y1dka2FKYnZnWWhtZVplcGdGZUhhSmFPZmNheGFCY01lVGFWZkVjZGJYZFFiY2g2YmVha2I1YmlmVGh6aFVnVmZEaGtlWWMyYUhhemQ0YlpnSGJTZHdnNWFCYmpnaGVXZ1lneGhNZWRlZWJFYmhoQmhOZHdnY2VEZmJiSGdsZkNoRWRCZDBjOWRYYmhmVWVDZldieWJvZkxlUGNVZWtlOWdRZjJiaGdUaFNheGFSZHhiSGhSYzFmTmNHaFZhWmEwYmJibmFaYnplYmUwZlplbmJGYmhlSmJNZWRkVWZvZVllR2FrZ1FjQWFiZFZlcGVhYVpibWc1ZE1hYWFSYVJleWJUYW5lTWZRY1RkRWcxZlJlU2ZSY1ZmT2dhZFhnUWJZYWNjRWNGaDBhVWVVYXBmR2ROZGhmRmd1ZlRiQmM5ZXdlV2VsZVplMGREZjJjdGZTaEZjSGJGaEdkRWEzZmhlVGNUZzJhUmZxZFVjeGRrZVRiY2JBZHRnWmdWZ2hkSmV5YkVoMmVvYUNlSmVnZnNoMmVHY2diUmVRZk5jSGF4ZkplUmFWYkZiV2NmZTJhNWJuZGVlbWQ5YmFoZWR4aFloS2dSaFhoVWRXZEVkQWNaZUtlU2NEY2diYmdFZkFnd2h0aEloaWF4YzFiSmRrZlliN2JHZ1VkQmVuZVVoVWNraFZjVGVtZGxoMGdHZUhlQmFCZWRkRmNGZUthVGVuYVViUmRjZzBkeGRSZWVnSGhCYVdnZGdBZGNiL2dYZUZmY2E1ZkJhMGNFaGJhSGFBZXNoaGJDYXdjY2JSZldmM2hBY0FkV2dVZFVlYmRlZWxodGg0Y1FmWGVaZURkWmJDY1ZlTGVRZ0hjOWhlYlZmUWV4YUxhTmZUYXNlcWFNYXhlSWY3ZVRiaWM4YldjR2dVZnhobmRRYnhheGU0aFJkQWF0YndmV2NrZkpkdmhZZm1nWmVwZkZoSGFKYU9lY2F4ZUJkTWVUYlZiRmZKYkZiVWE1YnBiZGhCYUFka2ZUY3poY2FaaENleGd3Z1diWGNqZ2NhSmRNaENheGI0ZkhlbmFRZUVlYWcwZmNoZGNjY1Zib2hQY2VkRWh0YUdhWmREYlpiVGRUZVJoMGR6ZlFkeGFnZkVjY2RUZFVkRGdJYlNhQWM2ZVFiaWd4ZDVhUWZCYlJibGVGaEJiRmRuYUdmVmhaZjBnYmVuZFpiemFiZzBoWmFuZ0ZjaGFKaE1jZGJVY29nUWJVZWthUWRMZmNlRmhwY0NiYmYyY29meWFaZDFkY2g2ZURmeWhGY3pnQWF3Z2toVWFLaEVoRmNHaElkWGNRY1RmY2NGYlplOWFVZVZiWmNTZmRnUWRsYjZnVGVBYTFmNGVKaEZkZ2UzZlJieWJvZUFmZGV6YjRhQ2JWYmhma2RIZ1JneWN4aHFkV2NCZmtoRmFlY1NiRmRaYVZlaGhKYzZjUmQyY1JiQmJiZWtmcGFrZmVlVWZzaFVnY2JSaDBoZGhUY1JmbGJXaGRlR2VkZy9jZmUwYVZiR2haZnhmWWhTY1RmSGdWaEtiRWRGYUpkRWNDZjNjQmdhYlFhbWQ5YWlkWmRtZGtjVWJjY2hib2I3YVdnUmE5ZkRmQmMxYm9kYmZEZHloMGF3Y0VmRGFOY1BiT2dRYlFlR2dHZmpjeGNCYlBoeGFWZ1pmT2VYZmxlZmFlZ2xoMGZrZEJjbGdoYTVnVmNRZEpoeGNYZFFhSWd4ZUphZ2dkZFFiUWN6ZXhmU2FVY1FjVWhiZmRkbWUxY2tlUWZXZjVjS2JaZEhlbGhMZUZlSGFFZWRhSGhVZDBoWmhWYW5oUmR1ZWRibmJOYnZkUmNtZDlhZWdFYmtlZGRvZ1NhZ2VoZWJnU2ZDZEZod2FXaGtkSmZ2ZFlmbWRaY3BoRmRIZUpkT2ZjYXhnQmRNYlRnVmJGZ0pjRmZVaDVicGRkYkJjQWZ6ZlFmV2VsYVJnQmhFYVplZmZFaFhjTmNNZVVmWGRoYXdmVmZuZVFmUGdhZDFnSWdVZWNhVWZZZVRnZWdGZ05kUGNaZUdlcGFUYUdhUmZzaGtiQmRSZm9nZWFVY3loZ2ZrYktkd2NVZ3JmS2F6ZkJheGdBZ3hnUmU2Y0hiUWN4ZEVnR2RVZHBjb2JiYW1iNWM2ZGJmeGRwZm5lUWVoZXdhUGVQZFFjdGJDY01lUWh0YVBoTmNUY3NiV2NaZHlkcGR2ZlplVGM1aHllVGFuaE1hUWVUYkVjMWFSZVNjUmZWZU9lYWdYZ1FjWWVjY0VlRmcwaFVhVWNwZk9oZGdSaEZoemVSaEFlVmIyZk1jeGU0aDFmWGJRaGdjZGFVY0RlUWRuYVJmM2FBY2JnVGcyZzlhcWdRZEJmQWJUYWJmQmJkaFpkVGVoYXRmNmRHYjJhUWhWZlliQWhrZnNkT2RCYmxiM2ZQYmxkbGNZZExhRWIxZGVnUGFHZDVoOWVjZzNhMWRQZWFoemd3YVNkVGNIaFZnS2ZFZ0ZjSmJFZkNhM2ZCYmFkUWZtZTloaWRaZG1la2ZVYWNna2I1YnpmRWZFZXhmTmRXYlJoMGJiY0RmU2FFYzFoU2RoY01jT2hNYkJlUWRyYkdjbmgxYlphY2UwY2RnUmdiaFhjbGNXYWFiQmVOY3JmU2NoZjFmeGNHYWhkTWZzZlhlUWF3aHNlS2V3YkZkNmJYYURkUmZPZE9mQWhJZmFjTWZrZmRhdmRRYVhmcGdEYmFlRmVOYkxnRmFIZUVoZGhIYVVmMGVaY1ZibmJSZXVoZGRuYk5ndmZSZm1mY2NXZkVka2Z4ZDFnU2FoZ0JjU2FUZUZjOWIrYUdnUWNvaHVkTWNBYlVjbWZVaERjY2h2ZUpkeGVnYkVkVGhWaHBiSmZBZ2tkZGVwZ2FkQWJSYndiV2dYZjFjUmhGY2tnNGhoZ0hlemZBaEVnRWVDZG9kVGRHYlRkQmZLZUNhZ2FZZmNjT2hVYllkWWFlY0VoVmVHZ1RkbWRwY1RhR2dSZE5hd2JDZDFnbGZXYUVmbmZwZEhoWmdFZUZhdWZTaG1lUmI1YlNoeGdSY3hlRmNCZ1JkQmRNYTFmWmQwYmJmbmdaYnpnYmYwZlpkbmJGaGhhSmdNYWRjVWNvZ1FiVWJrY1FiTGZjZEZncGZDaE9jeWZvZXZnT2JoZ29ma2ZXZm5oMWFSZkNhQWJsZlpkQ2doZXNhRGdQZkRlaGRNZU9iUmJFYzRoQ2ZFYkloUGFmY0JnaGE5ZkhoaGQ0ZnNhUGhGZzVkbmRIZW1mSmRjZFdkU2VRZEtnUmZ6ZEVjRGFBZHpjMWRpZ0FjQmhBZElkV2FnZHRjWmRWZWhlSmI2ZVJiMmZSaEJiYmNrZ3Bma2ZlY1Vlc2dVY2NkUmYxYUFkVGhWYXdhYWdKZHlodGYyYUtnRWJWZkdiWmZ4Z1lmU2hUZ0hiVmZLaEVlRmdKZEVnQ2UzZEJiYWVRZm1oOWZpZFpmbWRsZUNoTWJ4Y3hiemZVYzFiZGhuY1VkVWJrZlZlVGVtaGxkMGNHZEhhQmZCaGRlRmJGZ0tlVGFuaFVlUmZjZDBkeGRSZWNiRGhOaFdhYWdRaDhobGRXYWpiNWd4Y1JmaGZOZzRjVWYwZjlna2hhZGxkTWhaZEVjM2RBaExoV2NWYllmU2dlZWtjZGdrZ1FnV2JZZmVhSGJ6Z0ZnTGFIYTNoRWdNZ1lkRWIwZ0ZjU2ZuZVJnMmdmZDNkTWV6Z1JjamROaHRjV2NqY0ZoNWNZYkJkQmZTZVJnQWh0aHdmV2hrY0pkdmdZaG1mWmZwZkZjSGRKZk9mY2d4ZEJmTWZUZlZhRmJKYUhkUmZvZ1NnUGJCaGhoN2FRZldlY2RzZ1NjbGRKZHBjRWRXYXRjRmFVY1NnUmF3YkFnZ2c5ZEhnYWgxYWtkVWZZYXpoc2hmZ1VkbGFOZFBlWmdHaHBoVGFHZ1JjTmN3Y0NlMWJsaFdhRWFuZHBjSGVaYUVmRmR1ZVNmbWNSaDViUWUwYkFjS2ZWZFJnMWdHYkdiVWNNZEpnYmVtY3BkdmdiZTFmNWV1YUZka2E1ZU1mSWVUYUZjWWVVY2tiOGNMZ1phQ2hkZk9lUmJXZEpibWJhZ1JoUmd5ZlRlbmhNYVFjVGZFZzFhUmRTZ1JlVmJPYmFjWGNRZFlkY2FFZkZiMGJXZlJlNGQxaFBhUmZGZDRhVGFFaFlnRmJjZUVmcGVvY0RkM2dOZWJhRmhDYTFjR2FSZndlTWZiZlRlMmU5YXFmUmRXZ1FnNWJjYUFmdGhaZ1ZiaGNKZzZiUmYyZ1JiQmhiYWtlcGdrZmViVWdzZVVkY2JSYjBjZGdSaEJoQmVhZVhlbWM1aDJkY2MyZjljR2VaZXhlWWFTYVRoSGNWZ0tmRWNGZ0poRWVDZjNhQmNhYlFhbWQ5YWlnTWdpYUZjZGhJZ1VhQWZsYkFhVWZJZU1lRmFRZTBhZGVEZVdhY2g1ZVRjVGV3ZVZmUGFRY0VlR2ZGZzNhMWVRY2Vja2RWZGZhS2ZqZzhlQ2ZPYkFhZGM0aFFjeGcxZC9kQ2QwYVlmMGFCZXdjWWgwYUpnZ2dvZlJiUWhIZGtlSGFjZzFlWWFTYmVma2FkYWtkUWhXZDVhS2VaYUhkbGNMYUZiSGdFZWRhSGRVYzBoWmJWZG5iUmh1YWZhamh0Z3ZmVGdYZG9jV2FDZmthVmQ1YVloQmFCZVNkUmVBZnRod2RXY2tjSmR2YllkbWhaZXBnRmRIZ0plT2VjZXhlQmRNYVRiVmFGaEpiSGVRZDFncGdhYlJkZ2crZVNhVmE1Y1JlU2hrZTVnMWFFaFhoTmNNYVVoWGFoaHdlVmZuYlFiUGZhZzFiSWFVZWNnVWFZZVRoZWhGYk5jUGFiY0RoNGNvaFVlUmZOYTdlQ2YwYWdjcmRFaG1kWmRiYVplRmdsY25iU2dqZ2hoNWRIYjJhOGg1YVlkQmJGZG5nR2VWY1pkMGNiaG5iWmF6Z2JmMGZaZW5lRmZoZUpiTWRkY1Vnb2RRZlVna2ZRYkxiY2FGaHBnQ2hiZjJlb2F5Y0VjbGZ4Z3lkUmFYZk1iRGhNaFVhMWdOYlZlUmJWaFdlWWRIYVJkRWVjZEJkVWZQZEdkVWJwZkZhZGJRZU1iT2NRZUhndGQ0YmNmRmZaZDBhRGcyaHRjU2FGZkhoRmJHZUVhM2JoZVRiVGUyZ1JicWdVYXhia2ZUZGNkQWR0ZFplWGVrYVlhQmdEYTJnUmNLYWJkbGI4Y1pmZWFWY2NmSWNjZlFnVWdVZlRhVWFWY1diSWZCZFVlK2ZjYjJoUmJHYmNlMmRzaGVoWmRuYVZkS2hFY0ZjSmFFYkNnM2hCaGFoUWZtZDljaWNaZm1ja2FVZmNna2I1aHpmRWVFZnhiTmFVaFVoa2ZkZkdiaGZJYzhjR2RIY3RlQmhZaHlkeGJLYlVlbWdrZFJnYWMwZVZmUmdKaEhkQWNDYURiMGNkZ3JkV2ZSaFJnbmRPZXphbGU0ZVVhMGg5aGtnYWRsYU1iWmdFZTNnQWZMZFdlVmVZZFNnZWZrYWRka2FRYVdlNWNLZFpkSGJCZUNiR2ZGYXNlZGhIZFVhMGVaYVZhbmRSY3VjZGZuY05jdmRSaG1mY2NXYkVoa2Z4ZjFnU2ZoZEJhU2FSYkZiOGM0YUVmeGRGZGhlTmRIZVJjbmdWY1RnWWFLZWVjMWFOYUNiQWJBaFFoRmhRY1FnY2Q1Y09mRWRGaDRlQWFIZjFjWWZSZkJkd2Y2Z1JlVGQ5YUVnUWFtYmxjNWdXYURjbGFhZ0pkd2RaaGRkSWZRZHBiS2NjY0FhQmdHYmFlRWZCZlRiR2NSZU5od2JDaDFlbGRXYUVmbmdwY0hkWmRFYUZidWNTYW1nUmI1ZFNjeGRSZXhnSGFSZVVlRmRHY1ZiMWVwYWJjbWM1YTZkWWQyZ3hhbmVGYmhoSmNNaGRjVWdvZVFkVWNrYVFnTGRjZkZkcGZDZ2JlMmRKaG1lYWFSYlJieWFUZ25ldGVUYlRlRmVCZVJhQmR4ZjFja2VhZFhmUWdZY2NkRWVGYjBjVWRVY3BhT2FkZ1JhRmV6ZVRnRmdGZTRlY2FGaFpiMGNEYzJjdGZTYUZlSGRrYVNmYWFEY0JkVGVSZkdhUmU3Z0xkaGJrY1BkYmJBYXRlQmRYYnhnSWFtZFJmemRBaDZiSmJqZWRnb2VVaDBic2NVYmNoUmgwZ2RnVGJSaGxkV2ZkZEdkNWUyZ2NkMmg5Z0dnWmh4Y1liU2hUY0hoVmdLZ0VmRmVKYU1oWGN3ZHNkU2NRZm1mUmdpYWRlUmFRZlVnYmZsY0pkemhDYUVkVmNOZkRoVWRsZUJmTmNTaEZhMGNFZzNlQmRUY0NmVmQxYWdhVGhuaFVkUmdjYzBleGJSZWVnSGRCYVdoZGZBaDllcmFVZmhmUmV4Z1JmaGZOaDRjVWQwYzlna2JhZGxidGVOY2FkRGZnaExoVWFsY1ljSGZCYTBjZGQ0ZlhjV2U1Y1NoYmVYY2tlWGJGYkNnVmRtZ1ZjVWQwZlNoVmNtZ0FkVGNlYmxobGZ2YVJkbWNjYVdmRWJrZXhkMWhTZWhlQmhTZlJoQWJ0Z3dlV2NraEpidmdZYW1nWmRwYkZlSGVKYU9oZWMwZ1FoM2VCZVZhRmZDY0ZnVmRrYlVkZGVBYVJkc2hRaFdkeGFZaFNiaGFKZDFjUmZRY2dmRWdVZlhjTmZ3YVFhQWhrZGxoYWIxY0lmVWJjZ1ViWWhUYmVjRmdOYVBhWmNHZHBoVGJHZVJmTmV3ZUNjMWdsZldlRWZuY3BlT2FiZ1VoMWJFZ1NmbWNSYTViU2F4YVJkeGdIaFJjMWdOZEdjVmNaZjBlYmFuZ1plemFiYjBnWmhuYUZiaGhJZFlhUGVRZU5oRGdYZUJoSWdZYmZlaGJzZEdhS2IyZG9jbGJaZzFla2ZuaEFoaWNkYVpoSGZBaEVhSWdRZlZiUmRIZ1lnSGJwZktoUGh4Y1VhNGdXZVZobGZmZGZnQmc4ZitiR2NSYzBkc2VPY1FjWWE0Y1ZnbWRNYUJhSGNYYTFmc2VFZzNnaGdUYlRnMmhSZ3FhVWV4ZWtnVGNjZEFndGFaaFZkaGRKaDZlUmIyaFJjQmRiYmthcGRzZ01hVWVzZ2ZlYmhCZDBjRmRSZUJmVmM4aGRoR2M1ZzJmY2IyZjllR2RaZ3hhWWJTY1RlSGNWYUtoRWNGYkphRWZDZjNiQmNhaFFjbWQ5ZHFmSmFXaGthSmFjaGdoQmQ3aE9oa2F4Zk5hVWJVZWtnVmRUZG1hbGcwZUdoSGdCY0JoZGVGYkZiS2ZUZ25mVWZSYmNlMGJ4ZVJkZWhIY0JmZWhJZEhhUWJqaFVkaGM5YXhnVmIyYjVjNGVUZDFnTmVrZGNmbGRvZlpnVGMzYUJoZmdJZmhoNWh2ZmRobWcxYmtnUWRXZDViS2NaZUhhbGJMZ0ZlSGdFZmRkSGRVZjBlWmFWaG5kUmN1Y2RkbmVOZHZkUmhtY2NjV2RHY2hmZ2dPaEFlaGRCZlpoUmZCaGdnTmNXZ2xkNWR6Yllnbmg1ZmdhRmJDaDVoT2FKZTJjc2ZFY1RoVmNwYkpnQmd6aE5lbGJYY2hkaGh3Y1FiWGRSYVJlU2FrZzVhMWRFYVhiTmdNYlVjWGVoZndhVmZuY1FhUGFhaDFmSWZVZWNoVWJZaGJiTGdDZmdhSGFaYUdjRmdUY0RjR2c1ZHdoRmIwZlZlV2RDY25lTmZIYk9hRWdFYjZiTWRTYXhlNWFRZEJmUmFsZVloQmVGZG5mR2ZWYVpmMGRiY25nWmV6ZWJjMGJaZ25mRmZoZUpmTWJkY1Vob2hRYVVka2NRY0xjY2RGaHBhQ2ZiYjJlb2F5ZEVjbGF4ZHllUmVYY01mSGJNYlVoMWFOZlZoUmVWaFdjWWJIY1JhRWhjZEJhVWdQYkdoVWNwZkZiZGNRZmNjT2JaZGxjRmQ0YmNiRmdaYTBjRGUyZHRkU2FGYkhiRmdHaEVlM2FoYlRmVGMyZFJocWdVaHhma2RUYmVjUWJKY1ZiZmNCYUpoNmdSYzJkUmRCY2Joa2JwZGtkZWZVYnNiVWNjZ1JhMGFkZ1RlUmFsZVdhZGdHYTVlMmhKYXloY2NQYk5nQmdoZEVoV2FIZnNjTGNWYUJmWmVNaFNnSGM0aFhoRmh5Y01mMmhMZnpobGhZaEtiMGJZZ3liR2JVZlZnRGZBaHdhWmdCYkFobWJGYW5mQ2VYY2xoUGFPZ1FnUWNHZ0doamV4ZEJhUGh4ZVZkWmJLaDNkbGNOZVhjZ2Y5Y3JlVWNoZVJjeGhSY2hnTmQ0ZFVjMGI5YWtoYWNsYk1jWmRFYzNoQmFXY2NkMWdZYlNmZWZrYWRka2FRaFdlNWRLaFpjSGdsY0xkRmFIZEVhZGNIZVVmMWRSZ1ZnbmQ5Y3pkZGNtZHRnMGdiYkdnY2FXYUVla2J4YzFmU2VoZ0JjU2hSZkFkdGF3Yldma2VKY3ZnUGUyZ1liK2ZYZERkc2JDY05oaGFCYkVjSGZWZEZlWGhDZUVmNGZoY2ZlUWFOYmFhUWJYYVJiUmdTZGtnNWExaEVnWGFOZk1iVWRYY2hjd2VDYjFnNGFQaGFnMWNJZVVlY2NVZFliVGNlZEZlTmdQaFpnR2dvYkJmWGdFZWNlbGRXY1JhZGFXZEdlbGdCZ0hnWmhFYUZkdWRTZ21nUmc1YlNoeGVSZHhiSGFSYjFkTmFHZVJlQmEwZGNiSGNZaDdhYmgwY0JhaGFQZ0JkSmhNY2RiVWhvYlFlVWFrZFFiTGdjaEZmcGNDYWJnMmJKZ21iYWFSYVJjNmNBZFZma2dRY1RlRWIxZ1JoU2FSZlZnT2FhZlhjUWZZZ2NiRWZGaDBlVWZVZHBmT2RkZFJnRmhzaFRhRmVrZ3NlT2dCZThkbmdBZlNoWWFYZ1dlVGU0ZlVnU2VuaGhlWWhVZW1oUWQrZVhoVWNwZmZkT2dVZ2dlY2VYZ2xncGZ6YVRja2I1ZUJlYmNrZXBla2JlaFVic2RVZmNlUmcwZmRkVGNSZ2xiV2JkZkdoNWcyY2NoMmE5ZmNnWmIxaDhjNGZUYkhiVmZLYUVmRmZKZ0VkQ2gzY0JmYWNRZW1kOWRpYlpjbWVrYlVkY2drYTViemdEYTBhd2JaZkdlUWhCZUdoUWJDZlFoeGJWZlRjOGhUZ0xhVmY4Y1pnQ2F5ZUVoWmJKaDBiSWZDY0xlVGRJYlhiSmdsYjBkcWdDaHhkd2g1aFNjaGRNZitlV2VraE5ha2RQY2hodGJRZFFjSGg1Z0doSGVCZ3RhQmRNZnhoMGFoYlNiRWZSZUtnWmJIYmxhTGZGZUhoRWdkZEhmVWUwZFpkVmVuY1JndWRkZm5jTmd2YVJlbWhjYk1oRWVoYmhmN2hDaFZkOGZDY0hoUWZNZWthRWhnYXNkOGNiaENmc2RzYldkVGMwY2NmS2doZ3hhTWVHY1Jja2FBYVJna2dBZWthTWNWYVVmamhDYUNoNGVVZVJja2Q0ZDlhSGZYZU1hS2RXZkhhUmRhYVZhbmFRZVBkYWMxY0lhVWRjYVViWWFUZWViRmJOZFBnWmRHZnBoVGRHZVJhc2drZlFieGhBaEZkSGNEZmNhQ2RLZlJkSWJuYUVoQ2dGYTVoVmJoZVFoM2VIZFJnQmROY1VnVmE5ZzlmWWdsY3hhemhiYjBiWmduZ0ZkaGhKYk1iZGFVY29lUWRVYWtiUWNMZ2NmQWY0ZktkSmRqZ0ZoTWhhZ1JkUmd5Z1RibmJNZ1FkVGdFZzFnUmdTZlJjVmNPYVljR2I4aHljY2NFaEZoMGdVYVVicGNPZGRhUmRGYnpjVGhBYXhleGVmZUhieGYwaERiMmR0Z1NnRmRIYUZmR2VFYjNmaGFUYVJieWF0ZWtjQWEwYXRjY2NKZUVnUWZOYURiMGhJYS9jU2RTZEFjSWRLY1FkOGgzYkxjVWRzaEpnY2JWaHRmSWFBYzFjb2hDZFBlU2hFZDRmY2MyZGRlUGRaZzBlMGc0Z1RiSGJWaEtoRWZGZEpoRWNDaDNiQmdhYVFlbWI5YmljTWRDYmhhR2FjZ2hicGIvZE9ia2V4aE5mVWFVZ2tlVmZUZG1obGUwZEdkSGVCZUJiZGdGZEZmS2JIZEhia2Q3YmNmMGF4YVJiZWVIYkJlV2FkaEFoOWNyYVVkaGNSZ3hiUmhoYU1heGFVZjFjSmdrZVBiaGR0YVFlUWZIZDViR2FIZEJjdGJkaEthQmI1Ym9iYWMyaDVlS2NaYUhjbGRMZUZlSGJFZ2RhSGJVZDBjWmJWYW5nUmV1YU1oM2hOZ3lhUmZtYlZiRmVSYmhjNGU4Y0JmRmJkZ1FkUmRCZFpodGZXY2hjWWYyZE1oaWdNZm1kVWFuZkloSGVmaHpicGZNY1RhVmNGZkpjRmhVaDVkcGNkZ0JiaGd3ZlFjWGNSaFJoU2hnaEZlMWJEY0hjTmJjZVhhVmZKZHdiVmduZ1FlUGJhZzFiSWRVZ2NmVWRZZlRoZWdGZ05hUGVaY0NjSmZUYUJjQmRNaGtoUWN4aEFiRmNIaERkY2RDZktoUmVJYm5jRWNDZEZnMWJZZVJlUmd4Y0hhUmUxZ05mR2VWZlpiMGJiYW5mWmF6YWJlMGhaZG5kVmFSYkpiUmRkZ1FmUmdWY0JjVWZSZkZlZWVGZU5oWmNSYldiSmJtZGFoUmJSY3lkVGRuZU1hUWVUZ0ViMWhSY1NiVmdNYkJjT2czY1FmUWNXYWtkRmQwYlVoVWFwaE9mZGRSZEZoemNUZ0ZlRmM0Z2NnRmJaZTBoV2N5aE1mYmNSZTNmOGVTY1hnQ2R3ZFNkQWN4aHNmbWZGYmxjY2NUaGJmaGJaaFpmUmVRY0JjUWdSYjJoUmdCZmJka2dwZ2tkZWRVZXNiVWdjZ1JjMGhkYlRiUmVsZFdnZGFIZEZiMmFlZDJlY2hTaFpjd2NzY1NiR2hEaDBnRGRRYzFnd2hTZEdhbmU0ZVpnRGdpZkFnc2hJZjJiRWJkYmZmQmd3ZThiUmZBZ0JiRmRRYkViQWRjYlFia2NOYjBhR2JIZ0JmQmFkZEZhRmFLYVRhbmVVZlJhY2IwZXhiUmNlYUhlQmZXaGRmQWE4Yy9jWGhGY1VkMWdBZ2hkc2NzY0dhd2NZYzNhWmhBYlVmTGRIYVRiTmVIZEZiaGVoaFhjY2ZraDVocWFFaHllRWhlZUtlSGdGY2NjSGVYaGdnUmJOZDBkMGRaY1ZibmNSZXVoZGZuZU5ldmhSZG1mY2NXZEVla2Z4ZDFoU2RoYkJkU2RSY0ZmOWIraEdod2NZZ3JhYWFqYUllaGFYZlNjRmFBZUpiUWJOZkNkRGNoYTBiR2NXYndjdGJoZWZjUmNZaGliRGhpYkFiZGVRZ2xiOWJuY0dkSGhwZ0FhZWgzZWhid2hWZG5iUWRQZ2FkMWNJaFVnY2ZVYVliVGZlYkZhTmJQZlpoR2FwaFRnR2hVZ2RoK2dTaGhoMGZTYkdlaWg0aFBkTGJSZ0phZ2dIZEhkQmIzY0NmRmFnYSthVWgxYWhoRmVFYkZjZ2htY0llU2FJYy9kWmcxZGRlL2NIaHhmdGFBYVhlMGhvZVFnVWNraFFhTGhjZkZlcGhDYWJhMmVKZW1mYWNSY1JieWZUY25iTWVRYVRjQmNsY2ZlRWFWZG9nY2VZZ1NkQmdRZE9oUmVKZzZlQmYxZ3RlQWZPaEVoUWUvYUdhQmdnYm9kUGZBaDlnOGJUZm1jSmJjY1JkamM0ZlNkWGgzZkJjQWdYZG1nMWVrZEhia2J4YWZjSmNFZkliSmhHZGtkdGF5ZkZjR2cxYUlmWWJtY0Jia2ZlaFVoc2RVaGNlUmMwZWRlVGhSZWxhV2hkZUdoNWUyaGNkMmE5Y0diWmN4YVpnR2dRZWplZ2ZmaFhmQWVZY05nV2d6Z3dnRGZTZWpieGJyZmFmQ2ZoYVFhTmhrZVlkMWRHZ1VlQmFuZlVlVWRrZlZiVGJtZGxnMGZHZUhoQmNCYmRlRmFGY0tnVGZuZlVmUmZjaDBneGVSZUxnSGY0Z09hT2IxYzFmamVCaGxid2Y0ZkZkUmEwaHVhUWNVZEVicGhQZnhjOWdOZFdlaWZCaEhjQWJGaDVhVGRjZjBna2cyZERiamNvZEdmYmNHYnBkYWJIYVhhOWRRZ1NoQWhGZk5mSGJ5ZlFjaWVMZDNkc2I4YlRnMmc0YmFhT2dFYnhmMWdTaGhkQmFTYVJkQWV0Z3dkV2drZEpldmdZZm1jWmZwZkZjSGRKZU9jY2UwZFJjQ2hBYkFnUWVGZ1FnUWdjZDVkT2hFY0ZlNGRFYm5mMWVmZ0Nld2JvY3hoR2NUZ1ZiRmhYZlZmSmR3aFZlbmNRaFBlYWExZUljVWRjaFVhWWVUYWVkRmNOY1BjWmVHaHBoVGNHZlJjTWRrY0JhUWVFY1pmUWJIYUloVGhMYkFhZ2c5YlJiRGZKaHFkUmJWaGtna2JVZFVna2JFYlNlUmJvZXRlWmVqZ2RnNmhZYVJnUWJvYlFmbGU1ZEVkWmJsYXNkWmhYZEFnbGFlZVBhQWg0ZExmUGd5aDRjL2VZZ1VmZGc3Z1JhM2I4ZjZnVGdFaDFjUmdTY1JjVmRPY2FjWGRRYVljY2JFYkZkMGZVZVVjcGVPZWRhUmhGZHplR2RGYThhMWZKZVJkb2ZnZlJnamJzYWVoVGZYaGthVmhHYm5nWWRTZENieWNCZWloRmFSZkFnZmhXYmdhdGJaaFZkaGFKZzZiUmUyZ1JjQmRiY2tlcGJrZWVjVWJzY1VnY2VSZjBjZGJUZ1VoMWNZZkxiQ2dFZmtnZWZ6Y3NnT2hMY2thVWFjYUdlbWJGZEVkWGhRZ2NkSWZYZ3pna2dLZkRkamVaaHFlSmgyYkFjYWRJYkFhRWFuZlhmRWVSZWVoUWhFYUFlYmhBYXpkd2U0aFRmRGJrZ1JnT2NBaGhnQ2ZIY1hhd2JZZ2ZhMmRaZ1JiZWNIaEJoV2dkZEFkOWNyYlVmaGhSYXhhUmdoZU5iNGdVYzBkOWVrYWFmbGhOaE5mSGJUZzFhZWRGYlFhSmRiaEtoZ2NzYTliU2JUZDFhRGVhZmphZ2dQaFVhSGFsY2JnRmZFYlFnemhWY25iUmN1YmRkbmFOZnZnUmRtYWNoV2hFaGtkeGgxaFNkaGVCZ1NjUmNCYUZmd2RVZmhoWmd2ZGZhMmJZZjlnWGZEYnNkZGNmZFVmTWdKYkNlQmFWZUhjVmNnY0ljbWZPZGxkMWM0YlNhSGZvZVFnRGdnZ3BhOWRYYVhocGZGYlhoVmRKZ3dlVmZuYlFnUGJhaDFlSWhVZGNlVWNZZlRjZWFGZ05oUGdaZUdncGdUZlRkUmIwYXhnVGh4ZTFnZWhVY1hnUWVCZ05hZ2c0ZGplSmNEYUVkMGNDZVZjRWJqZUZkVWZrZ0ZlVWRBYVZmNmdPZmpia2ZuZkxmZ2ZvYVllV2VsY2NkQ2hmYUVoTWVMYmVjRWhRZ0xoY2RGaHBoQ2JiYjJjSmJtZ2FoUmRSY3loVGRuYU1lUWNCZkVoMWdjZ1NjUWExZ09iZGQyZmtiWWVQZTFocGZlYmVoMGhwZ09oZGVSZ0ZjemNUZkZkRmY0Y2NoRmhaZjBkRGgyY0pmNGVGYUhmRmFHaEVnM2JoZFRkVGUyZFJicWJVZHhha2RUZ2NhQWNzZ2NnZmFCZkpoNmNSZDJjUmFCYmJha2NwZWtkZWZVYnNlVWZjY1JlMGhkaFRiUmZsZUpoZGdDZzFkNGVOY1RhMGhKZEtjbmNSaGJnR2hDYlpiQ2RPaGxmSmRFZkNhM2NCYWFhUWRtZzliaWVaZ21ma2JVZGNia2E1YXpjRWZFZnhoTmZVZ1Via2hWZ1JiaWNCYTZkV2N6YmdkQWhKZGphSWFGY0NkamhCZXdmSmUwZFFmZWZlZEhkdGFXZVpoUWRaZHJmVGNnYWhieGJYZWhjcGY0Y0RlMGg4ZnRmWmVCZUJkUmNVYWlmSmRvaEZkaGVKY1hoR2N4Zk5lc2ZEZm1lZGZHYlRobmRsY0xoRmhIZ0VnZGZIZFVnMGJaZVZhbmVSZHVoZGFuaE5idmVSYm1kY2JXZ0Vka2Z4ZTFoUWJsaGxhY2ZCYTBkTWh4ZENlQ2ZFY2dkSmVpYk1hSWhRaEhib2dCYWNoeGJ0aE1mWGVsY2hlSmZDZVZhSmdwZWJhQmJGY3dhSGRYaFFkWWFSYkFiMGU5ZFVkQ2hFYnZmSGFqZXdnMWNOZnljQWFIZEplRmNJZmZhY2ZWZlFiYWVkYkhobGRQaFplR2NwZFRiR2ZSY05md2hDZTFkbGRXY0VlbmRwYUhoWmJFYkZkdWVTaG1hUmE1YlNieGR3ZTRlRWQxZTRiRmVXZkFkUWRYZElmVGZJYTJnRGRoaEpmdmJXY1JjSmhIZmRoVmM4ZVpiVWdsZmdjWGFjYUVoSmVMYmJmemg1Z21mSWZCZW9jeGFCYWpnSmFDYkxmd2ZJY1ZkRGhIaFFhYWJZYlRoc2ZZYmViMGFGYmdiV2ZFZlpna2hkZFJmRmZ6ZFRjRmZGZjRoY2RGaFphMGJEZzJldGJTYkZoSGJGZUdhRWIzY2hlVGNUYjJhUmFpZUdiaGFkZlFnT2hFY29oTGZOY1ZhMGErY0FlZ2dVZlZoWmZnYlZka2JjZWtoc2JEY2VkQmEwYkJoVWNSY2xnT2ZmaFdnNGhxY2NieWVaZkloSmZGYTVoVGJIYmhjWWJGZ1ZjQmFjaGxjWGMzZWdlVmhRZ21nUmVpaGNlR2RBYytjY2RrYTViemFFZ0VleGZOZVVlVWNrY1ZoVGdtZmxkMGJHYUhjQmZCYWRiRmFGZEtkUmQxYThnUmNjYTBieGNSaGVoSGZCaFdiZGdBZTlicmdVY2hnUmJ4ZVJkaGFOYzRlU2RVZThmbmZaZEJiVmNMYVhiRGYxZ3BiRWhBZEpiQmdjaG1iMWVrZlFoV2U1Y0tmWmRIZWxjTGNGZUhhRWhkZ0hkVWYwYVplVmFuaFJndWNkZW5kTmF2ZFJobWM5Z2ZiYWZRYU5hMWFRYlJoQmdEYU9oUWh0Z3NjUmNrZkpoM2hhZTJjWWExYUZhRGRzaDFmUGNHYjFoQWJaZTFmRmNKZUZmVWg1Z3BnZGZCYWhhd2FRZlhnUmVSYVNia2g1YzFlRWJYYk5nTWhVZ1hiaGN3YVhoamIxYzBjSmhGYklmZmRjZ1ZlVmF1ZGVhRWM5YVRnWmNIZUpiYWZHZVVmOWd3aFFnaWVJY1pkRWFuYkZnSGJkZWpkeGdpZ1llR2RSYjVkU2V4Y1JieGJIZFJkMWNOZEdiVmdaYjBiYmJuZVpjemJiZDBnWmVuaEZiaGhKaE1jZmJRYU5ocmZIZlViUWZBYmNiRWQ4aC9nYmUzZzVhNmdhZVFkeGE3YVRjaWU4Z1FkQmFUZ1loZWdTZlJkNWdPY2ZhUWdrYlViV2JrYUZjMGZVZlVhcGZPYmRlUmZGZnpiVGNGY0ZlNGNjZkZoWmgwY0RoMmN0YlNhRmFIZ0ZiR2dHZ3pjRWRvZUFjR2ZSY2hlVWF3aDVkdWJjYkJkZGJGY1ZoZ2NwaHpjUmF6YmhlQmZKY3pnRWJyaGVjVWhBYlVkWmIyY0FiM2FUY1JmbGNXZWRiR2I1YTJhY2QyZDlnR2RaYXhlWWVTYVRnSGVWZktiRWhGYUpjRWhBaG5leGZ3Z1FlbWg5aGllWmVtZWtnVWZjaGtlNWN6YUViRWF4Yk5jVWNVYmtnVmRUaGllcGI2ZFZlU2RVYU5nSWVCZ2diYWRBaGlid2ZaZE1ha2ZWZGZoS2VqZzhlQ2NPZ0FiZGM0ZlFheGQxaC9oQ2UwYllnMGZCYXdiWWIwZkpkZ2FvYVJnUWZIaGtoSGZjaDFoWWNTaGVia2hkZWtiUWVXYjVnS2RaYkhobGhMZUZlSGhFYmRlSGdVZTFiTmhXZENhd2RoYkpnSGhzYnNiVGQyZmxlRWdYaFJmZ2Q1ZFFoZ2VKYkZiVGNRY1VlOWFEZ3dlNGc3YktkemRZZWxmVGVYY29iZGNlZmhhNGNOY0NmUmZWYkJmVWIwY2RkbGNYZmhmaGJ3Z1FoWGFSYlJhU2NrZDVoMWFFZlhlTmJNY1VnWGZoaHdoVmRuZFFhSGJKYkZmSWFmZmJkRWJZZ0xiY2JVZ2hjbGJaZUdmcGVUZ0dkUmVOZXdoQ2cxY2xnV2FFZ25mcGdIaEloZ2c0YThnU2FtZnhmVGNTZXhhUmV4YkhnUmMxZU5hR2VWZFphMGhiZm5lWmN6ZmJkMGdZZ3ZhRmJnYXhnUmZkZFFnVWNRY1dkVWdRZmZjY2VGZnhoRWFSYldnSmdtaGFhUmFSYXlhVGhuZU1hUWhUZkVmMWFSZ1NiUmFWZE9kWWdUZEVoeWdjZEViRmMwZVVlVWJwaE9mZGdSZEZkemhUYkZlRmg0ZGNlRmhaZzBkRGQzaFJnU2VWYjNmOGZBYVFkVGRjZWVnTGJTYjBjK2NBZkJnRWE1aGNiQWd0ZFpoVmhoY0phNmNSZDJkUmVCY2Jka2hwaGtkZWZVZ3NmVWZjY1JlMGRkZVRjUmVsYmVoUGZXZEFmMWJPZXlmNGFVaEJoRmZsZ1dkQ2dSZ1FjZWhHaEJlMWZFaEFhSGNCYkxkU2QyZzlhK2NlaG1oa2ZNaGVlMGU0aHZmRWRBZVZoRGZFaGdiRmVVY0hkQWNvZDdoWGJEZlVnZ2VJY0Zha2VGZlJjM2FraDdmY2gwZ3hhUmZlZ0hhQmRXYWRjQWQ5aHJjVWhoZVJheGRSZGhkTmU0ZFVoMGM5Y2tmYWRsaE1lUmhXZ25hNWFJZkVjUmZkYkFoR2RRY2diZ2VCZ0FkOGVlZ2JkRGhaZkxkSGYzZ0VlT2FGYkVhMGVGZVNibmJSaDJhZmIzYU1kemJSZ2lhNGFZYlVoUWRRZjBlR2dIZk1mZGRBZkVkNGNSZERia2hvZmdnWWVtYjFicGVCY25ndGhDZFdoUmNCZE1kVGhWY0ZoSmhGaFVkNWFwaGRmQmdoZ3djUWJYYlJoUmVTZmtlNWQxZEViWGVOYU1lUWJYZ1JjYWJWYm5iUWhQYWFhMWRJYlVlY2FVZVlmVGRlYUZoTmJQZlpiR2VwZFRoR2RSY05od2VDZjFkbGRHYk9hSGVwZEhoWmhFY0ZjdWdTZW1nUmE1YVNheGFSZHhkSGZSZDFoTmRHZFZiWmMwY2JobmM5Z1pnYmcwY1plbmNGZWhnSmhNZWRmVWdvYlFhVWVrZFFhTGdjYUZlcGhDaGJoM2doY21kS2VoZG9hMGhIaERoeGdkZ0xiZ2RRYkZkR2NoYjFia2dhZlhmUWFZZGNhRWVGZDBjVWRVZXBmT2hkZlJmRmV6aFRoRmFGYjRhY2FGYVpnMGFEaDJldGNhaFhoUWJvYUphRWgzaE5jVGJYZGhhbGdxZFRmd2FVYlRiYWdBYUpjWmdDaGhiSWJ6ZlBiQ2hzYzhlWWJtZUJja2hlZlVoc2NVYWNlUmUwZmRkVGJSaGxjV2dkZUdlNWIyYmNjMmM5YUdoWmd4ZFliU2NUYUhlMGZEZWFieGcxZEViQWJIYkJmSmVQYzJlOWYrZWVlbWZrZU1nZWYwYjRldmFFY0FmVWMyZ0hoa2ZraGVnVGRuY3NlSmhGZEZlcGdCZ2RnRmJGY0thVGNuYVViUmdjZzBkeGFSZWVnSGdCZ1dhZGFBYjljcmRVY2hlUmR4ZFJkZ2FOZzBkZWVVZzlja2FhZ2xkTWRaZ0VmM2NBaExoV2hWZllkU2hlZWtnZGVrZVFnV2Y1ZUtjWmRIaGxjTGdCZkZic2hkZ0hoVWUwZVpoVmhuYlJjdWFkZG5lTmZ2aFJmbWRjZldoRWJrYXhkMWhTYmhhQmhiY1NnQ2NGZHdnV2JraEpndmdZYW1hWmdwYkZkSGJKYk9lY2N4Y0JoTWhUZ1FkVmRIZFRjUWNFYzdmZmRGZ3RnK2REaENiRWRkZEhiZ2FjZmxoWGdTZXBkRWNBZG5hRmQ1ZVdiQ2JaZEFiUGd4aDRkY2hZYTFnVWVhY2RmaGM0ZmFiS2NEYjRkYWNTaFZhOGZwY0FmeGRoZmZiSGhEY3NmRGZJYUVha2c3ZFFjMmRoZVRhU2h4YlJoeGhIYlJnMWdOYUdmVmFaZjBiYmNuY1pmemViZzBjWmJ2aFdkUmVKaEhnYWZFZ29nRWRXYzBhMGVRZldnbGZwZENjYmEyZkpibWhhZVJkUmd5YlRlbmFNYlFiVGZFZzFkUmFBZlJkVmZRZGFoVGVzYkRlV2NtZXRnMGdVZlVocGFPZGRnUmJGZ3pnVGFGYUZnNGRjZkZnWmM5ZUpiV2F0ZVNoRmVIYkZlR2ZFaDNiaGhUYlRoMmVSZ3FoVWN4aGtnVGJNYndlVWVmaEJlRmUwYzNnSmNTaDBmVmRQZFVoSWhoZWVnVmdRZVViT2hCZU5hZWdCZ1ZlZ2JFYkZjeWVFZnllTmRnZDRoU2ViaDFoa2daZVJnM2h4ZEtlQ2ZsZkljTmVjZ0RhOWdSZlNjUmZKZ3VhWmJuZWtkWWVjZ2xmNWUvaEVhRmF4aEVhWGVXZU1mVmVUZG1obGEwYkdiSGhCZUJoZGZGZUZjS2FUZW5mVWVSY2NhMGV4aFJmTGhIYjRiT2JPYTFnMWNqZUVnUmVvaDhnRWgxYzhkc2FHY2hmOGZvaE1kMWV0YlZjR2FuYmtnRmdDZHhibGNHYk5la2U5YTFmVWRHZGRmRWNLaFNnd2NIZVFkRGdoYk5iVWVSY1FkUmhCZlhlMWIxZlhjSGJOYXZiUmJtYmNiV2dFaGtmeGgxZ1NnaGNCZlNkUmFGZGtkMWdEaGhlY2M5YkxjR2haY2hkUGVuY0pmT2FjY3hiQmRNYVRhVmNGY0poRmZVYTVncGVkYUJlaGJ3YlNnU2JaYlJjVmQwZzRnaGRIZnpjQWZBY0hnamFZYzFjWGRuYzBhQmZPZUJhcGhkZE5meGRKaGhlTWFSZlFoSGRNZUdjSmNBZ0NkaGhwYTVlQmYzZ05hV2RFY25jcGRIZVpmRWNGZXVnU2FtZFJlNWZTYXhhUmh4Y0hjVWFsZ0RmUWZSZmthbWRaZmlnUmQ2Z1loUWZzZ3liV2VrY1liRmRKYVFiWmhKYldmZ2hVY0NnZmdIYUJkQ2NiZTJlSmVtYmFlUmRSY3lhVGRuZk1hUWhUY0VkMWZSZVNjUmIwYmNhYWFXYWtkWWhKZkVlOGEzYkhoUWhVZUFlTWZCYWxnNmJRZmdoSWd3YU9iUmdBaGdoZmRTaElmVmVYYUNjVmRPYkFlV2FGYWFoUmNtYWhlQWNVYXhna2dUZGNnQWN0YVpmVmFoaEpkNmFSYjJoUmRCYWJna2dvZXdjZGh4ZE5kYmdJaHhhVmZQZFJmQmNjZmJmSWFTYklnaWRPYWpkOGVLaFBjaGg1ZEhkUmZYYWxlZ2hFYUZnSmdFY0NhM2VCaGFmUWJtZzloaWdaYm1ia2JVZGNma2Q1aDdmUWJrZXhlUWNVaFJhMGRiZERhU2NVZzdlVmJqYlZlSmRmYVZjOGdaZkJoamZ4ZVhkSmF6ZDRnWWVQYnphZ2NDZWZiQmR4ZTViV2N4aDFmOWdiZkJnTmY0ZlVnMGM5ZmtnYWFsZk1nWmFFaDNoQWZMaFdnVmFZZ1NlTGFrZWtjOGhEZ2pleGNDY05ibmNCaEhlUGJuYkVoZGdIZ1VhMGZaYlZhbmVSYXVnZGZuaE5odmNSY21lY2NXYlJhZ2hRaDhoR2dSYjRoYmFDZmtlSWdrZlVmaGJZZm5lS2Z6ZlZlbmFSZXpkY2VMZ05leGJsYUFoWmgxYkZhSmVGYVVnNWNwYmRiQmJoYndlUWRYZlJiUmNTaGtnNWMxaFJiVmVsZk1lVWFYYWhjd2JWZm5kUWhQYmFmMWFJY1VhY2ZVaFlkYWVZYjNibGRQYlphR2RwY1RkR2NSZ05hd2hDZzFhbGhXaFRlM2hOaExlVGNraEZndWJTY21hUmM1YVNneGdSYXhjSGZSYzFiRmJUZlZlZ2N4Zk5iaWhZZDhnUGFSYklnMGRGY2dhOWNNZ09ja2ZNYkxkZWZFY1FlTGZjZ0ZicGhDaGJmemM5Zm9mS2VsaFVhK2VBaG5idGdDZFFjRWIwZllhUWRRZFZlSGVaZnhmWmVOaE5iZ2FjZ3hhQWgwYU5hSGViY2pmdGh6YVRmRmFGYzRmTGFWZ3BnZWZEZTJkc2h2ZEhjV2JwY3NlVGNuZUZjSWRaZVVmNGVtYkZla2cwaFRiT2JFZFFkS2dBY2xmd2E3ZUNnaWRGYkJoY2IwYXBjamhmZGxlQWQrZE9iRmJzZGRkUmJVZzBlUGNKY0Nhc2Y1Zk5oV2g4Z1JmTGNsYmhoV2hBZHllSmVLYkRoVWM5YVpjQ2IzYmNhUGZEY0Nmc2RuZ0liQ2hCYmFjTmR3Z3BlMGVFZUJnQWFSaFVlUmRkYlphQWFTZ29iMWdUY0Ria2RPaE9lbGY4ZkNnSGhEZ0JmWGdmY1FhVWJmY1BhRGVVZ09iR2cwY2xoamVVZkZiWWY5Z0NjVmhGZmlhVWdVZVpidGFhZ2doZ2V6ZkVoM2ZCZERlRmNnZVZhR2JOYkFlWWVwYUJmR2M1ZFhoWmFIZ3NnY2RXYXlkTmVXZ1dkQmc4ZGJnVGNWZzRnemNkZWpnWWJqYkZkU2ZJaFdnU2JXYVpnMWVTYmtoUWNBZ0hmUWFzYnJkY2JFaEpkdmdZaG1oWWFoZFdheWJFY2FlUGVWZEVoQmZDaEZjRmdVZkZjVWdZaG5hTWZVZDlkd2ZOYkFhWWI5YlFoZ2JJZjZmVWdqZkliWWJHZURoY2MrZldjRGZ4Z2RmTGJoYlFkZGdlYkVkaGRiZk5nd2RBZWJlS2hpYXNiZWhYaEJnTWFzZFZnMWdsZFVlVWhEZ3NlRGdaZmxicGJFYVNmbWRRZ2tlU2IxaGNjd2ZTaFZnNGhGaEdkVmQ0aHhnWmUzYlljb2dSZVVkWmhuZUZkaGRJYkVkT2RoYWxlRWZIYkFhVmFHZE5lVmhwYmZlYmYyY0FoeGdKY2tmWWM1YkNheWRFZVNhVmQyY2RmUmZTZFVnaGJraE5nRmU0aHloUGJBYVFkZ2FVZVFmOGdLZkljSGNVYjhhQWZSYkFmeGVQaGxmWmhwYURkeWhNYmRiUmR5ZlViSWZVY2piVWNXZ1FhU2FFaGtiRmcwYXBma2JPZ1ZnOGJSZVhjaGRWaDBnQWVpZ0FkVWFhYVVnTmQvaFVkMmNGZ1lnTmdFZGtnZGVHYVViMWZOZFhka2dSZDVoZmNHZzhobmZOZkVkVmRiY0NkemN0ZUtkUmNBYlpoRWFYZURia2RPZ0NkbWE4YzJnTGVpYndlVWNJZVJob2doZVdnUWZJYUthVWVVZjRiYmdDY3lnMGRoYkhiM2FBZkljTWdsZEVhZWdCaGpnQWdSZU5nd2ZNYmNkT2RUYmthWWNkZEVnb2RsZEZha2JkZnhoRWFWZG9jc2dHZzBjOWhqaFpiQmRaZWRhUmJuY2NlSGVXZ1JhbGdHZ01mZ2FJaDJlRmVpYmNlWmhJaFhha2ZOYldlemIxYVJiVWdoYm9lWmVHYlNkWWZuZk1oVGdvZGhoQmJ5YXNjV2RYYWdiTWV5YUFlMWJOYTRjRGJVZjFld2ZVYWdjY2ZyYU5md2NJY21lV2NUYk1jSGhQZFJnbGdNZ0Zlbmh0ZkpjRmFSYW9lOWdkZEFkVmh3ZlJjbmRvaFVnRGNoYXRneWJDaGxja2dSYlVoVGEwZjhiQmZUYkVhUGhNYkhmZ2ZVZWNoUmhKYUhoZWZFZzVkUGhaYldoc2NVZ1ZmVmJ3Y3liU2doZlVnaWJXY2pjTWRVYWFiZ2NRZjRnQ2J5ZWdjQ2RPZUVoQWVqYVZiRmJNYUtkRmJ4YkFjbWVJYlRlc2FRZkloQWFJaGlnWmNsZzBmRmFPZnhoNGVZZ1NhbGJVZFNjWmVWZU1mL2diZTNoMWJtZ0xmbGZnZTliRGREZ0piY2dPZ0FmVWZZZ0diaGFzYWhkR2d4YVplb2ZBZ2ljNGVMYU9kaWM4ZTNmZGNVaDBidmdUYkJka2MzYklnd2VJZzZiVGNpZllnWGdGZkdmdGFHaEdnemI4aGZiQWRDZVlicmNIZDJiMWhiZE9jVmNoYVhiT2RXY0FjWWJOZHhhWWJ1ZUVoU2FFYkJjQWFFZ3RhSWhMZFJjMWJWZ0Fha2JvYUNjT2dpYThjN2hOZG1oWmNHY2JlQmJZYlFkVGVIY2RiUmVPY2djOWF1YUlmVGRNYlZkRGVEZndlMmRaYWliOWVTaGNkbGdOZ3pnVmh3YUFiQ2VFYndkaGRaZk9naWdFYTlmU2gzYTRmT2NKY0JmUWdFYUNleWVjZGZkRGdBYzRhRWdQaGplWWVlYVpoeGUxZmpoUWNoYjFoL2dFYTBmTWI4YUVoaGRzaGhmWWVnYmRkTmdHYm5oNWZQYkVoQmdGYVhiS2VSaE5ic2FTZkdiQWJlYktnd2JvZGZnUmJqZWhkVGJXYWtnVWdJZ1FkSGUxaGdiSmhqZklncmZOY1RnTmZYZ1FkQmZoZjloV2V3YlphZWZSY0JhdGQ1YVZiQmVZZ2djRGRpZmtjK2dVYVNnQWJ0Z01oa2ZNY0pnUmdWY2hiU2dQYXdma2JsZE9lMWVvZHhmRGVRYUFoWmFBYXhmMWQ3Z1hnaWFNZUpnSGZ6ZDBmaWdWYW1ha2NQYUxnQmM1YmJkTWR3Z2RjZmJEYkJic2VHY05nMmJRZnNhVmNraE1mMWNSZFJnd2FFZkNnVmhBZ0RmSWhRYjBocmJIY2liRmU1aERhRmNnZitkWGQxYXdkQmViZlJkNGc5Y1BjWGJnZTJlT2NRZmNjcmNiYldjRWVZZEpjd2dOZ2ViRmNVZXBlTmdJZWhkVWRQZkRnQ2MwYmljTGhHZ1FlOWFCY3phMWZFZ1JiRmNWYUFiVWVBYUJjSGVGZUdoOGN5ZWVjQWhjZWhnSGZ3ZmtmYWRQaEZhNGg5YVJkQ2I1ZW9nS2RFY1JmamdIYkNmZ2JUaEFmSGcxYkdhYmZHaGdnTGRYZUhmMWgrZFFibGR0ZldlZWdRYXNjQ2FWZWtmUWQ3aEZhV2ZRYStjZmZoY0pkMmdQYXdla2hBZWFoVmNnaGRoVWVCaGtjcGNaaERlWmJuY1lnSGQxY2VhYWF4YVpodGJYZENjMWRlZ1VhaGNjZUFkVGUyZlZiYWRYaDJjOGVkZWRoamdFYUdjWmZWZzBkd2hVY1ZlaGFGYVdhRmhJZFZkR2FTYkVkOWNWZERoVmhCYmZnRmJCY0xiTmRRZ2dlWWVjaHhkZGJSZkxiQ2RJZ1BoZGhGZlJocmdCYkZiVWZqZVJibWR4aG9lQ2IxZXBnMmNmY2tlSWhQZEFmSGVBZldlV2VRYlpmVGhLZkJmUWJoZUtkQ2ZBY2VoYmVBZlpiYmNUaEdmTmNiY1hiMWFrYkJnRWYzZ3hoK2VMZG1jSmg4ZlZjR2M0Y2ZlRWRrZk5mMWRXZmtmaGVEZ1JoQWFGZXdmVWdoY0lndWRNaERmVWdzZmZoVGF3ZmFjZWcyYjllY2RGZFVkTWJQZ1ZmMWJwYnhoTWZSY0JnZ2RHYldlVmhEZUNiVWJkYzhhRWNYZXhoTWZRaFNiQmdpZlhnM2JRaEVoYWF3Z0plVmNJZXhhVmVXZkVmUmMwaGJnYmhCZ1ZiRGJRYlFkRWQyY1NkVWIxZU9kVmEzaEpkWGJQZUZlQmQ5YVhhMmUxZHdnU2J4YnRleGREZ1VhVmdlY0doVmd4YzBiWmZuZHNoamdMZ2hjUWYwZlVnM2VzY0NlSWFVYkpldmdRaGhkd2FaY05naGFoZFdoZGF5ZmRmdWJlY1VieGZqYlhkV2hjYlpmUmFVYzFhZWRTY1FhVWJXY2ZjWGYwY1lhZWQwaEVma2RFYUJkZ2JkZ01oSGdnZzlkR2JGYWtnSGhZYkFmNWRtZlNkU2NsYkdkRGdEYlJoT2hBZ3llQmNDYlhkU2FaY2pmV2JoZGtjY2VjYUJic2FCaFFoeGdKYXdnUmcyY3djUmNMZXhiZ2IzYVBoQ2FKZmFlSmVSZlZlaWNYZlVjRmNFZU1maWJ4ZWlnYWF5Y3BkT2hkZDBmNGNEZFhnMmVKaERkR2VWYUpmTGJDaDJiQWZDZlZnR2haZ2lhYmVXZGtjWmNJY2djOGRoY1Fnd2RraGtoSGZ4ZDBiZGFNZFhla2ZzZUNjamFZYURoWWdFY2toUGNSYW1mVmRKZVllbGg0YlVoY2NYY2xkV2NlY3dnOWM3YUNiZ2FOaHhjVGRSZ05kMWdBaHdmNGQyaE9iUmNaZXdiWGVTZVFoRGNKaGtiWmdLZmFnQWFFaG1jVmZYYVloUGdiZUdla2FUZUJkV2VJaE9mRmJFZ1FnWmJXZFhhUmMrY0xnbWF0YXZmVGNXYWRjR2dVZXhjNGdtYURkM2hrYmNlRWJBZE1jUGVTaGhkcGc5Z0phQ2FSYzloRGhEYWRmR2hZYjBkaGJkYlhjeGVWZEFmSGJFZDVkbWNkYUFlZ2JvYldkSGFSYWJoU2hrZVpjNGNRYlRjSWVlZEFnamYwZlphR2RDaEFjSGhGZEVoSmFNZFlmd2VCYlJoYmdFYXNiS2JiaEhnb2JMYkNlQWVFZjJkQWhsZ0JmV2NIaFhlcGJYZ1BhQWZCZm5iU2NtZzlhNWFHaDFkVWVqZVRnbGhnYWtlVmR3ZkpkOGFFZVdoWWhyZWZjUWRBZ2xlQWZnZm9lSmNmZVZocGhJYVFnMWVjYWFkZWRWYU5iQ2VZZkdjSmgyZE1jVmVaYnBjVGVqYnBmV2FUaEVoVWF1Y1diVWQxZ2JjZWUyZUFiSmZaaGxoSmYwZVRhRmJkY1RlZGhXYzVjamJGY0VjSmdoY1pnRWJjZzJnU2htZUphU2dWY2lhTWJEaFVlamROaElmVGN5aEVhbWRBaEZld2VUZURneGRzZUJiUWNsYUFoL2dBZ3loQmRVZkZnVWEwZTBjTGdCZWhnY2ZkZW1lQWdWY01kZ2RrYU9jWWRDZ3djemZOYnlkdGhUZEhjQmFGZEJjQmJEZndlTWdSZ0ZkVWE1ZkFiM2dsaFRlV2VXZjhjL2NaY2locGJWZUpiZ2MwYjdjRWVFYlFmeWJRZ1JoRWRHY1diWGhzYndoV2FUY05oSWRkZ0FjcGJLY01iV2NWYUpmWmJ3aDRlVWJQaERkUmdEZURhd2RnZjdnQmMwYWNiNWNRY1djNWJ3ZkxoRmI4ZDhlZmhoZ0ZnY2RWZnpnUWVlZEllbGdGZkJmTWhnZTRkaWhGYVdja2EzZWJjSGVCZkNmRGgzZEZoQWRIZFJhQWZaY0NoM2R3Z1JiWmNpaHRhNmJCaEhmWWFQYkhha2R4YmxhRWZnZ0lkVGJBYUJjeGFrYVVmMGN0YjBoWWNpaEFkOGVXaGphRWVhZ09kbGE4ZUNnVGRRZ2tmUmhUZlJkd2FvZ0pmMWZ3YTJoRGQyZmRmWmZRZDBoNGV1ZEVmU2g1ZE1kRmZ5ZzBjK2NGaFNiQmRHY0pnQmR3YVVjRGFsZlpjTGdiY1JiRmRlY2ZnV2ZKZGFjR2FVZ2hjd2FYYVJlZ2FFZkViZ2ZWY1hhUGJBYVZkOGREYm5nSmJwZldjUmJSZHNkSGJXZlpnS2RDZTBiSmN0Y2VoV2FkYnJiZWZ6Z3djVmFmZFdic2MvZk1hVWEwYmNlVWJrZE1lWWZhYlVkeGdhZkFiaWQ0Zk5nS2RGYUlhTGFTZ1hiOGhRYlNjMWY5ZkdkV2hsZndkMGhPY3hlTmJvaFBka2NaZDRlVWJVZzBibWZNZ0ZnMGgvZEFoeWMwZmdjWWVrYlliRGZRaERha2hlZ1VnSGFCZEJnSGQzZGhlVWFYaEhiVmN5ZE1mRmhwZVpmTmFYaGdicGFVYVJhNWI2aFFlSGdaYlVnZmRsZ3hkMGNIZmhnMWZrYkVkMGI1Z2FoU2hoZFZlV2VjaDNlOWRrYVlnSGJrZUZoRWdtZFZlQ2dPYnhkbGVOYUhoRmRKYURnSGMyZFJmTWFXaDNnc2ZIZ0xmamJwZG1lTmJDZHBnMGhIaEVoeGZLZVFoMWRrYUhhVmFuYkZhbWVEZEJhb2dJZEJkQmM4YmRkSGZIZUloZGRjaDBodGhEZWJlbWJBYXNoUGZuZHNiOWdLYUhhWmEyY1NhaGJOaC9mSGN3YkFkamhiZVZhOGRaYUZnR2FjZ1NhVGhFaEloTGhhaDFlTWdyYk9oUWZZYXViQmN5YkJkTWZHZ0hoRWFhZERnRmU1YXFmUGdqYUFkTWZIY3hiOWdvZ09lM2Z3Z1dmYmZWY3dmdGNYYjFjSmNEYlhkUWh0ZHRkV2VnaFFiNmdMY0NjVWU5ZVhiVGgwY0FlZWh4ZmxlTWFGY2xhRWhiYVVlQmdvZDhnSmVsZFpnd2NQYW1lUWZKYkRibGV3aHhlQmcyZk5iZWZTZG5jZ2V0ZFRoWGNSYmRkTGdnZFpmQmhJaHdnZ2NUZkJjMGJNZ1hiY2ZTZ2hkQ2dBYUJldGc1ZEVhRmVraExmRWRqZndkU2NLaGdiSWM2Y0FjeWZzZzNjU2QyYnRoaGZSY1FleGdlY0NiMGY1ZDhmRWNXZFlhcmFmZUZhVmF3ZURhd2FjYVBkZWdVZ3BndmFRYmhnd2ZlY05hRWIwY0hlZmhuaEpkdmFhZFVlOWh5ZEdiRGZKZENoVGVEZUpmQmhFZlFjQWRNZmVmR2gxYmNlTmZrZkZlcGVVY1RkVmFlaExiUWhRZXhnWGVVZ2hid2JlaFViMWcwZ1hoU2g0YUdoUWVTYk1mSWJFZndhZGdEaEZoM2VWaDVhUWNRY0VlVGhiYVFnc2hmZkFjMWd3aDVkRWN5ZjBiT2RJYkVlSWdiZ2FiUmRNYkZhWWhnaDhkRmZWYVFkbGRhaGRkQmdGYm1lS2czZ3BiWGJjYzFhSmhVZ1diSGh4aEtnU2UxZ0lkN2NHZXlhaGJMY1VoWGMxZzZhZmduZGtnVWJiaDBmNGVNZ0FhQmNSZGNlUWZsaHNlTmRWZ25ibGgwZUZiWGhCZ1JhTGhFZEJhWWZEaEdkNGRSYUpnUWgwYURhZWhBZTlkR2hMaEJjMWh6YUZkQWNKYWthVWVoY05mbGFVZXpnQmIwZ01ka2RaZmJnQWNtZ2xiUGhIYXlhMWN0YmFmaGI5ZDFlVWZuZ3hnU2VmY0doa2YyZ0RoM2JGYlBiV2hCZGxlTWRCY0RkcGV1YkNkV2FNaDNkVmZIYjlmUWVCaEZjbGVoYlVnUmJBZVBkU2ZBYnNlUGZTY2hhcGcrZmNhWGFSYnhiSGhBYzFoZWFLZndjTmNmaFdna2ZoaGNjVmJrZUpjcGRDZXdnZ2dvYlZnRGJCZUdkRGUxZDllbGJHZUdlaGNNY0RjSGdnZW9nRGFpYXhkZGRLYmdiRmdRYk5od2FnY0FnY2NGZnBiVWFUZ2toQWNkZVhjRWhSY3dhYWFnYXNhRWNVZnllTmhQZ2NibGhWZW5hUmRDYzRiMmRBZ2xmcGc1ZldhMWR0Y0VnQWdsZVpjMGJZZlhkbGR6aEdod2c0YnViUmFSZEljYmFQY0FjWmhjZ1VnZ2VaZE9mY2dBaDRiS2FLYm1mSWF3YUtoRmRnZG5jQ2czY05oQ2FDaFJla2VFYUdkMWJzYkxkTGNYZlJhYWZLY1VoRWF4aEJhd2NzaENhWGN3ZD1hPQBtOXZUTlZTT2ZHNjJsVWowcmQrUHpiT0JGSTRSblMwbG1xaTVuSVQ4UGFUcWpuVTFTbHFYUHZUL0tyNFFmM1hzb0RKczkzUCt5djJaZ0RhTmpEWWs0UT09ADAxMjM0NTY3ODkAQy5VVEYtOABmNmNhZTE2ZDY3MTRhZTg3OTdkY2M2OTQyNDU4MGMyZDE3M2IzMjliZmNmMDQ2MmY0NDEwN2I5ZjMwZDQwOGU2MWNhMjA2MTIwY2Y2NWMyNWFhNThkYjViMzViYTRkNGE1NzMxOWJkZDI4MzhjODQ4ZGE2NDBkMjE3MmRjNzk0NTQ4N2E0N2FmYjM3MzhlMTNiNTFjYzljYzc1OTg0ZGMxODY3YjJmODA1NzUyMTYzOTUxMzg4YTU5MDVhYjYwYTY5OWZjZmUzMTk0MWEyNmY3MDA4NjFmMzU5OWRjYTQ1Mzg2YzA5NzIwY2VhMjY1MWU1ZTU3ZTAwM2YwOGY1YzczAEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaYWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXowMTIzNDU2Nzg5Ky8ALgAobnVsbCkAUHVyZSB2aXJ0dWFsIGZ1bmN0aW9uIGNhbGxlZCEAZmluZFNhdHJlY0luZGV4OiAAZm9yOiAAbGliYysrYWJpOiAAU0FUUkVDIEJTVEFSOiAAAAAAAAAAACy3BABlAAAAMjZQcm9wYWdhdGVkUG9zaXRpb25Qcm9wZXJ0eQAAAAD8AAUADLcEAGi6BABQMjZQcm9wYWdhdGVkUG9zaXRpb25Qcm9wZXJ0eQAAAMT/BAA4twQAAAAAACy3BABQSzI2UHJvcGFnYXRlZFBvc2l0aW9uUHJvcGVydHkAAMT/BABotwQAAQAAACy3BABYtwQAwP4EAFi3BAA0vAQAaWlpaQBkaWkAdmlpZABQMTZFbnRpdHlDb2xsZWN0aW9uAAAAxP8EALa3BAAAAAAAeLkEAFBLMTZFbnRpdHlDb2xsZWN0aW9uAAAAAMT/BADctwQAAQAAAHi5BADMtwQA8LoEAAAAAABougQAZgAAADE2UG9zaXRpb25Qcm9wZXJ0eQBQSzE2UG9zaXRpb25Qcm9wZXJ0eQDE/wQAK7gEAAEAAABougQAcLoEAPT+BABwugQAJP8EADRCYXNlAAAAvAAFAGC4BABQNEJhc2UAAMT/BABwuAQAAAAAAGi4BABQSzRCYXNlAMT/BACIuAQAAQAAAGi4BAB2AAAAeLgEAAAAAABouAQAZwAAAGgAAABpAAAA8LoEAJC4BAA4U3ViY2xhc3MAAAD8AAUAxLgEAGi4BABQOFN1YmNsYXNzAADE/wQA3LgEAAAAAADQuAQAUEs4U3ViY2xhc3MAxP8EAPi4BAABAAAA0LgEAOi4BADA/gQAAAAAANC4BABnAAAAagAAAGsAAADwugQABLkEAGD+BABouAQAAAAAAIC5BABsAAAAbQAAAGkAMTZQb3NpdGlvblJlZ2lzdHJ5ADE2RW50aXR5Q29sbGVjdGlvbgC8AAUAZbkEAPwABQBSuQQAeLkEAAAAAAB4uQQAbgAAAG8AAABQMTZQb3NpdGlvblJlZ2lzdHJ5AMT/BACcuQQAAAAAAIC5BABQSzE2UG9zaXRpb25SZWdpc3RyeQAAAADE/wQAwLkEAAEAAACAuQQAaWkAdmkAAACwuQQA8LoEAGlpaQD0/gQA2LkEAGD+BACwuQQA4P4EAHZpaWkAAAAAYP4EALC5BAB2aWkA9P4EALC5BAAk/wQAaWlpZABBwPQSC4MI9P4EALC5BABwugQAJP8EAHj+BABQMTZQb3NpdGlvblByb3BlcnR5ALwABQAYuAQAxP8EAFS6BAAAAAAAaLoEAGlpaWlkaQAA9P4EALC5BABg/gQAwP4EAMD+BAAk/wQAwP4EAMD+BAB2aWlpZGlpAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0ljTlNfMTFjaGFyX3RyYWl0c0ljRUVOU185YWxsb2NhdG9ySWNFRUVFAAC8AAUAsLoEAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0loTlNfMTFjaGFyX3RyYWl0c0loRUVOU185YWxsb2NhdG9ySWhFRUVFAAC8AAUA+LoEAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0l3TlNfMTFjaGFyX3RyYWl0c0l3RUVOU185YWxsb2NhdG9ySXdFRUVFAAC8AAUAQLsEAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0lEc05TXzExY2hhcl90cmFpdHNJRHNFRU5TXzlhbGxvY2F0b3JJRHNFRUVFAAAAvAAFAIi7BABOU3QzX18yMTJiYXNpY19zdHJpbmdJRGlOU18xMWNoYXJfdHJhaXRzSURpRUVOU185YWxsb2NhdG9ySURpRUVFRQAAALwABQDUuwQATjEwZW1zY3JpcHRlbjN2YWxFAAC8AAUAILwEAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SWNFRQAAvAAFADy8BABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0lhRUUAALwABQBkvAQATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJaEVFAAC8AAUAjLwEAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SXNFRQAAvAAFALS8BABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0l0RUUAALwABQDcvAQATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJaUVFAAC8AAUABL0EAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SWpFRQAAvAAFACy9BABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0lsRUUAALwABQBUvQQATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJbUVFAAC8AAUAfL0EAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SXhFRQAAvAAFAKS9BABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0l5RUUAALwABQDMvQQATjEwZW1zY3Jp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ogAriCMAQbpVAFluCAAhKoYAOUeDAInj5gDlntQASftAAP9W6QAcD8oAxVmKAJT6KwDTwcUAD8XPANtargBHxYYAhUNiACGGOwAseZQAEGGHACpMewCALBoAQ78SAIgmkAB4PIkAqMTkAOXbewDEOsIAJvTqAPdnigANkr8AZaMrAD2TsQC9fAsApFHcACfdYwBp4d0AmpQZAKgplQBozigACe20AESfIABOmMoAcIJjAH58IwAPuTIAp/WOABRW5wAh8QgAtZ0qAG9+TQClGVEAtfmrAILf1gCW3WEAFjYCAMQ6nwCDoqEAcu1tADmNegCCuKkAazJcAEYnWwAANO0A0gB3APz0VQABWU0A4HGAAEGzkxMLfkD7Ifk/AAAAAC1EdD4AAACAmEb4PAAAAGBRzHg7AAAAgIMb8DkAAABAICV6OAAAAIAiguM2AAAAAB3zaTUZAAoAGRkZAAAAAAUAAAAAAAAJAAAAAAsAAAAAAAAAABkAEQoZGRkDCgcAAQAJCxgAAAkGCwAACwAGGQAAABkZGQBBwZQTCyEOAAAAAAAAAAAZAAoNGRkZAA0AAAIACQ4AAAAJAA4AAA4AQfuUEwsBDABBh5UTCxUTAAAAABMAAAAACQwAAAAAAAwAAAwAQbWVEwsBEABBwZUTCxUPAAAABA8AAAAACRAAAAAAABAAABAAQe+VEwsBEgBB+5UTCx4RAAAAABEAAAAACRIAAAAAABIAABIAABoAAAAaGhoAQbKWEwsOGgAAABoaGgAAAAAAAAkAQeOWEwsBFABB75YTCxUXAAAAABcAAAAACRQAAAAAABQAABQAQZ2XEwsBFgBBqZcTC/8CFQAAAAAVAAAAAAkWAAAAAAAWAAAWAAAwMTIzNDU2Nzg5QUJDREVG/////////////////////////////////////////////////////////////////wABAgMEBQYHCAn/////////CgsMDQ4PEBESExQVFhcYGRobHB0eHyAhIiP///////8KCwwNDg8QERITFBUWFxgZGhscHR4fICEiI/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////8AAQIEBwMGBQAAAAAAAADRdJ4AV529KoBwUg///z4nCgAAAGQAAADoAwAAECcAAKCGAQBAQg8AgJaYAADh9QUYAAAANQAAAHEAAABr////zvv//5K///8AQcyaEwsBUgBB9JoTCwj//////////wBBvJsTC/gJFNAEAHYAAAB3AAAAeAAAAHkAAAB6AAAAewAAAHwAAAB9AAAAfgAAAH8AAACAAAAAgQAAAIIAAACDAAAAAAAAAJzRBACEAAAAhQAAAIYAAACHAAAAiAAAAIkAAACKAAAAiwAAAIwAAACNAAAAjgAAAI8AAACQAAAAkQAAAE5TdDNfXzI5YmFzaWNfaW9zSWNOU18xMWNoYXJfdHJhaXRzSWNFRUVFAE5TdDNfXzIxNWJhc2ljX3N0cmVhbWJ1ZkljTlNfMTFjaGFyX3RyYWl0c0ljRUVFRQBOU3QzX18yMTNiYXNpY19pc3RyZWFtSWNOU18xMWNoYXJfdHJhaXRzSWNFRUVFAE5TdDNfXzIxM2Jhc2ljX29zdHJlYW1JY05TXzExY2hhcl90cmFpdHNJY0VFRUUATlN0M19fMjliYXNpY19pb3NJd05TXzExY2hhcl90cmFpdHNJd0VFRUUATlN0M19fMjE1YmFzaWNfc3RyZWFtYnVmSXdOU18xMWNoYXJfdHJhaXRzSXdFRUVFAE5TdDNfXzIxM2Jhc2ljX2lzdHJlYW1Jd05TXzExY2hhcl90cmFpdHNJd0VFRUUATlN0M19fMjEzYmFzaWNfb3N0cmVhbUl3TlNfMTFjaGFyX3RyYWl0c0l3RUVFRQBOU3QzX18yOGlvc19iYXNlRQAAAAAAHNAEAHYAAACSAAAAkwAAAHkAAAB6AAAAewAAAHwAAAB9AAAAfgAAAJQAAACVAAAAlgAAAIIAAACDAAAATlN0M19fMjEwX19zdGRpbmJ1ZkljRUUAvAAFAGLOBAD8AAUA/M8EABTQBAAIAAAAAAAAAFDQBACXAAAAmAAAAPj////4////UNAEAJkAAACaAAAAaP8EAJPOBAAAAAAAAQAAAHjQBAAD9P//AAAAAHjQBACbAAAAnAAAAPwABQA4zgQAlNAEAAAAAACU0AQAnQAAAJ4AAAC8AAUAqs8EAAAAAAD40AQAdgAAAJ8AAACgAAAAeQAAAHoAAAB7AAAAoQAAAH0AAAB+AAAAfwAAAIAAAACBAAAAogAAAKMAAABOU3QzX18yMTFfX3N0ZG91dGJ1ZkljRUUAAAAA/AAFANzQBAAU0AQABAAAAAAAAAAs0QQApAAAAKUAAAD8/////P///yzRBACmAAAApwAAAGj/BADCzgQAAAAAAAEAAAB40AQAA/T//wAAAACk0QQAhAAAAKgAAACpAAAAhwAAAIgAAACJAAAAigAAAIsAAACMAAAAqgAAAKsAAACsAAAAkAAAAJEAAABOU3QzX18yMTBfX3N0ZGluYnVmSXdFRQC8AAUAG88EAPwABQCE0QQAnNEEAAgAAAAAAAAA2NEEAK0AAACuAAAA+P////j////Y0QQArwAAALAAAABo/wQATM8EAAAAAAABAAAAANIEAAP0//8AAAAAANIEALEAAACyAAAA/AAFAPHOBACU0AQAAAAAAGjSBACEAAAAswAAALQAAACHAAAAiAAAAIkAAAC1AAAAiwAAAIwAAACNAAAAjgAAAI8AAAC2AAAAtwAAAE5TdDNfXzIxMV9fc3Rkb3V0YnVmSXdFRQAAAAD8AAUATNIEAJzRBAAEAAAAAAAAAJzSBAC4AAAAuQAAAPz////8////nNIEALoAAAC7AAAAaP8EAHvPBAAAAAAAAQAAAADSBAAD9P//AEHApRMLFN4SBJUAAAAA////////////////AEHgpRMLV0xDX0NUWVBFAAAAAExDX05VTUVSSUMAAExDX1RJTUUAAAAAAExDX0NPTExBVEUAAExDX01PTkVUQVJZAExDX01FU1NBR0VTAMDSBAAUAAAAQy5VVEYtOABB1KoTC/kDAQAAAAIAAAADAAAABAAAAAUAAAAGAAAABwAAAAgAAAAJAAAACgAAAAsAAAAMAAAADQAAAA4AAAAPAAAAEAAAABEAAAASAAAAEwAAABQAAAAVAAAAFgAAABcAAAAYAAAAGQAAABoAAAAbAAAAHAAAAB0AAAAeAAAAHwAAACAAAAAhAAAAIgAAACMAAAAkAAAAJQAAACYAAAAnAAAAKAAAACkAAAAqAAAAKwAAACwAAAAtAAAALgAAAC8AAAAwAAAAMQAAADIAAAAzAAAANAAAADUAAAA2AAAANwAAADgAAAA5AAAAOgAAADsAAAA8AAAAPQAAAD4AAAA/AAAAQAAAAGEAAABiAAAAYwAAAGQAAABlAAAAZgAAAGcAAABoAAAAaQAAAGoAAABrAAAAbAAAAG0AAABuAAAAbwAAAHAAAABxAAAAcgAAAHMAAAB0AAAAdQAAAHYAAAB3AAAAeAAAAHkAAAB6AAAAWwAAAFwAAABdAAAAXgAAAF8AAABgAAAAYQAAAGIAAABjAAAAZAAAAGUAAABmAAAAZwAAAGgAAABpAAAAagAAAGsAAABsAAAAbQAAAG4AAABvAAAAcAAAAHEAAAByAAAAcwAAAHQAAAB1AAAAdgAAAHcAAAB4AAAAeQAAAHoAAAB7AAAAfAAAAH0AAAB+AAAAfwBB1LYTC/kDAQAAAAIAAAADAAAABAAAAAUAAAAGAAAABwAAAAgAAAAJAAAACgAAAAsAAAAMAAAADQAAAA4AAAAPAAAAEAAAABEAAAASAAAAEwAAABQAAAAVAAAAFgAAABcAAAAYAAAAGQAAABoAAAAbAAAAHAAAAB0AAAAeAAAAHwAAACAAAAAhAAAAIgAAACMAAAAkAAAAJQAAACYAAAAnAAAAKAAAACkAAAAqAAAAKwAAACwAAAAtAAAALgAAAC8AAAAwAAAAMQAAADIAAAAzAAAANAAAADUAAAA2AAAANwAAADgAAAA5AAAAOgAAADsAAAA8AAAAPQAAAD4AAAA/AAAAQAAAAEEAAABCAAAAQwAAAEQAAABFAAAARgAAAEcAAABIAAAASQAAAEoAAABLAAAATAAAAE0AAABOAAAATwAAAFAAAABRAAAAUgAAAFMAAABUAAAAVQAAAFYAAABXAAAAWAAAAFkAAABaAAAAWwAAAFwAAABdAAAAXgAAAF8AAABgAAAAQQAAAEIAAABDAAAARAAAAEUAAABGAAAARwAAAEgAAABJAAAASgAAAEsAAABMAAAATQAAAE4AAABPAAAAUAAAAFEAAABSAAAAUwAAAFQAAABVAAAAVgAAAFcAAABYAAAAWQAAAFoAAAB7AAAAfAAAAH0AAAB+AAAAfwBB0L4TC4MCAgAAwAMAAMAEAADABQAAwAYAAMAHAADACAAAwAkAAMAKAADACwAAwAwAAMANAADADgAAwA8AAMAQAADAEQAAwBIAAMATAADAFAAAwBUAAMAWAADAFwAAwBgAAMAZAADAGgAAwBsAAMAcAADAHQAAwB4AAMAfAADAAAAAswEAAMMCAADDAwAAwwQAAMMFAADDBgAAwwcAAMMIAADDCQAAwwoAAMMLAADDDAAAww0AANMOAADDDwAAwwAADLsBAAzDAgAMwwMADMMEAAzbAAAAADAxMjM0NTY3ODlhYmNkZWZBQkNERUZ4WCstcFBpSW5OAGwAJUk6JU06JVMgJXAlSDolTQBB4MATC4EBJQAAAG0AAAAvAAAAJQAAAGQAAAAvAAAAJQAAAHkAAAAlAAAAWQAAAC0AAAAlAAAAbQAAAC0AAAAlAAAAZAAAACUAAABJAAAAOgAAACUAAABNAAAAOgAAACUAAABTAAAAIAAAACUAAABwAAAAAAAAACUAAABIAAAAOgAAACUAAABNAEHwwRMLZSUAAABIAAAAOgAAACUAAABNAAAAOgAAACUAAABTAAAAAAAAAGTqBAC8AAAAvQAAAL4AAAAAAAAAxOoEAL8AAADAAAAAvgAAAMEAAADCAAAAwwAAAMQAAADFAAAAxgAAAMcAAADIAEHgwhML/QMEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAFAgAABQAAAAUAAAAFAAAABQAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAMCAACCAAAAggAAAIIAAACCAAAAggAAAIIAAACCAAAAggAAAIIAAACCAAAAggAAAIIAAACCAAAAggAAAIIAAABCAQAAQgEAAEIBAABCAQAAQgEAAEIBAABCAQAAQgEAAEIBAABCAQAAggAAAIIAAACCAAAAggAAAIIAAACCAAAAggAAACoBAAAqAQAAKgEAACoBAAAqAQAAKgEAACoAAAAqAAAAKgAAACoAAAAqAAAAKgAAACoAAAAqAAAAKgAAACoAAAAqAAAAKgAAACoAAAAqAAAAKgAAACoAAAAqAAAAKgAAACoAAAAqAAAAggAAAIIAAACCAAAAggAAAIIAAACCAAAAMgEAADIBAAAyAQAAMgEAADIBAAAyAQAAMgAAADIAAAAyAAAAMgAAADIAAAAyAAAAMgAAADIAAAAyAAAAMgAAADIAAAAyAAAAMgAAADIAAAAyAAAAMgAAADIAAAAyAAAAMgAAADIAAACCAAAAggAAAIIAAACCAAAABABB5MoTC+0CLOoEAMkAAADKAAAAvgAAAMsAAADMAAAAzQAAAM4AAADPAAAA0AAAANEAAAAAAAAA/OoEANIAAADTAAAAvgAAANQAAADVAAAA1gAAANcAAADYAAAAAAAAACDrBADZAAAA2gAAAL4AAADbAAAA3AAAAN0AAADeAAAA3wAAAHQAAAByAAAAdQAAAGUAAAAAAAAAZgAAAGEAAABsAAAAcwAAAGUAAAAAAAAAJQAAAG0AAAAvAAAAJQAAAGQAAAAvAAAAJQAAAHkAAAAAAAAAJQAAAEgAAAA6AAAAJQAAAE0AAAA6AAAAJQAAAFMAAAAAAAAAJQAAAGEAAAAgAAAAJQAAAGIAAAAgAAAAJQAAAGQAAAAgAAAAJQAAAEgAAAA6AAAAJQAAAE0AAAA6AAAAJQAAAFMAAAAgAAAAJQAAAFkAAAAAAAAAJQAAAEkAAAA6AAAAJQAAAE0AAAA6AAAAJQAAAFMAAAAgAAAAJQAAAHAAQdzNEwv/CgTnBADgAAAA4QAAAL4AAABOU3QzX18yNmxvY2FsZTVmYWNldEUAAAD8AAUA7OYEAMD8BAAAAAAAhOcEAOAAAADiAAAAvgAAAOMAAADkAAAA5QAAAOYAAADnAAAA6AAAAOkAAADqAAAA6wAAAOwAAADtAAAA7gAAAE5TdDNfXzI1Y3R5cGVJd0VFAE5TdDNfXzIxMGN0eXBlX2Jhc2VFAAC8AAUAZucEAGj/BABU5wQAAAAAAAIAAAAE5wQAAgAAAHznBAACAAAAAAAAABjoBADgAAAA7wAAAL4AAADwAAAA8QAAAPIAAADzAAAA9AAAAPUAAAD2AAAATlN0M19fMjdjb2RlY3Z0SWNjMTFfX21ic3RhdGVfdEVFAE5TdDNfXzIxMmNvZGVjdnRfYmFzZUUAAAAAvAAFAPbnBABo/wQA1OcEAAAAAAACAAAABOcEAAIAAAAQ6AQAAgAAAAAAAACM6AQA4AAAAPcAAAC+AAAA+AAAAPkAAAD6AAAA+wAAAPwAAAD9AAAA/gAAAE5TdDNfXzI3Y29kZWN2dElEc2MxMV9fbWJzdGF0ZV90RUUAAGj/BABo6AQAAAAAAAIAAAAE5wQAAgAAABDoBAACAAAAAAAAAADpBADgAAAA/wAAAL4AAAAAAQAAAQEAAAIBAAADAQAABAEAAAUBAAAGAQAATlN0M19fMjdjb2RlY3Z0SURzRHUxMV9fbWJzdGF0ZV90RUUAaP8EANzoBAAAAAAAAgAAAATnBAACAAAAEOgEAAIAAAAAAAAAdOkEAOAAAAAHAQAAvgAAAAgBAAAJAQAACgEAAAsBAAAMAQAADQEAAA4BAABOU3QzX18yN2NvZGVjdnRJRGljMTFfX21ic3RhdGVfdEVFAABo/wQAUOkEAAAAAAACAAAABOcEAAIAAAAQ6AQAAgAAAAAAAADo6QQA4AAAAA8BAAC+AAAAEAEAABEBAAASAQAAEwEAABQBAAAVAQAAFgEAAE5TdDNfXzI3Y29kZWN2dElEaUR1MTFfX21ic3RhdGVfdEVFAGj/BADE6QQAAAAAAAIAAAAE5wQAAgAAABDoBAACAAAATlN0M19fMjdjb2RlY3Z0SXdjMTFfX21ic3RhdGVfdEVFAAAAaP8EAAjqBAAAAAAAAgAAAATnBAACAAAAEOgEAAIAAABOU3QzX18yNmxvY2FsZTVfX2ltcEUAAAD8AAUATOoEAATnBABOU3QzX18yN2NvbGxhdGVJY0VFAPwABQBw6gQABOcEAE5TdDNfXzI3Y29sbGF0ZUl3RUUA/AAFAJDqBAAE5wQATlN0M19fMjVjdHlwZUljRUUAAABo/wQAsOoEAAAAAAACAAAABOcEAAIAAAB85wQAAgAAAE5TdDNfXzI4bnVtcHVuY3RJY0VFAAAAAPwABQDk6gQABOcEAE5TdDNfXzI4bnVtcHVuY3RJd0VFAAAAAPwABQAI6wQABOcEAAAAAACE6gQAFwEAABgBAAC+AAAAGQEAABoBAAAbAQAAAAAAAKTqBAAcAQAAHQEAAL4AAAAeAQAAHwEAACABAAAAAAAAQOwEAOAAAAAhAQAAvgAAACIBAAAjAQAAJAEAACUBAAAmAQAAJwEAACgBAAApAQAAKgEAACsBAAAsAQAATlN0M19fMjdudW1fZ2V0SWNOU18xOWlzdHJlYW1idWZfaXRlcmF0b3JJY05TXzExY2hhcl90cmFpdHNJY0VFRUVFRQBOU3QzX18yOV9fbnVtX2dldEljRUUATlN0M19fMjE0X19udW1fZ2V0X2Jhc2VFAAC8AAUABuwEAGj/BADw6wQAAAAAAAEAAAAg7AQAAAAAAGj/BACs6wQAAAAAAAIAAAAE5wQAAgAAACjsBABB5NgTC8sBFO0EAOAAAAAtAQAAvgAAAC4BAAAvAQAAMAEAADEBAAAyAQAAMwEAADQBAAA1AQAANgEAADcBAAA4AQAATlN0M19fMjdudW1fZ2V0SXdOU18xOWlzdHJlYW1idWZfaXRlcmF0b3JJd05TXzExY2hhcl90cmFpdHNJd0VFRUVFRQBOU3QzX18yOV9fbnVtX2dldEl3RUUAAABo/wQA5OwEAAAAAAABAAAAIOwEAAAAAABo/wQAoOwEAAAAAAACAAAABOcEAAIAAAD87AQAQbjaEwvfAfztBADgAAAAOQEAAL4AAAA6AQAAOwEAADwBAAA9AQAAPgEAAD8BAABAAQAAQQEAAE5TdDNfXzI3bnVtX3B1dEljTlNfMTlvc3RyZWFtYnVmX2l0ZXJhdG9ySWNOU18xMWNoYXJfdHJhaXRzSWNFRUVFRUUATlN0M19fMjlfX251bV9wdXRJY0VFAE5TdDNfXzIxNF9fbnVtX3B1dF9iYXNlRQAAvAAFAMLtBABo/wQArO0EAAAAAAABAAAA3O0EAAAAAABo/wQAaO0EAAAAAAACAAAABOcEAAIAAADk7QQAQaDcEwu/AcTuBADgAAAAQgEAAL4AAABDAQAARAEAAEUBAABGAQAARwEAAEgBAABJAQAASgEAAE5TdDNfXzI3bnVtX3B1dEl3TlNfMTlvc3RyZWFtYnVmX2l0ZXJhdG9ySXdOU18xMWNoYXJfdHJhaXRzSXdFRUVFRUUATlN0M19fMjlfX251bV9wdXRJd0VFAAAAaP8EAJTuBAAAAAAAAQAAANztBAAAAAAAaP8EAFDuBAAAAAAAAgAAAATnBAACAAAArO4EAEHo3RMLmwvE7wQASwEAAEwBAAC+AAAATQEAAE4BAABPAQAAUAEAAFEBAABSAQAAUwEAAPj////E7wQAVAEAAFUBAABWAQAAVwEAAFgBAABZAQAAWgEAAE5TdDNfXzI4dGltZV9nZXRJY05TXzE5aXN0cmVhbWJ1Zl9pdGVyYXRvckljTlNfMTFjaGFyX3RyYWl0c0ljRUVFRUVFAE5TdDNfXzI5dGltZV9iYXNlRQC8AAUAfe8EAE5TdDNfXzIyMF9fdGltZV9nZXRfY19zdG9yYWdlSWNFRQAAALwABQCY7wQAaP8EADjvBAAAAAAAAwAAAATnBAACAAAAkO8EAAIAAAC87wQAAAgAAAAAAACw8AQAWwEAAFwBAAC+AAAAXQEAAF4BAABfAQAAYAEAAGEBAABiAQAAYwEAAPj///+w8AQAZAEAAGUBAABmAQAAZwEAAGgBAABpAQAAagEAAE5TdDNfXzI4dGltZV9nZXRJd05TXzE5aXN0cmVhbWJ1Zl9pdGVyYXRvckl3TlNfMTFjaGFyX3RyYWl0c0l3RUVFRUVFAE5TdDNfXzIyMF9fdGltZV9nZXRfY19zdG9yYWdlSXdFRQAAvAAFAIXwBABo/wQAQPAEAAAAAAADAAAABOcEAAIAAACQ7wQAAgAAAKjwBAAACAAAAAAAAFTxBABrAQAAbAEAAL4AAABtAQAATlN0M19fMjh0aW1lX3B1dEljTlNfMTlvc3RyZWFtYnVmX2l0ZXJhdG9ySWNOU18xMWNoYXJfdHJhaXRzSWNFRUVFRUUATlN0M19fMjEwX190aW1lX3B1dEUAAAC8AAUANfEEAGj/BADw8AQAAAAAAAIAAAAE5wQAAgAAAEzxBAAACAAAAAAAANTxBABuAQAAbwEAAL4AAABwAQAATlN0M19fMjh0aW1lX3B1dEl3TlNfMTlvc3RyZWFtYnVmX2l0ZXJhdG9ySXdOU18xMWNoYXJfdHJhaXRzSXdFRUVFRUUAAAAAaP8EAIzxBAAAAAAAAgAAAATnBAACAAAATPEEAAAIAAAAAAAAaPIEAOAAAABxAQAAvgAAAHIBAABzAQAAdAEAAHUBAAB2AQAAdwEAAHgBAAB5AQAAegEAAE5TdDNfXzIxMG1vbmV5cHVuY3RJY0xiMEVFRQBOU3QzX18yMTBtb25leV9iYXNlRQAAAAC8AAUASPIEAGj/BAAs8gQAAAAAAAIAAAAE5wQAAgAAAGDyBAACAAAAAAAAANzyBADgAAAAewEAAL4AAAB8AQAAfQEAAH4BAAB/AQAAgAEAAIEBAACCAQAAgwEAAIQBAABOU3QzX18yMTBtb25leXB1bmN0SWNMYjFFRUUAaP8EAMDyBAAAAAAAAgAAAATnBAACAAAAYPIEAAIAAAAAAAAAUPMEAOAAAACFAQAAvgAAAIYBAACHAQAAiAEAAIkBAACKAQAAiwEAAIwBAACNAQAAjgEAAE5TdDNfXzIxMG1vbmV5cHVuY3RJd0xiMEVFRQBo/wQANPMEAAAAAAACAAAABOcEAAIAAABg8gQAAgAAAAAAAADE8wQA4AAAAI8BAAC+AAAAkAEAAJEBAACSAQAAkwEAAJQBAACVAQAAlgEAAJcBAACYAQAATlN0M19fMjEwbW9uZXlwdW5jdEl3TGIxRUVFAGj/BACo8wQAAAAAAAIAAAAE5wQAAgAAAGDyBAACAAAAAAAAAGj0BADgAAAAmQEAAL4AAACaAQAAmwEAAE5TdDNfXzI5bW9uZXlfZ2V0SWNOU18xOWlzdHJlYW1idWZfaXRlcmF0b3JJY05TXzExY2hhcl90cmFpdHNJY0VFRUVFRQBOU3QzX18yMTFfX21vbmV5X2dldEljRUUAALwABQBG9AQAaP8EAAD0BAAAAAAAAgAAAATnBAACAAAAYPQEAEGM6RMLmwEM9QQA4AAAAJwBAAC+AAAAnQEAAJ4BAABOU3QzX18yOW1vbmV5X2dldEl3TlNfMTlpc3RyZWFtYnVmX2l0ZXJhdG9ySXdOU18xMWNoYXJfdHJhaXRzSXdFRUVFRUUATlN0M19fMjExX19tb25leV9nZXRJd0VFAAC8AAUA6vQEAGj/BACk9AQAAAAAAAIAAAAE5wQAAgAAAAT1BABBsOoTC5sBsPUEAOAAAACfAQAAvgAAAKABAAChAQAATlN0M19fMjltb25leV9wdXRJY05TXzE5b3N0cmVhbWJ1Zl9pdGVyYXRvckljTlNfMTFjaGFyX3RyYWl0c0ljRUVFRUVFAE5TdDNfXzIxMV9fbW9uZXlfcHV0SWNFRQAAvAAFAI71BABo/wQASPUEAAAAAAACAAAABOcEAAIAAACo9QQAQdTrEwubAVT2BADgAAAAogEAAL4AAACjAQAApAEAAE5TdDNfXzI5bW9uZXlfcHV0SXdOU18xOW9zdHJlYW1idWZfaXRlcmF0b3JJd05TXzExY2hhcl90cmFpdHNJd0VFRUVFRQBOU3QzX18yMTFfX21vbmV5X3B1dEl3RUUAALwABQAy9gQAaP8EAOz1BAAAAAAAAgAAAATnBAACAAAATPYEAEH47BMLuQjM9gQA4AAAAKUBAAC+AAAApgEAAKcBAACoAQAATlN0M19fMjhtZXNzYWdlc0ljRUUATlN0M19fMjEzbWVzc2FnZXNfYmFzZUUAAAAAvAAFAKn2BABo/wQAlPYEAAAAAAACAAAABOcEAAIAAADE9gQAAgAAAAAAAAAk9wQA4AAAAKkBAAC+AAAAqgEAAKsBAACsAQAATlN0M19fMjhtZXNzYWdlc0l3RUUAAAAAaP8EAAz3BAAAAAAAAgAAAATnBAACAAAAxPYEAAIAAABTAAAAdQAAAG4AAABkAAAAYQAAAHkAAAAAAAAATQAAAG8AAABuAAAAZAAAAGEAAAB5AAAAAAAAAFQAAAB1AAAAZQAAAHMAAABkAAAAYQAAAHkAAAAAAAAAVwAAAGUAAABkAAAAbgAAAGUAAABzAAAAZAAAAGEAAAB5AAAAAAAAAFQAAABoAAAAdQAAAHIAAABzAAAAZAAAAGEAAAB5AAAAAAAAAEYAAAByAAAAaQAAAGQAAABhAAAAeQAAAAAAAABTAAAAYQAAAHQAAAB1AAAAcgAAAGQAAABhAAAAeQAAAAAAAABTAAAAdQAAAG4AAAAAAAAATQAAAG8AAABuAAAAAAAAAFQAAAB1AAAAZQAAAAAAAABXAAAAZQAAAGQAAAAAAAAAVAAAAGgAAAB1AAAAAAAAAEYAAAByAAAAaQAAAAAAAABTAAAAYQAAAHQAAAAAAAAASgAAAGEAAABuAAAAdQAAAGEAAAByAAAAeQAAAAAAAABGAAAAZQAAAGIAAAByAAAAdQAAAGEAAAByAAAAeQAAAAAAAABNAAAAYQAAAHIAAABjAAAAaAAAAAAAAABBAAAAcAAAAHIAAABpAAAAbAAAAAAAAABNAAAAYQAAAHkAAAAAAAAASgAAAHUAAABuAAAAZQAAAAAAAABKAAAAdQAAAGwAAAB5AAAAAAAAAEEAAAB1AAAAZwAAAHUAAABzAAAAdAAAAAAAAABTAAAAZQAAAHAAAAB0AAAAZQAAAG0AAABiAAAAZQAAAHIAAAAAAAAATwAAAGMAAAB0AAAAbwAAAGIAAABlAAAAcgAAAAAAAABOAAAAbwAAAHYAAABlAAAAbQAAAGIAAABlAAAAcgAAAAAAAABEAAAAZQAAAGMAAABlAAAAbQAAAGIAAABlAAAAcgAAAAAAAABKAAAAYQAAAG4AAAAAAAAARgAAAGUAAABiAAAAAAAAAE0AAABhAAAAcgAAAAAAAABBAAAAcAAAAHIAAAAAAAAASgAAAHUAAABuAAAAAAAAAEoAAAB1AAAAbAAAAAAAAABBAAAAdQAAAGcAAAAAAAAAUwAAAGUAAABwAAAAAAAAAE8AAABjAAAAdAAAAAAAAABOAAAAbwAAAHYAAAAAAAAARAAAAGUAAABjAAAAAAAAAEEAAABNAAAAAAAAAFAAAABNAEG89RMLXLzvBABUAQAAVQEAAFYBAABXAQAAWAEAAFkBAABaAQAAAAAAAKjwBABkAQAAZQEAAGYBAABnAQAAaAEAAGkBAABqAQAATlN0M19fMjE0X19zaGFyZWRfY291bnRFAEG09hMLAyjTBABB0PYTC8gBMDAwMTAyMDMwNDA1MDYwNzA4MDkxMDExMTIxMzE0MTUxNjE3MTgxOTIwMjEyMjIzMjQyNTI2MjcyODI5MzAzMTMyMzMzNDM1MzYzNzM4Mzk0MDQxNDI0MzQ0NDU0NjQ3NDg0OTUwNTE1MjUzNTQ1NTU2NTc1ODU5NjA2MTYyNjM2NDY1NjY2NzY4Njk3MDcxNzI3Mzc0NzU3Njc3Nzg3OTgwODE4MjgzODQ4NTg2ODc4ODg5OTA5MTkyOTM5NDk1OTY5Nzk4OTkAQaj4EwuOCgoAAAAAAAAAZAAAAAAAAADoAwAAAAAAABAnAAAAAAAAoIYBAAAAAABAQg8AAAAAAICWmAAAAAAAAOH1BQAAAAAAypo7AAAAAADkC1QCAAAAAOh2SBcAAAAAEKXU6AAAAACgck4YCQAAAEB6EPNaAAAAgMakfo0DAAAAwW/yhiMAAACKXXhFYwEAAGSns7bgDQAA6IkEI8eKvAAFAAD7BAAAAAAAwPwEAK0BAACuAQAArwEAAE4xMF9fY3h4YWJpdjExNl9fc2hpbV90eXBlX2luZm9FAAAAAPwABQDc/AQA7AAFAE4xMF9fY3h4YWJpdjExN19fY2xhc3NfdHlwZV9pbmZvRQAAAPwABQAM/QQAAP0EAE4xMF9fY3h4YWJpdjExN19fcGJhc2VfdHlwZV9pbmZvRQAAAPwABQA8/QQAAP0EAE4xMF9fY3h4YWJpdjExOV9fcG9pbnRlcl90eXBlX2luZm9FAPwABQBs/QQAYP0EAE4xMF9fY3h4YWJpdjEyMF9fZnVuY3Rpb25fdHlwZV9pbmZvRQAAAAD8AAUAnP0EAAD9BABOMTBfX2N4eGFiaXYxMjlfX3BvaW50ZXJfdG9fbWVtYmVyX3R5cGVfaW5mb0UAAAD8AAUA0P0EAGD9BAAAAAAAUP4EALEBAACyAQAAswEAALQBAAC1AQAATjEwX19jeHhhYml2MTIzX19mdW5kYW1lbnRhbF90eXBlX2luZm9FAPwABQAo/gQAAP0EAHYAAAAU/gQAXP4EAERuAAAU/gQAaP4EAGIAAAAU/gQAdP4EAGMAAAAU/gQAgP4EAGgAAAAU/gQAjP4EAGEAAAAU/gQAmP4EAHMAAAAU/gQApP4EAHQAAAAU/gQAsP4EAGkAAAAU/gQAvP4EAGoAAAAU/gQAyP4EABT+BABB4AQAUGwAAMT/BADc/gQAAAAAANT+BABtAAAAFP4EAPD+BAB4AAAAFP4EAPz+BAB5AAAAFP4EAAj/BABmAAAAFP4EABT/BABkAAAAFP4EACD/BABOMTBfX2N4eGFiaXYxMjBfX3NpX2NsYXNzX3R5cGVfaW5mb0UAAAAA/AAFACz/BAAw/QQAAAAAALD/BACxAQAAtgEAALMBAAC0AQAAtwEAALgBAAC5AQAAugEAAE4xMF9fY3h4YWJpdjEyMV9fdm1pX2NsYXNzX3R5cGVfaW5mb0UAAAD8AAUAiP8EADD9BAAAAAAAkP0EALEBAAC7AQAAswEAALQBAAC8AQAAAAAAABwABQBNAAAAvQEAAL4BAAAAAAAARAAFAE0AAAC/AQAAwAEAAFN0OWV4Y2VwdGlvbgBTdDliYWRfYWxsb2MAAAD8AAUADQAFABwBBQBTdDIwYmFkX2FycmF5X25ld19sZW5ndGgAAAAA/AAFACgABQAcAAUAAAAAAHQABQACAAAAwQEAAMIBAABTdDExbG9naWNfZXJyb3IA/AAFAGQABQAcAQUAAAAAAKgABQACAAAAwwEAAMIBAABTdDEybGVuZ3RoX2Vycm9yAAAAAPwABQCUAAUAdAAFAAAAAAAw/QQAsQEAAMQBAACzAQAAtAEAALcBAADFAQAAxgEAAMcBAABTdDl0eXBlX2luZm8AAAAAvAAFANwABQAAAAAAVP8EALEBAADIAQAAswEAALQBAAC3AQAAyQEAAMoBAADLAQAAvAAFAAAABQAAAAAAHAEFAE0AAADMAQAAzQEAQbiCFAsRgBwGAAAAAACNl24SI+q4QAUAQdSCFAsBcABB7IIUCwtxAAAAcgAAAHQHBQBBhIMUCwECAEGUgxQLCP//////////AEHYgxQLCUgBBQAAAAAABQBB7IMUCwFzAEGEhBQLDnEAAAB0AAAAmAsFAAAEAEGchBQLAQEAQayEFAsF/////woAQfCEFAsJ4AEFAAAAAAAJAEGEhRQLAXAAQZiFFAsSdQAAAAAAAAByAAAAiAcFAAAEAEHEhRQLBP////8AQYiGFAsCsAE=",Ct(xe)||(xe=V(xe));function oo(x){if(x==xe&&C)return new Uint8Array(C);var D=pm(x);if(D)return D;if(G)return G(x);throw"both async and sync fetching of the wasm failed"}function ea(x){return Promise.resolve().then(()=>oo(x))}function gs(x,D,j){return ea(x).then(lt=>WebAssembly.instantiate(lt,D)).then(lt=>lt).then(j,lt=>{g("failed to asynchronously prepare wasm: "+lt),_t(xe)&&g("warning: Loading from a file URI ("+xe+") is not supported in most browsers. See https://emscripten.org/docs/getting_started/FAQ.html#how-do-i-run-a-local-webserver-for-testing-why-does-my-program-stall-in-downloading-or-preparing"),We(lt)})}function is(x,D,j,lt){return gs(D,j,lt)}function ja(){var x={env:XN,wasi_snapshot_preview1:XN};function D(ut,yt){var Yt=ut.exports;return Q=Yt,Y=Q.memory,Z(Y,"memory not found in wasm exports"),H(),nt=Q.__indirect_function_table,Z(nt,"table not found in wasm exports"),qt(Q.__wasm_call_ctors),Ve("wasm-instantiate"),Yt}ke("wasm-instantiate");var j=n;function lt(ut){Z(n===j,"the Module object should not be replaced during async compilation - perhaps the order of HTML elements is wrong?"),j=null,D(ut.instance)}if(n.instantiateWasm)try{return n.instantiateWasm(x,D)}catch(ut){g("Module.instantiateWasm callback failed with error: "+ut),o(ut)}return is(C,xe,x,lt).catch(o),{}}var qn,ae;function fe(x,D,j=!0){Object.getOwnPropertyDescriptor(n,x)||Object.defineProperty(n,x,{configurable:!0,get(){let lt=j?" (the initial value can be provided on Module, but after startup the value is only looked for on a local variable of that name)":"";We(`\`Module.${x}\` has been replaced by \`${D}\``+lt)}})}function ge(x){Object.getOwnPropertyDescriptor(n,x)&&We(`\`Module.${x}\` was supplied but \`${x}\` not included in INCOMING_MODULE_JS_API`)}function ue(x){return x==="FS_createPath"||x==="FS_createDataFile"||x==="FS_createPreloadedFile"||x==="FS_unlink"||x==="addRunDependency"||x==="FS_createLazyFile"||x==="FS_createDevice"||x==="removeRunDependency"}function Ke(x,D){typeof globalThis<"u"&&Object.defineProperty(globalThis,x,{configurable:!0,get(){Go("`"+x+"` is not longer defined by emscripten. "+D)}})}Ke("buffer","Please use HEAP8.buffer or wasmMemory.buffer");function An(x){typeof globalThis<"u"&&!Object.getOwnPropertyDescriptor(globalThis,x)&&Object.defineProperty(globalThis,x,{configurable:!0,get(){var D="`"+x+"` is a library symbol and not included by default; add it to your library.js __deps or to DEFAULT_LIBRARY_FUNCS_TO_INCLUDE on the command line",j=x;j.startsWith("_")||(j="$"+x),D+=" (e.g. -sDEFAULT_LIBRARY_FUNCS_TO_INCLUDE='"+j+"')",ue(x)&&(D+=". Alternatively, forcing filesystem support (-sFORCE_FILESYSTEM) can export this for you"),Go(D)}}),si(x)}function si(x){Object.getOwnPropertyDescriptor(n,x)||Object.defineProperty(n,x,{configurable:!0,get(){var D="'"+x+"' was not exported. add it to EXPORTED_RUNTIME_METHODS (see the Emscripten FAQ)";ue(x)&&(D+=". Alternatively, forcing filesystem support (-sFORCE_FILESYSTEM) can export this for you"),We(D)}})}var da={328460:()=>{console.log("no show")}};function _a(x){this.name="ExitStatus",this.message=`Program terminated with exit(${x})`,this.status=x}var Rl=x=>{for(;x.length>0;)x.shift()(n)},na=x=>(Z(typeof x=="number"),x>>>=0,"0x"+x.toString(16).padStart(8,"0")),Go=x=>{Go.shown||(Go.shown={}),Go.shown[x]||(Go.shown[x]=1,g(x))};function Ao(x){this.excPtr=x,this.ptr=x-24,this.set_type=function(D){P[this.ptr+4>>2]=D},this.get_type=function(){return P[this.ptr+4>>2]},this.set_destructor=function(D){P[this.ptr+8>>2]=D},this.get_destructor=function(){return P[this.ptr+8>>2]},this.set_caught=function(D){D=D?1:0,E[this.ptr+12>>0]=D},this.get_caught=function(){return E[this.ptr+12>>0]!=0},this.set_rethrown=function(D){D=D?1:0,E[this.ptr+13>>0]=D},this.get_rethrown=function(){return E[this.ptr+13>>0]!=0},this.init=function(D,j){this.set_adjusted_ptr(0),this.set_type(D),this.set_destructor(j)},this.set_adjusted_ptr=function(D){P[this.ptr+16>>2]=D},this.get_adjusted_ptr=function(){return P[this.ptr+16>>2]},this.get_exception_ptr=function(){var D=s8(this.get_type());if(D)return P[this.excPtr>>2];var j=this.get_adjusted_ptr();return j!==0?j:this.excPtr}}var Xs=0,Es=0;function wl(x,D,j){var lt=new Ao(x);lt.init(D,j),Xs=x,Es++,Z(!1,"Exception thrown, but exception catching is not enabled. Compile with -sNO_DISABLE_EXCEPTION_CATCHING or -sEXCEPTION_CATCHING_ALLOWED=[..] to catch.")}function ka(x,D,j,lt,ut){}function Wa(x){switch(x){case 1:return 0;case 2:return 1;case 4:return 2;case 8:return 3;default:throw new TypeError(`Unknown type size: ${x}`)}}function JV(){for(var x=new Array(256),D=0;D<256;++D)x[D]=String.fromCharCode(D);yl=x}var yl=void 0;function Bi(x){for(var D="",j=x;I[j];)D+=yl[I[j++]];return D}var sd={},zi={},js={},ca=void 0;function $n(x){throw new ca(x)}var mr=void 0;function hr(x){throw new mr(x)}function pr(x,D,j){x.forEach(function(Dt){js[Dt]=D});function lt(Dt){var pe=j(Dt);pe.length!==x.length&&hr("Mismatched type converter count");for(var Te=0;Te{zi.hasOwnProperty(Dt)?ut[pe]=zi[Dt]:(yt.push(Dt),sd.hasOwnProperty(Dt)||(sd[Dt]=[]),sd[Dt].push(()=>{ut[pe]=zi[Dt],++Yt,Yt===yt.length&<(ut)}))}),yt.length===0&<(ut)}function hs(x,D,j={}){var lt=D.name;if(x||$n(`type "${lt}" must have a positive integer typeid pointer`),zi.hasOwnProperty(x)){if(j.ignoreDuplicateRegistrations)return;$n(`Cannot register type '${lt}' twice`)}if(zi[x]=D,delete js[x],sd.hasOwnProperty(x)){var ut=sd[x];delete sd[x],ut.forEach(yt=>yt())}}function ma(x,D,j={}){if(!("argPackAdvance"in D))throw new TypeError("registerType registeredInstance requires argPackAdvance");return hs(x,D,j)}function Ed(x,D,j,lt,ut){var yt=Wa(j);D=Bi(D),ma(x,{name:D,fromWireType:function(Yt){return!!Yt},toWireType:function(Yt,Dt){return Dt?lt:ut},argPackAdvance:8,readValueFromPointer:function(Yt){var Dt;if(j===1)Dt=E;else if(j===2)Dt=B;else if(j===4)Dt=_;else throw new TypeError("Unknown boolean type size: "+D);return this.fromWireType(Dt[Yt>>yt])},destructorFunction:null})}function BW(x){if(!(this instanceof rh)||!(x instanceof rh))return!1;for(var D=this.$$.ptrType.registeredClass,j=this.$$.ptr,lt=x.$$.ptrType.registeredClass,ut=x.$$.ptr;D.baseClass;)j=D.upcast(j),D=D.baseClass;for(;lt.baseClass;)ut=lt.upcast(ut),lt=lt.baseClass;return D===lt&&j===ut}function bc(x){return{count:x.count,deleteScheduled:x.deleteScheduled,preservePointerOnDelete:x.preservePointerOnDelete,ptr:x.ptr,ptrType:x.ptrType,smartPtr:x.smartPtr,smartPtrType:x.smartPtrType}}function $R(x){function D(j){return j.$$.ptrType.registeredClass.name}$n(D(x)+" instance already deleted")}var up=!1;function LV(x){}function QW(x){x.smartPtr?x.smartPtrType.rawDestructor(x.smartPtr):x.ptrType.registeredClass.rawDestructor(x.ptr)}function tb(x){x.count.value-=1;var D=x.count.value===0;D&&QW(x)}function kW(x,D,j){if(D===j)return x;if(j.baseClass===void 0)return null;var lt=kW(x,D,j.baseClass);return lt===null?null:j.downcast(lt)}var YW={};function pg(){return Object.keys(MV).length}function MU(){var x=[];for(var D in MV)MV.hasOwnProperty(D)&&x.push(MV[D]);return x}var lh=[];function Zp(){for(;lh.length;){var x=lh.pop();x.$$.deleteScheduled=!1,x.delete()}}var lm=void 0;function _U(x){lm=x,lh.length&&lm&&lm(Zp)}function DU(){n.getInheritedInstanceCount=pg,n.getLiveInheritedInstances=MU,n.flushPendingDeletes=Zp,n.setDelayFunction=_U}var MV={};function eb(x,D){for(D===void 0&&$n("ptr should not be undefined");x.baseClass;)D=x.upcast(D),x=x.baseClass;return D}function Vg(x,D){return D=eb(x,D),MV[D]}function Rp(x,D){(!D.ptrType||!D.ptr)&&hr("makeClassHandle requires ptr and ptrType");var j=!!D.smartPtrType,lt=!!D.smartPtr;return j!==lt&&hr("Both smartPtrType and smartPtr must be specified"),D.count={value:1},kr(Object.create(x,{$$:{value:D}}))}function bp(x){var D=this.getPointee(x);if(!D)return this.destructor(x),null;var j=Vg(this.registeredClass,D);if(j!==void 0){if(j.$$.count.value===0)return j.$$.ptr=D,j.$$.smartPtr=x,j.clone();var lt=j.clone();return this.destructor(x),lt}function ut(){return this.isSmartPointer?Rp(this.registeredClass.instancePrototype,{ptrType:this.pointeeType,ptr:D,smartPtrType:this,smartPtr:x}):Rp(this.registeredClass.instancePrototype,{ptrType:this,ptr:x})}var yt=this.registeredClass.getActualType(D),Yt=YW[yt];if(!Yt)return ut.call(this);var Dt;this.isConst?Dt=Yt.constPointerType:Dt=Yt.pointerType;var pe=kW(D,this.registeredClass,Dt.registeredClass);return pe===null?ut.call(this):this.isSmartPointer?Rp(Dt.registeredClass.instancePrototype,{ptrType:Dt,ptr:pe,smartPtrType:this,smartPtr:x}):Rp(Dt.registeredClass.instancePrototype,{ptrType:Dt,ptr:pe})}var kr=function(x){return typeof FinalizationRegistry>"u"?(kr=D=>D,x):(up=new FinalizationRegistry(D=>{console.warn(D.leakWarning.stack.replace(/^Error: /,"")),tb(D.$$)}),kr=D=>{var j=D.$$,lt=!!j.smartPtr;if(lt){var ut={$$:j},yt=j.ptrType.registeredClass;ut.leakWarning=new Error(`Embind found a leaked C++ instance ${yt.name} <${na(j.ptr)}>. We'll free it automatically in this case, but this functionality is not reliable across various environments. Make sure to invoke .delete() manually once you're done with the instance instead. -Originally allocated`),"captureStackTrace"in Error&&Error.captureStackTrace(Zt.leakWarning,Rp),Zp.register(D,Zt,D)}return D},Lu=D=>Zp.unregister(D),kr(x))};function fV(){if(this.$$.ptr||$b(this),this.$$.preservePointerOnDelete)return this.$$.count.value+=1,this;var x=kr(Object.create(Object.getPrototypeOf(this),{$$:{value:Rc(this.$$)}}));return x.$$.count.value+=1,x.$$.deleteScheduled=!1,x}function xW(){this.$$.ptr||$b(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&$n("Object already scheduled for deletion"),Lu(this),tR(this.$$),this.$$.preservePointerOnDelete||(this.$$.smartPtr=void 0,this.$$.ptr=void 0)}function XW(){return!this.$$.ptr}function OU(){return this.$$.ptr||$b(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&$n("Object already scheduled for deletion"),lh.push(this),lh.length===1&&lm&&lm(Vp),this.$$.deleteScheduled=!0,this}function nR(){rh.prototype.isAliasOf=BW,rh.prototype.clone=fV,rh.prototype.delete=xW,rh.prototype.isDeleted=XW,rh.prototype.deleteLater=OU}function rh(){}var HU=48,Js=57;function ld(x){if(x===void 0)return"_unknown";x=x.replace(/[^a-zA-Z0-9_]/g,"$");var D=x.charCodeAt(0);return D>=HU&&D<=Js?`_${x}`:x}function iR(x,D){return x=ld(x),{[x]:function(){return D.apply(this,arguments)}}[x]}function wU(x,D,j){if(x[D].overloadTable===void 0){var lt=x[D];x[D]=function(){return x[D].overloadTable.hasOwnProperty(arguments.length)||$n(`Function '${j}' called with an invalid number of arguments (${arguments.length}) - expects one of (${x[D].overloadTable})!`),x[D].overloadTable[arguments.length].apply(this,arguments)},x[D].overloadTable=[],x[D].overloadTable[lt.argCount]=lt}}function PU(x,D,j){n.hasOwnProperty(x)?((j===void 0||n[x].overloadTable!==void 0&&n[x].overloadTable[j]!==void 0)&&$n(`Cannot register public name '${x}' twice`),wU(n,x,x),n.hasOwnProperty(j)&&$n(`Cannot register multiple overloads of a function with the same number of arguments (${j})!`),n[x].overloadTable[j]=D):(n[x]=D,j!==void 0&&(n[x].numArguments=j))}function JW(x,D,j,lt,Zt,yt,Yt,Dt){this.name=x,this.constructor=D,this.instancePrototype=j,this.rawDestructor=lt,this.baseClass=Zt,this.getActualType=yt,this.upcast=Yt,this.downcast=Dt,this.pureVirtualFunctions=[]}function FV(x,D,j){for(;D!==j;)D.upcast||$n(`Expected null or instance of ${j.name}, got an instance of ${D.name}`),x=D.upcast(x),D=D.baseClass;return x}function vU(x,D){if(D===null)return this.isReference&&$n(`null is not a valid ${this.name}`),0;D.$$||$n(`Cannot pass "${aR(D)}" as a ${this.name}`),D.$$.ptr||$n(`Cannot pass deleted object as a pointer of type ${this.name}`);var j=D.$$.ptrType.registeredClass,lt=FV(D.$$.ptr,j,this.registeredClass);return lt}function Zg(x,D){var j;if(D===null)return this.isReference&&$n(`null is not a valid ${this.name}`),this.isSmartPointer?(j=this.rawConstructor(),x!==null&&x.push(this.rawDestructor,j),j):0;D.$$||$n(`Cannot pass "${aR(D)}" as a ${this.name}`),D.$$.ptr||$n(`Cannot pass deleted object as a pointer of type ${this.name}`),!this.isConst&&D.$$.ptrType.isConst&&$n(`Cannot convert argument of type ${D.$$.smartPtrType?D.$$.smartPtrType.name:D.$$.ptrType.name} to parameter type ${this.name}`);var lt=D.$$.ptrType.registeredClass;if(j=FV(D.$$.ptr,lt,this.registeredClass),this.isSmartPointer)switch(D.$$.smartPtr===void 0&&$n("Passing raw pointer to smart pointer is illegal"),this.sharingPolicy){case 0:D.$$.smartPtrType===this?j=D.$$.smartPtr:$n(`Cannot convert argument of type ${D.$$.smartPtrType?D.$$.smartPtrType.name:D.$$.ptrType.name} to parameter type ${this.name}`);break;case 1:j=D.$$.smartPtr;break;case 2:if(D.$$.smartPtrType===this)j=D.$$.smartPtr;else{var Zt=D.clone();j=this.rawShare(j,dh.toHandle(function(){Zt.delete()})),x!==null&&x.push(this.rawDestructor,j)}break;default:$n("Unsupporting sharing policy")}return j}function Vg(x,D){if(D===null)return this.isReference&&$n(`null is not a valid ${this.name}`),0;D.$$||$n(`Cannot pass "${aR(D)}" as a ${this.name}`),D.$$.ptr||$n(`Cannot pass deleted object as a pointer of type ${this.name}`),D.$$.ptrType.isConst&&$n(`Cannot convert argument of type ${D.$$.ptrType.name} to parameter type ${this.name}`);var j=D.$$.ptrType.registeredClass,lt=FV(D.$$.ptr,j,this.registeredClass);return lt}function oR(x){return this.fromWireType(_[x>>2])}function SN(x){return this.rawGetPointee&&(x=this.rawGetPointee(x)),x}function Cd(x){this.rawDestructor&&this.rawDestructor(x)}function KU(x){x!==null&&x.delete()}function bg(){rm.prototype.getPointee=SN,rm.prototype.destructor=Cd,rm.prototype.argPackAdvance=8,rm.prototype.readValueFromPointer=oR,rm.prototype.deleteObject=KU,rm.prototype.fromWireType=Rp}function rm(x,D,j,lt,Zt,yt,Yt,Dt,pe,Se,en){this.name=x,this.registeredClass=D,this.isReference=j,this.isConst=lt,this.isSmartPointer=Zt,this.pointeeType=yt,this.sharingPolicy=Yt,this.rawGetPointee=Dt,this.rawConstructor=pe,this.rawShare=Se,this.rawDestructor=en,!Zt&&D.baseClass===void 0?lt?(this.toWireType=vU,this.destructorFunction=null):(this.toWireType=Vg,this.destructorFunction=null):this.toWireType=Zg}function Rg(x,D,j){n.hasOwnProperty(x)||hr("Replacing nonexistant public symbol"),n[x].overloadTable!==void 0&&j!==void 0?n[x].overloadTable[j]=D:(n[x]=D,n[x].argCount=j)}var LW=(x,D,j)=>{V("dynCall_"+x in n,`bad function pointer type - dynCall function not found for sig '${x}'`),j&&j.length?V(j.length===x.substring(1).replace(/j/g,"--").length):V(x.length==1);var lt=n["dynCall_"+x];return j&&j.length?lt.apply(null,[D].concat(j)):lt.call(null,D)},Id=[],MW=x=>{var D=Id[x];return D||(x>=Id.length&&(Id.length=x+1),Id[x]=D=nt.get(x)),V(nt.get(x)==D,"JavaScript-side Wasm function table mirror is out of date!"),D},Wg=(x,D,j)=>{if(x.includes("j"))return LW(x,D,j);V(MW(D),`missing table entry in dynCall: ${D}`);var lt=MW(D).apply(null,j);return lt},fg=(x,D)=>{V(x.includes("j")||x.includes("p"),"getDynCaller should only be called with i64 sigs");var j=[];return function(){return j.length=0,Object.assign(j,arguments),Wg(x,D,j)}};function dm(x,D){x=Bi(x);function j(){return x.includes("j")?fg(x,D):MW(D)}var lt=j();return typeof lt!="function"&&$n(`unknown function pointer with signature ${x}: ${D}`),lt}function Da(x,D){var j=iR(D,function(lt){this.name=D,this.message=lt;var Zt=new Error(lt).stack;Zt!==void 0&&(this.stack=this.toString()+` -`+Zt.replace(/^Error(:[^\n]*)?\n/,""))});return j.prototype=Object.create(x.prototype),j.prototype.constructor=j,j.prototype.toString=function(){return this.message===void 0?this.name:`${this.name}: ${this.message}`},j}var Zn=void 0;function Kt(x){var D=i8(x),j=Bi(D);return us(D),j}function De(x,D){var j=[],lt={};function Zt(yt){if(!lt[yt]&&!zi[yt]){if(js[yt]){js[yt].forEach(Zt);return}j.push(yt),lt[yt]=!0}}throw D.forEach(Zt),new Zn(`${x}: `+j.map(Kt).join([", "]))}function ti(x,D,j,lt,Zt,yt,Yt,Dt,pe,Se,en,Vn,bn){en=Bi(en),yt=dm(Zt,yt),Dt&&(Dt=dm(Yt,Dt)),Se&&(Se=dm(pe,Se)),bn=dm(Vn,bn);var Rn=ld(en);PU(Rn,function(){De(`Cannot construct ${en} due to unbound types`,[lt])}),pr([x,D,j],lt?[lt]:[],function(Xn){Xn=Xn[0];var vi,Ea;lt?(vi=Xn.registeredClass,Ea=vi.instancePrototype):Ea=rh.prototype;var Oo=iR(Rn,function(){if(Object.getPrototypeOf(this)!==Le)throw new ca("Use 'new' to construct "+en);if(kn.constructor_body===void 0)throw new ca(en+" has no accessible constructor");var _s=kn.constructor_body[arguments.length];if(_s===void 0)throw new ca(`Tried to invoke ctor of ${en} with invalid number of parameters (${arguments.length}) - expected (${Object.keys(kn.constructor_body).toString()}) parameters instead!`);return _s.apply(this,arguments)}),Le=Object.create(Ea,{constructor:{value:Oo}});Oo.prototype=Le;var kn=new JW(en,Oo,Le,bn,vi,yt,Dt,Se);kn.baseClass&&(kn.baseClass.__derivedClasses===void 0&&(kn.baseClass.__derivedClasses=[]),kn.baseClass.__derivedClasses.push(kn));var fa=new rm(en,kn,!0,!1,!1),Ya=new rm(en+"*",kn,!1,!1,!1),Nd=new rm(en+" const*",kn,!1,!0,!1);return YW[x]={pointerType:Ya,constPointerType:Nd},Rg(Rn,Oo),[fa,Ya,Nd]})}function Hi(x,D){for(var j=[],lt=0;lt>2]);return j}function Rl(x){for(;x.length;){var D=x.pop(),j=x.pop();j(D)}}function Pl(x,D){if(!(x instanceof Function))throw new TypeError(`new_ called with constructor type ${typeof x} which is not a function`);var j=iR(x.name||"unknownFunctionName",function(){});j.prototype=x.prototype;var lt=new j,Zt=x.apply(lt,D);return Zt instanceof Object?Zt:lt}function Bl(x,D,j,lt,Zt,yt){var Yt=D.length;Yt<2&&$n("argTypes array size mismatch! Must at least get return value and 'this' types!"),V(!yt,"Async bindings are only supported with JSPI.");for(var Dt=D[1]!==null&&j!==null,pe=!1,Se=1;Seup.unregister(D),kr(x))};function fZ(){if(this.$$.ptr||$R(this),this.$$.preservePointerOnDelete)return this.$$.count.value+=1,this;var x=kr(Object.create(Object.getPrototypeOf(this),{$$:{value:bc(this.$$)}}));return x.$$.count.value+=1,x.$$.deleteScheduled=!1,x}function xW(){this.$$.ptr||$R(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&$n("Object already scheduled for deletion"),LV(this),tb(this.$$),this.$$.preservePointerOnDelete||(this.$$.smartPtr=void 0,this.$$.ptr=void 0)}function XW(){return!this.$$.ptr}function OU(){return this.$$.ptr||$R(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&$n("Object already scheduled for deletion"),lh.push(this),lh.length===1&&lm&&lm(Zp),this.$$.deleteScheduled=!0,this}function nb(){rh.prototype.isAliasOf=BW,rh.prototype.clone=fZ,rh.prototype.delete=xW,rh.prototype.isDeleted=XW,rh.prototype.deleteLater=OU}function rh(){}var HU=48,Js=57;function ld(x){if(x===void 0)return"_unknown";x=x.replace(/[^a-zA-Z0-9_]/g,"$");var D=x.charCodeAt(0);return D>=HU&&D<=Js?`_${x}`:x}function ib(x,D){return x=ld(x),{[x]:function(){return D.apply(this,arguments)}}[x]}function wU(x,D,j){if(x[D].overloadTable===void 0){var lt=x[D];x[D]=function(){return x[D].overloadTable.hasOwnProperty(arguments.length)||$n(`Function '${j}' called with an invalid number of arguments (${arguments.length}) - expects one of (${x[D].overloadTable})!`),x[D].overloadTable[arguments.length].apply(this,arguments)},x[D].overloadTable=[],x[D].overloadTable[lt.argCount]=lt}}function PU(x,D,j){n.hasOwnProperty(x)?((j===void 0||n[x].overloadTable!==void 0&&n[x].overloadTable[j]!==void 0)&&$n(`Cannot register public name '${x}' twice`),wU(n,x,x),n.hasOwnProperty(j)&&$n(`Cannot register multiple overloads of a function with the same number of arguments (${j})!`),n[x].overloadTable[j]=D):(n[x]=D,j!==void 0&&(n[x].numArguments=j))}function JW(x,D,j,lt,ut,yt,Yt,Dt){this.name=x,this.constructor=D,this.instancePrototype=j,this.rawDestructor=lt,this.baseClass=ut,this.getActualType=yt,this.upcast=Yt,this.downcast=Dt,this.pureVirtualFunctions=[]}function FZ(x,D,j){for(;D!==j;)D.upcast||$n(`Expected null or instance of ${j.name}, got an instance of ${D.name}`),x=D.upcast(x),D=D.baseClass;return x}function vU(x,D){if(D===null)return this.isReference&&$n(`null is not a valid ${this.name}`),0;D.$$||$n(`Cannot pass "${ab(D)}" as a ${this.name}`),D.$$.ptr||$n(`Cannot pass deleted object as a pointer of type ${this.name}`);var j=D.$$.ptrType.registeredClass,lt=FZ(D.$$.ptr,j,this.registeredClass);return lt}function ug(x,D){var j;if(D===null)return this.isReference&&$n(`null is not a valid ${this.name}`),this.isSmartPointer?(j=this.rawConstructor(),x!==null&&x.push(this.rawDestructor,j),j):0;D.$$||$n(`Cannot pass "${ab(D)}" as a ${this.name}`),D.$$.ptr||$n(`Cannot pass deleted object as a pointer of type ${this.name}`),!this.isConst&&D.$$.ptrType.isConst&&$n(`Cannot convert argument of type ${D.$$.smartPtrType?D.$$.smartPtrType.name:D.$$.ptrType.name} to parameter type ${this.name}`);var lt=D.$$.ptrType.registeredClass;if(j=FZ(D.$$.ptr,lt,this.registeredClass),this.isSmartPointer)switch(D.$$.smartPtr===void 0&&$n("Passing raw pointer to smart pointer is illegal"),this.sharingPolicy){case 0:D.$$.smartPtrType===this?j=D.$$.smartPtr:$n(`Cannot convert argument of type ${D.$$.smartPtrType?D.$$.smartPtrType.name:D.$$.ptrType.name} to parameter type ${this.name}`);break;case 1:j=D.$$.smartPtr;break;case 2:if(D.$$.smartPtrType===this)j=D.$$.smartPtr;else{var ut=D.clone();j=this.rawShare(j,dh.toHandle(function(){ut.delete()})),x!==null&&x.push(this.rawDestructor,j)}break;default:$n("Unsupporting sharing policy")}return j}function Zg(x,D){if(D===null)return this.isReference&&$n(`null is not a valid ${this.name}`),0;D.$$||$n(`Cannot pass "${ab(D)}" as a ${this.name}`),D.$$.ptr||$n(`Cannot pass deleted object as a pointer of type ${this.name}`),D.$$.ptrType.isConst&&$n(`Cannot convert argument of type ${D.$$.ptrType.name} to parameter type ${this.name}`);var j=D.$$.ptrType.registeredClass,lt=FZ(D.$$.ptr,j,this.registeredClass);return lt}function ob(x){return this.fromWireType(_[x>>2])}function TN(x){return this.rawGetPointee&&(x=this.rawGetPointee(x)),x}function Cd(x){this.rawDestructor&&this.rawDestructor(x)}function KU(x){x!==null&&x.delete()}function Rg(){rm.prototype.getPointee=TN,rm.prototype.destructor=Cd,rm.prototype.argPackAdvance=8,rm.prototype.readValueFromPointer=ob,rm.prototype.deleteObject=KU,rm.prototype.fromWireType=bp}function rm(x,D,j,lt,ut,yt,Yt,Dt,pe,Te,en){this.name=x,this.registeredClass=D,this.isReference=j,this.isConst=lt,this.isSmartPointer=ut,this.pointeeType=yt,this.sharingPolicy=Yt,this.rawGetPointee=Dt,this.rawConstructor=pe,this.rawShare=Te,this.rawDestructor=en,!ut&&D.baseClass===void 0?lt?(this.toWireType=vU,this.destructorFunction=null):(this.toWireType=Zg,this.destructorFunction=null):this.toWireType=ug}function bg(x,D,j){n.hasOwnProperty(x)||hr("Replacing nonexistant public symbol"),n[x].overloadTable!==void 0&&j!==void 0?n[x].overloadTable[j]=D:(n[x]=D,n[x].argCount=j)}var LW=(x,D,j)=>{Z("dynCall_"+x in n,`bad function pointer type - dynCall function not found for sig '${x}'`),j&&j.length?Z(j.length===x.substring(1).replace(/j/g,"--").length):Z(x.length==1);var lt=n["dynCall_"+x];return j&&j.length?lt.apply(null,[D].concat(j)):lt.call(null,D)},Id=[],MW=x=>{var D=Id[x];return D||(x>=Id.length&&(Id.length=x+1),Id[x]=D=nt.get(x)),Z(nt.get(x)==D,"JavaScript-side Wasm function table mirror is out of date!"),D},Wg=(x,D,j)=>{if(x.includes("j"))return LW(x,D,j);Z(MW(D),`missing table entry in dynCall: ${D}`);var lt=MW(D).apply(null,j);return lt},fg=(x,D)=>{Z(x.includes("j")||x.includes("p"),"getDynCaller should only be called with i64 sigs");var j=[];return function(){return j.length=0,Object.assign(j,arguments),Wg(x,D,j)}};function dm(x,D){x=Bi(x);function j(){return x.includes("j")?fg(x,D):MW(D)}var lt=j();return typeof lt!="function"&&$n(`unknown function pointer with signature ${x}: ${D}`),lt}function Da(x,D){var j=ib(D,function(lt){this.name=D,this.message=lt;var ut=new Error(lt).stack;ut!==void 0&&(this.stack=this.toString()+` +`+ut.replace(/^Error(:[^\n]*)?\n/,""))});return j.prototype=Object.create(x.prototype),j.prototype.constructor=j,j.prototype.toString=function(){return this.message===void 0?this.name:`${this.name}: ${this.message}`},j}var un=void 0;function Kt(x){var D=i8(x),j=Bi(D);return Vs(D),j}function De(x,D){var j=[],lt={};function ut(yt){if(!lt[yt]&&!zi[yt]){if(js[yt]){js[yt].forEach(ut);return}j.push(yt),lt[yt]=!0}}throw D.forEach(ut),new un(`${x}: `+j.map(Kt).join([", "]))}function ti(x,D,j,lt,ut,yt,Yt,Dt,pe,Te,en,Zn,Rn){en=Bi(en),yt=dm(ut,yt),Dt&&(Dt=dm(Yt,Dt)),Te&&(Te=dm(pe,Te)),Rn=dm(Zn,Rn);var bn=ld(en);PU(bn,function(){De(`Cannot construct ${en} due to unbound types`,[lt])}),pr([x,D,j],lt?[lt]:[],function(Xn){Xn=Xn[0];var vi,Ea;lt?(vi=Xn.registeredClass,Ea=vi.instancePrototype):Ea=rh.prototype;var Oo=ib(bn,function(){if(Object.getPrototypeOf(this)!==Le)throw new ca("Use 'new' to construct "+en);if(kn.constructor_body===void 0)throw new ca(en+" has no accessible constructor");var _s=kn.constructor_body[arguments.length];if(_s===void 0)throw new ca(`Tried to invoke ctor of ${en} with invalid number of parameters (${arguments.length}) - expected (${Object.keys(kn.constructor_body).toString()}) parameters instead!`);return _s.apply(this,arguments)}),Le=Object.create(Ea,{constructor:{value:Oo}});Oo.prototype=Le;var kn=new JW(en,Oo,Le,Rn,vi,yt,Dt,Te);kn.baseClass&&(kn.baseClass.__derivedClasses===void 0&&(kn.baseClass.__derivedClasses=[]),kn.baseClass.__derivedClasses.push(kn));var fa=new rm(en,kn,!0,!1,!1),Ya=new rm(en+"*",kn,!1,!1,!1),Nd=new rm(en+" const*",kn,!1,!0,!1);return YW[x]={pointerType:Ya,constPointerType:Nd},bg(bn,Oo),[fa,Ya,Nd]})}function Hi(x,D){for(var j=[],lt=0;lt>2]);return j}function bl(x){for(;x.length;){var D=x.pop(),j=x.pop();j(D)}}function Pl(x,D){if(!(x instanceof Function))throw new TypeError(`new_ called with constructor type ${typeof x} which is not a function`);var j=ib(x.name||"unknownFunctionName",function(){});j.prototype=x.prototype;var lt=new j,ut=x.apply(lt,D);return ut instanceof Object?ut:lt}function Bl(x,D,j,lt,ut,yt){var Yt=D.length;Yt<2&&$n("argTypes array size mismatch! Must at least get return value and 'this' types!"),Z(!yt,"Async bindings are only supported with JSPI.");for(var Dt=D[1]!==null&&j!==null,pe=!1,Te=1;Te0?", ":"")+bn),Rn+=(en||yt?"var rv = ":"")+"invoker(fn"+(bn.length>0?", ":"")+bn+`); -`,pe)Rn+=`runDestructors(destructors); -`;else for(var Se=Dt?1:2;Se0?", ":"")+Rn),bn+=(en||yt?"var rv = ":"")+"invoker(fn"+(Rn.length>0?", ":"")+Rn+`); +`,pe)bn+=`runDestructors(destructors); +`;else for(var Te=Dt?1:2;Te0);var Yt=Hi(D,j);Zt=dm(lt,Zt),pr([],[x],function(Dt){Dt=Dt[0];var pe=`constructor ${Dt.name}`;if(Dt.registeredClass.constructor_body===void 0&&(Dt.registeredClass.constructor_body=[]),Dt.registeredClass.constructor_body[D-1]!==void 0)throw new ca(`Cannot register multiple constructors with identical number of parameters (${D-1}) for class '${Dt.name}'! Overload resolution is currently only performed using the parameter count, not actual type info!`);return Dt.registeredClass.constructor_body[D-1]=()=>{De(`Cannot construct ${Dt.name} due to unbound types`,Yt)},pr([],Yt,function(Se){return Se.splice(1,0,null),Dt.registeredClass.constructor_body[D-1]=Bl(pe,Se,null,Zt,yt),[]}),[]})}function ps(x,D,j,lt,Zt,yt,Yt,Dt,pe){var Se=Hi(j,lt);D=Bi(D),yt=dm(Zt,yt),pr([],[x],function(en){en=en[0];var Vn=`${en.name}.${D}`;D.startsWith("@@")&&(D=Symbol[D.substring(2)]),Dt&&en.registeredClass.pureVirtualFunctions.push(D);function bn(){De(`Cannot call ${Vn} due to unbound types`,Se)}var Rn=en.registeredClass.instancePrototype,Xn=Rn[D];return Xn===void 0||Xn.overloadTable===void 0&&Xn.className!==en.name&&Xn.argCount===j-2?(bn.argCount=j-2,bn.className=en.name,Rn[D]=bn):(wU(Rn,D,Vn),Rn[D].overloadTable[j-2]=bn),pr([],Se,function(vi){var Ea=Bl(Vn,vi,en,yt,Yt,pe);return Rn[D].overloadTable===void 0?(Ea.argCount=j-2,Rn[D]=Ea):Rn[D].overloadTable[j-2]=Ea,[]}),[]})}function Ql(x,D,j){return x instanceof Object||$n(`${j} with invalid "this": ${x}`),x instanceof D.registeredClass.constructor||$n(`${j} incompatible with "this" of type ${x.constructor.name}`),x.$$.ptr||$n(`cannot call emscripten binding method ${j} on deleted object`),FV(x.$$.ptr,x.$$.ptrType.registeredClass,D.registeredClass)}function Wp(x,D,j,lt,Zt,yt,Yt,Dt,pe,Se){D=Bi(D),Zt=dm(lt,Zt),pr([],[x],function(en){en=en[0];var Vn=`${en.name}.${D}`,bn={get(){De(`Cannot access ${Vn} due to unbound types`,[j,Yt])},enumerable:!0,configurable:!0};return pe?bn.set=()=>{De(`Cannot access ${Vn} due to unbound types`,[j,Yt])}:bn.set=Rn=>{$n(Vn+" is a read-only property")},Object.defineProperty(en.registeredClass.instancePrototype,D,bn),pr([],pe?[j,Yt]:[j],function(Rn){var Xn=Rn[0],vi={get(){var Oo=Ql(this,en,Vn+" getter");return Xn.fromWireType(Zt(yt,Oo))},enumerable:!0};if(pe){pe=dm(Dt,pe);var Ea=Rn[1];vi.set=function(Oo){var Le=Ql(this,en,Vn+" setter"),kn=[];pe(Se,Le,Ea.toWireType(kn,Oo)),Rl(kn)}}return Object.defineProperty(en.registeredClass.instancePrototype,D,vi),[]}),[]})}function zU(){Object.assign(Fg.prototype,{get(x){return V(this.allocated[x]!==void 0,`invalid handle: ${x}`),this.allocated[x]},has(x){return this.allocated[x]!==void 0},allocate(x){var D=this.freelist.pop()||this.allocated.length;return this.allocated[D]=x,D},free(x){V(this.allocated[x]!==void 0),this.allocated[x]=void 0,this.freelist.push(x)}})}function Fg(){this.allocated=[void 0],this.freelist=[]}var Ls=new Fg;function Ug(x){x>=Ls.reserved&&--Ls.get(x).refcount===0&&Ls.free(x)}function lO(){for(var x=0,D=Ls.reserved;D(x||$n("Cannot use deleted val. handle = "+x),Ls.get(x).value),toHandle:x=>{switch(x){case void 0:return 1;case null:return 2;case!0:return 3;case!1:return 4;default:return Ls.allocate({refcount:1,value:x})}}};function dO(x,D){D=Bi(D),ma(x,{name:D,fromWireType:function(j){var lt=dh.toValue(j);return Ug(j),lt},toWireType:function(j,lt){return dh.toHandle(lt)},argPackAdvance:8,readValueFromPointer:oR,destructorFunction:null})}function aR(x){if(x===null)return"null";var D=typeof x;return D==="object"||D==="array"||D==="function"?x.toString():""+x}function Wc(x,D){switch(D){case 2:return function(j){return this.fromWireType(w[j>>2])};case 3:return function(j){return this.fromWireType(z[j>>3])};default:throw new TypeError("Unknown float type: "+x)}}function y4(x,D,j){var lt=Wa(j);D=Bi(D),ma(x,{name:D,fromWireType:function(Zt){return Zt},toWireType:function(Zt,yt){if(typeof yt!="number"&&typeof yt!="boolean")throw new TypeError(`Cannot convert ${aR(yt)} to ${this.name}`);return yt},argPackAdvance:8,readValueFromPointer:Wc(D,lt),destructorFunction:null})}function cm(x,D,j,lt,Zt,yt,Yt){var Dt=Hi(D,j);x=Bi(x),Zt=dm(lt,Zt),PU(x,function(){De(`Cannot call ${x} due to unbound types`,Dt)},D-1),pr([],Dt,function(pe){var Se=[pe[0],null].concat(pe.slice(1));return Rg(x,Bl(x,Se,null,Zt,yt,Yt),D-1),[]})}function B4(x,D,j){switch(D){case 0:return j?function(Zt){return E[Zt]}:function(Zt){return I[Zt]};case 1:return j?function(Zt){return B[Zt>>1]}:function(Zt){return X[Zt>>1]};case 2:return j?function(Zt){return _[Zt>>2]}:function(Zt){return P[Zt>>2]};default:throw new TypeError("Unknown integer type: "+x)}}function cO(x,D,j,lt,Zt){D=Bi(D),Zt===-1&&(Zt=4294967295);var yt=Wa(j),Yt=Vn=>Vn;if(lt===0){var Dt=32-8*j;Yt=Vn=>Vn<

>>Dt}var pe=D.includes("unsigned"),Se=(Vn,bn)=>{if(typeof Vn!="number"&&typeof Vn!="boolean")throw new TypeError(`Cannot convert "${aR(Vn)}" to ${bn}`);if(VnZt)throw new TypeError(`Passing a number "${aR(Vn)}" from JS side to C/C++ side to an argument of type "${D}", which is outside the valid range [${lt}, ${Zt}]!`)},en;pe?en=function(Vn,bn){return Se(bn,this.name),bn>>>0}:en=function(Vn,bn){return Se(bn,this.name),bn},ma(x,{name:D,fromWireType:Yt,toWireType:en,argPackAdvance:8,readValueFromPointer:B4(D,yt,lt!==0),destructorFunction:null})}function UV(x,D,j){var lt=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],Zt=lt[D];function yt(Yt){Yt=Yt>>2;var Dt=P,pe=Dt[Yt],Se=Dt[Yt+1];return new Zt(Dt.buffer,Se,pe)}j=Bi(j),ma(x,{name:j,fromWireType:yt,argPackAdvance:8,readValueFromPointer:yt},{ignoreDuplicateRegistrations:!0})}var _W=(x,D,j,lt)=>{if(V(typeof x=="string"),!(lt>0))return 0;for(var Zt=j,yt=j+lt-1,Yt=0;Yt=55296&&Dt<=57343){var pe=x.charCodeAt(++Yt);Dt=65536+((Dt&1023)<<10)|pe&1023}if(Dt<=127){if(j>=yt)break;D[j++]=Dt}else if(Dt<=2047){if(j+1>=yt)break;D[j++]=192|Dt>>6,D[j++]=128|Dt&63}else if(Dt<=65535){if(j+2>=yt)break;D[j++]=224|Dt>>12,D[j++]=128|Dt>>6&63,D[j++]=128|Dt&63}else{if(j+3>=yt)break;Dt>1114111&&Go("Invalid Unicode code point "+na(Dt)+" encountered when serializing a JS string to a UTF-8 string in wasm memory! (Valid unicode code points should be in range 0-0x10FFFF)."),D[j++]=240|Dt>>18,D[j++]=128|Dt>>12&63,D[j++]=128|Dt>>6&63,D[j++]=128|Dt&63}}return D[j]=0,j-Zt},DW=(x,D,j)=>(V(typeof j=="number","stringToUTF8(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),_W(x,I,D,j)),Ta=x=>{for(var D=0,j=0;j=55296&<<=57343?(D+=4,++j):D+=3}return D},_u=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,GV=(x,D,j)=>{for(var lt=D+j,Zt=D;x[Zt]&&!(Zt>=lt);)++Zt;if(Zt-D>16&&x.buffer&&_u)return _u.decode(x.subarray(D,Zt));for(var yt="";D>10,56320|Se&1023)}}return yt},OW=(x,D)=>(V(typeof x=="number"),x?GV(I,x,D):"");function gN(x,D){D=Bi(D);var j=D==="std::string";ma(x,{name:D,fromWireType:function(lt){var Zt=P[lt>>2],yt=lt+4,Yt;if(j)for(var Dt=yt,pe=0;pe<=Zt;++pe){var Se=yt+pe;if(pe==Zt||I[Se]==0){var en=Se-Dt,Vn=OW(Dt,en);Yt===void 0?Yt=Vn:(Yt+="\0",Yt+=Vn),Dt=Se+1}}else{for(var bn=new Array(Zt),pe=0;pe>2]=yt,j&&Yt)DW(Zt,pe,yt+1);else if(Yt)for(var Se=0;Se255&&(us(pe),$n("String has UTF-16 code units that do not fit in 8 bits")),I[pe+Se]=en}else for(var Se=0;Se{V(x%2==0,"Pointer passed to UTF16ToString must be aligned to two bytes!");for(var j=x,lt=j>>1,Zt=lt+D/2;!(lt>=Zt)&&X[lt];)++lt;if(j=lt<<1,j-x>32&&mO)return mO.decode(I.subarray(x,j));for(var yt="",Yt=0;!(Yt>=D/2);++Yt){var Dt=B[x+Yt*2>>1];if(Dt==0)break;yt+=String.fromCharCode(Dt)}return yt},k4=(x,D,j)=>{if(V(D%2==0,"Pointer passed to stringToUTF16 must be aligned to two bytes!"),V(typeof j=="number","stringToUTF16(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),j===void 0&&(j=2147483647),j<2)return 0;j-=2;for(var lt=D,Zt=j>1]=Yt,D+=2}return B[D>>1]=0,D-lt},hO=x=>x.length*2,Gg=(x,D)=>{V(x%4==0,"Pointer passed to UTF32ToString must be aligned to four bytes!");for(var j=0,lt="";!(j>=D/4);){var Zt=_[x+j*4>>2];if(Zt==0)break;if(++j,Zt>=65536){var yt=Zt-65536;lt+=String.fromCharCode(55296|yt>>10,56320|yt&1023)}else lt+=String.fromCharCode(Zt)}return lt},HW=(x,D,j)=>{if(V(D%4==0,"Pointer passed to stringToUTF32 must be aligned to four bytes!"),V(typeof j=="number","stringToUTF32(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),j===void 0&&(j=2147483647),j<4)return 0;for(var lt=D,Zt=lt+j-4,yt=0;yt=55296&&Yt<=57343){var Dt=x.charCodeAt(++yt);Yt=65536+((Yt&1023)<<10)|Dt&1023}if(_[D>>2]=Yt,D+=4,D+4>Zt)break}return _[D>>2]=0,D-lt},Y4=x=>{for(var D=0,j=0;j=55296&<<=57343&&++j,D+=4}return D},pO=function(x,D,j){j=Bi(j);var lt,Zt,yt,Yt,Dt;D===2?(lt=Q4,Zt=k4,Yt=hO,yt=()=>X,Dt=1):D===4&&(lt=Gg,Zt=HW,Yt=Y4,yt=()=>P,Dt=2),ma(x,{name:j,fromWireType:function(pe){for(var Se=P[pe>>2],en=yt(),Vn,bn=pe+4,Rn=0;Rn<=Se;++Rn){var Xn=pe+4+Rn*D;if(Rn==Se||en[Xn>>Dt]==0){var vi=Xn-bn,Ea=lt(bn,vi);Vn===void 0?Vn=Ea:(Vn+="\0",Vn+=Ea),bn=Xn+D}}return us(pe),Vn},toWireType:function(pe,Se){typeof Se!="string"&&$n(`Cannot pass non-string to C++ string type ${j}`);var en=Yt(Se),Vn=Ms(4+en+D);return P[Vn>>2]=en>>Dt,Zt(Se,Vn+4,en+D),pe!==null&&pe.push(us,Vn),Vn},argPackAdvance:8,readValueFromPointer:oR,destructorFunction:function(pe){us(pe)}})};function uO(x,D){D=Bi(D),ma(x,{isVoid:!0,name:D,argPackAdvance:0,fromWireType:function(){},toWireType:function(j,lt){}})}var EN=!0,CN=()=>EN;function ZO(x,D){var j=zi[x];return j===void 0&&$n(D+" has unknown type "+Kt(x)),j}function x4(x,D,j){x=dh.toValue(x),D=ZO(D,"emval::as");var lt=[],Zt=dh.toHandle(lt);return P[j>>2]=Zt,D.toWireType(lt,x)}function IN(x,D){return x=dh.toValue(x),D=dh.toValue(D),dh.toHandle(x[D])}var NN={};function X4(x){var D=NN[x];return D===void 0?Bi(x):D}function VO(x){return dh.toHandle(X4(x))}function fc(x){var D=dh.toValue(x);Rl(D),Ug(x)}function Ag(x,D){return V(x==x>>>0||x==(x|0)),V(D===(D|0)),D+2097152>>>0<4194305-!!x?(x>>>0)+D*4294967296:NaN}function jU(x,D,j){var lt=Ag(x,D),Zt=new Date(lt*1e3);_[j>>2]=Zt.getUTCSeconds(),_[j+4>>2]=Zt.getUTCMinutes(),_[j+8>>2]=Zt.getUTCHours(),_[j+12>>2]=Zt.getUTCDate(),_[j+16>>2]=Zt.getUTCMonth(),_[j+20>>2]=Zt.getUTCFullYear()-1900,_[j+24>>2]=Zt.getUTCDay();var yt=Date.UTC(Zt.getUTCFullYear(),0,1,0,0,0,0),Yt=(Zt.getTime()-yt)/(1e3*60*60*24)|0;_[j+28>>2]=Yt}var wW=x=>x%4===0&&(x%100!==0||x%400===0),bO=[0,31,60,91,121,152,182,213,244,274,305,335],J4=[0,31,59,90,120,151,181,212,243,273,304,334],L4=x=>{var D=wW(x.getFullYear()),j=D?bO:J4,lt=j[x.getMonth()]+x.getDate()-1;return lt},M4=function(x){var D=(()=>{var j=new Date(_[x+20>>2]+1900,_[x+16>>2],_[x+12>>2],_[x+8>>2],_[x+4>>2],_[x>>2],0),lt=_[x+32>>2],Zt=j.getTimezoneOffset(),yt=new Date(j.getFullYear(),0,1),Yt=new Date(j.getFullYear(),6,1).getTimezoneOffset(),Dt=yt.getTimezoneOffset(),pe=Math.min(Dt,Yt);if(lt<0)_[x+32>>2]=+(Yt!=Dt&&pe==Zt);else if(lt>0!=(pe==Zt)){var Se=Math.max(Dt,Yt),en=lt>0?pe:Se;j.setTime(j.getTime()+(en-Zt)*6e4)}_[x+24>>2]=j.getDay();var Vn=L4(j)|0;return _[x+28>>2]=Vn,_[x>>2]=j.getSeconds(),_[x+4>>2]=j.getMinutes(),_[x+8>>2]=j.getHours(),_[x+12>>2]=j.getDate(),_[x+16>>2]=j.getMonth(),_[x+20>>2]=j.getYear(),j.getTime()/1e3})();return JN((qn=D,+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)),D>>>0},RO=x=>{var D=Ta(x)+1,j=Ms(D);return j&&DW(x,j,D),j},_4=(x,D,j)=>{var lt=new Date().getFullYear(),Zt=new Date(lt,0,1),yt=new Date(lt,6,1),Yt=Zt.getTimezoneOffset(),Dt=yt.getTimezoneOffset(),pe=Math.max(Yt,Dt);P[x>>2]=pe*60,_[D>>2]=+(Yt!=Dt);function Se(Xn){var vi=Xn.toTimeString().match(/\(([A-Za-z ]+)\)$/);return vi?vi[1]:"GMT"}var en=Se(Zt),Vn=Se(yt),bn=RO(en),Rn=RO(Vn);Dt>2]=bn,P[j+4>>2]=Rn):(P[j>>2]=Rn,P[j+4>>2]=bn)},PW=()=>{We("native code called abort()")},Tg=[],D4=(x,D)=>{V(Array.isArray(Tg)),V(D%16==0),Tg.length=0;var j;for(D>>=2;j=I[x++];){var lt=String.fromCharCode(j),Zt=["d","f","i"];V(Zt.includes(lt),`Invalid character ${j}("${lt}") in readEmAsmArgs! Use only [${Zt}], and do not specify "v" for void return argument.`),D+=j!=105&D,Tg.push(j==105?_[D]:z[D++>>1]),++D}return Tg},yN=(x,D,j)=>{var lt=D4(D,j);return da.hasOwnProperty(x)||We(`No EM_ASM constant found at address ${x}`),da[x].apply(null,lt)},WO=(x,D,j)=>yN(x,D,j);function AV(){return Date.now()}var qU;qU=()=>performance.now();var O4=(x,D,j)=>I.copyWithin(x,D,D+j),H4=()=>2147483648,w4=x=>{var D=Y.buffer,j=x-D.byteLength+65535>>>16;try{return Y.grow(j),H(),1}catch(lt){g(`growMemory: Attempted to grow heap from ${D.byteLength} bytes to ${x} bytes, but got error: ${lt}`)}},vW=x=>{var D=I.length;x>>>=0,V(x>D);var j=H4();if(x>j)return g(`Cannot enlarge memory, asked to go up to ${x} bytes, but the limit is ${j} bytes!`),!1;for(var lt=(pe,Se)=>pe+(Se-pe%Se)%Se,Zt=1;Zt<=4;Zt*=2){var yt=D*(1+.2/Zt);yt=Math.min(yt,x+100663296);var Yt=Math.min(j,lt(Math.max(x,yt),65536)),Dt=w4(Yt);if(Dt)return!0}return g(`Failed to grow the heap from ${D} bytes to ${Yt} bytes, not enough memory!`),!1},mm=x=>{var D=(globalThis.eval["\u2003"]=globalThis.eval)(OW(x));if(D==null)return 0;D+="";var j=mm,lt=Ta(D);return(!j.bufferSize||j.bufferSizel||"./this.program",$U=()=>{if(!$U.strings){var x=(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",D={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:x,_:P4()};for(var j in Sg)Sg[j]===void 0?delete D[j]:D[j]=Sg[j];var lt=[];for(var j in D)lt.push(`${j}=${D[j]}`);$U.strings=lt}return $U.strings},v4=(x,D)=>{for(var j=0;j>0]=x.charCodeAt(j);E[D>>0]=0},Sa={isAbs:x=>x.charAt(0)==="/",splitPath:x=>{var D=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;return D.exec(x).slice(1)},normalizeArray:(x,D)=>{for(var j=0,lt=x.length-1;lt>=0;lt--){var Zt=x[lt];Zt==="."?x.splice(lt,1):Zt===".."?(x.splice(lt,1),j++):j&&(x.splice(lt,1),j--)}if(D)for(;j;j--)x.unshift("..");return x},normalize:x=>{var D=Sa.isAbs(x),j=x.substr(-1)==="/";return x=Sa.normalizeArray(x.split("/").filter(lt=>!!lt),!D).join("/"),!x&&!D&&(x="."),x&&j&&(x+="/"),(D?"/":"")+x},dirname:x=>{var D=Sa.splitPath(x),j=D[0],lt=D[1];return!j&&!lt?".":(lt&&(lt=lt.substr(0,lt.length-1)),j+lt)},basename:x=>{if(x==="/")return"/";x=Sa.normalize(x),x=x.replace(/\/$/,"");var D=x.lastIndexOf("/");return D===-1?x:x.substr(D+1)},join:function(){var x=Array.prototype.slice.call(arguments);return Sa.normalize(x.join("/"))},join2:(x,D)=>Sa.normalize(x+"/"+D)},K4=()=>{if(typeof crypto=="object"&&typeof crypto.getRandomValues=="function")return x=>crypto.getRandomValues(x);We("no cryptographic support found for randomDevice. consider polyfilling it if you want to use something insecure like Math.random(), e.g. put this in a --pre-js: var crypto = { getRandomValues: (array) => { for (var i = 0; i < array.length; i++) array[i] = (Math.random()*256)|0 } };")},Du=x=>(Du=K4())(x),vt={resolve:function(){for(var x="",D=!1,j=arguments.length-1;j>=-1&&!D;j--){var lt=j>=0?arguments[j]:ht.cwd();if(typeof lt!="string")throw new TypeError("Arguments to path.resolve must be strings");if(!lt)return"";x=lt+"/"+x,D=Sa.isAbs(lt)}return x=Sa.normalizeArray(x.split("/").filter(Zt=>!!Zt),!D).join("/"),(D?"/":"")+x||"."},relative:(x,D)=>{x=vt.resolve(x).substr(1),D=vt.resolve(D).substr(1);function j(Se){for(var en=0;en=0&&Se[Vn]==="";Vn--);return en>Vn?[]:Se.slice(en,Vn-en+1)}for(var lt=j(x.split("/")),Zt=j(D.split("/")),yt=Math.min(lt.length,Zt.length),Yt=yt,Dt=0;Dt0?j:Ta(x)+1,Zt=new Array(lt),yt=_W(x,Zt,0,Zt.length);return D&&(Zt.length=yt),Zt}var Jn=()=>{if(!Te.length){var x=null;if(typeof window<"u"&&typeof window.prompt=="function"?(x=window.prompt("Input: "),x!==null&&(x+=` +`),bn+=`} +`,vi.push(bn),Pl(Function,vi).apply(null,Ea)}function Yr(x,D,j,lt,ut,yt){Z(D>0);var Yt=Hi(D,j);ut=dm(lt,ut),pr([],[x],function(Dt){Dt=Dt[0];var pe=`constructor ${Dt.name}`;if(Dt.registeredClass.constructor_body===void 0&&(Dt.registeredClass.constructor_body=[]),Dt.registeredClass.constructor_body[D-1]!==void 0)throw new ca(`Cannot register multiple constructors with identical number of parameters (${D-1}) for class '${Dt.name}'! Overload resolution is currently only performed using the parameter count, not actual type info!`);return Dt.registeredClass.constructor_body[D-1]=()=>{De(`Cannot construct ${Dt.name} due to unbound types`,Yt)},pr([],Yt,function(Te){return Te.splice(1,0,null),Dt.registeredClass.constructor_body[D-1]=Bl(pe,Te,null,ut,yt),[]}),[]})}function ps(x,D,j,lt,ut,yt,Yt,Dt,pe){var Te=Hi(j,lt);D=Bi(D),yt=dm(ut,yt),pr([],[x],function(en){en=en[0];var Zn=`${en.name}.${D}`;D.startsWith("@@")&&(D=Symbol[D.substring(2)]),Dt&&en.registeredClass.pureVirtualFunctions.push(D);function Rn(){De(`Cannot call ${Zn} due to unbound types`,Te)}var bn=en.registeredClass.instancePrototype,Xn=bn[D];return Xn===void 0||Xn.overloadTable===void 0&&Xn.className!==en.name&&Xn.argCount===j-2?(Rn.argCount=j-2,Rn.className=en.name,bn[D]=Rn):(wU(bn,D,Zn),bn[D].overloadTable[j-2]=Rn),pr([],Te,function(vi){var Ea=Bl(Zn,vi,en,yt,Yt,pe);return bn[D].overloadTable===void 0?(Ea.argCount=j-2,bn[D]=Ea):bn[D].overloadTable[j-2]=Ea,[]}),[]})}function Ql(x,D,j){return x instanceof Object||$n(`${j} with invalid "this": ${x}`),x instanceof D.registeredClass.constructor||$n(`${j} incompatible with "this" of type ${x.constructor.name}`),x.$$.ptr||$n(`cannot call emscripten binding method ${j} on deleted object`),FZ(x.$$.ptr,x.$$.ptrType.registeredClass,D.registeredClass)}function Wp(x,D,j,lt,ut,yt,Yt,Dt,pe,Te){D=Bi(D),ut=dm(lt,ut),pr([],[x],function(en){en=en[0];var Zn=`${en.name}.${D}`,Rn={get(){De(`Cannot access ${Zn} due to unbound types`,[j,Yt])},enumerable:!0,configurable:!0};return pe?Rn.set=()=>{De(`Cannot access ${Zn} due to unbound types`,[j,Yt])}:Rn.set=bn=>{$n(Zn+" is a read-only property")},Object.defineProperty(en.registeredClass.instancePrototype,D,Rn),pr([],pe?[j,Yt]:[j],function(bn){var Xn=bn[0],vi={get(){var Oo=Ql(this,en,Zn+" getter");return Xn.fromWireType(ut(yt,Oo))},enumerable:!0};if(pe){pe=dm(Dt,pe);var Ea=bn[1];vi.set=function(Oo){var Le=Ql(this,en,Zn+" setter"),kn=[];pe(Te,Le,Ea.toWireType(kn,Oo)),bl(kn)}}return Object.defineProperty(en.registeredClass.instancePrototype,D,vi),[]}),[]})}function zU(){Object.assign(Fg.prototype,{get(x){return Z(this.allocated[x]!==void 0,`invalid handle: ${x}`),this.allocated[x]},has(x){return this.allocated[x]!==void 0},allocate(x){var D=this.freelist.pop()||this.allocated.length;return this.allocated[D]=x,D},free(x){Z(this.allocated[x]!==void 0),this.allocated[x]=void 0,this.freelist.push(x)}})}function Fg(){this.allocated=[void 0],this.freelist=[]}var Ls=new Fg;function Ug(x){x>=Ls.reserved&&--Ls.get(x).refcount===0&&Ls.free(x)}function lO(){for(var x=0,D=Ls.reserved;D(x||$n("Cannot use deleted val. handle = "+x),Ls.get(x).value),toHandle:x=>{switch(x){case void 0:return 1;case null:return 2;case!0:return 3;case!1:return 4;default:return Ls.allocate({refcount:1,value:x})}}};function dO(x,D){D=Bi(D),ma(x,{name:D,fromWireType:function(j){var lt=dh.toValue(j);return Ug(j),lt},toWireType:function(j,lt){return dh.toHandle(lt)},argPackAdvance:8,readValueFromPointer:ob,destructorFunction:null})}function ab(x){if(x===null)return"null";var D=typeof x;return D==="object"||D==="array"||D==="function"?x.toString():""+x}function Wc(x,D){switch(D){case 2:return function(j){return this.fromWireType(w[j>>2])};case 3:return function(j){return this.fromWireType(z[j>>3])};default:throw new TypeError("Unknown float type: "+x)}}function y4(x,D,j){var lt=Wa(j);D=Bi(D),ma(x,{name:D,fromWireType:function(ut){return ut},toWireType:function(ut,yt){if(typeof yt!="number"&&typeof yt!="boolean")throw new TypeError(`Cannot convert ${ab(yt)} to ${this.name}`);return yt},argPackAdvance:8,readValueFromPointer:Wc(D,lt),destructorFunction:null})}function cm(x,D,j,lt,ut,yt,Yt){var Dt=Hi(D,j);x=Bi(x),ut=dm(lt,ut),PU(x,function(){De(`Cannot call ${x} due to unbound types`,Dt)},D-1),pr([],Dt,function(pe){var Te=[pe[0],null].concat(pe.slice(1));return bg(x,Bl(x,Te,null,ut,yt,Yt),D-1),[]})}function B4(x,D,j){switch(D){case 0:return j?function(ut){return E[ut]}:function(ut){return I[ut]};case 1:return j?function(ut){return B[ut>>1]}:function(ut){return X[ut>>1]};case 2:return j?function(ut){return _[ut>>2]}:function(ut){return P[ut>>2]};default:throw new TypeError("Unknown integer type: "+x)}}function cO(x,D,j,lt,ut){D=Bi(D),ut===-1&&(ut=4294967295);var yt=Wa(j),Yt=Zn=>Zn;if(lt===0){var Dt=32-8*j;Yt=Zn=>Zn<
>>Dt}var pe=D.includes("unsigned"),Te=(Zn,Rn)=>{if(typeof Zn!="number"&&typeof Zn!="boolean")throw new TypeError(`Cannot convert "${ab(Zn)}" to ${Rn}`);if(Znut)throw new TypeError(`Passing a number "${ab(Zn)}" from JS side to C/C++ side to an argument of type "${D}", which is outside the valid range [${lt}, ${ut}]!`)},en;pe?en=function(Zn,Rn){return Te(Rn,this.name),Rn>>>0}:en=function(Zn,Rn){return Te(Rn,this.name),Rn},ma(x,{name:D,fromWireType:Yt,toWireType:en,argPackAdvance:8,readValueFromPointer:B4(D,yt,lt!==0),destructorFunction:null})}function UZ(x,D,j){var lt=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],ut=lt[D];function yt(Yt){Yt=Yt>>2;var Dt=P,pe=Dt[Yt],Te=Dt[Yt+1];return new ut(Dt.buffer,Te,pe)}j=Bi(j),ma(x,{name:j,fromWireType:yt,argPackAdvance:8,readValueFromPointer:yt},{ignoreDuplicateRegistrations:!0})}var _W=(x,D,j,lt)=>{if(Z(typeof x=="string"),!(lt>0))return 0;for(var ut=j,yt=j+lt-1,Yt=0;Yt=55296&&Dt<=57343){var pe=x.charCodeAt(++Yt);Dt=65536+((Dt&1023)<<10)|pe&1023}if(Dt<=127){if(j>=yt)break;D[j++]=Dt}else if(Dt<=2047){if(j+1>=yt)break;D[j++]=192|Dt>>6,D[j++]=128|Dt&63}else if(Dt<=65535){if(j+2>=yt)break;D[j++]=224|Dt>>12,D[j++]=128|Dt>>6&63,D[j++]=128|Dt&63}else{if(j+3>=yt)break;Dt>1114111&&Go("Invalid Unicode code point "+na(Dt)+" encountered when serializing a JS string to a UTF-8 string in wasm memory! (Valid unicode code points should be in range 0-0x10FFFF)."),D[j++]=240|Dt>>18,D[j++]=128|Dt>>12&63,D[j++]=128|Dt>>6&63,D[j++]=128|Dt&63}}return D[j]=0,j-ut},DW=(x,D,j)=>(Z(typeof j=="number","stringToUTF8(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),_W(x,I,D,j)),Sa=x=>{for(var D=0,j=0;j=55296&<<=57343?(D+=4,++j):D+=3}return D},_V=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,GZ=(x,D,j)=>{for(var lt=D+j,ut=D;x[ut]&&!(ut>=lt);)++ut;if(ut-D>16&&x.buffer&&_V)return _V.decode(x.subarray(D,ut));for(var yt="";D>10,56320|Te&1023)}}return yt},OW=(x,D)=>(Z(typeof x=="number"),x?GZ(I,x,D):"");function gN(x,D){D=Bi(D);var j=D==="std::string";ma(x,{name:D,fromWireType:function(lt){var ut=P[lt>>2],yt=lt+4,Yt;if(j)for(var Dt=yt,pe=0;pe<=ut;++pe){var Te=yt+pe;if(pe==ut||I[Te]==0){var en=Te-Dt,Zn=OW(Dt,en);Yt===void 0?Yt=Zn:(Yt+="\0",Yt+=Zn),Dt=Te+1}}else{for(var Rn=new Array(ut),pe=0;pe>2]=yt,j&&Yt)DW(ut,pe,yt+1);else if(Yt)for(var Te=0;Te255&&(Vs(pe),$n("String has UTF-16 code units that do not fit in 8 bits")),I[pe+Te]=en}else for(var Te=0;Te{Z(x%2==0,"Pointer passed to UTF16ToString must be aligned to two bytes!");for(var j=x,lt=j>>1,ut=lt+D/2;!(lt>=ut)&&X[lt];)++lt;if(j=lt<<1,j-x>32&&mO)return mO.decode(I.subarray(x,j));for(var yt="",Yt=0;!(Yt>=D/2);++Yt){var Dt=B[x+Yt*2>>1];if(Dt==0)break;yt+=String.fromCharCode(Dt)}return yt},k4=(x,D,j)=>{if(Z(D%2==0,"Pointer passed to stringToUTF16 must be aligned to two bytes!"),Z(typeof j=="number","stringToUTF16(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),j===void 0&&(j=2147483647),j<2)return 0;j-=2;for(var lt=D,ut=j>1]=Yt,D+=2}return B[D>>1]=0,D-lt},hO=x=>x.length*2,Gg=(x,D)=>{Z(x%4==0,"Pointer passed to UTF32ToString must be aligned to four bytes!");for(var j=0,lt="";!(j>=D/4);){var ut=_[x+j*4>>2];if(ut==0)break;if(++j,ut>=65536){var yt=ut-65536;lt+=String.fromCharCode(55296|yt>>10,56320|yt&1023)}else lt+=String.fromCharCode(ut)}return lt},HW=(x,D,j)=>{if(Z(D%4==0,"Pointer passed to stringToUTF32 must be aligned to four bytes!"),Z(typeof j=="number","stringToUTF32(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!"),j===void 0&&(j=2147483647),j<4)return 0;for(var lt=D,ut=lt+j-4,yt=0;yt=55296&&Yt<=57343){var Dt=x.charCodeAt(++yt);Yt=65536+((Yt&1023)<<10)|Dt&1023}if(_[D>>2]=Yt,D+=4,D+4>ut)break}return _[D>>2]=0,D-lt},Y4=x=>{for(var D=0,j=0;j=55296&<<=57343&&++j,D+=4}return D},pO=function(x,D,j){j=Bi(j);var lt,ut,yt,Yt,Dt;D===2?(lt=Q4,ut=k4,Yt=hO,yt=()=>X,Dt=1):D===4&&(lt=Gg,ut=HW,Yt=Y4,yt=()=>P,Dt=2),ma(x,{name:j,fromWireType:function(pe){for(var Te=P[pe>>2],en=yt(),Zn,Rn=pe+4,bn=0;bn<=Te;++bn){var Xn=pe+4+bn*D;if(bn==Te||en[Xn>>Dt]==0){var vi=Xn-Rn,Ea=lt(Rn,vi);Zn===void 0?Zn=Ea:(Zn+="\0",Zn+=Ea),Rn=Xn+D}}return Vs(pe),Zn},toWireType:function(pe,Te){typeof Te!="string"&&$n(`Cannot pass non-string to C++ string type ${j}`);var en=Yt(Te),Zn=Ms(4+en+D);return P[Zn>>2]=en>>Dt,ut(Te,Zn+4,en+D),pe!==null&&pe.push(Vs,Zn),Zn},argPackAdvance:8,readValueFromPointer:ob,destructorFunction:function(pe){Vs(pe)}})};function VO(x,D){D=Bi(D),ma(x,{isVoid:!0,name:D,argPackAdvance:0,fromWireType:function(){},toWireType:function(j,lt){}})}var EN=!0,CN=()=>EN;function uO(x,D){var j=zi[x];return j===void 0&&$n(D+" has unknown type "+Kt(x)),j}function x4(x,D,j){x=dh.toValue(x),D=uO(D,"emval::as");var lt=[],ut=dh.toHandle(lt);return P[j>>2]=ut,D.toWireType(lt,x)}function IN(x,D){return x=dh.toValue(x),D=dh.toValue(D),dh.toHandle(x[D])}var NN={};function X4(x){var D=NN[x];return D===void 0?Bi(x):D}function ZO(x){return dh.toHandle(X4(x))}function fc(x){var D=dh.toValue(x);bl(D),Ug(x)}function Ag(x,D){return Z(x==x>>>0||x==(x|0)),Z(D===(D|0)),D+2097152>>>0<4194305-!!x?(x>>>0)+D*4294967296:NaN}function jU(x,D,j){var lt=Ag(x,D),ut=new Date(lt*1e3);_[j>>2]=ut.getUTCSeconds(),_[j+4>>2]=ut.getUTCMinutes(),_[j+8>>2]=ut.getUTCHours(),_[j+12>>2]=ut.getUTCDate(),_[j+16>>2]=ut.getUTCMonth(),_[j+20>>2]=ut.getUTCFullYear()-1900,_[j+24>>2]=ut.getUTCDay();var yt=Date.UTC(ut.getUTCFullYear(),0,1,0,0,0,0),Yt=(ut.getTime()-yt)/(1e3*60*60*24)|0;_[j+28>>2]=Yt}var wW=x=>x%4===0&&(x%100!==0||x%400===0),RO=[0,31,60,91,121,152,182,213,244,274,305,335],J4=[0,31,59,90,120,151,181,212,243,273,304,334],L4=x=>{var D=wW(x.getFullYear()),j=D?RO:J4,lt=j[x.getMonth()]+x.getDate()-1;return lt},M4=function(x){var D=(()=>{var j=new Date(_[x+20>>2]+1900,_[x+16>>2],_[x+12>>2],_[x+8>>2],_[x+4>>2],_[x>>2],0),lt=_[x+32>>2],ut=j.getTimezoneOffset(),yt=new Date(j.getFullYear(),0,1),Yt=new Date(j.getFullYear(),6,1).getTimezoneOffset(),Dt=yt.getTimezoneOffset(),pe=Math.min(Dt,Yt);if(lt<0)_[x+32>>2]=+(Yt!=Dt&&pe==ut);else if(lt>0!=(pe==ut)){var Te=Math.max(Dt,Yt),en=lt>0?pe:Te;j.setTime(j.getTime()+(en-ut)*6e4)}_[x+24>>2]=j.getDay();var Zn=L4(j)|0;return _[x+28>>2]=Zn,_[x>>2]=j.getSeconds(),_[x+4>>2]=j.getMinutes(),_[x+8>>2]=j.getHours(),_[x+12>>2]=j.getDate(),_[x+16>>2]=j.getMonth(),_[x+20>>2]=j.getYear(),j.getTime()/1e3})();return JN((qn=D,+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)),D>>>0},bO=x=>{var D=Sa(x)+1,j=Ms(D);return j&&DW(x,j,D),j},_4=(x,D,j)=>{var lt=new Date().getFullYear(),ut=new Date(lt,0,1),yt=new Date(lt,6,1),Yt=ut.getTimezoneOffset(),Dt=yt.getTimezoneOffset(),pe=Math.max(Yt,Dt);P[x>>2]=pe*60,_[D>>2]=+(Yt!=Dt);function Te(Xn){var vi=Xn.toTimeString().match(/\(([A-Za-z ]+)\)$/);return vi?vi[1]:"GMT"}var en=Te(ut),Zn=Te(yt),Rn=bO(en),bn=bO(Zn);Dt>2]=Rn,P[j+4>>2]=bn):(P[j>>2]=bn,P[j+4>>2]=Rn)},PW=()=>{We("native code called abort()")},Sg=[],D4=(x,D)=>{Z(Array.isArray(Sg)),Z(D%16==0),Sg.length=0;var j;for(D>>=2;j=I[x++];){var lt=String.fromCharCode(j),ut=["d","f","i"];Z(ut.includes(lt),`Invalid character ${j}("${lt}") in readEmAsmArgs! Use only [${ut}], and do not specify "v" for void return argument.`),D+=j!=105&D,Sg.push(j==105?_[D]:z[D++>>1]),++D}return Sg},yN=(x,D,j)=>{var lt=D4(D,j);return da.hasOwnProperty(x)||We(`No EM_ASM constant found at address ${x}`),da[x].apply(null,lt)},WO=(x,D,j)=>yN(x,D,j);function AZ(){return Date.now()}var qU;qU=()=>performance.now();var O4=(x,D,j)=>I.copyWithin(x,D,D+j),H4=()=>2147483648,w4=x=>{var D=Y.buffer,j=x-D.byteLength+65535>>>16;try{return Y.grow(j),H(),1}catch(lt){g(`growMemory: Attempted to grow heap from ${D.byteLength} bytes to ${x} bytes, but got error: ${lt}`)}},vW=x=>{var D=I.length;x>>>=0,Z(x>D);var j=H4();if(x>j)return g(`Cannot enlarge memory, asked to go up to ${x} bytes, but the limit is ${j} bytes!`),!1;for(var lt=(pe,Te)=>pe+(Te-pe%Te)%Te,ut=1;ut<=4;ut*=2){var yt=D*(1+.2/ut);yt=Math.min(yt,x+100663296);var Yt=Math.min(j,lt(Math.max(x,yt),65536)),Dt=w4(Yt);if(Dt)return!0}return g(`Failed to grow the heap from ${D} bytes to ${Yt} bytes, not enough memory!`),!1},mm=x=>{var D=(globalThis.eval["\u2003"]=globalThis.eval)(OW(x));if(D==null)return 0;D+="";var j=mm,lt=Sa(D);return(!j.bufferSize||j.bufferSizel||"./this.program",$U=()=>{if(!$U.strings){var x=(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",D={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:x,_:P4()};for(var j in Tg)Tg[j]===void 0?delete D[j]:D[j]=Tg[j];var lt=[];for(var j in D)lt.push(`${j}=${D[j]}`);$U.strings=lt}return $U.strings},v4=(x,D)=>{for(var j=0;j>0]=x.charCodeAt(j);E[D>>0]=0},Ta={isAbs:x=>x.charAt(0)==="/",splitPath:x=>{var D=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;return D.exec(x).slice(1)},normalizeArray:(x,D)=>{for(var j=0,lt=x.length-1;lt>=0;lt--){var ut=x[lt];ut==="."?x.splice(lt,1):ut===".."?(x.splice(lt,1),j++):j&&(x.splice(lt,1),j--)}if(D)for(;j;j--)x.unshift("..");return x},normalize:x=>{var D=Ta.isAbs(x),j=x.substr(-1)==="/";return x=Ta.normalizeArray(x.split("/").filter(lt=>!!lt),!D).join("/"),!x&&!D&&(x="."),x&&j&&(x+="/"),(D?"/":"")+x},dirname:x=>{var D=Ta.splitPath(x),j=D[0],lt=D[1];return!j&&!lt?".":(lt&&(lt=lt.substr(0,lt.length-1)),j+lt)},basename:x=>{if(x==="/")return"/";x=Ta.normalize(x),x=x.replace(/\/$/,"");var D=x.lastIndexOf("/");return D===-1?x:x.substr(D+1)},join:function(){var x=Array.prototype.slice.call(arguments);return Ta.normalize(x.join("/"))},join2:(x,D)=>Ta.normalize(x+"/"+D)},K4=()=>{if(typeof crypto=="object"&&typeof crypto.getRandomValues=="function")return x=>crypto.getRandomValues(x);We("no cryptographic support found for randomDevice. consider polyfilling it if you want to use something insecure like Math.random(), e.g. put this in a --pre-js: var crypto = { getRandomValues: (array) => { for (var i = 0; i < array.length; i++) array[i] = (Math.random()*256)|0 } };")},DV=x=>(DV=K4())(x),vt={resolve:function(){for(var x="",D=!1,j=arguments.length-1;j>=-1&&!D;j--){var lt=j>=0?arguments[j]:ht.cwd();if(typeof lt!="string")throw new TypeError("Arguments to path.resolve must be strings");if(!lt)return"";x=lt+"/"+x,D=Ta.isAbs(lt)}return x=Ta.normalizeArray(x.split("/").filter(ut=>!!ut),!D).join("/"),(D?"/":"")+x||"."},relative:(x,D)=>{x=vt.resolve(x).substr(1),D=vt.resolve(D).substr(1);function j(Te){for(var en=0;en=0&&Te[Zn]==="";Zn--);return en>Zn?[]:Te.slice(en,Zn-en+1)}for(var lt=j(x.split("/")),ut=j(D.split("/")),yt=Math.min(lt.length,ut.length),Yt=yt,Dt=0;Dt0?j:Sa(x)+1,ut=new Array(lt),yt=_W(x,ut,0,ut.length);return D&&(ut.length=yt),ut}var Jn=()=>{if(!Se.length){var x=null;if(typeof window<"u"&&typeof window.prompt=="function"?(x=window.prompt("Input: "),x!==null&&(x+=` `)):typeof readline=="function"&&(x=readline(),x!==null&&(x+=` -`)),!x)return null;Te=me(x,!0)}return Te.shift()},Ai={ttys:[],init:function(){},shutdown:function(){},register:function(x,D){Ai.ttys[x]={input:[],output:[],ops:D},ht.registerDevice(x,Ai.stream_ops)},stream_ops:{open:function(x){var D=Ai.ttys[x.node.rdev];if(!D)throw new ht.ErrnoError(43);x.tty=D,x.seekable=!1},close:function(x){x.tty.ops.fsync(x.tty)},fsync:function(x){x.tty.ops.fsync(x.tty)},read:function(x,D,j,lt,Zt){if(!x.tty||!x.tty.ops.get_char)throw new ht.ErrnoError(60);for(var yt=0,Yt=0;Yt0&&(T(GV(x.output,0)),x.output=[])},ioctl_tcgets:function(x){return{c_iflag:25856,c_oflag:5,c_cflag:191,c_lflag:35387,c_cc:[3,28,127,21,4,0,1,0,17,19,26,0,18,15,23,22,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]}},ioctl_tcsets:function(x,D,j){return 0},ioctl_tiocgwinsz:function(x){return[24,80]}},default_tty1_ops:{put_char:function(x,D){D===null||D===10?(g(GV(x.output,0)),x.output=[]):D!=0&&x.output.push(D)},fsync:function(x){x.output&&x.output.length>0&&(g(GV(x.output,0)),x.output=[])}}},ia=x=>{We("internal error: mmapAlloc called but `emscripten_builtin_memalign` native symbol not exported")},ni={ops_table:null,mount(x){return ni.createNode(null,"/",16895,0)},createNode(x,D,j,lt){if(ht.isBlkdev(j)||ht.isFIFO(j))throw new ht.ErrnoError(63);ni.ops_table||(ni.ops_table={dir:{node:{getattr:ni.node_ops.getattr,setattr:ni.node_ops.setattr,lookup:ni.node_ops.lookup,mknod:ni.node_ops.mknod,rename:ni.node_ops.rename,unlink:ni.node_ops.unlink,rmdir:ni.node_ops.rmdir,readdir:ni.node_ops.readdir,symlink:ni.node_ops.symlink},stream:{llseek:ni.stream_ops.llseek}},file:{node:{getattr:ni.node_ops.getattr,setattr:ni.node_ops.setattr},stream:{llseek:ni.stream_ops.llseek,read:ni.stream_ops.read,write:ni.stream_ops.write,allocate:ni.stream_ops.allocate,mmap:ni.stream_ops.mmap,msync:ni.stream_ops.msync}},link:{node:{getattr:ni.node_ops.getattr,setattr:ni.node_ops.setattr,readlink:ni.node_ops.readlink},stream:{}},chrdev:{node:{getattr:ni.node_ops.getattr,setattr:ni.node_ops.setattr},stream:ht.chrdev_stream_ops}});var Zt=ht.createNode(x,D,j,lt);return ht.isDir(Zt.mode)?(Zt.node_ops=ni.ops_table.dir.node,Zt.stream_ops=ni.ops_table.dir.stream,Zt.contents={}):ht.isFile(Zt.mode)?(Zt.node_ops=ni.ops_table.file.node,Zt.stream_ops=ni.ops_table.file.stream,Zt.usedBytes=0,Zt.contents=null):ht.isLink(Zt.mode)?(Zt.node_ops=ni.ops_table.link.node,Zt.stream_ops=ni.ops_table.link.stream):ht.isChrdev(Zt.mode)&&(Zt.node_ops=ni.ops_table.chrdev.node,Zt.stream_ops=ni.ops_table.chrdev.stream),Zt.timestamp=Date.now(),x&&(x.contents[D]=Zt,x.timestamp=Zt.timestamp),Zt},getFileDataAsTypedArray(x){return x.contents?x.contents.subarray?x.contents.subarray(0,x.usedBytes):new Uint8Array(x.contents):new Uint8Array(0)},expandFileStorage(x,D){var j=x.contents?x.contents.length:0;if(!(j>=D)){var lt=1024*1024;D=Math.max(D,j*(j>>0),j!=0&&(D=Math.max(D,256));var Zt=x.contents;x.contents=new Uint8Array(D),x.usedBytes>0&&x.contents.set(Zt.subarray(0,x.usedBytes),0)}},resizeFileStorage(x,D){if(x.usedBytes!=D)if(D==0)x.contents=null,x.usedBytes=0;else{var j=x.contents;x.contents=new Uint8Array(D),j&&x.contents.set(j.subarray(0,Math.min(D,x.usedBytes))),x.usedBytes=D}},node_ops:{getattr(x){var D={};return D.dev=ht.isChrdev(x.mode)?x.id:1,D.ino=x.id,D.mode=x.mode,D.nlink=1,D.uid=0,D.gid=0,D.rdev=x.rdev,ht.isDir(x.mode)?D.size=4096:ht.isFile(x.mode)?D.size=x.usedBytes:ht.isLink(x.mode)?D.size=x.link.length:D.size=0,D.atime=new Date(x.timestamp),D.mtime=new Date(x.timestamp),D.ctime=new Date(x.timestamp),D.blksize=4096,D.blocks=Math.ceil(D.size/D.blksize),D},setattr(x,D){D.mode!==void 0&&(x.mode=D.mode),D.timestamp!==void 0&&(x.timestamp=D.timestamp),D.size!==void 0&&ni.resizeFileStorage(x,D.size)},lookup(x,D){throw ht.genericErrors[44]},mknod(x,D,j,lt){return ni.createNode(x,D,j,lt)},rename(x,D,j){if(ht.isDir(x.mode)){var lt;try{lt=ht.lookupNode(D,j)}catch{}if(lt)for(var Zt in lt.contents)throw new ht.ErrnoError(55)}delete x.parent.contents[x.name],x.parent.timestamp=Date.now(),x.name=j,D.contents[j]=x,D.timestamp=x.parent.timestamp,x.parent=D},unlink(x,D){delete x.contents[D],x.timestamp=Date.now()},rmdir(x,D){var j=ht.lookupNode(x,D);for(var lt in j.contents)throw new ht.ErrnoError(55);delete x.contents[D],x.timestamp=Date.now()},readdir(x){var D=[".",".."];for(var j in x.contents)x.contents.hasOwnProperty(j)&&D.push(j);return D},symlink(x,D,j){var lt=ni.createNode(x,D,41471,0);return lt.link=j,lt},readlink(x){if(!ht.isLink(x.mode))throw new ht.ErrnoError(28);return x.link}},stream_ops:{read(x,D,j,lt,Zt){var yt=x.node.contents;if(Zt>=x.node.usedBytes)return 0;var Yt=Math.min(x.node.usedBytes-Zt,lt);if(V(Yt>=0),Yt>8&&yt.subarray)D.set(yt.subarray(Zt,Zt+Yt),j);else for(var Dt=0;Dt0||j+D{var Zt=lt?"":zt(`al ${x}`);U(x,yt=>{V(yt,`Loading data file "${x}" failed (no arrayBuffer).`),D(new Uint8Array(yt)),Zt&&ue(Zt)},yt=>{if(j)j();else throw`Loading data file "${x}" failed.`}),Zt&&ke(Zt)},BN=n.preloadPlugins||[];function z4(x,D,j,lt){typeof Browser<"u"&&Browser.init();var Zt=!1;return BN.forEach(function(yt){Zt||yt.canHandle(D)&&(yt.handle(x,D,j,lt),Zt=!0)}),Zt}function hm(x,D,j,lt,Zt,yt,Yt,Dt,pe,Se){var en=D?vt.resolve(Sa.join2(x,D)):x,Vn=zt(`cp ${en}`);function bn(Rn){function Xn(vi){Se&&Se(),Dt||ht.createDataFile(x,D,vi,lt,Zt,pe),yt&&yt(),ue(Vn)}z4(Rn,en,Xn,()=>{Yt&&Yt(),ue(Vn)})||Xn(Rn)}ke(Vn),typeof j=="string"?Oa(j,Rn=>bn(Rn),Yt):bn(j)}function gg(x){var D={r:0,"r+":2,w:577,"w+":578,a:1089,"a+":1090},j=D[x];if(typeof j>"u")throw new Error(`Unknown file open mode: ${x}`);return j}function QN(x,D){var j=0;return x&&(j|=365),D&&(j|=146),j}var KW={0:"Success",1:"Arg list too long",2:"Permission denied",3:"Address already in use",4:"Address not available",5:"Address family not supported by protocol family",6:"No more processes",7:"Socket already connected",8:"Bad file number",9:"Trying to read unreadable message",10:"Mount device busy",11:"Operation canceled",12:"No children",13:"Connection aborted",14:"Connection refused",15:"Connection reset by peer",16:"File locking deadlock error",17:"Destination address required",18:"Math arg out of domain of func",19:"Quota exceeded",20:"File exists",21:"Bad address",22:"File too large",23:"Host is unreachable",24:"Identifier removed",25:"Illegal byte sequence",26:"Connection already in progress",27:"Interrupted system call",28:"Invalid argument",29:"I/O error",30:"Socket is already connected",31:"Is a directory",32:"Too many symbolic links",33:"Too many open files",34:"Too many links",35:"Message too long",36:"Multihop attempted",37:"File or path name too long",38:"Network interface is not configured",39:"Connection reset by network",40:"Network is unreachable",41:"Too many open files in system",42:"No buffer space available",43:"No such device",44:"No such file or directory",45:"Exec format error",46:"No record locks available",47:"The link has been severed",48:"Not enough core",49:"No message of desired type",50:"Protocol not available",51:"No space left on device",52:"Function not implemented",53:"Socket is not connected",54:"Not a directory",55:"Directory not empty",56:"State not recoverable",57:"Socket operation on non-socket",59:"Not a typewriter",60:"No such device or address",61:"Value too large for defined data type",62:"Previous owner died",63:"Not super-user",64:"Broken pipe",65:"Protocol error",66:"Unknown protocol",67:"Protocol wrong type for socket",68:"Math result not representable",69:"Read only file system",70:"Illegal seek",71:"No such process",72:"Stale file handle",73:"Connection timed out",74:"Text file busy",75:"Cross-device link",100:"Device not a stream",101:"Bad font file fmt",102:"Invalid slot",103:"Invalid request code",104:"No anode",105:"Block device required",106:"Channel number out of range",107:"Level 3 halted",108:"Level 3 reset",109:"Link number out of range",110:"Protocol driver not attached",111:"No CSI structure available",112:"Level 2 halted",113:"Invalid exchange",114:"Invalid request descriptor",115:"Exchange full",116:"No data (for no delay io)",117:"Timer expired",118:"Out of streams resources",119:"Machine is not on the network",120:"Package not installed",121:"The object is remote",122:"Advertise error",123:"Srmount error",124:"Communication error on send",125:"Cross mount point (not really error)",126:"Given log. name not unique",127:"f.d. invalid for this operation",128:"Remote address changed",129:"Can access a needed shared lib",130:"Accessing a corrupted shared lib",131:".lib section in a.out corrupted",132:"Attempting to link in too many libs",133:"Attempting to exec a shared library",135:"Streams pipe error",136:"Too many users",137:"Socket type not supported",138:"Not supported",139:"Protocol family not supported",140:"Can't send after socket shutdown",141:"Too many references",142:"Host is down",148:"No medium (in tape drive)",156:"Level 2 not synchronized"},zW={};function Eg(x){return Go("warning: build with -sDEMANGLE_SUPPORT to link in libcxxabi demangling"),x}function ga(x){var D=/\b_Z[\w\d_]+/g;return x.replace(D,function(j){var lt=Eg(j);return j===lt?j:lt+" ["+j+"]"})}var ht={root:null,mounts:[],devices:{},streams:[],nextInode:1,nameTable:null,currentPath:"/",initialized:!1,ignorePermissions:!0,ErrnoError:null,genericErrors:{},filesystems:null,syncFSRequests:0,lookupPath:(x,D={})=>{if(x=vt.resolve(x),!x)return{path:"",node:null};var j={follow_mount:!0,recurse_count:0};if(D=Object.assign(j,D),D.recurse_count>8)throw new ht.ErrnoError(32);for(var lt=x.split("/").filter(Vn=>!!Vn),Zt=ht.root,yt="/",Yt=0;Yt40)throw new ht.ErrnoError(32)}}return{path:yt,node:Zt}},getPath:x=>{for(var D;;){if(ht.isRoot(x)){var j=x.mount.mountpoint;return D?j[j.length-1]!=="/"?`${j}/${D}`:j+D:j}D=D?`${x.name}/${D}`:x.name,x=x.parent}},hashName:(x,D)=>{for(var j=0,lt=0;lt>>0)%ht.nameTable.length},hashAddNode:x=>{var D=ht.hashName(x.parent.id,x.name);x.name_next=ht.nameTable[D],ht.nameTable[D]=x},hashRemoveNode:x=>{var D=ht.hashName(x.parent.id,x.name);if(ht.nameTable[D]===x)ht.nameTable[D]=x.name_next;else for(var j=ht.nameTable[D];j;){if(j.name_next===x){j.name_next=x.name_next;break}j=j.name_next}},lookupNode:(x,D)=>{var j=ht.mayLookup(x);if(j)throw new ht.ErrnoError(j,x);for(var lt=ht.hashName(x.id,D),Zt=ht.nameTable[lt];Zt;Zt=Zt.name_next){var yt=Zt.name;if(Zt.parent.id===x.id&&yt===D)return Zt}return ht.lookup(x,D)},createNode:(x,D,j,lt)=>{V(typeof x=="object");var Zt=new ht.FSNode(x,D,j,lt);return ht.hashAddNode(Zt),Zt},destroyNode:x=>{ht.hashRemoveNode(x)},isRoot:x=>x===x.parent,isMountpoint:x=>!!x.mounted,isFile:x=>(x&61440)===32768,isDir:x=>(x&61440)===16384,isLink:x=>(x&61440)===40960,isChrdev:x=>(x&61440)===8192,isBlkdev:x=>(x&61440)===24576,isFIFO:x=>(x&61440)===4096,isSocket:x=>(x&49152)===49152,flagsToPermissionString:x=>{var D=["r","w","rw"][x&3];return x&512&&(D+="w"),D},nodePermissions:(x,D)=>ht.ignorePermissions?0:D.includes("r")&&!(x.mode&292)||D.includes("w")&&!(x.mode&146)||D.includes("x")&&!(x.mode&73)?2:0,mayLookup:x=>{var D=ht.nodePermissions(x,"x");return D||(x.node_ops.lookup?0:2)},mayCreate:(x,D)=>{try{var j=ht.lookupNode(x,D);return 20}catch{}return ht.nodePermissions(x,"wx")},mayDelete:(x,D,j)=>{var lt;try{lt=ht.lookupNode(x,D)}catch(yt){return yt.errno}var Zt=ht.nodePermissions(x,"wx");if(Zt)return Zt;if(j){if(!ht.isDir(lt.mode))return 54;if(ht.isRoot(lt)||ht.getPath(lt)===ht.cwd())return 10}else if(ht.isDir(lt.mode))return 31;return 0},mayOpen:(x,D)=>x?ht.isLink(x.mode)?32:ht.isDir(x.mode)&&(ht.flagsToPermissionString(D)!=="r"||D&512)?31:ht.nodePermissions(x,ht.flagsToPermissionString(D)):44,MAX_OPEN_FDS:4096,nextfd:()=>{for(var x=0;x<=ht.MAX_OPEN_FDS;x++)if(!ht.streams[x])return x;throw new ht.ErrnoError(33)},getStreamChecked:x=>{var D=ht.getStream(x);if(!D)throw new ht.ErrnoError(8);return D},getStream:x=>ht.streams[x],createStream:(x,D=-1)=>(ht.FSStream||(ht.FSStream=function(){this.shared={}},ht.FSStream.prototype={},Object.defineProperties(ht.FSStream.prototype,{object:{get(){return this.node},set(j){this.node=j}},isRead:{get(){return(this.flags&2097155)!==1}},isWrite:{get(){return(this.flags&2097155)!==0}},isAppend:{get(){return this.flags&1024}},flags:{get(){return this.shared.flags},set(j){this.shared.flags=j}},position:{get(){return this.shared.position},set(j){this.shared.position=j}}})),x=Object.assign(new ht.FSStream,x),D==-1&&(D=ht.nextfd()),x.fd=D,ht.streams[D]=x,x),closeStream:x=>{ht.streams[x]=null},chrdev_stream_ops:{open:x=>{var D=ht.getDevice(x.node.rdev);x.stream_ops=D.stream_ops,x.stream_ops.open&&x.stream_ops.open(x)},llseek:()=>{throw new ht.ErrnoError(70)}},major:x=>x>>8,minor:x=>x&255,makedev:(x,D)=>x<<8|D,registerDevice:(x,D)=>{ht.devices[x]={stream_ops:D}},getDevice:x=>ht.devices[x],getMounts:x=>{for(var D=[],j=[x];j.length;){var lt=j.pop();D.push(lt),j.push.apply(j,lt.mounts)}return D},syncfs:(x,D)=>{typeof x=="function"&&(D=x,x=!1),ht.syncFSRequests++,ht.syncFSRequests>1&&g(`warning: ${ht.syncFSRequests} FS.syncfs operations in flight at once, probably just doing extra work`);var j=ht.getMounts(ht.root.mount),lt=0;function Zt(Yt){return V(ht.syncFSRequests>0),ht.syncFSRequests--,D(Yt)}function yt(Yt){if(Yt)return yt.errored?void 0:(yt.errored=!0,Zt(Yt));++lt>=j.length&&Zt(null)}j.forEach(Yt=>{if(!Yt.type.syncfs)return yt(null);Yt.type.syncfs(Yt,x,yt)})},mount:(x,D,j)=>{if(typeof x=="string")throw x;var lt=j==="/",Zt=!j,yt;if(lt&&ht.root)throw new ht.ErrnoError(10);if(!lt&&!Zt){var Yt=ht.lookupPath(j,{follow_mount:!1});if(j=Yt.path,yt=Yt.node,ht.isMountpoint(yt))throw new ht.ErrnoError(10);if(!ht.isDir(yt.mode))throw new ht.ErrnoError(54)}var Dt={type:x,opts:D,mountpoint:j,mounts:[]},pe=x.mount(Dt);return pe.mount=Dt,Dt.root=pe,lt?ht.root=pe:yt&&(yt.mounted=Dt,yt.mount&&yt.mount.mounts.push(Dt)),pe},unmount:x=>{var D=ht.lookupPath(x,{follow_mount:!1});if(!ht.isMountpoint(D.node))throw new ht.ErrnoError(28);var j=D.node,lt=j.mounted,Zt=ht.getMounts(lt);Object.keys(ht.nameTable).forEach(Yt=>{for(var Dt=ht.nameTable[Yt];Dt;){var pe=Dt.name_next;Zt.includes(Dt.mount)&&ht.destroyNode(Dt),Dt=pe}}),j.mounted=null;var yt=j.mount.mounts.indexOf(lt);V(yt!==-1),j.mount.mounts.splice(yt,1)},lookup:(x,D)=>x.node_ops.lookup(x,D),mknod:(x,D,j)=>{var lt=ht.lookupPath(x,{parent:!0}),Zt=lt.node,yt=Sa.basename(x);if(!yt||yt==="."||yt==="..")throw new ht.ErrnoError(28);var Yt=ht.mayCreate(Zt,yt);if(Yt)throw new ht.ErrnoError(Yt);if(!Zt.node_ops.mknod)throw new ht.ErrnoError(63);return Zt.node_ops.mknod(Zt,yt,D,j)},create:(x,D)=>(D=D!==void 0?D:438,D&=4095,D|=32768,ht.mknod(x,D,0)),mkdir:(x,D)=>(D=D!==void 0?D:511,D&=1023,D|=16384,ht.mknod(x,D,0)),mkdirTree:(x,D)=>{for(var j=x.split("/"),lt="",Zt=0;Zt(typeof j>"u"&&(j=D,D=438),D|=8192,ht.mknod(x,D,j)),symlink:(x,D)=>{if(!vt.resolve(x))throw new ht.ErrnoError(44);var j=ht.lookupPath(D,{parent:!0}),lt=j.node;if(!lt)throw new ht.ErrnoError(44);var Zt=Sa.basename(D),yt=ht.mayCreate(lt,Zt);if(yt)throw new ht.ErrnoError(yt);if(!lt.node_ops.symlink)throw new ht.ErrnoError(63);return lt.node_ops.symlink(lt,Zt,x)},rename:(x,D)=>{var j=Sa.dirname(x),lt=Sa.dirname(D),Zt=Sa.basename(x),yt=Sa.basename(D),Yt,Dt,pe;if(Yt=ht.lookupPath(x,{parent:!0}),Dt=Yt.node,Yt=ht.lookupPath(D,{parent:!0}),pe=Yt.node,!Dt||!pe)throw new ht.ErrnoError(44);if(Dt.mount!==pe.mount)throw new ht.ErrnoError(75);var Se=ht.lookupNode(Dt,Zt),en=vt.relative(x,lt);if(en.charAt(0)!==".")throw new ht.ErrnoError(28);if(en=vt.relative(D,j),en.charAt(0)!==".")throw new ht.ErrnoError(55);var Vn;try{Vn=ht.lookupNode(pe,yt)}catch{}if(Se!==Vn){var bn=ht.isDir(Se.mode),Rn=ht.mayDelete(Dt,Zt,bn);if(Rn)throw new ht.ErrnoError(Rn);if(Rn=Vn?ht.mayDelete(pe,yt,bn):ht.mayCreate(pe,yt),Rn)throw new ht.ErrnoError(Rn);if(!Dt.node_ops.rename)throw new ht.ErrnoError(63);if(ht.isMountpoint(Se)||Vn&&ht.isMountpoint(Vn))throw new ht.ErrnoError(10);if(pe!==Dt&&(Rn=ht.nodePermissions(Dt,"w"),Rn))throw new ht.ErrnoError(Rn);ht.hashRemoveNode(Se);try{Dt.node_ops.rename(Se,pe,yt)}catch(Xn){throw Xn}finally{ht.hashAddNode(Se)}}},rmdir:x=>{var D=ht.lookupPath(x,{parent:!0}),j=D.node,lt=Sa.basename(x),Zt=ht.lookupNode(j,lt),yt=ht.mayDelete(j,lt,!0);if(yt)throw new ht.ErrnoError(yt);if(!j.node_ops.rmdir)throw new ht.ErrnoError(63);if(ht.isMountpoint(Zt))throw new ht.ErrnoError(10);j.node_ops.rmdir(j,lt),ht.destroyNode(Zt)},readdir:x=>{var D=ht.lookupPath(x,{follow:!0}),j=D.node;if(!j.node_ops.readdir)throw new ht.ErrnoError(54);return j.node_ops.readdir(j)},unlink:x=>{var D=ht.lookupPath(x,{parent:!0}),j=D.node;if(!j)throw new ht.ErrnoError(44);var lt=Sa.basename(x),Zt=ht.lookupNode(j,lt),yt=ht.mayDelete(j,lt,!1);if(yt)throw new ht.ErrnoError(yt);if(!j.node_ops.unlink)throw new ht.ErrnoError(63);if(ht.isMountpoint(Zt))throw new ht.ErrnoError(10);j.node_ops.unlink(j,lt),ht.destroyNode(Zt)},readlink:x=>{var D=ht.lookupPath(x),j=D.node;if(!j)throw new ht.ErrnoError(44);if(!j.node_ops.readlink)throw new ht.ErrnoError(28);return vt.resolve(ht.getPath(j.parent),j.node_ops.readlink(j))},stat:(x,D)=>{var j=ht.lookupPath(x,{follow:!D}),lt=j.node;if(!lt)throw new ht.ErrnoError(44);if(!lt.node_ops.getattr)throw new ht.ErrnoError(63);return lt.node_ops.getattr(lt)},lstat:x=>ht.stat(x,!0),chmod:(x,D,j)=>{var lt;if(typeof x=="string"){var Zt=ht.lookupPath(x,{follow:!j});lt=Zt.node}else lt=x;if(!lt.node_ops.setattr)throw new ht.ErrnoError(63);lt.node_ops.setattr(lt,{mode:D&4095|lt.mode&-4096,timestamp:Date.now()})},lchmod:(x,D)=>{ht.chmod(x,D,!0)},fchmod:(x,D)=>{var j=ht.getStreamChecked(x);ht.chmod(j.node,D)},chown:(x,D,j,lt)=>{var Zt;if(typeof x=="string"){var yt=ht.lookupPath(x,{follow:!lt});Zt=yt.node}else Zt=x;if(!Zt.node_ops.setattr)throw new ht.ErrnoError(63);Zt.node_ops.setattr(Zt,{timestamp:Date.now()})},lchown:(x,D,j)=>{ht.chown(x,D,j,!0)},fchown:(x,D,j)=>{var lt=ht.getStreamChecked(x);ht.chown(lt.node,D,j)},truncate:(x,D)=>{if(D<0)throw new ht.ErrnoError(28);var j;if(typeof x=="string"){var lt=ht.lookupPath(x,{follow:!0});j=lt.node}else j=x;if(!j.node_ops.setattr)throw new ht.ErrnoError(63);if(ht.isDir(j.mode))throw new ht.ErrnoError(31);if(!ht.isFile(j.mode))throw new ht.ErrnoError(28);var Zt=ht.nodePermissions(j,"w");if(Zt)throw new ht.ErrnoError(Zt);j.node_ops.setattr(j,{size:D,timestamp:Date.now()})},ftruncate:(x,D)=>{var j=ht.getStreamChecked(x);if(!(j.flags&2097155))throw new ht.ErrnoError(28);ht.truncate(j.node,D)},utime:(x,D,j)=>{var lt=ht.lookupPath(x,{follow:!0}),Zt=lt.node;Zt.node_ops.setattr(Zt,{timestamp:Math.max(D,j)})},open:(x,D,j)=>{if(x==="")throw new ht.ErrnoError(44);D=typeof D=="string"?gg(D):D,j=typeof j>"u"?438:j,D&64?j=j&4095|32768:j=0;var lt;if(typeof x=="object")lt=x;else{x=Sa.normalize(x);try{var Zt=ht.lookupPath(x,{follow:!(D&131072)});lt=Zt.node}catch{}}var yt=!1;if(D&64)if(lt){if(D&128)throw new ht.ErrnoError(20)}else lt=ht.mknod(x,j,0),yt=!0;if(!lt)throw new ht.ErrnoError(44);if(ht.isChrdev(lt.mode)&&(D&=-513),D&65536&&!ht.isDir(lt.mode))throw new ht.ErrnoError(54);if(!yt){var Yt=ht.mayOpen(lt,D);if(Yt)throw new ht.ErrnoError(Yt)}D&512&&!yt&&ht.truncate(lt,0),D&=-131713;var Dt=ht.createStream({node:lt,path:ht.getPath(lt),flags:D,seekable:!0,position:0,stream_ops:lt.stream_ops,ungotten:[],error:!1});return Dt.stream_ops.open&&Dt.stream_ops.open(Dt),n.logReadFiles&&!(D&1)&&(ht.readFiles||(ht.readFiles={}),x in ht.readFiles||(ht.readFiles[x]=1)),Dt},close:x=>{if(ht.isClosed(x))throw new ht.ErrnoError(8);x.getdents&&(x.getdents=null);try{x.stream_ops.close&&x.stream_ops.close(x)}catch(D){throw D}finally{ht.closeStream(x.fd)}x.fd=null},isClosed:x=>x.fd===null,llseek:(x,D,j)=>{if(ht.isClosed(x))throw new ht.ErrnoError(8);if(!x.seekable||!x.stream_ops.llseek)throw new ht.ErrnoError(70);if(j!=0&&j!=1&&j!=2)throw new ht.ErrnoError(28);return x.position=x.stream_ops.llseek(x,D,j),x.ungotten=[],x.position},read:(x,D,j,lt,Zt)=>{if(V(j>=0),lt<0||Zt<0)throw new ht.ErrnoError(28);if(ht.isClosed(x))throw new ht.ErrnoError(8);if((x.flags&2097155)===1)throw new ht.ErrnoError(8);if(ht.isDir(x.node.mode))throw new ht.ErrnoError(31);if(!x.stream_ops.read)throw new ht.ErrnoError(28);var yt=typeof Zt<"u";if(!yt)Zt=x.position;else if(!x.seekable)throw new ht.ErrnoError(70);var Yt=x.stream_ops.read(x,D,j,lt,Zt);return yt||(x.position+=Yt),Yt},write:(x,D,j,lt,Zt,yt)=>{if(V(j>=0),lt<0||Zt<0)throw new ht.ErrnoError(28);if(ht.isClosed(x))throw new ht.ErrnoError(8);if(!(x.flags&2097155))throw new ht.ErrnoError(8);if(ht.isDir(x.node.mode))throw new ht.ErrnoError(31);if(!x.stream_ops.write)throw new ht.ErrnoError(28);x.seekable&&x.flags&1024&&ht.llseek(x,0,2);var Yt=typeof Zt<"u";if(!Yt)Zt=x.position;else if(!x.seekable)throw new ht.ErrnoError(70);var Dt=x.stream_ops.write(x,D,j,lt,Zt,yt);return Yt||(x.position+=Dt),Dt},allocate:(x,D,j)=>{if(ht.isClosed(x))throw new ht.ErrnoError(8);if(D<0||j<=0)throw new ht.ErrnoError(28);if(!(x.flags&2097155))throw new ht.ErrnoError(8);if(!ht.isFile(x.node.mode)&&!ht.isDir(x.node.mode))throw new ht.ErrnoError(43);if(!x.stream_ops.allocate)throw new ht.ErrnoError(138);x.stream_ops.allocate(x,D,j)},mmap:(x,D,j,lt,Zt)=>{if(lt&2&&!(Zt&2)&&(x.flags&2097155)!==2)throw new ht.ErrnoError(2);if((x.flags&2097155)===1)throw new ht.ErrnoError(2);if(!x.stream_ops.mmap)throw new ht.ErrnoError(43);return x.stream_ops.mmap(x,D,j,lt,Zt)},msync:(x,D,j,lt,Zt)=>(V(j>=0),x.stream_ops.msync?x.stream_ops.msync(x,D,j,lt,Zt):0),munmap:x=>0,ioctl:(x,D,j)=>{if(!x.stream_ops.ioctl)throw new ht.ErrnoError(59);return x.stream_ops.ioctl(x,D,j)},readFile:(x,D={})=>{if(D.flags=D.flags||0,D.encoding=D.encoding||"binary",D.encoding!=="utf8"&&D.encoding!=="binary")throw new Error(`Invalid encoding type "${D.encoding}"`);var j,lt=ht.open(x,D.flags),Zt=ht.stat(x),yt=Zt.size,Yt=new Uint8Array(yt);return ht.read(lt,Yt,0,yt,0),D.encoding==="utf8"?j=GV(Yt,0):D.encoding==="binary"&&(j=Yt),ht.close(lt),j},writeFile:(x,D,j={})=>{j.flags=j.flags||577;var lt=ht.open(x,j.flags,j.mode);if(typeof D=="string"){var Zt=new Uint8Array(Ta(D)+1),yt=_W(D,Zt,0,Zt.length);ht.write(lt,Zt,0,yt,void 0,j.canOwn)}else if(ArrayBuffer.isView(D))ht.write(lt,D,0,D.byteLength,void 0,j.canOwn);else throw new Error("Unsupported data type");ht.close(lt)},cwd:()=>ht.currentPath,chdir:x=>{var D=ht.lookupPath(x,{follow:!0});if(D.node===null)throw new ht.ErrnoError(44);if(!ht.isDir(D.node.mode))throw new ht.ErrnoError(54);var j=ht.nodePermissions(D.node,"x");if(j)throw new ht.ErrnoError(j);ht.currentPath=D.path},createDefaultDirectories:()=>{ht.mkdir("/tmp"),ht.mkdir("/home"),ht.mkdir("/home/web_user")},createDefaultDevices:()=>{ht.mkdir("/dev"),ht.registerDevice(ht.makedev(1,3),{read:()=>0,write:(lt,Zt,yt,Yt,Dt)=>Yt}),ht.mkdev("/dev/null",ht.makedev(1,3)),Ai.register(ht.makedev(5,0),Ai.default_tty_ops),Ai.register(ht.makedev(6,0),Ai.default_tty1_ops),ht.mkdev("/dev/tty",ht.makedev(5,0)),ht.mkdev("/dev/tty1",ht.makedev(6,0));var x=new Uint8Array(1024),D=0,j=()=>(D===0&&(D=Du(x).byteLength),x[--D]);ht.createDevice("/dev","random",j),ht.createDevice("/dev","urandom",j),ht.mkdir("/dev/shm"),ht.mkdir("/dev/shm/tmp")},createSpecialDirectories:()=>{ht.mkdir("/proc");var x=ht.mkdir("/proc/self");ht.mkdir("/proc/self/fd"),ht.mount({mount:()=>{var D=ht.createNode(x,"fd",16895,73);return D.node_ops={lookup:(j,lt)=>{var Zt=+lt,yt=ht.getStreamChecked(Zt),Yt={parent:null,mount:{mountpoint:"fake"},node_ops:{readlink:()=>yt.path}};return Yt.parent=Yt,Yt}},D}},{},"/proc/self/fd")},createStandardStreams:()=>{n.stdin?ht.createDevice("/dev","stdin",n.stdin):ht.symlink("/dev/tty","/dev/stdin"),n.stdout?ht.createDevice("/dev","stdout",null,n.stdout):ht.symlink("/dev/tty","/dev/stdout"),n.stderr?ht.createDevice("/dev","stderr",null,n.stderr):ht.symlink("/dev/tty1","/dev/stderr");var x=ht.open("/dev/stdin",0),D=ht.open("/dev/stdout",1),j=ht.open("/dev/stderr",1);V(x.fd===0,`invalid handle for stdin (${x.fd})`),V(D.fd===1,`invalid handle for stdout (${D.fd})`),V(j.fd===2,`invalid handle for stderr (${j.fd})`)},ensureErrnoError:()=>{ht.ErrnoError||(ht.ErrnoError=function(D,j){this.name="ErrnoError",this.node=j,this.setErrno=function(lt){this.errno=lt;for(var Zt in zW)if(zW[Zt]===lt){this.code=Zt;break}},this.setErrno(D),this.message=KW[D],this.stack&&(Object.defineProperty(this,"stack",{value:new Error().stack,writable:!0}),this.stack=ga(this.stack))},ht.ErrnoError.prototype=new Error,ht.ErrnoError.prototype.constructor=ht.ErrnoError,[44].forEach(x=>{ht.genericErrors[x]=new ht.ErrnoError(x),ht.genericErrors[x].stack=""}))},staticInit:()=>{ht.ensureErrnoError(),ht.nameTable=new Array(4096),ht.mount(ni,{},"/"),ht.createDefaultDirectories(),ht.createDefaultDevices(),ht.createSpecialDirectories(),ht.filesystems={MEMFS:ni}},init:(x,D,j)=>{V(!ht.init.initialized,"FS.init was previously called. If you want to initialize later with custom parameters, remove any earlier calls (note that one is automatically added to the generated code)"),ht.init.initialized=!0,ht.ensureErrnoError(),n.stdin=x||n.stdin,n.stdout=D||n.stdout,n.stderr=j||n.stderr,ht.createStandardStreams()},quit:()=>{ht.init.initialized=!1,UO(0);for(var x=0;x{var j=ht.analyzePath(x,D);return j.exists?j.object:null},analyzePath:(x,D)=>{try{var j=ht.lookupPath(x,{follow:!D});x=j.path}catch{}var lt={isRoot:!1,exists:!1,error:0,name:null,path:null,object:null,parentExists:!1,parentPath:null,parentObject:null};try{var j=ht.lookupPath(x,{parent:!0});lt.parentExists=!0,lt.parentPath=j.path,lt.parentObject=j.node,lt.name=Sa.basename(x),j=ht.lookupPath(x,{follow:!D}),lt.exists=!0,lt.path=j.path,lt.object=j.node,lt.name=j.node.name,lt.isRoot=j.path==="/"}catch(Zt){lt.error=Zt.errno}return lt},createPath:(x,D,j,lt)=>{x=typeof x=="string"?x:ht.getPath(x);for(var Zt=D.split("/").reverse();Zt.length;){var yt=Zt.pop();if(yt){var Yt=Sa.join2(x,yt);try{ht.mkdir(Yt)}catch{}x=Yt}}return Yt},createFile:(x,D,j,lt,Zt)=>{var yt=Sa.join2(typeof x=="string"?x:ht.getPath(x),D),Yt=QN(lt,Zt);return ht.create(yt,Yt)},createDataFile:(x,D,j,lt,Zt,yt)=>{var Yt=D;x&&(x=typeof x=="string"?x:ht.getPath(x),Yt=D?Sa.join2(x,D):x);var Dt=QN(lt,Zt),pe=ht.create(Yt,Dt);if(j){if(typeof j=="string"){for(var Se=new Array(j.length),en=0,Vn=j.length;en{var Zt=Sa.join2(typeof x=="string"?x:ht.getPath(x),D),yt=QN(!!j,!!lt);ht.createDevice.major||(ht.createDevice.major=64);var Yt=ht.makedev(ht.createDevice.major++,0);return ht.registerDevice(Yt,{open:Dt=>{Dt.seekable=!1},close:Dt=>{lt&<.buffer&<.buffer.length&<(10)},read:(Dt,pe,Se,en,Vn)=>{for(var bn=0,Rn=0;Rn{for(var bn=0;bn{if(x.isDevice||x.isFolder||x.link||x.contents)return!0;if(typeof XMLHttpRequest<"u")throw new Error("Lazy loading should have been performed (contents set) in createLazyFile, but it was not. Lazy loading only works in web workers. Use --embed-file or --preload-file in emcc on the main thread.");if(F)try{x.contents=me(F(x.url),!0),x.usedBytes=x.contents.length}catch{throw new ht.ErrnoError(29)}else throw new Error("Cannot load without read() or XMLHttpRequest.")},createLazyFile:(x,D,j,lt,Zt)=>{function yt(){this.lengthKnown=!1,this.chunks=[]}if(yt.prototype.get=function(Rn){if(!(Rn>this.length-1||Rn<0)){var Xn=Rn%this.chunkSize,vi=Rn/this.chunkSize|0;return this.getter(vi)[Xn]}},yt.prototype.setDataGetter=function(Rn){this.getter=Rn},yt.prototype.cacheLength=function(){var Rn=new XMLHttpRequest;if(Rn.open("HEAD",j,!1),Rn.send(null),!(Rn.status>=200&&Rn.status<300||Rn.status===304))throw new Error("Couldn't load "+j+". Status: "+Rn.status);var Xn=Number(Rn.getResponseHeader("Content-length")),vi,Ea=(vi=Rn.getResponseHeader("Accept-Ranges"))&&vi==="bytes",Oo=(vi=Rn.getResponseHeader("Content-Encoding"))&&vi==="gzip",Le=1024*1024;Ea||(Le=Xn);var kn=(Ya,Nd)=>{if(Ya>Nd)throw new Error("invalid range ("+Ya+", "+Nd+") or no bytes requested!");if(Nd>Xn-1)throw new Error("only "+Xn+" bytes available! programmer error!");var _s=new XMLHttpRequest;if(_s.open("GET",j,!1),Xn!==Le&&_s.setRequestHeader("Range","bytes="+Ya+"-"+Nd),_s.responseType="arraybuffer",_s.overrideMimeType&&_s.overrideMimeType("text/plain; charset=x-user-defined"),_s.send(null),!(_s.status>=200&&_s.status<300||_s.status===304))throw new Error("Couldn't load "+j+". Status: "+_s.status);return _s.response!==void 0?new Uint8Array(_s.response||[]):me(_s.responseText||"",!0)},fa=this;fa.setDataGetter(Ya=>{var Nd=Ya*Le,_s=(Ya+1)*Le-1;if(_s=Math.min(_s,Xn-1),typeof fa.chunks[Ya]>"u"&&(fa.chunks[Ya]=kn(Nd,_s)),typeof fa.chunks[Ya]>"u")throw new Error("doXHR failed!");return fa.chunks[Ya]}),(Oo||!Xn)&&(Le=Xn=1,Xn=this.getter(0).length,Le=Xn,T("LazyFiles on gzip forces download of the whole file when length is accessed")),this._length=Xn,this._chunkSize=Le,this.lengthKnown=!0},typeof XMLHttpRequest<"u"){if(!m)throw"Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";var Yt=new yt;Object.defineProperties(Yt,{length:{get:function(){return this.lengthKnown||this.cacheLength(),this._length}},chunkSize:{get:function(){return this.lengthKnown||this.cacheLength(),this._chunkSize}}});var Dt={isDevice:!1,contents:Yt}}else var Dt={isDevice:!1,url:j};var pe=ht.createFile(x,D,Dt,lt,Zt);Dt.contents?pe.contents=Dt.contents:Dt.url&&(pe.contents=null,pe.url=Dt.url),Object.defineProperties(pe,{usedBytes:{get:function(){return this.contents.length}}});var Se={},en=Object.keys(pe.stream_ops);en.forEach(bn=>{var Rn=pe.stream_ops[bn];Se[bn]=function(){return ht.forceLoadFile(pe),Rn.apply(null,arguments)}});function Vn(bn,Rn,Xn,vi,Ea){var Oo=bn.node.contents;if(Ea>=Oo.length)return 0;var Le=Math.min(Oo.length-Ea,vi);if(V(Le>=0),Oo.slice)for(var kn=0;kn(ht.forceLoadFile(pe),Vn(bn,Rn,Xn,vi,Ea)),Se.mmap=(bn,Rn,Xn,vi,Ea)=>{ht.forceLoadFile(pe);var Oo=ia(Rn);if(!Oo)throw new ht.ErrnoError(48);return Vn(bn,E,Oo,Rn,Xn),{ptr:Oo,allocated:!0}},pe.stream_ops=Se,pe},absolutePath:()=>{We("FS.absolutePath has been removed; use PATH_FS.resolve instead")},createFolder:()=>{We("FS.createFolder has been removed; use FS.mkdir instead")},createLink:()=>{We("FS.createLink has been removed; use FS.symlink instead")},joinPath:()=>{We("FS.joinPath has been removed; use PATH.join instead")},mmapAlloc:()=>{We("FS.mmapAlloc has been replaced by the top level function mmapAlloc")},standardizePath:()=>{We("FS.standardizePath has been removed; use PATH.normalize instead")}},Ou={DEFAULT_POLLMASK:5,calculateAt:function(x,D,j){if(Sa.isAbs(D))return D;var lt;if(x===-100)lt=ht.cwd();else{var Zt=Ou.getStreamFromFD(x);lt=Zt.path}if(D.length==0){if(!j)throw new ht.ErrnoError(44);return lt}return Sa.join2(lt,D)},doStat:function(x,D,j){try{var lt=x(D)}catch(Dt){if(Dt&&Dt.node&&Sa.normalize(D)!==Sa.normalize(ht.getPath(Dt.node)))return-54;throw Dt}_[j>>2]=lt.dev,_[j+4>>2]=lt.mode,P[j+8>>2]=lt.nlink,_[j+12>>2]=lt.uid,_[j+16>>2]=lt.gid,_[j+20>>2]=lt.rdev,ae=[lt.size>>>0,(qn=lt.size,+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[j+24>>2]=ae[0],_[j+28>>2]=ae[1],_[j+32>>2]=4096,_[j+36>>2]=lt.blocks;var Zt=lt.atime.getTime(),yt=lt.mtime.getTime(),Yt=lt.ctime.getTime();return ae=[Math.floor(Zt/1e3)>>>0,(qn=Math.floor(Zt/1e3),+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[j+40>>2]=ae[0],_[j+44>>2]=ae[1],P[j+48>>2]=Zt%1e3*1e3,ae=[Math.floor(yt/1e3)>>>0,(qn=Math.floor(yt/1e3),+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[j+56>>2]=ae[0],_[j+60>>2]=ae[1],P[j+64>>2]=yt%1e3*1e3,ae=[Math.floor(Yt/1e3)>>>0,(qn=Math.floor(Yt/1e3),+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[j+72>>2]=ae[0],_[j+76>>2]=ae[1],P[j+80>>2]=Yt%1e3*1e3,ae=[lt.ino>>>0,(qn=lt.ino,+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[j+88>>2]=ae[0],_[j+92>>2]=ae[1],0},doMsync:function(x,D,j,lt,Zt){if(!ht.isFile(D.node.mode))throw new ht.ErrnoError(43);if(lt&2)return 0;var yt=I.slice(x,x+j);ht.msync(D,yt,Zt,j,lt)},varargs:void 0,get(){V(Ou.varargs!=null),Ou.varargs+=4;var x=_[Ou.varargs-4>>2];return x},getStr(x){var D=OW(x);return D},getStreamFromFD:function(x){var D=ht.getStreamChecked(x);return D}},Cg=(x,D)=>{var j=0;return $U().forEach(function(lt,Zt){var yt=D+j;P[x+Zt*4>>2]=yt,v4(lt,yt),j+=lt.length+1}),0},j4=(x,D)=>{var j=$U();P[x>>2]=j.length;var lt=0;return j.forEach(function(Zt){lt+=Zt.length+1}),P[D>>2]=lt,0};function q4(x){try{var D=Ou.getStreamFromFD(x);return ht.close(D),0}catch(j){if(typeof ht>"u"||j.name!=="ErrnoError")throw j;return j.errno}}var $4=(x,D,j,lt)=>{for(var Zt=0,yt=0;yt>2],Dt=P[D+4>>2];D+=8;var pe=ht.read(x,E,Yt,Dt,lt);if(pe<0)return-1;if(Zt+=pe,pe>2]=yt,0}catch(Yt){if(typeof ht>"u"||Yt.name!=="ErrnoError")throw Yt;return Yt.errno}}function TV(x,D,j,lt,Zt){var yt=Ag(D,j);try{if(isNaN(yt))return 61;var Yt=Ou.getStreamFromFD(x);return ht.llseek(Yt,yt,lt),ae=[Yt.position>>>0,(qn=Yt.position,+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[Zt>>2]=ae[0],_[Zt+4>>2]=ae[1],Yt.getdents&&yt===0&<===0&&(Yt.getdents=null),0}catch(Dt){if(typeof ht>"u"||Dt.name!=="ErrnoError")throw Dt;return Dt.errno}}var Ng=(x,D,j,lt)=>{for(var Zt=0,yt=0;yt>2],Dt=P[D+4>>2];D+=8;var pe=ht.write(x,E,Yt,Dt,lt);if(pe<0)return-1;Zt+=pe,typeof lt<"u"&&(lt+=pe)}return Zt};function fO(x,D,j,lt){try{var Zt=Ou.getStreamFromFD(x),yt=Ng(Zt,D,j);return P[lt>>2]=yt,0}catch(Yt){if(typeof ht>"u"||Yt.name!=="ErrnoError")throw Yt;return Yt.errno}}var yg=(x,D)=>{for(var j=0,lt=0;lt<=D;j+=x[lt++]);return j},kN=[31,29,31,30,31,30,31,31,30,31,30,31],YN=[31,28,31,30,31,30,31,31,30,31,30,31],Bg=(x,D)=>{for(var j=new Date(x.getTime());D>0;){var lt=wW(j.getFullYear()),Zt=j.getMonth(),yt=(lt?kN:YN)[Zt];if(D>yt-j.getDate())D-=yt-j.getDate()+1,j.setDate(1),Zt<11?j.setMonth(Zt+1):(j.setMonth(0),j.setFullYear(j.getFullYear()+1));else return j.setDate(j.getDate()+D),j}return j},xN=(x,D)=>{V(x.length>=0,"writeArrayToMemory array must have a length (should be an array or typed array)"),E.set(x,D)},tG=(x,D,j,lt)=>{var Zt=_[lt+40>>2],yt={tm_sec:_[lt>>2],tm_min:_[lt+4>>2],tm_hour:_[lt+8>>2],tm_mday:_[lt+12>>2],tm_mon:_[lt+16>>2],tm_year:_[lt+20>>2],tm_wday:_[lt+24>>2],tm_yday:_[lt+28>>2],tm_isdst:_[lt+32>>2],tm_gmtoff:_[lt+36>>2],tm_zone:Zt?OW(Zt):""},Yt=OW(j),Dt={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var pe in Dt)Yt=Yt.replace(new RegExp(pe,"g"),Dt[pe]);var Se=["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],en=["January","February","March","April","May","June","July","August","September","October","November","December"];function Vn(Le,kn,fa){for(var Ya=typeof Le=="number"?Le.toString():Le||"";Ya.length0?1:0}var Ya;return(Ya=fa(Le.getFullYear()-kn.getFullYear()))===0&&(Ya=fa(Le.getMonth()-kn.getMonth()))===0&&(Ya=fa(Le.getDate()-kn.getDate())),Ya}function Xn(Le){switch(Le.getDay()){case 0:return new Date(Le.getFullYear()-1,11,29);case 1:return Le;case 2:return new Date(Le.getFullYear(),0,3);case 3:return new Date(Le.getFullYear(),0,2);case 4:return new Date(Le.getFullYear(),0,1);case 5:return new Date(Le.getFullYear()-1,11,31);case 6:return new Date(Le.getFullYear()-1,11,30)}}function vi(Le){var kn=Bg(new Date(Le.tm_year+1900,0,1),Le.tm_yday),fa=new Date(kn.getFullYear(),0,4),Ya=new Date(kn.getFullYear()+1,0,4),Nd=Xn(fa),_s=Xn(Ya);return Rn(Nd,kn)<=0?Rn(_s,kn)<=0?kn.getFullYear()+1:kn.getFullYear():kn.getFullYear()-1}var Ea={"%a":Le=>Se[Le.tm_wday].substring(0,3),"%A":Le=>Se[Le.tm_wday],"%b":Le=>en[Le.tm_mon].substring(0,3),"%B":Le=>en[Le.tm_mon],"%C":Le=>{var kn=Le.tm_year+1900;return bn(kn/100|0,2)},"%d":Le=>bn(Le.tm_mday,2),"%e":Le=>Vn(Le.tm_mday,2," "),"%g":Le=>vi(Le).toString().substring(2),"%G":Le=>vi(Le),"%H":Le=>bn(Le.tm_hour,2),"%I":Le=>{var kn=Le.tm_hour;return kn==0?kn=12:kn>12&&(kn-=12),bn(kn,2)},"%j":Le=>bn(Le.tm_mday+yg(wW(Le.tm_year+1900)?kN:YN,Le.tm_mon-1),3),"%m":Le=>bn(Le.tm_mon+1,2),"%M":Le=>bn(Le.tm_min,2),"%n":()=>` -`,"%p":Le=>Le.tm_hour>=0&&Le.tm_hour<12?"AM":"PM","%S":Le=>bn(Le.tm_sec,2),"%t":()=>" ","%u":Le=>Le.tm_wday||7,"%U":Le=>{var kn=Le.tm_yday+7-Le.tm_wday;return bn(Math.floor(kn/7),2)},"%V":Le=>{var kn=Math.floor((Le.tm_yday+7-(Le.tm_wday+6)%7)/7);if((Le.tm_wday+371-Le.tm_yday-2)%7<=2&&kn++,kn){if(kn==53){var Ya=(Le.tm_wday+371-Le.tm_yday)%7;Ya!=4&&(Ya!=3||!wW(Le.tm_year))&&(kn=1)}}else{kn=52;var fa=(Le.tm_wday+7-Le.tm_yday-1)%7;(fa==4||fa==5&&wW(Le.tm_year%400-1))&&kn++}return bn(kn,2)},"%w":Le=>Le.tm_wday,"%W":Le=>{var kn=Le.tm_yday+7-(Le.tm_wday+6)%7;return bn(Math.floor(kn/7),2)},"%y":Le=>(Le.tm_year+1900).toString().substring(2),"%Y":Le=>Le.tm_year+1900,"%z":Le=>{var kn=Le.tm_gmtoff,fa=kn>=0;return kn=Math.abs(kn)/60,kn=kn/60*100+kn%60,(fa?"+":"-")+("0000"+kn).slice(-4)},"%Z":Le=>Le.tm_zone,"%%":()=>"%"};Yt=Yt.replace(/%%/g,"\0\0");for(var pe in Ea)Yt.includes(pe)&&(Yt=Yt.replace(new RegExp(pe,"g"),Ea[pe](yt)));Yt=Yt.replace(/\0\0/g,"%");var Oo=me(Yt,!1);return Oo.length>D?0:(xN(Oo,x),Oo.length-1)},sR=(x,D,j,lt,Zt)=>tG(x,D,j,lt);function Qg(x){var D=n["_"+x];return V(D,"Cannot call unknown function "+x+", make sure it is exported"),D}var t8=x=>{var D=Ta(x)+1,j=AO(D);return DW(x,j,D),j},FO=function(x,D,j,lt,Zt){var yt={string:Xn=>{var vi=0;return Xn!=null&&Xn!==0&&(vi=t8(Xn)),vi},array:Xn=>{var vi=AO(Xn.length);return xN(Xn,vi),vi}};function Yt(Xn){return D==="string"?OW(Xn):D==="boolean"?!!Xn:Xn}var Dt=Qg(x),pe=[],Se=0;if(V(D!=="array",'Return type should not be "array".'),lt)for(var en=0;en(rR=Q.emscripten_stack_init)(),nG=()=>(nG=Q.emscripten_stack_get_free)(),iG=()=>(iG=Q.emscripten_stack_get_base)(),qW=()=>(qW=Q.emscripten_stack_get_end)(),$W=Je("stackSave"),o8=Je("stackRestore"),AO=Je("stackAlloc"),a8=()=>(a8=Q.emscripten_stack_get_current)(),rdt=Je("__cxa_increment_exception_refcount"),s8=Je("__cxa_is_pointer_type"),LN=n.dynCall_jiji=Je("dynCall_jiji"),Yg=n.dynCall_viijii=Je("dynCall_viijii"),l8=n.dynCall_iiiiij=Je("dynCall_iiiiij"),bt=n.dynCall_iiiiijj=Je("dynCall_iiiiijj"),oG=n.dynCall_iiiiiijj=Je("dynCall_iiiiiijj");function xg(x){try{for(var D=atob(x),j=new Uint8Array(D.length),lt=0;lt0||(d8(),Wt(),oe>0))return;function x(){Xg||(Xg=!0,n.calledRun=!0,!J&&(Nt(),i(n),n.onRuntimeInitialized&&n.onRuntimeInitialized(),V(!n._main,'compiled without a main, but one is present. if you added it from JS, use Module["onRuntimeInitialized"]'),kt()))}n.setStatus?(n.setStatus("Running..."),setTimeout(function(){setTimeout(function(){n.setStatus("")},1),x()},1)):x(),dt()}if(n.preInit)for(typeof n.preInit=="function"&&(n.preInit=[n.preInit]);n.preInit.length>0;)n.preInit.pop()();return SV(),e.ready}})(),lv=r0e;globalThis.Buffer=globalThis.Buffer||{};var cTt=(lv.hasOwnProperty("then")?lv:Promise.resolve(lv())).then(t=>{let e={find_nearby_indices:{rval:"boolean",params:["number","number"]},getCoveragePositions:{rval:null,params:["number","number","number","number","number"]},inflateEllipsoid:{rval:null,params:["number"]}},n={wasm:t};return Object.keys(e).forEach(i=>{n[i]=e[i].params?t.cwrap(i,e[i].rval,e[i].params):t.cwrap(i,e[i].rval)}),n});var{FinalizationRegistry:c0e}=globalThis,K0={_previousLoad:!1,_instance:void 0,_wasmModule:void 0,_positionPointer:-1,_precisionMode:75,async initInstance(){let t="default";if(!this._previousLoad)try{this._wasmModule=(await cTt).wasm,this._previousLoad=!0}catch(e){throw new Ut(`Failed to load the WASM module: ${e.message}`)}if(!this._instance){let{PositionRegistry:e}=this._wasmModule;this._instance=new e(t)}return{instance:this._instance,wasmModule:this._wasmModule}},get instance(){return this._instance},get wasmModule(){return this._wasmModule},get positionPointer(){return this._positionPointer},update(t){if(!this._instance)return 0;let e=Math.round(t/this._precisionMode)*this._precisionMode;return this._lastUpdate!==e&&(this._lastUpdate=e,this._positionPointer=this._instance.update(e)),this._positionPointer||0},updateJulianDate(t){if(!this._instance)return 0;if(!(t instanceof rt))throw new TypeError("Expected julianDate to be an instance of JulianDate");let e=rt.toDate(t).getTime();return this.update(e)},get precisionMode(){return this._precisionMode},set precisionMode(t){if(typeof t!="number"||t<=0)throw new TypeError("Precision mode must be a positive number.");this._precisionMode=t}},mTt={},JIi=new c0e(t=>{let e=mTt[t];e&&(K0._wasmModule.wasm.removePosition(e),delete mTt[t],console.log(`Entity with ID ${t} has been garbage collected, pointer ${e}`))});var hTt=v.WHITE,pTt=v.BLACK,uTt=0,ZTt=1,VTt=0,bTt=new v,m0e=new p,RTt=new v,WTt=new ln,fTt=new ln,FTt=new Wn,UTt=null,qet=null;function GTt(t){this.entity=t,this.pointPrimitive=void 0,this.billboard=void 0,this.color=void 0,this.outlineColor=void 0,this.pixelSize=void 0,this.outlineWidth=void 0}function z0(t,e){e.collectionChanged.addEventListener(z0.prototype._onCollectionChanged,this),this._cluster=t,this._cluster._isReallyDirty=!0,this._entityCollection=e,this._items=new qe,this._wasmItems=[],this._dynamicItems=[],this._onCollectionChanged(e,e.values,[],[]),this._fps=[!1,!1],this._fpsLastUpdate=[Oi(),Oi()]}z0.prototype.needsUpdate=function(t){let e=this._fps[t];if(e){let n=Oi(),i=(n-this._fpsLastUpdate[t])*xi.SECONDS_PER_MILLISECOND>=1/e;return i&&(this._fpsLastUpdate[t]=n),i}return!0};z0.prototype.update=function(t){if(!this.needsUpdate(this._entityCollection?.ThrottleType?.MAX))return!0;let e=this._items.values,n=this._cluster,{wasmModule:i,instance:o,updateJulianDate:a}=K0,s=this._entityCollection.owner?this._entityCollection.owner._wasmModule:null;s&&(s._wasmSatelliteCatalog=this._entityCollection.owner._wasmSatelliteCatalog);let l=this._wasmItems,r=this._dynamicItems;if(!e.length&&!l.length)return!0;if(s&&l.length&&!n._isReallyDirty&&n&&n._pointCollection&&n._pointCollection._pointPrimitives){let m=K0.updateJulianDate(t);m!==qet&&(qet=m,UTt=new Float64Array(s.HEAP8.buffer,qet,l.length*3));let h=new p;for(let Z=0,b=l.length;Z-1&&(p.fromArray(UTt,l[Z].array_index*3,h),l[Z].pointPrimitive&&(l[Z].pointPrimitive.position=h),l[Z].billboard&&(l[Z].billboard.position=h))}let d=this.needsUpdate(this._entityCollection?.ThrottleType?.DYNAMIC)&&r.length;if(!l.length||d||n._isReallyDirty){let m=!n._isReallyDirty&&d?r:e;for(let h=0,Z=m.length;h-1&&(b.array_index=u.array_index);let F=u._point,U=b.pointPrimitive,G=b.billboard,A=et.getValueOrDefault(F._heightReference,t,Ge.NONE),T=u.isShowing&&u.isAvailable(t)&&et.getValueOrDefault(F._show,t,!0);U&&(U.show=T);let g=U&&u.array_index?U.position:void 0;if(T&&!g&&(g=et.getValueOrUndefined(u._position,t,m0e),T=c(g)),!T){ZL(b,u,n);continue}et.isConstant(u._position)||(n._clusterDirty=!0);let C=!1,y=!1;if(A!==Ge.NONE&&!c(G)?(c(U)&&(ZL(b,u,n),U=void 0),G=n.getBillboard(u),G.id=u,G.image=void 0,b.billboard=G,C=!0,y=p.equals(G.position,g)&&G.heightReference===A):A===Ge.NONE&&!c(U)&&(c(G)&&(ZL(b,u,n),G=void 0),U=n.getPoint(u),U.id=u,b.pointPrimitive=U),c(U))U.show=!0,U.position=g,U.scaleByDistance=et.getValueOrUndefined(F._scaleByDistance,t,WTt),U.translucencyByDistance=et.getValueOrUndefined(F._translucencyByDistance,t,fTt),U.color=et.getValueOrDefault(F._color,t,hTt,bTt),U.outlineColor=et.getValueOrDefault(F._outlineColor,t,pTt,RTt),U.outlineWidth=et.getValueOrDefault(F._outlineWidth,t,uTt),U.pixelSize=et.getValueOrDefault(F._pixelSize,t,ZTt),U.distanceDisplayCondition=et.getValueOrUndefined(F._distanceDisplayCondition,t,FTt),U.disableDepthTestDistance=et.getValueOrDefault(F._disableDepthTestDistance,t,VTt);else if(c(G)){G.show=!0,G.position=g,G.scaleByDistance=et.getValueOrUndefined(F._scaleByDistance,t,WTt),G.translucencyByDistance=et.getValueOrUndefined(F._translucencyByDistance,t,fTt),G.distanceDisplayCondition=et.getValueOrUndefined(F._distanceDisplayCondition,t,FTt),G.disableDepthTestDistance=et.getValueOrDefault(F._disableDepthTestDistance,t,VTt),G.heightReference=A;let Y=et.getValueOrDefault(F._color,t,hTt,bTt),Q=et.getValueOrDefault(F._outlineColor,t,pTt,RTt),J=Math.round(et.getValueOrDefault(F._outlineWidth,t,uTt)),M=Math.max(1,Math.round(et.getValueOrDefault(F._pixelSize,t,ZTt)));if(J>0?(G.scale=1,C=C||J!==b.outlineWidth||M!==b.pixelSize||!v.equals(Y,b.color)||!v.equals(Q,b.outlineColor)):(G.scale=M/50,M=50,C=C||J!==b.outlineWidth||!v.equals(Y,b.color)||!v.equals(Q,b.outlineColor)),C){b.color=v.clone(Y,b.color),b.outlineColor=v.clone(Q,b.outlineColor),b.pixelSize=M,b.outlineWidth=J;let V=Y.alpha,E=Y.toCssColorString(),I=Q.toCssColorString(),B=JSON.stringify([E,M,I,J]);G.setImage(B,XA(V,E,I,J,M))}y&&G._updateClamping()}}this._cluster._isReallyDirty=!1}return!0};z0.prototype.getBoundingSphere=function(t,e){let n=this._items.get(t.id);if(!c(n)||!(c(n.pointPrimitive)||c(n.billboard)))return ve.FAILED;if(c(n.pointPrimitive))e.center=p.clone(n.pointPrimitive.position,e.center);else{let i=n.billboard;if(!c(i._clampedPosition))return ve.PENDING;e.center=p.clone(i._clampedPosition,e.center)}return e.radius=0,ve.DONE};z0.prototype.isDestroyed=function(){return!1};z0.prototype.destroy=function(){this._entityCollection.collectionChanged.removeEventListener(z0.prototype._onCollectionChanged,this);let t=this._entityCollection.values;for(let e=0;e{let F=s.get(u.id);if(F&&r.indexOf(F)===-1)if(!u._position.isConstant&&l.indexOf(F)===-1)r.push(F);else for(let U in u._point)u._point[U]?.isConstant===!1&&r.push(F)},h=u=>{r=r.filter(F=>F.entity.id!==u.id)},Z=u=>{let F=s.get(u.id);F&&u.wasmSchema&&l.indexOf(F)===-1&&l.push(F),m(u)},b=u=>{l=l.filter(F=>F.entity.id!==u.id),h(u)};for(o=e.length-1;o>-1;o--)a=e[o],c(a._point)&&c(a._position)&&(s.set(a.id,new GTt(a)),Z(a));for(o=i.length-1;o>-1;o--)a=i[o],Z(a),c(a._point)&&c(a._position)?s.contains(a.id)||s.set(a.id,new GTt(a)):(ZL(s.get(a.id),a,d),s.remove(a.id),b(a));for(o=n.length-1;o>-1;o--)a=n[o],ZL(s.get(a.id),a,d),s.remove(a.id),b(a);this._cluster._isReallyDirty=!0};function ZL(t,e,n){if(c(t)){let i=t.pointPrimitive;if(c(i)){t.pointPrimitive=void 0,n.removePoint(e);return}let o=t.billboard;c(o)&&(t.billboard=void 0,n.removeBillboard(e))}}var VL=z0;var kNi=R(W(),1);var tNi=R(W(),1);var G1i=R(W(),1);var ETt=[];function h0e(t,e,n,i,o){let a=ETt;a.length=o;let s,l=n.red,r=n.green,d=n.blue,m=n.alpha,h=i.red,Z=i.green,b=i.blue,u=i.alpha;if(v.equals(n,i)){for(s=0;s0?new Array(o):void 0;for(i=0;i0){let X=0,_=h[0];i=i.filter(function(P,w){let z=!1;return o?z=w===_||w===0&&_===1:z=w+1===_,z?(X++,_=h[X],!1):!0})}let b=Z.length;if(b<2||e<=0)return;if(a===Ln.GEODESIC||a===Ln.RHUMB){let X,_;a===Ln.GEODESIC?(X=k.chordLength(s,l.maximumRadius),_=xo.numberOfPoints):(X=s,_=xo.numberOfPointsRhumbLine);let P=xo.extractHeights(Z,l);if(c(i)){let w=1;for(r=0;r0)return Ft.fromPoints(e.positions,t),ve.DONE}return ve.FAILED};RL.prototype.isDestroyed=function(){return!1};RL.prototype.destroy=function(){let e=this._geometryUpdater._scene.id+this._primitives._guid,n=rv[e];c(n)&&(n.remove(this._line),n.length===0&&(this._primitives.removeAndDestroy(n),delete rv[e])),c(this._groundPolylinePrimitive)&&this._groundPrimitives.remove(this._groundPolylinePrimitive),At(this)};var WL=DZ;var bNi=R(W(),1);var F0e=new v,U0e=new Wn,G0e=new Wn;function OZ(t,e,n,i,o){let a;n instanceof Cn?a=Ul:a=zl,this.orderedGroundPrimitives=t,this.classificationType=e,this.appearanceType=a,this.materialProperty=n,this.updaters=new qe,this.createPrimitive=!0,this.primitive=void 0,this.oldPrimitive=void 0,this.geometry=new qe,this.material=void 0,this.updatersWithAttributes=new qe,this.attributes=new qe,this.invalidated=!1,this.removeMaterialSubscription=n.definitionChanged.addEventListener(OZ.prototype.onMaterialChanged,this),this.subscriptions=new qe,this.showsUpdated=new qe,this.zIndex=i,this._asynchronous=o}OZ.prototype.onMaterialChanged=function(){this.invalidated=!0};OZ.prototype.isMaterial=function(t){let e=this.materialProperty,n=t.fillMaterialProperty;return n===e||n instanceof Cn&&e instanceof Cn?!0:c(e)&&e.equals(n)};OZ.prototype.add=function(t,e,n){let i=e.id;if(this.updaters.set(i,e),this.geometry.set(i,n),!e.hasConstantFill||!e.fillMaterialProperty.isConstant||!et.isConstant(e.distanceDisplayConditionProperty))this.updatersWithAttributes.set(i,e);else{let o=this;this.subscriptions.set(i,e.entity.definitionChanged.addEventListener(function(a,s,l,r){s==="isShowing"&&o.showsUpdated.set(e.id,e)}))}this.createPrimitive=!0};OZ.prototype.remove=function(t){let e=t.id;if(this.createPrimitive=this.geometry.remove(e)||this.createPrimitive,this.updaters.remove(e)){this.updatersWithAttributes.remove(e);let n=this.subscriptions.get(e);return c(n)&&(n(),this.subscriptions.remove(e)),!0}return!1};OZ.prototype.update=function(t){let e=!0,n=this.primitive,i=this.orderedGroundPrimitives,o=this.geometry.values,a;if(this.createPrimitive){if(o.length>0)c(n)&&(c(this.oldPrimitive)?i.remove(n):this.oldPrimitive=n),n=new Gh({show:!1,asynchronous:this._asynchronous,geometryInstances:o.slice(),appearance:new this.appearanceType,classificationType:this.classificationType}),this.appearanceType===zl&&(this.material=Ua.getValue(t,this.materialProperty,this.material),n.appearance.material=this.material),i.add(n,this.zIndex),e=!1;else{c(n)&&(i.remove(n),n=void 0);let l=this.oldPrimitive;c(l)&&(i.remove(l),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=n,this.createPrimitive=!1}else if(c(n)&&n.ready){n.show=!0,c(this.oldPrimitive)&&(i.remove(this.oldPrimitive),this.oldPrimitive=void 0),this.appearanceType===zl&&(this.material=Ua.getValue(t,this.materialProperty,this.material),this.primitive.appearance.material=this.material);let s=this.updatersWithAttributes.values,l=s.length;for(a=0;a=0;i--){let o=e[i];if(o.remove(t)){o.updaters.length===0&&(e.splice(i,1),o.destroy());break}}};EI.prototype.update=function(t){let e,n=this._items,i=n.length;for(e=i-1;e>=0;e--){let a=n[e];if(a.invalidated){n.splice(e,1);let s=a.updaters.values,l=s.length;for(let r=0;r-1;l--)r=s[l],d=r.id,m=this._updaters.get(d),m.entity===r?(BTt(this,m),QTt(this,t,m)):(o.push(r),n.push(r));for(l=o.length-1;l>-1;l--)r=o[l],d=r.id,m=this._updaters.get(d),BTt(this,m),m.destroy(),this._updaters.remove(d),this._subscriptions.get(d)(),this._subscriptions.remove(d);for(l=n.length-1;l>-1;l--)r=n[l],d=r.id,m=new WL(r,this._scene),this._updaters.set(d,m),QTt(this,t,m),this._subscriptions.set(d,m.geometryChanged.addEventListener(Rb._onGeometryChanged,this));e.removeAll(),i.removeAll(),a.removeAll();let h=!0,Z=this._batches,b=Z.length;for(l=0;l-1;s--)r=n[s],l=r.id,i.remove(l)||(o.set(l,r),a.remove(l));for(s=e.length-1;s>-1;s--)r=e[s],l=r.id,o.remove(l)?a.set(l,r):i.set(l,r)};var FL=Rb;function wm(t){Nc.initializeTerrainHeights(),Gh.initializeTerrainHeights();let e=t.scene,n=t.dataSourceCollection;this._eventHelper=new rl,this._eventHelper.add(n.dataSourceAdded,this._onDataSourceAdded,this),this._eventHelper.add(n.dataSourceRemoved,this._onDataSourceRemoved,this),this._eventHelper.add(n.dataSourceMoved,this._onDataSourceMoved,this),this._eventHelper.add(e.postRender,this._postRender,this),this._dataSourceCollection=n,this._scene=e,this._visualizersCallback=f(t.visualizersCallback,wm.defaultVisualizersCallback);let i=!1,o=new Dm,a=new Dm;n.length>0&&(e.primitives.add(o),e.groundPrimitives.add(a),i=!0),this._primitives=o,this._groundPrimitives=a;for(let d=0,m=n.length;dnew o(t,i))]};Object.defineProperties(wm.prototype,{scene:{get:function(){return this._scene}},dataSources:{get:function(){return this._dataSourceCollection}},defaultDataSource:{get:function(){return this._defaultDataSource}},ready:{get:function(){return this._ready}}});wm.prototype.isDestroyed=function(){return!1};wm.prototype.destroy=function(){this._eventHelper.removeAll();let t=this._dataSourceCollection;for(let e=0,n=t.length;eI0e*s.maximumRadius?(h=XTt,p.normalize(r,h),p.negate(h,h),b=p.clone(p.UNIT_Z,tnt),Z=p.cross(b,h,dv),p.magnitude(Z)>k.EPSILON7&&(p.normalize(h,h),p.normalize(Z,Z),b=p.cross(h,Z,tnt),p.normalize(b,b),d=!0)):p.equalsEpsilon(r,g,k.EPSILON7)||(b=XTt,p.normalize(Q,b),p.normalize(J,J),Z=p.cross(b,J,tnt),m&&(Z=p.multiplyByScalar(Z,-1,Z)),p.equalsEpsilon(Z,p.ZERO,k.EPSILON7)||(h=p.cross(Z,b,dv),ot.multiplyByVector(Y,h,h),ot.multiplyByVector(Y,Z,Z),ot.multiplyByVector(Y,b,b),p.normalize(h,h),p.normalize(Z,Z),p.normalize(b,b),d=!0))}}c(t.boundingSphere)&&(r=t.boundingSphere.center);let U,G,A;i&&(U=p.clone(e.position,ent),G=p.clone(e.direction,JTt),A=p.clone(e.up,LTt));let T=C0e;d?(T[0]=h.x,T[1]=h.y,T[2]=h.z,T[3]=0,T[4]=Z.x,T[5]=Z.y,T[6]=Z.z,T[7]=0,T[8]=b.x,T[9]=b.y,T[10]=b.z,T[11]=0,T[12]=r.x,T[13]=r.y,T[14]=r.z,T[15]=0):Pe.eastNorthUpToFixedFrame(r,s,T),e._setTransform(T),i&&(p.clone(U,e.position),p.clone(G,e.direction),p.clone(A,e.up),p.cross(G,A,e.right))}if(n){let d=l===ut.SCENE2D||p.equals(t._offset3D,p.ZERO)?void 0:t._offset3D;e.lookAtTransform(e.transform,d)}}function GL(t,e,n){this.entity=t,this.scene=e,this.ellipsoid=f(n,mt.WGS84),this.boundingSphere=void 0,this._lastEntity=void 0,this._mode=void 0,this._lastCartesian=new p,this._defaultOffset3D=void 0,this._offset3D=new p}Object.defineProperties(GL,{defaultOffset3D:{get:function(){return this._defaultOffset3D},set:function(t){this._defaultOffset3D=p.clone(t,new p)}}});GL.defaultOffset3D=new p(-14e3,3500,3500);var UL=new Zu,y0e=new p;GL.prototype.update=function(t,e){let n=this.scene,i=this.ellipsoid,o=n.mode;if(o===ut.MORPHING)return;let a=this.entity,s=a.position;if(!c(s))return;let l=a!==this._lastEntity,r=o!==this._mode,d=n.camera,m=l||r,h=!0;if(l){let Z=a.viewFrom,b=c(Z);if(!b&&c(e)){UL.pitch=-k.PI_OVER_FOUR,UL.range=0;let u=s.getValue(t,y0e);if(c(u)){let F=2-1/Math.max(1,p.magnitude(u)/i.maximumRadius);UL.pitch*=F,UL.range=p.magnitude(u)*.05}d.viewBoundingSphere(e,UL),this.boundingSphere=e,m=!1,h=!1}else(!b||!c(Z.getValue(t,this._offset3D)))&&p.clone(GL._defaultOffset3D,this._offset3D)}else!r&&this._mode!==ut.SCENE2D&&p.clone(d.position,this._offset3D);this._lastEntity=a,this._mode=o,N0e(this,d,m,h,s,t,i)};var AL=GL;var qBi=R(W(),1);var gyi=R(W(),1);function SL(){this._cache={}}SL.prototype.fromColor=function(t,e){return cv(void 0,void 0,t,e,this._cache)};SL.prototype.fromUrl=function(t,e,n){return cv(t,void 0,e,n,this._cache)};SL.prototype.fromMakiIconId=function(t,e,n){return cv(Dn(`Assets/Textures/maki/${encodeURIComponent(t)}.png`),void 0,e,n,this._cache)};SL.prototype.fromText=function(t,e,n){return cv(void 0,t,e,n,this._cache)};var B0e=new v;function Q0e(t,e,n){t.save(),t.scale(n/24,n/24),t.fillStyle=e.toCssColorString(),t.strokeStyle=e.brighten(.6,B0e).toCssColorString(),t.lineWidth=.846,t.beginPath(),t.moveTo(6.72,.422),t.lineTo(17.28,.422),t.bezierCurveTo(18.553,.422,19.577,1.758,19.577,3.415),t.lineTo(19.577,10.973),t.bezierCurveTo(19.577,12.63,18.553,13.966,17.282,13.966),t.lineTo(14.386,14.008),t.lineTo(11.826,23.578),t.lineTo(9.614,14.008),t.lineTo(6.719,13.965),t.bezierCurveTo(5.446,13.983,4.422,12.629,4.422,10.972),t.lineTo(4.422,3.416),t.bezierCurveTo(4.423,1.76,5.447,.423,6.718,.423),t.closePath(),t.fill(),t.stroke(),t.restore()}function MTt(t,e,n){let i=n/2.5,o=i,a=i;e.width>e.height?a=i*(e.height/e.width):e.width${i}${wTt(o)}`:n+=`${i}${o}`)}return n.length>0&&(n=`${n}
`),n}function M0e(t,e,n){let i;return function(o,a){return c(i)||(i=t(e,n)),i}}function _0e(t,e){return new Th(M0e(wTt,t,e),!0)}function pv(t,e,n){let i=t.id;if(!c(i)||t.type!=="Feature")i=Si();else{let s=2,l=i;for(;c(e.getById(l));)l=`${i}_${s}`,s++;i=l}let o=e.getOrCreateEntity(i),a=t.properties;if(c(a)){o.properties=a;let s,l=a.title;if(c(l))o.name=l,s="title";else{let d=Number.MAX_VALUE;for(let m in a)if(a.hasOwnProperty(m)&&a[m]){let h=m.toLowerCase();if(d>1&&h==="title"){d=1,s=m;break}else d>2&&h==="name"?(d=2,s=m):d>3&&/title/i.test(m)?(d=3,s=m):d>4&&/name/i.test(m)&&(d=4,s=m)}c(s)&&(o.name=a[s])}let r=a.description;r!==null&&(o.description=c(r)?new Ii(r):n(a,s))}return o}function pnt(t,e){let n=new Array(t.length);for(let i=0;i2?d.perPositionHeight=new Ii(!0):o.clampToGround||(d.height=0);let Z=pv(e,t._entityCollection,o.describe);Z.polygon=d}function oSt(t,e,n,i,o){iSt(t,e,i,n.coordinates,o)}function aSt(t,e,n,i,o){let a=n.coordinates;for(let s=0;se&&(n==null?(n="…",i=3):i=n.length,t=t.substring(0,e-i)+n),t}function cs(t,e){for(var n=t.length-1;n>=0;n--)t[n]===e&&t.splice(n,1)}function xF(t,e){for(var n=t.length-1;n>=0;n--)e(t[n])===!0&&t.splice(n,1)}function XF(t){throw new Error("Unhandled case for value: '".concat(t,"'"))}var FQi=R(W());var rQi=R(W());var aQi=R(W()),JF=/[A-Za-z]/,Ir=/[\d]/;var Hh=/\s/,uv=/['"]/,mSt=/[\x00-\x1F\x7F]/,hSt=/A-Za-z\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FD5\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC/.source,w0e=/\u2700-\u27bf\udde6-\uddff\ud800-\udbff\udc00-\udfff\ufe0e\ufe0f\u0300-\u036f\ufe20-\ufe23\u20d0-\u20f0\ud83c\udffb-\udfff\u200d\u3299\u3297\u303d\u3030\u24c2\ud83c\udd70-\udd71\udd7e-\udd7f\udd8e\udd91-\udd9a\udde6-\uddff\ude01-\ude02\ude1a\ude2f\ude32-\ude3a\ude50-\ude51\u203c\u2049\u25aa-\u25ab\u25b6\u25c0\u25fb-\u25fe\u00a9\u00ae\u2122\u2139\udc04\u2600-\u26FF\u2b05\u2b06\u2b07\u2b1b\u2b1c\u2b50\u2b55\u231a\u231b\u2328\u23cf\u23e9-\u23f3\u23f8-\u23fa\udccf\u2935\u2934\u2190-\u21ff/.source,P0e=/\u0300-\u036F\u0483-\u0489\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u0610-\u061A\u064B-\u065F\u0670\u06D6-\u06DC\u06DF-\u06E4\u06E7\u06E8\u06EA-\u06ED\u0711\u0730-\u074A\u07A6-\u07B0\u07EB-\u07F3\u0816-\u0819\u081B-\u0823\u0825-\u0827\u0829-\u082D\u0859-\u085B\u08D4-\u08E1\u08E3-\u0903\u093A-\u093C\u093E-\u094F\u0951-\u0957\u0962\u0963\u0981-\u0983\u09BC\u09BE-\u09C4\u09C7\u09C8\u09CB-\u09CD\u09D7\u09E2\u09E3\u0A01-\u0A03\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A70\u0A71\u0A75\u0A81-\u0A83\u0ABC\u0ABE-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AE2\u0AE3\u0B01-\u0B03\u0B3C\u0B3E-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B62\u0B63\u0B82\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD7\u0C00-\u0C03\u0C3E-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C62\u0C63\u0C81-\u0C83\u0CBC\u0CBE-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CE2\u0CE3\u0D01-\u0D03\u0D3E-\u0D44\u0D46-\u0D48\u0D4A-\u0D4D\u0D57\u0D62\u0D63\u0D82\u0D83\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DF2\u0DF3\u0E31\u0E34-\u0E3A\u0E47-\u0E4E\u0EB1\u0EB4-\u0EB9\u0EBB\u0EBC\u0EC8-\u0ECD\u0F18\u0F19\u0F35\u0F37\u0F39\u0F3E\u0F3F\u0F71-\u0F84\u0F86\u0F87\u0F8D-\u0F97\u0F99-\u0FBC\u0FC6\u102B-\u103E\u1056-\u1059\u105E-\u1060\u1062-\u1064\u1067-\u106D\u1071-\u1074\u1082-\u108D\u108F\u109A-\u109D\u135D-\u135F\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17B4-\u17D3\u17DD\u180B-\u180D\u1885\u1886\u18A9\u1920-\u192B\u1930-\u193B\u1A17-\u1A1B\u1A55-\u1A5E\u1A60-\u1A7C\u1A7F\u1AB0-\u1ABE\u1B00-\u1B04\u1B34-\u1B44\u1B6B-\u1B73\u1B80-\u1B82\u1BA1-\u1BAD\u1BE6-\u1BF3\u1C24-\u1C37\u1CD0-\u1CD2\u1CD4-\u1CE8\u1CED\u1CF2-\u1CF4\u1CF8\u1CF9\u1DC0-\u1DF5\u1DFB-\u1DFF\u20D0-\u20F0\u2CEF-\u2CF1\u2D7F\u2DE0-\u2DFF\u302A-\u302F\u3099\u309A\uA66F-\uA672\uA674-\uA67D\uA69E\uA69F\uA6F0\uA6F1\uA802\uA806\uA80B\uA823-\uA827\uA880\uA881\uA8B4-\uA8C5\uA8E0-\uA8F1\uA926-\uA92D\uA947-\uA953\uA980-\uA983\uA9B3-\uA9C0\uA9E5\uAA29-\uAA36\uAA43\uAA4C\uAA4D\uAA7B-\uAA7D\uAAB0\uAAB2-\uAAB4\uAAB7\uAAB8\uAABE\uAABF\uAAC1\uAAEB-\uAAEF\uAAF5\uAAF6\uABE3-\uABEA\uABEC\uABED\uFB1E\uFE00-\uFE0F\uFE20-\uFE2F/.source,v0e=hSt+w0e+P0e,pSt=/0-9\u0660-\u0669\u06F0-\u06F9\u07C0-\u07C9\u0966-\u096F\u09E6-\u09EF\u0A66-\u0A6F\u0AE6-\u0AEF\u0B66-\u0B6F\u0BE6-\u0BEF\u0C66-\u0C6F\u0CE6-\u0CEF\u0D66-\u0D6F\u0DE6-\u0DEF\u0E50-\u0E59\u0ED0-\u0ED9\u0F20-\u0F29\u1040-\u1049\u1090-\u1099\u17E0-\u17E9\u1810-\u1819\u1946-\u194F\u19D0-\u19D9\u1A80-\u1A89\u1A90-\u1A99\u1B50-\u1B59\u1BB0-\u1BB9\u1C40-\u1C49\u1C50-\u1C59\uA620-\uA629\uA8D0-\uA8D9\uA900-\uA909\uA9D0-\uA9D9\uA9F0-\uA9F9\uAA50-\uAA59\uABF0-\uABF9\uFF10-\uFF19/.source,iQi=new RegExp("[".concat(hSt+pSt,"]")),unt=v0e+pSt,HZ=new RegExp("[".concat(unt,"]"));var Zv=function(){function t(e){e===void 0&&(e={}),this.tagName="",this.attrs={},this.innerHTML="",this.tagName=e.tagName||"",this.attrs=e.attrs||{},this.innerHTML=e.innerHtml||e.innerHTML||""}return t.prototype.setTagName=function(e){return this.tagName=e,this},t.prototype.getTagName=function(){return this.tagName||""},t.prototype.setAttr=function(e,n){var i=this.getAttrs();return i[e]=n,this},t.prototype.getAttr=function(e){return this.getAttrs()[e]},t.prototype.setAttrs=function(e){return Object.assign(this.getAttrs(),e),this},t.prototype.getAttrs=function(){return this.attrs||(this.attrs={})},t.prototype.setClass=function(e){return this.setAttr("class",e)},t.prototype.addClass=function(e){for(var n=this.getClass(),i=n?n.split(Hh):[],o=e.split(Hh),a;a=o.shift();)i.indexOf(a)===-1&&i.push(a);return this.getAttrs().class=i.join(" "),this},t.prototype.removeClass=function(e){for(var n=this.getClass(),i=n?n.split(Hh):[],o=e.split(Hh),a;i.length&&(a=o.shift());){var s=i.indexOf(a);s!==-1&&i.splice(s,1)}return this.getAttrs().class=i.join(" "),this},t.prototype.getClass=function(){return this.getAttrs().class||""},t.prototype.hasClass=function(e){return(" "+this.getClass()+" ").indexOf(" "+e+" ")!==-1},t.prototype.setInnerHTML=function(e){return this.innerHTML=e,this},t.prototype.setInnerHtml=function(e){return this.setInnerHTML(e)},t.prototype.getInnerHTML=function(){return this.innerHTML||""},t.prototype.getInnerHtml=function(){return this.getInnerHTML()},t.prototype.toAnchorString=function(){var e=this.getTagName(),n=this.buildAttrsStr();return n=n?" "+n:"",["<",e,n,">",this.getInnerHtml(),""].join("")},t.prototype.buildAttrsStr=function(){if(!this.attrs)return"";var e=this.getAttrs(),n=[];for(var i in e)e.hasOwnProperty(i)&&n.push(i+'="'+e[i]+'"');return n.join(" ")},t}();var cQi=R(W());function uSt(t,e,n){var i,o;n==null?(n="…",o=3,i=8):(o=n.length,i=n.length);var a=function(A){var T={},g=A,C=g.match(/^([a-z]+):\/\//i);return C&&(T.scheme=C[1],g=g.substr(C[0].length)),C=g.match(/^(.*?)(?=(\?|#|\/|$))/i),C&&(T.host=C[1],g=g.substr(C[0].length)),C=g.match(/^\/(.*?)(?=(\?|#|$))/i),C&&(T.path=C[1],g=g.substr(C[0].length)),C=g.match(/^\?(.*?)(?=(#|$))/i),C&&(T.query=C[1],g=g.substr(C[0].length)),C=g.match(/^#(.*?)$/i),C&&(T.fragment=C[1]),T},s=function(A){var T="";return A.scheme&&A.host&&(T+=A.scheme+"://"),A.host&&(T+=A.host),A.path&&(T+="/"+A.path),A.query&&(T+="?"+A.query),A.fragment&&(T+="#"+A.fragment),T},l=function(A,T){var g=T/2,C=Math.ceil(g),y=-1*Math.floor(g),Y="";return y<0&&(Y=A.substr(y)),A.substr(0,C)+n+Y};if(t.length<=e)return t;var r=e-o,d=a(t);if(d.query){var m=d.query.match(/^(.*?)(?=(\?|\#))(.*?)$/i);m&&(d.query=d.query.substr(0,m[1].length),t=s(d))}if(t.length<=e||(d.host&&(d.host=d.host.replace(/^www\./,""),t=s(d)),t.length<=e))return t;var h="";if(d.host&&(h+=d.host),h.length>=r)return d.host.length==e?(d.host.substr(0,e-o)+n).substr(0,r+i):l(h,r).substr(0,r+i);var Z="";if(d.path&&(Z+="/"+d.path),d.query&&(Z+="?"+d.query),Z)if((h+Z).length>=r){if((h+Z).length==e)return(h+Z).substr(0,e);var b=r-h.length;return(h+l(Z,b)).substr(0,r+i)}else h+=Z;if(d.fragment){var u="#"+d.fragment;if((h+u).length>=r){if((h+u).length==e)return(h+u).substr(0,e);var F=r-h.length;return(h+l(u,F)).substr(0,r+i)}else h+=u}if(d.scheme&&d.host){var U=d.scheme+"://";if((h+U).length0&&(G=h.substr(-1*Math.floor(r/2))),(h.substr(0,Math.ceil(r/2))+n+G).substr(0,r+i)}var hQi=R(W());function ZSt(t,e,n){if(t.length<=e)return t;var i,o;n==null?(n="…",i=8,o=3):(i=n.length,o=n.length);var a=e-o,s="";return a>0&&(s=t.substr(-1*Math.floor(a/2))),(t.substr(0,Math.ceil(a/2))+n+s).substr(0,a+i)}var ZQi=R(W());function VSt(t,e,n){return cSt(t,e,n)}var bSt=function(){function t(e){e===void 0&&(e={}),this.newWindow=!1,this.truncate={},this.className="",this.newWindow=e.newWindow||!1,this.truncate=e.truncate||{},this.className=e.className||""}return t.prototype.build=function(e){return new Zv({tagName:"a",attrs:this.createAttrs(e),innerHtml:this.processAnchorText(e.getAnchorText())})},t.prototype.createAttrs=function(e){var n={href:e.getAnchorHref()},i=this.createCssClass(e);return i&&(n.class=i),this.newWindow&&(n.target="_blank",n.rel="noopener noreferrer"),this.truncate&&this.truncate.length&&this.truncate.length=0;b--){var u=m[b];switch(u.state){case 11:y(u,Z);break;case 12:Y(u,Z);break;case 0:G(u,Z);break;case 1:A(u,Z);break;case 2:T(u,Z);break;case 3:g(u,Z);break;case 4:C(u,Z);break;case 5:Q(u,Z);break;case 6:J(u,Z);break;case 7:M(u,Z);break;case 13:V(u,Z);break;case 14:E(u,Z);break;case 8:I(u,Z);break;case 9:B(u,Z);break;case 10:X(u,Z);break;case 15:_(u,Z);break;case 16:P(u,Z);break;case 17:w(u,Z);break;case 18:z(u,Z);break;case 19:H(u,Z);break;case 20:nt(u,Z);break;case 21:$(u,Z);break;case 22:dt(u,Z);break;case 23:q(u,Z);break;case 24:at(u,Z);break;case 25:st(u,Z);break;case 26:Et(u,Z);break;case 27:Qt(u,Z);break;case 28:Wt(u,Z);break;case 29:Nt(u,Z);break;case 30:kt(u,Z);break;case 31:Mt(u,Z);break;case 32:ie(u,Z);break;case 33:oe(u,Z);break;case 34:He(u,Z);break;case 35:rn(u,Z);break;case 36:de(u,Z);break;case 37:qt(u,Z);break;case 38:zt(u,Z);break;case 39:ke(u,Z);break;case 40:ue(u,Z);break;case 41:We(u,Z);break;default:XF(u.state)}}}for(var F=m.length-1;F>=0;F--)m.forEach(function(Ct){return un(Ct)});return r;function U(Ct){if(Ct==="#")m.push(GWe(h,28));else if(Ct==="@")m.push(AWe(h,30));else if(Ct==="/")m.push(Ant(h,11));else if(Ct==="+")m.push(Tnt(h,37));else if(Ct==="(")m.push(Tnt(h,32));else{if(Ir.test(Ct)&&(m.push(Tnt(h,38)),m.push(FWe(h,13))),gSt(Ct)){var _t=Ct.toLowerCase()==="m"?15:22;m.push(UWe(h,_t))}Vv(Ct)&&m.push(Gnt(h,0)),HZ.test(Ct)&&m.push(Ant(h,5))}}function G(Ct,_t){_t===":"?Ct.state=2:_t==="-"?Ct.state=1:bnt(_t)||cs(m,Ct)}function A(Ct,_t){_t==="-"||(_t==="/"?(cs(m,Ct),m.push(Ant(h,11))):bnt(_t)?Ct.state=0:cs(m,Ct))}function T(Ct,_t){_t==="/"?Ct.state=3:_t==="."?cs(m,Ct):$0(_t)?(Ct.state=5,Vv(_t)&&m.push(Gnt(h,0))):cs(m,Ct)}function g(Ct,_t){_t==="/"?Ct.state=4:Rnt(_t)?(Ct.state=10,Ct.acceptStateReached=!0):un(Ct)}function C(Ct,_t){_t==="/"?Ct.state=10:$0(_t)?(Ct.state=5,Ct.acceptStateReached=!0):cs(m,Ct)}function y(Ct,_t){_t==="/"?Ct.state=12:cs(m,Ct)}function Y(Ct,_t){$0(_t)?Ct.state=5:cs(m,Ct)}function Q(Ct,_t){_t==="."?Ct.state=7:_t==="-"?Ct.state=6:_t===":"?Ct.state=8:Rv(_t)?Ct.state=10:bv(_t)||un(Ct)}function J(Ct,_t){_t==="-"||(_t==="."?un(Ct):$0(_t)?Ct.state=5:un(Ct))}function M(Ct,_t){_t==="."?un(Ct):$0(_t)?(Ct.state=5,Ct.acceptStateReached=!0):un(Ct)}function V(Ct,_t){_t==="."?Ct.state=14:_t===":"?Ct.state=8:Ir.test(_t)||(Rv(_t)?Ct.state=10:HZ.test(_t)?cs(m,Ct):un(Ct))}function E(Ct,_t){Ir.test(_t)?(Ct.octetsEncountered++,Ct.octetsEncountered===4&&(Ct.acceptStateReached=!0),Ct.state=13):un(Ct)}function I(Ct,_t){Ir.test(_t)?Ct.state=9:un(Ct)}function B(Ct,_t){Ir.test(_t)||(Rv(_t)?Ct.state=10:un(Ct))}function X(Ct,_t){Rnt(_t)||un(Ct)}function _(Ct,_t){_t.toLowerCase()==="a"?Ct.state=16:dt(Ct,_t)}function P(Ct,_t){_t.toLowerCase()==="i"?Ct.state=17:dt(Ct,_t)}function w(Ct,_t){_t.toLowerCase()==="l"?Ct.state=18:dt(Ct,_t)}function z(Ct,_t){_t.toLowerCase()==="t"?Ct.state=19:dt(Ct,_t)}function H(Ct,_t){_t.toLowerCase()==="o"?Ct.state=20:dt(Ct,_t)}function nt(Ct,_t){_t.toLowerCase()===":"?Ct.state=21:dt(Ct,_t)}function $(Ct,_t){Wv(_t)?Ct.state=22:cs(m,Ct)}function dt(Ct,_t){_t==="."?Ct.state=23:_t==="@"?Ct.state=24:Wv(_t)?Ct.state=22:cs(m,Ct)}function q(Ct,_t){_t==="."?cs(m,Ct):_t==="@"?cs(m,Ct):Wv(_t)?Ct.state=22:cs(m,Ct)}function at(Ct,_t){$0(_t)?Ct.state=25:cs(m,Ct)}function st(Ct,_t){_t==="."?Ct.state=27:_t==="-"?Ct.state=26:bv(_t)||un(Ct)}function Et(Ct,_t){_t==="-"||_t==="."?un(Ct):bv(_t)?Ct.state=25:un(Ct)}function Qt(Ct,_t){_t==="."||_t==="-"?un(Ct):$0(_t)?(Ct.state=25,Ct.acceptStateReached=!0):un(Ct)}function Wt(Ct,_t){fnt(_t)?(Ct.state=29,Ct.acceptStateReached=!0):cs(m,Ct)}function Nt(Ct,_t){fnt(_t)||un(Ct)}function kt(Ct,_t){Fnt(_t)?(Ct.state=31,Ct.acceptStateReached=!0):cs(m,Ct)}function Mt(Ct,_t){Fnt(_t)||(HZ.test(_t)?cs(m,Ct):un(Ct))}function qt(Ct,_t){Ir.test(_t)?Ct.state=38:(cs(m,Ct),U(_t))}function ie(Ct,_t){Ir.test(_t)?Ct.state=33:cs(m,Ct),U(_t)}function oe(Ct,_t){Ir.test(_t)?Ct.state=34:cs(m,Ct)}function He(Ct,_t){Ir.test(_t)?Ct.state=35:cs(m,Ct)}function rn(Ct,_t){_t===")"?Ct.state=36:cs(m,Ct)}function de(Ct,_t){Ir.test(_t)?Ct.state=38:Unt(_t)?Ct.state=39:cs(m,Ct)}function zt(Ct,_t){Ct.acceptStateReached=!0,fv(_t)?Ct.state=40:_t==="#"?Ct.state=41:Ir.test(_t)||(_t==="("?Ct.state=32:Unt(_t)?Ct.state=39:(un(Ct),Vv(_t)&&m.push(Gnt(h,0))))}function ke(Ct,_t){Ir.test(_t)?Ct.state=38:_t==="("?Ct.state=32:(un(Ct),U(_t))}function ue(Ct,_t){fv(_t)||(_t==="#"?Ct.state=41:Ir.test(_t)?Ct.state=38:un(Ct))}function We(Ct,_t){fv(_t)?Ct.state=40:Ir.test(_t)?cs(m,Ct):un(Ct)}function un(Ct){if(cs(m,Ct),!!Ct.acceptStateReached){var _t=Ct.startIdx,Je=t.slice(Ct.startIdx,h);if(Je=fWe(Je),Ct.type==="url"){var xe=t.charAt(Ct.startIdx-1);if(xe==="@")return;var oo=Ct.matchType;if(oo==="scheme"){var ea=Vnt.exec(Je);if(ea&&(_t=_t+ea.index,Je=Je.slice(ea.index)),!USt(Je))return}else if(oo==="tld"){if(!GSt(Je))return}else if(oo==="ipV4"){if(!ASt(Je))return}else XF(oo);r.push(new TSt({tagBuilder:n,matchedText:Je,offset:_t,urlMatchType:oo,url:Je,protocolRelativeMatch:Je.slice(0,2)==="//",stripPrefix:i,stripTrailingSlash:o,decodePercentEncoding:a}))}else if(Ct.type==="email")ESt(Je)&&r.push(new CSt({tagBuilder:n,matchedText:Je,offset:_t,email:Je.replace(SSt,"")}));else if(Ct.type==="hashtag")ISt(Je)&&r.push(new ySt({tagBuilder:n,matchedText:Je,offset:_t,serviceName:s,hashtag:Je.slice(1)}));else if(Ct.type==="mention")BSt(Je,l)&&r.push(new kSt({tagBuilder:n,matchedText:Je,offset:_t,serviceName:l,mention:Je.slice(1)}));else if(Ct.type==="phone"){if(Je=Je.replace(/ +$/g,""),YSt(Je)){var gs=Je.replace(/[^0-9,;#]/g,"");r.push(new xSt({tagBuilder:n,matchedText:Je,offset:_t,number:gs,plusSign:Je.charAt(0)==="+"}))}}else XF(Ct)}}}var WWe=/[\(\{\[]/,XSt=/[\)\}\]]/,JSt={")":"(","}":"{","]":"["};function fWe(t){for(var e={"(":0,"{":0,"[":0},n=0;n=0;)if(a=t.charAt(o),XSt.test(a)){var s=JSt[a];if(e[s]<0)e[s]++,o--;else break}else if(FSt.test(a))o--;else break;return t.slice(0,o+1)}function Gnt(t,e){return{type:"url",startIdx:t,state:e,acceptStateReached:!1,matchType:"scheme"}}function Ant(t,e){return{type:"url",startIdx:t,state:e,acceptStateReached:!1,matchType:"tld"}}function FWe(t,e){return{type:"url",startIdx:t,state:e,acceptStateReached:!1,matchType:"ipV4",octetsEncountered:1}}function UWe(t,e){return{type:"email",startIdx:t,state:e,acceptStateReached:!1}}function GWe(t,e){return{type:"hashtag",startIdx:t,state:e,acceptStateReached:!1}}function AWe(t,e){return{type:"mention",startIdx:t,state:e,acceptStateReached:!1}}function Tnt(t,e){return{type:"phone",startIdx:t,state:e,acceptStateReached:!1}}var C2i=R(W());function MSt(t,e){for(var n=e.onOpenTag,i=e.onCloseTag,o=e.onText,a=e.onComment,s=e.onDoctype,l=new Fb,r=0,d=t.length,m=0,h=0,Z=l;r"?(Z=new Fb(Nr(Nr({},Z),{name:dt()})),nt()):!JF.test(at)&&!Ir.test(at)&&at!==":"&&z()}function G(at){at===">"?z():JF.test(at)?m=3:z()}function A(at){Hh.test(at)||(at==="/"?m=12:at===">"?nt():at==="<"?H():at==="="||uv.test(at)||mSt.test(at)?z():m=5)}function T(at){Hh.test(at)?m=6:at==="/"?m=12:at==="="?m=7:at===">"?nt():at==="<"?H():uv.test(at)&&z()}function g(at){Hh.test(at)||(at==="/"?m=12:at==="="?m=7:at===">"?nt():at==="<"?H():uv.test(at)?z():m=5)}function C(at){Hh.test(at)||(at==='"'?m=8:at==="'"?m=9:/[>=`]/.test(at)?z():at==="<"?H():m=10)}function y(at){at==='"'&&(m=11)}function Y(at){at==="'"&&(m=11)}function Q(at){Hh.test(at)?m=4:at===">"?nt():at==="<"&&H()}function J(at){Hh.test(at)?m=4:at==="/"?m=12:at===">"?nt():at==="<"?H():(m=4,q())}function M(at){at===">"?(Z=new Fb(Nr(Nr({},Z),{isClosing:!0})),nt()):m=4}function V(at){t.substr(r,2)==="--"?(r+=2,Z=new Fb(Nr(Nr({},Z),{type:"comment"})),m=14):t.substr(r,7).toUpperCase()==="DOCTYPE"?(r+=7,Z=new Fb(Nr(Nr({},Z),{type:"doctype"})),m=20):z()}function E(at){at==="-"?m=15:at===">"?z():m=16}function I(at){at==="-"?m=18:at===">"?z():m=16}function B(at){at==="-"&&(m=17)}function X(at){at==="-"?m=18:m=16}function _(at){at===">"?nt():at==="!"?m=19:at==="-"||(m=16)}function P(at){at==="-"?m=17:at===">"?nt():m=16}function w(at){at===">"?nt():at==="<"&&H()}function z(){m=0,Z=l}function H(){m=1,Z=new Fb({idx:r})}function nt(){var at=t.slice(h,Z.idx);at&&o(at,h),Z.type==="comment"?a(Z.idx):Z.type==="doctype"?s(Z.idx):(Z.isOpening&&n(Z.name,Z.idx),Z.isClosing&&i(Z.name,Z.idx)),z(),h=r+1}function $(){var at=t.slice(h,r);o(at,h),h=r+1}function dt(){var at=Z.idx+(Z.isClosing?2:1);return t.slice(at,r).toLowerCase()}function q(){r--}}var Fb=function(){function t(e){e===void 0&&(e={}),this.idx=e.idx!==void 0?e.idx:-1,this.type=e.type||"tag",this.name=e.name||"",this.isOpening=!!e.isOpening,this.isClosing=!!e.isClosing}return t}();var TWe=function(){function t(e){e===void 0&&(e={}),this.version=t.version,this.urls={},this.email=!0,this.phone=!0,this.hashtag=!1,this.mention=!1,this.newWindow=!0,this.stripPrefix={scheme:!0,www:!0},this.stripTrailingSlash=!0,this.decodePercentEncoding=!0,this.truncate={length:0,location:"end"},this.className="",this.replaceFn=null,this.context=void 0,this.sanitizeHtml=!1,this.tagBuilder=null,this.urls=SWe(e.urls),this.email=Oh(e.email)?e.email:this.email,this.phone=Oh(e.phone)?e.phone:this.phone,this.hashtag=e.hashtag||this.hashtag,this.mention=e.mention||this.mention,this.newWindow=Oh(e.newWindow)?e.newWindow:this.newWindow,this.stripPrefix=gWe(e.stripPrefix),this.stripTrailingSlash=Oh(e.stripTrailingSlash)?e.stripTrailingSlash:this.stripTrailingSlash,this.decodePercentEncoding=Oh(e.decodePercentEncoding)?e.decodePercentEncoding:this.decodePercentEncoding,this.sanitizeHtml=e.sanitizeHtml||!1;var n=this.mention;if(n!==!1&&QSt.indexOf(n)===-1)throw new Error("invalid `mention` cfg '".concat(n,"' - see docs"));var i=this.hashtag;if(i!==!1&&NSt.indexOf(i)===-1)throw new Error("invalid `hashtag` cfg '".concat(i,"' - see docs"));this.truncate=EWe(e.truncate),this.className=e.className||this.className,this.replaceFn=e.replaceFn||this.replaceFn,this.context=e.context||this}return t.link=function(e,n){var i=new t(n);return i.link(e)},t.parse=function(e,n){var i=new t(n);return i.parse(e)},t.prototype.parse=function(e){var n=this,i=["a","style","script"],o=0,a=[];return MSt(e,{onOpenTag:function(s){i.indexOf(s)>=0&&o++},onText:function(s,l){if(o===0){var r=/( | |<|<|>|>|"|"|')/gi,d=s.split(r),m=l;d.forEach(function(h,Z){if(Z%2===0){var b=n.parseText(h,m);a.push.apply(a,b)}m+=h.length})}},onCloseTag:function(s){i.indexOf(s)>=0&&(o=Math.max(o-1,0))},onComment:function(s){},onDoctype:function(s){}}),a=this.compactMatches(a),a=this.removeUnwantedMatches(a),a},t.prototype.compactMatches=function(e){e.sort(function(r,d){return r.getOffset()-d.getOffset()});for(var n=0;na?n:n+1;e.splice(l,1);continue}if(e[n+1].getOffset()/g,">"));for(var n=this.parse(e),i=[],o=0,a=0,s=n.length;a{let i=new FileReader;i.addEventListener("load",function(){e(i.result)}),i.addEventListener("error",function(){n(i.error)}),i.readAsText(t)})}function Snt(t,e){let n=IL(t,"id");return n=c(n)?n:Si(),e.getOrCreateEntity(n)}function gnt(t){let e=PSt(t,"lon"),n=PSt(t,"lat"),i=EL(t,"ele",va.gpx);return p.fromDegrees(e,n,i)}function PSt(t,e){if(!c(t))return;let n=t.getAttribute(e);if(n!==null){let i=parseFloat(n);return isNaN(i)?void 0:i}}function IL(t,e){if(!c(t))return;let n=t.getAttribute(e);return n!==null?n:void 0}function LF(t,e,n){if(!c(t))return;let i=t.childNodes,o=i.length;for(let a=0;a${h.text}: ${h.value}

`)}if(!c(i)||i==="")return;i=CWe.link(i),CL.innerHTML=i;let s=CL.querySelectorAll("a");for(n=0;n',d+=`${CL.innerHTML}`,CL.innerHTML="",d}function tgt(t,e,n,i){let o=gnt(e),a=Snt(e,n);a.position=o;let s=c(i.waypointImage)?i.waypointImage:t._pinBuilder.fromMakiIconId("marker",v.RED,Uv);a.billboard=qSt(s);let l=Pm(e,"name",va.gpx);a.name=l,a.label=yWe(),a.label.text=l,a.description=Cnt(e,a),i.clampToGround&&(a.billboard.heightReference=Ge.CLAMP_TO_GROUND,a.label.heightReference=Ge.CLAMP_TO_GROUND)}function BWe(t,e,n,i){let o=Snt(e,n);o.description=Cnt(e,o);let a=Ent(e,"rtept",va.gpx),s=new Array(a.length);for(let l=0;l0?(l=l.concat(r.times),m.addSamples(l,s),d=d&&!0):d=!1;if(d){let h=c(i.waypointImage)?i.waypointImage:t._pinBuilder.fromMakiIconId("marker",v.RED,Uv);o.billboard=qSt(h),o.position=m,i.clampToGround&&(o.billboard.heightReference=Ge.CLAMP_TO_GROUND),o.availability=new ys,o.availability.addInterval(new ai({start:l[0],stop:l[l.length-1]}))}o.polyline=$St(i.trackColor),o.polyline.positions=s,i.clampToGround&&(o.polyline.clampToGround=!0)}function kWe(t){let e={positions:[],times:[]},n=Ent(t,"trkpt",va.gpx),i;for(let o=0;onew Array(e).fill(n,0,e)))}function Iv(t){return t.reduce((e,n)=>e.concat(Array.isArray(n)?Iv(n):n),[])}var ngt=[0,1,2,3].concat(...Cv([[2,4],[2,5],[4,6],[4,7],[8,8],[8,9],[16,10],[16,11],[32,12],[32,13],[64,14],[64,15],[2,0],[1,16],[1,17],[2,18],[2,19],[4,20],[4,21],[8,22],[8,23],[16,24],[16,25],[32,26],[32,27],[64,28],[64,29]]));function ks(){let t=this;function e(o){let a=t.dyn_tree,s=t.stat_desc.static_tree,l=t.stat_desc.extra_bits,r=t.stat_desc.extra_base,d=t.stat_desc.max_length,m,h,Z,b,u,F,U=0;for(b=0;b<=15;b++)o.bl_count[b]=0;for(a[o.heap[o.heap_max]*2+1]=0,m=o.heap_max+1;m<573;m++)h=o.heap[m],b=a[a[h*2+1]*2+1]+1,b>d&&(b=d,U++),a[h*2+1]=b,!(h>t.max_code)&&(o.bl_count[b]++,u=0,h>=r&&(u=l[h-r]),F=a[h*2],o.opt_len+=F*(b+u),s&&(o.static_len+=F*(s[h*2+1]+u)));if(U!==0){do{for(b=d-1;o.bl_count[b]===0;)b--;o.bl_count[b]--,o.bl_count[b+1]+=2,o.bl_count[d]--,U-=2}while(U>0);for(b=d;b!==0;b--)for(h=o.bl_count[b];h!==0;)Z=o.heap[--m],!(Z>t.max_code)&&(a[Z*2+1]!=b&&(o.opt_len+=(b-a[Z*2+1])*a[Z*2],a[Z*2+1]=b),h--)}}function n(o,a){let s=0;do s|=o&1,o>>>=1,s<<=1;while(--a>0);return s>>>1}function i(o,a,s){let l=[],r=0,d,m,h;for(d=1;d<=15;d++)l[d]=r=r+s[d-1]<<1;for(m=0;m<=a;m++)h=o[m*2+1],h!==0&&(o[m*2]=n(l[h]++,h))}t.build_tree=function(o){let a=t.dyn_tree,s=t.stat_desc.static_tree,l=t.stat_desc.elems,r,d,m=-1,h;for(o.heap_len=0,o.heap_max=573,r=0;r=1;r--)o.pqdownheap(a,r);h=l;do r=o.heap[1],o.heap[1]=o.heap[o.heap_len--],o.pqdownheap(a,1),d=o.heap[1],o.heap[--o.heap_max]=r,o.heap[--o.heap_max]=d,a[h*2]=a[r*2]+a[d*2],o.depth[h]=Math.max(o.depth[r],o.depth[d])+1,a[r*2+1]=a[d*2+1]=h,o.heap[1]=h++,o.pqdownheap(a,1);while(o.heap_len>=2);o.heap[--o.heap_max]=o.heap[1],e(o),i(a,t.max_code,o.bl_count)}}ks._length_code=[0,1,2,3,4,5,6,7].concat(...Cv([[2,8],[2,9],[2,10],[2,11],[4,12],[4,13],[4,14],[4,15],[8,16],[8,17],[8,18],[8,19],[16,20],[16,21],[16,22],[16,23],[32,24],[32,25],[32,26],[31,27],[1,28]]));ks.base_length=[0,1,2,3,4,5,6,7,8,10,12,14,16,20,24,28,32,40,48,56,64,80,96,112,128,160,192,224,0];ks.base_dist=[0,1,2,3,4,6,8,12,16,24,32,48,64,96,128,192,256,384,512,768,1024,1536,2048,3072,4096,6144,8192,12288,16384,24576];ks.d_code=function(t){return t<256?ngt[t]:ngt[256+(t>>>7)]};ks.extra_lbits=[0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0];ks.extra_dbits=[0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13];ks.extra_blbits=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7];ks.bl_order=[16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15];function fd(t,e,n,i,o){let a=this;a.static_tree=t,a.extra_bits=e,a.extra_base=n,a.elems=i,a.max_length=o}var HWe=[12,140,76,204,44,172,108,236,28,156,92,220,60,188,124,252,2,130,66,194,34,162,98,226,18,146,82,210,50,178,114,242,10,138,74,202,42,170,106,234,26,154,90,218,58,186,122,250,6,134,70,198,38,166,102,230,22,150,86,214,54,182,118,246,14,142,78,206,46,174,110,238,30,158,94,222,62,190,126,254,1,129,65,193,33,161,97,225,17,145,81,209,49,177,113,241,9,137,73,201,41,169,105,233,25,153,89,217,57,185,121,249,5,133,69,197,37,165,101,229,21,149,85,213,53,181,117,245,13,141,77,205,45,173,109,237,29,157,93,221,61,189,125,253,19,275,147,403,83,339,211,467,51,307,179,435,115,371,243,499,11,267,139,395,75,331,203,459,43,299,171,427,107,363,235,491,27,283,155,411,91,347,219,475,59,315,187,443,123,379,251,507,7,263,135,391,71,327,199,455,39,295,167,423,103,359,231,487,23,279,151,407,87,343,215,471,55,311,183,439,119,375,247,503,15,271,143,399,79,335,207,463,47,303,175,431,111,367,239,495,31,287,159,415,95,351,223,479,63,319,191,447,127,383,255,511,0,64,32,96,16,80,48,112,8,72,40,104,24,88,56,120,4,68,36,100,20,84,52,116,3,131,67,195,35,163,99,227],wWe=Cv([[144,8],[112,9],[24,7],[8,8]]);fd.static_ltree=Iv(HWe.map((t,e)=>[t,wWe[e]]));var PWe=[0,16,8,24,4,20,12,28,2,18,10,26,6,22,14,30,1,17,9,25,5,21,13,29,3,19,11,27,7,23],vWe=Cv([[30,5]]);fd.static_dtree=Iv(PWe.map((t,e)=>[t,vWe[e]]));fd.static_l_desc=new fd(fd.static_ltree,ks.extra_lbits,257,286,15);fd.static_d_desc=new fd(fd.static_dtree,ks.extra_dbits,0,30,15);fd.static_bl_desc=new fd(null,ks.extra_blbits,0,19,7);var KWe=9,zWe=8;function Ub(t,e,n,i,o){let a=this;a.good_length=t,a.max_lazy=e,a.nice_length=n,a.max_chain=i,a.func=o}var ogt=0,gv=1,yT=2,wZ=[new Ub(0,0,0,0,ogt),new Ub(4,4,8,4,gv),new Ub(4,5,16,8,gv),new Ub(4,6,32,32,gv),new Ub(4,4,16,16,yT),new Ub(8,16,32,32,yT),new Ub(8,16,128,128,yT),new Ub(8,32,128,256,yT),new Ub(32,128,258,1024,yT),new Ub(32,258,258,4096,yT)],Gv=["need dictionary","stream end","","","stream error","data error","","buffer error","",""],Vu=0,Av=1,BL=2,Tv=3,jWe=32,Int=42,Sv=113,QL=666,Nnt=8,qWe=0,ynt=1,$We=2,zs=3,Ev=258,wh=Ev+zs+1;function igt(t,e,n,i){let o=t[e*2],a=t[n*2];return o=3&&P[ks.bl_order[ae]*2+1]===0;ae--);return t.opt_len+=3*(ae+1)+5+5+4,ae}function Mt(ae){t.pending_buf[t.pending++]=ae}function qt(ae){Mt(ae&255),Mt(ae>>>8&255)}function ie(ae){Mt(ae>>8&255),Mt(ae&255&255)}function oe(ae,fe){let ge,Ze=fe;st>16-Ze?(ge=ae,at|=ge<>>16-st,st+=Ze-16):(at|=ae<=8&&(Mt(at&255),at>>>=8,st-=8)}function ke(){oe(ynt<<1,3),He(256,fd.static_ltree),zt(),1+q+10-st<9&&(oe(ynt<<1,3),He(256,fd.static_ltree),zt()),q=7}function ue(ae,fe){let ge,Ze,Ke;if(t.dist_buf[$]=ae,t.lc_buf[$]=fe&255,$++,ae===0?X[fe*2]++:(dt++,ae--,X[(ks._length_code[fe]+256+1)*2]++,_[ks.d_code(ae)*2]++),!($&8191)&&V>2){for(ge=$*8,Ze=C-G,Ke=0;Ke<30;Ke++)ge+=_[Ke*2]*(5+ks.extra_dbits[Ke]);if(ge>>>=3,dt8?qt(at):st>0&&Mt(at&255),at=0,st=0}function Ct(ae,fe,ge){un(),q=8,ge&&(qt(fe),qt(~fe)),t.pending_buf.set(r.subarray(ae,ae+fe),t.pending),t.pending+=fe}function _t(ae,fe,ge){oe((qWe<<1)+(ge?1:0),3),Ct(ae,fe,!0)}function Je(ae,fe,ge){let Ze,Ke,An=0;V>0?(w.build_tree(t),z.build_tree(t),An=kt(),Ze=t.opt_len+3+7>>>3,Ke=t.static_len+3+7>>>3,Ke<=Ze&&(Ze=Ke)):Ze=Ke=fe+5,fe+4<=Ze&&ae!=-1?_t(ae,fe,ge):Ke==Ze?(oe((ynt<<1)+(ge?1:0),3),We(fd.static_ltree,fd.static_dtree)):(oe(($We<<1)+(ge?1:0),3),de(w.max_code+1,z.max_code+1,An+1),We(X,_)),Qt(),ge&&un()}function xe(ae){Je(G>=0?G:-1,C-G,ae),G=C,e.flush_pending()}function oo(){let ae,fe,ge,Ze;do{if(Ze=d-Y-C,Ze===0&&C===0&&Y===0)Ze=a;else if(Ze==-1)Ze--;else if(C>=a+a-wh){r.set(r.subarray(a,a+a),0),y-=a,C-=a,G-=a,ae=b,ge=ae;do fe=h[--ge]&65535,h[ge]=fe>=a?fe-a:0;while(--ae!==0);ae=a,ge=ae;do fe=m[--ge]&65535,m[ge]=fe>=a?fe-a:0;while(--ae!==0);Ze+=a}if(e.avail_in===0)return;ae=e.read_buf(r,C+Y,Ze),Y+=ae,Y>=zs&&(Z=r[C]&255,Z=(Z<i-5&&(fe=i-5);;){if(Y<=1){if(oo(),Y===0&&ae==0)return Vu;if(Y===0)break}if(C+=Y,Y=0,ge=G+fe,(C===0||C>=ge)&&(Y=C-ge,C=ge,xe(!1),e.avail_out===0)||C-G>=a-wh&&(xe(!1),e.avail_out===0))return Vu}return xe(ae==4),e.avail_out===0?ae==4?BL:Vu:ae==4?Tv:Av}function gs(ae){let fe=J,ge=C,Ze,Ke,An=Q,si=C>a-wh?C-(a-wh):0,da=B,_a=l,bl=C+Ev,na=r[ge+An-1],Go=r[ge+An];Q>=I&&(fe>>=2),da>Y&&(da=Y);do if(Ze=ae,!(r[Ze+An]!=Go||r[Ze+An-1]!=na||r[Ze]!=r[ge]||r[++Ze]!=r[ge+1])){ge+=2,Ze++;do;while(r[++ge]==r[++Ze]&&r[++ge]==r[++Ze]&&r[++ge]==r[++Ze]&&r[++ge]==r[++Ze]&&r[++ge]==r[++Ze]&&r[++ge]==r[++Ze]&&r[++ge]==r[++Ze]&&r[++ge]==r[++Ze]&&geAn){if(y=ae,An=Ke,Ke>=da)break;na=r[ge+An-1],Go=r[ge+An]}}while((ae=m[ae&_a]&65535)>si&&--fe!==0);return An<=Y?An:Y}function is(ae){let fe=0,ge;for(;;){if(Y=zs&&(Z=(Z<=zs)if(ge=ue(C-y,A-zs),Y-=A,A<=M&&Y>=zs){A--;do C++,Z=(Z<=zs&&(Z=(Z<4096)&&(A=zs-1)),Q>=zs&&A<=Q){Ze=C+Y-zs,ge=ue(C-1-T,Q-zs),Y-=Q-1,Q-=2;do++C<=Ze&&(Z=(Z<KWe||Ze!=Nnt||ge<9||ge>15||fe<0||fe>9||An<0||An>2?-2:(ae.dstate=t,s=ge,a=1<9||ge<0||ge>2?-2:(wZ[V].func!=wZ[fe].func&&ae.total_in!==0&&(Ze=ae.deflate(1)),V!=fe&&(V=fe,M=wZ[V].max_lazy,I=wZ[V].good_length,B=wZ[V].nice_length,J=wZ[V].max_chain),E=ge,Ze)},t.deflateSetDictionary=function(ae,fe,ge){let Ze=ge,Ke,An=0;if(!fe||n!=Int)return-2;if(Zea-wh&&(Ze=a-wh,An=ge-Ze),r.set(fe.subarray(An,An+Ze),0),C=Ze,G=Ze,Z=r[0]&255,Z=(Z<4||fe<0)return-2;if(!ae.next_out||!ae.next_in&&ae.avail_in!==0||n==QL&&fe!=4)return ae.msg=Gv[4],-2;if(ae.avail_out===0)return ae.msg=Gv[7],-5;if(e=ae,An=o,o=fe,n==Int&&(Ze=Nnt+(s-8<<4)<<8,Ke=(V-1&255)>>1,Ke>3&&(Ke=3),Ze|=Ke<<6,C!==0&&(Ze|=jWe),Ze+=31-Ze%31,n=Sv,ie(Ze)),t.pending!==0){if(e.flush_pending(),e.avail_out===0)return o=-1,0}else if(e.avail_in===0&&fe<=An&&fe!=4)return e.msg=Gv[7],-5;if(n==QL&&e.avail_in!==0)return ae.msg=Gv[7],-5;if(e.avail_in!==0||Y!==0||fe!=0&&n!=QL){switch(si=-1,wZ[V].func){case ogt:si=ea(fe);break;case gv:si=is(fe);break;case yT:si=ja(fe);break;default:}if((si==BL||si==Tv)&&(n=QL),si==Vu||si==BL)return e.avail_out===0&&(o=-1),0;if(si==Av){if(fe==1)ke();else if(_t(0,0,!1),fe==3)for(ge=0;gen&&(o=n),o===0?0:(i.avail_in-=o,t.set(i.next_in.subarray(i.next_in_index,i.next_in_index+o),e),i.next_in_index+=o,i.total_in+=o,o)},flush_pending(){let t=this,e=t.dstate.pending;e>t.avail_out&&(e=t.avail_out),e!==0&&(t.next_out.set(t.dstate.pending_buf.subarray(t.dstate.pending_out,t.dstate.pending_out+e),t.next_out_index),t.next_out_index+=e,t.dstate.pending_out+=e,t.total_out+=e,t.avail_out-=e,t.dstate.pending-=e,t.dstate.pending===0&&(t.dstate.pending_out=0))}};function sgt(t){let e=this,n=new agt,i=efe(t&&t.chunkSize?t.chunkSize:64*1024),o=0,a=new Uint8Array(i),s=t?t.level:-1;typeof s>"u"&&(s=-1),n.deflateInit(s),n.next_out=a,e.append=function(l,r){let d,m,h=0,Z=0,b=0,u=[];if(l.length){n.next_in_index=0,n.next_in=l,n.avail_in=l.length;do{if(n.next_out_index=0,n.avail_out=i,d=n.deflate(o),d!=0)throw new Error("deflating: "+n.msg);n.next_out_index&&(n.next_out_index==i?u.push(new Uint8Array(a)):u.push(a.subarray(0,n.next_out_index))),b+=n.next_out_index,r&&n.next_in_index>0&&n.next_in_index!=h&&(r(n.next_in_index),h=n.next_in_index)}while(n.avail_in>0||n.avail_out===0);return u.length>1?(m=new Uint8Array(b),u.forEach(function(F){m.set(F,Z),Z+=F.length})):m=u[0]?new Uint8Array(u[0]):new Uint8Array,m}},e.flush=function(){let l,r,d=0,m=0,h=[];do{if(n.next_out_index=0,n.avail_out=i,l=n.deflate(4),l!=1&&l!=0)throw new Error("deflating: "+n.msg);i-n.avail_out>0&&h.push(a.slice(0,n.next_out_index)),m+=n.next_out_index}while(n.avail_in>0||n.avail_out===0);return n.deflateEnd(),r=new Uint8Array(m),h.forEach(function(Z){r.set(Z,d),d+=Z.length}),r}}function efe(t){return t+5*(Math.floor(t/16383)+1)}var Pki=R(W(),1);var Ph=[0,1,3,7,15,31,63,127,255,511,1023,2047,4095,8191,16383,32767,65535],Sgt=1440,nfe=0,ife=4,ofe=9,afe=5,sfe=[96,7,256,0,8,80,0,8,16,84,8,115,82,7,31,0,8,112,0,8,48,0,9,192,80,7,10,0,8,96,0,8,32,0,9,160,0,8,0,0,8,128,0,8,64,0,9,224,80,7,6,0,8,88,0,8,24,0,9,144,83,7,59,0,8,120,0,8,56,0,9,208,81,7,17,0,8,104,0,8,40,0,9,176,0,8,8,0,8,136,0,8,72,0,9,240,80,7,4,0,8,84,0,8,20,85,8,227,83,7,43,0,8,116,0,8,52,0,9,200,81,7,13,0,8,100,0,8,36,0,9,168,0,8,4,0,8,132,0,8,68,0,9,232,80,7,8,0,8,92,0,8,28,0,9,152,84,7,83,0,8,124,0,8,60,0,9,216,82,7,23,0,8,108,0,8,44,0,9,184,0,8,12,0,8,140,0,8,76,0,9,248,80,7,3,0,8,82,0,8,18,85,8,163,83,7,35,0,8,114,0,8,50,0,9,196,81,7,11,0,8,98,0,8,34,0,9,164,0,8,2,0,8,130,0,8,66,0,9,228,80,7,7,0,8,90,0,8,26,0,9,148,84,7,67,0,8,122,0,8,58,0,9,212,82,7,19,0,8,106,0,8,42,0,9,180,0,8,10,0,8,138,0,8,74,0,9,244,80,7,5,0,8,86,0,8,22,192,8,0,83,7,51,0,8,118,0,8,54,0,9,204,81,7,15,0,8,102,0,8,38,0,9,172,0,8,6,0,8,134,0,8,70,0,9,236,80,7,9,0,8,94,0,8,30,0,9,156,84,7,99,0,8,126,0,8,62,0,9,220,82,7,27,0,8,110,0,8,46,0,9,188,0,8,14,0,8,142,0,8,78,0,9,252,96,7,256,0,8,81,0,8,17,85,8,131,82,7,31,0,8,113,0,8,49,0,9,194,80,7,10,0,8,97,0,8,33,0,9,162,0,8,1,0,8,129,0,8,65,0,9,226,80,7,6,0,8,89,0,8,25,0,9,146,83,7,59,0,8,121,0,8,57,0,9,210,81,7,17,0,8,105,0,8,41,0,9,178,0,8,9,0,8,137,0,8,73,0,9,242,80,7,4,0,8,85,0,8,21,80,8,258,83,7,43,0,8,117,0,8,53,0,9,202,81,7,13,0,8,101,0,8,37,0,9,170,0,8,5,0,8,133,0,8,69,0,9,234,80,7,8,0,8,93,0,8,29,0,9,154,84,7,83,0,8,125,0,8,61,0,9,218,82,7,23,0,8,109,0,8,45,0,9,186,0,8,13,0,8,141,0,8,77,0,9,250,80,7,3,0,8,83,0,8,19,85,8,195,83,7,35,0,8,115,0,8,51,0,9,198,81,7,11,0,8,99,0,8,35,0,9,166,0,8,3,0,8,131,0,8,67,0,9,230,80,7,7,0,8,91,0,8,27,0,9,150,84,7,67,0,8,123,0,8,59,0,9,214,82,7,19,0,8,107,0,8,43,0,9,182,0,8,11,0,8,139,0,8,75,0,9,246,80,7,5,0,8,87,0,8,23,192,8,0,83,7,51,0,8,119,0,8,55,0,9,206,81,7,15,0,8,103,0,8,39,0,9,174,0,8,7,0,8,135,0,8,71,0,9,238,80,7,9,0,8,95,0,8,31,0,9,158,84,7,99,0,8,127,0,8,63,0,9,222,82,7,27,0,8,111,0,8,47,0,9,190,0,8,15,0,8,143,0,8,79,0,9,254,96,7,256,0,8,80,0,8,16,84,8,115,82,7,31,0,8,112,0,8,48,0,9,193,80,7,10,0,8,96,0,8,32,0,9,161,0,8,0,0,8,128,0,8,64,0,9,225,80,7,6,0,8,88,0,8,24,0,9,145,83,7,59,0,8,120,0,8,56,0,9,209,81,7,17,0,8,104,0,8,40,0,9,177,0,8,8,0,8,136,0,8,72,0,9,241,80,7,4,0,8,84,0,8,20,85,8,227,83,7,43,0,8,116,0,8,52,0,9,201,81,7,13,0,8,100,0,8,36,0,9,169,0,8,4,0,8,132,0,8,68,0,9,233,80,7,8,0,8,92,0,8,28,0,9,153,84,7,83,0,8,124,0,8,60,0,9,217,82,7,23,0,8,108,0,8,44,0,9,185,0,8,12,0,8,140,0,8,76,0,9,249,80,7,3,0,8,82,0,8,18,85,8,163,83,7,35,0,8,114,0,8,50,0,9,197,81,7,11,0,8,98,0,8,34,0,9,165,0,8,2,0,8,130,0,8,66,0,9,229,80,7,7,0,8,90,0,8,26,0,9,149,84,7,67,0,8,122,0,8,58,0,9,213,82,7,19,0,8,106,0,8,42,0,9,181,0,8,10,0,8,138,0,8,74,0,9,245,80,7,5,0,8,86,0,8,22,192,8,0,83,7,51,0,8,118,0,8,54,0,9,205,81,7,15,0,8,102,0,8,38,0,9,173,0,8,6,0,8,134,0,8,70,0,9,237,80,7,9,0,8,94,0,8,30,0,9,157,84,7,99,0,8,126,0,8,62,0,9,221,82,7,27,0,8,110,0,8,46,0,9,189,0,8,14,0,8,142,0,8,78,0,9,253,96,7,256,0,8,81,0,8,17,85,8,131,82,7,31,0,8,113,0,8,49,0,9,195,80,7,10,0,8,97,0,8,33,0,9,163,0,8,1,0,8,129,0,8,65,0,9,227,80,7,6,0,8,89,0,8,25,0,9,147,83,7,59,0,8,121,0,8,57,0,9,211,81,7,17,0,8,105,0,8,41,0,9,179,0,8,9,0,8,137,0,8,73,0,9,243,80,7,4,0,8,85,0,8,21,80,8,258,83,7,43,0,8,117,0,8,53,0,9,203,81,7,13,0,8,101,0,8,37,0,9,171,0,8,5,0,8,133,0,8,69,0,9,235,80,7,8,0,8,93,0,8,29,0,9,155,84,7,83,0,8,125,0,8,61,0,9,219,82,7,23,0,8,109,0,8,45,0,9,187,0,8,13,0,8,141,0,8,77,0,9,251,80,7,3,0,8,83,0,8,19,85,8,195,83,7,35,0,8,115,0,8,51,0,9,199,81,7,11,0,8,99,0,8,35,0,9,167,0,8,3,0,8,131,0,8,67,0,9,231,80,7,7,0,8,91,0,8,27,0,9,151,84,7,67,0,8,123,0,8,59,0,9,215,82,7,19,0,8,107,0,8,43,0,9,183,0,8,11,0,8,139,0,8,75,0,9,247,80,7,5,0,8,87,0,8,23,192,8,0,83,7,51,0,8,119,0,8,55,0,9,207,81,7,15,0,8,103,0,8,39,0,9,175,0,8,7,0,8,135,0,8,71,0,9,239,80,7,9,0,8,95,0,8,31,0,9,159,84,7,99,0,8,127,0,8,63,0,9,223,82,7,27,0,8,111,0,8,47,0,9,191,0,8,15,0,8,143,0,8,79,0,9,255],lfe=[80,5,1,87,5,257,83,5,17,91,5,4097,81,5,5,89,5,1025,85,5,65,93,5,16385,80,5,3,88,5,513,84,5,33,92,5,8193,82,5,9,90,5,2049,86,5,129,192,5,24577,80,5,2,87,5,385,83,5,25,91,5,6145,81,5,7,89,5,1537,85,5,97,93,5,24577,80,5,4,88,5,769,84,5,49,92,5,12289,82,5,13,90,5,3073,86,5,193,192,5,24577],rfe=[3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258,0,0],dfe=[0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,112,112],cfe=[1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577],mfe=[0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13],MF=15;function Ynt(){let t=this,e,n,i,o,a,s;function l(d,m,h,Z,b,u,F,U,G,A,T){let g,C,y,Y,Q,J,M,V,E,I,B,X,_,P,w;I=0,Q=h;do i[d[m+I]]++,I++,Q--;while(Q!==0);if(i[0]==h)return F[0]=-1,U[0]=0,0;for(V=U[0],J=1;J<=MF&&i[J]===0;J++);for(M=J,VQ&&(V=Q),U[0]=V,P=1<X+V;){if(Y++,X+=V,w=y-X,w=w>V?V:w,(C=1<<(J=M-X))>g+1&&(C-=g+1,_=M,JSgt)return-3;a[Y]=B=A[0],A[0]+=w,Y!==0?(s[Y]=Q,o[0]=J,o[1]=V,J=Q>>>X-V,o[2]=B-a[Y-1]-J,G.set(o,(a[Y-1]+J)*3)):F[0]=B}for(o[1]=M-X,I>=h?o[0]=192:T[I]>>X;J>>=1)Q^=J;for(Q^=J,E=(1<257?(A==-3?G.msg="oversubscribed distance tree":A==-5?(G.msg="incomplete distance tree",A=-3):A!=-4&&(G.msg="empty distance tree with lengths",A=-3),A):0)}}Ynt.inflate_trees_fixed=function(t,e,n,i){return t[0]=ofe,e[0]=afe,n[0]=sfe,i[0]=lfe,0};var Nv=0,lgt=1,rgt=2,dgt=3,cgt=4,mgt=5,hgt=6,Bnt=7,pgt=8,yv=9;function hfe(){let t=this,e,n=0,i,o=0,a=0,s=0,l=0,r=0,d=0,m=0,h,Z=0,b,u=0;function F(U,G,A,T,g,C,y,Y){let Q,J,M,V,E,I,B,X,_,P,w,z,H,nt,$,dt;B=Y.next_in_index,X=Y.avail_in,E=y.bitb,I=y.bitk,_=y.write,P=_>=J[dt+1],I-=J[dt+1],y.win[_++]=J[dt+2],P--;continue}do{if(E>>=J[dt+1],I-=J[dt+1],V&16){for(V&=15,H=J[dt+2]+(E&Ph[V]),E>>=V,I-=V;I<15;)X--,E|=(Y.read_byte(B++)&255)<>=J[dt+1],I-=J[dt+1],V&16){for(V&=15;I>=V,I-=V,P-=H,_>=nt)$=_-nt,_-$>0&&2>_-$?(y.win[_++]=y.win[$++],y.win[_++]=y.win[$++],H-=2):(y.win.set(y.win.subarray($,$+2),_),_+=2,$+=2,H-=2);else{$=_-nt;do $+=y.end;while($<0);if(V=y.end-$,H>V){if(H-=V,_-$>0&&V>_-$)do y.win[_++]=y.win[$++];while(--V!==0);else y.win.set(y.win.subarray($,$+V),_),_+=V,$+=V,V=0;$=0}}if(_-$>0&&H>_-$)do y.win[_++]=y.win[$++];while(--H!==0);else y.win.set(y.win.subarray($,$+H),_),_+=H,$+=H,H=0;break}else if(!(V&64))Q+=J[dt+2],Q+=E&Ph[V],dt=(M+Q)*3,V=J[dt];else return Y.msg="invalid distance code",H=Y.avail_in-X,H=I>>3>3:H,X+=H,B-=H,I-=H<<3,y.bitb=E,y.bitk=I,Y.avail_in=X,Y.total_in+=B-Y.next_in_index,Y.next_in_index=B,y.write=_,-3;while(!0);break}if(V&64)return V&32?(H=Y.avail_in-X,H=I>>3>3:H,X+=H,B-=H,I-=H<<3,y.bitb=E,y.bitk=I,Y.avail_in=X,Y.total_in+=B-Y.next_in_index,Y.next_in_index=B,y.write=_,1):(Y.msg="invalid literal/length code",H=Y.avail_in-X,H=I>>3>3:H,X+=H,B-=H,I-=H<<3,y.bitb=E,y.bitk=I,Y.avail_in=X,Y.total_in+=B-Y.next_in_index,Y.next_in_index=B,y.write=_,-3);if(Q+=J[dt+2],Q+=E&Ph[V],dt=(M+Q)*3,(V=J[dt])===0){E>>=J[dt+1],I-=J[dt+1],y.win[_++]=J[dt+2],P--;break}}while(!0)}while(P>=258&&X>=10);return H=Y.avail_in-X,H=I>>3>3:H,X+=H,B-=H,I-=H<<3,y.bitb=E,y.bitk=I,Y.avail_in=X,Y.total_in+=B-Y.next_in_index,Y.next_in_index=B,y.write=_,0}t.init=function(U,G,A,T,g,C){e=Nv,d=U,m=G,h=A,Z=T,b=g,u=C,i=null},t.proc=function(U,G,A){let T,g,C,y=0,Y=0,Q=0,J,M,V,E;for(Q=G.next_in_index,J=G.avail_in,y=U.bitb,Y=U.bitk,M=U.write,V=M=258&&J>=10&&(U.bitb=y,U.bitk=Y,G.avail_in=J,G.total_in+=Q-G.next_in_index,G.next_in_index=Q,U.write=M,A=F(d,m,h,Z,b,u,U,G),Q=G.next_in_index,J=G.avail_in,y=U.bitb,Y=U.bitk,M=U.write,V=M>>=i[g+1],Y-=i[g+1],C=i[g],C===0){s=i[g+2],e=hgt;break}if(C&16){l=C&15,n=i[g+2],e=rgt;break}if(!(C&64)){a=C,o=g/3+i[g+2];break}if(C&32){e=Bnt;break}return e=yv,G.msg="invalid literal/length code",A=-3,U.bitb=y,U.bitk=Y,G.avail_in=J,G.total_in+=Q-G.next_in_index,G.next_in_index=Q,U.write=M,U.inflate_flush(G,A);case rgt:for(T=l;Y>=T,Y-=T,a=m,i=b,o=u,e=dgt;case dgt:for(T=a;Y>=i[g+1],Y-=i[g+1],C=i[g],C&16){l=C&15,r=i[g+2],e=cgt;break}if(!(C&64)){a=C,o=g/3+i[g+2];break}return e=yv,G.msg="invalid distance code",A=-3,U.bitb=y,U.bitk=Y,G.avail_in=J,G.total_in+=Q-G.next_in_index,G.next_in_index=Q,U.write=M,U.inflate_flush(G,A);case cgt:for(T=l;Y>=T,Y-=T,e=mgt;case mgt:for(E=M-r;E<0;)E+=U.end;for(;n!==0;){if(V===0&&(M==U.end&&U.read!==0&&(M=0,V=M7&&(Y-=8,J++,Q--),U.write=M,A=U.inflate_flush(G,A),M=U.write,V=MF.avail_out&&(G=F.avail_out),G!==0&&U==-5&&(U=0),F.avail_out-=G,F.total_out+=G,F.next_out.set(n.win.subarray(T,T+G),A),A+=G,T+=G,T==n.end&&(T=0,n.write==n.end&&(n.write=0),G=n.write-T,G>F.avail_out&&(G=F.avail_out),G!==0&&U==-5&&(U=0),F.avail_out-=G,F.total_out+=G,F.next_out.set(n.win.subarray(T,T+G),A),A+=G,T+=G),F.next_out_index=A,n.read=T,U},n.proc=function(F,U){let G,A,T,g,C,y,Y,Q;for(g=F.next_in_index,C=F.avail_in,A=n.bitb,T=n.bitk,y=n.write,Y=y>>1){case 0:A>>>=3,T-=3,G=T&7,A>>>=G,T-=G,i=Qnt;break;case 1:J=[],M=[],V=[[]],E=[[]],Ynt.inflate_trees_fixed(J,M,V,E),m.init(J[0],M[0],V[0],0,E[0],0),A>>>=3,T-=3,i=Bv;break;case 2:A>>>=3,T-=3,i=Vgt;break;case 3:return A>>>=3,T-=3,i=BT,F.msg="invalid block type",U=-3,n.bitb=A,n.bitk=T,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U)}break;case Qnt:for(;T<32;){if(C!==0)U=0;else return n.bitb=A,n.bitk=T,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);C--,A|=(F.read_byte(g++)&255)<>>16&65535)!=(A&65535))return i=BT,F.msg="invalid stored block lengths",U=-3,n.bitb=A,n.bitk=T,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);o=A&65535,A=T=0,i=o!==0?Zgt:h!==0?Qv:yI;break;case Zgt:if(C===0||Y===0&&(y==n.end&&n.read!==0&&(y=0,Y=yC&&(G=C),G>Y&&(G=Y),n.win.set(F.read_buf(g,G),y),g+=G,C-=G,y+=G,Y-=G,(o-=G)!==0)break;i=h!==0?Qv:yI;break;case Vgt:for(;T<14;){if(C!==0)U=0;else return n.bitb=A,n.bitk=T,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);C--,A|=(F.read_byte(g++)&255)<29||(G>>5&31)>29)return i=BT,F.msg="too many length or distance symbols",U=-3,n.bitb=A,n.bitk=T,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);if(G=258+(G&31)+(G>>5&31),!l||l.length>>=14,T-=14,s=0,i=bgt;case bgt:for(;s<4+(a>>>10);){for(;T<3;){if(C!==0)U=0;else return n.bitb=A,n.bitk=T,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);C--,A|=(F.read_byte(g++)&255)<>>=3,T-=3}for(;s<19;)l[ugt[s++]]=0;if(r[0]=7,G=u.inflate_trees_bits(l,r,d,Z,F),G!=0)return U=G,U==-3&&(l=null,i=BT),n.bitb=A,n.bitk=T,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);s=0,i=Rgt;case Rgt:for(;G=a,!(s>=258+(G&31)+(G>>5&31));){let P,w;for(G=r[0];T>>=G,T-=G,l[s++]=w;else{for(Q=w==18?7:w-14,P=w==18?11:3;T>>=G,T-=G,P+=A&Ph[Q],A>>>=Q,T-=Q,Q=s,G=a,Q+P>258+(G&31)+(G>>5&31)||w==16&&Q<1)return l=null,i=BT,F.msg="invalid bit length repeat",U=-3,n.bitb=A,n.bitk=T,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);w=w==16?l[Q-1]:0;do l[Q++]=w;while(--P!==0);s=Q}}if(d[0]=-1,I=[],B=[],X=[],_=[],I[0]=9,B[0]=6,G=a,G=u.inflate_trees_dynamic(257+(G&31),1+(G>>5&31),l,I,B,X,_,Z,F),G!=0)return G==-3&&(l=null,i=BT),U=G,n.bitb=A,n.bitk=T,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);m.init(I[0],B[0],Z,X[0],Z,_[0]),i=Bv;case Bv:if(n.bitb=A,n.bitk=T,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,(U=m.proc(n,F,U))!=1)return n.inflate_flush(F,U);if(U=0,m.free(F),g=F.next_in_index,C=F.avail_in,A=n.bitb,T=n.bitk,y=n.write,Y=y15?(t.inflateEnd(n),-2):(t.wbits=i,n.istate.blocks=new pfe(n,1<>4)+8>s.wbits){s.mode=_F,n.msg="invalid win size",s.marker=5;break}s.mode=fgt;case fgt:if(n.avail_in===0)return o;if(o=i,n.avail_in--,n.total_in++,a=n.read_byte(n.next_in_index++)&255,((s.method<<8)+a)%31!==0){s.mode=_F,n.msg="incorrect header check",s.marker=5;break}if(!(a&ufe)){s.mode=kL;break}s.mode=Fgt;case Fgt:if(n.avail_in===0)return o;o=i,n.avail_in--,n.total_in++,s.need=(n.read_byte(n.next_in_index++)&255)<<24&4278190080,s.mode=Ugt;case Ugt:if(n.avail_in===0)return o;o=i,n.avail_in--,n.total_in++,s.need+=(n.read_byte(n.next_in_index++)&255)<<16&16711680,s.mode=Ggt;case Ggt:if(n.avail_in===0)return o;o=i,n.avail_in--,n.total_in++,s.need+=(n.read_byte(n.next_in_index++)&255)<<8&65280,s.mode=Agt;case Agt:return n.avail_in===0?o:(o=i,n.avail_in--,n.total_in++,s.need+=n.read_byte(n.next_in_index++)&255,s.mode=knt,2);case knt:return s.mode=_F,n.msg="need dictionary",s.marker=0,-2;case kL:if(o=s.blocks.proc(n,o),o==-3){s.mode=_F,s.marker=0;break}if(o==0&&(o=i),o!=1)return o;o=i,s.blocks.reset(n,s.was),s.mode=Tgt;case Tgt:return n.avail_in=0,1;case _F:return-3;default:return-2}},t.inflateSetDictionary=function(n,i,o){let a=0,s=o;if(!n||!n.istate||n.istate.mode!=knt)return-2;let l=n.istate;return s>=1<0&&n.next_in_index!=Z&&(r(n.next_in_index),Z=n.next_in_index)}while(n.avail_in>0||n.avail_out===0);return d.length>1?(h=new Uint8Array(u),d.forEach(function(F){h.set(F,b),b+=F.length})):h=d[0]?new Uint8Array(d[0]):new Uint8Array,h}},e.flush=function(){n.inflateEnd()}}var nYi=R(W(),1);var Kki=R(W(),1);var BI="/",xnt=new Date(2107,11,31),Xnt=new Date(1980,0,1),Ka=void 0,vh="undefined",tW="function";var jki=R(W(),1);var YL=class{constructor(e){return class extends TransformStream{constructor(n,i){let o=new e(i);super({transform(a,s){s.enqueue(o.append(a))},flush(a){let s=o.flush();s&&a.enqueue(s)}})}}}};var Wfe=64,Cgt=2;try{typeof navigator!=vh&&navigator.hardwareConcurrency&&(Cgt=navigator.hardwareConcurrency)}catch{}var ffe={chunkSize:512*1024,maxWorkers:Cgt,terminateWorkerTimeout:5e3,useWebWorkers:!0,useCompressionStream:!0,workerScripts:Ka,CompressionStreamNative:typeof CompressionStream!=vh&&CompressionStream,DecompressionStreamNative:typeof DecompressionStream!=vh&&DecompressionStream},OF=Object.assign({},ffe);function xL(){return OF}function kv(t){return Math.max(t.chunkSize,Wfe)}function QI(t){let{baseURL:e,chunkSize:n,maxWorkers:i,terminateWorkerTimeout:o,useCompressionStream:a,useWebWorkers:s,Deflate:l,Inflate:r,CompressionStream:d,DecompressionStream:m,workerScripts:h}=t;if(DF("baseURL",e),DF("chunkSize",n),DF("maxWorkers",i),DF("terminateWorkerTimeout",o),DF("useCompressionStream",a),DF("useWebWorkers",s),l&&(OF.CompressionStream=new YL(l)),r&&(OF.DecompressionStream=new YL(r)),DF("CompressionStream",d),DF("DecompressionStream",m),h!==Ka){let{deflate:Z,inflate:b}=h;if((Z||b)&&(OF.workerScripts||(OF.workerScripts={})),Z){if(!Array.isArray(Z))throw new Error("workerScripts.deflate must be an array");OF.workerScripts.deflate=Z}if(b){if(!Array.isArray(b))throw new Error("workerScripts.inflate must be an array");OF.workerScripts.inflate=b}}}function DF(t,e){e!==Ka&&(OF[t]=e)}var oYi=R(W(),1);var zYi=R(W(),1);var MYi=R(W(),1);var XYi=R(W(),1);var dYi=R(W(),1);var sYi=R(W(),1),Igt=[];for(let t=0;t<256;t++){let e=t;for(let n=0;n<8;n++)e&1?e=e>>>1^3988292384:e=e>>>1;Igt[t]=e}var eW=class{constructor(e){this.crc=e||-1}append(e){let n=this.crc|0;for(let i=0,o=e.length|0;i>>8^Igt[(n^e[i])&255];this.crc=n}get(){return~this.crc}};var XL=class extends TransformStream{constructor(){let e,n=new eW;super({transform(i,o){n.append(i),o.enqueue(i)},flush(){let i=new Uint8Array(4);new DataView(i.buffer).setUint32(0,n.get()),e.value=i}}),e=this}};var EYi=R(W(),1);var hYi=R(W(),1);function Yv(t){if(typeof TextEncoder==vh){t=unescape(encodeURIComponent(t));let e=new Uint8Array(t.length);for(let n=0;n0&&e&&(t[n-1]=Kc.partial(e,t[n-1]&2147483648>>e-1,1)),t},partial(t,e,n){return t===32?e:(n?e|0:e<<32-t)+t*1099511627776},getPartial(t){return Math.round(t/1099511627776)||32},_shiftRight(t,e,n,i){for(i===void 0&&(i=[]);e>=32;e-=32)i.push(n),n=0;if(e===0)return i.concat(t);for(let s=0;s>>e),n=t[s]<<32-e;let o=t.length?t[t.length-1]:0,a=Kc.getPartial(o);return i.push(Kc.partial(e+a&31,e+a>32?n:i.pop(),1)),i}},JL={bytes:{fromBits(t){let n=Kc.bitLength(t)/8,i=new Uint8Array(n),o;for(let a=0;a>>24,o<<=8;return i},toBits(t){let e=[],n,i=0;for(n=0;n9007199254740991)throw new Error("Cannot hash more than 2^53 - 1 bits");let a=new Uint32Array(n),s=0;for(let l=e.blockSize+i-(e.blockSize+i&e.blockSize-1);l<=o;l+=e.blockSize)e._block(a.subarray(16*s,16*(s+1))),s+=1;return n.splice(0,16*s),e}finalize(){let t=this,e=t._buffer,n=t._h;e=Kc.concat(e,[Kc.partial(1,1)]);for(let i=e.length+2;i&15;i++)e.push(0);for(e.push(Math.floor(t._length/4294967296)),e.push(t._length|0);e.length;)t._block(e.splice(0,16));return t.reset(),n}_f(t,e,n,i){if(t<=19)return e&n|~e&i;if(t<=39)return e^n^i;if(t<=59)return e&n|e&i|n&i;if(t<=79)return e^n^i}_S(t,e){return e<>>32-t}_block(t){let e=this,n=e._h,i=Array(80);for(let d=0;d<16;d++)i[d]=t[d];let o=n[0],a=n[1],s=n[2],l=n[3],r=n[4];for(let d=0;d<=79;d++){d>=16&&(i[d]=e._S(1,i[d-3]^i[d-8]^i[d-14]^i[d-16]));let m=e._S(5,o)+e._f(d,a,s,l)+r+i[d]+e._key[Math.floor(d/20)]|0;r=l,l=s,s=e._S(30,a),a=o,o=m}n[0]=n[0]+o|0,n[1]=n[1]+a|0,n[2]=n[2]+s|0,n[3]=n[3]+l|0,n[4]=n[4]+r|0}};var Jnt={};Jnt.aes=class{constructor(t){let e=this;e._tables=[[[],[],[],[],[]],[[],[],[],[],[]]],e._tables[0][0][0]||e._precompute();let n=e._tables[0][4],i=e._tables[1],o=t.length,a,s,l,r=1;if(o!==4&&o!==6&&o!==8)throw new Error("invalid aes key size");for(e._key=[s=t.slice(0),l=[]],a=o;a<4*o+28;a++){let d=s[a-1];(a%o===0||o===8&&a%o===4)&&(d=n[d>>>24]<<24^n[d>>16&255]<<16^n[d>>8&255]<<8^n[d&255],a%o===0&&(d=d<<8^d>>>24^r<<24,r=r<<1^(r>>7)*283)),s[a]=s[a-o]^d}for(let d=0;a;d++,a--){let m=s[d&3?a:a-4];a<=4||d<4?l[d]=m:l[d]=i[0][n[m>>>24]]^i[1][n[m>>16&255]]^i[2][n[m>>8&255]]^i[3][n[m&255]]}}encrypt(t){return this._crypt(t,0)}decrypt(t){return this._crypt(t,1)}_precompute(){let t=this._tables[0],e=this._tables[1],n=t[4],i=e[4],o=[],a=[],s,l,r,d;for(let m=0;m<256;m++)a[(o[m]=m<<1^(m>>7)*283)^m]=m;for(let m=s=0;!n[m];m^=l||1,s=a[s]||1){let h=s^s<<1^s<<2^s<<3^s<<4;h=h>>8^h&255^99,n[m]=h,i[h]=m,d=o[r=o[l=o[m]]];let Z=d*16843009^r*65537^l*257^m*16843008,b=o[h]*257^h*16843008;for(let u=0;u<4;u++)t[u][m]=b=b<<24^b>>>8,e[u][h]=Z=Z<<24^Z>>>8}for(let m=0;m<5;m++)t[m]=t[m].slice(0),e[m]=e[m].slice(0)}_crypt(t,e){if(t.length!==4)throw new Error("invalid aes block size");let n=this._key[e],i=n.length/4-2,o=[0,0,0,0],a=this._tables[e],s=a[0],l=a[1],r=a[2],d=a[3],m=a[4],h=t[0]^n[0],Z=t[e?3:1]^n[1],b=t[2]^n[2],u=t[e?1:3]^n[3],F=4,U,G,A;for(let T=0;T>>24]^l[Z>>16&255]^r[b>>8&255]^d[u&255]^n[F],G=s[Z>>>24]^l[b>>16&255]^r[u>>8&255]^d[h&255]^n[F+1],A=s[b>>>24]^l[u>>16&255]^r[h>>8&255]^d[Z&255]^n[F+2],u=s[u>>>24]^l[h>>16&255]^r[Z>>8&255]^d[b&255]^n[F+3],F+=4,h=U,Z=G,b=A;for(let T=0;T<4;T++)o[e?3&-T:T]=m[h>>>24]<<24^m[Z>>16&255]<<16^m[b>>8&255]<<8^m[u&255]^n[F++],U=h,h=Z,Z=b,b=u,u=U;return o}};var ygt={getRandomValues(t){let e=new Uint32Array(t.buffer),n=i=>{let o=987654321,a=4294967295;return function(){return o=36969*(o&65535)+(o>>16)&a,i=18e3*(i&65535)+(i>>16)&a,(((o<<16)+i&a)/4294967296+.5)*(Math.random()>.5?1:-1)}};for(let i=0,o;i>24&255)===255){let e=t>>16&255,n=t>>8&255,i=t&255;e===255?(e=0,n===255?(n=0,i===255?i=0:++i):++n):++e,t=0,t+=e<<16,t+=n<<8,t+=i}else t+=1<<24;return t}incCounter(t){(t[0]=this.incWord(t[0]))===0&&(t[1]=this.incWord(t[1]))}calculate(t,e,n){let i;if(!(i=e.length))return[];let o=Kc.bitLength(e);for(let a=0;a>5)+1<<2,a,s,l,r,d,m=new ArrayBuffer(o),h=new DataView(m),Z=0,b=Kc;for(e=JL.bytes.toBits(e),d=1;Z<(o||1);d++){for(a=s=t.encrypt(b.concat(e,[d])),l=1;lo&&(t=new n().update(t).finalize());for(let a=0;athis.resolveReady=s),password:Jgt(e,n),signed:i,strength:o-1,pending:new Uint8Array})},async transform(s,l){let r=this,{password:d,strength:m,resolveReady:h,ready:Z}=r;d?(await Nfe(r,m,d,bu(s,0,ML[m]+2)),s=bu(s,ML[m]+2),a?l.error(new Error(nW)):h()):await Z;let b=new Uint8Array(s.length-PF-(s.length-PF)%kI);l.enqueue(xgt(r,s,b,0,PF,!0))},async flush(s){let{signed:l,ctr:r,hmac:d,pending:m,ready:h}=this;if(d&&r){await h;let Z=bu(m,0,m.length-PF),b=bu(m,m.length-PF),u=new Uint8Array;if(Z.length){let F=DL(Gb,Z);d.update(F);let U=r.update(F);u=_L(Gb,U)}if(l){let F=bu(_L(Gb,d.digest()),0,PF);for(let U=0;Uthis.resolveReady=a),password:Jgt(e,n),strength:i-1,pending:new Uint8Array})},async transform(a,s){let l=this,{password:r,strength:d,resolveReady:m,ready:h}=l,Z=new Uint8Array;r?(Z=await yfe(l,d,r),m()):await h;let b=new Uint8Array(Z.length+a.length-a.length%kI);b.set(Z,0),s.enqueue(xgt(l,a,b,Z.length,0))},async flush(a){let{ctr:s,hmac:l,pending:r,ready:d}=this;if(l&&s){await d;let m=new Uint8Array;if(r.length){let h=s.update(DL(Gb,r));l.update(h),m=_L(Gb,h)}o.signature=_L(Gb,l.digest()).slice(0,PF),a.enqueue(_nt(m,o.signature))}}}),o=this}};function xgt(t,e,n,i,o,a){let{ctr:s,hmac:l,pending:r}=t,d=e.length-o;r.length&&(e=_nt(r,e),n=kfe(n,d-d%kI));let m;for(m=0;m<=d-kI;m+=kI){let h=DL(Gb,bu(e,m,m+kI));a&&l.update(h);let Z=s.update(h);a||l.update(Z),n.set(_L(Gb,Z),m+i)}return t.pending=bu(e,m),n}async function Nfe(t,e,n,i){let o=await Xgt(t,e,n,bu(i,0,ML[e])),a=bu(i,ML[e]);if(o[0]!=a[0]||o[1]!=a[1])throw new Error(wF)}async function yfe(t,e,n){let i=xv(new Uint8Array(ML[e])),o=await Xgt(t,e,n,i);return _nt(i,o)}async function Xgt(t,e,n,i){t.password=null;let o=await Bfe(Ufe,n,Tfe,!1,Sfe),a=await Qfe(Object.assign({salt:i},Mnt),o,8*(LL[e]*2+2)),s=new Uint8Array(a),l=DL(Gb,bu(s,0,LL[e])),r=DL(Gb,bu(s,LL[e],LL[e]*2)),d=bu(s,LL[e]*2);return Object.assign(t,{keys:{key:l,authentication:r,passwordVerification:d},ctr:new Cfe(new Efe(l),Array.from(gfe)),hmac:new Ife(r)}),d}async function Bfe(t,e,n,i,o){if(Bgt)try{return await OL.importKey(t,e,n,i,o)}catch{return Bgt=!1,HF.importKey(e)}else return HF.importKey(e)}async function Qfe(t,e,n){if(Qgt)try{return await OL.deriveBits(t,e,n)}catch{return Qgt=!1,HF.pbkdf2(e,t.salt,Mnt.iterations,n)}else return HF.pbkdf2(e,t.salt,Mnt.iterations,n)}function Jgt(t,e){return e===Ka?Yv(t):e}function _nt(t,e){let n=t;return t.length+e.length&&(n=new Uint8Array(t.length+e.length),n.set(t,0),n.set(e,t.length)),n}function kfe(t,e){if(e&&e>t.length){let n=t;t=new Uint8Array(e),t.set(n,0)}return t}function bu(t,e,n){return t.subarray(e,n)}function _L(t,e){return t.fromBits(e)}function DL(t,e){return t.toBits(e)}var yYi=R(W(),1);var YI=12,Mv=class extends TransformStream{constructor({password:e,passwordVerification:n,checkPasswordOnly:i}){super({start(){Object.assign(this,{password:e,passwordVerification:n}),Dgt(this,e)},transform(o,a){let s=this;if(s.password){let l=Lgt(s,o.subarray(0,YI));if(s.password=null,l[YI-1]!=s.passwordVerification)throw new Error(wF);o=o.subarray(YI)}i?a.error(new Error(nW)):a.enqueue(Lgt(s,o))}})}},_v=class extends TransformStream{constructor({password:e,passwordVerification:n}){super({start(){Object.assign(this,{password:e,passwordVerification:n}),Dgt(this,e)},transform(i,o){let a=this,s,l;if(a.password){a.password=null;let r=xv(new Uint8Array(YI));r[YI-1]=a.passwordVerification,s=new Uint8Array(i.length+r.length),s.set(Mgt(a,r),0),l=YI}else s=new Uint8Array(i.length),l=0;s.set(Mgt(a,i),l),o.enqueue(s)}})}};function Lgt(t,e){let n=new Uint8Array(e.length);for(let i=0;i>>24]),o=~t.crcKey2.get(),t.keys=[n,i,o]}function Ogt(t){let e=t.keys[2]|2;return Hgt(Math.imul(e,e^1)>>>8)}function Hgt(t){return t&255}function _gt(t){return t&4294967295}var wgt="deflate-raw",Dv=class extends TransformStream{constructor(e,{chunkSize:n,CompressionStream:i,CompressionStreamNative:o}){super({});let{compressed:a,encrypted:s,useCompressionStream:l,zipCrypto:r,signed:d,level:m}=e,h=this,Z,b,u=Pgt(super.readable);(!s||r)&&d&&(Z=new XL,u=Ab(u,Z)),a&&(u=Kgt(u,l,{level:m,chunkSize:n},o,i)),s&&(r?u=Ab(u,new _v(e)):(b=new Jv(e),u=Ab(u,b))),vgt(h,u,()=>{let F;s&&!r&&(F=b.signature),(!s||r)&&d&&(F=new DataView(Z.value.buffer).getUint32(0)),h.signature=F})}},Ov=class extends TransformStream{constructor(e,{chunkSize:n,DecompressionStream:i,DecompressionStreamNative:o}){super({});let{zipCrypto:a,encrypted:s,signed:l,signature:r,compressed:d,useCompressionStream:m}=e,h,Z,b=Pgt(super.readable);s&&(a?b=Ab(b,new Mv(e)):(Z=new Xv(e),b=Ab(b,Z))),d&&(b=Kgt(b,m,{chunkSize:n},o,i)),(!s||a)&&l&&(h=new XL,b=Ab(b,h)),vgt(this,b,()=>{if((!s||a)&&l){let u=new DataView(h.value.buffer);if(r!=u.getUint32(0,!1))throw new Error(QT)}})}};function Pgt(t){return Ab(t,new TransformStream({transform(e,n){e&&e.length&&n.enqueue(e)}}))}function vgt(t,e,n){e=Ab(e,new TransformStream({flush:n})),Object.defineProperty(t,"readable",{get(){return e}})}function Kgt(t,e,n,i,o){try{let a=e&&i?i:o;t=Ab(t,new a(wgt,n))}catch{if(e)try{t=Ab(t,new o(wgt,n))}catch{return t}else return t}return t}function Ab(t,e){return t.pipeThrough(e)}var zgt="message",jgt="start",qgt="pull",Ont="data",$gt="ack",Hnt="close",Pv="deflate",vv="inflate";var Hv=class extends TransformStream{constructor(e,n){super({});let i=this,{codecType:o}=e,a;o.startsWith(Pv)?a=Dv:o.startsWith(vv)&&(a=Ov);let s=0,l=0,r=new a(e,n),d=super.readable,m=new TransformStream({transform(Z,b){Z&&Z.length&&(l+=Z.length,b.enqueue(Z))},flush(){Object.assign(i,{inputSize:l})}}),h=new TransformStream({transform(Z,b){Z&&Z.length&&(s+=Z.length,b.enqueue(Z))},flush(){let{signature:Z}=r;Object.assign(i,{signature:Z,outputSize:s,inputSize:l})}});Object.defineProperty(i,"readable",{get(){return d.pipeThrough(m).pipeThrough(r).pipeThrough(h)}})}},wv=class extends TransformStream{constructor(e){let n;super({transform:i,flush(o){n&&n.length&&o.enqueue(n)}});function i(o,a){if(n){let s=new Uint8Array(n.length+o.length);s.set(n),s.set(o,n.length),o=s,n=null}o.length>e?(a.enqueue(o.slice(0,e)),i(o.slice(e),a)):n=o}}};var HYi=R(W(),1);var nEt=typeof Worker!=vh;var xI=class{constructor(e,{readable:n,writable:i},{options:o,config:a,streamOptions:s,useWebWorkers:l,transferStreams:r,scripts:d},m){let{signal:h}=s;return Object.assign(e,{busy:!0,readable:n.pipeThrough(new wv(a.chunkSize)).pipeThrough(new Pnt(n,s),{signal:h}),writable:i,options:Object.assign({},o),scripts:d,transferStreams:r,terminate(){return new Promise(Z=>{let{worker:b,busy:u}=e;b?(u?e.resolveTerminated=Z:(b.terminate(),Z()),e.interface=null):Z()})},onTaskFinished(){let{resolveTerminated:Z}=e;Z&&(e.resolveTerminated=null,e.terminated=!0,e.worker.terminate(),Z()),e.busy=!1,m(e)}}),(l&&nEt?Yfe:iEt)(e,a)}},Pnt=class extends TransformStream{constructor(e,{onstart:n,onprogress:i,size:o,onend:a}){let s=0;super({async start(){n&&await wnt(n,o)},async transform(l,r){s+=l.length,i&&await wnt(i,s,o),r.enqueue(l)},async flush(){e.size=s,a&&await wnt(a,s)}})}};async function wnt(t,...e){try{await t(...e)}catch{}}function iEt(t,e){return{run:()=>xfe(t,e)}}function Yfe(t,e){let{baseURL:n,chunkSize:i}=e;if(!t.interface){let o;try{o=Lfe(t.scripts[0],n,t)}catch{return nEt=!1,iEt(t,e)}Object.assign(t,{worker:o,interface:{run:()=>Xfe(t,{chunkSize:i})}})}return t.interface}async function xfe({options:t,readable:e,writable:n,onTaskFinished:i},o){try{let a=new Hv(t,o);await e.pipeThrough(a).pipeTo(n,{preventClose:!0,preventAbort:!0});let{signature:s,inputSize:l,outputSize:r}=a;return{signature:s,inputSize:l,outputSize:r}}finally{i()}}async function Xfe(t,e){let n,i,o=new Promise((Z,b)=>{n=Z,i=b});Object.assign(t,{reader:null,writer:null,resolveResult:n,rejectResult:i,result:o});let{readable:a,options:s,scripts:l}=t,{writable:r,closed:d}=Jfe(t.writable),m=Kv({type:jgt,scripts:l.slice(1),options:s,config:e,readable:a,writable:r},t);m||Object.assign(t,{reader:a.getReader(),writer:r.getWriter()});let h=await o;return m||await r.getWriter().close(),await d,h}function Jfe(t){let e,n=new Promise(o=>e=o);return{writable:new WritableStream({async write(o){let a=t.getWriter();await a.ready,await a.write(o),a.releaseLock()},close(){e()},abort(o){return t.getWriter().abort(o)}}),closed:n}}var tEt=!0,eEt=!0;function Lfe(t,e,n){let i={type:"module"},o,a;typeof t==tW&&(t=t());try{o=new URL(t,e)}catch{o=t}if(tEt)try{a=new Worker(o)}catch{tEt=!1,a=new Worker(o,i)}else a=new Worker(o,i);return a.addEventListener(zgt,s=>Mfe(s,n)),a}function Kv(t,{worker:e,writer:n,onTaskFinished:i,transferStreams:o}){try{let{value:a,readable:s,writable:l}=t,r=[];if(a&&(a.byteLength!G.busy);if(U)return aEt(U),new xI(U,t,e,F);if(kT.lengthvnt.push({resolve:G,stream:t,workerOptions:e}))}function F(U){if(vnt.length){let[{resolve:G,stream:A,workerOptions:T}]=vnt.splice(0,1);G(new xI(U,A,T,F))}else U.worker?(aEt(U),_fe(U,e)):kT=kT.filter(G=>G!=U)}}function _fe(t,e){let{config:n}=e,{terminateWorkerTimeout:i}=n;Number.isFinite(i)&&i>=0&&(t.terminated?t.terminated=!1:t.terminateTimeout=setTimeout(async()=>{kT=kT.filter(o=>o!=t);try{await t.terminate()}catch{}},i))}function aEt(t){let{terminateTimeout:e}=t;e&&(clearTimeout(e),t.terminateTimeout=null)}var txi=R(W(),1);var Dfe="Writer iterator completed too soon",Ofe="text/plain";var Hfe="Content-Type";var wfe=64*1024,jnt="writable",XI=class{constructor(){this.size=0}init(){this.initialized=!0}},jv=class extends XI{get readable(){let e=this,{chunkSize:n=wfe}=e,i=new ReadableStream({start(){this.chunkOffset=0},async pull(o){let{offset:a=0,size:s,diskNumberStart:l}=i,{chunkOffset:r}=this;o.enqueue(await Fd(e,a+r,Math.min(n,s-r),l)),r+n>s?o.close():this.chunkOffset+=n}});return i}},Knt=class extends XI{constructor(){super();let e=this,n=new WritableStream({write(i){return e.writeUint8Array(i)}});Object.defineProperty(e,jnt,{get(){return n}})}writeUint8Array(){}};var qv=class extends Knt{constructor(e){super(),Object.assign(this,{data:"data:"+(e||"")+";base64,",pending:[]})}writeUint8Array(e){let n=this,i=0,o=n.pending,a=n.pending.length;for(n.pending="",i=0;i2?n.data+=btoa(o):n.pending=o}getData(){return this.data+btoa(this.pending)}},iW=class extends jv{constructor(e){super(),Object.assign(this,{blob:e,size:e.size})}async readUint8Array(e,n){let i=this,o=e+n,s=await(e||on&&(s=s.slice(e,o)),new Uint8Array(s)}},HL=class extends XI{constructor(e){super();let n=this,i=new TransformStream,o=[];e&&o.push([Hfe,e]),Object.defineProperty(n,jnt,{get(){return i.writable}}),n.blob=new Response(i.readable,{headers:o}).blob()}getData(){return this.blob}},$v=class extends iW{constructor(e){super(new Blob([e],{type:Ofe}))}},tK=class extends HL{constructor(e){super(e),Object.assign(this,{encoding:e,utf8:!e||e.toLowerCase()=="utf-8"})}async getData(){let{encoding:e,utf8:n}=this,i=await super.getData();if(i.text&&n)return i.text();{let o=new FileReader;return new Promise((a,s)=>{Object.assign(o,{onload:({target:l})=>a(l.result),onerror:()=>s(o.error)}),o.readAsText(i,e)})}}};var znt=class extends jv{constructor(e){super(),this.readers=e}async init(){let e=this,{readers:n}=e;e.lastDiskNumber=0,e.lastDiskOffset=0,await Promise.all(n.map(async(i,o)=>{await i.init(),o!=n.length-1&&(e.lastDiskOffset+=i.size),e.size+=i.size})),super.init()}async readUint8Array(e,n,i=0){let o=this,{readers:a}=this,s,l=i;l==-1&&(l=a.length-1);let r=e;for(;r>=a[l].size;)r-=a[l].size,l++;let d=a[l],m=d.size;if(r+n<=m)s=await Fd(d,r,n);else{let h=m-r;s=new Uint8Array(n),s.set(await Fd(d,r,h)),s.set(await o.readUint8Array(e+h,n-h,i),h)}return o.lastDiskNumber=Math.max(l,o.lastDiskNumber),s}},eK=class extends XI{constructor(e,n=4294967295){super();let i=this;Object.assign(i,{diskNumber:0,diskOffset:0,size:0,maxSize:n,availableSize:n});let o,a,s,l=new WritableStream({async write(m){let{availableSize:h}=i;if(s)m.length>=h?(await r(m.slice(0,h)),await d(),i.diskOffset+=o.size,i.diskNumber++,s=null,await this.write(m.slice(h))):await r(m);else{let{value:Z,done:b}=await e.next();if(b&&!Z)throw new Error(Dfe);o=Z,o.size=0,o.maxSize&&(i.maxSize=o.maxSize),i.availableSize=i.maxSize,await Sb(o),a=Z.writable,s=a.getWriter(),await this.write(m)}},async close(){await s.ready,await d()}});Object.defineProperty(i,jnt,{get(){return l}});async function r(m){let h=m.length;h&&(await s.ready,await s.write(m),o.size+=h,i.size+=h,i.availableSize-=h)}async function d(){a.size=o.size,await s.close()}}};async function Sb(t,e){if(t.init&&!t.initialized)await t.init(e);else return Promise.resolve()}function nK(t){return Array.isArray(t)&&(t=new znt(t)),t instanceof ReadableStream&&(t={readable:t}),t}function iK(t){t.writable===Ka&&typeof t.next==tW&&(t=new eK(t)),t instanceof WritableStream&&(t={writable:t});let{writable:e}=t;return e.size===Ka&&(e.size=0),t instanceof eK||Object.assign(t,{diskNumber:0,diskOffset:0,availableSize:1/0,maxSize:1/0}),t}function Fd(t,e,n,i){return t.readUint8Array(e,n,i)}var Vxi=R(W(),1);var axi=R(W(),1);var nxi=R(W(),1),sEt="\0\u263A\u263B\u2665\u2666\u2663\u2660\u2022\u25D8\u25CB\u25D9\u2642\u2640\u266A\u266B\u263C\u25BA\u25C4\u2195\u203C\xB6\xA7\u25AC\u21A8\u2191\u2193\u2192\u2190\u221F\u2194\u25B2\u25BC !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~\u2302\xC7\xFC\xE9\xE2\xE4\xE0\xE5\xE7\xEA\xEB\xE8\xEF\xEE\xEC\xC4\xC5\xC9\xE6\xC6\xF4\xF6\xF2\xFB\xF9\xFF\xD6\xDC\xA2\xA3\xA5\u20A7\u0192\xE1\xED\xF3\xFA\xF1\xD1\xAA\xBA\xBF\u2310\xAC\xBD\xBC\xA1\xAB\xBB\u2591\u2592\u2593\u2502\u2524\u2561\u2562\u2556\u2555\u2563\u2551\u2557\u255D\u255C\u255B\u2510\u2514\u2534\u252C\u251C\u2500\u253C\u255E\u255F\u255A\u2554\u2569\u2566\u2560\u2550\u256C\u2567\u2568\u2564\u2565\u2559\u2558\u2552\u2553\u256B\u256A\u2518\u250C\u2588\u2584\u258C\u2590\u2580\u03B1\xDF\u0393\u03C0\u03A3\u03C3\xB5\u03C4\u03A6\u0398\u03A9\u03B4\u221E\u03C6\u03B5\u2229\u2261\xB1\u2265\u2264\u2320\u2321\xF7\u2248\xB0\u2219\xB7\u221A\u207F\xB2\u25A0 ".split(""),Pfe=sEt.length==256;function lEt(t){if(Pfe){let e="";for(let n=0;nthis[n]=e[n])}};var cit="File format is not recognized",qfe="End of central directory not found",$fe="End of Zip64 central directory locator not found",tFe="Central directory header not found",eFe="Local file header not found",nFe="Zip64 extra field not found",iFe="File contains encrypted entry",oFe="Encryption method not supported",cEt="Compression method not supported",mEt="Split zip file",hEt="utf-8",pEt="cp437",aFe=[[iit,4294967295],[oit,4294967295],[ait,4294967295],[oK,65535]],sFe={[65535]:{getValue:Ol,bytes:4},[4294967295]:{getValue:sK,bytes:8}},pK=class{constructor(e,n={}){Object.assign(this,{reader:nK(e),options:n,config:xL()})}async*getEntriesGenerator(e={}){let n=this,{reader:i}=n,{config:o}=n;if(await Sb(i),(i.size===Ka||!i.readUint8Array)&&(i=new iW(await new Response(i.readable).blob()),await Sb(i)),i.size<22)throw new Error(cit);i.chunkSize=kv(o);let a=await mFe(i,101010256,i.size,22,65535*16);if(!a){let M=await Fd(i,0,4),V=jr(M);throw Ol(V)==134695760?new Error(mEt):new Error(qfe)}let s=jr(a),l=Ol(s,12),r=Ol(s,16),d=a.offset,m=zr(s,20),h=d+22+m,Z=zr(s,4),b=i.lastDiskNumber||0,u=zr(s,6),F=zr(s,8),U=0,G=0;if(r==4294967295||l==4294967295||F==65535||u==65535){let M=await Fd(i,a.offset-20,20),V=jr(M);if(Ol(V,0)==117853008){r=sK(V,8);let E=await Fd(i,r,56,-1),I=jr(E),B=a.offset-20-56;if(Ol(I,0)!=101075792&&r!=B){let X=r;r=B,U=r-X,E=await Fd(i,r,56,-1),I=jr(E)}if(Ol(I,0)!=101075792)throw new Error($fe);Z==65535&&(Z=Ol(I,16)),u==65535&&(u=Ol(I,20)),F==65535&&(F=sK(I,32)),l==4294967295&&(l=sK(I,40)),r-=l}}if(r>=i.size&&(U=i.size-r-l-22,r=i.size-l-22),b!=Z)throw new Error(mEt);if(r<0)throw new Error(cit);let A=0,T=await Fd(i,r,l,u),g=jr(T);if(l){let M=a.offset-l;if(Ol(g,A)!=33639248&&r!=M){let V=r;r=M,U+=r-V,T=await Fd(i,r,l,u),g=jr(T)}}let C=a.offset-r-(i.lastDiskOffset||0);if(l!=C&&C>=0&&(l=C,T=await Fd(i,r,l,u),g=jr(T)),r<0||r>=i.size)throw new Error(cit);let y=vm(n,e,"filenameEncoding"),Y=vm(n,e,"commentEncoding");for(let M=0;MV.getData(kt,Wt,Mt),A=H;let{onprogress:Nt}=e;if(Nt)try{await Nt(M+1,F,new vF(V))}catch{}yield Wt}let Q=vm(n,e,"extractPrependedData"),J=vm(n,e,"extractAppendedData");return Q&&(n.prependedData=G>0?await Fd(i,0,G):new Uint8Array),n.comment=m?await Fd(i,d+22,m):new Uint8Array,J&&(n.appendedData=h>>8&255:Z>>>24&255),signature:Z,compressed:d!=0,encrypted:C,useWebWorkers:vm(o,i,"useWebWorkers"),useCompressionStream:vm(o,i,"useCompressionStream"),transferStreams:vm(o,i,"transferStreams"),checkPasswordOnly:V},config:m,streamOptions:{signal:M,size:Q,onstart:I,onprogress:B,onend:X}},P=0;try{({outputSize:P}=await zv({readable:J,writable:E},_))}catch(w){if(!V||w.message!=nW)throw w}finally{let w=vm(o,i,"preventClose");E.size+=P,!w&&!E.locked&&await E.getWriter().close()}return V?Ka:e.getData?e.getData():E}};function ZEt(t,e,n){let i=t.rawBitFlag=zr(e,n+2),o=(i&1)==1,a=Ol(e,n+6);Object.assign(t,{encrypted:o,version:zr(e,n),bitFlag:{level:(i&6)>>1,dataDescriptor:(i&8)==8,languageEncodingFlag:(i&2048)==2048},rawLastModDate:a,lastModDate:hFe(a),filenameLength:zr(e,n+22),extraFieldLength:zr(e,n+24)})}async function VEt(t,e,n,i,o){let{rawExtraField:a}=e,s=e.extraField=new Map,l=jr(new Uint8Array(a)),r=0;try{for(;re[o]==a);for(let o=0,a=0;o=5&&(a.push(JI),s.push(aK));let l=1;a.forEach((r,d)=>{if(t.data.length>=l+4){let m=Ol(i,l);e[r]=t[r]=new Date(m*1e3);let h=s[d];t[h]=m}l+=4})}async function mFe(t,e,n,i,o){let a=new Uint8Array(4),s=jr(a);pFe(s,0,e);let l=i+o;return await r(i)||await r(Math.min(l,n));async function r(d){let m=n-d,h=await Fd(t,m,d);for(let Z=h.length-i;Z>=0;Z--)if(h[Z]==a[0]&&h[Z+1]==a[1]&&h[Z+2]==a[2]&&h[Z+3]==a[3])return{offset:m+Z,buffer:h.slice(Z,Z+i).buffer}}}function vm(t,e,n){return e[n]===Ka?t.options[n]:e[n]}function hFe(t){let e=(t&4294901760)>>16,n=t&65535;try{return new Date(1980+((e&65024)>>9),((e&480)>>5)-1,e&31,(n&63488)>>11,(n&2016)>>5,(n&31)*2,0)}catch{}}function mit(t){return new Date(Number(t/BigInt(1e4)-BigInt(116444736e5)))}function LI(t,e){return t.getUint8(e)}function zr(t,e){return t.getUint16(e,!0)}function Ol(t,e){return t.getUint32(e,!0)}function sK(t,e){return Number(t.getBigUint64(e,!0))}function pFe(t,e,n){t.setUint32(e,n,!0)}function jr(t){return new DataView(t.buffer)}var Axi=R(W(),1);var bFe="File already exists",RFe="Zip file comment exceeds 64KB",WFe="File entry comment exceeds 64KB",fFe="File entry name exceeds 64KB",WEt="Version exceeds 65535",FFe="The strength must equal 1, 2, or 3",UFe="Extra field type exceeds 65535",GFe="Extra field data exceeds 64KB",Sit="Zip64 is not supported (make sure 'keepOrder' is set to 'true')",fEt=new Uint8Array([7,0,2,0,65,69,3,0,0]),Ait=0,FEt=[],VK=class{constructor(e,n={}){e=iK(e);let i=e.availableSize!==Ka&&e.availableSize>0&&e.availableSize!==1/0&&e.maxSize!==Ka&&e.maxSize>0&&e.maxSize!==1/0;Object.assign(this,{writer:e,addSplitZipSignature:i,options:n,config:xL(),files:new Map,filenames:new Set,offset:e.writable.size,pendingEntriesSize:0,pendingAddFileCalls:new Set,bufferedWrites:0})}async add(e="",n,i={}){let o=this,{pendingAddFileCalls:a,config:s}=o;AitFEt.push(r));let l;try{if(e=e.trim(),o.filenames.has(e))throw new Error(bFe);return o.filenames.add(e),l=AFe(o,e,n,i),a.add(l),await l}catch(r){throw o.filenames.delete(e),r}finally{a.delete(l);let r=FEt.shift();r?r():Ait--}}async close(e=new Uint8Array,n={}){let i=this,{pendingAddFileCalls:o,writer:a}=this,{writable:s}=a;for(;o.size;)await Promise.allSettled(Array.from(o));return await BFe(this,e,n),ms(i,n,"preventClose")||await s.getWriter().close(),a.getData?a.getData():s}};async function AFe(t,e,n,i){e=e.trim(),i.directory&&!e.endsWith(BI)?e+=BI:i.directory=e.endsWith(BI);let o=ms(t,i,"encodeText",Yv),a=o(e);if(ta(a)>65535)throw new Error(fFe);let s=i.comment||"",l=o(s);if(ta(l)>65535)throw new Error(WFe);let r=ms(t,i,"version",20);if(r>65535)throw new Error(WEt);let d=ms(t,i,"versionMadeBy",20);if(d>65535)throw new Error(WEt);let m=ms(t,i,JI,new Date),h=ms(t,i,wL),Z=ms(t,i,PL),b=ms(t,i,rit,!0),u=ms(t,i,sit,0),F=ms(t,i,lit,0),U=ms(t,i,"password"),G=ms(t,i,"rawPassword"),A=ms(t,i,"encryptionStrength",3),T=ms(t,i,"zipCrypto"),g=ms(t,i,"extendedTimestamp",!0),C=ms(t,i,"keepOrder",!0),y=ms(t,i,"level"),Y=ms(t,i,"useWebWorkers"),Q=ms(t,i,"bufferedWrite"),J=ms(t,i,"dataDescriptorSignature",!1),M=ms(t,i,"signal"),V=ms(t,i,"useCompressionStream"),E=ms(t,i,"dataDescriptor",!0),I=ms(t,i,dit);if(U!==Ka&&A!==Ka&&(A<1||A>3))throw new Error(FFe);let B=new Uint8Array,{extraField:X}=i;if(X){let Mt=0,qt=0;X.forEach(ie=>Mt+=4+ta(ie)),B=new Uint8Array(Mt),X.forEach((ie,oe)=>{if(oe>65535)throw new Error(UFe);if(ta(ie)>65535)throw new Error(GFe);ar(B,new Uint16Array([oe]),qt),ar(B,new Uint16Array([ta(ie)]),qt+2),ar(B,ie,qt+4),qt+=4+ta(ie)})}let _=0,P=0,w=0,z=I===!0;n&&(n=nK(n),await Sb(n),n.size===Ka?(E=!0,(I||I===Ka)&&(I=!0,w=_=4294967295)):(w=n.size,_=QFe(w)));let{diskOffset:H,diskNumber:nt,maxSize:$}=t.writer,dt=z||w>=4294967295,q=z||_>=4294967295,at=z||t.offset+t.pendingEntriesSize-H>=4294967295,Et=ms(t,i,"supportZip64SplitFile",!0)&&z||nt+Math.ceil(t.pendingEntriesSize/$)>=65535;if(at||dt||q||Et){if(I===!1||!C)throw new Error(Sit);I=!0}I=I||!1,i=Object.assign({},i,{rawFilename:a,rawComment:l,version:r,versionMadeBy:d,lastModDate:m,lastAccessDate:h,creationDate:Z,rawExtraField:B,zip64:I,zip64UncompressedSize:dt,zip64CompressedSize:q,zip64Offset:at,zip64DiskNumberStart:Et,password:U,rawPassword:G,level:!V&&t.config.CompressionStream===Ka?0:y,useWebWorkers:Y,encryptionStrength:A,extendedTimestamp:g,zipCrypto:T,bufferedWrite:Q,keepOrder:C,dataDescriptor:E,dataDescriptorSignature:J,signal:M,msDosCompatible:b,internalFileAttribute:u,externalFileAttribute:F,useCompressionStream:V});let Qt=gFe(i),Wt=CFe(i),Nt=ta(Qt.localHeaderArray,Wt.dataDescriptorArray);P=Nt+_,t.options.usdz&&(P+=P+64),t.pendingEntriesSize+=P;let kt;try{kt=await TFe(t,e,n,{headerInfo:Qt,dataDescriptorInfo:Wt,metadataSize:Nt},i)}finally{t.pendingEntriesSize-=P}return Object.assign(kt,{name:e,comment:s,extraField:X}),new vF(kt)}async function TFe(t,e,n,i,o){let{files:a,writer:s}=t,{keepOrder:l,dataDescriptor:r,signal:d}=o,{headerInfo:m}=i,{usdz:h}=t.options,Z=Array.from(a.values()).pop(),b={},u,F,U,G,A,T,g;a.set(e,b);try{let Q;l&&(Q=Z&&Z.lock,C()),(o.bufferedWrite||t.writerLocked||t.bufferedWrites&&l||!r)&&!h?(T=new TransformStream,g=new Response(T.readable).blob(),T.writable.size=0,u=!0,t.bufferedWrites++,await Sb(s)):(T=s,await y()),await Sb(T);let{writable:J}=s,{diskOffset:M}=s;if(t.addSplitZipSignature){delete t.addSplitZipSignature;let E=new Uint8Array(4),I=Ud(E);$o(I,0,134695760),await gb(J,E),t.offset+=4}h&&EFe(i,t.offset-M),u||(await Q,await Y(J));let{diskNumber:V}=s;if(A=!0,b.diskNumberStart=V,b=await SFe(n,T,b,i,t.config,o),A=!1,a.set(e,b),b.filename=e,u){await T.writable.getWriter().close();let E=await g;await Q,await y(),G=!0,r||(E=await NFe(b,E,J,o)),await Y(J),b.diskNumberStart=s.diskNumber,M=s.diskOffset,await E.stream().pipeTo(J,{preventClose:!0,preventAbort:!0,signal:d}),J.size+=E.size,G=!1}if(b.offset=t.offset-M,b.zip64)yFe(b,o);else if(b.offset>=4294967295)throw new Error(Sit);return t.offset+=b.size,b}catch(Q){if(u&&G||!u&&A){if(t.hasCorruptedEntries=!0,Q)try{Q.corruptedEntry=!0}catch{}u?t.offset+=T.writable.size:t.offset=T.writable.size}throw a.delete(e),Q}finally{u&&t.bufferedWrites--,U&&U(),F&&F()}function C(){b.lock=new Promise(Q=>U=Q)}async function y(){t.writerLocked=!0;let{lockWriter:Q}=t;t.lockWriter=new Promise(J=>F=()=>{t.writerLocked=!1,J()}),await Q}async function Y(Q){ta(m.localHeaderArray)>s.availableSize&&(s.availableSize=0,await gb(Q,new Uint8Array))}}async function SFe(t,e,{diskNumberStart:n,lock:i},o,a,s){let{headerInfo:l,dataDescriptorInfo:r,metadataSize:d}=o,{localHeaderArray:m,headerArray:h,lastModDate:Z,rawLastModDate:b,encrypted:u,compressed:F,version:U,compressionMethod:G,rawExtraFieldExtendedTimestamp:A,extraFieldExtendedTimestampFlag:T,rawExtraFieldNTFS:g,rawExtraFieldAES:C}=l,{dataDescriptorArray:y}=r,{rawFilename:Y,lastAccessDate:Q,creationDate:J,password:M,rawPassword:V,level:E,zip64:I,zip64UncompressedSize:B,zip64CompressedSize:X,zip64Offset:_,zip64DiskNumberStart:P,zipCrypto:w,dataDescriptor:z,directory:H,versionMadeBy:nt,rawComment:$,rawExtraField:dt,useWebWorkers:q,onstart:at,onprogress:st,onend:Et,signal:Qt,encryptionStrength:Wt,extendedTimestamp:Nt,msDosCompatible:kt,internalFileAttribute:Mt,externalFileAttribute:qt,useCompressionStream:ie}=s,oe={lock:i,versionMadeBy:nt,zip64:I,directory:!!H,filenameUTF8:!0,rawFilename:Y,commentUTF8:!0,rawComment:$,rawExtraFieldExtendedTimestamp:A,rawExtraFieldNTFS:g,rawExtraFieldAES:C,rawExtraField:dt,extendedTimestamp:Nt,msDosCompatible:kt,internalFileAttribute:Mt,externalFileAttribute:qt,diskNumberStart:n},He=0,rn=0,de,{writable:zt}=e;if(t){t.chunkSize=kv(a),await gb(zt,m);let ue=t.readable,We=ue.size=t.size,un={options:{codecType:Pv,level:E,rawPassword:V,password:M,encryptionStrength:Wt,zipCrypto:u&&w,passwordVerification:u&&w&&b>>8&255,signed:!0,compressed:F,encrypted:u,useWebWorkers:q,useCompressionStream:ie,transferStreams:!1},config:a,streamOptions:{signal:Qt,size:We,onstart:at,onprogress:st,onend:Et}},Ct=await zv({readable:ue,writable:zt},un);rn=Ct.inputSize,He=Ct.outputSize,de=Ct.signature,zt.size+=rn}else await gb(zt,m);let ke;if(I){let ue=4;B&&(ue+=8),X&&(ue+=8),_&&(ue+=8),P&&(ue+=4),ke=new Uint8Array(ue)}else ke=new Uint8Array;return IFe({signature:de,rawExtraFieldZip64:ke,compressedSize:He,uncompressedSize:rn,headerInfo:l,dataDescriptorInfo:r},s),z&&await gb(zt,y),Object.assign(oe,{uncompressedSize:rn,compressedSize:He,lastModDate:Z,rawLastModDate:b,creationDate:J,lastAccessDate:Q,encrypted:u,size:d+He,compressionMethod:G,version:U,headerArray:h,signature:de,rawExtraFieldZip64:ke,extraFieldExtendedTimestampFlag:T,zip64UncompressedSize:B,zip64CompressedSize:X,zip64Offset:_,zip64DiskNumberStart:P}),oe}function gFe(t){let{rawFilename:e,lastModDate:n,lastAccessDate:i,creationDate:o,rawPassword:a,password:s,level:l,zip64:r,zipCrypto:d,dataDescriptor:m,directory:h,rawExtraField:Z,encryptionStrength:b,extendedTimestamp:u}=t,F=l!==0&&!h,U=!!(s&&ta(s)||a&&ta(a)),G=t.version,A;if(U&&!d){A=new Uint8Array(ta(fEt)+2);let P=Ud(A);Ra(P,0,39169),ar(A,fEt,2),bK(P,8,b)}else A=new Uint8Array;let T,g,C;if(u){g=new Uint8Array(9+(i?4:0)+(o?4:0));let P=Ud(g);Ra(P,0,21589),Ra(P,2,ta(g)-4),C=1+(i?2:0)+(o?4:0),bK(P,4,C);let w=5;$o(P,w,Math.floor(n.getTime()/1e3)),w+=4,i&&($o(P,w,Math.floor(i.getTime()/1e3)),w+=4),o&&$o(P,w,Math.floor(o.getTime()/1e3));try{T=new Uint8Array(36);let z=Ud(T),H=Tit(n);Ra(z,0,10),Ra(z,2,32),Ra(z,8,1),Ra(z,10,24),Km(z,12,H),Km(z,20,Tit(i)||H),Km(z,28,Tit(o)||H)}catch{T=new Uint8Array}}else T=g=new Uint8Array;let y=2048;m&&(y=y|8);let Y=0;F&&(Y=8),r&&(G=G>45?G:45),U&&(y=y|1,d||(G=G>51?G:51,Y=99,F&&(A[9]=8)));let Q=new Uint8Array(26),J=Ud(Q);Ra(J,0,G),Ra(J,2,y),Ra(J,4,Y);let M=new Uint32Array(1),V=Ud(M),E;nxnt?E=xnt:E=n,Ra(V,0,(E.getHours()<<6|E.getMinutes())<<5|E.getSeconds()/2),Ra(V,2,(E.getFullYear()-1980<<4|E.getMonth()+1)<<5|E.getDate());let I=M[0];$o(J,6,I),Ra(J,22,ta(e));let B=ta(A,g,T,Z);Ra(J,24,B);let X=new Uint8Array(30+ta(e)+B),_=Ud(X);return $o(_,0,67324752),ar(X,Q,4),ar(X,e,30),ar(X,A,30+ta(e)),ar(X,g,30+ta(e,A)),ar(X,T,30+ta(e,A,g)),ar(X,Z,30+ta(e,A,g,T)),{localHeaderArray:X,headerArray:Q,headerView:J,lastModDate:n,rawLastModDate:I,encrypted:U,compressed:F,version:G,compressionMethod:Y,extraFieldExtendedTimestampFlag:C,rawExtraFieldExtendedTimestamp:g,rawExtraFieldNTFS:T,rawExtraFieldAES:A,extraFieldLength:B}}function EFe(t,e){let{headerInfo:n}=t,{localHeaderArray:i,extraFieldLength:o}=n,a=Ud(i),s=64-(e+ta(i))%64;s<4&&(s+=64);let l=new Uint8Array(s),r=Ud(l);Ra(r,0,6534),Ra(r,2,s-2);let d=i;n.localHeaderArray=i=new Uint8Array(ta(d)+s),ar(i,d),ar(i,l,ta(d)),a=Ud(i),Ra(a,28,o+s),t.metadataSize+=s}function CFe(t){let{zip64:e,dataDescriptor:n,dataDescriptorSignature:i}=t,o=new Uint8Array,a,s=0;return n&&(o=new Uint8Array(e?i?24:20:i?16:12),a=Ud(o),i&&(s=4,$o(a,0,134695760))),{dataDescriptorArray:o,dataDescriptorView:a,dataDescriptorOffset:s}}function IFe(t,e){let{signature:n,rawExtraFieldZip64:i,compressedSize:o,uncompressedSize:a,headerInfo:s,dataDescriptorInfo:l}=t,{headerView:r,encrypted:d}=s,{dataDescriptorView:m,dataDescriptorOffset:h}=l,{zip64:Z,zip64UncompressedSize:b,zip64CompressedSize:u,zipCrypto:F,dataDescriptor:U}=e;if((!d||F)&&n!==Ka&&($o(r,10,n),U&&$o(m,h,n)),Z){let G=Ud(i);Ra(G,0,1),Ra(G,2,ta(i)-4);let A=4;b&&($o(r,18,4294967295),Km(G,A,BigInt(a)),A+=8),u&&($o(r,14,4294967295),Km(G,A,BigInt(o))),U&&(Km(m,h+4,BigInt(o)),Km(m,h+12,BigInt(a)))}else $o(r,14,o),$o(r,18,a),U&&($o(m,h+4,o),$o(m,h+8,a))}async function NFe(t,e,n,{zipCrypto:i}){let o;o=await e.slice(0,26).arrayBuffer(),o.byteLength!=26&&(o=o.slice(0,26));let a=new DataView(o);return(!t.encrypted||i)&&$o(a,14,t.signature),t.zip64?($o(a,18,4294967295),$o(a,22,4294967295)):($o(a,18,t.compressedSize),$o(a,22,t.uncompressedSize)),await gb(n,new Uint8Array(o)),e.slice(o.byteLength)}function yFe(t,e){let{rawExtraFieldZip64:n,offset:i,diskNumberStart:o}=t,{zip64UncompressedSize:a,zip64CompressedSize:s,zip64Offset:l,zip64DiskNumberStart:r}=e,d=Ud(n),m=4;a&&(m+=8),s&&(m+=8),l&&(Km(d,m,BigInt(i)),m+=8),r&&$o(d,m,o)}async function BFe(t,e,n){let{files:i,writer:o}=t,{diskOffset:a,writable:s}=o,{diskNumber:l}=o,r=0,d=0,m=t.offset-a,h=i.size;for(let[,C]of i){let{rawFilename:y,rawExtraFieldZip64:Y,rawExtraFieldAES:Q,rawComment:J,rawExtraFieldNTFS:M,rawExtraField:V,extendedTimestamp:E,extraFieldExtendedTimestampFlag:I,lastModDate:B}=C,X;if(E){X=new Uint8Array(9);let _=Ud(X);Ra(_,0,21589),Ra(_,2,5),bK(_,4,I),$o(_,5,Math.floor(B.getTime()/1e3))}else X=new Uint8Array;C.rawExtraFieldCDExtendedTimestamp=X,d+=46+ta(y,J,Y,Q,M,X,V)}let Z=new Uint8Array(d),b=Ud(Z);await Sb(o);let u=0;for(let[C,y]of Array.from(i.values()).entries()){let{offset:Y,rawFilename:Q,rawExtraFieldZip64:J,rawExtraFieldAES:M,rawExtraFieldCDExtendedTimestamp:V,rawExtraFieldNTFS:E,rawExtraField:I,rawComment:B,versionMadeBy:X,headerArray:_,directory:P,zip64:w,zip64UncompressedSize:z,zip64CompressedSize:H,zip64DiskNumberStart:nt,zip64Offset:$,msDosCompatible:dt,internalFileAttribute:q,externalFileAttribute:at,diskNumberStart:st,uncompressedSize:Et,compressedSize:Qt}=y,Wt=ta(J,M,V,E,I);$o(b,r,33639248),Ra(b,r+4,X);let Nt=Ud(_);z||$o(Nt,18,Et),H||$o(Nt,14,Qt),ar(Z,_,r+6),Ra(b,r+30,Wt),Ra(b,r+32,ta(B)),Ra(b,r+34,w&&nt?65535:st),Ra(b,r+36,q),at?$o(b,r+38,at):P&&dt&&bK(b,r+38,16),$o(b,r+42,w&&$?4294967295:Y),ar(Z,Q,r+46),ar(Z,J,r+46+ta(Q)),ar(Z,M,r+46+ta(Q,J)),ar(Z,V,r+46+ta(Q,J,M)),ar(Z,E,r+46+ta(Q,J,M,V)),ar(Z,I,r+46+ta(Q,J,M,V,E)),ar(Z,B,r+46+ta(Q)+Wt);let kt=46+ta(Q,B)+Wt;if(r-u>o.availableSize&&(o.availableSize=0,await gb(s,Z.slice(u,r)),u=r),r+=kt,n.onprogress)try{await n.onprogress(C+1,i.size,new vF(y))}catch{}}await gb(s,u?Z.slice(u):Z);let F=o.diskNumber,{availableSize:U}=o;U<22&&F++;let G=ms(t,n,"zip64");if(m>=4294967295||d>=4294967295||h>=65535||F>=65535){if(G===!1)throw new Error(Sit);G=!0}let A=new Uint8Array(G?98:22),T=Ud(A);r=0,G&&($o(T,0,101075792),Km(T,4,BigInt(44)),Ra(T,12,45),Ra(T,14,45),$o(T,16,F),$o(T,20,l),Km(T,24,BigInt(h)),Km(T,32,BigInt(h)),Km(T,40,BigInt(d)),Km(T,48,BigInt(m)),$o(T,56,117853008),Km(T,64,BigInt(m)+BigInt(d)),$o(T,72,F+1),ms(t,n,"supportZip64SplitFile",!0)&&(F=65535,l=65535),h=65535,m=4294967295,d=4294967295,r+=76),$o(T,r,101010256),Ra(T,r+4,F),Ra(T,r+6,l),Ra(T,r+8,h),Ra(T,r+10,h),$o(T,r+12,d),$o(T,r+16,m);let g=ta(e);if(g)if(g<=65535)Ra(T,r+20,g);else throw new Error(RFe);await gb(s,A),g&&await gb(s,e)}async function gb(t,e){let n=t.getWriter();try{await n.ready,t.size+=ta(e),await n.write(e)}finally{n.releaseLock()}}function Tit(t){if(t)return(BigInt(t.getTime())+BigInt(116444736e5))*BigInt(1e4)}function ms(t,e,n,i){let o=e[n]===Ka?t.options[n]:e[n];return o===Ka?i:o}function QFe(t){return t+5*(Math.floor(t/16383)+1)}function bK(t,e,n){t.setUint8(e,n)}function Ra(t,e,n){t.setUint16(e,n,!0)}function $o(t,e,n){t.setUint32(e,n,!0)}function Km(t,e,n){t.setBigUint64(e,n,!0)}function ar(t,e,n){t.set(e,n)}function Ud(t){return new DataView(t.buffer)}function ta(...t){let e=0;return t.forEach(n=>n&&(e+=n.length)),e}QI({Deflate:sgt,Inflate:Egt});var xxi=R(W(),1);function kFe(t){return typeof t=="string"&&(t=document.getElementById(t)),t}var Ui=kFe;var Jxi=R(W(),1);function YFe(t,e){this.position=t,this.headingPitchRange=e}var zL=YFe;var Dxi=R(W(),1);function RK(t,e){this.id=e,this.name=t,this.playlistIndex=0,this.playlist=[],this.tourStart=new It,this.tourEnd=new It,this.entryStart=new It,this.entryEnd=new It,this._activeEntries=[]}RK.prototype.addPlaylistEntry=function(t){this.playlist.push(t)};RK.prototype.play=function(t,e){this.tourStart.raiseEvent();let n=this;AEt.call(this,t,e,function(i){n.playlistIndex=0,i||GEt(n._activeEntries),n.tourEnd.raiseEvent(i)})};RK.prototype.stop=function(){GEt(this._activeEntries)};function GEt(t){for(let e=t.pop();e!==void 0;e=t.pop())e.stop()}function AEt(t,e,n){let i=this.playlist[this.playlistIndex];if(i){let o=xFe.bind(this,t,e,n);if(this._activeEntries.push(i),this.entryStart.raiseEvent(i),i.blocking)i.play(o,t.scene.camera,e);else{let a=this;i.play(function(){a.entryEnd.raiseEvent(i);let s=a._activeEntries.indexOf(i);s>=0&&a._activeEntries.splice(s,1)}),o(t,e,n)}}else c(n)&&n(!1)}function xFe(t,e,n,i){let o=this.playlist[this.playlistIndex];if(this.entryEnd.raiseEvent(o,i),i)n(i);else{let a=this._activeEntries.indexOf(o);a>=0&&this._activeEntries.splice(a,1),this.playlistIndex++,AEt.call(this,t,e,n)}}var jL=RK;var sXi=R(W(),1);var tXi=R(W(),1);var jxi=R(W(),1),Jo=Object.freeze({Linear:Object.freeze({None:function(t){return t},In:function(t){return this.None(t)},Out:function(t){return this.None(t)},InOut:function(t){return this.None(t)}}),Quadratic:Object.freeze({In:function(t){return t*t},Out:function(t){return t*(2-t)},InOut:function(t){return(t*=2)<1?.5*t*t:-.5*(--t*(t-2)-1)}}),Cubic:Object.freeze({In:function(t){return t*t*t},Out:function(t){return--t*t*t+1},InOut:function(t){return(t*=2)<1?.5*t*t*t:.5*((t-=2)*t*t+2)}}),Quartic:Object.freeze({In:function(t){return t*t*t*t},Out:function(t){return 1- --t*t*t*t},InOut:function(t){return(t*=2)<1?.5*t*t*t*t:-.5*((t-=2)*t*t*t-2)}}),Quintic:Object.freeze({In:function(t){return t*t*t*t*t},Out:function(t){return--t*t*t*t*t+1},InOut:function(t){return(t*=2)<1?.5*t*t*t*t*t:.5*((t-=2)*t*t*t*t+2)}}),Sinusoidal:Object.freeze({In:function(t){return 1-Math.sin((1-t)*Math.PI/2)},Out:function(t){return Math.sin(t*Math.PI/2)},InOut:function(t){return .5*(1-Math.sin(Math.PI*(.5-t)))}}),Exponential:Object.freeze({In:function(t){return t===0?0:Math.pow(1024,t-1)},Out:function(t){return t===1?1:1-Math.pow(2,-10*t)},InOut:function(t){return t===0?0:t===1?1:(t*=2)<1?.5*Math.pow(1024,t-1):.5*(-Math.pow(2,-10*(t-1))+2)}}),Circular:Object.freeze({In:function(t){return 1-Math.sqrt(1-t*t)},Out:function(t){return Math.sqrt(1- --t*t)},InOut:function(t){return(t*=2)<1?-.5*(Math.sqrt(1-t*t)-1):.5*(Math.sqrt(1-(t-=2)*t)+1)}}),Elastic:Object.freeze({In:function(t){return t===0?0:t===1?1:-Math.pow(2,10*(t-1))*Math.sin((t-1.1)*5*Math.PI)},Out:function(t){return t===0?0:t===1?1:Math.pow(2,-10*t)*Math.sin((t-.1)*5*Math.PI)+1},InOut:function(t){return t===0?0:t===1?1:(t*=2,t<1?-.5*Math.pow(2,10*(t-1))*Math.sin((t-1.1)*5*Math.PI):.5*Math.pow(2,-10*(t-1))*Math.sin((t-1.1)*5*Math.PI)+1)}}),Back:Object.freeze({In:function(t){var e=1.70158;return t===1?1:t*t*((e+1)*t-e)},Out:function(t){var e=1.70158;return t===0?0:--t*t*((e+1)*t+e)+1},InOut:function(t){var e=2.5949095;return(t*=2)<1?.5*(t*t*((e+1)*t-e)):.5*((t-=2)*t*((e+1)*t+e)+2)}}),Bounce:Object.freeze({In:function(t){return 1-Jo.Bounce.Out(1-t)},Out:function(t){return t<.36363636363636365?7.5625*t*t:t<.7272727272727273?7.5625*(t-=.5454545454545454)*t+.75:t<.9090909090909091?7.5625*(t-=.8181818181818182)*t+.9375:7.5625*(t-=.9545454545454546)*t+.984375},InOut:function(t){return t<.5?Jo.Bounce.In(t*2)*.5:Jo.Bounce.Out(t*2-1)*.5+.5}}),generatePow:function(t){return t===void 0&&(t=4),t=t1e4?1e4:t,{In:function(e){return Math.pow(e,t)},Out:function(e){return 1-Math.pow(1-e,t)},InOut:function(e){return e<.5?Math.pow(e*2,t)/2:(1-Math.pow(2-e*2,t))/2+.5}}}}),qL=function(){return performance.now()},XFe=function(){function t(){this._tweens={},this._tweensAddedDuringUpdate={}}return t.prototype.getAll=function(){var e=this;return Object.keys(this._tweens).map(function(n){return e._tweens[n]})},t.prototype.removeAll=function(){this._tweens={}},t.prototype.add=function(e){this._tweens[e.getId()]=e,this._tweensAddedDuringUpdate[e.getId()]=e},t.prototype.remove=function(e){delete this._tweens[e.getId()],delete this._tweensAddedDuringUpdate[e.getId()]},t.prototype.update=function(e,n){e===void 0&&(e=qL()),n===void 0&&(n=!1);var i=Object.keys(this._tweens);if(i.length===0)return!1;for(;i.length>0;){this._tweensAddedDuringUpdate={};for(var o=0;o1?a(t[n],t[n-1],n-i):a(t[o],t[o+1>n?n:o+1],i-o)},Bezier:function(t,e){for(var n=0,i=t.length-1,o=Math.pow,a=MI.Utils.Bernstein,s=0;s<=i;s++)n+=o(1-e,i-s)*o(e,s)*t[s]*a(i,s);return n},CatmullRom:function(t,e){var n=t.length-1,i=n*e,o=Math.floor(i),a=MI.Utils.CatmullRom;return t[0]===t[n]?(e<0&&(o=Math.floor(i=n*(1+e))),a(t[(o-1+n)%n],t[o],t[(o+1)%n],t[(o+2)%n],i-o)):e<0?t[0]-(a(t[0],t[0],t[1],t[1],-i)-t[0]):e>1?t[n]-(a(t[n],t[n],t[n-1],t[n-1],i-n)-t[n]):a(t[o?o-1:0],t[o],t[n1;i--)n*=i;return t[e]=n,n}}(),CatmullRom:function(t,e,n,i,o){var a=(n-t)*.5,s=(i-e)*.5,l=o*o,r=o*l;return(2*e-2*n+a+s)*r+(-3*e+3*n-2*a-s)*l+a*o+e}}},TEt=function(){function t(){}return t.nextId=function(){return t._nextId++},t._nextId=0,t}(),git=new XFe,SEt=function(){function t(e,n){n===void 0&&(n=git),this._object=e,this._group=n,this._isPaused=!1,this._pauseStart=0,this._valuesStart={},this._valuesEnd={},this._valuesStartRepeat={},this._duration=1e3,this._isDynamic=!1,this._initialRepeat=0,this._repeat=0,this._yoyo=!1,this._isPlaying=!1,this._reversed=!1,this._delayTime=0,this._startTime=0,this._easingFunction=Jo.Linear.None,this._interpolationFunction=MI.Linear,this._chainedTweens=[],this._onStartCallbackFired=!1,this._onEveryStartCallbackFired=!1,this._id=TEt.nextId(),this._isChainStopped=!1,this._propertiesAreSetUp=!1,this._goToEnd=!1}return t.prototype.getId=function(){return this._id},t.prototype.isPlaying=function(){return this._isPlaying},t.prototype.isPaused=function(){return this._isPaused},t.prototype.getDuration=function(){return this._duration},t.prototype.to=function(e,n){if(n===void 0&&(n=1e3),this._isPlaying)throw new Error("Can not call Tween.to() while Tween is already started or paused. Stop the Tween first.");return this._valuesEnd=e,this._propertiesAreSetUp=!1,this._duration=n<0?0:n,this},t.prototype.duration=function(e){return e===void 0&&(e=1e3),this._duration=e<0?0:e,this},t.prototype.dynamic=function(e){return e===void 0&&(e=!1),this._isDynamic=e,this},t.prototype.start=function(e,n){if(e===void 0&&(e=qL()),n===void 0&&(n=!1),this._isPlaying)return this;if(this._group&&this._group.add(this),this._repeat=this._initialRepeat,this._reversed){this._reversed=!1;for(var i in this._valuesStartRepeat)this._swapEndStartRepeatValues(i),this._valuesStart[i]=this._valuesStartRepeat[i]}if(this._isPlaying=!0,this._isPaused=!1,this._onStartCallbackFired=!1,this._onEveryStartCallbackFired=!1,this._isChainStopped=!1,this._startTime=e,this._startTime+=this._delayTime,!this._propertiesAreSetUp||n){if(this._propertiesAreSetUp=!0,!this._isDynamic){var o={};for(var a in this._valuesEnd)o[a]=this._valuesEnd[a];this._valuesEnd=o}this._setupProperties(this._object,this._valuesStart,this._valuesEnd,this._valuesStartRepeat,n)}return this},t.prototype.startFromCurrentValues=function(e){return this.start(e,!0)},t.prototype._setupProperties=function(e,n,i,o,a){for(var s in i){var l=e[s],r=Array.isArray(l),d=r?"array":typeof l,m=!r&&Array.isArray(i[s]);if(!(d==="undefined"||d==="function")){if(m){var h=i[s];if(h.length===0)continue;for(var Z=[l],b=0,u=h.length;b"u"||a)&&(n[s]=l),r||(n[s]*=1),m?o[s]=i[s].slice().reverse():o[s]=n[s]||0}}},t.prototype.stop=function(){return this._isChainStopped||(this._isChainStopped=!0,this.stopChainedTweens()),this._isPlaying?(this._group&&this._group.remove(this),this._isPlaying=!1,this._isPaused=!1,this._onStopCallback&&this._onStopCallback(this._object),this):this},t.prototype.end=function(){return this._goToEnd=!0,this.update(1/0),this},t.prototype.pause=function(e){return e===void 0&&(e=qL()),this._isPaused||!this._isPlaying?this:(this._isPaused=!0,this._pauseStart=e,this._group&&this._group.remove(this),this)},t.prototype.resume=function(e){return e===void 0&&(e=qL()),!this._isPaused||!this._isPlaying?this:(this._isPaused=!1,this._startTime+=e-this._pauseStart,this._pauseStart=0,this._group&&this._group.add(this),this)},t.prototype.stopChainedTweens=function(){for(var e=0,n=this._chainedTweens.length;es)return!1;n&&this.start(e,!0)}if(this._goToEnd=!1,ed)return 1;var U=Math.trunc(l/r),G=l-U*r,A=Math.min(G/i._duration,1);return A===0&&l===i._duration?1:A},h=m(),Z=this._easingFunction(h);if(this._updateProperties(this._object,this._valuesStart,this._valuesEnd,Z),this._onUpdateCallback&&this._onUpdateCallback(this._object,h),this._duration===0||l>=this._duration)if(this._repeat>0){var b=Math.min(Math.trunc((l-this._duration)/r)+1,this._repeat);isFinite(this._repeat)&&(this._repeat-=b);for(a in this._valuesStartRepeat)!this._yoyo&&typeof this._valuesEnd[a]=="string"&&(this._valuesStartRepeat[a]=this._valuesStartRepeat[a]+parseFloat(this._valuesEnd[a])),this._yoyo&&this._swapEndStartRepeatValues(a),this._valuesStart[a]=this._valuesStartRepeat[a];return this._yoyo&&(this._reversed=!this._reversed),this._startTime+=r*b,this._onRepeatCallback&&this._onRepeatCallback(this._object),this._onEveryStartCallbackFired=!1,!0}else{this._onCompleteCallback&&this._onCompleteCallback(this._object);for(var u=0,F=this._chainedTweens.length;uthis._started+this._timeThreshold)){this._giveUpTime();return}i=this._nextNode()}this._pop()&&t&&this._process(!0)};function _Fe(t){let e=t.slice(0,Math.min(4,t.size)),n=kd(),i=new FileReader;return i.addEventListener("load",function(){n.resolve(new DataView(i.result).getUint32(0,!1)===1347093252)}),i.addEventListener("error",function(){n.reject(i.error)}),i.readAsArrayBuffer(e),n.promise}function DFe(t){let e=kd(),n=new FileReader;return n.addEventListener("load",function(){e.resolve(n.result)}),n.addEventListener("error",function(){e.reject(n.error)}),n.readAsText(t),e.promise}function xEt(t){let e={xsi:"http://www.w3.org/2001/XMLSchema-instance"},n,i,o,a;for(let s in e)e.hasOwnProperty(s)&&(o=RegExp(`[< ]${s}:`),a=`xmlns:${s}=`,o.test(t)&&t.indexOf(a)===-1&&(c(n)||(n=t.substr(0,t.indexOf("",e),i,o,a;for(;e!==-1&&e0?(zm.maximumRed=a,zm.red=void 0):(zm.maximumRed=void 0,zm.red=0),o>0?(zm.maximumGreen=o,zm.green=void 0):(zm.maximumGreen=void 0,zm.green=0),i>0?(zm.maximumBlue=i,zm.blue=void 0):(zm.maximumBlue=void 0,zm.blue=0),zm.alpha=n,v.fromRandom(zm)):new v(a,o,i,n)}function YT(t,e,n){let i=Gi(t,e,n);if(c(i))return Bit(i,Gi(t,"colorMode",n)==="random")}function HFe(t){let e=Lo(t,"TimeStamp",se.kmlgx),n=Gi(e,"when",se.kmlgx);if(!c(e)||!c(n)||n.length===0)return;let i=rt.fromIso8601(n),o=new ys;return o.addInterval(new ai({start:i,stop:Re.MAXIMUM_VALUE})),o}function wFe(t){let e=Lo(t,"TimeSpan",se.kmlgx);if(!c(e))return;let n,i=Lo(e,"begin",se.kmlgx),o=c(i)?rt.fromIso8601(i.textContent):void 0,a=Lo(e,"end",se.kmlgx),s=c(a)?rt.fromIso8601(a.textContent):void 0;if(c(o)&&c(s)){if(rt.lessThan(s,o)){let l=o;o=s,s=l}n=new ys,n.addInterval(new ai({start:o,stop:s}))}else c(o)?(n=new ys,n.addInterval(new ai({start:o,stop:Re.MAXIMUM_VALUE}))):c(s)&&(n=new ys,n.addInterval(new ai({start:Re.MINIMUM_VALUE,stop:s})));return n}function LEt(){let t=new Mr;return t.width=KF,t.height=KF,t.scaleByDistance=new ln(gEt,EEt,CEt,IEt),t.pixelOffsetScaleByDistance=new ln(gEt,EEt,CEt,IEt),t}function Xit(){let t=new sZ;return t.outline=!0,t.outlineColor=v.WHITE,t}function MEt(){let t=new aZ;return t.translucencyByDistance=new ln(3e6,1,5e6,0),t.pixelOffset=new K(17,0),t.horizontalOrigin=to.LEFT,t.font="16px sans-serif",t.style=Pa.FILL_AND_OUTLINE,t}function Jit(t,e,n,i,o){let a=Gi(t,"href",se.kml);if(!c(a)||a.length===0)return;if(a.indexOf("root://icons/palette-")===0){let l=a.charAt(21),r=f(io(t,"x",se.gx),0),d=f(io(t,"y",se.gx),0);r=Math.min(r/32,7),d=7-Math.min(d/32,7);let m=8*d+r;a=`https://maps.google.com/mapfiles/kml/pal${l}/icon${m}.png`}let s=xit(a,n,i);if(o){let l=Gi(t,"refreshMode",se.kml),r=Gi(t,"viewRefreshMode",se.kml);l==="onInterval"||l==="onExpire"?Gn(`kml-refreshMode-${l}`,`KML - Unsupported Icon refreshMode: ${l}`):(r==="onStop"||r==="onRegion")&&Gn(`kml-refreshMode-${r}`,`KML - Unsupported Icon viewRefreshMode: ${r}`);let d=f(Gi(t,"viewBoundScale",se.kml),1),m=r==="onStop"?"BBOX=[bboxWest],[bboxSouth],[bboxEast],[bboxNorth]":"",h=f(Gi(t,"viewFormat",se.kml),m),Z=Gi(t,"httpQuery",se.kml);c(h)&&s.setQueryParameters(Tc(UK(h))),c(Z)&&s.setQueryParameters(Tc(UK(Z)));let b=e._ellipsoid;return Mit(s,e.camera,e.canvas,d,e._lastCameraView.bbox,b),s}return s}function PFe(t,e,n,i,o){let a=io(e,"scale",se.kml),s=io(e,"heading",se.kml),l=YT(e,"color",se.kml),r=Lo(e,"Icon",se.kml),d=Jit(r,t,i,o,!1);c(r)&&!c(d)&&(d=!1);let m=io(r,"x",se.gx),h=io(r,"y",se.gx),Z=io(r,"w",se.gx),b=io(r,"h",se.gx),u=Lo(e,"hotSpot",se.kml),F=zF(u,"x"),U=zF(u,"y"),G=sr(u,"xunits"),A=sr(u,"yunits"),T=n.billboard;c(T)||(T=LEt(),n.billboard=T),T.image=d,T.scale=a,T.color=l,(c(m)||c(h)||c(Z)||c(b))&&(T.imageSubRegion=new Fe(m,h,Z,b)),c(s)&&s!==0&&(T.rotation=k.toRadians(-s),T.alignedAxis=p.UNIT_Z),a=f(a,1);let g,C;c(F)&&(G==="pixels"?g=-F*a:G==="insetPixels"?g=(F-KF)*a:G==="fraction"&&(g=-F*KF*a),g+=KF*.5*a),c(U)&&(A==="pixels"?C=U*a:A==="insetPixels"?C=(-U+KF)*a:A==="fraction"&&(C=U*KF*a),C-=KF*.5*a),(c(g)||c(C))&&(T.pixelOffset=new K(g,C))}function FK(t,e,n,i,o){for(let a=0,s=e.childNodes.length;a:clampToSeaFloor is currently not supported, using :clampToGround."),Ge.CLAMP_TO_GROUND):e==="relativeToSeaFloor"?(Gn("kml-gx:altitudeMode-relativeToSeaFloor","KML - :relativeToSeaFloor is currently not supported, using :relativeToGround."),Ge.RELATIVE_TO_GROUND):(c(t)?Gn("kml-altitudeMode-unknown",`KML - Unknown :${t}, using :CLAMP_TO_GROUND.`):Gn("kml-gx:altitudeMode-unknown",`KML - Unknown :${e}, using :CLAMP_TO_GROUND.`),Ge.CLAMP_TO_GROUND)}function zFe(t,e,n){return n==="relativeToSeaFloor"||e==="absolute"||e==="relativeToGround"?t:((c(e)&&e!=="clampToGround"||c(n)&&n!=="clampToSeaFloor")&&Gn("kml-altitudeMode-unknown",`KML - Unknown altitudeMode: ${f(e,n)}`),new vc(t))}function jFe(t,e,n,i){if(!c(t))return;if(n==="relativeToSeaFloor"||e==="absolute"||e==="relativeToGround")return t;(c(e)&&e!=="clampToGround"||c(n)&&n!=="clampToSeaFloor")&&Gn("kml-altitudeMode-unknown",`KML - Unknown altitudeMode: ${f(e,n)}`);let o=t.length;for(let a=0;a0&&Gn("kml-gx:angles","KML - gx:angles are not supported in gx:Tracks");let b=Math.min(l.length,d.length),u=[],F=[];for(let G=0;G0&&i.availability.addInterval(new ai({start:F[0],stop:F[F.length-1]})),h&&m&&Lit(e,i,o),!0}function kEt(t,e,n,i,o,a,s,l,r){let d=t[0],m=t[t.length-1],h=new Bs;h.addSamples(t,e),n.intervals.addInterval(new ai({start:d,stop:m,isStartIncluded:r,isStopIncluded:r,data:zFe(h,s,l)})),i.addInterval(new ai({start:d,stop:m,isStartIncluded:r,isStopIncluded:r})),o.intervals.addInterval(new ai({start:d,stop:m,isStartIncluded:r,isStopIncluded:r,data:a}))}function eUe(t,e,n,i,o){let a=vZ(n,"interpolate",se.gx),s=PZ(n,"Track",se.gx),l,r,d,m=!1,h=new _m,Z=new ys,b=new cl,u=t._ellipsoid;for(let F=0,U=s.length;F0)){for(u='',a=0;a`;u+="
${f(F.displayName,s)}${f(F.value,"")}
"}if(!c(u))return;u=LFe.link(u),Ba.innerHTML=u;let U=Ba.querySelectorAll("a");for(a=0;a1&&(Kh(Ba,"a","href",i),Kh(Ba,"link","href",i),Kh(Ba,"area","href",i),Kh(Ba,"img","src",i),Kh(Ba,"iframe","src",i),Kh(Ba,"video","src",i),Kh(Ba,"audio","src",i),Kh(Ba,"source","src",i),Kh(Ba,"track","src",i),Kh(Ba,"input","src",i),Kh(Ba,"embed","src",i),Kh(Ba,"script","src",i),Kh(Ba,"video","poster",i)),zh(Ba,"a","href",o),zh(Ba,"link","href",o),zh(Ba,"area","href",o),zh(Ba,"img","src",o),zh(Ba,"iframe","src",o),zh(Ba,"video","src",o),zh(Ba,"audio","src",o),zh(Ba,"source","src",o),zh(Ba,"track","src",o),zh(Ba,"input","src",o),zh(Ba,"embed","src",o),zh(Ba,"script","src",o),zh(Ba,"video","poster",o);let G='
',G+=`${Ba.innerHTML}
`,Ba.innerHTML="",e.description=G}function TK(t,e,n){let i=n.entityCollection,o=n.parentEntity,a=n.sourceResource,s=n.uriResolver,l=JEt(e,i,n.context),r=l.kml,d=vFe(t,e,n.styleCollection,a,s),m=Gi(e,"name",se.kml);l.name=m,l.parent=o;let h=wFe(e);c(h)||(h=HFe(e)),l.availability=h,Dit(l);function Z(T){return T?T.show&&Z(T.parent):!0}let b=vZ(e,"visibility",se.kml);l.show=Z(o)&&f(b,!0);let u=Lo(e,"author",se.atom),F=r.author;F.name=Gi(u,"name",se.atom),F.uri=Gi(u,"uri",se.atom),F.email=Gi(u,"email",se.atom);let U=Lo(e,"link",se.atom),G=r.link;G.href=sr(U,"href"),G.hreflang=sr(U,"hreflang"),G.rel=sr(U,"rel"),G.type=sr(U,"type"),G.title=sr(U,"title"),G.length=sr(U,"length"),r.address=Gi(e,"address",se.kml),r.phoneNumber=Gi(e,"phoneNumber",se.kml),r.snippet=Gi(e,"Snippet",se.kml),oUe(e,l),aUe(e,l,d,s,a);let A=t._ellipsoid;return vEt(e,l,A),PEt(e,l,A),c(Lo(e,"Region",se.kml))&&Gn("kml-region","KML - Placemark Regions are unsupported"),{entity:l,styleEntity:d}}function wEt(t,e,n,i){i.addNodes(e.childNodes,n),i.process()}function sUe(t,e,n,i){let o=TK(t,e,n),a=be(n);a.parentEntity=o.entity,wEt(t,e,a,i)}function lUe(t,e,n,i){let o=TK(t,e,n),a=o.entity,s=o.styleEntity,l=!1,r=e.childNodes;for(let d=0,m=r.length;dk.PI_OVER_TWO?k.PI_OVER_TWO:d}function l(d){return d>k.PI?d-k.TWO_PI:d<-k.PI?d+k.TWO_PI:d}let r=bG(t.queryParameters);if(r=r.replace(/%5B/g,"[").replace(/%5D/g,"]"),c(e)&&e._mode!==ut.MORPHING){let d,m;if(o=f(o,uUe),c(n)&&(Nit.x=n.clientWidth*.5,Nit.y=n.clientHeight*.5,d=e.pickEllipsoid(Nit,a,ZUe)),c(d)?m=a.cartesianToCartographic(d,_I):(m=Gt.center(o,_I),d=a.cartographicToCartesian(m)),c(i)&&!k.equalsEpsilon(i,1,k.EPSILON9)){let G=o.width*i*.5,A=o.height*i*.5;o=new Gt(l(m.longitude-G),s(m.latitude-A),l(m.longitude+G),s(m.latitude+A))}r=r.replace("[bboxWest]",k.toDegrees(o.west).toString()),r=r.replace("[bboxSouth]",k.toDegrees(o.south).toString()),r=r.replace("[bboxEast]",k.toDegrees(o.east).toString()),r=r.replace("[bboxNorth]",k.toDegrees(o.north).toString());let h=k.toDegrees(m.longitude).toString(),Z=k.toDegrees(m.latitude).toString();r=r.replace("[lookatLon]",h),r=r.replace("[lookatLat]",Z),r=r.replace("[lookatTilt]",k.toDegrees(e.pitch).toString()),r=r.replace("[lookatHeading]",k.toDegrees(e.heading).toString()),r=r.replace("[lookatRange]",p.distance(e.positionWC,d)),r=r.replace("[lookatTerrainLon]",h),r=r.replace("[lookatTerrainLat]",Z),r=r.replace("[lookatTerrainAlt]",m.height.toString()),a.cartesianToCartographic(e.positionWC,_I),r=r.replace("[cameraLon]",k.toDegrees(_I.longitude).toString()),r=r.replace("[cameraLat]",k.toDegrees(_I.latitude).toString()),r=r.replace("[cameraAlt]",k.toDegrees(_I.height).toString());let b=e.frustum,u=b.aspectRatio,F="",U="";if(c(u)){let G=k.toDegrees(b.fov);u>1?(F=G,U=G/u):(U=G,F=G*u)}r=r.replace("[horizFov]",F.toString()),r=r.replace("[vertFov]",U.toString())}else r=r.replace("[bboxWest]","-180"),r=r.replace("[bboxSouth]","-90"),r=r.replace("[bboxEast]","180"),r=r.replace("[bboxNorth]","90"),r=r.replace("[lookatLon]",""),r=r.replace("[lookatLat]",""),r=r.replace("[lookatRange]",""),r=r.replace("[lookatTilt]",""),r=r.replace("[lookatHeading]",""),r=r.replace("[lookatTerrainLon]",""),r=r.replace("[lookatTerrainLat]",""),r=r.replace("[lookatTerrainAlt]",""),r=r.replace("[cameraLon]",""),r=r.replace("[cameraLat]",""),r=r.replace("[cameraAlt]",""),r=r.replace("[horizFov]",""),r=r.replace("[vertFov]","");c(n)?(r=r.replace("[horizPixels]",n.clientWidth),r=r.replace("[vertPixels]",n.clientHeight)):(r=r.replace("[horizPixels]",""),r=r.replace("[vertPixels]","")),r=r.replace("[terrainEnabled]","1"),r=r.replace("[clientVersion]","1"),r=r.replace("[kmlVersion]","2.2"),r=r.replace("[clientName]","Cesium"),r=r.replace("[language]","English"),t.setQueryParameters(Tc(r))}function VUe(t,e,n,i){let a=TK(t,e,n).entity,s=n.sourceResource,l=n.uriResolver,r=Lo(e,"Link",se.kml);if(c(r)||(r=Lo(e,"Url",se.kml)),c(r)){let d=Gi(r,"href",se.kml),m,h;if(c(d)){let Z=d;if(d=xit(d,s,n.uriResolver),/^data:/.test(d.getUrlComponent()))/\.kmz/i.test(s.getUrlComponent())||(Z=s.getDerivedResource({url:Z}));else{if(Z=d.clone(),m=Gi(r,"viewRefreshMode",se.kml),m==="onRegion"){Gn("kml-refrehMode-onRegion","KML - Unsupported viewRefreshMode: onRegion");return}h=f(Gi(r,"viewBoundScale",se.kml),1);let U=m==="onStop"?"BBOX=[bboxWest],[bboxSouth],[bboxEast],[bboxNorth]":"",G=f(Gi(r,"viewFormat",se.kml),U),A=Gi(r,"httpQuery",se.kml);c(G)&&d.setQueryParameters(Tc(UK(G))),c(A)&&d.setQueryParameters(Tc(UK(A)));let T=t._ellipsoid;Mit(d,t.camera,t.canvas,h,t._lastCameraView.bbox,T)}let b={sourceUri:Z,uriResolver:l,context:a.id,screenOverlayContainer:n.screenOverlayContainer},u=new gr,F=_it(t,u,d,b).then(function(U){let G=t._entityCollection,A=u.values;G.suspendEvents();for(let C=0;C0||T==="onExpire"||m==="onStop"){let C=Lo(U,"NetworkLinkControl",se.kml),y=c(C),Y=rt.now(),Q={id:Si(),href:d,cookie:{},lastUpdated:Y,updating:!1,entity:a,viewBoundScale:h,needsUpdate:!1,cameraUpdateTime:Y},J=0;if(y&&(Q.cookie=Tc(f(Gi(C,"cookie",se.kml),"")),J=f(io(C,"minRefreshPeriod",se.kml),0)),T==="onInterval")y&&(g=Math.max(J,g)),Q.refreshMode=jF.INTERVAL,Q.time=g;else if(T==="onExpire"){let M;if(y&&(M=Gi(C,"expires",se.kml)),c(M))try{let V=rt.fromIso8601(M),E=rt.secondsDifference(V,Y);E>0&&E0;)this._screenOverlays.pop().remove()};function Dit(t){let e=t.parent;if(c(e)){let n=e.availability;if(c(n)){let i=t.availability;c(i)?i.intersect(n):t.availability=n}}}function WUe(t,e,n,i,o){return function(a){if(!i.contains(e.id))return;let s=!1,l=Lo(a,"NetworkLinkControl",se.kml),r=c(l),d=0;if(r){if(c(Lo(l,"Update",se.kml))){Gn("kml-networkLinkControl-update","KML - NetworkLinkControl updates aren't supported."),e.updating=!1,i.remove(e.id);return}e.cookie=Tc(f(Gi(l,"cookie",se.kml),"")),d=f(io(l,"minRefreshPeriod",se.kml),0)}let m=rt.now(),h=e.refreshMode;if(h===jF.INTERVAL)c(l)&&(e.time=Math.max(d,e.time));else if(h===jF.EXPIRE){let Y;if(c(l)&&(Y=Gi(l,"expires",se.kml)),c(Y))try{let Q=rt.fromIso8601(Y),J=rt.secondsDifference(Q,m);J>0&&Jm.time&&(Z=!0):m.refreshMode===jF.EXPIRE?rt.greaterThan(n,m.time)&&(Z=!0):m.refreshMode===jF.STOP&&(a&&(m.needsUpdate=!0,m.cameraUpdateTime=n),m.needsUpdate&&rt.secondsDifference(n,m.cameraUpdateTime)>=m.time&&(Z=!0)),Z){o(h),m.updating=!0;let b=new gr,u=m.href.clone();u.setQueryParameters(m.cookie);let F=f(i._ellipsoid,mt.WGS84);Mit(u,i.camera,i.canvas,m.viewBoundScale,s.bbox,F),_it(i,b,u,{context:h.id}).then(WUe(i,m,b,r,u)).catch(function(U){let G=`NetworkLink ${m.href} refresh failed: ${U}`;console.log(G),i._error.raiseEvent(i,G)}),d=!0}}r.set(m.id,m)}}),d&&(this._networkLinks=r,this._changed.raiseEvent(this)),!0};function fUe(){this.author={name:void 0,uri:void 0,email:void 0},this.link={href:void 0,hreflang:void 0,rel:void 0,type:void 0,title:void 0,length:void 0},this.address=void 0,this.phoneNumber=void 0,this.snippet=void 0,this.extendedData=void 0}jh._DeferredLoading=Cb;jh._getTimestamp=Oi;var iM=jh;var OJi=R(W(),1);var tCt=R(zEt(),1);var{abs:OI,min:Oit,max:jEt,ceil:SK,PI:gK,round:Hit}=Math,{toDegrees:qEt,toRadians:eCt}=k,HI=[.00675,.0125,.025,.05,.1,.2,.5,1,2,5,10].map(eCt),FUe=15,UUe=FUe,$Et=eCt(3),{MAX_VALUE:EK}=Gt,GUe=(t,e)=>{let n=new $e({geometry:new kR({positions:t,width:1}),attributes:{color:En.fromColor(e)}});return new Gh({geometryInstances:n,appearance:new zl({material:eo.fromType("Color",{color:e})})})},wit=class{constructor(e){this.viewer=e,this.lastRefresh=0,this.debounce=50,this.showLabels=!0,this.labelSettings={font:"12px Arial",outlineColor:v.BLACK,outlineWidth:4,style:Pa.FILL_AND_OUTLINE,eyeOffset:p.ZERO,scale:1,scaleByDistance:new ln(1,.85,8e6,.4)},this.ellipsoid=e.scene.globe.ellipsoid;let{scene:n}=e;this.labelEntities=[],this.polylines=new Mc,this.groundPolylines=[],n.primitives.add(this.polylines),this.currentExtent=this.getExtentView(),this.render=(0,tCt.debounce)(()=>{if(this._destroyed)return;this.viewer.scene.camera.percentageChanged=.1;let i=this.lastRefresh;if(new Date().getTime()-i{this.render()}),this.resizeObserver.observe(e.container),this.cameraChangedEventListener=i=>{this.render()},e.scene.camera.changed.addEventListener(this.cameraChangedEventListener),this.boundRender=this.render.bind(this),e.container.addEventListener("resize",this.boundRender),this._destroyed=!1,this.render()}removeAllLabels(){this.labelEntities.forEach(e=>{this.viewer.entities.remove(e)}),this.labelEntities=[]}destroy(){if(this._destroyed){console.error("destroy has already been called.");return}this.resizeObserver&&this.resizeObserver.disconnect(),this.cameraChangedEventListener&&this.viewer.scene.camera.changed.removeEventListener(this.cameraChangedEventListener),this.boundRender&&this.viewer.container.removeEventListener("resize",this.boundRender),this.removeAllLabels(),this.removePolylines(),this._destroyed=!0}isCameraCloseToGround(){return this.viewer.camera.positionCartographic.height<455983}hasTerrainProvider(){return!(this.viewer.terrainProvider instanceof Ru)}lineGraphicsObj(e,n,i){let o;if(i)return o=this.ellipsoid.cartographicArrayToCartesianArray(e),GUe(o,n);let a=e.map(s=>new gt(s.longitude,s.latitude,this.hasTerrainProvider()?this.viewer.camera.positionCartographic.height/90+1e9/this.viewer.camera.positionCartographic.height:10));return o=this.ellipsoid.cartographicArrayToCartesianArray(a),{positions:o,width:.5,material:eo.fromType("Color",{color:n})}}removePolylines(){this.polylines.removeAll();for(let e=0;e=Math.PI/2-s,r=e.south<=-Math.PI/2+s,m=l||r?0:UUe;for(a=0;aEK.east?G=e._east-(Y-EK.east):G=Y;let Q=[];for(U=Z;U=0?"N":"S":e>=0?"E":"W"}`}},Pit=wit;var t5i=R(W(),1);var __i=R(W(),1);var aLi=R(W(),1);var zJi=R(W(),1);var vit=class{constructor({name:e=null,orientation:n=new wt(0,0,0,1),inheritParentOrientation:i=!0}){this._id=Si(),this._name=e,this._inheritParentOrientation=i,this._setOrientation(n)}_setOrientation(e){e instanceof et?this._orientation=e:this._orientation=new Ii(e)}get id(){return this._id}get orientation(){return this._orientation}set orientation(e){this._setOrientation(e)}get inheritParentOrientation(){return this._inheritParentOrientation}set inheritParentOrientation(e){this._inheritParentOrientation=e}},oW=vit;var xT=class extends oW{constructor(e){super(e),this._minimumClockAngle=void 0,this._minimumClockAngleSubscription=void 0,this._maximumClockAngle=void 0,this._maximumClockAngleSubscription=void 0,this._innerHalfAngle=void 0,this._innerHalfAngleSubscription=void 0,this._outerHalfAngle=void 0,this._outerHalfAngleSubscription=void 0,this._lateralSurfaceMaterial=void 0,this._lateralSurfaceMaterialSubscription=void 0,this._intersectionColor=void 0,this._intersectionColorSubscription=void 0,this._intersectionWidth=void 0,this._intersectionWidthSubscription=void 0,this._showIntersection=void 0,this._showIntersectionSubscription=void 0,this._radius=void 0,this._radiusSubscription=void 0,this._show=void 0,this._showSubscription=void 0,this._definitionChanged=new It,this.merge(f(e,f.EMPTY_OBJECT))}};Object.defineProperties(xT.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},minimumClockAngle:ft("minimumClockAngle"),maximumClockAngle:ft("maximumClockAngle"),innerHalfAngle:ft("innerHalfAngle"),outerHalfAngle:ft("outerHalfAngle"),lateralSurfaceMaterial:la("lateralSurfaceMaterial"),intersectionColor:ft("intersectionColor"),intersectionWidth:ft("intersectionWidth"),showIntersection:ft("showIntersection"),radius:ft("radius"),show:ft("show")});xT.prototype.clone=function(t){return c(t)||(t=new xT),t.show=this.show,t.innerHalfAngle=this.innerHalfAngle,t.outerHalfAngle=this.outerHalfAngle,t.minimumClockAngle=this.minimumClockAngle,t.maximumClockAngle=this.maximumClockAngle,t.radius=this.radius,t.showIntersection=this.showIntersection,t.intersectionColor=this.intersectionColor,t.intersectionWidth=this.intersectionWidth,t.lateralSurfaceMaterial=this.lateralSurfaceMaterial,t};xT.prototype.merge=function(t){if(!c(t))throw new Ut("source is required.");this.show=f(this.show,t.show),this.innerHalfAngle=f(this.innerHalfAngle,t.innerHalfAngle),this.outerHalfAngle=f(this.outerHalfAngle,t.outerHalfAngle),this.minimumClockAngle=f(this.minimumClockAngle,t.minimumClockAngle),this.maximumClockAngle=f(this.maximumClockAngle,t.maximumClockAngle),this.radius=f(this.radius,t.radius),this.showIntersection=f(this.showIntersection,t.showIntersection),this.intersectionColor=f(this.intersectionColor,t.intersectionColor),this.intersectionWidth=f(this.intersectionWidth,t.intersectionWidth),this.lateralSurfaceMaterial=f(this.lateralSurfaceMaterial,t.lateralSurfaceMaterial)};var XT=xT;var RMi=R(W(),1);var zLi=R(W(),1);var lLi=R(W(),1),wI=`#version 300 es +`)),!x)return null;Se=me(x,!0)}return Se.shift()},Ai={ttys:[],init:function(){},shutdown:function(){},register:function(x,D){Ai.ttys[x]={input:[],output:[],ops:D},ht.registerDevice(x,Ai.stream_ops)},stream_ops:{open:function(x){var D=Ai.ttys[x.node.rdev];if(!D)throw new ht.ErrnoError(43);x.tty=D,x.seekable=!1},close:function(x){x.tty.ops.fsync(x.tty)},fsync:function(x){x.tty.ops.fsync(x.tty)},read:function(x,D,j,lt,ut){if(!x.tty||!x.tty.ops.get_char)throw new ht.ErrnoError(60);for(var yt=0,Yt=0;Yt0&&(S(GZ(x.output,0)),x.output=[])},ioctl_tcgets:function(x){return{c_iflag:25856,c_oflag:5,c_cflag:191,c_lflag:35387,c_cc:[3,28,127,21,4,0,1,0,17,19,26,0,18,15,23,22,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]}},ioctl_tcsets:function(x,D,j){return 0},ioctl_tiocgwinsz:function(x){return[24,80]}},default_tty1_ops:{put_char:function(x,D){D===null||D===10?(g(GZ(x.output,0)),x.output=[]):D!=0&&x.output.push(D)},fsync:function(x){x.output&&x.output.length>0&&(g(GZ(x.output,0)),x.output=[])}}},ia=x=>{We("internal error: mmapAlloc called but `emscripten_builtin_memalign` native symbol not exported")},ni={ops_table:null,mount(x){return ni.createNode(null,"/",16895,0)},createNode(x,D,j,lt){if(ht.isBlkdev(j)||ht.isFIFO(j))throw new ht.ErrnoError(63);ni.ops_table||(ni.ops_table={dir:{node:{getattr:ni.node_ops.getattr,setattr:ni.node_ops.setattr,lookup:ni.node_ops.lookup,mknod:ni.node_ops.mknod,rename:ni.node_ops.rename,unlink:ni.node_ops.unlink,rmdir:ni.node_ops.rmdir,readdir:ni.node_ops.readdir,symlink:ni.node_ops.symlink},stream:{llseek:ni.stream_ops.llseek}},file:{node:{getattr:ni.node_ops.getattr,setattr:ni.node_ops.setattr},stream:{llseek:ni.stream_ops.llseek,read:ni.stream_ops.read,write:ni.stream_ops.write,allocate:ni.stream_ops.allocate,mmap:ni.stream_ops.mmap,msync:ni.stream_ops.msync}},link:{node:{getattr:ni.node_ops.getattr,setattr:ni.node_ops.setattr,readlink:ni.node_ops.readlink},stream:{}},chrdev:{node:{getattr:ni.node_ops.getattr,setattr:ni.node_ops.setattr},stream:ht.chrdev_stream_ops}});var ut=ht.createNode(x,D,j,lt);return ht.isDir(ut.mode)?(ut.node_ops=ni.ops_table.dir.node,ut.stream_ops=ni.ops_table.dir.stream,ut.contents={}):ht.isFile(ut.mode)?(ut.node_ops=ni.ops_table.file.node,ut.stream_ops=ni.ops_table.file.stream,ut.usedBytes=0,ut.contents=null):ht.isLink(ut.mode)?(ut.node_ops=ni.ops_table.link.node,ut.stream_ops=ni.ops_table.link.stream):ht.isChrdev(ut.mode)&&(ut.node_ops=ni.ops_table.chrdev.node,ut.stream_ops=ni.ops_table.chrdev.stream),ut.timestamp=Date.now(),x&&(x.contents[D]=ut,x.timestamp=ut.timestamp),ut},getFileDataAsTypedArray(x){return x.contents?x.contents.subarray?x.contents.subarray(0,x.usedBytes):new Uint8Array(x.contents):new Uint8Array(0)},expandFileStorage(x,D){var j=x.contents?x.contents.length:0;if(!(j>=D)){var lt=1024*1024;D=Math.max(D,j*(j>>0),j!=0&&(D=Math.max(D,256));var ut=x.contents;x.contents=new Uint8Array(D),x.usedBytes>0&&x.contents.set(ut.subarray(0,x.usedBytes),0)}},resizeFileStorage(x,D){if(x.usedBytes!=D)if(D==0)x.contents=null,x.usedBytes=0;else{var j=x.contents;x.contents=new Uint8Array(D),j&&x.contents.set(j.subarray(0,Math.min(D,x.usedBytes))),x.usedBytes=D}},node_ops:{getattr(x){var D={};return D.dev=ht.isChrdev(x.mode)?x.id:1,D.ino=x.id,D.mode=x.mode,D.nlink=1,D.uid=0,D.gid=0,D.rdev=x.rdev,ht.isDir(x.mode)?D.size=4096:ht.isFile(x.mode)?D.size=x.usedBytes:ht.isLink(x.mode)?D.size=x.link.length:D.size=0,D.atime=new Date(x.timestamp),D.mtime=new Date(x.timestamp),D.ctime=new Date(x.timestamp),D.blksize=4096,D.blocks=Math.ceil(D.size/D.blksize),D},setattr(x,D){D.mode!==void 0&&(x.mode=D.mode),D.timestamp!==void 0&&(x.timestamp=D.timestamp),D.size!==void 0&&ni.resizeFileStorage(x,D.size)},lookup(x,D){throw ht.genericErrors[44]},mknod(x,D,j,lt){return ni.createNode(x,D,j,lt)},rename(x,D,j){if(ht.isDir(x.mode)){var lt;try{lt=ht.lookupNode(D,j)}catch{}if(lt)for(var ut in lt.contents)throw new ht.ErrnoError(55)}delete x.parent.contents[x.name],x.parent.timestamp=Date.now(),x.name=j,D.contents[j]=x,D.timestamp=x.parent.timestamp,x.parent=D},unlink(x,D){delete x.contents[D],x.timestamp=Date.now()},rmdir(x,D){var j=ht.lookupNode(x,D);for(var lt in j.contents)throw new ht.ErrnoError(55);delete x.contents[D],x.timestamp=Date.now()},readdir(x){var D=[".",".."];for(var j in x.contents)x.contents.hasOwnProperty(j)&&D.push(j);return D},symlink(x,D,j){var lt=ni.createNode(x,D,41471,0);return lt.link=j,lt},readlink(x){if(!ht.isLink(x.mode))throw new ht.ErrnoError(28);return x.link}},stream_ops:{read(x,D,j,lt,ut){var yt=x.node.contents;if(ut>=x.node.usedBytes)return 0;var Yt=Math.min(x.node.usedBytes-ut,lt);if(Z(Yt>=0),Yt>8&&yt.subarray)D.set(yt.subarray(ut,ut+Yt),j);else for(var Dt=0;Dt0||j+D{var ut=lt?"":zt(`al ${x}`);U(x,yt=>{Z(yt,`Loading data file "${x}" failed (no arrayBuffer).`),D(new Uint8Array(yt)),ut&&Ve(ut)},yt=>{if(j)j();else throw`Loading data file "${x}" failed.`}),ut&&ke(ut)},BN=n.preloadPlugins||[];function z4(x,D,j,lt){typeof Browser<"u"&&Browser.init();var ut=!1;return BN.forEach(function(yt){ut||yt.canHandle(D)&&(yt.handle(x,D,j,lt),ut=!0)}),ut}function hm(x,D,j,lt,ut,yt,Yt,Dt,pe,Te){var en=D?vt.resolve(Ta.join2(x,D)):x,Zn=zt(`cp ${en}`);function Rn(bn){function Xn(vi){Te&&Te(),Dt||ht.createDataFile(x,D,vi,lt,ut,pe),yt&&yt(),Ve(Zn)}z4(bn,en,Xn,()=>{Yt&&Yt(),Ve(Zn)})||Xn(bn)}ke(Zn),typeof j=="string"?Oa(j,bn=>Rn(bn),Yt):Rn(j)}function gg(x){var D={r:0,"r+":2,w:577,"w+":578,a:1089,"a+":1090},j=D[x];if(typeof j>"u")throw new Error(`Unknown file open mode: ${x}`);return j}function QN(x,D){var j=0;return x&&(j|=365),D&&(j|=146),j}var KW={0:"Success",1:"Arg list too long",2:"Permission denied",3:"Address already in use",4:"Address not available",5:"Address family not supported by protocol family",6:"No more processes",7:"Socket already connected",8:"Bad file number",9:"Trying to read unreadable message",10:"Mount device busy",11:"Operation canceled",12:"No children",13:"Connection aborted",14:"Connection refused",15:"Connection reset by peer",16:"File locking deadlock error",17:"Destination address required",18:"Math arg out of domain of func",19:"Quota exceeded",20:"File exists",21:"Bad address",22:"File too large",23:"Host is unreachable",24:"Identifier removed",25:"Illegal byte sequence",26:"Connection already in progress",27:"Interrupted system call",28:"Invalid argument",29:"I/O error",30:"Socket is already connected",31:"Is a directory",32:"Too many symbolic links",33:"Too many open files",34:"Too many links",35:"Message too long",36:"Multihop attempted",37:"File or path name too long",38:"Network interface is not configured",39:"Connection reset by network",40:"Network is unreachable",41:"Too many open files in system",42:"No buffer space available",43:"No such device",44:"No such file or directory",45:"Exec format error",46:"No record locks available",47:"The link has been severed",48:"Not enough core",49:"No message of desired type",50:"Protocol not available",51:"No space left on device",52:"Function not implemented",53:"Socket is not connected",54:"Not a directory",55:"Directory not empty",56:"State not recoverable",57:"Socket operation on non-socket",59:"Not a typewriter",60:"No such device or address",61:"Value too large for defined data type",62:"Previous owner died",63:"Not super-user",64:"Broken pipe",65:"Protocol error",66:"Unknown protocol",67:"Protocol wrong type for socket",68:"Math result not representable",69:"Read only file system",70:"Illegal seek",71:"No such process",72:"Stale file handle",73:"Connection timed out",74:"Text file busy",75:"Cross-device link",100:"Device not a stream",101:"Bad font file fmt",102:"Invalid slot",103:"Invalid request code",104:"No anode",105:"Block device required",106:"Channel number out of range",107:"Level 3 halted",108:"Level 3 reset",109:"Link number out of range",110:"Protocol driver not attached",111:"No CSI structure available",112:"Level 2 halted",113:"Invalid exchange",114:"Invalid request descriptor",115:"Exchange full",116:"No data (for no delay io)",117:"Timer expired",118:"Out of streams resources",119:"Machine is not on the network",120:"Package not installed",121:"The object is remote",122:"Advertise error",123:"Srmount error",124:"Communication error on send",125:"Cross mount point (not really error)",126:"Given log. name not unique",127:"f.d. invalid for this operation",128:"Remote address changed",129:"Can access a needed shared lib",130:"Accessing a corrupted shared lib",131:".lib section in a.out corrupted",132:"Attempting to link in too many libs",133:"Attempting to exec a shared library",135:"Streams pipe error",136:"Too many users",137:"Socket type not supported",138:"Not supported",139:"Protocol family not supported",140:"Can't send after socket shutdown",141:"Too many references",142:"Host is down",148:"No medium (in tape drive)",156:"Level 2 not synchronized"},zW={};function Eg(x){return Go("warning: build with -sDEMANGLE_SUPPORT to link in libcxxabi demangling"),x}function ga(x){var D=/\b_Z[\w\d_]+/g;return x.replace(D,function(j){var lt=Eg(j);return j===lt?j:lt+" ["+j+"]"})}var ht={root:null,mounts:[],devices:{},streams:[],nextInode:1,nameTable:null,currentPath:"/",initialized:!1,ignorePermissions:!0,ErrnoError:null,genericErrors:{},filesystems:null,syncFSRequests:0,lookupPath:(x,D={})=>{if(x=vt.resolve(x),!x)return{path:"",node:null};var j={follow_mount:!0,recurse_count:0};if(D=Object.assign(j,D),D.recurse_count>8)throw new ht.ErrnoError(32);for(var lt=x.split("/").filter(Zn=>!!Zn),ut=ht.root,yt="/",Yt=0;Yt40)throw new ht.ErrnoError(32)}}return{path:yt,node:ut}},getPath:x=>{for(var D;;){if(ht.isRoot(x)){var j=x.mount.mountpoint;return D?j[j.length-1]!=="/"?`${j}/${D}`:j+D:j}D=D?`${x.name}/${D}`:x.name,x=x.parent}},hashName:(x,D)=>{for(var j=0,lt=0;lt>>0)%ht.nameTable.length},hashAddNode:x=>{var D=ht.hashName(x.parent.id,x.name);x.name_next=ht.nameTable[D],ht.nameTable[D]=x},hashRemoveNode:x=>{var D=ht.hashName(x.parent.id,x.name);if(ht.nameTable[D]===x)ht.nameTable[D]=x.name_next;else for(var j=ht.nameTable[D];j;){if(j.name_next===x){j.name_next=x.name_next;break}j=j.name_next}},lookupNode:(x,D)=>{var j=ht.mayLookup(x);if(j)throw new ht.ErrnoError(j,x);for(var lt=ht.hashName(x.id,D),ut=ht.nameTable[lt];ut;ut=ut.name_next){var yt=ut.name;if(ut.parent.id===x.id&&yt===D)return ut}return ht.lookup(x,D)},createNode:(x,D,j,lt)=>{Z(typeof x=="object");var ut=new ht.FSNode(x,D,j,lt);return ht.hashAddNode(ut),ut},destroyNode:x=>{ht.hashRemoveNode(x)},isRoot:x=>x===x.parent,isMountpoint:x=>!!x.mounted,isFile:x=>(x&61440)===32768,isDir:x=>(x&61440)===16384,isLink:x=>(x&61440)===40960,isChrdev:x=>(x&61440)===8192,isBlkdev:x=>(x&61440)===24576,isFIFO:x=>(x&61440)===4096,isSocket:x=>(x&49152)===49152,flagsToPermissionString:x=>{var D=["r","w","rw"][x&3];return x&512&&(D+="w"),D},nodePermissions:(x,D)=>ht.ignorePermissions?0:D.includes("r")&&!(x.mode&292)||D.includes("w")&&!(x.mode&146)||D.includes("x")&&!(x.mode&73)?2:0,mayLookup:x=>{var D=ht.nodePermissions(x,"x");return D||(x.node_ops.lookup?0:2)},mayCreate:(x,D)=>{try{var j=ht.lookupNode(x,D);return 20}catch{}return ht.nodePermissions(x,"wx")},mayDelete:(x,D,j)=>{var lt;try{lt=ht.lookupNode(x,D)}catch(yt){return yt.errno}var ut=ht.nodePermissions(x,"wx");if(ut)return ut;if(j){if(!ht.isDir(lt.mode))return 54;if(ht.isRoot(lt)||ht.getPath(lt)===ht.cwd())return 10}else if(ht.isDir(lt.mode))return 31;return 0},mayOpen:(x,D)=>x?ht.isLink(x.mode)?32:ht.isDir(x.mode)&&(ht.flagsToPermissionString(D)!=="r"||D&512)?31:ht.nodePermissions(x,ht.flagsToPermissionString(D)):44,MAX_OPEN_FDS:4096,nextfd:()=>{for(var x=0;x<=ht.MAX_OPEN_FDS;x++)if(!ht.streams[x])return x;throw new ht.ErrnoError(33)},getStreamChecked:x=>{var D=ht.getStream(x);if(!D)throw new ht.ErrnoError(8);return D},getStream:x=>ht.streams[x],createStream:(x,D=-1)=>(ht.FSStream||(ht.FSStream=function(){this.shared={}},ht.FSStream.prototype={},Object.defineProperties(ht.FSStream.prototype,{object:{get(){return this.node},set(j){this.node=j}},isRead:{get(){return(this.flags&2097155)!==1}},isWrite:{get(){return(this.flags&2097155)!==0}},isAppend:{get(){return this.flags&1024}},flags:{get(){return this.shared.flags},set(j){this.shared.flags=j}},position:{get(){return this.shared.position},set(j){this.shared.position=j}}})),x=Object.assign(new ht.FSStream,x),D==-1&&(D=ht.nextfd()),x.fd=D,ht.streams[D]=x,x),closeStream:x=>{ht.streams[x]=null},chrdev_stream_ops:{open:x=>{var D=ht.getDevice(x.node.rdev);x.stream_ops=D.stream_ops,x.stream_ops.open&&x.stream_ops.open(x)},llseek:()=>{throw new ht.ErrnoError(70)}},major:x=>x>>8,minor:x=>x&255,makedev:(x,D)=>x<<8|D,registerDevice:(x,D)=>{ht.devices[x]={stream_ops:D}},getDevice:x=>ht.devices[x],getMounts:x=>{for(var D=[],j=[x];j.length;){var lt=j.pop();D.push(lt),j.push.apply(j,lt.mounts)}return D},syncfs:(x,D)=>{typeof x=="function"&&(D=x,x=!1),ht.syncFSRequests++,ht.syncFSRequests>1&&g(`warning: ${ht.syncFSRequests} FS.syncfs operations in flight at once, probably just doing extra work`);var j=ht.getMounts(ht.root.mount),lt=0;function ut(Yt){return Z(ht.syncFSRequests>0),ht.syncFSRequests--,D(Yt)}function yt(Yt){if(Yt)return yt.errored?void 0:(yt.errored=!0,ut(Yt));++lt>=j.length&&ut(null)}j.forEach(Yt=>{if(!Yt.type.syncfs)return yt(null);Yt.type.syncfs(Yt,x,yt)})},mount:(x,D,j)=>{if(typeof x=="string")throw x;var lt=j==="/",ut=!j,yt;if(lt&&ht.root)throw new ht.ErrnoError(10);if(!lt&&!ut){var Yt=ht.lookupPath(j,{follow_mount:!1});if(j=Yt.path,yt=Yt.node,ht.isMountpoint(yt))throw new ht.ErrnoError(10);if(!ht.isDir(yt.mode))throw new ht.ErrnoError(54)}var Dt={type:x,opts:D,mountpoint:j,mounts:[]},pe=x.mount(Dt);return pe.mount=Dt,Dt.root=pe,lt?ht.root=pe:yt&&(yt.mounted=Dt,yt.mount&&yt.mount.mounts.push(Dt)),pe},unmount:x=>{var D=ht.lookupPath(x,{follow_mount:!1});if(!ht.isMountpoint(D.node))throw new ht.ErrnoError(28);var j=D.node,lt=j.mounted,ut=ht.getMounts(lt);Object.keys(ht.nameTable).forEach(Yt=>{for(var Dt=ht.nameTable[Yt];Dt;){var pe=Dt.name_next;ut.includes(Dt.mount)&&ht.destroyNode(Dt),Dt=pe}}),j.mounted=null;var yt=j.mount.mounts.indexOf(lt);Z(yt!==-1),j.mount.mounts.splice(yt,1)},lookup:(x,D)=>x.node_ops.lookup(x,D),mknod:(x,D,j)=>{var lt=ht.lookupPath(x,{parent:!0}),ut=lt.node,yt=Ta.basename(x);if(!yt||yt==="."||yt==="..")throw new ht.ErrnoError(28);var Yt=ht.mayCreate(ut,yt);if(Yt)throw new ht.ErrnoError(Yt);if(!ut.node_ops.mknod)throw new ht.ErrnoError(63);return ut.node_ops.mknod(ut,yt,D,j)},create:(x,D)=>(D=D!==void 0?D:438,D&=4095,D|=32768,ht.mknod(x,D,0)),mkdir:(x,D)=>(D=D!==void 0?D:511,D&=1023,D|=16384,ht.mknod(x,D,0)),mkdirTree:(x,D)=>{for(var j=x.split("/"),lt="",ut=0;ut(typeof j>"u"&&(j=D,D=438),D|=8192,ht.mknod(x,D,j)),symlink:(x,D)=>{if(!vt.resolve(x))throw new ht.ErrnoError(44);var j=ht.lookupPath(D,{parent:!0}),lt=j.node;if(!lt)throw new ht.ErrnoError(44);var ut=Ta.basename(D),yt=ht.mayCreate(lt,ut);if(yt)throw new ht.ErrnoError(yt);if(!lt.node_ops.symlink)throw new ht.ErrnoError(63);return lt.node_ops.symlink(lt,ut,x)},rename:(x,D)=>{var j=Ta.dirname(x),lt=Ta.dirname(D),ut=Ta.basename(x),yt=Ta.basename(D),Yt,Dt,pe;if(Yt=ht.lookupPath(x,{parent:!0}),Dt=Yt.node,Yt=ht.lookupPath(D,{parent:!0}),pe=Yt.node,!Dt||!pe)throw new ht.ErrnoError(44);if(Dt.mount!==pe.mount)throw new ht.ErrnoError(75);var Te=ht.lookupNode(Dt,ut),en=vt.relative(x,lt);if(en.charAt(0)!==".")throw new ht.ErrnoError(28);if(en=vt.relative(D,j),en.charAt(0)!==".")throw new ht.ErrnoError(55);var Zn;try{Zn=ht.lookupNode(pe,yt)}catch{}if(Te!==Zn){var Rn=ht.isDir(Te.mode),bn=ht.mayDelete(Dt,ut,Rn);if(bn)throw new ht.ErrnoError(bn);if(bn=Zn?ht.mayDelete(pe,yt,Rn):ht.mayCreate(pe,yt),bn)throw new ht.ErrnoError(bn);if(!Dt.node_ops.rename)throw new ht.ErrnoError(63);if(ht.isMountpoint(Te)||Zn&&ht.isMountpoint(Zn))throw new ht.ErrnoError(10);if(pe!==Dt&&(bn=ht.nodePermissions(Dt,"w"),bn))throw new ht.ErrnoError(bn);ht.hashRemoveNode(Te);try{Dt.node_ops.rename(Te,pe,yt)}catch(Xn){throw Xn}finally{ht.hashAddNode(Te)}}},rmdir:x=>{var D=ht.lookupPath(x,{parent:!0}),j=D.node,lt=Ta.basename(x),ut=ht.lookupNode(j,lt),yt=ht.mayDelete(j,lt,!0);if(yt)throw new ht.ErrnoError(yt);if(!j.node_ops.rmdir)throw new ht.ErrnoError(63);if(ht.isMountpoint(ut))throw new ht.ErrnoError(10);j.node_ops.rmdir(j,lt),ht.destroyNode(ut)},readdir:x=>{var D=ht.lookupPath(x,{follow:!0}),j=D.node;if(!j.node_ops.readdir)throw new ht.ErrnoError(54);return j.node_ops.readdir(j)},unlink:x=>{var D=ht.lookupPath(x,{parent:!0}),j=D.node;if(!j)throw new ht.ErrnoError(44);var lt=Ta.basename(x),ut=ht.lookupNode(j,lt),yt=ht.mayDelete(j,lt,!1);if(yt)throw new ht.ErrnoError(yt);if(!j.node_ops.unlink)throw new ht.ErrnoError(63);if(ht.isMountpoint(ut))throw new ht.ErrnoError(10);j.node_ops.unlink(j,lt),ht.destroyNode(ut)},readlink:x=>{var D=ht.lookupPath(x),j=D.node;if(!j)throw new ht.ErrnoError(44);if(!j.node_ops.readlink)throw new ht.ErrnoError(28);return vt.resolve(ht.getPath(j.parent),j.node_ops.readlink(j))},stat:(x,D)=>{var j=ht.lookupPath(x,{follow:!D}),lt=j.node;if(!lt)throw new ht.ErrnoError(44);if(!lt.node_ops.getattr)throw new ht.ErrnoError(63);return lt.node_ops.getattr(lt)},lstat:x=>ht.stat(x,!0),chmod:(x,D,j)=>{var lt;if(typeof x=="string"){var ut=ht.lookupPath(x,{follow:!j});lt=ut.node}else lt=x;if(!lt.node_ops.setattr)throw new ht.ErrnoError(63);lt.node_ops.setattr(lt,{mode:D&4095|lt.mode&-4096,timestamp:Date.now()})},lchmod:(x,D)=>{ht.chmod(x,D,!0)},fchmod:(x,D)=>{var j=ht.getStreamChecked(x);ht.chmod(j.node,D)},chown:(x,D,j,lt)=>{var ut;if(typeof x=="string"){var yt=ht.lookupPath(x,{follow:!lt});ut=yt.node}else ut=x;if(!ut.node_ops.setattr)throw new ht.ErrnoError(63);ut.node_ops.setattr(ut,{timestamp:Date.now()})},lchown:(x,D,j)=>{ht.chown(x,D,j,!0)},fchown:(x,D,j)=>{var lt=ht.getStreamChecked(x);ht.chown(lt.node,D,j)},truncate:(x,D)=>{if(D<0)throw new ht.ErrnoError(28);var j;if(typeof x=="string"){var lt=ht.lookupPath(x,{follow:!0});j=lt.node}else j=x;if(!j.node_ops.setattr)throw new ht.ErrnoError(63);if(ht.isDir(j.mode))throw new ht.ErrnoError(31);if(!ht.isFile(j.mode))throw new ht.ErrnoError(28);var ut=ht.nodePermissions(j,"w");if(ut)throw new ht.ErrnoError(ut);j.node_ops.setattr(j,{size:D,timestamp:Date.now()})},ftruncate:(x,D)=>{var j=ht.getStreamChecked(x);if(!(j.flags&2097155))throw new ht.ErrnoError(28);ht.truncate(j.node,D)},utime:(x,D,j)=>{var lt=ht.lookupPath(x,{follow:!0}),ut=lt.node;ut.node_ops.setattr(ut,{timestamp:Math.max(D,j)})},open:(x,D,j)=>{if(x==="")throw new ht.ErrnoError(44);D=typeof D=="string"?gg(D):D,j=typeof j>"u"?438:j,D&64?j=j&4095|32768:j=0;var lt;if(typeof x=="object")lt=x;else{x=Ta.normalize(x);try{var ut=ht.lookupPath(x,{follow:!(D&131072)});lt=ut.node}catch{}}var yt=!1;if(D&64)if(lt){if(D&128)throw new ht.ErrnoError(20)}else lt=ht.mknod(x,j,0),yt=!0;if(!lt)throw new ht.ErrnoError(44);if(ht.isChrdev(lt.mode)&&(D&=-513),D&65536&&!ht.isDir(lt.mode))throw new ht.ErrnoError(54);if(!yt){var Yt=ht.mayOpen(lt,D);if(Yt)throw new ht.ErrnoError(Yt)}D&512&&!yt&&ht.truncate(lt,0),D&=-131713;var Dt=ht.createStream({node:lt,path:ht.getPath(lt),flags:D,seekable:!0,position:0,stream_ops:lt.stream_ops,ungotten:[],error:!1});return Dt.stream_ops.open&&Dt.stream_ops.open(Dt),n.logReadFiles&&!(D&1)&&(ht.readFiles||(ht.readFiles={}),x in ht.readFiles||(ht.readFiles[x]=1)),Dt},close:x=>{if(ht.isClosed(x))throw new ht.ErrnoError(8);x.getdents&&(x.getdents=null);try{x.stream_ops.close&&x.stream_ops.close(x)}catch(D){throw D}finally{ht.closeStream(x.fd)}x.fd=null},isClosed:x=>x.fd===null,llseek:(x,D,j)=>{if(ht.isClosed(x))throw new ht.ErrnoError(8);if(!x.seekable||!x.stream_ops.llseek)throw new ht.ErrnoError(70);if(j!=0&&j!=1&&j!=2)throw new ht.ErrnoError(28);return x.position=x.stream_ops.llseek(x,D,j),x.ungotten=[],x.position},read:(x,D,j,lt,ut)=>{if(Z(j>=0),lt<0||ut<0)throw new ht.ErrnoError(28);if(ht.isClosed(x))throw new ht.ErrnoError(8);if((x.flags&2097155)===1)throw new ht.ErrnoError(8);if(ht.isDir(x.node.mode))throw new ht.ErrnoError(31);if(!x.stream_ops.read)throw new ht.ErrnoError(28);var yt=typeof ut<"u";if(!yt)ut=x.position;else if(!x.seekable)throw new ht.ErrnoError(70);var Yt=x.stream_ops.read(x,D,j,lt,ut);return yt||(x.position+=Yt),Yt},write:(x,D,j,lt,ut,yt)=>{if(Z(j>=0),lt<0||ut<0)throw new ht.ErrnoError(28);if(ht.isClosed(x))throw new ht.ErrnoError(8);if(!(x.flags&2097155))throw new ht.ErrnoError(8);if(ht.isDir(x.node.mode))throw new ht.ErrnoError(31);if(!x.stream_ops.write)throw new ht.ErrnoError(28);x.seekable&&x.flags&1024&&ht.llseek(x,0,2);var Yt=typeof ut<"u";if(!Yt)ut=x.position;else if(!x.seekable)throw new ht.ErrnoError(70);var Dt=x.stream_ops.write(x,D,j,lt,ut,yt);return Yt||(x.position+=Dt),Dt},allocate:(x,D,j)=>{if(ht.isClosed(x))throw new ht.ErrnoError(8);if(D<0||j<=0)throw new ht.ErrnoError(28);if(!(x.flags&2097155))throw new ht.ErrnoError(8);if(!ht.isFile(x.node.mode)&&!ht.isDir(x.node.mode))throw new ht.ErrnoError(43);if(!x.stream_ops.allocate)throw new ht.ErrnoError(138);x.stream_ops.allocate(x,D,j)},mmap:(x,D,j,lt,ut)=>{if(lt&2&&!(ut&2)&&(x.flags&2097155)!==2)throw new ht.ErrnoError(2);if((x.flags&2097155)===1)throw new ht.ErrnoError(2);if(!x.stream_ops.mmap)throw new ht.ErrnoError(43);return x.stream_ops.mmap(x,D,j,lt,ut)},msync:(x,D,j,lt,ut)=>(Z(j>=0),x.stream_ops.msync?x.stream_ops.msync(x,D,j,lt,ut):0),munmap:x=>0,ioctl:(x,D,j)=>{if(!x.stream_ops.ioctl)throw new ht.ErrnoError(59);return x.stream_ops.ioctl(x,D,j)},readFile:(x,D={})=>{if(D.flags=D.flags||0,D.encoding=D.encoding||"binary",D.encoding!=="utf8"&&D.encoding!=="binary")throw new Error(`Invalid encoding type "${D.encoding}"`);var j,lt=ht.open(x,D.flags),ut=ht.stat(x),yt=ut.size,Yt=new Uint8Array(yt);return ht.read(lt,Yt,0,yt,0),D.encoding==="utf8"?j=GZ(Yt,0):D.encoding==="binary"&&(j=Yt),ht.close(lt),j},writeFile:(x,D,j={})=>{j.flags=j.flags||577;var lt=ht.open(x,j.flags,j.mode);if(typeof D=="string"){var ut=new Uint8Array(Sa(D)+1),yt=_W(D,ut,0,ut.length);ht.write(lt,ut,0,yt,void 0,j.canOwn)}else if(ArrayBuffer.isView(D))ht.write(lt,D,0,D.byteLength,void 0,j.canOwn);else throw new Error("Unsupported data type");ht.close(lt)},cwd:()=>ht.currentPath,chdir:x=>{var D=ht.lookupPath(x,{follow:!0});if(D.node===null)throw new ht.ErrnoError(44);if(!ht.isDir(D.node.mode))throw new ht.ErrnoError(54);var j=ht.nodePermissions(D.node,"x");if(j)throw new ht.ErrnoError(j);ht.currentPath=D.path},createDefaultDirectories:()=>{ht.mkdir("/tmp"),ht.mkdir("/home"),ht.mkdir("/home/web_user")},createDefaultDevices:()=>{ht.mkdir("/dev"),ht.registerDevice(ht.makedev(1,3),{read:()=>0,write:(lt,ut,yt,Yt,Dt)=>Yt}),ht.mkdev("/dev/null",ht.makedev(1,3)),Ai.register(ht.makedev(5,0),Ai.default_tty_ops),Ai.register(ht.makedev(6,0),Ai.default_tty1_ops),ht.mkdev("/dev/tty",ht.makedev(5,0)),ht.mkdev("/dev/tty1",ht.makedev(6,0));var x=new Uint8Array(1024),D=0,j=()=>(D===0&&(D=DV(x).byteLength),x[--D]);ht.createDevice("/dev","random",j),ht.createDevice("/dev","urandom",j),ht.mkdir("/dev/shm"),ht.mkdir("/dev/shm/tmp")},createSpecialDirectories:()=>{ht.mkdir("/proc");var x=ht.mkdir("/proc/self");ht.mkdir("/proc/self/fd"),ht.mount({mount:()=>{var D=ht.createNode(x,"fd",16895,73);return D.node_ops={lookup:(j,lt)=>{var ut=+lt,yt=ht.getStreamChecked(ut),Yt={parent:null,mount:{mountpoint:"fake"},node_ops:{readlink:()=>yt.path}};return Yt.parent=Yt,Yt}},D}},{},"/proc/self/fd")},createStandardStreams:()=>{n.stdin?ht.createDevice("/dev","stdin",n.stdin):ht.symlink("/dev/tty","/dev/stdin"),n.stdout?ht.createDevice("/dev","stdout",null,n.stdout):ht.symlink("/dev/tty","/dev/stdout"),n.stderr?ht.createDevice("/dev","stderr",null,n.stderr):ht.symlink("/dev/tty1","/dev/stderr");var x=ht.open("/dev/stdin",0),D=ht.open("/dev/stdout",1),j=ht.open("/dev/stderr",1);Z(x.fd===0,`invalid handle for stdin (${x.fd})`),Z(D.fd===1,`invalid handle for stdout (${D.fd})`),Z(j.fd===2,`invalid handle for stderr (${j.fd})`)},ensureErrnoError:()=>{ht.ErrnoError||(ht.ErrnoError=function(D,j){this.name="ErrnoError",this.node=j,this.setErrno=function(lt){this.errno=lt;for(var ut in zW)if(zW[ut]===lt){this.code=ut;break}},this.setErrno(D),this.message=KW[D],this.stack&&(Object.defineProperty(this,"stack",{value:new Error().stack,writable:!0}),this.stack=ga(this.stack))},ht.ErrnoError.prototype=new Error,ht.ErrnoError.prototype.constructor=ht.ErrnoError,[44].forEach(x=>{ht.genericErrors[x]=new ht.ErrnoError(x),ht.genericErrors[x].stack=""}))},staticInit:()=>{ht.ensureErrnoError(),ht.nameTable=new Array(4096),ht.mount(ni,{},"/"),ht.createDefaultDirectories(),ht.createDefaultDevices(),ht.createSpecialDirectories(),ht.filesystems={MEMFS:ni}},init:(x,D,j)=>{Z(!ht.init.initialized,"FS.init was previously called. If you want to initialize later with custom parameters, remove any earlier calls (note that one is automatically added to the generated code)"),ht.init.initialized=!0,ht.ensureErrnoError(),n.stdin=x||n.stdin,n.stdout=D||n.stdout,n.stderr=j||n.stderr,ht.createStandardStreams()},quit:()=>{ht.init.initialized=!1,UO(0);for(var x=0;x{var j=ht.analyzePath(x,D);return j.exists?j.object:null},analyzePath:(x,D)=>{try{var j=ht.lookupPath(x,{follow:!D});x=j.path}catch{}var lt={isRoot:!1,exists:!1,error:0,name:null,path:null,object:null,parentExists:!1,parentPath:null,parentObject:null};try{var j=ht.lookupPath(x,{parent:!0});lt.parentExists=!0,lt.parentPath=j.path,lt.parentObject=j.node,lt.name=Ta.basename(x),j=ht.lookupPath(x,{follow:!D}),lt.exists=!0,lt.path=j.path,lt.object=j.node,lt.name=j.node.name,lt.isRoot=j.path==="/"}catch(ut){lt.error=ut.errno}return lt},createPath:(x,D,j,lt)=>{x=typeof x=="string"?x:ht.getPath(x);for(var ut=D.split("/").reverse();ut.length;){var yt=ut.pop();if(yt){var Yt=Ta.join2(x,yt);try{ht.mkdir(Yt)}catch{}x=Yt}}return Yt},createFile:(x,D,j,lt,ut)=>{var yt=Ta.join2(typeof x=="string"?x:ht.getPath(x),D),Yt=QN(lt,ut);return ht.create(yt,Yt)},createDataFile:(x,D,j,lt,ut,yt)=>{var Yt=D;x&&(x=typeof x=="string"?x:ht.getPath(x),Yt=D?Ta.join2(x,D):x);var Dt=QN(lt,ut),pe=ht.create(Yt,Dt);if(j){if(typeof j=="string"){for(var Te=new Array(j.length),en=0,Zn=j.length;en{var ut=Ta.join2(typeof x=="string"?x:ht.getPath(x),D),yt=QN(!!j,!!lt);ht.createDevice.major||(ht.createDevice.major=64);var Yt=ht.makedev(ht.createDevice.major++,0);return ht.registerDevice(Yt,{open:Dt=>{Dt.seekable=!1},close:Dt=>{lt&<.buffer&<.buffer.length&<(10)},read:(Dt,pe,Te,en,Zn)=>{for(var Rn=0,bn=0;bn{for(var Rn=0;Rn{if(x.isDevice||x.isFolder||x.link||x.contents)return!0;if(typeof XMLHttpRequest<"u")throw new Error("Lazy loading should have been performed (contents set) in createLazyFile, but it was not. Lazy loading only works in web workers. Use --embed-file or --preload-file in emcc on the main thread.");if(F)try{x.contents=me(F(x.url),!0),x.usedBytes=x.contents.length}catch{throw new ht.ErrnoError(29)}else throw new Error("Cannot load without read() or XMLHttpRequest.")},createLazyFile:(x,D,j,lt,ut)=>{function yt(){this.lengthKnown=!1,this.chunks=[]}if(yt.prototype.get=function(bn){if(!(bn>this.length-1||bn<0)){var Xn=bn%this.chunkSize,vi=bn/this.chunkSize|0;return this.getter(vi)[Xn]}},yt.prototype.setDataGetter=function(bn){this.getter=bn},yt.prototype.cacheLength=function(){var bn=new XMLHttpRequest;if(bn.open("HEAD",j,!1),bn.send(null),!(bn.status>=200&&bn.status<300||bn.status===304))throw new Error("Couldn't load "+j+". Status: "+bn.status);var Xn=Number(bn.getResponseHeader("Content-length")),vi,Ea=(vi=bn.getResponseHeader("Accept-Ranges"))&&vi==="bytes",Oo=(vi=bn.getResponseHeader("Content-Encoding"))&&vi==="gzip",Le=1024*1024;Ea||(Le=Xn);var kn=(Ya,Nd)=>{if(Ya>Nd)throw new Error("invalid range ("+Ya+", "+Nd+") or no bytes requested!");if(Nd>Xn-1)throw new Error("only "+Xn+" bytes available! programmer error!");var _s=new XMLHttpRequest;if(_s.open("GET",j,!1),Xn!==Le&&_s.setRequestHeader("Range","bytes="+Ya+"-"+Nd),_s.responseType="arraybuffer",_s.overrideMimeType&&_s.overrideMimeType("text/plain; charset=x-user-defined"),_s.send(null),!(_s.status>=200&&_s.status<300||_s.status===304))throw new Error("Couldn't load "+j+". Status: "+_s.status);return _s.response!==void 0?new Uint8Array(_s.response||[]):me(_s.responseText||"",!0)},fa=this;fa.setDataGetter(Ya=>{var Nd=Ya*Le,_s=(Ya+1)*Le-1;if(_s=Math.min(_s,Xn-1),typeof fa.chunks[Ya]>"u"&&(fa.chunks[Ya]=kn(Nd,_s)),typeof fa.chunks[Ya]>"u")throw new Error("doXHR failed!");return fa.chunks[Ya]}),(Oo||!Xn)&&(Le=Xn=1,Xn=this.getter(0).length,Le=Xn,S("LazyFiles on gzip forces download of the whole file when length is accessed")),this._length=Xn,this._chunkSize=Le,this.lengthKnown=!0},typeof XMLHttpRequest<"u"){if(!m)throw"Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";var Yt=new yt;Object.defineProperties(Yt,{length:{get:function(){return this.lengthKnown||this.cacheLength(),this._length}},chunkSize:{get:function(){return this.lengthKnown||this.cacheLength(),this._chunkSize}}});var Dt={isDevice:!1,contents:Yt}}else var Dt={isDevice:!1,url:j};var pe=ht.createFile(x,D,Dt,lt,ut);Dt.contents?pe.contents=Dt.contents:Dt.url&&(pe.contents=null,pe.url=Dt.url),Object.defineProperties(pe,{usedBytes:{get:function(){return this.contents.length}}});var Te={},en=Object.keys(pe.stream_ops);en.forEach(Rn=>{var bn=pe.stream_ops[Rn];Te[Rn]=function(){return ht.forceLoadFile(pe),bn.apply(null,arguments)}});function Zn(Rn,bn,Xn,vi,Ea){var Oo=Rn.node.contents;if(Ea>=Oo.length)return 0;var Le=Math.min(Oo.length-Ea,vi);if(Z(Le>=0),Oo.slice)for(var kn=0;kn(ht.forceLoadFile(pe),Zn(Rn,bn,Xn,vi,Ea)),Te.mmap=(Rn,bn,Xn,vi,Ea)=>{ht.forceLoadFile(pe);var Oo=ia(bn);if(!Oo)throw new ht.ErrnoError(48);return Zn(Rn,E,Oo,bn,Xn),{ptr:Oo,allocated:!0}},pe.stream_ops=Te,pe},absolutePath:()=>{We("FS.absolutePath has been removed; use PATH_FS.resolve instead")},createFolder:()=>{We("FS.createFolder has been removed; use FS.mkdir instead")},createLink:()=>{We("FS.createLink has been removed; use FS.symlink instead")},joinPath:()=>{We("FS.joinPath has been removed; use PATH.join instead")},mmapAlloc:()=>{We("FS.mmapAlloc has been replaced by the top level function mmapAlloc")},standardizePath:()=>{We("FS.standardizePath has been removed; use PATH.normalize instead")}},OV={DEFAULT_POLLMASK:5,calculateAt:function(x,D,j){if(Ta.isAbs(D))return D;var lt;if(x===-100)lt=ht.cwd();else{var ut=OV.getStreamFromFD(x);lt=ut.path}if(D.length==0){if(!j)throw new ht.ErrnoError(44);return lt}return Ta.join2(lt,D)},doStat:function(x,D,j){try{var lt=x(D)}catch(Dt){if(Dt&&Dt.node&&Ta.normalize(D)!==Ta.normalize(ht.getPath(Dt.node)))return-54;throw Dt}_[j>>2]=lt.dev,_[j+4>>2]=lt.mode,P[j+8>>2]=lt.nlink,_[j+12>>2]=lt.uid,_[j+16>>2]=lt.gid,_[j+20>>2]=lt.rdev,ae=[lt.size>>>0,(qn=lt.size,+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[j+24>>2]=ae[0],_[j+28>>2]=ae[1],_[j+32>>2]=4096,_[j+36>>2]=lt.blocks;var ut=lt.atime.getTime(),yt=lt.mtime.getTime(),Yt=lt.ctime.getTime();return ae=[Math.floor(ut/1e3)>>>0,(qn=Math.floor(ut/1e3),+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[j+40>>2]=ae[0],_[j+44>>2]=ae[1],P[j+48>>2]=ut%1e3*1e3,ae=[Math.floor(yt/1e3)>>>0,(qn=Math.floor(yt/1e3),+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[j+56>>2]=ae[0],_[j+60>>2]=ae[1],P[j+64>>2]=yt%1e3*1e3,ae=[Math.floor(Yt/1e3)>>>0,(qn=Math.floor(Yt/1e3),+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[j+72>>2]=ae[0],_[j+76>>2]=ae[1],P[j+80>>2]=Yt%1e3*1e3,ae=[lt.ino>>>0,(qn=lt.ino,+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[j+88>>2]=ae[0],_[j+92>>2]=ae[1],0},doMsync:function(x,D,j,lt,ut){if(!ht.isFile(D.node.mode))throw new ht.ErrnoError(43);if(lt&2)return 0;var yt=I.slice(x,x+j);ht.msync(D,yt,ut,j,lt)},varargs:void 0,get(){Z(OV.varargs!=null),OV.varargs+=4;var x=_[OV.varargs-4>>2];return x},getStr(x){var D=OW(x);return D},getStreamFromFD:function(x){var D=ht.getStreamChecked(x);return D}},Cg=(x,D)=>{var j=0;return $U().forEach(function(lt,ut){var yt=D+j;P[x+ut*4>>2]=yt,v4(lt,yt),j+=lt.length+1}),0},j4=(x,D)=>{var j=$U();P[x>>2]=j.length;var lt=0;return j.forEach(function(ut){lt+=ut.length+1}),P[D>>2]=lt,0};function q4(x){try{var D=OV.getStreamFromFD(x);return ht.close(D),0}catch(j){if(typeof ht>"u"||j.name!=="ErrnoError")throw j;return j.errno}}var $4=(x,D,j,lt)=>{for(var ut=0,yt=0;yt>2],Dt=P[D+4>>2];D+=8;var pe=ht.read(x,E,Yt,Dt,lt);if(pe<0)return-1;if(ut+=pe,pe>2]=yt,0}catch(Yt){if(typeof ht>"u"||Yt.name!=="ErrnoError")throw Yt;return Yt.errno}}function SZ(x,D,j,lt,ut){var yt=Ag(D,j);try{if(isNaN(yt))return 61;var Yt=OV.getStreamFromFD(x);return ht.llseek(Yt,yt,lt),ae=[Yt.position>>>0,(qn=Yt.position,+Math.abs(qn)>=1?qn>0?+Math.floor(qn/4294967296)>>>0:~~+Math.ceil((qn-+(~~qn>>>0))/4294967296)>>>0:0)],_[ut>>2]=ae[0],_[ut+4>>2]=ae[1],Yt.getdents&&yt===0&<===0&&(Yt.getdents=null),0}catch(Dt){if(typeof ht>"u"||Dt.name!=="ErrnoError")throw Dt;return Dt.errno}}var Ng=(x,D,j,lt)=>{for(var ut=0,yt=0;yt>2],Dt=P[D+4>>2];D+=8;var pe=ht.write(x,E,Yt,Dt,lt);if(pe<0)return-1;ut+=pe,typeof lt<"u"&&(lt+=pe)}return ut};function fO(x,D,j,lt){try{var ut=OV.getStreamFromFD(x),yt=Ng(ut,D,j);return P[lt>>2]=yt,0}catch(Yt){if(typeof ht>"u"||Yt.name!=="ErrnoError")throw Yt;return Yt.errno}}var yg=(x,D)=>{for(var j=0,lt=0;lt<=D;j+=x[lt++]);return j},kN=[31,29,31,30,31,30,31,31,30,31,30,31],YN=[31,28,31,30,31,30,31,31,30,31,30,31],Bg=(x,D)=>{for(var j=new Date(x.getTime());D>0;){var lt=wW(j.getFullYear()),ut=j.getMonth(),yt=(lt?kN:YN)[ut];if(D>yt-j.getDate())D-=yt-j.getDate()+1,j.setDate(1),ut<11?j.setMonth(ut+1):(j.setMonth(0),j.setFullYear(j.getFullYear()+1));else return j.setDate(j.getDate()+D),j}return j},xN=(x,D)=>{Z(x.length>=0,"writeArrayToMemory array must have a length (should be an array or typed array)"),E.set(x,D)},tG=(x,D,j,lt)=>{var ut=_[lt+40>>2],yt={tm_sec:_[lt>>2],tm_min:_[lt+4>>2],tm_hour:_[lt+8>>2],tm_mday:_[lt+12>>2],tm_mon:_[lt+16>>2],tm_year:_[lt+20>>2],tm_wday:_[lt+24>>2],tm_yday:_[lt+28>>2],tm_isdst:_[lt+32>>2],tm_gmtoff:_[lt+36>>2],tm_zone:ut?OW(ut):""},Yt=OW(j),Dt={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var pe in Dt)Yt=Yt.replace(new RegExp(pe,"g"),Dt[pe]);var Te=["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],en=["January","February","March","April","May","June","July","August","September","October","November","December"];function Zn(Le,kn,fa){for(var Ya=typeof Le=="number"?Le.toString():Le||"";Ya.length0?1:0}var Ya;return(Ya=fa(Le.getFullYear()-kn.getFullYear()))===0&&(Ya=fa(Le.getMonth()-kn.getMonth()))===0&&(Ya=fa(Le.getDate()-kn.getDate())),Ya}function Xn(Le){switch(Le.getDay()){case 0:return new Date(Le.getFullYear()-1,11,29);case 1:return Le;case 2:return new Date(Le.getFullYear(),0,3);case 3:return new Date(Le.getFullYear(),0,2);case 4:return new Date(Le.getFullYear(),0,1);case 5:return new Date(Le.getFullYear()-1,11,31);case 6:return new Date(Le.getFullYear()-1,11,30)}}function vi(Le){var kn=Bg(new Date(Le.tm_year+1900,0,1),Le.tm_yday),fa=new Date(kn.getFullYear(),0,4),Ya=new Date(kn.getFullYear()+1,0,4),Nd=Xn(fa),_s=Xn(Ya);return bn(Nd,kn)<=0?bn(_s,kn)<=0?kn.getFullYear()+1:kn.getFullYear():kn.getFullYear()-1}var Ea={"%a":Le=>Te[Le.tm_wday].substring(0,3),"%A":Le=>Te[Le.tm_wday],"%b":Le=>en[Le.tm_mon].substring(0,3),"%B":Le=>en[Le.tm_mon],"%C":Le=>{var kn=Le.tm_year+1900;return Rn(kn/100|0,2)},"%d":Le=>Rn(Le.tm_mday,2),"%e":Le=>Zn(Le.tm_mday,2," "),"%g":Le=>vi(Le).toString().substring(2),"%G":Le=>vi(Le),"%H":Le=>Rn(Le.tm_hour,2),"%I":Le=>{var kn=Le.tm_hour;return kn==0?kn=12:kn>12&&(kn-=12),Rn(kn,2)},"%j":Le=>Rn(Le.tm_mday+yg(wW(Le.tm_year+1900)?kN:YN,Le.tm_mon-1),3),"%m":Le=>Rn(Le.tm_mon+1,2),"%M":Le=>Rn(Le.tm_min,2),"%n":()=>` +`,"%p":Le=>Le.tm_hour>=0&&Le.tm_hour<12?"AM":"PM","%S":Le=>Rn(Le.tm_sec,2),"%t":()=>" ","%u":Le=>Le.tm_wday||7,"%U":Le=>{var kn=Le.tm_yday+7-Le.tm_wday;return Rn(Math.floor(kn/7),2)},"%V":Le=>{var kn=Math.floor((Le.tm_yday+7-(Le.tm_wday+6)%7)/7);if((Le.tm_wday+371-Le.tm_yday-2)%7<=2&&kn++,kn){if(kn==53){var Ya=(Le.tm_wday+371-Le.tm_yday)%7;Ya!=4&&(Ya!=3||!wW(Le.tm_year))&&(kn=1)}}else{kn=52;var fa=(Le.tm_wday+7-Le.tm_yday-1)%7;(fa==4||fa==5&&wW(Le.tm_year%400-1))&&kn++}return Rn(kn,2)},"%w":Le=>Le.tm_wday,"%W":Le=>{var kn=Le.tm_yday+7-(Le.tm_wday+6)%7;return Rn(Math.floor(kn/7),2)},"%y":Le=>(Le.tm_year+1900).toString().substring(2),"%Y":Le=>Le.tm_year+1900,"%z":Le=>{var kn=Le.tm_gmtoff,fa=kn>=0;return kn=Math.abs(kn)/60,kn=kn/60*100+kn%60,(fa?"+":"-")+("0000"+kn).slice(-4)},"%Z":Le=>Le.tm_zone,"%%":()=>"%"};Yt=Yt.replace(/%%/g,"\0\0");for(var pe in Ea)Yt.includes(pe)&&(Yt=Yt.replace(new RegExp(pe,"g"),Ea[pe](yt)));Yt=Yt.replace(/\0\0/g,"%");var Oo=me(Yt,!1);return Oo.length>D?0:(xN(Oo,x),Oo.length-1)},sb=(x,D,j,lt,ut)=>tG(x,D,j,lt);function Qg(x){var D=n["_"+x];return Z(D,"Cannot call unknown function "+x+", make sure it is exported"),D}var t8=x=>{var D=Sa(x)+1,j=AO(D);return DW(x,j,D),j},FO=function(x,D,j,lt,ut){var yt={string:Xn=>{var vi=0;return Xn!=null&&Xn!==0&&(vi=t8(Xn)),vi},array:Xn=>{var vi=AO(Xn.length);return xN(Xn,vi),vi}};function Yt(Xn){return D==="string"?OW(Xn):D==="boolean"?!!Xn:Xn}var Dt=Qg(x),pe=[],Te=0;if(Z(D!=="array",'Return type should not be "array".'),lt)for(var en=0;en(rb=Q.emscripten_stack_init)(),nG=()=>(nG=Q.emscripten_stack_get_free)(),iG=()=>(iG=Q.emscripten_stack_get_base)(),qW=()=>(qW=Q.emscripten_stack_get_end)(),$W=Je("stackSave"),o8=Je("stackRestore"),AO=Je("stackAlloc"),a8=()=>(a8=Q.emscripten_stack_get_current)(),rdt=Je("__cxa_increment_exception_refcount"),s8=Je("__cxa_is_pointer_type"),LN=n.dynCall_jiji=Je("dynCall_jiji"),Yg=n.dynCall_viijii=Je("dynCall_viijii"),l8=n.dynCall_iiiiij=Je("dynCall_iiiiij"),Rt=n.dynCall_iiiiijj=Je("dynCall_iiiiijj"),oG=n.dynCall_iiiiiijj=Je("dynCall_iiiiiijj");function xg(x){try{for(var D=atob(x),j=new Uint8Array(D.length),lt=0;lt0||(d8(),Wt(),oe>0))return;function x(){Xg||(Xg=!0,n.calledRun=!0,!J&&(Nt(),i(n),n.onRuntimeInitialized&&n.onRuntimeInitialized(),Z(!n._main,'compiled without a main, but one is present. if you added it from JS, use Module["onRuntimeInitialized"]'),kt()))}n.setStatus?(n.setStatus("Running..."),setTimeout(function(){setTimeout(function(){n.setStatus("")},1),x()},1)):x(),dt()}if(n.preInit)for(typeof n.preInit=="function"&&(n.preInit=[n.preInit]);n.preInit.length>0;)n.preInit.pop()();return TZ(),e.ready}})(),lv=r0e;globalThis.Buffer=globalThis.Buffer||{};var cSt=(lv.hasOwnProperty("then")?lv:Promise.resolve(lv())).then(t=>{let e={find_nearby_indices:{rval:"boolean",params:["number","number"]},getCoveragePositions:{rval:null,params:["number","number","number","number","number"]},inflateEllipsoid:{rval:null,params:["number"]}},n={wasm:t};return Object.keys(e).forEach(i=>{n[i]=e[i].params?t.cwrap(i,e[i].rval,e[i].params):t.cwrap(i,e[i].rval)}),n});var{FinalizationRegistry:c0e}=globalThis,K0={_previousLoad:!1,_instance:void 0,_wasmModule:void 0,_positionPointer:-1,_precisionMode:75,async initInstance(){let t="default";if(!this._previousLoad)try{this._wasmModule=(await cSt).wasm,this._previousLoad=!0}catch(e){throw new Ut(`Failed to load the WASM module: ${e.message}`)}if(!this._instance){let{PositionRegistry:e}=this._wasmModule;this._instance=new e(t)}return{instance:this._instance,wasmModule:this._wasmModule}},get instance(){return this._instance},get wasmModule(){return this._wasmModule},get positionPointer(){return this._positionPointer},update(t){if(!this._instance)return 0;let e=Math.round(t/this._precisionMode)*this._precisionMode;return this._lastUpdate!==e&&(this._lastUpdate=e,this._positionPointer=this._instance.update(e)),this._positionPointer||0},updateJulianDate(t){if(!this._instance)return 0;if(!(t instanceof rt))throw new TypeError("Expected julianDate to be an instance of JulianDate");let e=rt.toDate(t).getTime();return this.update(e)},get precisionMode(){return this._precisionMode},set precisionMode(t){if(typeof t!="number"||t<=0)throw new TypeError("Precision mode must be a positive number.");this._precisionMode=t}},mSt={},JIi=new c0e(t=>{let e=mSt[t];e&&(K0._wasmModule.wasm.removePosition(e),delete mSt[t],console.log(`Entity with ID ${t} has been garbage collected, pointer ${e}`))});var hSt=v.WHITE,pSt=v.BLACK,VSt=0,uSt=1,ZSt=0,RSt=new v,m0e=new p,bSt=new v,WSt=new ln,fSt=new ln,FSt=new Wn,USt=null,qet=null;function GSt(t){this.entity=t,this.pointPrimitive=void 0,this.billboard=void 0,this.color=void 0,this.outlineColor=void 0,this.pixelSize=void 0,this.outlineWidth=void 0}function z0(t,e){e.collectionChanged.addEventListener(z0.prototype._onCollectionChanged,this),this._cluster=t,this._cluster._isReallyDirty=!0,this._entityCollection=e,this._items=new qe,this._wasmItems=[],this._dynamicItems=[],this._onCollectionChanged(e,e.values,[],[]),this._fps=[!1,!1],this._fpsLastUpdate=[Oi(),Oi()]}z0.prototype.needsUpdate=function(t){let e=this._fps[t];if(e){let n=Oi(),i=(n-this._fpsLastUpdate[t])*xi.SECONDS_PER_MILLISECOND>=1/e;return i&&(this._fpsLastUpdate[t]=n),i}return!0};z0.prototype.update=function(t){if(!this.needsUpdate(this._entityCollection?.ThrottleType?.MAX))return!0;let e=this._items.values,n=this._cluster,{wasmModule:i,instance:o,updateJulianDate:a}=K0,s=this._entityCollection.owner?this._entityCollection.owner._wasmModule:null;s&&(s._wasmSatelliteCatalog=this._entityCollection.owner._wasmSatelliteCatalog);let l=this._wasmItems,r=this._dynamicItems;if(!e.length&&!l.length)return!0;if(s&&l.length&&!n._isReallyDirty&&n&&n._pointCollection&&n._pointCollection._pointPrimitives){let m=K0.updateJulianDate(t);m!==qet&&(qet=m,USt=new Float64Array(s.HEAP8.buffer,qet,l.length*3));let h=new p;for(let u=0,R=l.length;u-1&&(p.fromArray(USt,l[u].array_index*3,h),l[u].pointPrimitive&&(l[u].pointPrimitive.position=h),l[u].billboard&&(l[u].billboard.position=h))}let d=this.needsUpdate(this._entityCollection?.ThrottleType?.DYNAMIC)&&r.length;if(!l.length||d||n._isReallyDirty){let m=!n._isReallyDirty&&d?r:e;for(let h=0,u=m.length;h-1&&(R.array_index=V.array_index);let F=V._point,U=R.pointPrimitive,G=R.billboard,A=et.getValueOrDefault(F._heightReference,t,Ge.NONE),S=V.isShowing&&V.isAvailable(t)&&et.getValueOrDefault(F._show,t,!0);U&&(U.show=S);let g=U&&V.array_index>-1?U.position:new p;if(S&&!g&&(g=et.getValueOrUndefined(V._position,t,m0e),S=c(g)),!S){uL(R,V,n);continue}et.isConstant(V._position)||(n._clusterDirty=!0);let C=!1,y=!1;if(A!==Ge.NONE&&!c(G)?(c(U)&&(uL(R,V,n),U=void 0),G=n.getBillboard(V),G.id=V,G.image=void 0,R.billboard=G,C=!0,y=p.equals(G.position,g)&&G.heightReference===A):A===Ge.NONE&&!c(U)&&(c(G)&&(uL(R,V,n),G=void 0),U=n.getPoint(V),U.id=V,R.pointPrimitive=U),c(U))U.show=!0,U.position=g,U.scaleByDistance=et.getValueOrUndefined(F._scaleByDistance,t,WSt),U.translucencyByDistance=et.getValueOrUndefined(F._translucencyByDistance,t,fSt),U.color=et.getValueOrDefault(F._color,t,hSt,RSt),U.outlineColor=et.getValueOrDefault(F._outlineColor,t,pSt,bSt),U.outlineWidth=et.getValueOrDefault(F._outlineWidth,t,VSt),U.pixelSize=et.getValueOrDefault(F._pixelSize,t,uSt),U.distanceDisplayCondition=et.getValueOrUndefined(F._distanceDisplayCondition,t,FSt),U.disableDepthTestDistance=et.getValueOrDefault(F._disableDepthTestDistance,t,ZSt);else if(c(G)){G.show=!0,G.position=g,G.scaleByDistance=et.getValueOrUndefined(F._scaleByDistance,t,WSt),G.translucencyByDistance=et.getValueOrUndefined(F._translucencyByDistance,t,fSt),G.distanceDisplayCondition=et.getValueOrUndefined(F._distanceDisplayCondition,t,FSt),G.disableDepthTestDistance=et.getValueOrDefault(F._disableDepthTestDistance,t,ZSt),G.heightReference=A;let Y=et.getValueOrDefault(F._color,t,hSt,RSt),Q=et.getValueOrDefault(F._outlineColor,t,pSt,bSt),J=Math.round(et.getValueOrDefault(F._outlineWidth,t,VSt)),M=Math.max(1,Math.round(et.getValueOrDefault(F._pixelSize,t,uSt)));if(J>0?(G.scale=1,C=C||J!==R.outlineWidth||M!==R.pixelSize||!v.equals(Y,R.color)||!v.equals(Q,R.outlineColor)):(G.scale=M/50,M=50,C=C||J!==R.outlineWidth||!v.equals(Y,R.color)||!v.equals(Q,R.outlineColor)),C){R.color=v.clone(Y,R.color),R.outlineColor=v.clone(Q,R.outlineColor),R.pixelSize=M,R.outlineWidth=J;let Z=Y.alpha,E=Y.toCssColorString(),I=Q.toCssColorString(),B=JSON.stringify([E,M,I,J]);G.setImage(B,XA(Z,E,I,J,M))}y&&G._updateClamping()}}this._cluster._isReallyDirty=!1}return!0};z0.prototype.getBoundingSphere=function(t,e){let n=this._items.get(t.id);if(!c(n)||!(c(n.pointPrimitive)||c(n.billboard)))return ve.FAILED;if(c(n.pointPrimitive))e.center=p.clone(n.pointPrimitive.position,e.center);else{let i=n.billboard;if(!c(i._clampedPosition))return ve.PENDING;e.center=p.clone(i._clampedPosition,e.center)}return e.radius=0,ve.DONE};z0.prototype.isDestroyed=function(){return!1};z0.prototype.destroy=function(){this._entityCollection.collectionChanged.removeEventListener(z0.prototype._onCollectionChanged,this);let t=this._entityCollection.values;for(let e=0;e{let F=s.get(V.id);if(F&&r.indexOf(F)===-1)if(!V._position.isConstant&&l.indexOf(F)===-1)r.push(F);else for(let U in V._point)V._point[U]?.isConstant===!1&&r.push(F)},h=V=>{r=r.filter(F=>F.entity.id!==V.id)},u=V=>{let F=s.get(V.id);F&&V.wasmSchema&&l.indexOf(F)===-1&&l.push(F),m(V)},R=V=>{l=l.filter(F=>F.entity.id!==V.id),h(V)};for(o=e.length-1;o>-1;o--)a=e[o],c(a._point)&&c(a._position)&&(s.set(a.id,new GSt(a)),u(a));for(o=i.length-1;o>-1;o--)a=i[o],u(a),c(a._point)&&c(a._position)?s.contains(a.id)||s.set(a.id,new GSt(a)):(uL(s.get(a.id),a,d),s.remove(a.id),R(a));for(o=n.length-1;o>-1;o--)a=n[o],uL(s.get(a.id),a,d),s.remove(a.id),R(a);this._cluster._isReallyDirty=!0};function uL(t,e,n){if(c(t)){let i=t.pointPrimitive;if(c(i)){t.pointPrimitive=void 0,n.removePoint(e);return}let o=t.billboard;c(o)&&(t.billboard=void 0,n.removeBillboard(e))}}var ZL=z0;var kNi=b(W(),1);var tNi=b(W(),1);var G1i=b(W(),1);var ESt=[];function h0e(t,e,n,i,o){let a=ESt;a.length=o;let s,l=n.red,r=n.green,d=n.blue,m=n.alpha,h=i.red,u=i.green,R=i.blue,V=i.alpha;if(v.equals(n,i)){for(s=0;s0?new Array(o):void 0;for(i=0;i0){let X=0,_=h[0];i=i.filter(function(P,w){let z=!1;return o?z=w===_||w===0&&_===1:z=w+1===_,z?(X++,_=h[X],!1):!0})}let R=u.length;if(R<2||e<=0)return;if(a===Ln.GEODESIC||a===Ln.RHUMB){let X,_;a===Ln.GEODESIC?(X=k.chordLength(s,l.maximumRadius),_=xo.numberOfPoints):(X=s,_=xo.numberOfPointsRhumbLine);let P=xo.extractHeights(u,l);if(c(i)){let w=1;for(r=0;r0)return Ft.fromPoints(e.positions,t),ve.DONE}return ve.FAILED};bL.prototype.isDestroyed=function(){return!1};bL.prototype.destroy=function(){let e=this._geometryUpdater._scene.id+this._primitives._guid,n=rv[e];c(n)&&(n.remove(this._line),n.length===0&&(this._primitives.removeAndDestroy(n),delete rv[e])),c(this._groundPolylinePrimitive)&&this._groundPrimitives.remove(this._groundPolylinePrimitive),At(this)};var WL=Du;var RNi=b(W(),1);var F0e=new v,U0e=new Wn,G0e=new Wn;function Ou(t,e,n,i,o){let a;n instanceof Cn?a=Ul:a=zl,this.orderedGroundPrimitives=t,this.classificationType=e,this.appearanceType=a,this.materialProperty=n,this.updaters=new qe,this.createPrimitive=!0,this.primitive=void 0,this.oldPrimitive=void 0,this.geometry=new qe,this.material=void 0,this.updatersWithAttributes=new qe,this.attributes=new qe,this.invalidated=!1,this.removeMaterialSubscription=n.definitionChanged.addEventListener(Ou.prototype.onMaterialChanged,this),this.subscriptions=new qe,this.showsUpdated=new qe,this.zIndex=i,this._asynchronous=o}Ou.prototype.onMaterialChanged=function(){this.invalidated=!0};Ou.prototype.isMaterial=function(t){let e=this.materialProperty,n=t.fillMaterialProperty;return n===e||n instanceof Cn&&e instanceof Cn?!0:c(e)&&e.equals(n)};Ou.prototype.add=function(t,e,n){let i=e.id;if(this.updaters.set(i,e),this.geometry.set(i,n),!e.hasConstantFill||!e.fillMaterialProperty.isConstant||!et.isConstant(e.distanceDisplayConditionProperty))this.updatersWithAttributes.set(i,e);else{let o=this;this.subscriptions.set(i,e.entity.definitionChanged.addEventListener(function(a,s,l,r){s==="isShowing"&&o.showsUpdated.set(e.id,e)}))}this.createPrimitive=!0};Ou.prototype.remove=function(t){let e=t.id;if(this.createPrimitive=this.geometry.remove(e)||this.createPrimitive,this.updaters.remove(e)){this.updatersWithAttributes.remove(e);let n=this.subscriptions.get(e);return c(n)&&(n(),this.subscriptions.remove(e)),!0}return!1};Ou.prototype.update=function(t){let e=!0,n=this.primitive,i=this.orderedGroundPrimitives,o=this.geometry.values,a;if(this.createPrimitive){if(o.length>0)c(n)&&(c(this.oldPrimitive)?i.remove(n):this.oldPrimitive=n),n=new Gh({show:!1,asynchronous:this._asynchronous,geometryInstances:o.slice(),appearance:new this.appearanceType,classificationType:this.classificationType}),this.appearanceType===zl&&(this.material=Ua.getValue(t,this.materialProperty,this.material),n.appearance.material=this.material),i.add(n,this.zIndex),e=!1;else{c(n)&&(i.remove(n),n=void 0);let l=this.oldPrimitive;c(l)&&(i.remove(l),this.oldPrimitive=void 0)}this.attributes.removeAll(),this.primitive=n,this.createPrimitive=!1}else if(c(n)&&n.ready){n.show=!0,c(this.oldPrimitive)&&(i.remove(this.oldPrimitive),this.oldPrimitive=void 0),this.appearanceType===zl&&(this.material=Ua.getValue(t,this.materialProperty,this.material),this.primitive.appearance.material=this.material);let s=this.updatersWithAttributes.values,l=s.length;for(a=0;a=0;i--){let o=e[i];if(o.remove(t)){o.updaters.length===0&&(e.splice(i,1),o.destroy());break}}};EI.prototype.update=function(t){let e,n=this._items,i=n.length;for(e=i-1;e>=0;e--){let a=n[e];if(a.invalidated){n.splice(e,1);let s=a.updaters.values,l=s.length;for(let r=0;r-1;l--)r=s[l],d=r.id,m=this._updaters.get(d),m.entity===r?(BSt(this,m),QSt(this,t,m)):(o.push(r),n.push(r));for(l=o.length-1;l>-1;l--)r=o[l],d=r.id,m=this._updaters.get(d),BSt(this,m),m.destroy(),this._updaters.remove(d),this._subscriptions.get(d)(),this._subscriptions.remove(d);for(l=n.length-1;l>-1;l--)r=n[l],d=r.id,m=new WL(r,this._scene),this._updaters.set(d,m),QSt(this,t,m),this._subscriptions.set(d,m.geometryChanged.addEventListener(bR._onGeometryChanged,this));e.removeAll(),i.removeAll(),a.removeAll();let h=!0,u=this._batches,R=u.length;for(l=0;l-1;s--)r=n[s],l=r.id,i.remove(l)||(o.set(l,r),a.remove(l));for(s=e.length-1;s>-1;s--)r=e[s],l=r.id,o.remove(l)?a.set(l,r):i.set(l,r)};var FL=bR;function wm(t){Nc.initializeTerrainHeights(),Gh.initializeTerrainHeights();let e=t.scene,n=t.dataSourceCollection;this._eventHelper=new rl,this._eventHelper.add(n.dataSourceAdded,this._onDataSourceAdded,this),this._eventHelper.add(n.dataSourceRemoved,this._onDataSourceRemoved,this),this._eventHelper.add(n.dataSourceMoved,this._onDataSourceMoved,this),this._eventHelper.add(e.postRender,this._postRender,this),this._dataSourceCollection=n,this._scene=e,this._visualizersCallback=f(t.visualizersCallback,wm.defaultVisualizersCallback);let i=!1,o=new Dm,a=new Dm;n.length>0&&(e.primitives.add(o),e.groundPrimitives.add(a),i=!0),this._primitives=o,this._groundPrimitives=a;for(let d=0,m=n.length;dnew o(t,i))]};Object.defineProperties(wm.prototype,{scene:{get:function(){return this._scene}},dataSources:{get:function(){return this._dataSourceCollection}},defaultDataSource:{get:function(){return this._defaultDataSource}},ready:{get:function(){return this._ready}}});wm.prototype.isDestroyed=function(){return!1};wm.prototype.destroy=function(){this._eventHelper.removeAll();let t=this._dataSourceCollection;for(let e=0,n=t.length;eI0e*s.maximumRadius?(h=XSt,p.normalize(r,h),p.negate(h,h),R=p.clone(p.UNIT_Z,tnt),u=p.cross(R,h,dv),p.magnitude(u)>k.EPSILON7&&(p.normalize(h,h),p.normalize(u,u),R=p.cross(h,u,tnt),p.normalize(R,R),d=!0)):p.equalsEpsilon(r,g,k.EPSILON7)||(R=XSt,p.normalize(Q,R),p.normalize(J,J),u=p.cross(R,J,tnt),m&&(u=p.multiplyByScalar(u,-1,u)),p.equalsEpsilon(u,p.ZERO,k.EPSILON7)||(h=p.cross(u,R,dv),ot.multiplyByVector(Y,h,h),ot.multiplyByVector(Y,u,u),ot.multiplyByVector(Y,R,R),p.normalize(h,h),p.normalize(u,u),p.normalize(R,R),d=!0))}}c(t.boundingSphere)&&(r=t.boundingSphere.center);let U,G,A;i&&(U=p.clone(e.position,ent),G=p.clone(e.direction,JSt),A=p.clone(e.up,LSt));let S=C0e;d?(S[0]=h.x,S[1]=h.y,S[2]=h.z,S[3]=0,S[4]=u.x,S[5]=u.y,S[6]=u.z,S[7]=0,S[8]=R.x,S[9]=R.y,S[10]=R.z,S[11]=0,S[12]=r.x,S[13]=r.y,S[14]=r.z,S[15]=0):Pe.eastNorthUpToFixedFrame(r,s,S),e._setTransform(S),i&&(p.clone(U,e.position),p.clone(G,e.direction),p.clone(A,e.up),p.cross(G,A,e.right))}if(n){let d=l===Vt.SCENE2D||p.equals(t._offset3D,p.ZERO)?void 0:t._offset3D;e.lookAtTransform(e.transform,d)}}function GL(t,e,n){this.entity=t,this.scene=e,this.ellipsoid=f(n,mt.WGS84),this.boundingSphere=void 0,this._lastEntity=void 0,this._mode=void 0,this._lastCartesian=new p,this._defaultOffset3D=void 0,this._offset3D=new p}Object.defineProperties(GL,{defaultOffset3D:{get:function(){return this._defaultOffset3D},set:function(t){this._defaultOffset3D=p.clone(t,new p)}}});GL.defaultOffset3D=new p(-14e3,3500,3500);var UL=new uV,y0e=new p;GL.prototype.update=function(t,e){let n=this.scene,i=this.ellipsoid,o=n.mode;if(o===Vt.MORPHING)return;let a=this.entity,s=a.position;if(!c(s))return;let l=a!==this._lastEntity,r=o!==this._mode,d=n.camera,m=l||r,h=!0;if(l){let u=a.viewFrom,R=c(u);if(!R&&c(e)){UL.pitch=-k.PI_OVER_FOUR,UL.range=0;let V=s.getValue(t,y0e);if(c(V)){let F=2-1/Math.max(1,p.magnitude(V)/i.maximumRadius);UL.pitch*=F,UL.range=p.magnitude(V)*.05}d.viewBoundingSphere(e,UL),this.boundingSphere=e,m=!1,h=!1}else(!R||!c(u.getValue(t,this._offset3D)))&&p.clone(GL._defaultOffset3D,this._offset3D)}else!r&&this._mode!==Vt.SCENE2D&&p.clone(d.position,this._offset3D);this._lastEntity=a,this._mode=o,N0e(this,d,m,h,s,t,i)};var AL=GL;var qBi=b(W(),1);var gyi=b(W(),1);function TL(){this._cache={}}TL.prototype.fromColor=function(t,e){return cv(void 0,void 0,t,e,this._cache)};TL.prototype.fromUrl=function(t,e,n){return cv(t,void 0,e,n,this._cache)};TL.prototype.fromMakiIconId=function(t,e,n){return cv(Dn(`Assets/Textures/maki/${encodeURIComponent(t)}.png`),void 0,e,n,this._cache)};TL.prototype.fromText=function(t,e,n){return cv(void 0,t,e,n,this._cache)};var B0e=new v;function Q0e(t,e,n){t.save(),t.scale(n/24,n/24),t.fillStyle=e.toCssColorString(),t.strokeStyle=e.brighten(.6,B0e).toCssColorString(),t.lineWidth=.846,t.beginPath(),t.moveTo(6.72,.422),t.lineTo(17.28,.422),t.bezierCurveTo(18.553,.422,19.577,1.758,19.577,3.415),t.lineTo(19.577,10.973),t.bezierCurveTo(19.577,12.63,18.553,13.966,17.282,13.966),t.lineTo(14.386,14.008),t.lineTo(11.826,23.578),t.lineTo(9.614,14.008),t.lineTo(6.719,13.965),t.bezierCurveTo(5.446,13.983,4.422,12.629,4.422,10.972),t.lineTo(4.422,3.416),t.bezierCurveTo(4.423,1.76,5.447,.423,6.718,.423),t.closePath(),t.fill(),t.stroke(),t.restore()}function MSt(t,e,n){let i=n/2.5,o=i,a=i;e.width>e.height?a=i*(e.height/e.width):e.width${i}${wSt(o)}`:n+=`${i}${o}`)}return n.length>0&&(n=`${n}
`),n}function M0e(t,e,n){let i;return function(o,a){return c(i)||(i=t(e,n)),i}}function _0e(t,e){return new Sh(M0e(wSt,t,e),!0)}function pv(t,e,n){let i=t.id;if(!c(i)||t.type!=="Feature")i=Ti();else{let s=2,l=i;for(;c(e.getById(l));)l=`${i}_${s}`,s++;i=l}let o=e.getOrCreateEntity(i),a=t.properties;if(c(a)){o.properties=a;let s,l=a.title;if(c(l))o.name=l,s="title";else{let d=Number.MAX_VALUE;for(let m in a)if(a.hasOwnProperty(m)&&a[m]){let h=m.toLowerCase();if(d>1&&h==="title"){d=1,s=m;break}else d>2&&h==="name"?(d=2,s=m):d>3&&/title/i.test(m)?(d=3,s=m):d>4&&/name/i.test(m)&&(d=4,s=m)}c(s)&&(o.name=a[s])}let r=a.description;r!==null&&(o.description=c(r)?new Ii(r):n(a,s))}return o}function pnt(t,e){let n=new Array(t.length);for(let i=0;i2?d.perPositionHeight=new Ii(!0):o.clampToGround||(d.height=0);let u=pv(e,t._entityCollection,o.describe);u.polygon=d}function oTt(t,e,n,i,o){iTt(t,e,i,n.coordinates,o)}function aTt(t,e,n,i,o){let a=n.coordinates;for(let s=0;se&&(n==null?(n="…",i=3):i=n.length,t=t.substring(0,e-i)+n),t}function cs(t,e){for(var n=t.length-1;n>=0;n--)t[n]===e&&t.splice(n,1)}function xF(t,e){for(var n=t.length-1;n>=0;n--)e(t[n])===!0&&t.splice(n,1)}function XF(t){throw new Error("Unhandled case for value: '".concat(t,"'"))}var FQi=b(W());var rQi=b(W());var aQi=b(W()),JF=/[A-Za-z]/,Ir=/[\d]/;var Hh=/\s/,Vv=/['"]/,mTt=/[\x00-\x1F\x7F]/,hTt=/A-Za-z\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FD5\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC/.source,w0e=/\u2700-\u27bf\udde6-\uddff\ud800-\udbff\udc00-\udfff\ufe0e\ufe0f\u0300-\u036f\ufe20-\ufe23\u20d0-\u20f0\ud83c\udffb-\udfff\u200d\u3299\u3297\u303d\u3030\u24c2\ud83c\udd70-\udd71\udd7e-\udd7f\udd8e\udd91-\udd9a\udde6-\uddff\ude01-\ude02\ude1a\ude2f\ude32-\ude3a\ude50-\ude51\u203c\u2049\u25aa-\u25ab\u25b6\u25c0\u25fb-\u25fe\u00a9\u00ae\u2122\u2139\udc04\u2600-\u26FF\u2b05\u2b06\u2b07\u2b1b\u2b1c\u2b50\u2b55\u231a\u231b\u2328\u23cf\u23e9-\u23f3\u23f8-\u23fa\udccf\u2935\u2934\u2190-\u21ff/.source,P0e=/\u0300-\u036F\u0483-\u0489\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u0610-\u061A\u064B-\u065F\u0670\u06D6-\u06DC\u06DF-\u06E4\u06E7\u06E8\u06EA-\u06ED\u0711\u0730-\u074A\u07A6-\u07B0\u07EB-\u07F3\u0816-\u0819\u081B-\u0823\u0825-\u0827\u0829-\u082D\u0859-\u085B\u08D4-\u08E1\u08E3-\u0903\u093A-\u093C\u093E-\u094F\u0951-\u0957\u0962\u0963\u0981-\u0983\u09BC\u09BE-\u09C4\u09C7\u09C8\u09CB-\u09CD\u09D7\u09E2\u09E3\u0A01-\u0A03\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A70\u0A71\u0A75\u0A81-\u0A83\u0ABC\u0ABE-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AE2\u0AE3\u0B01-\u0B03\u0B3C\u0B3E-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B62\u0B63\u0B82\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD7\u0C00-\u0C03\u0C3E-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C62\u0C63\u0C81-\u0C83\u0CBC\u0CBE-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CE2\u0CE3\u0D01-\u0D03\u0D3E-\u0D44\u0D46-\u0D48\u0D4A-\u0D4D\u0D57\u0D62\u0D63\u0D82\u0D83\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DF2\u0DF3\u0E31\u0E34-\u0E3A\u0E47-\u0E4E\u0EB1\u0EB4-\u0EB9\u0EBB\u0EBC\u0EC8-\u0ECD\u0F18\u0F19\u0F35\u0F37\u0F39\u0F3E\u0F3F\u0F71-\u0F84\u0F86\u0F87\u0F8D-\u0F97\u0F99-\u0FBC\u0FC6\u102B-\u103E\u1056-\u1059\u105E-\u1060\u1062-\u1064\u1067-\u106D\u1071-\u1074\u1082-\u108D\u108F\u109A-\u109D\u135D-\u135F\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17B4-\u17D3\u17DD\u180B-\u180D\u1885\u1886\u18A9\u1920-\u192B\u1930-\u193B\u1A17-\u1A1B\u1A55-\u1A5E\u1A60-\u1A7C\u1A7F\u1AB0-\u1ABE\u1B00-\u1B04\u1B34-\u1B44\u1B6B-\u1B73\u1B80-\u1B82\u1BA1-\u1BAD\u1BE6-\u1BF3\u1C24-\u1C37\u1CD0-\u1CD2\u1CD4-\u1CE8\u1CED\u1CF2-\u1CF4\u1CF8\u1CF9\u1DC0-\u1DF5\u1DFB-\u1DFF\u20D0-\u20F0\u2CEF-\u2CF1\u2D7F\u2DE0-\u2DFF\u302A-\u302F\u3099\u309A\uA66F-\uA672\uA674-\uA67D\uA69E\uA69F\uA6F0\uA6F1\uA802\uA806\uA80B\uA823-\uA827\uA880\uA881\uA8B4-\uA8C5\uA8E0-\uA8F1\uA926-\uA92D\uA947-\uA953\uA980-\uA983\uA9B3-\uA9C0\uA9E5\uAA29-\uAA36\uAA43\uAA4C\uAA4D\uAA7B-\uAA7D\uAAB0\uAAB2-\uAAB4\uAAB7\uAAB8\uAABE\uAABF\uAAC1\uAAEB-\uAAEF\uAAF5\uAAF6\uABE3-\uABEA\uABEC\uABED\uFB1E\uFE00-\uFE0F\uFE20-\uFE2F/.source,v0e=hTt+w0e+P0e,pTt=/0-9\u0660-\u0669\u06F0-\u06F9\u07C0-\u07C9\u0966-\u096F\u09E6-\u09EF\u0A66-\u0A6F\u0AE6-\u0AEF\u0B66-\u0B6F\u0BE6-\u0BEF\u0C66-\u0C6F\u0CE6-\u0CEF\u0D66-\u0D6F\u0DE6-\u0DEF\u0E50-\u0E59\u0ED0-\u0ED9\u0F20-\u0F29\u1040-\u1049\u1090-\u1099\u17E0-\u17E9\u1810-\u1819\u1946-\u194F\u19D0-\u19D9\u1A80-\u1A89\u1A90-\u1A99\u1B50-\u1B59\u1BB0-\u1BB9\u1C40-\u1C49\u1C50-\u1C59\uA620-\uA629\uA8D0-\uA8D9\uA900-\uA909\uA9D0-\uA9D9\uA9F0-\uA9F9\uAA50-\uAA59\uABF0-\uABF9\uFF10-\uFF19/.source,iQi=new RegExp("[".concat(hTt+pTt,"]")),Vnt=v0e+pTt,Hu=new RegExp("[".concat(Vnt,"]"));var uv=function(){function t(e){e===void 0&&(e={}),this.tagName="",this.attrs={},this.innerHTML="",this.tagName=e.tagName||"",this.attrs=e.attrs||{},this.innerHTML=e.innerHtml||e.innerHTML||""}return t.prototype.setTagName=function(e){return this.tagName=e,this},t.prototype.getTagName=function(){return this.tagName||""},t.prototype.setAttr=function(e,n){var i=this.getAttrs();return i[e]=n,this},t.prototype.getAttr=function(e){return this.getAttrs()[e]},t.prototype.setAttrs=function(e){return Object.assign(this.getAttrs(),e),this},t.prototype.getAttrs=function(){return this.attrs||(this.attrs={})},t.prototype.setClass=function(e){return this.setAttr("class",e)},t.prototype.addClass=function(e){for(var n=this.getClass(),i=n?n.split(Hh):[],o=e.split(Hh),a;a=o.shift();)i.indexOf(a)===-1&&i.push(a);return this.getAttrs().class=i.join(" "),this},t.prototype.removeClass=function(e){for(var n=this.getClass(),i=n?n.split(Hh):[],o=e.split(Hh),a;i.length&&(a=o.shift());){var s=i.indexOf(a);s!==-1&&i.splice(s,1)}return this.getAttrs().class=i.join(" "),this},t.prototype.getClass=function(){return this.getAttrs().class||""},t.prototype.hasClass=function(e){return(" "+this.getClass()+" ").indexOf(" "+e+" ")!==-1},t.prototype.setInnerHTML=function(e){return this.innerHTML=e,this},t.prototype.setInnerHtml=function(e){return this.setInnerHTML(e)},t.prototype.getInnerHTML=function(){return this.innerHTML||""},t.prototype.getInnerHtml=function(){return this.getInnerHTML()},t.prototype.toAnchorString=function(){var e=this.getTagName(),n=this.buildAttrsStr();return n=n?" "+n:"",["<",e,n,">",this.getInnerHtml(),""].join("")},t.prototype.buildAttrsStr=function(){if(!this.attrs)return"";var e=this.getAttrs(),n=[];for(var i in e)e.hasOwnProperty(i)&&n.push(i+'="'+e[i]+'"');return n.join(" ")},t}();var cQi=b(W());function VTt(t,e,n){var i,o;n==null?(n="…",o=3,i=8):(o=n.length,i=n.length);var a=function(A){var S={},g=A,C=g.match(/^([a-z]+):\/\//i);return C&&(S.scheme=C[1],g=g.substr(C[0].length)),C=g.match(/^(.*?)(?=(\?|#|\/|$))/i),C&&(S.host=C[1],g=g.substr(C[0].length)),C=g.match(/^\/(.*?)(?=(\?|#|$))/i),C&&(S.path=C[1],g=g.substr(C[0].length)),C=g.match(/^\?(.*?)(?=(#|$))/i),C&&(S.query=C[1],g=g.substr(C[0].length)),C=g.match(/^#(.*?)$/i),C&&(S.fragment=C[1]),S},s=function(A){var S="";return A.scheme&&A.host&&(S+=A.scheme+"://"),A.host&&(S+=A.host),A.path&&(S+="/"+A.path),A.query&&(S+="?"+A.query),A.fragment&&(S+="#"+A.fragment),S},l=function(A,S){var g=S/2,C=Math.ceil(g),y=-1*Math.floor(g),Y="";return y<0&&(Y=A.substr(y)),A.substr(0,C)+n+Y};if(t.length<=e)return t;var r=e-o,d=a(t);if(d.query){var m=d.query.match(/^(.*?)(?=(\?|\#))(.*?)$/i);m&&(d.query=d.query.substr(0,m[1].length),t=s(d))}if(t.length<=e||(d.host&&(d.host=d.host.replace(/^www\./,""),t=s(d)),t.length<=e))return t;var h="";if(d.host&&(h+=d.host),h.length>=r)return d.host.length==e?(d.host.substr(0,e-o)+n).substr(0,r+i):l(h,r).substr(0,r+i);var u="";if(d.path&&(u+="/"+d.path),d.query&&(u+="?"+d.query),u)if((h+u).length>=r){if((h+u).length==e)return(h+u).substr(0,e);var R=r-h.length;return(h+l(u,R)).substr(0,r+i)}else h+=u;if(d.fragment){var V="#"+d.fragment;if((h+V).length>=r){if((h+V).length==e)return(h+V).substr(0,e);var F=r-h.length;return(h+l(V,F)).substr(0,r+i)}else h+=V}if(d.scheme&&d.host){var U=d.scheme+"://";if((h+U).length0&&(G=h.substr(-1*Math.floor(r/2))),(h.substr(0,Math.ceil(r/2))+n+G).substr(0,r+i)}var hQi=b(W());function uTt(t,e,n){if(t.length<=e)return t;var i,o;n==null?(n="…",i=8,o=3):(i=n.length,o=n.length);var a=e-o,s="";return a>0&&(s=t.substr(-1*Math.floor(a/2))),(t.substr(0,Math.ceil(a/2))+n+s).substr(0,a+i)}var uQi=b(W());function ZTt(t,e,n){return cTt(t,e,n)}var RTt=function(){function t(e){e===void 0&&(e={}),this.newWindow=!1,this.truncate={},this.className="",this.newWindow=e.newWindow||!1,this.truncate=e.truncate||{},this.className=e.className||""}return t.prototype.build=function(e){return new uv({tagName:"a",attrs:this.createAttrs(e),innerHtml:this.processAnchorText(e.getAnchorText())})},t.prototype.createAttrs=function(e){var n={href:e.getAnchorHref()},i=this.createCssClass(e);return i&&(n.class=i),this.newWindow&&(n.target="_blank",n.rel="noopener noreferrer"),this.truncate&&this.truncate.length&&this.truncate.length=0;R--){var V=m[R];switch(V.state){case 11:y(V,u);break;case 12:Y(V,u);break;case 0:G(V,u);break;case 1:A(V,u);break;case 2:S(V,u);break;case 3:g(V,u);break;case 4:C(V,u);break;case 5:Q(V,u);break;case 6:J(V,u);break;case 7:M(V,u);break;case 13:Z(V,u);break;case 14:E(V,u);break;case 8:I(V,u);break;case 9:B(V,u);break;case 10:X(V,u);break;case 15:_(V,u);break;case 16:P(V,u);break;case 17:w(V,u);break;case 18:z(V,u);break;case 19:H(V,u);break;case 20:nt(V,u);break;case 21:$(V,u);break;case 22:dt(V,u);break;case 23:q(V,u);break;case 24:at(V,u);break;case 25:st(V,u);break;case 26:Et(V,u);break;case 27:Qt(V,u);break;case 28:Wt(V,u);break;case 29:Nt(V,u);break;case 30:kt(V,u);break;case 31:Mt(V,u);break;case 32:ie(V,u);break;case 33:oe(V,u);break;case 34:He(V,u);break;case 35:rn(V,u);break;case 36:de(V,u);break;case 37:qt(V,u);break;case 38:zt(V,u);break;case 39:ke(V,u);break;case 40:Ve(V,u);break;case 41:We(V,u);break;default:XF(V.state)}}}for(var F=m.length-1;F>=0;F--)m.forEach(function(Ct){return Vn(Ct)});return r;function U(Ct){if(Ct==="#")m.push(GWe(h,28));else if(Ct==="@")m.push(AWe(h,30));else if(Ct==="/")m.push(Ant(h,11));else if(Ct==="+")m.push(Snt(h,37));else if(Ct==="(")m.push(Snt(h,32));else{if(Ir.test(Ct)&&(m.push(Snt(h,38)),m.push(FWe(h,13))),gTt(Ct)){var _t=Ct.toLowerCase()==="m"?15:22;m.push(UWe(h,_t))}Zv(Ct)&&m.push(Gnt(h,0)),Hu.test(Ct)&&m.push(Ant(h,5))}}function G(Ct,_t){_t===":"?Ct.state=2:_t==="-"?Ct.state=1:Rnt(_t)||cs(m,Ct)}function A(Ct,_t){_t==="-"||(_t==="/"?(cs(m,Ct),m.push(Ant(h,11))):Rnt(_t)?Ct.state=0:cs(m,Ct))}function S(Ct,_t){_t==="/"?Ct.state=3:_t==="."?cs(m,Ct):$0(_t)?(Ct.state=5,Zv(_t)&&m.push(Gnt(h,0))):cs(m,Ct)}function g(Ct,_t){_t==="/"?Ct.state=4:bnt(_t)?(Ct.state=10,Ct.acceptStateReached=!0):Vn(Ct)}function C(Ct,_t){_t==="/"?Ct.state=10:$0(_t)?(Ct.state=5,Ct.acceptStateReached=!0):cs(m,Ct)}function y(Ct,_t){_t==="/"?Ct.state=12:cs(m,Ct)}function Y(Ct,_t){$0(_t)?Ct.state=5:cs(m,Ct)}function Q(Ct,_t){_t==="."?Ct.state=7:_t==="-"?Ct.state=6:_t===":"?Ct.state=8:bv(_t)?Ct.state=10:Rv(_t)||Vn(Ct)}function J(Ct,_t){_t==="-"||(_t==="."?Vn(Ct):$0(_t)?Ct.state=5:Vn(Ct))}function M(Ct,_t){_t==="."?Vn(Ct):$0(_t)?(Ct.state=5,Ct.acceptStateReached=!0):Vn(Ct)}function Z(Ct,_t){_t==="."?Ct.state=14:_t===":"?Ct.state=8:Ir.test(_t)||(bv(_t)?Ct.state=10:Hu.test(_t)?cs(m,Ct):Vn(Ct))}function E(Ct,_t){Ir.test(_t)?(Ct.octetsEncountered++,Ct.octetsEncountered===4&&(Ct.acceptStateReached=!0),Ct.state=13):Vn(Ct)}function I(Ct,_t){Ir.test(_t)?Ct.state=9:Vn(Ct)}function B(Ct,_t){Ir.test(_t)||(bv(_t)?Ct.state=10:Vn(Ct))}function X(Ct,_t){bnt(_t)||Vn(Ct)}function _(Ct,_t){_t.toLowerCase()==="a"?Ct.state=16:dt(Ct,_t)}function P(Ct,_t){_t.toLowerCase()==="i"?Ct.state=17:dt(Ct,_t)}function w(Ct,_t){_t.toLowerCase()==="l"?Ct.state=18:dt(Ct,_t)}function z(Ct,_t){_t.toLowerCase()==="t"?Ct.state=19:dt(Ct,_t)}function H(Ct,_t){_t.toLowerCase()==="o"?Ct.state=20:dt(Ct,_t)}function nt(Ct,_t){_t.toLowerCase()===":"?Ct.state=21:dt(Ct,_t)}function $(Ct,_t){Wv(_t)?Ct.state=22:cs(m,Ct)}function dt(Ct,_t){_t==="."?Ct.state=23:_t==="@"?Ct.state=24:Wv(_t)?Ct.state=22:cs(m,Ct)}function q(Ct,_t){_t==="."?cs(m,Ct):_t==="@"?cs(m,Ct):Wv(_t)?Ct.state=22:cs(m,Ct)}function at(Ct,_t){$0(_t)?Ct.state=25:cs(m,Ct)}function st(Ct,_t){_t==="."?Ct.state=27:_t==="-"?Ct.state=26:Rv(_t)||Vn(Ct)}function Et(Ct,_t){_t==="-"||_t==="."?Vn(Ct):Rv(_t)?Ct.state=25:Vn(Ct)}function Qt(Ct,_t){_t==="."||_t==="-"?Vn(Ct):$0(_t)?(Ct.state=25,Ct.acceptStateReached=!0):Vn(Ct)}function Wt(Ct,_t){fnt(_t)?(Ct.state=29,Ct.acceptStateReached=!0):cs(m,Ct)}function Nt(Ct,_t){fnt(_t)||Vn(Ct)}function kt(Ct,_t){Fnt(_t)?(Ct.state=31,Ct.acceptStateReached=!0):cs(m,Ct)}function Mt(Ct,_t){Fnt(_t)||(Hu.test(_t)?cs(m,Ct):Vn(Ct))}function qt(Ct,_t){Ir.test(_t)?Ct.state=38:(cs(m,Ct),U(_t))}function ie(Ct,_t){Ir.test(_t)?Ct.state=33:cs(m,Ct),U(_t)}function oe(Ct,_t){Ir.test(_t)?Ct.state=34:cs(m,Ct)}function He(Ct,_t){Ir.test(_t)?Ct.state=35:cs(m,Ct)}function rn(Ct,_t){_t===")"?Ct.state=36:cs(m,Ct)}function de(Ct,_t){Ir.test(_t)?Ct.state=38:Unt(_t)?Ct.state=39:cs(m,Ct)}function zt(Ct,_t){Ct.acceptStateReached=!0,fv(_t)?Ct.state=40:_t==="#"?Ct.state=41:Ir.test(_t)||(_t==="("?Ct.state=32:Unt(_t)?Ct.state=39:(Vn(Ct),Zv(_t)&&m.push(Gnt(h,0))))}function ke(Ct,_t){Ir.test(_t)?Ct.state=38:_t==="("?Ct.state=32:(Vn(Ct),U(_t))}function Ve(Ct,_t){fv(_t)||(_t==="#"?Ct.state=41:Ir.test(_t)?Ct.state=38:Vn(Ct))}function We(Ct,_t){fv(_t)?Ct.state=40:Ir.test(_t)?cs(m,Ct):Vn(Ct)}function Vn(Ct){if(cs(m,Ct),!!Ct.acceptStateReached){var _t=Ct.startIdx,Je=t.slice(Ct.startIdx,h);if(Je=fWe(Je),Ct.type==="url"){var xe=t.charAt(Ct.startIdx-1);if(xe==="@")return;var oo=Ct.matchType;if(oo==="scheme"){var ea=Znt.exec(Je);if(ea&&(_t=_t+ea.index,Je=Je.slice(ea.index)),!UTt(Je))return}else if(oo==="tld"){if(!GTt(Je))return}else if(oo==="ipV4"){if(!ATt(Je))return}else XF(oo);r.push(new STt({tagBuilder:n,matchedText:Je,offset:_t,urlMatchType:oo,url:Je,protocolRelativeMatch:Je.slice(0,2)==="//",stripPrefix:i,stripTrailingSlash:o,decodePercentEncoding:a}))}else if(Ct.type==="email")ETt(Je)&&r.push(new CTt({tagBuilder:n,matchedText:Je,offset:_t,email:Je.replace(TTt,"")}));else if(Ct.type==="hashtag")ITt(Je)&&r.push(new yTt({tagBuilder:n,matchedText:Je,offset:_t,serviceName:s,hashtag:Je.slice(1)}));else if(Ct.type==="mention")BTt(Je,l)&&r.push(new kTt({tagBuilder:n,matchedText:Je,offset:_t,serviceName:l,mention:Je.slice(1)}));else if(Ct.type==="phone"){if(Je=Je.replace(/ +$/g,""),YTt(Je)){var gs=Je.replace(/[^0-9,;#]/g,"");r.push(new xTt({tagBuilder:n,matchedText:Je,offset:_t,number:gs,plusSign:Je.charAt(0)==="+"}))}}else XF(Ct)}}}var WWe=/[\(\{\[]/,XTt=/[\)\}\]]/,JTt={")":"(","}":"{","]":"["};function fWe(t){for(var e={"(":0,"{":0,"[":0},n=0;n=0;)if(a=t.charAt(o),XTt.test(a)){var s=JTt[a];if(e[s]<0)e[s]++,o--;else break}else if(FTt.test(a))o--;else break;return t.slice(0,o+1)}function Gnt(t,e){return{type:"url",startIdx:t,state:e,acceptStateReached:!1,matchType:"scheme"}}function Ant(t,e){return{type:"url",startIdx:t,state:e,acceptStateReached:!1,matchType:"tld"}}function FWe(t,e){return{type:"url",startIdx:t,state:e,acceptStateReached:!1,matchType:"ipV4",octetsEncountered:1}}function UWe(t,e){return{type:"email",startIdx:t,state:e,acceptStateReached:!1}}function GWe(t,e){return{type:"hashtag",startIdx:t,state:e,acceptStateReached:!1}}function AWe(t,e){return{type:"mention",startIdx:t,state:e,acceptStateReached:!1}}function Snt(t,e){return{type:"phone",startIdx:t,state:e,acceptStateReached:!1}}var Cki=b(W());function MTt(t,e){for(var n=e.onOpenTag,i=e.onCloseTag,o=e.onText,a=e.onComment,s=e.onDoctype,l=new FR,r=0,d=t.length,m=0,h=0,u=l;r"?(u=new FR(Nr(Nr({},u),{name:dt()})),nt()):!JF.test(at)&&!Ir.test(at)&&at!==":"&&z()}function G(at){at===">"?z():JF.test(at)?m=3:z()}function A(at){Hh.test(at)||(at==="/"?m=12:at===">"?nt():at==="<"?H():at==="="||Vv.test(at)||mTt.test(at)?z():m=5)}function S(at){Hh.test(at)?m=6:at==="/"?m=12:at==="="?m=7:at===">"?nt():at==="<"?H():Vv.test(at)&&z()}function g(at){Hh.test(at)||(at==="/"?m=12:at==="="?m=7:at===">"?nt():at==="<"?H():Vv.test(at)?z():m=5)}function C(at){Hh.test(at)||(at==='"'?m=8:at==="'"?m=9:/[>=`]/.test(at)?z():at==="<"?H():m=10)}function y(at){at==='"'&&(m=11)}function Y(at){at==="'"&&(m=11)}function Q(at){Hh.test(at)?m=4:at===">"?nt():at==="<"&&H()}function J(at){Hh.test(at)?m=4:at==="/"?m=12:at===">"?nt():at==="<"?H():(m=4,q())}function M(at){at===">"?(u=new FR(Nr(Nr({},u),{isClosing:!0})),nt()):m=4}function Z(at){t.substr(r,2)==="--"?(r+=2,u=new FR(Nr(Nr({},u),{type:"comment"})),m=14):t.substr(r,7).toUpperCase()==="DOCTYPE"?(r+=7,u=new FR(Nr(Nr({},u),{type:"doctype"})),m=20):z()}function E(at){at==="-"?m=15:at===">"?z():m=16}function I(at){at==="-"?m=18:at===">"?z():m=16}function B(at){at==="-"&&(m=17)}function X(at){at==="-"?m=18:m=16}function _(at){at===">"?nt():at==="!"?m=19:at==="-"||(m=16)}function P(at){at==="-"?m=17:at===">"?nt():m=16}function w(at){at===">"?nt():at==="<"&&H()}function z(){m=0,u=l}function H(){m=1,u=new FR({idx:r})}function nt(){var at=t.slice(h,u.idx);at&&o(at,h),u.type==="comment"?a(u.idx):u.type==="doctype"?s(u.idx):(u.isOpening&&n(u.name,u.idx),u.isClosing&&i(u.name,u.idx)),z(),h=r+1}function $(){var at=t.slice(h,r);o(at,h),h=r+1}function dt(){var at=u.idx+(u.isClosing?2:1);return t.slice(at,r).toLowerCase()}function q(){r--}}var FR=function(){function t(e){e===void 0&&(e={}),this.idx=e.idx!==void 0?e.idx:-1,this.type=e.type||"tag",this.name=e.name||"",this.isOpening=!!e.isOpening,this.isClosing=!!e.isClosing}return t}();var SWe=function(){function t(e){e===void 0&&(e={}),this.version=t.version,this.urls={},this.email=!0,this.phone=!0,this.hashtag=!1,this.mention=!1,this.newWindow=!0,this.stripPrefix={scheme:!0,www:!0},this.stripTrailingSlash=!0,this.decodePercentEncoding=!0,this.truncate={length:0,location:"end"},this.className="",this.replaceFn=null,this.context=void 0,this.sanitizeHtml=!1,this.tagBuilder=null,this.urls=TWe(e.urls),this.email=Oh(e.email)?e.email:this.email,this.phone=Oh(e.phone)?e.phone:this.phone,this.hashtag=e.hashtag||this.hashtag,this.mention=e.mention||this.mention,this.newWindow=Oh(e.newWindow)?e.newWindow:this.newWindow,this.stripPrefix=gWe(e.stripPrefix),this.stripTrailingSlash=Oh(e.stripTrailingSlash)?e.stripTrailingSlash:this.stripTrailingSlash,this.decodePercentEncoding=Oh(e.decodePercentEncoding)?e.decodePercentEncoding:this.decodePercentEncoding,this.sanitizeHtml=e.sanitizeHtml||!1;var n=this.mention;if(n!==!1&&QTt.indexOf(n)===-1)throw new Error("invalid `mention` cfg '".concat(n,"' - see docs"));var i=this.hashtag;if(i!==!1&&NTt.indexOf(i)===-1)throw new Error("invalid `hashtag` cfg '".concat(i,"' - see docs"));this.truncate=EWe(e.truncate),this.className=e.className||this.className,this.replaceFn=e.replaceFn||this.replaceFn,this.context=e.context||this}return t.link=function(e,n){var i=new t(n);return i.link(e)},t.parse=function(e,n){var i=new t(n);return i.parse(e)},t.prototype.parse=function(e){var n=this,i=["a","style","script"],o=0,a=[];return MTt(e,{onOpenTag:function(s){i.indexOf(s)>=0&&o++},onText:function(s,l){if(o===0){var r=/( | |<|<|>|>|"|"|')/gi,d=s.split(r),m=l;d.forEach(function(h,u){if(u%2===0){var R=n.parseText(h,m);a.push.apply(a,R)}m+=h.length})}},onCloseTag:function(s){i.indexOf(s)>=0&&(o=Math.max(o-1,0))},onComment:function(s){},onDoctype:function(s){}}),a=this.compactMatches(a),a=this.removeUnwantedMatches(a),a},t.prototype.compactMatches=function(e){e.sort(function(r,d){return r.getOffset()-d.getOffset()});for(var n=0;na?n:n+1;e.splice(l,1);continue}if(e[n+1].getOffset()/g,">"));for(var n=this.parse(e),i=[],o=0,a=0,s=n.length;a{let i=new FileReader;i.addEventListener("load",function(){e(i.result)}),i.addEventListener("error",function(){n(i.error)}),i.readAsText(t)})}function Tnt(t,e){let n=IL(t,"id");return n=c(n)?n:Ti(),e.getOrCreateEntity(n)}function gnt(t){let e=PTt(t,"lon"),n=PTt(t,"lat"),i=EL(t,"ele",va.gpx);return p.fromDegrees(e,n,i)}function PTt(t,e){if(!c(t))return;let n=t.getAttribute(e);if(n!==null){let i=parseFloat(n);return isNaN(i)?void 0:i}}function IL(t,e){if(!c(t))return;let n=t.getAttribute(e);return n!==null?n:void 0}function LF(t,e,n){if(!c(t))return;let i=t.childNodes,o=i.length;for(let a=0;a${h.text}: ${h.value}

`)}if(!c(i)||i==="")return;i=CWe.link(i),CL.innerHTML=i;let s=CL.querySelectorAll("a");for(n=0;n',d+=`${CL.innerHTML}`,CL.innerHTML="",d}function tgt(t,e,n,i){let o=gnt(e),a=Tnt(e,n);a.position=o;let s=c(i.waypointImage)?i.waypointImage:t._pinBuilder.fromMakiIconId("marker",v.RED,Uv);a.billboard=qTt(s);let l=Pm(e,"name",va.gpx);a.name=l,a.label=yWe(),a.label.text=l,a.description=Cnt(e,a),i.clampToGround&&(a.billboard.heightReference=Ge.CLAMP_TO_GROUND,a.label.heightReference=Ge.CLAMP_TO_GROUND)}function BWe(t,e,n,i){let o=Tnt(e,n);o.description=Cnt(e,o);let a=Ent(e,"rtept",va.gpx),s=new Array(a.length);for(let l=0;l0?(l=l.concat(r.times),m.addSamples(l,s),d=d&&!0):d=!1;if(d){let h=c(i.waypointImage)?i.waypointImage:t._pinBuilder.fromMakiIconId("marker",v.RED,Uv);o.billboard=qTt(h),o.position=m,i.clampToGround&&(o.billboard.heightReference=Ge.CLAMP_TO_GROUND),o.availability=new ys,o.availability.addInterval(new ai({start:l[0],stop:l[l.length-1]}))}o.polyline=$Tt(i.trackColor),o.polyline.positions=s,i.clampToGround&&(o.polyline.clampToGround=!0)}function kWe(t){let e={positions:[],times:[]},n=Ent(t,"trkpt",va.gpx),i;for(let o=0;onew Array(e).fill(n,0,e)))}function Iv(t){return t.reduce((e,n)=>e.concat(Array.isArray(n)?Iv(n):n),[])}var ngt=[0,1,2,3].concat(...Cv([[2,4],[2,5],[4,6],[4,7],[8,8],[8,9],[16,10],[16,11],[32,12],[32,13],[64,14],[64,15],[2,0],[1,16],[1,17],[2,18],[2,19],[4,20],[4,21],[8,22],[8,23],[16,24],[16,25],[32,26],[32,27],[64,28],[64,29]]));function ks(){let t=this;function e(o){let a=t.dyn_tree,s=t.stat_desc.static_tree,l=t.stat_desc.extra_bits,r=t.stat_desc.extra_base,d=t.stat_desc.max_length,m,h,u,R,V,F,U=0;for(R=0;R<=15;R++)o.bl_count[R]=0;for(a[o.heap[o.heap_max]*2+1]=0,m=o.heap_max+1;m<573;m++)h=o.heap[m],R=a[a[h*2+1]*2+1]+1,R>d&&(R=d,U++),a[h*2+1]=R,!(h>t.max_code)&&(o.bl_count[R]++,V=0,h>=r&&(V=l[h-r]),F=a[h*2],o.opt_len+=F*(R+V),s&&(o.static_len+=F*(s[h*2+1]+V)));if(U!==0){do{for(R=d-1;o.bl_count[R]===0;)R--;o.bl_count[R]--,o.bl_count[R+1]+=2,o.bl_count[d]--,U-=2}while(U>0);for(R=d;R!==0;R--)for(h=o.bl_count[R];h!==0;)u=o.heap[--m],!(u>t.max_code)&&(a[u*2+1]!=R&&(o.opt_len+=(R-a[u*2+1])*a[u*2],a[u*2+1]=R),h--)}}function n(o,a){let s=0;do s|=o&1,o>>>=1,s<<=1;while(--a>0);return s>>>1}function i(o,a,s){let l=[],r=0,d,m,h;for(d=1;d<=15;d++)l[d]=r=r+s[d-1]<<1;for(m=0;m<=a;m++)h=o[m*2+1],h!==0&&(o[m*2]=n(l[h]++,h))}t.build_tree=function(o){let a=t.dyn_tree,s=t.stat_desc.static_tree,l=t.stat_desc.elems,r,d,m=-1,h;for(o.heap_len=0,o.heap_max=573,r=0;r=1;r--)o.pqdownheap(a,r);h=l;do r=o.heap[1],o.heap[1]=o.heap[o.heap_len--],o.pqdownheap(a,1),d=o.heap[1],o.heap[--o.heap_max]=r,o.heap[--o.heap_max]=d,a[h*2]=a[r*2]+a[d*2],o.depth[h]=Math.max(o.depth[r],o.depth[d])+1,a[r*2+1]=a[d*2+1]=h,o.heap[1]=h++,o.pqdownheap(a,1);while(o.heap_len>=2);o.heap[--o.heap_max]=o.heap[1],e(o),i(a,t.max_code,o.bl_count)}}ks._length_code=[0,1,2,3,4,5,6,7].concat(...Cv([[2,8],[2,9],[2,10],[2,11],[4,12],[4,13],[4,14],[4,15],[8,16],[8,17],[8,18],[8,19],[16,20],[16,21],[16,22],[16,23],[32,24],[32,25],[32,26],[31,27],[1,28]]));ks.base_length=[0,1,2,3,4,5,6,7,8,10,12,14,16,20,24,28,32,40,48,56,64,80,96,112,128,160,192,224,0];ks.base_dist=[0,1,2,3,4,6,8,12,16,24,32,48,64,96,128,192,256,384,512,768,1024,1536,2048,3072,4096,6144,8192,12288,16384,24576];ks.d_code=function(t){return t<256?ngt[t]:ngt[256+(t>>>7)]};ks.extra_lbits=[0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0];ks.extra_dbits=[0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13];ks.extra_blbits=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7];ks.bl_order=[16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15];function fd(t,e,n,i,o){let a=this;a.static_tree=t,a.extra_bits=e,a.extra_base=n,a.elems=i,a.max_length=o}var HWe=[12,140,76,204,44,172,108,236,28,156,92,220,60,188,124,252,2,130,66,194,34,162,98,226,18,146,82,210,50,178,114,242,10,138,74,202,42,170,106,234,26,154,90,218,58,186,122,250,6,134,70,198,38,166,102,230,22,150,86,214,54,182,118,246,14,142,78,206,46,174,110,238,30,158,94,222,62,190,126,254,1,129,65,193,33,161,97,225,17,145,81,209,49,177,113,241,9,137,73,201,41,169,105,233,25,153,89,217,57,185,121,249,5,133,69,197,37,165,101,229,21,149,85,213,53,181,117,245,13,141,77,205,45,173,109,237,29,157,93,221,61,189,125,253,19,275,147,403,83,339,211,467,51,307,179,435,115,371,243,499,11,267,139,395,75,331,203,459,43,299,171,427,107,363,235,491,27,283,155,411,91,347,219,475,59,315,187,443,123,379,251,507,7,263,135,391,71,327,199,455,39,295,167,423,103,359,231,487,23,279,151,407,87,343,215,471,55,311,183,439,119,375,247,503,15,271,143,399,79,335,207,463,47,303,175,431,111,367,239,495,31,287,159,415,95,351,223,479,63,319,191,447,127,383,255,511,0,64,32,96,16,80,48,112,8,72,40,104,24,88,56,120,4,68,36,100,20,84,52,116,3,131,67,195,35,163,99,227],wWe=Cv([[144,8],[112,9],[24,7],[8,8]]);fd.static_ltree=Iv(HWe.map((t,e)=>[t,wWe[e]]));var PWe=[0,16,8,24,4,20,12,28,2,18,10,26,6,22,14,30,1,17,9,25,5,21,13,29,3,19,11,27,7,23],vWe=Cv([[30,5]]);fd.static_dtree=Iv(PWe.map((t,e)=>[t,vWe[e]]));fd.static_l_desc=new fd(fd.static_ltree,ks.extra_lbits,257,286,15);fd.static_d_desc=new fd(fd.static_dtree,ks.extra_dbits,0,30,15);fd.static_bl_desc=new fd(null,ks.extra_blbits,0,19,7);var KWe=9,zWe=8;function UR(t,e,n,i,o){let a=this;a.good_length=t,a.max_lazy=e,a.nice_length=n,a.max_chain=i,a.func=o}var ogt=0,gv=1,yS=2,wu=[new UR(0,0,0,0,ogt),new UR(4,4,8,4,gv),new UR(4,5,16,8,gv),new UR(4,6,32,32,gv),new UR(4,4,16,16,yS),new UR(8,16,32,32,yS),new UR(8,16,128,128,yS),new UR(8,32,128,256,yS),new UR(32,128,258,1024,yS),new UR(32,258,258,4096,yS)],Gv=["need dictionary","stream end","","","stream error","data error","","buffer error","",""],ZV=0,Av=1,BL=2,Sv=3,jWe=32,Int=42,Tv=113,QL=666,Nnt=8,qWe=0,ynt=1,$We=2,zs=3,Ev=258,wh=Ev+zs+1;function igt(t,e,n,i){let o=t[e*2],a=t[n*2];return o=3&&P[ks.bl_order[ae]*2+1]===0;ae--);return t.opt_len+=3*(ae+1)+5+5+4,ae}function Mt(ae){t.pending_buf[t.pending++]=ae}function qt(ae){Mt(ae&255),Mt(ae>>>8&255)}function ie(ae){Mt(ae>>8&255),Mt(ae&255&255)}function oe(ae,fe){let ge,ue=fe;st>16-ue?(ge=ae,at|=ge<>>16-st,st+=ue-16):(at|=ae<=8&&(Mt(at&255),at>>>=8,st-=8)}function ke(){oe(ynt<<1,3),He(256,fd.static_ltree),zt(),1+q+10-st<9&&(oe(ynt<<1,3),He(256,fd.static_ltree),zt()),q=7}function Ve(ae,fe){let ge,ue,Ke;if(t.dist_buf[$]=ae,t.lc_buf[$]=fe&255,$++,ae===0?X[fe*2]++:(dt++,ae--,X[(ks._length_code[fe]+256+1)*2]++,_[ks.d_code(ae)*2]++),!($&8191)&&Z>2){for(ge=$*8,ue=C-G,Ke=0;Ke<30;Ke++)ge+=_[Ke*2]*(5+ks.extra_dbits[Ke]);if(ge>>>=3,dt8?qt(at):st>0&&Mt(at&255),at=0,st=0}function Ct(ae,fe,ge){Vn(),q=8,ge&&(qt(fe),qt(~fe)),t.pending_buf.set(r.subarray(ae,ae+fe),t.pending),t.pending+=fe}function _t(ae,fe,ge){oe((qWe<<1)+(ge?1:0),3),Ct(ae,fe,!0)}function Je(ae,fe,ge){let ue,Ke,An=0;Z>0?(w.build_tree(t),z.build_tree(t),An=kt(),ue=t.opt_len+3+7>>>3,Ke=t.static_len+3+7>>>3,Ke<=ue&&(ue=Ke)):ue=Ke=fe+5,fe+4<=ue&&ae!=-1?_t(ae,fe,ge):Ke==ue?(oe((ynt<<1)+(ge?1:0),3),We(fd.static_ltree,fd.static_dtree)):(oe(($We<<1)+(ge?1:0),3),de(w.max_code+1,z.max_code+1,An+1),We(X,_)),Qt(),ge&&Vn()}function xe(ae){Je(G>=0?G:-1,C-G,ae),G=C,e.flush_pending()}function oo(){let ae,fe,ge,ue;do{if(ue=d-Y-C,ue===0&&C===0&&Y===0)ue=a;else if(ue==-1)ue--;else if(C>=a+a-wh){r.set(r.subarray(a,a+a),0),y-=a,C-=a,G-=a,ae=R,ge=ae;do fe=h[--ge]&65535,h[ge]=fe>=a?fe-a:0;while(--ae!==0);ae=a,ge=ae;do fe=m[--ge]&65535,m[ge]=fe>=a?fe-a:0;while(--ae!==0);ue+=a}if(e.avail_in===0)return;ae=e.read_buf(r,C+Y,ue),Y+=ae,Y>=zs&&(u=r[C]&255,u=(u<i-5&&(fe=i-5);;){if(Y<=1){if(oo(),Y===0&&ae==0)return ZV;if(Y===0)break}if(C+=Y,Y=0,ge=G+fe,(C===0||C>=ge)&&(Y=C-ge,C=ge,xe(!1),e.avail_out===0)||C-G>=a-wh&&(xe(!1),e.avail_out===0))return ZV}return xe(ae==4),e.avail_out===0?ae==4?BL:ZV:ae==4?Sv:Av}function gs(ae){let fe=J,ge=C,ue,Ke,An=Q,si=C>a-wh?C-(a-wh):0,da=B,_a=l,Rl=C+Ev,na=r[ge+An-1],Go=r[ge+An];Q>=I&&(fe>>=2),da>Y&&(da=Y);do if(ue=ae,!(r[ue+An]!=Go||r[ue+An-1]!=na||r[ue]!=r[ge]||r[++ue]!=r[ge+1])){ge+=2,ue++;do;while(r[++ge]==r[++ue]&&r[++ge]==r[++ue]&&r[++ge]==r[++ue]&&r[++ge]==r[++ue]&&r[++ge]==r[++ue]&&r[++ge]==r[++ue]&&r[++ge]==r[++ue]&&r[++ge]==r[++ue]&&geAn){if(y=ae,An=Ke,Ke>=da)break;na=r[ge+An-1],Go=r[ge+An]}}while((ae=m[ae&_a]&65535)>si&&--fe!==0);return An<=Y?An:Y}function is(ae){let fe=0,ge;for(;;){if(Y=zs&&(u=(u<=zs)if(ge=Ve(C-y,A-zs),Y-=A,A<=M&&Y>=zs){A--;do C++,u=(u<=zs&&(u=(u<4096)&&(A=zs-1)),Q>=zs&&A<=Q){ue=C+Y-zs,ge=Ve(C-1-S,Q-zs),Y-=Q-1,Q-=2;do++C<=ue&&(u=(u<KWe||ue!=Nnt||ge<9||ge>15||fe<0||fe>9||An<0||An>2?-2:(ae.dstate=t,s=ge,a=1<9||ge<0||ge>2?-2:(wu[Z].func!=wu[fe].func&&ae.total_in!==0&&(ue=ae.deflate(1)),Z!=fe&&(Z=fe,M=wu[Z].max_lazy,I=wu[Z].good_length,B=wu[Z].nice_length,J=wu[Z].max_chain),E=ge,ue)},t.deflateSetDictionary=function(ae,fe,ge){let ue=ge,Ke,An=0;if(!fe||n!=Int)return-2;if(uea-wh&&(ue=a-wh,An=ge-ue),r.set(fe.subarray(An,An+ue),0),C=ue,G=ue,u=r[0]&255,u=(u<4||fe<0)return-2;if(!ae.next_out||!ae.next_in&&ae.avail_in!==0||n==QL&&fe!=4)return ae.msg=Gv[4],-2;if(ae.avail_out===0)return ae.msg=Gv[7],-5;if(e=ae,An=o,o=fe,n==Int&&(ue=Nnt+(s-8<<4)<<8,Ke=(Z-1&255)>>1,Ke>3&&(Ke=3),ue|=Ke<<6,C!==0&&(ue|=jWe),ue+=31-ue%31,n=Tv,ie(ue)),t.pending!==0){if(e.flush_pending(),e.avail_out===0)return o=-1,0}else if(e.avail_in===0&&fe<=An&&fe!=4)return e.msg=Gv[7],-5;if(n==QL&&e.avail_in!==0)return ae.msg=Gv[7],-5;if(e.avail_in!==0||Y!==0||fe!=0&&n!=QL){switch(si=-1,wu[Z].func){case ogt:si=ea(fe);break;case gv:si=is(fe);break;case yS:si=ja(fe);break;default:}if((si==BL||si==Sv)&&(n=QL),si==ZV||si==BL)return e.avail_out===0&&(o=-1),0;if(si==Av){if(fe==1)ke();else if(_t(0,0,!1),fe==3)for(ge=0;gen&&(o=n),o===0?0:(i.avail_in-=o,t.set(i.next_in.subarray(i.next_in_index,i.next_in_index+o),e),i.next_in_index+=o,i.total_in+=o,o)},flush_pending(){let t=this,e=t.dstate.pending;e>t.avail_out&&(e=t.avail_out),e!==0&&(t.next_out.set(t.dstate.pending_buf.subarray(t.dstate.pending_out,t.dstate.pending_out+e),t.next_out_index),t.next_out_index+=e,t.dstate.pending_out+=e,t.total_out+=e,t.avail_out-=e,t.dstate.pending-=e,t.dstate.pending===0&&(t.dstate.pending_out=0))}};function sgt(t){let e=this,n=new agt,i=efe(t&&t.chunkSize?t.chunkSize:64*1024),o=0,a=new Uint8Array(i),s=t?t.level:-1;typeof s>"u"&&(s=-1),n.deflateInit(s),n.next_out=a,e.append=function(l,r){let d,m,h=0,u=0,R=0,V=[];if(l.length){n.next_in_index=0,n.next_in=l,n.avail_in=l.length;do{if(n.next_out_index=0,n.avail_out=i,d=n.deflate(o),d!=0)throw new Error("deflating: "+n.msg);n.next_out_index&&(n.next_out_index==i?V.push(new Uint8Array(a)):V.push(a.subarray(0,n.next_out_index))),R+=n.next_out_index,r&&n.next_in_index>0&&n.next_in_index!=h&&(r(n.next_in_index),h=n.next_in_index)}while(n.avail_in>0||n.avail_out===0);return V.length>1?(m=new Uint8Array(R),V.forEach(function(F){m.set(F,u),u+=F.length})):m=V[0]?new Uint8Array(V[0]):new Uint8Array,m}},e.flush=function(){let l,r,d=0,m=0,h=[];do{if(n.next_out_index=0,n.avail_out=i,l=n.deflate(4),l!=1&&l!=0)throw new Error("deflating: "+n.msg);i-n.avail_out>0&&h.push(a.slice(0,n.next_out_index)),m+=n.next_out_index}while(n.avail_in>0||n.avail_out===0);return n.deflateEnd(),r=new Uint8Array(m),h.forEach(function(u){r.set(u,d),d+=u.length}),r}}function efe(t){return t+5*(Math.floor(t/16383)+1)}var P2i=b(W(),1);var Ph=[0,1,3,7,15,31,63,127,255,511,1023,2047,4095,8191,16383,32767,65535],Tgt=1440,nfe=0,ife=4,ofe=9,afe=5,sfe=[96,7,256,0,8,80,0,8,16,84,8,115,82,7,31,0,8,112,0,8,48,0,9,192,80,7,10,0,8,96,0,8,32,0,9,160,0,8,0,0,8,128,0,8,64,0,9,224,80,7,6,0,8,88,0,8,24,0,9,144,83,7,59,0,8,120,0,8,56,0,9,208,81,7,17,0,8,104,0,8,40,0,9,176,0,8,8,0,8,136,0,8,72,0,9,240,80,7,4,0,8,84,0,8,20,85,8,227,83,7,43,0,8,116,0,8,52,0,9,200,81,7,13,0,8,100,0,8,36,0,9,168,0,8,4,0,8,132,0,8,68,0,9,232,80,7,8,0,8,92,0,8,28,0,9,152,84,7,83,0,8,124,0,8,60,0,9,216,82,7,23,0,8,108,0,8,44,0,9,184,0,8,12,0,8,140,0,8,76,0,9,248,80,7,3,0,8,82,0,8,18,85,8,163,83,7,35,0,8,114,0,8,50,0,9,196,81,7,11,0,8,98,0,8,34,0,9,164,0,8,2,0,8,130,0,8,66,0,9,228,80,7,7,0,8,90,0,8,26,0,9,148,84,7,67,0,8,122,0,8,58,0,9,212,82,7,19,0,8,106,0,8,42,0,9,180,0,8,10,0,8,138,0,8,74,0,9,244,80,7,5,0,8,86,0,8,22,192,8,0,83,7,51,0,8,118,0,8,54,0,9,204,81,7,15,0,8,102,0,8,38,0,9,172,0,8,6,0,8,134,0,8,70,0,9,236,80,7,9,0,8,94,0,8,30,0,9,156,84,7,99,0,8,126,0,8,62,0,9,220,82,7,27,0,8,110,0,8,46,0,9,188,0,8,14,0,8,142,0,8,78,0,9,252,96,7,256,0,8,81,0,8,17,85,8,131,82,7,31,0,8,113,0,8,49,0,9,194,80,7,10,0,8,97,0,8,33,0,9,162,0,8,1,0,8,129,0,8,65,0,9,226,80,7,6,0,8,89,0,8,25,0,9,146,83,7,59,0,8,121,0,8,57,0,9,210,81,7,17,0,8,105,0,8,41,0,9,178,0,8,9,0,8,137,0,8,73,0,9,242,80,7,4,0,8,85,0,8,21,80,8,258,83,7,43,0,8,117,0,8,53,0,9,202,81,7,13,0,8,101,0,8,37,0,9,170,0,8,5,0,8,133,0,8,69,0,9,234,80,7,8,0,8,93,0,8,29,0,9,154,84,7,83,0,8,125,0,8,61,0,9,218,82,7,23,0,8,109,0,8,45,0,9,186,0,8,13,0,8,141,0,8,77,0,9,250,80,7,3,0,8,83,0,8,19,85,8,195,83,7,35,0,8,115,0,8,51,0,9,198,81,7,11,0,8,99,0,8,35,0,9,166,0,8,3,0,8,131,0,8,67,0,9,230,80,7,7,0,8,91,0,8,27,0,9,150,84,7,67,0,8,123,0,8,59,0,9,214,82,7,19,0,8,107,0,8,43,0,9,182,0,8,11,0,8,139,0,8,75,0,9,246,80,7,5,0,8,87,0,8,23,192,8,0,83,7,51,0,8,119,0,8,55,0,9,206,81,7,15,0,8,103,0,8,39,0,9,174,0,8,7,0,8,135,0,8,71,0,9,238,80,7,9,0,8,95,0,8,31,0,9,158,84,7,99,0,8,127,0,8,63,0,9,222,82,7,27,0,8,111,0,8,47,0,9,190,0,8,15,0,8,143,0,8,79,0,9,254,96,7,256,0,8,80,0,8,16,84,8,115,82,7,31,0,8,112,0,8,48,0,9,193,80,7,10,0,8,96,0,8,32,0,9,161,0,8,0,0,8,128,0,8,64,0,9,225,80,7,6,0,8,88,0,8,24,0,9,145,83,7,59,0,8,120,0,8,56,0,9,209,81,7,17,0,8,104,0,8,40,0,9,177,0,8,8,0,8,136,0,8,72,0,9,241,80,7,4,0,8,84,0,8,20,85,8,227,83,7,43,0,8,116,0,8,52,0,9,201,81,7,13,0,8,100,0,8,36,0,9,169,0,8,4,0,8,132,0,8,68,0,9,233,80,7,8,0,8,92,0,8,28,0,9,153,84,7,83,0,8,124,0,8,60,0,9,217,82,7,23,0,8,108,0,8,44,0,9,185,0,8,12,0,8,140,0,8,76,0,9,249,80,7,3,0,8,82,0,8,18,85,8,163,83,7,35,0,8,114,0,8,50,0,9,197,81,7,11,0,8,98,0,8,34,0,9,165,0,8,2,0,8,130,0,8,66,0,9,229,80,7,7,0,8,90,0,8,26,0,9,149,84,7,67,0,8,122,0,8,58,0,9,213,82,7,19,0,8,106,0,8,42,0,9,181,0,8,10,0,8,138,0,8,74,0,9,245,80,7,5,0,8,86,0,8,22,192,8,0,83,7,51,0,8,118,0,8,54,0,9,205,81,7,15,0,8,102,0,8,38,0,9,173,0,8,6,0,8,134,0,8,70,0,9,237,80,7,9,0,8,94,0,8,30,0,9,157,84,7,99,0,8,126,0,8,62,0,9,221,82,7,27,0,8,110,0,8,46,0,9,189,0,8,14,0,8,142,0,8,78,0,9,253,96,7,256,0,8,81,0,8,17,85,8,131,82,7,31,0,8,113,0,8,49,0,9,195,80,7,10,0,8,97,0,8,33,0,9,163,0,8,1,0,8,129,0,8,65,0,9,227,80,7,6,0,8,89,0,8,25,0,9,147,83,7,59,0,8,121,0,8,57,0,9,211,81,7,17,0,8,105,0,8,41,0,9,179,0,8,9,0,8,137,0,8,73,0,9,243,80,7,4,0,8,85,0,8,21,80,8,258,83,7,43,0,8,117,0,8,53,0,9,203,81,7,13,0,8,101,0,8,37,0,9,171,0,8,5,0,8,133,0,8,69,0,9,235,80,7,8,0,8,93,0,8,29,0,9,155,84,7,83,0,8,125,0,8,61,0,9,219,82,7,23,0,8,109,0,8,45,0,9,187,0,8,13,0,8,141,0,8,77,0,9,251,80,7,3,0,8,83,0,8,19,85,8,195,83,7,35,0,8,115,0,8,51,0,9,199,81,7,11,0,8,99,0,8,35,0,9,167,0,8,3,0,8,131,0,8,67,0,9,231,80,7,7,0,8,91,0,8,27,0,9,151,84,7,67,0,8,123,0,8,59,0,9,215,82,7,19,0,8,107,0,8,43,0,9,183,0,8,11,0,8,139,0,8,75,0,9,247,80,7,5,0,8,87,0,8,23,192,8,0,83,7,51,0,8,119,0,8,55,0,9,207,81,7,15,0,8,103,0,8,39,0,9,175,0,8,7,0,8,135,0,8,71,0,9,239,80,7,9,0,8,95,0,8,31,0,9,159,84,7,99,0,8,127,0,8,63,0,9,223,82,7,27,0,8,111,0,8,47,0,9,191,0,8,15,0,8,143,0,8,79,0,9,255],lfe=[80,5,1,87,5,257,83,5,17,91,5,4097,81,5,5,89,5,1025,85,5,65,93,5,16385,80,5,3,88,5,513,84,5,33,92,5,8193,82,5,9,90,5,2049,86,5,129,192,5,24577,80,5,2,87,5,385,83,5,25,91,5,6145,81,5,7,89,5,1537,85,5,97,93,5,24577,80,5,4,88,5,769,84,5,49,92,5,12289,82,5,13,90,5,3073,86,5,193,192,5,24577],rfe=[3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258,0,0],dfe=[0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,112,112],cfe=[1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577],mfe=[0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13],MF=15;function Ynt(){let t=this,e,n,i,o,a,s;function l(d,m,h,u,R,V,F,U,G,A,S){let g,C,y,Y,Q,J,M,Z,E,I,B,X,_,P,w;I=0,Q=h;do i[d[m+I]]++,I++,Q--;while(Q!==0);if(i[0]==h)return F[0]=-1,U[0]=0,0;for(Z=U[0],J=1;J<=MF&&i[J]===0;J++);for(M=J,ZQ&&(Z=Q),U[0]=Z,P=1<X+Z;){if(Y++,X+=Z,w=y-X,w=w>Z?Z:w,(C=1<<(J=M-X))>g+1&&(C-=g+1,_=M,JTgt)return-3;a[Y]=B=A[0],A[0]+=w,Y!==0?(s[Y]=Q,o[0]=J,o[1]=Z,J=Q>>>X-Z,o[2]=B-a[Y-1]-J,G.set(o,(a[Y-1]+J)*3)):F[0]=B}for(o[1]=M-X,I>=h?o[0]=192:S[I]>>X;J>>=1)Q^=J;for(Q^=J,E=(1<257?(A==-3?G.msg="oversubscribed distance tree":A==-5?(G.msg="incomplete distance tree",A=-3):A!=-4&&(G.msg="empty distance tree with lengths",A=-3),A):0)}}Ynt.inflate_trees_fixed=function(t,e,n,i){return t[0]=ofe,e[0]=afe,n[0]=sfe,i[0]=lfe,0};var Nv=0,lgt=1,rgt=2,dgt=3,cgt=4,mgt=5,hgt=6,Bnt=7,pgt=8,yv=9;function hfe(){let t=this,e,n=0,i,o=0,a=0,s=0,l=0,r=0,d=0,m=0,h,u=0,R,V=0;function F(U,G,A,S,g,C,y,Y){let Q,J,M,Z,E,I,B,X,_,P,w,z,H,nt,$,dt;B=Y.next_in_index,X=Y.avail_in,E=y.bitb,I=y.bitk,_=y.write,P=_>=J[dt+1],I-=J[dt+1],y.win[_++]=J[dt+2],P--;continue}do{if(E>>=J[dt+1],I-=J[dt+1],Z&16){for(Z&=15,H=J[dt+2]+(E&Ph[Z]),E>>=Z,I-=Z;I<15;)X--,E|=(Y.read_byte(B++)&255)<>=J[dt+1],I-=J[dt+1],Z&16){for(Z&=15;I>=Z,I-=Z,P-=H,_>=nt)$=_-nt,_-$>0&&2>_-$?(y.win[_++]=y.win[$++],y.win[_++]=y.win[$++],H-=2):(y.win.set(y.win.subarray($,$+2),_),_+=2,$+=2,H-=2);else{$=_-nt;do $+=y.end;while($<0);if(Z=y.end-$,H>Z){if(H-=Z,_-$>0&&Z>_-$)do y.win[_++]=y.win[$++];while(--Z!==0);else y.win.set(y.win.subarray($,$+Z),_),_+=Z,$+=Z,Z=0;$=0}}if(_-$>0&&H>_-$)do y.win[_++]=y.win[$++];while(--H!==0);else y.win.set(y.win.subarray($,$+H),_),_+=H,$+=H,H=0;break}else if(!(Z&64))Q+=J[dt+2],Q+=E&Ph[Z],dt=(M+Q)*3,Z=J[dt];else return Y.msg="invalid distance code",H=Y.avail_in-X,H=I>>3>3:H,X+=H,B-=H,I-=H<<3,y.bitb=E,y.bitk=I,Y.avail_in=X,Y.total_in+=B-Y.next_in_index,Y.next_in_index=B,y.write=_,-3;while(!0);break}if(Z&64)return Z&32?(H=Y.avail_in-X,H=I>>3>3:H,X+=H,B-=H,I-=H<<3,y.bitb=E,y.bitk=I,Y.avail_in=X,Y.total_in+=B-Y.next_in_index,Y.next_in_index=B,y.write=_,1):(Y.msg="invalid literal/length code",H=Y.avail_in-X,H=I>>3>3:H,X+=H,B-=H,I-=H<<3,y.bitb=E,y.bitk=I,Y.avail_in=X,Y.total_in+=B-Y.next_in_index,Y.next_in_index=B,y.write=_,-3);if(Q+=J[dt+2],Q+=E&Ph[Z],dt=(M+Q)*3,(Z=J[dt])===0){E>>=J[dt+1],I-=J[dt+1],y.win[_++]=J[dt+2],P--;break}}while(!0)}while(P>=258&&X>=10);return H=Y.avail_in-X,H=I>>3>3:H,X+=H,B-=H,I-=H<<3,y.bitb=E,y.bitk=I,Y.avail_in=X,Y.total_in+=B-Y.next_in_index,Y.next_in_index=B,y.write=_,0}t.init=function(U,G,A,S,g,C){e=Nv,d=U,m=G,h=A,u=S,R=g,V=C,i=null},t.proc=function(U,G,A){let S,g,C,y=0,Y=0,Q=0,J,M,Z,E;for(Q=G.next_in_index,J=G.avail_in,y=U.bitb,Y=U.bitk,M=U.write,Z=M=258&&J>=10&&(U.bitb=y,U.bitk=Y,G.avail_in=J,G.total_in+=Q-G.next_in_index,G.next_in_index=Q,U.write=M,A=F(d,m,h,u,R,V,U,G),Q=G.next_in_index,J=G.avail_in,y=U.bitb,Y=U.bitk,M=U.write,Z=M>>=i[g+1],Y-=i[g+1],C=i[g],C===0){s=i[g+2],e=hgt;break}if(C&16){l=C&15,n=i[g+2],e=rgt;break}if(!(C&64)){a=C,o=g/3+i[g+2];break}if(C&32){e=Bnt;break}return e=yv,G.msg="invalid literal/length code",A=-3,U.bitb=y,U.bitk=Y,G.avail_in=J,G.total_in+=Q-G.next_in_index,G.next_in_index=Q,U.write=M,U.inflate_flush(G,A);case rgt:for(S=l;Y>=S,Y-=S,a=m,i=R,o=V,e=dgt;case dgt:for(S=a;Y>=i[g+1],Y-=i[g+1],C=i[g],C&16){l=C&15,r=i[g+2],e=cgt;break}if(!(C&64)){a=C,o=g/3+i[g+2];break}return e=yv,G.msg="invalid distance code",A=-3,U.bitb=y,U.bitk=Y,G.avail_in=J,G.total_in+=Q-G.next_in_index,G.next_in_index=Q,U.write=M,U.inflate_flush(G,A);case cgt:for(S=l;Y>=S,Y-=S,e=mgt;case mgt:for(E=M-r;E<0;)E+=U.end;for(;n!==0;){if(Z===0&&(M==U.end&&U.read!==0&&(M=0,Z=M7&&(Y-=8,J++,Q--),U.write=M,A=U.inflate_flush(G,A),M=U.write,Z=MF.avail_out&&(G=F.avail_out),G!==0&&U==-5&&(U=0),F.avail_out-=G,F.total_out+=G,F.next_out.set(n.win.subarray(S,S+G),A),A+=G,S+=G,S==n.end&&(S=0,n.write==n.end&&(n.write=0),G=n.write-S,G>F.avail_out&&(G=F.avail_out),G!==0&&U==-5&&(U=0),F.avail_out-=G,F.total_out+=G,F.next_out.set(n.win.subarray(S,S+G),A),A+=G,S+=G),F.next_out_index=A,n.read=S,U},n.proc=function(F,U){let G,A,S,g,C,y,Y,Q;for(g=F.next_in_index,C=F.avail_in,A=n.bitb,S=n.bitk,y=n.write,Y=y>>1){case 0:A>>>=3,S-=3,G=S&7,A>>>=G,S-=G,i=Qnt;break;case 1:J=[],M=[],Z=[[]],E=[[]],Ynt.inflate_trees_fixed(J,M,Z,E),m.init(J[0],M[0],Z[0],0,E[0],0),A>>>=3,S-=3,i=Bv;break;case 2:A>>>=3,S-=3,i=Zgt;break;case 3:return A>>>=3,S-=3,i=BS,F.msg="invalid block type",U=-3,n.bitb=A,n.bitk=S,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U)}break;case Qnt:for(;S<32;){if(C!==0)U=0;else return n.bitb=A,n.bitk=S,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);C--,A|=(F.read_byte(g++)&255)<>>16&65535)!=(A&65535))return i=BS,F.msg="invalid stored block lengths",U=-3,n.bitb=A,n.bitk=S,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);o=A&65535,A=S=0,i=o!==0?ugt:h!==0?Qv:yI;break;case ugt:if(C===0||Y===0&&(y==n.end&&n.read!==0&&(y=0,Y=yC&&(G=C),G>Y&&(G=Y),n.win.set(F.read_buf(g,G),y),g+=G,C-=G,y+=G,Y-=G,(o-=G)!==0)break;i=h!==0?Qv:yI;break;case Zgt:for(;S<14;){if(C!==0)U=0;else return n.bitb=A,n.bitk=S,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);C--,A|=(F.read_byte(g++)&255)<29||(G>>5&31)>29)return i=BS,F.msg="too many length or distance symbols",U=-3,n.bitb=A,n.bitk=S,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);if(G=258+(G&31)+(G>>5&31),!l||l.length>>=14,S-=14,s=0,i=Rgt;case Rgt:for(;s<4+(a>>>10);){for(;S<3;){if(C!==0)U=0;else return n.bitb=A,n.bitk=S,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);C--,A|=(F.read_byte(g++)&255)<>>=3,S-=3}for(;s<19;)l[Vgt[s++]]=0;if(r[0]=7,G=V.inflate_trees_bits(l,r,d,u,F),G!=0)return U=G,U==-3&&(l=null,i=BS),n.bitb=A,n.bitk=S,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);s=0,i=bgt;case bgt:for(;G=a,!(s>=258+(G&31)+(G>>5&31));){let P,w;for(G=r[0];S>>=G,S-=G,l[s++]=w;else{for(Q=w==18?7:w-14,P=w==18?11:3;S>>=G,S-=G,P+=A&Ph[Q],A>>>=Q,S-=Q,Q=s,G=a,Q+P>258+(G&31)+(G>>5&31)||w==16&&Q<1)return l=null,i=BS,F.msg="invalid bit length repeat",U=-3,n.bitb=A,n.bitk=S,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);w=w==16?l[Q-1]:0;do l[Q++]=w;while(--P!==0);s=Q}}if(d[0]=-1,I=[],B=[],X=[],_=[],I[0]=9,B[0]=6,G=a,G=V.inflate_trees_dynamic(257+(G&31),1+(G>>5&31),l,I,B,X,_,u,F),G!=0)return G==-3&&(l=null,i=BS),U=G,n.bitb=A,n.bitk=S,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,n.inflate_flush(F,U);m.init(I[0],B[0],u,X[0],u,_[0]),i=Bv;case Bv:if(n.bitb=A,n.bitk=S,F.avail_in=C,F.total_in+=g-F.next_in_index,F.next_in_index=g,n.write=y,(U=m.proc(n,F,U))!=1)return n.inflate_flush(F,U);if(U=0,m.free(F),g=F.next_in_index,C=F.avail_in,A=n.bitb,S=n.bitk,y=n.write,Y=y15?(t.inflateEnd(n),-2):(t.wbits=i,n.istate.blocks=new pfe(n,1<>4)+8>s.wbits){s.mode=_F,n.msg="invalid win size",s.marker=5;break}s.mode=fgt;case fgt:if(n.avail_in===0)return o;if(o=i,n.avail_in--,n.total_in++,a=n.read_byte(n.next_in_index++)&255,((s.method<<8)+a)%31!==0){s.mode=_F,n.msg="incorrect header check",s.marker=5;break}if(!(a&Vfe)){s.mode=kL;break}s.mode=Fgt;case Fgt:if(n.avail_in===0)return o;o=i,n.avail_in--,n.total_in++,s.need=(n.read_byte(n.next_in_index++)&255)<<24&4278190080,s.mode=Ugt;case Ugt:if(n.avail_in===0)return o;o=i,n.avail_in--,n.total_in++,s.need+=(n.read_byte(n.next_in_index++)&255)<<16&16711680,s.mode=Ggt;case Ggt:if(n.avail_in===0)return o;o=i,n.avail_in--,n.total_in++,s.need+=(n.read_byte(n.next_in_index++)&255)<<8&65280,s.mode=Agt;case Agt:return n.avail_in===0?o:(o=i,n.avail_in--,n.total_in++,s.need+=n.read_byte(n.next_in_index++)&255,s.mode=knt,2);case knt:return s.mode=_F,n.msg="need dictionary",s.marker=0,-2;case kL:if(o=s.blocks.proc(n,o),o==-3){s.mode=_F,s.marker=0;break}if(o==0&&(o=i),o!=1)return o;o=i,s.blocks.reset(n,s.was),s.mode=Sgt;case Sgt:return n.avail_in=0,1;case _F:return-3;default:return-2}},t.inflateSetDictionary=function(n,i,o){let a=0,s=o;if(!n||!n.istate||n.istate.mode!=knt)return-2;let l=n.istate;return s>=1<0&&n.next_in_index!=u&&(r(n.next_in_index),u=n.next_in_index)}while(n.avail_in>0||n.avail_out===0);return d.length>1?(h=new Uint8Array(V),d.forEach(function(F){h.set(F,R),R+=F.length})):h=d[0]?new Uint8Array(d[0]):new Uint8Array,h}},e.flush=function(){n.inflateEnd()}}var nYi=b(W(),1);var K2i=b(W(),1);var BI="/",xnt=new Date(2107,11,31),Xnt=new Date(1980,0,1),Ka=void 0,vh="undefined",tW="function";var j2i=b(W(),1);var YL=class{constructor(e){return class extends TransformStream{constructor(n,i){let o=new e(i);super({transform(a,s){s.enqueue(o.append(a))},flush(a){let s=o.flush();s&&a.enqueue(s)}})}}}};var Wfe=64,Cgt=2;try{typeof navigator!=vh&&navigator.hardwareConcurrency&&(Cgt=navigator.hardwareConcurrency)}catch{}var ffe={chunkSize:512*1024,maxWorkers:Cgt,terminateWorkerTimeout:5e3,useWebWorkers:!0,useCompressionStream:!0,workerScripts:Ka,CompressionStreamNative:typeof CompressionStream!=vh&&CompressionStream,DecompressionStreamNative:typeof DecompressionStream!=vh&&DecompressionStream},OF=Object.assign({},ffe);function xL(){return OF}function kv(t){return Math.max(t.chunkSize,Wfe)}function QI(t){let{baseURL:e,chunkSize:n,maxWorkers:i,terminateWorkerTimeout:o,useCompressionStream:a,useWebWorkers:s,Deflate:l,Inflate:r,CompressionStream:d,DecompressionStream:m,workerScripts:h}=t;if(DF("baseURL",e),DF("chunkSize",n),DF("maxWorkers",i),DF("terminateWorkerTimeout",o),DF("useCompressionStream",a),DF("useWebWorkers",s),l&&(OF.CompressionStream=new YL(l)),r&&(OF.DecompressionStream=new YL(r)),DF("CompressionStream",d),DF("DecompressionStream",m),h!==Ka){let{deflate:u,inflate:R}=h;if((u||R)&&(OF.workerScripts||(OF.workerScripts={})),u){if(!Array.isArray(u))throw new Error("workerScripts.deflate must be an array");OF.workerScripts.deflate=u}if(R){if(!Array.isArray(R))throw new Error("workerScripts.inflate must be an array");OF.workerScripts.inflate=R}}}function DF(t,e){e!==Ka&&(OF[t]=e)}var oYi=b(W(),1);var zYi=b(W(),1);var MYi=b(W(),1);var XYi=b(W(),1);var dYi=b(W(),1);var sYi=b(W(),1),Igt=[];for(let t=0;t<256;t++){let e=t;for(let n=0;n<8;n++)e&1?e=e>>>1^3988292384:e=e>>>1;Igt[t]=e}var eW=class{constructor(e){this.crc=e||-1}append(e){let n=this.crc|0;for(let i=0,o=e.length|0;i>>8^Igt[(n^e[i])&255];this.crc=n}get(){return~this.crc}};var XL=class extends TransformStream{constructor(){let e,n=new eW;super({transform(i,o){n.append(i),o.enqueue(i)},flush(){let i=new Uint8Array(4);new DataView(i.buffer).setUint32(0,n.get()),e.value=i}}),e=this}};var EYi=b(W(),1);var hYi=b(W(),1);function Yv(t){if(typeof TextEncoder==vh){t=unescape(encodeURIComponent(t));let e=new Uint8Array(t.length);for(let n=0;n0&&e&&(t[n-1]=Kc.partial(e,t[n-1]&2147483648>>e-1,1)),t},partial(t,e,n){return t===32?e:(n?e|0:e<<32-t)+t*1099511627776},getPartial(t){return Math.round(t/1099511627776)||32},_shiftRight(t,e,n,i){for(i===void 0&&(i=[]);e>=32;e-=32)i.push(n),n=0;if(e===0)return i.concat(t);for(let s=0;s>>e),n=t[s]<<32-e;let o=t.length?t[t.length-1]:0,a=Kc.getPartial(o);return i.push(Kc.partial(e+a&31,e+a>32?n:i.pop(),1)),i}},JL={bytes:{fromBits(t){let n=Kc.bitLength(t)/8,i=new Uint8Array(n),o;for(let a=0;a>>24,o<<=8;return i},toBits(t){let e=[],n,i=0;for(n=0;n9007199254740991)throw new Error("Cannot hash more than 2^53 - 1 bits");let a=new Uint32Array(n),s=0;for(let l=e.blockSize+i-(e.blockSize+i&e.blockSize-1);l<=o;l+=e.blockSize)e._block(a.subarray(16*s,16*(s+1))),s+=1;return n.splice(0,16*s),e}finalize(){let t=this,e=t._buffer,n=t._h;e=Kc.concat(e,[Kc.partial(1,1)]);for(let i=e.length+2;i&15;i++)e.push(0);for(e.push(Math.floor(t._length/4294967296)),e.push(t._length|0);e.length;)t._block(e.splice(0,16));return t.reset(),n}_f(t,e,n,i){if(t<=19)return e&n|~e&i;if(t<=39)return e^n^i;if(t<=59)return e&n|e&i|n&i;if(t<=79)return e^n^i}_S(t,e){return e<>>32-t}_block(t){let e=this,n=e._h,i=Array(80);for(let d=0;d<16;d++)i[d]=t[d];let o=n[0],a=n[1],s=n[2],l=n[3],r=n[4];for(let d=0;d<=79;d++){d>=16&&(i[d]=e._S(1,i[d-3]^i[d-8]^i[d-14]^i[d-16]));let m=e._S(5,o)+e._f(d,a,s,l)+r+i[d]+e._key[Math.floor(d/20)]|0;r=l,l=s,s=e._S(30,a),a=o,o=m}n[0]=n[0]+o|0,n[1]=n[1]+a|0,n[2]=n[2]+s|0,n[3]=n[3]+l|0,n[4]=n[4]+r|0}};var Jnt={};Jnt.aes=class{constructor(t){let e=this;e._tables=[[[],[],[],[],[]],[[],[],[],[],[]]],e._tables[0][0][0]||e._precompute();let n=e._tables[0][4],i=e._tables[1],o=t.length,a,s,l,r=1;if(o!==4&&o!==6&&o!==8)throw new Error("invalid aes key size");for(e._key=[s=t.slice(0),l=[]],a=o;a<4*o+28;a++){let d=s[a-1];(a%o===0||o===8&&a%o===4)&&(d=n[d>>>24]<<24^n[d>>16&255]<<16^n[d>>8&255]<<8^n[d&255],a%o===0&&(d=d<<8^d>>>24^r<<24,r=r<<1^(r>>7)*283)),s[a]=s[a-o]^d}for(let d=0;a;d++,a--){let m=s[d&3?a:a-4];a<=4||d<4?l[d]=m:l[d]=i[0][n[m>>>24]]^i[1][n[m>>16&255]]^i[2][n[m>>8&255]]^i[3][n[m&255]]}}encrypt(t){return this._crypt(t,0)}decrypt(t){return this._crypt(t,1)}_precompute(){let t=this._tables[0],e=this._tables[1],n=t[4],i=e[4],o=[],a=[],s,l,r,d;for(let m=0;m<256;m++)a[(o[m]=m<<1^(m>>7)*283)^m]=m;for(let m=s=0;!n[m];m^=l||1,s=a[s]||1){let h=s^s<<1^s<<2^s<<3^s<<4;h=h>>8^h&255^99,n[m]=h,i[h]=m,d=o[r=o[l=o[m]]];let u=d*16843009^r*65537^l*257^m*16843008,R=o[h]*257^h*16843008;for(let V=0;V<4;V++)t[V][m]=R=R<<24^R>>>8,e[V][h]=u=u<<24^u>>>8}for(let m=0;m<5;m++)t[m]=t[m].slice(0),e[m]=e[m].slice(0)}_crypt(t,e){if(t.length!==4)throw new Error("invalid aes block size");let n=this._key[e],i=n.length/4-2,o=[0,0,0,0],a=this._tables[e],s=a[0],l=a[1],r=a[2],d=a[3],m=a[4],h=t[0]^n[0],u=t[e?3:1]^n[1],R=t[2]^n[2],V=t[e?1:3]^n[3],F=4,U,G,A;for(let S=0;S>>24]^l[u>>16&255]^r[R>>8&255]^d[V&255]^n[F],G=s[u>>>24]^l[R>>16&255]^r[V>>8&255]^d[h&255]^n[F+1],A=s[R>>>24]^l[V>>16&255]^r[h>>8&255]^d[u&255]^n[F+2],V=s[V>>>24]^l[h>>16&255]^r[u>>8&255]^d[R&255]^n[F+3],F+=4,h=U,u=G,R=A;for(let S=0;S<4;S++)o[e?3&-S:S]=m[h>>>24]<<24^m[u>>16&255]<<16^m[R>>8&255]<<8^m[V&255]^n[F++],U=h,h=u,u=R,R=V,V=U;return o}};var ygt={getRandomValues(t){let e=new Uint32Array(t.buffer),n=i=>{let o=987654321,a=4294967295;return function(){return o=36969*(o&65535)+(o>>16)&a,i=18e3*(i&65535)+(i>>16)&a,(((o<<16)+i&a)/4294967296+.5)*(Math.random()>.5?1:-1)}};for(let i=0,o;i>24&255)===255){let e=t>>16&255,n=t>>8&255,i=t&255;e===255?(e=0,n===255?(n=0,i===255?i=0:++i):++n):++e,t=0,t+=e<<16,t+=n<<8,t+=i}else t+=1<<24;return t}incCounter(t){(t[0]=this.incWord(t[0]))===0&&(t[1]=this.incWord(t[1]))}calculate(t,e,n){let i;if(!(i=e.length))return[];let o=Kc.bitLength(e);for(let a=0;a>5)+1<<2,a,s,l,r,d,m=new ArrayBuffer(o),h=new DataView(m),u=0,R=Kc;for(e=JL.bytes.toBits(e),d=1;u<(o||1);d++){for(a=s=t.encrypt(R.concat(e,[d])),l=1;lo&&(t=new n().update(t).finalize());for(let a=0;athis.resolveReady=s),password:Jgt(e,n),signed:i,strength:o-1,pending:new Uint8Array})},async transform(s,l){let r=this,{password:d,strength:m,resolveReady:h,ready:u}=r;d?(await Nfe(r,m,d,RV(s,0,ML[m]+2)),s=RV(s,ML[m]+2),a?l.error(new Error(nW)):h()):await u;let R=new Uint8Array(s.length-PF-(s.length-PF)%kI);l.enqueue(xgt(r,s,R,0,PF,!0))},async flush(s){let{signed:l,ctr:r,hmac:d,pending:m,ready:h}=this;if(d&&r){await h;let u=RV(m,0,m.length-PF),R=RV(m,m.length-PF),V=new Uint8Array;if(u.length){let F=DL(GR,u);d.update(F);let U=r.update(F);V=_L(GR,U)}if(l){let F=RV(_L(GR,d.digest()),0,PF);for(let U=0;Uthis.resolveReady=a),password:Jgt(e,n),strength:i-1,pending:new Uint8Array})},async transform(a,s){let l=this,{password:r,strength:d,resolveReady:m,ready:h}=l,u=new Uint8Array;r?(u=await yfe(l,d,r),m()):await h;let R=new Uint8Array(u.length+a.length-a.length%kI);R.set(u,0),s.enqueue(xgt(l,a,R,u.length,0))},async flush(a){let{ctr:s,hmac:l,pending:r,ready:d}=this;if(l&&s){await d;let m=new Uint8Array;if(r.length){let h=s.update(DL(GR,r));l.update(h),m=_L(GR,h)}o.signature=_L(GR,l.digest()).slice(0,PF),a.enqueue(_nt(m,o.signature))}}}),o=this}};function xgt(t,e,n,i,o,a){let{ctr:s,hmac:l,pending:r}=t,d=e.length-o;r.length&&(e=_nt(r,e),n=kfe(n,d-d%kI));let m;for(m=0;m<=d-kI;m+=kI){let h=DL(GR,RV(e,m,m+kI));a&&l.update(h);let u=s.update(h);a||l.update(u),n.set(_L(GR,u),m+i)}return t.pending=RV(e,m),n}async function Nfe(t,e,n,i){let o=await Xgt(t,e,n,RV(i,0,ML[e])),a=RV(i,ML[e]);if(o[0]!=a[0]||o[1]!=a[1])throw new Error(wF)}async function yfe(t,e,n){let i=xv(new Uint8Array(ML[e])),o=await Xgt(t,e,n,i);return _nt(i,o)}async function Xgt(t,e,n,i){t.password=null;let o=await Bfe(Ufe,n,Sfe,!1,Tfe),a=await Qfe(Object.assign({salt:i},Mnt),o,8*(LL[e]*2+2)),s=new Uint8Array(a),l=DL(GR,RV(s,0,LL[e])),r=DL(GR,RV(s,LL[e],LL[e]*2)),d=RV(s,LL[e]*2);return Object.assign(t,{keys:{key:l,authentication:r,passwordVerification:d},ctr:new Cfe(new Efe(l),Array.from(gfe)),hmac:new Ife(r)}),d}async function Bfe(t,e,n,i,o){if(Bgt)try{return await OL.importKey(t,e,n,i,o)}catch{return Bgt=!1,HF.importKey(e)}else return HF.importKey(e)}async function Qfe(t,e,n){if(Qgt)try{return await OL.deriveBits(t,e,n)}catch{return Qgt=!1,HF.pbkdf2(e,t.salt,Mnt.iterations,n)}else return HF.pbkdf2(e,t.salt,Mnt.iterations,n)}function Jgt(t,e){return e===Ka?Yv(t):e}function _nt(t,e){let n=t;return t.length+e.length&&(n=new Uint8Array(t.length+e.length),n.set(t,0),n.set(e,t.length)),n}function kfe(t,e){if(e&&e>t.length){let n=t;t=new Uint8Array(e),t.set(n,0)}return t}function RV(t,e,n){return t.subarray(e,n)}function _L(t,e){return t.fromBits(e)}function DL(t,e){return t.toBits(e)}var yYi=b(W(),1);var YI=12,Mv=class extends TransformStream{constructor({password:e,passwordVerification:n,checkPasswordOnly:i}){super({start(){Object.assign(this,{password:e,passwordVerification:n}),Dgt(this,e)},transform(o,a){let s=this;if(s.password){let l=Lgt(s,o.subarray(0,YI));if(s.password=null,l[YI-1]!=s.passwordVerification)throw new Error(wF);o=o.subarray(YI)}i?a.error(new Error(nW)):a.enqueue(Lgt(s,o))}})}},_v=class extends TransformStream{constructor({password:e,passwordVerification:n}){super({start(){Object.assign(this,{password:e,passwordVerification:n}),Dgt(this,e)},transform(i,o){let a=this,s,l;if(a.password){a.password=null;let r=xv(new Uint8Array(YI));r[YI-1]=a.passwordVerification,s=new Uint8Array(i.length+r.length),s.set(Mgt(a,r),0),l=YI}else s=new Uint8Array(i.length),l=0;s.set(Mgt(a,i),l),o.enqueue(s)}})}};function Lgt(t,e){let n=new Uint8Array(e.length);for(let i=0;i>>24]),o=~t.crcKey2.get(),t.keys=[n,i,o]}function Ogt(t){let e=t.keys[2]|2;return Hgt(Math.imul(e,e^1)>>>8)}function Hgt(t){return t&255}function _gt(t){return t&4294967295}var wgt="deflate-raw",Dv=class extends TransformStream{constructor(e,{chunkSize:n,CompressionStream:i,CompressionStreamNative:o}){super({});let{compressed:a,encrypted:s,useCompressionStream:l,zipCrypto:r,signed:d,level:m}=e,h=this,u,R,V=Pgt(super.readable);(!s||r)&&d&&(u=new XL,V=AR(V,u)),a&&(V=Kgt(V,l,{level:m,chunkSize:n},o,i)),s&&(r?V=AR(V,new _v(e)):(R=new Jv(e),V=AR(V,R))),vgt(h,V,()=>{let F;s&&!r&&(F=R.signature),(!s||r)&&d&&(F=new DataView(u.value.buffer).getUint32(0)),h.signature=F})}},Ov=class extends TransformStream{constructor(e,{chunkSize:n,DecompressionStream:i,DecompressionStreamNative:o}){super({});let{zipCrypto:a,encrypted:s,signed:l,signature:r,compressed:d,useCompressionStream:m}=e,h,u,R=Pgt(super.readable);s&&(a?R=AR(R,new Mv(e)):(u=new Xv(e),R=AR(R,u))),d&&(R=Kgt(R,m,{chunkSize:n},o,i)),(!s||a)&&l&&(h=new XL,R=AR(R,h)),vgt(this,R,()=>{if((!s||a)&&l){let V=new DataView(h.value.buffer);if(r!=V.getUint32(0,!1))throw new Error(QS)}})}};function Pgt(t){return AR(t,new TransformStream({transform(e,n){e&&e.length&&n.enqueue(e)}}))}function vgt(t,e,n){e=AR(e,new TransformStream({flush:n})),Object.defineProperty(t,"readable",{get(){return e}})}function Kgt(t,e,n,i,o){try{let a=e&&i?i:o;t=AR(t,new a(wgt,n))}catch{if(e)try{t=AR(t,new o(wgt,n))}catch{return t}else return t}return t}function AR(t,e){return t.pipeThrough(e)}var zgt="message",jgt="start",qgt="pull",Ont="data",$gt="ack",Hnt="close",Pv="deflate",vv="inflate";var Hv=class extends TransformStream{constructor(e,n){super({});let i=this,{codecType:o}=e,a;o.startsWith(Pv)?a=Dv:o.startsWith(vv)&&(a=Ov);let s=0,l=0,r=new a(e,n),d=super.readable,m=new TransformStream({transform(u,R){u&&u.length&&(l+=u.length,R.enqueue(u))},flush(){Object.assign(i,{inputSize:l})}}),h=new TransformStream({transform(u,R){u&&u.length&&(s+=u.length,R.enqueue(u))},flush(){let{signature:u}=r;Object.assign(i,{signature:u,outputSize:s,inputSize:l})}});Object.defineProperty(i,"readable",{get(){return d.pipeThrough(m).pipeThrough(r).pipeThrough(h)}})}},wv=class extends TransformStream{constructor(e){let n;super({transform:i,flush(o){n&&n.length&&o.enqueue(n)}});function i(o,a){if(n){let s=new Uint8Array(n.length+o.length);s.set(n),s.set(o,n.length),o=s,n=null}o.length>e?(a.enqueue(o.slice(0,e)),i(o.slice(e),a)):n=o}}};var HYi=b(W(),1);var nEt=typeof Worker!=vh;var xI=class{constructor(e,{readable:n,writable:i},{options:o,config:a,streamOptions:s,useWebWorkers:l,transferStreams:r,scripts:d},m){let{signal:h}=s;return Object.assign(e,{busy:!0,readable:n.pipeThrough(new wv(a.chunkSize)).pipeThrough(new Pnt(n,s),{signal:h}),writable:i,options:Object.assign({},o),scripts:d,transferStreams:r,terminate(){return new Promise(u=>{let{worker:R,busy:V}=e;R?(V?e.resolveTerminated=u:(R.terminate(),u()),e.interface=null):u()})},onTaskFinished(){let{resolveTerminated:u}=e;u&&(e.resolveTerminated=null,e.terminated=!0,e.worker.terminate(),u()),e.busy=!1,m(e)}}),(l&&nEt?Yfe:iEt)(e,a)}},Pnt=class extends TransformStream{constructor(e,{onstart:n,onprogress:i,size:o,onend:a}){let s=0;super({async start(){n&&await wnt(n,o)},async transform(l,r){s+=l.length,i&&await wnt(i,s,o),r.enqueue(l)},async flush(){e.size=s,a&&await wnt(a,s)}})}};async function wnt(t,...e){try{await t(...e)}catch{}}function iEt(t,e){return{run:()=>xfe(t,e)}}function Yfe(t,e){let{baseURL:n,chunkSize:i}=e;if(!t.interface){let o;try{o=Lfe(t.scripts[0],n,t)}catch{return nEt=!1,iEt(t,e)}Object.assign(t,{worker:o,interface:{run:()=>Xfe(t,{chunkSize:i})}})}return t.interface}async function xfe({options:t,readable:e,writable:n,onTaskFinished:i},o){try{let a=new Hv(t,o);await e.pipeThrough(a).pipeTo(n,{preventClose:!0,preventAbort:!0});let{signature:s,inputSize:l,outputSize:r}=a;return{signature:s,inputSize:l,outputSize:r}}finally{i()}}async function Xfe(t,e){let n,i,o=new Promise((u,R)=>{n=u,i=R});Object.assign(t,{reader:null,writer:null,resolveResult:n,rejectResult:i,result:o});let{readable:a,options:s,scripts:l}=t,{writable:r,closed:d}=Jfe(t.writable),m=Kv({type:jgt,scripts:l.slice(1),options:s,config:e,readable:a,writable:r},t);m||Object.assign(t,{reader:a.getReader(),writer:r.getWriter()});let h=await o;return m||await r.getWriter().close(),await d,h}function Jfe(t){let e,n=new Promise(o=>e=o);return{writable:new WritableStream({async write(o){let a=t.getWriter();await a.ready,await a.write(o),a.releaseLock()},close(){e()},abort(o){return t.getWriter().abort(o)}}),closed:n}}var tEt=!0,eEt=!0;function Lfe(t,e,n){let i={type:"module"},o,a;typeof t==tW&&(t=t());try{o=new URL(t,e)}catch{o=t}if(tEt)try{a=new Worker(o)}catch{tEt=!1,a=new Worker(o,i)}else a=new Worker(o,i);return a.addEventListener(zgt,s=>Mfe(s,n)),a}function Kv(t,{worker:e,writer:n,onTaskFinished:i,transferStreams:o}){try{let{value:a,readable:s,writable:l}=t,r=[];if(a&&(a.byteLength!G.busy);if(U)return aEt(U),new xI(U,t,e,F);if(kS.lengthvnt.push({resolve:G,stream:t,workerOptions:e}))}function F(U){if(vnt.length){let[{resolve:G,stream:A,workerOptions:S}]=vnt.splice(0,1);G(new xI(U,A,S,F))}else U.worker?(aEt(U),_fe(U,e)):kS=kS.filter(G=>G!=U)}}function _fe(t,e){let{config:n}=e,{terminateWorkerTimeout:i}=n;Number.isFinite(i)&&i>=0&&(t.terminated?t.terminated=!1:t.terminateTimeout=setTimeout(async()=>{kS=kS.filter(o=>o!=t);try{await t.terminate()}catch{}},i))}function aEt(t){let{terminateTimeout:e}=t;e&&(clearTimeout(e),t.terminateTimeout=null)}var txi=b(W(),1);var Dfe="Writer iterator completed too soon",Ofe="text/plain";var Hfe="Content-Type";var wfe=64*1024,jnt="writable",XI=class{constructor(){this.size=0}init(){this.initialized=!0}},jv=class extends XI{get readable(){let e=this,{chunkSize:n=wfe}=e,i=new ReadableStream({start(){this.chunkOffset=0},async pull(o){let{offset:a=0,size:s,diskNumberStart:l}=i,{chunkOffset:r}=this;o.enqueue(await Fd(e,a+r,Math.min(n,s-r),l)),r+n>s?o.close():this.chunkOffset+=n}});return i}},Knt=class extends XI{constructor(){super();let e=this,n=new WritableStream({write(i){return e.writeUint8Array(i)}});Object.defineProperty(e,jnt,{get(){return n}})}writeUint8Array(){}};var qv=class extends Knt{constructor(e){super(),Object.assign(this,{data:"data:"+(e||"")+";base64,",pending:[]})}writeUint8Array(e){let n=this,i=0,o=n.pending,a=n.pending.length;for(n.pending="",i=0;i2?n.data+=btoa(o):n.pending=o}getData(){return this.data+btoa(this.pending)}},iW=class extends jv{constructor(e){super(),Object.assign(this,{blob:e,size:e.size})}async readUint8Array(e,n){let i=this,o=e+n,s=await(e||on&&(s=s.slice(e,o)),new Uint8Array(s)}},HL=class extends XI{constructor(e){super();let n=this,i=new TransformStream,o=[];e&&o.push([Hfe,e]),Object.defineProperty(n,jnt,{get(){return i.writable}}),n.blob=new Response(i.readable,{headers:o}).blob()}getData(){return this.blob}},$v=class extends iW{constructor(e){super(new Blob([e],{type:Ofe}))}},t3=class extends HL{constructor(e){super(e),Object.assign(this,{encoding:e,utf8:!e||e.toLowerCase()=="utf-8"})}async getData(){let{encoding:e,utf8:n}=this,i=await super.getData();if(i.text&&n)return i.text();{let o=new FileReader;return new Promise((a,s)=>{Object.assign(o,{onload:({target:l})=>a(l.result),onerror:()=>s(o.error)}),o.readAsText(i,e)})}}};var znt=class extends jv{constructor(e){super(),this.readers=e}async init(){let e=this,{readers:n}=e;e.lastDiskNumber=0,e.lastDiskOffset=0,await Promise.all(n.map(async(i,o)=>{await i.init(),o!=n.length-1&&(e.lastDiskOffset+=i.size),e.size+=i.size})),super.init()}async readUint8Array(e,n,i=0){let o=this,{readers:a}=this,s,l=i;l==-1&&(l=a.length-1);let r=e;for(;r>=a[l].size;)r-=a[l].size,l++;let d=a[l],m=d.size;if(r+n<=m)s=await Fd(d,r,n);else{let h=m-r;s=new Uint8Array(n),s.set(await Fd(d,r,h)),s.set(await o.readUint8Array(e+h,n-h,i),h)}return o.lastDiskNumber=Math.max(l,o.lastDiskNumber),s}},e3=class extends XI{constructor(e,n=4294967295){super();let i=this;Object.assign(i,{diskNumber:0,diskOffset:0,size:0,maxSize:n,availableSize:n});let o,a,s,l=new WritableStream({async write(m){let{availableSize:h}=i;if(s)m.length>=h?(await r(m.slice(0,h)),await d(),i.diskOffset+=o.size,i.diskNumber++,s=null,await this.write(m.slice(h))):await r(m);else{let{value:u,done:R}=await e.next();if(R&&!u)throw new Error(Dfe);o=u,o.size=0,o.maxSize&&(i.maxSize=o.maxSize),i.availableSize=i.maxSize,await TR(o),a=u.writable,s=a.getWriter(),await this.write(m)}},async close(){await s.ready,await d()}});Object.defineProperty(i,jnt,{get(){return l}});async function r(m){let h=m.length;h&&(await s.ready,await s.write(m),o.size+=h,i.size+=h,i.availableSize-=h)}async function d(){a.size=o.size,await s.close()}}};async function TR(t,e){if(t.init&&!t.initialized)await t.init(e);else return Promise.resolve()}function n3(t){return Array.isArray(t)&&(t=new znt(t)),t instanceof ReadableStream&&(t={readable:t}),t}function i3(t){t.writable===Ka&&typeof t.next==tW&&(t=new e3(t)),t instanceof WritableStream&&(t={writable:t});let{writable:e}=t;return e.size===Ka&&(e.size=0),t instanceof e3||Object.assign(t,{diskNumber:0,diskOffset:0,availableSize:1/0,maxSize:1/0}),t}function Fd(t,e,n,i){return t.readUint8Array(e,n,i)}var Zxi=b(W(),1);var axi=b(W(),1);var nxi=b(W(),1),sEt="\0\u263A\u263B\u2665\u2666\u2663\u2660\u2022\u25D8\u25CB\u25D9\u2642\u2640\u266A\u266B\u263C\u25BA\u25C4\u2195\u203C\xB6\xA7\u25AC\u21A8\u2191\u2193\u2192\u2190\u221F\u2194\u25B2\u25BC !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~\u2302\xC7\xFC\xE9\xE2\xE4\xE0\xE5\xE7\xEA\xEB\xE8\xEF\xEE\xEC\xC4\xC5\xC9\xE6\xC6\xF4\xF6\xF2\xFB\xF9\xFF\xD6\xDC\xA2\xA3\xA5\u20A7\u0192\xE1\xED\xF3\xFA\xF1\xD1\xAA\xBA\xBF\u2310\xAC\xBD\xBC\xA1\xAB\xBB\u2591\u2592\u2593\u2502\u2524\u2561\u2562\u2556\u2555\u2563\u2551\u2557\u255D\u255C\u255B\u2510\u2514\u2534\u252C\u251C\u2500\u253C\u255E\u255F\u255A\u2554\u2569\u2566\u2560\u2550\u256C\u2567\u2568\u2564\u2565\u2559\u2558\u2552\u2553\u256B\u256A\u2518\u250C\u2588\u2584\u258C\u2590\u2580\u03B1\xDF\u0393\u03C0\u03A3\u03C3\xB5\u03C4\u03A6\u0398\u03A9\u03B4\u221E\u03C6\u03B5\u2229\u2261\xB1\u2265\u2264\u2320\u2321\xF7\u2248\xB0\u2219\xB7\u221A\u207F\xB2\u25A0 ".split(""),Pfe=sEt.length==256;function lEt(t){if(Pfe){let e="";for(let n=0;nthis[n]=e[n])}};var cit="File format is not recognized",qfe="End of central directory not found",$fe="End of Zip64 central directory locator not found",tFe="Central directory header not found",eFe="Local file header not found",nFe="Zip64 extra field not found",iFe="File contains encrypted entry",oFe="Encryption method not supported",cEt="Compression method not supported",mEt="Split zip file",hEt="utf-8",pEt="cp437",aFe=[[iit,4294967295],[oit,4294967295],[ait,4294967295],[o3,65535]],sFe={[65535]:{getValue:Ol,bytes:4},[4294967295]:{getValue:s3,bytes:8}},p3=class{constructor(e,n={}){Object.assign(this,{reader:n3(e),options:n,config:xL()})}async*getEntriesGenerator(e={}){let n=this,{reader:i}=n,{config:o}=n;if(await TR(i),(i.size===Ka||!i.readUint8Array)&&(i=new iW(await new Response(i.readable).blob()),await TR(i)),i.size<22)throw new Error(cit);i.chunkSize=kv(o);let a=await mFe(i,101010256,i.size,22,65535*16);if(!a){let M=await Fd(i,0,4),Z=jr(M);throw Ol(Z)==134695760?new Error(mEt):new Error(qfe)}let s=jr(a),l=Ol(s,12),r=Ol(s,16),d=a.offset,m=zr(s,20),h=d+22+m,u=zr(s,4),R=i.lastDiskNumber||0,V=zr(s,6),F=zr(s,8),U=0,G=0;if(r==4294967295||l==4294967295||F==65535||V==65535){let M=await Fd(i,a.offset-20,20),Z=jr(M);if(Ol(Z,0)==117853008){r=s3(Z,8);let E=await Fd(i,r,56,-1),I=jr(E),B=a.offset-20-56;if(Ol(I,0)!=101075792&&r!=B){let X=r;r=B,U=r-X,E=await Fd(i,r,56,-1),I=jr(E)}if(Ol(I,0)!=101075792)throw new Error($fe);u==65535&&(u=Ol(I,16)),V==65535&&(V=Ol(I,20)),F==65535&&(F=s3(I,32)),l==4294967295&&(l=s3(I,40)),r-=l}}if(r>=i.size&&(U=i.size-r-l-22,r=i.size-l-22),R!=u)throw new Error(mEt);if(r<0)throw new Error(cit);let A=0,S=await Fd(i,r,l,V),g=jr(S);if(l){let M=a.offset-l;if(Ol(g,A)!=33639248&&r!=M){let Z=r;r=M,U+=r-Z,S=await Fd(i,r,l,V),g=jr(S)}}let C=a.offset-r-(i.lastDiskOffset||0);if(l!=C&&C>=0&&(l=C,S=await Fd(i,r,l,V),g=jr(S)),r<0||r>=i.size)throw new Error(cit);let y=vm(n,e,"filenameEncoding"),Y=vm(n,e,"commentEncoding");for(let M=0;MZ.getData(kt,Wt,Mt),A=H;let{onprogress:Nt}=e;if(Nt)try{await Nt(M+1,F,new vF(Z))}catch{}yield Wt}let Q=vm(n,e,"extractPrependedData"),J=vm(n,e,"extractAppendedData");return Q&&(n.prependedData=G>0?await Fd(i,0,G):new Uint8Array),n.comment=m?await Fd(i,d+22,m):new Uint8Array,J&&(n.appendedData=h>>8&255:u>>>24&255),signature:u,compressed:d!=0,encrypted:C,useWebWorkers:vm(o,i,"useWebWorkers"),useCompressionStream:vm(o,i,"useCompressionStream"),transferStreams:vm(o,i,"transferStreams"),checkPasswordOnly:Z},config:m,streamOptions:{signal:M,size:Q,onstart:I,onprogress:B,onend:X}},P=0;try{({outputSize:P}=await zv({readable:J,writable:E},_))}catch(w){if(!Z||w.message!=nW)throw w}finally{let w=vm(o,i,"preventClose");E.size+=P,!w&&!E.locked&&await E.getWriter().close()}return Z?Ka:e.getData?e.getData():E}};function uEt(t,e,n){let i=t.rawBitFlag=zr(e,n+2),o=(i&1)==1,a=Ol(e,n+6);Object.assign(t,{encrypted:o,version:zr(e,n),bitFlag:{level:(i&6)>>1,dataDescriptor:(i&8)==8,languageEncodingFlag:(i&2048)==2048},rawLastModDate:a,lastModDate:hFe(a),filenameLength:zr(e,n+22),extraFieldLength:zr(e,n+24)})}async function ZEt(t,e,n,i,o){let{rawExtraField:a}=e,s=e.extraField=new Map,l=jr(new Uint8Array(a)),r=0;try{for(;re[o]==a);for(let o=0,a=0;o=5&&(a.push(JI),s.push(a3));let l=1;a.forEach((r,d)=>{if(t.data.length>=l+4){let m=Ol(i,l);e[r]=t[r]=new Date(m*1e3);let h=s[d];t[h]=m}l+=4})}async function mFe(t,e,n,i,o){let a=new Uint8Array(4),s=jr(a);pFe(s,0,e);let l=i+o;return await r(i)||await r(Math.min(l,n));async function r(d){let m=n-d,h=await Fd(t,m,d);for(let u=h.length-i;u>=0;u--)if(h[u]==a[0]&&h[u+1]==a[1]&&h[u+2]==a[2]&&h[u+3]==a[3])return{offset:m+u,buffer:h.slice(u,u+i).buffer}}}function vm(t,e,n){return e[n]===Ka?t.options[n]:e[n]}function hFe(t){let e=(t&4294901760)>>16,n=t&65535;try{return new Date(1980+((e&65024)>>9),((e&480)>>5)-1,e&31,(n&63488)>>11,(n&2016)>>5,(n&31)*2,0)}catch{}}function mit(t){return new Date(Number(t/BigInt(1e4)-BigInt(116444736e5)))}function LI(t,e){return t.getUint8(e)}function zr(t,e){return t.getUint16(e,!0)}function Ol(t,e){return t.getUint32(e,!0)}function s3(t,e){return Number(t.getBigUint64(e,!0))}function pFe(t,e,n){t.setUint32(e,n,!0)}function jr(t){return new DataView(t.buffer)}var Axi=b(W(),1);var RFe="File already exists",bFe="Zip file comment exceeds 64KB",WFe="File entry comment exceeds 64KB",fFe="File entry name exceeds 64KB",WEt="Version exceeds 65535",FFe="The strength must equal 1, 2, or 3",UFe="Extra field type exceeds 65535",GFe="Extra field data exceeds 64KB",Tit="Zip64 is not supported (make sure 'keepOrder' is set to 'true')",fEt=new Uint8Array([7,0,2,0,65,69,3,0,0]),Ait=0,FEt=[],Z3=class{constructor(e,n={}){e=i3(e);let i=e.availableSize!==Ka&&e.availableSize>0&&e.availableSize!==1/0&&e.maxSize!==Ka&&e.maxSize>0&&e.maxSize!==1/0;Object.assign(this,{writer:e,addSplitZipSignature:i,options:n,config:xL(),files:new Map,filenames:new Set,offset:e.writable.size,pendingEntriesSize:0,pendingAddFileCalls:new Set,bufferedWrites:0})}async add(e="",n,i={}){let o=this,{pendingAddFileCalls:a,config:s}=o;AitFEt.push(r));let l;try{if(e=e.trim(),o.filenames.has(e))throw new Error(RFe);return o.filenames.add(e),l=AFe(o,e,n,i),a.add(l),await l}catch(r){throw o.filenames.delete(e),r}finally{a.delete(l);let r=FEt.shift();r?r():Ait--}}async close(e=new Uint8Array,n={}){let i=this,{pendingAddFileCalls:o,writer:a}=this,{writable:s}=a;for(;o.size;)await Promise.allSettled(Array.from(o));return await BFe(this,e,n),ms(i,n,"preventClose")||await s.getWriter().close(),a.getData?a.getData():s}};async function AFe(t,e,n,i){e=e.trim(),i.directory&&!e.endsWith(BI)?e+=BI:i.directory=e.endsWith(BI);let o=ms(t,i,"encodeText",Yv),a=o(e);if(ta(a)>65535)throw new Error(fFe);let s=i.comment||"",l=o(s);if(ta(l)>65535)throw new Error(WFe);let r=ms(t,i,"version",20);if(r>65535)throw new Error(WEt);let d=ms(t,i,"versionMadeBy",20);if(d>65535)throw new Error(WEt);let m=ms(t,i,JI,new Date),h=ms(t,i,wL),u=ms(t,i,PL),R=ms(t,i,rit,!0),V=ms(t,i,sit,0),F=ms(t,i,lit,0),U=ms(t,i,"password"),G=ms(t,i,"rawPassword"),A=ms(t,i,"encryptionStrength",3),S=ms(t,i,"zipCrypto"),g=ms(t,i,"extendedTimestamp",!0),C=ms(t,i,"keepOrder",!0),y=ms(t,i,"level"),Y=ms(t,i,"useWebWorkers"),Q=ms(t,i,"bufferedWrite"),J=ms(t,i,"dataDescriptorSignature",!1),M=ms(t,i,"signal"),Z=ms(t,i,"useCompressionStream"),E=ms(t,i,"dataDescriptor",!0),I=ms(t,i,dit);if(U!==Ka&&A!==Ka&&(A<1||A>3))throw new Error(FFe);let B=new Uint8Array,{extraField:X}=i;if(X){let Mt=0,qt=0;X.forEach(ie=>Mt+=4+ta(ie)),B=new Uint8Array(Mt),X.forEach((ie,oe)=>{if(oe>65535)throw new Error(UFe);if(ta(ie)>65535)throw new Error(GFe);ar(B,new Uint16Array([oe]),qt),ar(B,new Uint16Array([ta(ie)]),qt+2),ar(B,ie,qt+4),qt+=4+ta(ie)})}let _=0,P=0,w=0,z=I===!0;n&&(n=n3(n),await TR(n),n.size===Ka?(E=!0,(I||I===Ka)&&(I=!0,w=_=4294967295)):(w=n.size,_=QFe(w)));let{diskOffset:H,diskNumber:nt,maxSize:$}=t.writer,dt=z||w>=4294967295,q=z||_>=4294967295,at=z||t.offset+t.pendingEntriesSize-H>=4294967295,Et=ms(t,i,"supportZip64SplitFile",!0)&&z||nt+Math.ceil(t.pendingEntriesSize/$)>=65535;if(at||dt||q||Et){if(I===!1||!C)throw new Error(Tit);I=!0}I=I||!1,i=Object.assign({},i,{rawFilename:a,rawComment:l,version:r,versionMadeBy:d,lastModDate:m,lastAccessDate:h,creationDate:u,rawExtraField:B,zip64:I,zip64UncompressedSize:dt,zip64CompressedSize:q,zip64Offset:at,zip64DiskNumberStart:Et,password:U,rawPassword:G,level:!Z&&t.config.CompressionStream===Ka?0:y,useWebWorkers:Y,encryptionStrength:A,extendedTimestamp:g,zipCrypto:S,bufferedWrite:Q,keepOrder:C,dataDescriptor:E,dataDescriptorSignature:J,signal:M,msDosCompatible:R,internalFileAttribute:V,externalFileAttribute:F,useCompressionStream:Z});let Qt=gFe(i),Wt=CFe(i),Nt=ta(Qt.localHeaderArray,Wt.dataDescriptorArray);P=Nt+_,t.options.usdz&&(P+=P+64),t.pendingEntriesSize+=P;let kt;try{kt=await SFe(t,e,n,{headerInfo:Qt,dataDescriptorInfo:Wt,metadataSize:Nt},i)}finally{t.pendingEntriesSize-=P}return Object.assign(kt,{name:e,comment:s,extraField:X}),new vF(kt)}async function SFe(t,e,n,i,o){let{files:a,writer:s}=t,{keepOrder:l,dataDescriptor:r,signal:d}=o,{headerInfo:m}=i,{usdz:h}=t.options,u=Array.from(a.values()).pop(),R={},V,F,U,G,A,S,g;a.set(e,R);try{let Q;l&&(Q=u&&u.lock,C()),(o.bufferedWrite||t.writerLocked||t.bufferedWrites&&l||!r)&&!h?(S=new TransformStream,g=new Response(S.readable).blob(),S.writable.size=0,V=!0,t.bufferedWrites++,await TR(s)):(S=s,await y()),await TR(S);let{writable:J}=s,{diskOffset:M}=s;if(t.addSplitZipSignature){delete t.addSplitZipSignature;let E=new Uint8Array(4),I=Ud(E);$o(I,0,134695760),await gR(J,E),t.offset+=4}h&&EFe(i,t.offset-M),V||(await Q,await Y(J));let{diskNumber:Z}=s;if(A=!0,R.diskNumberStart=Z,R=await TFe(n,S,R,i,t.config,o),A=!1,a.set(e,R),R.filename=e,V){await S.writable.getWriter().close();let E=await g;await Q,await y(),G=!0,r||(E=await NFe(R,E,J,o)),await Y(J),R.diskNumberStart=s.diskNumber,M=s.diskOffset,await E.stream().pipeTo(J,{preventClose:!0,preventAbort:!0,signal:d}),J.size+=E.size,G=!1}if(R.offset=t.offset-M,R.zip64)yFe(R,o);else if(R.offset>=4294967295)throw new Error(Tit);return t.offset+=R.size,R}catch(Q){if(V&&G||!V&&A){if(t.hasCorruptedEntries=!0,Q)try{Q.corruptedEntry=!0}catch{}V?t.offset+=S.writable.size:t.offset=S.writable.size}throw a.delete(e),Q}finally{V&&t.bufferedWrites--,U&&U(),F&&F()}function C(){R.lock=new Promise(Q=>U=Q)}async function y(){t.writerLocked=!0;let{lockWriter:Q}=t;t.lockWriter=new Promise(J=>F=()=>{t.writerLocked=!1,J()}),await Q}async function Y(Q){ta(m.localHeaderArray)>s.availableSize&&(s.availableSize=0,await gR(Q,new Uint8Array))}}async function TFe(t,e,{diskNumberStart:n,lock:i},o,a,s){let{headerInfo:l,dataDescriptorInfo:r,metadataSize:d}=o,{localHeaderArray:m,headerArray:h,lastModDate:u,rawLastModDate:R,encrypted:V,compressed:F,version:U,compressionMethod:G,rawExtraFieldExtendedTimestamp:A,extraFieldExtendedTimestampFlag:S,rawExtraFieldNTFS:g,rawExtraFieldAES:C}=l,{dataDescriptorArray:y}=r,{rawFilename:Y,lastAccessDate:Q,creationDate:J,password:M,rawPassword:Z,level:E,zip64:I,zip64UncompressedSize:B,zip64CompressedSize:X,zip64Offset:_,zip64DiskNumberStart:P,zipCrypto:w,dataDescriptor:z,directory:H,versionMadeBy:nt,rawComment:$,rawExtraField:dt,useWebWorkers:q,onstart:at,onprogress:st,onend:Et,signal:Qt,encryptionStrength:Wt,extendedTimestamp:Nt,msDosCompatible:kt,internalFileAttribute:Mt,externalFileAttribute:qt,useCompressionStream:ie}=s,oe={lock:i,versionMadeBy:nt,zip64:I,directory:!!H,filenameUTF8:!0,rawFilename:Y,commentUTF8:!0,rawComment:$,rawExtraFieldExtendedTimestamp:A,rawExtraFieldNTFS:g,rawExtraFieldAES:C,rawExtraField:dt,extendedTimestamp:Nt,msDosCompatible:kt,internalFileAttribute:Mt,externalFileAttribute:qt,diskNumberStart:n},He=0,rn=0,de,{writable:zt}=e;if(t){t.chunkSize=kv(a),await gR(zt,m);let Ve=t.readable,We=Ve.size=t.size,Vn={options:{codecType:Pv,level:E,rawPassword:Z,password:M,encryptionStrength:Wt,zipCrypto:V&&w,passwordVerification:V&&w&&R>>8&255,signed:!0,compressed:F,encrypted:V,useWebWorkers:q,useCompressionStream:ie,transferStreams:!1},config:a,streamOptions:{signal:Qt,size:We,onstart:at,onprogress:st,onend:Et}},Ct=await zv({readable:Ve,writable:zt},Vn);rn=Ct.inputSize,He=Ct.outputSize,de=Ct.signature,zt.size+=rn}else await gR(zt,m);let ke;if(I){let Ve=4;B&&(Ve+=8),X&&(Ve+=8),_&&(Ve+=8),P&&(Ve+=4),ke=new Uint8Array(Ve)}else ke=new Uint8Array;return IFe({signature:de,rawExtraFieldZip64:ke,compressedSize:He,uncompressedSize:rn,headerInfo:l,dataDescriptorInfo:r},s),z&&await gR(zt,y),Object.assign(oe,{uncompressedSize:rn,compressedSize:He,lastModDate:u,rawLastModDate:R,creationDate:J,lastAccessDate:Q,encrypted:V,size:d+He,compressionMethod:G,version:U,headerArray:h,signature:de,rawExtraFieldZip64:ke,extraFieldExtendedTimestampFlag:S,zip64UncompressedSize:B,zip64CompressedSize:X,zip64Offset:_,zip64DiskNumberStart:P}),oe}function gFe(t){let{rawFilename:e,lastModDate:n,lastAccessDate:i,creationDate:o,rawPassword:a,password:s,level:l,zip64:r,zipCrypto:d,dataDescriptor:m,directory:h,rawExtraField:u,encryptionStrength:R,extendedTimestamp:V}=t,F=l!==0&&!h,U=!!(s&&ta(s)||a&&ta(a)),G=t.version,A;if(U&&!d){A=new Uint8Array(ta(fEt)+2);let P=Ud(A);ba(P,0,39169),ar(A,fEt,2),R3(P,8,R)}else A=new Uint8Array;let S,g,C;if(V){g=new Uint8Array(9+(i?4:0)+(o?4:0));let P=Ud(g);ba(P,0,21589),ba(P,2,ta(g)-4),C=1+(i?2:0)+(o?4:0),R3(P,4,C);let w=5;$o(P,w,Math.floor(n.getTime()/1e3)),w+=4,i&&($o(P,w,Math.floor(i.getTime()/1e3)),w+=4),o&&$o(P,w,Math.floor(o.getTime()/1e3));try{S=new Uint8Array(36);let z=Ud(S),H=Sit(n);ba(z,0,10),ba(z,2,32),ba(z,8,1),ba(z,10,24),Km(z,12,H),Km(z,20,Sit(i)||H),Km(z,28,Sit(o)||H)}catch{S=new Uint8Array}}else S=g=new Uint8Array;let y=2048;m&&(y=y|8);let Y=0;F&&(Y=8),r&&(G=G>45?G:45),U&&(y=y|1,d||(G=G>51?G:51,Y=99,F&&(A[9]=8)));let Q=new Uint8Array(26),J=Ud(Q);ba(J,0,G),ba(J,2,y),ba(J,4,Y);let M=new Uint32Array(1),Z=Ud(M),E;nxnt?E=xnt:E=n,ba(Z,0,(E.getHours()<<6|E.getMinutes())<<5|E.getSeconds()/2),ba(Z,2,(E.getFullYear()-1980<<4|E.getMonth()+1)<<5|E.getDate());let I=M[0];$o(J,6,I),ba(J,22,ta(e));let B=ta(A,g,S,u);ba(J,24,B);let X=new Uint8Array(30+ta(e)+B),_=Ud(X);return $o(_,0,67324752),ar(X,Q,4),ar(X,e,30),ar(X,A,30+ta(e)),ar(X,g,30+ta(e,A)),ar(X,S,30+ta(e,A,g)),ar(X,u,30+ta(e,A,g,S)),{localHeaderArray:X,headerArray:Q,headerView:J,lastModDate:n,rawLastModDate:I,encrypted:U,compressed:F,version:G,compressionMethod:Y,extraFieldExtendedTimestampFlag:C,rawExtraFieldExtendedTimestamp:g,rawExtraFieldNTFS:S,rawExtraFieldAES:A,extraFieldLength:B}}function EFe(t,e){let{headerInfo:n}=t,{localHeaderArray:i,extraFieldLength:o}=n,a=Ud(i),s=64-(e+ta(i))%64;s<4&&(s+=64);let l=new Uint8Array(s),r=Ud(l);ba(r,0,6534),ba(r,2,s-2);let d=i;n.localHeaderArray=i=new Uint8Array(ta(d)+s),ar(i,d),ar(i,l,ta(d)),a=Ud(i),ba(a,28,o+s),t.metadataSize+=s}function CFe(t){let{zip64:e,dataDescriptor:n,dataDescriptorSignature:i}=t,o=new Uint8Array,a,s=0;return n&&(o=new Uint8Array(e?i?24:20:i?16:12),a=Ud(o),i&&(s=4,$o(a,0,134695760))),{dataDescriptorArray:o,dataDescriptorView:a,dataDescriptorOffset:s}}function IFe(t,e){let{signature:n,rawExtraFieldZip64:i,compressedSize:o,uncompressedSize:a,headerInfo:s,dataDescriptorInfo:l}=t,{headerView:r,encrypted:d}=s,{dataDescriptorView:m,dataDescriptorOffset:h}=l,{zip64:u,zip64UncompressedSize:R,zip64CompressedSize:V,zipCrypto:F,dataDescriptor:U}=e;if((!d||F)&&n!==Ka&&($o(r,10,n),U&&$o(m,h,n)),u){let G=Ud(i);ba(G,0,1),ba(G,2,ta(i)-4);let A=4;R&&($o(r,18,4294967295),Km(G,A,BigInt(a)),A+=8),V&&($o(r,14,4294967295),Km(G,A,BigInt(o))),U&&(Km(m,h+4,BigInt(o)),Km(m,h+12,BigInt(a)))}else $o(r,14,o),$o(r,18,a),U&&($o(m,h+4,o),$o(m,h+8,a))}async function NFe(t,e,n,{zipCrypto:i}){let o;o=await e.slice(0,26).arrayBuffer(),o.byteLength!=26&&(o=o.slice(0,26));let a=new DataView(o);return(!t.encrypted||i)&&$o(a,14,t.signature),t.zip64?($o(a,18,4294967295),$o(a,22,4294967295)):($o(a,18,t.compressedSize),$o(a,22,t.uncompressedSize)),await gR(n,new Uint8Array(o)),e.slice(o.byteLength)}function yFe(t,e){let{rawExtraFieldZip64:n,offset:i,diskNumberStart:o}=t,{zip64UncompressedSize:a,zip64CompressedSize:s,zip64Offset:l,zip64DiskNumberStart:r}=e,d=Ud(n),m=4;a&&(m+=8),s&&(m+=8),l&&(Km(d,m,BigInt(i)),m+=8),r&&$o(d,m,o)}async function BFe(t,e,n){let{files:i,writer:o}=t,{diskOffset:a,writable:s}=o,{diskNumber:l}=o,r=0,d=0,m=t.offset-a,h=i.size;for(let[,C]of i){let{rawFilename:y,rawExtraFieldZip64:Y,rawExtraFieldAES:Q,rawComment:J,rawExtraFieldNTFS:M,rawExtraField:Z,extendedTimestamp:E,extraFieldExtendedTimestampFlag:I,lastModDate:B}=C,X;if(E){X=new Uint8Array(9);let _=Ud(X);ba(_,0,21589),ba(_,2,5),R3(_,4,I),$o(_,5,Math.floor(B.getTime()/1e3))}else X=new Uint8Array;C.rawExtraFieldCDExtendedTimestamp=X,d+=46+ta(y,J,Y,Q,M,X,Z)}let u=new Uint8Array(d),R=Ud(u);await TR(o);let V=0;for(let[C,y]of Array.from(i.values()).entries()){let{offset:Y,rawFilename:Q,rawExtraFieldZip64:J,rawExtraFieldAES:M,rawExtraFieldCDExtendedTimestamp:Z,rawExtraFieldNTFS:E,rawExtraField:I,rawComment:B,versionMadeBy:X,headerArray:_,directory:P,zip64:w,zip64UncompressedSize:z,zip64CompressedSize:H,zip64DiskNumberStart:nt,zip64Offset:$,msDosCompatible:dt,internalFileAttribute:q,externalFileAttribute:at,diskNumberStart:st,uncompressedSize:Et,compressedSize:Qt}=y,Wt=ta(J,M,Z,E,I);$o(R,r,33639248),ba(R,r+4,X);let Nt=Ud(_);z||$o(Nt,18,Et),H||$o(Nt,14,Qt),ar(u,_,r+6),ba(R,r+30,Wt),ba(R,r+32,ta(B)),ba(R,r+34,w&&nt?65535:st),ba(R,r+36,q),at?$o(R,r+38,at):P&&dt&&R3(R,r+38,16),$o(R,r+42,w&&$?4294967295:Y),ar(u,Q,r+46),ar(u,J,r+46+ta(Q)),ar(u,M,r+46+ta(Q,J)),ar(u,Z,r+46+ta(Q,J,M)),ar(u,E,r+46+ta(Q,J,M,Z)),ar(u,I,r+46+ta(Q,J,M,Z,E)),ar(u,B,r+46+ta(Q)+Wt);let kt=46+ta(Q,B)+Wt;if(r-V>o.availableSize&&(o.availableSize=0,await gR(s,u.slice(V,r)),V=r),r+=kt,n.onprogress)try{await n.onprogress(C+1,i.size,new vF(y))}catch{}}await gR(s,V?u.slice(V):u);let F=o.diskNumber,{availableSize:U}=o;U<22&&F++;let G=ms(t,n,"zip64");if(m>=4294967295||d>=4294967295||h>=65535||F>=65535){if(G===!1)throw new Error(Tit);G=!0}let A=new Uint8Array(G?98:22),S=Ud(A);r=0,G&&($o(S,0,101075792),Km(S,4,BigInt(44)),ba(S,12,45),ba(S,14,45),$o(S,16,F),$o(S,20,l),Km(S,24,BigInt(h)),Km(S,32,BigInt(h)),Km(S,40,BigInt(d)),Km(S,48,BigInt(m)),$o(S,56,117853008),Km(S,64,BigInt(m)+BigInt(d)),$o(S,72,F+1),ms(t,n,"supportZip64SplitFile",!0)&&(F=65535,l=65535),h=65535,m=4294967295,d=4294967295,r+=76),$o(S,r,101010256),ba(S,r+4,F),ba(S,r+6,l),ba(S,r+8,h),ba(S,r+10,h),$o(S,r+12,d),$o(S,r+16,m);let g=ta(e);if(g)if(g<=65535)ba(S,r+20,g);else throw new Error(bFe);await gR(s,A),g&&await gR(s,e)}async function gR(t,e){let n=t.getWriter();try{await n.ready,t.size+=ta(e),await n.write(e)}finally{n.releaseLock()}}function Sit(t){if(t)return(BigInt(t.getTime())+BigInt(116444736e5))*BigInt(1e4)}function ms(t,e,n,i){let o=e[n]===Ka?t.options[n]:e[n];return o===Ka?i:o}function QFe(t){return t+5*(Math.floor(t/16383)+1)}function R3(t,e,n){t.setUint8(e,n)}function ba(t,e,n){t.setUint16(e,n,!0)}function $o(t,e,n){t.setUint32(e,n,!0)}function Km(t,e,n){t.setBigUint64(e,n,!0)}function ar(t,e,n){t.set(e,n)}function Ud(t){return new DataView(t.buffer)}function ta(...t){let e=0;return t.forEach(n=>n&&(e+=n.length)),e}QI({Deflate:sgt,Inflate:Egt});var xxi=b(W(),1);function kFe(t){return typeof t=="string"&&(t=document.getElementById(t)),t}var Ui=kFe;var Jxi=b(W(),1);function YFe(t,e){this.position=t,this.headingPitchRange=e}var zL=YFe;var Dxi=b(W(),1);function b3(t,e){this.id=e,this.name=t,this.playlistIndex=0,this.playlist=[],this.tourStart=new It,this.tourEnd=new It,this.entryStart=new It,this.entryEnd=new It,this._activeEntries=[]}b3.prototype.addPlaylistEntry=function(t){this.playlist.push(t)};b3.prototype.play=function(t,e){this.tourStart.raiseEvent();let n=this;AEt.call(this,t,e,function(i){n.playlistIndex=0,i||GEt(n._activeEntries),n.tourEnd.raiseEvent(i)})};b3.prototype.stop=function(){GEt(this._activeEntries)};function GEt(t){for(let e=t.pop();e!==void 0;e=t.pop())e.stop()}function AEt(t,e,n){let i=this.playlist[this.playlistIndex];if(i){let o=xFe.bind(this,t,e,n);if(this._activeEntries.push(i),this.entryStart.raiseEvent(i),i.blocking)i.play(o,t.scene.camera,e);else{let a=this;i.play(function(){a.entryEnd.raiseEvent(i);let s=a._activeEntries.indexOf(i);s>=0&&a._activeEntries.splice(s,1)}),o(t,e,n)}}else c(n)&&n(!1)}function xFe(t,e,n,i){let o=this.playlist[this.playlistIndex];if(this.entryEnd.raiseEvent(o,i),i)n(i);else{let a=this._activeEntries.indexOf(o);a>=0&&this._activeEntries.splice(a,1),this.playlistIndex++,AEt.call(this,t,e,n)}}var jL=b3;var sXi=b(W(),1);var tXi=b(W(),1);var jxi=b(W(),1),Jo=Object.freeze({Linear:Object.freeze({None:function(t){return t},In:function(t){return this.None(t)},Out:function(t){return this.None(t)},InOut:function(t){return this.None(t)}}),Quadratic:Object.freeze({In:function(t){return t*t},Out:function(t){return t*(2-t)},InOut:function(t){return(t*=2)<1?.5*t*t:-.5*(--t*(t-2)-1)}}),Cubic:Object.freeze({In:function(t){return t*t*t},Out:function(t){return--t*t*t+1},InOut:function(t){return(t*=2)<1?.5*t*t*t:.5*((t-=2)*t*t+2)}}),Quartic:Object.freeze({In:function(t){return t*t*t*t},Out:function(t){return 1- --t*t*t*t},InOut:function(t){return(t*=2)<1?.5*t*t*t*t:-.5*((t-=2)*t*t*t-2)}}),Quintic:Object.freeze({In:function(t){return t*t*t*t*t},Out:function(t){return--t*t*t*t*t+1},InOut:function(t){return(t*=2)<1?.5*t*t*t*t*t:.5*((t-=2)*t*t*t*t+2)}}),Sinusoidal:Object.freeze({In:function(t){return 1-Math.sin((1-t)*Math.PI/2)},Out:function(t){return Math.sin(t*Math.PI/2)},InOut:function(t){return .5*(1-Math.sin(Math.PI*(.5-t)))}}),Exponential:Object.freeze({In:function(t){return t===0?0:Math.pow(1024,t-1)},Out:function(t){return t===1?1:1-Math.pow(2,-10*t)},InOut:function(t){return t===0?0:t===1?1:(t*=2)<1?.5*Math.pow(1024,t-1):.5*(-Math.pow(2,-10*(t-1))+2)}}),Circular:Object.freeze({In:function(t){return 1-Math.sqrt(1-t*t)},Out:function(t){return Math.sqrt(1- --t*t)},InOut:function(t){return(t*=2)<1?-.5*(Math.sqrt(1-t*t)-1):.5*(Math.sqrt(1-(t-=2)*t)+1)}}),Elastic:Object.freeze({In:function(t){return t===0?0:t===1?1:-Math.pow(2,10*(t-1))*Math.sin((t-1.1)*5*Math.PI)},Out:function(t){return t===0?0:t===1?1:Math.pow(2,-10*t)*Math.sin((t-.1)*5*Math.PI)+1},InOut:function(t){return t===0?0:t===1?1:(t*=2,t<1?-.5*Math.pow(2,10*(t-1))*Math.sin((t-1.1)*5*Math.PI):.5*Math.pow(2,-10*(t-1))*Math.sin((t-1.1)*5*Math.PI)+1)}}),Back:Object.freeze({In:function(t){var e=1.70158;return t===1?1:t*t*((e+1)*t-e)},Out:function(t){var e=1.70158;return t===0?0:--t*t*((e+1)*t+e)+1},InOut:function(t){var e=2.5949095;return(t*=2)<1?.5*(t*t*((e+1)*t-e)):.5*((t-=2)*t*((e+1)*t+e)+2)}}),Bounce:Object.freeze({In:function(t){return 1-Jo.Bounce.Out(1-t)},Out:function(t){return t<.36363636363636365?7.5625*t*t:t<.7272727272727273?7.5625*(t-=.5454545454545454)*t+.75:t<.9090909090909091?7.5625*(t-=.8181818181818182)*t+.9375:7.5625*(t-=.9545454545454546)*t+.984375},InOut:function(t){return t<.5?Jo.Bounce.In(t*2)*.5:Jo.Bounce.Out(t*2-1)*.5+.5}}),generatePow:function(t){return t===void 0&&(t=4),t=t1e4?1e4:t,{In:function(e){return Math.pow(e,t)},Out:function(e){return 1-Math.pow(1-e,t)},InOut:function(e){return e<.5?Math.pow(e*2,t)/2:(1-Math.pow(2-e*2,t))/2+.5}}}}),qL=function(){return performance.now()},XFe=function(){function t(){this._tweens={},this._tweensAddedDuringUpdate={}}return t.prototype.getAll=function(){var e=this;return Object.keys(this._tweens).map(function(n){return e._tweens[n]})},t.prototype.removeAll=function(){this._tweens={}},t.prototype.add=function(e){this._tweens[e.getId()]=e,this._tweensAddedDuringUpdate[e.getId()]=e},t.prototype.remove=function(e){delete this._tweens[e.getId()],delete this._tweensAddedDuringUpdate[e.getId()]},t.prototype.update=function(e,n){e===void 0&&(e=qL()),n===void 0&&(n=!1);var i=Object.keys(this._tweens);if(i.length===0)return!1;for(;i.length>0;){this._tweensAddedDuringUpdate={};for(var o=0;o1?a(t[n],t[n-1],n-i):a(t[o],t[o+1>n?n:o+1],i-o)},Bezier:function(t,e){for(var n=0,i=t.length-1,o=Math.pow,a=MI.Utils.Bernstein,s=0;s<=i;s++)n+=o(1-e,i-s)*o(e,s)*t[s]*a(i,s);return n},CatmullRom:function(t,e){var n=t.length-1,i=n*e,o=Math.floor(i),a=MI.Utils.CatmullRom;return t[0]===t[n]?(e<0&&(o=Math.floor(i=n*(1+e))),a(t[(o-1+n)%n],t[o],t[(o+1)%n],t[(o+2)%n],i-o)):e<0?t[0]-(a(t[0],t[0],t[1],t[1],-i)-t[0]):e>1?t[n]-(a(t[n],t[n],t[n-1],t[n-1],i-n)-t[n]):a(t[o?o-1:0],t[o],t[n1;i--)n*=i;return t[e]=n,n}}(),CatmullRom:function(t,e,n,i,o){var a=(n-t)*.5,s=(i-e)*.5,l=o*o,r=o*l;return(2*e-2*n+a+s)*r+(-3*e+3*n-2*a-s)*l+a*o+e}}},SEt=function(){function t(){}return t.nextId=function(){return t._nextId++},t._nextId=0,t}(),git=new XFe,TEt=function(){function t(e,n){n===void 0&&(n=git),this._object=e,this._group=n,this._isPaused=!1,this._pauseStart=0,this._valuesStart={},this._valuesEnd={},this._valuesStartRepeat={},this._duration=1e3,this._isDynamic=!1,this._initialRepeat=0,this._repeat=0,this._yoyo=!1,this._isPlaying=!1,this._reversed=!1,this._delayTime=0,this._startTime=0,this._easingFunction=Jo.Linear.None,this._interpolationFunction=MI.Linear,this._chainedTweens=[],this._onStartCallbackFired=!1,this._onEveryStartCallbackFired=!1,this._id=SEt.nextId(),this._isChainStopped=!1,this._propertiesAreSetUp=!1,this._goToEnd=!1}return t.prototype.getId=function(){return this._id},t.prototype.isPlaying=function(){return this._isPlaying},t.prototype.isPaused=function(){return this._isPaused},t.prototype.getDuration=function(){return this._duration},t.prototype.to=function(e,n){if(n===void 0&&(n=1e3),this._isPlaying)throw new Error("Can not call Tween.to() while Tween is already started or paused. Stop the Tween first.");return this._valuesEnd=e,this._propertiesAreSetUp=!1,this._duration=n<0?0:n,this},t.prototype.duration=function(e){return e===void 0&&(e=1e3),this._duration=e<0?0:e,this},t.prototype.dynamic=function(e){return e===void 0&&(e=!1),this._isDynamic=e,this},t.prototype.start=function(e,n){if(e===void 0&&(e=qL()),n===void 0&&(n=!1),this._isPlaying)return this;if(this._group&&this._group.add(this),this._repeat=this._initialRepeat,this._reversed){this._reversed=!1;for(var i in this._valuesStartRepeat)this._swapEndStartRepeatValues(i),this._valuesStart[i]=this._valuesStartRepeat[i]}if(this._isPlaying=!0,this._isPaused=!1,this._onStartCallbackFired=!1,this._onEveryStartCallbackFired=!1,this._isChainStopped=!1,this._startTime=e,this._startTime+=this._delayTime,!this._propertiesAreSetUp||n){if(this._propertiesAreSetUp=!0,!this._isDynamic){var o={};for(var a in this._valuesEnd)o[a]=this._valuesEnd[a];this._valuesEnd=o}this._setupProperties(this._object,this._valuesStart,this._valuesEnd,this._valuesStartRepeat,n)}return this},t.prototype.startFromCurrentValues=function(e){return this.start(e,!0)},t.prototype._setupProperties=function(e,n,i,o,a){for(var s in i){var l=e[s],r=Array.isArray(l),d=r?"array":typeof l,m=!r&&Array.isArray(i[s]);if(!(d==="undefined"||d==="function")){if(m){var h=i[s];if(h.length===0)continue;for(var u=[l],R=0,V=h.length;R"u"||a)&&(n[s]=l),r||(n[s]*=1),m?o[s]=i[s].slice().reverse():o[s]=n[s]||0}}},t.prototype.stop=function(){return this._isChainStopped||(this._isChainStopped=!0,this.stopChainedTweens()),this._isPlaying?(this._group&&this._group.remove(this),this._isPlaying=!1,this._isPaused=!1,this._onStopCallback&&this._onStopCallback(this._object),this):this},t.prototype.end=function(){return this._goToEnd=!0,this.update(1/0),this},t.prototype.pause=function(e){return e===void 0&&(e=qL()),this._isPaused||!this._isPlaying?this:(this._isPaused=!0,this._pauseStart=e,this._group&&this._group.remove(this),this)},t.prototype.resume=function(e){return e===void 0&&(e=qL()),!this._isPaused||!this._isPlaying?this:(this._isPaused=!1,this._startTime+=e-this._pauseStart,this._pauseStart=0,this._group&&this._group.add(this),this)},t.prototype.stopChainedTweens=function(){for(var e=0,n=this._chainedTweens.length;es)return!1;n&&this.start(e,!0)}if(this._goToEnd=!1,ed)return 1;var U=Math.trunc(l/r),G=l-U*r,A=Math.min(G/i._duration,1);return A===0&&l===i._duration?1:A},h=m(),u=this._easingFunction(h);if(this._updateProperties(this._object,this._valuesStart,this._valuesEnd,u),this._onUpdateCallback&&this._onUpdateCallback(this._object,h),this._duration===0||l>=this._duration)if(this._repeat>0){var R=Math.min(Math.trunc((l-this._duration)/r)+1,this._repeat);isFinite(this._repeat)&&(this._repeat-=R);for(a in this._valuesStartRepeat)!this._yoyo&&typeof this._valuesEnd[a]=="string"&&(this._valuesStartRepeat[a]=this._valuesStartRepeat[a]+parseFloat(this._valuesEnd[a])),this._yoyo&&this._swapEndStartRepeatValues(a),this._valuesStart[a]=this._valuesStartRepeat[a];return this._yoyo&&(this._reversed=!this._reversed),this._startTime+=r*R,this._onRepeatCallback&&this._onRepeatCallback(this._object),this._onEveryStartCallbackFired=!1,!0}else{this._onCompleteCallback&&this._onCompleteCallback(this._object);for(var V=0,F=this._chainedTweens.length;Vthis._started+this._timeThreshold)){this._giveUpTime();return}i=this._nextNode()}this._pop()&&t&&this._process(!0)};function _Fe(t){let e=t.slice(0,Math.min(4,t.size)),n=kd(),i=new FileReader;return i.addEventListener("load",function(){n.resolve(new DataView(i.result).getUint32(0,!1)===1347093252)}),i.addEventListener("error",function(){n.reject(i.error)}),i.readAsArrayBuffer(e),n.promise}function DFe(t){let e=kd(),n=new FileReader;return n.addEventListener("load",function(){e.resolve(n.result)}),n.addEventListener("error",function(){e.reject(n.error)}),n.readAsText(t),e.promise}function xEt(t){let e={xsi:"http://www.w3.org/2001/XMLSchema-instance"},n,i,o,a;for(let s in e)e.hasOwnProperty(s)&&(o=RegExp(`[< ]${s}:`),a=`xmlns:${s}=`,o.test(t)&&t.indexOf(a)===-1&&(c(n)||(n=t.substr(0,t.indexOf("",e),i,o,a;for(;e!==-1&&e0?(zm.maximumRed=a,zm.red=void 0):(zm.maximumRed=void 0,zm.red=0),o>0?(zm.maximumGreen=o,zm.green=void 0):(zm.maximumGreen=void 0,zm.green=0),i>0?(zm.maximumBlue=i,zm.blue=void 0):(zm.maximumBlue=void 0,zm.blue=0),zm.alpha=n,v.fromRandom(zm)):new v(a,o,i,n)}function YS(t,e,n){let i=Gi(t,e,n);if(c(i))return Bit(i,Gi(t,"colorMode",n)==="random")}function HFe(t){let e=Lo(t,"TimeStamp",se.kmlgx),n=Gi(e,"when",se.kmlgx);if(!c(e)||!c(n)||n.length===0)return;let i=rt.fromIso8601(n),o=new ys;return o.addInterval(new ai({start:i,stop:be.MAXIMUM_VALUE})),o}function wFe(t){let e=Lo(t,"TimeSpan",se.kmlgx);if(!c(e))return;let n,i=Lo(e,"begin",se.kmlgx),o=c(i)?rt.fromIso8601(i.textContent):void 0,a=Lo(e,"end",se.kmlgx),s=c(a)?rt.fromIso8601(a.textContent):void 0;if(c(o)&&c(s)){if(rt.lessThan(s,o)){let l=o;o=s,s=l}n=new ys,n.addInterval(new ai({start:o,stop:s}))}else c(o)?(n=new ys,n.addInterval(new ai({start:o,stop:be.MAXIMUM_VALUE}))):c(s)&&(n=new ys,n.addInterval(new ai({start:be.MINIMUM_VALUE,stop:s})));return n}function LEt(){let t=new Mr;return t.width=KF,t.height=KF,t.scaleByDistance=new ln(gEt,EEt,CEt,IEt),t.pixelOffsetScaleByDistance=new ln(gEt,EEt,CEt,IEt),t}function Xit(){let t=new su;return t.outline=!0,t.outlineColor=v.WHITE,t}function MEt(){let t=new au;return t.translucencyByDistance=new ln(3e6,1,5e6,0),t.pixelOffset=new K(17,0),t.horizontalOrigin=to.LEFT,t.font="16px sans-serif",t.style=Pa.FILL_AND_OUTLINE,t}function Jit(t,e,n,i,o){let a=Gi(t,"href",se.kml);if(!c(a)||a.length===0)return;if(a.indexOf("root://icons/palette-")===0){let l=a.charAt(21),r=f(io(t,"x",se.gx),0),d=f(io(t,"y",se.gx),0);r=Math.min(r/32,7),d=7-Math.min(d/32,7);let m=8*d+r;a=`https://maps.google.com/mapfiles/kml/pal${l}/icon${m}.png`}let s=xit(a,n,i);if(o){let l=Gi(t,"refreshMode",se.kml),r=Gi(t,"viewRefreshMode",se.kml);l==="onInterval"||l==="onExpire"?Gn(`kml-refreshMode-${l}`,`KML - Unsupported Icon refreshMode: ${l}`):(r==="onStop"||r==="onRegion")&&Gn(`kml-refreshMode-${r}`,`KML - Unsupported Icon viewRefreshMode: ${r}`);let d=f(Gi(t,"viewBoundScale",se.kml),1),m=r==="onStop"?"BBOX=[bboxWest],[bboxSouth],[bboxEast],[bboxNorth]":"",h=f(Gi(t,"viewFormat",se.kml),m),u=Gi(t,"httpQuery",se.kml);c(h)&&s.setQueryParameters(Sc(U3(h))),c(u)&&s.setQueryParameters(Sc(U3(u)));let R=e._ellipsoid;return Mit(s,e.camera,e.canvas,d,e._lastCameraView.bbox,R),s}return s}function PFe(t,e,n,i,o){let a=io(e,"scale",se.kml),s=io(e,"heading",se.kml),l=YS(e,"color",se.kml),r=Lo(e,"Icon",se.kml),d=Jit(r,t,i,o,!1);c(r)&&!c(d)&&(d=!1);let m=io(r,"x",se.gx),h=io(r,"y",se.gx),u=io(r,"w",se.gx),R=io(r,"h",se.gx),V=Lo(e,"hotSpot",se.kml),F=zF(V,"x"),U=zF(V,"y"),G=sr(V,"xunits"),A=sr(V,"yunits"),S=n.billboard;c(S)||(S=LEt(),n.billboard=S),S.image=d,S.scale=a,S.color=l,(c(m)||c(h)||c(u)||c(R))&&(S.imageSubRegion=new Fe(m,h,u,R)),c(s)&&s!==0&&(S.rotation=k.toRadians(-s),S.alignedAxis=p.UNIT_Z),a=f(a,1);let g,C;c(F)&&(G==="pixels"?g=-F*a:G==="insetPixels"?g=(F-KF)*a:G==="fraction"&&(g=-F*KF*a),g+=KF*.5*a),c(U)&&(A==="pixels"?C=U*a:A==="insetPixels"?C=(-U+KF)*a:A==="fraction"&&(C=U*KF*a),C-=KF*.5*a),(c(g)||c(C))&&(S.pixelOffset=new K(g,C))}function F3(t,e,n,i,o){for(let a=0,s=e.childNodes.length;a:clampToSeaFloor is currently not supported, using :clampToGround."),Ge.CLAMP_TO_GROUND):e==="relativeToSeaFloor"?(Gn("kml-gx:altitudeMode-relativeToSeaFloor","KML - :relativeToSeaFloor is currently not supported, using :relativeToGround."),Ge.RELATIVE_TO_GROUND):(c(t)?Gn("kml-altitudeMode-unknown",`KML - Unknown :${t}, using :CLAMP_TO_GROUND.`):Gn("kml-gx:altitudeMode-unknown",`KML - Unknown :${e}, using :CLAMP_TO_GROUND.`),Ge.CLAMP_TO_GROUND)}function zFe(t,e,n){return n==="relativeToSeaFloor"||e==="absolute"||e==="relativeToGround"?t:((c(e)&&e!=="clampToGround"||c(n)&&n!=="clampToSeaFloor")&&Gn("kml-altitudeMode-unknown",`KML - Unknown altitudeMode: ${f(e,n)}`),new vc(t))}function jFe(t,e,n,i){if(!c(t))return;if(n==="relativeToSeaFloor"||e==="absolute"||e==="relativeToGround")return t;(c(e)&&e!=="clampToGround"||c(n)&&n!=="clampToSeaFloor")&&Gn("kml-altitudeMode-unknown",`KML - Unknown altitudeMode: ${f(e,n)}`);let o=t.length;for(let a=0;a0&&Gn("kml-gx:angles","KML - gx:angles are not supported in gx:Tracks");let R=Math.min(l.length,d.length),V=[],F=[];for(let G=0;G0&&i.availability.addInterval(new ai({start:F[0],stop:F[F.length-1]})),h&&m&&Lit(e,i,o),!0}function kEt(t,e,n,i,o,a,s,l,r){let d=t[0],m=t[t.length-1],h=new Bs;h.addSamples(t,e),n.intervals.addInterval(new ai({start:d,stop:m,isStartIncluded:r,isStopIncluded:r,data:zFe(h,s,l)})),i.addInterval(new ai({start:d,stop:m,isStartIncluded:r,isStopIncluded:r})),o.intervals.addInterval(new ai({start:d,stop:m,isStartIncluded:r,isStopIncluded:r,data:a}))}function eUe(t,e,n,i,o){let a=vu(n,"interpolate",se.gx),s=Pu(n,"Track",se.gx),l,r,d,m=!1,h=new _m,u=new ys,R=new cl,V=t._ellipsoid;for(let F=0,U=s.length;F0)){for(V='',a=0;a`;V+="
${f(F.displayName,s)}${f(F.value,"")}
"}if(!c(V))return;V=LFe.link(V),Ba.innerHTML=V;let U=Ba.querySelectorAll("a");for(a=0;a1&&(Kh(Ba,"a","href",i),Kh(Ba,"link","href",i),Kh(Ba,"area","href",i),Kh(Ba,"img","src",i),Kh(Ba,"iframe","src",i),Kh(Ba,"video","src",i),Kh(Ba,"audio","src",i),Kh(Ba,"source","src",i),Kh(Ba,"track","src",i),Kh(Ba,"input","src",i),Kh(Ba,"embed","src",i),Kh(Ba,"script","src",i),Kh(Ba,"video","poster",i)),zh(Ba,"a","href",o),zh(Ba,"link","href",o),zh(Ba,"area","href",o),zh(Ba,"img","src",o),zh(Ba,"iframe","src",o),zh(Ba,"video","src",o),zh(Ba,"audio","src",o),zh(Ba,"source","src",o),zh(Ba,"track","src",o),zh(Ba,"input","src",o),zh(Ba,"embed","src",o),zh(Ba,"script","src",o),zh(Ba,"video","poster",o);let G='
',G+=`${Ba.innerHTML}
`,Ba.innerHTML="",e.description=G}function S3(t,e,n){let i=n.entityCollection,o=n.parentEntity,a=n.sourceResource,s=n.uriResolver,l=JEt(e,i,n.context),r=l.kml,d=vFe(t,e,n.styleCollection,a,s),m=Gi(e,"name",se.kml);l.name=m,l.parent=o;let h=wFe(e);c(h)||(h=HFe(e)),l.availability=h,Dit(l);function u(S){return S?S.show&&u(S.parent):!0}let R=vu(e,"visibility",se.kml);l.show=u(o)&&f(R,!0);let V=Lo(e,"author",se.atom),F=r.author;F.name=Gi(V,"name",se.atom),F.uri=Gi(V,"uri",se.atom),F.email=Gi(V,"email",se.atom);let U=Lo(e,"link",se.atom),G=r.link;G.href=sr(U,"href"),G.hreflang=sr(U,"hreflang"),G.rel=sr(U,"rel"),G.type=sr(U,"type"),G.title=sr(U,"title"),G.length=sr(U,"length"),r.address=Gi(e,"address",se.kml),r.phoneNumber=Gi(e,"phoneNumber",se.kml),r.snippet=Gi(e,"Snippet",se.kml),oUe(e,l),aUe(e,l,d,s,a);let A=t._ellipsoid;return vEt(e,l,A),PEt(e,l,A),c(Lo(e,"Region",se.kml))&&Gn("kml-region","KML - Placemark Regions are unsupported"),{entity:l,styleEntity:d}}function wEt(t,e,n,i){i.addNodes(e.childNodes,n),i.process()}function sUe(t,e,n,i){let o=S3(t,e,n),a=Re(n);a.parentEntity=o.entity,wEt(t,e,a,i)}function lUe(t,e,n,i){let o=S3(t,e,n),a=o.entity,s=o.styleEntity,l=!1,r=e.childNodes;for(let d=0,m=r.length;dk.PI_OVER_TWO?k.PI_OVER_TWO:d}function l(d){return d>k.PI?d-k.TWO_PI:d<-k.PI?d+k.TWO_PI:d}let r=RG(t.queryParameters);if(r=r.replace(/%5B/g,"[").replace(/%5D/g,"]"),c(e)&&e._mode!==Vt.MORPHING){let d,m;if(o=f(o,VUe),c(n)&&(Nit.x=n.clientWidth*.5,Nit.y=n.clientHeight*.5,d=e.pickEllipsoid(Nit,a,uUe)),c(d)?m=a.cartesianToCartographic(d,_I):(m=Gt.center(o,_I),d=a.cartographicToCartesian(m)),c(i)&&!k.equalsEpsilon(i,1,k.EPSILON9)){let G=o.width*i*.5,A=o.height*i*.5;o=new Gt(l(m.longitude-G),s(m.latitude-A),l(m.longitude+G),s(m.latitude+A))}r=r.replace("[bboxWest]",k.toDegrees(o.west).toString()),r=r.replace("[bboxSouth]",k.toDegrees(o.south).toString()),r=r.replace("[bboxEast]",k.toDegrees(o.east).toString()),r=r.replace("[bboxNorth]",k.toDegrees(o.north).toString());let h=k.toDegrees(m.longitude).toString(),u=k.toDegrees(m.latitude).toString();r=r.replace("[lookatLon]",h),r=r.replace("[lookatLat]",u),r=r.replace("[lookatTilt]",k.toDegrees(e.pitch).toString()),r=r.replace("[lookatHeading]",k.toDegrees(e.heading).toString()),r=r.replace("[lookatRange]",p.distance(e.positionWC,d)),r=r.replace("[lookatTerrainLon]",h),r=r.replace("[lookatTerrainLat]",u),r=r.replace("[lookatTerrainAlt]",m.height.toString()),a.cartesianToCartographic(e.positionWC,_I),r=r.replace("[cameraLon]",k.toDegrees(_I.longitude).toString()),r=r.replace("[cameraLat]",k.toDegrees(_I.latitude).toString()),r=r.replace("[cameraAlt]",k.toDegrees(_I.height).toString());let R=e.frustum,V=R.aspectRatio,F="",U="";if(c(V)){let G=k.toDegrees(R.fov);V>1?(F=G,U=G/V):(U=G,F=G*V)}r=r.replace("[horizFov]",F.toString()),r=r.replace("[vertFov]",U.toString())}else r=r.replace("[bboxWest]","-180"),r=r.replace("[bboxSouth]","-90"),r=r.replace("[bboxEast]","180"),r=r.replace("[bboxNorth]","90"),r=r.replace("[lookatLon]",""),r=r.replace("[lookatLat]",""),r=r.replace("[lookatRange]",""),r=r.replace("[lookatTilt]",""),r=r.replace("[lookatHeading]",""),r=r.replace("[lookatTerrainLon]",""),r=r.replace("[lookatTerrainLat]",""),r=r.replace("[lookatTerrainAlt]",""),r=r.replace("[cameraLon]",""),r=r.replace("[cameraLat]",""),r=r.replace("[cameraAlt]",""),r=r.replace("[horizFov]",""),r=r.replace("[vertFov]","");c(n)?(r=r.replace("[horizPixels]",n.clientWidth),r=r.replace("[vertPixels]",n.clientHeight)):(r=r.replace("[horizPixels]",""),r=r.replace("[vertPixels]","")),r=r.replace("[terrainEnabled]","1"),r=r.replace("[clientVersion]","1"),r=r.replace("[kmlVersion]","2.2"),r=r.replace("[clientName]","Cesium"),r=r.replace("[language]","English"),t.setQueryParameters(Sc(r))}function ZUe(t,e,n,i){let a=S3(t,e,n).entity,s=n.sourceResource,l=n.uriResolver,r=Lo(e,"Link",se.kml);if(c(r)||(r=Lo(e,"Url",se.kml)),c(r)){let d=Gi(r,"href",se.kml),m,h;if(c(d)){let u=d;if(d=xit(d,s,n.uriResolver),/^data:/.test(d.getUrlComponent()))/\.kmz/i.test(s.getUrlComponent())||(u=s.getDerivedResource({url:u}));else{if(u=d.clone(),m=Gi(r,"viewRefreshMode",se.kml),m==="onRegion"){Gn("kml-refrehMode-onRegion","KML - Unsupported viewRefreshMode: onRegion");return}h=f(Gi(r,"viewBoundScale",se.kml),1);let U=m==="onStop"?"BBOX=[bboxWest],[bboxSouth],[bboxEast],[bboxNorth]":"",G=f(Gi(r,"viewFormat",se.kml),U),A=Gi(r,"httpQuery",se.kml);c(G)&&d.setQueryParameters(Sc(U3(G))),c(A)&&d.setQueryParameters(Sc(U3(A)));let S=t._ellipsoid;Mit(d,t.camera,t.canvas,h,t._lastCameraView.bbox,S)}let R={sourceUri:u,uriResolver:l,context:a.id,screenOverlayContainer:n.screenOverlayContainer},V=new gr,F=_it(t,V,d,R).then(function(U){let G=t._entityCollection,A=V.values;G.suspendEvents();for(let C=0;C0||S==="onExpire"||m==="onStop"){let C=Lo(U,"NetworkLinkControl",se.kml),y=c(C),Y=rt.now(),Q={id:Ti(),href:d,cookie:{},lastUpdated:Y,updating:!1,entity:a,viewBoundScale:h,needsUpdate:!1,cameraUpdateTime:Y},J=0;if(y&&(Q.cookie=Sc(f(Gi(C,"cookie",se.kml),"")),J=f(io(C,"minRefreshPeriod",se.kml),0)),S==="onInterval")y&&(g=Math.max(J,g)),Q.refreshMode=jF.INTERVAL,Q.time=g;else if(S==="onExpire"){let M;if(y&&(M=Gi(C,"expires",se.kml)),c(M))try{let Z=rt.fromIso8601(M),E=rt.secondsDifference(Z,Y);E>0&&E0;)this._screenOverlays.pop().remove()};function Dit(t){let e=t.parent;if(c(e)){let n=e.availability;if(c(n)){let i=t.availability;c(i)?i.intersect(n):t.availability=n}}}function WUe(t,e,n,i,o){return function(a){if(!i.contains(e.id))return;let s=!1,l=Lo(a,"NetworkLinkControl",se.kml),r=c(l),d=0;if(r){if(c(Lo(l,"Update",se.kml))){Gn("kml-networkLinkControl-update","KML - NetworkLinkControl updates aren't supported."),e.updating=!1,i.remove(e.id);return}e.cookie=Sc(f(Gi(l,"cookie",se.kml),"")),d=f(io(l,"minRefreshPeriod",se.kml),0)}let m=rt.now(),h=e.refreshMode;if(h===jF.INTERVAL)c(l)&&(e.time=Math.max(d,e.time));else if(h===jF.EXPIRE){let Y;if(c(l)&&(Y=Gi(l,"expires",se.kml)),c(Y))try{let Q=rt.fromIso8601(Y),J=rt.secondsDifference(Q,m);J>0&&Jm.time&&(u=!0):m.refreshMode===jF.EXPIRE?rt.greaterThan(n,m.time)&&(u=!0):m.refreshMode===jF.STOP&&(a&&(m.needsUpdate=!0,m.cameraUpdateTime=n),m.needsUpdate&&rt.secondsDifference(n,m.cameraUpdateTime)>=m.time&&(u=!0)),u){o(h),m.updating=!0;let R=new gr,V=m.href.clone();V.setQueryParameters(m.cookie);let F=f(i._ellipsoid,mt.WGS84);Mit(V,i.camera,i.canvas,m.viewBoundScale,s.bbox,F),_it(i,R,V,{context:h.id}).then(WUe(i,m,R,r,V)).catch(function(U){let G=`NetworkLink ${m.href} refresh failed: ${U}`;console.log(G),i._error.raiseEvent(i,G)}),d=!0}}r.set(m.id,m)}}),d&&(this._networkLinks=r,this._changed.raiseEvent(this)),!0};function fUe(){this.author={name:void 0,uri:void 0,email:void 0},this.link={href:void 0,hreflang:void 0,rel:void 0,type:void 0,title:void 0,length:void 0},this.address=void 0,this.phoneNumber=void 0,this.snippet=void 0,this.extendedData=void 0}jh._DeferredLoading=CR;jh._getTimestamp=Oi;var iM=jh;var OJi=b(W(),1);var tCt=b(zEt(),1);var{abs:OI,min:Oit,max:jEt,ceil:T3,PI:g3,round:Hit}=Math,{toDegrees:qEt,toRadians:eCt}=k,HI=[.00675,.0125,.025,.05,.1,.2,.5,1,2,5,10].map(eCt),FUe=15,UUe=FUe,$Et=eCt(3),{MAX_VALUE:E3}=Gt,GUe=(t,e)=>{let n=new $e({geometry:new kb({positions:t,width:1}),attributes:{color:En.fromColor(e)}});return new Gh({geometryInstances:n,appearance:new zl({material:eo.fromType("Color",{color:e})})})},wit=class{constructor(e){this.viewer=e,this.lastRefresh=0,this.debounce=50,this.showLabels=!0,this.labelSettings={font:"12px Arial",outlineColor:v.BLACK,outlineWidth:4,style:Pa.FILL_AND_OUTLINE,eyeOffset:p.ZERO,scale:1,scaleByDistance:new ln(1,.85,8e6,.4)},this.ellipsoid=e.scene.globe.ellipsoid;let{scene:n}=e;this.labelEntities=[],this.polylines=new Mc,this.groundPolylines=[],n.primitives.add(this.polylines),this.currentExtent=this.getExtentView(),this.render=(0,tCt.debounce)(()=>{if(this._destroyed)return;this.viewer.scene.camera.percentageChanged=.1;let i=this.lastRefresh;if(new Date().getTime()-i{this.render()}),this.resizeObserver.observe(e.container),this.cameraChangedEventListener=i=>{this.render()},e.scene.camera.changed.addEventListener(this.cameraChangedEventListener),this.boundRender=this.render.bind(this),e.container.addEventListener("resize",this.boundRender),this._destroyed=!1,this.render()}removeAllLabels(){this.labelEntities.forEach(e=>{this.viewer.entities.remove(e)}),this.labelEntities=[]}destroy(){if(this._destroyed){console.error("destroy has already been called.");return}this.resizeObserver&&this.resizeObserver.disconnect(),this.cameraChangedEventListener&&this.viewer.scene.camera.changed.removeEventListener(this.cameraChangedEventListener),this.boundRender&&this.viewer.container.removeEventListener("resize",this.boundRender),this.removeAllLabels(),this.removePolylines(),this._destroyed=!0}isCameraCloseToGround(){return this.viewer.camera.positionCartographic.height<455983}hasTerrainProvider(){return!(this.viewer.terrainProvider instanceof bV)}lineGraphicsObj(e,n,i){let o;if(i)return o=this.ellipsoid.cartographicArrayToCartesianArray(e),GUe(o,n);let a=e.map(s=>new gt(s.longitude,s.latitude,this.hasTerrainProvider()?this.viewer.camera.positionCartographic.height/90+1e9/this.viewer.camera.positionCartographic.height:10));return o=this.ellipsoid.cartographicArrayToCartesianArray(a),{positions:o,width:.5,material:eo.fromType("Color",{color:n})}}removePolylines(){this.polylines.removeAll();for(let e=0;e=Math.PI/2-s,r=e.south<=-Math.PI/2+s,m=l||r?0:UUe;for(a=0;aE3.east?G=e._east-(Y-E3.east):G=Y;let Q=[];for(U=u;U=0?"N":"S":e>=0?"E":"W"}`}},Pit=wit;var t5i=b(W(),1);var __i=b(W(),1);var aLi=b(W(),1);var zJi=b(W(),1);var vit=class{constructor({name:e=null,orientation:n=new wt(0,0,0,1),inheritParentOrientation:i=!0}){this._id=Ti(),this._name=e,this._inheritParentOrientation=i,this._setOrientation(n)}_setOrientation(e){e instanceof et?this._orientation=e:this._orientation=new Ii(e)}get id(){return this._id}get orientation(){return this._orientation}set orientation(e){this._setOrientation(e)}get inheritParentOrientation(){return this._inheritParentOrientation}set inheritParentOrientation(e){this._inheritParentOrientation=e}},oW=vit;var xS=class extends oW{constructor(e){super(e),this._minimumClockAngle=void 0,this._minimumClockAngleSubscription=void 0,this._maximumClockAngle=void 0,this._maximumClockAngleSubscription=void 0,this._innerHalfAngle=void 0,this._innerHalfAngleSubscription=void 0,this._outerHalfAngle=void 0,this._outerHalfAngleSubscription=void 0,this._lateralSurfaceMaterial=void 0,this._lateralSurfaceMaterialSubscription=void 0,this._intersectionColor=void 0,this._intersectionColorSubscription=void 0,this._intersectionWidth=void 0,this._intersectionWidthSubscription=void 0,this._showIntersection=void 0,this._showIntersectionSubscription=void 0,this._radius=void 0,this._radiusSubscription=void 0,this._show=void 0,this._showSubscription=void 0,this._definitionChanged=new It,this.merge(f(e,f.EMPTY_OBJECT))}};Object.defineProperties(xS.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},minimumClockAngle:ft("minimumClockAngle"),maximumClockAngle:ft("maximumClockAngle"),innerHalfAngle:ft("innerHalfAngle"),outerHalfAngle:ft("outerHalfAngle"),lateralSurfaceMaterial:la("lateralSurfaceMaterial"),intersectionColor:ft("intersectionColor"),intersectionWidth:ft("intersectionWidth"),showIntersection:ft("showIntersection"),radius:ft("radius"),show:ft("show")});xS.prototype.clone=function(t){return c(t)||(t=new xS),t.show=this.show,t.innerHalfAngle=this.innerHalfAngle,t.outerHalfAngle=this.outerHalfAngle,t.minimumClockAngle=this.minimumClockAngle,t.maximumClockAngle=this.maximumClockAngle,t.radius=this.radius,t.showIntersection=this.showIntersection,t.intersectionColor=this.intersectionColor,t.intersectionWidth=this.intersectionWidth,t.lateralSurfaceMaterial=this.lateralSurfaceMaterial,t};xS.prototype.merge=function(t){if(!c(t))throw new Ut("source is required.");this.show=f(this.show,t.show),this.innerHalfAngle=f(this.innerHalfAngle,t.innerHalfAngle),this.outerHalfAngle=f(this.outerHalfAngle,t.outerHalfAngle),this.minimumClockAngle=f(this.minimumClockAngle,t.minimumClockAngle),this.maximumClockAngle=f(this.maximumClockAngle,t.maximumClockAngle),this.radius=f(this.radius,t.radius),this.showIntersection=f(this.showIntersection,t.showIntersection),this.intersectionColor=f(this.intersectionColor,t.intersectionColor),this.intersectionWidth=f(this.intersectionWidth,t.intersectionWidth),this.lateralSurfaceMaterial=f(this.lateralSurfaceMaterial,t.lateralSurfaceMaterial)};var XS=xS;var bMi=b(W(),1);var zLi=b(W(),1);var lLi=b(W(),1),wI=`#version 300 es uniform vec4 u_intersectionColor; uniform float u_intersectionWidth; @@ -9075,7 +9075,7 @@ vec2 sensor2dTextureCoordinates(float sensorRadius, vec3 pointMC) s = s - floor(s); return vec2(s, t); -}`;var dLi=R(W(),1),PI=`#version 300 es +}`;var dLi=b(W(),1),PI=`#version 300 es uniform bool u_showIntersection; uniform bool u_showThroughEllipsoid; @@ -9172,7 +9172,7 @@ void main() // Notes: Each surface functions should have an associated tolerance based on the floating point error. bool isOnEllipsoid = isOnBoundary(ellipsoidValue, czm_epsilon3); out_FragColor = shade(isOnEllipsoid); -}`;var mLi=R(W(),1),vI=` +}`;var mLi=b(W(),1),vI=` #version 300 es in vec4 position; @@ -9189,8 +9189,8 @@ void main() v_positionWC = (czm_model * position).xyz; v_positionEC = (czm_modelView * position).xyz; v_normalEC = czm_normal * normal; -}`;var fLi=R(W(),1);var ZLi=R(W(),1);var AUe=new p,TUe=new p,SUe=new p,gUe=5906376272e3;function EUe(t,e=!0){let n=t._directions,i=n.length,o=new Float32Array(3*i),a=isFinite(t.radius)?t.radius:gUe,s=[p.ZERO];for(let l=i-2,r=i-1,d=0;d=3&&(this._frontFaceColorCommand.vertexArray=NUe(this,e),this._backFaceColorCommand.vertexArray=this._frontFaceColorCommand.vertexArray,this._pickCommand.vertexArray=this._frontFaceColorCommand.vertexArray)}if(!c(this._frontFaceColorCommand.vertexArray))return;let a=t.passes,s=!L.equals(this.modelMatrix,this._modelMatrix);s&&L.clone(this.modelMatrix,this._modelMatrix),(o||s)&&Ft.transform(this._boundingSphere,this.modelMatrix,this._boundingSphereWC),this._frontFaceColorCommand.modelMatrix=this.modelMatrix,this._backFaceColorCommand.modelMatrix=this._frontFaceColorCommand.modelMatrix,this._pickCommand.modelMatrix=this._frontFaceColorCommand.modelMatrix;let l=this._lateralSurfaceMaterial!==this.lateralSurfaceMaterial;if(this._lateralSurfaceMaterial=this.lateralSurfaceMaterial,this._lateralSurfaceMaterial.update(e),a.render){let r=this._frontFaceColorCommand,d=this._backFaceColorCommand;if(l||!c(r.shaderProgram)){let m=new Ve({sources:[wI,this._lateralSurfaceMaterial.shaderSource,PI]});r.shaderProgram=xn.replaceCache({context:e,shaderProgram:r.shaderProgram,vertexShaderSource:vI,fragmentShaderSource:m,attributeLocations:CK}),r.uniformMap=ze(this._uniforms,this._lateralSurfaceMaterial._uniforms),d.shaderProgram=r.shaderProgram,d.uniformMap=ze(this._uniforms,this._lateralSurfaceMaterial._uniforms),d.uniformMap.u_normalDirection=function(){return-1}}i?n.push(this._backFaceColorCommand,this._frontFaceColorCommand):n.push(this._frontFaceColorCommand)}if(a.pick){let r=this._pickCommand;if((!c(this._pickId)||this._id!==this.id)&&(this._id=this.id,this._pickId=this._pickId&&this._pickId.destroy(),this._pickId=e.createPickId({primitive:this._pickPrimitive,id:this.id})),l||!c(r.shaderProgram)){let d=new Ve({sources:[wI,this._lateralSurfaceMaterial.shaderSource,PI],pickColorQualifier:"uniform"});r.shaderProgram=xn.replaceCache({context:e,shaderProgram:r.shaderProgram,vertexShaderSource:vI,fragmentShaderSource:d,attributeLocations:CK});let m=this,h={czm_pickColor:function(){return m._pickId.color}};r.uniformMap=ze(ze(this._uniforms,this._lateralSurfaceMaterial._uniforms),h)}r.pass=i?Pt.TRANSLUCENT:Pt.OPAQUE,n.push(r)}};aM.prototype.isDestroyed=function(){return!1};aM.prototype.destroy=function(){return this._frontFaceColorCommand.vertexArray=this._frontFaceColorCommand.vertexArray&&this._frontFaceColorCommand.vertexArray.destroy(),this._frontFaceColorCommand.shaderProgram=this._frontFaceColorCommand.shaderProgram&&this._frontFaceColorCommand.shaderProgram.destroy(),this._pickCommand.shaderProgram=this._pickCommand.shaderProgram&&this._pickCommand.shaderProgram.destroy(),this._pickId=this._pickId&&this._pickId.destroy(),At(this)};var KZ=aM;var $Li=R(W(),1);function ac(t,e,n){let i=e[t.id];if(c(i)){let o=i.primitive;n.remove(o),o.isDestroyed()||o.destroy(),delete e[t.id]}}var yUe=v.WHITE,BUe=1,QUe=Number.POSITIVE_INFINITY,kUe=new ot,YUe=new p,xUe=new wt;function KI(t,e,n,i){let o=e[t];c(o)||(o=new Oc,e[t]=o),o.clock=n,o.cone=i,o.magnitude=1}function XUe(t,e,n,i,o){let a=t.directions,s,l=0,r=k.toRadians(2);if(e===0&&n===k.TWO_PI)for(s=0;se;s-=r)KI(l++,a,s,i);KI(l++,a,e,i)}else KI(l++,a,n,0)}a.length=l,t.directions=a}var zI=function(t,e){if(!c(t))throw new Ut("scene is required.");if(!c(e))throw new Ut("entityCollection is required.");e.collectionChanged.addEventListener(zI.prototype._onCollectionChanged,this),this._scene=t,this._primitives=t.primitives,this._entityCollection=e,this._hash={},this._entitiesToVisualize=new qe,this._onCollectionChanged(e,e.values,[],[])};zI.prototype.update=function(t){if(!c(t))throw new Ut("time is required.");let e=this._entitiesToVisualize.values,n=this._hash,i=this._primitives;for(let o=0,a=e.length;o-1;i--)ac(t[i],e,n);return At(this)};zI.prototype._onCollectionChanged=function(t,e,n,i){let o,a,s=this._entitiesToVisualize,l=this._hash,r=this._primitives;for(o=e.length-1;o>-1;o--)a=e[o],c(a._conicSensor)&&c(a._position)&&s.set(a.id,a);for(o=i.length-1;o>-1;o--)a=i[o],c(a._conicSensor)&&c(a._position)?s.set(a.id,a):(ac(a,l,r),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],ac(a,l,r),s.remove(a.id)};var LT=zI;var gMi=R(W(),1);var MT=class extends oW{constructor(e){super(e),this._directions=void 0,this._directionsSubscription=void 0,this._lateralSurfaceMaterial=void 0,this._lateralSurfaceMaterialSubscription=void 0,this._intersectionColor=void 0,this._intersectionColorSubscription=void 0,this._intersectionWidth=void 0,this._intersectionWidthSubscription=void 0,this._showIntersection=void 0,this._showIntersectionSubscription=void 0,this._radius=void 0,this._radiusSubscription=void 0,this._show=void 0,this._showSubscription=void 0,this._definitionChanged=new It,this.merge(f(e,f.EMPTY_OBJECT))}};Object.defineProperties(MT.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},directions:ft("directions"),lateralSurfaceMaterial:la("lateralSurfaceMaterial"),intersectionColor:ft("intersectionColor"),intersectionWidth:ft("intersectionWidth"),showIntersection:ft("showIntersection"),radius:ft("radius"),show:ft("show")});MT.prototype.clone=function(t){return c(t)||(t=new MT),t.directions=this.directions,t.radius=this.radius,t.show=this.show,t.showIntersection=this.showIntersection,t.intersectionColor=this.intersectionColor,t.intersectionWidth=this.intersectionWidth,t.lateralSurfaceMaterial=this.lateralSurfaceMaterial,t};MT.prototype.merge=function(t){if(!c(t))throw new Ut("source is required.");this.directions=f(this.directions,t.directions),this.radius=f(this.radius,t.radius),this.show=f(this.show,t.show),this.showIntersection=f(this.showIntersection,t.showIntersection),this.intersectionColor=f(this.intersectionColor,t.intersectionColor),this.intersectionWidth=f(this.intersectionWidth,t.intersectionWidth),this.lateralSurfaceMaterial=f(this.lateralSurfaceMaterial,t.lateralSurfaceMaterial)};var _T=MT;var OMi=R(W(),1);var JUe=v.WHITE,LUe=1,MUe=Number.POSITIVE_INFINITY,_Ue=new ot,DUe=new p,OUe=new wt,jI=function(t,e){if(!c(t))throw new Ut("scene is required.");if(!c(e))throw new Ut("entityCollection is required.");e.collectionChanged.addEventListener(jI.prototype._onCollectionChanged,this),this._scene=t,this._primitives=t.primitives,this._entityCollection=e,this._hash={},this._entitiesToVisualize=new qe,this._onCollectionChanged(e,e.values,[],[])};jI.prototype.update=function(t){if(!c(t))throw new Ut("time is required.");let e=this._entitiesToVisualize.values,n=this._hash,i=this._primitives;for(let o=0,a=e.length;o-1;i--)ac(t[i],e,n);return At(this)};jI.prototype._onCollectionChanged=function(t,e,n,i){let o,a,s=this._entitiesToVisualize,l=this._hash,r=this._primitives;for(o=e.length-1;o>-1;o--)a=e[o],c(a._customPatternSensor)&&c(a._position)&&s.set(a.id,a);for(o=i.length-1;o>-1;o--)a=i[o],c(a._customPatternSensor)&&c(a._position)?s.set(a.id,a):(ac(a,l,r),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],ac(a,l,r),s.remove(a.id)};var DT=jI;var $Mi=R(W(),1);var OT=class extends oW{constructor(e={}){super(e),this._definitionChanged=new It,this.xHalfAngle=e.xHalfAngle,this._xHalfAngleSubscription=void 0,this.yHalfAngle=e.yHalfAngle,this._yHalfAngleSubscription=void 0,this.lateralSurfaceMaterial=e.lateralSurfaceMaterial,this._lateralSurfaceMaterialSubscription=void 0,this.intersectionColor=e.intersectionColor,this._intersectionColorSubscription=void 0,this.intersectionWidth=e.intersectionWidth,this._intersectionWidthSubscription=void 0,this.showIntersection=e.showIntersection,this._showIntersectionSubscription=void 0,this.radius=e.radius,this._radiusSubscription=void 0,this.show=e.show,this._showSubscription=void 0}};Object.defineProperties(OT.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},xHalfAngle:ft("xHalfAngle"),yHalfAngle:ft("yHalfAngle"),lateralSurfaceMaterial:la("lateralSurfaceMaterial"),intersectionColor:ft("intersectionColor"),intersectionWidth:ft("intersectionWidth"),showIntersection:ft("showIntersection"),radius:ft("radius"),show:ft("show")});OT.prototype.clone=function(t){return c(t)||(t=new OT),t.xHalfAngle=this.xHalfAngle,t.yHalfAngle=this.yHalfAngle,t.radius=this.radius,t.show=this.show,t.showIntersection=this.showIntersection,t.intersectionColor=this.intersectionColor,t.intersectionWidth=this.intersectionWidth,t.lateralSurfaceMaterial=this.lateralSurfaceMaterial,t};OT.prototype.merge=function(t){if(!c(t))throw new Ut("source is required.");this.xHalfAngle=f(this.xHalfAngle,t.xHalfAngle),this.yHalfAngle=f(this.yHalfAngle,t.yHalfAngle),this.radius=f(this.radius,t.radius),this.show=f(this.show,t.show),this.showIntersection=f(this.showIntersection,t.showIntersection),this.intersectionColor=f(this.intersectionColor,t.intersectionColor),this.intersectionWidth=f(this.intersectionWidth,t.intersectionWidth),this.lateralSurfaceMaterial=f(this.lateralSurfaceMaterial,t.lateralSurfaceMaterial)};var HT=OT;var g_i=R(W(),1);var d_i=R(W(),1);function IK(t,e,n,i){let o=e[t];c(o)||(o=new Oc,e[t]=o),o.clock=n,o.cone=i,o.magnitude=1}function zit(t){let e=t._customSensor.directions,n=Math.tan(Math.min(t._xHalfAngle,k.toRadians(89))),i=Math.tan(Math.min(t._yHalfAngle,k.toRadians(89))),o=Math.atan(n/i),a=Math.atan(Math.sqrt(n*n+i*i));IK(0,e,o,a),IK(1,e,k.toRadians(180)-o,a),IK(2,e,k.toRadians(180)+o,a),IK(3,e,-o,a),e.length=4,t._customSensor.directions=e}var wT=class{constructor(e){e=f(e,f.EMPTY_OBJECT);let n=be(e);n._pickPrimitive=f(e._pickPrimitive,this),n.directions=void 0,this._customSensor=new KZ(n),this._xHalfAngle=f(e.xHalfAngle,k.PI_OVER_TWO),this._yHalfAngle=f(e.yHalfAngle,k.PI_OVER_TWO),zit(this)}};Object.defineProperties(wT.prototype,{xHalfAngle:{get:function(){return this._xHalfAngle},set:function(t){if(t>k.PI_OVER_TWO)throw new Ut("xHalfAngle must be less than or equal to 90 degrees.");this._xHalfAngle!==t&&(this._xHalfAngle=t,zit(this))}},yHalfAngle:{get:function(){return this._yHalfAngle},set:function(t){if(t>k.PI_OVER_TWO)throw new Ut("yHalfAngle must be less than or equal to 90 degrees.");this._yHalfAngle!==t&&(this._yHalfAngle=t,zit(this))}},show:{get:function(){return this._customSensor.show},set:function(t){this._customSensor.show=t}},showIntersection:{get:function(){return this._customSensor.showIntersection},set:function(t){this._customSensor.showIntersection=t}},showThroughEllipsoid:{get:function(){return this._customSensor.showThroughEllipsoid},set:function(t){this._customSensor.showThroughEllipsoid=t}},modelMatrix:{get:function(){return this._customSensor.modelMatrix},set:function(t){this._customSensor.modelMatrix=t}},radius:{get:function(){return this._customSensor.radius},set:function(t){this._customSensor.radius=t}},lateralSurfaceMaterial:{get:function(){return this._customSensor.lateralSurfaceMaterial},set:function(t){this._customSensor.lateralSurfaceMaterial=t}},intersectionColor:{get:function(){return this._customSensor.intersectionColor},set:function(t){this._customSensor.intersectionColor=t}},intersectionWidth:{get:function(){return this._customSensor.intersectionWidth},set:function(t){this._customSensor.intersectionWidth=t}},id:{get:function(){return this._customSensor.id},set:function(t){this._customSensor.id=t}}});wT.prototype.update=function(t){this._customSensor.update(t)};wT.prototype.isDestroyed=function(){return!1};wT.prototype.destroy=function(){return this._customSensor=this._customSensor&&this._customSensor.destroy(),At(this)};var PT=wT;var HUe=v.WHITE,wUe=1,PUe=Number.POSITIVE_INFINITY,vUe=new ot,KUe=new p,zUe=new wt,qI=function(t,e){if(!c(t))throw new Ut("scene is required.");if(!c(e))throw new Ut("entityCollection is required.");e.collectionChanged.addEventListener(qI.prototype._onCollectionChanged,this),this._scene=t,this._primitives=t.primitives,this._entityCollection=e,this._hash={},this._entitiesToVisualize=new qe,this._onCollectionChanged(e,e.values,[],[])};qI.prototype.update=function(t){if(!c(t))throw new Ut("time is required.");let e=this._entitiesToVisualize.values,n=this._hash,i=this._primitives;for(let o=0,a=e.length;o-1;i--)ac(t[i],e,n);return At(this)};qI.prototype._onCollectionChanged=function(t,e,n,i){let o,a,s=this._entitiesToVisualize,l=this._hash,r=this._primitives;for(o=e.length-1;o>-1;o--)a=e[o],c(a._rectangularSensor)&&c(a._position)&&s.set(a.id,a);for(o=i.length-1;o>-1;o--)a=i[o],c(a._rectangularSensor)&&c(a._position)?s.set(a.id,a):(ac(a,l,r),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],ac(a,l,r),s.remove(a.id)};var vT=qI;var Wu=O0.processPacketData,jUe=O0.processMaterialPacketData;function iCt(t,e,n,i,o){let a,s,l=[],r=e.unitSpherical,d=e.spherical,m=e.unitCartesian,h=e.cartesian;if(c(r)){for(a=0,s=r.length;ae[1]!=t[o][1]>e[1]&&e[0]<(t[o][0]-t[i][0])*(e[1]-t[i][1])/(t[o][1]-t[i][1])+t[i][0]&&(n=!n),o=i;return n}function sIt(t){return[t.x,t.y]}function lIt(t,e,n){let i=p.subtract(t,e,new p),o=p.dot(i,n),a=p.multiplyByScalar(n,o,new p);return p.subtract(t,a,new p)}function ZAe(t,e,n){if(!t||!e||e.length===0)return!1;e=e.map(F=>new p(F[0],F[1],F[2]));let i=e.slice().sort((F,U)=>p.distance(n,U)-p.distance(n,F)),[o,a,s]=i.slice(0,3),l=p.subtract(a,o,new p),r=p.subtract(s,o,new p),d=p.cross(l,r,new p);p.normalize(d,d);let m=p.negate(d,new p),h=e.map(F=>lIt(F,t,m)),Z=lIt(t,t,m),b=h.map(sIt);return uAe(b,sIt(Z))}var lM=ZAe;function VAe(t,e,n){if(!t||!e||e.length===0)return!1;let i=e[0],o=e[1],a=[t.x,t.y,t.z],s=[n,...i].map(m=>[m.x,m.y,m.z]),l=[...o].map(m=>[m.x,m.y,m.z]);if(!lM(t,l,n))return!1;let r=(0,MK.default)(s);return!!(0,MK.isPointInsideHull)(a,s,r)}var rM=VAe;KT();var dot={ConicSensorGraphics:XT,ConicSensorVisualizer:LT,CustomPatternSensorGraphics:_T,CustomPatternSensorVisualizer:DT,CustomSensorVolume:KZ,RectangularPyramidSensorVolume:PT,RectangularSensorGraphics:HT,RectangularSensorVisualizer:vT,initialize:KT,sensorStateInstance:JT,isPointIn3D:rM};var gpo=R(W(),1);var rpo=R(W(),1);var S5i=R(W(),1);var Ot={};vO(Ot,{Builder:()=>_K,ByteBuffer:()=>qT,Encoding:()=>o1,FILE_IDENTIFIER_LENGTH:()=>$h,SIZEOF_INT:()=>jm,SIZEOF_SHORT:()=>i1,SIZE_PREFIX_LENGTH:()=>xt,float32:()=>dM,float64:()=>cM,int32:()=>jZ,isLittleEndian:()=>jT});var V5i=R(W());var n5i=R(W()),i1=2,jm=4,$h=4,xt=4;var o5i=R(W()),jZ=new Int32Array(2),dM=new Float32Array(jZ.buffer),cM=new Float64Array(jZ.buffer),jT=new Uint16Array(new Uint8Array([1,0]).buffer)[0]===1;var s5i=R(W()),o1;(function(t){t[t.UTF8_BYTES=1]="UTF8_BYTES",t[t.UTF16_STRING=2]="UTF16_STRING"})(o1||(o1={}));var Z5i=R(W());var m5i=R(W());var qT=class t{constructor(e){this.bytes_=e,this.position_=0,this.text_decoder_=new TextDecoder}static allocate(e){return new t(new Uint8Array(e))}clear(){this.position_=0}bytes(){return this.bytes_}position(){return this.position_}setPosition(e){this.position_=e}capacity(){return this.bytes_.length}readInt8(e){return this.readUint8(e)<<24>>24}readUint8(e){return this.bytes_[e]}readInt16(e){return this.readUint16(e)<<16>>16}readUint16(e){return this.bytes_[e]|this.bytes_[e+1]<<8}readInt32(e){return this.bytes_[e]|this.bytes_[e+1]<<8|this.bytes_[e+2]<<16|this.bytes_[e+3]<<24}readUint32(e){return this.readInt32(e)>>>0}readInt64(e){return BigInt.asIntN(64,BigInt(this.readUint32(e))+(BigInt(this.readUint32(e+4))<>8}writeUint16(e,n){this.bytes_[e]=n,this.bytes_[e+1]=n>>8}writeInt32(e,n){this.bytes_[e]=n,this.bytes_[e+1]=n>>8,this.bytes_[e+2]=n>>16,this.bytes_[e+3]=n>>24}writeUint32(e,n){this.bytes_[e]=n,this.bytes_[e+1]=n>>8,this.bytes_[e+2]=n>>16,this.bytes_[e+3]=n>>24}writeInt64(e,n){this.writeInt32(e,Number(BigInt.asIntN(32,n))),this.writeInt32(e+4,Number(BigInt.asIntN(32,n>>BigInt(32))))}writeUint64(e,n){this.writeUint32(e,Number(BigInt.asUintN(32,n))),this.writeUint32(e+4,Number(BigInt.asUintN(32,n>>BigInt(32))))}writeFloat32(e,n){dM[0]=n,this.writeInt32(e,jZ[0])}writeFloat64(e,n){cM[0]=n,this.writeInt32(e,jZ[jT?0:1]),this.writeInt32(e+4,jZ[jT?1:0])}getBufferIdentifier(){if(this.bytes_.lengththis.minalign&&(this.minalign=e);let i=~(this.bb.capacity()-this.space+n)+1&e-1;for(;this.space=0&&this.vtable[n]==0;n--);let i=n+1;for(;n>=0;n--)this.addInt16(this.vtable[n]!=0?e-this.vtable[n]:0);let o=2;this.addInt16(e-this.object_start);let a=(i+o)*2;this.addInt16(a);let s=0,l=this.space;t:for(n=0;n=0;s--)this.writeInt8(a.charCodeAt(s))}this.prep(this.minalign,4+o),this.addOffset(e),o&&this.addInt32(this.bb.capacity()-this.space),this.bb.setPosition(this.space)}finishSizePrefixed(e,n){this.finish(e,n,!0)}requiredField(e,n){let i=this.bb.capacity()-e,o=i-this.bb.readInt32(i);if(!(n{t=new Uint8Array(t);let i=new n[`${e}COLLECTIONT`];return n[`${e}COLLECTION`][`getRootAs${e}COLLECTION`](new bAe(t)).unpackTo(i),i};var vho=R(W(),1);var k5i=R(W(),1);var E5i=R(W(),1);var N5i=R(W(),1);var aW={};vO(aW,{Band:()=>yb,BandT:()=>hM,CAT:()=>rU,CATCOLLECTION:()=>s1,CATCOLLECTIONT:()=>bM,CATT:()=>VM,DataMode:()=>$F,DeviceType:()=>tU,FrequencyRange:()=>qZ,FrequencyRangeT:()=>mM,IDM:()=>Wo,IDMCOLLECTION:()=>l1,IDMCOLLECTIONT:()=>RM,IDMT:()=>uM,PLD:()=>Bb,PLDCOLLECTION:()=>r1,PLDCOLLECTIONT:()=>WM,PLDT:()=>ZM,PolarizationType:()=>eU,SimplePolarization:()=>nU,StokesParameters:()=>$T,StokesParametersT:()=>pM,dataStatusCode:()=>iU,massType:()=>oU,objectType:()=>aU,opsStatusCode:()=>sU,orbitType:()=>lU});var XDi=R(W(),1);var _5i=R(W(),1);var J5i=R(W(),1);var qZ=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsFrequencyRange(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsFrequencyRange(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}LOWER(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat64(this.bb_pos+e):0}static startFrequencyRange(e){e.startObject(2)}static addLower(e,n){e.addFieldFloat64(0,n,0)}static addUpper(e,n){e.addFieldFloat64(1,n,0)}static endFrequencyRange(e){return e.endObject()}static createFrequencyRange(e,n,i){return t.startFrequencyRange(e),t.addLower(e,n),t.addUpper(e,i),t.endFrequencyRange(e)}unpack(){return new mM(this.LOWER(),this.UPPER())}unpackTo(e){e.LOWER=this.LOWER(),e.UPPER=this.UPPER()}},mM=class{constructor(e=0,n=0){this.LOWER=e,this.UPPER=n}pack(e){return qZ.createFrequencyRange(e,this.LOWER,this.UPPER)}};var yb=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsBand(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsBand(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}NAME(e){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,e):null}FREQUENCY_RANGE(e){let n=this.bb.__offset(this.bb_pos,6);return n?(e||new qZ).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}static startBand(e){e.startObject(2)}static addName(e,n){e.addFieldOffset(0,n,0)}static addFrequencyRange(e,n){e.addFieldOffset(1,n,0)}static endBand(e){return e.endObject()}unpack(){return new hM(this.NAME(),this.FREQUENCY_RANGE()!==null?this.FREQUENCY_RANGE().unpack():null)}unpackTo(e){e.NAME=this.NAME(),e.FREQUENCY_RANGE=this.FREQUENCY_RANGE()!==null?this.FREQUENCY_RANGE().unpack():null}},hM=class{constructor(e=null,n=null){this.NAME=e,this.FREQUENCY_RANGE=n}pack(e){let n=this.NAME!==null?e.createString(this.NAME):0,i=this.FREQUENCY_RANGE!==null?this.FREQUENCY_RANGE.pack(e):0;return yb.startBand(e),yb.addName(e,n),yb.addFrequencyRange(e,i),yb.endBand(e)}};var EDi=R(W(),1);var cDi=R(W(),1);var lDi=R(W(),1);var O5i=R(W(),1),$F;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})($F||($F={}));var w5i=R(W(),1),tU;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(tU||(tU={}));var v5i=R(W(),1),eU;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(eU||(eU={}));var z5i=R(W(),1),nU;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(nU||(nU={}));var q5i=R(W(),1);var $T=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsStokesParameters(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsStokesParameters(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}I(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}Q(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat64(this.bb_pos+e):0}U(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readFloat64(this.bb_pos+e):0}V(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readFloat64(this.bb_pos+e):0}static startStokesParameters(e){e.startObject(4)}static addI(e,n){e.addFieldFloat64(0,n,0)}static addQ(e,n){e.addFieldFloat64(1,n,0)}static addU(e,n){e.addFieldFloat64(2,n,0)}static addV(e,n){e.addFieldFloat64(3,n,0)}static endStokesParameters(e){return e.endObject()}static createStokesParameters(e,n,i,o,a){return t.startStokesParameters(e),t.addI(e,n),t.addQ(e,i),t.addU(e,o),t.addV(e,a),t.endStokesParameters(e)}unpack(){return new pM(this.I(),this.Q(),this.U(),this.V())}unpackTo(e){e.I=this.I(),e.Q=this.Q(),e.U=this.U(),e.V=this.V()}},pM=class{constructor(e=0,n=0,i=0,o=0){this.I=e,this.Q=n,this.U=i,this.V=o}pack(e){return $T.createStokesParameters(e,this.I,this.Q,this.U,this.V)}};var Wo=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsIDM(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsIDM(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$IDM")}ID(e){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,e):null}NAME(e){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.__string(this.bb_pos+n,e):null}DATA_MODE(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readInt8(this.bb_pos+e):$F.REAL}UPLINK(e){let n=this.bb.__offset(this.bb_pos,10);return n?(e||new qZ).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}DOWNLINK(e){let n=this.bb.__offset(this.bb_pos,12);return n?(e||new qZ).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}BEACON(e){let n=this.bb.__offset(this.bb_pos,14);return n?(e||new qZ).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}BAND(e,n){let i=this.bb.__offset(this.bb_pos,16);return i?(n||new yb).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}bandLength(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.__vector_len(this.bb_pos+e):0}POLARIZATION_TYPE(){let e=this.bb.__offset(this.bb_pos,18);return e?this.bb.readInt8(this.bb_pos+e):eU.linear}SIMPLE_POLARIZATION(){let e=this.bb.__offset(this.bb_pos,20);return e?this.bb.readInt8(this.bb_pos+e):nU.vertical}STOKES_PARAMETERS(e){let n=this.bb.__offset(this.bb_pos,22);return n?(e||new $T).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}POWER_REQUIRED(){let e=this.bb.__offset(this.bb_pos,24);return e?this.bb.readFloat64(this.bb_pos+e):0}POWER_TYPE(e){let n=this.bb.__offset(this.bb_pos,26);return n?this.bb.__string(this.bb_pos+n,e):null}TRANSMIT(){let e=this.bb.__offset(this.bb_pos,28);return e?!!this.bb.readInt8(this.bb_pos+e):!1}RECEIVE(){let e=this.bb.__offset(this.bb_pos,30);return e?!!this.bb.readInt8(this.bb_pos+e):!1}SENSOR_TYPE(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readInt8(this.bb_pos+e):tU.UNKNOWN}SOURCE(e){let n=this.bb.__offset(this.bb_pos,34);return n?this.bb.__string(this.bb_pos+n,e):null}LAST_OB_TIME(e){let n=this.bb.__offset(this.bb_pos,36);return n?this.bb.__string(this.bb_pos+n,e):null}LOWER_LEFT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,38);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_LEFT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,40);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_RIGHT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_LEFT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_RIGHT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_RIGHT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_RIGHT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,50);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_LEFT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,52);return e?this.bb.readFloat64(this.bb_pos+e):0}RIGHT_GEO_BELT_LIMIT(){let e=this.bb.__offset(this.bb_pos,54);return e?this.bb.readFloat64(this.bb_pos+e):0}LEFT_GEO_BELT_LIMIT(){let e=this.bb.__offset(this.bb_pos,56);return e?this.bb.readFloat64(this.bb_pos+e):0}MAGNITUDE_LIMIT(){let e=this.bb.__offset(this.bb_pos,58);return e?this.bb.readFloat64(this.bb_pos+e):0}TASKABLE(){let e=this.bb.__offset(this.bb_pos,60);return e?!!this.bb.readInt8(this.bb_pos+e):!1}static startIDM(e){e.startObject(29)}static addId(e,n){e.addFieldOffset(0,n,0)}static addName(e,n){e.addFieldOffset(1,n,0)}static addDataMode(e,n){e.addFieldInt8(2,n,$F.REAL)}static addUplink(e,n){e.addFieldOffset(3,n,0)}static addDownlink(e,n){e.addFieldOffset(4,n,0)}static addBeacon(e,n){e.addFieldOffset(5,n,0)}static addBand(e,n){e.addFieldOffset(6,n,0)}static createBandVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startBandVector(e,n){e.startVector(4,n,4)}static addPolarizationType(e,n){e.addFieldInt8(7,n,eU.linear)}static addSimplePolarization(e,n){e.addFieldInt8(8,n,nU.vertical)}static addStokesParameters(e,n){e.addFieldOffset(9,n,0)}static addPowerRequired(e,n){e.addFieldFloat64(10,n,0)}static addPowerType(e,n){e.addFieldOffset(11,n,0)}static addTransmit(e,n){e.addFieldInt8(12,+n,0)}static addReceive(e,n){e.addFieldInt8(13,+n,0)}static addSensorType(e,n){e.addFieldInt8(14,n,tU.UNKNOWN)}static addSource(e,n){e.addFieldOffset(15,n,0)}static addLastObTime(e,n){e.addFieldOffset(16,n,0)}static addLowerLeftElevationLimit(e,n){e.addFieldFloat64(17,n,0)}static addUpperLeftAzimuthLimit(e,n){e.addFieldFloat64(18,n,0)}static addLowerRightElevationLimit(e,n){e.addFieldFloat64(19,n,0)}static addLowerLeftAzimuthLimit(e,n){e.addFieldFloat64(20,n,0)}static addUpperRightElevationLimit(e,n){e.addFieldFloat64(21,n,0)}static addUpperRightAzimuthLimit(e,n){e.addFieldFloat64(22,n,0)}static addLowerRightAzimuthLimit(e,n){e.addFieldFloat64(23,n,0)}static addUpperLeftElevationLimit(e,n){e.addFieldFloat64(24,n,0)}static addRightGeoBeltLimit(e,n){e.addFieldFloat64(25,n,0)}static addLeftGeoBeltLimit(e,n){e.addFieldFloat64(26,n,0)}static addMagnitudeLimit(e,n){e.addFieldFloat64(27,n,0)}static addTaskable(e,n){e.addFieldInt8(28,+n,0)}static endIDM(e){return e.endObject()}static finishIDMBuffer(e,n){e.finish(n,"$IDM")}static finishSizePrefixedIDMBuffer(e,n){e.finish(n,"$IDM",!0)}unpack(){return new uM(this.ID(),this.NAME(),this.DATA_MODE(),this.UPLINK()!==null?this.UPLINK().unpack():null,this.DOWNLINK()!==null?this.DOWNLINK().unpack():null,this.BEACON()!==null?this.BEACON().unpack():null,this.bb.createObjList(this.BAND.bind(this),this.bandLength()),this.POLARIZATION_TYPE(),this.SIMPLE_POLARIZATION(),this.STOKES_PARAMETERS()!==null?this.STOKES_PARAMETERS().unpack():null,this.POWER_REQUIRED(),this.POWER_TYPE(),this.TRANSMIT(),this.RECEIVE(),this.SENSOR_TYPE(),this.SOURCE(),this.LAST_OB_TIME(),this.LOWER_LEFT_ELEVATION_LIMIT(),this.UPPER_LEFT_AZIMUTH_LIMIT(),this.LOWER_RIGHT_ELEVATION_LIMIT(),this.LOWER_LEFT_AZIMUTH_LIMIT(),this.UPPER_RIGHT_ELEVATION_LIMIT(),this.UPPER_RIGHT_AZIMUTH_LIMIT(),this.LOWER_RIGHT_AZIMUTH_LIMIT(),this.UPPER_LEFT_ELEVATION_LIMIT(),this.RIGHT_GEO_BELT_LIMIT(),this.LEFT_GEO_BELT_LIMIT(),this.MAGNITUDE_LIMIT(),this.TASKABLE())}unpackTo(e){e.ID=this.ID(),e.NAME=this.NAME(),e.DATA_MODE=this.DATA_MODE(),e.UPLINK=this.UPLINK()!==null?this.UPLINK().unpack():null,e.DOWNLINK=this.DOWNLINK()!==null?this.DOWNLINK().unpack():null,e.BEACON=this.BEACON()!==null?this.BEACON().unpack():null,e.BAND=this.bb.createObjList(this.BAND.bind(this),this.bandLength()),e.POLARIZATION_TYPE=this.POLARIZATION_TYPE(),e.SIMPLE_POLARIZATION=this.SIMPLE_POLARIZATION(),e.STOKES_PARAMETERS=this.STOKES_PARAMETERS()!==null?this.STOKES_PARAMETERS().unpack():null,e.POWER_REQUIRED=this.POWER_REQUIRED(),e.POWER_TYPE=this.POWER_TYPE(),e.TRANSMIT=this.TRANSMIT(),e.RECEIVE=this.RECEIVE(),e.SENSOR_TYPE=this.SENSOR_TYPE(),e.SOURCE=this.SOURCE(),e.LAST_OB_TIME=this.LAST_OB_TIME(),e.LOWER_LEFT_ELEVATION_LIMIT=this.LOWER_LEFT_ELEVATION_LIMIT(),e.UPPER_LEFT_AZIMUTH_LIMIT=this.UPPER_LEFT_AZIMUTH_LIMIT(),e.LOWER_RIGHT_ELEVATION_LIMIT=this.LOWER_RIGHT_ELEVATION_LIMIT(),e.LOWER_LEFT_AZIMUTH_LIMIT=this.LOWER_LEFT_AZIMUTH_LIMIT(),e.UPPER_RIGHT_ELEVATION_LIMIT=this.UPPER_RIGHT_ELEVATION_LIMIT(),e.UPPER_RIGHT_AZIMUTH_LIMIT=this.UPPER_RIGHT_AZIMUTH_LIMIT(),e.LOWER_RIGHT_AZIMUTH_LIMIT=this.LOWER_RIGHT_AZIMUTH_LIMIT(),e.UPPER_LEFT_ELEVATION_LIMIT=this.UPPER_LEFT_ELEVATION_LIMIT(),e.RIGHT_GEO_BELT_LIMIT=this.RIGHT_GEO_BELT_LIMIT(),e.LEFT_GEO_BELT_LIMIT=this.LEFT_GEO_BELT_LIMIT(),e.MAGNITUDE_LIMIT=this.MAGNITUDE_LIMIT(),e.TASKABLE=this.TASKABLE()}},uM=class{constructor(e=null,n=null,i=$F.REAL,o=null,a=null,s=null,l=[],r=eU.linear,d=nU.vertical,m=null,h=0,Z=null,b=!1,u=!1,F=tU.UNKNOWN,U=null,G=null,A=0,T=0,g=0,C=0,y=0,Y=0,Q=0,J=0,M=0,V=0,E=0,I=!1){this.ID=e,this.NAME=n,this.DATA_MODE=i,this.UPLINK=o,this.DOWNLINK=a,this.BEACON=s,this.BAND=l,this.POLARIZATION_TYPE=r,this.SIMPLE_POLARIZATION=d,this.STOKES_PARAMETERS=m,this.POWER_REQUIRED=h,this.POWER_TYPE=Z,this.TRANSMIT=b,this.RECEIVE=u,this.SENSOR_TYPE=F,this.SOURCE=U,this.LAST_OB_TIME=G,this.LOWER_LEFT_ELEVATION_LIMIT=A,this.UPPER_LEFT_AZIMUTH_LIMIT=T,this.LOWER_RIGHT_ELEVATION_LIMIT=g,this.LOWER_LEFT_AZIMUTH_LIMIT=C,this.UPPER_RIGHT_ELEVATION_LIMIT=y,this.UPPER_RIGHT_AZIMUTH_LIMIT=Y,this.LOWER_RIGHT_AZIMUTH_LIMIT=Q,this.UPPER_LEFT_ELEVATION_LIMIT=J,this.RIGHT_GEO_BELT_LIMIT=M,this.LEFT_GEO_BELT_LIMIT=V,this.MAGNITUDE_LIMIT=E,this.TASKABLE=I}pack(e){let n=this.ID!==null?e.createString(this.ID):0,i=this.NAME!==null?e.createString(this.NAME):0,o=this.UPLINK!==null?this.UPLINK.pack(e):0,a=this.DOWNLINK!==null?this.DOWNLINK.pack(e):0,s=this.BEACON!==null?this.BEACON.pack(e):0,l=Wo.createBandVector(e,e.createObjectOffsetList(this.BAND)),r=this.STOKES_PARAMETERS!==null?this.STOKES_PARAMETERS.pack(e):0,d=this.POWER_TYPE!==null?e.createString(this.POWER_TYPE):0,m=this.SOURCE!==null?e.createString(this.SOURCE):0,h=this.LAST_OB_TIME!==null?e.createString(this.LAST_OB_TIME):0;return Wo.startIDM(e),Wo.addId(e,n),Wo.addName(e,i),Wo.addDataMode(e,this.DATA_MODE),Wo.addUplink(e,o),Wo.addDownlink(e,a),Wo.addBeacon(e,s),Wo.addBand(e,l),Wo.addPolarizationType(e,this.POLARIZATION_TYPE),Wo.addSimplePolarization(e,this.SIMPLE_POLARIZATION),Wo.addStokesParameters(e,r),Wo.addPowerRequired(e,this.POWER_REQUIRED),Wo.addPowerType(e,d),Wo.addTransmit(e,this.TRANSMIT),Wo.addReceive(e,this.RECEIVE),Wo.addSensorType(e,this.SENSOR_TYPE),Wo.addSource(e,m),Wo.addLastObTime(e,h),Wo.addLowerLeftElevationLimit(e,this.LOWER_LEFT_ELEVATION_LIMIT),Wo.addUpperLeftAzimuthLimit(e,this.UPPER_LEFT_AZIMUTH_LIMIT),Wo.addLowerRightElevationLimit(e,this.LOWER_RIGHT_ELEVATION_LIMIT),Wo.addLowerLeftAzimuthLimit(e,this.LOWER_LEFT_AZIMUTH_LIMIT),Wo.addUpperRightElevationLimit(e,this.UPPER_RIGHT_ELEVATION_LIMIT),Wo.addUpperRightAzimuthLimit(e,this.UPPER_RIGHT_AZIMUTH_LIMIT),Wo.addLowerRightAzimuthLimit(e,this.LOWER_RIGHT_AZIMUTH_LIMIT),Wo.addUpperLeftElevationLimit(e,this.UPPER_LEFT_ELEVATION_LIMIT),Wo.addRightGeoBeltLimit(e,this.RIGHT_GEO_BELT_LIMIT),Wo.addLeftGeoBeltLimit(e,this.LEFT_GEO_BELT_LIMIT),Wo.addMagnitudeLimit(e,this.MAGNITUDE_LIMIT),Wo.addTaskable(e,this.TASKABLE),Wo.endIDM(e)}};var Bb=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsPLD(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsPLD(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$PLD")}PAYLOAD_DURATION(e){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,e):null}MASS_AT_LAUNCH(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat32(this.bb_pos+e):0}DIMENSIONS(e){let n=this.bb.__offset(this.bb_pos,8);return n?this.bb.__string(this.bb_pos+n,e):null}SOLAR_ARRAY_AREA(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readFloat32(this.bb_pos+e):0}SOLAR_ARRAY_DIMENSIONS(e){let n=this.bb.__offset(this.bb_pos,12);return n?this.bb.__string(this.bb_pos+n,e):null}NOMINAL_OPERATIONAL_LIFETIME(e){let n=this.bb.__offset(this.bb_pos,14);return n?this.bb.__string(this.bb_pos+n,e):null}INSTRUMENTS(e,n){let i=this.bb.__offset(this.bb_pos,16);return i?(n||new Wo).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}instrumentsLength(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.__vector_len(this.bb_pos+e):0}static startPLD(e){e.startObject(7)}static addPayloadDuration(e,n){e.addFieldOffset(0,n,0)}static addMassAtLaunch(e,n){e.addFieldFloat32(1,n,0)}static addDimensions(e,n){e.addFieldOffset(2,n,0)}static addSolarArrayArea(e,n){e.addFieldFloat32(3,n,0)}static addSolarArrayDimensions(e,n){e.addFieldOffset(4,n,0)}static addNominalOperationalLifetime(e,n){e.addFieldOffset(5,n,0)}static addInstruments(e,n){e.addFieldOffset(6,n,0)}static createInstrumentsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startInstrumentsVector(e,n){e.startVector(4,n,4)}static endPLD(e){return e.endObject()}static finishPLDBuffer(e,n){e.finish(n,"$PLD")}static finishSizePrefixedPLDBuffer(e,n){e.finish(n,"$PLD",!0)}static createPLD(e,n,i,o,a,s,l,r){return t.startPLD(e),t.addPayloadDuration(e,n),t.addMassAtLaunch(e,i),t.addDimensions(e,o),t.addSolarArrayArea(e,a),t.addSolarArrayDimensions(e,s),t.addNominalOperationalLifetime(e,l),t.addInstruments(e,r),t.endPLD(e)}unpack(){return new ZM(this.PAYLOAD_DURATION(),this.MASS_AT_LAUNCH(),this.DIMENSIONS(),this.SOLAR_ARRAY_AREA(),this.SOLAR_ARRAY_DIMENSIONS(),this.NOMINAL_OPERATIONAL_LIFETIME(),this.bb.createObjList(this.INSTRUMENTS.bind(this),this.instrumentsLength()))}unpackTo(e){e.PAYLOAD_DURATION=this.PAYLOAD_DURATION(),e.MASS_AT_LAUNCH=this.MASS_AT_LAUNCH(),e.DIMENSIONS=this.DIMENSIONS(),e.SOLAR_ARRAY_AREA=this.SOLAR_ARRAY_AREA(),e.SOLAR_ARRAY_DIMENSIONS=this.SOLAR_ARRAY_DIMENSIONS(),e.NOMINAL_OPERATIONAL_LIFETIME=this.NOMINAL_OPERATIONAL_LIFETIME(),e.INSTRUMENTS=this.bb.createObjList(this.INSTRUMENTS.bind(this),this.instrumentsLength())}},ZM=class{constructor(e=null,n=0,i=null,o=0,a=null,s=null,l=[]){this.PAYLOAD_DURATION=e,this.MASS_AT_LAUNCH=n,this.DIMENSIONS=i,this.SOLAR_ARRAY_AREA=o,this.SOLAR_ARRAY_DIMENSIONS=a,this.NOMINAL_OPERATIONAL_LIFETIME=s,this.INSTRUMENTS=l}pack(e){let n=this.PAYLOAD_DURATION!==null?e.createString(this.PAYLOAD_DURATION):0,i=this.DIMENSIONS!==null?e.createString(this.DIMENSIONS):0,o=this.SOLAR_ARRAY_DIMENSIONS!==null?e.createString(this.SOLAR_ARRAY_DIMENSIONS):0,a=this.NOMINAL_OPERATIONAL_LIFETIME!==null?e.createString(this.NOMINAL_OPERATIONAL_LIFETIME):0,s=Bb.createInstrumentsVector(e,e.createObjectOffsetList(this.INSTRUMENTS));return Bb.createPLD(e,n,this.MASS_AT_LAUNCH,i,this.SOLAR_ARRAY_AREA,o,a,s)}};var hDi=R(W(),1),iU;(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(iU||(iU={}));var uDi=R(W(),1),oU;(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(oU||(oU={}));var VDi=R(W(),1),aU;(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(aU||(aU={}));var RDi=R(W(),1),sU;(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(sU||(sU={}));var fDi=R(W(),1),lU;(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(lU||(lU={}));var rU=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsCAT(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsCAT(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$CAT")}OBJECT_NAME(e){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,e):null}OBJECT_ID(e){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.__string(this.bb_pos+n,e):null}NORAD_CAT_ID(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readUint32(this.bb_pos+e):0}OBJECT_TYPE(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readInt8(this.bb_pos+e):aU.UNKNOWN}OPS_STATUS_CODE(){let e=this.bb.__offset(this.bb_pos,12);return e?this.bb.readInt8(this.bb_pos+e):sU.UNKNOWN}OWNER(e){let n=this.bb.__offset(this.bb_pos,14);return n?this.bb.__string(this.bb_pos+n,e):null}LAUNCH_DATE(e){let n=this.bb.__offset(this.bb_pos,16);return n?this.bb.__string(this.bb_pos+n,e):null}LAUNCH_SITE(e){let n=this.bb.__offset(this.bb_pos,18);return n?this.bb.__string(this.bb_pos+n,e):null}DECAY_DATE(e){let n=this.bb.__offset(this.bb_pos,20);return n?this.bb.__string(this.bb_pos+n,e):null}PERIOD(){let e=this.bb.__offset(this.bb_pos,22);return e?this.bb.readFloat64(this.bb_pos+e):0}INCLINATION(){let e=this.bb.__offset(this.bb_pos,24);return e?this.bb.readFloat64(this.bb_pos+e):0}APOGEE(){let e=this.bb.__offset(this.bb_pos,26);return e?this.bb.readFloat64(this.bb_pos+e):0}PERIGEE(){let e=this.bb.__offset(this.bb_pos,28);return e?this.bb.readFloat64(this.bb_pos+e):0}RCS(){let e=this.bb.__offset(this.bb_pos,30);return e?this.bb.readFloat64(this.bb_pos+e):0}DATA_STATUS_CODE(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readInt8(this.bb_pos+e):iU.NO_CURRENT_ELEMENTS}ORBIT_CENTER(e){let n=this.bb.__offset(this.bb_pos,34);return n?this.bb.__string(this.bb_pos+n,e):null}ORBIT_TYPE(){let e=this.bb.__offset(this.bb_pos,36);return e?this.bb.readInt8(this.bb_pos+e):lU.ORBIT}DEPLOYMENT_DATE(e){let n=this.bb.__offset(this.bb_pos,38);return n?this.bb.__string(this.bb_pos+n,e):null}MANEUVERABLE(){let e=this.bb.__offset(this.bb_pos,40);return e?!!this.bb.readInt8(this.bb_pos+e):!1}SIZE(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS_TYPE(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readInt8(this.bb_pos+e):oU.DRY}PAYLOADS(e,n){let i=this.bb.__offset(this.bb_pos,48);return i?(n||new Bb).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}payloadsLength(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.__vector_len(this.bb_pos+e):0}static startCAT(e){e.startObject(23)}static addObjectName(e,n){e.addFieldOffset(0,n,0)}static addObjectId(e,n){e.addFieldOffset(1,n,0)}static addNoradCatId(e,n){e.addFieldInt32(2,n,0)}static addObjectType(e,n){e.addFieldInt8(3,n,aU.UNKNOWN)}static addOpsStatusCode(e,n){e.addFieldInt8(4,n,sU.UNKNOWN)}static addOwner(e,n){e.addFieldOffset(5,n,0)}static addLaunchDate(e,n){e.addFieldOffset(6,n,0)}static addLaunchSite(e,n){e.addFieldOffset(7,n,0)}static addDecayDate(e,n){e.addFieldOffset(8,n,0)}static addPeriod(e,n){e.addFieldFloat64(9,n,0)}static addInclination(e,n){e.addFieldFloat64(10,n,0)}static addApogee(e,n){e.addFieldFloat64(11,n,0)}static addPerigee(e,n){e.addFieldFloat64(12,n,0)}static addRcs(e,n){e.addFieldFloat64(13,n,0)}static addDataStatusCode(e,n){e.addFieldInt8(14,n,iU.NO_CURRENT_ELEMENTS)}static addOrbitCenter(e,n){e.addFieldOffset(15,n,0)}static addOrbitType(e,n){e.addFieldInt8(16,n,lU.ORBIT)}static addDeploymentDate(e,n){e.addFieldOffset(17,n,0)}static addManeuverable(e,n){e.addFieldInt8(18,+n,0)}static addSize(e,n){e.addFieldFloat64(19,n,0)}static addMass(e,n){e.addFieldFloat64(20,n,0)}static addMassType(e,n){e.addFieldInt8(21,n,oU.DRY)}static addPayloads(e,n){e.addFieldOffset(22,n,0)}static createPayloadsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startPayloadsVector(e,n){e.startVector(4,n,4)}static endCAT(e){return e.endObject()}static finishCATBuffer(e,n){e.finish(n,"$CAT")}static finishSizePrefixedCATBuffer(e,n){e.finish(n,"$CAT",!0)}static createCAT(e,n,i,o,a,s,l,r,d,m,h,Z,b,u,F,U,G,A,T,g,C,y,Y,Q){return t.startCAT(e),t.addObjectName(e,n),t.addObjectId(e,i),t.addNoradCatId(e,o),t.addObjectType(e,a),t.addOpsStatusCode(e,s),t.addOwner(e,l),t.addLaunchDate(e,r),t.addLaunchSite(e,d),t.addDecayDate(e,m),t.addPeriod(e,h),t.addInclination(e,Z),t.addApogee(e,b),t.addPerigee(e,u),t.addRcs(e,F),t.addDataStatusCode(e,U),t.addOrbitCenter(e,G),t.addOrbitType(e,A),t.addDeploymentDate(e,T),t.addManeuverable(e,g),t.addSize(e,C),t.addMass(e,y),t.addMassType(e,Y),t.addPayloads(e,Q),t.endCAT(e)}unpack(){return new VM(this.OBJECT_NAME(),this.OBJECT_ID(),this.NORAD_CAT_ID(),this.OBJECT_TYPE(),this.OPS_STATUS_CODE(),this.OWNER(),this.LAUNCH_DATE(),this.LAUNCH_SITE(),this.DECAY_DATE(),this.PERIOD(),this.INCLINATION(),this.APOGEE(),this.PERIGEE(),this.RCS(),this.DATA_STATUS_CODE(),this.ORBIT_CENTER(),this.ORBIT_TYPE(),this.DEPLOYMENT_DATE(),this.MANEUVERABLE(),this.SIZE(),this.MASS(),this.MASS_TYPE(),this.bb.createObjList(this.PAYLOADS.bind(this),this.payloadsLength()))}unpackTo(e){e.OBJECT_NAME=this.OBJECT_NAME(),e.OBJECT_ID=this.OBJECT_ID(),e.NORAD_CAT_ID=this.NORAD_CAT_ID(),e.OBJECT_TYPE=this.OBJECT_TYPE(),e.OPS_STATUS_CODE=this.OPS_STATUS_CODE(),e.OWNER=this.OWNER(),e.LAUNCH_DATE=this.LAUNCH_DATE(),e.LAUNCH_SITE=this.LAUNCH_SITE(),e.DECAY_DATE=this.DECAY_DATE(),e.PERIOD=this.PERIOD(),e.INCLINATION=this.INCLINATION(),e.APOGEE=this.APOGEE(),e.PERIGEE=this.PERIGEE(),e.RCS=this.RCS(),e.DATA_STATUS_CODE=this.DATA_STATUS_CODE(),e.ORBIT_CENTER=this.ORBIT_CENTER(),e.ORBIT_TYPE=this.ORBIT_TYPE(),e.DEPLOYMENT_DATE=this.DEPLOYMENT_DATE(),e.MANEUVERABLE=this.MANEUVERABLE(),e.SIZE=this.SIZE(),e.MASS=this.MASS(),e.MASS_TYPE=this.MASS_TYPE(),e.PAYLOADS=this.bb.createObjList(this.PAYLOADS.bind(this),this.payloadsLength())}},VM=class{constructor(e=null,n=null,i=0,o=aU.UNKNOWN,a=sU.UNKNOWN,s=null,l=null,r=null,d=null,m=0,h=0,Z=0,b=0,u=0,F=iU.NO_CURRENT_ELEMENTS,U=null,G=lU.ORBIT,A=null,T=!1,g=0,C=0,y=oU.DRY,Y=[]){this.OBJECT_NAME=e,this.OBJECT_ID=n,this.NORAD_CAT_ID=i,this.OBJECT_TYPE=o,this.OPS_STATUS_CODE=a,this.OWNER=s,this.LAUNCH_DATE=l,this.LAUNCH_SITE=r,this.DECAY_DATE=d,this.PERIOD=m,this.INCLINATION=h,this.APOGEE=Z,this.PERIGEE=b,this.RCS=u,this.DATA_STATUS_CODE=F,this.ORBIT_CENTER=U,this.ORBIT_TYPE=G,this.DEPLOYMENT_DATE=A,this.MANEUVERABLE=T,this.SIZE=g,this.MASS=C,this.MASS_TYPE=y,this.PAYLOADS=Y}pack(e){let n=this.OBJECT_NAME!==null?e.createString(this.OBJECT_NAME):0,i=this.OBJECT_ID!==null?e.createString(this.OBJECT_ID):0,o=this.OWNER!==null?e.createString(this.OWNER):0,a=this.LAUNCH_DATE!==null?e.createString(this.LAUNCH_DATE):0,s=this.LAUNCH_SITE!==null?e.createString(this.LAUNCH_SITE):0,l=this.DECAY_DATE!==null?e.createString(this.DECAY_DATE):0,r=this.ORBIT_CENTER!==null?e.createString(this.ORBIT_CENTER):0,d=this.DEPLOYMENT_DATE!==null?e.createString(this.DEPLOYMENT_DATE):0,m=rU.createPayloadsVector(e,e.createObjectOffsetList(this.PAYLOADS));return rU.createCAT(e,n,i,this.NORAD_CAT_ID,this.OBJECT_TYPE,this.OPS_STATUS_CODE,o,a,s,l,this.PERIOD,this.INCLINATION,this.APOGEE,this.PERIGEE,this.RCS,this.DATA_STATUS_CODE,r,this.ORBIT_TYPE,d,this.MANEUVERABLE,this.SIZE,this.MASS,this.MASS_TYPE,m)}};var NDi=R(W(),1);var s1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsCATCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsCATCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new rU).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startCATCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endCATCOLLECTION(e){return e.endObject()}static createCATCOLLECTION(e,n){return t.startCATCOLLECTION(e),t.addRecords(e,n),t.endCATCOLLECTION(e)}unpack(){return new bM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},bM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=s1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return s1.createCATCOLLECTION(e,n)}};var QDi=R(W(),1);var l1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsIDMCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsIDMCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new Wo).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startIDMCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endIDMCOLLECTION(e){return e.endObject()}static createIDMCOLLECTION(e,n){return t.startIDMCOLLECTION(e),t.addRecords(e,n),t.endIDMCOLLECTION(e)}unpack(){return new RM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},RM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=l1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return l1.createIDMCOLLECTION(e,n)}};var xDi=R(W(),1);var r1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsPLDCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsPLDCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new Bb).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startPLDCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endPLDCOLLECTION(e){return e.endObject()}static createPLDCOLLECTION(e,n){return t.startPLDCOLLECTION(e),t.addRecords(e,n),t.endPLDCOLLECTION(e)}unpack(){return new WM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},WM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=r1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return r1.createPLDCOLLECTION(e,n)}};var Uwi=R(W(),1);var oOi=R(W(),1);var dOi=R(W(),1);var sOi=R(W(),1);var KOi=R(W(),1);var NOi=R(W(),1);var EOi=R(W(),1);var mOi=R(W(),1),DK;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(DK||(DK={}));var pOi=R(W(),1),OK;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(OK||(OK={}));var ZOi=R(W(),1),HK;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(HK||(HK={}));var bOi=R(W(),1),wK;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(wK||(wK={}));var WOi=R(W(),1);var BOi=R(W(),1),PK;(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(PK||(PK={}));var kOi=R(W(),1),vK;(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(vK||(vK={}));var xOi=R(W(),1),KK;(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(KK||(KK={}));var JOi=R(W(),1),zK;(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(zK||(zK={}));var MOi=R(W(),1),jK;(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(jK||(jK={}));var qOi=R(W(),1);var gHi=R(W(),1);var bHi=R(W(),1);var lHi=R(W(),1);var iHi=R(W(),1);var tHi=R(W(),1),qK;(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(qK||(qK={}));var dHi=R(W(),1),$K;(function(t){t[t.CALCULATED=0]="CALCULATED",t[t.DEFAULT=1]="DEFAULT"})($K||($K={}));var mHi=R(W(),1),d1;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(d1||(d1={}));var WHi=R(W(),1);var FHi=R(W(),1),t3;(function(t){t[t.ELLIPSOID=0]="ELLIPSOID",t[t.BOX=1]="BOX"})(t3||(t3={}));var IHi=R(W(),1);var BHi=R(W(),1);var YHi=R(W(),1);var JHi=R(W(),1);var _Hi=R(W(),1);var HHi=R(W(),1);var vHi=R(W(),1);var cPi=R(W(),1);var iPi=R(W(),1);var sPi=R(W(),1);var Qvi=R(W(),1);var bPi=R(W(),1);var uPi=R(W(),1);var ivi=R(W(),1);var JPi=R(W(),1);var YPi=R(W(),1);var WPi=R(W(),1),e3;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(e3||(e3={}));var FPi=R(W(),1),n3;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(n3||(n3={}));var GPi=R(W(),1),i3;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(i3||(i3={}));var TPi=R(W(),1),o3;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(o3||(o3={}));var gPi=R(W(),1);var MPi=R(W(),1),a3;(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(a3||(a3={}));var DPi=R(W(),1),s3;(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(s3||(s3={}));var HPi=R(W(),1),l3;(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(l3||(l3={}));var PPi=R(W(),1),r3;(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(r3||(r3={}));var KPi=R(W(),1),d3;(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(d3||(d3={}));var svi=R(W(),1);var dvi=R(W(),1);var hvi=R(W(),1);var Zvi=R(W(),1);var Rvi=R(W(),1);var dKi=R(W(),1);var nKi=R(W(),1);var aKi=R(W(),1);var fKi=R(W(),1);var pKi=R(W(),1);var VKi=R(W(),1);var DKi=R(W(),1);var gKi=R(W(),1);var AKi=R(W(),1),fM;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(fM||(fM={}));var IKi=R(W(),1);var BKi=R(W(),1);var YKi=R(W(),1);var s3i=R(W(),1);var zKi=R(W(),1),c3;(function(t){t[t.OBSERVED=0]="OBSERVED",t[t.PREDICTED=1]="PREDICTED"})(c3||(c3={}));var $Ki=R(W(),1);var n3i=R(W(),1);var C3i=R(W(),1);var m3i=R(W(),1);var V3i=R(W(),1);var p3i=R(W(),1),m3;(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(m3||(m3={}));var f3i=R(W(),1);var G3i=R(W(),1);var z3i=R(W(),1);var _3i=R(W(),1);var J3i=R(W(),1);var Y3i=R(W(),1),h3;(function(t){t[t.OUTLIER=0]="OUTLIER"})(h3||(h3={}));var H3i=R(W(),1);var Qzi=R(W(),1);var azi=R(W(),1);var nzi=R(W(),1);var lzi=R(W(),1),p3;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(p3||(p3={}));var dzi=R(W(),1),u3;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(u3||(u3={}));var Azi=R(W(),1);var mzi=R(W(),1),Z3;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(Z3||(Z3={}));var pzi=R(W(),1),V3;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(V3||(V3={}));var Zzi=R(W(),1);var gzi=R(W(),1);var g8i=R(W(),1);var Hzi=R(W(),1);var Pzi=R(W(),1);var zzi=R(W(),1);var eji=R(W(),1);var qzi=R(W(),1);var Mji=R(W(),1);var Gji=R(W(),1);var fji=R(W(),1);var iji=R(W(),1),b3;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(b3||(b3={}));var aji=R(W(),1),R3;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(R3||(R3={}));var lji=R(W(),1),W3;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(W3||(W3={}));var dji=R(W(),1),f3;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(f3||(f3={}));var mji=R(W(),1);var Tji=R(W(),1),F3;(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(F3||(F3={}));var gji=R(W(),1),U3;(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(U3||(U3={}));var Cji=R(W(),1),G3;(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(G3||(G3={}));var Nji=R(W(),1),A3;(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(A3||(A3={}));var Bji=R(W(),1),T3;(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(T3||(T3={}));var Oji=R(W(),1);var Kji=R(W(),1);var wji=R(W(),1),S3;(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(S3||(S3={}));var t4i=R(W(),1);var jji=R(W(),1),g3;(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(g3||(g3={}));var o4i=R(W(),1);var l4i=R(W(),1);var d4i=R(W(),1);var h4i=R(W(),1);var k4i=R(W(),1);var F4i=R(W(),1);var Z4i=R(W(),1);var b4i=R(W(),1);var E4i=R(W(),1);var G4i=R(W(),1),E3;(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(E3||(E3={}));var X4i=R(W(),1);var M4i=R(W(),1);var O4i=R(W(),1);var P4i=R(W(),1);var U6i=R(W(),1);var Z6i=R(W(),1);var h6i=R(W(),1),C3;(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(C3||(C3={}));var R6i=R(W(),1);var w6i=R(W(),1);var I6i=R(W(),1);var g6i=R(W(),1),FM;(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(FM||(FM={}));var B6i=R(W(),1);var Y6i=R(W(),1);var J6i=R(W(),1);var D7i=R(W(),1);var Z7i=R(W(),1);var h7i=R(W(),1);var n7i=R(W(),1);var $6i=R(W(),1),c1;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(c1||(c1={}));var o7i=R(W(),1);var s7i=R(W(),1),UM;(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(UM||(UM={}));var R7i=R(W(),1);var F7i=R(W(),1);var A7i=R(W(),1);var g7i=R(W(),1);var I7i=R(W(),1);var sW={};vO(sW,{MET:()=>tS,METCOLLECTION:()=>m1,METCOLLECTIONT:()=>AM,METT:()=>GM,OMM:()=>eS,OMMCOLLECTION:()=>h1,OMMCOLLECTIONT:()=>SM,OMMT:()=>TM,RFM:()=>nS,RFMCOLLECTION:()=>p1,RFMCOLLECTIONT:()=>EM,RFMT:()=>gM,TIM:()=>iS,TIMCOLLECTION:()=>u1,TIMCOLLECTIONT:()=>IM,TIMT:()=>CM,ephemerisType:()=>dU,meanElementTheory:()=>fu,refFrame:()=>zc,timeSystem:()=>Fu});var Yqi=R(W(),1);var aqi=R(W(),1);var nqi=R(W(),1),fu;(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(fu||(fu={}));var tS=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsMET(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsMET(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$MET")}MEAN_ELEMENT_THEORY(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):fu.SGP4}static startMET(e){e.startObject(1)}static addMeanElementTheory(e,n){e.addFieldInt8(0,n,fu.SGP4)}static endMET(e){return e.endObject()}static finishMETBuffer(e,n){e.finish(n,"$MET")}static finishSizePrefixedMETBuffer(e,n){e.finish(n,"$MET",!0)}static createMET(e,n){return t.startMET(e),t.addMeanElementTheory(e,n),t.endMET(e)}unpack(){return new GM(this.MEAN_ELEMENT_THEORY())}unpackTo(e){e.MEAN_ELEMENT_THEORY=this.MEAN_ELEMENT_THEORY()}},GM=class{constructor(e=fu.SGP4){this.MEAN_ELEMENT_THEORY=e}pack(e){return tS.createMET(e,this.MEAN_ELEMENT_THEORY)}};var rqi=R(W(),1);var m1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsMETCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsMETCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new tS).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startMETCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endMETCOLLECTION(e){return e.endObject()}static createMETCOLLECTION(e,n){return t.startMETCOLLECTION(e),t.addRecords(e,n),t.endMETCOLLECTION(e)}unpack(){return new AM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},AM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=m1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return m1.createMETCOLLECTION(e,n)}};var fqi=R(W(),1);var cqi=R(W(),1),dU;(function(t){t[t.SGP=0]="SGP",t[t.SGP4=1]="SGP4",t[t.SDP4=2]="SDP4",t[t.SGP8=3]="SGP8",t[t.SDP8=4]="SDP8"})(dU||(dU={}));var hqi=R(W(),1),zc;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(zc||(zc={}));var uqi=R(W(),1),Fu;(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(Fu||(Fu={}));var eS=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsOMM(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsOMM(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$OMM")}CCSDS_OMM_VERS(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}CREATION_DATE(e){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.__string(this.bb_pos+n,e):null}ORIGINATOR(e){let n=this.bb.__offset(this.bb_pos,8);return n?this.bb.__string(this.bb_pos+n,e):null}OBJECT_NAME(e){let n=this.bb.__offset(this.bb_pos,10);return n?this.bb.__string(this.bb_pos+n,e):null}OBJECT_ID(e){let n=this.bb.__offset(this.bb_pos,12);return n?this.bb.__string(this.bb_pos+n,e):null}CENTER_NAME(e){let n=this.bb.__offset(this.bb_pos,14);return n?this.bb.__string(this.bb_pos+n,e):null}REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.readInt8(this.bb_pos+e):zc.TEME}REFERENCE_FRAME_EPOCH(e){let n=this.bb.__offset(this.bb_pos,18);return n?this.bb.__string(this.bb_pos+n,e):null}TIME_SYSTEM(){let e=this.bb.__offset(this.bb_pos,20);return e?this.bb.readInt8(this.bb_pos+e):Fu.UTC}MEAN_ELEMENT_THEORY(){let e=this.bb.__offset(this.bb_pos,22);return e?this.bb.readInt8(this.bb_pos+e):fu.SGP4}COMMENT(e){let n=this.bb.__offset(this.bb_pos,24);return n?this.bb.__string(this.bb_pos+n,e):null}EPOCH(e){let n=this.bb.__offset(this.bb_pos,26);return n?this.bb.__string(this.bb_pos+n,e):null}SEMI_MAJOR_AXIS(){let e=this.bb.__offset(this.bb_pos,28);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION(){let e=this.bb.__offset(this.bb_pos,30);return e?this.bb.readFloat64(this.bb_pos+e):0}ECCENTRICITY(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readFloat64(this.bb_pos+e):0}INCLINATION(){let e=this.bb.__offset(this.bb_pos,34);return e?this.bb.readFloat64(this.bb_pos+e):0}RA_OF_ASC_NODE(){let e=this.bb.__offset(this.bb_pos,36);return e?this.bb.readFloat64(this.bb_pos+e):0}ARG_OF_PERICENTER(){let e=this.bb.__offset(this.bb_pos,38);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_ANOMALY(){let e=this.bb.__offset(this.bb_pos,40);return e?this.bb.readFloat64(this.bb_pos+e):0}GM(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}SOLAR_RAD_AREA(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readFloat64(this.bb_pos+e):0}SOLAR_RAD_COEFF(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.readFloat64(this.bb_pos+e):0}DRAG_AREA(){let e=this.bb.__offset(this.bb_pos,50);return e?this.bb.readFloat64(this.bb_pos+e):0}DRAG_COEFF(){let e=this.bb.__offset(this.bb_pos,52);return e?this.bb.readFloat64(this.bb_pos+e):0}EPHEMERIS_TYPE(){let e=this.bb.__offset(this.bb_pos,54);return e?this.bb.readInt8(this.bb_pos+e):dU.SGP4}CLASSIFICATION_TYPE(e){let n=this.bb.__offset(this.bb_pos,56);return n?this.bb.__string(this.bb_pos+n,e):null}NORAD_CAT_ID(){let e=this.bb.__offset(this.bb_pos,58);return e?this.bb.readUint32(this.bb_pos+e):0}ELEMENT_SET_NO(){let e=this.bb.__offset(this.bb_pos,60);return e?this.bb.readUint32(this.bb_pos+e):0}REV_AT_EPOCH(){let e=this.bb.__offset(this.bb_pos,62);return e?this.bb.readFloat64(this.bb_pos+e):0}BSTAR(){let e=this.bb.__offset(this.bb_pos,64);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION_DOT(){let e=this.bb.__offset(this.bb_pos,66);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION_DDOT(){let e=this.bb.__offset(this.bb_pos,68);return e?this.bb.readFloat64(this.bb_pos+e):0}COV_REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,70);return e?this.bb.readInt8(this.bb_pos+e):zc.RSW}CX_X(){let e=this.bb.__offset(this.bb_pos,72);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_X(){let e=this.bb.__offset(this.bb_pos,74);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_Y(){let e=this.bb.__offset(this.bb_pos,76);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_X(){let e=this.bb.__offset(this.bb_pos,78);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_Y(){let e=this.bb.__offset(this.bb_pos,80);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_Z(){let e=this.bb.__offset(this.bb_pos,82);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_X(){let e=this.bb.__offset(this.bb_pos,84);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_Y(){let e=this.bb.__offset(this.bb_pos,86);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_Z(){let e=this.bb.__offset(this.bb_pos,88);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,90);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_X(){let e=this.bb.__offset(this.bb_pos,92);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Y(){let e=this.bb.__offset(this.bb_pos,94);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Z(){let e=this.bb.__offset(this.bb_pos,96);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,98);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Y_DOT(){let e=this.bb.__offset(this.bb_pos,100);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_X(){let e=this.bb.__offset(this.bb_pos,102);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Y(){let e=this.bb.__offset(this.bb_pos,104);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Z(){let e=this.bb.__offset(this.bb_pos,106);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,108);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Y_DOT(){let e=this.bb.__offset(this.bb_pos,110);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Z_DOT(){let e=this.bb.__offset(this.bb_pos,112);return e?this.bb.readFloat64(this.bb_pos+e):0}USER_DEFINED_BIP_0044_TYPE(){let e=this.bb.__offset(this.bb_pos,114);return e?this.bb.readUint32(this.bb_pos+e):0}USER_DEFINED_OBJECT_DESIGNATOR(e){let n=this.bb.__offset(this.bb_pos,116);return n?this.bb.__string(this.bb_pos+n,e):null}USER_DEFINED_EARTH_MODEL(e){let n=this.bb.__offset(this.bb_pos,118);return n?this.bb.__string(this.bb_pos+n,e):null}USER_DEFINED_EPOCH_TIMESTAMP(){let e=this.bb.__offset(this.bb_pos,120);return e?this.bb.readFloat64(this.bb_pos+e):0}USER_DEFINED_MICROSECONDS(){let e=this.bb.__offset(this.bb_pos,122);return e?this.bb.readFloat64(this.bb_pos+e):0}static startOMM(e){e.startObject(60)}static addCcsdsOmmVers(e,n){e.addFieldFloat64(0,n,0)}static addCreationDate(e,n){e.addFieldOffset(1,n,0)}static addOriginator(e,n){e.addFieldOffset(2,n,0)}static addObjectName(e,n){e.addFieldOffset(3,n,0)}static addObjectId(e,n){e.addFieldOffset(4,n,0)}static addCenterName(e,n){e.addFieldOffset(5,n,0)}static addReferenceFrame(e,n){e.addFieldInt8(6,n,zc.TEME)}static addReferenceFrameEpoch(e,n){e.addFieldOffset(7,n,0)}static addTimeSystem(e,n){e.addFieldInt8(8,n,Fu.UTC)}static addMeanElementTheory(e,n){e.addFieldInt8(9,n,fu.SGP4)}static addComment(e,n){e.addFieldOffset(10,n,0)}static addEpoch(e,n){e.addFieldOffset(11,n,0)}static addSemiMajorAxis(e,n){e.addFieldFloat64(12,n,0)}static addMeanMotion(e,n){e.addFieldFloat64(13,n,0)}static addEccentricity(e,n){e.addFieldFloat64(14,n,0)}static addInclination(e,n){e.addFieldFloat64(15,n,0)}static addRaOfAscNode(e,n){e.addFieldFloat64(16,n,0)}static addArgOfPericenter(e,n){e.addFieldFloat64(17,n,0)}static addMeanAnomaly(e,n){e.addFieldFloat64(18,n,0)}static addGm(e,n){e.addFieldFloat64(19,n,0)}static addMass(e,n){e.addFieldFloat64(20,n,0)}static addSolarRadArea(e,n){e.addFieldFloat64(21,n,0)}static addSolarRadCoeff(e,n){e.addFieldFloat64(22,n,0)}static addDragArea(e,n){e.addFieldFloat64(23,n,0)}static addDragCoeff(e,n){e.addFieldFloat64(24,n,0)}static addEphemerisType(e,n){e.addFieldInt8(25,n,dU.SGP4)}static addClassificationType(e,n){e.addFieldOffset(26,n,0)}static addNoradCatId(e,n){e.addFieldInt32(27,n,0)}static addElementSetNo(e,n){e.addFieldInt32(28,n,0)}static addRevAtEpoch(e,n){e.addFieldFloat64(29,n,0)}static addBstar(e,n){e.addFieldFloat64(30,n,0)}static addMeanMotionDot(e,n){e.addFieldFloat64(31,n,0)}static addMeanMotionDdot(e,n){e.addFieldFloat64(32,n,0)}static addCovReferenceFrame(e,n){e.addFieldInt8(33,n,zc.RSW)}static addCxX(e,n){e.addFieldFloat64(34,n,0)}static addCyX(e,n){e.addFieldFloat64(35,n,0)}static addCyY(e,n){e.addFieldFloat64(36,n,0)}static addCzX(e,n){e.addFieldFloat64(37,n,0)}static addCzY(e,n){e.addFieldFloat64(38,n,0)}static addCzZ(e,n){e.addFieldFloat64(39,n,0)}static addCxDotX(e,n){e.addFieldFloat64(40,n,0)}static addCxDotY(e,n){e.addFieldFloat64(41,n,0)}static addCxDotZ(e,n){e.addFieldFloat64(42,n,0)}static addCxDotXDot(e,n){e.addFieldFloat64(43,n,0)}static addCyDotX(e,n){e.addFieldFloat64(44,n,0)}static addCyDotY(e,n){e.addFieldFloat64(45,n,0)}static addCyDotZ(e,n){e.addFieldFloat64(46,n,0)}static addCyDotXDot(e,n){e.addFieldFloat64(47,n,0)}static addCyDotYDot(e,n){e.addFieldFloat64(48,n,0)}static addCzDotX(e,n){e.addFieldFloat64(49,n,0)}static addCzDotY(e,n){e.addFieldFloat64(50,n,0)}static addCzDotZ(e,n){e.addFieldFloat64(51,n,0)}static addCzDotXDot(e,n){e.addFieldFloat64(52,n,0)}static addCzDotYDot(e,n){e.addFieldFloat64(53,n,0)}static addCzDotZDot(e,n){e.addFieldFloat64(54,n,0)}static addUserDefinedBip0044Type(e,n){e.addFieldInt32(55,n,0)}static addUserDefinedObjectDesignator(e,n){e.addFieldOffset(56,n,0)}static addUserDefinedEarthModel(e,n){e.addFieldOffset(57,n,0)}static addUserDefinedEpochTimestamp(e,n){e.addFieldFloat64(58,n,0)}static addUserDefinedMicroseconds(e,n){e.addFieldFloat64(59,n,0)}static endOMM(e){return e.endObject()}static finishOMMBuffer(e,n){e.finish(n,"$OMM")}static finishSizePrefixedOMMBuffer(e,n){e.finish(n,"$OMM",!0)}static createOMM(e,n,i,o,a,s,l,r,d,m,h,Z,b,u,F,U,G,A,T,g,C,y,Y,Q,J,M,V,E,I,B,X,_,P,w,z,H,nt,$,dt,q,at,st,Et,Qt,Wt,Nt,kt,Mt,qt,ie,oe,He,rn,de,zt,ke,ue,We,un,Ct,_t){return t.startOMM(e),t.addCcsdsOmmVers(e,n),t.addCreationDate(e,i),t.addOriginator(e,o),t.addObjectName(e,a),t.addObjectId(e,s),t.addCenterName(e,l),t.addReferenceFrame(e,r),t.addReferenceFrameEpoch(e,d),t.addTimeSystem(e,m),t.addMeanElementTheory(e,h),t.addComment(e,Z),t.addEpoch(e,b),t.addSemiMajorAxis(e,u),t.addMeanMotion(e,F),t.addEccentricity(e,U),t.addInclination(e,G),t.addRaOfAscNode(e,A),t.addArgOfPericenter(e,T),t.addMeanAnomaly(e,g),t.addGm(e,C),t.addMass(e,y),t.addSolarRadArea(e,Y),t.addSolarRadCoeff(e,Q),t.addDragArea(e,J),t.addDragCoeff(e,M),t.addEphemerisType(e,V),t.addClassificationType(e,E),t.addNoradCatId(e,I),t.addElementSetNo(e,B),t.addRevAtEpoch(e,X),t.addBstar(e,_),t.addMeanMotionDot(e,P),t.addMeanMotionDdot(e,w),t.addCovReferenceFrame(e,z),t.addCxX(e,H),t.addCyX(e,nt),t.addCyY(e,$),t.addCzX(e,dt),t.addCzY(e,q),t.addCzZ(e,at),t.addCxDotX(e,st),t.addCxDotY(e,Et),t.addCxDotZ(e,Qt),t.addCxDotXDot(e,Wt),t.addCyDotX(e,Nt),t.addCyDotY(e,kt),t.addCyDotZ(e,Mt),t.addCyDotXDot(e,qt),t.addCyDotYDot(e,ie),t.addCzDotX(e,oe),t.addCzDotY(e,He),t.addCzDotZ(e,rn),t.addCzDotXDot(e,de),t.addCzDotYDot(e,zt),t.addCzDotZDot(e,ke),t.addUserDefinedBip0044Type(e,ue),t.addUserDefinedObjectDesignator(e,We),t.addUserDefinedEarthModel(e,un),t.addUserDefinedEpochTimestamp(e,Ct),t.addUserDefinedMicroseconds(e,_t),t.endOMM(e)}unpack(){return new TM(this.CCSDS_OMM_VERS(),this.CREATION_DATE(),this.ORIGINATOR(),this.OBJECT_NAME(),this.OBJECT_ID(),this.CENTER_NAME(),this.REFERENCE_FRAME(),this.REFERENCE_FRAME_EPOCH(),this.TIME_SYSTEM(),this.MEAN_ELEMENT_THEORY(),this.COMMENT(),this.EPOCH(),this.SEMI_MAJOR_AXIS(),this.MEAN_MOTION(),this.ECCENTRICITY(),this.INCLINATION(),this.RA_OF_ASC_NODE(),this.ARG_OF_PERICENTER(),this.MEAN_ANOMALY(),this.GM(),this.MASS(),this.SOLAR_RAD_AREA(),this.SOLAR_RAD_COEFF(),this.DRAG_AREA(),this.DRAG_COEFF(),this.EPHEMERIS_TYPE(),this.CLASSIFICATION_TYPE(),this.NORAD_CAT_ID(),this.ELEMENT_SET_NO(),this.REV_AT_EPOCH(),this.BSTAR(),this.MEAN_MOTION_DOT(),this.MEAN_MOTION_DDOT(),this.COV_REFERENCE_FRAME(),this.CX_X(),this.CY_X(),this.CY_Y(),this.CZ_X(),this.CZ_Y(),this.CZ_Z(),this.CX_DOT_X(),this.CX_DOT_Y(),this.CX_DOT_Z(),this.CX_DOT_X_DOT(),this.CY_DOT_X(),this.CY_DOT_Y(),this.CY_DOT_Z(),this.CY_DOT_X_DOT(),this.CY_DOT_Y_DOT(),this.CZ_DOT_X(),this.CZ_DOT_Y(),this.CZ_DOT_Z(),this.CZ_DOT_X_DOT(),this.CZ_DOT_Y_DOT(),this.CZ_DOT_Z_DOT(),this.USER_DEFINED_BIP_0044_TYPE(),this.USER_DEFINED_OBJECT_DESIGNATOR(),this.USER_DEFINED_EARTH_MODEL(),this.USER_DEFINED_EPOCH_TIMESTAMP(),this.USER_DEFINED_MICROSECONDS())}unpackTo(e){e.CCSDS_OMM_VERS=this.CCSDS_OMM_VERS(),e.CREATION_DATE=this.CREATION_DATE(),e.ORIGINATOR=this.ORIGINATOR(),e.OBJECT_NAME=this.OBJECT_NAME(),e.OBJECT_ID=this.OBJECT_ID(),e.CENTER_NAME=this.CENTER_NAME(),e.REFERENCE_FRAME=this.REFERENCE_FRAME(),e.REFERENCE_FRAME_EPOCH=this.REFERENCE_FRAME_EPOCH(),e.TIME_SYSTEM=this.TIME_SYSTEM(),e.MEAN_ELEMENT_THEORY=this.MEAN_ELEMENT_THEORY(),e.COMMENT=this.COMMENT(),e.EPOCH=this.EPOCH(),e.SEMI_MAJOR_AXIS=this.SEMI_MAJOR_AXIS(),e.MEAN_MOTION=this.MEAN_MOTION(),e.ECCENTRICITY=this.ECCENTRICITY(),e.INCLINATION=this.INCLINATION(),e.RA_OF_ASC_NODE=this.RA_OF_ASC_NODE(),e.ARG_OF_PERICENTER=this.ARG_OF_PERICENTER(),e.MEAN_ANOMALY=this.MEAN_ANOMALY(),e.GM=this.GM(),e.MASS=this.MASS(),e.SOLAR_RAD_AREA=this.SOLAR_RAD_AREA(),e.SOLAR_RAD_COEFF=this.SOLAR_RAD_COEFF(),e.DRAG_AREA=this.DRAG_AREA(),e.DRAG_COEFF=this.DRAG_COEFF(),e.EPHEMERIS_TYPE=this.EPHEMERIS_TYPE(),e.CLASSIFICATION_TYPE=this.CLASSIFICATION_TYPE(),e.NORAD_CAT_ID=this.NORAD_CAT_ID(),e.ELEMENT_SET_NO=this.ELEMENT_SET_NO(),e.REV_AT_EPOCH=this.REV_AT_EPOCH(),e.BSTAR=this.BSTAR(),e.MEAN_MOTION_DOT=this.MEAN_MOTION_DOT(),e.MEAN_MOTION_DDOT=this.MEAN_MOTION_DDOT(),e.COV_REFERENCE_FRAME=this.COV_REFERENCE_FRAME(),e.CX_X=this.CX_X(),e.CY_X=this.CY_X(),e.CY_Y=this.CY_Y(),e.CZ_X=this.CZ_X(),e.CZ_Y=this.CZ_Y(),e.CZ_Z=this.CZ_Z(),e.CX_DOT_X=this.CX_DOT_X(),e.CX_DOT_Y=this.CX_DOT_Y(),e.CX_DOT_Z=this.CX_DOT_Z(),e.CX_DOT_X_DOT=this.CX_DOT_X_DOT(),e.CY_DOT_X=this.CY_DOT_X(),e.CY_DOT_Y=this.CY_DOT_Y(),e.CY_DOT_Z=this.CY_DOT_Z(),e.CY_DOT_X_DOT=this.CY_DOT_X_DOT(),e.CY_DOT_Y_DOT=this.CY_DOT_Y_DOT(),e.CZ_DOT_X=this.CZ_DOT_X(),e.CZ_DOT_Y=this.CZ_DOT_Y(),e.CZ_DOT_Z=this.CZ_DOT_Z(),e.CZ_DOT_X_DOT=this.CZ_DOT_X_DOT(),e.CZ_DOT_Y_DOT=this.CZ_DOT_Y_DOT(),e.CZ_DOT_Z_DOT=this.CZ_DOT_Z_DOT(),e.USER_DEFINED_BIP_0044_TYPE=this.USER_DEFINED_BIP_0044_TYPE(),e.USER_DEFINED_OBJECT_DESIGNATOR=this.USER_DEFINED_OBJECT_DESIGNATOR(),e.USER_DEFINED_EARTH_MODEL=this.USER_DEFINED_EARTH_MODEL(),e.USER_DEFINED_EPOCH_TIMESTAMP=this.USER_DEFINED_EPOCH_TIMESTAMP(),e.USER_DEFINED_MICROSECONDS=this.USER_DEFINED_MICROSECONDS()}},TM=class{constructor(e=0,n=null,i=null,o=null,a=null,s=null,l=zc.TEME,r=null,d=Fu.UTC,m=fu.SGP4,h=null,Z=null,b=0,u=0,F=0,U=0,G=0,A=0,T=0,g=0,C=0,y=0,Y=0,Q=0,J=0,M=dU.SGP4,V=null,E=0,I=0,B=0,X=0,_=0,P=0,w=zc.RSW,z=0,H=0,nt=0,$=0,dt=0,q=0,at=0,st=0,Et=0,Qt=0,Wt=0,Nt=0,kt=0,Mt=0,qt=0,ie=0,oe=0,He=0,rn=0,de=0,zt=0,ke=0,ue=null,We=null,un=0,Ct=0){this.CCSDS_OMM_VERS=e,this.CREATION_DATE=n,this.ORIGINATOR=i,this.OBJECT_NAME=o,this.OBJECT_ID=a,this.CENTER_NAME=s,this.REFERENCE_FRAME=l,this.REFERENCE_FRAME_EPOCH=r,this.TIME_SYSTEM=d,this.MEAN_ELEMENT_THEORY=m,this.COMMENT=h,this.EPOCH=Z,this.SEMI_MAJOR_AXIS=b,this.MEAN_MOTION=u,this.ECCENTRICITY=F,this.INCLINATION=U,this.RA_OF_ASC_NODE=G,this.ARG_OF_PERICENTER=A,this.MEAN_ANOMALY=T,this.GM=g,this.MASS=C,this.SOLAR_RAD_AREA=y,this.SOLAR_RAD_COEFF=Y,this.DRAG_AREA=Q,this.DRAG_COEFF=J,this.EPHEMERIS_TYPE=M,this.CLASSIFICATION_TYPE=V,this.NORAD_CAT_ID=E,this.ELEMENT_SET_NO=I,this.REV_AT_EPOCH=B,this.BSTAR=X,this.MEAN_MOTION_DOT=_,this.MEAN_MOTION_DDOT=P,this.COV_REFERENCE_FRAME=w,this.CX_X=z,this.CY_X=H,this.CY_Y=nt,this.CZ_X=$,this.CZ_Y=dt,this.CZ_Z=q,this.CX_DOT_X=at,this.CX_DOT_Y=st,this.CX_DOT_Z=Et,this.CX_DOT_X_DOT=Qt,this.CY_DOT_X=Wt,this.CY_DOT_Y=Nt,this.CY_DOT_Z=kt,this.CY_DOT_X_DOT=Mt,this.CY_DOT_Y_DOT=qt,this.CZ_DOT_X=ie,this.CZ_DOT_Y=oe,this.CZ_DOT_Z=He,this.CZ_DOT_X_DOT=rn,this.CZ_DOT_Y_DOT=de,this.CZ_DOT_Z_DOT=zt,this.USER_DEFINED_BIP_0044_TYPE=ke,this.USER_DEFINED_OBJECT_DESIGNATOR=ue,this.USER_DEFINED_EARTH_MODEL=We,this.USER_DEFINED_EPOCH_TIMESTAMP=un,this.USER_DEFINED_MICROSECONDS=Ct}pack(e){let n=this.CREATION_DATE!==null?e.createString(this.CREATION_DATE):0,i=this.ORIGINATOR!==null?e.createString(this.ORIGINATOR):0,o=this.OBJECT_NAME!==null?e.createString(this.OBJECT_NAME):0,a=this.OBJECT_ID!==null?e.createString(this.OBJECT_ID):0,s=this.CENTER_NAME!==null?e.createString(this.CENTER_NAME):0,l=this.REFERENCE_FRAME_EPOCH!==null?e.createString(this.REFERENCE_FRAME_EPOCH):0,r=this.COMMENT!==null?e.createString(this.COMMENT):0,d=this.EPOCH!==null?e.createString(this.EPOCH):0,m=this.CLASSIFICATION_TYPE!==null?e.createString(this.CLASSIFICATION_TYPE):0,h=this.USER_DEFINED_OBJECT_DESIGNATOR!==null?e.createString(this.USER_DEFINED_OBJECT_DESIGNATOR):0,Z=this.USER_DEFINED_EARTH_MODEL!==null?e.createString(this.USER_DEFINED_EARTH_MODEL):0;return eS.createOMM(e,this.CCSDS_OMM_VERS,n,i,o,a,s,this.REFERENCE_FRAME,l,this.TIME_SYSTEM,this.MEAN_ELEMENT_THEORY,r,d,this.SEMI_MAJOR_AXIS,this.MEAN_MOTION,this.ECCENTRICITY,this.INCLINATION,this.RA_OF_ASC_NODE,this.ARG_OF_PERICENTER,this.MEAN_ANOMALY,this.GM,this.MASS,this.SOLAR_RAD_AREA,this.SOLAR_RAD_COEFF,this.DRAG_AREA,this.DRAG_COEFF,this.EPHEMERIS_TYPE,m,this.NORAD_CAT_ID,this.ELEMENT_SET_NO,this.REV_AT_EPOCH,this.BSTAR,this.MEAN_MOTION_DOT,this.MEAN_MOTION_DDOT,this.COV_REFERENCE_FRAME,this.CX_X,this.CY_X,this.CY_Y,this.CZ_X,this.CZ_Y,this.CZ_Z,this.CX_DOT_X,this.CX_DOT_Y,this.CX_DOT_Z,this.CX_DOT_X_DOT,this.CY_DOT_X,this.CY_DOT_Y,this.CY_DOT_Z,this.CY_DOT_X_DOT,this.CY_DOT_Y_DOT,this.CZ_DOT_X,this.CZ_DOT_Y,this.CZ_DOT_Z,this.CZ_DOT_X_DOT,this.CZ_DOT_Y_DOT,this.CZ_DOT_Z_DOT,this.USER_DEFINED_BIP_0044_TYPE,h,Z,this.USER_DEFINED_EPOCH_TIMESTAMP,this.USER_DEFINED_MICROSECONDS)}};var Gqi=R(W(),1);var h1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsOMMCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsOMMCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new eS).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startOMMCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endOMMCOLLECTION(e){return e.endObject()}static createOMMCOLLECTION(e,n){return t.startOMMCOLLECTION(e),t.addRecords(e,n),t.endOMMCOLLECTION(e)}unpack(){return new SM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},SM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=h1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return h1.createOMMCOLLECTION(e,n)}};var Sqi=R(W(),1);var nS=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsRFM(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsRFM(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$RFM")}REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):zc.ECEF}static startRFM(e){e.startObject(1)}static addReferenceFrame(e,n){e.addFieldInt8(0,n,zc.ECEF)}static endRFM(e){return e.endObject()}static finishRFMBuffer(e,n){e.finish(n,"$RFM")}static finishSizePrefixedRFMBuffer(e,n){e.finish(n,"$RFM",!0)}static createRFM(e,n){return t.startRFM(e),t.addReferenceFrame(e,n),t.endRFM(e)}unpack(){return new gM(this.REFERENCE_FRAME())}unpackTo(e){e.REFERENCE_FRAME=this.REFERENCE_FRAME()}},gM=class{constructor(e=zc.ECEF){this.REFERENCE_FRAME=e}pack(e){return nS.createRFM(e,this.REFERENCE_FRAME)}};var Cqi=R(W(),1);var p1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsRFMCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsRFMCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new nS).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startRFMCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endRFMCOLLECTION(e){return e.endObject()}static createRFMCOLLECTION(e,n){return t.startRFMCOLLECTION(e),t.addRecords(e,n),t.endRFMCOLLECTION(e)}unpack(){return new EM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},EM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=p1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return p1.createRFMCOLLECTION(e,n)}};var yqi=R(W(),1);var iS=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsTIM(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsTIM(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$TIM")}TIME_SYSTEM(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):Fu.GMST}static startTIM(e){e.startObject(1)}static addTimeSystem(e,n){e.addFieldInt8(0,n,Fu.GMST)}static endTIM(e){return e.endObject()}static finishTIMBuffer(e,n){e.finish(n,"$TIM")}static finishSizePrefixedTIMBuffer(e,n){e.finish(n,"$TIM",!0)}static createTIM(e,n){return t.startTIM(e),t.addTimeSystem(e,n),t.endTIM(e)}unpack(){return new CM(this.TIME_SYSTEM())}unpackTo(e){e.TIME_SYSTEM=this.TIME_SYSTEM()}},CM=class{constructor(e=Fu.GMST){this.TIME_SYSTEM=e}pack(e){return iS.createTIM(e,this.TIME_SYSTEM)}};var kqi=R(W(),1);var u1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsTIMCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsTIMCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new iS).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startTIMCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endTIMCOLLECTION(e){return e.endObject()}static createTIMCOLLECTION(e,n){return t.startTIMCOLLECTION(e),t.addRecords(e,n),t.endTIMCOLLECTION(e)}unpack(){return new IM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},IM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=u1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return u1.createTIMCOLLECTION(e,n)}};var i$i=R(W(),1);var zqi=R(W(),1);var $qi=R(W(),1);var v$i=R(W(),1);var c$i=R(W(),1);var l$i=R(W(),1);var h$i=R(W(),1),I3;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(I3||(I3={}));var u$i=R(W(),1),N3;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(N3||(N3={}));var C$i=R(W(),1);var V$i=R(W(),1),y3;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(y3||(y3={}));var R$i=R(W(),1),B3;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(B3||(B3={}));var f$i=R(W(),1);var y$i=R(W(),1);var k$i=R(W(),1);var X$i=R(W(),1);var uto=R(W(),1);var lto=R(W(),1);var cto=R(W(),1);var Cto=R(W(),1);var Fto=R(W(),1);var Rto=R(W(),1);var Ato=R(W(),1);var oro=R(W(),1);var Qto=R(W(),1);var Yto=R(W(),1);var Jto=R(W(),1);var Oto=R(W(),1);var Mto=R(W(),1);var Ieo=R(W(),1);var heo=R(W(),1);var deo=R(W(),1);var wto=R(W(),1),Q3;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(Q3||(Q3={}));var vto=R(W(),1),k3;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(k3||(k3={}));var zto=R(W(),1),Y3;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(Y3||(Y3={}));var qto=R(W(),1),x3;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(x3||(x3={}));var teo=R(W(),1);var ueo=R(W(),1),J3;(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(J3||(J3={}));var Veo=R(W(),1),L3;(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(L3||(L3={}));var Reo=R(W(),1),M3;(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(M3||(M3={}));var feo=R(W(),1),_3;(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(_3||(_3={}));var Ueo=R(W(),1),D3;(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(D3||(D3={}));var Beo=R(W(),1);var rno=R(W(),1);var qeo=R(W(),1);var _eo=R(W(),1);var Xeo=R(W(),1);var keo=R(W(),1),O3;(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(O3||(O3={}));var Oeo=R(W(),1),H3;(function(t){t[t.CALCULATED=0]="CALCULATED",t[t.DEFAULT=1]="DEFAULT"})(H3||(H3={}));var weo=R(W(),1),$Z;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})($Z||($Z={}));var tno=R(W(),1);var nno=R(W(),1),P3;(function(t){t[t.ELLIPSOID=0]="ELLIPSOID",t[t.BOX=1]="BOX"})(P3||(P3={}));var mno=R(W(),1);var pno=R(W(),1);var Vno=R(W(),1);var Wno=R(W(),1);var Uno=R(W(),1);var Ano=R(W(),1);var gno=R(W(),1);var Cno=R(W(),1),v3;(function(t){t[t.OBSERVED=0]="OBSERVED",t[t.PREDICTED=1]="PREDICTED"})(v3||(v3={}));var Nno=R(W(),1);var Qno=R(W(),1);var Jno=R(W(),1);var Yno=R(W(),1),K3;(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(K3||(K3={}));var _no=R(W(),1);var Hno=R(W(),1);var vno=R(W(),1);var jno=R(W(),1);var tio=R(W(),1);var nio=R(W(),1);var cio=R(W(),1);var lio=R(W(),1);var oio=R(W(),1),z3;(function(t){t[t.OUTLIER=0]="OUTLIER"})(z3||(z3={}));var pio=R(W(),1);var Vio=R(W(),1);var Jio=R(W(),1);var Tio=R(W(),1);var Wio=R(W(),1);var Fio=R(W(),1);var yio=R(W(),1);var gio=R(W(),1),j3;(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(j3||(j3={}));var _io=R(W(),1);var Pio=R(W(),1);var Oio=R(W(),1),Z1;(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(Z1||(Z1={}));var zio=R(W(),1);var $io=R(W(),1);var noo=R(W(),1);var Roo=R(W(),1);var Zoo=R(W(),1);var aoo=R(W(),1);var loo=R(W(),1);var doo=R(W(),1),V1;(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(V1||(V1={}));var Foo=R(W(),1);var Coo=R(W(),1);var Goo=R(W(),1),q3;(function(t){t[t.SGP=0]="SGP",t[t.SGP4=1]="SGP4",t[t.SDP4=2]="SDP4",t[t.SGP8=3]="SGP8",t[t.SDP8=4]="SDP8"})(q3||(q3={}));var yoo=R(W(),1);var Qoo=R(W(),1);var xoo=R(W(),1);var Loo=R(W(),1);var Doo=R(W(),1);var voo=R(W(),1);var Hoo=R(W(),1);var joo=R(W(),1);var Pao=R(W(),1);var Oao=R(W(),1);var Lao=R(W(),1);var tao=R(W(),1);var aao=R(W(),1);var nao=R(W(),1);var rao=R(W(),1);var mao=R(W(),1);var $3;(function(t){t[t.NONE=0]="NONE",t[t.MPE=1]="MPE",t[t.OMM=2]="OMM",t[t.PLD=3]="PLD",t[t.RFM=4]="RFM",t[t.CSM=5]="CSM",t[t.OSM=6]="OSM",t[t.CAT=7]="CAT",t[t.CRM=8]="CRM",t[t.SCM=9]="SCM",t[t.TDM=10]="TDM",t[t.IDM=11]="IDM",t[t.MET=12]="MET",t[t.ROC=13]="ROC",t[t.BOV=14]="BOV",t[t.EOP=15]="EOP",t[t.EOO=16]="EOO",t[t.EME=17]="EME",t[t.LDM=18]="LDM",t[t.PNM=19]="PNM",t[t.HYP=20]="HYP",t[t.CTR=21]="CTR",t[t.CDM=22]="CDM",t[t.SIT=23]="SIT",t[t.OEM=24]="OEM",t[t.TIM=25]="TIM",t[t.EPM=26]="EPM",t[t.PRG=27]="PRG"})($3||($3={}));var zao=R(W(),1);var $ao=R(W(),1);var nso=R(W(),1);var aso=R(W(),1);var rso=R(W(),1);var mso=R(W(),1);var eco=R(W(),1);var vdo=R(W(),1);var Hdo=R(W(),1),tz;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(tz||(tz={}));var jdo=R(W(),1);var Eco=R(W(),1);var dco=R(W(),1);var sco=R(W(),1),ez;(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(ez||(ez={}));var Rco=R(W(),1);var hco=R(W(),1);var uco=R(W(),1);var Fco=R(W(),1);var Pco=R(W(),1);var Yco=R(W(),1);var Jco=R(W(),1);var _co=R(W(),1);var wmo=R(W(),1);var emo=R(W(),1);var qco=R(W(),1);var imo=R(W(),1),nz;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(nz||(nz={}));var amo=R(W(),1),iz;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(iz||(iz={}));var lmo=R(W(),1);var Umo=R(W(),1);var dmo=R(W(),1),oz;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(oz||(oz={}));var mmo=R(W(),1),az;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(az||(az={}));var pmo=R(W(),1);var Tmo=R(W(),1);var ymo=R(W(),1);var gmo=R(W(),1),sz;(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(sz||(sz={}));var kmo=R(W(),1);var Sho=R(W(),1);var cho=R(W(),1);var lho=R(W(),1),yM;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(yM||(yM={}));var pho=R(W(),1);var Vho=R(W(),1);var Who=R(W(),1);var Dho=R(W(),1);var Yho=R(W(),1);var Bho=R(W(),1),lz;(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(lz||(lz={}));var Jho=R(W(),1);var{OMMT:VSe,OMMCOLLECTIONT:apo}=sW,{CATT:bSe,CATCOLLECTIONT:spo}=aW;Number.prototype.map=function(t,e,n,i){return(this-t)*(i-n)/(e-t)+n};var oS=class extends qa{constructor(e,n,i,o){super(e),this.constructor.prototype.wasmSchema={},this._position=new Bs,this._spaceCatalog=i,this._wasmModule=n,this._velocity={getValue:(a,s)=>this._velocity.getValueInReferenceFrame(a,0,s),getValueInReferenceFrame:(a,s,l)=>{let r=new Float64Array(n.HEAP8.buffer,i.getVelocity(this.properties.wasmSpaceEntity,rt.toDate(a).getTime(),s!==ri.TEME),3);if(c(l)||(l=new p),l=p.fromArray(r),s===ri.INERTIAL){let d=Pe.computeFixedToIcrfMatrix(a);if(c(d)){let m=new p;ot.multiplyByVector(d,l,m),l=m}}return l}},Object.defineProperty(this,"velocity",{get:()=>this._velocity,set:()=>{}}),Object.defineProperties(this._position,{isConstant:{get:()=>!1},_referenceFrame:{get:()=>this.entityCollection.referenceFrame},referenceFrame:{get:()=>this._referenceFrame}}),this._position.getValue=(a,s)=>this._position.getValueInReferenceFrame(a,0,s),this._position.getValueInReferenceFrame=(a,s,l)=>{let r=new Float64Array(n.HEAP8.buffer,i.getPositionInReferenceFrame(this.properties.wasmSpaceEntity,rt.toDate(a).getTime(),s!==ri.TEME),3);if(c(l)||(l=new p),l=p.fromArray(r),s===ri.INERTIAL){let d=Pe.computeFixedToIcrfMatrix(a);if(c(d)){let m=new p;ot.multiplyByVector(d,l,m),l=m}}return l},this.children={add:a=>(a=this.entityCollection.add(a),this.entityCollection.allValues||(Object.defineProperty(this.entityCollection,"allValues",{get:function(){return this._entities.values}}),Object.defineProperty(this.entityCollection,"values",{get:function(){return this._entities.values.filter(s=>!s._isChild)}})),a._isChild=!0,a.parent=this,a.position=this.position,a),remove:a=>{this.entityCollection.remove(a);let s=this._children.indexOf(this);this._children.splice(s,1)},values:this._children},this.loadOMM(o)}loadOMM(e){let n=new this._wasmModule.PropagatedPositionProperty;n.addOMM(e),this.properties.wasmSpaceEntity=n,this.properties.CAT=this.properties._CAT||new bSe,this.properties._CAT._value.APOGEE=n.apogee,this.properties._CAT._value.PERIGEE=n.perigee,this.properties._CAT._value.PERIOD=n.period_sec,this.properties.OMM=this.properties._OMM||new VSe,this.properties._OMM._value.ECCENTRICITY=n.ecco,this.properties._OMM._value.SEMI_MAJOR_AXIS=n.semi_major_axis/1e3,this.properties._OMM._value.SEMI_MINOR_AXIS=n.semi_minor_axis/1e3,this.array_index=this.properties.wasmSpaceEntity.array_index,this.samplesPerPeriod=180,this.extraEpochSamples=60,this.resolutionAtEpoch=5,this.autoEpochResolution=!0,this.epochBlockSize=.5,this.extraSamples=5,this.eccentricityThreshold=.2,this.targetIntervalCount=20,this._orbitShowing=!1,this._coverageShowing=!1,this.referenceFrame=ri.RIC,this._position._clearCache=!0}get orbitShowing(){return this._orbitShowing}get coverageShowing(){return this._coverageShowing}showCoverage(e={show:!1}){this._coverageShowing=e.show,e.show?this.entityCollection.owner._coverageGroup.push(this):this.entityCollection.owner._coverageGroup.remove({id:this.id})}showOrbit(e={show:!1}){if(this._orbitShowing=e.show,!e.show){this.path=null;return}e&&(e.color=e.material),e?.referenceEntity?this._localReferenceEntity=e.referenceEntity:this._localReferenceEntity=void 0,this.path=this.path||{};let{material:n,width:i,leadTime:o,trailTime:a,resolution:s}=this.path;this.path=Object.assign({},{material:n||v.WHITE,width:i||1.25,leadTime:o||5e3,trailTime:a||5e3,resolution:s||120,show:!0},e);let{ecco:l,period_sec:r}=this.properties.wasmSpaceEntity,d=l{a.filter(l=>l.properties?.pointer).forEach(l=>{this._wasmModule.removeEntity(l.properties.pointer)}),this._entityCollection.referenceFrame=this._viewer?.scene.referenceFrame||this._entityCollection.referenceFrame};this._entityCollection.collectionChanged.addEventListener(n,this),this._orbits={[Co.LEO]:[],[Co.MEO]:[],[Co.HEO]:[],[Co.GEO]:[],[Co.IGO]:[],[Co.EGO]:[],[Co.GEOIADC]:[],[Co.GEOSYNC]:[],[Co.SUNSYNC]:[],[Co.SEMISYNC]:[],[Co.POLAR]:[],[Co.UNKNOWN]:[]}}onAdd(e){~e.getByName(this._coverageGroup.name).length&&e.add(this._coverageGroup)}onRemove(e){e.getByName(this._coverageGroup.name).length&&e.remove(this._coverageGroup)}async load(e){return await this.loadOMM(e,"tle")}loadOMM(e,n,i=!1){if(!e)throw new Ut('The parameter "omm" is required.');if(!n)throw new Ut('The parameter "satcat" is required.');return new Promise(async o=>{let a=await K0.initInstance();if(this._wasmModule=a.wasmModule,this._coverageGroup=this._coverageGroup||new SJ({samples:72,sdc:this,coverageType:1,angle:90,groundCoverageOnly:!1,color:v.LIMEGREEN.withAlpha(.5)}),this.entities.suspendEvents(),this._wasmSatelliteCatalog=this._wasmSatelliteCatalog||a.instance,(e instanceof ArrayBuffer||e instanceof Uint8Array)&&(e instanceof ArrayBuffer&&(e=new Uint8Array(e)),this.OMM=a1(e,"OMM",sW)),(e.RECORDS||Array.isArray(e))&&(this.OMM={RECORDS:e?.RECORDS||e}),!this.OMM)throw Error("OMMCOLLECTIONT invalid");let s=[];this.CAT=new RSe,(n instanceof ArrayBuffer||e instanceof Uint8Array)&&(n instanceof ArrayBuffer&&(n=new Uint8Array(n)),this.CATRAW=a1(n,"CAT",aW)),(n.RECORDS||Array.isArray(n))&&(this.CATRAW={RECORDS:n?.RECORDS||n});for(let l=0;l{t.toBlob(function(a){e._files[n]=a,o()})});return this._promises.push(i),n}return""};function USe(t,e){return function(n){t._files[e]=n}}rz.prototype.model=function(t,e){let n=this._modelCallback;if(!c(n))throw new St("Encountered a model entity while exporting to KML, but no model callback was supplied.");let i={},o=n(t,e,i);for(let a in i)if(i.hasOwnProperty(a)){let s=Promise.resolve(i[a]);this._promises.push(s),s.then(USe(this,a))}return o};Object.defineProperties(rz.prototype,{promise:{get:function(){return Promise.all(this._promises)}},files:{get:function(){return this._files}}});function dz(t){this._time=t}dz.prototype.get=function(t,e,n){let i;return c(t)&&(i=c(t.getValue)?t.getValue(this._time,n):t),f(i,e)};dz.prototype.getColor=function(t,e){let n=this.get(t,e);if(c(n))return sS(n)};dz.prototype.getMaterialType=function(t){if(c(t))return t.getType(this._time)};function Wot(){this._ids={},this._styles={},this._count=0}Wot.prototype.get=function(t){let e=this._ids,n=t.innerHTML;if(c(e[n]))return e[n];let i=`style-${++this._count}`;return t.setAttribute("id",i),i=`#${i}`,e[n]=i,this._styles[n]=t,i};Wot.prototype.save=function(t){let e=this._styles,n=t.childNodes[0];for(let i in e)e.hasOwnProperty(i)&&t.insertBefore(e[i],n)};function qIt(){this._ids={}}qIt.prototype.get=function(t){if(!c(t))return this.get(Si());let e=this._ids;return c(e[t])?`${t.toString()}-${++e[t]}`:(e[t]=0,t)};function fot(t){t=f(t,f.EMPTY_OBJECT);let e=t.entities,n=f(t.kmz,!1),i=fot._createState(t),o=e.values.filter(function(d){return!c(d.parent)}),a=i.kmlDoc,s=a.documentElement;s.setAttributeNS(fSe,"xmlns:gx",eV);let l=a.createElement("Document");s.appendChild(l),t1t(i,l,o),i.styleCache.save(l);let r=i.externalFileHandler;return r.promise.then(function(){let m=new XMLSerializer().serializeToString(i.kmlDoc);return n?GSe(m,r.files):{kml:m,externalFiles:r.files}})}function GSe(t,e){let n=Dn("ThirdParty/Workers/z-worker-pako.js");QI({workerScripts:{deflate:[n,"./pako_deflate.min.js"],inflate:[n,"./pako_inflate.min.js"]}});let i=new HL,o=new VK(i);return o.add("doc.kml",new $v(t)).then(function(){let a=Object.keys(e);return $It(o,a,e,0)}).then(function(){return o.close()}).then(function(a){return{kmz:a}})}function $It(t,e,n,i){if(e.length===i)return;let o=e[i];return t.add(o,new iW(n[o])).then(function(){return $It(t,e,n,i+1)})}fot._createState=function(t){let e=t.entities,n=new Wot,i=e.computeAvailability(),o=c(t.time)?t.time:i.start,a=f(t.defaultAvailability,i),s=f(t.sampleDuration,60);a.start===Re.MINIMUM_VALUE?a.stop===Re.MAXIMUM_VALUE?a=new ai:rt.addSeconds(a.stop,-10*s,a.start):a.stop===Re.MAXIMUM_VALUE&&rt.addSeconds(a.start,10*s,a.stop);let l=new rz(t.modelCallback);return{kmlDoc:document.implementation.createDocument(WSe,"kml"),ellipsoid:f(t.ellipsoid,mt.WGS84),idManager:new qIt,styleCache:n,externalFileHandler:l,time:o,valueGetter:new dz(o),sampleDuration:s,defaultAvailability:new ys([a])}};function t1t(t,e,n){let i=t.kmlDoc,o=t.styleCache,a=t.valueGetter,s=t.idManager,l=n.length,r,d,m;for(let h=0;h0){let G=i.createElement("Placemark");G.setAttribute("id",s.get(Z.id));let A=Z.name,T=Z.label;if(c(T)){let C=i.createElement("LabelStyle"),y=a.get(T.text);A=c(y)&&y.length>0?y:A;let Y=a.getColor(T.fillColor);c(Y)&&(C.appendChild(ii(i,"color",Y)),C.appendChild(ii(i,"colorMode","normal")));let Q=a.get(T.scale);c(Q)&&C.appendChild(ii(i,"scale",Q)),m.push(C)}G.appendChild(ii(i,"name",A)),G.appendChild(ii(i,"visibility",Z.show)),G.appendChild(ii(i,"description",Z.description)),c(b)&&G.appendChild(b),e.appendChild(G);let g=m.length;if(g>0){let C=i.createElement("Style");for(let y=0;y1){let C=i.createElement("MultiGeometry");for(let y=0;y0){let G=i.createElement("Folder");G.setAttribute("id",s.get(Z.id)),G.appendChild(ii(i,"name",Z.name)),G.appendChild(ii(i,"visibility",Z.show)),G.appendChild(ii(i,"description",Z.description)),e.appendChild(G),t1t(t,G,U)}}}var qm=new p,jc=new gt,tV=new rt;function ASe(t,e,n,i){let o=t.kmlDoc,a=t.ellipsoid,s=t.valueGetter,l=f(e.billboard,e.point);if(!c(l)&&!c(e.path))return;let r=e.position;if(!r.isConstant){e1t(t,e,l,n,i);return}s.get(r,void 0,qm);let d=ii(o,"coordinates",aS(qm,a)),m=o.createElement("Point"),h=o.createElement("altitudeMode");h.appendChild(lS(t,l.heightReference)),m.appendChild(h),m.appendChild(d),n.push(m);let Z=l instanceof Mr?i1t(t,l):n1t(t,l);i.push(Z)}function e1t(t,e,n,i,o){let a=t.kmlDoc,s=t.ellipsoid,l=t.valueGetter,r,d=e.position,m=!0;d instanceof cl?(r=d.intervals,m=!1):r=f(e.availability,t.defaultAvailability);let h=n instanceof JR,Z,b,u,F=[];for(Z=0;Z1){let G=a.createElementNS(eV,"MultiTrack");for(Z=0;Z0&&(a=n);let s=e.coordinates,l=o.get(s),r=[],d=[Gt.northeast,Gt.southeast,Gt.southwest,Gt.northwest];for(let b=0;b<4;++b)d[b](l,jc),r.push(`${k.toDegrees(jc.longitude)},${k.toDegrees(jc.latitude)},${a}`);let m=ii(i,"coordinates",r.join(" ")),h=i.createElement("outerBoundaryIs"),Z=i.createElement("LinearRing");return Z.appendChild(m),h.appendChild(Z),[h]}function zIt(t,e,n,i){let o=t.kmlDoc,a=t.ellipsoid,s=[],l=e.length;for(let m=0;m0&&(a=n);let l=[],r=e.hierarchy,d=o.get(r),m=Array.isArray(d)?d:d.positions,h=i.createElement("outerBoundaryIs");h.appendChild(zIt(t,m,a,s)),l.push(h);let Z=d.holes;if(c(Z)){let b=Z.length;for(let u=0;u0&&r.appendChild(ii(a,"extrude",!0));let m=l?SSe(t,e,d):gSe(t,e,d),h=m.length;for(let U=0;U=0;--i)e+=n[i]<16?`0${n[i].toString(16)}`:n[i].toString(16);return e}var Uot=fot;var cuo=R(W(),1),Got="";var W9o=R(W(),1);var puo=R(W(),1);function ISe(t){let e,n=t.name,i=t.message;c(n)&&c(i)?e=`${n}: ${i}`:e=t.toString();let o=t.stack;return c(o)&&(e+=` -${o}`),e}var Qb=ISe;var ZGo=R(W(),1);var IZo=R(W(),1);var FZo=R(W(),1);var Zuo=R(W(),1),NSe={NONE:0,LERC:1},Uu=Object.freeze(NSe);var wuo=R(W(),1);var Cuo=R(W(),1);var buo=R(W(),1),ySe={NONE:0,BITS12:1},yr=Object.freeze(ySe);var rS=new p,BSe=new p,Gu=new K,cz=new L,QSe=new L,kSe=Math.pow(2,12);function sc(t,e,n,i,o,a,s,l,r,d){let m=yr.NONE,h,Z;if(c(e)&&c(n)&&c(i)&&c(o)){let b=e.minimum,u=e.maximum,F=p.subtract(u,b,BSe),U=i-n;Math.max(p.maximumComponent(F),U)0,b=f(t.isGeographic,!0),u=f(t.ellipsoid,mt.WGS84),F=1/u.maximumRadius,U=Gt.clone(t.nativeRectangle),G=Gt.clone(t.rectangle),A,T,g,C;c(G)?(A=G.west,T=G.south,g=G.east,C=G.north):b?(A=l(U.west),T=l(U.south),g=l(U.east),C=l(U.north)):(A=U.west*F,T=s-2*o(a(-U.south*F)),g=U.east*F,C=s-2*o(a(-U.north*F)));let y=t.relativeToCenter,Y=c(y);y=Y?y:p.ZERO;let Q=f(t.includeWebMercatorT,!1),J=f(t.exaggeration,1),M=f(t.exaggerationRelativeHeight,0),E=J!==1,I=f(t.structure,kb.DEFAULT_STRUCTURE),B=f(I.heightScale,kb.DEFAULT_STRUCTURE.heightScale),X=f(I.heightOffset,kb.DEFAULT_STRUCTURE.heightOffset),_=f(I.elementsPerHeight,kb.DEFAULT_STRUCTURE.elementsPerHeight),P=f(I.stride,kb.DEFAULT_STRUCTURE.stride),w=f(I.elementMultiplier,kb.DEFAULT_STRUCTURE.elementMultiplier),z=f(I.isBigEndian,kb.DEFAULT_STRUCTURE.isBigEndian),H=Gt.computeWidth(U),nt=Gt.computeHeight(U),$=H/(d-1),dt=nt/(m-1);b||(H*=F,nt*=F);let q=u.radiiSquared,at=q.x,st=q.y,Et=q.z,Qt=65536,Wt=-65536,Nt=Pe.eastNorthUpToFixedFrame(y,u),kt=L.inverseTransformation(Nt,xSe),Mt,qt;Q&&(Mt=Yo.geodeticLatitudeToMercatorAngle(T),qt=1/(Yo.geodeticLatitudeToMercatorAngle(C)-Mt));let ie=XSe;ie.x=Number.POSITIVE_INFINITY,ie.y=Number.POSITIVE_INFINITY,ie.z=Number.POSITIVE_INFINITY;let oe=JSe;oe.x=Number.NEGATIVE_INFINITY,oe.y=Number.NEGATIVE_INFINITY,oe.z=Number.NEGATIVE_INFINITY;let He=Number.POSITIVE_INFINITY,rn=d*m,de=h>0?d*2+m*2:0,zt=rn+de,ke=new Array(zt),ue=new Array(zt),We=new Array(zt),un=Q?new Array(zt):[],Ct=E?new Array(zt):[],_t=0,Je=m,xe=0,oo=d;Z&&(--_t,++Je,--xe,++oo);let ea=1e-5;for(let Ze=_t;Ze=m&&(Ke=m-1);let An=U.north-dt*Ke;b?An=l(An):An=s-2*o(a(-An*F));let si=(An-T)/(C-T);si=k.clamp(si,0,1);let da=Ze===_t,_a=Ze===Je-1;h>0&&(da?An+=ea*nt:_a&&(An-=ea*nt));let bl=e(An),na=n(An),Go=Et*na,Ao;Q&&(Ao=(Yo.geodeticLatitudeToMercatorAngle(An)-Mt)*qt);for(let Xs=xe;Xs=d&&(Es=d-1);let wl=Ke*(d*P)+Es*P,ka;if(_===1)ka=r[wl];else{ka=0;let ma;if(z)for(ma=0;ma<_;++ma)ka=ka*w+r[wl+ma];else for(ma=_-1;ma>=0;--ma)ka=ka*w+r[wl+ma]}ka=ka*B+X,Wt=Math.max(Wt,ka),Qt=Math.min(Qt,ka);let Wa=U.west+$*Es;b?Wa=l(Wa):Wa=Wa*F;let Ju=(Wa-A)/(g-A);Ju=k.clamp(Ju,0,1);let yl=Ke*d+Es;if(h>0){let ma=Xs===xe,Ed=Xs===oo-1,BW=da||_a||ma||Ed;if((da||_a)&&(ma||Ed))continue;BW&&(ka-=h,ma?(yl=rn+(m-Ke-1),Wa-=ea*H):_a?yl=rn+m+(d-Es-1):Ed?(yl=rn+m+d+Ke,Wa+=ea*H):da&&(yl=rn+m+d+m+Es))}let Bi=bl*e(Wa),sd=bl*n(Wa),zi=at*Bi,js=st*sd,$n=1/i(zi*Bi+js*sd+Go*na),mr=zi*$n,hr=js*$n,pr=Go*$n,hs=new p;hs.x=mr+Bi*ka,hs.y=hr+sd*ka,hs.z=pr+na*ka,L.multiplyByPoint(kt,hs,Aot),p.minimumByComponent(Aot,ie,ie),p.maximumByComponent(Aot,oe,oe),He=Math.min(He,ka),ke[yl]=hs,We[yl]=new K(Ju,si),ue[yl]=ka,Q&&(un[yl]=Ao),E&&(Ct[yl]=u.geodeticSurfaceNormal(hs))}}let gs=Ft.fromPoints(ke),is;c(G)&&(is=ci.fromRectangle(G,Qt,Wt,u));let ja;Y&&(ja=new BZ(u).computeHorizonCullingPointPossiblyUnderEllipsoid(y,ke,Qt));let qn=new Ff(ie,oe,y),ae=new lc(y,qn,He,Wt,Nt,!1,Q,E,J,M),fe=new Float32Array(zt*ae.stride),ge=0;for(let Ze=0;Ze0?T=El.getRegularGridAndSkirtIndicesAndEdgeIndices(A.gridWidth,A.gridHeight):T=El.getRegularGridIndicesAndEdgeIndices(A.gridWidth,A.gridHeight);let g=A.gridWidth*A.gridHeight;return G._mesh=new Au(h,new Float32Array(A.vertices),T.indices,T.indexCountWithoutSkirts,g,A.minimumHeight,A.maximumHeight,Ft.clone(A.boundingSphere3D),p.clone(A.occludeePointInScaledSpace),A.numberOfAttributes,ci.clone(A.orientedBoundingBox),lc.clone(A.encoding),T.westIndicesSouthToNorth,T.southIndicesEastToWest,T.eastIndicesNorthToSouth,T.northIndicesWestToEast),G._buffer=void 0,G._mesh})};lW.prototype._createMeshSync=function(t){let e=t.tilingScheme,n=t.x,i=t.y,o=t.level,a=f(t.exaggeration,1),s=f(t.exaggerationRelativeHeight,0),l=e.ellipsoid,r=e.tileXYToNativeRectangle(n,i,o),d=e.tileXYToRectangle(n,i,o),m=l.cartographicToCartesian(Gt.center(d)),h=this._structure,b=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(l,this._width,e.getNumberOfXTilesAtLevel(0))/(1<0?F=El.getRegularGridAndSkirtIndicesAndEdgeIndices(this._width,this._height):F=El.getRegularGridIndicesAndEdgeIndices(this._width,this._height);let U=u.gridWidth*u.gridHeight;return this._mesh=new Au(m,u.vertices,F.indices,F.indexCountWithoutSkirts,U,u.minimumHeight,u.maximumHeight,u.boundingSphere3D,u.occludeePointInScaledSpace,u.encoding.stride,u.orientedBoundingBox,u.encoding,F.westIndicesSouthToNorth,F.southIndicesEastToWest,F.eastIndicesNorthToSouth,F.northIndicesWestToEast),this._mesh};lW.prototype.interpolateHeight=function(t,e,n){let i=this._width,o=this._height,a=this._structure,s=a.stride,l=a.elementsPerHeight,r=a.elementMultiplier,d=a.isBigEndian,m=a.heightOffset,h=a.heightScale,Z=c(this._mesh),b=this._encoding===Uu.LERC;if(!Z&&b)return;let F;if(Z){let U=this._mesh.vertices,G=this._mesh.encoding;F=h1t(U,G,m,h,t,i,o,e,n)}else F=DSe(this._buffer,l,r,s,d,t,i,o,e,n),F=F*h+m;return F};lW.prototype.upsample=function(t,e,n,i,o,a,s){let l=this._mesh;if(!c(l))return;let r=this._width,d=this._height,m=this._structure,h=m.stride,Z=new this._bufferType(r*d*h),b=l.vertices,u=l.encoding,F=t.tileXYToRectangle(e,n,i),U=t.tileXYToRectangle(o,a,s),G=m.heightOffset,A=m.heightScale,T=m.elementsPerHeight,g=m.elementMultiplier,C=m.isBigEndian,y=Math.pow(g,T-1);for(let Y=0;Ym.highestEncodedHeight?m.highestEncodedHeight:V,OSe(Z,T,g,y,h,C,Y*r+J,V)}}return Promise.resolve(new lW({buffer:Z,width:r,height:d,childTileMask:0,structure:this._structure,createdByUpsampling:!0}))};lW.prototype.isChildAvailable=function(t,e,n,i){let o=2;return n!==t*2&&++o,i!==e*2&&(o-=2),(this._childTileMask&1<=s&&(b=s-1,Z=s-2);let u=h|0,F=u+1;F>=l&&(F=l-1,u=l-2);let U=m-Z,G=h-u;u=l-1-u,F=l-1-F;let A=uz(t,e,n,i,o,u*s+Z),T=uz(t,e,n,i,o,u*s+b),g=uz(t,e,n,i,o,F*s+Z),C=uz(t,e,n,i,o,F*s+b);return p1t(U,G,A,T,g,C)}function h1t(t,e,n,i,o,a,s,l,r){let d=(l-o.west)*(a-1)/(o.east-o.west),m=(r-o.south)*(s-1)/(o.north-o.south),h=d|0,Z=h+1;Z>=a&&(Z=a-1,h=a-2);let b=m|0,u=b+1;u>=s&&(u=s-1,b=s-2);let F=d-h,U=m-b;b=s-1-b,u=s-1-u;let G=(e.decodeHeight(t,b*a+h)-n)/i,A=(e.decodeHeight(t,b*a+Z)-n)/i,T=(e.decodeHeight(t,u*a+h)-n)/i,g=(e.decodeHeight(t,u*a+Z)-n)/i;return p1t(F,U,G,A,T,g)}function p1t(t,e,n,i,o,a){return e=0;--l)s=s*n+t[a+l];return s}function OSe(t,e,n,i,o,a,s,l){s*=o;let r;if(a)for(r=0;r0;--r)t[s+r]=l/i|0,l-=t[s+r]*i,i/=n;t[s+r]=l}var Gd=lW;function R1(t){t=f(t,f.EMPTY_OBJECT),this._tilingScheme=t.tilingScheme,c(this._tilingScheme)||(this._tilingScheme=new Qo({ellipsoid:f(t.ellipsoid,mt.WGS84)})),this._levelZeroMaximumGeometricError=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(this._tilingScheme.ellipsoid,64,this._tilingScheme.getNumberOfXTilesAtLevel(0)),this._errorEvent=new It}Object.defineProperties(R1.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){}},tilingScheme:{get:function(){return this._tilingScheme}},hasWaterMask:{get:function(){return!1}},hasVertexNormals:{get:function(){return!1}},availability:{get:function(){}}});R1.prototype.requestTileGeometry=function(t,e,n,i){return Promise.resolve(new Gd({buffer:new Uint8Array(16*16),width:16,height:16}))};R1.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<=3&&(this._frontFaceColorCommand.vertexArray=NUe(this,e),this._backFaceColorCommand.vertexArray=this._frontFaceColorCommand.vertexArray,this._pickCommand.vertexArray=this._frontFaceColorCommand.vertexArray)}if(!c(this._frontFaceColorCommand.vertexArray))return;let a=t.passes,s=!L.equals(this.modelMatrix,this._modelMatrix);s&&L.clone(this.modelMatrix,this._modelMatrix),(o||s)&&Ft.transform(this._boundingSphere,this.modelMatrix,this._boundingSphereWC),this._frontFaceColorCommand.modelMatrix=this.modelMatrix,this._backFaceColorCommand.modelMatrix=this._frontFaceColorCommand.modelMatrix,this._pickCommand.modelMatrix=this._frontFaceColorCommand.modelMatrix;let l=this._lateralSurfaceMaterial!==this.lateralSurfaceMaterial;if(this._lateralSurfaceMaterial=this.lateralSurfaceMaterial,this._lateralSurfaceMaterial.update(e),a.render){let r=this._frontFaceColorCommand,d=this._backFaceColorCommand;if(l||!c(r.shaderProgram)){let m=new Ze({sources:[wI,this._lateralSurfaceMaterial.shaderSource,PI]});r.shaderProgram=xn.replaceCache({context:e,shaderProgram:r.shaderProgram,vertexShaderSource:vI,fragmentShaderSource:m,attributeLocations:C3}),r.uniformMap=ze(this._uniforms,this._lateralSurfaceMaterial._uniforms),d.shaderProgram=r.shaderProgram,d.uniformMap=ze(this._uniforms,this._lateralSurfaceMaterial._uniforms),d.uniformMap.u_normalDirection=function(){return-1}}i?n.push(this._backFaceColorCommand,this._frontFaceColorCommand):n.push(this._frontFaceColorCommand)}if(a.pick){let r=this._pickCommand;if((!c(this._pickId)||this._id!==this.id)&&(this._id=this.id,this._pickId=this._pickId&&this._pickId.destroy(),this._pickId=e.createPickId({primitive:this._pickPrimitive,id:this.id})),l||!c(r.shaderProgram)){let d=new Ze({sources:[wI,this._lateralSurfaceMaterial.shaderSource,PI],pickColorQualifier:"uniform"});r.shaderProgram=xn.replaceCache({context:e,shaderProgram:r.shaderProgram,vertexShaderSource:vI,fragmentShaderSource:d,attributeLocations:C3});let m=this,h={czm_pickColor:function(){return m._pickId.color}};r.uniformMap=ze(ze(this._uniforms,this._lateralSurfaceMaterial._uniforms),h)}r.pass=i?Pt.TRANSLUCENT:Pt.OPAQUE,n.push(r)}};aM.prototype.isDestroyed=function(){return!1};aM.prototype.destroy=function(){return this._frontFaceColorCommand.vertexArray=this._frontFaceColorCommand.vertexArray&&this._frontFaceColorCommand.vertexArray.destroy(),this._frontFaceColorCommand.shaderProgram=this._frontFaceColorCommand.shaderProgram&&this._frontFaceColorCommand.shaderProgram.destroy(),this._pickCommand.shaderProgram=this._pickCommand.shaderProgram&&this._pickCommand.shaderProgram.destroy(),this._pickId=this._pickId&&this._pickId.destroy(),At(this)};var Ku=aM;var $Li=b(W(),1);function ac(t,e,n){let i=e[t.id];if(c(i)){let o=i.primitive;n.remove(o),o.isDestroyed()||o.destroy(),delete e[t.id]}}var yUe=v.WHITE,BUe=1,QUe=Number.POSITIVE_INFINITY,kUe=new ot,YUe=new p,xUe=new wt;function KI(t,e,n,i){let o=e[t];c(o)||(o=new Oc,e[t]=o),o.clock=n,o.cone=i,o.magnitude=1}function XUe(t,e,n,i,o){let a=t.directions,s,l=0,r=k.toRadians(2);if(e===0&&n===k.TWO_PI)for(s=0;se;s-=r)KI(l++,a,s,i);KI(l++,a,e,i)}else KI(l++,a,n,0)}a.length=l,t.directions=a}var zI=function(t,e){if(!c(t))throw new Ut("scene is required.");if(!c(e))throw new Ut("entityCollection is required.");e.collectionChanged.addEventListener(zI.prototype._onCollectionChanged,this),this._scene=t,this._primitives=t.primitives,this._entityCollection=e,this._hash={},this._entitiesToVisualize=new qe,this._onCollectionChanged(e,e.values,[],[])};zI.prototype.update=function(t){if(!c(t))throw new Ut("time is required.");let e=this._entitiesToVisualize.values,n=this._hash,i=this._primitives;for(let o=0,a=e.length;o-1;i--)ac(t[i],e,n);return At(this)};zI.prototype._onCollectionChanged=function(t,e,n,i){let o,a,s=this._entitiesToVisualize,l=this._hash,r=this._primitives;for(o=e.length-1;o>-1;o--)a=e[o],c(a._conicSensor)&&c(a._position)&&s.set(a.id,a);for(o=i.length-1;o>-1;o--)a=i[o],c(a._conicSensor)&&c(a._position)?s.set(a.id,a):(ac(a,l,r),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],ac(a,l,r),s.remove(a.id)};var LS=zI;var gMi=b(W(),1);var MS=class extends oW{constructor(e){super(e),this._directions=void 0,this._directionsSubscription=void 0,this._lateralSurfaceMaterial=void 0,this._lateralSurfaceMaterialSubscription=void 0,this._intersectionColor=void 0,this._intersectionColorSubscription=void 0,this._intersectionWidth=void 0,this._intersectionWidthSubscription=void 0,this._showIntersection=void 0,this._showIntersectionSubscription=void 0,this._radius=void 0,this._radiusSubscription=void 0,this._show=void 0,this._showSubscription=void 0,this._definitionChanged=new It,this.merge(f(e,f.EMPTY_OBJECT))}};Object.defineProperties(MS.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},directions:ft("directions"),lateralSurfaceMaterial:la("lateralSurfaceMaterial"),intersectionColor:ft("intersectionColor"),intersectionWidth:ft("intersectionWidth"),showIntersection:ft("showIntersection"),radius:ft("radius"),show:ft("show")});MS.prototype.clone=function(t){return c(t)||(t=new MS),t.directions=this.directions,t.radius=this.radius,t.show=this.show,t.showIntersection=this.showIntersection,t.intersectionColor=this.intersectionColor,t.intersectionWidth=this.intersectionWidth,t.lateralSurfaceMaterial=this.lateralSurfaceMaterial,t};MS.prototype.merge=function(t){if(!c(t))throw new Ut("source is required.");this.directions=f(this.directions,t.directions),this.radius=f(this.radius,t.radius),this.show=f(this.show,t.show),this.showIntersection=f(this.showIntersection,t.showIntersection),this.intersectionColor=f(this.intersectionColor,t.intersectionColor),this.intersectionWidth=f(this.intersectionWidth,t.intersectionWidth),this.lateralSurfaceMaterial=f(this.lateralSurfaceMaterial,t.lateralSurfaceMaterial)};var _S=MS;var OMi=b(W(),1);var JUe=v.WHITE,LUe=1,MUe=Number.POSITIVE_INFINITY,_Ue=new ot,DUe=new p,OUe=new wt,jI=function(t,e){if(!c(t))throw new Ut("scene is required.");if(!c(e))throw new Ut("entityCollection is required.");e.collectionChanged.addEventListener(jI.prototype._onCollectionChanged,this),this._scene=t,this._primitives=t.primitives,this._entityCollection=e,this._hash={},this._entitiesToVisualize=new qe,this._onCollectionChanged(e,e.values,[],[])};jI.prototype.update=function(t){if(!c(t))throw new Ut("time is required.");let e=this._entitiesToVisualize.values,n=this._hash,i=this._primitives;for(let o=0,a=e.length;o-1;i--)ac(t[i],e,n);return At(this)};jI.prototype._onCollectionChanged=function(t,e,n,i){let o,a,s=this._entitiesToVisualize,l=this._hash,r=this._primitives;for(o=e.length-1;o>-1;o--)a=e[o],c(a._customPatternSensor)&&c(a._position)&&s.set(a.id,a);for(o=i.length-1;o>-1;o--)a=i[o],c(a._customPatternSensor)&&c(a._position)?s.set(a.id,a):(ac(a,l,r),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],ac(a,l,r),s.remove(a.id)};var DS=jI;var $Mi=b(W(),1);var OS=class extends oW{constructor(e={}){super(e),this._definitionChanged=new It,this.xHalfAngle=e.xHalfAngle,this._xHalfAngleSubscription=void 0,this.yHalfAngle=e.yHalfAngle,this._yHalfAngleSubscription=void 0,this.lateralSurfaceMaterial=e.lateralSurfaceMaterial,this._lateralSurfaceMaterialSubscription=void 0,this.intersectionColor=e.intersectionColor,this._intersectionColorSubscription=void 0,this.intersectionWidth=e.intersectionWidth,this._intersectionWidthSubscription=void 0,this.showIntersection=e.showIntersection,this._showIntersectionSubscription=void 0,this.radius=e.radius,this._radiusSubscription=void 0,this.show=e.show,this._showSubscription=void 0}};Object.defineProperties(OS.prototype,{definitionChanged:{get:function(){return this._definitionChanged}},xHalfAngle:ft("xHalfAngle"),yHalfAngle:ft("yHalfAngle"),lateralSurfaceMaterial:la("lateralSurfaceMaterial"),intersectionColor:ft("intersectionColor"),intersectionWidth:ft("intersectionWidth"),showIntersection:ft("showIntersection"),radius:ft("radius"),show:ft("show")});OS.prototype.clone=function(t){return c(t)||(t=new OS),t.xHalfAngle=this.xHalfAngle,t.yHalfAngle=this.yHalfAngle,t.radius=this.radius,t.show=this.show,t.showIntersection=this.showIntersection,t.intersectionColor=this.intersectionColor,t.intersectionWidth=this.intersectionWidth,t.lateralSurfaceMaterial=this.lateralSurfaceMaterial,t};OS.prototype.merge=function(t){if(!c(t))throw new Ut("source is required.");this.xHalfAngle=f(this.xHalfAngle,t.xHalfAngle),this.yHalfAngle=f(this.yHalfAngle,t.yHalfAngle),this.radius=f(this.radius,t.radius),this.show=f(this.show,t.show),this.showIntersection=f(this.showIntersection,t.showIntersection),this.intersectionColor=f(this.intersectionColor,t.intersectionColor),this.intersectionWidth=f(this.intersectionWidth,t.intersectionWidth),this.lateralSurfaceMaterial=f(this.lateralSurfaceMaterial,t.lateralSurfaceMaterial)};var HS=OS;var g_i=b(W(),1);var d_i=b(W(),1);function I3(t,e,n,i){let o=e[t];c(o)||(o=new Oc,e[t]=o),o.clock=n,o.cone=i,o.magnitude=1}function zit(t){let e=t._customSensor.directions,n=Math.tan(Math.min(t._xHalfAngle,k.toRadians(89))),i=Math.tan(Math.min(t._yHalfAngle,k.toRadians(89))),o=Math.atan(n/i),a=Math.atan(Math.sqrt(n*n+i*i));I3(0,e,o,a),I3(1,e,k.toRadians(180)-o,a),I3(2,e,k.toRadians(180)+o,a),I3(3,e,-o,a),e.length=4,t._customSensor.directions=e}var wS=class{constructor(e){e=f(e,f.EMPTY_OBJECT);let n=Re(e);n._pickPrimitive=f(e._pickPrimitive,this),n.directions=void 0,this._customSensor=new Ku(n),this._xHalfAngle=f(e.xHalfAngle,k.PI_OVER_TWO),this._yHalfAngle=f(e.yHalfAngle,k.PI_OVER_TWO),zit(this)}};Object.defineProperties(wS.prototype,{xHalfAngle:{get:function(){return this._xHalfAngle},set:function(t){if(t>k.PI_OVER_TWO)throw new Ut("xHalfAngle must be less than or equal to 90 degrees.");this._xHalfAngle!==t&&(this._xHalfAngle=t,zit(this))}},yHalfAngle:{get:function(){return this._yHalfAngle},set:function(t){if(t>k.PI_OVER_TWO)throw new Ut("yHalfAngle must be less than or equal to 90 degrees.");this._yHalfAngle!==t&&(this._yHalfAngle=t,zit(this))}},show:{get:function(){return this._customSensor.show},set:function(t){this._customSensor.show=t}},showIntersection:{get:function(){return this._customSensor.showIntersection},set:function(t){this._customSensor.showIntersection=t}},showThroughEllipsoid:{get:function(){return this._customSensor.showThroughEllipsoid},set:function(t){this._customSensor.showThroughEllipsoid=t}},modelMatrix:{get:function(){return this._customSensor.modelMatrix},set:function(t){this._customSensor.modelMatrix=t}},radius:{get:function(){return this._customSensor.radius},set:function(t){this._customSensor.radius=t}},lateralSurfaceMaterial:{get:function(){return this._customSensor.lateralSurfaceMaterial},set:function(t){this._customSensor.lateralSurfaceMaterial=t}},intersectionColor:{get:function(){return this._customSensor.intersectionColor},set:function(t){this._customSensor.intersectionColor=t}},intersectionWidth:{get:function(){return this._customSensor.intersectionWidth},set:function(t){this._customSensor.intersectionWidth=t}},id:{get:function(){return this._customSensor.id},set:function(t){this._customSensor.id=t}}});wS.prototype.update=function(t){this._customSensor.update(t)};wS.prototype.isDestroyed=function(){return!1};wS.prototype.destroy=function(){return this._customSensor=this._customSensor&&this._customSensor.destroy(),At(this)};var PS=wS;var HUe=v.WHITE,wUe=1,PUe=Number.POSITIVE_INFINITY,vUe=new ot,KUe=new p,zUe=new wt,qI=function(t,e){if(!c(t))throw new Ut("scene is required.");if(!c(e))throw new Ut("entityCollection is required.");e.collectionChanged.addEventListener(qI.prototype._onCollectionChanged,this),this._scene=t,this._primitives=t.primitives,this._entityCollection=e,this._hash={},this._entitiesToVisualize=new qe,this._onCollectionChanged(e,e.values,[],[])};qI.prototype.update=function(t){if(!c(t))throw new Ut("time is required.");let e=this._entitiesToVisualize.values,n=this._hash,i=this._primitives;for(let o=0,a=e.length;o-1;i--)ac(t[i],e,n);return At(this)};qI.prototype._onCollectionChanged=function(t,e,n,i){let o,a,s=this._entitiesToVisualize,l=this._hash,r=this._primitives;for(o=e.length-1;o>-1;o--)a=e[o],c(a._rectangularSensor)&&c(a._position)&&s.set(a.id,a);for(o=i.length-1;o>-1;o--)a=i[o],c(a._rectangularSensor)&&c(a._position)?s.set(a.id,a):(ac(a,l,r),s.remove(a.id));for(o=n.length-1;o>-1;o--)a=n[o],ac(a,l,r),s.remove(a.id)};var vS=qI;var WV=O0.processPacketData,jUe=O0.processMaterialPacketData;function iCt(t,e,n,i,o){let a,s,l=[],r=e.unitSpherical,d=e.spherical,m=e.unitCartesian,h=e.cartesian;if(c(r)){for(a=0,s=r.length;ae[1]!=t[o][1]>e[1]&&e[0]<(t[o][0]-t[i][0])*(e[1]-t[i][1])/(t[o][1]-t[i][1])+t[i][0]&&(n=!n),o=i;return n}function sIt(t){return[t.x,t.y]}function lIt(t,e,n){let i=p.subtract(t,e,new p),o=p.dot(i,n),a=p.multiplyByScalar(n,o,new p);return p.subtract(t,a,new p)}function uAe(t,e,n){if(!t||!e||e.length===0)return!1;e=e.map(F=>new p(F[0],F[1],F[2]));let i=e.slice().sort((F,U)=>p.distance(n,U)-p.distance(n,F)),[o,a,s]=i.slice(0,3),l=p.subtract(a,o,new p),r=p.subtract(s,o,new p),d=p.cross(l,r,new p);p.normalize(d,d);let m=p.negate(d,new p),h=e.map(F=>lIt(F,t,m)),u=lIt(t,t,m),R=h.map(sIt);return VAe(R,sIt(u))}var lM=uAe;function ZAe(t,e,n){if(!t||!e||e.length===0)return!1;let i=e[0],o=e[1],a=[t.x,t.y,t.z],s=[n,...i].map(m=>[m.x,m.y,m.z]),l=[...o].map(m=>[m.x,m.y,m.z]);if(!lM(t,l,n))return!1;let r=(0,M3.default)(s);return!!(0,M3.isPointInsideHull)(a,s,r)}var rM=ZAe;KS();var dot={ConicSensorGraphics:XS,ConicSensorVisualizer:LS,CustomPatternSensorGraphics:_S,CustomPatternSensorVisualizer:DS,CustomSensorVolume:Ku,RectangularPyramidSensorVolume:PS,RectangularSensorGraphics:HS,RectangularSensorVisualizer:vS,initialize:KS,sensorStateInstance:JS,isPointIn3D:rM};var gpo=b(W(),1);var rpo=b(W(),1);var T5i=b(W(),1);var Ot={};vO(Ot,{Builder:()=>_3,ByteBuffer:()=>qS,Encoding:()=>o1,FILE_IDENTIFIER_LENGTH:()=>$h,SIZEOF_INT:()=>jm,SIZEOF_SHORT:()=>i1,SIZE_PREFIX_LENGTH:()=>xt,float32:()=>dM,float64:()=>cM,int32:()=>ju,isLittleEndian:()=>jS});var Z5i=b(W());var n5i=b(W()),i1=2,jm=4,$h=4,xt=4;var o5i=b(W()),ju=new Int32Array(2),dM=new Float32Array(ju.buffer),cM=new Float64Array(ju.buffer),jS=new Uint16Array(new Uint8Array([1,0]).buffer)[0]===1;var s5i=b(W()),o1;(function(t){t[t.UTF8_BYTES=1]="UTF8_BYTES",t[t.UTF16_STRING=2]="UTF16_STRING"})(o1||(o1={}));var u5i=b(W());var m5i=b(W());var qS=class t{constructor(e){this.bytes_=e,this.position_=0,this.text_decoder_=new TextDecoder}static allocate(e){return new t(new Uint8Array(e))}clear(){this.position_=0}bytes(){return this.bytes_}position(){return this.position_}setPosition(e){this.position_=e}capacity(){return this.bytes_.length}readInt8(e){return this.readUint8(e)<<24>>24}readUint8(e){return this.bytes_[e]}readInt16(e){return this.readUint16(e)<<16>>16}readUint16(e){return this.bytes_[e]|this.bytes_[e+1]<<8}readInt32(e){return this.bytes_[e]|this.bytes_[e+1]<<8|this.bytes_[e+2]<<16|this.bytes_[e+3]<<24}readUint32(e){return this.readInt32(e)>>>0}readInt64(e){return BigInt.asIntN(64,BigInt(this.readUint32(e))+(BigInt(this.readUint32(e+4))<>8}writeUint16(e,n){this.bytes_[e]=n,this.bytes_[e+1]=n>>8}writeInt32(e,n){this.bytes_[e]=n,this.bytes_[e+1]=n>>8,this.bytes_[e+2]=n>>16,this.bytes_[e+3]=n>>24}writeUint32(e,n){this.bytes_[e]=n,this.bytes_[e+1]=n>>8,this.bytes_[e+2]=n>>16,this.bytes_[e+3]=n>>24}writeInt64(e,n){this.writeInt32(e,Number(BigInt.asIntN(32,n))),this.writeInt32(e+4,Number(BigInt.asIntN(32,n>>BigInt(32))))}writeUint64(e,n){this.writeUint32(e,Number(BigInt.asUintN(32,n))),this.writeUint32(e+4,Number(BigInt.asUintN(32,n>>BigInt(32))))}writeFloat32(e,n){dM[0]=n,this.writeInt32(e,ju[0])}writeFloat64(e,n){cM[0]=n,this.writeInt32(e,ju[jS?0:1]),this.writeInt32(e+4,ju[jS?1:0])}getBufferIdentifier(){if(this.bytes_.lengththis.minalign&&(this.minalign=e);let i=~(this.bb.capacity()-this.space+n)+1&e-1;for(;this.space=0&&this.vtable[n]==0;n--);let i=n+1;for(;n>=0;n--)this.addInt16(this.vtable[n]!=0?e-this.vtable[n]:0);let o=2;this.addInt16(e-this.object_start);let a=(i+o)*2;this.addInt16(a);let s=0,l=this.space;t:for(n=0;n=0;s--)this.writeInt8(a.charCodeAt(s))}this.prep(this.minalign,4+o),this.addOffset(e),o&&this.addInt32(this.bb.capacity()-this.space),this.bb.setPosition(this.space)}finishSizePrefixed(e,n){this.finish(e,n,!0)}requiredField(e,n){let i=this.bb.capacity()-e,o=i-this.bb.readInt32(i);if(!(n{t=new Uint8Array(t);let i=new n[`${e}COLLECTIONT`];return n[`${e}COLLECTION`][`getRootAs${e}COLLECTION`](new RAe(t)).unpackTo(i),i};var vho=b(W(),1);var k5i=b(W(),1);var E5i=b(W(),1);var N5i=b(W(),1);var aW={};vO(aW,{Band:()=>yR,BandT:()=>hM,CAT:()=>rU,CATCOLLECTION:()=>s1,CATCOLLECTIONT:()=>RM,CATT:()=>ZM,DataMode:()=>$F,DeviceType:()=>tU,FrequencyRange:()=>qu,FrequencyRangeT:()=>mM,IDM:()=>Wo,IDMCOLLECTION:()=>l1,IDMCOLLECTIONT:()=>bM,IDMT:()=>VM,PLD:()=>BR,PLDCOLLECTION:()=>r1,PLDCOLLECTIONT:()=>WM,PLDT:()=>uM,PolarizationType:()=>eU,SimplePolarization:()=>nU,StokesParameters:()=>$S,StokesParametersT:()=>pM,dataStatusCode:()=>iU,massType:()=>oU,objectType:()=>aU,opsStatusCode:()=>sU,orbitType:()=>lU});var XDi=b(W(),1);var _5i=b(W(),1);var J5i=b(W(),1);var qu=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsFrequencyRange(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsFrequencyRange(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}LOWER(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat64(this.bb_pos+e):0}static startFrequencyRange(e){e.startObject(2)}static addLower(e,n){e.addFieldFloat64(0,n,0)}static addUpper(e,n){e.addFieldFloat64(1,n,0)}static endFrequencyRange(e){return e.endObject()}static createFrequencyRange(e,n,i){return t.startFrequencyRange(e),t.addLower(e,n),t.addUpper(e,i),t.endFrequencyRange(e)}unpack(){return new mM(this.LOWER(),this.UPPER())}unpackTo(e){e.LOWER=this.LOWER(),e.UPPER=this.UPPER()}},mM=class{constructor(e=0,n=0){this.LOWER=e,this.UPPER=n}pack(e){return qu.createFrequencyRange(e,this.LOWER,this.UPPER)}};var yR=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsBand(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsBand(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}NAME(e){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,e):null}FREQUENCY_RANGE(e){let n=this.bb.__offset(this.bb_pos,6);return n?(e||new qu).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}static startBand(e){e.startObject(2)}static addName(e,n){e.addFieldOffset(0,n,0)}static addFrequencyRange(e,n){e.addFieldOffset(1,n,0)}static endBand(e){return e.endObject()}unpack(){return new hM(this.NAME(),this.FREQUENCY_RANGE()!==null?this.FREQUENCY_RANGE().unpack():null)}unpackTo(e){e.NAME=this.NAME(),e.FREQUENCY_RANGE=this.FREQUENCY_RANGE()!==null?this.FREQUENCY_RANGE().unpack():null}},hM=class{constructor(e=null,n=null){this.NAME=e,this.FREQUENCY_RANGE=n}pack(e){let n=this.NAME!==null?e.createString(this.NAME):0,i=this.FREQUENCY_RANGE!==null?this.FREQUENCY_RANGE.pack(e):0;return yR.startBand(e),yR.addName(e,n),yR.addFrequencyRange(e,i),yR.endBand(e)}};var EDi=b(W(),1);var cDi=b(W(),1);var lDi=b(W(),1);var O5i=b(W(),1),$F;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})($F||($F={}));var w5i=b(W(),1),tU;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(tU||(tU={}));var v5i=b(W(),1),eU;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(eU||(eU={}));var z5i=b(W(),1),nU;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(nU||(nU={}));var q5i=b(W(),1);var $S=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsStokesParameters(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsStokesParameters(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}I(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}Q(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat64(this.bb_pos+e):0}U(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readFloat64(this.bb_pos+e):0}V(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readFloat64(this.bb_pos+e):0}static startStokesParameters(e){e.startObject(4)}static addI(e,n){e.addFieldFloat64(0,n,0)}static addQ(e,n){e.addFieldFloat64(1,n,0)}static addU(e,n){e.addFieldFloat64(2,n,0)}static addV(e,n){e.addFieldFloat64(3,n,0)}static endStokesParameters(e){return e.endObject()}static createStokesParameters(e,n,i,o,a){return t.startStokesParameters(e),t.addI(e,n),t.addQ(e,i),t.addU(e,o),t.addV(e,a),t.endStokesParameters(e)}unpack(){return new pM(this.I(),this.Q(),this.U(),this.V())}unpackTo(e){e.I=this.I(),e.Q=this.Q(),e.U=this.U(),e.V=this.V()}},pM=class{constructor(e=0,n=0,i=0,o=0){this.I=e,this.Q=n,this.U=i,this.V=o}pack(e){return $S.createStokesParameters(e,this.I,this.Q,this.U,this.V)}};var Wo=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsIDM(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsIDM(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$IDM")}ID(e){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,e):null}NAME(e){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.__string(this.bb_pos+n,e):null}DATA_MODE(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readInt8(this.bb_pos+e):$F.REAL}UPLINK(e){let n=this.bb.__offset(this.bb_pos,10);return n?(e||new qu).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}DOWNLINK(e){let n=this.bb.__offset(this.bb_pos,12);return n?(e||new qu).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}BEACON(e){let n=this.bb.__offset(this.bb_pos,14);return n?(e||new qu).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}BAND(e,n){let i=this.bb.__offset(this.bb_pos,16);return i?(n||new yR).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}bandLength(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.__vector_len(this.bb_pos+e):0}POLARIZATION_TYPE(){let e=this.bb.__offset(this.bb_pos,18);return e?this.bb.readInt8(this.bb_pos+e):eU.linear}SIMPLE_POLARIZATION(){let e=this.bb.__offset(this.bb_pos,20);return e?this.bb.readInt8(this.bb_pos+e):nU.vertical}STOKES_PARAMETERS(e){let n=this.bb.__offset(this.bb_pos,22);return n?(e||new $S).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}POWER_REQUIRED(){let e=this.bb.__offset(this.bb_pos,24);return e?this.bb.readFloat64(this.bb_pos+e):0}POWER_TYPE(e){let n=this.bb.__offset(this.bb_pos,26);return n?this.bb.__string(this.bb_pos+n,e):null}TRANSMIT(){let e=this.bb.__offset(this.bb_pos,28);return e?!!this.bb.readInt8(this.bb_pos+e):!1}RECEIVE(){let e=this.bb.__offset(this.bb_pos,30);return e?!!this.bb.readInt8(this.bb_pos+e):!1}SENSOR_TYPE(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readInt8(this.bb_pos+e):tU.UNKNOWN}SOURCE(e){let n=this.bb.__offset(this.bb_pos,34);return n?this.bb.__string(this.bb_pos+n,e):null}LAST_OB_TIME(e){let n=this.bb.__offset(this.bb_pos,36);return n?this.bb.__string(this.bb_pos+n,e):null}LOWER_LEFT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,38);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_LEFT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,40);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_RIGHT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_LEFT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_RIGHT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_RIGHT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.readFloat64(this.bb_pos+e):0}LOWER_RIGHT_AZIMUTH_LIMIT(){let e=this.bb.__offset(this.bb_pos,50);return e?this.bb.readFloat64(this.bb_pos+e):0}UPPER_LEFT_ELEVATION_LIMIT(){let e=this.bb.__offset(this.bb_pos,52);return e?this.bb.readFloat64(this.bb_pos+e):0}RIGHT_GEO_BELT_LIMIT(){let e=this.bb.__offset(this.bb_pos,54);return e?this.bb.readFloat64(this.bb_pos+e):0}LEFT_GEO_BELT_LIMIT(){let e=this.bb.__offset(this.bb_pos,56);return e?this.bb.readFloat64(this.bb_pos+e):0}MAGNITUDE_LIMIT(){let e=this.bb.__offset(this.bb_pos,58);return e?this.bb.readFloat64(this.bb_pos+e):0}TASKABLE(){let e=this.bb.__offset(this.bb_pos,60);return e?!!this.bb.readInt8(this.bb_pos+e):!1}static startIDM(e){e.startObject(29)}static addId(e,n){e.addFieldOffset(0,n,0)}static addName(e,n){e.addFieldOffset(1,n,0)}static addDataMode(e,n){e.addFieldInt8(2,n,$F.REAL)}static addUplink(e,n){e.addFieldOffset(3,n,0)}static addDownlink(e,n){e.addFieldOffset(4,n,0)}static addBeacon(e,n){e.addFieldOffset(5,n,0)}static addBand(e,n){e.addFieldOffset(6,n,0)}static createBandVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startBandVector(e,n){e.startVector(4,n,4)}static addPolarizationType(e,n){e.addFieldInt8(7,n,eU.linear)}static addSimplePolarization(e,n){e.addFieldInt8(8,n,nU.vertical)}static addStokesParameters(e,n){e.addFieldOffset(9,n,0)}static addPowerRequired(e,n){e.addFieldFloat64(10,n,0)}static addPowerType(e,n){e.addFieldOffset(11,n,0)}static addTransmit(e,n){e.addFieldInt8(12,+n,0)}static addReceive(e,n){e.addFieldInt8(13,+n,0)}static addSensorType(e,n){e.addFieldInt8(14,n,tU.UNKNOWN)}static addSource(e,n){e.addFieldOffset(15,n,0)}static addLastObTime(e,n){e.addFieldOffset(16,n,0)}static addLowerLeftElevationLimit(e,n){e.addFieldFloat64(17,n,0)}static addUpperLeftAzimuthLimit(e,n){e.addFieldFloat64(18,n,0)}static addLowerRightElevationLimit(e,n){e.addFieldFloat64(19,n,0)}static addLowerLeftAzimuthLimit(e,n){e.addFieldFloat64(20,n,0)}static addUpperRightElevationLimit(e,n){e.addFieldFloat64(21,n,0)}static addUpperRightAzimuthLimit(e,n){e.addFieldFloat64(22,n,0)}static addLowerRightAzimuthLimit(e,n){e.addFieldFloat64(23,n,0)}static addUpperLeftElevationLimit(e,n){e.addFieldFloat64(24,n,0)}static addRightGeoBeltLimit(e,n){e.addFieldFloat64(25,n,0)}static addLeftGeoBeltLimit(e,n){e.addFieldFloat64(26,n,0)}static addMagnitudeLimit(e,n){e.addFieldFloat64(27,n,0)}static addTaskable(e,n){e.addFieldInt8(28,+n,0)}static endIDM(e){return e.endObject()}static finishIDMBuffer(e,n){e.finish(n,"$IDM")}static finishSizePrefixedIDMBuffer(e,n){e.finish(n,"$IDM",!0)}unpack(){return new VM(this.ID(),this.NAME(),this.DATA_MODE(),this.UPLINK()!==null?this.UPLINK().unpack():null,this.DOWNLINK()!==null?this.DOWNLINK().unpack():null,this.BEACON()!==null?this.BEACON().unpack():null,this.bb.createObjList(this.BAND.bind(this),this.bandLength()),this.POLARIZATION_TYPE(),this.SIMPLE_POLARIZATION(),this.STOKES_PARAMETERS()!==null?this.STOKES_PARAMETERS().unpack():null,this.POWER_REQUIRED(),this.POWER_TYPE(),this.TRANSMIT(),this.RECEIVE(),this.SENSOR_TYPE(),this.SOURCE(),this.LAST_OB_TIME(),this.LOWER_LEFT_ELEVATION_LIMIT(),this.UPPER_LEFT_AZIMUTH_LIMIT(),this.LOWER_RIGHT_ELEVATION_LIMIT(),this.LOWER_LEFT_AZIMUTH_LIMIT(),this.UPPER_RIGHT_ELEVATION_LIMIT(),this.UPPER_RIGHT_AZIMUTH_LIMIT(),this.LOWER_RIGHT_AZIMUTH_LIMIT(),this.UPPER_LEFT_ELEVATION_LIMIT(),this.RIGHT_GEO_BELT_LIMIT(),this.LEFT_GEO_BELT_LIMIT(),this.MAGNITUDE_LIMIT(),this.TASKABLE())}unpackTo(e){e.ID=this.ID(),e.NAME=this.NAME(),e.DATA_MODE=this.DATA_MODE(),e.UPLINK=this.UPLINK()!==null?this.UPLINK().unpack():null,e.DOWNLINK=this.DOWNLINK()!==null?this.DOWNLINK().unpack():null,e.BEACON=this.BEACON()!==null?this.BEACON().unpack():null,e.BAND=this.bb.createObjList(this.BAND.bind(this),this.bandLength()),e.POLARIZATION_TYPE=this.POLARIZATION_TYPE(),e.SIMPLE_POLARIZATION=this.SIMPLE_POLARIZATION(),e.STOKES_PARAMETERS=this.STOKES_PARAMETERS()!==null?this.STOKES_PARAMETERS().unpack():null,e.POWER_REQUIRED=this.POWER_REQUIRED(),e.POWER_TYPE=this.POWER_TYPE(),e.TRANSMIT=this.TRANSMIT(),e.RECEIVE=this.RECEIVE(),e.SENSOR_TYPE=this.SENSOR_TYPE(),e.SOURCE=this.SOURCE(),e.LAST_OB_TIME=this.LAST_OB_TIME(),e.LOWER_LEFT_ELEVATION_LIMIT=this.LOWER_LEFT_ELEVATION_LIMIT(),e.UPPER_LEFT_AZIMUTH_LIMIT=this.UPPER_LEFT_AZIMUTH_LIMIT(),e.LOWER_RIGHT_ELEVATION_LIMIT=this.LOWER_RIGHT_ELEVATION_LIMIT(),e.LOWER_LEFT_AZIMUTH_LIMIT=this.LOWER_LEFT_AZIMUTH_LIMIT(),e.UPPER_RIGHT_ELEVATION_LIMIT=this.UPPER_RIGHT_ELEVATION_LIMIT(),e.UPPER_RIGHT_AZIMUTH_LIMIT=this.UPPER_RIGHT_AZIMUTH_LIMIT(),e.LOWER_RIGHT_AZIMUTH_LIMIT=this.LOWER_RIGHT_AZIMUTH_LIMIT(),e.UPPER_LEFT_ELEVATION_LIMIT=this.UPPER_LEFT_ELEVATION_LIMIT(),e.RIGHT_GEO_BELT_LIMIT=this.RIGHT_GEO_BELT_LIMIT(),e.LEFT_GEO_BELT_LIMIT=this.LEFT_GEO_BELT_LIMIT(),e.MAGNITUDE_LIMIT=this.MAGNITUDE_LIMIT(),e.TASKABLE=this.TASKABLE()}},VM=class{constructor(e=null,n=null,i=$F.REAL,o=null,a=null,s=null,l=[],r=eU.linear,d=nU.vertical,m=null,h=0,u=null,R=!1,V=!1,F=tU.UNKNOWN,U=null,G=null,A=0,S=0,g=0,C=0,y=0,Y=0,Q=0,J=0,M=0,Z=0,E=0,I=!1){this.ID=e,this.NAME=n,this.DATA_MODE=i,this.UPLINK=o,this.DOWNLINK=a,this.BEACON=s,this.BAND=l,this.POLARIZATION_TYPE=r,this.SIMPLE_POLARIZATION=d,this.STOKES_PARAMETERS=m,this.POWER_REQUIRED=h,this.POWER_TYPE=u,this.TRANSMIT=R,this.RECEIVE=V,this.SENSOR_TYPE=F,this.SOURCE=U,this.LAST_OB_TIME=G,this.LOWER_LEFT_ELEVATION_LIMIT=A,this.UPPER_LEFT_AZIMUTH_LIMIT=S,this.LOWER_RIGHT_ELEVATION_LIMIT=g,this.LOWER_LEFT_AZIMUTH_LIMIT=C,this.UPPER_RIGHT_ELEVATION_LIMIT=y,this.UPPER_RIGHT_AZIMUTH_LIMIT=Y,this.LOWER_RIGHT_AZIMUTH_LIMIT=Q,this.UPPER_LEFT_ELEVATION_LIMIT=J,this.RIGHT_GEO_BELT_LIMIT=M,this.LEFT_GEO_BELT_LIMIT=Z,this.MAGNITUDE_LIMIT=E,this.TASKABLE=I}pack(e){let n=this.ID!==null?e.createString(this.ID):0,i=this.NAME!==null?e.createString(this.NAME):0,o=this.UPLINK!==null?this.UPLINK.pack(e):0,a=this.DOWNLINK!==null?this.DOWNLINK.pack(e):0,s=this.BEACON!==null?this.BEACON.pack(e):0,l=Wo.createBandVector(e,e.createObjectOffsetList(this.BAND)),r=this.STOKES_PARAMETERS!==null?this.STOKES_PARAMETERS.pack(e):0,d=this.POWER_TYPE!==null?e.createString(this.POWER_TYPE):0,m=this.SOURCE!==null?e.createString(this.SOURCE):0,h=this.LAST_OB_TIME!==null?e.createString(this.LAST_OB_TIME):0;return Wo.startIDM(e),Wo.addId(e,n),Wo.addName(e,i),Wo.addDataMode(e,this.DATA_MODE),Wo.addUplink(e,o),Wo.addDownlink(e,a),Wo.addBeacon(e,s),Wo.addBand(e,l),Wo.addPolarizationType(e,this.POLARIZATION_TYPE),Wo.addSimplePolarization(e,this.SIMPLE_POLARIZATION),Wo.addStokesParameters(e,r),Wo.addPowerRequired(e,this.POWER_REQUIRED),Wo.addPowerType(e,d),Wo.addTransmit(e,this.TRANSMIT),Wo.addReceive(e,this.RECEIVE),Wo.addSensorType(e,this.SENSOR_TYPE),Wo.addSource(e,m),Wo.addLastObTime(e,h),Wo.addLowerLeftElevationLimit(e,this.LOWER_LEFT_ELEVATION_LIMIT),Wo.addUpperLeftAzimuthLimit(e,this.UPPER_LEFT_AZIMUTH_LIMIT),Wo.addLowerRightElevationLimit(e,this.LOWER_RIGHT_ELEVATION_LIMIT),Wo.addLowerLeftAzimuthLimit(e,this.LOWER_LEFT_AZIMUTH_LIMIT),Wo.addUpperRightElevationLimit(e,this.UPPER_RIGHT_ELEVATION_LIMIT),Wo.addUpperRightAzimuthLimit(e,this.UPPER_RIGHT_AZIMUTH_LIMIT),Wo.addLowerRightAzimuthLimit(e,this.LOWER_RIGHT_AZIMUTH_LIMIT),Wo.addUpperLeftElevationLimit(e,this.UPPER_LEFT_ELEVATION_LIMIT),Wo.addRightGeoBeltLimit(e,this.RIGHT_GEO_BELT_LIMIT),Wo.addLeftGeoBeltLimit(e,this.LEFT_GEO_BELT_LIMIT),Wo.addMagnitudeLimit(e,this.MAGNITUDE_LIMIT),Wo.addTaskable(e,this.TASKABLE),Wo.endIDM(e)}};var BR=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsPLD(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsPLD(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$PLD")}PAYLOAD_DURATION(e){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,e):null}MASS_AT_LAUNCH(){let e=this.bb.__offset(this.bb_pos,6);return e?this.bb.readFloat32(this.bb_pos+e):0}DIMENSIONS(e){let n=this.bb.__offset(this.bb_pos,8);return n?this.bb.__string(this.bb_pos+n,e):null}SOLAR_ARRAY_AREA(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readFloat32(this.bb_pos+e):0}SOLAR_ARRAY_DIMENSIONS(e){let n=this.bb.__offset(this.bb_pos,12);return n?this.bb.__string(this.bb_pos+n,e):null}NOMINAL_OPERATIONAL_LIFETIME(e){let n=this.bb.__offset(this.bb_pos,14);return n?this.bb.__string(this.bb_pos+n,e):null}INSTRUMENTS(e,n){let i=this.bb.__offset(this.bb_pos,16);return i?(n||new Wo).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}instrumentsLength(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.__vector_len(this.bb_pos+e):0}static startPLD(e){e.startObject(7)}static addPayloadDuration(e,n){e.addFieldOffset(0,n,0)}static addMassAtLaunch(e,n){e.addFieldFloat32(1,n,0)}static addDimensions(e,n){e.addFieldOffset(2,n,0)}static addSolarArrayArea(e,n){e.addFieldFloat32(3,n,0)}static addSolarArrayDimensions(e,n){e.addFieldOffset(4,n,0)}static addNominalOperationalLifetime(e,n){e.addFieldOffset(5,n,0)}static addInstruments(e,n){e.addFieldOffset(6,n,0)}static createInstrumentsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startInstrumentsVector(e,n){e.startVector(4,n,4)}static endPLD(e){return e.endObject()}static finishPLDBuffer(e,n){e.finish(n,"$PLD")}static finishSizePrefixedPLDBuffer(e,n){e.finish(n,"$PLD",!0)}static createPLD(e,n,i,o,a,s,l,r){return t.startPLD(e),t.addPayloadDuration(e,n),t.addMassAtLaunch(e,i),t.addDimensions(e,o),t.addSolarArrayArea(e,a),t.addSolarArrayDimensions(e,s),t.addNominalOperationalLifetime(e,l),t.addInstruments(e,r),t.endPLD(e)}unpack(){return new uM(this.PAYLOAD_DURATION(),this.MASS_AT_LAUNCH(),this.DIMENSIONS(),this.SOLAR_ARRAY_AREA(),this.SOLAR_ARRAY_DIMENSIONS(),this.NOMINAL_OPERATIONAL_LIFETIME(),this.bb.createObjList(this.INSTRUMENTS.bind(this),this.instrumentsLength()))}unpackTo(e){e.PAYLOAD_DURATION=this.PAYLOAD_DURATION(),e.MASS_AT_LAUNCH=this.MASS_AT_LAUNCH(),e.DIMENSIONS=this.DIMENSIONS(),e.SOLAR_ARRAY_AREA=this.SOLAR_ARRAY_AREA(),e.SOLAR_ARRAY_DIMENSIONS=this.SOLAR_ARRAY_DIMENSIONS(),e.NOMINAL_OPERATIONAL_LIFETIME=this.NOMINAL_OPERATIONAL_LIFETIME(),e.INSTRUMENTS=this.bb.createObjList(this.INSTRUMENTS.bind(this),this.instrumentsLength())}},uM=class{constructor(e=null,n=0,i=null,o=0,a=null,s=null,l=[]){this.PAYLOAD_DURATION=e,this.MASS_AT_LAUNCH=n,this.DIMENSIONS=i,this.SOLAR_ARRAY_AREA=o,this.SOLAR_ARRAY_DIMENSIONS=a,this.NOMINAL_OPERATIONAL_LIFETIME=s,this.INSTRUMENTS=l}pack(e){let n=this.PAYLOAD_DURATION!==null?e.createString(this.PAYLOAD_DURATION):0,i=this.DIMENSIONS!==null?e.createString(this.DIMENSIONS):0,o=this.SOLAR_ARRAY_DIMENSIONS!==null?e.createString(this.SOLAR_ARRAY_DIMENSIONS):0,a=this.NOMINAL_OPERATIONAL_LIFETIME!==null?e.createString(this.NOMINAL_OPERATIONAL_LIFETIME):0,s=BR.createInstrumentsVector(e,e.createObjectOffsetList(this.INSTRUMENTS));return BR.createPLD(e,n,this.MASS_AT_LAUNCH,i,this.SOLAR_ARRAY_AREA,o,a,s)}};var hDi=b(W(),1),iU;(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(iU||(iU={}));var VDi=b(W(),1),oU;(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(oU||(oU={}));var ZDi=b(W(),1),aU;(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(aU||(aU={}));var bDi=b(W(),1),sU;(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(sU||(sU={}));var fDi=b(W(),1),lU;(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(lU||(lU={}));var rU=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsCAT(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsCAT(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$CAT")}OBJECT_NAME(e){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,e):null}OBJECT_ID(e){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.__string(this.bb_pos+n,e):null}NORAD_CAT_ID(){let e=this.bb.__offset(this.bb_pos,8);return e?this.bb.readUint32(this.bb_pos+e):0}OBJECT_TYPE(){let e=this.bb.__offset(this.bb_pos,10);return e?this.bb.readInt8(this.bb_pos+e):aU.UNKNOWN}OPS_STATUS_CODE(){let e=this.bb.__offset(this.bb_pos,12);return e?this.bb.readInt8(this.bb_pos+e):sU.UNKNOWN}OWNER(e){let n=this.bb.__offset(this.bb_pos,14);return n?this.bb.__string(this.bb_pos+n,e):null}LAUNCH_DATE(e){let n=this.bb.__offset(this.bb_pos,16);return n?this.bb.__string(this.bb_pos+n,e):null}LAUNCH_SITE(e){let n=this.bb.__offset(this.bb_pos,18);return n?this.bb.__string(this.bb_pos+n,e):null}DECAY_DATE(e){let n=this.bb.__offset(this.bb_pos,20);return n?this.bb.__string(this.bb_pos+n,e):null}PERIOD(){let e=this.bb.__offset(this.bb_pos,22);return e?this.bb.readFloat64(this.bb_pos+e):0}INCLINATION(){let e=this.bb.__offset(this.bb_pos,24);return e?this.bb.readFloat64(this.bb_pos+e):0}APOGEE(){let e=this.bb.__offset(this.bb_pos,26);return e?this.bb.readFloat64(this.bb_pos+e):0}PERIGEE(){let e=this.bb.__offset(this.bb_pos,28);return e?this.bb.readFloat64(this.bb_pos+e):0}RCS(){let e=this.bb.__offset(this.bb_pos,30);return e?this.bb.readFloat64(this.bb_pos+e):0}DATA_STATUS_CODE(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readInt8(this.bb_pos+e):iU.NO_CURRENT_ELEMENTS}ORBIT_CENTER(e){let n=this.bb.__offset(this.bb_pos,34);return n?this.bb.__string(this.bb_pos+n,e):null}ORBIT_TYPE(){let e=this.bb.__offset(this.bb_pos,36);return e?this.bb.readInt8(this.bb_pos+e):lU.ORBIT}DEPLOYMENT_DATE(e){let n=this.bb.__offset(this.bb_pos,38);return n?this.bb.__string(this.bb_pos+n,e):null}MANEUVERABLE(){let e=this.bb.__offset(this.bb_pos,40);return e?!!this.bb.readInt8(this.bb_pos+e):!1}SIZE(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS_TYPE(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readInt8(this.bb_pos+e):oU.DRY}PAYLOADS(e,n){let i=this.bb.__offset(this.bb_pos,48);return i?(n||new BR).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}payloadsLength(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.__vector_len(this.bb_pos+e):0}static startCAT(e){e.startObject(23)}static addObjectName(e,n){e.addFieldOffset(0,n,0)}static addObjectId(e,n){e.addFieldOffset(1,n,0)}static addNoradCatId(e,n){e.addFieldInt32(2,n,0)}static addObjectType(e,n){e.addFieldInt8(3,n,aU.UNKNOWN)}static addOpsStatusCode(e,n){e.addFieldInt8(4,n,sU.UNKNOWN)}static addOwner(e,n){e.addFieldOffset(5,n,0)}static addLaunchDate(e,n){e.addFieldOffset(6,n,0)}static addLaunchSite(e,n){e.addFieldOffset(7,n,0)}static addDecayDate(e,n){e.addFieldOffset(8,n,0)}static addPeriod(e,n){e.addFieldFloat64(9,n,0)}static addInclination(e,n){e.addFieldFloat64(10,n,0)}static addApogee(e,n){e.addFieldFloat64(11,n,0)}static addPerigee(e,n){e.addFieldFloat64(12,n,0)}static addRcs(e,n){e.addFieldFloat64(13,n,0)}static addDataStatusCode(e,n){e.addFieldInt8(14,n,iU.NO_CURRENT_ELEMENTS)}static addOrbitCenter(e,n){e.addFieldOffset(15,n,0)}static addOrbitType(e,n){e.addFieldInt8(16,n,lU.ORBIT)}static addDeploymentDate(e,n){e.addFieldOffset(17,n,0)}static addManeuverable(e,n){e.addFieldInt8(18,+n,0)}static addSize(e,n){e.addFieldFloat64(19,n,0)}static addMass(e,n){e.addFieldFloat64(20,n,0)}static addMassType(e,n){e.addFieldInt8(21,n,oU.DRY)}static addPayloads(e,n){e.addFieldOffset(22,n,0)}static createPayloadsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startPayloadsVector(e,n){e.startVector(4,n,4)}static endCAT(e){return e.endObject()}static finishCATBuffer(e,n){e.finish(n,"$CAT")}static finishSizePrefixedCATBuffer(e,n){e.finish(n,"$CAT",!0)}static createCAT(e,n,i,o,a,s,l,r,d,m,h,u,R,V,F,U,G,A,S,g,C,y,Y,Q){return t.startCAT(e),t.addObjectName(e,n),t.addObjectId(e,i),t.addNoradCatId(e,o),t.addObjectType(e,a),t.addOpsStatusCode(e,s),t.addOwner(e,l),t.addLaunchDate(e,r),t.addLaunchSite(e,d),t.addDecayDate(e,m),t.addPeriod(e,h),t.addInclination(e,u),t.addApogee(e,R),t.addPerigee(e,V),t.addRcs(e,F),t.addDataStatusCode(e,U),t.addOrbitCenter(e,G),t.addOrbitType(e,A),t.addDeploymentDate(e,S),t.addManeuverable(e,g),t.addSize(e,C),t.addMass(e,y),t.addMassType(e,Y),t.addPayloads(e,Q),t.endCAT(e)}unpack(){return new ZM(this.OBJECT_NAME(),this.OBJECT_ID(),this.NORAD_CAT_ID(),this.OBJECT_TYPE(),this.OPS_STATUS_CODE(),this.OWNER(),this.LAUNCH_DATE(),this.LAUNCH_SITE(),this.DECAY_DATE(),this.PERIOD(),this.INCLINATION(),this.APOGEE(),this.PERIGEE(),this.RCS(),this.DATA_STATUS_CODE(),this.ORBIT_CENTER(),this.ORBIT_TYPE(),this.DEPLOYMENT_DATE(),this.MANEUVERABLE(),this.SIZE(),this.MASS(),this.MASS_TYPE(),this.bb.createObjList(this.PAYLOADS.bind(this),this.payloadsLength()))}unpackTo(e){e.OBJECT_NAME=this.OBJECT_NAME(),e.OBJECT_ID=this.OBJECT_ID(),e.NORAD_CAT_ID=this.NORAD_CAT_ID(),e.OBJECT_TYPE=this.OBJECT_TYPE(),e.OPS_STATUS_CODE=this.OPS_STATUS_CODE(),e.OWNER=this.OWNER(),e.LAUNCH_DATE=this.LAUNCH_DATE(),e.LAUNCH_SITE=this.LAUNCH_SITE(),e.DECAY_DATE=this.DECAY_DATE(),e.PERIOD=this.PERIOD(),e.INCLINATION=this.INCLINATION(),e.APOGEE=this.APOGEE(),e.PERIGEE=this.PERIGEE(),e.RCS=this.RCS(),e.DATA_STATUS_CODE=this.DATA_STATUS_CODE(),e.ORBIT_CENTER=this.ORBIT_CENTER(),e.ORBIT_TYPE=this.ORBIT_TYPE(),e.DEPLOYMENT_DATE=this.DEPLOYMENT_DATE(),e.MANEUVERABLE=this.MANEUVERABLE(),e.SIZE=this.SIZE(),e.MASS=this.MASS(),e.MASS_TYPE=this.MASS_TYPE(),e.PAYLOADS=this.bb.createObjList(this.PAYLOADS.bind(this),this.payloadsLength())}},ZM=class{constructor(e=null,n=null,i=0,o=aU.UNKNOWN,a=sU.UNKNOWN,s=null,l=null,r=null,d=null,m=0,h=0,u=0,R=0,V=0,F=iU.NO_CURRENT_ELEMENTS,U=null,G=lU.ORBIT,A=null,S=!1,g=0,C=0,y=oU.DRY,Y=[]){this.OBJECT_NAME=e,this.OBJECT_ID=n,this.NORAD_CAT_ID=i,this.OBJECT_TYPE=o,this.OPS_STATUS_CODE=a,this.OWNER=s,this.LAUNCH_DATE=l,this.LAUNCH_SITE=r,this.DECAY_DATE=d,this.PERIOD=m,this.INCLINATION=h,this.APOGEE=u,this.PERIGEE=R,this.RCS=V,this.DATA_STATUS_CODE=F,this.ORBIT_CENTER=U,this.ORBIT_TYPE=G,this.DEPLOYMENT_DATE=A,this.MANEUVERABLE=S,this.SIZE=g,this.MASS=C,this.MASS_TYPE=y,this.PAYLOADS=Y}pack(e){let n=this.OBJECT_NAME!==null?e.createString(this.OBJECT_NAME):0,i=this.OBJECT_ID!==null?e.createString(this.OBJECT_ID):0,o=this.OWNER!==null?e.createString(this.OWNER):0,a=this.LAUNCH_DATE!==null?e.createString(this.LAUNCH_DATE):0,s=this.LAUNCH_SITE!==null?e.createString(this.LAUNCH_SITE):0,l=this.DECAY_DATE!==null?e.createString(this.DECAY_DATE):0,r=this.ORBIT_CENTER!==null?e.createString(this.ORBIT_CENTER):0,d=this.DEPLOYMENT_DATE!==null?e.createString(this.DEPLOYMENT_DATE):0,m=rU.createPayloadsVector(e,e.createObjectOffsetList(this.PAYLOADS));return rU.createCAT(e,n,i,this.NORAD_CAT_ID,this.OBJECT_TYPE,this.OPS_STATUS_CODE,o,a,s,l,this.PERIOD,this.INCLINATION,this.APOGEE,this.PERIGEE,this.RCS,this.DATA_STATUS_CODE,r,this.ORBIT_TYPE,d,this.MANEUVERABLE,this.SIZE,this.MASS,this.MASS_TYPE,m)}};var NDi=b(W(),1);var s1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsCATCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsCATCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new rU).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startCATCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endCATCOLLECTION(e){return e.endObject()}static createCATCOLLECTION(e,n){return t.startCATCOLLECTION(e),t.addRecords(e,n),t.endCATCOLLECTION(e)}unpack(){return new RM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},RM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=s1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return s1.createCATCOLLECTION(e,n)}};var QDi=b(W(),1);var l1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsIDMCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsIDMCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new Wo).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startIDMCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endIDMCOLLECTION(e){return e.endObject()}static createIDMCOLLECTION(e,n){return t.startIDMCOLLECTION(e),t.addRecords(e,n),t.endIDMCOLLECTION(e)}unpack(){return new bM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},bM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=l1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return l1.createIDMCOLLECTION(e,n)}};var xDi=b(W(),1);var r1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsPLDCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsPLDCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new BR).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startPLDCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endPLDCOLLECTION(e){return e.endObject()}static createPLDCOLLECTION(e,n){return t.startPLDCOLLECTION(e),t.addRecords(e,n),t.endPLDCOLLECTION(e)}unpack(){return new WM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},WM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=r1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return r1.createPLDCOLLECTION(e,n)}};var Uwi=b(W(),1);var oOi=b(W(),1);var dOi=b(W(),1);var sOi=b(W(),1);var KOi=b(W(),1);var NOi=b(W(),1);var EOi=b(W(),1);var mOi=b(W(),1),D3;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(D3||(D3={}));var pOi=b(W(),1),O3;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(O3||(O3={}));var uOi=b(W(),1),H3;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(H3||(H3={}));var ROi=b(W(),1),w3;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(w3||(w3={}));var WOi=b(W(),1);var BOi=b(W(),1),P3;(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(P3||(P3={}));var kOi=b(W(),1),v3;(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(v3||(v3={}));var xOi=b(W(),1),K3;(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(K3||(K3={}));var JOi=b(W(),1),z3;(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(z3||(z3={}));var MOi=b(W(),1),j3;(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(j3||(j3={}));var qOi=b(W(),1);var gHi=b(W(),1);var RHi=b(W(),1);var lHi=b(W(),1);var iHi=b(W(),1);var tHi=b(W(),1),q3;(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(q3||(q3={}));var dHi=b(W(),1),$3;(function(t){t[t.CALCULATED=0]="CALCULATED",t[t.DEFAULT=1]="DEFAULT"})($3||($3={}));var mHi=b(W(),1),d1;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(d1||(d1={}));var WHi=b(W(),1);var FHi=b(W(),1),tK;(function(t){t[t.ELLIPSOID=0]="ELLIPSOID",t[t.BOX=1]="BOX"})(tK||(tK={}));var IHi=b(W(),1);var BHi=b(W(),1);var YHi=b(W(),1);var JHi=b(W(),1);var _Hi=b(W(),1);var HHi=b(W(),1);var vHi=b(W(),1);var cPi=b(W(),1);var iPi=b(W(),1);var sPi=b(W(),1);var Qvi=b(W(),1);var RPi=b(W(),1);var VPi=b(W(),1);var ivi=b(W(),1);var JPi=b(W(),1);var YPi=b(W(),1);var WPi=b(W(),1),eK;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(eK||(eK={}));var FPi=b(W(),1),nK;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(nK||(nK={}));var GPi=b(W(),1),iK;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(iK||(iK={}));var SPi=b(W(),1),oK;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(oK||(oK={}));var gPi=b(W(),1);var MPi=b(W(),1),aK;(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(aK||(aK={}));var DPi=b(W(),1),sK;(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(sK||(sK={}));var HPi=b(W(),1),lK;(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(lK||(lK={}));var PPi=b(W(),1),rK;(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(rK||(rK={}));var KPi=b(W(),1),dK;(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(dK||(dK={}));var svi=b(W(),1);var dvi=b(W(),1);var hvi=b(W(),1);var uvi=b(W(),1);var bvi=b(W(),1);var d3i=b(W(),1);var n3i=b(W(),1);var a3i=b(W(),1);var f3i=b(W(),1);var p3i=b(W(),1);var Z3i=b(W(),1);var D3i=b(W(),1);var g3i=b(W(),1);var A3i=b(W(),1),fM;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(fM||(fM={}));var I3i=b(W(),1);var B3i=b(W(),1);var Y3i=b(W(),1);var sKi=b(W(),1);var z3i=b(W(),1),cK;(function(t){t[t.OBSERVED=0]="OBSERVED",t[t.PREDICTED=1]="PREDICTED"})(cK||(cK={}));var $3i=b(W(),1);var nKi=b(W(),1);var CKi=b(W(),1);var mKi=b(W(),1);var ZKi=b(W(),1);var pKi=b(W(),1),mK;(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(mK||(mK={}));var fKi=b(W(),1);var GKi=b(W(),1);var zKi=b(W(),1);var _Ki=b(W(),1);var JKi=b(W(),1);var YKi=b(W(),1),hK;(function(t){t[t.OUTLIER=0]="OUTLIER"})(hK||(hK={}));var HKi=b(W(),1);var Qzi=b(W(),1);var azi=b(W(),1);var nzi=b(W(),1);var lzi=b(W(),1),pK;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(pK||(pK={}));var dzi=b(W(),1),VK;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(VK||(VK={}));var Azi=b(W(),1);var mzi=b(W(),1),uK;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(uK||(uK={}));var pzi=b(W(),1),ZK;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(ZK||(ZK={}));var uzi=b(W(),1);var gzi=b(W(),1);var g8i=b(W(),1);var Hzi=b(W(),1);var Pzi=b(W(),1);var zzi=b(W(),1);var eji=b(W(),1);var qzi=b(W(),1);var Mji=b(W(),1);var Gji=b(W(),1);var fji=b(W(),1);var iji=b(W(),1),RK;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(RK||(RK={}));var aji=b(W(),1),bK;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(bK||(bK={}));var lji=b(W(),1),WK;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(WK||(WK={}));var dji=b(W(),1),fK;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(fK||(fK={}));var mji=b(W(),1);var Sji=b(W(),1),FK;(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(FK||(FK={}));var gji=b(W(),1),UK;(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(UK||(UK={}));var Cji=b(W(),1),GK;(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(GK||(GK={}));var Nji=b(W(),1),AK;(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(AK||(AK={}));var Bji=b(W(),1),SK;(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(SK||(SK={}));var Oji=b(W(),1);var Kji=b(W(),1);var wji=b(W(),1),TK;(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(TK||(TK={}));var t4i=b(W(),1);var jji=b(W(),1),gK;(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(gK||(gK={}));var o4i=b(W(),1);var l4i=b(W(),1);var d4i=b(W(),1);var h4i=b(W(),1);var k4i=b(W(),1);var F4i=b(W(),1);var u4i=b(W(),1);var R4i=b(W(),1);var E4i=b(W(),1);var G4i=b(W(),1),EK;(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(EK||(EK={}));var X4i=b(W(),1);var M4i=b(W(),1);var O4i=b(W(),1);var P4i=b(W(),1);var U6i=b(W(),1);var u6i=b(W(),1);var h6i=b(W(),1),CK;(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(CK||(CK={}));var b6i=b(W(),1);var w6i=b(W(),1);var I6i=b(W(),1);var g6i=b(W(),1),FM;(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(FM||(FM={}));var B6i=b(W(),1);var Y6i=b(W(),1);var J6i=b(W(),1);var D7i=b(W(),1);var u7i=b(W(),1);var h7i=b(W(),1);var n7i=b(W(),1);var $6i=b(W(),1),c1;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(c1||(c1={}));var o7i=b(W(),1);var s7i=b(W(),1),UM;(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(UM||(UM={}));var b7i=b(W(),1);var F7i=b(W(),1);var A7i=b(W(),1);var g7i=b(W(),1);var I7i=b(W(),1);var sW={};vO(sW,{MET:()=>tT,METCOLLECTION:()=>m1,METCOLLECTIONT:()=>AM,METT:()=>GM,OMM:()=>eT,OMMCOLLECTION:()=>h1,OMMCOLLECTIONT:()=>TM,OMMT:()=>SM,RFM:()=>nT,RFMCOLLECTION:()=>p1,RFMCOLLECTIONT:()=>EM,RFMT:()=>gM,TIM:()=>iT,TIMCOLLECTION:()=>V1,TIMCOLLECTIONT:()=>IM,TIMT:()=>CM,ephemerisType:()=>dU,meanElementTheory:()=>fV,refFrame:()=>zc,timeSystem:()=>FV});var Yqi=b(W(),1);var aqi=b(W(),1);var nqi=b(W(),1),fV;(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(fV||(fV={}));var tT=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsMET(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsMET(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$MET")}MEAN_ELEMENT_THEORY(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):fV.SGP4}static startMET(e){e.startObject(1)}static addMeanElementTheory(e,n){e.addFieldInt8(0,n,fV.SGP4)}static endMET(e){return e.endObject()}static finishMETBuffer(e,n){e.finish(n,"$MET")}static finishSizePrefixedMETBuffer(e,n){e.finish(n,"$MET",!0)}static createMET(e,n){return t.startMET(e),t.addMeanElementTheory(e,n),t.endMET(e)}unpack(){return new GM(this.MEAN_ELEMENT_THEORY())}unpackTo(e){e.MEAN_ELEMENT_THEORY=this.MEAN_ELEMENT_THEORY()}},GM=class{constructor(e=fV.SGP4){this.MEAN_ELEMENT_THEORY=e}pack(e){return tT.createMET(e,this.MEAN_ELEMENT_THEORY)}};var rqi=b(W(),1);var m1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsMETCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsMETCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new tT).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startMETCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endMETCOLLECTION(e){return e.endObject()}static createMETCOLLECTION(e,n){return t.startMETCOLLECTION(e),t.addRecords(e,n),t.endMETCOLLECTION(e)}unpack(){return new AM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},AM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=m1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return m1.createMETCOLLECTION(e,n)}};var fqi=b(W(),1);var cqi=b(W(),1),dU;(function(t){t[t.SGP=0]="SGP",t[t.SGP4=1]="SGP4",t[t.SDP4=2]="SDP4",t[t.SGP8=3]="SGP8",t[t.SDP8=4]="SDP8"})(dU||(dU={}));var hqi=b(W(),1),zc;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(zc||(zc={}));var Vqi=b(W(),1),FV;(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(FV||(FV={}));var eT=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsOMM(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsOMM(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$OMM")}CCSDS_OMM_VERS(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readFloat64(this.bb_pos+e):0}CREATION_DATE(e){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.__string(this.bb_pos+n,e):null}ORIGINATOR(e){let n=this.bb.__offset(this.bb_pos,8);return n?this.bb.__string(this.bb_pos+n,e):null}OBJECT_NAME(e){let n=this.bb.__offset(this.bb_pos,10);return n?this.bb.__string(this.bb_pos+n,e):null}OBJECT_ID(e){let n=this.bb.__offset(this.bb_pos,12);return n?this.bb.__string(this.bb_pos+n,e):null}CENTER_NAME(e){let n=this.bb.__offset(this.bb_pos,14);return n?this.bb.__string(this.bb_pos+n,e):null}REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,16);return e?this.bb.readInt8(this.bb_pos+e):zc.TEME}REFERENCE_FRAME_EPOCH(e){let n=this.bb.__offset(this.bb_pos,18);return n?this.bb.__string(this.bb_pos+n,e):null}TIME_SYSTEM(){let e=this.bb.__offset(this.bb_pos,20);return e?this.bb.readInt8(this.bb_pos+e):FV.UTC}MEAN_ELEMENT_THEORY(){let e=this.bb.__offset(this.bb_pos,22);return e?this.bb.readInt8(this.bb_pos+e):fV.SGP4}COMMENT(e){let n=this.bb.__offset(this.bb_pos,24);return n?this.bb.__string(this.bb_pos+n,e):null}EPOCH(e){let n=this.bb.__offset(this.bb_pos,26);return n?this.bb.__string(this.bb_pos+n,e):null}SEMI_MAJOR_AXIS(){let e=this.bb.__offset(this.bb_pos,28);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION(){let e=this.bb.__offset(this.bb_pos,30);return e?this.bb.readFloat64(this.bb_pos+e):0}ECCENTRICITY(){let e=this.bb.__offset(this.bb_pos,32);return e?this.bb.readFloat64(this.bb_pos+e):0}INCLINATION(){let e=this.bb.__offset(this.bb_pos,34);return e?this.bb.readFloat64(this.bb_pos+e):0}RA_OF_ASC_NODE(){let e=this.bb.__offset(this.bb_pos,36);return e?this.bb.readFloat64(this.bb_pos+e):0}ARG_OF_PERICENTER(){let e=this.bb.__offset(this.bb_pos,38);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_ANOMALY(){let e=this.bb.__offset(this.bb_pos,40);return e?this.bb.readFloat64(this.bb_pos+e):0}GM(){let e=this.bb.__offset(this.bb_pos,42);return e?this.bb.readFloat64(this.bb_pos+e):0}MASS(){let e=this.bb.__offset(this.bb_pos,44);return e?this.bb.readFloat64(this.bb_pos+e):0}SOLAR_RAD_AREA(){let e=this.bb.__offset(this.bb_pos,46);return e?this.bb.readFloat64(this.bb_pos+e):0}SOLAR_RAD_COEFF(){let e=this.bb.__offset(this.bb_pos,48);return e?this.bb.readFloat64(this.bb_pos+e):0}DRAG_AREA(){let e=this.bb.__offset(this.bb_pos,50);return e?this.bb.readFloat64(this.bb_pos+e):0}DRAG_COEFF(){let e=this.bb.__offset(this.bb_pos,52);return e?this.bb.readFloat64(this.bb_pos+e):0}EPHEMERIS_TYPE(){let e=this.bb.__offset(this.bb_pos,54);return e?this.bb.readInt8(this.bb_pos+e):dU.SGP4}CLASSIFICATION_TYPE(e){let n=this.bb.__offset(this.bb_pos,56);return n?this.bb.__string(this.bb_pos+n,e):null}NORAD_CAT_ID(){let e=this.bb.__offset(this.bb_pos,58);return e?this.bb.readUint32(this.bb_pos+e):0}ELEMENT_SET_NO(){let e=this.bb.__offset(this.bb_pos,60);return e?this.bb.readUint32(this.bb_pos+e):0}REV_AT_EPOCH(){let e=this.bb.__offset(this.bb_pos,62);return e?this.bb.readFloat64(this.bb_pos+e):0}BSTAR(){let e=this.bb.__offset(this.bb_pos,64);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION_DOT(){let e=this.bb.__offset(this.bb_pos,66);return e?this.bb.readFloat64(this.bb_pos+e):0}MEAN_MOTION_DDOT(){let e=this.bb.__offset(this.bb_pos,68);return e?this.bb.readFloat64(this.bb_pos+e):0}COV_REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,70);return e?this.bb.readInt8(this.bb_pos+e):zc.RSW}CX_X(){let e=this.bb.__offset(this.bb_pos,72);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_X(){let e=this.bb.__offset(this.bb_pos,74);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_Y(){let e=this.bb.__offset(this.bb_pos,76);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_X(){let e=this.bb.__offset(this.bb_pos,78);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_Y(){let e=this.bb.__offset(this.bb_pos,80);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_Z(){let e=this.bb.__offset(this.bb_pos,82);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_X(){let e=this.bb.__offset(this.bb_pos,84);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_Y(){let e=this.bb.__offset(this.bb_pos,86);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_Z(){let e=this.bb.__offset(this.bb_pos,88);return e?this.bb.readFloat64(this.bb_pos+e):0}CX_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,90);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_X(){let e=this.bb.__offset(this.bb_pos,92);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Y(){let e=this.bb.__offset(this.bb_pos,94);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Z(){let e=this.bb.__offset(this.bb_pos,96);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,98);return e?this.bb.readFloat64(this.bb_pos+e):0}CY_DOT_Y_DOT(){let e=this.bb.__offset(this.bb_pos,100);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_X(){let e=this.bb.__offset(this.bb_pos,102);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Y(){let e=this.bb.__offset(this.bb_pos,104);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Z(){let e=this.bb.__offset(this.bb_pos,106);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_X_DOT(){let e=this.bb.__offset(this.bb_pos,108);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Y_DOT(){let e=this.bb.__offset(this.bb_pos,110);return e?this.bb.readFloat64(this.bb_pos+e):0}CZ_DOT_Z_DOT(){let e=this.bb.__offset(this.bb_pos,112);return e?this.bb.readFloat64(this.bb_pos+e):0}USER_DEFINED_BIP_0044_TYPE(){let e=this.bb.__offset(this.bb_pos,114);return e?this.bb.readUint32(this.bb_pos+e):0}USER_DEFINED_OBJECT_DESIGNATOR(e){let n=this.bb.__offset(this.bb_pos,116);return n?this.bb.__string(this.bb_pos+n,e):null}USER_DEFINED_EARTH_MODEL(e){let n=this.bb.__offset(this.bb_pos,118);return n?this.bb.__string(this.bb_pos+n,e):null}USER_DEFINED_EPOCH_TIMESTAMP(){let e=this.bb.__offset(this.bb_pos,120);return e?this.bb.readFloat64(this.bb_pos+e):0}USER_DEFINED_MICROSECONDS(){let e=this.bb.__offset(this.bb_pos,122);return e?this.bb.readFloat64(this.bb_pos+e):0}static startOMM(e){e.startObject(60)}static addCcsdsOmmVers(e,n){e.addFieldFloat64(0,n,0)}static addCreationDate(e,n){e.addFieldOffset(1,n,0)}static addOriginator(e,n){e.addFieldOffset(2,n,0)}static addObjectName(e,n){e.addFieldOffset(3,n,0)}static addObjectId(e,n){e.addFieldOffset(4,n,0)}static addCenterName(e,n){e.addFieldOffset(5,n,0)}static addReferenceFrame(e,n){e.addFieldInt8(6,n,zc.TEME)}static addReferenceFrameEpoch(e,n){e.addFieldOffset(7,n,0)}static addTimeSystem(e,n){e.addFieldInt8(8,n,FV.UTC)}static addMeanElementTheory(e,n){e.addFieldInt8(9,n,fV.SGP4)}static addComment(e,n){e.addFieldOffset(10,n,0)}static addEpoch(e,n){e.addFieldOffset(11,n,0)}static addSemiMajorAxis(e,n){e.addFieldFloat64(12,n,0)}static addMeanMotion(e,n){e.addFieldFloat64(13,n,0)}static addEccentricity(e,n){e.addFieldFloat64(14,n,0)}static addInclination(e,n){e.addFieldFloat64(15,n,0)}static addRaOfAscNode(e,n){e.addFieldFloat64(16,n,0)}static addArgOfPericenter(e,n){e.addFieldFloat64(17,n,0)}static addMeanAnomaly(e,n){e.addFieldFloat64(18,n,0)}static addGm(e,n){e.addFieldFloat64(19,n,0)}static addMass(e,n){e.addFieldFloat64(20,n,0)}static addSolarRadArea(e,n){e.addFieldFloat64(21,n,0)}static addSolarRadCoeff(e,n){e.addFieldFloat64(22,n,0)}static addDragArea(e,n){e.addFieldFloat64(23,n,0)}static addDragCoeff(e,n){e.addFieldFloat64(24,n,0)}static addEphemerisType(e,n){e.addFieldInt8(25,n,dU.SGP4)}static addClassificationType(e,n){e.addFieldOffset(26,n,0)}static addNoradCatId(e,n){e.addFieldInt32(27,n,0)}static addElementSetNo(e,n){e.addFieldInt32(28,n,0)}static addRevAtEpoch(e,n){e.addFieldFloat64(29,n,0)}static addBstar(e,n){e.addFieldFloat64(30,n,0)}static addMeanMotionDot(e,n){e.addFieldFloat64(31,n,0)}static addMeanMotionDdot(e,n){e.addFieldFloat64(32,n,0)}static addCovReferenceFrame(e,n){e.addFieldInt8(33,n,zc.RSW)}static addCxX(e,n){e.addFieldFloat64(34,n,0)}static addCyX(e,n){e.addFieldFloat64(35,n,0)}static addCyY(e,n){e.addFieldFloat64(36,n,0)}static addCzX(e,n){e.addFieldFloat64(37,n,0)}static addCzY(e,n){e.addFieldFloat64(38,n,0)}static addCzZ(e,n){e.addFieldFloat64(39,n,0)}static addCxDotX(e,n){e.addFieldFloat64(40,n,0)}static addCxDotY(e,n){e.addFieldFloat64(41,n,0)}static addCxDotZ(e,n){e.addFieldFloat64(42,n,0)}static addCxDotXDot(e,n){e.addFieldFloat64(43,n,0)}static addCyDotX(e,n){e.addFieldFloat64(44,n,0)}static addCyDotY(e,n){e.addFieldFloat64(45,n,0)}static addCyDotZ(e,n){e.addFieldFloat64(46,n,0)}static addCyDotXDot(e,n){e.addFieldFloat64(47,n,0)}static addCyDotYDot(e,n){e.addFieldFloat64(48,n,0)}static addCzDotX(e,n){e.addFieldFloat64(49,n,0)}static addCzDotY(e,n){e.addFieldFloat64(50,n,0)}static addCzDotZ(e,n){e.addFieldFloat64(51,n,0)}static addCzDotXDot(e,n){e.addFieldFloat64(52,n,0)}static addCzDotYDot(e,n){e.addFieldFloat64(53,n,0)}static addCzDotZDot(e,n){e.addFieldFloat64(54,n,0)}static addUserDefinedBip0044Type(e,n){e.addFieldInt32(55,n,0)}static addUserDefinedObjectDesignator(e,n){e.addFieldOffset(56,n,0)}static addUserDefinedEarthModel(e,n){e.addFieldOffset(57,n,0)}static addUserDefinedEpochTimestamp(e,n){e.addFieldFloat64(58,n,0)}static addUserDefinedMicroseconds(e,n){e.addFieldFloat64(59,n,0)}static endOMM(e){return e.endObject()}static finishOMMBuffer(e,n){e.finish(n,"$OMM")}static finishSizePrefixedOMMBuffer(e,n){e.finish(n,"$OMM",!0)}static createOMM(e,n,i,o,a,s,l,r,d,m,h,u,R,V,F,U,G,A,S,g,C,y,Y,Q,J,M,Z,E,I,B,X,_,P,w,z,H,nt,$,dt,q,at,st,Et,Qt,Wt,Nt,kt,Mt,qt,ie,oe,He,rn,de,zt,ke,Ve,We,Vn,Ct,_t){return t.startOMM(e),t.addCcsdsOmmVers(e,n),t.addCreationDate(e,i),t.addOriginator(e,o),t.addObjectName(e,a),t.addObjectId(e,s),t.addCenterName(e,l),t.addReferenceFrame(e,r),t.addReferenceFrameEpoch(e,d),t.addTimeSystem(e,m),t.addMeanElementTheory(e,h),t.addComment(e,u),t.addEpoch(e,R),t.addSemiMajorAxis(e,V),t.addMeanMotion(e,F),t.addEccentricity(e,U),t.addInclination(e,G),t.addRaOfAscNode(e,A),t.addArgOfPericenter(e,S),t.addMeanAnomaly(e,g),t.addGm(e,C),t.addMass(e,y),t.addSolarRadArea(e,Y),t.addSolarRadCoeff(e,Q),t.addDragArea(e,J),t.addDragCoeff(e,M),t.addEphemerisType(e,Z),t.addClassificationType(e,E),t.addNoradCatId(e,I),t.addElementSetNo(e,B),t.addRevAtEpoch(e,X),t.addBstar(e,_),t.addMeanMotionDot(e,P),t.addMeanMotionDdot(e,w),t.addCovReferenceFrame(e,z),t.addCxX(e,H),t.addCyX(e,nt),t.addCyY(e,$),t.addCzX(e,dt),t.addCzY(e,q),t.addCzZ(e,at),t.addCxDotX(e,st),t.addCxDotY(e,Et),t.addCxDotZ(e,Qt),t.addCxDotXDot(e,Wt),t.addCyDotX(e,Nt),t.addCyDotY(e,kt),t.addCyDotZ(e,Mt),t.addCyDotXDot(e,qt),t.addCyDotYDot(e,ie),t.addCzDotX(e,oe),t.addCzDotY(e,He),t.addCzDotZ(e,rn),t.addCzDotXDot(e,de),t.addCzDotYDot(e,zt),t.addCzDotZDot(e,ke),t.addUserDefinedBip0044Type(e,Ve),t.addUserDefinedObjectDesignator(e,We),t.addUserDefinedEarthModel(e,Vn),t.addUserDefinedEpochTimestamp(e,Ct),t.addUserDefinedMicroseconds(e,_t),t.endOMM(e)}unpack(){return new SM(this.CCSDS_OMM_VERS(),this.CREATION_DATE(),this.ORIGINATOR(),this.OBJECT_NAME(),this.OBJECT_ID(),this.CENTER_NAME(),this.REFERENCE_FRAME(),this.REFERENCE_FRAME_EPOCH(),this.TIME_SYSTEM(),this.MEAN_ELEMENT_THEORY(),this.COMMENT(),this.EPOCH(),this.SEMI_MAJOR_AXIS(),this.MEAN_MOTION(),this.ECCENTRICITY(),this.INCLINATION(),this.RA_OF_ASC_NODE(),this.ARG_OF_PERICENTER(),this.MEAN_ANOMALY(),this.GM(),this.MASS(),this.SOLAR_RAD_AREA(),this.SOLAR_RAD_COEFF(),this.DRAG_AREA(),this.DRAG_COEFF(),this.EPHEMERIS_TYPE(),this.CLASSIFICATION_TYPE(),this.NORAD_CAT_ID(),this.ELEMENT_SET_NO(),this.REV_AT_EPOCH(),this.BSTAR(),this.MEAN_MOTION_DOT(),this.MEAN_MOTION_DDOT(),this.COV_REFERENCE_FRAME(),this.CX_X(),this.CY_X(),this.CY_Y(),this.CZ_X(),this.CZ_Y(),this.CZ_Z(),this.CX_DOT_X(),this.CX_DOT_Y(),this.CX_DOT_Z(),this.CX_DOT_X_DOT(),this.CY_DOT_X(),this.CY_DOT_Y(),this.CY_DOT_Z(),this.CY_DOT_X_DOT(),this.CY_DOT_Y_DOT(),this.CZ_DOT_X(),this.CZ_DOT_Y(),this.CZ_DOT_Z(),this.CZ_DOT_X_DOT(),this.CZ_DOT_Y_DOT(),this.CZ_DOT_Z_DOT(),this.USER_DEFINED_BIP_0044_TYPE(),this.USER_DEFINED_OBJECT_DESIGNATOR(),this.USER_DEFINED_EARTH_MODEL(),this.USER_DEFINED_EPOCH_TIMESTAMP(),this.USER_DEFINED_MICROSECONDS())}unpackTo(e){e.CCSDS_OMM_VERS=this.CCSDS_OMM_VERS(),e.CREATION_DATE=this.CREATION_DATE(),e.ORIGINATOR=this.ORIGINATOR(),e.OBJECT_NAME=this.OBJECT_NAME(),e.OBJECT_ID=this.OBJECT_ID(),e.CENTER_NAME=this.CENTER_NAME(),e.REFERENCE_FRAME=this.REFERENCE_FRAME(),e.REFERENCE_FRAME_EPOCH=this.REFERENCE_FRAME_EPOCH(),e.TIME_SYSTEM=this.TIME_SYSTEM(),e.MEAN_ELEMENT_THEORY=this.MEAN_ELEMENT_THEORY(),e.COMMENT=this.COMMENT(),e.EPOCH=this.EPOCH(),e.SEMI_MAJOR_AXIS=this.SEMI_MAJOR_AXIS(),e.MEAN_MOTION=this.MEAN_MOTION(),e.ECCENTRICITY=this.ECCENTRICITY(),e.INCLINATION=this.INCLINATION(),e.RA_OF_ASC_NODE=this.RA_OF_ASC_NODE(),e.ARG_OF_PERICENTER=this.ARG_OF_PERICENTER(),e.MEAN_ANOMALY=this.MEAN_ANOMALY(),e.GM=this.GM(),e.MASS=this.MASS(),e.SOLAR_RAD_AREA=this.SOLAR_RAD_AREA(),e.SOLAR_RAD_COEFF=this.SOLAR_RAD_COEFF(),e.DRAG_AREA=this.DRAG_AREA(),e.DRAG_COEFF=this.DRAG_COEFF(),e.EPHEMERIS_TYPE=this.EPHEMERIS_TYPE(),e.CLASSIFICATION_TYPE=this.CLASSIFICATION_TYPE(),e.NORAD_CAT_ID=this.NORAD_CAT_ID(),e.ELEMENT_SET_NO=this.ELEMENT_SET_NO(),e.REV_AT_EPOCH=this.REV_AT_EPOCH(),e.BSTAR=this.BSTAR(),e.MEAN_MOTION_DOT=this.MEAN_MOTION_DOT(),e.MEAN_MOTION_DDOT=this.MEAN_MOTION_DDOT(),e.COV_REFERENCE_FRAME=this.COV_REFERENCE_FRAME(),e.CX_X=this.CX_X(),e.CY_X=this.CY_X(),e.CY_Y=this.CY_Y(),e.CZ_X=this.CZ_X(),e.CZ_Y=this.CZ_Y(),e.CZ_Z=this.CZ_Z(),e.CX_DOT_X=this.CX_DOT_X(),e.CX_DOT_Y=this.CX_DOT_Y(),e.CX_DOT_Z=this.CX_DOT_Z(),e.CX_DOT_X_DOT=this.CX_DOT_X_DOT(),e.CY_DOT_X=this.CY_DOT_X(),e.CY_DOT_Y=this.CY_DOT_Y(),e.CY_DOT_Z=this.CY_DOT_Z(),e.CY_DOT_X_DOT=this.CY_DOT_X_DOT(),e.CY_DOT_Y_DOT=this.CY_DOT_Y_DOT(),e.CZ_DOT_X=this.CZ_DOT_X(),e.CZ_DOT_Y=this.CZ_DOT_Y(),e.CZ_DOT_Z=this.CZ_DOT_Z(),e.CZ_DOT_X_DOT=this.CZ_DOT_X_DOT(),e.CZ_DOT_Y_DOT=this.CZ_DOT_Y_DOT(),e.CZ_DOT_Z_DOT=this.CZ_DOT_Z_DOT(),e.USER_DEFINED_BIP_0044_TYPE=this.USER_DEFINED_BIP_0044_TYPE(),e.USER_DEFINED_OBJECT_DESIGNATOR=this.USER_DEFINED_OBJECT_DESIGNATOR(),e.USER_DEFINED_EARTH_MODEL=this.USER_DEFINED_EARTH_MODEL(),e.USER_DEFINED_EPOCH_TIMESTAMP=this.USER_DEFINED_EPOCH_TIMESTAMP(),e.USER_DEFINED_MICROSECONDS=this.USER_DEFINED_MICROSECONDS()}},SM=class{constructor(e=0,n=null,i=null,o=null,a=null,s=null,l=zc.TEME,r=null,d=FV.UTC,m=fV.SGP4,h=null,u=null,R=0,V=0,F=0,U=0,G=0,A=0,S=0,g=0,C=0,y=0,Y=0,Q=0,J=0,M=dU.SGP4,Z=null,E=0,I=0,B=0,X=0,_=0,P=0,w=zc.RSW,z=0,H=0,nt=0,$=0,dt=0,q=0,at=0,st=0,Et=0,Qt=0,Wt=0,Nt=0,kt=0,Mt=0,qt=0,ie=0,oe=0,He=0,rn=0,de=0,zt=0,ke=0,Ve=null,We=null,Vn=0,Ct=0){this.CCSDS_OMM_VERS=e,this.CREATION_DATE=n,this.ORIGINATOR=i,this.OBJECT_NAME=o,this.OBJECT_ID=a,this.CENTER_NAME=s,this.REFERENCE_FRAME=l,this.REFERENCE_FRAME_EPOCH=r,this.TIME_SYSTEM=d,this.MEAN_ELEMENT_THEORY=m,this.COMMENT=h,this.EPOCH=u,this.SEMI_MAJOR_AXIS=R,this.MEAN_MOTION=V,this.ECCENTRICITY=F,this.INCLINATION=U,this.RA_OF_ASC_NODE=G,this.ARG_OF_PERICENTER=A,this.MEAN_ANOMALY=S,this.GM=g,this.MASS=C,this.SOLAR_RAD_AREA=y,this.SOLAR_RAD_COEFF=Y,this.DRAG_AREA=Q,this.DRAG_COEFF=J,this.EPHEMERIS_TYPE=M,this.CLASSIFICATION_TYPE=Z,this.NORAD_CAT_ID=E,this.ELEMENT_SET_NO=I,this.REV_AT_EPOCH=B,this.BSTAR=X,this.MEAN_MOTION_DOT=_,this.MEAN_MOTION_DDOT=P,this.COV_REFERENCE_FRAME=w,this.CX_X=z,this.CY_X=H,this.CY_Y=nt,this.CZ_X=$,this.CZ_Y=dt,this.CZ_Z=q,this.CX_DOT_X=at,this.CX_DOT_Y=st,this.CX_DOT_Z=Et,this.CX_DOT_X_DOT=Qt,this.CY_DOT_X=Wt,this.CY_DOT_Y=Nt,this.CY_DOT_Z=kt,this.CY_DOT_X_DOT=Mt,this.CY_DOT_Y_DOT=qt,this.CZ_DOT_X=ie,this.CZ_DOT_Y=oe,this.CZ_DOT_Z=He,this.CZ_DOT_X_DOT=rn,this.CZ_DOT_Y_DOT=de,this.CZ_DOT_Z_DOT=zt,this.USER_DEFINED_BIP_0044_TYPE=ke,this.USER_DEFINED_OBJECT_DESIGNATOR=Ve,this.USER_DEFINED_EARTH_MODEL=We,this.USER_DEFINED_EPOCH_TIMESTAMP=Vn,this.USER_DEFINED_MICROSECONDS=Ct}pack(e){let n=this.CREATION_DATE!==null?e.createString(this.CREATION_DATE):0,i=this.ORIGINATOR!==null?e.createString(this.ORIGINATOR):0,o=this.OBJECT_NAME!==null?e.createString(this.OBJECT_NAME):0,a=this.OBJECT_ID!==null?e.createString(this.OBJECT_ID):0,s=this.CENTER_NAME!==null?e.createString(this.CENTER_NAME):0,l=this.REFERENCE_FRAME_EPOCH!==null?e.createString(this.REFERENCE_FRAME_EPOCH):0,r=this.COMMENT!==null?e.createString(this.COMMENT):0,d=this.EPOCH!==null?e.createString(this.EPOCH):0,m=this.CLASSIFICATION_TYPE!==null?e.createString(this.CLASSIFICATION_TYPE):0,h=this.USER_DEFINED_OBJECT_DESIGNATOR!==null?e.createString(this.USER_DEFINED_OBJECT_DESIGNATOR):0,u=this.USER_DEFINED_EARTH_MODEL!==null?e.createString(this.USER_DEFINED_EARTH_MODEL):0;return eT.createOMM(e,this.CCSDS_OMM_VERS,n,i,o,a,s,this.REFERENCE_FRAME,l,this.TIME_SYSTEM,this.MEAN_ELEMENT_THEORY,r,d,this.SEMI_MAJOR_AXIS,this.MEAN_MOTION,this.ECCENTRICITY,this.INCLINATION,this.RA_OF_ASC_NODE,this.ARG_OF_PERICENTER,this.MEAN_ANOMALY,this.GM,this.MASS,this.SOLAR_RAD_AREA,this.SOLAR_RAD_COEFF,this.DRAG_AREA,this.DRAG_COEFF,this.EPHEMERIS_TYPE,m,this.NORAD_CAT_ID,this.ELEMENT_SET_NO,this.REV_AT_EPOCH,this.BSTAR,this.MEAN_MOTION_DOT,this.MEAN_MOTION_DDOT,this.COV_REFERENCE_FRAME,this.CX_X,this.CY_X,this.CY_Y,this.CZ_X,this.CZ_Y,this.CZ_Z,this.CX_DOT_X,this.CX_DOT_Y,this.CX_DOT_Z,this.CX_DOT_X_DOT,this.CY_DOT_X,this.CY_DOT_Y,this.CY_DOT_Z,this.CY_DOT_X_DOT,this.CY_DOT_Y_DOT,this.CZ_DOT_X,this.CZ_DOT_Y,this.CZ_DOT_Z,this.CZ_DOT_X_DOT,this.CZ_DOT_Y_DOT,this.CZ_DOT_Z_DOT,this.USER_DEFINED_BIP_0044_TYPE,h,u,this.USER_DEFINED_EPOCH_TIMESTAMP,this.USER_DEFINED_MICROSECONDS)}};var Gqi=b(W(),1);var h1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsOMMCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsOMMCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new eT).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startOMMCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endOMMCOLLECTION(e){return e.endObject()}static createOMMCOLLECTION(e,n){return t.startOMMCOLLECTION(e),t.addRecords(e,n),t.endOMMCOLLECTION(e)}unpack(){return new TM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},TM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=h1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return h1.createOMMCOLLECTION(e,n)}};var Tqi=b(W(),1);var nT=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsRFM(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsRFM(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$RFM")}REFERENCE_FRAME(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):zc.ECEF}static startRFM(e){e.startObject(1)}static addReferenceFrame(e,n){e.addFieldInt8(0,n,zc.ECEF)}static endRFM(e){return e.endObject()}static finishRFMBuffer(e,n){e.finish(n,"$RFM")}static finishSizePrefixedRFMBuffer(e,n){e.finish(n,"$RFM",!0)}static createRFM(e,n){return t.startRFM(e),t.addReferenceFrame(e,n),t.endRFM(e)}unpack(){return new gM(this.REFERENCE_FRAME())}unpackTo(e){e.REFERENCE_FRAME=this.REFERENCE_FRAME()}},gM=class{constructor(e=zc.ECEF){this.REFERENCE_FRAME=e}pack(e){return nT.createRFM(e,this.REFERENCE_FRAME)}};var Cqi=b(W(),1);var p1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsRFMCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsRFMCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new nT).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startRFMCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endRFMCOLLECTION(e){return e.endObject()}static createRFMCOLLECTION(e,n){return t.startRFMCOLLECTION(e),t.addRecords(e,n),t.endRFMCOLLECTION(e)}unpack(){return new EM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},EM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=p1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return p1.createRFMCOLLECTION(e,n)}};var yqi=b(W(),1);var iT=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsTIM(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsTIM(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static bufferHasIdentifier(e){return e.__has_identifier("$TIM")}TIME_SYSTEM(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.readInt8(this.bb_pos+e):FV.GMST}static startTIM(e){e.startObject(1)}static addTimeSystem(e,n){e.addFieldInt8(0,n,FV.GMST)}static endTIM(e){return e.endObject()}static finishTIMBuffer(e,n){e.finish(n,"$TIM")}static finishSizePrefixedTIMBuffer(e,n){e.finish(n,"$TIM",!0)}static createTIM(e,n){return t.startTIM(e),t.addTimeSystem(e,n),t.endTIM(e)}unpack(){return new CM(this.TIME_SYSTEM())}unpackTo(e){e.TIME_SYSTEM=this.TIME_SYSTEM()}},CM=class{constructor(e=FV.GMST){this.TIME_SYSTEM=e}pack(e){return iT.createTIM(e,this.TIME_SYSTEM)}};var kqi=b(W(),1);var V1=class t{constructor(){this.bb=null,this.bb_pos=0}__init(e,n){return this.bb_pos=e,this.bb=n,this}static getRootAsTIMCOLLECTION(e,n){return(n||new t).__init(e.readInt32(e.position())+e.position(),e)}static getSizePrefixedRootAsTIMCOLLECTION(e,n){return e.setPosition(e.position()+4),(n||new t).__init(e.readInt32(e.position())+e.position(),e)}RECORDS(e,n){let i=this.bb.__offset(this.bb_pos,4);return i?(n||new iT).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+i)+e*4),this.bb):null}recordsLength(){let e=this.bb.__offset(this.bb_pos,4);return e?this.bb.__vector_len(this.bb_pos+e):0}static startTIMCOLLECTION(e){e.startObject(1)}static addRecords(e,n){e.addFieldOffset(0,n,0)}static createRecordsVector(e,n){e.startVector(4,n.length,4);for(let i=n.length-1;i>=0;i--)e.addOffset(n[i]);return e.endVector()}static startRecordsVector(e,n){e.startVector(4,n,4)}static endTIMCOLLECTION(e){return e.endObject()}static createTIMCOLLECTION(e,n){return t.startTIMCOLLECTION(e),t.addRecords(e,n),t.endTIMCOLLECTION(e)}unpack(){return new IM(this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength()))}unpackTo(e){e.RECORDS=this.bb.createObjList(this.RECORDS.bind(this),this.recordsLength())}},IM=class{constructor(e=[]){this.RECORDS=e}pack(e){let n=V1.createRecordsVector(e,e.createObjectOffsetList(this.RECORDS));return V1.createTIMCOLLECTION(e,n)}};var i$i=b(W(),1);var zqi=b(W(),1);var $qi=b(W(),1);var v$i=b(W(),1);var c$i=b(W(),1);var l$i=b(W(),1);var h$i=b(W(),1),IK;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(IK||(IK={}));var V$i=b(W(),1),NK;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(NK||(NK={}));var C$i=b(W(),1);var Z$i=b(W(),1),yK;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(yK||(yK={}));var b$i=b(W(),1),BK;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(BK||(BK={}));var f$i=b(W(),1);var y$i=b(W(),1);var k$i=b(W(),1);var X$i=b(W(),1);var Vto=b(W(),1);var lto=b(W(),1);var cto=b(W(),1);var Cto=b(W(),1);var Fto=b(W(),1);var bto=b(W(),1);var Ato=b(W(),1);var oro=b(W(),1);var Qto=b(W(),1);var Yto=b(W(),1);var Jto=b(W(),1);var Oto=b(W(),1);var Mto=b(W(),1);var Ieo=b(W(),1);var heo=b(W(),1);var deo=b(W(),1);var wto=b(W(),1),QK;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(QK||(QK={}));var vto=b(W(),1),kK;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(kK||(kK={}));var zto=b(W(),1),YK;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(YK||(YK={}));var qto=b(W(),1),xK;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(xK||(xK={}));var teo=b(W(),1);var Veo=b(W(),1),JK;(function(t){t[t.NO_CURRENT_ELEMENTS=0]="NO_CURRENT_ELEMENTS",t[t.NO_INITIAL_ELEMENTS=1]="NO_INITIAL_ELEMENTS",t[t.NO_ELEMENTS_AVAILABLE=2]="NO_ELEMENTS_AVAILABLE",t[t.OK=3]="OK"})(JK||(JK={}));var Zeo=b(W(),1),LK;(function(t){t[t.DRY=0]="DRY",t[t.WET=1]="WET"})(LK||(LK={}));var beo=b(W(),1),MK;(function(t){t[t.PAYLOAD=0]="PAYLOAD",t[t.ROCKET_BODY=1]="ROCKET_BODY",t[t.DEBRIS=2]="DEBRIS",t[t.UNKNOWN=3]="UNKNOWN"})(MK||(MK={}));var feo=b(W(),1),_K;(function(t){t[t.OPERATIONAL=0]="OPERATIONAL",t[t.NONOPERATIONAL=1]="NONOPERATIONAL",t[t.PARTIALLY_OPERATIONAL=2]="PARTIALLY_OPERATIONAL",t[t.BACKUP_STANDBY=3]="BACKUP_STANDBY",t[t.SPARE=4]="SPARE",t[t.EXTENDED_MISSION=5]="EXTENDED_MISSION",t[t.DECAYED=6]="DECAYED",t[t.UNKNOWN=7]="UNKNOWN"})(_K||(_K={}));var Ueo=b(W(),1),DK;(function(t){t[t.ORBIT=0]="ORBIT",t[t.LANDING=1]="LANDING",t[t.IMPACT=2]="IMPACT",t[t.DOCKED=3]="DOCKED",t[t.ROUNDTRIP=4]="ROUNDTRIP"})(DK||(DK={}));var Beo=b(W(),1);var rno=b(W(),1);var qeo=b(W(),1);var _eo=b(W(),1);var Xeo=b(W(),1);var keo=b(W(),1),OK;(function(t){t[t.Signing=0]="Signing",t[t.Encryption=1]="Encryption"})(OK||(OK={}));var Oeo=b(W(),1),HK;(function(t){t[t.CALCULATED=0]="CALCULATED",t[t.DEFAULT=1]="DEFAULT"})(HK||(HK={}));var weo=b(W(),1),$u;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})($u||($u={}));var tno=b(W(),1);var nno=b(W(),1),PK;(function(t){t[t.ELLIPSOID=0]="ELLIPSOID",t[t.BOX=1]="BOX"})(PK||(PK={}));var mno=b(W(),1);var pno=b(W(),1);var Zno=b(W(),1);var Wno=b(W(),1);var Uno=b(W(),1);var Ano=b(W(),1);var gno=b(W(),1);var Cno=b(W(),1),vK;(function(t){t[t.OBSERVED=0]="OBSERVED",t[t.PREDICTED=1]="PREDICTED"})(vK||(vK={}));var Nno=b(W(),1);var Qno=b(W(),1);var Jno=b(W(),1);var Yno=b(W(),1),KK;(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(KK||(KK={}));var _no=b(W(),1);var Hno=b(W(),1);var vno=b(W(),1);var jno=b(W(),1);var tio=b(W(),1);var nio=b(W(),1);var cio=b(W(),1);var lio=b(W(),1);var oio=b(W(),1),zK;(function(t){t[t.OUTLIER=0]="OUTLIER"})(zK||(zK={}));var pio=b(W(),1);var Zio=b(W(),1);var Jio=b(W(),1);var Sio=b(W(),1);var Wio=b(W(),1);var Fio=b(W(),1);var yio=b(W(),1);var gio=b(W(),1),jK;(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(jK||(jK={}));var _io=b(W(),1);var Pio=b(W(),1);var Oio=b(W(),1),u1;(function(t){t[t.SGP4=0]="SGP4",t[t.SGP4XP=1]="SGP4XP",t[t.DSST=2]="DSST",t[t.USM=3]="USM"})(u1||(u1={}));var zio=b(W(),1);var $io=b(W(),1);var noo=b(W(),1);var boo=b(W(),1);var uoo=b(W(),1);var aoo=b(W(),1);var loo=b(W(),1);var doo=b(W(),1),Z1;(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(Z1||(Z1={}));var Foo=b(W(),1);var Coo=b(W(),1);var Goo=b(W(),1),qK;(function(t){t[t.SGP=0]="SGP",t[t.SGP4=1]="SGP4",t[t.SDP4=2]="SDP4",t[t.SGP8=3]="SGP8",t[t.SDP8=4]="SDP8"})(qK||(qK={}));var yoo=b(W(),1);var Qoo=b(W(),1);var xoo=b(W(),1);var Loo=b(W(),1);var Doo=b(W(),1);var voo=b(W(),1);var Hoo=b(W(),1);var joo=b(W(),1);var Pao=b(W(),1);var Oao=b(W(),1);var Lao=b(W(),1);var tao=b(W(),1);var aao=b(W(),1);var nao=b(W(),1);var rao=b(W(),1);var mao=b(W(),1);var $K;(function(t){t[t.NONE=0]="NONE",t[t.MPE=1]="MPE",t[t.OMM=2]="OMM",t[t.PLD=3]="PLD",t[t.RFM=4]="RFM",t[t.CSM=5]="CSM",t[t.OSM=6]="OSM",t[t.CAT=7]="CAT",t[t.CRM=8]="CRM",t[t.SCM=9]="SCM",t[t.TDM=10]="TDM",t[t.IDM=11]="IDM",t[t.MET=12]="MET",t[t.ROC=13]="ROC",t[t.BOV=14]="BOV",t[t.EOP=15]="EOP",t[t.EOO=16]="EOO",t[t.EME=17]="EME",t[t.LDM=18]="LDM",t[t.PNM=19]="PNM",t[t.HYP=20]="HYP",t[t.CTR=21]="CTR",t[t.CDM=22]="CDM",t[t.SIT=23]="SIT",t[t.OEM=24]="OEM",t[t.TIM=25]="TIM",t[t.EPM=26]="EPM",t[t.PRG=27]="PRG"})($K||($K={}));var zao=b(W(),1);var $ao=b(W(),1);var nso=b(W(),1);var aso=b(W(),1);var rso=b(W(),1);var mso=b(W(),1);var eco=b(W(),1);var vdo=b(W(),1);var Hdo=b(W(),1),tz;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(tz||(tz={}));var jdo=b(W(),1);var Eco=b(W(),1);var dco=b(W(),1);var sco=b(W(),1),ez;(function(t){t[t.LIQUID=0]="LIQUID",t[t.SOLID=1]="SOLID",t[t.HYBRID=2]="HYBRID",t[t.ION=3]="ION",t[t.NUCLEAR_THERMAL=4]="NUCLEAR_THERMAL",t[t.OTHER=5]="OTHER"})(ez||(ez={}));var bco=b(W(),1);var hco=b(W(),1);var Vco=b(W(),1);var Fco=b(W(),1);var Pco=b(W(),1);var Yco=b(W(),1);var Jco=b(W(),1);var _co=b(W(),1);var wmo=b(W(),1);var emo=b(W(),1);var qco=b(W(),1);var imo=b(W(),1),nz;(function(t){t[t.REAL=0]="REAL",t[t.SIMULATED=1]="SIMULATED",t[t.SYNTHETIC=2]="SYNTHETIC"})(nz||(nz={}));var amo=b(W(),1),iz;(function(t){t[t.UNKNOWN=0]="UNKNOWN",t[t.OPTICAL=1]="OPTICAL",t[t.INFRARED_SENSOR=2]="INFRARED_SENSOR",t[t.ULTRAVIOLET_SENSOR=3]="ULTRAVIOLET_SENSOR",t[t.X_RAY_SENSOR=4]="X_RAY_SENSOR",t[t.GAMMA_RAY_SENSOR=5]="GAMMA_RAY_SENSOR",t[t.RADAR=6]="RADAR",t[t.PHASED_ARRAY_RADAR=7]="PHASED_ARRAY_RADAR",t[t.SYNTHETIC_APERTURE_RADAR=8]="SYNTHETIC_APERTURE_RADAR",t[t.BISTATIC_RADIO_TELESCOPE=9]="BISTATIC_RADIO_TELESCOPE",t[t.RADIO_TELESCOPE=10]="RADIO_TELESCOPE",t[t.ATMOSPHERIC_SENSOR=11]="ATMOSPHERIC_SENSOR",t[t.SPACE_WEATHER_SENSOR=12]="SPACE_WEATHER_SENSOR",t[t.ENVIRONMENTAL_SENSOR=13]="ENVIRONMENTAL_SENSOR",t[t.SEISMIC_SENSOR=14]="SEISMIC_SENSOR",t[t.GRAVIMETRIC_SENSOR=15]="GRAVIMETRIC_SENSOR",t[t.MAGNETIC_SENSOR=16]="MAGNETIC_SENSOR",t[t.ELECTROMAGNETIC_SENSOR=17]="ELECTROMAGNETIC_SENSOR",t[t.THERMAL_SENSOR=18]="THERMAL_SENSOR",t[t.CHEMICAL_SENSOR=19]="CHEMICAL_SENSOR",t[t.BIOLOGICAL_SENSOR=20]="BIOLOGICAL_SENSOR",t[t.RADIATION_SENSOR=21]="RADIATION_SENSOR",t[t.PARTICLE_DETECTOR=22]="PARTICLE_DETECTOR",t[t.LIDAR=23]="LIDAR",t[t.SONAR=24]="SONAR",t[t.TELESCOPE=25]="TELESCOPE",t[t.SPECTROSCOPIC_SENSOR=26]="SPECTROSCOPIC_SENSOR",t[t.PHOTOMETRIC_SENSOR=27]="PHOTOMETRIC_SENSOR",t[t.POLARIMETRIC_SENSOR=28]="POLARIMETRIC_SENSOR",t[t.INTERFEROMETRIC_SENSOR=29]="INTERFEROMETRIC_SENSOR",t[t.MULTISPECTRAL_SENSOR=30]="MULTISPECTRAL_SENSOR",t[t.HYPERSPECTRAL_SENSOR=31]="HYPERSPECTRAL_SENSOR",t[t.GPS_RECEIVER=32]="GPS_RECEIVER",t[t.RADIO_COMMUNICATIONS=33]="RADIO_COMMUNICATIONS",t[t.LASER_COMMUNICATIONS=34]="LASER_COMMUNICATIONS",t[t.SATELLITE_COMMUNICATIONS=35]="SATELLITE_COMMUNICATIONS",t[t.LASER_INSTRUMENT=36]="LASER_INSTRUMENT",t[t.RF_ANALYZER=37]="RF_ANALYZER",t[t.IONOSPHERIC_SENSOR=38]="IONOSPHERIC_SENSOR",t[t.LASER_IMAGING=39]="LASER_IMAGING",t[t.OPTICAL_TELESCOPE=40]="OPTICAL_TELESCOPE",t[t.HIGH_RESOLUTION_OPTICAL=41]="HIGH_RESOLUTION_OPTICAL",t[t.RADIO=42]="RADIO",t[t.MICROWAVE_TRANSMITTER=43]="MICROWAVE_TRANSMITTER",t[t.RF_MONITOR=44]="RF_MONITOR",t[t.HF_RADIO_COMMUNICATIONS=45]="HF_RADIO_COMMUNICATIONS"})(iz||(iz={}));var lmo=b(W(),1);var Umo=b(W(),1);var dmo=b(W(),1),oz;(function(t){t[t.linear=0]="linear",t[t.circular=1]="circular",t[t.elliptical=2]="elliptical",t[t.unpolarized=3]="unpolarized"})(oz||(oz={}));var mmo=b(W(),1),az;(function(t){t[t.vertical=0]="vertical",t[t.horizontal=1]="horizontal",t[t.leftHandCircular=2]="leftHandCircular",t[t.rightHandCircular=3]="rightHandCircular"})(az||(az={}));var pmo=b(W(),1);var Smo=b(W(),1);var ymo=b(W(),1);var gmo=b(W(),1),sz;(function(t){t[t.LAUNCH_SITE=0]="LAUNCH_SITE",t[t.OBSERVATION_STATION=1]="OBSERVATION_STATION",t[t.HOBBYIST_OBSERVER=2]="HOBBYIST_OBSERVER",t[t.RESEARCH_FACILITY=3]="RESEARCH_FACILITY",t[t.SATELLITE_GROUND_STATION=4]="SATELLITE_GROUND_STATION",t[t.SPACEPORT=5]="SPACEPORT",t[t.MILITARY_BASE=6]="MILITARY_BASE",t[t.WEATHER_STATION=7]="WEATHER_STATION",t[t.ASTRONOMICAL_OBSERVATORY=8]="ASTRONOMICAL_OBSERVATORY",t[t.EDUCATIONAL_INSTITUTE=9]="EDUCATIONAL_INSTITUTE",t[t.COMMUNICATION_HUB=10]="COMMUNICATION_HUB",t[t.POWER_PLANT=11]="POWER_PLANT",t[t.INDUSTRIAL_COMPLEX=12]="INDUSTRIAL_COMPLEX",t[t.TRANSPORTATION_HUB=13]="TRANSPORTATION_HUB",t[t.URBAN_AREA=14]="URBAN_AREA",t[t.NATIONAL_PARK=15]="NATIONAL_PARK",t[t.HISTORICAL_SITE=16]="HISTORICAL_SITE",t[t.OTHER=17]="OTHER"})(sz||(sz={}));var kmo=b(W(),1);var Tho=b(W(),1);var cho=b(W(),1);var lho=b(W(),1),yM;(function(t){t[t.ECEF=0]="ECEF",t[t.ICRF=1]="ICRF",t[t.TEME=2]="TEME",t[t.ENU=3]="ENU",t[t.NED=4]="NED",t[t.NEU=5]="NEU",t[t.RIC=6]="RIC",t[t.J2000=7]="J2000",t[t.GCRF=8]="GCRF",t[t.GRC=9]="GRC",t[t.ITRF2000=10]="ITRF2000",t[t.ITRF93=11]="ITRF93",t[t.ITRF97=12]="ITRF97",t[t.TDR=13]="TDR",t[t.TOD=14]="TOD",t[t.RTN=15]="RTN",t[t.TVN=16]="TVN",t[t.VVLH=17]="VVLH",t[t.VLVH=18]="VLVH",t[t.LTP=19]="LTP",t[t.LVLH=20]="LVLH",t[t.PNE=21]="PNE",t[t.BRF=22]="BRF",t[t.RSW=23]="RSW",t[t.TNW=24]="TNW"})(yM||(yM={}));var pho=b(W(),1);var Zho=b(W(),1);var Who=b(W(),1);var Dho=b(W(),1);var Yho=b(W(),1);var Bho=b(W(),1),lz;(function(t){t[t.GMST=0]="GMST",t[t.GPS=1]="GPS",t[t.MET=2]="MET",t[t.MRT=3]="MRT",t[t.SCLK=4]="SCLK",t[t.TAI=5]="TAI",t[t.TCB=6]="TCB",t[t.TDB=7]="TDB",t[t.TCG=8]="TCG",t[t.TT=9]="TT",t[t.UT1=10]="UT1",t[t.UTC=11]="UTC"})(lz||(lz={}));var Jho=b(W(),1);var{OMMT:ZTe,OMMCOLLECTIONT:apo}=sW,{CATT:RTe,CATCOLLECTIONT:spo}=aW;Number.prototype.map=function(t,e,n,i){return(this-t)*(i-n)/(e-t)+n};var oT=class extends qa{constructor(e,n,i,o){super(e),this.constructor.prototype.wasmSchema={},this._position=new Bs,this._spaceCatalog=i,this._wasmModule=n,this._velocity={getValue:(a,s)=>this._velocity.getValueInReferenceFrame(a,0,s),getValueInReferenceFrame:(a,s,l)=>{let r=new Float64Array(n.HEAP8.buffer,i.getVelocity(this.properties.wasmSpaceEntity,rt.toDate(a).getTime(),s!==ri.TEME),3);if(c(l)||(l=new p),l=p.fromArray(r),s===ri.INERTIAL){let d=Pe.computeFixedToIcrfMatrix(a);if(c(d)){let m=new p;ot.multiplyByVector(d,l,m),l=m}}return l}},Object.defineProperty(this,"velocity",{get:()=>this._velocity,set:()=>{}}),Object.defineProperties(this._position,{isConstant:{get:()=>!1},_referenceFrame:{get:()=>this.entityCollection.referenceFrame},referenceFrame:{get:()=>this._referenceFrame}}),this._position.getValue=(a,s)=>this._position.getValueInReferenceFrame(a,0,s),this._position.getValueInReferenceFrame=(a,s,l)=>{let r=new Float64Array(n.HEAP8.buffer,i.getPositionInReferenceFrame(this.properties.wasmSpaceEntity,rt.toDate(a).getTime(),s!==ri.TEME),3);if(c(l)||(l=new p),l=p.fromArray(r),s===ri.INERTIAL){let d=Pe.computeFixedToIcrfMatrix(a);if(c(d)){let m=new p;ot.multiplyByVector(d,l,m),l=m}}return l},this.children={add:a=>(a=this.entityCollection.add(a),this.entityCollection.allValues||(Object.defineProperty(this.entityCollection,"allValues",{get:function(){return this._entities.values}}),Object.defineProperty(this.entityCollection,"values",{get:function(){return this._entities.values.filter(s=>!s._isChild)}})),a._isChild=!0,a.parent=this,a.position=this.position,a),remove:a=>{this.entityCollection.remove(a);let s=this._children.indexOf(this);this._children.splice(s,1)},values:this._children},this.loadOMM(o)}loadOMM(e){let n=new this._wasmModule.PropagatedPositionProperty;n.addOMM(e),this.properties.wasmSpaceEntity=n,this.properties.CAT=this.properties._CAT||new RTe,this.properties._CAT._value.APOGEE=n.apogee,this.properties._CAT._value.PERIGEE=n.perigee,this.properties._CAT._value.PERIOD=n.period_sec,this.properties.OMM=this.properties._OMM||new ZTe,this.properties._OMM._value.ECCENTRICITY=n.ecco,this.properties._OMM._value.SEMI_MAJOR_AXIS=n.semi_major_axis/1e3,this.properties._OMM._value.SEMI_MINOR_AXIS=n.semi_minor_axis/1e3,this.array_index=this.properties.wasmSpaceEntity.array_index,this.samplesPerPeriod=180,this.extraEpochSamples=60,this.resolutionAtEpoch=5,this.autoEpochResolution=!0,this.epochBlockSize=.5,this.extraSamples=5,this.eccentricityThreshold=.2,this.targetIntervalCount=20,this._orbitShowing=!1,this._coverageShowing=!1,this.referenceFrame=ri.RIC,this._position._clearCache=!0}get orbitShowing(){return this._orbitShowing}get coverageShowing(){return this._coverageShowing}showCoverage(e={show:!1}){this._coverageShowing=e.show,e.show?this.entityCollection.owner._coverageGroup.push(this):this.entityCollection.owner._coverageGroup.remove({id:this.id})}showOrbit(e={show:!1}){if(this._orbitShowing=e.show,!e.show){this.path=null;return}e&&(e.color=e.material),e?.referenceEntity?this._localReferenceEntity=e.referenceEntity:this._localReferenceEntity=void 0,this.path=this.path||{};let{material:n,width:i,leadTime:o,trailTime:a,resolution:s}=this.path;this.path=Object.assign({},{material:n||v.WHITE,width:i||1.25,leadTime:o||5e3,trailTime:a||5e3,resolution:s||120,show:!0},e);let{ecco:l,period_sec:r}=this.properties.wasmSpaceEntity,d=l{a.filter(l=>l.properties?.pointer).forEach(l=>{this._wasmModule.removeEntity(l.properties.pointer)}),this._entityCollection.referenceFrame=this._viewer?.scene.referenceFrame||this._entityCollection.referenceFrame};this._entityCollection.collectionChanged.addEventListener(n,this),this._orbits={[Co.LEO]:[],[Co.MEO]:[],[Co.HEO]:[],[Co.GEO]:[],[Co.IGO]:[],[Co.EGO]:[],[Co.GEOIADC]:[],[Co.GEOSYNC]:[],[Co.SUNSYNC]:[],[Co.SEMISYNC]:[],[Co.POLAR]:[],[Co.UNKNOWN]:[]}}onAdd(e){~e.getByName(this._coverageGroup.name).length&&e.add(this._coverageGroup)}onRemove(e){e.getByName(this._coverageGroup.name).length&&e.remove(this._coverageGroup)}async load(e){return await this.loadOMM(e,"tle")}loadOMM(e,n,i=!1){if(!e)throw new Ut('The parameter "omm" is required.');if(!n)throw new Ut('The parameter "satcat" is required.');return new Promise(async o=>{let a=await K0.initInstance();if(this._wasmModule=a.wasmModule,this._coverageGroup=this._coverageGroup||new TJ({samples:72,sdc:this,coverageType:1,angle:90,groundCoverageOnly:!1,color:v.LIMEGREEN.withAlpha(.5)}),this.entities.suspendEvents(),this._wasmSatelliteCatalog=this._wasmSatelliteCatalog||a.instance,(e instanceof ArrayBuffer||e instanceof Uint8Array)&&(e instanceof ArrayBuffer&&(e=new Uint8Array(e)),this.OMM=a1(e,"OMM",sW)),(e.RECORDS||Array.isArray(e))&&(this.OMM={RECORDS:e?.RECORDS||e}),!this.OMM)throw Error("OMMCOLLECTIONT invalid");let s=[];this.CAT=new bTe,(n instanceof ArrayBuffer||e instanceof Uint8Array)&&(n instanceof ArrayBuffer&&(n=new Uint8Array(n)),this.CATRAW=a1(n,"CAT",aW)),(n.RECORDS||Array.isArray(n))&&(this.CATRAW={RECORDS:n?.RECORDS||n});for(let l=0;l{t.toBlob(function(a){e._files[n]=a,o()})});return this._promises.push(i),n}return""};function UTe(t,e){return function(n){t._files[e]=n}}rz.prototype.model=function(t,e){let n=this._modelCallback;if(!c(n))throw new Tt("Encountered a model entity while exporting to KML, but no model callback was supplied.");let i={},o=n(t,e,i);for(let a in i)if(i.hasOwnProperty(a)){let s=Promise.resolve(i[a]);this._promises.push(s),s.then(UTe(this,a))}return o};Object.defineProperties(rz.prototype,{promise:{get:function(){return Promise.all(this._promises)}},files:{get:function(){return this._files}}});function dz(t){this._time=t}dz.prototype.get=function(t,e,n){let i;return c(t)&&(i=c(t.getValue)?t.getValue(this._time,n):t),f(i,e)};dz.prototype.getColor=function(t,e){let n=this.get(t,e);if(c(n))return sT(n)};dz.prototype.getMaterialType=function(t){if(c(t))return t.getType(this._time)};function Wot(){this._ids={},this._styles={},this._count=0}Wot.prototype.get=function(t){let e=this._ids,n=t.innerHTML;if(c(e[n]))return e[n];let i=`style-${++this._count}`;return t.setAttribute("id",i),i=`#${i}`,e[n]=i,this._styles[n]=t,i};Wot.prototype.save=function(t){let e=this._styles,n=t.childNodes[0];for(let i in e)e.hasOwnProperty(i)&&t.insertBefore(e[i],n)};function qIt(){this._ids={}}qIt.prototype.get=function(t){if(!c(t))return this.get(Ti());let e=this._ids;return c(e[t])?`${t.toString()}-${++e[t]}`:(e[t]=0,t)};function fot(t){t=f(t,f.EMPTY_OBJECT);let e=t.entities,n=f(t.kmz,!1),i=fot._createState(t),o=e.values.filter(function(d){return!c(d.parent)}),a=i.kmlDoc,s=a.documentElement;s.setAttributeNS(fTe,"xmlns:gx",eZ);let l=a.createElement("Document");s.appendChild(l),t1t(i,l,o),i.styleCache.save(l);let r=i.externalFileHandler;return r.promise.then(function(){let m=new XMLSerializer().serializeToString(i.kmlDoc);return n?GTe(m,r.files):{kml:m,externalFiles:r.files}})}function GTe(t,e){let n=Dn("ThirdParty/Workers/z-worker-pako.js");QI({workerScripts:{deflate:[n,"./pako_deflate.min.js"],inflate:[n,"./pako_inflate.min.js"]}});let i=new HL,o=new Z3(i);return o.add("doc.kml",new $v(t)).then(function(){let a=Object.keys(e);return $It(o,a,e,0)}).then(function(){return o.close()}).then(function(a){return{kmz:a}})}function $It(t,e,n,i){if(e.length===i)return;let o=e[i];return t.add(o,new iW(n[o])).then(function(){return $It(t,e,n,i+1)})}fot._createState=function(t){let e=t.entities,n=new Wot,i=e.computeAvailability(),o=c(t.time)?t.time:i.start,a=f(t.defaultAvailability,i),s=f(t.sampleDuration,60);a.start===be.MINIMUM_VALUE?a.stop===be.MAXIMUM_VALUE?a=new ai:rt.addSeconds(a.stop,-10*s,a.start):a.stop===be.MAXIMUM_VALUE&&rt.addSeconds(a.start,10*s,a.stop);let l=new rz(t.modelCallback);return{kmlDoc:document.implementation.createDocument(WTe,"kml"),ellipsoid:f(t.ellipsoid,mt.WGS84),idManager:new qIt,styleCache:n,externalFileHandler:l,time:o,valueGetter:new dz(o),sampleDuration:s,defaultAvailability:new ys([a])}};function t1t(t,e,n){let i=t.kmlDoc,o=t.styleCache,a=t.valueGetter,s=t.idManager,l=n.length,r,d,m;for(let h=0;h0){let G=i.createElement("Placemark");G.setAttribute("id",s.get(u.id));let A=u.name,S=u.label;if(c(S)){let C=i.createElement("LabelStyle"),y=a.get(S.text);A=c(y)&&y.length>0?y:A;let Y=a.getColor(S.fillColor);c(Y)&&(C.appendChild(ii(i,"color",Y)),C.appendChild(ii(i,"colorMode","normal")));let Q=a.get(S.scale);c(Q)&&C.appendChild(ii(i,"scale",Q)),m.push(C)}G.appendChild(ii(i,"name",A)),G.appendChild(ii(i,"visibility",u.show)),G.appendChild(ii(i,"description",u.description)),c(R)&&G.appendChild(R),e.appendChild(G);let g=m.length;if(g>0){let C=i.createElement("Style");for(let y=0;y1){let C=i.createElement("MultiGeometry");for(let y=0;y0){let G=i.createElement("Folder");G.setAttribute("id",s.get(u.id)),G.appendChild(ii(i,"name",u.name)),G.appendChild(ii(i,"visibility",u.show)),G.appendChild(ii(i,"description",u.description)),e.appendChild(G),t1t(t,G,U)}}}var qm=new p,jc=new gt,tZ=new rt;function ATe(t,e,n,i){let o=t.kmlDoc,a=t.ellipsoid,s=t.valueGetter,l=f(e.billboard,e.point);if(!c(l)&&!c(e.path))return;let r=e.position;if(!r.isConstant){e1t(t,e,l,n,i);return}s.get(r,void 0,qm);let d=ii(o,"coordinates",aT(qm,a)),m=o.createElement("Point"),h=o.createElement("altitudeMode");h.appendChild(lT(t,l.heightReference)),m.appendChild(h),m.appendChild(d),n.push(m);let u=l instanceof Mr?i1t(t,l):n1t(t,l);i.push(u)}function e1t(t,e,n,i,o){let a=t.kmlDoc,s=t.ellipsoid,l=t.valueGetter,r,d=e.position,m=!0;d instanceof cl?(r=d.intervals,m=!1):r=f(e.availability,t.defaultAvailability);let h=n instanceof Jb,u,R,V,F=[];for(u=0;u1){let G=a.createElementNS(eZ,"MultiTrack");for(u=0;u0&&(a=n);let s=e.coordinates,l=o.get(s),r=[],d=[Gt.northeast,Gt.southeast,Gt.southwest,Gt.northwest];for(let R=0;R<4;++R)d[R](l,jc),r.push(`${k.toDegrees(jc.longitude)},${k.toDegrees(jc.latitude)},${a}`);let m=ii(i,"coordinates",r.join(" ")),h=i.createElement("outerBoundaryIs"),u=i.createElement("LinearRing");return u.appendChild(m),h.appendChild(u),[h]}function zIt(t,e,n,i){let o=t.kmlDoc,a=t.ellipsoid,s=[],l=e.length;for(let m=0;m0&&(a=n);let l=[],r=e.hierarchy,d=o.get(r),m=Array.isArray(d)?d:d.positions,h=i.createElement("outerBoundaryIs");h.appendChild(zIt(t,m,a,s)),l.push(h);let u=d.holes;if(c(u)){let R=u.length;for(let V=0;V0&&r.appendChild(ii(a,"extrude",!0));let m=l?TTe(t,e,d):gTe(t,e,d),h=m.length;for(let U=0;U=0;--i)e+=n[i]<16?`0${n[i].toString(16)}`:n[i].toString(16);return e}var Uot=fot;var cVo=b(W(),1),Got="";var W9o=b(W(),1);var pVo=b(W(),1);function ITe(t){let e,n=t.name,i=t.message;c(n)&&c(i)?e=`${n}: ${i}`:e=t.toString();let o=t.stack;return c(o)&&(e+=` +${o}`),e}var QR=ITe;var uGo=b(W(),1);var Iuo=b(W(),1);var Fuo=b(W(),1);var uVo=b(W(),1),NTe={NONE:0,LERC:1},UV=Object.freeze(NTe);var wVo=b(W(),1);var CVo=b(W(),1);var RVo=b(W(),1),yTe={NONE:0,BITS12:1},yr=Object.freeze(yTe);var rT=new p,BTe=new p,GV=new K,cz=new L,QTe=new L,kTe=Math.pow(2,12);function sc(t,e,n,i,o,a,s,l,r,d){let m=yr.NONE,h,u;if(c(e)&&c(n)&&c(i)&&c(o)){let R=e.minimum,V=e.maximum,F=p.subtract(V,R,BTe),U=i-n;Math.max(p.maximumComponent(F),U)0,R=f(t.isGeographic,!0),V=f(t.ellipsoid,mt.WGS84),F=1/V.maximumRadius,U=Gt.clone(t.nativeRectangle),G=Gt.clone(t.rectangle),A,S,g,C;c(G)?(A=G.west,S=G.south,g=G.east,C=G.north):R?(A=l(U.west),S=l(U.south),g=l(U.east),C=l(U.north)):(A=U.west*F,S=s-2*o(a(-U.south*F)),g=U.east*F,C=s-2*o(a(-U.north*F)));let y=t.relativeToCenter,Y=c(y);y=Y?y:p.ZERO;let Q=f(t.includeWebMercatorT,!1),J=f(t.exaggeration,1),M=f(t.exaggerationRelativeHeight,0),E=J!==1,I=f(t.structure,kR.DEFAULT_STRUCTURE),B=f(I.heightScale,kR.DEFAULT_STRUCTURE.heightScale),X=f(I.heightOffset,kR.DEFAULT_STRUCTURE.heightOffset),_=f(I.elementsPerHeight,kR.DEFAULT_STRUCTURE.elementsPerHeight),P=f(I.stride,kR.DEFAULT_STRUCTURE.stride),w=f(I.elementMultiplier,kR.DEFAULT_STRUCTURE.elementMultiplier),z=f(I.isBigEndian,kR.DEFAULT_STRUCTURE.isBigEndian),H=Gt.computeWidth(U),nt=Gt.computeHeight(U),$=H/(d-1),dt=nt/(m-1);R||(H*=F,nt*=F);let q=V.radiiSquared,at=q.x,st=q.y,Et=q.z,Qt=65536,Wt=-65536,Nt=Pe.eastNorthUpToFixedFrame(y,V),kt=L.inverseTransformation(Nt,xTe),Mt,qt;Q&&(Mt=Yo.geodeticLatitudeToMercatorAngle(S),qt=1/(Yo.geodeticLatitudeToMercatorAngle(C)-Mt));let ie=XTe;ie.x=Number.POSITIVE_INFINITY,ie.y=Number.POSITIVE_INFINITY,ie.z=Number.POSITIVE_INFINITY;let oe=JTe;oe.x=Number.NEGATIVE_INFINITY,oe.y=Number.NEGATIVE_INFINITY,oe.z=Number.NEGATIVE_INFINITY;let He=Number.POSITIVE_INFINITY,rn=d*m,de=h>0?d*2+m*2:0,zt=rn+de,ke=new Array(zt),Ve=new Array(zt),We=new Array(zt),Vn=Q?new Array(zt):[],Ct=E?new Array(zt):[],_t=0,Je=m,xe=0,oo=d;u&&(--_t,++Je,--xe,++oo);let ea=1e-5;for(let ue=_t;ue=m&&(Ke=m-1);let An=U.north-dt*Ke;R?An=l(An):An=s-2*o(a(-An*F));let si=(An-S)/(C-S);si=k.clamp(si,0,1);let da=ue===_t,_a=ue===Je-1;h>0&&(da?An+=ea*nt:_a&&(An-=ea*nt));let Rl=e(An),na=n(An),Go=Et*na,Ao;Q&&(Ao=(Yo.geodeticLatitudeToMercatorAngle(An)-Mt)*qt);for(let Xs=xe;Xs=d&&(Es=d-1);let wl=Ke*(d*P)+Es*P,ka;if(_===1)ka=r[wl];else{ka=0;let ma;if(z)for(ma=0;ma<_;++ma)ka=ka*w+r[wl+ma];else for(ma=_-1;ma>=0;--ma)ka=ka*w+r[wl+ma]}ka=ka*B+X,Wt=Math.max(Wt,ka),Qt=Math.min(Qt,ka);let Wa=U.west+$*Es;R?Wa=l(Wa):Wa=Wa*F;let JV=(Wa-A)/(g-A);JV=k.clamp(JV,0,1);let yl=Ke*d+Es;if(h>0){let ma=Xs===xe,Ed=Xs===oo-1,BW=da||_a||ma||Ed;if((da||_a)&&(ma||Ed))continue;BW&&(ka-=h,ma?(yl=rn+(m-Ke-1),Wa-=ea*H):_a?yl=rn+m+(d-Es-1):Ed?(yl=rn+m+d+Ke,Wa+=ea*H):da&&(yl=rn+m+d+m+Es))}let Bi=Rl*e(Wa),sd=Rl*n(Wa),zi=at*Bi,js=st*sd,$n=1/i(zi*Bi+js*sd+Go*na),mr=zi*$n,hr=js*$n,pr=Go*$n,hs=new p;hs.x=mr+Bi*ka,hs.y=hr+sd*ka,hs.z=pr+na*ka,L.multiplyByPoint(kt,hs,Aot),p.minimumByComponent(Aot,ie,ie),p.maximumByComponent(Aot,oe,oe),He=Math.min(He,ka),ke[yl]=hs,We[yl]=new K(JV,si),Ve[yl]=ka,Q&&(Vn[yl]=Ao),E&&(Ct[yl]=V.geodeticSurfaceNormal(hs))}}let gs=Ft.fromPoints(ke),is;c(G)&&(is=ci.fromRectangle(G,Qt,Wt,V));let ja;Y&&(ja=new Bu(V).computeHorizonCullingPointPossiblyUnderEllipsoid(y,ke,Qt));let qn=new Ff(ie,oe,y),ae=new lc(y,qn,He,Wt,Nt,!1,Q,E,J,M),fe=new Float32Array(zt*ae.stride),ge=0;for(let ue=0;ue0?S=El.getRegularGridAndSkirtIndicesAndEdgeIndices(A.gridWidth,A.gridHeight):S=El.getRegularGridIndicesAndEdgeIndices(A.gridWidth,A.gridHeight);let g=A.gridWidth*A.gridHeight;return G._mesh=new AV(h,new Float32Array(A.vertices),S.indices,S.indexCountWithoutSkirts,g,A.minimumHeight,A.maximumHeight,Ft.clone(A.boundingSphere3D),p.clone(A.occludeePointInScaledSpace),A.numberOfAttributes,ci.clone(A.orientedBoundingBox),lc.clone(A.encoding),S.westIndicesSouthToNorth,S.southIndicesEastToWest,S.eastIndicesNorthToSouth,S.northIndicesWestToEast),G._buffer=void 0,G._mesh})};lW.prototype._createMeshSync=function(t){let e=t.tilingScheme,n=t.x,i=t.y,o=t.level,a=f(t.exaggeration,1),s=f(t.exaggerationRelativeHeight,0),l=e.ellipsoid,r=e.tileXYToNativeRectangle(n,i,o),d=e.tileXYToRectangle(n,i,o),m=l.cartographicToCartesian(Gt.center(d)),h=this._structure,R=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(l,this._width,e.getNumberOfXTilesAtLevel(0))/(1<0?F=El.getRegularGridAndSkirtIndicesAndEdgeIndices(this._width,this._height):F=El.getRegularGridIndicesAndEdgeIndices(this._width,this._height);let U=V.gridWidth*V.gridHeight;return this._mesh=new AV(m,V.vertices,F.indices,F.indexCountWithoutSkirts,U,V.minimumHeight,V.maximumHeight,V.boundingSphere3D,V.occludeePointInScaledSpace,V.encoding.stride,V.orientedBoundingBox,V.encoding,F.westIndicesSouthToNorth,F.southIndicesEastToWest,F.eastIndicesNorthToSouth,F.northIndicesWestToEast),this._mesh};lW.prototype.interpolateHeight=function(t,e,n){let i=this._width,o=this._height,a=this._structure,s=a.stride,l=a.elementsPerHeight,r=a.elementMultiplier,d=a.isBigEndian,m=a.heightOffset,h=a.heightScale,u=c(this._mesh),R=this._encoding===UV.LERC;if(!u&&R)return;let F;if(u){let U=this._mesh.vertices,G=this._mesh.encoding;F=h1t(U,G,m,h,t,i,o,e,n)}else F=DTe(this._buffer,l,r,s,d,t,i,o,e,n),F=F*h+m;return F};lW.prototype.upsample=function(t,e,n,i,o,a,s){let l=this._mesh;if(!c(l))return;let r=this._width,d=this._height,m=this._structure,h=m.stride,u=new this._bufferType(r*d*h),R=l.vertices,V=l.encoding,F=t.tileXYToRectangle(e,n,i),U=t.tileXYToRectangle(o,a,s),G=m.heightOffset,A=m.heightScale,S=m.elementsPerHeight,g=m.elementMultiplier,C=m.isBigEndian,y=Math.pow(g,S-1);for(let Y=0;Ym.highestEncodedHeight?m.highestEncodedHeight:Z,OTe(u,S,g,y,h,C,Y*r+J,Z)}}return Promise.resolve(new lW({buffer:u,width:r,height:d,childTileMask:0,structure:this._structure,createdByUpsampling:!0}))};lW.prototype.isChildAvailable=function(t,e,n,i){let o=2;return n!==t*2&&++o,i!==e*2&&(o-=2),(this._childTileMask&1<=s&&(R=s-1,u=s-2);let V=h|0,F=V+1;F>=l&&(F=l-1,V=l-2);let U=m-u,G=h-V;V=l-1-V,F=l-1-F;let A=Vz(t,e,n,i,o,V*s+u),S=Vz(t,e,n,i,o,V*s+R),g=Vz(t,e,n,i,o,F*s+u),C=Vz(t,e,n,i,o,F*s+R);return p1t(U,G,A,S,g,C)}function h1t(t,e,n,i,o,a,s,l,r){let d=(l-o.west)*(a-1)/(o.east-o.west),m=(r-o.south)*(s-1)/(o.north-o.south),h=d|0,u=h+1;u>=a&&(u=a-1,h=a-2);let R=m|0,V=R+1;V>=s&&(V=s-1,R=s-2);let F=d-h,U=m-R;R=s-1-R,V=s-1-V;let G=(e.decodeHeight(t,R*a+h)-n)/i,A=(e.decodeHeight(t,R*a+u)-n)/i,S=(e.decodeHeight(t,V*a+h)-n)/i,g=(e.decodeHeight(t,V*a+u)-n)/i;return p1t(F,U,G,A,S,g)}function p1t(t,e,n,i,o,a){return e=0;--l)s=s*n+t[a+l];return s}function OTe(t,e,n,i,o,a,s,l){s*=o;let r;if(a)for(r=0;r0;--r)t[s+r]=l/i|0,l-=t[s+r]*i,i/=n;t[s+r]=l}var Gd=lW;function b1(t){t=f(t,f.EMPTY_OBJECT),this._tilingScheme=t.tilingScheme,c(this._tilingScheme)||(this._tilingScheme=new Qo({ellipsoid:f(t.ellipsoid,mt.WGS84)})),this._levelZeroMaximumGeometricError=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(this._tilingScheme.ellipsoid,64,this._tilingScheme.getNumberOfXTilesAtLevel(0)),this._errorEvent=new It}Object.defineProperties(b1.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){}},tilingScheme:{get:function(){return this._tilingScheme}},hasWaterMask:{get:function(){return!1}},hasVertexNormals:{get:function(){return!1}},availability:{get:function(){}}});b1.prototype.requestTileGeometry=function(t,e,n,i){return Promise.resolve(new Gd({buffer:new Uint8Array(16*16),width:16,height:16}))};b1.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1< 0 uniform sampler2D u_dayTextures[TEXTURE_UNITS]; @@ -9846,7 +9846,7 @@ vec4 computeWaterColor(vec3 positionEyeCoordinates, vec2 textureCoordinates, mat } #endif // #ifdef SHOW_REFLECTIVE_OCEAN -`;var QZo=R(W(),1),YM=`#ifdef QUANTIZATION_BITS12 +`;var Quo=b(W(),1),YM=`#ifdef QUANTIZATION_BITS12 in vec4 compressed0; in float compressed1; #else @@ -10131,7 +10131,7 @@ void main() v_height = height; #endif } -`;var YZo=R(W(),1),rW=`uniform vec3 u_radiiAndDynamicAtmosphereColor; +`;var Yuo=b(W(),1),rW=`uniform vec3 u_radiiAndDynamicAtmosphereColor; uniform float u_atmosphereLightIntensity; uniform float u_atmosphereRayleighScaleHeight; @@ -10318,7 +10318,7 @@ vec4 computeAtmosphereColor( return vec4(color, opacity); } -`;var XZo=R(W(),1),W1=`void computeAtmosphereScattering(vec3 positionWC, vec3 lightDirection, out vec3 rayleighColor, out vec3 mieColor, out float opacity) { +`;var Xuo=b(W(),1),W1=`void computeAtmosphereScattering(vec3 positionWC, vec3 lightDirection, out vec3 rayleighColor, out vec3 mieColor, out float opacity) { vec3 cameraToPositionWC = positionWC - czm_viewerPositionWC; vec3 cameraToPositionWCDirection = normalize(cameraToPositionWC); @@ -10336,8 +10336,8 @@ vec4 computeAtmosphereColor( opacity ); } -`;var zZo=R(W(),1);var _Zo=R(W(),1);var HSe=new K;function wSe(t,e){let n=t.unionClippingRegions,i=t.length,o=Ml.useFloatTexture(e),a=Ml.getTextureResolution(t,e,HSe),s=a.x,l=a.y,r=o?KSe(s,l):zSe(s,l);return r+=` -`,r+=n?PSe(i):vSe(i),r}function PSe(t){return`float clip(vec4 fragCoord, sampler2D clippingPlanes, mat4 clippingPlanesMatrix) +`;var zuo=b(W(),1);var _uo=b(W(),1);var HTe=new K;function wTe(t,e){let n=t.unionClippingRegions,i=t.length,o=Ml.useFloatTexture(e),a=Ml.getTextureResolution(t,e,HTe),s=a.x,l=a.y,r=o?KTe(s,l):zTe(s,l);return r+=` +`,r+=n?PTe(i):vTe(i),r}function PTe(t){return`float clip(vec4 fragCoord, sampler2D clippingPlanes, mat4 clippingPlanesMatrix) { vec4 position = czm_windowToEyeCoordinates(fragCoord); vec3 clipNormal = vec3(0.0); @@ -10363,7 +10363,7 @@ vec4 computeAtmosphereColor( } return clipAmount; } -`}function vSe(t){return`float clip(vec4 fragCoord, sampler2D clippingPlanes, mat4 clippingPlanesMatrix) +`}function vTe(t){return`float clip(vec4 fragCoord, sampler2D clippingPlanes, mat4 clippingPlanesMatrix) { bool clipped = true; vec4 position = czm_windowToEyeCoordinates(fragCoord); @@ -10386,7 +10386,7 @@ vec4 computeAtmosphereColor( } return clipAmount; } -`}function KSe(t,e){let n=1/t,i=1/e,o=`${n}`;o.indexOf(".")===-1&&(o+=".0");let a=`${i}`;return a.indexOf(".")===-1&&(a+=".0"),`vec4 getClippingPlane(highp sampler2D packedClippingPlanes, int clippingPlaneNumber, mat4 transform) +`}function KTe(t,e){let n=1/t,i=1/e,o=`${n}`;o.indexOf(".")===-1&&(o+=".0");let a=`${i}`;return a.indexOf(".")===-1&&(a+=".0"),`vec4 getClippingPlane(highp sampler2D packedClippingPlanes, int clippingPlaneNumber, mat4 transform) { int pixY = clippingPlaneNumber / ${t}; int pixX = clippingPlaneNumber - (pixY * ${t}); @@ -10395,7 +10395,7 @@ vec4 computeAtmosphereColor( vec4 plane = texture(packedClippingPlanes, vec2(u, v)); return czm_transformPlane(plane, transform); } -`}function zSe(t,e){let n=1/t,i=1/e,o=`${n}`;o.indexOf(".")===-1&&(o+=".0");let a=`${i}`;return a.indexOf(".")===-1&&(a+=".0"),`vec4 getClippingPlane(highp sampler2D packedClippingPlanes, int clippingPlaneNumber, mat4 transform) +`}function zTe(t,e){let n=1/t,i=1/e,o=`${n}`;o.indexOf(".")===-1&&(o+=".0");let a=`${i}`;return a.indexOf(".")===-1&&(a+=".0"),`vec4 getClippingPlane(highp sampler2D packedClippingPlanes, int clippingPlaneNumber, mat4 transform) { int clippingPlaneStartIndex = clippingPlaneNumber * 2; int pixY = clippingPlaneStartIndex / ${t}; @@ -10409,19 +10409,19 @@ vec4 computeAtmosphereColor( plane.w = czm_unpackFloat(texture(packedClippingPlanes, vec2(u + ${o}, v))); return czm_transformPlane(plane, transform); } -`}var dW=wSe;function jSe(t,e,n,i,o,a){this.numberOfDayTextures=t,this.flags=e,this.material=n,this.shaderProgram=i,this.clippingShaderState=o,this.clippingPolygonShaderState=a}function Tot(){this.baseVertexShaderSource=void 0,this.baseFragmentShaderSource=void 0,this._shadersByTexturesFlags=[],this.material=void 0}function qSe(t){let e="vec4 getPosition(vec3 position, float height, vec2 textureCoordinates) { return getPosition3DMode(position, height, textureCoordinates); }",n="vec4 getPosition(vec3 position, float height, vec2 textureCoordinates) { return getPositionColumbusViewMode(position, height, textureCoordinates); }",i="vec4 getPosition(vec3 position, float height, vec2 textureCoordinates) { return getPositionMorphingMode(position, height, textureCoordinates); }",o;switch(t){case ut.SCENE3D:o=e;break;case ut.SCENE2D:case ut.COLUMBUS_VIEW:o=n;break;case ut.MORPHING:o=i;break}return o}function $Se(t){return t.webgl2?`void clipPolygons(highp sampler2D clippingDistance, int regionsLength, vec2 clippingPosition, int regionIndex) { +`}var dW=wTe;function jTe(t,e,n,i,o,a){this.numberOfDayTextures=t,this.flags=e,this.material=n,this.shaderProgram=i,this.clippingShaderState=o,this.clippingPolygonShaderState=a}function Sot(){this.baseVertexShaderSource=void 0,this.baseFragmentShaderSource=void 0,this._shadersByTexturesFlags=[],this.material=void 0}function qTe(t){let e="vec4 getPosition(vec3 position, float height, vec2 textureCoordinates) { return getPosition3DMode(position, height, textureCoordinates); }",n="vec4 getPosition(vec3 position, float height, vec2 textureCoordinates) { return getPositionColumbusViewMode(position, height, textureCoordinates); }",i="vec4 getPosition(vec3 position, float height, vec2 textureCoordinates) { return getPositionMorphingMode(position, height, textureCoordinates); }",o;switch(t){case Vt.SCENE3D:o=e;break;case Vt.SCENE2D:case Vt.COLUMBUS_VIEW:o=n;break;case Vt.MORPHING:o=i;break}return o}function $Te(t){return t.webgl2?`void clipPolygons(highp sampler2D clippingDistance, int regionsLength, vec2 clippingPosition, int regionIndex) { czm_clipPolygons(clippingDistance, regionsLength, clippingPosition, regionIndex); }`:`void clipPolygons(highp sampler2D clippingDistance, int regionsLength, vec2 clippingPosition, int regionIndex) { }`}function tge(t){return t.webgl2?`vec4 unpackClippingExtents(highp sampler2D extentsTexture, int index) { return czm_unpackClippingExtents(extentsTexture, index); }`:`vec4 unpackClippingExtents(highp sampler2D extentsTexture, int index) { return vec4(); - }`}function ege(t){return t?"float get2DYPositionFraction(vec2 textureCoordinates) { return get2DMercatorYPositionFraction(textureCoordinates); }":"float get2DYPositionFraction(vec2 textureCoordinates) { return get2DGeographicYPositionFraction(textureCoordinates); }"}Tot.prototype.getShaderProgram=function(t){let e=t.frameState,n=t.surfaceTile,i=t.numberOfDayTextures,o=t.applyBrightness,a=t.applyContrast,s=t.applyHue,l=t.applySaturation,r=t.applyGamma,d=t.applyAlpha,m=t.applyDayNightAlpha,h=t.applySplit,Z=t.showReflectiveOcean,b=t.showOceanWaves,u=t.enableLighting,F=t.dynamicAtmosphereLighting,U=t.dynamicAtmosphereLightingFromSun,G=t.showGroundAtmosphere,A=t.perFragmentGroundAtmosphere,T=t.hasVertexNormals,g=t.useWebMercatorProjection,C=t.enableFog,y=t.enableClippingPlanes,Y=t.clippingPlanes,Q=t.enableClippingPolygons,J=t.clippingPolygons,M=t.clippedByBoundaries,V=t.hasImageryLayerCutout,E=t.colorCorrect,I=t.highlightFillTile,B=t.colorToAlpha,X=t.hasGeodeticSurfaceNormals,_=t.hasExaggeration,P=t.showUndergroundColor,w=t.translucent,z=0,H="",$=n.renderedMesh.encoding;$.quantization===yr.BITS12&&(z=1,H="QUANTIZATION_BITS12");let q=0,at="";M&&(q=1,at="TILE_LIMIT_RECTANGLE");let st=0,Et="";V&&(st=1,Et="APPLY_IMAGERY_CUTOUT");let Qt=e.mode,Wt=Qt|o<<2|a<<3|s<<4|l<<5|r<<6|d<<7|Z<<8|b<<9|u<<10|F<<11|U<<12|G<<13|A<<14|T<<15|g<<16|C<<17|z<<18|h<<19|y<<20|Q<<21|q<<22|st<<23|E<<24|I<<25|B<<26|X<<27|_<<28|P<<29|w<<30|m<<31,Nt=0;c(Y)&&Y.length>0&&(Nt=y?Y.clippingPlanesState:0);let kt=0;c(J)&&J.length>0&&(kt=Q?J.clippingPolygonsState:0);let Mt=n.surfaceShader;if(c(Mt)&&Mt.numberOfDayTextures===i&&Mt.flags===Wt&&Mt.material===this.material&&Mt.clippingShaderState===Nt&&Mt.clippingPolygonShaderState===kt)return Mt.shaderProgram;let qt=this._shadersByTexturesFlags[i];if(c(qt)||(qt=this._shadersByTexturesFlags[i]=[]),Mt=qt[Wt],!c(Mt)||Mt.material!==this.material||Mt.clippingShaderState!==Nt||Mt.clippingPolygonShaderState!==kt){let ie=this.baseVertexShaderSource.clone(),oe=this.baseFragmentShaderSource.clone();Nt!==0&&oe.sources.unshift(dW(Y,e.context)),kt!==0&&(oe.sources.unshift($Se(e.context)),ie.sources.unshift(tge(e.context))),ie.defines.push(H),oe.defines.push(`TEXTURE_UNITS ${i}`,at,Et),o&&oe.defines.push("APPLY_BRIGHTNESS"),a&&oe.defines.push("APPLY_CONTRAST"),s&&oe.defines.push("APPLY_HUE"),l&&oe.defines.push("APPLY_SATURATION"),r&&oe.defines.push("APPLY_GAMMA"),d&&oe.defines.push("APPLY_ALPHA"),m&&oe.defines.push("APPLY_DAY_NIGHT_ALPHA"),Z&&(oe.defines.push("SHOW_REFLECTIVE_OCEAN"),ie.defines.push("SHOW_REFLECTIVE_OCEAN")),b&&oe.defines.push("SHOW_OCEAN_WAVES"),B&&oe.defines.push("APPLY_COLOR_TO_ALPHA"),P&&(ie.defines.push("UNDERGROUND_COLOR"),oe.defines.push("UNDERGROUND_COLOR")),w&&(ie.defines.push("TRANSLUCENT"),oe.defines.push("TRANSLUCENT")),u&&(T?(ie.defines.push("ENABLE_VERTEX_LIGHTING"),oe.defines.push("ENABLE_VERTEX_LIGHTING")):(ie.defines.push("ENABLE_DAYNIGHT_SHADING"),oe.defines.push("ENABLE_DAYNIGHT_SHADING"))),F&&(ie.defines.push("DYNAMIC_ATMOSPHERE_LIGHTING"),oe.defines.push("DYNAMIC_ATMOSPHERE_LIGHTING"),U&&(ie.defines.push("DYNAMIC_ATMOSPHERE_LIGHTING_FROM_SUN"),oe.defines.push("DYNAMIC_ATMOSPHERE_LIGHTING_FROM_SUN"))),G&&(ie.defines.push("GROUND_ATMOSPHERE"),oe.defines.push("GROUND_ATMOSPHERE"),A&&(ie.defines.push("PER_FRAGMENT_GROUND_ATMOSPHERE"),oe.defines.push("PER_FRAGMENT_GROUND_ATMOSPHERE"))),ie.defines.push("INCLUDE_WEB_MERCATOR_Y"),oe.defines.push("INCLUDE_WEB_MERCATOR_Y"),C&&(ie.defines.push("FOG"),oe.defines.push("FOG")),h&&oe.defines.push("APPLY_SPLIT"),y&&oe.defines.push("ENABLE_CLIPPING_PLANES"),Q&&(oe.defines.push("ENABLE_CLIPPING_POLYGONS"),ie.defines.push("ENABLE_CLIPPING_POLYGONS"),J.inverse&&oe.defines.push("CLIPPING_INVERSE"),oe.defines.push(`CLIPPING_POLYGON_REGIONS_LENGTH ${J.extentsCount}`),ie.defines.push(`CLIPPING_POLYGON_REGIONS_LENGTH ${J.extentsCount}`)),E&&oe.defines.push("COLOR_CORRECT"),I&&oe.defines.push("HIGHLIGHT_FILL_TILE"),X&&ie.defines.push("GEODETIC_SURFACE_NORMALS"),_&&ie.defines.push("EXAGGERATION");let He=` vec4 computeDayColor(vec4 initialColor, vec3 textureCoordinates, float nightBlend) + }`}function ege(t){return t?"float get2DYPositionFraction(vec2 textureCoordinates) { return get2DMercatorYPositionFraction(textureCoordinates); }":"float get2DYPositionFraction(vec2 textureCoordinates) { return get2DGeographicYPositionFraction(textureCoordinates); }"}Sot.prototype.getShaderProgram=function(t){let e=t.frameState,n=t.surfaceTile,i=t.numberOfDayTextures,o=t.applyBrightness,a=t.applyContrast,s=t.applyHue,l=t.applySaturation,r=t.applyGamma,d=t.applyAlpha,m=t.applyDayNightAlpha,h=t.applySplit,u=t.showReflectiveOcean,R=t.showOceanWaves,V=t.enableLighting,F=t.dynamicAtmosphereLighting,U=t.dynamicAtmosphereLightingFromSun,G=t.showGroundAtmosphere,A=t.perFragmentGroundAtmosphere,S=t.hasVertexNormals,g=t.useWebMercatorProjection,C=t.enableFog,y=t.enableClippingPlanes,Y=t.clippingPlanes,Q=t.enableClippingPolygons,J=t.clippingPolygons,M=t.clippedByBoundaries,Z=t.hasImageryLayerCutout,E=t.colorCorrect,I=t.highlightFillTile,B=t.colorToAlpha,X=t.hasGeodeticSurfaceNormals,_=t.hasExaggeration,P=t.showUndergroundColor,w=t.translucent,z=0,H="",$=n.renderedMesh.encoding;$.quantization===yr.BITS12&&(z=1,H="QUANTIZATION_BITS12");let q=0,at="";M&&(q=1,at="TILE_LIMIT_RECTANGLE");let st=0,Et="";Z&&(st=1,Et="APPLY_IMAGERY_CUTOUT");let Qt=e.mode,Wt=Qt|o<<2|a<<3|s<<4|l<<5|r<<6|d<<7|u<<8|R<<9|V<<10|F<<11|U<<12|G<<13|A<<14|S<<15|g<<16|C<<17|z<<18|h<<19|y<<20|Q<<21|q<<22|st<<23|E<<24|I<<25|B<<26|X<<27|_<<28|P<<29|w<<30|m<<31,Nt=0;c(Y)&&Y.length>0&&(Nt=y?Y.clippingPlanesState:0);let kt=0;c(J)&&J.length>0&&(kt=Q?J.clippingPolygonsState:0);let Mt=n.surfaceShader;if(c(Mt)&&Mt.numberOfDayTextures===i&&Mt.flags===Wt&&Mt.material===this.material&&Mt.clippingShaderState===Nt&&Mt.clippingPolygonShaderState===kt)return Mt.shaderProgram;let qt=this._shadersByTexturesFlags[i];if(c(qt)||(qt=this._shadersByTexturesFlags[i]=[]),Mt=qt[Wt],!c(Mt)||Mt.material!==this.material||Mt.clippingShaderState!==Nt||Mt.clippingPolygonShaderState!==kt){let ie=this.baseVertexShaderSource.clone(),oe=this.baseFragmentShaderSource.clone();Nt!==0&&oe.sources.unshift(dW(Y,e.context)),kt!==0&&(oe.sources.unshift($Te(e.context)),ie.sources.unshift(tge(e.context))),ie.defines.push(H),oe.defines.push(`TEXTURE_UNITS ${i}`,at,Et),o&&oe.defines.push("APPLY_BRIGHTNESS"),a&&oe.defines.push("APPLY_CONTRAST"),s&&oe.defines.push("APPLY_HUE"),l&&oe.defines.push("APPLY_SATURATION"),r&&oe.defines.push("APPLY_GAMMA"),d&&oe.defines.push("APPLY_ALPHA"),m&&oe.defines.push("APPLY_DAY_NIGHT_ALPHA"),u&&(oe.defines.push("SHOW_REFLECTIVE_OCEAN"),ie.defines.push("SHOW_REFLECTIVE_OCEAN")),R&&oe.defines.push("SHOW_OCEAN_WAVES"),B&&oe.defines.push("APPLY_COLOR_TO_ALPHA"),P&&(ie.defines.push("UNDERGROUND_COLOR"),oe.defines.push("UNDERGROUND_COLOR")),w&&(ie.defines.push("TRANSLUCENT"),oe.defines.push("TRANSLUCENT")),V&&(S?(ie.defines.push("ENABLE_VERTEX_LIGHTING"),oe.defines.push("ENABLE_VERTEX_LIGHTING")):(ie.defines.push("ENABLE_DAYNIGHT_SHADING"),oe.defines.push("ENABLE_DAYNIGHT_SHADING"))),F&&(ie.defines.push("DYNAMIC_ATMOSPHERE_LIGHTING"),oe.defines.push("DYNAMIC_ATMOSPHERE_LIGHTING"),U&&(ie.defines.push("DYNAMIC_ATMOSPHERE_LIGHTING_FROM_SUN"),oe.defines.push("DYNAMIC_ATMOSPHERE_LIGHTING_FROM_SUN"))),G&&(ie.defines.push("GROUND_ATMOSPHERE"),oe.defines.push("GROUND_ATMOSPHERE"),A&&(ie.defines.push("PER_FRAGMENT_GROUND_ATMOSPHERE"),oe.defines.push("PER_FRAGMENT_GROUND_ATMOSPHERE"))),ie.defines.push("INCLUDE_WEB_MERCATOR_Y"),oe.defines.push("INCLUDE_WEB_MERCATOR_Y"),C&&(ie.defines.push("FOG"),oe.defines.push("FOG")),h&&oe.defines.push("APPLY_SPLIT"),y&&oe.defines.push("ENABLE_CLIPPING_PLANES"),Q&&(oe.defines.push("ENABLE_CLIPPING_POLYGONS"),ie.defines.push("ENABLE_CLIPPING_POLYGONS"),J.inverse&&oe.defines.push("CLIPPING_INVERSE"),oe.defines.push(`CLIPPING_POLYGON_REGIONS_LENGTH ${J.extentsCount}`),ie.defines.push(`CLIPPING_POLYGON_REGIONS_LENGTH ${J.extentsCount}`)),E&&oe.defines.push("COLOR_CORRECT"),I&&oe.defines.push("HIGHLIGHT_FILL_TILE"),X&&ie.defines.push("GEODETIC_SURFACE_NORMALS"),_&&ie.defines.push("EXAGGERATION");let He=` vec4 computeDayColor(vec4 initialColor, vec3 textureCoordinates, float nightBlend) { vec4 color = initialColor; -`;V&&(He+=` vec4 cutoutAndColorResult; +`;Z&&(He+=` vec4 cutoutAndColorResult; bool texelUnclipped; -`);for(let de=0;de0?n.raiseEvent(r):c(e)&&console.log(`An error occurred in "${e.constructor.name}": ${Qb(i)}`),r};Zz.reportSuccess=function(t){c(t)&&(t.timesRetried=-1)};var za=Zz;var aVo=R(W(),1),ige={UNLOADED:0,TRANSITIONING:1,RECEIVED:2,TEXTURE_LOADED:3,READY:4,FAILED:5,INVALID:6,PLACEHOLDER:7},ho=Object.freeze(ige);var lVo=R(W(),1),oge={START:0,LOADING:1,DONE:2,FAILED:3},Br=Object.freeze(oge);var dVo=R(W(),1),age={FAILED:0,UNLOADED:1,RECEIVING:2,RECEIVED:3,TRANSFORMING:4,TRANSFORMED:5,READY:6},Ga=Object.freeze(age);function Us(){this.imagery=[],this.waterMaskTexture=void 0,this.waterMaskTranslationAndScale=new Rt(0,0,1,1),this.terrainData=void 0,this.vertexArray=void 0,this.tileBoundingRegion=void 0,this.occludeePointInScaledSpace=new p,this.boundingVolumeSourceTile=void 0,this.boundingVolumeIsFromMesh=!1,this.terrainState=Ga.UNLOADED,this.mesh=void 0,this.fill=void 0,this.pickBoundingSphere=new Ft,this.surfaceShader=void 0,this.isClipped=!0,this.clippedByBoundaries=!1}Object.defineProperties(Us.prototype,{eligibleForUnloading:{get:function(){let t=this.terrainState,n=!(t===Ga.RECEIVING||t===Ga.TRANSFORMING),i=this.imagery;for(let o=0,a=i.length;n&&o=0&&(m=A)}return m!==Number.MAX_VALUE?di.getPoint(t,m,o):void 0};Us.prototype.freeResources=function(){c(this.waterMaskTexture)&&(--this.waterMaskTexture.referenceCount,this.waterMaskTexture.referenceCount===0&&this.waterMaskTexture.destroy(),this.waterMaskTexture=void 0),this.terrainData=void 0,this.terrainState=Ga.UNLOADED,this.mesh=void 0,this.fill=this.fill&&this.fill.destroy();let t=this.imagery;for(let e=0,n=t.length;e=Ga.RECEIVED&&s.waterMaskTexture===void 0&&n.hasWaterMask)if(s.terrainData.waterMask!==void 0)Rge(e.context,s);else{let d=s._findAncestorTileWithTerrainData(t);c(d)&&c(d.data.waterMaskTexture)&&(s.waterMaskTexture=d.data.waterMaskTexture,++s.waterMaskTexture.referenceCount,s._computeWaterMaskTranslationAndScale(t,d,s.waterMaskTranslationAndScale))}}function hge(t,e,n,i,o,a,s){let l=e.parent;if(!l){e.state=Br.FAILED;return}let r=l.data.terrainData,d=l.x,m=l.y,h=l.level;if(!c(r))return;let Z=r.upsample(i.tilingScheme,d,m,h,o,a,s);c(Z)&&(t.terrainState=Ga.RECEIVING,Promise.resolve(Z).then(function(b){c(b)&&(t.terrainData=b,t.terrainState=Ga.RECEIVED)}).catch(function(){t.terrainState=Ga.FAILED}))}function pge(t,e,n,i,o){function a(r){if(!c(r)){t.terrainState=Ga.UNLOADED,t.request=void 0;return}t.terrainData=r,t.terrainState=Ga.RECEIVED,t.request=void 0}function s(r){if(t.request.state===qi.CANCELLED){t.terrainData=void 0,t.terrainState=Ga.UNLOADED,t.request=void 0;return}t.terrainState=Ga.FAILED,t.request=void 0;let d=`Failed to obtain terrain tile X: ${n} Y: ${i} Level: ${o}. Error message: "${r}"`;e._requestError=za.reportError(e._requestError,e,e.errorEvent,d,n,i,o),e._requestError.retry&&l()}function l(){let r=new Zs({throttle:!1,throttleByServer:!0,type:Xl.TERRAIN});t.request=r;let d=e.requestTileGeometry(n,i,o,r);c(d)?(t.terrainState=Ga.RECEIVING,Promise.resolve(d).then(function(m){a(m)}).catch(function(m){s(m)})):(t.terrainState=Ga.UNLOADED,t.request=void 0)}l()}var uge={tilingScheme:void 0,x:0,y:0,level:0,exaggeration:1,exaggerationRelativeHeight:0,throttle:!0};function Zge(t,e,n,i,o,a){let s=n.tilingScheme,l=uge;l.tilingScheme=s,l.x=i,l.y=o,l.level=a,l.exaggeration=e.verticalExaggeration,l.exaggerationRelativeHeight=e.verticalExaggerationRelativeHeight,l.throttle=!0;let d=t.terrainData.createMesh(l);c(d)&&(t.terrainState=Ga.TRANSFORMING,Promise.resolve(d).then(function(m){t.mesh=m,t.terrainState=Ga.TRANSFORMED}).catch(function(){t.terrainState=Ga.FAILED}))}Us._createVertexArrayForMesh=function(t,e){let n=e.vertices,i=we.createVertexBuffer({context:t,typedArray:n,usage:ce.STATIC_DRAW}),o=e.encoding.getAttributes(i),a=e.indices.indexBuffers||{},s=a[t.id];if(!c(s)||s.isDestroyed()){let l=e.indices;s=we.createIndexBuffer({context:t,typedArray:l,usage:ce.STATIC_DRAW,indexDatatype:re.fromSizeInBytes(l.BYTES_PER_ELEMENT)}),s.vertexArrayDestroyable=!1,s.referenceCount=1,a[t.id]=s,e.indices.indexBuffers=a}else++s.referenceCount;return new Ki({context:t,attributes:o,indexBuffer:s})};Us._freeVertexArray=function(t){if(c(t)){let e=t.indexBuffer;t.isDestroyed()||t.destroy(),c(e)&&!e.isDestroyed()&&c(e.referenceCount)&&(--e.referenceCount,e.referenceCount===0&&e.destroy())}};function Vge(t,e,n,i,o,a,s){t.vertexArray=Us._createVertexArrayForMesh(e,t.mesh),t.terrainState=Ga.READY,t.fill=t.fill&&t.fill.destroy(s)}function bge(t){let e=t.cache.tile_waterMaskData;if(!c(e)){let n=hn.create({context:t,pixelFormat:Ye.LUMINANCE,pixelDatatype:Ue.UNSIGNED_BYTE,source:{arrayBufferView:new Uint8Array([255]),width:1,height:1}});n.referenceCount=1;let i=new Hn({wrapS:Vi.CLAMP_TO_EDGE,wrapT:Vi.CLAMP_TO_EDGE,minificationFilter:On.LINEAR,magnificationFilter:bo.LINEAR});e={allWaterTexture:n,sampler:i,destroy:function(){this.allWaterTexture.destroy()}},t.cache.tile_waterMaskData=e}return e}function Rge(t,e){let n=e.terrainData.waterMask,i=bge(t),o,a=n.length;if(a===1)if(n[0]!==0)o=i.allWaterTexture;else return;else{let s=Math.sqrt(a);o=hn.create({context:t,pixelFormat:Ye.LUMINANCE,pixelDatatype:Ue.UNSIGNED_BYTE,source:{width:s,height:s,arrayBufferView:n},sampler:i.sampler,flipY:!1}),o.referenceCount=0}++o.referenceCount,e.waterMaskTexture=o,Rt.fromElements(0,0,1,1,e.waterMaskTranslationAndScale)}Us.prototype._findAncestorTileWithTerrainData=function(t){let e=t.parent;for(;c(e)&&(!c(e.data)||!c(e.data.terrainData)||e.data.terrainData.wasCreatedByUpsampling());)e=e.parent;return e};Us.prototype._computeWaterMaskTranslationAndScale=function(t,e,n){let i=e.rectangle,o=t.rectangle,a=o.width,s=o.height,l=a/i.width,r=s/i.height;return n.x=l*(o.west-i.west)/a,n.y=r*(o.south-i.south)/s,n.z=l,n.w=r,n};var Tu=Us;var bfo=R(W(),1);var RWo=R(W(),1);var mWo=R(W(),1);var Ybo=R(W(),1);var wVo=R(W(),1);function mU(t){if(t=f(t,f.EMPTY_OBJECT),this._ellipsoid=f(t.ellipsoid,mt.WGS84),this._numberOfLevelZeroTilesX=f(t.numberOfLevelZeroTilesX,1),this._numberOfLevelZeroTilesY=f(t.numberOfLevelZeroTilesY,1),this._projection=new Yo(this._ellipsoid),c(t.rectangleSouthwestInMeters)&&c(t.rectangleNortheastInMeters))this._rectangleSouthwestInMeters=t.rectangleSouthwestInMeters,this._rectangleNortheastInMeters=t.rectangleNortheastInMeters;else{let i=this._ellipsoid.maximumRadius*Math.PI;this._rectangleSouthwestInMeters=new K(-i,-i),this._rectangleNortheastInMeters=new K(i,i)}let e=this._projection.unproject(this._rectangleSouthwestInMeters),n=this._projection.unproject(this._rectangleNortheastInMeters);this._rectangle=new Gt(e.longitude,e.latitude,n.longitude,n.latitude)}Object.defineProperties(mU.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},rectangle:{get:function(){return this._rectangle}},projection:{get:function(){return this._projection}}});mU.prototype.getNumberOfXTilesAtLevel=function(t){return this._numberOfLevelZeroTilesX<=o&&(u=o-1);let F=b/d|0;return F>=a&&(F=a-1),c(n)?(n.x=u,n.y=F,n):new K(u,F)};var Gs=mU;var jVo=R(W(),1);var got,Z1t="AAPK3b7fccd1509046758d03c6641e404040gQG5edfR9eun2VcwtbXJKNbQjIZ7ma2vUd9ulqZK4lo3R_DJIAhwoGW9p86JNauB",f1={};f1.defaultAccessToken=Z1t;f1.defaultWorldImageryServer=new te({url:"https://ibasemaps-api.arcgis.com/arcgis/rest/services/World_Imagery/MapServer"});f1.defaultWorldHillshadeServer=new te({url:"https://ibasemaps-api.arcgis.com/arcgis/rest/services/Elevation/World_Hillshade/MapServer"});f1.defaultWorldOceanServer=new te({url:"https://ibasemaps-api.arcgis.com/arcgis/rest/services/Ocean/World_Ocean_Base/MapServer"});f1.getDefaultTokenCredit=function(t){if(t===Z1t){if(!c(got)){let e=' This application is using a default ArcGIS access token. Please assign Cesium.ArcGisMapService.defaultAccessToken with an API key from your ArcGIS Developer account before using the ArcGIS tile services. You can sign up for a free ArcGIS Developer account at https://developers.arcgis.com/.';got=new on(e,!0)}return got}};var tp=f1;var ibo=R(W(),1);function Eot(t){t=f(t,f.EMPTY_OBJECT),this._pixelsToCheck=t.pixelsToCheck,this._missingImagePixels=void 0,this._missingImageByteLength=void 0,this._isReady=!1;let e=te.createIfNeeded(t.missingImageUrl),n=this;function i(a){c(a.blob)&&(n._missingImageByteLength=a.blob.size);let s=vu(a);if(t.disableCheckIfAllPixelsAreTransparent){let l=!0,r=a.width,d=t.pixelsToCheck;for(let m=0,h=d.length;l&&m0&&(l=!1)}l&&(s=void 0)}n._missingImagePixels=s,n._isReady=!0}function o(){n._missingImagePixels=void 0,n._isReady=!0}e.fetchImage({preferBlob:!0,preferImageBitmap:!0,flipY:!0}).then(i).catch(o)}Eot.prototype.isReady=function(){return this._isReady};Eot.prototype.shouldDiscardImage=function(t){let e=this._pixelsToCheck,n=this._missingImagePixels;if(!c(n)||c(t.blob)&&t.blob.size!==this._missingImageByteLength)return!1;let i=vu(t),o=t.width;for(let a=0,s=e.length;a1&&o==="name"?(e=1,n=i):e>2&&o==="title"?(e=2,n=i):e>3&&/name/i.test(i)?(e=3,n=i):e>4&&/title/i.test(i)&&(e=4,n=i)}c(n)&&(this.name=t[n])};Cot.prototype.configureDescriptionFromProperties=function(t){function e(n){let i='';for(let o in n)if(n.hasOwnProperty(o)){let a=n[o];c(a)&&(typeof a=="object"?i+=``:i+=``)}return i+="
${o}${e(a)}
${o}${a}
",i}this.description=e(t)};var iV=Cot;var hbo=R(W(),1);function F1(){Ut.throwInstantiationError()}Object.defineProperties(F1.prototype,{rectangle:{get:Ut.throwInstantiationError},tileWidth:{get:Ut.throwInstantiationError},tileHeight:{get:Ut.throwInstantiationError},maximumLevel:{get:Ut.throwInstantiationError},minimumLevel:{get:Ut.throwInstantiationError},tilingScheme:{get:Ut.throwInstantiationError},tileDiscardPolicy:{get:Ut.throwInstantiationError},errorEvent:{get:Ut.throwInstantiationError},credit:{get:Ut.throwInstantiationError},proxy:{get:Ut.throwInstantiationError},hasAlphaChannel:{get:Ut.throwInstantiationError}});F1.prototype.getTileCredits=function(t,e,n){Ut.throwInstantiationError()};F1.prototype.requestImage=function(t,e,n,i){Ut.throwInstantiationError()};F1.prototype.pickFeatures=function(t,e,n,i,o){Ut.throwInstantiationError()};var Wge=/\.ktx2$/i;F1.loadImage=function(t,e){let n=te.createIfNeeded(e);return Wge.test(n.url)?Fm(n):c(t)&&c(t.tileDiscardPolicy)?n.fetchImage({preferBlob:!0,preferImageBitmap:!0,flipY:!0}):n.fetchImage({preferImageBitmap:!0,flipY:!0})};var $c=F1;var ubo=R(W(),1),fge={SATELLITE:1,OCEANS:2,HILLSHADE:3},oV=Object.freeze(fge);function V1t(t){this.useTiles=f(t.usePreCachedTilesIfAvailable,!0);let e=t.ellipsoid;this.tilingScheme=f(t.tilingScheme,new Qo({ellipsoid:e})),this.rectangle=f(t.rectangle,this.tilingScheme.rectangle),this.ellipsoid=e;let n=t.credit;typeof n=="string"&&(n=new on(n)),this.credit=n,this.tileCredits=void 0,this.tileDiscardPolicy=t.tileDiscardPolicy,this.tileWidth=f(t.tileWidth,256),this.tileHeight=f(t.tileHeight,256),this.maximumLevel=t.maximumLevel}V1t.prototype.build=function(t){t._useTiles=this.useTiles,t._tilingScheme=this.tilingScheme,t._rectangle=this.rectangle,t._credit=this.credit,t._tileCredits=this.tileCredits,t._tileDiscardPolicy=this.tileDiscardPolicy,t._tileWidth=this.tileWidth,t._tileHeight=this.tileHeight,t._maximumLevel=this.maximumLevel,this.useTiles&&!c(this.tileDiscardPolicy)&&(t._tileDiscardPolicy=new XM({missingImageUrl:b1t(t,0,0,this.maximumLevel).url,pixelsToCheck:[new K(0,0),new K(200,20),new K(20,200),new K(80,110),new K(160,130)],disableCheckIfAllPixelsAreTransparent:!0}))};function Fge(t,e){let n=t.tileInfo;if(!c(n))e.useTiles=!1;else{if(e.tileWidth=n.rows,e.tileHeight=n.cols,n.spatialReference.wkid===102100||n.spatialReference.wkid===102113)e.tilingScheme=new Gs({ellipsoid:e.ellipsoid});else if(t.tileInfo.spatialReference.wkid===4326)e.tilingScheme=new Qo({ellipsoid:e.ellipsoid});else{let i=`Tile spatial reference WKID ${t.tileInfo.spatialReference.wkid} is not supported.`;throw new St(i)}if(e.maximumLevel=t.tileInfo.lods.length-1,c(t.fullExtent)){if(c(t.fullExtent.spatialReference)&&c(t.fullExtent.spatialReference.wkid))if(t.fullExtent.spatialReference.wkid===102100||t.fullExtent.spatialReference.wkid===102113){let i=new Yo,o=t.fullExtent,a=i.unproject(new p(Math.max(o.xmin,-e.tilingScheme.ellipsoid.maximumRadius*Math.PI),Math.max(o.ymin,-e.tilingScheme.ellipsoid.maximumRadius*Math.PI),0)),s=i.unproject(new p(Math.min(o.xmax,e.tilingScheme.ellipsoid.maximumRadius*Math.PI),Math.min(o.ymax,e.tilingScheme.ellipsoid.maximumRadius*Math.PI),0));e.rectangle=new Gt(a.longitude,a.latitude,s.longitude,s.latitude)}else if(t.fullExtent.spatialReference.wkid===4326)e.rectangle=Gt.fromDegrees(t.fullExtent.xmin,t.fullExtent.ymin,t.fullExtent.xmax,t.fullExtent.ymax);else{let i=`fullExtent.spatialReference WKID ${t.fullExtent.spatialReference.wkid} is not supported.`;throw new St(i)}}else e.rectangle=e.tilingScheme.rectangle;e.useTiles=!0}c(t.copyrightText)&&t.copyrightText.length>0&&(c(e.credit)?e.tileCredits=[new on(t.copyrightText)]:e.credit=new on(t.copyrightText))}function Uge(t,e){let n=`An error occurred while accessing ${t.url}`;throw c(e)&&c(e.message)&&(n+=`: ${e.message}`),new St(n)}async function Gge(t,e){let n=t.getDerivedResource({queryParameters:{f:"json"}});try{let i=await n.fetchJson();Fge(i,e)}catch(i){Uge(t,i)}}function Yb(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._tileDiscardPolicy=t.tileDiscardPolicy,this._tileWidth=f(t.tileWidth,256),this._tileHeight=f(t.tileHeight,256),this._maximumLevel=t.maximumLevel,this._tilingScheme=f(t.tilingScheme,new Qo({ellipsoid:t.ellipsoid})),this._useTiles=f(t.usePreCachedTilesIfAvailable,!0),this._rectangle=f(t.rectangle,this._tilingScheme.rectangle),this._layers=t.layers,this._credit=t.credit,this._tileCredits=void 0;let e=t.credit;typeof e=="string"&&(e=new on(e)),this.enablePickFeatures=f(t.enablePickFeatures,!0),this._errorEvent=new It}Yb.fromBasemapType=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n,i,o;switch(t){case oV.SATELLITE:{n=f(e.token,tp.defaultAccessToken),i=te.createIfNeeded(tp.defaultWorldImageryServer),i.appendForwardSlash();let a=tp.getDefaultTokenCredit(n);c(a)&&(o=on.clone(a))}break;case oV.OCEANS:{n=f(e.token,tp.defaultAccessToken),i=te.createIfNeeded(tp.defaultWorldOceanServer),i.appendForwardSlash();let a=tp.getDefaultTokenCredit(n);c(a)&&(o=on.clone(a))}break;case oV.HILLSHADE:{n=f(e.token,tp.defaultAccessToken),i=te.createIfNeeded(tp.defaultWorldHillshadeServer),i.appendForwardSlash();let a=tp.getDefaultTokenCredit(n);c(a)&&(o=on.clone(a))}break;default:}return Yb.fromUrl(i,{...e,token:n,credit:o,usePreCachedTilesIfAvailable:!0})};function b1t(t,e,n,i,o){let a;if(t._useTiles)a=t._resource.getDerivedResource({url:`tile/${i}/${n}/${e}`,request:o});else{let s=t._tilingScheme.tileXYToNativeRectangle(e,n,i),r={bbox:`${s.west},${s.south},${s.east},${s.north}`,size:`${t._tileWidth},${t._tileHeight}`,format:"png32",transparent:!0,f:"image"};t._tilingScheme.projection instanceof yo?(r.bboxSR=4326,r.imageSR=4326):(r.bboxSR=3857,r.imageSR=3857),t.layers&&(r.layers=`show:${t.layers}`),a=t._resource.getDerivedResource({url:"export",request:o,queryParameters:r})}return a}Object.defineProperties(Yb.prototype,{url:{get:function(){return this._resource._url}},token:{get:function(){return this._resource.queryParameters.token}},proxy:{get:function(){return this._resource.proxy}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return 0}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},usingPrecachedTiles:{get:function(){return this._useTiles}},hasAlphaChannel:{get:function(){return!0}},layers:{get:function(){return this._layers}}});Yb.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=te.createIfNeeded(t);n.appendForwardSlash(),c(e.token)&&n.setQueryParameters({token:e.token});let i=new Yb(e);i._resource=n;let o=new V1t(e);return f(e.usePreCachedTilesIfAvailable,!0)&&await Gge(n,o),o.build(i),i};Yb.prototype.getTileCredits=function(t,e,n){return this._tileCredits};Yb.prototype.requestImage=function(t,e,n,i){return $c.loadImage(this,b1t(this,t,e,n,i))};Yb.prototype.pickFeatures=function(t,e,n,i,o){if(!this.enablePickFeatures)return;let a=this._tilingScheme.tileXYToNativeRectangle(t,e,n),s,l,r;if(this._tilingScheme.projection instanceof yo)s=k.toDegrees(i),l=k.toDegrees(o),r="4326";else{let Z=this._tilingScheme.projection.project(new gt(i,o,0));s=Z.x,l=Z.y,r="3857"}let d="visible";c(this._layers)&&(d+=`:${this._layers}`);let m={f:"json",tolerance:2,geometryType:"esriGeometryPoint",geometry:`${s},${l}`,mapExtent:`${a.west},${a.south},${a.east},${a.north}`,imageDisplay:`${this._tileWidth},${this._tileHeight},96`,sr:r,layers:d};return this._resource.getDerivedResource({url:"identify",queryParameters:m}).fetchJson().then(function(Z){let b=[],u=Z.results;if(!c(u))return b;for(let F=0;F`),this._tilingScheme=new Gs({numberOfLevelZeroTilesX:2,numberOfLevelZeroTilesY:2,ellipsoid:t.ellipsoid}),this._tileWidth=void 0,this._tileHeight=void 0,this._maximumLevel=void 0,this._imageUrlTemplate=void 0,this._imageUrlSubdomains=void 0,this._attributionList=void 0,this._errorEvent=new It}Object.defineProperties(lr.prototype,{url:{get:function(){return this._resource.url}},proxy:{get:function(){return this._resource.proxy}},key:{get:function(){return this._key}},mapStyle:{get:function(){return this._mapStyle}},mapLayer:{get:function(){return this._mapLayer}},culture:{get:function(){return this._culture}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return 0}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return c(this.mapLayer)}}});lr.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=e.tileProtocol;c(n)?n.length>0&&n[n.length-1]===":"&&(n=n.substr(0,n.length-1)):n=document.location.protocol==="http:"?"http":"https";let i=f(e.mapStyle,U1.AERIAL),o=te.createIfNeeded(t);o.appendForwardSlash();let a={incl:"ImageryProviders",key:e.key,uriScheme:n};c(e.mapLayer)&&(a.mapLayer=e.mapLayer),c(e.culture)&&(a.culture=e.culture);let s=o.getDerivedResource({url:`REST/v1/Imagery/Metadata/${i}`,queryParameters:a}),l=new lr(e);l._resource=o;let r=new R1t(e);return await gge(s,r),r.build(l),l};var Ege=new Gt;lr.prototype.getTileCredits=function(t,e,n){let i=this._tilingScheme.tileXYToRectangle(t,e,n,Ege);return Nge(this._attributionList,n,i)};lr.prototype.requestImage=function(t,e,n,i){let o=$c.loadImage(this,Cge(this,t,e,n,i));if(c(o))return o.catch(function(a){return c(a.blob)&&a.blob.size===0?G1.EMPTY_IMAGE:Promise.reject(a)})};lr.prototype.pickFeatures=function(t,e,n,i,o){};lr.tileXYToQuadKey=function(t,e,n){let i="";for(let o=n;o>=0;--o){let a=1<=0;--o){let a=1<=h.zoomMin&&e<=h.zoomMax){let Z=Gt.intersection(n,h.bbox,Ige);c(Z)&&(r=!0)}}r&&i.push(s.credit)}return i}lr._metadataCache={};var LM=lr;var QRo=R(W(),1);var WRo=R(W(),1);var W1t=/{[^}]+}/g,f1t={x:kge,y:xge,z:Lge,s:Mge,reverseX:Yge,reverseY:Xge,reverseZ:Jge,westDegrees:_ge,southDegrees:Dge,eastDegrees:Oge,northDegrees:Hge,westProjected:wge,southProjected:Pge,eastProjected:vge,northProjected:Kge,width:zge,height:jge},yge=ze(f1t,{i:qge,j:$ge,reverseI:tEe,reverseJ:eEe,longitudeDegrees:iEe,latitudeDegrees:oEe,longitudeProjected:aEe,latitudeProjected:sEe,format:rEe});function MM(t){t=f(t,f.EMPTY_OBJECT),this._errorEvent=new It;let e=te.createIfNeeded(t.url),n=te.createIfNeeded(t.pickFeaturesUrl);this._resource=e,this._urlSchemeZeroPadding=t.urlSchemeZeroPadding,this._getFeatureInfoFormats=t.getFeatureInfoFormats,this._pickFeaturesResource=n;let i=t.subdomains;Array.isArray(i)?i=i.slice():c(i)&&i.length>0?i=i.split(""):i=["a","b","c"],this._subdomains=i,this._tileWidth=f(t.tileWidth,256),this._tileHeight=f(t.tileHeight,256),this._minimumLevel=f(t.minimumLevel,0),this._maximumLevel=t.maximumLevel,this._tilingScheme=f(t.tilingScheme,new Gs({ellipsoid:t.ellipsoid})),this._rectangle=f(t.rectangle,this._tilingScheme.rectangle),this._rectangle=Gt.intersection(this._rectangle,this._tilingScheme.rectangle),this._tileDiscardPolicy=t.tileDiscardPolicy;let o=t.credit;typeof o=="string"&&(o=new on(o)),this._credit=o,this._hasAlphaChannel=f(t.hasAlphaChannel,!0);let a=t.customTags,s=ze(f1t,a),l=ze(yge,a);this._tags=s,this._pickFeaturesTags=l,this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this.enablePickFeatures=f(t.enablePickFeatures,!0)}Object.defineProperties(MM.prototype,{url:{get:function(){return this._resource.url}},urlSchemeZeroPadding:{get:function(){return this._urlSchemeZeroPadding}},pickFeaturesUrl:{get:function(){return this._pickFeaturesResource.url}},proxy:{get:function(){return this._resource.proxy}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return this._minimumLevel}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return this._hasAlphaChannel}}});MM.prototype.getTileCredits=function(t,e,n){};MM.prototype.requestImage=function(t,e,n,i){return $c.loadImage(this,Bge(this,t,e,n,i))};MM.prototype.pickFeatures=function(t,e,n,i,o){if(!this.enablePickFeatures||!c(this._pickFeaturesResource)||this._getFeatureInfoFormats.length===0)return;let a=0,s=this;function l(d,m){return d.callback(m)}function r(){if(a>=s._getFeatureInfoFormats.length)return Promise.resolve([]);let d=s._getFeatureInfoFormats[a],m=Qge(s,t,e,n,i,o,d.format);return++a,d.type==="json"?m.fetchJson().then(d.callback).catch(r):d.type==="xml"?m.fetchXML().then(d.callback).catch(r):d.type==="text"||d.type==="html"?m.fetchText().then(d.callback).catch(r):m.fetch({responseType:d.format}).then(l.bind(void 0,d)).catch(r)}return r()};var bz=!1,ep=new Gt,Rz=!1,_M=new Gt;function Bge(t,e,n,i,o){bz=!1,Rz=!1;let a=t._resource,s=a.getUrlComponent(!0),l=t._tags,r={},d=s.match(W1t);return c(d)&&d.forEach(function(m){let h=m.substring(1,m.length-1);c(l[h])&&(r[h]=l[h](t,e,n,i))}),a.getDerivedResource({request:o,templateValues:r})}var Iot=!1,T1=new K,Not=!1;function Qge(t,e,n,i,o,a,s){bz=!1,Rz=!1,Iot=!1,Not=!1;let l=t._pickFeaturesResource,r=l.getUrlComponent(!0),d=t._pickFeaturesTags,m={},h=r.match(W1t);return c(h)&&h.forEach(function(Z){let b=Z.substring(1,Z.length-1);c(d[b])&&(m[b]=d[b](t,e,n,i,o,a,s))}),l.getDerivedResource({templateValues:m})}function S1(t,e,n){if(t&&t.urlSchemeZeroPadding&&t.urlSchemeZeroPadding.hasOwnProperty(e)){let i=t.urlSchemeZeroPadding[e];if(typeof i=="string"){let o=i.length;o>1&&(n=n.length>=o?n:new Array(o-n.toString().length+1).join("0")+n)}}return n}function kge(t,e,n,i){return S1(t,"{x}",e)}function Yge(t,e,n,i){let o=t.tilingScheme.getNumberOfXTilesAtLevel(i)-e-1;return S1(t,"{reverseX}",o)}function xge(t,e,n,i){return S1(t,"{y}",n)}function Xge(t,e,n,i){let o=t.tilingScheme.getNumberOfYTilesAtLevel(i)-n-1;return S1(t,"{reverseY}",o)}function Jge(t,e,n,i){let o=t.maximumLevel,a=c(o)&&ie.rectangle.east&&(t.east=e.rectangle.east),t.southe.rectangle.north&&(t.north=e.rectangle.north),t}function U1t(t,e,n){let i=t.positionToTileXY(Gt.southwest(e),n),o=t.positionToTileXY(Gt.northeast(e),n);return(Math.abs(o.x-i.x)+1)*(Math.abs(o.y-i.y)+1)>4?0:n}Su._metadataSuccess=function(t,e,n,i,o){let a=/tileformat/i,s=/tileset/i,l=/tilesets/i,r=/boundingbox/i,d,m,h,Z=[],b=t.childNodes[0].childNodes;for(let Q=0;Q`),this._tilingScheme=void 0,this._version=void 0,this._tileWidth=256,this._tileHeight=256,this._maximumLevel=t.maximumLevel,this._errorEvent=new It}Object.defineProperties($m.prototype,{url:{get:function(){return this._url}},path:{get:function(){return this._path}},proxy:{get:function(){return this._resource.proxy}},channel:{get:function(){return this._channel}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return 0}},tilingScheme:{get:function(){return this._tilingScheme}},version:{get:function(){return this._version}},requestType:{get:function(){return this._requestType}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return!0}}});$m.fromUrl=async function(t,e,n){n=f(n,{});let i=f(n.path,"/default_map"),o=te.createIfNeeded(t).getDerivedResource({url:i[0]==="/"?i.substring(1):i});o.appendForwardSlash();let a=o.getDerivedResource({url:"query",queryParameters:{request:"Json",vars:"geeServerDefs",is2d:"t"}}),s=new G1t(n);s.channel=e,await mEe(a,s);let l=new $m(n);return s.build(l),l._resource=o,l._url=t,l._path=i,l};$m.prototype.getTileCredits=function(t,e,n){};$m.prototype.requestImage=function(t,e,n,i){let o=this._resource.getDerivedResource({url:"query",request:i,queryParameters:{request:this._requestType,channel:this._channel,version:this._version,x:t,y:e,z:n+1}});return $c.loadImage(this,o)};$m.prototype.pickFeatures=function(t,e,n,i,o){};$m._logoUrl=void 0;Object.defineProperties($m,{logoUrl:{get:function(){return c($m._logoUrl)||($m._logoUrl=Dn("Assets/Images/google_earth_credit.png")),$m._logoUrl},set:function(t){$m._logoUrl=t}}});var DM=$m;var e0o=R(W(),1);var hEe=/\/$/,A1t=new on('© Mapbox © OpenStreetMap Improve this map');function g1(t){t=f(t,f.EMPTY_OBJECT);let e=t.mapId,n=t.accessToken;this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0;let i=te.createIfNeeded(f(t.url,"https://{s}.tiles.mapbox.com/v4/"));this._mapId=e,this._accessToken=n;let o=f(t.format,"png");/\./.test(o)||(o=`.${o}`),this._format=o;let a=i.getUrlComponent();hEe.test(a)||(a+="/"),a+=`${e}/{z}/{x}/{y}${this._format}`,i.url=a,i.setQueryParameters({access_token:n});let s;c(t.credit)?(s=t.credit,typeof s=="string"&&(s=new on(s))):s=A1t,this._resource=i,this._imageryProvider=new Ad({url:i,credit:s,ellipsoid:t.ellipsoid,minimumLevel:t.minimumLevel,maximumLevel:t.maximumLevel,rectangle:t.rectangle})}Object.defineProperties(g1.prototype,{url:{get:function(){return this._imageryProvider.url}},rectangle:{get:function(){return this._imageryProvider.rectangle}},tileWidth:{get:function(){return this._imageryProvider.tileWidth}},tileHeight:{get:function(){return this._imageryProvider.tileHeight}},maximumLevel:{get:function(){return this._imageryProvider.maximumLevel}},minimumLevel:{get:function(){return this._imageryProvider.minimumLevel}},tilingScheme:{get:function(){return this._imageryProvider.tilingScheme}},tileDiscardPolicy:{get:function(){return this._imageryProvider.tileDiscardPolicy}},errorEvent:{get:function(){return this._imageryProvider.errorEvent}},credit:{get:function(){return this._imageryProvider.credit}},proxy:{get:function(){return this._imageryProvider.proxy}},hasAlphaChannel:{get:function(){return this._imageryProvider.hasAlphaChannel}}});g1.prototype.getTileCredits=function(t,e,n){};g1.prototype.requestImage=function(t,e,n,i){return this._imageryProvider.requestImage(t,e,n,i)};g1.prototype.pickFeatures=function(t,e,n,i,o){return this._imageryProvider.pickFeatures(t,e,n,i,o)};g1._defaultCredit=A1t;var OM=g1;var p0o=R(W(),1);function dS(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0;let e=f(t.rectangle,Gt.MAX_VALUE),n=new Qo({rectangle:e,numberOfLevelZeroTilesX:1,numberOfLevelZeroTilesY:1,ellipsoid:t.ellipsoid});this._tilingScheme=n,this._image=void 0,this._texture=void 0,this._hasError=!1,this._errorEvent=new It;let i=t.credit;typeof i=="string"&&(i=new on(i)),this._credit=i;let o=te.createIfNeeded(t.url);this._resource=o,this._tileWidth=t.tileWidth,this._tileHeight=t.tileHeight}Object.defineProperties(dS.prototype,{url:{get:function(){return this._resource.url}},proxy:{get:function(){return this._resource.proxy}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return 0}},minimumLevel:{get:function(){return 0}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return!0}}});function pEe(t,e,n,i){let o=`Failed to load image ${t.url}`;c(e)&&c(e.message)&&(o+=`: ${e.message}`);let a=za.reportError(i,n,c(n)?n._errorEvent:void 0,o,0,0,0,e);if(a.retry)return Bot(t,n,a);throw c(n)&&(n._hasError=!0),new St(o)}async function Bot(t,e,n){try{return await $c.loadImage(null,t)}catch(i){return pEe(t,i,e,n)}}dS.fromUrl=async function(t,e){let n=te.createIfNeeded(t),i=await Bot(n);e=f(e,f.EMPTY_OBJECT);let o=new dS({...e,url:t,tileWidth:i.width,tileHeight:i.height});return o._image=i,o};dS.prototype.getTileCredits=function(t,e,n){};dS.prototype.requestImage=async function(t,e,n,i){if(!this._hasError&&!c(this._image)){let o=await Bot(this._resource,this);return this._image=o,za.reportSuccess(this._errorEvent),o}return this._image};dS.prototype.pickFeatures=function(t,e,n,i,o){};var HM=dS;var x0o=R(W(),1);var W0o=R(W(),1);function uEe(t,e,n){this.type=t,c(e)||(t==="json"?e="application/json":t==="xml"?e="text/xml":t==="html"?e="text/html":t==="text"&&(e="text/plain")),this.format=e,c(n)||(t==="json"?n=ZEe:t==="xml"?n=WEe:(t==="html"||t==="text")&&(n=T1t)),this.callback=n}function ZEe(t){let e=[],n=t.features;for(let i=0;i0)for(let a=0;a\s*<\/body>/im,SEe=//im,gEe=/([\s\S]*)<\/title>/im;function T1t(t){if(TEe.test(t)||SEe.test(t))return;let e,n=gEe.exec(t);n&&n.length>1&&(e=n[1]);let i=new iV;return i.name=e,i.description=t,i.data=t,[i]}var cS=uEe;var S0o=R(W(),1);function wM(t){t=f(t,f.EMPTY_OBJECT),this._tileCache={},this._tilesRequestedForInterval=[];let e=this._clock=t.clock;this._times=t.times,this._requestImageFunction=t.requestImageFunction,this._reloadFunction=t.reloadFunction,this._currentIntervalIndex=-1,e.onTick.addEventListener(this._clockOnTick,this),this._clockOnTick(e)}Object.defineProperties(wM.prototype,{clock:{get:function(){return this._clock},set:function(t){this._clock!==t&&(this._clock=t,this._clockOnTick(t),this._reloadFunction())}},times:{get:function(){return this._times},set:function(t){this._times!==t&&(this._times=t,this._clockOnTick(this._clock),this._reloadFunction())}},currentInterval:{get:function(){return this._times.get(this._currentIntervalIndex)}}});wM.prototype.getFromCache=function(t,e,n,i){let o=S1t(t,e,n),a,s=this._tileCache[this._currentIntervalIndex];if(c(s)&&c(s[o])){let l=s[o];a=l.promise.catch(function(r){throw i.state=l.request.state,r}),delete s[o]}return a};wM.prototype.checkApproachingInterval=function(t,e,n,i){let o=S1t(t,e,n),a=this._tilesRequestedForInterval,s=g1t(this),l={key:o,priorityFunction:i.priorityFunction};(!c(s)||!E1t(this,l,s))&&a.push(l),a.length>=512&&a.splice(0,256)};wM.prototype._clockOnTick=function(t){let e=t.currentTime,i=this._times.indexOf(e),o=this._currentIntervalIndex;if(i!==o){let s=this._tileCache[o];for(let l in s)s.hasOwnProperty(l)&&s[l].request.cancel();delete this._tileCache[o],this._tilesRequestedForInterval=[],this._currentIntervalIndex=i,this._reloadFunction();return}let a=g1t(this);if(c(a)){let s=this._tilesRequestedForInterval,l=!0;for(;l&&s.length!==0;){let r=s.pop();l=E1t(this,r,a),l||s.push(r)}}};function S1t(t,e,n){return`${t}-${e}-${n}`}function EEe(t){let e=t.split("-");if(e.length===3)return{x:Number(e[0]),y:Number(e[1]),level:Number(e[2])}}function g1t(t){let e=t._times;if(!c(e))return;let n=t._clock,i=n.currentTime,o=n.canAnimate&&n.shouldAnimate,a=n.multiplier;if(!o&&a!==0)return;let s,l=e.indexOf(i);if(l<0)return;let r=e.get(l);return a>0?(s=rt.secondsDifference(r.stop,i),++l):(s=rt.secondsDifference(r.start,i),--l),s/=a,l>=0&&s<=5?e.get(l):void 0}function E1t(t,e,n){let i=t._times.indexOf(n.start),o=t._tileCache,a=o[i];c(a)||(a=o[i]={});let s=e.key;if(c(a[s]))return!0;let l=EEe(s),r=new Zs({throttle:!1,throttleByServer:!0,type:Xl.IMAGERY,priorityFunction:e.priorityFunction}),d=t._requestImageFunction(l.x,l.y,l.level,r,n);return c(d)?(a[s]={promise:d,request:r},!0):!1}var mS=wM;var CEe=[3034,3035,3042,3043,3044],IEe=[4471,4559];function aV(t){if(t=f(t,f.EMPTY_OBJECT),c(t.times)&&!c(t.clock))throw new Ut("options.times was specified, so options.clock is required.");this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._getFeatureInfoUrl=f(t.getFeatureInfoUrl,t.url);let e=te.createIfNeeded(t.url),n=te.createIfNeeded(this._getFeatureInfoUrl);e.setQueryParameters(aV.DefaultParameters,!0),n.setQueryParameters(aV.GetFeatureInfoDefaultParameters,!0),c(t.parameters)&&e.setQueryParameters(C1t(t.parameters)),c(t.getFeatureInfoParameters)&&n.setQueryParameters(C1t(t.getFeatureInfoParameters));let i=this;this._reload=void 0,c(t.times)&&(this._timeDynamicImagery=new mS({clock:t.clock,times:t.times,requestImageFunction:function(s,l,r,d,m){return I1t(i,s,l,r,d,m)},reloadFunction:function(){c(i._reload)&&i._reload()}}));let o={};if(o.layers=t.layers,o.bbox="{westProjected},{southProjected},{eastProjected},{northProjected}",o.width="{width}",o.height="{height}",parseFloat(e.queryParameters.version)>=1.3){o.crs=f(t.crs,t.tilingScheme&&t.tilingScheme.projection instanceof Yo?"EPSG:3857":"CRS:84");let s=o.crs.split(":");if(s[0]==="EPSG"&&s.length===2){let l=Number(s[1]);(l>=4e3&&l<5e3&&!IEe.includes(l)||CEe.includes(l))&&(o.bbox="{southProjected},{westProjected},{northProjected},{eastProjected}")}}else o.srs=f(t.srs,t.tilingScheme&&t.tilingScheme.projection instanceof Yo?"EPSG:3857":"EPSG:4326");e.setQueryParameters(o,!0),n.setQueryParameters(o,!0);let a={query_layers:t.layers,info_format:"{format}"};parseFloat(n.queryParameters.version)>=1.3?(a.i="{i}",a.j="{j}"):(a.x="{i}",a.y="{j}"),n.setQueryParameters(a,!0),this._resource=e,this._pickFeaturesResource=n,this._layers=t.layers,this._tileProvider=new Ad({url:e,pickFeaturesUrl:n,tilingScheme:f(t.tilingScheme,new Qo({ellipsoid:t.ellipsoid})),rectangle:t.rectangle,tileWidth:t.tileWidth,tileHeight:t.tileHeight,minimumLevel:t.minimumLevel,maximumLevel:t.maximumLevel,subdomains:t.subdomains,tileDiscardPolicy:t.tileDiscardPolicy,credit:t.credit,getFeatureInfoFormats:f(t.getFeatureInfoFormats,aV.DefaultGetFeatureInfoFormats),enablePickFeatures:t.enablePickFeatures})}function I1t(t,e,n,i,o,a){let s=c(a)?a.data:void 0,l=t._tileProvider;return c(s)&&l._resource.setQueryParameters(s),l.requestImage(e,n,i,o)}function NEe(t,e,n,i,o,a,s){let l=c(s)?s.data:void 0,r=t._tileProvider;return c(l)&&r._pickFeaturesResource.setQueryParameters(l),r.pickFeatures(e,n,i,o,a)}Object.defineProperties(aV.prototype,{url:{get:function(){return this._resource._url}},proxy:{get:function(){return this._resource.proxy}},layers:{get:function(){return this._layers}},tileWidth:{get:function(){return this._tileProvider.tileWidth}},tileHeight:{get:function(){return this._tileProvider.tileHeight}},maximumLevel:{get:function(){return this._tileProvider.maximumLevel}},minimumLevel:{get:function(){return this._tileProvider.minimumLevel}},tilingScheme:{get:function(){return this._tileProvider.tilingScheme}},rectangle:{get:function(){return this._tileProvider.rectangle}},tileDiscardPolicy:{get:function(){return this._tileProvider.tileDiscardPolicy}},errorEvent:{get:function(){return this._tileProvider.errorEvent}},credit:{get:function(){return this._tileProvider.credit}},hasAlphaChannel:{get:function(){return this._tileProvider.hasAlphaChannel}},enablePickFeatures:{get:function(){return this._tileProvider.enablePickFeatures},set:function(t){this._tileProvider.enablePickFeatures=t}},clock:{get:function(){return this._timeDynamicImagery.clock},set:function(t){this._timeDynamicImagery.clock=t}},times:{get:function(){return this._timeDynamicImagery.times},set:function(t){this._timeDynamicImagery.times=t}},getFeatureInfoUrl:{get:function(){return this._getFeatureInfoUrl}}});aV.prototype.getTileCredits=function(t,e,n){return this._tileProvider.getTileCredits(t,e,n)};aV.prototype.requestImage=function(t,e,n,i){let o,a=this._timeDynamicImagery,s;return c(a)&&(s=a.currentInterval,o=a.getFromCache(t,e,n,i)),c(o)||(o=I1t(this,t,e,n,i,s)),c(o)&&c(a)&&a.checkApproachingInterval(t,e,n,i),o};aV.prototype.pickFeatures=function(t,e,n,i,o){let a=this._timeDynamicImagery,s=c(a)?a.currentInterval:void 0;return NEe(this,t,e,n,i,o,s)};aV.DefaultParameters=Object.freeze({service:"WMS",version:"1.1.1",request:"GetMap",styles:"",format:"image/jpeg"});aV.GetFeatureInfoDefaultParameters=Object.freeze({service:"WMS",version:"1.1.1",request:"GetFeatureInfo"});aV.DefaultGetFeatureInfoFormats=Object.freeze([Object.freeze(new cS("json","application/json")),Object.freeze(new cS("xml","text/xml")),Object.freeze(new cS("text","text/html"))]);function C1t(t){let e={};for(let n in t)t.hasOwnProperty(n)&&(e[n.toLowerCase()]=t[n]);return e}var PM=aV;var K0o=R(W(),1);var yEe=Object.freeze({service:"WMTS",version:"1.0.0",request:"GetTile"});function vM(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0;let e=te.createIfNeeded(t.url),n=t.style,i=t.tileMatrixSetID,o=e.url,a=o.match(/{/g);if(!c(a)||a.length===1&&/{s}/.test(o))e.setQueryParameters(yEe),this._useKvp=!0;else{let h={style:n,Style:n,TileMatrixSet:i};e.setTemplateValues(h),this._useKvp=!1}this._resource=e,this._layer=t.layer,this._style=n,this._tileMatrixSetID=i,this._tileMatrixLabels=t.tileMatrixLabels,this._format=f(t.format,"image/jpeg"),this._tileDiscardPolicy=t.tileDiscardPolicy,this._tilingScheme=c(t.tilingScheme)?t.tilingScheme:new Gs({ellipsoid:t.ellipsoid}),this._tileWidth=f(t.tileWidth,256),this._tileHeight=f(t.tileHeight,256),this._minimumLevel=f(t.minimumLevel,0),this._maximumLevel=t.maximumLevel,this._rectangle=f(t.rectangle,this._tilingScheme.rectangle),this._dimensions=t.dimensions;let s=this;this._reload=void 0,c(t.times)&&(this._timeDynamicImagery=new mS({clock:t.clock,times:t.times,requestImageFunction:function(h,Z,b,u,F){return N1t(s,h,Z,b,u,F)},reloadFunction:function(){c(s._reload)&&s._reload()}}));let l=this._tilingScheme.positionToTileXY(Gt.southwest(this._rectangle),this._minimumLevel),r=this._tilingScheme.positionToTileXY(Gt.northeast(this._rectangle),this._minimumLevel),d=(Math.abs(r.x-l.x)+1)*(Math.abs(r.y-l.y)+1);this._errorEvent=new It;let m=t.credit;this._credit=typeof m=="string"?new on(m):m,this._subdomains=t.subdomains,Array.isArray(this._subdomains)?this._subdomains=this._subdomains.slice():c(this._subdomains)&&this._subdomains.length>0?this._subdomains=this._subdomains.split(""):this._subdomains=["a","b","c"]}function N1t(t,e,n,i,o,a){let s=t._tileMatrixLabels,l=c(s)?s[i]:i.toString(),r=t._subdomains,d=t._dimensions,m=c(a)?a.data:void 0,h,Z;if(!t._useKvp)Z={TileMatrix:l,TileRow:n.toString(),TileCol:e.toString(),s:r[(e+n+i)%r.length]},h=t._resource.getDerivedResource({request:o}),h.setTemplateValues(Z),c(d)&&h.setTemplateValues(d),c(m)&&h.setTemplateValues(m);else{let b={};b.tilematrix=l,b.layer=t._layer,b.style=t._style,b.tilerow=n,b.tilecol=e,b.tilematrixset=t._tileMatrixSetID,b.format=t._format,c(d)&&(b=ze(b,d)),c(m)&&(b=ze(b,m)),Z={s:r[(e+n+i)%r.length]},h=t._resource.getDerivedResource({queryParameters:b,request:o}),h.setTemplateValues(Z)}return $c.loadImage(t,h)}Object.defineProperties(vM.prototype,{url:{get:function(){return this._resource.url}},proxy:{get:function(){return this._resource.proxy}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return this._minimumLevel}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},format:{get:function(){return this._format}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return!0}},clock:{get:function(){return this._timeDynamicImagery.clock},set:function(t){this._timeDynamicImagery.clock=t}},times:{get:function(){return this._timeDynamicImagery.times},set:function(t){this._timeDynamicImagery.times=t}},dimensions:{get:function(){return this._dimensions},set:function(t){this._dimensions!==t&&(this._dimensions=t,c(this._reload)&&this._reload())}}});vM.prototype.getTileCredits=function(t,e,n){};vM.prototype.requestImage=function(t,e,n,i){let o,a=this._timeDynamicImagery,s;return c(a)&&(s=a.currentInterval,o=a.getFromCache(t,e,n,i)),c(o)||(o=N1t(this,t,e,n,i,s)),c(o)&&c(a)&&a.checkApproachingInterval(t,e,n,i),o};vM.prototype.pickFeatures=function(t,e,n,i,o){};var hS=vM;var BEe={ARCGIS_MAPSERVER:cW.fromUrl,BING:async(t,e)=>LM.fromUrl(t,e),GOOGLE_EARTH:async(t,e)=>{let n=e.channel;return delete e.channel,DM.fromUrl(t,n,e)},MAPBOX:(t,e)=>new OM({url:t,...e}),SINGLE_TILE:HM.fromUrl,TMS:hU.fromUrl,URL_TEMPLATE:(t,e)=>new Ad({url:t,...e}),WMS:(t,e)=>new PM({url:t,...e}),WMTS:(t,e)=>new hS({url:t,...e})};function xb(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._tileCredits=void 0,this._errorEvent=new It}Object.defineProperties(xb.prototype,{rectangle:{get:function(){return this._imageryProvider.rectangle}},tileWidth:{get:function(){return this._imageryProvider.tileWidth}},tileHeight:{get:function(){return this._imageryProvider.tileHeight}},maximumLevel:{get:function(){return this._imageryProvider.maximumLevel}},minimumLevel:{get:function(){return this._imageryProvider.minimumLevel}},tilingScheme:{get:function(){return this._imageryProvider.tilingScheme}},tileDiscardPolicy:{get:function(){return this._imageryProvider.tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._imageryProvider.credit}},hasAlphaChannel:{get:function(){return this._imageryProvider.hasAlphaChannel}},proxy:{get:function(){}}});xb.fromAssetId=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=gh._createEndpointResource(t,e),i=t.toString()+e.accessToken+e.server,o=xb._endpointCache[i];c(o)||(o=n.fetchJson(),xb._endpointCache[i]=o);let a=await o;if(a.type!=="IMAGERY")throw new St(`Cesium ion asset ${t} is not an imagery asset.`);let s,l=a.externalType;if(!c(l))s=await hU.fromUrl(new gh(a,n));else{let d=BEe[l];if(!c(d))throw new St(`Unrecognized Cesium ion imagery type: ${l}`);let m={...a.options},h=m.url;delete m.url,s=await d(h,m)}let r=new xb(e);return s.errorEvent.addEventListener(function(d){d.provider=r,r._errorEvent.raiseEvent(d)}),r._tileCredits=gh.getCreditsFromEndpoint(a,n),r._imageryProvider=s,r};xb.prototype.getTileCredits=function(t,e,n){let i=this._imageryProvider.getTileCredits(t,e,n);return c(i)?this._tileCredits.concat(i):this._tileCredits};xb.prototype.requestImage=function(t,e,n,i){return this._imageryProvider.requestImage(t,e,n,i)};xb.prototype.pickFeatures=function(t,e,n,i,o){return this._imageryProvider.pickFeatures(t,e,n,i,o)};xb._endpointCache={};var mW=xb;var pWo=R(W(),1),QEe={AERIAL:2,AERIAL_WITH_LABELS:3,ROAD:4},hW=Object.freeze(QEe);function kEe(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.style,hW.AERIAL);return mW.fromAssetId(e)}var pW=kEe;var fWo=R(W(),1),KM=`uniform sampler2D u_texture; + }`,oe.sources.push(He),ie.sources.push(qTe(Qt)),ie.sources.push(ege(g));let rn=xn.fromCache({context:e.context,vertexShaderSource:ie,fragmentShaderSource:oe,attributeLocations:$.getAttributeLocations()});Mt=qt[Wt]=new jTe(i,Wt,this.material,rn,Nt,kt)}return n.surfaceShader=Mt,Mt.shaderProgram};Sot.prototype.destroy=function(){let t,e,n=this._shadersByTexturesFlags;for(let i in n)if(n.hasOwnProperty(i)){let o=n[i];if(!c(o))continue;for(t in o)o.hasOwnProperty(t)&&(e=o[t],c(e)&&e.shaderProgram.destroy())}return At(this)};var xM=Sot;var OFo=b(W(),1);var quo=b(W(),1),nge={NONE:-1,PARTIAL:0,FULL:1},Ys=Object.freeze(nge);var XZo=b(W(),1);var iZo=b(W(),1);function uz(t,e,n,i,o,a,s){this.provider=t,this.message=e,this.x=n,this.y=i,this.level=o,this.timesRetried=f(a,0),this.retry=!1,this.error=s}uz.reportError=function(t,e,n,i,o,a,s,l){let r=t;return c(t)?(r.provider=e,r.message=i,r.x=o,r.y=a,r.level=s,r.retry=!1,r.error=l,++r.timesRetried):r=new uz(e,i,o,a,s,0,l),c(n)&&n.numberOfListeners>0?n.raiseEvent(r):c(e)&&console.log(`An error occurred in "${e.constructor.name}": ${QR(i)}`),r};uz.reportSuccess=function(t){c(t)&&(t.timesRetried=-1)};var za=uz;var aZo=b(W(),1),ige={UNLOADED:0,TRANSITIONING:1,RECEIVED:2,TEXTURE_LOADED:3,READY:4,FAILED:5,INVALID:6,PLACEHOLDER:7},ho=Object.freeze(ige);var lZo=b(W(),1),oge={START:0,LOADING:1,DONE:2,FAILED:3},Br=Object.freeze(oge);var dZo=b(W(),1),age={FAILED:0,UNLOADED:1,RECEIVING:2,RECEIVED:3,TRANSFORMING:4,TRANSFORMED:5,READY:6},Ga=Object.freeze(age);function Us(){this.imagery=[],this.waterMaskTexture=void 0,this.waterMaskTranslationAndScale=new bt(0,0,1,1),this.terrainData=void 0,this.vertexArray=void 0,this.tileBoundingRegion=void 0,this.occludeePointInScaledSpace=new p,this.boundingVolumeSourceTile=void 0,this.boundingVolumeIsFromMesh=!1,this.terrainState=Ga.UNLOADED,this.mesh=void 0,this.fill=void 0,this.pickBoundingSphere=new Ft,this.surfaceShader=void 0,this.isClipped=!0,this.clippedByBoundaries=!1}Object.defineProperties(Us.prototype,{eligibleForUnloading:{get:function(){let t=this.terrainState,n=!(t===Ga.RECEIVING||t===Ga.TRANSFORMING),i=this.imagery;for(let o=0,a=i.length;n&&o<a;++o){let s=i[o];n=!c(s.loadingImagery)||s.loadingImagery.state!==ho.TRANSITIONING}return n}},renderedMesh:{get:function(){if(c(this.vertexArray))return this.mesh;if(c(this.fill))return this.fill.mesh}}});var sge=new gt;function Tot(t,e,n,i,o,a){let s=t.getExaggeratedPosition(i,o,a);if(c(e)&&e!==Vt.SCENE3D){let r=n.ellipsoid.cartesianToCartographic(s,sge);s=n.project(r,a),s=p.fromElements(s.z,s.x,s.y,a)}return s}var lge=new p,rge=new p,dge=new p;Us.prototype.pick=function(t,e,n,i,o){let a=this.renderedMesh;if(!c(a))return;let s=a.vertices,l=a.indices,r=a.encoding,d=l.length,m=Number.MAX_VALUE;for(let h=0;h<d;h+=3){let u=l[h],R=l[h+1],V=l[h+2],F=Tot(r,e,n,s,u,lge),U=Tot(r,e,n,s,R,rge),G=Tot(r,e,n,s,V,dge),A=no.rayTriangleParametric(t,F,U,G,i);c(A)&&A<m&&A>=0&&(m=A)}return m!==Number.MAX_VALUE?di.getPoint(t,m,o):void 0};Us.prototype.freeResources=function(){c(this.waterMaskTexture)&&(--this.waterMaskTexture.referenceCount,this.waterMaskTexture.referenceCount===0&&this.waterMaskTexture.destroy(),this.waterMaskTexture=void 0),this.terrainData=void 0,this.terrainState=Ga.UNLOADED,this.mesh=void 0,this.fill=this.fill&&this.fill.destroy();let t=this.imagery;for(let e=0,n=t.length;e<n;++e)t[e].freeResources();this.imagery.length=0,this.freeVertexArray()};Us.prototype.freeVertexArray=function(){Us._freeVertexArray(this.vertexArray),this.vertexArray=void 0,Us._freeVertexArray(this.wireframeVertexArray),this.wireframeVertexArray=void 0};Us.initialize=function(t,e,n){let i=t.data;c(i)||(i=t.data=new Us),t.state===Br.START&&(cge(t,e,n),t.state=Br.LOADING)};Us.processStateMachine=function(t,e,n,i,o,a,s){Us.initialize(t,n,i);let l=t.data;if(t.state===Br.LOADING&&mge(t,e,n,i,o,a),s)return;let r=t.renderable;t.renderable=c(l.vertexArray);let d=l.terrainState===Ga.READY;t.upsampledFromParent=c(l.terrainData)&&l.terrainData.wasCreatedByUpsampling();let m=l.processImagery(t,n,e);if(d&&m){let h=t._loadedCallbacks,u={};for(let R in h)h.hasOwnProperty(R)&&(h[R](t)||(u[R]=h[R]));t._loadedCallbacks=u,t.state=Br.DONE}r&&(t.renderable=!0)};Us.prototype.processImagery=function(t,e,n,i){let o=t.data,a=t.upsampledFromParent,s=!1,l=!0,r=o.imagery,d,m;for(d=0,m=r.length;d<m;++d){let h=r[d];if(!c(h.loadingImagery)){a=!1;continue}if(h.loadingImagery.state===ho.PLACEHOLDER){let R=h.loadingImagery.imageryLayer;if(R.ready){h.freeResources(),r.splice(d,1),R._createTileImagerySkeletons(t,e,d),--d,m=r.length;continue}else a=!1}let u=h.processStateMachine(t,n,i);l=l&&u,s=s||u||c(h.readyImagery),a=a&&c(h.loadingImagery)&&(h.loadingImagery.state===ho.FAILED||h.loadingImagery.state===ho.INVALID)}return t.upsampledFromParent=a,t.renderable=t.renderable&&(s||l),l};function V1t(t,e,n,i){let o=t.renderedMesh,a=o.vertices,s=o.encoding,l=a.length/s.stride,r=lc.clone(s);r.hasGeodeticSurfaceNormals=e,r=lc.clone(r);let d=r.stride,m=new Float32Array(l*d);e?s.addGeodeticSurfaceNormals(a,m,n):s.removeGeodeticSurfaceNormals(a,m),o.vertices=m,o.stride=d,o!==t.mesh?(Us._freeVertexArray(t.fill.vertexArray),t.fill.vertexArray=Us._createVertexArrayForMesh(i.context,o)):(Us._freeVertexArray(t.vertexArray),t.vertexArray=Us._createVertexArrayForMesh(i.context,o)),Us._freeVertexArray(t.wireframeVertexArray),t.wireframeVertexArray=void 0}Us.prototype.addGeodeticSurfaceNormals=function(t,e){V1t(this,!0,t,e)};Us.prototype.removeGeodeticSurfaceNormals=function(t){V1t(this,!1,void 0,t)};Us.prototype.updateExaggeration=function(t,e,n){let i=this,o=i.renderedMesh;if(o===void 0)return;let a=e.verticalExaggeration,s=e.verticalExaggerationRelativeHeight,l=a!==1,r=o.encoding,d=r.exaggeration!==a,m=r.exaggerationRelativeHeight!==s;if(d||m){if(d)if(l&&!r.hasGeodeticSurfaceNormals){let h=t.tilingScheme.ellipsoid;i.addGeodeticSurfaceNormals(h,e)}else!l&&r.hasGeodeticSurfaceNormals&&i.removeGeodeticSurfaceNormals(e);if(r.exaggeration=a,r.exaggerationRelativeHeight=s,n!==void 0){n._tileToUpdateHeights.push(t);let h=t.customData,u=h.length;for(let R=0;R<u;R++){let V=h[R];V.level=-1}}}};function cge(t,e,n){let i=e.getTileDataAvailable(t.x,t.y,t.level);if(!c(i)&&c(t.parent)){let o=t.parent,a=o.data;c(a)&&c(a.terrainData)&&(i=a.terrainData.isChildAvailable(o.x,o.y,t.x,t.y))}i===!1&&(t.data.terrainState=Ga.FAILED);for(let o=0,a=n.length;o<a;++o){let s=n.get(o);s.show&&s._createTileImagerySkeletons(t,e)}}function mge(t,e,n,i,o,a){let s=t.data,l=t.parent;if(s.terrainState===Ga.FAILED&&l!==void 0&&(l.data!==void 0&&l.data.terrainData!==void 0&&l.data.terrainData.canUpsample!==!1||Us.processStateMachine(l,e,n,i,o,a,!0)),s.terrainState===Ga.FAILED&&hge(s,t,e,n,t.x,t.y,t.level),s.terrainState===Ga.UNLOADED&&pge(s,n,t.x,t.y,t.level),s.terrainState===Ga.RECEIVED&&uge(s,e,n,t.x,t.y,t.level),s.terrainState===Ga.TRANSFORMED&&(Zge(s,e.context,n,t.x,t.y,t.level,a),s.updateExaggeration(t,e,o)),s.terrainState>=Ga.RECEIVED&&s.waterMaskTexture===void 0&&n.hasWaterMask)if(s.terrainData.waterMask!==void 0)bge(e.context,s);else{let d=s._findAncestorTileWithTerrainData(t);c(d)&&c(d.data.waterMaskTexture)&&(s.waterMaskTexture=d.data.waterMaskTexture,++s.waterMaskTexture.referenceCount,s._computeWaterMaskTranslationAndScale(t,d,s.waterMaskTranslationAndScale))}}function hge(t,e,n,i,o,a,s){let l=e.parent;if(!l){e.state=Br.FAILED;return}let r=l.data.terrainData,d=l.x,m=l.y,h=l.level;if(!c(r))return;let u=r.upsample(i.tilingScheme,d,m,h,o,a,s);c(u)&&(t.terrainState=Ga.RECEIVING,Promise.resolve(u).then(function(R){c(R)&&(t.terrainData=R,t.terrainState=Ga.RECEIVED)}).catch(function(){t.terrainState=Ga.FAILED}))}function pge(t,e,n,i,o){function a(r){if(!c(r)){t.terrainState=Ga.UNLOADED,t.request=void 0;return}t.terrainData=r,t.terrainState=Ga.RECEIVED,t.request=void 0}function s(r){if(t.request.state===qi.CANCELLED){t.terrainData=void 0,t.terrainState=Ga.UNLOADED,t.request=void 0;return}t.terrainState=Ga.FAILED,t.request=void 0;let d=`Failed to obtain terrain tile X: ${n} Y: ${i} Level: ${o}. Error message: "${r}"`;e._requestError=za.reportError(e._requestError,e,e.errorEvent,d,n,i,o),e._requestError.retry&&l()}function l(){let r=new us({throttle:!1,throttleByServer:!0,type:Xl.TERRAIN});t.request=r;let d=e.requestTileGeometry(n,i,o,r);c(d)?(t.terrainState=Ga.RECEIVING,Promise.resolve(d).then(function(m){a(m)}).catch(function(m){s(m)})):(t.terrainState=Ga.UNLOADED,t.request=void 0)}l()}var Vge={tilingScheme:void 0,x:0,y:0,level:0,exaggeration:1,exaggerationRelativeHeight:0,throttle:!0};function uge(t,e,n,i,o,a){let s=n.tilingScheme,l=Vge;l.tilingScheme=s,l.x=i,l.y=o,l.level=a,l.exaggeration=e.verticalExaggeration,l.exaggerationRelativeHeight=e.verticalExaggerationRelativeHeight,l.throttle=!0;let d=t.terrainData.createMesh(l);c(d)&&(t.terrainState=Ga.TRANSFORMING,Promise.resolve(d).then(function(m){t.mesh=m,t.terrainState=Ga.TRANSFORMED}).catch(function(){t.terrainState=Ga.FAILED}))}Us._createVertexArrayForMesh=function(t,e){let n=e.vertices,i=we.createVertexBuffer({context:t,typedArray:n,usage:ce.STATIC_DRAW}),o=e.encoding.getAttributes(i),a=e.indices.indexBuffers||{},s=a[t.id];if(!c(s)||s.isDestroyed()){let l=e.indices;s=we.createIndexBuffer({context:t,typedArray:l,usage:ce.STATIC_DRAW,indexDatatype:re.fromSizeInBytes(l.BYTES_PER_ELEMENT)}),s.vertexArrayDestroyable=!1,s.referenceCount=1,a[t.id]=s,e.indices.indexBuffers=a}else++s.referenceCount;return new Ki({context:t,attributes:o,indexBuffer:s})};Us._freeVertexArray=function(t){if(c(t)){let e=t.indexBuffer;t.isDestroyed()||t.destroy(),c(e)&&!e.isDestroyed()&&c(e.referenceCount)&&(--e.referenceCount,e.referenceCount===0&&e.destroy())}};function Zge(t,e,n,i,o,a,s){t.vertexArray=Us._createVertexArrayForMesh(e,t.mesh),t.terrainState=Ga.READY,t.fill=t.fill&&t.fill.destroy(s)}function Rge(t){let e=t.cache.tile_waterMaskData;if(!c(e)){let n=hn.create({context:t,pixelFormat:Ye.LUMINANCE,pixelDatatype:Ue.UNSIGNED_BYTE,source:{arrayBufferView:new Uint8Array([255]),width:1,height:1}});n.referenceCount=1;let i=new Hn({wrapS:Zi.CLAMP_TO_EDGE,wrapT:Zi.CLAMP_TO_EDGE,minificationFilter:On.LINEAR,magnificationFilter:Ro.LINEAR});e={allWaterTexture:n,sampler:i,destroy:function(){this.allWaterTexture.destroy()}},t.cache.tile_waterMaskData=e}return e}function bge(t,e){let n=e.terrainData.waterMask,i=Rge(t),o,a=n.length;if(a===1)if(n[0]!==0)o=i.allWaterTexture;else return;else{let s=Math.sqrt(a);o=hn.create({context:t,pixelFormat:Ye.LUMINANCE,pixelDatatype:Ue.UNSIGNED_BYTE,source:{width:s,height:s,arrayBufferView:n},sampler:i.sampler,flipY:!1}),o.referenceCount=0}++o.referenceCount,e.waterMaskTexture=o,bt.fromElements(0,0,1,1,e.waterMaskTranslationAndScale)}Us.prototype._findAncestorTileWithTerrainData=function(t){let e=t.parent;for(;c(e)&&(!c(e.data)||!c(e.data.terrainData)||e.data.terrainData.wasCreatedByUpsampling());)e=e.parent;return e};Us.prototype._computeWaterMaskTranslationAndScale=function(t,e,n){let i=e.rectangle,o=t.rectangle,a=o.width,s=o.height,l=a/i.width,r=s/i.height;return n.x=l*(o.west-i.west)/a,n.y=r*(o.south-i.south)/s,n.z=l,n.w=r,n};var SV=Us;var Rfo=b(W(),1);var bWo=b(W(),1);var mWo=b(W(),1);var YRo=b(W(),1);var wZo=b(W(),1);function mU(t){if(t=f(t,f.EMPTY_OBJECT),this._ellipsoid=f(t.ellipsoid,mt.WGS84),this._numberOfLevelZeroTilesX=f(t.numberOfLevelZeroTilesX,1),this._numberOfLevelZeroTilesY=f(t.numberOfLevelZeroTilesY,1),this._projection=new Yo(this._ellipsoid),c(t.rectangleSouthwestInMeters)&&c(t.rectangleNortheastInMeters))this._rectangleSouthwestInMeters=t.rectangleSouthwestInMeters,this._rectangleNortheastInMeters=t.rectangleNortheastInMeters;else{let i=this._ellipsoid.maximumRadius*Math.PI;this._rectangleSouthwestInMeters=new K(-i,-i),this._rectangleNortheastInMeters=new K(i,i)}let e=this._projection.unproject(this._rectangleSouthwestInMeters),n=this._projection.unproject(this._rectangleNortheastInMeters);this._rectangle=new Gt(e.longitude,e.latitude,n.longitude,n.latitude)}Object.defineProperties(mU.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},rectangle:{get:function(){return this._rectangle}},projection:{get:function(){return this._projection}}});mU.prototype.getNumberOfXTilesAtLevel=function(t){return this._numberOfLevelZeroTilesX<<t};mU.prototype.getNumberOfYTilesAtLevel=function(t){return this._numberOfLevelZeroTilesY<<t};mU.prototype.rectangleToNativeRectangle=function(t,e){let n=this._projection,i=n.project(Gt.southwest(t)),o=n.project(Gt.northeast(t));return c(e)?(e.west=i.x,e.south=i.y,e.east=o.x,e.north=o.y,e):new Gt(i.x,i.y,o.x,o.y)};mU.prototype.tileXYToNativeRectangle=function(t,e,n,i){let o=this.getNumberOfXTilesAtLevel(n),a=this.getNumberOfYTilesAtLevel(n),s=(this._rectangleNortheastInMeters.x-this._rectangleSouthwestInMeters.x)/o,l=this._rectangleSouthwestInMeters.x+t*s,r=this._rectangleSouthwestInMeters.x+(t+1)*s,d=(this._rectangleNortheastInMeters.y-this._rectangleSouthwestInMeters.y)/a,m=this._rectangleNortheastInMeters.y-e*d,h=this._rectangleNortheastInMeters.y-(e+1)*d;return c(i)?(i.west=l,i.south=h,i.east=r,i.north=m,i):new Gt(l,h,r,m)};mU.prototype.tileXYToRectangle=function(t,e,n,i){let o=this.tileXYToNativeRectangle(t,e,n,i),a=this._projection,s=a.unproject(new K(o.west,o.south)),l=a.unproject(new K(o.east,o.north));return o.west=s.longitude,o.south=s.latitude,o.east=l.longitude,o.north=l.latitude,o};mU.prototype.positionToTileXY=function(t,e,n){let i=this._rectangle;if(!Gt.contains(i,t))return;let o=this.getNumberOfXTilesAtLevel(e),a=this.getNumberOfYTilesAtLevel(e),l=(this._rectangleNortheastInMeters.x-this._rectangleSouthwestInMeters.x)/o,d=(this._rectangleNortheastInMeters.y-this._rectangleSouthwestInMeters.y)/a,h=this._projection.project(t),u=h.x-this._rectangleSouthwestInMeters.x,R=this._rectangleNortheastInMeters.y-h.y,V=u/l|0;V>=o&&(V=o-1);let F=R/d|0;return F>=a&&(F=a-1),c(n)?(n.x=V,n.y=F,n):new K(V,F)};var Gs=mU;var jZo=b(W(),1);var got,u1t="AAPK3b7fccd1509046758d03c6641e404040gQG5edfR9eun2VcwtbXJKNbQjIZ7ma2vUd9ulqZK4lo3R_DJIAhwoGW9p86JNauB",f1={};f1.defaultAccessToken=u1t;f1.defaultWorldImageryServer=new te({url:"https://ibasemaps-api.arcgis.com/arcgis/rest/services/World_Imagery/MapServer"});f1.defaultWorldHillshadeServer=new te({url:"https://ibasemaps-api.arcgis.com/arcgis/rest/services/Elevation/World_Hillshade/MapServer"});f1.defaultWorldOceanServer=new te({url:"https://ibasemaps-api.arcgis.com/arcgis/rest/services/Ocean/World_Ocean_Base/MapServer"});f1.getDefaultTokenCredit=function(t){if(t===u1t){if(!c(got)){let e='<b> This application is using a default ArcGIS access token. Please assign <i>Cesium.ArcGisMapService.defaultAccessToken</i> with an API key from your ArcGIS Developer account before using the ArcGIS tile services. You can sign up for a free ArcGIS Developer account at <a href="https://developers.arcgis.com/">https://developers.arcgis.com/</a>.</b>';got=new on(e,!0)}return got}};var tp=f1;var iRo=b(W(),1);function Eot(t){t=f(t,f.EMPTY_OBJECT),this._pixelsToCheck=t.pixelsToCheck,this._missingImagePixels=void 0,this._missingImageByteLength=void 0,this._isReady=!1;let e=te.createIfNeeded(t.missingImageUrl),n=this;function i(a){c(a.blob)&&(n._missingImageByteLength=a.blob.size);let s=vV(a);if(t.disableCheckIfAllPixelsAreTransparent){let l=!0,r=a.width,d=t.pixelsToCheck;for(let m=0,h=d.length;l&&m<h;++m){let u=d[m],R=u.x*4+u.y*r;s[R+3]>0&&(l=!1)}l&&(s=void 0)}n._missingImagePixels=s,n._isReady=!0}function o(){n._missingImagePixels=void 0,n._isReady=!0}e.fetchImage({preferBlob:!0,preferImageBitmap:!0,flipY:!0}).then(i).catch(o)}Eot.prototype.isReady=function(){return this._isReady};Eot.prototype.shouldDiscardImage=function(t){let e=this._pixelsToCheck,n=this._missingImagePixels;if(!c(n)||c(t.blob)&&t.blob.size!==this._missingImageByteLength)return!1;let i=vV(t),o=t.width;for(let a=0,s=e.length;a<s;++a){let l=e[a],r=l.x*4+l.y*o;for(let d=0;d<4;++d){let m=r+d;if(i[m]!==n[m])return!1}}return!0};var XM=Eot;var sRo=b(W(),1);function Cot(){this.name=void 0,this.description=void 0,this.position=void 0,this.data=void 0,this.imageryLayer=void 0}Cot.prototype.configureNameFromProperties=function(t){let e=10,n;for(let i in t)if(t.hasOwnProperty(i)&&t[i]){let o=i.toLowerCase();e>1&&o==="name"?(e=1,n=i):e>2&&o==="title"?(e=2,n=i):e>3&&/name/i.test(i)?(e=3,n=i):e>4&&/title/i.test(i)&&(e=4,n=i)}c(n)&&(this.name=t[n])};Cot.prototype.configureDescriptionFromProperties=function(t){function e(n){let i='<table class="cesium-infoBox-defaultTable">';for(let o in n)if(n.hasOwnProperty(o)){let a=n[o];c(a)&&(typeof a=="object"?i+=`<tr><td>${o}</td><td>${e(a)}</td></tr>`:i+=`<tr><td>${o}</td><td>${a}</td></tr>`)}return i+="</table>",i}this.description=e(t)};var iZ=Cot;var hRo=b(W(),1);function F1(){Ut.throwInstantiationError()}Object.defineProperties(F1.prototype,{rectangle:{get:Ut.throwInstantiationError},tileWidth:{get:Ut.throwInstantiationError},tileHeight:{get:Ut.throwInstantiationError},maximumLevel:{get:Ut.throwInstantiationError},minimumLevel:{get:Ut.throwInstantiationError},tilingScheme:{get:Ut.throwInstantiationError},tileDiscardPolicy:{get:Ut.throwInstantiationError},errorEvent:{get:Ut.throwInstantiationError},credit:{get:Ut.throwInstantiationError},proxy:{get:Ut.throwInstantiationError},hasAlphaChannel:{get:Ut.throwInstantiationError}});F1.prototype.getTileCredits=function(t,e,n){Ut.throwInstantiationError()};F1.prototype.requestImage=function(t,e,n,i){Ut.throwInstantiationError()};F1.prototype.pickFeatures=function(t,e,n,i,o){Ut.throwInstantiationError()};var Wge=/\.ktx2$/i;F1.loadImage=function(t,e){let n=te.createIfNeeded(e);return Wge.test(n.url)?Fm(n):c(t)&&c(t.tileDiscardPolicy)?n.fetchImage({preferBlob:!0,preferImageBitmap:!0,flipY:!0}):n.fetchImage({preferImageBitmap:!0,flipY:!0})};var $c=F1;var VRo=b(W(),1),fge={SATELLITE:1,OCEANS:2,HILLSHADE:3},oZ=Object.freeze(fge);function Z1t(t){this.useTiles=f(t.usePreCachedTilesIfAvailable,!0);let e=t.ellipsoid;this.tilingScheme=f(t.tilingScheme,new Qo({ellipsoid:e})),this.rectangle=f(t.rectangle,this.tilingScheme.rectangle),this.ellipsoid=e;let n=t.credit;typeof n=="string"&&(n=new on(n)),this.credit=n,this.tileCredits=void 0,this.tileDiscardPolicy=t.tileDiscardPolicy,this.tileWidth=f(t.tileWidth,256),this.tileHeight=f(t.tileHeight,256),this.maximumLevel=t.maximumLevel}Z1t.prototype.build=function(t){t._useTiles=this.useTiles,t._tilingScheme=this.tilingScheme,t._rectangle=this.rectangle,t._credit=this.credit,t._tileCredits=this.tileCredits,t._tileDiscardPolicy=this.tileDiscardPolicy,t._tileWidth=this.tileWidth,t._tileHeight=this.tileHeight,t._maximumLevel=this.maximumLevel,this.useTiles&&!c(this.tileDiscardPolicy)&&(t._tileDiscardPolicy=new XM({missingImageUrl:R1t(t,0,0,this.maximumLevel).url,pixelsToCheck:[new K(0,0),new K(200,20),new K(20,200),new K(80,110),new K(160,130)],disableCheckIfAllPixelsAreTransparent:!0}))};function Fge(t,e){let n=t.tileInfo;if(!c(n))e.useTiles=!1;else{if(e.tileWidth=n.rows,e.tileHeight=n.cols,n.spatialReference.wkid===102100||n.spatialReference.wkid===102113)e.tilingScheme=new Gs({ellipsoid:e.ellipsoid});else if(t.tileInfo.spatialReference.wkid===4326)e.tilingScheme=new Qo({ellipsoid:e.ellipsoid});else{let i=`Tile spatial reference WKID ${t.tileInfo.spatialReference.wkid} is not supported.`;throw new Tt(i)}if(e.maximumLevel=t.tileInfo.lods.length-1,c(t.fullExtent)){if(c(t.fullExtent.spatialReference)&&c(t.fullExtent.spatialReference.wkid))if(t.fullExtent.spatialReference.wkid===102100||t.fullExtent.spatialReference.wkid===102113){let i=new Yo,o=t.fullExtent,a=i.unproject(new p(Math.max(o.xmin,-e.tilingScheme.ellipsoid.maximumRadius*Math.PI),Math.max(o.ymin,-e.tilingScheme.ellipsoid.maximumRadius*Math.PI),0)),s=i.unproject(new p(Math.min(o.xmax,e.tilingScheme.ellipsoid.maximumRadius*Math.PI),Math.min(o.ymax,e.tilingScheme.ellipsoid.maximumRadius*Math.PI),0));e.rectangle=new Gt(a.longitude,a.latitude,s.longitude,s.latitude)}else if(t.fullExtent.spatialReference.wkid===4326)e.rectangle=Gt.fromDegrees(t.fullExtent.xmin,t.fullExtent.ymin,t.fullExtent.xmax,t.fullExtent.ymax);else{let i=`fullExtent.spatialReference WKID ${t.fullExtent.spatialReference.wkid} is not supported.`;throw new Tt(i)}}else e.rectangle=e.tilingScheme.rectangle;e.useTiles=!0}c(t.copyrightText)&&t.copyrightText.length>0&&(c(e.credit)?e.tileCredits=[new on(t.copyrightText)]:e.credit=new on(t.copyrightText))}function Uge(t,e){let n=`An error occurred while accessing ${t.url}`;throw c(e)&&c(e.message)&&(n+=`: ${e.message}`),new Tt(n)}async function Gge(t,e){let n=t.getDerivedResource({queryParameters:{f:"json"}});try{let i=await n.fetchJson();Fge(i,e)}catch(i){Uge(t,i)}}function YR(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._tileDiscardPolicy=t.tileDiscardPolicy,this._tileWidth=f(t.tileWidth,256),this._tileHeight=f(t.tileHeight,256),this._maximumLevel=t.maximumLevel,this._tilingScheme=f(t.tilingScheme,new Qo({ellipsoid:t.ellipsoid})),this._useTiles=f(t.usePreCachedTilesIfAvailable,!0),this._rectangle=f(t.rectangle,this._tilingScheme.rectangle),this._layers=t.layers,this._credit=t.credit,this._tileCredits=void 0;let e=t.credit;typeof e=="string"&&(e=new on(e)),this.enablePickFeatures=f(t.enablePickFeatures,!0),this._errorEvent=new It}YR.fromBasemapType=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n,i,o;switch(t){case oZ.SATELLITE:{n=f(e.token,tp.defaultAccessToken),i=te.createIfNeeded(tp.defaultWorldImageryServer),i.appendForwardSlash();let a=tp.getDefaultTokenCredit(n);c(a)&&(o=on.clone(a))}break;case oZ.OCEANS:{n=f(e.token,tp.defaultAccessToken),i=te.createIfNeeded(tp.defaultWorldOceanServer),i.appendForwardSlash();let a=tp.getDefaultTokenCredit(n);c(a)&&(o=on.clone(a))}break;case oZ.HILLSHADE:{n=f(e.token,tp.defaultAccessToken),i=te.createIfNeeded(tp.defaultWorldHillshadeServer),i.appendForwardSlash();let a=tp.getDefaultTokenCredit(n);c(a)&&(o=on.clone(a))}break;default:}return YR.fromUrl(i,{...e,token:n,credit:o,usePreCachedTilesIfAvailable:!0})};function R1t(t,e,n,i,o){let a;if(t._useTiles)a=t._resource.getDerivedResource({url:`tile/${i}/${n}/${e}`,request:o});else{let s=t._tilingScheme.tileXYToNativeRectangle(e,n,i),r={bbox:`${s.west},${s.south},${s.east},${s.north}`,size:`${t._tileWidth},${t._tileHeight}`,format:"png32",transparent:!0,f:"image"};t._tilingScheme.projection instanceof yo?(r.bboxSR=4326,r.imageSR=4326):(r.bboxSR=3857,r.imageSR=3857),t.layers&&(r.layers=`show:${t.layers}`),a=t._resource.getDerivedResource({url:"export",request:o,queryParameters:r})}return a}Object.defineProperties(YR.prototype,{url:{get:function(){return this._resource._url}},token:{get:function(){return this._resource.queryParameters.token}},proxy:{get:function(){return this._resource.proxy}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return 0}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},usingPrecachedTiles:{get:function(){return this._useTiles}},hasAlphaChannel:{get:function(){return!0}},layers:{get:function(){return this._layers}}});YR.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=te.createIfNeeded(t);n.appendForwardSlash(),c(e.token)&&n.setQueryParameters({token:e.token});let i=new YR(e);i._resource=n;let o=new Z1t(e);return f(e.usePreCachedTilesIfAvailable,!0)&&await Gge(n,o),o.build(i),i};YR.prototype.getTileCredits=function(t,e,n){return this._tileCredits};YR.prototype.requestImage=function(t,e,n,i){return $c.loadImage(this,R1t(this,t,e,n,i))};YR.prototype.pickFeatures=function(t,e,n,i,o){if(!this.enablePickFeatures)return;let a=this._tilingScheme.tileXYToNativeRectangle(t,e,n),s,l,r;if(this._tilingScheme.projection instanceof yo)s=k.toDegrees(i),l=k.toDegrees(o),r="4326";else{let u=this._tilingScheme.projection.project(new gt(i,o,0));s=u.x,l=u.y,r="3857"}let d="visible";c(this._layers)&&(d+=`:${this._layers}`);let m={f:"json",tolerance:2,geometryType:"esriGeometryPoint",geometry:`${s},${l}`,mapExtent:`${a.west},${a.south},${a.east},${a.north}`,imageDisplay:`${this._tileWidth},${this._tileHeight},96`,sr:r,layers:d};return this._resource.getDerivedResource({url:"identify",queryParameters:m}).fetchJson().then(function(u){let R=[],V=u.results;if(!c(V))return R;for(let F=0;F<V.length;++F){let U=V[F],G=new iZ;if(G.data=U,G.name=U.value,G.properties=U.attributes,G.configureDescriptionFromProperties(U.attributes),U.geometryType==="esriGeometryPoint"&&U.geometry){let A=U.geometry.spatialReference&&U.geometry.spatialReference.wkid?U.geometry.spatialReference.wkid:4326;if(A===4326||A===4283)G.position=gt.fromDegrees(U.geometry.x,U.geometry.y,U.geometry.z);else if(A===102100||A===900913||A===3857){let S=new Yo;G.position=S.unproject(new p(U.geometry.x,U.geometry.y,U.geometry.z))}}R.push(G)}return R})};YR._metadataCache={};var cW=YR;var ibo=b(W(),1);var XRo=b(W(),1),Age={AERIAL:"Aerial",AERIAL_WITH_LABELS:"AerialWithLabels",AERIAL_WITH_LABELS_ON_DEMAND:"AerialWithLabelsOnDemand",ROAD:"Road",ROAD_ON_DEMAND:"RoadOnDemand",CANVAS_DARK:"CanvasDark",CANVAS_LIGHT:"CanvasLight",CANVAS_GRAY:"CanvasGray",ORDNANCE_SURVEY:"OrdnanceSurvey",COLLINS_BART:"CollinsBart"},U1=Object.freeze(Age);var MRo=b(W(),1);function JM(t){}JM.prototype.isReady=function(){return!0};JM.prototype.shouldDiscardImage=function(t){return JM.EMPTY_IMAGE===t};var Zz;Object.defineProperties(JM,{EMPTY_IMAGE:{get:function(){return c(Zz)||(Zz=new Image,Zz.src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII="),Zz}}});var G1=JM;function b1t(t){this.tileWidth=void 0,this.tileHeight=void 0,this.maximumLevel=void 0,this.imageUrlSubdomains=void 0,this.imageUrlTemplate=void 0,this.attributionList=void 0}b1t.prototype.build=function(t){t._tileWidth=this.tileWidth,t._tileHeight=this.tileHeight,t._maximumLevel=this.maximumLevel,t._imageUrlSubdomains=this.imageUrlSubdomains,t._imageUrlTemplate=this.imageUrlTemplate;let e=t._attributionList=this.attributionList;e||(e=[]),t._attributionList=e;for(let n=0,i=e.length;n<i;++n){let o=e[n];if(o.credit instanceof on)break;o.credit=new on(o.attribution);let a=o.coverageAreas;for(let s=0,l=o.coverageAreas.length;s<l;++s){let r=a[s],d=r.bbox;r.bbox=new Gt(k.toRadians(d[1]),k.toRadians(d[0]),k.toRadians(d[3]),k.toRadians(d[2]))}}};function Sge(t,e){if(t.resourceSets.length!==1)throw new Tt("metadata does not specify one resource in resourceSets");let n=t.resourceSets[0].resources[0];e.tileWidth=n.imageWidth,e.tileHeight=n.imageHeight,e.maximumLevel=n.zoomMax-1,e.imageUrlSubdomains=n.imageUrlSubdomains,e.imageUrlTemplate=n.imageUrl,e.attributionList=n.imageryProviders}function Tge(t,e,n){let i=`An error occurred while accessing ${t.url}`;throw c(e)&&c(e.message)&&(i+=`: ${e.message}`),za.reportError(void 0,n,c(n)?n._errorEvent:void 0,i,void 0,void 0,void 0,e),new Tt(i)}async function gge(t,e,n){let i=t.url,o=lr._metadataCache[i];c(o)||(o=t.fetchJsonp("jsonp"),lr._metadataCache[i]=o);try{let a=await o;return Sge(a,e)}catch(a){Tge(t,a,n)}}function lr(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=1,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._mapStyle=f(t.mapStyle,U1.AERIAL),this._mapLayer=t.mapLayer,this._culture=f(t.culture,""),this._key=t.key,this._tileDiscardPolicy=t.tileDiscardPolicy,c(this._tileDiscardPolicy)||(this._tileDiscardPolicy=new G1),this._proxy=t.proxy,this._credit=new on(`<a href="https://www.microsoft.com/en-us/maps/product/enduserterms"><img src="${lr.logoUrl}" title="Bing Imagery"/></a>`),this._tilingScheme=new Gs({numberOfLevelZeroTilesX:2,numberOfLevelZeroTilesY:2,ellipsoid:t.ellipsoid}),this._tileWidth=void 0,this._tileHeight=void 0,this._maximumLevel=void 0,this._imageUrlTemplate=void 0,this._imageUrlSubdomains=void 0,this._attributionList=void 0,this._errorEvent=new It}Object.defineProperties(lr.prototype,{url:{get:function(){return this._resource.url}},proxy:{get:function(){return this._resource.proxy}},key:{get:function(){return this._key}},mapStyle:{get:function(){return this._mapStyle}},mapLayer:{get:function(){return this._mapLayer}},culture:{get:function(){return this._culture}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return 0}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return c(this.mapLayer)}}});lr.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=e.tileProtocol;c(n)?n.length>0&&n[n.length-1]===":"&&(n=n.substr(0,n.length-1)):n=document.location.protocol==="http:"?"http":"https";let i=f(e.mapStyle,U1.AERIAL),o=te.createIfNeeded(t);o.appendForwardSlash();let a={incl:"ImageryProviders",key:e.key,uriScheme:n};c(e.mapLayer)&&(a.mapLayer=e.mapLayer),c(e.culture)&&(a.culture=e.culture);let s=o.getDerivedResource({url:`REST/v1/Imagery/Metadata/${i}`,queryParameters:a}),l=new lr(e);l._resource=o;let r=new b1t(e);return await gge(s,r),r.build(l),l};var Ege=new Gt;lr.prototype.getTileCredits=function(t,e,n){let i=this._tilingScheme.tileXYToRectangle(t,e,n,Ege);return Nge(this._attributionList,n,i)};lr.prototype.requestImage=function(t,e,n,i){let o=$c.loadImage(this,Cge(this,t,e,n,i));if(c(o))return o.catch(function(a){return c(a.blob)&&a.blob.size===0?G1.EMPTY_IMAGE:Promise.reject(a)})};lr.prototype.pickFeatures=function(t,e,n,i,o){};lr.tileXYToQuadKey=function(t,e,n){let i="";for(let o=n;o>=0;--o){let a=1<<o,s=0;t&a&&(s|=1),e&a&&(s|=2),i+=s}return i};lr.quadKeyToTileXY=function(t){let e=0,n=0,i=t.length-1;for(let o=i;o>=0;--o){let a=1<<o,s=+t[i-o];s&1&&(e|=a),s&2&&(n|=a)}return{x:e,y:n,level:i}};lr._logoUrl=void 0;Object.defineProperties(lr,{logoUrl:{get:function(){return c(lr._logoUrl)||(lr._logoUrl=Dn("Assets/Images/bing_maps_credit.png")),lr._logoUrl},set:function(t){lr._logoUrl=t}}});function Cge(t,e,n,i,o){let a=t._imageUrlTemplate,s=t._imageUrlSubdomains,l=(e+n+i)%s.length;return t._resource.getDerivedResource({url:a,request:o,templateValues:{quadkey:lr.tileXYToQuadKey(e,n,i),subdomain:s[l],culture:t._culture},queryParameters:{n:"z"}})}var Ige=new Gt;function Nge(t,e,n){++e;let i=[];for(let o=0,a=t.length;o<a;++o){let s=t[o],l=s.coverageAreas,r=!1;for(let d=0,m=s.coverageAreas.length;!r&&d<m;++d){let h=l[d];if(e>=h.zoomMin&&e<=h.zoomMax){let u=Gt.intersection(n,h.bbox,Ige);c(u)&&(r=!0)}}r&&i.push(s.credit)}return i}lr._metadataCache={};var LM=lr;var Qbo=b(W(),1);var Wbo=b(W(),1);var W1t=/{[^}]+}/g,f1t={x:kge,y:xge,z:Lge,s:Mge,reverseX:Yge,reverseY:Xge,reverseZ:Jge,westDegrees:_ge,southDegrees:Dge,eastDegrees:Oge,northDegrees:Hge,westProjected:wge,southProjected:Pge,eastProjected:vge,northProjected:Kge,width:zge,height:jge},yge=ze(f1t,{i:qge,j:$ge,reverseI:tEe,reverseJ:eEe,longitudeDegrees:iEe,latitudeDegrees:oEe,longitudeProjected:aEe,latitudeProjected:sEe,format:rEe});function MM(t){t=f(t,f.EMPTY_OBJECT),this._errorEvent=new It;let e=te.createIfNeeded(t.url),n=te.createIfNeeded(t.pickFeaturesUrl);this._resource=e,this._urlSchemeZeroPadding=t.urlSchemeZeroPadding,this._getFeatureInfoFormats=t.getFeatureInfoFormats,this._pickFeaturesResource=n;let i=t.subdomains;Array.isArray(i)?i=i.slice():c(i)&&i.length>0?i=i.split(""):i=["a","b","c"],this._subdomains=i,this._tileWidth=f(t.tileWidth,256),this._tileHeight=f(t.tileHeight,256),this._minimumLevel=f(t.minimumLevel,0),this._maximumLevel=t.maximumLevel,this._tilingScheme=f(t.tilingScheme,new Gs({ellipsoid:t.ellipsoid})),this._rectangle=f(t.rectangle,this._tilingScheme.rectangle),this._rectangle=Gt.intersection(this._rectangle,this._tilingScheme.rectangle),this._tileDiscardPolicy=t.tileDiscardPolicy;let o=t.credit;typeof o=="string"&&(o=new on(o)),this._credit=o,this._hasAlphaChannel=f(t.hasAlphaChannel,!0);let a=t.customTags,s=ze(f1t,a),l=ze(yge,a);this._tags=s,this._pickFeaturesTags=l,this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this.enablePickFeatures=f(t.enablePickFeatures,!0)}Object.defineProperties(MM.prototype,{url:{get:function(){return this._resource.url}},urlSchemeZeroPadding:{get:function(){return this._urlSchemeZeroPadding}},pickFeaturesUrl:{get:function(){return this._pickFeaturesResource.url}},proxy:{get:function(){return this._resource.proxy}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return this._minimumLevel}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return this._hasAlphaChannel}}});MM.prototype.getTileCredits=function(t,e,n){};MM.prototype.requestImage=function(t,e,n,i){return $c.loadImage(this,Bge(this,t,e,n,i))};MM.prototype.pickFeatures=function(t,e,n,i,o){if(!this.enablePickFeatures||!c(this._pickFeaturesResource)||this._getFeatureInfoFormats.length===0)return;let a=0,s=this;function l(d,m){return d.callback(m)}function r(){if(a>=s._getFeatureInfoFormats.length)return Promise.resolve([]);let d=s._getFeatureInfoFormats[a],m=Qge(s,t,e,n,i,o,d.format);return++a,d.type==="json"?m.fetchJson().then(d.callback).catch(r):d.type==="xml"?m.fetchXML().then(d.callback).catch(r):d.type==="text"||d.type==="html"?m.fetchText().then(d.callback).catch(r):m.fetch({responseType:d.format}).then(l.bind(void 0,d)).catch(r)}return r()};var Rz=!1,ep=new Gt,bz=!1,_M=new Gt;function Bge(t,e,n,i,o){Rz=!1,bz=!1;let a=t._resource,s=a.getUrlComponent(!0),l=t._tags,r={},d=s.match(W1t);return c(d)&&d.forEach(function(m){let h=m.substring(1,m.length-1);c(l[h])&&(r[h]=l[h](t,e,n,i))}),a.getDerivedResource({request:o,templateValues:r})}var Iot=!1,S1=new K,Not=!1;function Qge(t,e,n,i,o,a,s){Rz=!1,bz=!1,Iot=!1,Not=!1;let l=t._pickFeaturesResource,r=l.getUrlComponent(!0),d=t._pickFeaturesTags,m={},h=r.match(W1t);return c(h)&&h.forEach(function(u){let R=u.substring(1,u.length-1);c(d[R])&&(m[R]=d[R](t,e,n,i,o,a,s))}),l.getDerivedResource({templateValues:m})}function T1(t,e,n){if(t&&t.urlSchemeZeroPadding&&t.urlSchemeZeroPadding.hasOwnProperty(e)){let i=t.urlSchemeZeroPadding[e];if(typeof i=="string"){let o=i.length;o>1&&(n=n.length>=o?n:new Array(o-n.toString().length+1).join("0")+n)}}return n}function kge(t,e,n,i){return T1(t,"{x}",e)}function Yge(t,e,n,i){let o=t.tilingScheme.getNumberOfXTilesAtLevel(i)-e-1;return T1(t,"{reverseX}",o)}function xge(t,e,n,i){return T1(t,"{y}",n)}function Xge(t,e,n,i){let o=t.tilingScheme.getNumberOfYTilesAtLevel(i)-n-1;return T1(t,"{reverseY}",o)}function Jge(t,e,n,i){let o=t.maximumLevel,a=c(o)&&i<o?o-i-1:i;return T1(t,"{reverseZ}",a)}function Lge(t,e,n,i){return T1(t,"{z}",i)}function Mge(t,e,n,i){let o=(e+n+i)%t._subdomains.length;return t._subdomains[o]}function Wz(t,e,n,i){Rz||(t.tilingScheme.tileXYToRectangle(e,n,i,ep),ep.west=k.toDegrees(ep.west),ep.south=k.toDegrees(ep.south),ep.east=k.toDegrees(ep.east),ep.north=k.toDegrees(ep.north),Rz=!0)}function _ge(t,e,n,i){return Wz(t,e,n,i),ep.west}function Dge(t,e,n,i){return Wz(t,e,n,i),ep.south}function Oge(t,e,n,i){return Wz(t,e,n,i),ep.east}function Hge(t,e,n,i){return Wz(t,e,n,i),ep.north}function fz(t,e,n,i){bz||(t.tilingScheme.tileXYToNativeRectangle(e,n,i,_M),bz=!0)}function wge(t,e,n,i){return fz(t,e,n,i),_M.west}function Pge(t,e,n,i){return fz(t,e,n,i),_M.south}function vge(t,e,n,i){return fz(t,e,n,i),_M.east}function Kge(t,e,n,i){return fz(t,e,n,i),_M.north}function zge(t,e,n,i){return t.tileWidth}function jge(t,e,n,i){return t.tileHeight}function qge(t,e,n,i,o,a,s){return Fz(t,e,n,i,o,a),S1.x}function $ge(t,e,n,i,o,a,s){return Fz(t,e,n,i,o,a),S1.y}function tEe(t,e,n,i,o,a,s){return Fz(t,e,n,i,o,a),t.tileWidth-S1.x-1}function eEe(t,e,n,i,o,a,s){return Fz(t,e,n,i,o,a),t.tileHeight-S1.y-1}var nEe=new Gt,A1=new p;function Fz(t,e,n,i,o,a,s){if(Iot)return;yot(t,e,n,i,o,a);let l=A1,r=t.tilingScheme.tileXYToNativeRectangle(e,n,i,nEe);S1.x=t.tileWidth*(l.x-r.west)/r.width|0,S1.y=t.tileHeight*(r.north-l.y)/r.height|0,Iot=!0}function iEe(t,e,n,i,o,a,s){return k.toDegrees(o)}function oEe(t,e,n,i,o,a,s){return k.toDegrees(a)}function aEe(t,e,n,i,o,a,s){return yot(t,e,n,i,o,a),A1.x}function sEe(t,e,n,i,o,a,s){return yot(t,e,n,i,o,a),A1.y}var lEe=new gt;function yot(t,e,n,i,o,a,s){if(!Not){if(t.tilingScheme.projection instanceof yo)A1.x=k.toDegrees(o),A1.y=k.toDegrees(a);else{let l=lEe;l.longitude=o,l.latitude=a,t.tilingScheme.projection.project(l,A1)}Not=!0}}function rEe(t,e,n,i,o,a,s){return s}var Ad=MM;function TV(t){Ad.call(this,t)}TV._requestMetadata=async function(t,e,n,i){try{let o=await n.fetchXML();return TV._metadataSuccess(o,t,e,n,i)}catch(o){if(o instanceof yZ)return TV._metadataFailure(t,e);throw o}};TV.fromUrl=async function(t,e){let n=te.createIfNeeded(t);n.appendForwardSlash();let i=n,o=n.getDerivedResource({url:"tilemapresource.xml"});e=f(e,f.EMPTY_OBJECT);let a=await TV._requestMetadata(e,i,o);return new TV(a)};c(Object.create)&&(TV.prototype=Object.create(Ad.prototype),TV.prototype.constructor=TV);function F1t(t,e){return t.west<e.rectangle.west&&(t.west=e.rectangle.west),t.east>e.rectangle.east&&(t.east=e.rectangle.east),t.south<e.rectangle.south&&(t.south=e.rectangle.south),t.north>e.rectangle.north&&(t.north=e.rectangle.north),t}function U1t(t,e,n){let i=t.positionToTileXY(Gt.southwest(e),n),o=t.positionToTileXY(Gt.northeast(e),n);return(Math.abs(o.x-i.x)+1)*(Math.abs(o.y-i.y)+1)>4?0:n}TV._metadataSuccess=function(t,e,n,i,o){let a=/tileformat/i,s=/tileset/i,l=/tilesets/i,r=/boundingbox/i,d,m,h,u=[],R=t.childNodes[0].childNodes;for(let Q=0;Q<R.length;Q++)if(a.test(R.item(Q).nodeName))d=R.item(Q);else if(l.test(R.item(Q).nodeName)){h=R.item(Q);let J=R.item(Q).childNodes;for(let M=0;M<J.length;M++)s.test(J.item(M).nodeName)&&u.push(J.item(M))}else r.test(R.item(Q).nodeName)&&(m=R.item(Q));let V;if(!c(h)||!c(m))throw V=`Unable to find expected tilesets or bbox attributes in ${i.url}.`,c(o)&&za.reportError(void 0,o,o.errorEvent,V),new Tt(V);let F=f(e.fileExtension,d.getAttribute("extension")),U=f(e.tileWidth,parseInt(d.getAttribute("width"),10)),G=f(e.tileHeight,parseInt(d.getAttribute("height"),10)),A=f(e.minimumLevel,parseInt(u[0].getAttribute("order"),10)),S=f(e.maximumLevel,parseInt(u[u.length-1].getAttribute("order"),10)),g=h.getAttribute("profile"),C=e.tilingScheme;if(!c(C))if(g==="geodetic"||g==="global-geodetic")C=new Qo({ellipsoid:e.ellipsoid});else if(g==="mercator"||g==="global-mercator")C=new Gs({ellipsoid:e.ellipsoid});else throw V=`${i.url} specifies an unsupported profile attribute, ${g}.`,c(o)&&za.reportError(void 0,o,o.errorEvent,V),new Tt(V);let y=Gt.clone(e.rectangle);if(!c(y)){let Q,J,M,Z;f(e.flipXY,!1)?(M=new K(parseFloat(m.getAttribute("miny")),parseFloat(m.getAttribute("minx"))),Z=new K(parseFloat(m.getAttribute("maxy")),parseFloat(m.getAttribute("maxx")))):(M=new K(parseFloat(m.getAttribute("minx")),parseFloat(m.getAttribute("miny"))),Z=new K(parseFloat(m.getAttribute("maxx")),parseFloat(m.getAttribute("maxy"))));let I=g==="geodetic"||g==="mercator";if(C.projection instanceof yo||I)Q=gt.fromDegrees(M.x,M.y),J=gt.fromDegrees(Z.x,Z.y);else{let B=C.projection;Q=B.unproject(M),J=B.unproject(Z)}y=new Gt(Q.longitude,Q.latitude,J.longitude,J.latitude)}return y=F1t(y,C),A=U1t(C,y,A),{url:n.getDerivedResource({url:`{z}/{x}/{reverseY}.${F}`}),tilingScheme:C,rectangle:y,tileWidth:U,tileHeight:G,minimumLevel:A,maximumLevel:S,tileDiscardPolicy:e.tileDiscardPolicy,credit:e.credit}};TV._metadataFailure=function(t,e){let n=f(t.fileExtension,"png"),i=f(t.tileWidth,256),o=f(t.tileHeight,256),a=t.maximumLevel,s=c(t.tilingScheme)?t.tilingScheme:new Gs({ellipsoid:t.ellipsoid}),l=f(t.rectangle,s.rectangle);l=F1t(l,s);let r=U1t(s,l,t.minimumLevel);return{url:e.getDerivedResource({url:`{z}/{x}/{reverseY}.${n}`}),tilingScheme:s,rectangle:l,tileWidth:i,tileHeight:o,minimumLevel:r,maximumLevel:a,tileDiscardPolicy:t.tileDiscardPolicy,credit:t.credit}};var hU=TV;var vbo=b(W(),1);function G1t(t){this.channel=t.channel,this.ellipsoid=t.ellipsoid,this.tilingScheme=void 0,this.version=void 0}G1t.prototype.build=function(t){t._channel=this.channel,t._version=this.version,t._tilingScheme=this.tilingScheme};function dEe(t,e){let n;try{n=JSON.parse(t)}catch{n=JSON.parse(t.replace(/([\[\{,])[\n\r ]*([A-Za-z0-9]+)[\n\r ]*:/g,'$1"$2":'))}let i;for(let o=0;o<n.layers.length;o++)if(n.layers[o].id===e.channel){i=n.layers[o];break}if(!c(i)){let o=`Could not find layer with channel (id) of ${e.channel}.`;throw new Tt(o)}if(!c(i.version)){let o=`Could not find a version in channel (id) ${e.channel}.`;throw new Tt(o)}if(e.version=i.version,c(n.projection)&&n.projection==="flat")e.tilingScheme=new Qo({numberOfLevelZeroTilesX:2,numberOfLevelZeroTilesY:2,rectangle:new Gt(-Math.PI,-Math.PI,Math.PI,Math.PI),ellipsoid:e.ellipsoid});else if(!c(n.projection)||n.projection==="mercator")e.tilingScheme=new Gs({numberOfLevelZeroTilesX:2,numberOfLevelZeroTilesY:2,ellipsoid:e.ellipsoid});else{let o=`Unsupported projection ${n.projection}.`;throw new Tt(o)}return!0}function cEe(t,e,n){let i=`An error occurred while accessing ${e.url}.`;throw c(t)&&c(t.message)&&(i+=`: ${t.message}`),za.reportError(void 0,n,c(n)?n._errorEvent:void 0,i),new Tt(i)}async function mEe(t,e,n){try{let i=await t.fetchText();dEe(i,e)}catch(i){cEe(i,t,n)}}function $m(t){t=f(t,{}),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=1.9,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._tileDiscardPolicy=t.tileDiscardPolicy,this._channel=t.channel,this._requestType="ImageryMaps",this._credit=new on(`<a href="http://www.google.com/enterprise/mapsearth/products/earthenterprise.html"><img src="${$m.logoUrl}" title="Google Imagery"/></a>`),this._tilingScheme=void 0,this._version=void 0,this._tileWidth=256,this._tileHeight=256,this._maximumLevel=t.maximumLevel,this._errorEvent=new It}Object.defineProperties($m.prototype,{url:{get:function(){return this._url}},path:{get:function(){return this._path}},proxy:{get:function(){return this._resource.proxy}},channel:{get:function(){return this._channel}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return 0}},tilingScheme:{get:function(){return this._tilingScheme}},version:{get:function(){return this._version}},requestType:{get:function(){return this._requestType}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return!0}}});$m.fromUrl=async function(t,e,n){n=f(n,{});let i=f(n.path,"/default_map"),o=te.createIfNeeded(t).getDerivedResource({url:i[0]==="/"?i.substring(1):i});o.appendForwardSlash();let a=o.getDerivedResource({url:"query",queryParameters:{request:"Json",vars:"geeServerDefs",is2d:"t"}}),s=new G1t(n);s.channel=e,await mEe(a,s);let l=new $m(n);return s.build(l),l._resource=o,l._url=t,l._path=i,l};$m.prototype.getTileCredits=function(t,e,n){};$m.prototype.requestImage=function(t,e,n,i){let o=this._resource.getDerivedResource({url:"query",request:i,queryParameters:{request:this._requestType,channel:this._channel,version:this._version,x:t,y:e,z:n+1}});return $c.loadImage(this,o)};$m.prototype.pickFeatures=function(t,e,n,i,o){};$m._logoUrl=void 0;Object.defineProperties($m,{logoUrl:{get:function(){return c($m._logoUrl)||($m._logoUrl=Dn("Assets/Images/google_earth_credit.png")),$m._logoUrl},set:function(t){$m._logoUrl=t}}});var DM=$m;var e0o=b(W(),1);var hEe=/\/$/,A1t=new on('© <a href="https://www.mapbox.com/about/maps/">Mapbox</a> © <a href="http://www.openstreetmap.org/copyright">OpenStreetMap</a> <strong><a href="https://www.mapbox.com/map-feedback/">Improve this map</a></strong>');function g1(t){t=f(t,f.EMPTY_OBJECT);let e=t.mapId,n=t.accessToken;this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0;let i=te.createIfNeeded(f(t.url,"https://{s}.tiles.mapbox.com/v4/"));this._mapId=e,this._accessToken=n;let o=f(t.format,"png");/\./.test(o)||(o=`.${o}`),this._format=o;let a=i.getUrlComponent();hEe.test(a)||(a+="/"),a+=`${e}/{z}/{x}/{y}${this._format}`,i.url=a,i.setQueryParameters({access_token:n});let s;c(t.credit)?(s=t.credit,typeof s=="string"&&(s=new on(s))):s=A1t,this._resource=i,this._imageryProvider=new Ad({url:i,credit:s,ellipsoid:t.ellipsoid,minimumLevel:t.minimumLevel,maximumLevel:t.maximumLevel,rectangle:t.rectangle})}Object.defineProperties(g1.prototype,{url:{get:function(){return this._imageryProvider.url}},rectangle:{get:function(){return this._imageryProvider.rectangle}},tileWidth:{get:function(){return this._imageryProvider.tileWidth}},tileHeight:{get:function(){return this._imageryProvider.tileHeight}},maximumLevel:{get:function(){return this._imageryProvider.maximumLevel}},minimumLevel:{get:function(){return this._imageryProvider.minimumLevel}},tilingScheme:{get:function(){return this._imageryProvider.tilingScheme}},tileDiscardPolicy:{get:function(){return this._imageryProvider.tileDiscardPolicy}},errorEvent:{get:function(){return this._imageryProvider.errorEvent}},credit:{get:function(){return this._imageryProvider.credit}},proxy:{get:function(){return this._imageryProvider.proxy}},hasAlphaChannel:{get:function(){return this._imageryProvider.hasAlphaChannel}}});g1.prototype.getTileCredits=function(t,e,n){};g1.prototype.requestImage=function(t,e,n,i){return this._imageryProvider.requestImage(t,e,n,i)};g1.prototype.pickFeatures=function(t,e,n,i,o){return this._imageryProvider.pickFeatures(t,e,n,i,o)};g1._defaultCredit=A1t;var OM=g1;var p0o=b(W(),1);function dT(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0;let e=f(t.rectangle,Gt.MAX_VALUE),n=new Qo({rectangle:e,numberOfLevelZeroTilesX:1,numberOfLevelZeroTilesY:1,ellipsoid:t.ellipsoid});this._tilingScheme=n,this._image=void 0,this._texture=void 0,this._hasError=!1,this._errorEvent=new It;let i=t.credit;typeof i=="string"&&(i=new on(i)),this._credit=i;let o=te.createIfNeeded(t.url);this._resource=o,this._tileWidth=t.tileWidth,this._tileHeight=t.tileHeight}Object.defineProperties(dT.prototype,{url:{get:function(){return this._resource.url}},proxy:{get:function(){return this._resource.proxy}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return 0}},minimumLevel:{get:function(){return 0}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return!0}}});function pEe(t,e,n,i){let o=`Failed to load image ${t.url}`;c(e)&&c(e.message)&&(o+=`: ${e.message}`);let a=za.reportError(i,n,c(n)?n._errorEvent:void 0,o,0,0,0,e);if(a.retry)return Bot(t,n,a);throw c(n)&&(n._hasError=!0),new Tt(o)}async function Bot(t,e,n){try{return await $c.loadImage(null,t)}catch(i){return pEe(t,i,e,n)}}dT.fromUrl=async function(t,e){let n=te.createIfNeeded(t),i=await Bot(n);e=f(e,f.EMPTY_OBJECT);let o=new dT({...e,url:t,tileWidth:i.width,tileHeight:i.height});return o._image=i,o};dT.prototype.getTileCredits=function(t,e,n){};dT.prototype.requestImage=async function(t,e,n,i){if(!this._hasError&&!c(this._image)){let o=await Bot(this._resource,this);return this._image=o,za.reportSuccess(this._errorEvent),o}return this._image};dT.prototype.pickFeatures=function(t,e,n,i,o){};var HM=dT;var x0o=b(W(),1);var W0o=b(W(),1);function VEe(t,e,n){this.type=t,c(e)||(t==="json"?e="application/json":t==="xml"?e="text/xml":t==="html"?e="text/html":t==="text"&&(e="text/plain")),this.format=e,c(n)||(t==="json"?n=uEe:t==="xml"?n=WEe:(t==="html"||t==="text")&&(n=S1t)),this.callback=n}function uEe(t){let e=[],n=t.features;for(let i=0;i<n.length;++i){let o=n[i],a=new iZ;if(a.data=o,a.properties=o.properties,a.configureNameFromProperties(o.properties),a.configureDescriptionFromProperties(o.properties),c(o.geometry)&&o.geometry.type==="Point"){let s=o.geometry.coordinates[0],l=o.geometry.coordinates[1];a.position=gt.fromDegrees(s,l)}e.push(a)}return e}var Qot="http://www.mapinfo.com/mxp",ZEe="http://www.esri.com/wms",REe="http://www.opengis.net/wfs",bEe="http://www.opengis.net/gml";function WEe(t){let e=t.documentElement;if(e.localName==="MultiFeatureCollection"&&e.namespaceURI===Qot)return fEe(t);if(e.localName==="FeatureInfoResponse"&&e.namespaceURI===ZEe)return FEe(t);if(e.localName==="FeatureCollection"&&e.namespaceURI===REe)return UEe(t);if(e.localName==="ServiceExceptionReport")throw new Tt(new XMLSerializer().serializeToString(e));return e.localName==="msGMLOutput"?GEe(t):AEe(t)}function fEe(t){let e=[],i=t.documentElement.getElementsByTagNameNS(Qot,"Feature");for(let o=0;o<i.length;++o){let a=i[o],s={},l=a.getElementsByTagNameNS(Qot,"Val");for(let d=0;d<l.length;++d){let m=l[d];if(m.hasAttribute("ref")){let h=m.getAttribute("ref"),u=m.textContent.trim();s[h]=u}}let r=new iZ;r.data=a,r.properties=s,r.configureNameFromProperties(s),r.configureDescriptionFromProperties(s),e.push(r)}return e}function FEe(t){let e=t.documentElement,n=[],i,o=e.getElementsByTagNameNS("*","FIELDS");if(o.length>0)for(let a=0;a<o.length;++a){let s=o[a];i={};let l=s.attributes;for(let r=0;r<l.length;++r){let d=l[r];i[d.name]=d.value}n.push(Uz(s,i))}else{let a=e.getElementsByTagNameNS("*","FeatureInfo");for(let s=0;s<a.length;++s){let l=a[s];i={};let r=l.childNodes;for(let d=0;d<r.length;++d){let m=r[d];m.nodeType===Node.ELEMENT_NODE&&(i[m.localName]=m.textContent)}n.push(Uz(l,i))}}return n}function UEe(t){let e=[],i=t.documentElement.getElementsByTagNameNS(bEe,"featureMember");for(let o=0;o<i.length;++o){let a=i[o],s={};kot(a,s),e.push(Uz(a,s))}return e}function GEe(t){let e=[],n,i=t.documentElement.childNodes;for(let a=0;a<i.length;a++)if(i[a].nodeType===Node.ELEMENT_NODE){n=i[a];break}if(!c(n))throw new Tt("Unable to find first child of the feature info xml document");let o=n.childNodes;for(let a=0;a<o.length;++a){let s=o[a];if(s.nodeType===Node.ELEMENT_NODE){let l={};kot(s,l),e.push(Uz(s,l))}}return e}function kot(t,e){let n=!0;for(let i=0;i<t.childNodes.length;++i){let o=t.childNodes[i];o.nodeType===Node.ELEMENT_NODE&&(n=!1),!(o.localName==="Point"||o.localName==="LineString"||o.localName==="Polygon"||o.localName==="boundedBy")&&o.hasChildNodes()&&kot(o,e)&&(e[o.localName]=o.textContent)}return n}function Uz(t,e){let n=new iZ;return n.data=t,n.properties=e,n.configureNameFromProperties(e),n.configureDescriptionFromProperties(e),n}function AEe(t){let e=new XMLSerializer().serializeToString(t),n=document.createElement("div"),i=document.createElement("pre");i.textContent=e,n.appendChild(i);let o=new iZ;return o.data=t,o.description=n.innerHTML,[o]}var SEe=/<body>\s*<\/body>/im,TEe=/<ServiceExceptionReport([\s\S]*)<\/ServiceExceptionReport>/im,gEe=/<title>([\s\S]*)<\/title>/im;function S1t(t){if(SEe.test(t)||TEe.test(t))return;let e,n=gEe.exec(t);n&&n.length>1&&(e=n[1]);let i=new iZ;return i.name=e,i.description=t,i.data=t,[i]}var cT=VEe;var T0o=b(W(),1);function wM(t){t=f(t,f.EMPTY_OBJECT),this._tileCache={},this._tilesRequestedForInterval=[];let e=this._clock=t.clock;this._times=t.times,this._requestImageFunction=t.requestImageFunction,this._reloadFunction=t.reloadFunction,this._currentIntervalIndex=-1,e.onTick.addEventListener(this._clockOnTick,this),this._clockOnTick(e)}Object.defineProperties(wM.prototype,{clock:{get:function(){return this._clock},set:function(t){this._clock!==t&&(this._clock=t,this._clockOnTick(t),this._reloadFunction())}},times:{get:function(){return this._times},set:function(t){this._times!==t&&(this._times=t,this._clockOnTick(this._clock),this._reloadFunction())}},currentInterval:{get:function(){return this._times.get(this._currentIntervalIndex)}}});wM.prototype.getFromCache=function(t,e,n,i){let o=T1t(t,e,n),a,s=this._tileCache[this._currentIntervalIndex];if(c(s)&&c(s[o])){let l=s[o];a=l.promise.catch(function(r){throw i.state=l.request.state,r}),delete s[o]}return a};wM.prototype.checkApproachingInterval=function(t,e,n,i){let o=T1t(t,e,n),a=this._tilesRequestedForInterval,s=g1t(this),l={key:o,priorityFunction:i.priorityFunction};(!c(s)||!E1t(this,l,s))&&a.push(l),a.length>=512&&a.splice(0,256)};wM.prototype._clockOnTick=function(t){let e=t.currentTime,i=this._times.indexOf(e),o=this._currentIntervalIndex;if(i!==o){let s=this._tileCache[o];for(let l in s)s.hasOwnProperty(l)&&s[l].request.cancel();delete this._tileCache[o],this._tilesRequestedForInterval=[],this._currentIntervalIndex=i,this._reloadFunction();return}let a=g1t(this);if(c(a)){let s=this._tilesRequestedForInterval,l=!0;for(;l&&s.length!==0;){let r=s.pop();l=E1t(this,r,a),l||s.push(r)}}};function T1t(t,e,n){return`${t}-${e}-${n}`}function EEe(t){let e=t.split("-");if(e.length===3)return{x:Number(e[0]),y:Number(e[1]),level:Number(e[2])}}function g1t(t){let e=t._times;if(!c(e))return;let n=t._clock,i=n.currentTime,o=n.canAnimate&&n.shouldAnimate,a=n.multiplier;if(!o&&a!==0)return;let s,l=e.indexOf(i);if(l<0)return;let r=e.get(l);return a>0?(s=rt.secondsDifference(r.stop,i),++l):(s=rt.secondsDifference(r.start,i),--l),s/=a,l>=0&&s<=5?e.get(l):void 0}function E1t(t,e,n){let i=t._times.indexOf(n.start),o=t._tileCache,a=o[i];c(a)||(a=o[i]={});let s=e.key;if(c(a[s]))return!0;let l=EEe(s),r=new us({throttle:!1,throttleByServer:!0,type:Xl.IMAGERY,priorityFunction:e.priorityFunction}),d=t._requestImageFunction(l.x,l.y,l.level,r,n);return c(d)?(a[s]={promise:d,request:r},!0):!1}var mT=wM;var CEe=[3034,3035,3042,3043,3044],IEe=[4471,4559];function aZ(t){if(t=f(t,f.EMPTY_OBJECT),c(t.times)&&!c(t.clock))throw new Ut("options.times was specified, so options.clock is required.");this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._getFeatureInfoUrl=f(t.getFeatureInfoUrl,t.url);let e=te.createIfNeeded(t.url),n=te.createIfNeeded(this._getFeatureInfoUrl);e.setQueryParameters(aZ.DefaultParameters,!0),n.setQueryParameters(aZ.GetFeatureInfoDefaultParameters,!0),c(t.parameters)&&e.setQueryParameters(C1t(t.parameters)),c(t.getFeatureInfoParameters)&&n.setQueryParameters(C1t(t.getFeatureInfoParameters));let i=this;this._reload=void 0,c(t.times)&&(this._timeDynamicImagery=new mT({clock:t.clock,times:t.times,requestImageFunction:function(s,l,r,d,m){return I1t(i,s,l,r,d,m)},reloadFunction:function(){c(i._reload)&&i._reload()}}));let o={};if(o.layers=t.layers,o.bbox="{westProjected},{southProjected},{eastProjected},{northProjected}",o.width="{width}",o.height="{height}",parseFloat(e.queryParameters.version)>=1.3){o.crs=f(t.crs,t.tilingScheme&&t.tilingScheme.projection instanceof Yo?"EPSG:3857":"CRS:84");let s=o.crs.split(":");if(s[0]==="EPSG"&&s.length===2){let l=Number(s[1]);(l>=4e3&&l<5e3&&!IEe.includes(l)||CEe.includes(l))&&(o.bbox="{southProjected},{westProjected},{northProjected},{eastProjected}")}}else o.srs=f(t.srs,t.tilingScheme&&t.tilingScheme.projection instanceof Yo?"EPSG:3857":"EPSG:4326");e.setQueryParameters(o,!0),n.setQueryParameters(o,!0);let a={query_layers:t.layers,info_format:"{format}"};parseFloat(n.queryParameters.version)>=1.3?(a.i="{i}",a.j="{j}"):(a.x="{i}",a.y="{j}"),n.setQueryParameters(a,!0),this._resource=e,this._pickFeaturesResource=n,this._layers=t.layers,this._tileProvider=new Ad({url:e,pickFeaturesUrl:n,tilingScheme:f(t.tilingScheme,new Qo({ellipsoid:t.ellipsoid})),rectangle:t.rectangle,tileWidth:t.tileWidth,tileHeight:t.tileHeight,minimumLevel:t.minimumLevel,maximumLevel:t.maximumLevel,subdomains:t.subdomains,tileDiscardPolicy:t.tileDiscardPolicy,credit:t.credit,getFeatureInfoFormats:f(t.getFeatureInfoFormats,aZ.DefaultGetFeatureInfoFormats),enablePickFeatures:t.enablePickFeatures})}function I1t(t,e,n,i,o,a){let s=c(a)?a.data:void 0,l=t._tileProvider;return c(s)&&l._resource.setQueryParameters(s),l.requestImage(e,n,i,o)}function NEe(t,e,n,i,o,a,s){let l=c(s)?s.data:void 0,r=t._tileProvider;return c(l)&&r._pickFeaturesResource.setQueryParameters(l),r.pickFeatures(e,n,i,o,a)}Object.defineProperties(aZ.prototype,{url:{get:function(){return this._resource._url}},proxy:{get:function(){return this._resource.proxy}},layers:{get:function(){return this._layers}},tileWidth:{get:function(){return this._tileProvider.tileWidth}},tileHeight:{get:function(){return this._tileProvider.tileHeight}},maximumLevel:{get:function(){return this._tileProvider.maximumLevel}},minimumLevel:{get:function(){return this._tileProvider.minimumLevel}},tilingScheme:{get:function(){return this._tileProvider.tilingScheme}},rectangle:{get:function(){return this._tileProvider.rectangle}},tileDiscardPolicy:{get:function(){return this._tileProvider.tileDiscardPolicy}},errorEvent:{get:function(){return this._tileProvider.errorEvent}},credit:{get:function(){return this._tileProvider.credit}},hasAlphaChannel:{get:function(){return this._tileProvider.hasAlphaChannel}},enablePickFeatures:{get:function(){return this._tileProvider.enablePickFeatures},set:function(t){this._tileProvider.enablePickFeatures=t}},clock:{get:function(){return this._timeDynamicImagery.clock},set:function(t){this._timeDynamicImagery.clock=t}},times:{get:function(){return this._timeDynamicImagery.times},set:function(t){this._timeDynamicImagery.times=t}},getFeatureInfoUrl:{get:function(){return this._getFeatureInfoUrl}}});aZ.prototype.getTileCredits=function(t,e,n){return this._tileProvider.getTileCredits(t,e,n)};aZ.prototype.requestImage=function(t,e,n,i){let o,a=this._timeDynamicImagery,s;return c(a)&&(s=a.currentInterval,o=a.getFromCache(t,e,n,i)),c(o)||(o=I1t(this,t,e,n,i,s)),c(o)&&c(a)&&a.checkApproachingInterval(t,e,n,i),o};aZ.prototype.pickFeatures=function(t,e,n,i,o){let a=this._timeDynamicImagery,s=c(a)?a.currentInterval:void 0;return NEe(this,t,e,n,i,o,s)};aZ.DefaultParameters=Object.freeze({service:"WMS",version:"1.1.1",request:"GetMap",styles:"",format:"image/jpeg"});aZ.GetFeatureInfoDefaultParameters=Object.freeze({service:"WMS",version:"1.1.1",request:"GetFeatureInfo"});aZ.DefaultGetFeatureInfoFormats=Object.freeze([Object.freeze(new cT("json","application/json")),Object.freeze(new cT("xml","text/xml")),Object.freeze(new cT("text","text/html"))]);function C1t(t){let e={};for(let n in t)t.hasOwnProperty(n)&&(e[n.toLowerCase()]=t[n]);return e}var PM=aZ;var K0o=b(W(),1);var yEe=Object.freeze({service:"WMTS",version:"1.0.0",request:"GetTile"});function vM(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0;let e=te.createIfNeeded(t.url),n=t.style,i=t.tileMatrixSetID,o=e.url,a=o.match(/{/g);if(!c(a)||a.length===1&&/{s}/.test(o))e.setQueryParameters(yEe),this._useKvp=!0;else{let h={style:n,Style:n,TileMatrixSet:i};e.setTemplateValues(h),this._useKvp=!1}this._resource=e,this._layer=t.layer,this._style=n,this._tileMatrixSetID=i,this._tileMatrixLabels=t.tileMatrixLabels,this._format=f(t.format,"image/jpeg"),this._tileDiscardPolicy=t.tileDiscardPolicy,this._tilingScheme=c(t.tilingScheme)?t.tilingScheme:new Gs({ellipsoid:t.ellipsoid}),this._tileWidth=f(t.tileWidth,256),this._tileHeight=f(t.tileHeight,256),this._minimumLevel=f(t.minimumLevel,0),this._maximumLevel=t.maximumLevel,this._rectangle=f(t.rectangle,this._tilingScheme.rectangle),this._dimensions=t.dimensions;let s=this;this._reload=void 0,c(t.times)&&(this._timeDynamicImagery=new mT({clock:t.clock,times:t.times,requestImageFunction:function(h,u,R,V,F){return N1t(s,h,u,R,V,F)},reloadFunction:function(){c(s._reload)&&s._reload()}}));let l=this._tilingScheme.positionToTileXY(Gt.southwest(this._rectangle),this._minimumLevel),r=this._tilingScheme.positionToTileXY(Gt.northeast(this._rectangle),this._minimumLevel),d=(Math.abs(r.x-l.x)+1)*(Math.abs(r.y-l.y)+1);this._errorEvent=new It;let m=t.credit;this._credit=typeof m=="string"?new on(m):m,this._subdomains=t.subdomains,Array.isArray(this._subdomains)?this._subdomains=this._subdomains.slice():c(this._subdomains)&&this._subdomains.length>0?this._subdomains=this._subdomains.split(""):this._subdomains=["a","b","c"]}function N1t(t,e,n,i,o,a){let s=t._tileMatrixLabels,l=c(s)?s[i]:i.toString(),r=t._subdomains,d=t._dimensions,m=c(a)?a.data:void 0,h,u;if(!t._useKvp)u={TileMatrix:l,TileRow:n.toString(),TileCol:e.toString(),s:r[(e+n+i)%r.length]},h=t._resource.getDerivedResource({request:o}),h.setTemplateValues(u),c(d)&&h.setTemplateValues(d),c(m)&&h.setTemplateValues(m);else{let R={};R.tilematrix=l,R.layer=t._layer,R.style=t._style,R.tilerow=n,R.tilecol=e,R.tilematrixset=t._tileMatrixSetID,R.format=t._format,c(d)&&(R=ze(R,d)),c(m)&&(R=ze(R,m)),u={s:r[(e+n+i)%r.length]},h=t._resource.getDerivedResource({queryParameters:R,request:o}),h.setTemplateValues(u)}return $c.loadImage(t,h)}Object.defineProperties(vM.prototype,{url:{get:function(){return this._resource.url}},proxy:{get:function(){return this._resource.proxy}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return this._minimumLevel}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},format:{get:function(){return this._format}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return!0}},clock:{get:function(){return this._timeDynamicImagery.clock},set:function(t){this._timeDynamicImagery.clock=t}},times:{get:function(){return this._timeDynamicImagery.times},set:function(t){this._timeDynamicImagery.times=t}},dimensions:{get:function(){return this._dimensions},set:function(t){this._dimensions!==t&&(this._dimensions=t,c(this._reload)&&this._reload())}}});vM.prototype.getTileCredits=function(t,e,n){};vM.prototype.requestImage=function(t,e,n,i){let o,a=this._timeDynamicImagery,s;return c(a)&&(s=a.currentInterval,o=a.getFromCache(t,e,n,i)),c(o)||(o=N1t(this,t,e,n,i,s)),c(o)&&c(a)&&a.checkApproachingInterval(t,e,n,i),o};vM.prototype.pickFeatures=function(t,e,n,i,o){};var hT=vM;var BEe={ARCGIS_MAPSERVER:cW.fromUrl,BING:async(t,e)=>LM.fromUrl(t,e),GOOGLE_EARTH:async(t,e)=>{let n=e.channel;return delete e.channel,DM.fromUrl(t,n,e)},MAPBOX:(t,e)=>new OM({url:t,...e}),SINGLE_TILE:HM.fromUrl,TMS:hU.fromUrl,URL_TEMPLATE:(t,e)=>new Ad({url:t,...e}),WMS:(t,e)=>new PM({url:t,...e}),WMTS:(t,e)=>new hT({url:t,...e})};function xR(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._tileCredits=void 0,this._errorEvent=new It}Object.defineProperties(xR.prototype,{rectangle:{get:function(){return this._imageryProvider.rectangle}},tileWidth:{get:function(){return this._imageryProvider.tileWidth}},tileHeight:{get:function(){return this._imageryProvider.tileHeight}},maximumLevel:{get:function(){return this._imageryProvider.maximumLevel}},minimumLevel:{get:function(){return this._imageryProvider.minimumLevel}},tilingScheme:{get:function(){return this._imageryProvider.tilingScheme}},tileDiscardPolicy:{get:function(){return this._imageryProvider.tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._imageryProvider.credit}},hasAlphaChannel:{get:function(){return this._imageryProvider.hasAlphaChannel}},proxy:{get:function(){}}});xR.fromAssetId=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=gh._createEndpointResource(t,e),i=t.toString()+e.accessToken+e.server,o=xR._endpointCache[i];c(o)||(o=n.fetchJson(),xR._endpointCache[i]=o);let a=await o;if(a.type!=="IMAGERY")throw new Tt(`Cesium ion asset ${t} is not an imagery asset.`);let s,l=a.externalType;if(!c(l))s=await hU.fromUrl(new gh(a,n));else{let d=BEe[l];if(!c(d))throw new Tt(`Unrecognized Cesium ion imagery type: ${l}`);let m={...a.options},h=m.url;delete m.url,s=await d(h,m)}let r=new xR(e);return s.errorEvent.addEventListener(function(d){d.provider=r,r._errorEvent.raiseEvent(d)}),r._tileCredits=gh.getCreditsFromEndpoint(a,n),r._imageryProvider=s,r};xR.prototype.getTileCredits=function(t,e,n){let i=this._imageryProvider.getTileCredits(t,e,n);return c(i)?this._tileCredits.concat(i):this._tileCredits};xR.prototype.requestImage=function(t,e,n,i){return this._imageryProvider.requestImage(t,e,n,i)};xR.prototype.pickFeatures=function(t,e,n,i,o){return this._imageryProvider.pickFeatures(t,e,n,i,o)};xR._endpointCache={};var mW=xR;var pWo=b(W(),1),QEe={AERIAL:2,AERIAL_WITH_LABELS:3,ROAD:4},hW=Object.freeze(QEe);function kEe(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.style,hW.AERIAL);return mW.fromAssetId(e)}var pW=kEe;var fWo=b(W(),1),KM=`uniform sampler2D u_texture; in vec2 v_textureCoordinates; @@ -10451,7 +10451,7 @@ void main() { out_FragColor = texture(u_texture, v_textureCoordinates); } -`;var UWo=R(W(),1),zM=`in vec4 position; +`;var UWo=b(W(),1),zM=`in vec4 position; in float webMercatorT; uniform vec2 u_textureDimensions; @@ -10463,7 +10463,7 @@ void main() v_textureCoordinates = vec2(position.x, webMercatorT); gl_Position = czm_viewportOrthographic * (position * vec4(u_textureDimensions, 1.0, 1.0)); } -`;var gWo=R(W(),1);function E1(t,e,n,i,o){if(this.imageryLayer=t,this.x=e,this.y=n,this.level=i,this.request=void 0,i!==0){let a=e/2|0,s=n/2|0,l=i-1;this.parent=t.getImageryFromCache(a,s,l)}this.state=ho.UNLOADED,this.imageUrl=void 0,this.image=void 0,this.texture=void 0,this.textureWebMercator=void 0,this.credits=void 0,this.referenceCount=0,!c(o)&&t.ready&&(o=t.imageryProvider.tilingScheme.tileXYToRectangle(e,n,i)),this.rectangle=o}E1.createPlaceholder=function(t){let e=new E1(t,0,0,0);return e.addReference(),e.state=ho.PLACEHOLDER,e};E1.prototype.addReference=function(){++this.referenceCount};E1.prototype.releaseReference=function(){return--this.referenceCount,this.referenceCount===0?(this.imageryLayer.removeImageryFromCache(this),c(this.parent)&&this.parent.releaseReference(),c(this.image)&&c(this.image.destroy)&&this.image.destroy(),c(this.texture)&&this.texture.destroy(),c(this.textureWebMercator)&&this.texture!==this.textureWebMercator&&this.textureWebMercator.destroy(),At(this),0):this.referenceCount};E1.prototype.processStateMachine=function(t,e,n){this.state===ho.UNLOADED&&!n&&(this.state=ho.TRANSITIONING,this.imageryLayer._requestImagery(this)),this.state===ho.RECEIVED&&(this.state=ho.TRANSITIONING,this.imageryLayer._createTexture(t.context,this));let i=this.state===ho.READY&&e&&!this.texture;(this.state===ho.TEXTURE_LOADED||i)&&(this.state=ho.TRANSITIONING,this.imageryLayer._reprojectTexture(t,this,e))};var C1=E1;var NWo=R(W(),1);function Yot(t,e,n){this.readyImagery=void 0,this.loadingImagery=t,this.textureCoordinateRectangle=e,this.textureTranslationAndScale=void 0,this.useWebMercatorT=n}Yot.prototype.freeResources=function(){c(this.readyImagery)&&this.readyImagery.releaseReference(),c(this.loadingImagery)&&this.loadingImagery.releaseReference()};Yot.prototype.processStateMachine=function(t,e,n){let i=this.loadingImagery,o=i.imageryLayer;if(i.processStateMachine(e,!this.useWebMercatorT,n),i.state===ho.READY)return c(this.readyImagery)&&this.readyImagery.releaseReference(),this.readyImagery=this.loadingImagery,this.loadingImagery=void 0,this.textureTranslationAndScale=o._calculateTextureTranslationAndScale(t,this),!0;let a=i.parent,s;for(;c(a)&&(a.state!==ho.READY||!this.useWebMercatorT&&!c(a.texture));)a.state!==ho.FAILED&&a.state!==ho.INVALID&&(s=s||a),a=a.parent;return this.readyImagery!==a&&(c(this.readyImagery)&&this.readyImagery.releaseReference(),this.readyImagery=a,c(a)&&(a.addReference(),this.textureTranslationAndScale=o._calculateTextureTranslationAndScale(t,this))),i.state===ho.FAILED||i.state===ho.INVALID?c(s)?(s.processStateMachine(e,!this.useWebMercatorT,n),!1):!0:!1};var I1=Yot;function Uo(t,e){this._imageryProvider=t,this._readyEvent=new It,this._errorEvent=new It,e=f(e,f.EMPTY_OBJECT),t=f(t,f.EMPTY_OBJECT),this.alpha=f(e.alpha,f(t._defaultAlpha,1)),this.nightAlpha=f(e.nightAlpha,f(t._defaultNightAlpha,1)),this.dayAlpha=f(e.dayAlpha,f(t._defaultDayAlpha,1)),this.brightness=f(e.brightness,f(t._defaultBrightness,Uo.DEFAULT_BRIGHTNESS)),this.contrast=f(e.contrast,f(t._defaultContrast,Uo.DEFAULT_CONTRAST)),this.hue=f(e.hue,f(t._defaultHue,Uo.DEFAULT_HUE)),this.saturation=f(e.saturation,f(t._defaultSaturation,Uo.DEFAULT_SATURATION)),this.gamma=f(e.gamma,f(t._defaultGamma,Uo.DEFAULT_GAMMA)),this.splitDirection=f(e.splitDirection,Uo.DEFAULT_SPLIT),this.minificationFilter=f(e.minificationFilter,f(t._defaultMinificationFilter,Uo.DEFAULT_MINIFICATION_FILTER)),this.magnificationFilter=f(e.magnificationFilter,f(t._defaultMagnificationFilter,Uo.DEFAULT_MAGNIFICATION_FILTER)),this.show=f(e.show,!0),this._minimumTerrainLevel=e.minimumTerrainLevel,this._maximumTerrainLevel=e.maximumTerrainLevel,this._rectangle=f(e.rectangle,Gt.MAX_VALUE),this._maximumAnisotropy=e.maximumAnisotropy,this._imageryCache={},this._skeletonPlaceholder=new I1(C1.createPlaceholder(this)),this._show=!0,this._layerIndex=-1,this._isBaseLayer=!1,this._requestImageError=void 0,this._reprojectComputeCommands=[],this.cutoutRectangle=e.cutoutRectangle,this.colorToAlpha=e.colorToAlpha,this.colorToAlphaThreshold=f(e.colorToAlphaThreshold,Uo.DEFAULT_APPLY_COLOR_TO_ALPHA_THRESHOLD)}Object.defineProperties(Uo.prototype,{imageryProvider:{get:function(){return this._imageryProvider}},ready:{get:function(){return c(this._imageryProvider)}},errorEvent:{get:function(){return this._errorEvent}},readyEvent:{get:function(){return this._readyEvent}},rectangle:{get:function(){return this._rectangle}}});Uo.DEFAULT_BRIGHTNESS=1;Uo.DEFAULT_CONTRAST=1;Uo.DEFAULT_HUE=0;Uo.DEFAULT_SATURATION=1;Uo.DEFAULT_GAMMA=1;Uo.DEFAULT_SPLIT=Jc.NONE;Uo.DEFAULT_MINIFICATION_FILTER=On.LINEAR;Uo.DEFAULT_MAGNIFICATION_FILTER=bo.LINEAR;Uo.DEFAULT_APPLY_COLOR_TO_ALPHA_THRESHOLD=.004;Uo.fromProviderAsync=function(t,e){let n=new Uo(void 0,e);return LEe(n,Promise.resolve(t)),n};Uo.fromWorldImagery=function(t){return t=f(t,f.EMPTY_OBJECT),Uo.fromProviderAsync(pW({style:t.style}),t)};Uo.prototype.isBaseLayer=function(){return this._isBaseLayer};Uo.prototype.isDestroyed=function(){return!1};Uo.prototype.destroy=function(){return At(this)};var Q1t=new Gt,y1t=new Gt,xot=new Gt,k1t=new Gt;Uo.prototype.getImageryRectangle=function(){let t=this._imageryProvider,e=this._rectangle;return Gt.intersection(t.rectangle,e)};Uo.prototype._createTileImagerySkeletons=function(t,e,n){let i=t.data;if(!c(e)||c(this._minimumTerrainLevel)&&t.level<this._minimumTerrainLevel||c(this._maximumTerrainLevel)&&t.level>this._maximumTerrainLevel)return!1;c(n)||(n=i.imagery.length);let o=this._imageryProvider;if(!this.ready)return this._skeletonPlaceholder.loadingImagery.addReference(),i.imagery.splice(n,0,this._skeletonPlaceholder),!0;let a=o.tilingScheme.projection instanceof Yo&&t.rectangle.north<Yo.MaximumLatitude&&t.rectangle.south>-Yo.MaximumLatitude,s=Gt.intersection(o.rectangle,this._rectangle,Q1t),l=Gt.intersection(t.rectangle,s,y1t);if(!c(l)){if(!this.isBaseLayer())return!1;let I=s,B=t.rectangle;l=y1t,B.south>=I.north?l.north=l.south=I.north:B.north<=I.south?l.north=l.south=I.south:(l.south=Math.max(B.south,I.south),l.north=Math.min(B.north,I.north)),B.west>=I.east?l.west=l.east=I.east:B.east<=I.west?l.west=l.east=I.west:(l.west=Math.max(B.west,I.west),l.east=Math.min(B.east,I.east))}let r=0;l.south>0?r=l.south:l.north<0&&(r=l.north);let m=1*e.getLevelMaximumGeometricError(t.level),h=XEe(this,m,r);h=Math.max(0,h);let Z=o.maximumLevel;if(h>Z&&(h=Z),c(o.minimumLevel)){let I=o.minimumLevel;h<I&&(h=I)}let b=o.tilingScheme,u=b.positionToTileXY(Gt.northwest(l),h),F=b.positionToTileXY(Gt.southeast(l),h),U=t.rectangle.width/512,G=t.rectangle.height/512,A=b.tileXYToRectangle(u.x,u.y,h);Math.abs(A.south-t.rectangle.north)<G&&u.y<F.y&&++u.y,Math.abs(A.east-t.rectangle.west)<U&&u.x<F.x&&++u.x;let T=b.tileXYToRectangle(F.x,F.y,h);Math.abs(T.north-t.rectangle.south)<G&&F.y>u.y&&--F.y,Math.abs(T.west-t.rectangle.east)<U&&F.x>u.x&&--F.x;let g=Gt.clone(t.rectangle,k1t),C=b.tileXYToRectangle(u.x,u.y,h),y=Gt.intersection(C,s,xot),Y;a?(b.rectangleToNativeRectangle(g,g),b.rectangleToNativeRectangle(C,C),b.rectangleToNativeRectangle(y,y),b.rectangleToNativeRectangle(s,s),Y=b.tileXYToNativeRectangle.bind(b),U=g.width/512,G=g.height/512):Y=b.tileXYToRectangle.bind(b);let Q,J=0,M=1,V;!this.isBaseLayer()&&Math.abs(y.west-g.west)>=U&&(J=Math.min(1,(y.west-g.west)/g.width)),!this.isBaseLayer()&&Math.abs(y.north-g.north)>=G&&(M=Math.max(0,(y.north-g.south)/g.height));let E=M;for(let I=u.x;I<=F.x;I++)if(Q=J,C=Y(I,u.y,h),y=Gt.simpleIntersection(C,s,xot),!!c(y)){J=Math.min(1,(y.east-g.west)/g.width),I===F.x&&(this.isBaseLayer()||Math.abs(y.east-g.east)<U)&&(J=1),M=E;for(let B=u.y;B<=F.y;B++){if(V=M,C=Y(I,B,h),y=Gt.simpleIntersection(C,s,xot),!c(y))continue;M=Math.max(0,(y.south-g.south)/g.height),B===F.y&&(this.isBaseLayer()||Math.abs(y.south-g.south)<G)&&(M=0);let X=new Rt(Q,M,J,V),_=this.getImageryFromCache(I,B,h);i.imagery.splice(n,0,new I1(_,X,a)),++n}}return!0};Uo.prototype._calculateTextureTranslationAndScale=function(t,e){let n=e.readyImagery.rectangle,i=t.rectangle;if(e.useWebMercatorT){let r=e.readyImagery.imageryLayer.imageryProvider.tilingScheme;n=r.rectangleToNativeRectangle(n,Q1t),i=r.rectangleToNativeRectangle(i,k1t)}let o=i.width,a=i.height,s=o/n.width,l=a/n.height;return new Rt(s*(i.west-n.west)/o,l*(i.south-n.south)/a,s,l)};Uo.prototype._requestImagery=function(t){let e=this._imageryProvider,n=this;function i(s){if(!c(s))return o();t.image=s,t.state=ho.RECEIVED,t.request=void 0,za.reportSuccess(n._requestImageError)}function o(s){if(t.request.state===qi.CANCELLED){t.state=ho.UNLOADED,t.request=void 0;return}t.state=ho.FAILED,t.request=void 0;let l=`Failed to obtain image tile X: ${t.x} Y: ${t.y} Level: ${t.level}.`;n._requestImageError=za.reportError(n._requestImageError,e,e.errorEvent,l,t.x,t.y,t.level,s),n._requestImageError.retry&&a()}function a(){let s=new Zs({throttle:!1,throttleByServer:!0,type:Xl.IMAGERY});t.request=s,t.state=ho.TRANSITIONING;let l=e.requestImage(t.x,t.y,t.level,s);if(!c(l)){t.state=ho.UNLOADED,t.request=void 0;return}c(e.getTileCredits)&&(t.credits=e.getTileCredits(t.x,t.y,t.level)),l.then(function(r){i(r)}).catch(function(r){o(r)})}a()};Uo.prototype._createTextureWebGL=function(t,e){let n=new Hn({minificationFilter:this.minificationFilter,magnificationFilter:this.magnificationFilter}),i=e.image;return c(i.internalFormat)?new hn({context:t,pixelFormat:i.internalFormat,width:i.width,height:i.height,source:{arrayBufferView:i.bufferView},sampler:n}):new hn({context:t,source:i,pixelFormat:this._imageryProvider.hasAlphaChannel?Ye.RGBA:Ye.RGB,sampler:n})};Uo.prototype._createTexture=function(t,e){let n=this._imageryProvider,i=e.image;if(c(n.tileDiscardPolicy)){let a=n.tileDiscardPolicy;if(c(a)){if(!a.isReady()){e.state=ho.RECEIVED;return}if(a.shouldDiscardImage(i)){e.state=ho.INVALID;return}}}let o=this._createTextureWebGL(t,e);n.tilingScheme.projection instanceof Yo?e.textureWebMercator=o:e.texture=o,e.image=void 0,e.state=ho.TEXTURE_LOADED};function B1t(t,e,n){return`${t}:${e}:${n}`}Uo.prototype._finalizeReprojectTexture=function(t,e){let n=this.minificationFilter,i=this.magnificationFilter;if(n===On.LINEAR&&i===bo.LINEAR&&!Ye.isCompressedFormat(e.pixelFormat)&&k.isPowerOfTwo(e.width)&&k.isPowerOfTwo(e.height)){n=On.LINEAR_MIPMAP_LINEAR;let a=Sn.maximumTextureFilterAnisotropy,s=Math.min(a,f(this._maximumAnisotropy,a)),l=B1t(n,i,s),r=t.cache.imageryLayerMipmapSamplers;c(r)||(r={},t.cache.imageryLayerMipmapSamplers=r);let d=r[l];c(d)||(d=r[l]=new Hn({wrapS:Vi.CLAMP_TO_EDGE,wrapT:Vi.CLAMP_TO_EDGE,minificationFilter:n,magnificationFilter:i,maximumAnisotropy:s})),e.generateMipmap(JV.NICEST),e.sampler=d}else{let a=B1t(n,i,0),s=t.cache.imageryLayerNonMipmapSamplers;c(s)||(s={},t.cache.imageryLayerNonMipmapSamplers=s);let l=s[a];c(l)||(l=s[a]=new Hn({wrapS:Vi.CLAMP_TO_EDGE,wrapT:Vi.CLAMP_TO_EDGE,minificationFilter:n,magnificationFilter:i})),e.sampler=l}};Uo.prototype._reprojectTexture=function(t,e,n){let i=e.textureWebMercator||e.texture,o=e.rectangle,a=t.context;if(n=f(n,!0),n&&!(this._imageryProvider.tilingScheme.projection instanceof yo)&&o.width/i.width>1e-5){let s=this;e.addReference();let l=new Wm({persists:!0,owner:this,preExecute:function(r){xEe(r,a,i,e.rectangle)},postExecute:function(r){e.texture=r,s._finalizeReprojectTexture(a,r),e.state=ho.READY,e.releaseReference()},canceled:function(){e.state=ho.TEXTURE_LOADED,e.releaseReference()}});this._reprojectComputeCommands.push(l)}else n&&(e.texture=i),this._finalizeReprojectTexture(a,i),e.state=ho.READY};Uo.prototype.queueReprojectionCommands=function(t){let e=this._reprojectComputeCommands,n=e.length;for(let i=0;i<n;++i)t.commandList.push(e[i]);e.length=0};Uo.prototype.cancelReprojections=function(){this._reprojectComputeCommands.forEach(function(t){c(t.canceled)&&t.canceled()}),this._reprojectComputeCommands.length=0};Uo.prototype.getImageryFromCache=function(t,e,n,i){let o=Y1t(t,e,n),a=this._imageryCache[o];return c(a)||(a=new C1(this,t,e,n,i),this._imageryCache[o]=a),a.addReference(),a};Uo.prototype.removeImageryFromCache=function(t){let e=Y1t(t.x,t.y,t.level);delete this._imageryCache[e]};function Y1t(t,e,n){return JSON.stringify([t,e,n])}var Gz={u_textureDimensions:function(){return this.textureDimensions},u_texture:function(){return this.texture},textureDimensions:new K,texture:void 0},YEe=In.supportsTypedArrays()?new Float32Array(2*64):void 0;function xEe(t,e,n,i){let o=e.cache.imageryLayer_reproject;if(!c(o)){o=e.cache.imageryLayer_reproject={vertexArray:void 0,shaderProgram:void 0,sampler:void 0,destroy:function(){c(this.framebuffer)&&this.framebuffer.destroy(),c(this.vertexArray)&&this.vertexArray.destroy(),c(this.shaderProgram)&&this.shaderProgram.destroy()}};let U=new Float32Array(2*64*2),G=0;for(let y=0;y<64;++y){let Y=y/63;U[G++]=0,U[G++]=Y,U[G++]=1,U[G++]=Y}let A={position:0,webMercatorT:1},T=El.getRegularGridIndices(2,64),g=we.createIndexBuffer({context:e,typedArray:T,usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT});o.vertexArray=new Ki({context:e,attributes:[{index:A.position,vertexBuffer:we.createVertexBuffer({context:e,typedArray:U,usage:ce.STATIC_DRAW}),componentsPerAttribute:2},{index:A.webMercatorT,vertexBuffer:we.createVertexBuffer({context:e,sizeInBytes:64*2*4,usage:ce.STREAM_DRAW}),componentsPerAttribute:1}],indexBuffer:g});let C=new Ve({sources:[zM]});o.shaderProgram=xn.fromCache({context:e,vertexShaderSource:C,fragmentShaderSource:KM,attributeLocations:A}),o.sampler=new Hn({wrapS:Vi.CLAMP_TO_EDGE,wrapT:Vi.CLAMP_TO_EDGE,minificationFilter:On.LINEAR,magnificationFilter:bo.LINEAR})}n.sampler=o.sampler;let a=n.width,s=n.height;Gz.textureDimensions.x=a,Gz.textureDimensions.y=s,Gz.texture=n;let l=Math.sin(i.south),r=.5*Math.log((1+l)/(1-l));l=Math.sin(i.north);let m=1/(.5*Math.log((1+l)/(1-l))-r),h=new hn({context:e,width:a,height:s,pixelFormat:n.pixelFormat,pixelDatatype:n.pixelDatatype,preMultiplyAlpha:n.preMultiplyAlpha});k.isPowerOfTwo(a)&&k.isPowerOfTwo(s)&&h.generateMipmap(JV.NICEST);let Z=i.south,b=i.north,u=YEe,F=0;for(let U=0;U<64;++U){let G=U/63,A=k.lerp(Z,b,G);l=Math.sin(A);let g=(.5*Math.log((1+l)/(1-l))-r)*m;u[F++]=g,u[F++]=g}o.vertexArray.getAttribute(1).vertexBuffer.copyFromArrayView(u),t.shaderProgram=o.shaderProgram,t.outputTexture=h,t.uniformMap=Gz,t.vertexArray=o.vertexArray}function XEe(t,e,n){let i=t._imageryProvider,o=i.tilingScheme,a=o.ellipsoid,s=t._imageryProvider.tilingScheme.projection instanceof yo?1:Math.cos(n),l=o.rectangle,d=a.maximumRadius*l.width*s/(i.tileWidth*o.getNumberOfXTilesAtLevel(0))/e,m=Math.log(d)/Math.log(2);return Math.round(m)|0}function JEe(t,e){t.numberOfListeners>0?t.raiseEvent(e):console.error(e)}async function LEe(t,e){let n;try{if(n=await Promise.resolve(e),t.isDestroyed())return;t._imageryProvider=n,t._readyEvent.raiseEvent(n)}catch(i){JEe(t._errorEvent,i)}}var $r=Uo;var Dfo=R(W(),1);var Wfo=R(W(),1),MEe={WEST:0,NORTH:1,EAST:2,SOUTH:3,NORTHWEST:4,NORTHEAST:5,SOUTHWEST:6,SOUTHEAST:7},mi=MEe;var Ffo=R(W(),1),x1t={NONE:0,CULLED:1,RENDERED:2,REFINED:3,RENDERED_AND_KICKED:6,REFINED_AND_KICKED:7,CULLED_BUT_NEEDED:9,wasKicked:function(t){return t>=x1t.RENDERED_AND_KICKED},originalResult:function(t){return t&3},kick:function(t){return t|4}},Pi=x1t;function y1(t){this.tile=t,this.frameLastUpdated=void 0,this.westMeshes=[],this.westTiles=[],this.southMeshes=[],this.southTiles=[],this.eastMeshes=[],this.eastTiles=[],this.northMeshes=[],this.northTiles=[],this.southwestMesh=void 0,this.southwestTile=void 0,this.southeastMesh=void 0,this.southeastTile=void 0,this.northwestMesh=void 0,this.northwestTile=void 0,this.northeastMesh=void 0,this.northeastTile=void 0,this.changedThisFrame=!0,this.visitedFrame=void 0,this.enqueuedFrame=void 0,this.mesh=void 0,this.vertexArray=void 0,this.waterMaskTexture=void 0,this.waterMaskTranslationAndScale=new Rt}y1.prototype.update=function(t,e,n){this.changedThisFrame&&(O1t(t,e,this.tile,n),this.changedThisFrame=!1)};y1.prototype.destroy=function(t){this._destroyVertexArray(t),c(this.waterMaskTexture)&&(--this.waterMaskTexture.referenceCount,this.waterMaskTexture.referenceCount===0&&this.waterMaskTexture.destroy(),this.waterMaskTexture=void 0)};y1.prototype._destroyVertexArray=function(t){c(this.vertexArray)&&(c(t)?t.push(this.vertexArray):Tu._freeVertexArray(this.vertexArray),this.vertexArray=void 0)};var _Ee=new $V;y1.updateFillTiles=function(t,e,n,i){let o=t._quadtree,a=o._levelZeroTiles,s=o._lastSelectionFrameNumber,l=_Ee;l.clear();for(let d=0;d<e.length;++d){let m=e[d];c(m.data.vertexArray)&&l.enqueue(e[d])}let r=l.dequeue();for(;r!==void 0;){let d=r.findTileToWest(a),m=r.findTileToSouth(a),h=r.findTileToEast(a),Z=r.findTileToNorth(a);rr(t,n,r,d,s,mi.EAST,!1,l,i),rr(t,n,r,m,s,mi.NORTH,!1,l,i),rr(t,n,r,h,s,mi.WEST,!1,l,i),rr(t,n,r,Z,s,mi.SOUTH,!1,l,i);let b=d.findTileToNorth(a),u=d.findTileToSouth(a),F=h.findTileToNorth(a),U=h.findTileToSouth(a);rr(t,n,r,b,s,mi.SOUTHEAST,!1,l,i),rr(t,n,r,F,s,mi.SOUTHWEST,!1,l,i),rr(t,n,r,u,s,mi.NORTHEAST,!1,l,i),rr(t,n,r,U,s,mi.NORTHWEST,!1,l,i),r=l.dequeue()}};function rr(t,e,n,i,o,a,s,l,r){if(i===void 0)return;let d=i;for(;d&&(d._lastSelectionResultFrame!==o||Pi.wasKicked(d._lastSelectionResult)||Pi.originalResult(d._lastSelectionResult)===Pi.CULLED);){if(s)return;let m=d.parent;if(a>=mi.NORTHWEST&&m!==void 0)switch(a){case mi.NORTHWEST:d=d===m.northwestChild?m:void 0;break;case mi.NORTHEAST:d=d===m.northeastChild?m:void 0;break;case mi.SOUTHWEST:d=d===m.southwestChild?m:void 0;break;case mi.SOUTHEAST:d=d===m.southeastChild?m:void 0;break}else d=m}if(d!==void 0){if(d._lastSelectionResult===Pi.RENDERED){if(c(d.data.vertexArray))return;DEe(t,e,n,d,a,o,l,r);return}if(Pi.originalResult(i._lastSelectionResult)!==Pi.CULLED)switch(a){case mi.WEST:rr(t,e,n,i.northwestChild,o,a,!0,l,r),rr(t,e,n,i.southwestChild,o,a,!0,l,r);break;case mi.EAST:rr(t,e,n,i.southeastChild,o,a,!0,l,r),rr(t,e,n,i.northeastChild,o,a,!0,l,r);break;case mi.SOUTH:rr(t,e,n,i.southwestChild,o,a,!0,l,r),rr(t,e,n,i.southeastChild,o,a,!0,l,r);break;case mi.NORTH:rr(t,e,n,i.northeastChild,o,a,!0,l,r),rr(t,e,n,i.northwestChild,o,a,!0,l,r);break;case mi.NORTHWEST:rr(t,e,n,i.northwestChild,o,a,!0,l,r);break;case mi.NORTHEAST:rr(t,e,n,i.northeastChild,o,a,!0,l,r);break;case mi.SOUTHWEST:rr(t,e,n,i.southwestChild,o,a,!0,l,r);break;case mi.SOUTHEAST:rr(t,e,n,i.southeastChild,o,a,!0,l,r);break;default:throw new Ut("Invalid edge")}}}function DEe(t,e,n,i,o,a,s,l){let r=i.data;if(r.fill===void 0)r.fill=new y1(i);else if(r.fill.visitedFrame===a)return;r.fill.enqueuedFrame!==a&&(r.fill.enqueuedFrame=a,r.fill.changedThisFrame=!1,s.enqueue(i)),OEe(t,e,n,i,o,l)}function OEe(t,e,n,i,o,a){let s=i.data.fill,l,r=n.data.fill;c(r)?(r.visitedFrame=e.frameNumber,r.changedThisFrame&&(O1t(t,e,n,a),r.changedThisFrame=!1),l=n.data.fill.mesh):l=n.data.mesh;let d,m;switch(o){case mi.WEST:d=s.westMeshes,m=s.westTiles;break;case mi.SOUTH:d=s.southMeshes,m=s.southTiles;break;case mi.EAST:d=s.eastMeshes,m=s.eastTiles;break;case mi.NORTH:d=s.northMeshes,m=s.northTiles;break;case mi.NORTHWEST:s.changedThisFrame=s.changedThisFrame||s.northwestMesh!==l,s.northwestMesh=l,s.northwestTile=n;return;case mi.NORTHEAST:s.changedThisFrame=s.changedThisFrame||s.northeastMesh!==l,s.northeastMesh=l,s.northeastTile=n;return;case mi.SOUTHWEST:s.changedThisFrame=s.changedThisFrame||s.southwestMesh!==l,s.southwestMesh=l,s.southwestTile=n;return;case mi.SOUTHEAST:s.changedThisFrame=s.changedThisFrame||s.southeastMesh!==l,s.southeastMesh=l,s.southeastTile=n;return}if(n.level<=i.level){s.changedThisFrame=s.changedThisFrame||d[0]!==l||d.length!==1,d[0]=l,m[0]=n,d.length=1,m.length=1;return}let h,Z,b,u,F=n.rectangle,U,G=i.rectangle;switch(o){case mi.WEST:for(U=(G.north-G.south)*k.EPSILON5,h=0;h<m.length&&(b=m[h],u=b.rectangle,!k.greaterThan(F.north,u.south,U));++h);for(Z=h;Z<m.length&&(b=m[Z],u=b.rectangle,!k.greaterThanOrEquals(F.south,u.north,U));++Z);break;case mi.SOUTH:for(U=(G.east-G.west)*k.EPSILON5,h=0;h<m.length&&(b=m[h],u=b.rectangle,!k.lessThan(F.west,u.east,U));++h);for(Z=h;Z<m.length&&(b=m[Z],u=b.rectangle,!k.lessThanOrEquals(F.east,u.west,U));++Z);break;case mi.EAST:for(U=(G.north-G.south)*k.EPSILON5,h=0;h<m.length&&(b=m[h],u=b.rectangle,!k.lessThan(F.south,u.north,U));++h);for(Z=h;Z<m.length&&(b=m[Z],u=b.rectangle,!k.lessThanOrEquals(F.north,u.south,U));++Z);break;case mi.NORTH:for(U=(G.east-G.west)*k.EPSILON5,h=0;h<m.length&&(b=m[h],u=b.rectangle,!k.greaterThan(F.east,u.west,U));++h);for(Z=h;Z<m.length&&(b=m[Z],u=b.rectangle,!k.greaterThanOrEquals(F.west,u.east,U));++Z);break}Z-h===1?(s.changedThisFrame=s.changedThisFrame||d[h]!==l,d[h]=l,m[h]=n):(s.changedThisFrame=!0,d.splice(h,Z-h,l),m.splice(h,Z-h,n))}var pS=new gt,HEe=new gt,N1=new p,Mot=new p,Xot=new K,Jot=new K,np=new K;function Iz(){this.height=0,this.encodedNormal=new K}function Az(t,e,n,i,o,a,s,l,r){if(c(o))return o;let d;if(c(a)&&c(s))d=(a.height+s.height)*.5;else if(c(a))d=a.height;else if(c(s))d=s.height;else if(c(l))d=l.height;else{let h=t.tile.data.tileBoundingRegion,Z=0,b=0;c(h)&&(Z=h.minimumHeight,b=h.maximumHeight),d=(Z+b)*.5}return H1t(t,e,n,i,d,r),r}var wEe={minimumHeight:0,maximumHeight:0},PEe=new p,X1t=new Iz,J1t=new Iz,L1t=new Iz,M1t=new Iz,vEe=typeof Uint8Array<"u"?new Uint8Array(9*9):void 0,KEe={tilingScheme:void 0,x:0,y:0,level:0,exaggeration:1,exaggerationRelativeHeight:0};function O1t(t,e,n,i){Tu.initialize(n,t.terrainProvider,t._imageryLayers);let o=n.data,a=o.fill,s=n.rectangle,l=e.verticalExaggeration,r=e.verticalExaggerationRelativeHeight,d=l!==1,m=n.tilingScheme.ellipsoid,h=Sz(a,m,0,1,a.northwestTile,a.northwestMesh,a.northTiles,a.northMeshes,a.westTiles,a.westMeshes,L1t),Z=Sz(a,m,0,0,a.southwestTile,a.southwestMesh,a.westTiles,a.westMeshes,a.southTiles,a.southMeshes,X1t),b=Sz(a,m,1,0,a.southeastTile,a.southeastMesh,a.southTiles,a.southMeshes,a.eastTiles,a.eastMeshes,J1t),u=Sz(a,m,1,1,a.northeastTile,a.northeastMesh,a.eastTiles,a.eastMeshes,a.northTiles,a.northMeshes,M1t);h=Az(a,m,0,1,h,Z,u,b,L1t),Z=Az(a,m,0,0,Z,h,b,u,X1t),b=Az(a,m,1,1,b,Z,u,h,J1t),u=Az(a,m,1,1,u,b,h,Z,M1t);let F=Z.height,U=b.height,G=h.height,A=u.height,T=Math.min(F,U,G,A),g=Math.max(F,U,G,A),C=(T+g)*.5,y,Y,Q=t.getLevelMaximumGeometricError(n.level),J=m.maximumRadius-Q,M=Math.acos(J/m.maximumRadius)*4;if(M*=1.5,s.width>M&&g-T<=Q){let I=new Gd({width:9,height:9,buffer:vEe,structure:{heightOffset:g}}),B=KEe;B.tilingScheme=n.tilingScheme,B.x=n.x,B.y=n.y,B.level=n.level,B.exaggeration=l,B.exaggerationRelativeHeight=r,a.mesh=I._createMeshSync(B)}else{let I=d,B=Gt.center(s,HEe);B.height=C;let X=m.cartographicToCartesian(B,PEe),_=new lc(X,void 0,void 0,void 0,void 0,!0,!0,I,l,r),P=5,w;for(w=a.westMeshes,y=0,Y=w.length;y<Y;++y)P+=w[y].eastIndicesNorthToSouth.length;for(w=a.southMeshes,y=0,Y=w.length;y<Y;++y)P+=w[y].northIndicesWestToEast.length;for(w=a.eastMeshes,y=0,Y=w.length;y<Y;++y)P+=w[y].westIndicesSouthToNorth.length;for(w=a.northMeshes,y=0,Y=w.length;y<Y;++y)P+=w[y].southIndicesEastToWest.length;let z=wEe;z.minimumHeight=T,z.maximumHeight=g;let H=_.stride,nt=new Float32Array(P*H),$=0,dt=$;$=Tz(m,s,_,nt,$,0,1,h.height,h.encodedNormal,1,z),$=Ez(a,m,_,nt,$,a.westTiles,a.westMeshes,mi.EAST,z);let q=$;$=Tz(m,s,_,nt,$,0,0,Z.height,Z.encodedNormal,0,z),$=Ez(a,m,_,nt,$,a.southTiles,a.southMeshes,mi.NORTH,z);let at=$;$=Tz(m,s,_,nt,$,1,0,b.height,b.encodedNormal,0,z),$=Ez(a,m,_,nt,$,a.eastTiles,a.eastMeshes,mi.WEST,z);let st=$;$=Tz(m,s,_,nt,$,1,1,u.height,u.encodedNormal,1,z),$=Ez(a,m,_,nt,$,a.northTiles,a.northMeshes,mi.SOUTH,z),T=z.minimumHeight,g=z.maximumHeight;let Et=ci.fromRectangle(s,T,g,n.tilingScheme.ellipsoid),Qt=Yo.geodeticLatitudeToMercatorAngle(s.south),Wt=1/(Yo.geodeticLatitudeToMercatorAngle(s.north)-Qt),Nt=(Yo.geodeticLatitudeToMercatorAngle(B.latitude)-Qt)*Wt,kt=m.geodeticSurfaceNormalCartographic(pS,Mot),Mt=Ni.octEncode(kt,Xot),qt=$;_.encode(nt,$*H,Et.center,K.fromElements(.5,.5,np),C,Mt,Nt,kt),++$;let ie=$,oe=ie<256?1:2,He=(ie-1)*3,rn=He*oe,de=(nt.length-ie*H)*Float32Array.BYTES_PER_ELEMENT,zt;if(de>=rn){let _t=ie*H*Float32Array.BYTES_PER_ELEMENT;zt=ie<256?new Uint8Array(nt.buffer,_t,He):new Uint16Array(nt.buffer,_t,He)}else zt=ie<256?new Uint8Array(He):new Uint16Array(He);nt=new Float32Array(nt.buffer,0,ie*H);let ke=0;for(y=0;y<ie-2;++y)zt[ke++]=qt,zt[ke++]=y,zt[ke++]=y+1;zt[ke++]=qt,zt[ke++]=y,zt[ke++]=0;let ue=[];for(y=q;y>=dt;--y)ue.push(y);let We=[];for(y=at;y>=q;--y)We.push(y);let un=[];for(y=st;y>=at;--y)un.push(y);let Ct=[];for(Ct.push(0),y=qt-1;y>=st;--y)Ct.push(y);a.mesh=new Au(_.center,nt,zt,He,ie,T,g,Ft.fromOrientedBoundingBox(Et),nCe(t,Et.center,s,T,g),_.stride,Et,_,ue,We,un,Ct)}let V=e.context;a._destroyVertexArray(i),a.vertexArray=Tu._createVertexArrayForMesh(V,a.mesh),o.processImagery(n,t.terrainProvider,e,!0);let E=a.waterMaskTexture;if(a.waterMaskTexture=void 0,t.terrainProvider.hasWaterMask){let I=o._findAncestorTileWithTerrainData(n);c(I)&&c(I.data.waterMaskTexture)&&(a.waterMaskTexture=I.data.waterMaskTexture,++a.waterMaskTexture.referenceCount,o._computeWaterMaskTranslationAndScale(n,I,a.waterMaskTranslationAndScale))}c(E)&&(--E.referenceCount,E.referenceCount===0&&E.destroy())}function Tz(t,e,n,i,o,a,s,l,r,d,m){let h=pS;h.longitude=k.lerp(e.west,e.east,a),h.latitude=k.lerp(e.south,e.north,s),h.height=l;let Z=t.cartographicToCartesian(h,N1),b;n.hasGeodeticSurfaceNormals&&(b=t.geodeticSurfaceNormal(Z,Mot));let u=Jot;return u.x=a,u.y=s,n.encode(i,o*n.stride,Z,u,l,r,d,b),m.minimumHeight=Math.min(m.minimumHeight,l),m.maximumHeight=Math.max(m.maximumHeight,l),o+1}var Cz=new Gt;function jM(t,e,n,i){let o=t.rectangle,a=e.rectangle;e.x===0&&n.x===1&&t.x===t.tilingScheme.getNumberOfXTilesAtLevel(t.level)-1?(o=Gt.clone(t.rectangle,Cz),o.west-=k.TWO_PI,o.east-=k.TWO_PI):t.x===0&&n.x===0&&e.x===e.tilingScheme.getNumberOfXTilesAtLevel(e.level)-1&&(o=Gt.clone(t.rectangle,Cz),o.west+=k.TWO_PI,o.east+=k.TWO_PI);let s=o.east-o.west,l=(a.west-o.west)/s,r=(a.east-o.west)/s,d=o.north-o.south,m=(a.south-o.south)/d,h=(a.north-o.south)/d,Z=(n.x-l)/(r-l),b=(n.y-m)/(h-m);return Math.abs(Z)<Math.EPSILON5?Z=0:Math.abs(Z-1)<Math.EPSILON5&&(Z=1),Math.abs(b)<Math.EPSILON5?b=0:Math.abs(b-1)<Math.EPSILON5&&(b=1),i.x=Z,i.y=b,i}var zEe=new K;function Lot(t,e,n,i,o){let a=t.encoding,s=t.vertices;if(o.height=a.decodeHeight(s,e),a.hasVertexNormals)a.getOctEncodedNormal(s,e,o.encodedNormal);else{let l=o.encodedNormal;l.x=0,l.y=0}}var jEe=new K,qEe=new p;function $Ee(t,e,n,i,o,a,s,l,r,d){let m=i.encoding,h=i.vertices,Z=jM(e,n,m.decodeTextureCoordinates(h,o,np),np),b=jM(e,n,m.decodeTextureCoordinates(h,a,Jot),Jot),u;r?u=(s-Z.x)/(b.x-Z.x):u=(l-Z.y)/(b.y-Z.y);let F=m.decodeHeight(h,o),U=m.decodeHeight(h,a),G=n.rectangle;pS.longitude=k.lerp(G.west,G.east,s),pS.latitude=k.lerp(G.south,G.north,l),d.height=pS.height=k.lerp(F,U,u);let A;if(m.hasVertexNormals){let T=m.getOctEncodedNormal(h,o,zEe),g=m.getOctEncodedNormal(h,a,jEe),C=Ni.octDecode(T.x,T.y,N1),y=Ni.octDecode(g.x,g.y,qEe);A=p.lerp(C,y,u,N1),p.normalize(A,A),Ni.octEncode(A,d.encodedNormal)}else A=t.geodeticSurfaceNormalCartographic(pS,N1),Ni.octEncode(A,d.encodedNormal)}function H1t(t,e,n,i,o,a){a.height=o;let s=e.geodeticSurfaceNormalCartographic(pS,N1);Ni.octEncode(s,a.encodedNormal)}function Sz(t,e,n,i,o,a,s,l,r,d,m){if(D1t(t,e,l,s,!1,n,i,m)||D1t(t,e,d,r,!0,n,i,m))return m;let Z;if(_ot(o,a))return n===0?i===0?Z=a.eastIndicesNorthToSouth[0]:Z=a.southIndicesEastToWest[0]:i===0?Z=a.northIndicesWestToEast[0]:Z=a.westIndicesSouthToNorth[0],Lot(a,Z,n,i,m),m;let b;if(n===0?i===0?b=gz(t.westMeshes,t.westTiles,mi.EAST,t.southMeshes,t.southTiles,mi.NORTH,n,i):b=gz(t.northMeshes,t.northTiles,mi.SOUTH,t.westMeshes,t.westTiles,mi.EAST,n,i):i===0?b=gz(t.southMeshes,t.southTiles,mi.NORTH,t.eastMeshes,t.eastTiles,mi.WEST,n,i):b=gz(t.eastMeshes,t.eastTiles,mi.WEST,t.northMeshes,t.northTiles,mi.SOUTH,n,i),c(b))return H1t(t,e,n,i,b,m),m}function gz(t,e,n,i,o,a,s,l){let r=_1t(t,e,!1,n,s,l),d=_1t(i,o,!0,a,s,l);return c(r)&&c(d)?(r+d)*.5:c(r)?r:d}function Ez(t,e,n,i,o,a,s,l,r){for(let d=0;d<a.length;++d)o=tCe(t,e,n,i,o,a[d],s[d],l,r);return o}function tCe(t,e,n,i,o,a,s,l,r){let d=a.rectangle;l===mi.EAST&&t.tile.x===0?(d=Gt.clone(a.rectangle,Cz),d.west-=k.TWO_PI,d.east-=k.TWO_PI):l===mi.WEST&&a.x===0&&(d=Gt.clone(a.rectangle,Cz),d.west+=k.TWO_PI,d.east+=k.TWO_PI);let m=t.tile.rectangle,h,Z;o>0&&(n.decodeTextureCoordinates(i,o-1,np),h=np.x,Z=np.y);let b,u;switch(l){case mi.WEST:b=s.westIndicesSouthToNorth,u=!1;break;case mi.NORTH:b=s.northIndicesWestToEast,u=!0;break;case mi.EAST:b=s.eastIndicesNorthToSouth,u=!1;break;case mi.SOUTH:b=s.southIndicesEastToWest,u=!0;break}let F=a,U=t.tile,G=s.encoding,A=s.vertices,T=n.stride,g,C;G.hasWebMercatorT&&(g=Yo.geodeticLatitudeToMercatorAngle(m.south),C=1/(Yo.geodeticLatitudeToMercatorAngle(m.north)-g));for(let y=0;y<b.length;++y){let Y=b[y],Q=G.decodeTextureCoordinates(A,Y,np);jM(F,U,Q,Q);let J=Q.x,M=Q.y,V=u?J:M;if(V<0||V>1||Math.abs(J-h)<k.EPSILON5&&Math.abs(M-Z)<k.EPSILON5)continue;let E=Math.abs(J)<k.EPSILON5||Math.abs(J-1)<k.EPSILON5,I=Math.abs(M)<k.EPSILON5||Math.abs(M-1)<k.EPSILON5;if(E&&I)continue;let B=G.decodePosition(A,Y,N1),X=G.decodeHeight(A,Y),_;G.hasVertexNormals?_=G.getOctEncodedNormal(A,Y,Xot):(_=Xot,_.x=0,_.y=0);let P=M;if(G.hasWebMercatorT){let z=k.lerp(m.south,m.north,M);P=(Yo.geodeticLatitudeToMercatorAngle(z)-g)*C}let w;n.hasGeodeticSurfaceNormals&&(w=e.geodeticSurfaceNormal(B,Mot)),n.encode(i,o*T,B,Q,X,_,P,w),r.minimumHeight=Math.min(r.minimumHeight,X),r.maximumHeight=Math.max(r.maximumHeight,X),++o}return o}function _1t(t,e,n,i,o,a){let s,l,r;n?(s=0,l=t.length,r=1):(s=t.length-1,l=-1,r=-1);for(let d=s;d!==l;d+=r){let m=t[d],h=e[d];if(!_ot(h,m))continue;let Z;switch(i){case mi.WEST:Z=m.westIndicesSouthToNorth;break;case mi.SOUTH:Z=m.southIndicesEastToWest;break;case mi.EAST:Z=m.eastIndicesNorthToSouth;break;case mi.NORTH:Z=m.northIndicesWestToEast;break}let b=Z[n?0:Z.length-1];if(c(b))return m.encoding.decodeHeight(m.vertices,b)}}function _ot(t,e){return c(e)&&(!c(t.data.fill)||!t.data.fill.changedThisFrame)}function D1t(t,e,n,i,o,a,s,l){let r,d,m,h,Z,b=i[o?0:n.length-1],u=n[o?0:n.length-1];if(_ot(b,u)&&(a===0?s===0?(r=o?u.northIndicesWestToEast:u.eastIndicesNorthToSouth,d=o,m=o):(r=o?u.eastIndicesNorthToSouth:u.southIndicesEastToWest,d=!o,m=!1):s===0?(r=o?u.westIndicesSouthToNorth:u.northIndicesWestToEast,d=!o,m=!0):(r=o?u.southIndicesEastToWest:u.westIndicesSouthToNorth,d=o,m=!o),r.length>0)){h=o?0:r.length-1,Z=r[h],u.encoding.decodeTextureCoordinates(u.vertices,Z,np);let F=jM(b,t.tile,np,np);if(F.x===a&&F.y===s)return Lot(u,Z,a,s,l),!0;if(h=Ja(r,d?a:s,function(U,G){u.encoding.decodeTextureCoordinates(u.vertices,U,np);let A=jM(b,t.tile,np,np);return m?d?A.x-a:A.y-s:d?a-A.x:s-A.y}),h<0){if(h=~h,h>0&&h<r.length)return $Ee(e,b,t.tile,u,r[h-1],r[h],a,s,d,l),!0}else return Lot(u,r[h],a,s,l),!0}return!1}var eCe=[new p,new p,new p,new p];function nCe(t,e,n,i,o,a){let s=t.quadtree._occluders.ellipsoid,l=s.ellipsoid,r=eCe;return p.fromRadians(n.west,n.south,o,l,r[0]),p.fromRadians(n.east,n.south,o,l,r[1]),p.fromRadians(n.west,n.north,o,l,r[2]),p.fromRadians(n.east,n.north,o,l,r[3]),s.computeHorizonCullingPointPossiblyUnderEllipsoid(e,r,i,a)}var B1=y1;function As(t){this.lightingFadeOutDistance=65e5,this.lightingFadeInDistance=9e6,this.hasWaterMask=!1,this.oceanNormalMap=void 0,this.zoomedOutOceanSpecularIntensity=.5,this.enableLighting=!1,this.dynamicAtmosphereLighting=!1,this.dynamicAtmosphereLightingFromSun=!1,this.showGroundAtmosphere=!1,this.shadows=ui.RECEIVE_ONLY,this.vertexShadowDarkness=.3,this.fillHighlightColor=void 0,this.hueShift=0,this.saturationShift=0,this.brightnessShift=0,this.showSkirts=!0,this.backFaceCulling=!0,this.undergroundColor=void 0,this.undergroundColorAlphaByDistance=void 0,this.lambertDiffuseMultiplier=0,this.materialUniformMap=void 0,this._materialUniformMap=void 0,this._quadtree=void 0,this._terrainProvider=t.terrainProvider,this._imageryLayers=t.imageryLayers,this._surfaceShaderSet=t.surfaceShaderSet,this._renderState=void 0,this._blendRenderState=void 0,this._disableCullingRenderState=void 0,this._disableCullingBlendRenderState=void 0,this._errorEvent=new It,this._removeLayerAddedListener=this._imageryLayers.layerAdded.addEventListener(As.prototype._onLayerAdded,this),this._removeLayerRemovedListener=this._imageryLayers.layerRemoved.addEventListener(As.prototype._onLayerRemoved,this),this._removeLayerMovedListener=this._imageryLayers.layerMoved.addEventListener(As.prototype._onLayerMoved,this),this._removeLayerShownListener=this._imageryLayers.layerShownOrHidden.addEventListener(As.prototype._onLayerShownOrHidden,this),this._imageryLayersUpdatedEvent=new It,this._layerOrderChanged=!1,this._tilesToRenderByTextureCount=[],this._drawCommands=[],this._uniformMaps=[],this._usedDrawCommands=0,this._vertexArraysToDestroy=[],this._debug={wireframe:!1,boundingSphereTile:void 0},this._baseColor=void 0,this._firstPassInitialColor=void 0,this.baseColor=new v(0,0,.5,1),this._clippingPlanes=void 0,this._clippingPolygons=void 0,this.cartographicLimitRectangle=Gt.clone(Gt.MAX_VALUE),this._hasLoadedTilesThisFrame=!1,this._hasFillTilesThisFrame=!1,this._oldVerticalExaggeration=void 0,this._oldVerticalExaggerationRelativeHeight=void 0}Object.defineProperties(As.prototype,{baseColor:{get:function(){return this._baseColor},set:function(t){this._baseColor=t,this._firstPassInitialColor=Rt.fromColor(t,this._firstPassInitialColor)}},quadtree:{get:function(){return this._quadtree},set:function(t){this._quadtree=t}},tilingScheme:{get:function(){if(c(this._terrainProvider))return this._terrainProvider.tilingScheme}},errorEvent:{get:function(){return this._errorEvent}},imageryLayersUpdatedEvent:{get:function(){return this._imageryLayersUpdatedEvent}},terrainProvider:{get:function(){return this._terrainProvider},set:function(t){this._terrainProvider!==t&&(this._terrainProvider=t,c(this._quadtree)&&this._quadtree.invalidateAllTiles())}},clippingPlanes:{get:function(){return this._clippingPlanes},set:function(t){Ml.setOwner(t,this,"_clippingPlanes")}},clippingPolygons:{get:function(){return this._clippingPolygons},set:function(t){RZ.setOwner(t,this,"_clippingPolygons")}}});function iCe(t,e){let n=t.loadingImagery;c(n)||(n=t.readyImagery);let i=e.loadingImagery;return c(i)||(i=e.readyImagery),n.imageryLayer._layerIndex-i.imageryLayer._layerIndex}As.prototype.update=function(t){this._imageryLayers._update()};function oCe(t,e){let n=e.creditDisplay,i=t._terrainProvider;c(i)&&c(i.credit)&&n.addCreditToNextFrame(i.credit);let o=t._imageryLayers;for(let a=0,s=o.length;a<s;++a){let l=o.get(a);l.ready&&l.show&&c(l.imageryProvider.credit)&&n.addCreditToNextFrame(l.imageryProvider.credit)}}As.prototype.initialize=function(t){this._imageryLayers.queueReprojectionCommands(t),this._layerOrderChanged&&(this._layerOrderChanged=!1,this._quadtree.forEachLoadedTile(function(i){i.data.imagery.sort(iCe)})),oCe(this,t);let e=this._vertexArraysToDestroy,n=e.length;for(let i=0;i<n;++i)Tu._freeVertexArray(e[i]);e.length=0};As.prototype.beginUpdate=function(t){let e=this._tilesToRenderByTextureCount;for(let o=0,a=e.length;o<a;++o){let s=e[o];c(s)&&(s.length=0)}let n=this._clippingPlanes;c(n)&&n.enabled&&n.update(t);let i=this._clippingPolygons;c(i)&&i.enabled&&(i.update(t),i.queueCommands(t)),this._usedDrawCommands=0,this._hasLoadedTilesThisFrame=!1,this._hasFillTilesThisFrame=!1};As.prototype.endUpdate=function(t){if(!c(this._renderState)){this._renderState=he.fromCache({cull:{enabled:!0},depthTest:{enabled:!0,func:_d.LESS}}),this._blendRenderState=he.fromCache({cull:{enabled:!0},depthTest:{enabled:!0,func:_d.LESS_OR_EQUAL},blending:Pn.ALPHA_BLEND});let s=be(this._renderState,!0);s.cull.enabled=!1,this._disableCullingRenderState=he.fromCache(s),s=be(this._blendRenderState,!0),s.cull.enabled=!1,this._disableCullingBlendRenderState=he.fromCache(s)}this._hasFillTilesThisFrame&&this._hasLoadedTilesThisFrame&&B1.updateFillTiles(this,this._quadtree._tilesToRender,t,this._vertexArraysToDestroy);let e=this.quadtree,n=t.verticalExaggeration,i=t.verticalExaggerationRelativeHeight,o=this._oldVerticalExaggeration!==n||this._oldVerticalExaggerationRelativeHeight!==i;this._oldVerticalExaggeration=n,this._oldVerticalExaggerationRelativeHeight=i,o&&e.forEachLoadedTile(function(s){s.data.updateExaggeration(s,t,e)});let a=this._tilesToRenderByTextureCount;for(let s=0,l=a.length;s<l;++s){let r=a[s];if(c(r))for(let d=0,m=r.length;d<m;++d){let h=r[d],Z=h.data.tileBoundingRegion;ECe(this,h,t),t.minimumTerrainHeight=Math.min(t.minimumTerrainHeight,Z.minimumHeight)}}};function z1t(t,e){let n=e.globeTranslucencyState;if(n.translucent){let i=t.renderState.blending.enabled;n.pushDerivedCommands(t,i,e)}else e.commandList.push(t)}As.prototype.updateForPick=function(t){let e=this._drawCommands;for(let n=0,i=this._usedDrawCommands;n<i;++n)z1t(e[n],t)};As.prototype.cancelReprojections=function(){this._imageryLayers.cancelReprojections()};As.prototype.getLevelMaximumGeometricError=function(t){return c(this._terrainProvider)?this._terrainProvider.getLevelMaximumGeometricError(t):0};As.prototype.loadTile=function(t,e){let n=e.data,i=!0,o;c(n)&&(i=n.boundingVolumeSourceTile!==e||e._lastSelectionResult===Pi.CULLED_BUT_NEEDED,o=n.terrainState),Tu.processStateMachine(e,t,this.terrainProvider,this._imageryLayers,this.quadtree,this._vertexArraysToDestroy,i),n=e.data,i&&o!==e.data.terrainState&&this.computeTileVisibility(e,t,this.quadtree.occluders)!==Ys.NONE&&n.boundingVolumeSourceTile===e&&(i=!1,Tu.processStateMachine(e,t,this.terrainProvider,this._imageryLayers,this.quadtree,this._vertexArraysToDestroy,i))};var aCe=new Ft,j1t=new Gt,sCe=new Gt,lCe=new gt;function yz(t,e){if(e.west<e.east)return e;let n=Gt.clone(e,sCe);return Gt.center(t,lCe).longitude>0?n.east=k.PI:n.west=-k.PI,n}function q1t(t,e){if(e.cameraUnderground||e.globeTranslucencyState.translucent)return!0;if(t.backFaceCulling)return!1;let n=t._clippingPlanes;if(c(n)&&n.enabled)return!0;let i=t._clippingPolygons;return!!(c(i)&&i.enabled||!Gt.equals(t.cartographicLimitRectangle,Gt.MAX_VALUE))}As.prototype.computeTileVisibility=function(t,e,n){let i=this.computeDistanceToTile(t,e);t._distance=i;let o=q1t(this,e);if(e.fog.enabled&&!o&&k.fog(i,e.fog.density)>=1)return Ys.NONE;let a=t.data,s=a.tileBoundingRegion;if(a.boundingVolumeSourceTile===void 0)return Ys.PARTIAL;let l=e.cullingVolume,r=s.boundingVolume;c(r)||(r=s.boundingSphere),a.clippedByBoundaries=!1;let d=yz(t.rectangle,this.cartographicLimitRectangle),m=Gt.simpleIntersection(d,t.rectangle,j1t);if(!c(m))return Ys.NONE;if(Gt.equals(m,t.rectangle)||(a.clippedByBoundaries=!0),e.mode!==ut.SCENE3D&&(r=aCe,Ft.fromRectangleWithHeights2D(t.rectangle,e.mapProjection,s.minimumHeight,s.maximumHeight,r),p.fromElements(r.center.z,r.center.x,r.center.y,r.center),e.mode===ut.MORPHING&&c(a.renderedMesh)&&(r=Ft.union(s.boundingSphere,r,r))),!c(r))return Ys.PARTIAL;let h=this._clippingPlanes;if(c(h)&&h.enabled){let U=h.computeIntersectionWithBoundingVolume(r);if(t.isClipped=U!==yn.INSIDE,U===yn.OUTSIDE)return Ys.NONE}let Z=this._clippingPolygons;if(c(Z)&&Z.enabled){let U=Z.computeIntersectionWithBoundingVolume(s);t.isClipped=U!==yn.OUTSIDE}let b,u=l.computeVisibility(r);if(u===yn.OUTSIDE?b=Ys.NONE:u===yn.INTERSECTING?b=Ys.PARTIAL:u===yn.INSIDE&&(b=Ys.FULL),b===Ys.NONE)return b;let F=e.mode===ut.SCENE3D&&e.camera.frustum instanceof wn;if(e.mode===ut.SCENE3D&&!F&&c(n)&&!o){let U=a.occludeePointInScaledSpace;return!c(U)||n.ellipsoid.isScaledSpacePointVisiblePossiblyUnderEllipsoid(U,s.minimumHeight)?b:Ys.NONE}return b};As.prototype.canRefine=function(t){return c(t.data.terrainData)?!0:this.terrainProvider.getTileDataAvailable(t.x*2,t.y*2,t.level+1)!==void 0};var rCe=[],dCe=[];As.prototype.canRenderWithoutLosingDetail=function(t,e){let n=t.data,i=rCe;i.length=this._imageryLayers.length;let o=!1,a=!1,s;c(n)&&(o=n.terrainState===Ga.READY,a=!0,s=n.imagery);let l,r;for(l=0,r=i.length;l<r;++l)i[l]=a;if(c(s))for(l=0,r=s.length;l<r;++l){let h=s[l],Z=h.loadingImagery,b=!c(Z)||Z.state===ho.FAILED||Z.state===ho.INVALID,u=(h.loadingImagery||h.readyImagery).imageryLayer._layerIndex;i[u]=b&&i[u]}let d=this.quadtree._lastSelectionFrameNumber,m=dCe;for(m.length=0,m.push(t.southwestChild,t.southeastChild,t.northwestChild,t.northeastChild);m.length>0;){let h=m.pop(),Z=h._lastSelectionResultFrame===d?h._lastSelectionResult:Pi.NONE;if(Z===Pi.RENDERED){let b=h.data;if(!c(b))continue;if(!o&&h.data.terrainState===Ga.READY)return!1;let u=h.data.imagery;for(l=0,r=u.length;l<r;++l){let F=u[l],U=F.loadingImagery,G=!c(U)||U.state===ho.FAILED||U.state===ho.INVALID,A=(F.loadingImagery||F.readyImagery).imageryLayer._layerIndex;if(G&&!i[A])return!1}}else Z===Pi.REFINED&&m.push(h.southwestChild,h.southeastChild,h.northwestChild,h.northeastChild)}return!0};var cCe=new p;As.prototype.computeTileLoadPriority=function(t,e){let n=t.data;if(n===void 0)return 0;let i=n.tileBoundingRegion.boundingVolume;if(i===void 0)return 0;let o=e.camera.positionWC,a=e.camera.directionWC,s=p.subtract(i.center,o,cCe),l=p.magnitude(s);return l<k.EPSILON5?0:(p.divideByScalar(s,l,s),(1-p.dot(s,a))*t._distance)};var w1t=new L,Nz=new L,mCe=new Rt,hCe=new Rt,pCe=new Rt,uCe=new p,P1t=new p,ZCe=new p,VCe=new p;As.prototype.showTileThisFrame=function(t,e){let n=0,i=t.data.imagery;for(let l=0,r=i.length;l<r;++l){let d=i[l];c(d.readyImagery)&&d.readyImagery.imageryLayer.alpha!==0&&++n}let o=this._tilesToRenderByTextureCount[n];c(o)||(o=[],this._tilesToRenderByTextureCount[n]=o),o.push(t);let a=t.data;c(a.vertexArray)?this._hasLoadedTilesThisFrame=!0:this._hasFillTilesThisFrame=!0;let s=this._debug;++s.tilesRendered,s.texturesRendered+=n};var bCe=[new p,new p,new p,new p];function v1t(t,e,n,i,o,a){let s=t.quadtree._occluders.ellipsoid,l=s.ellipsoid,r=bCe;return p.fromRadians(n.west,n.south,o,l,r[0]),p.fromRadians(n.east,n.south,o,l,r[1]),p.fromRadians(n.west,n.north,o,l,r[2]),p.fromRadians(n.east,n.north,o,l,r[3]),s.computeHorizonCullingPointPossiblyUnderEllipsoid(e,r,i,a)}As.prototype.computeDistanceToTile=function(t,e){RCe(t,this,e);let n=t.data;if(n.boundingVolumeSourceTile===void 0)return 9999999999;let o=n.tileBoundingRegion,a=o.minimumHeight,s=o.maximumHeight;if(n.boundingVolumeSourceTile!==t){let r=e.camera.positionCartographic.height,d=Math.abs(r-a),m=Math.abs(r-s);d>m?(o.minimumHeight=a,o.maximumHeight=a):(o.minimumHeight=s,o.maximumHeight=s)}let l=o.distanceToCamera(e);return o.minimumHeight=a,o.maximumHeight=s,l};function RCe(t,e,n){let i=t.data;i===void 0&&(i=t.data=new Tu);let o=t.tilingScheme.ellipsoid;i.tileBoundingRegion===void 0&&(i.tileBoundingRegion=new eu({computeBoundingVolumes:!1,rectangle:t.rectangle,ellipsoid:o,minimumHeight:0,maximumHeight:0}));let a=i.tileBoundingRegion,s=a.minimumHeight,l=a.maximumHeight,r=!1,d=t,m=i.mesh,h=i.terrainData;if(m!==void 0&&m.minimumHeight!==void 0&&m.maximumHeight!==void 0)a.minimumHeight=m.minimumHeight,a.maximumHeight=m.maximumHeight,r=!0;else if(h!==void 0&&h._minimumHeight!==void 0&&h._maximumHeight!==void 0)a.minimumHeight=h._minimumHeight,a.maximumHeight=h._maximumHeight;else{a.minimumHeight=Number.NaN,a.maximumHeight=Number.NaN;let Z=t.parent;for(;Z!==void 0;){let b=Z.data;if(b!==void 0){let u=b.mesh,F=b.terrainData;if(u!==void 0&&u.minimumHeight!==void 0&&u.maximumHeight!==void 0){a.minimumHeight=u.minimumHeight,a.maximumHeight=u.maximumHeight;break}else if(F!==void 0&&F._minimumHeight!==void 0&&F._maximumHeight!==void 0){a.minimumHeight=F._minimumHeight,a.maximumHeight=F._maximumHeight;break}}Z=Z.parent}d=Z}if(d!==void 0){let Z=n.verticalExaggeration,b=n.verticalExaggerationRelativeHeight;if(Z!==1&&(r=!1,a.minimumHeight=Ps.getHeight(a.minimumHeight,Z,b),a.maximumHeight=Ps.getHeight(a.maximumHeight,Z,b)),r)i.boundingVolumeIsFromMesh||(a._orientedBoundingBox=ci.clone(m.orientedBoundingBox,a._orientedBoundingBox),a._boundingSphere=Ft.clone(m.boundingSphere3D,a._boundingSphere),i.occludeePointInScaledSpace=p.clone(m.occludeePointInScaledSpace,i.occludeePointInScaledSpace),c(i.occludeePointInScaledSpace)||(i.occludeePointInScaledSpace=v1t(e,a._orientedBoundingBox.center,t.rectangle,a.minimumHeight,a.maximumHeight,i.occludeePointInScaledSpace)));else{let F=a._orientedBoundingBox===void 0||a._boundingSphere===void 0;(a.minimumHeight!==s||a.maximumHeight!==l||F)&&(a.computeBoundingVolumes(o),i.occludeePointInScaledSpace=v1t(e,a._orientedBoundingBox.center,t.rectangle,a.minimumHeight,a.maximumHeight,i.occludeePointInScaledSpace))}i.boundingVolumeSourceTile=d,i.boundingVolumeIsFromMesh=r}else i.boundingVolumeSourceTile=void 0,i.boundingVolumeIsFromMesh=!1}As.prototype.isDestroyed=function(){return!1};As.prototype.destroy=function(){return this._tileProvider=this._tileProvider&&this._tileProvider.destroy(),this._clippingPlanes=this._clippingPlanes&&this._clippingPlanes.destroy(),this._clippingPolygons=this._clippingPolygons&&this._clippingPolygons.destroy(),this._removeLayerAddedListener=this._removeLayerAddedListener&&this._removeLayerAddedListener(),this._removeLayerRemovedListener=this._removeLayerRemovedListener&&this._removeLayerRemovedListener(),this._removeLayerMovedListener=this._removeLayerMovedListener&&this._removeLayerMovedListener(),this._removeLayerShownListener=this._removeLayerShownListener&&this._removeLayerShownListener(),At(this)};function WCe(t,e,n){return function(i){let o,a,s=-1,l=i.data.imagery,r=l.length,d;for(d=0;d<r;++d)if(o=l[d],a=f(o.readyImagery,o.loadingImagery),a.imageryLayer===e){s=d;break}if(s!==-1){let m=s+t;if(o=l[m],a=c(o)?f(o.readyImagery,o.loadingImagery):void 0,!c(a)||a.imageryLayer!==e)return!e._createTileImagerySkeletons(i,n,m);for(d=s;d<m;++d)l[d].freeResources();l.splice(s,t)}return!0}}As.prototype._onLayerAdded=function(t,e){if(!this.isDestroyed()&&t.show){let n=this._terrainProvider,i=this,o=this._imageryLayersUpdatedEvent,a=function(){t._imageryCache={},i._quadtree.forEachLoadedTile(function(s){if(c(s._loadedCallbacks[t._layerIndex]))return;let l,r=s.data.imagery,d=r.length,m=-1,h=0;for(l=0;l<d;++l){let b=r[l];if(f(b.readyImagery,b.loadingImagery).imageryLayer===t)m===-1&&(m=l),++h;else if(m!==-1)break}if(m===-1)return;let Z=m+h;t._createTileImagerySkeletons(s,n,Z)&&(s._loadedCallbacks[t._layerIndex]=WCe(h,t,n),s.state=Br.LOADING)})};if(t.ready){let s=t.imageryProvider;s._reload=a}this._quadtree.forEachLoadedTile(function(s){t._createTileImagerySkeletons(s,n)&&(s.state=Br.LOADING,s.level!==0&&(s._lastSelectionResultFrame!==i.quadtree._lastSelectionFrameNumber||s._lastSelectionResult!==Pi.RENDERED)&&(s.renderable=!1))}),this._layerOrderChanged=!0,o.raiseEvent()}};As.prototype._onLayerRemoved=function(t,e){this._quadtree.forEachLoadedTile(function(n){let i=n.data.imagery,o=-1,a=0;for(let s=0,l=i.length;s<l;++s){let r=i[s],d=r.loadingImagery;if(c(d)||(d=r.readyImagery),d.imageryLayer===t)o===-1&&(o=s),r.freeResources(),++a;else if(o!==-1)break}o!==-1&&i.splice(o,a)}),c(t.imageryProvider)&&(t.imageryProvider._reload=void 0),this._imageryLayersUpdatedEvent.raiseEvent()};As.prototype._onLayerMoved=function(t,e,n){this._layerOrderChanged=!0,this._imageryLayersUpdatedEvent.raiseEvent()};As.prototype._onLayerShownOrHidden=function(t,e,n){n?this._onLayerAdded(t,e):this._onLayerRemoved(t,e)};var fCe=new L,FCe=new L;function K1t(t,e){let n={u_initialColor:function(){return this.properties.initialColor},u_fillHighlightColor:function(){return this.properties.fillHighlightColor},u_zoomedOutOceanSpecularIntensity:function(){return this.properties.zoomedOutOceanSpecularIntensity},u_oceanNormalMap:function(){return this.properties.oceanNormalMap},u_atmosphereLightIntensity:function(){return this.properties.atmosphereLightIntensity},u_atmosphereRayleighCoefficient:function(){return this.properties.atmosphereRayleighCoefficient},u_atmosphereMieCoefficient:function(){return this.properties.atmosphereMieCoefficient},u_atmosphereRayleighScaleHeight:function(){return this.properties.atmosphereRayleighScaleHeight},u_atmosphereMieScaleHeight:function(){return this.properties.atmosphereMieScaleHeight},u_atmosphereMieAnisotropy:function(){return this.properties.atmosphereMieAnisotropy},u_lightingFadeDistance:function(){return this.properties.lightingFadeDistance},u_nightFadeDistance:function(){return this.properties.nightFadeDistance},u_center3D:function(){return this.properties.center3D},u_verticalExaggerationAndRelativeHeight:function(){return this.properties.verticalExaggerationAndRelativeHeight},u_tileRectangle:function(){return this.properties.tileRectangle},u_modifiedModelView:function(){let i=t.context.uniformState.view,o=L.multiplyByPoint(i,this.properties.rtc,P1t);return L.setTranslation(i,o,w1t),w1t},u_modifiedModelViewProjection:function(){let i=t.context.uniformState.view,o=t.context.uniformState.projection,a=L.multiplyByPoint(i,this.properties.rtc,P1t);return L.setTranslation(i,a,Nz),L.multiply(o,Nz,Nz),Nz},u_dayTextures:function(){return this.properties.dayTextures},u_dayTextureTranslationAndScale:function(){return this.properties.dayTextureTranslationAndScale},u_dayTextureTexCoordsRectangle:function(){return this.properties.dayTextureTexCoordsRectangle},u_dayTextureUseWebMercatorT:function(){return this.properties.dayTextureUseWebMercatorT},u_dayTextureAlpha:function(){return this.properties.dayTextureAlpha},u_dayTextureNightAlpha:function(){return this.properties.dayTextureNightAlpha},u_dayTextureDayAlpha:function(){return this.properties.dayTextureDayAlpha},u_dayTextureBrightness:function(){return this.properties.dayTextureBrightness},u_dayTextureContrast:function(){return this.properties.dayTextureContrast},u_dayTextureHue:function(){return this.properties.dayTextureHue},u_dayTextureSaturation:function(){return this.properties.dayTextureSaturation},u_dayTextureOneOverGamma:function(){return this.properties.dayTextureOneOverGamma},u_dayIntensity:function(){return this.properties.dayIntensity},u_southAndNorthLatitude:function(){return this.properties.southAndNorthLatitude},u_southMercatorYAndOneOverHeight:function(){return this.properties.southMercatorYAndOneOverHeight},u_waterMask:function(){return this.properties.waterMask},u_waterMaskTranslationAndScale:function(){return this.properties.waterMaskTranslationAndScale},u_minMaxHeight:function(){return this.properties.minMaxHeight},u_scaleAndBias:function(){return this.properties.scaleAndBias},u_dayTextureSplit:function(){return this.properties.dayTextureSplit},u_dayTextureCutoutRectangles:function(){return this.properties.dayTextureCutoutRectangles},u_clippingPlanes:function(){let i=e._clippingPlanes;return c(i)&&c(i.texture)?i.texture:t.context.defaultTexture},u_cartographicLimitRectangle:function(){return this.properties.localizedCartographicLimitRectangle},u_clippingPlanesMatrix:function(){let i=e._clippingPlanes,o=c(i)?L.multiply(t.context.uniformState.view,i.modelMatrix,fCe):L.IDENTITY;return L.inverseTranspose(o,FCe)},u_clippingPlanesEdgeStyle:function(){let i=this.properties.clippingPlanesEdgeColor;return i.alpha=this.properties.clippingPlanesEdgeWidth,i},u_clippingDistance:function(){let i=e._clippingPolygons.clippingTexture;return c(i)?i:t.context.defaultTexture},u_clippingExtents:function(){let i=e._clippingPolygons.extentsTexture;return c(i)?i:t.context.defaultTexture},u_minimumBrightness:function(){return t.fog.minimumBrightness},u_hsbShift:function(){return this.properties.hsbShift},u_colorsToAlpha:function(){return this.properties.colorsToAlpha},u_frontFaceAlphaByDistance:function(){return this.properties.frontFaceAlphaByDistance},u_backFaceAlphaByDistance:function(){return this.properties.backFaceAlphaByDistance},u_translucencyRectangle:function(){return this.properties.localizedTranslucencyRectangle},u_undergroundColor:function(){return this.properties.undergroundColor},u_undergroundColorAlphaByDistance:function(){return this.properties.undergroundColorAlphaByDistance},u_lambertDiffuseMultiplier:function(){return this.properties.lambertDiffuseMultiplier},u_vertexShadowDarkness:function(){return this.properties.vertexShadowDarkness},properties:{initialColor:new Rt(0,0,.5,1),fillHighlightColor:new v(0,0,0,0),zoomedOutOceanSpecularIntensity:.5,oceanNormalMap:void 0,lightingFadeDistance:new K(65e5,9e6),nightFadeDistance:new K(1e7,4e7),atmosphereLightIntensity:10,atmosphereRayleighCoefficient:new p(55e-7,13e-6,284e-7),atmosphereMieCoefficient:new p(21e-6,21e-6,21e-6),atmosphereRayleighScaleHeight:1e4,atmosphereMieScaleHeight:3200,atmosphereMieAnisotropy:.9,hsbShift:new p,center3D:void 0,rtc:new p,modifiedModelView:new L,tileRectangle:new Rt,verticalExaggerationAndRelativeHeight:new K(1,0),dayTextures:[],dayTextureTranslationAndScale:[],dayTextureTexCoordsRectangle:[],dayTextureUseWebMercatorT:[],dayTextureAlpha:[],dayTextureNightAlpha:[],dayTextureDayAlpha:[],dayTextureBrightness:[],dayTextureContrast:[],dayTextureHue:[],dayTextureSaturation:[],dayTextureOneOverGamma:[],dayTextureSplit:[],dayTextureCutoutRectangles:[],dayIntensity:0,colorsToAlpha:[],southAndNorthLatitude:new K,southMercatorYAndOneOverHeight:new K,waterMask:void 0,waterMaskTranslationAndScale:new Rt,minMaxHeight:new K,scaleAndBias:new L,clippingPlanesEdgeColor:v.clone(v.WHITE),clippingPlanesEdgeWidth:0,localizedCartographicLimitRectangle:new Rt,frontFaceAlphaByDistance:new Rt,backFaceAlphaByDistance:new Rt,localizedTranslucencyRectangle:new Rt,undergroundColor:v.clone(v.TRANSPARENT),undergroundColorAlphaByDistance:new Rt,lambertDiffuseMultiplier:0,vertexShadowDarkness:0}};return c(e.materialUniformMap)?ze(n,e.materialUniformMap):n}function UCe(t,e,n){let i=n.data,o,a;if(c(i.vertexArray)?(o=i.mesh,a=i.vertexArray):c(i.fill)&&c(i.fill.vertexArray)&&(o=i.fill.mesh,a=i.fill.vertexArray),!(!c(o)||!c(a))){if(c(i.wireframeVertexArray)){if(i.wireframeVertexArray.mesh===o)return;i.wireframeVertexArray.destroy(),i.wireframeVertexArray=void 0}i.wireframeVertexArray=GCe(t,a,o),i.wireframeVertexArray.mesh=o}}function GCe(t,e,n){let o={indices:n.indices,primitiveType:le.TRIANGLES};gi.toWireframe(o);let a=o.indices,s=we.createIndexBuffer({context:t,typedArray:a,usage:ce.STATIC_DRAW,indexDatatype:re.fromSizeInBytes(a.BYTES_PER_ELEMENT)});return new Ki({context:t,attributes:e._attributes,indexBuffer:s})}var $1t,tNt,Bz;(function(){let t=new $e({geometry:tZ.fromDimensions({dimensions:new p(2,2,2)})}),e=new $e({geometry:new g0({radius:1})}),n=new L,i,o;function a(s){return new Wi({geometryInstances:s,appearance:new jn({translucent:!1,flat:!0}),asynchronous:!1})}$1t=function(s,l){return s===i||(Bz(),i=s,n=L.fromRotationTranslation(s.halfAxes,s.center,n),t.modelMatrix=n,t.attributes.color=En.fromColor(l),o=a(t)),o},tNt=function(s,l){return s===i||(Bz(),i=s,n=L.fromTranslation(s.center,n),n=L.multiplyByUniformScale(n,s.radius,n),e.modelMatrix=n,e.attributes.color=En.fromColor(l),o=a(e)),o},Bz=function(){c(o)&&(o.destroy(),o=void 0,i=void 0)}})();var ACe=new Rt(0,0,0,0),TCe={frameState:void 0,surfaceTile:void 0,numberOfDayTextures:void 0,applyBrightness:void 0,applyContrast:void 0,applyHue:void 0,applySaturation:void 0,applyGamma:void 0,applyAlpha:void 0,applyDayNightAlpha:void 0,applySplit:void 0,showReflectiveOcean:void 0,showOceanWaves:void 0,enableLighting:void 0,dynamicAtmosphereLighting:void 0,dynamicAtmosphereLightingFromSun:void 0,showGroundAtmosphere:void 0,perFragmentGroundAtmosphere:void 0,hasVertexNormals:void 0,useWebMercatorProjection:void 0,enableFog:void 0,enableClippingPlanes:void 0,clippingPlanes:void 0,enableClippingPolygons:void 0,clippingPolygons:void 0,clippedByBoundaries:void 0,hasImageryLayerCutout:void 0,colorCorrect:void 0,colorToAlpha:void 0,hasGeodeticSurfaceNormals:void 0,hasExaggeration:void 0},SCe=v.TRANSPARENT,gCe=new ln;function ECe(t,e,n){let i=e.data;c(i.vertexArray)||(i.fill===void 0&&(i.fill=new B1(e)),i.fill.update(t,n));let o=n.creditDisplay,a=i.terrainData;if(c(a)&&c(a.credits)){let Ct=a.credits;for(let _t=0,Je=Ct.length;_t<Je;++_t)o.addCreditToNextFrame(Ct[_t])}let s=Sn.maximumTextureImageUnits,l=i.waterMaskTexture,r=i.waterMaskTranslationAndScale;!c(l)&&c(i.fill)&&(l=i.fill.waterMaskTexture,r=i.fill.waterMaskTranslationAndScale);let d=n.cameraUnderground,m=n.globeTranslucencyState,h=m.translucent,Z=m.frontFaceAlphaByDistance,b=m.backFaceAlphaByDistance,u=m.rectangle,F=f(t.undergroundColor,SCe),U=f(t.undergroundColorAlphaByDistance,gCe),G=q1t(t,n)&&n.mode===ut.SCENE3D&&F.alpha>0&&(U.nearValue>0||U.farValue>0),A=t.lambertDiffuseMultiplier,T=t.vertexShadowDarkness,g=t.hasWaterMask&&c(l),C=t.oceanNormalMap,y=g&&c(C),Y=t.terrainProvider,Q=c(Y)&&t.terrainProvider.hasVertexNormals,J=n.fog.enabled&&n.fog.renderable&&!d,M=t.showGroundAtmosphere&&n.mode===ut.SCENE3D,V=ui.castShadows(t.shadows)&&!h,E=ui.receiveShadows(t.shadows)&&!h,I=t.hueShift,B=t.saturationShift,X=t.brightnessShift,_=!(k.equalsEpsilon(I,0,k.EPSILON7)&&k.equalsEpsilon(B,0,k.EPSILON7)&&k.equalsEpsilon(X,0,k.EPSILON7)),P=!1;if(M){let Ct=p.magnitude(n.camera.positionWC),_t=t.nightFadeOutDistance;P=Ct>_t}g&&--s,y&&--s,c(n.shadowState)&&n.shadowState.shadowsEnabled&&--s,c(t.clippingPlanes)&&t.clippingPlanes.enabled&&--s,c(t.clippingPolygons)&&t.clippingPolygons.enabled&&(--s,--s),s-=m.numberOfTextureUniforms;let w=i.renderedMesh,z=w.center,H=w.encoding,nt=i.tileBoundingRegion,$=n.verticalExaggeration,dt=n.verticalExaggerationRelativeHeight,q=$!==1,at=H.hasGeodeticSurfaceNormals,st=mCe,Et=0,Qt=0,Wt=0,Nt=0,kt=!1;if(n.mode!==ut.SCENE3D){let Ct=n.mapProjection,_t=Ct.project(Gt.southwest(e.rectangle),ZCe),Je=Ct.project(Gt.northeast(e.rectangle),VCe);if(st.x=_t.x,st.y=_t.y,st.z=Je.x,st.w=Je.y,n.mode!==ut.MORPHING&&(z=uCe,z.x=0,z.y=(st.z+st.x)*.5,z.z=(st.w+st.y)*.5,st.x-=z.y,st.y-=z.z,st.z-=z.y,st.w-=z.z),n.mode===ut.SCENE2D&&H.quantization===yr.BITS12){let xe=1/(Math.pow(2,12)-1)*.5,oo=(st.z-st.x)*xe,ea=(st.w-st.y)*xe;st.x-=oo,st.y-=ea,st.z+=oo,st.w+=ea}Ct instanceof Yo&&(Et=e.rectangle.south,Qt=e.rectangle.north,Wt=Yo.geodeticLatitudeToMercatorAngle(Et),Nt=1/(Yo.geodeticLatitudeToMercatorAngle(Qt)-Wt),kt=!0)}let Mt=TCe;Mt.frameState=n,Mt.surfaceTile=i,Mt.showReflectiveOcean=g,Mt.showOceanWaves=y,Mt.enableLighting=t.enableLighting,Mt.dynamicAtmosphereLighting=t.dynamicAtmosphereLighting,Mt.dynamicAtmosphereLightingFromSun=t.dynamicAtmosphereLightingFromSun,Mt.showGroundAtmosphere=M,Mt.atmosphereLightIntensity=t.atmosphereLightIntensity,Mt.atmosphereRayleighCoefficient=t.atmosphereRayleighCoefficient,Mt.atmosphereMieCoefficient=t.atmosphereMieCoefficient,Mt.atmosphereRayleighScaleHeight=t.atmosphereRayleighScaleHeight,Mt.atmosphereMieScaleHeight=t.atmosphereMieScaleHeight,Mt.atmosphereMieAnisotropy=t.atmosphereMieAnisotropy,Mt.perFragmentGroundAtmosphere=P,Mt.hasVertexNormals=Q,Mt.useWebMercatorProjection=kt,Mt.clippedByBoundaries=i.clippedByBoundaries,Mt.hasGeodeticSurfaceNormals=at,Mt.hasExaggeration=q;let qt=i.imagery,ie=0,oe=qt.length,He=t.showSkirts&&!d&&!h,rn=t.backFaceCulling&&!d&&!h,de=rn?t._renderState:t._disableCullingRenderState,zt=rn?t._blendRenderState:t._disableCullingBlendRenderState,ke=de,ue=t._firstPassInitialColor,We=n.context;if(c(t._debug.boundingSphereTile)||Bz(),t._materialUniformMap!==t.materialUniformMap){t._materialUniformMap=t.materialUniformMap;let Ct=t._drawCommands.length;for(let _t=0;_t<Ct;++_t)t._uniformMaps[_t]=K1t(n,t)}do{let Ct=0,_t,Je;if(t._drawCommands.length<=t._usedDrawCommands?(_t=new Ee,_t.owner=e,_t.cull=!1,_t.boundingVolume=new Ft,_t.orientedBoundingBox=void 0,Je=K1t(n,t),t._drawCommands.push(_t),t._uniformMaps.push(Je)):(_t=t._drawCommands[t._usedDrawCommands],Je=t._uniformMaps[t._usedDrawCommands]),_t.owner=e,++t._usedDrawCommands,e===t._debug.boundingSphereTile){let zi=nt.boundingVolume,js=nt.boundingSphere;c(zi)?$1t(zi,v.RED).update(n):c(js)&&tNt(js,v.RED).update(n)}let xe=Je.properties;Rt.clone(ue,xe.initialColor),xe.oceanNormalMap=C,xe.lightingFadeDistance.x=t.lightingFadeOutDistance,xe.lightingFadeDistance.y=t.lightingFadeInDistance,xe.nightFadeDistance.x=t.nightFadeOutDistance,xe.nightFadeDistance.y=t.nightFadeInDistance,xe.atmosphereLightIntensity=t.atmosphereLightIntensity,xe.atmosphereRayleighCoefficient=t.atmosphereRayleighCoefficient,xe.atmosphereMieCoefficient=t.atmosphereMieCoefficient,xe.atmosphereRayleighScaleHeight=t.atmosphereRayleighScaleHeight,xe.atmosphereMieScaleHeight=t.atmosphereMieScaleHeight,xe.atmosphereMieAnisotropy=t.atmosphereMieAnisotropy,xe.zoomedOutOceanSpecularIntensity=t.zoomedOutOceanSpecularIntensity;let oo=d?b:Z,ea=d?Z:b;c(oo)&&(Rt.fromElements(oo.near,oo.nearValue,oo.far,oo.farValue,xe.frontFaceAlphaByDistance),Rt.fromElements(ea.near,ea.nearValue,ea.far,ea.farValue,xe.backFaceAlphaByDistance)),Rt.fromElements(U.near,U.nearValue,U.far,U.farValue,xe.undergroundColorAlphaByDistance),v.clone(F,xe.undergroundColor),xe.lambertDiffuseMultiplier=A,xe.vertexShadowDarkness=T;let gs=!c(i.vertexArray)&&c(t.fillHighlightColor)&&t.fillHighlightColor.alpha>0;gs&&v.clone(t.fillHighlightColor,xe.fillHighlightColor),xe.verticalExaggerationAndRelativeHeight.x=$,xe.verticalExaggerationAndRelativeHeight.y=dt,xe.center3D=w.center,p.clone(z,xe.rtc),Rt.clone(st,xe.tileRectangle),xe.southAndNorthLatitude.x=Et,xe.southAndNorthLatitude.y=Qt,xe.southMercatorYAndOneOverHeight.x=Wt,xe.southMercatorYAndOneOverHeight.y=Nt;let is=hCe,ja=yz(e.rectangle,t.cartographicLimitRectangle),qn=pCe,ae=yz(e.rectangle,u);p.fromElements(I,B,X,xe.hsbShift);let fe=e.rectangle,ge=1/fe.width,Ze=1/fe.height;is.x=(ja.west-fe.west)*ge,is.y=(ja.south-fe.south)*Ze,is.z=(ja.east-fe.west)*ge,is.w=(ja.north-fe.south)*Ze,Rt.clone(is,xe.localizedCartographicLimitRectangle),qn.x=(ae.west-fe.west)*ge,qn.y=(ae.south-fe.south)*Ze,qn.z=(ae.east-fe.west)*ge,qn.w=(ae.north-fe.south)*Ze,Rt.clone(qn,xe.localizedTranslucencyRectangle);let Ke=J&&k.fog(e._distance,n.fog.density)>k.EPSILON3;_=_&&(Ke||M);let An=!1,si=!1,da=!1,_a=!1,bl=!1,na=!1,Go=!1,Ao=!1,Xs=!1,Es=!1;for(;Ct<s&&ie<oe;){let zi=qt[ie],js=zi.readyImagery;if(++ie,!c(js)||js.imageryLayer.alpha===0)continue;let ca=zi.useWebMercatorT?js.textureWebMercator:js.texture,$n=js.imageryLayer;c(zi.textureTranslationAndScale)||(zi.textureTranslationAndScale=$n._calculateTextureTranslationAndScale(e,zi)),xe.dayTextures[Ct]=ca,xe.dayTextureTranslationAndScale[Ct]=zi.textureTranslationAndScale,xe.dayTextureTexCoordsRectangle[Ct]=zi.textureCoordinateRectangle,xe.dayTextureUseWebMercatorT[Ct]=zi.useWebMercatorT,xe.dayTextureAlpha[Ct]=$n.alpha,na=na||xe.dayTextureAlpha[Ct]!==1,xe.dayTextureNightAlpha[Ct]=$n.nightAlpha,Go=Go||xe.dayTextureNightAlpha[Ct]!==1,xe.dayTextureDayAlpha[Ct]=$n.dayAlpha,Go=Go||xe.dayTextureDayAlpha[Ct]!==1,xe.dayTextureBrightness[Ct]=$n.brightness,An=An||xe.dayTextureBrightness[Ct]!==$r.DEFAULT_BRIGHTNESS,xe.dayTextureContrast[Ct]=$n.contrast,si=si||xe.dayTextureContrast[Ct]!==$r.DEFAULT_CONTRAST,xe.dayTextureHue[Ct]=$n.hue,da=da||xe.dayTextureHue[Ct]!==$r.DEFAULT_HUE,xe.dayTextureSaturation[Ct]=$n.saturation,_a=_a||xe.dayTextureSaturation[Ct]!==$r.DEFAULT_SATURATION,xe.dayTextureOneOverGamma[Ct]=1/$n.gamma,bl=bl||xe.dayTextureOneOverGamma[Ct]!==1/$r.DEFAULT_GAMMA,xe.dayTextureSplit[Ct]=$n.splitDirection,Ao=Ao||xe.dayTextureSplit[Ct]!==0;let mr=xe.dayTextureCutoutRectangles[Ct];if(c(mr)||(mr=xe.dayTextureCutoutRectangles[Ct]=new Rt),Rt.clone(Rt.ZERO,mr),c($n.cutoutRectangle)){let hs=yz(fe,$n.cutoutRectangle),ma=Gt.simpleIntersection(hs,fe,j1t);Xs=c(ma)||Xs,mr.x=(hs.west-fe.west)*ge,mr.y=(hs.south-fe.south)*Ze,mr.z=(hs.east-fe.west)*ge,mr.w=(hs.north-fe.south)*Ze}let hr=xe.colorsToAlpha[Ct];c(hr)||(hr=xe.colorsToAlpha[Ct]=new Rt);let pr=c($n.colorToAlpha)&&$n.colorToAlphaThreshold>0;if(Es=Es||pr,pr){let hs=$n.colorToAlpha;hr.x=hs.red,hr.y=hs.green,hr.z=hs.blue,hr.w=$n.colorToAlphaThreshold}else hr.w=-1;if(c(js.credits)){let hs=js.credits;for(let ma=0,Ed=hs.length;ma<Ed;++ma)o.addCreditToNextFrame(hs[ma])}++Ct}xe.dayTextures.length=Ct,xe.waterMask=l,Rt.clone(r,xe.waterMaskTranslationAndScale),xe.minMaxHeight.x=H.minimumHeight,xe.minMaxHeight.y=H.maximumHeight,L.clone(H.matrix,xe.scaleAndBias);let wl=t._clippingPlanes,ka=c(wl)&&wl.enabled&&e.isClipped;ka&&(xe.clippingPlanesEdgeColor=v.clone(wl.edgeColor,xe.clippingPlanesEdgeColor),xe.clippingPlanesEdgeWidth=wl.edgeWidth);let Wa=t._clippingPolygons,Ju=c(Wa)&&Wa.enabled&&e.isClipped;Mt.numberOfDayTextures=Ct,Mt.applyBrightness=An,Mt.applyContrast=si,Mt.applyHue=da,Mt.applySaturation=_a,Mt.applyGamma=bl,Mt.applyAlpha=na,Mt.applyDayNightAlpha=Go,Mt.applySplit=Ao,Mt.enableFog=Ke,Mt.enableClippingPlanes=ka,Mt.clippingPlanes=wl,Mt.enableClippingPolygons=Ju,Mt.clippingPolygons=Wa,Mt.hasImageryLayerCutout=Xs,Mt.colorCorrect=_,Mt.highlightFillTile=gs,Mt.colorToAlpha=Es,Mt.showUndergroundColor=G,Mt.translucent=h;let yl=i.renderedMesh.indices.length;He||(yl=i.renderedMesh.indexCountWithoutSkirts),_t.shaderProgram=t._surfaceShaderSet.getShaderProgram(Mt),_t.castShadows=V,_t.receiveShadows=E,_t.renderState=ke,_t.primitiveType=le.TRIANGLES,_t.vertexArray=i.vertexArray||i.fill.vertexArray,_t.count=yl,_t.uniformMap=Je,_t.pass=Pt.GLOBE,t._debug.wireframe&&(UCe(We,t,e),c(i.wireframeVertexArray)&&(_t.vertexArray=i.wireframeVertexArray,_t.primitiveType=le.LINES,_t.count=yl*2));let Bi=_t.boundingVolume,sd=_t.orientedBoundingBox;n.mode!==ut.SCENE3D?(Ft.fromRectangleWithHeights2D(e.rectangle,n.mapProjection,nt.minimumHeight,nt.maximumHeight,Bi),p.fromElements(Bi.center.z,Bi.center.x,Bi.center.y,Bi.center),n.mode===ut.MORPHING&&(Bi=Ft.union(nt.boundingSphere,Bi,Bi))):(_t.boundingVolume=Ft.clone(nt.boundingSphere,Bi),_t.orientedBoundingBox=ci.clone(nt.boundingVolume,sd)),_t.dirty=!0,h&&m.updateDerivedCommands(_t,n),z1t(_t,n),ke=zt,ue=ACe}while(ie<oe)}var qM=As;var KFo=R(W(),1);function eNt(){this._enabled=!1,this._frontFaceAlpha=1,this._frontFaceAlphaByDistance=void 0,this._backFaceAlpha=1,this._backFaceAlphaByDistance=void 0,this._rectangle=Gt.clone(Gt.MAX_VALUE)}Object.defineProperties(eNt.prototype,{enabled:{get:function(){return this._enabled},set:function(t){this._enabled=t}},frontFaceAlpha:{get:function(){return this._frontFaceAlpha},set:function(t){this._frontFaceAlpha=t}},frontFaceAlphaByDistance:{get:function(){return this._frontFaceAlphaByDistance},set:function(t){this._frontFaceAlphaByDistance=ln.clone(t,this._frontFaceAlphaByDistance)}},backFaceAlpha:{get:function(){return this._backFaceAlpha},set:function(t){this._backFaceAlpha=t}},backFaceAlphaByDistance:{get:function(){return this._backFaceAlphaByDistance},set:function(t){this._backFaceAlphaByDistance=ln.clone(t,this._backFaceAlphaByDistance)}},rectangle:{get:function(){return this._rectangle},set:function(t){c(t)||(t=Gt.clone(Gt.MAX_VALUE)),Gt.clone(t,this._rectangle)}}});var $M=eNt;var oUo=R(W(),1);function dr(){this._layers=[],this.layerAdded=new It,this.layerRemoved=new It,this.layerMoved=new It,this.layerShownOrHidden=new It}Object.defineProperties(dr.prototype,{length:{get:function(){return this._layers.length}}});dr.prototype.add=function(t,e){c(e)?this._layers.splice(e,0,t):(e=this._layers.length,this._layers.push(t)),this._update(),this.layerAdded.raiseEvent(t,e);let i=t.readyEvent.addEventListener(()=>{this.layerShownOrHidden.raiseEvent(t,t._layerIndex,t.show),i()})};dr.prototype.addImageryProvider=function(t,e){let n=new $r(t);return this.add(n,e),n};dr.prototype.remove=function(t,e){e=f(e,!0);let n=this._layers.indexOf(t);return n!==-1?(this._layers.splice(n,1),this._update(),this.layerRemoved.raiseEvent(t,n),e&&t.destroy(),!0):!1};dr.prototype.removeAll=function(t){t=f(t,!0);let e=this._layers;for(let n=0,i=e.length;n<i;n++){let o=e[n];this.layerRemoved.raiseEvent(o,n),t&&o.destroy()}this._layers=[]};dr.prototype.contains=function(t){return this.indexOf(t)!==-1};dr.prototype.indexOf=function(t){return this._layers.indexOf(t)};dr.prototype.get=function(t){return this._layers[t]};function Qz(t,e){return t.indexOf(e)}function nNt(t,e,n){let i=t._layers;if(e=k.clamp(e,0,i.length-1),n=k.clamp(n,0,i.length-1),e===n)return;let o=i[e];i[e]=i[n],i[n]=o,t._update(),t.layerMoved.raiseEvent(o,n,e)}dr.prototype.raise=function(t){let e=Qz(this._layers,t);nNt(this,e,e+1)};dr.prototype.lower=function(t){let e=Qz(this._layers,t);nNt(this,e,e-1)};dr.prototype.raiseToTop=function(t){let e=Qz(this._layers,t);e!==this._layers.length-1&&(this._layers.splice(e,1),this._layers.push(t),this._update(),this.layerMoved.raiseEvent(t,this._layers.length-1,e))};dr.prototype.lowerToBottom=function(t){let e=Qz(this._layers,t);e!==0&&(this._layers.splice(e,1),this._layers.splice(0,0,t),this._update(),this.layerMoved.raiseEvent(t,0,e))};var CCe=new Gt;function iNt(t,e,n,i){let o=t.globe._surface._tilesToRender,a;for(let l=0;!c(a)&&l<o.length;++l){let r=o[l];Gt.contains(r.rectangle,e)&&(a=r)}if(!c(a))return;let s=a.data.imagery;for(let l=s.length-1;l>=0;--l){let r=s[l],d=r.readyImagery;if(!c(d)||!d.imageryLayer.ready)continue;let m=d.imageryLayer.imageryProvider;if(n&&!c(m.pickFeatures)||!Gt.contains(d.rectangle,e))continue;let h=CCe,Z=1/1024;h.west=k.lerp(a.rectangle.west,a.rectangle.east,r.textureCoordinateRectangle.x-Z),h.east=k.lerp(a.rectangle.west,a.rectangle.east,r.textureCoordinateRectangle.z+Z),h.south=k.lerp(a.rectangle.south,a.rectangle.north,r.textureCoordinateRectangle.y-Z),h.north=k.lerp(a.rectangle.south,a.rectangle.north,r.textureCoordinateRectangle.w+Z),Gt.contains(h,e)&&i(d)}}dr.prototype.pickImageryLayers=function(t,e){let n=e.globe.pick(t,e);if(!c(n))return;let i=e.globe.ellipsoid.cartesianToCartographic(n),o=[];if(iNt(e,i,!1,function(a){o.push(a.imageryLayer)}),o.length!==0)return o};dr.prototype.pickImageryLayerFeatures=function(t,e){let n=e.globe.pick(t,e);if(!c(n))return;let i=e.globe.ellipsoid.cartesianToCartographic(n),o=[],a=[];if(iNt(e,i,!0,function(s){if(!s.imageryLayer.ready)return;let r=s.imageryLayer.imageryProvider.pickFeatures(s.x,s.y,s.level,i.longitude,i.latitude);c(r)&&(o.push(r),a.push(s.imageryLayer))}),o.length!==0)return Promise.all(o).then(function(s){let l=[];for(let r=0;r<s.length;++r){let d=s[r],m=a[r];if(c(d)&&d.length>0)for(let h=0;h<d.length;++h){let Z=d[h];Z.imageryLayer=m,c(Z.position)||(Z.position=i),l.push(Z)}}return l})};dr.prototype.queueReprojectionCommands=function(t){let e=this._layers;for(let n=0,i=e.length;n<i;++n)e[n].queueReprojectionCommands(t)};dr.prototype.cancelReprojections=function(){let t=this._layers;for(let e=0,n=t.length;e<n;++e)t[e].cancelReprojections()};dr.prototype.isDestroyed=function(){return!1};dr.prototype.destroy=function(){return this.removeAll(!0),At(this)};dr.prototype._update=function(){let t=!0,e=this._layers,n,i,o,a;for(o=0,a=e.length;o<a;++o)i=e[o],i._layerIndex=o,i.show?(i._isBaseLayer=t,t=!1):i._isBaseLayer=!1,i.show!==i._show&&(c(i._show)&&(c(n)||(n=[]),n.push(i)),i._show=i.show);if(c(n))for(o=0,a=n.length;o<a;++o)i=n[o],this.layerShownOrHidden.raiseEvent(i,i._layerIndex,i.show)};var t_=dr;var XUo=R(W(),1);var rUo=R(W(),1);function oNt(t){this._ellipsoid=new BZ(t.ellipsoid,p.ZERO)}Object.defineProperties(oNt.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});var e_=oNt;var uUo=R(W(),1);function tm(t){this._tilingScheme=t.tilingScheme,this._x=t.x,this._y=t.y,this._level=t.level,this._parent=t.parent,this._rectangle=this._tilingScheme.tileXYToRectangle(this._x,this._y,this._level),this._southwestChild=void 0,this._southeastChild=void 0,this._northwestChild=void 0,this._northeastChild=void 0,this.replacementPrevious=void 0,this.replacementNext=void 0,this._distance=0,this._loadPriority=0,this._customData=[],this._frameUpdated=void 0,this._lastSelectionResult=Pi.NONE,this._lastSelectionResultFrame=void 0,this._loadedCallbacks={},this.state=Br.START,this.renderable=!1,this.upsampledFromParent=!1,this.data=void 0}tm.createLevelZeroTiles=function(t){let e=t.getNumberOfXTilesAtLevel(0),n=t.getNumberOfYTilesAtLevel(0),i=new Array(e*n),o=0;for(let a=0;a<n;++a)for(let s=0;s<e;++s)i[o++]=new tm({tilingScheme:t,x:s,y:a,level:0});return i};tm.prototype._updateCustomData=function(t,e,n){let i=this.customData,o,a,s;if(c(e)&&c(n)){for(i=i.filter(function(l){return n.indexOf(l)===-1}),this._customData=i,s=this._rectangle,o=0;o<e.length;++o)a=e[o],Gt.contains(s,a.positionCartographic)&&i.push(a);this._frameUpdated=t}else{let l=this._parent;if(c(l)&&this._frameUpdated!==l._frameUpdated){i.length=0,s=this._rectangle;let r=l.customData;for(o=0;o<r.length;++o)a=r[o],Gt.contains(s,a.positionCartographic)&&i.push(a);this._frameUpdated=l._frameUpdated}}};Object.defineProperties(tm.prototype,{tilingScheme:{get:function(){return this._tilingScheme}},x:{get:function(){return this._x}},y:{get:function(){return this._y}},level:{get:function(){return this._level}},parent:{get:function(){return this._parent}},rectangle:{get:function(){return this._rectangle}},children:{get:function(){return[this.northwestChild,this.northeastChild,this.southwestChild,this.southeastChild]}},southwestChild:{get:function(){return c(this._southwestChild)||(this._southwestChild=new tm({tilingScheme:this.tilingScheme,x:this.x*2,y:this.y*2+1,level:this.level+1,parent:this})),this._southwestChild}},southeastChild:{get:function(){return c(this._southeastChild)||(this._southeastChild=new tm({tilingScheme:this.tilingScheme,x:this.x*2+1,y:this.y*2+1,level:this.level+1,parent:this})),this._southeastChild}},northwestChild:{get:function(){return c(this._northwestChild)||(this._northwestChild=new tm({tilingScheme:this.tilingScheme,x:this.x*2,y:this.y*2,level:this.level+1,parent:this})),this._northwestChild}},northeastChild:{get:function(){return c(this._northeastChild)||(this._northeastChild=new tm({tilingScheme:this.tilingScheme,x:this.x*2+1,y:this.y*2,level:this.level+1,parent:this})),this._northeastChild}},customData:{get:function(){return this._customData}},needsLoading:{get:function(){return this.state<Br.DONE}},eligibleForUnloading:{get:function(){let t=!0;return c(this.data)&&(t=this.data.eligibleForUnloading,c(t)||(t=!0)),t}}});tm.prototype.findLevelZeroTile=function(t,e,n){let i=this.tilingScheme.getNumberOfXTilesAtLevel(0);if(e<0?e+=i:e>=i&&(e-=i),!(n<0||n>=this.tilingScheme.getNumberOfYTilesAtLevel(0)))return t.filter(function(o){return o.x===e&&o.y===n})[0]};tm.prototype.findTileToWest=function(t){let e=this.parent;if(e===void 0)return this.findLevelZeroTile(t,this.x-1,this.y);if(e.southeastChild===this)return e.southwestChild;if(e.northeastChild===this)return e.northwestChild;let n=e.findTileToWest(t);if(n!==void 0)return e.southwestChild===this?n.southeastChild:n.northeastChild};tm.prototype.findTileToEast=function(t){let e=this.parent;if(e===void 0)return this.findLevelZeroTile(t,this.x+1,this.y);if(e.southwestChild===this)return e.southeastChild;if(e.northwestChild===this)return e.northeastChild;let n=e.findTileToEast(t);if(n!==void 0)return e.southeastChild===this?n.southwestChild:n.northwestChild};tm.prototype.findTileToSouth=function(t){let e=this.parent;if(e===void 0)return this.findLevelZeroTile(t,this.x,this.y+1);if(e.northwestChild===this)return e.southwestChild;if(e.northeastChild===this)return e.southeastChild;let n=e.findTileToSouth(t);if(n!==void 0)return e.southwestChild===this?n.northwestChild:n.northeastChild};tm.prototype.findTileToNorth=function(t){let e=this.parent;if(e===void 0)return this.findLevelZeroTile(t,this.x,this.y-1);if(e.southwestChild===this)return e.northwestChild;if(e.southeastChild===this)return e.northeastChild;let n=e.findTileToNorth(t);if(n!==void 0)return e.northwestChild===this?n.southwestChild:n.southeastChild};tm.prototype.freeResources=function(){this.state=Br.START,this.renderable=!1,this.upsampledFromParent=!1,c(this.data)&&c(this.data.freeResources)&&this.data.freeResources(),kz(this._southwestChild),this._southwestChild=void 0,kz(this._southeastChild),this._southeastChild=void 0,kz(this._northwestChild),this._northwestChild=void 0,kz(this._northeastChild),this._northeastChild=void 0};function kz(t){c(t)&&t.freeResources()}var n_=tm;var bUo=R(W(),1);function Yz(){this.head=void 0,this.tail=void 0,this.count=0,this._lastBeforeStartOfFrame=void 0}Yz.prototype.markStartOfRenderFrame=function(){this._lastBeforeStartOfFrame=this.head};Yz.prototype.trimTiles=function(t){let e=this.tail,n=!0;for(;n&&c(this._lastBeforeStartOfFrame)&&this.count>t&&c(e);){n=e!==this._lastBeforeStartOfFrame;let i=e.replacementPrevious;e.eligibleForUnloading&&(e.freeResources(),aNt(this,e)),e=i}};function aNt(t,e){let n=e.replacementPrevious,i=e.replacementNext;e===t._lastBeforeStartOfFrame&&(t._lastBeforeStartOfFrame=i),e===t.head?t.head=i:n.replacementNext=i,e===t.tail?t.tail=n:i.replacementPrevious=n,e.replacementPrevious=void 0,e.replacementNext=void 0,--t.count}Yz.prototype.markTileRendered=function(t){let e=this.head;if(e===t){t===this._lastBeforeStartOfFrame&&(this._lastBeforeStartOfFrame=t.replacementNext);return}if(++this.count,!c(e)){t.replacementPrevious=void 0,t.replacementNext=void 0,this.head=t,this.tail=t;return}(c(t.replacementPrevious)||c(t.replacementNext))&&aNt(this,t),t.replacementPrevious=void 0,t.replacementNext=e,e.replacementPrevious=t,this.head=t};var i_=Yz;function gu(t){this._tileProvider=t.tileProvider,this._tileProvider.quadtree=this,this._debug={enableDebugOutput:!1,maxDepth:0,maxDepthVisited:0,tilesVisited:0,tilesCulled:0,tilesRendered:0,tilesWaitingForChildren:0,lastMaxDepth:-1,lastMaxDepthVisited:-1,lastTilesVisited:-1,lastTilesCulled:-1,lastTilesRendered:-1,lastTilesWaitingForChildren:-1,suspendLodUpdate:!1};let n=this._tileProvider.tilingScheme.ellipsoid;this._tilesToRender=[],this._tileLoadQueueHigh=[],this._tileLoadQueueMedium=[],this._tileLoadQueueLow=[],this._tileReplacementQueue=new i_,this._levelZeroTiles=void 0,this._loadQueueTimeSlice=5,this._tilesInvalidated=!1,this._addHeightCallbacks=[],this._removeHeightCallbacks=[],this._tileToUpdateHeights=[],this._lastTileIndex=0,this._updateHeightsTimeSlice=2,this._cameraPositionCartographic=void 0,this._cameraReferenceFrameOriginCartographic=void 0,this.maximumScreenSpaceError=f(t.maximumScreenSpaceError,2),this.tileCacheSize=f(t.tileCacheSize,100),this.loadingDescendantLimit=20,this.preloadAncestors=!0,this.preloadSiblings=!1,this._occluders=new e_({ellipsoid:n}),this._tileLoadProgressEvent=new It,this._lastTileLoadQueueLength=0,this._lastSelectionFrameNumber=void 0}Object.defineProperties(gu.prototype,{tileProvider:{get:function(){return this._tileProvider}},tileLoadProgressEvent:{get:function(){return this._tileLoadProgressEvent}},occluders:{get:function(){return this._occluders}}});gu.prototype.invalidateAllTiles=function(){this._tilesInvalidated=!0};function ICe(t){let e=t._tileReplacementQueue;e.head=void 0,e.tail=void 0,e.count=0,lNt(t);let n=t._levelZeroTiles;if(c(n))for(let i=0;i<n.length;++i){let a=n[i].customData,s=a.length;for(let l=0;l<s;++l){let r=a[l];r.level=0,t._addHeightCallbacks.push(r)}n[i].freeResources()}t._levelZeroTiles=void 0,t._tileProvider.cancelReprojections()}gu.prototype.forEachLoadedTile=function(t){let e=this._tileReplacementQueue.head;for(;c(e);)e.state!==Br.START&&t(e),e=e.replacementNext};gu.prototype.forEachRenderedTile=function(t){let e=this._tilesToRender;for(let n=0,i=e.length;n<i;++n)t(e[n])};gu.prototype.updateHeight=function(t,e){let n=this,i={positionOnEllipsoidSurface:void 0,positionCartographic:t,level:-1,callback:e};return i.removeFunc=function(){let o=n._addHeightCallbacks,a=o.length;for(let s=0;s<a;++s)if(o[s]===i){o.splice(s,1);break}n._removeHeightCallbacks.push(i),i.callback&&(i.callback=void 0)},n._addHeightCallbacks.push(i),i.removeFunc};gu.prototype.update=function(t){c(this._tileProvider.update)&&this._tileProvider.update(t)};function lNt(t){let e=t._debug;e.maxDepth=0,e.maxDepthVisited=0,e.tilesVisited=0,e.tilesCulled=0,e.tilesRendered=0,e.tilesWaitingForChildren=0,t._tileLoadQueueHigh.length=0,t._tileLoadQueueMedium.length=0,t._tileLoadQueueLow.length=0}gu.prototype.beginFrame=function(t){t.passes.render&&(this._tilesInvalidated&&(ICe(this),this._tilesInvalidated=!1),this._tileProvider.initialize(t),lNt(this),!this._debug.suspendLodUpdate&&this._tileReplacementQueue.markStartOfRenderFrame())};gu.prototype.render=function(t){let e=t.passes,n=this._tileProvider;e.render&&(n.beginUpdate(t),QCe(this,t),OCe(this,t),n.endUpdate(t)),e.pick&&this._tilesToRender.length>0&&n.updateForPick(t)};function NCe(t,e){let n=t._tileLoadQueueHigh.length+t._tileLoadQueueMedium.length+t._tileLoadQueueLow.length;if(n!==t._lastTileLoadQueueLength||t._tilesInvalidated){let o=It.prototype.raiseEvent.bind(t._tileLoadProgressEvent,n);e.afterRender.push(()=>(o(),!0)),t._lastTileLoadQueueLength=n}let i=t._debug;i.enableDebugOutput&&!i.suspendLodUpdate&&(i.maxDepth=t._tilesToRender.reduce(function(o,a){return Math.max(o,a.level)},-1),i.tilesRendered=t._tilesToRender.length,(i.tilesVisited!==i.lastTilesVisited||i.tilesRendered!==i.lastTilesRendered||i.tilesCulled!==i.lastTilesCulled||i.maxDepth!==i.lastMaxDepth||i.tilesWaitingForChildren!==i.lastTilesWaitingForChildren||i.maxDepthVisited!==i.lastMaxDepthVisited)&&(console.log(`Visited ${i.tilesVisited}, Rendered: ${i.tilesRendered}, Culled: ${i.tilesCulled}, Max Depth Rendered: ${i.maxDepth}, Max Depth Visited: ${i.maxDepthVisited}, Waiting for children: ${i.tilesWaitingForChildren}`),i.lastTilesVisited=i.tilesVisited,i.lastTilesRendered=i.tilesRendered,i.lastTilesCulled=i.tilesCulled,i.lastMaxDepth=i.maxDepth,i.lastTilesWaitingForChildren=i.tilesWaitingForChildren,i.lastMaxDepthVisited=i.maxDepthVisited))}gu.prototype.endFrame=function(t){!t.passes.render||t.mode===ut.MORPHING||(LCe(this,t),DCe(this,t),NCe(this,t))};gu.prototype.isDestroyed=function(){return!1};gu.prototype.destroy=function(){this._tileProvider=this._tileProvider&&this._tileProvider.destroy()};var a_,sNt=new gt;function yCe(t,e){let n=Gt.center(t.rectangle,sNt),i=n.longitude-a_.longitude,o=n.latitude-a_.latitude;n=Gt.center(e.rectangle,sNt);let a=n.longitude-a_.longitude,s=n.latitude-a_.latitude;return i*i+o*o-(a*a+s*s)}var BCe=new p,o_=[];function QCe(t,e){let n=t._debug;if(n.suspendLodUpdate)return;let i=t._tilesToRender;i.length=0;let o,a=t._tileProvider;if(!c(t._levelZeroTiles)){let F=a.tilingScheme;if(c(F)){let U=a.tilingScheme;t._levelZeroTiles=n_.createLevelZeroTiles(U);let G=t._levelZeroTiles.length;if(o_.length<G)for(o_=new Array(G),o=0;o<G;++o)o_[o]===void 0&&(o_[o]=new s_)}else return}t._occluders.ellipsoid.cameraPosition=e.camera.positionWC;let s,l=t._levelZeroTiles,r=l.length>1?t._occluders:void 0;a_=e.camera.positionCartographic,l.sort(yCe);let d=t._addHeightCallbacks,m=t._removeHeightCallbacks,h=e.frameNumber,Z;if(d.length>0||m.length>0){for(o=0,Z=l.length;o<Z;++o)s=l[o],s._updateCustomData(h,d,m);d.length=0,m.length=0}let b=e.camera;t._cameraPositionCartographic=b.positionCartographic;let u=L.getTranslation(b.transform,BCe);for(t._cameraReferenceFrameOriginCartographic=t.tileProvider.tilingScheme.ellipsoid.cartesianToCartographic(u,t._cameraReferenceFrameOriginCartographic),o=0,Z=l.length;o<Z;++o)s=l[o],t._tileReplacementQueue.markTileRendered(s),s.renderable?Td(t,s,a,e,r,!1,o_[o]):(uW(t,t._tileLoadQueueHigh,s,e),++n.tilesWaitingForChildren);t._lastSelectionFrameNumber=h}function uW(t,e,n,i){n.needsLoading&&(t.tileProvider.computeTileLoadPriority!==void 0&&(n._loadPriority=t.tileProvider.computeTileLoadPriority(n,i)),e.push(n))}function s_(){this.allAreRenderable=!0,this.anyWereRenderedLastFrame=!1,this.notYetRenderableCount=0}function rNt(){this.southwest=new s_,this.southeast=new s_,this.northwest=new s_,this.northeast=new s_}rNt.prototype.combine=function(t){let e=this.southwest,n=this.southeast,i=this.northwest,o=this.northeast;t.allAreRenderable=e.allAreRenderable&&n.allAreRenderable&&i.allAreRenderable&&o.allAreRenderable,t.anyWereRenderedLastFrame=e.anyWereRenderedLastFrame||n.anyWereRenderedLastFrame||i.anyWereRenderedLastFrame||o.anyWereRenderedLastFrame,t.notYetRenderableCount=e.notYetRenderableCount+n.notYetRenderableCount+i.notYetRenderableCount+o.notYetRenderableCount};var Hot=new Array(31);for(let t=0;t<Hot.length;++t)Hot[t]=new rNt;function kCe(t,e,n,i,o){let a=t._debug;++a.tilesVisited,t._tileReplacementQueue.markTileRendered(n),n._updateCustomData(e.frameNumber),n.level>a.maxDepthVisited&&(a.maxDepthVisited=n.level);let s=XCe(t,e,n)<t.maximumScreenSpaceError,l=n.southwestChild,r=n.southeastChild,d=n.northwestChild,m=n.northeastChild,h=t._lastSelectionFrameNumber,Z=n._lastSelectionResultFrame===h?n._lastSelectionResult:Pi.NONE,b=t.tileProvider;if(s||i){let u=Pi.originalResult(Z)===Pi.RENDERED,F=Pi.originalResult(Z)===Pi.CULLED||Z===Pi.NONE,U=n.state===Br.DONE,G=u||F||U;if(G||c(b.canRenderWithoutLosingDetail)&&(G=b.canRenderWithoutLosingDetail(n)),G){s&&uW(t,t._tileLoadQueueMedium,n,e),xz(t,n),o.allAreRenderable=n.renderable,o.anyWereRenderedLastFrame=Z===Pi.RENDERED,o.notYetRenderableCount=n.renderable?0:1,n._lastSelectionResultFrame=e.frameNumber,n._lastSelectionResult=Pi.RENDERED,o.anyWereRenderedLastFrame||t._tileToUpdateHeights.push(n);return}i=!0,s&&uW(t,t._tileLoadQueueHigh,n,e)}if(b.canRefine(n)){if(l.upsampledFromParent&&r.upsampledFromParent&&d.upsampledFromParent&&m.upsampledFromParent){xz(t,n),uW(t,t._tileLoadQueueMedium,n,e),t._tileReplacementQueue.markTileRendered(l),t._tileReplacementQueue.markTileRendered(r),t._tileReplacementQueue.markTileRendered(d),t._tileReplacementQueue.markTileRendered(m),o.allAreRenderable=n.renderable,o.anyWereRenderedLastFrame=Z===Pi.RENDERED,o.notYetRenderableCount=n.renderable?0:1,n._lastSelectionResultFrame=e.frameNumber,n._lastSelectionResult=Pi.RENDERED,o.anyWereRenderedLastFrame||t._tileToUpdateHeights.push(n);return}n._lastSelectionResultFrame=e.frameNumber,n._lastSelectionResult=Pi.REFINED;let F=t._tilesToRender.length,U=t._tileLoadQueueLow.length,G=t._tileLoadQueueMedium.length,A=t._tileLoadQueueHigh.length,T=t._tileToUpdateHeights.length;if(YCe(t,l,r,d,m,e,i,o),F!==t._tilesToRender.length){let g=o.allAreRenderable,C=o.anyWereRenderedLastFrame,y=o.notYetRenderableCount,Y=!1;if(!g&&!C){let Q=t._tilesToRender;for(let M=F;M<Q.length;++M){let V=Q[M];for(;V!==void 0&&V._lastSelectionResult!==Pi.KICKED&&V!==n;)V._lastSelectionResult=Pi.kick(V._lastSelectionResult),V=V.parent}t._tilesToRender.length=F,t._tileToUpdateHeights.length=T,xz(t,n),n._lastSelectionResult=Pi.RENDERED;let J=Z===Pi.RENDERED;!J&&y>t.loadingDescendantLimit&&(t._tileLoadQueueLow.length=U,t._tileLoadQueueMedium.length=G,t._tileLoadQueueHigh.length=A,uW(t,t._tileLoadQueueMedium,n,e),o.notYetRenderableCount=n.renderable?0:1,Y=!0),o.allAreRenderable=n.renderable,o.anyWereRenderedLastFrame=J,J||t._tileToUpdateHeights.push(n),++a.tilesWaitingForChildren}t.preloadAncestors&&!Y&&uW(t,t._tileLoadQueueLow,n,e)}return}n._lastSelectionResultFrame=e.frameNumber,n._lastSelectionResult=Pi.RENDERED,xz(t,n),uW(t,t._tileLoadQueueHigh,n,e),o.allAreRenderable=n.renderable,o.anyWereRenderedLastFrame=Z===Pi.RENDERED,o.notYetRenderableCount=n.renderable?0:1}function YCe(t,e,n,i,o,a,s,l){let r=a.camera.positionCartographic,d=t._tileProvider,m=t._occluders,h=Hot[e.level],Z=h.southwest,b=h.southeast,u=h.northwest,F=h.northeast;r.longitude<e.rectangle.east?r.latitude<e.rectangle.north?(Td(t,e,d,a,m,s,Z),Td(t,n,d,a,m,s,b),Td(t,i,d,a,m,s,u),Td(t,o,d,a,m,s,F)):(Td(t,i,d,a,m,s,u),Td(t,e,d,a,m,s,Z),Td(t,o,d,a,m,s,F),Td(t,n,d,a,m,s,b)):r.latitude<e.rectangle.north?(Td(t,n,d,a,m,s,b),Td(t,e,d,a,m,s,Z),Td(t,o,d,a,m,s,F),Td(t,i,d,a,m,s,u)):(Td(t,o,d,a,m,s,F),Td(t,i,d,a,m,s,u),Td(t,n,d,a,m,s,b),Td(t,e,d,a,m,s,Z)),h.combine(l)}function xCe(t,e){let n=e.rectangle;return c(t._cameraPositionCartographic)&&Gt.contains(n,t._cameraPositionCartographic)||c(t._cameraReferenceFrameOriginCartographic)&&Gt.contains(n,t._cameraReferenceFrameOriginCartographic)}function Td(t,e,n,i,o,a,s){if(n.computeTileVisibility(e,i,o)!==Ys.NONE)return kCe(t,i,e,a,s);if(++t._debug.tilesCulled,t._tileReplacementQueue.markTileRendered(e),s.allAreRenderable=!0,s.anyWereRenderedLastFrame=!1,s.notYetRenderableCount=0,xCe(t,e)){(!c(e.data)||!c(e.data.vertexArray))&&uW(t,t._tileLoadQueueMedium,e,i);let l=t._lastSelectionFrameNumber,r=e._lastSelectionResultFrame===l?e._lastSelectionResult:Pi.NONE;r!==Pi.CULLED_BUT_NEEDED&&r!==Pi.RENDERED&&t._tileToUpdateHeights.push(e),e._lastSelectionResult=Pi.CULLED_BUT_NEEDED}else t.preloadSiblings||e.level===0?(uW(t,t._tileLoadQueueLow,e,i),e._lastSelectionResult=Pi.CULLED):e._lastSelectionResult=Pi.CULLED;e._lastSelectionResultFrame=i.frameNumber}function XCe(t,e,n){if(e.mode===ut.SCENE2D||e.camera.frustum instanceof wn||e.camera.frustum instanceof el)return JCe(t,e,n);let i=t._tileProvider.getLevelMaximumGeometricError(n.level),o=n._distance,a=e.context.drawingBufferHeight,s=e.camera.frustum.sseDenominator,l=i*a/(o*s);return e.fog.enabled&&(l-=k.fog(o,e.fog.density)*e.fog.sse),l/=e.pixelRatio,l}function JCe(t,e,n){let o=e.camera.frustum,a=o.offCenterFrustum;c(a)&&(o=a);let s=e.context,l=s.drawingBufferWidth,r=s.drawingBufferHeight,d=t._tileProvider.getLevelMaximumGeometricError(n.level),m=Math.max(o.top-o.bottom,o.right-o.left)/Math.max(l,r),h=d/m;return e.fog.enabled&&e.mode!==ut.SCENE2D&&(h-=k.fog(n._distance,e.fog.density)*e.fog.sse),h/=e.pixelRatio,h}function xz(t,e){t._tilesToRender.push(e)}function LCe(t,e){let n=t._tileLoadQueueHigh,i=t._tileLoadQueueMedium,o=t._tileLoadQueueLow;if(n.length===0&&i.length===0&&o.length===0)return;t._tileReplacementQueue.trimTiles(t.tileCacheSize);let a=Oi()+t._loadQueueTimeSlice,s=t._tileProvider,l=Dot(t,e,s,a,n,!1);l=Dot(t,e,s,a,i,l),Dot(t,e,s,a,o,l)}function MCe(t,e){return t._loadPriority-e._loadPriority}function Dot(t,e,n,i,o,a){n.computeTileLoadPriority!==void 0&&o.sort(MCe);for(let s=0,l=o.length;s<l&&(Oi()<i||!a);++s){let r=o[s];t._tileReplacementQueue.markTileRendered(r),n.loadTile(e,r),a=!0}return a}var Q1=new di,Oot=new gt,pU=new p,_Ce=[];function DCe(t,e){if(!c(t.tileProvider.tilingScheme))return;let n=_Ce;n.length=0;let i=t._tileToUpdateHeights,o=Oi(),a=t._updateHeightsTimeSlice,s=o+a,l=e.mode,r=e.mapProjection,d=t.tileProvider.tilingScheme.ellipsoid,m;for(;i.length>0;){let h=i[0];if(!c(h.data)||!c(h.data.mesh)){let F=h._lastSelectionResultFrame===t._lastSelectionFrameNumber?h._lastSelectionResult:Pi.NONE;(F===Pi.RENDERED||F===Pi.CULLED_BUT_NEEDED)&&n.push(h),i.shift(),t._lastTileIndex=0;continue}let Z=h.customData,b=Z.length,u=!1;for(m=t._lastTileIndex;m<b;++m){let F=Z[m],U=h.data.terrainData,G=c(U)&&U.wasCreatedByUpsampling();if(h.level>F.level&&!G){if(c(F.positionOnEllipsoidSurface)||(F.positionOnEllipsoidSurface=p.fromRadians(F.positionCartographic.longitude,F.positionCartographic.latitude,0,d)),l===ut.SCENE3D){let T=d.geodeticSurfaceNormal(F.positionOnEllipsoidSurface,Q1.direction),g=d.getSurfaceNormalIntersectionWithZAxis(F.positionOnEllipsoidSurface,11500,Q1.origin);if(!c(g)){let C=0;c(h.data.tileBoundingRegion)&&(C=h.data.tileBoundingRegion.minimumHeight);let y=Math.min(C,-11500),Y=p.multiplyByScalar(T,Math.abs(y)+1,pU);p.subtract(F.positionOnEllipsoidSurface,Y,Q1.origin)}}else gt.clone(F.positionCartographic,Oot),Oot.height=-11500,r.project(Oot,pU),p.fromElements(pU.z,pU.x,pU.y,pU),p.clone(pU,Q1.origin),p.clone(p.UNIT_X,Q1.direction);let A=h.data.pick(Q1,l,r,!1,pU);c(A)&&(c(F.callback)&&F.callback(A),F.level=h.level)}if(Oi()>=s){u=!0;break}}if(u){t._lastTileIndex=m;break}else t._lastTileIndex=0,i.shift()}for(m=0;m<n.length;m++)i.push(n[m])}function OCe(t,e){let n=t._tileProvider,i=t._tilesToRender;for(let o=0,a=i.length;o<a;++o){let s=i[o];n.showTileThisFrame(s,e)}}var l_=gu;function sV(t){t=f(t,mt.WGS84);let e=new Ru({ellipsoid:t}),n=new t_;this._ellipsoid=t,this._imageryLayerCollection=n,this._surfaceShaderSet=new xM,this._material=void 0,this._surface=new l_({tileProvider:new qM({terrainProvider:e,imageryLayers:n,surfaceShaderSet:this._surfaceShaderSet})}),this._terrainProvider=e,this._terrainProviderChanged=new It,this._undergroundColor=v.clone(v.BLACK),this._undergroundColorAlphaByDistance=new ln(t.maximumRadius/1e3,0,t.maximumRadius/5,1),this._translucency=new $M,Pot(this),this.show=!0,this._oceanNormalMapResourceDirty=!0,this._oceanNormalMapResource=new te({url:Dn("Assets/Textures/waterNormalsSmall.jpg")}),this.maximumScreenSpaceError=2,this.tileCacheSize=100,this.loadingDescendantLimit=20,this.preloadAncestors=!0,this.preloadSiblings=!1,this.fillHighlightColor=void 0,this.enableLighting=!1,this.lambertDiffuseMultiplier=.9,this.dynamicAtmosphereLighting=!0,this.dynamicAtmosphereLightingFromSun=!1,this.showGroundAtmosphere=!0,this.atmosphereLightIntensity=10,this.atmosphereRayleighCoefficient=new p(55e-7,13e-6,284e-7),this.atmosphereMieCoefficient=new p(21e-6,21e-6,21e-6),this.atmosphereRayleighScaleHeight=1e4,this.atmosphereMieScaleHeight=3200,this.atmosphereMieAnisotropy=.9,this.lightingFadeOutDistance=1e7,this.lightingFadeInDistance=2e7,this.nightFadeOutDistance=1e7,this.nightFadeInDistance=5e7,this.showWaterEffect=!0,this.depthTestAgainstTerrain=!1,this.shadows=ui.RECEIVE_ONLY,this.atmosphereHueShift=0,this.atmosphereSaturationShift=0,this.atmosphereBrightnessShift=0,this.showSkirts=!0,this.backFaceCulling=!0,this._oceanNormalMap=void 0,this._zoomedOutOceanSpecularIntensity=void 0,this.vertexShadowDarkness=.3}Object.defineProperties(sV.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},imageryLayers:{get:function(){return this._imageryLayerCollection}},imageryLayersUpdatedEvent:{get:function(){return this._surface.tileProvider.imageryLayersUpdatedEvent}},tilesLoaded:{get:function(){return c(this._surface)?this._surface._tileLoadQueueHigh.length===0&&this._surface._tileLoadQueueMedium.length===0&&this._surface._tileLoadQueueLow.length===0:!0}},baseColor:{get:function(){return this._surface.tileProvider.baseColor},set:function(t){this._surface.tileProvider.baseColor=t}},clippingPlanes:{get:function(){return this._surface.tileProvider.clippingPlanes},set:function(t){this._surface.tileProvider.clippingPlanes=t}},clippingPolygons:{get:function(){return this._surface.tileProvider.clippingPolygons},set:function(t){this._surface.tileProvider.clippingPolygons=t}},cartographicLimitRectangle:{get:function(){return this._surface.tileProvider.cartographicLimitRectangle},set:function(t){c(t)||(t=Gt.clone(Gt.MAX_VALUE)),this._surface.tileProvider.cartographicLimitRectangle=t}},oceanNormalMapUrl:{get:function(){return this._oceanNormalMapResource.url},set:function(t){this._oceanNormalMapResource.url=t,this._oceanNormalMapResourceDirty=!0}},terrainProvider:{get:function(){return this._terrainProvider},set:function(t){t!==this._terrainProvider&&(this._terrainProvider=t,this._terrainProviderChanged.raiseEvent(t),c(this._material)&&Pot(this))}},terrainProviderChanged:{get:function(){return this._terrainProviderChanged}},tileLoadProgressEvent:{get:function(){return this._surface.tileLoadProgressEvent}},material:{get:function(){return this._material},set:function(t){this._material!==t&&(this._material=t,Pot(this))}},undergroundColor:{get:function(){return this._undergroundColor},set:function(t){this._undergroundColor=v.clone(t,this._undergroundColor)}},undergroundColorAlphaByDistance:{get:function(){return this._undergroundColorAlphaByDistance},set:function(t){this._undergroundColorAlphaByDistance=ln.clone(t,this._undergroundColorAlphaByDistance)}},translucency:{get:function(){return this._translucency}}});function Pot(t){let e=[],n=c(t._material)&&(c(t._material.shaderSource.match(/slope/))||c(t._material.shaderSource.match("normalEC"))),i=[rW,W1];c(t._material)&&(!n||t._terrainProvider.requestVertexNormals)?(i.push(t._material.shaderSource),e.push("APPLY_MATERIAL"),t._surface._tileProvider.materialUniformMap=t._material._uniforms):t._surface._tileProvider.materialUniformMap=void 0,i.push(kM),t._surfaceShaderSet.baseVertexShaderSource=new Ve({sources:[rW,W1,YM],defines:e}),t._surfaceShaderSet.baseFragmentShaderSource=new Ve({sources:i,defines:e}),t._surfaceShaderSet.material=t._material}function HCe(t){return function(e,n){let i=Ft.distanceSquaredTo(e.pickBoundingSphere,t),o=Ft.distanceSquaredTo(n.pickBoundingSphere,t);return i-o}}var wCe=[],PCe={start:0,stop:0};sV.prototype.pickWorldCoordinates=function(t,e,n,i){n=f(n,!0);let o=e.mode,a=e.mapProjection,s=wCe;s.length=0;let l=this._surface._tilesToRender,r=l.length,d,m;for(m=0;m<r;++m){d=l[m];let Z=d.data;if(!c(Z))continue;let b=Z.pickBoundingSphere;if(o!==ut.SCENE3D)Z.pickBoundingSphere=b=Ft.fromRectangleWithHeights2D(d.rectangle,a,Z.tileBoundingRegion.minimumHeight,Z.tileBoundingRegion.maximumHeight,b),p.fromElements(b.center.z,b.center.x,b.center.y,b.center);else if(c(Z.renderedMesh))Ft.clone(Z.tileBoundingRegion.boundingSphere,b);else continue;let u=no.raySphere(t,b,PCe);c(u)&&s.push(Z)}s.sort(HCe(t.origin));let h;for(r=s.length,m=0;m<r&&(h=s[m].pick(t,e.mode,e.mapProjection,n,i),!c(h));++m);return h};var vCe=new gt;sV.prototype.pick=function(t,e,n){if(n=this.pickWorldCoordinates(t,e,!0,n),c(n)&&e.mode!==ut.SCENE3D){n=p.fromElements(n.y,n.z,n.x,n);let i=e.mapProjection.unproject(n,vCe);n=e.globe.ellipsoid.cartographicToCartesian(i,n)}return n};var KCe=new p,dNt=new p,zCe=new gt,jCe=new di;function wot(t,e){return c(t)&&Gt.contains(t.rectangle,e)?t:void 0}sV.prototype.getHeight=function(t){let e=this._surface._levelZeroTiles;if(!c(e))return;let n,i,o=e.length;for(i=0;i<o&&(n=e[i],!Gt.contains(n.rectangle,t));++i);if(i>=o)return;let a=n;for(;c(n);)n=wot(n._southwestChild,t)||wot(n._southeastChild,t)||wot(n._northwestChild,t)||n._northeastChild,c(n)&&c(n.data)&&c(n.data.renderedMesh)&&(a=n);if(n=a,!c(n)||!c(n.data)||!c(n.data.renderedMesh))return;let s=this._surface._tileProvider.tilingScheme.projection,l=this._surface._tileProvider.tilingScheme.ellipsoid,r=p.fromRadians(t.longitude,t.latitude,0,l,KCe),d=jCe,m=l.geodeticSurfaceNormal(r,d.direction),h=l.getSurfaceNormalIntersectionWithZAxis(r,11500,d.origin);if(!c(h)){let b;c(n.data.tileBoundingRegion)&&(b=n.data.tileBoundingRegion.minimumHeight);let u=Math.min(f(b,0),-11500),F=p.multiplyByScalar(m,Math.abs(u)+1,dNt);p.subtract(r,F,d.origin)}let Z=n.data.pick(d,void 0,s,!1,dNt);if(c(Z))return l.cartesianToCartographic(Z,zCe).height};sV.prototype.update=function(t){this.show&&t.passes.render&&this._surface.update(t)};sV.prototype.beginFrame=function(t){let e=this._surface,n=e.tileProvider,i=this.terrainProvider,o=this.showWaterEffect&&c(i)&&i.hasWaterMask&&i.hasWaterMask;if(o&&this._oceanNormalMapResourceDirty){this._oceanNormalMapResourceDirty=!1;let l=this._oceanNormalMapResource,r=l.url;if(c(r)){let d=this;l.fetchImage().then(function(m){r===d._oceanNormalMapResource.url&&(d._oceanNormalMap=d._oceanNormalMap&&d._oceanNormalMap.destroy(),d._oceanNormalMap=new hn({context:t.context,source:m}))})}else this._oceanNormalMap=this._oceanNormalMap&&this._oceanNormalMap.destroy()}let a=t.passes,s=t.mode;a.render&&(this.showGroundAtmosphere?this._zoomedOutOceanSpecularIntensity=.4:this._zoomedOutOceanSpecularIntensity=.5,e.maximumScreenSpaceError=this.maximumScreenSpaceError,e.tileCacheSize=this.tileCacheSize,e.loadingDescendantLimit=this.loadingDescendantLimit,e.preloadAncestors=this.preloadAncestors,e.preloadSiblings=this.preloadSiblings,n.terrainProvider=this.terrainProvider,n.lightingFadeOutDistance=this.lightingFadeOutDistance,n.lightingFadeInDistance=this.lightingFadeInDistance,n.nightFadeOutDistance=this.nightFadeOutDistance,n.nightFadeInDistance=this.nightFadeInDistance,n.zoomedOutOceanSpecularIntensity=s===ut.SCENE3D?this._zoomedOutOceanSpecularIntensity:0,n.hasWaterMask=o,n.oceanNormalMap=this._oceanNormalMap,n.enableLighting=this.enableLighting,n.dynamicAtmosphereLighting=this.dynamicAtmosphereLighting,n.dynamicAtmosphereLightingFromSun=this.dynamicAtmosphereLightingFromSun,n.showGroundAtmosphere=this.showGroundAtmosphere,n.atmosphereLightIntensity=this.atmosphereLightIntensity,n.atmosphereRayleighCoefficient=this.atmosphereRayleighCoefficient,n.atmosphereMieCoefficient=this.atmosphereMieCoefficient,n.atmosphereRayleighScaleHeight=this.atmosphereRayleighScaleHeight,n.atmosphereMieScaleHeight=this.atmosphereMieScaleHeight,n.atmosphereMieAnisotropy=this.atmosphereMieAnisotropy,n.shadows=this.shadows,n.hueShift=this.atmosphereHueShift,n.saturationShift=this.atmosphereSaturationShift,n.brightnessShift=this.atmosphereBrightnessShift,n.fillHighlightColor=this.fillHighlightColor,n.showSkirts=this.showSkirts,n.backFaceCulling=this.backFaceCulling,n.vertexShadowDarkness=this.vertexShadowDarkness,n.undergroundColor=this._undergroundColor,n.undergroundColorAlphaByDistance=this._undergroundColorAlphaByDistance,n.lambertDiffuseMultiplier=this.lambertDiffuseMultiplier,e.beginFrame(t))};sV.prototype.render=function(t){this.show&&(c(this._material)&&this._material.update(t.context),this._surface.render(t))};sV.prototype.endFrame=function(t){this.show&&t.passes.render&&this._surface.endFrame(t)};sV.prototype.isDestroyed=function(){return!1};sV.prototype.destroy=function(){return this._surfaceShaderSet=this._surfaceShaderSet&&this._surfaceShaderSet.destroy(),this._surface=this._surface&&this._surface.destroy(),this._oceanNormalMap=this._oceanNormalMap&&this._oceanNormalMap.destroy(),At(this)};var r_=sV;var UAo=R(W(),1);var BGo=R(W(),1);var AGo=R(W(),1);var bGo=R(W(),1);function qCe(t,e,n,i){this.rightAscension=t,this.declination=e,this.rotation=n,this.rotationRate=i}var d_=qCe;var GNt={},$Ce=32.184,tIe=2451545,cNt=-.0529921,mNt=-.1059842,hNt=13.0120009,pNt=13.3407154,uNt=.9856003,ZNt=26.4057084,VNt=13.064993,bNt=.3287146,RNt=1.7484877,WNt=-.1589763,fNt=.0036096,FNt=.1643573,UNt=12.9590088,vot=new rt;GNt.ComputeMoon=function(t,e){c(t)||(t=rt.now()),vot=rt.addSeconds(t,$Ce,vot);let n=rt.totalDays(vot)-tIe,i=n/xi.DAYS_PER_JULIAN_CENTURY,o=(125.045+cNt*n)*k.RADIANS_PER_DEGREE,a=(250.089+mNt*n)*k.RADIANS_PER_DEGREE,s=(260.008+hNt*n)*k.RADIANS_PER_DEGREE,l=(176.625+pNt*n)*k.RADIANS_PER_DEGREE,r=(357.529+uNt*n)*k.RADIANS_PER_DEGREE,d=(311.589+ZNt*n)*k.RADIANS_PER_DEGREE,m=(134.963+VNt*n)*k.RADIANS_PER_DEGREE,h=(276.617+bNt*n)*k.RADIANS_PER_DEGREE,Z=(34.226+RNt*n)*k.RADIANS_PER_DEGREE,b=(15.134+WNt*n)*k.RADIANS_PER_DEGREE,u=(119.743+fNt*n)*k.RADIANS_PER_DEGREE,F=(239.961+FNt*n)*k.RADIANS_PER_DEGREE,U=(25.053+UNt*n)*k.RADIANS_PER_DEGREE,G=Math.sin(o),A=Math.sin(a),T=Math.sin(s),g=Math.sin(l),C=Math.sin(r),y=Math.sin(d),Y=Math.sin(m),Q=Math.sin(h),J=Math.sin(Z),M=Math.sin(b),V=Math.sin(u),E=Math.sin(F),I=Math.sin(U),B=Math.cos(o),X=Math.cos(a),_=Math.cos(s),P=Math.cos(l),w=Math.cos(r),z=Math.cos(d),H=Math.cos(m),nt=Math.cos(h),$=Math.cos(Z),dt=Math.cos(b),q=Math.cos(u),at=Math.cos(F),st=Math.cos(U),Et=(269.9949+.0031*i-3.8787*G-.1204*A+.07*T-.0172*g+.0072*y-.0052*M+.0043*I)*k.RADIANS_PER_DEGREE,Qt=(66.5392+.013*i+1.5419*B+.0239*X-.0278*_+.0068*P-.0029*z+9e-4*H+8e-4*dt-9e-4*st)*k.RADIANS_PER_DEGREE,Wt=(38.3213+13.17635815*n-14e-13*n*n+3.561*G+.1208*A-.0642*T+.0158*g+.0252*C-.0066*y-.0047*Y-.0046*Q+.0028*J+.0052*M+.004*V+.0019*E-.0044*I)*k.RADIANS_PER_DEGREE,Nt=(13.17635815-14e-13*(2*n)+3.561*B*cNt+.1208*X*mNt-.0642*_*hNt+.0158*P*pNt+.0252*w*uNt-.0066*z*ZNt-.0047*H*VNt-.0046*nt*bNt+.0028*$*RNt+.0052*dt*WNt+.004*q*fNt+.0019*at*FNt-.0044*st*UNt)/86400*k.RADIANS_PER_DEGREE;return c(e)||(e=new d_),e.rightAscension=Et,e.declination=Qt,e.rotation=Wt,e.rotationRate=Nt,e};var c_=GNt;function ANt(t){(!c(t)||typeof t!="function")&&(t=c_.ComputeMoon),this._computeFunction=t}var eIe=new p,nIe=new p,iIe=new p;function oIe(t,e,n){let i=eIe;i.x=Math.cos(t+k.PI_OVER_TWO),i.y=Math.sin(t+k.PI_OVER_TWO),i.z=0;let o=Math.cos(e),a=iIe;a.x=o*Math.cos(t),a.y=o*Math.sin(t),a.z=Math.sin(e);let s=p.cross(a,i,nIe);return c(n)||(n=new ot),n[0]=i.x,n[1]=s.x,n[2]=a.x,n[3]=i.y,n[4]=s.y,n[5]=a.y,n[6]=i.z,n[7]=s.z,n[8]=a.z,n}var aIe=new ot,sIe=new wt;ANt.prototype.evaluate=function(t,e){c(t)||(t=rt.now());let n=this._computeFunction(t),i=oIe(n.rightAscension,n.declination,e),o=k.zeroToTwoPi(n.rotation),a=wt.fromAxisAngle(p.UNIT_Z,o,sIe),s=ot.fromQuaternion(wt.conjugate(a,a),aIe);return ot.multiply(s,i,i)};var m_=ANt;var lAo=R(W(),1);var kGo=R(W(),1),k1=`uniform vec3 u_radii; +`;var gWo=b(W(),1);function E1(t,e,n,i,o){if(this.imageryLayer=t,this.x=e,this.y=n,this.level=i,this.request=void 0,i!==0){let a=e/2|0,s=n/2|0,l=i-1;this.parent=t.getImageryFromCache(a,s,l)}this.state=ho.UNLOADED,this.imageUrl=void 0,this.image=void 0,this.texture=void 0,this.textureWebMercator=void 0,this.credits=void 0,this.referenceCount=0,!c(o)&&t.ready&&(o=t.imageryProvider.tilingScheme.tileXYToRectangle(e,n,i)),this.rectangle=o}E1.createPlaceholder=function(t){let e=new E1(t,0,0,0);return e.addReference(),e.state=ho.PLACEHOLDER,e};E1.prototype.addReference=function(){++this.referenceCount};E1.prototype.releaseReference=function(){return--this.referenceCount,this.referenceCount===0?(this.imageryLayer.removeImageryFromCache(this),c(this.parent)&&this.parent.releaseReference(),c(this.image)&&c(this.image.destroy)&&this.image.destroy(),c(this.texture)&&this.texture.destroy(),c(this.textureWebMercator)&&this.texture!==this.textureWebMercator&&this.textureWebMercator.destroy(),At(this),0):this.referenceCount};E1.prototype.processStateMachine=function(t,e,n){this.state===ho.UNLOADED&&!n&&(this.state=ho.TRANSITIONING,this.imageryLayer._requestImagery(this)),this.state===ho.RECEIVED&&(this.state=ho.TRANSITIONING,this.imageryLayer._createTexture(t.context,this));let i=this.state===ho.READY&&e&&!this.texture;(this.state===ho.TEXTURE_LOADED||i)&&(this.state=ho.TRANSITIONING,this.imageryLayer._reprojectTexture(t,this,e))};var C1=E1;var NWo=b(W(),1);function Yot(t,e,n){this.readyImagery=void 0,this.loadingImagery=t,this.textureCoordinateRectangle=e,this.textureTranslationAndScale=void 0,this.useWebMercatorT=n}Yot.prototype.freeResources=function(){c(this.readyImagery)&&this.readyImagery.releaseReference(),c(this.loadingImagery)&&this.loadingImagery.releaseReference()};Yot.prototype.processStateMachine=function(t,e,n){let i=this.loadingImagery,o=i.imageryLayer;if(i.processStateMachine(e,!this.useWebMercatorT,n),i.state===ho.READY)return c(this.readyImagery)&&this.readyImagery.releaseReference(),this.readyImagery=this.loadingImagery,this.loadingImagery=void 0,this.textureTranslationAndScale=o._calculateTextureTranslationAndScale(t,this),!0;let a=i.parent,s;for(;c(a)&&(a.state!==ho.READY||!this.useWebMercatorT&&!c(a.texture));)a.state!==ho.FAILED&&a.state!==ho.INVALID&&(s=s||a),a=a.parent;return this.readyImagery!==a&&(c(this.readyImagery)&&this.readyImagery.releaseReference(),this.readyImagery=a,c(a)&&(a.addReference(),this.textureTranslationAndScale=o._calculateTextureTranslationAndScale(t,this))),i.state===ho.FAILED||i.state===ho.INVALID?c(s)?(s.processStateMachine(e,!this.useWebMercatorT,n),!1):!0:!1};var I1=Yot;function Uo(t,e){this._imageryProvider=t,this._readyEvent=new It,this._errorEvent=new It,e=f(e,f.EMPTY_OBJECT),t=f(t,f.EMPTY_OBJECT),this.alpha=f(e.alpha,f(t._defaultAlpha,1)),this.nightAlpha=f(e.nightAlpha,f(t._defaultNightAlpha,1)),this.dayAlpha=f(e.dayAlpha,f(t._defaultDayAlpha,1)),this.brightness=f(e.brightness,f(t._defaultBrightness,Uo.DEFAULT_BRIGHTNESS)),this.contrast=f(e.contrast,f(t._defaultContrast,Uo.DEFAULT_CONTRAST)),this.hue=f(e.hue,f(t._defaultHue,Uo.DEFAULT_HUE)),this.saturation=f(e.saturation,f(t._defaultSaturation,Uo.DEFAULT_SATURATION)),this.gamma=f(e.gamma,f(t._defaultGamma,Uo.DEFAULT_GAMMA)),this.splitDirection=f(e.splitDirection,Uo.DEFAULT_SPLIT),this.minificationFilter=f(e.minificationFilter,f(t._defaultMinificationFilter,Uo.DEFAULT_MINIFICATION_FILTER)),this.magnificationFilter=f(e.magnificationFilter,f(t._defaultMagnificationFilter,Uo.DEFAULT_MAGNIFICATION_FILTER)),this.show=f(e.show,!0),this._minimumTerrainLevel=e.minimumTerrainLevel,this._maximumTerrainLevel=e.maximumTerrainLevel,this._rectangle=f(e.rectangle,Gt.MAX_VALUE),this._maximumAnisotropy=e.maximumAnisotropy,this._imageryCache={},this._skeletonPlaceholder=new I1(C1.createPlaceholder(this)),this._show=!0,this._layerIndex=-1,this._isBaseLayer=!1,this._requestImageError=void 0,this._reprojectComputeCommands=[],this.cutoutRectangle=e.cutoutRectangle,this.colorToAlpha=e.colorToAlpha,this.colorToAlphaThreshold=f(e.colorToAlphaThreshold,Uo.DEFAULT_APPLY_COLOR_TO_ALPHA_THRESHOLD)}Object.defineProperties(Uo.prototype,{imageryProvider:{get:function(){return this._imageryProvider}},ready:{get:function(){return c(this._imageryProvider)}},errorEvent:{get:function(){return this._errorEvent}},readyEvent:{get:function(){return this._readyEvent}},rectangle:{get:function(){return this._rectangle}}});Uo.DEFAULT_BRIGHTNESS=1;Uo.DEFAULT_CONTRAST=1;Uo.DEFAULT_HUE=0;Uo.DEFAULT_SATURATION=1;Uo.DEFAULT_GAMMA=1;Uo.DEFAULT_SPLIT=Jc.NONE;Uo.DEFAULT_MINIFICATION_FILTER=On.LINEAR;Uo.DEFAULT_MAGNIFICATION_FILTER=Ro.LINEAR;Uo.DEFAULT_APPLY_COLOR_TO_ALPHA_THRESHOLD=.004;Uo.fromProviderAsync=function(t,e){let n=new Uo(void 0,e);return LEe(n,Promise.resolve(t)),n};Uo.fromWorldImagery=function(t){return t=f(t,f.EMPTY_OBJECT),Uo.fromProviderAsync(pW({style:t.style}),t)};Uo.prototype.isBaseLayer=function(){return this._isBaseLayer};Uo.prototype.isDestroyed=function(){return!1};Uo.prototype.destroy=function(){return At(this)};var Q1t=new Gt,y1t=new Gt,xot=new Gt,k1t=new Gt;Uo.prototype.getImageryRectangle=function(){let t=this._imageryProvider,e=this._rectangle;return Gt.intersection(t.rectangle,e)};Uo.prototype._createTileImagerySkeletons=function(t,e,n){let i=t.data;if(!c(e)||c(this._minimumTerrainLevel)&&t.level<this._minimumTerrainLevel||c(this._maximumTerrainLevel)&&t.level>this._maximumTerrainLevel)return!1;c(n)||(n=i.imagery.length);let o=this._imageryProvider;if(!this.ready)return this._skeletonPlaceholder.loadingImagery.addReference(),i.imagery.splice(n,0,this._skeletonPlaceholder),!0;let a=o.tilingScheme.projection instanceof Yo&&t.rectangle.north<Yo.MaximumLatitude&&t.rectangle.south>-Yo.MaximumLatitude,s=Gt.intersection(o.rectangle,this._rectangle,Q1t),l=Gt.intersection(t.rectangle,s,y1t);if(!c(l)){if(!this.isBaseLayer())return!1;let I=s,B=t.rectangle;l=y1t,B.south>=I.north?l.north=l.south=I.north:B.north<=I.south?l.north=l.south=I.south:(l.south=Math.max(B.south,I.south),l.north=Math.min(B.north,I.north)),B.west>=I.east?l.west=l.east=I.east:B.east<=I.west?l.west=l.east=I.west:(l.west=Math.max(B.west,I.west),l.east=Math.min(B.east,I.east))}let r=0;l.south>0?r=l.south:l.north<0&&(r=l.north);let m=1*e.getLevelMaximumGeometricError(t.level),h=XEe(this,m,r);h=Math.max(0,h);let u=o.maximumLevel;if(h>u&&(h=u),c(o.minimumLevel)){let I=o.minimumLevel;h<I&&(h=I)}let R=o.tilingScheme,V=R.positionToTileXY(Gt.northwest(l),h),F=R.positionToTileXY(Gt.southeast(l),h),U=t.rectangle.width/512,G=t.rectangle.height/512,A=R.tileXYToRectangle(V.x,V.y,h);Math.abs(A.south-t.rectangle.north)<G&&V.y<F.y&&++V.y,Math.abs(A.east-t.rectangle.west)<U&&V.x<F.x&&++V.x;let S=R.tileXYToRectangle(F.x,F.y,h);Math.abs(S.north-t.rectangle.south)<G&&F.y>V.y&&--F.y,Math.abs(S.west-t.rectangle.east)<U&&F.x>V.x&&--F.x;let g=Gt.clone(t.rectangle,k1t),C=R.tileXYToRectangle(V.x,V.y,h),y=Gt.intersection(C,s,xot),Y;a?(R.rectangleToNativeRectangle(g,g),R.rectangleToNativeRectangle(C,C),R.rectangleToNativeRectangle(y,y),R.rectangleToNativeRectangle(s,s),Y=R.tileXYToNativeRectangle.bind(R),U=g.width/512,G=g.height/512):Y=R.tileXYToRectangle.bind(R);let Q,J=0,M=1,Z;!this.isBaseLayer()&&Math.abs(y.west-g.west)>=U&&(J=Math.min(1,(y.west-g.west)/g.width)),!this.isBaseLayer()&&Math.abs(y.north-g.north)>=G&&(M=Math.max(0,(y.north-g.south)/g.height));let E=M;for(let I=V.x;I<=F.x;I++)if(Q=J,C=Y(I,V.y,h),y=Gt.simpleIntersection(C,s,xot),!!c(y)){J=Math.min(1,(y.east-g.west)/g.width),I===F.x&&(this.isBaseLayer()||Math.abs(y.east-g.east)<U)&&(J=1),M=E;for(let B=V.y;B<=F.y;B++){if(Z=M,C=Y(I,B,h),y=Gt.simpleIntersection(C,s,xot),!c(y))continue;M=Math.max(0,(y.south-g.south)/g.height),B===F.y&&(this.isBaseLayer()||Math.abs(y.south-g.south)<G)&&(M=0);let X=new bt(Q,M,J,Z),_=this.getImageryFromCache(I,B,h);i.imagery.splice(n,0,new I1(_,X,a)),++n}}return!0};Uo.prototype._calculateTextureTranslationAndScale=function(t,e){let n=e.readyImagery.rectangle,i=t.rectangle;if(e.useWebMercatorT){let r=e.readyImagery.imageryLayer.imageryProvider.tilingScheme;n=r.rectangleToNativeRectangle(n,Q1t),i=r.rectangleToNativeRectangle(i,k1t)}let o=i.width,a=i.height,s=o/n.width,l=a/n.height;return new bt(s*(i.west-n.west)/o,l*(i.south-n.south)/a,s,l)};Uo.prototype._requestImagery=function(t){let e=this._imageryProvider,n=this;function i(s){if(!c(s))return o();t.image=s,t.state=ho.RECEIVED,t.request=void 0,za.reportSuccess(n._requestImageError)}function o(s){if(t.request.state===qi.CANCELLED){t.state=ho.UNLOADED,t.request=void 0;return}t.state=ho.FAILED,t.request=void 0;let l=`Failed to obtain image tile X: ${t.x} Y: ${t.y} Level: ${t.level}.`;n._requestImageError=za.reportError(n._requestImageError,e,e.errorEvent,l,t.x,t.y,t.level,s),n._requestImageError.retry&&a()}function a(){let s=new us({throttle:!1,throttleByServer:!0,type:Xl.IMAGERY});t.request=s,t.state=ho.TRANSITIONING;let l=e.requestImage(t.x,t.y,t.level,s);if(!c(l)){t.state=ho.UNLOADED,t.request=void 0;return}c(e.getTileCredits)&&(t.credits=e.getTileCredits(t.x,t.y,t.level)),l.then(function(r){i(r)}).catch(function(r){o(r)})}a()};Uo.prototype._createTextureWebGL=function(t,e){let n=new Hn({minificationFilter:this.minificationFilter,magnificationFilter:this.magnificationFilter}),i=e.image;return c(i.internalFormat)?new hn({context:t,pixelFormat:i.internalFormat,width:i.width,height:i.height,source:{arrayBufferView:i.bufferView},sampler:n}):new hn({context:t,source:i,pixelFormat:this._imageryProvider.hasAlphaChannel?Ye.RGBA:Ye.RGB,sampler:n})};Uo.prototype._createTexture=function(t,e){let n=this._imageryProvider,i=e.image;if(c(n.tileDiscardPolicy)){let a=n.tileDiscardPolicy;if(c(a)){if(!a.isReady()){e.state=ho.RECEIVED;return}if(a.shouldDiscardImage(i)){e.state=ho.INVALID;return}}}let o=this._createTextureWebGL(t,e);n.tilingScheme.projection instanceof Yo?e.textureWebMercator=o:e.texture=o,e.image=void 0,e.state=ho.TEXTURE_LOADED};function B1t(t,e,n){return`${t}:${e}:${n}`}Uo.prototype._finalizeReprojectTexture=function(t,e){let n=this.minificationFilter,i=this.magnificationFilter;if(n===On.LINEAR&&i===Ro.LINEAR&&!Ye.isCompressedFormat(e.pixelFormat)&&k.isPowerOfTwo(e.width)&&k.isPowerOfTwo(e.height)){n=On.LINEAR_MIPMAP_LINEAR;let a=Tn.maximumTextureFilterAnisotropy,s=Math.min(a,f(this._maximumAnisotropy,a)),l=B1t(n,i,s),r=t.cache.imageryLayerMipmapSamplers;c(r)||(r={},t.cache.imageryLayerMipmapSamplers=r);let d=r[l];c(d)||(d=r[l]=new Hn({wrapS:Zi.CLAMP_TO_EDGE,wrapT:Zi.CLAMP_TO_EDGE,minificationFilter:n,magnificationFilter:i,maximumAnisotropy:s})),e.generateMipmap(JZ.NICEST),e.sampler=d}else{let a=B1t(n,i,0),s=t.cache.imageryLayerNonMipmapSamplers;c(s)||(s={},t.cache.imageryLayerNonMipmapSamplers=s);let l=s[a];c(l)||(l=s[a]=new Hn({wrapS:Zi.CLAMP_TO_EDGE,wrapT:Zi.CLAMP_TO_EDGE,minificationFilter:n,magnificationFilter:i})),e.sampler=l}};Uo.prototype._reprojectTexture=function(t,e,n){let i=e.textureWebMercator||e.texture,o=e.rectangle,a=t.context;if(n=f(n,!0),n&&!(this._imageryProvider.tilingScheme.projection instanceof yo)&&o.width/i.width>1e-5){let s=this;e.addReference();let l=new Wm({persists:!0,owner:this,preExecute:function(r){xEe(r,a,i,e.rectangle)},postExecute:function(r){e.texture=r,s._finalizeReprojectTexture(a,r),e.state=ho.READY,e.releaseReference()},canceled:function(){e.state=ho.TEXTURE_LOADED,e.releaseReference()}});this._reprojectComputeCommands.push(l)}else n&&(e.texture=i),this._finalizeReprojectTexture(a,i),e.state=ho.READY};Uo.prototype.queueReprojectionCommands=function(t){let e=this._reprojectComputeCommands,n=e.length;for(let i=0;i<n;++i)t.commandList.push(e[i]);e.length=0};Uo.prototype.cancelReprojections=function(){this._reprojectComputeCommands.forEach(function(t){c(t.canceled)&&t.canceled()}),this._reprojectComputeCommands.length=0};Uo.prototype.getImageryFromCache=function(t,e,n,i){let o=Y1t(t,e,n),a=this._imageryCache[o];return c(a)||(a=new C1(this,t,e,n,i),this._imageryCache[o]=a),a.addReference(),a};Uo.prototype.removeImageryFromCache=function(t){let e=Y1t(t.x,t.y,t.level);delete this._imageryCache[e]};function Y1t(t,e,n){return JSON.stringify([t,e,n])}var Gz={u_textureDimensions:function(){return this.textureDimensions},u_texture:function(){return this.texture},textureDimensions:new K,texture:void 0},YEe=In.supportsTypedArrays()?new Float32Array(2*64):void 0;function xEe(t,e,n,i){let o=e.cache.imageryLayer_reproject;if(!c(o)){o=e.cache.imageryLayer_reproject={vertexArray:void 0,shaderProgram:void 0,sampler:void 0,destroy:function(){c(this.framebuffer)&&this.framebuffer.destroy(),c(this.vertexArray)&&this.vertexArray.destroy(),c(this.shaderProgram)&&this.shaderProgram.destroy()}};let U=new Float32Array(2*64*2),G=0;for(let y=0;y<64;++y){let Y=y/63;U[G++]=0,U[G++]=Y,U[G++]=1,U[G++]=Y}let A={position:0,webMercatorT:1},S=El.getRegularGridIndices(2,64),g=we.createIndexBuffer({context:e,typedArray:S,usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT});o.vertexArray=new Ki({context:e,attributes:[{index:A.position,vertexBuffer:we.createVertexBuffer({context:e,typedArray:U,usage:ce.STATIC_DRAW}),componentsPerAttribute:2},{index:A.webMercatorT,vertexBuffer:we.createVertexBuffer({context:e,sizeInBytes:64*2*4,usage:ce.STREAM_DRAW}),componentsPerAttribute:1}],indexBuffer:g});let C=new Ze({sources:[zM]});o.shaderProgram=xn.fromCache({context:e,vertexShaderSource:C,fragmentShaderSource:KM,attributeLocations:A}),o.sampler=new Hn({wrapS:Zi.CLAMP_TO_EDGE,wrapT:Zi.CLAMP_TO_EDGE,minificationFilter:On.LINEAR,magnificationFilter:Ro.LINEAR})}n.sampler=o.sampler;let a=n.width,s=n.height;Gz.textureDimensions.x=a,Gz.textureDimensions.y=s,Gz.texture=n;let l=Math.sin(i.south),r=.5*Math.log((1+l)/(1-l));l=Math.sin(i.north);let m=1/(.5*Math.log((1+l)/(1-l))-r),h=new hn({context:e,width:a,height:s,pixelFormat:n.pixelFormat,pixelDatatype:n.pixelDatatype,preMultiplyAlpha:n.preMultiplyAlpha});k.isPowerOfTwo(a)&&k.isPowerOfTwo(s)&&h.generateMipmap(JZ.NICEST);let u=i.south,R=i.north,V=YEe,F=0;for(let U=0;U<64;++U){let G=U/63,A=k.lerp(u,R,G);l=Math.sin(A);let g=(.5*Math.log((1+l)/(1-l))-r)*m;V[F++]=g,V[F++]=g}o.vertexArray.getAttribute(1).vertexBuffer.copyFromArrayView(V),t.shaderProgram=o.shaderProgram,t.outputTexture=h,t.uniformMap=Gz,t.vertexArray=o.vertexArray}function XEe(t,e,n){let i=t._imageryProvider,o=i.tilingScheme,a=o.ellipsoid,s=t._imageryProvider.tilingScheme.projection instanceof yo?1:Math.cos(n),l=o.rectangle,d=a.maximumRadius*l.width*s/(i.tileWidth*o.getNumberOfXTilesAtLevel(0))/e,m=Math.log(d)/Math.log(2);return Math.round(m)|0}function JEe(t,e){t.numberOfListeners>0?t.raiseEvent(e):console.error(e)}async function LEe(t,e){let n;try{if(n=await Promise.resolve(e),t.isDestroyed())return;t._imageryProvider=n,t._readyEvent.raiseEvent(n)}catch(i){JEe(t._errorEvent,i)}}var $r=Uo;var Dfo=b(W(),1);var Wfo=b(W(),1),MEe={WEST:0,NORTH:1,EAST:2,SOUTH:3,NORTHWEST:4,NORTHEAST:5,SOUTHWEST:6,SOUTHEAST:7},mi=MEe;var Ffo=b(W(),1),x1t={NONE:0,CULLED:1,RENDERED:2,REFINED:3,RENDERED_AND_KICKED:6,REFINED_AND_KICKED:7,CULLED_BUT_NEEDED:9,wasKicked:function(t){return t>=x1t.RENDERED_AND_KICKED},originalResult:function(t){return t&3},kick:function(t){return t|4}},Pi=x1t;function y1(t){this.tile=t,this.frameLastUpdated=void 0,this.westMeshes=[],this.westTiles=[],this.southMeshes=[],this.southTiles=[],this.eastMeshes=[],this.eastTiles=[],this.northMeshes=[],this.northTiles=[],this.southwestMesh=void 0,this.southwestTile=void 0,this.southeastMesh=void 0,this.southeastTile=void 0,this.northwestMesh=void 0,this.northwestTile=void 0,this.northeastMesh=void 0,this.northeastTile=void 0,this.changedThisFrame=!0,this.visitedFrame=void 0,this.enqueuedFrame=void 0,this.mesh=void 0,this.vertexArray=void 0,this.waterMaskTexture=void 0,this.waterMaskTranslationAndScale=new bt}y1.prototype.update=function(t,e,n){this.changedThisFrame&&(O1t(t,e,this.tile,n),this.changedThisFrame=!1)};y1.prototype.destroy=function(t){this._destroyVertexArray(t),c(this.waterMaskTexture)&&(--this.waterMaskTexture.referenceCount,this.waterMaskTexture.referenceCount===0&&this.waterMaskTexture.destroy(),this.waterMaskTexture=void 0)};y1.prototype._destroyVertexArray=function(t){c(this.vertexArray)&&(c(t)?t.push(this.vertexArray):SV._freeVertexArray(this.vertexArray),this.vertexArray=void 0)};var _Ee=new $Z;y1.updateFillTiles=function(t,e,n,i){let o=t._quadtree,a=o._levelZeroTiles,s=o._lastSelectionFrameNumber,l=_Ee;l.clear();for(let d=0;d<e.length;++d){let m=e[d];c(m.data.vertexArray)&&l.enqueue(e[d])}let r=l.dequeue();for(;r!==void 0;){let d=r.findTileToWest(a),m=r.findTileToSouth(a),h=r.findTileToEast(a),u=r.findTileToNorth(a);rr(t,n,r,d,s,mi.EAST,!1,l,i),rr(t,n,r,m,s,mi.NORTH,!1,l,i),rr(t,n,r,h,s,mi.WEST,!1,l,i),rr(t,n,r,u,s,mi.SOUTH,!1,l,i);let R=d.findTileToNorth(a),V=d.findTileToSouth(a),F=h.findTileToNorth(a),U=h.findTileToSouth(a);rr(t,n,r,R,s,mi.SOUTHEAST,!1,l,i),rr(t,n,r,F,s,mi.SOUTHWEST,!1,l,i),rr(t,n,r,V,s,mi.NORTHEAST,!1,l,i),rr(t,n,r,U,s,mi.NORTHWEST,!1,l,i),r=l.dequeue()}};function rr(t,e,n,i,o,a,s,l,r){if(i===void 0)return;let d=i;for(;d&&(d._lastSelectionResultFrame!==o||Pi.wasKicked(d._lastSelectionResult)||Pi.originalResult(d._lastSelectionResult)===Pi.CULLED);){if(s)return;let m=d.parent;if(a>=mi.NORTHWEST&&m!==void 0)switch(a){case mi.NORTHWEST:d=d===m.northwestChild?m:void 0;break;case mi.NORTHEAST:d=d===m.northeastChild?m:void 0;break;case mi.SOUTHWEST:d=d===m.southwestChild?m:void 0;break;case mi.SOUTHEAST:d=d===m.southeastChild?m:void 0;break}else d=m}if(d!==void 0){if(d._lastSelectionResult===Pi.RENDERED){if(c(d.data.vertexArray))return;DEe(t,e,n,d,a,o,l,r);return}if(Pi.originalResult(i._lastSelectionResult)!==Pi.CULLED)switch(a){case mi.WEST:rr(t,e,n,i.northwestChild,o,a,!0,l,r),rr(t,e,n,i.southwestChild,o,a,!0,l,r);break;case mi.EAST:rr(t,e,n,i.southeastChild,o,a,!0,l,r),rr(t,e,n,i.northeastChild,o,a,!0,l,r);break;case mi.SOUTH:rr(t,e,n,i.southwestChild,o,a,!0,l,r),rr(t,e,n,i.southeastChild,o,a,!0,l,r);break;case mi.NORTH:rr(t,e,n,i.northeastChild,o,a,!0,l,r),rr(t,e,n,i.northwestChild,o,a,!0,l,r);break;case mi.NORTHWEST:rr(t,e,n,i.northwestChild,o,a,!0,l,r);break;case mi.NORTHEAST:rr(t,e,n,i.northeastChild,o,a,!0,l,r);break;case mi.SOUTHWEST:rr(t,e,n,i.southwestChild,o,a,!0,l,r);break;case mi.SOUTHEAST:rr(t,e,n,i.southeastChild,o,a,!0,l,r);break;default:throw new Ut("Invalid edge")}}}function DEe(t,e,n,i,o,a,s,l){let r=i.data;if(r.fill===void 0)r.fill=new y1(i);else if(r.fill.visitedFrame===a)return;r.fill.enqueuedFrame!==a&&(r.fill.enqueuedFrame=a,r.fill.changedThisFrame=!1,s.enqueue(i)),OEe(t,e,n,i,o,l)}function OEe(t,e,n,i,o,a){let s=i.data.fill,l,r=n.data.fill;c(r)?(r.visitedFrame=e.frameNumber,r.changedThisFrame&&(O1t(t,e,n,a),r.changedThisFrame=!1),l=n.data.fill.mesh):l=n.data.mesh;let d,m;switch(o){case mi.WEST:d=s.westMeshes,m=s.westTiles;break;case mi.SOUTH:d=s.southMeshes,m=s.southTiles;break;case mi.EAST:d=s.eastMeshes,m=s.eastTiles;break;case mi.NORTH:d=s.northMeshes,m=s.northTiles;break;case mi.NORTHWEST:s.changedThisFrame=s.changedThisFrame||s.northwestMesh!==l,s.northwestMesh=l,s.northwestTile=n;return;case mi.NORTHEAST:s.changedThisFrame=s.changedThisFrame||s.northeastMesh!==l,s.northeastMesh=l,s.northeastTile=n;return;case mi.SOUTHWEST:s.changedThisFrame=s.changedThisFrame||s.southwestMesh!==l,s.southwestMesh=l,s.southwestTile=n;return;case mi.SOUTHEAST:s.changedThisFrame=s.changedThisFrame||s.southeastMesh!==l,s.southeastMesh=l,s.southeastTile=n;return}if(n.level<=i.level){s.changedThisFrame=s.changedThisFrame||d[0]!==l||d.length!==1,d[0]=l,m[0]=n,d.length=1,m.length=1;return}let h,u,R,V,F=n.rectangle,U,G=i.rectangle;switch(o){case mi.WEST:for(U=(G.north-G.south)*k.EPSILON5,h=0;h<m.length&&(R=m[h],V=R.rectangle,!k.greaterThan(F.north,V.south,U));++h);for(u=h;u<m.length&&(R=m[u],V=R.rectangle,!k.greaterThanOrEquals(F.south,V.north,U));++u);break;case mi.SOUTH:for(U=(G.east-G.west)*k.EPSILON5,h=0;h<m.length&&(R=m[h],V=R.rectangle,!k.lessThan(F.west,V.east,U));++h);for(u=h;u<m.length&&(R=m[u],V=R.rectangle,!k.lessThanOrEquals(F.east,V.west,U));++u);break;case mi.EAST:for(U=(G.north-G.south)*k.EPSILON5,h=0;h<m.length&&(R=m[h],V=R.rectangle,!k.lessThan(F.south,V.north,U));++h);for(u=h;u<m.length&&(R=m[u],V=R.rectangle,!k.lessThanOrEquals(F.north,V.south,U));++u);break;case mi.NORTH:for(U=(G.east-G.west)*k.EPSILON5,h=0;h<m.length&&(R=m[h],V=R.rectangle,!k.greaterThan(F.east,V.west,U));++h);for(u=h;u<m.length&&(R=m[u],V=R.rectangle,!k.greaterThanOrEquals(F.west,V.east,U));++u);break}u-h===1?(s.changedThisFrame=s.changedThisFrame||d[h]!==l,d[h]=l,m[h]=n):(s.changedThisFrame=!0,d.splice(h,u-h,l),m.splice(h,u-h,n))}var pT=new gt,HEe=new gt,N1=new p,Mot=new p,Xot=new K,Jot=new K,np=new K;function Iz(){this.height=0,this.encodedNormal=new K}function Az(t,e,n,i,o,a,s,l,r){if(c(o))return o;let d;if(c(a)&&c(s))d=(a.height+s.height)*.5;else if(c(a))d=a.height;else if(c(s))d=s.height;else if(c(l))d=l.height;else{let h=t.tile.data.tileBoundingRegion,u=0,R=0;c(h)&&(u=h.minimumHeight,R=h.maximumHeight),d=(u+R)*.5}return H1t(t,e,n,i,d,r),r}var wEe={minimumHeight:0,maximumHeight:0},PEe=new p,X1t=new Iz,J1t=new Iz,L1t=new Iz,M1t=new Iz,vEe=typeof Uint8Array<"u"?new Uint8Array(9*9):void 0,KEe={tilingScheme:void 0,x:0,y:0,level:0,exaggeration:1,exaggerationRelativeHeight:0};function O1t(t,e,n,i){SV.initialize(n,t.terrainProvider,t._imageryLayers);let o=n.data,a=o.fill,s=n.rectangle,l=e.verticalExaggeration,r=e.verticalExaggerationRelativeHeight,d=l!==1,m=n.tilingScheme.ellipsoid,h=Tz(a,m,0,1,a.northwestTile,a.northwestMesh,a.northTiles,a.northMeshes,a.westTiles,a.westMeshes,L1t),u=Tz(a,m,0,0,a.southwestTile,a.southwestMesh,a.westTiles,a.westMeshes,a.southTiles,a.southMeshes,X1t),R=Tz(a,m,1,0,a.southeastTile,a.southeastMesh,a.southTiles,a.southMeshes,a.eastTiles,a.eastMeshes,J1t),V=Tz(a,m,1,1,a.northeastTile,a.northeastMesh,a.eastTiles,a.eastMeshes,a.northTiles,a.northMeshes,M1t);h=Az(a,m,0,1,h,u,V,R,L1t),u=Az(a,m,0,0,u,h,R,V,X1t),R=Az(a,m,1,1,R,u,V,h,J1t),V=Az(a,m,1,1,V,R,h,u,M1t);let F=u.height,U=R.height,G=h.height,A=V.height,S=Math.min(F,U,G,A),g=Math.max(F,U,G,A),C=(S+g)*.5,y,Y,Q=t.getLevelMaximumGeometricError(n.level),J=m.maximumRadius-Q,M=Math.acos(J/m.maximumRadius)*4;if(M*=1.5,s.width>M&&g-S<=Q){let I=new Gd({width:9,height:9,buffer:vEe,structure:{heightOffset:g}}),B=KEe;B.tilingScheme=n.tilingScheme,B.x=n.x,B.y=n.y,B.level=n.level,B.exaggeration=l,B.exaggerationRelativeHeight=r,a.mesh=I._createMeshSync(B)}else{let I=d,B=Gt.center(s,HEe);B.height=C;let X=m.cartographicToCartesian(B,PEe),_=new lc(X,void 0,void 0,void 0,void 0,!0,!0,I,l,r),P=5,w;for(w=a.westMeshes,y=0,Y=w.length;y<Y;++y)P+=w[y].eastIndicesNorthToSouth.length;for(w=a.southMeshes,y=0,Y=w.length;y<Y;++y)P+=w[y].northIndicesWestToEast.length;for(w=a.eastMeshes,y=0,Y=w.length;y<Y;++y)P+=w[y].westIndicesSouthToNorth.length;for(w=a.northMeshes,y=0,Y=w.length;y<Y;++y)P+=w[y].southIndicesEastToWest.length;let z=wEe;z.minimumHeight=S,z.maximumHeight=g;let H=_.stride,nt=new Float32Array(P*H),$=0,dt=$;$=Sz(m,s,_,nt,$,0,1,h.height,h.encodedNormal,1,z),$=Ez(a,m,_,nt,$,a.westTiles,a.westMeshes,mi.EAST,z);let q=$;$=Sz(m,s,_,nt,$,0,0,u.height,u.encodedNormal,0,z),$=Ez(a,m,_,nt,$,a.southTiles,a.southMeshes,mi.NORTH,z);let at=$;$=Sz(m,s,_,nt,$,1,0,R.height,R.encodedNormal,0,z),$=Ez(a,m,_,nt,$,a.eastTiles,a.eastMeshes,mi.WEST,z);let st=$;$=Sz(m,s,_,nt,$,1,1,V.height,V.encodedNormal,1,z),$=Ez(a,m,_,nt,$,a.northTiles,a.northMeshes,mi.SOUTH,z),S=z.minimumHeight,g=z.maximumHeight;let Et=ci.fromRectangle(s,S,g,n.tilingScheme.ellipsoid),Qt=Yo.geodeticLatitudeToMercatorAngle(s.south),Wt=1/(Yo.geodeticLatitudeToMercatorAngle(s.north)-Qt),Nt=(Yo.geodeticLatitudeToMercatorAngle(B.latitude)-Qt)*Wt,kt=m.geodeticSurfaceNormalCartographic(pT,Mot),Mt=Ni.octEncode(kt,Xot),qt=$;_.encode(nt,$*H,Et.center,K.fromElements(.5,.5,np),C,Mt,Nt,kt),++$;let ie=$,oe=ie<256?1:2,He=(ie-1)*3,rn=He*oe,de=(nt.length-ie*H)*Float32Array.BYTES_PER_ELEMENT,zt;if(de>=rn){let _t=ie*H*Float32Array.BYTES_PER_ELEMENT;zt=ie<256?new Uint8Array(nt.buffer,_t,He):new Uint16Array(nt.buffer,_t,He)}else zt=ie<256?new Uint8Array(He):new Uint16Array(He);nt=new Float32Array(nt.buffer,0,ie*H);let ke=0;for(y=0;y<ie-2;++y)zt[ke++]=qt,zt[ke++]=y,zt[ke++]=y+1;zt[ke++]=qt,zt[ke++]=y,zt[ke++]=0;let Ve=[];for(y=q;y>=dt;--y)Ve.push(y);let We=[];for(y=at;y>=q;--y)We.push(y);let Vn=[];for(y=st;y>=at;--y)Vn.push(y);let Ct=[];for(Ct.push(0),y=qt-1;y>=st;--y)Ct.push(y);a.mesh=new AV(_.center,nt,zt,He,ie,S,g,Ft.fromOrientedBoundingBox(Et),nCe(t,Et.center,s,S,g),_.stride,Et,_,Ve,We,Vn,Ct)}let Z=e.context;a._destroyVertexArray(i),a.vertexArray=SV._createVertexArrayForMesh(Z,a.mesh),o.processImagery(n,t.terrainProvider,e,!0);let E=a.waterMaskTexture;if(a.waterMaskTexture=void 0,t.terrainProvider.hasWaterMask){let I=o._findAncestorTileWithTerrainData(n);c(I)&&c(I.data.waterMaskTexture)&&(a.waterMaskTexture=I.data.waterMaskTexture,++a.waterMaskTexture.referenceCount,o._computeWaterMaskTranslationAndScale(n,I,a.waterMaskTranslationAndScale))}c(E)&&(--E.referenceCount,E.referenceCount===0&&E.destroy())}function Sz(t,e,n,i,o,a,s,l,r,d,m){let h=pT;h.longitude=k.lerp(e.west,e.east,a),h.latitude=k.lerp(e.south,e.north,s),h.height=l;let u=t.cartographicToCartesian(h,N1),R;n.hasGeodeticSurfaceNormals&&(R=t.geodeticSurfaceNormal(u,Mot));let V=Jot;return V.x=a,V.y=s,n.encode(i,o*n.stride,u,V,l,r,d,R),m.minimumHeight=Math.min(m.minimumHeight,l),m.maximumHeight=Math.max(m.maximumHeight,l),o+1}var Cz=new Gt;function jM(t,e,n,i){let o=t.rectangle,a=e.rectangle;e.x===0&&n.x===1&&t.x===t.tilingScheme.getNumberOfXTilesAtLevel(t.level)-1?(o=Gt.clone(t.rectangle,Cz),o.west-=k.TWO_PI,o.east-=k.TWO_PI):t.x===0&&n.x===0&&e.x===e.tilingScheme.getNumberOfXTilesAtLevel(e.level)-1&&(o=Gt.clone(t.rectangle,Cz),o.west+=k.TWO_PI,o.east+=k.TWO_PI);let s=o.east-o.west,l=(a.west-o.west)/s,r=(a.east-o.west)/s,d=o.north-o.south,m=(a.south-o.south)/d,h=(a.north-o.south)/d,u=(n.x-l)/(r-l),R=(n.y-m)/(h-m);return Math.abs(u)<Math.EPSILON5?u=0:Math.abs(u-1)<Math.EPSILON5&&(u=1),Math.abs(R)<Math.EPSILON5?R=0:Math.abs(R-1)<Math.EPSILON5&&(R=1),i.x=u,i.y=R,i}var zEe=new K;function Lot(t,e,n,i,o){let a=t.encoding,s=t.vertices;if(o.height=a.decodeHeight(s,e),a.hasVertexNormals)a.getOctEncodedNormal(s,e,o.encodedNormal);else{let l=o.encodedNormal;l.x=0,l.y=0}}var jEe=new K,qEe=new p;function $Ee(t,e,n,i,o,a,s,l,r,d){let m=i.encoding,h=i.vertices,u=jM(e,n,m.decodeTextureCoordinates(h,o,np),np),R=jM(e,n,m.decodeTextureCoordinates(h,a,Jot),Jot),V;r?V=(s-u.x)/(R.x-u.x):V=(l-u.y)/(R.y-u.y);let F=m.decodeHeight(h,o),U=m.decodeHeight(h,a),G=n.rectangle;pT.longitude=k.lerp(G.west,G.east,s),pT.latitude=k.lerp(G.south,G.north,l),d.height=pT.height=k.lerp(F,U,V);let A;if(m.hasVertexNormals){let S=m.getOctEncodedNormal(h,o,zEe),g=m.getOctEncodedNormal(h,a,jEe),C=Ni.octDecode(S.x,S.y,N1),y=Ni.octDecode(g.x,g.y,qEe);A=p.lerp(C,y,V,N1),p.normalize(A,A),Ni.octEncode(A,d.encodedNormal)}else A=t.geodeticSurfaceNormalCartographic(pT,N1),Ni.octEncode(A,d.encodedNormal)}function H1t(t,e,n,i,o,a){a.height=o;let s=e.geodeticSurfaceNormalCartographic(pT,N1);Ni.octEncode(s,a.encodedNormal)}function Tz(t,e,n,i,o,a,s,l,r,d,m){if(D1t(t,e,l,s,!1,n,i,m)||D1t(t,e,d,r,!0,n,i,m))return m;let u;if(_ot(o,a))return n===0?i===0?u=a.eastIndicesNorthToSouth[0]:u=a.southIndicesEastToWest[0]:i===0?u=a.northIndicesWestToEast[0]:u=a.westIndicesSouthToNorth[0],Lot(a,u,n,i,m),m;let R;if(n===0?i===0?R=gz(t.westMeshes,t.westTiles,mi.EAST,t.southMeshes,t.southTiles,mi.NORTH,n,i):R=gz(t.northMeshes,t.northTiles,mi.SOUTH,t.westMeshes,t.westTiles,mi.EAST,n,i):i===0?R=gz(t.southMeshes,t.southTiles,mi.NORTH,t.eastMeshes,t.eastTiles,mi.WEST,n,i):R=gz(t.eastMeshes,t.eastTiles,mi.WEST,t.northMeshes,t.northTiles,mi.SOUTH,n,i),c(R))return H1t(t,e,n,i,R,m),m}function gz(t,e,n,i,o,a,s,l){let r=_1t(t,e,!1,n,s,l),d=_1t(i,o,!0,a,s,l);return c(r)&&c(d)?(r+d)*.5:c(r)?r:d}function Ez(t,e,n,i,o,a,s,l,r){for(let d=0;d<a.length;++d)o=tCe(t,e,n,i,o,a[d],s[d],l,r);return o}function tCe(t,e,n,i,o,a,s,l,r){let d=a.rectangle;l===mi.EAST&&t.tile.x===0?(d=Gt.clone(a.rectangle,Cz),d.west-=k.TWO_PI,d.east-=k.TWO_PI):l===mi.WEST&&a.x===0&&(d=Gt.clone(a.rectangle,Cz),d.west+=k.TWO_PI,d.east+=k.TWO_PI);let m=t.tile.rectangle,h,u;o>0&&(n.decodeTextureCoordinates(i,o-1,np),h=np.x,u=np.y);let R,V;switch(l){case mi.WEST:R=s.westIndicesSouthToNorth,V=!1;break;case mi.NORTH:R=s.northIndicesWestToEast,V=!0;break;case mi.EAST:R=s.eastIndicesNorthToSouth,V=!1;break;case mi.SOUTH:R=s.southIndicesEastToWest,V=!0;break}let F=a,U=t.tile,G=s.encoding,A=s.vertices,S=n.stride,g,C;G.hasWebMercatorT&&(g=Yo.geodeticLatitudeToMercatorAngle(m.south),C=1/(Yo.geodeticLatitudeToMercatorAngle(m.north)-g));for(let y=0;y<R.length;++y){let Y=R[y],Q=G.decodeTextureCoordinates(A,Y,np);jM(F,U,Q,Q);let J=Q.x,M=Q.y,Z=V?J:M;if(Z<0||Z>1||Math.abs(J-h)<k.EPSILON5&&Math.abs(M-u)<k.EPSILON5)continue;let E=Math.abs(J)<k.EPSILON5||Math.abs(J-1)<k.EPSILON5,I=Math.abs(M)<k.EPSILON5||Math.abs(M-1)<k.EPSILON5;if(E&&I)continue;let B=G.decodePosition(A,Y,N1),X=G.decodeHeight(A,Y),_;G.hasVertexNormals?_=G.getOctEncodedNormal(A,Y,Xot):(_=Xot,_.x=0,_.y=0);let P=M;if(G.hasWebMercatorT){let z=k.lerp(m.south,m.north,M);P=(Yo.geodeticLatitudeToMercatorAngle(z)-g)*C}let w;n.hasGeodeticSurfaceNormals&&(w=e.geodeticSurfaceNormal(B,Mot)),n.encode(i,o*S,B,Q,X,_,P,w),r.minimumHeight=Math.min(r.minimumHeight,X),r.maximumHeight=Math.max(r.maximumHeight,X),++o}return o}function _1t(t,e,n,i,o,a){let s,l,r;n?(s=0,l=t.length,r=1):(s=t.length-1,l=-1,r=-1);for(let d=s;d!==l;d+=r){let m=t[d],h=e[d];if(!_ot(h,m))continue;let u;switch(i){case mi.WEST:u=m.westIndicesSouthToNorth;break;case mi.SOUTH:u=m.southIndicesEastToWest;break;case mi.EAST:u=m.eastIndicesNorthToSouth;break;case mi.NORTH:u=m.northIndicesWestToEast;break}let R=u[n?0:u.length-1];if(c(R))return m.encoding.decodeHeight(m.vertices,R)}}function _ot(t,e){return c(e)&&(!c(t.data.fill)||!t.data.fill.changedThisFrame)}function D1t(t,e,n,i,o,a,s,l){let r,d,m,h,u,R=i[o?0:n.length-1],V=n[o?0:n.length-1];if(_ot(R,V)&&(a===0?s===0?(r=o?V.northIndicesWestToEast:V.eastIndicesNorthToSouth,d=o,m=o):(r=o?V.eastIndicesNorthToSouth:V.southIndicesEastToWest,d=!o,m=!1):s===0?(r=o?V.westIndicesSouthToNorth:V.northIndicesWestToEast,d=!o,m=!0):(r=o?V.southIndicesEastToWest:V.westIndicesSouthToNorth,d=o,m=!o),r.length>0)){h=o?0:r.length-1,u=r[h],V.encoding.decodeTextureCoordinates(V.vertices,u,np);let F=jM(R,t.tile,np,np);if(F.x===a&&F.y===s)return Lot(V,u,a,s,l),!0;if(h=Ja(r,d?a:s,function(U,G){V.encoding.decodeTextureCoordinates(V.vertices,U,np);let A=jM(R,t.tile,np,np);return m?d?A.x-a:A.y-s:d?a-A.x:s-A.y}),h<0){if(h=~h,h>0&&h<r.length)return $Ee(e,R,t.tile,V,r[h-1],r[h],a,s,d,l),!0}else return Lot(V,r[h],a,s,l),!0}return!1}var eCe=[new p,new p,new p,new p];function nCe(t,e,n,i,o,a){let s=t.quadtree._occluders.ellipsoid,l=s.ellipsoid,r=eCe;return p.fromRadians(n.west,n.south,o,l,r[0]),p.fromRadians(n.east,n.south,o,l,r[1]),p.fromRadians(n.west,n.north,o,l,r[2]),p.fromRadians(n.east,n.north,o,l,r[3]),s.computeHorizonCullingPointPossiblyUnderEllipsoid(e,r,i,a)}var B1=y1;function As(t){this.lightingFadeOutDistance=65e5,this.lightingFadeInDistance=9e6,this.hasWaterMask=!1,this.oceanNormalMap=void 0,this.zoomedOutOceanSpecularIntensity=.5,this.enableLighting=!1,this.dynamicAtmosphereLighting=!1,this.dynamicAtmosphereLightingFromSun=!1,this.showGroundAtmosphere=!1,this.shadows=Vi.RECEIVE_ONLY,this.vertexShadowDarkness=.3,this.fillHighlightColor=void 0,this.hueShift=0,this.saturationShift=0,this.brightnessShift=0,this.showSkirts=!0,this.backFaceCulling=!0,this.undergroundColor=void 0,this.undergroundColorAlphaByDistance=void 0,this.lambertDiffuseMultiplier=0,this.materialUniformMap=void 0,this._materialUniformMap=void 0,this._quadtree=void 0,this._terrainProvider=t.terrainProvider,this._imageryLayers=t.imageryLayers,this._surfaceShaderSet=t.surfaceShaderSet,this._renderState=void 0,this._blendRenderState=void 0,this._disableCullingRenderState=void 0,this._disableCullingBlendRenderState=void 0,this._errorEvent=new It,this._removeLayerAddedListener=this._imageryLayers.layerAdded.addEventListener(As.prototype._onLayerAdded,this),this._removeLayerRemovedListener=this._imageryLayers.layerRemoved.addEventListener(As.prototype._onLayerRemoved,this),this._removeLayerMovedListener=this._imageryLayers.layerMoved.addEventListener(As.prototype._onLayerMoved,this),this._removeLayerShownListener=this._imageryLayers.layerShownOrHidden.addEventListener(As.prototype._onLayerShownOrHidden,this),this._imageryLayersUpdatedEvent=new It,this._layerOrderChanged=!1,this._tilesToRenderByTextureCount=[],this._drawCommands=[],this._uniformMaps=[],this._usedDrawCommands=0,this._vertexArraysToDestroy=[],this._debug={wireframe:!1,boundingSphereTile:void 0},this._baseColor=void 0,this._firstPassInitialColor=void 0,this.baseColor=new v(0,0,.5,1),this._clippingPlanes=void 0,this._clippingPolygons=void 0,this.cartographicLimitRectangle=Gt.clone(Gt.MAX_VALUE),this._hasLoadedTilesThisFrame=!1,this._hasFillTilesThisFrame=!1,this._oldVerticalExaggeration=void 0,this._oldVerticalExaggerationRelativeHeight=void 0}Object.defineProperties(As.prototype,{baseColor:{get:function(){return this._baseColor},set:function(t){this._baseColor=t,this._firstPassInitialColor=bt.fromColor(t,this._firstPassInitialColor)}},quadtree:{get:function(){return this._quadtree},set:function(t){this._quadtree=t}},tilingScheme:{get:function(){if(c(this._terrainProvider))return this._terrainProvider.tilingScheme}},errorEvent:{get:function(){return this._errorEvent}},imageryLayersUpdatedEvent:{get:function(){return this._imageryLayersUpdatedEvent}},terrainProvider:{get:function(){return this._terrainProvider},set:function(t){this._terrainProvider!==t&&(this._terrainProvider=t,c(this._quadtree)&&this._quadtree.invalidateAllTiles())}},clippingPlanes:{get:function(){return this._clippingPlanes},set:function(t){Ml.setOwner(t,this,"_clippingPlanes")}},clippingPolygons:{get:function(){return this._clippingPolygons},set:function(t){bu.setOwner(t,this,"_clippingPolygons")}}});function iCe(t,e){let n=t.loadingImagery;c(n)||(n=t.readyImagery);let i=e.loadingImagery;return c(i)||(i=e.readyImagery),n.imageryLayer._layerIndex-i.imageryLayer._layerIndex}As.prototype.update=function(t){this._imageryLayers._update()};function oCe(t,e){let n=e.creditDisplay,i=t._terrainProvider;c(i)&&c(i.credit)&&n.addCreditToNextFrame(i.credit);let o=t._imageryLayers;for(let a=0,s=o.length;a<s;++a){let l=o.get(a);l.ready&&l.show&&c(l.imageryProvider.credit)&&n.addCreditToNextFrame(l.imageryProvider.credit)}}As.prototype.initialize=function(t){this._imageryLayers.queueReprojectionCommands(t),this._layerOrderChanged&&(this._layerOrderChanged=!1,this._quadtree.forEachLoadedTile(function(i){i.data.imagery.sort(iCe)})),oCe(this,t);let e=this._vertexArraysToDestroy,n=e.length;for(let i=0;i<n;++i)SV._freeVertexArray(e[i]);e.length=0};As.prototype.beginUpdate=function(t){let e=this._tilesToRenderByTextureCount;for(let o=0,a=e.length;o<a;++o){let s=e[o];c(s)&&(s.length=0)}let n=this._clippingPlanes;c(n)&&n.enabled&&n.update(t);let i=this._clippingPolygons;c(i)&&i.enabled&&(i.update(t),i.queueCommands(t)),this._usedDrawCommands=0,this._hasLoadedTilesThisFrame=!1,this._hasFillTilesThisFrame=!1};As.prototype.endUpdate=function(t){if(!c(this._renderState)){this._renderState=he.fromCache({cull:{enabled:!0},depthTest:{enabled:!0,func:_d.LESS}}),this._blendRenderState=he.fromCache({cull:{enabled:!0},depthTest:{enabled:!0,func:_d.LESS_OR_EQUAL},blending:Pn.ALPHA_BLEND});let s=Re(this._renderState,!0);s.cull.enabled=!1,this._disableCullingRenderState=he.fromCache(s),s=Re(this._blendRenderState,!0),s.cull.enabled=!1,this._disableCullingBlendRenderState=he.fromCache(s)}this._hasFillTilesThisFrame&&this._hasLoadedTilesThisFrame&&B1.updateFillTiles(this,this._quadtree._tilesToRender,t,this._vertexArraysToDestroy);let e=this.quadtree,n=t.verticalExaggeration,i=t.verticalExaggerationRelativeHeight,o=this._oldVerticalExaggeration!==n||this._oldVerticalExaggerationRelativeHeight!==i;this._oldVerticalExaggeration=n,this._oldVerticalExaggerationRelativeHeight=i,o&&e.forEachLoadedTile(function(s){s.data.updateExaggeration(s,t,e)});let a=this._tilesToRenderByTextureCount;for(let s=0,l=a.length;s<l;++s){let r=a[s];if(c(r))for(let d=0,m=r.length;d<m;++d){let h=r[d],u=h.data.tileBoundingRegion;ECe(this,h,t),t.minimumTerrainHeight=Math.min(t.minimumTerrainHeight,u.minimumHeight)}}};function z1t(t,e){let n=e.globeTranslucencyState;if(n.translucent){let i=t.renderState.blending.enabled;n.pushDerivedCommands(t,i,e)}else e.commandList.push(t)}As.prototype.updateForPick=function(t){let e=this._drawCommands;for(let n=0,i=this._usedDrawCommands;n<i;++n)z1t(e[n],t)};As.prototype.cancelReprojections=function(){this._imageryLayers.cancelReprojections()};As.prototype.getLevelMaximumGeometricError=function(t){return c(this._terrainProvider)?this._terrainProvider.getLevelMaximumGeometricError(t):0};As.prototype.loadTile=function(t,e){let n=e.data,i=!0,o;c(n)&&(i=n.boundingVolumeSourceTile!==e||e._lastSelectionResult===Pi.CULLED_BUT_NEEDED,o=n.terrainState),SV.processStateMachine(e,t,this.terrainProvider,this._imageryLayers,this.quadtree,this._vertexArraysToDestroy,i),n=e.data,i&&o!==e.data.terrainState&&this.computeTileVisibility(e,t,this.quadtree.occluders)!==Ys.NONE&&n.boundingVolumeSourceTile===e&&(i=!1,SV.processStateMachine(e,t,this.terrainProvider,this._imageryLayers,this.quadtree,this._vertexArraysToDestroy,i))};var aCe=new Ft,j1t=new Gt,sCe=new Gt,lCe=new gt;function yz(t,e){if(e.west<e.east)return e;let n=Gt.clone(e,sCe);return Gt.center(t,lCe).longitude>0?n.east=k.PI:n.west=-k.PI,n}function q1t(t,e){if(e.cameraUnderground||e.globeTranslucencyState.translucent)return!0;if(t.backFaceCulling)return!1;let n=t._clippingPlanes;if(c(n)&&n.enabled)return!0;let i=t._clippingPolygons;return!!(c(i)&&i.enabled||!Gt.equals(t.cartographicLimitRectangle,Gt.MAX_VALUE))}As.prototype.computeTileVisibility=function(t,e,n){let i=this.computeDistanceToTile(t,e);t._distance=i;let o=q1t(this,e);if(e.fog.enabled&&!o&&k.fog(i,e.fog.density)>=1)return Ys.NONE;let a=t.data,s=a.tileBoundingRegion;if(a.boundingVolumeSourceTile===void 0)return Ys.PARTIAL;let l=e.cullingVolume,r=s.boundingVolume;c(r)||(r=s.boundingSphere),a.clippedByBoundaries=!1;let d=yz(t.rectangle,this.cartographicLimitRectangle),m=Gt.simpleIntersection(d,t.rectangle,j1t);if(!c(m))return Ys.NONE;if(Gt.equals(m,t.rectangle)||(a.clippedByBoundaries=!0),e.mode!==Vt.SCENE3D&&(r=aCe,Ft.fromRectangleWithHeights2D(t.rectangle,e.mapProjection,s.minimumHeight,s.maximumHeight,r),p.fromElements(r.center.z,r.center.x,r.center.y,r.center),e.mode===Vt.MORPHING&&c(a.renderedMesh)&&(r=Ft.union(s.boundingSphere,r,r))),!c(r))return Ys.PARTIAL;let h=this._clippingPlanes;if(c(h)&&h.enabled){let U=h.computeIntersectionWithBoundingVolume(r);if(t.isClipped=U!==yn.INSIDE,U===yn.OUTSIDE)return Ys.NONE}let u=this._clippingPolygons;if(c(u)&&u.enabled){let U=u.computeIntersectionWithBoundingVolume(s);t.isClipped=U!==yn.OUTSIDE}let R,V=l.computeVisibility(r);if(V===yn.OUTSIDE?R=Ys.NONE:V===yn.INTERSECTING?R=Ys.PARTIAL:V===yn.INSIDE&&(R=Ys.FULL),R===Ys.NONE)return R;let F=e.mode===Vt.SCENE3D&&e.camera.frustum instanceof wn;if(e.mode===Vt.SCENE3D&&!F&&c(n)&&!o){let U=a.occludeePointInScaledSpace;return!c(U)||n.ellipsoid.isScaledSpacePointVisiblePossiblyUnderEllipsoid(U,s.minimumHeight)?R:Ys.NONE}return R};As.prototype.canRefine=function(t){return c(t.data.terrainData)?!0:this.terrainProvider.getTileDataAvailable(t.x*2,t.y*2,t.level+1)!==void 0};var rCe=[],dCe=[];As.prototype.canRenderWithoutLosingDetail=function(t,e){let n=t.data,i=rCe;i.length=this._imageryLayers.length;let o=!1,a=!1,s;c(n)&&(o=n.terrainState===Ga.READY,a=!0,s=n.imagery);let l,r;for(l=0,r=i.length;l<r;++l)i[l]=a;if(c(s))for(l=0,r=s.length;l<r;++l){let h=s[l],u=h.loadingImagery,R=!c(u)||u.state===ho.FAILED||u.state===ho.INVALID,V=(h.loadingImagery||h.readyImagery).imageryLayer._layerIndex;i[V]=R&&i[V]}let d=this.quadtree._lastSelectionFrameNumber,m=dCe;for(m.length=0,m.push(t.southwestChild,t.southeastChild,t.northwestChild,t.northeastChild);m.length>0;){let h=m.pop(),u=h._lastSelectionResultFrame===d?h._lastSelectionResult:Pi.NONE;if(u===Pi.RENDERED){let R=h.data;if(!c(R))continue;if(!o&&h.data.terrainState===Ga.READY)return!1;let V=h.data.imagery;for(l=0,r=V.length;l<r;++l){let F=V[l],U=F.loadingImagery,G=!c(U)||U.state===ho.FAILED||U.state===ho.INVALID,A=(F.loadingImagery||F.readyImagery).imageryLayer._layerIndex;if(G&&!i[A])return!1}}else u===Pi.REFINED&&m.push(h.southwestChild,h.southeastChild,h.northwestChild,h.northeastChild)}return!0};var cCe=new p;As.prototype.computeTileLoadPriority=function(t,e){let n=t.data;if(n===void 0)return 0;let i=n.tileBoundingRegion.boundingVolume;if(i===void 0)return 0;let o=e.camera.positionWC,a=e.camera.directionWC,s=p.subtract(i.center,o,cCe),l=p.magnitude(s);return l<k.EPSILON5?0:(p.divideByScalar(s,l,s),(1-p.dot(s,a))*t._distance)};var w1t=new L,Nz=new L,mCe=new bt,hCe=new bt,pCe=new bt,VCe=new p,P1t=new p,uCe=new p,ZCe=new p;As.prototype.showTileThisFrame=function(t,e){let n=0,i=t.data.imagery;for(let l=0,r=i.length;l<r;++l){let d=i[l];c(d.readyImagery)&&d.readyImagery.imageryLayer.alpha!==0&&++n}let o=this._tilesToRenderByTextureCount[n];c(o)||(o=[],this._tilesToRenderByTextureCount[n]=o),o.push(t);let a=t.data;c(a.vertexArray)?this._hasLoadedTilesThisFrame=!0:this._hasFillTilesThisFrame=!0;let s=this._debug;++s.tilesRendered,s.texturesRendered+=n};var RCe=[new p,new p,new p,new p];function v1t(t,e,n,i,o,a){let s=t.quadtree._occluders.ellipsoid,l=s.ellipsoid,r=RCe;return p.fromRadians(n.west,n.south,o,l,r[0]),p.fromRadians(n.east,n.south,o,l,r[1]),p.fromRadians(n.west,n.north,o,l,r[2]),p.fromRadians(n.east,n.north,o,l,r[3]),s.computeHorizonCullingPointPossiblyUnderEllipsoid(e,r,i,a)}As.prototype.computeDistanceToTile=function(t,e){bCe(t,this,e);let n=t.data;if(n.boundingVolumeSourceTile===void 0)return 9999999999;let o=n.tileBoundingRegion,a=o.minimumHeight,s=o.maximumHeight;if(n.boundingVolumeSourceTile!==t){let r=e.camera.positionCartographic.height,d=Math.abs(r-a),m=Math.abs(r-s);d>m?(o.minimumHeight=a,o.maximumHeight=a):(o.minimumHeight=s,o.maximumHeight=s)}let l=o.distanceToCamera(e);return o.minimumHeight=a,o.maximumHeight=s,l};function bCe(t,e,n){let i=t.data;i===void 0&&(i=t.data=new SV);let o=t.tilingScheme.ellipsoid;i.tileBoundingRegion===void 0&&(i.tileBoundingRegion=new eV({computeBoundingVolumes:!1,rectangle:t.rectangle,ellipsoid:o,minimumHeight:0,maximumHeight:0}));let a=i.tileBoundingRegion,s=a.minimumHeight,l=a.maximumHeight,r=!1,d=t,m=i.mesh,h=i.terrainData;if(m!==void 0&&m.minimumHeight!==void 0&&m.maximumHeight!==void 0)a.minimumHeight=m.minimumHeight,a.maximumHeight=m.maximumHeight,r=!0;else if(h!==void 0&&h._minimumHeight!==void 0&&h._maximumHeight!==void 0)a.minimumHeight=h._minimumHeight,a.maximumHeight=h._maximumHeight;else{a.minimumHeight=Number.NaN,a.maximumHeight=Number.NaN;let u=t.parent;for(;u!==void 0;){let R=u.data;if(R!==void 0){let V=R.mesh,F=R.terrainData;if(V!==void 0&&V.minimumHeight!==void 0&&V.maximumHeight!==void 0){a.minimumHeight=V.minimumHeight,a.maximumHeight=V.maximumHeight;break}else if(F!==void 0&&F._minimumHeight!==void 0&&F._maximumHeight!==void 0){a.minimumHeight=F._minimumHeight,a.maximumHeight=F._maximumHeight;break}}u=u.parent}d=u}if(d!==void 0){let u=n.verticalExaggeration,R=n.verticalExaggerationRelativeHeight;if(u!==1&&(r=!1,a.minimumHeight=Ps.getHeight(a.minimumHeight,u,R),a.maximumHeight=Ps.getHeight(a.maximumHeight,u,R)),r)i.boundingVolumeIsFromMesh||(a._orientedBoundingBox=ci.clone(m.orientedBoundingBox,a._orientedBoundingBox),a._boundingSphere=Ft.clone(m.boundingSphere3D,a._boundingSphere),i.occludeePointInScaledSpace=p.clone(m.occludeePointInScaledSpace,i.occludeePointInScaledSpace),c(i.occludeePointInScaledSpace)||(i.occludeePointInScaledSpace=v1t(e,a._orientedBoundingBox.center,t.rectangle,a.minimumHeight,a.maximumHeight,i.occludeePointInScaledSpace)));else{let F=a._orientedBoundingBox===void 0||a._boundingSphere===void 0;(a.minimumHeight!==s||a.maximumHeight!==l||F)&&(a.computeBoundingVolumes(o),i.occludeePointInScaledSpace=v1t(e,a._orientedBoundingBox.center,t.rectangle,a.minimumHeight,a.maximumHeight,i.occludeePointInScaledSpace))}i.boundingVolumeSourceTile=d,i.boundingVolumeIsFromMesh=r}else i.boundingVolumeSourceTile=void 0,i.boundingVolumeIsFromMesh=!1}As.prototype.isDestroyed=function(){return!1};As.prototype.destroy=function(){return this._tileProvider=this._tileProvider&&this._tileProvider.destroy(),this._clippingPlanes=this._clippingPlanes&&this._clippingPlanes.destroy(),this._clippingPolygons=this._clippingPolygons&&this._clippingPolygons.destroy(),this._removeLayerAddedListener=this._removeLayerAddedListener&&this._removeLayerAddedListener(),this._removeLayerRemovedListener=this._removeLayerRemovedListener&&this._removeLayerRemovedListener(),this._removeLayerMovedListener=this._removeLayerMovedListener&&this._removeLayerMovedListener(),this._removeLayerShownListener=this._removeLayerShownListener&&this._removeLayerShownListener(),At(this)};function WCe(t,e,n){return function(i){let o,a,s=-1,l=i.data.imagery,r=l.length,d;for(d=0;d<r;++d)if(o=l[d],a=f(o.readyImagery,o.loadingImagery),a.imageryLayer===e){s=d;break}if(s!==-1){let m=s+t;if(o=l[m],a=c(o)?f(o.readyImagery,o.loadingImagery):void 0,!c(a)||a.imageryLayer!==e)return!e._createTileImagerySkeletons(i,n,m);for(d=s;d<m;++d)l[d].freeResources();l.splice(s,t)}return!0}}As.prototype._onLayerAdded=function(t,e){if(!this.isDestroyed()&&t.show){let n=this._terrainProvider,i=this,o=this._imageryLayersUpdatedEvent,a=function(){t._imageryCache={},i._quadtree.forEachLoadedTile(function(s){if(c(s._loadedCallbacks[t._layerIndex]))return;let l,r=s.data.imagery,d=r.length,m=-1,h=0;for(l=0;l<d;++l){let R=r[l];if(f(R.readyImagery,R.loadingImagery).imageryLayer===t)m===-1&&(m=l),++h;else if(m!==-1)break}if(m===-1)return;let u=m+h;t._createTileImagerySkeletons(s,n,u)&&(s._loadedCallbacks[t._layerIndex]=WCe(h,t,n),s.state=Br.LOADING)})};if(t.ready){let s=t.imageryProvider;s._reload=a}this._quadtree.forEachLoadedTile(function(s){t._createTileImagerySkeletons(s,n)&&(s.state=Br.LOADING,s.level!==0&&(s._lastSelectionResultFrame!==i.quadtree._lastSelectionFrameNumber||s._lastSelectionResult!==Pi.RENDERED)&&(s.renderable=!1))}),this._layerOrderChanged=!0,o.raiseEvent()}};As.prototype._onLayerRemoved=function(t,e){this._quadtree.forEachLoadedTile(function(n){let i=n.data.imagery,o=-1,a=0;for(let s=0,l=i.length;s<l;++s){let r=i[s],d=r.loadingImagery;if(c(d)||(d=r.readyImagery),d.imageryLayer===t)o===-1&&(o=s),r.freeResources(),++a;else if(o!==-1)break}o!==-1&&i.splice(o,a)}),c(t.imageryProvider)&&(t.imageryProvider._reload=void 0),this._imageryLayersUpdatedEvent.raiseEvent()};As.prototype._onLayerMoved=function(t,e,n){this._layerOrderChanged=!0,this._imageryLayersUpdatedEvent.raiseEvent()};As.prototype._onLayerShownOrHidden=function(t,e,n){n?this._onLayerAdded(t,e):this._onLayerRemoved(t,e)};var fCe=new L,FCe=new L;function K1t(t,e){let n={u_initialColor:function(){return this.properties.initialColor},u_fillHighlightColor:function(){return this.properties.fillHighlightColor},u_zoomedOutOceanSpecularIntensity:function(){return this.properties.zoomedOutOceanSpecularIntensity},u_oceanNormalMap:function(){return this.properties.oceanNormalMap},u_atmosphereLightIntensity:function(){return this.properties.atmosphereLightIntensity},u_atmosphereRayleighCoefficient:function(){return this.properties.atmosphereRayleighCoefficient},u_atmosphereMieCoefficient:function(){return this.properties.atmosphereMieCoefficient},u_atmosphereRayleighScaleHeight:function(){return this.properties.atmosphereRayleighScaleHeight},u_atmosphereMieScaleHeight:function(){return this.properties.atmosphereMieScaleHeight},u_atmosphereMieAnisotropy:function(){return this.properties.atmosphereMieAnisotropy},u_lightingFadeDistance:function(){return this.properties.lightingFadeDistance},u_nightFadeDistance:function(){return this.properties.nightFadeDistance},u_center3D:function(){return this.properties.center3D},u_verticalExaggerationAndRelativeHeight:function(){return this.properties.verticalExaggerationAndRelativeHeight},u_tileRectangle:function(){return this.properties.tileRectangle},u_modifiedModelView:function(){let i=t.context.uniformState.view,o=L.multiplyByPoint(i,this.properties.rtc,P1t);return L.setTranslation(i,o,w1t),w1t},u_modifiedModelViewProjection:function(){let i=t.context.uniformState.view,o=t.context.uniformState.projection,a=L.multiplyByPoint(i,this.properties.rtc,P1t);return L.setTranslation(i,a,Nz),L.multiply(o,Nz,Nz),Nz},u_dayTextures:function(){return this.properties.dayTextures},u_dayTextureTranslationAndScale:function(){return this.properties.dayTextureTranslationAndScale},u_dayTextureTexCoordsRectangle:function(){return this.properties.dayTextureTexCoordsRectangle},u_dayTextureUseWebMercatorT:function(){return this.properties.dayTextureUseWebMercatorT},u_dayTextureAlpha:function(){return this.properties.dayTextureAlpha},u_dayTextureNightAlpha:function(){return this.properties.dayTextureNightAlpha},u_dayTextureDayAlpha:function(){return this.properties.dayTextureDayAlpha},u_dayTextureBrightness:function(){return this.properties.dayTextureBrightness},u_dayTextureContrast:function(){return this.properties.dayTextureContrast},u_dayTextureHue:function(){return this.properties.dayTextureHue},u_dayTextureSaturation:function(){return this.properties.dayTextureSaturation},u_dayTextureOneOverGamma:function(){return this.properties.dayTextureOneOverGamma},u_dayIntensity:function(){return this.properties.dayIntensity},u_southAndNorthLatitude:function(){return this.properties.southAndNorthLatitude},u_southMercatorYAndOneOverHeight:function(){return this.properties.southMercatorYAndOneOverHeight},u_waterMask:function(){return this.properties.waterMask},u_waterMaskTranslationAndScale:function(){return this.properties.waterMaskTranslationAndScale},u_minMaxHeight:function(){return this.properties.minMaxHeight},u_scaleAndBias:function(){return this.properties.scaleAndBias},u_dayTextureSplit:function(){return this.properties.dayTextureSplit},u_dayTextureCutoutRectangles:function(){return this.properties.dayTextureCutoutRectangles},u_clippingPlanes:function(){let i=e._clippingPlanes;return c(i)&&c(i.texture)?i.texture:t.context.defaultTexture},u_cartographicLimitRectangle:function(){return this.properties.localizedCartographicLimitRectangle},u_clippingPlanesMatrix:function(){let i=e._clippingPlanes,o=c(i)?L.multiply(t.context.uniformState.view,i.modelMatrix,fCe):L.IDENTITY;return L.inverseTranspose(o,FCe)},u_clippingPlanesEdgeStyle:function(){let i=this.properties.clippingPlanesEdgeColor;return i.alpha=this.properties.clippingPlanesEdgeWidth,i},u_clippingDistance:function(){let i=e._clippingPolygons.clippingTexture;return c(i)?i:t.context.defaultTexture},u_clippingExtents:function(){let i=e._clippingPolygons.extentsTexture;return c(i)?i:t.context.defaultTexture},u_minimumBrightness:function(){return t.fog.minimumBrightness},u_hsbShift:function(){return this.properties.hsbShift},u_colorsToAlpha:function(){return this.properties.colorsToAlpha},u_frontFaceAlphaByDistance:function(){return this.properties.frontFaceAlphaByDistance},u_backFaceAlphaByDistance:function(){return this.properties.backFaceAlphaByDistance},u_translucencyRectangle:function(){return this.properties.localizedTranslucencyRectangle},u_undergroundColor:function(){return this.properties.undergroundColor},u_undergroundColorAlphaByDistance:function(){return this.properties.undergroundColorAlphaByDistance},u_lambertDiffuseMultiplier:function(){return this.properties.lambertDiffuseMultiplier},u_vertexShadowDarkness:function(){return this.properties.vertexShadowDarkness},properties:{initialColor:new bt(0,0,.5,1),fillHighlightColor:new v(0,0,0,0),zoomedOutOceanSpecularIntensity:.5,oceanNormalMap:void 0,lightingFadeDistance:new K(65e5,9e6),nightFadeDistance:new K(1e7,4e7),atmosphereLightIntensity:10,atmosphereRayleighCoefficient:new p(55e-7,13e-6,284e-7),atmosphereMieCoefficient:new p(21e-6,21e-6,21e-6),atmosphereRayleighScaleHeight:1e4,atmosphereMieScaleHeight:3200,atmosphereMieAnisotropy:.9,hsbShift:new p,center3D:void 0,rtc:new p,modifiedModelView:new L,tileRectangle:new bt,verticalExaggerationAndRelativeHeight:new K(1,0),dayTextures:[],dayTextureTranslationAndScale:[],dayTextureTexCoordsRectangle:[],dayTextureUseWebMercatorT:[],dayTextureAlpha:[],dayTextureNightAlpha:[],dayTextureDayAlpha:[],dayTextureBrightness:[],dayTextureContrast:[],dayTextureHue:[],dayTextureSaturation:[],dayTextureOneOverGamma:[],dayTextureSplit:[],dayTextureCutoutRectangles:[],dayIntensity:0,colorsToAlpha:[],southAndNorthLatitude:new K,southMercatorYAndOneOverHeight:new K,waterMask:void 0,waterMaskTranslationAndScale:new bt,minMaxHeight:new K,scaleAndBias:new L,clippingPlanesEdgeColor:v.clone(v.WHITE),clippingPlanesEdgeWidth:0,localizedCartographicLimitRectangle:new bt,frontFaceAlphaByDistance:new bt,backFaceAlphaByDistance:new bt,localizedTranslucencyRectangle:new bt,undergroundColor:v.clone(v.TRANSPARENT),undergroundColorAlphaByDistance:new bt,lambertDiffuseMultiplier:0,vertexShadowDarkness:0}};return c(e.materialUniformMap)?ze(n,e.materialUniformMap):n}function UCe(t,e,n){let i=n.data,o,a;if(c(i.vertexArray)?(o=i.mesh,a=i.vertexArray):c(i.fill)&&c(i.fill.vertexArray)&&(o=i.fill.mesh,a=i.fill.vertexArray),!(!c(o)||!c(a))){if(c(i.wireframeVertexArray)){if(i.wireframeVertexArray.mesh===o)return;i.wireframeVertexArray.destroy(),i.wireframeVertexArray=void 0}i.wireframeVertexArray=GCe(t,a,o),i.wireframeVertexArray.mesh=o}}function GCe(t,e,n){let o={indices:n.indices,primitiveType:le.TRIANGLES};gi.toWireframe(o);let a=o.indices,s=we.createIndexBuffer({context:t,typedArray:a,usage:ce.STATIC_DRAW,indexDatatype:re.fromSizeInBytes(a.BYTES_PER_ELEMENT)});return new Ki({context:t,attributes:e._attributes,indexBuffer:s})}var $1t,tNt,Bz;(function(){let t=new $e({geometry:tu.fromDimensions({dimensions:new p(2,2,2)})}),e=new $e({geometry:new g0({radius:1})}),n=new L,i,o;function a(s){return new Wi({geometryInstances:s,appearance:new jn({translucent:!1,flat:!0}),asynchronous:!1})}$1t=function(s,l){return s===i||(Bz(),i=s,n=L.fromRotationTranslation(s.halfAxes,s.center,n),t.modelMatrix=n,t.attributes.color=En.fromColor(l),o=a(t)),o},tNt=function(s,l){return s===i||(Bz(),i=s,n=L.fromTranslation(s.center,n),n=L.multiplyByUniformScale(n,s.radius,n),e.modelMatrix=n,e.attributes.color=En.fromColor(l),o=a(e)),o},Bz=function(){c(o)&&(o.destroy(),o=void 0,i=void 0)}})();var ACe=new bt(0,0,0,0),SCe={frameState:void 0,surfaceTile:void 0,numberOfDayTextures:void 0,applyBrightness:void 0,applyContrast:void 0,applyHue:void 0,applySaturation:void 0,applyGamma:void 0,applyAlpha:void 0,applyDayNightAlpha:void 0,applySplit:void 0,showReflectiveOcean:void 0,showOceanWaves:void 0,enableLighting:void 0,dynamicAtmosphereLighting:void 0,dynamicAtmosphereLightingFromSun:void 0,showGroundAtmosphere:void 0,perFragmentGroundAtmosphere:void 0,hasVertexNormals:void 0,useWebMercatorProjection:void 0,enableFog:void 0,enableClippingPlanes:void 0,clippingPlanes:void 0,enableClippingPolygons:void 0,clippingPolygons:void 0,clippedByBoundaries:void 0,hasImageryLayerCutout:void 0,colorCorrect:void 0,colorToAlpha:void 0,hasGeodeticSurfaceNormals:void 0,hasExaggeration:void 0},TCe=v.TRANSPARENT,gCe=new ln;function ECe(t,e,n){let i=e.data;c(i.vertexArray)||(i.fill===void 0&&(i.fill=new B1(e)),i.fill.update(t,n));let o=n.creditDisplay,a=i.terrainData;if(c(a)&&c(a.credits)){let Ct=a.credits;for(let _t=0,Je=Ct.length;_t<Je;++_t)o.addCreditToNextFrame(Ct[_t])}let s=Tn.maximumTextureImageUnits,l=i.waterMaskTexture,r=i.waterMaskTranslationAndScale;!c(l)&&c(i.fill)&&(l=i.fill.waterMaskTexture,r=i.fill.waterMaskTranslationAndScale);let d=n.cameraUnderground,m=n.globeTranslucencyState,h=m.translucent,u=m.frontFaceAlphaByDistance,R=m.backFaceAlphaByDistance,V=m.rectangle,F=f(t.undergroundColor,TCe),U=f(t.undergroundColorAlphaByDistance,gCe),G=q1t(t,n)&&n.mode===Vt.SCENE3D&&F.alpha>0&&(U.nearValue>0||U.farValue>0),A=t.lambertDiffuseMultiplier,S=t.vertexShadowDarkness,g=t.hasWaterMask&&c(l),C=t.oceanNormalMap,y=g&&c(C),Y=t.terrainProvider,Q=c(Y)&&t.terrainProvider.hasVertexNormals,J=n.fog.enabled&&n.fog.renderable&&!d,M=t.showGroundAtmosphere&&n.mode===Vt.SCENE3D,Z=Vi.castShadows(t.shadows)&&!h,E=Vi.receiveShadows(t.shadows)&&!h,I=t.hueShift,B=t.saturationShift,X=t.brightnessShift,_=!(k.equalsEpsilon(I,0,k.EPSILON7)&&k.equalsEpsilon(B,0,k.EPSILON7)&&k.equalsEpsilon(X,0,k.EPSILON7)),P=!1;if(M){let Ct=p.magnitude(n.camera.positionWC),_t=t.nightFadeOutDistance;P=Ct>_t}g&&--s,y&&--s,c(n.shadowState)&&n.shadowState.shadowsEnabled&&--s,c(t.clippingPlanes)&&t.clippingPlanes.enabled&&--s,c(t.clippingPolygons)&&t.clippingPolygons.enabled&&(--s,--s),s-=m.numberOfTextureUniforms;let w=i.renderedMesh,z=w.center,H=w.encoding,nt=i.tileBoundingRegion,$=n.verticalExaggeration,dt=n.verticalExaggerationRelativeHeight,q=$!==1,at=H.hasGeodeticSurfaceNormals,st=mCe,Et=0,Qt=0,Wt=0,Nt=0,kt=!1;if(n.mode!==Vt.SCENE3D){let Ct=n.mapProjection,_t=Ct.project(Gt.southwest(e.rectangle),uCe),Je=Ct.project(Gt.northeast(e.rectangle),ZCe);if(st.x=_t.x,st.y=_t.y,st.z=Je.x,st.w=Je.y,n.mode!==Vt.MORPHING&&(z=VCe,z.x=0,z.y=(st.z+st.x)*.5,z.z=(st.w+st.y)*.5,st.x-=z.y,st.y-=z.z,st.z-=z.y,st.w-=z.z),n.mode===Vt.SCENE2D&&H.quantization===yr.BITS12){let xe=1/(Math.pow(2,12)-1)*.5,oo=(st.z-st.x)*xe,ea=(st.w-st.y)*xe;st.x-=oo,st.y-=ea,st.z+=oo,st.w+=ea}Ct instanceof Yo&&(Et=e.rectangle.south,Qt=e.rectangle.north,Wt=Yo.geodeticLatitudeToMercatorAngle(Et),Nt=1/(Yo.geodeticLatitudeToMercatorAngle(Qt)-Wt),kt=!0)}let Mt=SCe;Mt.frameState=n,Mt.surfaceTile=i,Mt.showReflectiveOcean=g,Mt.showOceanWaves=y,Mt.enableLighting=t.enableLighting,Mt.dynamicAtmosphereLighting=t.dynamicAtmosphereLighting,Mt.dynamicAtmosphereLightingFromSun=t.dynamicAtmosphereLightingFromSun,Mt.showGroundAtmosphere=M,Mt.atmosphereLightIntensity=t.atmosphereLightIntensity,Mt.atmosphereRayleighCoefficient=t.atmosphereRayleighCoefficient,Mt.atmosphereMieCoefficient=t.atmosphereMieCoefficient,Mt.atmosphereRayleighScaleHeight=t.atmosphereRayleighScaleHeight,Mt.atmosphereMieScaleHeight=t.atmosphereMieScaleHeight,Mt.atmosphereMieAnisotropy=t.atmosphereMieAnisotropy,Mt.perFragmentGroundAtmosphere=P,Mt.hasVertexNormals=Q,Mt.useWebMercatorProjection=kt,Mt.clippedByBoundaries=i.clippedByBoundaries,Mt.hasGeodeticSurfaceNormals=at,Mt.hasExaggeration=q;let qt=i.imagery,ie=0,oe=qt.length,He=t.showSkirts&&!d&&!h,rn=t.backFaceCulling&&!d&&!h,de=rn?t._renderState:t._disableCullingRenderState,zt=rn?t._blendRenderState:t._disableCullingBlendRenderState,ke=de,Ve=t._firstPassInitialColor,We=n.context;if(c(t._debug.boundingSphereTile)||Bz(),t._materialUniformMap!==t.materialUniformMap){t._materialUniformMap=t.materialUniformMap;let Ct=t._drawCommands.length;for(let _t=0;_t<Ct;++_t)t._uniformMaps[_t]=K1t(n,t)}do{let Ct=0,_t,Je;if(t._drawCommands.length<=t._usedDrawCommands?(_t=new Ee,_t.owner=e,_t.cull=!1,_t.boundingVolume=new Ft,_t.orientedBoundingBox=void 0,Je=K1t(n,t),t._drawCommands.push(_t),t._uniformMaps.push(Je)):(_t=t._drawCommands[t._usedDrawCommands],Je=t._uniformMaps[t._usedDrawCommands]),_t.owner=e,++t._usedDrawCommands,e===t._debug.boundingSphereTile){let zi=nt.boundingVolume,js=nt.boundingSphere;c(zi)?$1t(zi,v.RED).update(n):c(js)&&tNt(js,v.RED).update(n)}let xe=Je.properties;bt.clone(Ve,xe.initialColor),xe.oceanNormalMap=C,xe.lightingFadeDistance.x=t.lightingFadeOutDistance,xe.lightingFadeDistance.y=t.lightingFadeInDistance,xe.nightFadeDistance.x=t.nightFadeOutDistance,xe.nightFadeDistance.y=t.nightFadeInDistance,xe.atmosphereLightIntensity=t.atmosphereLightIntensity,xe.atmosphereRayleighCoefficient=t.atmosphereRayleighCoefficient,xe.atmosphereMieCoefficient=t.atmosphereMieCoefficient,xe.atmosphereRayleighScaleHeight=t.atmosphereRayleighScaleHeight,xe.atmosphereMieScaleHeight=t.atmosphereMieScaleHeight,xe.atmosphereMieAnisotropy=t.atmosphereMieAnisotropy,xe.zoomedOutOceanSpecularIntensity=t.zoomedOutOceanSpecularIntensity;let oo=d?R:u,ea=d?u:R;c(oo)&&(bt.fromElements(oo.near,oo.nearValue,oo.far,oo.farValue,xe.frontFaceAlphaByDistance),bt.fromElements(ea.near,ea.nearValue,ea.far,ea.farValue,xe.backFaceAlphaByDistance)),bt.fromElements(U.near,U.nearValue,U.far,U.farValue,xe.undergroundColorAlphaByDistance),v.clone(F,xe.undergroundColor),xe.lambertDiffuseMultiplier=A,xe.vertexShadowDarkness=S;let gs=!c(i.vertexArray)&&c(t.fillHighlightColor)&&t.fillHighlightColor.alpha>0;gs&&v.clone(t.fillHighlightColor,xe.fillHighlightColor),xe.verticalExaggerationAndRelativeHeight.x=$,xe.verticalExaggerationAndRelativeHeight.y=dt,xe.center3D=w.center,p.clone(z,xe.rtc),bt.clone(st,xe.tileRectangle),xe.southAndNorthLatitude.x=Et,xe.southAndNorthLatitude.y=Qt,xe.southMercatorYAndOneOverHeight.x=Wt,xe.southMercatorYAndOneOverHeight.y=Nt;let is=hCe,ja=yz(e.rectangle,t.cartographicLimitRectangle),qn=pCe,ae=yz(e.rectangle,V);p.fromElements(I,B,X,xe.hsbShift);let fe=e.rectangle,ge=1/fe.width,ue=1/fe.height;is.x=(ja.west-fe.west)*ge,is.y=(ja.south-fe.south)*ue,is.z=(ja.east-fe.west)*ge,is.w=(ja.north-fe.south)*ue,bt.clone(is,xe.localizedCartographicLimitRectangle),qn.x=(ae.west-fe.west)*ge,qn.y=(ae.south-fe.south)*ue,qn.z=(ae.east-fe.west)*ge,qn.w=(ae.north-fe.south)*ue,bt.clone(qn,xe.localizedTranslucencyRectangle);let Ke=J&&k.fog(e._distance,n.fog.density)>k.EPSILON3;_=_&&(Ke||M);let An=!1,si=!1,da=!1,_a=!1,Rl=!1,na=!1,Go=!1,Ao=!1,Xs=!1,Es=!1;for(;Ct<s&&ie<oe;){let zi=qt[ie],js=zi.readyImagery;if(++ie,!c(js)||js.imageryLayer.alpha===0)continue;let ca=zi.useWebMercatorT?js.textureWebMercator:js.texture,$n=js.imageryLayer;c(zi.textureTranslationAndScale)||(zi.textureTranslationAndScale=$n._calculateTextureTranslationAndScale(e,zi)),xe.dayTextures[Ct]=ca,xe.dayTextureTranslationAndScale[Ct]=zi.textureTranslationAndScale,xe.dayTextureTexCoordsRectangle[Ct]=zi.textureCoordinateRectangle,xe.dayTextureUseWebMercatorT[Ct]=zi.useWebMercatorT,xe.dayTextureAlpha[Ct]=$n.alpha,na=na||xe.dayTextureAlpha[Ct]!==1,xe.dayTextureNightAlpha[Ct]=$n.nightAlpha,Go=Go||xe.dayTextureNightAlpha[Ct]!==1,xe.dayTextureDayAlpha[Ct]=$n.dayAlpha,Go=Go||xe.dayTextureDayAlpha[Ct]!==1,xe.dayTextureBrightness[Ct]=$n.brightness,An=An||xe.dayTextureBrightness[Ct]!==$r.DEFAULT_BRIGHTNESS,xe.dayTextureContrast[Ct]=$n.contrast,si=si||xe.dayTextureContrast[Ct]!==$r.DEFAULT_CONTRAST,xe.dayTextureHue[Ct]=$n.hue,da=da||xe.dayTextureHue[Ct]!==$r.DEFAULT_HUE,xe.dayTextureSaturation[Ct]=$n.saturation,_a=_a||xe.dayTextureSaturation[Ct]!==$r.DEFAULT_SATURATION,xe.dayTextureOneOverGamma[Ct]=1/$n.gamma,Rl=Rl||xe.dayTextureOneOverGamma[Ct]!==1/$r.DEFAULT_GAMMA,xe.dayTextureSplit[Ct]=$n.splitDirection,Ao=Ao||xe.dayTextureSplit[Ct]!==0;let mr=xe.dayTextureCutoutRectangles[Ct];if(c(mr)||(mr=xe.dayTextureCutoutRectangles[Ct]=new bt),bt.clone(bt.ZERO,mr),c($n.cutoutRectangle)){let hs=yz(fe,$n.cutoutRectangle),ma=Gt.simpleIntersection(hs,fe,j1t);Xs=c(ma)||Xs,mr.x=(hs.west-fe.west)*ge,mr.y=(hs.south-fe.south)*ue,mr.z=(hs.east-fe.west)*ge,mr.w=(hs.north-fe.south)*ue}let hr=xe.colorsToAlpha[Ct];c(hr)||(hr=xe.colorsToAlpha[Ct]=new bt);let pr=c($n.colorToAlpha)&&$n.colorToAlphaThreshold>0;if(Es=Es||pr,pr){let hs=$n.colorToAlpha;hr.x=hs.red,hr.y=hs.green,hr.z=hs.blue,hr.w=$n.colorToAlphaThreshold}else hr.w=-1;if(c(js.credits)){let hs=js.credits;for(let ma=0,Ed=hs.length;ma<Ed;++ma)o.addCreditToNextFrame(hs[ma])}++Ct}xe.dayTextures.length=Ct,xe.waterMask=l,bt.clone(r,xe.waterMaskTranslationAndScale),xe.minMaxHeight.x=H.minimumHeight,xe.minMaxHeight.y=H.maximumHeight,L.clone(H.matrix,xe.scaleAndBias);let wl=t._clippingPlanes,ka=c(wl)&&wl.enabled&&e.isClipped;ka&&(xe.clippingPlanesEdgeColor=v.clone(wl.edgeColor,xe.clippingPlanesEdgeColor),xe.clippingPlanesEdgeWidth=wl.edgeWidth);let Wa=t._clippingPolygons,JV=c(Wa)&&Wa.enabled&&e.isClipped;Mt.numberOfDayTextures=Ct,Mt.applyBrightness=An,Mt.applyContrast=si,Mt.applyHue=da,Mt.applySaturation=_a,Mt.applyGamma=Rl,Mt.applyAlpha=na,Mt.applyDayNightAlpha=Go,Mt.applySplit=Ao,Mt.enableFog=Ke,Mt.enableClippingPlanes=ka,Mt.clippingPlanes=wl,Mt.enableClippingPolygons=JV,Mt.clippingPolygons=Wa,Mt.hasImageryLayerCutout=Xs,Mt.colorCorrect=_,Mt.highlightFillTile=gs,Mt.colorToAlpha=Es,Mt.showUndergroundColor=G,Mt.translucent=h;let yl=i.renderedMesh.indices.length;He||(yl=i.renderedMesh.indexCountWithoutSkirts),_t.shaderProgram=t._surfaceShaderSet.getShaderProgram(Mt),_t.castShadows=Z,_t.receiveShadows=E,_t.renderState=ke,_t.primitiveType=le.TRIANGLES,_t.vertexArray=i.vertexArray||i.fill.vertexArray,_t.count=yl,_t.uniformMap=Je,_t.pass=Pt.GLOBE,t._debug.wireframe&&(UCe(We,t,e),c(i.wireframeVertexArray)&&(_t.vertexArray=i.wireframeVertexArray,_t.primitiveType=le.LINES,_t.count=yl*2));let Bi=_t.boundingVolume,sd=_t.orientedBoundingBox;n.mode!==Vt.SCENE3D?(Ft.fromRectangleWithHeights2D(e.rectangle,n.mapProjection,nt.minimumHeight,nt.maximumHeight,Bi),p.fromElements(Bi.center.z,Bi.center.x,Bi.center.y,Bi.center),n.mode===Vt.MORPHING&&(Bi=Ft.union(nt.boundingSphere,Bi,Bi))):(_t.boundingVolume=Ft.clone(nt.boundingSphere,Bi),_t.orientedBoundingBox=ci.clone(nt.boundingVolume,sd)),_t.dirty=!0,h&&m.updateDerivedCommands(_t,n),z1t(_t,n),ke=zt,Ve=ACe}while(ie<oe)}var qM=As;var KFo=b(W(),1);function eNt(){this._enabled=!1,this._frontFaceAlpha=1,this._frontFaceAlphaByDistance=void 0,this._backFaceAlpha=1,this._backFaceAlphaByDistance=void 0,this._rectangle=Gt.clone(Gt.MAX_VALUE)}Object.defineProperties(eNt.prototype,{enabled:{get:function(){return this._enabled},set:function(t){this._enabled=t}},frontFaceAlpha:{get:function(){return this._frontFaceAlpha},set:function(t){this._frontFaceAlpha=t}},frontFaceAlphaByDistance:{get:function(){return this._frontFaceAlphaByDistance},set:function(t){this._frontFaceAlphaByDistance=ln.clone(t,this._frontFaceAlphaByDistance)}},backFaceAlpha:{get:function(){return this._backFaceAlpha},set:function(t){this._backFaceAlpha=t}},backFaceAlphaByDistance:{get:function(){return this._backFaceAlphaByDistance},set:function(t){this._backFaceAlphaByDistance=ln.clone(t,this._backFaceAlphaByDistance)}},rectangle:{get:function(){return this._rectangle},set:function(t){c(t)||(t=Gt.clone(Gt.MAX_VALUE)),Gt.clone(t,this._rectangle)}}});var $M=eNt;var oUo=b(W(),1);function dr(){this._layers=[],this.layerAdded=new It,this.layerRemoved=new It,this.layerMoved=new It,this.layerShownOrHidden=new It}Object.defineProperties(dr.prototype,{length:{get:function(){return this._layers.length}}});dr.prototype.add=function(t,e){c(e)?this._layers.splice(e,0,t):(e=this._layers.length,this._layers.push(t)),this._update(),this.layerAdded.raiseEvent(t,e);let i=t.readyEvent.addEventListener(()=>{this.layerShownOrHidden.raiseEvent(t,t._layerIndex,t.show),i()})};dr.prototype.addImageryProvider=function(t,e){let n=new $r(t);return this.add(n,e),n};dr.prototype.remove=function(t,e){e=f(e,!0);let n=this._layers.indexOf(t);return n!==-1?(this._layers.splice(n,1),this._update(),this.layerRemoved.raiseEvent(t,n),e&&t.destroy(),!0):!1};dr.prototype.removeAll=function(t){t=f(t,!0);let e=this._layers;for(let n=0,i=e.length;n<i;n++){let o=e[n];this.layerRemoved.raiseEvent(o,n),t&&o.destroy()}this._layers=[]};dr.prototype.contains=function(t){return this.indexOf(t)!==-1};dr.prototype.indexOf=function(t){return this._layers.indexOf(t)};dr.prototype.get=function(t){return this._layers[t]};function Qz(t,e){return t.indexOf(e)}function nNt(t,e,n){let i=t._layers;if(e=k.clamp(e,0,i.length-1),n=k.clamp(n,0,i.length-1),e===n)return;let o=i[e];i[e]=i[n],i[n]=o,t._update(),t.layerMoved.raiseEvent(o,n,e)}dr.prototype.raise=function(t){let e=Qz(this._layers,t);nNt(this,e,e+1)};dr.prototype.lower=function(t){let e=Qz(this._layers,t);nNt(this,e,e-1)};dr.prototype.raiseToTop=function(t){let e=Qz(this._layers,t);e!==this._layers.length-1&&(this._layers.splice(e,1),this._layers.push(t),this._update(),this.layerMoved.raiseEvent(t,this._layers.length-1,e))};dr.prototype.lowerToBottom=function(t){let e=Qz(this._layers,t);e!==0&&(this._layers.splice(e,1),this._layers.splice(0,0,t),this._update(),this.layerMoved.raiseEvent(t,0,e))};var CCe=new Gt;function iNt(t,e,n,i){let o=t.globe._surface._tilesToRender,a;for(let l=0;!c(a)&&l<o.length;++l){let r=o[l];Gt.contains(r.rectangle,e)&&(a=r)}if(!c(a))return;let s=a.data.imagery;for(let l=s.length-1;l>=0;--l){let r=s[l],d=r.readyImagery;if(!c(d)||!d.imageryLayer.ready)continue;let m=d.imageryLayer.imageryProvider;if(n&&!c(m.pickFeatures)||!Gt.contains(d.rectangle,e))continue;let h=CCe,u=1/1024;h.west=k.lerp(a.rectangle.west,a.rectangle.east,r.textureCoordinateRectangle.x-u),h.east=k.lerp(a.rectangle.west,a.rectangle.east,r.textureCoordinateRectangle.z+u),h.south=k.lerp(a.rectangle.south,a.rectangle.north,r.textureCoordinateRectangle.y-u),h.north=k.lerp(a.rectangle.south,a.rectangle.north,r.textureCoordinateRectangle.w+u),Gt.contains(h,e)&&i(d)}}dr.prototype.pickImageryLayers=function(t,e){let n=e.globe.pick(t,e);if(!c(n))return;let i=e.globe.ellipsoid.cartesianToCartographic(n),o=[];if(iNt(e,i,!1,function(a){o.push(a.imageryLayer)}),o.length!==0)return o};dr.prototype.pickImageryLayerFeatures=function(t,e){let n=e.globe.pick(t,e);if(!c(n))return;let i=e.globe.ellipsoid.cartesianToCartographic(n),o=[],a=[];if(iNt(e,i,!0,function(s){if(!s.imageryLayer.ready)return;let r=s.imageryLayer.imageryProvider.pickFeatures(s.x,s.y,s.level,i.longitude,i.latitude);c(r)&&(o.push(r),a.push(s.imageryLayer))}),o.length!==0)return Promise.all(o).then(function(s){let l=[];for(let r=0;r<s.length;++r){let d=s[r],m=a[r];if(c(d)&&d.length>0)for(let h=0;h<d.length;++h){let u=d[h];u.imageryLayer=m,c(u.position)||(u.position=i),l.push(u)}}return l})};dr.prototype.queueReprojectionCommands=function(t){let e=this._layers;for(let n=0,i=e.length;n<i;++n)e[n].queueReprojectionCommands(t)};dr.prototype.cancelReprojections=function(){let t=this._layers;for(let e=0,n=t.length;e<n;++e)t[e].cancelReprojections()};dr.prototype.isDestroyed=function(){return!1};dr.prototype.destroy=function(){return this.removeAll(!0),At(this)};dr.prototype._update=function(){let t=!0,e=this._layers,n,i,o,a;for(o=0,a=e.length;o<a;++o)i=e[o],i._layerIndex=o,i.show?(i._isBaseLayer=t,t=!1):i._isBaseLayer=!1,i.show!==i._show&&(c(i._show)&&(c(n)||(n=[]),n.push(i)),i._show=i.show);if(c(n))for(o=0,a=n.length;o<a;++o)i=n[o],this.layerShownOrHidden.raiseEvent(i,i._layerIndex,i.show)};var t_=dr;var XUo=b(W(),1);var rUo=b(W(),1);function oNt(t){this._ellipsoid=new Bu(t.ellipsoid,p.ZERO)}Object.defineProperties(oNt.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});var e_=oNt;var VUo=b(W(),1);function tm(t){this._tilingScheme=t.tilingScheme,this._x=t.x,this._y=t.y,this._level=t.level,this._parent=t.parent,this._rectangle=this._tilingScheme.tileXYToRectangle(this._x,this._y,this._level),this._southwestChild=void 0,this._southeastChild=void 0,this._northwestChild=void 0,this._northeastChild=void 0,this.replacementPrevious=void 0,this.replacementNext=void 0,this._distance=0,this._loadPriority=0,this._customData=[],this._frameUpdated=void 0,this._lastSelectionResult=Pi.NONE,this._lastSelectionResultFrame=void 0,this._loadedCallbacks={},this.state=Br.START,this.renderable=!1,this.upsampledFromParent=!1,this.data=void 0}tm.createLevelZeroTiles=function(t){let e=t.getNumberOfXTilesAtLevel(0),n=t.getNumberOfYTilesAtLevel(0),i=new Array(e*n),o=0;for(let a=0;a<n;++a)for(let s=0;s<e;++s)i[o++]=new tm({tilingScheme:t,x:s,y:a,level:0});return i};tm.prototype._updateCustomData=function(t,e,n){let i=this.customData,o,a,s;if(c(e)&&c(n)){for(i=i.filter(function(l){return n.indexOf(l)===-1}),this._customData=i,s=this._rectangle,o=0;o<e.length;++o)a=e[o],Gt.contains(s,a.positionCartographic)&&i.push(a);this._frameUpdated=t}else{let l=this._parent;if(c(l)&&this._frameUpdated!==l._frameUpdated){i.length=0,s=this._rectangle;let r=l.customData;for(o=0;o<r.length;++o)a=r[o],Gt.contains(s,a.positionCartographic)&&i.push(a);this._frameUpdated=l._frameUpdated}}};Object.defineProperties(tm.prototype,{tilingScheme:{get:function(){return this._tilingScheme}},x:{get:function(){return this._x}},y:{get:function(){return this._y}},level:{get:function(){return this._level}},parent:{get:function(){return this._parent}},rectangle:{get:function(){return this._rectangle}},children:{get:function(){return[this.northwestChild,this.northeastChild,this.southwestChild,this.southeastChild]}},southwestChild:{get:function(){return c(this._southwestChild)||(this._southwestChild=new tm({tilingScheme:this.tilingScheme,x:this.x*2,y:this.y*2+1,level:this.level+1,parent:this})),this._southwestChild}},southeastChild:{get:function(){return c(this._southeastChild)||(this._southeastChild=new tm({tilingScheme:this.tilingScheme,x:this.x*2+1,y:this.y*2+1,level:this.level+1,parent:this})),this._southeastChild}},northwestChild:{get:function(){return c(this._northwestChild)||(this._northwestChild=new tm({tilingScheme:this.tilingScheme,x:this.x*2,y:this.y*2,level:this.level+1,parent:this})),this._northwestChild}},northeastChild:{get:function(){return c(this._northeastChild)||(this._northeastChild=new tm({tilingScheme:this.tilingScheme,x:this.x*2+1,y:this.y*2,level:this.level+1,parent:this})),this._northeastChild}},customData:{get:function(){return this._customData}},needsLoading:{get:function(){return this.state<Br.DONE}},eligibleForUnloading:{get:function(){let t=!0;return c(this.data)&&(t=this.data.eligibleForUnloading,c(t)||(t=!0)),t}}});tm.prototype.findLevelZeroTile=function(t,e,n){let i=this.tilingScheme.getNumberOfXTilesAtLevel(0);if(e<0?e+=i:e>=i&&(e-=i),!(n<0||n>=this.tilingScheme.getNumberOfYTilesAtLevel(0)))return t.filter(function(o){return o.x===e&&o.y===n})[0]};tm.prototype.findTileToWest=function(t){let e=this.parent;if(e===void 0)return this.findLevelZeroTile(t,this.x-1,this.y);if(e.southeastChild===this)return e.southwestChild;if(e.northeastChild===this)return e.northwestChild;let n=e.findTileToWest(t);if(n!==void 0)return e.southwestChild===this?n.southeastChild:n.northeastChild};tm.prototype.findTileToEast=function(t){let e=this.parent;if(e===void 0)return this.findLevelZeroTile(t,this.x+1,this.y);if(e.southwestChild===this)return e.southeastChild;if(e.northwestChild===this)return e.northeastChild;let n=e.findTileToEast(t);if(n!==void 0)return e.southeastChild===this?n.southwestChild:n.northwestChild};tm.prototype.findTileToSouth=function(t){let e=this.parent;if(e===void 0)return this.findLevelZeroTile(t,this.x,this.y+1);if(e.northwestChild===this)return e.southwestChild;if(e.northeastChild===this)return e.southeastChild;let n=e.findTileToSouth(t);if(n!==void 0)return e.southwestChild===this?n.northwestChild:n.northeastChild};tm.prototype.findTileToNorth=function(t){let e=this.parent;if(e===void 0)return this.findLevelZeroTile(t,this.x,this.y-1);if(e.southwestChild===this)return e.northwestChild;if(e.southeastChild===this)return e.northeastChild;let n=e.findTileToNorth(t);if(n!==void 0)return e.northwestChild===this?n.southwestChild:n.southeastChild};tm.prototype.freeResources=function(){this.state=Br.START,this.renderable=!1,this.upsampledFromParent=!1,c(this.data)&&c(this.data.freeResources)&&this.data.freeResources(),kz(this._southwestChild),this._southwestChild=void 0,kz(this._southeastChild),this._southeastChild=void 0,kz(this._northwestChild),this._northwestChild=void 0,kz(this._northeastChild),this._northeastChild=void 0};function kz(t){c(t)&&t.freeResources()}var n_=tm;var RUo=b(W(),1);function Yz(){this.head=void 0,this.tail=void 0,this.count=0,this._lastBeforeStartOfFrame=void 0}Yz.prototype.markStartOfRenderFrame=function(){this._lastBeforeStartOfFrame=this.head};Yz.prototype.trimTiles=function(t){let e=this.tail,n=!0;for(;n&&c(this._lastBeforeStartOfFrame)&&this.count>t&&c(e);){n=e!==this._lastBeforeStartOfFrame;let i=e.replacementPrevious;e.eligibleForUnloading&&(e.freeResources(),aNt(this,e)),e=i}};function aNt(t,e){let n=e.replacementPrevious,i=e.replacementNext;e===t._lastBeforeStartOfFrame&&(t._lastBeforeStartOfFrame=i),e===t.head?t.head=i:n.replacementNext=i,e===t.tail?t.tail=n:i.replacementPrevious=n,e.replacementPrevious=void 0,e.replacementNext=void 0,--t.count}Yz.prototype.markTileRendered=function(t){let e=this.head;if(e===t){t===this._lastBeforeStartOfFrame&&(this._lastBeforeStartOfFrame=t.replacementNext);return}if(++this.count,!c(e)){t.replacementPrevious=void 0,t.replacementNext=void 0,this.head=t,this.tail=t;return}(c(t.replacementPrevious)||c(t.replacementNext))&&aNt(this,t),t.replacementPrevious=void 0,t.replacementNext=e,e.replacementPrevious=t,this.head=t};var i_=Yz;function gV(t){this._tileProvider=t.tileProvider,this._tileProvider.quadtree=this,this._debug={enableDebugOutput:!1,maxDepth:0,maxDepthVisited:0,tilesVisited:0,tilesCulled:0,tilesRendered:0,tilesWaitingForChildren:0,lastMaxDepth:-1,lastMaxDepthVisited:-1,lastTilesVisited:-1,lastTilesCulled:-1,lastTilesRendered:-1,lastTilesWaitingForChildren:-1,suspendLodUpdate:!1};let n=this._tileProvider.tilingScheme.ellipsoid;this._tilesToRender=[],this._tileLoadQueueHigh=[],this._tileLoadQueueMedium=[],this._tileLoadQueueLow=[],this._tileReplacementQueue=new i_,this._levelZeroTiles=void 0,this._loadQueueTimeSlice=5,this._tilesInvalidated=!1,this._addHeightCallbacks=[],this._removeHeightCallbacks=[],this._tileToUpdateHeights=[],this._lastTileIndex=0,this._updateHeightsTimeSlice=2,this._cameraPositionCartographic=void 0,this._cameraReferenceFrameOriginCartographic=void 0,this.maximumScreenSpaceError=f(t.maximumScreenSpaceError,2),this.tileCacheSize=f(t.tileCacheSize,100),this.loadingDescendantLimit=20,this.preloadAncestors=!0,this.preloadSiblings=!1,this._occluders=new e_({ellipsoid:n}),this._tileLoadProgressEvent=new It,this._lastTileLoadQueueLength=0,this._lastSelectionFrameNumber=void 0}Object.defineProperties(gV.prototype,{tileProvider:{get:function(){return this._tileProvider}},tileLoadProgressEvent:{get:function(){return this._tileLoadProgressEvent}},occluders:{get:function(){return this._occluders}}});gV.prototype.invalidateAllTiles=function(){this._tilesInvalidated=!0};function ICe(t){let e=t._tileReplacementQueue;e.head=void 0,e.tail=void 0,e.count=0,lNt(t);let n=t._levelZeroTiles;if(c(n))for(let i=0;i<n.length;++i){let a=n[i].customData,s=a.length;for(let l=0;l<s;++l){let r=a[l];r.level=0,t._addHeightCallbacks.push(r)}n[i].freeResources()}t._levelZeroTiles=void 0,t._tileProvider.cancelReprojections()}gV.prototype.forEachLoadedTile=function(t){let e=this._tileReplacementQueue.head;for(;c(e);)e.state!==Br.START&&t(e),e=e.replacementNext};gV.prototype.forEachRenderedTile=function(t){let e=this._tilesToRender;for(let n=0,i=e.length;n<i;++n)t(e[n])};gV.prototype.updateHeight=function(t,e){let n=this,i={positionOnEllipsoidSurface:void 0,positionCartographic:t,level:-1,callback:e};return i.removeFunc=function(){let o=n._addHeightCallbacks,a=o.length;for(let s=0;s<a;++s)if(o[s]===i){o.splice(s,1);break}n._removeHeightCallbacks.push(i),i.callback&&(i.callback=void 0)},n._addHeightCallbacks.push(i),i.removeFunc};gV.prototype.update=function(t){c(this._tileProvider.update)&&this._tileProvider.update(t)};function lNt(t){let e=t._debug;e.maxDepth=0,e.maxDepthVisited=0,e.tilesVisited=0,e.tilesCulled=0,e.tilesRendered=0,e.tilesWaitingForChildren=0,t._tileLoadQueueHigh.length=0,t._tileLoadQueueMedium.length=0,t._tileLoadQueueLow.length=0}gV.prototype.beginFrame=function(t){t.passes.render&&(this._tilesInvalidated&&(ICe(this),this._tilesInvalidated=!1),this._tileProvider.initialize(t),lNt(this),!this._debug.suspendLodUpdate&&this._tileReplacementQueue.markStartOfRenderFrame())};gV.prototype.render=function(t){let e=t.passes,n=this._tileProvider;e.render&&(n.beginUpdate(t),QCe(this,t),OCe(this,t),n.endUpdate(t)),e.pick&&this._tilesToRender.length>0&&n.updateForPick(t)};function NCe(t,e){let n=t._tileLoadQueueHigh.length+t._tileLoadQueueMedium.length+t._tileLoadQueueLow.length;if(n!==t._lastTileLoadQueueLength||t._tilesInvalidated){let o=It.prototype.raiseEvent.bind(t._tileLoadProgressEvent,n);e.afterRender.push(()=>(o(),!0)),t._lastTileLoadQueueLength=n}let i=t._debug;i.enableDebugOutput&&!i.suspendLodUpdate&&(i.maxDepth=t._tilesToRender.reduce(function(o,a){return Math.max(o,a.level)},-1),i.tilesRendered=t._tilesToRender.length,(i.tilesVisited!==i.lastTilesVisited||i.tilesRendered!==i.lastTilesRendered||i.tilesCulled!==i.lastTilesCulled||i.maxDepth!==i.lastMaxDepth||i.tilesWaitingForChildren!==i.lastTilesWaitingForChildren||i.maxDepthVisited!==i.lastMaxDepthVisited)&&(console.log(`Visited ${i.tilesVisited}, Rendered: ${i.tilesRendered}, Culled: ${i.tilesCulled}, Max Depth Rendered: ${i.maxDepth}, Max Depth Visited: ${i.maxDepthVisited}, Waiting for children: ${i.tilesWaitingForChildren}`),i.lastTilesVisited=i.tilesVisited,i.lastTilesRendered=i.tilesRendered,i.lastTilesCulled=i.tilesCulled,i.lastMaxDepth=i.maxDepth,i.lastTilesWaitingForChildren=i.tilesWaitingForChildren,i.lastMaxDepthVisited=i.maxDepthVisited))}gV.prototype.endFrame=function(t){!t.passes.render||t.mode===Vt.MORPHING||(LCe(this,t),DCe(this,t),NCe(this,t))};gV.prototype.isDestroyed=function(){return!1};gV.prototype.destroy=function(){this._tileProvider=this._tileProvider&&this._tileProvider.destroy()};var a_,sNt=new gt;function yCe(t,e){let n=Gt.center(t.rectangle,sNt),i=n.longitude-a_.longitude,o=n.latitude-a_.latitude;n=Gt.center(e.rectangle,sNt);let a=n.longitude-a_.longitude,s=n.latitude-a_.latitude;return i*i+o*o-(a*a+s*s)}var BCe=new p,o_=[];function QCe(t,e){let n=t._debug;if(n.suspendLodUpdate)return;let i=t._tilesToRender;i.length=0;let o,a=t._tileProvider;if(!c(t._levelZeroTiles)){let F=a.tilingScheme;if(c(F)){let U=a.tilingScheme;t._levelZeroTiles=n_.createLevelZeroTiles(U);let G=t._levelZeroTiles.length;if(o_.length<G)for(o_=new Array(G),o=0;o<G;++o)o_[o]===void 0&&(o_[o]=new s_)}else return}t._occluders.ellipsoid.cameraPosition=e.camera.positionWC;let s,l=t._levelZeroTiles,r=l.length>1?t._occluders:void 0;a_=e.camera.positionCartographic,l.sort(yCe);let d=t._addHeightCallbacks,m=t._removeHeightCallbacks,h=e.frameNumber,u;if(d.length>0||m.length>0){for(o=0,u=l.length;o<u;++o)s=l[o],s._updateCustomData(h,d,m);d.length=0,m.length=0}let R=e.camera;t._cameraPositionCartographic=R.positionCartographic;let V=L.getTranslation(R.transform,BCe);for(t._cameraReferenceFrameOriginCartographic=t.tileProvider.tilingScheme.ellipsoid.cartesianToCartographic(V,t._cameraReferenceFrameOriginCartographic),o=0,u=l.length;o<u;++o)s=l[o],t._tileReplacementQueue.markTileRendered(s),s.renderable?Sd(t,s,a,e,r,!1,o_[o]):(VW(t,t._tileLoadQueueHigh,s,e),++n.tilesWaitingForChildren);t._lastSelectionFrameNumber=h}function VW(t,e,n,i){n.needsLoading&&(t.tileProvider.computeTileLoadPriority!==void 0&&(n._loadPriority=t.tileProvider.computeTileLoadPriority(n,i)),e.push(n))}function s_(){this.allAreRenderable=!0,this.anyWereRenderedLastFrame=!1,this.notYetRenderableCount=0}function rNt(){this.southwest=new s_,this.southeast=new s_,this.northwest=new s_,this.northeast=new s_}rNt.prototype.combine=function(t){let e=this.southwest,n=this.southeast,i=this.northwest,o=this.northeast;t.allAreRenderable=e.allAreRenderable&&n.allAreRenderable&&i.allAreRenderable&&o.allAreRenderable,t.anyWereRenderedLastFrame=e.anyWereRenderedLastFrame||n.anyWereRenderedLastFrame||i.anyWereRenderedLastFrame||o.anyWereRenderedLastFrame,t.notYetRenderableCount=e.notYetRenderableCount+n.notYetRenderableCount+i.notYetRenderableCount+o.notYetRenderableCount};var Hot=new Array(31);for(let t=0;t<Hot.length;++t)Hot[t]=new rNt;function kCe(t,e,n,i,o){let a=t._debug;++a.tilesVisited,t._tileReplacementQueue.markTileRendered(n),n._updateCustomData(e.frameNumber),n.level>a.maxDepthVisited&&(a.maxDepthVisited=n.level);let s=XCe(t,e,n)<t.maximumScreenSpaceError,l=n.southwestChild,r=n.southeastChild,d=n.northwestChild,m=n.northeastChild,h=t._lastSelectionFrameNumber,u=n._lastSelectionResultFrame===h?n._lastSelectionResult:Pi.NONE,R=t.tileProvider;if(s||i){let V=Pi.originalResult(u)===Pi.RENDERED,F=Pi.originalResult(u)===Pi.CULLED||u===Pi.NONE,U=n.state===Br.DONE,G=V||F||U;if(G||c(R.canRenderWithoutLosingDetail)&&(G=R.canRenderWithoutLosingDetail(n)),G){s&&VW(t,t._tileLoadQueueMedium,n,e),xz(t,n),o.allAreRenderable=n.renderable,o.anyWereRenderedLastFrame=u===Pi.RENDERED,o.notYetRenderableCount=n.renderable?0:1,n._lastSelectionResultFrame=e.frameNumber,n._lastSelectionResult=Pi.RENDERED,o.anyWereRenderedLastFrame||t._tileToUpdateHeights.push(n);return}i=!0,s&&VW(t,t._tileLoadQueueHigh,n,e)}if(R.canRefine(n)){if(l.upsampledFromParent&&r.upsampledFromParent&&d.upsampledFromParent&&m.upsampledFromParent){xz(t,n),VW(t,t._tileLoadQueueMedium,n,e),t._tileReplacementQueue.markTileRendered(l),t._tileReplacementQueue.markTileRendered(r),t._tileReplacementQueue.markTileRendered(d),t._tileReplacementQueue.markTileRendered(m),o.allAreRenderable=n.renderable,o.anyWereRenderedLastFrame=u===Pi.RENDERED,o.notYetRenderableCount=n.renderable?0:1,n._lastSelectionResultFrame=e.frameNumber,n._lastSelectionResult=Pi.RENDERED,o.anyWereRenderedLastFrame||t._tileToUpdateHeights.push(n);return}n._lastSelectionResultFrame=e.frameNumber,n._lastSelectionResult=Pi.REFINED;let F=t._tilesToRender.length,U=t._tileLoadQueueLow.length,G=t._tileLoadQueueMedium.length,A=t._tileLoadQueueHigh.length,S=t._tileToUpdateHeights.length;if(YCe(t,l,r,d,m,e,i,o),F!==t._tilesToRender.length){let g=o.allAreRenderable,C=o.anyWereRenderedLastFrame,y=o.notYetRenderableCount,Y=!1;if(!g&&!C){let Q=t._tilesToRender;for(let M=F;M<Q.length;++M){let Z=Q[M];for(;Z!==void 0&&Z._lastSelectionResult!==Pi.KICKED&&Z!==n;)Z._lastSelectionResult=Pi.kick(Z._lastSelectionResult),Z=Z.parent}t._tilesToRender.length=F,t._tileToUpdateHeights.length=S,xz(t,n),n._lastSelectionResult=Pi.RENDERED;let J=u===Pi.RENDERED;!J&&y>t.loadingDescendantLimit&&(t._tileLoadQueueLow.length=U,t._tileLoadQueueMedium.length=G,t._tileLoadQueueHigh.length=A,VW(t,t._tileLoadQueueMedium,n,e),o.notYetRenderableCount=n.renderable?0:1,Y=!0),o.allAreRenderable=n.renderable,o.anyWereRenderedLastFrame=J,J||t._tileToUpdateHeights.push(n),++a.tilesWaitingForChildren}t.preloadAncestors&&!Y&&VW(t,t._tileLoadQueueLow,n,e)}return}n._lastSelectionResultFrame=e.frameNumber,n._lastSelectionResult=Pi.RENDERED,xz(t,n),VW(t,t._tileLoadQueueHigh,n,e),o.allAreRenderable=n.renderable,o.anyWereRenderedLastFrame=u===Pi.RENDERED,o.notYetRenderableCount=n.renderable?0:1}function YCe(t,e,n,i,o,a,s,l){let r=a.camera.positionCartographic,d=t._tileProvider,m=t._occluders,h=Hot[e.level],u=h.southwest,R=h.southeast,V=h.northwest,F=h.northeast;r.longitude<e.rectangle.east?r.latitude<e.rectangle.north?(Sd(t,e,d,a,m,s,u),Sd(t,n,d,a,m,s,R),Sd(t,i,d,a,m,s,V),Sd(t,o,d,a,m,s,F)):(Sd(t,i,d,a,m,s,V),Sd(t,e,d,a,m,s,u),Sd(t,o,d,a,m,s,F),Sd(t,n,d,a,m,s,R)):r.latitude<e.rectangle.north?(Sd(t,n,d,a,m,s,R),Sd(t,e,d,a,m,s,u),Sd(t,o,d,a,m,s,F),Sd(t,i,d,a,m,s,V)):(Sd(t,o,d,a,m,s,F),Sd(t,i,d,a,m,s,V),Sd(t,n,d,a,m,s,R),Sd(t,e,d,a,m,s,u)),h.combine(l)}function xCe(t,e){let n=e.rectangle;return c(t._cameraPositionCartographic)&&Gt.contains(n,t._cameraPositionCartographic)||c(t._cameraReferenceFrameOriginCartographic)&&Gt.contains(n,t._cameraReferenceFrameOriginCartographic)}function Sd(t,e,n,i,o,a,s){if(n.computeTileVisibility(e,i,o)!==Ys.NONE)return kCe(t,i,e,a,s);if(++t._debug.tilesCulled,t._tileReplacementQueue.markTileRendered(e),s.allAreRenderable=!0,s.anyWereRenderedLastFrame=!1,s.notYetRenderableCount=0,xCe(t,e)){(!c(e.data)||!c(e.data.vertexArray))&&VW(t,t._tileLoadQueueMedium,e,i);let l=t._lastSelectionFrameNumber,r=e._lastSelectionResultFrame===l?e._lastSelectionResult:Pi.NONE;r!==Pi.CULLED_BUT_NEEDED&&r!==Pi.RENDERED&&t._tileToUpdateHeights.push(e),e._lastSelectionResult=Pi.CULLED_BUT_NEEDED}else t.preloadSiblings||e.level===0?(VW(t,t._tileLoadQueueLow,e,i),e._lastSelectionResult=Pi.CULLED):e._lastSelectionResult=Pi.CULLED;e._lastSelectionResultFrame=i.frameNumber}function XCe(t,e,n){if(e.mode===Vt.SCENE2D||e.camera.frustum instanceof wn||e.camera.frustum instanceof el)return JCe(t,e,n);let i=t._tileProvider.getLevelMaximumGeometricError(n.level),o=n._distance,a=e.context.drawingBufferHeight,s=e.camera.frustum.sseDenominator,l=i*a/(o*s);return e.fog.enabled&&(l-=k.fog(o,e.fog.density)*e.fog.sse),l/=e.pixelRatio,l}function JCe(t,e,n){let o=e.camera.frustum,a=o.offCenterFrustum;c(a)&&(o=a);let s=e.context,l=s.drawingBufferWidth,r=s.drawingBufferHeight,d=t._tileProvider.getLevelMaximumGeometricError(n.level),m=Math.max(o.top-o.bottom,o.right-o.left)/Math.max(l,r),h=d/m;return e.fog.enabled&&e.mode!==Vt.SCENE2D&&(h-=k.fog(n._distance,e.fog.density)*e.fog.sse),h/=e.pixelRatio,h}function xz(t,e){t._tilesToRender.push(e)}function LCe(t,e){let n=t._tileLoadQueueHigh,i=t._tileLoadQueueMedium,o=t._tileLoadQueueLow;if(n.length===0&&i.length===0&&o.length===0)return;t._tileReplacementQueue.trimTiles(t.tileCacheSize);let a=Oi()+t._loadQueueTimeSlice,s=t._tileProvider,l=Dot(t,e,s,a,n,!1);l=Dot(t,e,s,a,i,l),Dot(t,e,s,a,o,l)}function MCe(t,e){return t._loadPriority-e._loadPriority}function Dot(t,e,n,i,o,a){n.computeTileLoadPriority!==void 0&&o.sort(MCe);for(let s=0,l=o.length;s<l&&(Oi()<i||!a);++s){let r=o[s];t._tileReplacementQueue.markTileRendered(r),n.loadTile(e,r),a=!0}return a}var Q1=new di,Oot=new gt,pU=new p,_Ce=[];function DCe(t,e){if(!c(t.tileProvider.tilingScheme))return;let n=_Ce;n.length=0;let i=t._tileToUpdateHeights,o=Oi(),a=t._updateHeightsTimeSlice,s=o+a,l=e.mode,r=e.mapProjection,d=t.tileProvider.tilingScheme.ellipsoid,m;for(;i.length>0;){let h=i[0];if(!c(h.data)||!c(h.data.mesh)){let F=h._lastSelectionResultFrame===t._lastSelectionFrameNumber?h._lastSelectionResult:Pi.NONE;(F===Pi.RENDERED||F===Pi.CULLED_BUT_NEEDED)&&n.push(h),i.shift(),t._lastTileIndex=0;continue}let u=h.customData,R=u.length,V=!1;for(m=t._lastTileIndex;m<R;++m){let F=u[m],U=h.data.terrainData,G=c(U)&&U.wasCreatedByUpsampling();if(h.level>F.level&&!G){if(c(F.positionOnEllipsoidSurface)||(F.positionOnEllipsoidSurface=p.fromRadians(F.positionCartographic.longitude,F.positionCartographic.latitude,0,d)),l===Vt.SCENE3D){let S=d.geodeticSurfaceNormal(F.positionOnEllipsoidSurface,Q1.direction),g=d.getSurfaceNormalIntersectionWithZAxis(F.positionOnEllipsoidSurface,11500,Q1.origin);if(!c(g)){let C=0;c(h.data.tileBoundingRegion)&&(C=h.data.tileBoundingRegion.minimumHeight);let y=Math.min(C,-11500),Y=p.multiplyByScalar(S,Math.abs(y)+1,pU);p.subtract(F.positionOnEllipsoidSurface,Y,Q1.origin)}}else gt.clone(F.positionCartographic,Oot),Oot.height=-11500,r.project(Oot,pU),p.fromElements(pU.z,pU.x,pU.y,pU),p.clone(pU,Q1.origin),p.clone(p.UNIT_X,Q1.direction);let A=h.data.pick(Q1,l,r,!1,pU);c(A)&&(c(F.callback)&&F.callback(A),F.level=h.level)}if(Oi()>=s){V=!0;break}}if(V){t._lastTileIndex=m;break}else t._lastTileIndex=0,i.shift()}for(m=0;m<n.length;m++)i.push(n[m])}function OCe(t,e){let n=t._tileProvider,i=t._tilesToRender;for(let o=0,a=i.length;o<a;++o){let s=i[o];n.showTileThisFrame(s,e)}}var l_=gV;function sZ(t){t=f(t,mt.WGS84);let e=new bV({ellipsoid:t}),n=new t_;this._ellipsoid=t,this._imageryLayerCollection=n,this._surfaceShaderSet=new xM,this._material=void 0,this._surface=new l_({tileProvider:new qM({terrainProvider:e,imageryLayers:n,surfaceShaderSet:this._surfaceShaderSet})}),this._terrainProvider=e,this._terrainProviderChanged=new It,this._undergroundColor=v.clone(v.BLACK),this._undergroundColorAlphaByDistance=new ln(t.maximumRadius/1e3,0,t.maximumRadius/5,1),this._translucency=new $M,Pot(this),this.show=!0,this._oceanNormalMapResourceDirty=!0,this._oceanNormalMapResource=new te({url:Dn("Assets/Textures/waterNormalsSmall.jpg")}),this.maximumScreenSpaceError=2,this.tileCacheSize=100,this.loadingDescendantLimit=20,this.preloadAncestors=!0,this.preloadSiblings=!1,this.fillHighlightColor=void 0,this.enableLighting=!1,this.lambertDiffuseMultiplier=.9,this.dynamicAtmosphereLighting=!0,this.dynamicAtmosphereLightingFromSun=!1,this.showGroundAtmosphere=!0,this.atmosphereLightIntensity=10,this.atmosphereRayleighCoefficient=new p(55e-7,13e-6,284e-7),this.atmosphereMieCoefficient=new p(21e-6,21e-6,21e-6),this.atmosphereRayleighScaleHeight=1e4,this.atmosphereMieScaleHeight=3200,this.atmosphereMieAnisotropy=.9,this.lightingFadeOutDistance=1e7,this.lightingFadeInDistance=2e7,this.nightFadeOutDistance=1e7,this.nightFadeInDistance=5e7,this.showWaterEffect=!0,this.depthTestAgainstTerrain=!1,this.shadows=Vi.RECEIVE_ONLY,this.atmosphereHueShift=0,this.atmosphereSaturationShift=0,this.atmosphereBrightnessShift=0,this.showSkirts=!0,this.backFaceCulling=!0,this._oceanNormalMap=void 0,this._zoomedOutOceanSpecularIntensity=void 0,this.vertexShadowDarkness=.3}Object.defineProperties(sZ.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},imageryLayers:{get:function(){return this._imageryLayerCollection}},imageryLayersUpdatedEvent:{get:function(){return this._surface.tileProvider.imageryLayersUpdatedEvent}},tilesLoaded:{get:function(){return c(this._surface)?this._surface._tileLoadQueueHigh.length===0&&this._surface._tileLoadQueueMedium.length===0&&this._surface._tileLoadQueueLow.length===0:!0}},baseColor:{get:function(){return this._surface.tileProvider.baseColor},set:function(t){this._surface.tileProvider.baseColor=t}},clippingPlanes:{get:function(){return this._surface.tileProvider.clippingPlanes},set:function(t){this._surface.tileProvider.clippingPlanes=t}},clippingPolygons:{get:function(){return this._surface.tileProvider.clippingPolygons},set:function(t){this._surface.tileProvider.clippingPolygons=t}},cartographicLimitRectangle:{get:function(){return this._surface.tileProvider.cartographicLimitRectangle},set:function(t){c(t)||(t=Gt.clone(Gt.MAX_VALUE)),this._surface.tileProvider.cartographicLimitRectangle=t}},oceanNormalMapUrl:{get:function(){return this._oceanNormalMapResource.url},set:function(t){this._oceanNormalMapResource.url=t,this._oceanNormalMapResourceDirty=!0}},terrainProvider:{get:function(){return this._terrainProvider},set:function(t){t!==this._terrainProvider&&(this._terrainProvider=t,this._terrainProviderChanged.raiseEvent(t),c(this._material)&&Pot(this))}},terrainProviderChanged:{get:function(){return this._terrainProviderChanged}},tileLoadProgressEvent:{get:function(){return this._surface.tileLoadProgressEvent}},material:{get:function(){return this._material},set:function(t){this._material!==t&&(this._material=t,Pot(this))}},undergroundColor:{get:function(){return this._undergroundColor},set:function(t){this._undergroundColor=v.clone(t,this._undergroundColor)}},undergroundColorAlphaByDistance:{get:function(){return this._undergroundColorAlphaByDistance},set:function(t){this._undergroundColorAlphaByDistance=ln.clone(t,this._undergroundColorAlphaByDistance)}},translucency:{get:function(){return this._translucency}}});function Pot(t){let e=[],n=c(t._material)&&(c(t._material.shaderSource.match(/slope/))||c(t._material.shaderSource.match("normalEC"))),i=[rW,W1];c(t._material)&&(!n||t._terrainProvider.requestVertexNormals)?(i.push(t._material.shaderSource),e.push("APPLY_MATERIAL"),t._surface._tileProvider.materialUniformMap=t._material._uniforms):t._surface._tileProvider.materialUniformMap=void 0,i.push(kM),t._surfaceShaderSet.baseVertexShaderSource=new Ze({sources:[rW,W1,YM],defines:e}),t._surfaceShaderSet.baseFragmentShaderSource=new Ze({sources:i,defines:e}),t._surfaceShaderSet.material=t._material}function HCe(t){return function(e,n){let i=Ft.distanceSquaredTo(e.pickBoundingSphere,t),o=Ft.distanceSquaredTo(n.pickBoundingSphere,t);return i-o}}var wCe=[],PCe={start:0,stop:0};sZ.prototype.pickWorldCoordinates=function(t,e,n,i){n=f(n,!0);let o=e.mode,a=e.mapProjection,s=wCe;s.length=0;let l=this._surface._tilesToRender,r=l.length,d,m;for(m=0;m<r;++m){d=l[m];let u=d.data;if(!c(u))continue;let R=u.pickBoundingSphere;if(o!==Vt.SCENE3D)u.pickBoundingSphere=R=Ft.fromRectangleWithHeights2D(d.rectangle,a,u.tileBoundingRegion.minimumHeight,u.tileBoundingRegion.maximumHeight,R),p.fromElements(R.center.z,R.center.x,R.center.y,R.center);else if(c(u.renderedMesh))Ft.clone(u.tileBoundingRegion.boundingSphere,R);else continue;let V=no.raySphere(t,R,PCe);c(V)&&s.push(u)}s.sort(HCe(t.origin));let h;for(r=s.length,m=0;m<r&&(h=s[m].pick(t,e.mode,e.mapProjection,n,i),!c(h));++m);return h};var vCe=new gt;sZ.prototype.pick=function(t,e,n){if(n=this.pickWorldCoordinates(t,e,!0,n),c(n)&&e.mode!==Vt.SCENE3D){n=p.fromElements(n.y,n.z,n.x,n);let i=e.mapProjection.unproject(n,vCe);n=e.globe.ellipsoid.cartographicToCartesian(i,n)}return n};var KCe=new p,dNt=new p,zCe=new gt,jCe=new di;function wot(t,e){return c(t)&&Gt.contains(t.rectangle,e)?t:void 0}sZ.prototype.getHeight=function(t){let e=this._surface._levelZeroTiles;if(!c(e))return;let n,i,o=e.length;for(i=0;i<o&&(n=e[i],!Gt.contains(n.rectangle,t));++i);if(i>=o)return;let a=n;for(;c(n);)n=wot(n._southwestChild,t)||wot(n._southeastChild,t)||wot(n._northwestChild,t)||n._northeastChild,c(n)&&c(n.data)&&c(n.data.renderedMesh)&&(a=n);if(n=a,!c(n)||!c(n.data)||!c(n.data.renderedMesh))return;let s=this._surface._tileProvider.tilingScheme.projection,l=this._surface._tileProvider.tilingScheme.ellipsoid,r=p.fromRadians(t.longitude,t.latitude,0,l,KCe),d=jCe,m=l.geodeticSurfaceNormal(r,d.direction),h=l.getSurfaceNormalIntersectionWithZAxis(r,11500,d.origin);if(!c(h)){let R;c(n.data.tileBoundingRegion)&&(R=n.data.tileBoundingRegion.minimumHeight);let V=Math.min(f(R,0),-11500),F=p.multiplyByScalar(m,Math.abs(V)+1,dNt);p.subtract(r,F,d.origin)}let u=n.data.pick(d,void 0,s,!1,dNt);if(c(u))return l.cartesianToCartographic(u,zCe).height};sZ.prototype.update=function(t){this.show&&t.passes.render&&this._surface.update(t)};sZ.prototype.beginFrame=function(t){let e=this._surface,n=e.tileProvider,i=this.terrainProvider,o=this.showWaterEffect&&c(i)&&i.hasWaterMask&&i.hasWaterMask;if(o&&this._oceanNormalMapResourceDirty){this._oceanNormalMapResourceDirty=!1;let l=this._oceanNormalMapResource,r=l.url;if(c(r)){let d=this;l.fetchImage().then(function(m){r===d._oceanNormalMapResource.url&&(d._oceanNormalMap=d._oceanNormalMap&&d._oceanNormalMap.destroy(),d._oceanNormalMap=new hn({context:t.context,source:m}))})}else this._oceanNormalMap=this._oceanNormalMap&&this._oceanNormalMap.destroy()}let a=t.passes,s=t.mode;a.render&&(this.showGroundAtmosphere?this._zoomedOutOceanSpecularIntensity=.4:this._zoomedOutOceanSpecularIntensity=.5,e.maximumScreenSpaceError=this.maximumScreenSpaceError,e.tileCacheSize=this.tileCacheSize,e.loadingDescendantLimit=this.loadingDescendantLimit,e.preloadAncestors=this.preloadAncestors,e.preloadSiblings=this.preloadSiblings,n.terrainProvider=this.terrainProvider,n.lightingFadeOutDistance=this.lightingFadeOutDistance,n.lightingFadeInDistance=this.lightingFadeInDistance,n.nightFadeOutDistance=this.nightFadeOutDistance,n.nightFadeInDistance=this.nightFadeInDistance,n.zoomedOutOceanSpecularIntensity=s===Vt.SCENE3D?this._zoomedOutOceanSpecularIntensity:0,n.hasWaterMask=o,n.oceanNormalMap=this._oceanNormalMap,n.enableLighting=this.enableLighting,n.dynamicAtmosphereLighting=this.dynamicAtmosphereLighting,n.dynamicAtmosphereLightingFromSun=this.dynamicAtmosphereLightingFromSun,n.showGroundAtmosphere=this.showGroundAtmosphere,n.atmosphereLightIntensity=this.atmosphereLightIntensity,n.atmosphereRayleighCoefficient=this.atmosphereRayleighCoefficient,n.atmosphereMieCoefficient=this.atmosphereMieCoefficient,n.atmosphereRayleighScaleHeight=this.atmosphereRayleighScaleHeight,n.atmosphereMieScaleHeight=this.atmosphereMieScaleHeight,n.atmosphereMieAnisotropy=this.atmosphereMieAnisotropy,n.shadows=this.shadows,n.hueShift=this.atmosphereHueShift,n.saturationShift=this.atmosphereSaturationShift,n.brightnessShift=this.atmosphereBrightnessShift,n.fillHighlightColor=this.fillHighlightColor,n.showSkirts=this.showSkirts,n.backFaceCulling=this.backFaceCulling,n.vertexShadowDarkness=this.vertexShadowDarkness,n.undergroundColor=this._undergroundColor,n.undergroundColorAlphaByDistance=this._undergroundColorAlphaByDistance,n.lambertDiffuseMultiplier=this.lambertDiffuseMultiplier,e.beginFrame(t))};sZ.prototype.render=function(t){this.show&&(c(this._material)&&this._material.update(t.context),this._surface.render(t))};sZ.prototype.endFrame=function(t){this.show&&t.passes.render&&this._surface.endFrame(t)};sZ.prototype.isDestroyed=function(){return!1};sZ.prototype.destroy=function(){return this._surfaceShaderSet=this._surfaceShaderSet&&this._surfaceShaderSet.destroy(),this._surface=this._surface&&this._surface.destroy(),this._oceanNormalMap=this._oceanNormalMap&&this._oceanNormalMap.destroy(),At(this)};var r_=sZ;var UAo=b(W(),1);var BGo=b(W(),1);var AGo=b(W(),1);var RGo=b(W(),1);function qCe(t,e,n,i){this.rightAscension=t,this.declination=e,this.rotation=n,this.rotationRate=i}var d_=qCe;var GNt={},$Ce=32.184,tIe=2451545,cNt=-.0529921,mNt=-.1059842,hNt=13.0120009,pNt=13.3407154,VNt=.9856003,uNt=26.4057084,ZNt=13.064993,RNt=.3287146,bNt=1.7484877,WNt=-.1589763,fNt=.0036096,FNt=.1643573,UNt=12.9590088,vot=new rt;GNt.ComputeMoon=function(t,e){c(t)||(t=rt.now()),vot=rt.addSeconds(t,$Ce,vot);let n=rt.totalDays(vot)-tIe,i=n/xi.DAYS_PER_JULIAN_CENTURY,o=(125.045+cNt*n)*k.RADIANS_PER_DEGREE,a=(250.089+mNt*n)*k.RADIANS_PER_DEGREE,s=(260.008+hNt*n)*k.RADIANS_PER_DEGREE,l=(176.625+pNt*n)*k.RADIANS_PER_DEGREE,r=(357.529+VNt*n)*k.RADIANS_PER_DEGREE,d=(311.589+uNt*n)*k.RADIANS_PER_DEGREE,m=(134.963+ZNt*n)*k.RADIANS_PER_DEGREE,h=(276.617+RNt*n)*k.RADIANS_PER_DEGREE,u=(34.226+bNt*n)*k.RADIANS_PER_DEGREE,R=(15.134+WNt*n)*k.RADIANS_PER_DEGREE,V=(119.743+fNt*n)*k.RADIANS_PER_DEGREE,F=(239.961+FNt*n)*k.RADIANS_PER_DEGREE,U=(25.053+UNt*n)*k.RADIANS_PER_DEGREE,G=Math.sin(o),A=Math.sin(a),S=Math.sin(s),g=Math.sin(l),C=Math.sin(r),y=Math.sin(d),Y=Math.sin(m),Q=Math.sin(h),J=Math.sin(u),M=Math.sin(R),Z=Math.sin(V),E=Math.sin(F),I=Math.sin(U),B=Math.cos(o),X=Math.cos(a),_=Math.cos(s),P=Math.cos(l),w=Math.cos(r),z=Math.cos(d),H=Math.cos(m),nt=Math.cos(h),$=Math.cos(u),dt=Math.cos(R),q=Math.cos(V),at=Math.cos(F),st=Math.cos(U),Et=(269.9949+.0031*i-3.8787*G-.1204*A+.07*S-.0172*g+.0072*y-.0052*M+.0043*I)*k.RADIANS_PER_DEGREE,Qt=(66.5392+.013*i+1.5419*B+.0239*X-.0278*_+.0068*P-.0029*z+9e-4*H+8e-4*dt-9e-4*st)*k.RADIANS_PER_DEGREE,Wt=(38.3213+13.17635815*n-14e-13*n*n+3.561*G+.1208*A-.0642*S+.0158*g+.0252*C-.0066*y-.0047*Y-.0046*Q+.0028*J+.0052*M+.004*Z+.0019*E-.0044*I)*k.RADIANS_PER_DEGREE,Nt=(13.17635815-14e-13*(2*n)+3.561*B*cNt+.1208*X*mNt-.0642*_*hNt+.0158*P*pNt+.0252*w*VNt-.0066*z*uNt-.0047*H*ZNt-.0046*nt*RNt+.0028*$*bNt+.0052*dt*WNt+.004*q*fNt+.0019*at*FNt-.0044*st*UNt)/86400*k.RADIANS_PER_DEGREE;return c(e)||(e=new d_),e.rightAscension=Et,e.declination=Qt,e.rotation=Wt,e.rotationRate=Nt,e};var c_=GNt;function ANt(t){(!c(t)||typeof t!="function")&&(t=c_.ComputeMoon),this._computeFunction=t}var eIe=new p,nIe=new p,iIe=new p;function oIe(t,e,n){let i=eIe;i.x=Math.cos(t+k.PI_OVER_TWO),i.y=Math.sin(t+k.PI_OVER_TWO),i.z=0;let o=Math.cos(e),a=iIe;a.x=o*Math.cos(t),a.y=o*Math.sin(t),a.z=Math.sin(e);let s=p.cross(a,i,nIe);return c(n)||(n=new ot),n[0]=i.x,n[1]=s.x,n[2]=a.x,n[3]=i.y,n[4]=s.y,n[5]=a.y,n[6]=i.z,n[7]=s.z,n[8]=a.z,n}var aIe=new ot,sIe=new wt;ANt.prototype.evaluate=function(t,e){c(t)||(t=rt.now());let n=this._computeFunction(t),i=oIe(n.rightAscension,n.declination,e),o=k.zeroToTwoPi(n.rotation),a=wt.fromAxisAngle(p.UNIT_Z,o,sIe),s=ot.fromQuaternion(wt.conjugate(a,a),aIe);return ot.multiply(s,i,i)};var m_=ANt;var lAo=b(W(),1);var kGo=b(W(),1),k1=`uniform vec3 u_radii; uniform vec3 u_oneOverEllipsoidRadiiSquared; in vec3 v_positionEC; @@ -10567,7 +10567,7 @@ void main() #endif #endif } -`;var xGo=R(W(),1),Y1=`in vec3 position; +`;var xGo=b(W(),1),Y1=`in vec3 position; uniform vec3 u_radii; @@ -10595,7 +10595,7 @@ void main() czm_vertexLogDepth(); } -`;var Kot={position:0};function Xz(t){t=f(t,f.EMPTY_OBJECT),this.center=p.clone(f(t.center,p.ZERO)),this._center=new p,this.radii=p.clone(t.radii),this._radii=new p,this._oneOverEllipsoidRadiiSquared=new p,this._boundingSphere=new Ft,this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._modelMatrix=new L,this._computedModelMatrix=new L,this.show=f(t.show,!0),this.material=f(t.material,eo.fromType(eo.ColorType)),this._material=void 0,this._translucent=void 0,this.id=t.id,this._id=void 0,this.debugShowBoundingVolume=f(t.debugShowBoundingVolume,!1),this.onlySunLighting=f(t.onlySunLighting,!1),this._onlySunLighting=!1,this._depthTestEnabled=f(t.depthTestEnabled,!0),this._useLogDepth=!1,this._sp=void 0,this._rs=void 0,this._va=void 0,this._pickSP=void 0,this._pickId=void 0,this._colorCommand=new Ee({owner:f(t._owner,this)}),this._pickCommand=new Ee({owner:f(t._owner,this),pickOnly:!0});let e=this;this._uniforms={u_radii:function(){return e.radii},u_oneOverEllipsoidRadiiSquared:function(){return e._oneOverEllipsoidRadiiSquared}},this._pickUniforms={czm_pickColor:function(){return e._pickId.color}}}function lIe(t){let e=t.cache.ellipsoidPrimitive_vertexArray;if(c(e))return e;let n=Am.createGeometry(Am.fromDimensions({dimensions:new p(2,2,2),vertexFormat:ee.POSITION_ONLY}));return e=Ki.fromGeometry({context:t,geometry:n,attributeLocations:Kot,bufferUsage:ce.STATIC_DRAW,interleave:!0}),t.cache.ellipsoidPrimitive_vertexArray=e,e}Xz.prototype.update=function(t){if(!this.show||t.mode!==ut.SCENE3D||!c(this.center)||!c(this.radii))return;let e=t.context,n=this.material.isTranslucent(),i=this._translucent!==n;(!c(this._rs)||i)&&(this._translucent=n,this._rs=he.fromCache({cull:{enabled:!0,face:so.FRONT},depthTest:{enabled:this._depthTestEnabled},depthMask:!n&&e.fragmentDepth,blending:n?Pn.ALPHA_BLEND:void 0})),c(this._va)||(this._va=lIe(e));let o=!1,a=this.radii;if(!p.equals(this._radii,a)){p.clone(a,this._radii);let F=this._oneOverEllipsoidRadiiSquared;F.x=1/(a.x*a.x),F.y=1/(a.y*a.y),F.z=1/(a.z*a.z),o=!0}(!L.equals(this.modelMatrix,this._modelMatrix)||!p.equals(this.center,this._center))&&(L.clone(this.modelMatrix,this._modelMatrix),p.clone(this.center,this._center),L.multiplyByTranslation(this.modelMatrix,this.center,this._computedModelMatrix),o=!0),o&&(p.clone(p.ZERO,this._boundingSphere.center),this._boundingSphere.radius=p.maximumComponent(a),Ft.transform(this._boundingSphere,this._computedModelMatrix,this._boundingSphere));let s=this._material!==this.material;this._material=this.material,this._material.update(e);let l=this.onlySunLighting!==this._onlySunLighting;this._onlySunLighting=this.onlySunLighting;let r=t.useLogDepth,d=this._useLogDepth!==r;this._useLogDepth=r;let m=this._colorCommand,h,Z;(s||l||i||d)&&(h=new Ve({sources:[Y1]}),Z=new Ve({sources:[this.material.shaderSource,k1]}),this.onlySunLighting&&Z.defines.push("ONLY_SUN_LIGHTING"),!n&&e.fragmentDepth&&Z.defines.push("WRITE_DEPTH"),this._useLogDepth&&(h.defines.push("LOG_DEPTH"),Z.defines.push("LOG_DEPTH")),this._sp=xn.replaceCache({context:e,shaderProgram:this._sp,vertexShaderSource:h,fragmentShaderSource:Z,attributeLocations:Kot}),m.vertexArray=this._va,m.renderState=this._rs,m.shaderProgram=this._sp,m.uniformMap=ze(this._uniforms,this.material._uniforms),m.executeInClosestFrustum=n);let b=t.commandList,u=t.passes;if(u.render&&(m.boundingVolume=this._boundingSphere,m.debugShowBoundingVolume=this.debugShowBoundingVolume,m.modelMatrix=this._computedModelMatrix,m.pass=n?Pt.TRANSLUCENT:Pt.OPAQUE,b.push(m)),u.pick){let F=this._pickCommand;(!c(this._pickId)||this._id!==this.id)&&(this._id=this.id,this._pickId=this._pickId&&this._pickId.destroy(),this._pickId=e.createPickId({primitive:this,id:this.id})),(s||l||!c(this._pickSP)||d)&&(h=new Ve({sources:[Y1]}),Z=new Ve({sources:[this.material.shaderSource,k1],pickColorQualifier:"uniform"}),this.onlySunLighting&&Z.defines.push("ONLY_SUN_LIGHTING"),!n&&e.fragmentDepth&&Z.defines.push("WRITE_DEPTH"),this._useLogDepth&&(h.defines.push("LOG_DEPTH"),Z.defines.push("LOG_DEPTH")),this._pickSP=xn.replaceCache({context:e,shaderProgram:this._pickSP,vertexShaderSource:h,fragmentShaderSource:Z,attributeLocations:Kot}),F.vertexArray=this._va,F.renderState=this._rs,F.shaderProgram=this._pickSP,F.uniformMap=ze(ze(this._uniforms,this._pickUniforms),this.material._uniforms),F.executeInClosestFrustum=n),F.boundingVolume=this._boundingSphere,F.modelMatrix=this._computedModelMatrix,F.pass=n?Pt.TRANSLUCENT:Pt.OPAQUE,b.push(F)}};Xz.prototype.isDestroyed=function(){return!1};Xz.prototype.destroy=function(){return this._sp=this._sp&&this._sp.destroy(),this._pickSP=this._pickSP&&this._pickSP.destroy(),this._pickId=this._pickId&&this._pickId.destroy(),At(this)};var h_=Xz;function p_(t){t=f(t,f.EMPTY_OBJECT);let e=t.textureUrl;c(e)||(e=Dn("Assets/Textures/moonSmall.jpg")),this.show=f(t.show,!0),this.textureUrl=e,this._ellipsoid=f(t.ellipsoid,mt.MOON),this.onlySunLighting=f(t.onlySunLighting,!0),this._ellipsoidPrimitive=new h_({radii:this.ellipsoid.radii,material:eo.fromType(eo.ImageType),depthTestEnabled:!1,_owner:this}),this._ellipsoidPrimitive.material.translucent=!1,this._axes=new m_}Object.defineProperties(p_.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});var Jz=new ot,rIe=new ot,dIe=new p,Lz=[];p_.prototype.update=function(t){if(!this.show)return;let e=this._ellipsoidPrimitive;e.material.uniforms.image=this.textureUrl,e.onlySunLighting=this.onlySunLighting;let n=t.time;c(Pe.computeIcrfToFixedMatrix(n,Jz))||Pe.computeTemeToPseudoFixedMatrix(n,Jz);let i=this._axes.evaluate(n,rIe);ot.transpose(i,i),ot.multiply(Jz,i,i);let o=_V.computeMoonPositionInEarthInertialFrame(n,dIe);ot.multiplyByVector(Jz,o,o),L.fromRotationTranslation(i,o,e.modelMatrix);let a=t.commandList;return t.commandList=Lz,Lz.length=0,e.update(t),t.commandList=a,Lz.length===1?Lz[0]:void 0};p_.prototype.isDestroyed=function(){return!1};p_.prototype.destroy=function(){return this._ellipsoidPrimitive=this._ellipsoidPrimitive&&this._ellipsoidPrimitive.destroy(),At(this)};var u_=p_;var hMo=R(W(),1);var AAo=R(W(),1);var zot=[],jot=[];function cIe(t,e,n,i,o,a){let s=o-i+1,l=a-o,r=zot,d=jot,m,h;for(m=0;m<s;++m)r[m]=t[i+m];for(h=0;h<l;++h)d[h]=t[o+h+1];m=0,h=0;for(let Z=i;Z<=a;++Z){let b=r[m],u=d[h];m<s&&(h>=l||e(b,u,n)<=0)?(t[Z]=b,++m):h<l&&(t[Z]=u,++h)}}function qot(t,e,n,i,o){if(i>=o)return;let a=Math.floor((i+o)*.5);qot(t,e,n,i,a),qot(t,e,n,a+1,o),cIe(t,e,n,i,a,o)}function mIe(t,e,n){let i=t.length,o=Math.ceil(i*.5);zot.length=o,jot.length=o,qot(t,e,n,0,i-1),zot.length=0,jot.length=0}var ZW=mIe;var QAo=R(W(),1);function rc(t,e){this._occluderPosition=p.clone(t.center),this._occluderRadius=t.radius,this._horizonDistance=0,this._horizonPlaneNormal=void 0,this._horizonPlanePosition=void 0,this._cameraPosition=void 0,this.cameraPosition=e}var Mz=new p;Object.defineProperties(rc.prototype,{position:{get:function(){return this._occluderPosition}},radius:{get:function(){return this._occluderRadius}},cameraPosition:{set:function(t){t=p.clone(t,this._cameraPosition);let e=p.subtract(this._occluderPosition,t,Mz),n=p.magnitudeSquared(e),i=this._occluderRadius*this._occluderRadius,o,a,s;if(n>i){o=Math.sqrt(n-i),n=1/Math.sqrt(n),a=p.multiplyByScalar(e,n,Mz);let l=o*o*n;s=p.add(t,p.multiplyByScalar(a,l,Mz),Mz)}else o=Number.MAX_VALUE;this._horizonDistance=o,this._horizonPlaneNormal=a,this._horizonPlanePosition=s,this._cameraPosition=t}}});rc.fromBoundingSphere=function(t,e,n){return c(n)?(p.clone(t.center,n._occluderPosition),n._occluderRadius=t.radius,n.cameraPosition=e,n):new rc(t,e)};var SNt=new p;rc.prototype.isPointVisible=function(t){if(this._horizonDistance!==Number.MAX_VALUE){let e=p.subtract(t,this._occluderPosition,SNt),n=this._occluderRadius;if(n=p.magnitudeSquared(e)-n*n,n>0)return n=Math.sqrt(n)+this._horizonDistance,e=p.subtract(t,this._cameraPosition,e),n*n>p.magnitudeSquared(e)}return!1};var hIe=new p;rc.prototype.isBoundingSphereVisible=function(t){let e=p.clone(t.center,hIe),n=t.radius;if(this._horizonDistance!==Number.MAX_VALUE){let i=p.subtract(e,this._occluderPosition,SNt),o=this._occluderRadius-n;if(o=p.magnitudeSquared(i)-o*o,n<this._occluderRadius)return o>0?(o=Math.sqrt(o)+this._horizonDistance,i=p.subtract(e,this._cameraPosition,i),o*o+n*n>p.magnitudeSquared(i)):!1;if(o>0){i=p.subtract(e,this._cameraPosition,i);let a=p.magnitudeSquared(i),s=this._occluderRadius*this._occluderRadius,l=n*n;return(this._horizonDistance*this._horizonDistance+s)*l>a*s?!0:(o=Math.sqrt(o)+this._horizonDistance,o*o+l>a)}return!0}return!1};var pIe=new p;rc.prototype.computeVisibility=function(t){let e=p.clone(t.center),n=t.radius;if(n>this._occluderRadius)return Ys.FULL;if(this._horizonDistance!==Number.MAX_VALUE){let i=p.subtract(e,this._occluderPosition,pIe),o=this._occluderRadius-n,a=p.magnitudeSquared(i);if(o=a-o*o,o>0){o=Math.sqrt(o)+this._horizonDistance,i=p.subtract(e,this._cameraPosition,i);let s=p.magnitudeSquared(i);return o*o+n*n<s?Ys.NONE:(o=this._occluderRadius+n,o=a-o*o,o>0?(o=Math.sqrt(o)+this._horizonDistance,s<o*o+n*n?Ys.FULL:Ys.PARTIAL):(i=p.subtract(e,this._horizonPlanePosition,i),p.dot(i,this._horizonPlaneNormal)>-n?Ys.PARTIAL:Ys.FULL))}}return Ys.NONE};var _z=new p;rc.computeOccludeePoint=function(t,e,n){let i=p.clone(e),o=p.clone(t.center),a=t.radius,s=n.length,l=p.normalize(p.subtract(i,o,_z),_z),r=-p.dot(l,o),d=rc._anyRotationVector(o,l,r),m=rc._horizonToPlaneNormalDotProduct(t,l,r,d,n[0]);if(!m)return;let h;for(let b=1;b<s;++b){if(h=rc._horizonToPlaneNormalDotProduct(t,l,r,d,n[b]),!h)return;h<m&&(m=h)}if(m<.0017453283658983088)return;let Z=a/m;return p.add(o,p.multiplyByScalar(l,Z,_z),_z)};var uIe=[];rc.computeOccludeePointFromRectangle=function(t,e){e=f(e,mt.WGS84);let n=Gt.subsample(t,e,0,uIe),i=Ft.fromPoints(n),o=p.ZERO;if(!p.equals(o,i.center))return rc.computeOccludeePoint(new Ft(o,e.minimumRadius),i.center,n)};var ZIe=new p;rc._anyRotationVector=function(t,e,n){let i=p.abs(e,ZIe),o=i.x>i.y?0:1;(o===0&&i.z>i.x||o===1&&i.z>i.y)&&(o=2);let a=new p,s;o===0?(i.x=t.x,i.y=t.y+1,i.z=t.z+1,s=p.UNIT_X):o===1?(i.x=t.x+1,i.y=t.y,i.z=t.z+1,s=p.UNIT_Y):(i.x=t.x+1,i.y=t.y+1,i.z=t.z,s=p.UNIT_Z);let l=(p.dot(e,i)+n)/-p.dot(e,s);return p.normalize(p.subtract(p.add(i,p.multiplyByScalar(s,l,a),i),t,i),i)};var VIe=new p;rc._rotationVector=function(t,e,n,i,o){let a=p.subtract(i,t,VIe);if(a=p.normalize(a,a),p.dot(e,a)<.9999999847691291){let s=p.cross(e,a,a);if(p.magnitude(s)>k.EPSILON13)return p.normalize(s,new p)}return o};var $ot=new p,bIe=new p,Dz=new p,TNt=new p;rc._horizonToPlaneNormalDotProduct=function(t,e,n,i,o){let a=p.clone(o,$ot),s=p.clone(t.center,bIe),l=t.radius,r=p.subtract(s,a,Dz),d=p.magnitudeSquared(r),m=l*l;if(d<m)return!1;let h=d-m,Z=Math.sqrt(h),u=1/Math.sqrt(d),U=Z*u*Z;r=p.normalize(r,r);let G=p.add(a,p.multiplyByScalar(r,U,TNt),TNt),A=Math.sqrt(h-U*U),T=this._rotationVector(s,e,n,a,i),g=p.fromElements(T.x*T.x*r.x+(T.x*T.y-T.z)*r.y+(T.x*T.z+T.y)*r.z,(T.x*T.y+T.z)*r.x+T.y*T.y*r.y+(T.y*T.z-T.x)*r.z,(T.x*T.z-T.y)*r.x+(T.y*T.z+T.x)*r.y+T.z*T.z*r.z,$ot);g=p.normalize(g,g);let C=p.multiplyByScalar(g,A,$ot);T=p.normalize(p.subtract(p.add(G,C,Dz),s,Dz),Dz);let y=p.dot(e,T);T=p.normalize(p.subtract(p.subtract(G,C,T),s,T),T);let Y=p.dot(e,T);return y<Y?y:Y};var Z_=rc;var KAo=R(W(),1);var DAo=R(W(),1);function Xb(t){t=f(t,f.EMPTY_OBJECT),this.left=t.left,this._left=void 0,this.right=t.right,this._right=void 0,this.top=t.top,this._top=void 0,this.bottom=t.bottom,this._bottom=void 0,this.near=f(t.near,1),this._near=this.near,this.far=f(t.far,5e8),this._far=this.far,this._cullingVolume=new Jl,this._perspectiveMatrix=new L,this._infinitePerspective=new L}function tat(t){let e=t.top,n=t.bottom,i=t.right,o=t.left,a=t.near,s=t.far;(e!==t._top||n!==t._bottom||o!==t._left||i!==t._right||a!==t._near||s!==t._far)&&(t._left=o,t._right=i,t._top=e,t._bottom=n,t._near=a,t._far=s,t._perspectiveMatrix=L.computePerspectiveOffCenter(o,i,n,e,a,s,t._perspectiveMatrix),t._infinitePerspective=L.computeInfinitePerspectiveOffCenter(o,i,n,e,a,t._infinitePerspective))}Object.defineProperties(Xb.prototype,{projectionMatrix:{get:function(){return tat(this),this._perspectiveMatrix}},infiniteProjectionMatrix:{get:function(){return tat(this),this._infinitePerspective}}});var RIe=new p,WIe=new p,fIe=new p,FIe=new p;Xb.prototype.computeCullingVolume=function(t,e,n){let i=this._cullingVolume.planes,o=this.top,a=this.bottom,s=this.right,l=this.left,r=this.near,d=this.far,m=p.cross(e,n,RIe),h=WIe;p.multiplyByScalar(e,r,h),p.add(t,h,h);let Z=fIe;p.multiplyByScalar(e,d,Z),p.add(t,Z,Z);let b=FIe;p.multiplyByScalar(m,l,b),p.add(h,b,b),p.subtract(b,t,b),p.normalize(b,b),p.cross(b,n,b),p.normalize(b,b);let u=i[0];return c(u)||(u=i[0]=new Rt),u.x=b.x,u.y=b.y,u.z=b.z,u.w=-p.dot(b,t),p.multiplyByScalar(m,s,b),p.add(h,b,b),p.subtract(b,t,b),p.cross(n,b,b),p.normalize(b,b),u=i[1],c(u)||(u=i[1]=new Rt),u.x=b.x,u.y=b.y,u.z=b.z,u.w=-p.dot(b,t),p.multiplyByScalar(n,a,b),p.add(h,b,b),p.subtract(b,t,b),p.cross(m,b,b),p.normalize(b,b),u=i[2],c(u)||(u=i[2]=new Rt),u.x=b.x,u.y=b.y,u.z=b.z,u.w=-p.dot(b,t),p.multiplyByScalar(n,o,b),p.add(h,b,b),p.subtract(b,t,b),p.cross(b,m,b),p.normalize(b,b),u=i[3],c(u)||(u=i[3]=new Rt),u.x=b.x,u.y=b.y,u.z=b.z,u.w=-p.dot(b,t),u=i[4],c(u)||(u=i[4]=new Rt),u.x=e.x,u.y=e.y,u.z=e.z,u.w=-p.dot(e,h),p.negate(e,b),u=i[5],c(u)||(u=i[5]=new Rt),u.x=b.x,u.y=b.y,u.z=b.z,u.w=-p.dot(b,Z),this._cullingVolume};Xb.prototype.getPixelDimensions=function(t,e,n,i,o){tat(this);let a=1/this.near,s=this.top*a,l=2*i*n*s/e;s=this.right*a;let r=2*i*n*s/t;return o.x=r,o.y=l,o};Xb.prototype.clone=function(t){return c(t)||(t=new Xb),t.right=this.right,t.left=this.left,t.top=this.top,t.bottom=this.bottom,t.near=this.near,t.far=this.far,t._left=void 0,t._right=void 0,t._top=void 0,t._bottom=void 0,t._near=void 0,t._far=void 0,t};Xb.prototype.equals=function(t){return c(t)&&t instanceof Xb&&this.right===t.right&&this.left===t.left&&this.top===t.top&&this.bottom===t.bottom&&this.near===t.near&&this.far===t.far};Xb.prototype.equalsEpsilon=function(t,e,n){return t===this||c(t)&&t instanceof Xb&&k.equalsEpsilon(this.right,t.right,e,n)&&k.equalsEpsilon(this.left,t.left,e,n)&&k.equalsEpsilon(this.top,t.top,e,n)&&k.equalsEpsilon(this.bottom,t.bottom,e,n)&&k.equalsEpsilon(this.near,t.near,e,n)&&k.equalsEpsilon(this.far,t.far,e,n)};var em=Xb;function th(t){t=f(t,f.EMPTY_OBJECT),this._offCenterFrustum=new em,this.fov=t.fov,this._fov=void 0,this._fovy=void 0,this._sseDenominator=void 0,this.aspectRatio=t.aspectRatio,this._aspectRatio=void 0,this.near=f(t.near,1),this._near=this.near,this.far=f(t.far,5e8),this._far=this.far,this.xOffset=f(t.xOffset,0),this._xOffset=this.xOffset,this.yOffset=f(t.yOffset,0),this._yOffset=this.yOffset}th.packedLength=6;th.pack=function(t,e,n){return n=f(n,0),e[n++]=t.fov,e[n++]=t.aspectRatio,e[n++]=t.near,e[n++]=t.far,e[n++]=t.xOffset,e[n]=t.yOffset,e};th.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new th),n.fov=t[e++],n.aspectRatio=t[e++],n.near=t[e++],n.far=t[e++],n.xOffset=t[e++],n.yOffset=t[e],n};function lV(t){let e=t._offCenterFrustum;(t.fov!==t._fov||t.aspectRatio!==t._aspectRatio||t.near!==t._near||t.far!==t._far||t.xOffset!==t._xOffset||t.yOffset!==t._yOffset)&&(t._aspectRatio=t.aspectRatio,t._fov=t.fov,t._fovy=t.aspectRatio<=1?t.fov:Math.atan(Math.tan(t.fov*.5)/t.aspectRatio)*2,t._near=t.near,t._far=t.far,t._sseDenominator=2*Math.tan(.5*t._fovy),t._xOffset=t.xOffset,t._yOffset=t.yOffset,e.top=t.near*Math.tan(.5*t._fovy),e.bottom=-e.top,e.right=t.aspectRatio*e.top,e.left=-e.right,e.near=t.near,e.far=t.far,e.right+=t.xOffset,e.left+=t.xOffset,e.top+=t.yOffset,e.bottom+=t.yOffset)}Object.defineProperties(th.prototype,{projectionMatrix:{get:function(){return lV(this),this._offCenterFrustum.projectionMatrix}},infiniteProjectionMatrix:{get:function(){return lV(this),this._offCenterFrustum.infiniteProjectionMatrix}},fovy:{get:function(){return lV(this),this._fovy}},sseDenominator:{get:function(){return lV(this),this._sseDenominator}},offCenterFrustum:{get:function(){return lV(this),this._offCenterFrustum}}});th.prototype.computeCullingVolume=function(t,e,n){return lV(this),this._offCenterFrustum.computeCullingVolume(t,e,n)};th.prototype.getPixelDimensions=function(t,e,n,i,o){return lV(this),this._offCenterFrustum.getPixelDimensions(t,e,n,i,o)};th.prototype.clone=function(t){return c(t)||(t=new th),t.aspectRatio=this.aspectRatio,t.fov=this.fov,t.near=this.near,t.far=this.far,t._aspectRatio=void 0,t._fov=void 0,t._near=void 0,t._far=void 0,this._offCenterFrustum.clone(t._offCenterFrustum),t};th.prototype.equals=function(t){return!c(t)||!(t instanceof th)?!1:(lV(this),lV(t),this.fov===t.fov&&this.aspectRatio===t.aspectRatio&&this._offCenterFrustum.equals(t._offCenterFrustum))};th.prototype.equalsEpsilon=function(t,e,n){return!c(t)||!(t instanceof th)?!1:(lV(this),lV(t),k.equalsEpsilon(this.fov,t.fov,e,n)&&k.equalsEpsilon(this.aspectRatio,t.aspectRatio,e,n)&&this._offCenterFrustum.equalsEpsilon(t._offCenterFrustum,e,n))};var Io=th;var eTo=R(W(),1);var jAo=R(W(),1),V_={NONE:0,SCENE_LIGHT:1,SUNLIGHT:2};V_.fromGlobeFlags=function(t){return t.enableLighting&&t.dynamicAtmosphereLighting?t.dynamicAtmosphereLightingFromSun?V_.SUNLIGHT:V_.SCENE_LIGHT:V_.NONE};var uS=Object.freeze(V_);function UIe(){this.lightIntensity=10,this.rayleighCoefficient=new p(55e-7,13e-6,284e-7),this.mieCoefficient=new p(21e-6,21e-6,21e-6),this.rayleighScaleHeight=1e4,this.mieScaleHeight=3200,this.mieAnisotropy=.9,this.hueShift=0,this.saturationShift=0,this.brightnessShift=0,this.dynamicLighting=uS.NONE}var b_=UIe;var ZTo=R(W(),1);var iTo=R(W(),1),R_=`in vec2 v_textureCoordinates; +`;var Kot={position:0};function Xz(t){t=f(t,f.EMPTY_OBJECT),this.center=p.clone(f(t.center,p.ZERO)),this._center=new p,this.radii=p.clone(t.radii),this._radii=new p,this._oneOverEllipsoidRadiiSquared=new p,this._boundingSphere=new Ft,this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._modelMatrix=new L,this._computedModelMatrix=new L,this.show=f(t.show,!0),this.material=f(t.material,eo.fromType(eo.ColorType)),this._material=void 0,this._translucent=void 0,this.id=t.id,this._id=void 0,this.debugShowBoundingVolume=f(t.debugShowBoundingVolume,!1),this.onlySunLighting=f(t.onlySunLighting,!1),this._onlySunLighting=!1,this._depthTestEnabled=f(t.depthTestEnabled,!0),this._useLogDepth=!1,this._sp=void 0,this._rs=void 0,this._va=void 0,this._pickSP=void 0,this._pickId=void 0,this._colorCommand=new Ee({owner:f(t._owner,this)}),this._pickCommand=new Ee({owner:f(t._owner,this),pickOnly:!0});let e=this;this._uniforms={u_radii:function(){return e.radii},u_oneOverEllipsoidRadiiSquared:function(){return e._oneOverEllipsoidRadiiSquared}},this._pickUniforms={czm_pickColor:function(){return e._pickId.color}}}function lIe(t){let e=t.cache.ellipsoidPrimitive_vertexArray;if(c(e))return e;let n=Am.createGeometry(Am.fromDimensions({dimensions:new p(2,2,2),vertexFormat:ee.POSITION_ONLY}));return e=Ki.fromGeometry({context:t,geometry:n,attributeLocations:Kot,bufferUsage:ce.STATIC_DRAW,interleave:!0}),t.cache.ellipsoidPrimitive_vertexArray=e,e}Xz.prototype.update=function(t){if(!this.show||t.mode!==Vt.SCENE3D||!c(this.center)||!c(this.radii))return;let e=t.context,n=this.material.isTranslucent(),i=this._translucent!==n;(!c(this._rs)||i)&&(this._translucent=n,this._rs=he.fromCache({cull:{enabled:!0,face:so.FRONT},depthTest:{enabled:this._depthTestEnabled},depthMask:!n&&e.fragmentDepth,blending:n?Pn.ALPHA_BLEND:void 0})),c(this._va)||(this._va=lIe(e));let o=!1,a=this.radii;if(!p.equals(this._radii,a)){p.clone(a,this._radii);let F=this._oneOverEllipsoidRadiiSquared;F.x=1/(a.x*a.x),F.y=1/(a.y*a.y),F.z=1/(a.z*a.z),o=!0}(!L.equals(this.modelMatrix,this._modelMatrix)||!p.equals(this.center,this._center))&&(L.clone(this.modelMatrix,this._modelMatrix),p.clone(this.center,this._center),L.multiplyByTranslation(this.modelMatrix,this.center,this._computedModelMatrix),o=!0),o&&(p.clone(p.ZERO,this._boundingSphere.center),this._boundingSphere.radius=p.maximumComponent(a),Ft.transform(this._boundingSphere,this._computedModelMatrix,this._boundingSphere));let s=this._material!==this.material;this._material=this.material,this._material.update(e);let l=this.onlySunLighting!==this._onlySunLighting;this._onlySunLighting=this.onlySunLighting;let r=t.useLogDepth,d=this._useLogDepth!==r;this._useLogDepth=r;let m=this._colorCommand,h,u;(s||l||i||d)&&(h=new Ze({sources:[Y1]}),u=new Ze({sources:[this.material.shaderSource,k1]}),this.onlySunLighting&&u.defines.push("ONLY_SUN_LIGHTING"),!n&&e.fragmentDepth&&u.defines.push("WRITE_DEPTH"),this._useLogDepth&&(h.defines.push("LOG_DEPTH"),u.defines.push("LOG_DEPTH")),this._sp=xn.replaceCache({context:e,shaderProgram:this._sp,vertexShaderSource:h,fragmentShaderSource:u,attributeLocations:Kot}),m.vertexArray=this._va,m.renderState=this._rs,m.shaderProgram=this._sp,m.uniformMap=ze(this._uniforms,this.material._uniforms),m.executeInClosestFrustum=n);let R=t.commandList,V=t.passes;if(V.render&&(m.boundingVolume=this._boundingSphere,m.debugShowBoundingVolume=this.debugShowBoundingVolume,m.modelMatrix=this._computedModelMatrix,m.pass=n?Pt.TRANSLUCENT:Pt.OPAQUE,R.push(m)),V.pick){let F=this._pickCommand;(!c(this._pickId)||this._id!==this.id)&&(this._id=this.id,this._pickId=this._pickId&&this._pickId.destroy(),this._pickId=e.createPickId({primitive:this,id:this.id})),(s||l||!c(this._pickSP)||d)&&(h=new Ze({sources:[Y1]}),u=new Ze({sources:[this.material.shaderSource,k1],pickColorQualifier:"uniform"}),this.onlySunLighting&&u.defines.push("ONLY_SUN_LIGHTING"),!n&&e.fragmentDepth&&u.defines.push("WRITE_DEPTH"),this._useLogDepth&&(h.defines.push("LOG_DEPTH"),u.defines.push("LOG_DEPTH")),this._pickSP=xn.replaceCache({context:e,shaderProgram:this._pickSP,vertexShaderSource:h,fragmentShaderSource:u,attributeLocations:Kot}),F.vertexArray=this._va,F.renderState=this._rs,F.shaderProgram=this._pickSP,F.uniformMap=ze(ze(this._uniforms,this._pickUniforms),this.material._uniforms),F.executeInClosestFrustum=n),F.boundingVolume=this._boundingSphere,F.modelMatrix=this._computedModelMatrix,F.pass=n?Pt.TRANSLUCENT:Pt.OPAQUE,R.push(F)}};Xz.prototype.isDestroyed=function(){return!1};Xz.prototype.destroy=function(){return this._sp=this._sp&&this._sp.destroy(),this._pickSP=this._pickSP&&this._pickSP.destroy(),this._pickId=this._pickId&&this._pickId.destroy(),At(this)};var h_=Xz;function p_(t){t=f(t,f.EMPTY_OBJECT);let e=t.textureUrl;c(e)||(e=Dn("Assets/Textures/moonSmall.jpg")),this.show=f(t.show,!0),this.textureUrl=e,this._ellipsoid=f(t.ellipsoid,mt.MOON),this.onlySunLighting=f(t.onlySunLighting,!0),this._ellipsoidPrimitive=new h_({radii:this.ellipsoid.radii,material:eo.fromType(eo.ImageType),depthTestEnabled:!1,_owner:this}),this._ellipsoidPrimitive.material.translucent=!1,this._axes=new m_}Object.defineProperties(p_.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});var Jz=new ot,rIe=new ot,dIe=new p,Lz=[];p_.prototype.update=function(t){if(!this.show)return;let e=this._ellipsoidPrimitive;e.material.uniforms.image=this.textureUrl,e.onlySunLighting=this.onlySunLighting;let n=t.time;c(Pe.computeIcrfToFixedMatrix(n,Jz))||Pe.computeTemeToPseudoFixedMatrix(n,Jz);let i=this._axes.evaluate(n,rIe);ot.transpose(i,i),ot.multiply(Jz,i,i);let o=_Z.computeMoonPositionInEarthInertialFrame(n,dIe);ot.multiplyByVector(Jz,o,o),L.fromRotationTranslation(i,o,e.modelMatrix);let a=t.commandList;return t.commandList=Lz,Lz.length=0,e.update(t),t.commandList=a,Lz.length===1?Lz[0]:void 0};p_.prototype.isDestroyed=function(){return!1};p_.prototype.destroy=function(){return this._ellipsoidPrimitive=this._ellipsoidPrimitive&&this._ellipsoidPrimitive.destroy(),At(this)};var V_=p_;var hMo=b(W(),1);var AAo=b(W(),1);var zot=[],jot=[];function cIe(t,e,n,i,o,a){let s=o-i+1,l=a-o,r=zot,d=jot,m,h;for(m=0;m<s;++m)r[m]=t[i+m];for(h=0;h<l;++h)d[h]=t[o+h+1];m=0,h=0;for(let u=i;u<=a;++u){let R=r[m],V=d[h];m<s&&(h>=l||e(R,V,n)<=0)?(t[u]=R,++m):h<l&&(t[u]=V,++h)}}function qot(t,e,n,i,o){if(i>=o)return;let a=Math.floor((i+o)*.5);qot(t,e,n,i,a),qot(t,e,n,a+1,o),cIe(t,e,n,i,a,o)}function mIe(t,e,n){let i=t.length,o=Math.ceil(i*.5);zot.length=o,jot.length=o,qot(t,e,n,0,i-1),zot.length=0,jot.length=0}var uW=mIe;var QAo=b(W(),1);function rc(t,e){this._occluderPosition=p.clone(t.center),this._occluderRadius=t.radius,this._horizonDistance=0,this._horizonPlaneNormal=void 0,this._horizonPlanePosition=void 0,this._cameraPosition=void 0,this.cameraPosition=e}var Mz=new p;Object.defineProperties(rc.prototype,{position:{get:function(){return this._occluderPosition}},radius:{get:function(){return this._occluderRadius}},cameraPosition:{set:function(t){t=p.clone(t,this._cameraPosition);let e=p.subtract(this._occluderPosition,t,Mz),n=p.magnitudeSquared(e),i=this._occluderRadius*this._occluderRadius,o,a,s;if(n>i){o=Math.sqrt(n-i),n=1/Math.sqrt(n),a=p.multiplyByScalar(e,n,Mz);let l=o*o*n;s=p.add(t,p.multiplyByScalar(a,l,Mz),Mz)}else o=Number.MAX_VALUE;this._horizonDistance=o,this._horizonPlaneNormal=a,this._horizonPlanePosition=s,this._cameraPosition=t}}});rc.fromBoundingSphere=function(t,e,n){return c(n)?(p.clone(t.center,n._occluderPosition),n._occluderRadius=t.radius,n.cameraPosition=e,n):new rc(t,e)};var TNt=new p;rc.prototype.isPointVisible=function(t){if(this._horizonDistance!==Number.MAX_VALUE){let e=p.subtract(t,this._occluderPosition,TNt),n=this._occluderRadius;if(n=p.magnitudeSquared(e)-n*n,n>0)return n=Math.sqrt(n)+this._horizonDistance,e=p.subtract(t,this._cameraPosition,e),n*n>p.magnitudeSquared(e)}return!1};var hIe=new p;rc.prototype.isBoundingSphereVisible=function(t){let e=p.clone(t.center,hIe),n=t.radius;if(this._horizonDistance!==Number.MAX_VALUE){let i=p.subtract(e,this._occluderPosition,TNt),o=this._occluderRadius-n;if(o=p.magnitudeSquared(i)-o*o,n<this._occluderRadius)return o>0?(o=Math.sqrt(o)+this._horizonDistance,i=p.subtract(e,this._cameraPosition,i),o*o+n*n>p.magnitudeSquared(i)):!1;if(o>0){i=p.subtract(e,this._cameraPosition,i);let a=p.magnitudeSquared(i),s=this._occluderRadius*this._occluderRadius,l=n*n;return(this._horizonDistance*this._horizonDistance+s)*l>a*s?!0:(o=Math.sqrt(o)+this._horizonDistance,o*o+l>a)}return!0}return!1};var pIe=new p;rc.prototype.computeVisibility=function(t){let e=p.clone(t.center),n=t.radius;if(n>this._occluderRadius)return Ys.FULL;if(this._horizonDistance!==Number.MAX_VALUE){let i=p.subtract(e,this._occluderPosition,pIe),o=this._occluderRadius-n,a=p.magnitudeSquared(i);if(o=a-o*o,o>0){o=Math.sqrt(o)+this._horizonDistance,i=p.subtract(e,this._cameraPosition,i);let s=p.magnitudeSquared(i);return o*o+n*n<s?Ys.NONE:(o=this._occluderRadius+n,o=a-o*o,o>0?(o=Math.sqrt(o)+this._horizonDistance,s<o*o+n*n?Ys.FULL:Ys.PARTIAL):(i=p.subtract(e,this._horizonPlanePosition,i),p.dot(i,this._horizonPlaneNormal)>-n?Ys.PARTIAL:Ys.FULL))}}return Ys.NONE};var _z=new p;rc.computeOccludeePoint=function(t,e,n){let i=p.clone(e),o=p.clone(t.center),a=t.radius,s=n.length,l=p.normalize(p.subtract(i,o,_z),_z),r=-p.dot(l,o),d=rc._anyRotationVector(o,l,r),m=rc._horizonToPlaneNormalDotProduct(t,l,r,d,n[0]);if(!m)return;let h;for(let R=1;R<s;++R){if(h=rc._horizonToPlaneNormalDotProduct(t,l,r,d,n[R]),!h)return;h<m&&(m=h)}if(m<.0017453283658983088)return;let u=a/m;return p.add(o,p.multiplyByScalar(l,u,_z),_z)};var VIe=[];rc.computeOccludeePointFromRectangle=function(t,e){e=f(e,mt.WGS84);let n=Gt.subsample(t,e,0,VIe),i=Ft.fromPoints(n),o=p.ZERO;if(!p.equals(o,i.center))return rc.computeOccludeePoint(new Ft(o,e.minimumRadius),i.center,n)};var uIe=new p;rc._anyRotationVector=function(t,e,n){let i=p.abs(e,uIe),o=i.x>i.y?0:1;(o===0&&i.z>i.x||o===1&&i.z>i.y)&&(o=2);let a=new p,s;o===0?(i.x=t.x,i.y=t.y+1,i.z=t.z+1,s=p.UNIT_X):o===1?(i.x=t.x+1,i.y=t.y,i.z=t.z+1,s=p.UNIT_Y):(i.x=t.x+1,i.y=t.y+1,i.z=t.z,s=p.UNIT_Z);let l=(p.dot(e,i)+n)/-p.dot(e,s);return p.normalize(p.subtract(p.add(i,p.multiplyByScalar(s,l,a),i),t,i),i)};var ZIe=new p;rc._rotationVector=function(t,e,n,i,o){let a=p.subtract(i,t,ZIe);if(a=p.normalize(a,a),p.dot(e,a)<.9999999847691291){let s=p.cross(e,a,a);if(p.magnitude(s)>k.EPSILON13)return p.normalize(s,new p)}return o};var $ot=new p,RIe=new p,Dz=new p,SNt=new p;rc._horizonToPlaneNormalDotProduct=function(t,e,n,i,o){let a=p.clone(o,$ot),s=p.clone(t.center,RIe),l=t.radius,r=p.subtract(s,a,Dz),d=p.magnitudeSquared(r),m=l*l;if(d<m)return!1;let h=d-m,u=Math.sqrt(h),V=1/Math.sqrt(d),U=u*V*u;r=p.normalize(r,r);let G=p.add(a,p.multiplyByScalar(r,U,SNt),SNt),A=Math.sqrt(h-U*U),S=this._rotationVector(s,e,n,a,i),g=p.fromElements(S.x*S.x*r.x+(S.x*S.y-S.z)*r.y+(S.x*S.z+S.y)*r.z,(S.x*S.y+S.z)*r.x+S.y*S.y*r.y+(S.y*S.z-S.x)*r.z,(S.x*S.z-S.y)*r.x+(S.y*S.z+S.x)*r.y+S.z*S.z*r.z,$ot);g=p.normalize(g,g);let C=p.multiplyByScalar(g,A,$ot);S=p.normalize(p.subtract(p.add(G,C,Dz),s,Dz),Dz);let y=p.dot(e,S);S=p.normalize(p.subtract(p.subtract(G,C,S),s,S),S);let Y=p.dot(e,S);return y<Y?y:Y};var u_=rc;var KAo=b(W(),1);var DAo=b(W(),1);function XR(t){t=f(t,f.EMPTY_OBJECT),this.left=t.left,this._left=void 0,this.right=t.right,this._right=void 0,this.top=t.top,this._top=void 0,this.bottom=t.bottom,this._bottom=void 0,this.near=f(t.near,1),this._near=this.near,this.far=f(t.far,5e8),this._far=this.far,this._cullingVolume=new Jl,this._perspectiveMatrix=new L,this._infinitePerspective=new L}function tat(t){let e=t.top,n=t.bottom,i=t.right,o=t.left,a=t.near,s=t.far;(e!==t._top||n!==t._bottom||o!==t._left||i!==t._right||a!==t._near||s!==t._far)&&(t._left=o,t._right=i,t._top=e,t._bottom=n,t._near=a,t._far=s,t._perspectiveMatrix=L.computePerspectiveOffCenter(o,i,n,e,a,s,t._perspectiveMatrix),t._infinitePerspective=L.computeInfinitePerspectiveOffCenter(o,i,n,e,a,t._infinitePerspective))}Object.defineProperties(XR.prototype,{projectionMatrix:{get:function(){return tat(this),this._perspectiveMatrix}},infiniteProjectionMatrix:{get:function(){return tat(this),this._infinitePerspective}}});var bIe=new p,WIe=new p,fIe=new p,FIe=new p;XR.prototype.computeCullingVolume=function(t,e,n){let i=this._cullingVolume.planes,o=this.top,a=this.bottom,s=this.right,l=this.left,r=this.near,d=this.far,m=p.cross(e,n,bIe),h=WIe;p.multiplyByScalar(e,r,h),p.add(t,h,h);let u=fIe;p.multiplyByScalar(e,d,u),p.add(t,u,u);let R=FIe;p.multiplyByScalar(m,l,R),p.add(h,R,R),p.subtract(R,t,R),p.normalize(R,R),p.cross(R,n,R),p.normalize(R,R);let V=i[0];return c(V)||(V=i[0]=new bt),V.x=R.x,V.y=R.y,V.z=R.z,V.w=-p.dot(R,t),p.multiplyByScalar(m,s,R),p.add(h,R,R),p.subtract(R,t,R),p.cross(n,R,R),p.normalize(R,R),V=i[1],c(V)||(V=i[1]=new bt),V.x=R.x,V.y=R.y,V.z=R.z,V.w=-p.dot(R,t),p.multiplyByScalar(n,a,R),p.add(h,R,R),p.subtract(R,t,R),p.cross(m,R,R),p.normalize(R,R),V=i[2],c(V)||(V=i[2]=new bt),V.x=R.x,V.y=R.y,V.z=R.z,V.w=-p.dot(R,t),p.multiplyByScalar(n,o,R),p.add(h,R,R),p.subtract(R,t,R),p.cross(R,m,R),p.normalize(R,R),V=i[3],c(V)||(V=i[3]=new bt),V.x=R.x,V.y=R.y,V.z=R.z,V.w=-p.dot(R,t),V=i[4],c(V)||(V=i[4]=new bt),V.x=e.x,V.y=e.y,V.z=e.z,V.w=-p.dot(e,h),p.negate(e,R),V=i[5],c(V)||(V=i[5]=new bt),V.x=R.x,V.y=R.y,V.z=R.z,V.w=-p.dot(R,u),this._cullingVolume};XR.prototype.getPixelDimensions=function(t,e,n,i,o){tat(this);let a=1/this.near,s=this.top*a,l=2*i*n*s/e;s=this.right*a;let r=2*i*n*s/t;return o.x=r,o.y=l,o};XR.prototype.clone=function(t){return c(t)||(t=new XR),t.right=this.right,t.left=this.left,t.top=this.top,t.bottom=this.bottom,t.near=this.near,t.far=this.far,t._left=void 0,t._right=void 0,t._top=void 0,t._bottom=void 0,t._near=void 0,t._far=void 0,t};XR.prototype.equals=function(t){return c(t)&&t instanceof XR&&this.right===t.right&&this.left===t.left&&this.top===t.top&&this.bottom===t.bottom&&this.near===t.near&&this.far===t.far};XR.prototype.equalsEpsilon=function(t,e,n){return t===this||c(t)&&t instanceof XR&&k.equalsEpsilon(this.right,t.right,e,n)&&k.equalsEpsilon(this.left,t.left,e,n)&&k.equalsEpsilon(this.top,t.top,e,n)&&k.equalsEpsilon(this.bottom,t.bottom,e,n)&&k.equalsEpsilon(this.near,t.near,e,n)&&k.equalsEpsilon(this.far,t.far,e,n)};var em=XR;function th(t){t=f(t,f.EMPTY_OBJECT),this._offCenterFrustum=new em,this.fov=t.fov,this._fov=void 0,this._fovy=void 0,this._sseDenominator=void 0,this.aspectRatio=t.aspectRatio,this._aspectRatio=void 0,this.near=f(t.near,1),this._near=this.near,this.far=f(t.far,5e8),this._far=this.far,this.xOffset=f(t.xOffset,0),this._xOffset=this.xOffset,this.yOffset=f(t.yOffset,0),this._yOffset=this.yOffset}th.packedLength=6;th.pack=function(t,e,n){return n=f(n,0),e[n++]=t.fov,e[n++]=t.aspectRatio,e[n++]=t.near,e[n++]=t.far,e[n++]=t.xOffset,e[n]=t.yOffset,e};th.unpack=function(t,e,n){return e=f(e,0),c(n)||(n=new th),n.fov=t[e++],n.aspectRatio=t[e++],n.near=t[e++],n.far=t[e++],n.xOffset=t[e++],n.yOffset=t[e],n};function lZ(t){let e=t._offCenterFrustum;(t.fov!==t._fov||t.aspectRatio!==t._aspectRatio||t.near!==t._near||t.far!==t._far||t.xOffset!==t._xOffset||t.yOffset!==t._yOffset)&&(t._aspectRatio=t.aspectRatio,t._fov=t.fov,t._fovy=t.aspectRatio<=1?t.fov:Math.atan(Math.tan(t.fov*.5)/t.aspectRatio)*2,t._near=t.near,t._far=t.far,t._sseDenominator=2*Math.tan(.5*t._fovy),t._xOffset=t.xOffset,t._yOffset=t.yOffset,e.top=t.near*Math.tan(.5*t._fovy),e.bottom=-e.top,e.right=t.aspectRatio*e.top,e.left=-e.right,e.near=t.near,e.far=t.far,e.right+=t.xOffset,e.left+=t.xOffset,e.top+=t.yOffset,e.bottom+=t.yOffset)}Object.defineProperties(th.prototype,{projectionMatrix:{get:function(){return lZ(this),this._offCenterFrustum.projectionMatrix}},infiniteProjectionMatrix:{get:function(){return lZ(this),this._offCenterFrustum.infiniteProjectionMatrix}},fovy:{get:function(){return lZ(this),this._fovy}},sseDenominator:{get:function(){return lZ(this),this._sseDenominator}},offCenterFrustum:{get:function(){return lZ(this),this._offCenterFrustum}}});th.prototype.computeCullingVolume=function(t,e,n){return lZ(this),this._offCenterFrustum.computeCullingVolume(t,e,n)};th.prototype.getPixelDimensions=function(t,e,n,i,o){return lZ(this),this._offCenterFrustum.getPixelDimensions(t,e,n,i,o)};th.prototype.clone=function(t){return c(t)||(t=new th),t.aspectRatio=this.aspectRatio,t.fov=this.fov,t.near=this.near,t.far=this.far,t._aspectRatio=void 0,t._fov=void 0,t._near=void 0,t._far=void 0,this._offCenterFrustum.clone(t._offCenterFrustum),t};th.prototype.equals=function(t){return!c(t)||!(t instanceof th)?!1:(lZ(this),lZ(t),this.fov===t.fov&&this.aspectRatio===t.aspectRatio&&this._offCenterFrustum.equals(t._offCenterFrustum))};th.prototype.equalsEpsilon=function(t,e,n){return!c(t)||!(t instanceof th)?!1:(lZ(this),lZ(t),k.equalsEpsilon(this.fov,t.fov,e,n)&&k.equalsEpsilon(this.aspectRatio,t.aspectRatio,e,n)&&this._offCenterFrustum.equalsEpsilon(t._offCenterFrustum,e,n))};var Io=th;var eSo=b(W(),1);var jAo=b(W(),1),Z_={NONE:0,SCENE_LIGHT:1,SUNLIGHT:2};Z_.fromGlobeFlags=function(t){return t.enableLighting&&t.dynamicAtmosphereLighting?t.dynamicAtmosphereLightingFromSun?Z_.SUNLIGHT:Z_.SCENE_LIGHT:Z_.NONE};var VT=Object.freeze(Z_);function UIe(){this.lightIntensity=10,this.rayleighCoefficient=new p(55e-7,13e-6,284e-7),this.mieCoefficient=new p(21e-6,21e-6,21e-6),this.rayleighScaleHeight=1e4,this.mieScaleHeight=3200,this.mieAnisotropy=.9,this.hueShift=0,this.saturationShift=0,this.brightnessShift=0,this.dynamicLighting=VT.NONE}var R_=UIe;var uSo=b(W(),1);var iSo=b(W(),1),b_=`in vec2 v_textureCoordinates; const float M_PI = 3.141592653589793; float vdcRadicalInverse(int i) @@ -10678,14 +10678,14 @@ void main() { out_FragColor = vec4(integrateBrdf(v_textureCoordinates.y, v_textureCoordinates.x), 0.0, 1.0); } -`;function W_(){this._colorTexture=void 0,this._drawCommand=void 0}Object.defineProperties(W_.prototype,{colorTexture:{get:function(){return this._colorTexture}}});function GIe(t,e,n){let i=e.createViewportQuadCommand(R_,{framebuffer:n,renderState:he.fromCache({viewport:new Fe(0,0,256,256)})});t._drawCommand=i}W_.prototype.update=function(t){if(!c(this._colorTexture)){let e=t.context,n=new hn({context:e,width:256,height:256,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,sampler:Hn.NEAREST});this._colorTexture=n;let i=new Lr({context:e,colorTextures:[n],destroyAttachments:!1});GIe(this,e,i),this._drawCommand.execute(e),i.destroy(),this._drawCommand.shaderProgram=this._drawCommand.shaderProgram&&this._drawCommand.shaderProgram.destroy()}};W_.prototype.isDestroyed=function(){return!1};W_.prototype.destroy=function(){return this._colorTexture=this._colorTexture&&this._colorTexture.destroy(),At(this)};var f_=W_;var WSo=R(W(),1);var gTo=R(W(),1);var INt={};function AIe(t,e,n){let i,o,a;if(t instanceof Io){let s=Math.tan(.5*t.fovy);return i=t.near,o=t.near*s,a=t.aspectRatio*o,Math.max(e*i/a,n*i/o)}else if(t instanceof em)return i=t.near,o=t.top,a=t.right,Math.max(e*i/a,n*i/o);return Math.max(e,n)}var TIe=new p,gNt=new p;function NNt(t,e,n,i){if(c(i)&&n(.5)>i){let o=n(0),a=n(1),s=n(.5),l=s-o,r=s-a;return function(d){let m=n(d);if(d<=.5){let Z=(m-o)/l;return k.lerp(t,-k.PI_OVER_TWO,Z)}let h=(m-a)/r;return k.lerp(-k.PI_OVER_TWO,e,1-h)}}return function(o){return k.lerp(t,e,o)}}function nat(t,e,n,i,o){let a=o,s=Math.max(n,i);if(!c(a)){let l=t.position,r=e,d=t.up,m=t.right,h=t.frustum,Z=p.subtract(l,r,TIe),b=p.magnitude(p.multiplyByScalar(d,p.dot(Z,d),gNt)),u=p.magnitude(p.multiplyByScalar(m,p.dot(Z,m),gNt));a=Math.min(AIe(h,b,u)*.2,1e9)}if(s<a){let d=-Math.pow((a-n)*1e6,.125),m=Math.pow((a-i)*1e6,1/8);return function(h){let Z=h*(m-d)+d;return-Math.pow(Z,8)/1e6+a}}return function(l){return k.lerp(n,i,l)}}function F_(t,e){return k.equalsEpsilon(t,k.TWO_PI,k.EPSILON11)&&(t=0),e>t+Math.PI?t+=k.TWO_PI:e<t-Math.PI&&(t-=k.TWO_PI),t}var yNt=new p;function SIe(t,e,n,i,o,a,s,l){let r=t.camera,d=p.clone(r.position,yNt),m=r.pitch,h=F_(r.heading,i),Z=F_(r.roll,a),b=nat(r,n,d.z,n.z,s),u=NNt(m,o,b,l);function F(U){let G=U.time/e;r.setView({orientation:{heading:k.lerp(h,i,G),pitch:u(G),roll:k.lerp(Z,a,G)}}),K.lerp(d,n,G,r.position),r.position.z=b(G)}return F}function gIe(t,e){t.longitude<e.longitude?t.longitude+=k.TWO_PI:e.longitude+=k.TWO_PI}function EIe(t,e){let n=t.longitude-e.longitude;n<-k.PI?t.longitude+=k.TWO_PI:n>k.PI&&(e.longitude+=k.TWO_PI)}var CIe=new gt,IIe=new gt;function NIe(t,e,n,i,o,a,s,l,r,d){let m=t.camera,Z=t.mapProjection.ellipsoid,b=gt.clone(m.positionCartographic,CIe),u=m.pitch,F=F_(m.heading,i),U=F_(m.roll,a),G=Z.cartesianToCartographic(n,IIe);b.longitude=k.zeroToTwoPi(b.longitude),G.longitude=k.zeroToTwoPi(G.longitude);let A=!1;if(c(l)){let y=k.zeroToTwoPi(l),Y=Math.min(b.longitude,G.longitude),Q=Math.max(b.longitude,G.longitude),J=y>=Y&&y<=Q;if(c(r)){let M=Math.abs(b.longitude-G.longitude),V=k.TWO_PI-M;(J?M:V)<(J?V:M)*r&&!J&&(A=!0)}else J||(A=!0)}A?gIe(b,G):EIe(b,G);let T=nat(m,n,b.height,G.height,s),g=NNt(u,o,T,d);function C(){let y=b.longitude,Y=G.longitude,Q=b.latitude,J=G.latitude;return function(V){let E=V.time/e,I=p.fromRadians(k.lerp(y,Y,E),k.lerp(Q,J,E),T(E),Z);m.setView({destination:I,orientation:{heading:k.lerp(F,i,E),pitch:g(E),roll:k.lerp(U,a,E)}})}}return C()}function yIe(t,e,n,i,o,a,s){let l=t.camera,r=p.clone(l.position,yNt),d=F_(l.heading,i),m=l.frustum.right-l.frustum.left,h=nat(l,n,m,n.z,s);function Z(b){let u=b.time/e;l.setView({orientation:{heading:k.lerp(d,i,u)}}),K.lerp(r,n,u,l.position);let F=h(u),U=l.frustum,G=U.top/U.right,A=(F-(U.right-U.left))*.5;U.right+=A,U.left-=A,U.top=G*U.right,U.bottom=-U.top}return Z}var ENt=new gt,BIe=new p;function eat(t,e){return{startObject:{},stopObject:{},duration:0,complete:t,cancel:e}}function CNt(t,e){function n(){typeof e=="function"&&e(),t.enableInputs=!0}return n}INt.createTween=function(t,e){e=f(e,f.EMPTY_OBJECT);let n=e.destination,i=t.mode;if(i===ut.MORPHING)return eat();let o=f(e.convert,!0),a=t.mapProjection,s=a.ellipsoid,l=e.maximumHeight,r=e.flyOverLongitude,d=e.flyOverLongitudeWeight,m=e.pitchAdjustHeight,h=e.easingFunction;o&&i!==ut.SCENE3D&&(s.cartesianToCartographic(n,ENt),n=a.project(ENt,BIe));let Z=t.camera,b=e.endTransform;c(b)&&Z._setTransform(b);let u=e.duration;c(u)||(u=Math.ceil(p.distance(Z.position,n)/1e6)+2,u=Math.min(u,3));let F=f(e.heading,0),U=f(e.pitch,-k.PI_OVER_TWO),G=f(e.roll,0),A=t.screenSpaceCameraController;A.enableInputs=!1;let T=CNt(A,e.complete),g=CNt(A,e.cancel),C=Z.frustum,y=t.mode===ut.SCENE2D;if(y=y&&K.equalsEpsilon(Z.position,n,k.EPSILON6),y=y&&k.equalsEpsilon(Math.max(C.right-C.left,C.top-C.bottom),n.z,k.EPSILON6),y=y||t.mode!==ut.SCENE2D&&p.equalsEpsilon(n,Z.position,k.EPSILON10),y=y&&k.equalsEpsilon(k.negativePiToPi(F),k.negativePiToPi(Z.heading),k.EPSILON10)&&k.equalsEpsilon(k.negativePiToPi(U),k.negativePiToPi(Z.pitch),k.EPSILON10)&&k.equalsEpsilon(k.negativePiToPi(G),k.negativePiToPi(Z.roll),k.EPSILON10),y)return eat(T,g);let Y=new Array(4);if(Y[ut.SCENE2D]=yIe,Y[ut.SCENE3D]=NIe,Y[ut.COLUMBUS_VIEW]=SIe,u<=0)return eat(function(){Y[i](t,1,n,F,U,G,l,r,d,m)({time:1}),typeof T=="function"&&T()},g);let Q=Y[i](t,u,n,F,U,G,l,r,d,m);if(!c(h)){let J=Z.positionCartographic.height,M=i===ut.SCENE3D?s.cartesianToCartographic(n).height:n.z;J>M&&J>11500?h=Zl.CUBIC_OUT:h=Zl.QUINTIC_IN_OUT}return{duration:u,easingFunction:h,startObject:{time:0},stopObject:{time:u},update:Q,complete:T,cancel:g}};var U_=INt;var CTo=R(W(),1),QIe={ROTATE:0,INFINITE_SCROLL:1},eh=Object.freeze(QIe);var LTo=R(W(),1);var iat={},Oz=t=>t.position.constructor.name==="ConstantPositionProperty"?t:!1,BNt=function(t,e,n,i=mt.WGS84){let o=iat[t.id]||iat[e.id]||null;if(o===null){let l=Oz(t)||Oz(e),r=!Oz(t)&&!Oz(e),d=l||t;o=new BZ(i,d.position.getValue(n)),o.eid=d.id,r||(iat[l.id]=o)}let a=o.eid===t.id?e:t;return o.isPointVisible(a.position.getValue(n))},kIe=function(t,e){let n=0,i=0,o=0;try{let{fromCartesian:a}=gt,{subtract:s,normalize:l,dot:r,distance:d}=p,m=new oZ;m.setEndPoints(a(t),a(e));let h=m.startHeading<0?m.startHeading+k.TWO_PI:m.startHeading;n=k.toDegrees(h);let Z=new p(0,0,0),b=s(t,e,Z);b=l(b,Z);let u=new p,F=p.normalize(t,u),U=r(b,F);i=k.toDegrees(Math.acos(U))-90,o=d(t,e)}catch(a){console.log(a)}return{az:n,el:i,range:o}},oat=class{constructor(e,n,i){this.id=e,this.from=n,this.to=i,this.polylineCollectionArrays=[]}},ip={},YIe=(t,e,n,i=Date.now().toString())=>{if(ip[i])return i;ip[i]=new oat(i,e,n);for(let o=0;o<n.length;o++){let a=new Mc;for(let s=0;s<e.length;s++)a.add({positions:[n[o].position.getValue(t.clock.currentTime),e[s].position.getValue(t.clock.currentTime)],width:1,material:new eo({fabric:{type:"Color",uniforms:{color:v.LIMEGREEN}}}),show:!0});t.scene.primitives.add(a),ip[i].polylineCollectionArrays.push(a)}return ip[i].removeListener=t.clock.onTick.addEventListener(o=>{for(let a in ip)if(ip[a]){let{polylineCollectionArrays:s,from:l,to:r}=ip[a];for(let d=0;d<r.length;d++)for(let m=0;m<l.length;m++){let h=BNt(l[m],r[d],o.currentTime),Z=s[d].get(m);h?(Z.show=!0,Z.positions=[r[d].position.getValue(o.currentTime),l[m].position.getValue(o.currentTime)]):Z.show=!1}}}),t.scene.render(),i},xIe=(t,e)=>{if(e){let n=ip[e];if(!n)return;n.removeListener(),n.polylineCollectionArrays.forEach(i=>{t.scene.primitives.remove(i)}),delete ip[e]}else for(let n in ip)if(ip[n]){let i=ip[n];i.removeListener(),i.polylineCollectionArrays.forEach(o=>{t.scene.primitives.remove(o)}),delete ip[n]}t.scene.render()},XIe=()=>{throw Error("Not Implemented")},x1={calculateAccess:BNt,getAzElRange:kIe,addAccessLines:YIe,removeAccessLines:xIe,calculateSensorAccess:XIe};function fn(t){this._scene=t,this._transform=L.clone(L.IDENTITY),this._invTransform=L.clone(L.IDENTITY),this._actualTransform=L.clone(L.IDENTITY),this._actualInvTransform=L.clone(L.IDENTITY),this._transformChanged=!1,this.position=new p,this._position=new p,this._positionWC=new p,this._positionCartographic=new gt,this._oldPositionWC=void 0,this.positionWCDeltaMagnitude=0,this.positionWCDeltaMagnitudeLastFrame=0,this.timeSinceMoved=0,this._lastMovedTimestamp=0,this.direction=new p,this._direction=new p,this._directionWC=new p,this.up=new p,this._up=new p,this._upWC=new p,this.right=new p,this._right=new p,this._rightWC=new p,this.frustum=new Io,this.frustum.aspectRatio=t.drawingBufferWidth/t.drawingBufferHeight,this.frustum.fov=k.toRadians(60),this.defaultMoveAmount=1e5,this.defaultLookAmount=Math.PI/60,this.defaultRotateAmount=Math.PI/3600,this.defaultZoomAmount=1e5,this.constrainedAxis=void 0,this.maximumZoomFactor=1.5,this._moveStart=new It,this._moveEnd=new It,this._changed=new It,this._changedPosition=void 0,this._changedDirection=void 0,this._changedFrustum=void 0,this._changedHeading=void 0,this._changedRoll=void 0,this.percentageChanged=.5,this._viewMatrix=new L,this._invViewMatrix=new L,MNt(this),this._mode=ut.SCENE3D,this._modeChanged=!0;let e=t.mapProjection;this._projection=e,this._maxCoord=e.project(new gt(Math.PI,k.PI_OVER_TWO)),this._max2Dfrustum=void 0,$Nt(this,fn.DEFAULT_VIEW_RECTANGLE,this.position,!0);let n=p.magnitude(this.position);n+=n*fn.DEFAULT_VIEW_FACTOR,p.normalize(this.position,this.position),p.multiplyByScalar(this.position,n,this.position)}fn.TRANSFORM_2D=new L(0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1);fn.TRANSFORM_2D_INVERSE=L.inverseTransformation(fn.TRANSFORM_2D,new L);fn.DEFAULT_VIEW_RECTANGLE=Gt.fromDegrees(-95,-20,-70,90);fn.DEFAULT_VIEW_FACTOR=.5;fn.DEFAULT_OFFSET=new Zu(0,-k.PI_OVER_FOUR,0);function MNt(t){L.computeView(t._position,t._direction,t._up,t._right,t._viewMatrix),L.multiply(t._viewMatrix,t._actualInvTransform,t._viewMatrix),L.inverseTransformation(t._viewMatrix,t._invViewMatrix)}function JIe(t){if(!c(t._oldPositionWC))t._oldPositionWC=p.clone(t.positionWC,t._oldPositionWC);else{t.positionWCDeltaMagnitudeLastFrame=t.positionWCDeltaMagnitude;let e=p.subtract(t.positionWC,t._oldPositionWC,t._oldPositionWC);t.positionWCDeltaMagnitude=p.magnitude(e),t._oldPositionWC=p.clone(t.positionWC,t._oldPositionWC),t.positionWCDeltaMagnitude>0?(t.timeSinceMoved=0,t._lastMovedTimestamp=Oi()):t.timeSinceMoved=Math.max(Oi()-t._lastMovedTimestamp,0)/1e3}}fn.prototype.canPreloadFlight=function(){return c(this._currentFlight)&&this._mode!==ut.SCENE2D};fn.prototype._updateCameraChanged=function(){let t=this;if(JIe(t),t._changed.numberOfListeners===0)return;let e=t.percentageChanged,n=t.heading;c(t._changedHeading)||(t._changedHeading=n);let i=Math.abs(t._changedHeading-n)%k.TWO_PI;i=i>k.PI?k.TWO_PI-i:i;let o=i/Math.PI;o>e&&(t._changedHeading=n);let a=t.roll;c(t._changedRoll)||(t._changedRoll=a);let s=Math.abs(t._changedRoll-a)%k.TWO_PI;s=s>k.PI?k.TWO_PI-s:s;let l=s/Math.PI;if(l>e&&(t._changedRoll=a),(l>e||o>e)&&t._changed.raiseEvent(Math.max(l,o)),t._mode===ut.SCENE2D){if(!c(t._changedFrustum)){t._changedPosition=p.clone(t.position,t._changedPosition),t._changedFrustum=t.frustum.clone();return}let Z=t.position,b=t._changedPosition,u=t.frustum,F=t._changedFrustum,U=Z.x+u.left,G=Z.x+u.right,A=b.x+F.left,T=b.x+F.right,g=Z.y+u.bottom,C=Z.y+u.top,y=b.y+F.bottom,Y=b.y+F.top,Q=Math.max(U,A),J=Math.min(G,T),M=Math.max(g,y),V=Math.min(C,Y),E;if(Q>=J||M>=C)E=1;else{let I=F;U<A&&G>T&&g<y&&C>Y&&(I=u),E=1-(J-Q)*(V-M)/((I.right-I.left)*(I.top-I.bottom))}E>e&&(t._changed.raiseEvent(E),t._changedPosition=p.clone(t.position,t._changedPosition),t._changedFrustum=t.frustum.clone(t._changedFrustum));return}if(!c(t._changedDirection)){t._changedPosition=p.clone(t.positionWC,t._changedPosition),t._changedDirection=p.clone(t.directionWC,t._changedDirection);return}let r=k.acosClamped(p.dot(t.directionWC,t._changedDirection)),d;c(t.frustum.fovy)?d=r/(t.frustum.fovy*.5):d=r;let h=p.distance(t.positionWC,t._changedPosition)/t.positionCartographic.height;(d>e||h>e)&&(t._changed.raiseEvent(Math.max(d,h)),t._changedPosition=p.clone(t.positionWC,t._changedPosition),t._changedDirection=p.clone(t.directionWC,t._changedDirection))};function LIe(t){Pe.basisTo2D(t._projection,t._transform,t._actualTransform)}var MIe=new gt,_Ie=new p,Hz=new p,DIe=new Rt,OIe=new Rt,HIe=new Rt,wIe=new Rt,PIe=new Rt;function vIe(t){let e=t._projection,n=e.ellipsoid,i=L.getColumn(t._transform,3,DIe),o=n.cartesianToCartographic(i,MIe),a=e.project(o,_Ie),s=OIe;s.x=a.z,s.y=a.x,s.z=a.y,s.w=1;let l=Rt.clone(Rt.UNIT_X,PIe),r=Rt.add(L.getColumn(t._transform,0,Hz),i,Hz);n.cartesianToCartographic(r,o),e.project(o,a);let d=HIe;d.x=a.z,d.y=a.x,d.z=a.y,d.w=0,p.subtract(d,s,d),d.x=0;let m=wIe;if(p.magnitudeSquared(d)>k.EPSILON10)p.cross(l,d,m);else{let h=Rt.add(L.getColumn(t._transform,1,Hz),i,Hz);n.cartesianToCartographic(h,o),e.project(o,a),m.x=a.z,m.y=a.x,m.z=a.y,m.w=0,p.subtract(m,s,m),m.x=0,p.magnitudeSquared(m)<k.EPSILON10&&(Rt.clone(Rt.UNIT_Y,d),Rt.clone(Rt.UNIT_Z,m))}p.cross(m,l,d),p.normalize(d,d),p.cross(l,d,m),p.normalize(m,m),L.setColumn(t._actualTransform,0,d,t._actualTransform),L.setColumn(t._actualTransform,1,m,t._actualTransform),L.setColumn(t._actualTransform,2,l,t._actualTransform),L.setColumn(t._actualTransform,3,s,t._actualTransform)}var aat=new p;function cc(t){let e=t._mode,n=!1,i=0;e===ut.SCENE2D&&(i=t.frustum.right-t.frustum.left,n=i!==t._positionCartographic.height);let o=t._position,a=!p.equals(o,t.position)||n;a&&(o=p.clone(t.position,t._position));let s=t._direction;(isNaN(t.direction.x)||isNaN(t.direction.y)||isNaN(t.direction.z))&&(s=p.clone(t._direction,t.direction));let l=!p.equals(s,t.direction);l&&(p.normalize(t.direction,t.direction),s=p.clone(t.direction,t._direction));let r=t._up,d=!p.equals(r,t.up);d&&(p.normalize(t.up,t.up),r=p.clone(t.up,t._up));let m=t._right,h=!p.equals(m,t.right);h&&(p.normalize(t.right,t.right),m=p.clone(t.right,t._right));let Z=t._transformChanged||t._modeChanged;t._transformChanged=!1,Z&&(L.inverseTransformation(t._transform,t._invTransform),t._mode===ut.COLUMBUS_VIEW||t._mode===ut.SCENE2D?L.equals(L.IDENTITY,t._transform)?L.clone(fn.TRANSFORM_2D,t._actualTransform):t._mode===ut.COLUMBUS_VIEW?LIe(t):vIe(t):L.clone(t._transform,t._actualTransform),L.inverseTransformation(t._actualTransform,t._actualInvTransform),t._modeChanged=!1);let b=t._actualTransform;if(a||Z)if(t._positionWC=L.multiplyByPoint(b,o,t._positionWC),e===ut.SCENE3D||e===ut.MORPHING)t._positionCartographic=t._projection.ellipsoid.cartesianToCartographic(t._positionWC,t._positionCartographic);else{let u=aat;u.x=t._positionWC.y,u.y=t._positionWC.z,u.z=t._positionWC.x,e===ut.SCENE2D&&(u.z=i),t._projection.unproject(u,t._positionCartographic)}if(l||d||h){let u=p.dot(s,p.cross(r,m,aat));if(Math.abs(1-u)>k.EPSILON2){let F=1/p.magnitudeSquared(r),U=p.dot(r,s)*F,G=p.multiplyByScalar(s,U,aat);r=p.normalize(p.subtract(r,G,t._up),t._up),p.clone(r,t.up),m=p.cross(s,r,t._right),p.clone(m,t.right)}}(l||Z)&&(t._directionWC=L.multiplyByPointAsVector(b,s,t._directionWC),p.normalize(t._directionWC,t._directionWC)),(d||Z)&&(t._upWC=L.multiplyByPointAsVector(b,r,t._upWC),p.normalize(t._upWC,t._upWC)),(h||Z)&&(t._rightWC=L.multiplyByPointAsVector(b,m,t._rightWC),p.normalize(t._rightWC,t._rightWC)),(a||l||d||h||Z)&&MNt(t)}function _Nt(t,e){let n;return k.equalsEpsilon(Math.abs(t.z),1,k.EPSILON3)?n=Math.atan2(e.y,e.x)-k.PI_OVER_TWO:n=Math.atan2(t.y,t.x)-k.PI_OVER_TWO,k.TWO_PI-k.zeroToTwoPi(n)}function DNt(t){return k.PI_OVER_TWO-k.acosClamped(t.z)}function ONt(t,e,n){let i=0;return k.equalsEpsilon(Math.abs(t.z),1,k.EPSILON3)||(i=Math.atan2(-n.z,e.z),i=k.zeroToTwoPi(i+k.TWO_PI)),i}var vz=new L,Kz=new L;Object.defineProperties(fn.prototype,{transform:{get:function(){return this._transform}},inverseTransform:{get:function(){return cc(this),this._invTransform}},viewMatrix:{get:function(){return cc(this),this._viewMatrix}},inverseViewMatrix:{get:function(){return cc(this),this._invViewMatrix}},positionCartographic:{get:function(){return cc(this),this._positionCartographic}},positionWC:{get:function(){return cc(this),this._positionWC}},directionWC:{get:function(){return cc(this),this._directionWC}},upWC:{get:function(){return cc(this),this._upWC}},rightWC:{get:function(){return cc(this),this._rightWC}},heading:{get:function(){if(this._mode!==ut.MORPHING){let t=this._projection.ellipsoid,e=L.clone(this._transform,vz),n=Pe.eastNorthUpToFixedFrame(this.positionWC,t,Kz);this._setTransform(n);let i=_Nt(this.direction,this.up);return this._setTransform(e),i}}},pitch:{get:function(){if(this._mode!==ut.MORPHING){let t=this._projection.ellipsoid,e=L.clone(this._transform,vz),n=Pe.eastNorthUpToFixedFrame(this.positionWC,t,Kz);this._setTransform(n);let i=DNt(this.direction);return this._setTransform(e),i}}},roll:{get:function(){if(this._mode!==ut.MORPHING){let t=this._projection.ellipsoid,e=L.clone(this._transform,vz),n=Pe.eastNorthUpToFixedFrame(this.positionWC,t,Kz);this._setTransform(n);let i=ONt(this.direction,this.up,this.right);return this._setTransform(e),i}}},moveStart:{get:function(){return this._moveStart}},moveEnd:{get:function(){return this._moveEnd}},changed:{get:function(){return this._changed}}});fn.prototype.update=function(t){let e=!1;if(t!==this._mode&&(this._mode=t,this._modeChanged=t!==ut.MORPHING,e=this._mode===ut.SCENE2D),e){let n=this._max2Dfrustum=this.frustum.clone(),i=2,o=n.top/n.right;n.right=this._maxCoord.x*i,n.left=-n.right,n.top=o*n.right,n.bottom=-n.top}this._mode===ut.SCENE2D&&vNt(this,this.position)};var KIe=new p,zIe=new p,jIe=new p;fn.prototype._setTransform=function(t){let e=p.clone(this.positionWC,KIe),n=p.clone(this.upWC,zIe),i=p.clone(this.directionWC,jIe);L.clone(t,this._transform),this._transformChanged=!0,cc(this);let o=this._actualInvTransform;L.multiplyByPoint(o,e,this.position),L.multiplyByPointAsVector(o,i,this.direction),L.multiplyByPointAsVector(o,n,this.up),p.cross(this.direction,this.up,this.right),cc(this)};var qIe=new K,$Ie=new di,t1e=new p,e1e=new p;function HNt(t){if(!L.equals(L.IDENTITY,t.transform))return p.magnitude(t.position);let e=t._scene,n=e.globe,i=qIe;i.x=e.drawingBufferWidth/2,i.y=e.drawingBufferHeight/2;let o;if(c(n)){let l=t.getPickRay(i,$Ie);o=n.pickWorldCoordinates(l,e,!0,t1e)}let a;e.pickPositionSupported&&(a=e.pickPositionWorldCoordinates(i,e1e));let s;if(c(o)||c(a)){let l=c(a)?p.distance(a,t.positionWC):Number.POSITIVE_INFINITY,r=c(o)?p.distance(o,t.positionWC):Number.POSITIVE_INFINITY;s=Math.min(l,r)}else s=Math.max(t.positionCartographic.height,0);return s}fn.prototype._adjustOrthographicFrustum=function(t){this.frustum instanceof wn&&(!t&&this._positionCartographic.height<15e4||(this.frustum.width=HNt(this)))};var zz=new p,cat=new L,n1e=new L,mat=new wt,hat=new ot,wNt=new gt;function i1e(t,e,n){let i=L.clone(t.transform,cat),o=Pe.eastNorthUpToFixedFrame(e,t._projection.ellipsoid,n1e);t._setTransform(o),p.clone(p.ZERO,t.position),n.heading=n.heading-k.PI_OVER_TWO;let a=wt.fromHeadingPitchRoll(n,mat),s=ot.fromQuaternion(a,hat);ot.getColumn(s,0,t.direction),ot.getColumn(s,2,t.up),p.cross(t.direction,t.up,t.right),t._setTransform(i),t._adjustOrthographicFrustum(!0)}function o1e(t,e,n,i){let o=L.clone(t.transform,cat);if(t._setTransform(L.IDENTITY),!p.equals(e,t.positionWC)){if(i){let l=t._projection,r=l.ellipsoid.cartesianToCartographic(e,wNt);e=l.project(r,zz)}p.clone(e,t.position)}n.heading=n.heading-k.PI_OVER_TWO;let a=wt.fromHeadingPitchRoll(n,mat),s=ot.fromQuaternion(a,hat);ot.getColumn(s,0,t.direction),ot.getColumn(s,2,t.up),p.cross(t.direction,t.up,t.right),t._setTransform(o),t._adjustOrthographicFrustum(!0)}function a1e(t,e,n,i){let o=L.clone(t.transform,cat);if(t._setTransform(L.IDENTITY),!p.equals(e,t.positionWC)){if(i){let r=t._projection,d=r.ellipsoid.cartesianToCartographic(e,wNt);e=r.project(d,zz)}K.clone(e,t.position);let a=-e.z*.5,s=-a,l=t.frustum;if(s>a){let r=l.top/l.right;l.right=s,l.left=a,l.top=l.right*r,l.bottom=-l.top}}if(t._scene.mapMode2D===eh.ROTATE){n.heading=n.heading-k.PI_OVER_TWO,n.pitch=-k.PI_OVER_TWO,n.roll=0;let a=wt.fromHeadingPitchRoll(n,mat),s=ot.fromQuaternion(a,hat);ot.getColumn(s,2,t.up),p.cross(t.direction,t.up,t.right)}t._setTransform(o)}var s1e=new p,l1e=new p,r1e=new p;function PNt(t,e,n,i){let o=p.clone(n.direction,s1e),a=p.clone(n.up,l1e);if(t._scene.mode===ut.SCENE3D){let l=t._projection.ellipsoid,r=Pe.eastNorthUpToFixedFrame(e,l,vz),d=L.inverseTransformation(r,Kz);L.multiplyByPointAsVector(d,o,o),L.multiplyByPointAsVector(d,a,a)}let s=p.cross(o,a,r1e);return i.heading=_Nt(o,a),i.pitch=DNt(o),i.roll=ONt(o,a,s),i}var dat={destination:void 0,orientation:{direction:void 0,up:void 0,heading:void 0,pitch:void 0,roll:void 0},convert:void 0,endTransform:void 0},X1=new Jr;fn.prototype.setView=function(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.orientation,f.EMPTY_OBJECT),n=this._mode;if(n===ut.MORPHING)return;c(t.endTransform)&&this._setTransform(t.endTransform);let i=f(t.convert,!0),o=f(t.destination,p.clone(this.positionWC,zz));c(o)&&c(o.west)&&(o=this.getRectangleCameraCoordinates(o,zz),i=!1),c(e.direction)&&(e=PNt(this,o,e,dat.orientation)),X1.heading=f(e.heading,0),X1.pitch=f(e.pitch,-k.PI_OVER_TWO),X1.roll=f(e.roll,0),n===ut.SCENE3D?i1e(this,o,X1):n===ut.SCENE2D?a1e(this,o,X1,i):o1e(this,o,X1,i)};var d1e=new p;fn.prototype.flyHome=function(t){fn.prototype._resetTrack();let e=this._mode;if(e===ut.MORPHING&&this._scene.completeMorph(),e===ut.SCENE2D)this.flyTo({destination:fn.DEFAULT_VIEW_RECTANGLE,duration:t,endTransform:L.IDENTITY});else if(e===ut.SCENE3D){let n=this.getRectangleCameraCoordinates(fn.DEFAULT_VIEW_RECTANGLE),i=p.magnitude(n);i+=i*fn.DEFAULT_VIEW_FACTOR,p.normalize(n,n),p.multiplyByScalar(n,i,n),this.flyTo({destination:n,duration:t,endTransform:L.IDENTITY})}else if(e===ut.COLUMBUS_VIEW){let n=this._projection.ellipsoid.maximumRadius,i=new p(0,-1,1);i=p.multiplyByScalar(p.normalize(i,i),5*n,i),this.flyTo({destination:i,duration:t,orientation:{heading:0,pitch:-Math.acos(p.normalize(i,d1e).z),roll:0},endTransform:L.IDENTITY,convert:!1})}};fn.prototype.worldToCameraCoordinates=function(t,e){return c(e)||(e=new Rt),cc(this),L.multiplyByVector(this._actualInvTransform,t,e)};fn.prototype.worldToCameraCoordinatesPoint=function(t,e){return c(e)||(e=new p),cc(this),L.multiplyByPoint(this._actualInvTransform,t,e)};fn.prototype.worldToCameraCoordinatesVector=function(t,e){return c(e)||(e=new p),cc(this),L.multiplyByPointAsVector(this._actualInvTransform,t,e)};fn.prototype.cameraToWorldCoordinates=function(t,e){return c(e)||(e=new Rt),cc(this),L.multiplyByVector(this._actualTransform,t,e)};fn.prototype.cameraToWorldCoordinatesPoint=function(t,e){return c(e)||(e=new p),cc(this),L.multiplyByPoint(this._actualTransform,t,e)};fn.prototype.cameraToWorldCoordinatesVector=function(t,e){return c(e)||(e=new p),cc(this),L.multiplyByPointAsVector(this._actualTransform,t,e)};function vNt(t,e){let n=t._scene.mapMode2D===eh.ROTATE,i=t._maxCoord.x,o=t._maxCoord.y,a,s;n?(s=i,a=-s):(s=e.x-i*2,a=e.x+i*2),e.x>i&&(e.x=s),e.x<-i&&(e.x=a),e.y>o&&(e.y=o),e.y<-o&&(e.y=-o)}var QNt=new p;fn.prototype.move=function(t,e){let n=this.position;p.multiplyByScalar(t,e,QNt),p.add(n,QNt,n),this._mode===ut.SCENE2D&&vNt(this,n),this._adjustOrthographicFrustum(!0)};fn.prototype.moveForward=function(t){t=f(t,this.defaultMoveAmount),this._mode===ut.SCENE2D?jz(this,t):this.move(this.direction,t)};fn.prototype.moveBackward=function(t){t=f(t,this.defaultMoveAmount),this._mode===ut.SCENE2D?jz(this,-t):this.move(this.direction,-t)};fn.prototype.moveUp=function(t){t=f(t,this.defaultMoveAmount),this.move(this.up,t)};fn.prototype.moveDown=function(t){t=f(t,this.defaultMoveAmount),this.move(this.up,-t)};fn.prototype.moveRight=function(t){t=f(t,this.defaultMoveAmount),this.move(this.right,t)};fn.prototype.moveLeft=function(t){t=f(t,this.defaultMoveAmount),this.move(this.right,-t)};fn.prototype.lookLeft=function(t){t=f(t,this.defaultLookAmount),this._mode!==ut.SCENE2D&&this.look(this.up,-t)};fn.prototype.lookRight=function(t){t=f(t,this.defaultLookAmount),this._mode!==ut.SCENE2D&&this.look(this.up,t)};fn.prototype.lookUp=function(t){t=f(t,this.defaultLookAmount),this._mode!==ut.SCENE2D&&this.look(this.right,-t)};fn.prototype.lookDown=function(t){t=f(t,this.defaultLookAmount),this._mode!==ut.SCENE2D&&this.look(this.right,t)};var c1e=new wt,m1e=new ot;fn.prototype.look=function(t,e){let n=f(e,this.defaultLookAmount),i=wt.fromAxisAngle(t,-n,c1e),o=ot.fromQuaternion(i,m1e),a=this.direction,s=this.up,l=this.right;ot.multiplyByVector(o,a,a),ot.multiplyByVector(o,s,s),ot.multiplyByVector(o,l,l)};fn.prototype.twistLeft=function(t){t=f(t,this.defaultLookAmount),this.look(this.direction,t)};fn.prototype.twistRight=function(t){t=f(t,this.defaultLookAmount),this.look(this.direction,-t)};var h1e=new wt,p1e=new ot;fn.prototype.rotate=function(t,e){let n=f(e,this.defaultRotateAmount),i=wt.fromAxisAngle(t,-n,h1e),o=ot.fromQuaternion(i,p1e);ot.multiplyByVector(o,this.position,this.position),ot.multiplyByVector(o,this.direction,this.direction),ot.multiplyByVector(o,this.up,this.up),p.cross(this.direction,this.up,this.right),p.cross(this.right,this.direction,this.up),this._adjustOrthographicFrustum(!1)};fn.prototype.rotateDown=function(t){t=f(t,this.defaultRotateAmount),KNt(this,t)};fn.prototype.rotateUp=function(t){t=f(t,this.defaultRotateAmount),KNt(this,-t)};var u1e=new p,Z1e=new p,V1e=new p,kNt=new p;function KNt(t,e){let n=t.position;if(c(t.constrainedAxis)&&!p.equalsEpsilon(t.position,p.ZERO,k.EPSILON2)){let i=p.normalize(n,u1e),o=p.equalsEpsilon(i,t.constrainedAxis,k.EPSILON2),a=p.equalsEpsilon(i,p.negate(t.constrainedAxis,kNt),k.EPSILON2);if(!o&&!a){let s=p.normalize(t.constrainedAxis,Z1e),l=p.dot(i,s),r=k.acosClamped(l);e>0&&e>r&&(e=r-k.EPSILON4),l=p.dot(i,p.negate(s,kNt)),r=k.acosClamped(l),e<0&&-e>r&&(e=-r+k.EPSILON4);let d=p.cross(s,i,V1e);t.rotate(d,e)}else(o&&e<0||a&&e>0)&&t.rotate(t.right,e)}else t.rotate(t.right,e)}fn.prototype.rotateRight=function(t){t=f(t,this.defaultRotateAmount),zNt(this,-t)};fn.prototype.rotateLeft=function(t){t=f(t,this.defaultRotateAmount),zNt(this,t)};function zNt(t,e){c(t.constrainedAxis)?t.rotate(t.constrainedAxis,e):t.rotate(t.up,e)}function jz(t,e){let n=t.frustum,i;if(e=e*.5,Math.abs(n.top)+Math.abs(n.bottom)>Math.abs(n.left)+Math.abs(n.right)){let o=n.top-e,a=n.bottom+e,s=t._maxCoord.y;t._scene.mapMode2D===eh.ROTATE&&(s*=t.maximumZoomFactor),a>s&&(a=s,o=-s),o<=a&&(o=1,a=-1),i=n.right/n.top,n.top=o,n.bottom=a,n.right=n.top*i,n.left=-n.right}else{let o=n.right-e,a=n.left+e,s=t._maxCoord.x;t._scene.mapMode2D===eh.ROTATE&&(s*=t.maximumZoomFactor),o>s&&(o=s,a=-s),o<=a&&(o=1,a=-1),i=n.top/n.right,n.right=o,n.left=a,n.top=n.right*i,n.bottom=-n.top}}function jNt(t,e){t.move(t.direction,e)}fn.prototype.zoomIn=function(t){t=f(t,this.defaultZoomAmount),this._mode===ut.SCENE2D?jz(this,t):jNt(this,t)};fn.prototype.zoomOut=function(t){t=f(t,this.defaultZoomAmount),this._mode===ut.SCENE2D?jz(this,-t):jNt(this,-t)};fn.prototype.getMagnitude=function(){if(this._mode===ut.SCENE3D)return p.magnitude(this.position);if(this._mode===ut.COLUMBUS_VIEW)return Math.abs(this.position.z);if(this._mode===ut.SCENE2D)return Math.max(this.frustum.right-this.frustum.left,this.frustum.top-this.frustum.bottom)};var b1e=new L;fn.prototype.lookAt=function(t,e){let n=Pe.eastNorthUpToFixedFrame(t,mt.WGS84,b1e);this.lookAtTransform(n,e)};var R1e=new p,W1e=new wt,f1e=new wt,F1e=new ot;function qNt(t,e,n){e=k.clamp(e,-k.PI_OVER_TWO,k.PI_OVER_TWO),t=k.zeroToTwoPi(t)-k.PI_OVER_TWO;let i=wt.fromAxisAngle(p.UNIT_Y,-e,W1e),o=wt.fromAxisAngle(p.UNIT_Z,-t,f1e),a=wt.multiply(o,i,o),s=ot.fromQuaternion(a,F1e),l=p.clone(p.UNIT_X,R1e);return ot.multiplyByVector(s,l,l),p.negate(l,l),p.multiplyByScalar(l,n,l),l}fn.prototype.lookAtTransform=function(t,e){if(this._setTransform(t),!c(e))return;let n;if(c(e.heading)?n=qNt(e.heading,e.pitch,e.range):n=e,this._mode===ut.SCENE2D){K.clone(K.ZERO,this.position),p.negate(n,this.up),this.up.z=0,p.magnitudeSquared(this.up)<k.EPSILON10&&p.clone(p.UNIT_Y,this.up),p.normalize(this.up,this.up),this._setTransform(L.IDENTITY),p.negate(p.UNIT_Z,this.direction),p.cross(this.direction,this.up,this.right),p.normalize(this.right,this.right);let i=this.frustum,o=i.top/i.right;i.right=p.magnitude(n)*.5,i.left=-i.right,i.top=o*i.right,i.bottom=-i.top,this._setTransform(t);return}p.clone(n,this.position),p.negate(this.position,this.direction),p.normalize(this.direction,this.direction),p.cross(this.direction,p.UNIT_Z,this.right),p.magnitudeSquared(this.right)<k.EPSILON10&&p.clone(p.UNIT_X,this.right),p.normalize(this.right,this.right),p.cross(this.right,this.direction,this.up),p.normalize(this.up,this.up),this._adjustOrthographicFrustum(!0)};var G_=new gt,U1e=new gt,G1e=new p,A1e=new p,T1e=new p,S1e=new p,g1e=new p,E1e=new p,C1e=new p,sat=new p,I1e={direction:new p,right:new p,up:new p},YNt;function dc(t,e,n,i){return Math.abs(p.dot(e,n))/i-p.dot(t,n)}function $Nt(t,e,n,i){let o=t._projection.ellipsoid,a=i?t:I1e,s=e.north,l=e.south,r=e.east,d=e.west;d>r&&(r+=k.TWO_PI);let m=(d+r)*.5,h;if(l<-k.PI_OVER_TWO+k.RADIANS_PER_DEGREE&&s>k.PI_OVER_TWO-k.RADIANS_PER_DEGREE)h=0;else{let J=G_;J.longitude=m,J.latitude=s,J.height=0;let M=U1e;M.longitude=m,M.latitude=l,M.height=0;let V=YNt;(!c(V)||V.ellipsoid!==o)&&(YNt=V=new oZ(void 0,void 0,o)),V.setEndPoints(J,M),h=V.interpolateUsingFraction(.5,G_).latitude}let Z=G_;Z.longitude=m,Z.latitude=h,Z.height=0;let b=o.cartographicToCartesian(Z,C1e),u=G_;u.longitude=r,u.latitude=s;let F=o.cartographicToCartesian(u,G1e);u.longitude=d;let U=o.cartographicToCartesian(u,T1e);u.longitude=m;let G=o.cartographicToCartesian(u,g1e);u.latitude=l;let A=o.cartographicToCartesian(u,E1e);u.longitude=r;let T=o.cartographicToCartesian(u,S1e);u.longitude=d;let g=o.cartographicToCartesian(u,A1e);p.subtract(U,b,U),p.subtract(T,b,T),p.subtract(F,b,F),p.subtract(g,b,g),p.subtract(G,b,G),p.subtract(A,b,A);let C=o.geodeticSurfaceNormal(b,a.direction);p.negate(C,C);let y=p.cross(C,p.UNIT_Z,a.right);p.normalize(y,y);let Y=p.cross(y,C,a.up),Q;if(t.frustum instanceof wn){let J=Math.max(p.distance(F,U),p.distance(T,g)),M=Math.max(p.distance(F,T),p.distance(U,g)),V,E,I=t.frustum._offCenterFrustum,B=I.right/I.top,X=M*B;J>X?(V=J,E=V/B):(E=M,V=X),Q=Math.max(V,E)}else{let J=Math.tan(t.frustum.fovy*.5),M=t.frustum.aspectRatio*J;if(Q=Math.max(dc(C,Y,U,J),dc(C,Y,T,J),dc(C,Y,F,J),dc(C,Y,g,J),dc(C,Y,G,J),dc(C,Y,A,J),dc(C,y,U,M),dc(C,y,T,M),dc(C,y,F,M),dc(C,y,g,M),dc(C,y,G,M),dc(C,y,A,M)),l<0&&s>0){let V=G_;V.longitude=d,V.latitude=0,V.height=0;let E=o.cartographicToCartesian(V,sat);p.subtract(E,b,E),Q=Math.max(Q,dc(C,Y,E,J),dc(C,y,E,M)),V.longitude=r,E=o.cartographicToCartesian(V,sat),p.subtract(E,b,E),Q=Math.max(Q,dc(C,Y,E,J),dc(C,y,E,M))}}return p.add(b,p.multiplyByScalar(C,-Q,sat),n)}var N1e=new gt,y1e=new p,B1e=new p;function Q1e(t,e,n){let i=t._projection;e.west>e.east&&(e=Gt.MAX_VALUE);let o=t._actualTransform,a=t._actualInvTransform,s=N1e;s.longitude=e.east,s.latitude=e.north;let l=i.project(s,y1e);L.multiplyByPoint(o,l,l),L.multiplyByPoint(a,l,l),s.longitude=e.west,s.latitude=e.south;let r=i.project(s,B1e);if(L.multiplyByPoint(o,r,r),L.multiplyByPoint(a,r,r),n.x=(l.x-r.x)*.5+r.x,n.y=(l.y-r.y)*.5+r.y,c(t.frustum.fovy)){let d=Math.tan(t.frustum.fovy*.5),m=t.frustum.aspectRatio*d;n.z=Math.max((l.x-r.x)/m,(l.y-r.y)/d)*.5}else{let d=l.x-r.x,m=l.y-r.y;n.z=Math.max(d,m)}return n}var k1e=new gt,Y1e=new p,x1e=new p;function X1e(t,e,n){let i=t._projection,o=e.east;e.west>e.east&&(t._scene.mapMode2D===eh.INFINITE_SCROLL?o+=k.TWO_PI:(e=Gt.MAX_VALUE,o=e.east));let a=k1e;a.longitude=o,a.latitude=e.north;let s=i.project(a,Y1e);a.longitude=e.west,a.latitude=e.south;let l=i.project(a,x1e),r=Math.abs(s.x-l.x)*.5,d=Math.abs(s.y-l.y)*.5,m,h,Z=t.frustum.right/t.frustum.top,b=d*Z;return r>b?(m=r,h=m/Z):(h=d,m=b),d=Math.max(2*m,2*h),n.x=(s.x-l.x)*.5+l.x,n.y=(s.y-l.y)*.5+l.y,a=i.unproject(n,a),a.height=d,n=i.project(a,n),n}fn.prototype.getRectangleCameraCoordinates=function(t,e){let n=this._mode;if(c(e)||(e=new p),n===ut.SCENE3D)return $Nt(this,t,e);if(n===ut.COLUMBUS_VIEW)return Q1e(this,t,e);if(n===ut.SCENE2D)return X1e(this,t,e)};var J1e=new di;function L1e(t,e,n,i){n=f(n,mt.WGS84);let o=t.getPickRay(e,J1e),a=no.rayEllipsoid(o,n);if(!a)return;let s=a.start>0?a.start:a.stop;return di.getPoint(o,s,i)}var M1e=new di;function _1e(t,e,n,i){let a=t.getPickRay(e,M1e).origin;a=p.fromElements(a.y,a.z,0,a);let s=n.unproject(a);if(!(s.latitude<-k.PI_OVER_TWO||s.latitude>k.PI_OVER_TWO))return n.ellipsoid.cartographicToCartesian(s,i)}var D1e=new di;function O1e(t,e,n,i){let o=t.getPickRay(e,D1e),a=-o.origin.x/o.direction.x;di.getPoint(o,a,i);let s=n.unproject(new p(i.y,i.z,0));if(!(s.latitude<-k.PI_OVER_TWO||s.latitude>k.PI_OVER_TWO||s.longitude<-Math.PI||s.longitude>Math.PI))return n.ellipsoid.cartographicToCartesian(s,i)}fn.prototype.pickEllipsoid=function(t,e,n){let i=this._scene.canvas;if(!(i.clientWidth===0||i.clientHeight===0)){if(c(n)||(n=new p),e=f(e,mt.WGS84),this._mode===ut.SCENE3D)n=L1e(this,t,e,n);else if(this._mode===ut.SCENE2D)n=_1e(this,t,this._projection,n);else if(this._mode===ut.COLUMBUS_VIEW)n=O1e(this,t,this._projection,n);else return;return n}};var H1e=new p,w1e=new p,P1e=new p;function v1e(t,e,n){let i=t._scene.canvas,o=i.clientWidth,a=i.clientHeight,s=Math.tan(t.frustum.fovy*.5),l=t.frustum.aspectRatio*s,r=t.frustum.near,d=2/o*e.x-1,m=2/a*(a-e.y)-1,h=t.positionWC;p.clone(h,n.origin);let Z=p.multiplyByScalar(t.directionWC,r,H1e);p.add(h,Z,Z);let b=p.multiplyByScalar(t.rightWC,d*r*l,w1e),u=p.multiplyByScalar(t.upWC,m*r*s,P1e),F=p.add(Z,b,n.direction);return p.add(F,u,F),p.subtract(F,h,F),p.normalize(F,F),n}var wz=new p;function K1e(t,e,n){let i=t._scene.canvas,o=i.clientWidth,a=i.clientHeight,s=t.frustum,l=s.offCenterFrustum;c(l)&&(s=l);let r=2/o*e.x-1;r*=(s.right-s.left)*.5;let d=2/a*(a-e.y)-1;d*=(s.top-s.bottom)*.5;let m=n.origin;return p.clone(t.position,m),p.multiplyByScalar(t.right,r,wz),p.add(wz,m,m),p.multiplyByScalar(t.up,d,wz),p.add(wz,m,m),p.clone(t.directionWC,n.direction),(t._mode===ut.COLUMBUS_VIEW||t._mode===ut.SCENE2D)&&p.fromElements(n.origin.z,n.origin.x,n.origin.y,n.origin),n}fn.prototype.getPickRay=function(t,e){c(e)||(e=new di);let n=this._scene.canvas;if(n.clientWidth<=0||n.clientHeight<=0)return;let i=this.frustum;return c(i.aspectRatio)&&c(i.fov)&&c(i.near)?v1e(this,t,e):K1e(this,t,e)};var z1e=new p,j1e=new p;fn.prototype.distanceToBoundingSphere=function(t){let e=p.subtract(this.positionWC,t.center,z1e),n=p.multiplyByScalar(this.directionWC,p.dot(e,this.directionWC),j1e);return Math.max(0,p.magnitude(n)-t.radius)};var q1e=new K;fn.prototype.getPixelSize=function(t,e,n){let i=this.distanceToBoundingSphere(t),o=this.frustum.getPixelDimensions(e,n,i,this._scene.pixelRatio,q1e);return Math.max(o.x,o.y)};function $1e(t,e,n,i,o,a){let s=p.clone(e);n.y>i?s.y-=n.y-i:n.y<-i&&(s.y+=-i-n.y),n.z>o?s.z-=n.z-o:n.z<-o&&(s.z+=-o-n.z);function l(r){let d=p.lerp(e,s,r.time,new p);t.worldToCameraCoordinatesPoint(d,t.position)}return{easingFunction:Zl.EXPONENTIAL_OUT,startObject:{time:0},stopObject:{time:1},duration:a,update:l}}var tNe=new p,xNt=new p,eNe=new p,nNe=new p;function iNe(t,e){let n=t.position,i=t.direction,o=t.worldToCameraCoordinatesVector(p.UNIT_X,tNe),a=-p.dot(o,n)/p.dot(o,i),s=p.add(n,p.multiplyByScalar(i,a,xNt),xNt);t.cameraToWorldCoordinatesPoint(s,s),n=t.cameraToWorldCoordinatesPoint(t.position,eNe);let l=Math.tan(t.frustum.fovy*.5),r=t.frustum.aspectRatio*l,d=p.magnitude(p.subtract(n,s,nNe)),m=r*d,h=l*d,Z=t._maxCoord.x,b=t._maxCoord.y,u=Math.max(m-Z,Z),F=Math.max(h-b,b);if(n.z<-u||n.z>u||n.y<-F||n.y>F){let U=s.y<-u||s.y>u,G=s.z<-F||s.z>F;if(U||G)return $1e(t,n,s,u,F,e)}}fn.prototype.createCorrectPositionTween=function(t){if(this._mode===ut.COLUMBUS_VIEW)return iNe(this,t)};var oNe=new p,Qr={destination:void 0,heading:void 0,pitch:void 0,roll:void 0,duration:void 0,complete:void 0,cancel:void 0,endTransform:void 0,maximumHeight:void 0,easingFunction:void 0};fn.prototype.cancelFlight=function(){c(this._currentFlight)&&(this._currentFlight.cancelTween(),this._currentFlight=void 0)};fn.prototype.completeFlight=function(){if(c(this._currentFlight)){this._currentFlight.cancelTween();let t={destination:void 0,orientation:{heading:void 0,pitch:void 0,roll:void 0}};t.destination=Qr.destination,t.orientation.heading=Qr.heading,t.orientation.pitch=Qr.pitch,t.orientation.roll=Qr.roll,this.setView(t),c(this._currentFlight.complete)&&this._currentFlight.complete(),this._currentFlight=void 0}};fn.prototype.flyTo=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.destination;if(this._mode===ut.MORPHING)return;this.cancelFlight();let i=e instanceof Gt;i&&(e=this.getRectangleCameraCoordinates(e,oNe));let o=f(t.orientation,f.EMPTY_OBJECT);if(c(o.direction)&&(o=PNt(this,e,o,dat.orientation)),c(t.duration)&&t.duration<=0){let m=dat;m.destination=t.destination,m.orientation.heading=o.heading,m.orientation.pitch=o.pitch,m.orientation.roll=o.roll,m.convert=t.convert,m.endTransform=t.endTransform,this.setView(m),typeof t.complete=="function"&&t.complete();return}let a=this,s;Qr.destination=e,Qr.heading=o.heading,Qr.pitch=o.pitch,Qr.roll=o.roll,Qr.duration=t.duration,Qr.complete=function(){s===a._currentFlight&&(a._currentFlight=void 0),c(t.complete)&&t.complete()},Qr.cancel=t.cancel,Qr.endTransform=t.endTransform,Qr.convert=i?!1:t.convert,Qr.maximumHeight=t.maximumHeight,Qr.pitchAdjustHeight=t.pitchAdjustHeight,Qr.flyOverLongitude=t.flyOverLongitude,Qr.flyOverLongitudeWeight=t.flyOverLongitudeWeight,Qr.easingFunction=t.easingFunction;let l=this._scene,r=U_.createTween(l,Qr);if(r.duration===0){typeof r.complete=="function"&&r.complete();return}s=l.tweens.add(r),this._currentFlight=s;let d=this._scene.preloadFlightCamera;this._mode!==ut.SCENE2D&&(c(d)||(d=fn.clone(this)),d.setView({destination:e,orientation:o}),this._scene.preloadFlightCullingVolume=d.frustum.computeCullingVolume(d.positionWC,d.directionWC,d.upWC))};function aNe(t,e){let n=t.frustum,i=Math.tan(n.fovy*.5),o=n.aspectRatio*i;return Math.max(e/o,e/i)}function sNe(t,e){let n=t.frustum,i=n.offCenterFrustum;c(i)&&(n=i);let o,a,s=n.right/n.top,l=e*s;return e>l?(o=e,a=o/s):(a=e,o=l),Math.max(o,a)*1.5}var lNe=100;function tyt(t,e,n){n=Zu.clone(c(n)?n:fn.DEFAULT_OFFSET);let i=t._scene.screenSpaceCameraController.minimumZoomDistance,o=t._scene.screenSpaceCameraController.maximumZoomDistance,a=n.range;if(!c(a)||a===0){let s=e.radius;s===0?n.range=lNe:t.frustum instanceof wn||t._mode===ut.SCENE2D?n.range=sNe(t,s):n.range=aNe(t,s),n.range=k.clamp(n.range,i,o)}return n}fn.prototype.viewBoundingSphere=function(t,e){e=tyt(this,t,e),this.lookAt(t.center,e)};var rNe=new L,dNe=new p,cNe=new p,mNe=new p,hNe=new p,pNe=new Rt,uNe=new wt,ZNe=new ot;fn.prototype.flyToBoundingSphere=function(t,e){e=f(e,f.EMPTY_OBJECT);let n=this._mode===ut.SCENE2D||this._mode===ut.COLUMBUS_VIEW;this._setTransform(L.IDENTITY);let i=tyt(this,t,e.offset),o;n?o=p.multiplyByScalar(p.UNIT_Z,i.range,dNe):o=qNt(i.heading,i.pitch,i.range);let a=Pe.eastNorthUpToFixedFrame(t.center,mt.WGS84,rNe);L.multiplyByPoint(a,o,o);let s,l;if(!n){if(s=p.subtract(t.center,o,cNe),p.normalize(s,s),l=L.multiplyByPointAsVector(a,p.UNIT_Z,mNe),1-Math.abs(p.dot(s,l))<k.EPSILON6){let d=wt.fromAxisAngle(s,i.heading,uNe),m=ot.fromQuaternion(d,ZNe);p.fromCartesian4(L.getColumn(a,1,pNe),l),ot.multiplyByVector(m,l,l)}let r=p.cross(s,l,hNe);p.cross(r,s,l),p.normalize(l,l)}this.flyTo({destination:o,orientation:{direction:s,up:l},duration:e.duration,complete:e.complete,cancel:e.cancel,endTransform:e.endTransform,maximumHeight:e.maximumHeight,easingFunction:e.easingFunction,flyOverLongitude:e.flyOverLongitude,flyOverLongitudeWeight:e.flyOverLongitudeWeight,pitchAdjustHeight:e.pitchAdjustHeight})};var XNt=new p,JNt=new p,lat=new p,LNt=new p,A_=[new p,new p,new p,new p];function VNe(t,e){let n=e.radii,i=t.positionWC,o=p.multiplyComponents(e.oneOverRadii,i,XNt),a=p.magnitude(o),s=p.normalize(o,JNt),l,r;p.equalsEpsilon(s,p.UNIT_Z,k.EPSILON10)?(l=new p(0,1,0),r=new p(0,0,1)):(l=p.normalize(p.cross(p.UNIT_Z,s,lat),lat),r=p.normalize(p.cross(s,l,LNt),LNt));let d=Math.sqrt(p.magnitudeSquared(o)-1),m=p.multiplyByScalar(s,1/a,XNt),h=d/a,Z=p.multiplyByScalar(l,h,JNt),b=p.multiplyByScalar(r,h,lat),u=p.add(m,b,A_[0]);p.subtract(u,Z,u),p.multiplyComponents(n,u,u);let F=p.subtract(m,b,A_[1]);p.subtract(F,Z,F),p.multiplyComponents(n,F,F);let U=p.subtract(m,b,A_[2]);p.add(U,Z,U),p.multiplyComponents(n,U,U);let G=p.add(m,b,A_[3]);return p.add(G,Z,G),p.multiplyComponents(n,G,G),A_}var rat=new K,bNe=new p,uU=[new gt,new gt,new gt,new gt];function Pz(t,e,n,i,o,a){rat.x=t,rat.y=e;let s=i.pickEllipsoid(rat,o,bNe);return c(s)?(uU[n]=o.cartesianToCartographic(s,uU[n]),1):(uU[n]=o.cartesianToCartographic(a[n],uU[n]),0)}fn.prototype.computeViewRectangle=function(t,e){t=f(t,mt.WGS84);let n=this.frustum.computeCullingVolume(this.positionWC,this.directionWC,this.upWC),i=new Ft(p.ZERO,t.maximumRadius);if(n.computeVisibility(i)===yn.OUTSIDE)return;let a=this._scene.canvas,s=a.clientWidth,l=a.clientHeight,r=0,d=VNe(this,t);if(r+=Pz(0,0,0,this,t,d),r+=Pz(0,l,1,this,t,d),r+=Pz(s,l,2,this,t,d),r+=Pz(s,0,3,this,t,d),r<2)return Gt.MAX_VALUE;e=Gt.fromCartographicArray(uU,e);let m=0,h=uU[3].longitude;for(let Z=0;Z<4;++Z){let b=uU[Z].longitude,u=Math.abs(b-h);u>k.PI?m+=k.TWO_PI-u:m+=u,h=b}return k.equalsEpsilon(Math.abs(m),k.TWO_PI,k.EPSILON9)&&(e.west=-k.PI,e.east=k.PI,uU[0].latitude>=0?e.north=k.PI_OVER_TWO:e.south=-k.PI_OVER_TWO),e};fn.prototype.switchToPerspectiveFrustum=function(){if(this._mode===ut.SCENE2D||this.frustum instanceof Io)return;let t=this._scene;this.frustum=new Io,this.frustum.aspectRatio=t.drawingBufferWidth/t.drawingBufferHeight,this.frustum.fov=k.toRadians(60)};fn.prototype.switchToOrthographicFrustum=function(){if(this._mode===ut.SCENE2D||this.frustum instanceof wn)return;let t=HNt(this),e=this._scene;this.frustum=new wn,this.frustum.aspectRatio=e.drawingBufferWidth/e.drawingBufferHeight,this.frustum.width=t};fn.clone=function(t,e){return c(e)||(e=new fn(t._scene)),p.clone(t.position,e.position),p.clone(t.direction,e.direction),p.clone(t.up,e.up),p.clone(t.right,e.right),L.clone(t._transform,e.transform),e._transformChanged=!0,e.frustum=t.frustum.clone(),e};var{getAzElRange:pat}=x1,{PI_OVER_THREE:eyt}=k;fn.prototype.trackFromTo=function(t,e){this.unTrack(),this.fromEntity=t,this.toEntity=e;let n=this.toEntity.position.getValue(this._scene._frameState.time),i=this.fromEntity.position.getValue(this._scene._frameState.time),{range:o}=pat(n,i);this.currentZoomLevel=o,this._setTrackListener=this._scene._preRender.addEventListener(this._setTrack.bind(this));let{toEntity:a,fromEntity:s}=this,{time:l}=this._scene._frameState;this._wheelEventListener=this._scene.canvas.addEventListener("wheel",r=>{r.preventDefault();let d=a.position.getValue(l),m=s.position.getValue(l);if(!d||!m)return;let{range:h}=x1.getAzElRange(d,m),Z=this.currentZoomLevel/h,b=Math.max(1e-5,Math.log(1+2*Z)),u=r.deltaY*this.scrollFactor*b;this.currentZoomLevel=Math.min(Math.max(0,this.currentZoomLevel+u),h),this.currentZoomLevel<h?this.zoomActive=!0:this.zoomActive=!1,this._scene.render()})};fn.prototype.eyeDistToTarget=null;fn.prototype.fromEntity=null;fn.prototype.toEntity=null;fn.prototype.cmax=eyt;fn.prototype.scrollFactor=1e3;fn.prototype.currentZoomLevel=-1;fn.prototype.CATS=0;fn.prototype.zoomActive=!1;fn.prototype.trackDebug=!1;fn.prototype.cmin=function(t){return 2*Math.atan(1/t)};fn.prototype._resetTrack=function(){this?.frustum?.fov&&(this.frustum.fov=eyt),this._setTrackListener&&this._setTrackListener(),this._wheelEventListener&&this._wheelEventListener()};fn.prototype.unTrack=function(t=!0){this._wheelEventListener&&(this._scene.canvas.removeEventListener("wheel",this._wheelEventListener),this._wheelEventListener=null),this._setTrackListener&&this._scene._preRender.removeEventListener(this._setTrackListener),t&&this.flyHome(0),this.fromEntity=null,this.toEntity=null,this._resetTrack()};fn.prototype._setZoom=function(){let t=this.toEntity.position.getValue(this._scene._frameState.time),e=this.fromEntity.position.getValue(this._scene._frameState.time),{range:n}=pat(t,e),i=Math.min(this.currentZoomLevel,n),o=this.cmin(n);return(this.cmax-o)*(i/n)+o};fn.prototype._setTrack=function(){try{let t=this.toEntity.position.getValue(this._scene._frameState.time),e=this.fromEntity.position.getValue(this._scene._frameState.time),n=new p;p.subtract(t,e,n),p.normalize(n,n),p.multiplyByScalar(n,-1e-32,n);let i=new L,o=new L;this.fromEntity.computeModelMatrix(this._scene._frameState.time,i,!1,ri.ENU),L.inverse(i,o),L.multiplyByPointAsVector(o,n,n),this.lookAtTransform(i,n);let{az:a,el:s,range:l}=pat(t,e);this.frustum.fov=this.zoomActive?this._setZoom():this.cmax;let r=(this.frustum.fov-this.cmin(l))/(this.cmax-this.cmin(l));this.eyeDistToTarget=(1-r)*.1+r*l;let d=_V.computeSunPositionInEarthInertialFrame(this._scene._frameState.time),m=p.subtract(d,t,new p),h=p.normalize(m,new p),Z=p.normalize(p.subtract(t,e,new p),new p);this.CATS=p.dot(h,Z);let b=document.getElementById("debugPanel");this.trackDebug?(b||(b=document.createElement("div"),b.id="debugPanel",b.style.cssText=` +`;function W_(){this._colorTexture=void 0,this._drawCommand=void 0}Object.defineProperties(W_.prototype,{colorTexture:{get:function(){return this._colorTexture}}});function GIe(t,e,n){let i=e.createViewportQuadCommand(b_,{framebuffer:n,renderState:he.fromCache({viewport:new Fe(0,0,256,256)})});t._drawCommand=i}W_.prototype.update=function(t){if(!c(this._colorTexture)){let e=t.context,n=new hn({context:e,width:256,height:256,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,sampler:Hn.NEAREST});this._colorTexture=n;let i=new Lr({context:e,colorTextures:[n],destroyAttachments:!1});GIe(this,e,i),this._drawCommand.execute(e),i.destroy(),this._drawCommand.shaderProgram=this._drawCommand.shaderProgram&&this._drawCommand.shaderProgram.destroy()}};W_.prototype.isDestroyed=function(){return!1};W_.prototype.destroy=function(){return this._colorTexture=this._colorTexture&&this._colorTexture.destroy(),At(this)};var f_=W_;var WTo=b(W(),1);var gSo=b(W(),1);var INt={};function AIe(t,e,n){let i,o,a;if(t instanceof Io){let s=Math.tan(.5*t.fovy);return i=t.near,o=t.near*s,a=t.aspectRatio*o,Math.max(e*i/a,n*i/o)}else if(t instanceof em)return i=t.near,o=t.top,a=t.right,Math.max(e*i/a,n*i/o);return Math.max(e,n)}var SIe=new p,gNt=new p;function NNt(t,e,n,i){if(c(i)&&n(.5)>i){let o=n(0),a=n(1),s=n(.5),l=s-o,r=s-a;return function(d){let m=n(d);if(d<=.5){let u=(m-o)/l;return k.lerp(t,-k.PI_OVER_TWO,u)}let h=(m-a)/r;return k.lerp(-k.PI_OVER_TWO,e,1-h)}}return function(o){return k.lerp(t,e,o)}}function nat(t,e,n,i,o){let a=o,s=Math.max(n,i);if(!c(a)){let l=t.position,r=e,d=t.up,m=t.right,h=t.frustum,u=p.subtract(l,r,SIe),R=p.magnitude(p.multiplyByScalar(d,p.dot(u,d),gNt)),V=p.magnitude(p.multiplyByScalar(m,p.dot(u,m),gNt));a=Math.min(AIe(h,R,V)*.2,1e9)}if(s<a){let d=-Math.pow((a-n)*1e6,.125),m=Math.pow((a-i)*1e6,1/8);return function(h){let u=h*(m-d)+d;return-Math.pow(u,8)/1e6+a}}return function(l){return k.lerp(n,i,l)}}function F_(t,e){return k.equalsEpsilon(t,k.TWO_PI,k.EPSILON11)&&(t=0),e>t+Math.PI?t+=k.TWO_PI:e<t-Math.PI&&(t-=k.TWO_PI),t}var yNt=new p;function TIe(t,e,n,i,o,a,s,l){let r=t.camera,d=p.clone(r.position,yNt),m=r.pitch,h=F_(r.heading,i),u=F_(r.roll,a),R=nat(r,n,d.z,n.z,s),V=NNt(m,o,R,l);function F(U){let G=U.time/e;r.setView({orientation:{heading:k.lerp(h,i,G),pitch:V(G),roll:k.lerp(u,a,G)}}),K.lerp(d,n,G,r.position),r.position.z=R(G)}return F}function gIe(t,e){t.longitude<e.longitude?t.longitude+=k.TWO_PI:e.longitude+=k.TWO_PI}function EIe(t,e){let n=t.longitude-e.longitude;n<-k.PI?t.longitude+=k.TWO_PI:n>k.PI&&(e.longitude+=k.TWO_PI)}var CIe=new gt,IIe=new gt;function NIe(t,e,n,i,o,a,s,l,r,d){let m=t.camera,u=t.mapProjection.ellipsoid,R=gt.clone(m.positionCartographic,CIe),V=m.pitch,F=F_(m.heading,i),U=F_(m.roll,a),G=u.cartesianToCartographic(n,IIe);R.longitude=k.zeroToTwoPi(R.longitude),G.longitude=k.zeroToTwoPi(G.longitude);let A=!1;if(c(l)){let y=k.zeroToTwoPi(l),Y=Math.min(R.longitude,G.longitude),Q=Math.max(R.longitude,G.longitude),J=y>=Y&&y<=Q;if(c(r)){let M=Math.abs(R.longitude-G.longitude),Z=k.TWO_PI-M;(J?M:Z)<(J?Z:M)*r&&!J&&(A=!0)}else J||(A=!0)}A?gIe(R,G):EIe(R,G);let S=nat(m,n,R.height,G.height,s),g=NNt(V,o,S,d);function C(){let y=R.longitude,Y=G.longitude,Q=R.latitude,J=G.latitude;return function(Z){let E=Z.time/e,I=p.fromRadians(k.lerp(y,Y,E),k.lerp(Q,J,E),S(E),u);m.setView({destination:I,orientation:{heading:k.lerp(F,i,E),pitch:g(E),roll:k.lerp(U,a,E)}})}}return C()}function yIe(t,e,n,i,o,a,s){let l=t.camera,r=p.clone(l.position,yNt),d=F_(l.heading,i),m=l.frustum.right-l.frustum.left,h=nat(l,n,m,n.z,s);function u(R){let V=R.time/e;l.setView({orientation:{heading:k.lerp(d,i,V)}}),K.lerp(r,n,V,l.position);let F=h(V),U=l.frustum,G=U.top/U.right,A=(F-(U.right-U.left))*.5;U.right+=A,U.left-=A,U.top=G*U.right,U.bottom=-U.top}return u}var ENt=new gt,BIe=new p;function eat(t,e){return{startObject:{},stopObject:{},duration:0,complete:t,cancel:e}}function CNt(t,e){function n(){typeof e=="function"&&e(),t.enableInputs=!0}return n}INt.createTween=function(t,e){e=f(e,f.EMPTY_OBJECT);let n=e.destination,i=t.mode;if(i===Vt.MORPHING)return eat();let o=f(e.convert,!0),a=t.mapProjection,s=a.ellipsoid,l=e.maximumHeight,r=e.flyOverLongitude,d=e.flyOverLongitudeWeight,m=e.pitchAdjustHeight,h=e.easingFunction;o&&i!==Vt.SCENE3D&&(s.cartesianToCartographic(n,ENt),n=a.project(ENt,BIe));let u=t.camera,R=e.endTransform;c(R)&&u._setTransform(R);let V=e.duration;c(V)||(V=Math.ceil(p.distance(u.position,n)/1e6)+2,V=Math.min(V,3));let F=f(e.heading,0),U=f(e.pitch,-k.PI_OVER_TWO),G=f(e.roll,0),A=t.screenSpaceCameraController;A.enableInputs=!1;let S=CNt(A,e.complete),g=CNt(A,e.cancel),C=u.frustum,y=t.mode===Vt.SCENE2D;if(y=y&&K.equalsEpsilon(u.position,n,k.EPSILON6),y=y&&k.equalsEpsilon(Math.max(C.right-C.left,C.top-C.bottom),n.z,k.EPSILON6),y=y||t.mode!==Vt.SCENE2D&&p.equalsEpsilon(n,u.position,k.EPSILON10),y=y&&k.equalsEpsilon(k.negativePiToPi(F),k.negativePiToPi(u.heading),k.EPSILON10)&&k.equalsEpsilon(k.negativePiToPi(U),k.negativePiToPi(u.pitch),k.EPSILON10)&&k.equalsEpsilon(k.negativePiToPi(G),k.negativePiToPi(u.roll),k.EPSILON10),y)return eat(S,g);let Y=new Array(4);if(Y[Vt.SCENE2D]=yIe,Y[Vt.SCENE3D]=NIe,Y[Vt.COLUMBUS_VIEW]=TIe,V<=0)return eat(function(){Y[i](t,1,n,F,U,G,l,r,d,m)({time:1}),typeof S=="function"&&S()},g);let Q=Y[i](t,V,n,F,U,G,l,r,d,m);if(!c(h)){let J=u.positionCartographic.height,M=i===Vt.SCENE3D?s.cartesianToCartographic(n).height:n.z;J>M&&J>11500?h=ul.CUBIC_OUT:h=ul.QUINTIC_IN_OUT}return{duration:V,easingFunction:h,startObject:{time:0},stopObject:{time:V},update:Q,complete:S,cancel:g}};var U_=INt;var CSo=b(W(),1),QIe={ROTATE:0,INFINITE_SCROLL:1},eh=Object.freeze(QIe);var LSo=b(W(),1);var iat={},Oz=t=>t.position.constructor.name==="ConstantPositionProperty"?t:!1,BNt=function(t,e,n,i=mt.WGS84){let o=iat[t.id]||iat[e.id]||null;if(o===null){let l=Oz(t)||Oz(e),r=!Oz(t)&&!Oz(e),d=l||t;o=new Bu(i,d.position.getValue(n)),o.eid=d.id,r||(iat[l.id]=o)}let a=o.eid===t.id?e:t;return o.isPointVisible(a.position.getValue(n))},kIe=function(t,e){let n=0,i=0,o=0;try{let{fromCartesian:a}=gt,{subtract:s,normalize:l,dot:r,distance:d}=p,m=new ou;m.setEndPoints(a(t),a(e));let h=m.startHeading<0?m.startHeading+k.TWO_PI:m.startHeading;n=k.toDegrees(h);let u=new p(0,0,0),R=s(t,e,u);R=l(R,u);let V=new p,F=p.normalize(t,V),U=r(R,F);i=k.toDegrees(Math.acos(U))-90,o=d(t,e)}catch(a){console.log(a)}return{az:n,el:i,range:o}},oat=class{constructor(e,n,i){this.id=e,this.from=n,this.to=i,this.polylineCollectionArrays=[]}},ip={},YIe=(t,e,n,i=Date.now().toString())=>{if(ip[i])return i;ip[i]=new oat(i,e,n);for(let o=0;o<n.length;o++){let a=new Mc;for(let s=0;s<e.length;s++)a.add({positions:[n[o].position.getValue(t.clock.currentTime),e[s].position.getValue(t.clock.currentTime)],width:1,material:new eo({fabric:{type:"Color",uniforms:{color:v.LIMEGREEN}}}),show:!0});t.scene.primitives.add(a),ip[i].polylineCollectionArrays.push(a)}return ip[i].removeListener=t.clock.onTick.addEventListener(o=>{for(let a in ip)if(ip[a]){let{polylineCollectionArrays:s,from:l,to:r}=ip[a];for(let d=0;d<r.length;d++)for(let m=0;m<l.length;m++){let h=BNt(l[m],r[d],o.currentTime),u=s[d].get(m);h?(u.show=!0,u.positions=[r[d].position.getValue(o.currentTime),l[m].position.getValue(o.currentTime)]):u.show=!1}}}),t.scene.render(),i},xIe=(t,e)=>{if(e){let n=ip[e];if(!n)return;n.removeListener(),n.polylineCollectionArrays.forEach(i=>{t.scene.primitives.remove(i)}),delete ip[e]}else for(let n in ip)if(ip[n]){let i=ip[n];i.removeListener(),i.polylineCollectionArrays.forEach(o=>{t.scene.primitives.remove(o)}),delete ip[n]}t.scene.render()},XIe=()=>{throw Error("Not Implemented")},x1={calculateAccess:BNt,getAzElRange:kIe,addAccessLines:YIe,removeAccessLines:xIe,calculateSensorAccess:XIe};function fn(t){this._scene=t,this._transform=L.clone(L.IDENTITY),this._invTransform=L.clone(L.IDENTITY),this._actualTransform=L.clone(L.IDENTITY),this._actualInvTransform=L.clone(L.IDENTITY),this._transformChanged=!1,this.position=new p,this._position=new p,this._positionWC=new p,this._positionCartographic=new gt,this._oldPositionWC=void 0,this.positionWCDeltaMagnitude=0,this.positionWCDeltaMagnitudeLastFrame=0,this.timeSinceMoved=0,this._lastMovedTimestamp=0,this.direction=new p,this._direction=new p,this._directionWC=new p,this.up=new p,this._up=new p,this._upWC=new p,this.right=new p,this._right=new p,this._rightWC=new p,this.frustum=new Io,this.frustum.aspectRatio=t.drawingBufferWidth/t.drawingBufferHeight,this.frustum.fov=k.toRadians(60),this.defaultMoveAmount=1e5,this.defaultLookAmount=Math.PI/60,this.defaultRotateAmount=Math.PI/3600,this.defaultZoomAmount=1e5,this.constrainedAxis=void 0,this.maximumZoomFactor=1.5,this._moveStart=new It,this._moveEnd=new It,this._changed=new It,this._changedPosition=void 0,this._changedDirection=void 0,this._changedFrustum=void 0,this._changedHeading=void 0,this._changedRoll=void 0,this.percentageChanged=.5,this._viewMatrix=new L,this._invViewMatrix=new L,MNt(this),this._mode=Vt.SCENE3D,this._modeChanged=!0;let e=t.mapProjection;this._projection=e,this._maxCoord=e.project(new gt(Math.PI,k.PI_OVER_TWO)),this._max2Dfrustum=void 0,$Nt(this,fn.DEFAULT_VIEW_RECTANGLE,this.position,!0);let n=p.magnitude(this.position);n+=n*fn.DEFAULT_VIEW_FACTOR,p.normalize(this.position,this.position),p.multiplyByScalar(this.position,n,this.position)}fn.TRANSFORM_2D=new L(0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1);fn.TRANSFORM_2D_INVERSE=L.inverseTransformation(fn.TRANSFORM_2D,new L);fn.DEFAULT_VIEW_RECTANGLE=Gt.fromDegrees(-95,-20,-70,90);fn.DEFAULT_VIEW_FACTOR=.5;fn.DEFAULT_OFFSET=new uV(0,-k.PI_OVER_FOUR,0);function MNt(t){L.computeView(t._position,t._direction,t._up,t._right,t._viewMatrix),L.multiply(t._viewMatrix,t._actualInvTransform,t._viewMatrix),L.inverseTransformation(t._viewMatrix,t._invViewMatrix)}function JIe(t){if(!c(t._oldPositionWC))t._oldPositionWC=p.clone(t.positionWC,t._oldPositionWC);else{t.positionWCDeltaMagnitudeLastFrame=t.positionWCDeltaMagnitude;let e=p.subtract(t.positionWC,t._oldPositionWC,t._oldPositionWC);t.positionWCDeltaMagnitude=p.magnitude(e),t._oldPositionWC=p.clone(t.positionWC,t._oldPositionWC),t.positionWCDeltaMagnitude>0?(t.timeSinceMoved=0,t._lastMovedTimestamp=Oi()):t.timeSinceMoved=Math.max(Oi()-t._lastMovedTimestamp,0)/1e3}}fn.prototype.canPreloadFlight=function(){return c(this._currentFlight)&&this._mode!==Vt.SCENE2D};fn.prototype._updateCameraChanged=function(){let t=this;if(JIe(t),t._changed.numberOfListeners===0)return;let e=t.percentageChanged,n=t.heading;c(t._changedHeading)||(t._changedHeading=n);let i=Math.abs(t._changedHeading-n)%k.TWO_PI;i=i>k.PI?k.TWO_PI-i:i;let o=i/Math.PI;o>e&&(t._changedHeading=n);let a=t.roll;c(t._changedRoll)||(t._changedRoll=a);let s=Math.abs(t._changedRoll-a)%k.TWO_PI;s=s>k.PI?k.TWO_PI-s:s;let l=s/Math.PI;if(l>e&&(t._changedRoll=a),(l>e||o>e)&&t._changed.raiseEvent(Math.max(l,o)),t._mode===Vt.SCENE2D){if(!c(t._changedFrustum)){t._changedPosition=p.clone(t.position,t._changedPosition),t._changedFrustum=t.frustum.clone();return}let u=t.position,R=t._changedPosition,V=t.frustum,F=t._changedFrustum,U=u.x+V.left,G=u.x+V.right,A=R.x+F.left,S=R.x+F.right,g=u.y+V.bottom,C=u.y+V.top,y=R.y+F.bottom,Y=R.y+F.top,Q=Math.max(U,A),J=Math.min(G,S),M=Math.max(g,y),Z=Math.min(C,Y),E;if(Q>=J||M>=C)E=1;else{let I=F;U<A&&G>S&&g<y&&C>Y&&(I=V),E=1-(J-Q)*(Z-M)/((I.right-I.left)*(I.top-I.bottom))}E>e&&(t._changed.raiseEvent(E),t._changedPosition=p.clone(t.position,t._changedPosition),t._changedFrustum=t.frustum.clone(t._changedFrustum));return}if(!c(t._changedDirection)){t._changedPosition=p.clone(t.positionWC,t._changedPosition),t._changedDirection=p.clone(t.directionWC,t._changedDirection);return}let r=k.acosClamped(p.dot(t.directionWC,t._changedDirection)),d;c(t.frustum.fovy)?d=r/(t.frustum.fovy*.5):d=r;let h=p.distance(t.positionWC,t._changedPosition)/t.positionCartographic.height;(d>e||h>e)&&(t._changed.raiseEvent(Math.max(d,h)),t._changedPosition=p.clone(t.positionWC,t._changedPosition),t._changedDirection=p.clone(t.directionWC,t._changedDirection))};function LIe(t){Pe.basisTo2D(t._projection,t._transform,t._actualTransform)}var MIe=new gt,_Ie=new p,Hz=new p,DIe=new bt,OIe=new bt,HIe=new bt,wIe=new bt,PIe=new bt;function vIe(t){let e=t._projection,n=e.ellipsoid,i=L.getColumn(t._transform,3,DIe),o=n.cartesianToCartographic(i,MIe),a=e.project(o,_Ie),s=OIe;s.x=a.z,s.y=a.x,s.z=a.y,s.w=1;let l=bt.clone(bt.UNIT_X,PIe),r=bt.add(L.getColumn(t._transform,0,Hz),i,Hz);n.cartesianToCartographic(r,o),e.project(o,a);let d=HIe;d.x=a.z,d.y=a.x,d.z=a.y,d.w=0,p.subtract(d,s,d),d.x=0;let m=wIe;if(p.magnitudeSquared(d)>k.EPSILON10)p.cross(l,d,m);else{let h=bt.add(L.getColumn(t._transform,1,Hz),i,Hz);n.cartesianToCartographic(h,o),e.project(o,a),m.x=a.z,m.y=a.x,m.z=a.y,m.w=0,p.subtract(m,s,m),m.x=0,p.magnitudeSquared(m)<k.EPSILON10&&(bt.clone(bt.UNIT_Y,d),bt.clone(bt.UNIT_Z,m))}p.cross(m,l,d),p.normalize(d,d),p.cross(l,d,m),p.normalize(m,m),L.setColumn(t._actualTransform,0,d,t._actualTransform),L.setColumn(t._actualTransform,1,m,t._actualTransform),L.setColumn(t._actualTransform,2,l,t._actualTransform),L.setColumn(t._actualTransform,3,s,t._actualTransform)}var aat=new p;function cc(t){let e=t._mode,n=!1,i=0;e===Vt.SCENE2D&&(i=t.frustum.right-t.frustum.left,n=i!==t._positionCartographic.height);let o=t._position,a=!p.equals(o,t.position)||n;a&&(o=p.clone(t.position,t._position));let s=t._direction;(isNaN(t.direction.x)||isNaN(t.direction.y)||isNaN(t.direction.z))&&(s=p.clone(t._direction,t.direction));let l=!p.equals(s,t.direction);l&&(p.normalize(t.direction,t.direction),s=p.clone(t.direction,t._direction));let r=t._up,d=!p.equals(r,t.up);d&&(p.normalize(t.up,t.up),r=p.clone(t.up,t._up));let m=t._right,h=!p.equals(m,t.right);h&&(p.normalize(t.right,t.right),m=p.clone(t.right,t._right));let u=t._transformChanged||t._modeChanged;t._transformChanged=!1,u&&(L.inverseTransformation(t._transform,t._invTransform),t._mode===Vt.COLUMBUS_VIEW||t._mode===Vt.SCENE2D?L.equals(L.IDENTITY,t._transform)?L.clone(fn.TRANSFORM_2D,t._actualTransform):t._mode===Vt.COLUMBUS_VIEW?LIe(t):vIe(t):L.clone(t._transform,t._actualTransform),L.inverseTransformation(t._actualTransform,t._actualInvTransform),t._modeChanged=!1);let R=t._actualTransform;if(a||u)if(t._positionWC=L.multiplyByPoint(R,o,t._positionWC),e===Vt.SCENE3D||e===Vt.MORPHING)t._positionCartographic=t._projection.ellipsoid.cartesianToCartographic(t._positionWC,t._positionCartographic);else{let V=aat;V.x=t._positionWC.y,V.y=t._positionWC.z,V.z=t._positionWC.x,e===Vt.SCENE2D&&(V.z=i),t._projection.unproject(V,t._positionCartographic)}if(l||d||h){let V=p.dot(s,p.cross(r,m,aat));if(Math.abs(1-V)>k.EPSILON2){let F=1/p.magnitudeSquared(r),U=p.dot(r,s)*F,G=p.multiplyByScalar(s,U,aat);r=p.normalize(p.subtract(r,G,t._up),t._up),p.clone(r,t.up),m=p.cross(s,r,t._right),p.clone(m,t.right)}}(l||u)&&(t._directionWC=L.multiplyByPointAsVector(R,s,t._directionWC),p.normalize(t._directionWC,t._directionWC)),(d||u)&&(t._upWC=L.multiplyByPointAsVector(R,r,t._upWC),p.normalize(t._upWC,t._upWC)),(h||u)&&(t._rightWC=L.multiplyByPointAsVector(R,m,t._rightWC),p.normalize(t._rightWC,t._rightWC)),(a||l||d||h||u)&&MNt(t)}function _Nt(t,e){let n;return k.equalsEpsilon(Math.abs(t.z),1,k.EPSILON3)?n=Math.atan2(e.y,e.x)-k.PI_OVER_TWO:n=Math.atan2(t.y,t.x)-k.PI_OVER_TWO,k.TWO_PI-k.zeroToTwoPi(n)}function DNt(t){return k.PI_OVER_TWO-k.acosClamped(t.z)}function ONt(t,e,n){let i=0;return k.equalsEpsilon(Math.abs(t.z),1,k.EPSILON3)||(i=Math.atan2(-n.z,e.z),i=k.zeroToTwoPi(i+k.TWO_PI)),i}var vz=new L,Kz=new L;Object.defineProperties(fn.prototype,{transform:{get:function(){return this._transform}},inverseTransform:{get:function(){return cc(this),this._invTransform}},viewMatrix:{get:function(){return cc(this),this._viewMatrix}},inverseViewMatrix:{get:function(){return cc(this),this._invViewMatrix}},positionCartographic:{get:function(){return cc(this),this._positionCartographic}},positionWC:{get:function(){return cc(this),this._positionWC}},directionWC:{get:function(){return cc(this),this._directionWC}},upWC:{get:function(){return cc(this),this._upWC}},rightWC:{get:function(){return cc(this),this._rightWC}},heading:{get:function(){if(this._mode!==Vt.MORPHING){let t=this._projection.ellipsoid,e=L.clone(this._transform,vz),n=Pe.eastNorthUpToFixedFrame(this.positionWC,t,Kz);this._setTransform(n);let i=_Nt(this.direction,this.up);return this._setTransform(e),i}}},pitch:{get:function(){if(this._mode!==Vt.MORPHING){let t=this._projection.ellipsoid,e=L.clone(this._transform,vz),n=Pe.eastNorthUpToFixedFrame(this.positionWC,t,Kz);this._setTransform(n);let i=DNt(this.direction);return this._setTransform(e),i}}},roll:{get:function(){if(this._mode!==Vt.MORPHING){let t=this._projection.ellipsoid,e=L.clone(this._transform,vz),n=Pe.eastNorthUpToFixedFrame(this.positionWC,t,Kz);this._setTransform(n);let i=ONt(this.direction,this.up,this.right);return this._setTransform(e),i}}},moveStart:{get:function(){return this._moveStart}},moveEnd:{get:function(){return this._moveEnd}},changed:{get:function(){return this._changed}}});fn.prototype.update=function(t){let e=!1;if(t!==this._mode&&(this._mode=t,this._modeChanged=t!==Vt.MORPHING,e=this._mode===Vt.SCENE2D),e){let n=this._max2Dfrustum=this.frustum.clone(),i=2,o=n.top/n.right;n.right=this._maxCoord.x*i,n.left=-n.right,n.top=o*n.right,n.bottom=-n.top}this._mode===Vt.SCENE2D&&vNt(this,this.position)};var KIe=new p,zIe=new p,jIe=new p;fn.prototype._setTransform=function(t){let e=p.clone(this.positionWC,KIe),n=p.clone(this.upWC,zIe),i=p.clone(this.directionWC,jIe);L.clone(t,this._transform),this._transformChanged=!0,cc(this);let o=this._actualInvTransform;L.multiplyByPoint(o,e,this.position),L.multiplyByPointAsVector(o,i,this.direction),L.multiplyByPointAsVector(o,n,this.up),p.cross(this.direction,this.up,this.right),cc(this)};var qIe=new K,$Ie=new di,t1e=new p,e1e=new p;function HNt(t){if(!L.equals(L.IDENTITY,t.transform))return p.magnitude(t.position);let e=t._scene,n=e.globe,i=qIe;i.x=e.drawingBufferWidth/2,i.y=e.drawingBufferHeight/2;let o;if(c(n)){let l=t.getPickRay(i,$Ie);o=n.pickWorldCoordinates(l,e,!0,t1e)}let a;e.pickPositionSupported&&(a=e.pickPositionWorldCoordinates(i,e1e));let s;if(c(o)||c(a)){let l=c(a)?p.distance(a,t.positionWC):Number.POSITIVE_INFINITY,r=c(o)?p.distance(o,t.positionWC):Number.POSITIVE_INFINITY;s=Math.min(l,r)}else s=Math.max(t.positionCartographic.height,0);return s}fn.prototype._adjustOrthographicFrustum=function(t){this.frustum instanceof wn&&(!t&&this._positionCartographic.height<15e4||(this.frustum.width=HNt(this)))};var zz=new p,cat=new L,n1e=new L,mat=new wt,hat=new ot,wNt=new gt;function i1e(t,e,n){let i=L.clone(t.transform,cat),o=Pe.eastNorthUpToFixedFrame(e,t._projection.ellipsoid,n1e);t._setTransform(o),p.clone(p.ZERO,t.position),n.heading=n.heading-k.PI_OVER_TWO;let a=wt.fromHeadingPitchRoll(n,mat),s=ot.fromQuaternion(a,hat);ot.getColumn(s,0,t.direction),ot.getColumn(s,2,t.up),p.cross(t.direction,t.up,t.right),t._setTransform(i),t._adjustOrthographicFrustum(!0)}function o1e(t,e,n,i){let o=L.clone(t.transform,cat);if(t._setTransform(L.IDENTITY),!p.equals(e,t.positionWC)){if(i){let l=t._projection,r=l.ellipsoid.cartesianToCartographic(e,wNt);e=l.project(r,zz)}p.clone(e,t.position)}n.heading=n.heading-k.PI_OVER_TWO;let a=wt.fromHeadingPitchRoll(n,mat),s=ot.fromQuaternion(a,hat);ot.getColumn(s,0,t.direction),ot.getColumn(s,2,t.up),p.cross(t.direction,t.up,t.right),t._setTransform(o),t._adjustOrthographicFrustum(!0)}function a1e(t,e,n,i){let o=L.clone(t.transform,cat);if(t._setTransform(L.IDENTITY),!p.equals(e,t.positionWC)){if(i){let r=t._projection,d=r.ellipsoid.cartesianToCartographic(e,wNt);e=r.project(d,zz)}K.clone(e,t.position);let a=-e.z*.5,s=-a,l=t.frustum;if(s>a){let r=l.top/l.right;l.right=s,l.left=a,l.top=l.right*r,l.bottom=-l.top}}if(t._scene.mapMode2D===eh.ROTATE){n.heading=n.heading-k.PI_OVER_TWO,n.pitch=-k.PI_OVER_TWO,n.roll=0;let a=wt.fromHeadingPitchRoll(n,mat),s=ot.fromQuaternion(a,hat);ot.getColumn(s,2,t.up),p.cross(t.direction,t.up,t.right)}t._setTransform(o)}var s1e=new p,l1e=new p,r1e=new p;function PNt(t,e,n,i){let o=p.clone(n.direction,s1e),a=p.clone(n.up,l1e);if(t._scene.mode===Vt.SCENE3D){let l=t._projection.ellipsoid,r=Pe.eastNorthUpToFixedFrame(e,l,vz),d=L.inverseTransformation(r,Kz);L.multiplyByPointAsVector(d,o,o),L.multiplyByPointAsVector(d,a,a)}let s=p.cross(o,a,r1e);return i.heading=_Nt(o,a),i.pitch=DNt(o),i.roll=ONt(o,a,s),i}var dat={destination:void 0,orientation:{direction:void 0,up:void 0,heading:void 0,pitch:void 0,roll:void 0},convert:void 0,endTransform:void 0},X1=new Jr;fn.prototype.setView=function(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.orientation,f.EMPTY_OBJECT),n=this._mode;if(n===Vt.MORPHING)return;c(t.endTransform)&&this._setTransform(t.endTransform);let i=f(t.convert,!0),o=f(t.destination,p.clone(this.positionWC,zz));c(o)&&c(o.west)&&(o=this.getRectangleCameraCoordinates(o,zz),i=!1),c(e.direction)&&(e=PNt(this,o,e,dat.orientation)),X1.heading=f(e.heading,0),X1.pitch=f(e.pitch,-k.PI_OVER_TWO),X1.roll=f(e.roll,0),n===Vt.SCENE3D?i1e(this,o,X1):n===Vt.SCENE2D?a1e(this,o,X1,i):o1e(this,o,X1,i)};var d1e=new p;fn.prototype.flyHome=function(t){fn.prototype._resetTrack();let e=this._mode;if(e===Vt.MORPHING&&this._scene.completeMorph(),e===Vt.SCENE2D)this.flyTo({destination:fn.DEFAULT_VIEW_RECTANGLE,duration:t,endTransform:L.IDENTITY});else if(e===Vt.SCENE3D){let n=this.getRectangleCameraCoordinates(fn.DEFAULT_VIEW_RECTANGLE),i=p.magnitude(n);i+=i*fn.DEFAULT_VIEW_FACTOR,p.normalize(n,n),p.multiplyByScalar(n,i,n),this.flyTo({destination:n,duration:t,endTransform:L.IDENTITY})}else if(e===Vt.COLUMBUS_VIEW){let n=this._projection.ellipsoid.maximumRadius,i=new p(0,-1,1);i=p.multiplyByScalar(p.normalize(i,i),5*n,i),this.flyTo({destination:i,duration:t,orientation:{heading:0,pitch:-Math.acos(p.normalize(i,d1e).z),roll:0},endTransform:L.IDENTITY,convert:!1})}};fn.prototype.worldToCameraCoordinates=function(t,e){return c(e)||(e=new bt),cc(this),L.multiplyByVector(this._actualInvTransform,t,e)};fn.prototype.worldToCameraCoordinatesPoint=function(t,e){return c(e)||(e=new p),cc(this),L.multiplyByPoint(this._actualInvTransform,t,e)};fn.prototype.worldToCameraCoordinatesVector=function(t,e){return c(e)||(e=new p),cc(this),L.multiplyByPointAsVector(this._actualInvTransform,t,e)};fn.prototype.cameraToWorldCoordinates=function(t,e){return c(e)||(e=new bt),cc(this),L.multiplyByVector(this._actualTransform,t,e)};fn.prototype.cameraToWorldCoordinatesPoint=function(t,e){return c(e)||(e=new p),cc(this),L.multiplyByPoint(this._actualTransform,t,e)};fn.prototype.cameraToWorldCoordinatesVector=function(t,e){return c(e)||(e=new p),cc(this),L.multiplyByPointAsVector(this._actualTransform,t,e)};function vNt(t,e){let n=t._scene.mapMode2D===eh.ROTATE,i=t._maxCoord.x,o=t._maxCoord.y,a,s;n?(s=i,a=-s):(s=e.x-i*2,a=e.x+i*2),e.x>i&&(e.x=s),e.x<-i&&(e.x=a),e.y>o&&(e.y=o),e.y<-o&&(e.y=-o)}var QNt=new p;fn.prototype.move=function(t,e){let n=this.position;p.multiplyByScalar(t,e,QNt),p.add(n,QNt,n),this._mode===Vt.SCENE2D&&vNt(this,n),this._adjustOrthographicFrustum(!0)};fn.prototype.moveForward=function(t){t=f(t,this.defaultMoveAmount),this._mode===Vt.SCENE2D?jz(this,t):this.move(this.direction,t)};fn.prototype.moveBackward=function(t){t=f(t,this.defaultMoveAmount),this._mode===Vt.SCENE2D?jz(this,-t):this.move(this.direction,-t)};fn.prototype.moveUp=function(t){t=f(t,this.defaultMoveAmount),this.move(this.up,t)};fn.prototype.moveDown=function(t){t=f(t,this.defaultMoveAmount),this.move(this.up,-t)};fn.prototype.moveRight=function(t){t=f(t,this.defaultMoveAmount),this.move(this.right,t)};fn.prototype.moveLeft=function(t){t=f(t,this.defaultMoveAmount),this.move(this.right,-t)};fn.prototype.lookLeft=function(t){t=f(t,this.defaultLookAmount),this._mode!==Vt.SCENE2D&&this.look(this.up,-t)};fn.prototype.lookRight=function(t){t=f(t,this.defaultLookAmount),this._mode!==Vt.SCENE2D&&this.look(this.up,t)};fn.prototype.lookUp=function(t){t=f(t,this.defaultLookAmount),this._mode!==Vt.SCENE2D&&this.look(this.right,-t)};fn.prototype.lookDown=function(t){t=f(t,this.defaultLookAmount),this._mode!==Vt.SCENE2D&&this.look(this.right,t)};var c1e=new wt,m1e=new ot;fn.prototype.look=function(t,e){let n=f(e,this.defaultLookAmount),i=wt.fromAxisAngle(t,-n,c1e),o=ot.fromQuaternion(i,m1e),a=this.direction,s=this.up,l=this.right;ot.multiplyByVector(o,a,a),ot.multiplyByVector(o,s,s),ot.multiplyByVector(o,l,l)};fn.prototype.twistLeft=function(t){t=f(t,this.defaultLookAmount),this.look(this.direction,t)};fn.prototype.twistRight=function(t){t=f(t,this.defaultLookAmount),this.look(this.direction,-t)};var h1e=new wt,p1e=new ot;fn.prototype.rotate=function(t,e){let n=f(e,this.defaultRotateAmount),i=wt.fromAxisAngle(t,-n,h1e),o=ot.fromQuaternion(i,p1e);ot.multiplyByVector(o,this.position,this.position),ot.multiplyByVector(o,this.direction,this.direction),ot.multiplyByVector(o,this.up,this.up),p.cross(this.direction,this.up,this.right),p.cross(this.right,this.direction,this.up),this._adjustOrthographicFrustum(!1)};fn.prototype.rotateDown=function(t){t=f(t,this.defaultRotateAmount),KNt(this,t)};fn.prototype.rotateUp=function(t){t=f(t,this.defaultRotateAmount),KNt(this,-t)};var V1e=new p,u1e=new p,Z1e=new p,kNt=new p;function KNt(t,e){let n=t.position;if(c(t.constrainedAxis)&&!p.equalsEpsilon(t.position,p.ZERO,k.EPSILON2)){let i=p.normalize(n,V1e),o=p.equalsEpsilon(i,t.constrainedAxis,k.EPSILON2),a=p.equalsEpsilon(i,p.negate(t.constrainedAxis,kNt),k.EPSILON2);if(!o&&!a){let s=p.normalize(t.constrainedAxis,u1e),l=p.dot(i,s),r=k.acosClamped(l);e>0&&e>r&&(e=r-k.EPSILON4),l=p.dot(i,p.negate(s,kNt)),r=k.acosClamped(l),e<0&&-e>r&&(e=-r+k.EPSILON4);let d=p.cross(s,i,Z1e);t.rotate(d,e)}else(o&&e<0||a&&e>0)&&t.rotate(t.right,e)}else t.rotate(t.right,e)}fn.prototype.rotateRight=function(t){t=f(t,this.defaultRotateAmount),zNt(this,-t)};fn.prototype.rotateLeft=function(t){t=f(t,this.defaultRotateAmount),zNt(this,t)};function zNt(t,e){c(t.constrainedAxis)?t.rotate(t.constrainedAxis,e):t.rotate(t.up,e)}function jz(t,e){let n=t.frustum,i;if(e=e*.5,Math.abs(n.top)+Math.abs(n.bottom)>Math.abs(n.left)+Math.abs(n.right)){let o=n.top-e,a=n.bottom+e,s=t._maxCoord.y;t._scene.mapMode2D===eh.ROTATE&&(s*=t.maximumZoomFactor),a>s&&(a=s,o=-s),o<=a&&(o=1,a=-1),i=n.right/n.top,n.top=o,n.bottom=a,n.right=n.top*i,n.left=-n.right}else{let o=n.right-e,a=n.left+e,s=t._maxCoord.x;t._scene.mapMode2D===eh.ROTATE&&(s*=t.maximumZoomFactor),o>s&&(o=s,a=-s),o<=a&&(o=1,a=-1),i=n.top/n.right,n.right=o,n.left=a,n.top=n.right*i,n.bottom=-n.top}}function jNt(t,e){t.move(t.direction,e)}fn.prototype.zoomIn=function(t){t=f(t,this.defaultZoomAmount),this._mode===Vt.SCENE2D?jz(this,t):jNt(this,t)};fn.prototype.zoomOut=function(t){t=f(t,this.defaultZoomAmount),this._mode===Vt.SCENE2D?jz(this,-t):jNt(this,-t)};fn.prototype.getMagnitude=function(){if(this._mode===Vt.SCENE3D)return p.magnitude(this.position);if(this._mode===Vt.COLUMBUS_VIEW)return Math.abs(this.position.z);if(this._mode===Vt.SCENE2D)return Math.max(this.frustum.right-this.frustum.left,this.frustum.top-this.frustum.bottom)};var R1e=new L;fn.prototype.lookAt=function(t,e){let n=Pe.eastNorthUpToFixedFrame(t,mt.WGS84,R1e);this.lookAtTransform(n,e)};var b1e=new p,W1e=new wt,f1e=new wt,F1e=new ot;function qNt(t,e,n){e=k.clamp(e,-k.PI_OVER_TWO,k.PI_OVER_TWO),t=k.zeroToTwoPi(t)-k.PI_OVER_TWO;let i=wt.fromAxisAngle(p.UNIT_Y,-e,W1e),o=wt.fromAxisAngle(p.UNIT_Z,-t,f1e),a=wt.multiply(o,i,o),s=ot.fromQuaternion(a,F1e),l=p.clone(p.UNIT_X,b1e);return ot.multiplyByVector(s,l,l),p.negate(l,l),p.multiplyByScalar(l,n,l),l}fn.prototype.lookAtTransform=function(t,e){if(this._setTransform(t),!c(e))return;let n;if(c(e.heading)?n=qNt(e.heading,e.pitch,e.range):n=e,this._mode===Vt.SCENE2D){K.clone(K.ZERO,this.position),p.negate(n,this.up),this.up.z=0,p.magnitudeSquared(this.up)<k.EPSILON10&&p.clone(p.UNIT_Y,this.up),p.normalize(this.up,this.up),this._setTransform(L.IDENTITY),p.negate(p.UNIT_Z,this.direction),p.cross(this.direction,this.up,this.right),p.normalize(this.right,this.right);let i=this.frustum,o=i.top/i.right;i.right=p.magnitude(n)*.5,i.left=-i.right,i.top=o*i.right,i.bottom=-i.top,this._setTransform(t);return}p.clone(n,this.position),p.negate(this.position,this.direction),p.normalize(this.direction,this.direction),p.cross(this.direction,p.UNIT_Z,this.right),p.magnitudeSquared(this.right)<k.EPSILON10&&p.clone(p.UNIT_X,this.right),p.normalize(this.right,this.right),p.cross(this.right,this.direction,this.up),p.normalize(this.up,this.up),this._adjustOrthographicFrustum(!0)};var G_=new gt,U1e=new gt,G1e=new p,A1e=new p,S1e=new p,T1e=new p,g1e=new p,E1e=new p,C1e=new p,sat=new p,I1e={direction:new p,right:new p,up:new p},YNt;function dc(t,e,n,i){return Math.abs(p.dot(e,n))/i-p.dot(t,n)}function $Nt(t,e,n,i){let o=t._projection.ellipsoid,a=i?t:I1e,s=e.north,l=e.south,r=e.east,d=e.west;d>r&&(r+=k.TWO_PI);let m=(d+r)*.5,h;if(l<-k.PI_OVER_TWO+k.RADIANS_PER_DEGREE&&s>k.PI_OVER_TWO-k.RADIANS_PER_DEGREE)h=0;else{let J=G_;J.longitude=m,J.latitude=s,J.height=0;let M=U1e;M.longitude=m,M.latitude=l,M.height=0;let Z=YNt;(!c(Z)||Z.ellipsoid!==o)&&(YNt=Z=new ou(void 0,void 0,o)),Z.setEndPoints(J,M),h=Z.interpolateUsingFraction(.5,G_).latitude}let u=G_;u.longitude=m,u.latitude=h,u.height=0;let R=o.cartographicToCartesian(u,C1e),V=G_;V.longitude=r,V.latitude=s;let F=o.cartographicToCartesian(V,G1e);V.longitude=d;let U=o.cartographicToCartesian(V,S1e);V.longitude=m;let G=o.cartographicToCartesian(V,g1e);V.latitude=l;let A=o.cartographicToCartesian(V,E1e);V.longitude=r;let S=o.cartographicToCartesian(V,T1e);V.longitude=d;let g=o.cartographicToCartesian(V,A1e);p.subtract(U,R,U),p.subtract(S,R,S),p.subtract(F,R,F),p.subtract(g,R,g),p.subtract(G,R,G),p.subtract(A,R,A);let C=o.geodeticSurfaceNormal(R,a.direction);p.negate(C,C);let y=p.cross(C,p.UNIT_Z,a.right);p.normalize(y,y);let Y=p.cross(y,C,a.up),Q;if(t.frustum instanceof wn){let J=Math.max(p.distance(F,U),p.distance(S,g)),M=Math.max(p.distance(F,S),p.distance(U,g)),Z,E,I=t.frustum._offCenterFrustum,B=I.right/I.top,X=M*B;J>X?(Z=J,E=Z/B):(E=M,Z=X),Q=Math.max(Z,E)}else{let J=Math.tan(t.frustum.fovy*.5),M=t.frustum.aspectRatio*J;if(Q=Math.max(dc(C,Y,U,J),dc(C,Y,S,J),dc(C,Y,F,J),dc(C,Y,g,J),dc(C,Y,G,J),dc(C,Y,A,J),dc(C,y,U,M),dc(C,y,S,M),dc(C,y,F,M),dc(C,y,g,M),dc(C,y,G,M),dc(C,y,A,M)),l<0&&s>0){let Z=G_;Z.longitude=d,Z.latitude=0,Z.height=0;let E=o.cartographicToCartesian(Z,sat);p.subtract(E,R,E),Q=Math.max(Q,dc(C,Y,E,J),dc(C,y,E,M)),Z.longitude=r,E=o.cartographicToCartesian(Z,sat),p.subtract(E,R,E),Q=Math.max(Q,dc(C,Y,E,J),dc(C,y,E,M))}}return p.add(R,p.multiplyByScalar(C,-Q,sat),n)}var N1e=new gt,y1e=new p,B1e=new p;function Q1e(t,e,n){let i=t._projection;e.west>e.east&&(e=Gt.MAX_VALUE);let o=t._actualTransform,a=t._actualInvTransform,s=N1e;s.longitude=e.east,s.latitude=e.north;let l=i.project(s,y1e);L.multiplyByPoint(o,l,l),L.multiplyByPoint(a,l,l),s.longitude=e.west,s.latitude=e.south;let r=i.project(s,B1e);if(L.multiplyByPoint(o,r,r),L.multiplyByPoint(a,r,r),n.x=(l.x-r.x)*.5+r.x,n.y=(l.y-r.y)*.5+r.y,c(t.frustum.fovy)){let d=Math.tan(t.frustum.fovy*.5),m=t.frustum.aspectRatio*d;n.z=Math.max((l.x-r.x)/m,(l.y-r.y)/d)*.5}else{let d=l.x-r.x,m=l.y-r.y;n.z=Math.max(d,m)}return n}var k1e=new gt,Y1e=new p,x1e=new p;function X1e(t,e,n){let i=t._projection,o=e.east;e.west>e.east&&(t._scene.mapMode2D===eh.INFINITE_SCROLL?o+=k.TWO_PI:(e=Gt.MAX_VALUE,o=e.east));let a=k1e;a.longitude=o,a.latitude=e.north;let s=i.project(a,Y1e);a.longitude=e.west,a.latitude=e.south;let l=i.project(a,x1e),r=Math.abs(s.x-l.x)*.5,d=Math.abs(s.y-l.y)*.5,m,h,u=t.frustum.right/t.frustum.top,R=d*u;return r>R?(m=r,h=m/u):(h=d,m=R),d=Math.max(2*m,2*h),n.x=(s.x-l.x)*.5+l.x,n.y=(s.y-l.y)*.5+l.y,a=i.unproject(n,a),a.height=d,n=i.project(a,n),n}fn.prototype.getRectangleCameraCoordinates=function(t,e){let n=this._mode;if(c(e)||(e=new p),n===Vt.SCENE3D)return $Nt(this,t,e);if(n===Vt.COLUMBUS_VIEW)return Q1e(this,t,e);if(n===Vt.SCENE2D)return X1e(this,t,e)};var J1e=new di;function L1e(t,e,n,i){n=f(n,mt.WGS84);let o=t.getPickRay(e,J1e),a=no.rayEllipsoid(o,n);if(!a)return;let s=a.start>0?a.start:a.stop;return di.getPoint(o,s,i)}var M1e=new di;function _1e(t,e,n,i){let a=t.getPickRay(e,M1e).origin;a=p.fromElements(a.y,a.z,0,a);let s=n.unproject(a);if(!(s.latitude<-k.PI_OVER_TWO||s.latitude>k.PI_OVER_TWO))return n.ellipsoid.cartographicToCartesian(s,i)}var D1e=new di;function O1e(t,e,n,i){let o=t.getPickRay(e,D1e),a=-o.origin.x/o.direction.x;di.getPoint(o,a,i);let s=n.unproject(new p(i.y,i.z,0));if(!(s.latitude<-k.PI_OVER_TWO||s.latitude>k.PI_OVER_TWO||s.longitude<-Math.PI||s.longitude>Math.PI))return n.ellipsoid.cartographicToCartesian(s,i)}fn.prototype.pickEllipsoid=function(t,e,n){let i=this._scene.canvas;if(!(i.clientWidth===0||i.clientHeight===0)){if(c(n)||(n=new p),e=f(e,mt.WGS84),this._mode===Vt.SCENE3D)n=L1e(this,t,e,n);else if(this._mode===Vt.SCENE2D)n=_1e(this,t,this._projection,n);else if(this._mode===Vt.COLUMBUS_VIEW)n=O1e(this,t,this._projection,n);else return;return n}};var H1e=new p,w1e=new p,P1e=new p;function v1e(t,e,n){let i=t._scene.canvas,o=i.clientWidth,a=i.clientHeight,s=Math.tan(t.frustum.fovy*.5),l=t.frustum.aspectRatio*s,r=t.frustum.near,d=2/o*e.x-1,m=2/a*(a-e.y)-1,h=t.positionWC;p.clone(h,n.origin);let u=p.multiplyByScalar(t.directionWC,r,H1e);p.add(h,u,u);let R=p.multiplyByScalar(t.rightWC,d*r*l,w1e),V=p.multiplyByScalar(t.upWC,m*r*s,P1e),F=p.add(u,R,n.direction);return p.add(F,V,F),p.subtract(F,h,F),p.normalize(F,F),n}var wz=new p;function K1e(t,e,n){let i=t._scene.canvas,o=i.clientWidth,a=i.clientHeight,s=t.frustum,l=s.offCenterFrustum;c(l)&&(s=l);let r=2/o*e.x-1;r*=(s.right-s.left)*.5;let d=2/a*(a-e.y)-1;d*=(s.top-s.bottom)*.5;let m=n.origin;return p.clone(t.position,m),p.multiplyByScalar(t.right,r,wz),p.add(wz,m,m),p.multiplyByScalar(t.up,d,wz),p.add(wz,m,m),p.clone(t.directionWC,n.direction),(t._mode===Vt.COLUMBUS_VIEW||t._mode===Vt.SCENE2D)&&p.fromElements(n.origin.z,n.origin.x,n.origin.y,n.origin),n}fn.prototype.getPickRay=function(t,e){c(e)||(e=new di);let n=this._scene.canvas;if(n.clientWidth<=0||n.clientHeight<=0)return;let i=this.frustum;return c(i.aspectRatio)&&c(i.fov)&&c(i.near)?v1e(this,t,e):K1e(this,t,e)};var z1e=new p,j1e=new p;fn.prototype.distanceToBoundingSphere=function(t){let e=p.subtract(this.positionWC,t.center,z1e),n=p.multiplyByScalar(this.directionWC,p.dot(e,this.directionWC),j1e);return Math.max(0,p.magnitude(n)-t.radius)};var q1e=new K;fn.prototype.getPixelSize=function(t,e,n){let i=this.distanceToBoundingSphere(t),o=this.frustum.getPixelDimensions(e,n,i,this._scene.pixelRatio,q1e);return Math.max(o.x,o.y)};function $1e(t,e,n,i,o,a){let s=p.clone(e);n.y>i?s.y-=n.y-i:n.y<-i&&(s.y+=-i-n.y),n.z>o?s.z-=n.z-o:n.z<-o&&(s.z+=-o-n.z);function l(r){let d=p.lerp(e,s,r.time,new p);t.worldToCameraCoordinatesPoint(d,t.position)}return{easingFunction:ul.EXPONENTIAL_OUT,startObject:{time:0},stopObject:{time:1},duration:a,update:l}}var tNe=new p,xNt=new p,eNe=new p,nNe=new p;function iNe(t,e){let n=t.position,i=t.direction,o=t.worldToCameraCoordinatesVector(p.UNIT_X,tNe),a=-p.dot(o,n)/p.dot(o,i),s=p.add(n,p.multiplyByScalar(i,a,xNt),xNt);t.cameraToWorldCoordinatesPoint(s,s),n=t.cameraToWorldCoordinatesPoint(t.position,eNe);let l=Math.tan(t.frustum.fovy*.5),r=t.frustum.aspectRatio*l,d=p.magnitude(p.subtract(n,s,nNe)),m=r*d,h=l*d,u=t._maxCoord.x,R=t._maxCoord.y,V=Math.max(m-u,u),F=Math.max(h-R,R);if(n.z<-V||n.z>V||n.y<-F||n.y>F){let U=s.y<-V||s.y>V,G=s.z<-F||s.z>F;if(U||G)return $1e(t,n,s,V,F,e)}}fn.prototype.createCorrectPositionTween=function(t){if(this._mode===Vt.COLUMBUS_VIEW)return iNe(this,t)};var oNe=new p,Qr={destination:void 0,heading:void 0,pitch:void 0,roll:void 0,duration:void 0,complete:void 0,cancel:void 0,endTransform:void 0,maximumHeight:void 0,easingFunction:void 0};fn.prototype.cancelFlight=function(){c(this._currentFlight)&&(this._currentFlight.cancelTween(),this._currentFlight=void 0)};fn.prototype.completeFlight=function(){if(c(this._currentFlight)){this._currentFlight.cancelTween();let t={destination:void 0,orientation:{heading:void 0,pitch:void 0,roll:void 0}};t.destination=Qr.destination,t.orientation.heading=Qr.heading,t.orientation.pitch=Qr.pitch,t.orientation.roll=Qr.roll,this.setView(t),c(this._currentFlight.complete)&&this._currentFlight.complete(),this._currentFlight=void 0}};fn.prototype.flyTo=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.destination;if(this._mode===Vt.MORPHING)return;this.cancelFlight();let i=e instanceof Gt;i&&(e=this.getRectangleCameraCoordinates(e,oNe));let o=f(t.orientation,f.EMPTY_OBJECT);if(c(o.direction)&&(o=PNt(this,e,o,dat.orientation)),c(t.duration)&&t.duration<=0){let m=dat;m.destination=t.destination,m.orientation.heading=o.heading,m.orientation.pitch=o.pitch,m.orientation.roll=o.roll,m.convert=t.convert,m.endTransform=t.endTransform,this.setView(m),typeof t.complete=="function"&&t.complete();return}let a=this,s;Qr.destination=e,Qr.heading=o.heading,Qr.pitch=o.pitch,Qr.roll=o.roll,Qr.duration=t.duration,Qr.complete=function(){s===a._currentFlight&&(a._currentFlight=void 0),c(t.complete)&&t.complete()},Qr.cancel=t.cancel,Qr.endTransform=t.endTransform,Qr.convert=i?!1:t.convert,Qr.maximumHeight=t.maximumHeight,Qr.pitchAdjustHeight=t.pitchAdjustHeight,Qr.flyOverLongitude=t.flyOverLongitude,Qr.flyOverLongitudeWeight=t.flyOverLongitudeWeight,Qr.easingFunction=t.easingFunction;let l=this._scene,r=U_.createTween(l,Qr);if(r.duration===0){typeof r.complete=="function"&&r.complete();return}s=l.tweens.add(r),this._currentFlight=s;let d=this._scene.preloadFlightCamera;this._mode!==Vt.SCENE2D&&(c(d)||(d=fn.clone(this)),d.setView({destination:e,orientation:o}),this._scene.preloadFlightCullingVolume=d.frustum.computeCullingVolume(d.positionWC,d.directionWC,d.upWC))};function aNe(t,e){let n=t.frustum,i=Math.tan(n.fovy*.5),o=n.aspectRatio*i;return Math.max(e/o,e/i)}function sNe(t,e){let n=t.frustum,i=n.offCenterFrustum;c(i)&&(n=i);let o,a,s=n.right/n.top,l=e*s;return e>l?(o=e,a=o/s):(a=e,o=l),Math.max(o,a)*1.5}var lNe=100;function tyt(t,e,n){n=uV.clone(c(n)?n:fn.DEFAULT_OFFSET);let i=t._scene.screenSpaceCameraController.minimumZoomDistance,o=t._scene.screenSpaceCameraController.maximumZoomDistance,a=n.range;if(!c(a)||a===0){let s=e.radius;s===0?n.range=lNe:t.frustum instanceof wn||t._mode===Vt.SCENE2D?n.range=sNe(t,s):n.range=aNe(t,s),n.range=k.clamp(n.range,i,o)}return n}fn.prototype.viewBoundingSphere=function(t,e){e=tyt(this,t,e),this.lookAt(t.center,e)};var rNe=new L,dNe=new p,cNe=new p,mNe=new p,hNe=new p,pNe=new bt,VNe=new wt,uNe=new ot;fn.prototype.flyToBoundingSphere=function(t,e){e=f(e,f.EMPTY_OBJECT);let n=this._mode===Vt.SCENE2D||this._mode===Vt.COLUMBUS_VIEW;this._setTransform(L.IDENTITY);let i=tyt(this,t,e.offset),o;n?o=p.multiplyByScalar(p.UNIT_Z,i.range,dNe):o=qNt(i.heading,i.pitch,i.range);let a=Pe.eastNorthUpToFixedFrame(t.center,mt.WGS84,rNe);L.multiplyByPoint(a,o,o);let s,l;if(!n){if(s=p.subtract(t.center,o,cNe),p.normalize(s,s),l=L.multiplyByPointAsVector(a,p.UNIT_Z,mNe),1-Math.abs(p.dot(s,l))<k.EPSILON6){let d=wt.fromAxisAngle(s,i.heading,VNe),m=ot.fromQuaternion(d,uNe);p.fromCartesian4(L.getColumn(a,1,pNe),l),ot.multiplyByVector(m,l,l)}let r=p.cross(s,l,hNe);p.cross(r,s,l),p.normalize(l,l)}this.flyTo({destination:o,orientation:{direction:s,up:l},duration:e.duration,complete:e.complete,cancel:e.cancel,endTransform:e.endTransform,maximumHeight:e.maximumHeight,easingFunction:e.easingFunction,flyOverLongitude:e.flyOverLongitude,flyOverLongitudeWeight:e.flyOverLongitudeWeight,pitchAdjustHeight:e.pitchAdjustHeight})};var XNt=new p,JNt=new p,lat=new p,LNt=new p,A_=[new p,new p,new p,new p];function ZNe(t,e){let n=e.radii,i=t.positionWC,o=p.multiplyComponents(e.oneOverRadii,i,XNt),a=p.magnitude(o),s=p.normalize(o,JNt),l,r;p.equalsEpsilon(s,p.UNIT_Z,k.EPSILON10)?(l=new p(0,1,0),r=new p(0,0,1)):(l=p.normalize(p.cross(p.UNIT_Z,s,lat),lat),r=p.normalize(p.cross(s,l,LNt),LNt));let d=Math.sqrt(p.magnitudeSquared(o)-1),m=p.multiplyByScalar(s,1/a,XNt),h=d/a,u=p.multiplyByScalar(l,h,JNt),R=p.multiplyByScalar(r,h,lat),V=p.add(m,R,A_[0]);p.subtract(V,u,V),p.multiplyComponents(n,V,V);let F=p.subtract(m,R,A_[1]);p.subtract(F,u,F),p.multiplyComponents(n,F,F);let U=p.subtract(m,R,A_[2]);p.add(U,u,U),p.multiplyComponents(n,U,U);let G=p.add(m,R,A_[3]);return p.add(G,u,G),p.multiplyComponents(n,G,G),A_}var rat=new K,RNe=new p,VU=[new gt,new gt,new gt,new gt];function Pz(t,e,n,i,o,a){rat.x=t,rat.y=e;let s=i.pickEllipsoid(rat,o,RNe);return c(s)?(VU[n]=o.cartesianToCartographic(s,VU[n]),1):(VU[n]=o.cartesianToCartographic(a[n],VU[n]),0)}fn.prototype.computeViewRectangle=function(t,e){t=f(t,mt.WGS84);let n=this.frustum.computeCullingVolume(this.positionWC,this.directionWC,this.upWC),i=new Ft(p.ZERO,t.maximumRadius);if(n.computeVisibility(i)===yn.OUTSIDE)return;let a=this._scene.canvas,s=a.clientWidth,l=a.clientHeight,r=0,d=ZNe(this,t);if(r+=Pz(0,0,0,this,t,d),r+=Pz(0,l,1,this,t,d),r+=Pz(s,l,2,this,t,d),r+=Pz(s,0,3,this,t,d),r<2)return Gt.MAX_VALUE;e=Gt.fromCartographicArray(VU,e);let m=0,h=VU[3].longitude;for(let u=0;u<4;++u){let R=VU[u].longitude,V=Math.abs(R-h);V>k.PI?m+=k.TWO_PI-V:m+=V,h=R}return k.equalsEpsilon(Math.abs(m),k.TWO_PI,k.EPSILON9)&&(e.west=-k.PI,e.east=k.PI,VU[0].latitude>=0?e.north=k.PI_OVER_TWO:e.south=-k.PI_OVER_TWO),e};fn.prototype.switchToPerspectiveFrustum=function(){if(this._mode===Vt.SCENE2D||this.frustum instanceof Io)return;let t=this._scene;this.frustum=new Io,this.frustum.aspectRatio=t.drawingBufferWidth/t.drawingBufferHeight,this.frustum.fov=k.toRadians(60)};fn.prototype.switchToOrthographicFrustum=function(){if(this._mode===Vt.SCENE2D||this.frustum instanceof wn)return;let t=HNt(this),e=this._scene;this.frustum=new wn,this.frustum.aspectRatio=e.drawingBufferWidth/e.drawingBufferHeight,this.frustum.width=t};fn.clone=function(t,e){return c(e)||(e=new fn(t._scene)),p.clone(t.position,e.position),p.clone(t.direction,e.direction),p.clone(t.up,e.up),p.clone(t.right,e.right),L.clone(t._transform,e.transform),e._transformChanged=!0,e.frustum=t.frustum.clone(),e};var{getAzElRange:pat}=x1,{PI_OVER_THREE:eyt}=k;fn.prototype.trackFromTo=function(t,e){this.unTrack(),this.fromEntity=t,this.toEntity=e;let n=this.toEntity.position.getValue(this._scene._frameState.time),i=this.fromEntity.position.getValue(this._scene._frameState.time),{range:o}=pat(n,i);this.currentZoomLevel=o,this._setTrackListener=this._scene._preRender.addEventListener(this._setTrack.bind(this));let{toEntity:a,fromEntity:s}=this,{time:l}=this._scene._frameState;this._wheelEventListener=this._scene.canvas.addEventListener("wheel",r=>{r.preventDefault();let d=a.position.getValue(l),m=s.position.getValue(l);if(!d||!m)return;let{range:h}=x1.getAzElRange(d,m),u=this.currentZoomLevel/h,R=Math.max(1e-5,Math.log(1+2*u)),V=r.deltaY*this.scrollFactor*R;this.currentZoomLevel=Math.min(Math.max(0,this.currentZoomLevel+V),h),this.currentZoomLevel<h?this.zoomActive=!0:this.zoomActive=!1,this._scene.render()})};fn.prototype.eyeDistToTarget=null;fn.prototype.fromEntity=null;fn.prototype.toEntity=null;fn.prototype.cmax=eyt;fn.prototype.scrollFactor=1e3;fn.prototype.currentZoomLevel=-1;fn.prototype.CATS=0;fn.prototype.zoomActive=!1;fn.prototype.trackDebug=!1;fn.prototype.cmin=function(t){return 2*Math.atan(1/t)};fn.prototype._resetTrack=function(){this?.frustum?.fov&&(this.frustum.fov=eyt),this._setTrackListener&&this._setTrackListener(),this._wheelEventListener&&this._wheelEventListener()};fn.prototype.unTrack=function(t=!0){this._wheelEventListener&&(this._scene.canvas.removeEventListener("wheel",this._wheelEventListener),this._wheelEventListener=null),this._setTrackListener&&this._scene._preRender.removeEventListener(this._setTrackListener),t&&this.flyHome(0),this.fromEntity=null,this.toEntity=null,this._resetTrack()};fn.prototype._setZoom=function(){let t=this.toEntity.position.getValue(this._scene._frameState.time),e=this.fromEntity.position.getValue(this._scene._frameState.time),{range:n}=pat(t,e),i=Math.min(this.currentZoomLevel,n),o=this.cmin(n);return(this.cmax-o)*(i/n)+o};fn.prototype._setTrack=function(){try{let t=this.toEntity.position.getValue(this._scene._frameState.time),e=this.fromEntity.position.getValue(this._scene._frameState.time),n=new p;p.subtract(t,e,n),p.normalize(n,n),p.multiplyByScalar(n,-1e-32,n);let i=new L,o=new L;this.fromEntity.computeModelMatrix(this._scene._frameState.time,i,!1,ri.ENU),L.inverse(i,o),L.multiplyByPointAsVector(o,n,n),this.lookAtTransform(i,n);let{az:a,el:s,range:l}=pat(t,e);this.frustum.fov=this.zoomActive?this._setZoom():this.cmax;let r=(this.frustum.fov-this.cmin(l))/(this.cmax-this.cmin(l));this.eyeDistToTarget=(1-r)*.1+r*l;let d=_Z.computeSunPositionInEarthInertialFrame(this._scene._frameState.time),m=p.subtract(d,t,new p),h=p.normalize(m,new p),u=p.normalize(p.subtract(t,e,new p),new p);this.CATS=p.dot(h,u);let R=document.getElementById("debugPanel");this.trackDebug?(R||(R=document.createElement("div"),R.id="debugPanel",R.style.cssText=` background-color: rgba(0, 0, 0, 0.5); color: white; position: absolute; top: 10px; left: 10px; padding: 10px; - z-index: 1;`,document.body.appendChild(b)),b.innerHTML=` + z-index: 1;`,document.body.appendChild(R)),R.innerHTML=` <p style="font-size:.75rem"> <strong>${this.toEntity.name}<br/> <br/> @@ -10700,8 +10700,8 @@ void main() y: ${(e.y/1e3).toFixed(3)} km<br/> z: ${(e.z/1e3).toFixed(3)} km<br/> </p> - `):b&&b.parentNode.removeChild(b)}catch(t){console.log(t)}};var Aa=fn;var FSo=R(W(),1);function RNe(t){this.pass=t.pass,this.commandList=t.commandList,this.camera=t.camera,this.cullingVolume=t.cullingVolume,this.ready=!1}var Eu=RNe;var CSo=R(W(),1);var syt=R(uh(),1),nyt=576,WNe=100,T_="#ffffff",uat="#48b";function lyt(t,e){this.credit=t,this.count=f(e,1)}function fNe(t,e){let n=t.length;for(let i=0;i<n;i++){let o=t[i];if(on.equals(o,e))return!0}return!1}function FNe(t){let e=t._previousCesiumCredit,n=t._currentCesiumCredit;on.equals(n,e)||(c(e)&&t._cesiumCreditContainer.removeChild(e.element),c(n)&&t._cesiumCreditContainer.appendChild(n.element),t._previousCesiumCredit=n)}var ryt="cesium-credit-delimiter";function iyt(t){let e=document.createElement("span");return e.textContent=t,e.className=ryt,e}function oyt(t,e){if(c(e)){let n=document.createElement(e);n._creditId=t._creditId,n.appendChild(t),t=n}return t}function ayt(t,e,n,i){let o=t.childNodes,a=-1;e.sort(function(s,l){return l.count-s.count});for(let s=0;s<e.length;++s){let l=e[s].credit;if(c(l)){if(a=s,c(n)&&(a*=2,s>0)){let d=a-1;if(o.length<=d)t.appendChild(iyt(n));else{let m=o[d];m.className!==ryt&&t.replaceChild(iyt(n),m)}}let r=l.element;if(o.length<=a)t.appendChild(oyt(r,i));else{let d=o[a];d._creditId!==l._id&&t.replaceChild(oyt(r,i),d)}}}for(++a;a<o.length;)t.removeChild(o[a])}function UNe(t){let e=t._lightboxCredits,n=t.viewport.clientWidth,i=t.viewport.clientHeight;n!==t._lastViewportWidth&&(n<nyt?(e.className="cesium-credit-lightbox cesium-credit-lightbox-mobile",e.style.marginTop="0"):(e.className="cesium-credit-lightbox cesium-credit-lightbox-expanded",e.style.marginTop=`${Math.floor((i-e.clientHeight)*.5)}px`),t._lastViewportWidth=n),n>=nyt&&i!==t._lastViewportHeight&&(e.style.marginTop=`${Math.floor((i-e.clientHeight)*.5)}px`,t._lastViewportHeight=i)}function mc(t,e){let n=`${t} {`;for(let i in e)e.hasOwnProperty(i)&&(n+=`${i}: ${e[i]}; `);return n+=` } -`,n}function GNe(t){let e="";e+=mc(".cesium-credit-lightbox-overlay",{display:"none","z-index":"1",position:"absolute",top:"0",left:"0",width:"100%",height:"100%","background-color":"rgba(80, 80, 80, 0.8)"}),e+=mc(".cesium-credit-lightbox",{"background-color":"#303336",color:T_,position:"relative","min-height":`${WNe}px`,margin:"auto"}),e+=mc(".cesium-credit-lightbox > ul > li a, .cesium-credit-lightbox > ul > li a:visited",{color:T_}),e+=mc(".cesium-credit-lightbox > ul > li a:hover",{color:uat}),e+=mc(".cesium-credit-lightbox.cesium-credit-lightbox-expanded",{border:"1px solid #444","border-radius":"5px","max-width":"370px"}),e+=mc(".cesium-credit-lightbox.cesium-credit-lightbox-mobile",{height:"100%",width:"100%"}),e+=mc(".cesium-credit-lightbox-title",{padding:"20px 20px 0 20px"}),e+=mc(".cesium-credit-lightbox-close",{"font-size":"18pt",cursor:"pointer",position:"absolute",top:"0",right:"6px",color:T_}),e+=mc(".cesium-credit-lightbox-close:hover",{color:uat}),e+=mc(".cesium-credit-lightbox > ul",{margin:"0",padding:"12px 20px 12px 40px","font-size":"13px"}),e+=mc(".cesium-credit-lightbox > ul > li",{"padding-bottom":"6px"}),e+=mc(".cesium-credit-lightbox > ul > li *",{padding:"0",margin:"0"}),e+=mc(".cesium-credit-expand-link",{"padding-left":"5px",cursor:"pointer","text-decoration":"underline",color:T_}),e+=mc(".cesium-credit-expand-link:hover",{color:uat}),e+=mc(".cesium-credit-text",{color:T_}),e+=mc(".cesium-credit-textContainer *, .cesium-credit-logoContainer *",{display:"inline"});function n(a){if(a.shadowRoot)return a.shadowRoot;if(a.getRootNode){let s=a.getRootNode();if(s instanceof ShadowRoot)return s}}let i=f(n(t),document.head),o=document.createElement("style");o.innerHTML=e,i.appendChild(o)}function xs(t,e,n){let i=this;n=f(n,document.body);let o=document.createElement("div");o.className="cesium-credit-lightbox-overlay",n.appendChild(o);let a=document.createElement("div");a.className="cesium-credit-lightbox",o.appendChild(a);function s(u){a.contains(u.target)||i.hideLightbox()}o.addEventListener("click",s,!1);let l=document.createElement("div");l.className="cesium-credit-lightbox-title",l.textContent="Data provided by:",a.appendChild(l);let r=document.createElement("a");r.onclick=this.hideLightbox.bind(this),r.innerHTML="×",r.className="cesium-credit-lightbox-close",a.appendChild(r);let d=document.createElement("ul");a.appendChild(d);let m=document.createElement("div");m.className="cesium-credit-logoContainer",m.style.display="inline",t.appendChild(m);let h=document.createElement("div");h.className="cesium-credit-textContainer",h.style.display="inline",t.appendChild(h);let Z=document.createElement("a");Z.className="cesium-credit-expand-link",Z.onclick=this.showLightbox.bind(this),Z.textContent="Data attribution",t.appendChild(Z),GNe(t);let b=on.clone(xs.cesiumCredit);this._delimiter=f(e," \u2022 "),this._screenContainer=h,this._cesiumCreditContainer=m,this._lastViewportHeight=void 0,this._lastViewportWidth=void 0,this._lightboxCredits=a,this._creditList=d,this._lightbox=o,this._hideLightbox=s,this._expandLink=Z,this._expanded=!1,this._staticCredits=[],this._cesiumCredit=b,this._previousCesiumCredit=void 0,this._currentCesiumCredit=b,this._creditDisplayElementPool=[],this._creditDisplayElementIndex=0,this._currentFrameCredits={screenCredits:new qe,lightboxCredits:new qe},this._defaultCredit=void 0,this.viewport=n,this.container=t}function dyt(t,e,n,i){i=f(i,1);let o=e.get(n.id);if(c(o))o.count<Number.MAX_VALUE&&(o.count+=i);else{let a=t._creditDisplayElementPool,s=t._creditDisplayElementPoolIndex;s<a.length?(o=a[s],o.credit=n,o.count=i):(o=new lyt(n,i),a.push(o)),++t._creditDisplayElementPoolIndex,e.set(n.id,o)}}xs.prototype.addCreditToNextFrame=function(t){if(t.isIon()){c(this._defaultCredit)||(this._defaultCredit=on.clone(cyt())),this._currentCesiumCredit=this._defaultCredit;return}let e;t.showOnScreen?e=this._currentFrameCredits.screenCredits:e=this._currentFrameCredits.lightboxCredits,dyt(this,e,t)};xs.prototype.addStaticCredit=function(t){let e=this._staticCredits;fNe(e,t)||e.push(t)};xs.prototype.removeStaticCredit=function(t){let e=this._staticCredits,n=e.indexOf(t);n!==-1&&e.splice(n,1)};xs.prototype.showLightbox=function(){this._lightbox.style.display="block",this._expanded=!0};xs.prototype.hideLightbox=function(){this._lightbox.style.display="none",this._expanded=!1};xs.prototype.update=function(){this._expanded&&UNe(this)};xs.prototype.beginFrame=function(){let t=this._currentFrameCredits;this._creditDisplayElementPoolIndex=0;let e=t.screenCredits,n=t.lightboxCredits;e.removeAll(),n.removeAll();let i=this._staticCredits;for(let o=0;o<i.length;++o){let a=i[o],s=a.showOnScreen?e:n;a.isIon()&&on.equals(xs.cesiumCredit,this._cesiumCredit)||dyt(this,s,a,Number.MAX_VALUE)}on.equals(xs.cesiumCredit,this._cesiumCredit)||(this._cesiumCredit=on.clone(xs.cesiumCredit)),this._currentCesiumCredit=this._cesiumCredit};xs.prototype.endFrame=function(){let t=this._currentFrameCredits.screenCredits.values;ayt(this._screenContainer,t,this._delimiter,void 0);let e=this._currentFrameCredits.lightboxCredits.values;this._expandLink.style.display=e.length>0?"inline":"none",ayt(this._creditList,e,void 0,"li"),FNe(this)};xs.prototype.destroy=function(){return this._lightbox.removeEventListener("click",this._hideLightbox,!1),this.container.removeChild(this._cesiumCreditContainer),this.container.removeChild(this._screenContainer),this.container.removeChild(this._expandLink),this.viewport.removeChild(this._lightbox),At(this)};xs.prototype.isDestroyed=function(){return!1};xs._cesiumCredit=void 0;xs._cesiumCreditInitialized=!1;var qz;function cyt(){if(!c(qz)){let t=Dn("Assets/Images/ion-credit.png");t.indexOf("http://")!==0&&t.indexOf("https://")!==0&&t.indexOf("data:")!==0&&(t=new syt.default(t).path()),qz=new on(`<a href="https://cesium.com/" target="_blank"><img src="${t}" title="Cesium ion"/></a>`,!0)}return xs._cesiumCreditInitialized||(xs._cesiumCredit=qz,xs._cesiumCreditInitialized=!0),qz}Object.defineProperties(xs,{cesiumCredit:{get:function(){return cyt(),xs._cesiumCredit},set:function(t){xs._cesiumCredit=t,xs._cesiumCreditInitialized=!0}}});xs.CreditDisplayElement=lyt;var S_=xs;var ggo=R(W(),1);var PSo=R(W(),1);var $z=0,ANe=1;function ZS(t){let e=t.frustum,n=t.orientation,i=t.origin,o=f(t.vertexFormat,ee.DEFAULT),a=f(t._drawNearPlane,!0),s,l;e instanceof Io?(s=$z,l=Io.packedLength):e instanceof wn&&(s=ANe,l=wn.packedLength),this._frustumType=s,this._frustum=e.clone(),this._origin=p.clone(i),this._orientation=wt.clone(n),this._drawNearPlane=a,this._vertexFormat=o,this._workerName="createFrustumGeometry",this.packedLength=2+l+p.packedLength+wt.packedLength+ee.packedLength}ZS.pack=function(t,e,n){n=f(n,0);let i=t._frustumType,o=t._frustum;return e[n++]=i,i===$z?(Io.pack(o,e,n),n+=Io.packedLength):(wn.pack(o,e,n),n+=wn.packedLength),p.pack(t._origin,e,n),n+=p.packedLength,wt.pack(t._orientation,e,n),n+=wt.packedLength,ee.pack(t._vertexFormat,e,n),n+=ee.packedLength,e[n]=t._drawNearPlane?1:0,e};var TNe=new Io,SNe=new wn,gNe=new wt,ENe=new p,CNe=new ee;ZS.unpack=function(t,e,n){e=f(e,0);let i=t[e++],o;i===$z?(o=Io.unpack(t,e,TNe),e+=Io.packedLength):(o=wn.unpack(t,e,SNe),e+=wn.packedLength);let a=p.unpack(t,e,ENe);e+=p.packedLength;let s=wt.unpack(t,e,gNe);e+=wt.packedLength;let l=ee.unpack(t,e,CNe);e+=ee.packedLength;let r=t[e]===1;if(!c(n))return new ZS({frustum:o,origin:a,orientation:s,vertexFormat:l,_drawNearPlane:r});let d=i===n._frustumType?n._frustum:void 0;return n._frustum=o.clone(d),n._frustumType=i,n._origin=p.clone(a,n._origin),n._orientation=wt.clone(s,n._orientation),n._vertexFormat=ee.clone(l,n._vertexFormat),n._drawNearPlane=r,n};function J1(t,e,n,i,o,a,s,l){let r=t/3*2;for(let d=0;d<4;++d)c(e)&&(e[t]=a.x,e[t+1]=a.y,e[t+2]=a.z),c(n)&&(n[t]=s.x,n[t+1]=s.y,n[t+2]=s.z),c(i)&&(i[t]=l.x,i[t+1]=l.y,i[t+2]=l.z),t+=3;o[r]=0,o[r+1]=0,o[r+2]=1,o[r+3]=0,o[r+4]=1,o[r+5]=1,o[r+6]=0,o[r+7]=1}var INe=new ot,NNe=new L,Zat=new L,myt=new p,hyt=new p,pyt=new p,yNe=new p,BNe=new p,QNe=new p,ZU=new Array(3),g_=new Array(4);g_[0]=new Rt(-1,-1,1,1);g_[1]=new Rt(1,-1,1,1);g_[2]=new Rt(1,1,1,1);g_[3]=new Rt(-1,1,1,1);var uyt=new Array(4);for(let t=0;t<4;++t)uyt[t]=new Rt;ZS._computeNearFarPlanes=function(t,e,n,i,o,a,s,l){let r=ot.fromQuaternion(e,INe),d=f(a,myt),m=f(s,hyt),h=f(l,pyt);d=ot.getColumn(r,0,d),m=ot.getColumn(r,1,m),h=ot.getColumn(r,2,h),p.normalize(d,d),p.normalize(m,m),p.normalize(h,h),p.negate(d,d);let Z=L.computeView(t,h,m,d,NNe),b,u,F=i.projectionMatrix;if(n===$z){let U=L.multiply(F,Z,Zat);u=L.inverse(U,Zat)}else b=L.inverseTransformation(Z,Zat);c(u)?(ZU[0]=i.near,ZU[1]=i.far):(ZU[0]=0,ZU[1]=i.near,ZU[2]=i.far);for(let U=0;U<2;++U)for(let G=0;G<4;++G){let A=Rt.clone(g_[G],uyt[G]);if(c(u)){A=L.multiplyByVector(u,A,A);let T=1/A.w;p.multiplyByScalar(A,T,A),p.subtract(A,t,A),p.normalize(A,A);let g=p.dot(h,A);p.multiplyByScalar(A,ZU[U]/g,A),p.add(A,t,A)}else{let T=i.offCenterFrustum;c(T)&&(i=T);let g=ZU[U],C=ZU[U+1];A.x=(A.x*(i.right-i.left)+i.left+i.right)*.5,A.y=(A.y*(i.top-i.bottom)+i.bottom+i.top)*.5,A.z=(A.z*(g-C)-g-C)*.5,A.w=1,L.multiplyByVector(b,A,A)}o[12*U+G*3]=A.x,o[12*U+G*3+1]=A.y,o[12*U+G*3+2]=A.z}};ZS.createGeometry=function(t){let e=t._frustumType,n=t._frustum,i=t._origin,o=t._orientation,a=t._drawNearPlane,s=t._vertexFormat,l=a?6:5,r=new Float64Array(3*4*6);ZS._computeNearFarPlanes(i,o,e,n,r);let d=3*4*2;r[d]=r[3*4],r[d+1]=r[3*4+1],r[d+2]=r[3*4+2],r[d+3]=r[0],r[d+4]=r[1],r[d+5]=r[2],r[d+6]=r[3*3],r[d+7]=r[3*3+1],r[d+8]=r[3*3+2],r[d+9]=r[3*7],r[d+10]=r[3*7+1],r[d+11]=r[3*7+2],d+=3*4,r[d]=r[3*5],r[d+1]=r[3*5+1],r[d+2]=r[3*5+2],r[d+3]=r[3],r[d+4]=r[4],r[d+5]=r[5],r[d+6]=r[0],r[d+7]=r[1],r[d+8]=r[2],r[d+9]=r[3*4],r[d+10]=r[3*4+1],r[d+11]=r[3*4+2],d+=3*4,r[d]=r[3],r[d+1]=r[4],r[d+2]=r[5],r[d+3]=r[3*5],r[d+4]=r[3*5+1],r[d+5]=r[3*5+2],r[d+6]=r[3*6],r[d+7]=r[3*6+1],r[d+8]=r[3*6+2],r[d+9]=r[3*2],r[d+10]=r[3*2+1],r[d+11]=r[3*2+2],d+=3*4,r[d]=r[3*2],r[d+1]=r[3*2+1],r[d+2]=r[3*2+2],r[d+3]=r[3*6],r[d+4]=r[3*6+1],r[d+5]=r[3*6+2],r[d+6]=r[3*7],r[d+7]=r[3*7+1],r[d+8]=r[3*7+2],r[d+9]=r[3*3],r[d+10]=r[3*3+1],r[d+11]=r[3*3+2],a||(r=r.subarray(3*4));let m=new ei({position:new jt({componentDatatype:it.DOUBLE,componentsPerAttribute:3,values:r})});if(c(s.normal)||c(s.tangent)||c(s.bitangent)||c(s.st)){let Z=c(s.normal)?new Float32Array(12*l):void 0,b=c(s.tangent)?new Float32Array(3*4*l):void 0,u=c(s.bitangent)?new Float32Array(3*4*l):void 0,F=c(s.st)?new Float32Array(2*4*l):void 0,U=myt,G=hyt,A=pyt,T=p.negate(U,yNe),g=p.negate(G,BNe),C=p.negate(A,QNe);d=0,a&&(J1(d,Z,b,u,F,C,U,G),d+=3*4),J1(d,Z,b,u,F,A,T,G),d+=3*4,J1(d,Z,b,u,F,T,C,G),d+=3*4,J1(d,Z,b,u,F,g,C,T),d+=3*4,J1(d,Z,b,u,F,U,A,G),d+=3*4,J1(d,Z,b,u,F,G,A,T),c(Z)&&(m.normal=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:Z})),c(b)&&(m.tangent=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:b})),c(u)&&(m.bitangent=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:u})),c(F)&&(m.st=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:F}))}let h=new Uint16Array(6*l);for(let Z=0;Z<l;++Z){let b=Z*6,u=Z*4;h[b]=u,h[b+1]=u+1,h[b+2]=u+2,h[b+3]=u,h[b+4]=u+2,h[b+5]=u+3}return new _e({attributes:m,indices:h,primitiveType:le.TRIANGLES,boundingSphere:Ft.fromVertices(r)})};var VS=ZS;var rgo=R(W(),1);var Vat=0,kNe=1;function E_(t){let e=t.frustum,n=t.orientation,i=t.origin,o=f(t._drawNearPlane,!0),a,s;e instanceof Io?(a=Vat,s=Io.packedLength):e instanceof wn&&(a=kNe,s=wn.packedLength),this._frustumType=a,this._frustum=e.clone(),this._origin=p.clone(i),this._orientation=wt.clone(n),this._drawNearPlane=o,this._workerName="createFrustumOutlineGeometry",this.packedLength=2+s+p.packedLength+wt.packedLength}E_.pack=function(t,e,n){n=f(n,0);let i=t._frustumType,o=t._frustum;return e[n++]=i,i===Vat?(Io.pack(o,e,n),n+=Io.packedLength):(wn.pack(o,e,n),n+=wn.packedLength),p.pack(t._origin,e,n),n+=p.packedLength,wt.pack(t._orientation,e,n),n+=wt.packedLength,e[n]=t._drawNearPlane?1:0,e};var YNe=new Io,xNe=new wn,XNe=new wt,JNe=new p;E_.unpack=function(t,e,n){e=f(e,0);let i=t[e++],o;i===Vat?(o=Io.unpack(t,e,YNe),e+=Io.packedLength):(o=wn.unpack(t,e,xNe),e+=wn.packedLength);let a=p.unpack(t,e,JNe);e+=p.packedLength;let s=wt.unpack(t,e,XNe);e+=wt.packedLength;let l=t[e]===1;if(!c(n))return new E_({frustum:o,origin:a,orientation:s,_drawNearPlane:l});let r=i===n._frustumType?n._frustum:void 0;return n._frustum=o.clone(r),n._frustumType=i,n._origin=p.clone(a,n._origin),n._orientation=wt.clone(s,n._orientation),n._drawNearPlane=l,n};E_.createGeometry=function(t){let e=t._frustumType,n=t._frustum,i=t._origin,o=t._orientation,a=t._drawNearPlane,s=new Float64Array(3*4*2);VS._computeNearFarPlanes(i,o,e,n,s);let l=new ei({position:new jt({componentDatatype:it.DOUBLE,componentsPerAttribute:3,values:s})}),r,d,m=a?2:1,h=new Uint16Array(8*(m+1)),Z=a?0:1;for(;Z<2;++Z)r=a?Z*8:0,d=Z*4,h[r]=d,h[r+1]=d+1,h[r+2]=d+1,h[r+3]=d+2,h[r+4]=d+2,h[r+5]=d+3,h[r+6]=d+3,h[r+7]=d;for(Z=0;Z<2;++Z)r=(m+Z)*8,d=Z*4,h[r]=d,h[r+1]=d+4,h[r+2]=d+1,h[r+3]=d+5,h[r+4]=d+2,h[r+5]=d+6,h[r+6]=d+3,h[r+7]=d+7;return new _e({attributes:l,indices:h,primitiveType:le.LINES,boundingSphere:Ft.fromVertices(s)})};var C_=E_;function tj(t){t=f(t,f.EMPTY_OBJECT),this._camera=t.camera,this._frustumSplits=t.frustumSplits,this._color=f(t.color,v.CYAN),this._updateOnChange=f(t.updateOnChange,!0),this.show=f(t.show,!0),this.id=t.id,this._id=void 0,this._outlinePrimitives=[],this._planesPrimitives=[]}var LNe=new p,MNe=new ot,_Ne=new wt,DNe=new Io,ONe=new em,HNe=new wn,wNe=new el,PNe=new v,vNe=[1,1e5];tj.prototype.update=function(t){if(!this.show)return;let e=this._planesPrimitives,n=this._outlinePrimitives,i,o;if(this._updateOnChange){for(o=e.length,i=0;i<o;++i)n[i]=n[i]&&n[i].destroy(),e[i]=e[i]&&e[i].destroy();e.length=0,n.length=0}if(e.length===0){let a=this._camera,s=a.frustum,l;s instanceof Io?l=DNe:s instanceof em?l=ONe:s instanceof wn?l=HNe:l=wNe,l=s.clone(l);let r,d=this._frustumSplits;!c(d)||d.length<=1?(d=vNe,d[0]=this._camera.frustum.near,d[1]=this._camera.frustum.far,r=1):r=d.length-1;let m=a.positionWC,h=a.directionWC,Z=a.upWC,b=a.rightWC;b=p.negate(b,LNe);let u=MNe;ot.setColumn(u,0,b,u),ot.setColumn(u,1,Z,u),ot.setColumn(u,2,h,u);let F=wt.fromRotationMatrix(u,_Ne);for(e.length=n.length=r,i=0;i<r;++i)l.near=d[i],l.far=d[i+1],e[i]=new Wi({geometryInstances:new $e({geometry:new VS({origin:m,orientation:F,frustum:l,_drawNearPlane:i===0}),attributes:{color:En.fromColor(v.fromAlpha(this._color,.1,PNe))},id:this.id,pickPrimitive:this}),appearance:new jn({translucent:!0,flat:!0}),asynchronous:!1}),n[i]=new Wi({geometryInstances:new $e({geometry:new C_({origin:m,orientation:F,frustum:l,_drawNearPlane:i===0}),attributes:{color:En.fromColor(this._color)},id:this.id,pickPrimitive:this}),appearance:new jn({translucent:!1,flat:!0}),asynchronous:!1})}for(o=e.length,i=0;i<o;++i)n[i].update(t),e[i].update(t)};tj.prototype.isDestroyed=function(){return!1};tj.prototype.destroy=function(){let t=this._planesPrimitives.length;for(let e=0;e<t;++e)this._outlinePrimitives[e]=this._outlinePrimitives[e]&&this._outlinePrimitives[e].destroy(),this._planesPrimitives[e]=this._planesPrimitives[e]&&this._planesPrimitives[e].destroy();return At(this)};var Jb=tj;var tEo=R(W(),1);var Cgo=R(W(),1),I_=`in vec4 positionEC; + `):R&&R.parentNode.removeChild(R)}catch(t){console.log(t)}};var Aa=fn;var FTo=b(W(),1);function bNe(t){this.pass=t.pass,this.commandList=t.commandList,this.camera=t.camera,this.cullingVolume=t.cullingVolume,this.ready=!1}var EV=bNe;var CTo=b(W(),1);var syt=b(Vh(),1),nyt=576,WNe=100,S_="#ffffff",Vat="#48b";function lyt(t,e){this.credit=t,this.count=f(e,1)}function fNe(t,e){let n=t.length;for(let i=0;i<n;i++){let o=t[i];if(on.equals(o,e))return!0}return!1}function FNe(t){let e=t._previousCesiumCredit,n=t._currentCesiumCredit;on.equals(n,e)||(c(e)&&t._cesiumCreditContainer.removeChild(e.element),c(n)&&t._cesiumCreditContainer.appendChild(n.element),t._previousCesiumCredit=n)}var ryt="cesium-credit-delimiter";function iyt(t){let e=document.createElement("span");return e.textContent=t,e.className=ryt,e}function oyt(t,e){if(c(e)){let n=document.createElement(e);n._creditId=t._creditId,n.appendChild(t),t=n}return t}function ayt(t,e,n,i){let o=t.childNodes,a=-1;e.sort(function(s,l){return l.count-s.count});for(let s=0;s<e.length;++s){let l=e[s].credit;if(c(l)){if(a=s,c(n)&&(a*=2,s>0)){let d=a-1;if(o.length<=d)t.appendChild(iyt(n));else{let m=o[d];m.className!==ryt&&t.replaceChild(iyt(n),m)}}let r=l.element;if(o.length<=a)t.appendChild(oyt(r,i));else{let d=o[a];d._creditId!==l._id&&t.replaceChild(oyt(r,i),d)}}}for(++a;a<o.length;)t.removeChild(o[a])}function UNe(t){let e=t._lightboxCredits,n=t.viewport.clientWidth,i=t.viewport.clientHeight;n!==t._lastViewportWidth&&(n<nyt?(e.className="cesium-credit-lightbox cesium-credit-lightbox-mobile",e.style.marginTop="0"):(e.className="cesium-credit-lightbox cesium-credit-lightbox-expanded",e.style.marginTop=`${Math.floor((i-e.clientHeight)*.5)}px`),t._lastViewportWidth=n),n>=nyt&&i!==t._lastViewportHeight&&(e.style.marginTop=`${Math.floor((i-e.clientHeight)*.5)}px`,t._lastViewportHeight=i)}function mc(t,e){let n=`${t} {`;for(let i in e)e.hasOwnProperty(i)&&(n+=`${i}: ${e[i]}; `);return n+=` } +`,n}function GNe(t){let e="";e+=mc(".cesium-credit-lightbox-overlay",{display:"none","z-index":"1",position:"absolute",top:"0",left:"0",width:"100%",height:"100%","background-color":"rgba(80, 80, 80, 0.8)"}),e+=mc(".cesium-credit-lightbox",{"background-color":"#303336",color:S_,position:"relative","min-height":`${WNe}px`,margin:"auto"}),e+=mc(".cesium-credit-lightbox > ul > li a, .cesium-credit-lightbox > ul > li a:visited",{color:S_}),e+=mc(".cesium-credit-lightbox > ul > li a:hover",{color:Vat}),e+=mc(".cesium-credit-lightbox.cesium-credit-lightbox-expanded",{border:"1px solid #444","border-radius":"5px","max-width":"370px"}),e+=mc(".cesium-credit-lightbox.cesium-credit-lightbox-mobile",{height:"100%",width:"100%"}),e+=mc(".cesium-credit-lightbox-title",{padding:"20px 20px 0 20px"}),e+=mc(".cesium-credit-lightbox-close",{"font-size":"18pt",cursor:"pointer",position:"absolute",top:"0",right:"6px",color:S_}),e+=mc(".cesium-credit-lightbox-close:hover",{color:Vat}),e+=mc(".cesium-credit-lightbox > ul",{margin:"0",padding:"12px 20px 12px 40px","font-size":"13px"}),e+=mc(".cesium-credit-lightbox > ul > li",{"padding-bottom":"6px"}),e+=mc(".cesium-credit-lightbox > ul > li *",{padding:"0",margin:"0"}),e+=mc(".cesium-credit-expand-link",{"padding-left":"5px",cursor:"pointer","text-decoration":"underline",color:S_}),e+=mc(".cesium-credit-expand-link:hover",{color:Vat}),e+=mc(".cesium-credit-text",{color:S_}),e+=mc(".cesium-credit-textContainer *, .cesium-credit-logoContainer *",{display:"inline"});function n(a){if(a.shadowRoot)return a.shadowRoot;if(a.getRootNode){let s=a.getRootNode();if(s instanceof ShadowRoot)return s}}let i=f(n(t),document.head),o=document.createElement("style");o.innerHTML=e,i.appendChild(o)}function xs(t,e,n){let i=this;n=f(n,document.body);let o=document.createElement("div");o.className="cesium-credit-lightbox-overlay",n.appendChild(o);let a=document.createElement("div");a.className="cesium-credit-lightbox",o.appendChild(a);function s(V){a.contains(V.target)||i.hideLightbox()}o.addEventListener("click",s,!1);let l=document.createElement("div");l.className="cesium-credit-lightbox-title",l.textContent="Data provided by:",a.appendChild(l);let r=document.createElement("a");r.onclick=this.hideLightbox.bind(this),r.innerHTML="×",r.className="cesium-credit-lightbox-close",a.appendChild(r);let d=document.createElement("ul");a.appendChild(d);let m=document.createElement("div");m.className="cesium-credit-logoContainer",m.style.display="inline",t.appendChild(m);let h=document.createElement("div");h.className="cesium-credit-textContainer",h.style.display="inline",t.appendChild(h);let u=document.createElement("a");u.className="cesium-credit-expand-link",u.onclick=this.showLightbox.bind(this),u.textContent="Data attribution",t.appendChild(u),GNe(t);let R=on.clone(xs.cesiumCredit);this._delimiter=f(e," \u2022 "),this._screenContainer=h,this._cesiumCreditContainer=m,this._lastViewportHeight=void 0,this._lastViewportWidth=void 0,this._lightboxCredits=a,this._creditList=d,this._lightbox=o,this._hideLightbox=s,this._expandLink=u,this._expanded=!1,this._staticCredits=[],this._cesiumCredit=R,this._previousCesiumCredit=void 0,this._currentCesiumCredit=R,this._creditDisplayElementPool=[],this._creditDisplayElementIndex=0,this._currentFrameCredits={screenCredits:new qe,lightboxCredits:new qe},this._defaultCredit=void 0,this.viewport=n,this.container=t}function dyt(t,e,n,i){i=f(i,1);let o=e.get(n.id);if(c(o))o.count<Number.MAX_VALUE&&(o.count+=i);else{let a=t._creditDisplayElementPool,s=t._creditDisplayElementPoolIndex;s<a.length?(o=a[s],o.credit=n,o.count=i):(o=new lyt(n,i),a.push(o)),++t._creditDisplayElementPoolIndex,e.set(n.id,o)}}xs.prototype.addCreditToNextFrame=function(t){if(t.isIon()){c(this._defaultCredit)||(this._defaultCredit=on.clone(cyt())),this._currentCesiumCredit=this._defaultCredit;return}let e;t.showOnScreen?e=this._currentFrameCredits.screenCredits:e=this._currentFrameCredits.lightboxCredits,dyt(this,e,t)};xs.prototype.addStaticCredit=function(t){let e=this._staticCredits;fNe(e,t)||e.push(t)};xs.prototype.removeStaticCredit=function(t){let e=this._staticCredits,n=e.indexOf(t);n!==-1&&e.splice(n,1)};xs.prototype.showLightbox=function(){this._lightbox.style.display="block",this._expanded=!0};xs.prototype.hideLightbox=function(){this._lightbox.style.display="none",this._expanded=!1};xs.prototype.update=function(){this._expanded&&UNe(this)};xs.prototype.beginFrame=function(){let t=this._currentFrameCredits;this._creditDisplayElementPoolIndex=0;let e=t.screenCredits,n=t.lightboxCredits;e.removeAll(),n.removeAll();let i=this._staticCredits;for(let o=0;o<i.length;++o){let a=i[o],s=a.showOnScreen?e:n;a.isIon()&&on.equals(xs.cesiumCredit,this._cesiumCredit)||dyt(this,s,a,Number.MAX_VALUE)}on.equals(xs.cesiumCredit,this._cesiumCredit)||(this._cesiumCredit=on.clone(xs.cesiumCredit)),this._currentCesiumCredit=this._cesiumCredit};xs.prototype.endFrame=function(){let t=this._currentFrameCredits.screenCredits.values;ayt(this._screenContainer,t,this._delimiter,void 0);let e=this._currentFrameCredits.lightboxCredits.values;this._expandLink.style.display=e.length>0?"inline":"none",ayt(this._creditList,e,void 0,"li"),FNe(this)};xs.prototype.destroy=function(){return this._lightbox.removeEventListener("click",this._hideLightbox,!1),this.container.removeChild(this._cesiumCreditContainer),this.container.removeChild(this._screenContainer),this.container.removeChild(this._expandLink),this.viewport.removeChild(this._lightbox),At(this)};xs.prototype.isDestroyed=function(){return!1};xs._cesiumCredit=void 0;xs._cesiumCreditInitialized=!1;var qz;function cyt(){if(!c(qz)){let t=Dn("Assets/Images/ion-credit.png");t.indexOf("http://")!==0&&t.indexOf("https://")!==0&&t.indexOf("data:")!==0&&(t=new syt.default(t).path()),qz=new on(`<a href="https://cesium.com/" target="_blank"><img src="${t}" title="Cesium ion"/></a>`,!0)}return xs._cesiumCreditInitialized||(xs._cesiumCredit=qz,xs._cesiumCreditInitialized=!0),qz}Object.defineProperties(xs,{cesiumCredit:{get:function(){return cyt(),xs._cesiumCredit},set:function(t){xs._cesiumCredit=t,xs._cesiumCreditInitialized=!0}}});xs.CreditDisplayElement=lyt;var T_=xs;var ggo=b(W(),1);var PTo=b(W(),1);var $z=0,ANe=1;function uT(t){let e=t.frustum,n=t.orientation,i=t.origin,o=f(t.vertexFormat,ee.DEFAULT),a=f(t._drawNearPlane,!0),s,l;e instanceof Io?(s=$z,l=Io.packedLength):e instanceof wn&&(s=ANe,l=wn.packedLength),this._frustumType=s,this._frustum=e.clone(),this._origin=p.clone(i),this._orientation=wt.clone(n),this._drawNearPlane=a,this._vertexFormat=o,this._workerName="createFrustumGeometry",this.packedLength=2+l+p.packedLength+wt.packedLength+ee.packedLength}uT.pack=function(t,e,n){n=f(n,0);let i=t._frustumType,o=t._frustum;return e[n++]=i,i===$z?(Io.pack(o,e,n),n+=Io.packedLength):(wn.pack(o,e,n),n+=wn.packedLength),p.pack(t._origin,e,n),n+=p.packedLength,wt.pack(t._orientation,e,n),n+=wt.packedLength,ee.pack(t._vertexFormat,e,n),n+=ee.packedLength,e[n]=t._drawNearPlane?1:0,e};var SNe=new Io,TNe=new wn,gNe=new wt,ENe=new p,CNe=new ee;uT.unpack=function(t,e,n){e=f(e,0);let i=t[e++],o;i===$z?(o=Io.unpack(t,e,SNe),e+=Io.packedLength):(o=wn.unpack(t,e,TNe),e+=wn.packedLength);let a=p.unpack(t,e,ENe);e+=p.packedLength;let s=wt.unpack(t,e,gNe);e+=wt.packedLength;let l=ee.unpack(t,e,CNe);e+=ee.packedLength;let r=t[e]===1;if(!c(n))return new uT({frustum:o,origin:a,orientation:s,vertexFormat:l,_drawNearPlane:r});let d=i===n._frustumType?n._frustum:void 0;return n._frustum=o.clone(d),n._frustumType=i,n._origin=p.clone(a,n._origin),n._orientation=wt.clone(s,n._orientation),n._vertexFormat=ee.clone(l,n._vertexFormat),n._drawNearPlane=r,n};function J1(t,e,n,i,o,a,s,l){let r=t/3*2;for(let d=0;d<4;++d)c(e)&&(e[t]=a.x,e[t+1]=a.y,e[t+2]=a.z),c(n)&&(n[t]=s.x,n[t+1]=s.y,n[t+2]=s.z),c(i)&&(i[t]=l.x,i[t+1]=l.y,i[t+2]=l.z),t+=3;o[r]=0,o[r+1]=0,o[r+2]=1,o[r+3]=0,o[r+4]=1,o[r+5]=1,o[r+6]=0,o[r+7]=1}var INe=new ot,NNe=new L,uat=new L,myt=new p,hyt=new p,pyt=new p,yNe=new p,BNe=new p,QNe=new p,uU=new Array(3),g_=new Array(4);g_[0]=new bt(-1,-1,1,1);g_[1]=new bt(1,-1,1,1);g_[2]=new bt(1,1,1,1);g_[3]=new bt(-1,1,1,1);var Vyt=new Array(4);for(let t=0;t<4;++t)Vyt[t]=new bt;uT._computeNearFarPlanes=function(t,e,n,i,o,a,s,l){let r=ot.fromQuaternion(e,INe),d=f(a,myt),m=f(s,hyt),h=f(l,pyt);d=ot.getColumn(r,0,d),m=ot.getColumn(r,1,m),h=ot.getColumn(r,2,h),p.normalize(d,d),p.normalize(m,m),p.normalize(h,h),p.negate(d,d);let u=L.computeView(t,h,m,d,NNe),R,V,F=i.projectionMatrix;if(n===$z){let U=L.multiply(F,u,uat);V=L.inverse(U,uat)}else R=L.inverseTransformation(u,uat);c(V)?(uU[0]=i.near,uU[1]=i.far):(uU[0]=0,uU[1]=i.near,uU[2]=i.far);for(let U=0;U<2;++U)for(let G=0;G<4;++G){let A=bt.clone(g_[G],Vyt[G]);if(c(V)){A=L.multiplyByVector(V,A,A);let S=1/A.w;p.multiplyByScalar(A,S,A),p.subtract(A,t,A),p.normalize(A,A);let g=p.dot(h,A);p.multiplyByScalar(A,uU[U]/g,A),p.add(A,t,A)}else{let S=i.offCenterFrustum;c(S)&&(i=S);let g=uU[U],C=uU[U+1];A.x=(A.x*(i.right-i.left)+i.left+i.right)*.5,A.y=(A.y*(i.top-i.bottom)+i.bottom+i.top)*.5,A.z=(A.z*(g-C)-g-C)*.5,A.w=1,L.multiplyByVector(R,A,A)}o[12*U+G*3]=A.x,o[12*U+G*3+1]=A.y,o[12*U+G*3+2]=A.z}};uT.createGeometry=function(t){let e=t._frustumType,n=t._frustum,i=t._origin,o=t._orientation,a=t._drawNearPlane,s=t._vertexFormat,l=a?6:5,r=new Float64Array(3*4*6);uT._computeNearFarPlanes(i,o,e,n,r);let d=3*4*2;r[d]=r[3*4],r[d+1]=r[3*4+1],r[d+2]=r[3*4+2],r[d+3]=r[0],r[d+4]=r[1],r[d+5]=r[2],r[d+6]=r[3*3],r[d+7]=r[3*3+1],r[d+8]=r[3*3+2],r[d+9]=r[3*7],r[d+10]=r[3*7+1],r[d+11]=r[3*7+2],d+=3*4,r[d]=r[3*5],r[d+1]=r[3*5+1],r[d+2]=r[3*5+2],r[d+3]=r[3],r[d+4]=r[4],r[d+5]=r[5],r[d+6]=r[0],r[d+7]=r[1],r[d+8]=r[2],r[d+9]=r[3*4],r[d+10]=r[3*4+1],r[d+11]=r[3*4+2],d+=3*4,r[d]=r[3],r[d+1]=r[4],r[d+2]=r[5],r[d+3]=r[3*5],r[d+4]=r[3*5+1],r[d+5]=r[3*5+2],r[d+6]=r[3*6],r[d+7]=r[3*6+1],r[d+8]=r[3*6+2],r[d+9]=r[3*2],r[d+10]=r[3*2+1],r[d+11]=r[3*2+2],d+=3*4,r[d]=r[3*2],r[d+1]=r[3*2+1],r[d+2]=r[3*2+2],r[d+3]=r[3*6],r[d+4]=r[3*6+1],r[d+5]=r[3*6+2],r[d+6]=r[3*7],r[d+7]=r[3*7+1],r[d+8]=r[3*7+2],r[d+9]=r[3*3],r[d+10]=r[3*3+1],r[d+11]=r[3*3+2],a||(r=r.subarray(3*4));let m=new ei({position:new jt({componentDatatype:it.DOUBLE,componentsPerAttribute:3,values:r})});if(c(s.normal)||c(s.tangent)||c(s.bitangent)||c(s.st)){let u=c(s.normal)?new Float32Array(12*l):void 0,R=c(s.tangent)?new Float32Array(3*4*l):void 0,V=c(s.bitangent)?new Float32Array(3*4*l):void 0,F=c(s.st)?new Float32Array(2*4*l):void 0,U=myt,G=hyt,A=pyt,S=p.negate(U,yNe),g=p.negate(G,BNe),C=p.negate(A,QNe);d=0,a&&(J1(d,u,R,V,F,C,U,G),d+=3*4),J1(d,u,R,V,F,A,S,G),d+=3*4,J1(d,u,R,V,F,S,C,G),d+=3*4,J1(d,u,R,V,F,g,C,S),d+=3*4,J1(d,u,R,V,F,U,A,G),d+=3*4,J1(d,u,R,V,F,G,A,S),c(u)&&(m.normal=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:u})),c(R)&&(m.tangent=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:R})),c(V)&&(m.bitangent=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:V})),c(F)&&(m.st=new jt({componentDatatype:it.FLOAT,componentsPerAttribute:2,values:F}))}let h=new Uint16Array(6*l);for(let u=0;u<l;++u){let R=u*6,V=u*4;h[R]=V,h[R+1]=V+1,h[R+2]=V+2,h[R+3]=V,h[R+4]=V+2,h[R+5]=V+3}return new _e({attributes:m,indices:h,primitiveType:le.TRIANGLES,boundingSphere:Ft.fromVertices(r)})};var ZT=uT;var rgo=b(W(),1);var Zat=0,kNe=1;function E_(t){let e=t.frustum,n=t.orientation,i=t.origin,o=f(t._drawNearPlane,!0),a,s;e instanceof Io?(a=Zat,s=Io.packedLength):e instanceof wn&&(a=kNe,s=wn.packedLength),this._frustumType=a,this._frustum=e.clone(),this._origin=p.clone(i),this._orientation=wt.clone(n),this._drawNearPlane=o,this._workerName="createFrustumOutlineGeometry",this.packedLength=2+s+p.packedLength+wt.packedLength}E_.pack=function(t,e,n){n=f(n,0);let i=t._frustumType,o=t._frustum;return e[n++]=i,i===Zat?(Io.pack(o,e,n),n+=Io.packedLength):(wn.pack(o,e,n),n+=wn.packedLength),p.pack(t._origin,e,n),n+=p.packedLength,wt.pack(t._orientation,e,n),n+=wt.packedLength,e[n]=t._drawNearPlane?1:0,e};var YNe=new Io,xNe=new wn,XNe=new wt,JNe=new p;E_.unpack=function(t,e,n){e=f(e,0);let i=t[e++],o;i===Zat?(o=Io.unpack(t,e,YNe),e+=Io.packedLength):(o=wn.unpack(t,e,xNe),e+=wn.packedLength);let a=p.unpack(t,e,JNe);e+=p.packedLength;let s=wt.unpack(t,e,XNe);e+=wt.packedLength;let l=t[e]===1;if(!c(n))return new E_({frustum:o,origin:a,orientation:s,_drawNearPlane:l});let r=i===n._frustumType?n._frustum:void 0;return n._frustum=o.clone(r),n._frustumType=i,n._origin=p.clone(a,n._origin),n._orientation=wt.clone(s,n._orientation),n._drawNearPlane=l,n};E_.createGeometry=function(t){let e=t._frustumType,n=t._frustum,i=t._origin,o=t._orientation,a=t._drawNearPlane,s=new Float64Array(3*4*2);ZT._computeNearFarPlanes(i,o,e,n,s);let l=new ei({position:new jt({componentDatatype:it.DOUBLE,componentsPerAttribute:3,values:s})}),r,d,m=a?2:1,h=new Uint16Array(8*(m+1)),u=a?0:1;for(;u<2;++u)r=a?u*8:0,d=u*4,h[r]=d,h[r+1]=d+1,h[r+2]=d+1,h[r+3]=d+2,h[r+4]=d+2,h[r+5]=d+3,h[r+6]=d+3,h[r+7]=d;for(u=0;u<2;++u)r=(m+u)*8,d=u*4,h[r]=d,h[r+1]=d+4,h[r+2]=d+1,h[r+3]=d+5,h[r+4]=d+2,h[r+5]=d+6,h[r+6]=d+3,h[r+7]=d+7;return new _e({attributes:l,indices:h,primitiveType:le.LINES,boundingSphere:Ft.fromVertices(s)})};var C_=E_;function tj(t){t=f(t,f.EMPTY_OBJECT),this._camera=t.camera,this._frustumSplits=t.frustumSplits,this._color=f(t.color,v.CYAN),this._updateOnChange=f(t.updateOnChange,!0),this.show=f(t.show,!0),this.id=t.id,this._id=void 0,this._outlinePrimitives=[],this._planesPrimitives=[]}var LNe=new p,MNe=new ot,_Ne=new wt,DNe=new Io,ONe=new em,HNe=new wn,wNe=new el,PNe=new v,vNe=[1,1e5];tj.prototype.update=function(t){if(!this.show)return;let e=this._planesPrimitives,n=this._outlinePrimitives,i,o;if(this._updateOnChange){for(o=e.length,i=0;i<o;++i)n[i]=n[i]&&n[i].destroy(),e[i]=e[i]&&e[i].destroy();e.length=0,n.length=0}if(e.length===0){let a=this._camera,s=a.frustum,l;s instanceof Io?l=DNe:s instanceof em?l=ONe:s instanceof wn?l=HNe:l=wNe,l=s.clone(l);let r,d=this._frustumSplits;!c(d)||d.length<=1?(d=vNe,d[0]=this._camera.frustum.near,d[1]=this._camera.frustum.far,r=1):r=d.length-1;let m=a.positionWC,h=a.directionWC,u=a.upWC,R=a.rightWC;R=p.negate(R,LNe);let V=MNe;ot.setColumn(V,0,R,V),ot.setColumn(V,1,u,V),ot.setColumn(V,2,h,V);let F=wt.fromRotationMatrix(V,_Ne);for(e.length=n.length=r,i=0;i<r;++i)l.near=d[i],l.far=d[i+1],e[i]=new Wi({geometryInstances:new $e({geometry:new ZT({origin:m,orientation:F,frustum:l,_drawNearPlane:i===0}),attributes:{color:En.fromColor(v.fromAlpha(this._color,.1,PNe))},id:this.id,pickPrimitive:this}),appearance:new jn({translucent:!0,flat:!0}),asynchronous:!1}),n[i]=new Wi({geometryInstances:new $e({geometry:new C_({origin:m,orientation:F,frustum:l,_drawNearPlane:i===0}),attributes:{color:En.fromColor(this._color)},id:this.id,pickPrimitive:this}),appearance:new jn({translucent:!1,flat:!0}),asynchronous:!1})}for(o=e.length,i=0;i<o;++i)n[i].update(t),e[i].update(t)};tj.prototype.isDestroyed=function(){return!1};tj.prototype.destroy=function(){let t=this._planesPrimitives.length;for(let e=0;e<t;++e)this._outlinePrimitives[e]=this._outlinePrimitives[e]&&this._outlinePrimitives[e].destroy(),this._planesPrimitives[e]=this._planesPrimitives[e]&&this._planesPrimitives[e].destroy();return At(this)};var JR=tj;var tEo=b(W(),1);var Cgo=b(W(),1),I_=`in vec4 positionEC; void main() { @@ -10737,7 +10737,7 @@ void main() czm_writeLogDepth(); } -`;var Ngo=R(W(),1),N_=`in vec4 position; +`;var Ngo=b(W(),1),N_=`in vec4 position; out vec4 positionEC; @@ -10748,40 +10748,40 @@ void main() czm_vertexLogDepth(); } -`;function B_(t){this._rs=void 0,this._sp=void 0,this._va=void 0,this._command=void 0,this._mode=void 0,this._useLogDepth=!1,this._ellipsoidOffset=f(t,0)}var y_=In.supportsTypedArrays()?new Float32Array(12):[],Zyt=new p,Vyt=new p,bat=new p,byt=new p,ej=new p;function KNe(t,e){let n=t.radii,i=e.camera,o,a,s;if(i.frustum instanceof wn)o=p.ZERO,a=i.rightWC,s=i.upWC;else{let h=i.positionWC,Z=p.multiplyComponents(t.oneOverRadii,h,Zyt),b=p.normalize(Z,Vyt),u=p.normalize(p.cross(p.UNIT_Z,Z,bat),bat),F=p.normalize(p.cross(b,u,byt),byt),U=p.magnitude(Z),G=Math.sqrt(U*U-1);o=p.multiplyByScalar(b,1/U,Zyt);let A=G/U;a=p.multiplyByScalar(u,A,Vyt),s=p.multiplyByScalar(F,A,bat)}let l=p.add(o,s,ej);p.subtract(l,a,l),p.multiplyComponents(n,l,l),p.pack(l,y_,0);let r=p.subtract(o,s,ej);p.subtract(r,a,r),p.multiplyComponents(n,r,r),p.pack(r,y_,3);let d=p.add(o,s,ej);p.add(d,a,d),p.multiplyComponents(n,d,d),p.pack(d,y_,6);let m=p.subtract(o,s,ej);return p.add(m,a,m),p.multiplyComponents(n,m,m),p.pack(m,y_,9),y_}B_.prototype.update=function(t){if(this._mode=t.mode,t.mode!==ut.SCENE3D)return;let e=t.context,n=t.mapProjection.ellipsoid.radii,i=new mt(n.x+this._ellipsoidOffset,n.y+this._ellipsoidOffset,n.z+this._ellipsoidOffset),o=t.useLogDepth;if(c(this._command)||(this._rs=he.fromCache({cull:{enabled:!0},depthTest:{enabled:!0},colorMask:{red:!1,green:!1,blue:!1,alpha:!1}}),this._command=new Ee({renderState:this._rs,boundingVolume:new Ft(p.ZERO,i.maximumRadius),pass:Pt.OPAQUE,owner:this})),!c(this._sp)||this._useLogDepth!==o){this._useLogDepth=o;let s=new Ve({sources:[N_]}),l=new Ve({sources:[I_]});o&&(l.defines.push("LOG_DEPTH"),s.defines.push("LOG_DEPTH")),this._sp=xn.replaceCache({shaderProgram:this._sp,context:e,vertexShaderSource:s,fragmentShaderSource:l,attributeLocations:{position:0}}),this._command.shaderProgram=this._sp}let a=KNe(i,t);if(c(this._va))this._va.getAttribute(0).vertexBuffer.copyFromArrayView(a);else{let s=new _e({attributes:{position:new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:a})},indices:[0,1,2,2,1,3],primitiveType:le.TRIANGLES});this._va=Ki.fromGeometry({context:e,geometry:s,attributeLocations:{position:0},bufferUsage:ce.DYNAMIC_DRAW}),this._command.vertexArray=this._va}};B_.prototype.execute=function(t,e){this._mode===ut.SCENE3D&&this._command.execute(t,e)};B_.prototype.isDestroyed=function(){return!1};B_.prototype.destroy=function(){this._sp=this._sp&&this._sp.destroy(),this._va=this._va&&this._va.destroy()};var Q_=B_;var sEo=R(W(),1);function k_(){}var zNe=/\bgl_FragDepth\b/,jNe=/\bdiscard\b/;function qNe(t,e){let n=t.shaderCache.getDerivedShaderProgram(e,"depthOnly");if(!c(n)){let i=e._attributeLocations,o=e.fragmentShaderSource,a,s=!1,l=o.sources,r=l.length;for(a=0;a<r;++a)if(zNe.test(l[a])||jNe.test(l[a])){s=!0;break}let d=!1,m=o.defines;for(r=m.length,a=0;a<r;++a)if(m[a]==="LOG_DEPTH"){d=!0;break}let h;!s&&!d?(h=`void main() +`;function B_(t){this._rs=void 0,this._sp=void 0,this._va=void 0,this._command=void 0,this._mode=void 0,this._useLogDepth=!1,this._ellipsoidOffset=f(t,0)}var y_=In.supportsTypedArrays()?new Float32Array(12):[],uyt=new p,Zyt=new p,Rat=new p,Ryt=new p,ej=new p;function KNe(t,e){let n=t.radii,i=e.camera,o,a,s;if(i.frustum instanceof wn)o=p.ZERO,a=i.rightWC,s=i.upWC;else{let h=i.positionWC,u=p.multiplyComponents(t.oneOverRadii,h,uyt),R=p.normalize(u,Zyt),V=p.normalize(p.cross(p.UNIT_Z,u,Rat),Rat),F=p.normalize(p.cross(R,V,Ryt),Ryt),U=p.magnitude(u),G=Math.sqrt(U*U-1);o=p.multiplyByScalar(R,1/U,uyt);let A=G/U;a=p.multiplyByScalar(V,A,Zyt),s=p.multiplyByScalar(F,A,Rat)}let l=p.add(o,s,ej);p.subtract(l,a,l),p.multiplyComponents(n,l,l),p.pack(l,y_,0);let r=p.subtract(o,s,ej);p.subtract(r,a,r),p.multiplyComponents(n,r,r),p.pack(r,y_,3);let d=p.add(o,s,ej);p.add(d,a,d),p.multiplyComponents(n,d,d),p.pack(d,y_,6);let m=p.subtract(o,s,ej);return p.add(m,a,m),p.multiplyComponents(n,m,m),p.pack(m,y_,9),y_}B_.prototype.update=function(t){if(this._mode=t.mode,t.mode!==Vt.SCENE3D)return;let e=t.context,n=t.mapProjection.ellipsoid.radii,i=new mt(n.x+this._ellipsoidOffset,n.y+this._ellipsoidOffset,n.z+this._ellipsoidOffset),o=t.useLogDepth;if(c(this._command)||(this._rs=he.fromCache({cull:{enabled:!0},depthTest:{enabled:!0},colorMask:{red:!1,green:!1,blue:!1,alpha:!1}}),this._command=new Ee({renderState:this._rs,boundingVolume:new Ft(p.ZERO,i.maximumRadius),pass:Pt.OPAQUE,owner:this})),!c(this._sp)||this._useLogDepth!==o){this._useLogDepth=o;let s=new Ze({sources:[N_]}),l=new Ze({sources:[I_]});o&&(l.defines.push("LOG_DEPTH"),s.defines.push("LOG_DEPTH")),this._sp=xn.replaceCache({shaderProgram:this._sp,context:e,vertexShaderSource:s,fragmentShaderSource:l,attributeLocations:{position:0}}),this._command.shaderProgram=this._sp}let a=KNe(i,t);if(c(this._va))this._va.getAttribute(0).vertexBuffer.copyFromArrayView(a);else{let s=new _e({attributes:{position:new jt({componentDatatype:it.FLOAT,componentsPerAttribute:3,values:a})},indices:[0,1,2,2,1,3],primitiveType:le.TRIANGLES});this._va=Ki.fromGeometry({context:e,geometry:s,attributeLocations:{position:0},bufferUsage:ce.DYNAMIC_DRAW}),this._command.vertexArray=this._va}};B_.prototype.execute=function(t,e){this._mode===Vt.SCENE3D&&this._command.execute(t,e)};B_.prototype.isDestroyed=function(){return!1};B_.prototype.destroy=function(){this._sp=this._sp&&this._sp.destroy(),this._va=this._va&&this._va.destroy()};var Q_=B_;var sEo=b(W(),1);function k_(){}var zNe=/\bgl_FragDepth\b/,jNe=/\bdiscard\b/;function qNe(t,e){let n=t.shaderCache.getDerivedShaderProgram(e,"depthOnly");if(!c(n)){let i=e._attributeLocations,o=e.fragmentShaderSource,a,s=!1,l=o.sources,r=l.length;for(a=0;a<r;++a)if(zNe.test(l[a])||jNe.test(l[a])){s=!0;break}let d=!1,m=o.defines;for(r=m.length,a=0;a<r;++a)if(m[a]==="LOG_DEPTH"){d=!0;break}let h;!s&&!d?(h=`void main() { out_FragColor = vec4(1.0); } -`,o=new Ve({sources:[h]})):!s&&d&&(h=`void main() +`,o=new Ze({sources:[h]})):!s&&d&&(h=`void main() { out_FragColor = vec4(1.0); czm_writeLogDepth(); } -`,o=new Ve({defines:["LOG_DEPTH"],sources:[h]})),n=t.shaderCache.createDerivedShaderProgram(e,"depthOnly",{vertexShaderSource:e.vertexShaderSource,fragmentShaderSource:o,attributeLocations:i})}return n}function $Ne(t,e){let n=t._depthOnlyRenderStateCache,i=n[e.id];if(!c(i)){let o=he.getState(e);o.depthMask=!0,o.colorMask={red:!1,green:!1,blue:!1,alpha:!1},i=he.fromCache(o),n[e.id]=i}return i}k_.createDepthOnlyDerivedCommand=function(t,e,n,i){c(i)||(i={});let o,a;return c(i.depthOnlyCommand)&&(o=i.depthOnlyCommand.shaderProgram,a=i.depthOnlyCommand.renderState),i.depthOnlyCommand=Ee.shallowClone(e,i.depthOnlyCommand),!c(o)||i.shaderProgramId!==e.shaderProgram.id?(i.depthOnlyCommand.shaderProgram=qNe(n,e.shaderProgram),i.depthOnlyCommand.renderState=$Ne(t,e.renderState),i.shaderProgramId=e.shaderProgram.id):(i.depthOnlyCommand.shaderProgram=o,i.depthOnlyCommand.renderState=a),i};var tye=/\s+czm_writeLogDepth\(/,eye=/\s+czm_vertexLogDepth\(/;function nye(t,e){if(e.fragmentShaderSource.defines.indexOf("LOG_DEPTH_READ_ONLY")>=0)return e;let i=t.shaderCache.getDerivedShaderProgram(e,"logDepth");if(!c(i)){let o=e._attributeLocations,a=e.vertexShaderSource.clone(),s=e.fragmentShaderSource.clone();a.defines=c(a.defines)?a.defines.slice(0):[],a.defines.push("LOG_DEPTH"),s.defines=c(s.defines)?s.defines.slice(0):[],s.defines.push("LOG_DEPTH");let l,r,d=!1,m=a.sources,h=m.length;for(l=0;l<h;++l)if(eye.test(m[l])){d=!0;break}if(!d){for(l=0;l<h;++l)m[l]=Ve.replaceMain(m[l],"czm_log_depth_main");r=` +`,o=new Ze({defines:["LOG_DEPTH"],sources:[h]})),n=t.shaderCache.createDerivedShaderProgram(e,"depthOnly",{vertexShaderSource:e.vertexShaderSource,fragmentShaderSource:o,attributeLocations:i})}return n}function $Ne(t,e){let n=t._depthOnlyRenderStateCache,i=n[e.id];if(!c(i)){let o=he.getState(e);o.depthMask=!0,o.colorMask={red:!1,green:!1,blue:!1,alpha:!1},i=he.fromCache(o),n[e.id]=i}return i}k_.createDepthOnlyDerivedCommand=function(t,e,n,i){c(i)||(i={});let o,a;return c(i.depthOnlyCommand)&&(o=i.depthOnlyCommand.shaderProgram,a=i.depthOnlyCommand.renderState),i.depthOnlyCommand=Ee.shallowClone(e,i.depthOnlyCommand),!c(o)||i.shaderProgramId!==e.shaderProgram.id?(i.depthOnlyCommand.shaderProgram=qNe(n,e.shaderProgram),i.depthOnlyCommand.renderState=$Ne(t,e.renderState),i.shaderProgramId=e.shaderProgram.id):(i.depthOnlyCommand.shaderProgram=o,i.depthOnlyCommand.renderState=a),i};var tye=/\s+czm_writeLogDepth\(/,eye=/\s+czm_vertexLogDepth\(/;function nye(t,e){if(e.fragmentShaderSource.defines.indexOf("LOG_DEPTH_READ_ONLY")>=0)return e;let i=t.shaderCache.getDerivedShaderProgram(e,"logDepth");if(!c(i)){let o=e._attributeLocations,a=e.vertexShaderSource.clone(),s=e.fragmentShaderSource.clone();a.defines=c(a.defines)?a.defines.slice(0):[],a.defines.push("LOG_DEPTH"),s.defines=c(s.defines)?s.defines.slice(0):[],s.defines.push("LOG_DEPTH");let l,r,d=!1,m=a.sources,h=m.length;for(l=0;l<h;++l)if(eye.test(m[l])){d=!0;break}if(!d){for(l=0;l<h;++l)m[l]=Ze.replaceMain(m[l],"czm_log_depth_main");r=` void main() { czm_log_depth_main(); czm_vertexLogDepth(); } -`,m.push(r)}for(m=s.sources,h=m.length,d=!1,l=0;l<h;++l)tye.test(m[l])&&(d=!0);s.defines.indexOf("LOG_DEPTH_WRITE")!==-1&&(d=!0);let Z="";if(!d){for(l=0;l<h;l++)m[l]=Ve.replaceMain(m[l],"czm_log_depth_main");Z+=` +`,m.push(r)}for(m=s.sources,h=m.length,d=!1,l=0;l<h;++l)tye.test(m[l])&&(d=!0);s.defines.indexOf("LOG_DEPTH_WRITE")!==-1&&(d=!0);let u="";if(!d){for(l=0;l<h;l++)m[l]=Ze.replaceMain(m[l],"czm_log_depth_main");u+=` void main() { czm_log_depth_main(); czm_writeLogDepth(); } -`}m.push(Z),i=t.shaderCache.createDerivedShaderProgram(e,"logDepth",{vertexShaderSource:a,fragmentShaderSource:s,attributeLocations:o})}return i}k_.createLogDepthCommand=function(t,e,n){c(n)||(n={});let i;return c(n.command)&&(i=n.command.shaderProgram),n.command=Ee.shallowClone(t,n.command),!c(i)||n.shaderProgramId!==t.shaderProgram.id?(n.command.shaderProgram=nye(e,t.shaderProgram),n.shaderProgramId=t.shaderProgram.id):n.command.shaderProgram=i,n};function iye(t,e,n){let i=t.shaderCache.getDerivedShaderProgram(e,"pick");if(!c(i)){let o=e._attributeLocations,a=e.fragmentShaderSource,s=a.sources,l=s.length,d=s.some(Z=>Z.includes("out_FragData"))?"out_FragData_0":"out_FragColor",m=`void main () +`}m.push(u),i=t.shaderCache.createDerivedShaderProgram(e,"logDepth",{vertexShaderSource:a,fragmentShaderSource:s,attributeLocations:o})}return i}k_.createLogDepthCommand=function(t,e,n){c(n)||(n={});let i;return c(n.command)&&(i=n.command.shaderProgram),n.command=Ee.shallowClone(t,n.command),!c(i)||n.shaderProgramId!==t.shaderProgram.id?(n.command.shaderProgram=nye(e,t.shaderProgram),n.shaderProgramId=t.shaderProgram.id):n.command.shaderProgram=i,n};function iye(t,e,n){let i=t.shaderCache.getDerivedShaderProgram(e,"pick");if(!c(i)){let o=e._attributeLocations,a=e.fragmentShaderSource,s=a.sources,l=s.length,d=s.some(u=>u.includes("out_FragData"))?"out_FragData_0":"out_FragColor",m=`void main () { czm_non_pick_main(); if (${d}.a == 0.0) { discard; } ${d} = ${n}; -} `,h=new Array(l+1);for(let Z=0;Z<l;++Z)h[Z]=Ve.replaceMain(s[Z],"czm_non_pick_main");h[l]=m,a=new Ve({sources:h,defines:a.defines}),i=t.shaderCache.createDerivedShaderProgram(e,"pick",{vertexShaderSource:e.vertexShaderSource,fragmentShaderSource:a,attributeLocations:o})}return i}function oye(t,e){let n=t.picking.pickRenderStateCache,i=n[e.id];if(!c(i)){let o=he.getState(e);o.blending.enabled=!1,o.depthMask=!0,i=he.fromCache(o),n[e.id]=i}return i}k_.createPickDerivedCommand=function(t,e,n,i){c(i)||(i={});let o,a;return c(i.pickCommand)&&(o=i.pickCommand.shaderProgram,a=i.pickCommand.renderState),i.pickCommand=Ee.shallowClone(e,i.pickCommand),!c(o)||i.shaderProgramId!==e.shaderProgram.id?(i.pickCommand.shaderProgram=iye(n,e.shaderProgram,e.pickId),i.pickCommand.renderState=oye(t,e.renderState),i.shaderProgramId=e.shaderProgram.id):(i.pickCommand.shaderProgram=o,i.pickCommand.renderState=a),i};function aye(t,e){let n=t.shaderCache.getDerivedShaderProgram(e,"HDR");if(!c(n)){let i=e._attributeLocations,o=e.vertexShaderSource.clone(),a=e.fragmentShaderSource.clone();o.defines=c(o.defines)?o.defines.slice(0):[],o.defines.push("HDR"),a.defines=c(a.defines)?a.defines.slice(0):[],a.defines.push("HDR"),n=t.shaderCache.createDerivedShaderProgram(e,"HDR",{vertexShaderSource:o,fragmentShaderSource:a,attributeLocations:i})}return n}k_.createHdrCommand=function(t,e,n){c(n)||(n={});let i;return c(n.command)&&(i=n.command.shaderProgram),n.command=Ee.shallowClone(t,n.command),!c(i)||n.shaderProgramId!==t.shaderProgram.id?(n.command.shaderProgram=aye(e,t.shaderProgram),n.shaderProgramId=t.shaderProgram.id):n.command.shaderProgram=i,n};var VW=k_;var pEo=R(W(),1);function nj(t){this._scene=t,this._lastAlpha=void 0,this._lastBeta=void 0,this._lastGamma=void 0,this._alpha=void 0,this._beta=void 0,this._gamma=void 0;let e=this;function n(i){let o=i.alpha;if(!c(o)){e._alpha=void 0,e._beta=void 0,e._gamma=void 0;return}e._alpha=k.toRadians(o),e._beta=k.toRadians(i.beta),e._gamma=k.toRadians(i.gamma)}window.addEventListener("deviceorientation",n,!1),this._removeListener=function(){window.removeEventListener("deviceorientation",n,!1)}}var sye=new wt,Ryt=new wt,lye=new ot;function rye(t,e,n,i){let o=t.direction,a=t.right,s=t.up,l=wt.fromAxisAngle(o,n,Ryt),r=wt.fromAxisAngle(a,i,sye),d=wt.multiply(r,l,r),m=wt.fromAxisAngle(s,e,Ryt);wt.multiply(m,d,d);let h=ot.fromQuaternion(d,lye);ot.multiplyByVector(h,a,a),ot.multiplyByVector(h,s,s),ot.multiplyByVector(h,o,o)}nj.prototype.update=function(){if(!c(this._alpha))return;c(this._lastAlpha)||(this._lastAlpha=this._alpha,this._lastBeta=this._beta,this._lastGamma=this._gamma);let t=this._lastAlpha-this._alpha,e=this._lastBeta-this._beta,n=this._lastGamma-this._gamma;rye(this._scene.camera,-t,e,n),this._lastAlpha=this._alpha,this._lastBeta=this._beta,this._lastGamma=this._gamma};nj.prototype.isDestroyed=function(){return!1};nj.prototype.destroy=function(){return this._removeListener(),At(this)};var Y_=nj;var WEo=R(W(),1);function Wyt(){this.enabled=!0,this.renderable=!0,this.density=2e-4,this.screenSpaceErrorFactor=2,this.minimumBrightness=.03}var ij=[359.393,800.749,1275.6501,2151.1192,3141.7763,4777.5198,6281.2493,12364.307,15900.765,49889.0549,78026.8259,99260.7344,120036.3873,151011.0158,156091.1953,203849.3112,274866.9803,319916.3149,493552.0528,628733.5874],Lb=[2e-5,2e-4,1e-4,7e-5,5e-5,4e-5,3e-5,19e-6,1e-5,85e-7,62e-7,58e-7,53e-7,52e-7,51e-7,42e-7,4e-6,34e-7,26e-7,22e-7];for(let t=0;t<Lb.length;++t)Lb[t]*=1e6;var fyt=Lb[1],Rat=Lb[Lb.length-1];for(let t=0;t<Lb.length;++t)Lb[t]=(Lb[t]-Rat)/(fyt-Rat);var td=0;function dye(t){let e=ij,n=e.length;if(t<e[0])return td=0,td;if(t>e[n-1])return td=n-2,td;if(t>=e[td]){if(td+1<n&&t<e[td+1])return td;if(td+2<n&&t<e[td+2])return++td,td}else if(td-1>=0&&t>=e[td-1])return--td,td;let i;for(i=0;i<n-2&&!(t>=e[i]&&t<e[i+1]);++i);return td=i,td}var cye=new p;Wyt.prototype.update=function(t){if(!(t.fog.enabled=this.enabled))return;t.fog.renderable=this.renderable;let n=t.camera,i=n.positionCartographic;if(!c(i)||i.height>8e5||t.mode!==ut.SCENE3D){t.fog.enabled=!1,t.fog.density=0;return}let o=i.height,a=dye(o),s=k.clamp((o-ij[a])/(ij[a+1]-ij[a]),0,1),l=k.lerp(Lb[a],Lb[a+1],s),r=this.density*1e6,d=r/fyt*Rat;l=l*(r-d)*1e-6;let m=p.normalize(n.positionWC,cye),h=Math.abs(p.dot(n.directionWC,m));l*=1-h,t.fog.density=l,t.fog.sse=this.screenSpaceErrorFactor,t.fog.minimumBrightness=this.minimumBrightness};var x_=Wyt;var UEo=R(W(),1);function mye(t,e,n){this.context=t,this.commandList=[],this.shadowMaps=[],this.brdfLutGenerator=void 0,this.environmentMap=void 0,this.sphericalHarmonicCoefficients=void 0,this.specularEnvironmentMaps=void 0,this.specularEnvironmentMapsMaximumLOD=void 0,this.mode=ut.SCENE3D,this.morphTime=ut.getMorphTime(ut.SCENE3D),this.frameNumber=0,this.newFrame=!1,this.time=void 0,this.jobScheduler=n,this.mapProjection=void 0,this.camera=void 0,this.cameraUnderground=!1,this.globeTranslucencyState=void 0,this.cullingVolume=void 0,this.occluder=void 0,this.maximumScreenSpaceError=void 0,this.pixelRatio=1,this.passes={render:!1,pick:!1,pickVoxel:!1,depth:!1,postProcess:!1,offscreen:!1},this.creditDisplay=e,this.afterRender=[],this.scene3DOnly=!1,this.fog={enabled:!1,renderable:!1,density:void 0,sse:void 0,minimumBrightness:void 0},this.atmosphere=void 0,this.verticalExaggeration=1,this.verticalExaggerationRelativeHeight=0,this.shadowState={shadowsEnabled:!0,shadowMaps:[],lightShadowMaps:[],nearPlane:1,farPlane:5e3,closestObjectSize:1e3,lastDirtyTime:0,outOfView:!0},this.splitPosition=0,this.frustumSplits=[],this.backgroundColor=void 0,this.light=void 0,this.minimumDisableDepthTestDistance=void 0,this.invertClassification=!1,this.invertClassificationColor=void 0,this.useLogDepth=!1,this.tilesetPassState=void 0,this.minimumTerrainHeight=0}var X_=mye;var YEo=R(W(),1);var ed={OPAQUE_FRONT_FACE:0,OPAQUE_BACK_FACE:1,DEPTH_ONLY_FRONT_FACE:2,DEPTH_ONLY_BACK_FACE:3,DEPTH_ONLY_FRONT_AND_BACK_FACE:4,TRANSLUCENT_FRONT_FACE:5,TRANSLUCENT_BACK_FACE:6,TRANSLUCENT_FRONT_FACE_MANUAL_DEPTH_TEST:7,TRANSLUCENT_BACK_FACE_MANUAL_DEPTH_TEST:8,PICK_FRONT_FACE:9,PICK_BACK_FACE:10,DERIVED_COMMANDS_MAXIMUM_LENGTH:11},bS=ed.DERIVED_COMMANDS_MAXIMUM_LENGTH,Iyt=["opaqueFrontFaceCommand","opaqueBackFaceCommand","depthOnlyFrontFaceCommand","depthOnlyBackFaceCommand","depthOnlyFrontAndBackFaceCommand","translucentFrontFaceCommand","translucentBackFaceCommand","translucentFrontFaceManualDepthTestCommand","translucentBackFaceManualDepthTestCommand","pickFrontFaceCommand","pickBackFaceCommand"];function RS(){this._frontFaceAlphaByDistance=new ln(0,1,0,1),this._backFaceAlphaByDistance=new ln(0,1,0,1),this._frontFaceTranslucent=!1,this._backFaceTranslucent=!1,this._requiresManualDepthTest=!1,this._sunVisibleThroughGlobe=!1,this._environmentVisible=!1,this._useDepthPlane=!1,this._numberOfTextureUniforms=0,this._globeTranslucencyFramebuffer=void 0,this._rectangle=Gt.clone(Gt.MAX_VALUE),this._derivedCommandKey=0,this._derivedCommandsDirty=!1,this._derivedCommandPacks=void 0,this._derivedCommandTypes=new Array(bS),this._derivedBlendCommandTypes=new Array(bS),this._derivedPickCommandTypes=new Array(bS),this._derivedCommandTypesToUpdate=new Array(bS),this._derivedCommandsLength=0,this._derivedBlendCommandsLength=0,this._derivedPickCommandsLength=0,this._derivedCommandsToUpdateLength=0}Object.defineProperties(RS.prototype,{frontFaceAlphaByDistance:{get:function(){return this._frontFaceAlphaByDistance}},backFaceAlphaByDistance:{get:function(){return this._backFaceAlphaByDistance}},translucent:{get:function(){return this._frontFaceTranslucent}},sunVisibleThroughGlobe:{get:function(){return this._sunVisibleThroughGlobe}},environmentVisible:{get:function(){return this._environmentVisible}},useDepthPlane:{get:function(){return this._useDepthPlane}},numberOfTextureUniforms:{get:function(){return this._numberOfTextureUniforms}},rectangle:{get:function(){return this._rectangle}}});RS.prototype.update=function(t){let e=t.globe;if(!c(e)||!e.show){this._frontFaceTranslucent=!1,this._backFaceTranslucent=!1,this._sunVisibleThroughGlobe=!0,this._environmentVisible=!0,this._useDepthPlane=!1;return}this._frontFaceAlphaByDistance=Fyt(e.translucency.enabled,e.translucency.frontFaceAlpha,e.translucency.frontFaceAlphaByDistance,this._frontFaceAlphaByDistance),this._backFaceAlphaByDistance=Fyt(e.translucency.enabled,e.translucency.backFaceAlpha,e.translucency.backFaceAlphaByDistance,this._backFaceAlphaByDistance),this._frontFaceTranslucent=Uyt(e.translucency.enabled,this._frontFaceAlphaByDistance,e),this._backFaceTranslucent=Uyt(e.translucency.enabled,this._backFaceAlphaByDistance,e),this._requiresManualDepthTest=Zye(this,t,e),this._sunVisibleThroughGlobe=hye(this,t),this._environmentVisible=pye(this,t),this._useDepthPlane=uye(this,t),this._numberOfTextureUniforms=Vye(this),this._rectangle=Gt.clone(e.translucency.rectangle,this._rectangle),bye(this,t)};function Fyt(t,e,n,i){return t?c(n)?(ln.clone(n,i),i.nearValue*=e,i.farValue*=e,i):(i.nearValue=e,i.farValue=e,i):(i.nearValue=1,i.farValue=1,i)}function Uyt(t,e,n){return t&&(n.baseColor.alpha<1||e.nearValue<1||e.farValue<1)}function hye(t,e){let n=t._frontFaceTranslucent,i=t._backFaceTranslucent;return n&&(e.cameraUnderground||i)}function pye(t,e){return!e.cameraUnderground||t._frontFaceTranslucent}function uye(t,e){return!e.cameraUnderground&&!t._frontFaceTranslucent}function Zye(t,e,n){return t._frontFaceTranslucent&&!t._backFaceTranslucent&&!n.depthTestAgainstTerrain&&e.mode!==ut.SCENE2D&&e.context.depthTexture}function Vye(t){let e=0;return t._frontFaceTranslucent&&++e,t._requiresManualDepthTest&&++e,e}function bye(t,e){t._derivedCommandsLength=Wat(t,e,!1,!1,t._derivedCommandTypes),t._derivedBlendCommandsLength=Wat(t,e,!0,!1,t._derivedBlendCommandTypes),t._derivedPickCommandsLength=Wat(t,e,!1,!0,t._derivedPickCommandTypes);let n,i=0;for(n=0;n<t._derivedCommandsLength;++n)i|=1<<t._derivedCommandTypes[n];for(n=0;n<t._derivedBlendCommandsLength;++n)i|=1<<t._derivedBlendCommandTypes[n];for(n=0;n<t._derivedPickCommandsLength;++n)i|=1<<t._derivedPickCommandTypes[n];let o=0;for(n=0;n<bS;++n)(i&1<<n)>0&&(t._derivedCommandTypesToUpdate[o++]=n);t._derivedCommandsToUpdateLength=o;let a=i!==t._derivedCommandKey;t._derivedCommandKey=i,t._derivedCommandsDirty=a,!c(t._derivedCommandPacks)&&t._frontFaceTranslucent&&(t._derivedCommandPacks=yye())}function Wat(t,e,n,i,o){let a=0,s=t._frontFaceTranslucent,l=t._backFaceTranslucent;if(!s)return a;let r=e.cameraUnderground,d=t._requiresManualDepthTest,m=i?ed.PICK_FRONT_FACE:d?ed.TRANSLUCENT_FRONT_FACE_MANUAL_DEPTH_TEST:ed.TRANSLUCENT_FRONT_FACE,h=i?ed.PICK_BACK_FACE:d?ed.TRANSLUCENT_BACK_FACE_MANUAL_DEPTH_TEST:ed.TRANSLUCENT_BACK_FACE;return e.mode===ut.SCENE2D?(o[a++]=ed.DEPTH_ONLY_FRONT_FACE,o[a++]=m,a):(l?(n||(o[a++]=ed.DEPTH_ONLY_FRONT_AND_BACK_FACE),r?(o[a++]=m,o[a++]=h):(o[a++]=h,o[a++]=m)):r?(n||(o[a++]=ed.DEPTH_ONLY_BACK_FACE),o[a++]=ed.OPAQUE_FRONT_FACE,o[a++]=h):(n||(o[a++]=ed.DEPTH_ONLY_FRONT_FACE),o[a++]=ed.OPAQUE_BACK_FACE,o[a++]=m),a)}function Cu(t,e){let n=t.indexOf(e);n>-1&&t.splice(n,1)}function Gyt(t,e){return t.indexOf(e)>-1}function Rye(t,e){Cu(t.defines,"TRANSLUCENT"),Cu(e.defines,"TRANSLUCENT")}function Wye(t,e){Cu(t.defines,"GROUND_ATMOSPHERE"),Cu(e.defines,"GROUND_ATMOSPHERE"),Cu(t.defines,"FOG"),Cu(e.defines,"FOG"),Cu(t.defines,"TRANSLUCENT"),Cu(e.defines,"TRANSLUCENT")}function fat(t,e){if(Gyt(e.defines,"TILE_LIMIT_RECTANGLE")||Gyt(e.defines,"ENABLE_CLIPPING_PLANES"))return;let n=`void main() +} `,h=new Array(l+1);for(let u=0;u<l;++u)h[u]=Ze.replaceMain(s[u],"czm_non_pick_main");h[l]=m,a=new Ze({sources:h,defines:a.defines}),i=t.shaderCache.createDerivedShaderProgram(e,"pick",{vertexShaderSource:e.vertexShaderSource,fragmentShaderSource:a,attributeLocations:o})}return i}function oye(t,e){let n=t.picking.pickRenderStateCache,i=n[e.id];if(!c(i)){let o=he.getState(e);o.blending.enabled=!1,o.depthMask=!0,i=he.fromCache(o),n[e.id]=i}return i}k_.createPickDerivedCommand=function(t,e,n,i){c(i)||(i={});let o,a;return c(i.pickCommand)&&(o=i.pickCommand.shaderProgram,a=i.pickCommand.renderState),i.pickCommand=Ee.shallowClone(e,i.pickCommand),!c(o)||i.shaderProgramId!==e.shaderProgram.id?(i.pickCommand.shaderProgram=iye(n,e.shaderProgram,e.pickId),i.pickCommand.renderState=oye(t,e.renderState),i.shaderProgramId=e.shaderProgram.id):(i.pickCommand.shaderProgram=o,i.pickCommand.renderState=a),i};function aye(t,e){let n=t.shaderCache.getDerivedShaderProgram(e,"HDR");if(!c(n)){let i=e._attributeLocations,o=e.vertexShaderSource.clone(),a=e.fragmentShaderSource.clone();o.defines=c(o.defines)?o.defines.slice(0):[],o.defines.push("HDR"),a.defines=c(a.defines)?a.defines.slice(0):[],a.defines.push("HDR"),n=t.shaderCache.createDerivedShaderProgram(e,"HDR",{vertexShaderSource:o,fragmentShaderSource:a,attributeLocations:i})}return n}k_.createHdrCommand=function(t,e,n){c(n)||(n={});let i;return c(n.command)&&(i=n.command.shaderProgram),n.command=Ee.shallowClone(t,n.command),!c(i)||n.shaderProgramId!==t.shaderProgram.id?(n.command.shaderProgram=aye(e,t.shaderProgram),n.shaderProgramId=t.shaderProgram.id):n.command.shaderProgram=i,n};var ZW=k_;var pEo=b(W(),1);function nj(t){this._scene=t,this._lastAlpha=void 0,this._lastBeta=void 0,this._lastGamma=void 0,this._alpha=void 0,this._beta=void 0,this._gamma=void 0;let e=this;function n(i){let o=i.alpha;if(!c(o)){e._alpha=void 0,e._beta=void 0,e._gamma=void 0;return}e._alpha=k.toRadians(o),e._beta=k.toRadians(i.beta),e._gamma=k.toRadians(i.gamma)}window.addEventListener("deviceorientation",n,!1),this._removeListener=function(){window.removeEventListener("deviceorientation",n,!1)}}var sye=new wt,byt=new wt,lye=new ot;function rye(t,e,n,i){let o=t.direction,a=t.right,s=t.up,l=wt.fromAxisAngle(o,n,byt),r=wt.fromAxisAngle(a,i,sye),d=wt.multiply(r,l,r),m=wt.fromAxisAngle(s,e,byt);wt.multiply(m,d,d);let h=ot.fromQuaternion(d,lye);ot.multiplyByVector(h,a,a),ot.multiplyByVector(h,s,s),ot.multiplyByVector(h,o,o)}nj.prototype.update=function(){if(!c(this._alpha))return;c(this._lastAlpha)||(this._lastAlpha=this._alpha,this._lastBeta=this._beta,this._lastGamma=this._gamma);let t=this._lastAlpha-this._alpha,e=this._lastBeta-this._beta,n=this._lastGamma-this._gamma;rye(this._scene.camera,-t,e,n),this._lastAlpha=this._alpha,this._lastBeta=this._beta,this._lastGamma=this._gamma};nj.prototype.isDestroyed=function(){return!1};nj.prototype.destroy=function(){return this._removeListener(),At(this)};var Y_=nj;var WEo=b(W(),1);function Wyt(){this.enabled=!0,this.renderable=!0,this.density=2e-4,this.screenSpaceErrorFactor=2,this.minimumBrightness=.03}var ij=[359.393,800.749,1275.6501,2151.1192,3141.7763,4777.5198,6281.2493,12364.307,15900.765,49889.0549,78026.8259,99260.7344,120036.3873,151011.0158,156091.1953,203849.3112,274866.9803,319916.3149,493552.0528,628733.5874],LR=[2e-5,2e-4,1e-4,7e-5,5e-5,4e-5,3e-5,19e-6,1e-5,85e-7,62e-7,58e-7,53e-7,52e-7,51e-7,42e-7,4e-6,34e-7,26e-7,22e-7];for(let t=0;t<LR.length;++t)LR[t]*=1e6;var fyt=LR[1],bat=LR[LR.length-1];for(let t=0;t<LR.length;++t)LR[t]=(LR[t]-bat)/(fyt-bat);var td=0;function dye(t){let e=ij,n=e.length;if(t<e[0])return td=0,td;if(t>e[n-1])return td=n-2,td;if(t>=e[td]){if(td+1<n&&t<e[td+1])return td;if(td+2<n&&t<e[td+2])return++td,td}else if(td-1>=0&&t>=e[td-1])return--td,td;let i;for(i=0;i<n-2&&!(t>=e[i]&&t<e[i+1]);++i);return td=i,td}var cye=new p;Wyt.prototype.update=function(t){if(!(t.fog.enabled=this.enabled))return;t.fog.renderable=this.renderable;let n=t.camera,i=n.positionCartographic;if(!c(i)||i.height>8e5||t.mode!==Vt.SCENE3D){t.fog.enabled=!1,t.fog.density=0;return}let o=i.height,a=dye(o),s=k.clamp((o-ij[a])/(ij[a+1]-ij[a]),0,1),l=k.lerp(LR[a],LR[a+1],s),r=this.density*1e6,d=r/fyt*bat;l=l*(r-d)*1e-6;let m=p.normalize(n.positionWC,cye),h=Math.abs(p.dot(n.directionWC,m));l*=1-h,t.fog.density=l,t.fog.sse=this.screenSpaceErrorFactor,t.fog.minimumBrightness=this.minimumBrightness};var x_=Wyt;var UEo=b(W(),1);function mye(t,e,n){this.context=t,this.commandList=[],this.shadowMaps=[],this.brdfLutGenerator=void 0,this.environmentMap=void 0,this.sphericalHarmonicCoefficients=void 0,this.specularEnvironmentMaps=void 0,this.specularEnvironmentMapsMaximumLOD=void 0,this.mode=Vt.SCENE3D,this.morphTime=Vt.getMorphTime(Vt.SCENE3D),this.frameNumber=0,this.newFrame=!1,this.time=void 0,this.jobScheduler=n,this.mapProjection=void 0,this.camera=void 0,this.cameraUnderground=!1,this.globeTranslucencyState=void 0,this.cullingVolume=void 0,this.occluder=void 0,this.maximumScreenSpaceError=void 0,this.pixelRatio=1,this.passes={render:!1,pick:!1,pickVoxel:!1,depth:!1,postProcess:!1,offscreen:!1},this.creditDisplay=e,this.afterRender=[],this.scene3DOnly=!1,this.fog={enabled:!1,renderable:!1,density:void 0,sse:void 0,minimumBrightness:void 0},this.atmosphere=void 0,this.verticalExaggeration=1,this.verticalExaggerationRelativeHeight=0,this.shadowState={shadowsEnabled:!0,shadowMaps:[],lightShadowMaps:[],nearPlane:1,farPlane:5e3,closestObjectSize:1e3,lastDirtyTime:0,outOfView:!0},this.splitPosition=0,this.frustumSplits=[],this.backgroundColor=void 0,this.light=void 0,this.minimumDisableDepthTestDistance=void 0,this.invertClassification=!1,this.invertClassificationColor=void 0,this.useLogDepth=!1,this.tilesetPassState=void 0,this.minimumTerrainHeight=0}var X_=mye;var YEo=b(W(),1);var ed={OPAQUE_FRONT_FACE:0,OPAQUE_BACK_FACE:1,DEPTH_ONLY_FRONT_FACE:2,DEPTH_ONLY_BACK_FACE:3,DEPTH_ONLY_FRONT_AND_BACK_FACE:4,TRANSLUCENT_FRONT_FACE:5,TRANSLUCENT_BACK_FACE:6,TRANSLUCENT_FRONT_FACE_MANUAL_DEPTH_TEST:7,TRANSLUCENT_BACK_FACE_MANUAL_DEPTH_TEST:8,PICK_FRONT_FACE:9,PICK_BACK_FACE:10,DERIVED_COMMANDS_MAXIMUM_LENGTH:11},RT=ed.DERIVED_COMMANDS_MAXIMUM_LENGTH,Iyt=["opaqueFrontFaceCommand","opaqueBackFaceCommand","depthOnlyFrontFaceCommand","depthOnlyBackFaceCommand","depthOnlyFrontAndBackFaceCommand","translucentFrontFaceCommand","translucentBackFaceCommand","translucentFrontFaceManualDepthTestCommand","translucentBackFaceManualDepthTestCommand","pickFrontFaceCommand","pickBackFaceCommand"];function bT(){this._frontFaceAlphaByDistance=new ln(0,1,0,1),this._backFaceAlphaByDistance=new ln(0,1,0,1),this._frontFaceTranslucent=!1,this._backFaceTranslucent=!1,this._requiresManualDepthTest=!1,this._sunVisibleThroughGlobe=!1,this._environmentVisible=!1,this._useDepthPlane=!1,this._numberOfTextureUniforms=0,this._globeTranslucencyFramebuffer=void 0,this._rectangle=Gt.clone(Gt.MAX_VALUE),this._derivedCommandKey=0,this._derivedCommandsDirty=!1,this._derivedCommandPacks=void 0,this._derivedCommandTypes=new Array(RT),this._derivedBlendCommandTypes=new Array(RT),this._derivedPickCommandTypes=new Array(RT),this._derivedCommandTypesToUpdate=new Array(RT),this._derivedCommandsLength=0,this._derivedBlendCommandsLength=0,this._derivedPickCommandsLength=0,this._derivedCommandsToUpdateLength=0}Object.defineProperties(bT.prototype,{frontFaceAlphaByDistance:{get:function(){return this._frontFaceAlphaByDistance}},backFaceAlphaByDistance:{get:function(){return this._backFaceAlphaByDistance}},translucent:{get:function(){return this._frontFaceTranslucent}},sunVisibleThroughGlobe:{get:function(){return this._sunVisibleThroughGlobe}},environmentVisible:{get:function(){return this._environmentVisible}},useDepthPlane:{get:function(){return this._useDepthPlane}},numberOfTextureUniforms:{get:function(){return this._numberOfTextureUniforms}},rectangle:{get:function(){return this._rectangle}}});bT.prototype.update=function(t){let e=t.globe;if(!c(e)||!e.show){this._frontFaceTranslucent=!1,this._backFaceTranslucent=!1,this._sunVisibleThroughGlobe=!0,this._environmentVisible=!0,this._useDepthPlane=!1;return}this._frontFaceAlphaByDistance=Fyt(e.translucency.enabled,e.translucency.frontFaceAlpha,e.translucency.frontFaceAlphaByDistance,this._frontFaceAlphaByDistance),this._backFaceAlphaByDistance=Fyt(e.translucency.enabled,e.translucency.backFaceAlpha,e.translucency.backFaceAlphaByDistance,this._backFaceAlphaByDistance),this._frontFaceTranslucent=Uyt(e.translucency.enabled,this._frontFaceAlphaByDistance,e),this._backFaceTranslucent=Uyt(e.translucency.enabled,this._backFaceAlphaByDistance,e),this._requiresManualDepthTest=uye(this,t,e),this._sunVisibleThroughGlobe=hye(this,t),this._environmentVisible=pye(this,t),this._useDepthPlane=Vye(this,t),this._numberOfTextureUniforms=Zye(this),this._rectangle=Gt.clone(e.translucency.rectangle,this._rectangle),Rye(this,t)};function Fyt(t,e,n,i){return t?c(n)?(ln.clone(n,i),i.nearValue*=e,i.farValue*=e,i):(i.nearValue=e,i.farValue=e,i):(i.nearValue=1,i.farValue=1,i)}function Uyt(t,e,n){return t&&(n.baseColor.alpha<1||e.nearValue<1||e.farValue<1)}function hye(t,e){let n=t._frontFaceTranslucent,i=t._backFaceTranslucent;return n&&(e.cameraUnderground||i)}function pye(t,e){return!e.cameraUnderground||t._frontFaceTranslucent}function Vye(t,e){return!e.cameraUnderground&&!t._frontFaceTranslucent}function uye(t,e,n){return t._frontFaceTranslucent&&!t._backFaceTranslucent&&!n.depthTestAgainstTerrain&&e.mode!==Vt.SCENE2D&&e.context.depthTexture}function Zye(t){let e=0;return t._frontFaceTranslucent&&++e,t._requiresManualDepthTest&&++e,e}function Rye(t,e){t._derivedCommandsLength=Wat(t,e,!1,!1,t._derivedCommandTypes),t._derivedBlendCommandsLength=Wat(t,e,!0,!1,t._derivedBlendCommandTypes),t._derivedPickCommandsLength=Wat(t,e,!1,!0,t._derivedPickCommandTypes);let n,i=0;for(n=0;n<t._derivedCommandsLength;++n)i|=1<<t._derivedCommandTypes[n];for(n=0;n<t._derivedBlendCommandsLength;++n)i|=1<<t._derivedBlendCommandTypes[n];for(n=0;n<t._derivedPickCommandsLength;++n)i|=1<<t._derivedPickCommandTypes[n];let o=0;for(n=0;n<RT;++n)(i&1<<n)>0&&(t._derivedCommandTypesToUpdate[o++]=n);t._derivedCommandsToUpdateLength=o;let a=i!==t._derivedCommandKey;t._derivedCommandKey=i,t._derivedCommandsDirty=a,!c(t._derivedCommandPacks)&&t._frontFaceTranslucent&&(t._derivedCommandPacks=yye())}function Wat(t,e,n,i,o){let a=0,s=t._frontFaceTranslucent,l=t._backFaceTranslucent;if(!s)return a;let r=e.cameraUnderground,d=t._requiresManualDepthTest,m=i?ed.PICK_FRONT_FACE:d?ed.TRANSLUCENT_FRONT_FACE_MANUAL_DEPTH_TEST:ed.TRANSLUCENT_FRONT_FACE,h=i?ed.PICK_BACK_FACE:d?ed.TRANSLUCENT_BACK_FACE_MANUAL_DEPTH_TEST:ed.TRANSLUCENT_BACK_FACE;return e.mode===Vt.SCENE2D?(o[a++]=ed.DEPTH_ONLY_FRONT_FACE,o[a++]=m,a):(l?(n||(o[a++]=ed.DEPTH_ONLY_FRONT_AND_BACK_FACE),r?(o[a++]=m,o[a++]=h):(o[a++]=h,o[a++]=m)):r?(n||(o[a++]=ed.DEPTH_ONLY_BACK_FACE),o[a++]=ed.OPAQUE_FRONT_FACE,o[a++]=h):(n||(o[a++]=ed.DEPTH_ONLY_FRONT_FACE),o[a++]=ed.OPAQUE_BACK_FACE,o[a++]=m),a)}function CV(t,e){let n=t.indexOf(e);n>-1&&t.splice(n,1)}function Gyt(t,e){return t.indexOf(e)>-1}function bye(t,e){CV(t.defines,"TRANSLUCENT"),CV(e.defines,"TRANSLUCENT")}function Wye(t,e){CV(t.defines,"GROUND_ATMOSPHERE"),CV(e.defines,"GROUND_ATMOSPHERE"),CV(t.defines,"FOG"),CV(e.defines,"FOG"),CV(t.defines,"TRANSLUCENT"),CV(e.defines,"TRANSLUCENT")}function fat(t,e){if(Gyt(e.defines,"TILE_LIMIT_RECTANGLE")||Gyt(e.defines,"ENABLE_CLIPPING_PLANES"))return;let n=`void main() { out_FragColor = vec4(1.0); } -`;e.sources=[n]}function Fat(t,e){let n=e.sources,i=n.length;for(let a=0;a<i;++a)n[a]=Ve.replaceMain(n[a],"czm_globe_translucency_main");n.push(` +`;e.sources=[n]}function Fat(t,e){let n=e.sources,i=n.length;for(let a=0;a<i;++a)n[a]=Ze.replaceMain(n[a],"czm_globe_translucency_main");n.push(` uniform sampler2D u_classificationTexture; void main() @@ -10808,7 +10808,7 @@ void main() } out_FragColor = classificationColor * vec4(classificationColor.aaa, 1.0) + out_FragColor * (1.0 - classificationColor.a); } -`)}function Nyt(t,e){Fat(t,e),Cu(t.defines,"GROUND_ATMOSPHERE"),Cu(e.defines,"GROUND_ATMOSPHERE"),Cu(t.defines,"FOG"),Cu(e.defines,"FOG")}function fye(t,e){Fat(t,e),t.defines.push("GENERATE_POSITION"),e.defines.push("MANUAL_DEPTH_TEST")}function Fye(t,e){Nyt(t,e),t.defines.push("GENERATE_POSITION"),e.defines.push("MANUAL_DEPTH_TEST")}function Ayt(t,e){let n=`uniform sampler2D u_classificationTexture; +`)}function Nyt(t,e){Fat(t,e),CV(t.defines,"GROUND_ATMOSPHERE"),CV(e.defines,"GROUND_ATMOSPHERE"),CV(t.defines,"FOG"),CV(e.defines,"FOG")}function fye(t,e){Fat(t,e),t.defines.push("GENERATE_POSITION"),e.defines.push("MANUAL_DEPTH_TEST")}function Fye(t,e){Nyt(t,e),t.defines.push("GENERATE_POSITION"),e.defines.push("MANUAL_DEPTH_TEST")}function Ayt(t,e){let n=`uniform sampler2D u_classificationTexture; void main() { vec2 st = gl_FragCoord.xy / czm_viewport.zw; @@ -10819,7 +10819,7 @@ void main() } out_FragColor = pickColor; } -`;e.sources=[n]}function Uye(t,e,n,i,o,a){if(!c(o))return e;if(!i&&c(n))return n;let s=t.shaderCache.getDerivedShaderProgram(e,a);if(!c(s)){let l=e._attributeLocations,r=e.vertexShaderSource.clone(),d=e.fragmentShaderSource.clone();r.defines=c(r.defines)?r.defines.slice(0):[],d.defines=c(d.defines)?d.defines.slice(0):[],o(r,d),s=t.shaderCache.createDerivedShaderProgram(e,a,{vertexShaderSource:r,fragmentShaderSource:d,attributeLocations:l})}return s}function Gye(t){t.cull.face=so.BACK,t.cull.enabled=!0}function Aye(t){t.cull.face=so.FRONT,t.cull.enabled=!0}function Tye(t){t.cull.face=so.BACK,t.cull.enabled=!0,t.colorMask={red:!1,green:!1,blue:!1,alpha:!1}}function Sye(t){t.cull.face=so.FRONT,t.cull.enabled=!0,t.colorMask={red:!1,green:!1,blue:!1,alpha:!1}}function gye(t){t.cull.enabled=!1,t.colorMask={red:!1,green:!1,blue:!1,alpha:!1}}function Tyt(t){t.cull.face=so.BACK,t.cull.enabled=!0,t.depthMask=!1,t.blending=Pn.ALPHA_BLEND}function Syt(t){t.cull.face=so.FRONT,t.cull.enabled=!0,t.depthMask=!1,t.blending=Pn.ALPHA_BLEND}function Eye(t){t.cull.face=so.BACK,t.cull.enabled=!0,t.blending.enabled=!1}function Cye(t){t.cull.face=so.FRONT,t.cull.enabled=!0,t.blending.enabled=!1}function Iye(t,e,n,i,o){if(!c(i))return t;if(!n&&c(e))return e;let a=o[t.id];if(!c(a)){let s=he.getState(t);i(s),a=he.fromCache(s),o[t.id]=a}return a}function L1(t){return{u_classificationTexture:function(){return t._globeTranslucencyFramebuffer.classificationTexture}}}function Nye(t,e,n,i,o){return c(o)?!i&&c(n)?n:ze(e,o(t),!1):e}function rV(t){this.pass=t.pass,this.pickOnly=t.pickOnly,this.getShaderProgramFunction=t.getShaderProgramFunction,this.getRenderStateFunction=t.getRenderStateFunction,this.getUniformMapFunction=t.getUniformMapFunction,this.renderStateCache={}}function yye(){return[new rV({pass:Pt.GLOBE,pickOnly:!1,getShaderProgramFunction:Rye,getRenderStateFunction:Gye,getUniformMapFunction:void 0}),new rV({pass:Pt.GLOBE,pickOnly:!1,getShaderProgramFunction:Wye,getRenderStateFunction:Aye,getUniformMapFunction:void 0}),new rV({pass:Pt.GLOBE,pickOnly:!1,getShaderProgramFunction:fat,getRenderStateFunction:Tye,getUniformMapFunction:void 0}),new rV({pass:Pt.GLOBE,pickOnly:!1,getShaderProgramFunction:fat,getRenderStateFunction:Sye,getUniformMapFunction:void 0}),new rV({pass:Pt.GLOBE,pickOnly:!1,getShaderProgramFunction:fat,getRenderStateFunction:gye,getUniformMapFunction:void 0}),new rV({pass:Pt.TRANSLUCENT,pickOnly:!1,getShaderProgramFunction:Fat,getRenderStateFunction:Tyt,getUniformMapFunction:L1}),new rV({pass:Pt.TRANSLUCENT,pickOnly:!1,getShaderProgramFunction:Nyt,getRenderStateFunction:Syt,getUniformMapFunction:L1}),new rV({pass:Pt.TRANSLUCENT,pickOnly:!1,getShaderProgramFunction:fye,getRenderStateFunction:Tyt,getUniformMapFunction:L1}),new rV({pass:Pt.TRANSLUCENT,pickOnly:!1,getShaderProgramFunction:Fye,getRenderStateFunction:Syt,getUniformMapFunction:L1}),new rV({pass:Pt.TRANSLUCENT,pickOnly:!0,getShaderProgramFunction:Ayt,getRenderStateFunction:Eye,getUniformMapFunction:L1}),new rV({pass:Pt.TRANSLUCENT,pickOnly:!0,getShaderProgramFunction:Ayt,getRenderStateFunction:Cye,getUniformMapFunction:L1})]}var gyt=new Array(bS),Eyt=new Array(bS);RS.prototype.updateDerivedCommands=function(t,e){let n=this._derivedCommandTypesToUpdate,i=this._derivedCommandsToUpdateLength;if(i!==0){for(let o=0;o<i;++o)Eyt[o]=this._derivedCommandPacks[n[o]],gyt[o]=Iyt[n[o]];Bye(this,t,i,n,gyt,Eyt,e)}};function Bye(t,e,n,i,o,a,s){let l=e.derivedCommands.globeTranslucency,r=t._derivedCommandsDirty;if(e.dirty||!c(l)||r){e.dirty=!1,c(l)||(l={},e.derivedCommands.globeTranslucency=l);let d=s.frameNumber,m=f(l.uniformMapDirtyFrame,0),h=f(l.shaderProgramDirtyFrame,0),Z=f(l.renderStateDirtyFrame,0),b=l.uniformMap!==e.uniformMap,u=l.shaderProgramId!==e.shaderProgram.id,F=l.renderStateId!==e.renderState.id;b&&(l.uniformMapDirtyFrame=d),u&&(l.shaderProgramDirtyFrame=d),F&&(l.renderStateDirtyFrame=d),l.uniformMap=e.uniformMap,l.shaderProgramId=e.shaderProgram.id,l.renderStateId=e.renderState.id;for(let U=0;U<n;++U){let G=a[U],A=i[U],T=o[U],g=l[T],C,y,Y;c(g)?(C=g.uniformMap,y=g.shaderProgram,Y=g.renderState):(C=void 0,y=void 0,Y=void 0),g=Ee.shallowClone(e,g),l[T]=g;let Q=f(g.derivedCommands.uniformMapDirtyFrame,0),J=f(g.derivedCommands.shaderProgramDirtyFrame,0),M=f(g.derivedCommands.renderStateDirtyFrame,0),V=b||Q<m,E=u||J<h,I=F||M<Z;V&&(g.derivedCommands.uniformMapDirtyFrame=d),E&&(g.derivedCommands.shaderProgramDirtyFrame=d),I&&(g.derivedCommands.renderStateDirtyFrame=d),g.derivedCommands.type=A,g.pass=G.pass,g.pickOnly=G.pickOnly,g.uniformMap=Nye(t,e.uniformMap,C,V,G.getUniformMapFunction),g.shaderProgram=Uye(s.context,e.shaderProgram,y,E,G.getShaderProgramFunction,T),g.renderState=Iye(e.renderState,Y,I,G.getRenderStateFunction,G.renderStateCache)}}}RS.prototype.pushDerivedCommands=function(t,e,n){let i=n.passes.pick||n.passes.pickVoxel;if(i&&e)return;let o=this._derivedCommandTypes,a=this._derivedCommandsLength;if(i?(o=this._derivedPickCommandTypes,a=this._derivedPickCommandsLength):e&&(o=this._derivedBlendCommandTypes,a=this._derivedBlendCommandsLength),a===0){n.commandList.push(t);return}let s=t.derivedCommands.globeTranslucency;for(let l=0;l<a;++l){let r=Iyt[o[l]];n.commandList.push(s[r])}};function yyt(t,e,n,i,o,a,s){for(let l=0;l<e;++l){let r=t[l],d=r.derivedCommands.type;(!c(s)||s.indexOf(d)>-1)&&n(r,i,o,a)}}function Cyt(t,e,n,i,o,a){for(let s=0;s<e;++s)n(t[s],i,o,a)}var Qye=[ed.OPAQUE_FRONT_FACE,ed.OPAQUE_BACK_FACE],kye=[ed.DEPTH_ONLY_FRONT_FACE,ed.DEPTH_ONLY_BACK_FACE,ed.DEPTH_ONLY_FRONT_AND_BACK_FACE];RS.prototype.executeGlobeCommands=function(t,e,n,i,o){let a=i.context,s=t.commands[Pt.GLOBE],l=t.indices[Pt.GLOBE];l!==0&&(this._globeTranslucencyFramebuffer=n,n.clearClassification(a,o),yyt(s,l,e,i,a,o,Qye))};RS.prototype.executeGlobeClassificationCommands=function(t,e,n,i,o){let a=i.context,s=t.commands[Pt.GLOBE],l=t.indices[Pt.GLOBE],r=t.commands[Pt.TERRAIN_CLASSIFICATION],d=t.indices[Pt.TERRAIN_CLASSIFICATION];if(l===0||d===0)return;let m=this._frontFaceTranslucent,h=this._backFaceTranslucent;if((!m||!h)&&Cyt(r,d,e,i,a,o),!m&&!h)return;this._globeTranslucencyFramebuffer=n;let Z=a.uniformState.globeDepthTexture,b=o.framebuffer;if(o.framebuffer=n.classificationFramebuffer,yyt(s,l,e,i,a,o,kye),a.depthTexture){let u=n.packDepth(a,o);a.uniformState.globeDepthTexture=u}Cyt(r,d,e,i,a,o),a.uniformState.globeDepthTexture=Z,o.framebuffer=b};var J_=RS;var iCo=R(W(),1);var XEo=R(W(),1),nh=`uniform sampler2D colorTexture; +`;e.sources=[n]}function Uye(t,e,n,i,o,a){if(!c(o))return e;if(!i&&c(n))return n;let s=t.shaderCache.getDerivedShaderProgram(e,a);if(!c(s)){let l=e._attributeLocations,r=e.vertexShaderSource.clone(),d=e.fragmentShaderSource.clone();r.defines=c(r.defines)?r.defines.slice(0):[],d.defines=c(d.defines)?d.defines.slice(0):[],o(r,d),s=t.shaderCache.createDerivedShaderProgram(e,a,{vertexShaderSource:r,fragmentShaderSource:d,attributeLocations:l})}return s}function Gye(t){t.cull.face=so.BACK,t.cull.enabled=!0}function Aye(t){t.cull.face=so.FRONT,t.cull.enabled=!0}function Sye(t){t.cull.face=so.BACK,t.cull.enabled=!0,t.colorMask={red:!1,green:!1,blue:!1,alpha:!1}}function Tye(t){t.cull.face=so.FRONT,t.cull.enabled=!0,t.colorMask={red:!1,green:!1,blue:!1,alpha:!1}}function gye(t){t.cull.enabled=!1,t.colorMask={red:!1,green:!1,blue:!1,alpha:!1}}function Syt(t){t.cull.face=so.BACK,t.cull.enabled=!0,t.depthMask=!1,t.blending=Pn.ALPHA_BLEND}function Tyt(t){t.cull.face=so.FRONT,t.cull.enabled=!0,t.depthMask=!1,t.blending=Pn.ALPHA_BLEND}function Eye(t){t.cull.face=so.BACK,t.cull.enabled=!0,t.blending.enabled=!1}function Cye(t){t.cull.face=so.FRONT,t.cull.enabled=!0,t.blending.enabled=!1}function Iye(t,e,n,i,o){if(!c(i))return t;if(!n&&c(e))return e;let a=o[t.id];if(!c(a)){let s=he.getState(t);i(s),a=he.fromCache(s),o[t.id]=a}return a}function L1(t){return{u_classificationTexture:function(){return t._globeTranslucencyFramebuffer.classificationTexture}}}function Nye(t,e,n,i,o){return c(o)?!i&&c(n)?n:ze(e,o(t),!1):e}function rZ(t){this.pass=t.pass,this.pickOnly=t.pickOnly,this.getShaderProgramFunction=t.getShaderProgramFunction,this.getRenderStateFunction=t.getRenderStateFunction,this.getUniformMapFunction=t.getUniformMapFunction,this.renderStateCache={}}function yye(){return[new rZ({pass:Pt.GLOBE,pickOnly:!1,getShaderProgramFunction:bye,getRenderStateFunction:Gye,getUniformMapFunction:void 0}),new rZ({pass:Pt.GLOBE,pickOnly:!1,getShaderProgramFunction:Wye,getRenderStateFunction:Aye,getUniformMapFunction:void 0}),new rZ({pass:Pt.GLOBE,pickOnly:!1,getShaderProgramFunction:fat,getRenderStateFunction:Sye,getUniformMapFunction:void 0}),new rZ({pass:Pt.GLOBE,pickOnly:!1,getShaderProgramFunction:fat,getRenderStateFunction:Tye,getUniformMapFunction:void 0}),new rZ({pass:Pt.GLOBE,pickOnly:!1,getShaderProgramFunction:fat,getRenderStateFunction:gye,getUniformMapFunction:void 0}),new rZ({pass:Pt.TRANSLUCENT,pickOnly:!1,getShaderProgramFunction:Fat,getRenderStateFunction:Syt,getUniformMapFunction:L1}),new rZ({pass:Pt.TRANSLUCENT,pickOnly:!1,getShaderProgramFunction:Nyt,getRenderStateFunction:Tyt,getUniformMapFunction:L1}),new rZ({pass:Pt.TRANSLUCENT,pickOnly:!1,getShaderProgramFunction:fye,getRenderStateFunction:Syt,getUniformMapFunction:L1}),new rZ({pass:Pt.TRANSLUCENT,pickOnly:!1,getShaderProgramFunction:Fye,getRenderStateFunction:Tyt,getUniformMapFunction:L1}),new rZ({pass:Pt.TRANSLUCENT,pickOnly:!0,getShaderProgramFunction:Ayt,getRenderStateFunction:Eye,getUniformMapFunction:L1}),new rZ({pass:Pt.TRANSLUCENT,pickOnly:!0,getShaderProgramFunction:Ayt,getRenderStateFunction:Cye,getUniformMapFunction:L1})]}var gyt=new Array(RT),Eyt=new Array(RT);bT.prototype.updateDerivedCommands=function(t,e){let n=this._derivedCommandTypesToUpdate,i=this._derivedCommandsToUpdateLength;if(i!==0){for(let o=0;o<i;++o)Eyt[o]=this._derivedCommandPacks[n[o]],gyt[o]=Iyt[n[o]];Bye(this,t,i,n,gyt,Eyt,e)}};function Bye(t,e,n,i,o,a,s){let l=e.derivedCommands.globeTranslucency,r=t._derivedCommandsDirty;if(e.dirty||!c(l)||r){e.dirty=!1,c(l)||(l={},e.derivedCommands.globeTranslucency=l);let d=s.frameNumber,m=f(l.uniformMapDirtyFrame,0),h=f(l.shaderProgramDirtyFrame,0),u=f(l.renderStateDirtyFrame,0),R=l.uniformMap!==e.uniformMap,V=l.shaderProgramId!==e.shaderProgram.id,F=l.renderStateId!==e.renderState.id;R&&(l.uniformMapDirtyFrame=d),V&&(l.shaderProgramDirtyFrame=d),F&&(l.renderStateDirtyFrame=d),l.uniformMap=e.uniformMap,l.shaderProgramId=e.shaderProgram.id,l.renderStateId=e.renderState.id;for(let U=0;U<n;++U){let G=a[U],A=i[U],S=o[U],g=l[S],C,y,Y;c(g)?(C=g.uniformMap,y=g.shaderProgram,Y=g.renderState):(C=void 0,y=void 0,Y=void 0),g=Ee.shallowClone(e,g),l[S]=g;let Q=f(g.derivedCommands.uniformMapDirtyFrame,0),J=f(g.derivedCommands.shaderProgramDirtyFrame,0),M=f(g.derivedCommands.renderStateDirtyFrame,0),Z=R||Q<m,E=V||J<h,I=F||M<u;Z&&(g.derivedCommands.uniformMapDirtyFrame=d),E&&(g.derivedCommands.shaderProgramDirtyFrame=d),I&&(g.derivedCommands.renderStateDirtyFrame=d),g.derivedCommands.type=A,g.pass=G.pass,g.pickOnly=G.pickOnly,g.uniformMap=Nye(t,e.uniformMap,C,Z,G.getUniformMapFunction),g.shaderProgram=Uye(s.context,e.shaderProgram,y,E,G.getShaderProgramFunction,S),g.renderState=Iye(e.renderState,Y,I,G.getRenderStateFunction,G.renderStateCache)}}}bT.prototype.pushDerivedCommands=function(t,e,n){let i=n.passes.pick||n.passes.pickVoxel;if(i&&e)return;let o=this._derivedCommandTypes,a=this._derivedCommandsLength;if(i?(o=this._derivedPickCommandTypes,a=this._derivedPickCommandsLength):e&&(o=this._derivedBlendCommandTypes,a=this._derivedBlendCommandsLength),a===0){n.commandList.push(t);return}let s=t.derivedCommands.globeTranslucency;for(let l=0;l<a;++l){let r=Iyt[o[l]];n.commandList.push(s[r])}};function yyt(t,e,n,i,o,a,s){for(let l=0;l<e;++l){let r=t[l],d=r.derivedCommands.type;(!c(s)||s.indexOf(d)>-1)&&n(r,i,o,a)}}function Cyt(t,e,n,i,o,a){for(let s=0;s<e;++s)n(t[s],i,o,a)}var Qye=[ed.OPAQUE_FRONT_FACE,ed.OPAQUE_BACK_FACE],kye=[ed.DEPTH_ONLY_FRONT_FACE,ed.DEPTH_ONLY_BACK_FACE,ed.DEPTH_ONLY_FRONT_AND_BACK_FACE];bT.prototype.executeGlobeCommands=function(t,e,n,i,o){let a=i.context,s=t.commands[Pt.GLOBE],l=t.indices[Pt.GLOBE];l!==0&&(this._globeTranslucencyFramebuffer=n,n.clearClassification(a,o),yyt(s,l,e,i,a,o,Qye))};bT.prototype.executeGlobeClassificationCommands=function(t,e,n,i,o){let a=i.context,s=t.commands[Pt.GLOBE],l=t.indices[Pt.GLOBE],r=t.commands[Pt.TERRAIN_CLASSIFICATION],d=t.indices[Pt.TERRAIN_CLASSIFICATION];if(l===0||d===0)return;let m=this._frontFaceTranslucent,h=this._backFaceTranslucent;if((!m||!h)&&Cyt(r,d,e,i,a,o),!m&&!h)return;this._globeTranslucencyFramebuffer=n;let u=a.uniformState.globeDepthTexture,R=o.framebuffer;if(o.framebuffer=n.classificationFramebuffer,yyt(s,l,e,i,a,o,kye),a.depthTexture){let V=n.packDepth(a,o);a.uniformState.globeDepthTexture=V}Cyt(r,d,e,i,a,o),a.uniformState.globeDepthTexture=u,o.framebuffer=R};var J_=bT;var iCo=b(W(),1);var XEo=b(W(),1),nh=`uniform sampler2D colorTexture; in vec2 v_textureCoordinates; @@ -10827,7 +10827,7 @@ void main() { out_FragColor = texture(colorTexture, v_textureCoordinates); } -`;function Mb(){this._numSamples=1,this.previousFramebuffer=void 0,this._previousFramebuffer=void 0,this._depthStencilTexture=void 0,this._depthStencilRenderbuffer=void 0,this._fbo=new Ro({depthStencil:!0,createDepthAttachments:!1}),this._fboClassified=new Ro({depthStencil:!0,createDepthAttachments:!1}),this._rsUnclassified=void 0,this._rsClassified=void 0,this._unclassifiedCommand=void 0,this._classifiedCommand=void 0,this._translucentCommand=void 0,this._clearColorCommand=new ao({color:new v(0,0,0,0),owner:this}),this._clearCommand=new ao({color:new v(0,0,0,0),depth:1,stencil:0});let t=this;this._uniformMap={colorTexture:function(){return t._fbo.getColorTexture()},depthTexture:function(){return t._depthStencilTexture},classifiedTexture:function(){return t._fboClassified.getColorTexture()}}}Object.defineProperties(Mb.prototype,{unclassifiedCommand:{get:function(){return this._unclassifiedCommand}}});Mb.isTranslucencySupported=function(t){return t.depthTexture&&t.fragmentDepth};var Yye={depthMask:!1,stencilTest:{enabled:!0,frontFunction:Li.EQUAL,frontOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.KEEP},backFunction:Li.NEVER,reference:0,mask:gn.CLASSIFICATION_MASK},blending:Pn.ALPHA_BLEND},xye={depthMask:!1,stencilTest:{enabled:!0,frontFunction:Li.NOT_EQUAL,frontOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.KEEP},backFunction:Li.NEVER,reference:0,mask:gn.CLASSIFICATION_MASK},blending:Pn.ALPHA_BLEND},Xye={depthMask:!0,depthTest:{enabled:!0},stencilTest:gn.setCesium3DTileBit(),stencilMask:gn.CESIUM_3D_TILE_MASK,blending:Pn.ALPHA_BLEND},Jye=`uniform sampler2D colorTexture; +`;function MR(){this._numSamples=1,this.previousFramebuffer=void 0,this._previousFramebuffer=void 0,this._depthStencilTexture=void 0,this._depthStencilRenderbuffer=void 0,this._fbo=new bo({depthStencil:!0,createDepthAttachments:!1}),this._fboClassified=new bo({depthStencil:!0,createDepthAttachments:!1}),this._rsUnclassified=void 0,this._rsClassified=void 0,this._unclassifiedCommand=void 0,this._classifiedCommand=void 0,this._translucentCommand=void 0,this._clearColorCommand=new ao({color:new v(0,0,0,0),owner:this}),this._clearCommand=new ao({color:new v(0,0,0,0),depth:1,stencil:0});let t=this;this._uniformMap={colorTexture:function(){return t._fbo.getColorTexture()},depthTexture:function(){return t._depthStencilTexture},classifiedTexture:function(){return t._fboClassified.getColorTexture()}}}Object.defineProperties(MR.prototype,{unclassifiedCommand:{get:function(){return this._unclassifiedCommand}}});MR.isTranslucencySupported=function(t){return t.depthTexture&&t.fragmentDepth};var Yye={depthMask:!1,stencilTest:{enabled:!0,frontFunction:Li.EQUAL,frontOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.KEEP},backFunction:Li.NEVER,reference:0,mask:gn.CLASSIFICATION_MASK},blending:Pn.ALPHA_BLEND},xye={depthMask:!1,stencilTest:{enabled:!0,frontFunction:Li.NOT_EQUAL,frontOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.KEEP},backFunction:Li.NEVER,reference:0,mask:gn.CLASSIFICATION_MASK},blending:Pn.ALPHA_BLEND},Xye={depthMask:!0,depthTest:{enabled:!0},stencilTest:gn.setCesium3DTileBit(),stencilMask:gn.CESIUM_3D_TILE_MASK,blending:Pn.ALPHA_BLEND},Jye=`uniform sampler2D colorTexture; uniform sampler2D depthTexture; uniform sampler2D classifiedTexture; in vec2 v_textureCoordinates; @@ -10870,13 +10870,13 @@ void main() out_FragColor = color; #endif } -`;Mb.prototype.update=function(t,e,n){let i=this._fbo.getColorTexture(),o=this.previousFramebuffer!==this._previousFramebuffer;this._previousFramebuffer=this.previousFramebuffer;let a=this._numSamples!==e,s=t.drawingBufferWidth,l=t.drawingBufferHeight,r=!c(i)||i.width!==s||i.height!==l;if((r||o||a)&&(this._numSamples=e,this._depthStencilTexture=this._depthStencilTexture&&this._depthStencilTexture.destroy(),this._depthStencilRenderbuffer=this._depthStencilRenderbuffer&&this._depthStencilRenderbuffer.destroy(),c(this._previousFramebuffer)||(this._depthStencilTexture=new hn({context:t,width:s,height:l,pixelFormat:Ye.DEPTH_STENCIL,pixelDatatype:Ue.UNSIGNED_INT_24_8}),e>1&&(this._depthStencilRenderbuffer=new bh({context:t,width:s,height:l,format:Sc.DEPTH24_STENCIL8,numSamples:e})))),!c(this._fbo.framebuffer)||r||o||a){this._fbo.destroy(),this._fboClassified.destroy();let d,m;c(this._previousFramebuffer)?(d=n.getDepthStencilTexture(),m=n.getDepthStencilRenderbuffer()):(d=this._depthStencilTexture,m=this._depthStencilRenderbuffer),this._fbo.setDepthStencilTexture(d),c(m)&&this._fbo.setDepthStencilRenderbuffer(m),this._fbo.update(t,s,l,e),c(this._previousFramebuffer)||(this._fboClassified.setDepthStencilTexture(d),this._fboClassified.update(t,s,l))}if(c(this._rsUnclassified)||(this._rsUnclassified=he.fromCache(Yye),this._rsClassified=he.fromCache(xye),this._rsDefault=he.fromCache(Xye)),!c(this._unclassifiedCommand)||o||a){c(this._unclassifiedCommand)&&(this._unclassifiedCommand.shaderProgram=this._unclassifiedCommand.shaderProgram&&this._unclassifiedCommand.shaderProgram.destroy(),this._classifiedCommand.shaderProgram=this._classifiedCommand.shaderProgram&&this._classifiedCommand.shaderProgram.destroy());let d=c(this._previousFramebuffer)?Lye:Jye,m=new Ve({defines:["UNCLASSIFIED"],sources:[d]}),h=new Ve({sources:[d]});this._unclassifiedCommand=t.createViewportQuadCommand(m,{renderState:c(this._previousFramebuffer)?this._rsUnclassified:this._rsDefault,uniformMap:this._uniformMap,owner:this}),this._classifiedCommand=t.createViewportQuadCommand(h,{renderState:c(this._previousFramebuffer)?this._rsClassified:this._rsDefault,uniformMap:this._uniformMap,owner:this}),c(this._translucentCommand)&&(this._translucentCommand.shaderProgram=this._translucentCommand.shaderProgram&&this._translucentCommand.shaderProgram.destroy()),c(this._previousFramebuffer)||(this._translucentCommand=t.createViewportQuadCommand(nh,{renderState:this._rsUnclassified,uniformMap:this._uniformMap,owner:this}))}};Mb.prototype.prepareTextures=function(t,e){this._fbo._numSamples>1&&this._fbo.prepareTextures(t,e)};Mb.prototype.clear=function(t,e){c(this._previousFramebuffer)?this._fbo.clear(t,this._clearColorCommand,e):(this._fbo.clear(t,this._clearCommand,e),this._fboClassified.clear(t,this._clearCommand,e))};Mb.prototype.executeClassified=function(t,e){if(!c(this._previousFramebuffer)){let n=e.framebuffer;this.prepareTextures(t,!0),e.framebuffer=this._fboClassified.framebuffer,this._translucentCommand.execute(t,e),e.framebuffer=n}this._classifiedCommand.execute(t,e)};Mb.prototype.executeUnclassified=function(t,e){this._unclassifiedCommand.execute(t,e)};Mb.prototype.isDestroyed=function(){return!1};Mb.prototype.destroy=function(){return this._fbo.destroy(),this._fboClassified.destroy(),this._depthStencilTexture=this._depthStencilTexture&&this._depthStencilTexture.destroy(),this._depthStencilRenderbuffer=this._depthStencilRenderbuffer&&this._depthStencilRenderbuffer.destroy(),c(this._unclassifiedCommand)&&(this._unclassifiedCommand.shaderProgram=this._unclassifiedCommand.shaderProgram&&this._unclassifiedCommand.shaderProgram.destroy(),this._classifiedCommand.shaderProgram=this._classifiedCommand.shaderProgram&&this._classifiedCommand.shaderProgram.destroy()),At(this)};var M1=Mb;var rCo=R(W(),1);function oj(t){this._total=t,this.usedThisFrame=0,this.stolenFromMeThisFrame=0,this.starvedThisFrame=!1,this.starvedLastFrame=!1}Object.defineProperties(oj.prototype,{total:{get:function(){return this._total}}});function VU(t){let e=new Array(Vd.NUMBER_OF_JOB_TYPES);e[Vd.TEXTURE]=new oj(c(t)?t[Vd.TEXTURE]:10),e[Vd.PROGRAM]=new oj(c(t)?t[Vd.PROGRAM]:10),e[Vd.BUFFER]=new oj(c(t)?t[Vd.BUFFER]:30);let n=e.length,i,o=0;for(i=0;i<n;++i)o+=e[i].total;let a=new Array(n);for(i=0;i<n;++i)a[i]=!1;this._totalBudget=o,this._totalUsedThisFrame=0,this._budgets=e,this._executedThisFrame=a}VU.getTimestamp=Oi;Object.defineProperties(VU.prototype,{totalBudget:{get:function(){return this._totalBudget}}});VU.prototype.disableThisFrame=function(){this._totalUsedThisFrame=this._totalBudget};VU.prototype.resetBudgets=function(){let t=this._budgets,e=t.length;for(let n=0;n<e;++n){let i=t[n];i.starvedLastFrame=i.starvedThisFrame,i.starvedThisFrame=!1,i.usedThisFrame=0,i.stolenFromMeThisFrame=0}this._totalUsedThisFrame=0};VU.prototype.execute=function(t,e){let n=this._budgets,i=n[e],o=this._executedThisFrame[e];if(this._totalUsedThisFrame>=this._totalBudget&&o)return i.starvedThisFrame=!0,!1;let a;if(i.usedThisFrame+i.stolenFromMeThisFrame>=i.total){let r=n.length,d;for(d=0;d<r&&(a=n[d],!(a.usedThisFrame+a.stolenFromMeThisFrame<a.total&&!a.starvedLastFrame));++d);if(d===r&&o)return!1;o&&(i.starvedThisFrame=!0)}let s=VU.getTimestamp();t.execute();let l=VU.getTimestamp()-s;return this._totalUsedThisFrame+=l,a?a.stolenFromMeThisFrame+=l:i.usedThisFrame+=l,this._executedThisFrame[e]=!0,!0};var L_=VU;var uCo=R(W(),1);function aj(t){t=f(t,f.EMPTY_OBJECT);let e=Ui(t.container);this._container=e;let n=document.createElement("div");n.className="cesium-performanceDisplay";let i=document.createElement("div");i.className="cesium-performanceDisplay-fps",this._fpsText=document.createTextNode(""),i.appendChild(this._fpsText);let o=document.createElement("div");o.className="cesium-performanceDisplay-ms",this._msText=document.createTextNode(""),o.appendChild(this._msText),n.appendChild(o),n.appendChild(i),this._container.appendChild(n),this._lastFpsSampleTime=Oi(),this._lastMsSampleTime=Oi(),this._fpsFrameCount=0,this._msFrameCount=0,this._throttled=!1;let a=document.createElement("div");a.className="cesium-performanceDisplay-throttled",this._throttledText=document.createTextNode(""),a.appendChild(this._throttledText),n.appendChild(a)}Object.defineProperties(aj.prototype,{throttled:{get:function(){return this._throttled},set:function(t){this._throttled!==t&&(t?this._throttledText.nodeValue="(throttled)":this._throttledText.nodeValue="",this._throttled=t)}}});aj.prototype.update=function(t){let e=Oi(),n=f(t,!0);this._fpsFrameCount++;let i=e-this._lastFpsSampleTime;if(i>1e3){let a="N/A";n&&(a=this._fpsFrameCount*1e3/i|0),this._fpsText.nodeValue=`${a} FPS`,this._lastFpsSampleTime=e,this._fpsFrameCount=0}this._msFrameCount++;let o=e-this._lastMsSampleTime;if(o>200){let a="N/A";n&&(a=(o/this._msFrameCount).toFixed(2)),this._msText.nodeValue=`${a} MS`,this._lastMsSampleTime=e,this._msFrameCount=0}};aj.prototype.destroy=function(){return At(this)};var bW=aj;var dyo=R(W(),1);var FCo=R(W(),1);function WS(){this._framebuffer=new Ro,this._textureToCopy=void 0,this._copyDepthCommand=void 0}Object.defineProperties(WS.prototype,{framebuffer:{get:function(){return this._framebuffer.framebuffer}}});function Mye(t,e,n){let i=n.width,o=n.height;t._framebuffer.update(e,i,o)}function _ye(t,e,n){if(!c(t._copyDepthCommand)){let i=`uniform highp sampler2D u_texture; +`;MR.prototype.update=function(t,e,n){let i=this._fbo.getColorTexture(),o=this.previousFramebuffer!==this._previousFramebuffer;this._previousFramebuffer=this.previousFramebuffer;let a=this._numSamples!==e,s=t.drawingBufferWidth,l=t.drawingBufferHeight,r=!c(i)||i.width!==s||i.height!==l;if((r||o||a)&&(this._numSamples=e,this._depthStencilTexture=this._depthStencilTexture&&this._depthStencilTexture.destroy(),this._depthStencilRenderbuffer=this._depthStencilRenderbuffer&&this._depthStencilRenderbuffer.destroy(),c(this._previousFramebuffer)||(this._depthStencilTexture=new hn({context:t,width:s,height:l,pixelFormat:Ye.DEPTH_STENCIL,pixelDatatype:Ue.UNSIGNED_INT_24_8}),e>1&&(this._depthStencilRenderbuffer=new Rh({context:t,width:s,height:l,format:Tc.DEPTH24_STENCIL8,numSamples:e})))),!c(this._fbo.framebuffer)||r||o||a){this._fbo.destroy(),this._fboClassified.destroy();let d,m;c(this._previousFramebuffer)?(d=n.getDepthStencilTexture(),m=n.getDepthStencilRenderbuffer()):(d=this._depthStencilTexture,m=this._depthStencilRenderbuffer),this._fbo.setDepthStencilTexture(d),c(m)&&this._fbo.setDepthStencilRenderbuffer(m),this._fbo.update(t,s,l,e),c(this._previousFramebuffer)||(this._fboClassified.setDepthStencilTexture(d),this._fboClassified.update(t,s,l))}if(c(this._rsUnclassified)||(this._rsUnclassified=he.fromCache(Yye),this._rsClassified=he.fromCache(xye),this._rsDefault=he.fromCache(Xye)),!c(this._unclassifiedCommand)||o||a){c(this._unclassifiedCommand)&&(this._unclassifiedCommand.shaderProgram=this._unclassifiedCommand.shaderProgram&&this._unclassifiedCommand.shaderProgram.destroy(),this._classifiedCommand.shaderProgram=this._classifiedCommand.shaderProgram&&this._classifiedCommand.shaderProgram.destroy());let d=c(this._previousFramebuffer)?Lye:Jye,m=new Ze({defines:["UNCLASSIFIED"],sources:[d]}),h=new Ze({sources:[d]});this._unclassifiedCommand=t.createViewportQuadCommand(m,{renderState:c(this._previousFramebuffer)?this._rsUnclassified:this._rsDefault,uniformMap:this._uniformMap,owner:this}),this._classifiedCommand=t.createViewportQuadCommand(h,{renderState:c(this._previousFramebuffer)?this._rsClassified:this._rsDefault,uniformMap:this._uniformMap,owner:this}),c(this._translucentCommand)&&(this._translucentCommand.shaderProgram=this._translucentCommand.shaderProgram&&this._translucentCommand.shaderProgram.destroy()),c(this._previousFramebuffer)||(this._translucentCommand=t.createViewportQuadCommand(nh,{renderState:this._rsUnclassified,uniformMap:this._uniformMap,owner:this}))}};MR.prototype.prepareTextures=function(t,e){this._fbo._numSamples>1&&this._fbo.prepareTextures(t,e)};MR.prototype.clear=function(t,e){c(this._previousFramebuffer)?this._fbo.clear(t,this._clearColorCommand,e):(this._fbo.clear(t,this._clearCommand,e),this._fboClassified.clear(t,this._clearCommand,e))};MR.prototype.executeClassified=function(t,e){if(!c(this._previousFramebuffer)){let n=e.framebuffer;this.prepareTextures(t,!0),e.framebuffer=this._fboClassified.framebuffer,this._translucentCommand.execute(t,e),e.framebuffer=n}this._classifiedCommand.execute(t,e)};MR.prototype.executeUnclassified=function(t,e){this._unclassifiedCommand.execute(t,e)};MR.prototype.isDestroyed=function(){return!1};MR.prototype.destroy=function(){return this._fbo.destroy(),this._fboClassified.destroy(),this._depthStencilTexture=this._depthStencilTexture&&this._depthStencilTexture.destroy(),this._depthStencilRenderbuffer=this._depthStencilRenderbuffer&&this._depthStencilRenderbuffer.destroy(),c(this._unclassifiedCommand)&&(this._unclassifiedCommand.shaderProgram=this._unclassifiedCommand.shaderProgram&&this._unclassifiedCommand.shaderProgram.destroy(),this._classifiedCommand.shaderProgram=this._classifiedCommand.shaderProgram&&this._classifiedCommand.shaderProgram.destroy()),At(this)};var M1=MR;var rCo=b(W(),1);function oj(t){this._total=t,this.usedThisFrame=0,this.stolenFromMeThisFrame=0,this.starvedThisFrame=!1,this.starvedLastFrame=!1}Object.defineProperties(oj.prototype,{total:{get:function(){return this._total}}});function ZU(t){let e=new Array(Zd.NUMBER_OF_JOB_TYPES);e[Zd.TEXTURE]=new oj(c(t)?t[Zd.TEXTURE]:10),e[Zd.PROGRAM]=new oj(c(t)?t[Zd.PROGRAM]:10),e[Zd.BUFFER]=new oj(c(t)?t[Zd.BUFFER]:30);let n=e.length,i,o=0;for(i=0;i<n;++i)o+=e[i].total;let a=new Array(n);for(i=0;i<n;++i)a[i]=!1;this._totalBudget=o,this._totalUsedThisFrame=0,this._budgets=e,this._executedThisFrame=a}ZU.getTimestamp=Oi;Object.defineProperties(ZU.prototype,{totalBudget:{get:function(){return this._totalBudget}}});ZU.prototype.disableThisFrame=function(){this._totalUsedThisFrame=this._totalBudget};ZU.prototype.resetBudgets=function(){let t=this._budgets,e=t.length;for(let n=0;n<e;++n){let i=t[n];i.starvedLastFrame=i.starvedThisFrame,i.starvedThisFrame=!1,i.usedThisFrame=0,i.stolenFromMeThisFrame=0}this._totalUsedThisFrame=0};ZU.prototype.execute=function(t,e){let n=this._budgets,i=n[e],o=this._executedThisFrame[e];if(this._totalUsedThisFrame>=this._totalBudget&&o)return i.starvedThisFrame=!0,!1;let a;if(i.usedThisFrame+i.stolenFromMeThisFrame>=i.total){let r=n.length,d;for(d=0;d<r&&(a=n[d],!(a.usedThisFrame+a.stolenFromMeThisFrame<a.total&&!a.starvedLastFrame));++d);if(d===r&&o)return!1;o&&(i.starvedThisFrame=!0)}let s=ZU.getTimestamp();t.execute();let l=ZU.getTimestamp()-s;return this._totalUsedThisFrame+=l,a?a.stolenFromMeThisFrame+=l:i.usedThisFrame+=l,this._executedThisFrame[e]=!0,!0};var L_=ZU;var VCo=b(W(),1);function aj(t){t=f(t,f.EMPTY_OBJECT);let e=Ui(t.container);this._container=e;let n=document.createElement("div");n.className="cesium-performanceDisplay";let i=document.createElement("div");i.className="cesium-performanceDisplay-fps",this._fpsText=document.createTextNode(""),i.appendChild(this._fpsText);let o=document.createElement("div");o.className="cesium-performanceDisplay-ms",this._msText=document.createTextNode(""),o.appendChild(this._msText),n.appendChild(o),n.appendChild(i),this._container.appendChild(n),this._lastFpsSampleTime=Oi(),this._lastMsSampleTime=Oi(),this._fpsFrameCount=0,this._msFrameCount=0,this._throttled=!1;let a=document.createElement("div");a.className="cesium-performanceDisplay-throttled",this._throttledText=document.createTextNode(""),a.appendChild(this._throttledText),n.appendChild(a)}Object.defineProperties(aj.prototype,{throttled:{get:function(){return this._throttled},set:function(t){this._throttled!==t&&(t?this._throttledText.nodeValue="(throttled)":this._throttledText.nodeValue="",this._throttled=t)}}});aj.prototype.update=function(t){let e=Oi(),n=f(t,!0);this._fpsFrameCount++;let i=e-this._lastFpsSampleTime;if(i>1e3){let a="N/A";n&&(a=this._fpsFrameCount*1e3/i|0),this._fpsText.nodeValue=`${a} FPS`,this._lastFpsSampleTime=e,this._fpsFrameCount=0}this._msFrameCount++;let o=e-this._lastMsSampleTime;if(o>200){let a="N/A";n&&(a=(o/this._msFrameCount).toFixed(2)),this._msText.nodeValue=`${a} MS`,this._lastMsSampleTime=e,this._msFrameCount=0}};aj.prototype.destroy=function(){return At(this)};var RW=aj;var dyo=b(W(),1);var FCo=b(W(),1);function WT(){this._framebuffer=new bo,this._textureToCopy=void 0,this._copyDepthCommand=void 0}Object.defineProperties(WT.prototype,{framebuffer:{get:function(){return this._framebuffer.framebuffer}}});function Mye(t,e,n){let i=n.width,o=n.height;t._framebuffer.update(e,i,o)}function _ye(t,e,n){if(!c(t._copyDepthCommand)){let i=`uniform highp sampler2D u_texture; in vec2 v_textureCoordinates; void main() { out_FragColor = czm_packDepth(texture(u_texture, v_textureCoordinates).r); } -`;t._copyDepthCommand=e.createViewportQuadCommand(i,{renderState:he.fromCache(),uniformMap:{u_texture:function(){return t._textureToCopy}},owner:t})}t._textureToCopy=n,t._copyDepthCommand.framebuffer=t.framebuffer}WS.prototype.update=function(t,e){Mye(this,t,e),_ye(this,t,e)};var Dye=new Rt,Oye=new Rt(1,1/255,1/65025,1/16581375);WS.prototype.getDepth=function(t,e,n){if(!c(this.framebuffer))return;let i=t.readPixels({x:e,y:n,width:1,height:1,framebuffer:this.framebuffer}),o=Rt.unpack(i,0,Dye);return Rt.divideByScalar(o,255,o),Rt.dot(o,Oye)};WS.prototype.executeCopyDepth=function(t,e){this._copyDepthCommand.execute(t,e)};WS.prototype.isDestroyed=function(){return!1};WS.prototype.destroy=function(){return this._framebuffer.destroy(),c(this._copyDepthCommand)&&(this._copyDepthCommand.shaderProgram=c(this._copyDepthCommand.shaderProgram)&&this._copyDepthCommand.shaderProgram.destroy()),At(this)};var M_=WS;var xNo=R(W(),1);var TCo=R(W(),1);function Hye(t,e){this.near=f(t,0),this.far=f(e,0);let n=Pt.NUMBER_OF_PASSES,i=new Array(n),o=new Array(n);for(let a=0;a<n;++a)i[a]=[],o[a]=0;this.commands=i,this.indices=o}var __=Hye;var DCo=R(W(),1);var gCo=R(W(),1),bU=`uniform highp sampler2D u_depthTexture; +`;t._copyDepthCommand=e.createViewportQuadCommand(i,{renderState:he.fromCache(),uniformMap:{u_texture:function(){return t._textureToCopy}},owner:t})}t._textureToCopy=n,t._copyDepthCommand.framebuffer=t.framebuffer}WT.prototype.update=function(t,e){Mye(this,t,e),_ye(this,t,e)};var Dye=new bt,Oye=new bt(1,1/255,1/65025,1/16581375);WT.prototype.getDepth=function(t,e,n){if(!c(this.framebuffer))return;let i=t.readPixels({x:e,y:n,width:1,height:1,framebuffer:this.framebuffer}),o=bt.unpack(i,0,Dye);return bt.divideByScalar(o,255,o),bt.dot(o,Oye)};WT.prototype.executeCopyDepth=function(t,e){this._copyDepthCommand.execute(t,e)};WT.prototype.isDestroyed=function(){return!1};WT.prototype.destroy=function(){return this._framebuffer.destroy(),c(this._copyDepthCommand)&&(this._copyDepthCommand.shaderProgram=c(this._copyDepthCommand.shaderProgram)&&this._copyDepthCommand.shaderProgram.destroy()),At(this)};var M_=WT;var xNo=b(W(),1);var SCo=b(W(),1);function Hye(t,e){this.near=f(t,0),this.far=f(e,0);let n=Pt.NUMBER_OF_PASSES,i=new Array(n),o=new Array(n);for(let a=0;a<n;++a)i[a]=[],o[a]=0;this.commands=i,this.indices=o}var __=Hye;var DCo=b(W(),1);var gCo=b(W(),1),RU=`uniform highp sampler2D u_depthTexture; in vec2 v_textureCoordinates; @@ -10884,7 +10884,7 @@ void main() { out_FragColor = czm_packDepth(texture(u_depthTexture, v_textureCoordinates).r); } -`;function _b(){this._picking=!1,this._numSamples=1,this._tempCopyDepthTexture=void 0,this._pickColorFramebuffer=new Ro({depthStencil:!0,supportsDepthTexture:!0}),this._outputFramebuffer=new Ro({depthStencil:!0,supportsDepthTexture:!0}),this._copyDepthFramebuffer=new Ro,this._tempCopyDepthFramebuffer=new Ro,this._updateDepthFramebuffer=new Ro({createColorAttachments:!1,createDepthAttachments:!1,depthStencil:!0}),this._clearGlobeColorCommand=void 0,this._copyColorCommand=void 0,this._copyDepthCommand=void 0,this._tempCopyDepthCommand=void 0,this._updateDepthCommand=void 0,this._viewport=new Fe,this._rs=void 0,this._rsBlend=void 0,this._rsUpdate=void 0,this._useScissorTest=!1,this._scissorRectangle=void 0,this._useHdr=void 0,this._clearGlobeDepth=void 0}Object.defineProperties(_b.prototype,{colorFramebufferManager:{get:function(){return this._picking?this._pickColorFramebuffer:this._outputFramebuffer}},framebuffer:{get:function(){return this.colorFramebufferManager.framebuffer}},depthStencilTexture:{get:function(){return this.colorFramebufferManager.getDepthStencilTexture()}},picking:{get:function(){return this._picking},set:function(t){this._picking=t}}});function wye(t){t._pickColorFramebuffer.destroy(),t._outputFramebuffer.destroy(),t._copyDepthFramebuffer.destroy(),t._tempCopyDepthFramebuffer.destroy(),t._updateDepthFramebuffer.destroy()}function Byt(t,e,n,i,o){t._viewport.width=n,t._viewport.height=i;let a=!Fe.equals(t._viewport,o.viewport),s=a!==t._useScissorTest;t._useScissorTest=a,Fe.equals(t._scissorRectangle,o.viewport)||(t._scissorRectangle=Fe.clone(o.viewport,t._scissorRectangle),s=!0),(!c(t._rs)||!Fe.equals(t._viewport,t._rs.viewport)||s)&&(t._rs=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle}}),t._rsBlend=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle},blending:Pn.ALPHA_BLEND}),t._rsUpdate=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle},stencilTest:{enabled:!0,frontFunction:Li.EQUAL,frontOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.KEEP},backFunction:Li.NEVER,reference:gn.CESIUM_3D_TILE_MASK,mask:gn.CESIUM_3D_TILE_MASK}})),c(t._copyDepthCommand)||(t._copyDepthCommand=e.createViewportQuadCommand(bU,{uniformMap:{u_depthTexture:function(){return t.colorFramebufferManager.getDepthStencilTexture()}},owner:t})),t._copyDepthCommand.framebuffer=t._copyDepthFramebuffer.framebuffer,t._copyDepthCommand.renderState=t._rs,c(t._copyColorCommand)||(t._copyColorCommand=e.createViewportQuadCommand(nh,{uniformMap:{colorTexture:function(){return t.colorFramebufferManager.getColorTexture()}},owner:t})),t._copyColorCommand.renderState=t._rs,c(t._tempCopyDepthCommand)||(t._tempCopyDepthCommand=e.createViewportQuadCommand(bU,{uniformMap:{u_depthTexture:function(){return t._tempCopyDepthTexture}},owner:t})),t._tempCopyDepthCommand.framebuffer=t._tempCopyDepthFramebuffer.framebuffer,t._tempCopyDepthCommand.renderState=t._rs,c(t._updateDepthCommand)||(t._updateDepthCommand=e.createViewportQuadCommand(nh,{uniformMap:{colorTexture:function(){return t._tempCopyDepthFramebuffer.getColorTexture()}},owner:t})),t._updateDepthCommand.framebuffer=t._updateDepthFramebuffer.framebuffer,t._updateDepthCommand.renderState=t._rsUpdate,c(t._clearGlobeColorCommand)||(t._clearGlobeColorCommand=new ao({color:new v(0,0,0,0),stencil:0,owner:t})),t._clearGlobeColorCommand.framebuffer=t.framebuffer}_b.prototype.update=function(t,e,n,i,o,a){let s=n.width,l=n.height,r=o?t.halfFloatingPointTexture?Ue.HALF_FLOAT:Ue.FLOAT:Ue.UNSIGNED_BYTE;this._numSamples=i,this.picking?this._pickColorFramebuffer.update(t,s,l):this._outputFramebuffer.update(t,s,l,i,r),this._copyDepthFramebuffer.update(t,s,l),Byt(this,t,s,l,e),t.uniformState.globeDepthTexture=void 0,this._useHdr=o,this._clearGlobeDepth=a};_b.prototype.prepareColorTextures=function(t,e){!this.picking&&this._numSamples>1&&this._outputFramebuffer.prepareTextures(t,e)};_b.prototype.executeCopyDepth=function(t,e){c(this._copyDepthCommand)&&(this.prepareColorTextures(t),this._copyDepthCommand.execute(t,e),t.uniformState.globeDepthTexture=this._copyDepthFramebuffer.getColorTexture())};_b.prototype.executeUpdateDepth=function(t,e,n,i){let o=c(i)?i:e.framebuffer.depthStencilTexture;if(n||o!==this.colorFramebufferManager.getDepthStencilTexture()){if(c(this._updateDepthCommand)){if(!c(this._updateDepthFramebuffer.framebuffer)||this._updateDepthFramebuffer.getDepthStencilTexture()!==o||this._updateDepthFramebuffer.getColorTexture()!==this._copyDepthFramebuffer.getColorTexture()){let a=this._copyDepthFramebuffer.getColorTexture().width,s=this._copyDepthFramebuffer.getColorTexture().height;this._tempCopyDepthFramebuffer.destroy(),this._tempCopyDepthFramebuffer.update(t,a,s);let l=this._copyDepthFramebuffer.getColorTexture();this._updateDepthFramebuffer.setColorTexture(l,0),this._updateDepthFramebuffer.setDepthStencilTexture(o),this._updateDepthFramebuffer.update(t,a,s),Byt(this,t,a,s,e)}this._tempCopyDepthTexture=o,this._tempCopyDepthCommand.execute(t,e),this._updateDepthCommand.execute(t,e)}return}c(this._copyDepthCommand)&&this._copyDepthCommand.execute(t,e)};_b.prototype.executeCopyColor=function(t,e){c(this._copyColorCommand)&&this._copyColorCommand.execute(t,e)};_b.prototype.clear=function(t,e,n){let i=this._clearGlobeColorCommand;c(i)&&(v.clone(n,i.color),this.colorFramebufferManager.clear(t,i,e))};_b.prototype.isDestroyed=function(){return!1};_b.prototype.destroy=function(){return wye(this),c(this._copyColorCommand)&&(this._copyColorCommand.shaderProgram=this._copyColorCommand.shaderProgram.destroy()),c(this._copyDepthCommand)&&(this._copyDepthCommand.shaderProgram=this._copyDepthCommand.shaderProgram.destroy()),c(this._tempCopyDepthCommand)&&(this._tempCopyDepthCommand.shaderProgram=this._tempCopyDepthCommand.shaderProgram.destroy()),c(this._updateDepthCommand)&&(this._updateDepthCommand.shaderProgram=this._updateDepthCommand.shaderProgram.destroy()),At(this)};var D_=_b;var tIo=R(W(),1);function fS(){this._framebuffer=new Ro({depthStencil:!0,supportsDepthTexture:!0}),this._packedDepthFramebuffer=new Ro,this._renderState=void 0,this._packedDepthCommand=void 0,this._clearCommand=void 0,this._viewport=new Fe,this._useScissorTest=!1,this._scissorRectangle=void 0,this._useHdr=void 0}Object.defineProperties(fS.prototype,{classificationTexture:{get:function(){return this._framebuffer.getColorTexture()}},classificationFramebuffer:{get:function(){return this._framebuffer.framebuffer}},packedDepthFramebuffer:{get:function(){return this._packedDepthFramebuffer.framebuffer}},depthStencilTexture:{get:function(){return this._framebuffer.getDepthStencilTexture()}},depthStencilRenderbuffer:{get:function(){return this._framebuffer.getDepthStencilRenderbuffer()}},packedDepthTexture:{get:function(){return this._packedDepthFramebuffer.getColorTexture()}}});function Pye(t){t._framebuffer.destroy(),t._packedDepthFramebuffer.destroy()}function vye(t,e,n,i,o){let a=o?e.halfFloatingPointTexture?Ue.HALF_FLOAT:Ue.FLOAT:Ue.UNSIGNED_BYTE;t._framebuffer.update(e,n,i,1,a),t._packedDepthFramebuffer.update(e,n,i)}function Kye(t,e,n,i,o){t._viewport.width=n,t._viewport.height=i;let a=!Fe.equals(t._viewport,o.viewport),s=a!==t._useScissorTest;t._useScissorTest=a,Fe.equals(t._scissorRectangle,o.viewport)||(t._scissorRectangle=Fe.clone(o.viewport,t._scissorRectangle),s=!0),(!c(t._renderState)||!Fe.equals(t._viewport,t._renderState.viewport)||s)&&(t._renderState=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle}})),c(t._packedDepthCommand)||(t._packedDepthCommand=e.createViewportQuadCommand(bU,{uniformMap:{u_depthTexture:function(){return t.depthStencilTexture}},owner:t})),c(t._clearCommand)||(t._clearCommand=new ao({color:new v(0,0,0,0),depth:1,stencil:0,owner:t})),t._packedDepthCommand.framebuffer=t._packedDepthFramebuffer.framebuffer,t._packedDepthCommand.renderState=t._renderState,t._clearCommand.framebuffer=t.classificationFramebuffer,t._clearCommand.renderState=t._renderState}fS.prototype.updateAndClear=function(t,e,n,i){let o=e.width,a=e.height;vye(this,n,o,a,t),Kye(this,n,o,a,i),this._useHdr=t};fS.prototype.clearClassification=function(t,e){this._clearCommand.execute(t,e)};fS.prototype.packDepth=function(t,e){return this._packedDepthCommand.execute(t,e),this.packedDepthTexture};fS.prototype.isDestroyed=function(){return!1};fS.prototype.destroy=function(){return Pye(this),At(this)};var O_=fS;var GIo=R(W(),1);var nIo=R(W(),1),_1=`#ifdef MRT +`;function _R(){this._picking=!1,this._numSamples=1,this._tempCopyDepthTexture=void 0,this._pickColorFramebuffer=new bo({depthStencil:!0,supportsDepthTexture:!0}),this._outputFramebuffer=new bo({depthStencil:!0,supportsDepthTexture:!0}),this._copyDepthFramebuffer=new bo,this._tempCopyDepthFramebuffer=new bo,this._updateDepthFramebuffer=new bo({createColorAttachments:!1,createDepthAttachments:!1,depthStencil:!0}),this._clearGlobeColorCommand=void 0,this._copyColorCommand=void 0,this._copyDepthCommand=void 0,this._tempCopyDepthCommand=void 0,this._updateDepthCommand=void 0,this._viewport=new Fe,this._rs=void 0,this._rsBlend=void 0,this._rsUpdate=void 0,this._useScissorTest=!1,this._scissorRectangle=void 0,this._useHdr=void 0,this._clearGlobeDepth=void 0}Object.defineProperties(_R.prototype,{colorFramebufferManager:{get:function(){return this._picking?this._pickColorFramebuffer:this._outputFramebuffer}},framebuffer:{get:function(){return this.colorFramebufferManager.framebuffer}},depthStencilTexture:{get:function(){return this.colorFramebufferManager.getDepthStencilTexture()}},picking:{get:function(){return this._picking},set:function(t){this._picking=t}}});function wye(t){t._pickColorFramebuffer.destroy(),t._outputFramebuffer.destroy(),t._copyDepthFramebuffer.destroy(),t._tempCopyDepthFramebuffer.destroy(),t._updateDepthFramebuffer.destroy()}function Byt(t,e,n,i,o){t._viewport.width=n,t._viewport.height=i;let a=!Fe.equals(t._viewport,o.viewport),s=a!==t._useScissorTest;t._useScissorTest=a,Fe.equals(t._scissorRectangle,o.viewport)||(t._scissorRectangle=Fe.clone(o.viewport,t._scissorRectangle),s=!0),(!c(t._rs)||!Fe.equals(t._viewport,t._rs.viewport)||s)&&(t._rs=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle}}),t._rsBlend=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle},blending:Pn.ALPHA_BLEND}),t._rsUpdate=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle},stencilTest:{enabled:!0,frontFunction:Li.EQUAL,frontOperation:{fail:je.KEEP,zFail:je.KEEP,zPass:je.KEEP},backFunction:Li.NEVER,reference:gn.CESIUM_3D_TILE_MASK,mask:gn.CESIUM_3D_TILE_MASK}})),c(t._copyDepthCommand)||(t._copyDepthCommand=e.createViewportQuadCommand(RU,{uniformMap:{u_depthTexture:function(){return t.colorFramebufferManager.getDepthStencilTexture()}},owner:t})),t._copyDepthCommand.framebuffer=t._copyDepthFramebuffer.framebuffer,t._copyDepthCommand.renderState=t._rs,c(t._copyColorCommand)||(t._copyColorCommand=e.createViewportQuadCommand(nh,{uniformMap:{colorTexture:function(){return t.colorFramebufferManager.getColorTexture()}},owner:t})),t._copyColorCommand.renderState=t._rs,c(t._tempCopyDepthCommand)||(t._tempCopyDepthCommand=e.createViewportQuadCommand(RU,{uniformMap:{u_depthTexture:function(){return t._tempCopyDepthTexture}},owner:t})),t._tempCopyDepthCommand.framebuffer=t._tempCopyDepthFramebuffer.framebuffer,t._tempCopyDepthCommand.renderState=t._rs,c(t._updateDepthCommand)||(t._updateDepthCommand=e.createViewportQuadCommand(nh,{uniformMap:{colorTexture:function(){return t._tempCopyDepthFramebuffer.getColorTexture()}},owner:t})),t._updateDepthCommand.framebuffer=t._updateDepthFramebuffer.framebuffer,t._updateDepthCommand.renderState=t._rsUpdate,c(t._clearGlobeColorCommand)||(t._clearGlobeColorCommand=new ao({color:new v(0,0,0,0),stencil:0,owner:t})),t._clearGlobeColorCommand.framebuffer=t.framebuffer}_R.prototype.update=function(t,e,n,i,o,a){let s=n.width,l=n.height,r=o?t.halfFloatingPointTexture?Ue.HALF_FLOAT:Ue.FLOAT:Ue.UNSIGNED_BYTE;this._numSamples=i,this.picking?this._pickColorFramebuffer.update(t,s,l):this._outputFramebuffer.update(t,s,l,i,r),this._copyDepthFramebuffer.update(t,s,l),Byt(this,t,s,l,e),t.uniformState.globeDepthTexture=void 0,this._useHdr=o,this._clearGlobeDepth=a};_R.prototype.prepareColorTextures=function(t,e){!this.picking&&this._numSamples>1&&this._outputFramebuffer.prepareTextures(t,e)};_R.prototype.executeCopyDepth=function(t,e){c(this._copyDepthCommand)&&(this.prepareColorTextures(t),this._copyDepthCommand.execute(t,e),t.uniformState.globeDepthTexture=this._copyDepthFramebuffer.getColorTexture())};_R.prototype.executeUpdateDepth=function(t,e,n,i){let o=c(i)?i:e.framebuffer.depthStencilTexture;if(n||o!==this.colorFramebufferManager.getDepthStencilTexture()){if(c(this._updateDepthCommand)){if(!c(this._updateDepthFramebuffer.framebuffer)||this._updateDepthFramebuffer.getDepthStencilTexture()!==o||this._updateDepthFramebuffer.getColorTexture()!==this._copyDepthFramebuffer.getColorTexture()){let a=this._copyDepthFramebuffer.getColorTexture().width,s=this._copyDepthFramebuffer.getColorTexture().height;this._tempCopyDepthFramebuffer.destroy(),this._tempCopyDepthFramebuffer.update(t,a,s);let l=this._copyDepthFramebuffer.getColorTexture();this._updateDepthFramebuffer.setColorTexture(l,0),this._updateDepthFramebuffer.setDepthStencilTexture(o),this._updateDepthFramebuffer.update(t,a,s),Byt(this,t,a,s,e)}this._tempCopyDepthTexture=o,this._tempCopyDepthCommand.execute(t,e),this._updateDepthCommand.execute(t,e)}return}c(this._copyDepthCommand)&&this._copyDepthCommand.execute(t,e)};_R.prototype.executeCopyColor=function(t,e){c(this._copyColorCommand)&&this._copyColorCommand.execute(t,e)};_R.prototype.clear=function(t,e,n){let i=this._clearGlobeColorCommand;c(i)&&(v.clone(n,i.color),this.colorFramebufferManager.clear(t,i,e))};_R.prototype.isDestroyed=function(){return!1};_R.prototype.destroy=function(){return wye(this),c(this._copyColorCommand)&&(this._copyColorCommand.shaderProgram=this._copyColorCommand.shaderProgram.destroy()),c(this._copyDepthCommand)&&(this._copyDepthCommand.shaderProgram=this._copyDepthCommand.shaderProgram.destroy()),c(this._tempCopyDepthCommand)&&(this._tempCopyDepthCommand.shaderProgram=this._tempCopyDepthCommand.shaderProgram.destroy()),c(this._updateDepthCommand)&&(this._updateDepthCommand.shaderProgram=this._updateDepthCommand.shaderProgram.destroy()),At(this)};var D_=_R;var tIo=b(W(),1);function fT(){this._framebuffer=new bo({depthStencil:!0,supportsDepthTexture:!0}),this._packedDepthFramebuffer=new bo,this._renderState=void 0,this._packedDepthCommand=void 0,this._clearCommand=void 0,this._viewport=new Fe,this._useScissorTest=!1,this._scissorRectangle=void 0,this._useHdr=void 0}Object.defineProperties(fT.prototype,{classificationTexture:{get:function(){return this._framebuffer.getColorTexture()}},classificationFramebuffer:{get:function(){return this._framebuffer.framebuffer}},packedDepthFramebuffer:{get:function(){return this._packedDepthFramebuffer.framebuffer}},depthStencilTexture:{get:function(){return this._framebuffer.getDepthStencilTexture()}},depthStencilRenderbuffer:{get:function(){return this._framebuffer.getDepthStencilRenderbuffer()}},packedDepthTexture:{get:function(){return this._packedDepthFramebuffer.getColorTexture()}}});function Pye(t){t._framebuffer.destroy(),t._packedDepthFramebuffer.destroy()}function vye(t,e,n,i,o){let a=o?e.halfFloatingPointTexture?Ue.HALF_FLOAT:Ue.FLOAT:Ue.UNSIGNED_BYTE;t._framebuffer.update(e,n,i,1,a),t._packedDepthFramebuffer.update(e,n,i)}function Kye(t,e,n,i,o){t._viewport.width=n,t._viewport.height=i;let a=!Fe.equals(t._viewport,o.viewport),s=a!==t._useScissorTest;t._useScissorTest=a,Fe.equals(t._scissorRectangle,o.viewport)||(t._scissorRectangle=Fe.clone(o.viewport,t._scissorRectangle),s=!0),(!c(t._renderState)||!Fe.equals(t._viewport,t._renderState.viewport)||s)&&(t._renderState=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle}})),c(t._packedDepthCommand)||(t._packedDepthCommand=e.createViewportQuadCommand(RU,{uniformMap:{u_depthTexture:function(){return t.depthStencilTexture}},owner:t})),c(t._clearCommand)||(t._clearCommand=new ao({color:new v(0,0,0,0),depth:1,stencil:0,owner:t})),t._packedDepthCommand.framebuffer=t._packedDepthFramebuffer.framebuffer,t._packedDepthCommand.renderState=t._renderState,t._clearCommand.framebuffer=t.classificationFramebuffer,t._clearCommand.renderState=t._renderState}fT.prototype.updateAndClear=function(t,e,n,i){let o=e.width,a=e.height;vye(this,n,o,a,t),Kye(this,n,o,a,i),this._useHdr=t};fT.prototype.clearClassification=function(t,e){this._clearCommand.execute(t,e)};fT.prototype.packDepth=function(t,e){return this._packedDepthCommand.execute(t,e),this.packedDepthTexture};fT.prototype.isDestroyed=function(){return!1};fT.prototype.destroy=function(){return Pye(this),At(this)};var O_=fT;var GIo=b(W(),1);var nIo=b(W(),1),_1=`#ifdef MRT layout (location = 0) out vec4 out_FragData_0; layout (location = 1) out vec4 out_FragData_1; #else @@ -10911,7 +10911,7 @@ void main() discard; } -`;var oIo=R(W(),1),H_=`/** +`;var oIo=b(W(),1),H_=`/** * Compositing for Weighted Blended Order-Independent Transparency. See: * - http://jcgt.org/published/0002/02/09/ * - http://casual-effects.blogspot.com/2014/03/weighted-blended-order-independent.html @@ -10942,7 +10942,7 @@ void main() out_FragColor.a = 1.0; } } -`;function RW(t){this._numSamples=1,this._translucentMultipassSupport=!1,this._translucentMRTSupport=!1;let e=t.colorBufferFloat&&t.depthTexture&&t.floatBlend;this._translucentMRTSupport=t.drawBuffers&&e,this._translucentMultipassSupport=!this._translucentMRTSupport&&e,this._opaqueFBO=void 0,this._opaqueTexture=void 0,this._depthStencilTexture=void 0,this._accumulationTexture=void 0,this._translucentFBO=new Ro({colorAttachmentsLength:this._translucentMRTSupport?2:1,createColorAttachments:!1,createDepthAttachments:!1,depth:!0}),this._alphaFBO=new Ro({createColorAttachments:!1,createDepthAttachments:!1,depth:!0}),this._adjustTranslucentFBO=new Ro({colorAttachmentsLength:this._translucentMRTSupport?2:1,createColorAttachments:!1}),this._adjustAlphaFBO=new Ro({createColorAttachments:!1}),this._opaqueClearCommand=new ao({color:new v(0,0,0,0),owner:this}),this._translucentMRTClearCommand=new ao({color:new v(0,0,0,1),owner:this}),this._translucentMultipassClearCommand=new ao({color:new v(0,0,0,0),owner:this}),this._alphaClearCommand=new ao({color:new v(1,1,1,1),owner:this}),this._translucentRenderStateCache={},this._alphaRenderStateCache={},this._compositeCommand=void 0,this._adjustTranslucentCommand=void 0,this._adjustAlphaCommand=void 0,this._viewport=new Fe,this._rs=void 0,this._useScissorTest=!1,this._scissorRectangle=void 0,this._useHDR=!1}function Qyt(t){t._accumulationTexture=t._accumulationTexture&&!t._accumulationTexture.isDestroyed()&&t._accumulationTexture.destroy(),t._revealageTexture=t._revealageTexture&&!t._revealageTexture.isDestroyed()&&t._revealageTexture.destroy()}function Uat(t){t._translucentFBO.destroy(),t._alphaFBO.destroy(),t._adjustTranslucentFBO.destroy(),t._adjustAlphaFBO.destroy()}function kyt(t){Qyt(t),Uat(t)}function zye(t,e,n,i){Qyt(t),t._accumulationTexture=new hn({context:e,width:n,height:i,pixelFormat:Ye.RGBA,pixelDatatype:Ue.FLOAT});let o=new Float32Array(n*i*4);t._revealageTexture=new hn({context:e,pixelFormat:Ye.RGBA,pixelDatatype:Ue.FLOAT,source:{arrayBufferView:o,width:n,height:i},flipY:!1})}function jye(t,e){Uat(t);let n=pt.FRAMEBUFFER_COMPLETE,i=!0,{width:o,height:a}=t._accumulationTexture;if(t._translucentMRTSupport&&(t._translucentFBO.setColorTexture(t._accumulationTexture,0),t._translucentFBO.setColorTexture(t._revealageTexture,1),t._translucentFBO.setDepthStencilTexture(t._depthStencilTexture),t._translucentFBO.update(e,o,a),t._adjustTranslucentFBO.setColorTexture(t._accumulationTexture,0),t._adjustTranslucentFBO.setColorTexture(t._revealageTexture,1),t._adjustTranslucentFBO.update(e,o,a),(t._translucentFBO.status!==n||t._adjustTranslucentFBO.status!==n)&&(Uat(t),t._translucentMRTSupport=!1)),!t._translucentMRTSupport){t._translucentFBO.setColorTexture(t._accumulationTexture),t._translucentFBO.setDepthStencilTexture(t._depthStencilTexture),t._translucentFBO.update(e,o,a),t._alphaFBO.setColorTexture(t._revealageTexture),t._alphaFBO.setDepthStencilTexture(t._depthStencilTexture),t._alphaFBO.update(e,o,a),t._adjustTranslucentFBO.setColorTexture(t._accumulationTexture),t._adjustTranslucentFBO.update(e,o,a),t._adjustAlphaFBO.setColorTexture(t._revealageTexture),t._adjustAlphaFBO.update(e,o,a);let s=t._translucentFBO.status===n,l=t._alphaFBO.status===n,r=t._adjustTranslucentFBO.status===n,d=t._adjustAlphaFBO.status===n;(!s||!l||!r||!d)&&(kyt(t),t._translucentMultipassSupport=!1,i=!1)}return i}RW.prototype.update=function(t,e,n,i,o){if(!this.isSupported())return;this._opaqueFBO=n,this._opaqueTexture=n.getColorTexture(0),this._depthStencilTexture=n.getDepthStencilTexture();let{width:a,height:s}=this._opaqueTexture,l=this._accumulationTexture,r=!c(l)||l.width!==a||l.height!==s||i!==this._useHDR,d=this._numSamples!==o;if((r||d)&&(this._numSamples=o,zye(this,t,a,s)),(!c(this._translucentFBO.framebuffer)||r||d)&&!jye(this,t))return;this._useHDR=i;let m=this,h,Z;c(this._compositeCommand)||(h=new Ve({sources:[H_]}),this._translucentMRTSupport&&h.defines.push("MRT"),Z={u_opaque:function(){return m._opaqueTexture},u_accumulation:function(){return m._accumulationTexture},u_revealage:function(){return m._revealageTexture}},this._compositeCommand=t.createViewportQuadCommand(h,{uniformMap:Z,owner:this})),c(this._adjustTranslucentCommand)||(this._translucentMRTSupport?(h=new Ve({defines:["MRT"],sources:[_1]}),Z={u_bgColor:function(){return m._translucentMRTClearCommand.color},u_depthTexture:function(){return m._depthStencilTexture}},this._adjustTranslucentCommand=t.createViewportQuadCommand(h,{uniformMap:Z,owner:this})):this._translucentMultipassSupport&&(h=new Ve({sources:[_1]}),Z={u_bgColor:function(){return m._translucentMultipassClearCommand.color},u_depthTexture:function(){return m._depthStencilTexture}},this._adjustTranslucentCommand=t.createViewportQuadCommand(h,{uniformMap:Z,owner:this}),Z={u_bgColor:function(){return m._alphaClearCommand.color},u_depthTexture:function(){return m._depthStencilTexture}},this._adjustAlphaCommand=t.createViewportQuadCommand(h,{uniformMap:Z,owner:this}))),this._viewport.width=a,this._viewport.height=s;let b=!Fe.equals(this._viewport,e.viewport),u=b!==this._useScissorTest;this._useScissorTest=b,Fe.equals(this._scissorRectangle,e.viewport)||(this._scissorRectangle=Fe.clone(e.viewport,this._scissorRectangle),u=!0),(!c(this._rs)||!Fe.equals(this._viewport,this._rs.viewport)||u)&&(this._rs=he.fromCache({viewport:this._viewport,scissorTest:{enabled:this._useScissorTest,rectangle:this._scissorRectangle}})),c(this._compositeCommand)&&(this._compositeCommand.renderState=this._rs),this._adjustTranslucentCommand&&(this._adjustTranslucentCommand.renderState=this._rs),c(this._adjustAlphaCommand)&&(this._adjustAlphaCommand.renderState=this._rs)};var qye={enabled:!0,color:new v(0,0,0,0),equationRgb:pd.ADD,equationAlpha:pd.ADD,functionSourceRgb:Ha.ONE,functionDestinationRgb:Ha.ONE,functionSourceAlpha:Ha.ZERO,functionDestinationAlpha:Ha.ONE_MINUS_SOURCE_ALPHA},$ye={enabled:!0,color:new v(0,0,0,0),equationRgb:pd.ADD,equationAlpha:pd.ADD,functionSourceRgb:Ha.ONE,functionDestinationRgb:Ha.ONE,functionSourceAlpha:Ha.ONE,functionDestinationAlpha:Ha.ONE},tBe={enabled:!0,color:new v(0,0,0,0),equationRgb:pd.ADD,equationAlpha:pd.ADD,functionSourceRgb:Ha.ZERO,functionDestinationRgb:Ha.ONE_MINUS_SOURCE_ALPHA,functionSourceAlpha:Ha.ZERO,functionDestinationAlpha:Ha.ONE_MINUS_SOURCE_ALPHA};function Gat(t,e,n,i){let o=n[i.id];if(!c(o)){let a=he.getState(i);a.depthMask=!1,a.blending=e,o=he.fromCache(a),n[i.id]=o}return o}function eBe(t,e,n){return Gat(e,qye,t._translucentRenderStateCache,n)}function nBe(t,e,n){return Gat(e,$ye,t._translucentRenderStateCache,n)}function iBe(t,e,n){return Gat(e,tBe,t._alphaRenderStateCache,n)}var oBe=` vec3 Ci = czm_out_FragColor.rgb * czm_out_FragColor.a; +`;function bW(t){this._numSamples=1,this._translucentMultipassSupport=!1,this._translucentMRTSupport=!1;let e=t.colorBufferFloat&&t.depthTexture&&t.floatBlend;this._translucentMRTSupport=t.drawBuffers&&e,this._translucentMultipassSupport=!this._translucentMRTSupport&&e,this._opaqueFBO=void 0,this._opaqueTexture=void 0,this._depthStencilTexture=void 0,this._accumulationTexture=void 0,this._translucentFBO=new bo({colorAttachmentsLength:this._translucentMRTSupport?2:1,createColorAttachments:!1,createDepthAttachments:!1,depth:!0}),this._alphaFBO=new bo({createColorAttachments:!1,createDepthAttachments:!1,depth:!0}),this._adjustTranslucentFBO=new bo({colorAttachmentsLength:this._translucentMRTSupport?2:1,createColorAttachments:!1}),this._adjustAlphaFBO=new bo({createColorAttachments:!1}),this._opaqueClearCommand=new ao({color:new v(0,0,0,0),owner:this}),this._translucentMRTClearCommand=new ao({color:new v(0,0,0,1),owner:this}),this._translucentMultipassClearCommand=new ao({color:new v(0,0,0,0),owner:this}),this._alphaClearCommand=new ao({color:new v(1,1,1,1),owner:this}),this._translucentRenderStateCache={},this._alphaRenderStateCache={},this._compositeCommand=void 0,this._adjustTranslucentCommand=void 0,this._adjustAlphaCommand=void 0,this._viewport=new Fe,this._rs=void 0,this._useScissorTest=!1,this._scissorRectangle=void 0,this._useHDR=!1}function Qyt(t){t._accumulationTexture=t._accumulationTexture&&!t._accumulationTexture.isDestroyed()&&t._accumulationTexture.destroy(),t._revealageTexture=t._revealageTexture&&!t._revealageTexture.isDestroyed()&&t._revealageTexture.destroy()}function Uat(t){t._translucentFBO.destroy(),t._alphaFBO.destroy(),t._adjustTranslucentFBO.destroy(),t._adjustAlphaFBO.destroy()}function kyt(t){Qyt(t),Uat(t)}function zye(t,e,n,i){Qyt(t),t._accumulationTexture=new hn({context:e,width:n,height:i,pixelFormat:Ye.RGBA,pixelDatatype:Ue.FLOAT});let o=new Float32Array(n*i*4);t._revealageTexture=new hn({context:e,pixelFormat:Ye.RGBA,pixelDatatype:Ue.FLOAT,source:{arrayBufferView:o,width:n,height:i},flipY:!1})}function jye(t,e){Uat(t);let n=pt.FRAMEBUFFER_COMPLETE,i=!0,{width:o,height:a}=t._accumulationTexture;if(t._translucentMRTSupport&&(t._translucentFBO.setColorTexture(t._accumulationTexture,0),t._translucentFBO.setColorTexture(t._revealageTexture,1),t._translucentFBO.setDepthStencilTexture(t._depthStencilTexture),t._translucentFBO.update(e,o,a),t._adjustTranslucentFBO.setColorTexture(t._accumulationTexture,0),t._adjustTranslucentFBO.setColorTexture(t._revealageTexture,1),t._adjustTranslucentFBO.update(e,o,a),(t._translucentFBO.status!==n||t._adjustTranslucentFBO.status!==n)&&(Uat(t),t._translucentMRTSupport=!1)),!t._translucentMRTSupport){t._translucentFBO.setColorTexture(t._accumulationTexture),t._translucentFBO.setDepthStencilTexture(t._depthStencilTexture),t._translucentFBO.update(e,o,a),t._alphaFBO.setColorTexture(t._revealageTexture),t._alphaFBO.setDepthStencilTexture(t._depthStencilTexture),t._alphaFBO.update(e,o,a),t._adjustTranslucentFBO.setColorTexture(t._accumulationTexture),t._adjustTranslucentFBO.update(e,o,a),t._adjustAlphaFBO.setColorTexture(t._revealageTexture),t._adjustAlphaFBO.update(e,o,a);let s=t._translucentFBO.status===n,l=t._alphaFBO.status===n,r=t._adjustTranslucentFBO.status===n,d=t._adjustAlphaFBO.status===n;(!s||!l||!r||!d)&&(kyt(t),t._translucentMultipassSupport=!1,i=!1)}return i}bW.prototype.update=function(t,e,n,i,o){if(!this.isSupported())return;this._opaqueFBO=n,this._opaqueTexture=n.getColorTexture(0),this._depthStencilTexture=n.getDepthStencilTexture();let{width:a,height:s}=this._opaqueTexture,l=this._accumulationTexture,r=!c(l)||l.width!==a||l.height!==s||i!==this._useHDR,d=this._numSamples!==o;if((r||d)&&(this._numSamples=o,zye(this,t,a,s)),(!c(this._translucentFBO.framebuffer)||r||d)&&!jye(this,t))return;this._useHDR=i;let m=this,h,u;c(this._compositeCommand)||(h=new Ze({sources:[H_]}),this._translucentMRTSupport&&h.defines.push("MRT"),u={u_opaque:function(){return m._opaqueTexture},u_accumulation:function(){return m._accumulationTexture},u_revealage:function(){return m._revealageTexture}},this._compositeCommand=t.createViewportQuadCommand(h,{uniformMap:u,owner:this})),c(this._adjustTranslucentCommand)||(this._translucentMRTSupport?(h=new Ze({defines:["MRT"],sources:[_1]}),u={u_bgColor:function(){return m._translucentMRTClearCommand.color},u_depthTexture:function(){return m._depthStencilTexture}},this._adjustTranslucentCommand=t.createViewportQuadCommand(h,{uniformMap:u,owner:this})):this._translucentMultipassSupport&&(h=new Ze({sources:[_1]}),u={u_bgColor:function(){return m._translucentMultipassClearCommand.color},u_depthTexture:function(){return m._depthStencilTexture}},this._adjustTranslucentCommand=t.createViewportQuadCommand(h,{uniformMap:u,owner:this}),u={u_bgColor:function(){return m._alphaClearCommand.color},u_depthTexture:function(){return m._depthStencilTexture}},this._adjustAlphaCommand=t.createViewportQuadCommand(h,{uniformMap:u,owner:this}))),this._viewport.width=a,this._viewport.height=s;let R=!Fe.equals(this._viewport,e.viewport),V=R!==this._useScissorTest;this._useScissorTest=R,Fe.equals(this._scissorRectangle,e.viewport)||(this._scissorRectangle=Fe.clone(e.viewport,this._scissorRectangle),V=!0),(!c(this._rs)||!Fe.equals(this._viewport,this._rs.viewport)||V)&&(this._rs=he.fromCache({viewport:this._viewport,scissorTest:{enabled:this._useScissorTest,rectangle:this._scissorRectangle}})),c(this._compositeCommand)&&(this._compositeCommand.renderState=this._rs),this._adjustTranslucentCommand&&(this._adjustTranslucentCommand.renderState=this._rs),c(this._adjustAlphaCommand)&&(this._adjustAlphaCommand.renderState=this._rs)};var qye={enabled:!0,color:new v(0,0,0,0),equationRgb:pd.ADD,equationAlpha:pd.ADD,functionSourceRgb:Ha.ONE,functionDestinationRgb:Ha.ONE,functionSourceAlpha:Ha.ZERO,functionDestinationAlpha:Ha.ONE_MINUS_SOURCE_ALPHA},$ye={enabled:!0,color:new v(0,0,0,0),equationRgb:pd.ADD,equationAlpha:pd.ADD,functionSourceRgb:Ha.ONE,functionDestinationRgb:Ha.ONE,functionSourceAlpha:Ha.ONE,functionDestinationAlpha:Ha.ONE},tBe={enabled:!0,color:new v(0,0,0,0),equationRgb:pd.ADD,equationAlpha:pd.ADD,functionSourceRgb:Ha.ZERO,functionDestinationRgb:Ha.ONE_MINUS_SOURCE_ALPHA,functionSourceAlpha:Ha.ZERO,functionDestinationAlpha:Ha.ONE_MINUS_SOURCE_ALPHA};function Gat(t,e,n,i){let o=n[i.id];if(!c(o)){let a=he.getState(i);a.depthMask=!1,a.blending=e,o=he.fromCache(a),n[i.id]=o}return o}function eBe(t,e,n){return Gat(e,qye,t._translucentRenderStateCache,n)}function nBe(t,e,n){return Gat(e,$ye,t._translucentRenderStateCache,n)}function iBe(t,e,n){return Gat(e,tBe,t._alphaRenderStateCache,n)}var oBe=` vec3 Ci = czm_out_FragColor.rgb * czm_out_FragColor.a; float ai = czm_out_FragColor.a; float wzi = czm_alphaWeight(ai); out_FragData_0 = vec4(Ci * wzi, ai); @@ -10953,7 +10953,7 @@ void main() out_FragColor = vec4(Ci, ai) * wzi; `,sBe=` float ai = czm_out_FragColor.a; out_FragColor = vec4(ai); -`;function Aat(t,e,n,i){let{shaderCache:o}=t,a=o.getDerivedShaderProgram(e,n);if(c(a))return a;let s=e._attributeLocations,l=e.fragmentShaderSource.clone();l.sources=l.sources.map(function(m){return Ve.replaceMain(m,"czm_translucent_main").replace(/out_FragColor/g,"czm_out_FragColor").replace(/layout\s*\(location\s*=\s*0\)\s*out\s+vec4\s+out_FragColor;/g,"").replace(/\bdiscard\b/g,"czm_discard = true").replace(/czm_phong/g,"czm_translucentPhong")}),l.sources.splice(0,0,`vec4 czm_out_FragColor; +`;function Aat(t,e,n,i){let{shaderCache:o}=t,a=o.getDerivedShaderProgram(e,n);if(c(a))return a;let s=e._attributeLocations,l=e.fragmentShaderSource.clone();l.sources=l.sources.map(function(m){return Ze.replaceMain(m,"czm_translucent_main").replace(/out_FragColor/g,"czm_out_FragColor").replace(/layout\s*\(location\s*=\s*0\)\s*out\s+vec4\s+out_FragColor;/g,"").replace(/\bdiscard\b/g,"czm_discard = true").replace(/czm_phong/g,"czm_translucentPhong")}),l.sources.splice(0,0,`vec4 czm_out_FragColor; bool czm_discard = false; `);let r=[...i.matchAll(/out_FragData_(\d+)/g)],d="";for(let m=0;m<r.length;m++){let h=r[m];d=`layout (location = ${h[1]}) out vec4 ${h[0]}; ${d}`}return l.sources.push(d),l.sources.push(`void main() @@ -10964,12 +10964,12 @@ ${d}`}return l.sources.push(d),l.sources.push(`void main() discard; } ${i}} -`),o.createDerivedShaderProgram(e,n,{vertexShaderSource:e.vertexShaderSource,fragmentShaderSource:l,attributeLocations:s})}function lBe(t,e){return Aat(t,e,"translucentMRT",oBe)}function rBe(t,e){return Aat(t,e,"translucentMultipass",aBe)}function dBe(t,e){return Aat(t,e,"alphaMultipass",sBe)}RW.prototype.createDerivedCommands=function(t,e,n){if(c(n)||(n={}),this._translucentMRTSupport){let l,r;return c(n.translucentCommand)&&(l=n.translucentCommand.shaderProgram,r=n.translucentCommand.renderState),n.translucentCommand=Ee.shallowClone(t,n.translucentCommand),!c(l)||n.shaderProgramId!==t.shaderProgram.id?(n.translucentCommand.shaderProgram=lBe(e,t.shaderProgram),n.translucentCommand.renderState=eBe(this,e,t.renderState),n.shaderProgramId=t.shaderProgram.id):(n.translucentCommand.shaderProgram=l,n.translucentCommand.renderState=r),n}let i,o,a,s;return c(n.translucentCommand)&&(i=n.translucentCommand.shaderProgram,o=n.translucentCommand.renderState,a=n.alphaCommand.shaderProgram,s=n.alphaCommand.renderState),n.translucentCommand=Ee.shallowClone(t,n.translucentCommand),n.alphaCommand=Ee.shallowClone(t,n.alphaCommand),!c(i)||n.shaderProgramId!==t.shaderProgram.id?(n.translucentCommand.shaderProgram=rBe(e,t.shaderProgram),n.translucentCommand.renderState=nBe(this,e,t.renderState),n.alphaCommand.shaderProgram=dBe(e,t.shaderProgram),n.alphaCommand.renderState=iBe(this,e,t.renderState),n.shaderProgramId=t.shaderProgram.id):(n.translucentCommand.shaderProgram=i,n.translucentCommand.renderState=o,n.alphaCommand.shaderProgram=a,n.alphaCommand.renderState=s),n};function cBe(t,e,n,i,o,a){let s,l,r,{context:d,frameState:m}=e,{useLogDepth:h,shadowState:Z}=m,b=e._hdr,u=i.framebuffer,F=Z.lightShadowsEnabled;i.framebuffer=t._adjustTranslucentFBO.framebuffer,t._adjustTranslucentCommand.execute(d,i),i.framebuffer=t._adjustAlphaFBO.framebuffer,t._adjustAlphaCommand.execute(d,i);let U=t._opaqueFBO.framebuffer;for(i.framebuffer=t._translucentFBO.framebuffer,r=0;r<o.length;++r)s=o[r],s=h?s.derivedCommands.logDepth.command:s,s=b?s.derivedCommands.hdr.command:s,l=F&&s.receiveShadows?s.derivedCommands.oit.shadows.translucentCommand:s.derivedCommands.oit.translucentCommand,n(l,e,d,i,U);for(c(a)&&(s=a.unclassifiedCommand,l=F&&s.receiveShadows?s.derivedCommands.oit.shadows.translucentCommand:s.derivedCommands.oit.translucentCommand,n(l,e,d,i,U)),i.framebuffer=t._alphaFBO.framebuffer,r=0;r<o.length;++r)s=o[r],s=h?s.derivedCommands.logDepth.command:s,s=b?s.derivedCommands.hdr.command:s,l=F&&s.receiveShadows?s.derivedCommands.oit.shadows.alphaCommand:s.derivedCommands.oit.alphaCommand,n(l,e,d,i,U);c(a)&&(s=a.unclassifiedCommand,l=F&&s.receiveShadows?s.derivedCommands.oit.shadows.alphaCommand:s.derivedCommands.oit.alphaCommand,n(l,e,d,i,U)),i.framebuffer=u}function mBe(t,e,n,i,o,a){let{context:s,frameState:l}=e,{useLogDepth:r,shadowState:d}=l,m=e._hdr,h=i.framebuffer,Z=d.lightShadowsEnabled;i.framebuffer=t._adjustTranslucentFBO.framebuffer,t._adjustTranslucentCommand.execute(s,i);let b=t._opaqueFBO.framebuffer;i.framebuffer=t._translucentFBO.framebuffer;let u,F;for(let U=0;U<o.length;++U)u=o[U],u=r?u.derivedCommands.logDepth.command:u,u=m?u.derivedCommands.hdr.command:u,F=Z&&u.receiveShadows?u.derivedCommands.oit.shadows.translucentCommand:u.derivedCommands.oit.translucentCommand,n(F,e,s,i,b);c(a)&&(u=a.unclassifiedCommand,F=Z&&u.receiveShadows?u.derivedCommands.oit.shadows.translucentCommand:u.derivedCommands.oit.translucentCommand,n(F,e,s,i,b)),i.framebuffer=h}RW.prototype.executeCommands=function(t,e,n,i,o){if(this._translucentMRTSupport){mBe(this,t,e,n,i,o);return}cBe(this,t,e,n,i,o)};RW.prototype.execute=function(t,e){this._compositeCommand.execute(t,e)};RW.prototype.clear=function(t,e,n){let i=e.framebuffer;e.framebuffer=this._opaqueFBO.framebuffer,v.clone(n,this._opaqueClearCommand.color),this._opaqueClearCommand.execute(t,e),e.framebuffer=this._translucentFBO.framebuffer,(this._translucentMRTSupport?this._translucentMRTClearCommand:this._translucentMultipassClearCommand).execute(t,e),this._translucentMultipassSupport&&(e.framebuffer=this._alphaFBO.framebuffer,this._alphaClearCommand.execute(t,e)),e.framebuffer=i};RW.prototype.isSupported=function(){return this._translucentMRTSupport||this._translucentMultipassSupport};RW.prototype.isDestroyed=function(){return!1};RW.prototype.destroy=function(){return kyt(this),c(this._compositeCommand)&&(this._compositeCommand.shaderProgram=this._compositeCommand.shaderProgram&&this._compositeCommand.shaderProgram.destroy()),c(this._adjustTranslucentCommand)&&(this._adjustTranslucentCommand.shaderProgram=this._adjustTranslucentCommand.shaderProgram&&this._adjustTranslucentCommand.shaderProgram.destroy()),c(this._adjustAlphaCommand)&&(this._adjustAlphaCommand.shaderProgram=this._adjustAlphaCommand.shaderProgram&&this._adjustAlphaCommand.shaderProgram.destroy()),At(this)};var w_=RW;var CIo=R(W(),1);function P_(){this._framebuffer=new Ro({color:!1,depthStencil:!0,supportsDepthTexture:!0}),this._passState=void 0}Object.defineProperties(P_.prototype,{framebuffer:{get:function(){return this._framebuffer.framebuffer}}});function hBe(t){t._framebuffer.destroy()}function pBe(t,e){let n=e.drawingBufferWidth,i=e.drawingBufferHeight;t._framebuffer.update(e,n,i);let o=new Md(e);o.blendingEnabled=!1,o.scissorTest={enabled:!0,rectangle:new Fe},o.viewport=new Fe,t._passState=o}P_.prototype.update=function(t,e,n){let i=n.width,o=n.height;this._framebuffer.isDirty(i,o)&&pBe(this,t);let a=this.framebuffer,s=this._passState;return s.framebuffer=a,s.viewport.width=i,s.viewport.height=o,s.scissorTest.rectangle.x=e.x,s.scissorTest.rectangle.y=o-e.y,s.scissorTest.rectangle.width=1,s.scissorTest.rectangle.height=1,s};P_.prototype.isDestroyed=function(){return!1};P_.prototype.destroy=function(){return hBe(this),At(this)};var v_=P_;var XIo=R(W(),1);function D1(t){let e=new Md(t);e.blendingEnabled=!1,e.scissorTest={enabled:!0,rectangle:new Fe},e.viewport=new Fe,this._context=t,this._fb=new Ro({depthStencil:!0}),this._passState=e,this._width=0,this._height=0}D1.prototype.begin=function(t,e){let n=this._context,{width:i,height:o}=e;return Fe.clone(t,this._passState.scissorTest.rectangle),this._width=i,this._height=o,this._fb.update(n,i,o),this._passState.framebuffer=this._fb.framebuffer,this._passState.viewport.width=i,this._passState.viewport.height=o,this._passState};var K_=new v;D1.prototype.end=function(t){let e=f(t.width,1),n=f(t.height,1),i=this._context,o=i.readPixels({x:t.x,y:t.y,width:e,height:n,framebuffer:this._fb.framebuffer}),a=Math.max(e,n),s=a*a,l=Math.floor(e*.5),r=Math.floor(n*.5),d=0,m=0,h=0,Z=-1;for(let b=0;b<s;++b){if(-l<=d&&d<=l&&-r<=m&&m<=r){let u=4*((r-m)*e+d+l);K_.red=v.byteToFloat(o[u]),K_.green=v.byteToFloat(o[u+1]),K_.blue=v.byteToFloat(o[u+2]),K_.alpha=v.byteToFloat(o[u+3]);let F=i.getObjectByPickColor(K_);if(c(F))return F}if(d===m||d<0&&-d===m||d>0&&d===1-m){let u=h;h=-Z,Z=u}d+=h,m+=Z}};D1.prototype.readVoxelInfo=function(t){let e=f(t.width,1),n=f(t.height,1),o=this._context.readPixels({x:t.x,y:t.y,width:e,height:n,framebuffer:this._fb.framebuffer}),a=Math.floor(e*.5),l=4*(Math.floor(n*.5)*e+a);return o.slice(l,l+4)};D1.prototype.isDestroyed=function(){return!1};D1.prototype.destroy=function(){return this._fb.destroy(),At(this)};var z_=D1;var HIo=R(W(),1);function WW(){this._numSamples=1,this._colorFramebuffer=new Ro({depthStencil:!0,supportsDepthTexture:!0}),this._idFramebuffer=new Ro({depthStencil:!0,supportsDepthTexture:!0}),this._idClearColor=new v(0,0,0,0),this._clearCommand=new ao({color:new v(0,0,0,0),depth:1,owner:this})}function uBe(t){t._colorFramebuffer.destroy(),t._idFramebuffer.destroy()}Object.defineProperties(WW.prototype,{framebuffer:{get:function(){return this._colorFramebuffer.framebuffer}},idFramebuffer:{get:function(){return this._idFramebuffer.framebuffer}},depthStencilTexture:{get:function(){return this._colorFramebuffer.getDepthStencilTexture()}}});WW.prototype.update=function(t,e,n,i){let o=e.width,a=e.height,s=n?t.halfFloatingPointTexture?Ue.HALF_FLOAT:Ue.FLOAT:Ue.UNSIGNED_BYTE;this._numSamples=i,this._colorFramebuffer.update(t,o,a,i,s),this._idFramebuffer.update(t,o,a)};WW.prototype.clear=function(t,e,n){v.clone(n,this._clearCommand.color),v.clone(this._idClearColor,this._clearCommand.color),this._colorFramebuffer.clear(t,this._clearCommand,e),this._idFramebuffer.clear(t,this._clearCommand,e)};WW.prototype.getFramebuffer=function(){return this._colorFramebuffer.framebuffer};WW.prototype.getIdFramebuffer=function(){return this._idFramebuffer.framebuffer};WW.prototype.prepareColorTextures=function(t){this._numSamples>1&&this._colorFramebuffer.prepareTextures(t)};WW.prototype.isDestroyed=function(){return!1};WW.prototype.destroy=function(){return uBe(this),At(this)};var FS=WW;var _1o=R(W(),1);var KIo=R(W(),1);function US(){}US.getShadowCastShaderKeyword=function(t,e,n,i){return`castShadow ${t} ${e} ${n} ${i}`};US.createShadowCastVertexShader=function(t,e,n){let i=t.defines.slice(0),o=t.sources.slice(0);i.push("SHADOW_MAP"),n&&i.push("GENERATE_POSITION");let a=Ve.findPositionVarying(t),s=c(a);if(e&&!s){let l=o.length;for(let d=0;d<l;++d)o[d]=Ve.replaceMain(o[d],"czm_shadow_cast_main");o.push(`out vec3 v_positionEC; +`),o.createDerivedShaderProgram(e,n,{vertexShaderSource:e.vertexShaderSource,fragmentShaderSource:l,attributeLocations:s})}function lBe(t,e){return Aat(t,e,"translucentMRT",oBe)}function rBe(t,e){return Aat(t,e,"translucentMultipass",aBe)}function dBe(t,e){return Aat(t,e,"alphaMultipass",sBe)}bW.prototype.createDerivedCommands=function(t,e,n){if(c(n)||(n={}),this._translucentMRTSupport){let l,r;return c(n.translucentCommand)&&(l=n.translucentCommand.shaderProgram,r=n.translucentCommand.renderState),n.translucentCommand=Ee.shallowClone(t,n.translucentCommand),!c(l)||n.shaderProgramId!==t.shaderProgram.id?(n.translucentCommand.shaderProgram=lBe(e,t.shaderProgram),n.translucentCommand.renderState=eBe(this,e,t.renderState),n.shaderProgramId=t.shaderProgram.id):(n.translucentCommand.shaderProgram=l,n.translucentCommand.renderState=r),n}let i,o,a,s;return c(n.translucentCommand)&&(i=n.translucentCommand.shaderProgram,o=n.translucentCommand.renderState,a=n.alphaCommand.shaderProgram,s=n.alphaCommand.renderState),n.translucentCommand=Ee.shallowClone(t,n.translucentCommand),n.alphaCommand=Ee.shallowClone(t,n.alphaCommand),!c(i)||n.shaderProgramId!==t.shaderProgram.id?(n.translucentCommand.shaderProgram=rBe(e,t.shaderProgram),n.translucentCommand.renderState=nBe(this,e,t.renderState),n.alphaCommand.shaderProgram=dBe(e,t.shaderProgram),n.alphaCommand.renderState=iBe(this,e,t.renderState),n.shaderProgramId=t.shaderProgram.id):(n.translucentCommand.shaderProgram=i,n.translucentCommand.renderState=o,n.alphaCommand.shaderProgram=a,n.alphaCommand.renderState=s),n};function cBe(t,e,n,i,o,a){let s,l,r,{context:d,frameState:m}=e,{useLogDepth:h,shadowState:u}=m,R=e._hdr,V=i.framebuffer,F=u.lightShadowsEnabled;i.framebuffer=t._adjustTranslucentFBO.framebuffer,t._adjustTranslucentCommand.execute(d,i),i.framebuffer=t._adjustAlphaFBO.framebuffer,t._adjustAlphaCommand.execute(d,i);let U=t._opaqueFBO.framebuffer;for(i.framebuffer=t._translucentFBO.framebuffer,r=0;r<o.length;++r)s=o[r],s=h?s.derivedCommands.logDepth.command:s,s=R?s.derivedCommands.hdr.command:s,l=F&&s.receiveShadows?s.derivedCommands.oit.shadows.translucentCommand:s.derivedCommands.oit.translucentCommand,n(l,e,d,i,U);for(c(a)&&(s=a.unclassifiedCommand,l=F&&s.receiveShadows?s.derivedCommands.oit.shadows.translucentCommand:s.derivedCommands.oit.translucentCommand,n(l,e,d,i,U)),i.framebuffer=t._alphaFBO.framebuffer,r=0;r<o.length;++r)s=o[r],s=h?s.derivedCommands.logDepth.command:s,s=R?s.derivedCommands.hdr.command:s,l=F&&s.receiveShadows?s.derivedCommands.oit.shadows.alphaCommand:s.derivedCommands.oit.alphaCommand,n(l,e,d,i,U);c(a)&&(s=a.unclassifiedCommand,l=F&&s.receiveShadows?s.derivedCommands.oit.shadows.alphaCommand:s.derivedCommands.oit.alphaCommand,n(l,e,d,i,U)),i.framebuffer=V}function mBe(t,e,n,i,o,a){let{context:s,frameState:l}=e,{useLogDepth:r,shadowState:d}=l,m=e._hdr,h=i.framebuffer,u=d.lightShadowsEnabled;i.framebuffer=t._adjustTranslucentFBO.framebuffer,t._adjustTranslucentCommand.execute(s,i);let R=t._opaqueFBO.framebuffer;i.framebuffer=t._translucentFBO.framebuffer;let V,F;for(let U=0;U<o.length;++U)V=o[U],V=r?V.derivedCommands.logDepth.command:V,V=m?V.derivedCommands.hdr.command:V,F=u&&V.receiveShadows?V.derivedCommands.oit.shadows.translucentCommand:V.derivedCommands.oit.translucentCommand,n(F,e,s,i,R);c(a)&&(V=a.unclassifiedCommand,F=u&&V.receiveShadows?V.derivedCommands.oit.shadows.translucentCommand:V.derivedCommands.oit.translucentCommand,n(F,e,s,i,R)),i.framebuffer=h}bW.prototype.executeCommands=function(t,e,n,i,o){if(this._translucentMRTSupport){mBe(this,t,e,n,i,o);return}cBe(this,t,e,n,i,o)};bW.prototype.execute=function(t,e){this._compositeCommand.execute(t,e)};bW.prototype.clear=function(t,e,n){let i=e.framebuffer;e.framebuffer=this._opaqueFBO.framebuffer,v.clone(n,this._opaqueClearCommand.color),this._opaqueClearCommand.execute(t,e),e.framebuffer=this._translucentFBO.framebuffer,(this._translucentMRTSupport?this._translucentMRTClearCommand:this._translucentMultipassClearCommand).execute(t,e),this._translucentMultipassSupport&&(e.framebuffer=this._alphaFBO.framebuffer,this._alphaClearCommand.execute(t,e)),e.framebuffer=i};bW.prototype.isSupported=function(){return this._translucentMRTSupport||this._translucentMultipassSupport};bW.prototype.isDestroyed=function(){return!1};bW.prototype.destroy=function(){return kyt(this),c(this._compositeCommand)&&(this._compositeCommand.shaderProgram=this._compositeCommand.shaderProgram&&this._compositeCommand.shaderProgram.destroy()),c(this._adjustTranslucentCommand)&&(this._adjustTranslucentCommand.shaderProgram=this._adjustTranslucentCommand.shaderProgram&&this._adjustTranslucentCommand.shaderProgram.destroy()),c(this._adjustAlphaCommand)&&(this._adjustAlphaCommand.shaderProgram=this._adjustAlphaCommand.shaderProgram&&this._adjustAlphaCommand.shaderProgram.destroy()),At(this)};var w_=bW;var CIo=b(W(),1);function P_(){this._framebuffer=new bo({color:!1,depthStencil:!0,supportsDepthTexture:!0}),this._passState=void 0}Object.defineProperties(P_.prototype,{framebuffer:{get:function(){return this._framebuffer.framebuffer}}});function hBe(t){t._framebuffer.destroy()}function pBe(t,e){let n=e.drawingBufferWidth,i=e.drawingBufferHeight;t._framebuffer.update(e,n,i);let o=new Md(e);o.blendingEnabled=!1,o.scissorTest={enabled:!0,rectangle:new Fe},o.viewport=new Fe,t._passState=o}P_.prototype.update=function(t,e,n){let i=n.width,o=n.height;this._framebuffer.isDirty(i,o)&&pBe(this,t);let a=this.framebuffer,s=this._passState;return s.framebuffer=a,s.viewport.width=i,s.viewport.height=o,s.scissorTest.rectangle.x=e.x,s.scissorTest.rectangle.y=o-e.y,s.scissorTest.rectangle.width=1,s.scissorTest.rectangle.height=1,s};P_.prototype.isDestroyed=function(){return!1};P_.prototype.destroy=function(){return hBe(this),At(this)};var v_=P_;var XIo=b(W(),1);function D1(t){let e=new Md(t);e.blendingEnabled=!1,e.scissorTest={enabled:!0,rectangle:new Fe},e.viewport=new Fe,this._context=t,this._fb=new bo({depthStencil:!0}),this._passState=e,this._width=0,this._height=0}D1.prototype.begin=function(t,e){let n=this._context,{width:i,height:o}=e;return Fe.clone(t,this._passState.scissorTest.rectangle),this._width=i,this._height=o,this._fb.update(n,i,o),this._passState.framebuffer=this._fb.framebuffer,this._passState.viewport.width=i,this._passState.viewport.height=o,this._passState};var K_=new v;D1.prototype.end=function(t){let e=f(t.width,1),n=f(t.height,1),i=this._context,o=i.readPixels({x:t.x,y:t.y,width:e,height:n,framebuffer:this._fb.framebuffer}),a=Math.max(e,n),s=a*a,l=Math.floor(e*.5),r=Math.floor(n*.5),d=0,m=0,h=0,u=-1;for(let R=0;R<s;++R){if(-l<=d&&d<=l&&-r<=m&&m<=r){let V=4*((r-m)*e+d+l);K_.red=v.byteToFloat(o[V]),K_.green=v.byteToFloat(o[V+1]),K_.blue=v.byteToFloat(o[V+2]),K_.alpha=v.byteToFloat(o[V+3]);let F=i.getObjectByPickColor(K_);if(c(F))return F}if(d===m||d<0&&-d===m||d>0&&d===1-m){let V=h;h=-u,u=V}d+=h,m+=u}};D1.prototype.readVoxelInfo=function(t){let e=f(t.width,1),n=f(t.height,1),o=this._context.readPixels({x:t.x,y:t.y,width:e,height:n,framebuffer:this._fb.framebuffer}),a=Math.floor(e*.5),l=4*(Math.floor(n*.5)*e+a);return o.slice(l,l+4)};D1.prototype.isDestroyed=function(){return!1};D1.prototype.destroy=function(){return this._fb.destroy(),At(this)};var z_=D1;var HIo=b(W(),1);function WW(){this._numSamples=1,this._colorFramebuffer=new bo({depthStencil:!0,supportsDepthTexture:!0}),this._idFramebuffer=new bo({depthStencil:!0,supportsDepthTexture:!0}),this._idClearColor=new v(0,0,0,0),this._clearCommand=new ao({color:new v(0,0,0,0),depth:1,owner:this})}function VBe(t){t._colorFramebuffer.destroy(),t._idFramebuffer.destroy()}Object.defineProperties(WW.prototype,{framebuffer:{get:function(){return this._colorFramebuffer.framebuffer}},idFramebuffer:{get:function(){return this._idFramebuffer.framebuffer}},depthStencilTexture:{get:function(){return this._colorFramebuffer.getDepthStencilTexture()}}});WW.prototype.update=function(t,e,n,i){let o=e.width,a=e.height,s=n?t.halfFloatingPointTexture?Ue.HALF_FLOAT:Ue.FLOAT:Ue.UNSIGNED_BYTE;this._numSamples=i,this._colorFramebuffer.update(t,o,a,i,s),this._idFramebuffer.update(t,o,a)};WW.prototype.clear=function(t,e,n){v.clone(n,this._clearCommand.color),v.clone(this._idClearColor,this._clearCommand.color),this._colorFramebuffer.clear(t,this._clearCommand,e),this._idFramebuffer.clear(t,this._clearCommand,e)};WW.prototype.getFramebuffer=function(){return this._colorFramebuffer.framebuffer};WW.prototype.getIdFramebuffer=function(){return this._idFramebuffer.framebuffer};WW.prototype.prepareColorTextures=function(t){this._numSamples>1&&this._colorFramebuffer.prepareTextures(t)};WW.prototype.isDestroyed=function(){return!1};WW.prototype.destroy=function(){return VBe(this),At(this)};var FT=WW;var _1o=b(W(),1);var KIo=b(W(),1);function UT(){}UT.getShadowCastShaderKeyword=function(t,e,n,i){return`castShadow ${t} ${e} ${n} ${i}`};UT.createShadowCastVertexShader=function(t,e,n){let i=t.defines.slice(0),o=t.sources.slice(0);i.push("SHADOW_MAP"),n&&i.push("GENERATE_POSITION");let a=Ze.findPositionVarying(t),s=c(a);if(e&&!s){let l=o.length;for(let d=0;d<l;++d)o[d]=Ze.replaceMain(o[d],"czm_shadow_cast_main");o.push(`out vec3 v_positionEC; void main() { czm_shadow_cast_main(); v_positionEC = (czm_inverseProjection * gl_Position).xyz; -}`)}return new Ve({defines:i,sources:o})};US.createShadowCastFragmentShader=function(t,e,n,i){let o=t.defines.slice(0),a=t.sources.slice(0);o.push("SHADOW_MAP");let s=Ve.findPositionVarying(t),l=c(s);l||(s="v_positionEC");let r=a.length;for(let m=0;m<r;++m)a[m]=Ve.replaceMain(a[m],"czm_shadow_cast_main");let d="";return e&&(l||(d+=`in vec3 v_positionEC; +}`)}return new Ze({defines:i,sources:o})};UT.createShadowCastFragmentShader=function(t,e,n,i){let o=t.defines.slice(0),a=t.sources.slice(0);o.push("SHADOW_MAP");let s=Ze.findPositionVarying(t),l=c(s);l||(s="v_positionEC");let r=a.length;for(let m=0;m<r;++m)a[m]=Ze.replaceMain(a[m],"czm_shadow_cast_main");let d="";return e&&(l||(d+=`in vec3 v_positionEC; `),d+=`uniform vec4 shadowMap_lightPositionEC; `),i?d+=`void main() { @@ -10990,7 +10990,7 @@ void main() `:n?d+=` out_FragColor = vec4(1.0); `:d+=` out_FragColor = czm_packDepth(gl_FragCoord.z); `,d+=`} -`,a.push(d),new Ve({defines:o,sources:a})};US.getShadowReceiveShaderKeyword=function(t,e,n,i){let o=t._usesDepthTexture,a=t._polygonOffsetSupported,s=t._isPointLight,l=t._isSpotLight,r=t._numberOfCascades>1,d=t.debugCascadeColors,m=t.softShadows;return`receiveShadow ${o}${a}${s}${l}${r}${d}${m}${e}${n}${i}`};US.createShadowReceiveVertexShader=function(t,e,n){let i=t.defines.slice(0),o=t.sources.slice(0);return i.push("SHADOW_MAP"),e&&(n?i.push("GENERATE_POSITION_AND_NORMAL"):i.push("GENERATE_POSITION")),new Ve({defines:i,sources:o})};US.createShadowReceiveFragmentShader=function(t,e,n,i,o){let a=Ve.findNormalVarying(t),s=!i&&c(a)||i&&o,l=Ve.findPositionVarying(t),r=c(l),d=e._usesDepthTexture,m=e._polygonOffsetSupported,h=e._isPointLight,Z=e._isSpotLight,b=e._numberOfCascades>1,u=e.debugCascadeColors,F=e.softShadows,U=h?e._pointBias:i?e._terrainBias:e._primitiveBias,G=t.defines.slice(0),A=t.sources.slice(0),T=A.length;for(let y=0;y<T;++y)A[y]=Ve.replaceMain(A[y],"czm_shadow_receive_main");h?G.push("USE_CUBE_MAP_SHADOW"):d&&G.push("USE_SHADOW_DEPTH_TEXTURE"),F&&!h&&G.push("USE_SOFT_SHADOWS"),b&&n&&i&&(s?G.push("ENABLE_VERTEX_LIGHTING"):G.push("ENABLE_DAYNIGHT_SHADING")),n&&U.normalShading&&s&&(G.push("USE_NORMAL_SHADING"),U.normalShadingSmooth>0&&G.push("USE_NORMAL_SHADING_SMOOTH"));let g="";h?g+=`uniform samplerCube shadowMap_textureCube; +`,a.push(d),new Ze({defines:o,sources:a})};UT.getShadowReceiveShaderKeyword=function(t,e,n,i){let o=t._usesDepthTexture,a=t._polygonOffsetSupported,s=t._isPointLight,l=t._isSpotLight,r=t._numberOfCascades>1,d=t.debugCascadeColors,m=t.softShadows;return`receiveShadow ${o}${a}${s}${l}${r}${d}${m}${e}${n}${i}`};UT.createShadowReceiveVertexShader=function(t,e,n){let i=t.defines.slice(0),o=t.sources.slice(0);return i.push("SHADOW_MAP"),e&&(n?i.push("GENERATE_POSITION_AND_NORMAL"):i.push("GENERATE_POSITION")),new Ze({defines:i,sources:o})};UT.createShadowReceiveFragmentShader=function(t,e,n,i,o){let a=Ze.findNormalVarying(t),s=!i&&c(a)||i&&o,l=Ze.findPositionVarying(t),r=c(l),d=e._usesDepthTexture,m=e._polygonOffsetSupported,h=e._isPointLight,u=e._isSpotLight,R=e._numberOfCascades>1,V=e.debugCascadeColors,F=e.softShadows,U=h?e._pointBias:i?e._terrainBias:e._primitiveBias,G=t.defines.slice(0),A=t.sources.slice(0),S=A.length;for(let y=0;y<S;++y)A[y]=Ze.replaceMain(A[y],"czm_shadow_receive_main");h?G.push("USE_CUBE_MAP_SHADOW"):d&&G.push("USE_SHADOW_DEPTH_TEXTURE"),F&&!h&&G.push("USE_SOFT_SHADOWS"),R&&n&&i&&(s?G.push("ENABLE_VERTEX_LIGHTING"):G.push("ENABLE_DAYNIGHT_SHADING")),n&&U.normalShading&&s&&(G.push("USE_NORMAL_SHADING"),U.normalShadingSmooth>0&&G.push("USE_NORMAL_SHADING_SMOOTH"));let g="";h?g+=`uniform samplerCube shadowMap_textureCube; `:g+=`uniform sampler2D shadowMap_texture; `;let C;return r?C=` return vec4(${l}, 1.0); `:C=`#ifndef LOG_DEPTH @@ -11048,7 +11048,7 @@ ${U.normalOffset&&s?` float normalOffset = shadowMap_normalOffsetScaleDistanc shadowParameters.nDotL = clamp(dot(normalEC, -directionEC), 0.0, 1.0); shadowParameters.texCoords = directionWC; float visibility = czm_shadowVisibility(shadowMap_textureCube, shadowParameters); -`:Z?g+=` vec3 directionEC = normalize(positionEC.xyz - shadowMap_lightPositionEC.xyz); +`:u?g+=` vec3 directionEC = normalize(positionEC.xyz - shadowMap_lightPositionEC.xyz); float nDotL = clamp(dot(normalEC, -directionEC), 0.0, 1.0); applyNormalOffset(positionEC, normalEC, nDotL); vec4 shadowPosition = shadowMap_matrix * positionEC; @@ -11063,7 +11063,7 @@ ${U.normalOffset&&s?` float normalOffset = shadowMap_normalOffsetScaleDistanc shadowParameters.depth = shadowPosition.z; shadowParameters.nDotL = nDotL; float visibility = czm_shadowVisibility(shadowMap_texture, shadowParameters); -`:b?g+=` float maxDepth = shadowMap_cascadeSplits[1].w; +`:R?g+=` float maxDepth = shadowMap_cascadeSplits[1].w; // Stop early if the eye depth exceeds the last cascade if (depth > maxDepth) { @@ -11085,7 +11085,7 @@ ${U.normalOffset&&s?` float normalOffset = shadowMap_normalOffsetScaleDistanc float shadowMapMaximumDistance = shadowMap_normalOffsetScaleDistanceMaxDistanceAndDarkness.z; float fade = max((depth - shadowMapMaximumDistance * 0.8) / (shadowMapMaximumDistance * 0.2), 0.0); visibility = mix(visibility, 1.0, fade); -${u?` // Draw cascade colors for debugging +${V?` // Draw cascade colors for debugging out_FragColor *= czm_cascadeColor(weights); `:""}`:g+=` float nDotL = clamp(dot(normalEC, shadowMap_lightDirectionEC), 0.0, 1.0); applyNormalOffset(positionEC, normalEC, nDotL); @@ -11101,7 +11101,7 @@ ${u?` // Draw cascade colors for debugging float visibility = czm_shadowVisibility(shadowMap_texture, shadowParameters); `,g+=` out_FragColor.rgb *= visibility; } -`,A.push(g),new Ve({defines:G,sources:A})};var Db=US;function Ob(t){t=f(t,f.EMPTY_OBJECT);let e=t.context;this._enabled=f(t.enabled,!0),this._softShadows=f(t.softShadows,!1),this._normalOffset=f(t.normalOffset,!0),this.dirty=!0,this.fromLightSource=f(t.fromLightSource,!0),this.darkness=f(t.darkness,.3),this._darkness=this.darkness,this.fadingEnabled=f(t.fadingEnabled,!0),this.maximumDistance=f(t.maximumDistance,5e3),this._outOfView=!1,this._outOfViewPrevious=!1,this._needsUpdate=!0;let n=!0;(In.isInternetExplorer()||In.isEdge()||(In.isChrome()||In.isFirefox())&&In.isWindows()&&!e.depthTexture)&&(n=!1),this._polygonOffsetSupported=n,this._terrainBias={polygonOffset:n,polygonOffsetFactor:1.1,polygonOffsetUnits:4,normalOffset:this._normalOffset,normalOffsetScale:.5,normalShading:!0,normalShadingSmooth:.3,depthBias:1e-4},this._primitiveBias={polygonOffset:n,polygonOffsetFactor:1.1,polygonOffsetUnits:4,normalOffset:this._normalOffset,normalOffsetScale:.1,normalShading:!0,normalShadingSmooth:.05,depthBias:2e-5},this._pointBias={polygonOffset:!1,polygonOffsetFactor:1.1,polygonOffsetUnits:4,normalOffset:this._normalOffset,normalOffsetScale:0,normalShading:!0,normalShadingSmooth:.1,depthBias:5e-4},this._depthAttachment=void 0,this._colorAttachment=void 0,this._shadowMapMatrix=new L,this._shadowMapTexture=void 0,this._lightDirectionEC=new p,this._lightPositionEC=new Rt,this._distance=0,this._lightCamera=t.lightCamera,this._shadowMapCamera=new sj,this._shadowMapCullingVolume=void 0,this._sceneCamera=void 0,this._boundingSphere=new Ft,this._isPointLight=f(t.isPointLight,!1),this._pointLightRadius=f(t.pointLightRadius,100),this._cascadesEnabled=this._isPointLight?!1:f(t.cascadesEnabled,!0),this._numberOfCascades=this._cascadesEnabled?f(t.numberOfCascades,4):0,this._fitNearFar=!0,this._maximumCascadeDistances=[25,150,700,Number.MAX_VALUE],this._textureSize=new K,this._isSpotLight=!1,this._cascadesEnabled?this._shadowMapCamera.frustum=new el:c(this._lightCamera.frustum.fov)&&(this._isSpotLight=!0),this._cascadeSplits=[new Rt,new Rt],this._cascadeMatrices=[new L,new L,new L,new L],this._cascadeDistances=new Rt;let i;this._isPointLight?i=6:this._cascadesEnabled?i=this._numberOfCascades:i=1,this._passes=new Array(i);for(let o=0;o<i;++o)this._passes[o]=new ZBe(e);this.debugShow=!1,this.debugFreezeFrame=!1,this._debugFreezeFrame=!1,this._debugCascadeColors=!1,this._debugLightFrustum=void 0,this._debugCameraFrustum=void 0,this._debugCascadeFrustums=new Array(this._numberOfCascades),this._debugShadowViewCommand=void 0,this._usesDepthTexture=e.depthTexture,this._isPointLight&&(this._usesDepthTexture=!1),this._primitiveRenderState=void 0,this._terrainRenderState=void 0,this._pointRenderState=void 0,Sat(this),this._clearCommand=new ao({depth:1,color:new v}),this._clearPassState=new Md(e),this._size=f(t.size,2048),this.size=this._size}Ob.MAXIMUM_DISTANCE=2e4;function ZBe(t){this.camera=new sj,this.passState=new Md(t),this.framebuffer=void 0,this.textureOffsets=void 0,this.commandList=[],this.cullingVolume=void 0}function Tat(t,e){return he.fromCache({cull:{enabled:!0,face:so.BACK},depthTest:{enabled:!0},colorMask:{red:t,green:t,blue:t,alpha:t},depthMask:!0,polygonOffset:{enabled:e.polygonOffset,factor:e.polygonOffsetFactor,units:e.polygonOffsetUnits}})}function Sat(t){let e=!t._usesDepthTexture;t._primitiveRenderState=Tat(e,t._primitiveBias),t._terrainRenderState=Tat(e,t._terrainBias),t._pointRenderState=Tat(e,t._pointBias)}Ob.prototype.debugCreateRenderStates=function(){Sat(this)};Object.defineProperties(Ob.prototype,{enabled:{get:function(){return this._enabled},set:function(t){this.dirty=this._enabled!==t,this._enabled=t}},normalOffset:{get:function(){return this._normalOffset},set:function(t){this.dirty=this._normalOffset!==t,this._normalOffset=t,this._terrainBias.normalOffset=t,this._primitiveBias.normalOffset=t,this._pointBias.normalOffset=t}},softShadows:{get:function(){return this._softShadows},set:function(t){this.dirty=this._softShadows!==t,this._softShadows=t}},size:{get:function(){return this._size},set:function(t){FBe(this,t)}},outOfView:{get:function(){return this._outOfView}},shadowMapCullingVolume:{get:function(){return this._shadowMapCullingVolume}},passes:{get:function(){return this._passes}},isPointLight:{get:function(){return this._isPointLight}},debugCascadeColors:{get:function(){return this._debugCascadeColors},set:function(t){this.dirty=this._debugCascadeColors!==t,this._debugCascadeColors=t}}});function gat(t){let e=t._passes.length;for(let n=0;n<e;++n){let i=t._passes[n],o=i.framebuffer;c(o)&&!o.isDestroyed()&&o.destroy(),i.framebuffer=void 0}t._depthAttachment=t._depthAttachment&&t._depthAttachment.destroy(),t._colorAttachment=t._colorAttachment&&t._colorAttachment.destroy()}function VBe(t,e){let n=new bh({context:e,width:t._textureSize.x,height:t._textureSize.y,format:Sc.DEPTH_COMPONENT16}),i=new hn({context:e,width:t._textureSize.x,height:t._textureSize.y,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,sampler:Hn.NEAREST}),o=new Lr({context:e,depthRenderbuffer:n,colorTextures:[i],destroyAttachments:!1}),a=t._passes.length;for(let s=0;s<a;++s){let l=t._passes[s];l.framebuffer=o,l.passState.framebuffer=o}t._shadowMapTexture=i,t._depthAttachment=n,t._colorAttachment=i}function bBe(t,e){let n=new hn({context:e,width:t._textureSize.x,height:t._textureSize.y,pixelFormat:Ye.DEPTH_STENCIL,pixelDatatype:Ue.UNSIGNED_INT_24_8,sampler:Hn.NEAREST}),i=new Lr({context:e,depthStencilTexture:n,destroyAttachments:!1}),o=t._passes.length;for(let a=0;a<o;++a){let s=t._passes[a];s.framebuffer=i,s.passState.framebuffer=i}t._shadowMapTexture=n,t._depthAttachment=n}function RBe(t,e){let n=new bh({context:e,width:t._textureSize.x,height:t._textureSize.y,format:Sc.DEPTH_COMPONENT16}),i=new Ld({context:e,width:t._textureSize.x,height:t._textureSize.y,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,sampler:Hn.NEAREST}),o=[i.negativeX,i.negativeY,i.negativeZ,i.positiveX,i.positiveY,i.positiveZ];for(let a=0;a<6;++a){let s=new Lr({context:e,depthRenderbuffer:n,colorTextures:[o[a]],destroyAttachments:!1}),l=t._passes[a];l.framebuffer=s,l.passState.framebuffer=s}t._shadowMapTexture=i,t._depthAttachment=n,t._colorAttachment=i}function Xyt(t,e){t._isPointLight?RBe(t,e):t._usesDepthTexture?bBe(t,e):VBe(t,e)}function WBe(t,e){t._usesDepthTexture&&t._passes[0].framebuffer.status!==pt.FRAMEBUFFER_COMPLETE&&(t._usesDepthTexture=!1,Sat(t),gat(t),Xyt(t,e))}function fBe(t,e){(!c(t._passes[0].framebuffer)||t._shadowMapTexture.width!==t._textureSize.x)&&(gat(t),Xyt(t,e),WBe(t,e),Jyt(t,e))}function Jyt(t,e,n){n=f(n,0),(t._isPointLight||n===0)&&(t._clearCommand.framebuffer=t._passes[n].framebuffer,t._clearCommand.execute(e,t._clearPassState))}function FBe(t,e){t._size=e;let n=t._passes,i=n.length,o=t._textureSize;if(t._isPointLight){e=Sn.maximumCubeMapSize>=e?e:Sn.maximumCubeMapSize,o.x=e,o.y=e;let a=new Fe(0,0,e,e);n[0].passState.viewport=a,n[1].passState.viewport=a,n[2].passState.viewport=a,n[3].passState.viewport=a,n[4].passState.viewport=a,n[5].passState.viewport=a}else i===1?(e=Sn.maximumTextureSize>=e?e:Sn.maximumTextureSize,o.x=e,o.y=e,n[0].passState.viewport=new Fe(0,0,e,e)):i===4&&(e=Sn.maximumTextureSize>=e*2?e:Sn.maximumTextureSize/2,o.x=e*2,o.y=e*2,n[0].passState.viewport=new Fe(0,0,e,e),n[1].passState.viewport=new Fe(e,0,e,e),n[2].passState.viewport=new Fe(0,e,e,e),n[3].passState.viewport=new Fe(e,e,e,e));t._clearPassState.viewport=new Fe(0,0,o.x,o.y);for(let a=0;a<i;++a){let s=n[a],l=s.passState.viewport,r=l.x/o.x,d=l.y/o.y,m=l.width/o.x,h=l.height/o.y;s.textureOffsets=new L(m,0,0,r,0,h,0,d,0,0,1,0,0,0,0,1)}}var UBe=new Fe;function GBe(t,e){let n;t._isPointLight?n=`uniform samplerCube shadowMap_textureCube; +`,A.push(g),new Ze({defines:G,sources:A})};var DR=UT;function OR(t){t=f(t,f.EMPTY_OBJECT);let e=t.context;this._enabled=f(t.enabled,!0),this._softShadows=f(t.softShadows,!1),this._normalOffset=f(t.normalOffset,!0),this.dirty=!0,this.fromLightSource=f(t.fromLightSource,!0),this.darkness=f(t.darkness,.3),this._darkness=this.darkness,this.fadingEnabled=f(t.fadingEnabled,!0),this.maximumDistance=f(t.maximumDistance,5e3),this._outOfView=!1,this._outOfViewPrevious=!1,this._needsUpdate=!0;let n=!0;(In.isInternetExplorer()||In.isEdge()||(In.isChrome()||In.isFirefox())&&In.isWindows()&&!e.depthTexture)&&(n=!1),this._polygonOffsetSupported=n,this._terrainBias={polygonOffset:n,polygonOffsetFactor:1.1,polygonOffsetUnits:4,normalOffset:this._normalOffset,normalOffsetScale:.5,normalShading:!0,normalShadingSmooth:.3,depthBias:1e-4},this._primitiveBias={polygonOffset:n,polygonOffsetFactor:1.1,polygonOffsetUnits:4,normalOffset:this._normalOffset,normalOffsetScale:.1,normalShading:!0,normalShadingSmooth:.05,depthBias:2e-5},this._pointBias={polygonOffset:!1,polygonOffsetFactor:1.1,polygonOffsetUnits:4,normalOffset:this._normalOffset,normalOffsetScale:0,normalShading:!0,normalShadingSmooth:.1,depthBias:5e-4},this._depthAttachment=void 0,this._colorAttachment=void 0,this._shadowMapMatrix=new L,this._shadowMapTexture=void 0,this._lightDirectionEC=new p,this._lightPositionEC=new bt,this._distance=0,this._lightCamera=t.lightCamera,this._shadowMapCamera=new sj,this._shadowMapCullingVolume=void 0,this._sceneCamera=void 0,this._boundingSphere=new Ft,this._isPointLight=f(t.isPointLight,!1),this._pointLightRadius=f(t.pointLightRadius,100),this._cascadesEnabled=this._isPointLight?!1:f(t.cascadesEnabled,!0),this._numberOfCascades=this._cascadesEnabled?f(t.numberOfCascades,4):0,this._fitNearFar=!0,this._maximumCascadeDistances=[25,150,700,Number.MAX_VALUE],this._textureSize=new K,this._isSpotLight=!1,this._cascadesEnabled?this._shadowMapCamera.frustum=new el:c(this._lightCamera.frustum.fov)&&(this._isSpotLight=!0),this._cascadeSplits=[new bt,new bt],this._cascadeMatrices=[new L,new L,new L,new L],this._cascadeDistances=new bt;let i;this._isPointLight?i=6:this._cascadesEnabled?i=this._numberOfCascades:i=1,this._passes=new Array(i);for(let o=0;o<i;++o)this._passes[o]=new uBe(e);this.debugShow=!1,this.debugFreezeFrame=!1,this._debugFreezeFrame=!1,this._debugCascadeColors=!1,this._debugLightFrustum=void 0,this._debugCameraFrustum=void 0,this._debugCascadeFrustums=new Array(this._numberOfCascades),this._debugShadowViewCommand=void 0,this._usesDepthTexture=e.depthTexture,this._isPointLight&&(this._usesDepthTexture=!1),this._primitiveRenderState=void 0,this._terrainRenderState=void 0,this._pointRenderState=void 0,Tat(this),this._clearCommand=new ao({depth:1,color:new v}),this._clearPassState=new Md(e),this._size=f(t.size,2048),this.size=this._size}OR.MAXIMUM_DISTANCE=2e4;function uBe(t){this.camera=new sj,this.passState=new Md(t),this.framebuffer=void 0,this.textureOffsets=void 0,this.commandList=[],this.cullingVolume=void 0}function Sat(t,e){return he.fromCache({cull:{enabled:!0,face:so.BACK},depthTest:{enabled:!0},colorMask:{red:t,green:t,blue:t,alpha:t},depthMask:!0,polygonOffset:{enabled:e.polygonOffset,factor:e.polygonOffsetFactor,units:e.polygonOffsetUnits}})}function Tat(t){let e=!t._usesDepthTexture;t._primitiveRenderState=Sat(e,t._primitiveBias),t._terrainRenderState=Sat(e,t._terrainBias),t._pointRenderState=Sat(e,t._pointBias)}OR.prototype.debugCreateRenderStates=function(){Tat(this)};Object.defineProperties(OR.prototype,{enabled:{get:function(){return this._enabled},set:function(t){this.dirty=this._enabled!==t,this._enabled=t}},normalOffset:{get:function(){return this._normalOffset},set:function(t){this.dirty=this._normalOffset!==t,this._normalOffset=t,this._terrainBias.normalOffset=t,this._primitiveBias.normalOffset=t,this._pointBias.normalOffset=t}},softShadows:{get:function(){return this._softShadows},set:function(t){this.dirty=this._softShadows!==t,this._softShadows=t}},size:{get:function(){return this._size},set:function(t){FBe(this,t)}},outOfView:{get:function(){return this._outOfView}},shadowMapCullingVolume:{get:function(){return this._shadowMapCullingVolume}},passes:{get:function(){return this._passes}},isPointLight:{get:function(){return this._isPointLight}},debugCascadeColors:{get:function(){return this._debugCascadeColors},set:function(t){this.dirty=this._debugCascadeColors!==t,this._debugCascadeColors=t}}});function gat(t){let e=t._passes.length;for(let n=0;n<e;++n){let i=t._passes[n],o=i.framebuffer;c(o)&&!o.isDestroyed()&&o.destroy(),i.framebuffer=void 0}t._depthAttachment=t._depthAttachment&&t._depthAttachment.destroy(),t._colorAttachment=t._colorAttachment&&t._colorAttachment.destroy()}function ZBe(t,e){let n=new Rh({context:e,width:t._textureSize.x,height:t._textureSize.y,format:Tc.DEPTH_COMPONENT16}),i=new hn({context:e,width:t._textureSize.x,height:t._textureSize.y,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,sampler:Hn.NEAREST}),o=new Lr({context:e,depthRenderbuffer:n,colorTextures:[i],destroyAttachments:!1}),a=t._passes.length;for(let s=0;s<a;++s){let l=t._passes[s];l.framebuffer=o,l.passState.framebuffer=o}t._shadowMapTexture=i,t._depthAttachment=n,t._colorAttachment=i}function RBe(t,e){let n=new hn({context:e,width:t._textureSize.x,height:t._textureSize.y,pixelFormat:Ye.DEPTH_STENCIL,pixelDatatype:Ue.UNSIGNED_INT_24_8,sampler:Hn.NEAREST}),i=new Lr({context:e,depthStencilTexture:n,destroyAttachments:!1}),o=t._passes.length;for(let a=0;a<o;++a){let s=t._passes[a];s.framebuffer=i,s.passState.framebuffer=i}t._shadowMapTexture=n,t._depthAttachment=n}function bBe(t,e){let n=new Rh({context:e,width:t._textureSize.x,height:t._textureSize.y,format:Tc.DEPTH_COMPONENT16}),i=new Ld({context:e,width:t._textureSize.x,height:t._textureSize.y,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,sampler:Hn.NEAREST}),o=[i.negativeX,i.negativeY,i.negativeZ,i.positiveX,i.positiveY,i.positiveZ];for(let a=0;a<6;++a){let s=new Lr({context:e,depthRenderbuffer:n,colorTextures:[o[a]],destroyAttachments:!1}),l=t._passes[a];l.framebuffer=s,l.passState.framebuffer=s}t._shadowMapTexture=i,t._depthAttachment=n,t._colorAttachment=i}function Xyt(t,e){t._isPointLight?bBe(t,e):t._usesDepthTexture?RBe(t,e):ZBe(t,e)}function WBe(t,e){t._usesDepthTexture&&t._passes[0].framebuffer.status!==pt.FRAMEBUFFER_COMPLETE&&(t._usesDepthTexture=!1,Tat(t),gat(t),Xyt(t,e))}function fBe(t,e){(!c(t._passes[0].framebuffer)||t._shadowMapTexture.width!==t._textureSize.x)&&(gat(t),Xyt(t,e),WBe(t,e),Jyt(t,e))}function Jyt(t,e,n){n=f(n,0),(t._isPointLight||n===0)&&(t._clearCommand.framebuffer=t._passes[n].framebuffer,t._clearCommand.execute(e,t._clearPassState))}function FBe(t,e){t._size=e;let n=t._passes,i=n.length,o=t._textureSize;if(t._isPointLight){e=Tn.maximumCubeMapSize>=e?e:Tn.maximumCubeMapSize,o.x=e,o.y=e;let a=new Fe(0,0,e,e);n[0].passState.viewport=a,n[1].passState.viewport=a,n[2].passState.viewport=a,n[3].passState.viewport=a,n[4].passState.viewport=a,n[5].passState.viewport=a}else i===1?(e=Tn.maximumTextureSize>=e?e:Tn.maximumTextureSize,o.x=e,o.y=e,n[0].passState.viewport=new Fe(0,0,e,e)):i===4&&(e=Tn.maximumTextureSize>=e*2?e:Tn.maximumTextureSize/2,o.x=e*2,o.y=e*2,n[0].passState.viewport=new Fe(0,0,e,e),n[1].passState.viewport=new Fe(e,0,e,e),n[2].passState.viewport=new Fe(0,e,e,e),n[3].passState.viewport=new Fe(e,e,e,e));t._clearPassState.viewport=new Fe(0,0,o.x,o.y);for(let a=0;a<i;++a){let s=n[a],l=s.passState.viewport,r=l.x/o.x,d=l.y/o.y,m=l.width/o.x,h=l.height/o.y;s.textureOffsets=new L(m,0,0,r,0,h,0,d,0,0,1,0,0,0,0,1)}}var UBe=new Fe;function GBe(t,e){let n;t._isPointLight?n=`uniform samplerCube shadowMap_textureCube; in vec2 v_textureCoordinates; void main() { @@ -11162,7 +11162,7 @@ ${t._usesDepthTexture?` float shadow = texture(shadowMap_texture, v_textureCo `:` float shadow = czm_unpackDepth(texture(shadowMap_texture, v_textureCoordinates)); `} out_FragColor = vec4(vec3(shadow), 1.0); } -`;let i=e.createViewportQuadCommand(n,{uniformMap:{shadowMap_texture:function(){return t._shadowMapTexture},shadowMap_textureCube:function(){return t._shadowMapTexture}}});return i.pass=Pt.OVERLAY,i}function ABe(t,e){let n=e.context,i=e.context.drawingBufferWidth,o=e.context.drawingBufferHeight,a=Math.min(i,o)*.3,s=UBe;s.x=i-a,s.y=0,s.width=a,s.height=a;let l=t._debugShadowViewCommand;c(l)||(l=GBe(t,n),t._debugShadowViewCommand=l),(!c(l.renderState)||!Fe.equals(l.renderState.viewport,s))&&(l.renderState=he.fromCache({viewport:Fe.clone(s)})),e.commandList.push(t._debugShadowViewCommand)}var Hb=new Array(8);Hb[0]=new Rt(-1,-1,-1,1);Hb[1]=new Rt(1,-1,-1,1);Hb[2]=new Rt(1,1,-1,1);Hb[3]=new Rt(-1,1,-1,1);Hb[4]=new Rt(-1,-1,1,1);Hb[5]=new Rt(1,-1,1,1);Hb[6]=new Rt(1,1,1,1);Hb[7]=new Rt(-1,1,1,1);var RU=new L,Eat=new Array(8);for(let t=0;t<8;++t)Eat[t]=new Rt;function TBe(t,e){let n=new $e({geometry:new tZ({minimum:new p(-.5,-.5,-.5),maximum:new p(.5,.5,.5)}),attributes:{color:En.fromColor(e)}}),i=new $e({geometry:new g0({radius:.5}),attributes:{color:En.fromColor(e)}});return new Wi({geometryInstances:[n,i],appearance:new jn({translucent:!1,flat:!0}),asynchronous:!1,modelMatrix:t})}var SBe=[v.RED,v.GREEN,v.BLUE,v.MAGENTA],gBe=new p;function EBe(t,e){ABe(t,e);let n=t.debugFreezeFrame&&!t._debugFreezeFrame;if(t._debugFreezeFrame=t.debugFreezeFrame,t.debugFreezeFrame&&(n&&(t._debugCameraFrustum=t._debugCameraFrustum&&t._debugCameraFrustum.destroy(),t._debugCameraFrustum=new Jb({camera:t._sceneCamera,color:v.CYAN,updateOnChange:!1})),t._debugCameraFrustum.update(e)),t._cascadesEnabled){if(t.debugFreezeFrame){n&&(t._debugLightFrustum=t._debugLightFrustum&&t._debugLightFrustum.destroy(),t._debugLightFrustum=new Jb({camera:t._shadowMapCamera,color:v.YELLOW,updateOnChange:!1})),t._debugLightFrustum.update(e);for(let i=0;i<t._numberOfCascades;++i)n&&(t._debugCascadeFrustums[i]=t._debugCascadeFrustums[i]&&t._debugCascadeFrustums[i].destroy(),t._debugCascadeFrustums[i]=new Jb({camera:t._passes[i].camera,color:SBe[i],updateOnChange:!1})),t._debugCascadeFrustums[i].update(e)}}else if(t._isPointLight){if(!c(t._debugLightFrustum)||t._needsUpdate){let i=t._shadowMapCamera.positionWC,o=wt.IDENTITY,a=t._pointLightRadius*2,s=p.fromElements(a,a,a,gBe),l=L.fromTranslationQuaternionRotationScale(i,o,s,RU);t._debugLightFrustum=t._debugLightFrustum&&t._debugLightFrustum.destroy(),t._debugLightFrustum=TBe(l,v.YELLOW)}t._debugLightFrustum.update(e)}else(!c(t._debugLightFrustum)||t._needsUpdate)&&(t._debugLightFrustum=new Jb({camera:t._shadowMapCamera,color:v.YELLOW,updateOnChange:!1})),t._debugLightFrustum.update(e)}function sj(){this.viewMatrix=new L,this.inverseViewMatrix=new L,this.frustum=void 0,this.positionCartographic=new gt,this.positionWC=new p,this.directionWC=p.clone(p.UNIT_Z),this.upWC=p.clone(p.UNIT_Y),this.rightWC=p.clone(p.UNIT_X),this.viewProjectionMatrix=new L}sj.prototype.clone=function(t){L.clone(t.viewMatrix,this.viewMatrix),L.clone(t.inverseViewMatrix,this.inverseViewMatrix),this.frustum=t.frustum.clone(this.frustum),gt.clone(t.positionCartographic,this.positionCartographic),p.clone(t.positionWC,this.positionWC),p.clone(t.directionWC,this.directionWC),p.clone(t.upWC,this.upWC),p.clone(t.rightWC,this.rightWC)};var CBe=new L(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1);sj.prototype.getViewProjection=function(){let t=this.viewMatrix,e=this.frustum.projectionMatrix;return L.multiply(e,t,this.viewProjectionMatrix),L.multiply(CBe,this.viewProjectionMatrix,this.viewProjectionMatrix),this.viewProjectionMatrix};var IBe=new Array(5),NBe=new Io,yBe=new Array(4),Lyt=new p,Myt=new p;function BBe(t,e){let n=t._shadowMapCamera,i=t._sceneCamera,o=i.frustum.near,a=i.frustum.far,s=t._numberOfCascades,l,r=a-o,d=a/o,m=.9,h=!1;e.shadowState.closestObjectSize<200&&(h=!0,m=.9);let Z=yBe,b=IBe;for(b[0]=o,b[s]=a,l=0;l<s;++l){let M=(l+1)/s,V=o*Math.pow(d,M),E=o+r*M,I=k.lerp(E,V,m);b[l+1]=I,Z[l]=I-b[l]}if(h){for(l=0;l<s;++l)Z[l]=Math.min(Z[l],t._maximumCascadeDistances[l]);let M=b[0];for(l=0;l<s-1;++l)M+=Z[l],b[l+1]=M}Rt.unpack(b,0,t._cascadeSplits[0]),Rt.unpack(b,1,t._cascadeSplits[1]),Rt.unpack(Z,0,t._cascadeDistances);let u=n.frustum,F=u.left,U=u.right,G=u.bottom,A=u.top,T=u.near,g=u.far,C=n.positionWC,y=n.directionWC,Y=n.upWC,Q=i.frustum.clone(NBe),J=n.getViewProjection();for(l=0;l<s;++l){Q.near=b[l],Q.far=b[l+1];let M=L.multiply(Q.projectionMatrix,i.viewMatrix,RU),V=L.inverse(M,RU),E=L.multiply(J,V,RU),I=p.fromElements(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE,Lyt),B=p.fromElements(-Number.MAX_VALUE,-Number.MAX_VALUE,-Number.MAX_VALUE,Myt);for(let z=0;z<8;++z){let H=Rt.clone(Hb[z],Eat[z]);L.multiplyByVector(E,H,H),p.divideByScalar(H,H.w,H),p.minimumByComponent(H,I,I),p.maximumByComponent(H,B,B)}I.x=Math.max(I.x,0),I.y=Math.max(I.y,0),I.z=0,B.x=Math.min(B.x,1),B.y=Math.min(B.y,1),B.z=Math.min(B.z,1);let X=t._passes[l],_=X.camera;_.clone(n);let P=_.frustum;P.left=F+I.x*(U-F),P.right=F+B.x*(U-F),P.bottom=G+I.y*(A-G),P.top=G+B.y*(A-G),P.near=T+I.z*(g-T),P.far=T+B.z*(g-T),X.cullingVolume=_.frustum.computeCullingVolume(C,y,Y);let w=t._cascadeMatrices[l];L.multiply(_.getViewProjection(),i.inverseViewMatrix,w),L.multiply(X.textureOffsets,w,w)}}var QBe=new L,kBe=new p,YBe=new p,Yyt=new p;function xBe(t,e){let n=t._shadowMapCamera,i=t._sceneCamera,o=L.multiply(i.frustum.projectionMatrix,i.viewMatrix,RU),a=L.inverse(o,RU),s=n.directionWC,l=i.directionWC;p.equalsEpsilon(s,l,k.EPSILON10)&&(l=i.upWC);let r=p.cross(s,l,kBe);l=p.cross(r,s,YBe),p.normalize(l,l),p.normalize(r,r);let d=p.fromElements(0,0,0,Yyt),m=L.computeView(d,s,l,r,QBe),h=L.multiply(m,a,RU),Z=p.fromElements(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE,Lyt),b=p.fromElements(-Number.MAX_VALUE,-Number.MAX_VALUE,-Number.MAX_VALUE,Myt);for(let g=0;g<8;++g){let C=Rt.clone(Hb[g],Eat[g]);L.multiplyByVector(h,C,C),p.divideByScalar(C,C.w,C),p.minimumByComponent(C,Z,Z),p.maximumByComponent(C,b,b)}b.z+=1e3,Z.z-=10;let u=Yyt;u.x=-(.5*(Z.x+b.x)),u.y=-(.5*(Z.y+b.y)),u.z=-b.z;let F=L.fromTranslation(u,RU);m=L.multiply(F,m,m);let U=.5*(b.x-Z.x),G=.5*(b.y-Z.y),A=b.z-Z.z,T=n.frustum;T.left=-U,T.right=U,T.bottom=-G,T.top=G,T.near=.01,T.far=A,L.clone(m,n.viewMatrix),L.inverse(m,n.inverseViewMatrix),L.getTranslation(n.inverseViewMatrix,n.positionWC),e.mapProjection.ellipsoid.cartesianToCartographic(n.positionWC,n.positionCartographic),p.clone(s,n.directionWC),p.clone(l,n.upWC),p.clone(r,n.rightWC)}var XBe=[new p(-1,0,0),new p(0,-1,0),new p(0,0,-1),new p(1,0,0),new p(0,1,0),new p(0,0,1)],JBe=[new p(0,-1,0),new p(0,0,-1),new p(0,-1,0),new p(0,-1,0),new p(0,0,1),new p(0,-1,0)],LBe=[new p(0,0,1),new p(1,0,0),new p(-1,0,0),new p(0,0,-1),new p(1,0,0),new p(1,0,0)];function MBe(t,e){let n=new Io;n.fov=k.PI_OVER_TWO,n.near=1,n.far=t._pointLightRadius,n.aspectRatio=1;for(let i=0;i<6;++i){let o=t._passes[i].camera;o.positionWC=t._shadowMapCamera.positionWC,o.positionCartographic=e.mapProjection.ellipsoid.cartesianToCartographic(o.positionWC,o.positionCartographic),o.directionWC=XBe[i],o.upWC=JBe[i],o.rightWC=LBe[i],L.computeView(o.positionWC,o.directionWC,o.upWC,o.rightWC,o.viewMatrix),L.inverse(o.viewMatrix,o.inverseViewMatrix),o.frustum=n}}var _Be=new p,DBe=new p,_yt=new Ft,xyt=_yt.center;function OBe(t,e){let n=t._sceneCamera,i=t._shadowMapCamera,o=_yt;if(t._cascadesEnabled){if(n.frustum.near>=t.maximumDistance){t._outOfView=!0,t._needsUpdate=!1;return}let a=e.mapProjection.ellipsoid.geodeticSurfaceNormal(n.positionWC,_Be),s=p.negate(i.directionWC,DBe),l=p.dot(a,s);if(t.fadingEnabled){let r=k.clamp(l/.1,0,1);t._darkness=k.lerp(1,t.darkness,r)}else t._darkness=t.darkness;if(l<0){t._outOfView=!0,t._needsUpdate=!1;return}t._needsUpdate=!0,t._outOfView=!1}else if(t._isPointLight)o.center=i.positionWC,o.radius=t._pointLightRadius,t._outOfView=e.cullingVolume.computeVisibility(o)===yn.OUTSIDE,t._needsUpdate=!t._outOfView&&!t._boundingSphere.equals(o),Ft.clone(o,t._boundingSphere);else{let a=i.frustum.far/2,s=p.add(i.positionWC,p.multiplyByScalar(i.directionWC,a,xyt),xyt);o.center=s,o.radius=a,t._outOfView=e.cullingVolume.computeVisibility(o)===yn.OUTSIDE,t._needsUpdate=!t._outOfView&&!t._boundingSphere.equals(o),Ft.clone(o,t._boundingSphere)}}function HBe(t,e){let n=e.camera,i=t._lightCamera,o=t._sceneCamera,a=t._shadowMapCamera;t._cascadesEnabled?p.clone(i.directionWC,a.directionWC):t._isPointLight?p.clone(i.positionWC,a.positionWC):a.clone(i);let s=t._lightDirectionEC;L.multiplyByPointAsVector(n.viewMatrix,a.directionWC,s),p.normalize(s,s),p.negate(s,s),L.multiplyByPoint(n.viewMatrix,a.positionWC,t._lightPositionEC),t._lightPositionEC.w=t._pointLightRadius;let l,r;t._fitNearFar?(l=Math.min(e.shadowState.nearPlane,t.maximumDistance),r=Math.min(e.shadowState.farPlane,t.maximumDistance),r=Math.max(r,l+1)):(l=n.frustum.near,r=t.maximumDistance),t._sceneCamera=Aa.clone(n,o),n.frustum.clone(t._sceneCamera.frustum),t._sceneCamera.frustum.near=l,t._sceneCamera.frustum.far=r,t._distance=r-l,OBe(t,e),!t._outOfViewPrevious&&t._outOfView&&(t._needsUpdate=!0),t._outOfViewPrevious=t._outOfView}Ob.prototype.update=function(t){if(HBe(this,t),this._needsUpdate)if(fBe(this,t.context),this._isPointLight&&MBe(this,t),this._cascadesEnabled&&(xBe(this,t),this._numberOfCascades>1&&BBe(this,t)),this._isPointLight)this._shadowMapCullingVolume=Jl.fromBoundingSphere(this._boundingSphere);else{let e=this._shadowMapCamera,n=e.positionWC,i=e.directionWC,o=e.upWC;this._shadowMapCullingVolume=e.frustum.computeCullingVolume(n,i,o),this._passes.length===1&&this._passes[0].camera.clone(e)}if(this._passes.length===1){let e=this._sceneCamera.inverseViewMatrix;L.multiply(this._shadowMapCamera.getViewProjection(),e,this._shadowMapMatrix)}this.debugShow&&EBe(this,t)};Ob.prototype.updatePass=function(t,e){Jyt(this,t,e)};var wBe=new K;function Dyt(t,e,n){let i=t._isPointLight?t._pointBias:n?t._terrainBias:t._primitiveBias,o={shadowMap_texture:function(){return t._shadowMapTexture},shadowMap_textureCube:function(){return t._shadowMapTexture},shadowMap_matrix:function(){return t._shadowMapMatrix},shadowMap_cascadeSplits:function(){return t._cascadeSplits},shadowMap_cascadeMatrices:function(){return t._cascadeMatrices},shadowMap_lightDirectionEC:function(){return t._lightDirectionEC},shadowMap_lightPositionEC:function(){return t._lightPositionEC},shadowMap_cascadeDistances:function(){return t._cascadeDistances},shadowMap_texelSizeDepthBiasAndNormalShadingSmooth:function(){let a=wBe;return a.x=1/t._textureSize.x,a.y=1/t._textureSize.y,Rt.fromElements(a.x,a.y,i.depthBias,i.normalShadingSmooth,this.combinedUniforms1)},shadowMap_normalOffsetScaleDistanceMaxDistanceAndDarkness:function(){return Rt.fromElements(i.normalOffsetScale,t._distance,t.maximumDistance,t._darkness,this.combinedUniforms2)},combinedUniforms1:new Rt,combinedUniforms2:new Rt};return ze(e,o,!1)}function PBe(t,e,n,i,o,a){let s,l,r;if(c(a)&&(s=a.shaderProgram,l=a.renderState,r=a.uniformMap),a=Ee.shallowClone(n,a),a.castShadows=!0,a.receiveShadows=!1,!c(s)||o!==n.shaderProgram.id||e){let d=n.shaderProgram,m=n.pass===Pt.GLOBE,h=n.pass!==Pt.TRANSLUCENT,Z=t._isPointLight,b=t._usesDepthTexture,u=Db.getShadowCastShaderKeyword(Z,m,b,h);if(s=i.shaderCache.getDerivedShaderProgram(d,u),!c(s)){let U=d.vertexShaderSource,G=d.fragmentShaderSource,A=Db.createShadowCastVertexShader(U,Z,m),T=Db.createShadowCastFragmentShader(G,Z,b,h);s=i.shaderCache.createDerivedShaderProgram(d,u,{vertexShaderSource:A,fragmentShaderSource:T,attributeLocations:d._attributeLocations})}l=t._primitiveRenderState,Z?l=t._pointRenderState:m&&(l=t._terrainRenderState),n.renderState.cull.enabled||(l=be(l,!1),l.cull=be(l.cull,!1),l.cull.enabled=!1,l=he.fromCache(l)),r=Dyt(t,n.uniformMap,m)}return a.shaderProgram=s,a.renderState=l,a.uniformMap=r,a}Ob.createReceiveDerivedCommand=function(t,e,n,i,o){c(o)||(o={});let a=t.length>0,s=e.shaderProgram,l=s.vertexShaderSource,r=s.fragmentShaderSource,d=e.pass===Pt.GLOBE,m=!1;if(d&&(m=e.owner.data.renderedMesh.encoding.hasVertexNormals),e.receiveShadows&&a){let h,Z;c(o.receiveCommand)&&(h=o.receiveCommand.shaderProgram,Z=o.receiveCommand.uniformMap),o.receiveCommand=Ee.shallowClone(e,o.receiveCommand),o.castShadows=!1,o.receiveShadows=!0;let b=o.receiveShaderCastShadows!==e.castShadows,u=o.receiveShaderProgramId!==e.shaderProgram.id;if(!c(h)||u||n||b){let F=Db.getShadowReceiveShaderKeyword(t[0],e.castShadows,d,m);if(h=i.shaderCache.getDerivedShaderProgram(s,F),!c(h)){let U=Db.createShadowReceiveVertexShader(l,d,m),G=Db.createShadowReceiveFragmentShader(r,t[0],e.castShadows,d,m);h=i.shaderCache.createDerivedShaderProgram(s,F,{vertexShaderSource:U,fragmentShaderSource:G,attributeLocations:s._attributeLocations})}Z=Dyt(t[0],e.uniformMap,d)}o.receiveCommand.shaderProgram=h,o.receiveCommand.uniformMap=Z,o.receiveShaderProgramId=e.shaderProgram.id,o.receiveShaderCastShadows=e.castShadows}return o};Ob.createCastDerivedCommand=function(t,e,n,i,o){if(c(o)||(o={}),e.castShadows){let a=o.castCommands;c(a)||(a=o.castCommands=[]);let s=o.castShaderProgramId,l=t.length;a.length=l;for(let r=0;r<l;++r)a[r]=PBe(t[r],n,e,i,s,a[r]);o.castShaderProgramId=e.shaderProgram.id}return o};Ob.prototype.isDestroyed=function(){return!1};Ob.prototype.destroy=function(){gat(this),this._debugLightFrustum=this._debugLightFrustum&&this._debugLightFrustum.destroy(),this._debugCameraFrustum=this._debugCameraFrustum&&this._debugCameraFrustum.destroy(),this._debugShadowViewCommand=this._debugShadowViewCommand&&this._debugShadowViewCommand.shaderProgram&&this._debugShadowViewCommand.shaderProgram.destroy();for(let t=0;t<this._numberOfCascades;++t)this._debugCascadeFrustums[t]=this._debugCascadeFrustums[t]&&this._debugCascadeFrustums[t].destroy();return At(this)};var fW=Ob;var pNo=R(W(),1);var O1o=R(W(),1),j_=`uniform sampler2D u_opaqueDepthTexture; +`;let i=e.createViewportQuadCommand(n,{uniformMap:{shadowMap_texture:function(){return t._shadowMapTexture},shadowMap_textureCube:function(){return t._shadowMapTexture}}});return i.pass=Pt.OVERLAY,i}function ABe(t,e){let n=e.context,i=e.context.drawingBufferWidth,o=e.context.drawingBufferHeight,a=Math.min(i,o)*.3,s=UBe;s.x=i-a,s.y=0,s.width=a,s.height=a;let l=t._debugShadowViewCommand;c(l)||(l=GBe(t,n),t._debugShadowViewCommand=l),(!c(l.renderState)||!Fe.equals(l.renderState.viewport,s))&&(l.renderState=he.fromCache({viewport:Fe.clone(s)})),e.commandList.push(t._debugShadowViewCommand)}var HR=new Array(8);HR[0]=new bt(-1,-1,-1,1);HR[1]=new bt(1,-1,-1,1);HR[2]=new bt(1,1,-1,1);HR[3]=new bt(-1,1,-1,1);HR[4]=new bt(-1,-1,1,1);HR[5]=new bt(1,-1,1,1);HR[6]=new bt(1,1,1,1);HR[7]=new bt(-1,1,1,1);var bU=new L,Eat=new Array(8);for(let t=0;t<8;++t)Eat[t]=new bt;function SBe(t,e){let n=new $e({geometry:new tu({minimum:new p(-.5,-.5,-.5),maximum:new p(.5,.5,.5)}),attributes:{color:En.fromColor(e)}}),i=new $e({geometry:new g0({radius:.5}),attributes:{color:En.fromColor(e)}});return new Wi({geometryInstances:[n,i],appearance:new jn({translucent:!1,flat:!0}),asynchronous:!1,modelMatrix:t})}var TBe=[v.RED,v.GREEN,v.BLUE,v.MAGENTA],gBe=new p;function EBe(t,e){ABe(t,e);let n=t.debugFreezeFrame&&!t._debugFreezeFrame;if(t._debugFreezeFrame=t.debugFreezeFrame,t.debugFreezeFrame&&(n&&(t._debugCameraFrustum=t._debugCameraFrustum&&t._debugCameraFrustum.destroy(),t._debugCameraFrustum=new JR({camera:t._sceneCamera,color:v.CYAN,updateOnChange:!1})),t._debugCameraFrustum.update(e)),t._cascadesEnabled){if(t.debugFreezeFrame){n&&(t._debugLightFrustum=t._debugLightFrustum&&t._debugLightFrustum.destroy(),t._debugLightFrustum=new JR({camera:t._shadowMapCamera,color:v.YELLOW,updateOnChange:!1})),t._debugLightFrustum.update(e);for(let i=0;i<t._numberOfCascades;++i)n&&(t._debugCascadeFrustums[i]=t._debugCascadeFrustums[i]&&t._debugCascadeFrustums[i].destroy(),t._debugCascadeFrustums[i]=new JR({camera:t._passes[i].camera,color:TBe[i],updateOnChange:!1})),t._debugCascadeFrustums[i].update(e)}}else if(t._isPointLight){if(!c(t._debugLightFrustum)||t._needsUpdate){let i=t._shadowMapCamera.positionWC,o=wt.IDENTITY,a=t._pointLightRadius*2,s=p.fromElements(a,a,a,gBe),l=L.fromTranslationQuaternionRotationScale(i,o,s,bU);t._debugLightFrustum=t._debugLightFrustum&&t._debugLightFrustum.destroy(),t._debugLightFrustum=SBe(l,v.YELLOW)}t._debugLightFrustum.update(e)}else(!c(t._debugLightFrustum)||t._needsUpdate)&&(t._debugLightFrustum=new JR({camera:t._shadowMapCamera,color:v.YELLOW,updateOnChange:!1})),t._debugLightFrustum.update(e)}function sj(){this.viewMatrix=new L,this.inverseViewMatrix=new L,this.frustum=void 0,this.positionCartographic=new gt,this.positionWC=new p,this.directionWC=p.clone(p.UNIT_Z),this.upWC=p.clone(p.UNIT_Y),this.rightWC=p.clone(p.UNIT_X),this.viewProjectionMatrix=new L}sj.prototype.clone=function(t){L.clone(t.viewMatrix,this.viewMatrix),L.clone(t.inverseViewMatrix,this.inverseViewMatrix),this.frustum=t.frustum.clone(this.frustum),gt.clone(t.positionCartographic,this.positionCartographic),p.clone(t.positionWC,this.positionWC),p.clone(t.directionWC,this.directionWC),p.clone(t.upWC,this.upWC),p.clone(t.rightWC,this.rightWC)};var CBe=new L(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1);sj.prototype.getViewProjection=function(){let t=this.viewMatrix,e=this.frustum.projectionMatrix;return L.multiply(e,t,this.viewProjectionMatrix),L.multiply(CBe,this.viewProjectionMatrix,this.viewProjectionMatrix),this.viewProjectionMatrix};var IBe=new Array(5),NBe=new Io,yBe=new Array(4),Lyt=new p,Myt=new p;function BBe(t,e){let n=t._shadowMapCamera,i=t._sceneCamera,o=i.frustum.near,a=i.frustum.far,s=t._numberOfCascades,l,r=a-o,d=a/o,m=.9,h=!1;e.shadowState.closestObjectSize<200&&(h=!0,m=.9);let u=yBe,R=IBe;for(R[0]=o,R[s]=a,l=0;l<s;++l){let M=(l+1)/s,Z=o*Math.pow(d,M),E=o+r*M,I=k.lerp(E,Z,m);R[l+1]=I,u[l]=I-R[l]}if(h){for(l=0;l<s;++l)u[l]=Math.min(u[l],t._maximumCascadeDistances[l]);let M=R[0];for(l=0;l<s-1;++l)M+=u[l],R[l+1]=M}bt.unpack(R,0,t._cascadeSplits[0]),bt.unpack(R,1,t._cascadeSplits[1]),bt.unpack(u,0,t._cascadeDistances);let V=n.frustum,F=V.left,U=V.right,G=V.bottom,A=V.top,S=V.near,g=V.far,C=n.positionWC,y=n.directionWC,Y=n.upWC,Q=i.frustum.clone(NBe),J=n.getViewProjection();for(l=0;l<s;++l){Q.near=R[l],Q.far=R[l+1];let M=L.multiply(Q.projectionMatrix,i.viewMatrix,bU),Z=L.inverse(M,bU),E=L.multiply(J,Z,bU),I=p.fromElements(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE,Lyt),B=p.fromElements(-Number.MAX_VALUE,-Number.MAX_VALUE,-Number.MAX_VALUE,Myt);for(let z=0;z<8;++z){let H=bt.clone(HR[z],Eat[z]);L.multiplyByVector(E,H,H),p.divideByScalar(H,H.w,H),p.minimumByComponent(H,I,I),p.maximumByComponent(H,B,B)}I.x=Math.max(I.x,0),I.y=Math.max(I.y,0),I.z=0,B.x=Math.min(B.x,1),B.y=Math.min(B.y,1),B.z=Math.min(B.z,1);let X=t._passes[l],_=X.camera;_.clone(n);let P=_.frustum;P.left=F+I.x*(U-F),P.right=F+B.x*(U-F),P.bottom=G+I.y*(A-G),P.top=G+B.y*(A-G),P.near=S+I.z*(g-S),P.far=S+B.z*(g-S),X.cullingVolume=_.frustum.computeCullingVolume(C,y,Y);let w=t._cascadeMatrices[l];L.multiply(_.getViewProjection(),i.inverseViewMatrix,w),L.multiply(X.textureOffsets,w,w)}}var QBe=new L,kBe=new p,YBe=new p,Yyt=new p;function xBe(t,e){let n=t._shadowMapCamera,i=t._sceneCamera,o=L.multiply(i.frustum.projectionMatrix,i.viewMatrix,bU),a=L.inverse(o,bU),s=n.directionWC,l=i.directionWC;p.equalsEpsilon(s,l,k.EPSILON10)&&(l=i.upWC);let r=p.cross(s,l,kBe);l=p.cross(r,s,YBe),p.normalize(l,l),p.normalize(r,r);let d=p.fromElements(0,0,0,Yyt),m=L.computeView(d,s,l,r,QBe),h=L.multiply(m,a,bU),u=p.fromElements(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE,Lyt),R=p.fromElements(-Number.MAX_VALUE,-Number.MAX_VALUE,-Number.MAX_VALUE,Myt);for(let g=0;g<8;++g){let C=bt.clone(HR[g],Eat[g]);L.multiplyByVector(h,C,C),p.divideByScalar(C,C.w,C),p.minimumByComponent(C,u,u),p.maximumByComponent(C,R,R)}R.z+=1e3,u.z-=10;let V=Yyt;V.x=-(.5*(u.x+R.x)),V.y=-(.5*(u.y+R.y)),V.z=-R.z;let F=L.fromTranslation(V,bU);m=L.multiply(F,m,m);let U=.5*(R.x-u.x),G=.5*(R.y-u.y),A=R.z-u.z,S=n.frustum;S.left=-U,S.right=U,S.bottom=-G,S.top=G,S.near=.01,S.far=A,L.clone(m,n.viewMatrix),L.inverse(m,n.inverseViewMatrix),L.getTranslation(n.inverseViewMatrix,n.positionWC),e.mapProjection.ellipsoid.cartesianToCartographic(n.positionWC,n.positionCartographic),p.clone(s,n.directionWC),p.clone(l,n.upWC),p.clone(r,n.rightWC)}var XBe=[new p(-1,0,0),new p(0,-1,0),new p(0,0,-1),new p(1,0,0),new p(0,1,0),new p(0,0,1)],JBe=[new p(0,-1,0),new p(0,0,-1),new p(0,-1,0),new p(0,-1,0),new p(0,0,1),new p(0,-1,0)],LBe=[new p(0,0,1),new p(1,0,0),new p(-1,0,0),new p(0,0,-1),new p(1,0,0),new p(1,0,0)];function MBe(t,e){let n=new Io;n.fov=k.PI_OVER_TWO,n.near=1,n.far=t._pointLightRadius,n.aspectRatio=1;for(let i=0;i<6;++i){let o=t._passes[i].camera;o.positionWC=t._shadowMapCamera.positionWC,o.positionCartographic=e.mapProjection.ellipsoid.cartesianToCartographic(o.positionWC,o.positionCartographic),o.directionWC=XBe[i],o.upWC=JBe[i],o.rightWC=LBe[i],L.computeView(o.positionWC,o.directionWC,o.upWC,o.rightWC,o.viewMatrix),L.inverse(o.viewMatrix,o.inverseViewMatrix),o.frustum=n}}var _Be=new p,DBe=new p,_yt=new Ft,xyt=_yt.center;function OBe(t,e){let n=t._sceneCamera,i=t._shadowMapCamera,o=_yt;if(t._cascadesEnabled){if(n.frustum.near>=t.maximumDistance){t._outOfView=!0,t._needsUpdate=!1;return}let a=e.mapProjection.ellipsoid.geodeticSurfaceNormal(n.positionWC,_Be),s=p.negate(i.directionWC,DBe),l=p.dot(a,s);if(t.fadingEnabled){let r=k.clamp(l/.1,0,1);t._darkness=k.lerp(1,t.darkness,r)}else t._darkness=t.darkness;if(l<0){t._outOfView=!0,t._needsUpdate=!1;return}t._needsUpdate=!0,t._outOfView=!1}else if(t._isPointLight)o.center=i.positionWC,o.radius=t._pointLightRadius,t._outOfView=e.cullingVolume.computeVisibility(o)===yn.OUTSIDE,t._needsUpdate=!t._outOfView&&!t._boundingSphere.equals(o),Ft.clone(o,t._boundingSphere);else{let a=i.frustum.far/2,s=p.add(i.positionWC,p.multiplyByScalar(i.directionWC,a,xyt),xyt);o.center=s,o.radius=a,t._outOfView=e.cullingVolume.computeVisibility(o)===yn.OUTSIDE,t._needsUpdate=!t._outOfView&&!t._boundingSphere.equals(o),Ft.clone(o,t._boundingSphere)}}function HBe(t,e){let n=e.camera,i=t._lightCamera,o=t._sceneCamera,a=t._shadowMapCamera;t._cascadesEnabled?p.clone(i.directionWC,a.directionWC):t._isPointLight?p.clone(i.positionWC,a.positionWC):a.clone(i);let s=t._lightDirectionEC;L.multiplyByPointAsVector(n.viewMatrix,a.directionWC,s),p.normalize(s,s),p.negate(s,s),L.multiplyByPoint(n.viewMatrix,a.positionWC,t._lightPositionEC),t._lightPositionEC.w=t._pointLightRadius;let l,r;t._fitNearFar?(l=Math.min(e.shadowState.nearPlane,t.maximumDistance),r=Math.min(e.shadowState.farPlane,t.maximumDistance),r=Math.max(r,l+1)):(l=n.frustum.near,r=t.maximumDistance),t._sceneCamera=Aa.clone(n,o),n.frustum.clone(t._sceneCamera.frustum),t._sceneCamera.frustum.near=l,t._sceneCamera.frustum.far=r,t._distance=r-l,OBe(t,e),!t._outOfViewPrevious&&t._outOfView&&(t._needsUpdate=!0),t._outOfViewPrevious=t._outOfView}OR.prototype.update=function(t){if(HBe(this,t),this._needsUpdate)if(fBe(this,t.context),this._isPointLight&&MBe(this,t),this._cascadesEnabled&&(xBe(this,t),this._numberOfCascades>1&&BBe(this,t)),this._isPointLight)this._shadowMapCullingVolume=Jl.fromBoundingSphere(this._boundingSphere);else{let e=this._shadowMapCamera,n=e.positionWC,i=e.directionWC,o=e.upWC;this._shadowMapCullingVolume=e.frustum.computeCullingVolume(n,i,o),this._passes.length===1&&this._passes[0].camera.clone(e)}if(this._passes.length===1){let e=this._sceneCamera.inverseViewMatrix;L.multiply(this._shadowMapCamera.getViewProjection(),e,this._shadowMapMatrix)}this.debugShow&&EBe(this,t)};OR.prototype.updatePass=function(t,e){Jyt(this,t,e)};var wBe=new K;function Dyt(t,e,n){let i=t._isPointLight?t._pointBias:n?t._terrainBias:t._primitiveBias,o={shadowMap_texture:function(){return t._shadowMapTexture},shadowMap_textureCube:function(){return t._shadowMapTexture},shadowMap_matrix:function(){return t._shadowMapMatrix},shadowMap_cascadeSplits:function(){return t._cascadeSplits},shadowMap_cascadeMatrices:function(){return t._cascadeMatrices},shadowMap_lightDirectionEC:function(){return t._lightDirectionEC},shadowMap_lightPositionEC:function(){return t._lightPositionEC},shadowMap_cascadeDistances:function(){return t._cascadeDistances},shadowMap_texelSizeDepthBiasAndNormalShadingSmooth:function(){let a=wBe;return a.x=1/t._textureSize.x,a.y=1/t._textureSize.y,bt.fromElements(a.x,a.y,i.depthBias,i.normalShadingSmooth,this.combinedUniforms1)},shadowMap_normalOffsetScaleDistanceMaxDistanceAndDarkness:function(){return bt.fromElements(i.normalOffsetScale,t._distance,t.maximumDistance,t._darkness,this.combinedUniforms2)},combinedUniforms1:new bt,combinedUniforms2:new bt};return ze(e,o,!1)}function PBe(t,e,n,i,o,a){let s,l,r;if(c(a)&&(s=a.shaderProgram,l=a.renderState,r=a.uniformMap),a=Ee.shallowClone(n,a),a.castShadows=!0,a.receiveShadows=!1,!c(s)||o!==n.shaderProgram.id||e){let d=n.shaderProgram,m=n.pass===Pt.GLOBE,h=n.pass!==Pt.TRANSLUCENT,u=t._isPointLight,R=t._usesDepthTexture,V=DR.getShadowCastShaderKeyword(u,m,R,h);if(s=i.shaderCache.getDerivedShaderProgram(d,V),!c(s)){let U=d.vertexShaderSource,G=d.fragmentShaderSource,A=DR.createShadowCastVertexShader(U,u,m),S=DR.createShadowCastFragmentShader(G,u,R,h);s=i.shaderCache.createDerivedShaderProgram(d,V,{vertexShaderSource:A,fragmentShaderSource:S,attributeLocations:d._attributeLocations})}l=t._primitiveRenderState,u?l=t._pointRenderState:m&&(l=t._terrainRenderState),n.renderState.cull.enabled||(l=Re(l,!1),l.cull=Re(l.cull,!1),l.cull.enabled=!1,l=he.fromCache(l)),r=Dyt(t,n.uniformMap,m)}return a.shaderProgram=s,a.renderState=l,a.uniformMap=r,a}OR.createReceiveDerivedCommand=function(t,e,n,i,o){c(o)||(o={});let a=t.length>0,s=e.shaderProgram,l=s.vertexShaderSource,r=s.fragmentShaderSource,d=e.pass===Pt.GLOBE,m=!1;if(d&&(m=e.owner.data.renderedMesh.encoding.hasVertexNormals),e.receiveShadows&&a){let h,u;c(o.receiveCommand)&&(h=o.receiveCommand.shaderProgram,u=o.receiveCommand.uniformMap),o.receiveCommand=Ee.shallowClone(e,o.receiveCommand),o.castShadows=!1,o.receiveShadows=!0;let R=o.receiveShaderCastShadows!==e.castShadows,V=o.receiveShaderProgramId!==e.shaderProgram.id;if(!c(h)||V||n||R){let F=DR.getShadowReceiveShaderKeyword(t[0],e.castShadows,d,m);if(h=i.shaderCache.getDerivedShaderProgram(s,F),!c(h)){let U=DR.createShadowReceiveVertexShader(l,d,m),G=DR.createShadowReceiveFragmentShader(r,t[0],e.castShadows,d,m);h=i.shaderCache.createDerivedShaderProgram(s,F,{vertexShaderSource:U,fragmentShaderSource:G,attributeLocations:s._attributeLocations})}u=Dyt(t[0],e.uniformMap,d)}o.receiveCommand.shaderProgram=h,o.receiveCommand.uniformMap=u,o.receiveShaderProgramId=e.shaderProgram.id,o.receiveShaderCastShadows=e.castShadows}return o};OR.createCastDerivedCommand=function(t,e,n,i,o){if(c(o)||(o={}),e.castShadows){let a=o.castCommands;c(a)||(a=o.castCommands=[]);let s=o.castShaderProgramId,l=t.length;a.length=l;for(let r=0;r<l;++r)a[r]=PBe(t[r],n,e,i,s,a[r]);o.castShaderProgramId=e.shaderProgram.id}return o};OR.prototype.isDestroyed=function(){return!1};OR.prototype.destroy=function(){gat(this),this._debugLightFrustum=this._debugLightFrustum&&this._debugLightFrustum.destroy(),this._debugCameraFrustum=this._debugCameraFrustum&&this._debugCameraFrustum.destroy(),this._debugShadowViewCommand=this._debugShadowViewCommand&&this._debugShadowViewCommand.shaderProgram&&this._debugShadowViewCommand.shaderProgram.destroy();for(let t=0;t<this._numberOfCascades;++t)this._debugCascadeFrustums[t]=this._debugCascadeFrustums[t]&&this._debugCascadeFrustums[t].destroy();return At(this)};var fW=OR;var pNo=b(W(),1);var O1o=b(W(),1),j_=`uniform sampler2D u_opaqueDepthTexture; uniform sampler2D u_translucentDepthTexture; in vec2 v_textureCoordinates; @@ -11174,7 +11174,7 @@ void main() translucentDepth = czm_branchFreeTernary(translucentDepth > opaqueDepth, 1.0, translucentDepth); out_FragColor = czm_packDepth(translucentDepth); } -`;var w1o=R(W(),1),GS=`uniform sampler2D colorTexture; +`;var w1o=b(W(),1),GT=`uniform sampler2D colorTexture; #ifdef DEBUG_SHOW_DEPTH uniform sampler2D u_packedTranslucentDepth; @@ -11205,7 +11205,7 @@ void main() out_FragColor = color; #endif } -`;var vBe=!1;function WU(t){this._drawClassificationFBO=new Ro({createDepthAttachments:!1}),this._accumulationFBO=new Ro({createDepthAttachments:!1}),this._packFBO=new Ro,this._opaqueDepthStencilTexture=void 0,this._textureToComposite=void 0,this._translucentDepthStencilTexture=void 0,this._packDepthCommand=void 0,this._accumulateCommand=void 0,this._compositeCommand=void 0,this._copyCommand=void 0,this._clearColorCommand=new ao({color:new v(0,0,0,0),owner:this}),this._clearDepthStencilCommand=new ao({depth:1,stencil:0,owner:this}),this._supported=t.depthTexture,this._viewport=new Fe,this._rsDepth=void 0,this._rsAccumulate=void 0,this._rsComp=void 0,this._useScissorTest=void 0,this._scissorRectangle=void 0,this._hasTranslucentDepth=!1,this._frustumsDrawn=0}Object.defineProperties(WU.prototype,{hasTranslucentDepth:{get:function(){return this._hasTranslucentDepth}}});function Oyt(t){t._textureToComposite=void 0,t._translucentDepthStencilTexture=t._translucentDepthStencilTexture&&!t._translucentDepthStencilTexture.isDestroyed()&&t._translucentDepthStencilTexture.destroy()}function Hyt(t){t._drawClassificationFBO.destroy(),t._accumulationFBO.destroy(),t._packFBO.destroy()}function KBe(t,e,n,i){Oyt(t),t._translucentDepthStencilTexture=new hn({context:e,width:n,height:i,pixelFormat:Ye.DEPTH_STENCIL,pixelDatatype:Ue.UNSIGNED_INT_24_8,sampler:Hn.NEAREST})}function zBe(t,e,n,i){Hyt(t),t._drawClassificationFBO.setDepthStencilTexture(t._translucentDepthStencilTexture),t._drawClassificationFBO.update(e,n,i),t._accumulationFBO.setDepthStencilTexture(t._translucentDepthStencilTexture),t._accumulationFBO.update(e,n,i),t._packFBO.update(e,n,i)}function jBe(t,e,n,i){if(!t.isSupported())return;t._opaqueDepthStencilTexture=i;let o=t._opaqueDepthStencilTexture.width,a=t._opaqueDepthStencilTexture.height;t._drawClassificationFBO.isDirty(o,a)&&(KBe(t,e,o,a),zBe(t,e,o,a));let s,l;if(c(t._packDepthCommand)||(s=new Ve({sources:[j_]}),l={u_opaqueDepthTexture:function(){return t._opaqueDepthStencilTexture},u_translucentDepthTexture:function(){return t._translucentDepthStencilTexture}},t._packDepthCommand=e.createViewportQuadCommand(s,{uniformMap:l,owner:t})),!c(t._compositeCommand)){s=new Ve({sources:[GS]}),l={colorTexture:function(){return t._textureToComposite}},vBe&&(s.defines=["DEBUG_SHOW_DEPTH"],l.u_packedTranslucentDepth=function(){return t._packFBO.getColorTexture()}),t._compositeCommand=e.createViewportQuadCommand(s,{uniformMap:l,owner:t});let m=t._compositeCommand,h=m.shaderProgram,Z=e.shaderCache.createDerivedShaderProgram(h,"pick",{vertexShaderSource:h.vertexShaderSource,fragmentShaderSource:new Ve({sources:s.sources,defines:["PICK"]}),attributeLocations:h._attributeLocations}),b=Ee.shallowClone(m);b.shaderProgram=Z,m.derivedCommands.pick=b}c(t._copyCommand)||(s=new Ve({sources:[GS]}),l={colorTexture:function(){return t._drawClassificationFBO.getColorTexture()}},t._copyCommand=e.createViewportQuadCommand(s,{uniformMap:l,owner:t})),c(t._accumulateCommand)||(s=new Ve({sources:[GS]}),l={colorTexture:function(){return t._drawClassificationFBO.getColorTexture()}},t._accumulateCommand=e.createViewportQuadCommand(s,{uniformMap:l,owner:t})),t._viewport.width=o,t._viewport.height=a;let r=!Fe.equals(t._viewport,n.viewport),d=r!==t._useScissorTest;t._useScissorTest=r,Fe.equals(t._scissorRectangle,n.viewport)||(t._scissorRectangle=Fe.clone(n.viewport,t._scissorRectangle),d=!0),(!c(t._rsDepth)||!Fe.equals(t._viewport,t._rsDepth.viewport)||d)&&(t._rsDepth=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle}})),c(t._packDepthCommand)&&(t._packDepthCommand.renderState=t._rsDepth),(!c(t._rsAccumulate)||!Fe.equals(t._viewport,t._rsAccumulate.viewport)||d)&&(t._rsAccumulate=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle},stencilTest:{enabled:!0,frontFunction:Li.EQUAL,reference:gn.CESIUM_3D_TILE_MASK}})),c(t._accumulateCommand)&&(t._accumulateCommand.renderState=t._rsAccumulate),(!c(t._rsComp)||!Fe.equals(t._viewport,t._rsComp.viewport)||d)&&(t._rsComp=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle},blending:Pn.ALPHA_BLEND})),c(t._compositeCommand)&&(t._compositeCommand.renderState=t._rsComp,t._compositeCommand.derivedCommands.pick.renderState=t._rsComp)}WU.prototype.executeTranslucentCommands=function(t,e,n,i,o){let a=i.length,s,l,r=t.frameState.useLogDepth,d=t.context,m=n.framebuffer;for(l=0;l<a;++l)if(s=i[l],s=r?s.derivedCommands.logDepth.command:s,s.depthForTranslucentClassification){this._hasTranslucentDepth=!0;break}if(this._hasTranslucentDepth){for(jBe(this,d,n,o),n.framebuffer=this._drawClassificationFBO.framebuffer,this._clearDepthStencilCommand.execute(d,n),l=0;l<a;++l){if(s=i[l],s=r?s.derivedCommands.logDepth.command:s,!s.depthForTranslucentClassification)continue;let h=s.derivedCommands.depth.depthOnlyCommand;e(h,t,d,n)}this._frustumsDrawn+=this._hasTranslucentDepth?1:0,this._hasTranslucentDepth&&(n.framebuffer=this._packFBO.framebuffer,this._packDepthCommand.execute(d,n)),n.framebuffer=m}};WU.prototype.executeClassificationCommands=function(t,e,n,i){if(!this._hasTranslucentDepth)return;let o=t.context,a=o.uniformState,s=n.framebuffer;this._frustumsDrawn===2&&(n.framebuffer=this._accumulationFBO.framebuffer,this._copyCommand.execute(o,n)),n.framebuffer=this._drawClassificationFBO.framebuffer,this._frustumsDrawn>1&&this._clearColorCommand.execute(o,n),a.updatePass(Pt.CESIUM_3D_TILE_CLASSIFICATION);let l=a.globeDepthTexture;a.globeDepthTexture=this._packFBO.getColorTexture();let r=i.commands[Pt.CESIUM_3D_TILE_CLASSIFICATION],d=i.indices[Pt.CESIUM_3D_TILE_CLASSIFICATION];for(let m=0;m<d;++m)e(r[m],t,o,n);a.globeDepthTexture=l,n.framebuffer=s,this._frustumsDrawn!==1&&(n.framebuffer=this._accumulationFBO.framebuffer,this._accumulateCommand.execute(o,n),n.framebuffer=s)};WU.prototype.execute=function(t,e){if(!this._hasTranslucentDepth)return;this._frustumsDrawn===1?this._textureToComposite=this._drawClassificationFBO.getColorTexture():this._textureToComposite=this._accumulationFBO.getColorTexture(),(t.frameState.passes.pick?this._compositeCommand.derivedCommands.pick:this._compositeCommand).execute(t.context,e),qBe(this,t,e)};function qBe(t,e,n){if(!t._hasTranslucentDepth)return;let i=n.framebuffer;n.framebuffer=t._drawClassificationFBO.framebuffer,t._clearColorCommand.execute(e._context,n),n.framebuffer=i,t._frustumsDrawn>1&&(n.framebuffer=t._accumulationFBO.framebuffer,t._clearColorCommand.execute(e._context,n)),t._hasTranslucentDepth=!1,t._frustumsDrawn=0}WU.prototype.isSupported=function(){return this._supported};WU.prototype.isDestroyed=function(){return!1};WU.prototype.destroy=function(){return Oyt(this),Hyt(this),c(this._compositeCommand)&&(this._compositeCommand.shaderProgram=this._compositeCommand.shaderProgram&&this._compositeCommand.shaderProgram.destroy()),c(this._packDepthCommand)&&(this._packDepthCommand.shaderProgram=this._packDepthCommand.shaderProgram&&this._packDepthCommand.shaderProgram.destroy()),At(this)};var q_=WU;function $Be(){this.command=void 0,this.near=void 0,this.far=void 0}function lj(t,e,n){let i=t.context,o;i.depthTexture&&(o=new D_);let a;t._useOIT&&i.depthTexture&&(a=new w_(i));let s=new Md(i);s.viewport=Fe.clone(n),this.camera=e,this._cameraClone=Aa.clone(e),this._cameraStartFired=!1,this._cameraMovedTime=void 0,this.viewport=n,this.passState=s,this.pickFramebuffer=new z_(i),this.pickDepthFramebuffer=new v_,this.sceneFramebuffer=new FS,this.globeDepth=o,this.globeTranslucencyFramebuffer=new O_,this.oit=a,this.translucentTileClassification=new q_(i),this.pickDepths=[],this.frustumCommandsList=[],this.debugFrustumStatistics=void 0,this._commandExtents=[]}var wyt=new p,Pyt=new p;function tQe(t,e){let n=Math.max(Math.abs(t.x),Math.abs(e.x)),i=Math.max(Math.abs(t.y),Math.abs(e.y)),o=Math.max(Math.abs(t.z),Math.abs(e.z));return Math.max(Math.max(n,i),o)}function eQe(t,e,n){let i=1/Math.max(1,tQe(t.position,e.position));return p.multiplyByScalar(t.position,i,wyt),p.multiplyByScalar(e.position,i,Pyt),p.equalsEpsilon(wyt,Pyt,n)&&p.equalsEpsilon(t.direction,e.direction,n)&&p.equalsEpsilon(t.up,e.up,n)&&p.equalsEpsilon(t.right,e.right,n)&&L.equalsEpsilon(t.transform,e.transform,n)&&t.frustum.equalsEpsilon(e.frustum,n)}lj.prototype.checkForCameraUpdates=function(t){let e=this.camera,n=this._cameraClone;return eQe(e,n,k.EPSILON15)?(this._cameraStartFired&&Oi()-this._cameraMovedTime>t.cameraEventWaitTime&&(e.moveEnd.raiseEvent(),this._cameraStartFired=!1),!1):(this._cameraStartFired||(e.moveStart.raiseEvent(),this._cameraStartFired=!0),this._cameraMovedTime=Oi(),Aa.clone(e,n),!0)};function nQe(t,e,n,i){let o=e.frameState,a=o.camera,s=o.useLogDepth?e.logarithmicDepthFarToNearRatio:e.farToNearRatio,l=e.mode===ut.SCENE2D,r=e.nearToFarDistance2D;i*=1+k.EPSILON2,n=Math.min(Math.max(n,a.frustum.near),a.frustum.far),i=Math.max(Math.min(i,a.frustum.far),n);let d;l?(i=Math.min(i,a.position.z+e.nearToFarDistance2D),n=Math.min(n,i),d=Math.ceil(Math.max(1,i-n)/e.nearToFarDistance2D)):d=Math.ceil(Math.log(i/n)/Math.log(s));let m=t.frustumCommandsList;d||(d=0),m.length=d;for(let h=0;h<d;++h){let Z,b;l?(Z=Math.min(i-r,n+h*r),b=Math.min(i,Z+r)):(Z=Math.max(n,Math.pow(s,h)*n),b=Math.min(i,s*Z));let u=m[h];c(u)?(u.near=Z,u.far=b):u=m[h]=new __(Z,b)}}function iQe(t,e,n,i,o){e.debugShowFrustums&&(n.debugOverlappingFrustums=0);let a=t.frustumCommandsList,s=a.length;for(let l=0;l<s;++l){let r=a[l],d=r.near,m=r.far;if(i>m)continue;if(o<d)break;let h=n.pass,Z=r.indices[h]++;if(r.commands[h][Z]=n,e.debugShowFrustums&&(n.debugOverlappingFrustums|=1<<l),n.executeInClosestFrustum)break}if(e.debugShowFrustums){let l=t.debugFrustumStatistics.commandsInFrustums;l[n.debugOverlappingFrustums]=c(l[n.debugOverlappingFrustums])?l[n.debugOverlappingFrustums]+1:1,++t.debugFrustumStatistics.totalCommands}e.updateDerivedCommands(n)}var vyt=new Jl,oQe=new hd;lj.prototype.createPotentiallyVisibleSet=function(t){let e=t.frameState,n=e.camera,i=n.directionWC,o=n.positionWC,a=t._computeCommandList,s=t._overlayCommandList,l=e.commandList;t.debugShowFrustums&&(this.debugFrustumStatistics={totalCommands:0,commandsInFrustums:{}});let r=this.frustumCommandsList,d=r.length,m=Pt.NUMBER_OF_PASSES;for(let E=0;E<d;++E)for(let I=0;I<m;++I)r[E].indices[I]=0;a.length=0,s.length=0;let h=this._commandExtents,Z=h.length,b=0,u=+Number.MAX_VALUE,F=-Number.MAX_VALUE,U=e.shadowState.shadowsEnabled,G=+Number.MAX_VALUE,A=-Number.MAX_VALUE,T=Number.MAX_VALUE,g=e.mode===ut.SCENE3D?e.occluder:void 0,C=e.cullingVolume,y=vyt.planes;for(let E=0;E<5;++E)y[E]=C.planes[E];C=vyt;let Y=l.length;for(let E=0;E<Y;++E){let I=l[E],B=I.pass;if(B===Pt.COMPUTE)a.push(I);else if(B===Pt.OVERLAY)s.push(I);else{let X,_,P=I.boundingVolume;if(c(P)){if(!t.isVisible(I,C,g))continue;let z=P.computePlaneDistances(o,i,oQe);if(X=z.start,_=z.stop,u=Math.min(u,X),F=Math.max(F,_),U&&I.receiveShadows&&X<fW.MAXIMUM_DISTANCE&&!(B===Pt.GLOBE&&X<-100&&_>100)){let H=_-X;B!==Pt.GLOBE&&X<100&&(T=Math.min(T,H)),G=Math.min(G,X),A=Math.max(A,_)}}else I instanceof ao?(X=n.frustum.near,_=n.frustum.far):(X=n.frustum.near,_=n.frustum.far,u=Math.min(u,X),F=Math.max(F,_));let w=h[b];c(w)||(w=h[b]=new $Be),w.command=I,w.near=X,w.far=_,b++}}U&&(G=Math.min(Math.max(G,n.frustum.near),n.frustum.far),A=Math.max(Math.min(A,n.frustum.far),G)),U&&(e.shadowState.nearPlane=G,e.shadowState.farPlane=A,e.shadowState.closestObjectSize=T),nQe(this,t,u,F);let Q,J;for(Q=0;Q<b;Q++)J=h[Q],iQe(this,t,J.command,J.near,J.far);if(b<Z)for(Q=b;Q<Z&&(J=h[Q],!!c(J.command));Q++)J.command=void 0;let M=r.length,V=e.frustumSplits;V.length=M+1;for(let E=0;E<M;++E)V[E]=r[E].near,E===M-1&&(V[E+1]=r[E].far)};lj.prototype.destroy=function(){this.pickFramebuffer=this.pickFramebuffer&&this.pickFramebuffer.destroy(),this.pickDepthFramebuffer=this.pickDepthFramebuffer&&this.pickDepthFramebuffer.destroy(),this.sceneFramebuffer=this.sceneFramebuffer&&this.sceneFramebuffer.destroy(),this.globeDepth=this.globeDepth&&this.globeDepth.destroy(),this.oit=this.oit&&this.oit.destroy(),this.translucentTileClassification=this.translucentTileClassification&&this.translucentTileClassification.destroy(),this.globeTranslucencyFramebuffer=this.globeTranslucencyFramebuffer&&this.globeTranslucencyFramebuffer.destroy();let t,e=this.pickDepths,n=e.length;for(t=0;t<n;++t)e[t].destroy()};var AS=lj;var zyt=.1,aQe=new Eu({pass:ns.MOST_DETAILED_PRELOAD}),sQe=new Eu({pass:ns.MOST_DETAILED_PICK}),dj=new Eu({pass:ns.PICK});function nd(t){this._mostDetailedRayPicks=[],this.pickRenderStateCache={},this._pickPositionCache={},this._pickPositionCacheDirty=!1;let e=new Fe(0,0,1,1),n=new Aa(t);n.frustum=new wn({width:zyt,aspectRatio:1,near:.1}),this._pickOffscreenView=new AS(t,n,e)}nd.prototype.update=function(){this._pickPositionCacheDirty=!0};nd.prototype.getPickDepth=function(t,e){let n=t.view.pickDepths,i=n[e];return c(i)||(i=new M_,n[e]=i),i};var lQe=new el,rQe=new p,rj=new p,dQe=new K,cQe=new L;function mQe(t,e,n,i,o){let a=t.camera,s=a.frustum,l=s.offCenterFrustum;c(l)&&(s=l);let r=2*(e.x-o.x)/o.width-1;r*=(s.right-s.left)*.5;let d=2*(o.height-e.y-o.y)/o.height-1;d*=(s.top-s.bottom)*.5;let m=L.clone(a.transform,cQe);a._setTransform(L.IDENTITY);let h=p.clone(a.position,rQe);p.multiplyByScalar(a.right,r,rj),p.add(rj,h,h),p.multiplyByScalar(a.up,d,rj),p.add(rj,h,h),a._setTransform(m),t.mode===ut.SCENE2D&&p.fromElements(h.z,h.x,h.y,h);let Z=s.getPixelDimensions(o.width,o.height,1,1,dQe),b=lQe;return b.right=Z.x*.5,b.left=-b.right,b.top=Z.y*.5,b.bottom=-b.top,b.near=s.near,b.far=s.far,b.computeCullingVolume(h,a.directionWC,a.upWC)}var hQe=new em,pQe=new K;function uQe(t,e,n,i,o){let a=t.camera,s=a.frustum,l=s.near,r=Math.tan(s.fovy*.5),d=s.aspectRatio*r,m=2*(e.x-o.x)/o.width-1,h=2*(o.height-e.y-o.y)/o.height-1,Z=m*l*d,b=h*l*r,u=s.getPixelDimensions(o.width,o.height,1,1,pQe),F=u.x*n*.5,U=u.y*i*.5,G=hQe;return G.top=b+U,G.bottom=b-U,G.right=Z+F,G.left=Z-F,G.near=l,G.far=s.far,G.computeCullingVolume(a.positionWC,a.directionWC,a.upWC)}function Cat(t,e,n,i,o){let a=t.camera.frustum;return a instanceof wn||a instanceof el?mQe(t,e,n,i,o):uQe(t,e,n,i,o)}var dV=3,FW=3,hc=new Fe(0,0,dV,FW),Iat=new K,cj=new v(0,0,0,0);nd.prototype.pick=function(t,e,n,i){dV=f(n,3),FW=f(i,dV);let{context:o,frameState:a,defaultView:s}=t,{viewport:l,pickFramebuffer:r}=s;t.view=s,l.x=0,l.y=0,l.width=o.drawingBufferWidth,l.height=o.drawingBufferHeight;let d=s.passState;d.viewport=Fe.clone(l,d.viewport);let m=qo.transformWindowToDrawingBuffer(t,e,Iat);t.jobScheduler.disableThisFrame(),t.updateFrameState(),a.cullingVolume=Cat(t,m,dV,FW,l),a.invertClassification=!1,a.passes.pick=!0,a.tilesetPassState=dj,o.uniformState.update(a),t.updateEnvironment(),hc.x=m.x-(dV-1)*.5,hc.y=t.drawingBufferHeight-m.y-(FW-1)*.5,hc.width=dV,hc.height=FW,d=r.begin(hc,l),t.updateAndExecuteCommands(d,cj),t.resolveFramebuffers(d);let h=r.end(hc);return o.endFrame(),h};nd.prototype.pickVoxelCoordinate=function(t,e,n,i){dV=f(n,3),FW=f(i,dV);let{context:o,frameState:a,defaultView:s}=t,{viewport:l,pickFramebuffer:r}=s;t.view=s,l.x=0,l.y=0,l.width=o.drawingBufferWidth,l.height=o.drawingBufferHeight;let d=s.passState;d.viewport=Fe.clone(l,d.viewport);let m=qo.transformWindowToDrawingBuffer(t,e,Iat);t.jobScheduler.disableThisFrame(),t.updateFrameState(),a.cullingVolume=Cat(t,m,dV,FW,l),a.invertClassification=!1,a.passes.pickVoxel=!0,a.tilesetPassState=dj,o.uniformState.update(a),t.updateEnvironment(),hc.x=m.x-(dV-1)*.5,hc.y=t.drawingBufferHeight-m.y-(FW-1)*.5,hc.width=dV,hc.height=FW,d=r.begin(hc,l),t.updateAndExecuteCommands(d,cj),t.resolveFramebuffers(d);let h=r.readVoxelInfo(hc);return o.endFrame(),h};function ZQe(t,e){let{defaultView:n,context:i,frameState:o,environmentState:a}=t,{viewport:s,pickDepthFramebuffer:l}=n;t.view=n,s.x=0,s.y=0,s.width=i.drawingBufferWidth,s.height=i.drawingBufferHeight;let r=n.passState;r.viewport=Fe.clone(s,r.viewport),t.clearPasses(o.passes),o.passes.pick=!0,o.passes.depth=!0,o.cullingVolume=Cat(t,e,1,1,s),o.tilesetPassState=dj,t.updateEnvironment(),a.renderTranslucentDepthForPick=!0,r=l.update(i,e,s),t.updateAndExecuteCommands(r,cj),t.resolveFramebuffers(r),i.endFrame()}var VQe=new Io,bQe=new em,RQe=new wn,WQe=new el;nd.prototype.pickPositionWorldCoordinates=function(t,e,n){if(!t.useDepthPicking)return;let i=e.toString();if(this._pickPositionCacheDirty)this._pickPositionCache={},this._pickPositionCacheDirty=!1;else if(this._pickPositionCache.hasOwnProperty(i))return p.clone(this._pickPositionCache[i],n);let{context:o,frameState:a,camera:s,defaultView:l}=t,{uniformState:r}=o;t.view=l;let d=qo.transformWindowToDrawingBuffer(t,e,Iat);t.pickTranslucentDepth?ZQe(t,d):(t.updateFrameState(),r.update(a),t.updateEnvironment()),d.y=t.drawingBufferHeight-d.y;let m;c(s.frustum.fov)?m=s.frustum.clone(VQe):c(s.frustum.infiniteProjectionMatrix)?m=s.frustum.clone(bQe):c(s.frustum.width)?m=s.frustum.clone(RQe):m=s.frustum.clone(WQe);let h=l.frustumCommandsList,Z=h.length;for(let b=0;b<Z;++b){let F=this.getPickDepth(t,b).getDepth(o,d.x,d.y);if(c(F)&&F>0&&F<1){let U=h[b],G;return t.mode===ut.SCENE2D?(G=s.position.z,s.position.z=G-U.near+1,m.far=Math.max(1,U.far-U.near),m.near=1,r.update(a),r.updateFrustum(m)):(m.near=U.near*(b!==0?t.opaqueFrustumNearOffset:1),m.far=U.far,r.updateFrustum(m)),n=qo.drawingBufferToWgs84Coordinates(t,d,F,n),t.mode===ut.SCENE2D&&(s.position.z=G,r.update(a)),this._pickPositionCache[i]=p.clone(n),n}}this._pickPositionCache[i]=void 0};var fQe=new gt;nd.prototype.pickPosition=function(t,e,n){if(n=this.pickPositionWorldCoordinates(t,e,n),c(n)&&t.mode!==ut.SCENE3D){p.fromElements(n.y,n.z,n.x,n);let i=t.mapProjection,o=i.ellipsoid,a=i.unproject(n,fQe);o.cartographicToCartesian(a,n)}return n};function jyt(t,e){let n,i,o=[],a=[],s=[],l=[];c(t)||(t=Number.MAX_VALUE);let r=e();for(;c(r);){let d=r.object,m=r.position,h=r.exclude;if(c(m)&&!c(d)){o.push(r);break}if(!c(d)||!c(d.primitive)||!h&&(o.push(r),0>=--t))break;let Z=d.primitive,b=!1;typeof Z.getGeometryInstanceAttributes=="function"&&c(d.id)&&(i=Z.getGeometryInstanceAttributes(d.id),c(i)&&c(i.show)&&(b=!0,i.show=pi.toValue(!1,i.show),s.push(i))),d instanceof Fr&&(b=!0,d.show=!1,l.push(d)),b||(Z.show=!1,a.push(Z)),r=e()}for(n=0;n<a.length;++n)a[n].show=!0;for(n=0;n<s.length;++n)i=s[n],i.show=pi.toValue(!0,i.show);for(n=0;n<l.length;++n)l[n].show=!0;return o}nd.prototype.drillPick=function(t,e,n,i,o){let a=this;return jyt(n,function(){let r=a.pick(t,e,i,o);if(c(r))return{object:r,position:void 0,exclude:!1}}).map(function(r){return r.object})};var Kyt=new p,FQe=new p;function UQe(t,e,n){this.ray=t,this.width=e,this.tilesets=n,this.ready=!1;let i=this;this.promise=new Promise(o=>{i._completePick=()=>{o()}})}function qyt(t,e,n,i){let o=e.direction,a=p.mostOrthogonalAxis(o,Kyt),s=p.cross(o,a,Kyt),l=p.cross(o,s,FQe);return i.position=e.origin,i.direction=o,i.up=l,i.right=s,i.frustum.width=f(n,zyt),i.frustum.computeCullingVolume(i.positionWC,i.directionWC,i.upWC)}function GQe(t,e,n){let i=e.frameState,{ray:o,width:a,tilesets:s}=n,l=t._pickOffscreenView.camera,r=qyt(t,o,a,l),d=aQe;d.camera=l,d.cullingVolume=r;let m=!0,h=s.length;for(let Z=0;Z<h;++Z){let b=s[Z];b.show&&e.primitives.contains(b)&&(b.updateForPass(i,d),m=m&&d.ready)}return m&&n._completePick(),m}nd.prototype.updateMostDetailedRayPicks=function(t){let e=this._mostDetailedRayPicks;for(let n=0;n<e.length;++n)GQe(this,t,e[n])&&e.splice(n--,1)};function $yt(t,e,n){for(let i=0;i<t.length;++i){let o=t.get(i);o.show&&(c(o.isCesium3DTileset)?(!c(e)||e.indexOf(o)===-1)&&n.push(o):o instanceof Dm&&$yt(o,e,n))}}function mj(t,e,n,i,o,a){let s=[];if($yt(e.primitives,i,s),s.length===0)return Promise.resolve(a());let l=new UQe(n,o,s);return t._mostDetailedRayPicks.push(l),l.promise.then(function(){return a()})}function AQe(t,e){return!c(t)||!c(e)||e.length===0?!1:e.indexOf(t)>-1||e.indexOf(t.primitive)>-1||e.indexOf(t.id)>-1}function TQe(t,e,n,i,o,a,s){let{context:l,frameState:r}=e,d=l.uniformState,m=t._pickOffscreenView;e.view=m,qyt(t,n,o,m.camera),hc=Fe.clone(m.viewport,hc);let h=m.pickFramebuffer.begin(hc,m.viewport);e.jobScheduler.disableThisFrame(),e.updateFrameState(),r.invertClassification=!1,r.passes.pick=!0,r.passes.offscreen=!0,s?r.tilesetPassState=sQe:r.tilesetPassState=dj,d.update(r),e.updateEnvironment(),e.updateAndExecuteCommands(h,cj),e.resolveFramebuffers(h);let Z,b=m.pickFramebuffer.end(hc);if(e.context.depthTexture){let u=m.frustumCommandsList.length;for(let F=0;F<u;++F){let G=t.getPickDepth(e,F).getDepth(l,0,0);if(c(G)&&G>0&&G<1){let A=m.frustumCommandsList[F],T=A.near*(F!==0?e.opaqueFrustumNearOffset:1),g=A.far,C=T+G*(g-T);Z=di.getPoint(n,C);break}}}if(e.view=e.defaultView,l.endFrame(),c(b)||c(Z))return{object:b,position:Z,exclude:!c(Z)&&a||AQe(b,i)}}function tBt(t,e,n,i,o,a,s,l){return jyt(i,function(){return TQe(t,e,n,o,a,s,l)})}function O1(t,e,n,i,o,a,s){let l=tBt(t,e,n,1,i,o,a,s);if(l.length>0)return l[0]}function eBt(t,e,n,i,o,a,s,l){return tBt(t,e,n,i,o,a,s,l)}function hj(t,e){return new Promise((n,i)=>{e.then(function(o){let a=t.postRender.addEventListener(function(){a(),n(o)});t.requestRender()}).catch(function(o){i(o)})})}nd.prototype.pickFromRay=function(t,e,n,i){return O1(this,t,e,n,i,!1,!1)};nd.prototype.drillPickFromRay=function(t,e,n,i,o){return eBt(this,t,e,n,i,o,!1,!1)};nd.prototype.pickFromRayMostDetailed=function(t,e,n,i){let o=this;return e=di.clone(e),n=c(n)?n.slice():n,hj(t,mj(o,t,e,n,i,function(){return O1(o,t,e,n,i,!1,!0)}))};nd.prototype.drillPickFromRayMostDetailed=function(t,e,n,i,o){let a=this;return e=di.clone(e),i=c(i)?i.slice():i,hj(t,mj(a,t,e,i,o,function(){return eBt(a,t,e,n,i,o,!1,!0)}))};var SQe=new p,gQe=new p,EQe=new di,nBt=new gt;function Nat(t,e){let n=t.globe,i=c(n)?n.ellipsoid:t.mapProjection.ellipsoid,o=uo._defaultMaxTerrainHeight,a=i.geodeticSurfaceNormalCartographic(e,gQe),s=gt.toCartesian(e,i,SQe),l=EQe;l.origin=s,l.direction=a;let r=new di;return di.getPoint(l,o,r.origin),p.negate(a,r.direction),r}function iBt(t,e){let n=t.globe,i=c(n)?n.ellipsoid:t.mapProjection.ellipsoid,o=gt.fromCartesian(e,i,nBt);return Nat(t,o)}function oBt(t,e){let n=t.globe,i=c(n)?n.ellipsoid:t.mapProjection.ellipsoid;return gt.fromCartesian(e,i,nBt).height}function CQe(t,e,n,i,o){let a=Nat(e,n);return mj(t,e,a,i,o,function(){let s=O1(t,e,a,i,o,!0,!0);if(c(s))return oBt(e,s.position)})}function IQe(t,e,n,i,o,a){let s=iBt(e,n);return mj(t,e,s,i,o,function(){let l=O1(t,e,s,i,o,!0,!0);if(c(l))return p.clone(l.position,a)})}nd.prototype.sampleHeight=function(t,e,n,i){let o=Nat(t,e),a=O1(this,t,o,n,i,!0,!1);if(c(a))return oBt(t,a.position)};nd.prototype.clampToHeight=function(t,e,n,i,o){let a=iBt(t,e),s=O1(this,t,a,n,i,!0,!1);if(c(s))return p.clone(s.position,o)};nd.prototype.sampleHeightMostDetailed=function(t,e,n,i){n=c(n)?n.slice():n;let o=e.length,a=new Array(o);for(let s=0;s<o;++s)a[s]=CQe(this,t,e[s],n,i);return hj(t,Promise.all(a).then(function(s){let l=s.length;for(let r=0;r<l;++r)e[r].height=s[r];return e}))};nd.prototype.clampToHeightMostDetailed=function(t,e,n,i){n=c(n)?n.slice():n;let o=e.length,a=new Array(o);for(let s=0;s<o;++s)a[s]=IQe(this,t,e[s],n,i,e[s]);return hj(t,Promise.all(a).then(function(s){let l=s.length;for(let r=0;r<l;++r)e[r]=s[r];return e}))};nd.prototype.destroy=function(){this._pickOffscreenView=this._pickOffscreenView&&this._pickOffscreenView.destroy()};var $_=nd;var yQo=R(W(),1);var lQo=R(W(),1);var myo=R(W(),1),t9=`uniform sampler2D colorTexture; +`;var vBe=!1;function WU(t){this._drawClassificationFBO=new bo({createDepthAttachments:!1}),this._accumulationFBO=new bo({createDepthAttachments:!1}),this._packFBO=new bo,this._opaqueDepthStencilTexture=void 0,this._textureToComposite=void 0,this._translucentDepthStencilTexture=void 0,this._packDepthCommand=void 0,this._accumulateCommand=void 0,this._compositeCommand=void 0,this._copyCommand=void 0,this._clearColorCommand=new ao({color:new v(0,0,0,0),owner:this}),this._clearDepthStencilCommand=new ao({depth:1,stencil:0,owner:this}),this._supported=t.depthTexture,this._viewport=new Fe,this._rsDepth=void 0,this._rsAccumulate=void 0,this._rsComp=void 0,this._useScissorTest=void 0,this._scissorRectangle=void 0,this._hasTranslucentDepth=!1,this._frustumsDrawn=0}Object.defineProperties(WU.prototype,{hasTranslucentDepth:{get:function(){return this._hasTranslucentDepth}}});function Oyt(t){t._textureToComposite=void 0,t._translucentDepthStencilTexture=t._translucentDepthStencilTexture&&!t._translucentDepthStencilTexture.isDestroyed()&&t._translucentDepthStencilTexture.destroy()}function Hyt(t){t._drawClassificationFBO.destroy(),t._accumulationFBO.destroy(),t._packFBO.destroy()}function KBe(t,e,n,i){Oyt(t),t._translucentDepthStencilTexture=new hn({context:e,width:n,height:i,pixelFormat:Ye.DEPTH_STENCIL,pixelDatatype:Ue.UNSIGNED_INT_24_8,sampler:Hn.NEAREST})}function zBe(t,e,n,i){Hyt(t),t._drawClassificationFBO.setDepthStencilTexture(t._translucentDepthStencilTexture),t._drawClassificationFBO.update(e,n,i),t._accumulationFBO.setDepthStencilTexture(t._translucentDepthStencilTexture),t._accumulationFBO.update(e,n,i),t._packFBO.update(e,n,i)}function jBe(t,e,n,i){if(!t.isSupported())return;t._opaqueDepthStencilTexture=i;let o=t._opaqueDepthStencilTexture.width,a=t._opaqueDepthStencilTexture.height;t._drawClassificationFBO.isDirty(o,a)&&(KBe(t,e,o,a),zBe(t,e,o,a));let s,l;if(c(t._packDepthCommand)||(s=new Ze({sources:[j_]}),l={u_opaqueDepthTexture:function(){return t._opaqueDepthStencilTexture},u_translucentDepthTexture:function(){return t._translucentDepthStencilTexture}},t._packDepthCommand=e.createViewportQuadCommand(s,{uniformMap:l,owner:t})),!c(t._compositeCommand)){s=new Ze({sources:[GT]}),l={colorTexture:function(){return t._textureToComposite}},vBe&&(s.defines=["DEBUG_SHOW_DEPTH"],l.u_packedTranslucentDepth=function(){return t._packFBO.getColorTexture()}),t._compositeCommand=e.createViewportQuadCommand(s,{uniformMap:l,owner:t});let m=t._compositeCommand,h=m.shaderProgram,u=e.shaderCache.createDerivedShaderProgram(h,"pick",{vertexShaderSource:h.vertexShaderSource,fragmentShaderSource:new Ze({sources:s.sources,defines:["PICK"]}),attributeLocations:h._attributeLocations}),R=Ee.shallowClone(m);R.shaderProgram=u,m.derivedCommands.pick=R}c(t._copyCommand)||(s=new Ze({sources:[GT]}),l={colorTexture:function(){return t._drawClassificationFBO.getColorTexture()}},t._copyCommand=e.createViewportQuadCommand(s,{uniformMap:l,owner:t})),c(t._accumulateCommand)||(s=new Ze({sources:[GT]}),l={colorTexture:function(){return t._drawClassificationFBO.getColorTexture()}},t._accumulateCommand=e.createViewportQuadCommand(s,{uniformMap:l,owner:t})),t._viewport.width=o,t._viewport.height=a;let r=!Fe.equals(t._viewport,n.viewport),d=r!==t._useScissorTest;t._useScissorTest=r,Fe.equals(t._scissorRectangle,n.viewport)||(t._scissorRectangle=Fe.clone(n.viewport,t._scissorRectangle),d=!0),(!c(t._rsDepth)||!Fe.equals(t._viewport,t._rsDepth.viewport)||d)&&(t._rsDepth=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle}})),c(t._packDepthCommand)&&(t._packDepthCommand.renderState=t._rsDepth),(!c(t._rsAccumulate)||!Fe.equals(t._viewport,t._rsAccumulate.viewport)||d)&&(t._rsAccumulate=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle},stencilTest:{enabled:!0,frontFunction:Li.EQUAL,reference:gn.CESIUM_3D_TILE_MASK}})),c(t._accumulateCommand)&&(t._accumulateCommand.renderState=t._rsAccumulate),(!c(t._rsComp)||!Fe.equals(t._viewport,t._rsComp.viewport)||d)&&(t._rsComp=he.fromCache({viewport:t._viewport,scissorTest:{enabled:t._useScissorTest,rectangle:t._scissorRectangle},blending:Pn.ALPHA_BLEND})),c(t._compositeCommand)&&(t._compositeCommand.renderState=t._rsComp,t._compositeCommand.derivedCommands.pick.renderState=t._rsComp)}WU.prototype.executeTranslucentCommands=function(t,e,n,i,o){let a=i.length,s,l,r=t.frameState.useLogDepth,d=t.context,m=n.framebuffer;for(l=0;l<a;++l)if(s=i[l],s=r?s.derivedCommands.logDepth.command:s,s.depthForTranslucentClassification){this._hasTranslucentDepth=!0;break}if(this._hasTranslucentDepth){for(jBe(this,d,n,o),n.framebuffer=this._drawClassificationFBO.framebuffer,this._clearDepthStencilCommand.execute(d,n),l=0;l<a;++l){if(s=i[l],s=r?s.derivedCommands.logDepth.command:s,!s.depthForTranslucentClassification)continue;let h=s.derivedCommands.depth.depthOnlyCommand;e(h,t,d,n)}this._frustumsDrawn+=this._hasTranslucentDepth?1:0,this._hasTranslucentDepth&&(n.framebuffer=this._packFBO.framebuffer,this._packDepthCommand.execute(d,n)),n.framebuffer=m}};WU.prototype.executeClassificationCommands=function(t,e,n,i){if(!this._hasTranslucentDepth)return;let o=t.context,a=o.uniformState,s=n.framebuffer;this._frustumsDrawn===2&&(n.framebuffer=this._accumulationFBO.framebuffer,this._copyCommand.execute(o,n)),n.framebuffer=this._drawClassificationFBO.framebuffer,this._frustumsDrawn>1&&this._clearColorCommand.execute(o,n),a.updatePass(Pt.CESIUM_3D_TILE_CLASSIFICATION);let l=a.globeDepthTexture;a.globeDepthTexture=this._packFBO.getColorTexture();let r=i.commands[Pt.CESIUM_3D_TILE_CLASSIFICATION],d=i.indices[Pt.CESIUM_3D_TILE_CLASSIFICATION];for(let m=0;m<d;++m)e(r[m],t,o,n);a.globeDepthTexture=l,n.framebuffer=s,this._frustumsDrawn!==1&&(n.framebuffer=this._accumulationFBO.framebuffer,this._accumulateCommand.execute(o,n),n.framebuffer=s)};WU.prototype.execute=function(t,e){if(!this._hasTranslucentDepth)return;this._frustumsDrawn===1?this._textureToComposite=this._drawClassificationFBO.getColorTexture():this._textureToComposite=this._accumulationFBO.getColorTexture(),(t.frameState.passes.pick?this._compositeCommand.derivedCommands.pick:this._compositeCommand).execute(t.context,e),qBe(this,t,e)};function qBe(t,e,n){if(!t._hasTranslucentDepth)return;let i=n.framebuffer;n.framebuffer=t._drawClassificationFBO.framebuffer,t._clearColorCommand.execute(e._context,n),n.framebuffer=i,t._frustumsDrawn>1&&(n.framebuffer=t._accumulationFBO.framebuffer,t._clearColorCommand.execute(e._context,n)),t._hasTranslucentDepth=!1,t._frustumsDrawn=0}WU.prototype.isSupported=function(){return this._supported};WU.prototype.isDestroyed=function(){return!1};WU.prototype.destroy=function(){return Oyt(this),Hyt(this),c(this._compositeCommand)&&(this._compositeCommand.shaderProgram=this._compositeCommand.shaderProgram&&this._compositeCommand.shaderProgram.destroy()),c(this._packDepthCommand)&&(this._packDepthCommand.shaderProgram=this._packDepthCommand.shaderProgram&&this._packDepthCommand.shaderProgram.destroy()),At(this)};var q_=WU;function $Be(){this.command=void 0,this.near=void 0,this.far=void 0}function lj(t,e,n){let i=t.context,o;i.depthTexture&&(o=new D_);let a;t._useOIT&&i.depthTexture&&(a=new w_(i));let s=new Md(i);s.viewport=Fe.clone(n),this.camera=e,this._cameraClone=Aa.clone(e),this._cameraStartFired=!1,this._cameraMovedTime=void 0,this.viewport=n,this.passState=s,this.pickFramebuffer=new z_(i),this.pickDepthFramebuffer=new v_,this.sceneFramebuffer=new FT,this.globeDepth=o,this.globeTranslucencyFramebuffer=new O_,this.oit=a,this.translucentTileClassification=new q_(i),this.pickDepths=[],this.frustumCommandsList=[],this.debugFrustumStatistics=void 0,this._commandExtents=[]}var wyt=new p,Pyt=new p;function tQe(t,e){let n=Math.max(Math.abs(t.x),Math.abs(e.x)),i=Math.max(Math.abs(t.y),Math.abs(e.y)),o=Math.max(Math.abs(t.z),Math.abs(e.z));return Math.max(Math.max(n,i),o)}function eQe(t,e,n){let i=1/Math.max(1,tQe(t.position,e.position));return p.multiplyByScalar(t.position,i,wyt),p.multiplyByScalar(e.position,i,Pyt),p.equalsEpsilon(wyt,Pyt,n)&&p.equalsEpsilon(t.direction,e.direction,n)&&p.equalsEpsilon(t.up,e.up,n)&&p.equalsEpsilon(t.right,e.right,n)&&L.equalsEpsilon(t.transform,e.transform,n)&&t.frustum.equalsEpsilon(e.frustum,n)}lj.prototype.checkForCameraUpdates=function(t){let e=this.camera,n=this._cameraClone;return eQe(e,n,k.EPSILON15)?(this._cameraStartFired&&Oi()-this._cameraMovedTime>t.cameraEventWaitTime&&(e.moveEnd.raiseEvent(),this._cameraStartFired=!1),!1):(this._cameraStartFired||(e.moveStart.raiseEvent(),this._cameraStartFired=!0),this._cameraMovedTime=Oi(),Aa.clone(e,n),!0)};function nQe(t,e,n,i){let o=e.frameState,a=o.camera,s=o.useLogDepth?e.logarithmicDepthFarToNearRatio:e.farToNearRatio,l=e.mode===Vt.SCENE2D,r=e.nearToFarDistance2D;i*=1+k.EPSILON2,n=Math.min(Math.max(n,a.frustum.near),a.frustum.far),i=Math.max(Math.min(i,a.frustum.far),n);let d;l?(i=Math.min(i,a.position.z+e.nearToFarDistance2D),n=Math.min(n,i),d=Math.ceil(Math.max(1,i-n)/e.nearToFarDistance2D)):d=Math.ceil(Math.log(i/n)/Math.log(s));let m=t.frustumCommandsList;d||(d=0),m.length=d;for(let h=0;h<d;++h){let u,R;l?(u=Math.min(i-r,n+h*r),R=Math.min(i,u+r)):(u=Math.max(n,Math.pow(s,h)*n),R=Math.min(i,s*u));let V=m[h];c(V)?(V.near=u,V.far=R):V=m[h]=new __(u,R)}}function iQe(t,e,n,i,o){e.debugShowFrustums&&(n.debugOverlappingFrustums=0);let a=t.frustumCommandsList,s=a.length;for(let l=0;l<s;++l){let r=a[l],d=r.near,m=r.far;if(i>m)continue;if(o<d)break;let h=n.pass,u=r.indices[h]++;if(r.commands[h][u]=n,e.debugShowFrustums&&(n.debugOverlappingFrustums|=1<<l),n.executeInClosestFrustum)break}if(e.debugShowFrustums){let l=t.debugFrustumStatistics.commandsInFrustums;l[n.debugOverlappingFrustums]=c(l[n.debugOverlappingFrustums])?l[n.debugOverlappingFrustums]+1:1,++t.debugFrustumStatistics.totalCommands}e.updateDerivedCommands(n)}var vyt=new Jl,oQe=new hd;lj.prototype.createPotentiallyVisibleSet=function(t){let e=t.frameState,n=e.camera,i=n.directionWC,o=n.positionWC,a=t._computeCommandList,s=t._overlayCommandList,l=e.commandList;t.debugShowFrustums&&(this.debugFrustumStatistics={totalCommands:0,commandsInFrustums:{}});let r=this.frustumCommandsList,d=r.length,m=Pt.NUMBER_OF_PASSES;for(let E=0;E<d;++E)for(let I=0;I<m;++I)r[E].indices[I]=0;a.length=0,s.length=0;let h=this._commandExtents,u=h.length,R=0,V=+Number.MAX_VALUE,F=-Number.MAX_VALUE,U=e.shadowState.shadowsEnabled,G=+Number.MAX_VALUE,A=-Number.MAX_VALUE,S=Number.MAX_VALUE,g=e.mode===Vt.SCENE3D?e.occluder:void 0,C=e.cullingVolume,y=vyt.planes;for(let E=0;E<5;++E)y[E]=C.planes[E];C=vyt;let Y=l.length;for(let E=0;E<Y;++E){let I=l[E],B=I.pass;if(B===Pt.COMPUTE)a.push(I);else if(B===Pt.OVERLAY)s.push(I);else{let X,_,P=I.boundingVolume;if(c(P)){if(!t.isVisible(I,C,g))continue;let z=P.computePlaneDistances(o,i,oQe);if(X=z.start,_=z.stop,V=Math.min(V,X),F=Math.max(F,_),U&&I.receiveShadows&&X<fW.MAXIMUM_DISTANCE&&!(B===Pt.GLOBE&&X<-100&&_>100)){let H=_-X;B!==Pt.GLOBE&&X<100&&(S=Math.min(S,H)),G=Math.min(G,X),A=Math.max(A,_)}}else I instanceof ao?(X=n.frustum.near,_=n.frustum.far):(X=n.frustum.near,_=n.frustum.far,V=Math.min(V,X),F=Math.max(F,_));let w=h[R];c(w)||(w=h[R]=new $Be),w.command=I,w.near=X,w.far=_,R++}}U&&(G=Math.min(Math.max(G,n.frustum.near),n.frustum.far),A=Math.max(Math.min(A,n.frustum.far),G)),U&&(e.shadowState.nearPlane=G,e.shadowState.farPlane=A,e.shadowState.closestObjectSize=S),nQe(this,t,V,F);let Q,J;for(Q=0;Q<R;Q++)J=h[Q],iQe(this,t,J.command,J.near,J.far);if(R<u)for(Q=R;Q<u&&(J=h[Q],!!c(J.command));Q++)J.command=void 0;let M=r.length,Z=e.frustumSplits;Z.length=M+1;for(let E=0;E<M;++E)Z[E]=r[E].near,E===M-1&&(Z[E+1]=r[E].far)};lj.prototype.destroy=function(){this.pickFramebuffer=this.pickFramebuffer&&this.pickFramebuffer.destroy(),this.pickDepthFramebuffer=this.pickDepthFramebuffer&&this.pickDepthFramebuffer.destroy(),this.sceneFramebuffer=this.sceneFramebuffer&&this.sceneFramebuffer.destroy(),this.globeDepth=this.globeDepth&&this.globeDepth.destroy(),this.oit=this.oit&&this.oit.destroy(),this.translucentTileClassification=this.translucentTileClassification&&this.translucentTileClassification.destroy(),this.globeTranslucencyFramebuffer=this.globeTranslucencyFramebuffer&&this.globeTranslucencyFramebuffer.destroy();let t,e=this.pickDepths,n=e.length;for(t=0;t<n;++t)e[t].destroy()};var AT=lj;var zyt=.1,aQe=new EV({pass:ns.MOST_DETAILED_PRELOAD}),sQe=new EV({pass:ns.MOST_DETAILED_PICK}),dj=new EV({pass:ns.PICK});function nd(t){this._mostDetailedRayPicks=[],this.pickRenderStateCache={},this._pickPositionCache={},this._pickPositionCacheDirty=!1;let e=new Fe(0,0,1,1),n=new Aa(t);n.frustum=new wn({width:zyt,aspectRatio:1,near:.1}),this._pickOffscreenView=new AT(t,n,e)}nd.prototype.update=function(){this._pickPositionCacheDirty=!0};nd.prototype.getPickDepth=function(t,e){let n=t.view.pickDepths,i=n[e];return c(i)||(i=new M_,n[e]=i),i};var lQe=new el,rQe=new p,rj=new p,dQe=new K,cQe=new L;function mQe(t,e,n,i,o){let a=t.camera,s=a.frustum,l=s.offCenterFrustum;c(l)&&(s=l);let r=2*(e.x-o.x)/o.width-1;r*=(s.right-s.left)*.5;let d=2*(o.height-e.y-o.y)/o.height-1;d*=(s.top-s.bottom)*.5;let m=L.clone(a.transform,cQe);a._setTransform(L.IDENTITY);let h=p.clone(a.position,rQe);p.multiplyByScalar(a.right,r,rj),p.add(rj,h,h),p.multiplyByScalar(a.up,d,rj),p.add(rj,h,h),a._setTransform(m),t.mode===Vt.SCENE2D&&p.fromElements(h.z,h.x,h.y,h);let u=s.getPixelDimensions(o.width,o.height,1,1,dQe),R=lQe;return R.right=u.x*.5,R.left=-R.right,R.top=u.y*.5,R.bottom=-R.top,R.near=s.near,R.far=s.far,R.computeCullingVolume(h,a.directionWC,a.upWC)}var hQe=new em,pQe=new K;function VQe(t,e,n,i,o){let a=t.camera,s=a.frustum,l=s.near,r=Math.tan(s.fovy*.5),d=s.aspectRatio*r,m=2*(e.x-o.x)/o.width-1,h=2*(o.height-e.y-o.y)/o.height-1,u=m*l*d,R=h*l*r,V=s.getPixelDimensions(o.width,o.height,1,1,pQe),F=V.x*n*.5,U=V.y*i*.5,G=hQe;return G.top=R+U,G.bottom=R-U,G.right=u+F,G.left=u-F,G.near=l,G.far=s.far,G.computeCullingVolume(a.positionWC,a.directionWC,a.upWC)}function Cat(t,e,n,i,o){let a=t.camera.frustum;return a instanceof wn||a instanceof el?mQe(t,e,n,i,o):VQe(t,e,n,i,o)}var dZ=3,FW=3,hc=new Fe(0,0,dZ,FW),Iat=new K,cj=new v(0,0,0,0);nd.prototype.pick=function(t,e,n,i){dZ=f(n,3),FW=f(i,dZ);let{context:o,frameState:a,defaultView:s}=t,{viewport:l,pickFramebuffer:r}=s;t.view=s,l.x=0,l.y=0,l.width=o.drawingBufferWidth,l.height=o.drawingBufferHeight;let d=s.passState;d.viewport=Fe.clone(l,d.viewport);let m=qo.transformWindowToDrawingBuffer(t,e,Iat);t.jobScheduler.disableThisFrame(),t.updateFrameState(),a.cullingVolume=Cat(t,m,dZ,FW,l),a.invertClassification=!1,a.passes.pick=!0,a.tilesetPassState=dj,o.uniformState.update(a),t.updateEnvironment(),hc.x=m.x-(dZ-1)*.5,hc.y=t.drawingBufferHeight-m.y-(FW-1)*.5,hc.width=dZ,hc.height=FW,d=r.begin(hc,l),t.updateAndExecuteCommands(d,cj),t.resolveFramebuffers(d);let h=r.end(hc);return o.endFrame(),h};nd.prototype.pickVoxelCoordinate=function(t,e,n,i){dZ=f(n,3),FW=f(i,dZ);let{context:o,frameState:a,defaultView:s}=t,{viewport:l,pickFramebuffer:r}=s;t.view=s,l.x=0,l.y=0,l.width=o.drawingBufferWidth,l.height=o.drawingBufferHeight;let d=s.passState;d.viewport=Fe.clone(l,d.viewport);let m=qo.transformWindowToDrawingBuffer(t,e,Iat);t.jobScheduler.disableThisFrame(),t.updateFrameState(),a.cullingVolume=Cat(t,m,dZ,FW,l),a.invertClassification=!1,a.passes.pickVoxel=!0,a.tilesetPassState=dj,o.uniformState.update(a),t.updateEnvironment(),hc.x=m.x-(dZ-1)*.5,hc.y=t.drawingBufferHeight-m.y-(FW-1)*.5,hc.width=dZ,hc.height=FW,d=r.begin(hc,l),t.updateAndExecuteCommands(d,cj),t.resolveFramebuffers(d);let h=r.readVoxelInfo(hc);return o.endFrame(),h};function uQe(t,e){let{defaultView:n,context:i,frameState:o,environmentState:a}=t,{viewport:s,pickDepthFramebuffer:l}=n;t.view=n,s.x=0,s.y=0,s.width=i.drawingBufferWidth,s.height=i.drawingBufferHeight;let r=n.passState;r.viewport=Fe.clone(s,r.viewport),t.clearPasses(o.passes),o.passes.pick=!0,o.passes.depth=!0,o.cullingVolume=Cat(t,e,1,1,s),o.tilesetPassState=dj,t.updateEnvironment(),a.renderTranslucentDepthForPick=!0,r=l.update(i,e,s),t.updateAndExecuteCommands(r,cj),t.resolveFramebuffers(r),i.endFrame()}var ZQe=new Io,RQe=new em,bQe=new wn,WQe=new el;nd.prototype.pickPositionWorldCoordinates=function(t,e,n){if(!t.useDepthPicking)return;let i=e.toString();if(this._pickPositionCacheDirty)this._pickPositionCache={},this._pickPositionCacheDirty=!1;else if(this._pickPositionCache.hasOwnProperty(i))return p.clone(this._pickPositionCache[i],n);let{context:o,frameState:a,camera:s,defaultView:l}=t,{uniformState:r}=o;t.view=l;let d=qo.transformWindowToDrawingBuffer(t,e,Iat);t.pickTranslucentDepth?uQe(t,d):(t.updateFrameState(),r.update(a),t.updateEnvironment()),d.y=t.drawingBufferHeight-d.y;let m;c(s.frustum.fov)?m=s.frustum.clone(ZQe):c(s.frustum.infiniteProjectionMatrix)?m=s.frustum.clone(RQe):c(s.frustum.width)?m=s.frustum.clone(bQe):m=s.frustum.clone(WQe);let h=l.frustumCommandsList,u=h.length;for(let R=0;R<u;++R){let F=this.getPickDepth(t,R).getDepth(o,d.x,d.y);if(c(F)&&F>0&&F<1){let U=h[R],G;return t.mode===Vt.SCENE2D?(G=s.position.z,s.position.z=G-U.near+1,m.far=Math.max(1,U.far-U.near),m.near=1,r.update(a),r.updateFrustum(m)):(m.near=U.near*(R!==0?t.opaqueFrustumNearOffset:1),m.far=U.far,r.updateFrustum(m)),n=qo.drawingBufferToWgs84Coordinates(t,d,F,n),t.mode===Vt.SCENE2D&&(s.position.z=G,r.update(a)),this._pickPositionCache[i]=p.clone(n),n}}this._pickPositionCache[i]=void 0};var fQe=new gt;nd.prototype.pickPosition=function(t,e,n){if(n=this.pickPositionWorldCoordinates(t,e,n),c(n)&&t.mode!==Vt.SCENE3D){p.fromElements(n.y,n.z,n.x,n);let i=t.mapProjection,o=i.ellipsoid,a=i.unproject(n,fQe);o.cartographicToCartesian(a,n)}return n};function jyt(t,e){let n,i,o=[],a=[],s=[],l=[];c(t)||(t=Number.MAX_VALUE);let r=e();for(;c(r);){let d=r.object,m=r.position,h=r.exclude;if(c(m)&&!c(d)){o.push(r);break}if(!c(d)||!c(d.primitive)||!h&&(o.push(r),0>=--t))break;let u=d.primitive,R=!1;typeof u.getGeometryInstanceAttributes=="function"&&c(d.id)&&(i=u.getGeometryInstanceAttributes(d.id),c(i)&&c(i.show)&&(R=!0,i.show=pi.toValue(!1,i.show),s.push(i))),d instanceof Fr&&(R=!0,d.show=!1,l.push(d)),R||(u.show=!1,a.push(u)),r=e()}for(n=0;n<a.length;++n)a[n].show=!0;for(n=0;n<s.length;++n)i=s[n],i.show=pi.toValue(!0,i.show);for(n=0;n<l.length;++n)l[n].show=!0;return o}nd.prototype.drillPick=function(t,e,n,i,o){let a=this;return jyt(n,function(){let r=a.pick(t,e,i,o);if(c(r))return{object:r,position:void 0,exclude:!1}}).map(function(r){return r.object})};var Kyt=new p,FQe=new p;function UQe(t,e,n){this.ray=t,this.width=e,this.tilesets=n,this.ready=!1;let i=this;this.promise=new Promise(o=>{i._completePick=()=>{o()}})}function qyt(t,e,n,i){let o=e.direction,a=p.mostOrthogonalAxis(o,Kyt),s=p.cross(o,a,Kyt),l=p.cross(o,s,FQe);return i.position=e.origin,i.direction=o,i.up=l,i.right=s,i.frustum.width=f(n,zyt),i.frustum.computeCullingVolume(i.positionWC,i.directionWC,i.upWC)}function GQe(t,e,n){let i=e.frameState,{ray:o,width:a,tilesets:s}=n,l=t._pickOffscreenView.camera,r=qyt(t,o,a,l),d=aQe;d.camera=l,d.cullingVolume=r;let m=!0,h=s.length;for(let u=0;u<h;++u){let R=s[u];R.show&&e.primitives.contains(R)&&(R.updateForPass(i,d),m=m&&d.ready)}return m&&n._completePick(),m}nd.prototype.updateMostDetailedRayPicks=function(t){let e=this._mostDetailedRayPicks;for(let n=0;n<e.length;++n)GQe(this,t,e[n])&&e.splice(n--,1)};function $yt(t,e,n){for(let i=0;i<t.length;++i){let o=t.get(i);o.show&&(c(o.isCesium3DTileset)?(!c(e)||e.indexOf(o)===-1)&&n.push(o):o instanceof Dm&&$yt(o,e,n))}}function mj(t,e,n,i,o,a){let s=[];if($yt(e.primitives,i,s),s.length===0)return Promise.resolve(a());let l=new UQe(n,o,s);return t._mostDetailedRayPicks.push(l),l.promise.then(function(){return a()})}function AQe(t,e){return!c(t)||!c(e)||e.length===0?!1:e.indexOf(t)>-1||e.indexOf(t.primitive)>-1||e.indexOf(t.id)>-1}function SQe(t,e,n,i,o,a,s){let{context:l,frameState:r}=e,d=l.uniformState,m=t._pickOffscreenView;e.view=m,qyt(t,n,o,m.camera),hc=Fe.clone(m.viewport,hc);let h=m.pickFramebuffer.begin(hc,m.viewport);e.jobScheduler.disableThisFrame(),e.updateFrameState(),r.invertClassification=!1,r.passes.pick=!0,r.passes.offscreen=!0,s?r.tilesetPassState=sQe:r.tilesetPassState=dj,d.update(r),e.updateEnvironment(),e.updateAndExecuteCommands(h,cj),e.resolveFramebuffers(h);let u,R=m.pickFramebuffer.end(hc);if(e.context.depthTexture){let V=m.frustumCommandsList.length;for(let F=0;F<V;++F){let G=t.getPickDepth(e,F).getDepth(l,0,0);if(c(G)&&G>0&&G<1){let A=m.frustumCommandsList[F],S=A.near*(F!==0?e.opaqueFrustumNearOffset:1),g=A.far,C=S+G*(g-S);u=di.getPoint(n,C);break}}}if(e.view=e.defaultView,l.endFrame(),c(R)||c(u))return{object:R,position:u,exclude:!c(u)&&a||AQe(R,i)}}function tBt(t,e,n,i,o,a,s,l){return jyt(i,function(){return SQe(t,e,n,o,a,s,l)})}function O1(t,e,n,i,o,a,s){let l=tBt(t,e,n,1,i,o,a,s);if(l.length>0)return l[0]}function eBt(t,e,n,i,o,a,s,l){return tBt(t,e,n,i,o,a,s,l)}function hj(t,e){return new Promise((n,i)=>{e.then(function(o){let a=t.postRender.addEventListener(function(){a(),n(o)});t.requestRender()}).catch(function(o){i(o)})})}nd.prototype.pickFromRay=function(t,e,n,i){return O1(this,t,e,n,i,!1,!1)};nd.prototype.drillPickFromRay=function(t,e,n,i,o){return eBt(this,t,e,n,i,o,!1,!1)};nd.prototype.pickFromRayMostDetailed=function(t,e,n,i){let o=this;return e=di.clone(e),n=c(n)?n.slice():n,hj(t,mj(o,t,e,n,i,function(){return O1(o,t,e,n,i,!1,!0)}))};nd.prototype.drillPickFromRayMostDetailed=function(t,e,n,i,o){let a=this;return e=di.clone(e),i=c(i)?i.slice():i,hj(t,mj(a,t,e,i,o,function(){return eBt(a,t,e,n,i,o,!1,!0)}))};var TQe=new p,gQe=new p,EQe=new di,nBt=new gt;function Nat(t,e){let n=t.globe,i=c(n)?n.ellipsoid:t.mapProjection.ellipsoid,o=Vo._defaultMaxTerrainHeight,a=i.geodeticSurfaceNormalCartographic(e,gQe),s=gt.toCartesian(e,i,TQe),l=EQe;l.origin=s,l.direction=a;let r=new di;return di.getPoint(l,o,r.origin),p.negate(a,r.direction),r}function iBt(t,e){let n=t.globe,i=c(n)?n.ellipsoid:t.mapProjection.ellipsoid,o=gt.fromCartesian(e,i,nBt);return Nat(t,o)}function oBt(t,e){let n=t.globe,i=c(n)?n.ellipsoid:t.mapProjection.ellipsoid;return gt.fromCartesian(e,i,nBt).height}function CQe(t,e,n,i,o){let a=Nat(e,n);return mj(t,e,a,i,o,function(){let s=O1(t,e,a,i,o,!0,!0);if(c(s))return oBt(e,s.position)})}function IQe(t,e,n,i,o,a){let s=iBt(e,n);return mj(t,e,s,i,o,function(){let l=O1(t,e,s,i,o,!0,!0);if(c(l))return p.clone(l.position,a)})}nd.prototype.sampleHeight=function(t,e,n,i){let o=Nat(t,e),a=O1(this,t,o,n,i,!0,!1);if(c(a))return oBt(t,a.position)};nd.prototype.clampToHeight=function(t,e,n,i,o){let a=iBt(t,e),s=O1(this,t,a,n,i,!0,!1);if(c(s))return p.clone(s.position,o)};nd.prototype.sampleHeightMostDetailed=function(t,e,n,i){n=c(n)?n.slice():n;let o=e.length,a=new Array(o);for(let s=0;s<o;++s)a[s]=CQe(this,t,e[s],n,i);return hj(t,Promise.all(a).then(function(s){let l=s.length;for(let r=0;r<l;++r)e[r].height=s[r];return e}))};nd.prototype.clampToHeightMostDetailed=function(t,e,n,i){n=c(n)?n.slice():n;let o=e.length,a=new Array(o);for(let s=0;s<o;++s)a[s]=IQe(this,t,e[s],n,i,e[s]);return hj(t,Promise.all(a).then(function(s){let l=s.length;for(let r=0;r<l;++r)e[r]=s[r];return e}))};nd.prototype.destroy=function(){this._pickOffscreenView=this._pickOffscreenView&&this._pickOffscreenView.destroy()};var $_=nd;var yQo=b(W(),1);var lQo=b(W(),1);var myo=b(W(),1),t9=`uniform sampler2D colorTexture; in vec2 v_textureCoordinates; @@ -11226,7 +11226,7 @@ void main() out_FragColor = vec4(color, fragmentColor.a); } -`;var pyo=R(W(),1),e9=`uniform sampler2D randomTexture; +`;var pyo=b(W(),1),e9=`uniform sampler2D randomTexture; uniform sampler2D depthTexture; uniform float intensity; uniform float bias; @@ -11341,7 +11341,7 @@ void main(void) ao = pow(ao, intensity); out_FragColor = vec4(vec3(ao), 1.0); } -`;var Zyo=R(W(),1),n9=`uniform sampler2D colorTexture; +`;var uyo=b(W(),1),n9=`uniform sampler2D colorTexture; uniform sampler2D ambientOcclusionTexture; uniform bool ambientOcclusionOnly; in vec2 v_textureCoordinates; @@ -11352,7 +11352,7 @@ void main(void) vec4 ao = texture(ambientOcclusionTexture, v_textureCoordinates); out_FragColor = ambientOcclusionOnly ? ao : ao * color; } -`;var byo=R(W(),1),i9=`uniform sampler2D colorTexture; +`;var Ryo=b(W(),1),i9=`uniform sampler2D colorTexture; uniform float gradations; in vec2 v_textureCoordinates; @@ -11371,7 +11371,7 @@ void main(void) darkness = (darkness - fract(darkness)) / gradations; out_FragColor = vec4(vec3(darkness), 1.0); } -`;var Wyo=R(W(),1),o9=`uniform sampler2D colorTexture; +`;var Wyo=b(W(),1),o9=`uniform sampler2D colorTexture; uniform sampler2D bloomTexture; uniform bool glowOnly; @@ -11391,7 +11391,7 @@ void main(void) vec4 bloom = texture(bloomTexture, v_textureCoordinates); out_FragColor = glowOnly ? bloom : bloom + color; } -`;var Fyo=R(W(),1),a9=`uniform sampler2D colorTexture; +`;var Fyo=b(W(),1),a9=`uniform sampler2D colorTexture; uniform float brightness; in vec2 v_textureCoordinates; @@ -11402,7 +11402,7 @@ void main(void) vec3 target = vec3(0.0); out_FragColor = vec4(mix(target, rgb, brightness), 1.0); } -`;var Gyo=R(W(),1),s9=`uniform sampler2D colorTexture; +`;var Gyo=b(W(),1),s9=`uniform sampler2D colorTexture; uniform float contrast; uniform float brightness; @@ -11419,7 +11419,7 @@ void main(void) sceneColor = factor * (sceneColor - vec3(0.5)) + vec3(0.5); out_FragColor = vec4(sceneColor, 1.0); } -`;var Tyo=R(W(),1),l9=`uniform sampler2D colorTexture; +`;var Syo=b(W(),1),l9=`uniform sampler2D colorTexture; uniform sampler2D blurTexture; uniform sampler2D depthTexture; uniform float focalDistance; @@ -11458,7 +11458,7 @@ void main(void) float d = computeDepthBlur(-posInCamera.z); out_FragColor = mix(texture(colorTexture, v_textureCoordinates), texture(blurTexture, v_textureCoordinates), d); } -`;var gyo=R(W(),1),r9=`uniform sampler2D depthTexture; +`;var gyo=b(W(),1),r9=`uniform sampler2D depthTexture; in vec2 v_textureCoordinates; @@ -11467,7 +11467,7 @@ void main(void) float depth = czm_readDepth(depthTexture, v_textureCoordinates); out_FragColor = vec4(vec3(depth), 1.0); } -`;var Cyo=R(W(),1),d9=`uniform sampler2D depthTexture; +`;var Cyo=b(W(),1),d9=`uniform sampler2D depthTexture; uniform float length; uniform vec4 color; @@ -11527,7 +11527,7 @@ void main(void) float len = sqrt(horizEdge * horizEdge + vertEdge * vertEdge); out_FragColor = vec4(color.rgb, len > length ? color.a : 0.0); } -`;var Nyo=R(W(),1),c9=`uniform sampler2D colorTexture; +`;var Nyo=b(W(),1),c9=`uniform sampler2D colorTexture; in vec2 v_textureCoordinates; @@ -11563,7 +11563,7 @@ void main() c = czm_inverseGamma(c / w); out_FragColor = vec4(c, fragmentColor.a); } -`;var Byo=R(W(),1),m9=`in vec2 v_textureCoordinates; +`;var Byo=b(W(),1),m9=`in vec2 v_textureCoordinates; uniform sampler2D colorTexture; @@ -11584,7 +11584,7 @@ void main() float alpha = texture(colorTexture, v_textureCoordinates).a; out_FragColor = vec4(color.rgb, alpha); } -`;var kyo=R(W(),1),fU=`#define SAMPLES 8 +`;var kyo=b(W(),1),fU=`#define SAMPLES 8 uniform float delta; uniform float sigma; @@ -11631,7 +11631,7 @@ void main() out_FragColor = result; } -`;var xyo=R(W(),1),h9=`uniform sampler2D colorTexture; +`;var xyo=b(W(),1),h9=`uniform sampler2D colorTexture; uniform sampler2D dirtTexture; uniform sampler2D starTexture; uniform vec2 dirtTextureDimensions; @@ -11784,7 +11784,7 @@ void main(void) out_FragColor = result; } -`;var Jyo=R(W(),1),p9=`uniform sampler2D colorTexture; +`;var Jyo=b(W(),1),p9=`uniform sampler2D colorTexture; uniform vec3 white; in vec2 v_textureCoordinates; @@ -11808,7 +11808,7 @@ void main() color = czm_inverseGamma(color); out_FragColor = vec4(color, fragmentColor.a); } -`;var Myo=R(W(),1),u9=`uniform sampler2D colorTexture; +`;var Myo=b(W(),1),V9=`uniform sampler2D colorTexture; in vec2 v_textureCoordinates; @@ -11824,7 +11824,7 @@ void main(void) vec3 green = vec3(0.0, 1.0, 0.0); out_FragColor = vec4((noiseValue + rgb) * green, 1.0); } -`;var Dyo=R(W(),1),Z9=`uniform sampler2D colorTexture; +`;var Dyo=b(W(),1),u9=`uniform sampler2D colorTexture; in vec2 v_textureCoordinates; @@ -11847,7 +11847,7 @@ void main() color = czm_inverseGamma(color); out_FragColor = vec4(color, fragmentColor.a); } -`;var Hyo=R(W(),1),V9=`uniform sampler2D colorTexture; +`;var Hyo=b(W(),1),Z9=`uniform sampler2D colorTexture; uniform sampler2D silhouetteTexture; in vec2 v_textureCoordinates; @@ -11858,7 +11858,7 @@ void main(void) vec4 color = texture(colorTexture, v_textureCoordinates); out_FragColor = mix(color, silhouetteColor, silhouetteColor.a); } -`;var Pyo=R(W(),1);/** +`;var Pyo=b(W(),1);/** * @license * Copyright (c) 2014-2015, NVIDIA CORPORATION. All rights reserved. * @@ -11885,7 +11885,7 @@ void main(void) * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */var b9=`/** + */var R9=`/** * @license * Copyright (c) 2014-2015, NVIDIA CORPORATION. All rights reserved. * @@ -12533,7 +12533,7 @@ FxaaFloat4 FxaaPixelShader( if( horzSpan) posM.y += pixelOffsetSubpix * lengthSign; return FxaaFloat4(FxaaTexTop(tex, posM).xyz, lumaM); } -`;var nBo=R(W(),1);function TS(){this._uniformMap=void 0,this._command=void 0,this._colorTexture=void 0,this._depthTexture=void 0,this._ready=!1,this._name="czm_autoexposure",this._logDepthChanged=void 0,this._useLogDepth=void 0,this._framebuffers=void 0,this._previousLuminance=new Ro,this._commands=void 0,this._clearCommand=void 0,this._minMaxLuminance=new K,this.enabled=!0,this._enabled=!0,this.minimumLuminance=.1,this.maximumLuminance=10}Object.defineProperties(TS.prototype,{ready:{get:function(){return this._ready}},name:{get:function(){return this._name}},outputTexture:{get:function(){let t=this._framebuffers;if(c(t))return t[t.length-1].getColorTexture(0)}}});function aBt(t){let e=t._framebuffers;if(!c(e))return;let n=e.length;for(let i=0;i<n;++i)e[i].destroy();t._framebuffers=void 0,t._previousLuminance.destroy(),t._previousLuminance=void 0}function NQe(t,e){aBt(t);let n=t._width,i=t._height,o=e.halfFloatingPointTexture?Ue.HALF_FLOAT:Ue.FLOAT,a=Math.ceil(Math.log(Math.max(n,i))/Math.log(3)),s=new Array(a);for(let r=0;r<a;++r)n=Math.max(Math.ceil(n/3),1),i=Math.max(Math.ceil(i/3),1),s[r]=new Ro,s[r].update(e,n,i,1,o);let l=s[a-1].getColorTexture(0);t._previousLuminance.update(e,l.width,l.height,1,o),t._framebuffers=s}function sBt(t){let e=t._commands;if(!c(e))return;let n=e.length;for(let i=0;i<n;++i)e[i].shaderProgram.destroy();t._commands=void 0}function yQe(t,e){let n;if(e===0)n={colorTexture:function(){return t._colorTexture},colorTextureDimensions:function(){return t._colorTexture.dimensions}};else{let i=t._framebuffers[e-1].getColorTexture(0);n={colorTexture:function(){return i},colorTextureDimensions:function(){return i.dimensions}}}return n.minMaxLuminance=function(){return t._minMaxLuminance},n.previousLuminance=function(){return t._previousLuminance.getColorTexture(0)},n}function BQe(t,e){let n=`uniform sampler2D colorTexture; +`;var nBo=b(W(),1);function ST(){this._uniformMap=void 0,this._command=void 0,this._colorTexture=void 0,this._depthTexture=void 0,this._ready=!1,this._name="czm_autoexposure",this._logDepthChanged=void 0,this._useLogDepth=void 0,this._framebuffers=void 0,this._previousLuminance=new bo,this._commands=void 0,this._clearCommand=void 0,this._minMaxLuminance=new K,this.enabled=!0,this._enabled=!0,this.minimumLuminance=.1,this.maximumLuminance=10}Object.defineProperties(ST.prototype,{ready:{get:function(){return this._ready}},name:{get:function(){return this._name}},outputTexture:{get:function(){let t=this._framebuffers;if(c(t))return t[t.length-1].getColorTexture(0)}}});function aBt(t){let e=t._framebuffers;if(!c(e))return;let n=e.length;for(let i=0;i<n;++i)e[i].destroy();t._framebuffers=void 0,t._previousLuminance.destroy(),t._previousLuminance=void 0}function NQe(t,e){aBt(t);let n=t._width,i=t._height,o=e.halfFloatingPointTexture?Ue.HALF_FLOAT:Ue.FLOAT,a=Math.ceil(Math.log(Math.max(n,i))/Math.log(3)),s=new Array(a);for(let r=0;r<a;++r)n=Math.max(Math.ceil(n/3),1),i=Math.max(Math.ceil(i/3),1),s[r]=new bo,s[r].update(e,n,i,1,o);let l=s[a-1].getColorTexture(0);t._previousLuminance.update(e,l.width,l.height,1,o),t._framebuffers=s}function sBt(t){let e=t._commands;if(!c(e))return;let n=e.length;for(let i=0;i<n;++i)e[i].shaderProgram.destroy();t._commands=void 0}function yQe(t,e){let n;if(e===0)n={colorTexture:function(){return t._colorTexture},colorTextureDimensions:function(){return t._colorTexture.dimensions}};else{let i=t._framebuffers[e-1].getColorTexture(0);n={colorTexture:function(){return i},colorTextureDimensions:function(){return i.dimensions}}}return n.minMaxLuminance=function(){return t._minMaxLuminance},n.previousLuminance=function(){return t._previousLuminance.getColorTexture(0)},n}function BQe(t,e){let n=`uniform sampler2D colorTexture; in vec2 v_textureCoordinates; float sampleTexture(vec2 offset) { `;return t===0?n+=` vec4 color = texture(colorTexture, v_textureCoordinates + offset); @@ -12570,7 +12570,7 @@ void main() { color = clamp(color, minMaxLuminance.x, minMaxLuminance.y); `),n+=` out_FragColor = vec4(color); } -`,n}function QQe(t,e){sBt(t);let n=t._framebuffers,i=n.length,o=new Array(i);for(let a=0;a<i;++a)o[a]=e.createViewportQuadCommand(BQe(a,i),{framebuffer:n[a].framebuffer,uniformMap:yQe(t,a)});t._commands=o}TS.prototype.clear=function(t){let e=this._framebuffers;if(!c(e))return;let n=this._clearCommand;c(n)||(n=this._clearCommand=new ao({color:new v(0,0,0,0),framebuffer:void 0}));let i=e.length;for(let o=0;o<i;++o)e[o].clear(t,n)};TS.prototype.update=function(t){let e=t.drawingBufferWidth,n=t.drawingBufferHeight;(e!==this._width||n!==this._height)&&(this._width=e,this._height=n,NQe(this,t),QQe(this,t),this._ready||(this._ready=!0)),this._minMaxLuminance.x=this.minimumLuminance,this._minMaxLuminance.y=this.maximumLuminance;let i=this._framebuffers,o=i[i.length-1];i[i.length-1]=this._previousLuminance,this._commands[this._commands.length-1].framebuffer=this._previousLuminance.framebuffer,this._previousLuminance=o};TS.prototype.execute=function(t,e){this._colorTexture=e;let n=this._commands;if(!c(n))return;let i=n.length;for(let o=0;o<i;++o)n[o].execute(t)};TS.prototype.isDestroyed=function(){return!1};TS.prototype.destroy=function(){return aBt(this),sBt(this),At(this)};var R9=TS;var TBo=R(W(),1);var oBo=R(W(),1),kQe={NEAREST:0,LINEAR:1},op=kQe;function SS(t){t=f(t,f.EMPTY_OBJECT);let e=t.fragmentShader,n=f(t.textureScale,1),i=f(t.pixelFormat,Ye.RGBA);this._fragmentShader=e,this._uniforms=t.uniforms,this._textureScale=n,this._forcePowerOfTwo=f(t.forcePowerOfTwo,!1),this._sampleMode=f(t.sampleMode,op.NEAREST),this._pixelFormat=i,this._pixelDatatype=f(t.pixelDatatype,Ue.UNSIGNED_BYTE),this._clearColor=f(t.clearColor,v.BLACK),this._uniformMap=void 0,this._command=void 0,this._colorTexture=void 0,this._depthTexture=void 0,this._idTexture=void 0,this._actualUniforms={},this._dirtyUniforms=[],this._texturesToRelease=[],this._texturesToCreate=[],this._texturePromise=void 0;let o=new Md;o.scissorTest={enabled:!0,rectangle:c(t.scissorRectangle)?Fe.clone(t.scissorRectangle):new Fe},this._passState=o,this._ready=!1;let a=t.name;c(a)||(a=Si()),this._name=a,this._logDepthChanged=void 0,this._useLogDepth=void 0,this._selectedIdTexture=void 0,this._selected=void 0,this._selectedShadow=void 0,this._parentSelected=void 0,this._parentSelectedShadow=void 0,this._combinedSelected=void 0,this._combinedSelectedShadow=void 0,this._selectedLength=0,this._parentSelectedLength=0,this._selectedDirty=!0,this._textureCache=void 0,this._index=void 0,this.enabled=!0,this._enabled=!0}Object.defineProperties(SS.prototype,{ready:{get:function(){return this._ready}},name:{get:function(){return this._name}},fragmentShader:{get:function(){return this._fragmentShader}},uniforms:{get:function(){return this._uniforms}},textureScale:{get:function(){return this._textureScale}},forcePowerOfTwo:{get:function(){return this._forcePowerOfTwo}},sampleMode:{get:function(){return this._sampleMode}},pixelFormat:{get:function(){return this._pixelFormat}},pixelDatatype:{get:function(){return this._pixelDatatype}},clearColor:{get:function(){return this._clearColor}},scissorRectangle:{get:function(){return this._passState.scissorTest.rectangle}},outputTexture:{get:function(){if(c(this._textureCache)){let t=this._textureCache.getFramebuffer(this._name);if(c(t))return t.getColorTexture(0)}}},selected:{get:function(){return this._selected},set:function(t){this._selected=t}},parentSelected:{get:function(){return this._parentSelected},set:function(t){this._parentSelected=t}}});var YQe=/uniform\s+sampler2D\s+depthTexture/g;SS.prototype._isSupported=function(t){return!YQe.test(this._fragmentShader)||t.depthTexture};function xQe(t,e,n){let i=e[n];return(typeof i=="string"||i instanceof HTMLCanvasElement||i instanceof HTMLImageElement||i instanceof HTMLVideoElement||i instanceof ImageData)&&t._dirtyUniforms.push(n),{get:function(){return e[n]},set:function(o){let a=e[n];e[n]=o;let s=t._actualUniforms,l=s[n];c(l)&&l!==a&&l instanceof hn&&!c(t._textureCache.getStageByName(n))&&(t._texturesToRelease.push(l),delete s[n],delete s[`${n}Dimensions`]),a instanceof hn&&t._texturesToRelease.push(a),typeof o=="string"||o instanceof HTMLCanvasElement||o instanceof HTMLImageElement||o instanceof HTMLVideoElement||o instanceof ImageData?t._dirtyUniforms.push(n):s[n]=o}}}function XQe(t,e){return function(){let n=t._actualUniforms[e];return typeof n=="function"?n():n}}function JQe(t,e){return function(){let n=t[e]();if(c(n))return n.dimensions}}function LQe(t){if(c(t._uniformMap))return;let e={},n={},i=t._uniforms,o=t._actualUniforms;for(let a in i)if(i.hasOwnProperty(a)){typeof i[a]!="function"?(e[a]=XQe(t,a),n[a]=xQe(t,i,a)):(e[a]=i[a],n[a]=i[a]),o[a]=i[a];let s=e[a]();(typeof s=="string"||s instanceof hn||s instanceof HTMLImageElement||s instanceof HTMLCanvasElement||s instanceof HTMLVideoElement)&&(e[`${a}Dimensions`]=JQe(e,a))}t._uniforms={},Object.defineProperties(t._uniforms,n),t._uniformMap=ze(e,{colorTexture:function(){return t._colorTexture},colorTextureDimensions:function(){return t._colorTexture.dimensions},depthTexture:function(){return t._depthTexture},depthTextureDimensions:function(){return t._depthTexture.dimensions},czm_idTexture:function(){return t._idTexture},czm_selectedIdTexture:function(){return t._selectedIdTexture},czm_selectedIdTextureStep:function(){return 1/t._selectedIdTexture.width}})}function MQe(t,e){if(c(t._command)&&!t._logDepthChanged&&!t._selectedDirty)return;let n=t._fragmentShader;if(c(t._selectedIdTexture)){let o=t._selectedIdTexture.width;n=n.replace(/in\s+vec2\s+v_textureCoordinates;/g,""),n=`#define CZM_SELECTED_FEATURE +`,n}function QQe(t,e){sBt(t);let n=t._framebuffers,i=n.length,o=new Array(i);for(let a=0;a<i;++a)o[a]=e.createViewportQuadCommand(BQe(a,i),{framebuffer:n[a].framebuffer,uniformMap:yQe(t,a)});t._commands=o}ST.prototype.clear=function(t){let e=this._framebuffers;if(!c(e))return;let n=this._clearCommand;c(n)||(n=this._clearCommand=new ao({color:new v(0,0,0,0),framebuffer:void 0}));let i=e.length;for(let o=0;o<i;++o)e[o].clear(t,n)};ST.prototype.update=function(t){let e=t.drawingBufferWidth,n=t.drawingBufferHeight;(e!==this._width||n!==this._height)&&(this._width=e,this._height=n,NQe(this,t),QQe(this,t),this._ready||(this._ready=!0)),this._minMaxLuminance.x=this.minimumLuminance,this._minMaxLuminance.y=this.maximumLuminance;let i=this._framebuffers,o=i[i.length-1];i[i.length-1]=this._previousLuminance,this._commands[this._commands.length-1].framebuffer=this._previousLuminance.framebuffer,this._previousLuminance=o};ST.prototype.execute=function(t,e){this._colorTexture=e;let n=this._commands;if(!c(n))return;let i=n.length;for(let o=0;o<i;++o)n[o].execute(t)};ST.prototype.isDestroyed=function(){return!1};ST.prototype.destroy=function(){return aBt(this),sBt(this),At(this)};var b9=ST;var SBo=b(W(),1);var oBo=b(W(),1),kQe={NEAREST:0,LINEAR:1},op=kQe;function TT(t){t=f(t,f.EMPTY_OBJECT);let e=t.fragmentShader,n=f(t.textureScale,1),i=f(t.pixelFormat,Ye.RGBA);this._fragmentShader=e,this._uniforms=t.uniforms,this._textureScale=n,this._forcePowerOfTwo=f(t.forcePowerOfTwo,!1),this._sampleMode=f(t.sampleMode,op.NEAREST),this._pixelFormat=i,this._pixelDatatype=f(t.pixelDatatype,Ue.UNSIGNED_BYTE),this._clearColor=f(t.clearColor,v.BLACK),this._uniformMap=void 0,this._command=void 0,this._colorTexture=void 0,this._depthTexture=void 0,this._idTexture=void 0,this._actualUniforms={},this._dirtyUniforms=[],this._texturesToRelease=[],this._texturesToCreate=[],this._texturePromise=void 0;let o=new Md;o.scissorTest={enabled:!0,rectangle:c(t.scissorRectangle)?Fe.clone(t.scissorRectangle):new Fe},this._passState=o,this._ready=!1;let a=t.name;c(a)||(a=Ti()),this._name=a,this._logDepthChanged=void 0,this._useLogDepth=void 0,this._selectedIdTexture=void 0,this._selected=void 0,this._selectedShadow=void 0,this._parentSelected=void 0,this._parentSelectedShadow=void 0,this._combinedSelected=void 0,this._combinedSelectedShadow=void 0,this._selectedLength=0,this._parentSelectedLength=0,this._selectedDirty=!0,this._textureCache=void 0,this._index=void 0,this.enabled=!0,this._enabled=!0}Object.defineProperties(TT.prototype,{ready:{get:function(){return this._ready}},name:{get:function(){return this._name}},fragmentShader:{get:function(){return this._fragmentShader}},uniforms:{get:function(){return this._uniforms}},textureScale:{get:function(){return this._textureScale}},forcePowerOfTwo:{get:function(){return this._forcePowerOfTwo}},sampleMode:{get:function(){return this._sampleMode}},pixelFormat:{get:function(){return this._pixelFormat}},pixelDatatype:{get:function(){return this._pixelDatatype}},clearColor:{get:function(){return this._clearColor}},scissorRectangle:{get:function(){return this._passState.scissorTest.rectangle}},outputTexture:{get:function(){if(c(this._textureCache)){let t=this._textureCache.getFramebuffer(this._name);if(c(t))return t.getColorTexture(0)}}},selected:{get:function(){return this._selected},set:function(t){this._selected=t}},parentSelected:{get:function(){return this._parentSelected},set:function(t){this._parentSelected=t}}});var YQe=/uniform\s+sampler2D\s+depthTexture/g;TT.prototype._isSupported=function(t){return!YQe.test(this._fragmentShader)||t.depthTexture};function xQe(t,e,n){let i=e[n];return(typeof i=="string"||i instanceof HTMLCanvasElement||i instanceof HTMLImageElement||i instanceof HTMLVideoElement||i instanceof ImageData)&&t._dirtyUniforms.push(n),{get:function(){return e[n]},set:function(o){let a=e[n];e[n]=o;let s=t._actualUniforms,l=s[n];c(l)&&l!==a&&l instanceof hn&&!c(t._textureCache.getStageByName(n))&&(t._texturesToRelease.push(l),delete s[n],delete s[`${n}Dimensions`]),a instanceof hn&&t._texturesToRelease.push(a),typeof o=="string"||o instanceof HTMLCanvasElement||o instanceof HTMLImageElement||o instanceof HTMLVideoElement||o instanceof ImageData?t._dirtyUniforms.push(n):s[n]=o}}}function XQe(t,e){return function(){let n=t._actualUniforms[e];return typeof n=="function"?n():n}}function JQe(t,e){return function(){let n=t[e]();if(c(n))return n.dimensions}}function LQe(t){if(c(t._uniformMap))return;let e={},n={},i=t._uniforms,o=t._actualUniforms;for(let a in i)if(i.hasOwnProperty(a)){typeof i[a]!="function"?(e[a]=XQe(t,a),n[a]=xQe(t,i,a)):(e[a]=i[a],n[a]=i[a]),o[a]=i[a];let s=e[a]();(typeof s=="string"||s instanceof hn||s instanceof HTMLImageElement||s instanceof HTMLCanvasElement||s instanceof HTMLVideoElement)&&(e[`${a}Dimensions`]=JQe(e,a))}t._uniforms={},Object.defineProperties(t._uniforms,n),t._uniformMap=ze(e,{colorTexture:function(){return t._colorTexture},colorTextureDimensions:function(){return t._colorTexture.dimensions},depthTexture:function(){return t._depthTexture},depthTextureDimensions:function(){return t._depthTexture.dimensions},czm_idTexture:function(){return t._idTexture},czm_selectedIdTexture:function(){return t._selectedIdTexture},czm_selectedIdTextureStep:function(){return 1/t._selectedIdTexture.width}})}function MQe(t,e){if(c(t._command)&&!t._logDepthChanged&&!t._selectedDirty)return;let n=t._fragmentShader;if(c(t._selectedIdTexture)){let o=t._selectedIdTexture.width;n=n.replace(/in\s+vec2\s+v_textureCoordinates;/g,""),n=`#define CZM_SELECTED_FEATURE uniform sampler2D czm_idTexture; uniform sampler2D czm_selectedIdTexture; uniform float czm_selectedIdTextureStep; @@ -12595,8 +12595,8 @@ bool czm_selected() return czm_selected(vec2(0.0)); } -${n}`}let i=new Ve({defines:[t._useLogDepth?"LOG_DEPTH":""],sources:[n]});t._command=e.createViewportQuadCommand(i,{uniformMap:t._uniformMap,owner:t})}function _Qe(t){let e=t._sampleMode,n,i;e===op.LINEAR?(n=On.LINEAR,i=bo.LINEAR):(n=On.NEAREST,i=bo.NEAREST);let o=t._sampler;(!c(o)||o.minificationFilter!==n||o.magnificationFilter!==i)&&(t._sampler=new Hn({wrapS:Vi.CLAMP_TO_EDGE,wrapT:Vi.CLAMP_TO_EDGE,minificationFilter:n,magnificationFilter:i}))}function DQe(t,e){return function(n){t._texturesToCreate.push({name:e,source:n})}}function OQe(t,e){return function(){return t._textureCache.getOutputTexture(e)}}function HQe(t,e){let n,i,o,a=t._texturesToRelease,s=a.length;for(n=0;n<s;++n)i=a[n],i=i&&i.destroy();a.length=0;let l=t._texturesToCreate;for(s=l.length,n=0;n<s;++n){let h=l[n];o=h.name;let Z=h.source;t._actualUniforms[o]=new hn({context:e,source:Z})}l.length=0;let r=t._dirtyUniforms;if(r.length===0&&!c(t._texturePromise)){t._ready=!0;return}if(r.length===0||c(t._texturePromise))return;s=r.length;let d=t._uniforms,m=[];for(n=0;n<s;++n){o=r[n];let h=d[o],Z=t._textureCache.getStageByName(h);if(c(Z))t._actualUniforms[o]=OQe(t,h);else if(typeof h=="string"){let b=new te({url:h});m.push(b.fetchImage().then(DQe(t,o)))}else t._texturesToCreate.push({name:o,source:h})}r.length=0,m.length>0?(t._ready=!1,t._texturePromise=Promise.all(m).then(function(){t._ready=!0,t._texturePromise=void 0})):t._ready=!0}function lBt(t){c(t._command)&&(t._command.shaderProgram=t._command.shaderProgram&&t._command.shaderProgram.destroy(),t._command=void 0),t._selectedIdTexture=t._selectedIdTexture&&t._selectedIdTexture.destroy();let e=t._textureCache;if(!c(e))return;let n=t._uniforms,i=t._actualUniforms;for(let o in i)i.hasOwnProperty(o)&&i[o]instanceof hn&&(c(e.getStageByName(n[o]))||i[o].destroy(),t._dirtyUniforms.push(o))}function wQe(t){let e=c(t._selected)?t._selected.length:0,n=c(t._parentSelected)?t._parentSelected:0,i=t._selected!==t._selectedShadow||e!==t._selectedLength;if(i=i||t._parentSelected!==t._parentSelectedShadow||n!==t._parentSelectedLength,c(t._selected)&&c(t._parentSelected)?t._combinedSelected=t._selected.concat(t._parentSelected):c(t._parentSelected)?t._combinedSelected=t._parentSelected:t._combinedSelected=t._selected,!i&&c(t._combinedSelected)){if(!c(t._combinedSelectedShadow))return!0;e=t._combinedSelected.length;for(let o=0;o<e;++o)if(t._combinedSelected[o]!==t._combinedSelectedShadow[o])return!0}return i}function PQe(t,e){if(!t._selectedDirty)return;t._selectedIdTexture=t._selectedIdTexture&&t._selectedIdTexture.destroy(),t._selectedIdTexture=void 0;let n=t._combinedSelected;if(!c(n))return;let i,o,a=0,s=n.length;for(i=0;i<s;++i)o=n[i],c(o.pickIds)?a+=o.pickIds.length:c(o.pickId)&&++a;if(s===0||a===0){let m=new Uint8Array(4);m[0]=255,m[1]=255,m[2]=255,m[3]=255,t._selectedIdTexture=new hn({context:e,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,source:{arrayBufferView:m,width:1,height:1},sampler:Hn.NEAREST});return}let l,r=0,d=new Uint8Array(a*4);for(i=0;i<s;++i)if(o=n[i],c(o.pickIds)){let m=o.pickIds,h=m.length;for(let Z=0;Z<h;++Z)l=m[Z].color,d[r]=v.floatToByte(l.red),d[r+1]=v.floatToByte(l.green),d[r+2]=v.floatToByte(l.blue),d[r+3]=v.floatToByte(l.alpha),r+=4}else c(o.pickId)&&(l=o.pickId.color,d[r]=v.floatToByte(l.red),d[r+1]=v.floatToByte(l.green),d[r+2]=v.floatToByte(l.blue),d[r+3]=v.floatToByte(l.alpha),r+=4);t._selectedIdTexture=new hn({context:e,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,source:{arrayBufferView:d,width:a,height:1},sampler:Hn.NEAREST})}SS.prototype.update=function(t,e){if(this.enabled!==this._enabled&&!this.enabled&&lBt(this),this._enabled=this.enabled,!this._enabled||(this._logDepthChanged=e!==this._useLogDepth,this._useLogDepth=e,this._selectedDirty=wQe(this),this._selectedShadow=this._selected,this._parentSelectedShadow=this._parentSelected,this._combinedSelectedShadow=this._combinedSelected,this._selectedLength=c(this._selected)?this._selected.length:0,this._parentSelectedLength=c(this._parentSelected)?this._parentSelected.length:0,PQe(this,t),LQe(this),HQe(this,t),MQe(this,t),_Qe(this),this._selectedDirty=!1,!this._ready))return;let n=this._textureCache.getFramebuffer(this._name);if(this._command.framebuffer=n,!c(n))return;let i=n.getColorTexture(0),o;(i.width!==t.drawingBufferWidth||i.height!==t.drawingBufferHeight)&&(o=this._renderState,(!c(o)||i.width!==o.viewport.width||i.height!==o.viewport.height)&&(this._renderState=he.fromCache({viewport:new Fe(0,0,i.width,i.height)}))),this._command.renderState=o};SS.prototype.execute=function(t,e,n,i){if(!c(this._command)||!c(this._command.framebuffer)||!this._ready||!this._enabled)return;this._colorTexture=e,this._depthTexture=n,this._idTexture=i,Hn.equals(this._colorTexture.sampler,this._sampler)||(this._colorTexture.sampler=this._sampler);let o=this.scissorRectangle.width>0&&this.scissorRectangle.height>0?this._passState:void 0;c(o)&&(o.context=t),this._command.execute(t,o)};SS.prototype.isDestroyed=function(){return!1};SS.prototype.destroy=function(){return lBt(this),At(this)};var Qa=SS;var NBo=R(W(),1);function gS(t){t=f(t,f.EMPTY_OBJECT),this._stages=t.stages,this._inputPreviousStageTexture=f(t.inputPreviousStageTexture,!0);let e=t.name;c(e)||(e=Si()),this._name=e,this._uniforms=t.uniforms,this._textureCache=void 0,this._index=void 0,this._selected=void 0,this._selectedShadow=void 0,this._parentSelected=void 0,this._parentSelectedShadow=void 0,this._combinedSelected=void 0,this._combinedSelectedShadow=void 0,this._selectedLength=0,this._parentSelectedLength=0,this._selectedDirty=!0}Object.defineProperties(gS.prototype,{ready:{get:function(){let t=this._stages,e=t.length;for(let n=0;n<e;++n)if(!t[n].ready)return!1;return!0}},name:{get:function(){return this._name}},enabled:{get:function(){return this._stages[0].enabled},set:function(t){let e=this._stages,n=e.length;for(let i=0;i<n;++i)e[i].enabled=t}},uniforms:{get:function(){return this._uniforms}},inputPreviousStageTexture:{get:function(){return this._inputPreviousStageTexture}},length:{get:function(){return this._stages.length}},selected:{get:function(){return this._selected},set:function(t){this._selected=t}},parentSelected:{get:function(){return this._parentSelected},set:function(t){this._parentSelected=t}}});gS.prototype._isSupported=function(t){let e=this._stages,n=e.length;for(let i=0;i<n;++i)if(!e[i]._isSupported(t))return!1;return!0};gS.prototype.get=function(t){return this._stages[t]};function vQe(t){let e=c(t._selected)?t._selected.length:0,n=c(t._parentSelected)?t._parentSelected:0,i=t._selected!==t._selectedShadow||e!==t._selectedLength;if(i=i||t._parentSelected!==t._parentSelectedShadow||n!==t._parentSelectedLength,c(t._selected)&&c(t._parentSelected)?t._combinedSelected=t._selected.concat(t._parentSelected):c(t._parentSelected)?t._combinedSelected=t._parentSelected:t._combinedSelected=t._selected,!i&&c(t._combinedSelected)){if(!c(t._combinedSelectedShadow))return!0;e=t._combinedSelected.length;for(let o=0;o<e;++o)if(t._combinedSelected[o]!==t._combinedSelectedShadow[o])return!0}return i}gS.prototype.update=function(t,e){this._selectedDirty=vQe(this),this._selectedShadow=this._selected,this._parentSelectedShadow=this._parentSelected,this._combinedSelectedShadow=this._combinedSelected,this._selectedLength=c(this._selected)?this._selected.length:0,this._parentSelectedLength=c(this._parentSelected)?this._parentSelected.length:0;let n=this._stages,i=n.length;for(let o=0;o<i;++o){let a=n[o];this._selectedDirty&&(a.parentSelected=this._combinedSelected),a.update(t,e)}};gS.prototype.isDestroyed=function(){return!1};gS.prototype.destroy=function(){let t=this._stages,e=t.length;for(let n=0;n<e;++n)t[n].destroy();return At(this)};var nm=gS;var Vl={};function pj(t){let o=`#define USE_STEP_SIZE -${fU}`,a=new Qa({name:`${t}_x_direction`,fragmentShader:o,uniforms:{delta:1,sigma:2,stepSize:1,direction:0},sampleMode:op.LINEAR}),s=new Qa({name:`${t}_y_direction`,fragmentShader:o,uniforms:{delta:1,sigma:2,stepSize:1,direction:1},sampleMode:op.LINEAR}),l={};return Object.defineProperties(l,{delta:{get:function(){return a.uniforms.delta},set:function(r){let d=a.uniforms,m=s.uniforms;d.delta=m.delta=r}},sigma:{get:function(){return a.uniforms.sigma},set:function(r){let d=a.uniforms,m=s.uniforms;d.sigma=m.sigma=r}},stepSize:{get:function(){return a.uniforms.stepSize},set:function(r){let d=a.uniforms,m=s.uniforms;d.stepSize=m.stepSize=r}}}),new nm({name:t,stages:[a,s],uniforms:l})}Vl.createBlurStage=function(){return pj("czm_blur")};Vl.createDepthOfFieldStage=function(){let t=pj("czm_depth_of_field_blur"),e=new Qa({name:"czm_depth_of_field_composite",fragmentShader:l9,uniforms:{focalDistance:5,blurTexture:t.name}}),n={};return Object.defineProperties(n,{focalDistance:{get:function(){return e.uniforms.focalDistance},set:function(i){e.uniforms.focalDistance=i}},delta:{get:function(){return t.uniforms.delta},set:function(i){t.uniforms.delta=i}},sigma:{get:function(){return t.uniforms.sigma},set:function(i){t.uniforms.sigma=i}},stepSize:{get:function(){return t.uniforms.stepSize},set:function(i){t.uniforms.stepSize=i}}}),new nm({name:"czm_depth_of_field",stages:[t,e],inputPreviousStageTexture:!1,uniforms:n})};Vl.isDepthOfFieldSupported=function(t){return t.context.depthTexture};Vl.createEdgeDetectionStage=function(){let t=Si();return new Qa({name:`czm_edge_detection_${t}`,fragmentShader:d9,uniforms:{length:.25,color:v.clone(v.BLACK)}})};Vl.isEdgeDetectionSupported=function(t){return t.context.depthTexture};function KQe(t){if(!c(t))return Vl.createEdgeDetectionStage();let e=new nm({name:"czm_edge_detection_multiple",stages:t,inputPreviousStageTexture:!1}),n={},i="",o="";for(let l=0;l<t.length;++l)i+=`uniform sampler2D edgeTexture${l}; +${n}`}let i=new Ze({defines:[t._useLogDepth?"LOG_DEPTH":""],sources:[n]});t._command=e.createViewportQuadCommand(i,{uniformMap:t._uniformMap,owner:t})}function _Qe(t){let e=t._sampleMode,n,i;e===op.LINEAR?(n=On.LINEAR,i=Ro.LINEAR):(n=On.NEAREST,i=Ro.NEAREST);let o=t._sampler;(!c(o)||o.minificationFilter!==n||o.magnificationFilter!==i)&&(t._sampler=new Hn({wrapS:Zi.CLAMP_TO_EDGE,wrapT:Zi.CLAMP_TO_EDGE,minificationFilter:n,magnificationFilter:i}))}function DQe(t,e){return function(n){t._texturesToCreate.push({name:e,source:n})}}function OQe(t,e){return function(){return t._textureCache.getOutputTexture(e)}}function HQe(t,e){let n,i,o,a=t._texturesToRelease,s=a.length;for(n=0;n<s;++n)i=a[n],i=i&&i.destroy();a.length=0;let l=t._texturesToCreate;for(s=l.length,n=0;n<s;++n){let h=l[n];o=h.name;let u=h.source;t._actualUniforms[o]=new hn({context:e,source:u})}l.length=0;let r=t._dirtyUniforms;if(r.length===0&&!c(t._texturePromise)){t._ready=!0;return}if(r.length===0||c(t._texturePromise))return;s=r.length;let d=t._uniforms,m=[];for(n=0;n<s;++n){o=r[n];let h=d[o],u=t._textureCache.getStageByName(h);if(c(u))t._actualUniforms[o]=OQe(t,h);else if(typeof h=="string"){let R=new te({url:h});m.push(R.fetchImage().then(DQe(t,o)))}else t._texturesToCreate.push({name:o,source:h})}r.length=0,m.length>0?(t._ready=!1,t._texturePromise=Promise.all(m).then(function(){t._ready=!0,t._texturePromise=void 0})):t._ready=!0}function lBt(t){c(t._command)&&(t._command.shaderProgram=t._command.shaderProgram&&t._command.shaderProgram.destroy(),t._command=void 0),t._selectedIdTexture=t._selectedIdTexture&&t._selectedIdTexture.destroy();let e=t._textureCache;if(!c(e))return;let n=t._uniforms,i=t._actualUniforms;for(let o in i)i.hasOwnProperty(o)&&i[o]instanceof hn&&(c(e.getStageByName(n[o]))||i[o].destroy(),t._dirtyUniforms.push(o))}function wQe(t){let e=c(t._selected)?t._selected.length:0,n=c(t._parentSelected)?t._parentSelected:0,i=t._selected!==t._selectedShadow||e!==t._selectedLength;if(i=i||t._parentSelected!==t._parentSelectedShadow||n!==t._parentSelectedLength,c(t._selected)&&c(t._parentSelected)?t._combinedSelected=t._selected.concat(t._parentSelected):c(t._parentSelected)?t._combinedSelected=t._parentSelected:t._combinedSelected=t._selected,!i&&c(t._combinedSelected)){if(!c(t._combinedSelectedShadow))return!0;e=t._combinedSelected.length;for(let o=0;o<e;++o)if(t._combinedSelected[o]!==t._combinedSelectedShadow[o])return!0}return i}function PQe(t,e){if(!t._selectedDirty)return;t._selectedIdTexture=t._selectedIdTexture&&t._selectedIdTexture.destroy(),t._selectedIdTexture=void 0;let n=t._combinedSelected;if(!c(n))return;let i,o,a=0,s=n.length;for(i=0;i<s;++i)o=n[i],c(o.pickIds)?a+=o.pickIds.length:c(o.pickId)&&++a;if(s===0||a===0){let m=new Uint8Array(4);m[0]=255,m[1]=255,m[2]=255,m[3]=255,t._selectedIdTexture=new hn({context:e,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,source:{arrayBufferView:m,width:1,height:1},sampler:Hn.NEAREST});return}let l,r=0,d=new Uint8Array(a*4);for(i=0;i<s;++i)if(o=n[i],c(o.pickIds)){let m=o.pickIds,h=m.length;for(let u=0;u<h;++u)l=m[u].color,d[r]=v.floatToByte(l.red),d[r+1]=v.floatToByte(l.green),d[r+2]=v.floatToByte(l.blue),d[r+3]=v.floatToByte(l.alpha),r+=4}else c(o.pickId)&&(l=o.pickId.color,d[r]=v.floatToByte(l.red),d[r+1]=v.floatToByte(l.green),d[r+2]=v.floatToByte(l.blue),d[r+3]=v.floatToByte(l.alpha),r+=4);t._selectedIdTexture=new hn({context:e,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,source:{arrayBufferView:d,width:a,height:1},sampler:Hn.NEAREST})}TT.prototype.update=function(t,e){if(this.enabled!==this._enabled&&!this.enabled&&lBt(this),this._enabled=this.enabled,!this._enabled||(this._logDepthChanged=e!==this._useLogDepth,this._useLogDepth=e,this._selectedDirty=wQe(this),this._selectedShadow=this._selected,this._parentSelectedShadow=this._parentSelected,this._combinedSelectedShadow=this._combinedSelected,this._selectedLength=c(this._selected)?this._selected.length:0,this._parentSelectedLength=c(this._parentSelected)?this._parentSelected.length:0,PQe(this,t),LQe(this),HQe(this,t),MQe(this,t),_Qe(this),this._selectedDirty=!1,!this._ready))return;let n=this._textureCache.getFramebuffer(this._name);if(this._command.framebuffer=n,!c(n))return;let i=n.getColorTexture(0),o;(i.width!==t.drawingBufferWidth||i.height!==t.drawingBufferHeight)&&(o=this._renderState,(!c(o)||i.width!==o.viewport.width||i.height!==o.viewport.height)&&(this._renderState=he.fromCache({viewport:new Fe(0,0,i.width,i.height)}))),this._command.renderState=o};TT.prototype.execute=function(t,e,n,i){if(!c(this._command)||!c(this._command.framebuffer)||!this._ready||!this._enabled)return;this._colorTexture=e,this._depthTexture=n,this._idTexture=i,Hn.equals(this._colorTexture.sampler,this._sampler)||(this._colorTexture.sampler=this._sampler);let o=this.scissorRectangle.width>0&&this.scissorRectangle.height>0?this._passState:void 0;c(o)&&(o.context=t),this._command.execute(t,o)};TT.prototype.isDestroyed=function(){return!1};TT.prototype.destroy=function(){return lBt(this),At(this)};var Qa=TT;var NBo=b(W(),1);function gT(t){t=f(t,f.EMPTY_OBJECT),this._stages=t.stages,this._inputPreviousStageTexture=f(t.inputPreviousStageTexture,!0);let e=t.name;c(e)||(e=Ti()),this._name=e,this._uniforms=t.uniforms,this._textureCache=void 0,this._index=void 0,this._selected=void 0,this._selectedShadow=void 0,this._parentSelected=void 0,this._parentSelectedShadow=void 0,this._combinedSelected=void 0,this._combinedSelectedShadow=void 0,this._selectedLength=0,this._parentSelectedLength=0,this._selectedDirty=!0}Object.defineProperties(gT.prototype,{ready:{get:function(){let t=this._stages,e=t.length;for(let n=0;n<e;++n)if(!t[n].ready)return!1;return!0}},name:{get:function(){return this._name}},enabled:{get:function(){return this._stages[0].enabled},set:function(t){let e=this._stages,n=e.length;for(let i=0;i<n;++i)e[i].enabled=t}},uniforms:{get:function(){return this._uniforms}},inputPreviousStageTexture:{get:function(){return this._inputPreviousStageTexture}},length:{get:function(){return this._stages.length}},selected:{get:function(){return this._selected},set:function(t){this._selected=t}},parentSelected:{get:function(){return this._parentSelected},set:function(t){this._parentSelected=t}}});gT.prototype._isSupported=function(t){let e=this._stages,n=e.length;for(let i=0;i<n;++i)if(!e[i]._isSupported(t))return!1;return!0};gT.prototype.get=function(t){return this._stages[t]};function vQe(t){let e=c(t._selected)?t._selected.length:0,n=c(t._parentSelected)?t._parentSelected:0,i=t._selected!==t._selectedShadow||e!==t._selectedLength;if(i=i||t._parentSelected!==t._parentSelectedShadow||n!==t._parentSelectedLength,c(t._selected)&&c(t._parentSelected)?t._combinedSelected=t._selected.concat(t._parentSelected):c(t._parentSelected)?t._combinedSelected=t._parentSelected:t._combinedSelected=t._selected,!i&&c(t._combinedSelected)){if(!c(t._combinedSelectedShadow))return!0;e=t._combinedSelected.length;for(let o=0;o<e;++o)if(t._combinedSelected[o]!==t._combinedSelectedShadow[o])return!0}return i}gT.prototype.update=function(t,e){this._selectedDirty=vQe(this),this._selectedShadow=this._selected,this._parentSelectedShadow=this._parentSelected,this._combinedSelectedShadow=this._combinedSelected,this._selectedLength=c(this._selected)?this._selected.length:0,this._parentSelectedLength=c(this._parentSelected)?this._parentSelected.length:0;let n=this._stages,i=n.length;for(let o=0;o<i;++o){let a=n[o];this._selectedDirty&&(a.parentSelected=this._combinedSelected),a.update(t,e)}};gT.prototype.isDestroyed=function(){return!1};gT.prototype.destroy=function(){let t=this._stages,e=t.length;for(let n=0;n<e;++n)t[n].destroy();return At(this)};var nm=gT;var Zl={};function pj(t){let o=`#define USE_STEP_SIZE +${fU}`,a=new Qa({name:`${t}_x_direction`,fragmentShader:o,uniforms:{delta:1,sigma:2,stepSize:1,direction:0},sampleMode:op.LINEAR}),s=new Qa({name:`${t}_y_direction`,fragmentShader:o,uniforms:{delta:1,sigma:2,stepSize:1,direction:1},sampleMode:op.LINEAR}),l={};return Object.defineProperties(l,{delta:{get:function(){return a.uniforms.delta},set:function(r){let d=a.uniforms,m=s.uniforms;d.delta=m.delta=r}},sigma:{get:function(){return a.uniforms.sigma},set:function(r){let d=a.uniforms,m=s.uniforms;d.sigma=m.sigma=r}},stepSize:{get:function(){return a.uniforms.stepSize},set:function(r){let d=a.uniforms,m=s.uniforms;d.stepSize=m.stepSize=r}}}),new nm({name:t,stages:[a,s],uniforms:l})}Zl.createBlurStage=function(){return pj("czm_blur")};Zl.createDepthOfFieldStage=function(){let t=pj("czm_depth_of_field_blur"),e=new Qa({name:"czm_depth_of_field_composite",fragmentShader:l9,uniforms:{focalDistance:5,blurTexture:t.name}}),n={};return Object.defineProperties(n,{focalDistance:{get:function(){return e.uniforms.focalDistance},set:function(i){e.uniforms.focalDistance=i}},delta:{get:function(){return t.uniforms.delta},set:function(i){t.uniforms.delta=i}},sigma:{get:function(){return t.uniforms.sigma},set:function(i){t.uniforms.sigma=i}},stepSize:{get:function(){return t.uniforms.stepSize},set:function(i){t.uniforms.stepSize=i}}}),new nm({name:"czm_depth_of_field",stages:[t,e],inputPreviousStageTexture:!1,uniforms:n})};Zl.isDepthOfFieldSupported=function(t){return t.context.depthTexture};Zl.createEdgeDetectionStage=function(){let t=Ti();return new Qa({name:`czm_edge_detection_${t}`,fragmentShader:d9,uniforms:{length:.25,color:v.clone(v.BLACK)}})};Zl.isEdgeDetectionSupported=function(t){return t.context.depthTexture};function KQe(t){if(!c(t))return Zl.createEdgeDetectionStage();let e=new nm({name:"czm_edge_detection_multiple",stages:t,inputPreviousStageTexture:!1}),n={},i="",o="";for(let l=0;l<t.length;++l)i+=`uniform sampler2D edgeTexture${l}; `,o+=` vec4 edge${l} = texture(edgeTexture${l}, v_textureCoordinates); if (edge${l}.a > 0.0) { @@ -12611,13 +12611,13 @@ void main() { ${o} } out_FragColor = color; } -`,s=new Qa({name:"czm_edge_detection_combine",fragmentShader:a,uniforms:n});return new nm({name:"czm_edge_detection_composite",stages:[e,s]})}Vl.createSilhouetteStage=function(t){let e=KQe(t),n=new Qa({name:"czm_silhouette_color_edges",fragmentShader:V9,uniforms:{silhouetteTexture:e.name}});return new nm({name:"czm_silhouette",stages:[e,n],inputPreviousStageTexture:!1,uniforms:e.uniforms})};Vl.isSilhouetteSupported=function(t){return t.context.depthTexture};Vl.createBloomStage=function(){let t=new Qa({name:"czm_bloom_contrast_bias",fragmentShader:s9,uniforms:{contrast:128,brightness:-.3}}),e=pj("czm_bloom_blur"),n=new nm({name:"czm_bloom_contrast_bias_blur",stages:[t,e]}),i=new Qa({name:"czm_bloom_generate_composite",fragmentShader:o9,uniforms:{glowOnly:!1,bloomTexture:n.name}}),o={};return Object.defineProperties(o,{glowOnly:{get:function(){return i.uniforms.glowOnly},set:function(a){i.uniforms.glowOnly=a}},contrast:{get:function(){return t.uniforms.contrast},set:function(a){t.uniforms.contrast=a}},brightness:{get:function(){return t.uniforms.brightness},set:function(a){t.uniforms.brightness=a}},delta:{get:function(){return e.uniforms.delta},set:function(a){e.uniforms.delta=a}},sigma:{get:function(){return e.uniforms.sigma},set:function(a){e.uniforms.sigma=a}},stepSize:{get:function(){return e.uniforms.stepSize},set:function(a){e.uniforms.stepSize=a}}}),new nm({name:"czm_bloom",stages:[n,i],inputPreviousStageTexture:!1,uniforms:o})};Vl.createAmbientOcclusionStage=function(){let t=new Qa({name:"czm_ambient_occlusion_generate",fragmentShader:e9,uniforms:{intensity:3,bias:.1,lengthCap:.26,stepSize:1.95,frustumLength:1e3,randomTexture:void 0}}),e=pj("czm_ambient_occlusion_blur");e.uniforms.stepSize=.86;let n=new nm({name:"czm_ambient_occlusion_generate_blur",stages:[t,e]}),i=new Qa({name:"czm_ambient_occlusion_composite",fragmentShader:n9,uniforms:{ambientOcclusionOnly:!1,ambientOcclusionTexture:n.name}}),o={};return Object.defineProperties(o,{intensity:{get:function(){return t.uniforms.intensity},set:function(a){t.uniforms.intensity=a}},bias:{get:function(){return t.uniforms.bias},set:function(a){t.uniforms.bias=a}},lengthCap:{get:function(){return t.uniforms.lengthCap},set:function(a){t.uniforms.lengthCap=a}},stepSize:{get:function(){return t.uniforms.stepSize},set:function(a){t.uniforms.stepSize=a}},frustumLength:{get:function(){return t.uniforms.frustumLength},set:function(a){t.uniforms.frustumLength=a}},randomTexture:{get:function(){return t.uniforms.randomTexture},set:function(a){t.uniforms.randomTexture=a}},delta:{get:function(){return e.uniforms.delta},set:function(a){e.uniforms.delta=a}},sigma:{get:function(){return e.uniforms.sigma},set:function(a){e.uniforms.sigma=a}},blurStepSize:{get:function(){return e.uniforms.stepSize},set:function(a){e.uniforms.stepSize=a}},ambientOcclusionOnly:{get:function(){return i.uniforms.ambientOcclusionOnly},set:function(a){i.uniforms.ambientOcclusionOnly=a}}}),new nm({name:"czm_ambient_occlusion",stages:[n,i],inputPreviousStageTexture:!1,uniforms:o})};Vl.isAmbientOcclusionSupported=function(t){return t.context.depthTexture};var zQe=`#define FXAA_QUALITY_PRESET 39 -${b9} -${m9}`;Vl.createFXAAStage=function(){return new Qa({name:"czm_FXAA",fragmentShader:zQe,sampleMode:op.LINEAR})};Vl.createAcesTonemappingStage=function(t){let e=t?`#define AUTO_EXPOSURE -`:"";return e+=t9,new Qa({name:"czm_aces",fragmentShader:e,uniforms:{autoExposure:void 0}})};Vl.createFilmicTonemappingStage=function(t){let e=t?`#define AUTO_EXPOSURE -`:"";return e+=c9,new Qa({name:"czm_filmic",fragmentShader:e,uniforms:{autoExposure:void 0}})};Vl.createReinhardTonemappingStage=function(t){let e=t?`#define AUTO_EXPOSURE -`:"";return e+=Z9,new Qa({name:"czm_reinhard",fragmentShader:e,uniforms:{autoExposure:void 0}})};Vl.createModifiedReinhardTonemappingStage=function(t){let e=t?`#define AUTO_EXPOSURE -`:"";return e+=p9,new Qa({name:"czm_modified_reinhard",fragmentShader:e,uniforms:{white:v.WHITE,autoExposure:void 0}})};Vl.createAutoExposureStage=function(){return new R9};Vl.createBlackAndWhiteStage=function(){return new Qa({name:"czm_black_and_white",fragmentShader:i9,uniforms:{gradations:5}})};Vl.createBrightnessStage=function(){return new Qa({name:"czm_brightness",fragmentShader:a9,uniforms:{brightness:.5}})};Vl.createNightVisionStage=function(){return new Qa({name:"czm_night_vision",fragmentShader:u9})};Vl.createDepthViewStage=function(){return new Qa({name:"czm_depth_view",fragmentShader:r9})};Vl.createLensFlareStage=function(){return new Qa({name:"czm_lens_flare",fragmentShader:h9,uniforms:{dirtTexture:Dn("Assets/Textures/LensFlare/DirtMask.jpg"),starTexture:Dn("Assets/Textures/LensFlare/StarBurst.jpg"),intensity:2,distortion:10,ghostDispersal:.4,haloWidth:.4,dirtAmount:.4,earthRadius:mt.WGS84.maximumRadius}})};var Iu=Vl;var ZQo=R(W(),1);function UW(t){this._collection=t,this._framebuffers=[],this._stageNameToFramebuffer={},this._width=void 0,this._height=void 0,this._updateDependencies=!1}function f9(t){for(;c(t.length);)t=t.get(t.length-1);return t.name}function yat(t,e,n,i,o){if(!i.enabled||!i._isSupported(e))return o;let a=n[i.name]={};if(c(o)){let l=t.getStageByName(o);a[f9(l)]=!0}let s=i.uniforms;if(c(s)){let l=Object.getOwnPropertyNames(s),r=l.length;for(let d=0;d<r;++d){let m=s[l[d]];if(typeof m=="string"){let h=t.getStageByName(m);c(h)&&(a[f9(h)]=!0)}}}return i.name}function W9(t,e,n,i,o){if(c(i.enabled)&&!i.enabled||c(i._isSupported)&&!i._isSupported(e))return o;let a=o,s=!c(i.inputPreviousStageTexture)||i.inputPreviousStageTexture,l=o,r=i.length;for(let h=0;h<r;++h){let Z=i.get(h);c(Z.length)?l=W9(t,e,n,Z,o):l=yat(t,e,n,Z,o),s&&(o=l)}let d,m;if(s)for(d=1;d<r;++d)m=f9(i.get(d)),c(n[m])||(n[m]={}),n[m][a]=!0;else for(d=1;d<r;++d){m=f9(i.get(d));let h=n[m];for(let Z=0;Z<d;++Z)h[f9(i.get(Z))]=!0}return l}function jQe(t,e){let n={};if(c(t.ambientOcclusion)){let i=t.ambientOcclusion,o=t.bloom,a=t._tonemapping,s=t.fxaa,l=W9(t,e,n,i,void 0);l=W9(t,e,n,o,l),l=yat(t,e,n,a,l),l=W9(t,e,n,t,l),yat(t,e,n,s,l)}else W9(t,e,n,t,void 0);return n}function qQe(t,e,n){let o=t._collection.getStageByName(e),a=o._textureScale,s=o._forcePowerOfTwo,l=o._pixelFormat,r=o._pixelDatatype,d=o._clearColor,m,h,Z=t._framebuffers,b=Z.length;for(m=0;m<b;++m){if(h=Z[m],a!==h.textureScale||s!==h.forcePowerOfTwo||l!==h.pixelFormat||r!==h.pixelDatatype||!v.equals(d,h.clearColor))continue;let u=h.stages,F=u.length,U=!1;for(let G=0;G<F;++G)if(n[u[G]]){U=!0;break}if(!U)break}return c(h)&&m<b?(h.stages.push(e),h):(h={textureScale:a,forcePowerOfTwo:s,pixelFormat:l,pixelDatatype:r,clearColor:d,stages:[e],buffer:new Ro({pixelFormat:l,pixelDatatype:r}),clear:void 0},Z.push(h),h)}function $Qe(t,e){let n=jQe(t._collection,e);for(let i in n)n.hasOwnProperty(i)&&(t._stageNameToFramebuffer[i]=qQe(t,i,n[i]))}function Bat(t){let e=t._framebuffers,n=e.length;for(let i=0;i<n;++i)e[i].buffer.destroy()}function t2e(t,e){let n=t._width,i=t._height,o=t._framebuffers,a=o.length;for(let s=0;s<a;++s){let l=o[s],r=l.textureScale,d=Math.ceil(n*r),m=Math.ceil(i*r),h=Math.min(d,m);l.forcePowerOfTwo&&(k.isPowerOfTwo(h)||(h=k.nextPowerOfTwo(h)),d=h,m=h),l.buffer.update(e,d,m),l.clear=new ao({color:l.clearColor,framebuffer:l.buffer.framebuffer})}}UW.prototype.updateDependencies=function(){this._updateDependencies=!0};UW.prototype.update=function(t){let e=this._collection,n=this._updateDependencies,i=c(e.ambientOcclusion)&&e.ambientOcclusion.enabled&&e.ambientOcclusion._isSupported(t),o=c(e.bloom)&&e.bloom.enabled&&e.bloom._isSupported(t),a=c(e._tonemapping)&&e._tonemapping.enabled&&e._tonemapping._isSupported(t),s=c(e.fxaa)&&e.fxaa.enabled&&e.fxaa._isSupported(t),l=!c(e._activeStages)||e._activeStages.length>0||i||o||a||s;if((n||!l&&this._framebuffers.length>0)&&(Bat(this),this._framebuffers.length=0,this._stageNameToFramebuffer={},this._width=void 0,this._height=void 0),!n&&!l)return;this._framebuffers.length===0&&$Qe(this,t);let r=t.drawingBufferWidth,d=t.drawingBufferHeight,m=this._width!==r||this._height!==d;!n&&!m||(this._width=r,this._height=d,this._updateDependencies=!1,Bat(this),t2e(this,t))};UW.prototype.clear=function(t){let e=this._framebuffers;for(let n=0;n<e.length;++n)e[n].clear.execute(t)};UW.prototype.getStageByName=function(t){return this._collection.getStageByName(t)};UW.prototype.getOutputTexture=function(t){return this._collection.getOutputTexture(t)};UW.prototype.getFramebuffer=function(t){let e=this._stageNameToFramebuffer[t];if(c(e))return e.buffer.framebuffer};UW.prototype.isDestroyed=function(){return!1};UW.prototype.destroy=function(){return Bat(this),At(this)};var ES=UW;var bQo=R(W(),1),F9={REINHARD:0,MODIFIED_REINHARD:1,FILMIC:2,ACES:3,validate:function(t){return t===F9.REINHARD||t===F9.MODIFIED_REINHARD||t===F9.FILMIC||t===F9.ACES}},FU=Object.freeze(F9);var Qat=[];function im(){let t=Iu.createFXAAStage(),e=Iu.createAmbientOcclusionStage(),n=Iu.createBloomStage();this._autoExposureEnabled=!1,this._autoExposure=Iu.createAutoExposureStage(),this._tonemapping=void 0,this._tonemapper=void 0,this.tonemapper=FU.ACES;let i=this._tonemapping;t.enabled=!1,e.enabled=!1,n.enabled=!1,i.enabled=!1;let o=new ES(this),a={},s=Qat;for(s.push(t,e,n,i);s.length>0;){let r=s.pop();a[r.name]=r,r._textureCache=o;let d=r.length;if(c(d))for(let m=0;m<d;++m)s.push(r.get(m))}this._stages=[],this._activeStages=[],this._previousActiveStages=[],this._randomTexture=void 0;let l=this;e.uniforms.randomTexture=function(){return l._randomTexture},this._ao=e,this._bloom=n,this._fxaa=t,this._aoEnabled=void 0,this._bloomEnabled=void 0,this._tonemappingEnabled=void 0,this._fxaaEnabled=void 0,this._activeStagesChanged=!1,this._stagesRemoved=!1,this._textureCacheDirty=!1,this._stageNames=a,this._textureCache=o}Object.defineProperties(im.prototype,{ready:{get:function(){let t=!1,e=this._stages,n=e.length;for(let l=n-1;l>=0;--l){let r=e[l];t=t||r.ready&&r.enabled}let i=this._fxaa,o=this._ao,a=this._bloom,s=this._tonemapping;return t=t||i.ready&&i.enabled,t=t||o.ready&&o.enabled,t=t||a.ready&&a.enabled,t=t||s.ready&&s.enabled,t}},fxaa:{get:function(){return this._fxaa}},ambientOcclusion:{get:function(){return this._ao}},bloom:{get:function(){return this._bloom}},length:{get:function(){return kat(this),this._stages.length}},outputTexture:{get:function(){let t=this._fxaa;if(t.enabled&&t.ready)return this.getOutputTexture(t.name);let e=this._stages,n=e.length;for(let s=n-1;s>=0;--s){let l=e[s];if(c(l)&&l.ready&&l.enabled)return this.getOutputTexture(l.name)}let i=this._tonemapping;if(i.enabled&&i.ready)return this.getOutputTexture(i.name);let o=this._bloom;if(o.enabled&&o.ready)return this.getOutputTexture(o.name);let a=this._ao;if(a.enabled&&a.ready)return this.getOutputTexture(a.name)}},hasSelected:{get:function(){let t=this._stages.slice();for(;t.length>0;){let e=t.pop();if(!c(e))continue;if(c(e.selected))return!0;let n=e.length;if(c(n))for(let i=0;i<n;++i)t.push(e.get(i))}return!1}},tonemapper:{get:function(){return this._tonemapper},set:function(t){if(this._tonemapper===t)return;c(this._tonemapping)&&(delete this._stageNames[this._tonemapping.name],this._tonemapping.destroy());let e=this._autoExposureEnabled,n;switch(t){case FU.REINHARD:n=Iu.createReinhardTonemappingStage(e);break;case FU.MODIFIED_REINHARD:n=Iu.createModifiedReinhardTonemappingStage(e);break;case FU.FILMIC:n=Iu.createFilmicTonemappingStage(e);break;default:n=Iu.createAcesTonemappingStage(e);break}if(e){let i=this._autoExposure;n.uniforms.autoExposure=function(){return i.outputTexture}}this._tonemapper=t,this._tonemapping=n,c(this._stageNames)&&(this._stageNames[n.name]=n,n._textureCache=this._textureCache),this._textureCacheDirty=!0}}});function kat(t){if(!t._stagesRemoved)return;t._stagesRemoved=!1;let e=[],n=t._stages,i=n.length;for(let o=0,a=0;o<i;++o){let s=n[o];s&&(s._index=a++,e.push(s))}t._stages=e}im.prototype.add=function(t){let e=this._stageNames,n=Qat;for(n.push(t);n.length>0;){let o=n.pop();e[o.name]=o,o._textureCache=this._textureCache;let a=o.length;if(c(a))for(let s=0;s<a;++s)n.push(o.get(s))}let i=this._stages;return t._index=i.length,i.push(t),this._textureCacheDirty=!0,t};im.prototype.remove=function(t){if(!this.contains(t))return!1;let e=this._stageNames,n=Qat;for(n.push(t);n.length>0;){let i=n.pop();delete e[i.name];let o=i.length;if(c(o))for(let a=0;a<o;++a)n.push(i.get(a))}return this._stages[t._index]=void 0,this._stagesRemoved=!0,this._textureCacheDirty=!0,t._index=void 0,t._textureCache=void 0,t.destroy(),!0};im.prototype.contains=function(t){return c(t)&&c(t._index)&&t._textureCache===this._textureCache};im.prototype.get=function(t){return kat(this),this._stages[t]};im.prototype.removeAll=function(){let t=this._stages,e=t.length;for(let n=0;n<e;++n)this.remove(t[n]);t.length=0};im.prototype.getStageByName=function(t){return this._stageNames[t]};im.prototype.update=function(t,e,n){kat(this);let i=this._activeStages,o=this._activeStages=this._previousActiveStages;this._previousActiveStages=i;let a=this._stages,s=o.length=a.length,l,r,d=0;for(l=0;l<s;++l)r=a[l],r.ready&&r.enabled&&r._isSupported(t)&&(o[d++]=r);o.length=d;let m=d!==i.length;if(!m){for(l=0;l<d;++l)if(o[l]!==i[l]){m=!0;break}}let h=this._ao,Z=this._bloom,b=this._autoExposure,u=this._tonemapping,F=this._fxaa;u.enabled=n;let U=h.enabled&&h._isSupported(t),G=Z.enabled&&Z._isSupported(t),A=u.enabled&&u._isSupported(t),T=F.enabled&&F._isSupported(t);if((m||this._textureCacheDirty||U!==this._aoEnabled||G!==this._bloomEnabled||A!==this._tonemappingEnabled||T!==this._fxaaEnabled)&&(this._textureCache.updateDependencies(),this._aoEnabled=U,this._bloomEnabled=G,this._tonemappingEnabled=A,this._fxaaEnabled=T,this._textureCacheDirty=!1),c(this._randomTexture)&&!U&&(this._randomTexture.destroy(),this._randomTexture=void 0),!c(this._randomTexture)&&U){s=256*256*3;let g=new Uint8Array(s);for(l=0;l<s;l+=3)g[l]=Math.floor(Math.random()*255);this._randomTexture=new hn({context:t,pixelFormat:Ye.RGB,pixelDatatype:Ue.UNSIGNED_BYTE,source:{arrayBufferView:g,width:256,height:256},sampler:new Hn({wrapS:Vi.REPEAT,wrapT:Vi.REPEAT,minificationFilter:On.NEAREST,magnificationFilter:bo.NEAREST})})}for(this._textureCache.update(t),F.update(t,e),h.update(t,e),Z.update(t,e),u.update(t,e),this._autoExposureEnabled&&b.update(t,e),s=a.length,l=0;l<s;++l)a[l].update(t,e);for(d=0,l=0;l<s;++l)r=a[l],r.ready&&r.enabled&&r._isSupported(t)&&d++;m=d!==o.length,m&&this.update(t,e,n)};im.prototype.clear=function(t){this._textureCache.clear(t),this._autoExposureEnabled&&this._autoExposure.clear(t)};function CS(t){for(;c(t.length);)t=t.get(t.length-1);return t.outputTexture}im.prototype.getOutputTexture=function(t){let e=this.getStageByName(t);if(c(e))return CS(e)};function wb(t,e,n,i,o){if(c(t.execute)){t.execute(e,n,i,o);return}let a=t.length,s;if(t.inputPreviousStageTexture)for(wb(t.get(0),e,n,i,o),s=1;s<a;++s)wb(t.get(s),e,CS(t.get(s-1)),i,o);else for(s=0;s<a;++s)wb(t.get(s),e,n,i,o)}im.prototype.execute=function(t,e,n,i){let o=this._activeStages,a=o.length,s=this._fxaa,l=this._ao,r=this._bloom,d=this._autoExposure,m=this._tonemapping,h=l.enabled&&l._isSupported(t),Z=r.enabled&&r._isSupported(t),b=this._autoExposureEnabled,u=m.enabled&&m._isSupported(t),F=s.enabled&&s._isSupported(t);if(!F&&!h&&!Z&&!u&&a===0)return;let U=e;h&&l.ready&&(wb(l,t,U,n,i),U=CS(l)),Z&&r.ready&&(wb(r,t,U,n,i),U=CS(r)),b&&d.ready&&wb(d,t,U,n,i),u&&m.ready&&(wb(m,t,U,n,i),U=CS(m));let G=U;if(a>0){wb(o[0],t,U,n,i);for(let A=1;A<a;++A)wb(o[A],t,CS(o[A-1]),n,i);G=CS(o[a-1])}F&&s.ready&&wb(s,t,G,n,i)};im.prototype.copy=function(t,e){if(!c(this._copyColorCommand)){let n=this;this._copyColorCommand=t.createViewportQuadCommand(nh,{uniformMap:{colorTexture:function(){return n.outputTexture}},owner:this})}this._copyColorCommand.framebuffer=e,this._copyColorCommand.execute(t)};im.prototype.isDestroyed=function(){return!1};im.prototype.destroy=function(){return this._fxaa.destroy(),this._ao.destroy(),this._bloom.destroy(),this._autoExposure.destroy(),this._tonemapping.destroy(),this.removeAll(),this._textureCache=this._textureCache&&this._textureCache.destroy(),At(this)};var U9=im;var m2o=R(W(),1);var PQo=R(W(),1);var QQo=R(W(),1),e2e={SHIFT:0,CTRL:1,ALT:2},id=Object.freeze(e2e);var YQo=R(W(),1),n2e={LEFT_DOWN:0,LEFT_UP:1,LEFT_CLICK:2,LEFT_DOUBLE_CLICK:3,RIGHT_DOWN:5,RIGHT_UP:6,RIGHT_CLICK:7,MIDDLE_DOWN:10,MIDDLE_UP:11,MIDDLE_CLICK:12,MOUSE_MOVE:15,WHEEL:16,PINCH_START:17,PINCH_END:18,PINCH_MOVE:19},Zi=Object.freeze(n2e);function UU(t,e,n){let i=t._element;if(i===document)return n.x=e.clientX,n.y=e.clientY,n;let o=i.getBoundingClientRect();return n.x=e.clientX-o.left,n.y=e.clientY-o.top,n}function Mat(t,e){let n=t;return c(e)&&(n+=`+${e}`),n}function IS(t){if(t.shiftKey)return id.SHIFT;if(t.ctrlKey)return id.CTRL;if(t.altKey)return id.ALT}var cr={LEFT:0,MIDDLE:1,RIGHT:2};function ap(t,e,n,i){function o(a){i(t,a)}In.isInternetExplorer()?n.addEventListener(e,o,!1):n.addEventListener(e,o,{capture:!1,passive:!1}),t._removalFunctions.push(function(){n.removeEventListener(e,o,!1)})}function i2e(t){let e=t._element,n=c(e.disableRootEvents)?e:document;In.supportsPointerEvents()?(ap(t,"pointerdown",e,d2e),ap(t,"pointerup",e,bBt),ap(t,"pointermove",e,c2e),ap(t,"pointercancel",e,bBt)):(ap(t,"mousedown",e,RBt),ap(t,"mouseup",n,WBt),ap(t,"mousemove",n,fBt),ap(t,"touchstart",e,l2e),ap(t,"touchend",n,hBt),ap(t,"touchmove",n,r2e),ap(t,"touchcancel",n,hBt)),ap(t,"dblclick",e,a2e);let i;"onwheel"in e?i="wheel":document.onmousewheel!==void 0?i="mousewheel":i="DOMMouseScroll",ap(t,i,e,s2e)}function o2e(t){let e=t._removalFunctions;for(let n=0;n<e.length;++n)e[n]()}var rBt={position:new K};function _at(t){t._lastSeenTouchEvent=Oi()}function Dat(t){return Oi()-t._lastSeenTouchEvent>cV.mouseEmulationIgnoreMilliseconds}function Lat(t,e,n){let i=t.x-e.x,o=t.y-e.y;return Math.sqrt(i*i+o*o)<n}function RBt(t,e){if(!Dat(t))return;let n=e.button;t._buttonDown[n]=!0;let i;if(n===cr.LEFT)i=Zi.LEFT_DOWN;else if(n===cr.MIDDLE)i=Zi.MIDDLE_DOWN;else if(n===cr.RIGHT)i=Zi.RIGHT_DOWN;else return;let o=UU(t,e,t._primaryPosition);K.clone(o,t._primaryStartPosition),K.clone(o,t._primaryPreviousPosition);let a=IS(e),s=t.getInputAction(i,a);c(s)&&(K.clone(o,rBt.position),s(rBt),e.preventDefault())}var dBt={position:new K},cBt={position:new K};function Yat(t,e,n,i){let o=IS(i),a=t.getInputAction(e,o),s=t.getInputAction(n,o);if(c(a)||c(s)){let l=UU(t,i,t._primaryPosition);if(c(a)&&(K.clone(l,dBt.position),a(dBt)),c(s)){let r=t._primaryStartPosition;Lat(r,l,t._clickPixelTolerance)&&(K.clone(l,cBt.position),s(cBt))}}}function WBt(t,e){if(!Dat(t))return;let n=e.button;n!==cr.LEFT&&n!==cr.MIDDLE&&n!==cr.RIGHT||(t._buttonDown[cr.LEFT]&&(Yat(t,Zi.LEFT_UP,Zi.LEFT_CLICK,e),t._buttonDown[cr.LEFT]=!1),t._buttonDown[cr.MIDDLE]&&(Yat(t,Zi.MIDDLE_UP,Zi.MIDDLE_CLICK,e),t._buttonDown[cr.MIDDLE]=!1),t._buttonDown[cr.RIGHT]&&(Yat(t,Zi.RIGHT_UP,Zi.RIGHT_CLICK,e),t._buttonDown[cr.RIGHT]=!1))}var xat={startPosition:new K,endPosition:new K};function fBt(t,e){if(!Dat(t))return;let n=IS(e),i=UU(t,e,t._primaryPosition),o=t._primaryPreviousPosition,a=t.getInputAction(Zi.MOUSE_MOVE,n);c(a)&&(K.clone(o,xat.startPosition),K.clone(i,xat.endPosition),a(xat)),K.clone(i,o),(t._buttonDown[cr.LEFT]||t._buttonDown[cr.MIDDLE]||t._buttonDown[cr.RIGHT])&&e.preventDefault()}var mBt={position:new K};function a2e(t,e){let n=e.button,i;if(n===cr.LEFT)i=Zi.LEFT_DOUBLE_CLICK;else return;let o=IS(e),a=t.getInputAction(i,o);c(a)&&(UU(t,e,mBt.position),a(mBt))}function s2e(t,e){let n;if(c(e.deltaY)){let a=e.deltaMode;a===e.DOM_DELTA_PIXEL?n=-e.deltaY:a===e.DOM_DELTA_LINE?n=-e.deltaY*40:n=-e.deltaY*120}else e.detail>0?n=e.detail*-120:n=e.wheelDelta;if(!c(n))return;let i=IS(e),o=t.getInputAction(Zi.WHEEL,i);c(o)&&(o(n),e.preventDefault())}function l2e(t,e){_at(t);let n=e.changedTouches,i,o=n.length,a,s,l=t._positions;for(i=0;i<o;++i)a=n[i],s=a.identifier,l.set(s,UU(t,a,new K));uj(t,e);let r=t._previousPositions;for(i=0;i<o;++i)a=n[i],s=a.identifier,r.set(s,K.clone(l.get(s)))}function hBt(t,e){_at(t);let n=e.changedTouches,i,o=n.length,a,s,l=t._positions;for(i=0;i<o;++i)a=n[i],s=a.identifier,l.remove(s);uj(t,e);let r=t._previousPositions;for(i=0;i<o;++i)a=n[i],s=a.identifier,r.remove(s)}var pBt={position:new K},Xat={position1:new K,position2:new K},uBt={position:new K},ZBt={position:new K},VBt={position:new K};function uj(t,e){let n=IS(e),i=t._positions,o=i.length,a,s,l=t._isPinching;if(o!==1&&t._buttonDown[cr.LEFT]){if(t._buttonDown[cr.LEFT]=!1,c(t._touchHoldTimer)&&(clearTimeout(t._touchHoldTimer),t._touchHoldTimer=void 0),a=t.getInputAction(Zi.LEFT_UP,n),c(a)&&(K.clone(t._primaryPosition,uBt.position),a(uBt)),o===0&&!t._isTouchHolding&&(s=t.getInputAction(Zi.LEFT_CLICK,n),c(s))){let r=t._primaryStartPosition,d=t._previousPositions.values[0];Lat(r,d,t._clickPixelTolerance)&&(K.clone(t._primaryPosition,ZBt.position),s(ZBt))}t._isTouchHolding=!1}if(o===0&&l&&(t._isPinching=!1,a=t.getInputAction(Zi.PINCH_END,n),c(a)&&a()),o===1&&!l){let r=i.values[0];K.clone(r,t._primaryPosition),K.clone(r,t._primaryStartPosition),K.clone(r,t._primaryPreviousPosition),t._buttonDown[cr.LEFT]=!0,a=t.getInputAction(Zi.LEFT_DOWN,n),c(a)&&(K.clone(r,pBt.position),a(pBt)),t._touchHoldTimer=setTimeout(function(){if(!t.isDestroyed()&&(t._touchHoldTimer=void 0,t._isTouchHolding=!0,s=t.getInputAction(Zi.RIGHT_CLICK,n),c(s))){let d=t._primaryStartPosition,m=t._previousPositions.values[0];Lat(d,m,t._holdPixelTolerance)&&(K.clone(t._primaryPosition,VBt.position),s(VBt))}},cV.touchHoldDelayMilliseconds),e.preventDefault()}o===2&&!l&&(t._isPinching=!0,a=t.getInputAction(Zi.PINCH_START,n),c(a)&&(K.clone(i.values[0],Xat.position1),K.clone(i.values[1],Xat.position2),a(Xat),e.preventDefault()))}function r2e(t,e){_at(t);let n=e.changedTouches,i,o=n.length,a,s,l=t._positions;for(i=0;i<o;++i){a=n[i],s=a.identifier;let d=l.get(s);c(d)&&UU(t,a,d)}FBt(t,e);let r=t._previousPositions;for(i=0;i<o;++i)a=n[i],s=a.identifier,K.clone(l.get(s),r.get(s))}var Jat={startPosition:new K,endPosition:new K},G9={distance:{startPosition:new K,endPosition:new K},angleAndHeight:{startPosition:new K,endPosition:new K}};function FBt(t,e){let n=IS(e),i=t._positions,o=t._previousPositions,a=i.length,s;if(a===1&&t._buttonDown[cr.LEFT]){let l=i.values[0];K.clone(l,t._primaryPosition);let r=t._primaryPreviousPosition;s=t.getInputAction(Zi.MOUSE_MOVE,n),c(s)&&(K.clone(r,Jat.startPosition),K.clone(l,Jat.endPosition),s(Jat)),K.clone(l,r),e.preventDefault()}else if(a===2&&t._isPinching&&(s=t.getInputAction(Zi.PINCH_MOVE,n),c(s))){let l=i.values[0],r=i.values[1],d=o.values[0],m=o.values[1],h=r.x-l.x,Z=r.y-l.y,b=Math.sqrt(h*h+Z*Z)*.25,u=m.x-d.x,F=m.y-d.y,U=Math.sqrt(u*u+F*F)*.25,G=(r.y+l.y)*.125,A=(m.y+d.y)*.125,T=Math.atan2(Z,h),g=Math.atan2(F,u);K.fromElements(0,U,G9.distance.startPosition),K.fromElements(0,b,G9.distance.endPosition),K.fromElements(g,A,G9.angleAndHeight.startPosition),K.fromElements(T,G,G9.angleAndHeight.endPosition),s(G9)}}function d2e(t,e){if(e.target.setPointerCapture(e.pointerId),e.pointerType==="touch"){let n=t._positions,i=e.pointerId;n.set(i,UU(t,e,new K)),uj(t,e),t._previousPositions.set(i,K.clone(n.get(i)))}else RBt(t,e)}function bBt(t,e){if(e.pointerType==="touch"){let n=t._positions,i=e.pointerId;n.remove(i),uj(t,e),t._previousPositions.remove(i)}else WBt(t,e)}function c2e(t,e){if(e.pointerType==="touch"){let n=t._positions,i=e.pointerId,o=n.get(i);if(!c(o))return;UU(t,e,o),FBt(t,e);let a=t._previousPositions;K.clone(n.get(i),a.get(i))}else fBt(t,e)}function cV(t){this._inputEvents={},this._buttonDown={LEFT:!1,MIDDLE:!1,RIGHT:!1},this._isPinching=!1,this._isTouchHolding=!1,this._lastSeenTouchEvent=-cV.mouseEmulationIgnoreMilliseconds,this._primaryStartPosition=new K,this._primaryPosition=new K,this._primaryPreviousPosition=new K,this._positions=new qe,this._previousPositions=new qe,this._removalFunctions=[],this._touchHoldTimer=void 0,this._clickPixelTolerance=5,this._holdPixelTolerance=25,this._element=f(t,document),i2e(this)}cV.prototype.setInputAction=function(t,e,n){let i=Mat(e,n);this._inputEvents[i]=t};cV.prototype.getInputAction=function(t,e){let n=Mat(t,e);return this._inputEvents[n]};cV.prototype.removeInputAction=function(t,e){let n=Mat(t,e);delete this._inputEvents[n]};cV.prototype.isDestroyed=function(){return!1};cV.prototype.destroy=function(){return o2e(this),At(this)};cV.mouseEmulationIgnoreMilliseconds=800;cV.touchHoldDelayMilliseconds=1500;var sp=cV;function NS(t){this._scene=t,this._currentTweens=[],this._morphHandler=void 0,this._morphCancelled=!1,this._completeMorph=void 0,this._morphToOrthographic=!1}NS.prototype.completeMorph=function(){c(this._completeMorph)&&this._completeMorph()};NS.prototype.morphTo2D=function(t,e){c(this._completeMorph)&&this._completeMorph();let n=this._scene;this._previousMode=n.mode,this._morphToOrthographic=n.camera.frustum instanceof wn,!(this._previousMode===ut.SCENE2D||this._previousMode===ut.MORPHING)&&(this._scene.morphStart.raiseEvent(this,this._previousMode,ut.SCENE2D,!0),n._mode=ut.MORPHING,n.camera._setTransform(L.IDENTITY),this._previousMode===ut.COLUMBUS_VIEW?D2e(this,t):z2e(this,t,e),t===0&&c(this._completeMorph)&&this._completeMorph())};var m2e=new p,h2e=new p,p2e=new p,u2e=new p,Z2e=new p,V2e=new p,b2e=new p,R2e=new gt,W2e=new L,f2e=new Io,F2e=new wn,U2e={position:void 0,direction:void 0,up:void 0,position2D:void 0,direction2D:void 0,up2D:void 0,frustum:void 0};NS.prototype.morphToColumbusView=function(t,e){c(this._completeMorph)&&this._completeMorph();let n=this._scene;if(this._previousMode=n.mode,this._previousMode===ut.COLUMBUS_VIEW||this._previousMode===ut.MORPHING)return;this._scene.morphStart.raiseEvent(this,this._previousMode,ut.COLUMBUS_VIEW,!0),n.camera._setTransform(L.IDENTITY);let i=m2e,o=h2e,a=p2e;if(t>0)i.x=0,i.y=-1,i.z=1,i=p.multiplyByScalar(p.normalize(i,i),5*e.maximumRadius,i),p.negate(p.normalize(i,o),o),p.cross(p.UNIT_X,o,a);else{let d=n.camera;if(this._previousMode===ut.SCENE2D)p.clone(d.position,i),i.z=d.frustum.right-d.frustum.left,p.negate(p.UNIT_Z,o),p.clone(p.UNIT_Y,a);else{p.clone(d.positionWC,i),p.clone(d.directionWC,o),p.clone(d.upWC,a);let m=e.scaleToGeodeticSurface(i,b2e),h=Pe.eastNorthUpToFixedFrame(m,e,W2e);L.inverseTransformation(h,h),n.mapProjection.project(e.cartesianToCartographic(i,R2e),i),L.multiplyByPointAsVector(h,o,o),L.multiplyByPointAsVector(h,a,a)}}let s;this._morphToOrthographic?(s=F2e,s.width=n.camera.frustum.right-n.camera.frustum.left,s.aspectRatio=n.drawingBufferWidth/n.drawingBufferHeight):(s=f2e,s.aspectRatio=n.drawingBufferWidth/n.drawingBufferHeight,s.fov=k.toRadians(60));let l=U2e;l.position=i,l.direction=o,l.up=a,l.frustum=s;let r=q2e(l);A9(this,r),this._previousMode===ut.SCENE2D?j2e(this,t,l,r):(l.position2D=L.multiplyByPoint(Aa.TRANSFORM_2D,i,u2e),l.direction2D=L.multiplyByPointAsVector(Aa.TRANSFORM_2D,o,Z2e),l.up2D=L.multiplyByPointAsVector(Aa.TRANSFORM_2D,a,V2e),n._mode=ut.MORPHING,yBt(this,t,l,r)),t===0&&c(this._completeMorph)&&this._completeMorph()};var wat={position:new p,direction:new p,up:new p,frustum:void 0},GBt=new Io;NS.prototype.morphTo3D=function(t,e){c(this._completeMorph)&&this._completeMorph();let n=this._scene;if(this._previousMode=n.mode,!(this._previousMode===ut.SCENE3D||this._previousMode===ut.MORPHING)){if(this._scene.morphStart.raiseEvent(this,this._previousMode,ut.SCENE3D,!0),n._mode=ut.MORPHING,n.camera._setTransform(L.IDENTITY),this._previousMode===ut.SCENE2D)B2e(this,t,e);else{let i;t>0?(i=wat,p.fromDegrees(0,0,5*e.maximumRadius,e,i.position),p.negate(i.position,i.direction),p.normalize(i.direction,i.direction),p.clone(p.UNIT_Z,i.up)):i=ABt(this,e);let o,a=n.camera;a.frustum instanceof wn?o=a.frustum.clone():(o=GBt,o.aspectRatio=n.drawingBufferWidth/n.drawingBufferHeight,o.fov=k.toRadians(60)),i.frustum=o;let s=QBt(i);A9(this,s),Hat(this,t,i,s)}t===0&&c(this._completeMorph)&&this._completeMorph()}};NS.prototype.isDestroyed=function(){return!1};NS.prototype.destroy=function(){return Zj(this),At(this)};function A9(t,e){if(t._scene.completeMorphOnUserInput){t._morphHandler=new sp(t._scene.canvas);let n=function(){t._morphCancelled=!0,t._scene.camera.cancelFlight(),e(t)};t._completeMorph=n,t._morphHandler.setInputAction(n,Zi.LEFT_DOWN),t._morphHandler.setInputAction(n,Zi.MIDDLE_DOWN),t._morphHandler.setInputAction(n,Zi.RIGHT_DOWN),t._morphHandler.setInputAction(n,Zi.WHEEL)}}function Zj(t){let e=t._currentTweens;for(let n=0;n<e.length;++n)e[n].cancelTween();t._currentTweens.length=0,t._morphHandler=t._morphHandler&&t._morphHandler.destroy()}var G2e=new gt,A2e=new p,T2e=new L;function ABt(t,e){let n=t._scene,i=n.camera,o=wat,a=o.position,s=o.direction,l=o.up,r=n.mapProjection.unproject(i.position,G2e);e.cartographicToCartesian(r,a);let d=e.scaleToGeodeticSurface(a,A2e),m=Pe.eastNorthUpToFixedFrame(d,e,T2e);return L.multiplyByPointAsVector(m,i.direction,s),L.multiplyByPointAsVector(m,i.up,l),o}var S2e=new p,g2e=new p,E2e=new p,C2e=new p,I2e=new p,N2e=new p;function Hat(t,e,n,i){e*=.5;let o=t._scene,a=o.camera,s=p.clone(a.position,S2e),l=p.clone(a.direction,g2e),r=p.clone(a.up,E2e),d=L.multiplyByPoint(Aa.TRANSFORM_2D_INVERSE,n.position,C2e),m=L.multiplyByPointAsVector(Aa.TRANSFORM_2D_INVERSE,n.direction,I2e),h=L.multiplyByPointAsVector(Aa.TRANSFORM_2D_INVERSE,n.up,N2e);function Z(u){Nu(s,d,u.time,a.position),Nu(l,m,u.time,a.direction),Nu(r,h,u.time,a.up),p.cross(a.direction,a.up,a.right),p.normalize(a.right,a.right)}let b=o.tweens.add({duration:e,easingFunction:Zl.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:Z,complete:function(){BBt(t,o,0,1,e,i)}});t._currentTweens.push(b)}var y2e=new wn,TBt=new p,SBt=new p,gBt=new p,Pat=new p,EBt=new p,CBt=new p;function B2e(t,e,n){e/=3;let i=t._scene,o=i.camera,a;e>0?(a=wat,p.fromDegrees(0,0,5*n.maximumRadius,n,a.position),p.negate(a.position,a.direction),p.normalize(a.direction,a.direction),p.clone(p.UNIT_Z,a.up)):(o.position.z=o.frustum.right-o.frustum.left,a=ABt(t,n));let s;t._morphToOrthographic?(s=y2e,s.aspectRatio=i.drawingBufferWidth/i.drawingBufferHeight,s.width=o.frustum.right-o.frustum.left):(s=GBt,s.aspectRatio=i.drawingBufferWidth/i.drawingBufferHeight,s.fov=k.toRadians(60)),a.frustum=s;let l=QBt(a);A9(t,l);let r;t._morphToOrthographic?r=function(){Hat(t,e,a,l)}:r=function(){NBt(t,e,a,function(){Hat(t,e,a,l)})},e>0?(i._mode=ut.SCENE2D,o.flyTo({duration:e,destination:p.fromDegrees(0,0,5*n.maximumRadius,n,Pat),complete:function(){i._mode=ut.MORPHING,r()}})):r()}function Nu(t,e,n,i){return p.lerp(t,e,n,i)}function IBt(t,e,n,i,o){let a=t._scene,s=a.camera;if(s.frustum instanceof wn)return;let l=s.frustum.fov,r=k.RADIANS_PER_DEGREE*.5,d=n.position.z*Math.tan(l*.5);s.frustum.far=d/Math.tan(r*.5)+1e7;function m(Z){s.frustum.fov=k.lerp(l,r,Z.time);let b=d/Math.tan(s.frustum.fov*.5);i(s,b)}let h=a.tweens.add({duration:e,easingFunction:Zl.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:m,complete:function(){s.frustum=n.frustum.clone(),o(t)}});t._currentTweens.push(h)}var Q2e=new p,k2e=new p,Y2e=new p,Oat=new p,x2e=new p,X2e=new p,J2e=new el,L2e=new di,M2e=new p,_2e={position:void 0,direction:void 0,up:void 0,frustum:void 0};function D2e(t,e){e*=.5;let n=t._scene,i=n.camera,o=p.clone(i.position,Q2e),a=p.clone(i.direction,k2e),s=p.clone(i.up,Y2e),l=p.negate(p.UNIT_Z,x2e),r=p.clone(p.UNIT_Y,X2e),d=Oat;if(e>0)p.clone(p.ZERO,Oat),d.z=5*n.mapProjection.ellipsoid.maximumRadius;else{p.clone(o,Oat);let U=L2e;L.multiplyByPoint(Aa.TRANSFORM_2D,o,U.origin),L.multiplyByPointAsVector(Aa.TRANSFORM_2D,a,U.direction);let G=n.globe;if(c(G)){let A=G.pickWorldCoordinates(U,n,!0,M2e);c(A)&&(L.multiplyByPoint(Aa.TRANSFORM_2D_INVERSE,A,d),d.z+=p.distance(o,d))}}let m=J2e;m.right=d.z*.5,m.left=-m.right,m.top=m.right*(n.drawingBufferHeight/n.drawingBufferWidth),m.bottom=-m.top;let h=_2e;h.position=d,h.direction=l,h.up=r,h.frustum=m;let Z=kBt(h);A9(t,Z);function b(U){Nu(o,d,U.time,i.position),Nu(a,l,U.time,i.direction),Nu(s,r,U.time,i.up),p.cross(i.direction,i.up,i.right),p.normalize(i.right,i.right),i._adjustOrthographicFrustum(!0)}function u(U,G){U.position.z=G}let F=n.tweens.add({duration:e,easingFunction:Zl.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:b,complete:function(){IBt(t,e,h,u,Z)}});t._currentTweens.push(F)}var UBt=new gt,O2e={position:new p,direction:new p,up:new p,position2D:new p,direction2D:new p,up2D:new p,frustum:new el},H2e={position:new p,direction:new p,up:new p,frustum:void 0},w2e=new p,P2e=new di,v2e=new L,K2e=new p;function z2e(t,e,n){e*=.5;let i=t._scene,o=i.camera,a=O2e;if(e>0)p.clone(p.ZERO,a.position),a.position.z=5*n.maximumRadius,p.negate(p.UNIT_Z,a.direction),p.clone(p.UNIT_Y,a.up);else{n.cartesianToCartographic(o.positionWC,UBt),i.mapProjection.project(UBt,a.position),p.negate(p.UNIT_Z,a.direction),p.clone(p.UNIT_Y,a.up);let h=P2e;p.clone(a.position2D,h.origin);let Z=p.clone(o.directionWC,h.direction),b=n.scaleToGeodeticSurface(o.positionWC,K2e),u=Pe.eastNorthUpToFixedFrame(b,n,v2e);L.inverseTransformation(u,u),L.multiplyByPointAsVector(u,Z,Z),L.multiplyByPointAsVector(Aa.TRANSFORM_2D,Z,Z);let F=i.globe;if(c(F)){let U=F.pickWorldCoordinates(h,i,!0,w2e);if(c(U)){let G=p.distance(a.position2D,U);U.x+=G,p.clone(U,a.position2D)}}}function s(h,Z){h.position.x=Z}L.multiplyByPoint(Aa.TRANSFORM_2D,a.position,a.position2D),L.multiplyByPointAsVector(Aa.TRANSFORM_2D,a.direction,a.direction2D),L.multiplyByPointAsVector(Aa.TRANSFORM_2D,a.up,a.up2D);let l=a.frustum;l.right=a.position.z*.5,l.left=-l.right,l.top=l.right*(i.drawingBufferHeight/i.drawingBufferWidth),l.bottom=-l.top;let r=H2e;L.multiplyByPoint(Aa.TRANSFORM_2D_INVERSE,a.position2D,r.position),p.clone(a.direction,r.direction),p.clone(a.up,r.up),r.frustum=l;let d=kBt(r);A9(t,d);function m(){IBt(t,e,a,s,d)}yBt(t,e,a,m)}function NBt(t,e,n,i){let o=t._scene,a=o.camera,s=a.frustum.right-a.frustum.left;a.frustum=n.frustum.clone();let l=a.frustum.fov,r=k.RADIANS_PER_DEGREE*.5,d=s*Math.tan(l*.5);a.frustum.far=d/Math.tan(r*.5)+1e7,a.frustum.fov=r;function m(Z){a.frustum.fov=k.lerp(r,l,Z.time),a.position.z=d/Math.tan(a.frustum.fov*.5)}let h=o.tweens.add({duration:e,easingFunction:Zl.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:m,complete:function(){i(t)}});t._currentTweens.push(h)}function j2e(t,e,n,i){e*=.5;let o=t._scene,a=o.camera,s=p.clone(n.position,Pat),l=p.clone(n.direction,EBt),r=p.clone(n.up,CBt);o._mode=ut.MORPHING;function d(){a.frustum=n.frustum.clone();let m=p.clone(a.position,TBt),h=p.clone(a.direction,SBt),Z=p.clone(a.up,gBt);m.z=s.z;function b(F){Nu(m,s,F.time,a.position),Nu(h,l,F.time,a.direction),Nu(Z,r,F.time,a.up),p.cross(a.direction,a.up,a.right),p.normalize(a.right,a.right)}let u=o.tweens.add({duration:e,easingFunction:Zl.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:b,complete:function(){i(t)}});t._currentTweens.push(u)}t._morphToOrthographic?d():NBt(t,0,n,d)}function yBt(t,e,n,i){let o=t._scene,a=o.camera,s=p.clone(a.position,TBt),l=p.clone(a.direction,SBt),r=p.clone(a.up,gBt),d=p.clone(n.position2D,Pat),m=p.clone(n.direction2D,EBt),h=p.clone(n.up2D,CBt);function Z(u){Nu(s,d,u.time,a.position),Nu(l,m,u.time,a.direction),Nu(r,h,u.time,a.up),p.cross(a.direction,a.up,a.right),p.normalize(a.right,a.right),a._adjustOrthographicFrustum(!0)}let b=o.tweens.add({duration:e,easingFunction:Zl.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:Z,complete:function(){BBt(t,o,1,0,e,i)}});t._currentTweens.push(b)}function BBt(t,e,n,i,o,a){let s={object:e,property:"morphTime",startValue:n,stopValue:i,duration:o,easingFunction:Zl.QUARTIC_OUT};c(a)&&(s.complete=function(){a(t)});let l=e.tweens.addProperty(s);t._currentTweens.push(l)}function QBt(t){return function(e){let n=e._scene;n._mode=ut.SCENE3D,n.morphTime=ut.getMorphTime(ut.SCENE3D),Zj(e);let i=n.camera;(e._previousMode!==ut.MORPHING||e._morphCancelled)&&(e._morphCancelled=!1,p.clone(t.position,i.position),p.clone(t.direction,i.direction),p.clone(t.up,i.up),p.cross(i.direction,i.up,i.right),p.normalize(i.right,i.right),i.frustum=t.frustum.clone());let o=i.frustum;n.frameState.useLogDepth&&(o.near=.1,o.far=1e10);let a=c(e._completeMorph);e._completeMorph=void 0,n.camera.update(n.mode),e._scene.morphComplete.raiseEvent(e,e._previousMode,ut.SCENE3D,a)}}function kBt(t){return function(e){let n=e._scene;n._mode=ut.SCENE2D,n.morphTime=ut.getMorphTime(ut.SCENE2D),Zj(e);let i=n.camera;p.clone(t.position,i.position),i.position.z=n.mapProjection.ellipsoid.maximumRadius*2,p.clone(t.direction,i.direction),p.clone(t.up,i.up),p.cross(i.direction,i.up,i.right),p.normalize(i.right,i.right),i.frustum=t.frustum.clone();let o=c(e._completeMorph);e._completeMorph=void 0,n.camera.update(n.mode),e._scene.morphComplete.raiseEvent(e,e._previousMode,ut.SCENE2D,o)}}function q2e(t){return function(e){let n=e._scene;n._mode=ut.COLUMBUS_VIEW,n.morphTime=ut.getMorphTime(ut.COLUMBUS_VIEW),Zj(e);let i=n.camera;(e._previousModeMode!==ut.MORPHING||e._morphCancelled)&&(e._morphCancelled=!1,p.clone(t.position,i.position),p.clone(t.direction,i.direction),p.clone(t.up,i.up),p.cross(i.direction,i.up,i.right),p.normalize(i.right,i.right));let o=i.frustum;n.frameState.useLogDepth&&(o.near=.1,o.far=1e10);let a=c(e._completeMorph);e._completeMorph=void 0,n.camera.update(n.mode),e._scene.morphComplete.raiseEvent(e,e._previousMode,ut.COLUMBUS_VIEW,a)}}var T9=NS;var sko=R(W(),1);var G2o=R(W(),1);var p2o=R(W(),1),$2e={LEFT_DRAG:0,RIGHT_DRAG:1,MIDDLE_DRAG:2,WHEEL:3,PINCH:4},Mo=Object.freeze($2e);function pc(t,e){let n=t;return c(e)&&(n+=`+${e}`),n}function tke(t,e){K.clone(t.distance.startPosition,e.distance.startPosition),K.clone(t.distance.endPosition,e.distance.endPosition),K.clone(t.angleAndHeight.startPosition,e.angleAndHeight.startPosition),K.clone(t.angleAndHeight.endPosition,e.angleAndHeight.endPosition)}function YBt(t,e,n){let i=pc(Mo.PINCH,e),o=t._update,a=t._isDown,s=t._eventStartPosition,l=t._pressTime,r=t._releaseTime;o[i]=!0,a[i]=!1,s[i]=new K;let d=t._movement[i];c(d)||(d=t._movement[i]={}),d.distance={startPosition:new K,endPosition:new K},d.angleAndHeight={startPosition:new K,endPosition:new K},d.prevAngle=0,t._eventHandler.setInputAction(function(m){t._buttonsDown++,a[i]=!0,l[i]=new Date,K.lerp(m.position1,m.position2,.5,s[i])},Zi.PINCH_START,e),t._eventHandler.setInputAction(function(){t._buttonsDown=Math.max(t._buttonsDown-1,0),a[i]=!1,r[i]=new Date},Zi.PINCH_END,e),t._eventHandler.setInputAction(function(m){if(a[i]){o[i]?(tke(m,d),o[i]=!1,d.prevAngle=d.angleAndHeight.startPosition.x):(K.clone(m.distance.endPosition,d.distance.endPosition),K.clone(m.angleAndHeight.endPosition,d.angleAndHeight.endPosition));let h=d.angleAndHeight.endPosition.x,Z=d.prevAngle,b=Math.PI*2;for(;h>=Z+Math.PI;)h-=b;for(;h<Z-Math.PI;)h+=b;d.angleAndHeight.endPosition.x=-h*n.clientWidth/12,d.angleAndHeight.startPosition.x=-Z*n.clientWidth/12}},Zi.PINCH_MOVE,e)}function xBt(t,e){let n=pc(Mo.WHEEL,e),i=t._pressTime,o=t._releaseTime,a=t._update;a[n]=!0;let s=t._movement[n];c(s)||(s=t._movement[n]={});let l=t._lastMovement[n];c(l)||(l=t._lastMovement[n]={startPosition:new K,endPosition:new K,valid:!1}),s.startPosition=new K,K.clone(K.ZERO,s.startPosition),s.endPosition=new K,t._eventHandler.setInputAction(function(r){let d=7.5*k.toRadians(r);i[n]=o[n]=new Date,s.endPosition.x=0,s.endPosition.y=d,K.clone(s.endPosition,l.endPosition),l.valid=!0,a[n]=!1},Zi.WHEEL,e)}function H1(t,e,n){let i=pc(n,e),o=t._isDown,a=t._eventStartPosition,s=t._pressTime,l=t._releaseTime;o[i]=!1,a[i]=new K;let r=t._lastMovement[i];c(r)||(r=t._lastMovement[i]={startPosition:new K,endPosition:new K,valid:!1});let d,m;n===Mo.LEFT_DRAG?(d=Zi.LEFT_DOWN,m=Zi.LEFT_UP):n===Mo.RIGHT_DRAG?(d=Zi.RIGHT_DOWN,m=Zi.RIGHT_UP):n===Mo.MIDDLE_DRAG&&(d=Zi.MIDDLE_DOWN,m=Zi.MIDDLE_UP),t._eventHandler.setInputAction(function(h){t._buttonsDown++,r.valid=!1,o[i]=!0,s[i]=new Date,K.clone(h.position,a[i])},d,e),t._eventHandler.setInputAction(function(){t._buttonsDown=Math.max(t._buttonsDown-1,0),o[i]=!1,l[i]=new Date},m,e)}function XBt(t,e){K.clone(t.startPosition,e.startPosition),K.clone(t.endPosition,e.endPosition)}function JBt(t,e){let n=t._update,i=t._movement,o=t._lastMovement,a=t._isDown;for(let s in Mo)if(Mo.hasOwnProperty(s)){let l=Mo[s];if(c(l)){let r=pc(l,e);n[r]=!0,c(t._lastMovement[r])||(t._lastMovement[r]={startPosition:new K,endPosition:new K,valid:!1}),c(t._movement[r])||(t._movement[r]={startPosition:new K,endPosition:new K})}}t._eventHandler.setInputAction(function(s){for(let l in Mo)if(Mo.hasOwnProperty(l)){let r=Mo[l];if(c(r)){let d=pc(r,e);a[d]&&(n[d]?(XBt(i[d],o[d]),o[d].valid=!0,XBt(s,i[d]),n[d]=!1):K.clone(s.endPosition,i[d].endPosition))}}K.clone(s.endPosition,t._currentMousePosition)},Zi.MOUSE_MOVE,e)}function yu(t){this._eventHandler=new sp(t),this._update={},this._movement={},this._lastMovement={},this._isDown={},this._eventStartPosition={},this._pressTime={},this._releaseTime={},this._buttonsDown=0,this._currentMousePosition=new K,xBt(this,void 0),YBt(this,void 0,t),H1(this,void 0,Mo.LEFT_DRAG),H1(this,void 0,Mo.RIGHT_DRAG),H1(this,void 0,Mo.MIDDLE_DRAG),JBt(this,void 0);for(let e in id)if(id.hasOwnProperty(e)){let n=id[e];c(n)&&(xBt(this,n),YBt(this,n,t),H1(this,n,Mo.LEFT_DRAG),H1(this,n,Mo.RIGHT_DRAG),H1(this,n,Mo.MIDDLE_DRAG),JBt(this,n))}}Object.defineProperties(yu.prototype,{currentMousePosition:{get:function(){return this._currentMousePosition}},anyButtonDown:{get:function(){let t=!this._update[pc(Mo.WHEEL)]||!this._update[pc(Mo.WHEEL,id.SHIFT)]||!this._update[pc(Mo.WHEEL,id.CTRL)]||!this._update[pc(Mo.WHEEL,id.ALT)];return this._buttonsDown>0||t}}});yu.prototype.isMoving=function(t,e){let n=pc(t,e);return!this._update[n]};yu.prototype.getMovement=function(t,e){let n=pc(t,e);return this._movement[n]};yu.prototype.getLastMovement=function(t,e){let n=pc(t,e),i=this._lastMovement[n];if(i.valid)return i};yu.prototype.isButtonDown=function(t,e){let n=pc(t,e);return this._isDown[n]};yu.prototype.getStartMousePosition=function(t,e){if(t===Mo.WHEEL)return this._currentMousePosition;let n=pc(t,e);return this._eventStartPosition[n]};yu.prototype.getButtonPressTime=function(t,e){let n=pc(t,e);return this._pressTime[n]};yu.prototype.getButtonReleaseTime=function(t,e){let n=pc(t,e);return this._releaseTime[n]};yu.prototype.reset=function(){for(let t in this._update)this._update.hasOwnProperty(t)&&(this._update[t]=!0)};yu.prototype.isDestroyed=function(){return!1};yu.prototype.destroy=function(){return this._eventHandler=this._eventHandler&&this._eventHandler.destroy(),At(this)};var S9=yu;var y2o=R(W(),1);function Vj(t,e,n,i,o,a,s,l,r,d){this._tweens=t,this._tweenjs=e,this._startObject=be(n),this._stopObject=be(i),this._duration=o,this._delay=a,this._easingFunction=s,this._update=l,this._complete=r,this.cancel=d,this.needsStart=!0}Object.defineProperties(Vj.prototype,{startObject:{get:function(){return this._startObject}},stopObject:{get:function(){return this._stopObject}},duration:{get:function(){return this._duration}},delay:{get:function(){return this._delay}},easingFunction:{get:function(){return this._easingFunction}},update:{get:function(){return this._update}},complete:{get:function(){return this._complete}},tweenjs:{get:function(){return this._tweenjs}}});Vj.prototype.cancelTween=function(){this._tweens.remove(this)};function mV(){this._tweens=[]}Object.defineProperties(mV.prototype,{length:{get:function(){return this._tweens.length}}});mV.prototype.add=function(t){if(t=f(t,f.EMPTY_OBJECT),t.duration===0)return c(t.complete)&&t.complete(),new Vj(this);let e=t.duration/xi.SECONDS_PER_MILLISECOND,n=f(t.delay,0),i=n/xi.SECONDS_PER_MILLISECOND,o=f(t.easingFunction,Zl.LINEAR_NONE),a=t.startObject,s=new SEt(a);s.to(be(t.stopObject),e),s.delay(i),s.easing(o),c(t.update)&&s.onUpdate(function(){t.update(a)}),s.onComplete(f(t.complete,null)),s.repeat(f(t._repeat,0));let l=new Vj(this,s,t.startObject,t.stopObject,t.duration,n,o,t.update,t.complete,t.cancel);return this._tweens.push(l),l};mV.prototype.addProperty=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.object,n=t.property,i=t.startValue,o=t.stopValue;function a(s){e[n]=s.value}return this.add({startObject:{value:i},stopObject:{value:o},duration:f(t.duration,3),delay:t.delay,easingFunction:t.easingFunction,update:a,complete:t.complete,cancel:t.cancel,_repeat:t._repeat})};mV.prototype.addAlpha=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.material,n=[];for(let o in e.uniforms)e.uniforms.hasOwnProperty(o)&&c(e.uniforms[o])&&c(e.uniforms[o].alpha)&&n.push(o);function i(o){let a=n.length;for(let s=0;s<a;++s)e.uniforms[n[s]].alpha=o.alpha}return this.add({startObject:{alpha:f(t.startValue,0)},stopObject:{alpha:f(t.stopValue,1)},duration:f(t.duration,3),delay:t.delay,easingFunction:t.easingFunction,update:i,complete:t.complete,cancel:t.cancel})};mV.prototype.addOffsetIncrement=function(t){t=f(t,f.EMPTY_OBJECT);let n=t.material.uniforms;return this.addProperty({object:n,property:"offset",startValue:n.offset,stopValue:n.offset+1,duration:t.duration,delay:t.delay,easingFunction:t.easingFunction,update:t.update,cancel:t.cancel,_repeat:1/0})};mV.prototype.remove=function(t){if(!c(t))return!1;let e=this._tweens.indexOf(t);return e!==-1?(t.tweenjs.stop(),c(t.cancel)&&t.cancel(),this._tweens.splice(e,1),!0):!1};mV.prototype.removeAll=function(){let t=this._tweens;for(let e=0;e<t.length;++e){let n=t[e];n.tweenjs.stop(),c(n.cancel)&&n.cancel()}t.length=0};mV.prototype.contains=function(t){return c(t)&&this._tweens.indexOf(t)!==-1};mV.prototype.get=function(t){return this._tweens[t]};mV.prototype.update=function(t){let e=this._tweens,n=0;for(t=c(t)?t/xi.SECONDS_PER_MILLISECOND:Oi();n<e.length;){let i=e[n],o=i.tweenjs;i.needsStart?(i.needsStart=!1,o.start(t)):o.update(t)?n++:(o.stop(),e.splice(n,1))}};var yS=mV;function E9(t){this.enableInputs=!0,this.enableTranslate=!0,this.enableZoom=!0,this.enableRotate=!0,this.enableTilt=!0,this.enableLook=!0,this.inertiaSpin=.9,this.inertiaTranslate=.9,this.inertiaZoom=.8,this.maximumMovementRatio=.1,this.bounceAnimationTime=3,this.minimumZoomDistance=1,this.maximumZoomDistance=Number.POSITIVE_INFINITY,this.translateEventTypes=Mo.LEFT_DRAG,this.zoomEventTypes=[Mo.RIGHT_DRAG,Mo.WHEEL,Mo.PINCH],this.rotateEventTypes=Mo.LEFT_DRAG,this.tiltEventTypes=[Mo.MIDDLE_DRAG,Mo.PINCH,{eventType:Mo.LEFT_DRAG,modifier:id.CTRL},{eventType:Mo.RIGHT_DRAG,modifier:id.CTRL}],this.lookEventTypes={eventType:Mo.LEFT_DRAG,modifier:id.SHIFT},this.minimumPickingTerrainHeight=15e4,this._minimumPickingTerrainHeight=this.minimumPickingTerrainHeight,this.minimumCollisionTerrainHeight=15e3,this._minimumCollisionTerrainHeight=this.minimumCollisionTerrainHeight,this.minimumTrackBallHeight=75e5,this._minimumTrackBallHeight=this.minimumTrackBallHeight,this.enableCollisionDetection=!0,this._scene=t,this._globe=void 0,this._ellipsoid=void 0,this._lastGlobeHeight=0,this._aggregator=new S9(t.canvas),this._lastInertiaSpinMovement=void 0,this._lastInertiaZoomMovement=void 0,this._lastInertiaTranslateMovement=void 0,this._lastInertiaTiltMovement=void 0,this._inertiaDisablers={_lastInertiaZoomMovement:["_lastInertiaSpinMovement","_lastInertiaTranslateMovement","_lastInertiaTiltMovement"],_lastInertiaTiltMovement:["_lastInertiaSpinMovement","_lastInertiaTranslateMovement"]},this._tweens=new yS,this._tween=void 0,this._horizontalRotationAxis=void 0,this._tiltCenterMousePosition=new K(-1,-1),this._tiltCenter=new p,this._rotateMousePosition=new K(-1,-1),this._rotateStartPosition=new p,this._strafeStartPosition=new p,this._strafeMousePosition=new K,this._strafeEndMousePosition=new K,this._zoomMouseStart=new K(-1,-1),this._zoomWorldPosition=new p,this._useZoomWorldPosition=!1,this._tiltCVOffMap=!1,this._looking=!1,this._rotating=!1,this._strafing=!1,this._zoomingOnVector=!1,this._zoomingUnderground=!1,this._rotatingZoom=!1,this._adjustedHeightForTerrain=!1,this._cameraUnderground=!1;let e=t.mapProjection;this._maxCoord=e.project(new gt(Math.PI,k.PI_OVER_TWO)),this._zoomFactor=5,this._rotateFactor=void 0,this._rotateRateRangeAdjustment=void 0,this._maximumRotateRate=1.77,this._minimumRotateRate=1/5e3,this._minimumZoomRate=20,this._maximumZoomRate=5906376272e3,this._minimumUndergroundPickDistance=2e3,this._maximumUndergroundPickDistance=1e4}function eke(t,e){if(t<0)return 0;let n=(1-e)*25;return Math.exp(-n*t)}function nke(t){return K.equalsEpsilon(t.startPosition,t.endPosition,k.EPSILON14)}var ike=.4;function oke(t,e,n,i,o,a,s){let l=a[s];c(l)||(l=a[s]={startPosition:new K,endPosition:new K,motion:new K,inertiaEnabled:!0});let r=t.getButtonPressTime(e,n),d=t.getButtonReleaseTime(e,n),m=r&&d&&(d.getTime()-r.getTime())/1e3,Z=d&&(new Date().getTime()-d.getTime())/1e3;if(r&&d&&m<ike){let b=eke(Z,i),u=t.getLastMovement(e,n);if(!c(u)||nke(u)||!l.inertiaEnabled||(l.motion.x=(u.endPosition.x-u.startPosition.x)*.5,l.motion.y=(u.endPosition.y-u.startPosition.y)*.5,l.startPosition=K.clone(u.startPosition,l.startPosition),l.endPosition=K.multiplyByScalar(l.motion,b,l.endPosition),l.endPosition=K.add(l.startPosition,l.endPosition,l.endPosition),isNaN(l.endPosition.x)||isNaN(l.endPosition.y)||K.distance(l.startPosition,l.endPosition)<.5))return;if(!t.isButtonDown(e,n)){let F=t.getStartMousePosition(e,n);o(a,F,l)}}}function ake(t,e){if(c(e)){let n=t[e];c(n)&&(n.inertiaEnabled=!0);let i=t._inertiaDisablers[e];if(c(i)){let o=i.length;for(let a=0;a<o;++a)n=t[i[a]],c(n)&&(n.inertiaEnabled=!1)}}}var LBt=[];function om(t,e,n,i,o,a){if(!c(n))return;let s=t._aggregator;Array.isArray(n)||(LBt[0]=n,n=LBt);let l=n.length;for(let r=0;r<l;++r){let d=n[r],m=c(d.eventType)?d.eventType:d,h=d.modifier,Z=s.isMoving(m,h)&&s.getMovement(m,h),b=s.getStartMousePosition(m,h);t.enableInputs&&e&&(Z?(i(t,b,Z),ake(t,a)):o<1&&oke(s,m,h,o,i,t,a))}}var bj=new di,ske=new p,lke=new K,rke=new p,dke=new K,cke=new p,mke=new p,hke=new p,pke=new p,uke=new p,Zke=new p,Vke=new p,bke=new p,Rke=new p,Wke=new p,fke=new p,Fke=new p,Uke=new p,Gke=new p,Ake=new p,BS=new p,MBt=new p,_Bt=new p,vat={orientation:new Jr};function nst(t,e,n,i,o,a){let s=1;c(a)&&(s=k.clamp(Math.abs(a),.25,1));let l=n.endPosition.y-n.startPosition.y,d=l>0?t.minimumZoomDistance*s:0,m=t.maximumZoomDistance,h=o-d,Z=i*h;Z=k.clamp(Z,t._minimumZoomRate,t._maximumZoomRate);let b=l/t._scene.canvas.clientHeight;b=Math.min(b,t.maximumMovementRatio);let u=Z*b;if(t.enableCollisionDetection||t.minimumZoomDistance===0||!c(t._globe)){if(u>0&&Math.abs(o-d)<1||u<0&&Math.abs(o-m)<1)return;o-u<d?u=o-d-1:o-u>m&&(u=o-m)}let F=t._scene,U=F.camera,G=F.mode,A=vat.orientation;if(A.heading=U.heading,A.pitch=U.pitch,A.roll=U.roll,U.frustum instanceof wn){Math.abs(u)>0&&(U.zoomIn(u),U._adjustOrthographicFrustum());return}let T=K.equals(e,t._zoomMouseStart),g=t._zoomingOnVector,C=t._rotatingZoom,y;if(T||(t._zoomMouseStart=K.clone(e,t._zoomMouseStart),c(t._globe)&&(G===ut.SCENE2D?(y=U.getPickRay(e,bj).origin,y=p.fromElements(y.y,y.z,y.x)):y=GU(t,e,ske)),c(y)?(t._useZoomWorldPosition=!0,t._zoomWorldPosition=p.clone(y,t._zoomWorldPosition)):t._useZoomWorldPosition=!1,g=t._zoomingOnVector=!1,C=t._rotatingZoom=!1,t._zoomingUnderground=t._cameraUnderground),!t._useZoomWorldPosition){U.zoomIn(u);return}let Y=G===ut.COLUMBUS_VIEW;if(U.positionCartographic.height<2e6&&(C=!0),!T||C){if(G===ut.SCENE2D){let Q=t._zoomWorldPosition,J=U.position;if(!p.equals(Q,J)&&U.positionCartographic.height<t._maxCoord.x*2){let M=U.position.x,V=p.subtract(Q,J,rke);p.normalize(V,V);let E=p.distance(Q,J)*u/(U.getMagnitude()*.5);U.move(V,E*.5),(U.position.x<0&&M>0||U.position.x>0&&M<0)&&(y=U.getPickRay(e,bj).origin,y=p.fromElements(y.y,y.z,y.x),t._zoomWorldPosition=p.clone(y,t._zoomWorldPosition))}}else if(G===ut.SCENE3D){let Q=p.normalize(U.position,uke);if(t._cameraUnderground||t._zoomingUnderground||U.positionCartographic.height<3e3&&Math.abs(p.dot(U.direction,Q))<.6)Y=!0;else{let J=F.canvas,M=dke;M.x=J.clientWidth/2,M.y=J.clientHeight/2;let V=GU(t,M,cke);if(!c(V))Y=!0;else if(U.positionCartographic.height<1e6)if(p.dot(U.direction,Q)>=-.5)Y=!0;else{let E=Vke;p.clone(U.position,E);let I=t._zoomWorldPosition,B=Zke;if(B=p.normalize(I,B),p.dot(B,Q)<0)return;let X=Ake,_=Wke;p.clone(U.direction,_),p.add(E,p.multiplyByScalar(_,1e3,BS),X);let P=fke,w=Fke;p.subtract(I,E,P),p.normalize(P,w);let z=p.dot(Q,w);if(z>=0){t._zoomMouseStart.x=-1;return}let H=Math.acos(-z),nt=p.magnitude(E),$=p.magnitude(I),dt=nt-u,q=p.magnitude(P),at=Math.asin(k.clamp(q/$*Math.sin(H),-1,1)),st=Math.asin(k.clamp(dt/$*Math.sin(H),-1,1)),Et=at-st+H,Qt=bke;p.normalize(E,Qt);let Wt=Rke;Wt=p.cross(w,Qt,Wt),Wt=p.normalize(Wt,Wt),p.normalize(p.cross(Qt,Wt,BS),_),p.multiplyByScalar(p.normalize(X,BS),p.magnitude(X)-u,X),p.normalize(E,E),p.multiplyByScalar(E,dt,E);let Nt=Uke;p.multiplyByScalar(p.add(p.multiplyByScalar(Qt,Math.cos(Et)-1,MBt),p.multiplyByScalar(_,Math.sin(Et),_Bt),BS),dt,Nt),p.add(E,Nt,E),p.normalize(X,Qt),p.normalize(p.cross(Qt,Wt,BS),_);let kt=Gke;p.multiplyByScalar(p.add(p.multiplyByScalar(Qt,Math.cos(Et)-1,MBt),p.multiplyByScalar(_,Math.sin(Et),_Bt),BS),p.magnitude(X),kt),p.add(X,kt,X),p.clone(E,U.position),p.normalize(p.subtract(X,E,BS),U.direction),p.clone(U.direction,U.direction),p.cross(U.direction,U.up,U.right),p.cross(U.right,U.direction,U.up),U.setView(vat);return}else{let E=p.normalize(V,mke),I=p.normalize(t._zoomWorldPosition,hke),B=p.dot(I,E);if(B>0&&B<1){let X=k.acosClamped(B),_=p.cross(I,E,pke),P=Math.abs(X)>k.toRadians(20)?U.positionCartographic.height*.75:U.positionCartographic.height-u,w=u/P;U.rotate(_,X*w)}}}}t._rotatingZoom=!Y}if(!T&&Y||g){let Q,J=qo.wgs84ToWindowCoordinates(F,t._zoomWorldPosition,lke);G!==ut.COLUMBUS_VIEW&&K.equals(e,t._zoomMouseStart)&&c(J)?Q=U.getPickRay(J,bj):Q=U.getPickRay(e,bj);let M=Q.direction;(G===ut.COLUMBUS_VIEW||G===ut.SCENE2D)&&p.fromElements(M.y,M.z,M.x,M),U.move(M,u),t._zoomingOnVector=!0}else U.zoomIn(u);t._cameraUnderground||U.setView(vat)}var Tke=new di,Ske=new di,gke=new p;function Eke(t,e,n){let o=t._scene.camera,a=o.getPickRay(n.startPosition,Tke).origin,s=o.getPickRay(n.endPosition,Ske).origin;a=p.fromElements(a.y,a.z,a.x,a),s=p.fromElements(s.y,s.z,s.x,s);let l=p.subtract(a,s,gke),r=p.magnitude(l);r>0&&(p.normalize(l,l),o.move(l,r))}function DBt(t,e,n){c(n.distance)&&(n=n.distance);let o=t._scene.camera;nst(t,e,n,t._zoomFactor,o.getMagnitude())}var Cke=new K,Ike=new K;function OBt(t,e,n){if(c(n.angleAndHeight)){Nke(t,e,n.angleAndHeight);return}let i=t._scene,o=i.camera,a=i.canvas,s=a.clientWidth,l=a.clientHeight,r=Cke;r.x=2/s*n.startPosition.x-1,r.y=2/l*(l-n.startPosition.y)-1,r=K.normalize(r,r);let d=Ike;d.x=2/s*n.endPosition.x-1,d.y=2/l*(l-n.endPosition.y)-1,d=K.normalize(d,d);let m=k.acosClamped(r.x);r.y<0&&(m=k.TWO_PI-m);let h=k.acosClamped(d.x);d.y<0&&(h=k.TWO_PI-h);let Z=h-m;o.twistRight(Z)}function Nke(t,e,n){let i=t._rotateFactor*t._rotateRateRangeAdjustment;i>t._maximumRotateRate&&(i=t._maximumRotateRate),i<t._minimumRotateRate&&(i=t._minimumRotateRate);let o=t._scene,a=o.camera,s=o.canvas,l=(n.endPosition.x-n.startPosition.x)/s.clientWidth;l=Math.min(l,t.maximumMovementRatio);let r=i*l*Math.PI*4;a.twistRight(r)}function yke(t){let e=t._scene.mapMode2D===eh.ROTATE;L.equals(L.IDENTITY,t._scene.camera.transform)?(om(t,t.enableTranslate,t.translateEventTypes,Eke,t.inertiaTranslate,"_lastInertiaTranslateMovement"),om(t,t.enableZoom,t.zoomEventTypes,DBt,t.inertiaZoom,"_lastInertiaZoomMovement"),e&&om(t,t.enableRotate,t.tiltEventTypes,OBt,t.inertiaSpin,"_lastInertiaTiltMovement")):(om(t,t.enableZoom,t.zoomEventTypes,DBt,t.inertiaZoom,"_lastInertiaZoomMovement"),e&&om(t,t.enableRotate,t.translateEventTypes,OBt,t.inertiaSpin,"_lastInertiaSpinMovement"))}var KBt=new di,Bke=new p,Qke=new p;function GU(t,e,n){let i=t._scene,o=t._globe,a=i.camera;if(!c(o))return;let s=!t._cameraUnderground,l;i.pickPositionSupported&&(l=i.pickPositionWorldCoordinates(e,Bke));let r=a.getPickRay(e,KBt),d=o.pickWorldCoordinates(r,i,s,Qke),m=c(l)?p.distance(l,a.positionWC):Number.POSITIVE_INFINITY,h=c(d)?p.distance(d,a.positionWC):Number.POSITIVE_INFINITY;return m<h?p.clone(l,n):p.clone(d,n)}var kke=new gt;function Gj(t){let e=t._ellipsoid,n=t._scene,i=n.camera,o=n.mode,a=0;if(o===ut.SCENE3D){let r=e.cartesianToCartographic(i.position,kke);c(r)&&(a=r.height)}else a=i.position.z;let s=f(t._scene.globeHeight,0);return Math.abs(s-a)}var Yke=new p;function zBt(t,e){let n=e.origin,i=e.direction,o=Gj(t),a=p.normalize(n,Yke),s=Math.abs(p.dot(a,i));return s=Math.max(s,.5)*2,o*s}function jBt(t,e,n,i){let o=p.distance(e.origin,n),a=Gj(t),s=k.clamp(a*5,t._minimumUndergroundPickDistance,t._maximumUndergroundPickDistance);return o>s&&(o=Math.min(o,a/5),o=Math.max(o,100)),di.getPoint(e,o,i)}function qBt(t,e,n,i){let o;return c(n)?(o=p.distance(e.origin,n),o>t._maximumUndergroundPickDistance&&(o=Gj(t))):o=Gj(t),di.getPoint(e,o,i)}var xke=new K;function $Bt(t,e){let n=e.endPosition,i=K.subtract(e.endPosition,e.startPosition,xke),o=t._strafeEndMousePosition;K.add(o,i,o),e.endPosition=o,ist(t,e,t._strafeStartPosition),e.endPosition=n}var HBt=new di,Xke=new di,Kat=new p,Jke=new p,Lke=new p,Mke=new p,_ke=new Kn(p.UNIT_X,0),Dke=new K,Oke=new K;function Hke(t,e,n){if(p.equals(e,t._translateMousePosition)||(t._looking=!1),p.equals(e,t._strafeMousePosition)||(t._strafing=!1),t._looking){rp(t,e,n);return}if(t._strafing){$Bt(t,n);return}let o=t._scene.camera,a=t._cameraUnderground,s=K.clone(n.startPosition,Dke),l=K.clone(n.endPosition,Oke),r=o.getPickRay(s,HBt),d=p.clone(p.ZERO,Mke),m=p.UNIT_X,h;if(o.position.z<t._minimumPickingTerrainHeight&&(h=GU(t,s,Kat),c(h)&&(d.x=h.x)),a||d.x>o.position.z&&c(h)){let T=h;a&&(T=qBt(t,r,h,Kat)),K.clone(e,t._strafeMousePosition),K.clone(e,t._strafeEndMousePosition),p.clone(T,t._strafeStartPosition),t._strafing=!0,ist(t,n,t._strafeStartPosition);return}let Z=Kn.fromPointNormal(d,m,_ke);r=o.getPickRay(s,HBt);let b=no.rayPlane(r,Z,Kat),u=o.getPickRay(l,Xke),F=no.rayPlane(u,Z,Jke);if(!c(b)||!c(F)){t._looking=!0,rp(t,e,n),K.clone(e,t._translateMousePosition);return}let U=p.subtract(b,F,Lke),G=U.x;U.x=U.y,U.y=U.z,U.z=G;let A=p.magnitude(U);A>k.EPSILON6&&(p.normalize(U,U),o.move(U,A))}var tQt=new K,Wj=new di,fj=new p,wke=new p,eQt=new L,Pke=new L,vke=new p,Kke=new Kn(p.UNIT_X,0),zat=new p,$at=new gt,nQt=new L,zke=new wt,jke=new ot,Fj=new p;function qke(t,e,n){if(c(n.angleAndHeight)&&(n=n.angleAndHeight),K.equals(e,t._tiltCenterMousePosition)||(t._tiltCVOffMap=!1,t._looking=!1),t._looking){rp(t,e,n);return}let o=t._scene.camera;t._tiltCVOffMap||!t.onMap()||Math.abs(o.position.z)>t._minimumPickingTerrainHeight?(t._tiltCVOffMap=!0,$ke(t,e,n)):tYe(t,e,n)}function $ke(t,e,n){let i=t._scene,o=i.camera,a=i.canvas,s=tQt;s.x=a.clientWidth/2,s.y=a.clientHeight/2;let l=o.getPickRay(s,Wj),r=p.UNIT_X,d=l.origin,m=l.direction,h,Z=p.dot(r,m);if(Math.abs(Z)>k.EPSILON6&&(h=-p.dot(r,d)/Z),!c(h)||h<=0){t._looking=!0,rp(t,e,n),K.clone(e,t._tiltCenterMousePosition);return}let b=p.multiplyByScalar(m,h,fj);p.add(d,b,b);let u=i.mapProjection,F=u.ellipsoid;p.fromElements(b.y,b.z,b.x,b);let U=u.unproject(b,$at);F.cartographicToCartesian(U,b);let G=Pe.eastNorthUpToFixedFrame(b,F,eQt),A=t._globe,T=t._ellipsoid;t._globe=void 0,t._ellipsoid=mt.UNIT_SPHERE,t._rotateFactor=1,t._rotateRateRangeAdjustment=1;let g=L.clone(o.transform,nQt);o._setTransform(G),lp(t,e,n,p.UNIT_Z),o._setTransform(g),t._globe=A,t._ellipsoid=T;let C=T.maximumRadius;t._rotateFactor=1/C,t._rotateRateRangeAdjustment=C}function tYe(t,e,n){let i=t._scene,o=i.camera,a=t._cameraUnderground,s,l,r=p.UNIT_X;if(K.equals(e,t._tiltCenterMousePosition))s=p.clone(t._tiltCenter,fj);else{if(o.position.z<t._minimumPickingTerrainHeight&&(s=GU(t,e,fj)),!c(s)){l=o.getPickRay(e,Wj);let V=l.origin,E=l.direction,I,B=p.dot(r,E);if(Math.abs(B)>k.EPSILON6&&(I=-p.dot(r,V)/B),!c(I)||I<=0){t._looking=!0,rp(t,e,n),K.clone(e,t._tiltCenterMousePosition);return}s=p.multiplyByScalar(E,I,fj),p.add(V,s,s)}a&&(c(l)||(l=o.getPickRay(e,Wj)),jBt(t,l,s,s)),K.clone(e,t._tiltCenterMousePosition),p.clone(s,t._tiltCenter)}let d=i.canvas,m=tQt;m.x=d.clientWidth/2,m.y=t._tiltCenterMousePosition.y,l=o.getPickRay(m,Wj);let h=p.clone(p.ZERO,vke);h.x=s.x;let Z=Kn.fromPointNormal(h,r,Kke),b=no.rayPlane(l,Z,wke),u=o._projection,F=u.ellipsoid;p.fromElements(s.y,s.z,s.x,s);let U=u.unproject(s,$at);F.cartographicToCartesian(U,s);let G=Pe.eastNorthUpToFixedFrame(s,F,eQt),A;c(b)?(p.fromElements(b.y,b.z,b.x,b),U=u.unproject(b,$at),F.cartographicToCartesian(U,b),A=Pe.eastNorthUpToFixedFrame(b,F,Pke)):A=G;let T=t._globe,g=t._ellipsoid;t._globe=void 0,t._ellipsoid=mt.UNIT_SPHERE,t._rotateFactor=1,t._rotateRateRangeAdjustment=1;let C=p.UNIT_Z,y=L.clone(o.transform,nQt);o._setTransform(G);let Y=p.cross(p.UNIT_Z,p.normalize(o.position,zat),zat),Q=p.dot(o.right,Y);if(lp(t,e,n,C,!1,!0),o._setTransform(A),Q<0){let V=n.startPosition.y-n.endPosition.y;(a&&V<0||!a&&V>0)&&(C=void 0);let E=o.constrainedAxis;o.constrainedAxis=void 0,lp(t,e,n,C,!0,!1),o.constrainedAxis=E}else lp(t,e,n,C,!0,!1);if(c(o.constrainedAxis)){let V=p.cross(o.direction,o.constrainedAxis,Fj);p.equalsEpsilon(V,p.ZERO,k.EPSILON6)||(p.dot(V,o.right)<0&&p.negate(V,V),p.cross(V,o.direction,o.up),p.cross(o.direction,o.up,o.right),p.normalize(o.up,o.up),p.normalize(o.right,o.right))}o._setTransform(y),t._globe=T,t._ellipsoid=g;let J=g.maximumRadius;t._rotateFactor=1/J,t._rotateRateRangeAdjustment=J;let M=p.clone(o.positionWC,zat);if(t.enableCollisionDetection&&sst(t,!0),!p.equals(o.positionWC,M)){o._setTransform(A),o.worldToCameraCoordinatesPoint(M,M);let V=p.magnitudeSquared(M);p.magnitudeSquared(o.position)>V&&(p.normalize(o.position,o.position),p.multiplyByScalar(o.position,Math.sqrt(V),o.position));let E=p.angleBetween(M,o.position),I=p.cross(M,o.position,M);p.normalize(I,I);let B=wt.fromAxisAngle(I,E,zke),X=ot.fromQuaternion(B,jke);ot.multiplyByVector(X,o.direction,o.direction),ot.multiplyByVector(X,o.up,o.up),p.cross(o.direction,o.up,o.right),p.cross(o.right,o.direction,o.up),o._setTransform(y)}}var iQt=new K,oQt=new di,aQt=new p;function eYe(t,e,n){c(n.distance)&&(n=n.distance);let i=t._scene,o=i.camera,a=i.canvas,s=t._cameraUnderground,l;s?l=e:(l=iQt,l.x=a.clientWidth/2,l.y=a.clientHeight/2);let r=o.getPickRay(l,oQt),d=r.origin,m=r.direction,h=o.position.z,Z;h<t._minimumPickingTerrainHeight&&(Z=GU(t,l,aQt));let b;if(c(Z)&&(b=p.distance(d,Z)),s){let u=zBt(t,r,h);c(b)?b=Math.min(b,u):b=u}if(!c(b)){let u=p.UNIT_X;b=-p.dot(u,d)/p.dot(u,m)}nst(t,e,n,t._zoomFactor,b)}function nYe(t){let n=t._scene.camera;if(!L.equals(L.IDENTITY,n.transform))om(t,t.enableRotate,t.rotateEventTypes,lp,t.inertiaSpin,"_lastInertiaSpinMovement"),om(t,t.enableZoom,t.zoomEventTypes,sQt,t.inertiaZoom,"_lastInertiaZoomMovement");else{let i=t._tweens;if(t._aggregator.anyButtonDown&&i.removeAll(),om(t,t.enableTilt,t.tiltEventTypes,qke,t.inertiaSpin,"_lastInertiaTiltMovement"),om(t,t.enableTranslate,t.translateEventTypes,Hke,t.inertiaTranslate,"_lastInertiaTranslateMovement"),om(t,t.enableZoom,t.zoomEventTypes,eYe,t.inertiaZoom,"_lastInertiaZoomMovement"),om(t,t.enableLook,t.lookEventTypes,rp),!t._aggregator.anyButtonDown&&!i.contains(t._tween)){let o=n.createCorrectPositionTween(t.bounceAnimationTime);c(o)&&(t._tween=i.add(o))}i.update()}}var iYe=new di,oYe=new Kn(p.UNIT_X,0),aYe=new p,sYe=new p,lYe=new p;function ist(t,e,n){let i=t._scene,o=i.camera,a=o.getPickRay(e.endPosition,iYe),s=p.clone(o.direction,sYe);i.mode===ut.COLUMBUS_VIEW&&p.fromElements(s.z,s.x,s.y,s);let l=Kn.fromPointNormal(n,s,oYe),r=no.rayPlane(a,l,aYe);c(r)&&(s=p.subtract(n,r,s),i.mode===ut.COLUMBUS_VIEW&&p.fromElements(s.y,s.z,s.x,s),p.add(o.position,s,o.position))}var wBt=new p,rYe=new gt,tst=new p,est=new mt,dYe=new p,cYe=new p;function mYe(t,e,n){let o=t._scene.camera,a=t._cameraUnderground,s=t._ellipsoid;if(!L.equals(o.transform,L.IDENTITY)){lp(t,e,n);return}let l,r,d=s.geodeticSurfaceNormal(o.position,dYe);if(K.equals(e,t._rotateMousePosition)){if(t._looking)rp(t,e,n,d);else if(t._rotating)lp(t,e,n);else if(t._strafing){if(o.ignoreEllipsoid)return;$Bt(t,n)}else{if(o.ignoreEllipsoid||p.magnitude(o.position)<p.magnitude(t._rotateStartPosition))return;l=p.magnitude(t._rotateStartPosition),r=tst,r.x=r.y=r.z=l,s=mt.fromCartesian3(r,est),qat(t,e,n,s)}return}t._looking=!1,t._rotating=!1,t._strafing=!1;let m=s.cartesianToCartographic(o.positionWC,rYe).height,h=t._globe;if(c(h)&&m<t._minimumPickingTerrainHeight){let Z=GU(t,n.startPosition,lYe);if(c(Z)&&!o.ignoreEllipsoid){let b=!1,u=o.getPickRay(n.startPosition,KBt);if(a)b=!0,qBt(t,u,Z,Z);else{let F=s.geodeticSurfaceNormal(Z,cYe);Math.abs(p.dot(u.direction,F))<.05?b=!0:b=p.magnitude(o.position)<p.magnitude(Z)}b?(K.clone(e,t._strafeEndMousePosition),p.clone(Z,t._strafeStartPosition),t._strafing=!0,ist(t,n,t._strafeStartPosition)):(l=p.magnitude(Z),r=tst,r.x=r.y=r.z=l,s=mt.fromCartesian3(r,est),qat(t,e,n,s),p.clone(Z,t._rotateStartPosition))}else t._looking=!0,rp(t,e,n,d)}else c(o.pickEllipsoid(n.startPosition,t._ellipsoid,wBt))?(qat(t,e,n,t._ellipsoid),p.clone(wBt,t._rotateStartPosition)):m>t._minimumTrackBallHeight?(t._rotating=!0,lp(t,e,n)):(t._looking=!0,rp(t,e,n,d));K.clone(e,t._rotateMousePosition)}function lp(t,e,n,i,o,a){o=f(o,!1),a=f(a,!1);let s=t._scene,l=s.camera,r=s.canvas,d=l.constrainedAxis;c(i)&&(l.constrainedAxis=i);let m=p.magnitude(l.position),h=t._rotateFactor*(m-t._rotateRateRangeAdjustment);h>t._maximumRotateRate&&(h=t._maximumRotateRate),h<t._minimumRotateRate&&(h=t._minimumRotateRate);let Z=(n.startPosition.x-n.endPosition.x)/r.clientWidth,b=(n.startPosition.y-n.endPosition.y)/r.clientHeight;Z=Math.min(Z,t.maximumMovementRatio),b=Math.min(b,t.maximumMovementRatio);let u=h*Z*Math.PI*2,F=h*b*Math.PI;o||l.rotateRight(u),a||l.rotateUp(F),l.constrainedAxis=d}var hYe=Rt.clone(Rt.UNIT_W),pYe=Rt.clone(Rt.UNIT_W),Rj=new p,jat=new p,uYe=new p,ZYe=new p,VYe=new K,bYe=new K;function qat(t,e,n,i){let a=t._scene.camera,s=K.clone(n.startPosition,VYe),l=K.clone(n.endPosition,bYe),r=a.pickEllipsoid(s,i,hYe),d=a.pickEllipsoid(l,i,pYe);if(!c(r)||!c(d)){t._rotating=!0,lp(t,e,n);return}if(r=a.worldToCameraCoordinates(r,r),d=a.worldToCameraCoordinates(d,d),c(a.constrainedAxis)){let m=a.constrainedAxis,h=p.mostOrthogonalAxis(m,Rj);p.cross(h,m,h),p.normalize(h,h);let Z=p.cross(m,h,jat),b=p.magnitude(r),u=p.dot(m,r),F=Math.acos(u/b),U=p.multiplyByScalar(m,u,uYe);p.subtract(r,U,U),p.normalize(U,U);let G=p.magnitude(d),A=p.dot(m,d),T=Math.acos(A/G),g=p.multiplyByScalar(m,A,ZYe);p.subtract(d,g,g),p.normalize(g,g);let C=Math.acos(p.dot(U,h));p.dot(U,Z)<0&&(C=k.TWO_PI-C);let y=Math.acos(p.dot(g,h));p.dot(g,Z)<0&&(y=k.TWO_PI-y);let Y=C-y,Q;p.equalsEpsilon(m,a.position,k.EPSILON2)?Q=a.right:Q=p.cross(m,a.position,Rj);let J=p.cross(m,Q,Rj),M=p.dot(J,p.subtract(r,m,jat)),V=p.dot(J,p.subtract(d,m,jat)),E;M>0&&V>0?E=T-F:M>0&&V<=0?p.dot(a.position,m)>0?E=-F-T:E=F+T:E=F-T,a.rotateRight(Y),a.rotateUp(E)}else{p.normalize(r,r),p.normalize(d,d);let m=p.dot(r,d),h=p.cross(r,d,Rj);if(m<1&&!p.equalsEpsilon(h,p.ZERO,k.EPSILON14)){let Z=Math.acos(m);a.rotate(h,Z)}}}var RYe=new p,WYe=new gt;function sQt(t,e,n){c(n.distance)&&(n=n.distance);let i=t._ellipsoid,o=t._scene,a=o.camera,s=o.canvas,l=t._cameraUnderground,r;l?r=e:(r=iQt,r.x=s.clientWidth/2,r.y=s.clientHeight/2);let d=a.getPickRay(r,oQt),m,h=i.cartesianToCartographic(a.position,WYe)?.height;if(!h)return;h<t._minimumPickingTerrainHeight&&(m=GU(t,r,aQt));let Z;if(c(m)&&(Z=p.distance(d.origin,m)),l){let u=zBt(t,d,h);c(Z)?Z=Math.min(Z,u):Z=u}c(Z)||(Z=h);let b=p.normalize(a.position,RYe);nst(t,e,n,t._zoomFactor,Z,p.dot(b,a.direction))}var lQt=new K,Uj=new di,g9=new p,fYe=new p,rQt=new L,FYe=new L,dQt=new L,UYe=new wt,GYe=new ot,ost=new gt,ast=new p;function AYe(t,e,n){let o=t._scene.camera;if(!L.equals(o.transform,L.IDENTITY))return;if(c(n.angleAndHeight)&&(n=n.angleAndHeight),K.equals(e,t._tiltCenterMousePosition)||(t._tiltOnEllipsoid=!1,t._looking=!1),t._looking){let l=t._ellipsoid.geodeticSurfaceNormal(o.position,ast);rp(t,e,n,l);return}let s=t._ellipsoid.cartesianToCartographic(o.position,ost);t._tiltOnEllipsoid||s.height>t._minimumCollisionTerrainHeight?(t._tiltOnEllipsoid=!0,SYe(t,e,n)):gYe(t,e,n)}var TYe=new gt;function SYe(t,e,n){let i=t._ellipsoid,o=t._scene,a=o.camera,s=t.minimumZoomDistance*.25,l=i.cartesianToCartographic(a.positionWC,TYe).height;if(l-s-1<k.EPSILON3&&n.endPosition.y-n.startPosition.y<0)return;let r=o.canvas,d=lQt;d.x=r.clientWidth/2,d.y=r.clientHeight/2;let m=a.getPickRay(d,Uj),h,Z=no.rayEllipsoid(m,i);if(c(Z))h=di.getPoint(m,Z.start,g9);else if(l>t._minimumTrackBallHeight){let A=no.grazingAltitudeLocation(m,i);if(!c(A))return;let T=i.cartesianToCartographic(A,ost);T.height=0,h=i.cartographicToCartesian(T,g9)}else{t._looking=!0;let A=t._ellipsoid.geodeticSurfaceNormal(a.position,ast);rp(t,e,n,A),K.clone(e,t._tiltCenterMousePosition);return}let b=Pe.eastNorthUpToFixedFrame(h,i,rQt),u=t._globe,F=t._ellipsoid;t._globe=void 0,t._ellipsoid=mt.UNIT_SPHERE,t._rotateFactor=1,t._rotateRateRangeAdjustment=1;let U=L.clone(a.transform,dQt);a._setTransform(b),lp(t,e,n,p.UNIT_Z),a._setTransform(U),t._globe=u,t._ellipsoid=F;let G=F.maximumRadius;t._rotateFactor=1/G,t._rotateRateRangeAdjustment=G}function gYe(t,e,n){let i=t._ellipsoid,o=t._scene,a=o.camera,s=t._cameraUnderground,l,r,d;if(K.equals(e,t._tiltCenterMousePosition))l=p.clone(t._tiltCenter,g9);else{if(l=GU(t,e,g9),!c(l)){if(r=a.getPickRay(e,Uj),d=no.rayEllipsoid(r,i),!c(d)){if(i.cartesianToCartographic(a.position,ost).height<=t._minimumTrackBallHeight){t._looking=!0;let E=t._ellipsoid.geodeticSurfaceNormal(a.position,ast);rp(t,e,n,E),K.clone(e,t._tiltCenterMousePosition)}return}l=di.getPoint(r,d.start,g9)}s&&(c(r)||(r=a.getPickRay(e,Uj)),jBt(t,r,l,l)),K.clone(e,t._tiltCenterMousePosition),p.clone(l,t._tiltCenter)}let m=o.canvas,h=lQt;h.x=m.clientWidth/2,h.y=t._tiltCenterMousePosition.y,r=a.getPickRay(h,Uj);let Z=p.magnitude(l),b=p.fromElements(Z,Z,Z,tst),u=mt.fromCartesian3(b,est);if(d=no.rayEllipsoid(r,u),!c(d))return;let F=p.magnitude(r.origin)>Z?d.start:d.stop,U=di.getPoint(r,F,fYe),G=Pe.eastNorthUpToFixedFrame(l,i,rQt),A=Pe.eastNorthUpToFixedFrame(U,u,FYe),T=t._globe,g=t._ellipsoid;t._globe=void 0,t._ellipsoid=mt.UNIT_SPHERE,t._rotateFactor=1,t._rotateRateRangeAdjustment=1;let C=p.UNIT_Z,y=L.clone(a.transform,dQt);a._setTransform(A);let Y=p.cross(U,a.positionWC,Fj);if(p.dot(a.rightWC,Y)<0){let V=n.startPosition.y-n.endPosition.y;(s&&V<0||!s&&V>0)&&(C=void 0);let E=a.constrainedAxis;a.constrainedAxis=void 0,lp(t,e,n,C,!0,!1),a.constrainedAxis=E}else lp(t,e,n,C,!0,!1);if(a._setTransform(G),lp(t,e,n,C,!1,!0),c(a.constrainedAxis)){let V=p.cross(a.direction,a.constrainedAxis,Fj);p.equalsEpsilon(V,p.ZERO,k.EPSILON6)||(p.dot(V,a.right)<0&&p.negate(V,V),p.cross(V,a.direction,a.up),p.cross(a.direction,a.up,a.right),p.normalize(a.up,a.up),p.normalize(a.right,a.right))}a._setTransform(y),t._globe=T,t._ellipsoid=g;let J=g.maximumRadius;t._rotateFactor=1/J,t._rotateRateRangeAdjustment=J;let M=p.clone(a.positionWC,Fj);if(t.enableCollisionDetection&&sst(t,!0),!p.equals(a.positionWC,M)){a._setTransform(A),a.worldToCameraCoordinatesPoint(M,M);let V=p.magnitudeSquared(M);p.magnitudeSquared(a.position)>V&&(p.normalize(a.position,a.position),p.multiplyByScalar(a.position,Math.sqrt(V),a.position));let E=p.angleBetween(M,a.position),I=p.cross(M,a.position,M);p.normalize(I,I);let B=wt.fromAxisAngle(I,E,UYe),X=ot.fromQuaternion(B,GYe);ot.multiplyByVector(X,a.direction,a.direction),ot.multiplyByVector(X,a.up,a.up),p.cross(a.direction,a.up,a.right),p.cross(a.right,a.direction,a.up),a._setTransform(y)}}var EYe=new K,CYe=new K,PBt=new di,vBt=new di,IYe=new p,NYe=new p;function rp(t,e,n,i){let a=t._scene.camera,s=EYe;s.x=n.startPosition.x,s.y=0;let l=CYe;l.x=n.endPosition.x,l.y=0;let r=a.getPickRay(s,PBt),d=a.getPickRay(l,vBt),m=0,h,Z;a.frustum instanceof wn?(h=r.origin,Z=d.origin,p.add(a.direction,h,h),p.add(a.direction,Z,Z),p.subtract(h,a.position,h),p.subtract(Z,a.position,Z),p.normalize(h,h),p.normalize(Z,Z)):(h=r.direction,Z=d.direction);let b=p.dot(h,Z);b<1&&(m=Math.acos(b)),m=n.startPosition.x>n.endPosition.x?-m:m;let u=t._horizontalRotationAxis;if(c(i)?a.look(i,-m):c(u)?a.look(u,-m):a.lookLeft(m),s.x=0,s.y=n.startPosition.y,l.x=0,l.y=n.endPosition.y,r=a.getPickRay(s,PBt),d=a.getPickRay(l,vBt),m=0,a.frustum instanceof wn?(h=r.origin,Z=d.origin,p.add(a.direction,h,h),p.add(a.direction,Z,Z),p.subtract(h,a.position,h),p.subtract(Z,a.position,Z),p.normalize(h,h),p.normalize(Z,Z)):(h=r.direction,Z=d.direction),b=p.dot(h,Z),b<1&&(m=Math.acos(b)),m=n.startPosition.y>n.endPosition.y?-m:m,i=f(i,u),c(i)){let F=a.direction,U=p.negate(i,IYe),G=p.equalsEpsilon(F,i,k.EPSILON2),A=p.equalsEpsilon(F,U,k.EPSILON2);if(!G&&!A){b=p.dot(F,i);let T=k.acosClamped(b);m>0&&m>T&&(m=T-k.EPSILON4),b=p.dot(F,U),T=k.acosClamped(b),m<0&&-m>T&&(m=-T+k.EPSILON4);let g=p.cross(i,F,NYe);a.look(g,m)}else(G&&m<0||A&&m>0)&&a.look(a.right,-m)}else a.lookUp(m)}function yYe(t){om(t,t.enableRotate,t.rotateEventTypes,mYe,t.inertiaSpin,"_lastInertiaSpinMovement"),om(t,t.enableZoom,t.zoomEventTypes,sQt,t.inertiaZoom,"_lastInertiaZoomMovement"),om(t,t.enableTilt,t.tiltEventTypes,AYe,t.inertiaSpin,"_lastInertiaTiltMovement"),om(t,t.enableLook,t.lookEventTypes,rp)}var BYe=new L,QYe=new gt;function sst(t,e){t._adjustedHeightForTerrain=!0;let n=t._scene,i=n.mode,o=n.globe;if(i===ut.SCENE2D||i===ut.MORPHING)return;let a=n.camera,s=f(o?.ellipsoid,mt.WGS84),l=n.mapProjection,r,d;L.equals(a.transform,L.IDENTITY)||(r=L.clone(a.transform,BYe),d=p.magnitude(a.position),a._setTransform(L.IDENTITY));let m=QYe;i===ut.SCENE3D?s.cartesianToCartographic(a.position,m):l.unproject(a.position,m);let h=!1;if(m.height<t._minimumCollisionTerrainHeight){let Z=t._scene.globeHeight;if(c(Z)){let b=Z+t.minimumZoomDistance,u=Z-t._lastGlobeHeight,F=u/t._lastGlobeHeight;m.height<b&&(e||Math.abs(F)<=.1)&&(m.height=b,i===ut.SCENE3D?s.cartographicToCartesian(m,a.position):l.project(m,a.position),h=!0),e||Math.abs(F)<=.1?t._lastGlobeHeight=Z:t._lastGlobeHeight+=u*.1}}c(r)&&(a._setTransform(r),h&&(p.normalize(a.position,a.position),p.negate(a.position,a.direction),p.multiplyByScalar(a.position,Math.max(d,t.minimumZoomDistance),a.position),p.normalize(a.direction,a.direction),p.cross(a.direction,a.up,a.right),p.cross(a.right,a.direction,a.up)))}E9.prototype.onMap=function(){let t=this._scene,e=t.mode,n=t.camera;return e===ut.COLUMBUS_VIEW?Math.abs(n.position.x)-this._maxCoord.x<0&&Math.abs(n.position.y)-this._maxCoord.y<0:!0};var kYe=new p,YYe=new p;E9.prototype.update=function(){let t=this._scene,{camera:e,globe:n,mode:i}=t;L.equals(e.transform,L.IDENTITY)?(this._globe=n,this._ellipsoid=c(this._globe)?this._globe.ellipsoid:t.mapProjection.ellipsoid):(this._globe=void 0,this._ellipsoid=mt.UNIT_SPHERE);let{verticalExaggeration:o,verticalExaggerationRelativeHeight:a}=t;this._minimumCollisionTerrainHeight=Ps.getHeight(this.minimumCollisionTerrainHeight,o,a),this._minimumPickingTerrainHeight=Ps.getHeight(this.minimumPickingTerrainHeight,o,a),this._minimumTrackBallHeight=Ps.getHeight(this.minimumTrackBallHeight,o,a),this._cameraUnderground=t.cameraUnderground&&c(this._globe);let s=this._ellipsoid.maximumRadius;this._rotateFactor=1/s,this._rotateRateRangeAdjustment=s,this._adjustedHeightForTerrain=!1;let l=p.clone(e.positionWC,kYe),r=p.clone(e.directionWC,YYe);if(i===ut.SCENE2D?yke(this):i===ut.COLUMBUS_VIEW?(this._horizontalRotationAxis=p.UNIT_Z,nYe(this)):i===ut.SCENE3D&&(this._horizontalRotationAxis=void 0,yYe(this)),this.enableCollisionDetection&&!this._adjustedHeightForTerrain){let d=!p.equals(l,e.positionWC)||!p.equals(r,e.directionWC);sst(this,d)}this._aggregator.reset()};E9.prototype.isDestroyed=function(){return!1};E9.prototype.destroy=function(){return this._tweens.removeAll(),this._aggregator=this._aggregator&&this._aggregator.destroy(),At(this)};var C9=E9;var Cko=R(W(),1);var rko=R(W(),1),I9=`uniform sampler2D colorTexture; +`,s=new Qa({name:"czm_edge_detection_combine",fragmentShader:a,uniforms:n});return new nm({name:"czm_edge_detection_composite",stages:[e,s]})}Zl.createSilhouetteStage=function(t){let e=KQe(t),n=new Qa({name:"czm_silhouette_color_edges",fragmentShader:Z9,uniforms:{silhouetteTexture:e.name}});return new nm({name:"czm_silhouette",stages:[e,n],inputPreviousStageTexture:!1,uniforms:e.uniforms})};Zl.isSilhouetteSupported=function(t){return t.context.depthTexture};Zl.createBloomStage=function(){let t=new Qa({name:"czm_bloom_contrast_bias",fragmentShader:s9,uniforms:{contrast:128,brightness:-.3}}),e=pj("czm_bloom_blur"),n=new nm({name:"czm_bloom_contrast_bias_blur",stages:[t,e]}),i=new Qa({name:"czm_bloom_generate_composite",fragmentShader:o9,uniforms:{glowOnly:!1,bloomTexture:n.name}}),o={};return Object.defineProperties(o,{glowOnly:{get:function(){return i.uniforms.glowOnly},set:function(a){i.uniforms.glowOnly=a}},contrast:{get:function(){return t.uniforms.contrast},set:function(a){t.uniforms.contrast=a}},brightness:{get:function(){return t.uniforms.brightness},set:function(a){t.uniforms.brightness=a}},delta:{get:function(){return e.uniforms.delta},set:function(a){e.uniforms.delta=a}},sigma:{get:function(){return e.uniforms.sigma},set:function(a){e.uniforms.sigma=a}},stepSize:{get:function(){return e.uniforms.stepSize},set:function(a){e.uniforms.stepSize=a}}}),new nm({name:"czm_bloom",stages:[n,i],inputPreviousStageTexture:!1,uniforms:o})};Zl.createAmbientOcclusionStage=function(){let t=new Qa({name:"czm_ambient_occlusion_generate",fragmentShader:e9,uniforms:{intensity:3,bias:.1,lengthCap:.26,stepSize:1.95,frustumLength:1e3,randomTexture:void 0}}),e=pj("czm_ambient_occlusion_blur");e.uniforms.stepSize=.86;let n=new nm({name:"czm_ambient_occlusion_generate_blur",stages:[t,e]}),i=new Qa({name:"czm_ambient_occlusion_composite",fragmentShader:n9,uniforms:{ambientOcclusionOnly:!1,ambientOcclusionTexture:n.name}}),o={};return Object.defineProperties(o,{intensity:{get:function(){return t.uniforms.intensity},set:function(a){t.uniforms.intensity=a}},bias:{get:function(){return t.uniforms.bias},set:function(a){t.uniforms.bias=a}},lengthCap:{get:function(){return t.uniforms.lengthCap},set:function(a){t.uniforms.lengthCap=a}},stepSize:{get:function(){return t.uniforms.stepSize},set:function(a){t.uniforms.stepSize=a}},frustumLength:{get:function(){return t.uniforms.frustumLength},set:function(a){t.uniforms.frustumLength=a}},randomTexture:{get:function(){return t.uniforms.randomTexture},set:function(a){t.uniforms.randomTexture=a}},delta:{get:function(){return e.uniforms.delta},set:function(a){e.uniforms.delta=a}},sigma:{get:function(){return e.uniforms.sigma},set:function(a){e.uniforms.sigma=a}},blurStepSize:{get:function(){return e.uniforms.stepSize},set:function(a){e.uniforms.stepSize=a}},ambientOcclusionOnly:{get:function(){return i.uniforms.ambientOcclusionOnly},set:function(a){i.uniforms.ambientOcclusionOnly=a}}}),new nm({name:"czm_ambient_occlusion",stages:[n,i],inputPreviousStageTexture:!1,uniforms:o})};Zl.isAmbientOcclusionSupported=function(t){return t.context.depthTexture};var zQe=`#define FXAA_QUALITY_PRESET 39 +${R9} +${m9}`;Zl.createFXAAStage=function(){return new Qa({name:"czm_FXAA",fragmentShader:zQe,sampleMode:op.LINEAR})};Zl.createAcesTonemappingStage=function(t){let e=t?`#define AUTO_EXPOSURE +`:"";return e+=t9,new Qa({name:"czm_aces",fragmentShader:e,uniforms:{autoExposure:void 0}})};Zl.createFilmicTonemappingStage=function(t){let e=t?`#define AUTO_EXPOSURE +`:"";return e+=c9,new Qa({name:"czm_filmic",fragmentShader:e,uniforms:{autoExposure:void 0}})};Zl.createReinhardTonemappingStage=function(t){let e=t?`#define AUTO_EXPOSURE +`:"";return e+=u9,new Qa({name:"czm_reinhard",fragmentShader:e,uniforms:{autoExposure:void 0}})};Zl.createModifiedReinhardTonemappingStage=function(t){let e=t?`#define AUTO_EXPOSURE +`:"";return e+=p9,new Qa({name:"czm_modified_reinhard",fragmentShader:e,uniforms:{white:v.WHITE,autoExposure:void 0}})};Zl.createAutoExposureStage=function(){return new b9};Zl.createBlackAndWhiteStage=function(){return new Qa({name:"czm_black_and_white",fragmentShader:i9,uniforms:{gradations:5}})};Zl.createBrightnessStage=function(){return new Qa({name:"czm_brightness",fragmentShader:a9,uniforms:{brightness:.5}})};Zl.createNightVisionStage=function(){return new Qa({name:"czm_night_vision",fragmentShader:V9})};Zl.createDepthViewStage=function(){return new Qa({name:"czm_depth_view",fragmentShader:r9})};Zl.createLensFlareStage=function(){return new Qa({name:"czm_lens_flare",fragmentShader:h9,uniforms:{dirtTexture:Dn("Assets/Textures/LensFlare/DirtMask.jpg"),starTexture:Dn("Assets/Textures/LensFlare/StarBurst.jpg"),intensity:2,distortion:10,ghostDispersal:.4,haloWidth:.4,dirtAmount:.4,earthRadius:mt.WGS84.maximumRadius}})};var IV=Zl;var uQo=b(W(),1);function UW(t){this._collection=t,this._framebuffers=[],this._stageNameToFramebuffer={},this._width=void 0,this._height=void 0,this._updateDependencies=!1}function f9(t){for(;c(t.length);)t=t.get(t.length-1);return t.name}function yat(t,e,n,i,o){if(!i.enabled||!i._isSupported(e))return o;let a=n[i.name]={};if(c(o)){let l=t.getStageByName(o);a[f9(l)]=!0}let s=i.uniforms;if(c(s)){let l=Object.getOwnPropertyNames(s),r=l.length;for(let d=0;d<r;++d){let m=s[l[d]];if(typeof m=="string"){let h=t.getStageByName(m);c(h)&&(a[f9(h)]=!0)}}}return i.name}function W9(t,e,n,i,o){if(c(i.enabled)&&!i.enabled||c(i._isSupported)&&!i._isSupported(e))return o;let a=o,s=!c(i.inputPreviousStageTexture)||i.inputPreviousStageTexture,l=o,r=i.length;for(let h=0;h<r;++h){let u=i.get(h);c(u.length)?l=W9(t,e,n,u,o):l=yat(t,e,n,u,o),s&&(o=l)}let d,m;if(s)for(d=1;d<r;++d)m=f9(i.get(d)),c(n[m])||(n[m]={}),n[m][a]=!0;else for(d=1;d<r;++d){m=f9(i.get(d));let h=n[m];for(let u=0;u<d;++u)h[f9(i.get(u))]=!0}return l}function jQe(t,e){let n={};if(c(t.ambientOcclusion)){let i=t.ambientOcclusion,o=t.bloom,a=t._tonemapping,s=t.fxaa,l=W9(t,e,n,i,void 0);l=W9(t,e,n,o,l),l=yat(t,e,n,a,l),l=W9(t,e,n,t,l),yat(t,e,n,s,l)}else W9(t,e,n,t,void 0);return n}function qQe(t,e,n){let o=t._collection.getStageByName(e),a=o._textureScale,s=o._forcePowerOfTwo,l=o._pixelFormat,r=o._pixelDatatype,d=o._clearColor,m,h,u=t._framebuffers,R=u.length;for(m=0;m<R;++m){if(h=u[m],a!==h.textureScale||s!==h.forcePowerOfTwo||l!==h.pixelFormat||r!==h.pixelDatatype||!v.equals(d,h.clearColor))continue;let V=h.stages,F=V.length,U=!1;for(let G=0;G<F;++G)if(n[V[G]]){U=!0;break}if(!U)break}return c(h)&&m<R?(h.stages.push(e),h):(h={textureScale:a,forcePowerOfTwo:s,pixelFormat:l,pixelDatatype:r,clearColor:d,stages:[e],buffer:new bo({pixelFormat:l,pixelDatatype:r}),clear:void 0},u.push(h),h)}function $Qe(t,e){let n=jQe(t._collection,e);for(let i in n)n.hasOwnProperty(i)&&(t._stageNameToFramebuffer[i]=qQe(t,i,n[i]))}function Bat(t){let e=t._framebuffers,n=e.length;for(let i=0;i<n;++i)e[i].buffer.destroy()}function tke(t,e){let n=t._width,i=t._height,o=t._framebuffers,a=o.length;for(let s=0;s<a;++s){let l=o[s],r=l.textureScale,d=Math.ceil(n*r),m=Math.ceil(i*r),h=Math.min(d,m);l.forcePowerOfTwo&&(k.isPowerOfTwo(h)||(h=k.nextPowerOfTwo(h)),d=h,m=h),l.buffer.update(e,d,m),l.clear=new ao({color:l.clearColor,framebuffer:l.buffer.framebuffer})}}UW.prototype.updateDependencies=function(){this._updateDependencies=!0};UW.prototype.update=function(t){let e=this._collection,n=this._updateDependencies,i=c(e.ambientOcclusion)&&e.ambientOcclusion.enabled&&e.ambientOcclusion._isSupported(t),o=c(e.bloom)&&e.bloom.enabled&&e.bloom._isSupported(t),a=c(e._tonemapping)&&e._tonemapping.enabled&&e._tonemapping._isSupported(t),s=c(e.fxaa)&&e.fxaa.enabled&&e.fxaa._isSupported(t),l=!c(e._activeStages)||e._activeStages.length>0||i||o||a||s;if((n||!l&&this._framebuffers.length>0)&&(Bat(this),this._framebuffers.length=0,this._stageNameToFramebuffer={},this._width=void 0,this._height=void 0),!n&&!l)return;this._framebuffers.length===0&&$Qe(this,t);let r=t.drawingBufferWidth,d=t.drawingBufferHeight,m=this._width!==r||this._height!==d;!n&&!m||(this._width=r,this._height=d,this._updateDependencies=!1,Bat(this),tke(this,t))};UW.prototype.clear=function(t){let e=this._framebuffers;for(let n=0;n<e.length;++n)e[n].clear.execute(t)};UW.prototype.getStageByName=function(t){return this._collection.getStageByName(t)};UW.prototype.getOutputTexture=function(t){return this._collection.getOutputTexture(t)};UW.prototype.getFramebuffer=function(t){let e=this._stageNameToFramebuffer[t];if(c(e))return e.buffer.framebuffer};UW.prototype.isDestroyed=function(){return!1};UW.prototype.destroy=function(){return Bat(this),At(this)};var ET=UW;var RQo=b(W(),1),F9={REINHARD:0,MODIFIED_REINHARD:1,FILMIC:2,ACES:3,validate:function(t){return t===F9.REINHARD||t===F9.MODIFIED_REINHARD||t===F9.FILMIC||t===F9.ACES}},FU=Object.freeze(F9);var Qat=[];function im(){let t=IV.createFXAAStage(),e=IV.createAmbientOcclusionStage(),n=IV.createBloomStage();this._autoExposureEnabled=!1,this._autoExposure=IV.createAutoExposureStage(),this._tonemapping=void 0,this._tonemapper=void 0,this.tonemapper=FU.ACES;let i=this._tonemapping;t.enabled=!1,e.enabled=!1,n.enabled=!1,i.enabled=!1;let o=new ET(this),a={},s=Qat;for(s.push(t,e,n,i);s.length>0;){let r=s.pop();a[r.name]=r,r._textureCache=o;let d=r.length;if(c(d))for(let m=0;m<d;++m)s.push(r.get(m))}this._stages=[],this._activeStages=[],this._previousActiveStages=[],this._randomTexture=void 0;let l=this;e.uniforms.randomTexture=function(){return l._randomTexture},this._ao=e,this._bloom=n,this._fxaa=t,this._aoEnabled=void 0,this._bloomEnabled=void 0,this._tonemappingEnabled=void 0,this._fxaaEnabled=void 0,this._activeStagesChanged=!1,this._stagesRemoved=!1,this._textureCacheDirty=!1,this._stageNames=a,this._textureCache=o}Object.defineProperties(im.prototype,{ready:{get:function(){let t=!1,e=this._stages,n=e.length;for(let l=n-1;l>=0;--l){let r=e[l];t=t||r.ready&&r.enabled}let i=this._fxaa,o=this._ao,a=this._bloom,s=this._tonemapping;return t=t||i.ready&&i.enabled,t=t||o.ready&&o.enabled,t=t||a.ready&&a.enabled,t=t||s.ready&&s.enabled,t}},fxaa:{get:function(){return this._fxaa}},ambientOcclusion:{get:function(){return this._ao}},bloom:{get:function(){return this._bloom}},length:{get:function(){return kat(this),this._stages.length}},outputTexture:{get:function(){let t=this._fxaa;if(t.enabled&&t.ready)return this.getOutputTexture(t.name);let e=this._stages,n=e.length;for(let s=n-1;s>=0;--s){let l=e[s];if(c(l)&&l.ready&&l.enabled)return this.getOutputTexture(l.name)}let i=this._tonemapping;if(i.enabled&&i.ready)return this.getOutputTexture(i.name);let o=this._bloom;if(o.enabled&&o.ready)return this.getOutputTexture(o.name);let a=this._ao;if(a.enabled&&a.ready)return this.getOutputTexture(a.name)}},hasSelected:{get:function(){let t=this._stages.slice();for(;t.length>0;){let e=t.pop();if(!c(e))continue;if(c(e.selected))return!0;let n=e.length;if(c(n))for(let i=0;i<n;++i)t.push(e.get(i))}return!1}},tonemapper:{get:function(){return this._tonemapper},set:function(t){if(this._tonemapper===t)return;c(this._tonemapping)&&(delete this._stageNames[this._tonemapping.name],this._tonemapping.destroy());let e=this._autoExposureEnabled,n;switch(t){case FU.REINHARD:n=IV.createReinhardTonemappingStage(e);break;case FU.MODIFIED_REINHARD:n=IV.createModifiedReinhardTonemappingStage(e);break;case FU.FILMIC:n=IV.createFilmicTonemappingStage(e);break;default:n=IV.createAcesTonemappingStage(e);break}if(e){let i=this._autoExposure;n.uniforms.autoExposure=function(){return i.outputTexture}}this._tonemapper=t,this._tonemapping=n,c(this._stageNames)&&(this._stageNames[n.name]=n,n._textureCache=this._textureCache),this._textureCacheDirty=!0}}});function kat(t){if(!t._stagesRemoved)return;t._stagesRemoved=!1;let e=[],n=t._stages,i=n.length;for(let o=0,a=0;o<i;++o){let s=n[o];s&&(s._index=a++,e.push(s))}t._stages=e}im.prototype.add=function(t){let e=this._stageNames,n=Qat;for(n.push(t);n.length>0;){let o=n.pop();e[o.name]=o,o._textureCache=this._textureCache;let a=o.length;if(c(a))for(let s=0;s<a;++s)n.push(o.get(s))}let i=this._stages;return t._index=i.length,i.push(t),this._textureCacheDirty=!0,t};im.prototype.remove=function(t){if(!this.contains(t))return!1;let e=this._stageNames,n=Qat;for(n.push(t);n.length>0;){let i=n.pop();delete e[i.name];let o=i.length;if(c(o))for(let a=0;a<o;++a)n.push(i.get(a))}return this._stages[t._index]=void 0,this._stagesRemoved=!0,this._textureCacheDirty=!0,t._index=void 0,t._textureCache=void 0,t.destroy(),!0};im.prototype.contains=function(t){return c(t)&&c(t._index)&&t._textureCache===this._textureCache};im.prototype.get=function(t){return kat(this),this._stages[t]};im.prototype.removeAll=function(){let t=this._stages,e=t.length;for(let n=0;n<e;++n)this.remove(t[n]);t.length=0};im.prototype.getStageByName=function(t){return this._stageNames[t]};im.prototype.update=function(t,e,n){kat(this);let i=this._activeStages,o=this._activeStages=this._previousActiveStages;this._previousActiveStages=i;let a=this._stages,s=o.length=a.length,l,r,d=0;for(l=0;l<s;++l)r=a[l],r.ready&&r.enabled&&r._isSupported(t)&&(o[d++]=r);o.length=d;let m=d!==i.length;if(!m){for(l=0;l<d;++l)if(o[l]!==i[l]){m=!0;break}}let h=this._ao,u=this._bloom,R=this._autoExposure,V=this._tonemapping,F=this._fxaa;V.enabled=n;let U=h.enabled&&h._isSupported(t),G=u.enabled&&u._isSupported(t),A=V.enabled&&V._isSupported(t),S=F.enabled&&F._isSupported(t);if((m||this._textureCacheDirty||U!==this._aoEnabled||G!==this._bloomEnabled||A!==this._tonemappingEnabled||S!==this._fxaaEnabled)&&(this._textureCache.updateDependencies(),this._aoEnabled=U,this._bloomEnabled=G,this._tonemappingEnabled=A,this._fxaaEnabled=S,this._textureCacheDirty=!1),c(this._randomTexture)&&!U&&(this._randomTexture.destroy(),this._randomTexture=void 0),!c(this._randomTexture)&&U){s=256*256*3;let g=new Uint8Array(s);for(l=0;l<s;l+=3)g[l]=Math.floor(Math.random()*255);this._randomTexture=new hn({context:t,pixelFormat:Ye.RGB,pixelDatatype:Ue.UNSIGNED_BYTE,source:{arrayBufferView:g,width:256,height:256},sampler:new Hn({wrapS:Zi.REPEAT,wrapT:Zi.REPEAT,minificationFilter:On.NEAREST,magnificationFilter:Ro.NEAREST})})}for(this._textureCache.update(t),F.update(t,e),h.update(t,e),u.update(t,e),V.update(t,e),this._autoExposureEnabled&&R.update(t,e),s=a.length,l=0;l<s;++l)a[l].update(t,e);for(d=0,l=0;l<s;++l)r=a[l],r.ready&&r.enabled&&r._isSupported(t)&&d++;m=d!==o.length,m&&this.update(t,e,n)};im.prototype.clear=function(t){this._textureCache.clear(t),this._autoExposureEnabled&&this._autoExposure.clear(t)};function CT(t){for(;c(t.length);)t=t.get(t.length-1);return t.outputTexture}im.prototype.getOutputTexture=function(t){let e=this.getStageByName(t);if(c(e))return CT(e)};function wR(t,e,n,i,o){if(c(t.execute)){t.execute(e,n,i,o);return}let a=t.length,s;if(t.inputPreviousStageTexture)for(wR(t.get(0),e,n,i,o),s=1;s<a;++s)wR(t.get(s),e,CT(t.get(s-1)),i,o);else for(s=0;s<a;++s)wR(t.get(s),e,n,i,o)}im.prototype.execute=function(t,e,n,i){let o=this._activeStages,a=o.length,s=this._fxaa,l=this._ao,r=this._bloom,d=this._autoExposure,m=this._tonemapping,h=l.enabled&&l._isSupported(t),u=r.enabled&&r._isSupported(t),R=this._autoExposureEnabled,V=m.enabled&&m._isSupported(t),F=s.enabled&&s._isSupported(t);if(!F&&!h&&!u&&!V&&a===0)return;let U=e;h&&l.ready&&(wR(l,t,U,n,i),U=CT(l)),u&&r.ready&&(wR(r,t,U,n,i),U=CT(r)),R&&d.ready&&wR(d,t,U,n,i),V&&m.ready&&(wR(m,t,U,n,i),U=CT(m));let G=U;if(a>0){wR(o[0],t,U,n,i);for(let A=1;A<a;++A)wR(o[A],t,CT(o[A-1]),n,i);G=CT(o[a-1])}F&&s.ready&&wR(s,t,G,n,i)};im.prototype.copy=function(t,e){if(!c(this._copyColorCommand)){let n=this;this._copyColorCommand=t.createViewportQuadCommand(nh,{uniformMap:{colorTexture:function(){return n.outputTexture}},owner:this})}this._copyColorCommand.framebuffer=e,this._copyColorCommand.execute(t)};im.prototype.isDestroyed=function(){return!1};im.prototype.destroy=function(){return this._fxaa.destroy(),this._ao.destroy(),this._bloom.destroy(),this._autoExposure.destroy(),this._tonemapping.destroy(),this.removeAll(),this._textureCache=this._textureCache&&this._textureCache.destroy(),At(this)};var U9=im;var mko=b(W(),1);var PQo=b(W(),1);var QQo=b(W(),1),eke={SHIFT:0,CTRL:1,ALT:2},id=Object.freeze(eke);var YQo=b(W(),1),nke={LEFT_DOWN:0,LEFT_UP:1,LEFT_CLICK:2,LEFT_DOUBLE_CLICK:3,RIGHT_DOWN:5,RIGHT_UP:6,RIGHT_CLICK:7,MIDDLE_DOWN:10,MIDDLE_UP:11,MIDDLE_CLICK:12,MOUSE_MOVE:15,WHEEL:16,PINCH_START:17,PINCH_END:18,PINCH_MOVE:19},ui=Object.freeze(nke);function UU(t,e,n){let i=t._element;if(i===document)return n.x=e.clientX,n.y=e.clientY,n;let o=i.getBoundingClientRect();return n.x=e.clientX-o.left,n.y=e.clientY-o.top,n}function Mat(t,e){let n=t;return c(e)&&(n+=`+${e}`),n}function IT(t){if(t.shiftKey)return id.SHIFT;if(t.ctrlKey)return id.CTRL;if(t.altKey)return id.ALT}var cr={LEFT:0,MIDDLE:1,RIGHT:2};function ap(t,e,n,i){function o(a){i(t,a)}In.isInternetExplorer()?n.addEventListener(e,o,!1):n.addEventListener(e,o,{capture:!1,passive:!1}),t._removalFunctions.push(function(){n.removeEventListener(e,o,!1)})}function ike(t){let e=t._element,n=c(e.disableRootEvents)?e:document;In.supportsPointerEvents()?(ap(t,"pointerdown",e,dke),ap(t,"pointerup",e,RBt),ap(t,"pointermove",e,cke),ap(t,"pointercancel",e,RBt)):(ap(t,"mousedown",e,bBt),ap(t,"mouseup",n,WBt),ap(t,"mousemove",n,fBt),ap(t,"touchstart",e,lke),ap(t,"touchend",n,hBt),ap(t,"touchmove",n,rke),ap(t,"touchcancel",n,hBt)),ap(t,"dblclick",e,ake);let i;"onwheel"in e?i="wheel":document.onmousewheel!==void 0?i="mousewheel":i="DOMMouseScroll",ap(t,i,e,ske)}function oke(t){let e=t._removalFunctions;for(let n=0;n<e.length;++n)e[n]()}var rBt={position:new K};function _at(t){t._lastSeenTouchEvent=Oi()}function Dat(t){return Oi()-t._lastSeenTouchEvent>cZ.mouseEmulationIgnoreMilliseconds}function Lat(t,e,n){let i=t.x-e.x,o=t.y-e.y;return Math.sqrt(i*i+o*o)<n}function bBt(t,e){if(!Dat(t))return;let n=e.button;t._buttonDown[n]=!0;let i;if(n===cr.LEFT)i=ui.LEFT_DOWN;else if(n===cr.MIDDLE)i=ui.MIDDLE_DOWN;else if(n===cr.RIGHT)i=ui.RIGHT_DOWN;else return;let o=UU(t,e,t._primaryPosition);K.clone(o,t._primaryStartPosition),K.clone(o,t._primaryPreviousPosition);let a=IT(e),s=t.getInputAction(i,a);c(s)&&(K.clone(o,rBt.position),s(rBt),e.preventDefault())}var dBt={position:new K},cBt={position:new K};function Yat(t,e,n,i){let o=IT(i),a=t.getInputAction(e,o),s=t.getInputAction(n,o);if(c(a)||c(s)){let l=UU(t,i,t._primaryPosition);if(c(a)&&(K.clone(l,dBt.position),a(dBt)),c(s)){let r=t._primaryStartPosition;Lat(r,l,t._clickPixelTolerance)&&(K.clone(l,cBt.position),s(cBt))}}}function WBt(t,e){if(!Dat(t))return;let n=e.button;n!==cr.LEFT&&n!==cr.MIDDLE&&n!==cr.RIGHT||(t._buttonDown[cr.LEFT]&&(Yat(t,ui.LEFT_UP,ui.LEFT_CLICK,e),t._buttonDown[cr.LEFT]=!1),t._buttonDown[cr.MIDDLE]&&(Yat(t,ui.MIDDLE_UP,ui.MIDDLE_CLICK,e),t._buttonDown[cr.MIDDLE]=!1),t._buttonDown[cr.RIGHT]&&(Yat(t,ui.RIGHT_UP,ui.RIGHT_CLICK,e),t._buttonDown[cr.RIGHT]=!1))}var xat={startPosition:new K,endPosition:new K};function fBt(t,e){if(!Dat(t))return;let n=IT(e),i=UU(t,e,t._primaryPosition),o=t._primaryPreviousPosition,a=t.getInputAction(ui.MOUSE_MOVE,n);c(a)&&(K.clone(o,xat.startPosition),K.clone(i,xat.endPosition),a(xat)),K.clone(i,o),(t._buttonDown[cr.LEFT]||t._buttonDown[cr.MIDDLE]||t._buttonDown[cr.RIGHT])&&e.preventDefault()}var mBt={position:new K};function ake(t,e){let n=e.button,i;if(n===cr.LEFT)i=ui.LEFT_DOUBLE_CLICK;else return;let o=IT(e),a=t.getInputAction(i,o);c(a)&&(UU(t,e,mBt.position),a(mBt))}function ske(t,e){let n;if(c(e.deltaY)){let a=e.deltaMode;a===e.DOM_DELTA_PIXEL?n=-e.deltaY:a===e.DOM_DELTA_LINE?n=-e.deltaY*40:n=-e.deltaY*120}else e.detail>0?n=e.detail*-120:n=e.wheelDelta;if(!c(n))return;let i=IT(e),o=t.getInputAction(ui.WHEEL,i);c(o)&&(o(n),e.preventDefault())}function lke(t,e){_at(t);let n=e.changedTouches,i,o=n.length,a,s,l=t._positions;for(i=0;i<o;++i)a=n[i],s=a.identifier,l.set(s,UU(t,a,new K));Vj(t,e);let r=t._previousPositions;for(i=0;i<o;++i)a=n[i],s=a.identifier,r.set(s,K.clone(l.get(s)))}function hBt(t,e){_at(t);let n=e.changedTouches,i,o=n.length,a,s,l=t._positions;for(i=0;i<o;++i)a=n[i],s=a.identifier,l.remove(s);Vj(t,e);let r=t._previousPositions;for(i=0;i<o;++i)a=n[i],s=a.identifier,r.remove(s)}var pBt={position:new K},Xat={position1:new K,position2:new K},VBt={position:new K},uBt={position:new K},ZBt={position:new K};function Vj(t,e){let n=IT(e),i=t._positions,o=i.length,a,s,l=t._isPinching;if(o!==1&&t._buttonDown[cr.LEFT]){if(t._buttonDown[cr.LEFT]=!1,c(t._touchHoldTimer)&&(clearTimeout(t._touchHoldTimer),t._touchHoldTimer=void 0),a=t.getInputAction(ui.LEFT_UP,n),c(a)&&(K.clone(t._primaryPosition,VBt.position),a(VBt)),o===0&&!t._isTouchHolding&&(s=t.getInputAction(ui.LEFT_CLICK,n),c(s))){let r=t._primaryStartPosition,d=t._previousPositions.values[0];Lat(r,d,t._clickPixelTolerance)&&(K.clone(t._primaryPosition,uBt.position),s(uBt))}t._isTouchHolding=!1}if(o===0&&l&&(t._isPinching=!1,a=t.getInputAction(ui.PINCH_END,n),c(a)&&a()),o===1&&!l){let r=i.values[0];K.clone(r,t._primaryPosition),K.clone(r,t._primaryStartPosition),K.clone(r,t._primaryPreviousPosition),t._buttonDown[cr.LEFT]=!0,a=t.getInputAction(ui.LEFT_DOWN,n),c(a)&&(K.clone(r,pBt.position),a(pBt)),t._touchHoldTimer=setTimeout(function(){if(!t.isDestroyed()&&(t._touchHoldTimer=void 0,t._isTouchHolding=!0,s=t.getInputAction(ui.RIGHT_CLICK,n),c(s))){let d=t._primaryStartPosition,m=t._previousPositions.values[0];Lat(d,m,t._holdPixelTolerance)&&(K.clone(t._primaryPosition,ZBt.position),s(ZBt))}},cZ.touchHoldDelayMilliseconds),e.preventDefault()}o===2&&!l&&(t._isPinching=!0,a=t.getInputAction(ui.PINCH_START,n),c(a)&&(K.clone(i.values[0],Xat.position1),K.clone(i.values[1],Xat.position2),a(Xat),e.preventDefault()))}function rke(t,e){_at(t);let n=e.changedTouches,i,o=n.length,a,s,l=t._positions;for(i=0;i<o;++i){a=n[i],s=a.identifier;let d=l.get(s);c(d)&&UU(t,a,d)}FBt(t,e);let r=t._previousPositions;for(i=0;i<o;++i)a=n[i],s=a.identifier,K.clone(l.get(s),r.get(s))}var Jat={startPosition:new K,endPosition:new K},G9={distance:{startPosition:new K,endPosition:new K},angleAndHeight:{startPosition:new K,endPosition:new K}};function FBt(t,e){let n=IT(e),i=t._positions,o=t._previousPositions,a=i.length,s;if(a===1&&t._buttonDown[cr.LEFT]){let l=i.values[0];K.clone(l,t._primaryPosition);let r=t._primaryPreviousPosition;s=t.getInputAction(ui.MOUSE_MOVE,n),c(s)&&(K.clone(r,Jat.startPosition),K.clone(l,Jat.endPosition),s(Jat)),K.clone(l,r),e.preventDefault()}else if(a===2&&t._isPinching&&(s=t.getInputAction(ui.PINCH_MOVE,n),c(s))){let l=i.values[0],r=i.values[1],d=o.values[0],m=o.values[1],h=r.x-l.x,u=r.y-l.y,R=Math.sqrt(h*h+u*u)*.25,V=m.x-d.x,F=m.y-d.y,U=Math.sqrt(V*V+F*F)*.25,G=(r.y+l.y)*.125,A=(m.y+d.y)*.125,S=Math.atan2(u,h),g=Math.atan2(F,V);K.fromElements(0,U,G9.distance.startPosition),K.fromElements(0,R,G9.distance.endPosition),K.fromElements(g,A,G9.angleAndHeight.startPosition),K.fromElements(S,G,G9.angleAndHeight.endPosition),s(G9)}}function dke(t,e){if(e.target.setPointerCapture(e.pointerId),e.pointerType==="touch"){let n=t._positions,i=e.pointerId;n.set(i,UU(t,e,new K)),Vj(t,e),t._previousPositions.set(i,K.clone(n.get(i)))}else bBt(t,e)}function RBt(t,e){if(e.pointerType==="touch"){let n=t._positions,i=e.pointerId;n.remove(i),Vj(t,e),t._previousPositions.remove(i)}else WBt(t,e)}function cke(t,e){if(e.pointerType==="touch"){let n=t._positions,i=e.pointerId,o=n.get(i);if(!c(o))return;UU(t,e,o),FBt(t,e);let a=t._previousPositions;K.clone(n.get(i),a.get(i))}else fBt(t,e)}function cZ(t){this._inputEvents={},this._buttonDown={LEFT:!1,MIDDLE:!1,RIGHT:!1},this._isPinching=!1,this._isTouchHolding=!1,this._lastSeenTouchEvent=-cZ.mouseEmulationIgnoreMilliseconds,this._primaryStartPosition=new K,this._primaryPosition=new K,this._primaryPreviousPosition=new K,this._positions=new qe,this._previousPositions=new qe,this._removalFunctions=[],this._touchHoldTimer=void 0,this._clickPixelTolerance=5,this._holdPixelTolerance=25,this._element=f(t,document),ike(this)}cZ.prototype.setInputAction=function(t,e,n){let i=Mat(e,n);this._inputEvents[i]=t};cZ.prototype.getInputAction=function(t,e){let n=Mat(t,e);return this._inputEvents[n]};cZ.prototype.removeInputAction=function(t,e){let n=Mat(t,e);delete this._inputEvents[n]};cZ.prototype.isDestroyed=function(){return!1};cZ.prototype.destroy=function(){return oke(this),At(this)};cZ.mouseEmulationIgnoreMilliseconds=800;cZ.touchHoldDelayMilliseconds=1500;var sp=cZ;function NT(t){this._scene=t,this._currentTweens=[],this._morphHandler=void 0,this._morphCancelled=!1,this._completeMorph=void 0,this._morphToOrthographic=!1}NT.prototype.completeMorph=function(){c(this._completeMorph)&&this._completeMorph()};NT.prototype.morphTo2D=function(t,e){c(this._completeMorph)&&this._completeMorph();let n=this._scene;this._previousMode=n.mode,this._morphToOrthographic=n.camera.frustum instanceof wn,!(this._previousMode===Vt.SCENE2D||this._previousMode===Vt.MORPHING)&&(this._scene.morphStart.raiseEvent(this,this._previousMode,Vt.SCENE2D,!0),n._mode=Vt.MORPHING,n.camera._setTransform(L.IDENTITY),this._previousMode===Vt.COLUMBUS_VIEW?Dke(this,t):zke(this,t,e),t===0&&c(this._completeMorph)&&this._completeMorph())};var mke=new p,hke=new p,pke=new p,Vke=new p,uke=new p,Zke=new p,Rke=new p,bke=new gt,Wke=new L,fke=new Io,Fke=new wn,Uke={position:void 0,direction:void 0,up:void 0,position2D:void 0,direction2D:void 0,up2D:void 0,frustum:void 0};NT.prototype.morphToColumbusView=function(t,e){c(this._completeMorph)&&this._completeMorph();let n=this._scene;if(this._previousMode=n.mode,this._previousMode===Vt.COLUMBUS_VIEW||this._previousMode===Vt.MORPHING)return;this._scene.morphStart.raiseEvent(this,this._previousMode,Vt.COLUMBUS_VIEW,!0),n.camera._setTransform(L.IDENTITY);let i=mke,o=hke,a=pke;if(t>0)i.x=0,i.y=-1,i.z=1,i=p.multiplyByScalar(p.normalize(i,i),5*e.maximumRadius,i),p.negate(p.normalize(i,o),o),p.cross(p.UNIT_X,o,a);else{let d=n.camera;if(this._previousMode===Vt.SCENE2D)p.clone(d.position,i),i.z=d.frustum.right-d.frustum.left,p.negate(p.UNIT_Z,o),p.clone(p.UNIT_Y,a);else{p.clone(d.positionWC,i),p.clone(d.directionWC,o),p.clone(d.upWC,a);let m=e.scaleToGeodeticSurface(i,Rke),h=Pe.eastNorthUpToFixedFrame(m,e,Wke);L.inverseTransformation(h,h),n.mapProjection.project(e.cartesianToCartographic(i,bke),i),L.multiplyByPointAsVector(h,o,o),L.multiplyByPointAsVector(h,a,a)}}let s;this._morphToOrthographic?(s=Fke,s.width=n.camera.frustum.right-n.camera.frustum.left,s.aspectRatio=n.drawingBufferWidth/n.drawingBufferHeight):(s=fke,s.aspectRatio=n.drawingBufferWidth/n.drawingBufferHeight,s.fov=k.toRadians(60));let l=Uke;l.position=i,l.direction=o,l.up=a,l.frustum=s;let r=qke(l);A9(this,r),this._previousMode===Vt.SCENE2D?jke(this,t,l,r):(l.position2D=L.multiplyByPoint(Aa.TRANSFORM_2D,i,Vke),l.direction2D=L.multiplyByPointAsVector(Aa.TRANSFORM_2D,o,uke),l.up2D=L.multiplyByPointAsVector(Aa.TRANSFORM_2D,a,Zke),n._mode=Vt.MORPHING,yBt(this,t,l,r)),t===0&&c(this._completeMorph)&&this._completeMorph()};var wat={position:new p,direction:new p,up:new p,frustum:void 0},GBt=new Io;NT.prototype.morphTo3D=function(t,e){c(this._completeMorph)&&this._completeMorph();let n=this._scene;if(this._previousMode=n.mode,!(this._previousMode===Vt.SCENE3D||this._previousMode===Vt.MORPHING)){if(this._scene.morphStart.raiseEvent(this,this._previousMode,Vt.SCENE3D,!0),n._mode=Vt.MORPHING,n.camera._setTransform(L.IDENTITY),this._previousMode===Vt.SCENE2D)Bke(this,t,e);else{let i;t>0?(i=wat,p.fromDegrees(0,0,5*e.maximumRadius,e,i.position),p.negate(i.position,i.direction),p.normalize(i.direction,i.direction),p.clone(p.UNIT_Z,i.up)):i=ABt(this,e);let o,a=n.camera;a.frustum instanceof wn?o=a.frustum.clone():(o=GBt,o.aspectRatio=n.drawingBufferWidth/n.drawingBufferHeight,o.fov=k.toRadians(60)),i.frustum=o;let s=QBt(i);A9(this,s),Hat(this,t,i,s)}t===0&&c(this._completeMorph)&&this._completeMorph()}};NT.prototype.isDestroyed=function(){return!1};NT.prototype.destroy=function(){return uj(this),At(this)};function A9(t,e){if(t._scene.completeMorphOnUserInput){t._morphHandler=new sp(t._scene.canvas);let n=function(){t._morphCancelled=!0,t._scene.camera.cancelFlight(),e(t)};t._completeMorph=n,t._morphHandler.setInputAction(n,ui.LEFT_DOWN),t._morphHandler.setInputAction(n,ui.MIDDLE_DOWN),t._morphHandler.setInputAction(n,ui.RIGHT_DOWN),t._morphHandler.setInputAction(n,ui.WHEEL)}}function uj(t){let e=t._currentTweens;for(let n=0;n<e.length;++n)e[n].cancelTween();t._currentTweens.length=0,t._morphHandler=t._morphHandler&&t._morphHandler.destroy()}var Gke=new gt,Ake=new p,Ske=new L;function ABt(t,e){let n=t._scene,i=n.camera,o=wat,a=o.position,s=o.direction,l=o.up,r=n.mapProjection.unproject(i.position,Gke);e.cartographicToCartesian(r,a);let d=e.scaleToGeodeticSurface(a,Ake),m=Pe.eastNorthUpToFixedFrame(d,e,Ske);return L.multiplyByPointAsVector(m,i.direction,s),L.multiplyByPointAsVector(m,i.up,l),o}var Tke=new p,gke=new p,Eke=new p,Cke=new p,Ike=new p,Nke=new p;function Hat(t,e,n,i){e*=.5;let o=t._scene,a=o.camera,s=p.clone(a.position,Tke),l=p.clone(a.direction,gke),r=p.clone(a.up,Eke),d=L.multiplyByPoint(Aa.TRANSFORM_2D_INVERSE,n.position,Cke),m=L.multiplyByPointAsVector(Aa.TRANSFORM_2D_INVERSE,n.direction,Ike),h=L.multiplyByPointAsVector(Aa.TRANSFORM_2D_INVERSE,n.up,Nke);function u(V){NV(s,d,V.time,a.position),NV(l,m,V.time,a.direction),NV(r,h,V.time,a.up),p.cross(a.direction,a.up,a.right),p.normalize(a.right,a.right)}let R=o.tweens.add({duration:e,easingFunction:ul.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:u,complete:function(){BBt(t,o,0,1,e,i)}});t._currentTweens.push(R)}var yke=new wn,SBt=new p,TBt=new p,gBt=new p,Pat=new p,EBt=new p,CBt=new p;function Bke(t,e,n){e/=3;let i=t._scene,o=i.camera,a;e>0?(a=wat,p.fromDegrees(0,0,5*n.maximumRadius,n,a.position),p.negate(a.position,a.direction),p.normalize(a.direction,a.direction),p.clone(p.UNIT_Z,a.up)):(o.position.z=o.frustum.right-o.frustum.left,a=ABt(t,n));let s;t._morphToOrthographic?(s=yke,s.aspectRatio=i.drawingBufferWidth/i.drawingBufferHeight,s.width=o.frustum.right-o.frustum.left):(s=GBt,s.aspectRatio=i.drawingBufferWidth/i.drawingBufferHeight,s.fov=k.toRadians(60)),a.frustum=s;let l=QBt(a);A9(t,l);let r;t._morphToOrthographic?r=function(){Hat(t,e,a,l)}:r=function(){NBt(t,e,a,function(){Hat(t,e,a,l)})},e>0?(i._mode=Vt.SCENE2D,o.flyTo({duration:e,destination:p.fromDegrees(0,0,5*n.maximumRadius,n,Pat),complete:function(){i._mode=Vt.MORPHING,r()}})):r()}function NV(t,e,n,i){return p.lerp(t,e,n,i)}function IBt(t,e,n,i,o){let a=t._scene,s=a.camera;if(s.frustum instanceof wn)return;let l=s.frustum.fov,r=k.RADIANS_PER_DEGREE*.5,d=n.position.z*Math.tan(l*.5);s.frustum.far=d/Math.tan(r*.5)+1e7;function m(u){s.frustum.fov=k.lerp(l,r,u.time);let R=d/Math.tan(s.frustum.fov*.5);i(s,R)}let h=a.tweens.add({duration:e,easingFunction:ul.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:m,complete:function(){s.frustum=n.frustum.clone(),o(t)}});t._currentTweens.push(h)}var Qke=new p,kke=new p,Yke=new p,Oat=new p,xke=new p,Xke=new p,Jke=new el,Lke=new di,Mke=new p,_ke={position:void 0,direction:void 0,up:void 0,frustum:void 0};function Dke(t,e){e*=.5;let n=t._scene,i=n.camera,o=p.clone(i.position,Qke),a=p.clone(i.direction,kke),s=p.clone(i.up,Yke),l=p.negate(p.UNIT_Z,xke),r=p.clone(p.UNIT_Y,Xke),d=Oat;if(e>0)p.clone(p.ZERO,Oat),d.z=5*n.mapProjection.ellipsoid.maximumRadius;else{p.clone(o,Oat);let U=Lke;L.multiplyByPoint(Aa.TRANSFORM_2D,o,U.origin),L.multiplyByPointAsVector(Aa.TRANSFORM_2D,a,U.direction);let G=n.globe;if(c(G)){let A=G.pickWorldCoordinates(U,n,!0,Mke);c(A)&&(L.multiplyByPoint(Aa.TRANSFORM_2D_INVERSE,A,d),d.z+=p.distance(o,d))}}let m=Jke;m.right=d.z*.5,m.left=-m.right,m.top=m.right*(n.drawingBufferHeight/n.drawingBufferWidth),m.bottom=-m.top;let h=_ke;h.position=d,h.direction=l,h.up=r,h.frustum=m;let u=kBt(h);A9(t,u);function R(U){NV(o,d,U.time,i.position),NV(a,l,U.time,i.direction),NV(s,r,U.time,i.up),p.cross(i.direction,i.up,i.right),p.normalize(i.right,i.right),i._adjustOrthographicFrustum(!0)}function V(U,G){U.position.z=G}let F=n.tweens.add({duration:e,easingFunction:ul.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:R,complete:function(){IBt(t,e,h,V,u)}});t._currentTweens.push(F)}var UBt=new gt,Oke={position:new p,direction:new p,up:new p,position2D:new p,direction2D:new p,up2D:new p,frustum:new el},Hke={position:new p,direction:new p,up:new p,frustum:void 0},wke=new p,Pke=new di,vke=new L,Kke=new p;function zke(t,e,n){e*=.5;let i=t._scene,o=i.camera,a=Oke;if(e>0)p.clone(p.ZERO,a.position),a.position.z=5*n.maximumRadius,p.negate(p.UNIT_Z,a.direction),p.clone(p.UNIT_Y,a.up);else{n.cartesianToCartographic(o.positionWC,UBt),i.mapProjection.project(UBt,a.position),p.negate(p.UNIT_Z,a.direction),p.clone(p.UNIT_Y,a.up);let h=Pke;p.clone(a.position2D,h.origin);let u=p.clone(o.directionWC,h.direction),R=n.scaleToGeodeticSurface(o.positionWC,Kke),V=Pe.eastNorthUpToFixedFrame(R,n,vke);L.inverseTransformation(V,V),L.multiplyByPointAsVector(V,u,u),L.multiplyByPointAsVector(Aa.TRANSFORM_2D,u,u);let F=i.globe;if(c(F)){let U=F.pickWorldCoordinates(h,i,!0,wke);if(c(U)){let G=p.distance(a.position2D,U);U.x+=G,p.clone(U,a.position2D)}}}function s(h,u){h.position.x=u}L.multiplyByPoint(Aa.TRANSFORM_2D,a.position,a.position2D),L.multiplyByPointAsVector(Aa.TRANSFORM_2D,a.direction,a.direction2D),L.multiplyByPointAsVector(Aa.TRANSFORM_2D,a.up,a.up2D);let l=a.frustum;l.right=a.position.z*.5,l.left=-l.right,l.top=l.right*(i.drawingBufferHeight/i.drawingBufferWidth),l.bottom=-l.top;let r=Hke;L.multiplyByPoint(Aa.TRANSFORM_2D_INVERSE,a.position2D,r.position),p.clone(a.direction,r.direction),p.clone(a.up,r.up),r.frustum=l;let d=kBt(r);A9(t,d);function m(){IBt(t,e,a,s,d)}yBt(t,e,a,m)}function NBt(t,e,n,i){let o=t._scene,a=o.camera,s=a.frustum.right-a.frustum.left;a.frustum=n.frustum.clone();let l=a.frustum.fov,r=k.RADIANS_PER_DEGREE*.5,d=s*Math.tan(l*.5);a.frustum.far=d/Math.tan(r*.5)+1e7,a.frustum.fov=r;function m(u){a.frustum.fov=k.lerp(r,l,u.time),a.position.z=d/Math.tan(a.frustum.fov*.5)}let h=o.tweens.add({duration:e,easingFunction:ul.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:m,complete:function(){i(t)}});t._currentTweens.push(h)}function jke(t,e,n,i){e*=.5;let o=t._scene,a=o.camera,s=p.clone(n.position,Pat),l=p.clone(n.direction,EBt),r=p.clone(n.up,CBt);o._mode=Vt.MORPHING;function d(){a.frustum=n.frustum.clone();let m=p.clone(a.position,SBt),h=p.clone(a.direction,TBt),u=p.clone(a.up,gBt);m.z=s.z;function R(F){NV(m,s,F.time,a.position),NV(h,l,F.time,a.direction),NV(u,r,F.time,a.up),p.cross(a.direction,a.up,a.right),p.normalize(a.right,a.right)}let V=o.tweens.add({duration:e,easingFunction:ul.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:R,complete:function(){i(t)}});t._currentTweens.push(V)}t._morphToOrthographic?d():NBt(t,0,n,d)}function yBt(t,e,n,i){let o=t._scene,a=o.camera,s=p.clone(a.position,SBt),l=p.clone(a.direction,TBt),r=p.clone(a.up,gBt),d=p.clone(n.position2D,Pat),m=p.clone(n.direction2D,EBt),h=p.clone(n.up2D,CBt);function u(V){NV(s,d,V.time,a.position),NV(l,m,V.time,a.direction),NV(r,h,V.time,a.up),p.cross(a.direction,a.up,a.right),p.normalize(a.right,a.right),a._adjustOrthographicFrustum(!0)}let R=o.tweens.add({duration:e,easingFunction:ul.QUARTIC_OUT,startObject:{time:0},stopObject:{time:1},update:u,complete:function(){BBt(t,o,1,0,e,i)}});t._currentTweens.push(R)}function BBt(t,e,n,i,o,a){let s={object:e,property:"morphTime",startValue:n,stopValue:i,duration:o,easingFunction:ul.QUARTIC_OUT};c(a)&&(s.complete=function(){a(t)});let l=e.tweens.addProperty(s);t._currentTweens.push(l)}function QBt(t){return function(e){let n=e._scene;n._mode=Vt.SCENE3D,n.morphTime=Vt.getMorphTime(Vt.SCENE3D),uj(e);let i=n.camera;(e._previousMode!==Vt.MORPHING||e._morphCancelled)&&(e._morphCancelled=!1,p.clone(t.position,i.position),p.clone(t.direction,i.direction),p.clone(t.up,i.up),p.cross(i.direction,i.up,i.right),p.normalize(i.right,i.right),i.frustum=t.frustum.clone());let o=i.frustum;n.frameState.useLogDepth&&(o.near=.1,o.far=1e10);let a=c(e._completeMorph);e._completeMorph=void 0,n.camera.update(n.mode),e._scene.morphComplete.raiseEvent(e,e._previousMode,Vt.SCENE3D,a)}}function kBt(t){return function(e){let n=e._scene;n._mode=Vt.SCENE2D,n.morphTime=Vt.getMorphTime(Vt.SCENE2D),uj(e);let i=n.camera;p.clone(t.position,i.position),i.position.z=n.mapProjection.ellipsoid.maximumRadius*2,p.clone(t.direction,i.direction),p.clone(t.up,i.up),p.cross(i.direction,i.up,i.right),p.normalize(i.right,i.right),i.frustum=t.frustum.clone();let o=c(e._completeMorph);e._completeMorph=void 0,n.camera.update(n.mode),e._scene.morphComplete.raiseEvent(e,e._previousMode,Vt.SCENE2D,o)}}function qke(t){return function(e){let n=e._scene;n._mode=Vt.COLUMBUS_VIEW,n.morphTime=Vt.getMorphTime(Vt.COLUMBUS_VIEW),uj(e);let i=n.camera;(e._previousModeMode!==Vt.MORPHING||e._morphCancelled)&&(e._morphCancelled=!1,p.clone(t.position,i.position),p.clone(t.direction,i.direction),p.clone(t.up,i.up),p.cross(i.direction,i.up,i.right),p.normalize(i.right,i.right));let o=i.frustum;n.frameState.useLogDepth&&(o.near=.1,o.far=1e10);let a=c(e._completeMorph);e._completeMorph=void 0,n.camera.update(n.mode),e._scene.morphComplete.raiseEvent(e,e._previousMode,Vt.COLUMBUS_VIEW,a)}}var S9=NT;var s2o=b(W(),1);var Gko=b(W(),1);var pko=b(W(),1),$ke={LEFT_DRAG:0,RIGHT_DRAG:1,MIDDLE_DRAG:2,WHEEL:3,PINCH:4},Mo=Object.freeze($ke);function pc(t,e){let n=t;return c(e)&&(n+=`+${e}`),n}function t2e(t,e){K.clone(t.distance.startPosition,e.distance.startPosition),K.clone(t.distance.endPosition,e.distance.endPosition),K.clone(t.angleAndHeight.startPosition,e.angleAndHeight.startPosition),K.clone(t.angleAndHeight.endPosition,e.angleAndHeight.endPosition)}function YBt(t,e,n){let i=pc(Mo.PINCH,e),o=t._update,a=t._isDown,s=t._eventStartPosition,l=t._pressTime,r=t._releaseTime;o[i]=!0,a[i]=!1,s[i]=new K;let d=t._movement[i];c(d)||(d=t._movement[i]={}),d.distance={startPosition:new K,endPosition:new K},d.angleAndHeight={startPosition:new K,endPosition:new K},d.prevAngle=0,t._eventHandler.setInputAction(function(m){t._buttonsDown++,a[i]=!0,l[i]=new Date,K.lerp(m.position1,m.position2,.5,s[i])},ui.PINCH_START,e),t._eventHandler.setInputAction(function(){t._buttonsDown=Math.max(t._buttonsDown-1,0),a[i]=!1,r[i]=new Date},ui.PINCH_END,e),t._eventHandler.setInputAction(function(m){if(a[i]){o[i]?(t2e(m,d),o[i]=!1,d.prevAngle=d.angleAndHeight.startPosition.x):(K.clone(m.distance.endPosition,d.distance.endPosition),K.clone(m.angleAndHeight.endPosition,d.angleAndHeight.endPosition));let h=d.angleAndHeight.endPosition.x,u=d.prevAngle,R=Math.PI*2;for(;h>=u+Math.PI;)h-=R;for(;h<u-Math.PI;)h+=R;d.angleAndHeight.endPosition.x=-h*n.clientWidth/12,d.angleAndHeight.startPosition.x=-u*n.clientWidth/12}},ui.PINCH_MOVE,e)}function xBt(t,e){let n=pc(Mo.WHEEL,e),i=t._pressTime,o=t._releaseTime,a=t._update;a[n]=!0;let s=t._movement[n];c(s)||(s=t._movement[n]={});let l=t._lastMovement[n];c(l)||(l=t._lastMovement[n]={startPosition:new K,endPosition:new K,valid:!1}),s.startPosition=new K,K.clone(K.ZERO,s.startPosition),s.endPosition=new K,t._eventHandler.setInputAction(function(r){let d=7.5*k.toRadians(r);i[n]=o[n]=new Date,s.endPosition.x=0,s.endPosition.y=d,K.clone(s.endPosition,l.endPosition),l.valid=!0,a[n]=!1},ui.WHEEL,e)}function H1(t,e,n){let i=pc(n,e),o=t._isDown,a=t._eventStartPosition,s=t._pressTime,l=t._releaseTime;o[i]=!1,a[i]=new K;let r=t._lastMovement[i];c(r)||(r=t._lastMovement[i]={startPosition:new K,endPosition:new K,valid:!1});let d,m;n===Mo.LEFT_DRAG?(d=ui.LEFT_DOWN,m=ui.LEFT_UP):n===Mo.RIGHT_DRAG?(d=ui.RIGHT_DOWN,m=ui.RIGHT_UP):n===Mo.MIDDLE_DRAG&&(d=ui.MIDDLE_DOWN,m=ui.MIDDLE_UP),t._eventHandler.setInputAction(function(h){t._buttonsDown++,r.valid=!1,o[i]=!0,s[i]=new Date,K.clone(h.position,a[i])},d,e),t._eventHandler.setInputAction(function(){t._buttonsDown=Math.max(t._buttonsDown-1,0),o[i]=!1,l[i]=new Date},m,e)}function XBt(t,e){K.clone(t.startPosition,e.startPosition),K.clone(t.endPosition,e.endPosition)}function JBt(t,e){let n=t._update,i=t._movement,o=t._lastMovement,a=t._isDown;for(let s in Mo)if(Mo.hasOwnProperty(s)){let l=Mo[s];if(c(l)){let r=pc(l,e);n[r]=!0,c(t._lastMovement[r])||(t._lastMovement[r]={startPosition:new K,endPosition:new K,valid:!1}),c(t._movement[r])||(t._movement[r]={startPosition:new K,endPosition:new K})}}t._eventHandler.setInputAction(function(s){for(let l in Mo)if(Mo.hasOwnProperty(l)){let r=Mo[l];if(c(r)){let d=pc(r,e);a[d]&&(n[d]?(XBt(i[d],o[d]),o[d].valid=!0,XBt(s,i[d]),n[d]=!1):K.clone(s.endPosition,i[d].endPosition))}}K.clone(s.endPosition,t._currentMousePosition)},ui.MOUSE_MOVE,e)}function yV(t){this._eventHandler=new sp(t),this._update={},this._movement={},this._lastMovement={},this._isDown={},this._eventStartPosition={},this._pressTime={},this._releaseTime={},this._buttonsDown=0,this._currentMousePosition=new K,xBt(this,void 0),YBt(this,void 0,t),H1(this,void 0,Mo.LEFT_DRAG),H1(this,void 0,Mo.RIGHT_DRAG),H1(this,void 0,Mo.MIDDLE_DRAG),JBt(this,void 0);for(let e in id)if(id.hasOwnProperty(e)){let n=id[e];c(n)&&(xBt(this,n),YBt(this,n,t),H1(this,n,Mo.LEFT_DRAG),H1(this,n,Mo.RIGHT_DRAG),H1(this,n,Mo.MIDDLE_DRAG),JBt(this,n))}}Object.defineProperties(yV.prototype,{currentMousePosition:{get:function(){return this._currentMousePosition}},anyButtonDown:{get:function(){let t=!this._update[pc(Mo.WHEEL)]||!this._update[pc(Mo.WHEEL,id.SHIFT)]||!this._update[pc(Mo.WHEEL,id.CTRL)]||!this._update[pc(Mo.WHEEL,id.ALT)];return this._buttonsDown>0||t}}});yV.prototype.isMoving=function(t,e){let n=pc(t,e);return!this._update[n]};yV.prototype.getMovement=function(t,e){let n=pc(t,e);return this._movement[n]};yV.prototype.getLastMovement=function(t,e){let n=pc(t,e),i=this._lastMovement[n];if(i.valid)return i};yV.prototype.isButtonDown=function(t,e){let n=pc(t,e);return this._isDown[n]};yV.prototype.getStartMousePosition=function(t,e){if(t===Mo.WHEEL)return this._currentMousePosition;let n=pc(t,e);return this._eventStartPosition[n]};yV.prototype.getButtonPressTime=function(t,e){let n=pc(t,e);return this._pressTime[n]};yV.prototype.getButtonReleaseTime=function(t,e){let n=pc(t,e);return this._releaseTime[n]};yV.prototype.reset=function(){for(let t in this._update)this._update.hasOwnProperty(t)&&(this._update[t]=!0)};yV.prototype.isDestroyed=function(){return!1};yV.prototype.destroy=function(){return this._eventHandler=this._eventHandler&&this._eventHandler.destroy(),At(this)};var T9=yV;var yko=b(W(),1);function Zj(t,e,n,i,o,a,s,l,r,d){this._tweens=t,this._tweenjs=e,this._startObject=Re(n),this._stopObject=Re(i),this._duration=o,this._delay=a,this._easingFunction=s,this._update=l,this._complete=r,this.cancel=d,this.needsStart=!0}Object.defineProperties(Zj.prototype,{startObject:{get:function(){return this._startObject}},stopObject:{get:function(){return this._stopObject}},duration:{get:function(){return this._duration}},delay:{get:function(){return this._delay}},easingFunction:{get:function(){return this._easingFunction}},update:{get:function(){return this._update}},complete:{get:function(){return this._complete}},tweenjs:{get:function(){return this._tweenjs}}});Zj.prototype.cancelTween=function(){this._tweens.remove(this)};function mZ(){this._tweens=[]}Object.defineProperties(mZ.prototype,{length:{get:function(){return this._tweens.length}}});mZ.prototype.add=function(t){if(t=f(t,f.EMPTY_OBJECT),t.duration===0)return c(t.complete)&&t.complete(),new Zj(this);let e=t.duration/xi.SECONDS_PER_MILLISECOND,n=f(t.delay,0),i=n/xi.SECONDS_PER_MILLISECOND,o=f(t.easingFunction,ul.LINEAR_NONE),a=t.startObject,s=new TEt(a);s.to(Re(t.stopObject),e),s.delay(i),s.easing(o),c(t.update)&&s.onUpdate(function(){t.update(a)}),s.onComplete(f(t.complete,null)),s.repeat(f(t._repeat,0));let l=new Zj(this,s,t.startObject,t.stopObject,t.duration,n,o,t.update,t.complete,t.cancel);return this._tweens.push(l),l};mZ.prototype.addProperty=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.object,n=t.property,i=t.startValue,o=t.stopValue;function a(s){e[n]=s.value}return this.add({startObject:{value:i},stopObject:{value:o},duration:f(t.duration,3),delay:t.delay,easingFunction:t.easingFunction,update:a,complete:t.complete,cancel:t.cancel,_repeat:t._repeat})};mZ.prototype.addAlpha=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.material,n=[];for(let o in e.uniforms)e.uniforms.hasOwnProperty(o)&&c(e.uniforms[o])&&c(e.uniforms[o].alpha)&&n.push(o);function i(o){let a=n.length;for(let s=0;s<a;++s)e.uniforms[n[s]].alpha=o.alpha}return this.add({startObject:{alpha:f(t.startValue,0)},stopObject:{alpha:f(t.stopValue,1)},duration:f(t.duration,3),delay:t.delay,easingFunction:t.easingFunction,update:i,complete:t.complete,cancel:t.cancel})};mZ.prototype.addOffsetIncrement=function(t){t=f(t,f.EMPTY_OBJECT);let n=t.material.uniforms;return this.addProperty({object:n,property:"offset",startValue:n.offset,stopValue:n.offset+1,duration:t.duration,delay:t.delay,easingFunction:t.easingFunction,update:t.update,cancel:t.cancel,_repeat:1/0})};mZ.prototype.remove=function(t){if(!c(t))return!1;let e=this._tweens.indexOf(t);return e!==-1?(t.tweenjs.stop(),c(t.cancel)&&t.cancel(),this._tweens.splice(e,1),!0):!1};mZ.prototype.removeAll=function(){let t=this._tweens;for(let e=0;e<t.length;++e){let n=t[e];n.tweenjs.stop(),c(n.cancel)&&n.cancel()}t.length=0};mZ.prototype.contains=function(t){return c(t)&&this._tweens.indexOf(t)!==-1};mZ.prototype.get=function(t){return this._tweens[t]};mZ.prototype.update=function(t){let e=this._tweens,n=0;for(t=c(t)?t/xi.SECONDS_PER_MILLISECOND:Oi();n<e.length;){let i=e[n],o=i.tweenjs;i.needsStart?(i.needsStart=!1,o.start(t)):o.update(t)?n++:(o.stop(),e.splice(n,1))}};var yT=mZ;function E9(t){this.enableInputs=!0,this.enableTranslate=!0,this.enableZoom=!0,this.enableRotate=!0,this.enableTilt=!0,this.enableLook=!0,this.inertiaSpin=.9,this.inertiaTranslate=.9,this.inertiaZoom=.8,this.maximumMovementRatio=.1,this.bounceAnimationTime=3,this.minimumZoomDistance=1,this.maximumZoomDistance=Number.POSITIVE_INFINITY,this.translateEventTypes=Mo.LEFT_DRAG,this.zoomEventTypes=[Mo.RIGHT_DRAG,Mo.WHEEL,Mo.PINCH],this.rotateEventTypes=Mo.LEFT_DRAG,this.tiltEventTypes=[Mo.MIDDLE_DRAG,Mo.PINCH,{eventType:Mo.LEFT_DRAG,modifier:id.CTRL},{eventType:Mo.RIGHT_DRAG,modifier:id.CTRL}],this.lookEventTypes={eventType:Mo.LEFT_DRAG,modifier:id.SHIFT},this.minimumPickingTerrainHeight=15e4,this._minimumPickingTerrainHeight=this.minimumPickingTerrainHeight,this.minimumCollisionTerrainHeight=15e3,this._minimumCollisionTerrainHeight=this.minimumCollisionTerrainHeight,this.minimumTrackBallHeight=75e5,this._minimumTrackBallHeight=this.minimumTrackBallHeight,this.enableCollisionDetection=!0,this._scene=t,this._globe=void 0,this._ellipsoid=void 0,this._lastGlobeHeight=0,this._aggregator=new T9(t.canvas),this._lastInertiaSpinMovement=void 0,this._lastInertiaZoomMovement=void 0,this._lastInertiaTranslateMovement=void 0,this._lastInertiaTiltMovement=void 0,this._inertiaDisablers={_lastInertiaZoomMovement:["_lastInertiaSpinMovement","_lastInertiaTranslateMovement","_lastInertiaTiltMovement"],_lastInertiaTiltMovement:["_lastInertiaSpinMovement","_lastInertiaTranslateMovement"]},this._tweens=new yT,this._tween=void 0,this._horizontalRotationAxis=void 0,this._tiltCenterMousePosition=new K(-1,-1),this._tiltCenter=new p,this._rotateMousePosition=new K(-1,-1),this._rotateStartPosition=new p,this._strafeStartPosition=new p,this._strafeMousePosition=new K,this._strafeEndMousePosition=new K,this._zoomMouseStart=new K(-1,-1),this._zoomWorldPosition=new p,this._useZoomWorldPosition=!1,this._tiltCVOffMap=!1,this._looking=!1,this._rotating=!1,this._strafing=!1,this._zoomingOnVector=!1,this._zoomingUnderground=!1,this._rotatingZoom=!1,this._adjustedHeightForTerrain=!1,this._cameraUnderground=!1;let e=t.mapProjection;this._maxCoord=e.project(new gt(Math.PI,k.PI_OVER_TWO)),this._zoomFactor=5,this._rotateFactor=void 0,this._rotateRateRangeAdjustment=void 0,this._maximumRotateRate=1.77,this._minimumRotateRate=1/5e3,this._minimumZoomRate=20,this._maximumZoomRate=5906376272e3,this._minimumUndergroundPickDistance=2e3,this._maximumUndergroundPickDistance=1e4}function e2e(t,e){if(t<0)return 0;let n=(1-e)*25;return Math.exp(-n*t)}function n2e(t){return K.equalsEpsilon(t.startPosition,t.endPosition,k.EPSILON14)}var i2e=.4;function o2e(t,e,n,i,o,a,s){let l=a[s];c(l)||(l=a[s]={startPosition:new K,endPosition:new K,motion:new K,inertiaEnabled:!0});let r=t.getButtonPressTime(e,n),d=t.getButtonReleaseTime(e,n),m=r&&d&&(d.getTime()-r.getTime())/1e3,u=d&&(new Date().getTime()-d.getTime())/1e3;if(r&&d&&m<i2e){let R=e2e(u,i),V=t.getLastMovement(e,n);if(!c(V)||n2e(V)||!l.inertiaEnabled||(l.motion.x=(V.endPosition.x-V.startPosition.x)*.5,l.motion.y=(V.endPosition.y-V.startPosition.y)*.5,l.startPosition=K.clone(V.startPosition,l.startPosition),l.endPosition=K.multiplyByScalar(l.motion,R,l.endPosition),l.endPosition=K.add(l.startPosition,l.endPosition,l.endPosition),isNaN(l.endPosition.x)||isNaN(l.endPosition.y)||K.distance(l.startPosition,l.endPosition)<.5))return;if(!t.isButtonDown(e,n)){let F=t.getStartMousePosition(e,n);o(a,F,l)}}}function a2e(t,e){if(c(e)){let n=t[e];c(n)&&(n.inertiaEnabled=!0);let i=t._inertiaDisablers[e];if(c(i)){let o=i.length;for(let a=0;a<o;++a)n=t[i[a]],c(n)&&(n.inertiaEnabled=!1)}}}var LBt=[];function om(t,e,n,i,o,a){if(!c(n))return;let s=t._aggregator;Array.isArray(n)||(LBt[0]=n,n=LBt);let l=n.length;for(let r=0;r<l;++r){let d=n[r],m=c(d.eventType)?d.eventType:d,h=d.modifier,u=s.isMoving(m,h)&&s.getMovement(m,h),R=s.getStartMousePosition(m,h);t.enableInputs&&e&&(u?(i(t,R,u),a2e(t,a)):o<1&&o2e(s,m,h,o,i,t,a))}}var Rj=new di,s2e=new p,l2e=new K,r2e=new p,d2e=new K,c2e=new p,m2e=new p,h2e=new p,p2e=new p,V2e=new p,u2e=new p,Z2e=new p,R2e=new p,b2e=new p,W2e=new p,f2e=new p,F2e=new p,U2e=new p,G2e=new p,A2e=new p,BT=new p,MBt=new p,_Bt=new p,vat={orientation:new Jr};function nst(t,e,n,i,o,a){let s=1;c(a)&&(s=k.clamp(Math.abs(a),.25,1));let l=n.endPosition.y-n.startPosition.y,d=l>0?t.minimumZoomDistance*s:0,m=t.maximumZoomDistance,h=o-d,u=i*h;u=k.clamp(u,t._minimumZoomRate,t._maximumZoomRate);let R=l/t._scene.canvas.clientHeight;R=Math.min(R,t.maximumMovementRatio);let V=u*R;if(t.enableCollisionDetection||t.minimumZoomDistance===0||!c(t._globe)){if(V>0&&Math.abs(o-d)<1||V<0&&Math.abs(o-m)<1)return;o-V<d?V=o-d-1:o-V>m&&(V=o-m)}let F=t._scene,U=F.camera,G=F.mode,A=vat.orientation;if(A.heading=U.heading,A.pitch=U.pitch,A.roll=U.roll,U.frustum instanceof wn){Math.abs(V)>0&&(U.zoomIn(V),U._adjustOrthographicFrustum());return}let S=K.equals(e,t._zoomMouseStart),g=t._zoomingOnVector,C=t._rotatingZoom,y;if(S||(t._zoomMouseStart=K.clone(e,t._zoomMouseStart),c(t._globe)&&(G===Vt.SCENE2D?(y=U.getPickRay(e,Rj).origin,y=p.fromElements(y.y,y.z,y.x)):y=GU(t,e,s2e)),c(y)?(t._useZoomWorldPosition=!0,t._zoomWorldPosition=p.clone(y,t._zoomWorldPosition)):t._useZoomWorldPosition=!1,g=t._zoomingOnVector=!1,C=t._rotatingZoom=!1,t._zoomingUnderground=t._cameraUnderground),!t._useZoomWorldPosition){U.zoomIn(V);return}let Y=G===Vt.COLUMBUS_VIEW;if(U.positionCartographic.height<2e6&&(C=!0),!S||C){if(G===Vt.SCENE2D){let Q=t._zoomWorldPosition,J=U.position;if(!p.equals(Q,J)&&U.positionCartographic.height<t._maxCoord.x*2){let M=U.position.x,Z=p.subtract(Q,J,r2e);p.normalize(Z,Z);let E=p.distance(Q,J)*V/(U.getMagnitude()*.5);U.move(Z,E*.5),(U.position.x<0&&M>0||U.position.x>0&&M<0)&&(y=U.getPickRay(e,Rj).origin,y=p.fromElements(y.y,y.z,y.x),t._zoomWorldPosition=p.clone(y,t._zoomWorldPosition))}}else if(G===Vt.SCENE3D){let Q=p.normalize(U.position,V2e);if(t._cameraUnderground||t._zoomingUnderground||U.positionCartographic.height<3e3&&Math.abs(p.dot(U.direction,Q))<.6)Y=!0;else{let J=F.canvas,M=d2e;M.x=J.clientWidth/2,M.y=J.clientHeight/2;let Z=GU(t,M,c2e);if(!c(Z))Y=!0;else if(U.positionCartographic.height<1e6)if(p.dot(U.direction,Q)>=-.5)Y=!0;else{let E=Z2e;p.clone(U.position,E);let I=t._zoomWorldPosition,B=u2e;if(B=p.normalize(I,B),p.dot(B,Q)<0)return;let X=A2e,_=W2e;p.clone(U.direction,_),p.add(E,p.multiplyByScalar(_,1e3,BT),X);let P=f2e,w=F2e;p.subtract(I,E,P),p.normalize(P,w);let z=p.dot(Q,w);if(z>=0){t._zoomMouseStart.x=-1;return}let H=Math.acos(-z),nt=p.magnitude(E),$=p.magnitude(I),dt=nt-V,q=p.magnitude(P),at=Math.asin(k.clamp(q/$*Math.sin(H),-1,1)),st=Math.asin(k.clamp(dt/$*Math.sin(H),-1,1)),Et=at-st+H,Qt=R2e;p.normalize(E,Qt);let Wt=b2e;Wt=p.cross(w,Qt,Wt),Wt=p.normalize(Wt,Wt),p.normalize(p.cross(Qt,Wt,BT),_),p.multiplyByScalar(p.normalize(X,BT),p.magnitude(X)-V,X),p.normalize(E,E),p.multiplyByScalar(E,dt,E);let Nt=U2e;p.multiplyByScalar(p.add(p.multiplyByScalar(Qt,Math.cos(Et)-1,MBt),p.multiplyByScalar(_,Math.sin(Et),_Bt),BT),dt,Nt),p.add(E,Nt,E),p.normalize(X,Qt),p.normalize(p.cross(Qt,Wt,BT),_);let kt=G2e;p.multiplyByScalar(p.add(p.multiplyByScalar(Qt,Math.cos(Et)-1,MBt),p.multiplyByScalar(_,Math.sin(Et),_Bt),BT),p.magnitude(X),kt),p.add(X,kt,X),p.clone(E,U.position),p.normalize(p.subtract(X,E,BT),U.direction),p.clone(U.direction,U.direction),p.cross(U.direction,U.up,U.right),p.cross(U.right,U.direction,U.up),U.setView(vat);return}else{let E=p.normalize(Z,m2e),I=p.normalize(t._zoomWorldPosition,h2e),B=p.dot(I,E);if(B>0&&B<1){let X=k.acosClamped(B),_=p.cross(I,E,p2e),P=Math.abs(X)>k.toRadians(20)?U.positionCartographic.height*.75:U.positionCartographic.height-V,w=V/P;U.rotate(_,X*w)}}}}t._rotatingZoom=!Y}if(!S&&Y||g){let Q,J=qo.wgs84ToWindowCoordinates(F,t._zoomWorldPosition,l2e);G!==Vt.COLUMBUS_VIEW&&K.equals(e,t._zoomMouseStart)&&c(J)?Q=U.getPickRay(J,Rj):Q=U.getPickRay(e,Rj);let M=Q.direction;(G===Vt.COLUMBUS_VIEW||G===Vt.SCENE2D)&&p.fromElements(M.y,M.z,M.x,M),U.move(M,V),t._zoomingOnVector=!0}else U.zoomIn(V);t._cameraUnderground||U.setView(vat)}var S2e=new di,T2e=new di,g2e=new p;function E2e(t,e,n){let o=t._scene.camera,a=o.getPickRay(n.startPosition,S2e).origin,s=o.getPickRay(n.endPosition,T2e).origin;a=p.fromElements(a.y,a.z,a.x,a),s=p.fromElements(s.y,s.z,s.x,s);let l=p.subtract(a,s,g2e),r=p.magnitude(l);r>0&&(p.normalize(l,l),o.move(l,r))}function DBt(t,e,n){c(n.distance)&&(n=n.distance);let o=t._scene.camera;nst(t,e,n,t._zoomFactor,o.getMagnitude())}var C2e=new K,I2e=new K;function OBt(t,e,n){if(c(n.angleAndHeight)){N2e(t,e,n.angleAndHeight);return}let i=t._scene,o=i.camera,a=i.canvas,s=a.clientWidth,l=a.clientHeight,r=C2e;r.x=2/s*n.startPosition.x-1,r.y=2/l*(l-n.startPosition.y)-1,r=K.normalize(r,r);let d=I2e;d.x=2/s*n.endPosition.x-1,d.y=2/l*(l-n.endPosition.y)-1,d=K.normalize(d,d);let m=k.acosClamped(r.x);r.y<0&&(m=k.TWO_PI-m);let h=k.acosClamped(d.x);d.y<0&&(h=k.TWO_PI-h);let u=h-m;o.twistRight(u)}function N2e(t,e,n){let i=t._rotateFactor*t._rotateRateRangeAdjustment;i>t._maximumRotateRate&&(i=t._maximumRotateRate),i<t._minimumRotateRate&&(i=t._minimumRotateRate);let o=t._scene,a=o.camera,s=o.canvas,l=(n.endPosition.x-n.startPosition.x)/s.clientWidth;l=Math.min(l,t.maximumMovementRatio);let r=i*l*Math.PI*4;a.twistRight(r)}function y2e(t){let e=t._scene.mapMode2D===eh.ROTATE;L.equals(L.IDENTITY,t._scene.camera.transform)?(om(t,t.enableTranslate,t.translateEventTypes,E2e,t.inertiaTranslate,"_lastInertiaTranslateMovement"),om(t,t.enableZoom,t.zoomEventTypes,DBt,t.inertiaZoom,"_lastInertiaZoomMovement"),e&&om(t,t.enableRotate,t.tiltEventTypes,OBt,t.inertiaSpin,"_lastInertiaTiltMovement")):(om(t,t.enableZoom,t.zoomEventTypes,DBt,t.inertiaZoom,"_lastInertiaZoomMovement"),e&&om(t,t.enableRotate,t.translateEventTypes,OBt,t.inertiaSpin,"_lastInertiaSpinMovement"))}var KBt=new di,B2e=new p,Q2e=new p;function GU(t,e,n){let i=t._scene,o=t._globe,a=i.camera;if(!c(o))return;let s=!t._cameraUnderground,l;i.pickPositionSupported&&(l=i.pickPositionWorldCoordinates(e,B2e));let r=a.getPickRay(e,KBt),d=o.pickWorldCoordinates(r,i,s,Q2e),m=c(l)?p.distance(l,a.positionWC):Number.POSITIVE_INFINITY,h=c(d)?p.distance(d,a.positionWC):Number.POSITIVE_INFINITY;return m<h?p.clone(l,n):p.clone(d,n)}var k2e=new gt;function Gj(t){let e=t._ellipsoid,n=t._scene,i=n.camera,o=n.mode,a=0;if(o===Vt.SCENE3D){let r=e.cartesianToCartographic(i.position,k2e);c(r)&&(a=r.height)}else a=i.position.z;let s=f(t._scene.globeHeight,0);return Math.abs(s-a)}var Y2e=new p;function zBt(t,e){let n=e.origin,i=e.direction,o=Gj(t),a=p.normalize(n,Y2e),s=Math.abs(p.dot(a,i));return s=Math.max(s,.5)*2,o*s}function jBt(t,e,n,i){let o=p.distance(e.origin,n),a=Gj(t),s=k.clamp(a*5,t._minimumUndergroundPickDistance,t._maximumUndergroundPickDistance);return o>s&&(o=Math.min(o,a/5),o=Math.max(o,100)),di.getPoint(e,o,i)}function qBt(t,e,n,i){let o;return c(n)?(o=p.distance(e.origin,n),o>t._maximumUndergroundPickDistance&&(o=Gj(t))):o=Gj(t),di.getPoint(e,o,i)}var x2e=new K;function $Bt(t,e){let n=e.endPosition,i=K.subtract(e.endPosition,e.startPosition,x2e),o=t._strafeEndMousePosition;K.add(o,i,o),e.endPosition=o,ist(t,e,t._strafeStartPosition),e.endPosition=n}var HBt=new di,X2e=new di,Kat=new p,J2e=new p,L2e=new p,M2e=new p,_2e=new Kn(p.UNIT_X,0),D2e=new K,O2e=new K;function H2e(t,e,n){if(p.equals(e,t._translateMousePosition)||(t._looking=!1),p.equals(e,t._strafeMousePosition)||(t._strafing=!1),t._looking){rp(t,e,n);return}if(t._strafing){$Bt(t,n);return}let o=t._scene.camera,a=t._cameraUnderground,s=K.clone(n.startPosition,D2e),l=K.clone(n.endPosition,O2e),r=o.getPickRay(s,HBt),d=p.clone(p.ZERO,M2e),m=p.UNIT_X,h;if(o.position.z<t._minimumPickingTerrainHeight&&(h=GU(t,s,Kat),c(h)&&(d.x=h.x)),a||d.x>o.position.z&&c(h)){let S=h;a&&(S=qBt(t,r,h,Kat)),K.clone(e,t._strafeMousePosition),K.clone(e,t._strafeEndMousePosition),p.clone(S,t._strafeStartPosition),t._strafing=!0,ist(t,n,t._strafeStartPosition);return}let u=Kn.fromPointNormal(d,m,_2e);r=o.getPickRay(s,HBt);let R=no.rayPlane(r,u,Kat),V=o.getPickRay(l,X2e),F=no.rayPlane(V,u,J2e);if(!c(R)||!c(F)){t._looking=!0,rp(t,e,n),K.clone(e,t._translateMousePosition);return}let U=p.subtract(R,F,L2e),G=U.x;U.x=U.y,U.y=U.z,U.z=G;let A=p.magnitude(U);A>k.EPSILON6&&(p.normalize(U,U),o.move(U,A))}var tQt=new K,Wj=new di,fj=new p,w2e=new p,eQt=new L,P2e=new L,v2e=new p,K2e=new Kn(p.UNIT_X,0),zat=new p,$at=new gt,nQt=new L,z2e=new wt,j2e=new ot,Fj=new p;function q2e(t,e,n){if(c(n.angleAndHeight)&&(n=n.angleAndHeight),K.equals(e,t._tiltCenterMousePosition)||(t._tiltCVOffMap=!1,t._looking=!1),t._looking){rp(t,e,n);return}let o=t._scene.camera;t._tiltCVOffMap||!t.onMap()||Math.abs(o.position.z)>t._minimumPickingTerrainHeight?(t._tiltCVOffMap=!0,$2e(t,e,n)):tYe(t,e,n)}function $2e(t,e,n){let i=t._scene,o=i.camera,a=i.canvas,s=tQt;s.x=a.clientWidth/2,s.y=a.clientHeight/2;let l=o.getPickRay(s,Wj),r=p.UNIT_X,d=l.origin,m=l.direction,h,u=p.dot(r,m);if(Math.abs(u)>k.EPSILON6&&(h=-p.dot(r,d)/u),!c(h)||h<=0){t._looking=!0,rp(t,e,n),K.clone(e,t._tiltCenterMousePosition);return}let R=p.multiplyByScalar(m,h,fj);p.add(d,R,R);let V=i.mapProjection,F=V.ellipsoid;p.fromElements(R.y,R.z,R.x,R);let U=V.unproject(R,$at);F.cartographicToCartesian(U,R);let G=Pe.eastNorthUpToFixedFrame(R,F,eQt),A=t._globe,S=t._ellipsoid;t._globe=void 0,t._ellipsoid=mt.UNIT_SPHERE,t._rotateFactor=1,t._rotateRateRangeAdjustment=1;let g=L.clone(o.transform,nQt);o._setTransform(G),lp(t,e,n,p.UNIT_Z),o._setTransform(g),t._globe=A,t._ellipsoid=S;let C=S.maximumRadius;t._rotateFactor=1/C,t._rotateRateRangeAdjustment=C}function tYe(t,e,n){let i=t._scene,o=i.camera,a=t._cameraUnderground,s,l,r=p.UNIT_X;if(K.equals(e,t._tiltCenterMousePosition))s=p.clone(t._tiltCenter,fj);else{if(o.position.z<t._minimumPickingTerrainHeight&&(s=GU(t,e,fj)),!c(s)){l=o.getPickRay(e,Wj);let Z=l.origin,E=l.direction,I,B=p.dot(r,E);if(Math.abs(B)>k.EPSILON6&&(I=-p.dot(r,Z)/B),!c(I)||I<=0){t._looking=!0,rp(t,e,n),K.clone(e,t._tiltCenterMousePosition);return}s=p.multiplyByScalar(E,I,fj),p.add(Z,s,s)}a&&(c(l)||(l=o.getPickRay(e,Wj)),jBt(t,l,s,s)),K.clone(e,t._tiltCenterMousePosition),p.clone(s,t._tiltCenter)}let d=i.canvas,m=tQt;m.x=d.clientWidth/2,m.y=t._tiltCenterMousePosition.y,l=o.getPickRay(m,Wj);let h=p.clone(p.ZERO,v2e);h.x=s.x;let u=Kn.fromPointNormal(h,r,K2e),R=no.rayPlane(l,u,w2e),V=o._projection,F=V.ellipsoid;p.fromElements(s.y,s.z,s.x,s);let U=V.unproject(s,$at);F.cartographicToCartesian(U,s);let G=Pe.eastNorthUpToFixedFrame(s,F,eQt),A;c(R)?(p.fromElements(R.y,R.z,R.x,R),U=V.unproject(R,$at),F.cartographicToCartesian(U,R),A=Pe.eastNorthUpToFixedFrame(R,F,P2e)):A=G;let S=t._globe,g=t._ellipsoid;t._globe=void 0,t._ellipsoid=mt.UNIT_SPHERE,t._rotateFactor=1,t._rotateRateRangeAdjustment=1;let C=p.UNIT_Z,y=L.clone(o.transform,nQt);o._setTransform(G);let Y=p.cross(p.UNIT_Z,p.normalize(o.position,zat),zat),Q=p.dot(o.right,Y);if(lp(t,e,n,C,!1,!0),o._setTransform(A),Q<0){let Z=n.startPosition.y-n.endPosition.y;(a&&Z<0||!a&&Z>0)&&(C=void 0);let E=o.constrainedAxis;o.constrainedAxis=void 0,lp(t,e,n,C,!0,!1),o.constrainedAxis=E}else lp(t,e,n,C,!0,!1);if(c(o.constrainedAxis)){let Z=p.cross(o.direction,o.constrainedAxis,Fj);p.equalsEpsilon(Z,p.ZERO,k.EPSILON6)||(p.dot(Z,o.right)<0&&p.negate(Z,Z),p.cross(Z,o.direction,o.up),p.cross(o.direction,o.up,o.right),p.normalize(o.up,o.up),p.normalize(o.right,o.right))}o._setTransform(y),t._globe=S,t._ellipsoid=g;let J=g.maximumRadius;t._rotateFactor=1/J,t._rotateRateRangeAdjustment=J;let M=p.clone(o.positionWC,zat);if(t.enableCollisionDetection&&sst(t,!0),!p.equals(o.positionWC,M)){o._setTransform(A),o.worldToCameraCoordinatesPoint(M,M);let Z=p.magnitudeSquared(M);p.magnitudeSquared(o.position)>Z&&(p.normalize(o.position,o.position),p.multiplyByScalar(o.position,Math.sqrt(Z),o.position));let E=p.angleBetween(M,o.position),I=p.cross(M,o.position,M);p.normalize(I,I);let B=wt.fromAxisAngle(I,E,z2e),X=ot.fromQuaternion(B,j2e);ot.multiplyByVector(X,o.direction,o.direction),ot.multiplyByVector(X,o.up,o.up),p.cross(o.direction,o.up,o.right),p.cross(o.right,o.direction,o.up),o._setTransform(y)}}var iQt=new K,oQt=new di,aQt=new p;function eYe(t,e,n){c(n.distance)&&(n=n.distance);let i=t._scene,o=i.camera,a=i.canvas,s=t._cameraUnderground,l;s?l=e:(l=iQt,l.x=a.clientWidth/2,l.y=a.clientHeight/2);let r=o.getPickRay(l,oQt),d=r.origin,m=r.direction,h=o.position.z,u;h<t._minimumPickingTerrainHeight&&(u=GU(t,l,aQt));let R;if(c(u)&&(R=p.distance(d,u)),s){let V=zBt(t,r,h);c(R)?R=Math.min(R,V):R=V}if(!c(R)){let V=p.UNIT_X;R=-p.dot(V,d)/p.dot(V,m)}nst(t,e,n,t._zoomFactor,R)}function nYe(t){let n=t._scene.camera;if(!L.equals(L.IDENTITY,n.transform))om(t,t.enableRotate,t.rotateEventTypes,lp,t.inertiaSpin,"_lastInertiaSpinMovement"),om(t,t.enableZoom,t.zoomEventTypes,sQt,t.inertiaZoom,"_lastInertiaZoomMovement");else{let i=t._tweens;if(t._aggregator.anyButtonDown&&i.removeAll(),om(t,t.enableTilt,t.tiltEventTypes,q2e,t.inertiaSpin,"_lastInertiaTiltMovement"),om(t,t.enableTranslate,t.translateEventTypes,H2e,t.inertiaTranslate,"_lastInertiaTranslateMovement"),om(t,t.enableZoom,t.zoomEventTypes,eYe,t.inertiaZoom,"_lastInertiaZoomMovement"),om(t,t.enableLook,t.lookEventTypes,rp),!t._aggregator.anyButtonDown&&!i.contains(t._tween)){let o=n.createCorrectPositionTween(t.bounceAnimationTime);c(o)&&(t._tween=i.add(o))}i.update()}}var iYe=new di,oYe=new Kn(p.UNIT_X,0),aYe=new p,sYe=new p,lYe=new p;function ist(t,e,n){let i=t._scene,o=i.camera,a=o.getPickRay(e.endPosition,iYe),s=p.clone(o.direction,sYe);i.mode===Vt.COLUMBUS_VIEW&&p.fromElements(s.z,s.x,s.y,s);let l=Kn.fromPointNormal(n,s,oYe),r=no.rayPlane(a,l,aYe);c(r)&&(s=p.subtract(n,r,s),i.mode===Vt.COLUMBUS_VIEW&&p.fromElements(s.y,s.z,s.x,s),p.add(o.position,s,o.position))}var wBt=new p,rYe=new gt,tst=new p,est=new mt,dYe=new p,cYe=new p;function mYe(t,e,n){let o=t._scene.camera,a=t._cameraUnderground,s=t._ellipsoid;if(!L.equals(o.transform,L.IDENTITY)){lp(t,e,n);return}let l,r,d=s.geodeticSurfaceNormal(o.position,dYe);if(K.equals(e,t._rotateMousePosition)){if(t._looking)rp(t,e,n,d);else if(t._rotating)lp(t,e,n);else if(t._strafing){if(o.ignoreEllipsoid)return;$Bt(t,n)}else{if(o.ignoreEllipsoid||p.magnitude(o.position)<p.magnitude(t._rotateStartPosition))return;l=p.magnitude(t._rotateStartPosition),r=tst,r.x=r.y=r.z=l,s=mt.fromCartesian3(r,est),qat(t,e,n,s)}return}t._looking=!1,t._rotating=!1,t._strafing=!1;let m=s.cartesianToCartographic(o.positionWC,rYe).height,h=t._globe;if(c(h)&&m<t._minimumPickingTerrainHeight){let u=GU(t,n.startPosition,lYe);if(c(u)&&!o.ignoreEllipsoid){let R=!1,V=o.getPickRay(n.startPosition,KBt);if(a)R=!0,qBt(t,V,u,u);else{let F=s.geodeticSurfaceNormal(u,cYe);Math.abs(p.dot(V.direction,F))<.05?R=!0:R=p.magnitude(o.position)<p.magnitude(u)}R?(K.clone(e,t._strafeEndMousePosition),p.clone(u,t._strafeStartPosition),t._strafing=!0,ist(t,n,t._strafeStartPosition)):(l=p.magnitude(u),r=tst,r.x=r.y=r.z=l,s=mt.fromCartesian3(r,est),qat(t,e,n,s),p.clone(u,t._rotateStartPosition))}else t._looking=!0,rp(t,e,n,d)}else c(o.pickEllipsoid(n.startPosition,t._ellipsoid,wBt))?(qat(t,e,n,t._ellipsoid),p.clone(wBt,t._rotateStartPosition)):m>t._minimumTrackBallHeight?(t._rotating=!0,lp(t,e,n)):(t._looking=!0,rp(t,e,n,d));K.clone(e,t._rotateMousePosition)}function lp(t,e,n,i,o,a){o=f(o,!1),a=f(a,!1);let s=t._scene,l=s.camera,r=s.canvas,d=l.constrainedAxis;c(i)&&(l.constrainedAxis=i);let m=p.magnitude(l.position),h=t._rotateFactor*(m-t._rotateRateRangeAdjustment);h>t._maximumRotateRate&&(h=t._maximumRotateRate),h<t._minimumRotateRate&&(h=t._minimumRotateRate);let u=(n.startPosition.x-n.endPosition.x)/r.clientWidth,R=(n.startPosition.y-n.endPosition.y)/r.clientHeight;u=Math.min(u,t.maximumMovementRatio),R=Math.min(R,t.maximumMovementRatio);let V=h*u*Math.PI*2,F=h*R*Math.PI;o||l.rotateRight(V),a||l.rotateUp(F),l.constrainedAxis=d}var hYe=bt.clone(bt.UNIT_W),pYe=bt.clone(bt.UNIT_W),bj=new p,jat=new p,VYe=new p,uYe=new p,ZYe=new K,RYe=new K;function qat(t,e,n,i){let a=t._scene.camera,s=K.clone(n.startPosition,ZYe),l=K.clone(n.endPosition,RYe),r=a.pickEllipsoid(s,i,hYe),d=a.pickEllipsoid(l,i,pYe);if(!c(r)||!c(d)){t._rotating=!0,lp(t,e,n);return}if(r=a.worldToCameraCoordinates(r,r),d=a.worldToCameraCoordinates(d,d),c(a.constrainedAxis)){let m=a.constrainedAxis,h=p.mostOrthogonalAxis(m,bj);p.cross(h,m,h),p.normalize(h,h);let u=p.cross(m,h,jat),R=p.magnitude(r),V=p.dot(m,r),F=Math.acos(V/R),U=p.multiplyByScalar(m,V,VYe);p.subtract(r,U,U),p.normalize(U,U);let G=p.magnitude(d),A=p.dot(m,d),S=Math.acos(A/G),g=p.multiplyByScalar(m,A,uYe);p.subtract(d,g,g),p.normalize(g,g);let C=Math.acos(p.dot(U,h));p.dot(U,u)<0&&(C=k.TWO_PI-C);let y=Math.acos(p.dot(g,h));p.dot(g,u)<0&&(y=k.TWO_PI-y);let Y=C-y,Q;p.equalsEpsilon(m,a.position,k.EPSILON2)?Q=a.right:Q=p.cross(m,a.position,bj);let J=p.cross(m,Q,bj),M=p.dot(J,p.subtract(r,m,jat)),Z=p.dot(J,p.subtract(d,m,jat)),E;M>0&&Z>0?E=S-F:M>0&&Z<=0?p.dot(a.position,m)>0?E=-F-S:E=F+S:E=F-S,a.rotateRight(Y),a.rotateUp(E)}else{p.normalize(r,r),p.normalize(d,d);let m=p.dot(r,d),h=p.cross(r,d,bj);if(m<1&&!p.equalsEpsilon(h,p.ZERO,k.EPSILON14)){let u=Math.acos(m);a.rotate(h,u)}}}var bYe=new p,WYe=new gt;function sQt(t,e,n){c(n.distance)&&(n=n.distance);let i=t._ellipsoid,o=t._scene,a=o.camera,s=o.canvas,l=t._cameraUnderground,r;l?r=e:(r=iQt,r.x=s.clientWidth/2,r.y=s.clientHeight/2);let d=a.getPickRay(r,oQt),m,h=i.cartesianToCartographic(a.position,WYe)?.height;if(!h)return;h<t._minimumPickingTerrainHeight&&(m=GU(t,r,aQt));let u;if(c(m)&&(u=p.distance(d.origin,m)),l){let V=zBt(t,d,h);c(u)?u=Math.min(u,V):u=V}c(u)||(u=h);let R=p.normalize(a.position,bYe);nst(t,e,n,t._zoomFactor,u,p.dot(R,a.direction))}var lQt=new K,Uj=new di,g9=new p,fYe=new p,rQt=new L,FYe=new L,dQt=new L,UYe=new wt,GYe=new ot,ost=new gt,ast=new p;function AYe(t,e,n){let o=t._scene.camera;if(!L.equals(o.transform,L.IDENTITY))return;if(c(n.angleAndHeight)&&(n=n.angleAndHeight),K.equals(e,t._tiltCenterMousePosition)||(t._tiltOnEllipsoid=!1,t._looking=!1),t._looking){let l=t._ellipsoid.geodeticSurfaceNormal(o.position,ast);rp(t,e,n,l);return}let s=t._ellipsoid.cartesianToCartographic(o.position,ost);t._tiltOnEllipsoid||s.height>t._minimumCollisionTerrainHeight?(t._tiltOnEllipsoid=!0,TYe(t,e,n)):gYe(t,e,n)}var SYe=new gt;function TYe(t,e,n){let i=t._ellipsoid,o=t._scene,a=o.camera,s=t.minimumZoomDistance*.25,l=i.cartesianToCartographic(a.positionWC,SYe).height;if(l-s-1<k.EPSILON3&&n.endPosition.y-n.startPosition.y<0)return;let r=o.canvas,d=lQt;d.x=r.clientWidth/2,d.y=r.clientHeight/2;let m=a.getPickRay(d,Uj),h,u=no.rayEllipsoid(m,i);if(c(u))h=di.getPoint(m,u.start,g9);else if(l>t._minimumTrackBallHeight){let A=no.grazingAltitudeLocation(m,i);if(!c(A))return;let S=i.cartesianToCartographic(A,ost);S.height=0,h=i.cartographicToCartesian(S,g9)}else{t._looking=!0;let A=t._ellipsoid.geodeticSurfaceNormal(a.position,ast);rp(t,e,n,A),K.clone(e,t._tiltCenterMousePosition);return}let R=Pe.eastNorthUpToFixedFrame(h,i,rQt),V=t._globe,F=t._ellipsoid;t._globe=void 0,t._ellipsoid=mt.UNIT_SPHERE,t._rotateFactor=1,t._rotateRateRangeAdjustment=1;let U=L.clone(a.transform,dQt);a._setTransform(R),lp(t,e,n,p.UNIT_Z),a._setTransform(U),t._globe=V,t._ellipsoid=F;let G=F.maximumRadius;t._rotateFactor=1/G,t._rotateRateRangeAdjustment=G}function gYe(t,e,n){let i=t._ellipsoid,o=t._scene,a=o.camera,s=t._cameraUnderground,l,r,d;if(K.equals(e,t._tiltCenterMousePosition))l=p.clone(t._tiltCenter,g9);else{if(l=GU(t,e,g9),!c(l)){if(r=a.getPickRay(e,Uj),d=no.rayEllipsoid(r,i),!c(d)){if(i.cartesianToCartographic(a.position,ost).height<=t._minimumTrackBallHeight){t._looking=!0;let E=t._ellipsoid.geodeticSurfaceNormal(a.position,ast);rp(t,e,n,E),K.clone(e,t._tiltCenterMousePosition)}return}l=di.getPoint(r,d.start,g9)}s&&(c(r)||(r=a.getPickRay(e,Uj)),jBt(t,r,l,l)),K.clone(e,t._tiltCenterMousePosition),p.clone(l,t._tiltCenter)}let m=o.canvas,h=lQt;h.x=m.clientWidth/2,h.y=t._tiltCenterMousePosition.y,r=a.getPickRay(h,Uj);let u=p.magnitude(l),R=p.fromElements(u,u,u,tst),V=mt.fromCartesian3(R,est);if(d=no.rayEllipsoid(r,V),!c(d))return;let F=p.magnitude(r.origin)>u?d.start:d.stop,U=di.getPoint(r,F,fYe),G=Pe.eastNorthUpToFixedFrame(l,i,rQt),A=Pe.eastNorthUpToFixedFrame(U,V,FYe),S=t._globe,g=t._ellipsoid;t._globe=void 0,t._ellipsoid=mt.UNIT_SPHERE,t._rotateFactor=1,t._rotateRateRangeAdjustment=1;let C=p.UNIT_Z,y=L.clone(a.transform,dQt);a._setTransform(A);let Y=p.cross(U,a.positionWC,Fj);if(p.dot(a.rightWC,Y)<0){let Z=n.startPosition.y-n.endPosition.y;(s&&Z<0||!s&&Z>0)&&(C=void 0);let E=a.constrainedAxis;a.constrainedAxis=void 0,lp(t,e,n,C,!0,!1),a.constrainedAxis=E}else lp(t,e,n,C,!0,!1);if(a._setTransform(G),lp(t,e,n,C,!1,!0),c(a.constrainedAxis)){let Z=p.cross(a.direction,a.constrainedAxis,Fj);p.equalsEpsilon(Z,p.ZERO,k.EPSILON6)||(p.dot(Z,a.right)<0&&p.negate(Z,Z),p.cross(Z,a.direction,a.up),p.cross(a.direction,a.up,a.right),p.normalize(a.up,a.up),p.normalize(a.right,a.right))}a._setTransform(y),t._globe=S,t._ellipsoid=g;let J=g.maximumRadius;t._rotateFactor=1/J,t._rotateRateRangeAdjustment=J;let M=p.clone(a.positionWC,Fj);if(t.enableCollisionDetection&&sst(t,!0),!p.equals(a.positionWC,M)){a._setTransform(A),a.worldToCameraCoordinatesPoint(M,M);let Z=p.magnitudeSquared(M);p.magnitudeSquared(a.position)>Z&&(p.normalize(a.position,a.position),p.multiplyByScalar(a.position,Math.sqrt(Z),a.position));let E=p.angleBetween(M,a.position),I=p.cross(M,a.position,M);p.normalize(I,I);let B=wt.fromAxisAngle(I,E,UYe),X=ot.fromQuaternion(B,GYe);ot.multiplyByVector(X,a.direction,a.direction),ot.multiplyByVector(X,a.up,a.up),p.cross(a.direction,a.up,a.right),p.cross(a.right,a.direction,a.up),a._setTransform(y)}}var EYe=new K,CYe=new K,PBt=new di,vBt=new di,IYe=new p,NYe=new p;function rp(t,e,n,i){let a=t._scene.camera,s=EYe;s.x=n.startPosition.x,s.y=0;let l=CYe;l.x=n.endPosition.x,l.y=0;let r=a.getPickRay(s,PBt),d=a.getPickRay(l,vBt),m=0,h,u;a.frustum instanceof wn?(h=r.origin,u=d.origin,p.add(a.direction,h,h),p.add(a.direction,u,u),p.subtract(h,a.position,h),p.subtract(u,a.position,u),p.normalize(h,h),p.normalize(u,u)):(h=r.direction,u=d.direction);let R=p.dot(h,u);R<1&&(m=Math.acos(R)),m=n.startPosition.x>n.endPosition.x?-m:m;let V=t._horizontalRotationAxis;if(c(i)?a.look(i,-m):c(V)?a.look(V,-m):a.lookLeft(m),s.x=0,s.y=n.startPosition.y,l.x=0,l.y=n.endPosition.y,r=a.getPickRay(s,PBt),d=a.getPickRay(l,vBt),m=0,a.frustum instanceof wn?(h=r.origin,u=d.origin,p.add(a.direction,h,h),p.add(a.direction,u,u),p.subtract(h,a.position,h),p.subtract(u,a.position,u),p.normalize(h,h),p.normalize(u,u)):(h=r.direction,u=d.direction),R=p.dot(h,u),R<1&&(m=Math.acos(R)),m=n.startPosition.y>n.endPosition.y?-m:m,i=f(i,V),c(i)){let F=a.direction,U=p.negate(i,IYe),G=p.equalsEpsilon(F,i,k.EPSILON2),A=p.equalsEpsilon(F,U,k.EPSILON2);if(!G&&!A){R=p.dot(F,i);let S=k.acosClamped(R);m>0&&m>S&&(m=S-k.EPSILON4),R=p.dot(F,U),S=k.acosClamped(R),m<0&&-m>S&&(m=-S+k.EPSILON4);let g=p.cross(i,F,NYe);a.look(g,m)}else(G&&m<0||A&&m>0)&&a.look(a.right,-m)}else a.lookUp(m)}function yYe(t){om(t,t.enableRotate,t.rotateEventTypes,mYe,t.inertiaSpin,"_lastInertiaSpinMovement"),om(t,t.enableZoom,t.zoomEventTypes,sQt,t.inertiaZoom,"_lastInertiaZoomMovement"),om(t,t.enableTilt,t.tiltEventTypes,AYe,t.inertiaSpin,"_lastInertiaTiltMovement"),om(t,t.enableLook,t.lookEventTypes,rp)}var BYe=new L,QYe=new gt;function sst(t,e){t._adjustedHeightForTerrain=!0;let n=t._scene,i=n.mode,o=n.globe;if(i===Vt.SCENE2D||i===Vt.MORPHING)return;let a=n.camera,s=f(o?.ellipsoid,mt.WGS84),l=n.mapProjection,r,d;L.equals(a.transform,L.IDENTITY)||(r=L.clone(a.transform,BYe),d=p.magnitude(a.position),a._setTransform(L.IDENTITY));let m=QYe;i===Vt.SCENE3D?s.cartesianToCartographic(a.position,m):l.unproject(a.position,m);let h=!1;if(m.height<t._minimumCollisionTerrainHeight){let u=t._scene.globeHeight;if(c(u)){let R=u+t.minimumZoomDistance,V=u-t._lastGlobeHeight,F=V/t._lastGlobeHeight;m.height<R&&(e||Math.abs(F)<=.1)&&(m.height=R,i===Vt.SCENE3D?s.cartographicToCartesian(m,a.position):l.project(m,a.position),h=!0),e||Math.abs(F)<=.1?t._lastGlobeHeight=u:t._lastGlobeHeight+=V*.1}}c(r)&&(a._setTransform(r),h&&(p.normalize(a.position,a.position),p.negate(a.position,a.direction),p.multiplyByScalar(a.position,Math.max(d,t.minimumZoomDistance),a.position),p.normalize(a.direction,a.direction),p.cross(a.direction,a.up,a.right),p.cross(a.right,a.direction,a.up)))}E9.prototype.onMap=function(){let t=this._scene,e=t.mode,n=t.camera;return e===Vt.COLUMBUS_VIEW?Math.abs(n.position.x)-this._maxCoord.x<0&&Math.abs(n.position.y)-this._maxCoord.y<0:!0};var kYe=new p,YYe=new p;E9.prototype.update=function(){let t=this._scene,{camera:e,globe:n,mode:i}=t;L.equals(e.transform,L.IDENTITY)?(this._globe=n,this._ellipsoid=c(this._globe)?this._globe.ellipsoid:t.mapProjection.ellipsoid):(this._globe=void 0,this._ellipsoid=mt.UNIT_SPHERE);let{verticalExaggeration:o,verticalExaggerationRelativeHeight:a}=t;this._minimumCollisionTerrainHeight=Ps.getHeight(this.minimumCollisionTerrainHeight,o,a),this._minimumPickingTerrainHeight=Ps.getHeight(this.minimumPickingTerrainHeight,o,a),this._minimumTrackBallHeight=Ps.getHeight(this.minimumTrackBallHeight,o,a),this._cameraUnderground=t.cameraUnderground&&c(this._globe);let s=this._ellipsoid.maximumRadius;this._rotateFactor=1/s,this._rotateRateRangeAdjustment=s,this._adjustedHeightForTerrain=!1;let l=p.clone(e.positionWC,kYe),r=p.clone(e.directionWC,YYe);if(i===Vt.SCENE2D?y2e(this):i===Vt.COLUMBUS_VIEW?(this._horizontalRotationAxis=p.UNIT_Z,nYe(this)):i===Vt.SCENE3D&&(this._horizontalRotationAxis=void 0,yYe(this)),this.enableCollisionDetection&&!this._adjustedHeightForTerrain){let d=!p.equals(l,e.positionWC)||!p.equals(r,e.directionWC);sst(this,d)}this._aggregator.reset()};E9.prototype.isDestroyed=function(){return!1};E9.prototype.destroy=function(){return this._tweens.removeAll(),this._aggregator=this._aggregator&&this._aggregator.destroy(),At(this)};var C9=E9;var C2o=b(W(),1);var r2o=b(W(),1),I9=`uniform sampler2D colorTexture; uniform sampler2D colorTexture2; uniform vec2 center; @@ -12634,7 +12634,7 @@ void main() float t = smoothstep(0.5, 0.8, x); out_FragColor = mix(color0 + color1, color1, t); } -`;var cko=R(W(),1),N9=`uniform sampler2D colorTexture; +`;var c2o=b(W(),1),N9=`uniform sampler2D colorTexture; uniform float avgLuminance; uniform float threshold; @@ -12664,7 +12664,7 @@ void main() xyz.r = brightness; out_FragColor = vec4(czm_XYZToRGB(xyz), 1.0); } -`;function GW(){this._sceneFramebuffer=new FS;let t=.125,e=new Array(6);e[0]=new Qa({fragmentShader:nh,textureScale:t,forcePowerOfTwo:!0,sampleMode:op.LINEAR});let n=e[1]=new Qa({fragmentShader:N9,uniforms:{avgLuminance:.5,threshold:.25,offset:.1},textureScale:t,forcePowerOfTwo:!0}),i=this;this._delta=1,this._sigma=2,this._blurStep=new K,e[2]=new Qa({fragmentShader:fU,uniforms:{step:function(){return i._blurStep.x=i._blurStep.y=1/n.outputTexture.width,i._blurStep},delta:function(){return i._delta},sigma:function(){return i._sigma},direction:0},textureScale:t,forcePowerOfTwo:!0}),e[3]=new Qa({fragmentShader:fU,uniforms:{step:function(){return i._blurStep.x=i._blurStep.y=1/n.outputTexture.width,i._blurStep},delta:function(){return i._delta},sigma:function(){return i._sigma},direction:1},textureScale:t,forcePowerOfTwo:!0}),e[4]=new Qa({fragmentShader:nh,sampleMode:op.LINEAR}),this._uCenter=new K,this._uRadius=void 0,e[5]=new Qa({fragmentShader:I9,uniforms:{center:function(){return i._uCenter},radius:function(){return i._uRadius},colorTexture2:function(){return i._sceneFramebuffer.framebuffer.getColorTexture(0)}}}),this._stages=new nm({stages:e});let o=new ES(this),a=e.length;for(let s=0;s<a;++s)e[s]._textureCache=o;this._textureCache=o,this.length=e.length}GW.prototype.get=function(t){return this._stages.get(t)};GW.prototype.getStageByName=function(t){let e=this._stages.length;for(let n=0;n<e;++n){let i=this._stages.get(n);if(i.name===t)return i}};var xYe=new Rt,cQt=new K,XYe=new K,mQt=new L;function JYe(t,e,n){let i=e.uniformState,o=i.sunPositionWC,a=i.view,s=i.viewProjection,l=i.projection,r=L.computeViewportTransformation(n,0,1,mQt),d=L.multiplyByPoint(a,o,xYe),m=Pe.pointToGLWindowCoordinates(s,r,o,cQt);d.x+=k.SOLAR_RADIUS;let h=Pe.pointToGLWindowCoordinates(l,r,d,d),Z=K.magnitude(K.subtract(h,m,h))*30*2,b=XYe;b.x=Z,b.y=Z,t._uCenter=K.clone(m,t._uCenter),t._uRadius=Math.max(b.x,b.y)*.15;let u=e.drawingBufferWidth,F=e.drawingBufferHeight,U=t._stages,G=U.get(0),A=G.outputTexture.width,T=G.outputTexture.height,g=new Fe;g.width=A,g.height=T,r=L.computeViewportTransformation(g,0,1,mQt),m=Pe.pointToGLWindowCoordinates(s,r,o,cQt),b.x*=A/u,b.y*=T/F;let C=G.scissorRectangle;C.x=Math.max(m.x-b.x*.5,0),C.y=Math.max(m.y-b.y*.5,0),C.width=Math.min(b.x,u),C.height=Math.min(b.y,F);for(let y=1;y<4;++y)Fe.clone(C,U.get(y).scissorRectangle)}GW.prototype.clear=function(t,e,n){this._sceneFramebuffer.clear(t,e,n),this._textureCache.clear(t)};GW.prototype.update=function(t){let e=t.context,n=t.viewport,i=this._sceneFramebuffer;i.update(e,n);let o=i.framebuffer;return this._textureCache.update(e),this._stages.update(e,!1),JYe(this,e,n),o};GW.prototype.execute=function(t){let e=this._sceneFramebuffer.framebuffer.getColorTexture(0),n=this._stages,i=n.length;n.get(0).execute(t,e);for(let o=1;o<i;++o)n.get(o).execute(t,n.get(o-1).outputTexture)};GW.prototype.copy=function(t,e){if(!c(this._copyColorCommand)){let n=this;this._copyColorCommand=t.createViewportQuadCommand(nh,{uniformMap:{colorTexture:function(){return n._stages.get(n._stages.length-1).outputTexture}},owner:this})}this._copyColorCommand.framebuffer=e,this._copyColorCommand.execute(t)};GW.prototype.isDestroyed=function(){return!1};GW.prototype.destroy=function(){return this._textureCache.destroy(),this._stages.destroy(),At(this)};var y9=GW;var Yko=R(W(),1);function hQt(){this._cachedShowFrustumsShaders={}}function LYe(t){let e={},n=t.vertexAttributes;for(let i in n)n.hasOwnProperty(i)&&(e[i]=n[i].index);return e}function MYe(t,e){let n=t.context,i=e,o=i.fragmentShaderSource.clone(),a=[];o.sources=o.sources.map(function(m){m=Ve.replaceMain(m,"czm_Debug_main");let h=/out_FragData_(\d+)/g,Z;for(;(Z=h.exec(m))!==null;)a.indexOf(Z[1])===-1&&a.push(Z[1]);return m});let s=a.length,l="";l+=`uniform vec3 debugShowCommandsColor; +`;function GW(){this._sceneFramebuffer=new FT;let t=.125,e=new Array(6);e[0]=new Qa({fragmentShader:nh,textureScale:t,forcePowerOfTwo:!0,sampleMode:op.LINEAR});let n=e[1]=new Qa({fragmentShader:N9,uniforms:{avgLuminance:.5,threshold:.25,offset:.1},textureScale:t,forcePowerOfTwo:!0}),i=this;this._delta=1,this._sigma=2,this._blurStep=new K,e[2]=new Qa({fragmentShader:fU,uniforms:{step:function(){return i._blurStep.x=i._blurStep.y=1/n.outputTexture.width,i._blurStep},delta:function(){return i._delta},sigma:function(){return i._sigma},direction:0},textureScale:t,forcePowerOfTwo:!0}),e[3]=new Qa({fragmentShader:fU,uniforms:{step:function(){return i._blurStep.x=i._blurStep.y=1/n.outputTexture.width,i._blurStep},delta:function(){return i._delta},sigma:function(){return i._sigma},direction:1},textureScale:t,forcePowerOfTwo:!0}),e[4]=new Qa({fragmentShader:nh,sampleMode:op.LINEAR}),this._uCenter=new K,this._uRadius=void 0,e[5]=new Qa({fragmentShader:I9,uniforms:{center:function(){return i._uCenter},radius:function(){return i._uRadius},colorTexture2:function(){return i._sceneFramebuffer.framebuffer.getColorTexture(0)}}}),this._stages=new nm({stages:e});let o=new ET(this),a=e.length;for(let s=0;s<a;++s)e[s]._textureCache=o;this._textureCache=o,this.length=e.length}GW.prototype.get=function(t){return this._stages.get(t)};GW.prototype.getStageByName=function(t){let e=this._stages.length;for(let n=0;n<e;++n){let i=this._stages.get(n);if(i.name===t)return i}};var xYe=new bt,cQt=new K,XYe=new K,mQt=new L;function JYe(t,e,n){let i=e.uniformState,o=i.sunPositionWC,a=i.view,s=i.viewProjection,l=i.projection,r=L.computeViewportTransformation(n,0,1,mQt),d=L.multiplyByPoint(a,o,xYe),m=Pe.pointToGLWindowCoordinates(s,r,o,cQt);d.x+=k.SOLAR_RADIUS;let h=Pe.pointToGLWindowCoordinates(l,r,d,d),u=K.magnitude(K.subtract(h,m,h))*30*2,R=XYe;R.x=u,R.y=u,t._uCenter=K.clone(m,t._uCenter),t._uRadius=Math.max(R.x,R.y)*.15;let V=e.drawingBufferWidth,F=e.drawingBufferHeight,U=t._stages,G=U.get(0),A=G.outputTexture.width,S=G.outputTexture.height,g=new Fe;g.width=A,g.height=S,r=L.computeViewportTransformation(g,0,1,mQt),m=Pe.pointToGLWindowCoordinates(s,r,o,cQt),R.x*=A/V,R.y*=S/F;let C=G.scissorRectangle;C.x=Math.max(m.x-R.x*.5,0),C.y=Math.max(m.y-R.y*.5,0),C.width=Math.min(R.x,V),C.height=Math.min(R.y,F);for(let y=1;y<4;++y)Fe.clone(C,U.get(y).scissorRectangle)}GW.prototype.clear=function(t,e,n){this._sceneFramebuffer.clear(t,e,n),this._textureCache.clear(t)};GW.prototype.update=function(t){let e=t.context,n=t.viewport,i=this._sceneFramebuffer;i.update(e,n);let o=i.framebuffer;return this._textureCache.update(e),this._stages.update(e,!1),JYe(this,e,n),o};GW.prototype.execute=function(t){let e=this._sceneFramebuffer.framebuffer.getColorTexture(0),n=this._stages,i=n.length;n.get(0).execute(t,e);for(let o=1;o<i;++o)n.get(o).execute(t,n.get(o-1).outputTexture)};GW.prototype.copy=function(t,e){if(!c(this._copyColorCommand)){let n=this;this._copyColorCommand=t.createViewportQuadCommand(nh,{uniformMap:{colorTexture:function(){return n._stages.get(n._stages.length-1).outputTexture}},owner:this})}this._copyColorCommand.framebuffer=e,this._copyColorCommand.execute(t)};GW.prototype.isDestroyed=function(){return!1};GW.prototype.destroy=function(){return this._textureCache.destroy(),this._stages.destroy(),At(this)};var y9=GW;var Y2o=b(W(),1);function hQt(){this._cachedShowFrustumsShaders={}}function LYe(t){let e={},n=t.vertexAttributes;for(let i in n)n.hasOwnProperty(i)&&(e[i]=n[i].index);return e}function MYe(t,e){let n=t.context,i=e,o=i.fragmentShaderSource.clone(),a=[];o.sources=o.sources.map(function(m){m=Ze.replaceMain(m,"czm_Debug_main");let h=/out_FragData_(\d+)/g,u;for(;(u=h.exec(m))!==null;)a.indexOf(u[1])===-1&&a.push(u[1]);return m});let s=a.length,l="";l+=`uniform vec3 debugShowCommandsColor; `,l+=`uniform vec3 debugShowFrustumsColor; `,l+=`void main() { @@ -12673,7 +12673,7 @@ void main() `,l+=` out_FragData_${a[r]}.rgb *= debugShowFrustumsColor; `;else l+=` out_FragColor.rgb *= debugShowCommandsColor; `,l+=` out_FragColor.rgb *= debugShowFrustumsColor; -`;l+="}",o.sources.push(l);let d=LYe(i);return xn.fromCache({context:n,vertexShaderSource:i.vertexShaderSource,fragmentShaderSource:o,attributeLocations:d})}var B9=new v;function _Ye(t,e){let n;return c(e.uniformMap)?n=e.uniformMap:n={},c(n.debugShowCommandsColor)||c(n.debugShowFrustumsColor)||(n.debugShowCommandsColor=function(){return t.debugShowCommands?(c(e._debugColor)||(e._debugColor=v.fromRandom()),e._debugColor):v.WHITE},n.debugShowFrustumsColor=function(){return t.debugShowFrustums?(B9.red=e.debugOverlappingFrustums&1?1:0,B9.green=e.debugOverlappingFrustums&2?1:0,B9.blue=e.debugOverlappingFrustums&4?1:0,B9.alpha=1,B9):v.WHITE}),n}var DYe=new Ee;hQt.prototype.executeDebugShowFrustumsCommand=function(t,e,n){let i=e.shaderProgram.id,o=this._cachedShowFrustumsShaders[i];c(o)||(o=MYe(t,e.shaderProgram),this._cachedShowFrustumsShaders[i]=o);let a=Ee.shallowClone(e,DYe);a.shaderProgram=o,a.uniformMap=_Ye(t,e),a.execute(t.context,n)};var Q9=hQt;var _ko=R(W(),1);function QS(t,e,n){this._primitive=t,this._tileIndex=e,this._sampleIndex=n,this._metadata={},this._orientedBoundingBox=new ci}QS.fromKeyframeNode=function(t,e,n,i){let o=new QS(t,e,n),{spatialNode:a,metadata:s}=i;return o._metadata=OYe(t,s,n),o._orientedBoundingBox=wYe(t,a,n,o._orientedBoundingBox),o};function OYe(t,e,n){if(!c(e))return;let{names:i,types:o}=t.provider,a={};for(let s=0;s<i.length;s++){let l=i[s],r=Nn.getComponentCount(o[s]),d=e[s].slice(n*r,(n+1)*r);a[l]=d}return a}var pQt=new p,HYe=new p;function wYe(t,e,n,i){let o=e.dimensions,a=o.x*o.y,s=Math.floor(n/a),l=n-s*a,r=Math.floor(l/o.x),d=l-r*o.x,m=p.fromElements(d,r,s,pQt),h=p.divideComponents(p.subtract(m,t._paddingBefore,pQt),t.dimensions,HYe);return t._shape.computeOrientedBoundingBoxForSample(e,t.dimensions,h,i)}Object.defineProperties(QS.prototype,{metadata:{get:function(){return this._metadata}},primitive:{get:function(){return this._primitive}},sampleIndex:{get:function(){return this._sampleIndex}},tileIndex:{get:function(){return this._tileIndex}},orientedBoundingBox:{get:function(){return this._orientedBoundingBox.clone()}}});QS.prototype.hasProperty=function(t){return c(this._metadata[t])};QS.prototype.getNames=function(){return Object.keys(this._metadata)};QS.prototype.getProperty=function(t){return this._metadata[t]};var k9=QS;var DJo=R(W(),1);var lxo=R(W(),1);var DYo=R(W(),1);var Oko=R(W(),1),Y9=`struct Ray { +`;l+="}",o.sources.push(l);let d=LYe(i);return xn.fromCache({context:n,vertexShaderSource:i.vertexShaderSource,fragmentShaderSource:o,attributeLocations:d})}var B9=new v;function _Ye(t,e){let n;return c(e.uniformMap)?n=e.uniformMap:n={},c(n.debugShowCommandsColor)||c(n.debugShowFrustumsColor)||(n.debugShowCommandsColor=function(){return t.debugShowCommands?(c(e._debugColor)||(e._debugColor=v.fromRandom()),e._debugColor):v.WHITE},n.debugShowFrustumsColor=function(){return t.debugShowFrustums?(B9.red=e.debugOverlappingFrustums&1?1:0,B9.green=e.debugOverlappingFrustums&2?1:0,B9.blue=e.debugOverlappingFrustums&4?1:0,B9.alpha=1,B9):v.WHITE}),n}var DYe=new Ee;hQt.prototype.executeDebugShowFrustumsCommand=function(t,e,n){let i=e.shaderProgram.id,o=this._cachedShowFrustumsShaders[i];c(o)||(o=MYe(t,e.shaderProgram),this._cachedShowFrustumsShaders[i]=o);let a=Ee.shallowClone(e,DYe);a.shaderProgram=o,a.uniformMap=_Ye(t,e),a.execute(t.context,n)};var Q9=hQt;var _2o=b(W(),1);function QT(t,e,n){this._primitive=t,this._tileIndex=e,this._sampleIndex=n,this._metadata={},this._orientedBoundingBox=new ci}QT.fromKeyframeNode=function(t,e,n,i){let o=new QT(t,e,n),{spatialNode:a,metadata:s}=i;return o._metadata=OYe(t,s,n),o._orientedBoundingBox=wYe(t,a,n,o._orientedBoundingBox),o};function OYe(t,e,n){if(!c(e))return;let{names:i,types:o}=t.provider,a={};for(let s=0;s<i.length;s++){let l=i[s],r=Nn.getComponentCount(o[s]),d=e[s].slice(n*r,(n+1)*r);a[l]=d}return a}var pQt=new p,HYe=new p;function wYe(t,e,n,i){let o=e.dimensions,a=o.x*o.y,s=Math.floor(n/a),l=n-s*a,r=Math.floor(l/o.x),d=l-r*o.x,m=p.fromElements(d,r,s,pQt),h=p.divideComponents(p.subtract(m,t._paddingBefore,pQt),t.dimensions,HYe);return t._shape.computeOrientedBoundingBoxForSample(e,t.dimensions,h,i)}Object.defineProperties(QT.prototype,{metadata:{get:function(){return this._metadata}},primitive:{get:function(){return this._primitive}},sampleIndex:{get:function(){return this._sampleIndex}},tileIndex:{get:function(){return this._tileIndex}},orientedBoundingBox:{get:function(){return this._orientedBoundingBox.clone()}}});QT.prototype.hasProperty=function(t){return c(this._metadata[t])};QT.prototype.getNames=function(){return Object.keys(this._metadata)};QT.prototype.getProperty=function(t){return this._metadata[t]};var k9=QT;var DJo=b(W(),1);var lxo=b(W(),1);var DYo=b(W(),1);var O2o=b(W(),1),Y9=`struct Ray { vec3 pos; vec3 dir; vec3 rawDir; @@ -12704,7 +12704,7 @@ struct PointJacobianT { vec3 point; mat3 jacobianT; }; -`;var wko=R(W(),1),x9=`// See Intersection.glsl for the definition of intersectScene +`;var w2o=b(W(),1),x9=`// See Intersection.glsl for the definition of intersectScene // See IntersectionUtils.glsl for the definition of nextIntersection // See convertUvToBox.glsl, convertUvToCylinder.glsl, or convertUvToEllipsoid.glsl // for the definition of convertUvToShapeUvSpace. The appropriate function is @@ -12962,7 +12962,7 @@ void main() out_FragColor = colorAccum; #endif } -`;var vko=R(W(),1),X9=`in vec2 position; +`;var v2o=b(W(),1),X9=`in vec2 position; uniform vec4 u_ndcSpaceAxisAlignedBoundingBox; @@ -12973,7 +12973,7 @@ void main() { vec2 scale = 0.5 * (aabbMax - aabbMin); gl_Position = vec4(position * scale + translation, 0.0, 1.0); } -`;var zko=R(W(),1),J9=`/* Intersection defines +`;var z2o=b(W(),1),J9=`/* Intersection defines #define INTERSECTION_COUNT ### */ @@ -13139,7 +13139,7 @@ RayShapeIntersection nextIntersection(inout Intersections ix) { #endif // NOTE: initializeIntersections, nextIntersection aren't even declared unless INTERSECTION_COUNT > 1 -`;var qko=R(W(),1),L9=`// See IntersectionUtils.glsl for the definitions of Ray, Intersections, +`;var q2o=b(W(),1),L9=`// See IntersectionUtils.glsl for the definitions of Ray, Intersections, // setIntersectionPair, INF_HIT, NO_HIT /* intersectDepth defines (set in Scene/VoxelRenderResources.js) @@ -13162,7 +13162,7 @@ void intersectDepth(in vec2 screenCoord, in Ray ray, inout Intersections ix) { setIntersectionPair(ix, DEPTH_INTERSECTION_INDEX, vec2(NO_HIT)); } } -`;var tYo=R(W(),1),M9=`// See IntersectionUtils.glsl for the definitions of Ray, Intersections, INF_HIT, +`;var tYo=b(W(),1),M9=`// See IntersectionUtils.glsl for the definitions of Ray, Intersections, INF_HIT, // NO_HIT, setShapeIntersection /* Clipping plane defines (set in Scene/VoxelRenderResources.js) @@ -13240,7 +13240,7 @@ void intersectClippingPlanes(in Ray ray, inout Intersections ix) { setShapeIntersection(ix, CLIPPING_PLANES_INTERSECTION_INDEX, clippingVolume); #endif } -`;var nYo=R(W(),1),w1=`// See IntersectionUtils.glsl for the definitions of Ray, NO_HIT, INF_HIT, +`;var nYo=b(W(),1),w1=`// See IntersectionUtils.glsl for the definitions of Ray, NO_HIT, INF_HIT, // RayShapeIntersection vec4 intersectLongitude(in Ray ray, in float angle, in bool positiveNormal) { @@ -13342,7 +13342,7 @@ RayShapeIntersection intersectRegularWedge(in Ray ray, in vec2 minMaxAngle) return RayShapeIntersection(miss, miss); } } -`;var oYo=R(W(),1),_9=`// See IntersectionUtils.glsl for the definitions of Ray, RayShapeIntersection, +`;var oYo=b(W(),1),_9=`// See IntersectionUtils.glsl for the definitions of Ray, RayShapeIntersection, // NO_HIT, Intersections /* Box defines (set in Scene/VoxelBoxShape.js) @@ -13389,7 +13389,7 @@ void intersectShape(in Ray ray, inout Intersections ix) RayShapeIntersection intersection = intersectBox(ray, u_renderMinBounds, u_renderMaxBounds); setShapeIntersection(ix, BOX_INTERSECTION_INDEX, intersection); } -`;var sYo=R(W(),1),D9=`// See IntersectionUtils.glsl for the definitions of Ray, NO_HIT, Intersections, +`;var sYo=b(W(),1),D9=`// See IntersectionUtils.glsl for the definitions of Ray, NO_HIT, Intersections, // RayShapeIntersection, setSurfaceIntersection, setShapeIntersection, // intersectIntersections // See IntersectLongitude.glsl for the definitions of intersectHalfPlane, @@ -13535,7 +13535,7 @@ void intersectShape(Ray ray, inout Intersections ix) setShapeIntersection(ix, CYLINDER_INTERSECTION_INDEX_ANGLE + 1, wedgeIntersects[1]); #endif } -`;var rYo=R(W(),1),O9=`// See IntersectionUtils.glsl for the definitions of Ray, NO_HIT, INF_HIT, Intersections, +`;var rYo=b(W(),1),O9=`// See IntersectionUtils.glsl for the definitions of Ray, NO_HIT, INF_HIT, Intersections, // RayShapeIntersection, setSurfaceIntersection, setShapeIntersection // See IntersectLongitude.glsl for the definitions of intersectHalfPlane, // intersectFlippedWedge, intersectRegularWedge @@ -13873,7 +13873,7 @@ void intersectShape(in Ray ray, inout Intersections ix) { setShapeIntersection(ix, ELLIPSOID_INTERSECTION_INDEX_LONGITUDE + 1, wedgeIntersects[1]); #endif } -`;var cYo=R(W(),1),kS=`// Main intersection function for Voxel scenes. +`;var cYo=b(W(),1),kT=`// Main intersection function for Voxel scenes. // See IntersectBox.glsl, IntersectCylinder.glsl, or IntersectEllipsoid.glsl // for the definition of intersectShape. The appropriate function is selected // based on the VoxelPrimitive shape type, and added to the shader in @@ -13925,7 +13925,7 @@ RayShapeIntersection intersectScene(in vec2 screenCoord, in Ray ray, out Interse return intersection; } -`;var hYo=R(W(),1),H9=`/* Box defines (set in Scene/VoxelBoxShape.js) +`;var hYo=b(W(),1),H9=`/* Box defines (set in Scene/VoxelBoxShape.js) #define BOX_HAS_SHAPE_BOUNDS */ @@ -13969,7 +13969,7 @@ vec3 scaleShapeUvToShapeSpace(in vec3 shapeUv) { #else return shapeUv; #endif -}`;var uYo=R(W(),1),w9=`/* Cylinder defines (set in Scene/VoxelCylinderShape.js) +}`;var VYo=b(W(),1),w9=`/* Cylinder defines (set in Scene/VoxelCylinderShape.js) #define CYLINDER_HAS_SHAPE_BOUNDS_RADIUS #define CYLINDER_HAS_SHAPE_BOUNDS_HEIGHT #define CYLINDER_HAS_SHAPE_BOUNDS_ANGLE @@ -14068,7 +14068,7 @@ vec3 scaleShapeUvToShapeSpace(in vec3 shapeUv) { return vec3(radius, height, angle); } -`;var VYo=R(W(),1),P9=`/* Ellipsoid defines (set in Scene/VoxelEllipsoidShape.js) +`;var ZYo=b(W(),1),P9=`/* Ellipsoid defines (set in Scene/VoxelEllipsoidShape.js) #define ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_MIN_DISCONTINUITY #define ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_MAX_DISCONTINUITY #define ELLIPSOID_HAS_SHAPE_BOUNDS_LONGITUDE @@ -14207,7 +14207,7 @@ vec3 scaleShapeUvToShapeSpace(in vec3 shapeUv) { return vec3(longitude, latitude, height); } -`;var RYo=R(W(),1),v9=`// These octree flags must be in sync with GpuOctreeFlag in VoxelTraversal.js +`;var bYo=b(W(),1),v9=`// These octree flags must be in sync with GpuOctreeFlag in VoxelTraversal.js #define OCTREE_FLAG_INTERNAL 0 #define OCTREE_FLAG_LEAF 1 #define OCTREE_FLAG_PACKED_LEAF_FROM_PARENT 2 @@ -14432,7 +14432,7 @@ void traverseOctreeFromExisting(in vec3 shapePosition, inout TraversalData trave sampleDatas[1].tileUv = getClampedTileUv(shapePosition, sampleDatas[1].tileCoords); #endif } -`;var fYo=R(W(),1),K9=`// See Octree.glsl for the definitions of SampleData and intMod +`;var fYo=b(W(),1),K9=`// See Octree.glsl for the definitions of SampleData and intMod /* Megatexture defines (set in Scene/VoxelRenderResources.js) #define SAMPLE_COUNT ### @@ -14567,11 +14567,11 @@ Properties accumulatePropertiesFromMegatexture(in SampleData sampleDatas[SAMPLE_ return properties; #endif } -`;function PYe(t){let e=new EG;this.shaderBuilder=e;let n=t._customShader,i=ze(t._uniformMap,n.uniformMap);t._uniformMap=i;let o=n.uniforms;for(let Z in o)if(o.hasOwnProperty(Z)){let b=o[Z];e.addUniform(b.type,Z,Xt.FRAGMENT)}e.addUniform("sampler2D","u_megatextureTextures[METADATA_COUNT]",Xt.FRAGMENT),this.uniformMap=i;let a=t._clippingPlanes,s=c(a)&&a.enabled?a.length:0;this.clippingPlanes=a,this.clippingPlanesLength=s,e.addVertexLines([X9]),e.addFragmentLines([n.fragmentShaderText,"#line 0",v9,Y9,J9,K9]),s>0&&(e.addDefine("CLIPPING_PLANES",void 0,Xt.FRAGMENT),e.addDefine("CLIPPING_PLANES_COUNT",s,Xt.FRAGMENT),a.unionClippingRegions&&e.addDefine("CLIPPING_PLANES_UNION",void 0,Xt.FRAGMENT),e.addFragmentLines([M9])),t._depthTest&&(e.addDefine("DEPTH_TEST",void 0,Xt.FRAGMENT),e.addFragmentLines([L9]));let l=t._provider.shape;l==="BOX"?e.addFragmentLines([H9,_9,kS]):l==="CYLINDER"?e.addFragmentLines([w9,w1,D9,kS]):l==="ELLIPSOID"&&(e.addDefine("SHAPE_ELLIPSOID",void 0,Xt.FRAGMENT),e.addFragmentLines([P9,w1,O9,kS])),e.addFragmentLines([x9]);let r=t._shape,d=r.shaderDefines;for(let Z in d)if(d.hasOwnProperty(Z)){let b=d[Z];c(b)&&(b=b===!0?void 0:b,e.addDefine(Z,b,Xt.FRAGMENT))}let m=r.shaderMaximumIntersectionsLength;s>0&&(e.addDefine("CLIPPING_PLANES_INTERSECTION_INDEX",m,Xt.FRAGMENT),s===1?m+=1:a.unionClippingRegions?m+=2:m+=1),t._depthTest&&(e.addDefine("DEPTH_INTERSECTION_INDEX",m,Xt.FRAGMENT),m+=1),e.addDefine("INTERSECTION_COUNT",m,Xt.FRAGMENT),(!p.equals(t.paddingBefore,p.ZERO)||!p.equals(t.paddingAfter,p.ZERO))&&e.addDefine("PADDING",void 0,Xt.FRAGMENT),t._useLogDepth&&e.addDefine("LOG_DEPTH_READ_ONLY",void 0,Xt.FRAGMENT),t._jitter&&e.addDefine("JITTER",void 0,Xt.FRAGMENT),t._nearestSampling&&e.addDefine("NEAREST_SAMPLING",void 0,Xt.FRAGMENT);let h=t._traversal;e.addDefine("SAMPLE_COUNT",`${h._sampleCount}`,Xt.FRAGMENT)}var z9=PYe;var vYo=R(W(),1);function vYe(t,e){let{shaderBuilder:n}=t,{names:i,types:o,componentTypes:a,minimumValues:s,maximumValues:l}=e._provider,r=o.length,d=c(s)&&c(l);n.addDefine("METADATA_COUNT",r,Xt.FRAGMENT),d&&n.addDefine("STATISTICS",void 0,Xt.FRAGMENT);for(let Q=0;Q<r;Q++){let J=i[Q],M=o[Q],V=`PropertyStatistics_${J}`,E=`PropertyStatistics_${J}`;n.addStruct(V,E,Xt.FRAGMENT);let I=Aj(M);n.addStructField(V,I,"min"),n.addStructField(V,I,"max")}let m="Statistics",h="Statistics",Z="statistics";n.addStruct(m,h,Xt.FRAGMENT);for(let Q=0;Q<r;Q++){let J=i[Q],M=`PropertyStatistics_${J}`,V=J;n.addStructField(m,M,V)}let b="Metadata",u="Metadata",F="metadata";n.addStruct(b,u,Xt.FRAGMENT),n.addStructField(b,h,Z);for(let Q=0;Q<r;Q++){let J=i[Q],M=o[Q],V=Aj(M);n.addStructField(b,V,J)}for(let Q=0;Q<r;Q++){let J=i[Q],M=o[Q],V=zYe(M),E=`VoxelProperty_${J}`,I=`VoxelProperty_${J}`;n.addStruct(E,I,Xt.FRAGMENT),n.addStructField(E,V,"partialDerivativeLocal"),n.addStructField(E,V,"partialDerivativeWorld"),n.addStructField(E,V,"partialDerivativeView"),n.addStructField(E,V,"partialDerivativeValid")}let U="Voxel",G="Voxel",A="voxel";n.addStruct(U,G,Xt.FRAGMENT);for(let Q=0;Q<r;Q++){let J=i[Q],M=`VoxelProperty_${J}`;n.addStructField(U,M,J)}n.addStructField(U,"vec3","positionEC"),n.addStructField(U,"vec3","positionUv"),n.addStructField(U,"vec3","positionShapeUv"),n.addStructField(U,"vec3","positionUvLocal"),n.addStructField(U,"vec3","viewDirUv"),n.addStructField(U,"vec3","viewDirWorld"),n.addStructField(U,"vec3","surfaceNormal"),n.addStructField(U,"float","travelDistance"),n.addStructField(U,"int","stepCount"),n.addStructField(U,"int","tileIndex"),n.addStructField(U,"int","sampleIndex");let T="FragmentInput";n.addStruct(T,"FragmentInput",Xt.FRAGMENT),n.addStructField(T,u,F),n.addStructField(T,G,A);let C="Properties",y="Properties",Y="properties";n.addStruct(C,y,Xt.FRAGMENT);for(let Q=0;Q<r;Q++){let J=i[Q],M=o[Q],V=Aj(M);n.addStructField(C,V,J)}{let Q="clearProperties";n.addFunction(Q,`${y} clearProperties()`,Xt.FRAGMENT),n.addFunctionLines(Q,[`${y} ${Y};`]);for(let J=0;J<r;J++){let M=i[J],V=o[J],E=a[J],I=Aj(V,E);n.addFunctionLines(Q,[`${Y}.${M} = ${I}(0.0);`])}n.addFunctionLines(Q,[`return ${Y};`])}{let Q="sumProperties";n.addFunction(Q,`${y} sumProperties(${y} propertiesA, ${y} propertiesB)`,Xt.FRAGMENT),n.addFunctionLines(Q,[`${y} ${Y};`]);for(let J=0;J<r;J++){let M=i[J];n.addFunctionLines(Q,[`${Y}.${M} = propertiesA.${M} + propertiesB.${M};`])}n.addFunctionLines(Q,[`return ${Y};`])}{let Q="scaleProperties";n.addFunction(Q,`${y} scaleProperties(${y} ${Y}, float scale)`,Xt.FRAGMENT),n.addFunctionLines(Q,[`${y} scaledProperties = ${Y};`]);for(let J=0;J<r;J++){let M=i[J];n.addFunctionLines(Q,[`scaledProperties.${M} *= scale;`])}n.addFunctionLines(Q,["return scaledProperties;"])}{let Q="mixProperties";n.addFunction(Q,`${y} mixProperties(${y} propertiesA, ${y} propertiesB, float mixFactor)`,Xt.FRAGMENT),n.addFunctionLines(Q,[`${y} ${Y};`]);for(let J=0;J<r;J++){let M=i[J];n.addFunctionLines(Q,[`${Y}.${M} = mix(propertiesA.${M}, propertiesB.${M}, mixFactor);`])}n.addFunctionLines(Q,[`return ${Y};`])}{let Q="copyPropertiesToMetadata";n.addFunction(Q,`void copyPropertiesToMetadata(in ${y} ${Y}, inout ${u} ${F})`,Xt.FRAGMENT);for(let J=0;J<r;J++){let M=i[J];n.addFunctionLines(Q,[`${F}.${M} = ${Y}.${M};`])}}if(d){let Q="setStatistics";n.addFunction(Q,`void setStatistics(inout ${h} ${Z})`,Xt.FRAGMENT);for(let J=0;J<r;J++){let M=i[J],V=o[J],E=Nn.getComponentCount(V);for(let I=0;I<E;I++){let B=jYe(V,I),X=s[J][I],_=l[J][I];n.addFunctionLines(Q,[`${Z}.${M}.min${B} = ${uQt(X)};`,`${Z}.${M}.max${B} = ${uQt(_)};`])}}}{let Q="getPropertiesFromMegatextureAtUv";n.addFunction(Q,`${y} getPropertiesFromMegatextureAtUv(vec2 texcoord)`,Xt.FRAGMENT),n.addFunctionLines(Q,[`${y} ${Y};`]);for(let J=0;J<r;J++){let M=i[J],V=o[J],E=a[J],I=KYe(V,E);n.addFunctionLines(Q,[`properties.${M} = texture(u_megatextureTextures[${J}], texcoord)${I};`])}n.addFunctionLines(Q,[`return ${Y};`])}}function Aj(t){if(t===Nn.SCALAR)return"float";if(t===Nn.VEC2)return"vec2";if(t===Nn.VEC3)return"vec3";if(t===Nn.VEC4)return"vec4"}function KYe(t){if(t===Nn.SCALAR)return".r";if(t===Nn.VEC2)return".ra";if(t===Nn.VEC3)return".rgb";if(t===Nn.VEC4)return""}function zYe(t){if(t===Nn.SCALAR)return"vec3";if(t===Nn.VEC2)return"mat2";if(t===Nn.VEC3)return"mat3";if(t===Nn.VEC4)return"mat4"}function uQt(t){let e=t.toString();return e.indexOf(".")===-1&&(e=`${t}.0`),e}function jYe(t,e){return t===Nn.SCALAR?"":`[${e}]`}var j9=vYe;function qYe(t,e){let n=new z9(t);j9(n,t);let{shaderBuilder:i,clippingPlanes:o,clippingPlanesLength:a}=n;if(a>0){let G="getClippingPlane",A=dW(o,e),T=0,g=A.indexOf(")")+1,C=A.indexOf("{",g)+1,y=A.indexOf("}",C),Y=A.slice(T,g),Q=A.slice(C,y);i.addFunction(G,Y,Xt.FRAGMENT),i.addFunctionLines(G,[Q])}let s=i.clone();s.addDefine("PICKING",void 0,Xt.FRAGMENT);let l=i.clone();l.addDefine("PICKING_VOXEL",void 0,Xt.FRAGMENT);let r=i.buildShaderProgram(e),d=s.buildShaderProgram(e),m=l.buildShaderProgram(e),h=he.fromCache({cull:{enabled:!0,face:so.BACK},depthTest:{enabled:!1},depthMask:!1,blending:Pn.PRE_MULTIPLIED_ALPHA_BLEND}),Z=e.getViewportQuadVertexArray(),b=t._depthTest,u=new Ee({vertexArray:Z,primitiveType:le.TRIANGLES,renderState:h,shaderProgram:r,uniformMap:n.uniformMap,modelMatrix:t._compoundModelMatrix,pass:Pt.VOXELS,executeInClosestFrustum:!0,owner:this,cull:b,occlude:b}),F=Ee.shallowClone(u,new Ee);F.shaderProgram=d,F.pickOnly=!0;let U=Ee.shallowClone(u,new Ee);if(U.shaderProgram=m,U.pickOnly=!0,c(t._drawCommand)){let G=t._drawCommand;G.shaderProgram=G.shaderProgram&&G.shaderProgram.destroy()}if(c(t._drawCommandPick)){let G=t._drawCommandPick;G.shaderProgram=G.shaderProgram&&G.shaderProgram.destroy()}if(c(t._drawCommandPickVoxel)){let G=t._drawCommandPickVoxel;G.shaderProgram=G.shaderProgram&&G.shaderProgram.destroy()}t._drawCommand=u,t._drawCommandPick=F,t._drawCommandPickVoxel=U}var q9=qYe;var Oxo=R(W(),1);var Vxo=R(W(),1);function ih(){this.orientedBoundingBox=new ci,this.boundingSphere=new Ft,this.boundTransform=new L,this.shapeTransform=new L,this._minBounds=p.clone(ih.DefaultMinBounds,new p),this._maxBounds=p.clone(ih.DefaultMaxBounds,new p),this.shaderUniforms={renderMinBounds:new p,renderMaxBounds:new p,boxUvToShapeUvScale:new p,boxUvToShapeUvTranslate:new p},this.shaderDefines={BOX_INTERSECTION_INDEX:void 0,BOX_HAS_SHAPE_BOUNDS:void 0},this.shaderMaximumIntersectionsLength=0}var $Ye=new p,lst=new p,txe=new ot,exe=new p,nxe=new p,ixe=new p,oxe=new p,ZQt=L.fromRotationTranslation(ot.fromUniformScale(.5,new ot),new p(.5,.5,.5),new L);ih.prototype.update=function(t,e,n,i,o){i=f(i,ih.DefaultMinBounds),o=f(o,ih.DefaultMaxBounds);let a=ih.DefaultMinBounds,s=ih.DefaultMaxBounds;e=this._minBounds=p.clamp(e,a,s,this._minBounds),n=this._maxBounds=p.clamp(n,a,s,this._maxBounds),i=p.clamp(i,a,s,exe),o=p.clamp(o,a,s,nxe);let l=p.clamp(e,i,o,ixe),r=p.clamp(n,i,o,oxe),d=L.getScale(t,lst);if(l.x>r.x||l.y>r.y||l.z>r.z||(l.x===r.x)+(l.y===r.y)+(l.z===r.z)>=2||i.x>o.x||i.y>o.y||i.z>o.z||d.x===0||d.y===0||d.z===0)return!1;this.shapeTransform=L.clone(t,this.shapeTransform),this.orientedBoundingBox=dst(l,r,this.shapeTransform,this.orientedBoundingBox),this.boundTransform=L.fromRotationTranslation(this.orientedBoundingBox.halfAxes,this.orientedBoundingBox.center,this.boundTransform),this.boundingSphere=Ft.fromOrientedBoundingBox(this.orientedBoundingBox,this.boundingSphere);let{shaderUniforms:m,shaderDefines:h}=this;for(let u in h)h.hasOwnProperty(u)&&(h[u]=void 0);let Z=!p.equals(e,a)||!p.equals(n,s),b=0;if(h.BOX_INTERSECTION_INDEX=b,b+=1,m.renderMinBounds=L.multiplyByPoint(ZQt,l,m.renderMinBounds),m.renderMaxBounds=L.multiplyByPoint(ZQt,r,m.renderMaxBounds),Z){h.BOX_HAS_SHAPE_BOUNDS=!0;let u=e,F=n;m.boxUvToShapeUvScale=p.fromElements(2/(u.x===F.x?1:F.x-u.x),2/(u.y===F.y?1:F.y-u.y),2/(u.z===F.z?1:F.z-u.z),m.boxUvToShapeUvScale),m.boxUvToShapeUvTranslate=p.fromElements(-m.boxUvToShapeUvScale.x*(u.x*.5+.5),-m.boxUvToShapeUvScale.y*(u.y*.5+.5),-m.boxUvToShapeUvScale.z*(u.z*.5+.5),m.boxUvToShapeUvTranslate)}return this.shaderMaximumIntersectionsLength=b,!0};var Tj=new p,rst=new p;ih.prototype.computeOrientedBoundingBoxForTile=function(t,e,n,i,o){let a=this._minBounds,s=this._maxBounds,l=1/Math.pow(2,t),r=p.fromElements(k.lerp(a.x,s.x,l*e),k.lerp(a.y,s.y,l*n),k.lerp(a.z,s.z,l*i),Tj),d=p.fromElements(k.lerp(a.x,s.x,l*(e+1)),k.lerp(a.y,s.y,l*(n+1)),k.lerp(a.z,s.z,l*(i+1)),rst);return dst(r,d,this.shapeTransform,o)};var VQt=new p;ih.prototype.computeOrientedBoundingBoxForSample=function(t,e,n,i){let o=1/Math.pow(2,t.level),a=p.divideComponents(p.ONE,e,VQt),s=p.multiplyByScalar(a,o,VQt),l=p.multiplyByScalar(p.fromElements(t.x+n.x,t.y+n.y,t.z+n.z,Tj),o,Tj),r=p.add(l,s,rst),d=this._minBounds,m=this._maxBounds,h=p.fromElements(k.lerp(d.x,m.x,l.x),k.lerp(d.y,m.y,l.y),k.lerp(d.z,m.z,l.z),Tj),Z=p.fromElements(k.lerp(d.x,m.x,r.x),k.lerp(d.y,m.y,r.y),k.lerp(d.z,m.z,r.z),rst);return dst(h,Z,this.shapeTransform,i)};ih.DefaultMinBounds=Object.freeze(new p(-1,-1,-1));ih.DefaultMaxBounds=Object.freeze(new p(1,1,1));function dst(t,e,n,i){let o=ih.DefaultMinBounds,a=ih.DefaultMaxBounds;if(p.equals(t,o)&&p.equals(e,a))i.center=L.getTranslation(n,i.center),i.halfAxes=L.getMatrix3(n,i.halfAxes);else{let l=L.getScale(n,lst),r=p.midpoint(t,e,$Ye);i.center=L.multiplyByPoint(n,r,i.center),l=p.fromElements(l.x*.5*(e.x-t.x),l.y*.5*(e.y-t.y),l.z*.5*(e.z-t.z),lst);let d=L.getRotation(n,txe);i.halfAxes=ot.setScale(d,l,i.halfAxes)}return i}var Pb=ih;var gxo=R(W(),1);function Cl(){this.orientedBoundingBox=new ci,this.boundingSphere=new Ft,this.boundTransform=new L,this.shapeTransform=new L,this._minimumRadius=Cl.DefaultMinBounds.x,this._maximumRadius=Cl.DefaultMaxBounds.x,this._minimumHeight=Cl.DefaultMinBounds.y,this._maximumHeight=Cl.DefaultMaxBounds.y,this._minimumAngle=Cl.DefaultMinBounds.z,this._maximumAngle=Cl.DefaultMaxBounds.z,this.shaderUniforms={cylinderRenderHeightMinMax:new K,cylinderRenderRadiusMinMax:new K,cylinderRenderAngleMinMax:new K,cylinderUvToShapeUvRadius:new K,cylinderUvToShapeUvHeight:new K,cylinderUvToShapeUvAngle:new K,cylinderShapeUvAngleMinMax:new K,cylinderShapeUvAngleRangeZeroMid:0},this.shaderDefines={CYLINDER_HAS_RENDER_BOUNDS_RADIUS_MIN:void 0,CYLINDER_HAS_RENDER_BOUNDS_RADIUS_FLAT:void 0,CYLINDER_HAS_RENDER_BOUNDS_ANGLE:void 0,CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_EQUAL_ZERO:void 0,CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_UNDER_HALF:void 0,CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_OVER_HALF:void 0,CYLINDER_HAS_SHAPE_BOUNDS_RADIUS:void 0,CYLINDER_HAS_SHAPE_BOUNDS_HEIGHT:void 0,CYLINDER_HAS_SHAPE_BOUNDS_ANGLE:void 0,CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MIN_DISCONTINUITY:void 0,CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MAX_DISCONTINUITY:void 0,CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MIN_MAX_REVERSED:void 0,CYLINDER_INTERSECTION_INDEX_RADIUS_MAX:void 0,CYLINDER_INTERSECTION_INDEX_RADIUS_MIN:void 0,CYLINDER_INTERSECTION_INDEX_ANGLE:void 0},this.shaderMaximumIntersectionsLength=0}var fQt=new p;Cl.prototype.update=function(t,e,n,i,o){i=f(i,Cl.DefaultMinBounds),o=f(o,Cl.DefaultMaxBounds);let a=Cl.DefaultMinBounds.x,s=Cl.DefaultMaxBounds.x,l=Cl.DefaultMinBounds.y,r=Cl.DefaultMaxBounds.y,d=Cl.DefaultMinBounds.z,m=Cl.DefaultMaxBounds.z,h=m-d,Z=.5*h,b=k.EPSILON10,u=k.EPSILON3,F=k.EPSILON10,U=k.clamp(e.x,a,s),G=k.clamp(n.x,a,s),A=k.clamp(i.x,a,s),T=k.clamp(o.x,a,s),g=Math.max(U,A),C=Math.min(G,T),y=k.clamp(e.y,l,r),Y=k.clamp(n.y,l,r),Q=k.clamp(i.y,l,r),J=k.clamp(o.y,l,r),M=Math.max(y,Q),V=Math.min(Y,J),E=k.negativePiToPi(e.z),I=k.negativePiToPi(n.z),B=k.negativePiToPi(i.z),X=k.negativePiToPi(o.z),_=Math.max(E,B),P=Math.min(I,X),w=L.getScale(t,fQt);if(C===0||g>C||M>V||k.equalsEpsilon(w.x,0,void 0,b)||k.equalsEpsilon(w.y,0,void 0,b)||k.equalsEpsilon(w.z,0,void 0,b))return!1;this._minimumRadius=U,this._maximumRadius=G,this._minimumHeight=y,this._maximumHeight=Y,this._minimumAngle=E,this._maximumAngle=I,this.shapeTransform=L.clone(t,this.shapeTransform),this.orientedBoundingBox=mst(g,C,M,V,_,P,this.shapeTransform,this.orientedBoundingBox),this.boundTransform=L.fromRotationTranslation(this.orientedBoundingBox.halfAxes,this.orientedBoundingBox.center,this.boundTransform),this.boundingSphere=Ft.fromOrientedBoundingBox(this.orientedBoundingBox,this.boundingSphere);let nt=U===a&&G===s,$=y===l&&Y===r,dt=I<E,q=I-E+dt*h,at=q>Z+F&&q<h-F,st=q<Z-F,Et=q>=Z-F&&q<=Z+F,Qt=at||st||Et,Wt=k.equalsEpsilon(E,d,void 0,u),Nt=k.equalsEpsilon(I,m,void 0,u),kt=g===a,Mt=P<_,qt=P-_+Mt*h,ie=qt>=Z-F&&qt<h-F,oe=qt>F&&qt<Z-F,He=qt<=F,rn=ie||oe||He,{shaderUniforms:de,shaderDefines:zt}=this;for(let ue in zt)zt.hasOwnProperty(ue)&&(zt[ue]=void 0);let ke=0;if(zt.CYLINDER_INTERSECTION_INDEX_RADIUS_MAX=ke,ke+=1,kt||(zt.CYLINDER_HAS_RENDER_BOUNDS_RADIUS_MIN=!0,zt.CYLINDER_INTERSECTION_INDEX_RADIUS_MIN=ke,ke+=1),de.cylinderRenderRadiusMinMax=K.fromElements(g,C,de.cylinderRenderRadiusMinMax),g===C&&(zt.CYLINDER_HAS_RENDER_BOUNDS_RADIUS_FLAT=!0),!nt){zt.CYLINDER_HAS_SHAPE_BOUNDS_RADIUS=!0;let ue=G-U,We=0,un=1;ue!==0&&(We=1/ue,un=-U/ue),de.cylinderUvToShapeUvRadius=K.fromElements(We,un,de.cylinderUvToShapeUvRadius)}if(!$){zt.CYLINDER_HAS_SHAPE_BOUNDS_HEIGHT=!0;let ue=Y-y,We=0,un=1;ue!==0&&(We=2/ue,un=-(y+1)/ue),de.cylinderUvToShapeUvHeight=K.fromElements(We,un,de.cylinderUvToShapeUvHeight)}if(de.cylinderRenderHeightMinMax=K.fromElements(M,V,de.cylinderRenderHeightMinMax),dt&&(zt.CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MIN_MAX_REVERSED=!0),rn&&(zt.CYLINDER_HAS_RENDER_BOUNDS_ANGLE=!0,zt.CYLINDER_INTERSECTION_INDEX_ANGLE=ke,ie?(zt.CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_UNDER_HALF=!0,ke+=1):oe?(zt.CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_OVER_HALF=!0,ke+=2):He&&(zt.CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_EQUAL_ZERO=!0,ke+=2),de.cylinderRenderAngleMinMax=K.fromElements(_,P,de.cylinderRenderAngleMinMax)),Qt){zt.CYLINDER_HAS_SHAPE_BOUNDS_ANGLE=!0,Wt&&(zt.CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MIN_DISCONTINUITY=!0),Nt&&(zt.CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MAX_DISCONTINUITY=!0);let ue=(E-d)/h,We=(I-d)/h,un=1-q/h;if(de.cylinderShapeUvAngleMinMax=K.fromElements(ue,We,de.cylinderShapeUvAngleMinMax),de.cylinderShapeUvAngleRangeZeroMid=(We+.5*un)%1,q<=F)de.cylinderUvToShapeUvAngle=K.fromElements(0,1,de.cylinderUvToShapeUvAngle);else{let Ct=h/q,_t=-(E-d)/q;de.cylinderUvToShapeUvAngle=K.fromElements(Ct,_t,de.cylinderUvToShapeUvAngle)}}return this.shaderMaximumIntersectionsLength=ke,!0};Cl.prototype.computeOrientedBoundingBoxForTile=function(t,e,n,i,o){let a=this._minimumRadius,s=this._maximumRadius,l=this._minimumHeight,r=this._maximumHeight,d=this._minimumAngle,m=this._maximumAngle,h=1/Math.pow(2,t),Z=k.lerp(a,s,e*h),b=k.lerp(a,s,(e+1)*h),u=k.lerp(l,r,n*h),F=k.lerp(l,r,(n+1)*h),U=k.lerp(d,m,i*h),G=k.lerp(d,m,(i+1)*h);return mst(Z,b,u,F,U,G,this.shapeTransform,o)};var bQt=new p,RQt=new p,axe=new p;Cl.prototype.computeOrientedBoundingBoxForSample=function(t,e,n,i){let o=1/Math.pow(2,t.level),a=p.divideComponents(p.ONE,e,bQt),s=p.multiplyByScalar(a,o,bQt),l=p.multiplyByScalar(p.fromElements(t.x+n.x,t.y+n.y,t.z+n.z,RQt),o,RQt),r=p.add(l,s,axe),d=this._minimumRadius,m=this._maximumRadius,h=this._minimumHeight,Z=this._maximumHeight,b=this._minimumAngle,u=this._maximumAngle,F=k.lerp(d,m,l.x),U=k.lerp(d,m,r.x),G=k.lerp(h,Z,l.y),A=k.lerp(h,Z,r.y),T=k.lerp(b,u,l.z),g=k.lerp(b,u,r.z);return mst(F,U,G,A,T,g,this.shapeTransform,i)};Cl.DefaultMinBounds=Object.freeze(new p(0,-1,-k.PI));Cl.DefaultMaxBounds=Object.freeze(new p(1,1,+k.PI));var sxe=5,lxe=new Array(sxe),rxe=new p,dxe=new ot,cxe=new L,mxe=new L,hxe=new L,cst=new L,pxe=new p,uxe=new p,Zxe=new p,FQt=new Array(8);for(let t=0;t<8;t++)FQt[t]=new p;function WQt(t,e,n){return Math.abs(Rt.dot(t,e))<n}function Vxe(t){let e=L.getColumn(t,0,pxe),n=L.getColumn(t,1,uxe),i=L.getColumn(t,2,Zxe),o=k.EPSILON4;return WQt(e,n,o)&&WQt(n,i,o)}function bxe(t,e){let n=FQt;p.fromElements(-.5,-.5,-.5,n[0]),p.fromElements(-.5,-.5,.5,n[1]),p.fromElements(-.5,.5,-.5,n[2]),p.fromElements(-.5,.5,.5,n[3]),p.fromElements(.5,-.5,-.5,n[4]),p.fromElements(.5,-.5,.5,n[5]),p.fromElements(.5,.5,-.5,n[6]),p.fromElements(.5,.5,.5,n[7]);for(let i=0;i<8;++i)L.multiplyByPoint(t,n[i],n[i]);return ci.fromPoints(n,e)}function mst(t,e,n,i,o,a,s,l){let r=Cl.DefaultMinBounds,d=Cl.DefaultMaxBounds,m=r.x,h=d.x,Z=r.y,b=d.y,u=r.z,F=d.z;if(t===m&&e===h&&n===Z&&i===b&&o===u&&a===F)return l.center=L.getTranslation(s,l.center),l.halfAxes=L.getMatrix3(s,l.halfAxes),l;a<o&&(a+=k.TWO_PI);let G=a-o,A=o+G*.5,T=lxe,g=0;T[g++]=o,T[g++]=a,T[g++]=A,G>k.PI&&(T[g++]=A-k.PI_OVER_TWO,T[g++]=A+k.PI_OVER_TWO);let C=1,y=1,Y=-1,Q=-1;for(let dt=0;dt<g;++dt){let q=T[dt]-A,at=Math.cos(q),st=Math.sin(q),Et=at*t,Qt=st*t,Wt=at*e,Nt=st*e;C=Math.min(C,Et),y=Math.min(y,Qt),C=Math.min(C,Wt),y=Math.min(y,Nt),Y=Math.max(Y,Et),Q=Math.max(Q,Qt),Y=Math.max(Y,Wt),Q=Math.max(Q,Nt)}let J=Y-C,M=Q-y,V=i-n,E=(C+Y)*.5,I=(y+Q)*.5,B=(n+i)*.5,X=p.fromElements(E,I,B,rxe),_=ot.fromRotationZ(A,dxe),P=p.fromElements(J,M,V,fQt),w=L.fromScale(P,hxe),z=L.fromRotation(_,mxe),H=L.fromTranslation(X,cxe),nt=L.multiplyTransformation(z,L.multiplyTransformation(H,w,cst),cst),$=L.multiplyTransformation(s,nt,cst);return Vxe($)?ci.fromTransformation($,l):bxe($,l)}var vb=Cl;var Jxo=R(W(),1);function AW(){this.orientedBoundingBox=new ci,this.boundingSphere=new Ft,this.boundTransform=new L,this.shapeTransform=new L,this._rectangle=new Gt,this._minimumHeight=AW.DefaultMinBounds.z,this._maximumHeight=AW.DefaultMaxBounds.z,this._ellipsoid=new mt,this._translation=new p,this._rotation=new ot,this.shaderUniforms={ellipsoidRadiiUv:new p,eccentricitySquared:0,evoluteScale:new K,ellipsoidInverseRadiiSquaredUv:new p,ellipsoidRenderLongitudeMinMax:new K,ellipsoidShapeUvLongitudeMinMaxMid:new p,ellipsoidUvToShapeUvLongitude:new K,ellipsoidUvToShapeUvLatitude:new K,ellipsoidRenderLatitudeSinMinMax:new K,ellipsoidInverseHeightDifferenceUv:0,clipMinMaxHeight:new K},this.shaderDefines={ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_EQUAL_ZERO:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_UNDER_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_OVER_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_MIN_DISCONTINUITY:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_MAX_DISCONTINUITY:void 0,ELLIPSOID_HAS_SHAPE_BOUNDS_LONGITUDE:void 0,ELLIPSOID_HAS_SHAPE_BOUNDS_LONGITUDE_MIN_MAX_REVERSED:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_UNDER_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_EQUAL_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_OVER_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_UNDER_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_EQUAL_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_OVER_HALF:void 0,ELLIPSOID_HAS_SHAPE_BOUNDS_LATITUDE:void 0,ELLIPSOID_INTERSECTION_INDEX_LONGITUDE:void 0,ELLIPSOID_INTERSECTION_INDEX_LATITUDE_MAX:void 0,ELLIPSOID_INTERSECTION_INDEX_LATITUDE_MIN:void 0,ELLIPSOID_INTERSECTION_INDEX_HEIGHT_MAX:void 0,ELLIPSOID_INTERSECTION_INDEX_HEIGHT_MIN:void 0},this.shaderMaximumIntersectionsLength=0}var Rxe=new p,Wxe=new p,fxe=new p,Fxe=new p,Uxe=new p,Gxe=new p,Axe=new p,Txe=new p,Sxe=new ot,UQt=new p,GQt=new p,gxe=new Gt;AW.prototype.update=function(t,e,n,i,o){let{DefaultMinBounds:a,DefaultMaxBounds:s}=AW;i=f(i,a),o=f(o,s);let l=k.EPSILON10,r=k.EPSILON3,d=k.EPSILON10,m=k.EPSILON10,h=k.EPSILON3,Z=L.getScale(t,Txe),b=p.clone(a,Rxe);b.z=-p.minimumComponent(Z);let u=p.clamp(e,b,s,Wxe),F=p.clamp(n,b,s,fxe),U=p.clamp(i,b,s,Fxe),G=p.clamp(o,b,s,Uxe),A=p.maximumByComponent(u,U,Gxe),T=p.minimumByComponent(F,G,Axe),g=p.add(Z,p.fromElements(F.z,F.z,F.z,UQt),UQt),C=p.maximumComponent(g),y=p.add(Z,p.fromElements(T.z,T.z,T.z,GQt),GQt);if(A.y>T.y||A.y===s.y||T.y===a.y||A.z>T.z||k.equalsEpsilon(y,p.ZERO,void 0,l))return!1;this._rectangle=Gt.fromRadians(u.x,u.y,F.x,F.y),this._translation=L.getTranslation(t,this._translation),this._rotation=L.getRotation(t,this._rotation),this._ellipsoid=mt.fromCartesian3(Z,this._ellipsoid),this._minimumHeight=u.z,this._maximumHeight=F.z;let Y=Gt.fromRadians(A.x,A.y,T.x,T.y,gxe);this.orientedBoundingBox=hst(Y,A.z,T.z,this._ellipsoid,this._translation,this._rotation,this.orientedBoundingBox),this.shapeTransform=L.fromRotationTranslation(ot.setScale(this._rotation,g,Sxe),this._translation,this.shapeTransform),this.boundTransform=L.fromRotationTranslation(this.orientedBoundingBox.halfAxes,this.orientedBoundingBox.center,this.boundTransform),this.boundingSphere=Ft.fromOrientedBoundingBox(this.orientedBoundingBox,this.boundingSphere);let Q=s.x-a.x,J=.5*Q,M=T.x<A.x,V=T.x-A.x+M*Q,E=V<=d,I=V>=J-d&&V<Q-d,B=V>d&&V<J-d,X=E||I||B,_=F.x<u.x,P=F.x-u.x+_*Q,w=P>J+d&&P<Q-d,z=P>=J-d&&P<=J+d,H=P<J-d,nt=w||z||H,$=T.y<-h,dt=T.y>=-h&&T.y<=+h,q=T.y>+h&&T.y<s.y-m,at=$||dt||q,st=A.y>a.y+m&&A.y<-h,Et=A.y>=-h&&A.y<=+h,Qt=A.y>+h,Wt=st||Et||Qt,Nt=at||Wt,kt=F.y-u.y,Mt=F.y<-h,qt=F.y>=-h&&F.y<=+h,ie=F.y>+h&&F.y<s.y-m,oe=Mt||qt||ie,He=u.y>a.y+m&&u.y<-h,rn=u.y>=-h&&u.y<=+h,de=u.y>+h,ke=oe||(He||rn||de),{shaderUniforms:ue,shaderDefines:We}=this;for(let oo in We)We.hasOwnProperty(oo)&&(We[oo]=void 0);ue.ellipsoidRadiiUv=p.divideByScalar(g,C,ue.ellipsoidRadiiUv);let{x:un,z:Ct}=ue.ellipsoidRadiiUv,_t=Ct/un;ue.eccentricitySquared=1-_t*_t,ue.evoluteScale=K.fromElements((un*un-Ct*Ct)/un,(Ct*Ct-un*un)/Ct,ue.evoluteScale),ue.ellipsoidInverseRadiiSquaredUv=p.divideComponents(p.ONE,p.multiplyComponents(ue.ellipsoidRadiiUv,ue.ellipsoidRadiiUv,ue.ellipsoidInverseRadiiSquaredUv),ue.ellipsoidInverseRadiiSquaredUv);let Je=0;We.ELLIPSOID_INTERSECTION_INDEX_HEIGHT_MAX=Je,Je+=1,We.ELLIPSOID_INTERSECTION_INDEX_HEIGHT_MIN=Je,Je+=1,ue.clipMinMaxHeight=K.fromElements((A.z-F.z)/C,(T.z-F.z)/C,ue.clipMinMaxHeight);let xe=(F.z-u.z)/C;if(ue.ellipsoidInverseHeightDifferenceUv=1/xe,u.z===F.z&&(ue.ellipsoidInverseHeightDifferenceUv=0),X&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE=!0,We.ELLIPSOID_INTERSECTION_INDEX_LONGITUDE=Je,I?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_UNDER_HALF=!0,Je+=1):B?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_OVER_HALF=!0,Je+=2):E&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_EQUAL_ZERO=!0,Je+=2),ue.ellipsoidRenderLongitudeMinMax=K.fromElements(A.x,T.x,ue.ellipsoidRenderLongitudeMinMax)),nt)if(We.ELLIPSOID_HAS_SHAPE_BOUNDS_LONGITUDE=!0,F.x<u.x&&(We.ELLIPSOID_HAS_SHAPE_BOUNDS_LONGITUDE_MIN_MAX_REVERSED=!0),P<=d)ue.ellipsoidUvToShapeUvLongitude=K.fromElements(0,1,ue.ellipsoidUvToShapeUvLongitude);else{let ea=Q/P,gs=-(u.x-a.x)/P;ue.ellipsoidUvToShapeUvLongitude=K.fromElements(ea,gs,ue.ellipsoidUvToShapeUvLongitude)}if(X){let oo=k.equalsEpsilon(A.x,a.x,void 0,r),ea=k.equalsEpsilon(T.x,s.x,void 0,r);oo&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_MIN_DISCONTINUITY=!0),ea&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_MAX_DISCONTINUITY=!0);let gs=(u.x-a.x)/Q,is=(F.x-a.x)/Q,ja=(T.x-a.x)/Q,qn=1-V/Q,ae=(ja+.5*qn)%1;ue.ellipsoidShapeUvLongitudeMinMaxMid=p.fromElements(gs,is,ae,ue.ellipsoidShapeUvLongitudeMinMaxMid)}if(Nt&&(Wt&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN=!0,We.ELLIPSOID_INTERSECTION_INDEX_LATITUDE_MIN=Je,st?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_UNDER_HALF=!0,Je+=1):Et?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_EQUAL_HALF=!0,Je+=1):Qt&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_OVER_HALF=!0,Je+=2)),at&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX=!0,We.ELLIPSOID_INTERSECTION_INDEX_LATITUDE_MAX=Je,$?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_UNDER_HALF=!0,Je+=2):dt?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_EQUAL_HALF=!0,Je+=1):q&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_OVER_HALF=!0,Je+=1)),ue.ellipsoidRenderLatitudeSinMinMax=K.fromElements(Math.sin(A.y),Math.sin(T.y),ue.ellipsoidRenderLatitudeSinMinMax)),ke)if(We.ELLIPSOID_HAS_SHAPE_BOUNDS_LATITUDE=!0,kt<m)ue.ellipsoidUvToShapeUvLatitude=K.fromElements(0,1,ue.ellipsoidUvToShapeUvLatitude);else{let ea=(s.y-a.y)/kt,gs=(a.y-u.y)/kt;ue.ellipsoidUvToShapeUvLatitude=K.fromElements(ea,gs,ue.ellipsoidUvToShapeUvLatitude)}return this.shaderMaximumIntersectionsLength=Je,!0};var SQt=new Gt;AW.prototype.computeOrientedBoundingBoxForTile=function(t,e,n,i,o){let a=1/Math.pow(2,t),s=e*a,l=(e+1)*a,r=n*a,d=(n+1)*a,m=i*a,h=(i+1)*a,Z=Gt.subsection(this._rectangle,s,r,l,d,SQt),b=k.lerp(this._minimumHeight,this._maximumHeight,m),u=k.lerp(this._minimumHeight,this._maximumHeight,h);return hst(Z,b,u,this._ellipsoid,this._translation,this._rotation,o)};var AQt=new p,TQt=new p,Exe=new p;AW.prototype.computeOrientedBoundingBoxForSample=function(t,e,n,i){let o=1/Math.pow(2,t.level),a=p.divideComponents(p.ONE,e,AQt),s=p.multiplyByScalar(a,o,AQt),l=p.multiplyByScalar(p.fromElements(t.x+n.x,t.y+n.y,t.z+n.z,TQt),o,TQt),r=p.add(l,s,Exe),d=Gt.subsection(this._rectangle,l.x,l.y,r.x,r.y,SQt),m=k.lerp(this._minimumHeight,this._maximumHeight,l.z),h=k.lerp(this._minimumHeight,this._maximumHeight,r.z);return hst(d,m,h,this._ellipsoid,this._translation,this._rotation,i)};function hst(t,e,n,i,o,a,s){return s=ci.fromRectangle(t,e,n,i,s),s.center=p.add(s.center,o,s.center),s.halfAxes=ot.multiply(s.halfAxes,a,s.halfAxes),s}AW.DefaultMinBounds=Object.freeze(new p(-k.PI,-k.PI_OVER_TWO,-mt.WGS84.minimumRadius));AW.DefaultMaxBounds=Object.freeze(new p(k.PI,k.PI_OVER_TWO,10*mt.WGS84.maximumRadius));var YS=AW;var dp={BOX:"BOX",ELLIPSOID:"ELLIPSOID",CYLINDER:"CYLINDER"};dp.getMinBounds=function(t){switch(t){case dp.BOX:return Pb.DefaultMinBounds;case dp.ELLIPSOID:return YS.DefaultMinBounds;case dp.CYLINDER:return vb.DefaultMinBounds}};dp.getMaxBounds=function(t){switch(t){case dp.BOX:return Pb.DefaultMaxBounds;case dp.ELLIPSOID:return YS.DefaultMaxBounds;case dp.CYLINDER:return vb.DefaultMaxBounds}};dp.getShapeConstructor=function(t){switch(t){case dp.BOX:return Pb;case dp.ELLIPSOID:return YS;case dp.CYLINDER:return vb}};var _o=Object.freeze(dp);var HXo=R(W(),1);var vxo=R(W(),1);function hV(t){this._comparator=t.comparator,this._maximumLength=t.maximumLength,this._array=c(t.maximumLength)?new Array(t.maximumLength):[],this._length=0}Object.defineProperties(hV.prototype,{length:{get:function(){return this._length}},maximumLength:{get:function(){return this._maximumLength},set:function(t){if(c(t)){for(;this._length>t;)this.removeMinimum();this._array.length=t}this._maximumLength=t}},internalArray:{get:function(){return this._array}},comparator:{get:function(){return this._comparator}}});hV.prototype.clone=function(){let t=this._maximumLength,e=this._comparator,n=this._array,i=this._length,o=new hV({comparator:e,maximumLength:t});o._length=i;for(let a=0;a<i;a++)o._array[a]=n[a];return o};hV.prototype.reset=function(){this._length=0;let t=this._maximumLength;if(c(t))for(let e=0;e<t;e++)this._array[e]=void 0;else this._array.length=0};hV.prototype.resort=function(){let t=this._length;for(let e=0;e<t;e++)gQt(this,e)};hV.prototype.insert=function(t){let e,n=this._maximumLength;if(c(n)){if(n===0)return;if(this._length===n){let o=this._array[0];if(this._comparator(t,o)<=0)return t;e=this.removeMinimum()}}let i=this._length;return this._array[i]=t,this._length++,gQt(this,i),e};hV.prototype.removeMinimum=function(){let t=this._length;if(t===0)return;this._length--;let e=this._array[0];return t>=2&&(this._array[0]=this._array[t-1],EQt(this,0)),this._array[t-1]=void 0,e};hV.prototype.removeMaximum=function(){let t=this._length;if(t===0)return;this._length--;let e;if(t<=2)e=this._array[t-1];else{let n=pst(this,1,2)?1:2;e=this._array[n],this._array[n]=this._array[t-1],t>=4&&EQt(this,n)}return this._array[t-1]=void 0,e};hV.prototype.getMinimum=function(){if(this._length!==0)return this._array[0]};hV.prototype.getMaximum=function(){let t=this._length;if(t!==0)return t<=2?this._array[t-1]:this._array[pst(this,1,2)?1:2]};function Sj(t,e,n){let i=t._array,o=i[e];i[e]=i[n],i[n]=o}function $9(t,e,n){return t._comparator(t._array[e],t._array[n])<0}function pst(t,e,n){return t._comparator(t._array[e],t._array[n])>0}function gQt(t,e){if(e===0)return;let n=Math.floor(k.log2(e+1))%2===0,i=Math.floor((e-1)/2),o=$9(t,e,i);for(o!==n&&(Sj(t,e,i),e=i);e>=3;){let a=Math.floor((e-3)/4);if($9(t,e,a)!==o)break;Sj(t,e,a),e=a}}function EQt(t,e){let n=t._length,i=Math.floor(k.log2(e+1))%2===0,o;for(;(o=2*e+1)<n;){let a=o,s=o+1;if(s<n){$9(t,s,a)===i&&(a=s);let l=2*o+1,r=Math.max(Math.min(n-l,4),0);for(let d=0;d<r;d++){let m=l+d;$9(t,m,a)===i&&(a=m)}}if($9(t,a,e)===i&&(Sj(t,a,e),a!==o&&a!==s)){let l=Math.floor((a-1)/2);pst(t,a,l)===i&&Sj(t,a,l)}e=a}}var xS=hV;var zxo=R(W(),1),CQt=Object.freeze({UNLOADED:0,RECEIVING:1,RECEIVED:2,LOADED:3,FAILED:4,UNAVAILABLE:5});function gj(t,e){this.spatialNode=t,this.keyframe=e,this.state=CQt.UNLOADED,this.metadata=[],this.megatextureIndex=-1,this.priority=-Number.MAX_VALUE,this.highPriorityFrameNumber=-1}gj.priorityComparator=function(t,e){return t.priority-e.priority};gj.searchComparator=function(t,e){return t.keyframe-e.keyframe};gj.LoadState=CQt;var ra=gj;var VXo=R(W(),1);function AU(t,e,n,i,o){i===vn.UNSIGNED_SHORT&&(i=vn.FLOAT32);let a=t.floatingPointTexture;if(i===vn.FLOAT32&&!a)throw new St("Floating point texture not supported");let s;i===vn.FLOAT32||i===vn.FLOAT64?s=Ue.FLOAT:i===vn.UINT8&&(s=Ue.UNSIGNED_BYTE);let l;n===1?l=t.webgl2?Ye.RED:Ye.LUMINANCE:n===2?l=t.webgl2?Ye.RG:Ye.LUMINANCE_ALPHA:n===3?l=Ye.RGB:n===4&&(l=Ye.RGBA);let r=512*1024*1024,d=128*1024*1024;o=Math.min(f(o,d),r);let m=Sn.maximumTextureSize,h=vn.getSizeInBytes(i),Z=Math.floor(o/(n*h)),b=Math.min(m,k.previousPowerOfTwo(Math.floor(Math.sqrt(Z)))),u=Math.ceil(Math.sqrt(e.x)),F=Math.ceil(e.z/u),U=u*e.x,G=F*e.y,A=Math.floor(b/U),T=Math.floor(b/G);if(A===0||T===0)throw new St("Tileset is too large to fit into megatexture");this.channelCount=n,this.componentType=i,this.voxelCountPerTile=p.clone(e,new p),this.maximumTileCount=A*T,this.regionCountPerMegatexture=new K(A,T),this.voxelCountPerRegion=new K(U,G),this.sliceCountPerRegion=new K(u,F),this.voxelSizeUv=new K(1/b,1/b),this.sliceSizeUv=new K(e.x/b,e.y/b),this.regionSizeUv=new K(U/b,G/b),this.texture=new hn({context:t,pixelFormat:l,pixelDatatype:s,flipY:!1,width:b,height:b,sampler:new Hn({wrapS:Vi.CLAMP_TO_EDGE,wrapT:Vi.CLAMP_TO_EDGE,minificationFilter:On.LINEAR,magnificationFilter:bo.LINEAR})});let g=vn.toComponentDatatype(i);this.tileVoxelDataTemp=it.createTypedArray(g,U*G*n),this.nodes=new Array(this.maximumTileCount);for(let C=0;C<this.maximumTileCount;C++)this.nodes[C]=new Cxe(C);for(let C=0;C<this.maximumTileCount;C++){let y=this.nodes[C];y.previousNode=C>0?this.nodes[C-1]:void 0,y.nextNode=C<this.maximumTileCount-1?this.nodes[C+1]:void 0}this.occupiedList=void 0,this.emptyList=this.nodes[0],this.occupiedCount=0}function Cxe(t){this.index=t,this.nextNode=void 0,this.previousNode=void 0}AU.prototype.add=function(t){if(this.isFull())throw new Ut("Trying to add when there are no empty spots");let e=this.emptyList;this.emptyList=this.emptyList.nextNode,c(this.emptyList)&&(this.emptyList.previousNode=void 0),e.nextNode=this.occupiedList,c(e.nextNode)&&(e.nextNode.previousNode=e),this.occupiedList=e;let n=e.index;return this.writeDataToTexture(n,t),this.occupiedCount++,n};AU.prototype.remove=function(t){if(t<0||t>=this.maximumTileCount)throw new Ut("Megatexture index out of bounds");let e=this.nodes[t];c(e.previousNode)&&(e.previousNode.nextNode=e.nextNode),c(e.nextNode)&&(e.nextNode.previousNode=e.previousNode),e.nextNode=this.emptyList,c(e.nextNode)&&(e.nextNode.previousNode=e),e.previousNode=void 0,this.emptyList=e,this.occupiedCount--};AU.prototype.isFull=function(){return this.emptyList===void 0};AU.getApproximateTextureMemoryByteLength=function(t,e,n,i){i===vn.UNSIGNED_SHORT&&(i=vn.FLOAT32);let o=vn.getSizeInBytes(i),a=t*e.x*e.y*e.z,s=Math.ceil(Math.sqrt(e.x)),l=Math.ceil(e.z/s),r=s*e.x,d=l*e.y,m=k.previousPowerOfTwo(Math.floor(Math.sqrt(a)));for(;;){let Z=Math.floor(m/r),b=Math.floor(m/d);if(Z*b>=t)break;m*=2}return m*m*n*o};AU.prototype.writeDataToTexture=function(t,e){let n=e.constructor===Uint16Array?new Float32Array(e):e,i=this.voxelCountPerTile,o=this.sliceCountPerRegion,a=this.voxelCountPerRegion,s=this.channelCount,l=this.tileVoxelDataTemp;for(let F=0;F<i.z;F++){let U=F%o.x*i.x,G=Math.floor(F/o.x)*i.y;for(let A=0;A<i.y;A++)for(let T=0;T<i.x;T++){let g=F*i.y*i.x+A*i.x+T,C=(G+A)*a.x+(U+T);for(let y=0;y<s;y++)l[C*s+y]=n[g*s+y]}}let r=this.regionCountPerMegatexture,d=a.x,m=a.y,h=t%r.x*a.x,Z=Math.floor(t/r.x)*a.y,u={source:{arrayBufferView:l,width:d,height:m},xOffset:h,yOffset:Z};this.texture.copyFrom(u)};AU.prototype.isDestroyed=function(){return!1};AU.prototype.destroy=function(){return this.texture=this.texture&&this.texture.destroy(),At(this)};var P1=AU;var SXo=R(W(),1);function Bu(t,e,n,i,o,a,s){this.children=void 0,this.parent=o,this.level=t,this.x=e,this.y=n,this.z=i,this.dimensions=p.clone(s),this.keyframeNodes=[],this.renderableKeyframeNodes=[],this.renderableKeyframeNodeLerp=0,this.renderableKeyframeNodePrevious=void 0,this.renderableKeyframeNodeNext=void 0,this.orientedBoundingBox=new ci,this.approximateVoxelSize=0,this.screenSpaceError=0,this.visitedFrameNumber=-1,this.computeBoundingVolumes(a)}var Ixe=new p;Bu.prototype.computeBoundingVolumes=function(t){this.orientedBoundingBox=t.computeOrientedBoundingBoxForTile(this.level,this.x,this.y,this.z,this.orientedBoundingBox);let e=ot.getScale(this.orientedBoundingBox.halfAxes,Ixe),n=2*p.maximumComponent(e);this.approximateVoxelSize=n/p.minimumComponent(this.dimensions)};Bu.prototype.constructChildNodes=function(t){let{level:e,x:n,y:i,z:o}=this,a=n*2,s=i*2,l=o*2,r=s+1,d=a+1,m=l+1,h=e+1,Z=[[h,a,s,l],[h,d,s,l],[h,a,r,l],[h,d,r,l],[h,a,s,m],[h,d,s,m],[h,a,r,m],[h,d,r,m]];this.children=Z.map(([b,u,F,U])=>new Bu(b,u,F,U,this,t,this.dimensions))};Bu.prototype.visibility=function(t,e){let n=this.orientedBoundingBox;return t.cullingVolume.computeVisibilityWithPlaneMask(n,e)};Bu.prototype.computeScreenSpaceError=function(t,e){let n=this.orientedBoundingBox,i=Math.sqrt(n.distanceSquaredTo(t));i=Math.max(i,k.EPSILON7);let o=this.approximateVoxelSize,a=e*(o/i);this.screenSpaceError=a};var IQt={keyframe:0};function t5(t,e){return IQt.keyframe=t,Ja(e,IQt,ra.searchComparator)}Bu.prototype.computeSurroundingRenderableKeyframeNodes=function(t){let e=this,n=e.level,i=Math.floor(t),o=Math.ceil(t),a,s,l=+Number.MAX_VALUE,r=+Number.MAX_VALUE;for(;c(e);){let{renderableKeyframeNodes:h}=e;if(h.length>=1){let Z=Nxe(i,h),b=h[Z],u=o===i||i<b.keyframe?Z:Math.min(Z+1,h.length-1),F=h[u],U=i-b.keyframe,G=NQt(n-e.level,U);G<l&&(l=G,a=b);let A=F.keyframe-o,T=NQt(n-e.level,A);if(T<r&&(r=T,s=F),U===0&&A===0)break}e=e.parent}if(this.renderableKeyframeNodePrevious=a,this.renderableKeyframeNodeNext=s,!c(a)||!c(s))return;let d=a.keyframe,m=s.keyframe;this.renderableKeyframeNodeLerp=d===m?0:k.clamp((t-d)/(m-d),0,1)};function Nxe(t,e){let n=t5(t,e);return n<0?k.clamp(~n-1,0,e.length-1):n}function NQt(t,e){let n=Math.exp(t*4),i=e>=0?1:-200;return t*n+e*i}Bu.prototype.isVisited=function(t){return this.visitedFrameNumber===t};Bu.prototype.createKeyframeNode=function(t){let e=t5(t,this.keyframeNodes);if(e<0){e=~e;let n=new ra(this,t);this.keyframeNodes.splice(e,0,n)}};Bu.prototype.destroyKeyframeNode=function(t,e){let n=t.keyframe,i=t5(n,this.keyframeNodes);if(i<0)throw new Ut("Keyframe node does not exist.");if(this.keyframeNodes.splice(i,1),t.megatextureIndex!==-1){for(let a=0;a<e.length;a++)e[a].remove(t.megatextureIndex);let o=t5(n,this.renderableKeyframeNodes);if(o<0)throw new Ut("Renderable keyframe node does not exist.");this.renderableKeyframeNodes.splice(o,1)}t.spatialNode=void 0,t.state=ra.LoadState.UNLOADED,t.metadata={},t.megatextureIndex=-1,t.priority=-Number.MAX_VALUE,t.highPriorityFrameNumber=-1};Bu.prototype.addKeyframeNodeToMegatextures=function(t,e){if(t.state!==ra.LoadState.RECEIVED||t.megatextureIndex!==-1||t.metadata.length!==e.length)throw new Ut("Keyframe node cannot be added to megatexture");for(let o=0;o<e.length;o++){let a=e[o];t.megatextureIndex=a.add(t.metadata[o])}t.state=ra.LoadState.LOADED;let n=this.renderableKeyframeNodes,i=t5(t.keyframe,n);if(i>=0)throw new Ut("Keyframe already renderable");i=~i,n.splice(i,0,t)};Bu.prototype.isRenderable=function(t){let e=this.renderableKeyframeNodePrevious,n=this.renderableKeyframeNodeNext,i=this.level;return c(e)&&c(n)&&(e.spatialNode.level===i||n.spatialNode.level===i)&&this.visitedFrameNumber===t};var e5=Bu;function TW(t,e,n,i,o,a,s){this._primitive=t,this.megatextures=new Array(i.length);for(let u=0;u<i.length;u++){let F=i[u],U=Nn.getComponentCount(F),G=o[u];this.megatextures[u]=new P1(e,n,U,G,s)}let l=this.megatextures[0].maximumTileCount;this._simultaneousRequestCount=0,this._debugPrint=!1,this._frameNumber=0;let r=t._shape;this.rootNode=new e5(0,0,0,0,void 0,r,n),this._priorityQueue=new xS({maximumLength:l,comparator:ra.priorityComparator}),this._highPriorityKeyframeNodes=new Array(l),this._keyframeNodesInMegatexture=new Array(l),this._keyframeCount=a,this._sampleCount=void 0,this._keyframeLocation=0,this._binaryTreeKeyframeWeighting=new Array(a);let d=this._binaryTreeKeyframeWeighting;d[0]=0,d[a-1]=0,ust(d,1,a-2,0);let m=9,h=2048,Z=Math.floor(h/m),b=Math.ceil(l/Z);this.internalNodeTexture=new hn({context:e,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,flipY:!1,width:h,height:b,sampler:new Hn({minificationFilter:On.NEAREST,magnificationFilter:bo.NEAREST})}),this.internalNodeTilesPerRow=Z,this.internalNodeTexelSizeUv=new K(1/h,1/b),this.leafNodeTexture=void 0,this.leafNodeTilesPerRow=void 0,this.leafNodeTexelSizeUv=new K}TW.prototype.findKeyframeNode=function(t){return this._keyframeNodesInMegatexture.find(function(e){return e.megatextureIndex===t})};function ust(t,e,n,i){if(e>n)return;let o=Math.floor((e+n)/2);t[o]=i,ust(t,e,o-1,i+1),ust(t,o+1,n,i+1)}TW.simultaneousRequestCountMaximum=50;TW.prototype.update=function(t,e,n,i){let o=this._primitive,a=t.context,s=this.megatextures[0].maximumTileCount,l=this._keyframeCount,r=o._levelBlendFactor,d=r>0,m=l>1,h=(d?2:1)*(m?2:1);this._sampleCount=h;let Z=h>=2;if(Z&&!c(this.leafNodeTexture)){let A=Math.floor(512),T=Math.ceil(s/A);this.leafNodeTexture=new hn({context:a,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,flipY:!1,width:1024,height:T,sampler:new Hn({minificationFilter:On.NEAREST,magnificationFilter:bo.NEAREST})}),this.leafNodeTexelSizeUv=K.fromElements(1/1024,1/T,this.leafNodeTexelSizeUv),this.leafNodeTilesPerRow=A}else!Z&&c(this.leafNodeTexture)&&(this.leafNodeTexture=this.leafNodeTexture.destroy());if(this._keyframeLocation=k.clamp(e,0,l-1),n&&yQt(this,this.rootNode),i)return;this._frameNumber=t.frameNumber;let b=Oi();Qxe(this,t);let u=Oi();xxe(this,h,r);let F=Oi();if(this._debugPrint){let U=u-b,G=F-u,A=F-b;Yxe(this,U,G,A)}};TW.prototype.isRenderable=function(t){return t.isRenderable(this._frameNumber)};TW.prototype.isDestroyed=function(){return!1};TW.prototype.destroy=function(){let t=this.megatextures,e=t.length;for(let n=0;n<e;n++)t[n]=t[n]&&t[n].destroy();return this.internalNodeTexture=this.internalNodeTexture&&this.internalNodeTexture.destroy(),this.leafNodeTexture=this.leafNodeTexture&&this.leafNodeTexture.destroy(),At(this)};function yQt(t,e){if(e.computeBoundingVolumes(t._primitive._shape),c(e.children))for(let n=0;n<8;n++){let i=e.children[n];yQt(t,i)}}function yxe(t,e){if(t._simultaneousRequestCount>=TW.simultaneousRequestCountMaximum)return;let n=t._primitive._provider;function i(r){t._simultaneousRequestCount--;let d=n.types.length;if(!c(r))e.state=ra.LoadState.UNAVAILABLE;else if(r===ra.LoadState.FAILED)e.state=ra.LoadState.FAILED;else if(!Array.isArray(r)||r.length!==d)e.state=ra.LoadState.FAILED;else{let m=t.megatextures;for(let h=0;h<d;h++){let{voxelCountPerTile:Z,channelCount:b}=m[h],{x:u,y:F,z:U}=Z,G=u*F*U,A=r[h],T=G*b;if(A.length===T)e.metadata[h]=A,e.state=ra.LoadState.RECEIVED;else{e.state=ra.LoadState.FAILED;break}}}}function o(){t._simultaneousRequestCount--,e.state=ra.LoadState.FAILED}let{keyframe:a,spatialNode:s}=e,l=n.requestData({tileLevel:s.level,tileX:s.x,tileY:s.y,tileZ:s.z,keyframe:a});c(l)?(t._simultaneousRequestCount++,e.state=ra.LoadState.RECEIVING,l.then(i).catch(o)):e.state=ra.LoadState.FAILED}function Bxe(t){return t/(1+t)}function Qxe(t,e){let n=t._frameNumber,i=t._primitive,o=i._shape,a=i.screenSpaceError,s=t._priorityQueue,l=t._keyframeCount,r=k.clamp(Math.floor(t._keyframeLocation),0,l-2),d=r+1,{camera:m,context:h,pixelRatio:Z}=e,{positionWC:b,frustum:u}=m,U=h.drawingBufferHeight/Z/u.sseDenominator;function G(M,V){if(M.computeScreenSpaceError(b,U),V=M.visibility(e,V),V===Jl.MASK_OUTSIDE)return;if(M.visitedFrameNumber=n,l===1)M.createKeyframeNode(0);else if(M.keyframeNodes.length!==l)for(let _=0;_<l;_++)M.createKeyframeNode(_);let{screenSpaceError:E,keyframeNodes:I}=M,B=Bxe(E),X=!1;for(let _=0;_<I.length;_++){let P=I[_];P.priority=10*B+kxe(r,P.keyframe,d,t),P.state!==ra.LoadState.UNAVAILABLE&&P.state!==ra.LoadState.FAILED&&P.priority!==-Number.MAX_VALUE&&s.insert(P),P.state===ra.LoadState.LOADED&&(X=!0)}if(E<a||!X){M.children=void 0;return}c(M.children)||M.constructChildNodes(o);for(let _=0;_<8;_++){let P=M.children[_];G(P,V)}}s.reset(),G(t.rootNode,Jl.MASK_INDETERMINATE);let A=t._highPriorityKeyframeNodes,T=0,g;for(;s.length>0;)g=s.removeMaximum(),g.highPriorityFrameNumber=n,A[T]=g,T++;let C=t._keyframeNodesInMegatexture,y=t.megatextures[0],Y=y.occupiedCount;C.length=Y,C.sort(function(M,V){return M.highPriorityFrameNumber===V.highPriorityFrameNumber?V.priority-M.priority:V.highPriorityFrameNumber-M.highPriorityFrameNumber});let Q=0,J=0;for(let M=0;M<T;M++)if(g=A[M],!(g.state===ra.LoadState.LOADED||g.spatialNode===void 0)&&(g.state===ra.LoadState.UNLOADED&&yxe(t,g),g.state===ra.LoadState.RECEIVED)){let V=0;if(y.isFull()){V=Y-1-Q,Q++;let E=C[V];E.spatialNode.destroyKeyframeNode(E,t.megatextures)}else V=Y+J,J++;g.spatialNode.addKeyframeNodeToMegatextures(g,t.megatextures),C[V]=g}}function kxe(t,e,n,i){let o=Math.min(Math.abs(e-t),Math.abs(e-n)),a=Math.max(t,i._keyframeCount-n-1,1),s=Math.pow(1-o/a,4),l=Math.exp(-i._binaryTreeKeyframeWeighting[e]);return k.lerp(l,s,.15+.85*s)}function Yxe(t,e,n,i){let o=t._keyframeCount,a=t.rootNode,s=Object.keys(ra.LoadState).length,l=new Array(s),r=new Array(s),d=0;for(let G=0;G<s;G++){let A=new Array(o);l[G]=A;for(let T=0;T<o;T++)A[T]=0;r[G]=0}function m(G){let A=G.keyframeNodes;for(let T=0;T<A.length;T++){let g=A[T],C=g.keyframe,y=g.state;l[y][C]+=1,r[y]+=1,d++}if(c(G.children))for(let T=0;T<8;T++){let g=G.children[T];m(g)}}m(a);let h=`KEYFRAMES: ${l[ra.LoadState.LOADED]}`,Z=`UNLOADED: ${r[ra.LoadState.UNLOADED]} | RECEIVING: ${r[ra.LoadState.RECEIVING]} | RECEIVED: ${r[ra.LoadState.RECEIVED]} | LOADED: ${r[ra.LoadState.LOADED]} | FAILED: ${r[ra.LoadState.FAILED]} | UNAVAILABLE: ${r[ra.LoadState.UNAVAILABLE]} | TOTAL: ${d}`,b=Math.round(e*100)/100,u=Math.round(n*100)/100,F=Math.round(i*100)/100,U=`LOAD: ${b} | OCT: ${u} | ALL: ${F}`;console.log(`${h} || ${Z} || ${U}`)}var Ej={INTERNAL:0,LEAF:1,PACKED_LEAF_FROM_PARENT:2};function xxe(t,e,n){let i=t._primitive._screenSpaceError,o=t._keyframeLocation,a=t._frameNumber,s=e>=2,l=0,r=0,d=[],m=[];function h(b,u,F,U,G){let A=!1;if(c(b.children))for(let T=0;T<8;T++){let g=b.children[T];g.computeSurroundingRenderableKeyframeNodes(o),g.isRenderable(a)&&(A=!0)}if(A){d[G]=Ej.INTERNAL<<16|u,d[F]=U,l++,U=u,G=U*9+1;for(let T=0;T<8;T++){let g=b.children[T];u=l,F=u*9+0,h(g,u,F,U,G+T)}}else{if(s){let T=r*5,g=b.renderableKeyframeNodePrevious,C=b.level-g.spatialNode.level,y=g.spatialNode.parent,Y=c(y)?y.renderableKeyframeNodePrevious:g,Q=Xxe(b,i,n),J=C,M=1,V=g.megatextureIndex,E=Y.megatextureIndex;m[T+0]=Q,m[T+1]=J,m[T+2]=M,m[T+3]=V,m[T+4]=E,d[G]=Ej.LEAF<<16|r}else{let T=b.renderableKeyframeNodePrevious,C=b.level-T.spatialNode.level===0?Ej.LEAF:Ej.PACKED_LEAF_FROM_PARENT;d[G]=C<<16|T.megatextureIndex}r++}}let Z=t.rootNode;Z.computeSurroundingRenderableKeyframeNodes(o),Z.isRenderable(a)&&h(Z,0,0,0,0),Jxe(d,9,t.internalNodeTilesPerRow,t.internalNodeTexture),s&&Lxe(m,2,t.leafNodeTilesPerRow,t.leafNodeTexture)}function Xxe(t,e,n){if(t.parent===void 0)return 0;let i=t.screenSpaceError,o=t.parent.screenSpaceError,s=((e-i)/(o-i)+n-1)/n;return k.clamp(s,0,1)}function Jxe(t,e,n,i){let o=Ye.componentsLength(i.pixelFormat),a=Math.ceil(t.length/e),s=Math.max(1,e*Math.min(a,n)),l=Math.max(1,Math.ceil(a/n)),r=new Uint8Array(s*l*o);for(let h=0;h<t.length;h++){let Z=t[h],b=h*o;for(let u=0;u<o;u++)r[b+u]=Z>>>u*8&255}let m={source:{arrayBufferView:r,width:s,height:l},xOffset:0,yOffset:0};i.copyFrom(m)}function Lxe(t,e,n,i){let o=Ye.componentsLength(i.pixelFormat),a=5,s=Math.ceil(t.length/a),l=Math.max(1,e*Math.min(s,n)),r=Math.max(1,Math.ceil(s/n)),d=new Uint8Array(l*r*o);for(let Z=0;Z<s;Z++){let b=t[Z*a+0],u=t[Z*a+1],F=t[Z*a+2],U=t[Z*a+3],G=t[Z*a+4],A=k.clamp(Math.floor(65536*b),0,65535);d[Z*8+0]=A>>>0&255,d[Z*8+1]=A>>>8&255,d[Z*8+2]=u&255,d[Z*8+3]=F&255,d[Z*8+4]=U>>>0&255,d[Z*8+5]=U>>>8&255,d[Z*8+6]=G>>>0&255,d[Z*8+7]=G>>>8&255}let h={source:{arrayBufferView:d,width:l,height:r},xOffset:0,yOffset:0};i.copyFrom(h)}TW.getApproximateTextureMemoryByteLength=function(t,e,n,i){let o=0,a=n.length;for(let s=0;s<a;s++){let l=n[s],r=i[s],d=Nn.getComponentCount(l);o+=P1.getApproximateTextureMemoryByteLength(t,e,d,r)}return o};var v1=TW;var VJo=R(W(),1);var PXo=R(W(),1),Mxe={FLOAT:"float",VEC2:"vec2",VEC3:"vec3",VEC4:"vec4",INT:"int",INT_VEC2:"ivec2",INT_VEC3:"ivec3",INT_VEC4:"ivec4",BOOL:"bool",BOOL_VEC2:"bvec2",BOOL_VEC3:"bvec3",BOOL_VEC4:"bvec4",MAT2:"mat2",MAT3:"mat3",MAT4:"mat4",SAMPLER_2D:"sampler2D",SAMPLER_CUBE:"samplerCube"},K1=Object.freeze(Mxe);var sJo=R(W(),1);var KXo=R(W(),1);function _xe(t,e,n){let i=new Uint8ClampedArray(t.buffer),o=new ImageData(i,e,n),a=document.createElement("canvas");return a.width=e,a.height=n,a.getContext("2d").putImageData(o,0,0),a}var n5=_xe;function z1(){this._defaultTexture=void 0,this._textures={},this._loadedImages=[],this._lastUpdatedFrame=-1}z1.prototype.getTexture=function(t){return this._textures[t]};function Dxe(t,e,n){n.resource.fetchImage().then(function(i){t._loadedImages.push({id:e,image:i,textureUniform:n})}).catch(function(){let i=t._textures[e];c(i)&&i!==t._defaultTexture&&i.destroy(),t._textures[e]=t._defaultTexture})}z1.prototype.loadTexture2D=function(t,e){c(e.typedArray)?this._loadedImages.push({id:t,textureUniform:e}):Dxe(this,t,e)};function Oxe(t,e,n){let{id:i,textureUniform:o,image:a}=e,s=n.webgl2?Cj(o,a,n):Hxe(o,a,n),l=t._textures[i];c(l)&&l!==n.defaultTexture&&l.destroy(),t._textures[i]=s}function Cj(t,e,n){let{typedArray:i,sampler:o}=t,a=c(i)?QQt(t,n):new hn({context:n,source:e,sampler:o});return BQt(o)&&a.generateMipmap(),a}function Hxe(t,e,n){let{typedArray:i,sampler:o}=t,a=BQt(o),s=o.wrapS===Vi.REPEAT||o.wrapS===Vi.MIRRORED_REPEAT||o.wrapT===Vi.REPEAT||o.wrapT===Vi.MIRRORED_REPEAT,{width:l,height:r}=c(i)?t:e,d=[l,r].every(k.isPowerOfTwo);if((a||s)&&!d)if(c(i)){if(t.pixelDatatype===Ue.UNSIGNED_BYTE){let h=n5(i,l,r),Z=_f(h);return Cj({sampler:o},Z,n)}}else{let h=_f(e);return Cj(t,h,n)}else return Cj(t,e,n);return a?console.warn("Texture requires resizing for mipmaps but pixelDataType cannot be resized. The texture may be rendered incorrectly."):s&&console.warn("Texture requires resizing for wrapping but pixelDataType cannot be resized. The texture may be rendered incorrectly."),QQt(t,n)}function BQt(t){return[On.NEAREST_MIPMAP_NEAREST,On.NEAREST_MIPMAP_LINEAR,On.LINEAR_MIPMAP_NEAREST,On.LINEAR_MIPMAP_LINEAR].includes(t.minificationFilter)}function QQt(t,e){let{pixelFormat:n,pixelDatatype:i,width:o,height:a,typedArray:s,sampler:l}=t;return new hn({context:e,pixelFormat:n,pixelDatatype:i,source:{arrayBufferView:s,width:o,height:a},sampler:l,flipY:!1})}z1.prototype.update=function(t){if(t.frameNumber===this._lastUpdatedFrame)return;this._lastUpdatedFrame=t.frameNumber;let e=t.context;this._defaultTexture=e.defaultTexture;let n=this._loadedImages;for(let i=0;i<n.length;i++){let o=n[i];Oxe(this,o,e)}n.length=0};z1.prototype.isDestroyed=function(){return!1};z1.prototype.destroy=function(){let t=this._textures;for(let e in t)if(t.hasOwnProperty(e)){let n=t[e];n!==this._defaultTexture&&n.destroy()}return At(this)};var i5=z1;function o5(t){t=f(t,f.EMPTY_OBJECT),this.mode=f(t.mode,Z0.MODIFY_MATERIAL),this.lightingModel=t.lightingModel,this.uniforms=f(t.uniforms,f.EMPTY_OBJECT),this.varyings=f(t.varyings,f.EMPTY_OBJECT),this.vertexShaderText=t.vertexShaderText,this.fragmentShaderText=t.fragmentShaderText,this.translucencyMode=f(t.translucencyMode,iF.INHERIT),this._textureManager=new i5,this._defaultTexture=void 0,this.uniformMap=wxe(this),this.usedVariablesVertex={attributeSet:{},featureIdSet:{},metadataSet:{}},this.usedVariablesFragment={attributeSet:{},featureIdSet:{},metadataSet:{},materialSet:{}},Kxe(this),zxe(this)}function wxe(t){let e=t.uniforms,n={};for(let i in e)if(e.hasOwnProperty(i)){let o=e[i];o.type===K1.SAMPLER_2D?(t._textureManager.loadTexture2D(i,o.value),n[i]=Pxe(t,i)):n[i]=vxe(t,i)}return n}function Pxe(t,e){return function(){return f(t._textureManager.getTexture(e),t._defaultTexture)}}function vxe(t,e){return function(){return t.uniforms[e].value}}function XS(t,e,n){let i;for(;(i=e.exec(t))!==null;){let o=i[1];n[o]=!0}}function Kxe(t){let e=/[vf]sInput\.attributes\.(\w+)/g,n=/[vf]sInput\.featureIds\.(\w+)/g,i=/[vf]sInput\.metadata.(\w+)/g,o,a=t.vertexShaderText;c(a)&&(o=t.usedVariablesVertex.attributeSet,XS(a,e,o),o=t.usedVariablesVertex.featureIdSet,XS(a,n,o),o=t.usedVariablesVertex.metadataSet,XS(a,i,o));let s=t.fragmentShaderText;if(c(s)){o=t.usedVariablesFragment.attributeSet,XS(s,e,o),o=t.usedVariablesFragment.featureIdSet,XS(s,n,o),o=t.usedVariablesFragment.metadataSet,XS(s,i,o);let l=/material\.(\w+)/g,r=t.usedVariablesFragment.materialSet;XS(s,l,r)}}function kQt(t){let e=/^.*MC$/,n=/^.*WC$/,i=/^.*EC$/;return e.test(t)?`${t} (model coordinates)`:n.test(t)?`${t} (Cartesian world coordinates)`:i.test(t)?`${t} (eye coordinates)`:t}function uc(t,e,n,i){if(t.hasOwnProperty(e)){let o=`${kQt(e)} is not available in the ${i} shader. Did you mean ${kQt(n)} instead?`;throw new Ut(o)}}function zxe(t){let e=t.usedVariablesVertex.attributeSet;uc(e,"position","positionMC","vertex"),uc(e,"normal","normalMC","vertex"),uc(e,"tangent","tangentMC","vertex"),uc(e,"bitangent","bitangentMC","vertex"),uc(e,"positionWC","positionMC","vertex"),uc(e,"positionEC","positionMC","vertex"),uc(e,"normalEC","normalMC","vertex"),uc(e,"tangentEC","tangentMC","vertex"),uc(e,"bitangentEC","bitangentMC","vertex");let n=t.usedVariablesFragment.attributeSet;uc(n,"position","positionEC","fragment"),uc(n,"normal","normalEC","fragment"),uc(n,"tangent","tangentEC","fragment"),uc(n,"bitangent","bitangentEC","fragment"),uc(n,"normalMC","normalEC","fragment"),uc(n,"tangentMC","tangentEC","fragment"),uc(n,"bitangentMC","bitangentEC","fragment")}o5.prototype.setUniform=function(t,e){let n=this.uniforms[t];n.type===K1.SAMPLER_2D?this._textureManager.loadTexture2D(t,e):c(e.clone)?n.value=e.clone(n.value):n.value=e};o5.prototype.update=function(t){this._defaultTexture=t.context.defaultTexture,this._textureManager.update(t)};o5.prototype.isDestroyed=function(){return!1};o5.prototype.destroy=function(){this._textureManager=this._textureManager&&this._textureManager.destroy(),At(this)};var JS=o5;function Kb(t){t=f(t,f.EMPTY_OBJECT),this._ready=!1,this._provider=f(t.provider,Kb.DefaultProvider),this._traversal=void 0,this._shape=void 0,this._shapeVisible=!1,this._paddingBefore=new p,this._paddingAfter=new p,this._minBounds=new p,this._minBoundsOld=new p,this._maxBounds=new p,this._maxBoundsOld=new p,this._exaggeratedMinBounds=new p,this._exaggeratedMinBoundsOld=new p,this._exaggeratedMaxBounds=new p,this._exaggeratedMaxBoundsOld=new p,this._minClippingBounds=new p,this._minClippingBoundsOld=new p,this._maxClippingBounds=new p,this._maxClippingBoundsOld=new p,this._clippingPlanes=void 0,this._clippingPlanesState=0,this._clippingPlanesEnabled=!1,this._modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._exaggeratedModelMatrix=L.clone(this._modelMatrix),this._compoundModelMatrix=new L,this._compoundModelMatrixOld=new L,this._customShader=f(t.customShader,Kb.DefaultCustomShader),this._customShaderCompilationEvent=new It,this._shaderDirty=!0,this._drawCommand=void 0,this._drawCommandPick=void 0,this._pickId=void 0,this._clock=t.clock,this._transformPositionWorldToUv=new L,this._transformPositionUvToWorld=new L,this._transformDirectionWorldToLocal=new ot,this._transformNormalLocalToWorld=new ot,this._jitter=!1,this._nearestSampling=!1,this._levelBlendFactor=0,this._stepSizeMultiplier=1,this._depthTest=!0,this._useLogDepth=void 0,this._screenSpaceError=4,this._debugPolylines=new Mc,this._debugDraw=!1,this._disableRender=!1,this._disableUpdate=!1,this._uniforms={octreeInternalNodeTexture:void 0,octreeInternalNodeTilesPerRow:0,octreeInternalNodeTexelSizeUv:new K,octreeLeafNodeTexture:void 0,octreeLeafNodeTilesPerRow:0,octreeLeafNodeTexelSizeUv:new K,megatextureTextures:[],megatextureSliceDimensions:new K,megatextureTileDimensions:new K,megatextureVoxelSizeUv:new K,megatextureSliceSizeUv:new K,megatextureTileSizeUv:new K,dimensions:new p,paddingBefore:new p,paddingAfter:new p,transformPositionViewToUv:new L,transformPositionUvToView:new L,transformDirectionViewToLocal:new ot,transformNormalLocalToWorld:new ot,cameraPositionUv:new p,ndcSpaceAxisAlignedBoundingBox:new Rt,clippingPlanesTexture:void 0,clippingPlanesMatrix:new L,stepSize:0,pickColor:new v},this._shapeDefinesOld={},this._uniformMap={};let e=this._uniforms,n=this._uniformMap;for(let o in e)if(e.hasOwnProperty(o)){let a=`u_${o}`;n[a]=function(){return e[o]}}let i=this._provider;jxe(this,i)}function jxe(t,e){let{shape:n,minBounds:i=_o.getMinBounds(n),maxBounds:o=_o.getMaxBounds(n)}=e;t.minBounds=i,t.maxBounds=o,t.minClippingBounds=_o.getMinBounds(n),t.maxClippingBounds=_o.getMaxBounds(n),t._exaggeratedMinBounds=p.clone(t._minBounds,t._exaggeratedMinBounds),t._exaggeratedMaxBounds=p.clone(t._maxBounds,t._exaggeratedMaxBounds),t._exaggeratedModelMatrix=L.clone(t._modelMatrix,t._exaggeratedModelMatrix),xQt(t,e);let a=_o.getShapeConstructor(n);t._shape=new a,t._shapeVisible=XQt(t,t._shape,e)}Object.defineProperties(Kb.prototype,{ready:{get:function(){return this._ready}},provider:{get:function(){return this._provider}},boundingSphere:{get:function(){return this._shape.boundingSphere}},orientedBoundingBox:{get:function(){return this._shape.orientedBoundingBox}},modelMatrix:{get:function(){return this._modelMatrix},set:function(t){this._modelMatrix=L.clone(t,this._modelMatrix)}},shape:{get:function(){return this._provider.shape}},dimensions:{get:function(){return this._provider.dimensions}},minimumValues:{get:function(){return this._provider.minimumValues}},maximumValues:{get:function(){return this._provider.maximumValues}},show:{get:function(){return!this._disableRender},set:function(t){this._disableRender=!t}},disableUpdate:{get:function(){return this._disableUpdate},set:function(t){this._disableUpdate=t}},debugDraw:{get:function(){return this._debugDraw},set:function(t){this._debugDraw=t}},depthTest:{get:function(){return this._depthTest},set:function(t){this._depthTest!==t&&(this._depthTest=t,this._shaderDirty=!0)}},jitter:{get:function(){return this._jitter},set:function(t){this._jitter!==t&&(this._jitter=t,this._shaderDirty=!0)}},nearestSampling:{get:function(){return this._nearestSampling},set:function(t){this._nearestSampling!==t&&(this._nearestSampling=t,this._shaderDirty=!0)}},levelBlendFactor:{get:function(){return this._levelBlendFactor},set:function(t){this._levelBlendFactor=k.clamp(t,0,1)}},screenSpaceError:{get:function(){return this._screenSpaceError},set:function(t){this._screenSpaceError=t}},stepSize:{get:function(){return this._stepSizeMultiplier},set:function(t){this._stepSizeMultiplier=t}},minBounds:{get:function(){return this._minBounds},set:function(t){this._minBounds=p.clone(t,this._minBounds)}},maxBounds:{get:function(){return this._maxBounds},set:function(t){this._maxBounds=p.clone(t,this._maxBounds)}},minClippingBounds:{get:function(){return this._minClippingBounds},set:function(t){this._minClippingBounds=p.clone(t,this._minClippingBounds)}},maxClippingBounds:{get:function(){return this._maxClippingBounds},set:function(t){this._maxClippingBounds=p.clone(t,this._maxClippingBounds)}},clippingPlanes:{get:function(){return this._clippingPlanes},set:function(t){Ml.setOwner(t,this,"_clippingPlanes")}},customShader:{get:function(){return this._customShader},set:function(t){if(this._customShader!==t){let e=this._uniformMap,i=this._customShader.uniformMap;for(let o in i)i.hasOwnProperty(o)&&delete e[o];c(t)?this._customShader=t:this._customShader=Kb.DefaultCustomShader,this._shaderDirty=!0}}},customShaderCompilationEvent:{get:function(){return this._customShaderCompilationEvent}}});var qxe=new p,$xe=new Rt,tXe=new Rt,eXe=new p,nXe=new p,iXe=new ot,oXe=new ot,aXe=new L,sXe=new L,lXe=new L,rXe=L.fromRotationTranslation(ot.fromUniformScale(.5,new ot),new p(.5,.5,.5),new L),dXe=L.fromRotationTranslation(ot.fromUniformScale(2,new ot),new p(-1,-1,-1),new L);Kb.prototype.update=function(t){let e=this._provider;this._customShader.update(t);let n=t.context;if(!this._ready){ZXe(this,e,n),t.afterRender.push(()=>(this._ready=!0,!0));return}pXe(this,t);let i=xQt(this,e),o=this._shape;if(i&&(this._shapeVisible=XQt(this,o,e),RXe(this,o)&&(this._shaderDirty=!0)),!this._shapeVisible)return;let a=WXe(e.timeIntervalCollection,this._clock),s=this._traversal,l=s._sampleCount;if(s.update(t,a,i,this._disableUpdate),l!==s._sampleCount&&(this._shaderDirty=!0),!s.isRenderable(s.rootNode)||(this._debugDraw&&gXe(this,t),this._disableRender))return;this._useLogDepth!==t.useLogDepth&&(this._useLogDepth=t.useLogDepth,this._shaderDirty=!0),fXe(this,t)&&(this._shaderDirty=!0);let d=s.leafNodeTexture,m=this._uniforms;c(d)&&(m.octreeLeafNodeTexture=s.leafNodeTexture,m.octreeLeafNodeTexelSizeUv=K.clone(s.leafNodeTexelSizeUv,m.octreeLeafNodeTexelSizeUv),m.octreeLeafNodeTilesPerRow=s.leafNodeTilesPerRow),this._shaderDirty&&(q9(this,n),this._shaderDirty=!1);let h=n.uniformState.viewProjection,Z=o.orientedBoundingBox,b=GXe(Z,h,tXe);if(b.x===1||b.y===1||b.z===-1||b.w===-1)return;m.ndcSpaceAxisAlignedBoundingBox=Rt.clone(b,m.ndcSpaceAxisAlignedBoundingBox);let F=n.uniformState.inverseView;m.transformPositionViewToUv=L.multiplyTransformation(this._transformPositionWorldToUv,F,m.transformPositionViewToUv);let U=n.uniformState.view;m.transformPositionUvToView=L.multiplyTransformation(U,this._transformPositionUvToWorld,m.transformPositionUvToView);let G=n.uniformState.inverseViewRotation;m.transformDirectionViewToLocal=ot.multiply(this._transformDirectionWorldToLocal,G,m.transformDirectionViewToLocal),m.transformNormalLocalToWorld=ot.clone(this._transformNormalLocalToWorld,m.transformNormalLocalToWorld);let A=t.camera.positionWC;m.cameraPositionUv=L.multiplyByPoint(this._transformPositionWorldToUv,A,m.cameraPositionUv),m.stepSize=this._stepSizeMultiplier;let T=t.passes.pick?this._drawCommandPick:t.passes.pickVoxel?this._drawCommandPickVoxel:this._drawCommand;T.boundingVolume=o.boundingSphere,t.commandList.push(T)};var cXe=new p,Zst=new p,mXe=new gt,hXe=new p;function pXe(t,e){if(t._exaggeratedMinBounds=p.clone(t._minBounds,t._exaggeratedMinBounds),t._exaggeratedMaxBounds=p.clone(t._maxBounds,t._exaggeratedMaxBounds),t.shape===_o.ELLIPSOID){let n=e.verticalExaggerationRelativeHeight,i=e.verticalExaggeration;t._exaggeratedMinBounds.z=(t._minBounds.z-n)*i+n,t._exaggeratedMaxBounds.z=(t._maxBounds.z-n)*i+n}else if(t.shape===_o.BOX){let n=p.fromElements(1,1,e.verticalExaggeration,cXe);t._exaggeratedModelMatrix=L.multiplyByScale(t._modelMatrix,n,t._exaggeratedModelMatrix),t._exaggeratedModelMatrix=L.multiplyByTranslation(t._exaggeratedModelMatrix,uXe(t,e),t._exaggeratedModelMatrix)}}function uXe(t,e){let{shapeTransform:n=L.IDENTITY,globalTransform:i=L.IDENTITY}=t._provider,o=L.getTranslation(n,Zst),a=L.multiplyByPoint(t._modelMatrix,o,Zst),s=L.multiplyByPoint(i,a,Zst),r=mt.WGS84.cartesianToCartographic(s,mXe),d=0;c(r)&&(d=r.height);let m=Ps.getHeight(d,e.verticalExaggeration,e.verticalExaggerationRelativeHeight);return p.fromElements(0,0,(m-d)/e.verticalExaggeration,hXe)}function ZXe(t,e,n){let i=t._uniforms;t._pickId=n.createPickId({primitive:t}),i.pickColor=v.clone(t._pickId.color,i.pickColor);let{shaderDefines:o,shaderUniforms:a}=t._shape;t._shapeDefinesOld=be(o,!0);let s=t._uniformMap;for(let l in a)if(a.hasOwnProperty(l)){let r=`u_${l}`;s[r]=function(){return a[l]}}i.dimensions=p.clone(e.dimensions,i.dimensions),t._paddingBefore=p.clone(f(e.paddingBefore,p.ZERO),t._paddingBefore),i.paddingBefore=p.clone(t._paddingBefore,i.paddingBefore),t._paddingAfter=p.clone(f(e.paddingAfter,p.ZERO),t._paddingBefore),i.paddingAfter=p.clone(t._paddingAfter,i.paddingAfter),t._traversal=VXe(t,e,n),bXe(t._traversal,i)}function xQt(t,e){let n=f(e.shapeTransform,L.IDENTITY),i=f(e.globalTransform,L.IDENTITY);return L.multiplyTransformation(i,t._exaggeratedModelMatrix,t._compoundModelMatrix),L.multiplyTransformation(t._compoundModelMatrix,n,t._compoundModelMatrix),LS(t,"_compoundModelMatrix","_compoundModelMatrixOld")+LS(t,"_minBounds","_minBoundsOld")+LS(t,"_maxBounds","_maxBoundsOld")+LS(t,"_exaggeratedMinBounds","_exaggeratedMinBoundsOld")+LS(t,"_exaggeratedMaxBounds","_exaggeratedMaxBoundsOld")+LS(t,"_minClippingBounds","_minClippingBoundsOld")+LS(t,"_maxClippingBounds","_maxClippingBoundsOld")>0}function LS(t,e,n){let i=t[e],o=t[n],a=!i.equals(o);return a&&i.clone(o),a?1:0}function XQt(t,e,n){if(!e.update(t._compoundModelMatrix,t._exaggeratedMinBounds,t._exaggeratedMaxBounds,t.minClippingBounds,t.maxClippingBounds))return!1;let o=e.shapeTransform,a=L.inverse(o,aXe),s=L.getRotation(o,iXe),l=L.getScale(o,eXe),r=p.maximumComponent(l),d=p.divideByScalar(l,r,nXe),m=ot.multiplyByScale(s,d,oXe);return t._transformPositionWorldToUv=L.multiplyTransformation(rXe,a,t._transformPositionWorldToUv),t._transformPositionUvToWorld=L.multiplyTransformation(o,dXe,t._transformPositionUvToWorld),t._transformDirectionWorldToLocal=L.getMatrix3(a,t._transformDirectionWorldToLocal),t._transformNormalLocalToWorld=ot.inverseTranspose(m,t._transformNormalLocalToWorld),!0}function VXe(t,e,n){let i=p.clone(e.dimensions,qxe);p.add(i,t._paddingBefore,i),p.add(i,t._paddingAfter,i);let o=e.maximumTileCount,a=c(o)?v1.getApproximateTextureMemoryByteLength(o,i,e.types,e.componentTypes):void 0,s=f(e.keyframeCount,1);return new v1(t,n,i,e.types,e.componentTypes,s,a)}function bXe(t,e){e.octreeInternalNodeTexture=t.internalNodeTexture,e.octreeInternalNodeTexelSizeUv=K.clone(t.internalNodeTexelSizeUv,e.octreeInternalNodeTexelSizeUv),e.octreeInternalNodeTilesPerRow=t.internalNodeTilesPerRow;let n=t.megatextures,i=n[0],o=n.length;e.megatextureTextures=new Array(o);for(let a=0;a<o;a++)e.megatextureTextures[a]=n[a].texture;e.megatextureSliceDimensions=K.clone(i.sliceCountPerRegion,e.megatextureSliceDimensions),e.megatextureTileDimensions=K.clone(i.regionCountPerMegatexture,e.megatextureTileDimensions),e.megatextureVoxelSizeUv=K.clone(i.voxelSizeUv,e.megatextureVoxelSizeUv),e.megatextureSliceSizeUv=K.clone(i.sliceSizeUv,e.megatextureSliceSizeUv),e.megatextureTileSizeUv=K.clone(i.regionSizeUv,e.megatextureTileSizeUv)}function RXe(t,e){let n=e.shaderDefines,i=Object.keys(n).some(o=>n[o]!==t._shapeDefinesOld[o]);return i&&(t._shapeDefinesOld=be(n,!0)),i}function WXe(t,e){if(!c(t)||!c(e))return 0;let n=e.currentTime,i,o=t.indexOf(n);o>=0?i=t.get(o):(o=~o,o===t.length?(o=t.length-1,i=t.get(o),n=i.stop):(i=t.get(o),n=i.start));let a=rt.secondsDifference(i.stop,i.start),l=rt.secondsDifference(n,i.start)/a;return o+l}function fXe(t,e){let n=t.clippingPlanes;if(!c(n))return!1;n.update(e);let{clippingPlanesState:i,enabled:o}=n;if(o){let a=t._uniforms;a.clippingPlanesTexture=n.texture,a.clippingPlanesMatrix=L.transpose(L.multiplyTransformation(L.inverse(n.modelMatrix,a.clippingPlanesMatrix),t._transformPositionUvToWorld,a.clippingPlanesMatrix),a.clippingPlanesMatrix)}return t._clippingPlanesState===i&&t._clippingPlanesEnabled===o?!1:(t._clippingPlanesState=i,t._clippingPlanesEnabled=o,!0)}Kb.prototype.isDestroyed=function(){return!1};Kb.prototype.destroy=function(){let t=this._drawCommand;c(t)&&(t.shaderProgram=t.shaderProgram&&t.shaderProgram.destroy());let e=this._drawCommandPick;return c(e)&&(e.shaderProgram=e.shaderProgram&&e.shaderProgram.destroy()),this._pickId=this._pickId&&this._pickId.destroy(),this._traversal=this._traversal&&this._traversal.destroy(),this._clippingPlanes=this._clippingPlanes&&this._clippingPlanes.destroy(),At(this)};var YQt=new Array(new Rt(-1,-1,-1,1),new Rt(1,-1,-1,1),new Rt(-1,1,-1,1),new Rt(1,1,-1,1),new Rt(-1,-1,1,1),new Rt(1,-1,1,1),new Rt(-1,1,1,1),new Rt(1,1,1,1)),FXe=new Array(1,2,4,0,3,5,0,3,6,1,2,7,0,5,6,1,4,7,2,4,7,3,5,6),UXe=new Array(new Rt,new Rt,new Rt,new Rt,new Rt,new Rt,new Rt,new Rt);function GXe(t,e,n){let i=L.fromRotationTranslation(t.halfAxes,t.center,sXe),o=L.multiply(e,i,lXe),a=+Number.MAX_VALUE,s=-Number.MAX_VALUE,l=+Number.MAX_VALUE,r=-Number.MAX_VALUE,d,m=UXe,h=YQt.length;for(d=0;d<h;d++)L.multiplyByVector(o,YQt[d],m[d]);for(d=0;d<h;d++){let Z=m[d];if(Z.z>=-Z.w){let b=Z.x/Z.w,u=Z.y/Z.w;a=Math.min(a,b),s=Math.max(s,b),l=Math.min(l,u),r=Math.max(r,u)}else for(let b=0;b<3;b++){let u=FXe[d*3+b],F=m[u];if(F.z>=-F.w){let U=Z.z+Z.w,G=F.z+F.w,A=U/(U-G),T=Rt.lerp(Z,F,A,$xe),g=T.x/T.w,C=T.y/T.w;a=Math.min(a,g),s=Math.max(s,g),l=Math.min(l,C),r=Math.max(r,C)}}}return a=k.clamp(a,-1,1),l=k.clamp(l,-1,1),s=k.clamp(s,-1,1),r=k.clamp(r,-1,1),n=Rt.fromElements(a,l,s,r,n),n}var Vst=3e7,AXe=new p(Vst,0,0),TXe=new p(0,Vst,0),SXe=new p(0,0,Vst);function gXe(t,e){let n=t._traversal,i=t._debugPolylines;i.removeAll();function o(r,d,m,h){i.add({positions:[r,d],width:h,material:eo.fromType("Color",{color:m})})}function a(r,d,m){let h=r.computeCorners();o(h[0],h[1],d,m),o(h[2],h[3],d,m),o(h[4],h[5],d,m),o(h[6],h[7],d,m),o(h[0],h[2],d,m),o(h[4],h[6],d,m),o(h[1],h[3],d,m),o(h[5],h[7],d,m),o(h[0],h[4],d,m),o(h[2],h[6],d,m),o(h[1],h[5],d,m),o(h[3],h[7],d,m)}function s(r){if(!n.isRenderable(r))return;let d=r.level,h=Math.max(1,5/Math.pow(2,d)),b=[v.RED,v.LIME,v.BLUE][d%3];if(a(r.orientedBoundingBox,b,h),c(r.children))for(let u=0;u<8;u++)s(r.children[u])}a(t._shape.orientedBoundingBox,v.WHITE,5),s(n.rootNode);let l=10;o(p.ZERO,AXe,v.RED,l),o(p.ZERO,TXe,v.LIME,l),o(p.ZERO,SXe,v.BLUE,l),i.update(e)}Kb.DefaultCustomShader=new JS({fragmentShaderText:`void fragmentMain(FragmentInput fsInput, inout czm_modelMaterial material) +`;function PYe(t){let e=new EG;this.shaderBuilder=e;let n=t._customShader,i=ze(t._uniformMap,n.uniformMap);t._uniformMap=i;let o=n.uniforms;for(let u in o)if(o.hasOwnProperty(u)){let R=o[u];e.addUniform(R.type,u,Xt.FRAGMENT)}e.addUniform("sampler2D","u_megatextureTextures[METADATA_COUNT]",Xt.FRAGMENT),this.uniformMap=i;let a=t._clippingPlanes,s=c(a)&&a.enabled?a.length:0;this.clippingPlanes=a,this.clippingPlanesLength=s,e.addVertexLines([X9]),e.addFragmentLines([n.fragmentShaderText,"#line 0",v9,Y9,J9,K9]),s>0&&(e.addDefine("CLIPPING_PLANES",void 0,Xt.FRAGMENT),e.addDefine("CLIPPING_PLANES_COUNT",s,Xt.FRAGMENT),a.unionClippingRegions&&e.addDefine("CLIPPING_PLANES_UNION",void 0,Xt.FRAGMENT),e.addFragmentLines([M9])),t._depthTest&&(e.addDefine("DEPTH_TEST",void 0,Xt.FRAGMENT),e.addFragmentLines([L9]));let l=t._provider.shape;l==="BOX"?e.addFragmentLines([H9,_9,kT]):l==="CYLINDER"?e.addFragmentLines([w9,w1,D9,kT]):l==="ELLIPSOID"&&(e.addDefine("SHAPE_ELLIPSOID",void 0,Xt.FRAGMENT),e.addFragmentLines([P9,w1,O9,kT])),e.addFragmentLines([x9]);let r=t._shape,d=r.shaderDefines;for(let u in d)if(d.hasOwnProperty(u)){let R=d[u];c(R)&&(R=R===!0?void 0:R,e.addDefine(u,R,Xt.FRAGMENT))}let m=r.shaderMaximumIntersectionsLength;s>0&&(e.addDefine("CLIPPING_PLANES_INTERSECTION_INDEX",m,Xt.FRAGMENT),s===1?m+=1:a.unionClippingRegions?m+=2:m+=1),t._depthTest&&(e.addDefine("DEPTH_INTERSECTION_INDEX",m,Xt.FRAGMENT),m+=1),e.addDefine("INTERSECTION_COUNT",m,Xt.FRAGMENT),(!p.equals(t.paddingBefore,p.ZERO)||!p.equals(t.paddingAfter,p.ZERO))&&e.addDefine("PADDING",void 0,Xt.FRAGMENT),t._useLogDepth&&e.addDefine("LOG_DEPTH_READ_ONLY",void 0,Xt.FRAGMENT),t._jitter&&e.addDefine("JITTER",void 0,Xt.FRAGMENT),t._nearestSampling&&e.addDefine("NEAREST_SAMPLING",void 0,Xt.FRAGMENT);let h=t._traversal;e.addDefine("SAMPLE_COUNT",`${h._sampleCount}`,Xt.FRAGMENT)}var z9=PYe;var vYo=b(W(),1);function vYe(t,e){let{shaderBuilder:n}=t,{names:i,types:o,componentTypes:a,minimumValues:s,maximumValues:l}=e._provider,r=o.length,d=c(s)&&c(l);n.addDefine("METADATA_COUNT",r,Xt.FRAGMENT),d&&n.addDefine("STATISTICS",void 0,Xt.FRAGMENT);for(let Q=0;Q<r;Q++){let J=i[Q],M=o[Q],Z=`PropertyStatistics_${J}`,E=`PropertyStatistics_${J}`;n.addStruct(Z,E,Xt.FRAGMENT);let I=Aj(M);n.addStructField(Z,I,"min"),n.addStructField(Z,I,"max")}let m="Statistics",h="Statistics",u="statistics";n.addStruct(m,h,Xt.FRAGMENT);for(let Q=0;Q<r;Q++){let J=i[Q],M=`PropertyStatistics_${J}`,Z=J;n.addStructField(m,M,Z)}let R="Metadata",V="Metadata",F="metadata";n.addStruct(R,V,Xt.FRAGMENT),n.addStructField(R,h,u);for(let Q=0;Q<r;Q++){let J=i[Q],M=o[Q],Z=Aj(M);n.addStructField(R,Z,J)}for(let Q=0;Q<r;Q++){let J=i[Q],M=o[Q],Z=zYe(M),E=`VoxelProperty_${J}`,I=`VoxelProperty_${J}`;n.addStruct(E,I,Xt.FRAGMENT),n.addStructField(E,Z,"partialDerivativeLocal"),n.addStructField(E,Z,"partialDerivativeWorld"),n.addStructField(E,Z,"partialDerivativeView"),n.addStructField(E,Z,"partialDerivativeValid")}let U="Voxel",G="Voxel",A="voxel";n.addStruct(U,G,Xt.FRAGMENT);for(let Q=0;Q<r;Q++){let J=i[Q],M=`VoxelProperty_${J}`;n.addStructField(U,M,J)}n.addStructField(U,"vec3","positionEC"),n.addStructField(U,"vec3","positionUv"),n.addStructField(U,"vec3","positionShapeUv"),n.addStructField(U,"vec3","positionUvLocal"),n.addStructField(U,"vec3","viewDirUv"),n.addStructField(U,"vec3","viewDirWorld"),n.addStructField(U,"vec3","surfaceNormal"),n.addStructField(U,"float","travelDistance"),n.addStructField(U,"int","stepCount"),n.addStructField(U,"int","tileIndex"),n.addStructField(U,"int","sampleIndex");let S="FragmentInput";n.addStruct(S,"FragmentInput",Xt.FRAGMENT),n.addStructField(S,V,F),n.addStructField(S,G,A);let C="Properties",y="Properties",Y="properties";n.addStruct(C,y,Xt.FRAGMENT);for(let Q=0;Q<r;Q++){let J=i[Q],M=o[Q],Z=Aj(M);n.addStructField(C,Z,J)}{let Q="clearProperties";n.addFunction(Q,`${y} clearProperties()`,Xt.FRAGMENT),n.addFunctionLines(Q,[`${y} ${Y};`]);for(let J=0;J<r;J++){let M=i[J],Z=o[J],E=a[J],I=Aj(Z,E);n.addFunctionLines(Q,[`${Y}.${M} = ${I}(0.0);`])}n.addFunctionLines(Q,[`return ${Y};`])}{let Q="sumProperties";n.addFunction(Q,`${y} sumProperties(${y} propertiesA, ${y} propertiesB)`,Xt.FRAGMENT),n.addFunctionLines(Q,[`${y} ${Y};`]);for(let J=0;J<r;J++){let M=i[J];n.addFunctionLines(Q,[`${Y}.${M} = propertiesA.${M} + propertiesB.${M};`])}n.addFunctionLines(Q,[`return ${Y};`])}{let Q="scaleProperties";n.addFunction(Q,`${y} scaleProperties(${y} ${Y}, float scale)`,Xt.FRAGMENT),n.addFunctionLines(Q,[`${y} scaledProperties = ${Y};`]);for(let J=0;J<r;J++){let M=i[J];n.addFunctionLines(Q,[`scaledProperties.${M} *= scale;`])}n.addFunctionLines(Q,["return scaledProperties;"])}{let Q="mixProperties";n.addFunction(Q,`${y} mixProperties(${y} propertiesA, ${y} propertiesB, float mixFactor)`,Xt.FRAGMENT),n.addFunctionLines(Q,[`${y} ${Y};`]);for(let J=0;J<r;J++){let M=i[J];n.addFunctionLines(Q,[`${Y}.${M} = mix(propertiesA.${M}, propertiesB.${M}, mixFactor);`])}n.addFunctionLines(Q,[`return ${Y};`])}{let Q="copyPropertiesToMetadata";n.addFunction(Q,`void copyPropertiesToMetadata(in ${y} ${Y}, inout ${V} ${F})`,Xt.FRAGMENT);for(let J=0;J<r;J++){let M=i[J];n.addFunctionLines(Q,[`${F}.${M} = ${Y}.${M};`])}}if(d){let Q="setStatistics";n.addFunction(Q,`void setStatistics(inout ${h} ${u})`,Xt.FRAGMENT);for(let J=0;J<r;J++){let M=i[J],Z=o[J],E=Nn.getComponentCount(Z);for(let I=0;I<E;I++){let B=jYe(Z,I),X=s[J][I],_=l[J][I];n.addFunctionLines(Q,[`${u}.${M}.min${B} = ${VQt(X)};`,`${u}.${M}.max${B} = ${VQt(_)};`])}}}{let Q="getPropertiesFromMegatextureAtUv";n.addFunction(Q,`${y} getPropertiesFromMegatextureAtUv(vec2 texcoord)`,Xt.FRAGMENT),n.addFunctionLines(Q,[`${y} ${Y};`]);for(let J=0;J<r;J++){let M=i[J],Z=o[J],E=a[J],I=KYe(Z,E);n.addFunctionLines(Q,[`properties.${M} = texture(u_megatextureTextures[${J}], texcoord)${I};`])}n.addFunctionLines(Q,[`return ${Y};`])}}function Aj(t){if(t===Nn.SCALAR)return"float";if(t===Nn.VEC2)return"vec2";if(t===Nn.VEC3)return"vec3";if(t===Nn.VEC4)return"vec4"}function KYe(t){if(t===Nn.SCALAR)return".r";if(t===Nn.VEC2)return".ra";if(t===Nn.VEC3)return".rgb";if(t===Nn.VEC4)return""}function zYe(t){if(t===Nn.SCALAR)return"vec3";if(t===Nn.VEC2)return"mat2";if(t===Nn.VEC3)return"mat3";if(t===Nn.VEC4)return"mat4"}function VQt(t){let e=t.toString();return e.indexOf(".")===-1&&(e=`${t}.0`),e}function jYe(t,e){return t===Nn.SCALAR?"":`[${e}]`}var j9=vYe;function qYe(t,e){let n=new z9(t);j9(n,t);let{shaderBuilder:i,clippingPlanes:o,clippingPlanesLength:a}=n;if(a>0){let G="getClippingPlane",A=dW(o,e),S=0,g=A.indexOf(")")+1,C=A.indexOf("{",g)+1,y=A.indexOf("}",C),Y=A.slice(S,g),Q=A.slice(C,y);i.addFunction(G,Y,Xt.FRAGMENT),i.addFunctionLines(G,[Q])}let s=i.clone();s.addDefine("PICKING",void 0,Xt.FRAGMENT);let l=i.clone();l.addDefine("PICKING_VOXEL",void 0,Xt.FRAGMENT);let r=i.buildShaderProgram(e),d=s.buildShaderProgram(e),m=l.buildShaderProgram(e),h=he.fromCache({cull:{enabled:!0,face:so.BACK},depthTest:{enabled:!1},depthMask:!1,blending:Pn.PRE_MULTIPLIED_ALPHA_BLEND}),u=e.getViewportQuadVertexArray(),R=t._depthTest,V=new Ee({vertexArray:u,primitiveType:le.TRIANGLES,renderState:h,shaderProgram:r,uniformMap:n.uniformMap,modelMatrix:t._compoundModelMatrix,pass:Pt.VOXELS,executeInClosestFrustum:!0,owner:this,cull:R,occlude:R}),F=Ee.shallowClone(V,new Ee);F.shaderProgram=d,F.pickOnly=!0;let U=Ee.shallowClone(V,new Ee);if(U.shaderProgram=m,U.pickOnly=!0,c(t._drawCommand)){let G=t._drawCommand;G.shaderProgram=G.shaderProgram&&G.shaderProgram.destroy()}if(c(t._drawCommandPick)){let G=t._drawCommandPick;G.shaderProgram=G.shaderProgram&&G.shaderProgram.destroy()}if(c(t._drawCommandPickVoxel)){let G=t._drawCommandPickVoxel;G.shaderProgram=G.shaderProgram&&G.shaderProgram.destroy()}t._drawCommand=V,t._drawCommandPick=F,t._drawCommandPickVoxel=U}var q9=qYe;var Oxo=b(W(),1);var Zxo=b(W(),1);function ih(){this.orientedBoundingBox=new ci,this.boundingSphere=new Ft,this.boundTransform=new L,this.shapeTransform=new L,this._minBounds=p.clone(ih.DefaultMinBounds,new p),this._maxBounds=p.clone(ih.DefaultMaxBounds,new p),this.shaderUniforms={renderMinBounds:new p,renderMaxBounds:new p,boxUvToShapeUvScale:new p,boxUvToShapeUvTranslate:new p},this.shaderDefines={BOX_INTERSECTION_INDEX:void 0,BOX_HAS_SHAPE_BOUNDS:void 0},this.shaderMaximumIntersectionsLength=0}var $Ye=new p,lst=new p,txe=new ot,exe=new p,nxe=new p,ixe=new p,oxe=new p,uQt=L.fromRotationTranslation(ot.fromUniformScale(.5,new ot),new p(.5,.5,.5),new L);ih.prototype.update=function(t,e,n,i,o){i=f(i,ih.DefaultMinBounds),o=f(o,ih.DefaultMaxBounds);let a=ih.DefaultMinBounds,s=ih.DefaultMaxBounds;e=this._minBounds=p.clamp(e,a,s,this._minBounds),n=this._maxBounds=p.clamp(n,a,s,this._maxBounds),i=p.clamp(i,a,s,exe),o=p.clamp(o,a,s,nxe);let l=p.clamp(e,i,o,ixe),r=p.clamp(n,i,o,oxe),d=L.getScale(t,lst);if(l.x>r.x||l.y>r.y||l.z>r.z||(l.x===r.x)+(l.y===r.y)+(l.z===r.z)>=2||i.x>o.x||i.y>o.y||i.z>o.z||d.x===0||d.y===0||d.z===0)return!1;this.shapeTransform=L.clone(t,this.shapeTransform),this.orientedBoundingBox=dst(l,r,this.shapeTransform,this.orientedBoundingBox),this.boundTransform=L.fromRotationTranslation(this.orientedBoundingBox.halfAxes,this.orientedBoundingBox.center,this.boundTransform),this.boundingSphere=Ft.fromOrientedBoundingBox(this.orientedBoundingBox,this.boundingSphere);let{shaderUniforms:m,shaderDefines:h}=this;for(let V in h)h.hasOwnProperty(V)&&(h[V]=void 0);let u=!p.equals(e,a)||!p.equals(n,s),R=0;if(h.BOX_INTERSECTION_INDEX=R,R+=1,m.renderMinBounds=L.multiplyByPoint(uQt,l,m.renderMinBounds),m.renderMaxBounds=L.multiplyByPoint(uQt,r,m.renderMaxBounds),u){h.BOX_HAS_SHAPE_BOUNDS=!0;let V=e,F=n;m.boxUvToShapeUvScale=p.fromElements(2/(V.x===F.x?1:F.x-V.x),2/(V.y===F.y?1:F.y-V.y),2/(V.z===F.z?1:F.z-V.z),m.boxUvToShapeUvScale),m.boxUvToShapeUvTranslate=p.fromElements(-m.boxUvToShapeUvScale.x*(V.x*.5+.5),-m.boxUvToShapeUvScale.y*(V.y*.5+.5),-m.boxUvToShapeUvScale.z*(V.z*.5+.5),m.boxUvToShapeUvTranslate)}return this.shaderMaximumIntersectionsLength=R,!0};var Sj=new p,rst=new p;ih.prototype.computeOrientedBoundingBoxForTile=function(t,e,n,i,o){let a=this._minBounds,s=this._maxBounds,l=1/Math.pow(2,t),r=p.fromElements(k.lerp(a.x,s.x,l*e),k.lerp(a.y,s.y,l*n),k.lerp(a.z,s.z,l*i),Sj),d=p.fromElements(k.lerp(a.x,s.x,l*(e+1)),k.lerp(a.y,s.y,l*(n+1)),k.lerp(a.z,s.z,l*(i+1)),rst);return dst(r,d,this.shapeTransform,o)};var ZQt=new p;ih.prototype.computeOrientedBoundingBoxForSample=function(t,e,n,i){let o=1/Math.pow(2,t.level),a=p.divideComponents(p.ONE,e,ZQt),s=p.multiplyByScalar(a,o,ZQt),l=p.multiplyByScalar(p.fromElements(t.x+n.x,t.y+n.y,t.z+n.z,Sj),o,Sj),r=p.add(l,s,rst),d=this._minBounds,m=this._maxBounds,h=p.fromElements(k.lerp(d.x,m.x,l.x),k.lerp(d.y,m.y,l.y),k.lerp(d.z,m.z,l.z),Sj),u=p.fromElements(k.lerp(d.x,m.x,r.x),k.lerp(d.y,m.y,r.y),k.lerp(d.z,m.z,r.z),rst);return dst(h,u,this.shapeTransform,i)};ih.DefaultMinBounds=Object.freeze(new p(-1,-1,-1));ih.DefaultMaxBounds=Object.freeze(new p(1,1,1));function dst(t,e,n,i){let o=ih.DefaultMinBounds,a=ih.DefaultMaxBounds;if(p.equals(t,o)&&p.equals(e,a))i.center=L.getTranslation(n,i.center),i.halfAxes=L.getMatrix3(n,i.halfAxes);else{let l=L.getScale(n,lst),r=p.midpoint(t,e,$Ye);i.center=L.multiplyByPoint(n,r,i.center),l=p.fromElements(l.x*.5*(e.x-t.x),l.y*.5*(e.y-t.y),l.z*.5*(e.z-t.z),lst);let d=L.getRotation(n,txe);i.halfAxes=ot.setScale(d,l,i.halfAxes)}return i}var PR=ih;var gxo=b(W(),1);function Cl(){this.orientedBoundingBox=new ci,this.boundingSphere=new Ft,this.boundTransform=new L,this.shapeTransform=new L,this._minimumRadius=Cl.DefaultMinBounds.x,this._maximumRadius=Cl.DefaultMaxBounds.x,this._minimumHeight=Cl.DefaultMinBounds.y,this._maximumHeight=Cl.DefaultMaxBounds.y,this._minimumAngle=Cl.DefaultMinBounds.z,this._maximumAngle=Cl.DefaultMaxBounds.z,this.shaderUniforms={cylinderRenderHeightMinMax:new K,cylinderRenderRadiusMinMax:new K,cylinderRenderAngleMinMax:new K,cylinderUvToShapeUvRadius:new K,cylinderUvToShapeUvHeight:new K,cylinderUvToShapeUvAngle:new K,cylinderShapeUvAngleMinMax:new K,cylinderShapeUvAngleRangeZeroMid:0},this.shaderDefines={CYLINDER_HAS_RENDER_BOUNDS_RADIUS_MIN:void 0,CYLINDER_HAS_RENDER_BOUNDS_RADIUS_FLAT:void 0,CYLINDER_HAS_RENDER_BOUNDS_ANGLE:void 0,CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_EQUAL_ZERO:void 0,CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_UNDER_HALF:void 0,CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_OVER_HALF:void 0,CYLINDER_HAS_SHAPE_BOUNDS_RADIUS:void 0,CYLINDER_HAS_SHAPE_BOUNDS_HEIGHT:void 0,CYLINDER_HAS_SHAPE_BOUNDS_ANGLE:void 0,CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MIN_DISCONTINUITY:void 0,CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MAX_DISCONTINUITY:void 0,CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MIN_MAX_REVERSED:void 0,CYLINDER_INTERSECTION_INDEX_RADIUS_MAX:void 0,CYLINDER_INTERSECTION_INDEX_RADIUS_MIN:void 0,CYLINDER_INTERSECTION_INDEX_ANGLE:void 0},this.shaderMaximumIntersectionsLength=0}var fQt=new p;Cl.prototype.update=function(t,e,n,i,o){i=f(i,Cl.DefaultMinBounds),o=f(o,Cl.DefaultMaxBounds);let a=Cl.DefaultMinBounds.x,s=Cl.DefaultMaxBounds.x,l=Cl.DefaultMinBounds.y,r=Cl.DefaultMaxBounds.y,d=Cl.DefaultMinBounds.z,m=Cl.DefaultMaxBounds.z,h=m-d,u=.5*h,R=k.EPSILON10,V=k.EPSILON3,F=k.EPSILON10,U=k.clamp(e.x,a,s),G=k.clamp(n.x,a,s),A=k.clamp(i.x,a,s),S=k.clamp(o.x,a,s),g=Math.max(U,A),C=Math.min(G,S),y=k.clamp(e.y,l,r),Y=k.clamp(n.y,l,r),Q=k.clamp(i.y,l,r),J=k.clamp(o.y,l,r),M=Math.max(y,Q),Z=Math.min(Y,J),E=k.negativePiToPi(e.z),I=k.negativePiToPi(n.z),B=k.negativePiToPi(i.z),X=k.negativePiToPi(o.z),_=Math.max(E,B),P=Math.min(I,X),w=L.getScale(t,fQt);if(C===0||g>C||M>Z||k.equalsEpsilon(w.x,0,void 0,R)||k.equalsEpsilon(w.y,0,void 0,R)||k.equalsEpsilon(w.z,0,void 0,R))return!1;this._minimumRadius=U,this._maximumRadius=G,this._minimumHeight=y,this._maximumHeight=Y,this._minimumAngle=E,this._maximumAngle=I,this.shapeTransform=L.clone(t,this.shapeTransform),this.orientedBoundingBox=mst(g,C,M,Z,_,P,this.shapeTransform,this.orientedBoundingBox),this.boundTransform=L.fromRotationTranslation(this.orientedBoundingBox.halfAxes,this.orientedBoundingBox.center,this.boundTransform),this.boundingSphere=Ft.fromOrientedBoundingBox(this.orientedBoundingBox,this.boundingSphere);let nt=U===a&&G===s,$=y===l&&Y===r,dt=I<E,q=I-E+dt*h,at=q>u+F&&q<h-F,st=q<u-F,Et=q>=u-F&&q<=u+F,Qt=at||st||Et,Wt=k.equalsEpsilon(E,d,void 0,V),Nt=k.equalsEpsilon(I,m,void 0,V),kt=g===a,Mt=P<_,qt=P-_+Mt*h,ie=qt>=u-F&&qt<h-F,oe=qt>F&&qt<u-F,He=qt<=F,rn=ie||oe||He,{shaderUniforms:de,shaderDefines:zt}=this;for(let Ve in zt)zt.hasOwnProperty(Ve)&&(zt[Ve]=void 0);let ke=0;if(zt.CYLINDER_INTERSECTION_INDEX_RADIUS_MAX=ke,ke+=1,kt||(zt.CYLINDER_HAS_RENDER_BOUNDS_RADIUS_MIN=!0,zt.CYLINDER_INTERSECTION_INDEX_RADIUS_MIN=ke,ke+=1),de.cylinderRenderRadiusMinMax=K.fromElements(g,C,de.cylinderRenderRadiusMinMax),g===C&&(zt.CYLINDER_HAS_RENDER_BOUNDS_RADIUS_FLAT=!0),!nt){zt.CYLINDER_HAS_SHAPE_BOUNDS_RADIUS=!0;let Ve=G-U,We=0,Vn=1;Ve!==0&&(We=1/Ve,Vn=-U/Ve),de.cylinderUvToShapeUvRadius=K.fromElements(We,Vn,de.cylinderUvToShapeUvRadius)}if(!$){zt.CYLINDER_HAS_SHAPE_BOUNDS_HEIGHT=!0;let Ve=Y-y,We=0,Vn=1;Ve!==0&&(We=2/Ve,Vn=-(y+1)/Ve),de.cylinderUvToShapeUvHeight=K.fromElements(We,Vn,de.cylinderUvToShapeUvHeight)}if(de.cylinderRenderHeightMinMax=K.fromElements(M,Z,de.cylinderRenderHeightMinMax),dt&&(zt.CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MIN_MAX_REVERSED=!0),rn&&(zt.CYLINDER_HAS_RENDER_BOUNDS_ANGLE=!0,zt.CYLINDER_INTERSECTION_INDEX_ANGLE=ke,ie?(zt.CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_UNDER_HALF=!0,ke+=1):oe?(zt.CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_OVER_HALF=!0,ke+=2):He&&(zt.CYLINDER_HAS_RENDER_BOUNDS_ANGLE_RANGE_EQUAL_ZERO=!0,ke+=2),de.cylinderRenderAngleMinMax=K.fromElements(_,P,de.cylinderRenderAngleMinMax)),Qt){zt.CYLINDER_HAS_SHAPE_BOUNDS_ANGLE=!0,Wt&&(zt.CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MIN_DISCONTINUITY=!0),Nt&&(zt.CYLINDER_HAS_SHAPE_BOUNDS_ANGLE_MAX_DISCONTINUITY=!0);let Ve=(E-d)/h,We=(I-d)/h,Vn=1-q/h;if(de.cylinderShapeUvAngleMinMax=K.fromElements(Ve,We,de.cylinderShapeUvAngleMinMax),de.cylinderShapeUvAngleRangeZeroMid=(We+.5*Vn)%1,q<=F)de.cylinderUvToShapeUvAngle=K.fromElements(0,1,de.cylinderUvToShapeUvAngle);else{let Ct=h/q,_t=-(E-d)/q;de.cylinderUvToShapeUvAngle=K.fromElements(Ct,_t,de.cylinderUvToShapeUvAngle)}}return this.shaderMaximumIntersectionsLength=ke,!0};Cl.prototype.computeOrientedBoundingBoxForTile=function(t,e,n,i,o){let a=this._minimumRadius,s=this._maximumRadius,l=this._minimumHeight,r=this._maximumHeight,d=this._minimumAngle,m=this._maximumAngle,h=1/Math.pow(2,t),u=k.lerp(a,s,e*h),R=k.lerp(a,s,(e+1)*h),V=k.lerp(l,r,n*h),F=k.lerp(l,r,(n+1)*h),U=k.lerp(d,m,i*h),G=k.lerp(d,m,(i+1)*h);return mst(u,R,V,F,U,G,this.shapeTransform,o)};var RQt=new p,bQt=new p,axe=new p;Cl.prototype.computeOrientedBoundingBoxForSample=function(t,e,n,i){let o=1/Math.pow(2,t.level),a=p.divideComponents(p.ONE,e,RQt),s=p.multiplyByScalar(a,o,RQt),l=p.multiplyByScalar(p.fromElements(t.x+n.x,t.y+n.y,t.z+n.z,bQt),o,bQt),r=p.add(l,s,axe),d=this._minimumRadius,m=this._maximumRadius,h=this._minimumHeight,u=this._maximumHeight,R=this._minimumAngle,V=this._maximumAngle,F=k.lerp(d,m,l.x),U=k.lerp(d,m,r.x),G=k.lerp(h,u,l.y),A=k.lerp(h,u,r.y),S=k.lerp(R,V,l.z),g=k.lerp(R,V,r.z);return mst(F,U,G,A,S,g,this.shapeTransform,i)};Cl.DefaultMinBounds=Object.freeze(new p(0,-1,-k.PI));Cl.DefaultMaxBounds=Object.freeze(new p(1,1,+k.PI));var sxe=5,lxe=new Array(sxe),rxe=new p,dxe=new ot,cxe=new L,mxe=new L,hxe=new L,cst=new L,pxe=new p,Vxe=new p,uxe=new p,FQt=new Array(8);for(let t=0;t<8;t++)FQt[t]=new p;function WQt(t,e,n){return Math.abs(bt.dot(t,e))<n}function Zxe(t){let e=L.getColumn(t,0,pxe),n=L.getColumn(t,1,Vxe),i=L.getColumn(t,2,uxe),o=k.EPSILON4;return WQt(e,n,o)&&WQt(n,i,o)}function Rxe(t,e){let n=FQt;p.fromElements(-.5,-.5,-.5,n[0]),p.fromElements(-.5,-.5,.5,n[1]),p.fromElements(-.5,.5,-.5,n[2]),p.fromElements(-.5,.5,.5,n[3]),p.fromElements(.5,-.5,-.5,n[4]),p.fromElements(.5,-.5,.5,n[5]),p.fromElements(.5,.5,-.5,n[6]),p.fromElements(.5,.5,.5,n[7]);for(let i=0;i<8;++i)L.multiplyByPoint(t,n[i],n[i]);return ci.fromPoints(n,e)}function mst(t,e,n,i,o,a,s,l){let r=Cl.DefaultMinBounds,d=Cl.DefaultMaxBounds,m=r.x,h=d.x,u=r.y,R=d.y,V=r.z,F=d.z;if(t===m&&e===h&&n===u&&i===R&&o===V&&a===F)return l.center=L.getTranslation(s,l.center),l.halfAxes=L.getMatrix3(s,l.halfAxes),l;a<o&&(a+=k.TWO_PI);let G=a-o,A=o+G*.5,S=lxe,g=0;S[g++]=o,S[g++]=a,S[g++]=A,G>k.PI&&(S[g++]=A-k.PI_OVER_TWO,S[g++]=A+k.PI_OVER_TWO);let C=1,y=1,Y=-1,Q=-1;for(let dt=0;dt<g;++dt){let q=S[dt]-A,at=Math.cos(q),st=Math.sin(q),Et=at*t,Qt=st*t,Wt=at*e,Nt=st*e;C=Math.min(C,Et),y=Math.min(y,Qt),C=Math.min(C,Wt),y=Math.min(y,Nt),Y=Math.max(Y,Et),Q=Math.max(Q,Qt),Y=Math.max(Y,Wt),Q=Math.max(Q,Nt)}let J=Y-C,M=Q-y,Z=i-n,E=(C+Y)*.5,I=(y+Q)*.5,B=(n+i)*.5,X=p.fromElements(E,I,B,rxe),_=ot.fromRotationZ(A,dxe),P=p.fromElements(J,M,Z,fQt),w=L.fromScale(P,hxe),z=L.fromRotation(_,mxe),H=L.fromTranslation(X,cxe),nt=L.multiplyTransformation(z,L.multiplyTransformation(H,w,cst),cst),$=L.multiplyTransformation(s,nt,cst);return Zxe($)?ci.fromTransformation($,l):Rxe($,l)}var vR=Cl;var Jxo=b(W(),1);function AW(){this.orientedBoundingBox=new ci,this.boundingSphere=new Ft,this.boundTransform=new L,this.shapeTransform=new L,this._rectangle=new Gt,this._minimumHeight=AW.DefaultMinBounds.z,this._maximumHeight=AW.DefaultMaxBounds.z,this._ellipsoid=new mt,this._translation=new p,this._rotation=new ot,this.shaderUniforms={ellipsoidRadiiUv:new p,eccentricitySquared:0,evoluteScale:new K,ellipsoidInverseRadiiSquaredUv:new p,ellipsoidRenderLongitudeMinMax:new K,ellipsoidShapeUvLongitudeMinMaxMid:new p,ellipsoidUvToShapeUvLongitude:new K,ellipsoidUvToShapeUvLatitude:new K,ellipsoidRenderLatitudeSinMinMax:new K,ellipsoidInverseHeightDifferenceUv:0,clipMinMaxHeight:new K},this.shaderDefines={ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_EQUAL_ZERO:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_UNDER_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_OVER_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_MIN_DISCONTINUITY:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_MAX_DISCONTINUITY:void 0,ELLIPSOID_HAS_SHAPE_BOUNDS_LONGITUDE:void 0,ELLIPSOID_HAS_SHAPE_BOUNDS_LONGITUDE_MIN_MAX_REVERSED:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_UNDER_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_EQUAL_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_OVER_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_UNDER_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_EQUAL_HALF:void 0,ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_OVER_HALF:void 0,ELLIPSOID_HAS_SHAPE_BOUNDS_LATITUDE:void 0,ELLIPSOID_INTERSECTION_INDEX_LONGITUDE:void 0,ELLIPSOID_INTERSECTION_INDEX_LATITUDE_MAX:void 0,ELLIPSOID_INTERSECTION_INDEX_LATITUDE_MIN:void 0,ELLIPSOID_INTERSECTION_INDEX_HEIGHT_MAX:void 0,ELLIPSOID_INTERSECTION_INDEX_HEIGHT_MIN:void 0},this.shaderMaximumIntersectionsLength=0}var bxe=new p,Wxe=new p,fxe=new p,Fxe=new p,Uxe=new p,Gxe=new p,Axe=new p,Sxe=new p,Txe=new ot,UQt=new p,GQt=new p,gxe=new Gt;AW.prototype.update=function(t,e,n,i,o){let{DefaultMinBounds:a,DefaultMaxBounds:s}=AW;i=f(i,a),o=f(o,s);let l=k.EPSILON10,r=k.EPSILON3,d=k.EPSILON10,m=k.EPSILON10,h=k.EPSILON3,u=L.getScale(t,Sxe),R=p.clone(a,bxe);R.z=-p.minimumComponent(u);let V=p.clamp(e,R,s,Wxe),F=p.clamp(n,R,s,fxe),U=p.clamp(i,R,s,Fxe),G=p.clamp(o,R,s,Uxe),A=p.maximumByComponent(V,U,Gxe),S=p.minimumByComponent(F,G,Axe),g=p.add(u,p.fromElements(F.z,F.z,F.z,UQt),UQt),C=p.maximumComponent(g),y=p.add(u,p.fromElements(S.z,S.z,S.z,GQt),GQt);if(A.y>S.y||A.y===s.y||S.y===a.y||A.z>S.z||k.equalsEpsilon(y,p.ZERO,void 0,l))return!1;this._rectangle=Gt.fromRadians(V.x,V.y,F.x,F.y),this._translation=L.getTranslation(t,this._translation),this._rotation=L.getRotation(t,this._rotation),this._ellipsoid=mt.fromCartesian3(u,this._ellipsoid),this._minimumHeight=V.z,this._maximumHeight=F.z;let Y=Gt.fromRadians(A.x,A.y,S.x,S.y,gxe);this.orientedBoundingBox=hst(Y,A.z,S.z,this._ellipsoid,this._translation,this._rotation,this.orientedBoundingBox),this.shapeTransform=L.fromRotationTranslation(ot.setScale(this._rotation,g,Txe),this._translation,this.shapeTransform),this.boundTransform=L.fromRotationTranslation(this.orientedBoundingBox.halfAxes,this.orientedBoundingBox.center,this.boundTransform),this.boundingSphere=Ft.fromOrientedBoundingBox(this.orientedBoundingBox,this.boundingSphere);let Q=s.x-a.x,J=.5*Q,M=S.x<A.x,Z=S.x-A.x+M*Q,E=Z<=d,I=Z>=J-d&&Z<Q-d,B=Z>d&&Z<J-d,X=E||I||B,_=F.x<V.x,P=F.x-V.x+_*Q,w=P>J+d&&P<Q-d,z=P>=J-d&&P<=J+d,H=P<J-d,nt=w||z||H,$=S.y<-h,dt=S.y>=-h&&S.y<=+h,q=S.y>+h&&S.y<s.y-m,at=$||dt||q,st=A.y>a.y+m&&A.y<-h,Et=A.y>=-h&&A.y<=+h,Qt=A.y>+h,Wt=st||Et||Qt,Nt=at||Wt,kt=F.y-V.y,Mt=F.y<-h,qt=F.y>=-h&&F.y<=+h,ie=F.y>+h&&F.y<s.y-m,oe=Mt||qt||ie,He=V.y>a.y+m&&V.y<-h,rn=V.y>=-h&&V.y<=+h,de=V.y>+h,ke=oe||(He||rn||de),{shaderUniforms:Ve,shaderDefines:We}=this;for(let oo in We)We.hasOwnProperty(oo)&&(We[oo]=void 0);Ve.ellipsoidRadiiUv=p.divideByScalar(g,C,Ve.ellipsoidRadiiUv);let{x:Vn,z:Ct}=Ve.ellipsoidRadiiUv,_t=Ct/Vn;Ve.eccentricitySquared=1-_t*_t,Ve.evoluteScale=K.fromElements((Vn*Vn-Ct*Ct)/Vn,(Ct*Ct-Vn*Vn)/Ct,Ve.evoluteScale),Ve.ellipsoidInverseRadiiSquaredUv=p.divideComponents(p.ONE,p.multiplyComponents(Ve.ellipsoidRadiiUv,Ve.ellipsoidRadiiUv,Ve.ellipsoidInverseRadiiSquaredUv),Ve.ellipsoidInverseRadiiSquaredUv);let Je=0;We.ELLIPSOID_INTERSECTION_INDEX_HEIGHT_MAX=Je,Je+=1,We.ELLIPSOID_INTERSECTION_INDEX_HEIGHT_MIN=Je,Je+=1,Ve.clipMinMaxHeight=K.fromElements((A.z-F.z)/C,(S.z-F.z)/C,Ve.clipMinMaxHeight);let xe=(F.z-V.z)/C;if(Ve.ellipsoidInverseHeightDifferenceUv=1/xe,V.z===F.z&&(Ve.ellipsoidInverseHeightDifferenceUv=0),X&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE=!0,We.ELLIPSOID_INTERSECTION_INDEX_LONGITUDE=Je,I?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_UNDER_HALF=!0,Je+=1):B?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_OVER_HALF=!0,Je+=2):E&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_RANGE_EQUAL_ZERO=!0,Je+=2),Ve.ellipsoidRenderLongitudeMinMax=K.fromElements(A.x,S.x,Ve.ellipsoidRenderLongitudeMinMax)),nt)if(We.ELLIPSOID_HAS_SHAPE_BOUNDS_LONGITUDE=!0,F.x<V.x&&(We.ELLIPSOID_HAS_SHAPE_BOUNDS_LONGITUDE_MIN_MAX_REVERSED=!0),P<=d)Ve.ellipsoidUvToShapeUvLongitude=K.fromElements(0,1,Ve.ellipsoidUvToShapeUvLongitude);else{let ea=Q/P,gs=-(V.x-a.x)/P;Ve.ellipsoidUvToShapeUvLongitude=K.fromElements(ea,gs,Ve.ellipsoidUvToShapeUvLongitude)}if(X){let oo=k.equalsEpsilon(A.x,a.x,void 0,r),ea=k.equalsEpsilon(S.x,s.x,void 0,r);oo&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_MIN_DISCONTINUITY=!0),ea&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LONGITUDE_MAX_DISCONTINUITY=!0);let gs=(V.x-a.x)/Q,is=(F.x-a.x)/Q,ja=(S.x-a.x)/Q,qn=1-Z/Q,ae=(ja+.5*qn)%1;Ve.ellipsoidShapeUvLongitudeMinMaxMid=p.fromElements(gs,is,ae,Ve.ellipsoidShapeUvLongitudeMinMaxMid)}if(Nt&&(Wt&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN=!0,We.ELLIPSOID_INTERSECTION_INDEX_LATITUDE_MIN=Je,st?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_UNDER_HALF=!0,Je+=1):Et?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_EQUAL_HALF=!0,Je+=1):Qt&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MIN_OVER_HALF=!0,Je+=2)),at&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX=!0,We.ELLIPSOID_INTERSECTION_INDEX_LATITUDE_MAX=Je,$?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_UNDER_HALF=!0,Je+=2):dt?(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_EQUAL_HALF=!0,Je+=1):q&&(We.ELLIPSOID_HAS_RENDER_BOUNDS_LATITUDE_MAX_OVER_HALF=!0,Je+=1)),Ve.ellipsoidRenderLatitudeSinMinMax=K.fromElements(Math.sin(A.y),Math.sin(S.y),Ve.ellipsoidRenderLatitudeSinMinMax)),ke)if(We.ELLIPSOID_HAS_SHAPE_BOUNDS_LATITUDE=!0,kt<m)Ve.ellipsoidUvToShapeUvLatitude=K.fromElements(0,1,Ve.ellipsoidUvToShapeUvLatitude);else{let ea=(s.y-a.y)/kt,gs=(a.y-V.y)/kt;Ve.ellipsoidUvToShapeUvLatitude=K.fromElements(ea,gs,Ve.ellipsoidUvToShapeUvLatitude)}return this.shaderMaximumIntersectionsLength=Je,!0};var TQt=new Gt;AW.prototype.computeOrientedBoundingBoxForTile=function(t,e,n,i,o){let a=1/Math.pow(2,t),s=e*a,l=(e+1)*a,r=n*a,d=(n+1)*a,m=i*a,h=(i+1)*a,u=Gt.subsection(this._rectangle,s,r,l,d,TQt),R=k.lerp(this._minimumHeight,this._maximumHeight,m),V=k.lerp(this._minimumHeight,this._maximumHeight,h);return hst(u,R,V,this._ellipsoid,this._translation,this._rotation,o)};var AQt=new p,SQt=new p,Exe=new p;AW.prototype.computeOrientedBoundingBoxForSample=function(t,e,n,i){let o=1/Math.pow(2,t.level),a=p.divideComponents(p.ONE,e,AQt),s=p.multiplyByScalar(a,o,AQt),l=p.multiplyByScalar(p.fromElements(t.x+n.x,t.y+n.y,t.z+n.z,SQt),o,SQt),r=p.add(l,s,Exe),d=Gt.subsection(this._rectangle,l.x,l.y,r.x,r.y,TQt),m=k.lerp(this._minimumHeight,this._maximumHeight,l.z),h=k.lerp(this._minimumHeight,this._maximumHeight,r.z);return hst(d,m,h,this._ellipsoid,this._translation,this._rotation,i)};function hst(t,e,n,i,o,a,s){return s=ci.fromRectangle(t,e,n,i,s),s.center=p.add(s.center,o,s.center),s.halfAxes=ot.multiply(s.halfAxes,a,s.halfAxes),s}AW.DefaultMinBounds=Object.freeze(new p(-k.PI,-k.PI_OVER_TWO,-mt.WGS84.minimumRadius));AW.DefaultMaxBounds=Object.freeze(new p(k.PI,k.PI_OVER_TWO,10*mt.WGS84.maximumRadius));var YT=AW;var dp={BOX:"BOX",ELLIPSOID:"ELLIPSOID",CYLINDER:"CYLINDER"};dp.getMinBounds=function(t){switch(t){case dp.BOX:return PR.DefaultMinBounds;case dp.ELLIPSOID:return YT.DefaultMinBounds;case dp.CYLINDER:return vR.DefaultMinBounds}};dp.getMaxBounds=function(t){switch(t){case dp.BOX:return PR.DefaultMaxBounds;case dp.ELLIPSOID:return YT.DefaultMaxBounds;case dp.CYLINDER:return vR.DefaultMaxBounds}};dp.getShapeConstructor=function(t){switch(t){case dp.BOX:return PR;case dp.ELLIPSOID:return YT;case dp.CYLINDER:return vR}};var _o=Object.freeze(dp);var HXo=b(W(),1);var vxo=b(W(),1);function hZ(t){this._comparator=t.comparator,this._maximumLength=t.maximumLength,this._array=c(t.maximumLength)?new Array(t.maximumLength):[],this._length=0}Object.defineProperties(hZ.prototype,{length:{get:function(){return this._length}},maximumLength:{get:function(){return this._maximumLength},set:function(t){if(c(t)){for(;this._length>t;)this.removeMinimum();this._array.length=t}this._maximumLength=t}},internalArray:{get:function(){return this._array}},comparator:{get:function(){return this._comparator}}});hZ.prototype.clone=function(){let t=this._maximumLength,e=this._comparator,n=this._array,i=this._length,o=new hZ({comparator:e,maximumLength:t});o._length=i;for(let a=0;a<i;a++)o._array[a]=n[a];return o};hZ.prototype.reset=function(){this._length=0;let t=this._maximumLength;if(c(t))for(let e=0;e<t;e++)this._array[e]=void 0;else this._array.length=0};hZ.prototype.resort=function(){let t=this._length;for(let e=0;e<t;e++)gQt(this,e)};hZ.prototype.insert=function(t){let e,n=this._maximumLength;if(c(n)){if(n===0)return;if(this._length===n){let o=this._array[0];if(this._comparator(t,o)<=0)return t;e=this.removeMinimum()}}let i=this._length;return this._array[i]=t,this._length++,gQt(this,i),e};hZ.prototype.removeMinimum=function(){let t=this._length;if(t===0)return;this._length--;let e=this._array[0];return t>=2&&(this._array[0]=this._array[t-1],EQt(this,0)),this._array[t-1]=void 0,e};hZ.prototype.removeMaximum=function(){let t=this._length;if(t===0)return;this._length--;let e;if(t<=2)e=this._array[t-1];else{let n=pst(this,1,2)?1:2;e=this._array[n],this._array[n]=this._array[t-1],t>=4&&EQt(this,n)}return this._array[t-1]=void 0,e};hZ.prototype.getMinimum=function(){if(this._length!==0)return this._array[0]};hZ.prototype.getMaximum=function(){let t=this._length;if(t!==0)return t<=2?this._array[t-1]:this._array[pst(this,1,2)?1:2]};function Tj(t,e,n){let i=t._array,o=i[e];i[e]=i[n],i[n]=o}function $9(t,e,n){return t._comparator(t._array[e],t._array[n])<0}function pst(t,e,n){return t._comparator(t._array[e],t._array[n])>0}function gQt(t,e){if(e===0)return;let n=Math.floor(k.log2(e+1))%2===0,i=Math.floor((e-1)/2),o=$9(t,e,i);for(o!==n&&(Tj(t,e,i),e=i);e>=3;){let a=Math.floor((e-3)/4);if($9(t,e,a)!==o)break;Tj(t,e,a),e=a}}function EQt(t,e){let n=t._length,i=Math.floor(k.log2(e+1))%2===0,o;for(;(o=2*e+1)<n;){let a=o,s=o+1;if(s<n){$9(t,s,a)===i&&(a=s);let l=2*o+1,r=Math.max(Math.min(n-l,4),0);for(let d=0;d<r;d++){let m=l+d;$9(t,m,a)===i&&(a=m)}}if($9(t,a,e)===i&&(Tj(t,a,e),a!==o&&a!==s)){let l=Math.floor((a-1)/2);pst(t,a,l)===i&&Tj(t,a,l)}e=a}}var xT=hZ;var zxo=b(W(),1),CQt=Object.freeze({UNLOADED:0,RECEIVING:1,RECEIVED:2,LOADED:3,FAILED:4,UNAVAILABLE:5});function gj(t,e){this.spatialNode=t,this.keyframe=e,this.state=CQt.UNLOADED,this.metadata=[],this.megatextureIndex=-1,this.priority=-Number.MAX_VALUE,this.highPriorityFrameNumber=-1}gj.priorityComparator=function(t,e){return t.priority-e.priority};gj.searchComparator=function(t,e){return t.keyframe-e.keyframe};gj.LoadState=CQt;var ra=gj;var ZXo=b(W(),1);function AU(t,e,n,i,o){i===vn.UNSIGNED_SHORT&&(i=vn.FLOAT32);let a=t.floatingPointTexture;if(i===vn.FLOAT32&&!a)throw new Tt("Floating point texture not supported");let s;i===vn.FLOAT32||i===vn.FLOAT64?s=Ue.FLOAT:i===vn.UINT8&&(s=Ue.UNSIGNED_BYTE);let l;n===1?l=t.webgl2?Ye.RED:Ye.LUMINANCE:n===2?l=t.webgl2?Ye.RG:Ye.LUMINANCE_ALPHA:n===3?l=Ye.RGB:n===4&&(l=Ye.RGBA);let r=512*1024*1024,d=128*1024*1024;o=Math.min(f(o,d),r);let m=Tn.maximumTextureSize,h=vn.getSizeInBytes(i),u=Math.floor(o/(n*h)),R=Math.min(m,k.previousPowerOfTwo(Math.floor(Math.sqrt(u)))),V=Math.ceil(Math.sqrt(e.x)),F=Math.ceil(e.z/V),U=V*e.x,G=F*e.y,A=Math.floor(R/U),S=Math.floor(R/G);if(A===0||S===0)throw new Tt("Tileset is too large to fit into megatexture");this.channelCount=n,this.componentType=i,this.voxelCountPerTile=p.clone(e,new p),this.maximumTileCount=A*S,this.regionCountPerMegatexture=new K(A,S),this.voxelCountPerRegion=new K(U,G),this.sliceCountPerRegion=new K(V,F),this.voxelSizeUv=new K(1/R,1/R),this.sliceSizeUv=new K(e.x/R,e.y/R),this.regionSizeUv=new K(U/R,G/R),this.texture=new hn({context:t,pixelFormat:l,pixelDatatype:s,flipY:!1,width:R,height:R,sampler:new Hn({wrapS:Zi.CLAMP_TO_EDGE,wrapT:Zi.CLAMP_TO_EDGE,minificationFilter:On.LINEAR,magnificationFilter:Ro.LINEAR})});let g=vn.toComponentDatatype(i);this.tileVoxelDataTemp=it.createTypedArray(g,U*G*n),this.nodes=new Array(this.maximumTileCount);for(let C=0;C<this.maximumTileCount;C++)this.nodes[C]=new Cxe(C);for(let C=0;C<this.maximumTileCount;C++){let y=this.nodes[C];y.previousNode=C>0?this.nodes[C-1]:void 0,y.nextNode=C<this.maximumTileCount-1?this.nodes[C+1]:void 0}this.occupiedList=void 0,this.emptyList=this.nodes[0],this.occupiedCount=0}function Cxe(t){this.index=t,this.nextNode=void 0,this.previousNode=void 0}AU.prototype.add=function(t){if(this.isFull())throw new Ut("Trying to add when there are no empty spots");let e=this.emptyList;this.emptyList=this.emptyList.nextNode,c(this.emptyList)&&(this.emptyList.previousNode=void 0),e.nextNode=this.occupiedList,c(e.nextNode)&&(e.nextNode.previousNode=e),this.occupiedList=e;let n=e.index;return this.writeDataToTexture(n,t),this.occupiedCount++,n};AU.prototype.remove=function(t){if(t<0||t>=this.maximumTileCount)throw new Ut("Megatexture index out of bounds");let e=this.nodes[t];c(e.previousNode)&&(e.previousNode.nextNode=e.nextNode),c(e.nextNode)&&(e.nextNode.previousNode=e.previousNode),e.nextNode=this.emptyList,c(e.nextNode)&&(e.nextNode.previousNode=e),e.previousNode=void 0,this.emptyList=e,this.occupiedCount--};AU.prototype.isFull=function(){return this.emptyList===void 0};AU.getApproximateTextureMemoryByteLength=function(t,e,n,i){i===vn.UNSIGNED_SHORT&&(i=vn.FLOAT32);let o=vn.getSizeInBytes(i),a=t*e.x*e.y*e.z,s=Math.ceil(Math.sqrt(e.x)),l=Math.ceil(e.z/s),r=s*e.x,d=l*e.y,m=k.previousPowerOfTwo(Math.floor(Math.sqrt(a)));for(;;){let u=Math.floor(m/r),R=Math.floor(m/d);if(u*R>=t)break;m*=2}return m*m*n*o};AU.prototype.writeDataToTexture=function(t,e){let n=e.constructor===Uint16Array?new Float32Array(e):e,i=this.voxelCountPerTile,o=this.sliceCountPerRegion,a=this.voxelCountPerRegion,s=this.channelCount,l=this.tileVoxelDataTemp;for(let F=0;F<i.z;F++){let U=F%o.x*i.x,G=Math.floor(F/o.x)*i.y;for(let A=0;A<i.y;A++)for(let S=0;S<i.x;S++){let g=F*i.y*i.x+A*i.x+S,C=(G+A)*a.x+(U+S);for(let y=0;y<s;y++)l[C*s+y]=n[g*s+y]}}let r=this.regionCountPerMegatexture,d=a.x,m=a.y,h=t%r.x*a.x,u=Math.floor(t/r.x)*a.y,V={source:{arrayBufferView:l,width:d,height:m},xOffset:h,yOffset:u};this.texture.copyFrom(V)};AU.prototype.isDestroyed=function(){return!1};AU.prototype.destroy=function(){return this.texture=this.texture&&this.texture.destroy(),At(this)};var P1=AU;var TXo=b(W(),1);function BV(t,e,n,i,o,a,s){this.children=void 0,this.parent=o,this.level=t,this.x=e,this.y=n,this.z=i,this.dimensions=p.clone(s),this.keyframeNodes=[],this.renderableKeyframeNodes=[],this.renderableKeyframeNodeLerp=0,this.renderableKeyframeNodePrevious=void 0,this.renderableKeyframeNodeNext=void 0,this.orientedBoundingBox=new ci,this.approximateVoxelSize=0,this.screenSpaceError=0,this.visitedFrameNumber=-1,this.computeBoundingVolumes(a)}var Ixe=new p;BV.prototype.computeBoundingVolumes=function(t){this.orientedBoundingBox=t.computeOrientedBoundingBoxForTile(this.level,this.x,this.y,this.z,this.orientedBoundingBox);let e=ot.getScale(this.orientedBoundingBox.halfAxes,Ixe),n=2*p.maximumComponent(e);this.approximateVoxelSize=n/p.minimumComponent(this.dimensions)};BV.prototype.constructChildNodes=function(t){let{level:e,x:n,y:i,z:o}=this,a=n*2,s=i*2,l=o*2,r=s+1,d=a+1,m=l+1,h=e+1,u=[[h,a,s,l],[h,d,s,l],[h,a,r,l],[h,d,r,l],[h,a,s,m],[h,d,s,m],[h,a,r,m],[h,d,r,m]];this.children=u.map(([R,V,F,U])=>new BV(R,V,F,U,this,t,this.dimensions))};BV.prototype.visibility=function(t,e){let n=this.orientedBoundingBox;return t.cullingVolume.computeVisibilityWithPlaneMask(n,e)};BV.prototype.computeScreenSpaceError=function(t,e){let n=this.orientedBoundingBox,i=Math.sqrt(n.distanceSquaredTo(t));i=Math.max(i,k.EPSILON7);let o=this.approximateVoxelSize,a=e*(o/i);this.screenSpaceError=a};var IQt={keyframe:0};function t5(t,e){return IQt.keyframe=t,Ja(e,IQt,ra.searchComparator)}BV.prototype.computeSurroundingRenderableKeyframeNodes=function(t){let e=this,n=e.level,i=Math.floor(t),o=Math.ceil(t),a,s,l=+Number.MAX_VALUE,r=+Number.MAX_VALUE;for(;c(e);){let{renderableKeyframeNodes:h}=e;if(h.length>=1){let u=Nxe(i,h),R=h[u],V=o===i||i<R.keyframe?u:Math.min(u+1,h.length-1),F=h[V],U=i-R.keyframe,G=NQt(n-e.level,U);G<l&&(l=G,a=R);let A=F.keyframe-o,S=NQt(n-e.level,A);if(S<r&&(r=S,s=F),U===0&&A===0)break}e=e.parent}if(this.renderableKeyframeNodePrevious=a,this.renderableKeyframeNodeNext=s,!c(a)||!c(s))return;let d=a.keyframe,m=s.keyframe;this.renderableKeyframeNodeLerp=d===m?0:k.clamp((t-d)/(m-d),0,1)};function Nxe(t,e){let n=t5(t,e);return n<0?k.clamp(~n-1,0,e.length-1):n}function NQt(t,e){let n=Math.exp(t*4),i=e>=0?1:-200;return t*n+e*i}BV.prototype.isVisited=function(t){return this.visitedFrameNumber===t};BV.prototype.createKeyframeNode=function(t){let e=t5(t,this.keyframeNodes);if(e<0){e=~e;let n=new ra(this,t);this.keyframeNodes.splice(e,0,n)}};BV.prototype.destroyKeyframeNode=function(t,e){let n=t.keyframe,i=t5(n,this.keyframeNodes);if(i<0)throw new Ut("Keyframe node does not exist.");if(this.keyframeNodes.splice(i,1),t.megatextureIndex!==-1){for(let a=0;a<e.length;a++)e[a].remove(t.megatextureIndex);let o=t5(n,this.renderableKeyframeNodes);if(o<0)throw new Ut("Renderable keyframe node does not exist.");this.renderableKeyframeNodes.splice(o,1)}t.spatialNode=void 0,t.state=ra.LoadState.UNLOADED,t.metadata={},t.megatextureIndex=-1,t.priority=-Number.MAX_VALUE,t.highPriorityFrameNumber=-1};BV.prototype.addKeyframeNodeToMegatextures=function(t,e){if(t.state!==ra.LoadState.RECEIVED||t.megatextureIndex!==-1||t.metadata.length!==e.length)throw new Ut("Keyframe node cannot be added to megatexture");for(let o=0;o<e.length;o++){let a=e[o];t.megatextureIndex=a.add(t.metadata[o])}t.state=ra.LoadState.LOADED;let n=this.renderableKeyframeNodes,i=t5(t.keyframe,n);if(i>=0)throw new Ut("Keyframe already renderable");i=~i,n.splice(i,0,t)};BV.prototype.isRenderable=function(t){let e=this.renderableKeyframeNodePrevious,n=this.renderableKeyframeNodeNext,i=this.level;return c(e)&&c(n)&&(e.spatialNode.level===i||n.spatialNode.level===i)&&this.visitedFrameNumber===t};var e5=BV;function SW(t,e,n,i,o,a,s){this._primitive=t,this.megatextures=new Array(i.length);for(let V=0;V<i.length;V++){let F=i[V],U=Nn.getComponentCount(F),G=o[V];this.megatextures[V]=new P1(e,n,U,G,s)}let l=this.megatextures[0].maximumTileCount;this._simultaneousRequestCount=0,this._debugPrint=!1,this._frameNumber=0;let r=t._shape;this.rootNode=new e5(0,0,0,0,void 0,r,n),this._priorityQueue=new xT({maximumLength:l,comparator:ra.priorityComparator}),this._highPriorityKeyframeNodes=new Array(l),this._keyframeNodesInMegatexture=new Array(l),this._keyframeCount=a,this._sampleCount=void 0,this._keyframeLocation=0,this._binaryTreeKeyframeWeighting=new Array(a);let d=this._binaryTreeKeyframeWeighting;d[0]=0,d[a-1]=0,Vst(d,1,a-2,0);let m=9,h=2048,u=Math.floor(h/m),R=Math.ceil(l/u);this.internalNodeTexture=new hn({context:e,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,flipY:!1,width:h,height:R,sampler:new Hn({minificationFilter:On.NEAREST,magnificationFilter:Ro.NEAREST})}),this.internalNodeTilesPerRow=u,this.internalNodeTexelSizeUv=new K(1/h,1/R),this.leafNodeTexture=void 0,this.leafNodeTilesPerRow=void 0,this.leafNodeTexelSizeUv=new K}SW.prototype.findKeyframeNode=function(t){return this._keyframeNodesInMegatexture.find(function(e){return e.megatextureIndex===t})};function Vst(t,e,n,i){if(e>n)return;let o=Math.floor((e+n)/2);t[o]=i,Vst(t,e,o-1,i+1),Vst(t,o+1,n,i+1)}SW.simultaneousRequestCountMaximum=50;SW.prototype.update=function(t,e,n,i){let o=this._primitive,a=t.context,s=this.megatextures[0].maximumTileCount,l=this._keyframeCount,r=o._levelBlendFactor,d=r>0,m=l>1,h=(d?2:1)*(m?2:1);this._sampleCount=h;let u=h>=2;if(u&&!c(this.leafNodeTexture)){let A=Math.floor(512),S=Math.ceil(s/A);this.leafNodeTexture=new hn({context:a,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,flipY:!1,width:1024,height:S,sampler:new Hn({minificationFilter:On.NEAREST,magnificationFilter:Ro.NEAREST})}),this.leafNodeTexelSizeUv=K.fromElements(1/1024,1/S,this.leafNodeTexelSizeUv),this.leafNodeTilesPerRow=A}else!u&&c(this.leafNodeTexture)&&(this.leafNodeTexture=this.leafNodeTexture.destroy());if(this._keyframeLocation=k.clamp(e,0,l-1),n&&yQt(this,this.rootNode),i)return;this._frameNumber=t.frameNumber;let R=Oi();Qxe(this,t);let V=Oi();xxe(this,h,r);let F=Oi();if(this._debugPrint){let U=V-R,G=F-V,A=F-R;Yxe(this,U,G,A)}};SW.prototype.isRenderable=function(t){return t.isRenderable(this._frameNumber)};SW.prototype.isDestroyed=function(){return!1};SW.prototype.destroy=function(){let t=this.megatextures,e=t.length;for(let n=0;n<e;n++)t[n]=t[n]&&t[n].destroy();return this.internalNodeTexture=this.internalNodeTexture&&this.internalNodeTexture.destroy(),this.leafNodeTexture=this.leafNodeTexture&&this.leafNodeTexture.destroy(),At(this)};function yQt(t,e){if(e.computeBoundingVolumes(t._primitive._shape),c(e.children))for(let n=0;n<8;n++){let i=e.children[n];yQt(t,i)}}function yxe(t,e){if(t._simultaneousRequestCount>=SW.simultaneousRequestCountMaximum)return;let n=t._primitive._provider;function i(r){t._simultaneousRequestCount--;let d=n.types.length;if(!c(r))e.state=ra.LoadState.UNAVAILABLE;else if(r===ra.LoadState.FAILED)e.state=ra.LoadState.FAILED;else if(!Array.isArray(r)||r.length!==d)e.state=ra.LoadState.FAILED;else{let m=t.megatextures;for(let h=0;h<d;h++){let{voxelCountPerTile:u,channelCount:R}=m[h],{x:V,y:F,z:U}=u,G=V*F*U,A=r[h],S=G*R;if(A.length===S)e.metadata[h]=A,e.state=ra.LoadState.RECEIVED;else{e.state=ra.LoadState.FAILED;break}}}}function o(){t._simultaneousRequestCount--,e.state=ra.LoadState.FAILED}let{keyframe:a,spatialNode:s}=e,l=n.requestData({tileLevel:s.level,tileX:s.x,tileY:s.y,tileZ:s.z,keyframe:a});c(l)?(t._simultaneousRequestCount++,e.state=ra.LoadState.RECEIVING,l.then(i).catch(o)):e.state=ra.LoadState.FAILED}function Bxe(t){return t/(1+t)}function Qxe(t,e){let n=t._frameNumber,i=t._primitive,o=i._shape,a=i.screenSpaceError,s=t._priorityQueue,l=t._keyframeCount,r=k.clamp(Math.floor(t._keyframeLocation),0,l-2),d=r+1,{camera:m,context:h,pixelRatio:u}=e,{positionWC:R,frustum:V}=m,U=h.drawingBufferHeight/u/V.sseDenominator;function G(M,Z){if(M.computeScreenSpaceError(R,U),Z=M.visibility(e,Z),Z===Jl.MASK_OUTSIDE)return;if(M.visitedFrameNumber=n,l===1)M.createKeyframeNode(0);else if(M.keyframeNodes.length!==l)for(let _=0;_<l;_++)M.createKeyframeNode(_);let{screenSpaceError:E,keyframeNodes:I}=M,B=Bxe(E),X=!1;for(let _=0;_<I.length;_++){let P=I[_];P.priority=10*B+kxe(r,P.keyframe,d,t),P.state!==ra.LoadState.UNAVAILABLE&&P.state!==ra.LoadState.FAILED&&P.priority!==-Number.MAX_VALUE&&s.insert(P),P.state===ra.LoadState.LOADED&&(X=!0)}if(E<a||!X){M.children=void 0;return}c(M.children)||M.constructChildNodes(o);for(let _=0;_<8;_++){let P=M.children[_];G(P,Z)}}s.reset(),G(t.rootNode,Jl.MASK_INDETERMINATE);let A=t._highPriorityKeyframeNodes,S=0,g;for(;s.length>0;)g=s.removeMaximum(),g.highPriorityFrameNumber=n,A[S]=g,S++;let C=t._keyframeNodesInMegatexture,y=t.megatextures[0],Y=y.occupiedCount;C.length=Y,C.sort(function(M,Z){return M.highPriorityFrameNumber===Z.highPriorityFrameNumber?Z.priority-M.priority:Z.highPriorityFrameNumber-M.highPriorityFrameNumber});let Q=0,J=0;for(let M=0;M<S;M++)if(g=A[M],!(g.state===ra.LoadState.LOADED||g.spatialNode===void 0)&&(g.state===ra.LoadState.UNLOADED&&yxe(t,g),g.state===ra.LoadState.RECEIVED)){let Z=0;if(y.isFull()){Z=Y-1-Q,Q++;let E=C[Z];E.spatialNode.destroyKeyframeNode(E,t.megatextures)}else Z=Y+J,J++;g.spatialNode.addKeyframeNodeToMegatextures(g,t.megatextures),C[Z]=g}}function kxe(t,e,n,i){let o=Math.min(Math.abs(e-t),Math.abs(e-n)),a=Math.max(t,i._keyframeCount-n-1,1),s=Math.pow(1-o/a,4),l=Math.exp(-i._binaryTreeKeyframeWeighting[e]);return k.lerp(l,s,.15+.85*s)}function Yxe(t,e,n,i){let o=t._keyframeCount,a=t.rootNode,s=Object.keys(ra.LoadState).length,l=new Array(s),r=new Array(s),d=0;for(let G=0;G<s;G++){let A=new Array(o);l[G]=A;for(let S=0;S<o;S++)A[S]=0;r[G]=0}function m(G){let A=G.keyframeNodes;for(let S=0;S<A.length;S++){let g=A[S],C=g.keyframe,y=g.state;l[y][C]+=1,r[y]+=1,d++}if(c(G.children))for(let S=0;S<8;S++){let g=G.children[S];m(g)}}m(a);let h=`KEYFRAMES: ${l[ra.LoadState.LOADED]}`,u=`UNLOADED: ${r[ra.LoadState.UNLOADED]} | RECEIVING: ${r[ra.LoadState.RECEIVING]} | RECEIVED: ${r[ra.LoadState.RECEIVED]} | LOADED: ${r[ra.LoadState.LOADED]} | FAILED: ${r[ra.LoadState.FAILED]} | UNAVAILABLE: ${r[ra.LoadState.UNAVAILABLE]} | TOTAL: ${d}`,R=Math.round(e*100)/100,V=Math.round(n*100)/100,F=Math.round(i*100)/100,U=`LOAD: ${R} | OCT: ${V} | ALL: ${F}`;console.log(`${h} || ${u} || ${U}`)}var Ej={INTERNAL:0,LEAF:1,PACKED_LEAF_FROM_PARENT:2};function xxe(t,e,n){let i=t._primitive._screenSpaceError,o=t._keyframeLocation,a=t._frameNumber,s=e>=2,l=0,r=0,d=[],m=[];function h(R,V,F,U,G){let A=!1;if(c(R.children))for(let S=0;S<8;S++){let g=R.children[S];g.computeSurroundingRenderableKeyframeNodes(o),g.isRenderable(a)&&(A=!0)}if(A){d[G]=Ej.INTERNAL<<16|V,d[F]=U,l++,U=V,G=U*9+1;for(let S=0;S<8;S++){let g=R.children[S];V=l,F=V*9+0,h(g,V,F,U,G+S)}}else{if(s){let S=r*5,g=R.renderableKeyframeNodePrevious,C=R.level-g.spatialNode.level,y=g.spatialNode.parent,Y=c(y)?y.renderableKeyframeNodePrevious:g,Q=Xxe(R,i,n),J=C,M=1,Z=g.megatextureIndex,E=Y.megatextureIndex;m[S+0]=Q,m[S+1]=J,m[S+2]=M,m[S+3]=Z,m[S+4]=E,d[G]=Ej.LEAF<<16|r}else{let S=R.renderableKeyframeNodePrevious,C=R.level-S.spatialNode.level===0?Ej.LEAF:Ej.PACKED_LEAF_FROM_PARENT;d[G]=C<<16|S.megatextureIndex}r++}}let u=t.rootNode;u.computeSurroundingRenderableKeyframeNodes(o),u.isRenderable(a)&&h(u,0,0,0,0),Jxe(d,9,t.internalNodeTilesPerRow,t.internalNodeTexture),s&&Lxe(m,2,t.leafNodeTilesPerRow,t.leafNodeTexture)}function Xxe(t,e,n){if(t.parent===void 0)return 0;let i=t.screenSpaceError,o=t.parent.screenSpaceError,s=((e-i)/(o-i)+n-1)/n;return k.clamp(s,0,1)}function Jxe(t,e,n,i){let o=Ye.componentsLength(i.pixelFormat),a=Math.ceil(t.length/e),s=Math.max(1,e*Math.min(a,n)),l=Math.max(1,Math.ceil(a/n)),r=new Uint8Array(s*l*o);for(let h=0;h<t.length;h++){let u=t[h],R=h*o;for(let V=0;V<o;V++)r[R+V]=u>>>V*8&255}let m={source:{arrayBufferView:r,width:s,height:l},xOffset:0,yOffset:0};i.copyFrom(m)}function Lxe(t,e,n,i){let o=Ye.componentsLength(i.pixelFormat),a=5,s=Math.ceil(t.length/a),l=Math.max(1,e*Math.min(s,n)),r=Math.max(1,Math.ceil(s/n)),d=new Uint8Array(l*r*o);for(let u=0;u<s;u++){let R=t[u*a+0],V=t[u*a+1],F=t[u*a+2],U=t[u*a+3],G=t[u*a+4],A=k.clamp(Math.floor(65536*R),0,65535);d[u*8+0]=A>>>0&255,d[u*8+1]=A>>>8&255,d[u*8+2]=V&255,d[u*8+3]=F&255,d[u*8+4]=U>>>0&255,d[u*8+5]=U>>>8&255,d[u*8+6]=G>>>0&255,d[u*8+7]=G>>>8&255}let h={source:{arrayBufferView:d,width:l,height:r},xOffset:0,yOffset:0};i.copyFrom(h)}SW.getApproximateTextureMemoryByteLength=function(t,e,n,i){let o=0,a=n.length;for(let s=0;s<a;s++){let l=n[s],r=i[s],d=Nn.getComponentCount(l);o+=P1.getApproximateTextureMemoryByteLength(t,e,d,r)}return o};var v1=SW;var ZJo=b(W(),1);var PXo=b(W(),1),Mxe={FLOAT:"float",VEC2:"vec2",VEC3:"vec3",VEC4:"vec4",INT:"int",INT_VEC2:"ivec2",INT_VEC3:"ivec3",INT_VEC4:"ivec4",BOOL:"bool",BOOL_VEC2:"bvec2",BOOL_VEC3:"bvec3",BOOL_VEC4:"bvec4",MAT2:"mat2",MAT3:"mat3",MAT4:"mat4",SAMPLER_2D:"sampler2D",SAMPLER_CUBE:"samplerCube"},K1=Object.freeze(Mxe);var sJo=b(W(),1);var KXo=b(W(),1);function _xe(t,e,n){let i=new Uint8ClampedArray(t.buffer),o=new ImageData(i,e,n),a=document.createElement("canvas");return a.width=e,a.height=n,a.getContext("2d").putImageData(o,0,0),a}var n5=_xe;function z1(){this._defaultTexture=void 0,this._textures={},this._loadedImages=[],this._lastUpdatedFrame=-1}z1.prototype.getTexture=function(t){return this._textures[t]};function Dxe(t,e,n){n.resource.fetchImage().then(function(i){t._loadedImages.push({id:e,image:i,textureUniform:n})}).catch(function(){let i=t._textures[e];c(i)&&i!==t._defaultTexture&&i.destroy(),t._textures[e]=t._defaultTexture})}z1.prototype.loadTexture2D=function(t,e){c(e.typedArray)?this._loadedImages.push({id:t,textureUniform:e}):Dxe(this,t,e)};function Oxe(t,e,n){let{id:i,textureUniform:o,image:a}=e,s=n.webgl2?Cj(o,a,n):Hxe(o,a,n),l=t._textures[i];c(l)&&l!==n.defaultTexture&&l.destroy(),t._textures[i]=s}function Cj(t,e,n){let{typedArray:i,sampler:o}=t,a=c(i)?QQt(t,n):new hn({context:n,source:e,sampler:o});return BQt(o)&&a.generateMipmap(),a}function Hxe(t,e,n){let{typedArray:i,sampler:o}=t,a=BQt(o),s=o.wrapS===Zi.REPEAT||o.wrapS===Zi.MIRRORED_REPEAT||o.wrapT===Zi.REPEAT||o.wrapT===Zi.MIRRORED_REPEAT,{width:l,height:r}=c(i)?t:e,d=[l,r].every(k.isPowerOfTwo);if((a||s)&&!d)if(c(i)){if(t.pixelDatatype===Ue.UNSIGNED_BYTE){let h=n5(i,l,r),u=_f(h);return Cj({sampler:o},u,n)}}else{let h=_f(e);return Cj(t,h,n)}else return Cj(t,e,n);return a?console.warn("Texture requires resizing for mipmaps but pixelDataType cannot be resized. The texture may be rendered incorrectly."):s&&console.warn("Texture requires resizing for wrapping but pixelDataType cannot be resized. The texture may be rendered incorrectly."),QQt(t,n)}function BQt(t){return[On.NEAREST_MIPMAP_NEAREST,On.NEAREST_MIPMAP_LINEAR,On.LINEAR_MIPMAP_NEAREST,On.LINEAR_MIPMAP_LINEAR].includes(t.minificationFilter)}function QQt(t,e){let{pixelFormat:n,pixelDatatype:i,width:o,height:a,typedArray:s,sampler:l}=t;return new hn({context:e,pixelFormat:n,pixelDatatype:i,source:{arrayBufferView:s,width:o,height:a},sampler:l,flipY:!1})}z1.prototype.update=function(t){if(t.frameNumber===this._lastUpdatedFrame)return;this._lastUpdatedFrame=t.frameNumber;let e=t.context;this._defaultTexture=e.defaultTexture;let n=this._loadedImages;for(let i=0;i<n.length;i++){let o=n[i];Oxe(this,o,e)}n.length=0};z1.prototype.isDestroyed=function(){return!1};z1.prototype.destroy=function(){let t=this._textures;for(let e in t)if(t.hasOwnProperty(e)){let n=t[e];n!==this._defaultTexture&&n.destroy()}return At(this)};var i5=z1;function o5(t){t=f(t,f.EMPTY_OBJECT),this.mode=f(t.mode,u0.MODIFY_MATERIAL),this.lightingModel=t.lightingModel,this.uniforms=f(t.uniforms,f.EMPTY_OBJECT),this.varyings=f(t.varyings,f.EMPTY_OBJECT),this.vertexShaderText=t.vertexShaderText,this.fragmentShaderText=t.fragmentShaderText,this.translucencyMode=f(t.translucencyMode,iF.INHERIT),this._textureManager=new i5,this._defaultTexture=void 0,this.uniformMap=wxe(this),this.usedVariablesVertex={attributeSet:{},featureIdSet:{},metadataSet:{}},this.usedVariablesFragment={attributeSet:{},featureIdSet:{},metadataSet:{},materialSet:{}},Kxe(this),zxe(this)}function wxe(t){let e=t.uniforms,n={};for(let i in e)if(e.hasOwnProperty(i)){let o=e[i];o.type===K1.SAMPLER_2D?(t._textureManager.loadTexture2D(i,o.value),n[i]=Pxe(t,i)):n[i]=vxe(t,i)}return n}function Pxe(t,e){return function(){return f(t._textureManager.getTexture(e),t._defaultTexture)}}function vxe(t,e){return function(){return t.uniforms[e].value}}function XT(t,e,n){let i;for(;(i=e.exec(t))!==null;){let o=i[1];n[o]=!0}}function Kxe(t){let e=/[vf]sInput\.attributes\.(\w+)/g,n=/[vf]sInput\.featureIds\.(\w+)/g,i=/[vf]sInput\.metadata.(\w+)/g,o,a=t.vertexShaderText;c(a)&&(o=t.usedVariablesVertex.attributeSet,XT(a,e,o),o=t.usedVariablesVertex.featureIdSet,XT(a,n,o),o=t.usedVariablesVertex.metadataSet,XT(a,i,o));let s=t.fragmentShaderText;if(c(s)){o=t.usedVariablesFragment.attributeSet,XT(s,e,o),o=t.usedVariablesFragment.featureIdSet,XT(s,n,o),o=t.usedVariablesFragment.metadataSet,XT(s,i,o);let l=/material\.(\w+)/g,r=t.usedVariablesFragment.materialSet;XT(s,l,r)}}function kQt(t){let e=/^.*MC$/,n=/^.*WC$/,i=/^.*EC$/;return e.test(t)?`${t} (model coordinates)`:n.test(t)?`${t} (Cartesian world coordinates)`:i.test(t)?`${t} (eye coordinates)`:t}function Vc(t,e,n,i){if(t.hasOwnProperty(e)){let o=`${kQt(e)} is not available in the ${i} shader. Did you mean ${kQt(n)} instead?`;throw new Ut(o)}}function zxe(t){let e=t.usedVariablesVertex.attributeSet;Vc(e,"position","positionMC","vertex"),Vc(e,"normal","normalMC","vertex"),Vc(e,"tangent","tangentMC","vertex"),Vc(e,"bitangent","bitangentMC","vertex"),Vc(e,"positionWC","positionMC","vertex"),Vc(e,"positionEC","positionMC","vertex"),Vc(e,"normalEC","normalMC","vertex"),Vc(e,"tangentEC","tangentMC","vertex"),Vc(e,"bitangentEC","bitangentMC","vertex");let n=t.usedVariablesFragment.attributeSet;Vc(n,"position","positionEC","fragment"),Vc(n,"normal","normalEC","fragment"),Vc(n,"tangent","tangentEC","fragment"),Vc(n,"bitangent","bitangentEC","fragment"),Vc(n,"normalMC","normalEC","fragment"),Vc(n,"tangentMC","tangentEC","fragment"),Vc(n,"bitangentMC","bitangentEC","fragment")}o5.prototype.setUniform=function(t,e){let n=this.uniforms[t];n.type===K1.SAMPLER_2D?this._textureManager.loadTexture2D(t,e):c(e.clone)?n.value=e.clone(n.value):n.value=e};o5.prototype.update=function(t){this._defaultTexture=t.context.defaultTexture,this._textureManager.update(t)};o5.prototype.isDestroyed=function(){return!1};o5.prototype.destroy=function(){this._textureManager=this._textureManager&&this._textureManager.destroy(),At(this)};var JT=o5;function KR(t){t=f(t,f.EMPTY_OBJECT),this._ready=!1,this._provider=f(t.provider,KR.DefaultProvider),this._traversal=void 0,this._shape=void 0,this._shapeVisible=!1,this._paddingBefore=new p,this._paddingAfter=new p,this._minBounds=new p,this._minBoundsOld=new p,this._maxBounds=new p,this._maxBoundsOld=new p,this._exaggeratedMinBounds=new p,this._exaggeratedMinBoundsOld=new p,this._exaggeratedMaxBounds=new p,this._exaggeratedMaxBoundsOld=new p,this._minClippingBounds=new p,this._minClippingBoundsOld=new p,this._maxClippingBounds=new p,this._maxClippingBoundsOld=new p,this._clippingPlanes=void 0,this._clippingPlanesState=0,this._clippingPlanesEnabled=!1,this._modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._exaggeratedModelMatrix=L.clone(this._modelMatrix),this._compoundModelMatrix=new L,this._compoundModelMatrixOld=new L,this._customShader=f(t.customShader,KR.DefaultCustomShader),this._customShaderCompilationEvent=new It,this._shaderDirty=!0,this._drawCommand=void 0,this._drawCommandPick=void 0,this._pickId=void 0,this._clock=t.clock,this._transformPositionWorldToUv=new L,this._transformPositionUvToWorld=new L,this._transformDirectionWorldToLocal=new ot,this._transformNormalLocalToWorld=new ot,this._jitter=!1,this._nearestSampling=!1,this._levelBlendFactor=0,this._stepSizeMultiplier=1,this._depthTest=!0,this._useLogDepth=void 0,this._screenSpaceError=4,this._debugPolylines=new Mc,this._debugDraw=!1,this._disableRender=!1,this._disableUpdate=!1,this._uniforms={octreeInternalNodeTexture:void 0,octreeInternalNodeTilesPerRow:0,octreeInternalNodeTexelSizeUv:new K,octreeLeafNodeTexture:void 0,octreeLeafNodeTilesPerRow:0,octreeLeafNodeTexelSizeUv:new K,megatextureTextures:[],megatextureSliceDimensions:new K,megatextureTileDimensions:new K,megatextureVoxelSizeUv:new K,megatextureSliceSizeUv:new K,megatextureTileSizeUv:new K,dimensions:new p,paddingBefore:new p,paddingAfter:new p,transformPositionViewToUv:new L,transformPositionUvToView:new L,transformDirectionViewToLocal:new ot,transformNormalLocalToWorld:new ot,cameraPositionUv:new p,ndcSpaceAxisAlignedBoundingBox:new bt,clippingPlanesTexture:void 0,clippingPlanesMatrix:new L,stepSize:0,pickColor:new v},this._shapeDefinesOld={},this._uniformMap={};let e=this._uniforms,n=this._uniformMap;for(let o in e)if(e.hasOwnProperty(o)){let a=`u_${o}`;n[a]=function(){return e[o]}}let i=this._provider;jxe(this,i)}function jxe(t,e){let{shape:n,minBounds:i=_o.getMinBounds(n),maxBounds:o=_o.getMaxBounds(n)}=e;t.minBounds=i,t.maxBounds=o,t.minClippingBounds=_o.getMinBounds(n),t.maxClippingBounds=_o.getMaxBounds(n),t._exaggeratedMinBounds=p.clone(t._minBounds,t._exaggeratedMinBounds),t._exaggeratedMaxBounds=p.clone(t._maxBounds,t._exaggeratedMaxBounds),t._exaggeratedModelMatrix=L.clone(t._modelMatrix,t._exaggeratedModelMatrix),xQt(t,e);let a=_o.getShapeConstructor(n);t._shape=new a,t._shapeVisible=XQt(t,t._shape,e)}Object.defineProperties(KR.prototype,{ready:{get:function(){return this._ready}},provider:{get:function(){return this._provider}},boundingSphere:{get:function(){return this._shape.boundingSphere}},orientedBoundingBox:{get:function(){return this._shape.orientedBoundingBox}},modelMatrix:{get:function(){return this._modelMatrix},set:function(t){this._modelMatrix=L.clone(t,this._modelMatrix)}},shape:{get:function(){return this._provider.shape}},dimensions:{get:function(){return this._provider.dimensions}},minimumValues:{get:function(){return this._provider.minimumValues}},maximumValues:{get:function(){return this._provider.maximumValues}},show:{get:function(){return!this._disableRender},set:function(t){this._disableRender=!t}},disableUpdate:{get:function(){return this._disableUpdate},set:function(t){this._disableUpdate=t}},debugDraw:{get:function(){return this._debugDraw},set:function(t){this._debugDraw=t}},depthTest:{get:function(){return this._depthTest},set:function(t){this._depthTest!==t&&(this._depthTest=t,this._shaderDirty=!0)}},jitter:{get:function(){return this._jitter},set:function(t){this._jitter!==t&&(this._jitter=t,this._shaderDirty=!0)}},nearestSampling:{get:function(){return this._nearestSampling},set:function(t){this._nearestSampling!==t&&(this._nearestSampling=t,this._shaderDirty=!0)}},levelBlendFactor:{get:function(){return this._levelBlendFactor},set:function(t){this._levelBlendFactor=k.clamp(t,0,1)}},screenSpaceError:{get:function(){return this._screenSpaceError},set:function(t){this._screenSpaceError=t}},stepSize:{get:function(){return this._stepSizeMultiplier},set:function(t){this._stepSizeMultiplier=t}},minBounds:{get:function(){return this._minBounds},set:function(t){this._minBounds=p.clone(t,this._minBounds)}},maxBounds:{get:function(){return this._maxBounds},set:function(t){this._maxBounds=p.clone(t,this._maxBounds)}},minClippingBounds:{get:function(){return this._minClippingBounds},set:function(t){this._minClippingBounds=p.clone(t,this._minClippingBounds)}},maxClippingBounds:{get:function(){return this._maxClippingBounds},set:function(t){this._maxClippingBounds=p.clone(t,this._maxClippingBounds)}},clippingPlanes:{get:function(){return this._clippingPlanes},set:function(t){Ml.setOwner(t,this,"_clippingPlanes")}},customShader:{get:function(){return this._customShader},set:function(t){if(this._customShader!==t){let e=this._uniformMap,i=this._customShader.uniformMap;for(let o in i)i.hasOwnProperty(o)&&delete e[o];c(t)?this._customShader=t:this._customShader=KR.DefaultCustomShader,this._shaderDirty=!0}}},customShaderCompilationEvent:{get:function(){return this._customShaderCompilationEvent}}});var qxe=new p,$xe=new bt,tXe=new bt,eXe=new p,nXe=new p,iXe=new ot,oXe=new ot,aXe=new L,sXe=new L,lXe=new L,rXe=L.fromRotationTranslation(ot.fromUniformScale(.5,new ot),new p(.5,.5,.5),new L),dXe=L.fromRotationTranslation(ot.fromUniformScale(2,new ot),new p(-1,-1,-1),new L);KR.prototype.update=function(t){let e=this._provider;this._customShader.update(t);let n=t.context;if(!this._ready){uXe(this,e,n),t.afterRender.push(()=>(this._ready=!0,!0));return}pXe(this,t);let i=xQt(this,e),o=this._shape;if(i&&(this._shapeVisible=XQt(this,o,e),bXe(this,o)&&(this._shaderDirty=!0)),!this._shapeVisible)return;let a=WXe(e.timeIntervalCollection,this._clock),s=this._traversal,l=s._sampleCount;if(s.update(t,a,i,this._disableUpdate),l!==s._sampleCount&&(this._shaderDirty=!0),!s.isRenderable(s.rootNode)||(this._debugDraw&&gXe(this,t),this._disableRender))return;this._useLogDepth!==t.useLogDepth&&(this._useLogDepth=t.useLogDepth,this._shaderDirty=!0),fXe(this,t)&&(this._shaderDirty=!0);let d=s.leafNodeTexture,m=this._uniforms;c(d)&&(m.octreeLeafNodeTexture=s.leafNodeTexture,m.octreeLeafNodeTexelSizeUv=K.clone(s.leafNodeTexelSizeUv,m.octreeLeafNodeTexelSizeUv),m.octreeLeafNodeTilesPerRow=s.leafNodeTilesPerRow),this._shaderDirty&&(q9(this,n),this._shaderDirty=!1);let h=n.uniformState.viewProjection,u=o.orientedBoundingBox,R=GXe(u,h,tXe);if(R.x===1||R.y===1||R.z===-1||R.w===-1)return;m.ndcSpaceAxisAlignedBoundingBox=bt.clone(R,m.ndcSpaceAxisAlignedBoundingBox);let F=n.uniformState.inverseView;m.transformPositionViewToUv=L.multiplyTransformation(this._transformPositionWorldToUv,F,m.transformPositionViewToUv);let U=n.uniformState.view;m.transformPositionUvToView=L.multiplyTransformation(U,this._transformPositionUvToWorld,m.transformPositionUvToView);let G=n.uniformState.inverseViewRotation;m.transformDirectionViewToLocal=ot.multiply(this._transformDirectionWorldToLocal,G,m.transformDirectionViewToLocal),m.transformNormalLocalToWorld=ot.clone(this._transformNormalLocalToWorld,m.transformNormalLocalToWorld);let A=t.camera.positionWC;m.cameraPositionUv=L.multiplyByPoint(this._transformPositionWorldToUv,A,m.cameraPositionUv),m.stepSize=this._stepSizeMultiplier;let S=t.passes.pick?this._drawCommandPick:t.passes.pickVoxel?this._drawCommandPickVoxel:this._drawCommand;S.boundingVolume=o.boundingSphere,t.commandList.push(S)};var cXe=new p,ust=new p,mXe=new gt,hXe=new p;function pXe(t,e){if(t._exaggeratedMinBounds=p.clone(t._minBounds,t._exaggeratedMinBounds),t._exaggeratedMaxBounds=p.clone(t._maxBounds,t._exaggeratedMaxBounds),t.shape===_o.ELLIPSOID){let n=e.verticalExaggerationRelativeHeight,i=e.verticalExaggeration;t._exaggeratedMinBounds.z=(t._minBounds.z-n)*i+n,t._exaggeratedMaxBounds.z=(t._maxBounds.z-n)*i+n}else if(t.shape===_o.BOX){let n=p.fromElements(1,1,e.verticalExaggeration,cXe);t._exaggeratedModelMatrix=L.multiplyByScale(t._modelMatrix,n,t._exaggeratedModelMatrix),t._exaggeratedModelMatrix=L.multiplyByTranslation(t._exaggeratedModelMatrix,VXe(t,e),t._exaggeratedModelMatrix)}}function VXe(t,e){let{shapeTransform:n=L.IDENTITY,globalTransform:i=L.IDENTITY}=t._provider,o=L.getTranslation(n,ust),a=L.multiplyByPoint(t._modelMatrix,o,ust),s=L.multiplyByPoint(i,a,ust),r=mt.WGS84.cartesianToCartographic(s,mXe),d=0;c(r)&&(d=r.height);let m=Ps.getHeight(d,e.verticalExaggeration,e.verticalExaggerationRelativeHeight);return p.fromElements(0,0,(m-d)/e.verticalExaggeration,hXe)}function uXe(t,e,n){let i=t._uniforms;t._pickId=n.createPickId({primitive:t}),i.pickColor=v.clone(t._pickId.color,i.pickColor);let{shaderDefines:o,shaderUniforms:a}=t._shape;t._shapeDefinesOld=Re(o,!0);let s=t._uniformMap;for(let l in a)if(a.hasOwnProperty(l)){let r=`u_${l}`;s[r]=function(){return a[l]}}i.dimensions=p.clone(e.dimensions,i.dimensions),t._paddingBefore=p.clone(f(e.paddingBefore,p.ZERO),t._paddingBefore),i.paddingBefore=p.clone(t._paddingBefore,i.paddingBefore),t._paddingAfter=p.clone(f(e.paddingAfter,p.ZERO),t._paddingBefore),i.paddingAfter=p.clone(t._paddingAfter,i.paddingAfter),t._traversal=ZXe(t,e,n),RXe(t._traversal,i)}function xQt(t,e){let n=f(e.shapeTransform,L.IDENTITY),i=f(e.globalTransform,L.IDENTITY);return L.multiplyTransformation(i,t._exaggeratedModelMatrix,t._compoundModelMatrix),L.multiplyTransformation(t._compoundModelMatrix,n,t._compoundModelMatrix),LT(t,"_compoundModelMatrix","_compoundModelMatrixOld")+LT(t,"_minBounds","_minBoundsOld")+LT(t,"_maxBounds","_maxBoundsOld")+LT(t,"_exaggeratedMinBounds","_exaggeratedMinBoundsOld")+LT(t,"_exaggeratedMaxBounds","_exaggeratedMaxBoundsOld")+LT(t,"_minClippingBounds","_minClippingBoundsOld")+LT(t,"_maxClippingBounds","_maxClippingBoundsOld")>0}function LT(t,e,n){let i=t[e],o=t[n],a=!i.equals(o);return a&&i.clone(o),a?1:0}function XQt(t,e,n){if(!e.update(t._compoundModelMatrix,t._exaggeratedMinBounds,t._exaggeratedMaxBounds,t.minClippingBounds,t.maxClippingBounds))return!1;let o=e.shapeTransform,a=L.inverse(o,aXe),s=L.getRotation(o,iXe),l=L.getScale(o,eXe),r=p.maximumComponent(l),d=p.divideByScalar(l,r,nXe),m=ot.multiplyByScale(s,d,oXe);return t._transformPositionWorldToUv=L.multiplyTransformation(rXe,a,t._transformPositionWorldToUv),t._transformPositionUvToWorld=L.multiplyTransformation(o,dXe,t._transformPositionUvToWorld),t._transformDirectionWorldToLocal=L.getMatrix3(a,t._transformDirectionWorldToLocal),t._transformNormalLocalToWorld=ot.inverseTranspose(m,t._transformNormalLocalToWorld),!0}function ZXe(t,e,n){let i=p.clone(e.dimensions,qxe);p.add(i,t._paddingBefore,i),p.add(i,t._paddingAfter,i);let o=e.maximumTileCount,a=c(o)?v1.getApproximateTextureMemoryByteLength(o,i,e.types,e.componentTypes):void 0,s=f(e.keyframeCount,1);return new v1(t,n,i,e.types,e.componentTypes,s,a)}function RXe(t,e){e.octreeInternalNodeTexture=t.internalNodeTexture,e.octreeInternalNodeTexelSizeUv=K.clone(t.internalNodeTexelSizeUv,e.octreeInternalNodeTexelSizeUv),e.octreeInternalNodeTilesPerRow=t.internalNodeTilesPerRow;let n=t.megatextures,i=n[0],o=n.length;e.megatextureTextures=new Array(o);for(let a=0;a<o;a++)e.megatextureTextures[a]=n[a].texture;e.megatextureSliceDimensions=K.clone(i.sliceCountPerRegion,e.megatextureSliceDimensions),e.megatextureTileDimensions=K.clone(i.regionCountPerMegatexture,e.megatextureTileDimensions),e.megatextureVoxelSizeUv=K.clone(i.voxelSizeUv,e.megatextureVoxelSizeUv),e.megatextureSliceSizeUv=K.clone(i.sliceSizeUv,e.megatextureSliceSizeUv),e.megatextureTileSizeUv=K.clone(i.regionSizeUv,e.megatextureTileSizeUv)}function bXe(t,e){let n=e.shaderDefines,i=Object.keys(n).some(o=>n[o]!==t._shapeDefinesOld[o]);return i&&(t._shapeDefinesOld=Re(n,!0)),i}function WXe(t,e){if(!c(t)||!c(e))return 0;let n=e.currentTime,i,o=t.indexOf(n);o>=0?i=t.get(o):(o=~o,o===t.length?(o=t.length-1,i=t.get(o),n=i.stop):(i=t.get(o),n=i.start));let a=rt.secondsDifference(i.stop,i.start),l=rt.secondsDifference(n,i.start)/a;return o+l}function fXe(t,e){let n=t.clippingPlanes;if(!c(n))return!1;n.update(e);let{clippingPlanesState:i,enabled:o}=n;if(o){let a=t._uniforms;a.clippingPlanesTexture=n.texture,a.clippingPlanesMatrix=L.transpose(L.multiplyTransformation(L.inverse(n.modelMatrix,a.clippingPlanesMatrix),t._transformPositionUvToWorld,a.clippingPlanesMatrix),a.clippingPlanesMatrix)}return t._clippingPlanesState===i&&t._clippingPlanesEnabled===o?!1:(t._clippingPlanesState=i,t._clippingPlanesEnabled=o,!0)}KR.prototype.isDestroyed=function(){return!1};KR.prototype.destroy=function(){let t=this._drawCommand;c(t)&&(t.shaderProgram=t.shaderProgram&&t.shaderProgram.destroy());let e=this._drawCommandPick;return c(e)&&(e.shaderProgram=e.shaderProgram&&e.shaderProgram.destroy()),this._pickId=this._pickId&&this._pickId.destroy(),this._traversal=this._traversal&&this._traversal.destroy(),this._clippingPlanes=this._clippingPlanes&&this._clippingPlanes.destroy(),At(this)};var YQt=new Array(new bt(-1,-1,-1,1),new bt(1,-1,-1,1),new bt(-1,1,-1,1),new bt(1,1,-1,1),new bt(-1,-1,1,1),new bt(1,-1,1,1),new bt(-1,1,1,1),new bt(1,1,1,1)),FXe=new Array(1,2,4,0,3,5,0,3,6,1,2,7,0,5,6,1,4,7,2,4,7,3,5,6),UXe=new Array(new bt,new bt,new bt,new bt,new bt,new bt,new bt,new bt);function GXe(t,e,n){let i=L.fromRotationTranslation(t.halfAxes,t.center,sXe),o=L.multiply(e,i,lXe),a=+Number.MAX_VALUE,s=-Number.MAX_VALUE,l=+Number.MAX_VALUE,r=-Number.MAX_VALUE,d,m=UXe,h=YQt.length;for(d=0;d<h;d++)L.multiplyByVector(o,YQt[d],m[d]);for(d=0;d<h;d++){let u=m[d];if(u.z>=-u.w){let R=u.x/u.w,V=u.y/u.w;a=Math.min(a,R),s=Math.max(s,R),l=Math.min(l,V),r=Math.max(r,V)}else for(let R=0;R<3;R++){let V=FXe[d*3+R],F=m[V];if(F.z>=-F.w){let U=u.z+u.w,G=F.z+F.w,A=U/(U-G),S=bt.lerp(u,F,A,$xe),g=S.x/S.w,C=S.y/S.w;a=Math.min(a,g),s=Math.max(s,g),l=Math.min(l,C),r=Math.max(r,C)}}}return a=k.clamp(a,-1,1),l=k.clamp(l,-1,1),s=k.clamp(s,-1,1),r=k.clamp(r,-1,1),n=bt.fromElements(a,l,s,r,n),n}var Zst=3e7,AXe=new p(Zst,0,0),SXe=new p(0,Zst,0),TXe=new p(0,0,Zst);function gXe(t,e){let n=t._traversal,i=t._debugPolylines;i.removeAll();function o(r,d,m,h){i.add({positions:[r,d],width:h,material:eo.fromType("Color",{color:m})})}function a(r,d,m){let h=r.computeCorners();o(h[0],h[1],d,m),o(h[2],h[3],d,m),o(h[4],h[5],d,m),o(h[6],h[7],d,m),o(h[0],h[2],d,m),o(h[4],h[6],d,m),o(h[1],h[3],d,m),o(h[5],h[7],d,m),o(h[0],h[4],d,m),o(h[2],h[6],d,m),o(h[1],h[5],d,m),o(h[3],h[7],d,m)}function s(r){if(!n.isRenderable(r))return;let d=r.level,h=Math.max(1,5/Math.pow(2,d)),R=[v.RED,v.LIME,v.BLUE][d%3];if(a(r.orientedBoundingBox,R,h),c(r.children))for(let V=0;V<8;V++)s(r.children[V])}a(t._shape.orientedBoundingBox,v.WHITE,5),s(n.rootNode);let l=10;o(p.ZERO,AXe,v.RED,l),o(p.ZERO,SXe,v.LIME,l),o(p.ZERO,TXe,v.BLUE,l),i.update(e)}KR.DefaultCustomShader=new JT({fragmentShaderText:`void fragmentMain(FragmentInput fsInput, inout czm_modelMaterial material) { material.diffuse = vec3(1.0); material.alpha = 1.0; -}`});function JQt(){this.ready=!0,this.shape=_o.BOX,this.dimensions=new p(1,1,1),this.names=["data"],this.types=[Nn.SCALAR],this.componentTypes=[vn.FLOAT32],this.maximumTileCount=1}JQt.prototype.requestData=function(t){if(!((c(t)?f(t.tileLevel,0):0)>=1))return Promise.resolve([new Float32Array(1)])};Kb.DefaultProvider=new JQt;var TU=Kb;var Nj=function(t){return function(){t.frameState.afterRender.push(function(){t.requestRender()})}};function fo(t){t=f(t,f.EMPTY_OBJECT);let e=t.canvas,n=t.creditContainer,i=t.creditViewport,o=be(t.contextOptions),a=c(n),s=new a2(e,o);a||(n=document.createElement("div"),n.style.position="absolute",n.style.bottom="0",n.style["text-shadow"]="0 0 2px #000000",n.style.color="#ffffff",n.style["font-size"]="10px",n.style["padding-right"]="5px",e.parentNode.appendChild(n)),c(i)||(i=e.parentNode),this._id=Si(),this._jobScheduler=new L_,this._frameState=new X_(s,new S_(n," \u2022 ",i),this._jobScheduler),this._frameState.scene3DOnly=f(t.scene3DOnly,!1),this._removeCreditContainer=!a,this._creditContainer=n,this._canvas=e,this._context=s,this._computeEngine=new Zy(s),this._globe=void 0,this._globeTranslucencyState=new J_,this._primitives=new Dm,this._groundPrimitives=new Dm,this._globeHeight=void 0,this._globeHeightDirty=!0,this._cameraUnderground=!1,this._removeUpdateHeightCallback=void 0,this._logDepthBuffer=fo.defaultLogDepthBuffer&&s.fragmentDepth,this._logDepthBufferDirty=!0,this._tweens=new yS,this._shaderFrameCount=0,this._sunPostProcess=void 0,this._computeCommandList=[],this._overlayCommandList=[],this._useOIT=f(t.orderIndependentTranslucency,!0),this._executeOITFunction=void 0,this._depthPlane=new Q_(t.depthPlaneEllipsoidOffset),this._clearColorCommand=new ao({color:new v,stencil:0,owner:this}),this._depthClearCommand=new ao({depth:1,owner:this}),this._stencilClearCommand=new ao({stencil:0}),this._classificationStencilClearCommand=new ao({stencil:0,renderState:he.fromCache({stencilMask:gn.CLASSIFICATION_MASK})}),this._depthOnlyRenderStateCache={},this._transitioner=new T9(this),this._preUpdate=new It,this._postUpdate=new It,this._renderError=new It,this._preRender=new It,this._postRender=new It,this._minimumDisableDepthTestDistance=0,this._debugInspector=new Q9,this._msaaSamples=f(t.msaaSamples,1),this.rethrowRenderErrors=!1,this.completeMorphOnUserInput=!0,this.morphStart=new It,this.morphComplete=new It,this.skyBox=void 0,this.skyAtmosphere=void 0,this.sun=void 0,this.sunBloom=!0,this._sunBloom=void 0,this.moon=void 0,this.backgroundColor=v.clone(v.BLACK),this._mode=ut.SCENE3D,this._mapProjection=c(t.mapProjection)?t.mapProjection:new yo,this.morphTime=1,this.farToNearRatio=1e3,this.logarithmicDepthFarToNearRatio=1e9,this.nearToFarDistance2D=175e4,this.verticalExaggeration=1,this.verticalExaggerationRelativeHeight=0,this.debugCommandFilter=void 0,this.debugShowCommands=!1,this.debugShowFrustums=!1,this.debugShowFramesPerSecond=!1,this.debugShowDepthFrustum=1,this.debugShowFrustumPlanes=!1,this._debugShowFrustumPlanes=!1,this._debugFrustumPlanes=void 0,this.useDepthPicking=!0,this.pickTranslucentDepth=!1,this.cameraEventWaitTime=500,this.atmosphere=new b_,this.fog=new x_,this._shadowMapCamera=new Aa(this),this.shadowMap=new fW({context:s,lightCamera:this._shadowMapCamera,enabled:f(t.shadows,!1)}),this.invertClassification=!1,this.invertClassificationColor=v.clone(v.WHITE),this._actualInvertClassificationColor=v.clone(this._invertClassificationColor),this._invertClassification=new M1,this.focalLength=void 0,this.eyeSeparation=void 0,this.postProcessStages=new U9,this._brdfLutGenerator=new f_,this._performanceDisplay=void 0,this._debugVolume=void 0,this._screenSpaceCameraController=new C9(this),this._cameraUnderground=!1,this._mapMode2D=f(t.mapMode2D,eh.INFINITE_SCROLL),this._environmentState={skyBoxCommand:void 0,skyAtmosphereCommand:void 0,sunDrawCommand:void 0,sunComputeCommand:void 0,moonCommand:void 0,isSunVisible:!1,isMoonVisible:!1,isReadyForAtmosphere:!1,isSkyAtmosphereVisible:!1,clearGlobeDepth:!1,useDepthPlane:!1,renderTranslucentDepthForPick:!1,originalFramebuffer:void 0,useGlobeDepthFramebuffer:!1,useOIT:!1,useInvertClassification:!1,usePostProcess:!1,usePostProcessSelected:!1,useWebVR:!1},this._useWebVR=!1,this._cameraVR=void 0,this._aspectRatioVR=void 0,this.requestRenderMode=f(t.requestRenderMode,!1),this._renderRequested=!0,this.maximumRenderTimeChange=f(t.maximumRenderTimeChange,0),this._lastRenderTime=void 0,this._frameRateMonitor=void 0,this._removeRequestListenerCallback=xd.requestCompletedEvent.addEventListener(Nj(this)),this._removeTaskProcessorListenerCallback=$i.taskCompletedEvent.addEventListener(Nj(this)),this._removeGlobeCallbacks=[],this._removeTerrainProviderReadyListener=void 0;let l=new Fe(0,0,s.drawingBufferWidth,s.drawingBufferHeight),r=new Aa(this);this._logDepthBuffer&&(r.frustum.near=.1,r.frustum.far=1e10),this.preloadFlightCamera=new Aa(this),this.preloadFlightCullingVolume=void 0,this._picking=new $_(this),this._defaultView=new AS(this,r,l),this._view=this._defaultView,this._hdr=void 0,this._hdrDirty=void 0,this.highDynamicRange=!1,this.gamma=2.2,this.sphericalHarmonicCoefficients=void 0,this.specularEnvironmentMaps=void 0,this._specularEnvironmentMapAtlas=void 0,this.light=new gR,DQt(this,0,rt.now()),this.updateFrameState(),this.initializeFrame()}fo.defaultLogDepthBuffer=!0;function EXe(t,e){for(let i=0;i<t._removeGlobeCallbacks.length;++i)t._removeGlobeCallbacks[i]();t._removeGlobeCallbacks.length=0;let n=[];c(e)&&(n.push(e.imageryLayersUpdatedEvent.addEventListener(Nj(t))),n.push(e.terrainProviderChanged.addEventListener(Nj(t)))),t._removeGlobeCallbacks=n}Object.defineProperties(fo.prototype,{canvas:{get:function(){return this._canvas}},drawingBufferHeight:{get:function(){return this._context.drawingBufferHeight}},drawingBufferWidth:{get:function(){return this._context.drawingBufferWidth}},maximumAliasedLineWidth:{get:function(){return Sn.maximumAliasedLineWidth}},maximumCubeMapSize:{get:function(){return Sn.maximumCubeMapSize}},pickPositionSupported:{get:function(){return this._context.depthTexture}},sampleHeightSupported:{get:function(){return this._context.depthTexture}},clampToHeightSupported:{get:function(){return this._context.depthTexture}},invertClassificationSupported:{get:function(){return this._context.depthTexture}},specularEnvironmentMapsSupported:{get:function(){return dZ.isSupported(this._context)}},globe:{get:function(){return this._globe},set:function(t){this._globe=this._globe&&this._globe.destroy(),this._globe=t,EXe(this,t)}},primitives:{get:function(){return this._primitives}},groundPrimitives:{get:function(){return this._groundPrimitives}},camera:{get:function(){return this._view.camera},set:function(t){this._view.camera=t}},view:{get:function(){return this._view},set:function(t){this._view=t}},defaultView:{get:function(){return this._defaultView}},picking:{get:function(){return this._picking}},screenSpaceCameraController:{get:function(){return this._screenSpaceCameraController}},mapProjection:{get:function(){return this._mapProjection}},jobScheduler:{get:function(){return this._jobScheduler}},frameState:{get:function(){return this._frameState}},environmentState:{get:function(){return this._environmentState}},tweens:{get:function(){return this._tweens}},imageryLayers:{get:function(){if(c(this.globe))return this.globe.imageryLayers}},terrainProvider:{get:function(){if(c(this.globe))return this.globe.terrainProvider},set:function(t){this._removeTerrainProviderReadyListener=this._removeTerrainProviderReadyListener&&this._removeTerrainProviderReadyListener(),c(this.globe)&&(this.globe.terrainProvider=t)}},terrainProviderChanged:{get:function(){if(c(this.globe))return this.globe.terrainProviderChanged}},preUpdate:{get:function(){return this._preUpdate}},postUpdate:{get:function(){return this._postUpdate}},renderError:{get:function(){return this._renderError}},preRender:{get:function(){return this._preRender}},postRender:{get:function(){return this._postRender}},lastRenderTime:{get:function(){return this._lastRenderTime}},context:{get:function(){return this._context}},debugFrustumStatistics:{get:function(){return this._view.debugFrustumStatistics}},scene3DOnly:{get:function(){return this._frameState.scene3DOnly}},orderIndependentTranslucency:{get:function(){return this._useOIT}},id:{get:function(){return this._id}},mode:{get:function(){return this._mode},set:function(t){t===ut.SCENE2D?this.morphTo2D(0):t===ut.SCENE3D?this.morphTo3D(0):t===ut.COLUMBUS_VIEW&&this.morphToColumbusView(0),this._mode=t}},frustumCommandsList:{get:function(){return this._view.frustumCommandsList}},numberOfFrustums:{get:function(){return this._view.frustumCommandsList.length}},useWebVR:{get:function(){return this._useWebVR},set:function(t){this._useWebVR=t,this._useWebVR?(this._frameState.creditDisplay.container.style.visibility="hidden",this._cameraVR=new Aa(this),c(this._deviceOrientationCameraController)||(this._deviceOrientationCameraController=new Y_(this)),this._aspectRatioVR=this.camera.frustum.aspectRatio):(this._frameState.creditDisplay.container.style.visibility="visible",this._cameraVR=void 0,this._deviceOrientationCameraController=this._deviceOrientationCameraController&&!this._deviceOrientationCameraController.isDestroyed()&&this._deviceOrientationCameraController.destroy(),this.camera.frustum.aspectRatio=this._aspectRatioVR,this.camera.frustum.xOffset=0)}},mapMode2D:{get:function(){return this._mapMode2D}},splitPosition:{get:function(){return this._frameState.splitPosition},set:function(t){this._frameState.splitPosition=t}},minimumDisableDepthTestDistance:{get:function(){return this._minimumDisableDepthTestDistance},set:function(t){this._minimumDisableDepthTestDistance=t}},logarithmicDepthBuffer:{get:function(){return this._logDepthBuffer},set:function(t){t=this._context.fragmentDepth&&t,this._logDepthBuffer!==t&&(this._logDepthBuffer=t,this._logDepthBufferDirty=!0)}},gamma:{get:function(){return this._context.uniformState.gamma},set:function(t){this._context.uniformState.gamma=t}},highDynamicRange:{get:function(){return this._hdr},set:function(t){let e=this._context,n=t&&e.depthTexture&&(e.colorBufferFloat||e.colorBufferHalfFloat);this._hdrDirty=n!==this._hdr,this._hdr=n}},highDynamicRangeSupported:{get:function(){let t=this._context;return t.depthTexture&&(t.colorBufferFloat||t.colorBufferHalfFloat)}},cameraUnderground:{get:function(){return this._cameraUnderground}},msaaSamples:{get:function(){return this._msaaSamples},set:function(t){t=Math.min(t,Sn.maximumSamples),this._msaaSamples=t}},msaaSupported:{get:function(){return this._context.msaa}},pixelRatio:{get:function(){return this._frameState.pixelRatio},set:function(t){this._frameState.pixelRatio=t}},opaqueFrustumNearOffset:{get:function(){return .9999}},globeHeight:{get:function(){return this._globeHeight}}});fo.prototype.getCompressedTextureFormatSupported=function(t){let e=this.context;return(t==="WEBGL_compressed_texture_s3tc"||t==="s3tc")&&e.s3tc||(t==="WEBGL_compressed_texture_pvrtc"||t==="pvrtc")&&e.pvrtc||(t==="WEBGL_compressed_texture_etc"||t==="etc")&&e.etc||(t==="WEBGL_compressed_texture_etc1"||t==="etc1")&&e.etc1||(t==="WEBGL_compressed_texture_astc"||t==="astc")&&e.astc||(t==="EXT_texture_compression_bptc"||t==="bc7")&&e.bc7};function LQt(t,e,n){let i=t._frameState,o=t._context,a=t._view.oit,s=i.shadowState.lightShadowMaps,l=i.shadowState.lightShadowsEnabled,r=e.derivedCommands;c(e.pickId)&&(r.picking=VW.createPickDerivedCommand(t,e,o,r.picking)),e.pickOnly||(r.depth=VW.createDepthOnlyDerivedCommand(t,e,o,r.depth)),r.originalCommand=e,t._hdr&&(r.hdr=VW.createHdrCommand(e,o,r.hdr),e=r.hdr.command,r=e.derivedCommands),l&&e.receiveShadows&&(r.shadows=fW.createReceiveDerivedCommand(s,e,n,o,r.shadows)),e.pass===Pt.TRANSLUCENT&&c(a)&&a.isSupported()&&(l&&e.receiveShadows?(r.oit=c(r.oit)?r.oit:{},r.oit.shadows=a.createDerivedCommands(r.shadows.receiveCommand,o,r.oit.shadows)):r.oit=a.createDerivedCommands(e,o,r.oit))}fo.prototype.updateDerivedCommands=function(t){if(!c(t.derivedCommands))return;let e=this._frameState,n=this._context,i=!1,o=e.shadowState.lastDirtyTime;t.lastDirtyTime!==o&&(t.lastDirtyTime=o,t.dirty=!0,i=!0);let a=e.useLogDepth,s=this._hdr,l=t.derivedCommands,r=c(l.logDepth),d=c(l.hdr),m=c(l.originalCommand),h=a&&!r,Z=s&&!d,b=(!a||!s)&&!m;if(t.dirty=t.dirty||h||Z||b,t.dirty){t.dirty=!1;let u=e.shadowState.shadowMaps;e.shadowState.shadowsEnabled&&t.castShadows&&(l.shadows=fW.createCastDerivedCommand(u,t,i,n,l.shadows)),(r||h)&&(l.logDepth=VW.createLogDepthCommand(t,n,l.logDepth),LQt(this,l.logDepth.command,i)),(m||b)&&LQt(this,t,i)}};var CXe=new Eu({pass:ns.RENDER}),bst=new Eu({pass:ns.PRELOAD}),Rst=new Eu({pass:ns.PRELOAD_FLIGHT}),IXe=new Eu({pass:ns.REQUEST_RENDER_MODE_DEFER_CHECK}),MQt=new Ft,Wst;function NXe(t){let e=t.globe;if(t._mode===ut.SCENE3D&&c(e)&&e.show&&!t._cameraUnderground&&!t._globeTranslucencyState.translucent){let n=e.ellipsoid,i=t.frameState.minimumTerrainHeight;return MQt.radius=n.minimumRadius+i,Wst=Z_.fromBoundingSphere(MQt,t.camera.positionWC,Wst),Wst}}fo.prototype.clearPasses=function(t){t.render=!1,t.pick=!1,t.pickVoxel=!1,t.depth=!1,t.postProcess=!1,t.offscreen=!1};function DQt(t,e,n){let i=t._frameState;i.frameNumber=e,i.time=rt.clone(n,i.time)}fo.prototype.updateFrameState=function(){let t=this.camera,e=this._frameState;e.commandList.length=0,e.shadowMaps.length=0,e.brdfLutGenerator=this._brdfLutGenerator,e.environmentMap=this.skyBox&&this.skyBox._cubeMap,e.mode=this._mode,e.morphTime=this.morphTime,e.mapProjection=this.mapProjection,e.camera=t,e.cullingVolume=t.frustum.computeCullingVolume(t.positionWC,t.directionWC,t.upWC),e.occluder=NXe(this),e.minimumTerrainHeight=0,e.minimumDisableDepthTestDistance=this._minimumDisableDepthTestDistance,e.invertClassification=this.invertClassification,e.useLogDepth=this._logDepthBuffer&&!(this.camera.frustum instanceof wn||this.camera.frustum instanceof el),e.light=this.light,e.cameraUnderground=this._cameraUnderground,e.globeTranslucencyState=this._globeTranslucencyState;let{globe:n}=this;c(n)&&n._terrainExaggerationChanged&&(this.verticalExaggeration=n._terrainExaggeration,this.verticalExaggerationRelativeHeight=n._terrainExaggerationRelativeHeight,n._terrainExaggerationChanged=!1),e.verticalExaggeration=this.verticalExaggeration,e.verticalExaggerationRelativeHeight=this.verticalExaggerationRelativeHeight,c(this._specularEnvironmentMapAtlas)&&this._specularEnvironmentMapAtlas.ready?(e.specularEnvironmentMaps=this._specularEnvironmentMapAtlas.texture,e.specularEnvironmentMapsMaximumLOD=this._specularEnvironmentMapAtlas.maximumMipmapLevel):(e.specularEnvironmentMaps=void 0,e.specularEnvironmentMapsMaximumLOD=void 0),e.sphericalHarmonicCoefficients=this.sphericalHarmonicCoefficients,this._actualInvertClassificationColor=v.clone(this.invertClassificationColor,this._actualInvertClassificationColor),M1.isTranslucencySupported(this._context)||(this._actualInvertClassificationColor.alpha=1),e.invertClassificationColor=this._actualInvertClassificationColor,c(this.globe)?e.maximumScreenSpaceError=this.globe.maximumScreenSpaceError:e.maximumScreenSpaceError=2,this.clearPasses(e.passes),e.tilesetPassState=void 0};fo.prototype.isVisible=function(t,e,n){return c(t)&&(!c(t.boundingVolume)||!t.cull||e.computeVisibility(t.boundingVolume)!==yn.OUTSIDE&&(!c(n)||!t.occlude||!t.boundingVolume.isOccluded(n)))};var Ij=new L(0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1);Ij=L.inverseTransformation(Ij,Ij);function yXe(t,e,n,i){let o=e._frameState,a=o.context,s=t.boundingVolume;c(e._debugVolume)&&e._debugVolume.destroy();let l,r=p.clone(s.center);if(o.mode!==ut.SCENE3D){r=L.multiplyByPoint(Ij,r,r);let Z=o.mapProjection,b=Z.unproject(r);r=Z.ellipsoid.cartographicToCartesian(b)}if(c(s.radius)){let Z=s.radius;l=gi.toWireframe(Cr.createGeometry(new Cr({radii:new p(Z,Z,Z),vertexFormat:jn.FLAT_VERTEX_FORMAT}))),e._debugVolume=new Wi({geometryInstances:new $e({geometry:l,modelMatrix:L.fromTranslation(r),attributes:{color:new En(1,0,0,1)}}),appearance:new jn({flat:!0,translucent:!1}),asynchronous:!1})}else{let Z=s.halfAxes;l=gi.toWireframe(Am.createGeometry(Am.fromDimensions({dimensions:new p(2,2,2),vertexFormat:jn.FLAT_VERTEX_FORMAT}))),e._debugVolume=new Wi({geometryInstances:new $e({geometry:l,modelMatrix:L.fromRotationTranslation(Z,r,new L),attributes:{color:new En(1,0,0,1)}}),appearance:new jn({flat:!0,translucent:!1}),asynchronous:!1})}let d=o.commandList,m=o.commandList=[];e._debugVolume.update(o),t=m[0],o.useLogDepth&&(t=VW.createLogDepthCommand(t,a).command);let h;c(i)&&(h=n.framebuffer,n.framebuffer=i),t.execute(a,n),c(h)&&(n.framebuffer=h),o.commandList=d}function Sd(t,e,n,i,o){let a=e._frameState;if(c(e.debugCommandFilter)&&!e.debugCommandFilter(t))return;if(t instanceof ao){t.execute(n,i);return}t.debugShowBoundingVolume&&c(t.boundingVolume)&&yXe(t,e,i,o),a.useLogDepth&&c(t.derivedCommands.logDepth)&&(t=t.derivedCommands.logDepth.command);let s=a.passes;if(!s.pick&&!s.pickVoxel&&!s.depth&&e._hdr&&c(t.derivedCommands)&&c(t.derivedCommands.hdr)&&(t=t.derivedCommands.hdr.command),s.pick||s.depth){if(s.pick&&!s.depth&&c(t.derivedCommands.picking)){t=t.derivedCommands.picking.pickCommand,t.execute(n,i);return}else if(c(t.derivedCommands.depth)){t=t.derivedCommands.depth.depthOnlyCommand,t.execute(n,i);return}}if(e.debugShowCommands||e.debugShowFrustums){e._debugInspector.executeDebugShowFrustumsCommand(e,t,i);return}a.shadowState.lightShadowsEnabled&&t.receiveShadows&&c(t.derivedCommands.shadows)?t.derivedCommands.shadows.receiveCommand.execute(n,i):t.execute(n,i)}function a5(t,e,n,i){let o=e._frameState,a=t.derivedCommands;c(a)&&(o.useLogDepth&&c(a.logDepth)&&(t=a.logDepth.command),a=t.derivedCommands,c(a.picking)?(t=a.picking.pickCommand,t.execute(n,i)):c(a.depth)&&(t=a.depth.depthOnlyCommand,t.execute(n,i)))}function OQt(t,e,n){return e.boundingVolume.distanceSquaredTo(n)-t.boundingVolume.distanceSquaredTo(n)}function BXe(t,e,n){return t.boundingVolume.distanceSquaredTo(n)-e.boundingVolume.distanceSquaredTo(n)+k.EPSILON12}function QXe(t,e,n,i,o){let a=t.context;ZW(i,OQt,t.camera.positionWC),c(o)&&e(o.unclassifiedCommand,t,a,n);let s=i.length;for(let l=0;l<s;++l)e(i[l],t,a,n)}function kXe(t,e,n,i,o){let a=t.context;ZW(i,BXe,t.camera.positionWC),c(o)&&e(o.unclassifiedCommand,t,a,n);let s=i.length;for(let l=0;l<s;++l)e(i[l],t,a,n)}function YXe(t,e,n,i){let o=t.context;ZW(i,OQt,t.camera.positionWC);let a=i.length;for(let s=0;s<a;++s)e(i[s],t,o,n)}var xXe=new Io,XXe=new em,JXe=new wn,LXe=new el;function Fst(t,e){let{camera:n,context:i,frameState:o}=t,{uniformState:a}=i;a.updateCamera(n);let s;c(n.frustum.fov)?s=n.frustum.clone(xXe):c(n.frustum.infiniteProjectionMatrix)?s=n.frustum.clone(XXe):c(n.frustum.width)?s=n.frustum.clone(JXe):s=n.frustum.clone(LXe),s.near=n.frustum.near,s.far=n.frustum.far,a.updateFrustum(s),a.updatePass(Pt.ENVIRONMENT);let l=o.passes,r=l.pick||l.pickVoxel,d=t._environmentState,m=t._view,h=d.renderTranslucentDepthForPick,Z=d.useWebVR;if(!r){let E=d.skyBoxCommand;if(c(E)&&Sd(E,t,i,e),d.isSkyAtmosphereVisible&&Sd(d.skyAtmosphereCommand,t,i,e),d.isSunVisible&&(d.sunDrawCommand.execute(i,e),t.sunBloom&&!Z)){let I;d.useGlobeDepthFramebuffer?I=m.globeDepth.framebuffer:d.usePostProcess?I=m.sceneFramebuffer.framebuffer:I=d.originalFramebuffer,t._sunPostProcess.execute(i),t._sunPostProcess.copy(i,I),e.framebuffer=I}d.isMoonVisible&&d.moonCommand.execute(i,e)}let b;d.useOIT?(c(t._executeOITFunction)||(t._executeOITFunction=function(E,I,B,X,_){m.globeDepth.prepareColorTextures(i),m.oit.executeCommands(E,I,B,X,_)}),b=t._executeOITFunction):l.render?b=QXe:b=kXe;let u=m.frustumCommandsList,F=u.length,U=d.clearGlobeDepth,G=d.useDepthPlane,A=t._globeTranslucencyState,T=A.translucent,g=t._view.globeTranslucencyFramebuffer,C=t._depthClearCommand,y=t._stencilClearCommand,Y=t._classificationStencilClearCommand,Q=t._depthPlane,J=d.usePostProcessSelected,M=n.position.z,V;for(let E=0;E<F;++E){let I=F-E-1,B=u[I];t.mode===ut.SCENE2D?(n.position.z=M-B.near+1,s.far=Math.max(1,B.far-B.near),s.near=1,a.update(o),a.updateFrustum(s)):(s.near=I!==0?B.near*t.opaqueFrustumNearOffset:B.near,s.far=B.far,a.updateFrustum(s)),C.execute(i,e),i.stencilBuffer&&y.execute(i,e),a.updatePass(Pt.GLOBE);let X=B.commands[Pt.GLOBE],_=B.indices[Pt.GLOBE];if(T)A.executeGlobeCommands(B,Sd,g,t,e);else for(V=0;V<_;++V)Sd(X[V],t,i,e);let P=m.globeDepth;if(c(P)&&d.useGlobeDepthFramebuffer&&P.executeCopyDepth(i,e),!d.renderTranslucentDepthForPick)if(a.updatePass(Pt.TERRAIN_CLASSIFICATION),X=B.commands[Pt.TERRAIN_CLASSIFICATION],_=B.indices[Pt.TERRAIN_CLASSIFICATION],T)A.executeGlobeClassificationCommands(B,Sd,g,t,e);else for(V=0;V<_;++V)Sd(X[V],t,i,e);if(U&&(C.execute(i,e),G&&Q.execute(i,e)),!d.useInvertClassification||r||d.renderTranslucentDepthForPick){for(a.updatePass(Pt.CESIUM_3D_TILE),X=B.commands[Pt.CESIUM_3D_TILE],_=B.indices[Pt.CESIUM_3D_TILE],V=0;V<_;++V)Sd(X[V],t,i,e);if(_>0&&(c(P)&&d.useGlobeDepthFramebuffer&&(P.prepareColorTextures(i,U),P.executeUpdateDepth(i,e,U,P.depthStencilTexture)),!d.renderTranslucentDepthForPick))for(a.updatePass(Pt.CESIUM_3D_TILE_CLASSIFICATION),X=B.commands[Pt.CESIUM_3D_TILE_CLASSIFICATION],_=B.indices[Pt.CESIUM_3D_TILE_CLASSIFICATION],V=0;V<_;++V)Sd(X[V],t,i,e)}else{t._invertClassification.clear(i,e);let nt=e.framebuffer;for(e.framebuffer=t._invertClassification._fbo.framebuffer,a.updatePass(Pt.CESIUM_3D_TILE),X=B.commands[Pt.CESIUM_3D_TILE],_=B.indices[Pt.CESIUM_3D_TILE],V=0;V<_;++V)Sd(X[V],t,i,e);for(c(P)&&d.useGlobeDepthFramebuffer&&(t._invertClassification.prepareTextures(i),P.executeUpdateDepth(i,e,U,t._invertClassification._fbo.getDepthStencilTexture())),a.updatePass(Pt.CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW),X=B.commands[Pt.CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW],_=B.indices[Pt.CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW],V=0;V<_;++V)Sd(X[V],t,i,e);for(e.framebuffer=nt,t._invertClassification.executeClassified(i,e),o.invertClassificationColor.alpha===1&&t._invertClassification.executeUnclassified(i,e),_>0&&i.stencilBuffer&&Y.execute(i,e),a.updatePass(Pt.CESIUM_3D_TILE_CLASSIFICATION),X=B.commands[Pt.CESIUM_3D_TILE_CLASSIFICATION],_=B.indices[Pt.CESIUM_3D_TILE_CLASSIFICATION],V=0;V<_;++V)Sd(X[V],t,i,e)}for(_>0&&i.stencilBuffer&&y.execute(i,e),a.updatePass(Pt.VOXELS),X=B.commands[Pt.VOXELS],_=B.indices[Pt.VOXELS],X.length=_,YXe(t,Sd,e,X),a.updatePass(Pt.OPAQUE),X=B.commands[Pt.OPAQUE],_=B.indices[Pt.OPAQUE],V=0;V<_;++V)Sd(X[V],t,i,e);I!==0&&t.mode!==ut.SCENE2D&&(s.near=B.near,a.updateFrustum(s));let w;if(!r&&d.useInvertClassification&&o.invertClassificationColor.alpha<1&&(w=t._invertClassification),a.updatePass(Pt.TRANSLUCENT),X=B.commands[Pt.TRANSLUCENT],X.length=B.indices[Pt.TRANSLUCENT],b(t,Sd,e,X,w),B.indices[Pt.CESIUM_3D_TILE_CLASSIFICATION]>0&&m.translucentTileClassification.isSupported()&&(m.translucentTileClassification.executeTranslucentCommands(t,Sd,e,X,P.depthStencilTexture),m.translucentTileClassification.executeClassificationCommands(t,Sd,e,B)),i.depthTexture&&t.useDepthPicking&&(d.useGlobeDepthFramebuffer||h)){let nt=P.depthStencilTexture,$=t._picking.getPickDepth(t,I);$.update(i,nt),$.executeCopyDepth(i,e)}if(r||!J)continue;let H=e.framebuffer;if(e.framebuffer=m.sceneFramebuffer.getIdFramebuffer(),s.near=I!==0?B.near*t.opaqueFrustumNearOffset:B.near,s.far=B.far,a.updateFrustum(s),a.updatePass(Pt.GLOBE),X=B.commands[Pt.GLOBE],_=B.indices[Pt.GLOBE],T)A.executeGlobeCommands(B,a5,g,t,e);else for(V=0;V<_;++V)a5(X[V],t,i,e);for(U&&(C.framebuffer=e.framebuffer,C.execute(i,e),C.framebuffer=void 0),U&&G&&Q.execute(i,e),a.updatePass(Pt.CESIUM_3D_TILE),X=B.commands[Pt.CESIUM_3D_TILE],_=B.indices[Pt.CESIUM_3D_TILE],V=0;V<_;++V)a5(X[V],t,i,e);for(a.updatePass(Pt.OPAQUE),X=B.commands[Pt.OPAQUE],_=B.indices[Pt.OPAQUE],V=0;V<_;++V)a5(X[V],t,i,e);for(a.updatePass(Pt.TRANSLUCENT),X=B.commands[Pt.TRANSLUCENT],_=B.indices[Pt.TRANSLUCENT],V=0;V<_;++V)a5(X[V],t,i,e);e.framebuffer=H}}function HQt(t){t.context.uniformState.updatePass(Pt.COMPUTE);let n=t._environmentState.sunComputeCommand;c(n)&&n.execute(t._computeEngine);let i=t._computeCommandList,o=i.length;for(let a=0;a<o;++a)i[a].execute(t._computeEngine)}function MXe(t,e){t.context.uniformState.updatePass(Pt.OVERLAY);let i=t.context,o=t._overlayCommandList,a=o.length;for(let s=0;s<a;++s)o[s].execute(i,e)}function _Xe(t,e,n){let i=n.shadowMapCullingVolume,o=n.isPointLight,a=n.passes,s=a.length,l=e.length;for(let r=0;r<l;++r){let d=e[r];if(t.updateDerivedCommands(d),d.castShadows&&(d.pass===Pt.GLOBE||d.pass===Pt.CESIUM_3D_TILE||d.pass===Pt.OPAQUE||d.pass===Pt.TRANSLUCENT)&&t.isVisible(d,i))if(o)for(let m=0;m<s;++m)a[m].commandList.push(d);else if(s===1)a[0].commandList.push(d);else{let m=!1;for(let h=s-1;h>=0;--h){let Z=a[h].cullingVolume;if(t.isVisible(d,Z))a[h].commandList.push(d),m=!0;else if(m)break}}}}function wQt(t){let e=t.frameState,n=e.shadowState.shadowMaps,i=n.length;if(!e.shadowState.shadowsEnabled)return;let o=t.context,a=o.uniformState;for(let s=0;s<i;++s){let l=n[s];if(l.outOfView)continue;let r=l.passes,d=r.length;for(let h=0;h<d;++h)r[h].commandList.length=0;let m=t.frameState.commandList;_Xe(t,m,l);for(let h=0;h<d;++h){let Z=l.passes[h];a.updateCamera(Z.camera),l.updatePass(o,h);let b=Z.commandList.length;for(let u=0;u<b;++u){let F=Z.commandList[u];a.updatePass(F.pass),Sd(F.derivedCommands.shadows.castCommands[s],t,o,Z.passState)}}}}var DXe=new p;fo.prototype.updateAndExecuteCommands=function(t,e){let i=this._frameState.mode;this._environmentState.useWebVR?OXe(this,t,e):i!==ut.SCENE2D||this._mapMode2D===eh.ROTATE?SU(!0,this,t,e):(Ust(this,t,e),$Xe(this,t))};function OXe(t,e,n){let i=t._view,o=i.camera,s=t._environmentState.renderTranslucentDepthForPick;Ust(t,e,n),PQt(t),i.createPotentiallyVisibleSet(t),HQt(t),s||wQt(t);let l=e.viewport;l.x=0,l.y=0,l.width=l.width*.5;let r=Aa.clone(o,t._cameraVR);r.frustum=o.frustum;let d=o.frustum.near,m=d*f(t.focalLength,5),h=f(t.eyeSeparation,m/30),Z=p.multiplyByScalar(r.right,h*.5,DXe);o.frustum.aspectRatio=l.width/l.height;let b=.5*h*d/m;p.add(r.position,Z,o.position),o.frustum.xOffset=b,Fst(t,e),l.x=l.width,p.subtract(r.position,Z,o.position),o.frustum.xOffset=-b,Fst(t,e),Aa.clone(r,o)}var HXe=new gt(Math.PI,k.PI_OVER_TWO),wXe=new p,PXe=new p,vXe=new L,KXe=new L,zXe=new p,jXe=new p,qXe=new Fe;function $Xe(t,e){let n=t.context,i=t.frameState,o=t.camera,a=e.viewport,s=Fe.clone(a,qXe);e.viewport=s;let l=HXe,r=wXe;t.mapProjection.project(l,r);let m=p.clone(o.position,PXe),h=L.clone(o.transform,KXe),Z=o.frustum.clone();o._setTransform(L.IDENTITY);let b=L.computeViewportTransformation(s,0,1,vXe),u=o.frustum.projectionMatrix,F=o.positionWC.y,U=p.fromElements(k.sign(F)*r.x-F,0,-o.positionWC.x,zXe),G=Pe.pointToGLWindowCoordinates(u,b,U,jXe);G.x=Math.floor(G.x);let A=s.x,T=s.width;if(F===0||G.x<=A||G.x>=A+T)SU(!0,t,e);else if(Math.abs(A+T*.5-G.x)<1)s.width=G.x-s.x,o.position.x*=k.sign(o.position.x),o.frustum.right=0,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),SU(!0,t,e),s.x=G.x,o.position.x=-o.position.x,o.frustum.right=-o.frustum.left,o.frustum.left=0,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),SU(!1,t,e);else if(G.x>A+T*.5){s.width=G.x-A;let g=o.frustum.right;o.frustum.right=r.x-F,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),SU(!0,t,e),s.x=G.x,s.width=A+T-G.x,o.position.x=-o.position.x,o.frustum.left=-o.frustum.right,o.frustum.right=g-o.frustum.right*2,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),SU(!1,t,e)}else{s.x=G.x,s.width=A+T-G.x;let g=o.frustum.left;o.frustum.left=-r.x-F,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),SU(!0,t,e),s.x=A,s.width=G.x-A,o.position.x=-o.position.x,o.frustum.right=-o.frustum.left,o.frustum.left=g-o.frustum.left*2,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),SU(!1,t,e)}o._setTransform(h),p.clone(m,o.position),o.frustum=Z.clone(),e.viewport=a}function SU(t,e,n,i){let o=e._environmentState,a=e._view,s=o.renderTranslucentDepthForPick;t||(e.frameState.commandList.length=0),PQt(e),a.createPotentiallyVisibleSet(e),t&&(c(i)&&Ust(e,n,i),HQt(e),s||wQt(e)),Fst(e,n)}var _Qt=new Jl;fo.prototype.updateEnvironment=function(){let t=this._frameState,e=this._view,n=this._environmentState,i=t.passes.render,o=t.passes.offscreen,a=this.atmosphere,s=this.skyAtmosphere,l=this.globe,r=this._globeTranslucencyState;if(!i||this._mode!==ut.SCENE2D&&e.camera.frustum instanceof wn||!r.environmentVisible)n.skyAtmosphereCommand=void 0,n.skyBoxCommand=void 0,n.sunDrawCommand=void 0,n.sunComputeCommand=void 0,n.moonCommand=void 0;else{if(c(s)){if(c(l))s.setDynamicLighting(uS.fromGlobeFlags(l)),n.isReadyForAtmosphere=n.isReadyForAtmosphere||!l.show||l._surface._tilesToRender.length>0;else{let G=a.dynamicLighting;s.setDynamicLighting(G),n.isReadyForAtmosphere=!0}n.skyAtmosphereCommand=s.update(t,l),c(n.skyAtmosphereCommand)&&this.updateDerivedCommands(n.skyAtmosphereCommand)}else n.skyAtmosphereCommand=void 0;n.skyBoxCommand=c(this.skyBox)?this.skyBox.update(t,this._hdr):void 0;let U=c(this.sun)?this.sun.update(t,e.passState,this._hdr):void 0;n.sunDrawCommand=c(U)?U.drawCommand:void 0,n.sunComputeCommand=c(U)?U.computeCommand:void 0,n.moonCommand=c(this.moon)?this.moon.update(t):void 0}let d=n.clearGlobeDepth=c(l)&&l.show&&(!l.depthTestAgainstTerrain||this.mode===ut.SCENE2D);(n.useDepthPlane=d&&this.mode===ut.SCENE3D&&r.useDepthPlane)&&this._depthPlane.update(t),n.renderTranslucentDepthForPick=!1,n.useWebVR=this._useWebVR&&this.mode!==ut.SCENE2D&&!o;let h=t.mode===ut.SCENE3D&&!r.sunVisibleThroughGlobe?t.occluder:void 0,Z=t.cullingVolume,b=_Qt.planes;for(let U=0;U<5;++U)b[U]=Z.planes[U];Z=_Qt,n.isSkyAtmosphereVisible=c(n.skyAtmosphereCommand)&&n.isReadyForAtmosphere,n.isSunVisible=this.isVisible(n.sunDrawCommand,Z,h),n.isMoonVisible=this.isVisible(n.moonCommand,Z,h);let u=this.specularEnvironmentMaps,F=this._specularEnvironmentMapAtlas;c(u)&&(!c(F)||F.url!==u)?(F=F&&F.destroy(),this._specularEnvironmentMapAtlas=new dZ(u)):!c(u)&&c(F)&&(F.destroy(),this._specularEnvironmentMapAtlas=void 0),c(this._specularEnvironmentMapAtlas)&&this._specularEnvironmentMapAtlas.update(t)};function tJe(t){let e=t._frameState;t.debugShowFrustumPlanes!==t._debugShowFrustumPlanes&&(t.debugShowFrustumPlanes?t._debugFrustumPlanes=new Jb({camera:t.camera,updateOnChange:!1,frustumSplits:e.frustumSplits}):t._debugFrustumPlanes=t._debugFrustumPlanes&&t._debugFrustumPlanes.destroy(),t._debugShowFrustumPlanes=t.debugShowFrustumPlanes),c(t._debugFrustumPlanes)&&t._debugFrustumPlanes.update(e)}function eJe(t){let e=t._frameState,n=e.shadowMaps,i=n.length,o=i>0&&!e.passes.pick&&!e.passes.pickVoxel&&t.mode===ut.SCENE3D;if(o!==e.shadowState.shadowsEnabled&&(++e.shadowState.lastDirtyTime,e.shadowState.shadowsEnabled=o),e.shadowState.lightShadowsEnabled=!1,!!o){for(let a=0;a<i;++a)if(n[a]!==e.shadowState.shadowMaps[a]){++e.shadowState.lastDirtyTime;break}e.shadowState.shadowMaps.length=0,e.shadowState.lightShadowMaps.length=0;for(let a=0;a<i;++a){let s=n[a];s.update(e),e.shadowState.shadowMaps.push(s),s.fromLightSource&&(e.shadowState.lightShadowMaps.push(s),e.shadowState.lightShadowsEnabled=!0),s.dirty&&(++e.shadowState.lastDirtyTime,s.dirty=!1)}}}function PQt(t){let e=t._frameState;t._groundPrimitives.update(e),t._primitives.update(e),tJe(t),eJe(t),t._globe&&t._globe.render(e)}function Ust(t,e,n){let i=t._context,o=t._frameState,a=t._environmentState,s=t._view,l=t._frameState.passes,r=l.pick||l.pickVoxel;c(s.globeDepth)&&(s.globeDepth.picking=r);let d=a.useWebVR;a.originalFramebuffer=e.framebuffer,c(t.sun)&&t.sunBloom!==t._sunBloom?(t.sunBloom&&!d?t._sunPostProcess=new y9:c(t._sunPostProcess)&&(t._sunPostProcess=t._sunPostProcess.destroy()),t._sunBloom=t.sunBloom):!c(t.sun)&&c(t._sunPostProcess)&&(t._sunPostProcess=t._sunPostProcess.destroy(),t._sunBloom=!1);let m=t._clearColorCommand;v.clone(n,m.color),m.execute(i,e);let h=a.useGlobeDepthFramebuffer=c(s.globeDepth);h&&(s.globeDepth.update(i,e,s.viewport,t.msaaSamples,t._hdr,a.clearGlobeDepth),s.globeDepth.clear(i,e,n));let Z=s.oit,b=a.useOIT=!r&&c(Z)&&Z.isSupported();b&&(Z.update(i,e,s.globeDepth.colorFramebufferManager,t._hdr,t.msaaSamples),Z.clear(i,e,n),a.useOIT=Z.isSupported());let u=t.postProcessStages,F=a.usePostProcess=!r&&(t._hdr||u.length>0||u.ambientOcclusion.enabled||u.fxaa.enabled||u.bloom.enabled);if(a.usePostProcessSelected=!1,F&&(s.sceneFramebuffer.update(i,s.viewport,t._hdr,t.msaaSamples),s.sceneFramebuffer.clear(i,e,n),u.update(i,o.useLogDepth,t._hdr),u.clear(i),F=a.usePostProcess=u.ready,a.usePostProcessSelected=F&&u.hasSelected),a.isSunVisible&&t.sunBloom&&!d?(e.framebuffer=t._sunPostProcess.update(e),t._sunPostProcess.clear(i,e,n)):h?e.framebuffer=s.globeDepth.framebuffer:F&&(e.framebuffer=s.sceneFramebuffer.framebuffer),c(e.framebuffer)&&m.execute(i,e),a.useInvertClassification=!r&&c(e.framebuffer)&&t.invertClassification){let G;if(t.frameState.invertClassificationColor.alpha===1&&a.useGlobeDepthFramebuffer&&(G=s.globeDepth.framebuffer),c(G)||i.depthTexture){if(t._invertClassification.previousFramebuffer=G,t._invertClassification.update(i,t.msaaSamples,s.globeDepth.colorFramebufferManager),t._invertClassification.clear(i,e),t.frameState.invertClassificationColor.alpha<1&&b){let A=t._invertClassification.unclassifiedCommand,T=A.derivedCommands;T.oit=Z.createDerivedCommands(A,i,T.oit)}}else a.useInvertClassification=!1}t._globeTranslucencyState.translucent&&s.globeTranslucencyFramebuffer.updateAndClear(t._hdr,s.viewport,i,e)}fo.prototype.resolveFramebuffers=function(t){let e=this._context,n=this._environmentState,i=this._view,o=i.globeDepth;c(o)&&o.prepareColorTextures(e);let a=n.useOIT,s=n.useGlobeDepthFramebuffer,l=n.usePostProcess,r=n.originalFramebuffer,d=s?o.colorFramebufferManager:void 0,m=i.sceneFramebuffer._colorFramebuffer,h=i.sceneFramebuffer.idFramebuffer;a&&(t.framebuffer=l?m.framebuffer:r,i.oit.execute(e,t));let Z=i.translucentTileClassification;if(Z.hasTranslucentDepth&&Z.isSupported()&&Z.execute(this,t),l){i.sceneFramebuffer.prepareColorTextures(e);let b=m;s&&!a&&(b=d);let u=this.postProcessStages,F=b.getColorTexture(0),U=h.getColorTexture(0),G=f(d,m).getDepthStencilTexture();u.execute(e,F,G,U),u.copy(e,r)}!a&&!l&&s&&(t.framebuffer=r,o.executeCopyColor(e,t))};function nJe(t){let e=t._frameState.afterRender;for(let n=0,i=e.length;n<i;++n)e[n]()&&t.requestRender();e.length=0}function iJe(t){if(t.mode===ut.MORPHING)return;let n=t.camera.positionCartographic;return t.getHeight(n)}fo.prototype.getHeight=function(t,e){if(!c(t))return;let n=e===Ge.CLAMP_TO_TERRAIN||e===Ge.RELATIVE_TO_TERRAIN,i=e===Ge.CLAMP_TO_3D_TILE||e===Ge.RELATIVE_TO_3D_TILE;if(!c(t))return;let o=Number.NEGATIVE_INFINITY;if(!n){let s=this.primitives.length;for(let l=0;l<s;++l){let r=this.primitives.get(l);if(!r.isCesium3DTileset||!r.show||!r.enableCollision)continue;let d=r.getHeight(t,this);c(d)&&d>o&&(o=d)}}let a=this._globe;if(!i&&c(a)&&a.show){let s=a.getHeight(t);s>o&&(o=s)}if(o>Number.NEGATIVE_INFINITY)return o};var fst=new gt;fo.prototype.updateHeight=function(t,e,n){let i=()=>{gt.clone(t,fst);let b=this.getHeight(t,n);c(b)&&(fst.height=b,e(fst))},o=n===Ge.CLAMP_TO_TERRAIN||n===Ge.RELATIVE_TO_TERRAIN,a=n===Ge.CLAMP_TO_3D_TILE||n===Ge.RELATIVE_TO_3D_TILE,s;!a&&c(this.globe)&&(s=this.globe._surface.updateHeight(t,i));let l={},r=this.globe?.ellipsoid,d=b=>{if(o||b.isDestroyed()||!b.isCesium3DTileset)return;let u=b.updateHeight(t,i,r);l[b.id]=u};if(!o){let b=this.primitives.length;for(let u=0;u<b;++u){let F=this.primitives.get(u);d(F)}}let m=this.primitives.primitiveAdded.addEventListener(d),h=this.primitives.primitiveRemoved.addEventListener(b=>{b.isDestroyed()||!b.isCesium3DTileset||(c(l[b.id])&&l[b.id](),delete l[b.id])});return()=>{s=s&&s(),Object.values(l).forEach(b=>b()),l={},m(),h()}};function oJe(t){let e=t.camera,n=t._mode,i=t._screenSpaceCameraController,o=e.positionCartographic;if(!c(o))return!1;if(!i.onMap()&&o.height<0)return!0;if(n===ut.SCENE2D||n===ut.MORPHING)return!1;let a=t._globeHeight;return c(a)&&o.height<a}fo.prototype.initializeFrame=function(){if(this._shaderFrameCount++===120&&(this._shaderFrameCount=0,this._context.shaderCache.destroyReleasedShaderPrograms(),this._context.textureCache.destroyReleasedTextures()),this._tweens.update(),this._globeHeightDirty){c(this._removeUpdateHeightCallback)&&(this._removeUpdateHeightCallback(),this._removeUpdateHeightCallback=void 0),this._globeHeight=iJe(this),this._globeHeightDirty=!1;let t=this.camera.positionCartographic;this._removeUpdateHeightCallback=this.updateHeight(t,e=>{this.isDestroyed()||(this._globeHeight=e.height)})}this._cameraUnderground=oJe(this),this._globeTranslucencyState.update(this),this._screenSpaceCameraController.update(),c(this._deviceOrientationCameraController)&&this._deviceOrientationCameraController.update(),this.camera.update(this._mode),this.camera._updateCameraChanged()};function aJe(t,e){if(t.debugShowFramesPerSecond){if(!c(t._performanceDisplay)){let n=document.createElement("div");n.className="cesium-performanceDisplay-defaultContainer",t._canvas.parentNode.appendChild(n);let o=new bW({container:n});t._performanceDisplay=o,t._performanceContainer=n}t._performanceDisplay.throttled=t.requestRenderMode,t._performanceDisplay.update(e)}else c(t._performanceDisplay)&&(t._performanceDisplay=t._performanceDisplay&&t._performanceDisplay.destroy(),t._performanceContainer.parentNode.removeChild(t._performanceContainer))}function sJe(t){t._jobScheduler.resetBudgets();let e=t._frameState;t.primitives.prePassesUpdate(e),c(t.globe)&&t.globe.update(e),t._picking.update(),e.creditDisplay.update()}function lJe(t){let e=t._frameState;t.primitives.postPassesUpdate(e),xd.update()}var rJe=new v;function dJe(t){let e=t._frameState,n=t.context,i=n.uniformState,o=t._defaultView;t._view=o,t.updateFrameState(),e.passes.render=!0,e.passes.postProcess=t.postProcessStages.hasSelected,e.tilesetPassState=CXe;let a=f(t.backgroundColor,v.BLACK);t._hdr&&(a=v.clone(a,rJe),a.red=Math.pow(a.red,t.gamma),a.green=Math.pow(a.green,t.gamma),a.blue=Math.pow(a.blue,t.gamma)),e.backgroundColor=a,e.atmosphere=t.atmosphere,t.fog.update(e),i.update(e);let s=t.shadowMap;c(s)&&s.enabled&&(!c(t.light)||t.light instanceof gR?p.negate(i.sunDirectionWC,t._shadowMapCamera.direction):p.clone(t.light.direction,t._shadowMapCamera.direction),e.shadowMaps.push(s)),t._computeCommandList.length=0,t._overlayCommandList.length=0;let l=o.viewport;l.x=0,l.y=0,l.width=n.drawingBufferWidth,l.height=n.drawingBufferHeight;let r=o.passState;r.framebuffer=void 0,r.blendingEnabled=void 0,r.scissorTest=void 0,r.viewport=Fe.clone(l,r.viewport),c(t.globe)&&t.globe.beginFrame(e),t.updateEnvironment(),t.updateAndExecuteCommands(r,a),t.resolveFramebuffers(r),r.framebuffer=void 0,MXe(t,r),c(t.globe)&&(t.globe.endFrame(e),t.globe.tilesLoaded||(t._renderRequested=!0)),n.endFrame()}function MS(t,e){try{e(t)}catch(n){if(t._renderError.raiseEvent(t,n),t.rethrowRenderErrors)throw n}}function cJe(t){return t._picking.updateMostDetailedRayPicks(t)}fo.prototype.render=function(t){this._preUpdate.raiseEvent(this,t);let e=this._frameState;e.newFrame=!1,c(t)||(t=rt.now());let n=this._view.checkForCameraUpdates(this);n&&(this._globeHeightDirty=!0);let i=!this.requestRenderMode||this._renderRequested||n||this._logDepthBufferDirty||this._hdrDirty||this.mode===ut.MORPHING;if(!i&&c(this.maximumRenderTimeChange)&&c(this._lastRenderTime)){let o=Math.abs(rt.secondsDifference(this._lastRenderTime,t));i=i||o>this.maximumRenderTimeChange}if(i){this._lastRenderTime=rt.clone(t,this._lastRenderTime),this._renderRequested=!1,this._logDepthBufferDirty=!1,this._hdrDirty=!1;let o=k.incrementWrap(e.frameNumber,15e6,1);DQt(this,o,t),e.newFrame=!0}MS(this,sJe),this.primitives.show&&(MS(this,cJe),MS(this,mJe),MS(this,hJe),i||MS(this,pJe)),this._postUpdate.raiseEvent(this,t),i&&(this._preRender.raiseEvent(this,t),e.creditDisplay.beginFrame(),MS(this,dJe)),aJe(this,i),MS(this,lJe),nJe(this),i&&(this._postRender.raiseEvent(this,t),e.creditDisplay.endFrame())};fo.prototype.forceRender=function(t){this._renderRequested=!0,this.render(t)};fo.prototype.requestRender=function(){this._renderRequested=!0};fo.prototype.clampLineWidth=function(t){return Math.max(Sn.minimumAliasedLineWidth,Math.min(t,Sn.maximumAliasedLineWidth))};fo.prototype.pick=function(t,e,n){return this._picking.pick(this,t,e,n)};fo.prototype.pickVoxel=function(t,e,n){let i=this.pick(t,e,n);if(!c(i))return;let o=i.primitive;if(!(o instanceof TU))return;let a=this._picking.pickVoxelCoordinate(this,t,e,n),s=255*a[0]+a[1],l=o._traversal.findKeyframeNode(s);if(!c(l))return;let r=255*a[2]+a[3];return k9.fromKeyframeNode(o,s,r,l)};fo.prototype.pickPositionWorldCoordinates=function(t,e){return this._picking.pickPositionWorldCoordinates(this,t,e)};fo.prototype.pickPosition=function(t,e){return this._picking.pickPosition(this,t,e)};fo.prototype.drillPick=function(t,e,n,i){return this._picking.drillPick(this,t,e,n,i)};function mJe(t){let e=t._frameState;bst.camera=e.camera,bst.cullingVolume=e.cullingVolume,t.primitives.updateForPass(e,bst)}function hJe(t){let e=t._frameState;if(!e.camera.canPreloadFlight())return;Rst.camera=t.preloadFlightCamera,Rst.cullingVolume=t.preloadFlightCullingVolume,t.primitives.updateForPass(e,Rst)}function pJe(t){t.primitives.updateForPass(t._frameState,IXe)}fo.prototype.pickFromRay=function(t,e,n){return this._picking.pickFromRay(this,t,e,n)};fo.prototype.drillPickFromRay=function(t,e,n,i){return this._picking.drillPickFromRay(this,t,e,n,i)};fo.prototype.pickFromRayMostDetailed=function(t,e,n){return this._picking.pickFromRayMostDetailed(this,t,e,n)};fo.prototype.drillPickFromRayMostDetailed=function(t,e,n,i){return this._picking.drillPickFromRayMostDetailed(this,t,e,n,i)};fo.prototype.sampleHeight=function(t,e,n){return this._picking.sampleHeight(this,t,e,n)};fo.prototype.clampToHeight=function(t,e,n,i){return this._picking.clampToHeight(this,t,e,n,i)};fo.prototype.sampleHeightMostDetailed=function(t,e,n){return this._picking.sampleHeightMostDetailed(this,t,e,n)};fo.prototype.clampToHeightMostDetailed=function(t,e,n){return this._picking.clampToHeightMostDetailed(this,t,e,n)};fo.prototype.cartesianToCanvasCoordinates=function(t,e){return qo.wgs84ToWindowCoordinates(this,t,e)};fo.prototype.completeMorph=function(){this._transitioner.completeMorph()};fo.prototype.morphTo2D=function(t){let e,n=this.globe;c(n)?e=n.ellipsoid:e=this.mapProjection.ellipsoid,t=f(t,2),this._transitioner.morphTo2D(t,e)};fo.prototype.morphToColumbusView=function(t){let e,n=this.globe;c(n)?e=n.ellipsoid:e=this.mapProjection.ellipsoid,t=f(t,2),this._transitioner.morphToColumbusView(t,e)};fo.prototype.morphTo3D=function(t){let e,n=this.globe;c(n)?e=n.ellipsoid:e=this.mapProjection.ellipsoid,t=f(t,2),this._transitioner.morphTo3D(t,e)};function uJe(t,e){if(t._removeTerrainProviderReadyListener=t._removeTerrainProviderReadyListener&&t._removeTerrainProviderReadyListener(),e.ready){c(t.globe)&&(t.globe.terrainProvider=e.provider);return}t.globe.terrainProvider=void 0,t._removeTerrainProviderReadyListener=e.readyEvent.addEventListener(n=>{c(t)&&c(t.globe)&&(t.globe.terrainProvider=n),t._removeTerrainProviderReadyListener()})}fo.prototype.setTerrain=function(t){return uJe(this,t),t};fo.prototype.isDestroyed=function(){return!1};fo.prototype.destroy=function(){this._tweens.removeAll(),this._computeEngine=this._computeEngine&&this._computeEngine.destroy(),this._screenSpaceCameraController=this._screenSpaceCameraController&&this._screenSpaceCameraController.destroy(),this._deviceOrientationCameraController=this._deviceOrientationCameraController&&!this._deviceOrientationCameraController.isDestroyed()&&this._deviceOrientationCameraController.destroy(),this._primitives=this._primitives&&this._primitives.destroy(),this._groundPrimitives=this._groundPrimitives&&this._groundPrimitives.destroy(),this._globe=this._globe&&this._globe.destroy(),this._removeTerrainProviderReadyListener=this._removeTerrainProviderReadyListener&&this._removeTerrainProviderReadyListener(),this.skyBox=this.skyBox&&this.skyBox.destroy(),this.skyAtmosphere=this.skyAtmosphere&&this.skyAtmosphere.destroy(),this._debugSphere=this._debugSphere&&this._debugSphere.destroy(),this.sun=this.sun&&this.sun.destroy(),this._sunPostProcess=this._sunPostProcess&&this._sunPostProcess.destroy(),this._depthPlane=this._depthPlane&&this._depthPlane.destroy(),this._transitioner=this._transitioner&&this._transitioner.destroy(),this._debugFrustumPlanes=this._debugFrustumPlanes&&this._debugFrustumPlanes.destroy(),this._brdfLutGenerator=this._brdfLutGenerator&&this._brdfLutGenerator.destroy(),this._picking=this._picking&&this._picking.destroy(),this._defaultView=this._defaultView&&this._defaultView.destroy(),this._view=void 0,this._removeCreditContainer&&this._canvas.parentNode.removeChild(this._creditContainer),this.postProcessStages=this.postProcessStages&&this.postProcessStages.destroy(),this._context=this._context&&this._context.destroy(),this._frameState.creditDisplay=this._frameState.creditDisplay&&this._frameState.creditDisplay.destroy(),c(this._performanceDisplay)&&(this._performanceDisplay=this._performanceDisplay&&this._performanceDisplay.destroy(),this._performanceContainer.parentNode.removeChild(this._performanceContainer)),this._removeRequestListenerCallback(),this._removeTaskProcessorListenerCallback();for(let t=0;t<this._removeGlobeCallbacks.length;++t)this._removeGlobeCallbacks[t]();return this._removeGlobeCallbacks.length=0,c(this._removeUpdateHeightCallback)&&(this._removeUpdateHeightCallback(),this._removeUpdateHeightCallback=void 0),At(this)};var s5=fo;var OMo=R(W(),1);var uMo=R(W(),1),j1=`float interpolateByDistance(vec4 nearFarScalar, float distance) +}`});function JQt(){this.ready=!0,this.shape=_o.BOX,this.dimensions=new p(1,1,1),this.names=["data"],this.types=[Nn.SCALAR],this.componentTypes=[vn.FLOAT32],this.maximumTileCount=1}JQt.prototype.requestData=function(t){if(!((c(t)?f(t.tileLevel,0):0)>=1))return Promise.resolve([new Float32Array(1)])};KR.DefaultProvider=new JQt;var SU=KR;var Nj=function(t){return function(){t.frameState.afterRender.push(function(){t.requestRender()})}};function fo(t){t=f(t,f.EMPTY_OBJECT);let e=t.canvas,n=t.creditContainer,i=t.creditViewport,o=Re(t.contextOptions),a=c(n),s=new ak(e,o);a||(n=document.createElement("div"),n.style.position="absolute",n.style.bottom="0",n.style["text-shadow"]="0 0 2px #000000",n.style.color="#ffffff",n.style["font-size"]="10px",n.style["padding-right"]="5px",e.parentNode.appendChild(n)),c(i)||(i=e.parentNode),this._id=Ti(),this._jobScheduler=new L_,this._frameState=new X_(s,new T_(n," \u2022 ",i),this._jobScheduler),this._frameState.scene3DOnly=f(t.scene3DOnly,!1),this._removeCreditContainer=!a,this._creditContainer=n,this._canvas=e,this._context=s,this._computeEngine=new uy(s),this._globe=void 0,this._globeTranslucencyState=new J_,this._primitives=new Dm,this._groundPrimitives=new Dm,this._globeHeight=void 0,this._globeHeightDirty=!0,this._cameraUnderground=!1,this._removeUpdateHeightCallback=void 0,this._logDepthBuffer=fo.defaultLogDepthBuffer&&s.fragmentDepth,this._logDepthBufferDirty=!0,this._tweens=new yT,this._shaderFrameCount=0,this._sunPostProcess=void 0,this._computeCommandList=[],this._overlayCommandList=[],this._useOIT=f(t.orderIndependentTranslucency,!0),this._executeOITFunction=void 0,this._depthPlane=new Q_(t.depthPlaneEllipsoidOffset),this._clearColorCommand=new ao({color:new v,stencil:0,owner:this}),this._depthClearCommand=new ao({depth:1,owner:this}),this._stencilClearCommand=new ao({stencil:0}),this._classificationStencilClearCommand=new ao({stencil:0,renderState:he.fromCache({stencilMask:gn.CLASSIFICATION_MASK})}),this._depthOnlyRenderStateCache={},this._transitioner=new S9(this),this._preUpdate=new It,this._postUpdate=new It,this._renderError=new It,this._preRender=new It,this._postRender=new It,this._minimumDisableDepthTestDistance=0,this._debugInspector=new Q9,this._msaaSamples=f(t.msaaSamples,1),this.rethrowRenderErrors=!1,this.completeMorphOnUserInput=!0,this.morphStart=new It,this.morphComplete=new It,this.skyBox=void 0,this.skyAtmosphere=void 0,this.sun=void 0,this.sunBloom=!0,this._sunBloom=void 0,this.moon=void 0,this.backgroundColor=v.clone(v.BLACK),this._mode=Vt.SCENE3D,this._mapProjection=c(t.mapProjection)?t.mapProjection:new yo,this.morphTime=1,this.farToNearRatio=1e3,this.logarithmicDepthFarToNearRatio=1e9,this.nearToFarDistance2D=175e4,this.verticalExaggeration=1,this.verticalExaggerationRelativeHeight=0,this.debugCommandFilter=void 0,this.debugShowCommands=!1,this.debugShowFrustums=!1,this.debugShowFramesPerSecond=!1,this.debugShowDepthFrustum=1,this.debugShowFrustumPlanes=!1,this._debugShowFrustumPlanes=!1,this._debugFrustumPlanes=void 0,this.useDepthPicking=!0,this.pickTranslucentDepth=!1,this.cameraEventWaitTime=500,this.atmosphere=new R_,this.fog=new x_,this._shadowMapCamera=new Aa(this),this.shadowMap=new fW({context:s,lightCamera:this._shadowMapCamera,enabled:f(t.shadows,!1)}),this.invertClassification=!1,this.invertClassificationColor=v.clone(v.WHITE),this._actualInvertClassificationColor=v.clone(this._invertClassificationColor),this._invertClassification=new M1,this.focalLength=void 0,this.eyeSeparation=void 0,this.postProcessStages=new U9,this._brdfLutGenerator=new f_,this._performanceDisplay=void 0,this._debugVolume=void 0,this._screenSpaceCameraController=new C9(this),this._cameraUnderground=!1,this._mapMode2D=f(t.mapMode2D,eh.INFINITE_SCROLL),this._environmentState={skyBoxCommand:void 0,skyAtmosphereCommand:void 0,sunDrawCommand:void 0,sunComputeCommand:void 0,moonCommand:void 0,isSunVisible:!1,isMoonVisible:!1,isReadyForAtmosphere:!1,isSkyAtmosphereVisible:!1,clearGlobeDepth:!1,useDepthPlane:!1,renderTranslucentDepthForPick:!1,originalFramebuffer:void 0,useGlobeDepthFramebuffer:!1,useOIT:!1,useInvertClassification:!1,usePostProcess:!1,usePostProcessSelected:!1,useWebVR:!1},this._useWebVR=!1,this._cameraVR=void 0,this._aspectRatioVR=void 0,this.requestRenderMode=f(t.requestRenderMode,!1),this._renderRequested=!0,this.maximumRenderTimeChange=f(t.maximumRenderTimeChange,0),this._lastRenderTime=void 0,this._frameRateMonitor=void 0,this._removeRequestListenerCallback=xd.requestCompletedEvent.addEventListener(Nj(this)),this._removeTaskProcessorListenerCallback=$i.taskCompletedEvent.addEventListener(Nj(this)),this._removeGlobeCallbacks=[],this._removeTerrainProviderReadyListener=void 0;let l=new Fe(0,0,s.drawingBufferWidth,s.drawingBufferHeight),r=new Aa(this);this._logDepthBuffer&&(r.frustum.near=.1,r.frustum.far=1e10),this.preloadFlightCamera=new Aa(this),this.preloadFlightCullingVolume=void 0,this._picking=new $_(this),this._defaultView=new AT(this,r,l),this._view=this._defaultView,this._hdr=void 0,this._hdrDirty=void 0,this.highDynamicRange=!1,this.gamma=2.2,this.sphericalHarmonicCoefficients=void 0,this.specularEnvironmentMaps=void 0,this._specularEnvironmentMapAtlas=void 0,this.light=new gb,DQt(this,0,rt.now()),this.updateFrameState(),this.initializeFrame()}fo.defaultLogDepthBuffer=!0;function EXe(t,e){for(let i=0;i<t._removeGlobeCallbacks.length;++i)t._removeGlobeCallbacks[i]();t._removeGlobeCallbacks.length=0;let n=[];c(e)&&(n.push(e.imageryLayersUpdatedEvent.addEventListener(Nj(t))),n.push(e.terrainProviderChanged.addEventListener(Nj(t)))),t._removeGlobeCallbacks=n}Object.defineProperties(fo.prototype,{canvas:{get:function(){return this._canvas}},drawingBufferHeight:{get:function(){return this._context.drawingBufferHeight}},drawingBufferWidth:{get:function(){return this._context.drawingBufferWidth}},maximumAliasedLineWidth:{get:function(){return Tn.maximumAliasedLineWidth}},maximumCubeMapSize:{get:function(){return Tn.maximumCubeMapSize}},pickPositionSupported:{get:function(){return this._context.depthTexture}},sampleHeightSupported:{get:function(){return this._context.depthTexture}},clampToHeightSupported:{get:function(){return this._context.depthTexture}},invertClassificationSupported:{get:function(){return this._context.depthTexture}},specularEnvironmentMapsSupported:{get:function(){return du.isSupported(this._context)}},globe:{get:function(){return this._globe},set:function(t){this._globe=this._globe&&this._globe.destroy(),this._globe=t,EXe(this,t)}},primitives:{get:function(){return this._primitives}},groundPrimitives:{get:function(){return this._groundPrimitives}},camera:{get:function(){return this._view.camera},set:function(t){this._view.camera=t}},view:{get:function(){return this._view},set:function(t){this._view=t}},defaultView:{get:function(){return this._defaultView}},picking:{get:function(){return this._picking}},screenSpaceCameraController:{get:function(){return this._screenSpaceCameraController}},mapProjection:{get:function(){return this._mapProjection}},jobScheduler:{get:function(){return this._jobScheduler}},frameState:{get:function(){return this._frameState}},environmentState:{get:function(){return this._environmentState}},tweens:{get:function(){return this._tweens}},imageryLayers:{get:function(){if(c(this.globe))return this.globe.imageryLayers}},terrainProvider:{get:function(){if(c(this.globe))return this.globe.terrainProvider},set:function(t){this._removeTerrainProviderReadyListener=this._removeTerrainProviderReadyListener&&this._removeTerrainProviderReadyListener(),c(this.globe)&&(this.globe.terrainProvider=t)}},terrainProviderChanged:{get:function(){if(c(this.globe))return this.globe.terrainProviderChanged}},preUpdate:{get:function(){return this._preUpdate}},postUpdate:{get:function(){return this._postUpdate}},renderError:{get:function(){return this._renderError}},preRender:{get:function(){return this._preRender}},postRender:{get:function(){return this._postRender}},lastRenderTime:{get:function(){return this._lastRenderTime}},context:{get:function(){return this._context}},debugFrustumStatistics:{get:function(){return this._view.debugFrustumStatistics}},scene3DOnly:{get:function(){return this._frameState.scene3DOnly}},orderIndependentTranslucency:{get:function(){return this._useOIT}},id:{get:function(){return this._id}},mode:{get:function(){return this._mode},set:function(t){t===Vt.SCENE2D?this.morphTo2D(0):t===Vt.SCENE3D?this.morphTo3D(0):t===Vt.COLUMBUS_VIEW&&this.morphToColumbusView(0),this._mode=t}},frustumCommandsList:{get:function(){return this._view.frustumCommandsList}},numberOfFrustums:{get:function(){return this._view.frustumCommandsList.length}},useWebVR:{get:function(){return this._useWebVR},set:function(t){this._useWebVR=t,this._useWebVR?(this._frameState.creditDisplay.container.style.visibility="hidden",this._cameraVR=new Aa(this),c(this._deviceOrientationCameraController)||(this._deviceOrientationCameraController=new Y_(this)),this._aspectRatioVR=this.camera.frustum.aspectRatio):(this._frameState.creditDisplay.container.style.visibility="visible",this._cameraVR=void 0,this._deviceOrientationCameraController=this._deviceOrientationCameraController&&!this._deviceOrientationCameraController.isDestroyed()&&this._deviceOrientationCameraController.destroy(),this.camera.frustum.aspectRatio=this._aspectRatioVR,this.camera.frustum.xOffset=0)}},mapMode2D:{get:function(){return this._mapMode2D}},splitPosition:{get:function(){return this._frameState.splitPosition},set:function(t){this._frameState.splitPosition=t}},minimumDisableDepthTestDistance:{get:function(){return this._minimumDisableDepthTestDistance},set:function(t){this._minimumDisableDepthTestDistance=t}},logarithmicDepthBuffer:{get:function(){return this._logDepthBuffer},set:function(t){t=this._context.fragmentDepth&&t,this._logDepthBuffer!==t&&(this._logDepthBuffer=t,this._logDepthBufferDirty=!0)}},gamma:{get:function(){return this._context.uniformState.gamma},set:function(t){this._context.uniformState.gamma=t}},highDynamicRange:{get:function(){return this._hdr},set:function(t){let e=this._context,n=t&&e.depthTexture&&(e.colorBufferFloat||e.colorBufferHalfFloat);this._hdrDirty=n!==this._hdr,this._hdr=n}},highDynamicRangeSupported:{get:function(){let t=this._context;return t.depthTexture&&(t.colorBufferFloat||t.colorBufferHalfFloat)}},cameraUnderground:{get:function(){return this._cameraUnderground}},msaaSamples:{get:function(){return this._msaaSamples},set:function(t){t=Math.min(t,Tn.maximumSamples),this._msaaSamples=t}},msaaSupported:{get:function(){return this._context.msaa}},pixelRatio:{get:function(){return this._frameState.pixelRatio},set:function(t){this._frameState.pixelRatio=t}},opaqueFrustumNearOffset:{get:function(){return .9999}},globeHeight:{get:function(){return this._globeHeight}}});fo.prototype.getCompressedTextureFormatSupported=function(t){let e=this.context;return(t==="WEBGL_compressed_texture_s3tc"||t==="s3tc")&&e.s3tc||(t==="WEBGL_compressed_texture_pvrtc"||t==="pvrtc")&&e.pvrtc||(t==="WEBGL_compressed_texture_etc"||t==="etc")&&e.etc||(t==="WEBGL_compressed_texture_etc1"||t==="etc1")&&e.etc1||(t==="WEBGL_compressed_texture_astc"||t==="astc")&&e.astc||(t==="EXT_texture_compression_bptc"||t==="bc7")&&e.bc7};function LQt(t,e,n){let i=t._frameState,o=t._context,a=t._view.oit,s=i.shadowState.lightShadowMaps,l=i.shadowState.lightShadowsEnabled,r=e.derivedCommands;c(e.pickId)&&(r.picking=ZW.createPickDerivedCommand(t,e,o,r.picking)),e.pickOnly||(r.depth=ZW.createDepthOnlyDerivedCommand(t,e,o,r.depth)),r.originalCommand=e,t._hdr&&(r.hdr=ZW.createHdrCommand(e,o,r.hdr),e=r.hdr.command,r=e.derivedCommands),l&&e.receiveShadows&&(r.shadows=fW.createReceiveDerivedCommand(s,e,n,o,r.shadows)),e.pass===Pt.TRANSLUCENT&&c(a)&&a.isSupported()&&(l&&e.receiveShadows?(r.oit=c(r.oit)?r.oit:{},r.oit.shadows=a.createDerivedCommands(r.shadows.receiveCommand,o,r.oit.shadows)):r.oit=a.createDerivedCommands(e,o,r.oit))}fo.prototype.updateDerivedCommands=function(t){if(!c(t.derivedCommands))return;let e=this._frameState,n=this._context,i=!1,o=e.shadowState.lastDirtyTime;t.lastDirtyTime!==o&&(t.lastDirtyTime=o,t.dirty=!0,i=!0);let a=e.useLogDepth,s=this._hdr,l=t.derivedCommands,r=c(l.logDepth),d=c(l.hdr),m=c(l.originalCommand),h=a&&!r,u=s&&!d,R=(!a||!s)&&!m;if(t.dirty=t.dirty||h||u||R,t.dirty){t.dirty=!1;let V=e.shadowState.shadowMaps;e.shadowState.shadowsEnabled&&t.castShadows&&(l.shadows=fW.createCastDerivedCommand(V,t,i,n,l.shadows)),(r||h)&&(l.logDepth=ZW.createLogDepthCommand(t,n,l.logDepth),LQt(this,l.logDepth.command,i)),(m||R)&&LQt(this,t,i)}};var CXe=new EV({pass:ns.RENDER}),Rst=new EV({pass:ns.PRELOAD}),bst=new EV({pass:ns.PRELOAD_FLIGHT}),IXe=new EV({pass:ns.REQUEST_RENDER_MODE_DEFER_CHECK}),MQt=new Ft,Wst;function NXe(t){let e=t.globe;if(t._mode===Vt.SCENE3D&&c(e)&&e.show&&!t._cameraUnderground&&!t._globeTranslucencyState.translucent){let n=e.ellipsoid,i=t.frameState.minimumTerrainHeight;return MQt.radius=n.minimumRadius+i,Wst=u_.fromBoundingSphere(MQt,t.camera.positionWC,Wst),Wst}}fo.prototype.clearPasses=function(t){t.render=!1,t.pick=!1,t.pickVoxel=!1,t.depth=!1,t.postProcess=!1,t.offscreen=!1};function DQt(t,e,n){let i=t._frameState;i.frameNumber=e,i.time=rt.clone(n,i.time)}fo.prototype.updateFrameState=function(){let t=this.camera,e=this._frameState;e.commandList.length=0,e.shadowMaps.length=0,e.brdfLutGenerator=this._brdfLutGenerator,e.environmentMap=this.skyBox&&this.skyBox._cubeMap,e.mode=this._mode,e.morphTime=this.morphTime,e.mapProjection=this.mapProjection,e.camera=t,e.cullingVolume=t.frustum.computeCullingVolume(t.positionWC,t.directionWC,t.upWC),e.occluder=NXe(this),e.minimumTerrainHeight=0,e.minimumDisableDepthTestDistance=this._minimumDisableDepthTestDistance,e.invertClassification=this.invertClassification,e.useLogDepth=this._logDepthBuffer&&!(this.camera.frustum instanceof wn||this.camera.frustum instanceof el),e.light=this.light,e.cameraUnderground=this._cameraUnderground,e.globeTranslucencyState=this._globeTranslucencyState;let{globe:n}=this;c(n)&&n._terrainExaggerationChanged&&(this.verticalExaggeration=n._terrainExaggeration,this.verticalExaggerationRelativeHeight=n._terrainExaggerationRelativeHeight,n._terrainExaggerationChanged=!1),e.verticalExaggeration=this.verticalExaggeration,e.verticalExaggerationRelativeHeight=this.verticalExaggerationRelativeHeight,c(this._specularEnvironmentMapAtlas)&&this._specularEnvironmentMapAtlas.ready?(e.specularEnvironmentMaps=this._specularEnvironmentMapAtlas.texture,e.specularEnvironmentMapsMaximumLOD=this._specularEnvironmentMapAtlas.maximumMipmapLevel):(e.specularEnvironmentMaps=void 0,e.specularEnvironmentMapsMaximumLOD=void 0),e.sphericalHarmonicCoefficients=this.sphericalHarmonicCoefficients,this._actualInvertClassificationColor=v.clone(this.invertClassificationColor,this._actualInvertClassificationColor),M1.isTranslucencySupported(this._context)||(this._actualInvertClassificationColor.alpha=1),e.invertClassificationColor=this._actualInvertClassificationColor,c(this.globe)?e.maximumScreenSpaceError=this.globe.maximumScreenSpaceError:e.maximumScreenSpaceError=2,this.clearPasses(e.passes),e.tilesetPassState=void 0};fo.prototype.isVisible=function(t,e,n){return c(t)&&(!c(t.boundingVolume)||!t.cull||e.computeVisibility(t.boundingVolume)!==yn.OUTSIDE&&(!c(n)||!t.occlude||!t.boundingVolume.isOccluded(n)))};var Ij=new L(0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1);Ij=L.inverseTransformation(Ij,Ij);function yXe(t,e,n,i){let o=e._frameState,a=o.context,s=t.boundingVolume;c(e._debugVolume)&&e._debugVolume.destroy();let l,r=p.clone(s.center);if(o.mode!==Vt.SCENE3D){r=L.multiplyByPoint(Ij,r,r);let u=o.mapProjection,R=u.unproject(r);r=u.ellipsoid.cartographicToCartesian(R)}if(c(s.radius)){let u=s.radius;l=gi.toWireframe(Cr.createGeometry(new Cr({radii:new p(u,u,u),vertexFormat:jn.FLAT_VERTEX_FORMAT}))),e._debugVolume=new Wi({geometryInstances:new $e({geometry:l,modelMatrix:L.fromTranslation(r),attributes:{color:new En(1,0,0,1)}}),appearance:new jn({flat:!0,translucent:!1}),asynchronous:!1})}else{let u=s.halfAxes;l=gi.toWireframe(Am.createGeometry(Am.fromDimensions({dimensions:new p(2,2,2),vertexFormat:jn.FLAT_VERTEX_FORMAT}))),e._debugVolume=new Wi({geometryInstances:new $e({geometry:l,modelMatrix:L.fromRotationTranslation(u,r,new L),attributes:{color:new En(1,0,0,1)}}),appearance:new jn({flat:!0,translucent:!1}),asynchronous:!1})}let d=o.commandList,m=o.commandList=[];e._debugVolume.update(o),t=m[0],o.useLogDepth&&(t=ZW.createLogDepthCommand(t,a).command);let h;c(i)&&(h=n.framebuffer,n.framebuffer=i),t.execute(a,n),c(h)&&(n.framebuffer=h),o.commandList=d}function Td(t,e,n,i,o){let a=e._frameState;if(c(e.debugCommandFilter)&&!e.debugCommandFilter(t))return;if(t instanceof ao){t.execute(n,i);return}t.debugShowBoundingVolume&&c(t.boundingVolume)&&yXe(t,e,i,o),a.useLogDepth&&c(t.derivedCommands.logDepth)&&(t=t.derivedCommands.logDepth.command);let s=a.passes;if(!s.pick&&!s.pickVoxel&&!s.depth&&e._hdr&&c(t.derivedCommands)&&c(t.derivedCommands.hdr)&&(t=t.derivedCommands.hdr.command),s.pick||s.depth){if(s.pick&&!s.depth&&c(t.derivedCommands.picking)){t=t.derivedCommands.picking.pickCommand,t.execute(n,i);return}else if(c(t.derivedCommands.depth)){t=t.derivedCommands.depth.depthOnlyCommand,t.execute(n,i);return}}if(e.debugShowCommands||e.debugShowFrustums){e._debugInspector.executeDebugShowFrustumsCommand(e,t,i);return}a.shadowState.lightShadowsEnabled&&t.receiveShadows&&c(t.derivedCommands.shadows)?t.derivedCommands.shadows.receiveCommand.execute(n,i):t.execute(n,i)}function a5(t,e,n,i){let o=e._frameState,a=t.derivedCommands;c(a)&&(o.useLogDepth&&c(a.logDepth)&&(t=a.logDepth.command),a=t.derivedCommands,c(a.picking)?(t=a.picking.pickCommand,t.execute(n,i)):c(a.depth)&&(t=a.depth.depthOnlyCommand,t.execute(n,i)))}function OQt(t,e,n){return e.boundingVolume.distanceSquaredTo(n)-t.boundingVolume.distanceSquaredTo(n)}function BXe(t,e,n){return t.boundingVolume.distanceSquaredTo(n)-e.boundingVolume.distanceSquaredTo(n)+k.EPSILON12}function QXe(t,e,n,i,o){let a=t.context;uW(i,OQt,t.camera.positionWC),c(o)&&e(o.unclassifiedCommand,t,a,n);let s=i.length;for(let l=0;l<s;++l)e(i[l],t,a,n)}function kXe(t,e,n,i,o){let a=t.context;uW(i,BXe,t.camera.positionWC),c(o)&&e(o.unclassifiedCommand,t,a,n);let s=i.length;for(let l=0;l<s;++l)e(i[l],t,a,n)}function YXe(t,e,n,i){let o=t.context;uW(i,OQt,t.camera.positionWC);let a=i.length;for(let s=0;s<a;++s)e(i[s],t,o,n)}var xXe=new Io,XXe=new em,JXe=new wn,LXe=new el;function Fst(t,e){let{camera:n,context:i,frameState:o}=t,{uniformState:a}=i;a.updateCamera(n);let s;c(n.frustum.fov)?s=n.frustum.clone(xXe):c(n.frustum.infiniteProjectionMatrix)?s=n.frustum.clone(XXe):c(n.frustum.width)?s=n.frustum.clone(JXe):s=n.frustum.clone(LXe),s.near=n.frustum.near,s.far=n.frustum.far,a.updateFrustum(s),a.updatePass(Pt.ENVIRONMENT);let l=o.passes,r=l.pick||l.pickVoxel,d=t._environmentState,m=t._view,h=d.renderTranslucentDepthForPick,u=d.useWebVR;if(!r){let E=d.skyBoxCommand;if(c(E)&&Td(E,t,i,e),d.isSkyAtmosphereVisible&&Td(d.skyAtmosphereCommand,t,i,e),d.isSunVisible&&(d.sunDrawCommand.execute(i,e),t.sunBloom&&!u)){let I;d.useGlobeDepthFramebuffer?I=m.globeDepth.framebuffer:d.usePostProcess?I=m.sceneFramebuffer.framebuffer:I=d.originalFramebuffer,t._sunPostProcess.execute(i),t._sunPostProcess.copy(i,I),e.framebuffer=I}d.isMoonVisible&&d.moonCommand.execute(i,e)}let R;d.useOIT?(c(t._executeOITFunction)||(t._executeOITFunction=function(E,I,B,X,_){m.globeDepth.prepareColorTextures(i),m.oit.executeCommands(E,I,B,X,_)}),R=t._executeOITFunction):l.render?R=QXe:R=kXe;let V=m.frustumCommandsList,F=V.length,U=d.clearGlobeDepth,G=d.useDepthPlane,A=t._globeTranslucencyState,S=A.translucent,g=t._view.globeTranslucencyFramebuffer,C=t._depthClearCommand,y=t._stencilClearCommand,Y=t._classificationStencilClearCommand,Q=t._depthPlane,J=d.usePostProcessSelected,M=n.position.z,Z;for(let E=0;E<F;++E){let I=F-E-1,B=V[I];t.mode===Vt.SCENE2D?(n.position.z=M-B.near+1,s.far=Math.max(1,B.far-B.near),s.near=1,a.update(o),a.updateFrustum(s)):(s.near=I!==0?B.near*t.opaqueFrustumNearOffset:B.near,s.far=B.far,a.updateFrustum(s)),C.execute(i,e),i.stencilBuffer&&y.execute(i,e),a.updatePass(Pt.GLOBE);let X=B.commands[Pt.GLOBE],_=B.indices[Pt.GLOBE];if(S)A.executeGlobeCommands(B,Td,g,t,e);else for(Z=0;Z<_;++Z)Td(X[Z],t,i,e);let P=m.globeDepth;if(c(P)&&d.useGlobeDepthFramebuffer&&P.executeCopyDepth(i,e),!d.renderTranslucentDepthForPick)if(a.updatePass(Pt.TERRAIN_CLASSIFICATION),X=B.commands[Pt.TERRAIN_CLASSIFICATION],_=B.indices[Pt.TERRAIN_CLASSIFICATION],S)A.executeGlobeClassificationCommands(B,Td,g,t,e);else for(Z=0;Z<_;++Z)Td(X[Z],t,i,e);if(U&&(C.execute(i,e),G&&Q.execute(i,e)),!d.useInvertClassification||r||d.renderTranslucentDepthForPick){for(a.updatePass(Pt.CESIUM_3D_TILE),X=B.commands[Pt.CESIUM_3D_TILE],_=B.indices[Pt.CESIUM_3D_TILE],Z=0;Z<_;++Z)Td(X[Z],t,i,e);if(_>0&&(c(P)&&d.useGlobeDepthFramebuffer&&(P.prepareColorTextures(i,U),P.executeUpdateDepth(i,e,U,P.depthStencilTexture)),!d.renderTranslucentDepthForPick))for(a.updatePass(Pt.CESIUM_3D_TILE_CLASSIFICATION),X=B.commands[Pt.CESIUM_3D_TILE_CLASSIFICATION],_=B.indices[Pt.CESIUM_3D_TILE_CLASSIFICATION],Z=0;Z<_;++Z)Td(X[Z],t,i,e)}else{t._invertClassification.clear(i,e);let nt=e.framebuffer;for(e.framebuffer=t._invertClassification._fbo.framebuffer,a.updatePass(Pt.CESIUM_3D_TILE),X=B.commands[Pt.CESIUM_3D_TILE],_=B.indices[Pt.CESIUM_3D_TILE],Z=0;Z<_;++Z)Td(X[Z],t,i,e);for(c(P)&&d.useGlobeDepthFramebuffer&&(t._invertClassification.prepareTextures(i),P.executeUpdateDepth(i,e,U,t._invertClassification._fbo.getDepthStencilTexture())),a.updatePass(Pt.CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW),X=B.commands[Pt.CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW],_=B.indices[Pt.CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW],Z=0;Z<_;++Z)Td(X[Z],t,i,e);for(e.framebuffer=nt,t._invertClassification.executeClassified(i,e),o.invertClassificationColor.alpha===1&&t._invertClassification.executeUnclassified(i,e),_>0&&i.stencilBuffer&&Y.execute(i,e),a.updatePass(Pt.CESIUM_3D_TILE_CLASSIFICATION),X=B.commands[Pt.CESIUM_3D_TILE_CLASSIFICATION],_=B.indices[Pt.CESIUM_3D_TILE_CLASSIFICATION],Z=0;Z<_;++Z)Td(X[Z],t,i,e)}for(_>0&&i.stencilBuffer&&y.execute(i,e),a.updatePass(Pt.VOXELS),X=B.commands[Pt.VOXELS],_=B.indices[Pt.VOXELS],X.length=_,YXe(t,Td,e,X),a.updatePass(Pt.OPAQUE),X=B.commands[Pt.OPAQUE],_=B.indices[Pt.OPAQUE],Z=0;Z<_;++Z)Td(X[Z],t,i,e);I!==0&&t.mode!==Vt.SCENE2D&&(s.near=B.near,a.updateFrustum(s));let w;if(!r&&d.useInvertClassification&&o.invertClassificationColor.alpha<1&&(w=t._invertClassification),a.updatePass(Pt.TRANSLUCENT),X=B.commands[Pt.TRANSLUCENT],X.length=B.indices[Pt.TRANSLUCENT],R(t,Td,e,X,w),B.indices[Pt.CESIUM_3D_TILE_CLASSIFICATION]>0&&m.translucentTileClassification.isSupported()&&(m.translucentTileClassification.executeTranslucentCommands(t,Td,e,X,P.depthStencilTexture),m.translucentTileClassification.executeClassificationCommands(t,Td,e,B)),i.depthTexture&&t.useDepthPicking&&(d.useGlobeDepthFramebuffer||h)){let nt=P.depthStencilTexture,$=t._picking.getPickDepth(t,I);$.update(i,nt),$.executeCopyDepth(i,e)}if(r||!J)continue;let H=e.framebuffer;if(e.framebuffer=m.sceneFramebuffer.getIdFramebuffer(),s.near=I!==0?B.near*t.opaqueFrustumNearOffset:B.near,s.far=B.far,a.updateFrustum(s),a.updatePass(Pt.GLOBE),X=B.commands[Pt.GLOBE],_=B.indices[Pt.GLOBE],S)A.executeGlobeCommands(B,a5,g,t,e);else for(Z=0;Z<_;++Z)a5(X[Z],t,i,e);for(U&&(C.framebuffer=e.framebuffer,C.execute(i,e),C.framebuffer=void 0),U&&G&&Q.execute(i,e),a.updatePass(Pt.CESIUM_3D_TILE),X=B.commands[Pt.CESIUM_3D_TILE],_=B.indices[Pt.CESIUM_3D_TILE],Z=0;Z<_;++Z)a5(X[Z],t,i,e);for(a.updatePass(Pt.OPAQUE),X=B.commands[Pt.OPAQUE],_=B.indices[Pt.OPAQUE],Z=0;Z<_;++Z)a5(X[Z],t,i,e);for(a.updatePass(Pt.TRANSLUCENT),X=B.commands[Pt.TRANSLUCENT],_=B.indices[Pt.TRANSLUCENT],Z=0;Z<_;++Z)a5(X[Z],t,i,e);e.framebuffer=H}}function HQt(t){t.context.uniformState.updatePass(Pt.COMPUTE);let n=t._environmentState.sunComputeCommand;c(n)&&n.execute(t._computeEngine);let i=t._computeCommandList,o=i.length;for(let a=0;a<o;++a)i[a].execute(t._computeEngine)}function MXe(t,e){t.context.uniformState.updatePass(Pt.OVERLAY);let i=t.context,o=t._overlayCommandList,a=o.length;for(let s=0;s<a;++s)o[s].execute(i,e)}function _Xe(t,e,n){let i=n.shadowMapCullingVolume,o=n.isPointLight,a=n.passes,s=a.length,l=e.length;for(let r=0;r<l;++r){let d=e[r];if(t.updateDerivedCommands(d),d.castShadows&&(d.pass===Pt.GLOBE||d.pass===Pt.CESIUM_3D_TILE||d.pass===Pt.OPAQUE||d.pass===Pt.TRANSLUCENT)&&t.isVisible(d,i))if(o)for(let m=0;m<s;++m)a[m].commandList.push(d);else if(s===1)a[0].commandList.push(d);else{let m=!1;for(let h=s-1;h>=0;--h){let u=a[h].cullingVolume;if(t.isVisible(d,u))a[h].commandList.push(d),m=!0;else if(m)break}}}}function wQt(t){let e=t.frameState,n=e.shadowState.shadowMaps,i=n.length;if(!e.shadowState.shadowsEnabled)return;let o=t.context,a=o.uniformState;for(let s=0;s<i;++s){let l=n[s];if(l.outOfView)continue;let r=l.passes,d=r.length;for(let h=0;h<d;++h)r[h].commandList.length=0;let m=t.frameState.commandList;_Xe(t,m,l);for(let h=0;h<d;++h){let u=l.passes[h];a.updateCamera(u.camera),l.updatePass(o,h);let R=u.commandList.length;for(let V=0;V<R;++V){let F=u.commandList[V];a.updatePass(F.pass),Td(F.derivedCommands.shadows.castCommands[s],t,o,u.passState)}}}}var DXe=new p;fo.prototype.updateAndExecuteCommands=function(t,e){let i=this._frameState.mode;this._environmentState.useWebVR?OXe(this,t,e):i!==Vt.SCENE2D||this._mapMode2D===eh.ROTATE?TU(!0,this,t,e):(Ust(this,t,e),$Xe(this,t))};function OXe(t,e,n){let i=t._view,o=i.camera,s=t._environmentState.renderTranslucentDepthForPick;Ust(t,e,n),PQt(t),i.createPotentiallyVisibleSet(t),HQt(t),s||wQt(t);let l=e.viewport;l.x=0,l.y=0,l.width=l.width*.5;let r=Aa.clone(o,t._cameraVR);r.frustum=o.frustum;let d=o.frustum.near,m=d*f(t.focalLength,5),h=f(t.eyeSeparation,m/30),u=p.multiplyByScalar(r.right,h*.5,DXe);o.frustum.aspectRatio=l.width/l.height;let R=.5*h*d/m;p.add(r.position,u,o.position),o.frustum.xOffset=R,Fst(t,e),l.x=l.width,p.subtract(r.position,u,o.position),o.frustum.xOffset=-R,Fst(t,e),Aa.clone(r,o)}var HXe=new gt(Math.PI,k.PI_OVER_TWO),wXe=new p,PXe=new p,vXe=new L,KXe=new L,zXe=new p,jXe=new p,qXe=new Fe;function $Xe(t,e){let n=t.context,i=t.frameState,o=t.camera,a=e.viewport,s=Fe.clone(a,qXe);e.viewport=s;let l=HXe,r=wXe;t.mapProjection.project(l,r);let m=p.clone(o.position,PXe),h=L.clone(o.transform,KXe),u=o.frustum.clone();o._setTransform(L.IDENTITY);let R=L.computeViewportTransformation(s,0,1,vXe),V=o.frustum.projectionMatrix,F=o.positionWC.y,U=p.fromElements(k.sign(F)*r.x-F,0,-o.positionWC.x,zXe),G=Pe.pointToGLWindowCoordinates(V,R,U,jXe);G.x=Math.floor(G.x);let A=s.x,S=s.width;if(F===0||G.x<=A||G.x>=A+S)TU(!0,t,e);else if(Math.abs(A+S*.5-G.x)<1)s.width=G.x-s.x,o.position.x*=k.sign(o.position.x),o.frustum.right=0,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),TU(!0,t,e),s.x=G.x,o.position.x=-o.position.x,o.frustum.right=-o.frustum.left,o.frustum.left=0,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),TU(!1,t,e);else if(G.x>A+S*.5){s.width=G.x-A;let g=o.frustum.right;o.frustum.right=r.x-F,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),TU(!0,t,e),s.x=G.x,s.width=A+S-G.x,o.position.x=-o.position.x,o.frustum.left=-o.frustum.right,o.frustum.right=g-o.frustum.right*2,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),TU(!1,t,e)}else{s.x=G.x,s.width=A+S-G.x;let g=o.frustum.left;o.frustum.left=-r.x-F,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),TU(!0,t,e),s.x=A,s.width=G.x-A,o.position.x=-o.position.x,o.frustum.right=-o.frustum.left,o.frustum.left=g-o.frustum.left*2,i.cullingVolume=o.frustum.computeCullingVolume(o.positionWC,o.directionWC,o.upWC),n.uniformState.update(i),TU(!1,t,e)}o._setTransform(h),p.clone(m,o.position),o.frustum=u.clone(),e.viewport=a}function TU(t,e,n,i){let o=e._environmentState,a=e._view,s=o.renderTranslucentDepthForPick;t||(e.frameState.commandList.length=0),PQt(e),a.createPotentiallyVisibleSet(e),t&&(c(i)&&Ust(e,n,i),HQt(e),s||wQt(e)),Fst(e,n)}var _Qt=new Jl;fo.prototype.updateEnvironment=function(){let t=this._frameState,e=this._view,n=this._environmentState,i=t.passes.render,o=t.passes.offscreen,a=this.atmosphere,s=this.skyAtmosphere,l=this.globe,r=this._globeTranslucencyState;if(!i||this._mode!==Vt.SCENE2D&&e.camera.frustum instanceof wn||!r.environmentVisible)n.skyAtmosphereCommand=void 0,n.skyBoxCommand=void 0,n.sunDrawCommand=void 0,n.sunComputeCommand=void 0,n.moonCommand=void 0;else{if(c(s)){if(c(l))s.setDynamicLighting(VT.fromGlobeFlags(l)),n.isReadyForAtmosphere=n.isReadyForAtmosphere||!l.show||l._surface._tilesToRender.length>0;else{let G=a.dynamicLighting;s.setDynamicLighting(G),n.isReadyForAtmosphere=!0}n.skyAtmosphereCommand=s.update(t,l),c(n.skyAtmosphereCommand)&&this.updateDerivedCommands(n.skyAtmosphereCommand)}else n.skyAtmosphereCommand=void 0;n.skyBoxCommand=c(this.skyBox)?this.skyBox.update(t,this._hdr):void 0;let U=c(this.sun)?this.sun.update(t,e.passState,this._hdr):void 0;n.sunDrawCommand=c(U)?U.drawCommand:void 0,n.sunComputeCommand=c(U)?U.computeCommand:void 0,n.moonCommand=c(this.moon)?this.moon.update(t):void 0}let d=n.clearGlobeDepth=c(l)&&l.show&&(!l.depthTestAgainstTerrain||this.mode===Vt.SCENE2D);(n.useDepthPlane=d&&this.mode===Vt.SCENE3D&&r.useDepthPlane)&&this._depthPlane.update(t),n.renderTranslucentDepthForPick=!1,n.useWebVR=this._useWebVR&&this.mode!==Vt.SCENE2D&&!o;let h=t.mode===Vt.SCENE3D&&!r.sunVisibleThroughGlobe?t.occluder:void 0,u=t.cullingVolume,R=_Qt.planes;for(let U=0;U<5;++U)R[U]=u.planes[U];u=_Qt,n.isSkyAtmosphereVisible=c(n.skyAtmosphereCommand)&&n.isReadyForAtmosphere,n.isSunVisible=this.isVisible(n.sunDrawCommand,u,h),n.isMoonVisible=this.isVisible(n.moonCommand,u,h);let V=this.specularEnvironmentMaps,F=this._specularEnvironmentMapAtlas;c(V)&&(!c(F)||F.url!==V)?(F=F&&F.destroy(),this._specularEnvironmentMapAtlas=new du(V)):!c(V)&&c(F)&&(F.destroy(),this._specularEnvironmentMapAtlas=void 0),c(this._specularEnvironmentMapAtlas)&&this._specularEnvironmentMapAtlas.update(t)};function tJe(t){let e=t._frameState;t.debugShowFrustumPlanes!==t._debugShowFrustumPlanes&&(t.debugShowFrustumPlanes?t._debugFrustumPlanes=new JR({camera:t.camera,updateOnChange:!1,frustumSplits:e.frustumSplits}):t._debugFrustumPlanes=t._debugFrustumPlanes&&t._debugFrustumPlanes.destroy(),t._debugShowFrustumPlanes=t.debugShowFrustumPlanes),c(t._debugFrustumPlanes)&&t._debugFrustumPlanes.update(e)}function eJe(t){let e=t._frameState,n=e.shadowMaps,i=n.length,o=i>0&&!e.passes.pick&&!e.passes.pickVoxel&&t.mode===Vt.SCENE3D;if(o!==e.shadowState.shadowsEnabled&&(++e.shadowState.lastDirtyTime,e.shadowState.shadowsEnabled=o),e.shadowState.lightShadowsEnabled=!1,!!o){for(let a=0;a<i;++a)if(n[a]!==e.shadowState.shadowMaps[a]){++e.shadowState.lastDirtyTime;break}e.shadowState.shadowMaps.length=0,e.shadowState.lightShadowMaps.length=0;for(let a=0;a<i;++a){let s=n[a];s.update(e),e.shadowState.shadowMaps.push(s),s.fromLightSource&&(e.shadowState.lightShadowMaps.push(s),e.shadowState.lightShadowsEnabled=!0),s.dirty&&(++e.shadowState.lastDirtyTime,s.dirty=!1)}}}function PQt(t){let e=t._frameState;t._groundPrimitives.update(e),t._primitives.update(e),tJe(t),eJe(t),t._globe&&t._globe.render(e)}function Ust(t,e,n){let i=t._context,o=t._frameState,a=t._environmentState,s=t._view,l=t._frameState.passes,r=l.pick||l.pickVoxel;c(s.globeDepth)&&(s.globeDepth.picking=r);let d=a.useWebVR;a.originalFramebuffer=e.framebuffer,c(t.sun)&&t.sunBloom!==t._sunBloom?(t.sunBloom&&!d?t._sunPostProcess=new y9:c(t._sunPostProcess)&&(t._sunPostProcess=t._sunPostProcess.destroy()),t._sunBloom=t.sunBloom):!c(t.sun)&&c(t._sunPostProcess)&&(t._sunPostProcess=t._sunPostProcess.destroy(),t._sunBloom=!1);let m=t._clearColorCommand;v.clone(n,m.color),m.execute(i,e);let h=a.useGlobeDepthFramebuffer=c(s.globeDepth);h&&(s.globeDepth.update(i,e,s.viewport,t.msaaSamples,t._hdr,a.clearGlobeDepth),s.globeDepth.clear(i,e,n));let u=s.oit,R=a.useOIT=!r&&c(u)&&u.isSupported();R&&(u.update(i,e,s.globeDepth.colorFramebufferManager,t._hdr,t.msaaSamples),u.clear(i,e,n),a.useOIT=u.isSupported());let V=t.postProcessStages,F=a.usePostProcess=!r&&(t._hdr||V.length>0||V.ambientOcclusion.enabled||V.fxaa.enabled||V.bloom.enabled);if(a.usePostProcessSelected=!1,F&&(s.sceneFramebuffer.update(i,s.viewport,t._hdr,t.msaaSamples),s.sceneFramebuffer.clear(i,e,n),V.update(i,o.useLogDepth,t._hdr),V.clear(i),F=a.usePostProcess=V.ready,a.usePostProcessSelected=F&&V.hasSelected),a.isSunVisible&&t.sunBloom&&!d?(e.framebuffer=t._sunPostProcess.update(e),t._sunPostProcess.clear(i,e,n)):h?e.framebuffer=s.globeDepth.framebuffer:F&&(e.framebuffer=s.sceneFramebuffer.framebuffer),c(e.framebuffer)&&m.execute(i,e),a.useInvertClassification=!r&&c(e.framebuffer)&&t.invertClassification){let G;if(t.frameState.invertClassificationColor.alpha===1&&a.useGlobeDepthFramebuffer&&(G=s.globeDepth.framebuffer),c(G)||i.depthTexture){if(t._invertClassification.previousFramebuffer=G,t._invertClassification.update(i,t.msaaSamples,s.globeDepth.colorFramebufferManager),t._invertClassification.clear(i,e),t.frameState.invertClassificationColor.alpha<1&&R){let A=t._invertClassification.unclassifiedCommand,S=A.derivedCommands;S.oit=u.createDerivedCommands(A,i,S.oit)}}else a.useInvertClassification=!1}t._globeTranslucencyState.translucent&&s.globeTranslucencyFramebuffer.updateAndClear(t._hdr,s.viewport,i,e)}fo.prototype.resolveFramebuffers=function(t){let e=this._context,n=this._environmentState,i=this._view,o=i.globeDepth;c(o)&&o.prepareColorTextures(e);let a=n.useOIT,s=n.useGlobeDepthFramebuffer,l=n.usePostProcess,r=n.originalFramebuffer,d=s?o.colorFramebufferManager:void 0,m=i.sceneFramebuffer._colorFramebuffer,h=i.sceneFramebuffer.idFramebuffer;a&&(t.framebuffer=l?m.framebuffer:r,i.oit.execute(e,t));let u=i.translucentTileClassification;if(u.hasTranslucentDepth&&u.isSupported()&&u.execute(this,t),l){i.sceneFramebuffer.prepareColorTextures(e);let R=m;s&&!a&&(R=d);let V=this.postProcessStages,F=R.getColorTexture(0),U=h.getColorTexture(0),G=f(d,m).getDepthStencilTexture();V.execute(e,F,G,U),V.copy(e,r)}!a&&!l&&s&&(t.framebuffer=r,o.executeCopyColor(e,t))};function nJe(t){let e=t._frameState.afterRender;for(let n=0,i=e.length;n<i;++n)e[n]()&&t.requestRender();e.length=0}function iJe(t){if(t.mode===Vt.MORPHING)return;let n=t.camera.positionCartographic;return t.getHeight(n)}fo.prototype.getHeight=function(t,e){if(!c(t))return;let n=e===Ge.CLAMP_TO_TERRAIN||e===Ge.RELATIVE_TO_TERRAIN,i=e===Ge.CLAMP_TO_3D_TILE||e===Ge.RELATIVE_TO_3D_TILE;if(!c(t))return;let o=Number.NEGATIVE_INFINITY;if(!n){let s=this.primitives.length;for(let l=0;l<s;++l){let r=this.primitives.get(l);if(!r.isCesium3DTileset||!r.show||!r.enableCollision)continue;let d=r.getHeight(t,this);c(d)&&d>o&&(o=d)}}let a=this._globe;if(!i&&c(a)&&a.show){let s=a.getHeight(t);s>o&&(o=s)}if(o>Number.NEGATIVE_INFINITY)return o};var fst=new gt;fo.prototype.updateHeight=function(t,e,n){let i=()=>{gt.clone(t,fst);let R=this.getHeight(t,n);c(R)&&(fst.height=R,e(fst))},o=n===Ge.CLAMP_TO_TERRAIN||n===Ge.RELATIVE_TO_TERRAIN,a=n===Ge.CLAMP_TO_3D_TILE||n===Ge.RELATIVE_TO_3D_TILE,s;!a&&c(this.globe)&&(s=this.globe._surface.updateHeight(t,i));let l={},r=this.globe?.ellipsoid,d=R=>{if(o||R.isDestroyed()||!R.isCesium3DTileset)return;let V=R.updateHeight(t,i,r);l[R.id]=V};if(!o){let R=this.primitives.length;for(let V=0;V<R;++V){let F=this.primitives.get(V);d(F)}}let m=this.primitives.primitiveAdded.addEventListener(d),h=this.primitives.primitiveRemoved.addEventListener(R=>{R.isDestroyed()||!R.isCesium3DTileset||(c(l[R.id])&&l[R.id](),delete l[R.id])});return()=>{s=s&&s(),Object.values(l).forEach(R=>R()),l={},m(),h()}};function oJe(t){let e=t.camera,n=t._mode,i=t._screenSpaceCameraController,o=e.positionCartographic;if(!c(o))return!1;if(!i.onMap()&&o.height<0)return!0;if(n===Vt.SCENE2D||n===Vt.MORPHING)return!1;let a=t._globeHeight;return c(a)&&o.height<a}fo.prototype.initializeFrame=function(){if(this._shaderFrameCount++===120&&(this._shaderFrameCount=0,this._context.shaderCache.destroyReleasedShaderPrograms(),this._context.textureCache.destroyReleasedTextures()),this._tweens.update(),this._globeHeightDirty){c(this._removeUpdateHeightCallback)&&(this._removeUpdateHeightCallback(),this._removeUpdateHeightCallback=void 0),this._globeHeight=iJe(this),this._globeHeightDirty=!1;let t=this.camera.positionCartographic;this._removeUpdateHeightCallback=this.updateHeight(t,e=>{this.isDestroyed()||(this._globeHeight=e.height)})}this._cameraUnderground=oJe(this),this._globeTranslucencyState.update(this),this._screenSpaceCameraController.update(),c(this._deviceOrientationCameraController)&&this._deviceOrientationCameraController.update(),this.camera.update(this._mode),this.camera._updateCameraChanged()};function aJe(t,e){if(t.debugShowFramesPerSecond){if(!c(t._performanceDisplay)){let n=document.createElement("div");n.className="cesium-performanceDisplay-defaultContainer",t._canvas.parentNode.appendChild(n);let o=new RW({container:n});t._performanceDisplay=o,t._performanceContainer=n}t._performanceDisplay.throttled=t.requestRenderMode,t._performanceDisplay.update(e)}else c(t._performanceDisplay)&&(t._performanceDisplay=t._performanceDisplay&&t._performanceDisplay.destroy(),t._performanceContainer.parentNode.removeChild(t._performanceContainer))}function sJe(t){t._jobScheduler.resetBudgets();let e=t._frameState;t.primitives.prePassesUpdate(e),c(t.globe)&&t.globe.update(e),t._picking.update(),e.creditDisplay.update()}function lJe(t){let e=t._frameState;t.primitives.postPassesUpdate(e),xd.update()}var rJe=new v;function dJe(t){let e=t._frameState,n=t.context,i=n.uniformState,o=t._defaultView;t._view=o,t.updateFrameState(),e.passes.render=!0,e.passes.postProcess=t.postProcessStages.hasSelected,e.tilesetPassState=CXe;let a=f(t.backgroundColor,v.BLACK);t._hdr&&(a=v.clone(a,rJe),a.red=Math.pow(a.red,t.gamma),a.green=Math.pow(a.green,t.gamma),a.blue=Math.pow(a.blue,t.gamma)),e.backgroundColor=a,e.atmosphere=t.atmosphere,t.fog.update(e),i.update(e);let s=t.shadowMap;c(s)&&s.enabled&&(!c(t.light)||t.light instanceof gb?p.negate(i.sunDirectionWC,t._shadowMapCamera.direction):p.clone(t.light.direction,t._shadowMapCamera.direction),e.shadowMaps.push(s)),t._computeCommandList.length=0,t._overlayCommandList.length=0;let l=o.viewport;l.x=0,l.y=0,l.width=n.drawingBufferWidth,l.height=n.drawingBufferHeight;let r=o.passState;r.framebuffer=void 0,r.blendingEnabled=void 0,r.scissorTest=void 0,r.viewport=Fe.clone(l,r.viewport),c(t.globe)&&t.globe.beginFrame(e),t.updateEnvironment(),t.updateAndExecuteCommands(r,a),t.resolveFramebuffers(r),r.framebuffer=void 0,MXe(t,r),c(t.globe)&&(t.globe.endFrame(e),t.globe.tilesLoaded||(t._renderRequested=!0)),n.endFrame()}function MT(t,e){try{e(t)}catch(n){if(t._renderError.raiseEvent(t,n),t.rethrowRenderErrors)throw n}}function cJe(t){return t._picking.updateMostDetailedRayPicks(t)}fo.prototype.render=function(t){this._preUpdate.raiseEvent(this,t);let e=this._frameState;e.newFrame=!1,c(t)||(t=rt.now());let n=this._view.checkForCameraUpdates(this);n&&(this._globeHeightDirty=!0);let i=!this.requestRenderMode||this._renderRequested||n||this._logDepthBufferDirty||this._hdrDirty||this.mode===Vt.MORPHING;if(!i&&c(this.maximumRenderTimeChange)&&c(this._lastRenderTime)){let o=Math.abs(rt.secondsDifference(this._lastRenderTime,t));i=i||o>this.maximumRenderTimeChange}if(i){this._lastRenderTime=rt.clone(t,this._lastRenderTime),this._renderRequested=!1,this._logDepthBufferDirty=!1,this._hdrDirty=!1;let o=k.incrementWrap(e.frameNumber,15e6,1);DQt(this,o,t),e.newFrame=!0}MT(this,sJe),this.primitives.show&&(MT(this,cJe),MT(this,mJe),MT(this,hJe),i||MT(this,pJe)),this._postUpdate.raiseEvent(this,t),i&&(this._preRender.raiseEvent(this,t),e.creditDisplay.beginFrame(),MT(this,dJe)),aJe(this,i),MT(this,lJe),nJe(this),i&&(this._postRender.raiseEvent(this,t),e.creditDisplay.endFrame())};fo.prototype.forceRender=function(t){this._renderRequested=!0,this.render(t)};fo.prototype.requestRender=function(){this._renderRequested=!0};fo.prototype.clampLineWidth=function(t){return Math.max(Tn.minimumAliasedLineWidth,Math.min(t,Tn.maximumAliasedLineWidth))};fo.prototype.pick=function(t,e,n){return this._picking.pick(this,t,e,n)};fo.prototype.pickVoxel=function(t,e,n){let i=this.pick(t,e,n);if(!c(i))return;let o=i.primitive;if(!(o instanceof SU))return;let a=this._picking.pickVoxelCoordinate(this,t,e,n),s=255*a[0]+a[1],l=o._traversal.findKeyframeNode(s);if(!c(l))return;let r=255*a[2]+a[3];return k9.fromKeyframeNode(o,s,r,l)};fo.prototype.pickPositionWorldCoordinates=function(t,e){return this._picking.pickPositionWorldCoordinates(this,t,e)};fo.prototype.pickPosition=function(t,e){return this._picking.pickPosition(this,t,e)};fo.prototype.drillPick=function(t,e,n,i){return this._picking.drillPick(this,t,e,n,i)};function mJe(t){let e=t._frameState;Rst.camera=e.camera,Rst.cullingVolume=e.cullingVolume,t.primitives.updateForPass(e,Rst)}function hJe(t){let e=t._frameState;if(!e.camera.canPreloadFlight())return;bst.camera=t.preloadFlightCamera,bst.cullingVolume=t.preloadFlightCullingVolume,t.primitives.updateForPass(e,bst)}function pJe(t){t.primitives.updateForPass(t._frameState,IXe)}fo.prototype.pickFromRay=function(t,e,n){return this._picking.pickFromRay(this,t,e,n)};fo.prototype.drillPickFromRay=function(t,e,n,i){return this._picking.drillPickFromRay(this,t,e,n,i)};fo.prototype.pickFromRayMostDetailed=function(t,e,n){return this._picking.pickFromRayMostDetailed(this,t,e,n)};fo.prototype.drillPickFromRayMostDetailed=function(t,e,n,i){return this._picking.drillPickFromRayMostDetailed(this,t,e,n,i)};fo.prototype.sampleHeight=function(t,e,n){return this._picking.sampleHeight(this,t,e,n)};fo.prototype.clampToHeight=function(t,e,n,i){return this._picking.clampToHeight(this,t,e,n,i)};fo.prototype.sampleHeightMostDetailed=function(t,e,n){return this._picking.sampleHeightMostDetailed(this,t,e,n)};fo.prototype.clampToHeightMostDetailed=function(t,e,n){return this._picking.clampToHeightMostDetailed(this,t,e,n)};fo.prototype.cartesianToCanvasCoordinates=function(t,e){return qo.wgs84ToWindowCoordinates(this,t,e)};fo.prototype.completeMorph=function(){this._transitioner.completeMorph()};fo.prototype.morphTo2D=function(t){let e,n=this.globe;c(n)?e=n.ellipsoid:e=this.mapProjection.ellipsoid,t=f(t,2),this._transitioner.morphTo2D(t,e)};fo.prototype.morphToColumbusView=function(t){let e,n=this.globe;c(n)?e=n.ellipsoid:e=this.mapProjection.ellipsoid,t=f(t,2),this._transitioner.morphToColumbusView(t,e)};fo.prototype.morphTo3D=function(t){let e,n=this.globe;c(n)?e=n.ellipsoid:e=this.mapProjection.ellipsoid,t=f(t,2),this._transitioner.morphTo3D(t,e)};function VJe(t,e){if(t._removeTerrainProviderReadyListener=t._removeTerrainProviderReadyListener&&t._removeTerrainProviderReadyListener(),e.ready){c(t.globe)&&(t.globe.terrainProvider=e.provider);return}t.globe.terrainProvider=void 0,t._removeTerrainProviderReadyListener=e.readyEvent.addEventListener(n=>{c(t)&&c(t.globe)&&(t.globe.terrainProvider=n),t._removeTerrainProviderReadyListener()})}fo.prototype.setTerrain=function(t){return VJe(this,t),t};fo.prototype.isDestroyed=function(){return!1};fo.prototype.destroy=function(){this._tweens.removeAll(),this._computeEngine=this._computeEngine&&this._computeEngine.destroy(),this._screenSpaceCameraController=this._screenSpaceCameraController&&this._screenSpaceCameraController.destroy(),this._deviceOrientationCameraController=this._deviceOrientationCameraController&&!this._deviceOrientationCameraController.isDestroyed()&&this._deviceOrientationCameraController.destroy(),this._primitives=this._primitives&&this._primitives.destroy(),this._groundPrimitives=this._groundPrimitives&&this._groundPrimitives.destroy(),this._globe=this._globe&&this._globe.destroy(),this._removeTerrainProviderReadyListener=this._removeTerrainProviderReadyListener&&this._removeTerrainProviderReadyListener(),this.skyBox=this.skyBox&&this.skyBox.destroy(),this.skyAtmosphere=this.skyAtmosphere&&this.skyAtmosphere.destroy(),this._debugSphere=this._debugSphere&&this._debugSphere.destroy(),this.sun=this.sun&&this.sun.destroy(),this._sunPostProcess=this._sunPostProcess&&this._sunPostProcess.destroy(),this._depthPlane=this._depthPlane&&this._depthPlane.destroy(),this._transitioner=this._transitioner&&this._transitioner.destroy(),this._debugFrustumPlanes=this._debugFrustumPlanes&&this._debugFrustumPlanes.destroy(),this._brdfLutGenerator=this._brdfLutGenerator&&this._brdfLutGenerator.destroy(),this._picking=this._picking&&this._picking.destroy(),this._defaultView=this._defaultView&&this._defaultView.destroy(),this._view=void 0,this._removeCreditContainer&&this._canvas.parentNode.removeChild(this._creditContainer),this.postProcessStages=this.postProcessStages&&this.postProcessStages.destroy(),this._context=this._context&&this._context.destroy(),this._frameState.creditDisplay=this._frameState.creditDisplay&&this._frameState.creditDisplay.destroy(),c(this._performanceDisplay)&&(this._performanceDisplay=this._performanceDisplay&&this._performanceDisplay.destroy(),this._performanceContainer.parentNode.removeChild(this._performanceContainer)),this._removeRequestListenerCallback(),this._removeTaskProcessorListenerCallback();for(let t=0;t<this._removeGlobeCallbacks.length;++t)this._removeGlobeCallbacks[t]();return this._removeGlobeCallbacks.length=0,c(this._removeUpdateHeightCallback)&&(this._removeUpdateHeightCallback(),this._removeUpdateHeightCallback=void 0),At(this)};var s5=fo;var OMo=b(W(),1);var VMo=b(W(),1),j1=`float interpolateByDistance(vec4 nearFarScalar, float distance) { float startDistance = nearFarScalar.x; float startValue = nearFarScalar.y; @@ -14652,7 +14652,7 @@ void computeAtmosphereScattering(vec3 positionWC, vec3 lightDirection, out vec3 float nightAlpha = (u_radiiAndDynamicAtmosphereColor.z != 0.0) ? clamp(dot(normalize(positionWC), lightDirection), 0.0, 1.0) : 1.0; opacity *= pow(nightAlpha, 0.5); } -`;var VMo=R(W(),1),l5=`in vec3 v_outerPositionWC; +`;var ZMo=b(W(),1),l5=`in vec3 v_outerPositionWC; uniform vec3 u_hsbShift; @@ -14711,7 +14711,7 @@ void main (void) out_FragColor = color; } -`;var RMo=R(W(),1),r5=`in vec4 position; +`;var bMo=b(W(),1),r5=`in vec4 position; out vec3 v_outerPositionWC; @@ -14742,7 +14742,7 @@ void main(void) v_outerPositionWC = positionWC.xyz; gl_Position = czm_modelViewProjection * position; } -`;function q1(t){t=f(t,mt.WGS84),this.show=!0,this.perFragmentAtmosphere=!1,this._ellipsoid=t;let e=1.025,n=p.multiplyByScalar(t.radii,e,new p);this._scaleMatrix=L.fromScale(n),this._modelMatrix=new L,this._command=new Ee({owner:this,modelMatrix:this._modelMatrix}),this._spSkyFromSpace=void 0,this._spSkyFromAtmosphere=void 0,this._flags=void 0,this.atmosphereLightIntensity=50,this.atmosphereRayleighCoefficient=new p(55e-7,13e-6,284e-7),this.atmosphereMieCoefficient=new p(21e-6,21e-6,21e-6),this.atmosphereRayleighScaleHeight=1e4,this.atmosphereMieScaleHeight=3200,this.atmosphereMieAnisotropy=.9,this.hueShift=0,this.saturationShift=0,this.brightnessShift=0,this._hueSaturationBrightness=new p;let i=new p;i.x=t.maximumRadius*e,i.y=t.maximumRadius,i.z=0,this._radiiAndDynamicAtmosphereColor=i;let o=this;this._command.uniformMap={u_radiiAndDynamicAtmosphereColor:function(){return o._radiiAndDynamicAtmosphereColor},u_hsbShift:function(){return o._hueSaturationBrightness.x=o.hueShift,o._hueSaturationBrightness.y=o.saturationShift,o._hueSaturationBrightness.z=o.brightnessShift,o._hueSaturationBrightness},u_atmosphereLightIntensity:function(){return o.atmosphereLightIntensity},u_atmosphereRayleighCoefficient:function(){return o.atmosphereRayleighCoefficient},u_atmosphereMieCoefficient:function(){return o.atmosphereMieCoefficient},u_atmosphereRayleighScaleHeight:function(){return o.atmosphereRayleighScaleHeight},u_atmosphereMieScaleHeight:function(){return o.atmosphereMieScaleHeight},u_atmosphereMieAnisotropy:function(){return o.atmosphereMieAnisotropy}}}Object.defineProperties(q1.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});q1.prototype.setDynamicLighting=function(t){this._radiiAndDynamicAtmosphereColor.z=t};var Gst=new L;q1.prototype.update=function(t,e){if(!this.show)return;let n=t.mode;if(n!==ut.SCENE3D&&n!==ut.MORPHING||!t.passes.render)return;let i=L.fromRotationTranslation(t.context.uniformState.inverseViewRotation,p.ZERO,Gst),o=L.multiplyTransformation(i,$a.Y_UP_TO_Z_UP,Gst),a=L.multiply(this._scaleMatrix,o,Gst);L.clone(a,this._modelMatrix);let s=t.context,l=ZJe(this),r=t.globeTranslucencyState.translucent,d=this.perFragmentAtmosphere||r||!c(e)||!e.show,m=this._command;if(!c(m.vertexArray)){let Z=Cr.createGeometry(new Cr({radii:new p(1,1,1),slicePartitions:256,stackPartitions:256,vertexFormat:ee.POSITION_ONLY}));m.vertexArray=Ki.fromGeometry({context:s,geometry:Z,attributeLocations:gi.createAttributeLocations(Z),bufferUsage:ce.STATIC_DRAW}),m.renderState=he.fromCache({cull:{enabled:!0,face:so.FRONT},blending:Pn.ALPHA_BLEND,depthMask:!1})}let h=l|d<<2|r<<3;if(h!==this._flags){this._flags=h;let Z=[];l&&Z.push("COLOR_CORRECT"),d&&Z.push("PER_FRAGMENT_ATMOSPHERE"),r&&Z.push("GLOBE_TRANSLUCENT");let b=new Ve({defines:Z,sources:[rW,j1,r5]}),u=new Ve({defines:Z,sources:[rW,j1,l5]});this._spSkyAtmosphere=xn.fromCache({context:s,vertexShaderSource:b,fragmentShaderSource:u}),m.shaderProgram=this._spSkyAtmosphere}return m};function ZJe(t){return!(k.equalsEpsilon(t.hueShift,0,k.EPSILON7)&&k.equalsEpsilon(t.saturationShift,0,k.EPSILON7)&&k.equalsEpsilon(t.brightnessShift,0,k.EPSILON7))}q1.prototype.isDestroyed=function(){return!1};q1.prototype.destroy=function(){let t=this._command;return t.vertexArray=t.vertexArray&&t.vertexArray.destroy(),this._spSkyAtmosphere=this._spSkyAtmosphere&&this._spSkyAtmosphere.destroy(),At(this)};var d5=q1;var V_o=R(W(),1);var wMo=R(W(),1),c5=`uniform samplerCube u_cubeMap; +`;function q1(t){t=f(t,mt.WGS84),this.show=!0,this.perFragmentAtmosphere=!1,this._ellipsoid=t;let e=1.025,n=p.multiplyByScalar(t.radii,e,new p);this._scaleMatrix=L.fromScale(n),this._modelMatrix=new L,this._command=new Ee({owner:this,modelMatrix:this._modelMatrix}),this._spSkyFromSpace=void 0,this._spSkyFromAtmosphere=void 0,this._flags=void 0,this.atmosphereLightIntensity=50,this.atmosphereRayleighCoefficient=new p(55e-7,13e-6,284e-7),this.atmosphereMieCoefficient=new p(21e-6,21e-6,21e-6),this.atmosphereRayleighScaleHeight=1e4,this.atmosphereMieScaleHeight=3200,this.atmosphereMieAnisotropy=.9,this.hueShift=0,this.saturationShift=0,this.brightnessShift=0,this._hueSaturationBrightness=new p;let i=new p;i.x=t.maximumRadius*e,i.y=t.maximumRadius,i.z=0,this._radiiAndDynamicAtmosphereColor=i;let o=this;this._command.uniformMap={u_radiiAndDynamicAtmosphereColor:function(){return o._radiiAndDynamicAtmosphereColor},u_hsbShift:function(){return o._hueSaturationBrightness.x=o.hueShift,o._hueSaturationBrightness.y=o.saturationShift,o._hueSaturationBrightness.z=o.brightnessShift,o._hueSaturationBrightness},u_atmosphereLightIntensity:function(){return o.atmosphereLightIntensity},u_atmosphereRayleighCoefficient:function(){return o.atmosphereRayleighCoefficient},u_atmosphereMieCoefficient:function(){return o.atmosphereMieCoefficient},u_atmosphereRayleighScaleHeight:function(){return o.atmosphereRayleighScaleHeight},u_atmosphereMieScaleHeight:function(){return o.atmosphereMieScaleHeight},u_atmosphereMieAnisotropy:function(){return o.atmosphereMieAnisotropy}}}Object.defineProperties(q1.prototype,{ellipsoid:{get:function(){return this._ellipsoid}}});q1.prototype.setDynamicLighting=function(t){this._radiiAndDynamicAtmosphereColor.z=t};var Gst=new L;q1.prototype.update=function(t,e){if(!this.show)return;let n=t.mode;if(n!==Vt.SCENE3D&&n!==Vt.MORPHING||!t.passes.render)return;let i=L.fromRotationTranslation(t.context.uniformState.inverseViewRotation,p.ZERO,Gst),o=L.multiplyTransformation(i,$a.Y_UP_TO_Z_UP,Gst),a=L.multiply(this._scaleMatrix,o,Gst);L.clone(a,this._modelMatrix);let s=t.context,l=uJe(this),r=t.globeTranslucencyState.translucent,d=this.perFragmentAtmosphere||r||!c(e)||!e.show,m=this._command;if(!c(m.vertexArray)){let u=Cr.createGeometry(new Cr({radii:new p(1,1,1),slicePartitions:256,stackPartitions:256,vertexFormat:ee.POSITION_ONLY}));m.vertexArray=Ki.fromGeometry({context:s,geometry:u,attributeLocations:gi.createAttributeLocations(u),bufferUsage:ce.STATIC_DRAW}),m.renderState=he.fromCache({cull:{enabled:!0,face:so.FRONT},blending:Pn.ALPHA_BLEND,depthMask:!1})}let h=l|d<<2|r<<3;if(h!==this._flags){this._flags=h;let u=[];l&&u.push("COLOR_CORRECT"),d&&u.push("PER_FRAGMENT_ATMOSPHERE"),r&&u.push("GLOBE_TRANSLUCENT");let R=new Ze({defines:u,sources:[rW,j1,r5]}),V=new Ze({defines:u,sources:[rW,j1,l5]});this._spSkyAtmosphere=xn.fromCache({context:s,vertexShaderSource:R,fragmentShaderSource:V}),m.shaderProgram=this._spSkyAtmosphere}return m};function uJe(t){return!(k.equalsEpsilon(t.hueShift,0,k.EPSILON7)&&k.equalsEpsilon(t.saturationShift,0,k.EPSILON7)&&k.equalsEpsilon(t.brightnessShift,0,k.EPSILON7))}q1.prototype.isDestroyed=function(){return!1};q1.prototype.destroy=function(){let t=this._command;return t.vertexArray=t.vertexArray&&t.vertexArray.destroy(),this._spSkyAtmosphere=this._spSkyAtmosphere&&this._spSkyAtmosphere.destroy(),At(this)};var d5=q1;var Z_o=b(W(),1);var wMo=b(W(),1),c5=`uniform samplerCube u_cubeMap; in vec3 v_texCoord; @@ -14751,7 +14751,7 @@ void main() vec4 color = czm_textureCube(u_cubeMap, normalize(v_texCoord)); out_FragColor = vec4(czm_gammaCorrect(color).rgb, czm_morphTime); } -`;var vMo=R(W(),1),m5=`in vec3 position; +`;var vMo=b(W(),1),m5=`in vec3 position; out vec3 v_texCoord; @@ -14761,7 +14761,7 @@ void main() gl_Position = czm_projection * vec4(p, 1.0); v_texCoord = position.xyz; } -`;function yj(t){this.sources=t.sources,this._sources=void 0,this.show=f(t.show,!0),this._command=new Ee({modelMatrix:L.clone(L.IDENTITY),owner:this}),this._cubeMap=void 0,this._attributeLocations=void 0,this._useHdr=void 0}yj.prototype.update=function(t,e){let n=this;if(!this.show||t.mode!==ut.SCENE3D&&t.mode!==ut.MORPHING||!t.passes.render)return;let i=t.context;if(this._sources!==this.sources){this._sources=this.sources;let a=this.sources;typeof a.positiveX=="string"?c2(i,this._sources).then(function(s){n._cubeMap=n._cubeMap&&n._cubeMap.destroy(),n._cubeMap=s}):(this._cubeMap=this._cubeMap&&this._cubeMap.destroy(),this._cubeMap=new Ld({context:i,source:a}))}let o=this._command;if(!c(o.vertexArray)){o.uniformMap={u_cubeMap:function(){return n._cubeMap}};let a=Am.createGeometry(Am.fromDimensions({dimensions:new p(2,2,2),vertexFormat:ee.POSITION_ONLY})),s=this._attributeLocations=gi.createAttributeLocations(a);o.vertexArray=Ki.fromGeometry({context:i,geometry:a,attributeLocations:s,bufferUsage:ce.STATIC_DRAW}),o.renderState=he.fromCache({blending:Pn.ALPHA_BLEND})}if(!c(o.shaderProgram)||this._useHdr!==e){let a=new Ve({defines:[e?"HDR":""],sources:[c5]});o.shaderProgram=xn.fromCache({context:i,vertexShaderSource:m5,fragmentShaderSource:a,attributeLocations:this._attributeLocations}),this._useHdr=e}if(c(this._cubeMap))return o};yj.prototype.isDestroyed=function(){return!1};yj.prototype.destroy=function(){let t=this._command;return t.vertexArray=t.vertexArray&&t.vertexArray.destroy(),t.shaderProgram=t.shaderProgram&&t.shaderProgram.destroy(),this._cubeMap=this._cubeMap&&this._cubeMap.destroy(),At(this)};var h5=yj;var j_o=R(W(),1);var R_o=R(W(),1),p5=`uniform sampler2D u_texture; +`;function yj(t){this.sources=t.sources,this._sources=void 0,this.show=f(t.show,!0),this._command=new Ee({modelMatrix:L.clone(L.IDENTITY),owner:this}),this._cubeMap=void 0,this._attributeLocations=void 0,this._useHdr=void 0}yj.prototype.update=function(t,e){let n=this;if(!this.show||t.mode!==Vt.SCENE3D&&t.mode!==Vt.MORPHING||!t.passes.render)return;let i=t.context;if(this._sources!==this.sources){this._sources=this.sources;let a=this.sources;typeof a.positiveX=="string"?ck(i,this._sources).then(function(s){n._cubeMap=n._cubeMap&&n._cubeMap.destroy(),n._cubeMap=s}):(this._cubeMap=this._cubeMap&&this._cubeMap.destroy(),this._cubeMap=new Ld({context:i,source:a}))}let o=this._command;if(!c(o.vertexArray)){o.uniformMap={u_cubeMap:function(){return n._cubeMap}};let a=Am.createGeometry(Am.fromDimensions({dimensions:new p(2,2,2),vertexFormat:ee.POSITION_ONLY})),s=this._attributeLocations=gi.createAttributeLocations(a);o.vertexArray=Ki.fromGeometry({context:i,geometry:a,attributeLocations:s,bufferUsage:ce.STATIC_DRAW}),o.renderState=he.fromCache({blending:Pn.ALPHA_BLEND})}if(!c(o.shaderProgram)||this._useHdr!==e){let a=new Ze({defines:[e?"HDR":""],sources:[c5]});o.shaderProgram=xn.fromCache({context:i,vertexShaderSource:m5,fragmentShaderSource:a,attributeLocations:this._attributeLocations}),this._useHdr=e}if(c(this._cubeMap))return o};yj.prototype.isDestroyed=function(){return!1};yj.prototype.destroy=function(){let t=this._command;return t.vertexArray=t.vertexArray&&t.vertexArray.destroy(),t.shaderProgram=t.shaderProgram&&t.shaderProgram.destroy(),this._cubeMap=this._cubeMap&&this._cubeMap.destroy(),At(this)};var h5=yj;var j_o=b(W(),1);var b_o=b(W(),1),p5=`uniform sampler2D u_texture; in vec2 v_textureCoordinates; @@ -14770,7 +14770,7 @@ void main() vec4 color = texture(u_texture, v_textureCoordinates); out_FragColor = czm_gammaCorrect(color); } -`;var f_o=R(W(),1),u5=`uniform float u_radiusTS; +`;var f_o=b(W(),1),V5=`uniform float u_radiusTS; in vec2 v_textureCoordinates; @@ -14825,7 +14825,7 @@ void main() out_FragColor = clamp(color, vec4(0.0), vec4(1.0)); } -`;var U_o=R(W(),1),Z5=`in vec2 direction; +`;var U_o=b(W(),1),u5=`in vec2 direction; uniform float u_size; @@ -14853,9 +14853,9 @@ void main() v_textureCoordinates = direction; } -`;function b5(){this.show=!0,this._drawCommand=new Ee({primitiveType:le.TRIANGLES,boundingVolume:new Ft,owner:this}),this._commands={drawCommand:this._drawCommand,computeCommand:void 0},this._boundingVolume=new Ft,this._boundingVolume2D=new Ft,this._texture=void 0,this._drawingBufferWidth=void 0,this._drawingBufferHeight=void 0,this._radiusTS=void 0,this._size=void 0,this.glowFactor=1,this._glowFactorDirty=!1,this._useHdr=void 0;let t=this;this._uniformMap={u_texture:function(){return t._texture},u_size:function(){return t._size}}}Object.defineProperties(b5.prototype,{glowFactor:{get:function(){return this._glowFactor},set:function(t){t=Math.max(t,0),this._glowFactor=t,this._glowFactorDirty=!0}}});var VJe=new K,bJe=new K,RJe=new Rt,V5=new Rt;b5.prototype.update=function(t,e,n){if(!this.show)return;let i=t.mode;if(i===ut.SCENE2D||i===ut.MORPHING||!t.passes.render)return;let o=t.context,a=e.viewport.width,s=e.viewport.height;if(!c(this._texture)||a!==this._drawingBufferWidth||s!==this._drawingBufferHeight||this._glowFactorDirty||n!==this._useHdr){this._texture=this._texture&&this._texture.destroy(),this._drawingBufferWidth=a,this._drawingBufferHeight=s,this._glowFactorDirty=!1,this._useHdr=n;let g=Math.max(a,s);g=Math.pow(2,Math.ceil(Math.log(g)/Math.log(2))-2),g=Math.max(1,g);let C=n?o.halfFloatingPointTexture?Ue.HALF_FLOAT:Ue.FLOAT:Ue.UNSIGNED_BYTE;this._texture=new hn({context:o,width:g,height:g,pixelFormat:Ye.RGBA,pixelDatatype:C}),this._glowLengthTS=this._glowFactor*5,this._radiusTS=1/(1+2*this._glowLengthTS)*.5;let y=this,Y={u_radiusTS:function(){return y._radiusTS}};this._commands.computeCommand=new Wm({fragmentShaderSource:u5,outputTexture:this._texture,uniformMap:Y,persists:!1,owner:this,postExecute:function(){y._commands.computeCommand=void 0}})}let l=this._drawCommand;if(!c(l.vertexArray)){let g={direction:0},C=new Uint8Array(4*2);C[0]=0,C[1]=0,C[2]=255,C[3]=0,C[4]=255,C[5]=255,C[6]=0,C[7]=255;let y=we.createVertexBuffer({context:o,typedArray:C,usage:ce.STATIC_DRAW}),Y=[{index:g.direction,vertexBuffer:y,componentsPerAttribute:2,normalize:!0,componentDatatype:it.UNSIGNED_BYTE}],Q=we.createIndexBuffer({context:o,typedArray:new Uint16Array([0,1,2,0,2,3]),usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT});l.vertexArray=new Ki({context:o,attributes:Y,indexBuffer:Q}),l.shaderProgram=xn.fromCache({context:o,vertexShaderSource:Z5,fragmentShaderSource:p5,attributeLocations:g}),l.renderState=he.fromCache({blending:Pn.ALPHA_BLEND}),l.uniformMap=this._uniformMap}let r=o.uniformState.sunPositionWC,d=o.uniformState.sunPositionColumbusView,m=this._boundingVolume,h=this._boundingVolume2D;p.clone(r,m.center),h.center.x=d.z,h.center.y=d.x,h.center.z=d.y,m.radius=k.SOLAR_RADIUS+k.SOLAR_RADIUS*this._glowLengthTS,h.radius=m.radius,i===ut.SCENE3D?Ft.clone(m,l.boundingVolume):i===ut.COLUMBUS_VIEW&&Ft.clone(h,l.boundingVolume);let Z=qo.computeActualWgs84Position(t,r,V5),b=p.magnitude(p.subtract(Z,t.camera.position,V5)),u=o.uniformState.projection,F=RJe;F.x=0,F.y=0,F.z=-b,F.w=1;let U=L.multiplyByVector(u,F,V5),G=qo.clipToGLWindowCoordinates(e.viewport,U,VJe);F.x=k.SOLAR_RADIUS;let A=L.multiplyByVector(u,F,V5),T=qo.clipToGLWindowCoordinates(e.viewport,A,bJe);return this._size=K.magnitude(K.subtract(T,G,V5)),this._size=2*this._size*(1+2*this._glowLengthTS),this._size=Math.ceil(this._size),this._commands};b5.prototype.isDestroyed=function(){return!1};b5.prototype.destroy=function(){let t=this._drawCommand;return t.vertexArray=t.vertexArray&&t.vertexArray.destroy(),t.shaderProgram=t.shaderProgram&&t.shaderProgram.destroy(),this._texture=this._texture&&this._texture.destroy(),At(this)};var R5=b5;function $1(t){return Dn(`Assets/Textures/SkyBox/tycho2t3_80_${t}.jpg`)}function WJe(t){t._renderLoopRunning=!0;let e=0;function n(i){if(!t.isDestroyed())if(t._useDefaultRenderLoop)try{let o=t._targetFrameRate;if(!c(o))t.resize(),t.render(),requestAnimationFrame(n);else{let a=1e3/o,s=i-e;s>a&&(t.resize(),t.render(),e=i-s%a),requestAnimationFrame(n)}}catch(o){t._useDefaultRenderLoop=!1,t._renderLoopRunning=!1,t._showRenderLoopErrors&&t.showErrorPanel("An error occurred while rendering. Rendering has stopped.",void 0,o)}else t._renderLoopRunning=!1}requestAnimationFrame(n)}function vQt(t){let e=t._useBrowserRecommendedResolution?1:window.devicePixelRatio;return e*=t._resolutionScale,c(t._scene)&&(t._scene.pixelRatio=e),e}function KQt(t){let e=t._canvas,n=e.clientWidth,i=e.clientHeight,o=vQt(t);t._canvasClientWidth=n,t._canvasClientHeight=i,n*=o,i*=o,e.width=n,e.height=i,t._canRender=n!==0&&i!==0,t._lastDevicePixelRatio=window.devicePixelRatio}function zQt(t){let e=t._canvas,n=e.width,i=e.height;if(n!==0&&i!==0){let o=t._scene.camera.frustum;c(o.aspectRatio)?o.aspectRatio=n/i:(o.top=o.right*(i/n),o.bottom=-o.top)}}function _S(t,e){t=Ui(t),e=f(e,f.EMPTY_OBJECT);let n=document.createElement("div");n.className="cesium-widget",t.appendChild(n);let i=document.createElement("canvas"),o=In.supportsImageRenderingPixelated();this._supportsImageRenderingPixelated=o,o&&(i.style.imageRendering=In.imageRenderingValue()),i.oncontextmenu=function(){return!1},i.onselectstart=function(){return!1};function a(){i!==i.ownerDocument.activeElement&&i.ownerDocument.activeElement.blur()}f(e.blurActiveElementOnCanvasFocus,!0)&&(i.addEventListener("mousedown",a),i.addEventListener("pointerdown",a)),n.appendChild(i);let l=document.createElement("div");l.className="cesium-widget-credits";let r=c(e.creditContainer)?Ui(e.creditContainer):n;r.appendChild(l);let d=c(e.creditViewport)?Ui(e.creditViewport):n,m=f(e.showRenderLoopErrors,!0),h=f(e.useBrowserRecommendedResolution,!0);this._element=n,this._container=t,this._canvas=i,this._canvasClientWidth=0,this._canvasClientHeight=0,this._lastDevicePixelRatio=0,this._creditViewport=d,this._creditContainer=r,this._innerCreditContainer=l,this._canRender=!1,this._renderLoopRunning=!1,this._showRenderLoopErrors=m,this._resolutionScale=1,this._useBrowserRecommendedResolution=h,this._forceResize=!1,this._clock=c(e.clock)?e.clock:new kZ,KQt(this);try{let Z=new s5({canvas:i,contextOptions:e.contextOptions,creditContainer:l,creditViewport:d,mapProjection:e.mapProjection,orderIndependentTranslucency:e.orderIndependentTranslucency,scene3DOnly:f(e.scene3DOnly,!1),shadows:e.shadows,mapMode2D:e.mapMode2D,requestRenderMode:e.requestRenderMode,maximumRenderTimeChange:e.maximumRenderTimeChange,depthPlaneEllipsoidOffset:e.depthPlaneEllipsoidOffset,msaaSamples:e.msaaSamples});this._scene=Z,Z.camera.constrainedAxis=p.UNIT_Z,vQt(this),zQt(this);let b=f(Z.mapProjection.ellipsoid,mt.WGS84),u=e.globe;c(u)||(u=new r_(b)),u!==!1&&(Z.globe=u,Z.globe.shadows=f(e.terrainShadows,ui.RECEIVE_ONLY));let F=e.skyBox;c(F)||(F=new h5({sources:{positiveX:$1("px"),negativeX:$1("mx"),positiveY:$1("py"),negativeY:$1("my"),positiveZ:$1("pz"),negativeZ:$1("mz")}})),F!==!1&&(Z.skyBox=F,Z.sun=new R5,Z.moon=new u_);let U=e.skyAtmosphere;c(U)||(U=new d5(b),U.show=e.globe!==!1&&u.show),U!==!1&&(Z.skyAtmosphere=U);let G=e.baseLayer;e.globe!==!1&&G!==!1&&(c(G)||(G=$r.fromWorldImagery()),Z.imageryLayers.add(G)),c(e.terrainProvider)&&e.globe!==!1&&(Z.terrainProvider=e.terrainProvider),c(e.terrain)&&e.globe!==!1&&Z.setTerrain(e.terrain),this._screenSpaceEventHandler=new sp(i),c(e.sceneMode)&&(e.sceneMode===ut.SCENE2D&&this._scene.morphTo2D(0),e.sceneMode===ut.COLUMBUS_VIEW&&this._scene.morphToColumbusView(0)),this._useDefaultRenderLoop=void 0,this.useDefaultRenderLoop=f(e.useDefaultRenderLoop,!0),this._targetFrameRate=void 0,this.targetFrameRate=e.targetFrameRate;let A=this;this._onRenderError=function(T,g){A._useDefaultRenderLoop=!1,A._renderLoopRunning=!1,A._showRenderLoopErrors&&A.showErrorPanel("An error occurred while rendering. Rendering has stopped.",void 0,g)},Z.renderError.addEventListener(this._onRenderError)}catch(Z){throw m&&this.showErrorPanel("Error constructing CesiumWidget.",'Visit <a href="http://get.webgl.org">http://get.webgl.org</a> to verify that your web browser and hardware support WebGL. Consider trying a different web browser or updating your video drivers. Detailed error information is below:',Z),Z}}Object.defineProperties(_S.prototype,{container:{get:function(){return this._container}},canvas:{get:function(){return this._canvas}},creditContainer:{get:function(){return this._creditContainer}},creditViewport:{get:function(){return this._creditViewport}},scene:{get:function(){return this._scene}},imageryLayers:{get:function(){return this._scene.imageryLayers}},terrainProvider:{get:function(){return this._scene.terrainProvider},set:function(t){this._scene.terrainProvider=t}},creditDisplay:{get:function(){return this._scene.frameState.creditDisplay}},camera:{get:function(){return this._scene.camera}},clock:{get:function(){return this._clock}},screenSpaceEventHandler:{get:function(){return this._screenSpaceEventHandler}},targetFrameRate:{get:function(){return this._targetFrameRate},set:function(t){this._targetFrameRate=t}},useDefaultRenderLoop:{get:function(){return this._useDefaultRenderLoop},set:function(t){this._useDefaultRenderLoop!==t&&(this._useDefaultRenderLoop=t,t&&!this._renderLoopRunning&&WJe(this))}},resolutionScale:{get:function(){return this._resolutionScale},set:function(t){this._resolutionScale!==t&&(this._resolutionScale=t,this._forceResize=!0)}},useBrowserRecommendedResolution:{get:function(){return this._useBrowserRecommendedResolution},set:function(t){this._useBrowserRecommendedResolution!==t&&(this._useBrowserRecommendedResolution=t,this._forceResize=!0)}}});_S.prototype.showErrorPanel=function(t,e,n){let i=this._element,o=document.createElement("div");o.className="cesium-widget-errorPanel";let a=document.createElement("div");a.className="cesium-widget-errorPanel-content",o.appendChild(a);let s=document.createElement("div");s.className="cesium-widget-errorPanel-header",s.appendChild(document.createTextNode(t)),a.appendChild(s);let l=document.createElement("div");l.className="cesium-widget-errorPanel-scroll",a.appendChild(l);function r(){l.style.maxHeight=`${Math.max(Math.round(i.clientHeight*.9-100),30)}px`}r(),c(window.addEventListener)&&window.addEventListener("resize",r,!1);let d=c(e),m=c(n);if(d||m){let b=document.createElement("div");if(b.className="cesium-widget-errorPanel-message",l.appendChild(b),m){let u=Qb(n);d||(typeof n=="string"&&(n=new Error(n)),e=Qb({name:n.name,message:n.message}),u=n.stack),typeof console<"u"&&console.error(`${t} +`;function R5(){this.show=!0,this._drawCommand=new Ee({primitiveType:le.TRIANGLES,boundingVolume:new Ft,owner:this}),this._commands={drawCommand:this._drawCommand,computeCommand:void 0},this._boundingVolume=new Ft,this._boundingVolume2D=new Ft,this._texture=void 0,this._drawingBufferWidth=void 0,this._drawingBufferHeight=void 0,this._radiusTS=void 0,this._size=void 0,this.glowFactor=1,this._glowFactorDirty=!1,this._useHdr=void 0;let t=this;this._uniformMap={u_texture:function(){return t._texture},u_size:function(){return t._size}}}Object.defineProperties(R5.prototype,{glowFactor:{get:function(){return this._glowFactor},set:function(t){t=Math.max(t,0),this._glowFactor=t,this._glowFactorDirty=!0}}});var ZJe=new K,RJe=new K,bJe=new bt,Z5=new bt;R5.prototype.update=function(t,e,n){if(!this.show)return;let i=t.mode;if(i===Vt.SCENE2D||i===Vt.MORPHING||!t.passes.render)return;let o=t.context,a=e.viewport.width,s=e.viewport.height;if(!c(this._texture)||a!==this._drawingBufferWidth||s!==this._drawingBufferHeight||this._glowFactorDirty||n!==this._useHdr){this._texture=this._texture&&this._texture.destroy(),this._drawingBufferWidth=a,this._drawingBufferHeight=s,this._glowFactorDirty=!1,this._useHdr=n;let g=Math.max(a,s);g=Math.pow(2,Math.ceil(Math.log(g)/Math.log(2))-2),g=Math.max(1,g);let C=n?o.halfFloatingPointTexture?Ue.HALF_FLOAT:Ue.FLOAT:Ue.UNSIGNED_BYTE;this._texture=new hn({context:o,width:g,height:g,pixelFormat:Ye.RGBA,pixelDatatype:C}),this._glowLengthTS=this._glowFactor*5,this._radiusTS=1/(1+2*this._glowLengthTS)*.5;let y=this,Y={u_radiusTS:function(){return y._radiusTS}};this._commands.computeCommand=new Wm({fragmentShaderSource:V5,outputTexture:this._texture,uniformMap:Y,persists:!1,owner:this,postExecute:function(){y._commands.computeCommand=void 0}})}let l=this._drawCommand;if(!c(l.vertexArray)){let g={direction:0},C=new Uint8Array(4*2);C[0]=0,C[1]=0,C[2]=255,C[3]=0,C[4]=255,C[5]=255,C[6]=0,C[7]=255;let y=we.createVertexBuffer({context:o,typedArray:C,usage:ce.STATIC_DRAW}),Y=[{index:g.direction,vertexBuffer:y,componentsPerAttribute:2,normalize:!0,componentDatatype:it.UNSIGNED_BYTE}],Q=we.createIndexBuffer({context:o,typedArray:new Uint16Array([0,1,2,0,2,3]),usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT});l.vertexArray=new Ki({context:o,attributes:Y,indexBuffer:Q}),l.shaderProgram=xn.fromCache({context:o,vertexShaderSource:u5,fragmentShaderSource:p5,attributeLocations:g}),l.renderState=he.fromCache({blending:Pn.ALPHA_BLEND}),l.uniformMap=this._uniformMap}let r=o.uniformState.sunPositionWC,d=o.uniformState.sunPositionColumbusView,m=this._boundingVolume,h=this._boundingVolume2D;p.clone(r,m.center),h.center.x=d.z,h.center.y=d.x,h.center.z=d.y,m.radius=k.SOLAR_RADIUS+k.SOLAR_RADIUS*this._glowLengthTS,h.radius=m.radius,i===Vt.SCENE3D?Ft.clone(m,l.boundingVolume):i===Vt.COLUMBUS_VIEW&&Ft.clone(h,l.boundingVolume);let u=qo.computeActualWgs84Position(t,r,Z5),R=p.magnitude(p.subtract(u,t.camera.position,Z5)),V=o.uniformState.projection,F=bJe;F.x=0,F.y=0,F.z=-R,F.w=1;let U=L.multiplyByVector(V,F,Z5),G=qo.clipToGLWindowCoordinates(e.viewport,U,ZJe);F.x=k.SOLAR_RADIUS;let A=L.multiplyByVector(V,F,Z5),S=qo.clipToGLWindowCoordinates(e.viewport,A,RJe);return this._size=K.magnitude(K.subtract(S,G,Z5)),this._size=2*this._size*(1+2*this._glowLengthTS),this._size=Math.ceil(this._size),this._commands};R5.prototype.isDestroyed=function(){return!1};R5.prototype.destroy=function(){let t=this._drawCommand;return t.vertexArray=t.vertexArray&&t.vertexArray.destroy(),t.shaderProgram=t.shaderProgram&&t.shaderProgram.destroy(),this._texture=this._texture&&this._texture.destroy(),At(this)};var b5=R5;function $1(t){return Dn(`Assets/Textures/SkyBox/tycho2t3_80_${t}.jpg`)}function WJe(t){t._renderLoopRunning=!0;let e=0;function n(i){if(!t.isDestroyed())if(t._useDefaultRenderLoop)try{let o=t._targetFrameRate;if(!c(o))t.resize(),t.render(),requestAnimationFrame(n);else{let a=1e3/o,s=i-e;s>a&&(t.resize(),t.render(),e=i-s%a),requestAnimationFrame(n)}}catch(o){t._useDefaultRenderLoop=!1,t._renderLoopRunning=!1,t._showRenderLoopErrors&&t.showErrorPanel("An error occurred while rendering. Rendering has stopped.",void 0,o)}else t._renderLoopRunning=!1}requestAnimationFrame(n)}function vQt(t){let e=t._useBrowserRecommendedResolution?1:window.devicePixelRatio;return e*=t._resolutionScale,c(t._scene)&&(t._scene.pixelRatio=e),e}function KQt(t){let e=t._canvas,n=e.clientWidth,i=e.clientHeight,o=vQt(t);t._canvasClientWidth=n,t._canvasClientHeight=i,n*=o,i*=o,e.width=n,e.height=i,t._canRender=n!==0&&i!==0,t._lastDevicePixelRatio=window.devicePixelRatio}function zQt(t){let e=t._canvas,n=e.width,i=e.height;if(n!==0&&i!==0){let o=t._scene.camera.frustum;c(o.aspectRatio)?o.aspectRatio=n/i:(o.top=o.right*(i/n),o.bottom=-o.top)}}function _T(t,e){t=Ui(t),e=f(e,f.EMPTY_OBJECT);let n=document.createElement("div");n.className="cesium-widget",t.appendChild(n);let i=document.createElement("canvas"),o=In.supportsImageRenderingPixelated();this._supportsImageRenderingPixelated=o,o&&(i.style.imageRendering=In.imageRenderingValue()),i.oncontextmenu=function(){return!1},i.onselectstart=function(){return!1};function a(){i!==i.ownerDocument.activeElement&&i.ownerDocument.activeElement.blur()}f(e.blurActiveElementOnCanvasFocus,!0)&&(i.addEventListener("mousedown",a),i.addEventListener("pointerdown",a)),n.appendChild(i);let l=document.createElement("div");l.className="cesium-widget-credits";let r=c(e.creditContainer)?Ui(e.creditContainer):n;r.appendChild(l);let d=c(e.creditViewport)?Ui(e.creditViewport):n,m=f(e.showRenderLoopErrors,!0),h=f(e.useBrowserRecommendedResolution,!0);this._element=n,this._container=t,this._canvas=i,this._canvasClientWidth=0,this._canvasClientHeight=0,this._lastDevicePixelRatio=0,this._creditViewport=d,this._creditContainer=r,this._innerCreditContainer=l,this._canRender=!1,this._renderLoopRunning=!1,this._showRenderLoopErrors=m,this._resolutionScale=1,this._useBrowserRecommendedResolution=h,this._forceResize=!1,this._clock=c(e.clock)?e.clock:new ku,KQt(this);try{let u=new s5({canvas:i,contextOptions:e.contextOptions,creditContainer:l,creditViewport:d,mapProjection:e.mapProjection,orderIndependentTranslucency:e.orderIndependentTranslucency,scene3DOnly:f(e.scene3DOnly,!1),shadows:e.shadows,mapMode2D:e.mapMode2D,requestRenderMode:e.requestRenderMode,maximumRenderTimeChange:e.maximumRenderTimeChange,depthPlaneEllipsoidOffset:e.depthPlaneEllipsoidOffset,msaaSamples:e.msaaSamples});this._scene=u,u.camera.constrainedAxis=p.UNIT_Z,vQt(this),zQt(this);let R=f(u.mapProjection.ellipsoid,mt.WGS84),V=e.globe;c(V)||(V=new r_(R)),V!==!1&&(u.globe=V,u.globe.shadows=f(e.terrainShadows,Vi.RECEIVE_ONLY));let F=e.skyBox;c(F)||(F=new h5({sources:{positiveX:$1("px"),negativeX:$1("mx"),positiveY:$1("py"),negativeY:$1("my"),positiveZ:$1("pz"),negativeZ:$1("mz")}})),F!==!1&&(u.skyBox=F,u.sun=new b5,u.moon=new V_);let U=e.skyAtmosphere;c(U)||(U=new d5(R),U.show=e.globe!==!1&&V.show),U!==!1&&(u.skyAtmosphere=U);let G=e.baseLayer;e.globe!==!1&&G!==!1&&(c(G)||(G=$r.fromWorldImagery()),u.imageryLayers.add(G)),c(e.terrainProvider)&&e.globe!==!1&&(u.terrainProvider=e.terrainProvider),c(e.terrain)&&e.globe!==!1&&u.setTerrain(e.terrain),this._screenSpaceEventHandler=new sp(i),c(e.sceneMode)&&(e.sceneMode===Vt.SCENE2D&&this._scene.morphTo2D(0),e.sceneMode===Vt.COLUMBUS_VIEW&&this._scene.morphToColumbusView(0)),this._useDefaultRenderLoop=void 0,this.useDefaultRenderLoop=f(e.useDefaultRenderLoop,!0),this._targetFrameRate=void 0,this.targetFrameRate=e.targetFrameRate;let A=this;this._onRenderError=function(S,g){A._useDefaultRenderLoop=!1,A._renderLoopRunning=!1,A._showRenderLoopErrors&&A.showErrorPanel("An error occurred while rendering. Rendering has stopped.",void 0,g)},u.renderError.addEventListener(this._onRenderError)}catch(u){throw m&&this.showErrorPanel("Error constructing CesiumWidget.",'Visit <a href="http://get.webgl.org">http://get.webgl.org</a> to verify that your web browser and hardware support WebGL. Consider trying a different web browser or updating your video drivers. Detailed error information is below:',u),u}}Object.defineProperties(_T.prototype,{container:{get:function(){return this._container}},canvas:{get:function(){return this._canvas}},creditContainer:{get:function(){return this._creditContainer}},creditViewport:{get:function(){return this._creditViewport}},scene:{get:function(){return this._scene}},imageryLayers:{get:function(){return this._scene.imageryLayers}},terrainProvider:{get:function(){return this._scene.terrainProvider},set:function(t){this._scene.terrainProvider=t}},creditDisplay:{get:function(){return this._scene.frameState.creditDisplay}},camera:{get:function(){return this._scene.camera}},clock:{get:function(){return this._clock}},screenSpaceEventHandler:{get:function(){return this._screenSpaceEventHandler}},targetFrameRate:{get:function(){return this._targetFrameRate},set:function(t){this._targetFrameRate=t}},useDefaultRenderLoop:{get:function(){return this._useDefaultRenderLoop},set:function(t){this._useDefaultRenderLoop!==t&&(this._useDefaultRenderLoop=t,t&&!this._renderLoopRunning&&WJe(this))}},resolutionScale:{get:function(){return this._resolutionScale},set:function(t){this._resolutionScale!==t&&(this._resolutionScale=t,this._forceResize=!0)}},useBrowserRecommendedResolution:{get:function(){return this._useBrowserRecommendedResolution},set:function(t){this._useBrowserRecommendedResolution!==t&&(this._useBrowserRecommendedResolution=t,this._forceResize=!0)}}});_T.prototype.showErrorPanel=function(t,e,n){let i=this._element,o=document.createElement("div");o.className="cesium-widget-errorPanel";let a=document.createElement("div");a.className="cesium-widget-errorPanel-content",o.appendChild(a);let s=document.createElement("div");s.className="cesium-widget-errorPanel-header",s.appendChild(document.createTextNode(t)),a.appendChild(s);let l=document.createElement("div");l.className="cesium-widget-errorPanel-scroll",a.appendChild(l);function r(){l.style.maxHeight=`${Math.max(Math.round(i.clientHeight*.9-100),30)}px`}r(),c(window.addEventListener)&&window.addEventListener("resize",r,!1);let d=c(e),m=c(n);if(d||m){let R=document.createElement("div");if(R.className="cesium-widget-errorPanel-message",l.appendChild(R),m){let V=QR(n);d||(typeof n=="string"&&(n=new Error(n)),e=QR({name:n.name,message:n.message}),V=n.stack),typeof console<"u"&&console.error(`${t} ${e} -${u}`);let F=document.createElement("div");F.className="cesium-widget-errorPanel-message-details collapsed";let U=document.createElement("span");U.className="cesium-widget-errorPanel-more-details",U.appendChild(document.createTextNode("See more...")),F.appendChild(U),F.onclick=function(G){F.removeChild(U),F.appendChild(document.createTextNode(u)),F.className="cesium-widget-errorPanel-message-details",a.className="cesium-widget-errorPanel-content expanded",F.onclick=void 0},l.appendChild(F)}b.innerHTML=`<p>${e}</p>`}let h=document.createElement("div");h.className="cesium-widget-errorPanel-buttonPanel",a.appendChild(h);let Z=document.createElement("button");Z.setAttribute("type","button"),Z.className="cesium-button",Z.appendChild(document.createTextNode("OK")),Z.onclick=function(){c(r)&&c(window.removeEventListener)&&window.removeEventListener("resize",r,!1),i.removeChild(o)},h.appendChild(Z),i.appendChild(o)};_S.prototype.isDestroyed=function(){return!1};_S.prototype.destroy=function(){c(this._scene)&&(this._scene.renderError.removeEventListener(this._onRenderError),this._scene=this._scene.destroy()),this._container.removeChild(this._element),this._creditContainer.removeChild(this._innerCreditContainer),At(this)};_S.prototype.resize=function(){let t=this._canvas;!this._forceResize&&this._canvasClientWidth===t.clientWidth&&this._canvasClientHeight===t.clientHeight&&this._lastDevicePixelRatio===window.devicePixelRatio||(this._forceResize=!1,KQt(this),zQt(this),this._scene.requestRender())};_S.prototype.render=function(){if(this._canRender){this._scene.initializeFrame();let t=this._clock.tick();this._scene.render(t)}else this._clock.tick()};var W5=_S;var F9o=R(W(),1),f5=`uniform sampler2D u_noiseTexture; +${V}`);let F=document.createElement("div");F.className="cesium-widget-errorPanel-message-details collapsed";let U=document.createElement("span");U.className="cesium-widget-errorPanel-more-details",U.appendChild(document.createTextNode("See more...")),F.appendChild(U),F.onclick=function(G){F.removeChild(U),F.appendChild(document.createTextNode(V)),F.className="cesium-widget-errorPanel-message-details",a.className="cesium-widget-errorPanel-content expanded",F.onclick=void 0},l.appendChild(F)}R.innerHTML=`<p>${e}</p>`}let h=document.createElement("div");h.className="cesium-widget-errorPanel-buttonPanel",a.appendChild(h);let u=document.createElement("button");u.setAttribute("type","button"),u.className="cesium-button",u.appendChild(document.createTextNode("OK")),u.onclick=function(){c(r)&&c(window.removeEventListener)&&window.removeEventListener("resize",r,!1),i.removeChild(o)},h.appendChild(u),i.appendChild(o)};_T.prototype.isDestroyed=function(){return!1};_T.prototype.destroy=function(){c(this._scene)&&(this._scene.renderError.removeEventListener(this._onRenderError),this._scene=this._scene.destroy()),this._container.removeChild(this._element),this._creditContainer.removeChild(this._innerCreditContainer),At(this)};_T.prototype.resize=function(){let t=this._canvas;!this._forceResize&&this._canvasClientWidth===t.clientWidth&&this._canvasClientHeight===t.clientHeight&&this._lastDevicePixelRatio===window.devicePixelRatio||(this._forceResize=!1,KQt(this),zQt(this),this._scene.requestRender())};_T.prototype.render=function(){if(this._canRender){this._scene.initializeFrame();let t=this._clock.tick();this._scene.render(t)}else this._clock.tick()};var W5=_T;var F9o=b(W(),1),f5=`uniform sampler2D u_noiseTexture; uniform vec3 u_noiseTextureDimensions; uniform float u_noiseDetail; in vec2 v_offset; @@ -15118,7 +15118,7 @@ void main() { #endif #endif } -`;var G9o=R(W(),1),F5=`#ifdef INSTANCED +`;var G9o=b(W(),1),F5=`#ifdef INSTANCED in vec2 direction; #endif in vec4 positionHighAndScaleX; @@ -15166,7 +15166,7 @@ void main() { v_slice = slice; v_brightness = brightness; } -`;var T9o=R(W(),1),U5=`uniform vec3 u_noiseTextureDimensions; +`;var S9o=b(W(),1),U5=`uniform vec3 u_noiseTextureDimensions; uniform float u_noiseDetail; uniform vec3 u_noiseOffset; in vec2 v_position; @@ -15258,7 +15258,7 @@ void main() { float worley2 = clamp(worleyFBMNoise(position, 3.0, 3.0), 0.0, 1.0); out_FragColor = vec4(worley0, worley1, worley2, 1.0); } -`;var g9o=R(W(),1),G5=`uniform vec3 u_noiseTextureDimensions; +`;var g9o=b(W(),1),G5=`uniform vec3 u_noiseTextureDimensions; in vec2 position; out vec2 v_position; @@ -15276,7 +15276,7 @@ void main() transformedPos.y *= noiseTextureRows; v_position = transformedPos; } -`;var C9o=R(W(),1),A5=` +`;var C9o=b(W(),1),A5=` in vec2 v_textureCoordinates; void main() @@ -15292,14 +15292,14 @@ void main() out_FragColor = vec4(material.diffuse + material.emission, material.alpha); } -`;var n5o=R(W(),1);var k9o=R(W(),1);function nN(t,e){this._tilingScheme=t,this._maximumLevel=e,this._rootNodes=[]}var DS=new Gt;function fJe(t,e,n,i){let o=i.length;for(let a=0;a<o;++a){let s=i[a];if(s.x===e&&s.y===n&&s.level===t)return!0}return!1}nN.prototype.addAvailableTileRange=function(t,e,n,i,o){let a=this._tilingScheme,s=this._rootNodes;if(t===0)for(let Z=n;Z<=o;++Z)for(let b=e;b<=i;++b)fJe(t,b,Z,s)||s.push(new tN(a,void 0,0,b,Z));a.tileXYToRectangle(e,n,t,DS);let l=DS.west,r=DS.north;a.tileXYToRectangle(i,o,t,DS);let d=DS.east,m=DS.south,h=new TJe(t,l,m,d,r);for(let Z=0;Z<s.length;++Z){let b=s[Z];Ast(b.extent,h)&&SJe(this._maximumLevel,b,h)}};nN.prototype.computeMaximumLevelAtPosition=function(t){let e;for(let n=0;n<this._rootNodes.length;++n){let i=this._rootNodes[n];if(eN(i.extent,t)){e=i;break}}return c(e)?T5(void 0,e,t):-1};var FJe=[],UJe=[],GJe=new Gt,AJe=new Gt;nN.prototype.computeBestAvailableLevelOverRectangle=function(t){let e=FJe;e.length=0,t.east<t.west?(e.push(Gt.fromRadians(-Math.PI,t.south,t.east,t.north,GJe)),e.push(Gt.fromRadians(t.west,t.south,Math.PI,t.north,AJe))):e.push(t);let n=UJe;n.length=0;let i;for(i=0;i<this._rootNodes.length;++i)S5(n,this._rootNodes[i],e);for(i=n.length-1;i>=0;--i)if(c(n[i])&&n[i].length===0)return i;return 0};var jQt=new gt;nN.prototype.isTileAvailable=function(t,e,n){let i=this._tilingScheme.tileXYToRectangle(e,n,t,DS);return Gt.center(i,jQt),this.computeMaximumLevelAtPosition(jQt)>=t};nN.prototype.computeChildMaskForTile=function(t,e,n){let i=t+1;if(i>=this._maximumLevel)return 0;let o=0;return o|=this.isTileAvailable(i,2*e,2*n+1)?1:0,o|=this.isTileAvailable(i,2*e+1,2*n+1)?2:0,o|=this.isTileAvailable(i,2*e,2*n)?4:0,o|=this.isTileAvailable(i,2*e+1,2*n)?8:0,o};function tN(t,e,n,i,o){this.tilingScheme=t,this.parent=e,this.level=n,this.x=i,this.y=o,this.extent=t.tileXYToRectangle(i,o,n),this.rectangles=[],this._sw=void 0,this._se=void 0,this._nw=void 0,this._ne=void 0}Object.defineProperties(tN.prototype,{nw:{get:function(){return this._nw||(this._nw=new tN(this.tilingScheme,this,this.level+1,this.x*2,this.y*2)),this._nw}},ne:{get:function(){return this._ne||(this._ne=new tN(this.tilingScheme,this,this.level+1,this.x*2+1,this.y*2)),this._ne}},sw:{get:function(){return this._sw||(this._sw=new tN(this.tilingScheme,this,this.level+1,this.x*2,this.y*2+1)),this._sw}},se:{get:function(){return this._se||(this._se=new tN(this.tilingScheme,this,this.level+1,this.x*2+1,this.y*2+1)),this._se}}});function TJe(t,e,n,i,o){this.level=t,this.west=e,this.south=n,this.east=i,this.north=o}function Ast(t,e){let n=Math.max(t.west,e.west),i=Math.max(t.south,e.south),o=Math.min(t.east,e.east),a=Math.min(t.north,e.north);return i<a&&n<o}function SJe(t,e,n){for(;e.level<t;)if(Bj(e.nw.extent,n))e=e.nw;else if(Bj(e.ne.extent,n))e=e.ne;else if(Bj(e.sw.extent,n))e=e.sw;else if(Bj(e.se.extent,n))e=e.se;else break;if(e.rectangles.length===0||e.rectangles[e.rectangles.length-1].level<=n.level)e.rectangles.push(n);else{let i=Ja(e.rectangles,n.level,gJe);i<0&&(i=~i),e.rectangles.splice(i,0,n)}}function gJe(t,e){return t.level-e}function Bj(t,e){return e.west>=t.west&&e.east<=t.east&&e.south>=t.south&&e.north<=t.north}function eN(t,e){return e.longitude>=t.west&&e.longitude<=t.east&&e.latitude>=t.south&&e.latitude<=t.north}function T5(t,e,n){let i=0,o=!1;for(;!o;){let a=e._nw&&eN(e._nw.extent,n),s=e._ne&&eN(e._ne.extent,n),l=e._sw&&eN(e._sw.extent,n),r=e._se&&eN(e._se.extent,n);if(a+s+l+r>1){a&&(i=Math.max(i,T5(e,e._nw,n))),s&&(i=Math.max(i,T5(e,e._ne,n))),l&&(i=Math.max(i,T5(e,e._sw,n))),r&&(i=Math.max(i,T5(e,e._se,n)));break}else a?e=e._nw:s?e=e._ne:l?e=e._sw:r?e=e._se:o=!0}for(;e!==t;){let a=e.rectangles;for(let s=a.length-1;s>=0&&a[s].level>i;--s){let l=a[s];eN(l,n)&&(i=l.level)}e=e.parent}return i}function S5(t,e,n){if(!e)return;let i,o=!1;for(i=0;i<n.length;++i)o=o||Ast(e.extent,n[i]);if(!o)return;let a=e.rectangles;for(i=0;i<a.length;++i){let s=a[i];t[s.level]||(t[s.level]=n),t[s.level]=EJe(t[s.level],s)}S5(t,e._nw,n),S5(t,e._ne,n),S5(t,e._sw,n),S5(t,e._se,n)}function EJe(t,e){let n=[];for(let i=0;i<t.length;++i){let o=t[i];Ast(o,e)?(o.west<e.west&&n.push(new Gt(o.west,o.south,e.west,o.north)),o.east>e.east&&n.push(new Gt(e.east,o.south,o.east,o.north)),o.south<e.south&&n.push(new Gt(Math.max(e.west,o.west),o.south,Math.min(e.east,o.east),e.south)),o.north>e.north&&n.push(new Gt(Math.max(e.west,o.west),e.north,Math.min(e.east,o.east),o.north))):n.push(o)}return n}var pV=nN;var CJe=15;function qQt(t){this.ellipsoid=f(t.ellipsoid,mt.WGS84),this.credit=void 0,this.tilingScheme=void 0,this.height=void 0,this.width=void 0,this.encoding=void 0,this.lodCount=void 0,this.hasAvailability=!1,this.tilesAvailable=void 0,this.tilesAvailabilityLoaded=void 0,this.levelZeroMaximumGeometricError=void 0,this.terrainDataStructure=void 0}qQt.prototype.build=function(t){t._credit=this.credit,t._tilingScheme=this.tilingScheme,t._height=this.height,t._width=this.width,t._encoding=this.encoding,t._lodCount=this.lodCount,t._hasAvailability=this.hasAvailability,t._tilesAvailable=this.tilesAvailable,t._tilesAvailabilityLoaded=this.tilesAvailabilityLoaded,t._levelZeroMaximumGeometricError=this.levelZeroMaximumGeometricError,t._terrainDataStructure=this.terrainDataStructure};function IJe(t,e){let n=e.copyrightText;c(n)&&(t.credit=new on(n));let i=e.spatialReference,o=f(i.latestWkid,i.wkid),a=e.extent,s={ellipsoid:t.ellipsoid};if(o===4326)s.rectangle=Gt.fromDegrees(a.xmin,a.ymin,a.xmax,a.ymax),t.tilingScheme=new Qo(s);else if(o===3857){let d=Math.PI*t.ellipsoid.maximumRadius;e.extent.xmax>d&&(e.extent.xmax=d),e.extent.ymax>d&&(e.extent.ymax=d),e.extent.xmin<-d&&(e.extent.xmin=-d),e.extent.ymin<-d&&(e.extent.ymin=-d),s.rectangleSouthwestInMeters=new K(a.xmin,a.ymin),s.rectangleNortheastInMeters=new K(a.xmax,a.ymax),t.tilingScheme=new Gs(s)}else throw new St("Invalid spatial reference");let l=e.tileInfo;if(!c(l))throw new St("tileInfo is required");t.width=l.rows+1,t.height=l.cols+1,t.encoding=l.format==="LERC"?Uu.LERC:Uu.NONE,t.lodCount=l.lods.length-1,(t.hasAvailability=e.capabilities.indexOf("Tilemap")!==-1)&&(t.tilesAvailable=new pV(t.tilingScheme,t.lodCount),t.tilesAvailable.addAvailableTileRange(0,0,0,t.tilingScheme.getNumberOfXTilesAtLevel(0),t.tilingScheme.getNumberOfYTilesAtLevel(0)),t.tilesAvailabilityLoaded=new pV(t.tilingScheme,t.lodCount)),t.levelZeroMaximumGeometricError=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(t.tilingScheme.ellipsoid,t.width,t.tilingScheme.getNumberOfXTilesAtLevel(0)),e.bandCount>1&&console.log("ArcGISTiledElevationTerrainProvider: Terrain data has more than 1 band. Using the first one."),c(e.minValues)&&c(e.maxValues)?t.terrainDataStructure={elementMultiplier:1,lowestEncodedHeight:e.minValues[0],highestEncodedHeight:e.maxValues[0]}:t.terrainDataStructure={elementMultiplier:1}}async function NJe(t,e,n){try{let i=await e.fetchJson();IJe(t,i)}catch(i){let o=`An error occurred while accessing ${e}.`;throw za.reportError(void 0,n,c(n)?n._errorEvent:void 0,o),i}}function gU(t){t=f(t,f.EMPTY_OBJECT),this._resource=void 0,this._credit=void 0,this._tilingScheme=void 0,this._levelZeroMaximumGeometricError=void 0,this._maxLevel=void 0,this._terrainDataStructure=void 0,this._width=void 0,this._height=void 0,this._encoding=void 0,this._lodCount=void 0,this._hasAvailability=!1,this._tilesAvailable=void 0,this._tilesAvailabilityLoaded=void 0,this._availableCache={},this._errorEvent=new It}Object.defineProperties(gU.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},tilingScheme:{get:function(){return this._tilingScheme}},hasWaterMask:{get:function(){return!1}},hasVertexNormals:{get:function(){return!1}},availability:{get:function(){return this._tilesAvailable}}});gU.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT),t=await Promise.resolve(t);let n=te.createIfNeeded(t);n.appendForwardSlash(),c(e.token)&&(n=n.getDerivedResource({queryParameters:{token:e.token}}));let i=n.getDerivedResource({queryParameters:{f:"pjson"}}),o=new qQt(e);await NJe(o,i);let a=new gU(e);return o.build(a),a._resource=n,a};gU.prototype.requestTileGeometry=function(t,e,n,i){let o=this._resource.getDerivedResource({url:`tile/${n}/${e}/${t}`,request:i}),a=this._hasAvailability,s=Promise.resolve(!0),l;if(a&&!c(Tst(this,n+1,t*2,e*2))){let h=$Qt(this,n+1,t*2,e*2);s=h.promise,l=h.request}let r=o.fetchArrayBuffer();if(!c(r)||!c(s))return;let d=this,m=this._tilesAvailable;return Promise.all([r,s]).then(function(h){return new Gd({buffer:h[0],width:d._width,height:d._height,childTileMask:a?m.computeChildMaskForTile(n,t,e):CJe,structure:d._terrainDataStructure,encoding:d._encoding})}).catch(function(h){return c(l)&&l.state===qi.CANCELLED?(i.cancel(),i.deferred.promise.finally(function(){return i.state=qi.CANCELLED,Promise.reject(h)})):Promise.reject(h)})};function Tst(t,e,n,i){if(!t._hasAvailability)return;let o=t._tilesAvailabilityLoaded,a=t._tilesAvailable;if(e>t._lodCount)return!1;if(a.isTileAvailable(e,n,i))return!0;if(o.isTileAvailable(e,n,i))return!1}gU.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<<t)};gU.prototype.getTileDataAvailable=function(t,e,n){if(!this._hasAvailability)return;let i=Tst(this,n,t,e);if(c(i))return i;$Qt(this,n,t,e)};gU.prototype.loadTileDataAvailability=function(t,e,n){};function yJe(t,e,n,i){let o=e-1,a=n-1,s=i[t.y*e+t.x],l=[],r={startX:t.x,startY:t.y,endX:0,endY:0},d=new K(t.x+1,t.y+1),m=!1,h=!1;for(;!(m&&h);){let Z=d.x,b=h?d.y+1:d.y;if(!m){for(let u=t.y;u<b;++u)if(i[u*e+d.x]!==s){m=!0;break}m?(l.push(new K(d.x,t.y)),--d.x,--Z,r.endX=d.x):d.x===o?(r.endX=d.x,m=!0):++d.x}if(!h){let u=d.y*e;for(let F=t.x;F<=Z;++F)if(i[u+F]!==s){h=!0;break}h?(l.push(new K(t.x,d.y)),--d.y,r.endY=d.y):d.y===a?(r.endY=d.y,h=!0):++d.y}}return{endingIndices:l,range:r,value:s}}function BJe(t,e,n,i,o){let a=[];if(o.every(function(r){return r===o[0]}))return o[0]===1&&a.push({startX:t,startY:e,endX:t+n-1,endY:e+i-1}),a;let l=[new K(0,0)];for(;l.length>0;){let r=l.pop(),d=yJe(r,n,i,o);if(d.value===1){let h=d.range;h.startX+=t,h.endX+=t,h.startY+=e,h.endY+=e,a.push(h)}let m=d.endingIndices;m.length>0&&(l=l.concat(m))}return a}function $Qt(t,e,n,i){if(!t._hasAvailability)return{};let o=Math.floor(n/128)*128,a=Math.floor(i/128)*128,s=Math.min(1<<e,128),l=`tilemap/${e}/${a}/${o}/${s}/${s}`,r=t._availableCache;if(c(r[l]))return r[l];let d=new Zs({throttle:!1,throttleByServer:!0,type:Xl.TERRAIN}),h=t._resource.getDerivedResource({url:l,request:d}).fetchJson();return c(h)?(h=h.then(function(Z){let b=BJe(o,a,s,s,Z.data);t._tilesAvailabilityLoaded.addAvailableTileRange(e,o,a,o+s,a+s);let u=t._tilesAvailable;for(let F=0;F<b.length;++F){let U=b[F];u.addAvailableTileRange(e,U.startX,U.startY,U.endX,U.endY)}return Tst(t,e,n,i)}),r[l]={promise:h,request:d},h=h.finally(function(Z){return delete r[l],Z}),{promise:h,request:d}):{}}var Sst=gU;var d5o=R(W(),1);var t2t="https://dev.virtualearth.net/REST/v1/Locations";function gst(t){t=f(t,f.EMPTY_OBJECT);let e=t.key;this._key=e;let n={key:e};c(t.culture)&&(n.culture=t.culture),this._resource=new te({url:t2t,queryParameters:n}),this._credit=new on('<img src="http://dev.virtualearth.net/Branding/logo_powered_by.png"/>',!1)}Object.defineProperties(gst.prototype,{url:{get:function(){return t2t}},key:{get:function(){return this._key}},credit:{get:function(){return this._credit}}});gst.prototype.geocode=async function(t){return this._resource.getDerivedResource({queryParameters:{query:t}}).fetchJsonp("jsonp").then(function(n){return n.resourceSets.length===0?[]:n.resourceSets[0].resources.map(function(o){let a=o.bbox,s=a[0],l=a[1],r=a[2],d=a[3];return{displayName:o.name,destination:Gt.fromDegrees(l,s,d,r)}})})};var Est=gst;var h5o=R(W(),1);function Cst(){}Object.defineProperties(Cst.prototype,{credit:{get:function(){}}});Cst.prototype.geocode=function(t){let e=t.match(/[^\s,\n]+/g);if(e.length===2||e.length===3){let n=+e[0],i=+e[1],o=e.length===3?+e[2]:300;if(isNaN(n)&&isNaN(i)){let a=/^(\d+.?\d*)([nsew])/i;for(let s=0;s<e.length;++s){let l=e[s].match(a);a.test(e[s])&&l.length===3&&(/^[ns]/i.test(l[2])?i=/^[n]/i.test(l[2])?+l[1]:-l[1]:/^[ew]/i.test(l[2])&&(n=/^[e]/i.test(l[2])?+l[1]:-l[1]))}}if(!isNaN(n)&&!isNaN(i)&&!isNaN(o)){let a={displayName:t,destination:p.fromDegrees(n,i,o)};return Promise.resolve([a])}}return Promise.resolve([])};var Ist=Cst;var F5o=R(W(),1);var QJe=new Rt,e2t=new p,iN=new p;function kJe(t){let e=t.points,n=t.times;if(e.length<3){let i=n[0],o=1/(n[1]-i),a=e[0],s=e[1];return function(l,r){c(r)||(r=new p);let d=(l-i)*o;return p.lerp(a,s,d,r)}}return function(i,o){c(o)||(o=new p);let a=t._lastTimeIndex=t.findTimeInterval(i,t._lastTimeIndex),s=(i-n[a])/(n[a+1]-n[a]),l=QJe;l.z=s,l.y=s*s,l.x=l.y*s,l.w=1;let r,d,m,h,Z;return a===0?(r=e[0],d=e[1],m=t.firstTangent,h=p.subtract(e[2],r,e2t),p.multiplyByScalar(h,.5,h),Z=L.multiplyByVector($f.hermiteCoefficientMatrix,l,l)):a===e.length-2?(r=e[a],d=e[a+1],h=t.lastTangent,m=p.subtract(d,e[a-1],e2t),p.multiplyByScalar(m,.5,m),Z=L.multiplyByVector($f.hermiteCoefficientMatrix,l,l)):(r=e[a-1],d=e[a],m=e[a+1],h=e[a+2],Z=L.multiplyByVector(EU.catmullRomCoefficientMatrix,l,l)),o=p.multiplyByScalar(r,Z.x,o),p.multiplyByScalar(d,Z.y,iN),p.add(o,iN,o),p.multiplyByScalar(m,Z.z,iN),p.add(o,iN,o),p.multiplyByScalar(h,Z.w,iN),p.add(o,iN,o)}}var YJe=new p,xJe=new p;function EU(t){t=f(t,f.EMPTY_OBJECT);let e=t.points,n=t.times,i=t.firstTangent,o=t.lastTangent;if(e.length>2&&(c(i)||(i=YJe,p.multiplyByScalar(e[1],2,i),p.subtract(i,e[2],i),p.subtract(i,e[0],i),p.multiplyByScalar(i,.5,i)),!c(o))){let a=e.length-1;o=xJe,p.multiplyByScalar(e[a-1],2,o),p.subtract(e[a],o,o),p.add(o,e[a-2],o),p.multiplyByScalar(o,.5,o)}this._times=n,this._points=e,this._firstTangent=p.clone(i),this._lastTangent=p.clone(o),this._evaluateFunction=kJe(this),this._lastTimeIndex=0}Object.defineProperties(EU.prototype,{times:{get:function(){return this._times}},points:{get:function(){return this._points}},firstTangent:{get:function(){return this._firstTangent}},lastTangent:{get:function(){return this._lastTangent}}});EU.catmullRomCoefficientMatrix=new L(-.5,1,-.5,0,1.5,-2.5,0,1,-1.5,2,.5,0,.5,-.5,0,0);EU.prototype.findTimeInterval=ba.prototype.findTimeInterval;EU.prototype.wrapTime=ba.prototype.wrapTime;EU.prototype.clampTime=ba.prototype.clampTime;EU.prototype.evaluate=function(t,e){return this._evaluateFunction(t,e)};var Nst=EU;var mDo=R(W(),1);var M5o=R(W(),1);var S5o=R(W(),1);var Qj={};Qj.clipTriangleAtAxisAlignedThreshold=function(t,e,n,i,o,a){c(a)?a.length=0:a=[];let s,l,r;e?(s=n<t,l=i<t,r=o<t):(s=n>t,l=i>t,r=o>t);let d=s+l+r,m,h,Z,b,u,F;return d===1?s?(m=(t-n)/(i-n),h=(t-n)/(o-n),a.push(1),a.push(2),h!==1&&(a.push(-1),a.push(0),a.push(2),a.push(h)),m!==1&&(a.push(-1),a.push(0),a.push(1),a.push(m))):l?(Z=(t-i)/(o-i),b=(t-i)/(n-i),a.push(2),a.push(0),b!==1&&(a.push(-1),a.push(1),a.push(0),a.push(b)),Z!==1&&(a.push(-1),a.push(1),a.push(2),a.push(Z))):r&&(u=(t-o)/(n-o),F=(t-o)/(i-o),a.push(0),a.push(1),F!==1&&(a.push(-1),a.push(2),a.push(1),a.push(F)),u!==1&&(a.push(-1),a.push(2),a.push(0),a.push(u))):d===2?!s&&n!==t?(b=(t-i)/(n-i),u=(t-o)/(n-o),a.push(0),a.push(-1),a.push(1),a.push(0),a.push(b),a.push(-1),a.push(2),a.push(0),a.push(u)):!l&&i!==t?(F=(t-o)/(i-o),m=(t-n)/(i-n),a.push(1),a.push(-1),a.push(2),a.push(1),a.push(F),a.push(-1),a.push(0),a.push(1),a.push(m)):!r&&o!==t&&(h=(t-n)/(o-n),Z=(t-i)/(o-i),a.push(2),a.push(-1),a.push(0),a.push(2),a.push(h),a.push(-1),a.push(1),a.push(2),a.push(Z)):d!==3&&(a.push(0),a.push(1),a.push(2)),a};Qj.computeBarycentricCoordinates=function(t,e,n,i,o,a,s,l,r){let d=n-s,m=s-o,h=a-l,Z=i-l,b=1/(h*d+m*Z),u=e-l,F=t-s,U=(h*F+m*u)*b,G=(-Z*F+d*u)*b,A=1-U-G;return c(r)?(r.x=U,r.y=G,r.z=A,r):new p(U,G,A)};Qj.computeLineSegmentLineSegmentIntersection=function(t,e,n,i,o,a,s,l,r){let d=(s-o)*(e-a)-(l-a)*(t-o),m=(n-t)*(e-a)-(i-e)*(t-o),h=(l-a)*(n-t)-(s-o)*(i-e);if(h===0)return;let Z=d/h,b=m/h;if(Z>=0&&Z<=1&&b>=0&&b<=1)return c(r)||(r=new K),r.x=t+Z*(n-t),r.y=e+Z*(i-e),r};var SW=Qj;function CU(t){this._quantizedVertices=t.quantizedVertices,this._encodedNormals=t.encodedNormals,this._indices=t.indices,this._minimumHeight=t.minimumHeight,this._maximumHeight=t.maximumHeight,this._boundingSphere=t.boundingSphere,this._orientedBoundingBox=t.orientedBoundingBox,this._horizonOcclusionPoint=t.horizonOcclusionPoint,this._credits=t.credits;let e=this._quantizedVertices.length/3,n=this._uValues=this._quantizedVertices.subarray(0,e),i=this._vValues=this._quantizedVertices.subarray(e,2*e);this._heightValues=this._quantizedVertices.subarray(2*e,3*e);function o(s,l){return i[s]-i[l]}function a(s,l){return n[s]-n[l]}this._westIndices=Yj(t.westIndices,o,e),this._southIndices=Yj(t.southIndices,a,e),this._eastIndices=Yj(t.eastIndices,o,e),this._northIndices=Yj(t.northIndices,a,e),this._westSkirtHeight=t.westSkirtHeight,this._southSkirtHeight=t.southSkirtHeight,this._eastSkirtHeight=t.eastSkirtHeight,this._northSkirtHeight=t.northSkirtHeight,this._childTileMask=f(t.childTileMask,15),this._createdByUpsampling=f(t.createdByUpsampling,!1),this._waterMask=t.waterMask,this._mesh=void 0}Object.defineProperties(CU.prototype,{credits:{get:function(){return this._credits}},waterMask:{get:function(){return this._waterMask}},childTileMask:{get:function(){return this._childTileMask}},canUpsample:{get:function(){return c(this._mesh)}}});var kj=[];function Yj(t,e,n){kj.length=t.length;let i=!1;for(let o=0,a=t.length;o<a;++o)kj[o]=t[o],i=i||o>0&&e(t[o-1],t[o])>0;return i?(kj.sort(e),re.createTypedArray(n,kj)):t}var n2t="createVerticesFromQuantizedTerrainMesh",XJe=new $i(n2t),JJe=new $i(n2t,nV.maximumAsynchronousTasks);CU.prototype.createMesh=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.tilingScheme,n=t.x,i=t.y,o=t.level,a=f(t.exaggeration,1),s=f(t.exaggerationRelativeHeight,0),l=f(t.throttle,!0),r=e.ellipsoid,d=e.tileXYToRectangle(n,i,o),h=(l?JJe:XJe).scheduleTask({minimumHeight:this._minimumHeight,maximumHeight:this._maximumHeight,quantizedVertices:this._quantizedVertices,octEncodedNormals:this._encodedNormals,includeWebMercatorT:!0,indices:this._indices,westIndices:this._westIndices,southIndices:this._southIndices,eastIndices:this._eastIndices,northIndices:this._northIndices,westSkirtHeight:this._westSkirtHeight,southSkirtHeight:this._southSkirtHeight,eastSkirtHeight:this._eastSkirtHeight,northSkirtHeight:this._northSkirtHeight,rectangle:d,relativeToCenter:this._boundingSphere.center,ellipsoid:r,exaggeration:a,exaggerationRelativeHeight:s});if(!c(h))return;let Z=this;return Promise.resolve(h).then(function(b){let u=Z._quantizedVertices.length/3,F=u+Z._westIndices.length+Z._southIndices.length+Z._eastIndices.length+Z._northIndices.length,U=re.createTypedArray(F,b.indices),G=new Float32Array(b.vertices),A=b.center,T=b.minimumHeight,g=b.maximumHeight,C=Z._boundingSphere,y=Z._orientedBoundingBox,Y=f(p.clone(b.occludeePointInScaledSpace),Z._horizonOcclusionPoint),Q=b.vertexStride,J=lc.clone(b.encoding);return Z._mesh=new Au(A,G,U,b.indexCountWithoutSkirts,u,T,g,C,Y,Q,y,J,b.westIndicesSouthToNorth,b.southIndicesEastToWest,b.eastIndicesNorthToSouth,b.northIndicesWestToEast),Z._quantizedVertices=void 0,Z._encodedNormals=void 0,Z._indices=void 0,Z._uValues=void 0,Z._vValues=void 0,Z._heightValues=void 0,Z._westIndices=void 0,Z._southIndices=void 0,Z._eastIndices=void 0,Z._northIndices=void 0,Z._mesh})};var LJe=new $i("upsampleQuantizedTerrainMesh",nV.maximumAsynchronousTasks);CU.prototype.upsample=function(t,e,n,i,o,a,s){let l=this._mesh;if(!c(this._mesh))return;let r=e*2!==o,d=n*2===a,m=t.ellipsoid,h=t.tileXYToRectangle(o,a,s),Z=LJe.scheduleTask({vertices:l.vertices,vertexCountWithoutSkirts:l.vertexCountWithoutSkirts,indices:l.indices,indexCountWithoutSkirts:l.indexCountWithoutSkirts,encoding:l.encoding,minimumHeight:this._minimumHeight,maximumHeight:this._maximumHeight,isEastChild:r,isNorthChild:d,childRectangle:h,ellipsoid:m});if(!c(Z))return;let b=Math.min(this._westSkirtHeight,this._eastSkirtHeight);b=Math.min(b,this._southSkirtHeight),b=Math.min(b,this._northSkirtHeight);let u=r?b*.5:this._westSkirtHeight,F=d?b*.5:this._southSkirtHeight,U=r?this._eastSkirtHeight:b*.5,G=d?this._northSkirtHeight:b*.5,A=this._credits;return Promise.resolve(Z).then(function(T){let g=new Uint16Array(T.vertices),C=re.createTypedArray(g.length/3,T.indices),y;return c(T.encodedNormals)&&(y=new Uint8Array(T.encodedNormals)),new CU({quantizedVertices:g,indices:C,encodedNormals:y,minimumHeight:T.minimumHeight,maximumHeight:T.maximumHeight,boundingSphere:Ft.clone(T.boundingSphere),orientedBoundingBox:ci.clone(T.orientedBoundingBox),horizonOcclusionPoint:p.clone(T.horizonOcclusionPoint),westIndices:T.westIndices,southIndices:T.southIndices,eastIndices:T.eastIndices,northIndices:T.northIndices,westSkirtHeight:u,southSkirtHeight:F,eastSkirtHeight:U,northSkirtHeight:G,childTileMask:0,credits:A,createdByUpsampling:!0})})};var yst=32767,i2t=new p;CU.prototype.interpolateHeight=function(t,e,n){let i=k.clamp((e-t.west)/t.width,0,1);i*=yst;let o=k.clamp((n-t.south)/t.height,0,1);return o*=yst,c(this._mesh)?OJe(this,i,o):HJe(this,i,o)};function o2t(t,e,n,i,o,a,s,l){let r=Math.min(n,o,s),d=Math.max(n,o,s),m=Math.min(i,a,l),h=Math.max(i,a,l);return t>=r&&t<=d&&e>=m&&e<=h}var MJe=new K,_Je=new K,DJe=new K;function OJe(t,e,n){let i=t._mesh,o=i.vertices,a=i.encoding,s=i.indices;for(let l=0,r=s.length;l<r;l+=3){let d=s[l],m=s[l+1],h=s[l+2],Z=a.decodeTextureCoordinates(o,d,MJe),b=a.decodeTextureCoordinates(o,m,_Je),u=a.decodeTextureCoordinates(o,h,DJe);if(o2t(e,n,Z.x,Z.y,b.x,b.y,u.x,u.y)){let F=SW.computeBarycentricCoordinates(e,n,Z.x,Z.y,b.x,b.y,u.x,u.y,i2t);if(F.x>=-1e-15&&F.y>=-1e-15&&F.z>=-1e-15){let U=a.decodeHeight(o,d),G=a.decodeHeight(o,m),A=a.decodeHeight(o,h);return F.x*U+F.y*G+F.z*A}}}}function HJe(t,e,n){let i=t._uValues,o=t._vValues,a=t._heightValues,s=t._indices;for(let l=0,r=s.length;l<r;l+=3){let d=s[l],m=s[l+1],h=s[l+2],Z=i[d],b=i[m],u=i[h],F=o[d],U=o[m],G=o[h];if(o2t(e,n,Z,F,b,U,u,G)){let A=SW.computeBarycentricCoordinates(e,n,Z,F,b,U,u,G,i2t);if(A.x>=-1e-15&&A.y>=-1e-15&&A.z>=-1e-15){let T=A.x*a[d]+A.y*a[m]+A.z*a[h];return k.lerp(t._minimumHeight,t._maximumHeight,T/yst)}}}}CU.prototype.isChildAvailable=function(t,e,n,i){let o=2;return n!==t*2&&++o,i!==e*2&&(o-=2),(this._childTileMask&1<<o)!==0};CU.prototype.wasCreatedByUpsampling=function(){return this._createdByUpsampling};var OS=CU;function wJe(t){this.resource=t.resource,this.version=t.version,this.isHeightmap=t.isHeightmap,this.tileUrlTemplates=t.tileUrlTemplates,this.availability=t.availability,this.hasVertexNormals=t.hasVertexNormals,this.hasWaterMask=t.hasWaterMask,this.hasMetadata=t.hasMetadata,this.availabilityLevels=t.availabilityLevels,this.availabilityTilesLoaded=t.availabilityTilesLoaded,this.littleEndianExtensionSize=t.littleEndianExtensionSize,this.availabilityPromiseCache={}}function s2t(t){this.requestVertexNormals=f(t.requestVertexNormals,!1),this.requestWaterMask=f(t.requestWaterMask,!1),this.requestMetadata=f(t.requestMetadata,!0),this.ellipsoid=t.ellipsoid,this.heightmapWidth=65,this.heightmapStructure=void 0,this.hasWaterMask=!1,this.hasMetadata=!1,this.hasVertexNormals=!1,this.scheme=void 0,this.lastResource=void 0,this.layerJsonResource=void 0,this.previousError=void 0,this.availability=void 0,this.tilingScheme=void 0,this.levelZeroMaximumGeometricError=void 0,this.heightmapStructure=void 0,this.layers=[],this.attribution="",this.overallAvailability=[],this.overallMaxZoom=0,this.tileCredits=[]}s2t.prototype.build=function(t){t._heightmapWidth=this.heightmapWidth,t._scheme=this.scheme;let e=c(this.lastResource.credits)?this.lastResource.credits:[];t._tileCredits=e.concat(this.tileCredits),t._availability=this.availability,t._tilingScheme=this.tilingScheme,t._requestWaterMask=this.requestWaterMask,t._levelZeroMaximumGeometricError=this.levelZeroMaximumGeometricError,t._heightmapStructure=this.heightmapStructure,t._layers=this.layers,t._hasWaterMask=this.hasWaterMask,t._hasVertexNormals=this.hasVertexNormals,t._hasMetadata=this.hasMetadata};async function l2t(t,e,n){if(!e.format){let F="The tile format is not specified in the layer.json file.";throw t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,F),new St(F)}if(!e.tiles||e.tiles.length===0){let F="The layer.json file does not specify any tile URL templates.";throw t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,F),new St(F)}let i=!1,o=!1,a=!1,s=!0,l=!1;if(e.format==="heightmap-1.0")l=!0,c(t.heightmapStructure)||(t.heightmapStructure={heightScale:1/5,heightOffset:-1e3,elementsPerHeight:1,stride:1,elementMultiplier:256,isBigEndian:!1,lowestEncodedHeight:0,highestEncodedHeight:256*256-1}),o=!0,t.requestWaterMask=!0;else if(e.format.indexOf("quantized-mesh-1.")!==0){let F=`The tile format "${e.format}" is invalid or not supported.`;throw t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,F),new St(F)}let r=e.tiles,d=e.maxzoom;if(t.overallMaxZoom=Math.max(t.overallMaxZoom,d),!e.projection||e.projection==="EPSG:4326")t.tilingScheme=new Qo({numberOfLevelZeroTilesX:2,numberOfLevelZeroTilesY:1,ellipsoid:t.ellipsoid});else if(e.projection==="EPSG:3857")t.tilingScheme=new Gs({numberOfLevelZeroTilesX:1,numberOfLevelZeroTilesY:1,ellipsoid:t.ellipsoid});else{let F=`The projection "${e.projection}" is invalid or not supported.`;throw t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,F),new St(F)}if(t.levelZeroMaximumGeometricError=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(t.tilingScheme.ellipsoid,t.heightmapWidth,t.tilingScheme.getNumberOfXTilesAtLevel(0)),!e.scheme||e.scheme==="tms"||e.scheme==="slippyMap")t.scheme=e.scheme;else{let F=`The scheme "${e.scheme}" is invalid or not supported.`;throw t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,F),new St(F)}let m;c(e.extensions)&&e.extensions.indexOf("octvertexnormals")!==-1?i=!0:c(e.extensions)&&e.extensions.indexOf("vertexnormals")!==-1&&(i=!0,s=!1),c(e.extensions)&&e.extensions.indexOf("watermask")!==-1&&(o=!0),c(e.extensions)&&e.extensions.indexOf("metadata")!==-1&&(a=!0);let h=e.metadataAvailability,Z=e.available,b;if(c(Z)&&!c(h)){b=new pV(t.tilingScheme,Z.length);for(let F=0;F<Z.length;++F){let U=Z[F],G=t.tilingScheme.getNumberOfYTilesAtLevel(F);c(t.overallAvailability[F])||(t.overallAvailability[F]=[]);for(let A=0;A<U.length;++A){let T=U[A],g=G-T.endY-1,C=G-T.startY-1;t.overallAvailability[F].push([T.startX,g,T.endX,C]),b.addAvailableTileRange(F,T.startX,g,T.endX,C)}}}else c(h)&&(m=new pV(t.tilingScheme,d),b=new pV(t.tilingScheme,d),t.overallAvailability[0]=[[0,0,1,0]],b.addAvailableTileRange(0,0,0,1,0));t.hasWaterMask=t.hasWaterMask||o,t.hasVertexNormals=t.hasVertexNormals||i,t.hasMetadata=t.hasMetadata||a,c(e.attribution)&&(t.attribution.length>0&&(t.attribution+=" "),t.attribution+=e.attribution),t.layers.push(new wJe({resource:t.lastResource,version:e.version,isHeightmap:l,tileUrlTemplates:r,availability:b,hasVertexNormals:i,hasWaterMask:o,hasMetadata:a,availabilityLevels:h,availabilityTilesLoaded:m,littleEndianExtensionSize:s}));let u=e.parentUrl;return c(u)?c(b)?(t.lastResource=t.lastResource.getDerivedResource({url:u}),t.lastResource.appendForwardSlash(),t.layerJsonResource=t.lastResource.getDerivedResource({url:"layer.json"}),await kst(t),!0):(console.log("A layer.json can't have a parentUrl if it does't have an available array."),!0):!0}function PJe(t,e,n){let i=`An error occurred while accessing ${t.layerJsonResource.url}.`;if(c(e)&&(i+=` -${e.message}`),t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,i),t.previousError.retry)return kst(t,n);throw new St(i)}async function vJe(t,e,n){await l2t(t,e,n);let i=t.overallAvailability.length;if(i>0){let o=t.availability=new pV(t.tilingScheme,t.overallMaxZoom);for(let a=0;a<i;++a){let s=t.overallAvailability[a];for(let l=0;l<s.length;++l){let r=s[l];o.addAvailableTileRange(a,r[0],r[1],r[2],r[3])}}}if(t.attribution.length>0){let o=new on(t.attribution);t.tileCredits.push(o)}return!0}async function kst(t,e){try{let n=await t.layerJsonResource.fetchJson();return vJe(t,n,e)}catch(n){return c(n)&&n.statusCode===404?(await l2t(t,{tilejson:"2.1.0",format:"heightmap-1.0",version:"1.0.0",scheme:"tms",tiles:["{z}/{x}/{y}.terrain?v={version}"]},e),!0):PJe(t,n,e)}}function uV(t){t=f(t,f.EMPTY_OBJECT),this._heightmapWidth=void 0,this._heightmapStructure=void 0,this._hasWaterMask=!1,this._hasVertexNormals=!1,this._hasMetadata=!1,this._scheme=void 0,this._ellipsoid=t.ellipsoid,this._requestVertexNormals=f(t.requestVertexNormals,!1),this._requestWaterMask=f(t.requestWaterMask,!1),this._requestMetadata=f(t.requestMetadata,!0),this._errorEvent=new It;let e=t.credit;typeof e=="string"&&(e=new on(e)),this._credit=e,this._availability=void 0,this._tilingScheme=void 0,this._levelZeroMaximumGeometricError=void 0,this._layers=void 0,this._tileCredits=void 0}var Bst={OCT_VERTEX_NORMALS:1,WATER_MASK:2,METADATA:4};function a2t(t){return!c(t)||t.length===0?{Accept:"application/vnd.quantized-mesh,application/octet-stream;q=0.9,*/*;q=0.01"}:{Accept:`application/vnd.quantized-mesh;extensions=${t.join("-")},application/octet-stream;q=0.9,*/*;q=0.01`}}function KJe(t,e,n,i,o){let a=new Uint16Array(e,0,t._heightmapWidth*t._heightmapWidth);return new Gd({buffer:a,childTileMask:new Uint8Array(e,a.byteLength,1)[0],waterMask:new Uint8Array(e,a.byteLength+1,e.byteLength-a.byteLength-1),width:t._heightmapWidth,height:t._heightmapWidth,structure:t._heightmapStructure,credits:t._tileCredits})}function zJe(t,e,n,i,o,a){let s=a.littleEndianExtensionSize,l=0,r=3,d=r+1,m=Float64Array.BYTES_PER_ELEMENT*r,h=Float64Array.BYTES_PER_ELEMENT*d,b=Uint16Array.BYTES_PER_ELEMENT*3,u=3,F=Uint16Array.BYTES_PER_ELEMENT,U=F*u,G=new DataView(e),A=new p(G.getFloat64(l,!0),G.getFloat64(l+8,!0),G.getFloat64(l+16,!0));l+=m;let T=G.getFloat32(l,!0);l+=Float32Array.BYTES_PER_ELEMENT;let g=G.getFloat32(l,!0);l+=Float32Array.BYTES_PER_ELEMENT;let C=new Ft(new p(G.getFloat64(l,!0),G.getFloat64(l+8,!0),G.getFloat64(l+16,!0)),G.getFloat64(l+m,!0));l+=h;let y=new p(G.getFloat64(l,!0),G.getFloat64(l+8,!0),G.getFloat64(l+16,!0));l+=m;let Y=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let Q=new Uint16Array(e,l,Y*3);l+=Y*b,Y>64*1024&&(F=Uint32Array.BYTES_PER_ELEMENT,U=F*u);let J=Q.subarray(0,Y),M=Q.subarray(Y,2*Y),V=Q.subarray(Y*2,3*Y);Ni.zigZagDeltaDecode(J,M,V),l%F!==0&&(l+=F-l%F);let E=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let I=re.createTypedArrayFromArrayBuffer(Y,e,l,E*u);l+=E*U;let B=0,X=I.length;for(let Wt=0;Wt<X;++Wt){let Nt=I[Wt];I[Wt]=B-Nt,Nt===0&&++B}let _=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let P=re.createTypedArrayFromArrayBuffer(Y,e,l,_);l+=_*F;let w=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let z=re.createTypedArrayFromArrayBuffer(Y,e,l,w);l+=w*F;let H=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let nt=re.createTypedArrayFromArrayBuffer(Y,e,l,H);l+=H*F;let $=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let dt=re.createTypedArrayFromArrayBuffer(Y,e,l,$);l+=$*F;let q,at;for(;l<G.byteLength;){let Wt=G.getUint8(l,!0);l+=Uint8Array.BYTES_PER_ELEMENT;let Nt=G.getUint32(l,s);if(l+=Uint32Array.BYTES_PER_ELEMENT,Wt===Bst.OCT_VERTEX_NORMALS&&t._requestVertexNormals)q=new Uint8Array(e,l,Y*2);else if(Wt===Bst.WATER_MASK&&t._requestWaterMask)at=new Uint8Array(e,l,Nt);else if(Wt===Bst.METADATA&&t._requestMetadata){let kt=G.getUint32(l,!0);if(kt>0){let qt=ts(new Uint8Array(e),l+Uint32Array.BYTES_PER_ELEMENT,kt).available;if(c(qt))for(let ie=0;ie<qt.length;++ie){let oe=n+ie+1,He=qt[ie],rn=t._tilingScheme.getNumberOfYTilesAtLevel(oe);for(let de=0;de<He.length;++de){let zt=He[de],ke=rn-zt.endY-1,ue=rn-zt.startY-1;t.availability.addAvailableTileRange(oe,zt.startX,ke,zt.endX,ue),a.availability.addAvailableTileRange(oe,zt.startX,ke,zt.endX,ue)}}}a.availabilityTilesLoaded.addAvailableTileRange(n,i,o,i,o)}l+=Nt}let st=t.getLevelMaximumGeometricError(n)*5,Et=t._tilingScheme.tileXYToRectangle(i,o,n),Qt=ci.fromRectangle(Et,T,g,t._tilingScheme.ellipsoid);return new OS({center:A,minimumHeight:T,maximumHeight:g,boundingSphere:C,orientedBoundingBox:Qt,horizonOcclusionPoint:y,quantizedVertices:Q,encodedNormals:q,indices:I,westIndices:P,southIndices:z,eastIndices:nt,northIndices:dt,westSkirtHeight:st,southSkirtHeight:st,eastSkirtHeight:st,northSkirtHeight:st,childTileMask:t.availability.computeChildMaskForTile(n,i,o),waterMask:at,credits:t._tileCredits})}uV.prototype.requestTileGeometry=function(t,e,n,i){let o=this._layers,a,s=o.length,l=!1,r=Promise.resolve();if(s===1)a=o[0];else for(let d=0;d<s;++d){let m=o[d];if(!c(m.availability)||m.availability.isTileAvailable(n,t,e)){a=m;break}let h=Yst(this,t,e,n,m,d===0);h.result&&(l=!0,r=r.then(()=>h.promise))}return!c(a)&&l?r.then(()=>new Promise(d=>{setTimeout(()=>{let m=this.requestTileGeometry(t,e,n,i);d(m)},0)})):r2t(this,t,e,n,a,i)};function r2t(t,e,n,i,o,a){if(!c(o))return Promise.reject(new St("Terrain tile doesn't exist"));let s=o.tileUrlTemplates;if(s.length===0)return;let l;!t._scheme||t._scheme==="tms"?l=t._tilingScheme.getNumberOfYTilesAtLevel(i)-n-1:l=n;let r=[];t._requestVertexNormals&&o.hasVertexNormals&&r.push(o.littleEndianExtensionSize?"octvertexnormals":"vertexnormals"),t._requestWaterMask&&o.hasWaterMask&&r.push("watermask"),t._requestMetadata&&o.hasMetadata&&r.push("metadata");let d,m,h=s[(e+l+i)%s.length],Z=o.resource;c(Z._ionEndpoint)&&!c(Z._ionEndpoint.externalType)?(r.length!==0&&(m={extensions:r.join("-")}),d=a2t(void 0)):d=a2t(r);let b=Z.getDerivedResource({url:h,templateValues:{version:o.version,z:i,x:e,y:l},queryParameters:m,headers:d,request:a}).fetchArrayBuffer();if(c(b))return b.then(function(u){return c(u)?c(t._heightmapStructure)?KJe(t,u,i,e,n):zJe(t,u,i,e,n,o):Promise.reject(new St("Mesh buffer doesn't exist."))})}Object.defineProperties(uV.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},tilingScheme:{get:function(){return this._tilingScheme}},hasWaterMask:{get:function(){return this._hasWaterMask&&this._requestWaterMask}},hasVertexNormals:{get:function(){return this._hasVertexNormals&&this._requestVertexNormals}},hasMetadata:{get:function(){return this._hasMetadata&&this._requestMetadata}},requestVertexNormals:{get:function(){return this._requestVertexNormals}},requestWaterMask:{get:function(){return this._requestWaterMask}},requestMetadata:{get:function(){return this._requestMetadata}},availability:{get:function(){return this._availability}}});uV.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<<t)};uV.fromIonAssetId=async function(t,e){let n=await gh.fromAssetId(t);return uV.fromUrl(n,e)};uV.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT),t=await Promise.resolve(t);let n=te.createIfNeeded(t);n.appendForwardSlash();let i=new s2t(e);i.lastResource=n,i.layerJsonResource=i.lastResource.getDerivedResource({url:"layer.json"}),await kst(i);let o=new uV(e);return i.build(o),o};uV.prototype.getTileDataAvailable=function(t,e,n){if(!c(this._availability))return;if(n>this._availability._maximumLevel)return!1;if(this._availability.isTileAvailable(n,t,e))return!0;if(!this._hasMetadata)return!1;let i=this._layers,o=i.length;for(let a=0;a<o;++a)if(Yst(this,t,e,n,i[a],a===0).result)return;return!1};uV.prototype.loadTileDataAvailability=function(t,e,n){if(!c(this._availability)||n>this._availability._maximumLevel||this._availability.isTileAvailable(n,t,e)||!this._hasMetadata)return;let i=this._layers,o=i.length;for(let a=0;a<o;++a){let s=Yst(this,t,e,n,i[a],a===0);if(c(s.promise))return s.promise}};function Qst(t,e,n,i){if(i===0)return;let o=t.availabilityLevels,a=i%o===0?i-o:(i/o|0)*o,s=1<<i-a,l=e/s|0,r=n/s|0;return{level:a,x:l,y:r}}function Yst(t,e,n,i,o,a){if(!c(o.availabilityLevels))return{result:!1};let s,l=function(){delete o.availabilityPromiseCache[s]},r=o.availabilityTilesLoaded,d=o.availability,m=Qst(o,e,n,i);for(;c(m);){if(d.isTileAvailable(m.level,m.x,m.y)&&!r.isTileAvailable(m.level,m.x,m.y)){let h;if(!a&&(s=`${m.level}-${m.x}-${m.y}`,h=o.availabilityPromiseCache[s],!c(h))){let Z=new Zs({throttle:!1,throttleByServer:!0,type:Xl.TERRAIN});h=r2t(t,m.x,m.y,m.level,o,Z),c(h)&&(o.availabilityPromiseCache[s]=h,h.then(l))}return{result:!0,promise:h}}m=Qst(o,m.x,m.y,m.level)}return{result:!1}}uV._getAvailabilityTile=Qst;var HS=uV;var WDo=R(W(),1);function gW(t){t=f(t,f.EMPTY_OBJECT);let e=t.radius,n={center:t.center,semiMajorAxis:e,semiMinorAxis:e,ellipsoid:t.ellipsoid,height:t.height,extrudedHeight:t.extrudedHeight,granularity:t.granularity,vertexFormat:t.vertexFormat,stRotation:t.stRotation,shadowVolume:t.shadowVolume};this._ellipseGeometry=new Pc(n),this._workerName="createCircleGeometry"}gW.packedLength=Pc.packedLength;gW.pack=function(t,e,n){return Pc.pack(t._ellipseGeometry,e,n)};var jJe=new Pc({center:new p,semiMajorAxis:1,semiMinorAxis:1}),Zc={center:new p,radius:void 0,ellipsoid:mt.clone(mt.UNIT_SPHERE),height:void 0,extrudedHeight:void 0,granularity:void 0,vertexFormat:new ee,stRotation:void 0,semiMajorAxis:void 0,semiMinorAxis:void 0,shadowVolume:void 0};gW.unpack=function(t,e,n){let i=Pc.unpack(t,e,jJe);return Zc.center=p.clone(i._center,Zc.center),Zc.ellipsoid=mt.clone(i._ellipsoid,Zc.ellipsoid),Zc.height=i._height,Zc.extrudedHeight=i._extrudedHeight,Zc.granularity=i._granularity,Zc.vertexFormat=ee.clone(i._vertexFormat,Zc.vertexFormat),Zc.stRotation=i._stRotation,Zc.shadowVolume=i._shadowVolume,c(n)?(Zc.semiMajorAxis=i._semiMajorAxis,Zc.semiMinorAxis=i._semiMinorAxis,n._ellipseGeometry=new Pc(Zc),n):(Zc.radius=i._semiMajorAxis,new gW(Zc))};gW.createGeometry=function(t){return Pc.createGeometry(t._ellipseGeometry)};gW.createShadowVolume=function(t,e,n){let i=t._ellipseGeometry._granularity,o=t._ellipseGeometry._ellipsoid,a=e(i,o),s=n(i,o);return new gW({center:t._ellipseGeometry._center,radius:t._ellipseGeometry._semiMajorAxis,ellipsoid:o,stRotation:t._ellipseGeometry._stRotation,granularity:i,extrudedHeight:a,height:s,vertexFormat:ee.POSITION_ONLY,shadowVolume:!0})};Object.defineProperties(gW.prototype,{rectangle:{get:function(){return this._ellipseGeometry.rectangle}},textureCoordinateRotationPoints:{get:function(){return this._ellipseGeometry.textureCoordinateRotationPoints}}});var xst=gW;var SDo=R(W(),1);function oN(t){t=f(t,f.EMPTY_OBJECT);let e=t.radius,n={center:t.center,semiMajorAxis:e,semiMinorAxis:e,ellipsoid:t.ellipsoid,height:t.height,extrudedHeight:t.extrudedHeight,granularity:t.granularity,numberOfVerticalLines:t.numberOfVerticalLines};this._ellipseGeometry=new Lh(n),this._workerName="createCircleOutlineGeometry"}oN.packedLength=Lh.packedLength;oN.pack=function(t,e,n){return Lh.pack(t._ellipseGeometry,e,n)};var qJe=new Lh({center:new p,semiMajorAxis:1,semiMinorAxis:1}),cp={center:new p,radius:void 0,ellipsoid:mt.clone(mt.UNIT_SPHERE),height:void 0,extrudedHeight:void 0,granularity:void 0,numberOfVerticalLines:void 0,semiMajorAxis:void 0,semiMinorAxis:void 0};oN.unpack=function(t,e,n){let i=Lh.unpack(t,e,qJe);return cp.center=p.clone(i._center,cp.center),cp.ellipsoid=mt.clone(i._ellipsoid,cp.ellipsoid),cp.height=i._height,cp.extrudedHeight=i._extrudedHeight,cp.granularity=i._granularity,cp.numberOfVerticalLines=i._numberOfVerticalLines,c(n)?(cp.semiMajorAxis=i._semiMajorAxis,cp.semiMinorAxis=i._semiMinorAxis,n._ellipseGeometry=new Lh(cp),n):(cp.radius=i._semiMajorAxis,new oN(cp))};oN.createGeometry=function(t){return Lh.createGeometry(t._ellipseGeometry)};var Xst=oN;var EDo=R(W(),1),$Je=(t,e)=>{let n=i=>{!t.trackedEntity&&i.shouldAnimate===!0?e.entities._precisionMode=i.multiplier===1?75:0:e.entities._precisionMode=0};return t.clock.onTick.addEventListener(n),{remove:function(){t.clock.onTick.removeEventListener(n)}}},Jst=$Je;var vDo=R(W(),1);var LDo=R(W(),1);var xj=class{constructor(e){let n=e,{_times:i,_values:o,_value:a,_interpolationDegree:s,_derivativeTypes:l,_xTable:r,_yTable:d,_interpolationResult:m,_interpolationAlgorithm:h}=n,Z="ConstantPositionProperty";n instanceof cl?Z="CompositePositionProperty":n instanceof jl?Z="ConstantPositionProperty":n instanceof ql?Z="SampledProperty":n instanceof Bs?Z="SampledPositionProperty":n instanceof vc?Z="ScaledPositionProperty":n instanceof _m&&(Z="TimeIntervalCollectionProperty"),this._times=i,this._values=o,this._value=a,this._interpolationDegree=s,this._derivativeTypes=l,this._xTable=r,this._yTable=d,this._interpolationResult=m,this.interpolationAlgorithm=h?.type?.toUpperCase()||"LINEAR",this.propertyType=Z}},tLe=t=>t.position?new xj(t.position):null,eLe=t=>{let e=t,n;switch(e.propertyType){case"CompositePositionProperty":n=cl;break;case"ConstantPositionProperty":n=jl;break;case"SampledProperty":n=ql;break;case"SampledPositionProperty":n=Bs;break;case"ScaledPositionProperty":n=vc;break;case"TimeIntervalCollectionProperty":n=_m;break;default:throw new Error(`Unknown propertyType: ${e.propertyType}`)}let i=new n(p);for(let o in e)o!=="propertyType"&&o!=="interpolationAlgorithm"&&(i[o]=e[o]);return i.setInterpolationOptions&&i.setInterpolationOptions({interpolationAlgorithm:nLe(e.interpolationAlgorithm),interpolationDegree:e._interpolationDegree}),i};function nLe(t){switch(t){case"LAGRANGE":return dT;case"HERMITE":return rT;case"LINEAR":default:return _R}}var g5={SerializePosition:tLe,DeserializePosition:eLe,SerializedPosition:xj};var{OMMT:HDo,OMMCOLLECTIONT:iLe}=sW,{CATT:wDo,CATCOLLECTIONT:oLe}=aW,Lst=1,aLe=async({spaceCatalogDataSources:t,startTime:e,endTime:n,step:i=6e4,radius:o=5e3,screeningObjects:a=[]})=>{let s={OMM:new iLe,CAT:new oLe,entities:[]};Array.isArray(t)||(t=[t]);let l=[];for(let u of t)l=l.concat([...u.entities.values]);a.length===0&&(a=l);let r=a.map(u=>u.id);for(let u of l){let F=u.properties.OMM.getValue(),U=u.properties.CAT.getValue(),G=g5(u);G&&(s.entities.push({id:u.id,position:G}),s.OMM.RECORDS.push(F),s.CAT.RECORDS.push(U))}s.OMM=writeFB(s.OMM).buffer,s.CAT=writeFB(s.CAT).buffer;let d=new $i("ConjunctionAssessment",Lst),m=Math.ceil(r.length/Lst),h=[];for(let u=0;u<Lst;u++){let F={transferEntities:s,screeningObjectIds:r.slice(u*m,(u+1)*m),start:rt.toDate(e).getTime(),stop:rt.toDate(n).getTime(),step:i,radius:o};h.push(d.scheduleTask(F))}let Z=await Promise.all(h);return console.log(Z),Z.flat()},Mst=aLe;var oOo=R(W(),1);function aN(t){t=f(t,f.EMPTY_OBJECT),this._callback=t.callback,this._tilingScheme=t.tilingScheme,c(this._tilingScheme)||(this._tilingScheme=new Qo({ellipsoid:f(t.ellipsoid,mt.WGS84)})),this._width=t.width,this._height=t.height;let e=Math.max(this._width,this._height);this._levelZeroMaximumGeometricError=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(this._tilingScheme.ellipsoid,e,this._tilingScheme.getNumberOfXTilesAtLevel(0)),this._errorEvent=new It;let n=t.credit;typeof n=="string"&&(n=new on(n)),this._credit=n}Object.defineProperties(aN.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},tilingScheme:{get:function(){return this._tilingScheme}},hasWaterMask:{get:function(){return!1}},hasVertexNormals:{get:function(){return!1}},width:{get:function(){return this._width}},height:{get:function(){return this._height}}});aN.prototype.requestTileGeometry=function(t,e,n,i){let o=this._callback(t,e,n);if(!c(o))return;let a=this._width,s=this._height;return Promise.resolve(o).then(function(l){let r=l;return Array.isArray(r)&&(r=new Float64Array(r)),new Gd({buffer:r,width:a,height:s})})};aN.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<<t)};aN.prototype.getTileDataAvailable=function(t,e,n){};aN.prototype.loadTileDataAvailability=function(t,e,n){};var _st=aN;var sOo=R(W(),1);function d2t(t){this.proxy=t}d2t.prototype.getURL=function(t){let e=this.proxy.indexOf("?")===-1?"?":"";return this.proxy+e+encodeURIComponent(t)};var Dst=d2t;var VOo=R(W(),1);var c2t=t=>{let e;if(t.position)e=t.position?._property||t.position;else for(let u in t)if(t[u]?.position)e=t[u].position._property;else if(t[u]?.positions){e=t[u].positions;let F={x:0,y:0,z:0};for(let U=0;U<e._value.length;U++)F.x+=e._value[U].x,F.y+=e._value[U].y,F.z+=e._value[U].z;for(let U in F)F[U]&&(F[U]=F[U]/e._value.length);e._value=new p(F.x,F.y,F.z)}if(!e)return;let{id:n}=t,{_times:i,_values:o,_value:a,_interpolationDegree:s,_derivativeTypes:l,_xTable:r,_yTable:d,_interpolationResult:m,_interpolationAlgorithm:h}=e,Z="ConstantPositionProperty";e instanceof cl?Z="CompositePositionProperty":e instanceof jl?Z="ConstantPositionProperty":e instanceof ql?Z="SampledProperty":e instanceof Bs?Z="SampledPositionProperty":e instanceof vc?Z="ScaledPositionProperty":e instanceof _m&&(Z="TimeIntervalCollectionProperty"),t.properties=t.properties||{};let{jsonOMM:b}=t.properties;return{id:n,_times:i,_values:o,_value:a,_interpolationDegree:s,_derivativeTypes:l,_xTable:r,_yTable:d,_interpolationResult:m,interpolationAlgorithm:h?.type?.toUpperCase()||"LINEAR",propertyType:Z,jsonOMM:b}},sLe=async({fromEntity:t,toEntityArray:e,startTime:n,endTime:i,step:o=60,sensor:a=null,sensorOrientation:s,dateString:l=!1})=>{let r=[];if(Array.isArray(e)||(e=[e]),e.length){for(let G of e){let A=c2t(G);A&&r.push(A)}let d=3,m=Math.ceil(r.length/d),h=[],Z=new $i("AnalysisWorker",d),b=[];for(let G=0;G<r.length;G++)if(b.length<m&&b.push(r[G]),b.length>=m||G===r.length-1){let A={fromEntity:c2t(t),toEntityArray:b,startTime:n.toString(),endTime:i.toString(),dateString:l,step:o,sensor:a?{sensorName:a?.constructor?.name,...a}:null,sensorOrientation:s},T=Z.scheduleTask(A);h.push(T.then(g=>g)),b=[]}let u=await Promise.allSettled(h),F=u.filter(G=>G.reason);if(F.length)throw Error(JSON.stringify(F,null,4));let U={};for(let G=0;G<u.length;G++)for(let A in u[G].value)u[G].value[A]&&(U[A]=u[G].value[A]);return U}return Promise.reject("No Target Entities Found.")},Ost=sLe;var ROo=R(W(),1),lLe={SEARCH:0,AUTOCOMPLETE:1},IU=Object.freeze(lLe);var GOo=R(W(),1);function Xj(){Ut.throwInstantiationError()}Object.defineProperties(Xj.prototype,{credit:{get:Ut.throwInstantiationError}});Xj.getCreditsFromResult=function(t){if(c(t.attributions))return t.attributions.map(on.getIonCredit)};Xj.prototype.geocode=Ut.throwInstantiationError;var sN=Xj;var SOo=R(W(),1);function m2t(){Ut.throwInstantiationError()}m2t.createGeometry=function(t){Ut.throwInstantiationError()};var Hst=m2t;var POo=R(W(),1),pLe=R(wst(),1);var BOo=R(W(),1);var COo=R(W(),1);function rLe(t,e){return(t&e)!==0}var Vc=rLe;var dLe=[1,2,4,8],h2t=15,cLe=16,mLe=64,hLe=128;function zb(t,e,n,i,o,a){this._bits=t,this.cnodeVersion=e,this.imageryVersion=n,this.terrainVersion=i,this.imageryProvider=o,this.terrainProvider=a,this.ancestorHasTerrain=!1,this.terrainState=void 0}zb.clone=function(t,e){return c(e)?(e._bits=t._bits,e.cnodeVersion=t.cnodeVersion,e.imageryVersion=t.imageryVersion,e.terrainVersion=t.terrainVersion,e.imageryProvider=t.imageryProvider,e.terrainProvider=t.terrainProvider):e=new zb(t._bits,t.cnodeVersion,t.imageryVersion,t.terrainVersion,t.imageryProvider,t.terrainProvider),e.ancestorHasTerrain=t.ancestorHasTerrain,e.terrainState=t.terrainState,e};zb.prototype.setParent=function(t){this.ancestorHasTerrain=t.ancestorHasTerrain||this.hasTerrain()};zb.prototype.hasSubtree=function(){return Vc(this._bits,cLe)};zb.prototype.hasImagery=function(){return Vc(this._bits,mLe)};zb.prototype.hasTerrain=function(){return Vc(this._bits,hLe)};zb.prototype.hasChildren=function(){return Vc(this._bits,h2t)};zb.prototype.hasChild=function(t){return Vc(this._bits,dLe[t])};zb.prototype.getChildBitmask=function(){return this._bits&h2t};var E5=zb;function uLe(t){let e=t.length,n=new ArrayBuffer(e),i=new Uint8Array(n);for(let o=0;o<e;++o)i[o]=t.charCodeAt(o);return n}var ZLe=uLe(`E\xF4\xBD\vy\xE2jE"\x92,\xCDq\xF8IFgQ\0B%\xC6\xE8a,f)\b\xC64\xDCjb%y +`;var n5o=b(W(),1);var k9o=b(W(),1);function nN(t,e){this._tilingScheme=t,this._maximumLevel=e,this._rootNodes=[]}var DT=new Gt;function fJe(t,e,n,i){let o=i.length;for(let a=0;a<o;++a){let s=i[a];if(s.x===e&&s.y===n&&s.level===t)return!0}return!1}nN.prototype.addAvailableTileRange=function(t,e,n,i,o){let a=this._tilingScheme,s=this._rootNodes;if(t===0)for(let u=n;u<=o;++u)for(let R=e;R<=i;++R)fJe(t,R,u,s)||s.push(new tN(a,void 0,0,R,u));a.tileXYToRectangle(e,n,t,DT);let l=DT.west,r=DT.north;a.tileXYToRectangle(i,o,t,DT);let d=DT.east,m=DT.south,h=new SJe(t,l,m,d,r);for(let u=0;u<s.length;++u){let R=s[u];Ast(R.extent,h)&&TJe(this._maximumLevel,R,h)}};nN.prototype.computeMaximumLevelAtPosition=function(t){let e;for(let n=0;n<this._rootNodes.length;++n){let i=this._rootNodes[n];if(eN(i.extent,t)){e=i;break}}return c(e)?S5(void 0,e,t):-1};var FJe=[],UJe=[],GJe=new Gt,AJe=new Gt;nN.prototype.computeBestAvailableLevelOverRectangle=function(t){let e=FJe;e.length=0,t.east<t.west?(e.push(Gt.fromRadians(-Math.PI,t.south,t.east,t.north,GJe)),e.push(Gt.fromRadians(t.west,t.south,Math.PI,t.north,AJe))):e.push(t);let n=UJe;n.length=0;let i;for(i=0;i<this._rootNodes.length;++i)T5(n,this._rootNodes[i],e);for(i=n.length-1;i>=0;--i)if(c(n[i])&&n[i].length===0)return i;return 0};var jQt=new gt;nN.prototype.isTileAvailable=function(t,e,n){let i=this._tilingScheme.tileXYToRectangle(e,n,t,DT);return Gt.center(i,jQt),this.computeMaximumLevelAtPosition(jQt)>=t};nN.prototype.computeChildMaskForTile=function(t,e,n){let i=t+1;if(i>=this._maximumLevel)return 0;let o=0;return o|=this.isTileAvailable(i,2*e,2*n+1)?1:0,o|=this.isTileAvailable(i,2*e+1,2*n+1)?2:0,o|=this.isTileAvailable(i,2*e,2*n)?4:0,o|=this.isTileAvailable(i,2*e+1,2*n)?8:0,o};function tN(t,e,n,i,o){this.tilingScheme=t,this.parent=e,this.level=n,this.x=i,this.y=o,this.extent=t.tileXYToRectangle(i,o,n),this.rectangles=[],this._sw=void 0,this._se=void 0,this._nw=void 0,this._ne=void 0}Object.defineProperties(tN.prototype,{nw:{get:function(){return this._nw||(this._nw=new tN(this.tilingScheme,this,this.level+1,this.x*2,this.y*2)),this._nw}},ne:{get:function(){return this._ne||(this._ne=new tN(this.tilingScheme,this,this.level+1,this.x*2+1,this.y*2)),this._ne}},sw:{get:function(){return this._sw||(this._sw=new tN(this.tilingScheme,this,this.level+1,this.x*2,this.y*2+1)),this._sw}},se:{get:function(){return this._se||(this._se=new tN(this.tilingScheme,this,this.level+1,this.x*2+1,this.y*2+1)),this._se}}});function SJe(t,e,n,i,o){this.level=t,this.west=e,this.south=n,this.east=i,this.north=o}function Ast(t,e){let n=Math.max(t.west,e.west),i=Math.max(t.south,e.south),o=Math.min(t.east,e.east),a=Math.min(t.north,e.north);return i<a&&n<o}function TJe(t,e,n){for(;e.level<t;)if(Bj(e.nw.extent,n))e=e.nw;else if(Bj(e.ne.extent,n))e=e.ne;else if(Bj(e.sw.extent,n))e=e.sw;else if(Bj(e.se.extent,n))e=e.se;else break;if(e.rectangles.length===0||e.rectangles[e.rectangles.length-1].level<=n.level)e.rectangles.push(n);else{let i=Ja(e.rectangles,n.level,gJe);i<0&&(i=~i),e.rectangles.splice(i,0,n)}}function gJe(t,e){return t.level-e}function Bj(t,e){return e.west>=t.west&&e.east<=t.east&&e.south>=t.south&&e.north<=t.north}function eN(t,e){return e.longitude>=t.west&&e.longitude<=t.east&&e.latitude>=t.south&&e.latitude<=t.north}function S5(t,e,n){let i=0,o=!1;for(;!o;){let a=e._nw&&eN(e._nw.extent,n),s=e._ne&&eN(e._ne.extent,n),l=e._sw&&eN(e._sw.extent,n),r=e._se&&eN(e._se.extent,n);if(a+s+l+r>1){a&&(i=Math.max(i,S5(e,e._nw,n))),s&&(i=Math.max(i,S5(e,e._ne,n))),l&&(i=Math.max(i,S5(e,e._sw,n))),r&&(i=Math.max(i,S5(e,e._se,n)));break}else a?e=e._nw:s?e=e._ne:l?e=e._sw:r?e=e._se:o=!0}for(;e!==t;){let a=e.rectangles;for(let s=a.length-1;s>=0&&a[s].level>i;--s){let l=a[s];eN(l,n)&&(i=l.level)}e=e.parent}return i}function T5(t,e,n){if(!e)return;let i,o=!1;for(i=0;i<n.length;++i)o=o||Ast(e.extent,n[i]);if(!o)return;let a=e.rectangles;for(i=0;i<a.length;++i){let s=a[i];t[s.level]||(t[s.level]=n),t[s.level]=EJe(t[s.level],s)}T5(t,e._nw,n),T5(t,e._ne,n),T5(t,e._sw,n),T5(t,e._se,n)}function EJe(t,e){let n=[];for(let i=0;i<t.length;++i){let o=t[i];Ast(o,e)?(o.west<e.west&&n.push(new Gt(o.west,o.south,e.west,o.north)),o.east>e.east&&n.push(new Gt(e.east,o.south,o.east,o.north)),o.south<e.south&&n.push(new Gt(Math.max(e.west,o.west),o.south,Math.min(e.east,o.east),e.south)),o.north>e.north&&n.push(new Gt(Math.max(e.west,o.west),e.north,Math.min(e.east,o.east),o.north))):n.push(o)}return n}var pZ=nN;var CJe=15;function qQt(t){this.ellipsoid=f(t.ellipsoid,mt.WGS84),this.credit=void 0,this.tilingScheme=void 0,this.height=void 0,this.width=void 0,this.encoding=void 0,this.lodCount=void 0,this.hasAvailability=!1,this.tilesAvailable=void 0,this.tilesAvailabilityLoaded=void 0,this.levelZeroMaximumGeometricError=void 0,this.terrainDataStructure=void 0}qQt.prototype.build=function(t){t._credit=this.credit,t._tilingScheme=this.tilingScheme,t._height=this.height,t._width=this.width,t._encoding=this.encoding,t._lodCount=this.lodCount,t._hasAvailability=this.hasAvailability,t._tilesAvailable=this.tilesAvailable,t._tilesAvailabilityLoaded=this.tilesAvailabilityLoaded,t._levelZeroMaximumGeometricError=this.levelZeroMaximumGeometricError,t._terrainDataStructure=this.terrainDataStructure};function IJe(t,e){let n=e.copyrightText;c(n)&&(t.credit=new on(n));let i=e.spatialReference,o=f(i.latestWkid,i.wkid),a=e.extent,s={ellipsoid:t.ellipsoid};if(o===4326)s.rectangle=Gt.fromDegrees(a.xmin,a.ymin,a.xmax,a.ymax),t.tilingScheme=new Qo(s);else if(o===3857){let d=Math.PI*t.ellipsoid.maximumRadius;e.extent.xmax>d&&(e.extent.xmax=d),e.extent.ymax>d&&(e.extent.ymax=d),e.extent.xmin<-d&&(e.extent.xmin=-d),e.extent.ymin<-d&&(e.extent.ymin=-d),s.rectangleSouthwestInMeters=new K(a.xmin,a.ymin),s.rectangleNortheastInMeters=new K(a.xmax,a.ymax),t.tilingScheme=new Gs(s)}else throw new Tt("Invalid spatial reference");let l=e.tileInfo;if(!c(l))throw new Tt("tileInfo is required");t.width=l.rows+1,t.height=l.cols+1,t.encoding=l.format==="LERC"?UV.LERC:UV.NONE,t.lodCount=l.lods.length-1,(t.hasAvailability=e.capabilities.indexOf("Tilemap")!==-1)&&(t.tilesAvailable=new pZ(t.tilingScheme,t.lodCount),t.tilesAvailable.addAvailableTileRange(0,0,0,t.tilingScheme.getNumberOfXTilesAtLevel(0),t.tilingScheme.getNumberOfYTilesAtLevel(0)),t.tilesAvailabilityLoaded=new pZ(t.tilingScheme,t.lodCount)),t.levelZeroMaximumGeometricError=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(t.tilingScheme.ellipsoid,t.width,t.tilingScheme.getNumberOfXTilesAtLevel(0)),e.bandCount>1&&console.log("ArcGISTiledElevationTerrainProvider: Terrain data has more than 1 band. Using the first one."),c(e.minValues)&&c(e.maxValues)?t.terrainDataStructure={elementMultiplier:1,lowestEncodedHeight:e.minValues[0],highestEncodedHeight:e.maxValues[0]}:t.terrainDataStructure={elementMultiplier:1}}async function NJe(t,e,n){try{let i=await e.fetchJson();IJe(t,i)}catch(i){let o=`An error occurred while accessing ${e}.`;throw za.reportError(void 0,n,c(n)?n._errorEvent:void 0,o),i}}function gU(t){t=f(t,f.EMPTY_OBJECT),this._resource=void 0,this._credit=void 0,this._tilingScheme=void 0,this._levelZeroMaximumGeometricError=void 0,this._maxLevel=void 0,this._terrainDataStructure=void 0,this._width=void 0,this._height=void 0,this._encoding=void 0,this._lodCount=void 0,this._hasAvailability=!1,this._tilesAvailable=void 0,this._tilesAvailabilityLoaded=void 0,this._availableCache={},this._errorEvent=new It}Object.defineProperties(gU.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},tilingScheme:{get:function(){return this._tilingScheme}},hasWaterMask:{get:function(){return!1}},hasVertexNormals:{get:function(){return!1}},availability:{get:function(){return this._tilesAvailable}}});gU.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT),t=await Promise.resolve(t);let n=te.createIfNeeded(t);n.appendForwardSlash(),c(e.token)&&(n=n.getDerivedResource({queryParameters:{token:e.token}}));let i=n.getDerivedResource({queryParameters:{f:"pjson"}}),o=new qQt(e);await NJe(o,i);let a=new gU(e);return o.build(a),a._resource=n,a};gU.prototype.requestTileGeometry=function(t,e,n,i){let o=this._resource.getDerivedResource({url:`tile/${n}/${e}/${t}`,request:i}),a=this._hasAvailability,s=Promise.resolve(!0),l;if(a&&!c(Sst(this,n+1,t*2,e*2))){let h=$Qt(this,n+1,t*2,e*2);s=h.promise,l=h.request}let r=o.fetchArrayBuffer();if(!c(r)||!c(s))return;let d=this,m=this._tilesAvailable;return Promise.all([r,s]).then(function(h){return new Gd({buffer:h[0],width:d._width,height:d._height,childTileMask:a?m.computeChildMaskForTile(n,t,e):CJe,structure:d._terrainDataStructure,encoding:d._encoding})}).catch(function(h){return c(l)&&l.state===qi.CANCELLED?(i.cancel(),i.deferred.promise.finally(function(){return i.state=qi.CANCELLED,Promise.reject(h)})):Promise.reject(h)})};function Sst(t,e,n,i){if(!t._hasAvailability)return;let o=t._tilesAvailabilityLoaded,a=t._tilesAvailable;if(e>t._lodCount)return!1;if(a.isTileAvailable(e,n,i))return!0;if(o.isTileAvailable(e,n,i))return!1}gU.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<<t)};gU.prototype.getTileDataAvailable=function(t,e,n){if(!this._hasAvailability)return;let i=Sst(this,n,t,e);if(c(i))return i;$Qt(this,n,t,e)};gU.prototype.loadTileDataAvailability=function(t,e,n){};function yJe(t,e,n,i){let o=e-1,a=n-1,s=i[t.y*e+t.x],l=[],r={startX:t.x,startY:t.y,endX:0,endY:0},d=new K(t.x+1,t.y+1),m=!1,h=!1;for(;!(m&&h);){let u=d.x,R=h?d.y+1:d.y;if(!m){for(let V=t.y;V<R;++V)if(i[V*e+d.x]!==s){m=!0;break}m?(l.push(new K(d.x,t.y)),--d.x,--u,r.endX=d.x):d.x===o?(r.endX=d.x,m=!0):++d.x}if(!h){let V=d.y*e;for(let F=t.x;F<=u;++F)if(i[V+F]!==s){h=!0;break}h?(l.push(new K(t.x,d.y)),--d.y,r.endY=d.y):d.y===a?(r.endY=d.y,h=!0):++d.y}}return{endingIndices:l,range:r,value:s}}function BJe(t,e,n,i,o){let a=[];if(o.every(function(r){return r===o[0]}))return o[0]===1&&a.push({startX:t,startY:e,endX:t+n-1,endY:e+i-1}),a;let l=[new K(0,0)];for(;l.length>0;){let r=l.pop(),d=yJe(r,n,i,o);if(d.value===1){let h=d.range;h.startX+=t,h.endX+=t,h.startY+=e,h.endY+=e,a.push(h)}let m=d.endingIndices;m.length>0&&(l=l.concat(m))}return a}function $Qt(t,e,n,i){if(!t._hasAvailability)return{};let o=Math.floor(n/128)*128,a=Math.floor(i/128)*128,s=Math.min(1<<e,128),l=`tilemap/${e}/${a}/${o}/${s}/${s}`,r=t._availableCache;if(c(r[l]))return r[l];let d=new us({throttle:!1,throttleByServer:!0,type:Xl.TERRAIN}),h=t._resource.getDerivedResource({url:l,request:d}).fetchJson();return c(h)?(h=h.then(function(u){let R=BJe(o,a,s,s,u.data);t._tilesAvailabilityLoaded.addAvailableTileRange(e,o,a,o+s,a+s);let V=t._tilesAvailable;for(let F=0;F<R.length;++F){let U=R[F];V.addAvailableTileRange(e,U.startX,U.startY,U.endX,U.endY)}return Sst(t,e,n,i)}),r[l]={promise:h,request:d},h=h.finally(function(u){return delete r[l],u}),{promise:h,request:d}):{}}var Tst=gU;var d5o=b(W(),1);var tkt="https://dev.virtualearth.net/REST/v1/Locations";function gst(t){t=f(t,f.EMPTY_OBJECT);let e=t.key;this._key=e;let n={key:e};c(t.culture)&&(n.culture=t.culture),this._resource=new te({url:tkt,queryParameters:n}),this._credit=new on('<img src="http://dev.virtualearth.net/Branding/logo_powered_by.png"/>',!1)}Object.defineProperties(gst.prototype,{url:{get:function(){return tkt}},key:{get:function(){return this._key}},credit:{get:function(){return this._credit}}});gst.prototype.geocode=async function(t){return this._resource.getDerivedResource({queryParameters:{query:t}}).fetchJsonp("jsonp").then(function(n){return n.resourceSets.length===0?[]:n.resourceSets[0].resources.map(function(o){let a=o.bbox,s=a[0],l=a[1],r=a[2],d=a[3];return{displayName:o.name,destination:Gt.fromDegrees(l,s,d,r)}})})};var Est=gst;var h5o=b(W(),1);function Cst(){}Object.defineProperties(Cst.prototype,{credit:{get:function(){}}});Cst.prototype.geocode=function(t){let e=t.match(/[^\s,\n]+/g);if(e.length===2||e.length===3){let n=+e[0],i=+e[1],o=e.length===3?+e[2]:300;if(isNaN(n)&&isNaN(i)){let a=/^(\d+.?\d*)([nsew])/i;for(let s=0;s<e.length;++s){let l=e[s].match(a);a.test(e[s])&&l.length===3&&(/^[ns]/i.test(l[2])?i=/^[n]/i.test(l[2])?+l[1]:-l[1]:/^[ew]/i.test(l[2])&&(n=/^[e]/i.test(l[2])?+l[1]:-l[1]))}}if(!isNaN(n)&&!isNaN(i)&&!isNaN(o)){let a={displayName:t,destination:p.fromDegrees(n,i,o)};return Promise.resolve([a])}}return Promise.resolve([])};var Ist=Cst;var F5o=b(W(),1);var QJe=new bt,ekt=new p,iN=new p;function kJe(t){let e=t.points,n=t.times;if(e.length<3){let i=n[0],o=1/(n[1]-i),a=e[0],s=e[1];return function(l,r){c(r)||(r=new p);let d=(l-i)*o;return p.lerp(a,s,d,r)}}return function(i,o){c(o)||(o=new p);let a=t._lastTimeIndex=t.findTimeInterval(i,t._lastTimeIndex),s=(i-n[a])/(n[a+1]-n[a]),l=QJe;l.z=s,l.y=s*s,l.x=l.y*s,l.w=1;let r,d,m,h,u;return a===0?(r=e[0],d=e[1],m=t.firstTangent,h=p.subtract(e[2],r,ekt),p.multiplyByScalar(h,.5,h),u=L.multiplyByVector($f.hermiteCoefficientMatrix,l,l)):a===e.length-2?(r=e[a],d=e[a+1],h=t.lastTangent,m=p.subtract(d,e[a-1],ekt),p.multiplyByScalar(m,.5,m),u=L.multiplyByVector($f.hermiteCoefficientMatrix,l,l)):(r=e[a-1],d=e[a],m=e[a+1],h=e[a+2],u=L.multiplyByVector(EU.catmullRomCoefficientMatrix,l,l)),o=p.multiplyByScalar(r,u.x,o),p.multiplyByScalar(d,u.y,iN),p.add(o,iN,o),p.multiplyByScalar(m,u.z,iN),p.add(o,iN,o),p.multiplyByScalar(h,u.w,iN),p.add(o,iN,o)}}var YJe=new p,xJe=new p;function EU(t){t=f(t,f.EMPTY_OBJECT);let e=t.points,n=t.times,i=t.firstTangent,o=t.lastTangent;if(e.length>2&&(c(i)||(i=YJe,p.multiplyByScalar(e[1],2,i),p.subtract(i,e[2],i),p.subtract(i,e[0],i),p.multiplyByScalar(i,.5,i)),!c(o))){let a=e.length-1;o=xJe,p.multiplyByScalar(e[a-1],2,o),p.subtract(e[a],o,o),p.add(o,e[a-2],o),p.multiplyByScalar(o,.5,o)}this._times=n,this._points=e,this._firstTangent=p.clone(i),this._lastTangent=p.clone(o),this._evaluateFunction=kJe(this),this._lastTimeIndex=0}Object.defineProperties(EU.prototype,{times:{get:function(){return this._times}},points:{get:function(){return this._points}},firstTangent:{get:function(){return this._firstTangent}},lastTangent:{get:function(){return this._lastTangent}}});EU.catmullRomCoefficientMatrix=new L(-.5,1,-.5,0,1.5,-2.5,0,1,-1.5,2,.5,0,.5,-.5,0,0);EU.prototype.findTimeInterval=Ra.prototype.findTimeInterval;EU.prototype.wrapTime=Ra.prototype.wrapTime;EU.prototype.clampTime=Ra.prototype.clampTime;EU.prototype.evaluate=function(t,e){return this._evaluateFunction(t,e)};var Nst=EU;var mDo=b(W(),1);var M5o=b(W(),1);var T5o=b(W(),1);var Qj={};Qj.clipTriangleAtAxisAlignedThreshold=function(t,e,n,i,o,a){c(a)?a.length=0:a=[];let s,l,r;e?(s=n<t,l=i<t,r=o<t):(s=n>t,l=i>t,r=o>t);let d=s+l+r,m,h,u,R,V,F;return d===1?s?(m=(t-n)/(i-n),h=(t-n)/(o-n),a.push(1),a.push(2),h!==1&&(a.push(-1),a.push(0),a.push(2),a.push(h)),m!==1&&(a.push(-1),a.push(0),a.push(1),a.push(m))):l?(u=(t-i)/(o-i),R=(t-i)/(n-i),a.push(2),a.push(0),R!==1&&(a.push(-1),a.push(1),a.push(0),a.push(R)),u!==1&&(a.push(-1),a.push(1),a.push(2),a.push(u))):r&&(V=(t-o)/(n-o),F=(t-o)/(i-o),a.push(0),a.push(1),F!==1&&(a.push(-1),a.push(2),a.push(1),a.push(F)),V!==1&&(a.push(-1),a.push(2),a.push(0),a.push(V))):d===2?!s&&n!==t?(R=(t-i)/(n-i),V=(t-o)/(n-o),a.push(0),a.push(-1),a.push(1),a.push(0),a.push(R),a.push(-1),a.push(2),a.push(0),a.push(V)):!l&&i!==t?(F=(t-o)/(i-o),m=(t-n)/(i-n),a.push(1),a.push(-1),a.push(2),a.push(1),a.push(F),a.push(-1),a.push(0),a.push(1),a.push(m)):!r&&o!==t&&(h=(t-n)/(o-n),u=(t-i)/(o-i),a.push(2),a.push(-1),a.push(0),a.push(2),a.push(h),a.push(-1),a.push(1),a.push(2),a.push(u)):d!==3&&(a.push(0),a.push(1),a.push(2)),a};Qj.computeBarycentricCoordinates=function(t,e,n,i,o,a,s,l,r){let d=n-s,m=s-o,h=a-l,u=i-l,R=1/(h*d+m*u),V=e-l,F=t-s,U=(h*F+m*V)*R,G=(-u*F+d*V)*R,A=1-U-G;return c(r)?(r.x=U,r.y=G,r.z=A,r):new p(U,G,A)};Qj.computeLineSegmentLineSegmentIntersection=function(t,e,n,i,o,a,s,l,r){let d=(s-o)*(e-a)-(l-a)*(t-o),m=(n-t)*(e-a)-(i-e)*(t-o),h=(l-a)*(n-t)-(s-o)*(i-e);if(h===0)return;let u=d/h,R=m/h;if(u>=0&&u<=1&&R>=0&&R<=1)return c(r)||(r=new K),r.x=t+u*(n-t),r.y=e+u*(i-e),r};var TW=Qj;function CU(t){this._quantizedVertices=t.quantizedVertices,this._encodedNormals=t.encodedNormals,this._indices=t.indices,this._minimumHeight=t.minimumHeight,this._maximumHeight=t.maximumHeight,this._boundingSphere=t.boundingSphere,this._orientedBoundingBox=t.orientedBoundingBox,this._horizonOcclusionPoint=t.horizonOcclusionPoint,this._credits=t.credits;let e=this._quantizedVertices.length/3,n=this._uValues=this._quantizedVertices.subarray(0,e),i=this._vValues=this._quantizedVertices.subarray(e,2*e);this._heightValues=this._quantizedVertices.subarray(2*e,3*e);function o(s,l){return i[s]-i[l]}function a(s,l){return n[s]-n[l]}this._westIndices=Yj(t.westIndices,o,e),this._southIndices=Yj(t.southIndices,a,e),this._eastIndices=Yj(t.eastIndices,o,e),this._northIndices=Yj(t.northIndices,a,e),this._westSkirtHeight=t.westSkirtHeight,this._southSkirtHeight=t.southSkirtHeight,this._eastSkirtHeight=t.eastSkirtHeight,this._northSkirtHeight=t.northSkirtHeight,this._childTileMask=f(t.childTileMask,15),this._createdByUpsampling=f(t.createdByUpsampling,!1),this._waterMask=t.waterMask,this._mesh=void 0}Object.defineProperties(CU.prototype,{credits:{get:function(){return this._credits}},waterMask:{get:function(){return this._waterMask}},childTileMask:{get:function(){return this._childTileMask}},canUpsample:{get:function(){return c(this._mesh)}}});var kj=[];function Yj(t,e,n){kj.length=t.length;let i=!1;for(let o=0,a=t.length;o<a;++o)kj[o]=t[o],i=i||o>0&&e(t[o-1],t[o])>0;return i?(kj.sort(e),re.createTypedArray(n,kj)):t}var nkt="createVerticesFromQuantizedTerrainMesh",XJe=new $i(nkt),JJe=new $i(nkt,nZ.maximumAsynchronousTasks);CU.prototype.createMesh=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.tilingScheme,n=t.x,i=t.y,o=t.level,a=f(t.exaggeration,1),s=f(t.exaggerationRelativeHeight,0),l=f(t.throttle,!0),r=e.ellipsoid,d=e.tileXYToRectangle(n,i,o),h=(l?JJe:XJe).scheduleTask({minimumHeight:this._minimumHeight,maximumHeight:this._maximumHeight,quantizedVertices:this._quantizedVertices,octEncodedNormals:this._encodedNormals,includeWebMercatorT:!0,indices:this._indices,westIndices:this._westIndices,southIndices:this._southIndices,eastIndices:this._eastIndices,northIndices:this._northIndices,westSkirtHeight:this._westSkirtHeight,southSkirtHeight:this._southSkirtHeight,eastSkirtHeight:this._eastSkirtHeight,northSkirtHeight:this._northSkirtHeight,rectangle:d,relativeToCenter:this._boundingSphere.center,ellipsoid:r,exaggeration:a,exaggerationRelativeHeight:s});if(!c(h))return;let u=this;return Promise.resolve(h).then(function(R){let V=u._quantizedVertices.length/3,F=V+u._westIndices.length+u._southIndices.length+u._eastIndices.length+u._northIndices.length,U=re.createTypedArray(F,R.indices),G=new Float32Array(R.vertices),A=R.center,S=R.minimumHeight,g=R.maximumHeight,C=u._boundingSphere,y=u._orientedBoundingBox,Y=f(p.clone(R.occludeePointInScaledSpace),u._horizonOcclusionPoint),Q=R.vertexStride,J=lc.clone(R.encoding);return u._mesh=new AV(A,G,U,R.indexCountWithoutSkirts,V,S,g,C,Y,Q,y,J,R.westIndicesSouthToNorth,R.southIndicesEastToWest,R.eastIndicesNorthToSouth,R.northIndicesWestToEast),u._quantizedVertices=void 0,u._encodedNormals=void 0,u._indices=void 0,u._uValues=void 0,u._vValues=void 0,u._heightValues=void 0,u._westIndices=void 0,u._southIndices=void 0,u._eastIndices=void 0,u._northIndices=void 0,u._mesh})};var LJe=new $i("upsampleQuantizedTerrainMesh",nZ.maximumAsynchronousTasks);CU.prototype.upsample=function(t,e,n,i,o,a,s){let l=this._mesh;if(!c(this._mesh))return;let r=e*2!==o,d=n*2===a,m=t.ellipsoid,h=t.tileXYToRectangle(o,a,s),u=LJe.scheduleTask({vertices:l.vertices,vertexCountWithoutSkirts:l.vertexCountWithoutSkirts,indices:l.indices,indexCountWithoutSkirts:l.indexCountWithoutSkirts,encoding:l.encoding,minimumHeight:this._minimumHeight,maximumHeight:this._maximumHeight,isEastChild:r,isNorthChild:d,childRectangle:h,ellipsoid:m});if(!c(u))return;let R=Math.min(this._westSkirtHeight,this._eastSkirtHeight);R=Math.min(R,this._southSkirtHeight),R=Math.min(R,this._northSkirtHeight);let V=r?R*.5:this._westSkirtHeight,F=d?R*.5:this._southSkirtHeight,U=r?this._eastSkirtHeight:R*.5,G=d?this._northSkirtHeight:R*.5,A=this._credits;return Promise.resolve(u).then(function(S){let g=new Uint16Array(S.vertices),C=re.createTypedArray(g.length/3,S.indices),y;return c(S.encodedNormals)&&(y=new Uint8Array(S.encodedNormals)),new CU({quantizedVertices:g,indices:C,encodedNormals:y,minimumHeight:S.minimumHeight,maximumHeight:S.maximumHeight,boundingSphere:Ft.clone(S.boundingSphere),orientedBoundingBox:ci.clone(S.orientedBoundingBox),horizonOcclusionPoint:p.clone(S.horizonOcclusionPoint),westIndices:S.westIndices,southIndices:S.southIndices,eastIndices:S.eastIndices,northIndices:S.northIndices,westSkirtHeight:V,southSkirtHeight:F,eastSkirtHeight:U,northSkirtHeight:G,childTileMask:0,credits:A,createdByUpsampling:!0})})};var yst=32767,ikt=new p;CU.prototype.interpolateHeight=function(t,e,n){let i=k.clamp((e-t.west)/t.width,0,1);i*=yst;let o=k.clamp((n-t.south)/t.height,0,1);return o*=yst,c(this._mesh)?OJe(this,i,o):HJe(this,i,o)};function okt(t,e,n,i,o,a,s,l){let r=Math.min(n,o,s),d=Math.max(n,o,s),m=Math.min(i,a,l),h=Math.max(i,a,l);return t>=r&&t<=d&&e>=m&&e<=h}var MJe=new K,_Je=new K,DJe=new K;function OJe(t,e,n){let i=t._mesh,o=i.vertices,a=i.encoding,s=i.indices;for(let l=0,r=s.length;l<r;l+=3){let d=s[l],m=s[l+1],h=s[l+2],u=a.decodeTextureCoordinates(o,d,MJe),R=a.decodeTextureCoordinates(o,m,_Je),V=a.decodeTextureCoordinates(o,h,DJe);if(okt(e,n,u.x,u.y,R.x,R.y,V.x,V.y)){let F=TW.computeBarycentricCoordinates(e,n,u.x,u.y,R.x,R.y,V.x,V.y,ikt);if(F.x>=-1e-15&&F.y>=-1e-15&&F.z>=-1e-15){let U=a.decodeHeight(o,d),G=a.decodeHeight(o,m),A=a.decodeHeight(o,h);return F.x*U+F.y*G+F.z*A}}}}function HJe(t,e,n){let i=t._uValues,o=t._vValues,a=t._heightValues,s=t._indices;for(let l=0,r=s.length;l<r;l+=3){let d=s[l],m=s[l+1],h=s[l+2],u=i[d],R=i[m],V=i[h],F=o[d],U=o[m],G=o[h];if(okt(e,n,u,F,R,U,V,G)){let A=TW.computeBarycentricCoordinates(e,n,u,F,R,U,V,G,ikt);if(A.x>=-1e-15&&A.y>=-1e-15&&A.z>=-1e-15){let S=A.x*a[d]+A.y*a[m]+A.z*a[h];return k.lerp(t._minimumHeight,t._maximumHeight,S/yst)}}}}CU.prototype.isChildAvailable=function(t,e,n,i){let o=2;return n!==t*2&&++o,i!==e*2&&(o-=2),(this._childTileMask&1<<o)!==0};CU.prototype.wasCreatedByUpsampling=function(){return this._createdByUpsampling};var OT=CU;function wJe(t){this.resource=t.resource,this.version=t.version,this.isHeightmap=t.isHeightmap,this.tileUrlTemplates=t.tileUrlTemplates,this.availability=t.availability,this.hasVertexNormals=t.hasVertexNormals,this.hasWaterMask=t.hasWaterMask,this.hasMetadata=t.hasMetadata,this.availabilityLevels=t.availabilityLevels,this.availabilityTilesLoaded=t.availabilityTilesLoaded,this.littleEndianExtensionSize=t.littleEndianExtensionSize,this.availabilityPromiseCache={}}function skt(t){this.requestVertexNormals=f(t.requestVertexNormals,!1),this.requestWaterMask=f(t.requestWaterMask,!1),this.requestMetadata=f(t.requestMetadata,!0),this.ellipsoid=t.ellipsoid,this.heightmapWidth=65,this.heightmapStructure=void 0,this.hasWaterMask=!1,this.hasMetadata=!1,this.hasVertexNormals=!1,this.scheme=void 0,this.lastResource=void 0,this.layerJsonResource=void 0,this.previousError=void 0,this.availability=void 0,this.tilingScheme=void 0,this.levelZeroMaximumGeometricError=void 0,this.heightmapStructure=void 0,this.layers=[],this.attribution="",this.overallAvailability=[],this.overallMaxZoom=0,this.tileCredits=[]}skt.prototype.build=function(t){t._heightmapWidth=this.heightmapWidth,t._scheme=this.scheme;let e=c(this.lastResource.credits)?this.lastResource.credits:[];t._tileCredits=e.concat(this.tileCredits),t._availability=this.availability,t._tilingScheme=this.tilingScheme,t._requestWaterMask=this.requestWaterMask,t._levelZeroMaximumGeometricError=this.levelZeroMaximumGeometricError,t._heightmapStructure=this.heightmapStructure,t._layers=this.layers,t._hasWaterMask=this.hasWaterMask,t._hasVertexNormals=this.hasVertexNormals,t._hasMetadata=this.hasMetadata};async function lkt(t,e,n){if(!e.format){let F="The tile format is not specified in the layer.json file.";throw t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,F),new Tt(F)}if(!e.tiles||e.tiles.length===0){let F="The layer.json file does not specify any tile URL templates.";throw t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,F),new Tt(F)}let i=!1,o=!1,a=!1,s=!0,l=!1;if(e.format==="heightmap-1.0")l=!0,c(t.heightmapStructure)||(t.heightmapStructure={heightScale:1/5,heightOffset:-1e3,elementsPerHeight:1,stride:1,elementMultiplier:256,isBigEndian:!1,lowestEncodedHeight:0,highestEncodedHeight:256*256-1}),o=!0,t.requestWaterMask=!0;else if(e.format.indexOf("quantized-mesh-1.")!==0){let F=`The tile format "${e.format}" is invalid or not supported.`;throw t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,F),new Tt(F)}let r=e.tiles,d=e.maxzoom;if(t.overallMaxZoom=Math.max(t.overallMaxZoom,d),!e.projection||e.projection==="EPSG:4326")t.tilingScheme=new Qo({numberOfLevelZeroTilesX:2,numberOfLevelZeroTilesY:1,ellipsoid:t.ellipsoid});else if(e.projection==="EPSG:3857")t.tilingScheme=new Gs({numberOfLevelZeroTilesX:1,numberOfLevelZeroTilesY:1,ellipsoid:t.ellipsoid});else{let F=`The projection "${e.projection}" is invalid or not supported.`;throw t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,F),new Tt(F)}if(t.levelZeroMaximumGeometricError=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(t.tilingScheme.ellipsoid,t.heightmapWidth,t.tilingScheme.getNumberOfXTilesAtLevel(0)),!e.scheme||e.scheme==="tms"||e.scheme==="slippyMap")t.scheme=e.scheme;else{let F=`The scheme "${e.scheme}" is invalid or not supported.`;throw t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,F),new Tt(F)}let m;c(e.extensions)&&e.extensions.indexOf("octvertexnormals")!==-1?i=!0:c(e.extensions)&&e.extensions.indexOf("vertexnormals")!==-1&&(i=!0,s=!1),c(e.extensions)&&e.extensions.indexOf("watermask")!==-1&&(o=!0),c(e.extensions)&&e.extensions.indexOf("metadata")!==-1&&(a=!0);let h=e.metadataAvailability,u=e.available,R;if(c(u)&&!c(h)){R=new pZ(t.tilingScheme,u.length);for(let F=0;F<u.length;++F){let U=u[F],G=t.tilingScheme.getNumberOfYTilesAtLevel(F);c(t.overallAvailability[F])||(t.overallAvailability[F]=[]);for(let A=0;A<U.length;++A){let S=U[A],g=G-S.endY-1,C=G-S.startY-1;t.overallAvailability[F].push([S.startX,g,S.endX,C]),R.addAvailableTileRange(F,S.startX,g,S.endX,C)}}}else c(h)&&(m=new pZ(t.tilingScheme,d),R=new pZ(t.tilingScheme,d),t.overallAvailability[0]=[[0,0,1,0]],R.addAvailableTileRange(0,0,0,1,0));t.hasWaterMask=t.hasWaterMask||o,t.hasVertexNormals=t.hasVertexNormals||i,t.hasMetadata=t.hasMetadata||a,c(e.attribution)&&(t.attribution.length>0&&(t.attribution+=" "),t.attribution+=e.attribution),t.layers.push(new wJe({resource:t.lastResource,version:e.version,isHeightmap:l,tileUrlTemplates:r,availability:R,hasVertexNormals:i,hasWaterMask:o,hasMetadata:a,availabilityLevels:h,availabilityTilesLoaded:m,littleEndianExtensionSize:s}));let V=e.parentUrl;return c(V)?c(R)?(t.lastResource=t.lastResource.getDerivedResource({url:V}),t.lastResource.appendForwardSlash(),t.layerJsonResource=t.lastResource.getDerivedResource({url:"layer.json"}),await kst(t),!0):(console.log("A layer.json can't have a parentUrl if it does't have an available array."),!0):!0}function PJe(t,e,n){let i=`An error occurred while accessing ${t.layerJsonResource.url}.`;if(c(e)&&(i+=` +${e.message}`),t.previousError=za.reportError(t.previousError,n,c(n)?n._errorEvent:void 0,i),t.previousError.retry)return kst(t,n);throw new Tt(i)}async function vJe(t,e,n){await lkt(t,e,n);let i=t.overallAvailability.length;if(i>0){let o=t.availability=new pZ(t.tilingScheme,t.overallMaxZoom);for(let a=0;a<i;++a){let s=t.overallAvailability[a];for(let l=0;l<s.length;++l){let r=s[l];o.addAvailableTileRange(a,r[0],r[1],r[2],r[3])}}}if(t.attribution.length>0){let o=new on(t.attribution);t.tileCredits.push(o)}return!0}async function kst(t,e){try{let n=await t.layerJsonResource.fetchJson();return vJe(t,n,e)}catch(n){return c(n)&&n.statusCode===404?(await lkt(t,{tilejson:"2.1.0",format:"heightmap-1.0",version:"1.0.0",scheme:"tms",tiles:["{z}/{x}/{y}.terrain?v={version}"]},e),!0):PJe(t,n,e)}}function VZ(t){t=f(t,f.EMPTY_OBJECT),this._heightmapWidth=void 0,this._heightmapStructure=void 0,this._hasWaterMask=!1,this._hasVertexNormals=!1,this._hasMetadata=!1,this._scheme=void 0,this._ellipsoid=t.ellipsoid,this._requestVertexNormals=f(t.requestVertexNormals,!1),this._requestWaterMask=f(t.requestWaterMask,!1),this._requestMetadata=f(t.requestMetadata,!0),this._errorEvent=new It;let e=t.credit;typeof e=="string"&&(e=new on(e)),this._credit=e,this._availability=void 0,this._tilingScheme=void 0,this._levelZeroMaximumGeometricError=void 0,this._layers=void 0,this._tileCredits=void 0}var Bst={OCT_VERTEX_NORMALS:1,WATER_MASK:2,METADATA:4};function akt(t){return!c(t)||t.length===0?{Accept:"application/vnd.quantized-mesh,application/octet-stream;q=0.9,*/*;q=0.01"}:{Accept:`application/vnd.quantized-mesh;extensions=${t.join("-")},application/octet-stream;q=0.9,*/*;q=0.01`}}function KJe(t,e,n,i,o){let a=new Uint16Array(e,0,t._heightmapWidth*t._heightmapWidth);return new Gd({buffer:a,childTileMask:new Uint8Array(e,a.byteLength,1)[0],waterMask:new Uint8Array(e,a.byteLength+1,e.byteLength-a.byteLength-1),width:t._heightmapWidth,height:t._heightmapWidth,structure:t._heightmapStructure,credits:t._tileCredits})}function zJe(t,e,n,i,o,a){let s=a.littleEndianExtensionSize,l=0,r=3,d=r+1,m=Float64Array.BYTES_PER_ELEMENT*r,h=Float64Array.BYTES_PER_ELEMENT*d,R=Uint16Array.BYTES_PER_ELEMENT*3,V=3,F=Uint16Array.BYTES_PER_ELEMENT,U=F*V,G=new DataView(e),A=new p(G.getFloat64(l,!0),G.getFloat64(l+8,!0),G.getFloat64(l+16,!0));l+=m;let S=G.getFloat32(l,!0);l+=Float32Array.BYTES_PER_ELEMENT;let g=G.getFloat32(l,!0);l+=Float32Array.BYTES_PER_ELEMENT;let C=new Ft(new p(G.getFloat64(l,!0),G.getFloat64(l+8,!0),G.getFloat64(l+16,!0)),G.getFloat64(l+m,!0));l+=h;let y=new p(G.getFloat64(l,!0),G.getFloat64(l+8,!0),G.getFloat64(l+16,!0));l+=m;let Y=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let Q=new Uint16Array(e,l,Y*3);l+=Y*R,Y>64*1024&&(F=Uint32Array.BYTES_PER_ELEMENT,U=F*V);let J=Q.subarray(0,Y),M=Q.subarray(Y,2*Y),Z=Q.subarray(Y*2,3*Y);Ni.zigZagDeltaDecode(J,M,Z),l%F!==0&&(l+=F-l%F);let E=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let I=re.createTypedArrayFromArrayBuffer(Y,e,l,E*V);l+=E*U;let B=0,X=I.length;for(let Wt=0;Wt<X;++Wt){let Nt=I[Wt];I[Wt]=B-Nt,Nt===0&&++B}let _=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let P=re.createTypedArrayFromArrayBuffer(Y,e,l,_);l+=_*F;let w=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let z=re.createTypedArrayFromArrayBuffer(Y,e,l,w);l+=w*F;let H=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let nt=re.createTypedArrayFromArrayBuffer(Y,e,l,H);l+=H*F;let $=G.getUint32(l,!0);l+=Uint32Array.BYTES_PER_ELEMENT;let dt=re.createTypedArrayFromArrayBuffer(Y,e,l,$);l+=$*F;let q,at;for(;l<G.byteLength;){let Wt=G.getUint8(l,!0);l+=Uint8Array.BYTES_PER_ELEMENT;let Nt=G.getUint32(l,s);if(l+=Uint32Array.BYTES_PER_ELEMENT,Wt===Bst.OCT_VERTEX_NORMALS&&t._requestVertexNormals)q=new Uint8Array(e,l,Y*2);else if(Wt===Bst.WATER_MASK&&t._requestWaterMask)at=new Uint8Array(e,l,Nt);else if(Wt===Bst.METADATA&&t._requestMetadata){let kt=G.getUint32(l,!0);if(kt>0){let qt=ts(new Uint8Array(e),l+Uint32Array.BYTES_PER_ELEMENT,kt).available;if(c(qt))for(let ie=0;ie<qt.length;++ie){let oe=n+ie+1,He=qt[ie],rn=t._tilingScheme.getNumberOfYTilesAtLevel(oe);for(let de=0;de<He.length;++de){let zt=He[de],ke=rn-zt.endY-1,Ve=rn-zt.startY-1;t.availability.addAvailableTileRange(oe,zt.startX,ke,zt.endX,Ve),a.availability.addAvailableTileRange(oe,zt.startX,ke,zt.endX,Ve)}}}a.availabilityTilesLoaded.addAvailableTileRange(n,i,o,i,o)}l+=Nt}let st=t.getLevelMaximumGeometricError(n)*5,Et=t._tilingScheme.tileXYToRectangle(i,o,n),Qt=ci.fromRectangle(Et,S,g,t._tilingScheme.ellipsoid);return new OT({center:A,minimumHeight:S,maximumHeight:g,boundingSphere:C,orientedBoundingBox:Qt,horizonOcclusionPoint:y,quantizedVertices:Q,encodedNormals:q,indices:I,westIndices:P,southIndices:z,eastIndices:nt,northIndices:dt,westSkirtHeight:st,southSkirtHeight:st,eastSkirtHeight:st,northSkirtHeight:st,childTileMask:t.availability.computeChildMaskForTile(n,i,o),waterMask:at,credits:t._tileCredits})}VZ.prototype.requestTileGeometry=function(t,e,n,i){let o=this._layers,a,s=o.length,l=!1,r=Promise.resolve();if(s===1)a=o[0];else for(let d=0;d<s;++d){let m=o[d];if(!c(m.availability)||m.availability.isTileAvailable(n,t,e)){a=m;break}let h=Yst(this,t,e,n,m,d===0);h.result&&(l=!0,r=r.then(()=>h.promise))}return!c(a)&&l?r.then(()=>new Promise(d=>{setTimeout(()=>{let m=this.requestTileGeometry(t,e,n,i);d(m)},0)})):rkt(this,t,e,n,a,i)};function rkt(t,e,n,i,o,a){if(!c(o))return Promise.reject(new Tt("Terrain tile doesn't exist"));let s=o.tileUrlTemplates;if(s.length===0)return;let l;!t._scheme||t._scheme==="tms"?l=t._tilingScheme.getNumberOfYTilesAtLevel(i)-n-1:l=n;let r=[];t._requestVertexNormals&&o.hasVertexNormals&&r.push(o.littleEndianExtensionSize?"octvertexnormals":"vertexnormals"),t._requestWaterMask&&o.hasWaterMask&&r.push("watermask"),t._requestMetadata&&o.hasMetadata&&r.push("metadata");let d,m,h=s[(e+l+i)%s.length],u=o.resource;c(u._ionEndpoint)&&!c(u._ionEndpoint.externalType)?(r.length!==0&&(m={extensions:r.join("-")}),d=akt(void 0)):d=akt(r);let R=u.getDerivedResource({url:h,templateValues:{version:o.version,z:i,x:e,y:l},queryParameters:m,headers:d,request:a}).fetchArrayBuffer();if(c(R))return R.then(function(V){return c(V)?c(t._heightmapStructure)?KJe(t,V,i,e,n):zJe(t,V,i,e,n,o):Promise.reject(new Tt("Mesh buffer doesn't exist."))})}Object.defineProperties(VZ.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},tilingScheme:{get:function(){return this._tilingScheme}},hasWaterMask:{get:function(){return this._hasWaterMask&&this._requestWaterMask}},hasVertexNormals:{get:function(){return this._hasVertexNormals&&this._requestVertexNormals}},hasMetadata:{get:function(){return this._hasMetadata&&this._requestMetadata}},requestVertexNormals:{get:function(){return this._requestVertexNormals}},requestWaterMask:{get:function(){return this._requestWaterMask}},requestMetadata:{get:function(){return this._requestMetadata}},availability:{get:function(){return this._availability}}});VZ.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<<t)};VZ.fromIonAssetId=async function(t,e){let n=await gh.fromAssetId(t);return VZ.fromUrl(n,e)};VZ.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT),t=await Promise.resolve(t);let n=te.createIfNeeded(t);n.appendForwardSlash();let i=new skt(e);i.lastResource=n,i.layerJsonResource=i.lastResource.getDerivedResource({url:"layer.json"}),await kst(i);let o=new VZ(e);return i.build(o),o};VZ.prototype.getTileDataAvailable=function(t,e,n){if(!c(this._availability))return;if(n>this._availability._maximumLevel)return!1;if(this._availability.isTileAvailable(n,t,e))return!0;if(!this._hasMetadata)return!1;let i=this._layers,o=i.length;for(let a=0;a<o;++a)if(Yst(this,t,e,n,i[a],a===0).result)return;return!1};VZ.prototype.loadTileDataAvailability=function(t,e,n){if(!c(this._availability)||n>this._availability._maximumLevel||this._availability.isTileAvailable(n,t,e)||!this._hasMetadata)return;let i=this._layers,o=i.length;for(let a=0;a<o;++a){let s=Yst(this,t,e,n,i[a],a===0);if(c(s.promise))return s.promise}};function Qst(t,e,n,i){if(i===0)return;let o=t.availabilityLevels,a=i%o===0?i-o:(i/o|0)*o,s=1<<i-a,l=e/s|0,r=n/s|0;return{level:a,x:l,y:r}}function Yst(t,e,n,i,o,a){if(!c(o.availabilityLevels))return{result:!1};let s,l=function(){delete o.availabilityPromiseCache[s]},r=o.availabilityTilesLoaded,d=o.availability,m=Qst(o,e,n,i);for(;c(m);){if(d.isTileAvailable(m.level,m.x,m.y)&&!r.isTileAvailable(m.level,m.x,m.y)){let h;if(!a&&(s=`${m.level}-${m.x}-${m.y}`,h=o.availabilityPromiseCache[s],!c(h))){let u=new us({throttle:!1,throttleByServer:!0,type:Xl.TERRAIN});h=rkt(t,m.x,m.y,m.level,o,u),c(h)&&(o.availabilityPromiseCache[s]=h,h.then(l))}return{result:!0,promise:h}}m=Qst(o,m.x,m.y,m.level)}return{result:!1}}VZ._getAvailabilityTile=Qst;var HT=VZ;var WDo=b(W(),1);function gW(t){t=f(t,f.EMPTY_OBJECT);let e=t.radius,n={center:t.center,semiMajorAxis:e,semiMinorAxis:e,ellipsoid:t.ellipsoid,height:t.height,extrudedHeight:t.extrudedHeight,granularity:t.granularity,vertexFormat:t.vertexFormat,stRotation:t.stRotation,shadowVolume:t.shadowVolume};this._ellipseGeometry=new Pc(n),this._workerName="createCircleGeometry"}gW.packedLength=Pc.packedLength;gW.pack=function(t,e,n){return Pc.pack(t._ellipseGeometry,e,n)};var jJe=new Pc({center:new p,semiMajorAxis:1,semiMinorAxis:1}),uc={center:new p,radius:void 0,ellipsoid:mt.clone(mt.UNIT_SPHERE),height:void 0,extrudedHeight:void 0,granularity:void 0,vertexFormat:new ee,stRotation:void 0,semiMajorAxis:void 0,semiMinorAxis:void 0,shadowVolume:void 0};gW.unpack=function(t,e,n){let i=Pc.unpack(t,e,jJe);return uc.center=p.clone(i._center,uc.center),uc.ellipsoid=mt.clone(i._ellipsoid,uc.ellipsoid),uc.height=i._height,uc.extrudedHeight=i._extrudedHeight,uc.granularity=i._granularity,uc.vertexFormat=ee.clone(i._vertexFormat,uc.vertexFormat),uc.stRotation=i._stRotation,uc.shadowVolume=i._shadowVolume,c(n)?(uc.semiMajorAxis=i._semiMajorAxis,uc.semiMinorAxis=i._semiMinorAxis,n._ellipseGeometry=new Pc(uc),n):(uc.radius=i._semiMajorAxis,new gW(uc))};gW.createGeometry=function(t){return Pc.createGeometry(t._ellipseGeometry)};gW.createShadowVolume=function(t,e,n){let i=t._ellipseGeometry._granularity,o=t._ellipseGeometry._ellipsoid,a=e(i,o),s=n(i,o);return new gW({center:t._ellipseGeometry._center,radius:t._ellipseGeometry._semiMajorAxis,ellipsoid:o,stRotation:t._ellipseGeometry._stRotation,granularity:i,extrudedHeight:a,height:s,vertexFormat:ee.POSITION_ONLY,shadowVolume:!0})};Object.defineProperties(gW.prototype,{rectangle:{get:function(){return this._ellipseGeometry.rectangle}},textureCoordinateRotationPoints:{get:function(){return this._ellipseGeometry.textureCoordinateRotationPoints}}});var xst=gW;var TDo=b(W(),1);function oN(t){t=f(t,f.EMPTY_OBJECT);let e=t.radius,n={center:t.center,semiMajorAxis:e,semiMinorAxis:e,ellipsoid:t.ellipsoid,height:t.height,extrudedHeight:t.extrudedHeight,granularity:t.granularity,numberOfVerticalLines:t.numberOfVerticalLines};this._ellipseGeometry=new Lh(n),this._workerName="createCircleOutlineGeometry"}oN.packedLength=Lh.packedLength;oN.pack=function(t,e,n){return Lh.pack(t._ellipseGeometry,e,n)};var qJe=new Lh({center:new p,semiMajorAxis:1,semiMinorAxis:1}),cp={center:new p,radius:void 0,ellipsoid:mt.clone(mt.UNIT_SPHERE),height:void 0,extrudedHeight:void 0,granularity:void 0,numberOfVerticalLines:void 0,semiMajorAxis:void 0,semiMinorAxis:void 0};oN.unpack=function(t,e,n){let i=Lh.unpack(t,e,qJe);return cp.center=p.clone(i._center,cp.center),cp.ellipsoid=mt.clone(i._ellipsoid,cp.ellipsoid),cp.height=i._height,cp.extrudedHeight=i._extrudedHeight,cp.granularity=i._granularity,cp.numberOfVerticalLines=i._numberOfVerticalLines,c(n)?(cp.semiMajorAxis=i._semiMajorAxis,cp.semiMinorAxis=i._semiMinorAxis,n._ellipseGeometry=new Lh(cp),n):(cp.radius=i._semiMajorAxis,new oN(cp))};oN.createGeometry=function(t){return Lh.createGeometry(t._ellipseGeometry)};var Xst=oN;var EDo=b(W(),1),$Je=(t,e)=>{let n=i=>{!t.trackedEntity&&i.shouldAnimate===!0?e.entities._precisionMode=i.multiplier===1?75:0:e.entities._precisionMode=0};return t.clock.onTick.addEventListener(n),{remove:function(){t.clock.onTick.removeEventListener(n)}}},Jst=$Je;var vDo=b(W(),1);var LDo=b(W(),1);var xj=class{constructor(e){let n=e,{_times:i,_values:o,_value:a,_interpolationDegree:s,_derivativeTypes:l,_xTable:r,_yTable:d,_interpolationResult:m,_interpolationAlgorithm:h}=n,u="ConstantPositionProperty";n instanceof cl?u="CompositePositionProperty":n instanceof jl?u="ConstantPositionProperty":n instanceof ql?u="SampledProperty":n instanceof Bs?u="SampledPositionProperty":n instanceof vc?u="ScaledPositionProperty":n instanceof _m&&(u="TimeIntervalCollectionProperty"),this._times=i,this._values=o,this._value=a,this._interpolationDegree=s,this._derivativeTypes=l,this._xTable=r,this._yTable=d,this._interpolationResult=m,this.interpolationAlgorithm=h?.type?.toUpperCase()||"LINEAR",this.propertyType=u}},tLe=t=>t.position?new xj(t.position):null,eLe=t=>{let e=t,n;switch(e.propertyType){case"CompositePositionProperty":n=cl;break;case"ConstantPositionProperty":n=jl;break;case"SampledProperty":n=ql;break;case"SampledPositionProperty":n=Bs;break;case"ScaledPositionProperty":n=vc;break;case"TimeIntervalCollectionProperty":n=_m;break;default:throw new Error(`Unknown propertyType: ${e.propertyType}`)}let i=new n(p);for(let o in e)o!=="propertyType"&&o!=="interpolationAlgorithm"&&(i[o]=e[o]);return i.setInterpolationOptions&&i.setInterpolationOptions({interpolationAlgorithm:nLe(e.interpolationAlgorithm),interpolationDegree:e._interpolationDegree}),i};function nLe(t){switch(t){case"LAGRANGE":return dS;case"HERMITE":return rS;case"LINEAR":default:return _b}}var g5={SerializePosition:tLe,DeserializePosition:eLe,SerializedPosition:xj};var{OMMT:HDo,OMMCOLLECTIONT:iLe}=sW,{CATT:wDo,CATCOLLECTIONT:oLe}=aW,Lst=1,aLe=async({spaceCatalogDataSources:t,startTime:e,endTime:n,step:i=6e4,radius:o=5e3,screeningObjects:a=[]})=>{let s={OMM:new iLe,CAT:new oLe,entities:[]};Array.isArray(t)||(t=[t]);let l=[];for(let V of t)l=l.concat([...V.entities.values]);a.length===0&&(a=l);let r=a.map(V=>V.id);for(let V of l){let F=V.properties.OMM.getValue(),U=V.properties.CAT.getValue(),G=g5(V);G&&(s.entities.push({id:V.id,position:G}),s.OMM.RECORDS.push(F),s.CAT.RECORDS.push(U))}s.OMM=writeFB(s.OMM).buffer,s.CAT=writeFB(s.CAT).buffer;let d=new $i("ConjunctionAssessment",Lst),m=Math.ceil(r.length/Lst),h=[];for(let V=0;V<Lst;V++){let F={transferEntities:s,screeningObjectIds:r.slice(V*m,(V+1)*m),start:rt.toDate(e).getTime(),stop:rt.toDate(n).getTime(),step:i,radius:o};h.push(d.scheduleTask(F))}let u=await Promise.all(h);return console.log(u),u.flat()},Mst=aLe;var oOo=b(W(),1);function aN(t){t=f(t,f.EMPTY_OBJECT),this._callback=t.callback,this._tilingScheme=t.tilingScheme,c(this._tilingScheme)||(this._tilingScheme=new Qo({ellipsoid:f(t.ellipsoid,mt.WGS84)})),this._width=t.width,this._height=t.height;let e=Math.max(this._width,this._height);this._levelZeroMaximumGeometricError=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(this._tilingScheme.ellipsoid,e,this._tilingScheme.getNumberOfXTilesAtLevel(0)),this._errorEvent=new It;let n=t.credit;typeof n=="string"&&(n=new on(n)),this._credit=n}Object.defineProperties(aN.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},tilingScheme:{get:function(){return this._tilingScheme}},hasWaterMask:{get:function(){return!1}},hasVertexNormals:{get:function(){return!1}},width:{get:function(){return this._width}},height:{get:function(){return this._height}}});aN.prototype.requestTileGeometry=function(t,e,n,i){let o=this._callback(t,e,n);if(!c(o))return;let a=this._width,s=this._height;return Promise.resolve(o).then(function(l){let r=l;return Array.isArray(r)&&(r=new Float64Array(r)),new Gd({buffer:r,width:a,height:s})})};aN.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<<t)};aN.prototype.getTileDataAvailable=function(t,e,n){};aN.prototype.loadTileDataAvailability=function(t,e,n){};var _st=aN;var sOo=b(W(),1);function dkt(t){this.proxy=t}dkt.prototype.getURL=function(t){let e=this.proxy.indexOf("?")===-1?"?":"";return this.proxy+e+encodeURIComponent(t)};var Dst=dkt;var ZOo=b(W(),1);var ckt=t=>{let e;if(t.position)e=t.position?._property||t.position;else for(let V in t)if(t[V]?.position)e=t[V].position._property;else if(t[V]?.positions){e=t[V].positions;let F={x:0,y:0,z:0};for(let U=0;U<e._value.length;U++)F.x+=e._value[U].x,F.y+=e._value[U].y,F.z+=e._value[U].z;for(let U in F)F[U]&&(F[U]=F[U]/e._value.length);e._value=new p(F.x,F.y,F.z)}if(!e)return;let{id:n}=t,{_times:i,_values:o,_value:a,_interpolationDegree:s,_derivativeTypes:l,_xTable:r,_yTable:d,_interpolationResult:m,_interpolationAlgorithm:h}=e,u="ConstantPositionProperty";e instanceof cl?u="CompositePositionProperty":e instanceof jl?u="ConstantPositionProperty":e instanceof ql?u="SampledProperty":e instanceof Bs?u="SampledPositionProperty":e instanceof vc?u="ScaledPositionProperty":e instanceof _m&&(u="TimeIntervalCollectionProperty"),t.properties=t.properties||{};let{jsonOMM:R}=t.properties;return{id:n,_times:i,_values:o,_value:a,_interpolationDegree:s,_derivativeTypes:l,_xTable:r,_yTable:d,_interpolationResult:m,interpolationAlgorithm:h?.type?.toUpperCase()||"LINEAR",propertyType:u,jsonOMM:R}},sLe=async({fromEntity:t,toEntityArray:e,startTime:n,endTime:i,step:o=60,sensor:a=null,sensorOrientation:s,dateString:l=!1})=>{let r=[];if(Array.isArray(e)||(e=[e]),e.length){for(let G of e){let A=ckt(G);A&&r.push(A)}let d=3,m=Math.ceil(r.length/d),h=[],u=new $i("AnalysisWorker",d),R=[];for(let G=0;G<r.length;G++)if(R.length<m&&R.push(r[G]),R.length>=m||G===r.length-1){let A={fromEntity:ckt(t),toEntityArray:R,startTime:n.toString(),endTime:i.toString(),dateString:l,step:o,sensor:a?{sensorName:a?.constructor?.name,...a}:null,sensorOrientation:s},S=u.scheduleTask(A);h.push(S.then(g=>g)),R=[]}let V=await Promise.allSettled(h),F=V.filter(G=>G.reason);if(F.length)throw Error(JSON.stringify(F,null,4));let U={};for(let G=0;G<V.length;G++)for(let A in V[G].value)V[G].value[A]&&(U[A]=V[G].value[A]);return U}return Promise.reject("No Target Entities Found.")},Ost=sLe;var bOo=b(W(),1),lLe={SEARCH:0,AUTOCOMPLETE:1},IU=Object.freeze(lLe);var GOo=b(W(),1);function Xj(){Ut.throwInstantiationError()}Object.defineProperties(Xj.prototype,{credit:{get:Ut.throwInstantiationError}});Xj.getCreditsFromResult=function(t){if(c(t.attributions))return t.attributions.map(on.getIonCredit)};Xj.prototype.geocode=Ut.throwInstantiationError;var sN=Xj;var TOo=b(W(),1);function mkt(){Ut.throwInstantiationError()}mkt.createGeometry=function(t){Ut.throwInstantiationError()};var Hst=mkt;var POo=b(W(),1),pLe=b(wst(),1);var BOo=b(W(),1);var COo=b(W(),1);function rLe(t,e){return(t&e)!==0}var Zc=rLe;var dLe=[1,2,4,8],hkt=15,cLe=16,mLe=64,hLe=128;function zR(t,e,n,i,o,a){this._bits=t,this.cnodeVersion=e,this.imageryVersion=n,this.terrainVersion=i,this.imageryProvider=o,this.terrainProvider=a,this.ancestorHasTerrain=!1,this.terrainState=void 0}zR.clone=function(t,e){return c(e)?(e._bits=t._bits,e.cnodeVersion=t.cnodeVersion,e.imageryVersion=t.imageryVersion,e.terrainVersion=t.terrainVersion,e.imageryProvider=t.imageryProvider,e.terrainProvider=t.terrainProvider):e=new zR(t._bits,t.cnodeVersion,t.imageryVersion,t.terrainVersion,t.imageryProvider,t.terrainProvider),e.ancestorHasTerrain=t.ancestorHasTerrain,e.terrainState=t.terrainState,e};zR.prototype.setParent=function(t){this.ancestorHasTerrain=t.ancestorHasTerrain||this.hasTerrain()};zR.prototype.hasSubtree=function(){return Zc(this._bits,cLe)};zR.prototype.hasImagery=function(){return Zc(this._bits,mLe)};zR.prototype.hasTerrain=function(){return Zc(this._bits,hLe)};zR.prototype.hasChildren=function(){return Zc(this._bits,hkt)};zR.prototype.hasChild=function(t){return Zc(this._bits,dLe[t])};zR.prototype.getChildBitmask=function(){return this._bits&hkt};var E5=zR;function VLe(t){let e=t.length,n=new ArrayBuffer(e),i=new Uint8Array(n);for(let o=0;o<e;++o)i[o]=t.charCodeAt(o);return n}var uLe=VLe(`E\xF4\xBD\vy\xE2jE"\x92,\xCDq\xF8IFgQ\0B%\xC6\xE8a,f)\b\xC64\xDCjb%y wmi\xD6\xF0\x9Ck\x93\xA1\xBDNu\xE0A[\xDF@V\f\xD9\xBBr\x9B\x81|3S\xEEOl\xD4q\xB0{\xC0\x7FEVZ\xADwUe\v3\x92*\xACl5\xC50s\xF83>mF8J\xB4\xDD\xF0.\xDDu\xDA\x8CDt"\xFAa"\f3"So\xAF9D\v\x8C9\xD99L\xB9\xBF\x7F\xAB\\\x8CP_\x9F"ux\xE9\x07q\x91h;\xC1\xC4\x9B\x7F\xF0<VqH\x82'UfYNe\x98u\xA3aF}a?A\0\x9F\xD7\xB44M\xCE\x87F\xB0\xD5\xB8\x8A'{\x8B\xDC+\xBBMg0\xC8\xD1\xF6\\\x8FP\xFA[/F\x9Bn5/'C.\xEB \f^\xA5s\x1Be4\xE5l.jC'c#U\xA9?q{gC}:\xAF\xCD\xE2TU\x9C\xFDK\xC6\xE2\x9F/(\xED\xCB\\\xC6-f\x07\x88\xA7;/*"N\xB0k.\xDD\r\x95}}G\xBAC\xB2\xB2+>M\xAA>}\xE6\xCEI\x89\xC6\xE6x\fa1-\xA4O\xA5~q \x88\xEC\r1\xE8N\v\0nPh}=\b\r\x95\xA6n\xA3h\x97$[k\xF3#\xF3\xB6s\xB3\r\v@\xC0\x9F\xD8Q]\xFA".j\xDFI\0\xB9\xA0wU\xC6\xEFj\xBF{GL\x7F\x83\xEE\xDC\xDCF\x85\xA9\xADS\x07+S4\x07\xFF\x94Y\xE48\xE81\x83N\xB9XFk\xCB-#\x86\x92p\x005\x88"\xCF1\xB2&/\xE7\xC3u-6,rt\xB0#G\xB7\xD3\xD1&\x857r\xE2\0\x8CD\xCF\xDA3-\xDE\`\x86i#i*|\xCDKQ\r\x95T9w.)\xEA\x1B\xA6P\xA2j\x8FoP\x99\\>T\xFB\xEFP[\v\x07E\x89m(w7\xDB\x8EJfJo\x99 \xE5p\xE2\xB9q~\fmI-z\xFEr\xC7\xF2Y0\x8F\xBB]s\xE5\xC9 \xEAx\xEC \x90\xF0\x8A\x7FB|G\`\xB0\xBD&\xB7q\xB6\xC7\x9F\xD13\x82=\xD3\xAB\xEEc\x99\xC8+S\xA0D\\q\xC6\xCCD2O<\xCA\xC0)=R\xD3aX\xA9}e\xB4\xDC\xCF\r\xF4=\xF1\b\xA9B\xDA# \xD8\xBF^PI\xF8M\xC0\xCBGLO\xF7{+\xD8\xC51\x92;\xB5o\xDCl\r\x92\x88\xD1\x9E\xDB?\xE2\xE9\xDA_\xD4\x84\xE2FaZ\xDEU\xCF\xA4\0\xBE\xFD\xCEg\xF1Ji\x97\xE6 H\xD8]\x7F~\xAEq N\xAE\xC0V\xA9\x91<\x82r\xE7v\xEC)I\xD6]-\x83\xE3\xDB6\xA9;f\x97\x87j\xD5\xB6=P^R\xB9K\xC7sWx\xC9\xF4.Y\x07\x95\x93o\xD0KW>''\xC7\`\xDB;\xED\x9ASD>?\x8D\x92mw\xA2 \xEB?R\xA8\xC6U^1I7\x85\xF4\xC5&-\xA9\xBF\x8B'T\xDA\xC3j \xE5*x\xB0\xD6\x90pr\xAA\x8Bh\xBD\x88\xF7_H\xB1~\xC0XL?f\xF9>\xE1e\xC0p\xA7\xCF8i\xAF\xF0VldI\x9C'\xADxtO\xC2\x87\xDEV9\0\xDAw\v\xCB-\x1B\x89\xFB5O\xF5\bQ\`\xC1 ZGM&30x\xDA\xC0\x9CFG\xE2[y\`In7gS >\xE9\xECF9\xB2\xF14\r\xC6\x84Sun\xE1\fY\xD9\xDE)\x85{II\xA5wy\xBEIV.6\xE7\v:\xBBOb{\xD2M1\x95/\xBD8{\xA8O!\xE1\xECFpv\x95})"x\x88 -\x90\xDD\x9D\\\xDA\xDEQ\xCF\xF0\xFCYRe|3\xDF\xF3H\xDA\xBB*u\xDB\`\xB2\xD4\xFC\xED\x1B\xEC\x7F5\xA8\xFF(1\x07-\xC8\xDC\x88F|\x8A["`);function mp(t){this.imageryPresent=!0,this.protoImagery=void 0,this.terrainPresent=!0,this.negativeAltitudeExponentBias=32,this.negativeAltitudeThreshold=k.EPSILON12,this.providers={},this.key=void 0,this._resource=void 0,this._quadPacketVersion=1,this._tileInfo={},this._subtreePromises={}}Object.defineProperties(mp.prototype,{url:{get:function(){return this._resource.url}},proxy:{get:function(){return this._resource.proxy}},resource:{get:function(){return this._resource}}});mp.fromUrl=async function(t){let e=t;typeof e!="string"&&!(e instanceof te)&&(e=t.url);let n=te.createIfNeeded(e);n.appendForwardSlash();let i=new mp;i._resource=n;try{await VLe(i),await i.getQuadTreePacket("",i._quadPacketVersion)}catch(o){let a=`An error occurred while accessing ${u2t(i,"",1).url}: ${o}`;throw new St(a)}return i};mp.tileXYToQuadKey=function(t,e,n){let i="";for(let o=n;o>=0;--o){let a=1<<o,s=0;Vc(e,a)?Vc(t,a)&&(s|=1):(s|=2,Vc(t,a)||(s|=1)),i+=s}return i};mp.quadKeyToTileXY=function(t){let e=0,n=0,i=t.length-1;for(let o=i;o>=0;--o){let a=1<<o,s=+t[i-o];Vc(s,2)?Vc(s,1)||(e|=a):(n|=a,Vc(s,1)&&(e|=a))}return{x:e,y:n,level:i}};mp.prototype.isValid=function(t){let e=this.getTileInformationFromQuadKey(t);if(c(e))return e!==null;let n=!0,i=t,o;for(;i.length>1;)if(o=i.substring(i.length-1),i=i.substring(0,i.length-1),e=this.getTileInformationFromQuadKey(i),c(e)){!e.hasSubtree()&&!e.hasChild(parseInt(o))&&(n=!1);break}else if(e===null){n=!1;break}return n};var p2t=new $i("decodeGoogleEarthEnterprisePacket");mp.prototype.getQuadTreePacket=function(t,e,n){e=f(e,1),t=f(t,"");let o=u2t(this,t,e,n).fetchArrayBuffer();if(!c(o))return;let a=this._tileInfo,s=this.key;return o.then(function(l){return p2t.scheduleTask({buffer:l,quadKey:t,type:"Metadata",key:s},[l]).then(function(d){let m,h=-1;if(t!==""){h=t.length+1;let u=d[t];m=a[t],m._bits|=u._bits,delete d[t]}let Z=Object.keys(d);Z.sort(function(u,F){return u.length-F.length});let b=Z.length;for(let u=0;u<b;++u){let F=Z[u];if(d[F]!==null){let G=E5.clone(d[F]),A=F.length;if(A===h)G.setParent(m);else if(A>1){let T=a[F.substring(0,F.length-1)];G.setParent(T)}a[F]=G}else a[F]=null}})})};mp.prototype.populateSubtree=function(t,e,n,i){let o=mp.tileXYToQuadKey(t,e,n);return Kst(this,o,i)};function Kst(t,e,n){let i=t._tileInfo,o=e,a=i[o];if(c(a)&&(!a.hasSubtree()||a.hasChildren()))return a;for(;a===void 0&&o.length>1;)o=o.substring(0,o.length-1),a=i[o];let s,l=t._subtreePromises,r=l[o];if(c(r))return r.then(function(){return s=new Zs({throttle:n.throttle,throttleByServer:n.throttleByServer,type:n.type,priorityFunction:n.priorityFunction}),Kst(t,e,s)});if(!c(a)||!a.hasSubtree())return Promise.reject(new St(`Couldn't load metadata for tile ${e}`));if(r=t.getQuadTreePacket(o,a.cnodeVersion,n),!!c(r))return l[o]=r,r.then(function(){return s=new Zs({throttle:n.throttle,throttleByServer:n.throttleByServer,type:n.type,priorityFunction:n.priorityFunction}),Kst(t,e,s)}).finally(function(){delete l[o]})}mp.prototype.getTileInformation=function(t,e,n){let i=mp.tileXYToQuadKey(t,e,n);return this._tileInfo[i]};mp.prototype.getTileInformationFromQuadKey=function(t){return this._tileInfo[t]};function u2t(t,e,n,i){return t._resource.getDerivedResource({url:`flatfile?q2-0${e}-q.${n.toString()}`,request:i})}var Pst,vst;function VLe(t){let e=t._resource.getDerivedResource({url:"dbRoot.v5",queryParameters:{output:"proto"}});if(!c(vst)){let n=Dn("ThirdParty/google-earth-dbroot-parser.js"),i=window.cesiumGoogleEarthDbRootParser;vst=VG(n).then(function(){Pst=window.cesiumGoogleEarthDbRootParser(pLe),c(i)?window.cesiumGoogleEarthDbRootParser=i:delete window.cesiumGoogleEarthDbRootParser})}return vst.then(function(){return e.fetchArrayBuffer()}).then(function(n){let i=Pst.EncryptedDbRootProto.decode(new Uint8Array(n)),o=i.encryptionData,a=o.byteOffset,s=a+o.byteLength,l=t.key=o.buffer.slice(a,s);o=i.dbrootData,a=o.byteOffset,s=a+o.byteLength;let r=o.buffer.slice(a,s);return p2t.scheduleTask({buffer:r,type:"DbRoot",key:l},[r])}).then(function(n){let i=Pst.DbRootProto.decode(new Uint8Array(n.buffer));if(t.imageryPresent=f(i.imageryPresent,t.imageryPresent),t.protoImagery=i.protoImagery,t.terrainPresent=f(i.terrainPresent,t.terrainPresent),c(i.endSnippet)&&c(i.endSnippet.model)){let l=i.endSnippet.model;t.negativeAltitudeExponentBias=f(l.negativeAltitudeExponentBias,t.negativeAltitudeExponentBias),t.negativeAltitudeThreshold=f(l.compressedNegativeAltitudeThreshold,t.negativeAltitudeThreshold)}c(i.databaseVersion)&&(t._quadPacketVersion=f(i.databaseVersion.quadtreeVersion,t._quadPacketVersion));let o=t.providers,a=f(i.providerInfo,[]),s=a.length;for(let l=0;l<s;++l){let r=a[l],d=r.copyrightString;c(d)&&(o[r.providerId]=new on(d.value))}}).catch(function(){console.log(`Failed to retrieve ${e.url}. Using defaults.`),t.key=ZLe})}var EW=mp;var cHo=R(W(),1);function wS(t){t=f(t,f.EMPTY_OBJECT),this._buffer=t.buffer,this._credits=t.credits,this._negativeAltitudeExponentBias=t.negativeAltitudeExponentBias,this._negativeElevationThreshold=t.negativeElevationThreshold;let e=f(t.childTileMask,15),n=e&3;n|=e&4?8:0,n|=e&8?4:0,this._childTileMask=n,this._createdByUpsampling=f(t.createdByUpsampling,!1),this._skirtHeight=void 0,this._bufferType=this._buffer.constructor,this._mesh=void 0,this._minimumHeight=void 0,this._maximumHeight=void 0}Object.defineProperties(wS.prototype,{credits:{get:function(){return this._credits}},waterMask:{get:function(){}}});var b2t="createVerticesFromGoogleEarthEnterpriseBuffer",bLe=new $i(b2t),RLe=new $i(b2t,nV.maximumAsynchronousTasks),Z2t=new Gt,zst=new Gt;wS.prototype.createMesh=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.tilingScheme,n=t.x,i=t.y,o=t.level,a=f(t.exaggeration,1),s=f(t.exaggerationRelativeHeight,0),l=f(t.throttle,!0),r=e.ellipsoid;e.tileXYToNativeRectangle(n,i,o,Z2t),e.tileXYToRectangle(n,i,o,zst);let d=r.cartographicToCartesian(Gt.center(zst)),h=40075.16/(1<<o);this._skirtHeight=Math.min(h*8,1e3);let b=(l?RLe:bLe).scheduleTask({buffer:this._buffer,nativeRectangle:Z2t,rectangle:zst,relativeToCenter:d,ellipsoid:r,skirtHeight:this._skirtHeight,exaggeration:a,exaggerationRelativeHeight:s,includeWebMercatorT:!0,negativeAltitudeExponentBias:this._negativeAltitudeExponentBias,negativeElevationThreshold:this._negativeElevationThreshold});if(!c(b))return;let u=this;return b.then(function(F){return u._mesh=new Au(d,new Float32Array(F.vertices),new Uint16Array(F.indices),F.indexCountWithoutSkirts,F.vertexCountWithoutSkirts,F.minimumHeight,F.maximumHeight,Ft.clone(F.boundingSphere3D),p.clone(F.occludeePointInScaledSpace),F.numberOfAttributes,ci.clone(F.orientedBoundingBox),lc.clone(F.encoding),F.westIndicesSouthToNorth,F.southIndicesEastToWest,F.eastIndicesNorthToSouth,F.northIndicesWestToEast),u._minimumHeight=F.minimumHeight,u._maximumHeight=F.maximumHeight,u._buffer=void 0,u._mesh})};wS.prototype.interpolateHeight=function(t,e,n){let i=k.clamp((e-t.west)/t.width,0,1),o=k.clamp((n-t.south)/t.height,0,1);return c(this._mesh)?GLe(this,i,o):SLe(this,i,o,t)};var WLe=new $i("upsampleQuantizedTerrainMesh",nV.maximumAsynchronousTasks);wS.prototype.upsample=function(t,e,n,i,o,a,s){let l=this._mesh;if(!c(this._mesh))return;let r=e*2!==o,d=n*2===a,m=t.ellipsoid,h=t.tileXYToRectangle(o,a,s),Z=WLe.scheduleTask({vertices:l.vertices,indices:l.indices,indexCountWithoutSkirts:l.indexCountWithoutSkirts,vertexCountWithoutSkirts:l.vertexCountWithoutSkirts,encoding:l.encoding,minimumHeight:this._minimumHeight,maximumHeight:this._maximumHeight,isEastChild:r,isNorthChild:d,childRectangle:h,ellipsoid:m});if(!c(Z))return;let b=this;return Z.then(function(u){let F=new Uint16Array(u.vertices),U=re.createTypedArray(F.length/3,u.indices),G=b._skirtHeight;return new OS({quantizedVertices:F,indices:U,minimumHeight:u.minimumHeight,maximumHeight:u.maximumHeight,boundingSphere:Ft.clone(u.boundingSphere),orientedBoundingBox:ci.clone(u.orientedBoundingBox),horizonOcclusionPoint:p.clone(u.horizonOcclusionPoint),westIndices:u.westIndices,southIndices:u.southIndices,eastIndices:u.eastIndices,northIndices:u.northIndices,westSkirtHeight:G,southSkirtHeight:G,eastSkirtHeight:G,northSkirtHeight:G,childTileMask:0,createdByUpsampling:!0,credits:b._credits})})};wS.prototype.isChildAvailable=function(t,e,n,i){let o=2;return n!==t*2&&++o,i!==e*2&&(o-=2),(this._childTileMask&1<<o)!==0};wS.prototype.wasCreatedByUpsampling=function(){return this._createdByUpsampling};var fLe=new K,FLe=new K,ULe=new K,R2t=new p;function GLe(t,e,n){let i=t._mesh,o=i.vertices,a=i.encoding,s=i.indices;for(let l=0,r=s.length;l<r;l+=3){let d=s[l],m=s[l+1],h=s[l+2],Z=a.decodeTextureCoordinates(o,d,fLe),b=a.decodeTextureCoordinates(o,m,FLe),u=a.decodeTextureCoordinates(o,h,ULe),F=SW.computeBarycentricCoordinates(e,n,Z.x,Z.y,b.x,b.y,u.x,u.y,R2t);if(F.x>=-1e-15&&F.y>=-1e-15&&F.z>=-1e-15){let U=a.decodeHeight(o,d),G=a.decodeHeight(o,m),A=a.decodeHeight(o,h);return F.x*U+F.y*G+F.z*A}}}var ALe=Uint16Array.BYTES_PER_ELEMENT,V2t=Uint32Array.BYTES_PER_ELEMENT,jst=Int32Array.BYTES_PER_ELEMENT,TLe=Float32Array.BYTES_PER_ELEMENT,qst=Float64Array.BYTES_PER_ELEMENT;function SLe(t,e,n,i){let o=t._buffer,a=0,s=0,l=0;n>.5?(e>.5?(a=2,s=.5):a=3,l=.5):e>.5&&(a=1,s=.5);let r=new DataView(o),d=0;for(let C=0;C<a;++C)d+=r.getUint32(d,!0),d+=V2t;d+=V2t,d+=2*qst;let m=k.toRadians(r.getFloat64(d,!0)*180);d+=qst;let h=k.toRadians(r.getFloat64(d,!0)*180);d+=qst;let Z=i.width/m/2,b=i.height/h/2,u=r.getInt32(d,!0);d+=jst;let F=r.getInt32(d,!0)*3;d+=jst,d+=jst;let U=new Array(u),G=new Array(u),A=new Array(u),T;for(T=0;T<u;++T)U[T]=s+r.getUint8(d++)*Z,G[T]=l+r.getUint8(d++)*b,A[T]=r.getFloat32(d,!0)*6371010,d+=TLe;let g=new Array(F);for(T=0;T<F;++T)g[T]=r.getUint16(d,!0),d+=ALe;for(T=0;T<F;T+=3){let C=g[T],y=g[T+1],Y=g[T+2],Q=U[C],J=U[y],M=U[Y],V=G[C],E=G[y],I=G[Y],B=SW.computeBarycentricCoordinates(e,n,Q,V,J,E,M,I,R2t);if(B.x>=-1e-15&&B.y>=-1e-15&&B.z>=-1e-15)return B.x*A[C]+B.y*A[y]+B.z*A[Y]}}var lN=wS;var EHo=R(W(),1);var Qu={UNKNOWN:0,NONE:1,SELF:2,PARENT:3},Jj=new rt;function Lj(){this._terrainCache={},this._lastTidy=rt.now()}Lj.prototype.add=function(t,e){this._terrainCache[t]={buffer:e,timestamp:rt.now()}};Lj.prototype.get=function(t){let n=this._terrainCache[t];if(c(n))return delete this._terrainCache[t],n.buffer};Lj.prototype.tidy=function(){if(rt.now(Jj),rt.secondsDifference(Jj,this._lastTidy)>10){let t=this._terrainCache,e=Object.keys(t),n=e.length;for(let i=0;i<n;++i){let o=e[i],a=t[o];rt.secondsDifference(Jj,a.timestamp)>10&&delete t[o]}rt.clone(Jj,this._lastTidy)}};function NU(t){t=f(t,f.EMPTY_OBJECT),this._tilingScheme=new Qo({numberOfLevelZeroTilesX:2,numberOfLevelZeroTilesY:2,rectangle:new Gt(-k.PI,-k.PI,k.PI,k.PI),ellipsoid:t.ellipsoid});let e=t.credit;typeof e=="string"&&(e=new on(e)),this._credit=e,this._levelZeroMaximumGeometricError=40075.16,this._terrainCache=new Lj,this._terrainPromises={},this._terrainRequests={},this._errorEvent=new It}Object.defineProperties(NU.prototype,{url:{get:function(){return this._metadata.url}},proxy:{get:function(){return this._metadata.proxy}},tilingScheme:{get:function(){return this._tilingScheme}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasWaterMask:{get:function(){return!1}},hasVertexNormals:{get:function(){return!1}},availability:{get:function(){}}});NU.fromMetadata=function(t,e){if(!t.terrainPresent)throw new St(`The server ${t.url} doesn't have terrain`);let n=new NU(e);return n._metadata=t,n};var gLe=new $i("decodeGoogleEarthEnterprisePacket");function W2t(t,e,n){let i=e.getChildBitmask();if(e.terrainState===Qu.PARENT){i=0;for(let o=0;o<4;++o){let a=n.getTileInformationFromQuadKey(t+o.toString());c(a)&&a.hasTerrain()&&(i|=1<<o)}}return i}NU.prototype.requestTileGeometry=function(t,e,n,i){let o=EW.tileXYToQuadKey(t,e,n),a=this._terrainCache,s=this._metadata,l=s.getTileInformationFromQuadKey(o);if(!c(l))return Promise.reject(new St("Terrain tile doesn't exist"));let r=l.terrainState;c(r)||(r=l.terrainState=Qu.UNKNOWN);let d=a.get(o);if(c(d)){let G=s.providers[l.terrainProvider];return Promise.resolve(new lN({buffer:d,childTileMask:W2t(o,l,s),credits:c(G)?[G]:void 0,negativeAltitudeExponentBias:s.negativeAltitudeExponentBias,negativeElevationThreshold:s.negativeAltitudeThreshold}))}if(a.tidy(),l.ancestorHasTerrain){if(r===Qu.NONE)return Promise.reject(new St("Terrain tile doesn't exist"))}else return Promise.resolve(new Gd({buffer:new Uint8Array(16*16),width:16,height:16}));let m,h=o,Z=-1;switch(r){case Qu.SELF:Z=l.terrainVersion;break;case Qu.PARENT:h=h.substring(0,h.length-1),m=s.getTileInformationFromQuadKey(h),Z=m.terrainVersion;break;case Qu.UNKNOWN:l.hasTerrain()?Z=l.terrainVersion:(h=h.substring(0,h.length-1),m=s.getTileInformationFromQuadKey(h),c(m)&&m.hasTerrain()&&(Z=m.terrainVersion));break}if(Z<0)return Promise.reject(new St("Terrain tile doesn't exist"));let b=this._terrainPromises,u=this._terrainRequests,F,U;if(c(b[h]))F=b[h],U=u[h];else{U=i;let G=ELe(this,h,Z,U).fetchArrayBuffer();if(!c(G))return;F=G.then(function(A){return c(A)?gLe.scheduleTask({buffer:A,type:"Terrain",key:s.key},[A]).then(function(T){let g=s.getTileInformationFromQuadKey(h);g.terrainState=Qu.SELF,a.add(h,T[0]);let C=g.terrainProvider,y=T.length-1;for(let Y=0;Y<y;++Y){let Q=h+Y.toString(),J=s.getTileInformationFromQuadKey(Q);c(J)&&(a.add(Q,T[Y+1]),J.terrainState=Qu.PARENT,J.terrainProvider===0&&(J.terrainProvider=C))}}):Promise.reject(new St("Failed to load terrain."))}),b[h]=F,u[h]=U,F=F.finally(function(){delete b[h],delete u[h]})}return F.then(function(){let G=a.get(o);if(c(G)){let A=s.providers[l.terrainProvider];return new lN({buffer:G,childTileMask:W2t(o,l,s),credits:c(A)?[A]:void 0,negativeAltitudeExponentBias:s.negativeAltitudeExponentBias,negativeElevationThreshold:s.negativeAltitudeThreshold})}return Promise.reject(new St("Failed to load terrain."))}).catch(function(G){return U.state===qi.CANCELLED?(i.state=U.state,Promise.reject(G)):(l.terrainState=Qu.NONE,Promise.reject(G))})};NU.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<<t)};NU.prototype.getTileDataAvailable=function(t,e,n){let i=this._metadata,o=EW.tileXYToQuadKey(t,e,n),a=i.getTileInformation(t,e,n);if(a===null)return!1;if(c(a)){if(!a.ancestorHasTerrain)return!0;let s=a.terrainState;if(s===Qu.NONE)return!1;if((!c(s)||s===Qu.UNKNOWN)&&(a.terrainState=Qu.UNKNOWN,!a.hasTerrain())){o=o.substring(0,o.length-1);let l=i.getTileInformationFromQuadKey(o);if(!c(l)||!l.hasTerrain())return!1}return!0}if(i.isValid(o)){let s=new Zs({throttle:!1,throttleByServer:!0,type:Xl.TERRAIN});i.populateSubtree(t,e,n,s)}return!1};NU.prototype.loadTileDataAvailability=function(t,e,n){};function ELe(t,e,n,i){return n=c(n)&&n>0?n:1,t._metadata.resource.getDerivedResource({url:`flatfile?f1c-0${e}-t.${n.toString()}`,request:i})}var $st=NU;var yHo=R(W(),1);var Mj={};Mj.defaultApiKey=void 0;Mj.mapTilesApiEndpoint=new te({url:"https://tile.googleapis.com/v1/"});Mj.getDefaultCredit=function(){return new on('<img src="https://assets.ion-development.cesium.com/google-credit.png" alt="Google">',!0)};var PS=Mj;var kHo=R(W(),1);var C5={};C5.type=void 0;C5.getRequiredDataPoints=Ut.throwInstantiationError;C5.interpolateOrderZero=Ut.throwInstantiationError;C5.interpolate=Ut.throwInstantiationError;var tlt=C5;var zHo=R(W(),1);var _Ho=R(W(),1);function elt(t){this._url=te.createIfNeeded(t),this._url.appendForwardSlash()}Object.defineProperties(elt.prototype,{url:{get:function(){return this._url}},credit:{get:function(){}}});elt.prototype.geocode=async function(t,e){return this._url.getDerivedResource({url:e===IU.AUTOCOMPLETE?"autocomplete":"search",queryParameters:{text:t}}).fetchJson().then(function(i){return i.features.map(function(o){let a,s=o.bbox;if(c(s))a=Gt.fromDegrees(s[0],s[1],s[2],s[3]);else{let l=o.geometry.coordinates[0],r=o.geometry.coordinates[1];a=p.fromDegrees(l,r)}return{displayName:o.properties.label,destination:a,attributions:i.attributions}})})};var I5=elt;function nlt(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.accessToken,cZ.defaultAccessToken),n=te.createIfNeeded(f(t.server,cZ.defaultServer));n.appendForwardSlash();let i=cZ.getDefaultTokenCredit(e);c(i)&&t.scene.frameState.creditDisplay.addStaticCredit(on.clone(i));let o=n.getDerivedResource({url:"v1/geocode"});c(e)&&o.appendQueryParameters({access_token:e}),this._accessToken=e,this._server=n,this._pelias=new I5(o)}Object.defineProperties(nlt.prototype,{credit:{get:function(){}}});nlt.prototype.geocode=async function(t,e){return this._pelias.geocode(t,e)};var N5=nlt;var $Ho=R(W(),1);function _j(){Ut.throwInstantiationError()}Object.defineProperties(_j.prototype,{ellipsoid:{get:Ut.throwInstantiationError}});_j.prototype.project=Ut.throwInstantiationError;_j.prototype.unproject=Ut.throwInstantiationError;var ilt=_j;var owo=R(W(),1);function rN(t){t=f(t,f.EMPTY_OBJECT);let e=t.weights,n=t.times;this._times=n,this._weights=e,this._count=e.length/n.length,this._lastTimeIndex=0}Object.defineProperties(rN.prototype,{times:{get:function(){return this._times}},weights:{get:function(){return this._weights}}});rN.prototype.findTimeInterval=ba.prototype.findTimeInterval;rN.prototype.wrapTime=ba.prototype.wrapTime;rN.prototype.clampTime=ba.prototype.clampTime;rN.prototype.evaluate=function(t,e){let n=this.weights,i=this.times,o=this._lastTimeIndex=this.findTimeInterval(t,this._lastTimeIndex),a=(t-i[o])/(i[o+1]-i[o]);c(e)||(e=new Array(this._count));for(let s=0;s<this._count;s++){let l=o*this._count+s;e[s]=n[l]*(1-a)+n[l+this._count]*a}return e};var olt=rN;var pwo=R(W(),1);function alt(t,e,n){t=te.createIfNeeded(t),t.appendForwardSlash(),t.setQueryParameters({key:e}),this._url=t,this._params=f(n,{}),this._credit=new on('Geodata copyright <a href="https://www.openstreetmap.org/">OpenStreetMap</a> contributors',!1)}Object.defineProperties(alt.prototype,{url:{get:function(){return this._url}},params:{get:function(){return this._params}},credit:{get:function(){return this._credit}}});alt.prototype.geocode=async function(t){return this._url.getDerivedResource({url:"json",queryParameters:ze(this._params,{q:t})}).fetchJson().then(function(n){return n.results.map(function(i){let o,a=i.bounds;if(c(a))o=Gt.fromDegrees(a.southwest.lng,a.southwest.lat,a.northeast.lng,a.northeast.lat);else{let s=i.geometry.lat,l=i.geometry.lng;o=p.fromDegrees(s,l)}return{displayName:i.formatted,destination:o}})})};var slt=alt;var Vwo=R(W(),1);var CLe={packedLength:void 0,pack:Ut.throwInstantiationError,unpack:Ut.throwInstantiationError},llt=CLe;var Wwo=R(W(),1);var ILe={packedInterpolationLength:void 0,convertPackedArrayForInterpolation:Ut.throwInstantiationError,unpackInterpolationResult:Ut.throwInstantiationError},rlt=ILe;var Uwo=R(W(),1);function f2t(){Ut.throwInstantiationError()}f2t.prototype.getURL=Ut.throwInstantiationError;var dlt=f2t;var Jwo=R(W(),1);function NLe(t,e,n,i,o,a,s){let l=xo.numberOfPoints(t,e,o),r,d=n.red,m=n.green,h=n.blue,Z=n.alpha,b=i.red,u=i.green,F=i.blue,U=i.alpha;if(v.equals(n,i)){for(r=0;r<l;r++)a[s++]=v.floatToByte(d),a[s++]=v.floatToByte(m),a[s++]=v.floatToByte(h),a[s++]=v.floatToByte(Z);return s}let G=(b-d)/l,A=(u-m)/l,T=(F-h)/l,g=(U-Z)/l,C=s;for(r=0;r<l;r++)a[C++]=v.floatToByte(d+r*G),a[C++]=v.floatToByte(m+r*A),a[C++]=v.floatToByte(h+r*T),a[C++]=v.floatToByte(Z+r*g);return C}function y5(t){t=f(t,f.EMPTY_OBJECT);let e=t.positions,n=t.colors,i=f(t.colorsPerVertex,!1);this._positions=e,this._colors=n,this._colorsPerVertex=i,this._arcType=f(t.arcType,Ln.GEODESIC),this._granularity=f(t.granularity,k.RADIANS_PER_DEGREE),this._ellipsoid=f(t.ellipsoid,mt.WGS84),this._workerName="createSimplePolylineGeometry";let o=1+e.length*p.packedLength;o+=c(n)?1+n.length*v.packedLength:1,this.packedLength=o+mt.packedLength+3}y5.pack=function(t,e,n){n=f(n,0);let i,o=t._positions,a=o.length;for(e[n++]=a,i=0;i<a;++i,n+=p.packedLength)p.pack(o[i],e,n);let s=t._colors;for(a=c(s)?s.length:0,e[n++]=a,i=0;i<a;++i,n+=v.packedLength)v.pack(s[i],e,n);return mt.pack(t._ellipsoid,e,n),n+=mt.packedLength,e[n++]=t._colorsPerVertex?1:0,e[n++]=t._arcType,e[n]=t._granularity,e};y5.unpack=function(t,e,n){e=f(e,0);let i,o=t[e++],a=new Array(o);for(i=0;i<o;++i,e+=p.packedLength)a[i]=p.unpack(t,e);o=t[e++];let s=o>0?new Array(o):void 0;for(i=0;i<o;++i,e+=v.packedLength)s[i]=v.unpack(t,e);let l=mt.unpack(t,e);e+=mt.packedLength;let r=t[e++]===1,d=t[e++],m=t[e];return c(n)?(n._positions=a,n._colors=s,n._ellipsoid=l,n._colorsPerVertex=r,n._arcType=d,n._granularity=m,n):new y5({positions:a,colors:s,ellipsoid:l,colorsPerVertex:r,arcType:d,granularity:m})};var Dj=new Array(2),Oj=new Array(2),yLe={positions:Dj,height:Oj,ellipsoid:void 0,minDistance:void 0,granularity:void 0};y5.createGeometry=function(t){let e=t._positions,n=t._colors,i=t._colorsPerVertex,o=t._arcType,a=t._granularity,s=t._ellipsoid,l=k.chordLength(a,s.maximumRadius),r=c(n)&&!i,d,m=e.length,h,Z,b,u,F=0;if(o===Ln.GEODESIC||o===Ln.RHUMB){let g,C,y;o===Ln.GEODESIC?(g=k.chordLength(a,s.maximumRadius),C=xo.numberOfPoints,y=xo.generateArc):(g=a,C=xo.numberOfPointsRhumbLine,y=xo.generateRhumbArc);let Y=xo.extractHeights(e,s),Q=yLe;if(o===Ln.GEODESIC?Q.minDistance=l:Q.granularity=a,Q.ellipsoid=s,r){let J=0;for(d=0;d<m-1;d++)J+=C(e[d],e[d+1],g)+1;h=new Float64Array(J*3),b=new Uint8Array(J*4),Q.positions=Dj,Q.height=Oj;let M=0;for(d=0;d<m-1;++d){Dj[0]=e[d],Dj[1]=e[d+1],Oj[0]=Y[d],Oj[1]=Y[d+1];let V=y(Q);if(c(n)){let E=V.length/3;u=n[d];for(let I=0;I<E;++I)b[M++]=v.floatToByte(u.red),b[M++]=v.floatToByte(u.green),b[M++]=v.floatToByte(u.blue),b[M++]=v.floatToByte(u.alpha)}h.set(V,F),F+=V.length}}else if(Q.positions=e,Q.height=Y,h=new Float64Array(y(Q)),c(n)){for(b=new Uint8Array(h.length/3*4),d=0;d<m-1;++d){let M=e[d],V=e[d+1],E=n[d],I=n[d+1];F=NLe(M,V,E,I,l,b,F)}let J=n[m-1];b[F++]=v.floatToByte(J.red),b[F++]=v.floatToByte(J.green),b[F++]=v.floatToByte(J.blue),b[F++]=v.floatToByte(J.alpha)}}else{Z=r?m*2-2:m,h=new Float64Array(Z*3),b=c(n)?new Uint8Array(Z*4):void 0;let g=0,C=0;for(d=0;d<m;++d){let y=e[d];if(r&&d>0&&(p.pack(y,h,g),g+=3,u=n[d-1],b[C++]=v.floatToByte(u.red),b[C++]=v.floatToByte(u.green),b[C++]=v.floatToByte(u.blue),b[C++]=v.floatToByte(u.alpha)),r&&d===m-1)break;p.pack(y,h,g),g+=3,c(n)&&(u=n[d],b[C++]=v.floatToByte(u.red),b[C++]=v.floatToByte(u.green),b[C++]=v.floatToByte(u.blue),b[C++]=v.floatToByte(u.alpha))}}let U=new ei;U.position=new jt({componentDatatype:it.DOUBLE,componentsPerAttribute:3,values:h}),c(n)&&(U.color=new jt({componentDatatype:it.UNSIGNED_BYTE,componentsPerAttribute:4,values:b,normalize:!0})),Z=h.length/3;let G=(Z-1)*2,A=re.createTypedArray(Z,G),T=0;for(d=0;d<Z-1;++d)A[T++]=d,A[T++]=d+1;return new _e({attributes:U,indices:A,primitiveType:le.LINES,boundingSphere:Ft.fromPoints(e)})};var clt=y5;var wwo=R(W(),1);function dN(t){let e=f(t.radius,1),i={radii:new p(e,e,e),stackPartitions:t.stackPartitions,slicePartitions:t.slicePartitions,vertexFormat:t.vertexFormat};this._ellipsoidGeometry=new Cr(i),this._workerName="createSphereGeometry"}dN.packedLength=Cr.packedLength;dN.pack=function(t,e,n){return Cr.pack(t._ellipsoidGeometry,e,n)};var BLe=new Cr,yU={radius:void 0,radii:new p,vertexFormat:new ee,stackPartitions:void 0,slicePartitions:void 0};dN.unpack=function(t,e,n){let i=Cr.unpack(t,e,BLe);return yU.vertexFormat=ee.clone(i._vertexFormat,yU.vertexFormat),yU.stackPartitions=i._stackPartitions,yU.slicePartitions=i._slicePartitions,c(n)?(p.clone(i._radii,yU.radii),n._ellipsoidGeometry=new Cr(yU),n):(yU.radius=i._radii.x,new dN(yU))};dN.createGeometry=function(t){return Cr.createGeometry(t._ellipsoidGeometry)};var mlt=dN;var Kwo=R(W(),1);function BU(t){}Object.defineProperties(BU.prototype,{ellipsoid:{get:Ut.throwInstantiationError},rectangle:{get:Ut.throwInstantiationError},projection:{get:Ut.throwInstantiationError}});BU.prototype.getNumberOfXTilesAtLevel=Ut.throwInstantiationError;BU.prototype.getNumberOfYTilesAtLevel=Ut.throwInstantiationError;BU.prototype.rectangleToNativeRectangle=Ut.throwInstantiationError;BU.prototype.tileXYToNativeRectangle=Ut.throwInstantiationError;BU.prototype.tileXYToRectangle=Ut.throwInstantiationError;BU.prototype.positionToTileXY=Ut.throwInstantiationError;var hlt=BU;var mPo=R(W(),1);function QLe(t,e){this.rectangle=t,this.maxLevel=e}function F2t(t){this.ellipsoid=f(t.ellipsoid,mt.WGS84),this.tilingScheme=void 0,this.heightmapWidth=void 0,this.heightmapHeight=void 0,this.levelZeroMaximumGeometricError=void 0,this.rectangles=[]}F2t.prototype.build=function(t){t._tilingScheme=this.tilingScheme,t._heightmapWidth=this.heightmapWidth,t._heightmapHeight=this.heightmapHeight,t._levelZeroMaximumGeometricError=this.levelZeroMaximumGeometricError,t._rectangles=this.rectangles};function kLe(t,e){let n=e.getElementsByTagName("SRS")[0].textContent;if(n==="EPSG:4326")t.tilingScheme=new Qo({ellipsoid:t.ellipsoid});else throw new St(`SRS ${n} is not supported`);let i=e.getElementsByTagName("TileFormat")[0];t.heightmapWidth=parseInt(i.getAttribute("width"),10),t.heightmapHeight=parseInt(i.getAttribute("height"),10),t.levelZeroMaximumGeometricError=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(t.ellipsoid,Math.min(t.heightmapWidth,t.heightmapHeight),t.tilingScheme.getNumberOfXTilesAtLevel(0));let o=e.getElementsByTagName("DataExtent");for(let a=0;a<o.length;++a){let s=o[a],l=k.toRadians(parseFloat(s.getAttribute("minx"))),r=k.toRadians(parseFloat(s.getAttribute("miny"))),d=k.toRadians(parseFloat(s.getAttribute("maxx"))),m=k.toRadians(parseFloat(s.getAttribute("maxy"))),h=parseInt(s.getAttribute("maxlevel"),10);t.rectangles.push(new QLe(new Gt(l,r,d,m),h))}}function YLe(t,e,n){let i=`An error occurred while accessing ${t.url}`;throw c(e)&&c(e.message)&&(i=`${i}: ${e.message}`),za.reportError(void 0,n,c(n)?n._errorEvent:void 0,i),new St(i)}async function xLe(t,e,n){try{let i=await e.fetchXML();kLe(t,i)}catch(i){YLe(e,i,n)}}function QU(t){t=f(t,f.EMPTY_OBJECT),this._errorEvent=new It,this._terrainDataStructure={heightScale:1/1e3,heightOffset:-1e3,elementsPerHeight:3,stride:4,elementMultiplier:256,isBigEndian:!0,lowestEncodedHeight:0,highestEncodedHeight:256*256*256-1};let e=t.credit;typeof e=="string"&&(e=new on(e)),this._credit=e,this._tilingScheme=void 0,this._rectangles=[]}Object.defineProperties(QU.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},tilingScheme:{get:function(){return this._tilingScheme}},hasWaterMask:{get:function(){return!1}},hasVertexNormals:{get:function(){return!1}},availability:{get:function(){}}});QU.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=new F2t(e),i=te.createIfNeeded(t);await xLe(n,i);let o=new QU(e);return n.build(o),o._resource=i,o};QU.prototype.requestTileGeometry=function(t,e,n,i){let o=this._tilingScheme.getNumberOfYTilesAtLevel(n),s=this._resource.getDerivedResource({url:`${n}/${t}/${o-e-1}.tif`,queryParameters:{cesium:!0},request:i}).fetchImage({preferImageBitmap:!0});if(!c(s))return;let l=this;return Promise.resolve(s).then(function(r){return new Gd({buffer:vu(r),width:l._heightmapWidth,height:l._heightmapHeight,childTileMask:XLe(l,t,e,n),structure:l._terrainDataStructure})})};QU.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<<t)};var U2t=new Gt;function XLe(t,e,n,i){let o=t._tilingScheme,a=t._rectangles,s=o.tileXYToRectangle(e,n,i),l=0;for(let r=0;r<a.length&&l!==15;++r){let d=a[r];if(d.maxLevel<=i)continue;let m=d.rectangle,h=Gt.intersection(m,s,U2t);c(h)&&(Hj(o,m,e*2,n*2,i+1)&&(l|=4),Hj(o,m,e*2+1,n*2,i+1)&&(l|=8),Hj(o,m,e*2,n*2+1,i+1)&&(l|=1),Hj(o,m,e*2+1,n*2+1,i+1)&&(l|=2))}return l}function Hj(t,e,n,i,o){let a=t.tileXYToRectangle(n,i,o);return c(Gt.intersection(a,e,U2t))}QU.prototype.getTileDataAvailable=function(t,e,n){};QU.prototype.loadTileDataAvailability=function(t,e,n){};var plt=QU;var RPo=R(W(),1);function vS(t){t=f(t,f.EMPTY_OBJECT),this._clock=void 0,this._element=void 0,this._clockSubscription=void 0,this._seekFunction=void 0,this._lastPlaybackRate=void 0,this.clock=t.clock,this.element=t.element,this.epoch=f(t.epoch,Re.MINIMUM_VALUE),this.tolerance=f(t.tolerance,1),this._seeking=!1,this._seekFunction=void 0,this._firstTickAfterSeek=!1}Object.defineProperties(vS.prototype,{clock:{get:function(){return this._clock},set:function(t){let e=this._clock;e!==t&&(c(e)&&(this._clockSubscription(),this._clockSubscription=void 0),c(t)&&(this._clockSubscription=t.onTick.addEventListener(vS.prototype._onTick,this)),this._clock=t)}},element:{get:function(){return this._element},set:function(t){let e=this._element;e!==t&&(c(e)&&e.removeEventListener("seeked",this._seekFunction,!1),c(t)&&(this._seeking=!1,this._seekFunction=JLe(this),t.addEventListener("seeked",this._seekFunction,!1)),this._element=t,this._seeking=!1,this._firstTickAfterSeek=!1)}}});vS.prototype.destroy=function(){return this.element=void 0,this.clock=void 0,At(this)};vS.prototype.isDestroyed=function(){return!1};vS.prototype._trySetPlaybackRate=function(t){if(this._lastPlaybackRate===t.multiplier)return;let e=this._element;try{e.playbackRate=t.multiplier}catch{e.playbackRate=0}this._lastPlaybackRate=t.multiplier};vS.prototype._onTick=function(t){let e=this._element;if(!c(e)||e.readyState<2)return;let n=e.paused,i=t.shouldAnimate;if(i===n&&(i?e.play():e.pause()),this._seeking||this._firstTickAfterSeek){this._firstTickAfterSeek=!1;return}this._trySetPlaybackRate(t);let o=t.currentTime,a=f(this.epoch,Re.MINIMUM_VALUE),s=rt.secondsDifference(o,a),l=e.duration,r,d=e.currentTime;e.loop?(s=s%l,s<0&&(s=l-s),r=s):s>l?r=l:s<0?r=0:r=s;let m=i?f(this.tolerance,1):.001;Math.abs(r-d)>m&&(this._seeking=!0,e.currentTime=r)};function JLe(t){return function(){t._seeking=!1,t._firstTickAfterSeek=!0}}var ult=vS;var fPo=R(W(),1),LLe={VK_FORMAT_UNDEFINED:0,VK_FORMAT_R4G4_UNORM_PACK8:1,VK_FORMAT_R4G4B4A4_UNORM_PACK16:2,VK_FORMAT_B4G4R4A4_UNORM_PACK16:3,VK_FORMAT_R5G6B5_UNORM_PACK16:4,VK_FORMAT_B5G6R5_UNORM_PACK16:5,VK_FORMAT_R5G5B5A1_UNORM_PACK16:6,VK_FORMAT_B5G5R5A1_UNORM_PACK16:7,VK_FORMAT_A1R5G5B5_UNORM_PACK16:8,VK_FORMAT_R8_UNORM:9,VK_FORMAT_R8_SNORM:10,VK_FORMAT_R8_USCALED:11,VK_FORMAT_R8_SSCALED:12,VK_FORMAT_R8_UINT:13,VK_FORMAT_R8_SINT:14,VK_FORMAT_R8_SRGB:15,VK_FORMAT_R8G8_UNORM:16,VK_FORMAT_R8G8_SNORM:17,VK_FORMAT_R8G8_USCALED:18,VK_FORMAT_R8G8_SSCALED:19,VK_FORMAT_R8G8_UINT:20,VK_FORMAT_R8G8_SINT:21,VK_FORMAT_R8G8_SRGB:22,VK_FORMAT_R8G8B8_UNORM:23,VK_FORMAT_R8G8B8_SNORM:24,VK_FORMAT_R8G8B8_USCALED:25,VK_FORMAT_R8G8B8_SSCALED:26,VK_FORMAT_R8G8B8_UINT:27,VK_FORMAT_R8G8B8_SINT:28,VK_FORMAT_R8G8B8_SRGB:29,VK_FORMAT_B8G8R8_UNORM:30,VK_FORMAT_B8G8R8_SNORM:31,VK_FORMAT_B8G8R8_USCALED:32,VK_FORMAT_B8G8R8_SSCALED:33,VK_FORMAT_B8G8R8_UINT:34,VK_FORMAT_B8G8R8_SINT:35,VK_FORMAT_B8G8R8_SRGB:36,VK_FORMAT_R8G8B8A8_UNORM:37,VK_FORMAT_R8G8B8A8_SNORM:38,VK_FORMAT_R8G8B8A8_USCALED:39,VK_FORMAT_R8G8B8A8_SSCALED:40,VK_FORMAT_R8G8B8A8_UINT:41,VK_FORMAT_R8G8B8A8_SINT:42,VK_FORMAT_R8G8B8A8_SRGB:43,VK_FORMAT_B8G8R8A8_UNORM:44,VK_FORMAT_B8G8R8A8_SNORM:45,VK_FORMAT_B8G8R8A8_USCALED:46,VK_FORMAT_B8G8R8A8_SSCALED:47,VK_FORMAT_B8G8R8A8_UINT:48,VK_FORMAT_B8G8R8A8_SINT:49,VK_FORMAT_B8G8R8A8_SRGB:50,VK_FORMAT_A8B8G8R8_UNORM_PACK32:51,VK_FORMAT_A8B8G8R8_SNORM_PACK32:52,VK_FORMAT_A8B8G8R8_USCALED_PACK32:53,VK_FORMAT_A8B8G8R8_SSCALED_PACK32:54,VK_FORMAT_A8B8G8R8_UINT_PACK32:55,VK_FORMAT_A8B8G8R8_SINT_PACK32:56,VK_FORMAT_A8B8G8R8_SRGB_PACK32:57,VK_FORMAT_A2R10G10B10_UNORM_PACK32:58,VK_FORMAT_A2R10G10B10_SNORM_PACK32:59,VK_FORMAT_A2R10G10B10_USCALED_PACK32:60,VK_FORMAT_A2R10G10B10_SSCALED_PACK32:61,VK_FORMAT_A2R10G10B10_UINT_PACK32:62,VK_FORMAT_A2R10G10B10_SINT_PACK32:63,VK_FORMAT_A2B10G10R10_UNORM_PACK32:64,VK_FORMAT_A2B10G10R10_SNORM_PACK32:65,VK_FORMAT_A2B10G10R10_USCALED_PACK32:66,VK_FORMAT_A2B10G10R10_SSCALED_PACK32:67,VK_FORMAT_A2B10G10R10_UINT_PACK32:68,VK_FORMAT_A2B10G10R10_SINT_PACK32:69,VK_FORMAT_R16_UNORM:70,VK_FORMAT_R16_SNORM:71,VK_FORMAT_R16_USCALED:72,VK_FORMAT_R16_SSCALED:73,VK_FORMAT_R16_UINT:74,VK_FORMAT_R16_SINT:75,VK_FORMAT_R16_SFLOAT:76,VK_FORMAT_R16G16_UNORM:77,VK_FORMAT_R16G16_SNORM:78,VK_FORMAT_R16G16_USCALED:79,VK_FORMAT_R16G16_SSCALED:80,VK_FORMAT_R16G16_UINT:81,VK_FORMAT_R16G16_SINT:82,VK_FORMAT_R16G16_SFLOAT:83,VK_FORMAT_R16G16B16_UNORM:84,VK_FORMAT_R16G16B16_SNORM:85,VK_FORMAT_R16G16B16_USCALED:86,VK_FORMAT_R16G16B16_SSCALED:87,VK_FORMAT_R16G16B16_UINT:88,VK_FORMAT_R16G16B16_SINT:89,VK_FORMAT_R16G16B16_SFLOAT:90,VK_FORMAT_R16G16B16A16_UNORM:91,VK_FORMAT_R16G16B16A16_SNORM:92,VK_FORMAT_R16G16B16A16_USCALED:93,VK_FORMAT_R16G16B16A16_SSCALED:94,VK_FORMAT_R16G16B16A16_UINT:95,VK_FORMAT_R16G16B16A16_SINT:96,VK_FORMAT_R16G16B16A16_SFLOAT:97,VK_FORMAT_R32_UINT:98,VK_FORMAT_R32_SINT:99,VK_FORMAT_R32_SFLOAT:100,VK_FORMAT_R32G32_UINT:101,VK_FORMAT_R32G32_SINT:102,VK_FORMAT_R32G32_SFLOAT:103,VK_FORMAT_R32G32B32_UINT:104,VK_FORMAT_R32G32B32_SINT:105,VK_FORMAT_R32G32B32_SFLOAT:106,VK_FORMAT_R32G32B32A32_UINT:107,VK_FORMAT_R32G32B32A32_SINT:108,VK_FORMAT_R32G32B32A32_SFLOAT:109,VK_FORMAT_R64_UINT:110,VK_FORMAT_R64_SINT:111,VK_FORMAT_R64_SFLOAT:112,VK_FORMAT_R64G64_UINT:113,VK_FORMAT_R64G64_SINT:114,VK_FORMAT_R64G64_SFLOAT:115,VK_FORMAT_R64G64B64_UINT:116,VK_FORMAT_R64G64B64_SINT:117,VK_FORMAT_R64G64B64_SFLOAT:118,VK_FORMAT_R64G64B64A64_UINT:119,VK_FORMAT_R64G64B64A64_SINT:120,VK_FORMAT_R64G64B64A64_SFLOAT:121,VK_FORMAT_B10G11R11_UFLOAT_PACK32:122,VK_FORMAT_E5B9G9R9_UFLOAT_PACK32:123,VK_FORMAT_D16_UNORM:124,VK_FORMAT_X8_D24_UNORM_PACK32:125,VK_FORMAT_D32_SFLOAT:126,VK_FORMAT_S8_UINT:127,VK_FORMAT_D16_UNORM_S8_UINT:128,VK_FORMAT_D24_UNORM_S8_UINT:129,VK_FORMAT_D32_SFLOAT_S8_UINT:130,VK_FORMAT_BC1_RGB_UNORM_BLOCK:131,VK_FORMAT_BC1_RGB_SRGB_BLOCK:132,VK_FORMAT_BC1_RGBA_UNORM_BLOCK:133,VK_FORMAT_BC1_RGBA_SRGB_BLOCK:134,VK_FORMAT_BC2_UNORM_BLOCK:135,VK_FORMAT_BC2_SRGB_BLOCK:136,VK_FORMAT_BC3_UNORM_BLOCK:137,VK_FORMAT_BC3_SRGB_BLOCK:138,VK_FORMAT_BC4_UNORM_BLOCK:139,VK_FORMAT_BC4_SNORM_BLOCK:140,VK_FORMAT_BC5_UNORM_BLOCK:141,VK_FORMAT_BC5_SNORM_BLOCK:142,VK_FORMAT_BC6H_UFLOAT_BLOCK:143,VK_FORMAT_BC6H_SFLOAT_BLOCK:144,VK_FORMAT_BC7_UNORM_BLOCK:145,VK_FORMAT_BC7_SRGB_BLOCK:146,VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK:147,VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK:148,VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK:149,VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK:150,VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK:151,VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK:152,VK_FORMAT_EAC_R11_UNORM_BLOCK:153,VK_FORMAT_EAC_R11_SNORM_BLOCK:154,VK_FORMAT_EAC_R11G11_UNORM_BLOCK:155,VK_FORMAT_EAC_R11G11_SNORM_BLOCK:156,VK_FORMAT_ASTC_4x4_UNORM_BLOCK:157,VK_FORMAT_ASTC_4x4_SRGB_BLOCK:158,VK_FORMAT_ASTC_5x4_UNORM_BLOCK:159,VK_FORMAT_ASTC_5x4_SRGB_BLOCK:160,VK_FORMAT_ASTC_5x5_UNORM_BLOCK:161,VK_FORMAT_ASTC_5x5_SRGB_BLOCK:162,VK_FORMAT_ASTC_6x5_UNORM_BLOCK:163,VK_FORMAT_ASTC_6x5_SRGB_BLOCK:164,VK_FORMAT_ASTC_6x6_UNORM_BLOCK:165,VK_FORMAT_ASTC_6x6_SRGB_BLOCK:166,VK_FORMAT_ASTC_8x5_UNORM_BLOCK:167,VK_FORMAT_ASTC_8x5_SRGB_BLOCK:168,VK_FORMAT_ASTC_8x6_UNORM_BLOCK:169,VK_FORMAT_ASTC_8x6_SRGB_BLOCK:170,VK_FORMAT_ASTC_8x8_UNORM_BLOCK:171,VK_FORMAT_ASTC_8x8_SRGB_BLOCK:172,VK_FORMAT_ASTC_10x5_UNORM_BLOCK:173,VK_FORMAT_ASTC_10x5_SRGB_BLOCK:174,VK_FORMAT_ASTC_10x6_UNORM_BLOCK:175,VK_FORMAT_ASTC_10x6_SRGB_BLOCK:176,VK_FORMAT_ASTC_10x8_UNORM_BLOCK:177,VK_FORMAT_ASTC_10x8_SRGB_BLOCK:178,VK_FORMAT_ASTC_10x10_UNORM_BLOCK:179,VK_FORMAT_ASTC_10x10_SRGB_BLOCK:180,VK_FORMAT_ASTC_12x10_UNORM_BLOCK:181,VK_FORMAT_ASTC_12x10_SRGB_BLOCK:182,VK_FORMAT_ASTC_12x12_UNORM_BLOCK:183,VK_FORMAT_ASTC_12x12_SRGB_BLOCK:184,VK_FORMAT_G8B8G8R8_422_UNORM:1000156e3,VK_FORMAT_B8G8R8G8_422_UNORM:1000156001,VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM:1000156002,VK_FORMAT_G8_B8R8_2PLANE_420_UNORM:1000156003,VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM:1000156004,VK_FORMAT_G8_B8R8_2PLANE_422_UNORM:1000156005,VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM:1000156006,VK_FORMAT_R10X6_UNORM_PACK16:1000156007,VK_FORMAT_R10X6G10X6_UNORM_2PACK16:1000156008,VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16:1000156009,VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16:1000156010,VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16:1000156011,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16:1000156012,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16:1000156013,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16:1000156014,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16:1000156015,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16:1000156016,VK_FORMAT_R12X4_UNORM_PACK16:1000156017,VK_FORMAT_R12X4G12X4_UNORM_2PACK16:1000156018,VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16:1000156019,VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16:1000156020,VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16:1000156021,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16:1000156022,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16:1000156023,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16:1000156024,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16:1000156025,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16:1000156026,VK_FORMAT_G16B16G16R16_422_UNORM:1000156027,VK_FORMAT_B16G16R16G16_422_UNORM:1000156028,VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM:1000156029,VK_FORMAT_G16_B16R16_2PLANE_420_UNORM:1000156030,VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM:1000156031,VK_FORMAT_G16_B16R16_2PLANE_422_UNORM:1000156032,VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM:1000156033,VK_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG:1000054e3,VK_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG:1000054001,VK_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG:1000054002,VK_FORMAT_PVRTC2_4BPP_UNORM_BLOCK_IMG:1000054003,VK_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG:1000054004,VK_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG:1000054005,VK_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG:1000054006,VK_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG:1000054007,VK_FORMAT_ASTC_4x4_SFLOAT_BLOCK_EXT:1000066e3,VK_FORMAT_ASTC_5x4_SFLOAT_BLOCK_EXT:1000066001,VK_FORMAT_ASTC_5x5_SFLOAT_BLOCK_EXT:1000066002,VK_FORMAT_ASTC_6x5_SFLOAT_BLOCK_EXT:1000066003,VK_FORMAT_ASTC_6x6_SFLOAT_BLOCK_EXT:1000066004,VK_FORMAT_ASTC_8x5_SFLOAT_BLOCK_EXT:1000066005,VK_FORMAT_ASTC_8x6_SFLOAT_BLOCK_EXT:1000066006,VK_FORMAT_ASTC_8x8_SFLOAT_BLOCK_EXT:1000066007,VK_FORMAT_ASTC_10x5_SFLOAT_BLOCK_EXT:1000066008,VK_FORMAT_ASTC_10x6_SFLOAT_BLOCK_EXT:1000066009,VK_FORMAT_ASTC_10x8_SFLOAT_BLOCK_EXT:1000066010,VK_FORMAT_ASTC_10x10_SFLOAT_BLOCK_EXT:1000066011,VK_FORMAT_ASTC_12x10_SFLOAT_BLOCK_EXT:1000066012,VK_FORMAT_ASTC_12x12_SFLOAT_BLOCK_EXT:1000066013,VK_FORMAT_G8B8G8R8_422_UNORM_KHR:1000156e3,VK_FORMAT_B8G8R8G8_422_UNORM_KHR:1000156001,VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM_KHR:1000156002,VK_FORMAT_G8_B8R8_2PLANE_420_UNORM_KHR:1000156003,VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM_KHR:1000156004,VK_FORMAT_G8_B8R8_2PLANE_422_UNORM_KHR:1000156005,VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM_KHR:1000156006,VK_FORMAT_R10X6_UNORM_PACK16_KHR:1000156007,VK_FORMAT_R10X6G10X6_UNORM_2PACK16_KHR:1000156008,VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16_KHR:1000156009,VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16_KHR:1000156010,VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16_KHR:1000156011,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16_KHR:1000156012,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16_KHR:1000156013,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16_KHR:1000156014,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16_KHR:1000156015,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16_KHR:1000156016,VK_FORMAT_R12X4_UNORM_PACK16_KHR:1000156017,VK_FORMAT_R12X4G12X4_UNORM_2PACK16_KHR:1000156018,VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16_KHR:1000156019,VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16_KHR:1000156020,VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16_KHR:1000156021,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16_KHR:1000156022,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16_KHR:1000156023,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16_KHR:1000156024,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16_KHR:1000156025,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16_KHR:1000156026,VK_FORMAT_G16B16G16R16_422_UNORM_KHR:1000156027,VK_FORMAT_B16G16R16G16_422_UNORM_KHR:1000156028,VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM_KHR:1000156029,VK_FORMAT_G16_B16R16_2PLANE_420_UNORM_KHR:1000156030,VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM_KHR:1000156031,VK_FORMAT_G16_B16R16_2PLANE_422_UNORM_KHR:1000156032,VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM_KHR:1000156033},Zlt=Object.freeze(LLe);var APo=R(W(),1);function MLe(t){return t=f(t,f.EMPTY_OBJECT),HS.fromIonAssetId(2426648,{requestVertexNormals:f(t.requestVertexNormals,!1)})}var B5=MLe;var EPo=R(W(),1);function _Le(t){return t=f(t,f.EMPTY_OBJECT),HS.fromIonAssetId(1,{requestVertexNormals:f(t.requestVertexNormals,!1),requestWaterMask:f(t.requestWaterMask,!1)})}var KS=_Le;var NPo=R(W(),1);var DLe=1953029805,OLe=2917034100;function Vlt(t,e){if(Vlt.passThroughDataForTesting)return e;let n=t.byteLength;if(n===0||n%4!==0)throw new St("The length of key must be greater than 0 and a multiple of 4.");let i=new DataView(e),o=i.getUint32(0,!0);if(o===DLe||o===OLe)return e;let a=new DataView(t),s=0,l=e.byteLength,r=l-l%8,d=n,m,h=8;for(;s<r;)for(h=(h+8)%24,m=h;s<r&&m<d;)i.setUint32(s,i.getUint32(s,!0)^a.getUint32(m,!0),!0),i.setUint32(s+4,i.getUint32(s+4,!0)^a.getUint32(m+4,!0),!0),s+=8,m+=24;if(s<l)for(m>=d&&(h=(h+8)%24,m=h);s<l;)i.setUint8(s,i.getUint8(s)^a.getUint8(m)),s++,m++}Vlt.passThroughDataForTesting=!1;var Q5=Vlt;var YPo=R(W(),1);var HLe=new p;function wLe(t,e,n,i){let o=YG(t,e,n,i,HLe);return c(o)?o.x>0&&o.y>0&&o.z>0:!1}var blt=wLe;var JPo=R(W(),1);async function PLe(t,e,n,i){return c(i)||(i=!1),zLe(t,e,n,i)}function vLe(t,e,n){let i=t[0],o=i.terrainProvider.requestTileGeometry(i.x,i.y,i.level);if(!o)return!1;let a;return n?a=o.then(A2t(i)):a=o.then(A2t(i)).catch(jLe(i)),t.shift(),e.push(a),!0}function KLe(t){return new Promise(function(e){setTimeout(e,t)})}function Rlt(t,e,n){return t.length?vLe(t,e,n)?Rlt(t,e):KLe(100).then(()=>Rlt(t,e)):Promise.resolve()}function zLe(t,e,n,i){let o=t.tilingScheme,a,s=[],l={};for(a=0;a<n.length;++a){let d=o.positionToTileXY(n[a],e);if(!c(d))continue;let m=d.toString();if(!l.hasOwnProperty(m)){let h={x:d.x,y:d.y,level:e,tilingScheme:o,terrainProvider:t,positions:[]};l[m]=h,s.push(h)}l[m].positions.push(n[a])}let r=[];return Rlt(s,r,i).then(function(){return Promise.all(r).then(function(){return n})})}function G2t(t,e,n){let i=e.interpolateHeight(n,t.longitude,t.latitude);return i===void 0?!1:(t.height=i,!0)}function A2t(t){let e=t.positions,n=t.tilingScheme.tileXYToRectangle(t.x,t.y,t.level);return function(i){let o=!1;for(let a=0;a<e.length;++a){let s=e[a];if(!G2t(s,i,n)){o=!0;break}}return o?i.createMesh({tilingScheme:t.tilingScheme,x:t.x,y:t.y,level:t.level,throttle:!1}).then(function(){for(let a=0;a<e.length;++a){let s=e[a];G2t(s,i,n)}}):Promise.resolve()}}function jLe(t){let e=t.positions;return function(){for(let n=0;n<e.length;++n){let i=e[n];i.height=void 0}}}var k5=PLe;var OPo=R(W(),1);var Wlt=new K;async function T2t(t,e,n){c(n)||(n=!1);let i=[],o=[],a=t.availability,s=[];for(let r=0;r<e.length;++r){let d=e[r],m=a.computeMaximumLevelAtPosition(d);if(o[r]=m,m===0){t.tilingScheme.positionToTileXY(d,1,Wlt);let Z=t.loadTileDataAvailability(Wlt.x,Wlt.y,1);c(Z)&&s.push(Z)}let h=i[m];c(h)||(i[m]=h=[]),h.push(d)}await Promise.all(s),await Promise.all(i.map(function(r,d){if(c(r))return k5(t,d,r,n)}));let l=[];for(let r=0;r<e.length;++r){let d=e[r];a.computeMaximumLevelAtPosition(d)!==o[r]&&l.push(d)}return l.length>0&&await T2t(t,l,n),e}var zS=T2t;var wPo=R(W(),1);function qLe(t){return t<=.04045?t*.07739938080495357:Math.pow((t+.055)*.9478672985781991,2.4)}var jS=qLe;var KPo=R(W(),1);function $Le(t){switch(t){case pt.FLOAT:return"float";case pt.FLOAT_VEC2:return"vec2";case pt.FLOAT_VEC3:return"vec3";case pt.FLOAT_VEC4:return"vec4";case pt.FLOAT_MAT2:return"mat2";case pt.FLOAT_MAT3:return"mat3";case pt.FLOAT_MAT4:return"mat4";case pt.SAMPLER_2D:return"sampler2D";case pt.BOOL:return"bool"}}var flt=$Le;var jPo=R(W(),1);function tMe(t,e,n){return function(){n.apply(t,arguments),e.apply(t,arguments)}}var Y5=tMe;var nvo=R(W(),1);var eMe=new p(1,1,1);function Flt(t){t=f(t,eMe),this._dimensions=p.clone(t)}Object.defineProperties(Flt.prototype,{dimensions:{get:function(){return this._dimensions},set:function(t){p.clone(t,this._dimensions)}}});var nMe=new p;Flt.prototype.emit=function(t){let e=this._dimensions,n=p.multiplyByScalar(e,.5,nMe),i=k.randomBetween(-n.x,n.x),o=k.randomBetween(-n.y,n.y),a=k.randomBetween(-n.z,n.z);t.position=p.fromElements(i,o,a,t.position),t.velocity=p.normalize(t.position,t.velocity)};var Ult=Flt;var avo=R(W(),1);function jb(){this.featurePropertiesDirty=!1}Object.defineProperties(jb.prototype,{featuresLength:{get:function(){Ut.throwInstantiationError()}},pointsLength:{get:function(){Ut.throwInstantiationError()}},trianglesLength:{get:function(){Ut.throwInstantiationError()}},geometryByteLength:{get:function(){Ut.throwInstantiationError()}},texturesByteLength:{get:function(){Ut.throwInstantiationError()}},batchTableByteLength:{get:function(){Ut.throwInstantiationError()}},innerContents:{get:function(){Ut.throwInstantiationError()}},ready:{get:function(){Ut.throwInstantiationError()}},tileset:{get:function(){Ut.throwInstantiationError()}},tile:{get:function(){Ut.throwInstantiationError()}},url:{get:function(){Ut.throwInstantiationError()}},batchTable:{get:function(){Ut.throwInstantiationError()}},metadata:{get:function(){Ut.throwInstantiationError()},set:function(t){Ut.throwInstantiationError()}},group:{get:function(){Ut.throwInstantiationError()},set:function(t){Ut.throwInstantiationError()}}});jb.prototype.hasProperty=function(t,e){Ut.throwInstantiationError()};jb.prototype.getFeature=function(t){Ut.throwInstantiationError()};jb.prototype.applyDebugSettings=function(t,e){Ut.throwInstantiationError()};jb.prototype.applyStyle=function(t){Ut.throwInstantiationError()};jb.prototype.update=function(t,e){Ut.throwInstantiationError()};jb.prototype.pick=function(t,e,n){Ut.throwInstantiationError()};jb.prototype.isDestroyed=function(){Ut.throwInstantiationError()};jb.prototype.destroy=function(){Ut.throwInstantiationError()};var Glt=jb;var Rvo=R(W(),1);var cvo=R(W(),1);function cN(t,e){this._conditionsExpression=be(t,!0),this._conditions=t.conditions,this._runtimeConditions=void 0,oMe(this,e)}Object.defineProperties(cN.prototype,{conditionsExpression:{get:function(){return this._conditionsExpression}}});function iMe(t,e){this.condition=t,this.expression=e}function oMe(t,e){let n=[],i=t._conditions;if(!c(i))return;let o=i.length;for(let a=0;a<o;++a){let s=i[a],l=String(s[0]),r=String(s[1]);n.push(new iMe(new xp(l,e),new xp(r,e)))}t._runtimeConditions=n}cN.prototype.evaluate=function(t,e){let n=this._runtimeConditions;if(!c(n))return;let i=n.length;for(let o=0;o<i;++o){let a=n[o];if(a.condition.evaluate(t))return a.expression.evaluate(t,e)}};cN.prototype.evaluateColor=function(t,e){let n=this._runtimeConditions;if(!c(n))return;let i=n.length;for(let o=0;o<i;++o){let a=n[o];if(a.condition.evaluate(t))return a.expression.evaluateColor(t,e)}};cN.prototype.getShaderFunction=function(t,e,n,i){let o=this._runtimeConditions;if(!c(o)||o.length===0)return;let a="",s=o.length;for(let l=0;l<s;++l){let r=o[l],d=r.condition.getShaderExpression(e,n),m=r.expression.getShaderExpression(e,n);a+=` ${l===0?"if":"else if"} (${d}) +\x90\xDD\x9D\\\xDA\xDEQ\xCF\xF0\xFCYRe|3\xDF\xF3H\xDA\xBB*u\xDB\`\xB2\xD4\xFC\xED\x1B\xEC\x7F5\xA8\xFF(1\x07-\xC8\xDC\x88F|\x8A["`);function mp(t){this.imageryPresent=!0,this.protoImagery=void 0,this.terrainPresent=!0,this.negativeAltitudeExponentBias=32,this.negativeAltitudeThreshold=k.EPSILON12,this.providers={},this.key=void 0,this._resource=void 0,this._quadPacketVersion=1,this._tileInfo={},this._subtreePromises={}}Object.defineProperties(mp.prototype,{url:{get:function(){return this._resource.url}},proxy:{get:function(){return this._resource.proxy}},resource:{get:function(){return this._resource}}});mp.fromUrl=async function(t){let e=t;typeof e!="string"&&!(e instanceof te)&&(e=t.url);let n=te.createIfNeeded(e);n.appendForwardSlash();let i=new mp;i._resource=n;try{await ZLe(i),await i.getQuadTreePacket("",i._quadPacketVersion)}catch(o){let a=`An error occurred while accessing ${Vkt(i,"",1).url}: ${o}`;throw new Tt(a)}return i};mp.tileXYToQuadKey=function(t,e,n){let i="";for(let o=n;o>=0;--o){let a=1<<o,s=0;Zc(e,a)?Zc(t,a)&&(s|=1):(s|=2,Zc(t,a)||(s|=1)),i+=s}return i};mp.quadKeyToTileXY=function(t){let e=0,n=0,i=t.length-1;for(let o=i;o>=0;--o){let a=1<<o,s=+t[i-o];Zc(s,2)?Zc(s,1)||(e|=a):(n|=a,Zc(s,1)&&(e|=a))}return{x:e,y:n,level:i}};mp.prototype.isValid=function(t){let e=this.getTileInformationFromQuadKey(t);if(c(e))return e!==null;let n=!0,i=t,o;for(;i.length>1;)if(o=i.substring(i.length-1),i=i.substring(0,i.length-1),e=this.getTileInformationFromQuadKey(i),c(e)){!e.hasSubtree()&&!e.hasChild(parseInt(o))&&(n=!1);break}else if(e===null){n=!1;break}return n};var pkt=new $i("decodeGoogleEarthEnterprisePacket");mp.prototype.getQuadTreePacket=function(t,e,n){e=f(e,1),t=f(t,"");let o=Vkt(this,t,e,n).fetchArrayBuffer();if(!c(o))return;let a=this._tileInfo,s=this.key;return o.then(function(l){return pkt.scheduleTask({buffer:l,quadKey:t,type:"Metadata",key:s},[l]).then(function(d){let m,h=-1;if(t!==""){h=t.length+1;let V=d[t];m=a[t],m._bits|=V._bits,delete d[t]}let u=Object.keys(d);u.sort(function(V,F){return V.length-F.length});let R=u.length;for(let V=0;V<R;++V){let F=u[V];if(d[F]!==null){let G=E5.clone(d[F]),A=F.length;if(A===h)G.setParent(m);else if(A>1){let S=a[F.substring(0,F.length-1)];G.setParent(S)}a[F]=G}else a[F]=null}})})};mp.prototype.populateSubtree=function(t,e,n,i){let o=mp.tileXYToQuadKey(t,e,n);return Kst(this,o,i)};function Kst(t,e,n){let i=t._tileInfo,o=e,a=i[o];if(c(a)&&(!a.hasSubtree()||a.hasChildren()))return a;for(;a===void 0&&o.length>1;)o=o.substring(0,o.length-1),a=i[o];let s,l=t._subtreePromises,r=l[o];if(c(r))return r.then(function(){return s=new us({throttle:n.throttle,throttleByServer:n.throttleByServer,type:n.type,priorityFunction:n.priorityFunction}),Kst(t,e,s)});if(!c(a)||!a.hasSubtree())return Promise.reject(new Tt(`Couldn't load metadata for tile ${e}`));if(r=t.getQuadTreePacket(o,a.cnodeVersion,n),!!c(r))return l[o]=r,r.then(function(){return s=new us({throttle:n.throttle,throttleByServer:n.throttleByServer,type:n.type,priorityFunction:n.priorityFunction}),Kst(t,e,s)}).finally(function(){delete l[o]})}mp.prototype.getTileInformation=function(t,e,n){let i=mp.tileXYToQuadKey(t,e,n);return this._tileInfo[i]};mp.prototype.getTileInformationFromQuadKey=function(t){return this._tileInfo[t]};function Vkt(t,e,n,i){return t._resource.getDerivedResource({url:`flatfile?q2-0${e}-q.${n.toString()}`,request:i})}var Pst,vst;function ZLe(t){let e=t._resource.getDerivedResource({url:"dbRoot.v5",queryParameters:{output:"proto"}});if(!c(vst)){let n=Dn("ThirdParty/google-earth-dbroot-parser.js"),i=window.cesiumGoogleEarthDbRootParser;vst=ZG(n).then(function(){Pst=window.cesiumGoogleEarthDbRootParser(pLe),c(i)?window.cesiumGoogleEarthDbRootParser=i:delete window.cesiumGoogleEarthDbRootParser})}return vst.then(function(){return e.fetchArrayBuffer()}).then(function(n){let i=Pst.EncryptedDbRootProto.decode(new Uint8Array(n)),o=i.encryptionData,a=o.byteOffset,s=a+o.byteLength,l=t.key=o.buffer.slice(a,s);o=i.dbrootData,a=o.byteOffset,s=a+o.byteLength;let r=o.buffer.slice(a,s);return pkt.scheduleTask({buffer:r,type:"DbRoot",key:l},[r])}).then(function(n){let i=Pst.DbRootProto.decode(new Uint8Array(n.buffer));if(t.imageryPresent=f(i.imageryPresent,t.imageryPresent),t.protoImagery=i.protoImagery,t.terrainPresent=f(i.terrainPresent,t.terrainPresent),c(i.endSnippet)&&c(i.endSnippet.model)){let l=i.endSnippet.model;t.negativeAltitudeExponentBias=f(l.negativeAltitudeExponentBias,t.negativeAltitudeExponentBias),t.negativeAltitudeThreshold=f(l.compressedNegativeAltitudeThreshold,t.negativeAltitudeThreshold)}c(i.databaseVersion)&&(t._quadPacketVersion=f(i.databaseVersion.quadtreeVersion,t._quadPacketVersion));let o=t.providers,a=f(i.providerInfo,[]),s=a.length;for(let l=0;l<s;++l){let r=a[l],d=r.copyrightString;c(d)&&(o[r.providerId]=new on(d.value))}}).catch(function(){console.log(`Failed to retrieve ${e.url}. Using defaults.`),t.key=uLe})}var EW=mp;var cHo=b(W(),1);function wT(t){t=f(t,f.EMPTY_OBJECT),this._buffer=t.buffer,this._credits=t.credits,this._negativeAltitudeExponentBias=t.negativeAltitudeExponentBias,this._negativeElevationThreshold=t.negativeElevationThreshold;let e=f(t.childTileMask,15),n=e&3;n|=e&4?8:0,n|=e&8?4:0,this._childTileMask=n,this._createdByUpsampling=f(t.createdByUpsampling,!1),this._skirtHeight=void 0,this._bufferType=this._buffer.constructor,this._mesh=void 0,this._minimumHeight=void 0,this._maximumHeight=void 0}Object.defineProperties(wT.prototype,{credits:{get:function(){return this._credits}},waterMask:{get:function(){}}});var Rkt="createVerticesFromGoogleEarthEnterpriseBuffer",RLe=new $i(Rkt),bLe=new $i(Rkt,nZ.maximumAsynchronousTasks),ukt=new Gt,zst=new Gt;wT.prototype.createMesh=function(t){t=f(t,f.EMPTY_OBJECT);let e=t.tilingScheme,n=t.x,i=t.y,o=t.level,a=f(t.exaggeration,1),s=f(t.exaggerationRelativeHeight,0),l=f(t.throttle,!0),r=e.ellipsoid;e.tileXYToNativeRectangle(n,i,o,ukt),e.tileXYToRectangle(n,i,o,zst);let d=r.cartographicToCartesian(Gt.center(zst)),h=40075.16/(1<<o);this._skirtHeight=Math.min(h*8,1e3);let R=(l?bLe:RLe).scheduleTask({buffer:this._buffer,nativeRectangle:ukt,rectangle:zst,relativeToCenter:d,ellipsoid:r,skirtHeight:this._skirtHeight,exaggeration:a,exaggerationRelativeHeight:s,includeWebMercatorT:!0,negativeAltitudeExponentBias:this._negativeAltitudeExponentBias,negativeElevationThreshold:this._negativeElevationThreshold});if(!c(R))return;let V=this;return R.then(function(F){return V._mesh=new AV(d,new Float32Array(F.vertices),new Uint16Array(F.indices),F.indexCountWithoutSkirts,F.vertexCountWithoutSkirts,F.minimumHeight,F.maximumHeight,Ft.clone(F.boundingSphere3D),p.clone(F.occludeePointInScaledSpace),F.numberOfAttributes,ci.clone(F.orientedBoundingBox),lc.clone(F.encoding),F.westIndicesSouthToNorth,F.southIndicesEastToWest,F.eastIndicesNorthToSouth,F.northIndicesWestToEast),V._minimumHeight=F.minimumHeight,V._maximumHeight=F.maximumHeight,V._buffer=void 0,V._mesh})};wT.prototype.interpolateHeight=function(t,e,n){let i=k.clamp((e-t.west)/t.width,0,1),o=k.clamp((n-t.south)/t.height,0,1);return c(this._mesh)?GLe(this,i,o):TLe(this,i,o,t)};var WLe=new $i("upsampleQuantizedTerrainMesh",nZ.maximumAsynchronousTasks);wT.prototype.upsample=function(t,e,n,i,o,a,s){let l=this._mesh;if(!c(this._mesh))return;let r=e*2!==o,d=n*2===a,m=t.ellipsoid,h=t.tileXYToRectangle(o,a,s),u=WLe.scheduleTask({vertices:l.vertices,indices:l.indices,indexCountWithoutSkirts:l.indexCountWithoutSkirts,vertexCountWithoutSkirts:l.vertexCountWithoutSkirts,encoding:l.encoding,minimumHeight:this._minimumHeight,maximumHeight:this._maximumHeight,isEastChild:r,isNorthChild:d,childRectangle:h,ellipsoid:m});if(!c(u))return;let R=this;return u.then(function(V){let F=new Uint16Array(V.vertices),U=re.createTypedArray(F.length/3,V.indices),G=R._skirtHeight;return new OT({quantizedVertices:F,indices:U,minimumHeight:V.minimumHeight,maximumHeight:V.maximumHeight,boundingSphere:Ft.clone(V.boundingSphere),orientedBoundingBox:ci.clone(V.orientedBoundingBox),horizonOcclusionPoint:p.clone(V.horizonOcclusionPoint),westIndices:V.westIndices,southIndices:V.southIndices,eastIndices:V.eastIndices,northIndices:V.northIndices,westSkirtHeight:G,southSkirtHeight:G,eastSkirtHeight:G,northSkirtHeight:G,childTileMask:0,createdByUpsampling:!0,credits:R._credits})})};wT.prototype.isChildAvailable=function(t,e,n,i){let o=2;return n!==t*2&&++o,i!==e*2&&(o-=2),(this._childTileMask&1<<o)!==0};wT.prototype.wasCreatedByUpsampling=function(){return this._createdByUpsampling};var fLe=new K,FLe=new K,ULe=new K,bkt=new p;function GLe(t,e,n){let i=t._mesh,o=i.vertices,a=i.encoding,s=i.indices;for(let l=0,r=s.length;l<r;l+=3){let d=s[l],m=s[l+1],h=s[l+2],u=a.decodeTextureCoordinates(o,d,fLe),R=a.decodeTextureCoordinates(o,m,FLe),V=a.decodeTextureCoordinates(o,h,ULe),F=TW.computeBarycentricCoordinates(e,n,u.x,u.y,R.x,R.y,V.x,V.y,bkt);if(F.x>=-1e-15&&F.y>=-1e-15&&F.z>=-1e-15){let U=a.decodeHeight(o,d),G=a.decodeHeight(o,m),A=a.decodeHeight(o,h);return F.x*U+F.y*G+F.z*A}}}var ALe=Uint16Array.BYTES_PER_ELEMENT,Zkt=Uint32Array.BYTES_PER_ELEMENT,jst=Int32Array.BYTES_PER_ELEMENT,SLe=Float32Array.BYTES_PER_ELEMENT,qst=Float64Array.BYTES_PER_ELEMENT;function TLe(t,e,n,i){let o=t._buffer,a=0,s=0,l=0;n>.5?(e>.5?(a=2,s=.5):a=3,l=.5):e>.5&&(a=1,s=.5);let r=new DataView(o),d=0;for(let C=0;C<a;++C)d+=r.getUint32(d,!0),d+=Zkt;d+=Zkt,d+=2*qst;let m=k.toRadians(r.getFloat64(d,!0)*180);d+=qst;let h=k.toRadians(r.getFloat64(d,!0)*180);d+=qst;let u=i.width/m/2,R=i.height/h/2,V=r.getInt32(d,!0);d+=jst;let F=r.getInt32(d,!0)*3;d+=jst,d+=jst;let U=new Array(V),G=new Array(V),A=new Array(V),S;for(S=0;S<V;++S)U[S]=s+r.getUint8(d++)*u,G[S]=l+r.getUint8(d++)*R,A[S]=r.getFloat32(d,!0)*6371010,d+=SLe;let g=new Array(F);for(S=0;S<F;++S)g[S]=r.getUint16(d,!0),d+=ALe;for(S=0;S<F;S+=3){let C=g[S],y=g[S+1],Y=g[S+2],Q=U[C],J=U[y],M=U[Y],Z=G[C],E=G[y],I=G[Y],B=TW.computeBarycentricCoordinates(e,n,Q,Z,J,E,M,I,bkt);if(B.x>=-1e-15&&B.y>=-1e-15&&B.z>=-1e-15)return B.x*A[C]+B.y*A[y]+B.z*A[Y]}}var lN=wT;var EHo=b(W(),1);var QV={UNKNOWN:0,NONE:1,SELF:2,PARENT:3},Jj=new rt;function Lj(){this._terrainCache={},this._lastTidy=rt.now()}Lj.prototype.add=function(t,e){this._terrainCache[t]={buffer:e,timestamp:rt.now()}};Lj.prototype.get=function(t){let n=this._terrainCache[t];if(c(n))return delete this._terrainCache[t],n.buffer};Lj.prototype.tidy=function(){if(rt.now(Jj),rt.secondsDifference(Jj,this._lastTidy)>10){let t=this._terrainCache,e=Object.keys(t),n=e.length;for(let i=0;i<n;++i){let o=e[i],a=t[o];rt.secondsDifference(Jj,a.timestamp)>10&&delete t[o]}rt.clone(Jj,this._lastTidy)}};function NU(t){t=f(t,f.EMPTY_OBJECT),this._tilingScheme=new Qo({numberOfLevelZeroTilesX:2,numberOfLevelZeroTilesY:2,rectangle:new Gt(-k.PI,-k.PI,k.PI,k.PI),ellipsoid:t.ellipsoid});let e=t.credit;typeof e=="string"&&(e=new on(e)),this._credit=e,this._levelZeroMaximumGeometricError=40075.16,this._terrainCache=new Lj,this._terrainPromises={},this._terrainRequests={},this._errorEvent=new It}Object.defineProperties(NU.prototype,{url:{get:function(){return this._metadata.url}},proxy:{get:function(){return this._metadata.proxy}},tilingScheme:{get:function(){return this._tilingScheme}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasWaterMask:{get:function(){return!1}},hasVertexNormals:{get:function(){return!1}},availability:{get:function(){}}});NU.fromMetadata=function(t,e){if(!t.terrainPresent)throw new Tt(`The server ${t.url} doesn't have terrain`);let n=new NU(e);return n._metadata=t,n};var gLe=new $i("decodeGoogleEarthEnterprisePacket");function Wkt(t,e,n){let i=e.getChildBitmask();if(e.terrainState===QV.PARENT){i=0;for(let o=0;o<4;++o){let a=n.getTileInformationFromQuadKey(t+o.toString());c(a)&&a.hasTerrain()&&(i|=1<<o)}}return i}NU.prototype.requestTileGeometry=function(t,e,n,i){let o=EW.tileXYToQuadKey(t,e,n),a=this._terrainCache,s=this._metadata,l=s.getTileInformationFromQuadKey(o);if(!c(l))return Promise.reject(new Tt("Terrain tile doesn't exist"));let r=l.terrainState;c(r)||(r=l.terrainState=QV.UNKNOWN);let d=a.get(o);if(c(d)){let G=s.providers[l.terrainProvider];return Promise.resolve(new lN({buffer:d,childTileMask:Wkt(o,l,s),credits:c(G)?[G]:void 0,negativeAltitudeExponentBias:s.negativeAltitudeExponentBias,negativeElevationThreshold:s.negativeAltitudeThreshold}))}if(a.tidy(),l.ancestorHasTerrain){if(r===QV.NONE)return Promise.reject(new Tt("Terrain tile doesn't exist"))}else return Promise.resolve(new Gd({buffer:new Uint8Array(16*16),width:16,height:16}));let m,h=o,u=-1;switch(r){case QV.SELF:u=l.terrainVersion;break;case QV.PARENT:h=h.substring(0,h.length-1),m=s.getTileInformationFromQuadKey(h),u=m.terrainVersion;break;case QV.UNKNOWN:l.hasTerrain()?u=l.terrainVersion:(h=h.substring(0,h.length-1),m=s.getTileInformationFromQuadKey(h),c(m)&&m.hasTerrain()&&(u=m.terrainVersion));break}if(u<0)return Promise.reject(new Tt("Terrain tile doesn't exist"));let R=this._terrainPromises,V=this._terrainRequests,F,U;if(c(R[h]))F=R[h],U=V[h];else{U=i;let G=ELe(this,h,u,U).fetchArrayBuffer();if(!c(G))return;F=G.then(function(A){return c(A)?gLe.scheduleTask({buffer:A,type:"Terrain",key:s.key},[A]).then(function(S){let g=s.getTileInformationFromQuadKey(h);g.terrainState=QV.SELF,a.add(h,S[0]);let C=g.terrainProvider,y=S.length-1;for(let Y=0;Y<y;++Y){let Q=h+Y.toString(),J=s.getTileInformationFromQuadKey(Q);c(J)&&(a.add(Q,S[Y+1]),J.terrainState=QV.PARENT,J.terrainProvider===0&&(J.terrainProvider=C))}}):Promise.reject(new Tt("Failed to load terrain."))}),R[h]=F,V[h]=U,F=F.finally(function(){delete R[h],delete V[h]})}return F.then(function(){let G=a.get(o);if(c(G)){let A=s.providers[l.terrainProvider];return new lN({buffer:G,childTileMask:Wkt(o,l,s),credits:c(A)?[A]:void 0,negativeAltitudeExponentBias:s.negativeAltitudeExponentBias,negativeElevationThreshold:s.negativeAltitudeThreshold})}return Promise.reject(new Tt("Failed to load terrain."))}).catch(function(G){return U.state===qi.CANCELLED?(i.state=U.state,Promise.reject(G)):(l.terrainState=QV.NONE,Promise.reject(G))})};NU.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<<t)};NU.prototype.getTileDataAvailable=function(t,e,n){let i=this._metadata,o=EW.tileXYToQuadKey(t,e,n),a=i.getTileInformation(t,e,n);if(a===null)return!1;if(c(a)){if(!a.ancestorHasTerrain)return!0;let s=a.terrainState;if(s===QV.NONE)return!1;if((!c(s)||s===QV.UNKNOWN)&&(a.terrainState=QV.UNKNOWN,!a.hasTerrain())){o=o.substring(0,o.length-1);let l=i.getTileInformationFromQuadKey(o);if(!c(l)||!l.hasTerrain())return!1}return!0}if(i.isValid(o)){let s=new us({throttle:!1,throttleByServer:!0,type:Xl.TERRAIN});i.populateSubtree(t,e,n,s)}return!1};NU.prototype.loadTileDataAvailability=function(t,e,n){};function ELe(t,e,n,i){return n=c(n)&&n>0?n:1,t._metadata.resource.getDerivedResource({url:`flatfile?f1c-0${e}-t.${n.toString()}`,request:i})}var $st=NU;var yHo=b(W(),1);var Mj={};Mj.defaultApiKey=void 0;Mj.mapTilesApiEndpoint=new te({url:"https://tile.googleapis.com/v1/"});Mj.getDefaultCredit=function(){return new on('<img src="https://assets.ion-development.cesium.com/google-credit.png" alt="Google">',!0)};var PT=Mj;var kHo=b(W(),1);var C5={};C5.type=void 0;C5.getRequiredDataPoints=Ut.throwInstantiationError;C5.interpolateOrderZero=Ut.throwInstantiationError;C5.interpolate=Ut.throwInstantiationError;var tlt=C5;var zHo=b(W(),1);var _Ho=b(W(),1);function elt(t){this._url=te.createIfNeeded(t),this._url.appendForwardSlash()}Object.defineProperties(elt.prototype,{url:{get:function(){return this._url}},credit:{get:function(){}}});elt.prototype.geocode=async function(t,e){return this._url.getDerivedResource({url:e===IU.AUTOCOMPLETE?"autocomplete":"search",queryParameters:{text:t}}).fetchJson().then(function(i){return i.features.map(function(o){let a,s=o.bbox;if(c(s))a=Gt.fromDegrees(s[0],s[1],s[2],s[3]);else{let l=o.geometry.coordinates[0],r=o.geometry.coordinates[1];a=p.fromDegrees(l,r)}return{displayName:o.properties.label,destination:a,attributions:i.attributions}})})};var I5=elt;function nlt(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.accessToken,cu.defaultAccessToken),n=te.createIfNeeded(f(t.server,cu.defaultServer));n.appendForwardSlash();let i=cu.getDefaultTokenCredit(e);c(i)&&t.scene.frameState.creditDisplay.addStaticCredit(on.clone(i));let o=n.getDerivedResource({url:"v1/geocode"});c(e)&&o.appendQueryParameters({access_token:e}),this._accessToken=e,this._server=n,this._pelias=new I5(o)}Object.defineProperties(nlt.prototype,{credit:{get:function(){}}});nlt.prototype.geocode=async function(t,e){return this._pelias.geocode(t,e)};var N5=nlt;var $Ho=b(W(),1);function _j(){Ut.throwInstantiationError()}Object.defineProperties(_j.prototype,{ellipsoid:{get:Ut.throwInstantiationError}});_j.prototype.project=Ut.throwInstantiationError;_j.prototype.unproject=Ut.throwInstantiationError;var ilt=_j;var owo=b(W(),1);function rN(t){t=f(t,f.EMPTY_OBJECT);let e=t.weights,n=t.times;this._times=n,this._weights=e,this._count=e.length/n.length,this._lastTimeIndex=0}Object.defineProperties(rN.prototype,{times:{get:function(){return this._times}},weights:{get:function(){return this._weights}}});rN.prototype.findTimeInterval=Ra.prototype.findTimeInterval;rN.prototype.wrapTime=Ra.prototype.wrapTime;rN.prototype.clampTime=Ra.prototype.clampTime;rN.prototype.evaluate=function(t,e){let n=this.weights,i=this.times,o=this._lastTimeIndex=this.findTimeInterval(t,this._lastTimeIndex),a=(t-i[o])/(i[o+1]-i[o]);c(e)||(e=new Array(this._count));for(let s=0;s<this._count;s++){let l=o*this._count+s;e[s]=n[l]*(1-a)+n[l+this._count]*a}return e};var olt=rN;var pwo=b(W(),1);function alt(t,e,n){t=te.createIfNeeded(t),t.appendForwardSlash(),t.setQueryParameters({key:e}),this._url=t,this._params=f(n,{}),this._credit=new on('Geodata copyright <a href="https://www.openstreetmap.org/">OpenStreetMap</a> contributors',!1)}Object.defineProperties(alt.prototype,{url:{get:function(){return this._url}},params:{get:function(){return this._params}},credit:{get:function(){return this._credit}}});alt.prototype.geocode=async function(t){return this._url.getDerivedResource({url:"json",queryParameters:ze(this._params,{q:t})}).fetchJson().then(function(n){return n.results.map(function(i){let o,a=i.bounds;if(c(a))o=Gt.fromDegrees(a.southwest.lng,a.southwest.lat,a.northeast.lng,a.northeast.lat);else{let s=i.geometry.lat,l=i.geometry.lng;o=p.fromDegrees(s,l)}return{displayName:i.formatted,destination:o}})})};var slt=alt;var Zwo=b(W(),1);var CLe={packedLength:void 0,pack:Ut.throwInstantiationError,unpack:Ut.throwInstantiationError},llt=CLe;var Wwo=b(W(),1);var ILe={packedInterpolationLength:void 0,convertPackedArrayForInterpolation:Ut.throwInstantiationError,unpackInterpolationResult:Ut.throwInstantiationError},rlt=ILe;var Uwo=b(W(),1);function fkt(){Ut.throwInstantiationError()}fkt.prototype.getURL=Ut.throwInstantiationError;var dlt=fkt;var Jwo=b(W(),1);function NLe(t,e,n,i,o,a,s){let l=xo.numberOfPoints(t,e,o),r,d=n.red,m=n.green,h=n.blue,u=n.alpha,R=i.red,V=i.green,F=i.blue,U=i.alpha;if(v.equals(n,i)){for(r=0;r<l;r++)a[s++]=v.floatToByte(d),a[s++]=v.floatToByte(m),a[s++]=v.floatToByte(h),a[s++]=v.floatToByte(u);return s}let G=(R-d)/l,A=(V-m)/l,S=(F-h)/l,g=(U-u)/l,C=s;for(r=0;r<l;r++)a[C++]=v.floatToByte(d+r*G),a[C++]=v.floatToByte(m+r*A),a[C++]=v.floatToByte(h+r*S),a[C++]=v.floatToByte(u+r*g);return C}function y5(t){t=f(t,f.EMPTY_OBJECT);let e=t.positions,n=t.colors,i=f(t.colorsPerVertex,!1);this._positions=e,this._colors=n,this._colorsPerVertex=i,this._arcType=f(t.arcType,Ln.GEODESIC),this._granularity=f(t.granularity,k.RADIANS_PER_DEGREE),this._ellipsoid=f(t.ellipsoid,mt.WGS84),this._workerName="createSimplePolylineGeometry";let o=1+e.length*p.packedLength;o+=c(n)?1+n.length*v.packedLength:1,this.packedLength=o+mt.packedLength+3}y5.pack=function(t,e,n){n=f(n,0);let i,o=t._positions,a=o.length;for(e[n++]=a,i=0;i<a;++i,n+=p.packedLength)p.pack(o[i],e,n);let s=t._colors;for(a=c(s)?s.length:0,e[n++]=a,i=0;i<a;++i,n+=v.packedLength)v.pack(s[i],e,n);return mt.pack(t._ellipsoid,e,n),n+=mt.packedLength,e[n++]=t._colorsPerVertex?1:0,e[n++]=t._arcType,e[n]=t._granularity,e};y5.unpack=function(t,e,n){e=f(e,0);let i,o=t[e++],a=new Array(o);for(i=0;i<o;++i,e+=p.packedLength)a[i]=p.unpack(t,e);o=t[e++];let s=o>0?new Array(o):void 0;for(i=0;i<o;++i,e+=v.packedLength)s[i]=v.unpack(t,e);let l=mt.unpack(t,e);e+=mt.packedLength;let r=t[e++]===1,d=t[e++],m=t[e];return c(n)?(n._positions=a,n._colors=s,n._ellipsoid=l,n._colorsPerVertex=r,n._arcType=d,n._granularity=m,n):new y5({positions:a,colors:s,ellipsoid:l,colorsPerVertex:r,arcType:d,granularity:m})};var Dj=new Array(2),Oj=new Array(2),yLe={positions:Dj,height:Oj,ellipsoid:void 0,minDistance:void 0,granularity:void 0};y5.createGeometry=function(t){let e=t._positions,n=t._colors,i=t._colorsPerVertex,o=t._arcType,a=t._granularity,s=t._ellipsoid,l=k.chordLength(a,s.maximumRadius),r=c(n)&&!i,d,m=e.length,h,u,R,V,F=0;if(o===Ln.GEODESIC||o===Ln.RHUMB){let g,C,y;o===Ln.GEODESIC?(g=k.chordLength(a,s.maximumRadius),C=xo.numberOfPoints,y=xo.generateArc):(g=a,C=xo.numberOfPointsRhumbLine,y=xo.generateRhumbArc);let Y=xo.extractHeights(e,s),Q=yLe;if(o===Ln.GEODESIC?Q.minDistance=l:Q.granularity=a,Q.ellipsoid=s,r){let J=0;for(d=0;d<m-1;d++)J+=C(e[d],e[d+1],g)+1;h=new Float64Array(J*3),R=new Uint8Array(J*4),Q.positions=Dj,Q.height=Oj;let M=0;for(d=0;d<m-1;++d){Dj[0]=e[d],Dj[1]=e[d+1],Oj[0]=Y[d],Oj[1]=Y[d+1];let Z=y(Q);if(c(n)){let E=Z.length/3;V=n[d];for(let I=0;I<E;++I)R[M++]=v.floatToByte(V.red),R[M++]=v.floatToByte(V.green),R[M++]=v.floatToByte(V.blue),R[M++]=v.floatToByte(V.alpha)}h.set(Z,F),F+=Z.length}}else if(Q.positions=e,Q.height=Y,h=new Float64Array(y(Q)),c(n)){for(R=new Uint8Array(h.length/3*4),d=0;d<m-1;++d){let M=e[d],Z=e[d+1],E=n[d],I=n[d+1];F=NLe(M,Z,E,I,l,R,F)}let J=n[m-1];R[F++]=v.floatToByte(J.red),R[F++]=v.floatToByte(J.green),R[F++]=v.floatToByte(J.blue),R[F++]=v.floatToByte(J.alpha)}}else{u=r?m*2-2:m,h=new Float64Array(u*3),R=c(n)?new Uint8Array(u*4):void 0;let g=0,C=0;for(d=0;d<m;++d){let y=e[d];if(r&&d>0&&(p.pack(y,h,g),g+=3,V=n[d-1],R[C++]=v.floatToByte(V.red),R[C++]=v.floatToByte(V.green),R[C++]=v.floatToByte(V.blue),R[C++]=v.floatToByte(V.alpha)),r&&d===m-1)break;p.pack(y,h,g),g+=3,c(n)&&(V=n[d],R[C++]=v.floatToByte(V.red),R[C++]=v.floatToByte(V.green),R[C++]=v.floatToByte(V.blue),R[C++]=v.floatToByte(V.alpha))}}let U=new ei;U.position=new jt({componentDatatype:it.DOUBLE,componentsPerAttribute:3,values:h}),c(n)&&(U.color=new jt({componentDatatype:it.UNSIGNED_BYTE,componentsPerAttribute:4,values:R,normalize:!0})),u=h.length/3;let G=(u-1)*2,A=re.createTypedArray(u,G),S=0;for(d=0;d<u-1;++d)A[S++]=d,A[S++]=d+1;return new _e({attributes:U,indices:A,primitiveType:le.LINES,boundingSphere:Ft.fromPoints(e)})};var clt=y5;var wwo=b(W(),1);function dN(t){let e=f(t.radius,1),i={radii:new p(e,e,e),stackPartitions:t.stackPartitions,slicePartitions:t.slicePartitions,vertexFormat:t.vertexFormat};this._ellipsoidGeometry=new Cr(i),this._workerName="createSphereGeometry"}dN.packedLength=Cr.packedLength;dN.pack=function(t,e,n){return Cr.pack(t._ellipsoidGeometry,e,n)};var BLe=new Cr,yU={radius:void 0,radii:new p,vertexFormat:new ee,stackPartitions:void 0,slicePartitions:void 0};dN.unpack=function(t,e,n){let i=Cr.unpack(t,e,BLe);return yU.vertexFormat=ee.clone(i._vertexFormat,yU.vertexFormat),yU.stackPartitions=i._stackPartitions,yU.slicePartitions=i._slicePartitions,c(n)?(p.clone(i._radii,yU.radii),n._ellipsoidGeometry=new Cr(yU),n):(yU.radius=i._radii.x,new dN(yU))};dN.createGeometry=function(t){return Cr.createGeometry(t._ellipsoidGeometry)};var mlt=dN;var Kwo=b(W(),1);function BU(t){}Object.defineProperties(BU.prototype,{ellipsoid:{get:Ut.throwInstantiationError},rectangle:{get:Ut.throwInstantiationError},projection:{get:Ut.throwInstantiationError}});BU.prototype.getNumberOfXTilesAtLevel=Ut.throwInstantiationError;BU.prototype.getNumberOfYTilesAtLevel=Ut.throwInstantiationError;BU.prototype.rectangleToNativeRectangle=Ut.throwInstantiationError;BU.prototype.tileXYToNativeRectangle=Ut.throwInstantiationError;BU.prototype.tileXYToRectangle=Ut.throwInstantiationError;BU.prototype.positionToTileXY=Ut.throwInstantiationError;var hlt=BU;var mPo=b(W(),1);function QLe(t,e){this.rectangle=t,this.maxLevel=e}function Fkt(t){this.ellipsoid=f(t.ellipsoid,mt.WGS84),this.tilingScheme=void 0,this.heightmapWidth=void 0,this.heightmapHeight=void 0,this.levelZeroMaximumGeometricError=void 0,this.rectangles=[]}Fkt.prototype.build=function(t){t._tilingScheme=this.tilingScheme,t._heightmapWidth=this.heightmapWidth,t._heightmapHeight=this.heightmapHeight,t._levelZeroMaximumGeometricError=this.levelZeroMaximumGeometricError,t._rectangles=this.rectangles};function kLe(t,e){let n=e.getElementsByTagName("SRS")[0].textContent;if(n==="EPSG:4326")t.tilingScheme=new Qo({ellipsoid:t.ellipsoid});else throw new Tt(`SRS ${n} is not supported`);let i=e.getElementsByTagName("TileFormat")[0];t.heightmapWidth=parseInt(i.getAttribute("width"),10),t.heightmapHeight=parseInt(i.getAttribute("height"),10),t.levelZeroMaximumGeometricError=El.getEstimatedLevelZeroGeometricErrorForAHeightmap(t.ellipsoid,Math.min(t.heightmapWidth,t.heightmapHeight),t.tilingScheme.getNumberOfXTilesAtLevel(0));let o=e.getElementsByTagName("DataExtent");for(let a=0;a<o.length;++a){let s=o[a],l=k.toRadians(parseFloat(s.getAttribute("minx"))),r=k.toRadians(parseFloat(s.getAttribute("miny"))),d=k.toRadians(parseFloat(s.getAttribute("maxx"))),m=k.toRadians(parseFloat(s.getAttribute("maxy"))),h=parseInt(s.getAttribute("maxlevel"),10);t.rectangles.push(new QLe(new Gt(l,r,d,m),h))}}function YLe(t,e,n){let i=`An error occurred while accessing ${t.url}`;throw c(e)&&c(e.message)&&(i=`${i}: ${e.message}`),za.reportError(void 0,n,c(n)?n._errorEvent:void 0,i),new Tt(i)}async function xLe(t,e,n){try{let i=await e.fetchXML();kLe(t,i)}catch(i){YLe(e,i,n)}}function QU(t){t=f(t,f.EMPTY_OBJECT),this._errorEvent=new It,this._terrainDataStructure={heightScale:1/1e3,heightOffset:-1e3,elementsPerHeight:3,stride:4,elementMultiplier:256,isBigEndian:!0,lowestEncodedHeight:0,highestEncodedHeight:256*256*256-1};let e=t.credit;typeof e=="string"&&(e=new on(e)),this._credit=e,this._tilingScheme=void 0,this._rectangles=[]}Object.defineProperties(QU.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},tilingScheme:{get:function(){return this._tilingScheme}},hasWaterMask:{get:function(){return!1}},hasVertexNormals:{get:function(){return!1}},availability:{get:function(){}}});QU.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=new Fkt(e),i=te.createIfNeeded(t);await xLe(n,i);let o=new QU(e);return n.build(o),o._resource=i,o};QU.prototype.requestTileGeometry=function(t,e,n,i){let o=this._tilingScheme.getNumberOfYTilesAtLevel(n),s=this._resource.getDerivedResource({url:`${n}/${t}/${o-e-1}.tif`,queryParameters:{cesium:!0},request:i}).fetchImage({preferImageBitmap:!0});if(!c(s))return;let l=this;return Promise.resolve(s).then(function(r){return new Gd({buffer:vV(r),width:l._heightmapWidth,height:l._heightmapHeight,childTileMask:XLe(l,t,e,n),structure:l._terrainDataStructure})})};QU.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<<t)};var Ukt=new Gt;function XLe(t,e,n,i){let o=t._tilingScheme,a=t._rectangles,s=o.tileXYToRectangle(e,n,i),l=0;for(let r=0;r<a.length&&l!==15;++r){let d=a[r];if(d.maxLevel<=i)continue;let m=d.rectangle,h=Gt.intersection(m,s,Ukt);c(h)&&(Hj(o,m,e*2,n*2,i+1)&&(l|=4),Hj(o,m,e*2+1,n*2,i+1)&&(l|=8),Hj(o,m,e*2,n*2+1,i+1)&&(l|=1),Hj(o,m,e*2+1,n*2+1,i+1)&&(l|=2))}return l}function Hj(t,e,n,i,o){let a=t.tileXYToRectangle(n,i,o);return c(Gt.intersection(a,e,Ukt))}QU.prototype.getTileDataAvailable=function(t,e,n){};QU.prototype.loadTileDataAvailability=function(t,e,n){};var plt=QU;var bPo=b(W(),1);function vT(t){t=f(t,f.EMPTY_OBJECT),this._clock=void 0,this._element=void 0,this._clockSubscription=void 0,this._seekFunction=void 0,this._lastPlaybackRate=void 0,this.clock=t.clock,this.element=t.element,this.epoch=f(t.epoch,be.MINIMUM_VALUE),this.tolerance=f(t.tolerance,1),this._seeking=!1,this._seekFunction=void 0,this._firstTickAfterSeek=!1}Object.defineProperties(vT.prototype,{clock:{get:function(){return this._clock},set:function(t){let e=this._clock;e!==t&&(c(e)&&(this._clockSubscription(),this._clockSubscription=void 0),c(t)&&(this._clockSubscription=t.onTick.addEventListener(vT.prototype._onTick,this)),this._clock=t)}},element:{get:function(){return this._element},set:function(t){let e=this._element;e!==t&&(c(e)&&e.removeEventListener("seeked",this._seekFunction,!1),c(t)&&(this._seeking=!1,this._seekFunction=JLe(this),t.addEventListener("seeked",this._seekFunction,!1)),this._element=t,this._seeking=!1,this._firstTickAfterSeek=!1)}}});vT.prototype.destroy=function(){return this.element=void 0,this.clock=void 0,At(this)};vT.prototype.isDestroyed=function(){return!1};vT.prototype._trySetPlaybackRate=function(t){if(this._lastPlaybackRate===t.multiplier)return;let e=this._element;try{e.playbackRate=t.multiplier}catch{e.playbackRate=0}this._lastPlaybackRate=t.multiplier};vT.prototype._onTick=function(t){let e=this._element;if(!c(e)||e.readyState<2)return;let n=e.paused,i=t.shouldAnimate;if(i===n&&(i?e.play():e.pause()),this._seeking||this._firstTickAfterSeek){this._firstTickAfterSeek=!1;return}this._trySetPlaybackRate(t);let o=t.currentTime,a=f(this.epoch,be.MINIMUM_VALUE),s=rt.secondsDifference(o,a),l=e.duration,r,d=e.currentTime;e.loop?(s=s%l,s<0&&(s=l-s),r=s):s>l?r=l:s<0?r=0:r=s;let m=i?f(this.tolerance,1):.001;Math.abs(r-d)>m&&(this._seeking=!0,e.currentTime=r)};function JLe(t){return function(){t._seeking=!1,t._firstTickAfterSeek=!0}}var Vlt=vT;var fPo=b(W(),1),LLe={VK_FORMAT_UNDEFINED:0,VK_FORMAT_R4G4_UNORM_PACK8:1,VK_FORMAT_R4G4B4A4_UNORM_PACK16:2,VK_FORMAT_B4G4R4A4_UNORM_PACK16:3,VK_FORMAT_R5G6B5_UNORM_PACK16:4,VK_FORMAT_B5G6R5_UNORM_PACK16:5,VK_FORMAT_R5G5B5A1_UNORM_PACK16:6,VK_FORMAT_B5G5R5A1_UNORM_PACK16:7,VK_FORMAT_A1R5G5B5_UNORM_PACK16:8,VK_FORMAT_R8_UNORM:9,VK_FORMAT_R8_SNORM:10,VK_FORMAT_R8_USCALED:11,VK_FORMAT_R8_SSCALED:12,VK_FORMAT_R8_UINT:13,VK_FORMAT_R8_SINT:14,VK_FORMAT_R8_SRGB:15,VK_FORMAT_R8G8_UNORM:16,VK_FORMAT_R8G8_SNORM:17,VK_FORMAT_R8G8_USCALED:18,VK_FORMAT_R8G8_SSCALED:19,VK_FORMAT_R8G8_UINT:20,VK_FORMAT_R8G8_SINT:21,VK_FORMAT_R8G8_SRGB:22,VK_FORMAT_R8G8B8_UNORM:23,VK_FORMAT_R8G8B8_SNORM:24,VK_FORMAT_R8G8B8_USCALED:25,VK_FORMAT_R8G8B8_SSCALED:26,VK_FORMAT_R8G8B8_UINT:27,VK_FORMAT_R8G8B8_SINT:28,VK_FORMAT_R8G8B8_SRGB:29,VK_FORMAT_B8G8R8_UNORM:30,VK_FORMAT_B8G8R8_SNORM:31,VK_FORMAT_B8G8R8_USCALED:32,VK_FORMAT_B8G8R8_SSCALED:33,VK_FORMAT_B8G8R8_UINT:34,VK_FORMAT_B8G8R8_SINT:35,VK_FORMAT_B8G8R8_SRGB:36,VK_FORMAT_R8G8B8A8_UNORM:37,VK_FORMAT_R8G8B8A8_SNORM:38,VK_FORMAT_R8G8B8A8_USCALED:39,VK_FORMAT_R8G8B8A8_SSCALED:40,VK_FORMAT_R8G8B8A8_UINT:41,VK_FORMAT_R8G8B8A8_SINT:42,VK_FORMAT_R8G8B8A8_SRGB:43,VK_FORMAT_B8G8R8A8_UNORM:44,VK_FORMAT_B8G8R8A8_SNORM:45,VK_FORMAT_B8G8R8A8_USCALED:46,VK_FORMAT_B8G8R8A8_SSCALED:47,VK_FORMAT_B8G8R8A8_UINT:48,VK_FORMAT_B8G8R8A8_SINT:49,VK_FORMAT_B8G8R8A8_SRGB:50,VK_FORMAT_A8B8G8R8_UNORM_PACK32:51,VK_FORMAT_A8B8G8R8_SNORM_PACK32:52,VK_FORMAT_A8B8G8R8_USCALED_PACK32:53,VK_FORMAT_A8B8G8R8_SSCALED_PACK32:54,VK_FORMAT_A8B8G8R8_UINT_PACK32:55,VK_FORMAT_A8B8G8R8_SINT_PACK32:56,VK_FORMAT_A8B8G8R8_SRGB_PACK32:57,VK_FORMAT_A2R10G10B10_UNORM_PACK32:58,VK_FORMAT_A2R10G10B10_SNORM_PACK32:59,VK_FORMAT_A2R10G10B10_USCALED_PACK32:60,VK_FORMAT_A2R10G10B10_SSCALED_PACK32:61,VK_FORMAT_A2R10G10B10_UINT_PACK32:62,VK_FORMAT_A2R10G10B10_SINT_PACK32:63,VK_FORMAT_A2B10G10R10_UNORM_PACK32:64,VK_FORMAT_A2B10G10R10_SNORM_PACK32:65,VK_FORMAT_A2B10G10R10_USCALED_PACK32:66,VK_FORMAT_A2B10G10R10_SSCALED_PACK32:67,VK_FORMAT_A2B10G10R10_UINT_PACK32:68,VK_FORMAT_A2B10G10R10_SINT_PACK32:69,VK_FORMAT_R16_UNORM:70,VK_FORMAT_R16_SNORM:71,VK_FORMAT_R16_USCALED:72,VK_FORMAT_R16_SSCALED:73,VK_FORMAT_R16_UINT:74,VK_FORMAT_R16_SINT:75,VK_FORMAT_R16_SFLOAT:76,VK_FORMAT_R16G16_UNORM:77,VK_FORMAT_R16G16_SNORM:78,VK_FORMAT_R16G16_USCALED:79,VK_FORMAT_R16G16_SSCALED:80,VK_FORMAT_R16G16_UINT:81,VK_FORMAT_R16G16_SINT:82,VK_FORMAT_R16G16_SFLOAT:83,VK_FORMAT_R16G16B16_UNORM:84,VK_FORMAT_R16G16B16_SNORM:85,VK_FORMAT_R16G16B16_USCALED:86,VK_FORMAT_R16G16B16_SSCALED:87,VK_FORMAT_R16G16B16_UINT:88,VK_FORMAT_R16G16B16_SINT:89,VK_FORMAT_R16G16B16_SFLOAT:90,VK_FORMAT_R16G16B16A16_UNORM:91,VK_FORMAT_R16G16B16A16_SNORM:92,VK_FORMAT_R16G16B16A16_USCALED:93,VK_FORMAT_R16G16B16A16_SSCALED:94,VK_FORMAT_R16G16B16A16_UINT:95,VK_FORMAT_R16G16B16A16_SINT:96,VK_FORMAT_R16G16B16A16_SFLOAT:97,VK_FORMAT_R32_UINT:98,VK_FORMAT_R32_SINT:99,VK_FORMAT_R32_SFLOAT:100,VK_FORMAT_R32G32_UINT:101,VK_FORMAT_R32G32_SINT:102,VK_FORMAT_R32G32_SFLOAT:103,VK_FORMAT_R32G32B32_UINT:104,VK_FORMAT_R32G32B32_SINT:105,VK_FORMAT_R32G32B32_SFLOAT:106,VK_FORMAT_R32G32B32A32_UINT:107,VK_FORMAT_R32G32B32A32_SINT:108,VK_FORMAT_R32G32B32A32_SFLOAT:109,VK_FORMAT_R64_UINT:110,VK_FORMAT_R64_SINT:111,VK_FORMAT_R64_SFLOAT:112,VK_FORMAT_R64G64_UINT:113,VK_FORMAT_R64G64_SINT:114,VK_FORMAT_R64G64_SFLOAT:115,VK_FORMAT_R64G64B64_UINT:116,VK_FORMAT_R64G64B64_SINT:117,VK_FORMAT_R64G64B64_SFLOAT:118,VK_FORMAT_R64G64B64A64_UINT:119,VK_FORMAT_R64G64B64A64_SINT:120,VK_FORMAT_R64G64B64A64_SFLOAT:121,VK_FORMAT_B10G11R11_UFLOAT_PACK32:122,VK_FORMAT_E5B9G9R9_UFLOAT_PACK32:123,VK_FORMAT_D16_UNORM:124,VK_FORMAT_X8_D24_UNORM_PACK32:125,VK_FORMAT_D32_SFLOAT:126,VK_FORMAT_S8_UINT:127,VK_FORMAT_D16_UNORM_S8_UINT:128,VK_FORMAT_D24_UNORM_S8_UINT:129,VK_FORMAT_D32_SFLOAT_S8_UINT:130,VK_FORMAT_BC1_RGB_UNORM_BLOCK:131,VK_FORMAT_BC1_RGB_SRGB_BLOCK:132,VK_FORMAT_BC1_RGBA_UNORM_BLOCK:133,VK_FORMAT_BC1_RGBA_SRGB_BLOCK:134,VK_FORMAT_BC2_UNORM_BLOCK:135,VK_FORMAT_BC2_SRGB_BLOCK:136,VK_FORMAT_BC3_UNORM_BLOCK:137,VK_FORMAT_BC3_SRGB_BLOCK:138,VK_FORMAT_BC4_UNORM_BLOCK:139,VK_FORMAT_BC4_SNORM_BLOCK:140,VK_FORMAT_BC5_UNORM_BLOCK:141,VK_FORMAT_BC5_SNORM_BLOCK:142,VK_FORMAT_BC6H_UFLOAT_BLOCK:143,VK_FORMAT_BC6H_SFLOAT_BLOCK:144,VK_FORMAT_BC7_UNORM_BLOCK:145,VK_FORMAT_BC7_SRGB_BLOCK:146,VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK:147,VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK:148,VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK:149,VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK:150,VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK:151,VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK:152,VK_FORMAT_EAC_R11_UNORM_BLOCK:153,VK_FORMAT_EAC_R11_SNORM_BLOCK:154,VK_FORMAT_EAC_R11G11_UNORM_BLOCK:155,VK_FORMAT_EAC_R11G11_SNORM_BLOCK:156,VK_FORMAT_ASTC_4x4_UNORM_BLOCK:157,VK_FORMAT_ASTC_4x4_SRGB_BLOCK:158,VK_FORMAT_ASTC_5x4_UNORM_BLOCK:159,VK_FORMAT_ASTC_5x4_SRGB_BLOCK:160,VK_FORMAT_ASTC_5x5_UNORM_BLOCK:161,VK_FORMAT_ASTC_5x5_SRGB_BLOCK:162,VK_FORMAT_ASTC_6x5_UNORM_BLOCK:163,VK_FORMAT_ASTC_6x5_SRGB_BLOCK:164,VK_FORMAT_ASTC_6x6_UNORM_BLOCK:165,VK_FORMAT_ASTC_6x6_SRGB_BLOCK:166,VK_FORMAT_ASTC_8x5_UNORM_BLOCK:167,VK_FORMAT_ASTC_8x5_SRGB_BLOCK:168,VK_FORMAT_ASTC_8x6_UNORM_BLOCK:169,VK_FORMAT_ASTC_8x6_SRGB_BLOCK:170,VK_FORMAT_ASTC_8x8_UNORM_BLOCK:171,VK_FORMAT_ASTC_8x8_SRGB_BLOCK:172,VK_FORMAT_ASTC_10x5_UNORM_BLOCK:173,VK_FORMAT_ASTC_10x5_SRGB_BLOCK:174,VK_FORMAT_ASTC_10x6_UNORM_BLOCK:175,VK_FORMAT_ASTC_10x6_SRGB_BLOCK:176,VK_FORMAT_ASTC_10x8_UNORM_BLOCK:177,VK_FORMAT_ASTC_10x8_SRGB_BLOCK:178,VK_FORMAT_ASTC_10x10_UNORM_BLOCK:179,VK_FORMAT_ASTC_10x10_SRGB_BLOCK:180,VK_FORMAT_ASTC_12x10_UNORM_BLOCK:181,VK_FORMAT_ASTC_12x10_SRGB_BLOCK:182,VK_FORMAT_ASTC_12x12_UNORM_BLOCK:183,VK_FORMAT_ASTC_12x12_SRGB_BLOCK:184,VK_FORMAT_G8B8G8R8_422_UNORM:1000156e3,VK_FORMAT_B8G8R8G8_422_UNORM:1000156001,VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM:1000156002,VK_FORMAT_G8_B8R8_2PLANE_420_UNORM:1000156003,VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM:1000156004,VK_FORMAT_G8_B8R8_2PLANE_422_UNORM:1000156005,VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM:1000156006,VK_FORMAT_R10X6_UNORM_PACK16:1000156007,VK_FORMAT_R10X6G10X6_UNORM_2PACK16:1000156008,VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16:1000156009,VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16:1000156010,VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16:1000156011,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16:1000156012,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16:1000156013,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16:1000156014,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16:1000156015,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16:1000156016,VK_FORMAT_R12X4_UNORM_PACK16:1000156017,VK_FORMAT_R12X4G12X4_UNORM_2PACK16:1000156018,VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16:1000156019,VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16:1000156020,VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16:1000156021,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16:1000156022,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16:1000156023,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16:1000156024,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16:1000156025,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16:1000156026,VK_FORMAT_G16B16G16R16_422_UNORM:1000156027,VK_FORMAT_B16G16R16G16_422_UNORM:1000156028,VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM:1000156029,VK_FORMAT_G16_B16R16_2PLANE_420_UNORM:1000156030,VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM:1000156031,VK_FORMAT_G16_B16R16_2PLANE_422_UNORM:1000156032,VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM:1000156033,VK_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG:1000054e3,VK_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG:1000054001,VK_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG:1000054002,VK_FORMAT_PVRTC2_4BPP_UNORM_BLOCK_IMG:1000054003,VK_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG:1000054004,VK_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG:1000054005,VK_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG:1000054006,VK_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG:1000054007,VK_FORMAT_ASTC_4x4_SFLOAT_BLOCK_EXT:1000066e3,VK_FORMAT_ASTC_5x4_SFLOAT_BLOCK_EXT:1000066001,VK_FORMAT_ASTC_5x5_SFLOAT_BLOCK_EXT:1000066002,VK_FORMAT_ASTC_6x5_SFLOAT_BLOCK_EXT:1000066003,VK_FORMAT_ASTC_6x6_SFLOAT_BLOCK_EXT:1000066004,VK_FORMAT_ASTC_8x5_SFLOAT_BLOCK_EXT:1000066005,VK_FORMAT_ASTC_8x6_SFLOAT_BLOCK_EXT:1000066006,VK_FORMAT_ASTC_8x8_SFLOAT_BLOCK_EXT:1000066007,VK_FORMAT_ASTC_10x5_SFLOAT_BLOCK_EXT:1000066008,VK_FORMAT_ASTC_10x6_SFLOAT_BLOCK_EXT:1000066009,VK_FORMAT_ASTC_10x8_SFLOAT_BLOCK_EXT:1000066010,VK_FORMAT_ASTC_10x10_SFLOAT_BLOCK_EXT:1000066011,VK_FORMAT_ASTC_12x10_SFLOAT_BLOCK_EXT:1000066012,VK_FORMAT_ASTC_12x12_SFLOAT_BLOCK_EXT:1000066013,VK_FORMAT_G8B8G8R8_422_UNORM_KHR:1000156e3,VK_FORMAT_B8G8R8G8_422_UNORM_KHR:1000156001,VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM_KHR:1000156002,VK_FORMAT_G8_B8R8_2PLANE_420_UNORM_KHR:1000156003,VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM_KHR:1000156004,VK_FORMAT_G8_B8R8_2PLANE_422_UNORM_KHR:1000156005,VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM_KHR:1000156006,VK_FORMAT_R10X6_UNORM_PACK16_KHR:1000156007,VK_FORMAT_R10X6G10X6_UNORM_2PACK16_KHR:1000156008,VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16_KHR:1000156009,VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16_KHR:1000156010,VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16_KHR:1000156011,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16_KHR:1000156012,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16_KHR:1000156013,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16_KHR:1000156014,VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16_KHR:1000156015,VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16_KHR:1000156016,VK_FORMAT_R12X4_UNORM_PACK16_KHR:1000156017,VK_FORMAT_R12X4G12X4_UNORM_2PACK16_KHR:1000156018,VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16_KHR:1000156019,VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16_KHR:1000156020,VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16_KHR:1000156021,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16_KHR:1000156022,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16_KHR:1000156023,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16_KHR:1000156024,VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16_KHR:1000156025,VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16_KHR:1000156026,VK_FORMAT_G16B16G16R16_422_UNORM_KHR:1000156027,VK_FORMAT_B16G16R16G16_422_UNORM_KHR:1000156028,VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM_KHR:1000156029,VK_FORMAT_G16_B16R16_2PLANE_420_UNORM_KHR:1000156030,VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM_KHR:1000156031,VK_FORMAT_G16_B16R16_2PLANE_422_UNORM_KHR:1000156032,VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM_KHR:1000156033},ult=Object.freeze(LLe);var APo=b(W(),1);function MLe(t){return t=f(t,f.EMPTY_OBJECT),HT.fromIonAssetId(2426648,{requestVertexNormals:f(t.requestVertexNormals,!1)})}var B5=MLe;var EPo=b(W(),1);function _Le(t){return t=f(t,f.EMPTY_OBJECT),HT.fromIonAssetId(1,{requestVertexNormals:f(t.requestVertexNormals,!1),requestWaterMask:f(t.requestWaterMask,!1)})}var KT=_Le;var NPo=b(W(),1);var DLe=1953029805,OLe=2917034100;function Zlt(t,e){if(Zlt.passThroughDataForTesting)return e;let n=t.byteLength;if(n===0||n%4!==0)throw new Tt("The length of key must be greater than 0 and a multiple of 4.");let i=new DataView(e),o=i.getUint32(0,!0);if(o===DLe||o===OLe)return e;let a=new DataView(t),s=0,l=e.byteLength,r=l-l%8,d=n,m,h=8;for(;s<r;)for(h=(h+8)%24,m=h;s<r&&m<d;)i.setUint32(s,i.getUint32(s,!0)^a.getUint32(m,!0),!0),i.setUint32(s+4,i.getUint32(s+4,!0)^a.getUint32(m+4,!0),!0),s+=8,m+=24;if(s<l)for(m>=d&&(h=(h+8)%24,m=h);s<l;)i.setUint8(s,i.getUint8(s)^a.getUint8(m)),s++,m++}Zlt.passThroughDataForTesting=!1;var Q5=Zlt;var YPo=b(W(),1);var HLe=new p;function wLe(t,e,n,i){let o=YG(t,e,n,i,HLe);return c(o)?o.x>0&&o.y>0&&o.z>0:!1}var Rlt=wLe;var JPo=b(W(),1);async function PLe(t,e,n,i){return c(i)||(i=!1),zLe(t,e,n,i)}function vLe(t,e,n){let i=t[0],o=i.terrainProvider.requestTileGeometry(i.x,i.y,i.level);if(!o)return!1;let a;return n?a=o.then(Akt(i)):a=o.then(Akt(i)).catch(jLe(i)),t.shift(),e.push(a),!0}function KLe(t){return new Promise(function(e){setTimeout(e,t)})}function blt(t,e,n){return t.length?vLe(t,e,n)?blt(t,e):KLe(100).then(()=>blt(t,e)):Promise.resolve()}function zLe(t,e,n,i){let o=t.tilingScheme,a,s=[],l={};for(a=0;a<n.length;++a){let d=o.positionToTileXY(n[a],e);if(!c(d))continue;let m=d.toString();if(!l.hasOwnProperty(m)){let h={x:d.x,y:d.y,level:e,tilingScheme:o,terrainProvider:t,positions:[]};l[m]=h,s.push(h)}l[m].positions.push(n[a])}let r=[];return blt(s,r,i).then(function(){return Promise.all(r).then(function(){return n})})}function Gkt(t,e,n){let i=e.interpolateHeight(n,t.longitude,t.latitude);return i===void 0?!1:(t.height=i,!0)}function Akt(t){let e=t.positions,n=t.tilingScheme.tileXYToRectangle(t.x,t.y,t.level);return function(i){let o=!1;for(let a=0;a<e.length;++a){let s=e[a];if(!Gkt(s,i,n)){o=!0;break}}return o?i.createMesh({tilingScheme:t.tilingScheme,x:t.x,y:t.y,level:t.level,throttle:!1}).then(function(){for(let a=0;a<e.length;++a){let s=e[a];Gkt(s,i,n)}}):Promise.resolve()}}function jLe(t){let e=t.positions;return function(){for(let n=0;n<e.length;++n){let i=e[n];i.height=void 0}}}var k5=PLe;var OPo=b(W(),1);var Wlt=new K;async function Skt(t,e,n){c(n)||(n=!1);let i=[],o=[],a=t.availability,s=[];for(let r=0;r<e.length;++r){let d=e[r],m=a.computeMaximumLevelAtPosition(d);if(o[r]=m,m===0){t.tilingScheme.positionToTileXY(d,1,Wlt);let u=t.loadTileDataAvailability(Wlt.x,Wlt.y,1);c(u)&&s.push(u)}let h=i[m];c(h)||(i[m]=h=[]),h.push(d)}await Promise.all(s),await Promise.all(i.map(function(r,d){if(c(r))return k5(t,d,r,n)}));let l=[];for(let r=0;r<e.length;++r){let d=e[r];a.computeMaximumLevelAtPosition(d)!==o[r]&&l.push(d)}return l.length>0&&await Skt(t,l,n),e}var zT=Skt;var wPo=b(W(),1);function qLe(t){return t<=.04045?t*.07739938080495357:Math.pow((t+.055)*.9478672985781991,2.4)}var jT=qLe;var KPo=b(W(),1);function $Le(t){switch(t){case pt.FLOAT:return"float";case pt.FLOAT_VEC2:return"vec2";case pt.FLOAT_VEC3:return"vec3";case pt.FLOAT_VEC4:return"vec4";case pt.FLOAT_MAT2:return"mat2";case pt.FLOAT_MAT3:return"mat3";case pt.FLOAT_MAT4:return"mat4";case pt.SAMPLER_2D:return"sampler2D";case pt.BOOL:return"bool"}}var flt=$Le;var jPo=b(W(),1);function tMe(t,e,n){return function(){n.apply(t,arguments),e.apply(t,arguments)}}var Y5=tMe;var nvo=b(W(),1);var eMe=new p(1,1,1);function Flt(t){t=f(t,eMe),this._dimensions=p.clone(t)}Object.defineProperties(Flt.prototype,{dimensions:{get:function(){return this._dimensions},set:function(t){p.clone(t,this._dimensions)}}});var nMe=new p;Flt.prototype.emit=function(t){let e=this._dimensions,n=p.multiplyByScalar(e,.5,nMe),i=k.randomBetween(-n.x,n.x),o=k.randomBetween(-n.y,n.y),a=k.randomBetween(-n.z,n.z);t.position=p.fromElements(i,o,a,t.position),t.velocity=p.normalize(t.position,t.velocity)};var Ult=Flt;var avo=b(W(),1);function jR(){this.featurePropertiesDirty=!1}Object.defineProperties(jR.prototype,{featuresLength:{get:function(){Ut.throwInstantiationError()}},pointsLength:{get:function(){Ut.throwInstantiationError()}},trianglesLength:{get:function(){Ut.throwInstantiationError()}},geometryByteLength:{get:function(){Ut.throwInstantiationError()}},texturesByteLength:{get:function(){Ut.throwInstantiationError()}},batchTableByteLength:{get:function(){Ut.throwInstantiationError()}},innerContents:{get:function(){Ut.throwInstantiationError()}},ready:{get:function(){Ut.throwInstantiationError()}},tileset:{get:function(){Ut.throwInstantiationError()}},tile:{get:function(){Ut.throwInstantiationError()}},url:{get:function(){Ut.throwInstantiationError()}},batchTable:{get:function(){Ut.throwInstantiationError()}},metadata:{get:function(){Ut.throwInstantiationError()},set:function(t){Ut.throwInstantiationError()}},group:{get:function(){Ut.throwInstantiationError()},set:function(t){Ut.throwInstantiationError()}}});jR.prototype.hasProperty=function(t,e){Ut.throwInstantiationError()};jR.prototype.getFeature=function(t){Ut.throwInstantiationError()};jR.prototype.applyDebugSettings=function(t,e){Ut.throwInstantiationError()};jR.prototype.applyStyle=function(t){Ut.throwInstantiationError()};jR.prototype.update=function(t,e){Ut.throwInstantiationError()};jR.prototype.pick=function(t,e,n){Ut.throwInstantiationError()};jR.prototype.isDestroyed=function(){Ut.throwInstantiationError()};jR.prototype.destroy=function(){Ut.throwInstantiationError()};var Glt=jR;var bvo=b(W(),1);var cvo=b(W(),1);function cN(t,e){this._conditionsExpression=Re(t,!0),this._conditions=t.conditions,this._runtimeConditions=void 0,oMe(this,e)}Object.defineProperties(cN.prototype,{conditionsExpression:{get:function(){return this._conditionsExpression}}});function iMe(t,e){this.condition=t,this.expression=e}function oMe(t,e){let n=[],i=t._conditions;if(!c(i))return;let o=i.length;for(let a=0;a<o;++a){let s=i[a],l=String(s[0]),r=String(s[1]);n.push(new iMe(new xp(l,e),new xp(r,e)))}t._runtimeConditions=n}cN.prototype.evaluate=function(t,e){let n=this._runtimeConditions;if(!c(n))return;let i=n.length;for(let o=0;o<i;++o){let a=n[o];if(a.condition.evaluate(t))return a.expression.evaluate(t,e)}};cN.prototype.evaluateColor=function(t,e){let n=this._runtimeConditions;if(!c(n))return;let i=n.length;for(let o=0;o<i;++o){let a=n[o];if(a.condition.evaluate(t))return a.expression.evaluateColor(t,e)}};cN.prototype.getShaderFunction=function(t,e,n,i){let o=this._runtimeConditions;if(!c(o)||o.length===0)return;let a="",s=o.length;for(let l=0;l<s;++l){let r=o[l],d=r.condition.getShaderExpression(e,n),m=r.expression.getShaderExpression(e,n);a+=` ${l===0?"if":"else if"} (${d}) { return ${m}; } @@ -15307,7 +15307,7 @@ ZGM&30x\xDA\xC0\x9CFG\xE2[y\`In7gS { ${a} return ${i}(1.0); } -`,a};cN.prototype.getVariables=function(){let t=[],e=this._runtimeConditions;if(!c(e)||e.length===0)return t;let n=e.length;for(let i=0;i<n;++i){let o=e[i];t.push.apply(t,o.condition.getVariables()),t.push.apply(t,o.expression.getVariables())}return t=t.filter(function(i,o,a){return a.indexOf(i)===o}),t};var x5=cN;function kU(t){this._style={},this._ready=!1,this._show=void 0,this._color=void 0,this._pointSize=void 0,this._pointOutlineColor=void 0,this._pointOutlineWidth=void 0,this._labelColor=void 0,this._labelOutlineColor=void 0,this._labelOutlineWidth=void 0,this._font=void 0,this._labelStyle=void 0,this._labelText=void 0,this._backgroundColor=void 0,this._backgroundPadding=void 0,this._backgroundEnabled=void 0,this._scaleByDistance=void 0,this._translucencyByDistance=void 0,this._distanceDisplayCondition=void 0,this._heightOffset=void 0,this._anchorLineEnabled=void 0,this._anchorLineColor=void 0,this._image=void 0,this._disableDepthTestDistance=void 0,this._horizontalOrigin=void 0,this._verticalOrigin=void 0,this._labelHorizontalOrigin=void 0,this._labelVerticalOrigin=void 0,this._meta=void 0,this._colorShaderFunction=void 0,this._showShaderFunction=void 0,this._pointSizeShaderFunction=void 0,this._colorShaderFunctionReady=!1,this._showShaderFunctionReady=!1,this._pointSizeShaderFunctionReady=!1,this._colorShaderTranslucent=!1,aMe(this,t)}function aMe(t,e){e=f(be(e,!0),t._style),t._style=e,t.show=e.show,t.color=e.color,t.pointSize=e.pointSize,t.pointOutlineColor=e.pointOutlineColor,t.pointOutlineWidth=e.pointOutlineWidth,t.labelColor=e.labelColor,t.labelOutlineColor=e.labelOutlineColor,t.labelOutlineWidth=e.labelOutlineWidth,t.labelStyle=e.labelStyle,t.font=e.font,t.labelText=e.labelText,t.backgroundColor=e.backgroundColor,t.backgroundPadding=e.backgroundPadding,t.backgroundEnabled=e.backgroundEnabled,t.scaleByDistance=e.scaleByDistance,t.translucencyByDistance=e.translucencyByDistance,t.distanceDisplayCondition=e.distanceDisplayCondition,t.heightOffset=e.heightOffset,t.anchorLineEnabled=e.anchorLineEnabled,t.anchorLineColor=e.anchorLineColor,t.image=e.image,t.disableDepthTestDistance=e.disableDepthTestDistance,t.horizontalOrigin=e.horizontalOrigin,t.verticalOrigin=e.verticalOrigin,t.labelHorizontalOrigin=e.labelHorizontalOrigin,t.labelVerticalOrigin=e.labelVerticalOrigin;let n={};if(c(e.meta)){let i=e.defines,o=f(e.meta,f.EMPTY_OBJECT);for(let a in o)o.hasOwnProperty(a)&&(n[a]=new xp(o[a],i))}t._meta=n,t._ready=!0}function Ts(t,e){let n=f(t._style,f.EMPTY_OBJECT).defines;if(c(e)){if(typeof e=="boolean"||typeof e=="number")return new xp(String(e));if(typeof e=="string")return new xp(e,n);if(c(e.conditions))return new x5(e,n)}else return;return e}function Ss(t){if(c(t)){if(c(t.expression))return t.expression;if(c(t.conditionsExpression))return be(t.conditionsExpression,!0)}else return;return t}Object.defineProperties(kU.prototype,{style:{get:function(){return this._style}},show:{get:function(){return this._show},set:function(t){this._show=Ts(this,t),this._style.show=Ss(this._show),this._showShaderFunctionReady=!1}},color:{get:function(){return this._color},set:function(t){this._color=Ts(this,t),this._style.color=Ss(this._color),this._colorShaderFunctionReady=!1}},pointSize:{get:function(){return this._pointSize},set:function(t){this._pointSize=Ts(this,t),this._style.pointSize=Ss(this._pointSize),this._pointSizeShaderFunctionReady=!1}},pointOutlineColor:{get:function(){return this._pointOutlineColor},set:function(t){this._pointOutlineColor=Ts(this,t),this._style.pointOutlineColor=Ss(this._pointOutlineColor)}},pointOutlineWidth:{get:function(){return this._pointOutlineWidth},set:function(t){this._pointOutlineWidth=Ts(this,t),this._style.pointOutlineWidth=Ss(this._pointOutlineWidth)}},labelColor:{get:function(){return this._labelColor},set:function(t){this._labelColor=Ts(this,t),this._style.labelColor=Ss(this._labelColor)}},labelOutlineColor:{get:function(){return this._labelOutlineColor},set:function(t){this._labelOutlineColor=Ts(this,t),this._style.labelOutlineColor=Ss(this._labelOutlineColor)}},labelOutlineWidth:{get:function(){return this._labelOutlineWidth},set:function(t){this._labelOutlineWidth=Ts(this,t),this._style.labelOutlineWidth=Ss(this._labelOutlineWidth)}},font:{get:function(){return this._font},set:function(t){this._font=Ts(this,t),this._style.font=Ss(this._font)}},labelStyle:{get:function(){return this._labelStyle},set:function(t){this._labelStyle=Ts(this,t),this._style.labelStyle=Ss(this._labelStyle)}},labelText:{get:function(){return this._labelText},set:function(t){this._labelText=Ts(this,t),this._style.labelText=Ss(this._labelText)}},backgroundColor:{get:function(){return this._backgroundColor},set:function(t){this._backgroundColor=Ts(this,t),this._style.backgroundColor=Ss(this._backgroundColor)}},backgroundPadding:{get:function(){return this._backgroundPadding},set:function(t){this._backgroundPadding=Ts(this,t),this._style.backgroundPadding=Ss(this._backgroundPadding)}},backgroundEnabled:{get:function(){return this._backgroundEnabled},set:function(t){this._backgroundEnabled=Ts(this,t),this._style.backgroundEnabled=Ss(this._backgroundEnabled)}},scaleByDistance:{get:function(){return this._scaleByDistance},set:function(t){this._scaleByDistance=Ts(this,t),this._style.scaleByDistance=Ss(this._scaleByDistance)}},translucencyByDistance:{get:function(){return this._translucencyByDistance},set:function(t){this._translucencyByDistance=Ts(this,t),this._style.translucencyByDistance=Ss(this._translucencyByDistance)}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){this._distanceDisplayCondition=Ts(this,t),this._style.distanceDisplayCondition=Ss(this._distanceDisplayCondition)}},heightOffset:{get:function(){return this._heightOffset},set:function(t){this._heightOffset=Ts(this,t),this._style.heightOffset=Ss(this._heightOffset)}},anchorLineEnabled:{get:function(){return this._anchorLineEnabled},set:function(t){this._anchorLineEnabled=Ts(this,t),this._style.anchorLineEnabled=Ss(this._anchorLineEnabled)}},anchorLineColor:{get:function(){return this._anchorLineColor},set:function(t){this._anchorLineColor=Ts(this,t),this._style.anchorLineColor=Ss(this._anchorLineColor)}},image:{get:function(){return this._image},set:function(t){this._image=Ts(this,t),this._style.image=Ss(this._image)}},disableDepthTestDistance:{get:function(){return this._disableDepthTestDistance},set:function(t){this._disableDepthTestDistance=Ts(this,t),this._style.disableDepthTestDistance=Ss(this._disableDepthTestDistance)}},horizontalOrigin:{get:function(){return this._horizontalOrigin},set:function(t){this._horizontalOrigin=Ts(this,t),this._style.horizontalOrigin=Ss(this._horizontalOrigin)}},verticalOrigin:{get:function(){return this._verticalOrigin},set:function(t){this._verticalOrigin=Ts(this,t),this._style.verticalOrigin=Ss(this._verticalOrigin)}},labelHorizontalOrigin:{get:function(){return this._labelHorizontalOrigin},set:function(t){this._labelHorizontalOrigin=Ts(this,t),this._style.labelHorizontalOrigin=Ss(this._labelHorizontalOrigin)}},labelVerticalOrigin:{get:function(){return this._labelVerticalOrigin},set:function(t){this._labelVerticalOrigin=Ts(this,t),this._style.labelVerticalOrigin=Ss(this._labelVerticalOrigin)}},meta:{get:function(){return this._meta},set:function(t){this._meta=t}}});kU.fromUrl=function(t){return te.createIfNeeded(t).fetchJson(t).then(function(n){return new kU(n)})};kU.prototype.getColorShaderFunction=function(t,e,n){return this._colorShaderFunctionReady?(n.translucent=this._colorShaderTranslucent,this._colorShaderFunction):(this._colorShaderFunctionReady=!0,c(this.color)&&c(this.color.getShaderFunction)?this._colorShaderFunction=this.color.getShaderFunction(t,e,n,"vec4"):this._colorShaderFunction=void 0,this._colorShaderTranslucent=n.translucent,this._colorShaderFunction)};kU.prototype.getShowShaderFunction=function(t,e,n){return this._showShaderFunctionReady?this._showShaderFunction:(this._showShaderFunctionReady=!0,c(this.show)&&c(this.show.getShaderFunction)?this._showShaderFunction=this.show.getShaderFunction(t,e,n,"bool"):this._showShaderFunction=void 0,this._showShaderFunction)};kU.prototype.getPointSizeShaderFunction=function(t,e,n){return this._pointSizeShaderFunctionReady?this._pointSizeShaderFunction:(this._pointSizeShaderFunctionReady=!0,c(this.pointSize)&&c(this.pointSize.getShaderFunction)?this._pointSizeShaderFunction=this.pointSize.getShaderFunction(t,e,n,"float"):this._pointSizeShaderFunction=void 0,this._pointSizeShaderFunction)};kU.prototype.getVariables=function(){let t=[];return c(this.color)&&c(this.color.getVariables)&&t.push.apply(t,this.color.getVariables()),c(this.show)&&c(this.show.getVariables)&&t.push.apply(t,this.show.getVariables()),c(this.pointSize)&&c(this.pointSize.getVariables)&&t.push.apply(t,this.pointSize.getVariables()),t=t.filter(function(e,n,i){return i.indexOf(e)===n}),t};var qS=kU;var jvo=R(W(),1);var Uvo=R(W(),1);function X5(t){t=f(t,f.EMPTY_OBJECT),this._maximumSubtreeCount=f(t.maximumSubtreeCount,0),this._subtreeRequestCounter=0,this._queue=new xS({comparator:X5.comparator})}X5.prototype.addSubtree=function(t){let e=new sMe(t,this._subtreeRequestCounter);this._subtreeRequestCounter++,this._queue.insert(e);let n=t.implicitCoordinates;if(n.level>0){let i=n.getParentSubtreeCoordinates(),o=this.find(i)}if(this._maximumSubtreeCount>0)for(;this._queue.length>this._maximumSubtreeCount&&this._queue.getMinimum()!==e;)this._queue.removeMinimum()};X5.prototype.find=function(t){let e=this._queue,n=e.internalArray,i=e.length;for(let o=0;o<i;o++){let a=n[o],l=a.subtree.implicitCoordinates;if(t.isEqual(l))return a.subtree}};X5.comparator=function(t,e){let n=t.subtree.implicitCoordinates,i=e.subtree.implicitCoordinates;return n.isAncestor(i)?1:i.isAncestor(n)?-1:t.stamp-e.stamp};function sMe(t,e){this.subtree=t,this.stamp=e}var J5=X5;var gvo=R(W(),1);function wj(t){this._resource=t,this._metadataTable=void 0}Object.defineProperties(wj.prototype,{metadataTable:{get:function(){return this._metadataTable}}});wj.fromJson=async function(t,e,n,i){let o;c(e)?o={json:e,binary:void 0}:o=rMe(n);let a=await lMe(t,o.json,o.binary),s={},l=o.json.bufferViews.length;for(let h=0;h<l;++h){let Z=o.json.bufferViews[h],b=Z.byteOffset,u=b+Z.byteLength,U=a[Z.buffer].subarray(b,u);s[h]=U}let r=o.json.voxelTable,d=o.json.propertyTables[r],m=new wj(t);return m._metadataTable=new Bm({count:d.count,properties:d.properties,class:i.classes[d.class],bufferViews:s}),m};function lMe(t,e,n){let i=e.buffers.length,o=new Array(i);for(let a=0;a<i;a++){let s=e.buffers[a];if(c(s.uri)){let r=t.getDerivedResource({url:s.uri});o[a]=r.fetchArrayBuffer().then(function(d){return new Uint8Array(d)})}else o[a]=Promise.resolve(n)}return Promise.all(o)}function rMe(t){let n=new DataView(t.buffer,t.byteOffset),i=8,o=n.getUint32(i,!0);i+=8;let a=n.getUint32(i,!0);i+=8;let s=ts(t,i,o);i+=o;let l=t.subarray(i,i+a);return{json:s,binary:l}}var L5=wj;function Pj(t){t=f(t,f.EMPTY_OBJECT),this.shapeTransform=void 0,this.globalTransform=void 0,this.shape=void 0,this.minBounds=void 0,this.maxBounds=void 0,this.dimensions=void 0,this.paddingBefore=void 0,this.paddingAfter=void 0,this.names=void 0,this.types=void 0,this.componentTypes=void 0,this.minimumValues=void 0,this.maximumValues=void 0,this.maximumTileCount=void 0,this._implicitTileset=void 0,this._subtreeCache=new J5}Pj.fromUrl=async function(t){let e=te.createIfNeeded(t),n=await e.fetchJson();cMe(n);let i=ZMe(n,e);await i.load();let o=n.root,a=o.content.extensions["3DTILES_content_voxels"],s=a.class,l=co(n,"3DTILES_metadata")?n.extensions["3DTILES_metadata"]:n,r=i.schema,d=new $A({metadataJson:l,schema:r}),m=new Pj;VMe(m,d,s);let h=new eT(e,o,r),{shape:Z,minBounds:b,maxBounds:u,shapeTransform:F,globalTransform:U}=mMe(o);m.shape=Z,m.minBounds=b,m.maxBounds=u,m.dimensions=p.unpack(a.dimensions),m.shapeTransform=F,m.globalTransform=U,m.maximumTileCount=dMe(d);let G,A;return c(a.padding)&&(G=p.unpack(a.padding.before),A=p.unpack(a.padding.after)),m.paddingBefore=G,m.paddingAfter=A,m._implicitTileset=h,jo.unload(i),m};function dMe(t){if(c(t.tileset))return t.tileset.getPropertyBySemantic(GA.TILESET_TILE_COUNT)}function cMe(t){let e=t.root;if(!c(e.content))throw new St("Root must have content");if(!co(e.content,"3DTILES_content_voxels"))throw new St("Root tile content must have 3DTILES_content_voxels extension");if(!co(e,"3DTILES_implicit_tiling")&&!c(e.implicitTiling))throw new St("Root tile must have implicit tiling");if(!c(t.schema)&&!c(t.schemaUri)&&!co(t,"3DTILES_metadata"))throw new St("Tileset must have a metadata schema")}function mMe(t){let e=t.boundingVolume,n;if(c(t.transform)?n=L.unpack(t.transform):n=L.clone(L.IDENTITY),c(e.box))return pMe(e.box,n);if(c(e.region))return hMe(e.region);if(co(e,"3DTILES_bounding_volume_cylinder"))return uMe(e.extensions["3DTILES_bounding_volume_cylinder"].cylinder,n);throw new St("Only box, region and 3DTILES_bounding_volume_cylinder are supported in Cesium3DTilesVoxelProvider")}function hMe(t){let e=t[0],n=t[1],i=t[2],o=t[3],a=t[4],s=t[5],l=L.fromScale(mt.WGS84.radii),r=new p(e,n,a),d=new p(i,o,s);return{shape:_o.ELLIPSOID,minBounds:r,maxBounds:d,shapeTransform:l,globalTransform:L.clone(L.IDENTITY)}}function pMe(t,e){let n=ci.unpack(t),i=L.fromRotationTranslation(n.halfAxes,n.center);return{shape:_o.BOX,minBounds:p.clone(Pb.DefaultMinBounds),maxBounds:p.clone(Pb.DefaultMaxBounds),shapeTransform:i,globalTransform:e}}function uMe(t,e){let n=ci.unpack(t),i=L.fromRotationTranslation(n.halfAxes,n.center);return{shape:_o.CYLINDER,minBounds:p.clone(vb.DefaultMinBounds),maxBounds:p.clone(vb.DefaultMaxBounds),shapeTransform:i,globalTransform:e}}function ZMe(t,e){let{schemaUri:n,schema:i}=t;return c(n)?jo.getSchemaLoader({resource:e.getDerivedResource({url:n})}):jo.getSchemaLoader({schema:i})}function VMe(t,e,n){let{schema:i,statistics:o}=e,a=o?.classes[n],s=i.classes[n].properties,l=Object.entries(s).map(([h,Z])=>{let{type:b,componentType:u}=Z,F=a?.properties[h].min,U=a?.properties[h].max,G=Nn.getComponentCount(b),A=S2t(F,G),T=S2t(U,G);return{id:h,type:b,componentType:u,minValue:A,maxValue:T}});t.names=l.map(h=>h.id),t.types=l.map(h=>h.type),t.componentTypes=l.map(h=>h.componentType);let r=l.map(h=>h.minValue),d=l.map(h=>h.maxValue),m=r.some(c);t.minimumValues=m?r:void 0,t.maximumValues=m?d:void 0}function S2t(t,e){if(!c(t))return;let n=Array.isArray(t)?t:[t];return Array.from({length:e},(i,o)=>n[o])}async function bMe(t,e){let n=t.contentUriTemplates[0].getDerivedResource({templateValues:e.getTemplateValues()}),i=t.baseResource.getDerivedResource({url:n.url}),o=await i.fetchArrayBuffer(),a=db(o);return await L5.fromJson(i,a.jsonPayload,a.binaryPayload,t.metadataSchema)}async function RMe(t,e){let n=t._implicitTileset,i=t._subtreeCache,o=i.find(e);if(c(o))return o;let a=n.subtreeUriTemplate.getDerivedResource({templateValues:e.getTemplateValues()}),s=n.baseResource.getDerivedResource({url:a.url}),l=await s.fetchArrayBuffer();if(o=i.find(e),c(o))return o;let r=db(l);return o=await UA.fromSubtreeJson(s,r.jsonPayload,r.binaryPayload,n,e),i.addSubtree(o),o}Pj.prototype.requestData=function(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.tileLevel,0),n=f(t.tileX,0),i=f(t.tileY,0),o=f(t.tileZ,0);if(f(t.keyframe,0)!==0)return;let s=this._implicitTileset,l=this.names,r=new nT({subdivisionScheme:s.subdivisionScheme,subtreeLevels:s.subtreeLevels,level:e,x:n,y:i,z:o}),d=r.isSubtreeRoot()&&r.level>0,m=d?r.getParentSubtreeCoordinates():r.getSubtreeCoordinates();return RMe(this,m).then(function(Z){return(d?Z.childSubtreeIsAvailableAtCoordinates(r):Z.tileIsAvailableAtCoordinates(r))?bMe(s,r):Promise.reject("Tile is not available")}).then(function(Z){return l.map(function(b){return Z.metadataTable.getPropertyTypedArray(b)})})};var Alt=Pj;var nKo=R(W(),1);function Tlt(t){t=f(t,1),this._radius=f(t,1)}Object.defineProperties(Tlt.prototype,{radius:{get:function(){return this._radius},set:function(t){this._radius=t}}});Tlt.prototype.emit=function(t){let e=k.randomBetween(0,k.TWO_PI),n=k.randomBetween(0,this._radius),i=n*Math.cos(e),o=n*Math.sin(e),a=0;t.position=p.fromElements(i,o,a,t.position),t.velocity=p.clone(p.UNIT_Z,t.velocity)};var M5=Tlt;var wKo=R(W(),1);var oKo=R(W(),1),Slt={CUMULUS:0};Slt.validate=function(t){return t===Slt.CUMULUS};var mN=Object.freeze(Slt);var mKo=R(W(),1);function ZV(t,e){if(t=f(t,f.EMPTY_OBJECT),this._show=f(t.show,!0),this._position=p.clone(f(t.position,p.ZERO)),!c(t.scale)&&c(t.maximumSize))this._maximumSize=p.clone(t.maximumSize),this._scale=new K(this._maximumSize.x,this._maximumSize.y);else{this._scale=K.clone(f(t.scale,new K(20,12)));let n=new p(this._scale.x,this._scale.y,Math.min(this._scale.x,this._scale.y)/1.5);this._maximumSize=p.clone(f(t.maximumSize,n))}this._slice=f(t.slice,-1),this._color=v.clone(f(t.color,v.WHITE)),this._brightness=f(t.brightness,1),this._cloudCollection=e,this._index=-1}var WMe=ZV.SHOW_INDEX=0,fMe=ZV.POSITION_INDEX=1,FMe=ZV.SCALE_INDEX=2,UMe=ZV.MAXIMUM_SIZE_INDEX=3,GMe=ZV.SLICE_INDEX=4,AMe=ZV.BRIGHTNESS_INDEX=5,TMe=ZV.COLOR_INDEX=6;ZV.NUMBER_OF_PROPERTIES=7;function $S(t,e){let n=t._cloudCollection;c(n)&&(n._updateCloud(t,e),t._dirty=!0)}Object.defineProperties(ZV.prototype,{show:{get:function(){return this._show},set:function(t){this._show!==t&&(this._show=t,$S(this,WMe))}},position:{get:function(){return this._position},set:function(t){let e=this._position;p.equals(e,t)||(p.clone(t,e),$S(this,fMe))}},scale:{get:function(){return this._scale},set:function(t){let e=this._scale;K.equals(e,t)||(K.clone(t,e),$S(this,FMe))}},maximumSize:{get:function(){return this._maximumSize},set:function(t){let e=this._maximumSize;p.equals(e,t)||(p.clone(t,e),$S(this,UMe))}},color:{get:function(){return this._color},set:function(t){let e=this._color;v.equals(e,t)||(v.clone(t,e),$S(this,TMe))}},slice:{get:function(){return this._slice},set:function(t){this._slice!==t&&(this._slice=t,$S(this,GMe))}},brightness:{get:function(){return this._brightness},set:function(t){this._brightness!==t&&(this._brightness=t,$S(this,AMe))}}});ZV.prototype._destroy=function(){this._cloudCollection=void 0};var hp=ZV;var pp,vj=new p,SMe={positionHighAndScaleX:0,positionLowAndScaleY:1,packedAttribute0:2,packedAttribute1:3,color:4},gMe={direction:0,positionHighAndScaleX:1,positionLowAndScaleY:2,packedAttribute0:3,packedAttribute1:4,color:5},EMe=hp.SHOW_INDEX,CMe=hp.POSITION_INDEX,IMe=hp.SCALE_INDEX,NMe=hp.MAXIMUM_SIZE_INDEX,yMe=hp.SLICE_INDEX,BMe=hp.BRIGHTNESS_INDEX,QMe=hp.NUMBER_OF_PROPERTIES,kMe=hp.COLOR_INDEX;function VV(t){t=f(t,f.EMPTY_OBJECT),this._clouds=[],this._cloudsToUpdate=[],this._cloudsToUpdateIndex=0,this._cloudsRemoved=!1,this._createVertexArray=!1,this._propertiesChanged=new Uint32Array(QMe),this._noiseTexture=void 0,this._textureSliceWidth=128,this._noiseTextureRows=4,this.noiseDetail=f(t.noiseDetail,16),this.noiseOffset=p.clone(f(t.noiseOffset,p.ZERO)),this._loading=!1,this._ready=!1;let e=this;this._uniforms={u_noiseTexture:function(){return e._noiseTexture},u_noiseTextureDimensions:g2t(e),u_noiseDetail:function(){return e.noiseDetail}},this._vaNoise=void 0,this._spNoise=void 0,this._spCreated=!1,this._sp=void 0,this._rs=void 0,this.show=f(t.show,!0),this._colorCommands=[],this.debugBillboards=f(t.debugBillboards,!1),this._compiledDebugBillboards=!1,this.debugEllipsoids=f(t.debugEllipsoids,!1),this._compiledDebugEllipsoids=!1}function g2t(t){return function(){return vj.x=t._textureSliceWidth,vj.y=t._noiseTextureRows,vj.z=1/t._noiseTextureRows,vj}}Object.defineProperties(VV.prototype,{length:{get:function(){return Elt(this),this._clouds.length}}});function E2t(t){let e=t.length;for(let n=0;n<e;++n)t[n]&&t[n]._destroy()}VV.prototype.add=function(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.cloudType,mN.CUMULUS),n;return e===mN.CUMULUS&&(n=new hp(t,this),n._index=this._clouds.length,this._clouds.push(n),this._createVertexArray=!0),n};VV.prototype.remove=function(t){return this.contains(t)?(this._clouds[t._index]=void 0,this._cloudsRemoved=!0,this._createVertexArray=!0,t._destroy(),!0):!1};VV.prototype.removeAll=function(){E2t(this._clouds),this._clouds=[],this._cloudsToUpdate=[],this._cloudsToUpdateIndex=0,this._cloudsRemoved=!1,this._createVertexArray=!0};function Elt(t){if(t._cloudsRemoved){t._cloudsRemoved=!1;let e=[],n=t._clouds,i=n.length;for(let o=0,a=0;o<i;++o){let s=n[o];c(s)&&(n._index=a++,e.push(s))}t._clouds=e}}VV.prototype._updateCloud=function(t,e){t._dirty||(this._cloudsToUpdate[this._cloudsToUpdateIndex++]=t),++this._propertiesChanged[e]};VV.prototype.contains=function(t){return c(t)&&t._cloudCollection===this};VV.prototype.get=function(t){return Elt(this),this._clouds[t]};var YMe=new Float32Array([-1,-1,1,-1,1,1,-1,1]),xMe=new Uint16Array([0,1,2,0,2,3]);function XMe(t){let e=we.createVertexBuffer({context:t,typedArray:YMe,usage:ce.STATIC_DRAW}),n=we.createIndexBuffer({context:t,typedArray:xMe,usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT}),i=[{index:0,vertexBuffer:e,componentsPerAttribute:2,componentDatatype:it.FLOAT}];return new Ki({context:t,attributes:i,indexBuffer:n})}var Clt;function JMe(t){let n=t.cache.cloudCollection_indexBufferBatched;if(c(n))return n;let i=16384*6-6,o=new Uint16Array(i);for(let a=0,s=0;a<i;a+=6,s+=4)o[a]=s,o[a+1]=s+1,o[a+2]=s+2,o[a+3]=s,o[a+4]=s+2,o[a+5]=s+3;return n=we.createIndexBuffer({context:t,typedArray:o,usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT}),n.vertexArrayDestroyable=!1,t.cache.cloudCollection_indexBufferBatched=n,n}function LMe(t){let e=t.cache.cloudCollection_indexBufferInstanced;return c(e)||(e=we.createIndexBuffer({context:t,typedArray:new Uint16Array([0,1,2,0,2,3]),usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT}),e.vertexArrayDestroyable=!1,t.cache.cloudCollection_indexBufferInstanced=e),e}function MMe(t){let e=t.cache.cloudCollection_vertexBufferInstanced;return c(e)||(e=we.createVertexBuffer({context:t,typedArray:new Float32Array([0,0,1,0,1,1,0,1]),usage:ce.STATIC_DRAW}),e.vertexArrayDestroyable=!1,t.cache.cloudCollection_vertexBufferInstanced=e),e}function _Me(t,e,n){let i=[{index:pp.positionHighAndScaleX,componentsPerAttribute:4,componentDatatype:it.FLOAT,usage:ce.STATIC_DRAW},{index:pp.positionLowAndScaleY,componentsPerAttribute:4,componentDatatype:it.FLOAT,usage:ce.STATIC_DRAW},{index:pp.packedAttribute0,componentsPerAttribute:4,componentDatatype:it.FLOAT,usage:ce.STATIC_DRAW},{index:pp.packedAttribute1,componentsPerAttribute:4,componentDatatype:it.FLOAT,usage:ce.STATIC_DRAW},{index:pp.color,componentsPerAttribute:4,componentDatatype:it.UNSIGNED_BYTE,normalize:!0,usage:ce.STATIC_DRAW}];n&&i.push({index:pp.direction,componentsPerAttribute:2,componentDatatype:it.FLOAT,vertexBuffer:MMe(t)});let o=n?e:4*e;return new CR(t,i,o,n)}var glt=new Mi;function C2t(t,e,n,i){let o,a=n[pp.positionHighAndScaleX],s=n[pp.positionLowAndScaleY],l=i.position;Mi.fromCartesian(l,glt);let r=i.scale,d=glt.high,m=glt.low;t._instanced?(o=i._index,a(o,d.x,d.y,d.z,r.x),s(o,m.x,m.y,m.z,r.y)):(o=i._index*4,a(o+0,d.x,d.y,d.z,r.x),a(o+1,d.x,d.y,d.z,r.x),a(o+2,d.x,d.y,d.z,r.x),a(o+3,d.x,d.y,d.z,r.x),s(o+0,m.x,m.y,m.z,r.y),s(o+1,m.x,m.y,m.z,r.y),s(o+2,m.x,m.y,m.z,r.y),s(o+3,m.x,m.y,m.z,r.y))}function I2t(t,e,n,i){let o,a=n[pp.packedAttribute0],s=i.show,l=i.brightness;t._instanced?(o=i._index,a(o,s,l,0,0)):(o=i._index*4,a(o+0,s,l,0,0),a(o+1,s,l,1,0),a(o+2,s,l,1,1),a(o+3,s,l,0,1))}function N2t(t,e,n,i){let o,a=n[pp.packedAttribute1],s=i.maximumSize,l=i.slice;t._instanced?(o=i._index,a(o,s.x,s.y,s.z,l)):(o=i._index*4,a(o+0,s.x,s.y,s.z,l),a(o+1,s.x,s.y,s.z,l),a(o+2,s.x,s.y,s.z,l),a(o+3,s.x,s.y,s.z,l))}function y2t(t,e,n,i){let o,a=n[pp.color],s=i.color,l=v.floatToByte(s.red),r=v.floatToByte(s.green),d=v.floatToByte(s.blue),m=v.floatToByte(s.alpha);t._instanced?(o=i._index,a(o,l,r,d,m)):(o=i._index*4,a(o+0,l,r,d,m),a(o+1,l,r,d,m),a(o+2,l,r,d,m),a(o+3,l,r,d,m))}function DMe(t,e,n,i){C2t(t,e,n,i),I2t(t,e,n,i),N2t(t,e,n,i),y2t(t,e,n,i)}function OMe(t,e,n,i){let o=t,a=o._textureSliceWidth,s=o._noiseTextureRows,l=e.context;o._vaNoise=XMe(l),o._spNoise=xn.fromCache({context:l,vertexShaderSource:n,fragmentShaderSource:i,attributeLocations:{position:0}});let r=o.noiseDetail,d=o.noiseOffset;o._noiseTexture=new hn({context:l,width:a*a/s,height:a*s,pixelDatatype:Ue.UNSIGNED_BYTE,pixelFormat:Ye.RGBA,sampler:new Hn({wrapS:Vi.REPEAT,wrapT:Vi.REPEAT,minificationFilter:On.NEAREST,magnificationFilter:bo.NEAREST})});let m=new Wm({vertexArray:o._vaNoise,shaderProgram:o._spNoise,outputTexture:o._noiseTexture,uniformMap:{u_noiseTextureDimensions:g2t(o),u_noiseDetail:function(){return r},u_noiseOffset:function(){return d}},persists:!1,owner:t,postExecute:function(h){o._ready=!0,o._loading=!1}});e.commandList.push(m),o._loading=!0}function HMe(t,e){let n=t,i=e.context;n._createVertexArray=!1,n._vaf=n._vaf&&n._vaf.destroy();let o=t._clouds,a=o.length;if(a>0){n._vaf=_Me(i,a,n._instanced);let s=n._vaf.writers,l;for(l=0;l<a;++l){let r=o[l];DMe(t,e,s,r)}n._vaf.commit(Clt(i))}}var wMe=[];function PMe(t,e){let n=e.context,i=t,a=i._clouds.length,s=i._cloudsToUpdate,l=i._cloudsToUpdateIndex,r=i._propertiesChanged,d=wMe;d.length=0,(r[CMe]||r[IMe])&&d.push(C2t),(r[EMe]||r[BMe])&&d.push(I2t),(r[NMe]||r[yMe])&&d.push(N2t),r[kMe]&&d.push(y2t);let m=d.length,h=i._vaf.writers,Z,b,u;if(l/a>.1){for(Z=0;Z<l;++Z)for(b=s[Z],b._dirty=!1,u=0;u<m;++u)d[u](t,e,h,b);i._vaf.commit(Clt(n))}else{for(Z=0;Z<l;++Z){for(b=s[Z],b._dirty=!1,u=0;u<m;++u)d[u](t,e,h,b);i._instanced?i._vaf.subCommit(b._index,1):i._vaf.subCommit(b._index*4,4)}i._vaf.endSubCommits()}i._cloudsToUpdateIndex=0}function vMe(t,e,n,i){let o=e.context,a=t,s=new Ve({defines:[],sources:[n]});a._instanced&&s.defines.push("INSTANCED");let l=new Ve({defines:[],sources:[i]});a.debugBillboards&&l.defines.push("DEBUG_BILLBOARDS"),a.debugEllipsoids&&l.defines.push("DEBUG_ELLIPSOIDS"),a._sp=xn.replaceCache({context:o,shaderProgram:a._sp,vertexShaderSource:s,fragmentShaderSource:l,attributeLocations:pp}),a._rs=he.fromCache({depthTest:{enabled:!0,func:pt.LESS},depthMask:!1,blending:Pn.ALPHA_BLEND}),a._spCreated=!0,a._compiledDebugBillboards=a.debugBillboards,a._compiledDebugEllipsoids=a.debugEllipsoids}function KMe(t,e){let n=t,i=e.passes,o=n._uniforms,a=e.commandList;if(i.render){let s=n._colorCommands,l=n._vaf.va,r=l.length;s.length=r;for(let d=0;d<r;d++){let m=s[d];c(m)||(m=s[d]=new Ee),m.pass=Pt.TRANSLUCENT,m.owner=t,m.uniformMap=o,m.count=l[d].indicesCount,m.vertexArray=l[d].va,m.shaderProgram=n._sp,m.renderState=n._rs,n._instanced&&(m.count=6,m.instanceCount=n._clouds.length),a.push(m)}}}VV.prototype.update=function(t){if(Elt(this),!this.show)return;let e=this.debugBillboards||this.debugEllipsoids;this._ready=e?!0:c(this._noiseTexture),!this._ready&&!this._loading&&!e&&OMe(this,t,G5,U5),this._instanced=t.context.instancedArrays,pp=this._instanced?gMe:SMe,Clt=this._instanced?LMe:JMe;let i=this._clouds.length,o=this._cloudsToUpdate,a=this._cloudsToUpdateIndex;this._createVertexArray?HMe(this,t):a>0&&PMe(this,t),a>i*1.5&&(o.length=i),!(!c(this._vaf)||!c(this._vaf.va)||!this._ready&!e)&&((!this._spCreated||this.debugBillboards!==this._compiledDebugBillboards||this.debugEllipsoids!==this._compiledDebugEllipsoids)&&vMe(this,t,F5,f5),KMe(this,t))};VV.prototype.isDestroyed=function(){return!1};VV.prototype.destroy=function(){return this._noiseTexture=this._noiseTexture&&this._noiseTexture.destroy(),this._sp=this._sp&&this._sp.destroy(),this._vaf=this._vaf&&this._vaf.destroy(),E2t(this._clouds),At(this)};var Ilt=VV;var jKo=R(W(),1);var zMe=k.toRadians(30);function Nlt(t){this._angle=f(t,zMe)}Object.defineProperties(Nlt.prototype,{angle:{get:function(){return this._angle},set:function(t){this._angle=t}}});Nlt.prototype.emit=function(t){let e=Math.tan(this._angle),n=k.randomBetween(0,k.TWO_PI),i=k.randomBetween(0,e),o=i*Math.cos(n),a=i*Math.sin(n),s=1;t.velocity=p.fromElements(o,a,s,t.velocity),p.normalize(t.velocity,t.velocity),t.position=p.clone(p.ZERO,t.position)};var ylt=Nlt;var n3o=R(W(),1);function _5(t){t=f(t,f.EMPTY_OBJECT);let e=t.attributeName,n=t.perInstanceAttribute;c(n)||(n=!1);let i=f(t.glslDatatype,"vec3"),o=`v_${e}`,a;if(e==="normal"||e==="tangent"||e==="bitangent")a=`vec4 getColor() { return vec4((${o} + vec3(1.0)) * 0.5, 1.0); } +`,a};cN.prototype.getVariables=function(){let t=[],e=this._runtimeConditions;if(!c(e)||e.length===0)return t;let n=e.length;for(let i=0;i<n;++i){let o=e[i];t.push.apply(t,o.condition.getVariables()),t.push.apply(t,o.expression.getVariables())}return t=t.filter(function(i,o,a){return a.indexOf(i)===o}),t};var x5=cN;function kU(t){this._style={},this._ready=!1,this._show=void 0,this._color=void 0,this._pointSize=void 0,this._pointOutlineColor=void 0,this._pointOutlineWidth=void 0,this._labelColor=void 0,this._labelOutlineColor=void 0,this._labelOutlineWidth=void 0,this._font=void 0,this._labelStyle=void 0,this._labelText=void 0,this._backgroundColor=void 0,this._backgroundPadding=void 0,this._backgroundEnabled=void 0,this._scaleByDistance=void 0,this._translucencyByDistance=void 0,this._distanceDisplayCondition=void 0,this._heightOffset=void 0,this._anchorLineEnabled=void 0,this._anchorLineColor=void 0,this._image=void 0,this._disableDepthTestDistance=void 0,this._horizontalOrigin=void 0,this._verticalOrigin=void 0,this._labelHorizontalOrigin=void 0,this._labelVerticalOrigin=void 0,this._meta=void 0,this._colorShaderFunction=void 0,this._showShaderFunction=void 0,this._pointSizeShaderFunction=void 0,this._colorShaderFunctionReady=!1,this._showShaderFunctionReady=!1,this._pointSizeShaderFunctionReady=!1,this._colorShaderTranslucent=!1,aMe(this,t)}function aMe(t,e){e=f(Re(e,!0),t._style),t._style=e,t.show=e.show,t.color=e.color,t.pointSize=e.pointSize,t.pointOutlineColor=e.pointOutlineColor,t.pointOutlineWidth=e.pointOutlineWidth,t.labelColor=e.labelColor,t.labelOutlineColor=e.labelOutlineColor,t.labelOutlineWidth=e.labelOutlineWidth,t.labelStyle=e.labelStyle,t.font=e.font,t.labelText=e.labelText,t.backgroundColor=e.backgroundColor,t.backgroundPadding=e.backgroundPadding,t.backgroundEnabled=e.backgroundEnabled,t.scaleByDistance=e.scaleByDistance,t.translucencyByDistance=e.translucencyByDistance,t.distanceDisplayCondition=e.distanceDisplayCondition,t.heightOffset=e.heightOffset,t.anchorLineEnabled=e.anchorLineEnabled,t.anchorLineColor=e.anchorLineColor,t.image=e.image,t.disableDepthTestDistance=e.disableDepthTestDistance,t.horizontalOrigin=e.horizontalOrigin,t.verticalOrigin=e.verticalOrigin,t.labelHorizontalOrigin=e.labelHorizontalOrigin,t.labelVerticalOrigin=e.labelVerticalOrigin;let n={};if(c(e.meta)){let i=e.defines,o=f(e.meta,f.EMPTY_OBJECT);for(let a in o)o.hasOwnProperty(a)&&(n[a]=new xp(o[a],i))}t._meta=n,t._ready=!0}function Ss(t,e){let n=f(t._style,f.EMPTY_OBJECT).defines;if(c(e)){if(typeof e=="boolean"||typeof e=="number")return new xp(String(e));if(typeof e=="string")return new xp(e,n);if(c(e.conditions))return new x5(e,n)}else return;return e}function Ts(t){if(c(t)){if(c(t.expression))return t.expression;if(c(t.conditionsExpression))return Re(t.conditionsExpression,!0)}else return;return t}Object.defineProperties(kU.prototype,{style:{get:function(){return this._style}},show:{get:function(){return this._show},set:function(t){this._show=Ss(this,t),this._style.show=Ts(this._show),this._showShaderFunctionReady=!1}},color:{get:function(){return this._color},set:function(t){this._color=Ss(this,t),this._style.color=Ts(this._color),this._colorShaderFunctionReady=!1}},pointSize:{get:function(){return this._pointSize},set:function(t){this._pointSize=Ss(this,t),this._style.pointSize=Ts(this._pointSize),this._pointSizeShaderFunctionReady=!1}},pointOutlineColor:{get:function(){return this._pointOutlineColor},set:function(t){this._pointOutlineColor=Ss(this,t),this._style.pointOutlineColor=Ts(this._pointOutlineColor)}},pointOutlineWidth:{get:function(){return this._pointOutlineWidth},set:function(t){this._pointOutlineWidth=Ss(this,t),this._style.pointOutlineWidth=Ts(this._pointOutlineWidth)}},labelColor:{get:function(){return this._labelColor},set:function(t){this._labelColor=Ss(this,t),this._style.labelColor=Ts(this._labelColor)}},labelOutlineColor:{get:function(){return this._labelOutlineColor},set:function(t){this._labelOutlineColor=Ss(this,t),this._style.labelOutlineColor=Ts(this._labelOutlineColor)}},labelOutlineWidth:{get:function(){return this._labelOutlineWidth},set:function(t){this._labelOutlineWidth=Ss(this,t),this._style.labelOutlineWidth=Ts(this._labelOutlineWidth)}},font:{get:function(){return this._font},set:function(t){this._font=Ss(this,t),this._style.font=Ts(this._font)}},labelStyle:{get:function(){return this._labelStyle},set:function(t){this._labelStyle=Ss(this,t),this._style.labelStyle=Ts(this._labelStyle)}},labelText:{get:function(){return this._labelText},set:function(t){this._labelText=Ss(this,t),this._style.labelText=Ts(this._labelText)}},backgroundColor:{get:function(){return this._backgroundColor},set:function(t){this._backgroundColor=Ss(this,t),this._style.backgroundColor=Ts(this._backgroundColor)}},backgroundPadding:{get:function(){return this._backgroundPadding},set:function(t){this._backgroundPadding=Ss(this,t),this._style.backgroundPadding=Ts(this._backgroundPadding)}},backgroundEnabled:{get:function(){return this._backgroundEnabled},set:function(t){this._backgroundEnabled=Ss(this,t),this._style.backgroundEnabled=Ts(this._backgroundEnabled)}},scaleByDistance:{get:function(){return this._scaleByDistance},set:function(t){this._scaleByDistance=Ss(this,t),this._style.scaleByDistance=Ts(this._scaleByDistance)}},translucencyByDistance:{get:function(){return this._translucencyByDistance},set:function(t){this._translucencyByDistance=Ss(this,t),this._style.translucencyByDistance=Ts(this._translucencyByDistance)}},distanceDisplayCondition:{get:function(){return this._distanceDisplayCondition},set:function(t){this._distanceDisplayCondition=Ss(this,t),this._style.distanceDisplayCondition=Ts(this._distanceDisplayCondition)}},heightOffset:{get:function(){return this._heightOffset},set:function(t){this._heightOffset=Ss(this,t),this._style.heightOffset=Ts(this._heightOffset)}},anchorLineEnabled:{get:function(){return this._anchorLineEnabled},set:function(t){this._anchorLineEnabled=Ss(this,t),this._style.anchorLineEnabled=Ts(this._anchorLineEnabled)}},anchorLineColor:{get:function(){return this._anchorLineColor},set:function(t){this._anchorLineColor=Ss(this,t),this._style.anchorLineColor=Ts(this._anchorLineColor)}},image:{get:function(){return this._image},set:function(t){this._image=Ss(this,t),this._style.image=Ts(this._image)}},disableDepthTestDistance:{get:function(){return this._disableDepthTestDistance},set:function(t){this._disableDepthTestDistance=Ss(this,t),this._style.disableDepthTestDistance=Ts(this._disableDepthTestDistance)}},horizontalOrigin:{get:function(){return this._horizontalOrigin},set:function(t){this._horizontalOrigin=Ss(this,t),this._style.horizontalOrigin=Ts(this._horizontalOrigin)}},verticalOrigin:{get:function(){return this._verticalOrigin},set:function(t){this._verticalOrigin=Ss(this,t),this._style.verticalOrigin=Ts(this._verticalOrigin)}},labelHorizontalOrigin:{get:function(){return this._labelHorizontalOrigin},set:function(t){this._labelHorizontalOrigin=Ss(this,t),this._style.labelHorizontalOrigin=Ts(this._labelHorizontalOrigin)}},labelVerticalOrigin:{get:function(){return this._labelVerticalOrigin},set:function(t){this._labelVerticalOrigin=Ss(this,t),this._style.labelVerticalOrigin=Ts(this._labelVerticalOrigin)}},meta:{get:function(){return this._meta},set:function(t){this._meta=t}}});kU.fromUrl=function(t){return te.createIfNeeded(t).fetchJson(t).then(function(n){return new kU(n)})};kU.prototype.getColorShaderFunction=function(t,e,n){return this._colorShaderFunctionReady?(n.translucent=this._colorShaderTranslucent,this._colorShaderFunction):(this._colorShaderFunctionReady=!0,c(this.color)&&c(this.color.getShaderFunction)?this._colorShaderFunction=this.color.getShaderFunction(t,e,n,"vec4"):this._colorShaderFunction=void 0,this._colorShaderTranslucent=n.translucent,this._colorShaderFunction)};kU.prototype.getShowShaderFunction=function(t,e,n){return this._showShaderFunctionReady?this._showShaderFunction:(this._showShaderFunctionReady=!0,c(this.show)&&c(this.show.getShaderFunction)?this._showShaderFunction=this.show.getShaderFunction(t,e,n,"bool"):this._showShaderFunction=void 0,this._showShaderFunction)};kU.prototype.getPointSizeShaderFunction=function(t,e,n){return this._pointSizeShaderFunctionReady?this._pointSizeShaderFunction:(this._pointSizeShaderFunctionReady=!0,c(this.pointSize)&&c(this.pointSize.getShaderFunction)?this._pointSizeShaderFunction=this.pointSize.getShaderFunction(t,e,n,"float"):this._pointSizeShaderFunction=void 0,this._pointSizeShaderFunction)};kU.prototype.getVariables=function(){let t=[];return c(this.color)&&c(this.color.getVariables)&&t.push.apply(t,this.color.getVariables()),c(this.show)&&c(this.show.getVariables)&&t.push.apply(t,this.show.getVariables()),c(this.pointSize)&&c(this.pointSize.getVariables)&&t.push.apply(t,this.pointSize.getVariables()),t=t.filter(function(e,n,i){return i.indexOf(e)===n}),t};var qT=kU;var jvo=b(W(),1);var Uvo=b(W(),1);function X5(t){t=f(t,f.EMPTY_OBJECT),this._maximumSubtreeCount=f(t.maximumSubtreeCount,0),this._subtreeRequestCounter=0,this._queue=new xT({comparator:X5.comparator})}X5.prototype.addSubtree=function(t){let e=new sMe(t,this._subtreeRequestCounter);this._subtreeRequestCounter++,this._queue.insert(e);let n=t.implicitCoordinates;if(n.level>0){let i=n.getParentSubtreeCoordinates(),o=this.find(i)}if(this._maximumSubtreeCount>0)for(;this._queue.length>this._maximumSubtreeCount&&this._queue.getMinimum()!==e;)this._queue.removeMinimum()};X5.prototype.find=function(t){let e=this._queue,n=e.internalArray,i=e.length;for(let o=0;o<i;o++){let a=n[o],l=a.subtree.implicitCoordinates;if(t.isEqual(l))return a.subtree}};X5.comparator=function(t,e){let n=t.subtree.implicitCoordinates,i=e.subtree.implicitCoordinates;return n.isAncestor(i)?1:i.isAncestor(n)?-1:t.stamp-e.stamp};function sMe(t,e){this.subtree=t,this.stamp=e}var J5=X5;var gvo=b(W(),1);function wj(t){this._resource=t,this._metadataTable=void 0}Object.defineProperties(wj.prototype,{metadataTable:{get:function(){return this._metadataTable}}});wj.fromJson=async function(t,e,n,i){let o;c(e)?o={json:e,binary:void 0}:o=rMe(n);let a=await lMe(t,o.json,o.binary),s={},l=o.json.bufferViews.length;for(let h=0;h<l;++h){let u=o.json.bufferViews[h],R=u.byteOffset,V=R+u.byteLength,U=a[u.buffer].subarray(R,V);s[h]=U}let r=o.json.voxelTable,d=o.json.propertyTables[r],m=new wj(t);return m._metadataTable=new Bm({count:d.count,properties:d.properties,class:i.classes[d.class],bufferViews:s}),m};function lMe(t,e,n){let i=e.buffers.length,o=new Array(i);for(let a=0;a<i;a++){let s=e.buffers[a];if(c(s.uri)){let r=t.getDerivedResource({url:s.uri});o[a]=r.fetchArrayBuffer().then(function(d){return new Uint8Array(d)})}else o[a]=Promise.resolve(n)}return Promise.all(o)}function rMe(t){let n=new DataView(t.buffer,t.byteOffset),i=8,o=n.getUint32(i,!0);i+=8;let a=n.getUint32(i,!0);i+=8;let s=ts(t,i,o);i+=o;let l=t.subarray(i,i+a);return{json:s,binary:l}}var L5=wj;function Pj(t){t=f(t,f.EMPTY_OBJECT),this.shapeTransform=void 0,this.globalTransform=void 0,this.shape=void 0,this.minBounds=void 0,this.maxBounds=void 0,this.dimensions=void 0,this.paddingBefore=void 0,this.paddingAfter=void 0,this.names=void 0,this.types=void 0,this.componentTypes=void 0,this.minimumValues=void 0,this.maximumValues=void 0,this.maximumTileCount=void 0,this._implicitTileset=void 0,this._subtreeCache=new J5}Pj.fromUrl=async function(t){let e=te.createIfNeeded(t),n=await e.fetchJson();cMe(n);let i=uMe(n,e);await i.load();let o=n.root,a=o.content.extensions["3DTILES_content_voxels"],s=a.class,l=co(n,"3DTILES_metadata")?n.extensions["3DTILES_metadata"]:n,r=i.schema,d=new $A({metadataJson:l,schema:r}),m=new Pj;ZMe(m,d,s);let h=new eS(e,o,r),{shape:u,minBounds:R,maxBounds:V,shapeTransform:F,globalTransform:U}=mMe(o);m.shape=u,m.minBounds=R,m.maxBounds=V,m.dimensions=p.unpack(a.dimensions),m.shapeTransform=F,m.globalTransform=U,m.maximumTileCount=dMe(d);let G,A;return c(a.padding)&&(G=p.unpack(a.padding.before),A=p.unpack(a.padding.after)),m.paddingBefore=G,m.paddingAfter=A,m._implicitTileset=h,jo.unload(i),m};function dMe(t){if(c(t.tileset))return t.tileset.getPropertyBySemantic(GA.TILESET_TILE_COUNT)}function cMe(t){let e=t.root;if(!c(e.content))throw new Tt("Root must have content");if(!co(e.content,"3DTILES_content_voxels"))throw new Tt("Root tile content must have 3DTILES_content_voxels extension");if(!co(e,"3DTILES_implicit_tiling")&&!c(e.implicitTiling))throw new Tt("Root tile must have implicit tiling");if(!c(t.schema)&&!c(t.schemaUri)&&!co(t,"3DTILES_metadata"))throw new Tt("Tileset must have a metadata schema")}function mMe(t){let e=t.boundingVolume,n;if(c(t.transform)?n=L.unpack(t.transform):n=L.clone(L.IDENTITY),c(e.box))return pMe(e.box,n);if(c(e.region))return hMe(e.region);if(co(e,"3DTILES_bounding_volume_cylinder"))return VMe(e.extensions["3DTILES_bounding_volume_cylinder"].cylinder,n);throw new Tt("Only box, region and 3DTILES_bounding_volume_cylinder are supported in Cesium3DTilesVoxelProvider")}function hMe(t){let e=t[0],n=t[1],i=t[2],o=t[3],a=t[4],s=t[5],l=L.fromScale(mt.WGS84.radii),r=new p(e,n,a),d=new p(i,o,s);return{shape:_o.ELLIPSOID,minBounds:r,maxBounds:d,shapeTransform:l,globalTransform:L.clone(L.IDENTITY)}}function pMe(t,e){let n=ci.unpack(t),i=L.fromRotationTranslation(n.halfAxes,n.center);return{shape:_o.BOX,minBounds:p.clone(PR.DefaultMinBounds),maxBounds:p.clone(PR.DefaultMaxBounds),shapeTransform:i,globalTransform:e}}function VMe(t,e){let n=ci.unpack(t),i=L.fromRotationTranslation(n.halfAxes,n.center);return{shape:_o.CYLINDER,minBounds:p.clone(vR.DefaultMinBounds),maxBounds:p.clone(vR.DefaultMaxBounds),shapeTransform:i,globalTransform:e}}function uMe(t,e){let{schemaUri:n,schema:i}=t;return c(n)?jo.getSchemaLoader({resource:e.getDerivedResource({url:n})}):jo.getSchemaLoader({schema:i})}function ZMe(t,e,n){let{schema:i,statistics:o}=e,a=o?.classes[n],s=i.classes[n].properties,l=Object.entries(s).map(([h,u])=>{let{type:R,componentType:V}=u,F=a?.properties[h].min,U=a?.properties[h].max,G=Nn.getComponentCount(R),A=Tkt(F,G),S=Tkt(U,G);return{id:h,type:R,componentType:V,minValue:A,maxValue:S}});t.names=l.map(h=>h.id),t.types=l.map(h=>h.type),t.componentTypes=l.map(h=>h.componentType);let r=l.map(h=>h.minValue),d=l.map(h=>h.maxValue),m=r.some(c);t.minimumValues=m?r:void 0,t.maximumValues=m?d:void 0}function Tkt(t,e){if(!c(t))return;let n=Array.isArray(t)?t:[t];return Array.from({length:e},(i,o)=>n[o])}async function RMe(t,e){let n=t.contentUriTemplates[0].getDerivedResource({templateValues:e.getTemplateValues()}),i=t.baseResource.getDerivedResource({url:n.url}),o=await i.fetchArrayBuffer(),a=dR(o);return await L5.fromJson(i,a.jsonPayload,a.binaryPayload,t.metadataSchema)}async function bMe(t,e){let n=t._implicitTileset,i=t._subtreeCache,o=i.find(e);if(c(o))return o;let a=n.subtreeUriTemplate.getDerivedResource({templateValues:e.getTemplateValues()}),s=n.baseResource.getDerivedResource({url:a.url}),l=await s.fetchArrayBuffer();if(o=i.find(e),c(o))return o;let r=dR(l);return o=await UA.fromSubtreeJson(s,r.jsonPayload,r.binaryPayload,n,e),i.addSubtree(o),o}Pj.prototype.requestData=function(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.tileLevel,0),n=f(t.tileX,0),i=f(t.tileY,0),o=f(t.tileZ,0);if(f(t.keyframe,0)!==0)return;let s=this._implicitTileset,l=this.names,r=new nS({subdivisionScheme:s.subdivisionScheme,subtreeLevels:s.subtreeLevels,level:e,x:n,y:i,z:o}),d=r.isSubtreeRoot()&&r.level>0,m=d?r.getParentSubtreeCoordinates():r.getSubtreeCoordinates();return bMe(this,m).then(function(u){return(d?u.childSubtreeIsAvailableAtCoordinates(r):u.tileIsAvailableAtCoordinates(r))?RMe(s,r):Promise.reject("Tile is not available")}).then(function(u){return l.map(function(R){return u.metadataTable.getPropertyTypedArray(R)})})};var Alt=Pj;var n3o=b(W(),1);function Slt(t){t=f(t,1),this._radius=f(t,1)}Object.defineProperties(Slt.prototype,{radius:{get:function(){return this._radius},set:function(t){this._radius=t}}});Slt.prototype.emit=function(t){let e=k.randomBetween(0,k.TWO_PI),n=k.randomBetween(0,this._radius),i=n*Math.cos(e),o=n*Math.sin(e),a=0;t.position=p.fromElements(i,o,a,t.position),t.velocity=p.clone(p.UNIT_Z,t.velocity)};var M5=Slt;var w3o=b(W(),1);var o3o=b(W(),1),Tlt={CUMULUS:0};Tlt.validate=function(t){return t===Tlt.CUMULUS};var mN=Object.freeze(Tlt);var m3o=b(W(),1);function uZ(t,e){if(t=f(t,f.EMPTY_OBJECT),this._show=f(t.show,!0),this._position=p.clone(f(t.position,p.ZERO)),!c(t.scale)&&c(t.maximumSize))this._maximumSize=p.clone(t.maximumSize),this._scale=new K(this._maximumSize.x,this._maximumSize.y);else{this._scale=K.clone(f(t.scale,new K(20,12)));let n=new p(this._scale.x,this._scale.y,Math.min(this._scale.x,this._scale.y)/1.5);this._maximumSize=p.clone(f(t.maximumSize,n))}this._slice=f(t.slice,-1),this._color=v.clone(f(t.color,v.WHITE)),this._brightness=f(t.brightness,1),this._cloudCollection=e,this._index=-1}var WMe=uZ.SHOW_INDEX=0,fMe=uZ.POSITION_INDEX=1,FMe=uZ.SCALE_INDEX=2,UMe=uZ.MAXIMUM_SIZE_INDEX=3,GMe=uZ.SLICE_INDEX=4,AMe=uZ.BRIGHTNESS_INDEX=5,SMe=uZ.COLOR_INDEX=6;uZ.NUMBER_OF_PROPERTIES=7;function $T(t,e){let n=t._cloudCollection;c(n)&&(n._updateCloud(t,e),t._dirty=!0)}Object.defineProperties(uZ.prototype,{show:{get:function(){return this._show},set:function(t){this._show!==t&&(this._show=t,$T(this,WMe))}},position:{get:function(){return this._position},set:function(t){let e=this._position;p.equals(e,t)||(p.clone(t,e),$T(this,fMe))}},scale:{get:function(){return this._scale},set:function(t){let e=this._scale;K.equals(e,t)||(K.clone(t,e),$T(this,FMe))}},maximumSize:{get:function(){return this._maximumSize},set:function(t){let e=this._maximumSize;p.equals(e,t)||(p.clone(t,e),$T(this,UMe))}},color:{get:function(){return this._color},set:function(t){let e=this._color;v.equals(e,t)||(v.clone(t,e),$T(this,SMe))}},slice:{get:function(){return this._slice},set:function(t){this._slice!==t&&(this._slice=t,$T(this,GMe))}},brightness:{get:function(){return this._brightness},set:function(t){this._brightness!==t&&(this._brightness=t,$T(this,AMe))}}});uZ.prototype._destroy=function(){this._cloudCollection=void 0};var hp=uZ;var pp,vj=new p,TMe={positionHighAndScaleX:0,positionLowAndScaleY:1,packedAttribute0:2,packedAttribute1:3,color:4},gMe={direction:0,positionHighAndScaleX:1,positionLowAndScaleY:2,packedAttribute0:3,packedAttribute1:4,color:5},EMe=hp.SHOW_INDEX,CMe=hp.POSITION_INDEX,IMe=hp.SCALE_INDEX,NMe=hp.MAXIMUM_SIZE_INDEX,yMe=hp.SLICE_INDEX,BMe=hp.BRIGHTNESS_INDEX,QMe=hp.NUMBER_OF_PROPERTIES,kMe=hp.COLOR_INDEX;function ZZ(t){t=f(t,f.EMPTY_OBJECT),this._clouds=[],this._cloudsToUpdate=[],this._cloudsToUpdateIndex=0,this._cloudsRemoved=!1,this._createVertexArray=!1,this._propertiesChanged=new Uint32Array(QMe),this._noiseTexture=void 0,this._textureSliceWidth=128,this._noiseTextureRows=4,this.noiseDetail=f(t.noiseDetail,16),this.noiseOffset=p.clone(f(t.noiseOffset,p.ZERO)),this._loading=!1,this._ready=!1;let e=this;this._uniforms={u_noiseTexture:function(){return e._noiseTexture},u_noiseTextureDimensions:gkt(e),u_noiseDetail:function(){return e.noiseDetail}},this._vaNoise=void 0,this._spNoise=void 0,this._spCreated=!1,this._sp=void 0,this._rs=void 0,this.show=f(t.show,!0),this._colorCommands=[],this.debugBillboards=f(t.debugBillboards,!1),this._compiledDebugBillboards=!1,this.debugEllipsoids=f(t.debugEllipsoids,!1),this._compiledDebugEllipsoids=!1}function gkt(t){return function(){return vj.x=t._textureSliceWidth,vj.y=t._noiseTextureRows,vj.z=1/t._noiseTextureRows,vj}}Object.defineProperties(ZZ.prototype,{length:{get:function(){return Elt(this),this._clouds.length}}});function Ekt(t){let e=t.length;for(let n=0;n<e;++n)t[n]&&t[n]._destroy()}ZZ.prototype.add=function(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.cloudType,mN.CUMULUS),n;return e===mN.CUMULUS&&(n=new hp(t,this),n._index=this._clouds.length,this._clouds.push(n),this._createVertexArray=!0),n};ZZ.prototype.remove=function(t){return this.contains(t)?(this._clouds[t._index]=void 0,this._cloudsRemoved=!0,this._createVertexArray=!0,t._destroy(),!0):!1};ZZ.prototype.removeAll=function(){Ekt(this._clouds),this._clouds=[],this._cloudsToUpdate=[],this._cloudsToUpdateIndex=0,this._cloudsRemoved=!1,this._createVertexArray=!0};function Elt(t){if(t._cloudsRemoved){t._cloudsRemoved=!1;let e=[],n=t._clouds,i=n.length;for(let o=0,a=0;o<i;++o){let s=n[o];c(s)&&(n._index=a++,e.push(s))}t._clouds=e}}ZZ.prototype._updateCloud=function(t,e){t._dirty||(this._cloudsToUpdate[this._cloudsToUpdateIndex++]=t),++this._propertiesChanged[e]};ZZ.prototype.contains=function(t){return c(t)&&t._cloudCollection===this};ZZ.prototype.get=function(t){return Elt(this),this._clouds[t]};var YMe=new Float32Array([-1,-1,1,-1,1,1,-1,1]),xMe=new Uint16Array([0,1,2,0,2,3]);function XMe(t){let e=we.createVertexBuffer({context:t,typedArray:YMe,usage:ce.STATIC_DRAW}),n=we.createIndexBuffer({context:t,typedArray:xMe,usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT}),i=[{index:0,vertexBuffer:e,componentsPerAttribute:2,componentDatatype:it.FLOAT}];return new Ki({context:t,attributes:i,indexBuffer:n})}var Clt;function JMe(t){let n=t.cache.cloudCollection_indexBufferBatched;if(c(n))return n;let i=16384*6-6,o=new Uint16Array(i);for(let a=0,s=0;a<i;a+=6,s+=4)o[a]=s,o[a+1]=s+1,o[a+2]=s+2,o[a+3]=s,o[a+4]=s+2,o[a+5]=s+3;return n=we.createIndexBuffer({context:t,typedArray:o,usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT}),n.vertexArrayDestroyable=!1,t.cache.cloudCollection_indexBufferBatched=n,n}function LMe(t){let e=t.cache.cloudCollection_indexBufferInstanced;return c(e)||(e=we.createIndexBuffer({context:t,typedArray:new Uint16Array([0,1,2,0,2,3]),usage:ce.STATIC_DRAW,indexDatatype:re.UNSIGNED_SHORT}),e.vertexArrayDestroyable=!1,t.cache.cloudCollection_indexBufferInstanced=e),e}function MMe(t){let e=t.cache.cloudCollection_vertexBufferInstanced;return c(e)||(e=we.createVertexBuffer({context:t,typedArray:new Float32Array([0,0,1,0,1,1,0,1]),usage:ce.STATIC_DRAW}),e.vertexArrayDestroyable=!1,t.cache.cloudCollection_vertexBufferInstanced=e),e}function _Me(t,e,n){let i=[{index:pp.positionHighAndScaleX,componentsPerAttribute:4,componentDatatype:it.FLOAT,usage:ce.STATIC_DRAW},{index:pp.positionLowAndScaleY,componentsPerAttribute:4,componentDatatype:it.FLOAT,usage:ce.STATIC_DRAW},{index:pp.packedAttribute0,componentsPerAttribute:4,componentDatatype:it.FLOAT,usage:ce.STATIC_DRAW},{index:pp.packedAttribute1,componentsPerAttribute:4,componentDatatype:it.FLOAT,usage:ce.STATIC_DRAW},{index:pp.color,componentsPerAttribute:4,componentDatatype:it.UNSIGNED_BYTE,normalize:!0,usage:ce.STATIC_DRAW}];n&&i.push({index:pp.direction,componentsPerAttribute:2,componentDatatype:it.FLOAT,vertexBuffer:MMe(t)});let o=n?e:4*e;return new Cb(t,i,o,n)}var glt=new Mi;function Ckt(t,e,n,i){let o,a=n[pp.positionHighAndScaleX],s=n[pp.positionLowAndScaleY],l=i.position;Mi.fromCartesian(l,glt);let r=i.scale,d=glt.high,m=glt.low;t._instanced?(o=i._index,a(o,d.x,d.y,d.z,r.x),s(o,m.x,m.y,m.z,r.y)):(o=i._index*4,a(o+0,d.x,d.y,d.z,r.x),a(o+1,d.x,d.y,d.z,r.x),a(o+2,d.x,d.y,d.z,r.x),a(o+3,d.x,d.y,d.z,r.x),s(o+0,m.x,m.y,m.z,r.y),s(o+1,m.x,m.y,m.z,r.y),s(o+2,m.x,m.y,m.z,r.y),s(o+3,m.x,m.y,m.z,r.y))}function Ikt(t,e,n,i){let o,a=n[pp.packedAttribute0],s=i.show,l=i.brightness;t._instanced?(o=i._index,a(o,s,l,0,0)):(o=i._index*4,a(o+0,s,l,0,0),a(o+1,s,l,1,0),a(o+2,s,l,1,1),a(o+3,s,l,0,1))}function Nkt(t,e,n,i){let o,a=n[pp.packedAttribute1],s=i.maximumSize,l=i.slice;t._instanced?(o=i._index,a(o,s.x,s.y,s.z,l)):(o=i._index*4,a(o+0,s.x,s.y,s.z,l),a(o+1,s.x,s.y,s.z,l),a(o+2,s.x,s.y,s.z,l),a(o+3,s.x,s.y,s.z,l))}function ykt(t,e,n,i){let o,a=n[pp.color],s=i.color,l=v.floatToByte(s.red),r=v.floatToByte(s.green),d=v.floatToByte(s.blue),m=v.floatToByte(s.alpha);t._instanced?(o=i._index,a(o,l,r,d,m)):(o=i._index*4,a(o+0,l,r,d,m),a(o+1,l,r,d,m),a(o+2,l,r,d,m),a(o+3,l,r,d,m))}function DMe(t,e,n,i){Ckt(t,e,n,i),Ikt(t,e,n,i),Nkt(t,e,n,i),ykt(t,e,n,i)}function OMe(t,e,n,i){let o=t,a=o._textureSliceWidth,s=o._noiseTextureRows,l=e.context;o._vaNoise=XMe(l),o._spNoise=xn.fromCache({context:l,vertexShaderSource:n,fragmentShaderSource:i,attributeLocations:{position:0}});let r=o.noiseDetail,d=o.noiseOffset;o._noiseTexture=new hn({context:l,width:a*a/s,height:a*s,pixelDatatype:Ue.UNSIGNED_BYTE,pixelFormat:Ye.RGBA,sampler:new Hn({wrapS:Zi.REPEAT,wrapT:Zi.REPEAT,minificationFilter:On.NEAREST,magnificationFilter:Ro.NEAREST})});let m=new Wm({vertexArray:o._vaNoise,shaderProgram:o._spNoise,outputTexture:o._noiseTexture,uniformMap:{u_noiseTextureDimensions:gkt(o),u_noiseDetail:function(){return r},u_noiseOffset:function(){return d}},persists:!1,owner:t,postExecute:function(h){o._ready=!0,o._loading=!1}});e.commandList.push(m),o._loading=!0}function HMe(t,e){let n=t,i=e.context;n._createVertexArray=!1,n._vaf=n._vaf&&n._vaf.destroy();let o=t._clouds,a=o.length;if(a>0){n._vaf=_Me(i,a,n._instanced);let s=n._vaf.writers,l;for(l=0;l<a;++l){let r=o[l];DMe(t,e,s,r)}n._vaf.commit(Clt(i))}}var wMe=[];function PMe(t,e){let n=e.context,i=t,a=i._clouds.length,s=i._cloudsToUpdate,l=i._cloudsToUpdateIndex,r=i._propertiesChanged,d=wMe;d.length=0,(r[CMe]||r[IMe])&&d.push(Ckt),(r[EMe]||r[BMe])&&d.push(Ikt),(r[NMe]||r[yMe])&&d.push(Nkt),r[kMe]&&d.push(ykt);let m=d.length,h=i._vaf.writers,u,R,V;if(l/a>.1){for(u=0;u<l;++u)for(R=s[u],R._dirty=!1,V=0;V<m;++V)d[V](t,e,h,R);i._vaf.commit(Clt(n))}else{for(u=0;u<l;++u){for(R=s[u],R._dirty=!1,V=0;V<m;++V)d[V](t,e,h,R);i._instanced?i._vaf.subCommit(R._index,1):i._vaf.subCommit(R._index*4,4)}i._vaf.endSubCommits()}i._cloudsToUpdateIndex=0}function vMe(t,e,n,i){let o=e.context,a=t,s=new Ze({defines:[],sources:[n]});a._instanced&&s.defines.push("INSTANCED");let l=new Ze({defines:[],sources:[i]});a.debugBillboards&&l.defines.push("DEBUG_BILLBOARDS"),a.debugEllipsoids&&l.defines.push("DEBUG_ELLIPSOIDS"),a._sp=xn.replaceCache({context:o,shaderProgram:a._sp,vertexShaderSource:s,fragmentShaderSource:l,attributeLocations:pp}),a._rs=he.fromCache({depthTest:{enabled:!0,func:pt.LESS},depthMask:!1,blending:Pn.ALPHA_BLEND}),a._spCreated=!0,a._compiledDebugBillboards=a.debugBillboards,a._compiledDebugEllipsoids=a.debugEllipsoids}function KMe(t,e){let n=t,i=e.passes,o=n._uniforms,a=e.commandList;if(i.render){let s=n._colorCommands,l=n._vaf.va,r=l.length;s.length=r;for(let d=0;d<r;d++){let m=s[d];c(m)||(m=s[d]=new Ee),m.pass=Pt.TRANSLUCENT,m.owner=t,m.uniformMap=o,m.count=l[d].indicesCount,m.vertexArray=l[d].va,m.shaderProgram=n._sp,m.renderState=n._rs,n._instanced&&(m.count=6,m.instanceCount=n._clouds.length),a.push(m)}}}ZZ.prototype.update=function(t){if(Elt(this),!this.show)return;let e=this.debugBillboards||this.debugEllipsoids;this._ready=e?!0:c(this._noiseTexture),!this._ready&&!this._loading&&!e&&OMe(this,t,G5,U5),this._instanced=t.context.instancedArrays,pp=this._instanced?gMe:TMe,Clt=this._instanced?LMe:JMe;let i=this._clouds.length,o=this._cloudsToUpdate,a=this._cloudsToUpdateIndex;this._createVertexArray?HMe(this,t):a>0&&PMe(this,t),a>i*1.5&&(o.length=i),!(!c(this._vaf)||!c(this._vaf.va)||!this._ready&!e)&&((!this._spCreated||this.debugBillboards!==this._compiledDebugBillboards||this.debugEllipsoids!==this._compiledDebugEllipsoids)&&vMe(this,t,F5,f5),KMe(this,t))};ZZ.prototype.isDestroyed=function(){return!1};ZZ.prototype.destroy=function(){return this._noiseTexture=this._noiseTexture&&this._noiseTexture.destroy(),this._sp=this._sp&&this._sp.destroy(),this._vaf=this._vaf&&this._vaf.destroy(),Ekt(this._clouds),At(this)};var Ilt=ZZ;var j3o=b(W(),1);var zMe=k.toRadians(30);function Nlt(t){this._angle=f(t,zMe)}Object.defineProperties(Nlt.prototype,{angle:{get:function(){return this._angle},set:function(t){this._angle=t}}});Nlt.prototype.emit=function(t){let e=Math.tan(this._angle),n=k.randomBetween(0,k.TWO_PI),i=k.randomBetween(0,e),o=i*Math.cos(n),a=i*Math.sin(n),s=1;t.velocity=p.fromElements(o,a,s,t.velocity),p.normalize(t.velocity,t.velocity),t.position=p.clone(p.ZERO,t.position)};var ylt=Nlt;var nKo=b(W(),1);function _5(t){t=f(t,f.EMPTY_OBJECT);let e=t.attributeName,n=t.perInstanceAttribute;c(n)||(n=!1);let i=f(t.glslDatatype,"vec3"),o=`v_${e}`,a;if(e==="normal"||e==="tangent"||e==="bitangent")a=`vec4 getColor() { return vec4((${o} + vec3(1.0)) * 0.5, 1.0); } `;else switch(e==="st"&&(i="vec2"),i){case"float":a=`vec4 getColor() { return vec4(vec3(${o}), 1.0); } `;break;case"vec2":a=`vec4 getColor() { return vec4(${o}, 0.0, 1.0); } `;break;case"vec3":a=`vec4 getColor() { return vec4(${o}, 1.0); } @@ -15328,7 +15328,7 @@ ${a} void main() { out_FragColor = getColor(); -}`;this.material=void 0,this.translucent=f(t.translucent,!1),this._vertexShaderSource=f(t.vertexShaderSource,s),this._fragmentShaderSource=f(t.fragmentShaderSource,l),this._renderState=ua.getDefaultRenderState(!1,!1,t.renderState),this._closed=f(t.closed,!1),this._attributeName=e,this._glslDatatype=i}Object.defineProperties(_5.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},attributeName:{get:function(){return this._attributeName}},glslDatatype:{get:function(){return this._glslDatatype}}});_5.prototype.getFragmentShaderSource=ua.prototype.getFragmentShaderSource;_5.prototype.isTranslucent=ua.prototype.isTranslucent;_5.prototype.getRenderState=ua.prototype.getRenderState;var Blt=_5;var Z3o=R(W(),1);function Kj(t){t=f(t,f.EMPTY_OBJECT),this.length=f(t.length,1e7),this._length=void 0,this.width=f(t.width,2),this._width=void 0,this.show=f(t.show,!0),this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._modelMatrix=new L,this.id=t.id,this._id=void 0,this._primitive=void 0,this.entity=t.entity}Kj.prototype.update=function(t){if(!this.show)return;let e=this.modelMatrix;if(this.entity&&typeof this.entity.computeModelMatrix=="function"&&(e=this.entity.computeModelMatrix(t.time)||e),!c(this._primitive)||!L.equals(this._modelMatrix,e)||this._length!==this.length||this._width!==this.width||this._id!==this.id){this._modelMatrix=L.clone(e,this._modelMatrix),this._length=this.length,this._width=this.width,this._id=this.id,c(this._primitive)&&this._primitive.destroy(),e[12]===0&&e[13]===0&&e[14]===0&&(e[14]=.01);let n=new $e({geometry:new j0({positions:[p.ZERO,p.UNIT_X],width:this.width,vertexFormat:Ul.VERTEX_FORMAT,colors:[v.RED,v.RED],arcType:Ln.NONE}),modelMatrix:L.multiplyByUniformScale(e,this.length,new L),id:this.id,pickPrimitive:this}),i=new $e({geometry:new j0({positions:[p.ZERO,p.UNIT_Y],width:this.width,vertexFormat:Ul.VERTEX_FORMAT,colors:[v.GREEN,v.GREEN],arcType:Ln.NONE}),modelMatrix:L.multiplyByUniformScale(e,this.length,new L),id:this.id,pickPrimitive:this}),o=new $e({geometry:new j0({positions:[p.ZERO,p.UNIT_Z],width:this.width,vertexFormat:Ul.VERTEX_FORMAT,colors:[v.BLUE,v.BLUE],arcType:Ln.NONE}),modelMatrix:L.multiplyByUniformScale(e,this.length,new L),id:this.id,pickPrimitive:this});this._primitive=new Wi({geometryInstances:[n,i,o],appearance:new Ul,asynchronous:!1})}this._primitive.update(t)};Kj.prototype.isDestroyed=function(){return!1};Kj.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),At(this)};var D5=Kj;var f3o=R(W(),1);function jMe(t){this.direction=p.clone(t.direction),this.color=v.clone(f(t.color,v.WHITE)),this.intensity=f(t.intensity,1)}var Qlt=jMe;var B3o=R(W(),1);var U3o=R(W(),1),O5=`in vec3 v_positionMC; +}`;this.material=void 0,this.translucent=f(t.translucent,!1),this._vertexShaderSource=f(t.vertexShaderSource,s),this._fragmentShaderSource=f(t.fragmentShaderSource,l),this._renderState=Va.getDefaultRenderState(!1,!1,t.renderState),this._closed=f(t.closed,!1),this._attributeName=e,this._glslDatatype=i}Object.defineProperties(_5.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},attributeName:{get:function(){return this._attributeName}},glslDatatype:{get:function(){return this._glslDatatype}}});_5.prototype.getFragmentShaderSource=Va.prototype.getFragmentShaderSource;_5.prototype.isTranslucent=Va.prototype.isTranslucent;_5.prototype.getRenderState=Va.prototype.getRenderState;var Blt=_5;var uKo=b(W(),1);function Kj(t){t=f(t,f.EMPTY_OBJECT),this.length=f(t.length,1e7),this._length=void 0,this.width=f(t.width,2),this._width=void 0,this.show=f(t.show,!0),this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._modelMatrix=new L,this.id=t.id,this._id=void 0,this._primitive=void 0,this.entity=t.entity}Kj.prototype.update=function(t){if(!this.show)return;let e=this.modelMatrix;if(this.entity&&typeof this.entity.computeModelMatrix=="function"&&(e=this.entity.computeModelMatrix(t.time)||e),!c(this._primitive)||!L.equals(this._modelMatrix,e)||this._length!==this.length||this._width!==this.width||this._id!==this.id){this._modelMatrix=L.clone(e,this._modelMatrix),this._length=this.length,this._width=this.width,this._id=this.id,c(this._primitive)&&this._primitive.destroy(),e[12]===0&&e[13]===0&&e[14]===0&&(e[14]=.01);let n=new $e({geometry:new j0({positions:[p.ZERO,p.UNIT_X],width:this.width,vertexFormat:Ul.VERTEX_FORMAT,colors:[v.RED,v.RED],arcType:Ln.NONE}),modelMatrix:L.multiplyByUniformScale(e,this.length,new L),id:this.id,pickPrimitive:this}),i=new $e({geometry:new j0({positions:[p.ZERO,p.UNIT_Y],width:this.width,vertexFormat:Ul.VERTEX_FORMAT,colors:[v.GREEN,v.GREEN],arcType:Ln.NONE}),modelMatrix:L.multiplyByUniformScale(e,this.length,new L),id:this.id,pickPrimitive:this}),o=new $e({geometry:new j0({positions:[p.ZERO,p.UNIT_Z],width:this.width,vertexFormat:Ul.VERTEX_FORMAT,colors:[v.BLUE,v.BLUE],arcType:Ln.NONE}),modelMatrix:L.multiplyByUniformScale(e,this.length,new L),id:this.id,pickPrimitive:this});this._primitive=new Wi({geometryInstances:[n,i,o],appearance:new Ul,asynchronous:!1})}this._primitive.update(t)};Kj.prototype.isDestroyed=function(){return!1};Kj.prototype.destroy=function(){return this._primitive=this._primitive&&this._primitive.destroy(),At(this)};var D5=Kj;var fKo=b(W(),1);function jMe(t){this.direction=p.clone(t.direction),this.color=v.clone(f(t.color,v.WHITE)),this.intensity=f(t.intensity,1)}var Qlt=jMe;var BKo=b(W(),1);var UKo=b(W(),1),O5=`in vec3 v_positionMC; in vec3 v_positionEC; in vec2 v_st; @@ -15361,7 +15361,7 @@ void main() out_FragColor = czm_phong(normalize(positionToEyeEC), material, czm_lightDirectionEC); #endif } -`;var A3o=R(W(),1),H5=`in vec3 position3DHigh; +`;var AKo=b(W(),1),H5=`in vec3 position3DHigh; in vec3 position3DLow; in vec2 st; in float batchId; @@ -15380,7 +15380,7 @@ void main() gl_Position = czm_modelViewProjectionRelativeToEye * p; } -`;function tg(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.translucent,!0),n=f(t.aboveGround,!1);this.material=c(t.material)?t.material:eo.fromType(eo.ColorType),this.translucent=f(t.translucent,!0),this._vertexShaderSource=f(t.vertexShaderSource,H5),this._fragmentShaderSource=f(t.fragmentShaderSource,O5),this._renderState=ua.getDefaultRenderState(e,!n,t.renderState),this._closed=!1,this._flat=f(t.flat,!1),this._faceForward=f(t.faceForward,n),this._aboveGround=n}Object.defineProperties(tg.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},vertexFormat:{get:function(){return tg.VERTEX_FORMAT}},flat:{get:function(){return this._flat}},faceForward:{get:function(){return this._faceForward}},aboveGround:{get:function(){return this._aboveGround}}});tg.VERTEX_FORMAT=ee.POSITION_AND_ST;tg.prototype.getFragmentShaderSource=ua.prototype.getFragmentShaderSource;tg.prototype.isTranslucent=ua.prototype.isTranslucent;tg.prototype.getRenderState=ua.prototype.getRenderState;var klt=tg;var w3o=R(W(),1);function w5(t){if(t=f(t,f.EMPTY_OBJECT),!c(t.id))throw new Ut("options.id is required.");if(!c(EH[t.id]))throw new Ut(`options.id ${t.id} is not found in embedded imagery provider`);if(!c(t.path))throw new Ut("options.path is required.");if(!c(EH[t.id][`/${t.path}/0/0/0.jpg`]))throw new Ut(`options.path ${t.path} is not found in embedded imagery provider`);this._staticImagerySource=EH[t.id],this._staticImageryPath=t.path,this._tilingScheme=this._staticImagerySource.tilemapresource.TileMap.SRS.indexOf("4326")>-1?new Qo({ellipsoid:mt.WGS84}):new Gs({ellipsoid:mt.WGS84}),this._reverseY=!(this._staticImagerySource.tilemapresource.TileMap.SRS.indexOf("4326")>-1);let{width:e,height:n}=this._staticImagerySource.tilemapresource.TileMap.TileFormat[0].$;this._tileWidth=e,this._tileHeight=n,this._minimumLevel=0,this._maximumLevel=this._staticImagerySource.tilemapresource.TileMap.TileSets[0].TileSet.length-1,this._rectangle=this._tilingScheme.rectangle,this._errorEvent=new It;let i=t.credit;this._credit=typeof i=="string"?new on(i):i,this._readyPromise=kd()}function qMe(t,e,n,i,o,a){let s=t._staticImagerySource[`/${t._staticImageryPath}/${i}/${e}/${n}.jpg`];return s?te.fetchImage({url:s}):null}Object.defineProperties(w5.prototype,{url:{get:function(){return this._resource.url}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return this._minimumLevel}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},format:{get:function(){return this._format}},ready:{value:!0},readyPromise:{get:function(){return this._readyPromise.promise}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return!0}},clock:{get:function(){return this._timeDynamicImagery.clock},set:function(t){this._timeDynamicImagery.clock=t}},times:{get:function(){return this._timeDynamicImagery.times},set:function(t){this._timeDynamicImagery.times=t}}});w5.prototype.getTileCredits=function(t,e,n){};w5.prototype.pickFeatures=function(t,e,n,i,o){};w5.prototype.requestImage=function(t,e,n,i){let o,a;return this._reverseY&&(e=this.tilingScheme.getNumberOfYTilesAtLevel(n)-e-1),c(o)||(o=qMe(this,t,e,n,i,a)),o};var Ylt=w5;var tzo=R(W(),1);function oh(t){this._scene=t.scene,this.samplingWindow=f(t.samplingWindow,oh.defaultSettings.samplingWindow),this.quietPeriod=f(t.quietPeriod,oh.defaultSettings.quietPeriod),this.warmupPeriod=f(t.warmupPeriod,oh.defaultSettings.warmupPeriod),this.minimumFrameRateDuringWarmup=f(t.minimumFrameRateDuringWarmup,oh.defaultSettings.minimumFrameRateDuringWarmup),this.minimumFrameRateAfterWarmup=f(t.minimumFrameRateAfterWarmup,oh.defaultSettings.minimumFrameRateAfterWarmup),this._lowFrameRate=new It,this._nominalFrameRate=new It,this._frameTimes=[],this._needsQuietPeriod=!0,this._quietPeriodEndTime=0,this._warmupPeriodEndTime=0,this._frameRateIsLow=!1,this._lastFramesPerSecond=void 0,this._pauseCount=0;let e=this;this._preUpdateRemoveListener=this._scene.preUpdate.addEventListener(function(o,a){$Me(e,a)}),this._hiddenPropertyName=document.hidden!==void 0?"hidden":document.mozHidden!==void 0?"mozHidden":document.msHidden!==void 0?"msHidden":document.webkitHidden!==void 0?"webkitHidden":void 0;let n=document.hidden!==void 0?"visibilitychange":document.mozHidden!==void 0?"mozvisibilitychange":document.msHidden!==void 0?"msvisibilitychange":document.webkitHidden!==void 0?"webkitvisibilitychange":void 0;function i(){t_e(e)}this._visibilityChangeRemoveListener=void 0,c(n)&&(document.addEventListener(n,i,!1),this._visibilityChangeRemoveListener=function(){document.removeEventListener(n,i,!1)})}oh.defaultSettings={samplingWindow:5,quietPeriod:2,warmupPeriod:5,minimumFrameRateDuringWarmup:4,minimumFrameRateAfterWarmup:8};oh.fromScene=function(t){return(!c(t._frameRateMonitor)||t._frameRateMonitor.isDestroyed())&&(t._frameRateMonitor=new oh({scene:t})),t._frameRateMonitor};Object.defineProperties(oh.prototype,{scene:{get:function(){return this._scene}},lowFrameRate:{get:function(){return this._lowFrameRate}},nominalFrameRate:{get:function(){return this._nominalFrameRate}},lastFramesPerSecond:{get:function(){return this._lastFramesPerSecond}}});oh.prototype.pause=function(){++this._pauseCount,this._pauseCount===1&&(this._frameTimes.length=0,this._lastFramesPerSecond=void 0)};oh.prototype.unpause=function(){--this._pauseCount,this._pauseCount<=0&&(this._pauseCount=0,this._needsQuietPeriod=!0)};oh.prototype.isDestroyed=function(){return!1};oh.prototype.destroy=function(){return this._preUpdateRemoveListener(),c(this._visibilityChangeRemoveListener)&&this._visibilityChangeRemoveListener(),At(this)};function $Me(t,e){if(t._pauseCount>0)return;let n=Oi();if(t._needsQuietPeriod)t._needsQuietPeriod=!1,t._frameTimes.length=0,t._quietPeriodEndTime=n+t.quietPeriod/xi.SECONDS_PER_MILLISECOND,t._warmupPeriodEndTime=t._quietPeriodEndTime+(t.warmupPeriod+t.samplingWindow)/xi.SECONDS_PER_MILLISECOND;else if(n>=t._quietPeriodEndTime){t._frameTimes.push(n);let i=n-t.samplingWindow/xi.SECONDS_PER_MILLISECOND;if(t._frameTimes.length>=2&&t._frameTimes[0]<=i){for(;t._frameTimes.length>=2&&t._frameTimes[1]<i;)t._frameTimes.shift();let o=(n-t._frameTimes[0])/(t._frameTimes.length-1);t._lastFramesPerSecond=1e3/o;let a=1e3/(n>t._warmupPeriodEndTime?t.minimumFrameRateAfterWarmup:t.minimumFrameRateDuringWarmup);o>a?t._frameRateIsLow||(t._frameRateIsLow=!0,t._needsQuietPeriod=!0,t.lowFrameRate.raiseEvent(t.scene,t._lastFramesPerSecond)):t._frameRateIsLow&&(t._frameRateIsLow=!1,t._needsQuietPeriod=!0,t.nominalFrameRate.raiseEvent(t.scene,t._lastFramesPerSecond))}}}function t_e(t){document[t._hiddenPropertyName]?t.pause():t.unpause()}var P5=oh;var uzo=R(W(),1);var B2t=R(wst(),1);function xlt(){this._image=new Image}xlt.prototype.isReady=function(){return!0};xlt.prototype.shouldDiscardImage=function(t){return t===this._image};function eg(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._tileDiscardPolicy=t.tileDiscardPolicy,this._tilingScheme=new Qo({numberOfLevelZeroTilesX:2,numberOfLevelZeroTilesY:2,rectangle:new Gt(-k.PI,-k.PI,k.PI,k.PI),ellipsoid:t.ellipsoid});let e=t.credit;typeof e=="string"&&(e=new on(e)),this._credit=e,this._tileWidth=256,this._tileHeight=256,this._maximumLevel=23,c(this._tileDiscardPolicy)||(this._tileDiscardPolicy=new xlt),this._errorEvent=new It}Object.defineProperties(eg.prototype,{url:{get:function(){return this._metadata.url}},proxy:{get:function(){return this._metadata.proxy}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return 0}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return!1}}});eg.fromMetadata=function(t,e){if(!t.imageryPresent)throw new St(`The server ${t.url} doesn't have imagery`);let n=new eg(e);return n._metadata=t,n};eg.prototype.getTileCredits=function(t,e,n){let i=this._metadata,o=i.getTileInformation(t,e,n);if(c(o)){let a=i.providers[o.imageryProvider];if(c(a))return[a]}};eg.prototype.requestImage=function(t,e,n,i){let o=this._tileDiscardPolicy._image,a=this._metadata,s=EW.tileXYToQuadKey(t,e,n),l=a.getTileInformation(t,e,n);if(!c(l)){if(a.isValid(s)){let d=new Zs({throttle:i.throttle,throttleByServer:i.throttleByServer,type:i.type,priorityFunction:i.priorityFunction});a.populateSubtree(t,e,n,d);return}return Promise.resolve(o)}if(!l.hasImagery())return Promise.resolve(o);let r=e_e(this,l,t,e,n,i).fetchArrayBuffer();if(c(r))return r.then(function(d){Q5(a.key,d);let m=new Uint8Array(d),h,Z=a.protoImagery;if((!c(Z)||!Z)&&(h=n_e(m)),!c(h)&&(!c(Z)||Z)){let b=i_e(m);h=b.imageType,m=b.imageData}return!c(h)||!c(m)?o:ZA({uint8Array:m,format:h,flipY:!0})})};eg.prototype.pickFeatures=function(t,e,n,i,o){};function e_e(t,e,n,i,o,a){let s=EW.tileXYToQuadKey(n,i,o),l=e.imageryVersion;return l=c(l)&&l>0?l:1,t._metadata.resource.getDerivedResource({url:`flatfile?f1-0${s}-i.${l.toString()}`,request:a})}function n_e(t){let e="JFIF";if(t[6]===e.charCodeAt(0)&&t[7]===e.charCodeAt(1)&&t[8]===e.charCodeAt(2)&&t[9]===e.charCodeAt(3))return"image/jpeg";let n="PNG";if(t[1]===n.charCodeAt(0)&&t[2]===n.charCodeAt(1)&&t[3]===n.charCodeAt(2))return"image/png"}function i_e(t){let e=B2t.Reader.create(t),n=e.len,i={};for(;e.pos<n;){let s=e.uint32(),l;switch(s>>>3){case 1:i.imageType=e.uint32();break;case 2:i.imageData=e.bytes();break;case 3:i.alphaType=e.uint32();break;case 4:i.imageAlpha=e.bytes();break;case 5:if(l=i.copyrightIds,c(l)||(l=i.copyrightIds=[]),(s&7)===2){let r=e.uint32()+e.pos;for(;e.pos<r;)l.push(e.uint32())}else l.push(e.uint32());break;default:e.skipType(s&7);break}}let o=i.imageType;if(c(o))switch(o){case 0:i.imageType="image/jpeg";break;case 4:i.imageType="image/png";break;default:throw new St("GoogleEarthEnterpriseImageryProvider: Unsupported image type.")}let a=i.alphaType;return c(a)&&a!==0&&(console.log("GoogleEarthEnterpriseImageryProvider: External alpha not supported."),delete i.alphaType,delete i.imageAlpha),i}var Xlt=eg;var Fzo=R(W(),1);var o_e=new v(1,1,1,.4),a_e=new v(0,1,0,.05),s_e=new v(0,.5,0,.2);function ng(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._tilingScheme=c(t.tilingScheme)?t.tilingScheme:new Qo({ellipsoid:t.ellipsoid}),this._cells=f(t.cells,8),this._color=f(t.color,o_e),this._glowColor=f(t.glowColor,a_e),this._glowWidth=f(t.glowWidth,6),this._backgroundColor=f(t.backgroundColor,s_e),this._errorEvent=new It,this._tileWidth=f(t.tileWidth,256),this._tileHeight=f(t.tileHeight,256),this._canvasSize=f(t.canvasSize,256),this._canvas=this._createGridCanvas()}Object.defineProperties(ng.prototype,{proxy:{get:function(){}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){}},minimumLevel:{get:function(){}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){}},hasAlphaChannel:{get:function(){return!0}}});ng.prototype._drawGrid=function(t){let n=this._canvasSize;for(let i=0;i<=this._cells;++i){let a=1+i/this._cells*(n-1);t.moveTo(a,0),t.lineTo(a,n),t.moveTo(0,a),t.lineTo(n,a)}t.stroke()};ng.prototype._createGridCanvas=function(){let t=document.createElement("canvas");t.width=this._canvasSize,t.height=this._canvasSize;let e=0,n=this._canvasSize,i=t.getContext("2d"),o=this._backgroundColor.toCssColorString();i.fillStyle=o,i.fillRect(e,e,n,n);let a=this._glowColor.toCssColorString();i.strokeStyle=a,i.lineWidth=this._glowWidth,i.strokeRect(e,e,n,n),this._drawGrid(i),i.lineWidth=this._glowWidth*.5,i.strokeRect(e,e,n,n),this._drawGrid(i);let s=this._color.toCssColorString();return i.strokeStyle=s,i.lineWidth=2,i.strokeRect(e,e,n,n),i.lineWidth=1,this._drawGrid(i),t};ng.prototype.getTileCredits=function(t,e,n){};ng.prototype.requestImage=function(t,e,n,i){return Promise.resolve(this._canvas)};ng.prototype.pickFeatures=function(t,e,n,i,o){};var Jlt=ng;var i4o=R(W(),1);var Ejo=R(W(),1);var cjo=R(W(),1);var Nzo=R(W(),1);function bV(){}bV._maxDecodingConcurrency=Math.max(In.hardwareConcurrency-1,1);bV._decodeTaskProcessor=new $i("decodeI3S",bV._maxDecodingConcurrency);bV._promise=void 0;async function l_e(){if(await bV._decodeTaskProcessor.initWebAssemblyModule({wasmBinaryFile:"ThirdParty/draco_decoder.wasm"}))return bV._decodeTaskProcessor;throw new St("I3S decoder could not be initialized.")}bV.decode=async function(t,e,n,i,o){return c(bV._promise)||(bV._promise=l_e()),bV._promise.then(function(a){let s=n._parent._data,l=n._parent._inverseRotationMatrix,r=0,d=0,m=0;c(s.obb)?(r=s.obb.center[0],d=s.obb.center[1],m=s.obb.center[2]):c(s.mbs)&&(r=s.mbs[0],d=s.mbs[1],m=s.mbs[2]);let h=ot.fromRotationX(-k.PI_OVER_TWO),Z=new ot;ot.multiply(h,l,Z);let b=gt.fromDegrees(r,d,m),u=mt.WGS84.cartographicToCartesian(b),F={binaryData:n._data,featureData:c(i)&&c(i[0])?i[0].data:void 0,schema:e,bufferInfo:n._geometryBufferInfo,ellipsoidRadiiSquare:mt.WGS84.radiiSquared,url:t,geoidDataList:n._dataProvider._geoidDataList,cartographicCenter:b,cartesianCenter:u,parentRotation:Z,enableFeatures:n._dataProvider.showFeatures,splitGeometryByColorTransparency:n._dataProvider.adjustMaterialAlphaMode,symbologyData:o,calculateNormals:n._dataProvider.calculateNormals};return a.scheduleTask(F)})};var v5=bV;var kzo=R(W(),1);function Llt(t,e){this._parent=t,this._dataProvider=t._dataProvider,this._layer=t._layer,c(this._parent._nodeIndex)?this._resource=this._parent._layer.resource.getDerivedResource({url:`nodes/${this._parent._data.mesh.attribute.resource}/${e}`}):this._resource=this._parent.resource.getDerivedResource({url:e})}Object.defineProperties(Llt.prototype,{resource:{get:function(){return this._resource}},data:{get:function(){return this._data}}});Llt.prototype.load=async function(){return this._data=await RV.loadJson(this._resource),this._data};var K5=Llt;var Jzo=R(W(),1);function CW(t,e){this._storageInfo=e,this._parent=t,this._dataProvider=t._dataProvider,this._loadPromise=void 0;let n=`attributes/${e.key}/0`;c(this._parent._nodeIndex)?this._resource=this._parent._layer.resource.getDerivedResource({url:`nodes/${this._parent._data.mesh.attribute.resource}/${n}`}):this._resource=this._parent.resource.getDerivedResource({url:n})}Object.defineProperties(CW.prototype,{resource:{get:function(){return this._resource}},header:{get:function(){return this._header}},values:{get:function(){if(c(this._values)){if(c(this._values.attributeValues))return this._values.attributeValues;if(c(this._values.objectIds))return this._values.objectIds}return[]}},name:{get:function(){return this._storageInfo.name}}});function zj(t){return t==="UInt8"||t==="Int8"?1:t==="UInt16"||t==="Int16"?2:t==="UInt32"||t==="Int32"||t==="Oid32"||t==="Float32"?4:t==="UInt64"||t==="Int64"||t==="Float64"?8:0}function r_e(t){return t==="String"?1:zj(t)}async function d_e(t){let e=await t._dataProvider._loadBinary(t._resource),n=new DataView(e);t._data=e,t._validateHeader(n);let i=t._parseHeader(n),o=t._getBodyOffset(i);t._validateBody(n,o),t._parseBody(n,o)}CW.prototype.load=function(){return c(this._loadPromise)?this._loadPromise:(this._loadPromise=d_e(this).catch(function(t){console.error(t)}),this._loadPromise)};CW.prototype._parseValue=function(t,e,n){let i;if(e==="UInt8")i=t.getUint8(n),n+=1;else if(e==="Int8")i=t.getInt8(n),n+=1;else if(e==="UInt16")i=t.getUint16(n,!0),n+=2;else if(e==="Int16")i=t.getInt16(n,!0),n+=2;else if(e==="UInt32")i=t.getUint32(n,!0),n+=4;else if(e==="Oid32")i=t.getUint32(n,!0),n+=4;else if(e==="Int32")i=t.getInt32(n,!0),n+=4;else if(e==="UInt64"){let o=t.getUint32(n,!0),a=t.getUint32(n+4,!0);i=o+Math.pow(2,32)*a,n+=8}else if(e==="Int64"){let o=t.getUint32(n,!0),a=t.getUint32(n+4,!0);a<Math.pow(2,31)?i=o+Math.pow(2,32)*a:i=o+Math.pow(2,32)*(a-Math.pow(2,32)),n+=8}else e==="Float32"?(i=t.getFloat32(n,!0),n+=4):e==="Float64"?(i=t.getFloat64(n,!0),n+=8):e==="String"&&(i=String.fromCharCode(t.getUint8(n)),n+=1);return{value:i,offset:n}};CW.prototype._parseHeader=function(t){let e=0;this._header={};for(let n=0;n<this._storageInfo.header.length;n++){let i=this._storageInfo.header[n],o=this._parseValue(t,i.valueType,e);this._header[i.property]=o.value,e=o.offset}return e};CW.prototype._parseBody=function(t,e){this._values={};for(let n=0;n<this._storageInfo.ordering.length;n++){let i=this._storageInfo.ordering[n],o=i==="ObjectIds"?"objectIds":i,a=this._storageInfo[o];if(c(a)){this._values[o]=[];for(let s=0;s<this._header.count;++s)if(a.valueType!=="String"){let l=this._parseValue(t,a.valueType,e);this._values[o].push(l.value),e=l.offset}else{let l=this._values.attributeByteCounts[s],r="";for(let d=0;d<l;++d){let m=this._parseValue(t,a.valueType,e);m.value.charCodeAt(0)!==0&&(r+=m.value),e=m.offset}this._values[o].push(r)}}}};CW.prototype._getBodyOffset=function(t){let e=0;return c(this._storageInfo.attributeValues)?e=zj(this._storageInfo.attributeValues.valueType):c(this._storageInfo.objectIds)&&(e=zj(this._storageInfo.objectIds.valueType)),e>0?Math.ceil(t/e)*e:t};CW.prototype._validateHeader=function(t){let e=0;for(let n=0;n<this._storageInfo.header.length;n++){let i=this._storageInfo.header[n];e+=r_e(i.valueType)}if(t.byteLength<e)throw new St(`Invalid attribute buffer size (field: ${this.name}, header: ${e}, actual: ${t.byteLength})`)};CW.prototype._validateBody=function(t,e){if(!c(this._header.count))throw new St(`Invalid attribute buffer (field: ${this.name}, count is missing)`);let n;for(let i=0;i<this._storageInfo.ordering.length&&e<t.byteLength;i++){let o=this._storageInfo.ordering[i],a=o==="ObjectIds"?"objectIds":o,s=this._storageInfo[a];if(c(s))if(s.valueType!=="String"){a==="attributeByteCounts"&&(n=e);let l=zj(s.valueType);e+=l*this._header.count}else{if(!c(n))throw new St(`Invalid attribute buffer (field: ${this.name}, attributeByteCounts is missing)`);for(let l=0;l<this._header.count&&e<t.byteLength;++l){let r=this._parseValue(t,this._storageInfo.attributeByteCounts.valueType,n);e+=r.value,n=r.offset}}else throw new St(`Invalid attribute buffer (field: ${this.name}, ${a} is missing)`)}if(t.byteLength<e)throw new St(`Invalid attribute buffer size (field: ${this.name}, expected: ${e}, actual: ${t.byteLength})`)};var z5=CW;var wzo=R(W(),1);function j5(t,e){let n=t._dataProvider,i=t._layer,o;c(t._nodeIndex)?o=i.resource.getDerivedResource({url:`nodes/${t._data.mesh.geometry.resource}/${e}`}):o=t.resource.getDerivedResource({url:e}),this._parent=t,this._dataProvider=n,this._layer=i,this._resource=o,this._customAttributes=void 0}Object.defineProperties(j5.prototype,{resource:{get:function(){return this._resource}},data:{get:function(){return this._data}},customAttributes:{get:function(){return this._customAttributes}}});j5.prototype.load=function(){let t=this;return this._dataProvider._loadBinary(this._resource).then(function(e){return t._data=e,e})};var c_e=new p,m_e=new p,h_e=new p,p_e=new p,u_e=new p;function Mlt(t,e,n,i){let o=p.subtract(i,n,c_e),a=p.cross(o,p.subtract(t,n,m_e),p_e),s=p.cross(o,p.subtract(e,n,h_e),u_e);return p.dot(a,s)>=0}var Z_e=new p,V_e=new p,b_e=new p,R_e=new p,W_e=new p,f_e=new p,F_e=new p,U_e=new p,G_e=new p,A_e=new p;j5.prototype.getClosestPointIndexOnTriangle=function(t,e,n){if(c(this._customAttributes)&&c(this._customAttributes.positions)){let i=new p(t,e,n);i.x-=this._customAttributes.cartesianCenter.x,i.y-=this._customAttributes.cartesianCenter.y,i.z-=this._customAttributes.cartesianCenter.z,ot.multiplyByVector(this._customAttributes.parentRotation,i,i);let o=Number.MAX_VALUE,a,s,l,r,d=this._customAttributes.positions,m=this._customAttributes.indices,h;c(m)?h=m.length:h=d.length/3;for(let Z=0;Z<h;Z++){let b,u,F;c(m)?(b=m[Z],u=m[Z+1],F=m[Z+2]):(b=Z*3,u=Z*3+1,F=Z*3+2);let U=p.fromElements(d[b*3],d[b*3+1],d[b*3+2],Z_e),G=p.fromElements(d[u*3],d[u*3+1],d[u*3+2],V_e),A=new p(d[F*3],d[F*3+1],d[F*3+2],b_e);if(!Mlt(i,U,G,A)||!Mlt(i,G,U,A)||!Mlt(i,A,U,G))continue;let T=p.subtract(G,U,R_e),g=p.subtract(A,U,W_e),C=p.cross(T,g,f_e);if(p.magnitude(C)===0)continue;let y=p.normalize(C,F_e),Y=p.subtract(i,U,U_e),Q=Math.abs(p.dot(Y,y));if(Q<o){o=Q,a=Z;let J=p.magnitudeSquared(p.subtract(i,U,Y)),M=p.magnitudeSquared(p.subtract(i,G,G_e)),V=p.magnitudeSquared(p.subtract(i,A,A_e));J<M&&J<V?(l=b,r=U,s=J):M<V?(l=u,r=G,s=M):(l=F,r=A,s=V)}}if(c(a))return{index:l,distanceSquared:s,distance:Math.sqrt(s),queriedPosition:i,closestPosition:p.clone(r)}}return{index:-1,distanceSquared:Number.Infinity,distance:Number.Infinity}};function Q2t(t){let e=[],n=t.length;for(let i=0;i<n;i++)i<3?e.push(jS(t[i])):e.push(t[i]);return e}j5.prototype._generateGltf=function(t,e,n,i,o,a,s,l){let r={pbrMetallicRoughness:{metallicFactor:0},doubleSided:!0,name:"Material"},d=!1,m,h="";if(c(this._parent._data.mesh)&&c(this._layer._data.materialDefinitions)){let T=this._parent._data.mesh.material.definition;if(T>=0&&T<this._layer._data.materialDefinitions.length){if(m=this._layer._data.materialDefinitions[T],r=m,c(r.pbrMetallicRoughness)&&c(r.pbrMetallicRoughness.baseColorTexture)){d=!0,r.pbrMetallicRoughness.baseColorTexture.index=0;let g="0";if(c(this._layer._data.textureSetDefinitions))for(let C=0;C<this._layer._data.textureSetDefinitions.length;C++){let y=this._layer._data.textureSetDefinitions[C];for(let Y=0;Y<y.formats.length;Y++){let Q=y.formats[Y];if(Q.format==="jpg"){g=Q.name;break}}}c(this._parent._data.mesh)&&this._parent._data.mesh.material.resource>=0&&(h=this._layer.resource.getDerivedResource({url:`nodes/${this._parent._data.mesh.material.resource}/textures/${g}`}).url)}c(r.pbrMetallicRoughness)&&c(r.pbrMetallicRoughness.baseColorFactor)&&(r.pbrMetallicRoughness.baseColorFactor=Q2t(r.pbrMetallicRoughness.baseColorFactor)),c(r.emissiveFactor)&&(r.emissiveFactor=Q2t(r.emissiveFactor))}}else c(this._parent._data.textureData)&&(d=!0,h=this._parent.resource.getDerivedResource({url:`${this._parent._data.textureData[0].href}`}).url,r.pbrMetallicRoughness.baseColorTexture={index:0});c(r.alphaMode)&&(r.alphaMode=r.alphaMode.toUpperCase());let Z=[],b=[],u=[];d&&(Z=[{sampler:0,source:0}],b=[{uri:h}],u=[{magFilter:9729,minFilter:9986,wrapS:10497,wrapT:10497}]);let F=[],U=n.length;for(let A=0;A<U;A++){let T=n[A].primitives,g=T.length;for(let C=0;C<g;C++){let y=T[C];if(c(y.material)){for(;y.material>=F.length;){let Q=be(r,!0);F.push(Q)}let Y=F[y.material];c(y.extra)&&y.extra.isTransparent?c(Y.alphaMode)||(Y.alphaMode="BLEND"):Y.alphaMode==="BLEND"&&(Y.alphaMode="OPAQUE")}}}return{scene:0,scenes:[{nodes:t}],nodes:e,meshes:n,buffers:i,bufferViews:o,accessors:a,materials:F,textures:Z,images:b,samplers:u,asset:{version:"2.0"},extensions:s,extensionsUsed:l}};var hN=j5;function bc(t,e,n){let i,o,a,s;n?(i=0,o=t):(i=t._level+1,o=t._layer),typeof e=="number"?a=e:s=t.resource.getDerivedResource({url:`${e}/`}),this._parent=t,this._dataProvider=t._dataProvider,this._isRoot=n,this._level=i,this._layer=o,this._nodeIndex=a,this._resource=s,this._isLoading=!1,this._tile=void 0,this._data=void 0,this._geometryData=[],this._featureData=[],this._fields={},this._children=[],this._childrenReadyPromise=void 0,this._globalTransform=void 0,this._inverseGlobalTransform=void 0,this._inverseRotationMatrix=void 0,this._symbologyData=void 0}Object.defineProperties(bc.prototype,{resource:{get:function(){return this._resource}},layer:{get:function(){return this._layer}},parent:{get:function(){return this._parent}},children:{get:function(){return this._children}},geometryData:{get:function(){return this._geometryData}},featureData:{get:function(){return this._featureData}},fields:{get:function(){return this._fields}},tile:{get:function(){return this._tile}},data:{get:function(){return this._data}}});bc.prototype.load=async function(){let t=this;function e(){if(!t._isRoot){let o=t._create3DTileDefinition();t._tile=new iu(t._layer._tileset,t._dataProvider.resource,o,t._parent._tile),t._tile._i3sNode=t}}if(!c(this._nodeIndex)){let o=await RV.loadJson(this._resource);t._data=o,e();return}let n=await this._layer._getNodeInNodePages(this._nodeIndex);t._data=n;let i;t._isRoot?i="nodes/root/":c(n.mesh)&&(i=`../${n.mesh.geometry.resource}/`),c(i)&&(t._resource=t._parent.resource.getDerivedResource({url:i})),e()};function k2t(t,e){let n=new z5(t,e);return t._fields[e.name]=n,n.load()}bc.prototype.loadFields=function(){let t=this._layer._data.attributeStorageInfo,e=[];if(c(t))for(let n=0;n<t.length;n++){let i=t[n],o=this._fields[i.name];c(o)?e.push(o.load()):e.push(k2t(this,i))}return Promise.all(e)};bc.prototype.loadField=function(t){let e=this._fields[t];if(c(e))return e.load();let n=this._layer._data.attributeStorageInfo;if(c(n))for(let i=0;i<n.length;i++){let o=n[i];if(o.name===t)return k2t(this,o)}return Promise.resolve()};bc.prototype.getFieldsForPickedPosition=function(t){let e=this.geometryData[0];if(!c(e.customAttributes.featureIndex))return{};let n=e.getClosestPointIndexOnTriangle(t.x,t.y,t.z);if(n.index===-1||n.index>e.customAttributes.featureIndex.length)return{};let i=e.customAttributes.featureIndex[n.index];return this.getFieldsForFeature(i)};bc.prototype.getFieldsForFeature=function(t){let e={};for(let n in this.fields)if(this.fields.hasOwnProperty(n)){let i=this.fields[n];t>=0&&t<i.values.length&&(e[i.name]=i.values[t])}return e};bc.prototype._loadChildren=function(){let t=this;if(c(this._childrenReadyPromise))return this._childrenReadyPromise;let e=[];if(c(t._data.children))for(let n=0;n<t._data.children.length;n++){let i=t._data.children[n],o=new bc(t,f(i.href,i),!1);t._children.push(o),e.push(o.load())}return this._childrenReadyPromise=Promise.all(e).then(function(){for(let n=0;n<t._children.length;n++)t._tile.children.push(t._children[n]._tile)}),this._childrenReadyPromise};bc.prototype._loadGeometryData=function(){let t=[];if(c(this._data.geometryData))for(let e=0;e<this._data.geometryData.length;e++){let n=new hN(this,this._data.geometryData[e].href);this._geometryData.push(n),t.push(n.load())}else if(c(this._data.mesh)){let e=this._layer._findBestGeometryBuffers(this._data.mesh.geometry.definition,["position","uv0"]),n=`./geometries/${e.bufferIndex}/`,i=new hN(this,n);i._geometryDefinitions=e.definition,i._geometryBufferInfo=e.geometryBufferInfo,this._geometryData.push(i),t.push(i.load())}return Promise.all(t)};bc.prototype._loadFeatureData=function(){let t=[];if(c(this._data.featureData))for(let e=0;e<this._data.featureData.length;e++){let n=new K5(this,this._data.featureData[e].href);this._featureData.push(n),t.push(n.load())}return Promise.all(t)};bc.prototype._clearGeometryData=function(){this._geometryData=[]};bc.prototype._create3DTileDefinition=function(){let t=this._data.obb,e=this._data.mbs;if(!c(t)&&!c(e)){console.error("Failed to load I3S node. Bounding volume is required.");return}let n;if(c(t)?n=gt.fromDegrees(t.center[0],t.center[1],t.center[2]):n=gt.fromDegrees(e[0],e[1],e[2]),c(this._dataProvider._geoidDataList)&&c(n))for(let G=0;G<this._dataProvider._geoidDataList.length;G++){let A=this._dataProvider._geoidDataList[G],T=A.projection.project(n);if(T.x>A.nativeExtent.west&&T.x<A.nativeExtent.east&&T.y>A.nativeExtent.south&&T.y<A.nativeExtent.north){n.height+=E_e(T.x,T.y,A);break}}let i={},o,a=0;c(t)?(i={box:[0,0,0,t.halfSize[0],0,0,0,t.halfSize[1],0,0,0,t.halfSize[2]]},a=Math.max(Math.max(this._data.obb.halfSize[0],this._data.obb.halfSize[1]),this._data.obb.halfSize[2]),o=mt.WGS84.cartographicToCartesian(n)):(i={sphere:[0,0,0,e[3]]},o=mt.WGS84.cartographicToCartesian(n),a=this._data.mbs[3]),a*=2;let s=1/0;if(c(this._data.lodThreshold))if(this._layer._data.nodePages.lodSelectionMetricType==="maxScreenThresholdSQ"){let G=Math.sqrt(this._data.lodThreshold/(Math.PI*.25));s=a/G}else if(this._layer._data.nodePages.lodSelectionMetricType==="maxScreenThreshold"){let G=this._data.lodThreshold;s=a/G}else console.error("Invalid lodSelectionMetricType in Layer");else if(c(this._data.lodSelection))for(let G=0;G<this._data.lodSelection.length;G++)this._data.lodSelection[G].metricType==="maxScreenThreshold"&&(s=a/this._data.lodSelection[G].maxError);s===1/0&&(s=1e5);let l=s*16,r=new Jr(0,0,0),d=Pe.headingPitchRollQuaternion(o,r);c(this._data.obb)&&(d=new wt(this._data.obb.quaternion[0],this._data.obb.quaternion[1],this._data.obb.quaternion[2],this._data.obb.quaternion[3]));let m=ot.fromQuaternion(d),h=ot.inverse(m,new ot),Z=new L(m[0],m[1],m[2],0,m[3],m[4],m[5],0,m[6],m[7],m[8],0,o.x,o.y,o.z,1),b=L.inverse(Z,new L),u=L.clone(Z);c(this._parent._globalTransform)&&L.multiply(Z,this._parent._inverseGlobalTransform,u),this._globalTransform=Z,this._inverseGlobalTransform=b,this._inverseRotationMatrix=h;let F=[];for(let G=0;G<this._children.length;G++)F.push(this._children[G]._create3DTileDefinition());return{children:F,refine:"REPLACE",boundingVolume:i,transform:[u[0],u[4],u[8],u[12],u[1],u[5],u[9],u[13],u[2],u[6],u[10],u[14],u[3],u[7],u[11],u[15]],content:{uri:c(this._resource)?this._resource.url:void 0},geometricError:l}};bc.prototype._loadSymbology=async function(){!c(this._symbologyData)&&c(this._layer._symbology)&&(this._symbologyData=await this._layer._symbology._getSymbology(this))};bc.prototype._createContentURL=async function(){let t={scene:0,scenes:[{nodes:[0]}],nodes:[{name:"singleNode"}],meshes:[],buffers:[],bufferViews:[],accessors:[],materials:[],textures:[],images:[],samplers:[],asset:{version:"2.0"}},e=[this._loadGeometryData()];if(this._dataProvider.legacyVersion16&&e.push(this._loadFeatureData()),await Promise.all(e),c(this._geometryData)&&this._geometryData.length>0){this._dataProvider._applySymbology&&await this._loadSymbology();let o=this._geometryData[0].resource.url,a=this._layer._data.store.defaultGeometrySchema,s=this._geometryData[0],l=await v5.decode(o,a,s,this._featureData[0],this._symbologyData);if(!c(l))return;t=s._generateGltf(l.meshData.nodesInScene,l.meshData.nodes,l.meshData.meshes,l.meshData.buffers,l.meshData.bufferViews,l.meshData.accessors,l.meshData.rootExtensions,l.meshData.extensionsUsed),this._geometryData[0]._customAttributes=l.meshData._customAttributes}let n=this._dataProvider._binarizeGltf(t),i=new Blob([n],{type:"application/binary"});return URL.createObjectURL(i)};async function T_e(t){let e=t._layer._filters,n=[];for(let i=0;i<e.length;i++){let o=t.loadField(e[i].name);n.push(o)}return await Promise.all(n),e}function S_e(t,e,n){if(!c(n.values)||n.values.length===0)return!1;let i=c(e)?e.values:[],o;t<i.length&&(o=i[t]);let a=!1;for(let s=0;s<n.values.length;s++)if(n.values[s]===o){a=!0;break}return a}async function Y2t(t,e){let n=t._tile.content.batchTable;if(c(n)&&n.featuresLength>0){n.setAllShow(!0);let i=await T_e(t);if(i.length>0)for(let o=0;o<n.featuresLength;o++)for(let a=0;a<i.length;a++){let s=i[a];if(!S_e(o,t._fields[s.name],s)){n.setShow(o,!1);break}}}e.show=!0}bc.prototype._filterFeatures=function(){let t=[];for(let n=0;n<this._children.length;n++){let i=this._children[n]._filterFeatures();t.push(i)}let e=this._tile?.content?._model;if(c(this._geometryData)&&this._geometryData.length>0&&c(e)&&e.ready){e.show=!1;let n=Y2t(this,e);t.push(n)}return Promise.all(t)};iu.prototype._hookedRequestContent=iu.prototype.requestContent;iu.prototype.requestContent=function(){if(!this.tileset._isI3STileSet)return this._hookedRequestContent();if(!this._isLoading){this._isLoading=!0;let t=this;return this._i3sNode._createContentURL().then(e=>{if(!c(e)){t._isLoading=!1;return}return t._contentResource=new te({url:e}),t._hookedRequestContent()}).then(e=>{let n=e?._model;return c(t._i3sNode._geometryData)&&t._i3sNode._geometryData.length>0&&c(n)&&(n.show=!1,n.readyEvent.addEventListener(()=>{Y2t(t._i3sNode,n)})),t._isLoading=!1,e})}};function g_e(t,e,n,i,o,a){let s=n*(1-t)+i*t,l=o*(1-t)+a*t;return s*(1-e)+l*e}function jj(t,e,n,i){let o=t+e*n;return i[o]}function E_e(t,e,n){let i=n.nativeExtent,o=(t-i.west)/(i.east-i.west)*(n.width-1),a=(e-i.south)/(i.north-i.south)*(n.height-1),s=Math.floor(o),l=Math.floor(a);o-=s,a-=l;let r=s<n.width?s+1:s,d=l<n.height?l+1:l;l=n.height-1-l,d=n.height-1-d;let m=jj(s,l,n.width,n.buffer),h=jj(r,l,n.width,n.buffer),Z=jj(s,d,n.width,n.buffer),b=jj(r,d,n.width,n.buffer),u=g_e(o,a,m,h,Z,b);return u=u*n.scale+n.offset,u}Object.defineProperties(iu.prototype,{i3sNode:{get:function(){return this._i3sNode}}});var pN=bc;var Vjo=R(W(),1);function qj(t){this._layer=t,this._defaultSymbology=void 0,this._valueFields=[],this._uniqueValueHash=void 0,this._classBreaksHash=void 0,this._parseLayerSymbology()}Object.defineProperties(qj.prototype,{defaultSymbology:{get:function(){return this._defaultSymbology}}});function _lt(t,e){let n=[];for(let i=0;i<t.length;i++){let o=v.byteToFloat(t[i]);i<3?n.push(jS(o)):n.push(o)}return n.length===3&&(c(e)?n.push(1-e/100):n.push(1)),n}function uN(t,e){let n={edges:void 0,material:void 0};if(c(t)&&c(t.symbolLayers))for(let i=0;i<t.symbolLayers.length;i++){let o=t.symbolLayers[i];if(o.type==="Fill"){let a=o.edges,s=o.outline;if(c(a)?(n.edges={},c(a.color)&&(n.edges.color=_lt(a.color,a.transparency))):c(s)&&(n.edges={},c(s.color)&&(n.edges.color=_lt(s.color,s.transparency))),!e){let l=o.material;c(l)&&(n.material={colorMixMode:l.colorMixMode},c(l.color)&&(n.material.color=_lt(l.color,l.transparency)))}break}}return n}function C_e(t,e){if(c(t.uniqueValueGroups)){let n={};for(let i=0;i<t.uniqueValueGroups.length;i++){let o=t.uniqueValueGroups[i].classes;if(c(o))for(let a=0;a<o.length;a++){let s=uN(o[a].symbol,e),l=o[a].values;for(let r=0;r<l.length;r++){let d=l[r],m=n;for(let h=0;h<d.length;h++){let Z=d[h];h===d.length-1?m[Z]=s:(c(m[Z])||(m[Z]={}),m=m[Z])}}}}return n}if(c(t.uniqueValueInfos)){let n={};for(let i=0;i<t.uniqueValueInfos.length;i++){let o=t.uniqueValueInfos[i];n[o.value]=uN(o.symbol,e)}return n}}function I_e(t,e){if(c(t.classBreakInfos)){let n=[...t.classBreakInfos];n.sort(function(o,a){let s=f(o.classMaxValue,o.classMinValue),l=f(a.classMaxValue,a.classMinValue);return s-l});let i={ranges:[],symbols:[]};c(t.minValue)&&(i.ranges.push(t.minValue),i.symbols.push(void 0));for(let o=0;o<n.length;o++){let a=n[o];c(a.classMinValue)&&(i.ranges.length===0||a.classMinValue>i.ranges[i.ranges.length-1])&&(i.ranges.push(a.classMinValue),i.symbols.push(void 0)),c(a.classMaxValue)&&(i.ranges.length===0||a.classMaxValue>i.ranges[i.ranges.length-1])&&(i.ranges.push(a.classMaxValue),i.symbols.push(uN(a.symbol,e)))}return i.symbols.push(void 0),i}}qj.prototype._parseLayerSymbology=function(){let t=this._layer.data.drawingInfo;if(c(t)&&c(t.renderer)){let e=this._layer.data.cachedDrawingInfo,n=c(e)&&e.color===!0,i=t.renderer;i.type==="simple"?this._defaultSymbology=uN(i.symbol,n):i.type==="uniqueValue"?(this._defaultSymbology=uN(i.defaultSymbol,n),this._valueFields.push(i.field1),c(i.field2)&&this._valueFields.push(i.field2),c(i.field3)&&this._valueFields.push(i.field3),this._uniqueValueHash=C_e(i,n)):i.type==="classBreaks"&&(this._defaultSymbology=uN(i.defaultSymbol,n),this._valueFields.push(i.field),this._classBreaksHash=I_e(i,n))}};function x2t(t,e,n,i){let o=e[n];if(i<o.length){let a=o[i],s=t[a];return c(s)&&++n<e.length?x2t(s,e,n,i):s}}function N_e(t,e){let n=0,i=t.length;if(n<i)do{let o=n+i>>>1;t[o]<e?n=o+1:i=o}while(n<i);return n}function y_e(t,e,n){let i=e[n],o=N_e(t.ranges,i);return t.symbols[o]}qj.prototype._getSymbology=async function(t){let e={default:this._defaultSymbology};if(this._valueFields.length>0){let n=[];for(let a=0;a<this._valueFields.length;a++)n.push(t.loadField(this._valueFields[a]));await Promise.all(n);let i=[];for(let a=0;a<this._valueFields.length;a++)i.push(t.fields[this._valueFields[a]].values);let o;if(c(this._uniqueValueHash)?o=a=>x2t(this._uniqueValueHash,i,0,a):c(this._classBreaksHash)&&(o=a=>y_e(this._classBreaksHash,i[0],a)),c(o)){let a=i[0];for(let s=0;s<a.length;s++){let l=o(s);c(l)&&(e[s]=l)}}}return e};var q5=qj;function ah(t,e,n){this._dataProvider=t,this._parent=n,!c(e.href)&&c(e.id)&&(e.href=`layers/${e.id}`);let i=this._parent.resource.getUrlComponent(),o="";i.match(/layers\/\d/)?o=`${i}`.replace(/\/+$/,""):o=`${i}`.replace(/\/?$/,"/").concat(`${e.href}`),this._version=e.store.version;let a=this._version.split(".");this._majorVersion=parseInt(a[0]),this._minorVersion=a.length>1?parseInt(a[1]):0,this._resource=new te({url:o}),this._resource.setQueryParameters(this._dataProvider.resource.queryParameters),this._resource.appendForwardSlash(),this._data=e,this._rootNode=void 0,this._nodePages={},this._nodePageFetches={},this._extent=void 0,this._tileset=void 0,this._geometryDefinitions=void 0,this._filters=[],this._symbology=void 0,this._computeGeometryDefinitions(!0),this._computeExtent()}Object.defineProperties(ah.prototype,{resource:{get:function(){return this._resource}},rootNode:{get:function(){return this._rootNode}},tileset:{get:function(){return this._tileset}},data:{get:function(){return this._data}},version:{get:function(){return this._version}},majorVersion:{get:function(){return this._majorVersion}},minorVersion:{get:function(){return this._minorVersion}},legacyVersion16:{get:function(){if(c(this.version))return this.majorVersion<1||this.majorVersion===1&&this.minorVersion<=6}}});ah.prototype.load=async function(t){if(this._data.spatialReference.wkid!==4326)throw new St(`Unsupported spatial reference: ${this._data.spatialReference.wkid}`);if(this._dataProvider.applySymbology&&(this._symbology=new q5(this)),await this._dataProvider.loadGeoidData(),await this._loadRootNode(t),await this._create3DTileset(t),this._rootNode._tile=this._tileset._root,this._tileset._root._i3sNode=this._rootNode,this.legacyVersion16)return this._rootNode._loadChildren()};ah.prototype._computeGeometryDefinitions=function(t){if(this._geometryDefinitions=[],c(this._data.geometryDefinitions))for(let e=0;e<this._data.geometryDefinitions.length;e++){let n=[],i=this._data.geometryDefinitions[e].geometryBuffers;for(let o=0;o<i.length;o++){let a=i[o],s=[],l=!1;if(c(a.compressedAttributes)&&t){l=!0;let r=a.compressedAttributes.attributes;for(let d=0;d<r.length;d++)s.push(r[d])}else for(let r in a)r!=="offset"&&s.push(r);n.push({compressed:l,attributes:s,index:i.indexOf(a)})}n.sort(function(o,a){return o.compressed&&!a.compressed?-1:!o.compressed&&a.compressed?1:o.attributes.length-a.attributes.length}),this._geometryDefinitions.push(n)}};ah.prototype._findBestGeometryBuffers=function(t,e){let n=this._geometryDefinitions[t];if(c(n))for(let i=0;i<n.length;++i){let o=n[i],a=!1,s=o.attributes;for(let l=0;l<e.length;l++)if(!s.includes(e[l])){a=!0;break}if(!a)return{bufferIndex:o.index,definition:n,geometryBufferInfo:o}}return 0};ah.prototype._loadRootNode=function(t){if(c(this._data.nodePages)){let e=0;c(this._data.nodePages.rootIndex)&&(e=this._data.nodePages.rootIndex),this._rootNode=new pN(this,e,!0)}else this._rootNode=new pN(this,this._data.store.rootNode,!0);return this._rootNode.load(t)};ah.prototype._getNodeInNodePages=function(t){let e=Math.floor(t/this._data.nodePages.nodesPerPage),n=t%this._data.nodePages.nodesPerPage;return this._loadNodePage(e).then(function(i){return i.nodes[n]})};ah._fetchJson=function(t){return t.fetchJson()};ah.prototype._loadNodePage=function(t){let e=this;if(!c(this._nodePageFetches[t])){let n=this.resource.getDerivedResource({url:`nodepages/${t}/`}),i=ah._fetchJson(n).then(function(o){return c(o.error)&&o.error.code!==200?Promise.reject(o.error):(e._nodePages[t]=o.nodes,o)});this._nodePageFetches[t]=i}return this._nodePageFetches[t]};ah.prototype._computeExtent=function(){c(this._data.fullExtent)?this._extent=Gt.fromDegrees(this._data.fullExtent.xmin,this._data.fullExtent.ymin,this._data.fullExtent.xmax,this._data.fullExtent.ymax):c(this._data.store.extent)&&(this._extent=Gt.fromDegrees(this._data.store.extent[0],this._data.store.extent[1],this._data.store.extent[2],this._data.store.extent[3]))};ah.prototype._create3DTileset=async function(t){let e={asset:{version:"1.0"},geometricError:Number.MAX_VALUE,root:this._rootNode._create3DTileDefinition()},n=new Blob([JSON.stringify(e)],{type:"application/json"}),i=URL.createObjectURL(n),o=this._symbology?.defaultSymbology?.edges?.color;c(o)&&!c(t?.outlineColor)&&(t=c(t)?be(t):{},t.outlineColor=v.fromCartesian4(Rt.fromArray(o))),this._tileset=await Pr.fromUrl(i,t),this._tileset.show=this._parent.show,this._tileset._isI3STileSet=!0,this._tileset.tileUnload.addEventListener(function(a){a._i3sNode._clearGeometryData(),URL.revokeObjectURL(a._contentResource._url),a._contentResource=a._i3sNode.resource}),this._tileset.tileVisible.addEventListener(function(a){c(a._i3sNode)&&a._i3sNode._loadChildren()})};ah.prototype._updateVisibility=function(){c(this._tileset)&&(this._tileset.show=this._parent.show)};ah.prototype.filterByAttributes=function(t){this._filters=c(t)?be(t,!0):[];let e=this._rootNode;return c(e)?e._filterFeatures():Promise.resolve()};var ig=ah;var Bjo=R(W(),1);function $j(t,e){this._dataProvider=t,this._resource=new te({url:e}),this._resource.setQueryParameters(t.resource.queryParameters),this._resource.appendForwardSlash()}Object.defineProperties($j.prototype,{resource:{get:function(){return this._resource}},data:{get:function(){return this._data}},names:{get:function(){let t=[],e=this._data.summary;if(c(e))for(let n=0;n<e.length;++n)t.push(e[n].fieldName);return t}}});$j.prototype.load=async function(){return this._data=await RV.loadJson(this._resource),this._data};$j.prototype._getValues=function(t){let e=this._data.summary;if(c(e))for(let n=0;n<e.length;++n){let i=e[n];if(i.fieldName===t)return c(i.mostFrequentValues)?[...i.mostFrequentValues]:[]}};var $5=$j;var Ljo=R(W(),1);function tD(t,e,n){this._dataProvider=t,this._parent=e,this._data=n,this._name=n.name,this._modelName=n.modelName,this._visibility=f(n.visibility,!0),this._resource=void 0,this._sublayers=[],this._i3sLayers=[]}Object.defineProperties(tD.prototype,{resource:{get:function(){return this._resource}},data:{get:function(){return this._data}},name:{get:function(){return this._name}},modelName:{get:function(){return this._modelName}},sublayers:{get:function(){return this._sublayers}},visibility:{get:function(){return this._visibility},set:function(t){if(this._visibility!==t){this._visibility=t;for(let e=0;e<this._i3sLayers.length;e++)this._i3sLayers[e]._updateVisibility()}}},show:{get:function(){return this._visibility&&this._parent.show}}});tD._fromData=async function(t,e,n,i){let o=new tD(t,i,n);if(o._data.layerType==="group"){let a=o._data.sublayers;if(c(a)){let s=[];for(let r=0;r<a.length;r++){let d=tD._fromData(t,e,a[r],o);s.push(d)}let l=await Promise.all(s);for(let r=0;r<l.length;r++){let d=l[r];o._sublayers.push(d),o._i3sLayers.push(...d._i3sLayers)}}}else if(o._data.layerType==="3DObject"){let a=e.concat(`/sublayers/${o._data.id}`),s=new te({url:a});s.setQueryParameters(t.resource.queryParameters),s.appendForwardSlash(),o._resource=s;let l=await RV.loadJson(o._resource),r=new ig(t,l,o);o._i3sLayers.push(r)}else console.log(`${o._data.layerType} layer ${o._data.name} is skipped as not supported.`);return o};var eD=tD;var L2t=R(X2t(),1);function Hl(t){t=f(t,f.EMPTY_OBJECT),this._name=t.name,this._show=f(t.show,!0),this._geoidTiledTerrainProvider=t.geoidTiledTerrainProvider,this._showFeatures=f(t.showFeatures,!1),this._adjustMaterialAlphaMode=f(t.adjustMaterialAlphaMode,!1),this._applySymbology=f(t.applySymbology,!1),this._calculateNormals=f(t.calculateNormals,!1),this._cesium3dTilesetOptions=f(t.cesium3dTilesetOptions,f.EMPTY_OBJECT),this._layers=[],this._sublayers=[],this._data=void 0,this._extent=void 0,this._geoidDataPromise=void 0,this._geoidDataList=void 0,this._decoderTaskProcessor=void 0,this._taskProcessorReadyPromise=void 0,this._attributeStatistics=[],this._layersExtent=[]}Object.defineProperties(Hl.prototype,{name:{get:function(){return this._name}},show:{get:function(){return this._show},set:function(t){if(this._show!==t){this._show=t;for(let e=0;e<this._layers.length;e++)this._layers[e]._updateVisibility()}}},geoidTiledTerrainProvider:{get:function(){return this._geoidTiledTerrainProvider}},layers:{get:function(){return this._layers}},sublayers:{get:function(){return this._sublayers}},data:{get:function(){return this._data}},extent:{get:function(){return this._extent}},resource:{get:function(){return this._resource}},showFeatures:{get:function(){return this._showFeatures}},adjustMaterialAlphaMode:{get:function(){return this._adjustMaterialAlphaMode}},applySymbology:{get:function(){return this._applySymbology}},calculateNormals:{get:function(){return this._calculateNormals}}});Hl.prototype.destroy=function(){for(let t=0;t<this._layers.length;t++)c(this._layers[t]._tileset)&&this._layers[t]._tileset.destroy();return At(this)};Hl.prototype.isDestroyed=function(){return!1};Hl.prototype.update=function(t){for(let e=0;e<this._layers.length;e++)c(this._layers[e]._tileset)&&this._layers[e]._tileset.update(t)};Hl.prototype.prePassesUpdate=function(t){for(let e=0;e<this._layers.length;e++)c(this._layers[e]._tileset)&&this._layers[e]._tileset.prePassesUpdate(t)};Hl.prototype.postPassesUpdate=function(t){for(let e=0;e<this._layers.length;e++)c(this._layers[e]._tileset)&&this._layers[e]._tileset.postPassesUpdate(t)};Hl.prototype.updateForPass=function(t,e){for(let n=0;n<this._layers.length;n++)c(this._layers[n]._tileset)&&this._layers[n]._tileset.updateForPass(t,e)};function B_e(t,e){let n=t.resource.getUrlComponent(),i="";return n.match(/layers\/\d/)?i=`${n}`.replace(/\/+$/,""):i=`${n}`.replace(/\/?$/,"/").concat(`layers/${e}`),i}async function J2t(t,e,n){if(e.layerType==="Building"){c(n.showFeatures)||(t._showFeatures=!0),c(n.adjustMaterialAlphaMode)||(t._adjustMaterialAlphaMode=!0),c(n.applySymbology)||(t._applySymbology=!0),c(n.calculateNormals)||(t._calculateNormals=!0);let i=B_e(t,e.id);if(c(e.sublayers)){let o=[];for(let s=0;s<e.sublayers.length;s++){let l=eD._fromData(t,i,e.sublayers[s],t);o.push(l)}let a=await Promise.all(o);for(let s=0;s<a.length;s++){let l=a[s];t._sublayers.push(l),t._layers.push(...l._i3sLayers)}}if(c(e.statisticsHRef)){let o=i.concat(`/${e.statisticsHRef}`),a=new $5(t,o);await a.load(),t._attributeStatistics.push(a)}if(c(e.fullExtent)){let o=Gt.fromDegrees(e.fullExtent.xmin,e.fullExtent.ymin,e.fullExtent.xmax,e.fullExtent.ymax);t._layersExtent.push(o)}}else if(e.layerType==="3DObject"||e.layerType==="IntegratedMesh"){!c(n.calculateNormals)&&!c(e.textureSetDefinitions)&&(t._calculateNormals=!0);let i=new ig(t,e,t);t._layers.push(i),c(i._extent)&&t._layersExtent.push(i._extent)}else console.log(`${e.layerType} layer ${e.name} is skipped as not supported.`)}Hl.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=te.createIfNeeded(t);n.setQueryParameters({f:"pjson"},!0);let i=await Hl.loadJson(n),o=new Hl(e);if(o._resource=n,o._data=i,c(i.layers)){let s=[];for(let l=0;l<i.layers.length;l++){let r=J2t(o,i.layers[l],e);s.push(r)}await Promise.all(s)}else await J2t(o,i,e);o._computeExtent();let a=[];for(let s=0;s<o._layers.length;s++)a.push(o._layers[s].load(e.cesium3dTilesetOptions));return await Promise.all(a),o};Hl._fetchJson=function(t){return t.fetchJson()};Hl.loadJson=async function(t){let e=await Hl._fetchJson(t);if(c(e.error)){if(console.error("Failed to fetch I3S ",t.url),c(e.error.message)&&console.error(e.error.message),c(e.error.details))for(let n=0;n<e.error.details.length;n++)console.log(e.error.details[n]);throw new St(e.error)}return e};Hl.prototype._loadBinary=async function(t){let e=await t.fetchArrayBuffer();if(e.byteLength>0&&new Uint8Array(e)[0]===123&&new TextDecoder().decode(e).includes("404"))throw new St(`Failed to load binary: ${t.url}`);return e};Hl.prototype._binarizeGltf=function(t){let n=new TextEncoder().encode(JSON.stringify(t)),i=new Uint8Array(n.byteLength+20),o={magic:new Uint8Array(i.buffer,0,4),version:new Uint32Array(i.buffer,4,1),length:new Uint32Array(i.buffer,8,1),chunkLength:new Uint32Array(i.buffer,12,1),chunkType:new Uint32Array(i.buffer,16,1),chunkData:new Uint8Array(i.buffer,20,n.byteLength)};return o.magic[0]=103,o.magic[1]=108,o.magic[2]=84,o.magic[3]=70,o.version[0]=2,o.length[0]=i.byteLength,o.chunkLength[0]=n.byteLength,o.chunkType[0]=1313821514,o.chunkData.set(n),i};var Q_e=new K;function k_e(t,e){let n=t.tilingScheme,i=[],o={},a=t._lodCount,s=gt.fromRadians(e.west,e.north),l=gt.fromRadians(e.east,e.south),r=n.positionToTileXY(s,a),d=n.positionToTileXY(l,a);for(let h=r.x;h<=d.x;h++)for(let Z=r.y;Z<=d.y;Z++){let b=K.fromElements(h,Z,Q_e),u=b.toString();if(!o.hasOwnProperty(u)){let F={x:b.x,y:b.y,level:a,tilingScheme:n,terrainProvider:t,positions:[]};o[u]=F,i.push(F)}}let m=[];for(let h=0;h<i.length;++h){let Z=i[h],b=Z.terrainProvider.requestTileGeometry(Z.x,Z.y,Z.level);m.push(b)}return Promise.all(m).then(function(h){let Z=[];for(let b=0;b<h.length;b++){let u={tilingScheme:n,x:i[b].x,y:i[b].y,level:i[b].level},F=h[b],U="Geographic";n._projection instanceof Yo&&(U="WebMercator");let G={projectionType:U,projection:n._projection,nativeExtent:n.tileXYToNativeRectangle(u.x,u.y,u.level),height:F._height,width:F._width,scale:F._structure.heightScale,offset:F._structure.heightOffset};if(F._encoding===Uu.LERC){let A=L2t.default.decode(F._buffer);G.buffer=A.pixels[0]}else G.buffer=F._buffer;Z.push(G)}return Z})}async function Y_e(t){let e=t._geoidTiledTerrainProvider;if(c(e))try{let n=await k_e(e,t._extent);t._geoidDataList=n}catch{console.log("Error retrieving Geoid Terrain tiles - no geoid conversion will be performed.")}}Hl.prototype.loadGeoidData=async function(){return c(this._geoidDataPromise)?this._geoidDataPromise:(this._geoidDataPromise=Y_e(this),this._geoidDataPromise)};Hl.prototype._computeExtent=function(){let t;for(let e=0;e<this._layersExtent.length;e++){let n=this._layersExtent[e];c(t)?Gt.union(t,n,t):t=Gt.clone(n)}this._extent=t};Hl.prototype.getAttributeNames=function(){let t=[];for(let e=0;e<this._attributeStatistics.length;++e)t.push(...this._attributeStatistics[e].names);return t};Hl.prototype.getAttributeValues=function(t){for(let e=0;e<this._attributeStatistics.length;++e){let n=this._attributeStatistics[e]._getValues(t);if(c(n))return n}return[]};Hl.prototype.filterByAttributes=function(t){let e=[];for(let n=0;n<this._layers.length;n++){let i=this._layers[n].filterByAttributes(t);e.push(i)}return Promise.all(e)};var RV=Hl;var s4o=R(W(),1);function M2t(){}Object.defineProperties(M2t.prototype,{color:{get:Ut.throwInstantiationError},intensity:{get:Ut.throwInstantiationError}});var Dlt=M2t;var u4o=R(W(),1);function x_e(){return window.devicePixelRatio||1}function X_e(t,e,n){n||(n=x_e());let i=document.createElement("canvas");return i.width=t*n,i.height=e*n,i.style.width=`${t}px`,i.style.height=`${e}px`,i.getContext("2d").scale(n,n),i}function J_e({entity:t,text:e,fontSize:n="14",fontFamily:i="Helvetica",fontStyle:o="",fillStyle:a="white",bgColor:s="#111",lineWidth:l=2,cornerRadius:r=3,horizontalOrigin:d=to.LEFT,verticalOrigin:m=hi.CENTER,scaleByDistance:h=new ln(150,1,8e6,.35),pixelOffset:Z=new K(20,0)}){if(!t._labelCanvas||t._labelCanvasText!==e){let b=`${o} ${n}px ${i}`,u=document.createElement("div");u.style.position="absolute",u.style.font=b,u.innerHTML=e,document.body.appendChild(u);let{height:F,width:U}=u.getBoundingClientRect(),G=X_e(U*1.1,F*1.5,devicePixelRatio);G.width=U*1.1,G.height=F*1.5,document.body.removeChild(u);let A=G.getContext("2d");A.font=b,A.beginPath(),A.moveTo(r,0),A.lineTo(G.width-r,0),A.arcTo(G.width,0,G.width,r,r),A.lineTo(G.width,G.height-r),A.arcTo(G.width,G.height,G.width-r,G.height,r),A.lineTo(r,G.height),A.arcTo(0,G.height,0,G.height-r,r),A.lineTo(0,r),A.arcTo(0,0,r,0,r),A.closePath(),A.fillStyle=s,A.fill(),A.textAlign="center",A.textBaseline="middle",A.fillStyle=a,A.lineWidth=l;let T=G.width/2,g=G.height/2;A.fillText(e,T,g),t._labelCanvas=G,t._labelCanvasText=e}t.billboard=new Mr({image:new Ii(t._labelCanvas),horizontalOrigin:d,verticalOrigin:m,scaleByDistance:h,width:t._labelCanvas.width,height:t._labelCanvas.height,pixelOffset:Z})}var Olt=J_e;var F4o=R(W(),1);var L_e=/\/$/,_2t=new on('© <a href="https://www.mapbox.com/about/maps/">Mapbox</a> © <a href="http://www.openstreetmap.org/copyright">OpenStreetMap</a> <strong><a href="https://www.mapbox.com/map-feedback/">Improve this map</a></strong>');function ZN(t){t=f(t,f.EMPTY_OBJECT);let e=t.styleId,n=t.accessToken;this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0;let i=te.createIfNeeded(f(t.url,"https://api.mapbox.com/styles/v1/"));this._styleId=e,this._accessToken=n;let o=f(t.tilesize,512);this._tilesize=o;let a=f(t.username,"mapbox");this._username=a;let s=c(t.scaleFactor)?"@2x":"",l=i.getUrlComponent();L_e.test(l)||(l+="/"),l+=`${this._username}/${e}/tiles/${this._tilesize}/{z}/{x}/{y}${s}`,i.url=l,i.setQueryParameters({access_token:n});let r;c(t.credit)?(r=t.credit,typeof r=="string"&&(r=new on(r))):r=_2t,this._resource=i,this._imageryProvider=new Ad({url:i,credit:r,ellipsoid:t.ellipsoid,minimumLevel:t.minimumLevel,maximumLevel:t.maximumLevel,rectangle:t.rectangle})}Object.defineProperties(ZN.prototype,{url:{get:function(){return this._imageryProvider.url}},rectangle:{get:function(){return this._imageryProvider.rectangle}},tileWidth:{get:function(){return this._imageryProvider.tileWidth}},tileHeight:{get:function(){return this._imageryProvider.tileHeight}},maximumLevel:{get:function(){return this._imageryProvider.maximumLevel}},minimumLevel:{get:function(){return this._imageryProvider.minimumLevel}},tilingScheme:{get:function(){return this._imageryProvider.tilingScheme}},tileDiscardPolicy:{get:function(){return this._imageryProvider.tileDiscardPolicy}},errorEvent:{get:function(){return this._imageryProvider.errorEvent}},credit:{get:function(){return this._imageryProvider.credit}},proxy:{get:function(){return this._imageryProvider.proxy}},hasAlphaChannel:{get:function(){return this._imageryProvider.hasAlphaChannel}}});ZN.prototype.getTileCredits=function(t,e,n){};ZN.prototype.requestImage=function(t,e,n,i){return this._imageryProvider.requestImage(t,e,n,i)};ZN.prototype.pickFeatures=function(t,e,n,i,o){return this._imageryProvider.pickFeatures(t,e,n,i,o)};ZN._defaultCredit=_2t;var Hlt=ZN;var G4o=R(W(),1);function wlt(t){}wlt.prototype.isReady=function(){return!0};wlt.prototype.shouldDiscardImage=function(t){return!1};var Plt=wlt;var y4o=R(W(),1);var M_e=new on("MapQuest, Open Street Map and contributors, CC-BY-SA");function e4(t){t=f(t,f.EMPTY_OBJECT);let e=te.createIfNeeded(f(t.url,"https://tile.openstreetmap.org/"));e.appendForwardSlash(),e.url+=`{z}/{x}/{y}${t.retinaTiles?"@2x":""}.${f(t.fileExtension,"png")}`;let n=new Gs({ellipsoid:t.ellipsoid}),i=256,o=256,a=f(t.minimumLevel,0),s=t.maximumLevel,l=f(t.rectangle,n.rectangle),r=n.positionToTileXY(Gt.southwest(l),a),d=n.positionToTileXY(Gt.northeast(l),a),m=(Math.abs(d.x-r.x)+1)*(Math.abs(d.y-r.y)+1),h=f(t.credit,M_e);typeof h=="string"&&(h=new on(h)),Ad.call(this,{url:e,credit:h,tilingScheme:n,tileWidth:i,tileHeight:o,minimumLevel:a,maximumLevel:s,rectangle:l})}c(Object.create)&&(e4.prototype=Object.create(Ad.prototype),e4.prototype.constructor=e4);var IW=e4;var J4o=R(W(),1);var __e=new K(1,1);function vlt(t){t=f(t,f.EMPTY_OBJECT),this.mass=f(t.mass,1),this.position=p.clone(f(t.position,p.ZERO)),this.velocity=p.clone(f(t.velocity,p.ZERO)),this.life=f(t.life,Number.MAX_VALUE),this.image=t.image,this.startColor=v.clone(f(t.startColor,v.WHITE)),this.endColor=v.clone(f(t.endColor,v.WHITE)),this.startScale=f(t.startScale,1),this.endScale=f(t.endScale,1),this.imageSize=K.clone(f(t.imageSize,__e)),this._age=0,this._normalizedAge=0,this._billboard=void 0}Object.defineProperties(vlt.prototype,{age:{get:function(){return this._age}},normalizedAge:{get:function(){return this._normalizedAge}}});var D2t=new p;vlt.prototype.update=function(t,e){return p.multiplyByScalar(this.velocity,t,D2t),p.add(this.position,D2t,this.position),c(e)&&e(this,t),this._age+=t,this.life===Number.MAX_VALUE?this._normalizedAge=0:this._normalizedAge=this._age/this.life,this._age<=this.life};var VN=vlt;var _4o=R(W(),1);function O2t(t){t=f(t,f.EMPTY_OBJECT),this.time=f(t.time,0),this.minimum=f(t.minimum,0),this.maximum=f(t.maximum,50),this._complete=!1}Object.defineProperties(O2t.prototype,{complete:{get:function(){return this._complete}}});var Klt=O2t;var H4o=R(W(),1);function H2t(t){}H2t.prototype.emit=function(t){Ut.throwInstantiationError()};var zlt=H2t;var s8o=R(W(),1);var w2t=new K(1,1);function nD(t){t=f(t,f.EMPTY_OBJECT),this.show=f(t.show,!0),this.updateCallback=t.updateCallback,this.loop=f(t.loop,!0),this.image=f(t.image,void 0);let e=t.emitter;c(e)||(e=new M5(.5)),this._emitter=e,this._bursts=t.bursts,this._modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._emitterModelMatrix=L.clone(f(t.emitterModelMatrix,L.IDENTITY)),this._matrixDirty=!0,this._combinedMatrix=new L,this._startColor=v.clone(f(t.color,f(t.startColor,v.WHITE))),this._endColor=v.clone(f(t.color,f(t.endColor,v.WHITE))),this._startScale=f(t.scale,f(t.startScale,1)),this._endScale=f(t.scale,f(t.endScale,1)),this._emissionRate=f(t.emissionRate,5),this._minimumSpeed=f(t.speed,f(t.minimumSpeed,1)),this._maximumSpeed=f(t.speed,f(t.maximumSpeed,1)),this._minimumParticleLife=f(t.particleLife,f(t.minimumParticleLife,5)),this._maximumParticleLife=f(t.particleLife,f(t.maximumParticleLife,5)),this._minimumMass=f(t.mass,f(t.minimumMass,1)),this._maximumMass=f(t.mass,f(t.maximumMass,1)),this._minimumImageSize=K.clone(f(t.imageSize,f(t.minimumImageSize,w2t))),this._maximumImageSize=K.clone(f(t.imageSize,f(t.maximumImageSize,w2t))),this._sizeInMeters=f(t.sizeInMeters,!1),this._lifetime=f(t.lifetime,Number.MAX_VALUE),this._billboardCollection=void 0,this._particles=[],this._particlePool=[],this._previousTime=void 0,this._currentTime=0,this._carryOver=0,this._complete=new It,this._isComplete=!1,this._updateParticlePool=!0,this._particleEstimate=0}Object.defineProperties(nD.prototype,{emitter:{get:function(){return this._emitter},set:function(t){this._emitter=t}},bursts:{get:function(){return this._bursts},set:function(t){this._bursts=t,this._updateParticlePool=!0}},modelMatrix:{get:function(){return this._modelMatrix},set:function(t){this._matrixDirty=this._matrixDirty||!L.equals(this._modelMatrix,t),L.clone(t,this._modelMatrix)}},emitterModelMatrix:{get:function(){return this._emitterModelMatrix},set:function(t){this._matrixDirty=this._matrixDirty||!L.equals(this._emitterModelMatrix,t),L.clone(t,this._emitterModelMatrix)}},startColor:{get:function(){return this._startColor},set:function(t){v.clone(t,this._startColor)}},endColor:{get:function(){return this._endColor},set:function(t){v.clone(t,this._endColor)}},startScale:{get:function(){return this._startScale},set:function(t){this._startScale=t}},endScale:{get:function(){return this._endScale},set:function(t){this._endScale=t}},emissionRate:{get:function(){return this._emissionRate},set:function(t){this._emissionRate=t,this._updateParticlePool=!0}},minimumSpeed:{get:function(){return this._minimumSpeed},set:function(t){this._minimumSpeed=t}},maximumSpeed:{get:function(){return this._maximumSpeed},set:function(t){this._maximumSpeed=t}},minimumParticleLife:{get:function(){return this._minimumParticleLife},set:function(t){this._minimumParticleLife=t}},maximumParticleLife:{get:function(){return this._maximumParticleLife},set:function(t){this._maximumParticleLife=t,this._updateParticlePool=!0}},minimumMass:{get:function(){return this._minimumMass},set:function(t){this._minimumMass=t}},maximumMass:{get:function(){return this._maximumMass},set:function(t){this._maximumMass=t}},minimumImageSize:{get:function(){return this._minimumImageSize},set:function(t){this._minimumImageSize=t}},maximumImageSize:{get:function(){return this._maximumImageSize},set:function(t){this._maximumImageSize=t}},sizeInMeters:{get:function(){return this._sizeInMeters},set:function(t){this._sizeInMeters=t}},lifetime:{get:function(){return this._lifetime},set:function(t){this._lifetime=t}},complete:{get:function(){return this._complete}},isComplete:{get:function(){return this._isComplete}}});function D_e(t){let e=t._emissionRate,n=t._maximumParticleLife,i=0,o=t._bursts;if(c(o)){let h=o.length;for(let Z=0;Z<h;++Z)i+=o[Z].maximum}let a=t._billboardCollection,s=t.image,l=Math.ceil(e*n+i),r=t._particles,d=t._particlePool,m=Math.max(l-r.length-d.length,0);for(let h=0;h<m;++h){let Z=new VN;Z._billboard=a.add({image:s,show:!1}),d.push(Z)}t._particleEstimate=l}function O_e(t){let e=t._particlePool.pop();return c(e)||(e=new VN),e}function H_e(t,e){t._particlePool.push(e)}function w_e(t){let e=t._particles,n=t._particlePool,i=t._billboardCollection,o=e.length,a=n.length,s=t._particleEstimate,l=a-Math.max(s-o-a,0);for(let r=l;r<a;++r){let d=n[r];i.remove(d._billboard)}n.length=l}function P_e(t){c(t._billboard)&&(t._billboard.show=!1)}function P2t(t,e){let n=e._billboard;c(n)||(n=e._billboard=t._billboardCollection.add({image:e.image})),n.width=e.imageSize.x,n.height=e.imageSize.y,n.position=e.position,n.sizeInMeters=t.sizeInMeters,n.show=!0;let i=k.lerp(e.startColor.red,e.endColor.red,e.normalizedAge),o=k.lerp(e.startColor.green,e.endColor.green,e.normalizedAge),a=k.lerp(e.startColor.blue,e.endColor.blue,e.normalizedAge),s=k.lerp(e.startColor.alpha,e.endColor.alpha,e.normalizedAge);n.color=new v(i,o,a,s),n.scale=k.lerp(e.startScale,e.endScale,e.normalizedAge)}function v_e(t,e){e.startColor=v.clone(t._startColor,e.startColor),e.endColor=v.clone(t._endColor,e.endColor),e.startScale=t._startScale,e.endScale=t._endScale,e.image=t.image,e.life=k.randomBetween(t._minimumParticleLife,t._maximumParticleLife),e.mass=k.randomBetween(t._minimumMass,t._maximumMass),e.imageSize.x=k.randomBetween(t._minimumImageSize.x,t._maximumImageSize.x),e.imageSize.y=k.randomBetween(t._minimumImageSize.y,t._maximumImageSize.y),e._normalizedAge=0,e._age=0;let n=k.randomBetween(t._minimumSpeed,t._maximumSpeed);p.multiplyByScalar(e.velocity,n,e.velocity),t._particles.push(e)}function K_e(t,e){if(t._isComplete)return 0;e=k.mod(e,t._lifetime);let n=e*t._emissionRate,i=Math.floor(n);if(t._carryOver+=n-i,t._carryOver>1&&(i++,t._carryOver-=1),c(t.bursts)){let o=t.bursts.length;for(let a=0;a<o;a++){let s=t.bursts[a],l=t._currentTime;c(s)&&!s._complete&&l>s.time&&(i+=k.randomBetween(s.minimum,s.maximum),s._complete=!0)}}return i}var n4=new p;nD.prototype.update=function(t){if(!this.show)return;c(this._billboardCollection)||(this._billboardCollection=new yh),this._updateParticlePool&&(D_e(this),this._updateParticlePool=!1);let e=0;this._previousTime&&(e=rt.secondsDifference(t.time,this._previousTime)),e<0&&(e=0);let n=this._particles,i=this._emitter,o=this.updateCallback,a,s,l=n.length;for(a=0;a<l;++a)s=n[a],s.update(e,o)?P2t(this,s):(P_e(s),H_e(this,s),n[a]=n[l-1],--a,--l);n.length=l;let r=K_e(this,e);if(r>0&&c(i)){this._matrixDirty&&(this._combinedMatrix=L.multiply(this.modelMatrix,this.emitterModelMatrix,this._combinedMatrix),this._matrixDirty=!1);let d=this._combinedMatrix;for(a=0;a<r;a++)s=O_e(this),this._emitter.emit(s),p.add(s.position,s.velocity,n4),L.multiplyByPoint(d,n4,n4),s.position=L.multiplyByPoint(d,s.position,s.position),p.subtract(n4,s.position,s.velocity),p.normalize(s.velocity,s.velocity),v_e(this,s),P2t(this,s)}if(this._billboardCollection.update(t),this._previousTime=rt.clone(t.time,this._previousTime),this._currentTime+=e,this._lifetime!==Number.MAX_VALUE&&this._currentTime>this._lifetime)if(this.loop){if(this._currentTime=k.mod(this._currentTime,this._lifetime),this.bursts){let d=this.bursts.length;for(a=0;a<d;a++)this.bursts[a]._complete=!1}}else this._isComplete=!0,this._complete.raiseEvent(this);t.frameNumber%120===0&&w_e(this)};nD.prototype.isDestroyed=function(){return!1};nD.prototype.destroy=function(){return this._billboardCollection=this._billboardCollection&&this._billboardCollection.destroy(),At(this)};var jlt=nD;var m8o=R(W(),1);var bN={},NW;async function z_e(t,e,n,i=!0){let a=`${e||"https://api.planet.com/basemaps/v1/mosaics/wmts"}?api_key=${n}`,l=await(await fetch(a)).text(),d=new DOMParser().parseFromString(l,"application/xml").getElementsByTagName("ResourceURL");NW=i?"monthly":"quarterly",bN[NW]=[],Array.from(d).forEach(b=>{let u=b.getAttribute("template");if(u.includes(NW)){let F=`.*/(.*?${NW}.*?)/.*`,U=new RegExp(F),G=u.match(U)[1];bN[NW].push(G)}}),bN[NW].sort();let m=q_e(bN[NW],i),h=ys.fromIso8601DateArray({iso8601Dates:m,leadingInterval:!0,trailingInterval:!0,isStopIncluded:!1,dataCallback:j_e}),Z=new hS({url:`https://tiles{s}.planet.com/basemaps/v1/planet-tiles/{Name}/gmap/{TileMatrix}/{TileCol}/{TileRow}.png?api_key=${n}`,layer:"planet",style:"default",tileMatrixSetID:"GoogleMapsCompatible15",tileWidth:256,tileHeight:256,minimumLevel:0,maximumLevel:15,tilingScheme:new Gs({numberOfLevelZeroTilesX:1,numberOfLevelZeroTilesY:1}),format:"image/png",subdomains:"0123",clock:t.clock,times:h,credit:"PLANET"});t.imageryLayers.addImageryProvider(Z)}function j_e(t,e){let n;return e<=1?n=bN[NW][0]:n=bN[NW][e-1],{Name:n}}function q_e(t,e){let n=[];return t.forEach(i=>{if(e){let o=i.split("_"),a=`${o[2]}-${o[3]}-01T00:00:00Z`;n.push(a)}else{let o={q1:"-01-01",q2:"-04-01",q3:"-07-01",q4:"-10-01"},a=i.split("_")[2],s=a.slice(0,4),l=a.slice(4,6),r=`${s}${o[l]}T00:00:00Z`;n.push(r)}}),n}var qlt=z_e;var $8o=R(W(),1);var z2t=R(KO(),1);var p8o=R(W(),1);function $_e(t,e,n){return` float clipDistance = clip(gl_FragCoord, ${t}, ${e}); +`;function tg(t){t=f(t,f.EMPTY_OBJECT);let e=f(t.translucent,!0),n=f(t.aboveGround,!1);this.material=c(t.material)?t.material:eo.fromType(eo.ColorType),this.translucent=f(t.translucent,!0),this._vertexShaderSource=f(t.vertexShaderSource,H5),this._fragmentShaderSource=f(t.fragmentShaderSource,O5),this._renderState=Va.getDefaultRenderState(e,!n,t.renderState),this._closed=!1,this._flat=f(t.flat,!1),this._faceForward=f(t.faceForward,n),this._aboveGround=n}Object.defineProperties(tg.prototype,{vertexShaderSource:{get:function(){return this._vertexShaderSource}},fragmentShaderSource:{get:function(){return this._fragmentShaderSource}},renderState:{get:function(){return this._renderState}},closed:{get:function(){return this._closed}},vertexFormat:{get:function(){return tg.VERTEX_FORMAT}},flat:{get:function(){return this._flat}},faceForward:{get:function(){return this._faceForward}},aboveGround:{get:function(){return this._aboveGround}}});tg.VERTEX_FORMAT=ee.POSITION_AND_ST;tg.prototype.getFragmentShaderSource=Va.prototype.getFragmentShaderSource;tg.prototype.isTranslucent=Va.prototype.isTranslucent;tg.prototype.getRenderState=Va.prototype.getRenderState;var klt=tg;var wKo=b(W(),1);function w5(t){if(t=f(t,f.EMPTY_OBJECT),!c(t.id))throw new Ut("options.id is required.");if(!c(EH[t.id]))throw new Ut(`options.id ${t.id} is not found in embedded imagery provider`);if(!c(t.path))throw new Ut("options.path is required.");if(!c(EH[t.id][`/${t.path}/0/0/0.jpg`]))throw new Ut(`options.path ${t.path} is not found in embedded imagery provider`);this._staticImagerySource=EH[t.id],this._staticImageryPath=t.path,this._tilingScheme=this._staticImagerySource.tilemapresource.TileMap.SRS.indexOf("4326")>-1?new Qo({ellipsoid:mt.WGS84}):new Gs({ellipsoid:mt.WGS84}),this._reverseY=!(this._staticImagerySource.tilemapresource.TileMap.SRS.indexOf("4326")>-1);let{width:e,height:n}=this._staticImagerySource.tilemapresource.TileMap.TileFormat[0].$;this._tileWidth=e,this._tileHeight=n,this._minimumLevel=0,this._maximumLevel=this._staticImagerySource.tilemapresource.TileMap.TileSets[0].TileSet.length-1,this._rectangle=this._tilingScheme.rectangle,this._errorEvent=new It;let i=t.credit;this._credit=typeof i=="string"?new on(i):i,this._readyPromise=kd()}function qMe(t,e,n,i,o,a){let s=t._staticImagerySource[`/${t._staticImageryPath}/${i}/${e}/${n}.jpg`];return s?te.fetchImage({url:s}):null}Object.defineProperties(w5.prototype,{url:{get:function(){return this._resource.url}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return this._minimumLevel}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},format:{get:function(){return this._format}},ready:{value:!0},readyPromise:{get:function(){return this._readyPromise.promise}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return!0}},clock:{get:function(){return this._timeDynamicImagery.clock},set:function(t){this._timeDynamicImagery.clock=t}},times:{get:function(){return this._timeDynamicImagery.times},set:function(t){this._timeDynamicImagery.times=t}}});w5.prototype.getTileCredits=function(t,e,n){};w5.prototype.pickFeatures=function(t,e,n,i,o){};w5.prototype.requestImage=function(t,e,n,i){let o,a;return this._reverseY&&(e=this.tilingScheme.getNumberOfYTilesAtLevel(n)-e-1),c(o)||(o=qMe(this,t,e,n,i,a)),o};var Ylt=w5;var tzo=b(W(),1);function oh(t){this._scene=t.scene,this.samplingWindow=f(t.samplingWindow,oh.defaultSettings.samplingWindow),this.quietPeriod=f(t.quietPeriod,oh.defaultSettings.quietPeriod),this.warmupPeriod=f(t.warmupPeriod,oh.defaultSettings.warmupPeriod),this.minimumFrameRateDuringWarmup=f(t.minimumFrameRateDuringWarmup,oh.defaultSettings.minimumFrameRateDuringWarmup),this.minimumFrameRateAfterWarmup=f(t.minimumFrameRateAfterWarmup,oh.defaultSettings.minimumFrameRateAfterWarmup),this._lowFrameRate=new It,this._nominalFrameRate=new It,this._frameTimes=[],this._needsQuietPeriod=!0,this._quietPeriodEndTime=0,this._warmupPeriodEndTime=0,this._frameRateIsLow=!1,this._lastFramesPerSecond=void 0,this._pauseCount=0;let e=this;this._preUpdateRemoveListener=this._scene.preUpdate.addEventListener(function(o,a){$Me(e,a)}),this._hiddenPropertyName=document.hidden!==void 0?"hidden":document.mozHidden!==void 0?"mozHidden":document.msHidden!==void 0?"msHidden":document.webkitHidden!==void 0?"webkitHidden":void 0;let n=document.hidden!==void 0?"visibilitychange":document.mozHidden!==void 0?"mozvisibilitychange":document.msHidden!==void 0?"msvisibilitychange":document.webkitHidden!==void 0?"webkitvisibilitychange":void 0;function i(){t_e(e)}this._visibilityChangeRemoveListener=void 0,c(n)&&(document.addEventListener(n,i,!1),this._visibilityChangeRemoveListener=function(){document.removeEventListener(n,i,!1)})}oh.defaultSettings={samplingWindow:5,quietPeriod:2,warmupPeriod:5,minimumFrameRateDuringWarmup:4,minimumFrameRateAfterWarmup:8};oh.fromScene=function(t){return(!c(t._frameRateMonitor)||t._frameRateMonitor.isDestroyed())&&(t._frameRateMonitor=new oh({scene:t})),t._frameRateMonitor};Object.defineProperties(oh.prototype,{scene:{get:function(){return this._scene}},lowFrameRate:{get:function(){return this._lowFrameRate}},nominalFrameRate:{get:function(){return this._nominalFrameRate}},lastFramesPerSecond:{get:function(){return this._lastFramesPerSecond}}});oh.prototype.pause=function(){++this._pauseCount,this._pauseCount===1&&(this._frameTimes.length=0,this._lastFramesPerSecond=void 0)};oh.prototype.unpause=function(){--this._pauseCount,this._pauseCount<=0&&(this._pauseCount=0,this._needsQuietPeriod=!0)};oh.prototype.isDestroyed=function(){return!1};oh.prototype.destroy=function(){return this._preUpdateRemoveListener(),c(this._visibilityChangeRemoveListener)&&this._visibilityChangeRemoveListener(),At(this)};function $Me(t,e){if(t._pauseCount>0)return;let n=Oi();if(t._needsQuietPeriod)t._needsQuietPeriod=!1,t._frameTimes.length=0,t._quietPeriodEndTime=n+t.quietPeriod/xi.SECONDS_PER_MILLISECOND,t._warmupPeriodEndTime=t._quietPeriodEndTime+(t.warmupPeriod+t.samplingWindow)/xi.SECONDS_PER_MILLISECOND;else if(n>=t._quietPeriodEndTime){t._frameTimes.push(n);let i=n-t.samplingWindow/xi.SECONDS_PER_MILLISECOND;if(t._frameTimes.length>=2&&t._frameTimes[0]<=i){for(;t._frameTimes.length>=2&&t._frameTimes[1]<i;)t._frameTimes.shift();let o=(n-t._frameTimes[0])/(t._frameTimes.length-1);t._lastFramesPerSecond=1e3/o;let a=1e3/(n>t._warmupPeriodEndTime?t.minimumFrameRateAfterWarmup:t.minimumFrameRateDuringWarmup);o>a?t._frameRateIsLow||(t._frameRateIsLow=!0,t._needsQuietPeriod=!0,t.lowFrameRate.raiseEvent(t.scene,t._lastFramesPerSecond)):t._frameRateIsLow&&(t._frameRateIsLow=!1,t._needsQuietPeriod=!0,t.nominalFrameRate.raiseEvent(t.scene,t._lastFramesPerSecond))}}}function t_e(t){document[t._hiddenPropertyName]?t.pause():t.unpause()}var P5=oh;var Vzo=b(W(),1);var Bkt=b(wst(),1);function xlt(){this._image=new Image}xlt.prototype.isReady=function(){return!0};xlt.prototype.shouldDiscardImage=function(t){return t===this._image};function eg(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._tileDiscardPolicy=t.tileDiscardPolicy,this._tilingScheme=new Qo({numberOfLevelZeroTilesX:2,numberOfLevelZeroTilesY:2,rectangle:new Gt(-k.PI,-k.PI,k.PI,k.PI),ellipsoid:t.ellipsoid});let e=t.credit;typeof e=="string"&&(e=new on(e)),this._credit=e,this._tileWidth=256,this._tileHeight=256,this._maximumLevel=23,c(this._tileDiscardPolicy)||(this._tileDiscardPolicy=new xlt),this._errorEvent=new It}Object.defineProperties(eg.prototype,{url:{get:function(){return this._metadata.url}},proxy:{get:function(){return this._metadata.proxy}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return 0}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return!1}}});eg.fromMetadata=function(t,e){if(!t.imageryPresent)throw new Tt(`The server ${t.url} doesn't have imagery`);let n=new eg(e);return n._metadata=t,n};eg.prototype.getTileCredits=function(t,e,n){let i=this._metadata,o=i.getTileInformation(t,e,n);if(c(o)){let a=i.providers[o.imageryProvider];if(c(a))return[a]}};eg.prototype.requestImage=function(t,e,n,i){let o=this._tileDiscardPolicy._image,a=this._metadata,s=EW.tileXYToQuadKey(t,e,n),l=a.getTileInformation(t,e,n);if(!c(l)){if(a.isValid(s)){let d=new us({throttle:i.throttle,throttleByServer:i.throttleByServer,type:i.type,priorityFunction:i.priorityFunction});a.populateSubtree(t,e,n,d);return}return Promise.resolve(o)}if(!l.hasImagery())return Promise.resolve(o);let r=e_e(this,l,t,e,n,i).fetchArrayBuffer();if(c(r))return r.then(function(d){Q5(a.key,d);let m=new Uint8Array(d),h,u=a.protoImagery;if((!c(u)||!u)&&(h=n_e(m)),!c(h)&&(!c(u)||u)){let R=i_e(m);h=R.imageType,m=R.imageData}return!c(h)||!c(m)?o:uA({uint8Array:m,format:h,flipY:!0})})};eg.prototype.pickFeatures=function(t,e,n,i,o){};function e_e(t,e,n,i,o,a){let s=EW.tileXYToQuadKey(n,i,o),l=e.imageryVersion;return l=c(l)&&l>0?l:1,t._metadata.resource.getDerivedResource({url:`flatfile?f1-0${s}-i.${l.toString()}`,request:a})}function n_e(t){let e="JFIF";if(t[6]===e.charCodeAt(0)&&t[7]===e.charCodeAt(1)&&t[8]===e.charCodeAt(2)&&t[9]===e.charCodeAt(3))return"image/jpeg";let n="PNG";if(t[1]===n.charCodeAt(0)&&t[2]===n.charCodeAt(1)&&t[3]===n.charCodeAt(2))return"image/png"}function i_e(t){let e=Bkt.Reader.create(t),n=e.len,i={};for(;e.pos<n;){let s=e.uint32(),l;switch(s>>>3){case 1:i.imageType=e.uint32();break;case 2:i.imageData=e.bytes();break;case 3:i.alphaType=e.uint32();break;case 4:i.imageAlpha=e.bytes();break;case 5:if(l=i.copyrightIds,c(l)||(l=i.copyrightIds=[]),(s&7)===2){let r=e.uint32()+e.pos;for(;e.pos<r;)l.push(e.uint32())}else l.push(e.uint32());break;default:e.skipType(s&7);break}}let o=i.imageType;if(c(o))switch(o){case 0:i.imageType="image/jpeg";break;case 4:i.imageType="image/png";break;default:throw new Tt("GoogleEarthEnterpriseImageryProvider: Unsupported image type.")}let a=i.alphaType;return c(a)&&a!==0&&(console.log("GoogleEarthEnterpriseImageryProvider: External alpha not supported."),delete i.alphaType,delete i.imageAlpha),i}var Xlt=eg;var Fzo=b(W(),1);var o_e=new v(1,1,1,.4),a_e=new v(0,1,0,.05),s_e=new v(0,.5,0,.2);function ng(t){t=f(t,f.EMPTY_OBJECT),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0,this._tilingScheme=c(t.tilingScheme)?t.tilingScheme:new Qo({ellipsoid:t.ellipsoid}),this._cells=f(t.cells,8),this._color=f(t.color,o_e),this._glowColor=f(t.glowColor,a_e),this._glowWidth=f(t.glowWidth,6),this._backgroundColor=f(t.backgroundColor,s_e),this._errorEvent=new It,this._tileWidth=f(t.tileWidth,256),this._tileHeight=f(t.tileHeight,256),this._canvasSize=f(t.canvasSize,256),this._canvas=this._createGridCanvas()}Object.defineProperties(ng.prototype,{proxy:{get:function(){}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){}},minimumLevel:{get:function(){}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){}},hasAlphaChannel:{get:function(){return!0}}});ng.prototype._drawGrid=function(t){let n=this._canvasSize;for(let i=0;i<=this._cells;++i){let a=1+i/this._cells*(n-1);t.moveTo(a,0),t.lineTo(a,n),t.moveTo(0,a),t.lineTo(n,a)}t.stroke()};ng.prototype._createGridCanvas=function(){let t=document.createElement("canvas");t.width=this._canvasSize,t.height=this._canvasSize;let e=0,n=this._canvasSize,i=t.getContext("2d"),o=this._backgroundColor.toCssColorString();i.fillStyle=o,i.fillRect(e,e,n,n);let a=this._glowColor.toCssColorString();i.strokeStyle=a,i.lineWidth=this._glowWidth,i.strokeRect(e,e,n,n),this._drawGrid(i),i.lineWidth=this._glowWidth*.5,i.strokeRect(e,e,n,n),this._drawGrid(i);let s=this._color.toCssColorString();return i.strokeStyle=s,i.lineWidth=2,i.strokeRect(e,e,n,n),i.lineWidth=1,this._drawGrid(i),t};ng.prototype.getTileCredits=function(t,e,n){};ng.prototype.requestImage=function(t,e,n,i){return Promise.resolve(this._canvas)};ng.prototype.pickFeatures=function(t,e,n,i,o){};var Jlt=ng;var i4o=b(W(),1);var Ejo=b(W(),1);var cjo=b(W(),1);var Nzo=b(W(),1);function RZ(){}RZ._maxDecodingConcurrency=Math.max(In.hardwareConcurrency-1,1);RZ._decodeTaskProcessor=new $i("decodeI3S",RZ._maxDecodingConcurrency);RZ._promise=void 0;async function l_e(){if(await RZ._decodeTaskProcessor.initWebAssemblyModule({wasmBinaryFile:"ThirdParty/draco_decoder.wasm"}))return RZ._decodeTaskProcessor;throw new Tt("I3S decoder could not be initialized.")}RZ.decode=async function(t,e,n,i,o){return c(RZ._promise)||(RZ._promise=l_e()),RZ._promise.then(function(a){let s=n._parent._data,l=n._parent._inverseRotationMatrix,r=0,d=0,m=0;c(s.obb)?(r=s.obb.center[0],d=s.obb.center[1],m=s.obb.center[2]):c(s.mbs)&&(r=s.mbs[0],d=s.mbs[1],m=s.mbs[2]);let h=ot.fromRotationX(-k.PI_OVER_TWO),u=new ot;ot.multiply(h,l,u);let R=gt.fromDegrees(r,d,m),V=mt.WGS84.cartographicToCartesian(R),F={binaryData:n._data,featureData:c(i)&&c(i[0])?i[0].data:void 0,schema:e,bufferInfo:n._geometryBufferInfo,ellipsoidRadiiSquare:mt.WGS84.radiiSquared,url:t,geoidDataList:n._dataProvider._geoidDataList,cartographicCenter:R,cartesianCenter:V,parentRotation:u,enableFeatures:n._dataProvider.showFeatures,splitGeometryByColorTransparency:n._dataProvider.adjustMaterialAlphaMode,symbologyData:o,calculateNormals:n._dataProvider.calculateNormals};return a.scheduleTask(F)})};var v5=RZ;var kzo=b(W(),1);function Llt(t,e){this._parent=t,this._dataProvider=t._dataProvider,this._layer=t._layer,c(this._parent._nodeIndex)?this._resource=this._parent._layer.resource.getDerivedResource({url:`nodes/${this._parent._data.mesh.attribute.resource}/${e}`}):this._resource=this._parent.resource.getDerivedResource({url:e})}Object.defineProperties(Llt.prototype,{resource:{get:function(){return this._resource}},data:{get:function(){return this._data}}});Llt.prototype.load=async function(){return this._data=await bZ.loadJson(this._resource),this._data};var K5=Llt;var Jzo=b(W(),1);function CW(t,e){this._storageInfo=e,this._parent=t,this._dataProvider=t._dataProvider,this._loadPromise=void 0;let n=`attributes/${e.key}/0`;c(this._parent._nodeIndex)?this._resource=this._parent._layer.resource.getDerivedResource({url:`nodes/${this._parent._data.mesh.attribute.resource}/${n}`}):this._resource=this._parent.resource.getDerivedResource({url:n})}Object.defineProperties(CW.prototype,{resource:{get:function(){return this._resource}},header:{get:function(){return this._header}},values:{get:function(){if(c(this._values)){if(c(this._values.attributeValues))return this._values.attributeValues;if(c(this._values.objectIds))return this._values.objectIds}return[]}},name:{get:function(){return this._storageInfo.name}}});function zj(t){return t==="UInt8"||t==="Int8"?1:t==="UInt16"||t==="Int16"?2:t==="UInt32"||t==="Int32"||t==="Oid32"||t==="Float32"?4:t==="UInt64"||t==="Int64"||t==="Float64"?8:0}function r_e(t){return t==="String"?1:zj(t)}async function d_e(t){let e=await t._dataProvider._loadBinary(t._resource),n=new DataView(e);t._data=e,t._validateHeader(n);let i=t._parseHeader(n),o=t._getBodyOffset(i);t._validateBody(n,o),t._parseBody(n,o)}CW.prototype.load=function(){return c(this._loadPromise)?this._loadPromise:(this._loadPromise=d_e(this).catch(function(t){console.error(t)}),this._loadPromise)};CW.prototype._parseValue=function(t,e,n){let i;if(e==="UInt8")i=t.getUint8(n),n+=1;else if(e==="Int8")i=t.getInt8(n),n+=1;else if(e==="UInt16")i=t.getUint16(n,!0),n+=2;else if(e==="Int16")i=t.getInt16(n,!0),n+=2;else if(e==="UInt32")i=t.getUint32(n,!0),n+=4;else if(e==="Oid32")i=t.getUint32(n,!0),n+=4;else if(e==="Int32")i=t.getInt32(n,!0),n+=4;else if(e==="UInt64"){let o=t.getUint32(n,!0),a=t.getUint32(n+4,!0);i=o+Math.pow(2,32)*a,n+=8}else if(e==="Int64"){let o=t.getUint32(n,!0),a=t.getUint32(n+4,!0);a<Math.pow(2,31)?i=o+Math.pow(2,32)*a:i=o+Math.pow(2,32)*(a-Math.pow(2,32)),n+=8}else e==="Float32"?(i=t.getFloat32(n,!0),n+=4):e==="Float64"?(i=t.getFloat64(n,!0),n+=8):e==="String"&&(i=String.fromCharCode(t.getUint8(n)),n+=1);return{value:i,offset:n}};CW.prototype._parseHeader=function(t){let e=0;this._header={};for(let n=0;n<this._storageInfo.header.length;n++){let i=this._storageInfo.header[n],o=this._parseValue(t,i.valueType,e);this._header[i.property]=o.value,e=o.offset}return e};CW.prototype._parseBody=function(t,e){this._values={};for(let n=0;n<this._storageInfo.ordering.length;n++){let i=this._storageInfo.ordering[n],o=i==="ObjectIds"?"objectIds":i,a=this._storageInfo[o];if(c(a)){this._values[o]=[];for(let s=0;s<this._header.count;++s)if(a.valueType!=="String"){let l=this._parseValue(t,a.valueType,e);this._values[o].push(l.value),e=l.offset}else{let l=this._values.attributeByteCounts[s],r="";for(let d=0;d<l;++d){let m=this._parseValue(t,a.valueType,e);m.value.charCodeAt(0)!==0&&(r+=m.value),e=m.offset}this._values[o].push(r)}}}};CW.prototype._getBodyOffset=function(t){let e=0;return c(this._storageInfo.attributeValues)?e=zj(this._storageInfo.attributeValues.valueType):c(this._storageInfo.objectIds)&&(e=zj(this._storageInfo.objectIds.valueType)),e>0?Math.ceil(t/e)*e:t};CW.prototype._validateHeader=function(t){let e=0;for(let n=0;n<this._storageInfo.header.length;n++){let i=this._storageInfo.header[n];e+=r_e(i.valueType)}if(t.byteLength<e)throw new Tt(`Invalid attribute buffer size (field: ${this.name}, header: ${e}, actual: ${t.byteLength})`)};CW.prototype._validateBody=function(t,e){if(!c(this._header.count))throw new Tt(`Invalid attribute buffer (field: ${this.name}, count is missing)`);let n;for(let i=0;i<this._storageInfo.ordering.length&&e<t.byteLength;i++){let o=this._storageInfo.ordering[i],a=o==="ObjectIds"?"objectIds":o,s=this._storageInfo[a];if(c(s))if(s.valueType!=="String"){a==="attributeByteCounts"&&(n=e);let l=zj(s.valueType);e+=l*this._header.count}else{if(!c(n))throw new Tt(`Invalid attribute buffer (field: ${this.name}, attributeByteCounts is missing)`);for(let l=0;l<this._header.count&&e<t.byteLength;++l){let r=this._parseValue(t,this._storageInfo.attributeByteCounts.valueType,n);e+=r.value,n=r.offset}}else throw new Tt(`Invalid attribute buffer (field: ${this.name}, ${a} is missing)`)}if(t.byteLength<e)throw new Tt(`Invalid attribute buffer size (field: ${this.name}, expected: ${e}, actual: ${t.byteLength})`)};var z5=CW;var wzo=b(W(),1);function j5(t,e){let n=t._dataProvider,i=t._layer,o;c(t._nodeIndex)?o=i.resource.getDerivedResource({url:`nodes/${t._data.mesh.geometry.resource}/${e}`}):o=t.resource.getDerivedResource({url:e}),this._parent=t,this._dataProvider=n,this._layer=i,this._resource=o,this._customAttributes=void 0}Object.defineProperties(j5.prototype,{resource:{get:function(){return this._resource}},data:{get:function(){return this._data}},customAttributes:{get:function(){return this._customAttributes}}});j5.prototype.load=function(){let t=this;return this._dataProvider._loadBinary(this._resource).then(function(e){return t._data=e,e})};var c_e=new p,m_e=new p,h_e=new p,p_e=new p,V_e=new p;function Mlt(t,e,n,i){let o=p.subtract(i,n,c_e),a=p.cross(o,p.subtract(t,n,m_e),p_e),s=p.cross(o,p.subtract(e,n,h_e),V_e);return p.dot(a,s)>=0}var u_e=new p,Z_e=new p,R_e=new p,b_e=new p,W_e=new p,f_e=new p,F_e=new p,U_e=new p,G_e=new p,A_e=new p;j5.prototype.getClosestPointIndexOnTriangle=function(t,e,n){if(c(this._customAttributes)&&c(this._customAttributes.positions)){let i=new p(t,e,n);i.x-=this._customAttributes.cartesianCenter.x,i.y-=this._customAttributes.cartesianCenter.y,i.z-=this._customAttributes.cartesianCenter.z,ot.multiplyByVector(this._customAttributes.parentRotation,i,i);let o=Number.MAX_VALUE,a,s,l,r,d=this._customAttributes.positions,m=this._customAttributes.indices,h;c(m)?h=m.length:h=d.length/3;for(let u=0;u<h;u++){let R,V,F;c(m)?(R=m[u],V=m[u+1],F=m[u+2]):(R=u*3,V=u*3+1,F=u*3+2);let U=p.fromElements(d[R*3],d[R*3+1],d[R*3+2],u_e),G=p.fromElements(d[V*3],d[V*3+1],d[V*3+2],Z_e),A=new p(d[F*3],d[F*3+1],d[F*3+2],R_e);if(!Mlt(i,U,G,A)||!Mlt(i,G,U,A)||!Mlt(i,A,U,G))continue;let S=p.subtract(G,U,b_e),g=p.subtract(A,U,W_e),C=p.cross(S,g,f_e);if(p.magnitude(C)===0)continue;let y=p.normalize(C,F_e),Y=p.subtract(i,U,U_e),Q=Math.abs(p.dot(Y,y));if(Q<o){o=Q,a=u;let J=p.magnitudeSquared(p.subtract(i,U,Y)),M=p.magnitudeSquared(p.subtract(i,G,G_e)),Z=p.magnitudeSquared(p.subtract(i,A,A_e));J<M&&J<Z?(l=R,r=U,s=J):M<Z?(l=V,r=G,s=M):(l=F,r=A,s=Z)}}if(c(a))return{index:l,distanceSquared:s,distance:Math.sqrt(s),queriedPosition:i,closestPosition:p.clone(r)}}return{index:-1,distanceSquared:Number.Infinity,distance:Number.Infinity}};function Qkt(t){let e=[],n=t.length;for(let i=0;i<n;i++)i<3?e.push(jT(t[i])):e.push(t[i]);return e}j5.prototype._generateGltf=function(t,e,n,i,o,a,s,l){let r={pbrMetallicRoughness:{metallicFactor:0},doubleSided:!0,name:"Material"},d=!1,m,h="";if(c(this._parent._data.mesh)&&c(this._layer._data.materialDefinitions)){let S=this._parent._data.mesh.material.definition;if(S>=0&&S<this._layer._data.materialDefinitions.length){if(m=this._layer._data.materialDefinitions[S],r=m,c(r.pbrMetallicRoughness)&&c(r.pbrMetallicRoughness.baseColorTexture)){d=!0,r.pbrMetallicRoughness.baseColorTexture.index=0;let g="0";if(c(this._layer._data.textureSetDefinitions))for(let C=0;C<this._layer._data.textureSetDefinitions.length;C++){let y=this._layer._data.textureSetDefinitions[C];for(let Y=0;Y<y.formats.length;Y++){let Q=y.formats[Y];if(Q.format==="jpg"){g=Q.name;break}}}c(this._parent._data.mesh)&&this._parent._data.mesh.material.resource>=0&&(h=this._layer.resource.getDerivedResource({url:`nodes/${this._parent._data.mesh.material.resource}/textures/${g}`}).url)}c(r.pbrMetallicRoughness)&&c(r.pbrMetallicRoughness.baseColorFactor)&&(r.pbrMetallicRoughness.baseColorFactor=Qkt(r.pbrMetallicRoughness.baseColorFactor)),c(r.emissiveFactor)&&(r.emissiveFactor=Qkt(r.emissiveFactor))}}else c(this._parent._data.textureData)&&(d=!0,h=this._parent.resource.getDerivedResource({url:`${this._parent._data.textureData[0].href}`}).url,r.pbrMetallicRoughness.baseColorTexture={index:0});c(r.alphaMode)&&(r.alphaMode=r.alphaMode.toUpperCase());let u=[],R=[],V=[];d&&(u=[{sampler:0,source:0}],R=[{uri:h}],V=[{magFilter:9729,minFilter:9986,wrapS:10497,wrapT:10497}]);let F=[],U=n.length;for(let A=0;A<U;A++){let S=n[A].primitives,g=S.length;for(let C=0;C<g;C++){let y=S[C];if(c(y.material)){for(;y.material>=F.length;){let Q=Re(r,!0);F.push(Q)}let Y=F[y.material];c(y.extra)&&y.extra.isTransparent?c(Y.alphaMode)||(Y.alphaMode="BLEND"):Y.alphaMode==="BLEND"&&(Y.alphaMode="OPAQUE")}}}return{scene:0,scenes:[{nodes:t}],nodes:e,meshes:n,buffers:i,bufferViews:o,accessors:a,materials:F,textures:u,images:R,samplers:V,asset:{version:"2.0"},extensions:s,extensionsUsed:l}};var hN=j5;function Rc(t,e,n){let i,o,a,s;n?(i=0,o=t):(i=t._level+1,o=t._layer),typeof e=="number"?a=e:s=t.resource.getDerivedResource({url:`${e}/`}),this._parent=t,this._dataProvider=t._dataProvider,this._isRoot=n,this._level=i,this._layer=o,this._nodeIndex=a,this._resource=s,this._isLoading=!1,this._tile=void 0,this._data=void 0,this._geometryData=[],this._featureData=[],this._fields={},this._children=[],this._childrenReadyPromise=void 0,this._globalTransform=void 0,this._inverseGlobalTransform=void 0,this._inverseRotationMatrix=void 0,this._symbologyData=void 0}Object.defineProperties(Rc.prototype,{resource:{get:function(){return this._resource}},layer:{get:function(){return this._layer}},parent:{get:function(){return this._parent}},children:{get:function(){return this._children}},geometryData:{get:function(){return this._geometryData}},featureData:{get:function(){return this._featureData}},fields:{get:function(){return this._fields}},tile:{get:function(){return this._tile}},data:{get:function(){return this._data}}});Rc.prototype.load=async function(){let t=this;function e(){if(!t._isRoot){let o=t._create3DTileDefinition();t._tile=new iV(t._layer._tileset,t._dataProvider.resource,o,t._parent._tile),t._tile._i3sNode=t}}if(!c(this._nodeIndex)){let o=await bZ.loadJson(this._resource);t._data=o,e();return}let n=await this._layer._getNodeInNodePages(this._nodeIndex);t._data=n;let i;t._isRoot?i="nodes/root/":c(n.mesh)&&(i=`../${n.mesh.geometry.resource}/`),c(i)&&(t._resource=t._parent.resource.getDerivedResource({url:i})),e()};function kkt(t,e){let n=new z5(t,e);return t._fields[e.name]=n,n.load()}Rc.prototype.loadFields=function(){let t=this._layer._data.attributeStorageInfo,e=[];if(c(t))for(let n=0;n<t.length;n++){let i=t[n],o=this._fields[i.name];c(o)?e.push(o.load()):e.push(kkt(this,i))}return Promise.all(e)};Rc.prototype.loadField=function(t){let e=this._fields[t];if(c(e))return e.load();let n=this._layer._data.attributeStorageInfo;if(c(n))for(let i=0;i<n.length;i++){let o=n[i];if(o.name===t)return kkt(this,o)}return Promise.resolve()};Rc.prototype.getFieldsForPickedPosition=function(t){let e=this.geometryData[0];if(!c(e.customAttributes.featureIndex))return{};let n=e.getClosestPointIndexOnTriangle(t.x,t.y,t.z);if(n.index===-1||n.index>e.customAttributes.featureIndex.length)return{};let i=e.customAttributes.featureIndex[n.index];return this.getFieldsForFeature(i)};Rc.prototype.getFieldsForFeature=function(t){let e={};for(let n in this.fields)if(this.fields.hasOwnProperty(n)){let i=this.fields[n];t>=0&&t<i.values.length&&(e[i.name]=i.values[t])}return e};Rc.prototype._loadChildren=function(){let t=this;if(c(this._childrenReadyPromise))return this._childrenReadyPromise;let e=[];if(c(t._data.children))for(let n=0;n<t._data.children.length;n++){let i=t._data.children[n],o=new Rc(t,f(i.href,i),!1);t._children.push(o),e.push(o.load())}return this._childrenReadyPromise=Promise.all(e).then(function(){for(let n=0;n<t._children.length;n++)t._tile.children.push(t._children[n]._tile)}),this._childrenReadyPromise};Rc.prototype._loadGeometryData=function(){let t=[];if(c(this._data.geometryData))for(let e=0;e<this._data.geometryData.length;e++){let n=new hN(this,this._data.geometryData[e].href);this._geometryData.push(n),t.push(n.load())}else if(c(this._data.mesh)){let e=this._layer._findBestGeometryBuffers(this._data.mesh.geometry.definition,["position","uv0"]),n=`./geometries/${e.bufferIndex}/`,i=new hN(this,n);i._geometryDefinitions=e.definition,i._geometryBufferInfo=e.geometryBufferInfo,this._geometryData.push(i),t.push(i.load())}return Promise.all(t)};Rc.prototype._loadFeatureData=function(){let t=[];if(c(this._data.featureData))for(let e=0;e<this._data.featureData.length;e++){let n=new K5(this,this._data.featureData[e].href);this._featureData.push(n),t.push(n.load())}return Promise.all(t)};Rc.prototype._clearGeometryData=function(){this._geometryData=[]};Rc.prototype._create3DTileDefinition=function(){let t=this._data.obb,e=this._data.mbs;if(!c(t)&&!c(e)){console.error("Failed to load I3S node. Bounding volume is required.");return}let n;if(c(t)?n=gt.fromDegrees(t.center[0],t.center[1],t.center[2]):n=gt.fromDegrees(e[0],e[1],e[2]),c(this._dataProvider._geoidDataList)&&c(n))for(let G=0;G<this._dataProvider._geoidDataList.length;G++){let A=this._dataProvider._geoidDataList[G],S=A.projection.project(n);if(S.x>A.nativeExtent.west&&S.x<A.nativeExtent.east&&S.y>A.nativeExtent.south&&S.y<A.nativeExtent.north){n.height+=E_e(S.x,S.y,A);break}}let i={},o,a=0;c(t)?(i={box:[0,0,0,t.halfSize[0],0,0,0,t.halfSize[1],0,0,0,t.halfSize[2]]},a=Math.max(Math.max(this._data.obb.halfSize[0],this._data.obb.halfSize[1]),this._data.obb.halfSize[2]),o=mt.WGS84.cartographicToCartesian(n)):(i={sphere:[0,0,0,e[3]]},o=mt.WGS84.cartographicToCartesian(n),a=this._data.mbs[3]),a*=2;let s=1/0;if(c(this._data.lodThreshold))if(this._layer._data.nodePages.lodSelectionMetricType==="maxScreenThresholdSQ"){let G=Math.sqrt(this._data.lodThreshold/(Math.PI*.25));s=a/G}else if(this._layer._data.nodePages.lodSelectionMetricType==="maxScreenThreshold"){let G=this._data.lodThreshold;s=a/G}else console.error("Invalid lodSelectionMetricType in Layer");else if(c(this._data.lodSelection))for(let G=0;G<this._data.lodSelection.length;G++)this._data.lodSelection[G].metricType==="maxScreenThreshold"&&(s=a/this._data.lodSelection[G].maxError);s===1/0&&(s=1e5);let l=s*16,r=new Jr(0,0,0),d=Pe.headingPitchRollQuaternion(o,r);c(this._data.obb)&&(d=new wt(this._data.obb.quaternion[0],this._data.obb.quaternion[1],this._data.obb.quaternion[2],this._data.obb.quaternion[3]));let m=ot.fromQuaternion(d),h=ot.inverse(m,new ot),u=new L(m[0],m[1],m[2],0,m[3],m[4],m[5],0,m[6],m[7],m[8],0,o.x,o.y,o.z,1),R=L.inverse(u,new L),V=L.clone(u);c(this._parent._globalTransform)&&L.multiply(u,this._parent._inverseGlobalTransform,V),this._globalTransform=u,this._inverseGlobalTransform=R,this._inverseRotationMatrix=h;let F=[];for(let G=0;G<this._children.length;G++)F.push(this._children[G]._create3DTileDefinition());return{children:F,refine:"REPLACE",boundingVolume:i,transform:[V[0],V[4],V[8],V[12],V[1],V[5],V[9],V[13],V[2],V[6],V[10],V[14],V[3],V[7],V[11],V[15]],content:{uri:c(this._resource)?this._resource.url:void 0},geometricError:l}};Rc.prototype._loadSymbology=async function(){!c(this._symbologyData)&&c(this._layer._symbology)&&(this._symbologyData=await this._layer._symbology._getSymbology(this))};Rc.prototype._createContentURL=async function(){let t={scene:0,scenes:[{nodes:[0]}],nodes:[{name:"singleNode"}],meshes:[],buffers:[],bufferViews:[],accessors:[],materials:[],textures:[],images:[],samplers:[],asset:{version:"2.0"}},e=[this._loadGeometryData()];if(this._dataProvider.legacyVersion16&&e.push(this._loadFeatureData()),await Promise.all(e),c(this._geometryData)&&this._geometryData.length>0){this._dataProvider._applySymbology&&await this._loadSymbology();let o=this._geometryData[0].resource.url,a=this._layer._data.store.defaultGeometrySchema,s=this._geometryData[0],l=await v5.decode(o,a,s,this._featureData[0],this._symbologyData);if(!c(l))return;t=s._generateGltf(l.meshData.nodesInScene,l.meshData.nodes,l.meshData.meshes,l.meshData.buffers,l.meshData.bufferViews,l.meshData.accessors,l.meshData.rootExtensions,l.meshData.extensionsUsed),this._geometryData[0]._customAttributes=l.meshData._customAttributes}let n=this._dataProvider._binarizeGltf(t),i=new Blob([n],{type:"application/binary"});return URL.createObjectURL(i)};async function S_e(t){let e=t._layer._filters,n=[];for(let i=0;i<e.length;i++){let o=t.loadField(e[i].name);n.push(o)}return await Promise.all(n),e}function T_e(t,e,n){if(!c(n.values)||n.values.length===0)return!1;let i=c(e)?e.values:[],o;t<i.length&&(o=i[t]);let a=!1;for(let s=0;s<n.values.length;s++)if(n.values[s]===o){a=!0;break}return a}async function Ykt(t,e){let n=t._tile.content.batchTable;if(c(n)&&n.featuresLength>0){n.setAllShow(!0);let i=await S_e(t);if(i.length>0)for(let o=0;o<n.featuresLength;o++)for(let a=0;a<i.length;a++){let s=i[a];if(!T_e(o,t._fields[s.name],s)){n.setShow(o,!1);break}}}e.show=!0}Rc.prototype._filterFeatures=function(){let t=[];for(let n=0;n<this._children.length;n++){let i=this._children[n]._filterFeatures();t.push(i)}let e=this._tile?.content?._model;if(c(this._geometryData)&&this._geometryData.length>0&&c(e)&&e.ready){e.show=!1;let n=Ykt(this,e);t.push(n)}return Promise.all(t)};iV.prototype._hookedRequestContent=iV.prototype.requestContent;iV.prototype.requestContent=function(){if(!this.tileset._isI3STileSet)return this._hookedRequestContent();if(!this._isLoading){this._isLoading=!0;let t=this;return this._i3sNode._createContentURL().then(e=>{if(!c(e)){t._isLoading=!1;return}return t._contentResource=new te({url:e}),t._hookedRequestContent()}).then(e=>{let n=e?._model;return c(t._i3sNode._geometryData)&&t._i3sNode._geometryData.length>0&&c(n)&&(n.show=!1,n.readyEvent.addEventListener(()=>{Ykt(t._i3sNode,n)})),t._isLoading=!1,e})}};function g_e(t,e,n,i,o,a){let s=n*(1-t)+i*t,l=o*(1-t)+a*t;return s*(1-e)+l*e}function jj(t,e,n,i){let o=t+e*n;return i[o]}function E_e(t,e,n){let i=n.nativeExtent,o=(t-i.west)/(i.east-i.west)*(n.width-1),a=(e-i.south)/(i.north-i.south)*(n.height-1),s=Math.floor(o),l=Math.floor(a);o-=s,a-=l;let r=s<n.width?s+1:s,d=l<n.height?l+1:l;l=n.height-1-l,d=n.height-1-d;let m=jj(s,l,n.width,n.buffer),h=jj(r,l,n.width,n.buffer),u=jj(s,d,n.width,n.buffer),R=jj(r,d,n.width,n.buffer),V=g_e(o,a,m,h,u,R);return V=V*n.scale+n.offset,V}Object.defineProperties(iV.prototype,{i3sNode:{get:function(){return this._i3sNode}}});var pN=Rc;var Zjo=b(W(),1);function qj(t){this._layer=t,this._defaultSymbology=void 0,this._valueFields=[],this._uniqueValueHash=void 0,this._classBreaksHash=void 0,this._parseLayerSymbology()}Object.defineProperties(qj.prototype,{defaultSymbology:{get:function(){return this._defaultSymbology}}});function _lt(t,e){let n=[];for(let i=0;i<t.length;i++){let o=v.byteToFloat(t[i]);i<3?n.push(jT(o)):n.push(o)}return n.length===3&&(c(e)?n.push(1-e/100):n.push(1)),n}function VN(t,e){let n={edges:void 0,material:void 0};if(c(t)&&c(t.symbolLayers))for(let i=0;i<t.symbolLayers.length;i++){let o=t.symbolLayers[i];if(o.type==="Fill"){let a=o.edges,s=o.outline;if(c(a)?(n.edges={},c(a.color)&&(n.edges.color=_lt(a.color,a.transparency))):c(s)&&(n.edges={},c(s.color)&&(n.edges.color=_lt(s.color,s.transparency))),!e){let l=o.material;c(l)&&(n.material={colorMixMode:l.colorMixMode},c(l.color)&&(n.material.color=_lt(l.color,l.transparency)))}break}}return n}function C_e(t,e){if(c(t.uniqueValueGroups)){let n={};for(let i=0;i<t.uniqueValueGroups.length;i++){let o=t.uniqueValueGroups[i].classes;if(c(o))for(let a=0;a<o.length;a++){let s=VN(o[a].symbol,e),l=o[a].values;for(let r=0;r<l.length;r++){let d=l[r],m=n;for(let h=0;h<d.length;h++){let u=d[h];h===d.length-1?m[u]=s:(c(m[u])||(m[u]={}),m=m[u])}}}}return n}if(c(t.uniqueValueInfos)){let n={};for(let i=0;i<t.uniqueValueInfos.length;i++){let o=t.uniqueValueInfos[i];n[o.value]=VN(o.symbol,e)}return n}}function I_e(t,e){if(c(t.classBreakInfos)){let n=[...t.classBreakInfos];n.sort(function(o,a){let s=f(o.classMaxValue,o.classMinValue),l=f(a.classMaxValue,a.classMinValue);return s-l});let i={ranges:[],symbols:[]};c(t.minValue)&&(i.ranges.push(t.minValue),i.symbols.push(void 0));for(let o=0;o<n.length;o++){let a=n[o];c(a.classMinValue)&&(i.ranges.length===0||a.classMinValue>i.ranges[i.ranges.length-1])&&(i.ranges.push(a.classMinValue),i.symbols.push(void 0)),c(a.classMaxValue)&&(i.ranges.length===0||a.classMaxValue>i.ranges[i.ranges.length-1])&&(i.ranges.push(a.classMaxValue),i.symbols.push(VN(a.symbol,e)))}return i.symbols.push(void 0),i}}qj.prototype._parseLayerSymbology=function(){let t=this._layer.data.drawingInfo;if(c(t)&&c(t.renderer)){let e=this._layer.data.cachedDrawingInfo,n=c(e)&&e.color===!0,i=t.renderer;i.type==="simple"?this._defaultSymbology=VN(i.symbol,n):i.type==="uniqueValue"?(this._defaultSymbology=VN(i.defaultSymbol,n),this._valueFields.push(i.field1),c(i.field2)&&this._valueFields.push(i.field2),c(i.field3)&&this._valueFields.push(i.field3),this._uniqueValueHash=C_e(i,n)):i.type==="classBreaks"&&(this._defaultSymbology=VN(i.defaultSymbol,n),this._valueFields.push(i.field),this._classBreaksHash=I_e(i,n))}};function xkt(t,e,n,i){let o=e[n];if(i<o.length){let a=o[i],s=t[a];return c(s)&&++n<e.length?xkt(s,e,n,i):s}}function N_e(t,e){let n=0,i=t.length;if(n<i)do{let o=n+i>>>1;t[o]<e?n=o+1:i=o}while(n<i);return n}function y_e(t,e,n){let i=e[n],o=N_e(t.ranges,i);return t.symbols[o]}qj.prototype._getSymbology=async function(t){let e={default:this._defaultSymbology};if(this._valueFields.length>0){let n=[];for(let a=0;a<this._valueFields.length;a++)n.push(t.loadField(this._valueFields[a]));await Promise.all(n);let i=[];for(let a=0;a<this._valueFields.length;a++)i.push(t.fields[this._valueFields[a]].values);let o;if(c(this._uniqueValueHash)?o=a=>xkt(this._uniqueValueHash,i,0,a):c(this._classBreaksHash)&&(o=a=>y_e(this._classBreaksHash,i[0],a)),c(o)){let a=i[0];for(let s=0;s<a.length;s++){let l=o(s);c(l)&&(e[s]=l)}}}return e};var q5=qj;function ah(t,e,n){this._dataProvider=t,this._parent=n,!c(e.href)&&c(e.id)&&(e.href=`layers/${e.id}`);let i=this._parent.resource.getUrlComponent(),o="";i.match(/layers\/\d/)?o=`${i}`.replace(/\/+$/,""):o=`${i}`.replace(/\/?$/,"/").concat(`${e.href}`),this._version=e.store.version;let a=this._version.split(".");this._majorVersion=parseInt(a[0]),this._minorVersion=a.length>1?parseInt(a[1]):0,this._resource=new te({url:o}),this._resource.setQueryParameters(this._dataProvider.resource.queryParameters),this._resource.appendForwardSlash(),this._data=e,this._rootNode=void 0,this._nodePages={},this._nodePageFetches={},this._extent=void 0,this._tileset=void 0,this._geometryDefinitions=void 0,this._filters=[],this._symbology=void 0,this._computeGeometryDefinitions(!0),this._computeExtent()}Object.defineProperties(ah.prototype,{resource:{get:function(){return this._resource}},rootNode:{get:function(){return this._rootNode}},tileset:{get:function(){return this._tileset}},data:{get:function(){return this._data}},version:{get:function(){return this._version}},majorVersion:{get:function(){return this._majorVersion}},minorVersion:{get:function(){return this._minorVersion}},legacyVersion16:{get:function(){if(c(this.version))return this.majorVersion<1||this.majorVersion===1&&this.minorVersion<=6}}});ah.prototype.load=async function(t){if(this._data.spatialReference.wkid!==4326)throw new Tt(`Unsupported spatial reference: ${this._data.spatialReference.wkid}`);if(this._dataProvider.applySymbology&&(this._symbology=new q5(this)),await this._dataProvider.loadGeoidData(),await this._loadRootNode(t),await this._create3DTileset(t),this._rootNode._tile=this._tileset._root,this._tileset._root._i3sNode=this._rootNode,this.legacyVersion16)return this._rootNode._loadChildren()};ah.prototype._computeGeometryDefinitions=function(t){if(this._geometryDefinitions=[],c(this._data.geometryDefinitions))for(let e=0;e<this._data.geometryDefinitions.length;e++){let n=[],i=this._data.geometryDefinitions[e].geometryBuffers;for(let o=0;o<i.length;o++){let a=i[o],s=[],l=!1;if(c(a.compressedAttributes)&&t){l=!0;let r=a.compressedAttributes.attributes;for(let d=0;d<r.length;d++)s.push(r[d])}else for(let r in a)r!=="offset"&&s.push(r);n.push({compressed:l,attributes:s,index:i.indexOf(a)})}n.sort(function(o,a){return o.compressed&&!a.compressed?-1:!o.compressed&&a.compressed?1:o.attributes.length-a.attributes.length}),this._geometryDefinitions.push(n)}};ah.prototype._findBestGeometryBuffers=function(t,e){let n=this._geometryDefinitions[t];if(c(n))for(let i=0;i<n.length;++i){let o=n[i],a=!1,s=o.attributes;for(let l=0;l<e.length;l++)if(!s.includes(e[l])){a=!0;break}if(!a)return{bufferIndex:o.index,definition:n,geometryBufferInfo:o}}return 0};ah.prototype._loadRootNode=function(t){if(c(this._data.nodePages)){let e=0;c(this._data.nodePages.rootIndex)&&(e=this._data.nodePages.rootIndex),this._rootNode=new pN(this,e,!0)}else this._rootNode=new pN(this,this._data.store.rootNode,!0);return this._rootNode.load(t)};ah.prototype._getNodeInNodePages=function(t){let e=Math.floor(t/this._data.nodePages.nodesPerPage),n=t%this._data.nodePages.nodesPerPage;return this._loadNodePage(e).then(function(i){return i.nodes[n]})};ah._fetchJson=function(t){return t.fetchJson()};ah.prototype._loadNodePage=function(t){let e=this;if(!c(this._nodePageFetches[t])){let n=this.resource.getDerivedResource({url:`nodepages/${t}/`}),i=ah._fetchJson(n).then(function(o){return c(o.error)&&o.error.code!==200?Promise.reject(o.error):(e._nodePages[t]=o.nodes,o)});this._nodePageFetches[t]=i}return this._nodePageFetches[t]};ah.prototype._computeExtent=function(){c(this._data.fullExtent)?this._extent=Gt.fromDegrees(this._data.fullExtent.xmin,this._data.fullExtent.ymin,this._data.fullExtent.xmax,this._data.fullExtent.ymax):c(this._data.store.extent)&&(this._extent=Gt.fromDegrees(this._data.store.extent[0],this._data.store.extent[1],this._data.store.extent[2],this._data.store.extent[3]))};ah.prototype._create3DTileset=async function(t){let e={asset:{version:"1.0"},geometricError:Number.MAX_VALUE,root:this._rootNode._create3DTileDefinition()},n=new Blob([JSON.stringify(e)],{type:"application/json"}),i=URL.createObjectURL(n),o=this._symbology?.defaultSymbology?.edges?.color;c(o)&&!c(t?.outlineColor)&&(t=c(t)?Re(t):{},t.outlineColor=v.fromCartesian4(bt.fromArray(o))),this._tileset=await Pr.fromUrl(i,t),this._tileset.show=this._parent.show,this._tileset._isI3STileSet=!0,this._tileset.tileUnload.addEventListener(function(a){a._i3sNode._clearGeometryData(),URL.revokeObjectURL(a._contentResource._url),a._contentResource=a._i3sNode.resource}),this._tileset.tileVisible.addEventListener(function(a){c(a._i3sNode)&&a._i3sNode._loadChildren()})};ah.prototype._updateVisibility=function(){c(this._tileset)&&(this._tileset.show=this._parent.show)};ah.prototype.filterByAttributes=function(t){this._filters=c(t)?Re(t,!0):[];let e=this._rootNode;return c(e)?e._filterFeatures():Promise.resolve()};var ig=ah;var Bjo=b(W(),1);function $j(t,e){this._dataProvider=t,this._resource=new te({url:e}),this._resource.setQueryParameters(t.resource.queryParameters),this._resource.appendForwardSlash()}Object.defineProperties($j.prototype,{resource:{get:function(){return this._resource}},data:{get:function(){return this._data}},names:{get:function(){let t=[],e=this._data.summary;if(c(e))for(let n=0;n<e.length;++n)t.push(e[n].fieldName);return t}}});$j.prototype.load=async function(){return this._data=await bZ.loadJson(this._resource),this._data};$j.prototype._getValues=function(t){let e=this._data.summary;if(c(e))for(let n=0;n<e.length;++n){let i=e[n];if(i.fieldName===t)return c(i.mostFrequentValues)?[...i.mostFrequentValues]:[]}};var $5=$j;var Ljo=b(W(),1);function tD(t,e,n){this._dataProvider=t,this._parent=e,this._data=n,this._name=n.name,this._modelName=n.modelName,this._visibility=f(n.visibility,!0),this._resource=void 0,this._sublayers=[],this._i3sLayers=[]}Object.defineProperties(tD.prototype,{resource:{get:function(){return this._resource}},data:{get:function(){return this._data}},name:{get:function(){return this._name}},modelName:{get:function(){return this._modelName}},sublayers:{get:function(){return this._sublayers}},visibility:{get:function(){return this._visibility},set:function(t){if(this._visibility!==t){this._visibility=t;for(let e=0;e<this._i3sLayers.length;e++)this._i3sLayers[e]._updateVisibility()}}},show:{get:function(){return this._visibility&&this._parent.show}}});tD._fromData=async function(t,e,n,i){let o=new tD(t,i,n);if(o._data.layerType==="group"){let a=o._data.sublayers;if(c(a)){let s=[];for(let r=0;r<a.length;r++){let d=tD._fromData(t,e,a[r],o);s.push(d)}let l=await Promise.all(s);for(let r=0;r<l.length;r++){let d=l[r];o._sublayers.push(d),o._i3sLayers.push(...d._i3sLayers)}}}else if(o._data.layerType==="3DObject"){let a=e.concat(`/sublayers/${o._data.id}`),s=new te({url:a});s.setQueryParameters(t.resource.queryParameters),s.appendForwardSlash(),o._resource=s;let l=await bZ.loadJson(o._resource),r=new ig(t,l,o);o._i3sLayers.push(r)}else console.log(`${o._data.layerType} layer ${o._data.name} is skipped as not supported.`);return o};var eD=tD;var Lkt=b(Xkt(),1);function Hl(t){t=f(t,f.EMPTY_OBJECT),this._name=t.name,this._show=f(t.show,!0),this._geoidTiledTerrainProvider=t.geoidTiledTerrainProvider,this._showFeatures=f(t.showFeatures,!1),this._adjustMaterialAlphaMode=f(t.adjustMaterialAlphaMode,!1),this._applySymbology=f(t.applySymbology,!1),this._calculateNormals=f(t.calculateNormals,!1),this._cesium3dTilesetOptions=f(t.cesium3dTilesetOptions,f.EMPTY_OBJECT),this._layers=[],this._sublayers=[],this._data=void 0,this._extent=void 0,this._geoidDataPromise=void 0,this._geoidDataList=void 0,this._decoderTaskProcessor=void 0,this._taskProcessorReadyPromise=void 0,this._attributeStatistics=[],this._layersExtent=[]}Object.defineProperties(Hl.prototype,{name:{get:function(){return this._name}},show:{get:function(){return this._show},set:function(t){if(this._show!==t){this._show=t;for(let e=0;e<this._layers.length;e++)this._layers[e]._updateVisibility()}}},geoidTiledTerrainProvider:{get:function(){return this._geoidTiledTerrainProvider}},layers:{get:function(){return this._layers}},sublayers:{get:function(){return this._sublayers}},data:{get:function(){return this._data}},extent:{get:function(){return this._extent}},resource:{get:function(){return this._resource}},showFeatures:{get:function(){return this._showFeatures}},adjustMaterialAlphaMode:{get:function(){return this._adjustMaterialAlphaMode}},applySymbology:{get:function(){return this._applySymbology}},calculateNormals:{get:function(){return this._calculateNormals}}});Hl.prototype.destroy=function(){for(let t=0;t<this._layers.length;t++)c(this._layers[t]._tileset)&&this._layers[t]._tileset.destroy();return At(this)};Hl.prototype.isDestroyed=function(){return!1};Hl.prototype.update=function(t){for(let e=0;e<this._layers.length;e++)c(this._layers[e]._tileset)&&this._layers[e]._tileset.update(t)};Hl.prototype.prePassesUpdate=function(t){for(let e=0;e<this._layers.length;e++)c(this._layers[e]._tileset)&&this._layers[e]._tileset.prePassesUpdate(t)};Hl.prototype.postPassesUpdate=function(t){for(let e=0;e<this._layers.length;e++)c(this._layers[e]._tileset)&&this._layers[e]._tileset.postPassesUpdate(t)};Hl.prototype.updateForPass=function(t,e){for(let n=0;n<this._layers.length;n++)c(this._layers[n]._tileset)&&this._layers[n]._tileset.updateForPass(t,e)};function B_e(t,e){let n=t.resource.getUrlComponent(),i="";return n.match(/layers\/\d/)?i=`${n}`.replace(/\/+$/,""):i=`${n}`.replace(/\/?$/,"/").concat(`layers/${e}`),i}async function Jkt(t,e,n){if(e.layerType==="Building"){c(n.showFeatures)||(t._showFeatures=!0),c(n.adjustMaterialAlphaMode)||(t._adjustMaterialAlphaMode=!0),c(n.applySymbology)||(t._applySymbology=!0),c(n.calculateNormals)||(t._calculateNormals=!0);let i=B_e(t,e.id);if(c(e.sublayers)){let o=[];for(let s=0;s<e.sublayers.length;s++){let l=eD._fromData(t,i,e.sublayers[s],t);o.push(l)}let a=await Promise.all(o);for(let s=0;s<a.length;s++){let l=a[s];t._sublayers.push(l),t._layers.push(...l._i3sLayers)}}if(c(e.statisticsHRef)){let o=i.concat(`/${e.statisticsHRef}`),a=new $5(t,o);await a.load(),t._attributeStatistics.push(a)}if(c(e.fullExtent)){let o=Gt.fromDegrees(e.fullExtent.xmin,e.fullExtent.ymin,e.fullExtent.xmax,e.fullExtent.ymax);t._layersExtent.push(o)}}else if(e.layerType==="3DObject"||e.layerType==="IntegratedMesh"){!c(n.calculateNormals)&&!c(e.textureSetDefinitions)&&(t._calculateNormals=!0);let i=new ig(t,e,t);t._layers.push(i),c(i._extent)&&t._layersExtent.push(i._extent)}else console.log(`${e.layerType} layer ${e.name} is skipped as not supported.`)}Hl.fromUrl=async function(t,e){e=f(e,f.EMPTY_OBJECT);let n=te.createIfNeeded(t);n.setQueryParameters({f:"pjson"},!0);let i=await Hl.loadJson(n),o=new Hl(e);if(o._resource=n,o._data=i,c(i.layers)){let s=[];for(let l=0;l<i.layers.length;l++){let r=Jkt(o,i.layers[l],e);s.push(r)}await Promise.all(s)}else await Jkt(o,i,e);o._computeExtent();let a=[];for(let s=0;s<o._layers.length;s++)a.push(o._layers[s].load(e.cesium3dTilesetOptions));return await Promise.all(a),o};Hl._fetchJson=function(t){return t.fetchJson()};Hl.loadJson=async function(t){let e=await Hl._fetchJson(t);if(c(e.error)){if(console.error("Failed to fetch I3S ",t.url),c(e.error.message)&&console.error(e.error.message),c(e.error.details))for(let n=0;n<e.error.details.length;n++)console.log(e.error.details[n]);throw new Tt(e.error)}return e};Hl.prototype._loadBinary=async function(t){let e=await t.fetchArrayBuffer();if(e.byteLength>0&&new Uint8Array(e)[0]===123&&new TextDecoder().decode(e).includes("404"))throw new Tt(`Failed to load binary: ${t.url}`);return e};Hl.prototype._binarizeGltf=function(t){let n=new TextEncoder().encode(JSON.stringify(t)),i=new Uint8Array(n.byteLength+20),o={magic:new Uint8Array(i.buffer,0,4),version:new Uint32Array(i.buffer,4,1),length:new Uint32Array(i.buffer,8,1),chunkLength:new Uint32Array(i.buffer,12,1),chunkType:new Uint32Array(i.buffer,16,1),chunkData:new Uint8Array(i.buffer,20,n.byteLength)};return o.magic[0]=103,o.magic[1]=108,o.magic[2]=84,o.magic[3]=70,o.version[0]=2,o.length[0]=i.byteLength,o.chunkLength[0]=n.byteLength,o.chunkType[0]=1313821514,o.chunkData.set(n),i};var Q_e=new K;function k_e(t,e){let n=t.tilingScheme,i=[],o={},a=t._lodCount,s=gt.fromRadians(e.west,e.north),l=gt.fromRadians(e.east,e.south),r=n.positionToTileXY(s,a),d=n.positionToTileXY(l,a);for(let h=r.x;h<=d.x;h++)for(let u=r.y;u<=d.y;u++){let R=K.fromElements(h,u,Q_e),V=R.toString();if(!o.hasOwnProperty(V)){let F={x:R.x,y:R.y,level:a,tilingScheme:n,terrainProvider:t,positions:[]};o[V]=F,i.push(F)}}let m=[];for(let h=0;h<i.length;++h){let u=i[h],R=u.terrainProvider.requestTileGeometry(u.x,u.y,u.level);m.push(R)}return Promise.all(m).then(function(h){let u=[];for(let R=0;R<h.length;R++){let V={tilingScheme:n,x:i[R].x,y:i[R].y,level:i[R].level},F=h[R],U="Geographic";n._projection instanceof Yo&&(U="WebMercator");let G={projectionType:U,projection:n._projection,nativeExtent:n.tileXYToNativeRectangle(V.x,V.y,V.level),height:F._height,width:F._width,scale:F._structure.heightScale,offset:F._structure.heightOffset};if(F._encoding===UV.LERC){let A=Lkt.default.decode(F._buffer);G.buffer=A.pixels[0]}else G.buffer=F._buffer;u.push(G)}return u})}async function Y_e(t){let e=t._geoidTiledTerrainProvider;if(c(e))try{let n=await k_e(e,t._extent);t._geoidDataList=n}catch{console.log("Error retrieving Geoid Terrain tiles - no geoid conversion will be performed.")}}Hl.prototype.loadGeoidData=async function(){return c(this._geoidDataPromise)?this._geoidDataPromise:(this._geoidDataPromise=Y_e(this),this._geoidDataPromise)};Hl.prototype._computeExtent=function(){let t;for(let e=0;e<this._layersExtent.length;e++){let n=this._layersExtent[e];c(t)?Gt.union(t,n,t):t=Gt.clone(n)}this._extent=t};Hl.prototype.getAttributeNames=function(){let t=[];for(let e=0;e<this._attributeStatistics.length;++e)t.push(...this._attributeStatistics[e].names);return t};Hl.prototype.getAttributeValues=function(t){for(let e=0;e<this._attributeStatistics.length;++e){let n=this._attributeStatistics[e]._getValues(t);if(c(n))return n}return[]};Hl.prototype.filterByAttributes=function(t){let e=[];for(let n=0;n<this._layers.length;n++){let i=this._layers[n].filterByAttributes(t);e.push(i)}return Promise.all(e)};var bZ=Hl;var s4o=b(W(),1);function Mkt(){}Object.defineProperties(Mkt.prototype,{color:{get:Ut.throwInstantiationError},intensity:{get:Ut.throwInstantiationError}});var Dlt=Mkt;var V4o=b(W(),1);function x_e(){return window.devicePixelRatio||1}function X_e(t,e,n){n||(n=x_e());let i=document.createElement("canvas");return i.width=t*n,i.height=e*n,i.style.width=`${t}px`,i.style.height=`${e}px`,i.getContext("2d").scale(n,n),i}function J_e({entity:t,text:e,fontSize:n="14",fontFamily:i="Helvetica",fontStyle:o="",fillStyle:a="white",bgColor:s="#111",lineWidth:l=2,cornerRadius:r=3,horizontalOrigin:d=to.LEFT,verticalOrigin:m=hi.CENTER,scaleByDistance:h=new ln(150,1,8e6,.35),pixelOffset:u=new K(20,0)}){if(!t._labelCanvas||t._labelCanvasText!==e){let R=`${o} ${n}px ${i}`,V=document.createElement("div");V.style.position="absolute",V.style.font=R,V.innerHTML=e,document.body.appendChild(V);let{height:F,width:U}=V.getBoundingClientRect(),G=X_e(U*1.1,F*1.5,devicePixelRatio);G.width=U*1.1,G.height=F*1.5,document.body.removeChild(V);let A=G.getContext("2d");A.font=R,A.beginPath(),A.moveTo(r,0),A.lineTo(G.width-r,0),A.arcTo(G.width,0,G.width,r,r),A.lineTo(G.width,G.height-r),A.arcTo(G.width,G.height,G.width-r,G.height,r),A.lineTo(r,G.height),A.arcTo(0,G.height,0,G.height-r,r),A.lineTo(0,r),A.arcTo(0,0,r,0,r),A.closePath(),A.fillStyle=s,A.fill(),A.textAlign="center",A.textBaseline="middle",A.fillStyle=a,A.lineWidth=l;let S=G.width/2,g=G.height/2;A.fillText(e,S,g),t._labelCanvas=G,t._labelCanvasText=e}t.billboard=new Mr({image:new Ii(t._labelCanvas),horizontalOrigin:d,verticalOrigin:m,scaleByDistance:h,width:t._labelCanvas.width,height:t._labelCanvas.height,pixelOffset:u})}var Olt=J_e;var F4o=b(W(),1);var L_e=/\/$/,_kt=new on('© <a href="https://www.mapbox.com/about/maps/">Mapbox</a> © <a href="http://www.openstreetmap.org/copyright">OpenStreetMap</a> <strong><a href="https://www.mapbox.com/map-feedback/">Improve this map</a></strong>');function uN(t){t=f(t,f.EMPTY_OBJECT);let e=t.styleId,n=t.accessToken;this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0;let i=te.createIfNeeded(f(t.url,"https://api.mapbox.com/styles/v1/"));this._styleId=e,this._accessToken=n;let o=f(t.tilesize,512);this._tilesize=o;let a=f(t.username,"mapbox");this._username=a;let s=c(t.scaleFactor)?"@2x":"",l=i.getUrlComponent();L_e.test(l)||(l+="/"),l+=`${this._username}/${e}/tiles/${this._tilesize}/{z}/{x}/{y}${s}`,i.url=l,i.setQueryParameters({access_token:n});let r;c(t.credit)?(r=t.credit,typeof r=="string"&&(r=new on(r))):r=_kt,this._resource=i,this._imageryProvider=new Ad({url:i,credit:r,ellipsoid:t.ellipsoid,minimumLevel:t.minimumLevel,maximumLevel:t.maximumLevel,rectangle:t.rectangle})}Object.defineProperties(uN.prototype,{url:{get:function(){return this._imageryProvider.url}},rectangle:{get:function(){return this._imageryProvider.rectangle}},tileWidth:{get:function(){return this._imageryProvider.tileWidth}},tileHeight:{get:function(){return this._imageryProvider.tileHeight}},maximumLevel:{get:function(){return this._imageryProvider.maximumLevel}},minimumLevel:{get:function(){return this._imageryProvider.minimumLevel}},tilingScheme:{get:function(){return this._imageryProvider.tilingScheme}},tileDiscardPolicy:{get:function(){return this._imageryProvider.tileDiscardPolicy}},errorEvent:{get:function(){return this._imageryProvider.errorEvent}},credit:{get:function(){return this._imageryProvider.credit}},proxy:{get:function(){return this._imageryProvider.proxy}},hasAlphaChannel:{get:function(){return this._imageryProvider.hasAlphaChannel}}});uN.prototype.getTileCredits=function(t,e,n){};uN.prototype.requestImage=function(t,e,n,i){return this._imageryProvider.requestImage(t,e,n,i)};uN.prototype.pickFeatures=function(t,e,n,i,o){return this._imageryProvider.pickFeatures(t,e,n,i,o)};uN._defaultCredit=_kt;var Hlt=uN;var G4o=b(W(),1);function wlt(t){}wlt.prototype.isReady=function(){return!0};wlt.prototype.shouldDiscardImage=function(t){return!1};var Plt=wlt;var y4o=b(W(),1);var M_e=new on("MapQuest, Open Street Map and contributors, CC-BY-SA");function e4(t){t=f(t,f.EMPTY_OBJECT);let e=te.createIfNeeded(f(t.url,"https://tile.openstreetmap.org/"));e.appendForwardSlash(),e.url+=`{z}/{x}/{y}${t.retinaTiles?"@2x":""}.${f(t.fileExtension,"png")}`;let n=new Gs({ellipsoid:t.ellipsoid}),i=256,o=256,a=f(t.minimumLevel,0),s=t.maximumLevel,l=f(t.rectangle,n.rectangle),r=n.positionToTileXY(Gt.southwest(l),a),d=n.positionToTileXY(Gt.northeast(l),a),m=(Math.abs(d.x-r.x)+1)*(Math.abs(d.y-r.y)+1),h=f(t.credit,M_e);typeof h=="string"&&(h=new on(h)),Ad.call(this,{url:e,credit:h,tilingScheme:n,tileWidth:i,tileHeight:o,minimumLevel:a,maximumLevel:s,rectangle:l})}c(Object.create)&&(e4.prototype=Object.create(Ad.prototype),e4.prototype.constructor=e4);var IW=e4;var J4o=b(W(),1);var __e=new K(1,1);function vlt(t){t=f(t,f.EMPTY_OBJECT),this.mass=f(t.mass,1),this.position=p.clone(f(t.position,p.ZERO)),this.velocity=p.clone(f(t.velocity,p.ZERO)),this.life=f(t.life,Number.MAX_VALUE),this.image=t.image,this.startColor=v.clone(f(t.startColor,v.WHITE)),this.endColor=v.clone(f(t.endColor,v.WHITE)),this.startScale=f(t.startScale,1),this.endScale=f(t.endScale,1),this.imageSize=K.clone(f(t.imageSize,__e)),this._age=0,this._normalizedAge=0,this._billboard=void 0}Object.defineProperties(vlt.prototype,{age:{get:function(){return this._age}},normalizedAge:{get:function(){return this._normalizedAge}}});var Dkt=new p;vlt.prototype.update=function(t,e){return p.multiplyByScalar(this.velocity,t,Dkt),p.add(this.position,Dkt,this.position),c(e)&&e(this,t),this._age+=t,this.life===Number.MAX_VALUE?this._normalizedAge=0:this._normalizedAge=this._age/this.life,this._age<=this.life};var ZN=vlt;var _4o=b(W(),1);function Okt(t){t=f(t,f.EMPTY_OBJECT),this.time=f(t.time,0),this.minimum=f(t.minimum,0),this.maximum=f(t.maximum,50),this._complete=!1}Object.defineProperties(Okt.prototype,{complete:{get:function(){return this._complete}}});var Klt=Okt;var H4o=b(W(),1);function Hkt(t){}Hkt.prototype.emit=function(t){Ut.throwInstantiationError()};var zlt=Hkt;var s8o=b(W(),1);var wkt=new K(1,1);function nD(t){t=f(t,f.EMPTY_OBJECT),this.show=f(t.show,!0),this.updateCallback=t.updateCallback,this.loop=f(t.loop,!0),this.image=f(t.image,void 0);let e=t.emitter;c(e)||(e=new M5(.5)),this._emitter=e,this._bursts=t.bursts,this._modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this._emitterModelMatrix=L.clone(f(t.emitterModelMatrix,L.IDENTITY)),this._matrixDirty=!0,this._combinedMatrix=new L,this._startColor=v.clone(f(t.color,f(t.startColor,v.WHITE))),this._endColor=v.clone(f(t.color,f(t.endColor,v.WHITE))),this._startScale=f(t.scale,f(t.startScale,1)),this._endScale=f(t.scale,f(t.endScale,1)),this._emissionRate=f(t.emissionRate,5),this._minimumSpeed=f(t.speed,f(t.minimumSpeed,1)),this._maximumSpeed=f(t.speed,f(t.maximumSpeed,1)),this._minimumParticleLife=f(t.particleLife,f(t.minimumParticleLife,5)),this._maximumParticleLife=f(t.particleLife,f(t.maximumParticleLife,5)),this._minimumMass=f(t.mass,f(t.minimumMass,1)),this._maximumMass=f(t.mass,f(t.maximumMass,1)),this._minimumImageSize=K.clone(f(t.imageSize,f(t.minimumImageSize,wkt))),this._maximumImageSize=K.clone(f(t.imageSize,f(t.maximumImageSize,wkt))),this._sizeInMeters=f(t.sizeInMeters,!1),this._lifetime=f(t.lifetime,Number.MAX_VALUE),this._billboardCollection=void 0,this._particles=[],this._particlePool=[],this._previousTime=void 0,this._currentTime=0,this._carryOver=0,this._complete=new It,this._isComplete=!1,this._updateParticlePool=!0,this._particleEstimate=0}Object.defineProperties(nD.prototype,{emitter:{get:function(){return this._emitter},set:function(t){this._emitter=t}},bursts:{get:function(){return this._bursts},set:function(t){this._bursts=t,this._updateParticlePool=!0}},modelMatrix:{get:function(){return this._modelMatrix},set:function(t){this._matrixDirty=this._matrixDirty||!L.equals(this._modelMatrix,t),L.clone(t,this._modelMatrix)}},emitterModelMatrix:{get:function(){return this._emitterModelMatrix},set:function(t){this._matrixDirty=this._matrixDirty||!L.equals(this._emitterModelMatrix,t),L.clone(t,this._emitterModelMatrix)}},startColor:{get:function(){return this._startColor},set:function(t){v.clone(t,this._startColor)}},endColor:{get:function(){return this._endColor},set:function(t){v.clone(t,this._endColor)}},startScale:{get:function(){return this._startScale},set:function(t){this._startScale=t}},endScale:{get:function(){return this._endScale},set:function(t){this._endScale=t}},emissionRate:{get:function(){return this._emissionRate},set:function(t){this._emissionRate=t,this._updateParticlePool=!0}},minimumSpeed:{get:function(){return this._minimumSpeed},set:function(t){this._minimumSpeed=t}},maximumSpeed:{get:function(){return this._maximumSpeed},set:function(t){this._maximumSpeed=t}},minimumParticleLife:{get:function(){return this._minimumParticleLife},set:function(t){this._minimumParticleLife=t}},maximumParticleLife:{get:function(){return this._maximumParticleLife},set:function(t){this._maximumParticleLife=t,this._updateParticlePool=!0}},minimumMass:{get:function(){return this._minimumMass},set:function(t){this._minimumMass=t}},maximumMass:{get:function(){return this._maximumMass},set:function(t){this._maximumMass=t}},minimumImageSize:{get:function(){return this._minimumImageSize},set:function(t){this._minimumImageSize=t}},maximumImageSize:{get:function(){return this._maximumImageSize},set:function(t){this._maximumImageSize=t}},sizeInMeters:{get:function(){return this._sizeInMeters},set:function(t){this._sizeInMeters=t}},lifetime:{get:function(){return this._lifetime},set:function(t){this._lifetime=t}},complete:{get:function(){return this._complete}},isComplete:{get:function(){return this._isComplete}}});function D_e(t){let e=t._emissionRate,n=t._maximumParticleLife,i=0,o=t._bursts;if(c(o)){let h=o.length;for(let u=0;u<h;++u)i+=o[u].maximum}let a=t._billboardCollection,s=t.image,l=Math.ceil(e*n+i),r=t._particles,d=t._particlePool,m=Math.max(l-r.length-d.length,0);for(let h=0;h<m;++h){let u=new ZN;u._billboard=a.add({image:s,show:!1}),d.push(u)}t._particleEstimate=l}function O_e(t){let e=t._particlePool.pop();return c(e)||(e=new ZN),e}function H_e(t,e){t._particlePool.push(e)}function w_e(t){let e=t._particles,n=t._particlePool,i=t._billboardCollection,o=e.length,a=n.length,s=t._particleEstimate,l=a-Math.max(s-o-a,0);for(let r=l;r<a;++r){let d=n[r];i.remove(d._billboard)}n.length=l}function P_e(t){c(t._billboard)&&(t._billboard.show=!1)}function Pkt(t,e){let n=e._billboard;c(n)||(n=e._billboard=t._billboardCollection.add({image:e.image})),n.width=e.imageSize.x,n.height=e.imageSize.y,n.position=e.position,n.sizeInMeters=t.sizeInMeters,n.show=!0;let i=k.lerp(e.startColor.red,e.endColor.red,e.normalizedAge),o=k.lerp(e.startColor.green,e.endColor.green,e.normalizedAge),a=k.lerp(e.startColor.blue,e.endColor.blue,e.normalizedAge),s=k.lerp(e.startColor.alpha,e.endColor.alpha,e.normalizedAge);n.color=new v(i,o,a,s),n.scale=k.lerp(e.startScale,e.endScale,e.normalizedAge)}function v_e(t,e){e.startColor=v.clone(t._startColor,e.startColor),e.endColor=v.clone(t._endColor,e.endColor),e.startScale=t._startScale,e.endScale=t._endScale,e.image=t.image,e.life=k.randomBetween(t._minimumParticleLife,t._maximumParticleLife),e.mass=k.randomBetween(t._minimumMass,t._maximumMass),e.imageSize.x=k.randomBetween(t._minimumImageSize.x,t._maximumImageSize.x),e.imageSize.y=k.randomBetween(t._minimumImageSize.y,t._maximumImageSize.y),e._normalizedAge=0,e._age=0;let n=k.randomBetween(t._minimumSpeed,t._maximumSpeed);p.multiplyByScalar(e.velocity,n,e.velocity),t._particles.push(e)}function K_e(t,e){if(t._isComplete)return 0;e=k.mod(e,t._lifetime);let n=e*t._emissionRate,i=Math.floor(n);if(t._carryOver+=n-i,t._carryOver>1&&(i++,t._carryOver-=1),c(t.bursts)){let o=t.bursts.length;for(let a=0;a<o;a++){let s=t.bursts[a],l=t._currentTime;c(s)&&!s._complete&&l>s.time&&(i+=k.randomBetween(s.minimum,s.maximum),s._complete=!0)}}return i}var n4=new p;nD.prototype.update=function(t){if(!this.show)return;c(this._billboardCollection)||(this._billboardCollection=new yh),this._updateParticlePool&&(D_e(this),this._updateParticlePool=!1);let e=0;this._previousTime&&(e=rt.secondsDifference(t.time,this._previousTime)),e<0&&(e=0);let n=this._particles,i=this._emitter,o=this.updateCallback,a,s,l=n.length;for(a=0;a<l;++a)s=n[a],s.update(e,o)?Pkt(this,s):(P_e(s),H_e(this,s),n[a]=n[l-1],--a,--l);n.length=l;let r=K_e(this,e);if(r>0&&c(i)){this._matrixDirty&&(this._combinedMatrix=L.multiply(this.modelMatrix,this.emitterModelMatrix,this._combinedMatrix),this._matrixDirty=!1);let d=this._combinedMatrix;for(a=0;a<r;a++)s=O_e(this),this._emitter.emit(s),p.add(s.position,s.velocity,n4),L.multiplyByPoint(d,n4,n4),s.position=L.multiplyByPoint(d,s.position,s.position),p.subtract(n4,s.position,s.velocity),p.normalize(s.velocity,s.velocity),v_e(this,s),Pkt(this,s)}if(this._billboardCollection.update(t),this._previousTime=rt.clone(t.time,this._previousTime),this._currentTime+=e,this._lifetime!==Number.MAX_VALUE&&this._currentTime>this._lifetime)if(this.loop){if(this._currentTime=k.mod(this._currentTime,this._lifetime),this.bursts){let d=this.bursts.length;for(a=0;a<d;a++)this.bursts[a]._complete=!1}}else this._isComplete=!0,this._complete.raiseEvent(this);t.frameNumber%120===0&&w_e(this)};nD.prototype.isDestroyed=function(){return!1};nD.prototype.destroy=function(){return this._billboardCollection=this._billboardCollection&&this._billboardCollection.destroy(),At(this)};var jlt=nD;var m8o=b(W(),1);var RN={},NW;async function z_e(t,e,n,i=!0){let a=`${e||"https://api.planet.com/basemaps/v1/mosaics/wmts"}?api_key=${n}`,l=await(await fetch(a)).text(),d=new DOMParser().parseFromString(l,"application/xml").getElementsByTagName("ResourceURL");NW=i?"monthly":"quarterly",RN[NW]=[],Array.from(d).forEach(R=>{let V=R.getAttribute("template");if(V.includes(NW)){let F=`.*/(.*?${NW}.*?)/.*`,U=new RegExp(F),G=V.match(U)[1];RN[NW].push(G)}}),RN[NW].sort();let m=q_e(RN[NW],i),h=ys.fromIso8601DateArray({iso8601Dates:m,leadingInterval:!0,trailingInterval:!0,isStopIncluded:!1,dataCallback:j_e}),u=new hT({url:`https://tiles{s}.planet.com/basemaps/v1/planet-tiles/{Name}/gmap/{TileMatrix}/{TileCol}/{TileRow}.png?api_key=${n}`,layer:"planet",style:"default",tileMatrixSetID:"GoogleMapsCompatible15",tileWidth:256,tileHeight:256,minimumLevel:0,maximumLevel:15,tilingScheme:new Gs({numberOfLevelZeroTilesX:1,numberOfLevelZeroTilesY:1}),format:"image/png",subdomains:"0123",clock:t.clock,times:h,credit:"PLANET"});t.imageryLayers.addImageryProvider(u)}function j_e(t,e){let n;return e<=1?n=RN[NW][0]:n=RN[NW][e-1],{Name:n}}function q_e(t,e){let n=[];return t.forEach(i=>{if(e){let o=i.split("_"),a=`${o[2]}-${o[3]}-01T00:00:00Z`;n.push(a)}else{let o={q1:"-01-01",q2:"-04-01",q3:"-07-01",q4:"-10-01"},a=i.split("_")[2],s=a.slice(0,4),l=a.slice(4,6),r=`${s}${o[l]}T00:00:00Z`;n.push(r)}}),n}var qlt=z_e;var $8o=b(W(),1);var zkt=b(KO(),1);var p8o=b(W(),1);function $_e(t,e,n){return` float clipDistance = clip(gl_FragCoord, ${t}, ${e}); vec4 clippingPlanesEdgeColor = vec4(1.0); clippingPlanesEdgeColor.rgb = ${n}.rgb; float clippingPlanesEdgeWidth = ${n}.a; @@ -15388,7 +15388,7 @@ void main() { out_FragColor = clippingPlanesEdgeColor; } -`}var iD=$_e;var V8o=R(W(),1);var t9e={modifyFragmentShader:function(e){return e=Ve.replaceMain(e,"czm_splitter_main"),e+=`uniform float czm_splitDirection; +`}var iD=$_e;var Z8o=b(W(),1);var t9e={modifyFragmentShader:function(e){return e=Ze.replaceMain(e,"czm_splitter_main"),e+=`uniform float czm_splitDirection; void main() { #ifndef SHADOW_MAP @@ -15397,8 +15397,8 @@ void main() #endif czm_splitter_main(); } -`,e},addUniforms:function(e,n){n.czm_splitDirection=function(){return e.splitDirection}}},RN=t9e;var og={NEEDS_DECODE:0,DECODING:1,READY:2,FAILED:3};function oD(t){this._parsedContent=void 0,this._drawCommand=void 0,this._isTranslucent=!1,this._styleTranslucent=!1,this._constantColor=v.clone(v.DARKGRAY),this._highlightColor=v.clone(v.WHITE),this._pointSize=1,this._rtcCenter=void 0,this._quantizedVolumeScale=void 0,this._quantizedVolumeOffset=void 0,this._styleableShaderAttributes=void 0,this._isQuantized=!1,this._isOctEncoded16P=!1,this._isRGB565=!1,this._hasColors=!1,this._hasNormals=!1,this._hasBatchIds=!1,this._decodingState=og.READY,this._dequantizeInShader=!0,this._isQuantizedDraco=!1,this._isOctEncodedDraco=!1,this._quantizedRange=0,this._octEncodedRange=0,this.backFaceCulling=!1,this._backFaceCulling=!1,this.normalShading=!0,this._normalShading=!0,this._opaqueRenderState=void 0,this._translucentRenderState=void 0,this._mode=void 0,this._ready=!1,this._pointsLength=0,this._geometryByteLength=0,this._vertexShaderLoaded=t.vertexShaderLoaded,this._fragmentShaderLoaded=t.fragmentShaderLoaded,this._uniformMapLoaded=t.uniformMapLoaded,this._batchTableLoaded=t.batchTableLoaded,this._pickIdLoaded=t.pickIdLoaded,this._opaquePass=f(t.opaquePass,Pt.OPAQUE),this._cull=f(t.cull,!0),this.style=void 0,this._style=void 0,this.styleDirty=!1,this.modelMatrix=L.clone(L.IDENTITY),this._modelMatrix=L.clone(L.IDENTITY),this.time=0,this.shadows=ui.ENABLED,this._boundingSphere=void 0,this.clippingPlanes=void 0,this.isClipped=!1,this.clippingPlanesDirty=!1,this.clippingPlanesOriginMatrix=void 0,this.attenuation=!1,this._attenuation=!1,this.geometricError=0,this.geometricErrorScale=1,this.maximumAttenuation=this._pointSize,this.splitDirection=f(t.splitDirection,Jc.NONE),this._splittingEnabled=!1,this._error=void 0,e9e(this,t)}Object.defineProperties(oD.prototype,{pointsLength:{get:function(){return this._pointsLength}},geometryByteLength:{get:function(){return this._geometryByteLength}},ready:{get:function(){return this._ready}},color:{get:function(){return v.clone(this._highlightColor)},set:function(t){this._highlightColor=v.clone(t,this._highlightColor)}},boundingSphere:{get:function(){if(c(this._drawCommand))return this._drawCommand.boundingVolume},set:function(t){this._boundingSphere=Ft.clone(t,this._boundingSphere)}}});function e9e(t,e){let n=xA.parse(e.arrayBuffer,e.byteOffset);if(t._parsedContent=n,t._rtcCenter=n.rtcCenter,t._hasNormals=n.hasNormals,t._hasColors=n.hasColors,t._hasBatchIds=n.hasBatchIds,t._isTranslucent=n.isTranslucent,!n.hasBatchIds&&c(n.batchTableBinary)&&(n.styleableProperties=wR.getBinaryProperties(n.pointsLength,n.batchTableJson,n.batchTableBinary)),c(n.draco)){let l=n.draco;t._decodingState=og.NEEDS_DECODE,l.dequantizeInShader=t._dequantizeInShader}let i=n.positions;c(i)&&(t._isQuantized=i.isQuantized,t._quantizedVolumeScale=i.quantizedVolumeScale,t._quantizedVolumeOffset=i.quantizedVolumeOffset,t._quantizedRange=i.quantizedRange);let o=n.normals;c(o)&&(t._isOctEncoded16P=o.octEncoded);let a=n.colors;c(a)&&(c(a.constantColor)&&(t._constantColor=v.clone(a.constantColor,t._constantColor),t._hasColors=!1),t._isRGB565=a.isRGB565);let s=n.batchIds;c(n.batchIds)&&(s.name="BATCH_ID",s.semantic="BATCH_ID",s.setIndex=void 0),n.hasBatchIds&&t._batchTableLoaded(n.batchLength,n.batchTableJson,n.batchTableBinary),t._pointsLength=n.pointsLength}var n9e=new p,i9e=new p,o9e=new p,v2t,i4;function a9e(t){if(!c(i4)){v2t=new z2t.default(0),i4=new Array(t);for(let e=0;e<t;++e)i4[e]=v2t.random()}return i4}function s9e(t){let n=t.length/3,i=Math.min(n,20),o=a9e(20),a=Number.MAX_VALUE,s=-Number.MAX_VALUE,l=p.fromElements(a,a,a,n9e),r=p.fromElements(s,s,s,i9e);for(let m=0;m<i;++m){let h=Math.floor(o[m]*n),Z=p.unpack(t,h*3,o9e);p.minimumByComponent(l,Z,l),p.maximumByComponent(r,Z,r)}let d=Ft.fromCornerPoints(l,r);return d.radius+=k.EPSILON2,d}function K2t(t,e){let n=it.fromTypedArray(t);return n===it.INT||n===it.UNSIGNED_INT||n===it.DOUBLE?(Gn("Cast pnts property to floats",`Point cloud property "${e}" will be cast to a float array because INT, UNSIGNED_INT, and DOUBLE are not valid WebGL vertex attribute types. Some precision may be lost.`),new Float32Array(t)):t}var l9e=new Rt,r9e=new Rt,d9e=new v,j2t=0,o4=1,irt=2,q2t=3,c9e=4,$lt=new L,m9e=new L;function h9e(t,e){let n=e.context,i=t._parsedContent,o=t._pointsLength,a=i.positions,s=i.colors,l=i.normals,r=i.batchIds,d=i.styleableProperties,m=c(d),h=t._isQuantized,Z=t._isQuantizedDraco,b=t._isOctEncoded16P,u=t._isOctEncodedDraco,F=t._quantizedRange,U=t._octEncodedRange,G=t._isRGB565,A=t._isTranslucent,T=t._hasColors,g=t._hasNormals,C=t._hasBatchIds,y,Y,Q=[],J={};if(t._styleableShaderAttributes=J,m){let w=c9e;for(let z in d)if(d.hasOwnProperty(z)){let H=d[z],nt=K2t(H.typedArray,z);y=H.componentCount,Y=it.fromTypedArray(nt);let $=we.createVertexBuffer({context:n,typedArray:nt,usage:ce.STATIC_DRAW});t._geometryByteLength+=$.sizeInBytes;let dt={index:w,vertexBuffer:$,componentsPerAttribute:y,componentDatatype:Y,normalize:!1,offsetInBytes:0,strideInBytes:0};Q.push(dt),J[z]={location:w,componentCount:y},++w}}let M=we.createVertexBuffer({context:n,typedArray:a.typedArray,usage:ce.STATIC_DRAW});t._geometryByteLength+=M.sizeInBytes;let V;T&&(V=we.createVertexBuffer({context:n,typedArray:s.typedArray,usage:ce.STATIC_DRAW}),t._geometryByteLength+=V.sizeInBytes);let E;g&&(E=we.createVertexBuffer({context:n,typedArray:l.typedArray,usage:ce.STATIC_DRAW}),t._geometryByteLength+=E.sizeInBytes);let I;C&&(r.typedArray=K2t(r.typedArray,"batchIds"),I=we.createVertexBuffer({context:n,typedArray:r.typedArray,usage:ce.STATIC_DRAW}),t._geometryByteLength+=I.sizeInBytes);let B=[];if(h?Y=it.UNSIGNED_SHORT:Z?Y=F<=255?it.UNSIGNED_BYTE:it.UNSIGNED_SHORT:Y=it.FLOAT,B.push({index:j2t,vertexBuffer:M,componentsPerAttribute:3,componentDatatype:Y,normalize:!1,offsetInBytes:0,strideInBytes:0}),t._cull&&(h||Z?t._boundingSphere=Ft.fromCornerPoints(p.ZERO,t._quantizedVolumeScale):t._boundingSphere=s9e(a.typedArray)),T)if(G)B.push({index:o4,vertexBuffer:V,componentsPerAttribute:1,componentDatatype:it.UNSIGNED_SHORT,normalize:!1,offsetInBytes:0,strideInBytes:0});else{let w=A?4:3;B.push({index:o4,vertexBuffer:V,componentsPerAttribute:w,componentDatatype:it.UNSIGNED_BYTE,normalize:!0,offsetInBytes:0,strideInBytes:0})}g&&(b?(y=2,Y=it.UNSIGNED_BYTE):u?(y=2,Y=U<=255?it.UNSIGNED_BYTE:it.UNSIGNED_SHORT):(y=3,Y=it.FLOAT),B.push({index:irt,vertexBuffer:E,componentsPerAttribute:y,componentDatatype:Y,normalize:!1,offsetInBytes:0,strideInBytes:0})),C&&B.push({index:q2t,vertexBuffer:I,componentsPerAttribute:1,componentDatatype:it.fromTypedArray(r.typedArray),normalize:!1,offsetInBytes:0,strideInBytes:0}),m&&(B=B.concat(Q));let X=new Ki({context:n,attributes:B}),_={depthTest:{enabled:!0}},P={depthTest:{enabled:!0},depthMask:!1,blending:Pn.ALPHA_BLEND};t._opaquePass===Pt.CESIUM_3D_TILE&&(_.stencilTest=gn.setCesium3DTileBit(),_.stencilMask=gn.CESIUM_3D_TILE_MASK,P.stencilTest=gn.setCesium3DTileBit(),P.stencilMask=gn.CESIUM_3D_TILE_MASK),t._opaqueRenderState=he.fromCache(_),t._translucentRenderState=he.fromCache(P),t._drawCommand=new Ee({boundingVolume:new Ft,cull:t._cull,modelMatrix:new L,primitiveType:le.POINTS,vertexArray:X,count:o,shaderProgram:void 0,uniformMap:void 0,renderState:A?t._translucentRenderState:t._opaqueRenderState,pass:A?Pt.TRANSLUCENT:t._opaquePass,owner:t,castShadows:!1,receiveShadows:!1,pickId:t._pickIdLoaded()})}function p9e(t,e){let n=e.context,i=t._isQuantized,o=t._isQuantizedDraco,a=t._isOctEncodedDraco,s={u_pointSizeAndTimeAndGeometricErrorAndDepthMultiplier:function(){let l=l9e;if(l.x=t._attenuation?t.maximumAttenuation:t._pointSize,l.x*=e.pixelRatio,l.y=t.time,t._attenuation){let r=e.camera.frustum,d;e.mode===ut.SCENE2D||r instanceof wn?d=Number.POSITIVE_INFINITY:d=n.drawingBufferHeight/e.camera.frustum.sseDenominator,l.z=t.geometricError*t.geometricErrorScale,l.w=d}return l},u_highlightColor:function(){return t._highlightColor},u_constantColor:function(){return t._constantColor},u_clippingPlanes:function(){let l=t.clippingPlanes;return t.isClipped?l.texture:n.defaultTexture},u_clippingPlanesEdgeStyle:function(){let l=t.clippingPlanes;if(!c(l))return v.TRANSPARENT;let r=v.clone(l.edgeColor,d9e);return r.alpha=l.edgeWidth,r},u_clippingPlanesMatrix:function(){let l=t.clippingPlanes;if(!c(l))return L.IDENTITY;let r=f(t.clippingPlanesOriginMatrix,t._modelMatrix);L.multiply(n.uniformState.view3D,r,$lt);let d=L.multiply($lt,l.modelMatrix,$lt);return L.inverseTranspose(d,m9e)}};RN.addUniforms(t,s),(i||o||a)&&(s=ze(s,{u_quantizedVolumeScaleAndOctEncodedRange:function(){let l=r9e;if(c(t._quantizedVolumeScale)){let r=p.clone(t._quantizedVolumeScale,l);p.divideByScalar(r,t._quantizedRange,l)}return l.w=t._octEncodedRange,l}})),c(t._uniformMapLoaded)&&(s=t._uniformMapLoaded(s)),t._drawCommand.uniformMap=s}function trt(t,e){let n=/czm_3dtiles_property_(\d+)/g,i=n.exec(t);for(;i!==null;){let o=parseInt(i[1]);e.indexOf(o)===-1&&e.push(o),i=n.exec(t)}}function ert(t,e){t=t.slice(t.indexOf(` -`));let n=/czm_3dtiles_builtin_property_(\w+)/g,i=n.exec(t);for(;i!==null;){let o=i[1];e.indexOf(o)===-1&&e.push(o),i=n.exec(t)}}function nrt(t,e){let n=t.numberOfAttributes;for(let i=0;i<n;++i){let o=t.getAttribute(i);if(o.index===e)return o}}var u9e={POSITION:"czm_3dtiles_builtin_property_POSITION",POSITION_ABSOLUTE:"czm_3dtiles_builtin_property_POSITION_ABSOLUTE",COLOR:"czm_3dtiles_builtin_property_COLOR",NORMAL:"czm_3dtiles_builtin_property_NORMAL"};function Z9e(t,e,n){let i,o,a,s=e.context,l=c(n),r=t._isQuantized,d=t._isQuantizedDraco,m=t._isOctEncoded16P,h=t._isOctEncodedDraco,Z=t._isRGB565,b=t._isTranslucent,u=t._hasColors,F=t._hasNormals,U=t._hasBatchIds,G=t._backFaceCulling,A=t._normalShading,T=t._drawCommand.vertexArray,g=t.clippingPlanes,C=t._attenuation,y,Y,Q,J=b,M=be(u9e),V={},E=t._styleableShaderAttributes;for(o in E)E.hasOwnProperty(o)&&(a=E[o],M[o]=`czm_3dtiles_property_${a.location}`,V[a.location]=a);if(l){let Wt={translucent:!1},Nt="(vec3 czm_3dtiles_builtin_property_POSITION, vec3 czm_3dtiles_builtin_property_POSITION_ABSOLUTE, vec4 czm_3dtiles_builtin_property_COLOR, vec3 czm_3dtiles_builtin_property_NORMAL)";y=n.getColorShaderFunction(`getColorFromStyle${Nt}`,M,Wt),Y=n.getShowShaderFunction(`getShowFromStyle${Nt}`,M,Wt),Q=n.getPointSizeShaderFunction(`getPointSizeFromStyle${Nt}`,M,Wt),c(y)&&Wt.translucent&&(J=!0)}t._styleTranslucent=J;let I=c(y),B=c(Y),X=c(Q),_=t.isClipped,P=[],w=[];I&&(trt(y,P),ert(y,w)),B&&(trt(Y,P),ert(Y,w)),X&&(trt(Q,P),ert(Q,w));let z=w.indexOf("COLOR")>=0,H=w.indexOf("NORMAL")>=0;if(H&&!F)throw new St("Style references the NORMAL semantic but the point cloud does not have normals");for(o in E)if(E.hasOwnProperty(o)){a=E[o];let Wt=P.indexOf(a.location)>=0,Nt=nrt(T,a.location);Nt.enabled=Wt}let nt=u&&(!I||z);if(u){let Wt=nrt(T,o4);Wt.enabled=nt}let $=F&&(A||G||H);if(F){let Wt=nrt(T,irt);Wt.enabled=$}let dt={a_position:j2t};nt&&(dt.a_color=o4),$&&(dt.a_normal=irt),U&&(dt.a_batchId=q2t);let q="",at=P.length;for(i=0;i<at;++i){let Wt=P[i];a=V[Wt];let Nt=a.componentCount,kt=`czm_3dtiles_property_${Wt}`,Mt;Nt===1?Mt="float":Mt=`vec${Nt}`,q+=`in ${Mt} ${kt}; +`,e},addUniforms:function(e,n){n.czm_splitDirection=function(){return e.splitDirection}}},bN=t9e;var og={NEEDS_DECODE:0,DECODING:1,READY:2,FAILED:3};function oD(t){this._parsedContent=void 0,this._drawCommand=void 0,this._isTranslucent=!1,this._styleTranslucent=!1,this._constantColor=v.clone(v.DARKGRAY),this._highlightColor=v.clone(v.WHITE),this._pointSize=1,this._rtcCenter=void 0,this._quantizedVolumeScale=void 0,this._quantizedVolumeOffset=void 0,this._styleableShaderAttributes=void 0,this._isQuantized=!1,this._isOctEncoded16P=!1,this._isRGB565=!1,this._hasColors=!1,this._hasNormals=!1,this._hasBatchIds=!1,this._decodingState=og.READY,this._dequantizeInShader=!0,this._isQuantizedDraco=!1,this._isOctEncodedDraco=!1,this._quantizedRange=0,this._octEncodedRange=0,this.backFaceCulling=!1,this._backFaceCulling=!1,this.normalShading=!0,this._normalShading=!0,this._opaqueRenderState=void 0,this._translucentRenderState=void 0,this._mode=void 0,this._ready=!1,this._pointsLength=0,this._geometryByteLength=0,this._vertexShaderLoaded=t.vertexShaderLoaded,this._fragmentShaderLoaded=t.fragmentShaderLoaded,this._uniformMapLoaded=t.uniformMapLoaded,this._batchTableLoaded=t.batchTableLoaded,this._pickIdLoaded=t.pickIdLoaded,this._opaquePass=f(t.opaquePass,Pt.OPAQUE),this._cull=f(t.cull,!0),this.style=void 0,this._style=void 0,this.styleDirty=!1,this.modelMatrix=L.clone(L.IDENTITY),this._modelMatrix=L.clone(L.IDENTITY),this.time=0,this.shadows=Vi.ENABLED,this._boundingSphere=void 0,this.clippingPlanes=void 0,this.isClipped=!1,this.clippingPlanesDirty=!1,this.clippingPlanesOriginMatrix=void 0,this.attenuation=!1,this._attenuation=!1,this.geometricError=0,this.geometricErrorScale=1,this.maximumAttenuation=this._pointSize,this.splitDirection=f(t.splitDirection,Jc.NONE),this._splittingEnabled=!1,this._error=void 0,e9e(this,t)}Object.defineProperties(oD.prototype,{pointsLength:{get:function(){return this._pointsLength}},geometryByteLength:{get:function(){return this._geometryByteLength}},ready:{get:function(){return this._ready}},color:{get:function(){return v.clone(this._highlightColor)},set:function(t){this._highlightColor=v.clone(t,this._highlightColor)}},boundingSphere:{get:function(){if(c(this._drawCommand))return this._drawCommand.boundingVolume},set:function(t){this._boundingSphere=Ft.clone(t,this._boundingSphere)}}});function e9e(t,e){let n=xA.parse(e.arrayBuffer,e.byteOffset);if(t._parsedContent=n,t._rtcCenter=n.rtcCenter,t._hasNormals=n.hasNormals,t._hasColors=n.hasColors,t._hasBatchIds=n.hasBatchIds,t._isTranslucent=n.isTranslucent,!n.hasBatchIds&&c(n.batchTableBinary)&&(n.styleableProperties=wb.getBinaryProperties(n.pointsLength,n.batchTableJson,n.batchTableBinary)),c(n.draco)){let l=n.draco;t._decodingState=og.NEEDS_DECODE,l.dequantizeInShader=t._dequantizeInShader}let i=n.positions;c(i)&&(t._isQuantized=i.isQuantized,t._quantizedVolumeScale=i.quantizedVolumeScale,t._quantizedVolumeOffset=i.quantizedVolumeOffset,t._quantizedRange=i.quantizedRange);let o=n.normals;c(o)&&(t._isOctEncoded16P=o.octEncoded);let a=n.colors;c(a)&&(c(a.constantColor)&&(t._constantColor=v.clone(a.constantColor,t._constantColor),t._hasColors=!1),t._isRGB565=a.isRGB565);let s=n.batchIds;c(n.batchIds)&&(s.name="BATCH_ID",s.semantic="BATCH_ID",s.setIndex=void 0),n.hasBatchIds&&t._batchTableLoaded(n.batchLength,n.batchTableJson,n.batchTableBinary),t._pointsLength=n.pointsLength}var n9e=new p,i9e=new p,o9e=new p,vkt,i4;function a9e(t){if(!c(i4)){vkt=new zkt.default(0),i4=new Array(t);for(let e=0;e<t;++e)i4[e]=vkt.random()}return i4}function s9e(t){let n=t.length/3,i=Math.min(n,20),o=a9e(20),a=Number.MAX_VALUE,s=-Number.MAX_VALUE,l=p.fromElements(a,a,a,n9e),r=p.fromElements(s,s,s,i9e);for(let m=0;m<i;++m){let h=Math.floor(o[m]*n),u=p.unpack(t,h*3,o9e);p.minimumByComponent(l,u,l),p.maximumByComponent(r,u,r)}let d=Ft.fromCornerPoints(l,r);return d.radius+=k.EPSILON2,d}function Kkt(t,e){let n=it.fromTypedArray(t);return n===it.INT||n===it.UNSIGNED_INT||n===it.DOUBLE?(Gn("Cast pnts property to floats",`Point cloud property "${e}" will be cast to a float array because INT, UNSIGNED_INT, and DOUBLE are not valid WebGL vertex attribute types. Some precision may be lost.`),new Float32Array(t)):t}var l9e=new bt,r9e=new bt,d9e=new v,jkt=0,o4=1,irt=2,qkt=3,c9e=4,$lt=new L,m9e=new L;function h9e(t,e){let n=e.context,i=t._parsedContent,o=t._pointsLength,a=i.positions,s=i.colors,l=i.normals,r=i.batchIds,d=i.styleableProperties,m=c(d),h=t._isQuantized,u=t._isQuantizedDraco,R=t._isOctEncoded16P,V=t._isOctEncodedDraco,F=t._quantizedRange,U=t._octEncodedRange,G=t._isRGB565,A=t._isTranslucent,S=t._hasColors,g=t._hasNormals,C=t._hasBatchIds,y,Y,Q=[],J={};if(t._styleableShaderAttributes=J,m){let w=c9e;for(let z in d)if(d.hasOwnProperty(z)){let H=d[z],nt=Kkt(H.typedArray,z);y=H.componentCount,Y=it.fromTypedArray(nt);let $=we.createVertexBuffer({context:n,typedArray:nt,usage:ce.STATIC_DRAW});t._geometryByteLength+=$.sizeInBytes;let dt={index:w,vertexBuffer:$,componentsPerAttribute:y,componentDatatype:Y,normalize:!1,offsetInBytes:0,strideInBytes:0};Q.push(dt),J[z]={location:w,componentCount:y},++w}}let M=we.createVertexBuffer({context:n,typedArray:a.typedArray,usage:ce.STATIC_DRAW});t._geometryByteLength+=M.sizeInBytes;let Z;S&&(Z=we.createVertexBuffer({context:n,typedArray:s.typedArray,usage:ce.STATIC_DRAW}),t._geometryByteLength+=Z.sizeInBytes);let E;g&&(E=we.createVertexBuffer({context:n,typedArray:l.typedArray,usage:ce.STATIC_DRAW}),t._geometryByteLength+=E.sizeInBytes);let I;C&&(r.typedArray=Kkt(r.typedArray,"batchIds"),I=we.createVertexBuffer({context:n,typedArray:r.typedArray,usage:ce.STATIC_DRAW}),t._geometryByteLength+=I.sizeInBytes);let B=[];if(h?Y=it.UNSIGNED_SHORT:u?Y=F<=255?it.UNSIGNED_BYTE:it.UNSIGNED_SHORT:Y=it.FLOAT,B.push({index:jkt,vertexBuffer:M,componentsPerAttribute:3,componentDatatype:Y,normalize:!1,offsetInBytes:0,strideInBytes:0}),t._cull&&(h||u?t._boundingSphere=Ft.fromCornerPoints(p.ZERO,t._quantizedVolumeScale):t._boundingSphere=s9e(a.typedArray)),S)if(G)B.push({index:o4,vertexBuffer:Z,componentsPerAttribute:1,componentDatatype:it.UNSIGNED_SHORT,normalize:!1,offsetInBytes:0,strideInBytes:0});else{let w=A?4:3;B.push({index:o4,vertexBuffer:Z,componentsPerAttribute:w,componentDatatype:it.UNSIGNED_BYTE,normalize:!0,offsetInBytes:0,strideInBytes:0})}g&&(R?(y=2,Y=it.UNSIGNED_BYTE):V?(y=2,Y=U<=255?it.UNSIGNED_BYTE:it.UNSIGNED_SHORT):(y=3,Y=it.FLOAT),B.push({index:irt,vertexBuffer:E,componentsPerAttribute:y,componentDatatype:Y,normalize:!1,offsetInBytes:0,strideInBytes:0})),C&&B.push({index:qkt,vertexBuffer:I,componentsPerAttribute:1,componentDatatype:it.fromTypedArray(r.typedArray),normalize:!1,offsetInBytes:0,strideInBytes:0}),m&&(B=B.concat(Q));let X=new Ki({context:n,attributes:B}),_={depthTest:{enabled:!0}},P={depthTest:{enabled:!0},depthMask:!1,blending:Pn.ALPHA_BLEND};t._opaquePass===Pt.CESIUM_3D_TILE&&(_.stencilTest=gn.setCesium3DTileBit(),_.stencilMask=gn.CESIUM_3D_TILE_MASK,P.stencilTest=gn.setCesium3DTileBit(),P.stencilMask=gn.CESIUM_3D_TILE_MASK),t._opaqueRenderState=he.fromCache(_),t._translucentRenderState=he.fromCache(P),t._drawCommand=new Ee({boundingVolume:new Ft,cull:t._cull,modelMatrix:new L,primitiveType:le.POINTS,vertexArray:X,count:o,shaderProgram:void 0,uniformMap:void 0,renderState:A?t._translucentRenderState:t._opaqueRenderState,pass:A?Pt.TRANSLUCENT:t._opaquePass,owner:t,castShadows:!1,receiveShadows:!1,pickId:t._pickIdLoaded()})}function p9e(t,e){let n=e.context,i=t._isQuantized,o=t._isQuantizedDraco,a=t._isOctEncodedDraco,s={u_pointSizeAndTimeAndGeometricErrorAndDepthMultiplier:function(){let l=l9e;if(l.x=t._attenuation?t.maximumAttenuation:t._pointSize,l.x*=e.pixelRatio,l.y=t.time,t._attenuation){let r=e.camera.frustum,d;e.mode===Vt.SCENE2D||r instanceof wn?d=Number.POSITIVE_INFINITY:d=n.drawingBufferHeight/e.camera.frustum.sseDenominator,l.z=t.geometricError*t.geometricErrorScale,l.w=d}return l},u_highlightColor:function(){return t._highlightColor},u_constantColor:function(){return t._constantColor},u_clippingPlanes:function(){let l=t.clippingPlanes;return t.isClipped?l.texture:n.defaultTexture},u_clippingPlanesEdgeStyle:function(){let l=t.clippingPlanes;if(!c(l))return v.TRANSPARENT;let r=v.clone(l.edgeColor,d9e);return r.alpha=l.edgeWidth,r},u_clippingPlanesMatrix:function(){let l=t.clippingPlanes;if(!c(l))return L.IDENTITY;let r=f(t.clippingPlanesOriginMatrix,t._modelMatrix);L.multiply(n.uniformState.view3D,r,$lt);let d=L.multiply($lt,l.modelMatrix,$lt);return L.inverseTranspose(d,m9e)}};bN.addUniforms(t,s),(i||o||a)&&(s=ze(s,{u_quantizedVolumeScaleAndOctEncodedRange:function(){let l=r9e;if(c(t._quantizedVolumeScale)){let r=p.clone(t._quantizedVolumeScale,l);p.divideByScalar(r,t._quantizedRange,l)}return l.w=t._octEncodedRange,l}})),c(t._uniformMapLoaded)&&(s=t._uniformMapLoaded(s)),t._drawCommand.uniformMap=s}function trt(t,e){let n=/czm_3dtiles_property_(\d+)/g,i=n.exec(t);for(;i!==null;){let o=parseInt(i[1]);e.indexOf(o)===-1&&e.push(o),i=n.exec(t)}}function ert(t,e){t=t.slice(t.indexOf(` +`));let n=/czm_3dtiles_builtin_property_(\w+)/g,i=n.exec(t);for(;i!==null;){let o=i[1];e.indexOf(o)===-1&&e.push(o),i=n.exec(t)}}function nrt(t,e){let n=t.numberOfAttributes;for(let i=0;i<n;++i){let o=t.getAttribute(i);if(o.index===e)return o}}var V9e={POSITION:"czm_3dtiles_builtin_property_POSITION",POSITION_ABSOLUTE:"czm_3dtiles_builtin_property_POSITION_ABSOLUTE",COLOR:"czm_3dtiles_builtin_property_COLOR",NORMAL:"czm_3dtiles_builtin_property_NORMAL"};function u9e(t,e,n){let i,o,a,s=e.context,l=c(n),r=t._isQuantized,d=t._isQuantizedDraco,m=t._isOctEncoded16P,h=t._isOctEncodedDraco,u=t._isRGB565,R=t._isTranslucent,V=t._hasColors,F=t._hasNormals,U=t._hasBatchIds,G=t._backFaceCulling,A=t._normalShading,S=t._drawCommand.vertexArray,g=t.clippingPlanes,C=t._attenuation,y,Y,Q,J=R,M=Re(V9e),Z={},E=t._styleableShaderAttributes;for(o in E)E.hasOwnProperty(o)&&(a=E[o],M[o]=`czm_3dtiles_property_${a.location}`,Z[a.location]=a);if(l){let Wt={translucent:!1},Nt="(vec3 czm_3dtiles_builtin_property_POSITION, vec3 czm_3dtiles_builtin_property_POSITION_ABSOLUTE, vec4 czm_3dtiles_builtin_property_COLOR, vec3 czm_3dtiles_builtin_property_NORMAL)";y=n.getColorShaderFunction(`getColorFromStyle${Nt}`,M,Wt),Y=n.getShowShaderFunction(`getShowFromStyle${Nt}`,M,Wt),Q=n.getPointSizeShaderFunction(`getPointSizeFromStyle${Nt}`,M,Wt),c(y)&&Wt.translucent&&(J=!0)}t._styleTranslucent=J;let I=c(y),B=c(Y),X=c(Q),_=t.isClipped,P=[],w=[];I&&(trt(y,P),ert(y,w)),B&&(trt(Y,P),ert(Y,w)),X&&(trt(Q,P),ert(Q,w));let z=w.indexOf("COLOR")>=0,H=w.indexOf("NORMAL")>=0;if(H&&!F)throw new Tt("Style references the NORMAL semantic but the point cloud does not have normals");for(o in E)if(E.hasOwnProperty(o)){a=E[o];let Wt=P.indexOf(a.location)>=0,Nt=nrt(S,a.location);Nt.enabled=Wt}let nt=V&&(!I||z);if(V){let Wt=nrt(S,o4);Wt.enabled=nt}let $=F&&(A||G||H);if(F){let Wt=nrt(S,irt);Wt.enabled=$}let dt={a_position:jkt};nt&&(dt.a_color=o4),$&&(dt.a_normal=irt),U&&(dt.a_batchId=qkt);let q="",at=P.length;for(i=0;i<at;++i){let Wt=P[i];a=Z[Wt];let Nt=a.componentCount,kt=`czm_3dtiles_property_${Wt}`,Mt;Nt===1?Mt="float":Mt=`vec${Nt}`,q+=`in ${Mt} ${kt}; `,dt[kt]=a.location}p9e(t,e);let st=`in vec3 a_position; out vec4 v_color; uniform vec4 u_pointSizeAndTimeAndGeometricErrorAndDepthMultiplier; @@ -15408,8 +15408,8 @@ uniform vec4 u_highlightColor; float tiles3d_tileset_time; `,C&&(st+=`float u_geometricError; float u_depthMultiplier; -`),st+=q,nt&&(b?st+=`in vec4 a_color; -`:Z?st+=`in float a_color; +`),st+=q,nt&&(R?st+=`in vec4 a_color; +`:u?st+=`in float a_color; const float SHIFT_RIGHT_11 = 1.0 / 2048.0; const float SHIFT_RIGHT_5 = 1.0 / 32.0; const float SHIFT_LEFT_11 = 2048.0; @@ -15427,8 +15427,8 @@ const float NORMALIZE_5 = 1.0 / 32.0; tiles3d_tileset_time = u_pointSizeAndTimeAndGeometricErrorAndDepthMultiplier.y; `,C&&(st+=` u_geometricError = u_pointSizeAndTimeAndGeometricErrorAndDepthMultiplier.z; u_depthMultiplier = u_pointSizeAndTimeAndGeometricErrorAndDepthMultiplier.w; -`),nt?b?st+=` vec4 color = a_color; -`:Z?st+=` float compressed = a_color; +`),nt?R?st+=` vec4 color = a_color; +`:u?st+=` float compressed = a_color; float r = floor(compressed * SHIFT_RIGHT_11); compressed -= r * SHIFT_LEFT_11; float g = floor(compressed * SHIFT_RIGHT_5); @@ -15475,8 +15475,8 @@ uniform vec4 u_clippingPlanesEdgeStyle; { out_FragColor = czm_gammaCorrect(v_color); `,_&&(Et+=iD("u_clippingPlanes","u_clippingPlanesMatrix","u_clippingPlanesEdgeStyle")),Et+=`} -`,t.splitDirection!==Jc.NONE&&(Et=RN.modifyFragmentShader(Et)),c(t._vertexShaderLoaded)&&(st=t._vertexShaderLoaded(st)),c(t._fragmentShaderLoaded)&&(Et=t._fragmentShaderLoaded(Et));let Qt=t._drawCommand;c(Qt.shaderProgram)&&Qt.shaderProgram.destroy(),Qt.shaderProgram=xn.fromCache({context:s,vertexShaderSource:st,fragmentShaderSource:Et,attributeLocations:dt});try{Qt.shaderProgram._bind()}catch{throw new St("Error generating style shader: this may be caused by a type mismatch, index out-of-bounds, or other syntax error.")}}function V9e(t,e){if(t._decodingState===og.READY)return!1;if(t._decodingState===og.NEEDS_DECODE){let n=t._parsedContent,i=n.draco,o=$R.decodePointCloud(i,e);c(o)&&(t._decodingState=og.DECODING,o.then(function(a){t._decodingState=og.READY;let s=c(a.POSITION)?a.POSITION.array:void 0,l=c(a.RGB)?a.RGB.array:void 0,r=c(a.RGBA)?a.RGBA.array:void 0,d=c(a.NORMAL)?a.NORMAL.array:void 0,m=c(a.BATCH_ID)?a.BATCH_ID.array:void 0,h=c(s)&&c(a.POSITION.data.quantization),Z=c(d)&&c(a.NORMAL.data.quantization);if(h){let U=a.POSITION.data.quantization,G=U.range;t._quantizedVolumeScale=p.fromElements(G,G,G),t._quantizedVolumeOffset=p.unpack(U.minValues),t._quantizedRange=(1<<U.quantizationBits)-1,t._isQuantizedDraco=!0}Z&&(t._octEncodedRange=(1<<a.NORMAL.data.quantization.quantizationBits)-1,t._isOctEncodedDraco=!0);let b=n.styleableProperties,u=i.batchTableProperties;for(let U in u)if(u.hasOwnProperty(U)){let G=a[U];c(b)||(b={}),b[U]={typedArray:G.array,componentCount:G.data.componentsPerAttribute}}c(s)&&(n.positions={typedArray:s});let F=f(r,l);c(F)&&(n.colors={typedArray:F}),c(d)&&(n.normals={typedArray:d}),c(m)&&(n.batchIds={typedArray:m}),n.styleableProperties=b}).catch(function(a){t._decodingState=og.FAILED,t._error=a}))}return!0}var b9e=new Rt,R9e=new p;oD.prototype.update=function(t){let e=t.context;if(c(this._error)){let d=this._error;throw this._error=void 0,d}if(V9e(this,e))return;let i=!1,o=!L.equals(this._modelMatrix,this.modelMatrix);if(this._mode!==t.mode&&(this._mode=t.mode,o=!0),c(this._drawCommand)||(h9e(this,t),o=!0,i=!0,this._ready=!0,this._parsedContent=void 0),o){L.clone(this.modelMatrix,this._modelMatrix);let d=this._drawCommand.modelMatrix;if(L.clone(this._modelMatrix,d),c(this._rtcCenter)&&L.multiplyByTranslation(d,this._rtcCenter,d),c(this._quantizedVolumeOffset)&&L.multiplyByTranslation(d,this._quantizedVolumeOffset,d),t.mode!==ut.SCENE3D){let h=t.mapProjection,Z=L.getColumn(d,3,b9e);Rt.equals(Z,Rt.UNIT_W)||Pe.basisTo2D(h,d,d)}let m=this._drawCommand.boundingVolume;if(Ft.clone(this._boundingSphere,m),this._cull){let h=m.center;L.multiplyByPoint(d,h,h);let Z=L.getScale(d,R9e);m.radius*=p.maximumComponent(Z)}}this.clippingPlanesDirty&&(this.clippingPlanesDirty=!1,i=!0),this._attenuation!==this.attenuation&&(this._attenuation=this.attenuation,i=!0),this.backFaceCulling!==this._backFaceCulling&&(this._backFaceCulling=this.backFaceCulling,i=!0),this.normalShading!==this._normalShading&&(this._normalShading=this.normalShading,i=!0),(this._style!==this.style||this.styleDirty)&&(this._style=this.style,this.styleDirty=!1,i=!0);let a=this.splitDirection!==Jc.NONE;this._splittingEnabled!==a&&(this._splittingEnabled=a,i=!0),i&&Z9e(this,t,this._style),this._drawCommand.castShadows=ui.castShadows(this.shadows),this._drawCommand.receiveShadows=ui.receiveShadows(this.shadows);let s=this._highlightColor.alpha<1||this._constantColor.alpha<1||this._styleTranslucent;this._drawCommand.renderState=s?this._translucentRenderState:this._opaqueRenderState,this._drawCommand.pass=s?Pt.TRANSLUCENT:this._opaquePass;let l=t.commandList,r=t.passes;(r.render||r.pick)&&l.push(this._drawCommand)};oD.prototype.isDestroyed=function(){return!1};oD.prototype.destroy=function(){let t=this._drawCommand;return c(t)&&(t.vertexArray=t.vertexArray&&t.vertexArray.destroy(),t.shaderProgram=t.shaderProgram&&t.shaderProgram.destroy()),At(this)};var aD=oD;var n6o=R(W(),1);function up(){Ut.throwInstantiationError()}up.computeDefaultLevelZeroMaximumGeometricError=function(t){return t.ellipsoid.maximumRadius*2*Math.PI*.25/(65*t.getNumberOfXTilesAtLevel(0))};Object.defineProperties(up.prototype,{quadtree:{get:Ut.throwInstantiationError,set:Ut.throwInstantiationError},tilingScheme:{get:Ut.throwInstantiationError},errorEvent:{get:Ut.throwInstantiationError}});up.prototype.update=Ut.throwInstantiationError;up.prototype.beginUpdate=Ut.throwInstantiationError;up.prototype.endUpdate=Ut.throwInstantiationError;up.prototype.getLevelMaximumGeometricError=Ut.throwInstantiationError;up.prototype.loadTile=Ut.throwInstantiationError;up.prototype.computeTileVisibility=Ut.throwInstantiationError;up.prototype.showTileThisFrame=Ut.throwInstantiationError;up.prototype.computeDistanceToTile=Ut.throwInstantiationError;up.prototype.isDestroyed=Ut.throwInstantiationError;up.prototype.destroy=Ut.throwInstantiationError;var ort=up;var l6o=R(W(),1);function art(t){t=f(t,1),this._radius=f(t,1)}Object.defineProperties(art.prototype,{radius:{get:function(){return this._radius},set:function(t){this._radius=t}}});art.prototype.emit=function(t){let e=k.randomBetween(0,k.TWO_PI),n=k.randomBetween(0,k.PI),i=k.randomBetween(0,this._radius),o=i*Math.cos(e)*Math.sin(n),a=i*Math.sin(e)*Math.sin(n),s=i*Math.cos(n);t.position=p.fromElements(o,a,s,t.position),t.velocity=p.normalize(t.position,t.velocity)};var srt=art;var c6o=R(W(),1);function sD(){}sD.prototype.evaluate=function(t,e){Ut.throwInstantiationError()};sD.prototype.evaluateColor=function(t,e){Ut.throwInstantiationError()};sD.prototype.getShaderFunction=function(t,e,n,i){Ut.throwInstantiationError()};sD.prototype.getVariables=function(){Ut.throwInstantiationError()};var lrt=sD;var Z6o=R(W(),1);function WN(t){this._ready=!1,this._provider=void 0,this._errorEvent=new It,this._readyEvent=new It,f9e(this,t)}Object.defineProperties(WN.prototype,{errorEvent:{get:function(){return this._errorEvent}},readyEvent:{get:function(){return this._readyEvent}},ready:{get:function(){return this._ready}},provider:{get:function(){return this._provider}}});WN.fromWorldTerrain=function(t){return new WN(KS(t))};WN.fromWorldBathymetry=function(t){return new WN(B5(t))};function W9e(t,e){t.numberOfListeners>0?t.raiseEvent(e):console.error(e)}async function f9e(t,e){let n;try{n=await Promise.resolve(e),t._provider=n,t._ready=!0,t._readyEvent.raiseEvent(n)}catch(i){W9e(t._errorEvent,i)}}var lD=WN;var R6o=R(W(),1);function fN(){}fN.prototype.boundingVolume=void 0;fN.prototype.boundingSphere=void 0;fN.prototype.distanceToCamera=function(t){Ut.throwInstantiationError()};fN.prototype.intersectPlane=function(t){Ut.throwInstantiationError()};fN.prototype.createDebugVolume=function(t){Ut.throwInstantiationError()};var rrt=fN;var T6o=R(W(),1);function rD(t){t=f(t,f.EMPTY_OBJECT),this._tilingScheme=c(t.tilingScheme)?t.tilingScheme:new Qo({ellipsoid:t.ellipsoid}),this._color=f(t.color,v.YELLOW),this._errorEvent=new It,this._tileWidth=f(t.tileWidth,256),this._tileHeight=f(t.tileHeight,256),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0}Object.defineProperties(rD.prototype,{proxy:{get:function(){}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){}},minimumLevel:{get:function(){}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){}},hasAlphaChannel:{get:function(){return!0}}});rD.prototype.getTileCredits=function(t,e,n){};rD.prototype.requestImage=function(t,e,n,i){let o=document.createElement("canvas");o.width=256,o.height=256;let a=o.getContext("2d"),s=this._color.toCssColorString();return a.strokeStyle=s,a.lineWidth=2,a.strokeRect(1,1,255,255),a.font="bold 25px Arial",a.textAlign="center",a.fillStyle=s,a.fillText(`L: ${n}`,124,86),a.fillText(`X: ${t}`,124,136),a.fillText(`Y: ${e}`,124,186),Promise.resolve(o)};rD.prototype.pickFeatures=function(t,e,n,i,o){};var dD=rD;var E6o=R(W(),1);function drt(t){Ut.throwInstantiationError()}drt.prototype.isReady=Ut.throwInstantiationError;drt.prototype.shouldDiscardImage=Ut.throwInstantiationError;var crt=drt;var I6o=R(W(),1),F9e={START:0,LOADING:1,READY:2,UPSAMPLED_ONLY:3},mrt=Object.freeze(F9e);var v6o=R(W(),1);function sg(t){t=f(t,f.EMPTY_OBJECT),this.show=f(t.show,!0),this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this.shadows=f(t.shadows,ui.ENABLED),this.maximumMemoryUsage=f(t.maximumMemoryUsage,256),this.shading=new eb(t.shading),this.style=t.style,this.frameFailed=new It,this.frameChanged=new It,this._clock=t.clock,this._intervals=t.intervals,this._clippingPlanes=void 0,this.clippingPlanes=t.clippingPlanes,this._pointCloudEyeDomeLighting=new l0,this._loadTimestamp=void 0,this._clippingPlanesState=0,this._styleDirty=!1,this._pickId=void 0,this._totalMemoryUsageInBytes=0,this._frames=[],this._previousInterval=void 0,this._nextInterval=void 0,this._lastRenderedFrame=void 0,this._clockMultiplier=0,this._runningSum=0,this._runningLength=0,this._runningIndex=0,this._runningSamples=new Array(5).fill(0),this._runningAverage=0}Object.defineProperties(sg.prototype,{clippingPlanes:{get:function(){return this._clippingPlanes},set:function(t){Ml.setOwner(t,this,"_clippingPlanes")}},totalMemoryUsageInBytes:{get:function(){return this._totalMemoryUsageInBytes}},boundingSphere:{get:function(){if(c(this._lastRenderedFrame))return this._lastRenderedFrame.pointCloud.boundingSphere}}});function U9e(t){return`uniform vec4 czm_pickColor; -${t}`}function G9e(t){return function(e){return ze(e,{czm_pickColor:function(){return t._pickId.color}})}}function A9e(){return"czm_pickColor"}sg.prototype.makeStyleDirty=function(){this._styleDirty=!0};sg.prototype._getAverageLoadTime=function(){return this._runningLength===0?.05:this._runningAverage};var T9e=new rt;function prt(t){let e=t._clock,n=e.canAnimate&&e.shouldAnimate,i=e.multiplier;return n?i:0}function ag(t,e){return t._intervals.indexOf(e.start)}function S9e(t,e){let n=t._intervals,i=t._clock,o=prt(t);if(o===0)return;let a=t._getAverageLoadTime(),s=rt.addSeconds(i.currentTime,a*o,T9e),l=n.indexOf(s),r=ag(t,e);return l===r&&(o>=0?++l:--l),n.get(l)}function g9e(t){let e=t._intervals,i=t._clock.currentTime,o=e.indexOf(i);return e.get(o)}function E9e(t,e,n){let i=prt(t),o=ag(t,e),a=ag(t,n);return i>=0?o>=a:o<=a}function tkt(t,e){return function(n){let i=c(n.message)?n.message:n.toString();t.frameFailed.numberOfListeners>0?t.frameFailed.raiseEvent({uri:e,message:i}):(console.log(`A frame failed to load: ${e}`),console.log(`Error: ${i}`))}}function C9e(t,e,n){let i=ag(t,e),o=t._frames,a=o[i];if(!c(a)){let s=e.data.transform,l=c(s)?L.fromArray(s):void 0,r=e.data.uri;a={pointCloud:void 0,transform:l,timestamp:Oi(),sequential:!0,ready:!1,touchedFrameNumber:n.frameNumber,uri:r},o[i]=a,te.fetchArrayBuffer({url:r}).then(function(d){a.pointCloud=new aD({arrayBuffer:d,cull:!0,fragmentShaderLoaded:U9e,uniformMapLoaded:G9e(t),pickIdLoaded:A9e})}).catch(tkt(t,r))}return a}function I9e(t,e){t._runningSum+=e,t._runningSum-=t._runningSamples[t._runningIndex],t._runningSamples[t._runningIndex]=e,t._runningLength=Math.min(t._runningLength+1,t._runningSamples.length),t._runningIndex=(t._runningIndex+1)%t._runningSamples.length,t._runningAverage=t._runningSum/t._runningLength}function N9e(t,e,n,i){e.touchedFrameNumber<i.frameNumber-1&&(e.sequential=!1);let o=e.pointCloud;if(c(o)&&!e.ready){let a=i.commandList,s=a.length;if(ekt(t,e,n,i),o.ready&&(e.ready=!0,t._totalMemoryUsageInBytes+=o.geometryByteLength,a.length=s,e.sequential)){let l=(Oi()-e.timestamp)/1e3;I9e(t,l)}}e.touchedFrameNumber=i.frameNumber}var y9e=new L;function B9e(t,e){let n=t.shading;return c(n)&&c(n.baseResolution)?n.baseResolution:c(e.boundingSphere)?k.cbrt(e.boundingSphere.volume()/e.pointsLength):0}function Q9e(t){let e=t.shading;return c(e)&&c(e.maximumAttenuation)?e.maximumAttenuation:10}var k9e=new eb;function ekt(t,e,n,i){let o=f(t.shading,k9e),a=e.pointCloud,s=f(e.transform,L.IDENTITY);a.modelMatrix=L.multiplyTransformation(t.modelMatrix,s,y9e),a.style=t.style,a.time=n.timeSinceLoad,a.shadows=t.shadows,a.clippingPlanes=t._clippingPlanes,a.isClipped=n.isClipped,a.attenuation=o.attenuation,a.backFaceCulling=o.backFaceCulling,a.normalShading=o.normalShading,a.geometricError=B9e(t,a),a.geometricErrorScale=o.geometricErrorScale,a.maximumAttenuation=Q9e(t);try{a.update(i)}catch(l){tkt(t,e.uri)(l)}e.touchedFrameNumber=i.frameNumber}function hrt(t,e,n,i){let o=C9e(t,e,i);N9e(t,o,n,i)}function Y9e(t){return function(e){return e.touchedFrameNumber<t.frameNumber}}function nkt(t,e){let n=t._frames,i=n.length;for(let o=0;o<i;++o){let a=n[o];if(c(a)&&(!c(e)||e(a))){let s=a.pointCloud;a.ready&&(t._totalMemoryUsageInBytes-=s.geometryByteLength),c(s)&&s.destroy(),a===t._lastRenderedFrame&&(t._lastRenderedFrame=void 0),n[o]=void 0}}}function x9e(t,e){let n=ag(t,e),i=t._frames[n];if(c(i)&&i.ready)return i}function $2t(t,e,n,i,o){return c(n)?n.ready?!0:(hrt(t,e,i,o),n.ready):!1}function X9e(t,e,n,i,o){let a,s,l,r=t._intervals,d=t._frames,m=ag(t,n),h=ag(t,e);if(m>=h){for(a=m;a>=h;--a)if(s=r.get(a),l=d[a],$2t(t,s,l,i,o))return s}else for(a=m;a<=h;++a)if(s=r.get(a),l=d[a],$2t(t,s,l,i,o))return s;return e}function J9e(t,e,n){let i=t._frames,o=i.length;for(let a=0;a<o;++a){let s=i[a];c(s)&&c(s.pointCloud)&&(s.pointCloud.clippingPlanesDirty=e,s.pointCloud.styleDirty=n)}}var FN={timeSinceLoad:0,isClipped:!1,clippingPlanesDirty:!1};sg.prototype.update=function(t){if(t.mode===ut.MORPHING||!this.show)return;c(this._pickId)||(this._pickId=t.context.createPickId({primitive:this})),c(this._loadTimestamp)||(this._loadTimestamp=rt.clone(t.time));let e=Math.max(rt.secondsDifference(t.time,this._loadTimestamp)*1e3,0),n=this._clippingPlanes,i=0,o=!1,a=c(n)&&n.enabled;a&&(n.update(t),i=n.clippingPlanesState),this._clippingPlanesState!==i&&(this._clippingPlanesState=i,o=!0);let s=this._styleDirty;this._styleDirty=!1,(o||s)&&J9e(this,o,s),FN.timeSinceLoad=e,FN.isClipped=a;let l=this.shading,r=this._pointCloudEyeDomeLighting,d=t.commandList,m=d.length,h=this._previousInterval,Z=this._nextInterval,b=g9e(this);if(!c(b))return;let u=!1,F=prt(this),U=F===0;F!==this._clockMultiplier&&(u=!0,this._clockMultiplier=F),(!c(h)||U)&&(h=b),(!c(Z)||u||E9e(this,b,Z))&&(Z=S9e(this,b)),h=X9e(this,h,b,FN,t);let G=x9e(this,h);c(G)||(hrt(this,h,FN,t),G=this._lastRenderedFrame),c(G)&&ekt(this,G,FN,t),c(Z)&&hrt(this,Z,FN,t);let A=this;c(G)&&!c(this._lastRenderedFrame)&&t.afterRender.push(function(){return!0}),c(G)&&G!==this._lastRenderedFrame&&A.frameChanged.numberOfListeners>0&&t.afterRender.push(function(){return A.frameChanged.raiseEvent(A),!0}),this._previousInterval=h,this._nextInterval=Z,this._lastRenderedFrame=G;let T=this._totalMemoryUsageInBytes,g=this.maximumMemoryUsage*1024*1024;T>g&&nkt(this,Y9e(t));let y=d.length-m;c(l)&&l.attenuation&&l.eyeDomeLighting&&y>0&&r.update(t,m,l,this.boundingSphere)};sg.prototype.isDestroyed=function(){return!1};sg.prototype.destroy=function(){return nkt(this),this._clippingPlanes=this._clippingPlanes&&this._clippingPlanes.destroy(),this._pickId=this._pickId&&this._pickId.destroy(),At(this)};var UN=sg;var s7o=R(W(),1);function a4(t,e){this.show=!0,c(t)||(t=new Fe),this.rectangle=Fe.clone(t),c(e)||(e=eo.fromType(eo.ColorType,{color:new v(1,1,1,1)})),this.material=e,this._material=void 0,this._overlayCommand=void 0,this._rs=void 0}a4.prototype.update=function(t){if(!this.show)return;let e=this._rs;if((!c(e)||!Fe.equals(e.viewport,this.rectangle))&&(this._rs=he.fromCache({blending:Pn.ALPHA_BLEND,viewport:this.rectangle})),t.passes.render){let i=t.context;if(this._material!==this.material||!c(this._overlayCommand)){this._material=this.material,c(this._overlayCommand)&&this._overlayCommand.shaderProgram.destroy();let o=new Ve({sources:[this._material.shaderSource,A5]});this._overlayCommand=i.createViewportQuadCommand(o,{renderState:this._rs,uniformMap:this._material._uniforms,owner:this}),this._overlayCommand.pass=Pt.OVERLAY}this._material.update(i),this._overlayCommand.renderState=this._rs,this._overlayCommand.uniformMap=this._material._uniforms,t.commandList.push(this._overlayCommand)}};a4.prototype.isDestroyed=function(){return!1};a4.prototype.destroy=function(){return c(this._overlayCommand)&&(this._overlayCommand.shaderProgram=this._overlayCommand.shaderProgram&&this._overlayCommand.shaderProgram.destroy()),At(this)};var urt=a4;var d7o=R(W(),1);function Zrt(){Ut.throwInstantiationError()}Object.defineProperties(Zrt.prototype,{globalTransform:{get:Ut.throwInstantiationError},shapeTransform:{get:Ut.throwInstantiationError},shape:{get:Ut.throwInstantiationError},minBounds:{get:Ut.throwInstantiationError},maxBounds:{get:Ut.throwInstantiationError},dimensions:{get:Ut.throwInstantiationError},paddingBefore:{get:Ut.throwInstantiationError},paddingAfter:{get:Ut.throwInstantiationError},names:{get:Ut.throwInstantiationError},types:{get:Ut.throwInstantiationError},componentTypes:{get:Ut.throwInstantiationError},minimumValues:{get:Ut.throwInstantiationError},maximumValues:{get:Ut.throwInstantiationError},maximumTileCount:{get:Ut.throwInstantiationError},keyframeCount:{get:Ut.throwInstantiationError},timeIntervalCollection:{get:Ut.throwInstantiationError}});Zrt.prototype.requestData=Ut.throwInstantiationError;var Vrt=Zrt;var h7o=R(W(),1);function lg(){Ut.throwInstantiationError()}Object.defineProperties(lg.prototype,{orientedBoundingBox:{get:Ut.throwInstantiationError},boundingSphere:{get:Ut.throwInstantiationError},boundTransform:{get:Ut.throwInstantiationError},shapeTransform:{get:Ut.throwInstantiationError},shaderUniforms:{get:Ut.throwInstantiationError},shaderDefines:{get:Ut.throwInstantiationError},shaderMaximumIntersectionsLength:{get:Ut.throwInstantiationError}});lg.prototype.update=Ut.throwInstantiationError;lg.prototype.computeOrientedBoundingBoxForTile=Ut.throwInstantiationError;lg.prototype.computeOrientedBoundingBoxForSample=Ut.throwInstantiationError;lg.DefaultMinBounds=Ut.throwInstantiationError;lg.DefaultMaxBounds=Ut.throwInstantiationError;var brt=lg;var R7o=R(W(),1);async function Rrt(t,e){let n=e.terrainProvider,i=e.mapProjection,o=i.ellipsoid,a,s=e.camera.getRectangleCameraCoordinates(t);if(e.mode===ut.SCENE3D?a=o.cartesianToCartographic(s):a=i.unproject(s),!c(n))return a;let l=n.availability;if(!c(l)||e.mode===ut.SCENE2D)return a;let r=[Gt.center(t),Gt.southeast(t),Gt.southwest(t),Gt.northeast(t),Gt.northwest(t)],d=await Rrt._sampleTerrainMostDetailed(n,r),m=!1,h=d.reduce(function(b,u){return c(u.height)?(m=!0,Math.max(u.height,b)):b},-Number.MAX_VALUE),Z=a;return m&&(Z.height+=h),Z}Rrt._sampleTerrainMostDetailed=zS;var rg=Rrt;var Q7o=R(W(),1);var L9e=new v,M9e=new v,_9e=new v,D9e=new v,ikt=new Rt,cD=new Uint8Array(4);function okt(t,e,n,i){let o=e.height===n.height?0:(t-e.height)/(n.height-e.height);return v.lerp(e.color,n.color,o,i)}function s4(t,e){return{height:t,color:v.clone(e)}}function akt(t){return t=t.filter(function(e,n,i){let o=n>0,a=n<i.length-1,s=o?e.height===i[n-1].height:!0,l=a?e.height===i[n+1].height:!0;return!s||!l}),t=t.filter(function(e,n,i){let o=n>0,a=n<i.length-1,s=o?v.equals(e.color,i[n-1].color):!1,l=a?v.equals(e.color,i[n+1].color):!1;return!s||!l}),t=t.filter(function(e,n,i){let o=n>0,a=o?v.equals(e.color,i[n-1].color):!1,s=o?e.height===i[n-1].height:!0;return!a||!s}),t}function O9e(t){let e,n,i=[],o=t.length;for(e=0;e<o;e++){let a=t[e],s=a.entries,l=s.length,r=[];for(n=0;n<l;n++){let b=s[n],u=k.clamp(b.height,sh._minimumHeight,sh._maximumHeight),F=v.clone(b.color,L9e);F.red*=F.alpha,F.green*=F.alpha,F.blue*=F.alpha,r.push(s4(u,F))}let d=!0,m=!0;for(n=0;n<l-1;n++){let b=r[n+0],u=r[n+1];d=d&&b.height<=u.height,m=m&&b.height>=u.height}m?r=r.reverse():d||ZW(r,function(b,u){return k.sign(b.height-u.height)});let h=f(a.extendDownwards,!1),Z=f(a.extendUpwards,!1);r.length===1&&!h&&!Z&&(h=!0,Z=!0),h&&r.splice(0,0,s4(sh._minimumHeight,r[0].color)),Z&&r.splice(r.length,0,s4(sh._maximumHeight,r[r.length-1].color)),r=akt(r),i.push(r)}return i}function H9e(t){let e=O9e(t),n=[],i=[],o;function a(d,m){n.push(s4(d,m))}function s(d,m,h){let Z=v.multiplyByScalar(h,1-m.alpha,D9e);Z=v.add(Z,m,Z),a(d,Z)}let l=e.length;for(o=0;o<l;o++){let d=e[o],m=0,h=0;i=n,n=[];let Z=d.length,b=i.length;for(;m<Z||h<b;){let u=m<Z?d[m]:void 0,F=m>0?d[m-1]:void 0,U=m<Z-1?d[m+1]:void 0,G=h<b?i[h]:void 0,A=h>0?i[h-1]:void 0,T=h<b-1?i[h+1]:void 0;if(c(u)&&c(G)&&u.height===G.height){let g=c(T)&&G.height===T.height,C=!c(A),y=!c(T),Y=c(U)&&u.height===U.height,Q=!c(F),J=!c(U);g?Y?(s(u.height,u.color,G.color),s(u.height,U.color,T.color)):Q?(a(u.height,G.color),s(u.height,u.color,T.color)):J?(s(u.height,u.color,G.color),a(u.height,T.color)):(s(u.height,u.color,G.color),s(u.height,u.color,T.color)):C?Y?(a(u.height,u.color),s(u.height,U.color,G.color)):J?(a(u.height,u.color),a(u.height,G.color)):(Q||a(u.height,u.color),s(u.height,u.color,G.color)):y?Y?(s(u.height,u.color,G.color),a(u.height,U.color)):Q?(a(u.height,G.color),a(u.height,u.color)):J?s(u.height,u.color,G.color):(s(u.height,u.color,G.color),a(u.height,u.color)):Y?(s(u.height,u.color,G.color),s(u.height,U.color,G.color)):Q?(a(u.height,G.color),s(u.height,u.color,G.color)):J?(s(u.height,u.color,G.color),a(u.height,G.color)):s(u.height,u.color,G.color),m+=Y?2:1,h+=g?2:1}else if(c(u)&&c(G)&&c(A)&&u.height<G.height){let g=okt(u.height,A,G,_9e);c(F)?c(U)?s(u.height,u.color,g):(s(u.height,u.color,g),a(u.height,g)):(a(u.height,g),s(u.height,u.color,g)),m++}else if(c(G)&&c(u)&&c(F)&&G.height<u.height){let g=okt(G.height,F,u,M9e);c(A)?c(T)?s(G.height,g,G.color):(s(G.height,g,G.color),a(G.height,g)):(a(G.height,g),s(G.height,g,G.color)),h++}else c(u)&&(!c(G)||u.height<G.height)?(c(G)&&!c(A)&&!c(U)?(a(u.height,u.color),a(u.height,sh._emptyColor),a(G.height,sh._emptyColor)):(!c(G)&&c(A)&&!c(F)&&(a(A.height,sh._emptyColor),a(u.height,sh._emptyColor)),a(u.height,u.color)),m++):c(G)&&(!c(u)||G.height<u.height)&&(a(G.height,G.color),h++)}}return akt(n)}function sh(t){let{scene:e,layers:n}=f(t,f.EMPTY_OBJECT),{context:i}=e,o=H9e(n),a=o.length,s,l,r;if(!sh._useFloatTexture(i)){l=Ue.UNSIGNED_BYTE,r=Ye.RGBA,s=new Uint8Array(a*4);for(let b=0;b<a;b++)Rt.packFloat(o[b].height,ikt),Rt.pack(ikt,s,b*4)}else{l=Ue.FLOAT,r=i.webgl2?Ye.RED:Ye.LUMINANCE,s=new Float32Array(a);for(let b=0;b<a;b++)s[b]=o[b].height}let m=hn.create({context:i,pixelFormat:r,pixelDatatype:l,source:{arrayBufferView:s,width:a,height:1},sampler:new Hn({wrapS:Vi.CLAMP_TO_EDGE,wrapT:Vi.CLAMP_TO_EDGE,minificationFilter:On.NEAREST,magnificationFilter:bo.NEAREST})}),h=new Uint8Array(a*4);for(let b=0;b<a;b++)o[b].color.toBytes(cD),h[b*4+0]=cD[0],h[b*4+1]=cD[1],h[b*4+2]=cD[2],h[b*4+3]=cD[3];let Z=hn.create({context:i,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,source:{arrayBufferView:h,width:a,height:1},sampler:new Hn({wrapS:Vi.CLAMP_TO_EDGE,wrapT:Vi.CLAMP_TO_EDGE,minificationFilter:On.LINEAR,magnificationFilter:bo.LINEAR})});return eo.fromType("ElevationBand",{heights:m,colors:Z})}sh._useFloatTexture=function(t){return t.floatingPointTexture};sh._maximumHeight=5906376425472;sh._minimumHeight=-5906376425472;sh._emptyColor=new v(0,0,0,0);var Wrt=sh;var _7o=R(W(),1);async function w9e(t,e){if(e=f(e,{}),e.cacheBytes=f(e.cacheBytes,1536*1024*1024),e.maximumCacheOverflowBytes=f(e.maximumCacheOverflowBytes,1024*1024*1024),e.enableCollision=f(e.enableCollision,!0),t=f(t,PS.defaultApiKey),!c(t))return P9e(e);let n,i=PS.getDefaultCredit();c(i)&&(n=[i]);let o=new te({url:`${PS.mapTilesApiEndpoint}3dtiles/root.json`,queryParameters:{key:t},credits:n});return Pr.fromUrl(o,e)}var skt={};async function P9e(t){let i=skt[2275207];c(i)||(i=gh.fromAssetId(2275207),skt[2275207]=i);let o=await i;return Pr.fromUrl(o,t)}var frt=w9e;var K7o=R(W(),1);async function v9e(t){let e=await Pr.fromIonAssetId(96188,t);t=f(t,f.EMPTY_OBJECT);let n=t.style;if(!c(n)){let i=f(t.defaultColor,v.WHITE).toCssColorString();n=new qS({color:`Boolean(\${feature['cesium#color']}) ? color(\${feature['cesium#color']}) : ${i}`})}return e.style=n,e}var Frt=v9e;var aqo=R(W(),1);function K9e(t){t=f(t,f.EMPTY_OBJECT);let e=[],n=t.geometry;(!c(n.attributes)||!c(n.primitiveType))&&(n=n.constructor.createGeometry(n));let i=n.attributes,o=L.clone(f(t.modelMatrix,L.IDENTITY)),a=f(t.length,1e4);if(c(i.normal)&&e.push(new $e({geometry:gi.createLineSegmentsForVectors(n,"normal",a),attributes:{color:new En(1,0,0,1)},modelMatrix:o})),c(i.tangent)&&e.push(new $e({geometry:gi.createLineSegmentsForVectors(n,"tangent",a),attributes:{color:new En(0,1,0,1)},modelMatrix:o})),c(i.bitangent)&&e.push(new $e({geometry:gi.createLineSegmentsForVectors(n,"bitangent",a),attributes:{color:new En(0,0,1,1)},modelMatrix:o})),e.length>0)return new Wi({asynchronous:!1,geometryInstances:e,appearance:new jn({flat:!0,translucent:!1})})}var Urt=K9e;var lqo=R(W(),1),Grt=`uniform sampler2D u_depthTexture; +`,t.splitDirection!==Jc.NONE&&(Et=bN.modifyFragmentShader(Et)),c(t._vertexShaderLoaded)&&(st=t._vertexShaderLoaded(st)),c(t._fragmentShaderLoaded)&&(Et=t._fragmentShaderLoaded(Et));let Qt=t._drawCommand;c(Qt.shaderProgram)&&Qt.shaderProgram.destroy(),Qt.shaderProgram=xn.fromCache({context:s,vertexShaderSource:st,fragmentShaderSource:Et,attributeLocations:dt});try{Qt.shaderProgram._bind()}catch{throw new Tt("Error generating style shader: this may be caused by a type mismatch, index out-of-bounds, or other syntax error.")}}function Z9e(t,e){if(t._decodingState===og.READY)return!1;if(t._decodingState===og.NEEDS_DECODE){let n=t._parsedContent,i=n.draco,o=$b.decodePointCloud(i,e);c(o)&&(t._decodingState=og.DECODING,o.then(function(a){t._decodingState=og.READY;let s=c(a.POSITION)?a.POSITION.array:void 0,l=c(a.RGB)?a.RGB.array:void 0,r=c(a.RGBA)?a.RGBA.array:void 0,d=c(a.NORMAL)?a.NORMAL.array:void 0,m=c(a.BATCH_ID)?a.BATCH_ID.array:void 0,h=c(s)&&c(a.POSITION.data.quantization),u=c(d)&&c(a.NORMAL.data.quantization);if(h){let U=a.POSITION.data.quantization,G=U.range;t._quantizedVolumeScale=p.fromElements(G,G,G),t._quantizedVolumeOffset=p.unpack(U.minValues),t._quantizedRange=(1<<U.quantizationBits)-1,t._isQuantizedDraco=!0}u&&(t._octEncodedRange=(1<<a.NORMAL.data.quantization.quantizationBits)-1,t._isOctEncodedDraco=!0);let R=n.styleableProperties,V=i.batchTableProperties;for(let U in V)if(V.hasOwnProperty(U)){let G=a[U];c(R)||(R={}),R[U]={typedArray:G.array,componentCount:G.data.componentsPerAttribute}}c(s)&&(n.positions={typedArray:s});let F=f(r,l);c(F)&&(n.colors={typedArray:F}),c(d)&&(n.normals={typedArray:d}),c(m)&&(n.batchIds={typedArray:m}),n.styleableProperties=R}).catch(function(a){t._decodingState=og.FAILED,t._error=a}))}return!0}var R9e=new bt,b9e=new p;oD.prototype.update=function(t){let e=t.context;if(c(this._error)){let d=this._error;throw this._error=void 0,d}if(Z9e(this,e))return;let i=!1,o=!L.equals(this._modelMatrix,this.modelMatrix);if(this._mode!==t.mode&&(this._mode=t.mode,o=!0),c(this._drawCommand)||(h9e(this,t),o=!0,i=!0,this._ready=!0,this._parsedContent=void 0),o){L.clone(this.modelMatrix,this._modelMatrix);let d=this._drawCommand.modelMatrix;if(L.clone(this._modelMatrix,d),c(this._rtcCenter)&&L.multiplyByTranslation(d,this._rtcCenter,d),c(this._quantizedVolumeOffset)&&L.multiplyByTranslation(d,this._quantizedVolumeOffset,d),t.mode!==Vt.SCENE3D){let h=t.mapProjection,u=L.getColumn(d,3,R9e);bt.equals(u,bt.UNIT_W)||Pe.basisTo2D(h,d,d)}let m=this._drawCommand.boundingVolume;if(Ft.clone(this._boundingSphere,m),this._cull){let h=m.center;L.multiplyByPoint(d,h,h);let u=L.getScale(d,b9e);m.radius*=p.maximumComponent(u)}}this.clippingPlanesDirty&&(this.clippingPlanesDirty=!1,i=!0),this._attenuation!==this.attenuation&&(this._attenuation=this.attenuation,i=!0),this.backFaceCulling!==this._backFaceCulling&&(this._backFaceCulling=this.backFaceCulling,i=!0),this.normalShading!==this._normalShading&&(this._normalShading=this.normalShading,i=!0),(this._style!==this.style||this.styleDirty)&&(this._style=this.style,this.styleDirty=!1,i=!0);let a=this.splitDirection!==Jc.NONE;this._splittingEnabled!==a&&(this._splittingEnabled=a,i=!0),i&&u9e(this,t,this._style),this._drawCommand.castShadows=Vi.castShadows(this.shadows),this._drawCommand.receiveShadows=Vi.receiveShadows(this.shadows);let s=this._highlightColor.alpha<1||this._constantColor.alpha<1||this._styleTranslucent;this._drawCommand.renderState=s?this._translucentRenderState:this._opaqueRenderState,this._drawCommand.pass=s?Pt.TRANSLUCENT:this._opaquePass;let l=t.commandList,r=t.passes;(r.render||r.pick)&&l.push(this._drawCommand)};oD.prototype.isDestroyed=function(){return!1};oD.prototype.destroy=function(){let t=this._drawCommand;return c(t)&&(t.vertexArray=t.vertexArray&&t.vertexArray.destroy(),t.shaderProgram=t.shaderProgram&&t.shaderProgram.destroy()),At(this)};var aD=oD;var n6o=b(W(),1);function Vp(){Ut.throwInstantiationError()}Vp.computeDefaultLevelZeroMaximumGeometricError=function(t){return t.ellipsoid.maximumRadius*2*Math.PI*.25/(65*t.getNumberOfXTilesAtLevel(0))};Object.defineProperties(Vp.prototype,{quadtree:{get:Ut.throwInstantiationError,set:Ut.throwInstantiationError},tilingScheme:{get:Ut.throwInstantiationError},errorEvent:{get:Ut.throwInstantiationError}});Vp.prototype.update=Ut.throwInstantiationError;Vp.prototype.beginUpdate=Ut.throwInstantiationError;Vp.prototype.endUpdate=Ut.throwInstantiationError;Vp.prototype.getLevelMaximumGeometricError=Ut.throwInstantiationError;Vp.prototype.loadTile=Ut.throwInstantiationError;Vp.prototype.computeTileVisibility=Ut.throwInstantiationError;Vp.prototype.showTileThisFrame=Ut.throwInstantiationError;Vp.prototype.computeDistanceToTile=Ut.throwInstantiationError;Vp.prototype.isDestroyed=Ut.throwInstantiationError;Vp.prototype.destroy=Ut.throwInstantiationError;var ort=Vp;var l6o=b(W(),1);function art(t){t=f(t,1),this._radius=f(t,1)}Object.defineProperties(art.prototype,{radius:{get:function(){return this._radius},set:function(t){this._radius=t}}});art.prototype.emit=function(t){let e=k.randomBetween(0,k.TWO_PI),n=k.randomBetween(0,k.PI),i=k.randomBetween(0,this._radius),o=i*Math.cos(e)*Math.sin(n),a=i*Math.sin(e)*Math.sin(n),s=i*Math.cos(n);t.position=p.fromElements(o,a,s,t.position),t.velocity=p.normalize(t.position,t.velocity)};var srt=art;var c6o=b(W(),1);function sD(){}sD.prototype.evaluate=function(t,e){Ut.throwInstantiationError()};sD.prototype.evaluateColor=function(t,e){Ut.throwInstantiationError()};sD.prototype.getShaderFunction=function(t,e,n,i){Ut.throwInstantiationError()};sD.prototype.getVariables=function(){Ut.throwInstantiationError()};var lrt=sD;var u6o=b(W(),1);function WN(t){this._ready=!1,this._provider=void 0,this._errorEvent=new It,this._readyEvent=new It,f9e(this,t)}Object.defineProperties(WN.prototype,{errorEvent:{get:function(){return this._errorEvent}},readyEvent:{get:function(){return this._readyEvent}},ready:{get:function(){return this._ready}},provider:{get:function(){return this._provider}}});WN.fromWorldTerrain=function(t){return new WN(KT(t))};WN.fromWorldBathymetry=function(t){return new WN(B5(t))};function W9e(t,e){t.numberOfListeners>0?t.raiseEvent(e):console.error(e)}async function f9e(t,e){let n;try{n=await Promise.resolve(e),t._provider=n,t._ready=!0,t._readyEvent.raiseEvent(n)}catch(i){W9e(t._errorEvent,i)}}var lD=WN;var b6o=b(W(),1);function fN(){}fN.prototype.boundingVolume=void 0;fN.prototype.boundingSphere=void 0;fN.prototype.distanceToCamera=function(t){Ut.throwInstantiationError()};fN.prototype.intersectPlane=function(t){Ut.throwInstantiationError()};fN.prototype.createDebugVolume=function(t){Ut.throwInstantiationError()};var rrt=fN;var S6o=b(W(),1);function rD(t){t=f(t,f.EMPTY_OBJECT),this._tilingScheme=c(t.tilingScheme)?t.tilingScheme:new Qo({ellipsoid:t.ellipsoid}),this._color=f(t.color,v.YELLOW),this._errorEvent=new It,this._tileWidth=f(t.tileWidth,256),this._tileHeight=f(t.tileHeight,256),this._defaultAlpha=void 0,this._defaultNightAlpha=void 0,this._defaultDayAlpha=void 0,this._defaultBrightness=void 0,this._defaultContrast=void 0,this._defaultHue=void 0,this._defaultSaturation=void 0,this._defaultGamma=void 0,this._defaultMinificationFilter=void 0,this._defaultMagnificationFilter=void 0}Object.defineProperties(rD.prototype,{proxy:{get:function(){}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){}},minimumLevel:{get:function(){}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){}},errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){}},hasAlphaChannel:{get:function(){return!0}}});rD.prototype.getTileCredits=function(t,e,n){};rD.prototype.requestImage=function(t,e,n,i){let o=document.createElement("canvas");o.width=256,o.height=256;let a=o.getContext("2d"),s=this._color.toCssColorString();return a.strokeStyle=s,a.lineWidth=2,a.strokeRect(1,1,255,255),a.font="bold 25px Arial",a.textAlign="center",a.fillStyle=s,a.fillText(`L: ${n}`,124,86),a.fillText(`X: ${t}`,124,136),a.fillText(`Y: ${e}`,124,186),Promise.resolve(o)};rD.prototype.pickFeatures=function(t,e,n,i,o){};var dD=rD;var E6o=b(W(),1);function drt(t){Ut.throwInstantiationError()}drt.prototype.isReady=Ut.throwInstantiationError;drt.prototype.shouldDiscardImage=Ut.throwInstantiationError;var crt=drt;var I6o=b(W(),1),F9e={START:0,LOADING:1,READY:2,UPSAMPLED_ONLY:3},mrt=Object.freeze(F9e);var v6o=b(W(),1);function sg(t){t=f(t,f.EMPTY_OBJECT),this.show=f(t.show,!0),this.modelMatrix=L.clone(f(t.modelMatrix,L.IDENTITY)),this.shadows=f(t.shadows,Vi.ENABLED),this.maximumMemoryUsage=f(t.maximumMemoryUsage,256),this.shading=new eR(t.shading),this.style=t.style,this.frameFailed=new It,this.frameChanged=new It,this._clock=t.clock,this._intervals=t.intervals,this._clippingPlanes=void 0,this.clippingPlanes=t.clippingPlanes,this._pointCloudEyeDomeLighting=new l0,this._loadTimestamp=void 0,this._clippingPlanesState=0,this._styleDirty=!1,this._pickId=void 0,this._totalMemoryUsageInBytes=0,this._frames=[],this._previousInterval=void 0,this._nextInterval=void 0,this._lastRenderedFrame=void 0,this._clockMultiplier=0,this._runningSum=0,this._runningLength=0,this._runningIndex=0,this._runningSamples=new Array(5).fill(0),this._runningAverage=0}Object.defineProperties(sg.prototype,{clippingPlanes:{get:function(){return this._clippingPlanes},set:function(t){Ml.setOwner(t,this,"_clippingPlanes")}},totalMemoryUsageInBytes:{get:function(){return this._totalMemoryUsageInBytes}},boundingSphere:{get:function(){if(c(this._lastRenderedFrame))return this._lastRenderedFrame.pointCloud.boundingSphere}}});function U9e(t){return`uniform vec4 czm_pickColor; +${t}`}function G9e(t){return function(e){return ze(e,{czm_pickColor:function(){return t._pickId.color}})}}function A9e(){return"czm_pickColor"}sg.prototype.makeStyleDirty=function(){this._styleDirty=!0};sg.prototype._getAverageLoadTime=function(){return this._runningLength===0?.05:this._runningAverage};var S9e=new rt;function prt(t){let e=t._clock,n=e.canAnimate&&e.shouldAnimate,i=e.multiplier;return n?i:0}function ag(t,e){return t._intervals.indexOf(e.start)}function T9e(t,e){let n=t._intervals,i=t._clock,o=prt(t);if(o===0)return;let a=t._getAverageLoadTime(),s=rt.addSeconds(i.currentTime,a*o,S9e),l=n.indexOf(s),r=ag(t,e);return l===r&&(o>=0?++l:--l),n.get(l)}function g9e(t){let e=t._intervals,i=t._clock.currentTime,o=e.indexOf(i);return e.get(o)}function E9e(t,e,n){let i=prt(t),o=ag(t,e),a=ag(t,n);return i>=0?o>=a:o<=a}function t2t(t,e){return function(n){let i=c(n.message)?n.message:n.toString();t.frameFailed.numberOfListeners>0?t.frameFailed.raiseEvent({uri:e,message:i}):(console.log(`A frame failed to load: ${e}`),console.log(`Error: ${i}`))}}function C9e(t,e,n){let i=ag(t,e),o=t._frames,a=o[i];if(!c(a)){let s=e.data.transform,l=c(s)?L.fromArray(s):void 0,r=e.data.uri;a={pointCloud:void 0,transform:l,timestamp:Oi(),sequential:!0,ready:!1,touchedFrameNumber:n.frameNumber,uri:r},o[i]=a,te.fetchArrayBuffer({url:r}).then(function(d){a.pointCloud=new aD({arrayBuffer:d,cull:!0,fragmentShaderLoaded:U9e,uniformMapLoaded:G9e(t),pickIdLoaded:A9e})}).catch(t2t(t,r))}return a}function I9e(t,e){t._runningSum+=e,t._runningSum-=t._runningSamples[t._runningIndex],t._runningSamples[t._runningIndex]=e,t._runningLength=Math.min(t._runningLength+1,t._runningSamples.length),t._runningIndex=(t._runningIndex+1)%t._runningSamples.length,t._runningAverage=t._runningSum/t._runningLength}function N9e(t,e,n,i){e.touchedFrameNumber<i.frameNumber-1&&(e.sequential=!1);let o=e.pointCloud;if(c(o)&&!e.ready){let a=i.commandList,s=a.length;if(e2t(t,e,n,i),o.ready&&(e.ready=!0,t._totalMemoryUsageInBytes+=o.geometryByteLength,a.length=s,e.sequential)){let l=(Oi()-e.timestamp)/1e3;I9e(t,l)}}e.touchedFrameNumber=i.frameNumber}var y9e=new L;function B9e(t,e){let n=t.shading;return c(n)&&c(n.baseResolution)?n.baseResolution:c(e.boundingSphere)?k.cbrt(e.boundingSphere.volume()/e.pointsLength):0}function Q9e(t){let e=t.shading;return c(e)&&c(e.maximumAttenuation)?e.maximumAttenuation:10}var k9e=new eR;function e2t(t,e,n,i){let o=f(t.shading,k9e),a=e.pointCloud,s=f(e.transform,L.IDENTITY);a.modelMatrix=L.multiplyTransformation(t.modelMatrix,s,y9e),a.style=t.style,a.time=n.timeSinceLoad,a.shadows=t.shadows,a.clippingPlanes=t._clippingPlanes,a.isClipped=n.isClipped,a.attenuation=o.attenuation,a.backFaceCulling=o.backFaceCulling,a.normalShading=o.normalShading,a.geometricError=B9e(t,a),a.geometricErrorScale=o.geometricErrorScale,a.maximumAttenuation=Q9e(t);try{a.update(i)}catch(l){t2t(t,e.uri)(l)}e.touchedFrameNumber=i.frameNumber}function hrt(t,e,n,i){let o=C9e(t,e,i);N9e(t,o,n,i)}function Y9e(t){return function(e){return e.touchedFrameNumber<t.frameNumber}}function n2t(t,e){let n=t._frames,i=n.length;for(let o=0;o<i;++o){let a=n[o];if(c(a)&&(!c(e)||e(a))){let s=a.pointCloud;a.ready&&(t._totalMemoryUsageInBytes-=s.geometryByteLength),c(s)&&s.destroy(),a===t._lastRenderedFrame&&(t._lastRenderedFrame=void 0),n[o]=void 0}}}function x9e(t,e){let n=ag(t,e),i=t._frames[n];if(c(i)&&i.ready)return i}function $kt(t,e,n,i,o){return c(n)?n.ready?!0:(hrt(t,e,i,o),n.ready):!1}function X9e(t,e,n,i,o){let a,s,l,r=t._intervals,d=t._frames,m=ag(t,n),h=ag(t,e);if(m>=h){for(a=m;a>=h;--a)if(s=r.get(a),l=d[a],$kt(t,s,l,i,o))return s}else for(a=m;a<=h;++a)if(s=r.get(a),l=d[a],$kt(t,s,l,i,o))return s;return e}function J9e(t,e,n){let i=t._frames,o=i.length;for(let a=0;a<o;++a){let s=i[a];c(s)&&c(s.pointCloud)&&(s.pointCloud.clippingPlanesDirty=e,s.pointCloud.styleDirty=n)}}var FN={timeSinceLoad:0,isClipped:!1,clippingPlanesDirty:!1};sg.prototype.update=function(t){if(t.mode===Vt.MORPHING||!this.show)return;c(this._pickId)||(this._pickId=t.context.createPickId({primitive:this})),c(this._loadTimestamp)||(this._loadTimestamp=rt.clone(t.time));let e=Math.max(rt.secondsDifference(t.time,this._loadTimestamp)*1e3,0),n=this._clippingPlanes,i=0,o=!1,a=c(n)&&n.enabled;a&&(n.update(t),i=n.clippingPlanesState),this._clippingPlanesState!==i&&(this._clippingPlanesState=i,o=!0);let s=this._styleDirty;this._styleDirty=!1,(o||s)&&J9e(this,o,s),FN.timeSinceLoad=e,FN.isClipped=a;let l=this.shading,r=this._pointCloudEyeDomeLighting,d=t.commandList,m=d.length,h=this._previousInterval,u=this._nextInterval,R=g9e(this);if(!c(R))return;let V=!1,F=prt(this),U=F===0;F!==this._clockMultiplier&&(V=!0,this._clockMultiplier=F),(!c(h)||U)&&(h=R),(!c(u)||V||E9e(this,R,u))&&(u=T9e(this,R)),h=X9e(this,h,R,FN,t);let G=x9e(this,h);c(G)||(hrt(this,h,FN,t),G=this._lastRenderedFrame),c(G)&&e2t(this,G,FN,t),c(u)&&hrt(this,u,FN,t);let A=this;c(G)&&!c(this._lastRenderedFrame)&&t.afterRender.push(function(){return!0}),c(G)&&G!==this._lastRenderedFrame&&A.frameChanged.numberOfListeners>0&&t.afterRender.push(function(){return A.frameChanged.raiseEvent(A),!0}),this._previousInterval=h,this._nextInterval=u,this._lastRenderedFrame=G;let S=this._totalMemoryUsageInBytes,g=this.maximumMemoryUsage*1024*1024;S>g&&n2t(this,Y9e(t));let y=d.length-m;c(l)&&l.attenuation&&l.eyeDomeLighting&&y>0&&r.update(t,m,l,this.boundingSphere)};sg.prototype.isDestroyed=function(){return!1};sg.prototype.destroy=function(){return n2t(this),this._clippingPlanes=this._clippingPlanes&&this._clippingPlanes.destroy(),this._pickId=this._pickId&&this._pickId.destroy(),At(this)};var UN=sg;var s7o=b(W(),1);function a4(t,e){this.show=!0,c(t)||(t=new Fe),this.rectangle=Fe.clone(t),c(e)||(e=eo.fromType(eo.ColorType,{color:new v(1,1,1,1)})),this.material=e,this._material=void 0,this._overlayCommand=void 0,this._rs=void 0}a4.prototype.update=function(t){if(!this.show)return;let e=this._rs;if((!c(e)||!Fe.equals(e.viewport,this.rectangle))&&(this._rs=he.fromCache({blending:Pn.ALPHA_BLEND,viewport:this.rectangle})),t.passes.render){let i=t.context;if(this._material!==this.material||!c(this._overlayCommand)){this._material=this.material,c(this._overlayCommand)&&this._overlayCommand.shaderProgram.destroy();let o=new Ze({sources:[this._material.shaderSource,A5]});this._overlayCommand=i.createViewportQuadCommand(o,{renderState:this._rs,uniformMap:this._material._uniforms,owner:this}),this._overlayCommand.pass=Pt.OVERLAY}this._material.update(i),this._overlayCommand.renderState=this._rs,this._overlayCommand.uniformMap=this._material._uniforms,t.commandList.push(this._overlayCommand)}};a4.prototype.isDestroyed=function(){return!1};a4.prototype.destroy=function(){return c(this._overlayCommand)&&(this._overlayCommand.shaderProgram=this._overlayCommand.shaderProgram&&this._overlayCommand.shaderProgram.destroy()),At(this)};var Vrt=a4;var d7o=b(W(),1);function urt(){Ut.throwInstantiationError()}Object.defineProperties(urt.prototype,{globalTransform:{get:Ut.throwInstantiationError},shapeTransform:{get:Ut.throwInstantiationError},shape:{get:Ut.throwInstantiationError},minBounds:{get:Ut.throwInstantiationError},maxBounds:{get:Ut.throwInstantiationError},dimensions:{get:Ut.throwInstantiationError},paddingBefore:{get:Ut.throwInstantiationError},paddingAfter:{get:Ut.throwInstantiationError},names:{get:Ut.throwInstantiationError},types:{get:Ut.throwInstantiationError},componentTypes:{get:Ut.throwInstantiationError},minimumValues:{get:Ut.throwInstantiationError},maximumValues:{get:Ut.throwInstantiationError},maximumTileCount:{get:Ut.throwInstantiationError},keyframeCount:{get:Ut.throwInstantiationError},timeIntervalCollection:{get:Ut.throwInstantiationError}});urt.prototype.requestData=Ut.throwInstantiationError;var Zrt=urt;var h7o=b(W(),1);function lg(){Ut.throwInstantiationError()}Object.defineProperties(lg.prototype,{orientedBoundingBox:{get:Ut.throwInstantiationError},boundingSphere:{get:Ut.throwInstantiationError},boundTransform:{get:Ut.throwInstantiationError},shapeTransform:{get:Ut.throwInstantiationError},shaderUniforms:{get:Ut.throwInstantiationError},shaderDefines:{get:Ut.throwInstantiationError},shaderMaximumIntersectionsLength:{get:Ut.throwInstantiationError}});lg.prototype.update=Ut.throwInstantiationError;lg.prototype.computeOrientedBoundingBoxForTile=Ut.throwInstantiationError;lg.prototype.computeOrientedBoundingBoxForSample=Ut.throwInstantiationError;lg.DefaultMinBounds=Ut.throwInstantiationError;lg.DefaultMaxBounds=Ut.throwInstantiationError;var Rrt=lg;var b7o=b(W(),1);async function brt(t,e){let n=e.terrainProvider,i=e.mapProjection,o=i.ellipsoid,a,s=e.camera.getRectangleCameraCoordinates(t);if(e.mode===Vt.SCENE3D?a=o.cartesianToCartographic(s):a=i.unproject(s),!c(n))return a;let l=n.availability;if(!c(l)||e.mode===Vt.SCENE2D)return a;let r=[Gt.center(t),Gt.southeast(t),Gt.southwest(t),Gt.northeast(t),Gt.northwest(t)],d=await brt._sampleTerrainMostDetailed(n,r),m=!1,h=d.reduce(function(R,V){return c(V.height)?(m=!0,Math.max(V.height,R)):R},-Number.MAX_VALUE),u=a;return m&&(u.height+=h),u}brt._sampleTerrainMostDetailed=zT;var rg=brt;var Q7o=b(W(),1);var L9e=new v,M9e=new v,_9e=new v,D9e=new v,i2t=new bt,cD=new Uint8Array(4);function o2t(t,e,n,i){let o=e.height===n.height?0:(t-e.height)/(n.height-e.height);return v.lerp(e.color,n.color,o,i)}function s4(t,e){return{height:t,color:v.clone(e)}}function a2t(t){return t=t.filter(function(e,n,i){let o=n>0,a=n<i.length-1,s=o?e.height===i[n-1].height:!0,l=a?e.height===i[n+1].height:!0;return!s||!l}),t=t.filter(function(e,n,i){let o=n>0,a=n<i.length-1,s=o?v.equals(e.color,i[n-1].color):!1,l=a?v.equals(e.color,i[n+1].color):!1;return!s||!l}),t=t.filter(function(e,n,i){let o=n>0,a=o?v.equals(e.color,i[n-1].color):!1,s=o?e.height===i[n-1].height:!0;return!a||!s}),t}function O9e(t){let e,n,i=[],o=t.length;for(e=0;e<o;e++){let a=t[e],s=a.entries,l=s.length,r=[];for(n=0;n<l;n++){let R=s[n],V=k.clamp(R.height,sh._minimumHeight,sh._maximumHeight),F=v.clone(R.color,L9e);F.red*=F.alpha,F.green*=F.alpha,F.blue*=F.alpha,r.push(s4(V,F))}let d=!0,m=!0;for(n=0;n<l-1;n++){let R=r[n+0],V=r[n+1];d=d&&R.height<=V.height,m=m&&R.height>=V.height}m?r=r.reverse():d||uW(r,function(R,V){return k.sign(R.height-V.height)});let h=f(a.extendDownwards,!1),u=f(a.extendUpwards,!1);r.length===1&&!h&&!u&&(h=!0,u=!0),h&&r.splice(0,0,s4(sh._minimumHeight,r[0].color)),u&&r.splice(r.length,0,s4(sh._maximumHeight,r[r.length-1].color)),r=a2t(r),i.push(r)}return i}function H9e(t){let e=O9e(t),n=[],i=[],o;function a(d,m){n.push(s4(d,m))}function s(d,m,h){let u=v.multiplyByScalar(h,1-m.alpha,D9e);u=v.add(u,m,u),a(d,u)}let l=e.length;for(o=0;o<l;o++){let d=e[o],m=0,h=0;i=n,n=[];let u=d.length,R=i.length;for(;m<u||h<R;){let V=m<u?d[m]:void 0,F=m>0?d[m-1]:void 0,U=m<u-1?d[m+1]:void 0,G=h<R?i[h]:void 0,A=h>0?i[h-1]:void 0,S=h<R-1?i[h+1]:void 0;if(c(V)&&c(G)&&V.height===G.height){let g=c(S)&&G.height===S.height,C=!c(A),y=!c(S),Y=c(U)&&V.height===U.height,Q=!c(F),J=!c(U);g?Y?(s(V.height,V.color,G.color),s(V.height,U.color,S.color)):Q?(a(V.height,G.color),s(V.height,V.color,S.color)):J?(s(V.height,V.color,G.color),a(V.height,S.color)):(s(V.height,V.color,G.color),s(V.height,V.color,S.color)):C?Y?(a(V.height,V.color),s(V.height,U.color,G.color)):J?(a(V.height,V.color),a(V.height,G.color)):(Q||a(V.height,V.color),s(V.height,V.color,G.color)):y?Y?(s(V.height,V.color,G.color),a(V.height,U.color)):Q?(a(V.height,G.color),a(V.height,V.color)):J?s(V.height,V.color,G.color):(s(V.height,V.color,G.color),a(V.height,V.color)):Y?(s(V.height,V.color,G.color),s(V.height,U.color,G.color)):Q?(a(V.height,G.color),s(V.height,V.color,G.color)):J?(s(V.height,V.color,G.color),a(V.height,G.color)):s(V.height,V.color,G.color),m+=Y?2:1,h+=g?2:1}else if(c(V)&&c(G)&&c(A)&&V.height<G.height){let g=o2t(V.height,A,G,_9e);c(F)?c(U)?s(V.height,V.color,g):(s(V.height,V.color,g),a(V.height,g)):(a(V.height,g),s(V.height,V.color,g)),m++}else if(c(G)&&c(V)&&c(F)&&G.height<V.height){let g=o2t(G.height,F,V,M9e);c(A)?c(S)?s(G.height,g,G.color):(s(G.height,g,G.color),a(G.height,g)):(a(G.height,g),s(G.height,g,G.color)),h++}else c(V)&&(!c(G)||V.height<G.height)?(c(G)&&!c(A)&&!c(U)?(a(V.height,V.color),a(V.height,sh._emptyColor),a(G.height,sh._emptyColor)):(!c(G)&&c(A)&&!c(F)&&(a(A.height,sh._emptyColor),a(V.height,sh._emptyColor)),a(V.height,V.color)),m++):c(G)&&(!c(V)||G.height<V.height)&&(a(G.height,G.color),h++)}}return a2t(n)}function sh(t){let{scene:e,layers:n}=f(t,f.EMPTY_OBJECT),{context:i}=e,o=H9e(n),a=o.length,s,l,r;if(!sh._useFloatTexture(i)){l=Ue.UNSIGNED_BYTE,r=Ye.RGBA,s=new Uint8Array(a*4);for(let R=0;R<a;R++)bt.packFloat(o[R].height,i2t),bt.pack(i2t,s,R*4)}else{l=Ue.FLOAT,r=i.webgl2?Ye.RED:Ye.LUMINANCE,s=new Float32Array(a);for(let R=0;R<a;R++)s[R]=o[R].height}let m=hn.create({context:i,pixelFormat:r,pixelDatatype:l,source:{arrayBufferView:s,width:a,height:1},sampler:new Hn({wrapS:Zi.CLAMP_TO_EDGE,wrapT:Zi.CLAMP_TO_EDGE,minificationFilter:On.NEAREST,magnificationFilter:Ro.NEAREST})}),h=new Uint8Array(a*4);for(let R=0;R<a;R++)o[R].color.toBytes(cD),h[R*4+0]=cD[0],h[R*4+1]=cD[1],h[R*4+2]=cD[2],h[R*4+3]=cD[3];let u=hn.create({context:i,pixelFormat:Ye.RGBA,pixelDatatype:Ue.UNSIGNED_BYTE,source:{arrayBufferView:h,width:a,height:1},sampler:new Hn({wrapS:Zi.CLAMP_TO_EDGE,wrapT:Zi.CLAMP_TO_EDGE,minificationFilter:On.LINEAR,magnificationFilter:Ro.LINEAR})});return eo.fromType("ElevationBand",{heights:m,colors:u})}sh._useFloatTexture=function(t){return t.floatingPointTexture};sh._maximumHeight=5906376425472;sh._minimumHeight=-5906376425472;sh._emptyColor=new v(0,0,0,0);var Wrt=sh;var _7o=b(W(),1);async function w9e(t,e){if(e=f(e,{}),e.cacheBytes=f(e.cacheBytes,1536*1024*1024),e.maximumCacheOverflowBytes=f(e.maximumCacheOverflowBytes,1024*1024*1024),e.enableCollision=f(e.enableCollision,!0),t=f(t,PT.defaultApiKey),!c(t))return P9e(e);let n,i=PT.getDefaultCredit();c(i)&&(n=[i]);let o=new te({url:`${PT.mapTilesApiEndpoint}3dtiles/root.json`,queryParameters:{key:t},credits:n});return Pr.fromUrl(o,e)}var s2t={};async function P9e(t){let i=s2t[2275207];c(i)||(i=gh.fromAssetId(2275207),s2t[2275207]=i);let o=await i;return Pr.fromUrl(o,t)}var frt=w9e;var K7o=b(W(),1);async function v9e(t){let e=await Pr.fromIonAssetId(96188,t);t=f(t,f.EMPTY_OBJECT);let n=t.style;if(!c(n)){let i=f(t.defaultColor,v.WHITE).toCssColorString();n=new qT({color:`Boolean(\${feature['cesium#color']}) ? color(\${feature['cesium#color']}) : ${i}`})}return e.style=n,e}var Frt=v9e;var aqo=b(W(),1);function K9e(t){t=f(t,f.EMPTY_OBJECT);let e=[],n=t.geometry;(!c(n.attributes)||!c(n.primitiveType))&&(n=n.constructor.createGeometry(n));let i=n.attributes,o=L.clone(f(t.modelMatrix,L.IDENTITY)),a=f(t.length,1e4);if(c(i.normal)&&e.push(new $e({geometry:gi.createLineSegmentsForVectors(n,"normal",a),attributes:{color:new En(1,0,0,1)},modelMatrix:o})),c(i.tangent)&&e.push(new $e({geometry:gi.createLineSegmentsForVectors(n,"tangent",a),attributes:{color:new En(0,1,0,1)},modelMatrix:o})),c(i.bitangent)&&e.push(new $e({geometry:gi.createLineSegmentsForVectors(n,"bitangent",a),attributes:{color:new En(0,0,1,1)},modelMatrix:o})),e.length>0)return new Wi({asynchronous:!1,geometryInstances:e,appearance:new jn({flat:!0,translucent:!1})})}var Urt=K9e;var lqo=b(W(),1),Grt=`uniform sampler2D u_depthTexture; in vec2 v_textureCoordinates; @@ -15490,33 +15490,33 @@ void main() float scale = pow(z_ndc * 0.5 + 0.5, 8.0); out_FragColor = vec4(mix(vec3(0.0), vec3(1.0), scale), 1.0); } -`;var Zqo=R(W(),1);function z9e(t){t=f(t,f.EMPTY_OBJECT),this.typedArray=t.typedArray,this.width=t.width,this.height=t.height,this.pixelFormat=f(t.pixelFormat,Ye.RGBA),this.pixelDatatype=f(t.pixelDatatype,Ue.UNSIGNED_BYTE);let e=t.url;typeof e=="string"&&(e=te.createIfNeeded(e)),this.resource=e;let i=f(t.repeat,!0)?Vi.REPEAT:Vi.CLAMP_TO_EDGE;this.sampler=new Hn({wrapS:i,wrapT:i,minificationFilter:t.minificationFilter,magnificationFilter:t.magnificationFilter,maximumAnisotropy:t.maximumAnisotropy})}var Art=z9e;var bqo=R(W(),1),j9e={FLOAT:"float",VEC2:"vec2",VEC3:"vec3",VEC4:"vec4",MAT2:"mat2",MAT3:"mat2",MAT4:"mat4"},Trt=Object.freeze(j9e);var fqo=R(W(),1);function q9e(t){async function e({data:i}){let o=[],a={id:i.id,result:void 0,error:void 0};self.CESIUM_BASE_URL=i.baseUrl;try{let s=await t(i.parameters,o);a.result=s}catch(s){s instanceof Error?a.error={name:s.name,message:s.message,stack:s.stack}:a.error=s}i.canTransferArrayBuffer||(o.length=0);try{postMessage(a,o)}catch(s){a.result=void 0,a.error=`postMessage failed with error: ${Qb(s)} - with responseMessage: ${JSON.stringify(a)}`,postMessage(a)}}function n(i){postMessage({id:i.data?.id,error:`postMessage failed with error: ${JSON.stringify(i)}`})}return self.onmessage=e,self.onmessageerror=n,self}var Srt=q9e;globalThis.CESIUM_VERSION="1.116";var STa=R(W(),1);var HWa=R(W(),1);var MWa=R(W(),1);var yWa=R(W(),1),mD;typeof ko<"u"&&(mD=ko);(function(){/*! +`;var uqo=b(W(),1);function z9e(t){t=f(t,f.EMPTY_OBJECT),this.typedArray=t.typedArray,this.width=t.width,this.height=t.height,this.pixelFormat=f(t.pixelFormat,Ye.RGBA),this.pixelDatatype=f(t.pixelDatatype,Ue.UNSIGNED_BYTE);let e=t.url;typeof e=="string"&&(e=te.createIfNeeded(e)),this.resource=e;let i=f(t.repeat,!0)?Zi.REPEAT:Zi.CLAMP_TO_EDGE;this.sampler=new Hn({wrapS:i,wrapT:i,minificationFilter:t.minificationFilter,magnificationFilter:t.magnificationFilter,maximumAnisotropy:t.maximumAnisotropy})}var Art=z9e;var Rqo=b(W(),1),j9e={FLOAT:"float",VEC2:"vec2",VEC3:"vec3",VEC4:"vec4",MAT2:"mat2",MAT3:"mat2",MAT4:"mat4"},Srt=Object.freeze(j9e);var fqo=b(W(),1);function q9e(t){async function e({data:i}){let o=[],a={id:i.id,result:void 0,error:void 0};self.CESIUM_BASE_URL=i.baseUrl;try{let s=await t(i.parameters,o);a.result=s}catch(s){s instanceof Error?a.error={name:s.name,message:s.message,stack:s.stack}:a.error=s}i.canTransferArrayBuffer||(o.length=0);try{postMessage(a,o)}catch(s){a.result=void 0,a.error=`postMessage failed with error: ${QR(s)} + with responseMessage: ${JSON.stringify(a)}`,postMessage(a)}}function n(i){postMessage({id:i.data?.id,error:`postMessage failed with error: ${JSON.stringify(i)}`})}return self.onmessage=e,self.onmessageerror=n,self}var Trt=q9e;globalThis.CESIUM_VERSION="1.116";var TSa=b(W(),1);var HWa=b(W(),1);var MWa=b(W(),1);var yWa=b(W(),1),mD;typeof ko<"u"&&(mD=ko);(function(){/*! * Knockout JavaScript library v3.5.1 * (c) The Knockout.js team - http://knockoutjs.com/ * License: MIT (http://www.opensource.org/licenses/mit-license.php) - */(function(){(function(t){var e=this||(0,eval)("this"),n=e.document,i=e.navigator,o=e.jQuery,a=e.JSON;o||typeof jQuery>"u"||(o=jQuery),function(s){s(e.ko={})}(function(s,l){function r(V,E){return V===null||typeof V in F?V===E:!1}function d(V,E){var I;return function(){I||(I=u.a.setTimeout(function(){I=t,V()},E))}}function m(V,E){var I;return function(){clearTimeout(I),I=u.a.setTimeout(V,E)}}function h(V,E){E&&E!=="change"?E==="beforeChange"?this.pc(V):this.gb(V,E):this.qc(V)}function Z(V,E){E!==null&&E.s&&E.s()}function b(V,E){var I=this.qd,B=I[g];B.ra||(this.Qb&&this.mb[E]?(I.uc(E,V,this.mb[E]),this.mb[E]=null,--this.Qb):B.I[E]||I.uc(E,V,B.J?{da:V}:I.$c(V)),V.Ja&&V.gd())}var u=typeof s<"u"?s:{};u.b=function(V,E){for(var I=V.split("."),B=u,X=0;X<I.length-1;X++)B=B[I[X]];B[I[I.length-1]]=E},u.L=function(V,E,I){V[E]=I},u.version="3.5.1",u.b("version",u.version),u.options={deferUpdates:!1,useOnlyNativeEvents:!1,foreachHidesDestroyed:!1},u.a=function(){function V(q,at){for(var st in q)X.call(q,st)&&at(st,q[st])}function E(q,at){if(at)for(var st in at)X.call(at,st)&&(q[st]=at[st]);return q}function I(q,at){return q.__proto__=at,q}function B(q,at,st,Et){var Qt=q[at].match($)||[];u.a.D(st.match($),function(Wt){u.a.Na(Qt,Wt,Et)}),q[at]=Qt.join(" ")}var X=Object.prototype.hasOwnProperty,_={__proto__:[]}instanceof Array,P=typeof Symbol=="function",w={},z={};w[i&&/Firefox\/2/i.test(i.userAgent)?"KeyboardEvent":"UIEvents"]=["keyup","keydown","keypress"],w.MouseEvents="click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave".split(" "),V(w,function(q,at){if(at.length)for(var st=0,Et=at.length;st<Et;st++)z[at[st]]=q});var H={propertychange:!0},nt=n&&function(){for(var q=3,at=n.createElement("div"),st=at.getElementsByTagName("i");at.innerHTML="<!--[if gt IE "+ ++q+"]><i></i><![endif]-->",st[0];);return 4<q?q:t}(),$=/\S+/g,dt;return{Jc:["authenticity_token",/^__RequestVerificationToken(_.*)?$/],D:function(q,at,st){for(var Et=0,Qt=q.length;Et<Qt;Et++)at.call(st,q[Et],Et,q)},A:typeof Array.prototype.indexOf=="function"?function(q,at){return Array.prototype.indexOf.call(q,at)}:function(q,at){for(var st=0,Et=q.length;st<Et;st++)if(q[st]===at)return st;return-1},Lb:function(q,at,st){for(var Et=0,Qt=q.length;Et<Qt;Et++)if(at.call(st,q[Et],Et,q))return q[Et];return t},Pa:function(q,at){var st=u.a.A(q,at);0<st?q.splice(st,1):st===0&&q.shift()},wc:function(q){var at=[];return q&&u.a.D(q,function(st){0>u.a.A(at,st)&&at.push(st)}),at},Mb:function(q,at,st){var Et=[];if(q)for(var Qt=0,Wt=q.length;Qt<Wt;Qt++)Et.push(at.call(st,q[Qt],Qt));return Et},jb:function(q,at,st){var Et=[];if(q)for(var Qt=0,Wt=q.length;Qt<Wt;Qt++)at.call(st,q[Qt],Qt)&&Et.push(q[Qt]);return Et},Nb:function(q,at){if(at instanceof Array)q.push.apply(q,at);else for(var st=0,Et=at.length;st<Et;st++)q.push(at[st]);return q},Na:function(q,at,st){var Et=u.a.A(u.a.bc(q),at);0>Et?st&&q.push(at):st||q.splice(Et,1)},Ba:_,extend:E,setPrototypeOf:I,Ab:_?I:E,P:V,Ga:function(q,at,st){if(!q)return q;var Et={},Qt;for(Qt in q)X.call(q,Qt)&&(Et[Qt]=at.call(st,q[Qt],Qt,q));return Et},Tb:function(q){for(;q.firstChild;)u.removeNode(q.firstChild)},Yb:function(q){q=u.a.la(q);for(var at=(q[0]&&q[0].ownerDocument||n).createElement("div"),st=0,Et=q.length;st<Et;st++)at.appendChild(u.oa(q[st]));return at},Ca:function(q,at){for(var st=0,Et=q.length,Qt=[];st<Et;st++){var Wt=q[st].cloneNode(!0);Qt.push(at?u.oa(Wt):Wt)}return Qt},va:function(q,at){if(u.a.Tb(q),at)for(var st=0,Et=at.length;st<Et;st++)q.appendChild(at[st])},Xc:function(q,at){var st=q.nodeType?[q]:q;if(0<st.length){for(var Et=st[0],Qt=Et.parentNode,Wt=0,Nt=at.length;Wt<Nt;Wt++)Qt.insertBefore(at[Wt],Et);for(Wt=0,Nt=st.length;Wt<Nt;Wt++)u.removeNode(st[Wt])}},Ua:function(q,at){if(q.length){for(at=at.nodeType===8&&at.parentNode||at;q.length&&q[0].parentNode!==at;)q.splice(0,1);for(;1<q.length&&q[q.length-1].parentNode!==at;)q.length--;if(1<q.length){var st=q[0],Et=q[q.length-1];for(q.length=0;st!==Et;)q.push(st),st=st.nextSibling;q.push(Et)}}return q},Zc:function(q,at){7>nt?q.setAttribute("selected",at):q.selected=at},Db:function(q){return q===null||q===t?"":q.trim?q.trim():q.toString().replace(/^[\s\xa0]+|[\s\xa0]+$/g,"")},Ud:function(q,at){return q=q||"",at.length>q.length?!1:q.substring(0,at.length)===at},vd:function(q,at){if(q===at)return!0;if(q.nodeType===11)return!1;if(at.contains)return at.contains(q.nodeType!==1?q.parentNode:q);if(at.compareDocumentPosition)return(at.compareDocumentPosition(q)&16)==16;for(;q&&q!=at;)q=q.parentNode;return!!q},Sb:function(q){return u.a.vd(q,q.ownerDocument.documentElement)},kd:function(q){return!!u.a.Lb(q,u.a.Sb)},R:function(q){return q&&q.tagName&&q.tagName.toLowerCase()},Ac:function(q){return u.onError?function(){try{return q.apply(this,arguments)}catch(at){throw u.onError&&u.onError(at),at}}:q},setTimeout:function(q,at){return setTimeout(u.a.Ac(q),at)},Gc:function(q){setTimeout(function(){throw u.onError&&u.onError(q),q},0)},B:function(q,at,st){var Et=u.a.Ac(st);if(st=H[at],u.options.useOnlyNativeEvents||st||!o)if(st||typeof q.addEventListener!="function")if(typeof q.attachEvent<"u"){var Qt=function(Nt){Et.call(q,Nt)},Wt="on"+at;q.attachEvent(Wt,Qt),u.a.K.za(q,function(){q.detachEvent(Wt,Qt)})}else throw Error("Browser doesn't support addEventListener or attachEvent");else q.addEventListener(at,Et,!1);else dt||(dt=typeof o(q).on=="function"?"on":"bind"),o(q)[dt](at,Et)},Fb:function(q,at){if(!q||!q.nodeType)throw Error("element must be a DOM node when calling triggerEvent");var st;if(u.a.R(q)==="input"&&q.type&&at.toLowerCase()=="click"?(st=q.type,st=st=="checkbox"||st=="radio"):st=!1,u.options.useOnlyNativeEvents||!o||st)if(typeof n.createEvent=="function")if(typeof q.dispatchEvent=="function")st=n.createEvent(z[at]||"HTMLEvents"),st.initEvent(at,!0,!0,e,0,0,0,0,0,!1,!1,!1,!1,0,q),q.dispatchEvent(st);else throw Error("The supplied element doesn't support dispatchEvent");else if(st&&q.click)q.click();else if(typeof q.fireEvent<"u")q.fireEvent("on"+at);else throw Error("Browser doesn't support triggering events");else o(q).trigger(at)},f:function(q){return u.O(q)?q():q},bc:function(q){return u.O(q)?q.v():q},Eb:function(q,at,st){var Et;at&&(typeof q.classList=="object"?(Et=q.classList[st?"add":"remove"],u.a.D(at.match($),function(Qt){Et.call(q.classList,Qt)})):typeof q.className.baseVal=="string"?B(q.className,"baseVal",at,st):B(q,"className",at,st))},Bb:function(q,at){var st=u.a.f(at);(st===null||st===t)&&(st="");var Et=u.h.firstChild(q);!Et||Et.nodeType!=3||u.h.nextSibling(Et)?u.h.va(q,[q.ownerDocument.createTextNode(st)]):Et.data=st,u.a.Ad(q)},Yc:function(q,at){if(q.name=at,7>=nt)try{var st=q.name.replace(/[&<>'"]/g,function(Et){return"&#"+Et.charCodeAt(0)+";"});q.mergeAttributes(n.createElement("<input name='"+st+"'/>"),!1)}catch{}},Ad:function(q){9<=nt&&(q=q.nodeType==1?q:q.parentNode,q.style&&(q.style.zoom=q.style.zoom))},wd:function(q){if(nt){var at=q.style.width;q.style.width=0,q.style.width=at}},Pd:function(q,at){q=u.a.f(q),at=u.a.f(at);for(var st=[],Et=q;Et<=at;Et++)st.push(Et);return st},la:function(q){for(var at=[],st=0,Et=q.length;st<Et;st++)at.push(q[st]);return at},Da:function(q){return P?Symbol(q):q},Zd:nt===6,$d:nt===7,W:nt,Lc:function(q,at){for(var st=u.a.la(q.getElementsByTagName("input")).concat(u.a.la(q.getElementsByTagName("textarea"))),Et=typeof at=="string"?function(Nt){return Nt.name===at}:function(Nt){return at.test(Nt.name)},Qt=[],Wt=st.length-1;0<=Wt;Wt--)Et(st[Wt])&&Qt.push(st[Wt]);return Qt},Nd:function(q){return typeof q=="string"&&(q=u.a.Db(q))?a&&a.parse?a.parse(q):new Function("return "+q)():null},hc:function(q,at,st){if(!a||!a.stringify)throw Error("Cannot find JSON.stringify(). Some browsers (e.g., IE < 8) don't support it natively, but you can overcome this by adding a script reference to json2.js, downloadable from http://www.json.org/json2.js");return a.stringify(u.a.f(q),at,st)},Od:function(q,at,st){st=st||{};var Et=st.params||{},Qt=st.includeFields||this.Jc,Wt=q;if(typeof q=="object"&&u.a.R(q)==="form")for(var Wt=q.action,Nt=Qt.length-1;0<=Nt;Nt--)for(var kt=u.a.Lc(q,Qt[Nt]),Mt=kt.length-1;0<=Mt;Mt--)Et[kt[Mt].name]=kt[Mt].value;at=u.a.f(at);var qt=n.createElement("form");qt.style.display="none",qt.action=Wt,qt.method="post";for(var ie in at)q=n.createElement("input"),q.type="hidden",q.name=ie,q.value=u.a.hc(u.a.f(at[ie])),qt.appendChild(q);V(Et,function(oe,He){var rn=n.createElement("input");rn.type="hidden",rn.name=oe,rn.value=He,qt.appendChild(rn)}),n.body.appendChild(qt),st.submitter?st.submitter(qt):qt.submit(),setTimeout(function(){qt.parentNode.removeChild(qt)},0)}}}(),u.b("utils",u.a),u.b("utils.arrayForEach",u.a.D),u.b("utils.arrayFirst",u.a.Lb),u.b("utils.arrayFilter",u.a.jb),u.b("utils.arrayGetDistinctValues",u.a.wc),u.b("utils.arrayIndexOf",u.a.A),u.b("utils.arrayMap",u.a.Mb),u.b("utils.arrayPushAll",u.a.Nb),u.b("utils.arrayRemoveItem",u.a.Pa),u.b("utils.cloneNodes",u.a.Ca),u.b("utils.createSymbolOrString",u.a.Da),u.b("utils.extend",u.a.extend),u.b("utils.fieldsIncludedWithJsonPost",u.a.Jc),u.b("utils.getFormFields",u.a.Lc),u.b("utils.objectMap",u.a.Ga),u.b("utils.peekObservable",u.a.bc),u.b("utils.postJson",u.a.Od),u.b("utils.parseJson",u.a.Nd),u.b("utils.registerEventHandler",u.a.B),u.b("utils.stringifyJson",u.a.hc),u.b("utils.range",u.a.Pd),u.b("utils.toggleDomNodeCssClass",u.a.Eb),u.b("utils.triggerEvent",u.a.Fb),u.b("utils.unwrapObservable",u.a.f),u.b("utils.objectForEach",u.a.P),u.b("utils.addOrRemoveItem",u.a.Na),u.b("utils.setTextContent",u.a.Bb),u.b("unwrap",u.a.f),Function.prototype.bind||(Function.prototype.bind=function(V){var E=this;if(arguments.length===1)return function(){return E.apply(V,arguments)};var I=Array.prototype.slice.call(arguments,1);return function(){var B=I.slice(0);return B.push.apply(B,arguments),E.apply(V,B)}}),u.a.g=new function(){var V=0,E="__ko__"+new Date().getTime(),I={},B,X;return u.a.W?(B=function(_,P){var w=_[E];if(!w||w==="null"||!I[w]){if(!P)return t;w=_[E]="ko"+V++,I[w]={}}return I[w]},X=function(_){var P=_[E];return P?(delete I[P],_[E]=null,!0):!1}):(B=function(_,P){var w=_[E];return!w&&P&&(w=_[E]={}),w},X=function(_){return _[E]?(delete _[E],!0):!1}),{get:function(_,P){var w=B(_,!1);return w&&w[P]},set:function(_,P,w){(_=B(_,w!==t))&&(_[P]=w)},Ub:function(_,P,w){return _=B(_,!0),_[P]||(_[P]=w)},clear:X,Z:function(){return V+++E}}},u.b("utils.domData",u.a.g),u.b("utils.domData.clear",u.a.g.clear),u.a.K=new function(){function V(P,w){var z=u.a.g.get(P,B);return z===t&&w&&(z=[],u.a.g.set(P,B,z)),z}function E(P){var w=V(P,!1);if(w)for(var w=w.slice(0),z=0;z<w.length;z++)w[z](P);u.a.g.clear(P),u.a.K.cleanExternalData(P),_[P.nodeType]&&I(P.childNodes,!0)}function I(P,w){for(var z=[],H,nt=0;nt<P.length;nt++)if((!w||P[nt].nodeType===8)&&(E(z[z.length]=H=P[nt]),P[nt]!==H))for(;nt--&&u.a.A(z,P[nt])==-1;);}var B=u.a.g.Z(),X={1:!0,8:!0,9:!0},_={1:!0,9:!0};return{za:function(P,w){if(typeof w!="function")throw Error("Callback must be a function");V(P,!0).push(w)},yb:function(P,w){var z=V(P,!1);z&&(u.a.Pa(z,w),z.length==0&&u.a.g.set(P,B,t))},oa:function(P){return u.u.G(function(){X[P.nodeType]&&(E(P),_[P.nodeType]&&I(P.getElementsByTagName("*")))}),P},removeNode:function(P){u.oa(P),P.parentNode&&P.parentNode.removeChild(P)},cleanExternalData:function(P){o&&typeof o.cleanData=="function"&&o.cleanData([P])}}},u.oa=u.a.K.oa,u.removeNode=u.a.K.removeNode,u.b("cleanNode",u.oa),u.b("removeNode",u.removeNode),u.b("utils.domNodeDisposal",u.a.K),u.b("utils.domNodeDisposal.addDisposeCallback",u.a.K.za),u.b("utils.domNodeDisposal.removeDisposeCallback",u.a.K.yb),function(){var V=[0,"",""],E=[1,"<table>","</table>"],I=[3,"<table><tbody><tr>","</tr></tbody></table>"],B=[1,"<select multiple='multiple'>","</select>"],X={thead:E,tbody:E,tfoot:E,tr:[2,"<table><tbody>","</tbody></table>"],td:I,th:I,option:B,optgroup:B},_=8>=u.a.W;u.a.ua=function(P,w){var z;if(o){if(o.parseHTML)z=o.parseHTML(P,w)||[];else if((z=o.clean([P],w))&&z[0]){for(var H=z[0];H.parentNode&&H.parentNode.nodeType!==11;)H=H.parentNode;H.parentNode&&H.parentNode.removeChild(H)}}else{(z=w)||(z=n);var H=z.parentWindow||z.defaultView||e,nt=u.a.Db(P).toLowerCase(),$=z.createElement("div"),dt;for(dt=(nt=nt.match(/^(?:\x3c!--.*?--\x3e\s*?)*?<([a-z]+)[\s>]/))&&X[nt[1]]||V,nt=dt[0],dt="ignored<div>"+dt[1]+P+dt[2]+"</div>",typeof H.innerShiv=="function"?$.appendChild(H.innerShiv(dt)):(_&&z.body.appendChild($),$.innerHTML=dt,_&&$.parentNode.removeChild($));nt--;)$=$.lastChild;z=u.a.la($.lastChild.childNodes)}return z},u.a.Md=function(P,w){var z=u.a.ua(P,w);return z.length&&z[0].parentElement||u.a.Yb(z)},u.a.fc=function(P,w){if(u.a.Tb(P),w=u.a.f(w),w!==null&&w!==t)if(typeof w!="string"&&(w=w.toString()),o)o(P).html(w);else for(var z=u.a.ua(w,P.ownerDocument),H=0;H<z.length;H++)P.appendChild(z[H])}}(),u.b("utils.parseHtmlFragment",u.a.ua),u.b("utils.setHtml",u.a.fc),u.aa=function(){function V(I,B){if(I){if(I.nodeType==8){var X=u.aa.Uc(I.nodeValue);X!=null&&B.push({ud:I,Kd:X})}else if(I.nodeType==1)for(var X=0,_=I.childNodes,P=_.length;X<P;X++)V(_[X],B)}}var E={};return{Xb:function(I){if(typeof I!="function")throw Error("You can only pass a function to ko.memoization.memoize()");var B=(4294967296*(1+Math.random())|0).toString(16).substring(1)+(4294967296*(1+Math.random())|0).toString(16).substring(1);return E[B]=I,"<!--[ko_memo:"+B+"]-->"},bd:function(I,B){var X=E[I];if(X===t)throw Error("Couldn't find any memo with ID "+I+". Perhaps it's already been unmemoized.");try{return X.apply(null,B||[]),!0}finally{delete E[I]}},cd:function(I,B){var X=[];V(I,X);for(var _=0,P=X.length;_<P;_++){var w=X[_].ud,z=[w];B&&u.a.Nb(z,B),u.aa.bd(X[_].Kd,z),w.nodeValue="",w.parentNode&&w.parentNode.removeChild(w)}},Uc:function(I){return(I=I.match(/^\[ko_memo\:(.*?)\]$/))?I[1]:null}}}(),u.b("memoization",u.aa),u.b("memoization.memoize",u.aa.Xb),u.b("memoization.unmemoize",u.aa.bd),u.b("memoization.parseMemoText",u.aa.Uc),u.b("memoization.unmemoizeDomNodeAndDescendants",u.aa.cd),u.na=function(){function V(){if(X){for(var w=X,z=0,H;P<X;)if(H=B[P++]){if(P>w){if(5e3<=++z){P=X,u.a.Gc(Error("'Too much recursion' after processing "+z+" task groups."));break}w=X}try{H()}catch(nt){u.a.Gc(nt)}}}}function E(){V(),P=X=B.length=0}var I,B=[],X=0,_=1,P=0;return e.MutationObserver?I=function(w){var z=n.createElement("div");return new MutationObserver(w).observe(z,{attributes:!0}),function(){z.classList.toggle("foo")}}(E):I=n&&"onreadystatechange"in n.createElement("script")?function(w){var z=n.createElement("script");z.onreadystatechange=function(){z.onreadystatechange=null,n.documentElement.removeChild(z),z=null,w()},n.documentElement.appendChild(z)}:function(w){setTimeout(w,0)},{scheduler:I,zb:function(w){return X||u.na.scheduler(E),B[X++]=w,_++},cancel:function(w){w=w-(_-X),w>=P&&w<X&&(B[w]=null)},resetForTesting:function(){var w=X-P;return P=X=B.length=0,w},Sd:V}}(),u.b("tasks",u.na),u.b("tasks.schedule",u.na.zb),u.b("tasks.runEarly",u.na.Sd),u.Ta={throttle:function(V,E){V.throttleEvaluation=E;var I=null;return u.$({read:V,write:function(B){clearTimeout(I),I=u.a.setTimeout(function(){V(B)},E)}})},rateLimit:function(V,E){var I,B,X;typeof E=="number"?I=E:(I=E.timeout,B=E.method),V.Hb=!1,X=typeof B=="function"?B:B=="notifyWhenChangesStop"?m:d,V.ub(function(_){return X(_,I,E)})},deferred:function(V,E){if(E!==!0)throw Error("The 'deferred' extender only accepts the value 'true', because it is not supported to turn deferral off once enabled.");V.Hb||(V.Hb=!0,V.ub(function(I){var B,X=!1;return function(){if(!X){u.na.cancel(B),B=u.na.zb(I);try{X=!0,V.notifySubscribers(t,"dirty")}finally{X=!1}}}}))},notify:function(V,E){V.equalityComparer=E=="always"?null:r}};var F={undefined:1,boolean:1,number:1,string:1};u.b("extenders",u.Ta),u.ic=function(V,E,I){this.da=V,this.lc=E,this.mc=I,this.Ib=!1,this.fb=this.Jb=null,u.L(this,"dispose",this.s),u.L(this,"disposeWhenNodeIsRemoved",this.l)},u.ic.prototype.s=function(){this.Ib||(this.fb&&u.a.K.yb(this.Jb,this.fb),this.Ib=!0,this.mc(),this.da=this.lc=this.mc=this.Jb=this.fb=null)},u.ic.prototype.l=function(V){this.Jb=V,u.a.K.za(V,this.fb=this.s.bind(this))},u.T=function(){u.a.Ab(this,U),U.qb(this)};var U={qb:function(V){V.U={change:[]},V.sc=1},subscribe:function(V,E,I){var B=this;I=I||"change";var X=new u.ic(B,E?V.bind(E):V,function(){u.a.Pa(B.U[I],X),B.hb&&B.hb(I)});return B.Qa&&B.Qa(I),B.U[I]||(B.U[I]=[]),B.U[I].push(X),X},notifySubscribers:function(V,E){if(E=E||"change",E==="change"&&this.Gb(),this.Wa(E)){var I=E==="change"&&this.ed||this.U[E].slice(0);try{u.u.xc();for(var B=0,X;X=I[B];++B)X.Ib||X.lc(V)}finally{u.u.end()}}},ob:function(){return this.sc},Dd:function(V){return this.ob()!==V},Gb:function(){++this.sc},ub:function(V){var E=this,I=u.O(E),B,X,_,P,w;E.gb||(E.gb=E.notifySubscribers,E.notifySubscribers=h);var z=V(function(){E.Ja=!1,I&&P===E&&(P=E.nc?E.nc():E());var H=X||w&&E.sb(_,P);w=X=B=!1,H&&E.gb(_=P)});E.qc=function(H,nt){nt&&E.Ja||(w=!nt),E.ed=E.U.change.slice(0),E.Ja=B=!0,P=H,z()},E.pc=function(H){B||(_=H,E.gb(H,"beforeChange"))},E.rc=function(){w=!0},E.gd=function(){E.sb(_,E.v(!0))&&(X=!0)}},Wa:function(V){return this.U[V]&&this.U[V].length},Bd:function(V){if(V)return this.U[V]&&this.U[V].length||0;var E=0;return u.a.P(this.U,function(I,B){I!=="dirty"&&(E+=B.length)}),E},sb:function(V,E){return!this.equalityComparer||!this.equalityComparer(V,E)},toString:function(){return"[object Object]"},extend:function(V){var E=this;return V&&u.a.P(V,function(I,B){var X=u.Ta[I];typeof X=="function"&&(E=X(E,B)||E)}),E}};u.L(U,"init",U.qb),u.L(U,"subscribe",U.subscribe),u.L(U,"extend",U.extend),u.L(U,"getSubscriptionsCount",U.Bd),u.a.Ba&&u.a.setPrototypeOf(U,Function.prototype),u.T.fn=U,u.Qc=function(V){return V!=null&&typeof V.subscribe=="function"&&typeof V.notifySubscribers=="function"},u.b("subscribable",u.T),u.b("isSubscribable",u.Qc),u.S=u.u=function(){function V(_){I.push(B),B=_}function E(){B=I.pop()}var I=[],B,X=0;return{xc:V,end:E,cc:function(_){if(B){if(!u.Qc(_))throw Error("Only subscribable things can act as dependencies");B.od.call(B.pd,_,_.fd||(_.fd=++X))}},G:function(_,P,w){try{return V(),_.apply(P,w||[])}finally{E()}},qa:function(){if(B)return B.o.qa()},Va:function(){if(B)return B.o.Va()},Ya:function(){if(B)return B.Ya},o:function(){if(B)return B.o}}}(),u.b("computedContext",u.S),u.b("computedContext.getDependenciesCount",u.S.qa),u.b("computedContext.getDependencies",u.S.Va),u.b("computedContext.isInitial",u.S.Ya),u.b("computedContext.registerDependency",u.S.cc),u.b("ignoreDependencies",u.Yd=u.u.G);var G=u.a.Da("_latestValue");u.ta=function(V){function E(){return 0<arguments.length?(E.sb(E[G],arguments[0])&&(E.ya(),E[G]=arguments[0],E.xa()),this):(u.u.cc(E),E[G])}return E[G]=V,u.a.Ba||u.a.extend(E,u.T.fn),u.T.fn.qb(E),u.a.Ab(E,A),u.options.deferUpdates&&u.Ta.deferred(E,!0),E};var A={equalityComparer:r,v:function(){return this[G]},xa:function(){this.notifySubscribers(this[G],"spectate"),this.notifySubscribers(this[G])},ya:function(){this.notifySubscribers(this[G],"beforeChange")}};u.a.Ba&&u.a.setPrototypeOf(A,u.T.fn);var T=u.ta.Ma="__ko_proto__";A[T]=u.ta,u.O=function(V){if((V=typeof V=="function"&&V[T])&&V!==A[T]&&V!==u.o.fn[T])throw Error("Invalid object that looks like an observable; possibly from another Knockout instance");return!!V},u.Za=function(V){return typeof V=="function"&&(V[T]===A[T]||V[T]===u.o.fn[T]&&V.Nc)},u.b("observable",u.ta),u.b("isObservable",u.O),u.b("isWriteableObservable",u.Za),u.b("isWritableObservable",u.Za),u.b("observable.fn",A),u.L(A,"peek",A.v),u.L(A,"valueHasMutated",A.xa),u.L(A,"valueWillMutate",A.ya),u.Ha=function(V){if(V=V||[],typeof V!="object"||!("length"in V))throw Error("The argument passed when initializing an observable array must be an array, or null, or undefined.");return V=u.ta(V),u.a.Ab(V,u.Ha.fn),V.extend({trackArrayChanges:!0})},u.Ha.fn={remove:function(V){for(var E=this.v(),I=[],B=typeof V!="function"||u.O(V)?function(P){return P===V}:V,X=0;X<E.length;X++){var _=E[X];if(B(_)){if(I.length===0&&this.ya(),E[X]!==_)throw Error("Array modified during remove; cannot remove item");I.push(_),E.splice(X,1),X--}}return I.length&&this.xa(),I},removeAll:function(V){if(V===t){var E=this.v(),I=E.slice(0);return this.ya(),E.splice(0,E.length),this.xa(),I}return V?this.remove(function(B){return 0<=u.a.A(V,B)}):[]},destroy:function(V){var E=this.v(),I=typeof V!="function"||u.O(V)?function(_){return _===V}:V;this.ya();for(var B=E.length-1;0<=B;B--){var X=E[B];I(X)&&(X._destroy=!0)}this.xa()},destroyAll:function(V){return V===t?this.destroy(function(){return!0}):V?this.destroy(function(E){return 0<=u.a.A(V,E)}):[]},indexOf:function(V){var E=this();return u.a.A(E,V)},replace:function(V,E){var I=this.indexOf(V);0<=I&&(this.ya(),this.v()[I]=E,this.xa())},sorted:function(V){var E=this().slice(0);return V?E.sort(V):E.sort()},reversed:function(){return this().slice(0).reverse()}},u.a.Ba&&u.a.setPrototypeOf(u.Ha.fn,u.ta.fn),u.a.D("pop push reverse shift sort splice unshift".split(" "),function(V){u.Ha.fn[V]=function(){var E=this.v();this.ya(),this.zc(E,V,arguments);var I=E[V].apply(E,arguments);return this.xa(),I===E?this:I}}),u.a.D(["slice"],function(V){u.Ha.fn[V]=function(){var E=this();return E[V].apply(E,arguments)}}),u.Pc=function(V){return u.O(V)&&typeof V.remove=="function"&&typeof V.push=="function"},u.b("observableArray",u.Ha),u.b("isObservableArray",u.Pc),u.Ta.trackArrayChanges=function(V,E){function I(){function $(){if(w){var dt=[].concat(V.v()||[]),q;V.Wa("arrayChange")&&((!X||1<w)&&(X=u.a.Pb(z,dt,V.Ob)),q=X),z=dt,X=null,w=0,q&&q.length&&V.notifySubscribers(q,"arrayChange")}}B?$():(B=!0,P=V.subscribe(function(){++w},null,"spectate"),z=[].concat(V.v()||[]),X=null,_=V.subscribe($))}if(V.Ob={},E&&typeof E=="object"&&u.a.extend(V.Ob,E),V.Ob.sparse=!0,!V.zc){var B=!1,X=null,_,P,w=0,z,H=V.Qa,nt=V.hb;V.Qa=function($){H&&H.call(V,$),$==="arrayChange"&&I()},V.hb=function($){nt&&nt.call(V,$),$!=="arrayChange"||V.Wa("arrayChange")||(_&&_.s(),P&&P.s(),P=_=null,B=!1,z=t)},V.zc=function($,dt,q){function at(qt,ie,oe){return st[st.length]={status:qt,value:ie,index:oe}}if(B&&!w){var st=[],Et=$.length,Qt=q.length,Wt=0;switch(dt){case"push":Wt=Et;case"unshift":for(dt=0;dt<Qt;dt++)at("added",q[dt],Wt+dt);break;case"pop":Wt=Et-1;case"shift":Et&&at("deleted",$[Wt],Wt);break;case"splice":dt=Math.min(Math.max(0,0>q[0]?Et+q[0]:q[0]),Et);for(var Et=Qt===1?Et:Math.min(dt+(q[1]||0),Et),Qt=dt+Qt-2,Wt=Math.max(Et,Qt),Nt=[],kt=[],Mt=2;dt<Wt;++dt,++Mt)dt<Et&&kt.push(at("deleted",$[dt],dt)),dt<Qt&&Nt.push(at("added",q[Mt],dt));u.a.Kc(kt,Nt);break;default:return}X=st}}}};var g=u.a.Da("_state");u.o=u.$=function(V,E,I){function B(){if(0<arguments.length){if(typeof X=="function")X.apply(_.nb,arguments);else throw Error("Cannot write a value to a ko.computed unless you specify a 'write' option. If you wish to read the current value, don't pass any parameters.");return this}return _.ra||u.u.cc(B),(_.ka||_.J&&B.Xa())&&B.ha(),_.X}if(typeof V=="object"?I=V:(I=I||{},V&&(I.read=V)),typeof I.read!="function")throw Error("Pass a function that returns the value of the ko.computed");var X=I.write,_={X:t,sa:!0,ka:!0,rb:!1,jc:!1,ra:!1,wb:!1,J:!1,Wc:I.read,nb:E||I.owner,l:I.disposeWhenNodeIsRemoved||I.l||null,Sa:I.disposeWhen||I.Sa,Rb:null,I:{},V:0,Ic:null};return B[g]=_,B.Nc=typeof X=="function",u.a.Ba||u.a.extend(B,u.T.fn),u.T.fn.qb(B),u.a.Ab(B,C),I.pure?(_.wb=!0,_.J=!0,u.a.extend(B,y)):I.deferEvaluation&&u.a.extend(B,Y),u.options.deferUpdates&&u.Ta.deferred(B,!0),_.l&&(_.jc=!0,_.l.nodeType||(_.l=null)),_.J||I.deferEvaluation||B.ha(),_.l&&B.ja()&&u.a.K.za(_.l,_.Rb=function(){B.s()}),B};var C={equalityComparer:r,qa:function(){return this[g].V},Va:function(){var V=[];return u.a.P(this[g].I,function(E,I){V[I.Ka]=I.da}),V},Vb:function(V){if(!this[g].V)return!1;var E=this.Va();return u.a.A(E,V)!==-1?!0:!!u.a.Lb(E,function(I){return I.Vb&&I.Vb(V)})},uc:function(V,E,I){if(this[g].wb&&E===this)throw Error("A 'pure' computed must not be called recursively");this[g].I[V]=I,I.Ka=this[g].V++,I.La=E.ob()},Xa:function(){var V,E,I=this[g].I;for(V in I)if(Object.prototype.hasOwnProperty.call(I,V)&&(E=I[V],this.Ia&&E.da.Ja||E.da.Dd(E.La)))return!0},Jd:function(){this.Ia&&!this[g].rb&&this.Ia(!1)},ja:function(){var V=this[g];return V.ka||0<V.V},Rd:function(){this.Ja?this[g].ka&&(this[g].sa=!0):this.Hc()},$c:function(V){if(V.Hb){var E=V.subscribe(this.Jd,this,"dirty"),I=V.subscribe(this.Rd,this);return{da:V,s:function(){E.s(),I.s()}}}return V.subscribe(this.Hc,this)},Hc:function(){var V=this,E=V.throttleEvaluation;E&&0<=E?(clearTimeout(this[g].Ic),this[g].Ic=u.a.setTimeout(function(){V.ha(!0)},E)):V.Ia?V.Ia(!0):V.ha(!0)},ha:function(V){var E=this[g],I=E.Sa,B=!1;if(!E.rb&&!E.ra){if(E.l&&!u.a.Sb(E.l)||I&&I()){if(!E.jc){this.s();return}}else E.jc=!1;E.rb=!0;try{B=this.zd(V)}finally{E.rb=!1}return B}},zd:function(V){var E=this[g],B=!1,I=E.wb?t:!E.V,B={qd:this,mb:E.I,Qb:E.V};u.u.xc({pd:B,od:b,o:this,Ya:I}),E.I={},E.V=0;var X=this.yd(E,B);return E.V?B=this.sb(E.X,X):(this.s(),B=!0),B&&(E.J?this.Gb():this.notifySubscribers(E.X,"beforeChange"),E.X=X,this.notifySubscribers(E.X,"spectate"),!E.J&&V&&this.notifySubscribers(E.X),this.rc&&this.rc()),I&&this.notifySubscribers(E.X,"awake"),B},yd:function(V,E){try{var I=V.Wc;return V.nb?I.call(V.nb):I()}finally{u.u.end(),E.Qb&&!V.J&&u.a.P(E.mb,Z),V.sa=V.ka=!1}},v:function(V){var E=this[g];return(E.ka&&(V||!E.V)||E.J&&this.Xa())&&this.ha(),E.X},ub:function(V){u.T.fn.ub.call(this,V),this.nc=function(){return this[g].J||(this[g].sa?this.ha():this[g].ka=!1),this[g].X},this.Ia=function(E){this.pc(this[g].X),this[g].ka=!0,E&&(this[g].sa=!0),this.qc(this,!E)}},s:function(){var V=this[g];!V.J&&V.I&&u.a.P(V.I,function(E,I){I.s&&I.s()}),V.l&&V.Rb&&u.a.K.yb(V.l,V.Rb),V.I=t,V.V=0,V.ra=!0,V.sa=!1,V.ka=!1,V.J=!1,V.l=t,V.Sa=t,V.Wc=t,this.Nc||(V.nb=t)}},y={Qa:function(V){var E=this,I=E[g];if(!I.ra&&I.J&&V=="change"){if(I.J=!1,I.sa||E.Xa())I.I=null,I.V=0,E.ha()&&E.Gb();else{var B=[];u.a.P(I.I,function(X,_){B[_.Ka]=X}),u.a.D(B,function(X,_){var P=I.I[X],w=E.$c(P.da);w.Ka=_,w.La=P.La,I.I[X]=w}),E.Xa()&&E.ha()&&E.Gb()}I.ra||E.notifySubscribers(I.X,"awake")}},hb:function(V){var E=this[g];E.ra||V!="change"||this.Wa("change")||(u.a.P(E.I,function(I,B){B.s&&(E.I[I]={da:B.da,Ka:B.Ka,La:B.La},B.s())}),E.J=!0,this.notifySubscribers(t,"asleep"))},ob:function(){var V=this[g];return V.J&&(V.sa||this.Xa())&&this.ha(),u.T.fn.ob.call(this)}},Y={Qa:function(V){V!="change"&&V!="beforeChange"||this.v()}};u.a.Ba&&u.a.setPrototypeOf(C,u.T.fn);var Q=u.ta.Ma;C[Q]=u.o,u.Oc=function(V){return typeof V=="function"&&V[Q]===C[Q]},u.Fd=function(V){return u.Oc(V)&&V[g]&&V[g].wb},u.b("computed",u.o),u.b("dependentObservable",u.o),u.b("isComputed",u.Oc),u.b("isPureComputed",u.Fd),u.b("computed.fn",C),u.L(C,"peek",C.v),u.L(C,"dispose",C.s),u.L(C,"isActive",C.ja),u.L(C,"getDependenciesCount",C.qa),u.L(C,"getDependencies",C.Va),u.xb=function(V,E){return typeof V=="function"?u.o(V,E,{pure:!0}):(V=u.a.extend({},V),V.pure=!0,u.o(V,E))},u.b("pureComputed",u.xb),function(){function V(B,X,_){if(_=_||new I,B=X(B),typeof B!="object"||B===null||B===t||B instanceof RegExp||B instanceof Date||B instanceof String||B instanceof Number||B instanceof Boolean)return B;var P=B instanceof Array?[]:{};return _.save(B,P),E(B,function(w){var z=X(B[w]);switch(typeof z){case"boolean":case"number":case"string":case"function":P[w]=z;break;case"object":case"undefined":var H=_.get(z);P[w]=H!==t?H:V(z,X,_)}}),P}function E(B,X){if(B instanceof Array){for(var _=0;_<B.length;_++)X(_);typeof B.toJSON=="function"&&X("toJSON")}else for(_ in B)X(_)}function I(){this.keys=[],this.values=[]}u.ad=function(B){if(arguments.length==0)throw Error("When calling ko.toJS, pass the object you want to convert.");return V(B,function(X){for(var _=0;u.O(X)&&10>_;_++)X=X();return X})},u.toJSON=function(B,X,_){return B=u.ad(B),u.a.hc(B,X,_)},I.prototype={constructor:I,save:function(B,X){var _=u.a.A(this.keys,B);0<=_?this.values[_]=X:(this.keys.push(B),this.values.push(X))},get:function(B){return B=u.a.A(this.keys,B),0<=B?this.values[B]:t}}}(),u.b("toJS",u.ad),u.b("toJSON",u.toJSON),u.Wd=function(V,E,I){function B(X){var _=u.xb(V,I).extend({ma:"always"}),P=_.subscribe(function(w){w&&(P.s(),X(w))});return _.notifySubscribers(_.v()),P}return typeof Promise!="function"||E?B(E.bind(I)):new Promise(B)},u.b("when",u.Wd),function(){u.w={M:function(V){switch(u.a.R(V)){case"option":return V.__ko__hasDomDataOptionValue__===!0?u.a.g.get(V,u.c.options.$b):7>=u.a.W?V.getAttributeNode("value")&&V.getAttributeNode("value").specified?V.value:V.text:V.value;case"select":return 0<=V.selectedIndex?u.w.M(V.options[V.selectedIndex]):t;default:return V.value}},cb:function(V,E,I){switch(u.a.R(V)){case"option":typeof E=="string"?(u.a.g.set(V,u.c.options.$b,t),"__ko__hasDomDataOptionValue__"in V&&delete V.__ko__hasDomDataOptionValue__,V.value=E):(u.a.g.set(V,u.c.options.$b,E),V.__ko__hasDomDataOptionValue__=!0,V.value=typeof E=="number"?E:"");break;case"select":(E===""||E===null)&&(E=t);for(var B=-1,X=0,_=V.options.length,P;X<_;++X)if(P=u.w.M(V.options[X]),P==E||P===""&&E===t){B=X;break}(I||0<=B||E===t&&1<V.size)&&(V.selectedIndex=B,u.a.W===6&&u.a.setTimeout(function(){V.selectedIndex=B},0));break;default:(E===null||E===t)&&(E=""),V.value=E}}}}(),u.b("selectExtensions",u.w),u.b("selectExtensions.readValue",u.w.M),u.b("selectExtensions.writeValue",u.w.cb),u.m=function(){function V(w){w=u.a.Db(w),w.charCodeAt(0)===123&&(w=w.slice(1,-1)),w+=` + */(function(){(function(t){var e=this||(0,eval)("this"),n=e.document,i=e.navigator,o=e.jQuery,a=e.JSON;o||typeof jQuery>"u"||(o=jQuery),function(s){s(e.ko={})}(function(s,l){function r(Z,E){return Z===null||typeof Z in F?Z===E:!1}function d(Z,E){var I;return function(){I||(I=V.a.setTimeout(function(){I=t,Z()},E))}}function m(Z,E){var I;return function(){clearTimeout(I),I=V.a.setTimeout(Z,E)}}function h(Z,E){E&&E!=="change"?E==="beforeChange"?this.pc(Z):this.gb(Z,E):this.qc(Z)}function u(Z,E){E!==null&&E.s&&E.s()}function R(Z,E){var I=this.qd,B=I[g];B.ra||(this.Qb&&this.mb[E]?(I.uc(E,Z,this.mb[E]),this.mb[E]=null,--this.Qb):B.I[E]||I.uc(E,Z,B.J?{da:Z}:I.$c(Z)),Z.Ja&&Z.gd())}var V=typeof s<"u"?s:{};V.b=function(Z,E){for(var I=Z.split("."),B=V,X=0;X<I.length-1;X++)B=B[I[X]];B[I[I.length-1]]=E},V.L=function(Z,E,I){Z[E]=I},V.version="3.5.1",V.b("version",V.version),V.options={deferUpdates:!1,useOnlyNativeEvents:!1,foreachHidesDestroyed:!1},V.a=function(){function Z(q,at){for(var st in q)X.call(q,st)&&at(st,q[st])}function E(q,at){if(at)for(var st in at)X.call(at,st)&&(q[st]=at[st]);return q}function I(q,at){return q.__proto__=at,q}function B(q,at,st,Et){var Qt=q[at].match($)||[];V.a.D(st.match($),function(Wt){V.a.Na(Qt,Wt,Et)}),q[at]=Qt.join(" ")}var X=Object.prototype.hasOwnProperty,_={__proto__:[]}instanceof Array,P=typeof Symbol=="function",w={},z={};w[i&&/Firefox\/2/i.test(i.userAgent)?"KeyboardEvent":"UIEvents"]=["keyup","keydown","keypress"],w.MouseEvents="click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave".split(" "),Z(w,function(q,at){if(at.length)for(var st=0,Et=at.length;st<Et;st++)z[at[st]]=q});var H={propertychange:!0},nt=n&&function(){for(var q=3,at=n.createElement("div"),st=at.getElementsByTagName("i");at.innerHTML="<!--[if gt IE "+ ++q+"]><i></i><![endif]-->",st[0];);return 4<q?q:t}(),$=/\S+/g,dt;return{Jc:["authenticity_token",/^__RequestVerificationToken(_.*)?$/],D:function(q,at,st){for(var Et=0,Qt=q.length;Et<Qt;Et++)at.call(st,q[Et],Et,q)},A:typeof Array.prototype.indexOf=="function"?function(q,at){return Array.prototype.indexOf.call(q,at)}:function(q,at){for(var st=0,Et=q.length;st<Et;st++)if(q[st]===at)return st;return-1},Lb:function(q,at,st){for(var Et=0,Qt=q.length;Et<Qt;Et++)if(at.call(st,q[Et],Et,q))return q[Et];return t},Pa:function(q,at){var st=V.a.A(q,at);0<st?q.splice(st,1):st===0&&q.shift()},wc:function(q){var at=[];return q&&V.a.D(q,function(st){0>V.a.A(at,st)&&at.push(st)}),at},Mb:function(q,at,st){var Et=[];if(q)for(var Qt=0,Wt=q.length;Qt<Wt;Qt++)Et.push(at.call(st,q[Qt],Qt));return Et},jb:function(q,at,st){var Et=[];if(q)for(var Qt=0,Wt=q.length;Qt<Wt;Qt++)at.call(st,q[Qt],Qt)&&Et.push(q[Qt]);return Et},Nb:function(q,at){if(at instanceof Array)q.push.apply(q,at);else for(var st=0,Et=at.length;st<Et;st++)q.push(at[st]);return q},Na:function(q,at,st){var Et=V.a.A(V.a.bc(q),at);0>Et?st&&q.push(at):st||q.splice(Et,1)},Ba:_,extend:E,setPrototypeOf:I,Ab:_?I:E,P:Z,Ga:function(q,at,st){if(!q)return q;var Et={},Qt;for(Qt in q)X.call(q,Qt)&&(Et[Qt]=at.call(st,q[Qt],Qt,q));return Et},Tb:function(q){for(;q.firstChild;)V.removeNode(q.firstChild)},Yb:function(q){q=V.a.la(q);for(var at=(q[0]&&q[0].ownerDocument||n).createElement("div"),st=0,Et=q.length;st<Et;st++)at.appendChild(V.oa(q[st]));return at},Ca:function(q,at){for(var st=0,Et=q.length,Qt=[];st<Et;st++){var Wt=q[st].cloneNode(!0);Qt.push(at?V.oa(Wt):Wt)}return Qt},va:function(q,at){if(V.a.Tb(q),at)for(var st=0,Et=at.length;st<Et;st++)q.appendChild(at[st])},Xc:function(q,at){var st=q.nodeType?[q]:q;if(0<st.length){for(var Et=st[0],Qt=Et.parentNode,Wt=0,Nt=at.length;Wt<Nt;Wt++)Qt.insertBefore(at[Wt],Et);for(Wt=0,Nt=st.length;Wt<Nt;Wt++)V.removeNode(st[Wt])}},Ua:function(q,at){if(q.length){for(at=at.nodeType===8&&at.parentNode||at;q.length&&q[0].parentNode!==at;)q.splice(0,1);for(;1<q.length&&q[q.length-1].parentNode!==at;)q.length--;if(1<q.length){var st=q[0],Et=q[q.length-1];for(q.length=0;st!==Et;)q.push(st),st=st.nextSibling;q.push(Et)}}return q},Zc:function(q,at){7>nt?q.setAttribute("selected",at):q.selected=at},Db:function(q){return q===null||q===t?"":q.trim?q.trim():q.toString().replace(/^[\s\xa0]+|[\s\xa0]+$/g,"")},Ud:function(q,at){return q=q||"",at.length>q.length?!1:q.substring(0,at.length)===at},vd:function(q,at){if(q===at)return!0;if(q.nodeType===11)return!1;if(at.contains)return at.contains(q.nodeType!==1?q.parentNode:q);if(at.compareDocumentPosition)return(at.compareDocumentPosition(q)&16)==16;for(;q&&q!=at;)q=q.parentNode;return!!q},Sb:function(q){return V.a.vd(q,q.ownerDocument.documentElement)},kd:function(q){return!!V.a.Lb(q,V.a.Sb)},R:function(q){return q&&q.tagName&&q.tagName.toLowerCase()},Ac:function(q){return V.onError?function(){try{return q.apply(this,arguments)}catch(at){throw V.onError&&V.onError(at),at}}:q},setTimeout:function(q,at){return setTimeout(V.a.Ac(q),at)},Gc:function(q){setTimeout(function(){throw V.onError&&V.onError(q),q},0)},B:function(q,at,st){var Et=V.a.Ac(st);if(st=H[at],V.options.useOnlyNativeEvents||st||!o)if(st||typeof q.addEventListener!="function")if(typeof q.attachEvent<"u"){var Qt=function(Nt){Et.call(q,Nt)},Wt="on"+at;q.attachEvent(Wt,Qt),V.a.K.za(q,function(){q.detachEvent(Wt,Qt)})}else throw Error("Browser doesn't support addEventListener or attachEvent");else q.addEventListener(at,Et,!1);else dt||(dt=typeof o(q).on=="function"?"on":"bind"),o(q)[dt](at,Et)},Fb:function(q,at){if(!q||!q.nodeType)throw Error("element must be a DOM node when calling triggerEvent");var st;if(V.a.R(q)==="input"&&q.type&&at.toLowerCase()=="click"?(st=q.type,st=st=="checkbox"||st=="radio"):st=!1,V.options.useOnlyNativeEvents||!o||st)if(typeof n.createEvent=="function")if(typeof q.dispatchEvent=="function")st=n.createEvent(z[at]||"HTMLEvents"),st.initEvent(at,!0,!0,e,0,0,0,0,0,!1,!1,!1,!1,0,q),q.dispatchEvent(st);else throw Error("The supplied element doesn't support dispatchEvent");else if(st&&q.click)q.click();else if(typeof q.fireEvent<"u")q.fireEvent("on"+at);else throw Error("Browser doesn't support triggering events");else o(q).trigger(at)},f:function(q){return V.O(q)?q():q},bc:function(q){return V.O(q)?q.v():q},Eb:function(q,at,st){var Et;at&&(typeof q.classList=="object"?(Et=q.classList[st?"add":"remove"],V.a.D(at.match($),function(Qt){Et.call(q.classList,Qt)})):typeof q.className.baseVal=="string"?B(q.className,"baseVal",at,st):B(q,"className",at,st))},Bb:function(q,at){var st=V.a.f(at);(st===null||st===t)&&(st="");var Et=V.h.firstChild(q);!Et||Et.nodeType!=3||V.h.nextSibling(Et)?V.h.va(q,[q.ownerDocument.createTextNode(st)]):Et.data=st,V.a.Ad(q)},Yc:function(q,at){if(q.name=at,7>=nt)try{var st=q.name.replace(/[&<>'"]/g,function(Et){return"&#"+Et.charCodeAt(0)+";"});q.mergeAttributes(n.createElement("<input name='"+st+"'/>"),!1)}catch{}},Ad:function(q){9<=nt&&(q=q.nodeType==1?q:q.parentNode,q.style&&(q.style.zoom=q.style.zoom))},wd:function(q){if(nt){var at=q.style.width;q.style.width=0,q.style.width=at}},Pd:function(q,at){q=V.a.f(q),at=V.a.f(at);for(var st=[],Et=q;Et<=at;Et++)st.push(Et);return st},la:function(q){for(var at=[],st=0,Et=q.length;st<Et;st++)at.push(q[st]);return at},Da:function(q){return P?Symbol(q):q},Zd:nt===6,$d:nt===7,W:nt,Lc:function(q,at){for(var st=V.a.la(q.getElementsByTagName("input")).concat(V.a.la(q.getElementsByTagName("textarea"))),Et=typeof at=="string"?function(Nt){return Nt.name===at}:function(Nt){return at.test(Nt.name)},Qt=[],Wt=st.length-1;0<=Wt;Wt--)Et(st[Wt])&&Qt.push(st[Wt]);return Qt},Nd:function(q){return typeof q=="string"&&(q=V.a.Db(q))?a&&a.parse?a.parse(q):new Function("return "+q)():null},hc:function(q,at,st){if(!a||!a.stringify)throw Error("Cannot find JSON.stringify(). Some browsers (e.g., IE < 8) don't support it natively, but you can overcome this by adding a script reference to json2.js, downloadable from http://www.json.org/json2.js");return a.stringify(V.a.f(q),at,st)},Od:function(q,at,st){st=st||{};var Et=st.params||{},Qt=st.includeFields||this.Jc,Wt=q;if(typeof q=="object"&&V.a.R(q)==="form")for(var Wt=q.action,Nt=Qt.length-1;0<=Nt;Nt--)for(var kt=V.a.Lc(q,Qt[Nt]),Mt=kt.length-1;0<=Mt;Mt--)Et[kt[Mt].name]=kt[Mt].value;at=V.a.f(at);var qt=n.createElement("form");qt.style.display="none",qt.action=Wt,qt.method="post";for(var ie in at)q=n.createElement("input"),q.type="hidden",q.name=ie,q.value=V.a.hc(V.a.f(at[ie])),qt.appendChild(q);Z(Et,function(oe,He){var rn=n.createElement("input");rn.type="hidden",rn.name=oe,rn.value=He,qt.appendChild(rn)}),n.body.appendChild(qt),st.submitter?st.submitter(qt):qt.submit(),setTimeout(function(){qt.parentNode.removeChild(qt)},0)}}}(),V.b("utils",V.a),V.b("utils.arrayForEach",V.a.D),V.b("utils.arrayFirst",V.a.Lb),V.b("utils.arrayFilter",V.a.jb),V.b("utils.arrayGetDistinctValues",V.a.wc),V.b("utils.arrayIndexOf",V.a.A),V.b("utils.arrayMap",V.a.Mb),V.b("utils.arrayPushAll",V.a.Nb),V.b("utils.arrayRemoveItem",V.a.Pa),V.b("utils.cloneNodes",V.a.Ca),V.b("utils.createSymbolOrString",V.a.Da),V.b("utils.extend",V.a.extend),V.b("utils.fieldsIncludedWithJsonPost",V.a.Jc),V.b("utils.getFormFields",V.a.Lc),V.b("utils.objectMap",V.a.Ga),V.b("utils.peekObservable",V.a.bc),V.b("utils.postJson",V.a.Od),V.b("utils.parseJson",V.a.Nd),V.b("utils.registerEventHandler",V.a.B),V.b("utils.stringifyJson",V.a.hc),V.b("utils.range",V.a.Pd),V.b("utils.toggleDomNodeCssClass",V.a.Eb),V.b("utils.triggerEvent",V.a.Fb),V.b("utils.unwrapObservable",V.a.f),V.b("utils.objectForEach",V.a.P),V.b("utils.addOrRemoveItem",V.a.Na),V.b("utils.setTextContent",V.a.Bb),V.b("unwrap",V.a.f),Function.prototype.bind||(Function.prototype.bind=function(Z){var E=this;if(arguments.length===1)return function(){return E.apply(Z,arguments)};var I=Array.prototype.slice.call(arguments,1);return function(){var B=I.slice(0);return B.push.apply(B,arguments),E.apply(Z,B)}}),V.a.g=new function(){var Z=0,E="__ko__"+new Date().getTime(),I={},B,X;return V.a.W?(B=function(_,P){var w=_[E];if(!w||w==="null"||!I[w]){if(!P)return t;w=_[E]="ko"+Z++,I[w]={}}return I[w]},X=function(_){var P=_[E];return P?(delete I[P],_[E]=null,!0):!1}):(B=function(_,P){var w=_[E];return!w&&P&&(w=_[E]={}),w},X=function(_){return _[E]?(delete _[E],!0):!1}),{get:function(_,P){var w=B(_,!1);return w&&w[P]},set:function(_,P,w){(_=B(_,w!==t))&&(_[P]=w)},Ub:function(_,P,w){return _=B(_,!0),_[P]||(_[P]=w)},clear:X,Z:function(){return Z+++E}}},V.b("utils.domData",V.a.g),V.b("utils.domData.clear",V.a.g.clear),V.a.K=new function(){function Z(P,w){var z=V.a.g.get(P,B);return z===t&&w&&(z=[],V.a.g.set(P,B,z)),z}function E(P){var w=Z(P,!1);if(w)for(var w=w.slice(0),z=0;z<w.length;z++)w[z](P);V.a.g.clear(P),V.a.K.cleanExternalData(P),_[P.nodeType]&&I(P.childNodes,!0)}function I(P,w){for(var z=[],H,nt=0;nt<P.length;nt++)if((!w||P[nt].nodeType===8)&&(E(z[z.length]=H=P[nt]),P[nt]!==H))for(;nt--&&V.a.A(z,P[nt])==-1;);}var B=V.a.g.Z(),X={1:!0,8:!0,9:!0},_={1:!0,9:!0};return{za:function(P,w){if(typeof w!="function")throw Error("Callback must be a function");Z(P,!0).push(w)},yb:function(P,w){var z=Z(P,!1);z&&(V.a.Pa(z,w),z.length==0&&V.a.g.set(P,B,t))},oa:function(P){return V.u.G(function(){X[P.nodeType]&&(E(P),_[P.nodeType]&&I(P.getElementsByTagName("*")))}),P},removeNode:function(P){V.oa(P),P.parentNode&&P.parentNode.removeChild(P)},cleanExternalData:function(P){o&&typeof o.cleanData=="function"&&o.cleanData([P])}}},V.oa=V.a.K.oa,V.removeNode=V.a.K.removeNode,V.b("cleanNode",V.oa),V.b("removeNode",V.removeNode),V.b("utils.domNodeDisposal",V.a.K),V.b("utils.domNodeDisposal.addDisposeCallback",V.a.K.za),V.b("utils.domNodeDisposal.removeDisposeCallback",V.a.K.yb),function(){var Z=[0,"",""],E=[1,"<table>","</table>"],I=[3,"<table><tbody><tr>","</tr></tbody></table>"],B=[1,"<select multiple='multiple'>","</select>"],X={thead:E,tbody:E,tfoot:E,tr:[2,"<table><tbody>","</tbody></table>"],td:I,th:I,option:B,optgroup:B},_=8>=V.a.W;V.a.ua=function(P,w){var z;if(o){if(o.parseHTML)z=o.parseHTML(P,w)||[];else if((z=o.clean([P],w))&&z[0]){for(var H=z[0];H.parentNode&&H.parentNode.nodeType!==11;)H=H.parentNode;H.parentNode&&H.parentNode.removeChild(H)}}else{(z=w)||(z=n);var H=z.parentWindow||z.defaultView||e,nt=V.a.Db(P).toLowerCase(),$=z.createElement("div"),dt;for(dt=(nt=nt.match(/^(?:\x3c!--.*?--\x3e\s*?)*?<([a-z]+)[\s>]/))&&X[nt[1]]||Z,nt=dt[0],dt="ignored<div>"+dt[1]+P+dt[2]+"</div>",typeof H.innerShiv=="function"?$.appendChild(H.innerShiv(dt)):(_&&z.body.appendChild($),$.innerHTML=dt,_&&$.parentNode.removeChild($));nt--;)$=$.lastChild;z=V.a.la($.lastChild.childNodes)}return z},V.a.Md=function(P,w){var z=V.a.ua(P,w);return z.length&&z[0].parentElement||V.a.Yb(z)},V.a.fc=function(P,w){if(V.a.Tb(P),w=V.a.f(w),w!==null&&w!==t)if(typeof w!="string"&&(w=w.toString()),o)o(P).html(w);else for(var z=V.a.ua(w,P.ownerDocument),H=0;H<z.length;H++)P.appendChild(z[H])}}(),V.b("utils.parseHtmlFragment",V.a.ua),V.b("utils.setHtml",V.a.fc),V.aa=function(){function Z(I,B){if(I){if(I.nodeType==8){var X=V.aa.Uc(I.nodeValue);X!=null&&B.push({ud:I,Kd:X})}else if(I.nodeType==1)for(var X=0,_=I.childNodes,P=_.length;X<P;X++)Z(_[X],B)}}var E={};return{Xb:function(I){if(typeof I!="function")throw Error("You can only pass a function to ko.memoization.memoize()");var B=(4294967296*(1+Math.random())|0).toString(16).substring(1)+(4294967296*(1+Math.random())|0).toString(16).substring(1);return E[B]=I,"<!--[ko_memo:"+B+"]-->"},bd:function(I,B){var X=E[I];if(X===t)throw Error("Couldn't find any memo with ID "+I+". Perhaps it's already been unmemoized.");try{return X.apply(null,B||[]),!0}finally{delete E[I]}},cd:function(I,B){var X=[];Z(I,X);for(var _=0,P=X.length;_<P;_++){var w=X[_].ud,z=[w];B&&V.a.Nb(z,B),V.aa.bd(X[_].Kd,z),w.nodeValue="",w.parentNode&&w.parentNode.removeChild(w)}},Uc:function(I){return(I=I.match(/^\[ko_memo\:(.*?)\]$/))?I[1]:null}}}(),V.b("memoization",V.aa),V.b("memoization.memoize",V.aa.Xb),V.b("memoization.unmemoize",V.aa.bd),V.b("memoization.parseMemoText",V.aa.Uc),V.b("memoization.unmemoizeDomNodeAndDescendants",V.aa.cd),V.na=function(){function Z(){if(X){for(var w=X,z=0,H;P<X;)if(H=B[P++]){if(P>w){if(5e3<=++z){P=X,V.a.Gc(Error("'Too much recursion' after processing "+z+" task groups."));break}w=X}try{H()}catch(nt){V.a.Gc(nt)}}}}function E(){Z(),P=X=B.length=0}var I,B=[],X=0,_=1,P=0;return e.MutationObserver?I=function(w){var z=n.createElement("div");return new MutationObserver(w).observe(z,{attributes:!0}),function(){z.classList.toggle("foo")}}(E):I=n&&"onreadystatechange"in n.createElement("script")?function(w){var z=n.createElement("script");z.onreadystatechange=function(){z.onreadystatechange=null,n.documentElement.removeChild(z),z=null,w()},n.documentElement.appendChild(z)}:function(w){setTimeout(w,0)},{scheduler:I,zb:function(w){return X||V.na.scheduler(E),B[X++]=w,_++},cancel:function(w){w=w-(_-X),w>=P&&w<X&&(B[w]=null)},resetForTesting:function(){var w=X-P;return P=X=B.length=0,w},Sd:Z}}(),V.b("tasks",V.na),V.b("tasks.schedule",V.na.zb),V.b("tasks.runEarly",V.na.Sd),V.Ta={throttle:function(Z,E){Z.throttleEvaluation=E;var I=null;return V.$({read:Z,write:function(B){clearTimeout(I),I=V.a.setTimeout(function(){Z(B)},E)}})},rateLimit:function(Z,E){var I,B,X;typeof E=="number"?I=E:(I=E.timeout,B=E.method),Z.Hb=!1,X=typeof B=="function"?B:B=="notifyWhenChangesStop"?m:d,Z.ub(function(_){return X(_,I,E)})},deferred:function(Z,E){if(E!==!0)throw Error("The 'deferred' extender only accepts the value 'true', because it is not supported to turn deferral off once enabled.");Z.Hb||(Z.Hb=!0,Z.ub(function(I){var B,X=!1;return function(){if(!X){V.na.cancel(B),B=V.na.zb(I);try{X=!0,Z.notifySubscribers(t,"dirty")}finally{X=!1}}}}))},notify:function(Z,E){Z.equalityComparer=E=="always"?null:r}};var F={undefined:1,boolean:1,number:1,string:1};V.b("extenders",V.Ta),V.ic=function(Z,E,I){this.da=Z,this.lc=E,this.mc=I,this.Ib=!1,this.fb=this.Jb=null,V.L(this,"dispose",this.s),V.L(this,"disposeWhenNodeIsRemoved",this.l)},V.ic.prototype.s=function(){this.Ib||(this.fb&&V.a.K.yb(this.Jb,this.fb),this.Ib=!0,this.mc(),this.da=this.lc=this.mc=this.Jb=this.fb=null)},V.ic.prototype.l=function(Z){this.Jb=Z,V.a.K.za(Z,this.fb=this.s.bind(this))},V.T=function(){V.a.Ab(this,U),U.qb(this)};var U={qb:function(Z){Z.U={change:[]},Z.sc=1},subscribe:function(Z,E,I){var B=this;I=I||"change";var X=new V.ic(B,E?Z.bind(E):Z,function(){V.a.Pa(B.U[I],X),B.hb&&B.hb(I)});return B.Qa&&B.Qa(I),B.U[I]||(B.U[I]=[]),B.U[I].push(X),X},notifySubscribers:function(Z,E){if(E=E||"change",E==="change"&&this.Gb(),this.Wa(E)){var I=E==="change"&&this.ed||this.U[E].slice(0);try{V.u.xc();for(var B=0,X;X=I[B];++B)X.Ib||X.lc(Z)}finally{V.u.end()}}},ob:function(){return this.sc},Dd:function(Z){return this.ob()!==Z},Gb:function(){++this.sc},ub:function(Z){var E=this,I=V.O(E),B,X,_,P,w;E.gb||(E.gb=E.notifySubscribers,E.notifySubscribers=h);var z=Z(function(){E.Ja=!1,I&&P===E&&(P=E.nc?E.nc():E());var H=X||w&&E.sb(_,P);w=X=B=!1,H&&E.gb(_=P)});E.qc=function(H,nt){nt&&E.Ja||(w=!nt),E.ed=E.U.change.slice(0),E.Ja=B=!0,P=H,z()},E.pc=function(H){B||(_=H,E.gb(H,"beforeChange"))},E.rc=function(){w=!0},E.gd=function(){E.sb(_,E.v(!0))&&(X=!0)}},Wa:function(Z){return this.U[Z]&&this.U[Z].length},Bd:function(Z){if(Z)return this.U[Z]&&this.U[Z].length||0;var E=0;return V.a.P(this.U,function(I,B){I!=="dirty"&&(E+=B.length)}),E},sb:function(Z,E){return!this.equalityComparer||!this.equalityComparer(Z,E)},toString:function(){return"[object Object]"},extend:function(Z){var E=this;return Z&&V.a.P(Z,function(I,B){var X=V.Ta[I];typeof X=="function"&&(E=X(E,B)||E)}),E}};V.L(U,"init",U.qb),V.L(U,"subscribe",U.subscribe),V.L(U,"extend",U.extend),V.L(U,"getSubscriptionsCount",U.Bd),V.a.Ba&&V.a.setPrototypeOf(U,Function.prototype),V.T.fn=U,V.Qc=function(Z){return Z!=null&&typeof Z.subscribe=="function"&&typeof Z.notifySubscribers=="function"},V.b("subscribable",V.T),V.b("isSubscribable",V.Qc),V.S=V.u=function(){function Z(_){I.push(B),B=_}function E(){B=I.pop()}var I=[],B,X=0;return{xc:Z,end:E,cc:function(_){if(B){if(!V.Qc(_))throw Error("Only subscribable things can act as dependencies");B.od.call(B.pd,_,_.fd||(_.fd=++X))}},G:function(_,P,w){try{return Z(),_.apply(P,w||[])}finally{E()}},qa:function(){if(B)return B.o.qa()},Va:function(){if(B)return B.o.Va()},Ya:function(){if(B)return B.Ya},o:function(){if(B)return B.o}}}(),V.b("computedContext",V.S),V.b("computedContext.getDependenciesCount",V.S.qa),V.b("computedContext.getDependencies",V.S.Va),V.b("computedContext.isInitial",V.S.Ya),V.b("computedContext.registerDependency",V.S.cc),V.b("ignoreDependencies",V.Yd=V.u.G);var G=V.a.Da("_latestValue");V.ta=function(Z){function E(){return 0<arguments.length?(E.sb(E[G],arguments[0])&&(E.ya(),E[G]=arguments[0],E.xa()),this):(V.u.cc(E),E[G])}return E[G]=Z,V.a.Ba||V.a.extend(E,V.T.fn),V.T.fn.qb(E),V.a.Ab(E,A),V.options.deferUpdates&&V.Ta.deferred(E,!0),E};var A={equalityComparer:r,v:function(){return this[G]},xa:function(){this.notifySubscribers(this[G],"spectate"),this.notifySubscribers(this[G])},ya:function(){this.notifySubscribers(this[G],"beforeChange")}};V.a.Ba&&V.a.setPrototypeOf(A,V.T.fn);var S=V.ta.Ma="__ko_proto__";A[S]=V.ta,V.O=function(Z){if((Z=typeof Z=="function"&&Z[S])&&Z!==A[S]&&Z!==V.o.fn[S])throw Error("Invalid object that looks like an observable; possibly from another Knockout instance");return!!Z},V.Za=function(Z){return typeof Z=="function"&&(Z[S]===A[S]||Z[S]===V.o.fn[S]&&Z.Nc)},V.b("observable",V.ta),V.b("isObservable",V.O),V.b("isWriteableObservable",V.Za),V.b("isWritableObservable",V.Za),V.b("observable.fn",A),V.L(A,"peek",A.v),V.L(A,"valueHasMutated",A.xa),V.L(A,"valueWillMutate",A.ya),V.Ha=function(Z){if(Z=Z||[],typeof Z!="object"||!("length"in Z))throw Error("The argument passed when initializing an observable array must be an array, or null, or undefined.");return Z=V.ta(Z),V.a.Ab(Z,V.Ha.fn),Z.extend({trackArrayChanges:!0})},V.Ha.fn={remove:function(Z){for(var E=this.v(),I=[],B=typeof Z!="function"||V.O(Z)?function(P){return P===Z}:Z,X=0;X<E.length;X++){var _=E[X];if(B(_)){if(I.length===0&&this.ya(),E[X]!==_)throw Error("Array modified during remove; cannot remove item");I.push(_),E.splice(X,1),X--}}return I.length&&this.xa(),I},removeAll:function(Z){if(Z===t){var E=this.v(),I=E.slice(0);return this.ya(),E.splice(0,E.length),this.xa(),I}return Z?this.remove(function(B){return 0<=V.a.A(Z,B)}):[]},destroy:function(Z){var E=this.v(),I=typeof Z!="function"||V.O(Z)?function(_){return _===Z}:Z;this.ya();for(var B=E.length-1;0<=B;B--){var X=E[B];I(X)&&(X._destroy=!0)}this.xa()},destroyAll:function(Z){return Z===t?this.destroy(function(){return!0}):Z?this.destroy(function(E){return 0<=V.a.A(Z,E)}):[]},indexOf:function(Z){var E=this();return V.a.A(E,Z)},replace:function(Z,E){var I=this.indexOf(Z);0<=I&&(this.ya(),this.v()[I]=E,this.xa())},sorted:function(Z){var E=this().slice(0);return Z?E.sort(Z):E.sort()},reversed:function(){return this().slice(0).reverse()}},V.a.Ba&&V.a.setPrototypeOf(V.Ha.fn,V.ta.fn),V.a.D("pop push reverse shift sort splice unshift".split(" "),function(Z){V.Ha.fn[Z]=function(){var E=this.v();this.ya(),this.zc(E,Z,arguments);var I=E[Z].apply(E,arguments);return this.xa(),I===E?this:I}}),V.a.D(["slice"],function(Z){V.Ha.fn[Z]=function(){var E=this();return E[Z].apply(E,arguments)}}),V.Pc=function(Z){return V.O(Z)&&typeof Z.remove=="function"&&typeof Z.push=="function"},V.b("observableArray",V.Ha),V.b("isObservableArray",V.Pc),V.Ta.trackArrayChanges=function(Z,E){function I(){function $(){if(w){var dt=[].concat(Z.v()||[]),q;Z.Wa("arrayChange")&&((!X||1<w)&&(X=V.a.Pb(z,dt,Z.Ob)),q=X),z=dt,X=null,w=0,q&&q.length&&Z.notifySubscribers(q,"arrayChange")}}B?$():(B=!0,P=Z.subscribe(function(){++w},null,"spectate"),z=[].concat(Z.v()||[]),X=null,_=Z.subscribe($))}if(Z.Ob={},E&&typeof E=="object"&&V.a.extend(Z.Ob,E),Z.Ob.sparse=!0,!Z.zc){var B=!1,X=null,_,P,w=0,z,H=Z.Qa,nt=Z.hb;Z.Qa=function($){H&&H.call(Z,$),$==="arrayChange"&&I()},Z.hb=function($){nt&&nt.call(Z,$),$!=="arrayChange"||Z.Wa("arrayChange")||(_&&_.s(),P&&P.s(),P=_=null,B=!1,z=t)},Z.zc=function($,dt,q){function at(qt,ie,oe){return st[st.length]={status:qt,value:ie,index:oe}}if(B&&!w){var st=[],Et=$.length,Qt=q.length,Wt=0;switch(dt){case"push":Wt=Et;case"unshift":for(dt=0;dt<Qt;dt++)at("added",q[dt],Wt+dt);break;case"pop":Wt=Et-1;case"shift":Et&&at("deleted",$[Wt],Wt);break;case"splice":dt=Math.min(Math.max(0,0>q[0]?Et+q[0]:q[0]),Et);for(var Et=Qt===1?Et:Math.min(dt+(q[1]||0),Et),Qt=dt+Qt-2,Wt=Math.max(Et,Qt),Nt=[],kt=[],Mt=2;dt<Wt;++dt,++Mt)dt<Et&&kt.push(at("deleted",$[dt],dt)),dt<Qt&&Nt.push(at("added",q[Mt],dt));V.a.Kc(kt,Nt);break;default:return}X=st}}}};var g=V.a.Da("_state");V.o=V.$=function(Z,E,I){function B(){if(0<arguments.length){if(typeof X=="function")X.apply(_.nb,arguments);else throw Error("Cannot write a value to a ko.computed unless you specify a 'write' option. If you wish to read the current value, don't pass any parameters.");return this}return _.ra||V.u.cc(B),(_.ka||_.J&&B.Xa())&&B.ha(),_.X}if(typeof Z=="object"?I=Z:(I=I||{},Z&&(I.read=Z)),typeof I.read!="function")throw Error("Pass a function that returns the value of the ko.computed");var X=I.write,_={X:t,sa:!0,ka:!0,rb:!1,jc:!1,ra:!1,wb:!1,J:!1,Wc:I.read,nb:E||I.owner,l:I.disposeWhenNodeIsRemoved||I.l||null,Sa:I.disposeWhen||I.Sa,Rb:null,I:{},V:0,Ic:null};return B[g]=_,B.Nc=typeof X=="function",V.a.Ba||V.a.extend(B,V.T.fn),V.T.fn.qb(B),V.a.Ab(B,C),I.pure?(_.wb=!0,_.J=!0,V.a.extend(B,y)):I.deferEvaluation&&V.a.extend(B,Y),V.options.deferUpdates&&V.Ta.deferred(B,!0),_.l&&(_.jc=!0,_.l.nodeType||(_.l=null)),_.J||I.deferEvaluation||B.ha(),_.l&&B.ja()&&V.a.K.za(_.l,_.Rb=function(){B.s()}),B};var C={equalityComparer:r,qa:function(){return this[g].V},Va:function(){var Z=[];return V.a.P(this[g].I,function(E,I){Z[I.Ka]=I.da}),Z},Vb:function(Z){if(!this[g].V)return!1;var E=this.Va();return V.a.A(E,Z)!==-1?!0:!!V.a.Lb(E,function(I){return I.Vb&&I.Vb(Z)})},uc:function(Z,E,I){if(this[g].wb&&E===this)throw Error("A 'pure' computed must not be called recursively");this[g].I[Z]=I,I.Ka=this[g].V++,I.La=E.ob()},Xa:function(){var Z,E,I=this[g].I;for(Z in I)if(Object.prototype.hasOwnProperty.call(I,Z)&&(E=I[Z],this.Ia&&E.da.Ja||E.da.Dd(E.La)))return!0},Jd:function(){this.Ia&&!this[g].rb&&this.Ia(!1)},ja:function(){var Z=this[g];return Z.ka||0<Z.V},Rd:function(){this.Ja?this[g].ka&&(this[g].sa=!0):this.Hc()},$c:function(Z){if(Z.Hb){var E=Z.subscribe(this.Jd,this,"dirty"),I=Z.subscribe(this.Rd,this);return{da:Z,s:function(){E.s(),I.s()}}}return Z.subscribe(this.Hc,this)},Hc:function(){var Z=this,E=Z.throttleEvaluation;E&&0<=E?(clearTimeout(this[g].Ic),this[g].Ic=V.a.setTimeout(function(){Z.ha(!0)},E)):Z.Ia?Z.Ia(!0):Z.ha(!0)},ha:function(Z){var E=this[g],I=E.Sa,B=!1;if(!E.rb&&!E.ra){if(E.l&&!V.a.Sb(E.l)||I&&I()){if(!E.jc){this.s();return}}else E.jc=!1;E.rb=!0;try{B=this.zd(Z)}finally{E.rb=!1}return B}},zd:function(Z){var E=this[g],B=!1,I=E.wb?t:!E.V,B={qd:this,mb:E.I,Qb:E.V};V.u.xc({pd:B,od:R,o:this,Ya:I}),E.I={},E.V=0;var X=this.yd(E,B);return E.V?B=this.sb(E.X,X):(this.s(),B=!0),B&&(E.J?this.Gb():this.notifySubscribers(E.X,"beforeChange"),E.X=X,this.notifySubscribers(E.X,"spectate"),!E.J&&Z&&this.notifySubscribers(E.X),this.rc&&this.rc()),I&&this.notifySubscribers(E.X,"awake"),B},yd:function(Z,E){try{var I=Z.Wc;return Z.nb?I.call(Z.nb):I()}finally{V.u.end(),E.Qb&&!Z.J&&V.a.P(E.mb,u),Z.sa=Z.ka=!1}},v:function(Z){var E=this[g];return(E.ka&&(Z||!E.V)||E.J&&this.Xa())&&this.ha(),E.X},ub:function(Z){V.T.fn.ub.call(this,Z),this.nc=function(){return this[g].J||(this[g].sa?this.ha():this[g].ka=!1),this[g].X},this.Ia=function(E){this.pc(this[g].X),this[g].ka=!0,E&&(this[g].sa=!0),this.qc(this,!E)}},s:function(){var Z=this[g];!Z.J&&Z.I&&V.a.P(Z.I,function(E,I){I.s&&I.s()}),Z.l&&Z.Rb&&V.a.K.yb(Z.l,Z.Rb),Z.I=t,Z.V=0,Z.ra=!0,Z.sa=!1,Z.ka=!1,Z.J=!1,Z.l=t,Z.Sa=t,Z.Wc=t,this.Nc||(Z.nb=t)}},y={Qa:function(Z){var E=this,I=E[g];if(!I.ra&&I.J&&Z=="change"){if(I.J=!1,I.sa||E.Xa())I.I=null,I.V=0,E.ha()&&E.Gb();else{var B=[];V.a.P(I.I,function(X,_){B[_.Ka]=X}),V.a.D(B,function(X,_){var P=I.I[X],w=E.$c(P.da);w.Ka=_,w.La=P.La,I.I[X]=w}),E.Xa()&&E.ha()&&E.Gb()}I.ra||E.notifySubscribers(I.X,"awake")}},hb:function(Z){var E=this[g];E.ra||Z!="change"||this.Wa("change")||(V.a.P(E.I,function(I,B){B.s&&(E.I[I]={da:B.da,Ka:B.Ka,La:B.La},B.s())}),E.J=!0,this.notifySubscribers(t,"asleep"))},ob:function(){var Z=this[g];return Z.J&&(Z.sa||this.Xa())&&this.ha(),V.T.fn.ob.call(this)}},Y={Qa:function(Z){Z!="change"&&Z!="beforeChange"||this.v()}};V.a.Ba&&V.a.setPrototypeOf(C,V.T.fn);var Q=V.ta.Ma;C[Q]=V.o,V.Oc=function(Z){return typeof Z=="function"&&Z[Q]===C[Q]},V.Fd=function(Z){return V.Oc(Z)&&Z[g]&&Z[g].wb},V.b("computed",V.o),V.b("dependentObservable",V.o),V.b("isComputed",V.Oc),V.b("isPureComputed",V.Fd),V.b("computed.fn",C),V.L(C,"peek",C.v),V.L(C,"dispose",C.s),V.L(C,"isActive",C.ja),V.L(C,"getDependenciesCount",C.qa),V.L(C,"getDependencies",C.Va),V.xb=function(Z,E){return typeof Z=="function"?V.o(Z,E,{pure:!0}):(Z=V.a.extend({},Z),Z.pure=!0,V.o(Z,E))},V.b("pureComputed",V.xb),function(){function Z(B,X,_){if(_=_||new I,B=X(B),typeof B!="object"||B===null||B===t||B instanceof RegExp||B instanceof Date||B instanceof String||B instanceof Number||B instanceof Boolean)return B;var P=B instanceof Array?[]:{};return _.save(B,P),E(B,function(w){var z=X(B[w]);switch(typeof z){case"boolean":case"number":case"string":case"function":P[w]=z;break;case"object":case"undefined":var H=_.get(z);P[w]=H!==t?H:Z(z,X,_)}}),P}function E(B,X){if(B instanceof Array){for(var _=0;_<B.length;_++)X(_);typeof B.toJSON=="function"&&X("toJSON")}else for(_ in B)X(_)}function I(){this.keys=[],this.values=[]}V.ad=function(B){if(arguments.length==0)throw Error("When calling ko.toJS, pass the object you want to convert.");return Z(B,function(X){for(var _=0;V.O(X)&&10>_;_++)X=X();return X})},V.toJSON=function(B,X,_){return B=V.ad(B),V.a.hc(B,X,_)},I.prototype={constructor:I,save:function(B,X){var _=V.a.A(this.keys,B);0<=_?this.values[_]=X:(this.keys.push(B),this.values.push(X))},get:function(B){return B=V.a.A(this.keys,B),0<=B?this.values[B]:t}}}(),V.b("toJS",V.ad),V.b("toJSON",V.toJSON),V.Wd=function(Z,E,I){function B(X){var _=V.xb(Z,I).extend({ma:"always"}),P=_.subscribe(function(w){w&&(P.s(),X(w))});return _.notifySubscribers(_.v()),P}return typeof Promise!="function"||E?B(E.bind(I)):new Promise(B)},V.b("when",V.Wd),function(){V.w={M:function(Z){switch(V.a.R(Z)){case"option":return Z.__ko__hasDomDataOptionValue__===!0?V.a.g.get(Z,V.c.options.$b):7>=V.a.W?Z.getAttributeNode("value")&&Z.getAttributeNode("value").specified?Z.value:Z.text:Z.value;case"select":return 0<=Z.selectedIndex?V.w.M(Z.options[Z.selectedIndex]):t;default:return Z.value}},cb:function(Z,E,I){switch(V.a.R(Z)){case"option":typeof E=="string"?(V.a.g.set(Z,V.c.options.$b,t),"__ko__hasDomDataOptionValue__"in Z&&delete Z.__ko__hasDomDataOptionValue__,Z.value=E):(V.a.g.set(Z,V.c.options.$b,E),Z.__ko__hasDomDataOptionValue__=!0,Z.value=typeof E=="number"?E:"");break;case"select":(E===""||E===null)&&(E=t);for(var B=-1,X=0,_=Z.options.length,P;X<_;++X)if(P=V.w.M(Z.options[X]),P==E||P===""&&E===t){B=X;break}(I||0<=B||E===t&&1<Z.size)&&(Z.selectedIndex=B,V.a.W===6&&V.a.setTimeout(function(){Z.selectedIndex=B},0));break;default:(E===null||E===t)&&(E=""),Z.value=E}}}}(),V.b("selectExtensions",V.w),V.b("selectExtensions.readValue",V.w.M),V.b("selectExtensions.writeValue",V.w.cb),V.m=function(){function Z(w){w=V.a.Db(w),w.charCodeAt(0)===123&&(w=w.slice(1,-1)),w+=` ,`;var z=[],H=w.match(B),nt,$=[],dt=0;if(1<H.length){for(var q=0,at;at=H[q];++q){var st=at.charCodeAt(0);if(st===44){if(0>=dt){z.push(nt&&$.length?{key:nt,value:$.join("")}:{unknown:nt||$.join("")}),nt=dt=0,$=[];continue}}else if(st===58){if(!dt&&!nt&&$.length===1){nt=$.pop();continue}}else{if(st===47&&1<at.length&&(at.charCodeAt(1)===47||at.charCodeAt(1)===42))continue;st===47&&q&&1<at.length?(st=H[q-1].match(X))&&!_[st[0]]&&(w=w.substr(w.indexOf(at)+1),H=w.match(B),q=-1,at="/"):st===40||st===123||st===91?++dt:st===41||st===125||st===93?--dt:nt||$.length||st!==34&&st!==39||(at=at.slice(1,-1))}$.push(at)}if(0<dt)throw Error("Unbalanced parentheses, braces, or brackets")}return z}var E=["true","false","null","undefined"],I=/^(?:[$_a-z][$\w]*|(.+)(\.\s*[$_a-z][$\w]*|\[.+\]))$/i,B=RegExp(`"(?:\\\\.|[^"])*"|'(?:\\\\.|[^'])*'|\`(?:\\\\.|[^\`])*\`|/\\*(?:[^*]|\\*+[^*/])*\\*+/|//.* -|/(?:\\\\.|[^/])+/w*|[^\\s:,/][^,"'\`{}()/:[\\]]*[^\\s,"'\`{}()/:[\\]]|[^\\s]`,"g"),X=/[\])"'A-Za-z0-9_$]+$/,_={in:1,return:1,typeof:1},P={};return{Ra:[],wa:P,ac:V,vb:function(w,z){function H(st,Et){var Qt;if(!q){var Wt=u.getBindingHandler(st);if(Wt&&Wt.preprocess&&!(Et=Wt.preprocess(Et,st,H)))return;(Wt=P[st])&&(Qt=Et,0<=u.a.A(E,Qt)?Qt=!1:(Wt=Qt.match(I),Qt=Wt===null?!1:Wt[1]?"Object("+Wt[1]+")"+Wt[2]:Qt),Wt=Qt),Wt&&$.push("'"+(typeof P[st]=="string"?P[st]:st)+"':function(_z){"+Qt+"=_z}")}dt&&(Et="function(){return "+Et+" }"),nt.push("'"+st+"':"+Et)}z=z||{};var nt=[],$=[],dt=z.valueAccessors,q=z.bindingParams,at=typeof w=="string"?V(w):w;return u.a.D(at,function(st){H(st.key||st.unknown,st.value)}),$.length&&H("_ko_property_writers","{"+$.join(",")+" }"),nt.join(",")},Id:function(w,z){for(var H=0;H<w.length;H++)if(w[H].key==z)return!0;return!1},eb:function(w,z,H,nt,$){w&&u.O(w)?!u.Za(w)||$&&w.v()===nt||w(nt):(w=z.get("_ko_property_writers"))&&w[H]&&w[H](nt)}}}(),u.b("expressionRewriting",u.m),u.b("expressionRewriting.bindingRewriteValidators",u.m.Ra),u.b("expressionRewriting.parseObjectLiteral",u.m.ac),u.b("expressionRewriting.preProcessBindings",u.m.vb),u.b("expressionRewriting._twoWayBindings",u.m.wa),u.b("jsonExpressionRewriting",u.m),u.b("jsonExpressionRewriting.insertPropertyAccessorsIntoJson",u.m.vb),function(){function V(H){return H.nodeType==8&&_.test(X?H.text:H.nodeValue)}function E(H){return H.nodeType==8&&P.test(X?H.text:H.nodeValue)}function I(H,nt){for(var $=H,dt=1,q=[];$=$.nextSibling;){if(E($)&&(u.a.g.set($,z,!0),dt--,dt===0))return q;q.push($),V($)&&dt++}if(!nt)throw Error("Cannot find closing comment tag to match: "+H.nodeValue);return null}function B(H,nt){var $=I(H,nt);return $?0<$.length?$[$.length-1].nextSibling:H.nextSibling:null}var X=n&&n.createComment("test").text==="<!--test-->",_=X?/^\x3c!--\s*ko(?:\s+([\s\S]+))?\s*--\x3e$/:/^\s*ko(?:\s+([\s\S]+))?\s*$/,P=X?/^\x3c!--\s*\/ko\s*--\x3e$/:/^\s*\/ko\s*$/,w={ul:!0,ol:!0},z="__ko_matchedEndComment__";u.h={ea:{},childNodes:function(H){return V(H)?I(H):H.childNodes},Ea:function(H){if(V(H)){H=u.h.childNodes(H);for(var nt=0,$=H.length;nt<$;nt++)u.removeNode(H[nt])}else u.a.Tb(H)},va:function(H,nt){if(V(H)){u.h.Ea(H);for(var $=H.nextSibling,dt=0,q=nt.length;dt<q;dt++)$.parentNode.insertBefore(nt[dt],$)}else u.a.va(H,nt)},Vc:function(H,nt){var $;V(H)?($=H.nextSibling,H=H.parentNode):$=H.firstChild,$?nt!==$&&H.insertBefore(nt,$):H.appendChild(nt)},Wb:function(H,nt,$){$?($=$.nextSibling,V(H)&&(H=H.parentNode),$?nt!==$&&H.insertBefore(nt,$):H.appendChild(nt)):u.h.Vc(H,nt)},firstChild:function(H){if(V(H))return!H.nextSibling||E(H.nextSibling)?null:H.nextSibling;if(H.firstChild&&E(H.firstChild))throw Error("Found invalid end comment, as the first child of "+H);return H.firstChild},nextSibling:function(H){if(V(H)&&(H=B(H)),H.nextSibling&&E(H.nextSibling)){var nt=H.nextSibling;if(E(nt)&&!u.a.g.get(nt,z))throw Error("Found end comment without a matching opening comment, as child of "+H);return null}return H.nextSibling},Cd:V,Vd:function(H){return(H=(X?H.text:H.nodeValue).match(_))?H[1]:null},Sc:function(H){if(w[u.a.R(H)]){var nt=H.firstChild;if(nt)do if(nt.nodeType===1){var $;$=nt.firstChild;var dt=null;if($)do if(dt)dt.push($);else if(V($)){var q=B($,!0);q?$=q:dt=[$]}else E($)&&(dt=[$]);while($=$.nextSibling);if($=dt)for(dt=nt.nextSibling,q=0;q<$.length;q++)dt?H.insertBefore($[q],dt):H.appendChild($[q])}while(nt=nt.nextSibling)}}}}(),u.b("virtualElements",u.h),u.b("virtualElements.allowedBindings",u.h.ea),u.b("virtualElements.emptyNode",u.h.Ea),u.b("virtualElements.insertAfter",u.h.Wb),u.b("virtualElements.prepend",u.h.Vc),u.b("virtualElements.setDomNodeChildren",u.h.va),function(){u.ga=function(){this.nd={}},u.a.extend(u.ga.prototype,{nodeHasBindings:function(V){switch(V.nodeType){case 1:return V.getAttribute("data-bind")!=null||u.j.getComponentNameForNode(V);case 8:return u.h.Cd(V);default:return!1}},getBindings:function(V,E){var I=this.getBindingsString(V,E),I=I?this.parseBindingsString(I,E,V):null;return u.j.tc(I,V,E,!1)},getBindingAccessors:function(V,E){var I=this.getBindingsString(V,E),I=I?this.parseBindingsString(I,E,V,{valueAccessors:!0}):null;return u.j.tc(I,V,E,!0)},getBindingsString:function(V){switch(V.nodeType){case 1:return V.getAttribute("data-bind");case 8:return u.h.Vd(V);default:return null}},parseBindingsString:function(V,E,I,B){try{var X=this.nd,_=V+(B&&B.valueAccessors||""),P;if(!(P=X[_])){var w,z="with($context){with($data||{}){return{"+u.m.vb(V,B)+"}}}";w=new Function("$context","$element",z),P=X[_]=w}return P(E,I)}catch(H){throw H.message=`Unable to parse bindings. -Bindings value: `+V+` -Message: `+H.message,H}}}),u.ga.instance=new u.ga}(),u.b("bindingProvider",u.ga),function(){function V(Wt){var Nt=(Wt=u.a.g.get(Wt,Qt))&&Wt.N;Nt&&(Wt.N=null,Nt.Tc())}function E(Wt,Nt,kt){this.node=Wt,this.yc=Nt,this.kb=[],this.H=!1,Nt.N||u.a.K.za(Wt,V),kt&&kt.N&&(kt.N.kb.push(Wt),this.Kb=kt)}function I(Wt){return function(){return Wt}}function B(Wt){return Wt()}function X(Wt){return u.a.Ga(u.u.G(Wt),function(Nt,kt){return function(){return Wt()[kt]}})}function _(Wt,Nt,kt){return typeof Wt=="function"?X(Wt.bind(null,Nt,kt)):u.a.Ga(Wt,I)}function P(Wt,Nt){return X(this.getBindings.bind(this,Wt,Nt))}function w(Wt,Nt){var kt=u.h.firstChild(Nt);if(kt){var Mt,qt=u.ga.instance,ie=qt.preprocessNode;if(ie){for(;Mt=kt;)kt=u.h.nextSibling(Mt),ie.call(qt,Mt);kt=u.h.firstChild(Nt)}for(;Mt=kt;)kt=u.h.nextSibling(Mt),z(Wt,Mt)}u.i.ma(Nt,u.i.H)}function z(Wt,Nt){var kt=Wt,Mt=Nt.nodeType===1;Mt&&u.h.Sc(Nt),(Mt||u.ga.instance.nodeHasBindings(Nt))&&(kt=nt(Nt,null,Wt).bindingContextForDescendants),kt&&!st[u.a.R(Nt)]&&w(kt,Nt)}function H(Wt){var Nt=[],kt={},Mt=[];return u.a.P(Wt,function qt(ie){if(!kt[ie]){var oe=u.getBindingHandler(ie);oe&&(oe.after&&(Mt.push(ie),u.a.D(oe.after,function(He){if(Wt[He]){if(u.a.A(Mt,He)!==-1)throw Error("Cannot combine the following bindings, because they have a cyclic dependency: "+Mt.join(", "));qt(He)}}),Mt.length--),Nt.push({key:ie,Mc:oe})),kt[ie]=!0}}),Nt}function nt(Wt,Nt,kt){var Mt=u.a.g.Ub(Wt,Qt,{}),qt=Mt.hd;if(!Nt){if(qt)throw Error("You cannot apply bindings multiple times to the same element.");Mt.hd=!0}qt||(Mt.context=kt),Mt.Zb||(Mt.Zb={});var ie;if(Nt&&typeof Nt!="function")ie=Nt;else{var oe=u.ga.instance,He=oe.getBindingAccessors||P,rn=u.$(function(){return(ie=Nt?Nt(kt,Wt):He.call(oe,Wt,kt))&&(kt[dt]&&kt[dt](),kt[at]&&kt[at]()),ie},null,{l:Wt});ie&&rn.ja()||(rn=null)}var de=kt,zt;if(ie){var ke=function(){return u.a.Ga(rn?rn():ie,B)},ue=rn?function(We){return function(){return B(rn()[We])}}:function(We){return ie[We]};ke.get=function(We){return ie[We]&&B(ue(We))},ke.has=function(We){return We in ie},u.i.H in ie&&u.i.subscribe(Wt,u.i.H,function(){var We=(0,ie[u.i.H])();if(We){var un=u.h.childNodes(Wt);un.length&&We(un,u.Ec(un[0]))}}),u.i.pa in ie&&(de=u.i.Cb(Wt,kt),u.i.subscribe(Wt,u.i.pa,function(){var We=(0,ie[u.i.pa])();We&&u.h.firstChild(Wt)&&We(Wt)})),Mt=H(ie),u.a.D(Mt,function(We){var un=We.Mc.init,Ct=We.Mc.update,_t=We.key;if(Wt.nodeType===8&&!u.h.ea[_t])throw Error("The binding '"+_t+"' cannot be used with virtual elements");try{typeof un=="function"&&u.u.G(function(){var Je=un(Wt,ue(_t),ke,de.$data,de);if(Je&&Je.controlsDescendantBindings){if(zt!==t)throw Error("Multiple bindings ("+zt+" and "+_t+") are trying to control descendant bindings of the same element. You cannot use these bindings together on the same element.");zt=_t}}),typeof Ct=="function"&&u.$(function(){Ct(Wt,ue(_t),ke,de.$data,de)},null,{l:Wt})}catch(Je){throw Je.message='Unable to process binding "'+_t+": "+ie[_t]+`" -Message: `+Je.message,Je}})}return Mt=zt===t,{shouldBindDescendants:Mt,bindingContextForDescendants:Mt&&de}}function $(Wt,Nt){return Wt&&Wt instanceof u.fa?Wt:new u.fa(Wt,t,t,Nt)}var dt=u.a.Da("_subscribable"),q=u.a.Da("_ancestorBindingInfo"),at=u.a.Da("_dataDependency");u.c={};var st={script:!0,textarea:!0,template:!0};u.getBindingHandler=function(Wt){return u.c[Wt]};var Et={};u.fa=function(Wt,Nt,kt,Mt,qt){function ie(){var ue=de?rn():rn,We=u.a.f(ue);return Nt?(u.a.extend(oe,Nt),q in Nt&&(oe[q]=Nt[q])):(oe.$parents=[],oe.$root=We,oe.ko=u),oe[dt]=zt,He?We=oe.$data:(oe.$rawData=ue,oe.$data=We),kt&&(oe[kt]=We),Mt&&Mt(oe,Nt,We),Nt&&Nt[dt]&&!u.S.o().Vb(Nt[dt])&&Nt[dt](),ke&&(oe[at]=ke),oe.$data}var oe=this,He=Wt===Et,rn=He?t:Wt,de=typeof rn=="function"&&!u.O(rn),zt,ke=qt&&qt.dataDependency;qt&&qt.exportDependencies?ie():(zt=u.xb(ie),zt.v(),zt.ja()?zt.equalityComparer=null:oe[dt]=t)},u.fa.prototype.createChildContext=function(Wt,Nt,kt,Mt){if(!Mt&&Nt&&typeof Nt=="object"&&(Mt=Nt,Nt=Mt.as,kt=Mt.extend),Nt&&Mt&&Mt.noChildContext){var qt=typeof Wt=="function"&&!u.O(Wt);return new u.fa(Et,this,null,function(ie){kt&&kt(ie),ie[Nt]=qt?Wt():Wt},Mt)}return new u.fa(Wt,this,Nt,function(ie,oe){ie.$parentContext=oe,ie.$parent=oe.$data,ie.$parents=(oe.$parents||[]).slice(0),ie.$parents.unshift(ie.$parent),kt&&kt(ie)},Mt)},u.fa.prototype.extend=function(Wt,Nt){return new u.fa(Et,this,null,function(kt){u.a.extend(kt,typeof Wt=="function"?Wt(kt):Wt)},Nt)};var Qt=u.a.g.Z();E.prototype.Tc=function(){this.Kb&&this.Kb.N&&this.Kb.N.sd(this.node)},E.prototype.sd=function(Wt){u.a.Pa(this.kb,Wt),!this.kb.length&&this.H&&this.Cc()},E.prototype.Cc=function(){this.H=!0,this.yc.N&&!this.kb.length&&(this.yc.N=null,u.a.K.yb(this.node,V),u.i.ma(this.node,u.i.pa),this.Tc())},u.i={H:"childrenComplete",pa:"descendantsComplete",subscribe:function(Wt,Nt,kt,Mt,qt){var ie=u.a.g.Ub(Wt,Qt,{});return ie.Fa||(ie.Fa=new u.T),qt&&qt.notifyImmediately&&ie.Zb[Nt]&&u.u.G(kt,Mt,[Wt]),ie.Fa.subscribe(kt,Mt,Nt)},ma:function(Wt,Nt){var kt=u.a.g.get(Wt,Qt);if(kt&&(kt.Zb[Nt]=!0,kt.Fa&&kt.Fa.notifySubscribers(Wt,Nt),Nt==u.i.H)){if(kt.N)kt.N.Cc();else if(kt.N===t&&kt.Fa&&kt.Fa.Wa(u.i.pa))throw Error("descendantsComplete event not supported for bindings on this node")}},Cb:function(Wt,Nt){var kt=u.a.g.Ub(Wt,Qt,{});return kt.N||(kt.N=new E(Wt,kt,Nt[q])),Nt[q]==kt?Nt:Nt.extend(function(Mt){Mt[q]=kt})}},u.Td=function(Wt){return(Wt=u.a.g.get(Wt,Qt))&&Wt.context},u.ib=function(Wt,Nt,kt){return Wt.nodeType===1&&u.h.Sc(Wt),nt(Wt,Nt,$(kt))},u.ld=function(Wt,Nt,kt){return kt=$(kt),u.ib(Wt,_(Nt,kt,Wt),kt)},u.Oa=function(Wt,Nt){Nt.nodeType!==1&&Nt.nodeType!==8||w($(Wt),Nt)},u.vc=function(Wt,Nt,kt){if(!o&&e.jQuery&&(o=e.jQuery),2>arguments.length){if(Nt=n.body,!Nt)throw Error("ko.applyBindings: could not find document.body; has the document been loaded?")}else if(!Nt||Nt.nodeType!==1&&Nt.nodeType!==8)throw Error("ko.applyBindings: first parameter should be your view model; second parameter should be a DOM node");z($(Wt,kt),Nt)},u.Dc=function(Wt){return!Wt||Wt.nodeType!==1&&Wt.nodeType!==8?t:u.Td(Wt)},u.Ec=function(Wt){return(Wt=u.Dc(Wt))?Wt.$data:t},u.b("bindingHandlers",u.c),u.b("bindingEvent",u.i),u.b("bindingEvent.subscribe",u.i.subscribe),u.b("bindingEvent.startPossiblyAsyncContentBinding",u.i.Cb),u.b("applyBindings",u.vc),u.b("applyBindingsToDescendants",u.Oa),u.b("applyBindingAccessorsToNode",u.ib),u.b("applyBindingsToNode",u.ld),u.b("contextFor",u.Dc),u.b("dataFor",u.Ec)}(),function(V){function E(P,w){var z=Object.prototype.hasOwnProperty.call(X,P)?X[P]:V,H;z?z.subscribe(w):(z=X[P]=new u.T,z.subscribe(w),I(P,function(nt,$){var dt=!(!$||!$.synchronous);_[P]={definition:nt,Gd:dt},delete X[P],H||dt?z.notifySubscribers(nt):u.na.zb(function(){z.notifySubscribers(nt)})}),H=!0)}function I(P,w){B("getConfig",[P],function(z){z?B("loadComponent",[P,z],function(H){w(H,z)}):w(null,null)})}function B(P,w,z,H){H||(H=u.j.loaders.slice(0));var nt=H.shift();if(nt){var $=nt[P];if($){var dt=!1;if($.apply(nt,w.concat(function(q){dt?z(null):q!==null?z(q):B(P,w,z,H)}))!==V&&(dt=!0,!nt.suppressLoaderExceptions))throw Error("Component loaders must supply values by invoking the callback, not by returning values synchronously.")}else B(P,w,z,H)}else z(null)}var X={},_={};u.j={get:function(P,w){var z=Object.prototype.hasOwnProperty.call(_,P)?_[P]:V;z?z.Gd?u.u.G(function(){w(z.definition)}):u.na.zb(function(){w(z.definition)}):E(P,w)},Bc:function(P){delete _[P]},oc:B},u.j.loaders=[],u.b("components",u.j),u.b("components.get",u.j.get),u.b("components.clearCachedDefinition",u.j.Bc)}(),function(){function V(z,H,nt,$){function dt(){--at===0&&$(q)}var q={},at=2,st=nt.template;nt=nt.viewModel,st?X(H,st,function(Et){u.j.oc("loadTemplate",[z,Et],function(Qt){q.template=Qt,dt()})}):dt(),nt?X(H,nt,function(Et){u.j.oc("loadViewModel",[z,Et],function(Qt){q[w]=Qt,dt()})}):dt()}function E(z,H,nt){if(typeof H=="function")nt(function(dt){return new H(dt)});else if(typeof H[w]=="function")nt(H[w]);else if("instance"in H){var $=H.instance;nt(function(){return $})}else"viewModel"in H?E(z,H.viewModel,nt):z("Unknown viewModel value: "+H)}function I(z){switch(u.a.R(z)){case"script":return u.a.ua(z.text);case"textarea":return u.a.ua(z.value);case"template":if(B(z.content))return u.a.Ca(z.content.childNodes)}return u.a.Ca(z.childNodes)}function B(z){return e.DocumentFragment?z instanceof DocumentFragment:z&&z.nodeType===11}function X(z,H,nt){typeof H.require=="string"?l||e.require?(l||e.require)([H.require],function($){$&&typeof $=="object"&&$.Xd&&$.default&&($=$.default),nt($)}):z("Uses require, but no AMD loader is present"):nt(H)}function _(z){return function(H){throw Error("Component '"+z+"': "+H)}}var P={};u.j.register=function(z,H){if(!H)throw Error("Invalid configuration for "+z);if(u.j.tb(z))throw Error("Component "+z+" is already registered");P[z]=H},u.j.tb=function(z){return Object.prototype.hasOwnProperty.call(P,z)},u.j.unregister=function(z){delete P[z],u.j.Bc(z)},u.j.Fc={getConfig:function(z,H){H(u.j.tb(z)?P[z]:null)},loadComponent:function(z,H,nt){var $=_(z);X($,H,function(dt){V(z,$,dt,nt)})},loadTemplate:function(z,H,nt){if(z=_(z),typeof H=="string")nt(u.a.ua(H));else if(H instanceof Array)nt(H);else if(B(H))nt(u.a.la(H.childNodes));else if(H.element)if(H=H.element,e.HTMLElement?H instanceof HTMLElement:H&&H.tagName&&H.nodeType===1)nt(I(H));else if(typeof H=="string"){var $=n.getElementById(H);$?nt(I($)):z("Cannot find element with ID "+H)}else z("Unknown element type: "+H);else z("Unknown template value: "+H)},loadViewModel:function(z,H,nt){E(_(z),H,nt)}};var w="createViewModel";u.b("components.register",u.j.register),u.b("components.isRegistered",u.j.tb),u.b("components.unregister",u.j.unregister),u.b("components.defaultLoader",u.j.Fc),u.j.loaders.push(u.j.Fc),u.j.dd=P}(),function(){function V(I,B){var X=I.getAttribute("params");if(X){var X=E.parseBindingsString(X,B,I,{valueAccessors:!0,bindingParams:!0}),X=u.a.Ga(X,function(w){return u.o(w,null,{l:I})}),_=u.a.Ga(X,function(w){var z=w.v();return w.ja()?u.o({read:function(){return u.a.f(w())},write:u.Za(z)&&function(H){w()(H)},l:I}):z});return Object.prototype.hasOwnProperty.call(_,"$raw")||(_.$raw=X),_}return{$raw:{}}}u.j.getComponentNameForNode=function(I){var B=u.a.R(I);if(u.j.tb(B)&&(B.indexOf("-")!=-1||""+I=="[object HTMLUnknownElement]"||8>=u.a.W&&I.tagName===B))return B},u.j.tc=function(I,B,X,_){if(B.nodeType===1){var P=u.j.getComponentNameForNode(B);if(P){if(I=I||{},I.component)throw Error('Cannot use the "component" binding on a custom element matching a component');var w={name:P,params:V(B,X)};I.component=_?function(){return w}:w}}return I};var E=new u.ga;9>u.a.W&&(u.j.register=function(I){return function(B){return I.apply(this,arguments)}}(u.j.register),n.createDocumentFragment=function(I){return function(){var B=I(),X=u.j.dd,_;for(_ in X);return B}}(n.createDocumentFragment))}(),function(){function V(B,X,_){if(X=X.template,!X)throw Error("Component '"+B+"' has no template");B=u.a.Ca(X),u.h.va(_,B)}function E(B,X,_){var P=B.createViewModel;return P?P.call(B,X,_):X}var I=0;u.c.component={init:function(B,X,_,P,w){function z(){var q=H&&H.dispose;typeof q=="function"&&q.call(H),$&&$.s(),nt=H=$=null}var H,nt,$,dt=u.a.la(u.h.childNodes(B));return u.h.Ea(B),u.a.K.za(B,z),u.o(function(){var q=u.a.f(X()),at,st;if(typeof q=="string"?at=q:(at=u.a.f(q.name),st=u.a.f(q.params)),!at)throw Error("No component name specified");var Et=u.i.Cb(B,w),Qt=nt=++I;u.j.get(at,function(Wt){if(nt===Qt){if(z(),!Wt)throw Error("Unknown component '"+at+"'");V(at,Wt,B);var Nt=E(Wt,st,{element:B,templateNodes:dt});Wt=Et.createChildContext(Nt,{extend:function(kt){kt.$component=Nt,kt.$componentTemplateNodes=dt}}),Nt&&Nt.koDescendantsComplete&&($=u.i.subscribe(B,u.i.pa,Nt.koDescendantsComplete,Nt)),H=Nt,u.Oa(Wt,B)}})},null,{l:B}),{controlsDescendantBindings:!0}}},u.h.ea.component=!0}();var J={class:"className",for:"htmlFor"};u.c.attr={update:function(V,E){var I=u.a.f(E())||{};u.a.P(I,function(B,X){X=u.a.f(X);var _=B.indexOf(":"),_="lookupNamespaceURI"in V&&0<_&&V.lookupNamespaceURI(B.substr(0,_)),P=X===!1||X===null||X===t;P?_?V.removeAttributeNS(_,B):V.removeAttribute(B):X=X.toString(),8>=u.a.W&&B in J?(B=J[B],P?V.removeAttribute(B):V[B]=X):P||(_?V.setAttributeNS(_,B,X):V.setAttribute(B,X)),B==="name"&&u.a.Yc(V,P?"":X)})}},function(){u.c.checked={after:["value","attr"],init:function(V,E,I){function B(){var q=V.checked,at=_();if(!u.S.Ya()&&(q||!w&&!u.S.qa())){var st=u.u.G(E);if(H){var Et=nt?st.v():st,Qt=dt;dt=at,Qt!==at?q&&(u.a.Na(Et,at,!0),u.a.Na(Et,Qt,!1)):u.a.Na(Et,at,q),nt&&u.Za(st)&&st(Et)}else P&&(at===t?at=q:q||(at=t)),u.m.eb(st,I,"checked",at,!0)}}function X(){var q=u.a.f(E()),at=_();H?(V.checked=0<=u.a.A(q,at),dt=at):V.checked=P&&at===t?!!q:_()===q}var _=u.xb(function(){if(I.has("checkedValue"))return u.a.f(I.get("checkedValue"));if($)return I.has("value")?u.a.f(I.get("value")):V.value}),P=V.type=="checkbox",w=V.type=="radio";if(P||w){var z=E(),H=P&&u.a.f(z)instanceof Array,nt=!(H&&z.push&&z.splice),$=w||H,dt=H?_():t;w&&!V.name&&u.c.uniqueName.init(V,function(){return!0}),u.o(B,null,{l:V}),u.a.B(V,"click",B),u.o(X,null,{l:V}),z=t}}},u.m.wa.checked=!0,u.c.checkedValue={update:function(V,E){V.value=u.a.f(E())}}}(),u.c.class={update:function(V,E){var I=u.a.Db(u.a.f(E()));u.a.Eb(V,V.__ko__cssValue,!1),V.__ko__cssValue=I,u.a.Eb(V,I,!0)}},u.c.css={update:function(V,E){var I=u.a.f(E());I!==null&&typeof I=="object"?u.a.P(I,function(B,X){X=u.a.f(X),u.a.Eb(V,B,X)}):u.c.class.update(V,E)}},u.c.enable={update:function(V,E){var I=u.a.f(E());I&&V.disabled?V.removeAttribute("disabled"):I||V.disabled||(V.disabled=!0)}},u.c.disable={update:function(V,E){u.c.enable.update(V,function(){return!u.a.f(E())})}},u.c.event={init:function(V,E,I,B,X){var _=E()||{};u.a.P(_,function(P){typeof P=="string"&&u.a.B(V,P,function(w){var z,H=E()[P];if(H){try{var nt=u.a.la(arguments);B=X.$data,nt.unshift(B),z=H.apply(B,nt)}finally{z!==!0&&(w.preventDefault?w.preventDefault():w.returnValue=!1)}I.get(P+"Bubble")===!1&&(w.cancelBubble=!0,w.stopPropagation&&w.stopPropagation())}})})}},u.c.foreach={Rc:function(V){return function(){var E=V(),I=u.a.bc(E);return!I||typeof I.length=="number"?{foreach:E,templateEngine:u.ba.Ma}:(u.a.f(E),{foreach:I.data,as:I.as,noChildContext:I.noChildContext,includeDestroyed:I.includeDestroyed,afterAdd:I.afterAdd,beforeRemove:I.beforeRemove,afterRender:I.afterRender,beforeMove:I.beforeMove,afterMove:I.afterMove,templateEngine:u.ba.Ma})}},init:function(V,E){return u.c.template.init(V,u.c.foreach.Rc(E))},update:function(V,E,I,B,X){return u.c.template.update(V,u.c.foreach.Rc(E),I,B,X)}},u.m.Ra.foreach=!1,u.h.ea.foreach=!0,u.c.hasfocus={init:function(V,E,I){function B(P){V.__ko_hasfocusUpdating=!0;var w=V.ownerDocument;if("activeElement"in w){var z;try{z=w.activeElement}catch{z=w.body}P=z===V}w=E(),u.m.eb(w,I,"hasfocus",P,!0),V.__ko_hasfocusLastValue=P,V.__ko_hasfocusUpdating=!1}var X=B.bind(null,!0),_=B.bind(null,!1);u.a.B(V,"focus",X),u.a.B(V,"focusin",X),u.a.B(V,"blur",_),u.a.B(V,"focusout",_),V.__ko_hasfocusLastValue=!1},update:function(V,E){var I=!!u.a.f(E());V.__ko_hasfocusUpdating||V.__ko_hasfocusLastValue===I||(I?V.focus():V.blur(),!I&&V.__ko_hasfocusLastValue&&V.ownerDocument.body.focus(),u.u.G(u.a.Fb,null,[V,I?"focusin":"focusout"]))}},u.m.wa.hasfocus=!0,u.c.hasFocus=u.c.hasfocus,u.m.wa.hasFocus="hasfocus",u.c.html={init:function(){return{controlsDescendantBindings:!0}},update:function(V,E){u.a.fc(V,E())}},function(){function V(E,I,B){u.c[E]={init:function(X,_,P,w,z){var H,nt,$={},dt,q,at;if(I){w=P.get("as");var st=P.get("noChildContext");at=!(w&&st),$={as:w,noChildContext:st,exportDependencies:at}}return q=(dt=P.get("completeOn")=="render")||P.has(u.i.pa),u.o(function(){var Et=u.a.f(_()),Qt=!B!=!Et,Wt=!nt,Nt;(at||Qt!==H)&&(q&&(z=u.i.Cb(X,z)),Qt&&((!I||at)&&($.dataDependency=u.S.o()),Nt=I?z.createChildContext(typeof Et=="function"?Et:_,$):u.S.qa()?z.extend(null,$):z),Wt&&u.S.qa()&&(nt=u.a.Ca(u.h.childNodes(X),!0)),Qt?(Wt||u.h.va(X,u.a.Ca(nt)),u.Oa(Nt,X)):(u.h.Ea(X),dt||u.i.ma(X,u.i.H)),H=Qt)},null,{l:X}),{controlsDescendantBindings:!0}}},u.m.Ra[E]=!1,u.h.ea[E]=!0}V("if"),V("ifnot",!1,!0),V("with",!0)}(),u.c.let={init:function(V,E,I,B,X){return E=X.extend(E),u.Oa(E,V),{controlsDescendantBindings:!0}}},u.h.ea.let=!0;var M={};u.c.options={init:function(V){if(u.a.R(V)!=="select")throw Error("options binding applies only to SELECT elements");for(;0<V.length;)V.remove(0);return{controlsDescendantBindings:!0}},update:function(V,E,I){function B(){return u.a.jb(V.options,function(st){return st.selected})}function X(st,Et,Qt){var Wt=typeof Et;return Wt=="function"?Et(st):Wt=="string"?st[Et]:Qt}function _(st,Et){if(q&&H)u.i.ma(V,u.i.H);else if(dt.length){var Qt=0<=u.a.A(dt,u.w.M(Et[0]));u.a.Zc(Et[0],Qt),q&&!Qt&&u.u.G(u.a.Fb,null,[V,"change"])}}var P=V.multiple,w=V.length!=0&&P?V.scrollTop:null,z=u.a.f(E()),H=I.get("valueAllowUnset")&&I.has("value"),nt=I.get("optionsIncludeDestroyed");E={};var $,dt=[];H||(P?dt=u.a.Mb(B(),u.w.M):0<=V.selectedIndex&&dt.push(u.w.M(V.options[V.selectedIndex]))),z&&(typeof z.length>"u"&&(z=[z]),$=u.a.jb(z,function(st){return nt||st===t||st===null||!u.a.f(st._destroy)}),I.has("optionsCaption")&&(z=u.a.f(I.get("optionsCaption")),z!==null&&z!==t&&$.unshift(M)));var q=!1;if(E.beforeRemove=function(st){V.removeChild(st)},z=_,I.has("optionsAfterRender")&&typeof I.get("optionsAfterRender")=="function"&&(z=function(st,Et){_(0,Et),u.u.G(I.get("optionsAfterRender"),null,[Et[0],st!==M?st:t])}),u.a.ec(V,$,function(st,Et,Qt){return Qt.length&&(dt=!H&&Qt[0].selected?[u.w.M(Qt[0])]:[],q=!0),Et=V.ownerDocument.createElement("option"),st===M?(u.a.Bb(Et,I.get("optionsCaption")),u.w.cb(Et,t)):(Qt=X(st,I.get("optionsValue"),st),u.w.cb(Et,u.a.f(Qt)),st=X(st,I.get("optionsText"),Qt),u.a.Bb(Et,st)),[Et]},E,z),!H){var at;P?at=dt.length&&B().length<dt.length:at=dt.length&&0<=V.selectedIndex?u.w.M(V.options[V.selectedIndex])!==dt[0]:dt.length||0<=V.selectedIndex,at&&u.u.G(u.a.Fb,null,[V,"change"])}(H||u.S.Ya())&&u.i.ma(V,u.i.H),u.a.wd(V),w&&20<Math.abs(w-V.scrollTop)&&(V.scrollTop=w)}},u.c.options.$b=u.a.g.Z(),u.c.selectedOptions={init:function(V,E,I){function B(){var P=E(),w=[];u.a.D(V.getElementsByTagName("option"),function(z){z.selected&&w.push(u.w.M(z))}),u.m.eb(P,I,"selectedOptions",w)}function X(){var P=u.a.f(E()),w=V.scrollTop;P&&typeof P.length=="number"&&u.a.D(V.getElementsByTagName("option"),function(z){var H=0<=u.a.A(P,u.w.M(z));z.selected!=H&&u.a.Zc(z,H)}),V.scrollTop=w}if(u.a.R(V)!="select")throw Error("selectedOptions binding applies only to SELECT elements");var _;u.i.subscribe(V,u.i.H,function(){_?B():(u.a.B(V,"change",B),_=u.o(X,null,{l:V}))},null,{notifyImmediately:!0})},update:function(){}},u.m.wa.selectedOptions=!0,u.c.style={update:function(V,E){var I=u.a.f(E()||{});u.a.P(I,function(B,X){if(X=u.a.f(X),(X===null||X===t||X===!1)&&(X=""),o)o(V).css(B,X);else if(/^--/.test(B))V.style.setProperty(B,X);else{B=B.replace(/-(\w)/g,function(P,w){return w.toUpperCase()});var _=V.style[B];V.style[B]=X,X===_||V.style[B]!=_||isNaN(X)||(V.style[B]=X+"px")}})}},u.c.submit={init:function(V,E,I,B,X){if(typeof E()!="function")throw Error("The value for a submit binding must be a function");u.a.B(V,"submit",function(_){var P,w=E();try{P=w.call(X.$data,V)}finally{P!==!0&&(_.preventDefault?_.preventDefault():_.returnValue=!1)}})}},u.c.text={init:function(){return{controlsDescendantBindings:!0}},update:function(V,E){u.a.Bb(V,E())}},u.h.ea.text=!0,function(){if(e&&e.navigator){var V=function($){if($)return parseFloat($[1])},E=e.navigator.userAgent,I,B,X,_,P;(I=e.opera&&e.opera.version&&parseInt(e.opera.version()))||(P=V(E.match(/Edge\/([^ ]+)$/)))||V(E.match(/Chrome\/([^ ]+)/))||(B=V(E.match(/Version\/([^ ]+) Safari/)))||(X=V(E.match(/Firefox\/([^ ]+)/)))||(_=u.a.W||V(E.match(/MSIE ([^ ]+)/)))||(_=V(E.match(/rv:([^ )]+)/)))}if(8<=_&&10>_)var w=u.a.g.Z(),z=u.a.g.Z(),H=function($){var dt=this.activeElement;(dt=dt&&u.a.g.get(dt,z))&&dt($)},nt=function($,dt){var q=$.ownerDocument;u.a.g.get(q,w)||(u.a.g.set(q,w,!0),u.a.B(q,"selectionchange",H)),u.a.g.set($,z,dt)};u.c.textInput={init:function($,dt,q){function at(ie,oe){u.a.B($,ie,oe)}function st(){var ie=u.a.f(dt());(ie===null||ie===t)&&(ie=""),kt!==t&&ie===kt?u.a.setTimeout(st,4):$.value!==ie&&(qt=!0,$.value=ie,qt=!1,Wt=$.value)}function Et(){Nt||(kt=$.value,Nt=u.a.setTimeout(Qt,4))}function Qt(){clearTimeout(Nt),kt=Nt=t;var ie=$.value;Wt!==ie&&(Wt=ie,u.m.eb(dt(),q,"textInput",ie))}var Wt=$.value,Nt,kt,Mt=u.a.W==9?Et:Qt,qt=!1;_&&at("keypress",Qt),11>_&&at("propertychange",function(ie){qt||ie.propertyName!=="value"||Mt(ie)}),_==8&&(at("keyup",Qt),at("keydown",Qt)),nt&&(nt($,Mt),at("dragend",Et)),(!_||9<=_)&&at("input",Mt),5>B&&u.a.R($)==="textarea"?(at("keydown",Et),at("paste",Et),at("cut",Et)):11>I?at("keydown",Et):4>X?(at("DOMAutoComplete",Qt),at("dragdrop",Qt),at("drop",Qt)):P&&$.type==="number"&&at("keydown",Et),at("change",Qt),at("blur",Qt),u.o(st,null,{l:$})}},u.m.wa.textInput=!0,u.c.textinput={preprocess:function($,dt,q){q("textInput",$)}}}(),u.c.uniqueName={init:function(V,E){if(E()){var I="ko_unique_"+ ++u.c.uniqueName.rd;u.a.Yc(V,I)}}},u.c.uniqueName.rd=0,u.c.using={init:function(V,E,I,B,X){var _;return I.has("as")&&(_={as:I.get("as"),noChildContext:I.get("noChildContext")}),E=X.createChildContext(E,_),u.Oa(E,V),{controlsDescendantBindings:!0}}},u.h.ea.using=!0,u.c.value={init:function(V,E,I){var B=u.a.R(V),X=B=="input";if(!X||V.type!="checkbox"&&V.type!="radio"){var _=[],P=I.get("valueUpdate"),w=!1,z=null;P&&(typeof P=="string"?_=[P]:_=u.a.wc(P),u.a.Pa(_,"change"));var H=function(){z=null,w=!1;var dt=E(),q=u.w.M(V);u.m.eb(dt,I,"value",q)};!u.a.W||!X||V.type!="text"||V.autocomplete=="off"||V.form&&V.form.autocomplete=="off"||u.a.A(_,"propertychange")!=-1||(u.a.B(V,"propertychange",function(){w=!0}),u.a.B(V,"focus",function(){w=!1}),u.a.B(V,"blur",function(){w&&H()})),u.a.D(_,function(dt){var q=H;u.a.Ud(dt,"after")&&(q=function(){z=u.w.M(V),u.a.setTimeout(H,0)},dt=dt.substring(5)),u.a.B(V,dt,q)});var nt;if(nt=X&&V.type=="file"?function(){var dt=u.a.f(E());dt===null||dt===t||dt===""?V.value="":u.u.G(H)}:function(){var dt=u.a.f(E()),q=u.w.M(V);z!==null&&dt===z?u.a.setTimeout(nt,0):(dt!==q||q===t)&&(B==="select"?(q=I.get("valueAllowUnset"),u.w.cb(V,dt,q),q||dt===u.w.M(V)||u.u.G(H)):u.w.cb(V,dt))},B==="select"){var $;u.i.subscribe(V,u.i.H,function(){$?I.get("valueAllowUnset")?nt():H():(u.a.B(V,"change",H),$=u.o(nt,null,{l:V}))},null,{notifyImmediately:!0})}else u.a.B(V,"change",H),u.o(nt,null,{l:V})}else u.ib(V,{checkedValue:E})},update:function(){}},u.m.wa.value=!0,u.c.visible={update:function(V,E){var I=u.a.f(E()),B=V.style.display!="none";I&&!B?V.style.display="":!I&&B&&(V.style.display="none")}},u.c.hidden={update:function(V,E){u.c.visible.update(V,function(){return!u.a.f(E())})}},function(V){u.c[V]={init:function(E,I,B,X,_){return u.c.event.init.call(this,E,function(){var P={};return P[V]=I(),P},B,X,_)}}}("click"),u.ca=function(){},u.ca.prototype.renderTemplateSource=function(){throw Error("Override renderTemplateSource")},u.ca.prototype.createJavaScriptEvaluatorBlock=function(){throw Error("Override createJavaScriptEvaluatorBlock")},u.ca.prototype.makeTemplateSource=function(V,E){if(typeof V=="string"){E=E||n;var I=E.getElementById(V);if(!I)throw Error("Cannot find template with ID "+V);return new u.C.F(I)}if(V.nodeType==1||V.nodeType==8)return new u.C.ia(V);throw Error("Unknown template type: "+V)},u.ca.prototype.renderTemplate=function(V,E,I,B){return V=this.makeTemplateSource(V,B),this.renderTemplateSource(V,E,I,B)},u.ca.prototype.isTemplateRewritten=function(V,E){return this.allowTemplateRewriting===!1?!0:this.makeTemplateSource(V,E).data("isRewritten")},u.ca.prototype.rewriteTemplate=function(V,E,I){V=this.makeTemplateSource(V,I),E=E(V.text()),V.text(E),V.data("isRewritten",!0)},u.b("templateEngine",u.ca),u.kc=function(){function V(B,X,_,P){B=u.m.ac(B);for(var w=u.m.Ra,z=0;z<B.length;z++){var H=B[z].key;if(Object.prototype.hasOwnProperty.call(w,H)){var nt=w[H];if(typeof nt=="function"){if(H=nt(B[z].value))throw Error(H)}else if(!nt)throw Error("This template engine does not support the '"+H+"' binding within its templates")}}return _="ko.__tr_ambtns(function($context,$element){return(function(){return{ "+u.m.vb(B,{valueAccessors:!0})+" } })()},'"+_.toLowerCase()+"')",P.createJavaScriptEvaluatorBlock(_)+X}var E=/(<([a-z]+\d*)(?:\s+(?!data-bind\s*=\s*)[a-z0-9\-]+(?:=(?:\"[^\"]*\"|\'[^\']*\'|[^>]*))?)*\s+)data-bind\s*=\s*(["'])([\s\S]*?)\3/gi,I=/\x3c!--\s*ko\b\s*([\s\S]*?)\s*--\x3e/g;return{xd:function(B,X,_){X.isTemplateRewritten(B,_)||X.rewriteTemplate(B,function(P){return u.kc.Ld(P,X)},_)},Ld:function(B,X){return B.replace(E,function(_,P,w,z,H){return V(H,P,w,X)}).replace(I,function(_,P){return V(P,"<!-- ko -->","#comment",X)})},md:function(B,X){return u.aa.Xb(function(_,P){var w=_.nextSibling;w&&w.nodeName.toLowerCase()===X&&u.ib(w,B,P)})}}}(),u.b("__tr_ambtns",u.kc.md),function(){u.C={},u.C.F=function(I){if(this.F=I){var B=u.a.R(I);this.ab=B==="script"?1:B==="textarea"?2:B=="template"&&I.content&&I.content.nodeType===11?3:4}},u.C.F.prototype.text=function(){var I=this.ab===1?"text":this.ab===2?"value":"innerHTML";if(arguments.length==0)return this.F[I];var B=arguments[0];I==="innerHTML"?u.a.fc(this.F,B):this.F[I]=B};var V=u.a.g.Z()+"_";u.C.F.prototype.data=function(I){if(arguments.length===1)return u.a.g.get(this.F,V+I);u.a.g.set(this.F,V+I,arguments[1])};var E=u.a.g.Z();u.C.F.prototype.nodes=function(){var I=this.F;if(arguments.length==0){var B=u.a.g.get(I,E)||{},X=B.lb||(this.ab===3?I.content:this.ab===4?I:t);if(!X||B.jd){var _=this.text();_&&_!==B.bb&&(X=u.a.Md(_,I.ownerDocument),u.a.g.set(I,E,{lb:X,bb:_,jd:!0}))}return X}B=arguments[0],this.ab!==t&&this.text(""),u.a.g.set(I,E,{lb:B})},u.C.ia=function(I){this.F=I},u.C.ia.prototype=new u.C.F,u.C.ia.prototype.constructor=u.C.ia,u.C.ia.prototype.text=function(){if(arguments.length==0){var I=u.a.g.get(this.F,E)||{};return I.bb===t&&I.lb&&(I.bb=I.lb.innerHTML),I.bb}u.a.g.set(this.F,E,{bb:arguments[0]})},u.b("templateSources",u.C),u.b("templateSources.domElement",u.C.F),u.b("templateSources.anonymousTemplate",u.C.ia)}(),function(){function V(z,H,nt){var $;for(H=u.h.nextSibling(H);z&&($=z)!==H;)z=u.h.nextSibling($),nt($,z)}function E(z,H){if(z.length){var nt=z[0],$=z[z.length-1],dt=nt.parentNode,q=u.ga.instance,at=q.preprocessNode;if(at){if(V(nt,$,function(st,Et){var Qt=st.previousSibling,Wt=at.call(q,st);Wt&&(st===nt&&(nt=Wt[0]||Et),st===$&&($=Wt[Wt.length-1]||Qt))}),z.length=0,!nt)return;nt===$?z.push(nt):(z.push(nt,$),u.a.Ua(z,dt))}V(nt,$,function(st){st.nodeType!==1&&st.nodeType!==8||u.vc(H,st)}),V(nt,$,function(st){st.nodeType!==1&&st.nodeType!==8||u.aa.cd(st,[H])}),u.a.Ua(z,dt)}}function I(z){return z.nodeType?z:0<z.length?z[0]:null}function B(z,H,nt,$,dt){dt=dt||{};var q=(z&&I(z)||nt||{}).ownerDocument,at=dt.templateEngine||_;if(u.kc.xd(nt,at,q),nt=at.renderTemplate(nt,$,dt,q),typeof nt.length!="number"||0<nt.length&&typeof nt[0].nodeType!="number")throw Error("Template engine must return an array of DOM nodes");switch(q=!1,H){case"replaceChildren":u.h.va(z,nt),q=!0;break;case"replaceNode":u.a.Xc(z,nt),q=!0;break;case"ignoreTargetNode":break;default:throw Error("Unknown renderMode: "+H)}return q&&(E(nt,$),dt.afterRender&&u.u.G(dt.afterRender,null,[nt,$[dt.as||"$data"]]),H=="replaceChildren"&&u.i.ma(z,u.i.H)),nt}function X(z,H,nt){return u.O(z)?z():typeof z=="function"?z(H,nt):z}var _;u.gc=function(z){if(z!=t&&!(z instanceof u.ca))throw Error("templateEngine must inherit from ko.templateEngine");_=z},u.dc=function(z,H,nt,$,dt){if(nt=nt||{},(nt.templateEngine||_)==t)throw Error("Set a template engine before calling renderTemplate");if(dt=dt||"replaceChildren",$){var q=I($);return u.$(function(){var st=H&&H instanceof u.fa?H:new u.fa(H,null,null,null,{exportDependencies:!0}),at=X(z,st.$data,st),st=B($,dt,at,st,nt);dt=="replaceNode"&&($=st,q=I($))},null,{Sa:function(){return!q||!u.a.Sb(q)},l:q&&dt=="replaceNode"?q.parentNode:q})}return u.aa.Xb(function(at){u.dc(z,H,nt,at,"replaceNode")})},u.Qd=function(z,H,nt,$,dt){function q(kt,Mt){u.u.G(u.a.ec,null,[$,kt,st,nt,at,Mt]),u.i.ma($,u.i.H)}function at(kt,Mt){E(Mt,Et),nt.afterRender&&nt.afterRender(Mt,kt),Et=null}function st(kt,Mt){Et=dt.createChildContext(kt,{as:Qt,noChildContext:nt.noChildContext,extend:function(ie){ie.$index=Mt,Qt&&(ie[Qt+"Index"]=Mt)}});var qt=X(z,kt,Et);return B($,"ignoreTargetNode",qt,Et,nt)}var Et,Qt=nt.as,Wt=nt.includeDestroyed===!1||u.options.foreachHidesDestroyed&&!nt.includeDestroyed;if(Wt||nt.beforeRemove||!u.Pc(H))return u.$(function(){var kt=u.a.f(H)||[];typeof kt.length>"u"&&(kt=[kt]),Wt&&(kt=u.a.jb(kt,function(Mt){return Mt===t||Mt===null||!u.a.f(Mt._destroy)})),q(kt)},null,{l:$});q(H.v());var Nt=H.subscribe(function(kt){q(H(),kt)},null,"arrayChange");return Nt.l($),Nt};var P=u.a.g.Z(),w=u.a.g.Z();u.c.template={init:function(z,H){var nt=u.a.f(H());if(typeof nt=="string"||"name"in nt)u.h.Ea(z);else if("nodes"in nt){if(nt=nt.nodes||[],u.O(nt))throw Error('The "nodes" option must be a plain, non-observable array.');var $=nt[0]&&nt[0].parentNode;$&&u.a.g.get($,w)||($=u.a.Yb(nt),u.a.g.set($,w,!0)),new u.C.ia(z).nodes($)}else if(nt=u.h.childNodes(z),0<nt.length)$=u.a.Yb(nt),new u.C.ia(z).nodes($);else throw Error("Anonymous template defined, but no template content was provided");return{controlsDescendantBindings:!0}},update:function(z,H,nt,$,dt){var q=H();H=u.a.f(q),nt=!0,$=null,typeof H=="string"?H={}:(q="name"in H?H.name:z,"if"in H&&(nt=u.a.f(H.if)),nt&&"ifnot"in H&&(nt=!u.a.f(H.ifnot)),nt&&!q&&(nt=!1)),"foreach"in H?$=u.Qd(q,nt&&H.foreach||[],H,z,dt):nt?(nt=dt,"data"in H&&(nt=dt.createChildContext(H.data,{as:H.as,noChildContext:H.noChildContext,exportDependencies:!0})),$=u.dc(q,nt,H,z)):u.h.Ea(z),dt=$,(H=u.a.g.get(z,P))&&typeof H.s=="function"&&H.s(),u.a.g.set(z,P,!dt||dt.ja&&!dt.ja()?t:dt)}},u.m.Ra.template=function(z){return z=u.m.ac(z),z.length==1&&z[0].unknown||u.m.Id(z,"name")?null:"This template engine does not support anonymous templates nested within its templates"},u.h.ea.template=!0}(),u.b("setTemplateEngine",u.gc),u.b("renderTemplate",u.dc),u.a.Kc=function(V,E,I){if(V.length&&E.length){var B,X,_,P,w;for(B=X=0;(!I||B<I)&&(P=V[X]);++X){for(_=0;w=E[_];++_)if(P.value===w.value){P.moved=w.index,w.moved=P.index,E.splice(_,1),B=_=0;break}B+=_}}},u.a.Pb=function(){function V(E,I,B,X,_){var P=Math.min,w=Math.max,z=[],H,nt=E.length,$,dt=I.length,q=dt-nt||1,at=nt+dt+1,st,Et,Qt;for(H=0;H<=nt;H++)for(Et=st,z.push(st=[]),Qt=P(dt,H+q),$=w(0,H-1);$<=Qt;$++)st[$]=$?H?E[H-1]===I[$-1]?Et[$-1]:P(Et[$]||at,st[$-1]||at)+1:$+1:H+1;for(P=[],w=[],q=[],H=nt,$=dt;H||$;)dt=z[H][$]-1,$&&dt===z[H][$-1]?w.push(P[P.length]={status:B,value:I[--$],index:$}):H&&dt===z[H-1][$]?q.push(P[P.length]={status:X,value:E[--H],index:H}):(--$,--H,_.sparse||P.push({status:"retained",value:I[$]}));return u.a.Kc(q,w,!_.dontLimitMoves&&10*nt),P.reverse()}return function(E,I,B){return B=typeof B=="boolean"?{dontLimitMoves:B}:B||{},E=E||[],I=I||[],E.length<I.length?V(E,I,"added","deleted",B):V(I,E,"deleted","added",B)}}(),u.b("utils.compareArrays",u.a.Pb),function(){function V(B,X,_,P,w){var z=[],H=u.$(function(){var nt=X(_,w,u.a.Ua(z,B))||[];0<z.length&&(u.a.Xc(z,nt),P&&u.u.G(P,null,[_,nt,w])),z.length=0,u.a.Nb(z,nt)},null,{l:B,Sa:function(){return!u.a.kd(z)}});return{Y:z,$:H.ja()?H:t}}var E=u.a.g.Z(),I=u.a.g.Z();u.a.ec=function(B,X,_,P,w,z){function H(We){qt={Aa:We,pb:u.ta(Et++)},at.push(qt),q||Mt.push(qt)}function nt(We){qt=dt[We],Et!==qt.pb.v()&&kt.push(qt),qt.pb(Et++),u.a.Ua(qt.Y,B),at.push(qt)}function $(We,un){if(We)for(var Ct=0,_t=un.length;Ct<_t;Ct++)u.a.D(un[Ct].Y,function(Je){We(Je,Ct,un[Ct].Aa)})}X=X||[],typeof X.length>"u"&&(X=[X]),P=P||{};var dt=u.a.g.get(B,E),q=!dt,at=[],st=0,Et=0,Qt=[],Wt=[],Nt=[],kt=[],Mt=[],qt,ie=0;if(q)u.a.D(X,H);else{if(!z||dt&&dt._countWaitingForRemove){var oe=u.a.Mb(dt,function(We){return We.Aa});z=u.a.Pb(oe,X,{dontLimitMoves:P.dontLimitMoves,sparse:!0})}for(var oe=0,He,rn,de;He=z[oe];oe++)switch(rn=He.moved,de=He.index,He.status){case"deleted":for(;st<de;)nt(st++);rn===t&&(qt=dt[st],qt.$&&(qt.$.s(),qt.$=t),u.a.Ua(qt.Y,B).length&&(P.beforeRemove&&(at.push(qt),ie++,qt.Aa===I?qt=null:Nt.push(qt)),qt&&Qt.push.apply(Qt,qt.Y))),st++;break;case"added":for(;Et<de;)nt(st++);rn!==t?(Wt.push(at.length),nt(rn)):H(He.value)}for(;Et<X.length;)nt(st++);at._countWaitingForRemove=ie}u.a.g.set(B,E,at),$(P.beforeMove,kt),u.a.D(Qt,P.beforeRemove?u.oa:u.removeNode);var zt,ke,ue;try{ue=B.ownerDocument.activeElement}catch{}if(Wt.length)for(;(oe=Wt.shift())!=t;){for(qt=at[oe],zt=t;oe;)if((ke=at[--oe].Y)&&ke.length){zt=ke[ke.length-1];break}for(X=0;st=qt.Y[X];zt=st,X++)u.h.Wb(B,st,zt)}for(oe=0;qt=at[oe];oe++){for(qt.Y||u.a.extend(qt,V(B,_,qt.Aa,w,qt.pb)),X=0;st=qt.Y[X];zt=st,X++)u.h.Wb(B,st,zt);!qt.Ed&&w&&(w(qt.Aa,qt.Y,qt.pb),qt.Ed=!0,zt=qt.Y[qt.Y.length-1])}for(ue&&B.ownerDocument.activeElement!=ue&&ue.focus(),$(P.beforeRemove,Nt),oe=0;oe<Nt.length;++oe)Nt[oe].Aa=I;$(P.afterMove,kt),$(P.afterAdd,Mt)}}(),u.b("utils.setDomNodeChildrenFromArrayMapping",u.a.ec),u.ba=function(){this.allowTemplateRewriting=!1},u.ba.prototype=new u.ca,u.ba.prototype.constructor=u.ba,u.ba.prototype.renderTemplateSource=function(V,E,I,B){return(E=!(9>u.a.W)&&V.nodes?V.nodes():null)?u.a.la(E.cloneNode(!0).childNodes):(V=V.text(),u.a.ua(V,B))},u.ba.Ma=new u.ba,u.gc(u.ba.Ma),u.b("nativeTemplateEngine",u.ba),function(){u.$a=function(){var E=this.Hd=function(){if(!o||!o.tmpl)return 0;try{if(0<=o.tmpl.tag.tmpl.open.toString().indexOf("__"))return 2}catch{}return 1}();this.renderTemplateSource=function(I,B,X,_){if(_=_||n,X=X||{},2>E)throw Error("Your version of jQuery.tmpl is too old. Please upgrade to jQuery.tmpl 1.0.0pre or later.");var P=I.data("precompiled");return P||(P=I.text()||"",P=o.template(null,"{{ko_with $item.koBindingContext}}"+P+"{{/ko_with}}"),I.data("precompiled",P)),I=[B.$data],B=o.extend({koBindingContext:B},X.templateOptions),B=o.tmpl(P,I,B),B.appendTo(_.createElement("div")),o.fragments={},B},this.createJavaScriptEvaluatorBlock=function(I){return"{{ko_code ((function() { return "+I+" })()) }}"},this.addTemplate=function(I,B){n.write("<script type='text/html' id='"+I+"'>"+B+"<\/script>")},0<E&&(o.tmpl.tag.ko_code={open:"__.push($1 || '');"},o.tmpl.tag.ko_with={open:"with($1) {",close:"} "})},u.$a.prototype=new u.ca,u.$a.prototype.constructor=u.$a;var V=new u.$a;0<V.Hd&&u.gc(V),u.b("jqueryTmplTemplateEngine",u.$a)}()})})()})()})();var $9e=ko;typeof window<"u"?(ko=window.ko,typeof mD<"u"?window.ko=mD:delete window.ko):(ko=global.ko,typeof mD<"u"?global.ko=mD:delete global.ko);var dg=$9e;var QWa=R(W(),1);/** +|/(?:\\\\.|[^/])+/w*|[^\\s:,/][^,"'\`{}()/:[\\]]*[^\\s,"'\`{}()/:[\\]]|[^\\s]`,"g"),X=/[\])"'A-Za-z0-9_$]+$/,_={in:1,return:1,typeof:1},P={};return{Ra:[],wa:P,ac:Z,vb:function(w,z){function H(st,Et){var Qt;if(!q){var Wt=V.getBindingHandler(st);if(Wt&&Wt.preprocess&&!(Et=Wt.preprocess(Et,st,H)))return;(Wt=P[st])&&(Qt=Et,0<=V.a.A(E,Qt)?Qt=!1:(Wt=Qt.match(I),Qt=Wt===null?!1:Wt[1]?"Object("+Wt[1]+")"+Wt[2]:Qt),Wt=Qt),Wt&&$.push("'"+(typeof P[st]=="string"?P[st]:st)+"':function(_z){"+Qt+"=_z}")}dt&&(Et="function(){return "+Et+" }"),nt.push("'"+st+"':"+Et)}z=z||{};var nt=[],$=[],dt=z.valueAccessors,q=z.bindingParams,at=typeof w=="string"?Z(w):w;return V.a.D(at,function(st){H(st.key||st.unknown,st.value)}),$.length&&H("_ko_property_writers","{"+$.join(",")+" }"),nt.join(",")},Id:function(w,z){for(var H=0;H<w.length;H++)if(w[H].key==z)return!0;return!1},eb:function(w,z,H,nt,$){w&&V.O(w)?!V.Za(w)||$&&w.v()===nt||w(nt):(w=z.get("_ko_property_writers"))&&w[H]&&w[H](nt)}}}(),V.b("expressionRewriting",V.m),V.b("expressionRewriting.bindingRewriteValidators",V.m.Ra),V.b("expressionRewriting.parseObjectLiteral",V.m.ac),V.b("expressionRewriting.preProcessBindings",V.m.vb),V.b("expressionRewriting._twoWayBindings",V.m.wa),V.b("jsonExpressionRewriting",V.m),V.b("jsonExpressionRewriting.insertPropertyAccessorsIntoJson",V.m.vb),function(){function Z(H){return H.nodeType==8&&_.test(X?H.text:H.nodeValue)}function E(H){return H.nodeType==8&&P.test(X?H.text:H.nodeValue)}function I(H,nt){for(var $=H,dt=1,q=[];$=$.nextSibling;){if(E($)&&(V.a.g.set($,z,!0),dt--,dt===0))return q;q.push($),Z($)&&dt++}if(!nt)throw Error("Cannot find closing comment tag to match: "+H.nodeValue);return null}function B(H,nt){var $=I(H,nt);return $?0<$.length?$[$.length-1].nextSibling:H.nextSibling:null}var X=n&&n.createComment("test").text==="<!--test-->",_=X?/^\x3c!--\s*ko(?:\s+([\s\S]+))?\s*--\x3e$/:/^\s*ko(?:\s+([\s\S]+))?\s*$/,P=X?/^\x3c!--\s*\/ko\s*--\x3e$/:/^\s*\/ko\s*$/,w={ul:!0,ol:!0},z="__ko_matchedEndComment__";V.h={ea:{},childNodes:function(H){return Z(H)?I(H):H.childNodes},Ea:function(H){if(Z(H)){H=V.h.childNodes(H);for(var nt=0,$=H.length;nt<$;nt++)V.removeNode(H[nt])}else V.a.Tb(H)},va:function(H,nt){if(Z(H)){V.h.Ea(H);for(var $=H.nextSibling,dt=0,q=nt.length;dt<q;dt++)$.parentNode.insertBefore(nt[dt],$)}else V.a.va(H,nt)},Vc:function(H,nt){var $;Z(H)?($=H.nextSibling,H=H.parentNode):$=H.firstChild,$?nt!==$&&H.insertBefore(nt,$):H.appendChild(nt)},Wb:function(H,nt,$){$?($=$.nextSibling,Z(H)&&(H=H.parentNode),$?nt!==$&&H.insertBefore(nt,$):H.appendChild(nt)):V.h.Vc(H,nt)},firstChild:function(H){if(Z(H))return!H.nextSibling||E(H.nextSibling)?null:H.nextSibling;if(H.firstChild&&E(H.firstChild))throw Error("Found invalid end comment, as the first child of "+H);return H.firstChild},nextSibling:function(H){if(Z(H)&&(H=B(H)),H.nextSibling&&E(H.nextSibling)){var nt=H.nextSibling;if(E(nt)&&!V.a.g.get(nt,z))throw Error("Found end comment without a matching opening comment, as child of "+H);return null}return H.nextSibling},Cd:Z,Vd:function(H){return(H=(X?H.text:H.nodeValue).match(_))?H[1]:null},Sc:function(H){if(w[V.a.R(H)]){var nt=H.firstChild;if(nt)do if(nt.nodeType===1){var $;$=nt.firstChild;var dt=null;if($)do if(dt)dt.push($);else if(Z($)){var q=B($,!0);q?$=q:dt=[$]}else E($)&&(dt=[$]);while($=$.nextSibling);if($=dt)for(dt=nt.nextSibling,q=0;q<$.length;q++)dt?H.insertBefore($[q],dt):H.appendChild($[q])}while(nt=nt.nextSibling)}}}}(),V.b("virtualElements",V.h),V.b("virtualElements.allowedBindings",V.h.ea),V.b("virtualElements.emptyNode",V.h.Ea),V.b("virtualElements.insertAfter",V.h.Wb),V.b("virtualElements.prepend",V.h.Vc),V.b("virtualElements.setDomNodeChildren",V.h.va),function(){V.ga=function(){this.nd={}},V.a.extend(V.ga.prototype,{nodeHasBindings:function(Z){switch(Z.nodeType){case 1:return Z.getAttribute("data-bind")!=null||V.j.getComponentNameForNode(Z);case 8:return V.h.Cd(Z);default:return!1}},getBindings:function(Z,E){var I=this.getBindingsString(Z,E),I=I?this.parseBindingsString(I,E,Z):null;return V.j.tc(I,Z,E,!1)},getBindingAccessors:function(Z,E){var I=this.getBindingsString(Z,E),I=I?this.parseBindingsString(I,E,Z,{valueAccessors:!0}):null;return V.j.tc(I,Z,E,!0)},getBindingsString:function(Z){switch(Z.nodeType){case 1:return Z.getAttribute("data-bind");case 8:return V.h.Vd(Z);default:return null}},parseBindingsString:function(Z,E,I,B){try{var X=this.nd,_=Z+(B&&B.valueAccessors||""),P;if(!(P=X[_])){var w,z="with($context){with($data||{}){return{"+V.m.vb(Z,B)+"}}}";w=new Function("$context","$element",z),P=X[_]=w}return P(E,I)}catch(H){throw H.message=`Unable to parse bindings. +Bindings value: `+Z+` +Message: `+H.message,H}}}),V.ga.instance=new V.ga}(),V.b("bindingProvider",V.ga),function(){function Z(Wt){var Nt=(Wt=V.a.g.get(Wt,Qt))&&Wt.N;Nt&&(Wt.N=null,Nt.Tc())}function E(Wt,Nt,kt){this.node=Wt,this.yc=Nt,this.kb=[],this.H=!1,Nt.N||V.a.K.za(Wt,Z),kt&&kt.N&&(kt.N.kb.push(Wt),this.Kb=kt)}function I(Wt){return function(){return Wt}}function B(Wt){return Wt()}function X(Wt){return V.a.Ga(V.u.G(Wt),function(Nt,kt){return function(){return Wt()[kt]}})}function _(Wt,Nt,kt){return typeof Wt=="function"?X(Wt.bind(null,Nt,kt)):V.a.Ga(Wt,I)}function P(Wt,Nt){return X(this.getBindings.bind(this,Wt,Nt))}function w(Wt,Nt){var kt=V.h.firstChild(Nt);if(kt){var Mt,qt=V.ga.instance,ie=qt.preprocessNode;if(ie){for(;Mt=kt;)kt=V.h.nextSibling(Mt),ie.call(qt,Mt);kt=V.h.firstChild(Nt)}for(;Mt=kt;)kt=V.h.nextSibling(Mt),z(Wt,Mt)}V.i.ma(Nt,V.i.H)}function z(Wt,Nt){var kt=Wt,Mt=Nt.nodeType===1;Mt&&V.h.Sc(Nt),(Mt||V.ga.instance.nodeHasBindings(Nt))&&(kt=nt(Nt,null,Wt).bindingContextForDescendants),kt&&!st[V.a.R(Nt)]&&w(kt,Nt)}function H(Wt){var Nt=[],kt={},Mt=[];return V.a.P(Wt,function qt(ie){if(!kt[ie]){var oe=V.getBindingHandler(ie);oe&&(oe.after&&(Mt.push(ie),V.a.D(oe.after,function(He){if(Wt[He]){if(V.a.A(Mt,He)!==-1)throw Error("Cannot combine the following bindings, because they have a cyclic dependency: "+Mt.join(", "));qt(He)}}),Mt.length--),Nt.push({key:ie,Mc:oe})),kt[ie]=!0}}),Nt}function nt(Wt,Nt,kt){var Mt=V.a.g.Ub(Wt,Qt,{}),qt=Mt.hd;if(!Nt){if(qt)throw Error("You cannot apply bindings multiple times to the same element.");Mt.hd=!0}qt||(Mt.context=kt),Mt.Zb||(Mt.Zb={});var ie;if(Nt&&typeof Nt!="function")ie=Nt;else{var oe=V.ga.instance,He=oe.getBindingAccessors||P,rn=V.$(function(){return(ie=Nt?Nt(kt,Wt):He.call(oe,Wt,kt))&&(kt[dt]&&kt[dt](),kt[at]&&kt[at]()),ie},null,{l:Wt});ie&&rn.ja()||(rn=null)}var de=kt,zt;if(ie){var ke=function(){return V.a.Ga(rn?rn():ie,B)},Ve=rn?function(We){return function(){return B(rn()[We])}}:function(We){return ie[We]};ke.get=function(We){return ie[We]&&B(Ve(We))},ke.has=function(We){return We in ie},V.i.H in ie&&V.i.subscribe(Wt,V.i.H,function(){var We=(0,ie[V.i.H])();if(We){var Vn=V.h.childNodes(Wt);Vn.length&&We(Vn,V.Ec(Vn[0]))}}),V.i.pa in ie&&(de=V.i.Cb(Wt,kt),V.i.subscribe(Wt,V.i.pa,function(){var We=(0,ie[V.i.pa])();We&&V.h.firstChild(Wt)&&We(Wt)})),Mt=H(ie),V.a.D(Mt,function(We){var Vn=We.Mc.init,Ct=We.Mc.update,_t=We.key;if(Wt.nodeType===8&&!V.h.ea[_t])throw Error("The binding '"+_t+"' cannot be used with virtual elements");try{typeof Vn=="function"&&V.u.G(function(){var Je=Vn(Wt,Ve(_t),ke,de.$data,de);if(Je&&Je.controlsDescendantBindings){if(zt!==t)throw Error("Multiple bindings ("+zt+" and "+_t+") are trying to control descendant bindings of the same element. You cannot use these bindings together on the same element.");zt=_t}}),typeof Ct=="function"&&V.$(function(){Ct(Wt,Ve(_t),ke,de.$data,de)},null,{l:Wt})}catch(Je){throw Je.message='Unable to process binding "'+_t+": "+ie[_t]+`" +Message: `+Je.message,Je}})}return Mt=zt===t,{shouldBindDescendants:Mt,bindingContextForDescendants:Mt&&de}}function $(Wt,Nt){return Wt&&Wt instanceof V.fa?Wt:new V.fa(Wt,t,t,Nt)}var dt=V.a.Da("_subscribable"),q=V.a.Da("_ancestorBindingInfo"),at=V.a.Da("_dataDependency");V.c={};var st={script:!0,textarea:!0,template:!0};V.getBindingHandler=function(Wt){return V.c[Wt]};var Et={};V.fa=function(Wt,Nt,kt,Mt,qt){function ie(){var Ve=de?rn():rn,We=V.a.f(Ve);return Nt?(V.a.extend(oe,Nt),q in Nt&&(oe[q]=Nt[q])):(oe.$parents=[],oe.$root=We,oe.ko=V),oe[dt]=zt,He?We=oe.$data:(oe.$rawData=Ve,oe.$data=We),kt&&(oe[kt]=We),Mt&&Mt(oe,Nt,We),Nt&&Nt[dt]&&!V.S.o().Vb(Nt[dt])&&Nt[dt](),ke&&(oe[at]=ke),oe.$data}var oe=this,He=Wt===Et,rn=He?t:Wt,de=typeof rn=="function"&&!V.O(rn),zt,ke=qt&&qt.dataDependency;qt&&qt.exportDependencies?ie():(zt=V.xb(ie),zt.v(),zt.ja()?zt.equalityComparer=null:oe[dt]=t)},V.fa.prototype.createChildContext=function(Wt,Nt,kt,Mt){if(!Mt&&Nt&&typeof Nt=="object"&&(Mt=Nt,Nt=Mt.as,kt=Mt.extend),Nt&&Mt&&Mt.noChildContext){var qt=typeof Wt=="function"&&!V.O(Wt);return new V.fa(Et,this,null,function(ie){kt&&kt(ie),ie[Nt]=qt?Wt():Wt},Mt)}return new V.fa(Wt,this,Nt,function(ie,oe){ie.$parentContext=oe,ie.$parent=oe.$data,ie.$parents=(oe.$parents||[]).slice(0),ie.$parents.unshift(ie.$parent),kt&&kt(ie)},Mt)},V.fa.prototype.extend=function(Wt,Nt){return new V.fa(Et,this,null,function(kt){V.a.extend(kt,typeof Wt=="function"?Wt(kt):Wt)},Nt)};var Qt=V.a.g.Z();E.prototype.Tc=function(){this.Kb&&this.Kb.N&&this.Kb.N.sd(this.node)},E.prototype.sd=function(Wt){V.a.Pa(this.kb,Wt),!this.kb.length&&this.H&&this.Cc()},E.prototype.Cc=function(){this.H=!0,this.yc.N&&!this.kb.length&&(this.yc.N=null,V.a.K.yb(this.node,Z),V.i.ma(this.node,V.i.pa),this.Tc())},V.i={H:"childrenComplete",pa:"descendantsComplete",subscribe:function(Wt,Nt,kt,Mt,qt){var ie=V.a.g.Ub(Wt,Qt,{});return ie.Fa||(ie.Fa=new V.T),qt&&qt.notifyImmediately&&ie.Zb[Nt]&&V.u.G(kt,Mt,[Wt]),ie.Fa.subscribe(kt,Mt,Nt)},ma:function(Wt,Nt){var kt=V.a.g.get(Wt,Qt);if(kt&&(kt.Zb[Nt]=!0,kt.Fa&&kt.Fa.notifySubscribers(Wt,Nt),Nt==V.i.H)){if(kt.N)kt.N.Cc();else if(kt.N===t&&kt.Fa&&kt.Fa.Wa(V.i.pa))throw Error("descendantsComplete event not supported for bindings on this node")}},Cb:function(Wt,Nt){var kt=V.a.g.Ub(Wt,Qt,{});return kt.N||(kt.N=new E(Wt,kt,Nt[q])),Nt[q]==kt?Nt:Nt.extend(function(Mt){Mt[q]=kt})}},V.Td=function(Wt){return(Wt=V.a.g.get(Wt,Qt))&&Wt.context},V.ib=function(Wt,Nt,kt){return Wt.nodeType===1&&V.h.Sc(Wt),nt(Wt,Nt,$(kt))},V.ld=function(Wt,Nt,kt){return kt=$(kt),V.ib(Wt,_(Nt,kt,Wt),kt)},V.Oa=function(Wt,Nt){Nt.nodeType!==1&&Nt.nodeType!==8||w($(Wt),Nt)},V.vc=function(Wt,Nt,kt){if(!o&&e.jQuery&&(o=e.jQuery),2>arguments.length){if(Nt=n.body,!Nt)throw Error("ko.applyBindings: could not find document.body; has the document been loaded?")}else if(!Nt||Nt.nodeType!==1&&Nt.nodeType!==8)throw Error("ko.applyBindings: first parameter should be your view model; second parameter should be a DOM node");z($(Wt,kt),Nt)},V.Dc=function(Wt){return!Wt||Wt.nodeType!==1&&Wt.nodeType!==8?t:V.Td(Wt)},V.Ec=function(Wt){return(Wt=V.Dc(Wt))?Wt.$data:t},V.b("bindingHandlers",V.c),V.b("bindingEvent",V.i),V.b("bindingEvent.subscribe",V.i.subscribe),V.b("bindingEvent.startPossiblyAsyncContentBinding",V.i.Cb),V.b("applyBindings",V.vc),V.b("applyBindingsToDescendants",V.Oa),V.b("applyBindingAccessorsToNode",V.ib),V.b("applyBindingsToNode",V.ld),V.b("contextFor",V.Dc),V.b("dataFor",V.Ec)}(),function(Z){function E(P,w){var z=Object.prototype.hasOwnProperty.call(X,P)?X[P]:Z,H;z?z.subscribe(w):(z=X[P]=new V.T,z.subscribe(w),I(P,function(nt,$){var dt=!(!$||!$.synchronous);_[P]={definition:nt,Gd:dt},delete X[P],H||dt?z.notifySubscribers(nt):V.na.zb(function(){z.notifySubscribers(nt)})}),H=!0)}function I(P,w){B("getConfig",[P],function(z){z?B("loadComponent",[P,z],function(H){w(H,z)}):w(null,null)})}function B(P,w,z,H){H||(H=V.j.loaders.slice(0));var nt=H.shift();if(nt){var $=nt[P];if($){var dt=!1;if($.apply(nt,w.concat(function(q){dt?z(null):q!==null?z(q):B(P,w,z,H)}))!==Z&&(dt=!0,!nt.suppressLoaderExceptions))throw Error("Component loaders must supply values by invoking the callback, not by returning values synchronously.")}else B(P,w,z,H)}else z(null)}var X={},_={};V.j={get:function(P,w){var z=Object.prototype.hasOwnProperty.call(_,P)?_[P]:Z;z?z.Gd?V.u.G(function(){w(z.definition)}):V.na.zb(function(){w(z.definition)}):E(P,w)},Bc:function(P){delete _[P]},oc:B},V.j.loaders=[],V.b("components",V.j),V.b("components.get",V.j.get),V.b("components.clearCachedDefinition",V.j.Bc)}(),function(){function Z(z,H,nt,$){function dt(){--at===0&&$(q)}var q={},at=2,st=nt.template;nt=nt.viewModel,st?X(H,st,function(Et){V.j.oc("loadTemplate",[z,Et],function(Qt){q.template=Qt,dt()})}):dt(),nt?X(H,nt,function(Et){V.j.oc("loadViewModel",[z,Et],function(Qt){q[w]=Qt,dt()})}):dt()}function E(z,H,nt){if(typeof H=="function")nt(function(dt){return new H(dt)});else if(typeof H[w]=="function")nt(H[w]);else if("instance"in H){var $=H.instance;nt(function(){return $})}else"viewModel"in H?E(z,H.viewModel,nt):z("Unknown viewModel value: "+H)}function I(z){switch(V.a.R(z)){case"script":return V.a.ua(z.text);case"textarea":return V.a.ua(z.value);case"template":if(B(z.content))return V.a.Ca(z.content.childNodes)}return V.a.Ca(z.childNodes)}function B(z){return e.DocumentFragment?z instanceof DocumentFragment:z&&z.nodeType===11}function X(z,H,nt){typeof H.require=="string"?l||e.require?(l||e.require)([H.require],function($){$&&typeof $=="object"&&$.Xd&&$.default&&($=$.default),nt($)}):z("Uses require, but no AMD loader is present"):nt(H)}function _(z){return function(H){throw Error("Component '"+z+"': "+H)}}var P={};V.j.register=function(z,H){if(!H)throw Error("Invalid configuration for "+z);if(V.j.tb(z))throw Error("Component "+z+" is already registered");P[z]=H},V.j.tb=function(z){return Object.prototype.hasOwnProperty.call(P,z)},V.j.unregister=function(z){delete P[z],V.j.Bc(z)},V.j.Fc={getConfig:function(z,H){H(V.j.tb(z)?P[z]:null)},loadComponent:function(z,H,nt){var $=_(z);X($,H,function(dt){Z(z,$,dt,nt)})},loadTemplate:function(z,H,nt){if(z=_(z),typeof H=="string")nt(V.a.ua(H));else if(H instanceof Array)nt(H);else if(B(H))nt(V.a.la(H.childNodes));else if(H.element)if(H=H.element,e.HTMLElement?H instanceof HTMLElement:H&&H.tagName&&H.nodeType===1)nt(I(H));else if(typeof H=="string"){var $=n.getElementById(H);$?nt(I($)):z("Cannot find element with ID "+H)}else z("Unknown element type: "+H);else z("Unknown template value: "+H)},loadViewModel:function(z,H,nt){E(_(z),H,nt)}};var w="createViewModel";V.b("components.register",V.j.register),V.b("components.isRegistered",V.j.tb),V.b("components.unregister",V.j.unregister),V.b("components.defaultLoader",V.j.Fc),V.j.loaders.push(V.j.Fc),V.j.dd=P}(),function(){function Z(I,B){var X=I.getAttribute("params");if(X){var X=E.parseBindingsString(X,B,I,{valueAccessors:!0,bindingParams:!0}),X=V.a.Ga(X,function(w){return V.o(w,null,{l:I})}),_=V.a.Ga(X,function(w){var z=w.v();return w.ja()?V.o({read:function(){return V.a.f(w())},write:V.Za(z)&&function(H){w()(H)},l:I}):z});return Object.prototype.hasOwnProperty.call(_,"$raw")||(_.$raw=X),_}return{$raw:{}}}V.j.getComponentNameForNode=function(I){var B=V.a.R(I);if(V.j.tb(B)&&(B.indexOf("-")!=-1||""+I=="[object HTMLUnknownElement]"||8>=V.a.W&&I.tagName===B))return B},V.j.tc=function(I,B,X,_){if(B.nodeType===1){var P=V.j.getComponentNameForNode(B);if(P){if(I=I||{},I.component)throw Error('Cannot use the "component" binding on a custom element matching a component');var w={name:P,params:Z(B,X)};I.component=_?function(){return w}:w}}return I};var E=new V.ga;9>V.a.W&&(V.j.register=function(I){return function(B){return I.apply(this,arguments)}}(V.j.register),n.createDocumentFragment=function(I){return function(){var B=I(),X=V.j.dd,_;for(_ in X);return B}}(n.createDocumentFragment))}(),function(){function Z(B,X,_){if(X=X.template,!X)throw Error("Component '"+B+"' has no template");B=V.a.Ca(X),V.h.va(_,B)}function E(B,X,_){var P=B.createViewModel;return P?P.call(B,X,_):X}var I=0;V.c.component={init:function(B,X,_,P,w){function z(){var q=H&&H.dispose;typeof q=="function"&&q.call(H),$&&$.s(),nt=H=$=null}var H,nt,$,dt=V.a.la(V.h.childNodes(B));return V.h.Ea(B),V.a.K.za(B,z),V.o(function(){var q=V.a.f(X()),at,st;if(typeof q=="string"?at=q:(at=V.a.f(q.name),st=V.a.f(q.params)),!at)throw Error("No component name specified");var Et=V.i.Cb(B,w),Qt=nt=++I;V.j.get(at,function(Wt){if(nt===Qt){if(z(),!Wt)throw Error("Unknown component '"+at+"'");Z(at,Wt,B);var Nt=E(Wt,st,{element:B,templateNodes:dt});Wt=Et.createChildContext(Nt,{extend:function(kt){kt.$component=Nt,kt.$componentTemplateNodes=dt}}),Nt&&Nt.koDescendantsComplete&&($=V.i.subscribe(B,V.i.pa,Nt.koDescendantsComplete,Nt)),H=Nt,V.Oa(Wt,B)}})},null,{l:B}),{controlsDescendantBindings:!0}}},V.h.ea.component=!0}();var J={class:"className",for:"htmlFor"};V.c.attr={update:function(Z,E){var I=V.a.f(E())||{};V.a.P(I,function(B,X){X=V.a.f(X);var _=B.indexOf(":"),_="lookupNamespaceURI"in Z&&0<_&&Z.lookupNamespaceURI(B.substr(0,_)),P=X===!1||X===null||X===t;P?_?Z.removeAttributeNS(_,B):Z.removeAttribute(B):X=X.toString(),8>=V.a.W&&B in J?(B=J[B],P?Z.removeAttribute(B):Z[B]=X):P||(_?Z.setAttributeNS(_,B,X):Z.setAttribute(B,X)),B==="name"&&V.a.Yc(Z,P?"":X)})}},function(){V.c.checked={after:["value","attr"],init:function(Z,E,I){function B(){var q=Z.checked,at=_();if(!V.S.Ya()&&(q||!w&&!V.S.qa())){var st=V.u.G(E);if(H){var Et=nt?st.v():st,Qt=dt;dt=at,Qt!==at?q&&(V.a.Na(Et,at,!0),V.a.Na(Et,Qt,!1)):V.a.Na(Et,at,q),nt&&V.Za(st)&&st(Et)}else P&&(at===t?at=q:q||(at=t)),V.m.eb(st,I,"checked",at,!0)}}function X(){var q=V.a.f(E()),at=_();H?(Z.checked=0<=V.a.A(q,at),dt=at):Z.checked=P&&at===t?!!q:_()===q}var _=V.xb(function(){if(I.has("checkedValue"))return V.a.f(I.get("checkedValue"));if($)return I.has("value")?V.a.f(I.get("value")):Z.value}),P=Z.type=="checkbox",w=Z.type=="radio";if(P||w){var z=E(),H=P&&V.a.f(z)instanceof Array,nt=!(H&&z.push&&z.splice),$=w||H,dt=H?_():t;w&&!Z.name&&V.c.uniqueName.init(Z,function(){return!0}),V.o(B,null,{l:Z}),V.a.B(Z,"click",B),V.o(X,null,{l:Z}),z=t}}},V.m.wa.checked=!0,V.c.checkedValue={update:function(Z,E){Z.value=V.a.f(E())}}}(),V.c.class={update:function(Z,E){var I=V.a.Db(V.a.f(E()));V.a.Eb(Z,Z.__ko__cssValue,!1),Z.__ko__cssValue=I,V.a.Eb(Z,I,!0)}},V.c.css={update:function(Z,E){var I=V.a.f(E());I!==null&&typeof I=="object"?V.a.P(I,function(B,X){X=V.a.f(X),V.a.Eb(Z,B,X)}):V.c.class.update(Z,E)}},V.c.enable={update:function(Z,E){var I=V.a.f(E());I&&Z.disabled?Z.removeAttribute("disabled"):I||Z.disabled||(Z.disabled=!0)}},V.c.disable={update:function(Z,E){V.c.enable.update(Z,function(){return!V.a.f(E())})}},V.c.event={init:function(Z,E,I,B,X){var _=E()||{};V.a.P(_,function(P){typeof P=="string"&&V.a.B(Z,P,function(w){var z,H=E()[P];if(H){try{var nt=V.a.la(arguments);B=X.$data,nt.unshift(B),z=H.apply(B,nt)}finally{z!==!0&&(w.preventDefault?w.preventDefault():w.returnValue=!1)}I.get(P+"Bubble")===!1&&(w.cancelBubble=!0,w.stopPropagation&&w.stopPropagation())}})})}},V.c.foreach={Rc:function(Z){return function(){var E=Z(),I=V.a.bc(E);return!I||typeof I.length=="number"?{foreach:E,templateEngine:V.ba.Ma}:(V.a.f(E),{foreach:I.data,as:I.as,noChildContext:I.noChildContext,includeDestroyed:I.includeDestroyed,afterAdd:I.afterAdd,beforeRemove:I.beforeRemove,afterRender:I.afterRender,beforeMove:I.beforeMove,afterMove:I.afterMove,templateEngine:V.ba.Ma})}},init:function(Z,E){return V.c.template.init(Z,V.c.foreach.Rc(E))},update:function(Z,E,I,B,X){return V.c.template.update(Z,V.c.foreach.Rc(E),I,B,X)}},V.m.Ra.foreach=!1,V.h.ea.foreach=!0,V.c.hasfocus={init:function(Z,E,I){function B(P){Z.__ko_hasfocusUpdating=!0;var w=Z.ownerDocument;if("activeElement"in w){var z;try{z=w.activeElement}catch{z=w.body}P=z===Z}w=E(),V.m.eb(w,I,"hasfocus",P,!0),Z.__ko_hasfocusLastValue=P,Z.__ko_hasfocusUpdating=!1}var X=B.bind(null,!0),_=B.bind(null,!1);V.a.B(Z,"focus",X),V.a.B(Z,"focusin",X),V.a.B(Z,"blur",_),V.a.B(Z,"focusout",_),Z.__ko_hasfocusLastValue=!1},update:function(Z,E){var I=!!V.a.f(E());Z.__ko_hasfocusUpdating||Z.__ko_hasfocusLastValue===I||(I?Z.focus():Z.blur(),!I&&Z.__ko_hasfocusLastValue&&Z.ownerDocument.body.focus(),V.u.G(V.a.Fb,null,[Z,I?"focusin":"focusout"]))}},V.m.wa.hasfocus=!0,V.c.hasFocus=V.c.hasfocus,V.m.wa.hasFocus="hasfocus",V.c.html={init:function(){return{controlsDescendantBindings:!0}},update:function(Z,E){V.a.fc(Z,E())}},function(){function Z(E,I,B){V.c[E]={init:function(X,_,P,w,z){var H,nt,$={},dt,q,at;if(I){w=P.get("as");var st=P.get("noChildContext");at=!(w&&st),$={as:w,noChildContext:st,exportDependencies:at}}return q=(dt=P.get("completeOn")=="render")||P.has(V.i.pa),V.o(function(){var Et=V.a.f(_()),Qt=!B!=!Et,Wt=!nt,Nt;(at||Qt!==H)&&(q&&(z=V.i.Cb(X,z)),Qt&&((!I||at)&&($.dataDependency=V.S.o()),Nt=I?z.createChildContext(typeof Et=="function"?Et:_,$):V.S.qa()?z.extend(null,$):z),Wt&&V.S.qa()&&(nt=V.a.Ca(V.h.childNodes(X),!0)),Qt?(Wt||V.h.va(X,V.a.Ca(nt)),V.Oa(Nt,X)):(V.h.Ea(X),dt||V.i.ma(X,V.i.H)),H=Qt)},null,{l:X}),{controlsDescendantBindings:!0}}},V.m.Ra[E]=!1,V.h.ea[E]=!0}Z("if"),Z("ifnot",!1,!0),Z("with",!0)}(),V.c.let={init:function(Z,E,I,B,X){return E=X.extend(E),V.Oa(E,Z),{controlsDescendantBindings:!0}}},V.h.ea.let=!0;var M={};V.c.options={init:function(Z){if(V.a.R(Z)!=="select")throw Error("options binding applies only to SELECT elements");for(;0<Z.length;)Z.remove(0);return{controlsDescendantBindings:!0}},update:function(Z,E,I){function B(){return V.a.jb(Z.options,function(st){return st.selected})}function X(st,Et,Qt){var Wt=typeof Et;return Wt=="function"?Et(st):Wt=="string"?st[Et]:Qt}function _(st,Et){if(q&&H)V.i.ma(Z,V.i.H);else if(dt.length){var Qt=0<=V.a.A(dt,V.w.M(Et[0]));V.a.Zc(Et[0],Qt),q&&!Qt&&V.u.G(V.a.Fb,null,[Z,"change"])}}var P=Z.multiple,w=Z.length!=0&&P?Z.scrollTop:null,z=V.a.f(E()),H=I.get("valueAllowUnset")&&I.has("value"),nt=I.get("optionsIncludeDestroyed");E={};var $,dt=[];H||(P?dt=V.a.Mb(B(),V.w.M):0<=Z.selectedIndex&&dt.push(V.w.M(Z.options[Z.selectedIndex]))),z&&(typeof z.length>"u"&&(z=[z]),$=V.a.jb(z,function(st){return nt||st===t||st===null||!V.a.f(st._destroy)}),I.has("optionsCaption")&&(z=V.a.f(I.get("optionsCaption")),z!==null&&z!==t&&$.unshift(M)));var q=!1;if(E.beforeRemove=function(st){Z.removeChild(st)},z=_,I.has("optionsAfterRender")&&typeof I.get("optionsAfterRender")=="function"&&(z=function(st,Et){_(0,Et),V.u.G(I.get("optionsAfterRender"),null,[Et[0],st!==M?st:t])}),V.a.ec(Z,$,function(st,Et,Qt){return Qt.length&&(dt=!H&&Qt[0].selected?[V.w.M(Qt[0])]:[],q=!0),Et=Z.ownerDocument.createElement("option"),st===M?(V.a.Bb(Et,I.get("optionsCaption")),V.w.cb(Et,t)):(Qt=X(st,I.get("optionsValue"),st),V.w.cb(Et,V.a.f(Qt)),st=X(st,I.get("optionsText"),Qt),V.a.Bb(Et,st)),[Et]},E,z),!H){var at;P?at=dt.length&&B().length<dt.length:at=dt.length&&0<=Z.selectedIndex?V.w.M(Z.options[Z.selectedIndex])!==dt[0]:dt.length||0<=Z.selectedIndex,at&&V.u.G(V.a.Fb,null,[Z,"change"])}(H||V.S.Ya())&&V.i.ma(Z,V.i.H),V.a.wd(Z),w&&20<Math.abs(w-Z.scrollTop)&&(Z.scrollTop=w)}},V.c.options.$b=V.a.g.Z(),V.c.selectedOptions={init:function(Z,E,I){function B(){var P=E(),w=[];V.a.D(Z.getElementsByTagName("option"),function(z){z.selected&&w.push(V.w.M(z))}),V.m.eb(P,I,"selectedOptions",w)}function X(){var P=V.a.f(E()),w=Z.scrollTop;P&&typeof P.length=="number"&&V.a.D(Z.getElementsByTagName("option"),function(z){var H=0<=V.a.A(P,V.w.M(z));z.selected!=H&&V.a.Zc(z,H)}),Z.scrollTop=w}if(V.a.R(Z)!="select")throw Error("selectedOptions binding applies only to SELECT elements");var _;V.i.subscribe(Z,V.i.H,function(){_?B():(V.a.B(Z,"change",B),_=V.o(X,null,{l:Z}))},null,{notifyImmediately:!0})},update:function(){}},V.m.wa.selectedOptions=!0,V.c.style={update:function(Z,E){var I=V.a.f(E()||{});V.a.P(I,function(B,X){if(X=V.a.f(X),(X===null||X===t||X===!1)&&(X=""),o)o(Z).css(B,X);else if(/^--/.test(B))Z.style.setProperty(B,X);else{B=B.replace(/-(\w)/g,function(P,w){return w.toUpperCase()});var _=Z.style[B];Z.style[B]=X,X===_||Z.style[B]!=_||isNaN(X)||(Z.style[B]=X+"px")}})}},V.c.submit={init:function(Z,E,I,B,X){if(typeof E()!="function")throw Error("The value for a submit binding must be a function");V.a.B(Z,"submit",function(_){var P,w=E();try{P=w.call(X.$data,Z)}finally{P!==!0&&(_.preventDefault?_.preventDefault():_.returnValue=!1)}})}},V.c.text={init:function(){return{controlsDescendantBindings:!0}},update:function(Z,E){V.a.Bb(Z,E())}},V.h.ea.text=!0,function(){if(e&&e.navigator){var Z=function($){if($)return parseFloat($[1])},E=e.navigator.userAgent,I,B,X,_,P;(I=e.opera&&e.opera.version&&parseInt(e.opera.version()))||(P=Z(E.match(/Edge\/([^ ]+)$/)))||Z(E.match(/Chrome\/([^ ]+)/))||(B=Z(E.match(/Version\/([^ ]+) Safari/)))||(X=Z(E.match(/Firefox\/([^ ]+)/)))||(_=V.a.W||Z(E.match(/MSIE ([^ ]+)/)))||(_=Z(E.match(/rv:([^ )]+)/)))}if(8<=_&&10>_)var w=V.a.g.Z(),z=V.a.g.Z(),H=function($){var dt=this.activeElement;(dt=dt&&V.a.g.get(dt,z))&&dt($)},nt=function($,dt){var q=$.ownerDocument;V.a.g.get(q,w)||(V.a.g.set(q,w,!0),V.a.B(q,"selectionchange",H)),V.a.g.set($,z,dt)};V.c.textInput={init:function($,dt,q){function at(ie,oe){V.a.B($,ie,oe)}function st(){var ie=V.a.f(dt());(ie===null||ie===t)&&(ie=""),kt!==t&&ie===kt?V.a.setTimeout(st,4):$.value!==ie&&(qt=!0,$.value=ie,qt=!1,Wt=$.value)}function Et(){Nt||(kt=$.value,Nt=V.a.setTimeout(Qt,4))}function Qt(){clearTimeout(Nt),kt=Nt=t;var ie=$.value;Wt!==ie&&(Wt=ie,V.m.eb(dt(),q,"textInput",ie))}var Wt=$.value,Nt,kt,Mt=V.a.W==9?Et:Qt,qt=!1;_&&at("keypress",Qt),11>_&&at("propertychange",function(ie){qt||ie.propertyName!=="value"||Mt(ie)}),_==8&&(at("keyup",Qt),at("keydown",Qt)),nt&&(nt($,Mt),at("dragend",Et)),(!_||9<=_)&&at("input",Mt),5>B&&V.a.R($)==="textarea"?(at("keydown",Et),at("paste",Et),at("cut",Et)):11>I?at("keydown",Et):4>X?(at("DOMAutoComplete",Qt),at("dragdrop",Qt),at("drop",Qt)):P&&$.type==="number"&&at("keydown",Et),at("change",Qt),at("blur",Qt),V.o(st,null,{l:$})}},V.m.wa.textInput=!0,V.c.textinput={preprocess:function($,dt,q){q("textInput",$)}}}(),V.c.uniqueName={init:function(Z,E){if(E()){var I="ko_unique_"+ ++V.c.uniqueName.rd;V.a.Yc(Z,I)}}},V.c.uniqueName.rd=0,V.c.using={init:function(Z,E,I,B,X){var _;return I.has("as")&&(_={as:I.get("as"),noChildContext:I.get("noChildContext")}),E=X.createChildContext(E,_),V.Oa(E,Z),{controlsDescendantBindings:!0}}},V.h.ea.using=!0,V.c.value={init:function(Z,E,I){var B=V.a.R(Z),X=B=="input";if(!X||Z.type!="checkbox"&&Z.type!="radio"){var _=[],P=I.get("valueUpdate"),w=!1,z=null;P&&(typeof P=="string"?_=[P]:_=V.a.wc(P),V.a.Pa(_,"change"));var H=function(){z=null,w=!1;var dt=E(),q=V.w.M(Z);V.m.eb(dt,I,"value",q)};!V.a.W||!X||Z.type!="text"||Z.autocomplete=="off"||Z.form&&Z.form.autocomplete=="off"||V.a.A(_,"propertychange")!=-1||(V.a.B(Z,"propertychange",function(){w=!0}),V.a.B(Z,"focus",function(){w=!1}),V.a.B(Z,"blur",function(){w&&H()})),V.a.D(_,function(dt){var q=H;V.a.Ud(dt,"after")&&(q=function(){z=V.w.M(Z),V.a.setTimeout(H,0)},dt=dt.substring(5)),V.a.B(Z,dt,q)});var nt;if(nt=X&&Z.type=="file"?function(){var dt=V.a.f(E());dt===null||dt===t||dt===""?Z.value="":V.u.G(H)}:function(){var dt=V.a.f(E()),q=V.w.M(Z);z!==null&&dt===z?V.a.setTimeout(nt,0):(dt!==q||q===t)&&(B==="select"?(q=I.get("valueAllowUnset"),V.w.cb(Z,dt,q),q||dt===V.w.M(Z)||V.u.G(H)):V.w.cb(Z,dt))},B==="select"){var $;V.i.subscribe(Z,V.i.H,function(){$?I.get("valueAllowUnset")?nt():H():(V.a.B(Z,"change",H),$=V.o(nt,null,{l:Z}))},null,{notifyImmediately:!0})}else V.a.B(Z,"change",H),V.o(nt,null,{l:Z})}else V.ib(Z,{checkedValue:E})},update:function(){}},V.m.wa.value=!0,V.c.visible={update:function(Z,E){var I=V.a.f(E()),B=Z.style.display!="none";I&&!B?Z.style.display="":!I&&B&&(Z.style.display="none")}},V.c.hidden={update:function(Z,E){V.c.visible.update(Z,function(){return!V.a.f(E())})}},function(Z){V.c[Z]={init:function(E,I,B,X,_){return V.c.event.init.call(this,E,function(){var P={};return P[Z]=I(),P},B,X,_)}}}("click"),V.ca=function(){},V.ca.prototype.renderTemplateSource=function(){throw Error("Override renderTemplateSource")},V.ca.prototype.createJavaScriptEvaluatorBlock=function(){throw Error("Override createJavaScriptEvaluatorBlock")},V.ca.prototype.makeTemplateSource=function(Z,E){if(typeof Z=="string"){E=E||n;var I=E.getElementById(Z);if(!I)throw Error("Cannot find template with ID "+Z);return new V.C.F(I)}if(Z.nodeType==1||Z.nodeType==8)return new V.C.ia(Z);throw Error("Unknown template type: "+Z)},V.ca.prototype.renderTemplate=function(Z,E,I,B){return Z=this.makeTemplateSource(Z,B),this.renderTemplateSource(Z,E,I,B)},V.ca.prototype.isTemplateRewritten=function(Z,E){return this.allowTemplateRewriting===!1?!0:this.makeTemplateSource(Z,E).data("isRewritten")},V.ca.prototype.rewriteTemplate=function(Z,E,I){Z=this.makeTemplateSource(Z,I),E=E(Z.text()),Z.text(E),Z.data("isRewritten",!0)},V.b("templateEngine",V.ca),V.kc=function(){function Z(B,X,_,P){B=V.m.ac(B);for(var w=V.m.Ra,z=0;z<B.length;z++){var H=B[z].key;if(Object.prototype.hasOwnProperty.call(w,H)){var nt=w[H];if(typeof nt=="function"){if(H=nt(B[z].value))throw Error(H)}else if(!nt)throw Error("This template engine does not support the '"+H+"' binding within its templates")}}return _="ko.__tr_ambtns(function($context,$element){return(function(){return{ "+V.m.vb(B,{valueAccessors:!0})+" } })()},'"+_.toLowerCase()+"')",P.createJavaScriptEvaluatorBlock(_)+X}var E=/(<([a-z]+\d*)(?:\s+(?!data-bind\s*=\s*)[a-z0-9\-]+(?:=(?:\"[^\"]*\"|\'[^\']*\'|[^>]*))?)*\s+)data-bind\s*=\s*(["'])([\s\S]*?)\3/gi,I=/\x3c!--\s*ko\b\s*([\s\S]*?)\s*--\x3e/g;return{xd:function(B,X,_){X.isTemplateRewritten(B,_)||X.rewriteTemplate(B,function(P){return V.kc.Ld(P,X)},_)},Ld:function(B,X){return B.replace(E,function(_,P,w,z,H){return Z(H,P,w,X)}).replace(I,function(_,P){return Z(P,"<!-- ko -->","#comment",X)})},md:function(B,X){return V.aa.Xb(function(_,P){var w=_.nextSibling;w&&w.nodeName.toLowerCase()===X&&V.ib(w,B,P)})}}}(),V.b("__tr_ambtns",V.kc.md),function(){V.C={},V.C.F=function(I){if(this.F=I){var B=V.a.R(I);this.ab=B==="script"?1:B==="textarea"?2:B=="template"&&I.content&&I.content.nodeType===11?3:4}},V.C.F.prototype.text=function(){var I=this.ab===1?"text":this.ab===2?"value":"innerHTML";if(arguments.length==0)return this.F[I];var B=arguments[0];I==="innerHTML"?V.a.fc(this.F,B):this.F[I]=B};var Z=V.a.g.Z()+"_";V.C.F.prototype.data=function(I){if(arguments.length===1)return V.a.g.get(this.F,Z+I);V.a.g.set(this.F,Z+I,arguments[1])};var E=V.a.g.Z();V.C.F.prototype.nodes=function(){var I=this.F;if(arguments.length==0){var B=V.a.g.get(I,E)||{},X=B.lb||(this.ab===3?I.content:this.ab===4?I:t);if(!X||B.jd){var _=this.text();_&&_!==B.bb&&(X=V.a.Md(_,I.ownerDocument),V.a.g.set(I,E,{lb:X,bb:_,jd:!0}))}return X}B=arguments[0],this.ab!==t&&this.text(""),V.a.g.set(I,E,{lb:B})},V.C.ia=function(I){this.F=I},V.C.ia.prototype=new V.C.F,V.C.ia.prototype.constructor=V.C.ia,V.C.ia.prototype.text=function(){if(arguments.length==0){var I=V.a.g.get(this.F,E)||{};return I.bb===t&&I.lb&&(I.bb=I.lb.innerHTML),I.bb}V.a.g.set(this.F,E,{bb:arguments[0]})},V.b("templateSources",V.C),V.b("templateSources.domElement",V.C.F),V.b("templateSources.anonymousTemplate",V.C.ia)}(),function(){function Z(z,H,nt){var $;for(H=V.h.nextSibling(H);z&&($=z)!==H;)z=V.h.nextSibling($),nt($,z)}function E(z,H){if(z.length){var nt=z[0],$=z[z.length-1],dt=nt.parentNode,q=V.ga.instance,at=q.preprocessNode;if(at){if(Z(nt,$,function(st,Et){var Qt=st.previousSibling,Wt=at.call(q,st);Wt&&(st===nt&&(nt=Wt[0]||Et),st===$&&($=Wt[Wt.length-1]||Qt))}),z.length=0,!nt)return;nt===$?z.push(nt):(z.push(nt,$),V.a.Ua(z,dt))}Z(nt,$,function(st){st.nodeType!==1&&st.nodeType!==8||V.vc(H,st)}),Z(nt,$,function(st){st.nodeType!==1&&st.nodeType!==8||V.aa.cd(st,[H])}),V.a.Ua(z,dt)}}function I(z){return z.nodeType?z:0<z.length?z[0]:null}function B(z,H,nt,$,dt){dt=dt||{};var q=(z&&I(z)||nt||{}).ownerDocument,at=dt.templateEngine||_;if(V.kc.xd(nt,at,q),nt=at.renderTemplate(nt,$,dt,q),typeof nt.length!="number"||0<nt.length&&typeof nt[0].nodeType!="number")throw Error("Template engine must return an array of DOM nodes");switch(q=!1,H){case"replaceChildren":V.h.va(z,nt),q=!0;break;case"replaceNode":V.a.Xc(z,nt),q=!0;break;case"ignoreTargetNode":break;default:throw Error("Unknown renderMode: "+H)}return q&&(E(nt,$),dt.afterRender&&V.u.G(dt.afterRender,null,[nt,$[dt.as||"$data"]]),H=="replaceChildren"&&V.i.ma(z,V.i.H)),nt}function X(z,H,nt){return V.O(z)?z():typeof z=="function"?z(H,nt):z}var _;V.gc=function(z){if(z!=t&&!(z instanceof V.ca))throw Error("templateEngine must inherit from ko.templateEngine");_=z},V.dc=function(z,H,nt,$,dt){if(nt=nt||{},(nt.templateEngine||_)==t)throw Error("Set a template engine before calling renderTemplate");if(dt=dt||"replaceChildren",$){var q=I($);return V.$(function(){var st=H&&H instanceof V.fa?H:new V.fa(H,null,null,null,{exportDependencies:!0}),at=X(z,st.$data,st),st=B($,dt,at,st,nt);dt=="replaceNode"&&($=st,q=I($))},null,{Sa:function(){return!q||!V.a.Sb(q)},l:q&&dt=="replaceNode"?q.parentNode:q})}return V.aa.Xb(function(at){V.dc(z,H,nt,at,"replaceNode")})},V.Qd=function(z,H,nt,$,dt){function q(kt,Mt){V.u.G(V.a.ec,null,[$,kt,st,nt,at,Mt]),V.i.ma($,V.i.H)}function at(kt,Mt){E(Mt,Et),nt.afterRender&&nt.afterRender(Mt,kt),Et=null}function st(kt,Mt){Et=dt.createChildContext(kt,{as:Qt,noChildContext:nt.noChildContext,extend:function(ie){ie.$index=Mt,Qt&&(ie[Qt+"Index"]=Mt)}});var qt=X(z,kt,Et);return B($,"ignoreTargetNode",qt,Et,nt)}var Et,Qt=nt.as,Wt=nt.includeDestroyed===!1||V.options.foreachHidesDestroyed&&!nt.includeDestroyed;if(Wt||nt.beforeRemove||!V.Pc(H))return V.$(function(){var kt=V.a.f(H)||[];typeof kt.length>"u"&&(kt=[kt]),Wt&&(kt=V.a.jb(kt,function(Mt){return Mt===t||Mt===null||!V.a.f(Mt._destroy)})),q(kt)},null,{l:$});q(H.v());var Nt=H.subscribe(function(kt){q(H(),kt)},null,"arrayChange");return Nt.l($),Nt};var P=V.a.g.Z(),w=V.a.g.Z();V.c.template={init:function(z,H){var nt=V.a.f(H());if(typeof nt=="string"||"name"in nt)V.h.Ea(z);else if("nodes"in nt){if(nt=nt.nodes||[],V.O(nt))throw Error('The "nodes" option must be a plain, non-observable array.');var $=nt[0]&&nt[0].parentNode;$&&V.a.g.get($,w)||($=V.a.Yb(nt),V.a.g.set($,w,!0)),new V.C.ia(z).nodes($)}else if(nt=V.h.childNodes(z),0<nt.length)$=V.a.Yb(nt),new V.C.ia(z).nodes($);else throw Error("Anonymous template defined, but no template content was provided");return{controlsDescendantBindings:!0}},update:function(z,H,nt,$,dt){var q=H();H=V.a.f(q),nt=!0,$=null,typeof H=="string"?H={}:(q="name"in H?H.name:z,"if"in H&&(nt=V.a.f(H.if)),nt&&"ifnot"in H&&(nt=!V.a.f(H.ifnot)),nt&&!q&&(nt=!1)),"foreach"in H?$=V.Qd(q,nt&&H.foreach||[],H,z,dt):nt?(nt=dt,"data"in H&&(nt=dt.createChildContext(H.data,{as:H.as,noChildContext:H.noChildContext,exportDependencies:!0})),$=V.dc(q,nt,H,z)):V.h.Ea(z),dt=$,(H=V.a.g.get(z,P))&&typeof H.s=="function"&&H.s(),V.a.g.set(z,P,!dt||dt.ja&&!dt.ja()?t:dt)}},V.m.Ra.template=function(z){return z=V.m.ac(z),z.length==1&&z[0].unknown||V.m.Id(z,"name")?null:"This template engine does not support anonymous templates nested within its templates"},V.h.ea.template=!0}(),V.b("setTemplateEngine",V.gc),V.b("renderTemplate",V.dc),V.a.Kc=function(Z,E,I){if(Z.length&&E.length){var B,X,_,P,w;for(B=X=0;(!I||B<I)&&(P=Z[X]);++X){for(_=0;w=E[_];++_)if(P.value===w.value){P.moved=w.index,w.moved=P.index,E.splice(_,1),B=_=0;break}B+=_}}},V.a.Pb=function(){function Z(E,I,B,X,_){var P=Math.min,w=Math.max,z=[],H,nt=E.length,$,dt=I.length,q=dt-nt||1,at=nt+dt+1,st,Et,Qt;for(H=0;H<=nt;H++)for(Et=st,z.push(st=[]),Qt=P(dt,H+q),$=w(0,H-1);$<=Qt;$++)st[$]=$?H?E[H-1]===I[$-1]?Et[$-1]:P(Et[$]||at,st[$-1]||at)+1:$+1:H+1;for(P=[],w=[],q=[],H=nt,$=dt;H||$;)dt=z[H][$]-1,$&&dt===z[H][$-1]?w.push(P[P.length]={status:B,value:I[--$],index:$}):H&&dt===z[H-1][$]?q.push(P[P.length]={status:X,value:E[--H],index:H}):(--$,--H,_.sparse||P.push({status:"retained",value:I[$]}));return V.a.Kc(q,w,!_.dontLimitMoves&&10*nt),P.reverse()}return function(E,I,B){return B=typeof B=="boolean"?{dontLimitMoves:B}:B||{},E=E||[],I=I||[],E.length<I.length?Z(E,I,"added","deleted",B):Z(I,E,"deleted","added",B)}}(),V.b("utils.compareArrays",V.a.Pb),function(){function Z(B,X,_,P,w){var z=[],H=V.$(function(){var nt=X(_,w,V.a.Ua(z,B))||[];0<z.length&&(V.a.Xc(z,nt),P&&V.u.G(P,null,[_,nt,w])),z.length=0,V.a.Nb(z,nt)},null,{l:B,Sa:function(){return!V.a.kd(z)}});return{Y:z,$:H.ja()?H:t}}var E=V.a.g.Z(),I=V.a.g.Z();V.a.ec=function(B,X,_,P,w,z){function H(We){qt={Aa:We,pb:V.ta(Et++)},at.push(qt),q||Mt.push(qt)}function nt(We){qt=dt[We],Et!==qt.pb.v()&&kt.push(qt),qt.pb(Et++),V.a.Ua(qt.Y,B),at.push(qt)}function $(We,Vn){if(We)for(var Ct=0,_t=Vn.length;Ct<_t;Ct++)V.a.D(Vn[Ct].Y,function(Je){We(Je,Ct,Vn[Ct].Aa)})}X=X||[],typeof X.length>"u"&&(X=[X]),P=P||{};var dt=V.a.g.get(B,E),q=!dt,at=[],st=0,Et=0,Qt=[],Wt=[],Nt=[],kt=[],Mt=[],qt,ie=0;if(q)V.a.D(X,H);else{if(!z||dt&&dt._countWaitingForRemove){var oe=V.a.Mb(dt,function(We){return We.Aa});z=V.a.Pb(oe,X,{dontLimitMoves:P.dontLimitMoves,sparse:!0})}for(var oe=0,He,rn,de;He=z[oe];oe++)switch(rn=He.moved,de=He.index,He.status){case"deleted":for(;st<de;)nt(st++);rn===t&&(qt=dt[st],qt.$&&(qt.$.s(),qt.$=t),V.a.Ua(qt.Y,B).length&&(P.beforeRemove&&(at.push(qt),ie++,qt.Aa===I?qt=null:Nt.push(qt)),qt&&Qt.push.apply(Qt,qt.Y))),st++;break;case"added":for(;Et<de;)nt(st++);rn!==t?(Wt.push(at.length),nt(rn)):H(He.value)}for(;Et<X.length;)nt(st++);at._countWaitingForRemove=ie}V.a.g.set(B,E,at),$(P.beforeMove,kt),V.a.D(Qt,P.beforeRemove?V.oa:V.removeNode);var zt,ke,Ve;try{Ve=B.ownerDocument.activeElement}catch{}if(Wt.length)for(;(oe=Wt.shift())!=t;){for(qt=at[oe],zt=t;oe;)if((ke=at[--oe].Y)&&ke.length){zt=ke[ke.length-1];break}for(X=0;st=qt.Y[X];zt=st,X++)V.h.Wb(B,st,zt)}for(oe=0;qt=at[oe];oe++){for(qt.Y||V.a.extend(qt,Z(B,_,qt.Aa,w,qt.pb)),X=0;st=qt.Y[X];zt=st,X++)V.h.Wb(B,st,zt);!qt.Ed&&w&&(w(qt.Aa,qt.Y,qt.pb),qt.Ed=!0,zt=qt.Y[qt.Y.length-1])}for(Ve&&B.ownerDocument.activeElement!=Ve&&Ve.focus(),$(P.beforeRemove,Nt),oe=0;oe<Nt.length;++oe)Nt[oe].Aa=I;$(P.afterMove,kt),$(P.afterAdd,Mt)}}(),V.b("utils.setDomNodeChildrenFromArrayMapping",V.a.ec),V.ba=function(){this.allowTemplateRewriting=!1},V.ba.prototype=new V.ca,V.ba.prototype.constructor=V.ba,V.ba.prototype.renderTemplateSource=function(Z,E,I,B){return(E=!(9>V.a.W)&&Z.nodes?Z.nodes():null)?V.a.la(E.cloneNode(!0).childNodes):(Z=Z.text(),V.a.ua(Z,B))},V.ba.Ma=new V.ba,V.gc(V.ba.Ma),V.b("nativeTemplateEngine",V.ba),function(){V.$a=function(){var E=this.Hd=function(){if(!o||!o.tmpl)return 0;try{if(0<=o.tmpl.tag.tmpl.open.toString().indexOf("__"))return 2}catch{}return 1}();this.renderTemplateSource=function(I,B,X,_){if(_=_||n,X=X||{},2>E)throw Error("Your version of jQuery.tmpl is too old. Please upgrade to jQuery.tmpl 1.0.0pre or later.");var P=I.data("precompiled");return P||(P=I.text()||"",P=o.template(null,"{{ko_with $item.koBindingContext}}"+P+"{{/ko_with}}"),I.data("precompiled",P)),I=[B.$data],B=o.extend({koBindingContext:B},X.templateOptions),B=o.tmpl(P,I,B),B.appendTo(_.createElement("div")),o.fragments={},B},this.createJavaScriptEvaluatorBlock=function(I){return"{{ko_code ((function() { return "+I+" })()) }}"},this.addTemplate=function(I,B){n.write("<script type='text/html' id='"+I+"'>"+B+"<\/script>")},0<E&&(o.tmpl.tag.ko_code={open:"__.push($1 || '');"},o.tmpl.tag.ko_with={open:"with($1) {",close:"} "})},V.$a.prototype=new V.ca,V.$a.prototype.constructor=V.$a;var Z=new V.$a;0<Z.Hd&&V.gc(Z),V.b("jqueryTmplTemplateEngine",V.$a)}()})})()})()})();var $9e=ko;typeof window<"u"?(ko=window.ko,typeof mD<"u"?window.ko=mD:delete window.ko):(ko=global.ko,typeof mD<"u"?global.ko=mD:delete global.ko);var dg=$9e;var QWa=b(W(),1);/** * @license * Knockout ES5 plugin - https://github.com/SteveSanderson/knockout-es5 * Copyright (c) Steve Sanderson * MIT license - */var grt="__knockoutObservables",Ert="__knockoutSubscribable";function lkt(t,e){if(!t)throw new Error("When calling ko.track, you must pass an object as the first parameter.");var n=this,i=rkt(t,!0);return e=e||Object.getOwnPropertyNames(t),e.forEach(function(o){if(!(o===grt||o===Ert)&&!(o in i)){var a=t[o],s=a instanceof Array,l=n.isObservable(a)?a:s?n.observableArray(a):n.observable(a);Object.defineProperty(t,o,{configurable:!0,enumerable:!0,get:l,set:n.isWriteableObservable(l)?l:void 0}),i[o]=l,s&&e5e(n,l)}}),t}function rkt(t,e){var n=t[grt];return!n&&e&&(n={},Object.defineProperty(t,grt,{value:n})),n}function t5e(t,e,n){var i=this,o={owner:t,deferEvaluation:!0};if(typeof n=="function")o.read=n;else{if("value"in n)throw new Error('For ko.defineProperty, you must not specify a "value" for the property. You must provide a "get" function.');if(typeof n.get!="function")throw new Error('For ko.defineProperty, the third parameter must be either an evaluator function, or an options object containing a function called "get".');o.read=n.get,o.write=n.set}return t[e]=i.computed(o),lkt.call(i,t,[e]),t}function e5e(t,e){var n=null;t.computed(function(){n&&(n.dispose(),n=null);var i=e();i instanceof Array&&(n=n5e(t,e,i))})}function n5e(t,e,n){var i=i5e(t,n);return i.subscribe(e)}function i5e(t,e){var n=e[Ert];if(!n){n=new t.subscribable,Object.defineProperty(e,Ert,{value:n});var i={};o5e(e,n,i),a5e(t,e,n,i)}return n}function o5e(t,e,n){["pop","push","reverse","shift","sort","splice","unshift"].forEach(function(i){var o=t[i];t[i]=function(){var a=o.apply(this,arguments);return n.pause!==!0&&e.notifySubscribers(this),a}})}function a5e(t,e,n,i){["remove","removeAll","destroy","destroyAll","replace"].forEach(function(o){Object.defineProperty(e,o,{enumerable:!1,value:function(){var a;i.pause=!0;try{a=t.observableArray.fn[o].apply(t.observableArray(e),arguments)}finally{i.pause=!1}return n.notifySubscribers(e),a}})})}function dkt(t,e){if(!t)return null;var n=rkt(t,!1);return n&&n[e]||null}function s5e(t,e){var n=dkt(t,e);n&&n.valueHasMutated()}function l5e(t){t.track=lkt,t.getObservable=dkt,t.valueHasMutated=s5e,t.defineProperty=t5e}var hD={attachToKo:l5e};var YWa=R(W(),1),ckt="http://www.w3.org/2000/svg",mkt="cesium-svgPath-svg",r5e={register:function(t){t.bindingHandlers.cesiumSvgPath={init:function(e,n){let i=document.createElementNS(ckt,"svg:svg");i.setAttribute("class",mkt);let o=document.createElementNS(ckt,"path");return i.appendChild(o),t.virtualElements.setDomNodeChildren(e,[i]),t.computed({read:function(){let a=t.unwrap(n());o.setAttribute("d",t.unwrap(a.path));let s=t.unwrap(a.width),l=t.unwrap(a.height);i.setAttribute("width",s),i.setAttribute("height",l),i.setAttribute("viewBox",`0 0 ${s} ${l}`),a.css&&i.setAttribute("class",`${mkt} ${t.unwrap(a.css)}`)},disposeWhenNodeIsRemoved:e}),{controlsDescendantBindings:!0}}},t.virtualElements.allowedBindings.cesiumSvgPath=!0}},pD=r5e;hD.attachToKo(dg);pD.register(dg);var Lt=dg;function uD(t){c(t)||(t=new kZ),this._clock=t,this._eventHelper=new rl,this._eventHelper.add(t.onTick,this.synchronize,this),this.systemTime=Lt.observable(rt.now()),this.systemTime.equalityComparer=rt.equals,this.startTime=Lt.observable(t.startTime),this.startTime.equalityComparer=rt.equals,this.startTime.subscribe(function(e){t.startTime=e,this.synchronize()},this),this.stopTime=Lt.observable(t.stopTime),this.stopTime.equalityComparer=rt.equals,this.stopTime.subscribe(function(e){t.stopTime=e,this.synchronize()},this),this.currentTime=Lt.observable(t.currentTime),this.currentTime.equalityComparer=rt.equals,this.currentTime.subscribe(function(e){t.currentTime=e,this.synchronize()},this),this.multiplier=Lt.observable(t.multiplier),this.multiplier.subscribe(function(e){t.multiplier=e,this.synchronize()},this),this.clockStep=Lt.observable(t.clockStep),this.clockStep.subscribe(function(e){t.clockStep=e,this.synchronize()},this),this.clockRange=Lt.observable(t.clockRange),this.clockRange.subscribe(function(e){t.clockRange=e,this.synchronize()},this),this.canAnimate=Lt.observable(t.canAnimate),this.canAnimate.subscribe(function(e){t.canAnimate=e,this.synchronize()},this),this.shouldAnimate=Lt.observable(t.shouldAnimate),this.shouldAnimate.subscribe(function(e){t.shouldAnimate=e,this.synchronize()},this),Lt.track(this,["systemTime","startTime","stopTime","currentTime","multiplier","clockStep","clockRange","canAnimate","shouldAnimate"])}Object.defineProperties(uD.prototype,{clock:{get:function(){return this._clock}}});uD.prototype.synchronize=function(){let t=this._clock;this.systemTime=rt.now(),this.startTime=t.startTime,this.stopTime=t.stopTime,this.currentTime=t.currentTime,this.multiplier=t.multiplier,this.clockStep=t.clockStep,this.clockRange=t.clockRange,this.canAnimate=t.canAnimate,this.shouldAnimate=t.shouldAnimate};uD.prototype.isDestroyed=function(){return!1};uD.prototype.destroy=function(){this._eventHelper.removeAll(),At(this)};var ZD=uD;var vWa=R(W(),1);function d5e(){this.canExecute=void 0,this.beforeExecute=void 0,this.afterExecute=void 0,Ut.throwInstantiationError()}var Crt=d5e;var qWa=R(W(),1);var VD={};VD.createCheckbox=function(t,e,n){let i=document.createElement("div"),o=document.createElement("label"),a=document.createElement("input");a.type="checkbox";let s=`checked: ${e}`;return c(n)&&(s+=`, enable: ${n}`),a.setAttribute("data-bind",s),o.appendChild(a),o.appendChild(document.createTextNode(t)),i.appendChild(o),i};VD.createSection=function(t,e,n,i){let o=document.createElement("div");o.className="cesium-cesiumInspector-section",o.setAttribute("data-bind",`css: { "cesium-cesiumInspector-section-collapsed": !${n} }`),t.appendChild(o);let a=document.createElement("h3");a.className="cesium-cesiumInspector-sectionHeader",a.appendChild(document.createTextNode(e)),a.setAttribute("data-bind",`click: ${i}`),o.appendChild(a);let s=document.createElement("div");return s.className="cesium-cesiumInspector-sectionContent",o.appendChild(s),s};VD.createRangeInput=function(t,e,n,i,o,a){a=f(a,e);let s=document.createElement("input");s.setAttribute("data-bind",`value: ${a}`),s.type="number";let l=document.createElement("input");l.type="range",l.min=n,l.max=i,l.step=f(o,"any"),l.setAttribute("data-bind",`valueUpdate: "input", value: ${e}`);let r=document.createElement("div");r.appendChild(l);let d=document.createElement("div");return d.className="cesium-cesiumInspector-slider",d.appendChild(document.createTextNode(t)),d.appendChild(s),d.appendChild(r),d};VD.createButton=function(t,e,n){let i=document.createElement("button");i.type="button",i.textContent=t,i.className="cesium-cesiumInspector-pickButton";let o=`click: ${e}`;return c(n)&&(o+=`, css: {"cesium-cesiumInspector-pickButtonHighlight" : ${n}}`),i.setAttribute("data-bind",o),i};var gd=VD;var ofa=R(W(),1);function hkt(t,e){this._command=t,e=f(e,f.EMPTY_OBJECT),this.toggled=f(e.toggled,!1),this.tooltip=f(e.tooltip,""),Lt.track(this,["toggled","tooltip"])}Object.defineProperties(hkt.prototype,{command:{get:function(){return this._command}}});var YU=hkt;var cfa=R(W(),1);function c5e(t,e){e=f(e,!0);let n=new It,i=new It;function o(){let a={args:arguments,cancel:!1},s;return n.raiseEvent(a),a.cancel||(s=t.apply(null,arguments),i.raiseEvent(s)),s}return o.canExecute=e,Lt.track(o,["canExecute"]),Object.defineProperties(o,{beforeExecute:{value:n},afterExecute:{value:i}}),o}var bi=c5e;var pfa=R(W(),1);function m5e(t,e,n,i,o){return n.call(i,t[e]),Lt.getObservable(t,e).subscribe(n,i,o)}var od=m5e;var Tfa=R(W(),1);var Rfa=R(W(),1);function h5e(t){return function(e){let n=t._scene.pick(e.position);c(n)&&n.primitive instanceof Pr&&(t.tileset=n.primitive),t.pickActive=!1}}function ukt(t,e){e?t._eventHandler.setInputAction(function(n){let i=t._scene.pick(n.endPosition);c(i)&&i.primitive instanceof Pr&&(t.tileset=i.primitive)},Zi.MOUSE_MOVE):(t._eventHandler.removeInputAction(Zi.MOUSE_MOVE),t.picking=t.picking)}var p5e={maximumFractionDigits:3};function bD(t){let e=t/1048576;return e<1?e.toLocaleString(void 0,p5e):Math.round(e).toLocaleString()}function RD(t,e){if(!c(t))return"";let n=e?t._statisticsPerPass[ns.PICK]:t._statisticsPerPass[ns.RENDER],i='<ul class="cesium-cesiumInspector-statistics">';return i+=`<li><strong>Visited: </strong>${n.visited.toLocaleString()}</li><li><strong>Selected: </strong>${n.selected.toLocaleString()}</li><li><strong>Commands: </strong>${n.numberOfCommands.toLocaleString()}</li>`,i+="</ul>",e||(i+='<ul class="cesium-cesiumInspector-statistics">',i+=`<li><strong>Requests: </strong>${n.numberOfPendingRequests.toLocaleString()}</li><li><strong>Attempted: </strong>${n.numberOfAttemptedRequests.toLocaleString()}</li><li><strong>Processing: </strong>${n.numberOfTilesProcessing.toLocaleString()}</li><li><strong>Content Ready: </strong>${n.numberOfTilesWithContentReady.toLocaleString()}</li><li><strong>Total: </strong>${n.numberOfTilesTotal.toLocaleString()}</li>`,i+="</ul>",i+='<ul class="cesium-cesiumInspector-statistics">',i+=`<li><strong>Features Selected: </strong>${n.numberOfFeaturesSelected.toLocaleString()}</li><li><strong>Features Loaded: </strong>${n.numberOfFeaturesLoaded.toLocaleString()}</li><li><strong>Points Selected: </strong>${n.numberOfPointsSelected.toLocaleString()}</li><li><strong>Points Loaded: </strong>${n.numberOfPointsLoaded.toLocaleString()}</li><li><strong>Triangles Selected: </strong>${n.numberOfTrianglesSelected.toLocaleString()}</li>`,i+="</ul>",i+='<ul class="cesium-cesiumInspector-statistics">',i+=`<li><strong>Tiles styled: </strong>${n.numberOfTilesStyled.toLocaleString()}</li><li><strong>Features styled: </strong>${n.numberOfFeaturesStyled.toLocaleString()}</li>`,i+="</ul>",i+='<ul class="cesium-cesiumInspector-statistics">',i+=`<li><strong>Children Union Culled: </strong>${n.numberOfTilesCulledWithChildrenUnion.toLocaleString()}</li>`,i+="</ul>",i+='<ul class="cesium-cesiumInspector-statistics">',i+=`<li><strong>Geometry Memory (MB): </strong>${bD(n.geometryByteLength)}</li><li><strong>Texture Memory (MB): </strong>${bD(n.texturesByteLength)}</li><li><strong>Batch Table Memory (MB): </strong>${bD(n.batchTableByteLength)}</li>`,i+="</ul>"),i}function Zkt(){let t=jo.statistics;return` + */var grt="__knockoutObservables",Ert="__knockoutSubscribable";function l2t(t,e){if(!t)throw new Error("When calling ko.track, you must pass an object as the first parameter.");var n=this,i=r2t(t,!0);return e=e||Object.getOwnPropertyNames(t),e.forEach(function(o){if(!(o===grt||o===Ert)&&!(o in i)){var a=t[o],s=a instanceof Array,l=n.isObservable(a)?a:s?n.observableArray(a):n.observable(a);Object.defineProperty(t,o,{configurable:!0,enumerable:!0,get:l,set:n.isWriteableObservable(l)?l:void 0}),i[o]=l,s&&e5e(n,l)}}),t}function r2t(t,e){var n=t[grt];return!n&&e&&(n={},Object.defineProperty(t,grt,{value:n})),n}function t5e(t,e,n){var i=this,o={owner:t,deferEvaluation:!0};if(typeof n=="function")o.read=n;else{if("value"in n)throw new Error('For ko.defineProperty, you must not specify a "value" for the property. You must provide a "get" function.');if(typeof n.get!="function")throw new Error('For ko.defineProperty, the third parameter must be either an evaluator function, or an options object containing a function called "get".');o.read=n.get,o.write=n.set}return t[e]=i.computed(o),l2t.call(i,t,[e]),t}function e5e(t,e){var n=null;t.computed(function(){n&&(n.dispose(),n=null);var i=e();i instanceof Array&&(n=n5e(t,e,i))})}function n5e(t,e,n){var i=i5e(t,n);return i.subscribe(e)}function i5e(t,e){var n=e[Ert];if(!n){n=new t.subscribable,Object.defineProperty(e,Ert,{value:n});var i={};o5e(e,n,i),a5e(t,e,n,i)}return n}function o5e(t,e,n){["pop","push","reverse","shift","sort","splice","unshift"].forEach(function(i){var o=t[i];t[i]=function(){var a=o.apply(this,arguments);return n.pause!==!0&&e.notifySubscribers(this),a}})}function a5e(t,e,n,i){["remove","removeAll","destroy","destroyAll","replace"].forEach(function(o){Object.defineProperty(e,o,{enumerable:!1,value:function(){var a;i.pause=!0;try{a=t.observableArray.fn[o].apply(t.observableArray(e),arguments)}finally{i.pause=!1}return n.notifySubscribers(e),a}})})}function d2t(t,e){if(!t)return null;var n=r2t(t,!1);return n&&n[e]||null}function s5e(t,e){var n=d2t(t,e);n&&n.valueHasMutated()}function l5e(t){t.track=l2t,t.getObservable=d2t,t.valueHasMutated=s5e,t.defineProperty=t5e}var hD={attachToKo:l5e};var YWa=b(W(),1),c2t="http://www.w3.org/2000/svg",m2t="cesium-svgPath-svg",r5e={register:function(t){t.bindingHandlers.cesiumSvgPath={init:function(e,n){let i=document.createElementNS(c2t,"svg:svg");i.setAttribute("class",m2t);let o=document.createElementNS(c2t,"path");return i.appendChild(o),t.virtualElements.setDomNodeChildren(e,[i]),t.computed({read:function(){let a=t.unwrap(n());o.setAttribute("d",t.unwrap(a.path));let s=t.unwrap(a.width),l=t.unwrap(a.height);i.setAttribute("width",s),i.setAttribute("height",l),i.setAttribute("viewBox",`0 0 ${s} ${l}`),a.css&&i.setAttribute("class",`${m2t} ${t.unwrap(a.css)}`)},disposeWhenNodeIsRemoved:e}),{controlsDescendantBindings:!0}}},t.virtualElements.allowedBindings.cesiumSvgPath=!0}},pD=r5e;hD.attachToKo(dg);pD.register(dg);var Lt=dg;function VD(t){c(t)||(t=new ku),this._clock=t,this._eventHelper=new rl,this._eventHelper.add(t.onTick,this.synchronize,this),this.systemTime=Lt.observable(rt.now()),this.systemTime.equalityComparer=rt.equals,this.startTime=Lt.observable(t.startTime),this.startTime.equalityComparer=rt.equals,this.startTime.subscribe(function(e){t.startTime=e,this.synchronize()},this),this.stopTime=Lt.observable(t.stopTime),this.stopTime.equalityComparer=rt.equals,this.stopTime.subscribe(function(e){t.stopTime=e,this.synchronize()},this),this.currentTime=Lt.observable(t.currentTime),this.currentTime.equalityComparer=rt.equals,this.currentTime.subscribe(function(e){t.currentTime=e,this.synchronize()},this),this.multiplier=Lt.observable(t.multiplier),this.multiplier.subscribe(function(e){t.multiplier=e,this.synchronize()},this),this.clockStep=Lt.observable(t.clockStep),this.clockStep.subscribe(function(e){t.clockStep=e,this.synchronize()},this),this.clockRange=Lt.observable(t.clockRange),this.clockRange.subscribe(function(e){t.clockRange=e,this.synchronize()},this),this.canAnimate=Lt.observable(t.canAnimate),this.canAnimate.subscribe(function(e){t.canAnimate=e,this.synchronize()},this),this.shouldAnimate=Lt.observable(t.shouldAnimate),this.shouldAnimate.subscribe(function(e){t.shouldAnimate=e,this.synchronize()},this),Lt.track(this,["systemTime","startTime","stopTime","currentTime","multiplier","clockStep","clockRange","canAnimate","shouldAnimate"])}Object.defineProperties(VD.prototype,{clock:{get:function(){return this._clock}}});VD.prototype.synchronize=function(){let t=this._clock;this.systemTime=rt.now(),this.startTime=t.startTime,this.stopTime=t.stopTime,this.currentTime=t.currentTime,this.multiplier=t.multiplier,this.clockStep=t.clockStep,this.clockRange=t.clockRange,this.canAnimate=t.canAnimate,this.shouldAnimate=t.shouldAnimate};VD.prototype.isDestroyed=function(){return!1};VD.prototype.destroy=function(){this._eventHelper.removeAll(),At(this)};var uD=VD;var vWa=b(W(),1);function d5e(){this.canExecute=void 0,this.beforeExecute=void 0,this.afterExecute=void 0,Ut.throwInstantiationError()}var Crt=d5e;var qWa=b(W(),1);var ZD={};ZD.createCheckbox=function(t,e,n){let i=document.createElement("div"),o=document.createElement("label"),a=document.createElement("input");a.type="checkbox";let s=`checked: ${e}`;return c(n)&&(s+=`, enable: ${n}`),a.setAttribute("data-bind",s),o.appendChild(a),o.appendChild(document.createTextNode(t)),i.appendChild(o),i};ZD.createSection=function(t,e,n,i){let o=document.createElement("div");o.className="cesium-cesiumInspector-section",o.setAttribute("data-bind",`css: { "cesium-cesiumInspector-section-collapsed": !${n} }`),t.appendChild(o);let a=document.createElement("h3");a.className="cesium-cesiumInspector-sectionHeader",a.appendChild(document.createTextNode(e)),a.setAttribute("data-bind",`click: ${i}`),o.appendChild(a);let s=document.createElement("div");return s.className="cesium-cesiumInspector-sectionContent",o.appendChild(s),s};ZD.createRangeInput=function(t,e,n,i,o,a){a=f(a,e);let s=document.createElement("input");s.setAttribute("data-bind",`value: ${a}`),s.type="number";let l=document.createElement("input");l.type="range",l.min=n,l.max=i,l.step=f(o,"any"),l.setAttribute("data-bind",`valueUpdate: "input", value: ${e}`);let r=document.createElement("div");r.appendChild(l);let d=document.createElement("div");return d.className="cesium-cesiumInspector-slider",d.appendChild(document.createTextNode(t)),d.appendChild(s),d.appendChild(r),d};ZD.createButton=function(t,e,n){let i=document.createElement("button");i.type="button",i.textContent=t,i.className="cesium-cesiumInspector-pickButton";let o=`click: ${e}`;return c(n)&&(o+=`, css: {"cesium-cesiumInspector-pickButtonHighlight" : ${n}}`),i.setAttribute("data-bind",o),i};var gd=ZD;var ofa=b(W(),1);function h2t(t,e){this._command=t,e=f(e,f.EMPTY_OBJECT),this.toggled=f(e.toggled,!1),this.tooltip=f(e.tooltip,""),Lt.track(this,["toggled","tooltip"])}Object.defineProperties(h2t.prototype,{command:{get:function(){return this._command}}});var YU=h2t;var cfa=b(W(),1);function c5e(t,e){e=f(e,!0);let n=new It,i=new It;function o(){let a={args:arguments,cancel:!1},s;return n.raiseEvent(a),a.cancel||(s=t.apply(null,arguments),i.raiseEvent(s)),s}return o.canExecute=e,Lt.track(o,["canExecute"]),Object.defineProperties(o,{beforeExecute:{value:n},afterExecute:{value:i}}),o}var Ri=c5e;var pfa=b(W(),1);function m5e(t,e,n,i,o){return n.call(i,t[e]),Lt.getObservable(t,e).subscribe(n,i,o)}var od=m5e;var Sfa=b(W(),1);var bfa=b(W(),1);function h5e(t){return function(e){let n=t._scene.pick(e.position);c(n)&&n.primitive instanceof Pr&&(t.tileset=n.primitive),t.pickActive=!1}}function V2t(t,e){e?t._eventHandler.setInputAction(function(n){let i=t._scene.pick(n.endPosition);c(i)&&i.primitive instanceof Pr&&(t.tileset=i.primitive)},ui.MOUSE_MOVE):(t._eventHandler.removeInputAction(ui.MOUSE_MOVE),t.picking=t.picking)}var p5e={maximumFractionDigits:3};function RD(t){let e=t/1048576;return e<1?e.toLocaleString(void 0,p5e):Math.round(e).toLocaleString()}function bD(t,e){if(!c(t))return"";let n=e?t._statisticsPerPass[ns.PICK]:t._statisticsPerPass[ns.RENDER],i='<ul class="cesium-cesiumInspector-statistics">';return i+=`<li><strong>Visited: </strong>${n.visited.toLocaleString()}</li><li><strong>Selected: </strong>${n.selected.toLocaleString()}</li><li><strong>Commands: </strong>${n.numberOfCommands.toLocaleString()}</li>`,i+="</ul>",e||(i+='<ul class="cesium-cesiumInspector-statistics">',i+=`<li><strong>Requests: </strong>${n.numberOfPendingRequests.toLocaleString()}</li><li><strong>Attempted: </strong>${n.numberOfAttemptedRequests.toLocaleString()}</li><li><strong>Processing: </strong>${n.numberOfTilesProcessing.toLocaleString()}</li><li><strong>Content Ready: </strong>${n.numberOfTilesWithContentReady.toLocaleString()}</li><li><strong>Total: </strong>${n.numberOfTilesTotal.toLocaleString()}</li>`,i+="</ul>",i+='<ul class="cesium-cesiumInspector-statistics">',i+=`<li><strong>Features Selected: </strong>${n.numberOfFeaturesSelected.toLocaleString()}</li><li><strong>Features Loaded: </strong>${n.numberOfFeaturesLoaded.toLocaleString()}</li><li><strong>Points Selected: </strong>${n.numberOfPointsSelected.toLocaleString()}</li><li><strong>Points Loaded: </strong>${n.numberOfPointsLoaded.toLocaleString()}</li><li><strong>Triangles Selected: </strong>${n.numberOfTrianglesSelected.toLocaleString()}</li>`,i+="</ul>",i+='<ul class="cesium-cesiumInspector-statistics">',i+=`<li><strong>Tiles styled: </strong>${n.numberOfTilesStyled.toLocaleString()}</li><li><strong>Features styled: </strong>${n.numberOfFeaturesStyled.toLocaleString()}</li>`,i+="</ul>",i+='<ul class="cesium-cesiumInspector-statistics">',i+=`<li><strong>Children Union Culled: </strong>${n.numberOfTilesCulledWithChildrenUnion.toLocaleString()}</li>`,i+="</ul>",i+='<ul class="cesium-cesiumInspector-statistics">',i+=`<li><strong>Geometry Memory (MB): </strong>${RD(n.geometryByteLength)}</li><li><strong>Texture Memory (MB): </strong>${RD(n.texturesByteLength)}</li><li><strong>Batch Table Memory (MB): </strong>${RD(n.batchTableByteLength)}</li>`,i+="</ul>"),i}function u2t(){let t=jo.statistics;return` <ul class="cesium-cesiumInspector-statistics"> - <li><strong>Geometry Memory (MB): </strong>${bD(t.geometryByteLength)}</li> - <li><strong>Texture Memory (MB): </strong>${bD(t.texturesByteLength)}</li> + <li><strong>Geometry Memory (MB): </strong>${RD(t.geometryByteLength)}</li> + <li><strong>Texture Memory (MB): </strong>${RD(t.texturesByteLength)}</li> </ul> - `}var u5e=[{text:"Highlight",value:Nm.HIGHLIGHT},{text:"Replace",value:Nm.REPLACE},{text:"Mix",value:Nm.MIX}],pkt=new v(1,1,0,.4),Z5e=new v,l4=new v;function ad(t,e){let n=this,i=t.canvas;this._eventHandler=new sp(i),this._scene=t,this._performanceContainer=e,this._canvas=i,this._performanceDisplay=new bW({container:e}),this._statisticsText="",this._pickStatisticsText="",this._resourceCacheStatisticsText="",this._editorError="",this.performance=!1,this.showStatistics=!0,this.showPickStatistics=!0,this.showResourceCacheStatistics=!1,this.inspectorVisible=!0,this.tilesetVisible=!1,this.displayVisible=!1,this.updateVisible=!1,this.loggingVisible=!1,this.styleVisible=!1,this.tileDebugLabelsVisible=!1,this.optimizationVisible=!1,this.styleString="{}",this.hasEnabledWireframe=!1,this._tileset=void 0,this._feature=void 0,this._tile=void 0,Lt.track(this,["performance","inspectorVisible","_statisticsText","_pickStatisticsText","_resourceCacheStatisticsText","_editorError","showPickStatistics","showStatistics","showResourceCacheStatistics","tilesetVisible","displayVisible","updateVisible","loggingVisible","styleVisible","optimizationVisible","tileDebugLabelsVisible","styleString","_feature","_tile","_tileset","hasEnabledWireframe"]),this._properties=Lt.observable({}),this.properties=[],Lt.defineProperty(this,"properties",function(){let H=[],nt=n._properties();for(let $ in nt)nt.hasOwnProperty($)&&H.push($);return H});let o=Lt.observable();Lt.defineProperty(this,"dynamicScreenSpaceError",{get:function(){return o()},set:function(H){o(H),c(n._tileset)&&(n._tileset.dynamicScreenSpaceError=H)}}),this.dynamicScreenSpaceError=!1;let a=Lt.observable();Lt.defineProperty(this,"colorBlendMode",{get:function(){return a()},set:function(H){a(H),c(n._tileset)&&(n._tileset.colorBlendMode=H,n._scene.requestRender())}}),this.colorBlendMode=Nm.HIGHLIGHT;let s=Lt.observable(),l=Lt.observable();Lt.defineProperty(this,"picking",{get:function(){return l()},set:function(H){l(H),H?n._eventHandler.setInputAction(function(nt){let $=t.pick(nt.endPosition);if($ instanceof Fr?(n.feature=$,n.tile=$.content.tile):c($)&&c($.content)?(n.feature=void 0,n.tile=$.content.tile):(n.feature=void 0,n.tile=void 0),!!c(n._tileset)){if(s&&c($)&&c($.content)){let dt;t.pickPositionSupported&&(dt=t.pickPosition(nt.endPosition),c(dt)&&(n._tileset.debugPickPosition=dt)),n._tileset.debugPickedTile=$.content.tile}else n._tileset.debugPickedTile=void 0;n._scene.requestRender()}},Zi.MOUSE_MOVE):(n.feature=void 0,n.tile=void 0,n._eventHandler.removeInputAction(Zi.MOUSE_MOVE))}}),this.picking=!0;let r=Lt.observable();Lt.defineProperty(this,"colorize",{get:function(){return r()},set:function(H){r(H),c(n._tileset)&&(n._tileset.debugColorizeTiles=H,n._scene.requestRender())}}),this.colorize=!1;let d=Lt.observable();Lt.defineProperty(this,"wireframe",{get:function(){return d()},set:function(H){d(H),c(n._tileset)&&(n._tileset.debugWireframe=H,n._scene.requestRender())}}),this.wireframe=!1;let m=Lt.observable();Lt.defineProperty(this,"showBoundingVolumes",{get:function(){return m()},set:function(H){m(H),c(n._tileset)&&(n._tileset.debugShowBoundingVolume=H,n._scene.requestRender())}}),this.showBoundingVolumes=!1;let h=Lt.observable();Lt.defineProperty(this,"showContentBoundingVolumes",{get:function(){return h()},set:function(H){h(H),c(n._tileset)&&(n._tileset.debugShowContentBoundingVolume=H,n._scene.requestRender())}}),this.showContentBoundingVolumes=!1;let Z=Lt.observable();Lt.defineProperty(this,"showRequestVolumes",{get:function(){return Z()},set:function(H){Z(H),c(n._tileset)&&(n._tileset.debugShowViewerRequestVolume=H,n._scene.requestRender())}}),this.showRequestVolumes=!1;let b=Lt.observable();Lt.defineProperty(this,"freezeFrame",{get:function(){return b()},set:function(H){b(H),c(n._tileset)&&(n._tileset.debugFreezeFrame=H,n._scene.debugShowFrustumPlanes=H,n._scene.requestRender())}}),this.freezeFrame=!1,Lt.defineProperty(this,"showOnlyPickedTileDebugLabel",{get:function(){return s()},set:function(H){s(H),c(n._tileset)&&(n._tileset.debugPickedTileLabelOnly=H,n._scene.requestRender())}}),this.showOnlyPickedTileDebugLabel=!1;let u=Lt.observable();Lt.defineProperty(this,"showGeometricError",{get:function(){return u()},set:function(H){u(H),c(n._tileset)&&(n._tileset.debugShowGeometricError=H,n._scene.requestRender())}}),this.showGeometricError=!1;let F=Lt.observable();Lt.defineProperty(this,"showRenderingStatistics",{get:function(){return F()},set:function(H){F(H),c(n._tileset)&&(n._tileset.debugShowRenderingStatistics=H,n._scene.requestRender())}}),this.showRenderingStatistics=!1;let U=Lt.observable();Lt.defineProperty(this,"showMemoryUsage",{get:function(){return U()},set:function(H){U(H),c(n._tileset)&&(n._tileset.debugShowMemoryUsage=H,n._scene.requestRender())}}),this.showMemoryUsage=!1;let G=Lt.observable();Lt.defineProperty(this,"showUrl",{get:function(){return G()},set:function(H){G(H),c(n._tileset)&&(n._tileset.debugShowUrl=H,n._scene.requestRender())}}),this.showUrl=!1;let A=Lt.observable();Lt.defineProperty(this,"maximumScreenSpaceError",{get:function(){return A()},set:function(H){H=Number(H),isNaN(H)||(A(H),c(n._tileset)&&(n._tileset.maximumScreenSpaceError=H))}}),this.maximumScreenSpaceError=16;let T=Lt.observable();Lt.defineProperty(this,"dynamicScreenSpaceErrorDensity",{get:function(){return T()},set:function(H){H=Number(H),isNaN(H)||(T(H),c(n._tileset)&&(n._tileset.dynamicScreenSpaceErrorDensity=H))}}),this.dynamicScreenSpaceErrorDensity=2e-4,this.dynamicScreenSpaceErrorDensitySliderValue=void 0,Lt.defineProperty(this,"dynamicScreenSpaceErrorDensitySliderValue",{get:function(){return Math.pow(T(),1/6)},set:function(H){let nt=Math.pow(H,6);T(nt),c(n._tileset)&&(n._tileset.dynamicScreenSpaceErrorDensity=nt)}});let g=Lt.observable();Lt.defineProperty(this,"dynamicScreenSpaceErrorFactor",{get:function(){return g()},set:function(H){H=Number(H),isNaN(H)||(g(H),c(n._tileset)&&(n._tileset.dynamicScreenSpaceErrorFactor=H))}}),this.dynamicScreenSpaceErrorFactor=24;let C=h5e(this),y=Lt.observable();Lt.defineProperty(this,"pickActive",{get:function(){return y()},set:function(H){y(H),H?n._eventHandler.setInputAction(C,Zi.LEFT_CLICK):n._eventHandler.removeInputAction(Zi.LEFT_CLICK)}});let Y=Lt.observable();Lt.defineProperty(this,"pointCloudShading",{get:function(){return Y()},set:function(H){Y(H),c(n._tileset)&&(n._tileset.pointCloudShading.attenuation=H)}}),this.pointCloudShading=!1;let Q=Lt.observable();Lt.defineProperty(this,"geometricErrorScale",{get:function(){return Q()},set:function(H){H=Number(H),isNaN(H)||(Q(H),c(n._tileset)&&(n._tileset.pointCloudShading.geometricErrorScale=H))}}),this.geometricErrorScale=1;let J=Lt.observable();Lt.defineProperty(this,"maximumAttenuation",{get:function(){return J()},set:function(H){H=Number(H),isNaN(H)||(J(H),c(n._tileset)&&(n._tileset.pointCloudShading.maximumAttenuation=H===0?void 0:H))}}),this.maximumAttenuation=0;let M=Lt.observable();Lt.defineProperty(this,"baseResolution",{get:function(){return M()},set:function(H){H=Number(H),isNaN(H)||(M(H),c(n._tileset)&&(n._tileset.pointCloudShading.baseResolution=H===0?void 0:H))}}),this.baseResolution=0;let V=Lt.observable();Lt.defineProperty(this,"eyeDomeLighting",{get:function(){return V()},set:function(H){V(H),c(n._tileset)&&(n._tileset.pointCloudShading.eyeDomeLighting=H)}}),this.eyeDomeLighting=!1;let E=Lt.observable();Lt.defineProperty(this,"eyeDomeLightingStrength",{get:function(){return E()},set:function(H){H=Number(H),isNaN(H)||(E(H),c(n._tileset)&&(n._tileset.pointCloudShading.eyeDomeLightingStrength=H))}}),this.eyeDomeLightingStrength=1;let I=Lt.observable();Lt.defineProperty(this,"eyeDomeLightingRadius",{get:function(){return I()},set:function(H){H=Number(H),isNaN(H)||(I(H),c(n._tileset)&&(n._tileset.pointCloudShading.eyeDomeLightingRadius=H))}}),this.eyeDomeLightingRadius=1,this.pickActive=!1;let B=Lt.observable();Lt.defineProperty(this,"skipLevelOfDetail",{get:function(){return B()},set:function(H){B(H),c(n._tileset)&&(n._tileset.skipLevelOfDetail=H)}}),this.skipLevelOfDetail=!0;let X=Lt.observable();Lt.defineProperty(this,"skipScreenSpaceErrorFactor",{get:function(){return X()},set:function(H){H=Number(H),isNaN(H)||(X(H),c(n._tileset)&&(n._tileset.skipScreenSpaceErrorFactor=H))}}),this.skipScreenSpaceErrorFactor=16;let _=Lt.observable();Lt.defineProperty(this,"baseScreenSpaceError",{get:function(){return _()},set:function(H){H=Number(H),isNaN(H)||(_(H),c(n._tileset)&&(n._tileset.baseScreenSpaceError=H))}}),this.baseScreenSpaceError=1024;let P=Lt.observable();Lt.defineProperty(this,"skipLevels",{get:function(){return P()},set:function(H){H=Number(H),isNaN(H)||(P(H),c(n._tileset)&&(n._tileset.skipLevels=H))}}),this.skipLevels=1;let w=Lt.observable();Lt.defineProperty(this,"immediatelyLoadDesiredLevelOfDetail",{get:function(){return w()},set:function(H){w(H),c(n._tileset)&&(n._tileset.immediatelyLoadDesiredLevelOfDetail=H)}}),this.immediatelyLoadDesiredLevelOfDetail=!1;let z=Lt.observable();Lt.defineProperty(this,"loadSiblings",{get:function(){return z()},set:function(H){z(H),c(n._tileset)&&(n._tileset.loadSiblings=H)}}),this.loadSiblings=!1,this._style=void 0,this._shouldStyle=!1,this._definedProperties=["properties","dynamicScreenSpaceError","colorBlendMode","picking","colorize","wireframe","showBoundingVolumes","showContentBoundingVolumes","showRequestVolumes","freezeFrame","maximumScreenSpaceError","dynamicScreenSpaceErrorDensity","baseScreenSpaceError","skipScreenSpaceErrorFactor","skipLevelOfDetail","skipLevels","immediatelyLoadDesiredLevelOfDetail","loadSiblings","dynamicScreenSpaceErrorDensitySliderValue","dynamicScreenSpaceErrorFactor","pickActive","showOnlyPickedTileDebugLabel","showGeometricError","showRenderingStatistics","showMemoryUsage","showUrl","pointCloudShading","geometricErrorScale","maximumAttenuation","baseResolution","eyeDomeLighting","eyeDomeLightingStrength","eyeDomeLightingRadius"],this._removePostRenderEvent=t.postRender.addEventListener(function(){n._update()}),c(this._tileset)||ukt(this,!0)}Object.defineProperties(ad.prototype,{scene:{get:function(){return this._scene}},performanceContainer:{get:function(){return this._performanceContainer}},statisticsText:{get:function(){return this._statisticsText}},pickStatisticsText:{get:function(){return this._pickStatisticsText}},resourceCacheStatisticsText:{get:function(){return this._resourceCacheStatisticsText}},colorBlendModes:{get:function(){return u5e}},editorError:{get:function(){return this._editorError}},tileset:{get:function(){return this._tileset},set:function(t){if(this._tileset=t,this._style=void 0,this.styleString="{}",this.feature=void 0,this.tile=void 0,c(t)){this._properties(t.properties);let e=["colorize","wireframe","showBoundingVolumes","showContentBoundingVolumes","showRequestVolumes","freezeFrame","showOnlyPickedTileDebugLabel","showGeometricError","showRenderingStatistics","showMemoryUsage","showUrl"],n=e.length;for(let o=0;o<n;++o){let a=e[o];this[a]=this[a]}this.maximumScreenSpaceError=t.maximumScreenSpaceError,this.dynamicScreenSpaceError=t.dynamicScreenSpaceError,this.dynamicScreenSpaceErrorDensity=t.dynamicScreenSpaceErrorDensity,this.dynamicScreenSpaceErrorFactor=t.dynamicScreenSpaceErrorFactor,this.colorBlendMode=t.colorBlendMode,this.skipLevelOfDetail=t.skipLevelOfDetail,this.skipScreenSpaceErrorFactor=t.skipScreenSpaceErrorFactor,this.baseScreenSpaceError=t.baseScreenSpaceError,this.skipLevels=t.skipLevels,this.immediatelyLoadDesiredLevelOfDetail=t.immediatelyLoadDesiredLevelOfDetail,this.loadSiblings=t.loadSiblings,this.hasEnabledWireframe=t._enableDebugWireframe;let i=t.pointCloudShading;this.pointCloudShading=i.attenuation,this.geometricErrorScale=i.geometricErrorScale,this.maximumAttenuation=i.maximumAttenuation?i.maximumAttenuation:0,this.baseResolution=i.baseResolution?i.baseResolution:0,this.eyeDomeLighting=i.eyeDomeLighting,this.eyeDomeLightingStrength=i.eyeDomeLightingStrength,this.eyeDomeLightingRadius=i.eyeDomeLightingRadius,this._scene.requestRender()}else this._properties({});this._statisticsText=RD(t,!1),this._pickStatisticsText=RD(t,!0),this._resourceCacheStatisticsText=Zkt(),ukt(this,!1)}},feature:{get:function(){return this._feature},set:function(t){if(this._feature===t)return;let e=this._feature;c(e)&&!e.content.isDestroyed()&&(!this.colorize&&c(this._style)?e.color=c(this._style.color)?this._style.color.evaluateColor(e,Z5e):v.WHITE:e.color=l4,this._scene.requestRender()),c(t)&&(v.clone(t.color,l4),t.color=pkt,this._scene.requestRender()),this._feature=t}},tile:{get:function(){return this._tile},set:function(t){if(this._tile===t)return;let e=this._tile;c(e)&&!e.isDestroyed()&&!Irt(e.content)&&(e.color=l4,this._scene.requestRender()),c(t)&&!Irt(t.content)&&(v.clone(t.color,l4),t.color=pkt,this._scene.requestRender()),this._tile=t}}});function Irt(t){if(!c(t))return!1;if(t.featuresLength>0)return!0;let e=t.innerContents;if(c(e)){let n=e.length;for(let i=0;i<n;++i)if(!Irt(e[i]))return!1;return!0}return!1}ad.prototype.togglePickTileset=function(){this.pickActive=!this.pickActive};ad.prototype.toggleInspector=function(){this.inspectorVisible=!this.inspectorVisible};ad.prototype.toggleTileset=function(){this.tilesetVisible=!this.tilesetVisible};ad.prototype.toggleDisplay=function(){this.displayVisible=!this.displayVisible};ad.prototype.toggleUpdate=function(){this.updateVisible=!this.updateVisible};ad.prototype.toggleLogging=function(){this.loggingVisible=!this.loggingVisible};ad.prototype.toggleStyle=function(){this.styleVisible=!this.styleVisible};ad.prototype.toggleTileDebugLabels=function(){this.tileDebugLabelsVisible=!this.tileDebugLabelsVisible};ad.prototype.toggleOptimization=function(){this.optimizationVisible=!this.optimizationVisible};ad.prototype.trimTilesCache=function(){c(this._tileset)&&this._tileset.trimLoadedTiles()};ad.prototype.compileStyle=function(){let t=this._tileset;if(!(!c(t)||this.styleString===JSON.stringify(t.style))){this._editorError="";try{this.styleString.length===0&&(this.styleString="{}"),this._style=new qS(JSON.parse(this.styleString)),this._shouldStyle=!0,this._scene.requestRender()}catch(e){this._editorError=e.toString()}this.feature=this._feature,this.tile=this._tile}};ad.prototype.styleEditorKeyPress=function(t,e){if(e.keyCode===9){e.preventDefault();let n=e.target,i=n.selectionStart,o=n.selectionEnd,a=o,l=n.value.slice(i,o).split(` + `}var V5e=[{text:"Highlight",value:Nm.HIGHLIGHT},{text:"Replace",value:Nm.REPLACE},{text:"Mix",value:Nm.MIX}],p2t=new v(1,1,0,.4),u5e=new v,l4=new v;function ad(t,e){let n=this,i=t.canvas;this._eventHandler=new sp(i),this._scene=t,this._performanceContainer=e,this._canvas=i,this._performanceDisplay=new RW({container:e}),this._statisticsText="",this._pickStatisticsText="",this._resourceCacheStatisticsText="",this._editorError="",this.performance=!1,this.showStatistics=!0,this.showPickStatistics=!0,this.showResourceCacheStatistics=!1,this.inspectorVisible=!0,this.tilesetVisible=!1,this.displayVisible=!1,this.updateVisible=!1,this.loggingVisible=!1,this.styleVisible=!1,this.tileDebugLabelsVisible=!1,this.optimizationVisible=!1,this.styleString="{}",this.hasEnabledWireframe=!1,this._tileset=void 0,this._feature=void 0,this._tile=void 0,Lt.track(this,["performance","inspectorVisible","_statisticsText","_pickStatisticsText","_resourceCacheStatisticsText","_editorError","showPickStatistics","showStatistics","showResourceCacheStatistics","tilesetVisible","displayVisible","updateVisible","loggingVisible","styleVisible","optimizationVisible","tileDebugLabelsVisible","styleString","_feature","_tile","_tileset","hasEnabledWireframe"]),this._properties=Lt.observable({}),this.properties=[],Lt.defineProperty(this,"properties",function(){let H=[],nt=n._properties();for(let $ in nt)nt.hasOwnProperty($)&&H.push($);return H});let o=Lt.observable();Lt.defineProperty(this,"dynamicScreenSpaceError",{get:function(){return o()},set:function(H){o(H),c(n._tileset)&&(n._tileset.dynamicScreenSpaceError=H)}}),this.dynamicScreenSpaceError=!1;let a=Lt.observable();Lt.defineProperty(this,"colorBlendMode",{get:function(){return a()},set:function(H){a(H),c(n._tileset)&&(n._tileset.colorBlendMode=H,n._scene.requestRender())}}),this.colorBlendMode=Nm.HIGHLIGHT;let s=Lt.observable(),l=Lt.observable();Lt.defineProperty(this,"picking",{get:function(){return l()},set:function(H){l(H),H?n._eventHandler.setInputAction(function(nt){let $=t.pick(nt.endPosition);if($ instanceof Fr?(n.feature=$,n.tile=$.content.tile):c($)&&c($.content)?(n.feature=void 0,n.tile=$.content.tile):(n.feature=void 0,n.tile=void 0),!!c(n._tileset)){if(s&&c($)&&c($.content)){let dt;t.pickPositionSupported&&(dt=t.pickPosition(nt.endPosition),c(dt)&&(n._tileset.debugPickPosition=dt)),n._tileset.debugPickedTile=$.content.tile}else n._tileset.debugPickedTile=void 0;n._scene.requestRender()}},ui.MOUSE_MOVE):(n.feature=void 0,n.tile=void 0,n._eventHandler.removeInputAction(ui.MOUSE_MOVE))}}),this.picking=!0;let r=Lt.observable();Lt.defineProperty(this,"colorize",{get:function(){return r()},set:function(H){r(H),c(n._tileset)&&(n._tileset.debugColorizeTiles=H,n._scene.requestRender())}}),this.colorize=!1;let d=Lt.observable();Lt.defineProperty(this,"wireframe",{get:function(){return d()},set:function(H){d(H),c(n._tileset)&&(n._tileset.debugWireframe=H,n._scene.requestRender())}}),this.wireframe=!1;let m=Lt.observable();Lt.defineProperty(this,"showBoundingVolumes",{get:function(){return m()},set:function(H){m(H),c(n._tileset)&&(n._tileset.debugShowBoundingVolume=H,n._scene.requestRender())}}),this.showBoundingVolumes=!1;let h=Lt.observable();Lt.defineProperty(this,"showContentBoundingVolumes",{get:function(){return h()},set:function(H){h(H),c(n._tileset)&&(n._tileset.debugShowContentBoundingVolume=H,n._scene.requestRender())}}),this.showContentBoundingVolumes=!1;let u=Lt.observable();Lt.defineProperty(this,"showRequestVolumes",{get:function(){return u()},set:function(H){u(H),c(n._tileset)&&(n._tileset.debugShowViewerRequestVolume=H,n._scene.requestRender())}}),this.showRequestVolumes=!1;let R=Lt.observable();Lt.defineProperty(this,"freezeFrame",{get:function(){return R()},set:function(H){R(H),c(n._tileset)&&(n._tileset.debugFreezeFrame=H,n._scene.debugShowFrustumPlanes=H,n._scene.requestRender())}}),this.freezeFrame=!1,Lt.defineProperty(this,"showOnlyPickedTileDebugLabel",{get:function(){return s()},set:function(H){s(H),c(n._tileset)&&(n._tileset.debugPickedTileLabelOnly=H,n._scene.requestRender())}}),this.showOnlyPickedTileDebugLabel=!1;let V=Lt.observable();Lt.defineProperty(this,"showGeometricError",{get:function(){return V()},set:function(H){V(H),c(n._tileset)&&(n._tileset.debugShowGeometricError=H,n._scene.requestRender())}}),this.showGeometricError=!1;let F=Lt.observable();Lt.defineProperty(this,"showRenderingStatistics",{get:function(){return F()},set:function(H){F(H),c(n._tileset)&&(n._tileset.debugShowRenderingStatistics=H,n._scene.requestRender())}}),this.showRenderingStatistics=!1;let U=Lt.observable();Lt.defineProperty(this,"showMemoryUsage",{get:function(){return U()},set:function(H){U(H),c(n._tileset)&&(n._tileset.debugShowMemoryUsage=H,n._scene.requestRender())}}),this.showMemoryUsage=!1;let G=Lt.observable();Lt.defineProperty(this,"showUrl",{get:function(){return G()},set:function(H){G(H),c(n._tileset)&&(n._tileset.debugShowUrl=H,n._scene.requestRender())}}),this.showUrl=!1;let A=Lt.observable();Lt.defineProperty(this,"maximumScreenSpaceError",{get:function(){return A()},set:function(H){H=Number(H),isNaN(H)||(A(H),c(n._tileset)&&(n._tileset.maximumScreenSpaceError=H))}}),this.maximumScreenSpaceError=16;let S=Lt.observable();Lt.defineProperty(this,"dynamicScreenSpaceErrorDensity",{get:function(){return S()},set:function(H){H=Number(H),isNaN(H)||(S(H),c(n._tileset)&&(n._tileset.dynamicScreenSpaceErrorDensity=H))}}),this.dynamicScreenSpaceErrorDensity=2e-4,this.dynamicScreenSpaceErrorDensitySliderValue=void 0,Lt.defineProperty(this,"dynamicScreenSpaceErrorDensitySliderValue",{get:function(){return Math.pow(S(),1/6)},set:function(H){let nt=Math.pow(H,6);S(nt),c(n._tileset)&&(n._tileset.dynamicScreenSpaceErrorDensity=nt)}});let g=Lt.observable();Lt.defineProperty(this,"dynamicScreenSpaceErrorFactor",{get:function(){return g()},set:function(H){H=Number(H),isNaN(H)||(g(H),c(n._tileset)&&(n._tileset.dynamicScreenSpaceErrorFactor=H))}}),this.dynamicScreenSpaceErrorFactor=24;let C=h5e(this),y=Lt.observable();Lt.defineProperty(this,"pickActive",{get:function(){return y()},set:function(H){y(H),H?n._eventHandler.setInputAction(C,ui.LEFT_CLICK):n._eventHandler.removeInputAction(ui.LEFT_CLICK)}});let Y=Lt.observable();Lt.defineProperty(this,"pointCloudShading",{get:function(){return Y()},set:function(H){Y(H),c(n._tileset)&&(n._tileset.pointCloudShading.attenuation=H)}}),this.pointCloudShading=!1;let Q=Lt.observable();Lt.defineProperty(this,"geometricErrorScale",{get:function(){return Q()},set:function(H){H=Number(H),isNaN(H)||(Q(H),c(n._tileset)&&(n._tileset.pointCloudShading.geometricErrorScale=H))}}),this.geometricErrorScale=1;let J=Lt.observable();Lt.defineProperty(this,"maximumAttenuation",{get:function(){return J()},set:function(H){H=Number(H),isNaN(H)||(J(H),c(n._tileset)&&(n._tileset.pointCloudShading.maximumAttenuation=H===0?void 0:H))}}),this.maximumAttenuation=0;let M=Lt.observable();Lt.defineProperty(this,"baseResolution",{get:function(){return M()},set:function(H){H=Number(H),isNaN(H)||(M(H),c(n._tileset)&&(n._tileset.pointCloudShading.baseResolution=H===0?void 0:H))}}),this.baseResolution=0;let Z=Lt.observable();Lt.defineProperty(this,"eyeDomeLighting",{get:function(){return Z()},set:function(H){Z(H),c(n._tileset)&&(n._tileset.pointCloudShading.eyeDomeLighting=H)}}),this.eyeDomeLighting=!1;let E=Lt.observable();Lt.defineProperty(this,"eyeDomeLightingStrength",{get:function(){return E()},set:function(H){H=Number(H),isNaN(H)||(E(H),c(n._tileset)&&(n._tileset.pointCloudShading.eyeDomeLightingStrength=H))}}),this.eyeDomeLightingStrength=1;let I=Lt.observable();Lt.defineProperty(this,"eyeDomeLightingRadius",{get:function(){return I()},set:function(H){H=Number(H),isNaN(H)||(I(H),c(n._tileset)&&(n._tileset.pointCloudShading.eyeDomeLightingRadius=H))}}),this.eyeDomeLightingRadius=1,this.pickActive=!1;let B=Lt.observable();Lt.defineProperty(this,"skipLevelOfDetail",{get:function(){return B()},set:function(H){B(H),c(n._tileset)&&(n._tileset.skipLevelOfDetail=H)}}),this.skipLevelOfDetail=!0;let X=Lt.observable();Lt.defineProperty(this,"skipScreenSpaceErrorFactor",{get:function(){return X()},set:function(H){H=Number(H),isNaN(H)||(X(H),c(n._tileset)&&(n._tileset.skipScreenSpaceErrorFactor=H))}}),this.skipScreenSpaceErrorFactor=16;let _=Lt.observable();Lt.defineProperty(this,"baseScreenSpaceError",{get:function(){return _()},set:function(H){H=Number(H),isNaN(H)||(_(H),c(n._tileset)&&(n._tileset.baseScreenSpaceError=H))}}),this.baseScreenSpaceError=1024;let P=Lt.observable();Lt.defineProperty(this,"skipLevels",{get:function(){return P()},set:function(H){H=Number(H),isNaN(H)||(P(H),c(n._tileset)&&(n._tileset.skipLevels=H))}}),this.skipLevels=1;let w=Lt.observable();Lt.defineProperty(this,"immediatelyLoadDesiredLevelOfDetail",{get:function(){return w()},set:function(H){w(H),c(n._tileset)&&(n._tileset.immediatelyLoadDesiredLevelOfDetail=H)}}),this.immediatelyLoadDesiredLevelOfDetail=!1;let z=Lt.observable();Lt.defineProperty(this,"loadSiblings",{get:function(){return z()},set:function(H){z(H),c(n._tileset)&&(n._tileset.loadSiblings=H)}}),this.loadSiblings=!1,this._style=void 0,this._shouldStyle=!1,this._definedProperties=["properties","dynamicScreenSpaceError","colorBlendMode","picking","colorize","wireframe","showBoundingVolumes","showContentBoundingVolumes","showRequestVolumes","freezeFrame","maximumScreenSpaceError","dynamicScreenSpaceErrorDensity","baseScreenSpaceError","skipScreenSpaceErrorFactor","skipLevelOfDetail","skipLevels","immediatelyLoadDesiredLevelOfDetail","loadSiblings","dynamicScreenSpaceErrorDensitySliderValue","dynamicScreenSpaceErrorFactor","pickActive","showOnlyPickedTileDebugLabel","showGeometricError","showRenderingStatistics","showMemoryUsage","showUrl","pointCloudShading","geometricErrorScale","maximumAttenuation","baseResolution","eyeDomeLighting","eyeDomeLightingStrength","eyeDomeLightingRadius"],this._removePostRenderEvent=t.postRender.addEventListener(function(){n._update()}),c(this._tileset)||V2t(this,!0)}Object.defineProperties(ad.prototype,{scene:{get:function(){return this._scene}},performanceContainer:{get:function(){return this._performanceContainer}},statisticsText:{get:function(){return this._statisticsText}},pickStatisticsText:{get:function(){return this._pickStatisticsText}},resourceCacheStatisticsText:{get:function(){return this._resourceCacheStatisticsText}},colorBlendModes:{get:function(){return V5e}},editorError:{get:function(){return this._editorError}},tileset:{get:function(){return this._tileset},set:function(t){if(this._tileset=t,this._style=void 0,this.styleString="{}",this.feature=void 0,this.tile=void 0,c(t)){this._properties(t.properties);let e=["colorize","wireframe","showBoundingVolumes","showContentBoundingVolumes","showRequestVolumes","freezeFrame","showOnlyPickedTileDebugLabel","showGeometricError","showRenderingStatistics","showMemoryUsage","showUrl"],n=e.length;for(let o=0;o<n;++o){let a=e[o];this[a]=this[a]}this.maximumScreenSpaceError=t.maximumScreenSpaceError,this.dynamicScreenSpaceError=t.dynamicScreenSpaceError,this.dynamicScreenSpaceErrorDensity=t.dynamicScreenSpaceErrorDensity,this.dynamicScreenSpaceErrorFactor=t.dynamicScreenSpaceErrorFactor,this.colorBlendMode=t.colorBlendMode,this.skipLevelOfDetail=t.skipLevelOfDetail,this.skipScreenSpaceErrorFactor=t.skipScreenSpaceErrorFactor,this.baseScreenSpaceError=t.baseScreenSpaceError,this.skipLevels=t.skipLevels,this.immediatelyLoadDesiredLevelOfDetail=t.immediatelyLoadDesiredLevelOfDetail,this.loadSiblings=t.loadSiblings,this.hasEnabledWireframe=t._enableDebugWireframe;let i=t.pointCloudShading;this.pointCloudShading=i.attenuation,this.geometricErrorScale=i.geometricErrorScale,this.maximumAttenuation=i.maximumAttenuation?i.maximumAttenuation:0,this.baseResolution=i.baseResolution?i.baseResolution:0,this.eyeDomeLighting=i.eyeDomeLighting,this.eyeDomeLightingStrength=i.eyeDomeLightingStrength,this.eyeDomeLightingRadius=i.eyeDomeLightingRadius,this._scene.requestRender()}else this._properties({});this._statisticsText=bD(t,!1),this._pickStatisticsText=bD(t,!0),this._resourceCacheStatisticsText=u2t(),V2t(this,!1)}},feature:{get:function(){return this._feature},set:function(t){if(this._feature===t)return;let e=this._feature;c(e)&&!e.content.isDestroyed()&&(!this.colorize&&c(this._style)?e.color=c(this._style.color)?this._style.color.evaluateColor(e,u5e):v.WHITE:e.color=l4,this._scene.requestRender()),c(t)&&(v.clone(t.color,l4),t.color=p2t,this._scene.requestRender()),this._feature=t}},tile:{get:function(){return this._tile},set:function(t){if(this._tile===t)return;let e=this._tile;c(e)&&!e.isDestroyed()&&!Irt(e.content)&&(e.color=l4,this._scene.requestRender()),c(t)&&!Irt(t.content)&&(v.clone(t.color,l4),t.color=p2t,this._scene.requestRender()),this._tile=t}}});function Irt(t){if(!c(t))return!1;if(t.featuresLength>0)return!0;let e=t.innerContents;if(c(e)){let n=e.length;for(let i=0;i<n;++i)if(!Irt(e[i]))return!1;return!0}return!1}ad.prototype.togglePickTileset=function(){this.pickActive=!this.pickActive};ad.prototype.toggleInspector=function(){this.inspectorVisible=!this.inspectorVisible};ad.prototype.toggleTileset=function(){this.tilesetVisible=!this.tilesetVisible};ad.prototype.toggleDisplay=function(){this.displayVisible=!this.displayVisible};ad.prototype.toggleUpdate=function(){this.updateVisible=!this.updateVisible};ad.prototype.toggleLogging=function(){this.loggingVisible=!this.loggingVisible};ad.prototype.toggleStyle=function(){this.styleVisible=!this.styleVisible};ad.prototype.toggleTileDebugLabels=function(){this.tileDebugLabelsVisible=!this.tileDebugLabelsVisible};ad.prototype.toggleOptimization=function(){this.optimizationVisible=!this.optimizationVisible};ad.prototype.trimTilesCache=function(){c(this._tileset)&&this._tileset.trimLoadedTiles()};ad.prototype.compileStyle=function(){let t=this._tileset;if(!(!c(t)||this.styleString===JSON.stringify(t.style))){this._editorError="";try{this.styleString.length===0&&(this.styleString="{}"),this._style=new qT(JSON.parse(this.styleString)),this._shouldStyle=!0,this._scene.requestRender()}catch(e){this._editorError=e.toString()}this.feature=this._feature,this.tile=this._tile}};ad.prototype.styleEditorKeyPress=function(t,e){if(e.keyCode===9){e.preventDefault();let n=e.target,i=n.selectionStart,o=n.selectionEnd,a=o,l=n.value.slice(i,o).split(` `),r=l.length,d;if(e.shiftKey)for(d=0;d<r;++d)l[d][0]===" "&&(l[d][1]===" "?(l[d]=l[d].substr(2),a-=2):(l[d]=l[d].substr(1),a-=1));else for(d=0;d<r;++d)l[d]=` ${l[d]}`,a+=2;let m=l.join(` -`);n.value=n.value.slice(0,i)+m+n.value.slice(o),n.selectionStart=i!==o?i:a,n.selectionEnd=a}else e.ctrlKey&&(e.keyCode===10||e.keyCode===13)&&this.compileStyle();return!0};ad.prototype._update=function(){let t=this._tileset;if(this.performance&&this._performanceDisplay.update(),c(t)){if(t.isDestroyed()){this.tile=void 0,this.feature=void 0,this.tileset=void 0;return}let e=t.style;this._style!==t.style&&(this._shouldStyle?(t.style=this._style,this._shouldStyle=!1):(this._style=e,this.styleString=JSON.stringify(e.style,null," ")))}this.showStatistics&&(this._statisticsText=RD(t,!1),this._pickStatisticsText=RD(t,!0),this._resourceCacheStatisticsText=Zkt())};ad.prototype.isDestroyed=function(){return!1};ad.prototype.destroy=function(){this._eventHandler.destroy(),this._removePostRenderEvent();let t=this;return this._definedProperties.forEach(function(e){Lt.getObservable(t,e).dispose()}),At(this)};ad.getStatistics=RD;var WD=ad;function r4(t,e){t=Ui(t);let n=document.createElement("div"),i=document.createElement("div");i.setAttribute("data-bind","visible: performance");let o=new WD(e,i);this._viewModel=o,this._container=t,this._element=n;let a=document.createElement("div");a.textContent="3D Tiles Inspector",a.className="cesium-cesiumInspector-button",a.setAttribute("data-bind","click: toggleInspector"),n.appendChild(a),n.className="cesium-cesiumInspector cesium-3DTilesInspector",n.setAttribute("data-bind",'css: { "cesium-cesiumInspector-visible" : inspectorVisible, "cesium-cesiumInspector-hidden" : !inspectorVisible}'),t.appendChild(n);let s=document.createElement("div");s.className="cesium-cesiumInspector-dropDown",n.appendChild(s);let l=gd.createSection,r=gd.createCheckbox,d=gd.createRangeInput,m=gd.createButton,h=l(s,"Tileset","tilesetVisible","toggleTileset"),Z=l(s,"Display","displayVisible","toggleDisplay"),b=l(s,"Update","updateVisible","toggleUpdate"),u=l(s,"Logging","loggingVisible","toggleLogging"),F=l(s,"Tile Debug Labels","tileDebugLabelsVisible","toggleTileDebugLabels"),U=l(s,"Style","styleVisible","toggleStyle"),G=l(s,"Optimization","optimizationVisible","toggleOptimization"),A=document.createElement("div");A.className="field-group";let T=document.createElement("label");T.className="field-label",T.appendChild(document.createTextNode("Properties: "));let g=document.createElement("div");g.setAttribute("data-bind","text: properties"),A.appendChild(T),A.appendChild(g),h.appendChild(A),h.appendChild(m("Pick Tileset","togglePickTileset","pickActive")),h.appendChild(m("Trim Tiles Cache","trimTilesCache")),h.appendChild(r("Enable Picking","picking")),Z.appendChild(r("Colorize","colorize"));let C=Z.appendChild(r("Wireframe","wireframe","_tileset === undefined || hasEnabledWireframe")),y=document.createElement("p");y.setAttribute("data-bind","visible: _tileset !== undefined && !hasEnabledWireframe"),y.setAttribute("class","cesium-3DTilesInspector-disabledElementsInfo"),y.innerText="Set enableDebugWireframe to true in the tileset constructor to enable this option.",C.appendChild(y),Z.appendChild(r("Bounding Volumes","showBoundingVolumes")),Z.appendChild(r("Content Volumes","showContentBoundingVolumes")),Z.appendChild(r("Request Volumes","showRequestVolumes")),Z.appendChild(r("Point Cloud Shading","pointCloudShading"));let Y=document.createElement("div");Y.setAttribute("data-bind","visible: pointCloudShading"),Y.appendChild(d("Geometric Error Scale","geometricErrorScale",0,2,.01)),Y.appendChild(d("Maximum Attenuation","maximumAttenuation",0,32,1)),Y.appendChild(d("Base Resolution","baseResolution",0,1,.01)),Y.appendChild(r("Eye Dome Lighting (EDL)","eyeDomeLighting")),Z.appendChild(Y);let Q=document.createElement("div");Q.setAttribute("data-bind","visible: eyeDomeLighting"),Q.appendChild(d("EDL Strength","eyeDomeLightingStrength",0,2,.1)),Q.appendChild(d("EDL Radius","eyeDomeLightingRadius",0,4,.1)),Y.appendChild(Q),b.appendChild(r("Freeze Frame","freezeFrame")),b.appendChild(r("Dynamic Screen Space Error","dynamicScreenSpaceError"));let J=document.createElement("div");J.appendChild(d("Maximum Screen Space Error","maximumScreenSpaceError",0,128,1)),b.appendChild(J);let M=document.createElement("div");M.setAttribute("data-bind","visible: dynamicScreenSpaceError"),M.appendChild(d("Screen Space Error Density","dynamicScreenSpaceErrorDensitySliderValue",0,1,.005,"dynamicScreenSpaceErrorDensity")),M.appendChild(d("Screen Space Error Factor","dynamicScreenSpaceErrorFactor",1,32,.1)),b.appendChild(M),u.appendChild(r("Performance","performance")),u.appendChild(i),u.appendChild(r("Statistics","showStatistics"));let V=document.createElement("div");V.className="cesium-3dTilesInspector-statistics",V.setAttribute("data-bind","html: statisticsText, visible: showStatistics"),u.appendChild(V),u.appendChild(r("Pick Statistics","showPickStatistics"));let E=document.createElement("div");E.className="cesium-3dTilesInspector-statistics",E.setAttribute("data-bind","html: pickStatisticsText, visible: showPickStatistics"),u.appendChild(E),u.appendChild(r("Resource Cache Statistics","showResourceCacheStatistics"));let I=document.createElement("div");I.className="cesium-3dTilesInspector-statistics",I.setAttribute("data-bind","html: resourceCacheStatisticsText, visible: showResourceCacheStatistics"),u.appendChild(I);let B=document.createElement("div");U.appendChild(B),B.appendChild(document.createTextNode("Color Blend Mode: "));let X=document.createElement("select");X.setAttribute("data-bind",'options: colorBlendModes, optionsText: "text", optionsValue: "value", value: colorBlendMode'),B.appendChild(X);let _=document.createElement("textarea");_.setAttribute("data-bind","textInput: styleString, event: { keydown: styleEditorKeyPress }"),B.className="cesium-cesiumInspector-styleEditor",B.appendChild(_);let P=m("Compile (Ctrl+Enter)","compileStyle");B.appendChild(P);let w=document.createElement("div");w.className="cesium-cesiumInspector-error",w.setAttribute("data-bind","text: editorError"),B.appendChild(w),F.appendChild(r("Show Picked Only","showOnlyPickedTileDebugLabel")),F.appendChild(r("Geometric Error","showGeometricError")),F.appendChild(r("Rendering Statistics","showRenderingStatistics")),F.appendChild(r("Memory Usage (MB)","showMemoryUsage")),F.appendChild(r("Url","showUrl")),G.appendChild(r("Skip Tile LODs","skipLevelOfDetail"));let z=document.createElement("div");z.appendChild(d("Skip SSE Factor","skipScreenSpaceErrorFactor",1,50,1)),G.appendChild(z);let H=document.createElement("div");H.appendChild(d("SSE before skipping LOD","baseScreenSpaceError",0,4096,1)),G.appendChild(H);let nt=document.createElement("div");nt.appendChild(d("Min. levels to skip","skipLevels",0,10,1)),G.appendChild(nt),G.appendChild(r("Load only tiles that meet the max SSE.","immediatelyLoadDesiredLevelOfDetail")),G.appendChild(r("Load siblings of visible tiles","loadSiblings")),Lt.applyBindings(o,n)}Object.defineProperties(r4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});r4.prototype.isDestroyed=function(){return!1};r4.prototype.destroy=function(){return Lt.cleanNode(this._element),this._container.removeChild(this._element),this.viewModel.destroy(),At(this)};var fD=r4;var Ifa=R(W(),1);var cg="http://www.w3.org/2000/svg",Rkt="http://www.w3.org/1999/xlink",d4,FD=v.fromCssColorString("rgba(247,250,255,0.384)"),c4=v.fromCssColorString("rgba(143,191,255,0.216)"),Nrt=v.fromCssColorString("rgba(153,197,255,0.098)"),m4=v.fromCssColorString("rgba(255,255,255,0.086)"),V5e=v.fromCssColorString("rgba(255,255,255,0.267)"),b5e=v.fromCssColorString("rgba(255,255,255,0)"),Vkt=v.fromCssColorString("rgba(66,67,68,0.3)"),bkt=v.fromCssColorString("rgba(0,0,0,0.5)");function xU(t){return v.fromCssColorString(window.getComputedStyle(t).getPropertyValue("color"))}var UD={animation_pathReset:{tagName:"path",transform:"translate(16,16) scale(0.85) translate(-16,-16)",d:"M24.316,5.318,9.833,13.682,9.833,5.5,5.5,5.5,5.5,25.5,9.833,25.5,9.833,17.318,24.316,25.682z"},animation_pathPause:{tagName:"path",transform:"translate(16,16) scale(0.85) translate(-16,-16)",d:"M13,5.5,7.5,5.5,7.5,25.5,13,25.5zM24.5,5.5,19,5.5,19,25.5,24.5,25.5z"},animation_pathPlay:{tagName:"path",transform:"translate(16,16) scale(0.85) translate(-16,-16)",d:"M6.684,25.682L24.316,15.5L6.684,5.318V25.682z"},animation_pathPlayReverse:{tagName:"path",transform:"translate(16,16) scale(-0.85,0.85) translate(-16,-16)",d:"M6.684,25.682L24.316,15.5L6.684,5.318V25.682z"},animation_pathLoop:{tagName:"path",transform:"translate(16,16) scale(0.85) translate(-16,-16)",d:"M24.249,15.499c-0.009,4.832-3.918,8.741-8.75,8.75c-2.515,0-4.768-1.064-6.365-2.763l2.068-1.442l-7.901-3.703l0.744,8.694l2.193-1.529c2.244,2.594,5.562,4.242,9.26,4.242c6.767,0,12.249-5.482,12.249-12.249H24.249zM15.499,6.75c2.516,0,4.769,1.065,6.367,2.764l-2.068,1.443l7.901,3.701l-0.746-8.693l-2.192,1.529c-2.245-2.594-5.562-4.245-9.262-4.245C8.734,3.25,3.25,8.734,3.249,15.499H6.75C6.758,10.668,10.668,6.758,15.499,6.75z"},animation_pathClock:{tagName:"path",transform:"translate(16,16) scale(0.85) translate(-16,-15.5)",d:"M15.5,2.374C8.251,2.375,2.376,8.251,2.374,15.5C2.376,22.748,8.251,28.623,15.5,28.627c7.249-0.004,13.124-5.879,13.125-13.127C28.624,8.251,22.749,2.375,15.5,2.374zM15.5,25.623C9.909,25.615,5.385,21.09,5.375,15.5C5.385,9.909,9.909,5.384,15.5,5.374c5.59,0.01,10.115,4.535,10.124,10.125C25.615,21.09,21.091,25.615,15.5,25.623zM8.625,15.5c-0.001-0.552-0.448-0.999-1.001-1c-0.553,0-1,0.448-1,1c0,0.553,0.449,1,1,1C8.176,16.5,8.624,16.053,8.625,15.5zM8.179,18.572c-0.478,0.277-0.642,0.889-0.365,1.367c0.275,0.479,0.889,0.641,1.365,0.365c0.479-0.275,0.643-0.887,0.367-1.367C9.27,18.461,8.658,18.297,8.179,18.572zM9.18,10.696c-0.479-0.276-1.09-0.112-1.366,0.366s-0.111,1.09,0.365,1.366c0.479,0.276,1.09,0.113,1.367-0.366C9.821,11.584,9.657,10.973,9.18,10.696zM22.822,12.428c0.478-0.275,0.643-0.888,0.366-1.366c-0.275-0.478-0.89-0.642-1.366-0.366c-0.479,0.278-0.642,0.89-0.366,1.367C21.732,12.54,22.344,12.705,22.822,12.428zM12.062,21.455c-0.478-0.275-1.089-0.111-1.366,0.367c-0.275,0.479-0.111,1.09,0.366,1.365c0.478,0.277,1.091,0.111,1.365-0.365C12.704,22.344,12.54,21.732,12.062,21.455zM12.062,9.545c0.479-0.276,0.642-0.888,0.366-1.366c-0.276-0.478-0.888-0.642-1.366-0.366s-0.642,0.888-0.366,1.366C10.973,9.658,11.584,9.822,12.062,9.545zM22.823,18.572c-0.48-0.275-1.092-0.111-1.367,0.365c-0.275,0.479-0.112,1.092,0.367,1.367c0.477,0.275,1.089,0.113,1.365-0.365C23.464,19.461,23.3,18.848,22.823,18.572zM19.938,7.813c-0.477-0.276-1.091-0.111-1.365,0.366c-0.275,0.48-0.111,1.091,0.366,1.367s1.089,0.112,1.366-0.366C20.581,8.702,20.418,8.089,19.938,7.813zM23.378,14.5c-0.554,0.002-1.001,0.45-1.001,1c0.001,0.552,0.448,1,1.001,1c0.551,0,1-0.447,1-1C24.378,14.949,23.929,14.5,23.378,14.5zM15.501,6.624c-0.552,0-1,0.448-1,1l-0.466,7.343l-3.004,1.96c-0.478,0.277-0.642,0.889-0.365,1.365c0.275,0.479,0.889,0.643,1.365,0.367l3.305-1.676C15.39,16.99,15.444,17,15.501,17c0.828,0,1.5-0.671,1.5-1.5l-0.5-7.876C16.501,7.072,16.053,6.624,15.501,6.624zM15.501,22.377c-0.552,0-1,0.447-1,1s0.448,1,1,1s1-0.447,1-1S16.053,22.377,15.501,22.377zM18.939,21.455c-0.479,0.277-0.643,0.889-0.366,1.367c0.275,0.477,0.888,0.643,1.366,0.365c0.478-0.275,0.642-0.889,0.366-1.365C20.028,21.344,19.417,21.18,18.939,21.455z"},animation_pathWingButton:{tagName:"path",d:"m 4.5,0.5 c -2.216,0 -4,1.784 -4,4 l 0,24 c 0,2.216 1.784,4 4,4 l 13.71875,0 C 22.478584,27.272785 27.273681,22.511272 32.5,18.25 l 0,-13.75 c 0,-2.216 -1.784,-4 -4,-4 l -24,0 z"},animation_pathPointer:{tagName:"path",d:"M-15,-65,-15,-55,15,-55,15,-65,0,-95z"},animation_pathSwooshFX:{tagName:"path",d:"m 85,0 c 0,16.617 -4.813944,35.356 -13.131081,48.4508 h 6.099803 c 8.317138,-13.0948 13.13322,-28.5955 13.13322,-45.2124 0,-46.94483 -38.402714,-85.00262 -85.7743869,-85.00262 -1.0218522,0 -2.0373001,0.0241 -3.0506131,0.0589 45.958443,1.59437 82.723058,35.77285 82.723058,81.70532 z"}};function WV(t){let e=document.createElementNS(cg,t.tagName);for(let n in t)if(t.hasOwnProperty(n)&&n!=="tagName")if(n==="children"){let i=t.children.length;for(let o=0;o<i;++o)e.appendChild(WV(t.children[o]))}else n.indexOf("xlink:")===0?e.setAttributeNS(Rkt,n.substring(6),t[n]):n==="textContent"?e.textContent=t[n]:e.setAttribute(n,t[n]);return e}function yrt(t,e,n){let i=document.createElementNS(cg,"text");i.setAttribute("x",t),i.setAttribute("y",e),i.setAttribute("class","cesium-animation-svgText");let o=document.createElementNS(cg,"tspan");return o.textContent=n,i.appendChild(o),i}function R5e(t,e,n){t.setAttribute("transform",`translate(100,100) rotate(${n})`),e.setAttribute("transform",`rotate(${n})`)}var h4=new v;function Il(t,e){let n=e.alpha,i=1-n;return h4.red=t.red*i+e.red*n,h4.green=t.green*i+e.green*n,h4.blue=t.blue*i+e.blue*n,h4.toCssColorString()}function Brt(t,e,n){let i=UD[n],o={tagName:"g",class:"cesium-animation-rectButton",transform:`translate(${t},${e})`,children:[{tagName:"rect",class:"cesium-animation-buttonGlow",width:32,height:32,rx:2,ry:2},{tagName:"rect",class:"cesium-animation-buttonMain",width:32,height:32,rx:4,ry:4},{class:"cesium-animation-buttonPath",id:n,tagName:i.tagName,transform:i.transform,d:i.d},{tagName:"title",textContent:""}]};return WV(o)}function W5e(t,e,n){let i=UD[n],o=UD.animation_pathWingButton,a={tagName:"g",class:"cesium-animation-rectButton",transform:`translate(${t},${e})`,children:[{class:"cesium-animation-buttonGlow",id:"animation_pathWingButton",tagName:o.tagName,d:o.d},{class:"cesium-animation-buttonMain",id:"animation_pathWingButton",tagName:o.tagName,d:o.d},{class:"cesium-animation-buttonPath",id:n,tagName:i.tagName,transform:i.transform,d:i.d},{tagName:"title",textContent:""}]};return WV(a)}function f5e(t,e){let n=t._viewModel,i=n.shuttleRingDragging;if(!(i&&d4!==t))if(e.type==="mousedown"||i&&e.type==="mousemove"||e.type==="touchstart"&&e.touches.length===1||i&&e.type==="touchmove"&&e.touches.length===1){let o=t._centerX,a=t._centerY,l=t._svgNode.getBoundingClientRect(),r,d;if(e.type==="touchstart"||e.type==="touchmove"?(r=e.touches[0].clientX,d=e.touches[0].clientY):(r=e.clientX,d=e.clientY),!i&&(r>l.right||r<l.left||d<l.top||d>l.bottom))return;let m=t._shuttleRingPointer.getBoundingClientRect(),h=r-o-l.left,Z=d-a-l.top,b=Math.atan2(Z,h)*180/Math.PI+90;b>180&&(b-=360);let u=n.shuttleRingAngle;i||r<m.right&&r>m.left&&d>m.top&&d<m.bottom?(d4=t,n.shuttleRingDragging=!0,n.shuttleRingAngle=b):b<u?n.slower():b>u&&n.faster(),e.preventDefault()}else t===d4&&(d4=void 0),n.shuttleRingDragging=!1}function yW(t,e){this._viewModel=e,this.svgElement=t,this._enabled=void 0,this._toggled=void 0;let n=this;this._clickFunction=function(){let i=n._viewModel.command;i.canExecute&&i()},t.addEventListener("click",this._clickFunction,!0),this._subscriptions=[od(e,"toggled",this.setToggled,this),od(e,"tooltip",this.setTooltip,this),od(e.command,"canExecute",this.setEnabled,this)]}yW.prototype.destroy=function(){this.svgElement.removeEventListener("click",this._clickFunction,!0);let t=this._subscriptions;for(let e=0,n=t.length;e<n;e++)t[e].dispose();At(this)};yW.prototype.isDestroyed=function(){return!1};yW.prototype.setEnabled=function(t){if(this._enabled!==t){if(this._enabled=t,!t){this.svgElement.setAttribute("class","cesium-animation-buttonDisabled");return}if(this._toggled){this.svgElement.setAttribute("class","cesium-animation-rectButton cesium-animation-buttonToggled");return}this.svgElement.setAttribute("class","cesium-animation-rectButton")}};yW.prototype.setToggled=function(t){this._toggled!==t&&(this._toggled=t,this._enabled&&(t?this.svgElement.setAttribute("class","cesium-animation-rectButton cesium-animation-buttonToggled"):this.svgElement.setAttribute("class","cesium-animation-rectButton")))};yW.prototype.setTooltip=function(t){this.svgElement.getElementsByTagName("title")[0].textContent=t};function GN(t,e){t=Ui(t),this._viewModel=e,this._container=t,this._centerX=0,this._centerY=0,this._defsElement=void 0,this._svgNode=void 0,this._topG=void 0,this._lastHeight=void 0,this._lastWidth=void 0;let n=t.ownerDocument,i=document.createElement("style");i.textContent=".cesium-animation-rectButton .cesium-animation-buttonGlow { filter: url(#animation_blurred); }.cesium-animation-rectButton .cesium-animation-buttonMain { fill: url(#animation_buttonNormal); }.cesium-animation-buttonToggled .cesium-animation-buttonMain { fill: url(#animation_buttonToggled); }.cesium-animation-rectButton:hover .cesium-animation-buttonMain { fill: url(#animation_buttonHovered); }.cesium-animation-buttonDisabled .cesium-animation-buttonMain { fill: url(#animation_buttonDisabled); }.cesium-animation-shuttleRingG .cesium-animation-shuttleRingSwoosh { fill: url(#animation_shuttleRingSwooshGradient); }.cesium-animation-shuttleRingG:hover .cesium-animation-shuttleRingSwoosh { fill: url(#animation_shuttleRingSwooshHovered); }.cesium-animation-shuttleRingPointer { fill: url(#animation_shuttleRingPointerGradient); }.cesium-animation-shuttleRingPausePointer { fill: url(#animation_shuttleRingPointerPaused); }.cesium-animation-knobOuter { fill: url(#animation_knobOuter); }.cesium-animation-knobInner { fill: url(#animation_knobInner); }",n.head.insertBefore(i,n.head.childNodes[0]);let o=document.createElement("div");o.className="cesium-animation-theme",o.innerHTML='<div class="cesium-animation-themeNormal"></div><div class="cesium-animation-themeHover"></div><div class="cesium-animation-themeSelect"></div><div class="cesium-animation-themeDisabled"></div><div class="cesium-animation-themeKnob"></div><div class="cesium-animation-themePointer"></div><div class="cesium-animation-themeSwoosh"></div><div class="cesium-animation-themeSwooshHover"></div>',this._theme=o,this._themeNormal=o.childNodes[0],this._themeHover=o.childNodes[1],this._themeSelect=o.childNodes[2],this._themeDisabled=o.childNodes[3],this._themeKnob=o.childNodes[4],this._themePointer=o.childNodes[5],this._themeSwoosh=o.childNodes[6],this._themeSwooshHover=o.childNodes[7];let a=document.createElementNS(cg,"svg:svg");this._svgNode=a,a.setAttributeNS("http://www.w3.org/2000/xmlns/","xmlns:xlink",Rkt);let s=document.createElementNS(cg,"g");this._topG=s,this._realtimeSVG=new yW(W5e(3,4,"animation_pathClock"),e.playRealtimeViewModel),this._playReverseSVG=new yW(Brt(44,99,"animation_pathPlayReverse"),e.playReverseViewModel),this._playForwardSVG=new yW(Brt(124,99,"animation_pathPlay"),e.playForwardViewModel),this._pauseSVG=new yW(Brt(84,99,"animation_pathPause"),e.pauseViewModel);let l=document.createElementNS(cg,"g");l.appendChild(this._realtimeSVG.svgElement),l.appendChild(this._playReverseSVG.svgElement),l.appendChild(this._playForwardSVG.svgElement),l.appendChild(this._pauseSVG.svgElement);let r=WV({tagName:"circle",class:"cesium-animation-shuttleRingBack",cx:100,cy:100,r:99});this._shuttleRingBackPanel=r;let d=UD.animation_pathSwooshFX,m=UD.animation_pathPointer,h=WV({tagName:"g",class:"cesium-animation-shuttleRingSwoosh",children:[{tagName:d.tagName,transform:"translate(100,97) scale(-1,1)",id:"animation_pathSwooshFX",d:d.d},{tagName:d.tagName,transform:"translate(100,97)",id:"animation_pathSwooshFX",d:d.d},{tagName:"line",x1:100,y1:8,x2:100,y2:22}]});this._shuttleRingSwooshG=h,this._shuttleRingPointer=WV({class:"cesium-animation-shuttleRingPointer",id:"animation_pathPointer",tagName:m.tagName,d:m.d});let Z=WV({tagName:"g",transform:"translate(100,100)"});this._knobOuter=WV({tagName:"circle",class:"cesium-animation-knobOuter",cx:0,cy:0,r:71});let b=61,u=WV({tagName:"circle",class:"cesium-animation-knobInner",cx:0,cy:0,r:b});this._knobDate=yrt(0,-24,""),this._knobTime=yrt(0,-7,""),this._knobStatus=yrt(0,-41,"");let F=WV({tagName:"circle",class:"cesium-animation-blank",cx:0,cy:0,r:b}),U=document.createElementNS(cg,"g");U.setAttribute("class","cesium-animation-shuttleRingG"),t.appendChild(o),s.appendChild(U),s.appendChild(Z),s.appendChild(l),U.appendChild(r),U.appendChild(h),U.appendChild(this._shuttleRingPointer),Z.appendChild(this._knobOuter),Z.appendChild(u),Z.appendChild(this._knobDate),Z.appendChild(this._knobTime),Z.appendChild(this._knobStatus),Z.appendChild(F),a.appendChild(s),t.appendChild(a);let G=this;function A(Y){f5e(G,Y)}this._mouseCallback=A,r.addEventListener("mousedown",A,!0),r.addEventListener("touchstart",A,!0),h.addEventListener("mousedown",A,!0),h.addEventListener("touchstart",A,!0),n.addEventListener("mousemove",A,!0),n.addEventListener("touchmove",A,!0),n.addEventListener("mouseup",A,!0),n.addEventListener("touchend",A,!0),n.addEventListener("touchcancel",A,!0),this._shuttleRingPointer.addEventListener("mousedown",A,!0),this._shuttleRingPointer.addEventListener("touchstart",A,!0),this._knobOuter.addEventListener("mousedown",A,!0),this._knobOuter.addEventListener("touchstart",A,!0);let T=this._knobTime.childNodes[0],g=this._knobDate.childNodes[0],C=this._knobStatus.childNodes[0],y;this._subscriptions=[od(e.pauseViewModel,"toggled",function(Y){y!==Y&&(y=Y,y?G._shuttleRingPointer.setAttribute("class","cesium-animation-shuttleRingPausePointer"):G._shuttleRingPointer.setAttribute("class","cesium-animation-shuttleRingPointer"))}),od(e,"shuttleRingAngle",function(Y){R5e(G._shuttleRingPointer,G._knobOuter,Y)}),od(e,"dateLabel",function(Y){g.textContent!==Y&&(g.textContent=Y)}),od(e,"timeLabel",function(Y){T.textContent!==Y&&(T.textContent=Y)}),od(e,"multiplierLabel",function(Y){C.textContent!==Y&&(C.textContent=Y)})],this.applyThemeChanges(),this.resize()}Object.defineProperties(GN.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});GN.prototype.isDestroyed=function(){return!1};GN.prototype.destroy=function(){c(this._observer)&&(this._observer.disconnect(),this._observer=void 0);let t=this._container.ownerDocument,e=this._mouseCallback;this._shuttleRingBackPanel.removeEventListener("mousedown",e,!0),this._shuttleRingBackPanel.removeEventListener("touchstart",e,!0),this._shuttleRingSwooshG.removeEventListener("mousedown",e,!0),this._shuttleRingSwooshG.removeEventListener("touchstart",e,!0),t.removeEventListener("mousemove",e,!0),t.removeEventListener("touchmove",e,!0),t.removeEventListener("mouseup",e,!0),t.removeEventListener("touchend",e,!0),t.removeEventListener("touchcancel",e,!0),this._shuttleRingPointer.removeEventListener("mousedown",e,!0),this._shuttleRingPointer.removeEventListener("touchstart",e,!0),this._knobOuter.removeEventListener("mousedown",e,!0),this._knobOuter.removeEventListener("touchstart",e,!0),this._container.removeChild(this._svgNode),this._container.removeChild(this._theme),this._realtimeSVG.destroy(),this._playReverseSVG.destroy(),this._playForwardSVG.destroy(),this._pauseSVG.destroy();let n=this._subscriptions;for(let i=0,o=n.length;i<o;i++)n[i].dispose();return At(this)};GN.prototype.resize=function(){let t=this._container.clientWidth,e=this._container.clientHeight;if(t===this._lastWidth&&e===this._lastHeight)return;let n=this._svgNode,i=200,o=132,a=t,s=e;t===0&&e===0?(a=i,s=o):t===0?(s=e,a=i*(e/o)):e===0&&(a=t,s=o*(t/i));let l=a/i,r=s/o;n.style.cssText=`width: ${a}px; height: ${s}px; position: absolute; bottom: 0; left: 0; overflow: hidden;`,n.setAttribute("width",a),n.setAttribute("height",s),n.setAttribute("viewBox",`0 0 ${a} ${s}`),this._topG.setAttribute("transform",`scale(${l},${r})`),this._centerX=Math.max(1,100*l),this._centerY=Math.max(1,100*r),this._lastHeight=t,this._lastWidth=e};GN.prototype.applyThemeChanges=function(){let t=this._container.ownerDocument;if(!t.body.contains(this._container)){if(c(this._observer))return;let m=this;m._observer=new MutationObserver(function(){t.body.contains(m._container)&&(m._observer.disconnect(),m._observer=void 0,m.applyThemeChanges())}),m._observer.observe(t,{childList:!0,subtree:!0});return}let e=xU(this._themeNormal),n=xU(this._themeHover),i=xU(this._themeSelect),o=xU(this._themeDisabled),a=xU(this._themeKnob),s=xU(this._themePointer),l=xU(this._themeSwoosh),r=xU(this._themeSwooshHover),d=WV({tagName:"defs",children:[{id:"animation_buttonNormal",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-color":Il(e,FD)},{tagName:"stop",offset:"12%","stop-color":Il(e,c4)},{tagName:"stop",offset:"46%","stop-color":Il(e,Nrt)},{tagName:"stop",offset:"81%","stop-color":Il(e,m4)}]},{id:"animation_buttonHovered",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-color":Il(n,FD)},{tagName:"stop",offset:"12%","stop-color":Il(n,c4)},{tagName:"stop",offset:"46%","stop-color":Il(n,Nrt)},{tagName:"stop",offset:"81%","stop-color":Il(n,m4)}]},{id:"animation_buttonToggled",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-color":Il(i,FD)},{tagName:"stop",offset:"12%","stop-color":Il(i,c4)},{tagName:"stop",offset:"46%","stop-color":Il(i,Nrt)},{tagName:"stop",offset:"81%","stop-color":Il(i,m4)}]},{id:"animation_buttonDisabled",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-color":Il(o,V5e)},{tagName:"stop",offset:"75%","stop-color":Il(o,b5e)}]},{id:"animation_blurred",tagName:"filter",width:"200%",height:"200%",x:"-50%",y:"-50%",children:[{tagName:"feGaussianBlur",stdDeviation:4,in:"SourceGraphic"}]},{id:"animation_shuttleRingSwooshGradient",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-opacity":.2,"stop-color":l.toCssColorString()},{tagName:"stop",offset:"85%","stop-opacity":.85,"stop-color":l.toCssColorString()},{tagName:"stop",offset:"95%","stop-opacity":.05,"stop-color":l.toCssColorString()}]},{id:"animation_shuttleRingSwooshHovered",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-opacity":.2,"stop-color":r.toCssColorString()},{tagName:"stop",offset:"85%","stop-opacity":.85,"stop-color":r.toCssColorString()},{tagName:"stop",offset:"95%","stop-opacity":.05,"stop-color":r.toCssColorString()}]},{id:"animation_shuttleRingPointerGradient",tagName:"linearGradient",x1:"0%",y1:"50%",x2:"100%",y2:"50%",children:[{tagName:"stop",offset:"0%","stop-color":s.toCssColorString()},{tagName:"stop",offset:"40%","stop-color":s.toCssColorString()},{tagName:"stop",offset:"60%","stop-color":Il(s,bkt)},{tagName:"stop",offset:"100%","stop-color":Il(s,bkt)}]},{id:"animation_shuttleRingPointerPaused",tagName:"linearGradient",x1:"0%",y1:"50%",x2:"100%",y2:"50%",children:[{tagName:"stop",offset:"0%","stop-color":"#CCC"},{tagName:"stop",offset:"40%","stop-color":"#CCC"},{tagName:"stop",offset:"60%","stop-color":"#555"},{tagName:"stop",offset:"100%","stop-color":"#555"}]},{id:"animation_knobOuter",tagName:"linearGradient",x1:"20%",y1:"0%",x2:"90%",y2:"100%",children:[{tagName:"stop",offset:"5%","stop-color":Il(a,FD)},{tagName:"stop",offset:"60%","stop-color":Il(a,Vkt)},{tagName:"stop",offset:"85%","stop-color":Il(a,c4)}]},{id:"animation_knobInner",tagName:"linearGradient",x1:"20%",y1:"0%",x2:"90%",y2:"100%",children:[{tagName:"stop",offset:"5%","stop-color":Il(a,Vkt)},{tagName:"stop",offset:"60%","stop-color":Il(a,FD)},{tagName:"stop",offset:"85%","stop-color":Il(a,m4)}]}]});c(this._defsElement)?this._svgNode.replaceChild(d,this._defsElement):this._svgNode.appendChild(d),this._defsElement=d};var GD=GN;var Xfa=R(W(),1);var F5e=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],XU=15,AN=105;function Wkt(t,e){return t-e}function Qrt(t,e){let n=Ja(e,t,Wkt);return n<0?~n:n}function U5e(t,e){if(Math.abs(t)<=XU)return t/XU;let n=XU,i=AN,o,a=0,s;return t>0?(o=Math.log(e[e.length-1]),s=(o-a)/(i-n),Math.exp(a+s*(t-n))):(o=Math.log(-e[0]),s=(o-a)/(i-n),-Math.exp(a+s*(Math.abs(t)-n)))}function G5e(t,e,n){if(n.clockStep===ya.SYSTEM_CLOCK)return XU;if(Math.abs(t)<=1)return t*XU;let i=e[e.length-1];t>i?t=i:t<-i&&(t=-i);let o=XU,a=AN,s,l=0,r;return t>0?(s=Math.log(i),r=(s-l)/(a-o),(Math.log(t)-l)/r+o):(s=Math.log(-e[0]),r=(s-l)/(a-o),-((Math.log(Math.abs(t))-l)/r+o))}function ku(t){let e=this;this._clockViewModel=t,this._allShuttleRingTicks=[],this._dateFormatter=ku.defaultDateFormatter,this._timeFormatter=ku.defaultTimeFormatter,this.shuttleRingDragging=!1,this.snapToTicks=!1,Lt.track(this,["_allShuttleRingTicks","_dateFormatter","_timeFormatter","shuttleRingDragging","snapToTicks"]),this._sortedFilteredPositiveTicks=[],this.setShuttleRingTicks(ku.defaultTicks),this.timeLabel=void 0,Lt.defineProperty(this,"timeLabel",function(){return e._timeFormatter(e._clockViewModel.currentTime,e)}),this.dateLabel=void 0,Lt.defineProperty(this,"dateLabel",function(){return e._dateFormatter(e._clockViewModel.currentTime,e)}),this.multiplierLabel=void 0,Lt.defineProperty(this,"multiplierLabel",function(){let s=e._clockViewModel;if(s.clockStep===ya.SYSTEM_CLOCK)return"Today";let l=s.multiplier;return l%1===0?`${l.toFixed(0)}x`:`${l.toFixed(3).replace(/0{0,3}$/,"")}x`}),this.shuttleRingAngle=void 0,Lt.defineProperty(this,"shuttleRingAngle",{get:function(){return G5e(t.multiplier,e._allShuttleRingTicks,t)},set:function(s){s=Math.max(Math.min(s,AN),-AN);let l=e._allShuttleRingTicks,r=e._clockViewModel;if(r.clockStep=ya.SYSTEM_CLOCK_MULTIPLIER,Math.abs(s)===AN){r.multiplier=s>0?l[l.length-1]:l[0];return}let d=U5e(s,l);if(e.snapToTicks)d=l[Qrt(d,l)];else if(d!==0){let m=Math.abs(d);if(m>100){let h=m.toFixed(0).length-2,Z=Math.pow(10,h);d=Math.round(d/Z)*Z|0}else m>XU?d=Math.round(d):m>1?d=+d.toFixed(1):m>0&&(d=+d.toFixed(2))}r.multiplier=d}}),this._canAnimate=void 0,Lt.defineProperty(this,"_canAnimate",function(){let s=e._clockViewModel,l=s.clockRange;if(e.shuttleRingDragging||l===pl.UNBOUNDED)return!0;let r=s.multiplier,d=s.currentTime,m=s.startTime,h=!1;if(l===pl.LOOP_STOP)h=rt.greaterThan(d,m)||d.equals(m)&&r>0;else{let Z=s.stopTime;h=rt.greaterThan(d,m)&&rt.lessThan(d,Z)||d.equals(m)&&r>0||d.equals(Z)&&r<0}return h||(s.shouldAnimate=!1),h}),this._isSystemTimeAvailable=void 0,Lt.defineProperty(this,"_isSystemTimeAvailable",function(){let s=e._clockViewModel;if(s.clockRange===pl.UNBOUNDED)return!0;let r=s.systemTime;return rt.greaterThanOrEquals(r,s.startTime)&&rt.lessThanOrEquals(r,s.stopTime)}),this._isAnimating=void 0,Lt.defineProperty(this,"_isAnimating",function(){return e._clockViewModel.shouldAnimate&&(e._canAnimate||e.shuttleRingDragging)});let n=bi(function(){let s=e._clockViewModel;s.shouldAnimate?s.shouldAnimate=!1:e._canAnimate&&(s.shouldAnimate=!0)});this._pauseViewModel=new YU(n,{toggled:Lt.computed(function(){return!e._isAnimating}),tooltip:"Pause"});let i=bi(function(){let s=e._clockViewModel,l=s.multiplier;l>0&&(s.multiplier=-l),s.shouldAnimate=!0});this._playReverseViewModel=new YU(i,{toggled:Lt.computed(function(){return e._isAnimating&&t.multiplier<0}),tooltip:"Play Reverse"});let o=bi(function(){let s=e._clockViewModel,l=s.multiplier;l<0&&(s.multiplier=-l),s.shouldAnimate=!0});this._playForwardViewModel=new YU(o,{toggled:Lt.computed(function(){return e._isAnimating&&t.multiplier>0&&t.clockStep!==ya.SYSTEM_CLOCK}),tooltip:"Play Forward"});let a=bi(function(){e._clockViewModel.clockStep=ya.SYSTEM_CLOCK},Lt.getObservable(this,"_isSystemTimeAvailable"));this._playRealtimeViewModel=new YU(a,{toggled:Lt.computed(function(){return t.clockStep===ya.SYSTEM_CLOCK}),tooltip:Lt.computed(function(){return e._isSystemTimeAvailable?"Today (real-time)":"Current time not in range"})}),this._slower=bi(function(){let s=e._clockViewModel,l=e._allShuttleRingTicks,r=s.multiplier,d=Qrt(r,l)-1;d>=0&&(s.multiplier=l[d])}),this._faster=bi(function(){let s=e._clockViewModel,l=e._allShuttleRingTicks,r=s.multiplier,d=Qrt(r,l)+1;d<l.length&&(s.multiplier=l[d])})}ku.defaultDateFormatter=function(t,e){let n=rt.toGregorianDate(t);return`${F5e[n.month-1]} ${n.day} ${n.year}`};ku.defaultTicks=[.001,.002,.005,.01,.02,.05,.1,.25,.5,1,2,5,10,15,30,60,120,300,600,900,1800,3600,7200,14400,21600,43200,86400,172800,345600,604800];ku.defaultTimeFormatter=function(t,e){let n=rt.toGregorianDate(t),i=Math.round(n.millisecond);return Math.abs(e._clockViewModel.multiplier)<1?`${n.hour.toString().padStart(2,"0")}:${n.minute.toString().padStart(2,"0")}:${n.second.toString().padStart(2,"0")}.${i.toString().padStart(3,"0")}`:`${n.hour.toString().padStart(2,"0")}:${n.minute.toString().padStart(2,"0")}:${n.second.toString().padStart(2,"0")} UTC`};ku.prototype.getShuttleRingTicks=function(){return this._sortedFilteredPositiveTicks.slice(0)};ku.prototype.setShuttleRingTicks=function(t){let e,n,i,o={},a=this._sortedFilteredPositiveTicks;for(a.length=0,e=0,n=t.length;e<n;++e)i=t[e],o.hasOwnProperty(i)||(o[i]=!0,a.push(i));a.sort(Wkt);let s=[];for(n=a.length,e=n-1;e>=0;--e)i=a[e],i!==0&&s.push(-i);Array.prototype.push.apply(s,a),this._allShuttleRingTicks=s};Object.defineProperties(ku.prototype,{slower:{get:function(){return this._slower}},faster:{get:function(){return this._faster}},clockViewModel:{get:function(){return this._clockViewModel}},pauseViewModel:{get:function(){return this._pauseViewModel}},playReverseViewModel:{get:function(){return this._playReverseViewModel}},playForwardViewModel:{get:function(){return this._playForwardViewModel}},playRealtimeViewModel:{get:function(){return this._playRealtimeViewModel}},dateFormatter:{get:function(){return this._dateFormatter},set:function(t){this._dateFormatter=t}},timeFormatter:{get:function(){return this._timeFormatter},set:function(t){this._timeFormatter=t}}});ku._maxShuttleRingAngle=AN;ku._realtimeShuttleRingAngle=XU;var AD=ku;var jfa=R(W(),1);var Ofa=R(W(),1);function fkt(t){t=f(t,f.EMPTY_OBJECT);let e=t.globe,n=f(t.imageryProviderViewModels,[]),i=f(t.terrainProviderViewModels,[]);this._globe=e,this.imageryProviderViewModels=n.slice(0),this.terrainProviderViewModels=i.slice(0),this.dropDownVisible=!1,Lt.track(this,["imageryProviderViewModels","terrainProviderViewModels","dropDownVisible"]);let o=Lt.getObservable(this,"imageryProviderViewModels"),a=Lt.pureComputed(function(){let h=o(),Z={},b;for(b=0;b<h.length;b++){let U=h[b],G=U.category;c(Z[G])?Z[G].push(U):Z[G]=[U]}let u=Object.keys(Z),F=[];for(b=0;b<u.length;b++){let U=u[b];F.push({name:U,providers:Z[U]})}return F});this._imageryProviders=a;let s=Lt.getObservable(this,"terrainProviderViewModels"),l=Lt.pureComputed(function(){let h=s(),Z={},b;for(b=0;b<h.length;b++){let U=h[b],G=U.category;c(Z[G])?Z[G].push(U):Z[G]=[U]}let u=Object.keys(Z),F=[];for(b=0;b<u.length;b++){let U=u[b];F.push({name:U,providers:Z[U]})}return F});this._terrainProviders=l,this.buttonTooltip=void 0,Lt.defineProperty(this,"buttonTooltip",function(){let h=this.selectedImagery,Z=this.selectedTerrain,b=c(h)?h.name:void 0,u=c(Z)?Z.name:void 0;return c(b)&&c(u)?`${b} -${u}`:c(b)?b:u}),this.buttonImageUrl=void 0,Lt.defineProperty(this,"buttonImageUrl",function(){let h=this.selectedImagery;if(c(h))return h.iconUrl}),this.selectedImagery=void 0;let r=Lt.observable();this._currentImageryLayers=[],Lt.defineProperty(this,"selectedImagery",{get:function(){return r()},set:function(h){if(r()===h){this.dropDownVisible=!1;return}let Z,b=this._currentImageryLayers,u=b.length,F=this._globe.imageryLayers,U=!1;for(Z=0;Z<u;Z++){let G=F.length;for(let A=0;A<G;A++){let T=F.get(A);if(T===b[Z]){F.remove(T),U=!0;break}}}if(c(h)){let G=h.creationCommand();if(Array.isArray(G)){let A=G.length;for(this._currentImageryLayers=[],Z=A-1;Z>=0;Z--){let T=$r.fromProviderAsync(G[Z]);F.add(T,0),this._currentImageryLayers.push(T)}}else{this._currentImageryLayers=[];let A=$r.fromProviderAsync(G);if(A.name=h.name,U)F.add(A,0);else{let T=F.get(0);c(T)&&F.remove(T),F.add(A,0)}this._currentImageryLayers.push(A)}}r(h),this.dropDownVisible=!1}}),this.selectedTerrain=void 0;let d=Lt.observable();Lt.defineProperty(this,"selectedTerrain",{get:function(){return d()},set:function(h){if(d()===h){this.dropDownVisible=!1;return}let Z;if(c(h)&&(Z=h.creationCommand()),c(Z)&&!c(Z.then))this._globe.depthTestAgainstTerrain=!(Z instanceof Ru),this._globe.terrainProvider=Z;else if(c(Z)){let b=!1,u=this._globe.terrainProviderChanged.addEventListener(()=>{b=!0,u()}),U=new lD(Z).readyEvent.addEventListener(G=>{b||(this._globe.depthTestAgainstTerrain=!(G instanceof Ru),this._globe.terrainProvider=G,U())})}d(h),this.dropDownVisible=!1}});let m=this;this._toggleDropDown=bi(function(){m.dropDownVisible=!m.dropDownVisible}),this.selectedImagery=f(t.selectedImageryProviderViewModel,n[0]),this.selectedTerrain=f(t.selectedTerrainProviderViewModel,i[0])}Object.defineProperties(fkt.prototype,{toggleDropDown:{get:function(){return this._toggleDropDown}},globe:{get:function(){return this._globe}}});var TD=fkt;function p4(t,e){t=Ui(t);let n=new TD(e),i=document.createElement("button");i.type="button",i.className="cesium-button cesium-toolbar-button",i.setAttribute("data-bind","attr: { title: buttonTooltip },click: toggleDropDown"),t.appendChild(i);let o=document.createElement("img");o.setAttribute("draggable","false"),o.className="cesium-baseLayerPicker-selected",o.setAttribute("data-bind","attr: { src: buttonImageUrl }, visible: !!buttonImageUrl"),i.appendChild(o);let a=document.createElement("div");a.className="cesium-baseLayerPicker-dropDown",a.setAttribute("data-bind",'css: { "cesium-baseLayerPicker-dropDown-visible" : dropDownVisible }'),t.appendChild(a);let s=document.createElement("div");s.className="cesium-baseLayerPicker-sectionTitle",s.setAttribute("data-bind","visible: imageryProviderViewModels.length > 0"),s.innerHTML="Imagery",a.appendChild(s);let l=document.createElement("div");l.className="cesium-baseLayerPicker-section",l.setAttribute("data-bind","foreach: _imageryProviders"),a.appendChild(l);let r=document.createElement("div");r.className="cesium-baseLayerPicker-category",l.appendChild(r);let d=document.createElement("div");d.className="cesium-baseLayerPicker-categoryTitle",d.setAttribute("data-bind","text: name"),r.appendChild(d);let m=document.createElement("div");m.className="cesium-baseLayerPicker-choices",m.setAttribute("data-bind","foreach: providers"),r.appendChild(m);let h=document.createElement("div");h.className="cesium-baseLayerPicker-item",h.setAttribute("data-bind",'css: { "cesium-baseLayerPicker-selectedItem" : $data === $parents[1].selectedImagery },attr: { title: tooltip },visible: creationCommand.canExecute,click: function($data) { $parents[1].selectedImagery = $data; }'),m.appendChild(h);let Z=document.createElement("img");Z.className="cesium-baseLayerPicker-itemIcon",Z.setAttribute("data-bind","attr: { src: iconUrl }"),Z.setAttribute("draggable","false"),h.appendChild(Z);let b=document.createElement("div");b.className="cesium-baseLayerPicker-itemLabel",b.setAttribute("data-bind","text: name"),h.appendChild(b);let u=document.createElement("div");u.className="cesium-baseLayerPicker-sectionTitle",u.setAttribute("data-bind","visible: terrainProviderViewModels.length > 0"),u.innerHTML="Terrain",a.appendChild(u);let F=document.createElement("div");F.className="cesium-baseLayerPicker-section",F.setAttribute("data-bind","foreach: _terrainProviders"),a.appendChild(F);let U=document.createElement("div");U.className="cesium-baseLayerPicker-category",F.appendChild(U);let G=document.createElement("div");G.className="cesium-baseLayerPicker-categoryTitle",G.setAttribute("data-bind","text: name"),U.appendChild(G);let A=document.createElement("div");A.className="cesium-baseLayerPicker-choices",A.setAttribute("data-bind","foreach: providers"),U.appendChild(A);let T=document.createElement("div");T.className="cesium-baseLayerPicker-item",T.setAttribute("data-bind",'css: { "cesium-baseLayerPicker-selectedItem" : $data === $parents[1].selectedTerrain },attr: { title: tooltip },visible: creationCommand.canExecute,click: function($data) { $parents[1].selectedTerrain = $data; }'),A.appendChild(T);let g=document.createElement("img");g.className="cesium-baseLayerPicker-itemIcon",g.setAttribute("data-bind","attr: { src: iconUrl }"),g.setAttribute("draggable","false"),T.appendChild(g);let C=document.createElement("div");C.className="cesium-baseLayerPicker-itemLabel",C.setAttribute("data-bind","text: name"),T.appendChild(C),Lt.applyBindings(n,i),Lt.applyBindings(n,a),this._viewModel=n,this._container=t,this._element=i,this._dropPanel=a,this._closeDropDown=function(y){i.contains(y.target)||a.contains(y.target)||(n.dropDownVisible=!1)},In.supportsPointerEvents()?document.addEventListener("pointerdown",this._closeDropDown,!0):(document.addEventListener("mousedown",this._closeDropDown,!0),document.addEventListener("touchstart",this._closeDropDown,!0))}Object.defineProperties(p4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});p4.prototype.isDestroyed=function(){return!1};p4.prototype.destroy=function(){return In.supportsPointerEvents()?document.removeEventListener("pointerdown",this._closeDropDown,!0):(document.removeEventListener("mousedown",this._closeDropDown,!0),document.removeEventListener("touchstart",this._closeDropDown,!0)),Lt.cleanNode(this._element),Lt.cleanNode(this._dropPanel),this._container.removeChild(this._element),this._container.removeChild(this._dropPanel),At(this)};var SD=p4;var iFa=R(W(),1);function Fkt(t){let e=t.creationFunction;c(e.canExecute)||(e=bi(e)),this._creationCommand=e,this.name=t.name,this.tooltip=t.tooltip,this.iconUrl=t.iconUrl,this._category=f(t.category,""),Lt.track(this,["name","tooltip","iconUrl"])}Object.defineProperties(Fkt.prototype,{creationCommand:{get:function(){return this._creationCommand}},category:{get:function(){return this._category}}});var Nl=Fkt;var lFa=R(W(),1);function A5e(){let t=[],e=devicePixelRatio>=2;return t.push(new Nl({name:"Bing Maps Aerial",iconUrl:Dn("Widgets/Images/ImageryProviders/bingAerial.png"),tooltip:"Bing Maps aerial imagery, provided by Cesium ion",category:"Cesium ion",creationFunction:function(){return pW({style:hW.AERIAL})}})),t.push(new Nl({name:"Bing Maps Aerial with Labels",iconUrl:Dn("Widgets/Images/ImageryProviders/bingAerialLabels.png"),tooltip:"Bing Maps aerial imagery with labels, provided by Cesium ion",category:"Cesium ion",creationFunction:function(){return pW({style:hW.AERIAL_WITH_LABELS})}})),t.push(new Nl({name:"Bing Maps Roads",iconUrl:Dn("Widgets/Images/ImageryProviders/bingRoads.png"),tooltip:"Bing Maps standard road maps, provided by Cesium ion",category:"Cesium ion",creationFunction:function(){return pW({style:hW.ROAD})}})),t.push(new Nl({name:"ArcGIS World Imagery",iconUrl:Dn("Widgets/Images/ImageryProviders/ArcGisMapServiceWorldImagery.png"),tooltip:`ArcGIS World Imagery provides one meter or better satellite and aerial imagery in many parts of the world and lower resolution satellite imagery worldwide. The map includes 15m TerraColor imagery at small and mid-scales (~1:591M down to ~1:288k) for the world. The map features Maxar imagery at 0.3m resolution for select metropolitan areas around the world, 0.5m resolution across the United States and parts of Western Europe, and 1m resolution imagery across the rest of the world. In addition to commercial sources, the World Imagery map features high-resolution aerial photography contributed by the GIS User Community. This imagery ranges from 0.3m to 0.03m resolution (down to ~1:280 nin select communities). For more information on this map, including the terms of use, visit us online at -https://www.arcgis.com/home/item.html?id=10df2279f9684e4a9f6a7f08febac2a9`,category:"Other",creationFunction:function(){return cW.fromBasemapType(oV.SATELLITE,{enablePickFeatures:!1})}})),t.push(new Nl({name:"ArcGIS World Hillshade",iconUrl:Dn("Widgets/Images/ImageryProviders/ArcGisMapServiceWorldHillshade.png"),tooltip:`ArcGIS World Hillshade map portrays elevation as an artistic hillshade. This map is designed to be used as a backdrop for topographical, soil, hydro, landcover or other outdoor recreational maps. The map was compiled from a variety of sources from several data providers. The basemap has global coverage down to a scale of ~1:72k. In select areas of the United States and Europe, coverage is available down to ~1:9k. For more information on this map, including the terms of use, visit us online at -https://www.arcgis.com/home/item.html?id=1b243539f4514b6ba35e7d995890db1d`,category:"Other",creationFunction:function(){return cW.fromBasemapType(oV.HILLSHADE,{enablePickFeatures:!1})}})),t.push(new Nl({name:"Esri World Ocean",iconUrl:Dn("Widgets/Images/ImageryProviders/ArcGisMapServiceWorldOcean.png"),tooltip:`ArcGIS World Ocean map is designed to be used as a base map by marine GIS professionals and as a reference map by anyone interested in ocean data. The base map features marine bathymetry. Land features include inland waters and roads overlaid on land cover and shaded relief imagery. The map was compiled from a variety of best available sources from several data providers, including General Bathymetric Chart of the Oceans GEBCO_08 Grid, National Oceanic and Atmospheric Administration (NOAA), and National Geographic, Garmin, HERE, Geonames.org, and Esri, and various other contributors. The base map currently provides coverage for the world down to a scale of ~1:577k, and coverage down to 1:72k in US coastal areas, and various other areas. Coverage down to ~ 1:9k is available limited areas based on regional hydrographic survey data. The base map was designed and developed by Esri. For more information on this map, including our terms of use, visit us online at -https://www.arcgis.com/home/item.html?id=1e126e7520f9466c9ca28b8f28b5e500`,category:"Other",creationFunction:function(){return cW.fromBasemapType(oV.OCEANS,{enablePickFeatures:!1})}})),t.push(new Nl({name:"Open\xADStreet\xADMap",iconUrl:Dn("Widgets/Images/ImageryProviders/openStreetMap.png"),tooltip:`OpenStreetMap (OSM) is a collaborative project to create a free editable map of the world. +`);n.value=n.value.slice(0,i)+m+n.value.slice(o),n.selectionStart=i!==o?i:a,n.selectionEnd=a}else e.ctrlKey&&(e.keyCode===10||e.keyCode===13)&&this.compileStyle();return!0};ad.prototype._update=function(){let t=this._tileset;if(this.performance&&this._performanceDisplay.update(),c(t)){if(t.isDestroyed()){this.tile=void 0,this.feature=void 0,this.tileset=void 0;return}let e=t.style;this._style!==t.style&&(this._shouldStyle?(t.style=this._style,this._shouldStyle=!1):(this._style=e,this.styleString=JSON.stringify(e.style,null," ")))}this.showStatistics&&(this._statisticsText=bD(t,!1),this._pickStatisticsText=bD(t,!0),this._resourceCacheStatisticsText=u2t())};ad.prototype.isDestroyed=function(){return!1};ad.prototype.destroy=function(){this._eventHandler.destroy(),this._removePostRenderEvent();let t=this;return this._definedProperties.forEach(function(e){Lt.getObservable(t,e).dispose()}),At(this)};ad.getStatistics=bD;var WD=ad;function r4(t,e){t=Ui(t);let n=document.createElement("div"),i=document.createElement("div");i.setAttribute("data-bind","visible: performance");let o=new WD(e,i);this._viewModel=o,this._container=t,this._element=n;let a=document.createElement("div");a.textContent="3D Tiles Inspector",a.className="cesium-cesiumInspector-button",a.setAttribute("data-bind","click: toggleInspector"),n.appendChild(a),n.className="cesium-cesiumInspector cesium-3DTilesInspector",n.setAttribute("data-bind",'css: { "cesium-cesiumInspector-visible" : inspectorVisible, "cesium-cesiumInspector-hidden" : !inspectorVisible}'),t.appendChild(n);let s=document.createElement("div");s.className="cesium-cesiumInspector-dropDown",n.appendChild(s);let l=gd.createSection,r=gd.createCheckbox,d=gd.createRangeInput,m=gd.createButton,h=l(s,"Tileset","tilesetVisible","toggleTileset"),u=l(s,"Display","displayVisible","toggleDisplay"),R=l(s,"Update","updateVisible","toggleUpdate"),V=l(s,"Logging","loggingVisible","toggleLogging"),F=l(s,"Tile Debug Labels","tileDebugLabelsVisible","toggleTileDebugLabels"),U=l(s,"Style","styleVisible","toggleStyle"),G=l(s,"Optimization","optimizationVisible","toggleOptimization"),A=document.createElement("div");A.className="field-group";let S=document.createElement("label");S.className="field-label",S.appendChild(document.createTextNode("Properties: "));let g=document.createElement("div");g.setAttribute("data-bind","text: properties"),A.appendChild(S),A.appendChild(g),h.appendChild(A),h.appendChild(m("Pick Tileset","togglePickTileset","pickActive")),h.appendChild(m("Trim Tiles Cache","trimTilesCache")),h.appendChild(r("Enable Picking","picking")),u.appendChild(r("Colorize","colorize"));let C=u.appendChild(r("Wireframe","wireframe","_tileset === undefined || hasEnabledWireframe")),y=document.createElement("p");y.setAttribute("data-bind","visible: _tileset !== undefined && !hasEnabledWireframe"),y.setAttribute("class","cesium-3DTilesInspector-disabledElementsInfo"),y.innerText="Set enableDebugWireframe to true in the tileset constructor to enable this option.",C.appendChild(y),u.appendChild(r("Bounding Volumes","showBoundingVolumes")),u.appendChild(r("Content Volumes","showContentBoundingVolumes")),u.appendChild(r("Request Volumes","showRequestVolumes")),u.appendChild(r("Point Cloud Shading","pointCloudShading"));let Y=document.createElement("div");Y.setAttribute("data-bind","visible: pointCloudShading"),Y.appendChild(d("Geometric Error Scale","geometricErrorScale",0,2,.01)),Y.appendChild(d("Maximum Attenuation","maximumAttenuation",0,32,1)),Y.appendChild(d("Base Resolution","baseResolution",0,1,.01)),Y.appendChild(r("Eye Dome Lighting (EDL)","eyeDomeLighting")),u.appendChild(Y);let Q=document.createElement("div");Q.setAttribute("data-bind","visible: eyeDomeLighting"),Q.appendChild(d("EDL Strength","eyeDomeLightingStrength",0,2,.1)),Q.appendChild(d("EDL Radius","eyeDomeLightingRadius",0,4,.1)),Y.appendChild(Q),R.appendChild(r("Freeze Frame","freezeFrame")),R.appendChild(r("Dynamic Screen Space Error","dynamicScreenSpaceError"));let J=document.createElement("div");J.appendChild(d("Maximum Screen Space Error","maximumScreenSpaceError",0,128,1)),R.appendChild(J);let M=document.createElement("div");M.setAttribute("data-bind","visible: dynamicScreenSpaceError"),M.appendChild(d("Screen Space Error Density","dynamicScreenSpaceErrorDensitySliderValue",0,1,.005,"dynamicScreenSpaceErrorDensity")),M.appendChild(d("Screen Space Error Factor","dynamicScreenSpaceErrorFactor",1,32,.1)),R.appendChild(M),V.appendChild(r("Performance","performance")),V.appendChild(i),V.appendChild(r("Statistics","showStatistics"));let Z=document.createElement("div");Z.className="cesium-3dTilesInspector-statistics",Z.setAttribute("data-bind","html: statisticsText, visible: showStatistics"),V.appendChild(Z),V.appendChild(r("Pick Statistics","showPickStatistics"));let E=document.createElement("div");E.className="cesium-3dTilesInspector-statistics",E.setAttribute("data-bind","html: pickStatisticsText, visible: showPickStatistics"),V.appendChild(E),V.appendChild(r("Resource Cache Statistics","showResourceCacheStatistics"));let I=document.createElement("div");I.className="cesium-3dTilesInspector-statistics",I.setAttribute("data-bind","html: resourceCacheStatisticsText, visible: showResourceCacheStatistics"),V.appendChild(I);let B=document.createElement("div");U.appendChild(B),B.appendChild(document.createTextNode("Color Blend Mode: "));let X=document.createElement("select");X.setAttribute("data-bind",'options: colorBlendModes, optionsText: "text", optionsValue: "value", value: colorBlendMode'),B.appendChild(X);let _=document.createElement("textarea");_.setAttribute("data-bind","textInput: styleString, event: { keydown: styleEditorKeyPress }"),B.className="cesium-cesiumInspector-styleEditor",B.appendChild(_);let P=m("Compile (Ctrl+Enter)","compileStyle");B.appendChild(P);let w=document.createElement("div");w.className="cesium-cesiumInspector-error",w.setAttribute("data-bind","text: editorError"),B.appendChild(w),F.appendChild(r("Show Picked Only","showOnlyPickedTileDebugLabel")),F.appendChild(r("Geometric Error","showGeometricError")),F.appendChild(r("Rendering Statistics","showRenderingStatistics")),F.appendChild(r("Memory Usage (MB)","showMemoryUsage")),F.appendChild(r("Url","showUrl")),G.appendChild(r("Skip Tile LODs","skipLevelOfDetail"));let z=document.createElement("div");z.appendChild(d("Skip SSE Factor","skipScreenSpaceErrorFactor",1,50,1)),G.appendChild(z);let H=document.createElement("div");H.appendChild(d("SSE before skipping LOD","baseScreenSpaceError",0,4096,1)),G.appendChild(H);let nt=document.createElement("div");nt.appendChild(d("Min. levels to skip","skipLevels",0,10,1)),G.appendChild(nt),G.appendChild(r("Load only tiles that meet the max SSE.","immediatelyLoadDesiredLevelOfDetail")),G.appendChild(r("Load siblings of visible tiles","loadSiblings")),Lt.applyBindings(o,n)}Object.defineProperties(r4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});r4.prototype.isDestroyed=function(){return!1};r4.prototype.destroy=function(){return Lt.cleanNode(this._element),this._container.removeChild(this._element),this.viewModel.destroy(),At(this)};var fD=r4;var Ifa=b(W(),1);var cg="http://www.w3.org/2000/svg",b2t="http://www.w3.org/1999/xlink",d4,FD=v.fromCssColorString("rgba(247,250,255,0.384)"),c4=v.fromCssColorString("rgba(143,191,255,0.216)"),Nrt=v.fromCssColorString("rgba(153,197,255,0.098)"),m4=v.fromCssColorString("rgba(255,255,255,0.086)"),Z5e=v.fromCssColorString("rgba(255,255,255,0.267)"),R5e=v.fromCssColorString("rgba(255,255,255,0)"),Z2t=v.fromCssColorString("rgba(66,67,68,0.3)"),R2t=v.fromCssColorString("rgba(0,0,0,0.5)");function xU(t){return v.fromCssColorString(window.getComputedStyle(t).getPropertyValue("color"))}var UD={animation_pathReset:{tagName:"path",transform:"translate(16,16) scale(0.85) translate(-16,-16)",d:"M24.316,5.318,9.833,13.682,9.833,5.5,5.5,5.5,5.5,25.5,9.833,25.5,9.833,17.318,24.316,25.682z"},animation_pathPause:{tagName:"path",transform:"translate(16,16) scale(0.85) translate(-16,-16)",d:"M13,5.5,7.5,5.5,7.5,25.5,13,25.5zM24.5,5.5,19,5.5,19,25.5,24.5,25.5z"},animation_pathPlay:{tagName:"path",transform:"translate(16,16) scale(0.85) translate(-16,-16)",d:"M6.684,25.682L24.316,15.5L6.684,5.318V25.682z"},animation_pathPlayReverse:{tagName:"path",transform:"translate(16,16) scale(-0.85,0.85) translate(-16,-16)",d:"M6.684,25.682L24.316,15.5L6.684,5.318V25.682z"},animation_pathLoop:{tagName:"path",transform:"translate(16,16) scale(0.85) translate(-16,-16)",d:"M24.249,15.499c-0.009,4.832-3.918,8.741-8.75,8.75c-2.515,0-4.768-1.064-6.365-2.763l2.068-1.442l-7.901-3.703l0.744,8.694l2.193-1.529c2.244,2.594,5.562,4.242,9.26,4.242c6.767,0,12.249-5.482,12.249-12.249H24.249zM15.499,6.75c2.516,0,4.769,1.065,6.367,2.764l-2.068,1.443l7.901,3.701l-0.746-8.693l-2.192,1.529c-2.245-2.594-5.562-4.245-9.262-4.245C8.734,3.25,3.25,8.734,3.249,15.499H6.75C6.758,10.668,10.668,6.758,15.499,6.75z"},animation_pathClock:{tagName:"path",transform:"translate(16,16) scale(0.85) translate(-16,-15.5)",d:"M15.5,2.374C8.251,2.375,2.376,8.251,2.374,15.5C2.376,22.748,8.251,28.623,15.5,28.627c7.249-0.004,13.124-5.879,13.125-13.127C28.624,8.251,22.749,2.375,15.5,2.374zM15.5,25.623C9.909,25.615,5.385,21.09,5.375,15.5C5.385,9.909,9.909,5.384,15.5,5.374c5.59,0.01,10.115,4.535,10.124,10.125C25.615,21.09,21.091,25.615,15.5,25.623zM8.625,15.5c-0.001-0.552-0.448-0.999-1.001-1c-0.553,0-1,0.448-1,1c0,0.553,0.449,1,1,1C8.176,16.5,8.624,16.053,8.625,15.5zM8.179,18.572c-0.478,0.277-0.642,0.889-0.365,1.367c0.275,0.479,0.889,0.641,1.365,0.365c0.479-0.275,0.643-0.887,0.367-1.367C9.27,18.461,8.658,18.297,8.179,18.572zM9.18,10.696c-0.479-0.276-1.09-0.112-1.366,0.366s-0.111,1.09,0.365,1.366c0.479,0.276,1.09,0.113,1.367-0.366C9.821,11.584,9.657,10.973,9.18,10.696zM22.822,12.428c0.478-0.275,0.643-0.888,0.366-1.366c-0.275-0.478-0.89-0.642-1.366-0.366c-0.479,0.278-0.642,0.89-0.366,1.367C21.732,12.54,22.344,12.705,22.822,12.428zM12.062,21.455c-0.478-0.275-1.089-0.111-1.366,0.367c-0.275,0.479-0.111,1.09,0.366,1.365c0.478,0.277,1.091,0.111,1.365-0.365C12.704,22.344,12.54,21.732,12.062,21.455zM12.062,9.545c0.479-0.276,0.642-0.888,0.366-1.366c-0.276-0.478-0.888-0.642-1.366-0.366s-0.642,0.888-0.366,1.366C10.973,9.658,11.584,9.822,12.062,9.545zM22.823,18.572c-0.48-0.275-1.092-0.111-1.367,0.365c-0.275,0.479-0.112,1.092,0.367,1.367c0.477,0.275,1.089,0.113,1.365-0.365C23.464,19.461,23.3,18.848,22.823,18.572zM19.938,7.813c-0.477-0.276-1.091-0.111-1.365,0.366c-0.275,0.48-0.111,1.091,0.366,1.367s1.089,0.112,1.366-0.366C20.581,8.702,20.418,8.089,19.938,7.813zM23.378,14.5c-0.554,0.002-1.001,0.45-1.001,1c0.001,0.552,0.448,1,1.001,1c0.551,0,1-0.447,1-1C24.378,14.949,23.929,14.5,23.378,14.5zM15.501,6.624c-0.552,0-1,0.448-1,1l-0.466,7.343l-3.004,1.96c-0.478,0.277-0.642,0.889-0.365,1.365c0.275,0.479,0.889,0.643,1.365,0.367l3.305-1.676C15.39,16.99,15.444,17,15.501,17c0.828,0,1.5-0.671,1.5-1.5l-0.5-7.876C16.501,7.072,16.053,6.624,15.501,6.624zM15.501,22.377c-0.552,0-1,0.447-1,1s0.448,1,1,1s1-0.447,1-1S16.053,22.377,15.501,22.377zM18.939,21.455c-0.479,0.277-0.643,0.889-0.366,1.367c0.275,0.477,0.888,0.643,1.366,0.365c0.478-0.275,0.642-0.889,0.366-1.365C20.028,21.344,19.417,21.18,18.939,21.455z"},animation_pathWingButton:{tagName:"path",d:"m 4.5,0.5 c -2.216,0 -4,1.784 -4,4 l 0,24 c 0,2.216 1.784,4 4,4 l 13.71875,0 C 22.478584,27.272785 27.273681,22.511272 32.5,18.25 l 0,-13.75 c 0,-2.216 -1.784,-4 -4,-4 l -24,0 z"},animation_pathPointer:{tagName:"path",d:"M-15,-65,-15,-55,15,-55,15,-65,0,-95z"},animation_pathSwooshFX:{tagName:"path",d:"m 85,0 c 0,16.617 -4.813944,35.356 -13.131081,48.4508 h 6.099803 c 8.317138,-13.0948 13.13322,-28.5955 13.13322,-45.2124 0,-46.94483 -38.402714,-85.00262 -85.7743869,-85.00262 -1.0218522,0 -2.0373001,0.0241 -3.0506131,0.0589 45.958443,1.59437 82.723058,35.77285 82.723058,81.70532 z"}};function WZ(t){let e=document.createElementNS(cg,t.tagName);for(let n in t)if(t.hasOwnProperty(n)&&n!=="tagName")if(n==="children"){let i=t.children.length;for(let o=0;o<i;++o)e.appendChild(WZ(t.children[o]))}else n.indexOf("xlink:")===0?e.setAttributeNS(b2t,n.substring(6),t[n]):n==="textContent"?e.textContent=t[n]:e.setAttribute(n,t[n]);return e}function yrt(t,e,n){let i=document.createElementNS(cg,"text");i.setAttribute("x",t),i.setAttribute("y",e),i.setAttribute("class","cesium-animation-svgText");let o=document.createElementNS(cg,"tspan");return o.textContent=n,i.appendChild(o),i}function b5e(t,e,n){t.setAttribute("transform",`translate(100,100) rotate(${n})`),e.setAttribute("transform",`rotate(${n})`)}var h4=new v;function Il(t,e){let n=e.alpha,i=1-n;return h4.red=t.red*i+e.red*n,h4.green=t.green*i+e.green*n,h4.blue=t.blue*i+e.blue*n,h4.toCssColorString()}function Brt(t,e,n){let i=UD[n],o={tagName:"g",class:"cesium-animation-rectButton",transform:`translate(${t},${e})`,children:[{tagName:"rect",class:"cesium-animation-buttonGlow",width:32,height:32,rx:2,ry:2},{tagName:"rect",class:"cesium-animation-buttonMain",width:32,height:32,rx:4,ry:4},{class:"cesium-animation-buttonPath",id:n,tagName:i.tagName,transform:i.transform,d:i.d},{tagName:"title",textContent:""}]};return WZ(o)}function W5e(t,e,n){let i=UD[n],o=UD.animation_pathWingButton,a={tagName:"g",class:"cesium-animation-rectButton",transform:`translate(${t},${e})`,children:[{class:"cesium-animation-buttonGlow",id:"animation_pathWingButton",tagName:o.tagName,d:o.d},{class:"cesium-animation-buttonMain",id:"animation_pathWingButton",tagName:o.tagName,d:o.d},{class:"cesium-animation-buttonPath",id:n,tagName:i.tagName,transform:i.transform,d:i.d},{tagName:"title",textContent:""}]};return WZ(a)}function f5e(t,e){let n=t._viewModel,i=n.shuttleRingDragging;if(!(i&&d4!==t))if(e.type==="mousedown"||i&&e.type==="mousemove"||e.type==="touchstart"&&e.touches.length===1||i&&e.type==="touchmove"&&e.touches.length===1){let o=t._centerX,a=t._centerY,l=t._svgNode.getBoundingClientRect(),r,d;if(e.type==="touchstart"||e.type==="touchmove"?(r=e.touches[0].clientX,d=e.touches[0].clientY):(r=e.clientX,d=e.clientY),!i&&(r>l.right||r<l.left||d<l.top||d>l.bottom))return;let m=t._shuttleRingPointer.getBoundingClientRect(),h=r-o-l.left,u=d-a-l.top,R=Math.atan2(u,h)*180/Math.PI+90;R>180&&(R-=360);let V=n.shuttleRingAngle;i||r<m.right&&r>m.left&&d>m.top&&d<m.bottom?(d4=t,n.shuttleRingDragging=!0,n.shuttleRingAngle=R):R<V?n.slower():R>V&&n.faster(),e.preventDefault()}else t===d4&&(d4=void 0),n.shuttleRingDragging=!1}function yW(t,e){this._viewModel=e,this.svgElement=t,this._enabled=void 0,this._toggled=void 0;let n=this;this._clickFunction=function(){let i=n._viewModel.command;i.canExecute&&i()},t.addEventListener("click",this._clickFunction,!0),this._subscriptions=[od(e,"toggled",this.setToggled,this),od(e,"tooltip",this.setTooltip,this),od(e.command,"canExecute",this.setEnabled,this)]}yW.prototype.destroy=function(){this.svgElement.removeEventListener("click",this._clickFunction,!0);let t=this._subscriptions;for(let e=0,n=t.length;e<n;e++)t[e].dispose();At(this)};yW.prototype.isDestroyed=function(){return!1};yW.prototype.setEnabled=function(t){if(this._enabled!==t){if(this._enabled=t,!t){this.svgElement.setAttribute("class","cesium-animation-buttonDisabled");return}if(this._toggled){this.svgElement.setAttribute("class","cesium-animation-rectButton cesium-animation-buttonToggled");return}this.svgElement.setAttribute("class","cesium-animation-rectButton")}};yW.prototype.setToggled=function(t){this._toggled!==t&&(this._toggled=t,this._enabled&&(t?this.svgElement.setAttribute("class","cesium-animation-rectButton cesium-animation-buttonToggled"):this.svgElement.setAttribute("class","cesium-animation-rectButton")))};yW.prototype.setTooltip=function(t){this.svgElement.getElementsByTagName("title")[0].textContent=t};function GN(t,e){t=Ui(t),this._viewModel=e,this._container=t,this._centerX=0,this._centerY=0,this._defsElement=void 0,this._svgNode=void 0,this._topG=void 0,this._lastHeight=void 0,this._lastWidth=void 0;let n=t.ownerDocument,i=document.createElement("style");i.textContent=".cesium-animation-rectButton .cesium-animation-buttonGlow { filter: url(#animation_blurred); }.cesium-animation-rectButton .cesium-animation-buttonMain { fill: url(#animation_buttonNormal); }.cesium-animation-buttonToggled .cesium-animation-buttonMain { fill: url(#animation_buttonToggled); }.cesium-animation-rectButton:hover .cesium-animation-buttonMain { fill: url(#animation_buttonHovered); }.cesium-animation-buttonDisabled .cesium-animation-buttonMain { fill: url(#animation_buttonDisabled); }.cesium-animation-shuttleRingG .cesium-animation-shuttleRingSwoosh { fill: url(#animation_shuttleRingSwooshGradient); }.cesium-animation-shuttleRingG:hover .cesium-animation-shuttleRingSwoosh { fill: url(#animation_shuttleRingSwooshHovered); }.cesium-animation-shuttleRingPointer { fill: url(#animation_shuttleRingPointerGradient); }.cesium-animation-shuttleRingPausePointer { fill: url(#animation_shuttleRingPointerPaused); }.cesium-animation-knobOuter { fill: url(#animation_knobOuter); }.cesium-animation-knobInner { fill: url(#animation_knobInner); }",n.head.insertBefore(i,n.head.childNodes[0]);let o=document.createElement("div");o.className="cesium-animation-theme",o.innerHTML='<div class="cesium-animation-themeNormal"></div><div class="cesium-animation-themeHover"></div><div class="cesium-animation-themeSelect"></div><div class="cesium-animation-themeDisabled"></div><div class="cesium-animation-themeKnob"></div><div class="cesium-animation-themePointer"></div><div class="cesium-animation-themeSwoosh"></div><div class="cesium-animation-themeSwooshHover"></div>',this._theme=o,this._themeNormal=o.childNodes[0],this._themeHover=o.childNodes[1],this._themeSelect=o.childNodes[2],this._themeDisabled=o.childNodes[3],this._themeKnob=o.childNodes[4],this._themePointer=o.childNodes[5],this._themeSwoosh=o.childNodes[6],this._themeSwooshHover=o.childNodes[7];let a=document.createElementNS(cg,"svg:svg");this._svgNode=a,a.setAttributeNS("http://www.w3.org/2000/xmlns/","xmlns:xlink",b2t);let s=document.createElementNS(cg,"g");this._topG=s,this._realtimeSVG=new yW(W5e(3,4,"animation_pathClock"),e.playRealtimeViewModel),this._playReverseSVG=new yW(Brt(44,99,"animation_pathPlayReverse"),e.playReverseViewModel),this._playForwardSVG=new yW(Brt(124,99,"animation_pathPlay"),e.playForwardViewModel),this._pauseSVG=new yW(Brt(84,99,"animation_pathPause"),e.pauseViewModel);let l=document.createElementNS(cg,"g");l.appendChild(this._realtimeSVG.svgElement),l.appendChild(this._playReverseSVG.svgElement),l.appendChild(this._playForwardSVG.svgElement),l.appendChild(this._pauseSVG.svgElement);let r=WZ({tagName:"circle",class:"cesium-animation-shuttleRingBack",cx:100,cy:100,r:99});this._shuttleRingBackPanel=r;let d=UD.animation_pathSwooshFX,m=UD.animation_pathPointer,h=WZ({tagName:"g",class:"cesium-animation-shuttleRingSwoosh",children:[{tagName:d.tagName,transform:"translate(100,97) scale(-1,1)",id:"animation_pathSwooshFX",d:d.d},{tagName:d.tagName,transform:"translate(100,97)",id:"animation_pathSwooshFX",d:d.d},{tagName:"line",x1:100,y1:8,x2:100,y2:22}]});this._shuttleRingSwooshG=h,this._shuttleRingPointer=WZ({class:"cesium-animation-shuttleRingPointer",id:"animation_pathPointer",tagName:m.tagName,d:m.d});let u=WZ({tagName:"g",transform:"translate(100,100)"});this._knobOuter=WZ({tagName:"circle",class:"cesium-animation-knobOuter",cx:0,cy:0,r:71});let R=61,V=WZ({tagName:"circle",class:"cesium-animation-knobInner",cx:0,cy:0,r:R});this._knobDate=yrt(0,-24,""),this._knobTime=yrt(0,-7,""),this._knobStatus=yrt(0,-41,"");let F=WZ({tagName:"circle",class:"cesium-animation-blank",cx:0,cy:0,r:R}),U=document.createElementNS(cg,"g");U.setAttribute("class","cesium-animation-shuttleRingG"),t.appendChild(o),s.appendChild(U),s.appendChild(u),s.appendChild(l),U.appendChild(r),U.appendChild(h),U.appendChild(this._shuttleRingPointer),u.appendChild(this._knobOuter),u.appendChild(V),u.appendChild(this._knobDate),u.appendChild(this._knobTime),u.appendChild(this._knobStatus),u.appendChild(F),a.appendChild(s),t.appendChild(a);let G=this;function A(Y){f5e(G,Y)}this._mouseCallback=A,r.addEventListener("mousedown",A,!0),r.addEventListener("touchstart",A,!0),h.addEventListener("mousedown",A,!0),h.addEventListener("touchstart",A,!0),n.addEventListener("mousemove",A,!0),n.addEventListener("touchmove",A,!0),n.addEventListener("mouseup",A,!0),n.addEventListener("touchend",A,!0),n.addEventListener("touchcancel",A,!0),this._shuttleRingPointer.addEventListener("mousedown",A,!0),this._shuttleRingPointer.addEventListener("touchstart",A,!0),this._knobOuter.addEventListener("mousedown",A,!0),this._knobOuter.addEventListener("touchstart",A,!0);let S=this._knobTime.childNodes[0],g=this._knobDate.childNodes[0],C=this._knobStatus.childNodes[0],y;this._subscriptions=[od(e.pauseViewModel,"toggled",function(Y){y!==Y&&(y=Y,y?G._shuttleRingPointer.setAttribute("class","cesium-animation-shuttleRingPausePointer"):G._shuttleRingPointer.setAttribute("class","cesium-animation-shuttleRingPointer"))}),od(e,"shuttleRingAngle",function(Y){b5e(G._shuttleRingPointer,G._knobOuter,Y)}),od(e,"dateLabel",function(Y){g.textContent!==Y&&(g.textContent=Y)}),od(e,"timeLabel",function(Y){S.textContent!==Y&&(S.textContent=Y)}),od(e,"multiplierLabel",function(Y){C.textContent!==Y&&(C.textContent=Y)})],this.applyThemeChanges(),this.resize()}Object.defineProperties(GN.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});GN.prototype.isDestroyed=function(){return!1};GN.prototype.destroy=function(){c(this._observer)&&(this._observer.disconnect(),this._observer=void 0);let t=this._container.ownerDocument,e=this._mouseCallback;this._shuttleRingBackPanel.removeEventListener("mousedown",e,!0),this._shuttleRingBackPanel.removeEventListener("touchstart",e,!0),this._shuttleRingSwooshG.removeEventListener("mousedown",e,!0),this._shuttleRingSwooshG.removeEventListener("touchstart",e,!0),t.removeEventListener("mousemove",e,!0),t.removeEventListener("touchmove",e,!0),t.removeEventListener("mouseup",e,!0),t.removeEventListener("touchend",e,!0),t.removeEventListener("touchcancel",e,!0),this._shuttleRingPointer.removeEventListener("mousedown",e,!0),this._shuttleRingPointer.removeEventListener("touchstart",e,!0),this._knobOuter.removeEventListener("mousedown",e,!0),this._knobOuter.removeEventListener("touchstart",e,!0),this._container.removeChild(this._svgNode),this._container.removeChild(this._theme),this._realtimeSVG.destroy(),this._playReverseSVG.destroy(),this._playForwardSVG.destroy(),this._pauseSVG.destroy();let n=this._subscriptions;for(let i=0,o=n.length;i<o;i++)n[i].dispose();return At(this)};GN.prototype.resize=function(){let t=this._container.clientWidth,e=this._container.clientHeight;if(t===this._lastWidth&&e===this._lastHeight)return;let n=this._svgNode,i=200,o=132,a=t,s=e;t===0&&e===0?(a=i,s=o):t===0?(s=e,a=i*(e/o)):e===0&&(a=t,s=o*(t/i));let l=a/i,r=s/o;n.style.cssText=`width: ${a}px; height: ${s}px; position: absolute; bottom: 0; left: 0; overflow: hidden;`,n.setAttribute("width",a),n.setAttribute("height",s),n.setAttribute("viewBox",`0 0 ${a} ${s}`),this._topG.setAttribute("transform",`scale(${l},${r})`),this._centerX=Math.max(1,100*l),this._centerY=Math.max(1,100*r),this._lastHeight=t,this._lastWidth=e};GN.prototype.applyThemeChanges=function(){let t=this._container.ownerDocument;if(!t.body.contains(this._container)){if(c(this._observer))return;let m=this;m._observer=new MutationObserver(function(){t.body.contains(m._container)&&(m._observer.disconnect(),m._observer=void 0,m.applyThemeChanges())}),m._observer.observe(t,{childList:!0,subtree:!0});return}let e=xU(this._themeNormal),n=xU(this._themeHover),i=xU(this._themeSelect),o=xU(this._themeDisabled),a=xU(this._themeKnob),s=xU(this._themePointer),l=xU(this._themeSwoosh),r=xU(this._themeSwooshHover),d=WZ({tagName:"defs",children:[{id:"animation_buttonNormal",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-color":Il(e,FD)},{tagName:"stop",offset:"12%","stop-color":Il(e,c4)},{tagName:"stop",offset:"46%","stop-color":Il(e,Nrt)},{tagName:"stop",offset:"81%","stop-color":Il(e,m4)}]},{id:"animation_buttonHovered",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-color":Il(n,FD)},{tagName:"stop",offset:"12%","stop-color":Il(n,c4)},{tagName:"stop",offset:"46%","stop-color":Il(n,Nrt)},{tagName:"stop",offset:"81%","stop-color":Il(n,m4)}]},{id:"animation_buttonToggled",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-color":Il(i,FD)},{tagName:"stop",offset:"12%","stop-color":Il(i,c4)},{tagName:"stop",offset:"46%","stop-color":Il(i,Nrt)},{tagName:"stop",offset:"81%","stop-color":Il(i,m4)}]},{id:"animation_buttonDisabled",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-color":Il(o,Z5e)},{tagName:"stop",offset:"75%","stop-color":Il(o,R5e)}]},{id:"animation_blurred",tagName:"filter",width:"200%",height:"200%",x:"-50%",y:"-50%",children:[{tagName:"feGaussianBlur",stdDeviation:4,in:"SourceGraphic"}]},{id:"animation_shuttleRingSwooshGradient",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-opacity":.2,"stop-color":l.toCssColorString()},{tagName:"stop",offset:"85%","stop-opacity":.85,"stop-color":l.toCssColorString()},{tagName:"stop",offset:"95%","stop-opacity":.05,"stop-color":l.toCssColorString()}]},{id:"animation_shuttleRingSwooshHovered",tagName:"linearGradient",x1:"50%",y1:"0%",x2:"50%",y2:"100%",children:[{tagName:"stop",offset:"0%","stop-opacity":.2,"stop-color":r.toCssColorString()},{tagName:"stop",offset:"85%","stop-opacity":.85,"stop-color":r.toCssColorString()},{tagName:"stop",offset:"95%","stop-opacity":.05,"stop-color":r.toCssColorString()}]},{id:"animation_shuttleRingPointerGradient",tagName:"linearGradient",x1:"0%",y1:"50%",x2:"100%",y2:"50%",children:[{tagName:"stop",offset:"0%","stop-color":s.toCssColorString()},{tagName:"stop",offset:"40%","stop-color":s.toCssColorString()},{tagName:"stop",offset:"60%","stop-color":Il(s,R2t)},{tagName:"stop",offset:"100%","stop-color":Il(s,R2t)}]},{id:"animation_shuttleRingPointerPaused",tagName:"linearGradient",x1:"0%",y1:"50%",x2:"100%",y2:"50%",children:[{tagName:"stop",offset:"0%","stop-color":"#CCC"},{tagName:"stop",offset:"40%","stop-color":"#CCC"},{tagName:"stop",offset:"60%","stop-color":"#555"},{tagName:"stop",offset:"100%","stop-color":"#555"}]},{id:"animation_knobOuter",tagName:"linearGradient",x1:"20%",y1:"0%",x2:"90%",y2:"100%",children:[{tagName:"stop",offset:"5%","stop-color":Il(a,FD)},{tagName:"stop",offset:"60%","stop-color":Il(a,Z2t)},{tagName:"stop",offset:"85%","stop-color":Il(a,c4)}]},{id:"animation_knobInner",tagName:"linearGradient",x1:"20%",y1:"0%",x2:"90%",y2:"100%",children:[{tagName:"stop",offset:"5%","stop-color":Il(a,Z2t)},{tagName:"stop",offset:"60%","stop-color":Il(a,FD)},{tagName:"stop",offset:"85%","stop-color":Il(a,m4)}]}]});c(this._defsElement)?this._svgNode.replaceChild(d,this._defsElement):this._svgNode.appendChild(d),this._defsElement=d};var GD=GN;var Xfa=b(W(),1);var F5e=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],XU=15,AN=105;function W2t(t,e){return t-e}function Qrt(t,e){let n=Ja(e,t,W2t);return n<0?~n:n}function U5e(t,e){if(Math.abs(t)<=XU)return t/XU;let n=XU,i=AN,o,a=0,s;return t>0?(o=Math.log(e[e.length-1]),s=(o-a)/(i-n),Math.exp(a+s*(t-n))):(o=Math.log(-e[0]),s=(o-a)/(i-n),-Math.exp(a+s*(Math.abs(t)-n)))}function G5e(t,e,n){if(n.clockStep===ya.SYSTEM_CLOCK)return XU;if(Math.abs(t)<=1)return t*XU;let i=e[e.length-1];t>i?t=i:t<-i&&(t=-i);let o=XU,a=AN,s,l=0,r;return t>0?(s=Math.log(i),r=(s-l)/(a-o),(Math.log(t)-l)/r+o):(s=Math.log(-e[0]),r=(s-l)/(a-o),-((Math.log(Math.abs(t))-l)/r+o))}function kV(t){let e=this;this._clockViewModel=t,this._allShuttleRingTicks=[],this._dateFormatter=kV.defaultDateFormatter,this._timeFormatter=kV.defaultTimeFormatter,this.shuttleRingDragging=!1,this.snapToTicks=!1,Lt.track(this,["_allShuttleRingTicks","_dateFormatter","_timeFormatter","shuttleRingDragging","snapToTicks"]),this._sortedFilteredPositiveTicks=[],this.setShuttleRingTicks(kV.defaultTicks),this.timeLabel=void 0,Lt.defineProperty(this,"timeLabel",function(){return e._timeFormatter(e._clockViewModel.currentTime,e)}),this.dateLabel=void 0,Lt.defineProperty(this,"dateLabel",function(){return e._dateFormatter(e._clockViewModel.currentTime,e)}),this.multiplierLabel=void 0,Lt.defineProperty(this,"multiplierLabel",function(){let s=e._clockViewModel;if(s.clockStep===ya.SYSTEM_CLOCK)return"Today";let l=s.multiplier;return l%1===0?`${l.toFixed(0)}x`:`${l.toFixed(3).replace(/0{0,3}$/,"")}x`}),this.shuttleRingAngle=void 0,Lt.defineProperty(this,"shuttleRingAngle",{get:function(){return G5e(t.multiplier,e._allShuttleRingTicks,t)},set:function(s){s=Math.max(Math.min(s,AN),-AN);let l=e._allShuttleRingTicks,r=e._clockViewModel;if(r.clockStep=ya.SYSTEM_CLOCK_MULTIPLIER,Math.abs(s)===AN){r.multiplier=s>0?l[l.length-1]:l[0];return}let d=U5e(s,l);if(e.snapToTicks)d=l[Qrt(d,l)];else if(d!==0){let m=Math.abs(d);if(m>100){let h=m.toFixed(0).length-2,u=Math.pow(10,h);d=Math.round(d/u)*u|0}else m>XU?d=Math.round(d):m>1?d=+d.toFixed(1):m>0&&(d=+d.toFixed(2))}r.multiplier=d}}),this._canAnimate=void 0,Lt.defineProperty(this,"_canAnimate",function(){let s=e._clockViewModel,l=s.clockRange;if(e.shuttleRingDragging||l===pl.UNBOUNDED)return!0;let r=s.multiplier,d=s.currentTime,m=s.startTime,h=!1;if(l===pl.LOOP_STOP)h=rt.greaterThan(d,m)||d.equals(m)&&r>0;else{let u=s.stopTime;h=rt.greaterThan(d,m)&&rt.lessThan(d,u)||d.equals(m)&&r>0||d.equals(u)&&r<0}return h||(s.shouldAnimate=!1),h}),this._isSystemTimeAvailable=void 0,Lt.defineProperty(this,"_isSystemTimeAvailable",function(){let s=e._clockViewModel;if(s.clockRange===pl.UNBOUNDED)return!0;let r=s.systemTime;return rt.greaterThanOrEquals(r,s.startTime)&&rt.lessThanOrEquals(r,s.stopTime)}),this._isAnimating=void 0,Lt.defineProperty(this,"_isAnimating",function(){return e._clockViewModel.shouldAnimate&&(e._canAnimate||e.shuttleRingDragging)});let n=Ri(function(){let s=e._clockViewModel;s.shouldAnimate?s.shouldAnimate=!1:e._canAnimate&&(s.shouldAnimate=!0)});this._pauseViewModel=new YU(n,{toggled:Lt.computed(function(){return!e._isAnimating}),tooltip:"Pause"});let i=Ri(function(){let s=e._clockViewModel,l=s.multiplier;l>0&&(s.multiplier=-l),s.shouldAnimate=!0});this._playReverseViewModel=new YU(i,{toggled:Lt.computed(function(){return e._isAnimating&&t.multiplier<0}),tooltip:"Play Reverse"});let o=Ri(function(){let s=e._clockViewModel,l=s.multiplier;l<0&&(s.multiplier=-l),s.shouldAnimate=!0});this._playForwardViewModel=new YU(o,{toggled:Lt.computed(function(){return e._isAnimating&&t.multiplier>0&&t.clockStep!==ya.SYSTEM_CLOCK}),tooltip:"Play Forward"});let a=Ri(function(){e._clockViewModel.clockStep=ya.SYSTEM_CLOCK},Lt.getObservable(this,"_isSystemTimeAvailable"));this._playRealtimeViewModel=new YU(a,{toggled:Lt.computed(function(){return t.clockStep===ya.SYSTEM_CLOCK}),tooltip:Lt.computed(function(){return e._isSystemTimeAvailable?"Today (real-time)":"Current time not in range"})}),this._slower=Ri(function(){let s=e._clockViewModel,l=e._allShuttleRingTicks,r=s.multiplier,d=Qrt(r,l)-1;d>=0&&(s.multiplier=l[d])}),this._faster=Ri(function(){let s=e._clockViewModel,l=e._allShuttleRingTicks,r=s.multiplier,d=Qrt(r,l)+1;d<l.length&&(s.multiplier=l[d])})}kV.defaultDateFormatter=function(t,e){let n=rt.toGregorianDate(t);return`${F5e[n.month-1]} ${n.day} ${n.year}`};kV.defaultTicks=[.001,.002,.005,.01,.02,.05,.1,.25,.5,1,2,5,10,15,30,60,120,300,600,900,1800,3600,7200,14400,21600,43200,86400,172800,345600,604800];kV.defaultTimeFormatter=function(t,e){let n=rt.toGregorianDate(t),i=Math.round(n.millisecond);return Math.abs(e._clockViewModel.multiplier)<1?`${n.hour.toString().padStart(2,"0")}:${n.minute.toString().padStart(2,"0")}:${n.second.toString().padStart(2,"0")}.${i.toString().padStart(3,"0")}`:`${n.hour.toString().padStart(2,"0")}:${n.minute.toString().padStart(2,"0")}:${n.second.toString().padStart(2,"0")} UTC`};kV.prototype.getShuttleRingTicks=function(){return this._sortedFilteredPositiveTicks.slice(0)};kV.prototype.setShuttleRingTicks=function(t){let e,n,i,o={},a=this._sortedFilteredPositiveTicks;for(a.length=0,e=0,n=t.length;e<n;++e)i=t[e],o.hasOwnProperty(i)||(o[i]=!0,a.push(i));a.sort(W2t);let s=[];for(n=a.length,e=n-1;e>=0;--e)i=a[e],i!==0&&s.push(-i);Array.prototype.push.apply(s,a),this._allShuttleRingTicks=s};Object.defineProperties(kV.prototype,{slower:{get:function(){return this._slower}},faster:{get:function(){return this._faster}},clockViewModel:{get:function(){return this._clockViewModel}},pauseViewModel:{get:function(){return this._pauseViewModel}},playReverseViewModel:{get:function(){return this._playReverseViewModel}},playForwardViewModel:{get:function(){return this._playForwardViewModel}},playRealtimeViewModel:{get:function(){return this._playRealtimeViewModel}},dateFormatter:{get:function(){return this._dateFormatter},set:function(t){this._dateFormatter=t}},timeFormatter:{get:function(){return this._timeFormatter},set:function(t){this._timeFormatter=t}}});kV._maxShuttleRingAngle=AN;kV._realtimeShuttleRingAngle=XU;var AD=kV;var jfa=b(W(),1);var Ofa=b(W(),1);function f2t(t){t=f(t,f.EMPTY_OBJECT);let e=t.globe,n=f(t.imageryProviderViewModels,[]),i=f(t.terrainProviderViewModels,[]);this._globe=e,this.imageryProviderViewModels=n.slice(0),this.terrainProviderViewModels=i.slice(0),this.dropDownVisible=!1,Lt.track(this,["imageryProviderViewModels","terrainProviderViewModels","dropDownVisible"]);let o=Lt.getObservable(this,"imageryProviderViewModels"),a=Lt.pureComputed(function(){let h=o(),u={},R;for(R=0;R<h.length;R++){let U=h[R],G=U.category;c(u[G])?u[G].push(U):u[G]=[U]}let V=Object.keys(u),F=[];for(R=0;R<V.length;R++){let U=V[R];F.push({name:U,providers:u[U]})}return F});this._imageryProviders=a;let s=Lt.getObservable(this,"terrainProviderViewModels"),l=Lt.pureComputed(function(){let h=s(),u={},R;for(R=0;R<h.length;R++){let U=h[R],G=U.category;c(u[G])?u[G].push(U):u[G]=[U]}let V=Object.keys(u),F=[];for(R=0;R<V.length;R++){let U=V[R];F.push({name:U,providers:u[U]})}return F});this._terrainProviders=l,this.buttonTooltip=void 0,Lt.defineProperty(this,"buttonTooltip",function(){let h=this.selectedImagery,u=this.selectedTerrain,R=c(h)?h.name:void 0,V=c(u)?u.name:void 0;return c(R)&&c(V)?`${R} +${V}`:c(R)?R:V}),this.buttonImageUrl=void 0,Lt.defineProperty(this,"buttonImageUrl",function(){let h=this.selectedImagery;if(c(h))return h.iconUrl}),this.selectedImagery=void 0;let r=Lt.observable();this._currentImageryLayers=[],Lt.defineProperty(this,"selectedImagery",{get:function(){return r()},set:function(h){if(r()===h){this.dropDownVisible=!1;return}let u,R=this._currentImageryLayers,V=R.length,F=this._globe.imageryLayers,U=!1;for(u=0;u<V;u++){let G=F.length;for(let A=0;A<G;A++){let S=F.get(A);if(S===R[u]){F.remove(S),U=!0;break}}}if(c(h)){let G=h.creationCommand();if(Array.isArray(G)){let A=G.length;for(this._currentImageryLayers=[],u=A-1;u>=0;u--){let S=$r.fromProviderAsync(G[u]);F.add(S,0),this._currentImageryLayers.push(S)}}else{this._currentImageryLayers=[];let A=$r.fromProviderAsync(G);if(A.name=h.name,U)F.add(A,0);else{let S=F.get(0);c(S)&&F.remove(S),F.add(A,0)}this._currentImageryLayers.push(A)}}r(h),this.dropDownVisible=!1}}),this.selectedTerrain=void 0;let d=Lt.observable();Lt.defineProperty(this,"selectedTerrain",{get:function(){return d()},set:function(h){if(d()===h){this.dropDownVisible=!1;return}let u;if(c(h)&&(u=h.creationCommand()),c(u)&&!c(u.then))this._globe.depthTestAgainstTerrain=!(u instanceof bV),this._globe.terrainProvider=u;else if(c(u)){let R=!1,V=this._globe.terrainProviderChanged.addEventListener(()=>{R=!0,V()}),U=new lD(u).readyEvent.addEventListener(G=>{R||(this._globe.depthTestAgainstTerrain=!(G instanceof bV),this._globe.terrainProvider=G,U())})}d(h),this.dropDownVisible=!1}});let m=this;this._toggleDropDown=Ri(function(){m.dropDownVisible=!m.dropDownVisible}),this.selectedImagery=f(t.selectedImageryProviderViewModel,n[0]),this.selectedTerrain=f(t.selectedTerrainProviderViewModel,i[0])}Object.defineProperties(f2t.prototype,{toggleDropDown:{get:function(){return this._toggleDropDown}},globe:{get:function(){return this._globe}}});var SD=f2t;function p4(t,e){t=Ui(t);let n=new SD(e),i=document.createElement("button");i.type="button",i.className="cesium-button cesium-toolbar-button",i.setAttribute("data-bind","attr: { title: buttonTooltip },click: toggleDropDown"),t.appendChild(i);let o=document.createElement("img");o.setAttribute("draggable","false"),o.className="cesium-baseLayerPicker-selected",o.setAttribute("data-bind","attr: { src: buttonImageUrl }, visible: !!buttonImageUrl"),i.appendChild(o);let a=document.createElement("div");a.className="cesium-baseLayerPicker-dropDown",a.setAttribute("data-bind",'css: { "cesium-baseLayerPicker-dropDown-visible" : dropDownVisible }'),t.appendChild(a);let s=document.createElement("div");s.className="cesium-baseLayerPicker-sectionTitle",s.setAttribute("data-bind","visible: imageryProviderViewModels.length > 0"),s.innerHTML="Imagery",a.appendChild(s);let l=document.createElement("div");l.className="cesium-baseLayerPicker-section",l.setAttribute("data-bind","foreach: _imageryProviders"),a.appendChild(l);let r=document.createElement("div");r.className="cesium-baseLayerPicker-category",l.appendChild(r);let d=document.createElement("div");d.className="cesium-baseLayerPicker-categoryTitle",d.setAttribute("data-bind","text: name"),r.appendChild(d);let m=document.createElement("div");m.className="cesium-baseLayerPicker-choices",m.setAttribute("data-bind","foreach: providers"),r.appendChild(m);let h=document.createElement("div");h.className="cesium-baseLayerPicker-item",h.setAttribute("data-bind",'css: { "cesium-baseLayerPicker-selectedItem" : $data === $parents[1].selectedImagery },attr: { title: tooltip },visible: creationCommand.canExecute,click: function($data) { $parents[1].selectedImagery = $data; }'),m.appendChild(h);let u=document.createElement("img");u.className="cesium-baseLayerPicker-itemIcon",u.setAttribute("data-bind","attr: { src: iconUrl }"),u.setAttribute("draggable","false"),h.appendChild(u);let R=document.createElement("div");R.className="cesium-baseLayerPicker-itemLabel",R.setAttribute("data-bind","text: name"),h.appendChild(R);let V=document.createElement("div");V.className="cesium-baseLayerPicker-sectionTitle",V.setAttribute("data-bind","visible: terrainProviderViewModels.length > 0"),V.innerHTML="Terrain",a.appendChild(V);let F=document.createElement("div");F.className="cesium-baseLayerPicker-section",F.setAttribute("data-bind","foreach: _terrainProviders"),a.appendChild(F);let U=document.createElement("div");U.className="cesium-baseLayerPicker-category",F.appendChild(U);let G=document.createElement("div");G.className="cesium-baseLayerPicker-categoryTitle",G.setAttribute("data-bind","text: name"),U.appendChild(G);let A=document.createElement("div");A.className="cesium-baseLayerPicker-choices",A.setAttribute("data-bind","foreach: providers"),U.appendChild(A);let S=document.createElement("div");S.className="cesium-baseLayerPicker-item",S.setAttribute("data-bind",'css: { "cesium-baseLayerPicker-selectedItem" : $data === $parents[1].selectedTerrain },attr: { title: tooltip },visible: creationCommand.canExecute,click: function($data) { $parents[1].selectedTerrain = $data; }'),A.appendChild(S);let g=document.createElement("img");g.className="cesium-baseLayerPicker-itemIcon",g.setAttribute("data-bind","attr: { src: iconUrl }"),g.setAttribute("draggable","false"),S.appendChild(g);let C=document.createElement("div");C.className="cesium-baseLayerPicker-itemLabel",C.setAttribute("data-bind","text: name"),S.appendChild(C),Lt.applyBindings(n,i),Lt.applyBindings(n,a),this._viewModel=n,this._container=t,this._element=i,this._dropPanel=a,this._closeDropDown=function(y){i.contains(y.target)||a.contains(y.target)||(n.dropDownVisible=!1)},In.supportsPointerEvents()?document.addEventListener("pointerdown",this._closeDropDown,!0):(document.addEventListener("mousedown",this._closeDropDown,!0),document.addEventListener("touchstart",this._closeDropDown,!0))}Object.defineProperties(p4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});p4.prototype.isDestroyed=function(){return!1};p4.prototype.destroy=function(){return In.supportsPointerEvents()?document.removeEventListener("pointerdown",this._closeDropDown,!0):(document.removeEventListener("mousedown",this._closeDropDown,!0),document.removeEventListener("touchstart",this._closeDropDown,!0)),Lt.cleanNode(this._element),Lt.cleanNode(this._dropPanel),this._container.removeChild(this._element),this._container.removeChild(this._dropPanel),At(this)};var TD=p4;var iFa=b(W(),1);function F2t(t){let e=t.creationFunction;c(e.canExecute)||(e=Ri(e)),this._creationCommand=e,this.name=t.name,this.tooltip=t.tooltip,this.iconUrl=t.iconUrl,this._category=f(t.category,""),Lt.track(this,["name","tooltip","iconUrl"])}Object.defineProperties(F2t.prototype,{creationCommand:{get:function(){return this._creationCommand}},category:{get:function(){return this._category}}});var Nl=F2t;var lFa=b(W(),1);function A5e(){let t=[],e=devicePixelRatio>=2;return t.push(new Nl({name:"Bing Maps Aerial",iconUrl:Dn("Widgets/Images/ImageryProviders/bingAerial.png"),tooltip:"Bing Maps aerial imagery, provided by Cesium ion",category:"Cesium ion",creationFunction:function(){return pW({style:hW.AERIAL})}})),t.push(new Nl({name:"Bing Maps Aerial with Labels",iconUrl:Dn("Widgets/Images/ImageryProviders/bingAerialLabels.png"),tooltip:"Bing Maps aerial imagery with labels, provided by Cesium ion",category:"Cesium ion",creationFunction:function(){return pW({style:hW.AERIAL_WITH_LABELS})}})),t.push(new Nl({name:"Bing Maps Roads",iconUrl:Dn("Widgets/Images/ImageryProviders/bingRoads.png"),tooltip:"Bing Maps standard road maps, provided by Cesium ion",category:"Cesium ion",creationFunction:function(){return pW({style:hW.ROAD})}})),t.push(new Nl({name:"ArcGIS World Imagery",iconUrl:Dn("Widgets/Images/ImageryProviders/ArcGisMapServiceWorldImagery.png"),tooltip:`ArcGIS World Imagery provides one meter or better satellite and aerial imagery in many parts of the world and lower resolution satellite imagery worldwide. The map includes 15m TerraColor imagery at small and mid-scales (~1:591M down to ~1:288k) for the world. The map features Maxar imagery at 0.3m resolution for select metropolitan areas around the world, 0.5m resolution across the United States and parts of Western Europe, and 1m resolution imagery across the rest of the world. In addition to commercial sources, the World Imagery map features high-resolution aerial photography contributed by the GIS User Community. This imagery ranges from 0.3m to 0.03m resolution (down to ~1:280 nin select communities). For more information on this map, including the terms of use, visit us online at +https://www.arcgis.com/home/item.html?id=10df2279f9684e4a9f6a7f08febac2a9`,category:"Other",creationFunction:function(){return cW.fromBasemapType(oZ.SATELLITE,{enablePickFeatures:!1})}})),t.push(new Nl({name:"ArcGIS World Hillshade",iconUrl:Dn("Widgets/Images/ImageryProviders/ArcGisMapServiceWorldHillshade.png"),tooltip:`ArcGIS World Hillshade map portrays elevation as an artistic hillshade. This map is designed to be used as a backdrop for topographical, soil, hydro, landcover or other outdoor recreational maps. The map was compiled from a variety of sources from several data providers. The basemap has global coverage down to a scale of ~1:72k. In select areas of the United States and Europe, coverage is available down to ~1:9k. For more information on this map, including the terms of use, visit us online at +https://www.arcgis.com/home/item.html?id=1b243539f4514b6ba35e7d995890db1d`,category:"Other",creationFunction:function(){return cW.fromBasemapType(oZ.HILLSHADE,{enablePickFeatures:!1})}})),t.push(new Nl({name:"Esri World Ocean",iconUrl:Dn("Widgets/Images/ImageryProviders/ArcGisMapServiceWorldOcean.png"),tooltip:`ArcGIS World Ocean map is designed to be used as a base map by marine GIS professionals and as a reference map by anyone interested in ocean data. The base map features marine bathymetry. Land features include inland waters and roads overlaid on land cover and shaded relief imagery. The map was compiled from a variety of best available sources from several data providers, including General Bathymetric Chart of the Oceans GEBCO_08 Grid, National Oceanic and Atmospheric Administration (NOAA), and National Geographic, Garmin, HERE, Geonames.org, and Esri, and various other contributors. The base map currently provides coverage for the world down to a scale of ~1:577k, and coverage down to 1:72k in US coastal areas, and various other areas. Coverage down to ~ 1:9k is available limited areas based on regional hydrographic survey data. The base map was designed and developed by Esri. For more information on this map, including our terms of use, visit us online at +https://www.arcgis.com/home/item.html?id=1e126e7520f9466c9ca28b8f28b5e500`,category:"Other",creationFunction:function(){return cW.fromBasemapType(oZ.OCEANS,{enablePickFeatures:!1})}})),t.push(new Nl({name:"Open\xADStreet\xADMap",iconUrl:Dn("Widgets/Images/ImageryProviders/openStreetMap.png"),tooltip:`OpenStreetMap (OSM) is a collaborative project to create a free editable map of the world. http://www.openstreetmap.org`,category:"Other",creationFunction:function(){return new IW({url:"https://tile.openstreetmap.org/"})}})),t.push(new Nl({name:"Stadia x Stamen Watercolor",iconUrl:Dn("Widgets/Images/ImageryProviders/stamenWatercolor.png"),tooltip:`Based on the original basemaps created for the Knight Foundation and reminiscent of hand drawn maps, the watercolor maps from Stamen Design apply raster effect area washes and organic edges over a paper texture to add warm pop to any map. https://docs.stadiamaps.com/map-styles/stamen-watercolor/`,category:"Other",creationFunction:function(){return new IW({url:"https://tiles.stadiamaps.com/tiles/stamen_watercolor/",fileExtension:"jpg",credit:`© <a href="https://stamen.com/" target="_blank">Stamen Design</a> © <a href="https://www.stadiamaps.com/" target="_blank">Stadia Maps</a> @@ -15532,7 +15532,7 @@ https://docs.stadiamaps.com/map-styles/alidade-smooth/`,category:"Other",creatio https://docs.stadiamaps.com/map-styles/alidade-smooth-dark/`,category:"Other",creationFunction:function(){return new IW({url:"https://tiles.stadiamaps.com/tiles/alidade_smooth_dark/",retinaTiles:e,credit:`© <a href="https://www.stadiamaps.com/" target="_blank">Stadia Maps</a> © <a href="https://openmaptiles.org/" target="_blank">OpenMapTiles</a> © <a href="https://www.openstreetmap.org/about/" target="_blank">OpenStreetMap contributors</a>`})}})),t.push(new Nl({name:"Sentinel-2",iconUrl:Dn("Widgets/Images/ImageryProviders/sentinel-2.png"),tooltip:"Sentinel-2 cloudless by EOX IT Services GmbH (Contains modified Copernicus Sentinel data 2016 and 2017).",category:"Cesium ion",creationFunction:function(){return mW.fromAssetId(3954)}})),t.push(new Nl({name:"Blue Marble",iconUrl:Dn("Widgets/Images/ImageryProviders/blueMarble.png"),tooltip:"Blue Marble Next Generation July, 2004 imagery from NASA.",category:"Cesium ion",creationFunction:function(){return mW.fromAssetId(3845)}})),t.push(new Nl({name:"Earth at night",iconUrl:Dn("Widgets/Images/ImageryProviders/earthAtNight.png"),tooltip:"The Earth at night, also known as The Black Marble, is a 500 meter resolution global composite imagery layer released by NASA.",category:"Cesium ion",creationFunction:function(){return mW.fromAssetId(3812)}})),t.push(new Nl({name:"Natural Earth\xA0II",iconUrl:Dn("Widgets/Images/ImageryProviders/naturalEarthII.png"),tooltip:`Natural Earth II, darkened for contrast. -http://www.naturalearthdata.com/`,category:"Cesium ion",creationFunction:function(){return hU.fromUrl(Dn("Assets/Textures/NaturalEarthII"))}})),t}var gD=A5e;var mFa=R(W(),1);function T5e(){let t=[];return t.push(new Nl({name:"WGS84 Ellipsoid",iconUrl:Dn("Widgets/Images/TerrainProviders/Ellipsoid.png"),tooltip:"WGS84 standard ellipsoid, also known as EPSG:4326",category:"Cesium ion",creationFunction:function(){return new Ru}})),t.push(new Nl({name:"Cesium World Terrain",iconUrl:Dn("Widgets/Images/TerrainProviders/CesiumWorldTerrain.png"),tooltip:"High-resolution global terrain tileset curated from several datasources and hosted by Cesium ion",category:"Cesium ion",creationFunction:function(){return KS({requestWaterMask:!0,requestVertexNormals:!0})}})),t}var ED=T5e;var TFa=R(W(),1);var bFa=R(W(),1);function S5e(t){let e;if(c(t)){e="Command Statistics";let n=t.commandsInFrustums;for(let i in n)if(n.hasOwnProperty(i)){let o=parseInt(i,10),a;if(o===7)a="1, 2 and 3";else{let s=[];for(let l=2;l>=0;l--){let r=Math.pow(2,l);o>=r&&(s.push(l+1),o-=r)}a=s.reverse().join(" and ")}e+=`<br>    ${n[i]} in frustum ${a}`}e+=`<br>Total: ${t.totalCommands}`}return e}function krt(t,e,n){let i=Math.min(n,e);return i=Math.max(i,t),i}var g5e=new di,E5e=new p;function CD(t,e){let n=this,i=t.canvas,o=new sp(i);this._eventHandler=o,this._scene=t,this._canvas=i,this._primitive=void 0,this._tile=void 0,this._modelMatrixPrimitive=void 0,this._performanceDisplay=void 0,this._performanceContainer=e;let a=this._scene.globe;a.depthTestAgainstTerrain=!0,this.frustums=!1,this.frustumPlanes=!1,this.performance=!1,this.shaderCacheText="",this.primitiveBoundingSphere=!1,this.primitiveReferenceFrame=!1,this.filterPrimitive=!1,this.tileBoundingSphere=!1,this.filterTile=!1,this.wireframe=!1,this.depthFrustum=1,this._numberOfFrustums=1,this.suspendUpdates=!1,this.tileCoordinates=!1,this.frustumStatisticText=!1,this.tileText="",this.hasPickedPrimitive=!1,this.hasPickedTile=!1,this.pickPrimitiveActive=!1,this.pickTileActive=!1,this.dropDownVisible=!0,this.generalVisible=!0,this.primitivesVisible=!1,this.terrainVisible=!1,this.depthFrustumText="",Lt.track(this,["frustums","frustumPlanes","performance","shaderCacheText","primitiveBoundingSphere","primitiveReferenceFrame","filterPrimitive","tileBoundingSphere","filterTile","wireframe","depthFrustum","suspendUpdates","tileCoordinates","frustumStatisticText","tileText","hasPickedPrimitive","hasPickedTile","pickPrimitiveActive","pickTileActive","dropDownVisible","generalVisible","primitivesVisible","terrainVisible","depthFrustumText"]),this._toggleDropDown=bi(function(){n.dropDownVisible=!n.dropDownVisible}),this._toggleGeneral=bi(function(){n.generalVisible=!n.generalVisible}),this._togglePrimitives=bi(function(){n.primitivesVisible=!n.primitivesVisible}),this._toggleTerrain=bi(function(){n.terrainVisible=!n.terrainVisible}),this._frustumsSubscription=Lt.getObservable(this,"frustums").subscribe(function(d){n._scene.debugShowFrustums=d,n._scene.requestRender()}),this._frustumPlanesSubscription=Lt.getObservable(this,"frustumPlanes").subscribe(function(d){n._scene.debugShowFrustumPlanes=d,n._scene.requestRender()}),this._performanceSubscription=Lt.getObservable(this,"performance").subscribe(function(d){d?n._performanceDisplay=new bW({container:n._performanceContainer}):n._performanceContainer.innerHTML=""}),this._showPrimitiveBoundingSphere=bi(function(){return n._primitive.debugShowBoundingVolume=n.primitiveBoundingSphere,n._scene.requestRender(),!0}),this._primitiveBoundingSphereSubscription=Lt.getObservable(this,"primitiveBoundingSphere").subscribe(function(){n._showPrimitiveBoundingSphere()}),this._showPrimitiveReferenceFrame=bi(function(){if(n.primitiveReferenceFrame){let d=n._primitive.modelMatrix;n._modelMatrixPrimitive=new D5({modelMatrix:d}),n._scene.primitives.add(n._modelMatrixPrimitive)}else c(n._modelMatrixPrimitive)&&(n._scene.primitives.remove(n._modelMatrixPrimitive),n._modelMatrixPrimitive=void 0);return n._scene.requestRender(),!0}),this._primitiveReferenceFrameSubscription=Lt.getObservable(this,"primitiveReferenceFrame").subscribe(function(){n._showPrimitiveReferenceFrame()}),this._doFilterPrimitive=bi(function(){return n.filterPrimitive?n._scene.debugCommandFilter=function(d){return c(n._modelMatrixPrimitive)&&d.owner===n._modelMatrixPrimitive._primitive?!0:c(n._primitive)?d.owner===n._primitive||d.owner===n._primitive._billboardCollection||d.owner.primitive===n._primitive:!1}:n._scene.debugCommandFilter=void 0,!0}),this._filterPrimitiveSubscription=Lt.getObservable(this,"filterPrimitive").subscribe(function(){n._doFilterPrimitive(),n._scene.requestRender()}),this._wireframeSubscription=Lt.getObservable(this,"wireframe").subscribe(function(d){a._surface.tileProvider._debug.wireframe=d,n._scene.requestRender()}),this._depthFrustumSubscription=Lt.getObservable(this,"depthFrustum").subscribe(function(d){n._scene.debugShowDepthFrustum=d,n._scene.requestRender()}),this._incrementDepthFrustum=bi(function(){let d=n.depthFrustum+1;return n.depthFrustum=krt(1,n._numberOfFrustums,d),n._scene.requestRender(),!0}),this._decrementDepthFrustum=bi(function(){let d=n.depthFrustum-1;return n.depthFrustum=krt(1,n._numberOfFrustums,d),n._scene.requestRender(),!0}),this._suspendUpdatesSubscription=Lt.getObservable(this,"suspendUpdates").subscribe(function(d){a._surface._debug.suspendLodUpdate=d,d||(n.filterTile=!1)});let s;this._showTileCoordinates=bi(function(){return n.tileCoordinates&&!c(s)?s=t.imageryLayers.addImageryProvider(new dD({tilingScheme:t.terrainProvider.tilingScheme})):!n.tileCoordinates&&c(s)&&(t.imageryLayers.remove(s),s=void 0),!0}),this._tileCoordinatesSubscription=Lt.getObservable(this,"tileCoordinates").subscribe(function(){n._showTileCoordinates(),n._scene.requestRender()}),this._tileBoundingSphereSubscription=Lt.getObservable(this,"tileBoundingSphere").subscribe(function(){n._showTileBoundingSphere(),n._scene.requestRender()}),this._showTileBoundingSphere=bi(function(){return n.tileBoundingSphere?a._surface.tileProvider._debug.boundingSphereTile=n._tile:a._surface.tileProvider._debug.boundingSphereTile=void 0,n._scene.requestRender(),!0}),this._doFilterTile=bi(function(){return n.filterTile?(n.suspendUpdates=!0,a._surface._tilesToRender=[],c(n._tile)&&n._tile.renderable&&a._surface._tilesToRender.push(n._tile)):n.suspendUpdates=!1,!0}),this._filterTileSubscription=Lt.getObservable(this,"filterTile").subscribe(function(){n.doFilterTile(),n._scene.requestRender()});function l(d){let m=n._scene.pick({x:d.position.x,y:d.position.y});c(m)&&(n.primitive=c(m.collection)?m.collection:m.primitive),n._scene.requestRender(),n.pickPrimitiveActive=!1}this._pickPrimitive=bi(function(){n.pickPrimitiveActive=!n.pickPrimitiveActive}),this._pickPrimitiveActiveSubscription=Lt.getObservable(this,"pickPrimitiveActive").subscribe(function(d){d?o.setInputAction(l,Zi.LEFT_CLICK):o.removeInputAction(Zi.LEFT_CLICK)});function r(d){let m,h=a.ellipsoid,Z=n._scene.camera.getPickRay(d.position,g5e),b=a.pick(Z,n._scene,E5e);if(c(b)){let u=h.cartesianToCartographic(b),F=a._surface.tileProvider._tilesToRenderByTextureCount;for(let U=0;!m&&U<F.length;++U){let G=F[U];if(c(G))for(let A=0;!m&&A<G.length;++A){let T=G[A];Gt.contains(T.rectangle,u)&&(m=T)}}}n.tile=m,n.pickTileActive=!1}this._pickTile=bi(function(){n.pickTileActive=!n.pickTileActive}),this._pickTileActiveSubscription=Lt.getObservable(this,"pickTileActive").subscribe(function(d){d?o.setInputAction(r,Zi.LEFT_CLICK):o.removeInputAction(Zi.LEFT_CLICK)}),this._removePostRenderEvent=t.postRender.addEventListener(function(){n._update()})}Object.defineProperties(CD.prototype,{scene:{get:function(){return this._scene}},performanceContainer:{get:function(){return this._performanceContainer}},toggleDropDown:{get:function(){return this._toggleDropDown}},showPrimitiveBoundingSphere:{get:function(){return this._showPrimitiveBoundingSphere}},showPrimitiveReferenceFrame:{get:function(){return this._showPrimitiveReferenceFrame}},doFilterPrimitive:{get:function(){return this._doFilterPrimitive}},incrementDepthFrustum:{get:function(){return this._incrementDepthFrustum}},decrementDepthFrustum:{get:function(){return this._decrementDepthFrustum}},showTileCoordinates:{get:function(){return this._showTileCoordinates}},showTileBoundingSphere:{get:function(){return this._showTileBoundingSphere}},doFilterTile:{get:function(){return this._doFilterTile}},toggleGeneral:{get:function(){return this._toggleGeneral}},togglePrimitives:{get:function(){return this._togglePrimitives}},toggleTerrain:{get:function(){return this._toggleTerrain}},pickPrimitive:{get:function(){return this._pickPrimitive}},pickTile:{get:function(){return this._pickTile}},selectParent:{get:function(){let t=this;return bi(function(){t.tile=t.tile.parent})}},selectNW:{get:function(){let t=this;return bi(function(){t.tile=t.tile.northwestChild})}},selectNE:{get:function(){let t=this;return bi(function(){t.tile=t.tile.northeastChild})}},selectSW:{get:function(){let t=this;return bi(function(){t.tile=t.tile.southwestChild})}},selectSE:{get:function(){let t=this;return bi(function(){t.tile=t.tile.southeastChild})}},primitive:{get:function(){return this._primitive},set:function(t){let e=this._primitive;t!==e&&(this.hasPickedPrimitive=!0,c(e)&&(e.debugShowBoundingVolume=!1),this._scene.debugCommandFilter=void 0,c(this._modelMatrixPrimitive)&&(this._scene.primitives.remove(this._modelMatrixPrimitive),this._modelMatrixPrimitive=void 0),this._primitive=t,t.show=!1,setTimeout(function(){t.show=!0},50),this.showPrimitiveBoundingSphere(),this.showPrimitiveReferenceFrame(),this.doFilterPrimitive())}},tile:{get:function(){return this._tile},set:function(t){if(c(t)){this.hasPickedTile=!0;let e=this._tile;if(t!==e){this.tileText=`L: ${t.level} X: ${t.x} Y: ${t.y}`,this.tileText+=`<br>SW corner: ${t.rectangle.west}, ${t.rectangle.south}`,this.tileText+=`<br>NE corner: ${t.rectangle.east}, ${t.rectangle.north}`;let n=t.data;c(n)&&c(n.tileBoundingRegion)?this.tileText+=`<br>Min: ${n.tileBoundingRegion.minimumHeight} Max: ${n.tileBoundingRegion.maximumHeight}`:this.tileText+="<br>(Tile is not loaded)"}this._tile=t,this.showTileBoundingSphere(),this.doFilterTile()}else this.hasPickedTile=!1,this._tile=void 0}}});CD.prototype._update=function(){this.frustums&&(this.frustumStatisticText=S5e(this._scene.debugFrustumStatistics));let t=this._scene.numberOfFrustums;this._numberOfFrustums=t,this.depthFrustum=krt(1,t,this.depthFrustum),this.depthFrustumText=`${this.depthFrustum} of ${t}`,this.performance&&this._performanceDisplay.update(),this.primitiveReferenceFrame&&(this._modelMatrixPrimitive.modelMatrix=this._primitive.modelMatrix),this.shaderCacheText=`Cached shaders: ${this._scene.context.shaderCache.numberOfShaders}`};CD.prototype.isDestroyed=function(){return!1};CD.prototype.destroy=function(){return this._eventHandler.destroy(),this._removePostRenderEvent(),this._frustumsSubscription.dispose(),this._frustumPlanesSubscription.dispose(),this._performanceSubscription.dispose(),this._primitiveBoundingSphereSubscription.dispose(),this._primitiveReferenceFrameSubscription.dispose(),this._filterPrimitiveSubscription.dispose(),this._wireframeSubscription.dispose(),this._depthFrustumSubscription.dispose(),this._suspendUpdatesSubscription.dispose(),this._tileCoordinatesSubscription.dispose(),this._tileBoundingSphereSubscription.dispose(),this._filterTileSubscription.dispose(),this._pickPrimitiveActiveSubscription.dispose(),this._pickTileActiveSubscription.dispose(),At(this)};var ID=CD;function u4(t,e){t=Ui(t);let n=document.createElement("div"),i=new ID(e,n);this._viewModel=i,this._container=t;let o=document.createElement("div");this._element=o;let a=document.createElement("div");a.textContent="Cesium Inspector",a.className="cesium-cesiumInspector-button",a.setAttribute("data-bind","click: toggleDropDown"),o.appendChild(a),o.className="cesium-cesiumInspector",o.setAttribute("data-bind",'css: { "cesium-cesiumInspector-visible" : dropDownVisible, "cesium-cesiumInspector-hidden" : !dropDownVisible }'),t.appendChild(this._element);let s=document.createElement("div");s.className="cesium-cesiumInspector-dropDown",o.appendChild(s);let l=gd.createSection,r=gd.createCheckbox,d=l(s,"General","generalVisible","toggleGeneral"),m=r("Show Frustums","frustums"),h=document.createElement("div");h.className="cesium-cesiumInspector-frustumStatistics",h.setAttribute("data-bind","visible: frustums, html: frustumStatisticText"),m.appendChild(h),d.appendChild(m),d.appendChild(r("Show Frustum Planes","frustumPlanes")),d.appendChild(r("Performance Display","performance")),n.className="cesium-cesiumInspector-performanceDisplay",d.appendChild(n);let Z=document.createElement("div");Z.className="cesium-cesiumInspector-shaderCache",Z.setAttribute("data-bind","html: shaderCacheText"),d.appendChild(Z);let b=document.createElement("div");d.appendChild(b);let u=document.createElement("span");u.setAttribute("data-bind",'html: "     Frustum:"'),b.appendChild(u);let F=document.createElement("span");F.setAttribute("data-bind","text: depthFrustumText"),b.appendChild(F);let U=document.createElement("input");U.type="button",U.value="-",U.className="cesium-cesiumInspector-pickButton",U.setAttribute("data-bind","click: decrementDepthFrustum"),b.appendChild(U);let G=document.createElement("input");G.type="button",G.value="+",G.className="cesium-cesiumInspector-pickButton",G.setAttribute("data-bind","click: incrementDepthFrustum"),b.appendChild(G);let A=l(s,"Primitives","primitivesVisible","togglePrimitives"),T=document.createElement("div");T.className="cesium-cesiumInspector-pickSection",A.appendChild(T);let g=document.createElement("input");g.type="button",g.value="Pick a primitive",g.className="cesium-cesiumInspector-pickButton",g.setAttribute("data-bind",'css: {"cesium-cesiumInspector-pickButtonHighlight" : pickPrimitiveActive}, click: pickPrimitive');let C=document.createElement("div");C.className="cesium-cesiumInspector-center",C.appendChild(g),T.appendChild(C),T.appendChild(r("Show bounding sphere","primitiveBoundingSphere","hasPickedPrimitive")),T.appendChild(r("Show reference frame","primitiveReferenceFrame","hasPickedPrimitive")),this._primitiveOnly=r("Show only selected","filterPrimitive","hasPickedPrimitive"),T.appendChild(this._primitiveOnly);let y=l(s,"Terrain","terrainVisible","toggleTerrain"),Y=document.createElement("div");Y.className="cesium-cesiumInspector-pickSection",y.appendChild(Y);let Q=document.createElement("input");Q.type="button",Q.value="Pick a tile",Q.className="cesium-cesiumInspector-pickButton",Q.setAttribute("data-bind",'css: {"cesium-cesiumInspector-pickButtonHighlight" : pickTileActive}, click: pickTile'),C=document.createElement("div"),C.appendChild(Q),C.className="cesium-cesiumInspector-center",Y.appendChild(C);let J=document.createElement("div");Y.appendChild(J);let M=document.createElement("input");M.type="button",M.value="Parent",M.className="cesium-cesiumInspector-pickButton",M.setAttribute("data-bind","click: selectParent");let V=document.createElement("input");V.type="button",V.value="NW",V.className="cesium-cesiumInspector-pickButton",V.setAttribute("data-bind","click: selectNW");let E=document.createElement("input");E.type="button",E.value="NE",E.className="cesium-cesiumInspector-pickButton",E.setAttribute("data-bind","click: selectNE");let I=document.createElement("input");I.type="button",I.value="SW",I.className="cesium-cesiumInspector-pickButton",I.setAttribute("data-bind","click: selectSW");let B=document.createElement("input");B.type="button",B.value="SE",B.className="cesium-cesiumInspector-pickButton",B.setAttribute("data-bind","click: selectSE");let X=document.createElement("div");X.className="cesium-cesiumInspector-tileText",J.className="cesium-cesiumInspector-frustumStatistics",J.appendChild(X),J.setAttribute("data-bind","visible: hasPickedTile"),X.setAttribute("data-bind","html: tileText");let _=document.createElement("div");_.className="cesium-cesiumInspector-relativeText",_.textContent="Select relative:",J.appendChild(_);let P=document.createElement("table"),w=document.createElement("tr"),z=document.createElement("tr"),H=document.createElement("td");H.appendChild(M);let nt=document.createElement("td");nt.appendChild(V);let $=document.createElement("td");$.appendChild(E),w.appendChild(H),w.appendChild(nt),w.appendChild($);let dt=document.createElement("td"),q=document.createElement("td");q.appendChild(I);let at=document.createElement("td");at.appendChild(B),z.appendChild(dt),z.appendChild(q),z.appendChild(at),P.appendChild(w),P.appendChild(z),J.appendChild(P),Y.appendChild(r("Show bounding volume","tileBoundingSphere","hasPickedTile")),Y.appendChild(r("Show only selected","filterTile","hasPickedTile")),y.appendChild(r("Wireframe","wireframe")),y.appendChild(r("Suspend LOD update","suspendUpdates")),y.appendChild(r("Show tile coordinates","tileCoordinates")),Lt.applyBindings(i,this._element)}Object.defineProperties(u4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});u4.prototype.isDestroyed=function(){return!1};u4.prototype.destroy=function(){return Lt.cleanNode(this._element),this._container.removeChild(this._element),this.viewModel.destroy(),At(this)};var ND=u4;var XFa=R(W(),1);var NFa=R(W(),1);function Z4(t,e){c(e)||(e=document.body),e=Ui(e);let n=this,i=Lt.observable(Ds.fullscreen),o=Lt.observable(Ds.enabled),a=e.ownerDocument;this.isFullscreen=void 0,Lt.defineProperty(this,"isFullscreen",{get:function(){return i()}}),this.isFullscreenEnabled=void 0,Lt.defineProperty(this,"isFullscreenEnabled",{get:function(){return o()},set:function(s){o(s&&Ds.enabled)}}),this.tooltip=void 0,Lt.defineProperty(this,"tooltip",function(){return this.isFullscreenEnabled?i()?"Exit full screen":"Full screen":"Full screen unavailable"}),this._command=bi(function(){Ds.fullscreen?Ds.exitFullscreen():Ds.requestFullscreen(n._fullscreenElement)},Lt.getObservable(this,"isFullscreenEnabled")),this._fullscreenElement=f(Ui(t),a.body),this._callback=function(){i(Ds.fullscreen)},a.addEventListener(Ds.changeEventName,this._callback)}Object.defineProperties(Z4.prototype,{fullscreenElement:{get:function(){return this._fullscreenElement},set:function(t){this._fullscreenElement=t}},command:{get:function(){return this._command}}});Z4.prototype.isDestroyed=function(){return!1};Z4.prototype.destroy=function(){document.removeEventListener(Ds.changeEventName,this._callback),At(this)};var yD=Z4;var C5e="M 83.96875 17.5625 L 83.96875 17.59375 L 76.65625 24.875 L 97.09375 24.96875 L 76.09375 45.96875 L 81.9375 51.8125 L 102.78125 30.9375 L 102.875 51.15625 L 110.15625 43.875 L 110.1875 17.59375 L 83.96875 17.5625 z M 44.125 17.59375 L 17.90625 17.625 L 17.9375 43.90625 L 25.21875 51.1875 L 25.3125 30.96875 L 46.15625 51.8125 L 52 45.96875 L 31 25 L 51.4375 24.90625 L 44.125 17.59375 z M 46.0625 76.03125 L 25.1875 96.875 L 25.09375 76.65625 L 17.8125 83.9375 L 17.8125 110.21875 L 44 110.25 L 51.3125 102.9375 L 30.90625 102.84375 L 51.875 81.875 L 46.0625 76.03125 z M 82 76.15625 L 76.15625 82 L 97.15625 103 L 76.71875 103.0625 L 84.03125 110.375 L 110.25 110.34375 L 110.21875 84.0625 L 102.9375 76.8125 L 102.84375 97 L 82 76.15625 z",I5e="M 104.34375 17.5625 L 83.5 38.4375 L 83.40625 18.21875 L 76.125 25.5 L 76.09375 51.78125 L 102.3125 51.8125 L 102.3125 51.78125 L 109.625 44.5 L 89.1875 44.40625 L 110.1875 23.40625 L 104.34375 17.5625 z M 23.75 17.59375 L 17.90625 23.4375 L 38.90625 44.4375 L 18.5 44.53125 L 25.78125 51.8125 L 52 51.78125 L 51.96875 25.53125 L 44.6875 18.25 L 44.625 38.46875 L 23.75 17.59375 z M 25.6875 76.03125 L 18.375 83.3125 L 38.78125 83.40625 L 17.8125 104.40625 L 23.625 110.25 L 44.5 89.375 L 44.59375 109.59375 L 51.875 102.3125 L 51.875 76.0625 L 25.6875 76.03125 z M 102.375 76.15625 L 76.15625 76.1875 L 76.1875 102.4375 L 83.46875 109.71875 L 83.5625 89.53125 L 104.40625 110.375 L 110.25 104.53125 L 89.25 83.53125 L 109.6875 83.46875 L 102.375 76.15625 z";function V4(t,e){t=Ui(t);let n=new yD(e,t);n._exitFullScreenPath=I5e,n._enterFullScreenPath=C5e;let i=document.createElement("button");i.type="button",i.className="cesium-button cesium-fullscreenButton",i.setAttribute("data-bind","attr: { title: tooltip },click: command,enable: isFullscreenEnabled,cesiumSvgPath: { path: isFullscreen ? _exitFullScreenPath : _enterFullScreenPath, width: 128, height: 128 }"),t.appendChild(i),Lt.applyBindings(n,i),this._container=t,this._viewModel=n,this._element=i}Object.defineProperties(V4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});V4.prototype.isDestroyed=function(){return!1};V4.prototype.destroy=function(){return this._viewModel.destroy(),Lt.cleanNode(this._element),this._container.removeChild(this._element),At(this)};var BD=V4;var jFa=R(W(),1);var OFa=R(W(),1);var Ukt=1e3;function Yu(t){c(t.geocoderServices)?this._geocoderServices=t.geocoderServices:this._geocoderServices=[new N5({scene:t.scene})],this._viewContainer=t.container,this._scene=t.scene,this._flightDuration=t.flightDuration,this._searchText="",this._isSearchInProgress=!1,this._wasGeocodeCancelled=!1,this._previousCredits=[],this._complete=new It,this._suggestions=[],this._selectedSuggestion=void 0,this._showSuggestions=!0,this._handleArrowDown=Akt,this._handleArrowUp=Gkt;let e=this;this._suggestionsVisible=Lt.pureComputed(function(){let o=Lt.getObservable(e,"_suggestions")().length>0,a=Lt.getObservable(e,"_showSuggestions")();return o&&a}),this._searchCommand=bi(function(i){if(i=f(i,IU.SEARCH),e._focusTextbox=!1,c(e._selectedSuggestion))return e.activateSuggestion(e._selectedSuggestion),!1;if(e.hideSuggestions(),e.isSearchInProgress)Y5e(e);else return Q5e(e,e._geocoderServices,i)}),this.deselectSuggestion=function(){e._selectedSuggestion=void 0},this.handleKeyDown=function(i,o){let a=o.key==="ArrowDown"||o.key==="Down"||o.keyCode===40,s=o.key==="ArrowUp"||o.key==="Up"||o.keyCode===38;return(a||s)&&o.preventDefault(),!0},this.handleKeyUp=function(i,o){let a=o.key==="ArrowDown"||o.key==="Down"||o.keyCode===40,s=o.key==="ArrowUp"||o.key==="Up"||o.keyCode===38,l=o.key==="Enter"||o.keyCode===13;return s?Gkt(e):a?Akt(e):l&&e._searchCommand(),!0},this.activateSuggestion=function(i){e.hideSuggestions(),e._searchText=i.displayName;let o=i.destination;gkt(e),e.destinationFound(e,o)},this.hideSuggestions=function(){e._showSuggestions=!1,e._selectedSuggestion=void 0},this.showSuggestions=function(){e._showSuggestions=!0},this.handleMouseover=function(i,o){i!==e._selectedSuggestion&&(e._selectedSuggestion=i)},this.keepExpanded=!1,this.autoComplete=f(t.autocomplete,!0),this.destinationFound=f(t.destinationFound,Yu.flyToDestination),this._focusTextbox=!1,Lt.track(this,["_searchText","_isSearchInProgress","keepExpanded","_suggestions","_selectedSuggestion","_showSuggestions","_focusTextbox"]);let n=Lt.getObservable(this,"_searchText");n.extend({rateLimit:{timeout:500}}),this._suggestionSubscription=n.subscribe(function(){Yu._updateSearchSuggestions(e)}),this.isSearchInProgress=void 0,Lt.defineProperty(this,"isSearchInProgress",{get:function(){return this._isSearchInProgress}}),this.searchText=void 0,Lt.defineProperty(this,"searchText",{get:function(){return this.isSearchInProgress?"Searching...":this._searchText},set:function(i){this._searchText=i}}),this.flightDuration=void 0,Lt.defineProperty(this,"flightDuration",{get:function(){return this._flightDuration},set:function(i){this._flightDuration=i}})}Object.defineProperties(Yu.prototype,{complete:{get:function(){return this._complete}},scene:{get:function(){return this._scene}},search:{get:function(){return this._searchCommand}},selectedSuggestion:{get:function(){return this._selectedSuggestion}},suggestions:{get:function(){return this._suggestions}}});Yu.prototype.destroy=function(){this._suggestionSubscription.dispose()};function Gkt(t){if(t._suggestions.length===0)return;let e=t._suggestions.indexOf(t._selectedSuggestion);if(e===-1||e===0){t._selectedSuggestion=void 0;return}let n=e-1;t._selectedSuggestion=t._suggestions[n],Yu._adjustSuggestionsScroll(t,n)}function Akt(t){if(t._suggestions.length===0)return;let e=t._suggestions.length,i=(t._suggestions.indexOf(t._selectedSuggestion)+1)%e;t._selectedSuggestion=t._suggestions[i],Yu._adjustSuggestionsScroll(t,i)}function N5e(t,e){let n=c(e)?e.availability:void 0;return c(n)?zS(e,[t]).then(function(i){return t=i[0],t.height+=Ukt,t}):(t.height+=Ukt,Promise.resolve(t))}function y5e(t,e){let n=t._scene,o=n.mapProjection.ellipsoid,a=n.camera,s=n.terrainProvider,l=e,r;return e instanceof Gt?k.equalsEpsilon(e.south,e.north,k.EPSILON7)&&k.equalsEpsilon(e.east,e.west,k.EPSILON7)?e=Gt.center(e):r=rg(e,n):e=o.cartesianToCartographic(e),c(r)||(r=N5e(e,s)),r.then(function(d){l=o.cartographicToCartesian(d)}).finally(function(){a.flyTo({destination:l,complete:function(){t._complete.raiseEvent()},duration:t._flightDuration,endTransform:L.IDENTITY})})}async function B5e(t,e,n){try{return{state:"fulfilled",value:await t.geocode(e,n),credits:t.credit}}catch(i){return{state:"rejected",reason:i}}}async function Q5e(t,e,n){let i=t._searchText;if(Skt(i)){t.showSuggestions();return}t._isSearchInProgress=!0,t._wasGeocodeCancelled=!1;let o,a;for(o=0;o<e.length;o++){if(t._wasGeocodeCancelled)return;if(a=await B5e(e[o],i,n),c(a)&&a.state==="fulfilled"&&a.value.length>0)break}if(t._wasGeocodeCancelled)return;t._isSearchInProgress=!1,xrt(t);let s=a.value;if(a.state==="fulfilled"&&c(s)&&s.length>0){t._searchText=s[0].displayName,t.destinationFound(t,s[0].destination);let l=Tkt(t,sN.getCreditsFromResult(s[0]));c(l)||Yrt(t,e[o].credit);return}t._searchText=`${i} (not found)`}function Yrt(t,e){c(e)&&!t._scene.isDestroyed()&&!t._scene.frameState.creditDisplay.isDestroyed()&&(t._scene.frameState.creditDisplay.addStaticCredit(e),t._previousCredits.push(e))}function Tkt(t,e){return c(e)&&e.forEach(n=>Yrt(t,n)),e}function xrt(t){!t._scene.isDestroyed()&&!t._scene.frameState.creditDisplay.isDestroyed()&&t._previousCredits.forEach(e=>{t._scene.frameState.creditDisplay.removeStaticCredit(e)}),t._previousCredits.length=0}function k5e(t,e){let n=Ui(t._viewContainer),i=n.getElementsByClassName("search-results")[0],a=n.getElementsByTagName("li")[e];if(e===0){i.scrollTop=0;return}let s=a.offsetTop;s+a.clientHeight>i.clientHeight?i.scrollTop=s+a.clientHeight:s<i.scrollTop&&(i.scrollTop=s)}function Y5e(t){t._isSearchInProgress&&(t._isSearchInProgress=!1,t._wasGeocodeCancelled=!0)}function Skt(t){return/^\s*$/.test(t)}function gkt(t){Lt.getObservable(t,"_suggestions").removeAll()}async function x5e(t){if(!t.autoComplete)return;let e=t._searchText;if(gkt(t),xrt(t),!Skt(e))for(let n of t._geocoderServices){let i=await n.geocode(e,IU.AUTOCOMPLETE);if(t._suggestions=t._suggestions.concat(i),i.length>0){let o=!0;i.forEach(a=>{let s=sN.getCreditsFromResult(a);o=o&&!c(s),Tkt(t,s)}),o&&Yrt(t,n.credit)}if(t._suggestions.length>=5)return}}Yu.flyToDestination=y5e;Yu._updateSearchSuggestions=x5e;Yu._adjustSuggestionsScroll=k5e;Yu.prototype.isDestroyed=function(){return!1};Yu.prototype.destroy=function(){return xrt(this),At(this)};var QD=Yu;var X5e="M29.772,26.433l-7.126-7.126c0.96-1.583,1.523-3.435,1.524-5.421C24.169,8.093,19.478,3.401,13.688,3.399C7.897,3.401,3.204,8.093,3.204,13.885c0,5.789,4.693,10.481,10.484,10.481c1.987,0,3.839-0.563,5.422-1.523l7.128,7.127L29.772,26.433zM7.203,13.885c0.006-3.582,2.903-6.478,6.484-6.486c3.579,0.008,6.478,2.904,6.484,6.486c-0.007,3.58-2.905,6.476-6.484,6.484C10.106,20.361,7.209,17.465,7.203,13.885z",J5e="M24.778,21.419 19.276,15.917 24.777,10.415 21.949,7.585 16.447,13.087 10.945,7.585 8.117,10.415 13.618,15.917 8.116,21.419 10.946,24.248 16.447,18.746 21.948,24.248z";function b4(t){let e=Ui(t.container),n=new QD(t);n._startSearchPath=X5e,n._stopSearchPath=J5e;let i=document.createElement("form");i.setAttribute("data-bind","submit: search");let o=document.createElement("input");o.type="search",o.className="cesium-geocoder-input",o.setAttribute("placeholder","Enter an address or landmark..."),o.setAttribute("data-bind",'textInput: searchText,disable: isSearchInProgress,event: { keyup: handleKeyUp, keydown: handleKeyDown, mouseover: deselectSuggestion },css: { "cesium-geocoder-input-wide" : keepExpanded || searchText.length > 0 },hasFocus: _focusTextbox'),this._onTextBoxFocus=function(){setTimeout(function(){o.select()},0)},o.addEventListener("focus",this._onTextBoxFocus,!1),i.appendChild(o),this._textBox=o;let a=document.createElement("span");a.className="cesium-geocoder-searchButton",a.setAttribute("data-bind","click: search,cesiumSvgPath: { path: isSearchInProgress ? _stopSearchPath : _startSearchPath, width: 32, height: 32 }"),i.appendChild(a),e.appendChild(i);let s=document.createElement("div");s.className="search-results",s.setAttribute("data-bind","visible: _suggestionsVisible");let l=document.createElement("ul");l.setAttribute("data-bind","foreach: _suggestions");let r=document.createElement("li");l.appendChild(r),r.setAttribute("data-bind","text: $data.displayName, click: $parent.activateSuggestion, event: { mouseover: $parent.handleMouseover}, css: { active: $data === $parent._selectedSuggestion }"),s.appendChild(l),e.appendChild(s),Lt.applyBindings(n,i),Lt.applyBindings(n,s),this._container=e,this._searchSuggestionsContainer=s,this._viewModel=n,this._form=i,this._onInputBegin=function(d){let m=d.target;typeof d.composedPath=="function"&&(m=d.composedPath()[0]),e.contains(m)||(n._focusTextbox=!1,n.hideSuggestions())},this._onInputEnd=function(d){n._focusTextbox=!0,n.showSuggestions()},In.supportsPointerEvents()?(document.addEventListener("pointerdown",this._onInputBegin,!0),e.addEventListener("pointerup",this._onInputEnd,!0),e.addEventListener("pointercancel",this._onInputEnd,!0)):(document.addEventListener("mousedown",this._onInputBegin,!0),e.addEventListener("mouseup",this._onInputEnd,!0),document.addEventListener("touchstart",this._onInputBegin,!0),e.addEventListener("touchend",this._onInputEnd,!0),e.addEventListener("touchcancel",this._onInputEnd,!0))}Object.defineProperties(b4.prototype,{container:{get:function(){return this._container}},searchSuggestionsContainer:{get:function(){return this._searchSuggestionsContainer}},viewModel:{get:function(){return this._viewModel}}});b4.prototype.isDestroyed=function(){return!1};b4.prototype.destroy=function(){let t=this._container;return In.supportsPointerEvents()?(document.removeEventListener("pointerdown",this._onInputBegin,!0),t.removeEventListener("pointerup",this._onInputEnd,!0)):(document.removeEventListener("mousedown",this._onInputBegin,!0),t.removeEventListener("mouseup",this._onInputEnd,!0),document.removeEventListener("touchstart",this._onInputBegin,!0),t.removeEventListener("touchend",this._onInputEnd,!0)),this._viewModel.destroy(),Lt.cleanNode(this._form),Lt.cleanNode(this._searchSuggestionsContainer),t.removeChild(this._form),t.removeChild(this._searchSuggestionsContainer),this._textBox.removeEventListener("focus",this._onTextBoxFocus,!1),At(this)};var kD=b4;var rUa=R(W(),1);var eUa=R(W(),1);function Ekt(t,e){this._scene=t,this._duration=e;let n=this;this._command=bi(function(){n._scene.camera.flyHome(n._duration)}),this.tooltip="View Home",Lt.track(this,["tooltip"])}Object.defineProperties(Ekt.prototype,{scene:{get:function(){return this._scene}},command:{get:function(){return this._command}},duration:{get:function(){return this._duration},set:function(t){this._duration=t}}});var YD=Ekt;function R4(t,e,n){t=Ui(t);let i=new YD(e,n);i._svgPath="M14,4l-10,8.75h20l-4.25-3.7188v-4.6562h-2.812v2.1875l-2.938-2.5625zm-7.0938,9.906v10.094h14.094v-10.094h-14.094zm2.1876,2.313h3.3122v4.25h-3.3122v-4.25zm5.8442,1.281h3.406v6.438h-3.406v-6.438z";let o=document.createElement("button");o.type="button",o.className="cesium-button cesium-toolbar-button cesium-home-button",o.setAttribute("data-bind","attr: { title: tooltip },click: command,cesiumSvgPath: { path: _svgPath, width: 28, height: 28 }"),t.appendChild(o),Lt.applyBindings(i,o),this._container=t,this._viewModel=i,this._element=o}Object.defineProperties(R4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});R4.prototype.isDestroyed=function(){return!1};R4.prototype.destroy=function(){return Lt.cleanNode(this._element),this._container.removeChild(this._element),At(this)};var xD=R4;var RUa=R(W(),1);var hUa=R(W(),1);function L5e(t,e){e.currentTarget.parentElement.parentElement.querySelector(`#${t.name}-expander`).classList.toggle("active"),e.currentTarget.textContent=e.currentTarget.textContent==="+"?"-":"+"}function Ikt(t,e){Lt.track(t);for(let n=0;n<t.sublayers.length;n++)Ikt(t.sublayers[n],e)}function W4(t){return t.modelName==="FullModel"}function Nkt(t){return t.modelName==="Overview"}function ykt(t){return Nkt(t)||W4(t)}function Ckt(t,e){if(ykt(t)){t.visibility=!1;for(let i=0;i<t.sublayers.length;i++)t.sublayers[i].visibility=!0;let n={name:t.name,modelName:t.modelName,disable:Lt.observable(!1),index:e.sublayers.length};return e.topLayers.push(n),e.sublayers.push(t),n}}function M5e(t,e){if(ykt(t)){e.sublayers.forEach(i=>i.visibility=!1),e.sublayers[t.index].visibility=!0;let n=document.getElementById("bsl-wrapper");W4(t)?(e.currentLevel=e.selectedLevel,n.style.display="block"):(e.selectedLevel=e.currentLevel,e.currentLevel="All",n.style.display="none")}}async function _5e(t,e){try{let n=t.getAttributeNames();for(let i=0;i<n.length;i++)if(n[i]==="BldgLevel"){let o=t.getAttributeValues(n[i]);for(let a=0;a<o.length;a++)e.push(o[a])}e.sort((i,o)=>i-o),e.unshift("All")}catch(n){console.log(`There was an error getting attributes: ${n}`)}}function D5e(t){let e=this;this.levels=[],this.viewModel={sublayers:[],levels:this.levels,currentLevel:Lt.observable(),selectedLevel:"All",topLayers:[{name:"Select a layer to explore...",disable:Lt.observable(!0),index:-1}],currentLayer:Lt.observable(),expandClickHandler:L5e,setOptionDisable:function(i,o){Lt.applyBindingsToNode(i,{disable:o.disable},o)},defaultLayer:void 0},this.viewModel.currentLayer.subscribe(function(i){M5e(i,e.viewModel)});let n=t.sublayers;for(let i=0;i<n.length;i++){Ikt(n[i],this.viewModel);let o=Ckt(n[i],this.viewModel);c(o)&&(Nkt(o)||!c(this.viewModel.defaultLayer)&&W4(o))&&(this.viewModel.defaultLayer=o)}if(this.viewModel.topLayers.length===1&&n.length>0){t.show=!1;let i={name:"Full Model",modelName:"FullModel",visibility:t.show,sublayers:t.sublayers};this.viewModel.defaultLayer=Ckt(i,this.viewModel),this.viewModel.currentLayer.subscribe(function(o){t.show=W4(o)})}else this.viewModel.topLayers.length===1&&(this.viewModel.topLayers[0].name="Building layers not found");return _5e(t,this.levels),this.viewModel.currentLevel.subscribe(function(i){i!=="All"?t.filterByAttributes([{name:"BldgLevel",values:[i]}]):t.filterByAttributes()}),this.viewModel}var XD=D5e;function O5e(t,e){let n=document.getElementById(t),i=document.createElement("div");i.classList.add("cesium-viewer-i3s-explorer"),i.innerHTML=` +http://www.naturalearthdata.com/`,category:"Cesium ion",creationFunction:function(){return hU.fromUrl(Dn("Assets/Textures/NaturalEarthII"))}})),t}var gD=A5e;var mFa=b(W(),1);function S5e(){let t=[];return t.push(new Nl({name:"WGS84 Ellipsoid",iconUrl:Dn("Widgets/Images/TerrainProviders/Ellipsoid.png"),tooltip:"WGS84 standard ellipsoid, also known as EPSG:4326",category:"Cesium ion",creationFunction:function(){return new bV}})),t.push(new Nl({name:"Cesium World Terrain",iconUrl:Dn("Widgets/Images/TerrainProviders/CesiumWorldTerrain.png"),tooltip:"High-resolution global terrain tileset curated from several datasources and hosted by Cesium ion",category:"Cesium ion",creationFunction:function(){return KT({requestWaterMask:!0,requestVertexNormals:!0})}})),t}var ED=S5e;var SFa=b(W(),1);var RFa=b(W(),1);function T5e(t){let e;if(c(t)){e="Command Statistics";let n=t.commandsInFrustums;for(let i in n)if(n.hasOwnProperty(i)){let o=parseInt(i,10),a;if(o===7)a="1, 2 and 3";else{let s=[];for(let l=2;l>=0;l--){let r=Math.pow(2,l);o>=r&&(s.push(l+1),o-=r)}a=s.reverse().join(" and ")}e+=`<br>    ${n[i]} in frustum ${a}`}e+=`<br>Total: ${t.totalCommands}`}return e}function krt(t,e,n){let i=Math.min(n,e);return i=Math.max(i,t),i}var g5e=new di,E5e=new p;function CD(t,e){let n=this,i=t.canvas,o=new sp(i);this._eventHandler=o,this._scene=t,this._canvas=i,this._primitive=void 0,this._tile=void 0,this._modelMatrixPrimitive=void 0,this._performanceDisplay=void 0,this._performanceContainer=e;let a=this._scene.globe;a.depthTestAgainstTerrain=!0,this.frustums=!1,this.frustumPlanes=!1,this.performance=!1,this.shaderCacheText="",this.primitiveBoundingSphere=!1,this.primitiveReferenceFrame=!1,this.filterPrimitive=!1,this.tileBoundingSphere=!1,this.filterTile=!1,this.wireframe=!1,this.depthFrustum=1,this._numberOfFrustums=1,this.suspendUpdates=!1,this.tileCoordinates=!1,this.frustumStatisticText=!1,this.tileText="",this.hasPickedPrimitive=!1,this.hasPickedTile=!1,this.pickPrimitiveActive=!1,this.pickTileActive=!1,this.dropDownVisible=!0,this.generalVisible=!0,this.primitivesVisible=!1,this.terrainVisible=!1,this.depthFrustumText="",Lt.track(this,["frustums","frustumPlanes","performance","shaderCacheText","primitiveBoundingSphere","primitiveReferenceFrame","filterPrimitive","tileBoundingSphere","filterTile","wireframe","depthFrustum","suspendUpdates","tileCoordinates","frustumStatisticText","tileText","hasPickedPrimitive","hasPickedTile","pickPrimitiveActive","pickTileActive","dropDownVisible","generalVisible","primitivesVisible","terrainVisible","depthFrustumText"]),this._toggleDropDown=Ri(function(){n.dropDownVisible=!n.dropDownVisible}),this._toggleGeneral=Ri(function(){n.generalVisible=!n.generalVisible}),this._togglePrimitives=Ri(function(){n.primitivesVisible=!n.primitivesVisible}),this._toggleTerrain=Ri(function(){n.terrainVisible=!n.terrainVisible}),this._frustumsSubscription=Lt.getObservable(this,"frustums").subscribe(function(d){n._scene.debugShowFrustums=d,n._scene.requestRender()}),this._frustumPlanesSubscription=Lt.getObservable(this,"frustumPlanes").subscribe(function(d){n._scene.debugShowFrustumPlanes=d,n._scene.requestRender()}),this._performanceSubscription=Lt.getObservable(this,"performance").subscribe(function(d){d?n._performanceDisplay=new RW({container:n._performanceContainer}):n._performanceContainer.innerHTML=""}),this._showPrimitiveBoundingSphere=Ri(function(){return n._primitive.debugShowBoundingVolume=n.primitiveBoundingSphere,n._scene.requestRender(),!0}),this._primitiveBoundingSphereSubscription=Lt.getObservable(this,"primitiveBoundingSphere").subscribe(function(){n._showPrimitiveBoundingSphere()}),this._showPrimitiveReferenceFrame=Ri(function(){if(n.primitiveReferenceFrame){let d=n._primitive.modelMatrix;n._modelMatrixPrimitive=new D5({modelMatrix:d}),n._scene.primitives.add(n._modelMatrixPrimitive)}else c(n._modelMatrixPrimitive)&&(n._scene.primitives.remove(n._modelMatrixPrimitive),n._modelMatrixPrimitive=void 0);return n._scene.requestRender(),!0}),this._primitiveReferenceFrameSubscription=Lt.getObservable(this,"primitiveReferenceFrame").subscribe(function(){n._showPrimitiveReferenceFrame()}),this._doFilterPrimitive=Ri(function(){return n.filterPrimitive?n._scene.debugCommandFilter=function(d){return c(n._modelMatrixPrimitive)&&d.owner===n._modelMatrixPrimitive._primitive?!0:c(n._primitive)?d.owner===n._primitive||d.owner===n._primitive._billboardCollection||d.owner.primitive===n._primitive:!1}:n._scene.debugCommandFilter=void 0,!0}),this._filterPrimitiveSubscription=Lt.getObservable(this,"filterPrimitive").subscribe(function(){n._doFilterPrimitive(),n._scene.requestRender()}),this._wireframeSubscription=Lt.getObservable(this,"wireframe").subscribe(function(d){a._surface.tileProvider._debug.wireframe=d,n._scene.requestRender()}),this._depthFrustumSubscription=Lt.getObservable(this,"depthFrustum").subscribe(function(d){n._scene.debugShowDepthFrustum=d,n._scene.requestRender()}),this._incrementDepthFrustum=Ri(function(){let d=n.depthFrustum+1;return n.depthFrustum=krt(1,n._numberOfFrustums,d),n._scene.requestRender(),!0}),this._decrementDepthFrustum=Ri(function(){let d=n.depthFrustum-1;return n.depthFrustum=krt(1,n._numberOfFrustums,d),n._scene.requestRender(),!0}),this._suspendUpdatesSubscription=Lt.getObservable(this,"suspendUpdates").subscribe(function(d){a._surface._debug.suspendLodUpdate=d,d||(n.filterTile=!1)});let s;this._showTileCoordinates=Ri(function(){return n.tileCoordinates&&!c(s)?s=t.imageryLayers.addImageryProvider(new dD({tilingScheme:t.terrainProvider.tilingScheme})):!n.tileCoordinates&&c(s)&&(t.imageryLayers.remove(s),s=void 0),!0}),this._tileCoordinatesSubscription=Lt.getObservable(this,"tileCoordinates").subscribe(function(){n._showTileCoordinates(),n._scene.requestRender()}),this._tileBoundingSphereSubscription=Lt.getObservable(this,"tileBoundingSphere").subscribe(function(){n._showTileBoundingSphere(),n._scene.requestRender()}),this._showTileBoundingSphere=Ri(function(){return n.tileBoundingSphere?a._surface.tileProvider._debug.boundingSphereTile=n._tile:a._surface.tileProvider._debug.boundingSphereTile=void 0,n._scene.requestRender(),!0}),this._doFilterTile=Ri(function(){return n.filterTile?(n.suspendUpdates=!0,a._surface._tilesToRender=[],c(n._tile)&&n._tile.renderable&&a._surface._tilesToRender.push(n._tile)):n.suspendUpdates=!1,!0}),this._filterTileSubscription=Lt.getObservable(this,"filterTile").subscribe(function(){n.doFilterTile(),n._scene.requestRender()});function l(d){let m=n._scene.pick({x:d.position.x,y:d.position.y});c(m)&&(n.primitive=c(m.collection)?m.collection:m.primitive),n._scene.requestRender(),n.pickPrimitiveActive=!1}this._pickPrimitive=Ri(function(){n.pickPrimitiveActive=!n.pickPrimitiveActive}),this._pickPrimitiveActiveSubscription=Lt.getObservable(this,"pickPrimitiveActive").subscribe(function(d){d?o.setInputAction(l,ui.LEFT_CLICK):o.removeInputAction(ui.LEFT_CLICK)});function r(d){let m,h=a.ellipsoid,u=n._scene.camera.getPickRay(d.position,g5e),R=a.pick(u,n._scene,E5e);if(c(R)){let V=h.cartesianToCartographic(R),F=a._surface.tileProvider._tilesToRenderByTextureCount;for(let U=0;!m&&U<F.length;++U){let G=F[U];if(c(G))for(let A=0;!m&&A<G.length;++A){let S=G[A];Gt.contains(S.rectangle,V)&&(m=S)}}}n.tile=m,n.pickTileActive=!1}this._pickTile=Ri(function(){n.pickTileActive=!n.pickTileActive}),this._pickTileActiveSubscription=Lt.getObservable(this,"pickTileActive").subscribe(function(d){d?o.setInputAction(r,ui.LEFT_CLICK):o.removeInputAction(ui.LEFT_CLICK)}),this._removePostRenderEvent=t.postRender.addEventListener(function(){n._update()})}Object.defineProperties(CD.prototype,{scene:{get:function(){return this._scene}},performanceContainer:{get:function(){return this._performanceContainer}},toggleDropDown:{get:function(){return this._toggleDropDown}},showPrimitiveBoundingSphere:{get:function(){return this._showPrimitiveBoundingSphere}},showPrimitiveReferenceFrame:{get:function(){return this._showPrimitiveReferenceFrame}},doFilterPrimitive:{get:function(){return this._doFilterPrimitive}},incrementDepthFrustum:{get:function(){return this._incrementDepthFrustum}},decrementDepthFrustum:{get:function(){return this._decrementDepthFrustum}},showTileCoordinates:{get:function(){return this._showTileCoordinates}},showTileBoundingSphere:{get:function(){return this._showTileBoundingSphere}},doFilterTile:{get:function(){return this._doFilterTile}},toggleGeneral:{get:function(){return this._toggleGeneral}},togglePrimitives:{get:function(){return this._togglePrimitives}},toggleTerrain:{get:function(){return this._toggleTerrain}},pickPrimitive:{get:function(){return this._pickPrimitive}},pickTile:{get:function(){return this._pickTile}},selectParent:{get:function(){let t=this;return Ri(function(){t.tile=t.tile.parent})}},selectNW:{get:function(){let t=this;return Ri(function(){t.tile=t.tile.northwestChild})}},selectNE:{get:function(){let t=this;return Ri(function(){t.tile=t.tile.northeastChild})}},selectSW:{get:function(){let t=this;return Ri(function(){t.tile=t.tile.southwestChild})}},selectSE:{get:function(){let t=this;return Ri(function(){t.tile=t.tile.southeastChild})}},primitive:{get:function(){return this._primitive},set:function(t){let e=this._primitive;t!==e&&(this.hasPickedPrimitive=!0,c(e)&&(e.debugShowBoundingVolume=!1),this._scene.debugCommandFilter=void 0,c(this._modelMatrixPrimitive)&&(this._scene.primitives.remove(this._modelMatrixPrimitive),this._modelMatrixPrimitive=void 0),this._primitive=t,t.show=!1,setTimeout(function(){t.show=!0},50),this.showPrimitiveBoundingSphere(),this.showPrimitiveReferenceFrame(),this.doFilterPrimitive())}},tile:{get:function(){return this._tile},set:function(t){if(c(t)){this.hasPickedTile=!0;let e=this._tile;if(t!==e){this.tileText=`L: ${t.level} X: ${t.x} Y: ${t.y}`,this.tileText+=`<br>SW corner: ${t.rectangle.west}, ${t.rectangle.south}`,this.tileText+=`<br>NE corner: ${t.rectangle.east}, ${t.rectangle.north}`;let n=t.data;c(n)&&c(n.tileBoundingRegion)?this.tileText+=`<br>Min: ${n.tileBoundingRegion.minimumHeight} Max: ${n.tileBoundingRegion.maximumHeight}`:this.tileText+="<br>(Tile is not loaded)"}this._tile=t,this.showTileBoundingSphere(),this.doFilterTile()}else this.hasPickedTile=!1,this._tile=void 0}}});CD.prototype._update=function(){this.frustums&&(this.frustumStatisticText=T5e(this._scene.debugFrustumStatistics));let t=this._scene.numberOfFrustums;this._numberOfFrustums=t,this.depthFrustum=krt(1,t,this.depthFrustum),this.depthFrustumText=`${this.depthFrustum} of ${t}`,this.performance&&this._performanceDisplay.update(),this.primitiveReferenceFrame&&(this._modelMatrixPrimitive.modelMatrix=this._primitive.modelMatrix),this.shaderCacheText=`Cached shaders: ${this._scene.context.shaderCache.numberOfShaders}`};CD.prototype.isDestroyed=function(){return!1};CD.prototype.destroy=function(){return this._eventHandler.destroy(),this._removePostRenderEvent(),this._frustumsSubscription.dispose(),this._frustumPlanesSubscription.dispose(),this._performanceSubscription.dispose(),this._primitiveBoundingSphereSubscription.dispose(),this._primitiveReferenceFrameSubscription.dispose(),this._filterPrimitiveSubscription.dispose(),this._wireframeSubscription.dispose(),this._depthFrustumSubscription.dispose(),this._suspendUpdatesSubscription.dispose(),this._tileCoordinatesSubscription.dispose(),this._tileBoundingSphereSubscription.dispose(),this._filterTileSubscription.dispose(),this._pickPrimitiveActiveSubscription.dispose(),this._pickTileActiveSubscription.dispose(),At(this)};var ID=CD;function V4(t,e){t=Ui(t);let n=document.createElement("div"),i=new ID(e,n);this._viewModel=i,this._container=t;let o=document.createElement("div");this._element=o;let a=document.createElement("div");a.textContent="Cesium Inspector",a.className="cesium-cesiumInspector-button",a.setAttribute("data-bind","click: toggleDropDown"),o.appendChild(a),o.className="cesium-cesiumInspector",o.setAttribute("data-bind",'css: { "cesium-cesiumInspector-visible" : dropDownVisible, "cesium-cesiumInspector-hidden" : !dropDownVisible }'),t.appendChild(this._element);let s=document.createElement("div");s.className="cesium-cesiumInspector-dropDown",o.appendChild(s);let l=gd.createSection,r=gd.createCheckbox,d=l(s,"General","generalVisible","toggleGeneral"),m=r("Show Frustums","frustums"),h=document.createElement("div");h.className="cesium-cesiumInspector-frustumStatistics",h.setAttribute("data-bind","visible: frustums, html: frustumStatisticText"),m.appendChild(h),d.appendChild(m),d.appendChild(r("Show Frustum Planes","frustumPlanes")),d.appendChild(r("Performance Display","performance")),n.className="cesium-cesiumInspector-performanceDisplay",d.appendChild(n);let u=document.createElement("div");u.className="cesium-cesiumInspector-shaderCache",u.setAttribute("data-bind","html: shaderCacheText"),d.appendChild(u);let R=document.createElement("div");d.appendChild(R);let V=document.createElement("span");V.setAttribute("data-bind",'html: "     Frustum:"'),R.appendChild(V);let F=document.createElement("span");F.setAttribute("data-bind","text: depthFrustumText"),R.appendChild(F);let U=document.createElement("input");U.type="button",U.value="-",U.className="cesium-cesiumInspector-pickButton",U.setAttribute("data-bind","click: decrementDepthFrustum"),R.appendChild(U);let G=document.createElement("input");G.type="button",G.value="+",G.className="cesium-cesiumInspector-pickButton",G.setAttribute("data-bind","click: incrementDepthFrustum"),R.appendChild(G);let A=l(s,"Primitives","primitivesVisible","togglePrimitives"),S=document.createElement("div");S.className="cesium-cesiumInspector-pickSection",A.appendChild(S);let g=document.createElement("input");g.type="button",g.value="Pick a primitive",g.className="cesium-cesiumInspector-pickButton",g.setAttribute("data-bind",'css: {"cesium-cesiumInspector-pickButtonHighlight" : pickPrimitiveActive}, click: pickPrimitive');let C=document.createElement("div");C.className="cesium-cesiumInspector-center",C.appendChild(g),S.appendChild(C),S.appendChild(r("Show bounding sphere","primitiveBoundingSphere","hasPickedPrimitive")),S.appendChild(r("Show reference frame","primitiveReferenceFrame","hasPickedPrimitive")),this._primitiveOnly=r("Show only selected","filterPrimitive","hasPickedPrimitive"),S.appendChild(this._primitiveOnly);let y=l(s,"Terrain","terrainVisible","toggleTerrain"),Y=document.createElement("div");Y.className="cesium-cesiumInspector-pickSection",y.appendChild(Y);let Q=document.createElement("input");Q.type="button",Q.value="Pick a tile",Q.className="cesium-cesiumInspector-pickButton",Q.setAttribute("data-bind",'css: {"cesium-cesiumInspector-pickButtonHighlight" : pickTileActive}, click: pickTile'),C=document.createElement("div"),C.appendChild(Q),C.className="cesium-cesiumInspector-center",Y.appendChild(C);let J=document.createElement("div");Y.appendChild(J);let M=document.createElement("input");M.type="button",M.value="Parent",M.className="cesium-cesiumInspector-pickButton",M.setAttribute("data-bind","click: selectParent");let Z=document.createElement("input");Z.type="button",Z.value="NW",Z.className="cesium-cesiumInspector-pickButton",Z.setAttribute("data-bind","click: selectNW");let E=document.createElement("input");E.type="button",E.value="NE",E.className="cesium-cesiumInspector-pickButton",E.setAttribute("data-bind","click: selectNE");let I=document.createElement("input");I.type="button",I.value="SW",I.className="cesium-cesiumInspector-pickButton",I.setAttribute("data-bind","click: selectSW");let B=document.createElement("input");B.type="button",B.value="SE",B.className="cesium-cesiumInspector-pickButton",B.setAttribute("data-bind","click: selectSE");let X=document.createElement("div");X.className="cesium-cesiumInspector-tileText",J.className="cesium-cesiumInspector-frustumStatistics",J.appendChild(X),J.setAttribute("data-bind","visible: hasPickedTile"),X.setAttribute("data-bind","html: tileText");let _=document.createElement("div");_.className="cesium-cesiumInspector-relativeText",_.textContent="Select relative:",J.appendChild(_);let P=document.createElement("table"),w=document.createElement("tr"),z=document.createElement("tr"),H=document.createElement("td");H.appendChild(M);let nt=document.createElement("td");nt.appendChild(Z);let $=document.createElement("td");$.appendChild(E),w.appendChild(H),w.appendChild(nt),w.appendChild($);let dt=document.createElement("td"),q=document.createElement("td");q.appendChild(I);let at=document.createElement("td");at.appendChild(B),z.appendChild(dt),z.appendChild(q),z.appendChild(at),P.appendChild(w),P.appendChild(z),J.appendChild(P),Y.appendChild(r("Show bounding volume","tileBoundingSphere","hasPickedTile")),Y.appendChild(r("Show only selected","filterTile","hasPickedTile")),y.appendChild(r("Wireframe","wireframe")),y.appendChild(r("Suspend LOD update","suspendUpdates")),y.appendChild(r("Show tile coordinates","tileCoordinates")),Lt.applyBindings(i,this._element)}Object.defineProperties(V4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});V4.prototype.isDestroyed=function(){return!1};V4.prototype.destroy=function(){return Lt.cleanNode(this._element),this._container.removeChild(this._element),this.viewModel.destroy(),At(this)};var ND=V4;var XFa=b(W(),1);var NFa=b(W(),1);function u4(t,e){c(e)||(e=document.body),e=Ui(e);let n=this,i=Lt.observable(Ds.fullscreen),o=Lt.observable(Ds.enabled),a=e.ownerDocument;this.isFullscreen=void 0,Lt.defineProperty(this,"isFullscreen",{get:function(){return i()}}),this.isFullscreenEnabled=void 0,Lt.defineProperty(this,"isFullscreenEnabled",{get:function(){return o()},set:function(s){o(s&&Ds.enabled)}}),this.tooltip=void 0,Lt.defineProperty(this,"tooltip",function(){return this.isFullscreenEnabled?i()?"Exit full screen":"Full screen":"Full screen unavailable"}),this._command=Ri(function(){Ds.fullscreen?Ds.exitFullscreen():Ds.requestFullscreen(n._fullscreenElement)},Lt.getObservable(this,"isFullscreenEnabled")),this._fullscreenElement=f(Ui(t),a.body),this._callback=function(){i(Ds.fullscreen)},a.addEventListener(Ds.changeEventName,this._callback)}Object.defineProperties(u4.prototype,{fullscreenElement:{get:function(){return this._fullscreenElement},set:function(t){this._fullscreenElement=t}},command:{get:function(){return this._command}}});u4.prototype.isDestroyed=function(){return!1};u4.prototype.destroy=function(){document.removeEventListener(Ds.changeEventName,this._callback),At(this)};var yD=u4;var C5e="M 83.96875 17.5625 L 83.96875 17.59375 L 76.65625 24.875 L 97.09375 24.96875 L 76.09375 45.96875 L 81.9375 51.8125 L 102.78125 30.9375 L 102.875 51.15625 L 110.15625 43.875 L 110.1875 17.59375 L 83.96875 17.5625 z M 44.125 17.59375 L 17.90625 17.625 L 17.9375 43.90625 L 25.21875 51.1875 L 25.3125 30.96875 L 46.15625 51.8125 L 52 45.96875 L 31 25 L 51.4375 24.90625 L 44.125 17.59375 z M 46.0625 76.03125 L 25.1875 96.875 L 25.09375 76.65625 L 17.8125 83.9375 L 17.8125 110.21875 L 44 110.25 L 51.3125 102.9375 L 30.90625 102.84375 L 51.875 81.875 L 46.0625 76.03125 z M 82 76.15625 L 76.15625 82 L 97.15625 103 L 76.71875 103.0625 L 84.03125 110.375 L 110.25 110.34375 L 110.21875 84.0625 L 102.9375 76.8125 L 102.84375 97 L 82 76.15625 z",I5e="M 104.34375 17.5625 L 83.5 38.4375 L 83.40625 18.21875 L 76.125 25.5 L 76.09375 51.78125 L 102.3125 51.8125 L 102.3125 51.78125 L 109.625 44.5 L 89.1875 44.40625 L 110.1875 23.40625 L 104.34375 17.5625 z M 23.75 17.59375 L 17.90625 23.4375 L 38.90625 44.4375 L 18.5 44.53125 L 25.78125 51.8125 L 52 51.78125 L 51.96875 25.53125 L 44.6875 18.25 L 44.625 38.46875 L 23.75 17.59375 z M 25.6875 76.03125 L 18.375 83.3125 L 38.78125 83.40625 L 17.8125 104.40625 L 23.625 110.25 L 44.5 89.375 L 44.59375 109.59375 L 51.875 102.3125 L 51.875 76.0625 L 25.6875 76.03125 z M 102.375 76.15625 L 76.15625 76.1875 L 76.1875 102.4375 L 83.46875 109.71875 L 83.5625 89.53125 L 104.40625 110.375 L 110.25 104.53125 L 89.25 83.53125 L 109.6875 83.46875 L 102.375 76.15625 z";function Z4(t,e){t=Ui(t);let n=new yD(e,t);n._exitFullScreenPath=I5e,n._enterFullScreenPath=C5e;let i=document.createElement("button");i.type="button",i.className="cesium-button cesium-fullscreenButton",i.setAttribute("data-bind","attr: { title: tooltip },click: command,enable: isFullscreenEnabled,cesiumSvgPath: { path: isFullscreen ? _exitFullScreenPath : _enterFullScreenPath, width: 128, height: 128 }"),t.appendChild(i),Lt.applyBindings(n,i),this._container=t,this._viewModel=n,this._element=i}Object.defineProperties(Z4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});Z4.prototype.isDestroyed=function(){return!1};Z4.prototype.destroy=function(){return this._viewModel.destroy(),Lt.cleanNode(this._element),this._container.removeChild(this._element),At(this)};var BD=Z4;var jFa=b(W(),1);var OFa=b(W(),1);var U2t=1e3;function YV(t){c(t.geocoderServices)?this._geocoderServices=t.geocoderServices:this._geocoderServices=[new N5({scene:t.scene})],this._viewContainer=t.container,this._scene=t.scene,this._flightDuration=t.flightDuration,this._searchText="",this._isSearchInProgress=!1,this._wasGeocodeCancelled=!1,this._previousCredits=[],this._complete=new It,this._suggestions=[],this._selectedSuggestion=void 0,this._showSuggestions=!0,this._handleArrowDown=A2t,this._handleArrowUp=G2t;let e=this;this._suggestionsVisible=Lt.pureComputed(function(){let o=Lt.getObservable(e,"_suggestions")().length>0,a=Lt.getObservable(e,"_showSuggestions")();return o&&a}),this._searchCommand=Ri(function(i){if(i=f(i,IU.SEARCH),e._focusTextbox=!1,c(e._selectedSuggestion))return e.activateSuggestion(e._selectedSuggestion),!1;if(e.hideSuggestions(),e.isSearchInProgress)Y5e(e);else return Q5e(e,e._geocoderServices,i)}),this.deselectSuggestion=function(){e._selectedSuggestion=void 0},this.handleKeyDown=function(i,o){let a=o.key==="ArrowDown"||o.key==="Down"||o.keyCode===40,s=o.key==="ArrowUp"||o.key==="Up"||o.keyCode===38;return(a||s)&&o.preventDefault(),!0},this.handleKeyUp=function(i,o){let a=o.key==="ArrowDown"||o.key==="Down"||o.keyCode===40,s=o.key==="ArrowUp"||o.key==="Up"||o.keyCode===38,l=o.key==="Enter"||o.keyCode===13;return s?G2t(e):a?A2t(e):l&&e._searchCommand(),!0},this.activateSuggestion=function(i){e.hideSuggestions(),e._searchText=i.displayName;let o=i.destination;g2t(e),e.destinationFound(e,o)},this.hideSuggestions=function(){e._showSuggestions=!1,e._selectedSuggestion=void 0},this.showSuggestions=function(){e._showSuggestions=!0},this.handleMouseover=function(i,o){i!==e._selectedSuggestion&&(e._selectedSuggestion=i)},this.keepExpanded=!1,this.autoComplete=f(t.autocomplete,!0),this.destinationFound=f(t.destinationFound,YV.flyToDestination),this._focusTextbox=!1,Lt.track(this,["_searchText","_isSearchInProgress","keepExpanded","_suggestions","_selectedSuggestion","_showSuggestions","_focusTextbox"]);let n=Lt.getObservable(this,"_searchText");n.extend({rateLimit:{timeout:500}}),this._suggestionSubscription=n.subscribe(function(){YV._updateSearchSuggestions(e)}),this.isSearchInProgress=void 0,Lt.defineProperty(this,"isSearchInProgress",{get:function(){return this._isSearchInProgress}}),this.searchText=void 0,Lt.defineProperty(this,"searchText",{get:function(){return this.isSearchInProgress?"Searching...":this._searchText},set:function(i){this._searchText=i}}),this.flightDuration=void 0,Lt.defineProperty(this,"flightDuration",{get:function(){return this._flightDuration},set:function(i){this._flightDuration=i}})}Object.defineProperties(YV.prototype,{complete:{get:function(){return this._complete}},scene:{get:function(){return this._scene}},search:{get:function(){return this._searchCommand}},selectedSuggestion:{get:function(){return this._selectedSuggestion}},suggestions:{get:function(){return this._suggestions}}});YV.prototype.destroy=function(){this._suggestionSubscription.dispose()};function G2t(t){if(t._suggestions.length===0)return;let e=t._suggestions.indexOf(t._selectedSuggestion);if(e===-1||e===0){t._selectedSuggestion=void 0;return}let n=e-1;t._selectedSuggestion=t._suggestions[n],YV._adjustSuggestionsScroll(t,n)}function A2t(t){if(t._suggestions.length===0)return;let e=t._suggestions.length,i=(t._suggestions.indexOf(t._selectedSuggestion)+1)%e;t._selectedSuggestion=t._suggestions[i],YV._adjustSuggestionsScroll(t,i)}function N5e(t,e){let n=c(e)?e.availability:void 0;return c(n)?zT(e,[t]).then(function(i){return t=i[0],t.height+=U2t,t}):(t.height+=U2t,Promise.resolve(t))}function y5e(t,e){let n=t._scene,o=n.mapProjection.ellipsoid,a=n.camera,s=n.terrainProvider,l=e,r;return e instanceof Gt?k.equalsEpsilon(e.south,e.north,k.EPSILON7)&&k.equalsEpsilon(e.east,e.west,k.EPSILON7)?e=Gt.center(e):r=rg(e,n):e=o.cartesianToCartographic(e),c(r)||(r=N5e(e,s)),r.then(function(d){l=o.cartographicToCartesian(d)}).finally(function(){a.flyTo({destination:l,complete:function(){t._complete.raiseEvent()},duration:t._flightDuration,endTransform:L.IDENTITY})})}async function B5e(t,e,n){try{return{state:"fulfilled",value:await t.geocode(e,n),credits:t.credit}}catch(i){return{state:"rejected",reason:i}}}async function Q5e(t,e,n){let i=t._searchText;if(T2t(i)){t.showSuggestions();return}t._isSearchInProgress=!0,t._wasGeocodeCancelled=!1;let o,a;for(o=0;o<e.length;o++){if(t._wasGeocodeCancelled)return;if(a=await B5e(e[o],i,n),c(a)&&a.state==="fulfilled"&&a.value.length>0)break}if(t._wasGeocodeCancelled)return;t._isSearchInProgress=!1,xrt(t);let s=a.value;if(a.state==="fulfilled"&&c(s)&&s.length>0){t._searchText=s[0].displayName,t.destinationFound(t,s[0].destination);let l=S2t(t,sN.getCreditsFromResult(s[0]));c(l)||Yrt(t,e[o].credit);return}t._searchText=`${i} (not found)`}function Yrt(t,e){c(e)&&!t._scene.isDestroyed()&&!t._scene.frameState.creditDisplay.isDestroyed()&&(t._scene.frameState.creditDisplay.addStaticCredit(e),t._previousCredits.push(e))}function S2t(t,e){return c(e)&&e.forEach(n=>Yrt(t,n)),e}function xrt(t){!t._scene.isDestroyed()&&!t._scene.frameState.creditDisplay.isDestroyed()&&t._previousCredits.forEach(e=>{t._scene.frameState.creditDisplay.removeStaticCredit(e)}),t._previousCredits.length=0}function k5e(t,e){let n=Ui(t._viewContainer),i=n.getElementsByClassName("search-results")[0],a=n.getElementsByTagName("li")[e];if(e===0){i.scrollTop=0;return}let s=a.offsetTop;s+a.clientHeight>i.clientHeight?i.scrollTop=s+a.clientHeight:s<i.scrollTop&&(i.scrollTop=s)}function Y5e(t){t._isSearchInProgress&&(t._isSearchInProgress=!1,t._wasGeocodeCancelled=!0)}function T2t(t){return/^\s*$/.test(t)}function g2t(t){Lt.getObservable(t,"_suggestions").removeAll()}async function x5e(t){if(!t.autoComplete)return;let e=t._searchText;if(g2t(t),xrt(t),!T2t(e))for(let n of t._geocoderServices){let i=await n.geocode(e,IU.AUTOCOMPLETE);if(t._suggestions=t._suggestions.concat(i),i.length>0){let o=!0;i.forEach(a=>{let s=sN.getCreditsFromResult(a);o=o&&!c(s),S2t(t,s)}),o&&Yrt(t,n.credit)}if(t._suggestions.length>=5)return}}YV.flyToDestination=y5e;YV._updateSearchSuggestions=x5e;YV._adjustSuggestionsScroll=k5e;YV.prototype.isDestroyed=function(){return!1};YV.prototype.destroy=function(){return xrt(this),At(this)};var QD=YV;var X5e="M29.772,26.433l-7.126-7.126c0.96-1.583,1.523-3.435,1.524-5.421C24.169,8.093,19.478,3.401,13.688,3.399C7.897,3.401,3.204,8.093,3.204,13.885c0,5.789,4.693,10.481,10.484,10.481c1.987,0,3.839-0.563,5.422-1.523l7.128,7.127L29.772,26.433zM7.203,13.885c0.006-3.582,2.903-6.478,6.484-6.486c3.579,0.008,6.478,2.904,6.484,6.486c-0.007,3.58-2.905,6.476-6.484,6.484C10.106,20.361,7.209,17.465,7.203,13.885z",J5e="M24.778,21.419 19.276,15.917 24.777,10.415 21.949,7.585 16.447,13.087 10.945,7.585 8.117,10.415 13.618,15.917 8.116,21.419 10.946,24.248 16.447,18.746 21.948,24.248z";function R4(t){let e=Ui(t.container),n=new QD(t);n._startSearchPath=X5e,n._stopSearchPath=J5e;let i=document.createElement("form");i.setAttribute("data-bind","submit: search");let o=document.createElement("input");o.type="search",o.className="cesium-geocoder-input",o.setAttribute("placeholder","Enter an address or landmark..."),o.setAttribute("data-bind",'textInput: searchText,disable: isSearchInProgress,event: { keyup: handleKeyUp, keydown: handleKeyDown, mouseover: deselectSuggestion },css: { "cesium-geocoder-input-wide" : keepExpanded || searchText.length > 0 },hasFocus: _focusTextbox'),this._onTextBoxFocus=function(){setTimeout(function(){o.select()},0)},o.addEventListener("focus",this._onTextBoxFocus,!1),i.appendChild(o),this._textBox=o;let a=document.createElement("span");a.className="cesium-geocoder-searchButton",a.setAttribute("data-bind","click: search,cesiumSvgPath: { path: isSearchInProgress ? _stopSearchPath : _startSearchPath, width: 32, height: 32 }"),i.appendChild(a),e.appendChild(i);let s=document.createElement("div");s.className="search-results",s.setAttribute("data-bind","visible: _suggestionsVisible");let l=document.createElement("ul");l.setAttribute("data-bind","foreach: _suggestions");let r=document.createElement("li");l.appendChild(r),r.setAttribute("data-bind","text: $data.displayName, click: $parent.activateSuggestion, event: { mouseover: $parent.handleMouseover}, css: { active: $data === $parent._selectedSuggestion }"),s.appendChild(l),e.appendChild(s),Lt.applyBindings(n,i),Lt.applyBindings(n,s),this._container=e,this._searchSuggestionsContainer=s,this._viewModel=n,this._form=i,this._onInputBegin=function(d){let m=d.target;typeof d.composedPath=="function"&&(m=d.composedPath()[0]),e.contains(m)||(n._focusTextbox=!1,n.hideSuggestions())},this._onInputEnd=function(d){n._focusTextbox=!0,n.showSuggestions()},In.supportsPointerEvents()?(document.addEventListener("pointerdown",this._onInputBegin,!0),e.addEventListener("pointerup",this._onInputEnd,!0),e.addEventListener("pointercancel",this._onInputEnd,!0)):(document.addEventListener("mousedown",this._onInputBegin,!0),e.addEventListener("mouseup",this._onInputEnd,!0),document.addEventListener("touchstart",this._onInputBegin,!0),e.addEventListener("touchend",this._onInputEnd,!0),e.addEventListener("touchcancel",this._onInputEnd,!0))}Object.defineProperties(R4.prototype,{container:{get:function(){return this._container}},searchSuggestionsContainer:{get:function(){return this._searchSuggestionsContainer}},viewModel:{get:function(){return this._viewModel}}});R4.prototype.isDestroyed=function(){return!1};R4.prototype.destroy=function(){let t=this._container;return In.supportsPointerEvents()?(document.removeEventListener("pointerdown",this._onInputBegin,!0),t.removeEventListener("pointerup",this._onInputEnd,!0)):(document.removeEventListener("mousedown",this._onInputBegin,!0),t.removeEventListener("mouseup",this._onInputEnd,!0),document.removeEventListener("touchstart",this._onInputBegin,!0),t.removeEventListener("touchend",this._onInputEnd,!0)),this._viewModel.destroy(),Lt.cleanNode(this._form),Lt.cleanNode(this._searchSuggestionsContainer),t.removeChild(this._form),t.removeChild(this._searchSuggestionsContainer),this._textBox.removeEventListener("focus",this._onTextBoxFocus,!1),At(this)};var kD=R4;var rUa=b(W(),1);var eUa=b(W(),1);function E2t(t,e){this._scene=t,this._duration=e;let n=this;this._command=Ri(function(){n._scene.camera.flyHome(n._duration)}),this.tooltip="View Home",Lt.track(this,["tooltip"])}Object.defineProperties(E2t.prototype,{scene:{get:function(){return this._scene}},command:{get:function(){return this._command}},duration:{get:function(){return this._duration},set:function(t){this._duration=t}}});var YD=E2t;function b4(t,e,n){t=Ui(t);let i=new YD(e,n);i._svgPath="M14,4l-10,8.75h20l-4.25-3.7188v-4.6562h-2.812v2.1875l-2.938-2.5625zm-7.0938,9.906v10.094h14.094v-10.094h-14.094zm2.1876,2.313h3.3122v4.25h-3.3122v-4.25zm5.8442,1.281h3.406v6.438h-3.406v-6.438z";let o=document.createElement("button");o.type="button",o.className="cesium-button cesium-toolbar-button cesium-home-button",o.setAttribute("data-bind","attr: { title: tooltip },click: command,cesiumSvgPath: { path: _svgPath, width: 28, height: 28 }"),t.appendChild(o),Lt.applyBindings(i,o),this._container=t,this._viewModel=i,this._element=o}Object.defineProperties(b4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});b4.prototype.isDestroyed=function(){return!1};b4.prototype.destroy=function(){return Lt.cleanNode(this._element),this._container.removeChild(this._element),At(this)};var xD=b4;var bUa=b(W(),1);var hUa=b(W(),1);function L5e(t,e){e.currentTarget.parentElement.parentElement.querySelector(`#${t.name}-expander`).classList.toggle("active"),e.currentTarget.textContent=e.currentTarget.textContent==="+"?"-":"+"}function I2t(t,e){Lt.track(t);for(let n=0;n<t.sublayers.length;n++)I2t(t.sublayers[n],e)}function W4(t){return t.modelName==="FullModel"}function N2t(t){return t.modelName==="Overview"}function y2t(t){return N2t(t)||W4(t)}function C2t(t,e){if(y2t(t)){t.visibility=!1;for(let i=0;i<t.sublayers.length;i++)t.sublayers[i].visibility=!0;let n={name:t.name,modelName:t.modelName,disable:Lt.observable(!1),index:e.sublayers.length};return e.topLayers.push(n),e.sublayers.push(t),n}}function M5e(t,e){if(y2t(t)){e.sublayers.forEach(i=>i.visibility=!1),e.sublayers[t.index].visibility=!0;let n=document.getElementById("bsl-wrapper");W4(t)?(e.currentLevel=e.selectedLevel,n.style.display="block"):(e.selectedLevel=e.currentLevel,e.currentLevel="All",n.style.display="none")}}async function _5e(t,e){try{let n=t.getAttributeNames();for(let i=0;i<n.length;i++)if(n[i]==="BldgLevel"){let o=t.getAttributeValues(n[i]);for(let a=0;a<o.length;a++)e.push(o[a])}e.sort((i,o)=>i-o),e.unshift("All")}catch(n){console.log(`There was an error getting attributes: ${n}`)}}function D5e(t){let e=this;this.levels=[],this.viewModel={sublayers:[],levels:this.levels,currentLevel:Lt.observable(),selectedLevel:"All",topLayers:[{name:"Select a layer to explore...",disable:Lt.observable(!0),index:-1}],currentLayer:Lt.observable(),expandClickHandler:L5e,setOptionDisable:function(i,o){Lt.applyBindingsToNode(i,{disable:o.disable},o)},defaultLayer:void 0},this.viewModel.currentLayer.subscribe(function(i){M5e(i,e.viewModel)});let n=t.sublayers;for(let i=0;i<n.length;i++){I2t(n[i],this.viewModel);let o=C2t(n[i],this.viewModel);c(o)&&(N2t(o)||!c(this.viewModel.defaultLayer)&&W4(o))&&(this.viewModel.defaultLayer=o)}if(this.viewModel.topLayers.length===1&&n.length>0){t.show=!1;let i={name:"Full Model",modelName:"FullModel",visibility:t.show,sublayers:t.sublayers};this.viewModel.defaultLayer=C2t(i,this.viewModel),this.viewModel.currentLayer.subscribe(function(o){t.show=W4(o)})}else this.viewModel.topLayers.length===1&&(this.viewModel.topLayers[0].name="Building layers not found");return _5e(t,this.levels),this.viewModel.currentLevel.subscribe(function(i){i!=="All"?t.filterByAttributes([{name:"BldgLevel",values:[i]}]):t.filterByAttributes()}),this.viewModel}var XD=D5e;function O5e(t,e){let n=document.getElementById(t),i=document.createElement("div");i.classList.add("cesium-viewer-i3s-explorer"),i.innerHTML=` <h3>Building explorer</h3> <select data-bind="options: topLayers, optionsText: 'name', optionsAfterRender: setOptionDisable, value: currentLayer" @@ -15574,8 +15574,8 @@ http://www.naturalearthdata.com/`,category:"Cesium ion",creationFunction:functio </li> </ul> </ul> - </div>`,n.appendChild(i);let o=new XD(e);Lt.track(o),Lt.applyBindings(o,n),c(o.defaultLayer)&&(o.currentLayer=o.defaultLayer)}var Xrt=O5e;var CUa=R(W(),1);var UUa=R(W(),1);var H5e="M 13.84375 7.03125 C 11.412798 7.03125 9.46875 8.975298 9.46875 11.40625 L 9.46875 11.59375 L 2.53125 7.21875 L 2.53125 24.0625 L 9.46875 19.6875 C 9.4853444 22.104033 11.423165 24.0625 13.84375 24.0625 L 25.875 24.0625 C 28.305952 24.0625 30.28125 22.087202 30.28125 19.65625 L 30.28125 11.40625 C 30.28125 8.975298 28.305952 7.03125 25.875 7.03125 L 13.84375 7.03125 z",w5e="M 27.34375 1.65625 L 5.28125 27.9375 L 8.09375 30.3125 L 30.15625 4.03125 L 27.34375 1.65625 z M 13.84375 7.03125 C 11.412798 7.03125 9.46875 8.975298 9.46875 11.40625 L 9.46875 11.59375 L 2.53125 7.21875 L 2.53125 24.0625 L 9.46875 19.6875 C 9.4724893 20.232036 9.5676108 20.7379 9.75 21.21875 L 21.65625 7.03125 L 13.84375 7.03125 z M 28.21875 7.71875 L 14.53125 24.0625 L 25.875 24.0625 C 28.305952 24.0625 30.28125 22.087202 30.28125 19.65625 L 30.28125 11.40625 C 30.28125 9.8371439 29.456025 8.4902779 28.21875 7.71875 z";function Jrt(){this._cameraClicked=new It,this._closeClicked=new It,this.maxHeight=500,this.enableCamera=!1,this.isCameraTracking=!1,this.showInfo=!1,this.titleText="",this.description="",Lt.track(this,["showInfo","titleText","description","maxHeight","enableCamera","isCameraTracking"]),this._loadingIndicatorHtml='<div class="cesium-infoBox-loadingContainer"><span class="cesium-infoBox-loading"></span></div>',this.cameraIconPath=void 0,Lt.defineProperty(this,"cameraIconPath",{get:function(){return!this.enableCamera||this.isCameraTracking?w5e:H5e}}),Lt.defineProperty(this,"_bodyless",{get:function(){return!c(this.description)||this.description.length===0}})}Jrt.prototype.maxHeightOffset=function(t){return`${this.maxHeight-t}px`};Object.defineProperties(Jrt.prototype,{cameraClicked:{get:function(){return this._cameraClicked}},closeClicked:{get:function(){return this._closeClicked}}});var JD=Jrt;function f4(t){t=Ui(t);let e=document.createElement("div");e.className="cesium-infoBox",e.setAttribute("data-bind",'css: { "cesium-infoBox-visible" : showInfo, "cesium-infoBox-bodyless" : _bodyless }'),t.appendChild(e);let n=document.createElement("div");n.className="cesium-infoBox-title",n.setAttribute("data-bind","text: titleText"),e.appendChild(n);let i=document.createElement("button");i.type="button",i.className="cesium-button cesium-infoBox-camera",i.setAttribute("data-bind",'attr: { title: "Focus camera on object" },click: function () { cameraClicked.raiseEvent(this); },enable: enableCamera,cesiumSvgPath: { path: cameraIconPath, width: 32, height: 32 }'),e.appendChild(i);let o=document.createElement("button");o.type="button",o.className="cesium-infoBox-close",o.setAttribute("data-bind","click: function () { closeClicked.raiseEvent(this); }"),o.innerHTML="×",e.appendChild(o);let a=document.createElement("iframe");a.className="cesium-infoBox-iframe",a.setAttribute("sandbox","allow-same-origin allow-popups allow-forms"),a.setAttribute("data-bind","style : { maxHeight : maxHeightOffset(40) }"),a.setAttribute("allowfullscreen",!0),e.appendChild(a);let s=new JD;Lt.applyBindings(s,e),this._container=t,this._element=e,this._frame=a,this._viewModel=s,this._descriptionSubscription=void 0;let l=this;a.addEventListener("load",function(){let r=a.contentDocument,d=r.createElement("link");d.href=Dn("Widgets/InfoBox/InfoBoxDescription.css"),d.rel="stylesheet",d.type="text/css";let m=r.createElement("div");m.className="cesium-infoBox-description",r.head.appendChild(d),r.body.appendChild(m),l._descriptionSubscription=od(s,"description",function(h){a.style.height="5px",m.innerHTML=h;let Z=null,b=m.firstElementChild;if(b!==null&&m.childNodes.length===1){let F=window.getComputedStyle(b);if(F!==null){let U=F["background-color"],G=v.fromCssColorString(U);c(G)&&G.alpha!==0&&(Z=F["background-color"])}}e.style["background-color"]=Z;let u=m.getBoundingClientRect().height;a.style.height=`${u}px`})}),a.setAttribute("src","about:blank")}Object.defineProperties(f4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}},frame:{get:function(){return this._frame}}});f4.prototype.isDestroyed=function(){return!1};f4.prototype.destroy=function(){let t=this._container;return Lt.cleanNode(this._element),t.removeChild(this._element),c(this._descriptionSubscription)&&this._descriptionSubscription.dispose(),At(this)};var LD=f4;var LUa=R(W(),1);var BUa=R(W(),1);function Bkt(){this.showInstructions=!1;let t=this;this._command=bi(function(){t.showInstructions=!t.showInstructions}),this._showClick=bi(function(){t._touch=!1}),this._showTouch=bi(function(){t._touch=!0}),this._touch=!1,this.tooltip="Navigation Instructions",Lt.track(this,["tooltip","showInstructions","_touch"])}Object.defineProperties(Bkt.prototype,{command:{get:function(){return this._command}},showClick:{get:function(){return this._showClick}},showTouch:{get:function(){return this._showTouch}}});var MD=Bkt;function F4(t){let e=Ui(t.container),n=new MD,i=f(t.instructionsInitiallyVisible,!1);n.showInstructions=i,n._svgPath="M16,1.466C7.973,1.466,1.466,7.973,1.466,16c0,8.027,6.507,14.534,14.534,14.534c8.027,0,14.534-6.507,14.534-14.534C30.534,7.973,24.027,1.466,16,1.466z M17.328,24.371h-2.707v-2.596h2.707V24.371zM17.328,19.003v0.858h-2.707v-1.057c0-3.19,3.63-3.696,3.63-5.963c0-1.034-0.924-1.826-2.134-1.826c-1.254,0-2.354,0.924-2.354,0.924l-1.541-1.915c0,0,1.519-1.584,4.137-1.584c2.487,0,4.796,1.54,4.796,4.136C21.156,16.208,17.328,16.627,17.328,19.003z";let o=document.createElement("span");o.className="cesium-navigationHelpButton-wrapper",e.appendChild(o);let a=document.createElement("button");a.type="button",a.className="cesium-button cesium-toolbar-button cesium-navigation-help-button",a.setAttribute("data-bind","attr: { title: tooltip },click: command,cesiumSvgPath: { path: _svgPath, width: 32, height: 32 }"),o.appendChild(a);let s=document.createElement("div");s.className="cesium-navigation-help",s.setAttribute("data-bind",'css: { "cesium-navigation-help-visible" : showInstructions}'),o.appendChild(s);let l=document.createElement("button");l.type="button",l.className="cesium-navigation-button cesium-navigation-button-left",l.setAttribute("data-bind",'click: showClick, css: {"cesium-navigation-button-selected": !_touch, "cesium-navigation-button-unselected": _touch}');let r=document.createElement("img");r.src=Dn("Widgets/Images/NavigationHelp/Mouse.svg"),r.className="cesium-navigation-button-icon",r.style.width="25px",r.style.height="25px",l.appendChild(r),l.appendChild(document.createTextNode("Mouse"));let d=document.createElement("button");d.type="button",d.className="cesium-navigation-button cesium-navigation-button-right",d.setAttribute("data-bind",'click: showTouch, css: {"cesium-navigation-button-selected": _touch, "cesium-navigation-button-unselected": !_touch}');let m=document.createElement("img");m.src=Dn("Widgets/Images/NavigationHelp/Touch.svg"),m.className="cesium-navigation-button-icon",m.style.width="25px",m.style.height="25px",d.appendChild(m),d.appendChild(document.createTextNode("Touch")),s.appendChild(l),s.appendChild(d);let h=document.createElement("div");h.className="cesium-click-navigation-help cesium-navigation-help-instructions",h.setAttribute("data-bind",'css: { "cesium-click-navigation-help-visible" : !_touch}'),h.innerHTML=` <table> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/MouseLeft.svg")}" width="48" height="48" /></td> <td> <div class="cesium-navigation-help-pan">Pan view</div> <div class="cesium-navigation-help-details">Left click + drag</div> </td> </tr> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/MouseRight.svg")}" width="48" height="48" /></td> <td> <div class="cesium-navigation-help-zoom">Zoom view</div> <div class="cesium-navigation-help-details">Right click + drag, or</div> <div class="cesium-navigation-help-details">Mouse wheel scroll</div> </td> </tr> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/MouseMiddle.svg")}" width="48" height="48" /></td> <td> <div class="cesium-navigation-help-rotate">Rotate view</div> <div class="cesium-navigation-help-details">Middle click + drag, or</div> <div class="cesium-navigation-help-details">CTRL + Left/Right click + drag</div> </td> </tr> </table>`,s.appendChild(h);let Z=document.createElement("div");Z.className="cesium-touch-navigation-help cesium-navigation-help-instructions",Z.setAttribute("data-bind",'css: { "cesium-touch-navigation-help-visible" : _touch}'),Z.innerHTML=` <table> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/TouchDrag.svg")}" width="70" height="48" /></td> <td> <div class="cesium-navigation-help-pan">Pan view</div> <div class="cesium-navigation-help-details">One finger drag</div> </td> </tr> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/TouchZoom.svg")}" width="70" height="48" /></td> <td> <div class="cesium-navigation-help-zoom">Zoom view</div> <div class="cesium-navigation-help-details">Two finger pinch</div> </td> </tr> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/TouchTilt.svg")}" width="70" height="48" /></td> <td> <div class="cesium-navigation-help-rotate">Tilt view</div> <div class="cesium-navigation-help-details">Two finger drag, same direction</div> </td> </tr> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/TouchRotate.svg")}" width="70" height="48" /></td> <td> <div class="cesium-navigation-help-tilt">Rotate view</div> <div class="cesium-navigation-help-details">Two finger drag, opposite direction</div> </td> </tr> </table>`,s.appendChild(Z),Lt.applyBindings(n,o),this._container=e,this._viewModel=n,this._wrapper=o,this._closeInstructions=function(b){o.contains(b.target)||(n.showInstructions=!1)},In.supportsPointerEvents()?document.addEventListener("pointerdown",this._closeInstructions,!0):(document.addEventListener("mousedown",this._closeInstructions,!0),document.addEventListener("touchstart",this._closeInstructions,!0))}Object.defineProperties(F4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});F4.prototype.isDestroyed=function(){return!1};F4.prototype.destroy=function(){return In.supportsPointerEvents()?document.removeEventListener("pointerdown",this._closeInstructions,!0):(document.removeEventListener("mousedown",this._closeInstructions,!0),document.removeEventListener("touchstart",this._closeInstructions,!0)),Lt.cleanNode(this._wrapper),this._container.removeChild(this._wrapper),At(this)};var _D=F4;var tGa=R(W(),1);var PUa=R(W(),1);function Lrt(t){this._scene=t.scene,this.lowFrameRateMessage=f(t.lowFrameRateMessage,"This application appears to be performing poorly on your system. Please try using a different web browser or updating your video drivers."),this.lowFrameRateMessageDismissed=!1,this.showingLowFrameRateMessage=!1,Lt.track(this,["lowFrameRateMessage","lowFrameRateMessageDismissed","showingLowFrameRateMessage"]);let e=this;this._dismissMessage=bi(function(){e.showingLowFrameRateMessage=!1,e.lowFrameRateMessageDismissed=!0});let n=P5.fromScene(t.scene);this._unsubscribeLowFrameRate=n.lowFrameRate.addEventListener(function(){e.lowFrameRateMessageDismissed||(e.showingLowFrameRateMessage=!0)}),this._unsubscribeNominalFrameRate=n.nominalFrameRate.addEventListener(function(){e.showingLowFrameRateMessage=!1})}Object.defineProperties(Lrt.prototype,{scene:{get:function(){return this._scene}},dismissMessage:{get:function(){return this._dismissMessage}}});Lrt.prototype.destroy=function(){return this._unsubscribeLowFrameRate(),this._unsubscribeNominalFrameRate(),At(this)};var DD=Lrt;function U4(t){let e=Ui(t.container),n=new DD(t),i=document.createElement("div");i.className="cesium-performance-watchdog-message-area",i.setAttribute("data-bind","visible: showingLowFrameRateMessage");let o=document.createElement("button");o.setAttribute("type","button"),o.className="cesium-performance-watchdog-message-dismiss",o.innerHTML="×",o.setAttribute("data-bind","click: dismissMessage"),i.appendChild(o);let a=document.createElement("div");a.className="cesium-performance-watchdog-message",a.setAttribute("data-bind","html: lowFrameRateMessage"),i.appendChild(a),e.appendChild(i),Lt.applyBindings(n,i),this._container=e,this._viewModel=n,this._element=i}Object.defineProperties(U4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});U4.prototype.isDestroyed=function(){return!1};U4.prototype.destroy=function(){return this._viewModel.destroy(),Lt.cleanNode(this._element),this._container.removeChild(this._element),At(this)};var OD=U4;var pGa=R(W(),1);var sGa=R(W(),1);function G4(t){this._scene=t,this._orthographic=t.camera.frustum instanceof wn,this._flightInProgress=!1,this.dropDownVisible=!1,this.tooltipPerspective="Perspective Projection",this.tooltipOrthographic="Orthographic Projection",this.selectedTooltip=void 0,this.sceneMode=t.mode,Lt.track(this,["_orthographic","_flightInProgress","sceneMode","dropDownVisible","tooltipPerspective","tooltipOrthographic"]);let e=this;Lt.defineProperty(this,"selectedTooltip",function(){return e._orthographic?e.tooltipOrthographic:e.tooltipPerspective}),this._toggleDropDown=bi(function(){e.sceneMode===ut.SCENE2D||e._flightInProgress||(e.dropDownVisible=!e.dropDownVisible)}),this._eventHelper=new rl,this._eventHelper.add(t.morphComplete,function(n,i,o,a){e.sceneMode=o,e._orthographic=o===ut.SCENE2D||e._scene.camera.frustum instanceof wn}),this._eventHelper.add(t.preRender,function(){e._flightInProgress=c(t.camera._currentFlight)}),this._switchToPerspective=bi(function(){e.sceneMode!==ut.SCENE2D&&(e._scene.camera.switchToPerspectiveFrustum(),e._orthographic=!1,e.dropDownVisible=!1)}),this._switchToOrthographic=bi(function(){e.sceneMode!==ut.SCENE2D&&(e._scene.camera.switchToOrthographicFrustum(),e._orthographic=!0,e.dropDownVisible=!1)}),this._sceneMode=ut}Object.defineProperties(G4.prototype,{scene:{get:function(){return this._scene}},toggleDropDown:{get:function(){return this._toggleDropDown}},switchToPerspective:{get:function(){return this._switchToPerspective}},switchToOrthographic:{get:function(){return this._switchToOrthographic}},isOrthographicProjection:{get:function(){return this._orthographic}}});G4.prototype.isDestroyed=function(){return!1};G4.prototype.destroy=function(){this._eventHelper.removeAll(),At(this)};var HD=G4;var P5e="M 28.15625,10.4375 9.125,13.21875 13.75,43.25 41.75,55.09375 50.8125,37 54.5,11.9375 z m 0.125,3 19.976451,0.394265 L 43.03125,16.875 22.6875,14.28125 z M 50.971746,15.705477 47.90625,36.03125 42.53125,46 44.84375,19.3125 z M 12.625,16.03125 l 29.15625,3.6875 -2.65625,31 L 16.4375,41.125 z",v5e="m 31.560594,6.5254438 -20.75,12.4687502 0.1875,24.5625 22.28125,11.8125 19.5,-12 0.65625,-0.375 0,-0.75 0.0312,-23.21875 z m 0.0625,3.125 16.65625,9.5000002 -16.125,10.28125 -17.34375,-9.71875 z m 18.96875,11.1875002 0.15625,20.65625 -17.46875,10.59375 0.15625,-20.28125 z m -37.0625,1.25 17.21875,9.625 -0.15625,19.21875 -16.9375,-9 z";function A4(t,e){t=Ui(t);let n=new HD(e);n._perspectivePath=P5e,n._orthographicPath=v5e;let i=document.createElement("span");i.className="cesium-projectionPicker-wrapper cesium-toolbar-button",t.appendChild(i);let o=document.createElement("button");o.type="button",o.className="cesium-button cesium-toolbar-button",o.setAttribute("data-bind",'css: { "cesium-projectionPicker-buttonPerspective": !_orthographic, "cesium-projectionPicker-buttonOrthographic": _orthographic, "cesium-button-disabled" : sceneMode === _sceneMode.SCENE2D || _flightInProgress, "cesium-projectionPicker-selected": dropDownVisible },attr: { title: selectedTooltip },click: toggleDropDown'),o.innerHTML='<!-- ko cesiumSvgPath: { path: _perspectivePath, width: 64, height: 64, css: "cesium-projectionPicker-iconPerspective" } --><!-- /ko --><!-- ko cesiumSvgPath: { path: _orthographicPath, width: 64, height: 64, css: "cesium-projectionPicker-iconOrthographic" } --><!-- /ko -->',i.appendChild(o);let a=document.createElement("button");a.type="button",a.className="cesium-button cesium-toolbar-button cesium-projectionPicker-dropDown-icon",a.setAttribute("data-bind",'css: { "cesium-projectionPicker-visible" : (dropDownVisible && _orthographic), "cesium-projectionPicker-none" : !_orthographic, "cesium-projectionPicker-hidden" : !dropDownVisible },attr: { title: tooltipPerspective },click: switchToPerspective,cesiumSvgPath: { path: _perspectivePath, width: 64, height: 64 }'),i.appendChild(a);let s=document.createElement("button");s.type="button",s.className="cesium-button cesium-toolbar-button cesium-projectionPicker-dropDown-icon",s.setAttribute("data-bind",'css: { "cesium-projectionPicker-visible" : (dropDownVisible && !_orthographic), "cesium-projectionPicker-none" : _orthographic, "cesium-projectionPicker-hidden" : !dropDownVisible},attr: { title: tooltipOrthographic },click: switchToOrthographic,cesiumSvgPath: { path: _orthographicPath, width: 64, height: 64 }'),i.appendChild(s),Lt.applyBindings(n,i),this._viewModel=n,this._container=t,this._wrapper=i,this._closeDropDown=function(l){i.contains(l.target)||(n.dropDownVisible=!1)},In.supportsPointerEvents()?document.addEventListener("pointerdown",this._closeDropDown,!0):(document.addEventListener("mousedown",this._closeDropDown,!0),document.addEventListener("touchstart",this._closeDropDown,!0))}Object.defineProperties(A4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});A4.prototype.isDestroyed=function(){return!1};A4.prototype.destroy=function(){return this._viewModel.destroy(),In.supportsPointerEvents()?document.removeEventListener("pointerdown",this._closeDropDown,!0):(document.removeEventListener("mousedown",this._closeDropDown,!0),document.removeEventListener("touchstart",this._closeDropDown,!0)),Lt.cleanNode(this._wrapper),this._container.removeChild(this._wrapper),At(this)};var wD=A4;var gGa=R(W(),1);var fGa=R(W(),1);function T4(t,e){this._scene=t;let n=this,i=function(o,a,s,l){n.sceneMode=s,n.dropDownVisible=!1};this._eventHelper=new rl,this._eventHelper.add(t.morphStart,i),this._duration=f(e,2),this.sceneMode=t.mode,this.dropDownVisible=!1,this.tooltip2D="2D",this.tooltip3D="3D",this.tooltipColumbusView="Columbus View",Lt.track(this,["sceneMode","dropDownVisible","tooltip2D","tooltip3D","tooltipColumbusView"]),this.selectedTooltip=void 0,Lt.defineProperty(this,"selectedTooltip",function(){let o=n.sceneMode;return o===ut.SCENE2D?n.tooltip2D:o===ut.SCENE3D?n.tooltip3D:n.tooltipColumbusView}),this._toggleDropDown=bi(function(){n.dropDownVisible=!n.dropDownVisible}),this._morphTo2D=bi(function(){t.morphTo2D(n._duration)}),this._morphTo3D=bi(function(){t.morphTo3D(n._duration)}),this._morphToColumbusView=bi(function(){t.morphToColumbusView(n._duration)}),this._sceneMode=ut}Object.defineProperties(T4.prototype,{scene:{get:function(){return this._scene}},duration:{get:function(){return this._duration},set:function(t){this._duration=t}},toggleDropDown:{get:function(){return this._toggleDropDown}},morphTo2D:{get:function(){return this._morphTo2D}},morphTo3D:{get:function(){return this._morphTo3D}},morphToColumbusView:{get:function(){return this._morphToColumbusView}}});T4.prototype.isDestroyed=function(){return!1};T4.prototype.destroy=function(){this._eventHelper.removeAll(),At(this)};var PD=T4;var K5e="m 32.401392,4.9330437 c -7.087603,0 -14.096095,2.884602 -19.10793,7.8946843 -5.0118352,5.010083 -7.9296167,11.987468 -7.9296167,19.072999 0,7.085531 2.9177815,14.097848 7.9296167,19.107931 4.837653,4.835961 11.541408,7.631372 18.374354,7.82482 0.05712,0.01231 0.454119,0.139729 0.454119,0.139729 l 0.03493,-0.104797 c 0.08246,7.84e-4 0.162033,0.03493 0.244525,0.03493 0.08304,0 0.161515,-0.03414 0.244526,-0.03493 l 0.03493,0.104797 c 0,0 0.309474,-0.129487 0.349323,-0.139729 6.867765,-0.168094 13.582903,-2.965206 18.444218,-7.82482 2.558195,-2.5573 4.551081,-5.638134 5.903547,-8.977584 1.297191,-3.202966 2.02607,-6.661489 2.02607,-10.130347 0,-6.237309 -2.366261,-12.31219 -6.322734,-17.116794 -0.0034,-0.02316 0.0049,-0.04488 0,-0.06986 -0.01733,-0.08745 -0.104529,-0.278855 -0.104797,-0.279458 -5.31e-4,-0.0012 -0.522988,-0.628147 -0.523984,-0.62878 -3.47e-4,-2.2e-4 -0.133444,-0.03532 -0.244525,-0.06987 C 51.944299,13.447603 51.751076,13.104317 51.474391,12.827728 46.462556,7.8176457 39.488996,4.9330437 32.401392,4.9330437 z m -2.130866,3.5281554 0.104797,9.6762289 c -4.111695,-0.08361 -7.109829,-0.423664 -9.257041,-0.943171 1.198093,-2.269271 2.524531,-4.124404 3.91241,-5.414496 2.167498,-2.0147811 3.950145,-2.8540169 5.239834,-3.3185619 z m 2.794579,0 c 1.280302,0.4754953 3.022186,1.3285948 5.065173,3.2486979 1.424667,1.338973 2.788862,3.303645 3.982275,5.728886 -2.29082,0.403367 -5.381258,0.621049 -8.942651,0.698645 L 33.065105,8.4611991 z m 5.728886,0.2445256 c 4.004072,1.1230822 7.793098,3.1481363 10.724195,6.0782083 0.03468,0.03466 0.07033,0.06991 0.104797,0.104797 -0.45375,0.313891 -0.923054,0.663002 -1.956205,1.082899 -0.647388,0.263114 -1.906242,0.477396 -2.829511,0.733577 -1.382296,-2.988132 -3.027146,-5.368585 -4.785716,-7.0213781 -0.422866,-0.397432 -0.835818,-0.6453247 -1.25756,-0.9781032 z m -15.33525,0.7685092 c -0.106753,0.09503 -0.207753,0.145402 -0.31439,0.244526 -1.684973,1.5662541 -3.298068,3.8232211 -4.680919,6.5672591 -0.343797,-0.14942 -1.035052,-0.273198 -1.292493,-0.419186 -0.956528,-0.542427 -1.362964,-1.022024 -1.537018,-1.292493 -0.0241,-0.03745 -0.01868,-0.0401 -0.03493,-0.06986 2.250095,-2.163342 4.948824,-3.869984 7.859752,-5.0302421 z m -9.641296,7.0912431 c 0.464973,0.571618 0.937729,1.169056 1.956205,1.746612 0.349907,0.198425 1.107143,0.335404 1.537018,0.523983 -1.20166,3.172984 -1.998037,7.051901 -2.165798,11.772162 C 14.256557,30.361384 12.934823,30.161483 12.280427,29.90959 10.644437,29.279855 9.6888882,28.674891 9.1714586,28.267775 8.6540289,27.860658 8.6474751,27.778724 8.6474751,27.778724 l -0.069864,0.03493 C 9.3100294,23.691285 11.163248,19.798527 13.817445,16.565477 z m 37.552149,0.523984 c 2.548924,3.289983 4.265057,7.202594 4.890513,11.318043 -0.650428,0.410896 -1.756876,1.001936 -3.563088,1.606882 -1.171552,0.392383 -3.163859,0.759153 -4.960377,1.117832 -0.04367,-4.752703 -0.784809,-8.591423 -1.88634,-11.807094 0.917574,-0.263678 2.170552,-0.486495 2.864443,-0.76851 1.274693,-0.518066 2.003942,-1.001558 2.654849,-1.467153 z m -31.439008,2.619917 c 2.487341,0.672766 5.775813,1.137775 10.479669,1.222628 l 0.104797,10.689263 0,0.03493 0,0.733577 c -5.435005,-0.09059 -9.512219,-0.519044 -12.610536,-1.117831 0.106127,-4.776683 0.879334,-8.55791 2.02607,-11.562569 z m 23.264866,0.31439 c 1.073459,3.067541 1.833795,6.821314 1.816476,11.702298 -3.054474,0.423245 -7.062018,0.648559 -11.702298,0.698644 l 0,-0.838373 -0.104796,-10.654331 c 4.082416,-0.0864 7.404468,-0.403886 9.990618,-0.908238 z M 8.2632205,30.922625 c 0.7558676,0.510548 1.5529563,1.013339 3.0041715,1.57195 0.937518,0.360875 2.612202,0.647642 3.91241,0.978102 0.112814,3.85566 0.703989,7.107756 1.606883,9.920754 -1.147172,-0.324262 -2.644553,-0.640648 -3.423359,-0.978102 -1.516688,-0.657177 -2.386627,-1.287332 -2.864443,-1.71168 -0.477816,-0.424347 -0.489051,-0.489051 -0.489051,-0.489051 L 9.8002387,40.319395 C 8.791691,37.621767 8.1584238,34.769583 8.1584238,31.900727 c 0,-0.330153 0.090589,-0.648169 0.1047967,-0.978102 z m 48.2763445,0.419186 c 0.0047,0.188973 0.06986,0.36991 0.06986,0.558916 0,2.938869 -0.620228,5.873558 -1.676747,8.628261 -0.07435,0.07583 -0.06552,0.07411 -0.454119,0.349323 -0.606965,0.429857 -1.631665,1.042044 -3.318562,1.676747 -1.208528,0.454713 -3.204964,0.850894 -5.135038,1.25756 0.84593,-2.765726 1.41808,-6.005357 1.606883,-9.815957 2.232369,-0.413371 4.483758,-0.840201 5.938479,-1.327425 1.410632,-0.472457 2.153108,-0.89469 2.96924,-1.327425 z m -38.530252,2.864443 c 3.208141,0.56697 7.372279,0.898588 12.575603,0.978103 l 0.174662,9.885821 c -4.392517,-0.06139 -8.106722,-0.320566 -10.863925,-0.803441 -1.051954,-2.664695 -1.692909,-6.043794 -1.88634,-10.060483 z m 26.793022,0.31439 c -0.246298,3.923551 -0.877762,7.263679 -1.816476,9.885822 -2.561957,0.361954 -5.766249,0.560708 -9.431703,0.62878 l -0.174661,-9.815957 c 4.491734,-0.04969 8.334769,-0.293032 11.42284,-0.698645 z M 12.035901,44.860585 c 0.09977,0.04523 0.105535,0.09465 0.209594,0.139729 1.337656,0.579602 3.441099,1.058072 5.589157,1.537018 1.545042,3.399208 3.548524,5.969402 5.589157,7.789888 -3.034411,-1.215537 -5.871615,-3.007978 -8.174142,-5.309699 -1.245911,-1.245475 -2.271794,-2.662961 -3.213766,-4.156936 z m 40.69605,0 c -0.941972,1.493975 -1.967855,2.911461 -3.213765,4.156936 -2.74253,2.741571 -6.244106,4.696717 -9.955686,5.868615 0.261347,-0.241079 0.507495,-0.394491 0.768509,-0.663713 1.674841,-1.727516 3.320792,-4.181056 4.645987,-7.265904 2.962447,-0.503021 5.408965,-1.122293 7.161107,-1.781544 0.284034,-0.106865 0.337297,-0.207323 0.593848,-0.31439 z m -31.404076,2.305527 c 2.645807,0.376448 5.701178,0.649995 9.466635,0.698645 l 0.139729,7.789888 c -1.38739,-0.480844 -3.316218,-1.29837 -5.659022,-3.388427 -1.388822,-1.238993 -2.743668,-3.0113 -3.947342,-5.100106 z m 20.365491,0.104797 c -1.04872,2.041937 -2.174337,3.779068 -3.353494,4.995309 -1.853177,1.911459 -3.425515,2.82679 -4.611055,3.353494 l -0.139729,-7.789887 c 3.13091,-0.05714 5.728238,-0.278725 8.104278,-0.558916 z",z5e="m 2.9825053,17.550598 0,1.368113 0,26.267766 0,1.368113 1.36811,0 54.9981397,0 1.36811,0 0,-1.368113 0,-26.267766 0,-1.368113 -1.36811,0 -54.9981397,0 -1.36811,0 z m 2.73623,2.736226 10.3292497,0 0,10.466063 -10.3292497,0 0,-10.466063 z m 13.0654697,0 11.69737,0 0,10.466063 -11.69737,0 0,-10.466063 z m 14.43359,0 11.69737,0 0,10.466063 -11.69737,0 0,-10.466063 z m 14.43359,0 10.32926,0 0,10.466063 -10.32926,0 0,-10.466063 z m -41.9326497,13.202288 10.3292497,0 0,10.329252 -10.3292497,0 0,-10.329252 z m 13.0654697,0 11.69737,0 0,10.329252 -11.69737,0 0,-10.329252 z m 14.43359,0 11.69737,0 0,10.329252 -11.69737,0 0,-10.329252 z m 14.43359,0 10.32926,0 0,10.329252 -10.32926,0 0,-10.329252 z",j5e="m 14.723969,17.675598 -0.340489,0.817175 -11.1680536,26.183638 -0.817175,1.872692 2.076986,0 54.7506996,0 2.07698,0 -0.81717,-1.872692 -11.16805,-26.183638 -0.34049,-0.817175 -0.91933,0 -32.414586,0 -0.919322,0 z m 1.838643,2.723916 6.196908,0 -2.928209,10.418977 -7.729111,0 4.460412,-10.418977 z m 9.02297,0 4.903049,0 0,10.418977 -7.831258,0 2.928209,-10.418977 z m 7.626964,0 5.584031,0 2.62176,10.418977 -8.205791,0 0,-10.418977 z m 8.410081,0 5.51593,0 4.46042,10.418977 -7.38863,0 -2.58772,-10.418977 z m -30.678091,13.142892 8.103649,0 -2.89416,10.282782 -9.6018026,0 4.3923136,-10.282782 z m 10.929711,0 8.614384,0 0,10.282782 -11.508544,0 2.89416,-10.282782 z m 11.338299,0 8.852721,0 2.58772,10.282782 -11.440441,0 0,-10.282782 z m 11.678781,0 7.86531,0 4.39231,10.282782 -9.6699,0 -2.58772,-10.282782 z";function S4(t,e,n){t=Ui(t);let i=new PD(e,n);i._globePath=K5e,i._flatMapPath=z5e,i._columbusViewPath=j5e;let o=document.createElement("span");o.className="cesium-sceneModePicker-wrapper cesium-toolbar-button",t.appendChild(o);let a=document.createElement("button");a.type="button",a.className="cesium-button cesium-toolbar-button",a.setAttribute("data-bind",'css: { "cesium-sceneModePicker-button2D": sceneMode === _sceneMode.SCENE2D, "cesium-sceneModePicker-button3D": sceneMode === _sceneMode.SCENE3D, "cesium-sceneModePicker-buttonColumbusView": sceneMode === _sceneMode.COLUMBUS_VIEW, "cesium-sceneModePicker-selected": dropDownVisible },attr: { title: selectedTooltip },click: toggleDropDown'),a.innerHTML='<!-- ko cesiumSvgPath: { path: _globePath, width: 64, height: 64, css: "cesium-sceneModePicker-slide-svg cesium-sceneModePicker-icon3D" } --><!-- /ko --><!-- ko cesiumSvgPath: { path: _flatMapPath, width: 64, height: 64, css: "cesium-sceneModePicker-slide-svg cesium-sceneModePicker-icon2D" } --><!-- /ko --><!-- ko cesiumSvgPath: { path: _columbusViewPath, width: 64, height: 64, css: "cesium-sceneModePicker-slide-svg cesium-sceneModePicker-iconColumbusView" } --><!-- /ko -->',o.appendChild(a);let s=document.createElement("button");s.type="button",s.className="cesium-button cesium-toolbar-button cesium-sceneModePicker-dropDown-icon",s.setAttribute("data-bind",'css: { "cesium-sceneModePicker-visible" : (dropDownVisible && (sceneMode !== _sceneMode.SCENE3D)) || (!dropDownVisible && (sceneMode === _sceneMode.SCENE3D)), "cesium-sceneModePicker-none" : sceneMode === _sceneMode.SCENE3D, "cesium-sceneModePicker-hidden" : !dropDownVisible },attr: { title: tooltip3D },click: morphTo3D,cesiumSvgPath: { path: _globePath, width: 64, height: 64 }'),o.appendChild(s);let l=document.createElement("button");l.type="button",l.className="cesium-button cesium-toolbar-button cesium-sceneModePicker-dropDown-icon",l.setAttribute("data-bind",'css: { "cesium-sceneModePicker-visible" : (dropDownVisible && (sceneMode !== _sceneMode.SCENE2D)), "cesium-sceneModePicker-none" : sceneMode === _sceneMode.SCENE2D, "cesium-sceneModePicker-hidden" : !dropDownVisible },attr: { title: tooltip2D },click: morphTo2D,cesiumSvgPath: { path: _flatMapPath, width: 64, height: 64 }'),o.appendChild(l);let r=document.createElement("button");r.type="button",r.className="cesium-button cesium-toolbar-button cesium-sceneModePicker-dropDown-icon",r.setAttribute("data-bind",'css: { "cesium-sceneModePicker-visible" : (dropDownVisible && (sceneMode !== _sceneMode.COLUMBUS_VIEW)) || (!dropDownVisible && (sceneMode === _sceneMode.COLUMBUS_VIEW)), "cesium-sceneModePicker-none" : sceneMode === _sceneMode.COLUMBUS_VIEW, "cesium-sceneModePicker-hidden" : !dropDownVisible},attr: { title: tooltipColumbusView },click: morphToColumbusView,cesiumSvgPath: { path: _columbusViewPath, width: 64, height: 64 }'),o.appendChild(r),Lt.applyBindings(i,o),this._viewModel=i,this._container=t,this._wrapper=o,this._closeDropDown=function(d){o.contains(d.target)||(i.dropDownVisible=!1)},In.supportsPointerEvents()?document.addEventListener("pointerdown",this._closeDropDown,!0):(document.addEventListener("mousedown",this._closeDropDown,!0),document.addEventListener("touchstart",this._closeDropDown,!0))}Object.defineProperties(S4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});S4.prototype.isDestroyed=function(){return!1};S4.prototype.destroy=function(){return this._viewModel.destroy(),In.supportsPointerEvents()?document.removeEventListener("pointerdown",this._closeDropDown,!0):(document.removeEventListener("mousedown",this._closeDropDown,!0),document.removeEventListener("touchstart",this._closeDropDown,!0)),Lt.cleanNode(this._wrapper),this._container.removeChild(this._wrapper),At(this)};var vD=S4;var JGa=R(W(),1);var yGa=R(W(),1);var q5e=new K,g4="-1000px";function KD(t,e,n){this._scene=t,this._screenPositionX=g4,this._screenPositionY=g4,this._tweens=t.tweens,this._container=f(n,document.body),this._selectionIndicatorElement=e,this._scale=1,this.position=void 0,this.showSelection=!1,Lt.track(this,["position","_screenPositionX","_screenPositionY","_scale","showSelection"]),this.isVisible=void 0,Lt.defineProperty(this,"isVisible",{get:function(){return this.showSelection&&c(this.position)}}),Lt.defineProperty(this,"_transform",{get:function(){return`scale(${this._scale})`}}),this.computeScreenSpacePosition=function(i,o){return qo.wgs84ToWindowCoordinates(t,i,o)}}KD.prototype.update=function(){if(this.showSelection&&c(this.position)){let t=this.computeScreenSpacePosition(this.position,q5e);if(!c(t))this._screenPositionX=g4,this._screenPositionY=g4;else{let e=this._container,n=e.parentNode.clientWidth,i=e.parentNode.clientHeight,o=this._selectionIndicatorElement.clientWidth,a=o*.5;t.x=Math.min(Math.max(t.x,-o),n+o)-a,t.y=Math.min(Math.max(t.y,-o),i+o)-a,this._screenPositionX=`${Math.floor(t.x+.25)}px`,this._screenPositionY=`${Math.floor(t.y+.25)}px`}}};KD.prototype.animateAppear=function(){this._tweens.addProperty({object:this,property:"_scale",startValue:2,stopValue:1,duration:.8,easingFunction:Zl.EXPONENTIAL_OUT})};KD.prototype.animateDepart=function(){this._tweens.addProperty({object:this,property:"_scale",startValue:this._scale,stopValue:1.5,duration:.8,easingFunction:Zl.EXPONENTIAL_OUT})};Object.defineProperties(KD.prototype,{container:{get:function(){return this._container}},selectionIndicatorElement:{get:function(){return this._selectionIndicatorElement}},scene:{get:function(){return this._scene}}});var zD=KD;function E4(t,e){t=Ui(t),this._container=t;let n=document.createElement("div");n.className="cesium-selection-wrapper",n.setAttribute("data-bind",'style: { "top" : _screenPositionY, "left" : _screenPositionX },css: { "cesium-selection-wrapper-visible" : isVisible }'),t.appendChild(n),this._element=n;let i="http://www.w3.org/2000/svg",o="M -34 -34 L -34 -11.25 L -30 -15.25 L -30 -30 L -15.25 -30 L -11.25 -34 L -34 -34 z M 11.25 -34 L 15.25 -30 L 30 -30 L 30 -15.25 L 34 -11.25 L 34 -34 L 11.25 -34 z M -34 11.25 L -34 34 L -11.25 34 L -15.25 30 L -30 30 L -30 15.25 L -34 11.25 z M 34 11.25 L 30 15.25 L 30 30 L 15.25 30 L 11.25 34 L 34 34 L 34 11.25 z",a=document.createElementNS(i,"svg:svg");a.setAttribute("width",160),a.setAttribute("height",160),a.setAttribute("viewBox","0 0 160 160");let s=document.createElementNS(i,"g");s.setAttribute("transform","translate(80,80)"),a.appendChild(s);let l=document.createElementNS(i,"path");l.setAttribute("data-bind","attr: { transform: _transform }"),l.setAttribute("d",o),s.appendChild(l),n.appendChild(a);let r=new zD(e,this._element,this._container);this._viewModel=r,Lt.applyBindings(this._viewModel,this._element)}Object.defineProperties(E4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});E4.prototype.isDestroyed=function(){return!1};E4.prototype.destroy=function(){let t=this._container;return Lt.cleanNode(this._element),t.removeChild(this._element),At(this)};var jD=E4;var jGa=R(W(),1);var _Ga=R(W(),1);function mg(t,e,n){this._color=t,this._height=e,this._base=f(n,0)}mg.prototype.getHeight=function(){return this._height};mg.prototype.getBase=function(){return this._base};mg.prototype.getStartTime=function(){return this._start};mg.prototype.getStopTime=function(){return this._stop};mg.prototype.setRange=function(t,e){this._start=t,this._stop=e};mg.prototype.render=function(t){let e="";if(this._start&&this._stop&&this._color){let n=rt.secondsDifference(this._start,t.epochJulian),i=Math.round(t.timeBarWidth*t.getAlpha(n)),o=rt.secondsDifference(this._stop,t.epochJulian),a=Math.round(t.timeBarWidth*t.getAlpha(o))-i;i<0&&(a+=i,i=0),i+a>t.timeBarWidth&&(a=t.timeBarWidth-i),a>0&&(e=`<span class="cesium-timeline-highlight" style="left: ${i.toString()}px; width: ${a.toString()}px; bottom: ${this._base.toString()}px; height: ${this._height}px; background-color: ${this._color};"></span>`)}return e};var qD=mg;var HGa=R(W(),1);function Qkt(t,e,n,i){this.interval=t,this.height=e,this.color=n||new v(.5,.5,.5,1),this.backgroundColor=i||new v(0,0,0,0)}Qkt.prototype.render=function(t,e){let n=this.interval.start,i=this.interval.stop,o=e.startJulian,a=rt.addSeconds(e.startJulian,e.duration,new rt);if(rt.lessThan(n,o)&&rt.greaterThan(i,a))t.fillStyle=this.color.toCssColorString(),t.fillRect(0,e.y,e.timeBarWidth,this.height);else if(rt.lessThanOrEquals(n,a)&&rt.greaterThanOrEquals(i,o)){let s,l,r;for(s=0;s<e.timeBarWidth;++s){let d=rt.addSeconds(e.startJulian,s/e.timeBarWidth*e.duration,new rt);!c(l)&&rt.greaterThanOrEquals(d,n)?l=s:!c(r)&&rt.greaterThanOrEquals(d,i)&&(r=s)}t.fillStyle=this.backgroundColor.toCssColorString(),t.fillRect(0,e.y,e.timeBarWidth,this.height),c(l)&&(c(r)||(r=e.timeBarWidth),t.fillStyle=this.color.toCssColorString(),t.fillRect(l,e.y,Math.max(r-l,1),this.height))}};var $D=Qkt;var Mrt=1e12,xu={none:0,scrub:1,slide:2,zoom:3,touchOnly:4},am={none:0,scrub:1,slideZoom:2,singleTap:3,ignore:4},JU=[.001,.002,.005,.01,.02,.05,.1,.25,.5,1,2,5,10,15,30,60,120,300,600,900,1800,3600,7200,14400,21600,43200,86400,172800,345600,604800,1296e3,2592e3,5184e3,7776e3,15552e3,31536e3,63072e3,126144e3,15768e4,31536e4,63072e4,126144e4,15768e5,31536e5,63072e5,126144e5,15768e6,31536e6],$5e=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];function sm(t,e){t=Ui(t);let n=t.ownerDocument;this.container=t;let i=n.createElement("div");i.className="cesium-timeline-main",t.appendChild(i),this._topDiv=i,this._endJulian=void 0,this._epochJulian=void 0,this._lastXPos=void 0,this._scrubElement=void 0,this._startJulian=void 0,this._timeBarSecondsSpan=void 0,this._clock=e,this._scrubJulian=e.currentTime,this._mainTicSpan=-1,this._mouseMode=xu.none,this._touchMode=am.none,this._touchState={centerX:0,spanX:0},this._mouseX=0,this._timelineDrag=0,this._timelineDragLocation=void 0,this._lastHeight=void 0,this._lastWidth=void 0,this._topDiv.innerHTML='<div class="cesium-timeline-bar"></div><div class="cesium-timeline-trackContainer"><canvas class="cesium-timeline-tracks" width="10" height="1"></canvas></div><div class="cesium-timeline-needle"></div><span class="cesium-timeline-ruler"></span>',this._timeBarEle=this._topDiv.childNodes[0],this._trackContainer=this._topDiv.childNodes[1],this._trackListEle=this._topDiv.childNodes[1].childNodes[0],this._needleEle=this._topDiv.childNodes[2],this._rulerEle=this._topDiv.childNodes[3],this._context=this._trackListEle.getContext("2d"),this._trackList=[],this._highlightRanges=[],this.zoomTo(e.startTime,e.stopTime),this._onMouseDown=tDe(this),this._onMouseUp=eDe(this),this._onMouseMove=nDe(this),this._onMouseWheel=iDe(this),this._onTouchStart=oDe(this),this._onTouchMove=sDe(this),this._onTouchEnd=aDe(this);let o=this._timeBarEle;n.addEventListener("mouseup",this._onMouseUp,!1),n.addEventListener("mousemove",this._onMouseMove,!1),o.addEventListener("mousedown",this._onMouseDown,!1),o.addEventListener("DOMMouseScroll",this._onMouseWheel,!1),o.addEventListener("mousewheel",this._onMouseWheel,!1),o.addEventListener("touchstart",this._onTouchStart,!1),o.addEventListener("touchmove",this._onTouchMove,!1),o.addEventListener("touchend",this._onTouchEnd,!1),o.addEventListener("touchcancel",this._onTouchEnd,!1),this._topDiv.oncontextmenu=function(){return!1},e.onTick.addEventListener(this.updateFromClock,this),this.updateFromClock()}sm.prototype.addEventListener=function(t,e,n){this._topDiv.addEventListener(t,e,n)};sm.prototype.removeEventListener=function(t,e,n){this._topDiv.removeEventListener(t,e,n)};sm.prototype.isDestroyed=function(){return!1};sm.prototype.destroy=function(){this._clock.onTick.removeEventListener(this.updateFromClock,this);let t=this.container.ownerDocument;t.removeEventListener("mouseup",this._onMouseUp,!1),t.removeEventListener("mousemove",this._onMouseMove,!1);let e=this._timeBarEle;e.removeEventListener("mousedown",this._onMouseDown,!1),e.removeEventListener("DOMMouseScroll",this._onMouseWheel,!1),e.removeEventListener("mousewheel",this._onMouseWheel,!1),e.removeEventListener("touchstart",this._onTouchStart,!1),e.removeEventListener("touchmove",this._onTouchMove,!1),e.removeEventListener("touchend",this._onTouchEnd,!1),e.removeEventListener("touchcancel",this._onTouchEnd,!1),this.container.removeChild(this._topDiv),At(this)};sm.prototype.addHighlightRange=function(t,e,n){let i=new qD(t,e,n);return this._highlightRanges.push(i),this.resize(),i};sm.prototype.addTrack=function(t,e,n,i){let o=new $D(t,e,n,i);return this._trackList.push(o),this._lastHeight=void 0,this.resize(),o};sm.prototype.zoomTo=function(t,e){if(this._startJulian=t,this._endJulian=e,this._timeBarSecondsSpan=rt.secondsDifference(e,t),this._clock&&this._clock.clockRange!==pl.UNBOUNDED){let i=this._clock.startTime,o=this._clock.stopTime,a=rt.secondsDifference(o,i),s=rt.secondsDifference(i,this._startJulian),l=rt.secondsDifference(o,this._endJulian);this._timeBarSecondsSpan>=a?(this._timeBarSecondsSpan=a,this._startJulian=this._clock.startTime,this._endJulian=this._clock.stopTime):s>0?(this._endJulian=rt.addSeconds(this._endJulian,s,new rt),this._startJulian=i,this._timeBarSecondsSpan=rt.secondsDifference(this._endJulian,this._startJulian)):l<0&&(this._startJulian=rt.addSeconds(this._startJulian,l,new rt),this._endJulian=o,this._timeBarSecondsSpan=rt.secondsDifference(this._endJulian,this._startJulian))}this._makeTics();let n=document.createEvent("Event");n.initEvent("setzoom",!0,!0),n.startJulian=this._startJulian,n.endJulian=this._endJulian,n.epochJulian=this._epochJulian,n.totalSpan=this._timeBarSecondsSpan,n.mainTicSpan=this._mainTicSpan,this._topDiv.dispatchEvent(n)};sm.prototype.zoomFrom=function(t){let e=rt.secondsDifference(this._scrubJulian,this._startJulian);t>1||e<0||e>this._timeBarSecondsSpan?e=this._timeBarSecondsSpan*.5:e+=e-this._timeBarSecondsSpan*.5;let n=this._timeBarSecondsSpan-e;this.zoomTo(rt.addSeconds(this._startJulian,e-e*t,new rt),rt.addSeconds(this._endJulian,n*t-n,new rt))};function _rt(t){return t<10?`0${t.toString()}`:t.toString()}sm.prototype.makeLabel=function(t){let e=rt.toGregorianDate(t),n=e.millisecond,i=" UTC";if(n>0&&this._timeBarSecondsSpan<3600){for(i=Math.floor(n).toString();i.length<3;)i=`0${i}`;i=`.${i}`}return`${$5e[e.month-1]} ${e.day} ${e.year} ${_rt(e.hour)}:${_rt(e.minute)}:${_rt(e.second)}${i}`};sm.prototype.smallestTicInPixels=7;sm.prototype._makeTics=function(){let t=this._timeBarEle,e=rt.secondsDifference(this._scrubJulian,this._startJulian),n=Math.round(e*this._topDiv.clientWidth/this._timeBarSecondsSpan),i=n-8,o,a=this;this._needleEle.style.left=`${n.toString()}px`;let s="",l=.01,r=31536e6,d=1e-10,m=0,h=this._timeBarSecondsSpan;h<l?(h=l,this._timeBarSecondsSpan=l,this._endJulian=rt.addSeconds(this._startJulian,l,new rt)):h>r&&(h=r,this._timeBarSecondsSpan=r,this._endJulian=rt.addSeconds(this._startJulian,r,new rt));let Z=this._timeBarEle.clientWidth;Z<10&&(Z=10);let b=this._startJulian,u=Math.min(h/Z*1e-5,.4),F,U=rt.toGregorianDate(b);h>31536e4?F=rt.fromDate(new Date(Date.UTC(Math.floor(U.year/100)*100,0))):h>31536e3?F=rt.fromDate(new Date(Date.UTC(Math.floor(U.year/10)*10,0))):h>86400?F=rt.fromDate(new Date(Date.UTC(U.year,0))):F=rt.fromDate(new Date(Date.UTC(U.year,U.month,U.day)));let G=rt.secondsDifference(this._startJulian,rt.addSeconds(F,u,new rt)),A=G+h;this._epochJulian=F;function T(H){return Math.floor(G/H)*H}function g(H,nt){return Math.ceil(H/nt+.5)*nt}function C(H){return(H-G)/h}function y(H,nt){return H-nt*Math.round(H/nt)}this._rulerEle.innerHTML=this.makeLabel(rt.addSeconds(this._endJulian,-l,new rt));let Y=this._rulerEle.offsetWidth+20;Y<30&&(Y=180);let Q=m;m-=d;let J={startTime:G,startJulian:b,epochJulian:F,duration:h,timeBarWidth:Z,getAlpha:C};this._highlightRanges.forEach(function(H){s+=H.render(J)});let M=0,V=0,E=0,I=Y/Z;I>1&&(I=1),I*=this._timeBarSecondsSpan;let B=-1,X=-1,_=JU.length,P;for(P=0;P<_;++P){let H=JU[P];if(++B,M=H,H>I&&H>m)break;X<0&&Z*(H/this._timeBarSecondsSpan)>=this.smallestTicInPixels&&(X=B)}if(B>0){for(;B>0;)if(--B,Math.abs(y(M,JU[B]))<1e-5){JU[B]>=m&&(V=JU[B]);break}if(X>=0)for(;X<B;){if(Math.abs(y(V,JU[X]))<1e-5&&JU[X]>=m){E=JU[X];break}++X}}m=Q,m>d&&E<1e-5&&Math.abs(m-M)>d&&(E=m,m<=M+d&&(V=0));let w=-999999,z;if(Z*(E/this._timeBarSecondsSpan)>=3)for(o=T(E);o<=A;o=g(o,E))s+=`<span class="cesium-timeline-ticTiny" style="left: ${Math.round(Z*C(o)).toString()}px;"></span>`;if(Z*(V/this._timeBarSecondsSpan)>=3)for(o=T(V);o<=A;o=g(o,V))s+=`<span class="cesium-timeline-ticSub" style="left: ${Math.round(Z*C(o)).toString()}px;"></span>`;if(Z*(M/this._timeBarSecondsSpan)>=2){this._mainTicSpan=M,A+=M,o=T(M);let H=rt.computeTaiMinusUtc(F);for(;o<=A;){let nt=rt.addSeconds(b,o-G,new rt);if(M>2.1){let at=rt.computeTaiMinusUtc(nt);Math.abs(at-H)>.1&&(o+=at-H,nt=rt.addSeconds(b,o-G,new rt))}let $=Math.round(Z*C(o)),dt=this.makeLabel(nt);this._rulerEle.innerHTML=dt,z=this._rulerEle.offsetWidth,z<10&&(z=Y);let q=$-(z/2-1);q>w?(w=q+z+5,s+=`<span class="cesium-timeline-ticMain" style="left: ${$.toString()}px;"></span><span class="cesium-timeline-ticLabel" style="left: ${q.toString()}px;">${dt}</span>`):s+=`<span class="cesium-timeline-ticSub" style="left: ${$.toString()}px;"></span>`,o=g(o,M)}}else this._mainTicSpan=-1;s+=`<span class="cesium-timeline-icon16" style="left:${i}px;bottom:0;background-position: 0 0;"></span>`,t.innerHTML=s,this._scrubElement=t.lastChild,this._context.clearRect(0,0,this._trackListEle.width,this._trackListEle.height),J.y=0,this._trackList.forEach(function(H){H.render(a._context,J),J.y+=H.height})};sm.prototype.updateFromClock=function(){this._scrubJulian=this._clock.currentTime;let t=this._scrubElement;if(c(this._scrubElement)){let e=rt.secondsDifference(this._scrubJulian,this._startJulian),n=Math.round(e*this._topDiv.clientWidth/this._timeBarSecondsSpan);this._lastXPos!==n&&(this._lastXPos=n,t.style.left=`${n-8}px`,this._needleEle.style.left=`${n}px`)}c(this._timelineDragLocation)&&(this._setTimeBarTime(this._timelineDragLocation,this._timelineDragLocation*this._timeBarSecondsSpan/this._topDiv.clientWidth),this.zoomTo(rt.addSeconds(this._startJulian,this._timelineDrag,new rt),rt.addSeconds(this._endJulian,this._timelineDrag,new rt)))};sm.prototype._setTimeBarTime=function(t,e){if(t=Math.round(t),this._scrubJulian=rt.addSeconds(this._startJulian,e,new rt),this._scrubElement){let i=t-8;this._scrubElement.style.left=`${i.toString()}px`,this._needleEle.style.left=`${t.toString()}px`}let n=document.createEvent("Event");n.initEvent("settime",!0,!0),n.clientX=t,n.timeSeconds=e,n.timeJulian=this._scrubJulian,n.clock=this._clock,this._topDiv.dispatchEvent(n)};function tDe(t){return function(e){t._mouseMode!==xu.touchOnly&&(e.button===0?(t._mouseMode=xu.scrub,t._scrubElement&&(t._scrubElement.style.backgroundPosition="-16px 0"),t._onMouseMove(e)):(t._mouseX=e.clientX,e.button===2?t._mouseMode=xu.zoom:t._mouseMode=xu.slide)),e.preventDefault()}}function eDe(t){return function(e){t._mouseMode=xu.none,t._scrubElement&&(t._scrubElement.style.backgroundPosition="0 0"),t._timelineDrag=0,t._timelineDragLocation=void 0}}function nDe(t){return function(e){let n;if(t._mouseMode===xu.scrub){e.preventDefault();let i=e.clientX-t._topDiv.getBoundingClientRect().left;i<0?(t._timelineDragLocation=0,t._timelineDrag=-.01*t._timeBarSecondsSpan):i>t._topDiv.clientWidth?(t._timelineDragLocation=t._topDiv.clientWidth,t._timelineDrag=.01*t._timeBarSecondsSpan):(t._timelineDragLocation=void 0,t._setTimeBarTime(i,i*t._timeBarSecondsSpan/t._topDiv.clientWidth))}else if(t._mouseMode===xu.slide){if(n=t._mouseX-e.clientX,t._mouseX=e.clientX,n!==0){let i=n*t._timeBarSecondsSpan/t._topDiv.clientWidth;t.zoomTo(rt.addSeconds(t._startJulian,i,new rt),rt.addSeconds(t._endJulian,i,new rt))}}else t._mouseMode===xu.zoom&&(n=t._mouseX-e.clientX,t._mouseX=e.clientX,n!==0&&t.zoomFrom(Math.pow(1.01,n)))}}function iDe(t){return function(e){let n=e.wheelDeltaY||e.wheelDelta||-e.detail;Mrt=Math.max(Math.min(Math.abs(n),Mrt),1),n/=Mrt,t.zoomFrom(Math.pow(1.05,-n))}}function oDe(t){return function(e){let n=e.touches.length,i,o,a=t._topDiv.getBoundingClientRect().left;e.preventDefault(),t._mouseMode=xu.touchOnly,n===1?(i=rt.secondsDifference(t._scrubJulian,t._startJulian),o=Math.round(i*t._topDiv.clientWidth/t._timeBarSecondsSpan+a),Math.abs(e.touches[0].clientX-o)<50?(t._touchMode=am.scrub,t._scrubElement&&(t._scrubElement.style.backgroundPosition=n===1?"-16px 0":"0 0")):(t._touchMode=am.singleTap,t._touchState.centerX=e.touches[0].clientX-a)):n===2?(t._touchMode=am.slideZoom,t._touchState.centerX=(e.touches[0].clientX+e.touches[1].clientX)*.5-a,t._touchState.spanX=Math.abs(e.touches[0].clientX-e.touches[1].clientX)):t._touchMode=am.ignore}}function aDe(t){return function(e){let n=e.touches.length,i=t._topDiv.getBoundingClientRect().left;t._touchMode===am.singleTap?(t._touchMode=am.scrub,t._onTouchMove(e)):t._touchMode===am.scrub&&t._onTouchMove(e),t._mouseMode=xu.touchOnly,n!==1?t._touchMode=n>0?am.ignore:am.none:t._touchMode===am.slideZoom&&(t._touchState.centerX=e.touches[0].clientX-i),t._scrubElement&&(t._scrubElement.style.backgroundPosition="0 0")}}function sDe(t){return function(e){let n,i,o,a,s,l,r=1,d=t._topDiv.getBoundingClientRect().left;t._touchMode===am.singleTap&&(t._touchMode=am.slideZoom),t._mouseMode=xu.touchOnly,t._touchMode===am.scrub?(e.preventDefault(),e.changedTouches.length===1&&(i=e.changedTouches[0].clientX-d,i>=0&&i<=t._topDiv.clientWidth&&t._setTimeBarTime(i,i*t._timeBarSecondsSpan/t._topDiv.clientWidth))):t._touchMode===am.slideZoom&&(o=e.touches.length,o===2?(a=(e.touches[0].clientX+e.touches[1].clientX)*.5-d,s=Math.abs(e.touches[0].clientX-e.touches[1].clientX)):o===1&&(a=e.touches[0].clientX-d,s=0),c(a)&&(s>0&&t._touchState.spanX>0?(r=t._touchState.spanX/s,l=rt.addSeconds(t._startJulian,(t._touchState.centerX*t._timeBarSecondsSpan-a*t._timeBarSecondsSpan*r)/t._topDiv.clientWidth,new rt)):(n=t._touchState.centerX-a,l=rt.addSeconds(t._startJulian,n*t._timeBarSecondsSpan/t._topDiv.clientWidth,new rt)),t.zoomTo(l,rt.addSeconds(l,t._timeBarSecondsSpan*r,new rt)),t._touchState.centerX=a,t._touchState.spanX=s))}}sm.prototype.resize=function(){let t=this.container.clientWidth,e=this.container.clientHeight;if(t===this._lastWidth&&e===this._lastHeight)return;this._trackContainer.style.height=`${e}px`;let n=1;this._trackList.forEach(function(i){n+=i.height}),this._trackListEle.style.height=`${n.toString()}px`,this._trackListEle.width=this._trackListEle.clientWidth,this._trackListEle.height=n,this._makeTics(),this._lastXPos=void 0,this._lastWidth=t,this._lastHeight=e};var tO=sm;var uAa=R(W(),1);var lAa=R(W(),1);var Jkt=R(Xkt(),1);function dDe(t){let e=!1,n=window.screen;return c(n)&&(c(n.lockOrientation)?e=n.lockOrientation(t):c(n.mozLockOrientation)?e=n.mozLockOrientation(t):c(n.msLockOrientation)?e=n.msLockOrientation(t):c(n.orientation&&n.orientation.lock)&&(e=n.orientation.lock(t))),e}function Lkt(){let t=window.screen;c(t)&&(c(t.unlockOrientation)?t.unlockOrientation():c(t.mozUnlockOrientation)?t.mozUnlockOrientation():c(t.msUnlockOrientation)?t.msUnlockOrientation():c(t.orientation&&t.orientation.unlock)&&t.orientation.unlock())}function cDe(t,e,n,i){i()||(n()?(e.useWebVR=!1,t._locked&&(Lkt(),t._locked=!1),t._noSleep.disable(),Ds.exitFullscreen(),n(!1)):(Ds.fullscreen||Ds.requestFullscreen(t._vrElement),t._noSleep.enable(),t._locked||(t._locked=dDe("landscape")),e.useWebVR=!0,n(!0)))}function C4(t,e){let n=this,i=Lt.observable(Ds.enabled),o=Lt.observable(!1);this.isVRMode=void 0,Lt.defineProperty(this,"isVRMode",{get:function(){return o()}}),this.isVREnabled=void 0,Lt.defineProperty(this,"isVREnabled",{get:function(){return i()},set:function(s){i(s&&Ds.enabled)}}),this.tooltip=void 0,Lt.defineProperty(this,"tooltip",function(){return i()?o()?"Exit VR mode":"Enter VR mode":"VR mode is unavailable"});let a=Lt.observable(!1);this._isOrthographic=void 0,Lt.defineProperty(this,"_isOrthographic",{get:function(){return a()}}),this._eventHelper=new rl,this._eventHelper.add(t.preRender,function(){a(t.camera.frustum instanceof wn)}),this._locked=!1,this._noSleep=new Jkt.default,this._command=bi(function(){cDe(n,t,o,a)},Lt.getObservable(this,"isVREnabled")),this._vrElement=f(Ui(e),document.body),this._callback=function(){!Ds.fullscreen&&o()&&(t.useWebVR=!1,n._locked&&(Lkt(),n._locked=!1),n._noSleep.disable(),o(!1))},document.addEventListener(Ds.changeEventName,this._callback)}Object.defineProperties(C4.prototype,{vrElement:{get:function(){return this._vrElement},set:function(t){this._vrElement=t}},command:{get:function(){return this._command}}});C4.prototype.isDestroyed=function(){return!1};C4.prototype.destroy=function(){this._eventHelper.removeAll(),document.removeEventListener(Ds.changeEventName,this._callback),At(this)};var eO=C4;var mDe="M 5.3125 6.375 C 4.008126 6.375 2.96875 7.4141499 2.96875 8.71875 L 2.96875 19.5 C 2.96875 20.8043 4.008126 21.875 5.3125 21.875 L 13.65625 21.875 C 13.71832 20.0547 14.845166 18.59375 16.21875 18.59375 C 17.592088 18.59375 18.71881 20.0552 18.78125 21.875 L 27.09375 21.875 C 28.398125 21.875 29.4375 20.8043 29.4375 19.5 L 29.4375 8.71875 C 29.4375 7.4141499 28.398125 6.375 27.09375 6.375 L 5.3125 6.375 z M 9.625 10.4375 C 11.55989 10.4375 13.125 12.03385 13.125 13.96875 C 13.125 15.90365 11.55989 17.46875 9.625 17.46875 C 7.69011 17.46875 6.125 15.90365 6.125 13.96875 C 6.125 12.03385 7.69011 10.4375 9.625 10.4375 z M 22.46875 10.4375 C 24.40364 10.4375 25.96875 12.03385 25.96875 13.96875 C 25.96875 15.90365 24.40364 17.46875 22.46875 17.46875 C 20.53386 17.46875 18.96875 15.90365 18.96875 13.96875 C 18.96875 12.03385 20.53386 10.4375 22.46875 10.4375 z",hDe="M 25.770585,2.4552065 C 15.72282,13.962707 10.699956,19.704407 8.1768352,22.580207 c -1.261561,1.4379 -1.902282,2.1427 -2.21875,2.5 -0.141624,0.1599 -0.208984,0.2355 -0.25,0.2813 l 0.6875,0.75 c 10e-5,-10e-5 0.679191,0.727 0.6875,0.7187 0.01662,-0.016 0.02451,-0.024 0.03125,-0.031 0.01348,-0.014 0.04013,-0.038 0.0625,-0.062 0.04474,-0.05 0.120921,-0.1315 0.28125,-0.3126 0.320657,-0.3619 0.956139,-1.0921 2.2187499,-2.5312 2.5252219,-2.8781 7.5454589,-8.6169 17.5937499,-20.1250005 l -1.5,-1.3125 z m -20.5624998,3.9063 c -1.304375,0 -2.34375,1.0391 -2.34375,2.3437 l 0,10.8125005 c 0,1.3043 1.039375,2.375 2.34375,2.375 l 2.25,0 c 1.9518039,-2.2246 7.4710958,-8.5584 13.5624998,-15.5312005 l -15.8124998,0 z m 21.1249998,0 c -1.855467,2.1245 -2.114296,2.4005 -3.59375,4.0936995 1.767282,0.1815 3.15625,1.685301 3.15625,3.500001 0,1.9349 -1.56511,3.5 -3.5,3.5 -1.658043,0 -3.043426,-1.1411 -3.40625,-2.6875 -1.089617,1.2461 -2.647139,2.9988 -3.46875,3.9375 0.191501,-0.062 0.388502,-0.094 0.59375,-0.094 1.373338,0 2.50006,1.4614 2.5625,3.2812 l 8.3125,0 c 1.304375,0 2.34375,-1.0707 2.34375,-2.375 l 0,-10.8125005 c 0,-1.3046 -1.039375,-2.3437 -2.34375,-2.3437 l -0.65625,0 z M 9.5518351,10.423906 c 1.9348899,0 3.4999999,1.596401 3.4999999,3.531301 0,1.9349 -1.56511,3.5 -3.4999999,3.5 -1.9348899,0 -3.4999999,-1.5651 -3.4999999,-3.5 0,-1.9349 1.56511,-3.531301 3.4999999,-3.531301 z m 4.2187499,10.312601 c -0.206517,0.2356 -0.844218,0.9428 -1.03125,1.1562 l 0.8125,0 c 0.01392,-0.4081 0.107026,-0.7968 0.21875,-1.1562 z";function I4(t,e,n){t=Ui(t);let i=new eO(e,n);i._exitVRPath=hDe,i._enterVRPath=mDe;let o=document.createElement("button");o.type="button",o.className="cesium-button cesium-vrButton",o.setAttribute("data-bind",'css: { "cesium-button-disabled" : _isOrthographic }, attr: { title: tooltip },click: command,enable: isVREnabled,cesiumSvgPath: { path: isVRMode ? _exitVRPath : _enterVRPath, width: 32, height: 32 }'),t.appendChild(o),Lt.applyBindings(i,o),this._container=t,this._viewModel=i,this._element=o}Object.defineProperties(I4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});I4.prototype.isDestroyed=function(){return!1};I4.prototype.destroy=function(){return this._viewModel.destroy(),Lt.cleanNode(this._element),this._container.removeChild(this._element),At(this)};var nO=I4;var YAa=R(W(),1);var LU=new Ft;function Dkt(t){let e=t.clock;e.currentTime=t.timeJulian,e.shouldAnimate=!1}function pDe(t){let e=t.getPropertyIds(),n="";return e.forEach(function(i){let o=t.getProperty(i);c(o)&&(n+=`<tr><th>${i}</th><td>${o}</td></tr>`)}),n.length>0&&(n=`<table class="cesium-infoBox-defaultTable"><tbody>${n}</tbody></table>`),n}function uDe(t){let e,n=[],i=t.getPropertyIds();for(e=0;e<i.length;e++){let a=i[e];/^name$/i.test(a)?n[0]=t.getProperty(a):/name/i.test(a)?n[1]=t.getProperty(a):/^title$/i.test(a)?n[2]=t.getProperty(a):/^(id|identifier)$/i.test(a)?n[3]=t.getProperty(a):/element/i.test(a)?n[4]=t.getProperty(a):/(id|identifier)$/i.test(a)&&(n[5]=t.getProperty(a))}let o=n.length;for(e=0;e<o;e++){let a=n[e];if(c(a)&&a!=="")return a}return"Unnamed Feature"}function Mkt(t,e){let n=t.scene.pick(e.position);if(c(n)){let i=f(n.id,n.primitive.id);if(i instanceof qa&&i.id.toString().indexOf("noclick:")!==0)return i;if(n instanceof Fr)return new qa({name:uDe(n),description:pDe(n),feature:n})}if(c(t.scene.globe))return bDe(t,e.position)}var ZDe=new rt;function Okt(t,e,n){if(c(n)){let i=n.clock;if(c(i)&&(i.getValue(e),c(t))){let o=i.startTime,a=i.stopTime;rt.equals(o,a)&&(a=rt.addSeconds(o,k.EPSILON2,ZDe)),t.updateFromClock(),t.zoomTo(o,a)}}}var VDe=new p;function bDe(t,e){let n=t.scene,i=n.camera.getPickRay(e),o=n.imageryLayers.pickImageryLayerFeatures(i,n);if(!c(o))return;let a=new qa({id:"Loading...",description:"Loading feature information..."});return o.then(function(s){if(t.selectedEntity!==a)return;if(!c(s)||s.length===0){t.selectedEntity=_kt();return}let l=s[0],r=new qa({id:l.name,description:l.description});if(c(l.position)){let d=t.scene.globe.ellipsoid.cartographicToCartesian(l.position,VDe);r.position=new jl(d)}t.selectedEntity=r},function(){t.selectedEntity===a&&(t.selectedEntity=_kt())}),a}function _kt(){return new qa({id:"None",description:"No features found."})}function RDe(t,e){let n=t._geocoder,i=t._homeButton,o=t._sceneModePicker,a=t._projectionPicker,s=t._baseLayerPicker,l=t._animation,r=t._timeline,d=t._fullscreenButton,m=t._infoBox,h=t._selectionIndicator,Z=e?"hidden":"visible";if(c(n)&&(n.container.style.visibility=Z),c(i)&&(i.container.style.visibility=Z),c(o)&&(o.container.style.visibility=Z),c(a)&&(a.container.style.visibility=Z),c(s)&&(s.container.style.visibility=Z),c(l)&&(l.container.style.visibility=Z),c(r)&&(r.container.style.visibility=Z),c(d)&&d.viewModel.isFullscreenEnabled&&(d.container.style.visibility=Z),c(m)&&(m.container.style.visibility=Z),c(h)&&(h.container.style.visibility=Z),t._container){let b=e||!c(d)?0:d.container.clientWidth;t._vrButton.container.style.right=`${b}px`,t.forceResize()}}function Do(t,e){t=Ui(t),e=f(e,f.EMPTY_OBJECT);let n=(!c(e.globe)||e.globe!==!1)&&(!c(e.baseLayerPicker)||e.baseLayerPicker!==!1),i=this,o=document.createElement("div");o.className="cesium-viewer",t.appendChild(o);let a=document.createElement("div");a.className="cesium-viewer-cesiumWidgetContainer",o.appendChild(a);let s;e.bottomContainer?s=e.bottomContainer:(s=document.createElement("div"),s.className="cesium-viewer-bottom",o.appendChild(s));let l=f(e.scene3DOnly,!1),r,d,m=!1;c(e.clockViewModel)?(d=e.clockViewModel,r=d.clock):(r=new kZ,d=new ZD(r),m=!0),c(e.shouldAnimate)&&(r.shouldAnimate=e.shouldAnimate);let h=new W5(a,{baseLayer:n||c(e.baseLayer)||c(e.imageryProvider)?!1:void 0,clock:r,skyBox:e.skyBox,skyAtmosphere:e.skyAtmosphere,sceneMode:e.sceneMode,mapProjection:e.mapProjection,globe:e.globe,orderIndependentTranslucency:e.orderIndependentTranslucency,contextOptions:e.contextOptions,useDefaultRenderLoop:e.useDefaultRenderLoop,targetFrameRate:e.targetFrameRate,showRenderLoopErrors:e.showRenderLoopErrors,useBrowserRecommendedResolution:e.useBrowserRecommendedResolution,creditContainer:c(e.creditContainer)?e.creditContainer:s,creditViewport:e.creditViewport,scene3DOnly:l,shadows:e.shadows,terrainShadows:e.terrainShadows,mapMode2D:e.mapMode2D,blurActiveElementOnCanvasFocus:e.blurActiveElementOnCanvasFocus,requestRenderMode:e.requestRenderMode,maximumRenderTimeChange:e.maximumRenderTimeChange,depthPlaneEllipsoidOffset:e.depthPlaneEllipsoidOffset,msaaSamples:e.msaaSamples}),Z=e.dataSources,b=!1;c(Z)||(Z=new YJ,b=!0);let u=h.scene,F=new kF({scene:u,dataSourceCollection:Z}),U=new rl;U.add(r.onTick,Do.prototype._onTick,this),U.add(u.morphStart,Do.prototype._clearTrackedObject,this);let G;if(!c(e.selectionIndicator)||e.selectionIndicator!==!1){let $=document.createElement("div");$.className="cesium-viewer-selectionIndicatorContainer",o.appendChild($),G=new jD($,u)}let A;if(!c(e.infoBox)||e.infoBox!==!1){let $=document.createElement("div");$.className="cesium-viewer-infoBoxContainer",o.appendChild($),A=new LD($);let dt=A.viewModel;U.add(dt.cameraClicked,Do.prototype._onInfoBoxCameraClicked,this),U.add(dt.closeClicked,Do.prototype._onInfoBoxClockClicked,this)}let T=document.createElement("div");T.className="cesium-viewer-toolbar",o.appendChild(T);let g;if(!c(e.geocoder)||e.geocoder!==!1){let $=document.createElement("div");$.className="cesium-viewer-geocoderContainer",T.appendChild($);let dt;c(e.geocoder)&&typeof e.geocoder!="boolean"&&(dt=Array.isArray(e.geocoder)?e.geocoder:[e.geocoder]),g=new kD({container:$,geocoderServices:dt,scene:u}),U.add(g.viewModel.search.beforeExecute,Do.prototype._clearObjects,this)}let C;(!c(e.homeButton)||e.homeButton!==!1)&&(C=new xD(T,u),c(g)&&U.add(C.viewModel.command.afterExecute,function(){let $=g.viewModel;$.searchText="",$.isSearchInProgress&&$.search()}),U.add(C.viewModel.command.beforeExecute,Do.prototype._clearTrackedObject,this));let y;!l&&(!c(e.sceneModePicker)||e.sceneModePicker!==!1)&&(y=new vD(T,u));let Y;e.projectionPicker&&(Y=new wD(T,u));let Q,J;if(n){let $=f(e.imageryProviderViewModels,gD()),dt=f(e.terrainProviderViewModels,ED());Q=new SD(T,{globe:u.globe,imageryProviderViewModels:$,selectedImageryProviderViewModel:e.selectedImageryProviderViewModel,terrainProviderViewModels:dt,selectedTerrainProviderViewModel:e.selectedTerrainProviderViewModel}),J=T.getElementsByClassName("cesium-baseLayerPicker-dropDown")[0]}c(e.baseLayer)&&e.baseLayer!==!1&&(n&&(Q.viewModel.selectedImagery=void 0),u.imageryLayers.removeAll(),u.imageryLayers.add(e.baseLayer)),c(e.terrainProvider)&&(n&&(Q.viewModel.selectedTerrain=void 0),u.terrainProvider=e.terrainProvider),c(e.terrain)&&(n&&(Q.viewModel.selectedTerrain=void 0,u.globe.depthTestAgainstTerrain=!0),u.setTerrain(e.terrain));let M;if(!c(e.navigationHelpButton)||e.navigationHelpButton!==!1){let $=!0;try{if(c(window.localStorage)){let dt=window.localStorage.getItem("cesium-hasSeenNavHelp");c(dt)&&dt?$=!1:window.localStorage.setItem("cesium-hasSeenNavHelp","true")}}catch{}M=new _D({container:T,instructionsInitiallyVisible:f(e.navigationInstructionsInitiallyVisible,$)})}let V;if(!c(e.animation)||e.animation!==!1){let $=document.createElement("div");$.className="cesium-viewer-animationContainer",o.appendChild($),V=new GD($,new AD(d))}else if(e.animationContainer!==!1){let $=document.createElement("div");$.className="cesium-viewer-animationContainer",o.appendChild($),this._animation={container:$,resize:()=>{}}}let E;if(!c(e.timeline)||e.timeline!==!1){let $=document.createElement("div");$.className="cesium-viewer-timelineContainer",o.appendChild($),E=new tO($,r),E.addEventListener("settime",Dkt,!1),E.zoomTo(r.startTime,r.stopTime)}else if(e.timelineContainer!==!1){let $=document.createElement("div");$.className="cesium-viewer-timelineContainer",$.style.overflow="visible",o.appendChild($),E={container:$,resize:()=>{},updateFromClock:()=>{},zoomTo:()=>{}}}let I,B,X;(!c(e.fullscreenButton)||e.fullscreenButton!==!1)&&(X=document.createElement("div"),X.className="cesium-viewer-fullscreenContainer",o.appendChild(X),I=new BD(X,e.fullscreenElement),B=od(I.viewModel,"isFullscreenEnabled",function($){X.style.display=$?"block":"none",c(E)&&(E.container.style.right=`${X.clientWidth}px`,E.resize())}));let _,P,w;if(e.vrButton){let $=document.createElement("div");$.className="cesium-viewer-vrContainer",o.appendChild($),_=new nO($,u,e.fullScreenElement),P=od(_.viewModel,"isVREnabled",function(dt){$.style.display=dt?"block":"none",c(I)&&($.style.right=`${X.clientWidth}px`),c(E)&&(E.container.style.right=`${$.clientWidth}px`,E.resize())}),w=od(_.viewModel,"isVRMode",function(dt){RDe(i,dt)})}this._baseLayerPickerDropDown=J,this._fullscreenSubscription=B,this._vrSubscription=P,this._vrModeSubscription=w,this._dataSourceChangedListeners={},this._automaticallyTrackDataSourceClocks=f(e.automaticallyTrackDataSourceClocks,!0),this._container=t,this._bottomContainer=s,this._element=o,this._cesiumWidget=h,this._selectionIndicator=G,this._infoBox=A,this._dataSourceCollection=Z,this._destroyDataSourceCollection=b,this._dataSourceDisplay=F,this._clockViewModel=d,this._destroyClockViewModel=m,this._toolbar=T,this._homeButton=C,this._sceneModePicker=y,this._projectionPicker=Y,this._baseLayerPicker=Q,this._navigationHelpButton=M,this._animation=V,this._timeline=E,this._fullscreenButton=I,this._vrButton=_,this._geocoder=g,this._eventHelper=U,this._lastWidth=0,this._lastHeight=0,this._allowDataSourcesToSuspendAnimation=!0,this._entityView=void 0,this._enableInfoOrSelection=c(A)||c(G),this._clockTrackedDataSource=void 0,this._trackedEntity=void 0,this._needTrackedEntityUpdate=!1,this._selectedEntity=void 0,this._zoomIsFlight=!1,this._zoomTarget=void 0,this._zoomPromise=void 0,this._zoomOptions=void 0,this._selectedEntityChanged=new It,this._trackedEntityChanged=new It,this._referenceFrame=0,Lt.track(this,["_trackedEntity","_selectedEntity","_clockTrackedDataSource"]),U.add(Z.dataSourceAdded,Do.prototype._onDataSourceAdded,this),U.add(Z.dataSourceRemoved,Do.prototype._onDataSourceRemoved,this),U.add(u.postUpdate,Do.prototype.resize,this),U.add(u.postRender,Do.prototype._postRender,this);let z=Z.length;for(let $=0;$<z;$++)this._dataSourceAdded(Z,Z.get($));this._dataSourceAdded(void 0,F.defaultDataSource),U.add(Z.dataSourceAdded,Do.prototype._dataSourceAdded,this),U.add(Z.dataSourceRemoved,Do.prototype._dataSourceRemoved,this);function H($){i.camera.unTrack(!1);let dt=Mkt(i,$);c(dt)?et.getValueOrUndefined(dt.position,i.clock.currentTime)?i.trackedEntity=dt:i.zoomTo(dt):c(i.trackedEntity)&&(i.trackedEntity=void 0)}function nt($){i.selectedEntity=Mkt(i,$)}h.screenSpaceEventHandler.setInputAction(nt,Zi.LEFT_CLICK),h.screenSpaceEventHandler.setInputAction(H,Zi.LEFT_DOUBLE_CLICK),u.fxaa=!0,u.fxaaOrderIndependentTranslucency=!0,this._bottomContainer.style.pointerEvents="none",this.container.style.userSelect="none"}Object.defineProperties(Do.prototype,{container:{get:function(){return this._container}},creditDisplay:{get:function(){return this._cesiumWidget.creditDisplay}},bottomContainer:{get:function(){return this._bottomContainer}},cesiumWidget:{get:function(){return this._cesiumWidget}},selectionIndicator:{get:function(){return this._selectionIndicator}},infoBox:{get:function(){return this._infoBox}},geocoder:{get:function(){return this._geocoder}},homeButton:{get:function(){return this._homeButton}},sceneModePicker:{get:function(){return this._sceneModePicker}},projectionPicker:{get:function(){return this._projectionPicker}},baseLayerPicker:{get:function(){return this._baseLayerPicker}},navigationHelpButton:{get:function(){return this._navigationHelpButton}},animation:{get:function(){return this._animation}},timeline:{get:function(){return this._timeline}},fullscreenButton:{get:function(){return this._fullscreenButton}},vrButton:{get:function(){return this._vrButton}},dataSourceDisplay:{get:function(){return this._dataSourceDisplay}},entities:{get:function(){return this._dataSourceDisplay.defaultDataSource.entities}},dataSources:{get:function(){return this._dataSourceCollection}},canvas:{get:function(){return this._cesiumWidget.canvas}},scene:{get:function(){return this._cesiumWidget.scene}},shadows:{get:function(){return this.scene.shadowMap.enabled},set:function(t){this.scene.shadowMap.enabled=t}},terrainShadows:{get:function(){return this.scene.globe.shadows},set:function(t){this.scene.globe.shadows=t}},shadowMap:{get:function(){return this.scene.shadowMap}},imageryLayers:{get:function(){return this.scene.imageryLayers}},terrainProvider:{get:function(){return this.scene.terrainProvider},set:function(t){this.scene.terrainProvider=t}},camera:{get:function(){return this.scene.camera}},postProcessStages:{get:function(){return this.scene.postProcessStages}},clock:{get:function(){return this._clockViewModel.clock}},clockViewModel:{get:function(){return this._clockViewModel}},screenSpaceEventHandler:{get:function(){return this._cesiumWidget.screenSpaceEventHandler}},targetFrameRate:{get:function(){return this._cesiumWidget.targetFrameRate},set:function(t){this._cesiumWidget.targetFrameRate=t}},useDefaultRenderLoop:{get:function(){return this._cesiumWidget.useDefaultRenderLoop},set:function(t){this._cesiumWidget.useDefaultRenderLoop=t}},resolutionScale:{get:function(){return this._cesiumWidget.resolutionScale},set:function(t){this._cesiumWidget.resolutionScale=t}},useBrowserRecommendedResolution:{get:function(){return this._cesiumWidget.useBrowserRecommendedResolution},set:function(t){this._cesiumWidget.useBrowserRecommendedResolution=t}},allowDataSourcesToSuspendAnimation:{get:function(){return this._allowDataSourcesToSuspendAnimation},set:function(t){this._allowDataSourcesToSuspendAnimation=t}},trackedEntity:{get:function(){return this._trackedEntity},set:function(t){if(this._trackedEntity!==t){this._trackedEntity=t,wrt(this);let e=this.scene,n=e.mode;!c(t)||!c(t.position)?(this._needTrackedEntityUpdate=!1,(n===ut.COLUMBUS_VIEW||n===ut.SCENE2D)&&(e.screenSpaceCameraController.enableTranslate=!0),(n===ut.COLUMBUS_VIEW||n===ut.SCENE3D)&&(e.screenSpaceCameraController.enableTilt=!0),this._entityView=void 0,this.camera.lookAtTransform(L.IDENTITY)):this._needTrackedEntityUpdate=!0,this._trackedEntityChanged.raiseEvent(t),this.scene.requestRender()}}},selectedEntity:{get:function(){return this._selectedEntity},set:function(t){if(this._selectedEntity!==t){this._selectedEntity=t;let e=c(this._selectionIndicator)?this._selectionIndicator.viewModel:void 0;c(t)?c(e)&&e.animateAppear():c(e)&&e.animateDepart(),this._selectedEntityChanged.raiseEvent(t)}}},selectedEntityChanged:{get:function(){return this._selectedEntityChanged}},trackedEntityChanged:{get:function(){return this._trackedEntityChanged}},clockTrackedDataSource:{get:function(){return this._clockTrackedDataSource},set:function(t){this._clockTrackedDataSource!==t&&(this._clockTrackedDataSource=t,Okt(this._timeline,this.clock,t))}},referenceFrame:{get:function(){return this._referenceFrame},set:function(t){this._referenceFrame=t}}});Do.prototype.extend=function(t,e){t(this,e)};Do.prototype.resize=function(){let t=this._cesiumWidget,e=this._container,n=e.clientWidth,i=e.clientHeight,o=c(this._animation),a=c(this._timeline);if(t.resize(),n===this._lastWidth&&i===this._lastHeight)return;let s=i-125,l=this._baseLayerPickerDropDown;if(c(l)&&(l.style.maxHeight=`${s}px`),c(this._geocoder)){let b=this._geocoder.searchSuggestionsContainer;b.style.maxHeight=`${s}px`}c(this._infoBox)&&(this._infoBox.viewModel.maxHeight=s);let r=this._timeline,d,m=0,h=0,Z=0;if(o&&window.getComputedStyle(this._animation.container).visibility!=="hidden"){let b=this._lastWidth;d=this._animation.container,n>900?(m=169,b<=900&&(d.style.width="169px",d.style.height="112px",this._animation.resize())):n>=600?(m=136,(b<600||b>900)&&(d.style.width="136px",d.style.height="90px",this._animation.resize())):(m=106,(b>600||b===0)&&(d.style.width="106px",d.style.height="70px",this._animation.resize())),h=m+5}if(a&&window.getComputedStyle(this._timeline.container).visibility!=="hidden"){let b=this._fullscreenButton,u=this._vrButton,F=r.container,U=F.style;Z=F.clientHeight+3,U.left=`${m}px`;let G=0;c(b)&&(G+=b.container.clientWidth),c(u)&&(G+=u.container.clientWidth),U.right=`${G}px`,r.resize()}this._bottomContainer.style.left=`${h}px`,this._bottomContainer.style.bottom=`${Z}px`,this._lastWidth=n,this._lastHeight=i};Do.prototype.forceResize=function(){this._lastWidth=0,this.resize()};Do.prototype.render=function(){this._cesiumWidget.render()};Do.prototype.isDestroyed=function(){return!1};Do.prototype.destroy=function(){let t;c(this.screenSpaceEventHandler)&&!this.screenSpaceEventHandler.isDestroyed()&&(this.screenSpaceEventHandler.removeInputAction(Zi.LEFT_CLICK),this.screenSpaceEventHandler.removeInputAction(Zi.LEFT_DOUBLE_CLICK));let e=this.dataSources,n=e.length;for(t=0;t<n;t++)this._dataSourceRemoved(e,e.get(t));return this._dataSourceRemoved(void 0,this._dataSourceDisplay.defaultDataSource),this._container.removeChild(this._element),this._element.removeChild(this._toolbar),this._eventHelper.removeAll(),c(this._geocoder)&&(this._geocoder=this._geocoder.destroy()),c(this._homeButton)&&(this._homeButton=this._homeButton.destroy()),c(this._sceneModePicker)&&(this._sceneModePicker=this._sceneModePicker.destroy()),c(this._projectionPicker)&&(this._projectionPicker=this._projectionPicker.destroy()),c(this._baseLayerPicker)&&(this._baseLayerPicker=this._baseLayerPicker.destroy()),c(this._animation)&&(this._element.removeChild(this._animation.container),this._animation=this._animation.destroy()),c(this._timeline)&&(this._timeline.removeEventListener("settime",Dkt,!1),this._element.removeChild(this._timeline.container),this._timeline=this._timeline.destroy()),c(this._fullscreenButton)&&(this._fullscreenSubscription.dispose(),this._element.removeChild(this._fullscreenButton.container),this._fullscreenButton=this._fullscreenButton.destroy()),c(this._vrButton)&&(this._vrSubscription.dispose(),this._vrModeSubscription.dispose(),this._element.removeChild(this._vrButton.container),this._vrButton=this._vrButton.destroy()),c(this._infoBox)&&(this._element.removeChild(this._infoBox.container),this._infoBox=this._infoBox.destroy()),c(this._selectionIndicator)&&(this._element.removeChild(this._selectionIndicator.container),this._selectionIndicator=this._selectionIndicator.destroy()),this._destroyClockViewModel&&(this._clockViewModel=this._clockViewModel.destroy()),this._dataSourceDisplay=this._dataSourceDisplay.destroy(),this._cesiumWidget=this._cesiumWidget.destroy(),this._destroyDataSourceCollection&&(this._dataSourceCollection=this._dataSourceCollection.destroy()),At(this)};Do.prototype._dataSourceAdded=function(t,e){e.entities.collectionChanged.addEventListener(Do.prototype._onEntityCollectionChanged,this)};Do.prototype._dataSourceRemoved=function(t,e){let n=e.entities;n.collectionChanged.removeEventListener(Do.prototype._onEntityCollectionChanged,this),c(this.trackedEntity)&&n.getById(this.trackedEntity.id)===this.trackedEntity&&(this.trackedEntity=void 0),c(this.selectedEntity)&&n.getById(this.selectedEntity.id)===this.selectedEntity&&(this.selectedEntity=void 0)};Do.prototype._onTick=function(t){let e=t.currentTime,n=this._dataSourceDisplay.update(e);this._allowDataSourcesToSuspendAnimation&&(this._clockViewModel.canAnimate=n);let i=this._entityView;if(c(i)){let m=this._trackedEntity;this._dataSourceDisplay.getBoundingSphere(m,!1,LU)===ve.DONE&&i.update(e,LU)}let o,a=!1,s=this.selectedEntity,l=c(s)&&this._enableInfoOrSelection;l&&s.isShowing&&s.isAvailable(e)&&(this._dataSourceDisplay.getBoundingSphere(s,!0,LU)!==ve.FAILED?o=LU.center:c(s.position)&&(o=s.position.getValue(e,o)),a=c(o));let r=c(this._selectionIndicator)?this._selectionIndicator.viewModel:void 0;c(r)&&(r.position=p.clone(o,r.position),r.showSelection=l&&a,r.update());let d=c(this._infoBox)?this._infoBox.viewModel:void 0;c(d)&&(d.showInfo=l,d.enableCamera=a,d.isCameraTracking=this.trackedEntity===this.selectedEntity,l?(d.titleText=f(s.name,s.id),d.description=et.getValueOrDefault(s.description,e,"")):(d.titleText="",d.description=""))};Do.prototype._onEntityCollectionChanged=function(t,e,n){let i=n.length;for(let o=0;o<i;o++){let a=n[o];this.trackedEntity===a&&(this.trackedEntity=void 0),this.selectedEntity===a&&(this.selectedEntity=void 0)}};Do.prototype._onInfoBoxCameraClicked=function(t){if(t.isCameraTracking&&this.trackedEntity===this.selectedEntity)this.trackedEntity=void 0;else{let n=this.selectedEntity.position;c(n)?this.trackedEntity=this.selectedEntity:this.zoomTo(this.selectedEntity)}};Do.prototype._clearTrackedObject=function(){this.trackedEntity=void 0};Do.prototype._onInfoBoxClockClicked=function(t){this.selectedEntity=void 0};Do.prototype._clearObjects=function(){this.trackedEntity=void 0,this.selectedEntity=void 0};Do.prototype._onDataSourceChanged=function(t){this.clockTrackedDataSource===t&&Okt(this.timeline,this.clock,t)};Do.prototype._onDataSourceAdded=function(t,e){this._automaticallyTrackDataSourceClocks&&(this.clockTrackedDataSource=e);let n=e.entities.id,i=this._eventHelper.add(e.changedEvent,Do.prototype._onDataSourceChanged,this);this._dataSourceChangedListeners[n]=i};Do.prototype._onDataSourceRemoved=function(t,e){let n=this.clockTrackedDataSource===e,i=e.entities.id;if(this._dataSourceChangedListeners[i](),this._dataSourceChangedListeners[i]=void 0,n){let o=t.length;this._automaticallyTrackDataSourceClocks&&o>0?this.clockTrackedDataSource=t.get(o-1):this.clockTrackedDataSource=void 0}};Do.prototype.zoomTo=function(t,e){return Hkt(this,t,{offset:e},!1)};Do.prototype.flyTo=function(t,e){return Hkt(this,t,e,!0)};function Hkt(t,e,n,i){wrt(t);let o=new Promise(a=>{t._completeZoom=function(s){a(s)}});return t._zoomPromise=o,t._zoomIsFlight=i,t._zoomOptions=n,Promise.resolve(e).then(function(a){if(t._zoomPromise===o){if(a instanceof $r){let s;c(a.imageryProvider)?s=Promise.resolve(a.getImageryRectangle()):s=new Promise(l=>{let r=a.readyEvent.addEventListener(()=>{r(),l(a.getImageryRectangle())})}),s.then(function(l){return rg(l,t.scene)}).then(function(l){t._zoomPromise===o&&(t._zoomTarget=l)});return}if(a instanceof Pr||a instanceof UN||a instanceof TU){t._zoomTarget=a;return}if(a.isLoading&&c(a.loadingEvent)){let s=a.loadingEvent.addEventListener(function(){s(),t._zoomPromise===o&&(t._zoomTarget=a.entities.values.slice(0))});return}if(Array.isArray(a)){t._zoomTarget=a.slice(0);return}a=f(a.values,a),c(a.entities)&&(a=a.entities.values),Array.isArray(a)?t._zoomTarget=a.slice(0):t._zoomTarget=[a]}}),t.scene.requestRender(),o}function iO(t){t._zoomPromise=void 0,t._zoomTarget=void 0,t._zoomOptions=void 0}function wrt(t){let e=t._zoomPromise;c(e)&&(iO(t),t._completeZoom(!1))}Do.prototype._postRender=function(){WDe(this),fDe(this)};function WDe(t){let e=t._zoomTarget;if(!c(e)||t.scene.mode===ut.MORPHING)return;let n=t.scene,i=n.camera,o=f(t._zoomOptions,{}),a;function s(m){c(o.offset)||(o.offset=new Zu(0,-.5,m.radius)),a={offset:o.offset,duration:o.duration,maximumHeight:o.maximumHeight,complete:function(){t._completeZoom(!0)},cancel:function(){t._completeZoom(!1)}},t._zoomIsFlight?i.flyToBoundingSphere(e.boundingSphere,a):(i.viewBoundingSphere(m,o.offset),i.lookAtTransform(L.IDENTITY),t._completeZoom(!0)),iO(t)}if(e instanceof UN){if(c(e.boundingSphere)){s(e.boundingSphere);return}let m=e.frameChanged.addEventListener(function(h){s(h.boundingSphere),m()});return}if(e instanceof Pr||e instanceof TU){s(e.boundingSphere);return}if(e instanceof gt){a={destination:n.mapProjection.ellipsoid.cartographicToCartesian(e),duration:o.duration,maximumHeight:o.maximumHeight,complete:function(){t._completeZoom(!0)},cancel:function(){t._completeZoom(!1)}},t._zoomIsFlight?i.flyTo(a):(i.setView(a),t._completeZoom(!0)),iO(t);return}let l=e,r=[];for(let m=0,h=l.length;m<h;m++){let Z=t._dataSourceDisplay.getBoundingSphere(l[m],!1,LU);if(Z===ve.PENDING)return;Z!==ve.FAILED&&r.push(Ft.clone(LU))}if(r.length===0){wrt(t);return}t.trackedEntity=void 0;let d=Ft.fromBoundingSpheres(r);t._zoomIsFlight?(iO(t),i.flyToBoundingSphere(d,{duration:o.duration,maximumHeight:o.maximumHeight,complete:function(){t._completeZoom(!0)},cancel:function(){t._completeZoom(!1)},offset:o.offset})):(i.viewBoundingSphere(d,o.offset),i.lookAtTransform(L.IDENTITY),iO(t),t._completeZoom(!0))}function fDe(t){if(!t._needTrackedEntityUpdate)return;let e=t._trackedEntity,n=t.clock.currentTime,i=et.getValueOrUndefined(e.position,n);if(!c(i))return;let o=t.scene,a=t._dataSourceDisplay.getBoundingSphere(e,!1,LU);if(a===ve.PENDING)return;let s=o.mode;(s===ut.COLUMBUS_VIEW||s===ut.SCENE2D)&&(o.screenSpaceCameraController.enableTranslate=!1),(s===ut.COLUMBUS_VIEW||s===ut.SCENE3D)&&(o.screenSpaceCameraController.enableTilt=!1);let l=a!==ve.FAILED?LU:void 0;t._entityView=new AL(e,o,o.mapProjection.ellipsoid),t._entityView.update(n,l),t._needTrackedEntityUpdate=!1}var Prt=Do;var XAa=R(W(),1),FDe='.cesium-svgPath-svg{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden}.cesium-button{display:inline-block;position:relative;background:#303336;border:1px solid #444;color:#edffff;fill:#edffff;border-radius:4px;padding:5px 12px;margin:2px 3px;cursor:pointer;overflow:hidden;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.cesium-button:focus{color:#fff;fill:#fff;border-color:#ea4;outline:0}.cesium-button:hover{color:#fff;fill:#fff;background:#48b;border-color:#aef;box-shadow:0 0 8px #fff}.cesium-button:active{color:#000;fill:#000;background:#adf;border-color:#fff;box-shadow:0 0 8px #fff}.cesium-button-disabled,.cesium-button-disabled:active,.cesium-button-disabled:focus,.cesium-button-disabled:hover,.cesium-button:disabled{background:#303336;border-color:#444;color:#646464;fill:#646464;box-shadow:none;cursor:default}.cesium-button option{background-color:#000;color:#eee}.cesium-button option:disabled{color:#777}.cesium-button input,.cesium-button label{cursor:pointer}.cesium-button input{vertical-align:sub}.cesium-toolbar-button{box-sizing:border-box;width:32px;height:32px;border-radius:14%;padding:0;vertical-align:middle;z-index:0}.cesium-performanceDisplay-defaultContainer{position:absolute;top:50px;right:10px;text-align:right}.cesium-performanceDisplay{background-color:rgba(40,40,40,.7);padding:7px;border-radius:5px;border:1px solid #444;font:bold 12px sans-serif}.cesium-performanceDisplay-fps{color:#e52}.cesium-performanceDisplay-throttled{color:#a42}.cesium-performanceDisplay-ms{color:#de3}.cesium-animation-theme{visibility:hidden;display:block;position:absolute;z-index:-100}.cesium-animation-themeNormal{color:#222}.cesium-animation-themeHover{color:#4488b0}.cesium-animation-themeSelect{color:#242}.cesium-animation-themeDisabled{color:#333}.cesium-animation-themeKnob{color:#222}.cesium-animation-themePointer{color:#2e2}.cesium-animation-themeSwoosh{color:#8ac}.cesium-animation-themeSwooshHover{color:#aef}.cesium-animation-svgText{fill:#edffff;font-family:Sans-Serif;font-size:15px;text-anchor:middle}.cesium-animation-blank{fill:#000;fill-opacity:0.01;stroke:none}.cesium-animation-rectButton{cursor:pointer;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.cesium-animation-rectButton .cesium-animation-buttonGlow{fill:#fff;stroke:none;display:none}.cesium-animation-rectButton:hover .cesium-animation-buttonGlow{display:block}.cesium-animation-rectButton .cesium-animation-buttonPath{fill:#edffff}.cesium-animation-rectButton .cesium-animation-buttonMain{stroke:#444;stroke-width:1.2}.cesium-animation-rectButton:hover .cesium-animation-buttonMain{stroke:#aef}.cesium-animation-rectButton:active .cesium-animation-buttonMain{fill:#abd6ff}.cesium-animation-buttonDisabled{-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.cesium-animation-buttonDisabled .cesium-animation-buttonMain{stroke:#555}.cesium-animation-buttonDisabled .cesium-animation-buttonPath{fill:#818181}.cesium-animation-buttonDisabled .cesium-animation-buttonGlow{display:none}.cesium-animation-buttonToggled .cesium-animation-buttonGlow{display:block;fill:#2e2}.cesium-animation-buttonToggled .cesium-animation-buttonMain{stroke:#2e2}.cesium-animation-buttonToggled:hover .cesium-animation-buttonGlow{fill:#fff}.cesium-animation-buttonToggled:hover .cesium-animation-buttonMain{stroke:#2e2}.cesium-animation-shuttleRingG{cursor:pointer}.cesium-animation-shuttleRingPointer{cursor:pointer}.cesium-animation-shuttleRingPausePointer{cursor:pointer}.cesium-animation-shuttleRingBack{fill:#181818;fill-opacity:0.8;stroke:#333;stroke-width:1.2}.cesium-animation-shuttleRingSwoosh line{stroke:#8ac;stroke-width:3;stroke-opacity:0.2;stroke-linecap:round}.cesium-animation-knobOuter{cursor:pointer;stroke:#444;stroke-width:1.2}.cesium-animation-knobInner{cursor:pointer}.cesium-baseLayerPicker-selected{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.cesium-baseLayerPicker-dropDown{display:block;position:absolute;box-sizing:content-box;top:auto;right:0;width:320px;max-height:500px;margin-top:5px;background-color:rgba(38,38,38,.75);border:1px solid #444;padding:6px;overflow:auto;border-radius:10px;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none;transform:translate(0,-20%);visibility:hidden;opacity:0;transition:visibility 0s .2s,opacity .2s ease-in,transform .2s ease-in}.cesium-baseLayerPicker-dropDown-visible{transform:translate(0,0);visibility:visible;opacity:1;transition:opacity .2s ease-out,transform .2s ease-out}.cesium-baseLayerPicker-sectionTitle{display:block;font-family:sans-serif;font-size:16pt;text-align:left;color:#edffff;margin-bottom:4px}.cesium-baseLayerPicker-choices{margin-bottom:5px}.cesium-baseLayerPicker-categoryTitle{color:#edffff;font-size:11pt}.cesium-baseLayerPicker-choices{display:block;border:1px solid #888;border-radius:5px;padding:5px 0}.cesium-baseLayerPicker-item{display:inline-block;vertical-align:top;margin:2px 5px;width:64px;text-align:center;cursor:pointer}.cesium-baseLayerPicker-itemLabel{display:block;font-family:sans-serif;font-size:8pt;text-align:center;vertical-align:middle;color:#edffff;cursor:pointer;word-wrap:break-word}.cesium-baseLayerPicker-item:focus .cesium-baseLayerPicker-itemLabel,.cesium-baseLayerPicker-item:hover .cesium-baseLayerPicker-itemLabel{text-decoration:underline}.cesium-baseLayerPicker-itemIcon{display:inline-block;position:relative;width:inherit;height:auto;background-size:100% 100%;border:solid 1px #444;border-radius:9px;color:#edffff;margin:0;padding:0;cursor:pointer;box-sizing:border-box}.cesium-baseLayerPicker-item:hover .cesium-baseLayerPicker-itemIcon{border-color:#fff;box-shadow:0 0 8px #fff,0 0 8px #fff}.cesium-baseLayerPicker-selectedItem .cesium-baseLayerPicker-itemLabel{color:#bdecf8}.cesium-baseLayerPicker-selectedItem .cesium-baseLayerPicker-itemIcon{border:double 4px #bdecf8}.cesium-widget{position:relative}.cesium-widget,.cesium-widget canvas{width:100%;height:100%;touch-action:none}.cesium-widget-credits{display:block;position:absolute;bottom:0;left:0;color:#fff;font-size:10px;text-shadow:0 0 2px #000;padding-right:5px}.cesium-widget-credits a,.cesium-widget-credits a:visited{color:#fff}.cesium-widget-errorPanel{position:absolute;top:0;right:0;bottom:0;left:0;text-align:center;background:rgba(0,0,0,.7);z-index:99999}.cesium-widget-errorPanel:before{display:inline-block;vertical-align:middle;height:100%;content:""}.cesium-widget-errorPanel-content{width:75%;max-width:500px;display:inline-block;text-align:left;vertical-align:middle;border:1px solid #510c00;border-radius:7px;background-color:#f0d9d5;font-size:14px;color:#510c00}.cesium-widget-errorPanel-content.expanded{max-width:75%}.cesium-widget-errorPanel-header{font-size:18px;font-family:"Open Sans",Verdana,Geneva,sans-serif;background:#d69d93;border-bottom:2px solid #510c00;padding-bottom:10px;border-radius:3px 3px 0 0;padding:15px}.cesium-widget-errorPanel-scroll{overflow:auto;font-family:"Open Sans",Verdana,Geneva,sans-serif;white-space:pre-wrap;padding:0 15px;margin:10px 0 20px 0}.cesium-widget-errorPanel-buttonPanel{padding:0 15px;margin:10px 0 20px 0;text-align:right}.cesium-widget-errorPanel-buttonPanel button{border-color:#510c00;background:#d69d93;color:#202020;margin:0}.cesium-widget-errorPanel-buttonPanel button:focus{border-color:#510c00;background:#f0d9d5;color:#510c00}.cesium-widget-errorPanel-buttonPanel button:hover{border-color:#510c00;background:#f0d9d5;color:#510c00}.cesium-widget-errorPanel-buttonPanel button:active{border-color:#510c00;background:#b17b72;color:#510c00}.cesium-widget-errorPanel-more-details{text-decoration:underline;cursor:pointer}.cesium-widget-errorPanel-more-details:hover{color:#2b0700}.cesium-cesiumInspector{border-radius:5px;transition:width ease-in-out .25s;background:rgba(48,51,54,.8);border:1px solid #444;color:#edffff;display:inline-block;position:relative;padding:4px 12px;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden}.cesium-cesiumInspector-button{text-align:center;font-size:11pt}.cesium-cesiumInspector-visible .cesium-cesiumInspector-button{border-bottom:1px solid #aaa;padding-bottom:3px}.cesium-cesiumInspector input:enabled,.cesium-cesiumInspector-button{cursor:pointer}.cesium-cesiumInspector-visible{width:185px;height:auto}.cesium-cesiumInspector-hidden{width:122px;height:17px}.cesium-cesiumInspector-sectionContent{max-height:500px}.cesium-cesiumInspector-section-collapsed .cesium-cesiumInspector-sectionContent{max-height:0;padding:0!important;overflow:hidden}.cesium-cesiumInspector-dropDown{margin:5px 0;font-family:sans-serif;font-size:10pt;width:185px}.cesium-cesiumInspector-frustumStatistics{padding-left:10px;padding:5px;background-color:rgba(80,80,80,.75)}.cesium-cesiumInspector-pickButton{background-color:rgba(0,0,0,.3);border:1px solid #444;color:#edffff;border-radius:5px;padding:3px 7px;cursor:pointer;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none;margin:0 auto}.cesium-cesiumInspector-pickButton:focus{outline:0}.cesium-cesiumInspector-pickButton:active,.cesium-cesiumInspector-pickButtonHighlight{color:#000;background:#adf;border-color:#fff;box-shadow:0 0 8px #fff}.cesium-cesiumInspector-center{text-align:center}.cesium-cesiumInspector-sectionHeader{font-weight:700;font-size:10pt;margin:0;cursor:pointer}.cesium-cesiumInspector-pickSection{border:1px solid #aaa;border-radius:5px;padding:3px;margin-bottom:5px}.cesium-cesiumInspector-sectionContent{margin-bottom:10px;transition:max-height .25s}.cesium-cesiumInspector-tileText{padding-bottom:10px;border-bottom:1px solid #aaa}.cesium-cesiumInspector-relativeText{padding-top:10px}.cesium-cesiumInspector-sectionHeader::before{margin-right:5px;content:"-";width:1ch;display:inline-block}.cesium-cesiumInspector-section-collapsed .cesium-cesiumInspector-sectionHeader::before{content:"+"}ul.cesium-cesiumInspector-statistics{margin:0;padding-top:3px;padding-bottom:3px}ul.cesium-cesiumInspector-statistics+ul.cesium-cesiumInspector-statistics{border-top:1px solid #aaa}.cesium-cesiumInspector-slider{margin-top:5px}.cesium-cesiumInspector-slider input[type=number]{text-align:left;background-color:#222;outline:0;border:1px solid #444;color:#edffff;width:100px;border-radius:3px;padding:1px;margin-left:10px;cursor:auto}.cesium-cesiumInspector-slider input[type=number]::-webkit-inner-spin-button,.cesium-cesiumInspector-slider input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.cesium-cesiumInspector-slider input[type=range]{margin-left:5px;vertical-align:middle}.cesium-cesiumInspector-hide .cesium-cesiumInspector-styleEditor{display:none}.cesium-cesiumInspector-styleEditor{padding:10px;border-radius:5px;background:rgba(48,51,54,.8);border:1px solid #444}.cesium-cesiumInspector-styleEditor textarea{width:100%;height:300px;background:0 0;color:#edffff;border:none;padding:0;white-space:pre;overflow-wrap:normal;overflow-x:auto}.cesium-3DTilesInspector{width:300px;pointer-events:all}.cesium-3DTilesInspector-statistics{font-size:11px}.cesium-3DTilesInspector div,.cesium-3DTilesInspector input[type=range]{width:100%;box-sizing:border-box}.cesium-cesiumInspector-error{color:#ff9e9e;overflow:auto}.cesium-3DTilesInspector .cesium-cesiumInspector-section{margin-top:3px}.cesium-3DTilesInspector .cesium-cesiumInspector-sectionHeader+.cesium-cesiumInspector-show{border-top:1px solid #fff}input.cesium-cesiumInspector-url{overflow:hidden;white-space:nowrap;overflow-x:scroll;background-color:transparent;color:#fff;outline:0;border:none;height:1em;width:100%}.cesium-cesiumInspector .field-group{display:table}.cesium-cesiumInspector .field-group>label{display:table-cell;font-weight:700}.cesium-cesiumInspector .field-group>.field{display:table-cell;width:100%}.cesium-button.cesium-fullscreenButton{display:block;width:100%;height:100%;margin:0;border-radius:0}.cesium-button.cesium-vrButton{display:block;width:100%;height:100%;margin:0;border-radius:0}.cesium-viewer-geocoderContainer .cesium-geocoder-input{border:solid 1px #444;background-color:rgba(40,40,40,.7);color:#fff;display:inline-block;vertical-align:middle;width:0;height:32px;margin:0;padding:0 32px 0 0;border-radius:0;box-sizing:border-box;transition:width ease-in-out .25s,background-color .2s ease-in-out;-webkit-appearance:none}.cesium-viewer-geocoderContainer:hover .cesium-geocoder-input{border-color:#aef;box-shadow:0 0 8px #fff}.cesium-viewer-geocoderContainer .cesium-geocoder-input:focus{border-color:#ea4;background-color:rgba(15,15,15,.9);box-shadow:none;outline:0}.cesium-viewer-geocoderContainer .cesium-geocoder-input-wide,.cesium-viewer-geocoderContainer .cesium-geocoder-input:focus,.cesium-viewer-geocoderContainer:hover .cesium-geocoder-input{padding-left:4px;width:250px}.cesium-viewer-geocoderContainer .search-results{position:absolute;background-color:#000;color:#eee;overflow-y:auto;opacity:.8;width:100%}.cesium-viewer-geocoderContainer .search-results ul{list-style-type:none;margin:0;padding:0}.cesium-viewer-geocoderContainer .search-results ul li{font-size:14px;padding:3px 10px}.cesium-viewer-geocoderContainer .search-results ul li:hover{cursor:pointer}.cesium-viewer-geocoderContainer .search-results ul li.active{background:#48b}.cesium-geocoder-searchButton{background-color:#303336;display:inline-block;position:absolute;cursor:pointer;width:32px;top:1px;right:1px;height:30px;vertical-align:middle;fill:#edffff}.cesium-geocoder-searchButton:hover{background-color:#48b}.cesium-infoBox{display:block;position:absolute;top:50px;right:0;width:40%;max-width:480px;background:rgba(38,38,38,.95);color:#edffff;border:1px solid #444;border-right:none;border-top-left-radius:7px;border-bottom-left-radius:7px;box-shadow:0 0 10px 1px #000;transform:translate(100%,0);visibility:hidden;opacity:0;transition:visibility 0s .2s,opacity .2s ease-in,transform .2s ease-in}.cesium-infoBox-visible{transform:translate(0,0);visibility:visible;opacity:1;transition:opacity .2s ease-out,transform .2s ease-out}.cesium-infoBox-title{display:block;height:20px;padding:5px 30px 5px 25px;background:#545454;border-top-left-radius:7px;text-align:center;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;box-sizing:content-box}.cesium-infoBox-bodyless .cesium-infoBox-title{border-bottom-left-radius:7px}button.cesium-infoBox-camera{display:block;position:absolute;top:4px;left:4px;width:22px;height:22px;background:0 0;border-color:transparent;border-radius:3px;padding:0 5px;margin:0}button.cesium-infoBox-close{display:block;position:absolute;top:5px;right:5px;height:20px;background:0 0;border:none;border-radius:2px;font-weight:700;font-size:16px;padding:0 5px;margin:0;color:#edffff}button.cesium-infoBox-close:focus{background:rgba(238,136,0,.44);outline:0}button.cesium-infoBox-close:hover{background:#888;color:#000}button.cesium-infoBox-close:active{background:#a00;color:#000}.cesium-infoBox-bodyless .cesium-infoBox-iframe{display:none}.cesium-infoBox-iframe{border:none;width:100%;width:calc(100% - 2px)}span.cesium-sceneModePicker-wrapper{display:inline-block;position:relative;margin:0 3px}.cesium-sceneModePicker-visible{visibility:visible;opacity:1;transition:opacity .25s linear}.cesium-sceneModePicker-hidden{visibility:hidden;opacity:0;transition:visibility 0s .25s,opacity .25s linear}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-none{display:none}.cesium-sceneModePicker-slide-svg{transition:left 2s;top:0;left:0}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-dropDown-icon{box-sizing:border-box;padding:0;margin:3px 0}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button2D,.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button3D,.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-buttonColumbusView{margin:0 0 3px 0}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button3D .cesium-sceneModePicker-icon2D{left:100%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button3D .cesium-sceneModePicker-iconColumbusView{left:200%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-buttonColumbusView .cesium-sceneModePicker-icon3D{left:-200%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-buttonColumbusView .cesium-sceneModePicker-icon2D{left:-100%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button2D .cesium-sceneModePicker-icon3D{left:-100%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button2D .cesium-sceneModePicker-iconColumbusView{left:100%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-selected{border-color:#2e2;box-shadow:0 0 8px #fff,0 0 8px #fff}span.cesium-projectionPicker-wrapper{display:inline-block;position:relative;margin:0 3px}.cesium-projectionPicker-visible{visibility:visible;opacity:1;transition:opacity .25s linear}.cesium-projectionPicker-hidden{visibility:hidden;opacity:0;transition:visibility 0s .25s,opacity .25s linear}.cesium-projectionPicker-wrapper .cesium-projectionPicker-none{display:none}.cesium-projectionPicker-wrapper .cesium-projectionPicker-dropDown-icon{box-sizing:border-box;padding:0;margin:3px 0}.cesium-projectionPicker-wrapper .cesium-projectionPicker-buttonOrthographic,.cesium-projectionPicker-wrapper .cesium-projectionPicker-buttonPerspective{margin:0 0 3px 0}.cesium-projectionPicker-wrapper .cesium-projectionPicker-buttonPerspective .cesium-projectionPicker-iconOrthographic{left:100%}.cesium-projectionPicker-wrapper .cesium-projectionPicker-buttonOrthographic .cesium-projectionPicker-iconPerspective{left:-100%}.cesium-projectionPicker-wrapper .cesium-projectionPicker-selected{border-color:#2e2;box-shadow:0 0 8px #fff,0 0 8px #fff}.cesium-performance-watchdog-message-area{position:relative;background-color:#ff0;color:#000;padding:10px}.cesium-performance-watchdog-message{margin-right:30px}.cesium-performance-watchdog-message-dismiss{position:absolute;right:0;margin:0 10px 0 0}.cesium-navigationHelpButton-wrapper{position:relative;display:inline-block}.cesium-navigation-help{visibility:hidden;position:absolute;top:38px;right:2px;width:250px;border-radius:10px;transform:scale(.01);transform-origin:234px -10px;transition:visibility 0s .25s,transform .25s ease-in}.cesium-navigation-help-visible{visibility:visible;transform:scale(1);transition:transform .25s ease-out}.cesium-navigation-help-instructions{border:1px solid #444;background-color:rgba(38,38,38,.75);padding-bottom:5px;border-radius:0 0 10px 10px}.cesium-click-navigation-help{display:none}.cesium-touch-navigation-help{display:none;padding-top:5px}.cesium-click-navigation-help-visible{display:block}.cesium-touch-navigation-help-visible{display:block}.cesium-navigation-help-pan{color:#6cf;font-weight:700}.cesium-navigation-help-zoom{color:#65fd00;font-weight:700}.cesium-navigation-help-rotate{color:#ffd800;font-weight:700}.cesium-navigation-help-tilt{color:#d800d8;font-weight:700}.cesium-navigation-help-details{color:#fff}.cesium-navigation-button{color:#fff;background-color:transparent;border-bottom:none;border-top:1px solid #444;border-right:1px solid #444;margin:0;width:50%;cursor:pointer}.cesium-navigation-button-icon{vertical-align:middle;padding:5px 1px}.cesium-navigation-button:focus{outline:0}.cesium-navigation-button-left{border-radius:10px 0 0 0;border-left:1px solid #444}.cesium-navigation-button-right{border-radius:0 10px 0 0;border-left:none}.cesium-navigation-button-selected{background-color:rgba(38,38,38,.75)}.cesium-navigation-button-unselected{background-color:rgba(0,0,0,.75)}.cesium-navigation-button-unselected:hover{background-color:rgba(76,76,76,.75)}.cesium-selection-wrapper{position:absolute;width:160px;height:160px;pointer-events:none;visibility:hidden;opacity:0;transition:visibility 0s .2s,opacity .2s ease-in}.cesium-selection-wrapper-visible{visibility:visible;opacity:1;transition:opacity .2s ease-out}.cesium-selection-wrapper svg{fill:#2e2;stroke:#000;stroke-width:1.1px}.cesium-timeline-main{position:relative;left:0;bottom:0;overflow:hidden;border:solid 1px #888}.cesium-timeline-trackContainer{width:100%;overflow:auto;border-top:solid 1px #888;position:relative;top:0;left:0}.cesium-timeline-tracks{position:absolute;top:0;left:0;width:100%}.cesium-timeline-needle{position:absolute;left:0;top:1.7em;bottom:0;width:1px;background:red}.cesium-timeline-bar{position:relative;left:0;top:0;overflow:hidden;cursor:pointer;width:100%;height:1.7em;background:linear-gradient(to bottom,rgba(116,117,119,.8) 0,rgba(58,68,82,.8) 11%,rgba(46,50,56,.8) 46%,rgba(53,53,53,.8) 81%,rgba(53,53,53,.8) 100%)}.cesium-timeline-ruler{visibility:hidden;white-space:nowrap;font-size:80%;z-index:-200}.cesium-timeline-highlight{position:absolute;bottom:0;left:0;background:#08f}.cesium-timeline-ticLabel{position:absolute;top:0;left:0;white-space:nowrap;font-size:80%;color:#eee}.cesium-timeline-ticMain{position:absolute;bottom:0;left:0;width:1px;height:50%;background:#eee}.cesium-timeline-ticSub{position:absolute;bottom:0;left:0;width:1px;height:33%;background:#aaa}.cesium-timeline-ticTiny{position:absolute;bottom:0;left:0;width:1px;height:25%;background:#888}.cesium-timeline-icon16{display:block;position:absolute;width:16px;height:16px;background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAQCAYAAAB3AH1ZAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9sIDBITKIVzLEMAAAKNSURBVEjHxdXNSxRhHAfw7zzrqhuoWJnSkrippUVSEKsHI9BTUYdAJA/RoYMREV26rAdn6tAfUARi16hQqkOBQRgUEYFWEC3OwczMjdZd92VmdWfmeelgTjO7q7gb0VzmmZnn85vvPPPMM8B/3qTcE2PPpuTZKB1eWuUQACgXYACYwVFbCTTVeZXB/i55o4LFelcAZfStYD4vpAoPGAGo4GBcQEgSOAUMQyAezwK6iQfDPXnhS/FkHZ+/8VLMWxxqWkfH3gbMRNOYi2roavbja0zHQmoFPYf8ED4Ko4aivm9MOG/u9I8mwrafeK7a/tVrNc/bARYN5noadeq7q0342vXw9CIMU6BmW8rVP9cPBPe52uu+v3O/y9sB4gkTWs6Qsk0mj5ExXMelejvA8WafYmkmGPHanTijdtvif8rx5RiCjdWKs2Cp3jWRDl96KhrbqlBeJqBOLyLQXg0IgbkZDS0dO8EZxZfPSTA9jvDDK3mT0OmP1FXh3XwEEAKdTX5MRWLgjCK4pwH3xt/YnjgLHAv4lHTCAKMMu/wV+KZGob6PoKyMQ0+sgBpZVJZn0NterxQaVqef/DRn+/EXYds/mZx2eVeAW9d65dhCEsaKCb7K8HH0gqTevyh9GDkn0VULRiaLzJKGBu9swfdaiie5RVo9ESURN8E8BE0n7ggACJy8KzghSCzp6DmwWxkaCm24EBXr8wI8Hrkq06QBiRC0t24HALS11IBTCyJl4vb1AXmzpbVYTwoVOXN0h7L8Mwtm8bXPybIQ/5FCX3dA2cr6XowvGCA02CvztAnz9+JiZk1AMxG6fEreSoBiPNmoyNnuWiWVzAIAtISO08E6pZi/3N96AIDn4E3h3P8L/wshP+txtEs4JAAAAABJRU5ErkJggg==");background-repeat:no-repeat}.cesium-viewer{font-family:sans-serif;font-size:16px;overflow:hidden;display:block;position:relative;top:0;left:0;width:100%;height:100%}.cesium-viewer-cesiumWidgetContainer{width:100%;height:100%}.cesium-viewer-bottom{display:block;position:absolute;bottom:0;left:0;padding-right:5px}.cesium-viewer .cesium-widget-credits{display:inline;position:static;bottom:auto;left:auto;padding-right:0;color:#fff;font-size:10px;text-shadow:0 0 2px #000}.cesium-viewer-timelineContainer{position:absolute;bottom:0;left:169px;right:29px;height:27px;padding:0;margin:0;overflow:hidden;font-size:14px}.cesium-viewer-animationContainer{position:absolute;bottom:0;left:0;padding:0;width:169px;height:112px}.cesium-viewer-fullscreenContainer{position:absolute;bottom:0;right:0;padding:0;width:29px;height:29px;overflow:hidden}.cesium-viewer-vrContainer{position:absolute;bottom:0;right:0;padding:0;width:29px;height:29px;overflow:hidden}.cesium-viewer-toolbar{display:block;position:absolute;top:5px;right:5px}.cesium-viewer-cesiumInspectorContainer{display:block;position:absolute;top:50px;right:10px}.cesium-viewer-geocoderContainer{position:relative;display:inline-block;margin:0 3px}.cesium-viewer-cesium3DTilesInspectorContainer{display:block;position:absolute;top:50px;right:10px;max-height:calc(100% - 120px);box-sizing:border-box;overflow-y:auto;overflow-x:hidden}.cesium-viewer-bottom{z-index:10000}';function UDe(t,e){let n=document.head||document.getElementsByTagName("head")[0],i=document.createElement("style");i.innerText=FDe,n.appendChild(i)}var vrt=UDe;var MAa=R(W(),1);var oO,wkt;function GDe(){let t=180/Math.PI*Math.atan2(oO.scene.camera.position.x,oO.scene.camera.position.y),e=t>0?t:360+t;console.log(`Azimuth: ${e}`),console.log(`Pointing: ${(e+180)%360}`)}function ADe(t,e={autosave:!1,interval:1e3}){oO=t;let{view:n}=t.storage.queryOptions;if(c(n)){let i=n.split(/[ ,]+/);if(i.length>1){let o=isNaN(+i[0])?0:+i[0],a=isNaN(+i[1])?0:+i[1],s=i.length>2&&!isNaN(+i[2])?+i[2]:300,l=i.length>3&&!isNaN(+i[3])?k.toRadians(+i[3]):void 0,r=i.length>4&&!isNaN(+i[4])?k.toRadians(+i[4]):void 0,d=i.length>5&&!isNaN(+i[5])?k.toRadians(+i[5]):void 0;oO.camera.setView({destination:p.fromDegrees(o,a,s),orientation:{heading:l,pitch:r,roll:d}})}}e.autosave&&oO.camera.changed.addEventListener(()=>{window.clearTimeout(wkt),wkt=window.setTimeout(GDe,1e3)})}var Krt=ADe;var OAa=R(W(),1);function TDe(t){let e=document.createElement("div");e.className="cesium-viewer-cesium3DTilesInspectorContainer",t.container.appendChild(e);let n=new fD(e,t.scene);Object.defineProperties(t,{cesium3DTilesInspector:{get:function(){return n}}})}var zrt=TDe;var PAa=R(W(),1);function SDe(t){let e=document.createElement("div");e.className="cesium-viewer-cesiumInspectorContainer",t.container.appendChild(e);let n=new ND(e,t.scene);Object.defineProperties(t,{cesiumInspector:{get:function(){return n}}})}var jrt=SDe;var jAa=R(W(),1);function gDe(t,e){e=f(e,f.EMPTY_OBJECT);let n=!0,i=f(e.flyToOnDrop,!0),o=new It,a=f(e.clearOnDrop,!0),s=f(e.dropTarget,t.container),l=f(e.clampToGround,!0),r=e.proxy;s=Ui(s),Object.defineProperties(t,{dropTarget:{get:function(){return s},set:function(m){Pkt(s,d),s=m,qrt(s,d)}},dropEnabled:{get:function(){return n},set:function(m){m!==n&&(m?qrt(s,d):Pkt(s,d),n=m)}},dropError:{get:function(){return o}},clearOnDrop:{get:function(){return a},set:function(m){a=m}},flyToOnDrop:{get:function(){return i},set:function(m){i=m}},proxy:{get:function(){return r},set:function(m){r=m}},clampToGround:{get:function(){return l},set:function(m){l=m}}});function d(m){hg(m),a&&(t.entities.removeAll(),t.dataSources.removeAll());let h=m.dataTransfer.files,Z=h.length;for(let b=0;b<Z;b++){let u=h[b],F=new FileReader;F.onload=EDe(t,u,r,l),F.onerror=CDe(t,u),F.readAsText(u)}}qrt(s,d),t.destroy=Y5(t,t.destroy,function(){t.dropEnabled=!1}),t._handleDrop=d}function hg(t){t.stopPropagation(),t.preventDefault()}function Pkt(t,e){let n=t;c(n)&&(n.removeEventListener("drop",e,!1),n.removeEventListener("dragenter",hg,!1),n.removeEventListener("dragover",hg,!1),n.removeEventListener("dragexit",hg,!1))}function qrt(t,e){t.addEventListener("drop",e,!1),t.addEventListener("dragenter",hg,!1),t.addEventListener("dragover",hg,!1),t.addEventListener("dragexit",hg,!1)}function EDe(t,e,n,i){let o=t.scene;return function(a){let s=e.name;try{let l;if(/\.czml$/i.test(s))l=O0.load(JSON.parse(a.target.result),{sourceUri:s});else if(/\.geojson$/i.test(s)||/\.json$/i.test(s)||/\.topojson$/i.test(s))l=gL.load(JSON.parse(a.target.result),{sourceUri:s,clampToGround:i});else if(/\.(kml|kmz)$/i.test(s))l=iM.load(e,{sourceUri:s,proxy:n,camera:o.camera,canvas:o.canvas,clampToGround:i,screenOverlayContainer:t.container});else if(/\.gpx$/i.test(s))l=NL.load(e,{sourceUri:s,proxy:n});else{t.dropError.raiseEvent(t,s,`Unrecognized file: ${s}`);return}c(l)&&t.dataSources.add(l).then(function(r){t.flyToOnDrop&&t.flyTo(r)}).catch(function(r){t.dropError.raiseEvent(t,s,r)})}catch(l){t.dropError.raiseEvent(t,s,l)}}}function CDe(t,e){return function(n){t.dropError.raiseEvent(t,e.name,n.target.error)}}var $rt=gDe;var iTa=R(W(),1);function IDe(t,e){e=f(e,f.EMPTY_OBJECT);let n=new OD({scene:t.scene,container:t.bottomContainer,lowFrameRateMessage:e.lowFrameRateMessage});Object.defineProperties(t,{performanceWatchdog:{get:function(){return n}}})}var tdt=IDe;var sTa=R(W(),1);function NDe(t){if(t.scene.mode!==ut.SCENE3D)return;let e=t.scene,n=t.clock.currentTime,i=e.camera,o=p.clone(i.position);if(t.referenceFrame===ri.INERTIAL&&!t.trackedEntity){let a=Pe.computeIcrfToFixedMatrix(n);if(c(a)){let s=L.fromRotationTranslation(a);i.lookAtTransform(s,o)}}else t.trackedEntity||i.lookAtTransform(L.IDENTITY)}function yDe(t){Object.defineProperty(t,"referenceFrame",{get:function(){return this._referenceFrame},set:function(e){this._referenceFrame=e,this.scene.referenceFrame=e,this.eventBus&&this.eventBus.emit("referenceFrame",this._referenceFrame);let n=this.dataSources._dataSources;for(let i=0;i<n.length;i++)n[i]._entityCollection.referenceFrame=e}}),t.dataSources.dataSourceAdded.addEventListener(function(e,n){n._viewer=t,n._entityCollection.referenceFrame=t.referenceFrame}),t.scene.preRender.addEventListener(function(){NDe(t)})}var edt=yDe;var dTa=R(W(),1);function ndt(t,e){t.storage={},t.storage.queryOptions=Tc(window.location.search.substring(1))}var ATa=R(W(),1);var FTa=R(W(),1);var uTa=R(W(),1);function vkt(t){let e=t.split(` + </div>`,n.appendChild(i);let o=new XD(e);Lt.track(o),Lt.applyBindings(o,n),c(o.defaultLayer)&&(o.currentLayer=o.defaultLayer)}var Xrt=O5e;var CUa=b(W(),1);var UUa=b(W(),1);var H5e="M 13.84375 7.03125 C 11.412798 7.03125 9.46875 8.975298 9.46875 11.40625 L 9.46875 11.59375 L 2.53125 7.21875 L 2.53125 24.0625 L 9.46875 19.6875 C 9.4853444 22.104033 11.423165 24.0625 13.84375 24.0625 L 25.875 24.0625 C 28.305952 24.0625 30.28125 22.087202 30.28125 19.65625 L 30.28125 11.40625 C 30.28125 8.975298 28.305952 7.03125 25.875 7.03125 L 13.84375 7.03125 z",w5e="M 27.34375 1.65625 L 5.28125 27.9375 L 8.09375 30.3125 L 30.15625 4.03125 L 27.34375 1.65625 z M 13.84375 7.03125 C 11.412798 7.03125 9.46875 8.975298 9.46875 11.40625 L 9.46875 11.59375 L 2.53125 7.21875 L 2.53125 24.0625 L 9.46875 19.6875 C 9.4724893 20.232036 9.5676108 20.7379 9.75 21.21875 L 21.65625 7.03125 L 13.84375 7.03125 z M 28.21875 7.71875 L 14.53125 24.0625 L 25.875 24.0625 C 28.305952 24.0625 30.28125 22.087202 30.28125 19.65625 L 30.28125 11.40625 C 30.28125 9.8371439 29.456025 8.4902779 28.21875 7.71875 z";function Jrt(){this._cameraClicked=new It,this._closeClicked=new It,this.maxHeight=500,this.enableCamera=!1,this.isCameraTracking=!1,this.showInfo=!1,this.titleText="",this.description="",Lt.track(this,["showInfo","titleText","description","maxHeight","enableCamera","isCameraTracking"]),this._loadingIndicatorHtml='<div class="cesium-infoBox-loadingContainer"><span class="cesium-infoBox-loading"></span></div>',this.cameraIconPath=void 0,Lt.defineProperty(this,"cameraIconPath",{get:function(){return!this.enableCamera||this.isCameraTracking?w5e:H5e}}),Lt.defineProperty(this,"_bodyless",{get:function(){return!c(this.description)||this.description.length===0}})}Jrt.prototype.maxHeightOffset=function(t){return`${this.maxHeight-t}px`};Object.defineProperties(Jrt.prototype,{cameraClicked:{get:function(){return this._cameraClicked}},closeClicked:{get:function(){return this._closeClicked}}});var JD=Jrt;function f4(t){t=Ui(t);let e=document.createElement("div");e.className="cesium-infoBox",e.setAttribute("data-bind",'css: { "cesium-infoBox-visible" : showInfo, "cesium-infoBox-bodyless" : _bodyless }'),t.appendChild(e);let n=document.createElement("div");n.className="cesium-infoBox-title",n.setAttribute("data-bind","text: titleText"),e.appendChild(n);let i=document.createElement("button");i.type="button",i.className="cesium-button cesium-infoBox-camera",i.setAttribute("data-bind",'attr: { title: "Focus camera on object" },click: function () { cameraClicked.raiseEvent(this); },enable: enableCamera,cesiumSvgPath: { path: cameraIconPath, width: 32, height: 32 }'),e.appendChild(i);let o=document.createElement("button");o.type="button",o.className="cesium-infoBox-close",o.setAttribute("data-bind","click: function () { closeClicked.raiseEvent(this); }"),o.innerHTML="×",e.appendChild(o);let a=document.createElement("iframe");a.className="cesium-infoBox-iframe",a.setAttribute("sandbox","allow-same-origin allow-popups allow-forms"),a.setAttribute("data-bind","style : { maxHeight : maxHeightOffset(40) }"),a.setAttribute("allowfullscreen",!0),e.appendChild(a);let s=new JD;Lt.applyBindings(s,e),this._container=t,this._element=e,this._frame=a,this._viewModel=s,this._descriptionSubscription=void 0;let l=this;a.addEventListener("load",function(){let r=a.contentDocument,d=r.createElement("link");d.href=Dn("Widgets/InfoBox/InfoBoxDescription.css"),d.rel="stylesheet",d.type="text/css";let m=r.createElement("div");m.className="cesium-infoBox-description",r.head.appendChild(d),r.body.appendChild(m),l._descriptionSubscription=od(s,"description",function(h){a.style.height="5px",m.innerHTML=h;let u=null,R=m.firstElementChild;if(R!==null&&m.childNodes.length===1){let F=window.getComputedStyle(R);if(F!==null){let U=F["background-color"],G=v.fromCssColorString(U);c(G)&&G.alpha!==0&&(u=F["background-color"])}}e.style["background-color"]=u;let V=m.getBoundingClientRect().height;a.style.height=`${V}px`})}),a.setAttribute("src","about:blank")}Object.defineProperties(f4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}},frame:{get:function(){return this._frame}}});f4.prototype.isDestroyed=function(){return!1};f4.prototype.destroy=function(){let t=this._container;return Lt.cleanNode(this._element),t.removeChild(this._element),c(this._descriptionSubscription)&&this._descriptionSubscription.dispose(),At(this)};var LD=f4;var LUa=b(W(),1);var BUa=b(W(),1);function B2t(){this.showInstructions=!1;let t=this;this._command=Ri(function(){t.showInstructions=!t.showInstructions}),this._showClick=Ri(function(){t._touch=!1}),this._showTouch=Ri(function(){t._touch=!0}),this._touch=!1,this.tooltip="Navigation Instructions",Lt.track(this,["tooltip","showInstructions","_touch"])}Object.defineProperties(B2t.prototype,{command:{get:function(){return this._command}},showClick:{get:function(){return this._showClick}},showTouch:{get:function(){return this._showTouch}}});var MD=B2t;function F4(t){let e=Ui(t.container),n=new MD,i=f(t.instructionsInitiallyVisible,!1);n.showInstructions=i,n._svgPath="M16,1.466C7.973,1.466,1.466,7.973,1.466,16c0,8.027,6.507,14.534,14.534,14.534c8.027,0,14.534-6.507,14.534-14.534C30.534,7.973,24.027,1.466,16,1.466z M17.328,24.371h-2.707v-2.596h2.707V24.371zM17.328,19.003v0.858h-2.707v-1.057c0-3.19,3.63-3.696,3.63-5.963c0-1.034-0.924-1.826-2.134-1.826c-1.254,0-2.354,0.924-2.354,0.924l-1.541-1.915c0,0,1.519-1.584,4.137-1.584c2.487,0,4.796,1.54,4.796,4.136C21.156,16.208,17.328,16.627,17.328,19.003z";let o=document.createElement("span");o.className="cesium-navigationHelpButton-wrapper",e.appendChild(o);let a=document.createElement("button");a.type="button",a.className="cesium-button cesium-toolbar-button cesium-navigation-help-button",a.setAttribute("data-bind","attr: { title: tooltip },click: command,cesiumSvgPath: { path: _svgPath, width: 32, height: 32 }"),o.appendChild(a);let s=document.createElement("div");s.className="cesium-navigation-help",s.setAttribute("data-bind",'css: { "cesium-navigation-help-visible" : showInstructions}'),o.appendChild(s);let l=document.createElement("button");l.type="button",l.className="cesium-navigation-button cesium-navigation-button-left",l.setAttribute("data-bind",'click: showClick, css: {"cesium-navigation-button-selected": !_touch, "cesium-navigation-button-unselected": _touch}');let r=document.createElement("img");r.src=Dn("Widgets/Images/NavigationHelp/Mouse.svg"),r.className="cesium-navigation-button-icon",r.style.width="25px",r.style.height="25px",l.appendChild(r),l.appendChild(document.createTextNode("Mouse"));let d=document.createElement("button");d.type="button",d.className="cesium-navigation-button cesium-navigation-button-right",d.setAttribute("data-bind",'click: showTouch, css: {"cesium-navigation-button-selected": _touch, "cesium-navigation-button-unselected": !_touch}');let m=document.createElement("img");m.src=Dn("Widgets/Images/NavigationHelp/Touch.svg"),m.className="cesium-navigation-button-icon",m.style.width="25px",m.style.height="25px",d.appendChild(m),d.appendChild(document.createTextNode("Touch")),s.appendChild(l),s.appendChild(d);let h=document.createElement("div");h.className="cesium-click-navigation-help cesium-navigation-help-instructions",h.setAttribute("data-bind",'css: { "cesium-click-navigation-help-visible" : !_touch}'),h.innerHTML=` <table> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/MouseLeft.svg")}" width="48" height="48" /></td> <td> <div class="cesium-navigation-help-pan">Pan view</div> <div class="cesium-navigation-help-details">Left click + drag</div> </td> </tr> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/MouseRight.svg")}" width="48" height="48" /></td> <td> <div class="cesium-navigation-help-zoom">Zoom view</div> <div class="cesium-navigation-help-details">Right click + drag, or</div> <div class="cesium-navigation-help-details">Mouse wheel scroll</div> </td> </tr> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/MouseMiddle.svg")}" width="48" height="48" /></td> <td> <div class="cesium-navigation-help-rotate">Rotate view</div> <div class="cesium-navigation-help-details">Middle click + drag, or</div> <div class="cesium-navigation-help-details">CTRL + Left/Right click + drag</div> </td> </tr> </table>`,s.appendChild(h);let u=document.createElement("div");u.className="cesium-touch-navigation-help cesium-navigation-help-instructions",u.setAttribute("data-bind",'css: { "cesium-touch-navigation-help-visible" : _touch}'),u.innerHTML=` <table> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/TouchDrag.svg")}" width="70" height="48" /></td> <td> <div class="cesium-navigation-help-pan">Pan view</div> <div class="cesium-navigation-help-details">One finger drag</div> </td> </tr> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/TouchZoom.svg")}" width="70" height="48" /></td> <td> <div class="cesium-navigation-help-zoom">Zoom view</div> <div class="cesium-navigation-help-details">Two finger pinch</div> </td> </tr> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/TouchTilt.svg")}" width="70" height="48" /></td> <td> <div class="cesium-navigation-help-rotate">Tilt view</div> <div class="cesium-navigation-help-details">Two finger drag, same direction</div> </td> </tr> <tr> <td><img src="${Dn("Widgets/Images/NavigationHelp/TouchRotate.svg")}" width="70" height="48" /></td> <td> <div class="cesium-navigation-help-tilt">Rotate view</div> <div class="cesium-navigation-help-details">Two finger drag, opposite direction</div> </td> </tr> </table>`,s.appendChild(u),Lt.applyBindings(n,o),this._container=e,this._viewModel=n,this._wrapper=o,this._closeInstructions=function(R){o.contains(R.target)||(n.showInstructions=!1)},In.supportsPointerEvents()?document.addEventListener("pointerdown",this._closeInstructions,!0):(document.addEventListener("mousedown",this._closeInstructions,!0),document.addEventListener("touchstart",this._closeInstructions,!0))}Object.defineProperties(F4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});F4.prototype.isDestroyed=function(){return!1};F4.prototype.destroy=function(){return In.supportsPointerEvents()?document.removeEventListener("pointerdown",this._closeInstructions,!0):(document.removeEventListener("mousedown",this._closeInstructions,!0),document.removeEventListener("touchstart",this._closeInstructions,!0)),Lt.cleanNode(this._wrapper),this._container.removeChild(this._wrapper),At(this)};var _D=F4;var tGa=b(W(),1);var PUa=b(W(),1);function Lrt(t){this._scene=t.scene,this.lowFrameRateMessage=f(t.lowFrameRateMessage,"This application appears to be performing poorly on your system. Please try using a different web browser or updating your video drivers."),this.lowFrameRateMessageDismissed=!1,this.showingLowFrameRateMessage=!1,Lt.track(this,["lowFrameRateMessage","lowFrameRateMessageDismissed","showingLowFrameRateMessage"]);let e=this;this._dismissMessage=Ri(function(){e.showingLowFrameRateMessage=!1,e.lowFrameRateMessageDismissed=!0});let n=P5.fromScene(t.scene);this._unsubscribeLowFrameRate=n.lowFrameRate.addEventListener(function(){e.lowFrameRateMessageDismissed||(e.showingLowFrameRateMessage=!0)}),this._unsubscribeNominalFrameRate=n.nominalFrameRate.addEventListener(function(){e.showingLowFrameRateMessage=!1})}Object.defineProperties(Lrt.prototype,{scene:{get:function(){return this._scene}},dismissMessage:{get:function(){return this._dismissMessage}}});Lrt.prototype.destroy=function(){return this._unsubscribeLowFrameRate(),this._unsubscribeNominalFrameRate(),At(this)};var DD=Lrt;function U4(t){let e=Ui(t.container),n=new DD(t),i=document.createElement("div");i.className="cesium-performance-watchdog-message-area",i.setAttribute("data-bind","visible: showingLowFrameRateMessage");let o=document.createElement("button");o.setAttribute("type","button"),o.className="cesium-performance-watchdog-message-dismiss",o.innerHTML="×",o.setAttribute("data-bind","click: dismissMessage"),i.appendChild(o);let a=document.createElement("div");a.className="cesium-performance-watchdog-message",a.setAttribute("data-bind","html: lowFrameRateMessage"),i.appendChild(a),e.appendChild(i),Lt.applyBindings(n,i),this._container=e,this._viewModel=n,this._element=i}Object.defineProperties(U4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});U4.prototype.isDestroyed=function(){return!1};U4.prototype.destroy=function(){return this._viewModel.destroy(),Lt.cleanNode(this._element),this._container.removeChild(this._element),At(this)};var OD=U4;var pGa=b(W(),1);var sGa=b(W(),1);function G4(t){this._scene=t,this._orthographic=t.camera.frustum instanceof wn,this._flightInProgress=!1,this.dropDownVisible=!1,this.tooltipPerspective="Perspective Projection",this.tooltipOrthographic="Orthographic Projection",this.selectedTooltip=void 0,this.sceneMode=t.mode,Lt.track(this,["_orthographic","_flightInProgress","sceneMode","dropDownVisible","tooltipPerspective","tooltipOrthographic"]);let e=this;Lt.defineProperty(this,"selectedTooltip",function(){return e._orthographic?e.tooltipOrthographic:e.tooltipPerspective}),this._toggleDropDown=Ri(function(){e.sceneMode===Vt.SCENE2D||e._flightInProgress||(e.dropDownVisible=!e.dropDownVisible)}),this._eventHelper=new rl,this._eventHelper.add(t.morphComplete,function(n,i,o,a){e.sceneMode=o,e._orthographic=o===Vt.SCENE2D||e._scene.camera.frustum instanceof wn}),this._eventHelper.add(t.preRender,function(){e._flightInProgress=c(t.camera._currentFlight)}),this._switchToPerspective=Ri(function(){e.sceneMode!==Vt.SCENE2D&&(e._scene.camera.switchToPerspectiveFrustum(),e._orthographic=!1,e.dropDownVisible=!1)}),this._switchToOrthographic=Ri(function(){e.sceneMode!==Vt.SCENE2D&&(e._scene.camera.switchToOrthographicFrustum(),e._orthographic=!0,e.dropDownVisible=!1)}),this._sceneMode=Vt}Object.defineProperties(G4.prototype,{scene:{get:function(){return this._scene}},toggleDropDown:{get:function(){return this._toggleDropDown}},switchToPerspective:{get:function(){return this._switchToPerspective}},switchToOrthographic:{get:function(){return this._switchToOrthographic}},isOrthographicProjection:{get:function(){return this._orthographic}}});G4.prototype.isDestroyed=function(){return!1};G4.prototype.destroy=function(){this._eventHelper.removeAll(),At(this)};var HD=G4;var P5e="M 28.15625,10.4375 9.125,13.21875 13.75,43.25 41.75,55.09375 50.8125,37 54.5,11.9375 z m 0.125,3 19.976451,0.394265 L 43.03125,16.875 22.6875,14.28125 z M 50.971746,15.705477 47.90625,36.03125 42.53125,46 44.84375,19.3125 z M 12.625,16.03125 l 29.15625,3.6875 -2.65625,31 L 16.4375,41.125 z",v5e="m 31.560594,6.5254438 -20.75,12.4687502 0.1875,24.5625 22.28125,11.8125 19.5,-12 0.65625,-0.375 0,-0.75 0.0312,-23.21875 z m 0.0625,3.125 16.65625,9.5000002 -16.125,10.28125 -17.34375,-9.71875 z m 18.96875,11.1875002 0.15625,20.65625 -17.46875,10.59375 0.15625,-20.28125 z m -37.0625,1.25 17.21875,9.625 -0.15625,19.21875 -16.9375,-9 z";function A4(t,e){t=Ui(t);let n=new HD(e);n._perspectivePath=P5e,n._orthographicPath=v5e;let i=document.createElement("span");i.className="cesium-projectionPicker-wrapper cesium-toolbar-button",t.appendChild(i);let o=document.createElement("button");o.type="button",o.className="cesium-button cesium-toolbar-button",o.setAttribute("data-bind",'css: { "cesium-projectionPicker-buttonPerspective": !_orthographic, "cesium-projectionPicker-buttonOrthographic": _orthographic, "cesium-button-disabled" : sceneMode === _sceneMode.SCENE2D || _flightInProgress, "cesium-projectionPicker-selected": dropDownVisible },attr: { title: selectedTooltip },click: toggleDropDown'),o.innerHTML='<!-- ko cesiumSvgPath: { path: _perspectivePath, width: 64, height: 64, css: "cesium-projectionPicker-iconPerspective" } --><!-- /ko --><!-- ko cesiumSvgPath: { path: _orthographicPath, width: 64, height: 64, css: "cesium-projectionPicker-iconOrthographic" } --><!-- /ko -->',i.appendChild(o);let a=document.createElement("button");a.type="button",a.className="cesium-button cesium-toolbar-button cesium-projectionPicker-dropDown-icon",a.setAttribute("data-bind",'css: { "cesium-projectionPicker-visible" : (dropDownVisible && _orthographic), "cesium-projectionPicker-none" : !_orthographic, "cesium-projectionPicker-hidden" : !dropDownVisible },attr: { title: tooltipPerspective },click: switchToPerspective,cesiumSvgPath: { path: _perspectivePath, width: 64, height: 64 }'),i.appendChild(a);let s=document.createElement("button");s.type="button",s.className="cesium-button cesium-toolbar-button cesium-projectionPicker-dropDown-icon",s.setAttribute("data-bind",'css: { "cesium-projectionPicker-visible" : (dropDownVisible && !_orthographic), "cesium-projectionPicker-none" : _orthographic, "cesium-projectionPicker-hidden" : !dropDownVisible},attr: { title: tooltipOrthographic },click: switchToOrthographic,cesiumSvgPath: { path: _orthographicPath, width: 64, height: 64 }'),i.appendChild(s),Lt.applyBindings(n,i),this._viewModel=n,this._container=t,this._wrapper=i,this._closeDropDown=function(l){i.contains(l.target)||(n.dropDownVisible=!1)},In.supportsPointerEvents()?document.addEventListener("pointerdown",this._closeDropDown,!0):(document.addEventListener("mousedown",this._closeDropDown,!0),document.addEventListener("touchstart",this._closeDropDown,!0))}Object.defineProperties(A4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});A4.prototype.isDestroyed=function(){return!1};A4.prototype.destroy=function(){return this._viewModel.destroy(),In.supportsPointerEvents()?document.removeEventListener("pointerdown",this._closeDropDown,!0):(document.removeEventListener("mousedown",this._closeDropDown,!0),document.removeEventListener("touchstart",this._closeDropDown,!0)),Lt.cleanNode(this._wrapper),this._container.removeChild(this._wrapper),At(this)};var wD=A4;var gGa=b(W(),1);var fGa=b(W(),1);function S4(t,e){this._scene=t;let n=this,i=function(o,a,s,l){n.sceneMode=s,n.dropDownVisible=!1};this._eventHelper=new rl,this._eventHelper.add(t.morphStart,i),this._duration=f(e,2),this.sceneMode=t.mode,this.dropDownVisible=!1,this.tooltip2D="2D",this.tooltip3D="3D",this.tooltipColumbusView="Columbus View",Lt.track(this,["sceneMode","dropDownVisible","tooltip2D","tooltip3D","tooltipColumbusView"]),this.selectedTooltip=void 0,Lt.defineProperty(this,"selectedTooltip",function(){let o=n.sceneMode;return o===Vt.SCENE2D?n.tooltip2D:o===Vt.SCENE3D?n.tooltip3D:n.tooltipColumbusView}),this._toggleDropDown=Ri(function(){n.dropDownVisible=!n.dropDownVisible}),this._morphTo2D=Ri(function(){t.morphTo2D(n._duration)}),this._morphTo3D=Ri(function(){t.morphTo3D(n._duration)}),this._morphToColumbusView=Ri(function(){t.morphToColumbusView(n._duration)}),this._sceneMode=Vt}Object.defineProperties(S4.prototype,{scene:{get:function(){return this._scene}},duration:{get:function(){return this._duration},set:function(t){this._duration=t}},toggleDropDown:{get:function(){return this._toggleDropDown}},morphTo2D:{get:function(){return this._morphTo2D}},morphTo3D:{get:function(){return this._morphTo3D}},morphToColumbusView:{get:function(){return this._morphToColumbusView}}});S4.prototype.isDestroyed=function(){return!1};S4.prototype.destroy=function(){this._eventHelper.removeAll(),At(this)};var PD=S4;var K5e="m 32.401392,4.9330437 c -7.087603,0 -14.096095,2.884602 -19.10793,7.8946843 -5.0118352,5.010083 -7.9296167,11.987468 -7.9296167,19.072999 0,7.085531 2.9177815,14.097848 7.9296167,19.107931 4.837653,4.835961 11.541408,7.631372 18.374354,7.82482 0.05712,0.01231 0.454119,0.139729 0.454119,0.139729 l 0.03493,-0.104797 c 0.08246,7.84e-4 0.162033,0.03493 0.244525,0.03493 0.08304,0 0.161515,-0.03414 0.244526,-0.03493 l 0.03493,0.104797 c 0,0 0.309474,-0.129487 0.349323,-0.139729 6.867765,-0.168094 13.582903,-2.965206 18.444218,-7.82482 2.558195,-2.5573 4.551081,-5.638134 5.903547,-8.977584 1.297191,-3.202966 2.02607,-6.661489 2.02607,-10.130347 0,-6.237309 -2.366261,-12.31219 -6.322734,-17.116794 -0.0034,-0.02316 0.0049,-0.04488 0,-0.06986 -0.01733,-0.08745 -0.104529,-0.278855 -0.104797,-0.279458 -5.31e-4,-0.0012 -0.522988,-0.628147 -0.523984,-0.62878 -3.47e-4,-2.2e-4 -0.133444,-0.03532 -0.244525,-0.06987 C 51.944299,13.447603 51.751076,13.104317 51.474391,12.827728 46.462556,7.8176457 39.488996,4.9330437 32.401392,4.9330437 z m -2.130866,3.5281554 0.104797,9.6762289 c -4.111695,-0.08361 -7.109829,-0.423664 -9.257041,-0.943171 1.198093,-2.269271 2.524531,-4.124404 3.91241,-5.414496 2.167498,-2.0147811 3.950145,-2.8540169 5.239834,-3.3185619 z m 2.794579,0 c 1.280302,0.4754953 3.022186,1.3285948 5.065173,3.2486979 1.424667,1.338973 2.788862,3.303645 3.982275,5.728886 -2.29082,0.403367 -5.381258,0.621049 -8.942651,0.698645 L 33.065105,8.4611991 z m 5.728886,0.2445256 c 4.004072,1.1230822 7.793098,3.1481363 10.724195,6.0782083 0.03468,0.03466 0.07033,0.06991 0.104797,0.104797 -0.45375,0.313891 -0.923054,0.663002 -1.956205,1.082899 -0.647388,0.263114 -1.906242,0.477396 -2.829511,0.733577 -1.382296,-2.988132 -3.027146,-5.368585 -4.785716,-7.0213781 -0.422866,-0.397432 -0.835818,-0.6453247 -1.25756,-0.9781032 z m -15.33525,0.7685092 c -0.106753,0.09503 -0.207753,0.145402 -0.31439,0.244526 -1.684973,1.5662541 -3.298068,3.8232211 -4.680919,6.5672591 -0.343797,-0.14942 -1.035052,-0.273198 -1.292493,-0.419186 -0.956528,-0.542427 -1.362964,-1.022024 -1.537018,-1.292493 -0.0241,-0.03745 -0.01868,-0.0401 -0.03493,-0.06986 2.250095,-2.163342 4.948824,-3.869984 7.859752,-5.0302421 z m -9.641296,7.0912431 c 0.464973,0.571618 0.937729,1.169056 1.956205,1.746612 0.349907,0.198425 1.107143,0.335404 1.537018,0.523983 -1.20166,3.172984 -1.998037,7.051901 -2.165798,11.772162 C 14.256557,30.361384 12.934823,30.161483 12.280427,29.90959 10.644437,29.279855 9.6888882,28.674891 9.1714586,28.267775 8.6540289,27.860658 8.6474751,27.778724 8.6474751,27.778724 l -0.069864,0.03493 C 9.3100294,23.691285 11.163248,19.798527 13.817445,16.565477 z m 37.552149,0.523984 c 2.548924,3.289983 4.265057,7.202594 4.890513,11.318043 -0.650428,0.410896 -1.756876,1.001936 -3.563088,1.606882 -1.171552,0.392383 -3.163859,0.759153 -4.960377,1.117832 -0.04367,-4.752703 -0.784809,-8.591423 -1.88634,-11.807094 0.917574,-0.263678 2.170552,-0.486495 2.864443,-0.76851 1.274693,-0.518066 2.003942,-1.001558 2.654849,-1.467153 z m -31.439008,2.619917 c 2.487341,0.672766 5.775813,1.137775 10.479669,1.222628 l 0.104797,10.689263 0,0.03493 0,0.733577 c -5.435005,-0.09059 -9.512219,-0.519044 -12.610536,-1.117831 0.106127,-4.776683 0.879334,-8.55791 2.02607,-11.562569 z m 23.264866,0.31439 c 1.073459,3.067541 1.833795,6.821314 1.816476,11.702298 -3.054474,0.423245 -7.062018,0.648559 -11.702298,0.698644 l 0,-0.838373 -0.104796,-10.654331 c 4.082416,-0.0864 7.404468,-0.403886 9.990618,-0.908238 z M 8.2632205,30.922625 c 0.7558676,0.510548 1.5529563,1.013339 3.0041715,1.57195 0.937518,0.360875 2.612202,0.647642 3.91241,0.978102 0.112814,3.85566 0.703989,7.107756 1.606883,9.920754 -1.147172,-0.324262 -2.644553,-0.640648 -3.423359,-0.978102 -1.516688,-0.657177 -2.386627,-1.287332 -2.864443,-1.71168 -0.477816,-0.424347 -0.489051,-0.489051 -0.489051,-0.489051 L 9.8002387,40.319395 C 8.791691,37.621767 8.1584238,34.769583 8.1584238,31.900727 c 0,-0.330153 0.090589,-0.648169 0.1047967,-0.978102 z m 48.2763445,0.419186 c 0.0047,0.188973 0.06986,0.36991 0.06986,0.558916 0,2.938869 -0.620228,5.873558 -1.676747,8.628261 -0.07435,0.07583 -0.06552,0.07411 -0.454119,0.349323 -0.606965,0.429857 -1.631665,1.042044 -3.318562,1.676747 -1.208528,0.454713 -3.204964,0.850894 -5.135038,1.25756 0.84593,-2.765726 1.41808,-6.005357 1.606883,-9.815957 2.232369,-0.413371 4.483758,-0.840201 5.938479,-1.327425 1.410632,-0.472457 2.153108,-0.89469 2.96924,-1.327425 z m -38.530252,2.864443 c 3.208141,0.56697 7.372279,0.898588 12.575603,0.978103 l 0.174662,9.885821 c -4.392517,-0.06139 -8.106722,-0.320566 -10.863925,-0.803441 -1.051954,-2.664695 -1.692909,-6.043794 -1.88634,-10.060483 z m 26.793022,0.31439 c -0.246298,3.923551 -0.877762,7.263679 -1.816476,9.885822 -2.561957,0.361954 -5.766249,0.560708 -9.431703,0.62878 l -0.174661,-9.815957 c 4.491734,-0.04969 8.334769,-0.293032 11.42284,-0.698645 z M 12.035901,44.860585 c 0.09977,0.04523 0.105535,0.09465 0.209594,0.139729 1.337656,0.579602 3.441099,1.058072 5.589157,1.537018 1.545042,3.399208 3.548524,5.969402 5.589157,7.789888 -3.034411,-1.215537 -5.871615,-3.007978 -8.174142,-5.309699 -1.245911,-1.245475 -2.271794,-2.662961 -3.213766,-4.156936 z m 40.69605,0 c -0.941972,1.493975 -1.967855,2.911461 -3.213765,4.156936 -2.74253,2.741571 -6.244106,4.696717 -9.955686,5.868615 0.261347,-0.241079 0.507495,-0.394491 0.768509,-0.663713 1.674841,-1.727516 3.320792,-4.181056 4.645987,-7.265904 2.962447,-0.503021 5.408965,-1.122293 7.161107,-1.781544 0.284034,-0.106865 0.337297,-0.207323 0.593848,-0.31439 z m -31.404076,2.305527 c 2.645807,0.376448 5.701178,0.649995 9.466635,0.698645 l 0.139729,7.789888 c -1.38739,-0.480844 -3.316218,-1.29837 -5.659022,-3.388427 -1.388822,-1.238993 -2.743668,-3.0113 -3.947342,-5.100106 z m 20.365491,0.104797 c -1.04872,2.041937 -2.174337,3.779068 -3.353494,4.995309 -1.853177,1.911459 -3.425515,2.82679 -4.611055,3.353494 l -0.139729,-7.789887 c 3.13091,-0.05714 5.728238,-0.278725 8.104278,-0.558916 z",z5e="m 2.9825053,17.550598 0,1.368113 0,26.267766 0,1.368113 1.36811,0 54.9981397,0 1.36811,0 0,-1.368113 0,-26.267766 0,-1.368113 -1.36811,0 -54.9981397,0 -1.36811,0 z m 2.73623,2.736226 10.3292497,0 0,10.466063 -10.3292497,0 0,-10.466063 z m 13.0654697,0 11.69737,0 0,10.466063 -11.69737,0 0,-10.466063 z m 14.43359,0 11.69737,0 0,10.466063 -11.69737,0 0,-10.466063 z m 14.43359,0 10.32926,0 0,10.466063 -10.32926,0 0,-10.466063 z m -41.9326497,13.202288 10.3292497,0 0,10.329252 -10.3292497,0 0,-10.329252 z m 13.0654697,0 11.69737,0 0,10.329252 -11.69737,0 0,-10.329252 z m 14.43359,0 11.69737,0 0,10.329252 -11.69737,0 0,-10.329252 z m 14.43359,0 10.32926,0 0,10.329252 -10.32926,0 0,-10.329252 z",j5e="m 14.723969,17.675598 -0.340489,0.817175 -11.1680536,26.183638 -0.817175,1.872692 2.076986,0 54.7506996,0 2.07698,0 -0.81717,-1.872692 -11.16805,-26.183638 -0.34049,-0.817175 -0.91933,0 -32.414586,0 -0.919322,0 z m 1.838643,2.723916 6.196908,0 -2.928209,10.418977 -7.729111,0 4.460412,-10.418977 z m 9.02297,0 4.903049,0 0,10.418977 -7.831258,0 2.928209,-10.418977 z m 7.626964,0 5.584031,0 2.62176,10.418977 -8.205791,0 0,-10.418977 z m 8.410081,0 5.51593,0 4.46042,10.418977 -7.38863,0 -2.58772,-10.418977 z m -30.678091,13.142892 8.103649,0 -2.89416,10.282782 -9.6018026,0 4.3923136,-10.282782 z m 10.929711,0 8.614384,0 0,10.282782 -11.508544,0 2.89416,-10.282782 z m 11.338299,0 8.852721,0 2.58772,10.282782 -11.440441,0 0,-10.282782 z m 11.678781,0 7.86531,0 4.39231,10.282782 -9.6699,0 -2.58772,-10.282782 z";function T4(t,e,n){t=Ui(t);let i=new PD(e,n);i._globePath=K5e,i._flatMapPath=z5e,i._columbusViewPath=j5e;let o=document.createElement("span");o.className="cesium-sceneModePicker-wrapper cesium-toolbar-button",t.appendChild(o);let a=document.createElement("button");a.type="button",a.className="cesium-button cesium-toolbar-button",a.setAttribute("data-bind",'css: { "cesium-sceneModePicker-button2D": sceneMode === _sceneMode.SCENE2D, "cesium-sceneModePicker-button3D": sceneMode === _sceneMode.SCENE3D, "cesium-sceneModePicker-buttonColumbusView": sceneMode === _sceneMode.COLUMBUS_VIEW, "cesium-sceneModePicker-selected": dropDownVisible },attr: { title: selectedTooltip },click: toggleDropDown'),a.innerHTML='<!-- ko cesiumSvgPath: { path: _globePath, width: 64, height: 64, css: "cesium-sceneModePicker-slide-svg cesium-sceneModePicker-icon3D" } --><!-- /ko --><!-- ko cesiumSvgPath: { path: _flatMapPath, width: 64, height: 64, css: "cesium-sceneModePicker-slide-svg cesium-sceneModePicker-icon2D" } --><!-- /ko --><!-- ko cesiumSvgPath: { path: _columbusViewPath, width: 64, height: 64, css: "cesium-sceneModePicker-slide-svg cesium-sceneModePicker-iconColumbusView" } --><!-- /ko -->',o.appendChild(a);let s=document.createElement("button");s.type="button",s.className="cesium-button cesium-toolbar-button cesium-sceneModePicker-dropDown-icon",s.setAttribute("data-bind",'css: { "cesium-sceneModePicker-visible" : (dropDownVisible && (sceneMode !== _sceneMode.SCENE3D)) || (!dropDownVisible && (sceneMode === _sceneMode.SCENE3D)), "cesium-sceneModePicker-none" : sceneMode === _sceneMode.SCENE3D, "cesium-sceneModePicker-hidden" : !dropDownVisible },attr: { title: tooltip3D },click: morphTo3D,cesiumSvgPath: { path: _globePath, width: 64, height: 64 }'),o.appendChild(s);let l=document.createElement("button");l.type="button",l.className="cesium-button cesium-toolbar-button cesium-sceneModePicker-dropDown-icon",l.setAttribute("data-bind",'css: { "cesium-sceneModePicker-visible" : (dropDownVisible && (sceneMode !== _sceneMode.SCENE2D)), "cesium-sceneModePicker-none" : sceneMode === _sceneMode.SCENE2D, "cesium-sceneModePicker-hidden" : !dropDownVisible },attr: { title: tooltip2D },click: morphTo2D,cesiumSvgPath: { path: _flatMapPath, width: 64, height: 64 }'),o.appendChild(l);let r=document.createElement("button");r.type="button",r.className="cesium-button cesium-toolbar-button cesium-sceneModePicker-dropDown-icon",r.setAttribute("data-bind",'css: { "cesium-sceneModePicker-visible" : (dropDownVisible && (sceneMode !== _sceneMode.COLUMBUS_VIEW)) || (!dropDownVisible && (sceneMode === _sceneMode.COLUMBUS_VIEW)), "cesium-sceneModePicker-none" : sceneMode === _sceneMode.COLUMBUS_VIEW, "cesium-sceneModePicker-hidden" : !dropDownVisible},attr: { title: tooltipColumbusView },click: morphToColumbusView,cesiumSvgPath: { path: _columbusViewPath, width: 64, height: 64 }'),o.appendChild(r),Lt.applyBindings(i,o),this._viewModel=i,this._container=t,this._wrapper=o,this._closeDropDown=function(d){o.contains(d.target)||(i.dropDownVisible=!1)},In.supportsPointerEvents()?document.addEventListener("pointerdown",this._closeDropDown,!0):(document.addEventListener("mousedown",this._closeDropDown,!0),document.addEventListener("touchstart",this._closeDropDown,!0))}Object.defineProperties(T4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});T4.prototype.isDestroyed=function(){return!1};T4.prototype.destroy=function(){return this._viewModel.destroy(),In.supportsPointerEvents()?document.removeEventListener("pointerdown",this._closeDropDown,!0):(document.removeEventListener("mousedown",this._closeDropDown,!0),document.removeEventListener("touchstart",this._closeDropDown,!0)),Lt.cleanNode(this._wrapper),this._container.removeChild(this._wrapper),At(this)};var vD=T4;var JGa=b(W(),1);var yGa=b(W(),1);var q5e=new K,g4="-1000px";function KD(t,e,n){this._scene=t,this._screenPositionX=g4,this._screenPositionY=g4,this._tweens=t.tweens,this._container=f(n,document.body),this._selectionIndicatorElement=e,this._scale=1,this.position=void 0,this.showSelection=!1,Lt.track(this,["position","_screenPositionX","_screenPositionY","_scale","showSelection"]),this.isVisible=void 0,Lt.defineProperty(this,"isVisible",{get:function(){return this.showSelection&&c(this.position)}}),Lt.defineProperty(this,"_transform",{get:function(){return`scale(${this._scale})`}}),this.computeScreenSpacePosition=function(i,o){return qo.wgs84ToWindowCoordinates(t,i,o)}}KD.prototype.update=function(){if(this.showSelection&&c(this.position)){let t=this.computeScreenSpacePosition(this.position,q5e);if(!c(t))this._screenPositionX=g4,this._screenPositionY=g4;else{let e=this._container,n=e.parentNode.clientWidth,i=e.parentNode.clientHeight,o=this._selectionIndicatorElement.clientWidth,a=o*.5;t.x=Math.min(Math.max(t.x,-o),n+o)-a,t.y=Math.min(Math.max(t.y,-o),i+o)-a,this._screenPositionX=`${Math.floor(t.x+.25)}px`,this._screenPositionY=`${Math.floor(t.y+.25)}px`}}};KD.prototype.animateAppear=function(){this._tweens.addProperty({object:this,property:"_scale",startValue:2,stopValue:1,duration:.8,easingFunction:ul.EXPONENTIAL_OUT})};KD.prototype.animateDepart=function(){this._tweens.addProperty({object:this,property:"_scale",startValue:this._scale,stopValue:1.5,duration:.8,easingFunction:ul.EXPONENTIAL_OUT})};Object.defineProperties(KD.prototype,{container:{get:function(){return this._container}},selectionIndicatorElement:{get:function(){return this._selectionIndicatorElement}},scene:{get:function(){return this._scene}}});var zD=KD;function E4(t,e){t=Ui(t),this._container=t;let n=document.createElement("div");n.className="cesium-selection-wrapper",n.setAttribute("data-bind",'style: { "top" : _screenPositionY, "left" : _screenPositionX },css: { "cesium-selection-wrapper-visible" : isVisible }'),t.appendChild(n),this._element=n;let i="http://www.w3.org/2000/svg",o="M -34 -34 L -34 -11.25 L -30 -15.25 L -30 -30 L -15.25 -30 L -11.25 -34 L -34 -34 z M 11.25 -34 L 15.25 -30 L 30 -30 L 30 -15.25 L 34 -11.25 L 34 -34 L 11.25 -34 z M -34 11.25 L -34 34 L -11.25 34 L -15.25 30 L -30 30 L -30 15.25 L -34 11.25 z M 34 11.25 L 30 15.25 L 30 30 L 15.25 30 L 11.25 34 L 34 34 L 34 11.25 z",a=document.createElementNS(i,"svg:svg");a.setAttribute("width",160),a.setAttribute("height",160),a.setAttribute("viewBox","0 0 160 160");let s=document.createElementNS(i,"g");s.setAttribute("transform","translate(80,80)"),a.appendChild(s);let l=document.createElementNS(i,"path");l.setAttribute("data-bind","attr: { transform: _transform }"),l.setAttribute("d",o),s.appendChild(l),n.appendChild(a);let r=new zD(e,this._element,this._container);this._viewModel=r,Lt.applyBindings(this._viewModel,this._element)}Object.defineProperties(E4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});E4.prototype.isDestroyed=function(){return!1};E4.prototype.destroy=function(){let t=this._container;return Lt.cleanNode(this._element),t.removeChild(this._element),At(this)};var jD=E4;var jGa=b(W(),1);var _Ga=b(W(),1);function mg(t,e,n){this._color=t,this._height=e,this._base=f(n,0)}mg.prototype.getHeight=function(){return this._height};mg.prototype.getBase=function(){return this._base};mg.prototype.getStartTime=function(){return this._start};mg.prototype.getStopTime=function(){return this._stop};mg.prototype.setRange=function(t,e){this._start=t,this._stop=e};mg.prototype.render=function(t){let e="";if(this._start&&this._stop&&this._color){let n=rt.secondsDifference(this._start,t.epochJulian),i=Math.round(t.timeBarWidth*t.getAlpha(n)),o=rt.secondsDifference(this._stop,t.epochJulian),a=Math.round(t.timeBarWidth*t.getAlpha(o))-i;i<0&&(a+=i,i=0),i+a>t.timeBarWidth&&(a=t.timeBarWidth-i),a>0&&(e=`<span class="cesium-timeline-highlight" style="left: ${i.toString()}px; width: ${a.toString()}px; bottom: ${this._base.toString()}px; height: ${this._height}px; background-color: ${this._color};"></span>`)}return e};var qD=mg;var HGa=b(W(),1);function Q2t(t,e,n,i){this.interval=t,this.height=e,this.color=n||new v(.5,.5,.5,1),this.backgroundColor=i||new v(0,0,0,0)}Q2t.prototype.render=function(t,e){let n=this.interval.start,i=this.interval.stop,o=e.startJulian,a=rt.addSeconds(e.startJulian,e.duration,new rt);if(rt.lessThan(n,o)&&rt.greaterThan(i,a))t.fillStyle=this.color.toCssColorString(),t.fillRect(0,e.y,e.timeBarWidth,this.height);else if(rt.lessThanOrEquals(n,a)&&rt.greaterThanOrEquals(i,o)){let s,l,r;for(s=0;s<e.timeBarWidth;++s){let d=rt.addSeconds(e.startJulian,s/e.timeBarWidth*e.duration,new rt);!c(l)&&rt.greaterThanOrEquals(d,n)?l=s:!c(r)&&rt.greaterThanOrEquals(d,i)&&(r=s)}t.fillStyle=this.backgroundColor.toCssColorString(),t.fillRect(0,e.y,e.timeBarWidth,this.height),c(l)&&(c(r)||(r=e.timeBarWidth),t.fillStyle=this.color.toCssColorString(),t.fillRect(l,e.y,Math.max(r-l,1),this.height))}};var $D=Q2t;var Mrt=1e12,xV={none:0,scrub:1,slide:2,zoom:3,touchOnly:4},am={none:0,scrub:1,slideZoom:2,singleTap:3,ignore:4},JU=[.001,.002,.005,.01,.02,.05,.1,.25,.5,1,2,5,10,15,30,60,120,300,600,900,1800,3600,7200,14400,21600,43200,86400,172800,345600,604800,1296e3,2592e3,5184e3,7776e3,15552e3,31536e3,63072e3,126144e3,15768e4,31536e4,63072e4,126144e4,15768e5,31536e5,63072e5,126144e5,15768e6,31536e6],$5e=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];function sm(t,e){t=Ui(t);let n=t.ownerDocument;this.container=t;let i=n.createElement("div");i.className="cesium-timeline-main",t.appendChild(i),this._topDiv=i,this._endJulian=void 0,this._epochJulian=void 0,this._lastXPos=void 0,this._scrubElement=void 0,this._startJulian=void 0,this._timeBarSecondsSpan=void 0,this._clock=e,this._scrubJulian=e.currentTime,this._mainTicSpan=-1,this._mouseMode=xV.none,this._touchMode=am.none,this._touchState={centerX:0,spanX:0},this._mouseX=0,this._timelineDrag=0,this._timelineDragLocation=void 0,this._lastHeight=void 0,this._lastWidth=void 0,this._topDiv.innerHTML='<div class="cesium-timeline-bar"></div><div class="cesium-timeline-trackContainer"><canvas class="cesium-timeline-tracks" width="10" height="1"></canvas></div><div class="cesium-timeline-needle"></div><span class="cesium-timeline-ruler"></span>',this._timeBarEle=this._topDiv.childNodes[0],this._trackContainer=this._topDiv.childNodes[1],this._trackListEle=this._topDiv.childNodes[1].childNodes[0],this._needleEle=this._topDiv.childNodes[2],this._rulerEle=this._topDiv.childNodes[3],this._context=this._trackListEle.getContext("2d"),this._trackList=[],this._highlightRanges=[],this.zoomTo(e.startTime,e.stopTime),this._onMouseDown=tDe(this),this._onMouseUp=eDe(this),this._onMouseMove=nDe(this),this._onMouseWheel=iDe(this),this._onTouchStart=oDe(this),this._onTouchMove=sDe(this),this._onTouchEnd=aDe(this);let o=this._timeBarEle;n.addEventListener("mouseup",this._onMouseUp,!1),n.addEventListener("mousemove",this._onMouseMove,!1),o.addEventListener("mousedown",this._onMouseDown,!1),o.addEventListener("DOMMouseScroll",this._onMouseWheel,!1),o.addEventListener("mousewheel",this._onMouseWheel,!1),o.addEventListener("touchstart",this._onTouchStart,!1),o.addEventListener("touchmove",this._onTouchMove,!1),o.addEventListener("touchend",this._onTouchEnd,!1),o.addEventListener("touchcancel",this._onTouchEnd,!1),this._topDiv.oncontextmenu=function(){return!1},e.onTick.addEventListener(this.updateFromClock,this),this.updateFromClock()}sm.prototype.addEventListener=function(t,e,n){this._topDiv.addEventListener(t,e,n)};sm.prototype.removeEventListener=function(t,e,n){this._topDiv.removeEventListener(t,e,n)};sm.prototype.isDestroyed=function(){return!1};sm.prototype.destroy=function(){this._clock.onTick.removeEventListener(this.updateFromClock,this);let t=this.container.ownerDocument;t.removeEventListener("mouseup",this._onMouseUp,!1),t.removeEventListener("mousemove",this._onMouseMove,!1);let e=this._timeBarEle;e.removeEventListener("mousedown",this._onMouseDown,!1),e.removeEventListener("DOMMouseScroll",this._onMouseWheel,!1),e.removeEventListener("mousewheel",this._onMouseWheel,!1),e.removeEventListener("touchstart",this._onTouchStart,!1),e.removeEventListener("touchmove",this._onTouchMove,!1),e.removeEventListener("touchend",this._onTouchEnd,!1),e.removeEventListener("touchcancel",this._onTouchEnd,!1),this.container.removeChild(this._topDiv),At(this)};sm.prototype.addHighlightRange=function(t,e,n){let i=new qD(t,e,n);return this._highlightRanges.push(i),this.resize(),i};sm.prototype.addTrack=function(t,e,n,i){let o=new $D(t,e,n,i);return this._trackList.push(o),this._lastHeight=void 0,this.resize(),o};sm.prototype.zoomTo=function(t,e){if(this._startJulian=t,this._endJulian=e,this._timeBarSecondsSpan=rt.secondsDifference(e,t),this._clock&&this._clock.clockRange!==pl.UNBOUNDED){let i=this._clock.startTime,o=this._clock.stopTime,a=rt.secondsDifference(o,i),s=rt.secondsDifference(i,this._startJulian),l=rt.secondsDifference(o,this._endJulian);this._timeBarSecondsSpan>=a?(this._timeBarSecondsSpan=a,this._startJulian=this._clock.startTime,this._endJulian=this._clock.stopTime):s>0?(this._endJulian=rt.addSeconds(this._endJulian,s,new rt),this._startJulian=i,this._timeBarSecondsSpan=rt.secondsDifference(this._endJulian,this._startJulian)):l<0&&(this._startJulian=rt.addSeconds(this._startJulian,l,new rt),this._endJulian=o,this._timeBarSecondsSpan=rt.secondsDifference(this._endJulian,this._startJulian))}this._makeTics();let n=document.createEvent("Event");n.initEvent("setzoom",!0,!0),n.startJulian=this._startJulian,n.endJulian=this._endJulian,n.epochJulian=this._epochJulian,n.totalSpan=this._timeBarSecondsSpan,n.mainTicSpan=this._mainTicSpan,this._topDiv.dispatchEvent(n)};sm.prototype.zoomFrom=function(t){let e=rt.secondsDifference(this._scrubJulian,this._startJulian);t>1||e<0||e>this._timeBarSecondsSpan?e=this._timeBarSecondsSpan*.5:e+=e-this._timeBarSecondsSpan*.5;let n=this._timeBarSecondsSpan-e;this.zoomTo(rt.addSeconds(this._startJulian,e-e*t,new rt),rt.addSeconds(this._endJulian,n*t-n,new rt))};function _rt(t){return t<10?`0${t.toString()}`:t.toString()}sm.prototype.makeLabel=function(t){let e=rt.toGregorianDate(t),n=e.millisecond,i=" UTC";if(n>0&&this._timeBarSecondsSpan<3600){for(i=Math.floor(n).toString();i.length<3;)i=`0${i}`;i=`.${i}`}return`${$5e[e.month-1]} ${e.day} ${e.year} ${_rt(e.hour)}:${_rt(e.minute)}:${_rt(e.second)}${i}`};sm.prototype.smallestTicInPixels=7;sm.prototype._makeTics=function(){let t=this._timeBarEle,e=rt.secondsDifference(this._scrubJulian,this._startJulian),n=Math.round(e*this._topDiv.clientWidth/this._timeBarSecondsSpan),i=n-8,o,a=this;this._needleEle.style.left=`${n.toString()}px`;let s="",l=.01,r=31536e6,d=1e-10,m=0,h=this._timeBarSecondsSpan;h<l?(h=l,this._timeBarSecondsSpan=l,this._endJulian=rt.addSeconds(this._startJulian,l,new rt)):h>r&&(h=r,this._timeBarSecondsSpan=r,this._endJulian=rt.addSeconds(this._startJulian,r,new rt));let u=this._timeBarEle.clientWidth;u<10&&(u=10);let R=this._startJulian,V=Math.min(h/u*1e-5,.4),F,U=rt.toGregorianDate(R);h>31536e4?F=rt.fromDate(new Date(Date.UTC(Math.floor(U.year/100)*100,0))):h>31536e3?F=rt.fromDate(new Date(Date.UTC(Math.floor(U.year/10)*10,0))):h>86400?F=rt.fromDate(new Date(Date.UTC(U.year,0))):F=rt.fromDate(new Date(Date.UTC(U.year,U.month,U.day)));let G=rt.secondsDifference(this._startJulian,rt.addSeconds(F,V,new rt)),A=G+h;this._epochJulian=F;function S(H){return Math.floor(G/H)*H}function g(H,nt){return Math.ceil(H/nt+.5)*nt}function C(H){return(H-G)/h}function y(H,nt){return H-nt*Math.round(H/nt)}this._rulerEle.innerHTML=this.makeLabel(rt.addSeconds(this._endJulian,-l,new rt));let Y=this._rulerEle.offsetWidth+20;Y<30&&(Y=180);let Q=m;m-=d;let J={startTime:G,startJulian:R,epochJulian:F,duration:h,timeBarWidth:u,getAlpha:C};this._highlightRanges.forEach(function(H){s+=H.render(J)});let M=0,Z=0,E=0,I=Y/u;I>1&&(I=1),I*=this._timeBarSecondsSpan;let B=-1,X=-1,_=JU.length,P;for(P=0;P<_;++P){let H=JU[P];if(++B,M=H,H>I&&H>m)break;X<0&&u*(H/this._timeBarSecondsSpan)>=this.smallestTicInPixels&&(X=B)}if(B>0){for(;B>0;)if(--B,Math.abs(y(M,JU[B]))<1e-5){JU[B]>=m&&(Z=JU[B]);break}if(X>=0)for(;X<B;){if(Math.abs(y(Z,JU[X]))<1e-5&&JU[X]>=m){E=JU[X];break}++X}}m=Q,m>d&&E<1e-5&&Math.abs(m-M)>d&&(E=m,m<=M+d&&(Z=0));let w=-999999,z;if(u*(E/this._timeBarSecondsSpan)>=3)for(o=S(E);o<=A;o=g(o,E))s+=`<span class="cesium-timeline-ticTiny" style="left: ${Math.round(u*C(o)).toString()}px;"></span>`;if(u*(Z/this._timeBarSecondsSpan)>=3)for(o=S(Z);o<=A;o=g(o,Z))s+=`<span class="cesium-timeline-ticSub" style="left: ${Math.round(u*C(o)).toString()}px;"></span>`;if(u*(M/this._timeBarSecondsSpan)>=2){this._mainTicSpan=M,A+=M,o=S(M);let H=rt.computeTaiMinusUtc(F);for(;o<=A;){let nt=rt.addSeconds(R,o-G,new rt);if(M>2.1){let at=rt.computeTaiMinusUtc(nt);Math.abs(at-H)>.1&&(o+=at-H,nt=rt.addSeconds(R,o-G,new rt))}let $=Math.round(u*C(o)),dt=this.makeLabel(nt);this._rulerEle.innerHTML=dt,z=this._rulerEle.offsetWidth,z<10&&(z=Y);let q=$-(z/2-1);q>w?(w=q+z+5,s+=`<span class="cesium-timeline-ticMain" style="left: ${$.toString()}px;"></span><span class="cesium-timeline-ticLabel" style="left: ${q.toString()}px;">${dt}</span>`):s+=`<span class="cesium-timeline-ticSub" style="left: ${$.toString()}px;"></span>`,o=g(o,M)}}else this._mainTicSpan=-1;s+=`<span class="cesium-timeline-icon16" style="left:${i}px;bottom:0;background-position: 0 0;"></span>`,t.innerHTML=s,this._scrubElement=t.lastChild,this._context.clearRect(0,0,this._trackListEle.width,this._trackListEle.height),J.y=0,this._trackList.forEach(function(H){H.render(a._context,J),J.y+=H.height})};sm.prototype.updateFromClock=function(){this._scrubJulian=this._clock.currentTime;let t=this._scrubElement;if(c(this._scrubElement)){let e=rt.secondsDifference(this._scrubJulian,this._startJulian),n=Math.round(e*this._topDiv.clientWidth/this._timeBarSecondsSpan);this._lastXPos!==n&&(this._lastXPos=n,t.style.left=`${n-8}px`,this._needleEle.style.left=`${n}px`)}c(this._timelineDragLocation)&&(this._setTimeBarTime(this._timelineDragLocation,this._timelineDragLocation*this._timeBarSecondsSpan/this._topDiv.clientWidth),this.zoomTo(rt.addSeconds(this._startJulian,this._timelineDrag,new rt),rt.addSeconds(this._endJulian,this._timelineDrag,new rt)))};sm.prototype._setTimeBarTime=function(t,e){if(t=Math.round(t),this._scrubJulian=rt.addSeconds(this._startJulian,e,new rt),this._scrubElement){let i=t-8;this._scrubElement.style.left=`${i.toString()}px`,this._needleEle.style.left=`${t.toString()}px`}let n=document.createEvent("Event");n.initEvent("settime",!0,!0),n.clientX=t,n.timeSeconds=e,n.timeJulian=this._scrubJulian,n.clock=this._clock,this._topDiv.dispatchEvent(n)};function tDe(t){return function(e){t._mouseMode!==xV.touchOnly&&(e.button===0?(t._mouseMode=xV.scrub,t._scrubElement&&(t._scrubElement.style.backgroundPosition="-16px 0"),t._onMouseMove(e)):(t._mouseX=e.clientX,e.button===2?t._mouseMode=xV.zoom:t._mouseMode=xV.slide)),e.preventDefault()}}function eDe(t){return function(e){t._mouseMode=xV.none,t._scrubElement&&(t._scrubElement.style.backgroundPosition="0 0"),t._timelineDrag=0,t._timelineDragLocation=void 0}}function nDe(t){return function(e){let n;if(t._mouseMode===xV.scrub){e.preventDefault();let i=e.clientX-t._topDiv.getBoundingClientRect().left;i<0?(t._timelineDragLocation=0,t._timelineDrag=-.01*t._timeBarSecondsSpan):i>t._topDiv.clientWidth?(t._timelineDragLocation=t._topDiv.clientWidth,t._timelineDrag=.01*t._timeBarSecondsSpan):(t._timelineDragLocation=void 0,t._setTimeBarTime(i,i*t._timeBarSecondsSpan/t._topDiv.clientWidth))}else if(t._mouseMode===xV.slide){if(n=t._mouseX-e.clientX,t._mouseX=e.clientX,n!==0){let i=n*t._timeBarSecondsSpan/t._topDiv.clientWidth;t.zoomTo(rt.addSeconds(t._startJulian,i,new rt),rt.addSeconds(t._endJulian,i,new rt))}}else t._mouseMode===xV.zoom&&(n=t._mouseX-e.clientX,t._mouseX=e.clientX,n!==0&&t.zoomFrom(Math.pow(1.01,n)))}}function iDe(t){return function(e){let n=e.wheelDeltaY||e.wheelDelta||-e.detail;Mrt=Math.max(Math.min(Math.abs(n),Mrt),1),n/=Mrt,t.zoomFrom(Math.pow(1.05,-n))}}function oDe(t){return function(e){let n=e.touches.length,i,o,a=t._topDiv.getBoundingClientRect().left;e.preventDefault(),t._mouseMode=xV.touchOnly,n===1?(i=rt.secondsDifference(t._scrubJulian,t._startJulian),o=Math.round(i*t._topDiv.clientWidth/t._timeBarSecondsSpan+a),Math.abs(e.touches[0].clientX-o)<50?(t._touchMode=am.scrub,t._scrubElement&&(t._scrubElement.style.backgroundPosition=n===1?"-16px 0":"0 0")):(t._touchMode=am.singleTap,t._touchState.centerX=e.touches[0].clientX-a)):n===2?(t._touchMode=am.slideZoom,t._touchState.centerX=(e.touches[0].clientX+e.touches[1].clientX)*.5-a,t._touchState.spanX=Math.abs(e.touches[0].clientX-e.touches[1].clientX)):t._touchMode=am.ignore}}function aDe(t){return function(e){let n=e.touches.length,i=t._topDiv.getBoundingClientRect().left;t._touchMode===am.singleTap?(t._touchMode=am.scrub,t._onTouchMove(e)):t._touchMode===am.scrub&&t._onTouchMove(e),t._mouseMode=xV.touchOnly,n!==1?t._touchMode=n>0?am.ignore:am.none:t._touchMode===am.slideZoom&&(t._touchState.centerX=e.touches[0].clientX-i),t._scrubElement&&(t._scrubElement.style.backgroundPosition="0 0")}}function sDe(t){return function(e){let n,i,o,a,s,l,r=1,d=t._topDiv.getBoundingClientRect().left;t._touchMode===am.singleTap&&(t._touchMode=am.slideZoom),t._mouseMode=xV.touchOnly,t._touchMode===am.scrub?(e.preventDefault(),e.changedTouches.length===1&&(i=e.changedTouches[0].clientX-d,i>=0&&i<=t._topDiv.clientWidth&&t._setTimeBarTime(i,i*t._timeBarSecondsSpan/t._topDiv.clientWidth))):t._touchMode===am.slideZoom&&(o=e.touches.length,o===2?(a=(e.touches[0].clientX+e.touches[1].clientX)*.5-d,s=Math.abs(e.touches[0].clientX-e.touches[1].clientX)):o===1&&(a=e.touches[0].clientX-d,s=0),c(a)&&(s>0&&t._touchState.spanX>0?(r=t._touchState.spanX/s,l=rt.addSeconds(t._startJulian,(t._touchState.centerX*t._timeBarSecondsSpan-a*t._timeBarSecondsSpan*r)/t._topDiv.clientWidth,new rt)):(n=t._touchState.centerX-a,l=rt.addSeconds(t._startJulian,n*t._timeBarSecondsSpan/t._topDiv.clientWidth,new rt)),t.zoomTo(l,rt.addSeconds(l,t._timeBarSecondsSpan*r,new rt)),t._touchState.centerX=a,t._touchState.spanX=s))}}sm.prototype.resize=function(){let t=this.container.clientWidth,e=this.container.clientHeight;if(t===this._lastWidth&&e===this._lastHeight)return;this._trackContainer.style.height=`${e}px`;let n=1;this._trackList.forEach(function(i){n+=i.height}),this._trackListEle.style.height=`${n.toString()}px`,this._trackListEle.width=this._trackListEle.clientWidth,this._trackListEle.height=n,this._makeTics(),this._lastXPos=void 0,this._lastWidth=t,this._lastHeight=e};var tO=sm;var VAa=b(W(),1);var lAa=b(W(),1);var J2t=b(X2t(),1);function dDe(t){let e=!1,n=window.screen;return c(n)&&(c(n.lockOrientation)?e=n.lockOrientation(t):c(n.mozLockOrientation)?e=n.mozLockOrientation(t):c(n.msLockOrientation)?e=n.msLockOrientation(t):c(n.orientation&&n.orientation.lock)&&(e=n.orientation.lock(t))),e}function L2t(){let t=window.screen;c(t)&&(c(t.unlockOrientation)?t.unlockOrientation():c(t.mozUnlockOrientation)?t.mozUnlockOrientation():c(t.msUnlockOrientation)?t.msUnlockOrientation():c(t.orientation&&t.orientation.unlock)&&t.orientation.unlock())}function cDe(t,e,n,i){i()||(n()?(e.useWebVR=!1,t._locked&&(L2t(),t._locked=!1),t._noSleep.disable(),Ds.exitFullscreen(),n(!1)):(Ds.fullscreen||Ds.requestFullscreen(t._vrElement),t._noSleep.enable(),t._locked||(t._locked=dDe("landscape")),e.useWebVR=!0,n(!0)))}function C4(t,e){let n=this,i=Lt.observable(Ds.enabled),o=Lt.observable(!1);this.isVRMode=void 0,Lt.defineProperty(this,"isVRMode",{get:function(){return o()}}),this.isVREnabled=void 0,Lt.defineProperty(this,"isVREnabled",{get:function(){return i()},set:function(s){i(s&&Ds.enabled)}}),this.tooltip=void 0,Lt.defineProperty(this,"tooltip",function(){return i()?o()?"Exit VR mode":"Enter VR mode":"VR mode is unavailable"});let a=Lt.observable(!1);this._isOrthographic=void 0,Lt.defineProperty(this,"_isOrthographic",{get:function(){return a()}}),this._eventHelper=new rl,this._eventHelper.add(t.preRender,function(){a(t.camera.frustum instanceof wn)}),this._locked=!1,this._noSleep=new J2t.default,this._command=Ri(function(){cDe(n,t,o,a)},Lt.getObservable(this,"isVREnabled")),this._vrElement=f(Ui(e),document.body),this._callback=function(){!Ds.fullscreen&&o()&&(t.useWebVR=!1,n._locked&&(L2t(),n._locked=!1),n._noSleep.disable(),o(!1))},document.addEventListener(Ds.changeEventName,this._callback)}Object.defineProperties(C4.prototype,{vrElement:{get:function(){return this._vrElement},set:function(t){this._vrElement=t}},command:{get:function(){return this._command}}});C4.prototype.isDestroyed=function(){return!1};C4.prototype.destroy=function(){this._eventHelper.removeAll(),document.removeEventListener(Ds.changeEventName,this._callback),At(this)};var eO=C4;var mDe="M 5.3125 6.375 C 4.008126 6.375 2.96875 7.4141499 2.96875 8.71875 L 2.96875 19.5 C 2.96875 20.8043 4.008126 21.875 5.3125 21.875 L 13.65625 21.875 C 13.71832 20.0547 14.845166 18.59375 16.21875 18.59375 C 17.592088 18.59375 18.71881 20.0552 18.78125 21.875 L 27.09375 21.875 C 28.398125 21.875 29.4375 20.8043 29.4375 19.5 L 29.4375 8.71875 C 29.4375 7.4141499 28.398125 6.375 27.09375 6.375 L 5.3125 6.375 z M 9.625 10.4375 C 11.55989 10.4375 13.125 12.03385 13.125 13.96875 C 13.125 15.90365 11.55989 17.46875 9.625 17.46875 C 7.69011 17.46875 6.125 15.90365 6.125 13.96875 C 6.125 12.03385 7.69011 10.4375 9.625 10.4375 z M 22.46875 10.4375 C 24.40364 10.4375 25.96875 12.03385 25.96875 13.96875 C 25.96875 15.90365 24.40364 17.46875 22.46875 17.46875 C 20.53386 17.46875 18.96875 15.90365 18.96875 13.96875 C 18.96875 12.03385 20.53386 10.4375 22.46875 10.4375 z",hDe="M 25.770585,2.4552065 C 15.72282,13.962707 10.699956,19.704407 8.1768352,22.580207 c -1.261561,1.4379 -1.902282,2.1427 -2.21875,2.5 -0.141624,0.1599 -0.208984,0.2355 -0.25,0.2813 l 0.6875,0.75 c 10e-5,-10e-5 0.679191,0.727 0.6875,0.7187 0.01662,-0.016 0.02451,-0.024 0.03125,-0.031 0.01348,-0.014 0.04013,-0.038 0.0625,-0.062 0.04474,-0.05 0.120921,-0.1315 0.28125,-0.3126 0.320657,-0.3619 0.956139,-1.0921 2.2187499,-2.5312 2.5252219,-2.8781 7.5454589,-8.6169 17.5937499,-20.1250005 l -1.5,-1.3125 z m -20.5624998,3.9063 c -1.304375,0 -2.34375,1.0391 -2.34375,2.3437 l 0,10.8125005 c 0,1.3043 1.039375,2.375 2.34375,2.375 l 2.25,0 c 1.9518039,-2.2246 7.4710958,-8.5584 13.5624998,-15.5312005 l -15.8124998,0 z m 21.1249998,0 c -1.855467,2.1245 -2.114296,2.4005 -3.59375,4.0936995 1.767282,0.1815 3.15625,1.685301 3.15625,3.500001 0,1.9349 -1.56511,3.5 -3.5,3.5 -1.658043,0 -3.043426,-1.1411 -3.40625,-2.6875 -1.089617,1.2461 -2.647139,2.9988 -3.46875,3.9375 0.191501,-0.062 0.388502,-0.094 0.59375,-0.094 1.373338,0 2.50006,1.4614 2.5625,3.2812 l 8.3125,0 c 1.304375,0 2.34375,-1.0707 2.34375,-2.375 l 0,-10.8125005 c 0,-1.3046 -1.039375,-2.3437 -2.34375,-2.3437 l -0.65625,0 z M 9.5518351,10.423906 c 1.9348899,0 3.4999999,1.596401 3.4999999,3.531301 0,1.9349 -1.56511,3.5 -3.4999999,3.5 -1.9348899,0 -3.4999999,-1.5651 -3.4999999,-3.5 0,-1.9349 1.56511,-3.531301 3.4999999,-3.531301 z m 4.2187499,10.312601 c -0.206517,0.2356 -0.844218,0.9428 -1.03125,1.1562 l 0.8125,0 c 0.01392,-0.4081 0.107026,-0.7968 0.21875,-1.1562 z";function I4(t,e,n){t=Ui(t);let i=new eO(e,n);i._exitVRPath=hDe,i._enterVRPath=mDe;let o=document.createElement("button");o.type="button",o.className="cesium-button cesium-vrButton",o.setAttribute("data-bind",'css: { "cesium-button-disabled" : _isOrthographic }, attr: { title: tooltip },click: command,enable: isVREnabled,cesiumSvgPath: { path: isVRMode ? _exitVRPath : _enterVRPath, width: 32, height: 32 }'),t.appendChild(o),Lt.applyBindings(i,o),this._container=t,this._viewModel=i,this._element=o}Object.defineProperties(I4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});I4.prototype.isDestroyed=function(){return!1};I4.prototype.destroy=function(){return this._viewModel.destroy(),Lt.cleanNode(this._element),this._container.removeChild(this._element),At(this)};var nO=I4;var YAa=b(W(),1);var LU=new Ft;function D2t(t){let e=t.clock;e.currentTime=t.timeJulian,e.shouldAnimate=!1}function pDe(t){let e=t.getPropertyIds(),n="";return e.forEach(function(i){let o=t.getProperty(i);c(o)&&(n+=`<tr><th>${i}</th><td>${o}</td></tr>`)}),n.length>0&&(n=`<table class="cesium-infoBox-defaultTable"><tbody>${n}</tbody></table>`),n}function VDe(t){let e,n=[],i=t.getPropertyIds();for(e=0;e<i.length;e++){let a=i[e];/^name$/i.test(a)?n[0]=t.getProperty(a):/name/i.test(a)?n[1]=t.getProperty(a):/^title$/i.test(a)?n[2]=t.getProperty(a):/^(id|identifier)$/i.test(a)?n[3]=t.getProperty(a):/element/i.test(a)?n[4]=t.getProperty(a):/(id|identifier)$/i.test(a)&&(n[5]=t.getProperty(a))}let o=n.length;for(e=0;e<o;e++){let a=n[e];if(c(a)&&a!=="")return a}return"Unnamed Feature"}function M2t(t,e){let n=t.scene.pick(e.position);if(c(n)){let i=f(n.id,n.primitive.id);if(i instanceof qa&&i.id.toString().indexOf("noclick:")!==0)return i;if(n instanceof Fr)return new qa({name:VDe(n),description:pDe(n),feature:n})}if(c(t.scene.globe))return RDe(t,e.position)}var uDe=new rt;function O2t(t,e,n){if(c(n)){let i=n.clock;if(c(i)&&(i.getValue(e),c(t))){let o=i.startTime,a=i.stopTime;rt.equals(o,a)&&(a=rt.addSeconds(o,k.EPSILON2,uDe)),t.updateFromClock(),t.zoomTo(o,a)}}}var ZDe=new p;function RDe(t,e){let n=t.scene,i=n.camera.getPickRay(e),o=n.imageryLayers.pickImageryLayerFeatures(i,n);if(!c(o))return;let a=new qa({id:"Loading...",description:"Loading feature information..."});return o.then(function(s){if(t.selectedEntity!==a)return;if(!c(s)||s.length===0){t.selectedEntity=_2t();return}let l=s[0],r=new qa({id:l.name,description:l.description});if(c(l.position)){let d=t.scene.globe.ellipsoid.cartographicToCartesian(l.position,ZDe);r.position=new jl(d)}t.selectedEntity=r},function(){t.selectedEntity===a&&(t.selectedEntity=_2t())}),a}function _2t(){return new qa({id:"None",description:"No features found."})}function bDe(t,e){let n=t._geocoder,i=t._homeButton,o=t._sceneModePicker,a=t._projectionPicker,s=t._baseLayerPicker,l=t._animation,r=t._timeline,d=t._fullscreenButton,m=t._infoBox,h=t._selectionIndicator,u=e?"hidden":"visible";if(c(n)&&(n.container.style.visibility=u),c(i)&&(i.container.style.visibility=u),c(o)&&(o.container.style.visibility=u),c(a)&&(a.container.style.visibility=u),c(s)&&(s.container.style.visibility=u),c(l)&&(l.container.style.visibility=u),c(r)&&(r.container.style.visibility=u),c(d)&&d.viewModel.isFullscreenEnabled&&(d.container.style.visibility=u),c(m)&&(m.container.style.visibility=u),c(h)&&(h.container.style.visibility=u),t._container){let R=e||!c(d)?0:d.container.clientWidth;t._vrButton.container.style.right=`${R}px`,t.forceResize()}}function Do(t,e){t=Ui(t),e=f(e,f.EMPTY_OBJECT);let n=(!c(e.globe)||e.globe!==!1)&&(!c(e.baseLayerPicker)||e.baseLayerPicker!==!1),i=this,o=document.createElement("div");o.className="cesium-viewer",t.appendChild(o);let a=document.createElement("div");a.className="cesium-viewer-cesiumWidgetContainer",o.appendChild(a);let s;e.bottomContainer?s=e.bottomContainer:(s=document.createElement("div"),s.className="cesium-viewer-bottom",o.appendChild(s));let l=f(e.scene3DOnly,!1),r,d,m=!1;c(e.clockViewModel)?(d=e.clockViewModel,r=d.clock):(r=new ku,d=new uD(r),m=!0),c(e.shouldAnimate)&&(r.shouldAnimate=e.shouldAnimate);let h=new W5(a,{baseLayer:n||c(e.baseLayer)||c(e.imageryProvider)?!1:void 0,clock:r,skyBox:e.skyBox,skyAtmosphere:e.skyAtmosphere,sceneMode:e.sceneMode,mapProjection:e.mapProjection,globe:e.globe,orderIndependentTranslucency:e.orderIndependentTranslucency,contextOptions:e.contextOptions,useDefaultRenderLoop:e.useDefaultRenderLoop,targetFrameRate:e.targetFrameRate,showRenderLoopErrors:e.showRenderLoopErrors,useBrowserRecommendedResolution:e.useBrowserRecommendedResolution,creditContainer:c(e.creditContainer)?e.creditContainer:s,creditViewport:e.creditViewport,scene3DOnly:l,shadows:e.shadows,terrainShadows:e.terrainShadows,mapMode2D:e.mapMode2D,blurActiveElementOnCanvasFocus:e.blurActiveElementOnCanvasFocus,requestRenderMode:e.requestRenderMode,maximumRenderTimeChange:e.maximumRenderTimeChange,depthPlaneEllipsoidOffset:e.depthPlaneEllipsoidOffset,msaaSamples:e.msaaSamples}),u=e.dataSources,R=!1;c(u)||(u=new YJ,R=!0);let V=h.scene,F=new kF({scene:V,dataSourceCollection:u}),U=new rl;U.add(r.onTick,Do.prototype._onTick,this),U.add(V.morphStart,Do.prototype._clearTrackedObject,this);let G;if(!c(e.selectionIndicator)||e.selectionIndicator!==!1){let $=document.createElement("div");$.className="cesium-viewer-selectionIndicatorContainer",o.appendChild($),G=new jD($,V)}let A;if(!c(e.infoBox)||e.infoBox!==!1){let $=document.createElement("div");$.className="cesium-viewer-infoBoxContainer",o.appendChild($),A=new LD($);let dt=A.viewModel;U.add(dt.cameraClicked,Do.prototype._onInfoBoxCameraClicked,this),U.add(dt.closeClicked,Do.prototype._onInfoBoxClockClicked,this)}let S=document.createElement("div");S.className="cesium-viewer-toolbar",o.appendChild(S);let g;if(!c(e.geocoder)||e.geocoder!==!1){let $=document.createElement("div");$.className="cesium-viewer-geocoderContainer",S.appendChild($);let dt;c(e.geocoder)&&typeof e.geocoder!="boolean"&&(dt=Array.isArray(e.geocoder)?e.geocoder:[e.geocoder]),g=new kD({container:$,geocoderServices:dt,scene:V}),U.add(g.viewModel.search.beforeExecute,Do.prototype._clearObjects,this)}let C;(!c(e.homeButton)||e.homeButton!==!1)&&(C=new xD(S,V),c(g)&&U.add(C.viewModel.command.afterExecute,function(){let $=g.viewModel;$.searchText="",$.isSearchInProgress&&$.search()}),U.add(C.viewModel.command.beforeExecute,Do.prototype._clearTrackedObject,this));let y;!l&&(!c(e.sceneModePicker)||e.sceneModePicker!==!1)&&(y=new vD(S,V));let Y;e.projectionPicker&&(Y=new wD(S,V));let Q,J;if(n){let $=f(e.imageryProviderViewModels,gD()),dt=f(e.terrainProviderViewModels,ED());Q=new TD(S,{globe:V.globe,imageryProviderViewModels:$,selectedImageryProviderViewModel:e.selectedImageryProviderViewModel,terrainProviderViewModels:dt,selectedTerrainProviderViewModel:e.selectedTerrainProviderViewModel}),J=S.getElementsByClassName("cesium-baseLayerPicker-dropDown")[0]}c(e.baseLayer)&&e.baseLayer!==!1&&(n&&(Q.viewModel.selectedImagery=void 0),V.imageryLayers.removeAll(),V.imageryLayers.add(e.baseLayer)),c(e.terrainProvider)&&(n&&(Q.viewModel.selectedTerrain=void 0),V.terrainProvider=e.terrainProvider),c(e.terrain)&&(n&&(Q.viewModel.selectedTerrain=void 0,V.globe.depthTestAgainstTerrain=!0),V.setTerrain(e.terrain));let M;if(!c(e.navigationHelpButton)||e.navigationHelpButton!==!1){let $=!0;try{if(c(window.localStorage)){let dt=window.localStorage.getItem("cesium-hasSeenNavHelp");c(dt)&&dt?$=!1:window.localStorage.setItem("cesium-hasSeenNavHelp","true")}}catch{}M=new _D({container:S,instructionsInitiallyVisible:f(e.navigationInstructionsInitiallyVisible,$)})}let Z;if(!c(e.animation)||e.animation!==!1){let $=document.createElement("div");$.className="cesium-viewer-animationContainer",o.appendChild($),Z=new GD($,new AD(d))}else if(e.animationContainer!==!1){let $=document.createElement("div");$.className="cesium-viewer-animationContainer",o.appendChild($),this._animation={container:$,resize:()=>{}}}let E;if(!c(e.timeline)||e.timeline!==!1){let $=document.createElement("div");$.className="cesium-viewer-timelineContainer",o.appendChild($),E=new tO($,r),E.addEventListener("settime",D2t,!1),E.zoomTo(r.startTime,r.stopTime)}else if(e.timelineContainer!==!1){let $=document.createElement("div");$.className="cesium-viewer-timelineContainer",$.style.overflow="visible",o.appendChild($),E={container:$,resize:()=>{},updateFromClock:()=>{},zoomTo:()=>{}}}let I,B,X;(!c(e.fullscreenButton)||e.fullscreenButton!==!1)&&(X=document.createElement("div"),X.className="cesium-viewer-fullscreenContainer",o.appendChild(X),I=new BD(X,e.fullscreenElement),B=od(I.viewModel,"isFullscreenEnabled",function($){X.style.display=$?"block":"none",c(E)&&(E.container.style.right=`${X.clientWidth}px`,E.resize())}));let _,P,w;if(e.vrButton){let $=document.createElement("div");$.className="cesium-viewer-vrContainer",o.appendChild($),_=new nO($,V,e.fullScreenElement),P=od(_.viewModel,"isVREnabled",function(dt){$.style.display=dt?"block":"none",c(I)&&($.style.right=`${X.clientWidth}px`),c(E)&&(E.container.style.right=`${$.clientWidth}px`,E.resize())}),w=od(_.viewModel,"isVRMode",function(dt){bDe(i,dt)})}this._baseLayerPickerDropDown=J,this._fullscreenSubscription=B,this._vrSubscription=P,this._vrModeSubscription=w,this._dataSourceChangedListeners={},this._automaticallyTrackDataSourceClocks=f(e.automaticallyTrackDataSourceClocks,!0),this._container=t,this._bottomContainer=s,this._element=o,this._cesiumWidget=h,this._selectionIndicator=G,this._infoBox=A,this._dataSourceCollection=u,this._destroyDataSourceCollection=R,this._dataSourceDisplay=F,this._clockViewModel=d,this._destroyClockViewModel=m,this._toolbar=S,this._homeButton=C,this._sceneModePicker=y,this._projectionPicker=Y,this._baseLayerPicker=Q,this._navigationHelpButton=M,this._animation=Z,this._timeline=E,this._fullscreenButton=I,this._vrButton=_,this._geocoder=g,this._eventHelper=U,this._lastWidth=0,this._lastHeight=0,this._allowDataSourcesToSuspendAnimation=!0,this._entityView=void 0,this._enableInfoOrSelection=c(A)||c(G),this._clockTrackedDataSource=void 0,this._trackedEntity=void 0,this._needTrackedEntityUpdate=!1,this._selectedEntity=void 0,this._zoomIsFlight=!1,this._zoomTarget=void 0,this._zoomPromise=void 0,this._zoomOptions=void 0,this._selectedEntityChanged=new It,this._trackedEntityChanged=new It,this._referenceFrame=0,Lt.track(this,["_trackedEntity","_selectedEntity","_clockTrackedDataSource"]),U.add(u.dataSourceAdded,Do.prototype._onDataSourceAdded,this),U.add(u.dataSourceRemoved,Do.prototype._onDataSourceRemoved,this),U.add(V.postUpdate,Do.prototype.resize,this),U.add(V.postRender,Do.prototype._postRender,this);let z=u.length;for(let $=0;$<z;$++)this._dataSourceAdded(u,u.get($));this._dataSourceAdded(void 0,F.defaultDataSource),U.add(u.dataSourceAdded,Do.prototype._dataSourceAdded,this),U.add(u.dataSourceRemoved,Do.prototype._dataSourceRemoved,this);function H($){i.camera.unTrack(!1);let dt=M2t(i,$);c(dt)?et.getValueOrUndefined(dt.position,i.clock.currentTime)?i.trackedEntity=dt:i.zoomTo(dt):c(i.trackedEntity)&&(i.trackedEntity=void 0)}function nt($){i.selectedEntity=M2t(i,$)}h.screenSpaceEventHandler.setInputAction(nt,ui.LEFT_CLICK),h.screenSpaceEventHandler.setInputAction(H,ui.LEFT_DOUBLE_CLICK),V.fxaa=!0,V.fxaaOrderIndependentTranslucency=!0,this._bottomContainer.style.pointerEvents="none",this.container.style.userSelect="none"}Object.defineProperties(Do.prototype,{container:{get:function(){return this._container}},creditDisplay:{get:function(){return this._cesiumWidget.creditDisplay}},bottomContainer:{get:function(){return this._bottomContainer}},cesiumWidget:{get:function(){return this._cesiumWidget}},selectionIndicator:{get:function(){return this._selectionIndicator}},infoBox:{get:function(){return this._infoBox}},geocoder:{get:function(){return this._geocoder}},homeButton:{get:function(){return this._homeButton}},sceneModePicker:{get:function(){return this._sceneModePicker}},projectionPicker:{get:function(){return this._projectionPicker}},baseLayerPicker:{get:function(){return this._baseLayerPicker}},navigationHelpButton:{get:function(){return this._navigationHelpButton}},animation:{get:function(){return this._animation}},timeline:{get:function(){return this._timeline}},fullscreenButton:{get:function(){return this._fullscreenButton}},vrButton:{get:function(){return this._vrButton}},dataSourceDisplay:{get:function(){return this._dataSourceDisplay}},entities:{get:function(){return this._dataSourceDisplay.defaultDataSource.entities}},dataSources:{get:function(){return this._dataSourceCollection}},canvas:{get:function(){return this._cesiumWidget.canvas}},scene:{get:function(){return this._cesiumWidget.scene}},shadows:{get:function(){return this.scene.shadowMap.enabled},set:function(t){this.scene.shadowMap.enabled=t}},terrainShadows:{get:function(){return this.scene.globe.shadows},set:function(t){this.scene.globe.shadows=t}},shadowMap:{get:function(){return this.scene.shadowMap}},imageryLayers:{get:function(){return this.scene.imageryLayers}},terrainProvider:{get:function(){return this.scene.terrainProvider},set:function(t){this.scene.terrainProvider=t}},camera:{get:function(){return this.scene.camera}},postProcessStages:{get:function(){return this.scene.postProcessStages}},clock:{get:function(){return this._clockViewModel.clock}},clockViewModel:{get:function(){return this._clockViewModel}},screenSpaceEventHandler:{get:function(){return this._cesiumWidget.screenSpaceEventHandler}},targetFrameRate:{get:function(){return this._cesiumWidget.targetFrameRate},set:function(t){this._cesiumWidget.targetFrameRate=t}},useDefaultRenderLoop:{get:function(){return this._cesiumWidget.useDefaultRenderLoop},set:function(t){this._cesiumWidget.useDefaultRenderLoop=t}},resolutionScale:{get:function(){return this._cesiumWidget.resolutionScale},set:function(t){this._cesiumWidget.resolutionScale=t}},useBrowserRecommendedResolution:{get:function(){return this._cesiumWidget.useBrowserRecommendedResolution},set:function(t){this._cesiumWidget.useBrowserRecommendedResolution=t}},allowDataSourcesToSuspendAnimation:{get:function(){return this._allowDataSourcesToSuspendAnimation},set:function(t){this._allowDataSourcesToSuspendAnimation=t}},trackedEntity:{get:function(){return this._trackedEntity},set:function(t){if(this._trackedEntity!==t){this._trackedEntity=t,wrt(this);let e=this.scene,n=e.mode;!c(t)||!c(t.position)?(this._needTrackedEntityUpdate=!1,(n===Vt.COLUMBUS_VIEW||n===Vt.SCENE2D)&&(e.screenSpaceCameraController.enableTranslate=!0),(n===Vt.COLUMBUS_VIEW||n===Vt.SCENE3D)&&(e.screenSpaceCameraController.enableTilt=!0),this._entityView=void 0,this.camera.lookAtTransform(L.IDENTITY)):this._needTrackedEntityUpdate=!0,this._trackedEntityChanged.raiseEvent(t),this.scene.requestRender()}}},selectedEntity:{get:function(){return this._selectedEntity},set:function(t){if(this._selectedEntity!==t){this._selectedEntity=t;let e=c(this._selectionIndicator)?this._selectionIndicator.viewModel:void 0;c(t)?c(e)&&e.animateAppear():c(e)&&e.animateDepart(),this._selectedEntityChanged.raiseEvent(t)}}},selectedEntityChanged:{get:function(){return this._selectedEntityChanged}},trackedEntityChanged:{get:function(){return this._trackedEntityChanged}},clockTrackedDataSource:{get:function(){return this._clockTrackedDataSource},set:function(t){this._clockTrackedDataSource!==t&&(this._clockTrackedDataSource=t,O2t(this._timeline,this.clock,t))}},referenceFrame:{get:function(){return this._referenceFrame},set:function(t){this._referenceFrame=t}}});Do.prototype.extend=function(t,e){t(this,e)};Do.prototype.resize=function(){let t=this._cesiumWidget,e=this._container,n=e.clientWidth,i=e.clientHeight,o=c(this._animation),a=c(this._timeline);if(t.resize(),n===this._lastWidth&&i===this._lastHeight)return;let s=i-125,l=this._baseLayerPickerDropDown;if(c(l)&&(l.style.maxHeight=`${s}px`),c(this._geocoder)){let R=this._geocoder.searchSuggestionsContainer;R.style.maxHeight=`${s}px`}c(this._infoBox)&&(this._infoBox.viewModel.maxHeight=s);let r=this._timeline,d,m=0,h=0,u=0;if(o&&window.getComputedStyle(this._animation.container).visibility!=="hidden"){let R=this._lastWidth;d=this._animation.container,n>900?(m=169,R<=900&&(d.style.width="169px",d.style.height="112px",this._animation.resize())):n>=600?(m=136,(R<600||R>900)&&(d.style.width="136px",d.style.height="90px",this._animation.resize())):(m=106,(R>600||R===0)&&(d.style.width="106px",d.style.height="70px",this._animation.resize())),h=m+5}if(a&&window.getComputedStyle(this._timeline.container).visibility!=="hidden"){let R=this._fullscreenButton,V=this._vrButton,F=r.container,U=F.style;u=F.clientHeight+3,U.left=`${m}px`;let G=0;c(R)&&(G+=R.container.clientWidth),c(V)&&(G+=V.container.clientWidth),U.right=`${G}px`,r.resize()}this._bottomContainer.style.left=`${h}px`,this._bottomContainer.style.bottom=`${u}px`,this._lastWidth=n,this._lastHeight=i};Do.prototype.forceResize=function(){this._lastWidth=0,this.resize()};Do.prototype.render=function(){this._cesiumWidget.render()};Do.prototype.isDestroyed=function(){return!1};Do.prototype.destroy=function(){let t;c(this.screenSpaceEventHandler)&&!this.screenSpaceEventHandler.isDestroyed()&&(this.screenSpaceEventHandler.removeInputAction(ui.LEFT_CLICK),this.screenSpaceEventHandler.removeInputAction(ui.LEFT_DOUBLE_CLICK));let e=this.dataSources,n=e.length;for(t=0;t<n;t++)this._dataSourceRemoved(e,e.get(t));return this._dataSourceRemoved(void 0,this._dataSourceDisplay.defaultDataSource),this._container.removeChild(this._element),this._element.removeChild(this._toolbar),this._eventHelper.removeAll(),c(this._geocoder)&&(this._geocoder=this._geocoder.destroy()),c(this._homeButton)&&(this._homeButton=this._homeButton.destroy()),c(this._sceneModePicker)&&(this._sceneModePicker=this._sceneModePicker.destroy()),c(this._projectionPicker)&&(this._projectionPicker=this._projectionPicker.destroy()),c(this._baseLayerPicker)&&(this._baseLayerPicker=this._baseLayerPicker.destroy()),c(this._animation)&&(this._element.removeChild(this._animation.container),this._animation=this._animation.destroy()),c(this._timeline)&&(this._timeline.removeEventListener("settime",D2t,!1),this._element.removeChild(this._timeline.container),this._timeline=this._timeline.destroy()),c(this._fullscreenButton)&&(this._fullscreenSubscription.dispose(),this._element.removeChild(this._fullscreenButton.container),this._fullscreenButton=this._fullscreenButton.destroy()),c(this._vrButton)&&(this._vrSubscription.dispose(),this._vrModeSubscription.dispose(),this._element.removeChild(this._vrButton.container),this._vrButton=this._vrButton.destroy()),c(this._infoBox)&&(this._element.removeChild(this._infoBox.container),this._infoBox=this._infoBox.destroy()),c(this._selectionIndicator)&&(this._element.removeChild(this._selectionIndicator.container),this._selectionIndicator=this._selectionIndicator.destroy()),this._destroyClockViewModel&&(this._clockViewModel=this._clockViewModel.destroy()),this._dataSourceDisplay=this._dataSourceDisplay.destroy(),this._cesiumWidget=this._cesiumWidget.destroy(),this._destroyDataSourceCollection&&(this._dataSourceCollection=this._dataSourceCollection.destroy()),At(this)};Do.prototype._dataSourceAdded=function(t,e){e.entities.collectionChanged.addEventListener(Do.prototype._onEntityCollectionChanged,this)};Do.prototype._dataSourceRemoved=function(t,e){let n=e.entities;n.collectionChanged.removeEventListener(Do.prototype._onEntityCollectionChanged,this),c(this.trackedEntity)&&n.getById(this.trackedEntity.id)===this.trackedEntity&&(this.trackedEntity=void 0),c(this.selectedEntity)&&n.getById(this.selectedEntity.id)===this.selectedEntity&&(this.selectedEntity=void 0)};Do.prototype._onTick=function(t){let e=t.currentTime,n=this._dataSourceDisplay.update(e);this._allowDataSourcesToSuspendAnimation&&(this._clockViewModel.canAnimate=n);let i=this._entityView;if(c(i)){let m=this._trackedEntity;this._dataSourceDisplay.getBoundingSphere(m,!1,LU)===ve.DONE&&i.update(e,LU)}let o,a=!1,s=this.selectedEntity,l=c(s)&&this._enableInfoOrSelection;l&&s.isShowing&&s.isAvailable(e)&&(this._dataSourceDisplay.getBoundingSphere(s,!0,LU)!==ve.FAILED?o=LU.center:c(s.position)&&(o=s.position.getValue(e,o)),a=c(o));let r=c(this._selectionIndicator)?this._selectionIndicator.viewModel:void 0;c(r)&&(r.position=p.clone(o,r.position),r.showSelection=l&&a,r.update());let d=c(this._infoBox)?this._infoBox.viewModel:void 0;c(d)&&(d.showInfo=l,d.enableCamera=a,d.isCameraTracking=this.trackedEntity===this.selectedEntity,l?(d.titleText=f(s.name,s.id),d.description=et.getValueOrDefault(s.description,e,"")):(d.titleText="",d.description=""))};Do.prototype._onEntityCollectionChanged=function(t,e,n){let i=n.length;for(let o=0;o<i;o++){let a=n[o];this.trackedEntity===a&&(this.trackedEntity=void 0),this.selectedEntity===a&&(this.selectedEntity=void 0)}};Do.prototype._onInfoBoxCameraClicked=function(t){if(t.isCameraTracking&&this.trackedEntity===this.selectedEntity)this.trackedEntity=void 0;else{let n=this.selectedEntity.position;c(n)?this.trackedEntity=this.selectedEntity:this.zoomTo(this.selectedEntity)}};Do.prototype._clearTrackedObject=function(){this.trackedEntity=void 0};Do.prototype._onInfoBoxClockClicked=function(t){this.selectedEntity=void 0};Do.prototype._clearObjects=function(){this.trackedEntity=void 0,this.selectedEntity=void 0};Do.prototype._onDataSourceChanged=function(t){this.clockTrackedDataSource===t&&O2t(this.timeline,this.clock,t)};Do.prototype._onDataSourceAdded=function(t,e){this._automaticallyTrackDataSourceClocks&&(this.clockTrackedDataSource=e);let n=e.entities.id,i=this._eventHelper.add(e.changedEvent,Do.prototype._onDataSourceChanged,this);this._dataSourceChangedListeners[n]=i};Do.prototype._onDataSourceRemoved=function(t,e){let n=this.clockTrackedDataSource===e,i=e.entities.id;if(this._dataSourceChangedListeners[i](),this._dataSourceChangedListeners[i]=void 0,n){let o=t.length;this._automaticallyTrackDataSourceClocks&&o>0?this.clockTrackedDataSource=t.get(o-1):this.clockTrackedDataSource=void 0}};Do.prototype.zoomTo=function(t,e){return H2t(this,t,{offset:e},!1)};Do.prototype.flyTo=function(t,e){return H2t(this,t,e,!0)};function H2t(t,e,n,i){wrt(t);let o=new Promise(a=>{t._completeZoom=function(s){a(s)}});return t._zoomPromise=o,t._zoomIsFlight=i,t._zoomOptions=n,Promise.resolve(e).then(function(a){if(t._zoomPromise===o){if(a instanceof $r){let s;c(a.imageryProvider)?s=Promise.resolve(a.getImageryRectangle()):s=new Promise(l=>{let r=a.readyEvent.addEventListener(()=>{r(),l(a.getImageryRectangle())})}),s.then(function(l){return rg(l,t.scene)}).then(function(l){t._zoomPromise===o&&(t._zoomTarget=l)});return}if(a instanceof Pr||a instanceof UN||a instanceof SU){t._zoomTarget=a;return}if(a.isLoading&&c(a.loadingEvent)){let s=a.loadingEvent.addEventListener(function(){s(),t._zoomPromise===o&&(t._zoomTarget=a.entities.values.slice(0))});return}if(Array.isArray(a)){t._zoomTarget=a.slice(0);return}a=f(a.values,a),c(a.entities)&&(a=a.entities.values),Array.isArray(a)?t._zoomTarget=a.slice(0):t._zoomTarget=[a]}}),t.scene.requestRender(),o}function iO(t){t._zoomPromise=void 0,t._zoomTarget=void 0,t._zoomOptions=void 0}function wrt(t){let e=t._zoomPromise;c(e)&&(iO(t),t._completeZoom(!1))}Do.prototype._postRender=function(){WDe(this),fDe(this)};function WDe(t){let e=t._zoomTarget;if(!c(e)||t.scene.mode===Vt.MORPHING)return;let n=t.scene,i=n.camera,o=f(t._zoomOptions,{}),a;function s(m){c(o.offset)||(o.offset=new uV(0,-.5,m.radius)),a={offset:o.offset,duration:o.duration,maximumHeight:o.maximumHeight,complete:function(){t._completeZoom(!0)},cancel:function(){t._completeZoom(!1)}},t._zoomIsFlight?i.flyToBoundingSphere(e.boundingSphere,a):(i.viewBoundingSphere(m,o.offset),i.lookAtTransform(L.IDENTITY),t._completeZoom(!0)),iO(t)}if(e instanceof UN){if(c(e.boundingSphere)){s(e.boundingSphere);return}let m=e.frameChanged.addEventListener(function(h){s(h.boundingSphere),m()});return}if(e instanceof Pr||e instanceof SU){s(e.boundingSphere);return}if(e instanceof gt){a={destination:n.mapProjection.ellipsoid.cartographicToCartesian(e),duration:o.duration,maximumHeight:o.maximumHeight,complete:function(){t._completeZoom(!0)},cancel:function(){t._completeZoom(!1)}},t._zoomIsFlight?i.flyTo(a):(i.setView(a),t._completeZoom(!0)),iO(t);return}let l=e,r=[];for(let m=0,h=l.length;m<h;m++){let u=t._dataSourceDisplay.getBoundingSphere(l[m],!1,LU);if(u===ve.PENDING)return;u!==ve.FAILED&&r.push(Ft.clone(LU))}if(r.length===0){wrt(t);return}t.trackedEntity=void 0;let d=Ft.fromBoundingSpheres(r);t._zoomIsFlight?(iO(t),i.flyToBoundingSphere(d,{duration:o.duration,maximumHeight:o.maximumHeight,complete:function(){t._completeZoom(!0)},cancel:function(){t._completeZoom(!1)},offset:o.offset})):(i.viewBoundingSphere(d,o.offset),i.lookAtTransform(L.IDENTITY),iO(t),t._completeZoom(!0))}function fDe(t){if(!t._needTrackedEntityUpdate)return;let e=t._trackedEntity,n=t.clock.currentTime,i=et.getValueOrUndefined(e.position,n);if(!c(i))return;let o=t.scene,a=t._dataSourceDisplay.getBoundingSphere(e,!1,LU);if(a===ve.PENDING)return;let s=o.mode;(s===Vt.COLUMBUS_VIEW||s===Vt.SCENE2D)&&(o.screenSpaceCameraController.enableTranslate=!1),(s===Vt.COLUMBUS_VIEW||s===Vt.SCENE3D)&&(o.screenSpaceCameraController.enableTilt=!1);let l=a!==ve.FAILED?LU:void 0;t._entityView=new AL(e,o,o.mapProjection.ellipsoid),t._entityView.update(n,l),t._needTrackedEntityUpdate=!1}var Prt=Do;var XAa=b(W(),1),FDe='.cesium-svgPath-svg{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden}.cesium-button{display:inline-block;position:relative;background:#303336;border:1px solid #444;color:#edffff;fill:#edffff;border-radius:4px;padding:5px 12px;margin:2px 3px;cursor:pointer;overflow:hidden;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.cesium-button:focus{color:#fff;fill:#fff;border-color:#ea4;outline:0}.cesium-button:hover{color:#fff;fill:#fff;background:#48b;border-color:#aef;box-shadow:0 0 8px #fff}.cesium-button:active{color:#000;fill:#000;background:#adf;border-color:#fff;box-shadow:0 0 8px #fff}.cesium-button-disabled,.cesium-button-disabled:active,.cesium-button-disabled:focus,.cesium-button-disabled:hover,.cesium-button:disabled{background:#303336;border-color:#444;color:#646464;fill:#646464;box-shadow:none;cursor:default}.cesium-button option{background-color:#000;color:#eee}.cesium-button option:disabled{color:#777}.cesium-button input,.cesium-button label{cursor:pointer}.cesium-button input{vertical-align:sub}.cesium-toolbar-button{box-sizing:border-box;width:32px;height:32px;border-radius:14%;padding:0;vertical-align:middle;z-index:0}.cesium-performanceDisplay-defaultContainer{position:absolute;top:50px;right:10px;text-align:right}.cesium-performanceDisplay{background-color:rgba(40,40,40,.7);padding:7px;border-radius:5px;border:1px solid #444;font:bold 12px sans-serif}.cesium-performanceDisplay-fps{color:#e52}.cesium-performanceDisplay-throttled{color:#a42}.cesium-performanceDisplay-ms{color:#de3}.cesium-animation-theme{visibility:hidden;display:block;position:absolute;z-index:-100}.cesium-animation-themeNormal{color:#222}.cesium-animation-themeHover{color:#4488b0}.cesium-animation-themeSelect{color:#242}.cesium-animation-themeDisabled{color:#333}.cesium-animation-themeKnob{color:#222}.cesium-animation-themePointer{color:#2e2}.cesium-animation-themeSwoosh{color:#8ac}.cesium-animation-themeSwooshHover{color:#aef}.cesium-animation-svgText{fill:#edffff;font-family:Sans-Serif;font-size:15px;text-anchor:middle}.cesium-animation-blank{fill:#000;fill-opacity:0.01;stroke:none}.cesium-animation-rectButton{cursor:pointer;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.cesium-animation-rectButton .cesium-animation-buttonGlow{fill:#fff;stroke:none;display:none}.cesium-animation-rectButton:hover .cesium-animation-buttonGlow{display:block}.cesium-animation-rectButton .cesium-animation-buttonPath{fill:#edffff}.cesium-animation-rectButton .cesium-animation-buttonMain{stroke:#444;stroke-width:1.2}.cesium-animation-rectButton:hover .cesium-animation-buttonMain{stroke:#aef}.cesium-animation-rectButton:active .cesium-animation-buttonMain{fill:#abd6ff}.cesium-animation-buttonDisabled{-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.cesium-animation-buttonDisabled .cesium-animation-buttonMain{stroke:#555}.cesium-animation-buttonDisabled .cesium-animation-buttonPath{fill:#818181}.cesium-animation-buttonDisabled .cesium-animation-buttonGlow{display:none}.cesium-animation-buttonToggled .cesium-animation-buttonGlow{display:block;fill:#2e2}.cesium-animation-buttonToggled .cesium-animation-buttonMain{stroke:#2e2}.cesium-animation-buttonToggled:hover .cesium-animation-buttonGlow{fill:#fff}.cesium-animation-buttonToggled:hover .cesium-animation-buttonMain{stroke:#2e2}.cesium-animation-shuttleRingG{cursor:pointer}.cesium-animation-shuttleRingPointer{cursor:pointer}.cesium-animation-shuttleRingPausePointer{cursor:pointer}.cesium-animation-shuttleRingBack{fill:#181818;fill-opacity:0.8;stroke:#333;stroke-width:1.2}.cesium-animation-shuttleRingSwoosh line{stroke:#8ac;stroke-width:3;stroke-opacity:0.2;stroke-linecap:round}.cesium-animation-knobOuter{cursor:pointer;stroke:#444;stroke-width:1.2}.cesium-animation-knobInner{cursor:pointer}.cesium-baseLayerPicker-selected{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.cesium-baseLayerPicker-dropDown{display:block;position:absolute;box-sizing:content-box;top:auto;right:0;width:320px;max-height:500px;margin-top:5px;background-color:rgba(38,38,38,.75);border:1px solid #444;padding:6px;overflow:auto;border-radius:10px;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none;transform:translate(0,-20%);visibility:hidden;opacity:0;transition:visibility 0s .2s,opacity .2s ease-in,transform .2s ease-in}.cesium-baseLayerPicker-dropDown-visible{transform:translate(0,0);visibility:visible;opacity:1;transition:opacity .2s ease-out,transform .2s ease-out}.cesium-baseLayerPicker-sectionTitle{display:block;font-family:sans-serif;font-size:16pt;text-align:left;color:#edffff;margin-bottom:4px}.cesium-baseLayerPicker-choices{margin-bottom:5px}.cesium-baseLayerPicker-categoryTitle{color:#edffff;font-size:11pt}.cesium-baseLayerPicker-choices{display:block;border:1px solid #888;border-radius:5px;padding:5px 0}.cesium-baseLayerPicker-item{display:inline-block;vertical-align:top;margin:2px 5px;width:64px;text-align:center;cursor:pointer}.cesium-baseLayerPicker-itemLabel{display:block;font-family:sans-serif;font-size:8pt;text-align:center;vertical-align:middle;color:#edffff;cursor:pointer;word-wrap:break-word}.cesium-baseLayerPicker-item:focus .cesium-baseLayerPicker-itemLabel,.cesium-baseLayerPicker-item:hover .cesium-baseLayerPicker-itemLabel{text-decoration:underline}.cesium-baseLayerPicker-itemIcon{display:inline-block;position:relative;width:inherit;height:auto;background-size:100% 100%;border:solid 1px #444;border-radius:9px;color:#edffff;margin:0;padding:0;cursor:pointer;box-sizing:border-box}.cesium-baseLayerPicker-item:hover .cesium-baseLayerPicker-itemIcon{border-color:#fff;box-shadow:0 0 8px #fff,0 0 8px #fff}.cesium-baseLayerPicker-selectedItem .cesium-baseLayerPicker-itemLabel{color:#bdecf8}.cesium-baseLayerPicker-selectedItem .cesium-baseLayerPicker-itemIcon{border:double 4px #bdecf8}.cesium-widget{position:relative}.cesium-widget,.cesium-widget canvas{width:100%;height:100%;touch-action:none}.cesium-widget-credits{display:block;position:absolute;bottom:0;left:0;color:#fff;font-size:10px;text-shadow:0 0 2px #000;padding-right:5px}.cesium-widget-credits a,.cesium-widget-credits a:visited{color:#fff}.cesium-widget-errorPanel{position:absolute;top:0;right:0;bottom:0;left:0;text-align:center;background:rgba(0,0,0,.7);z-index:99999}.cesium-widget-errorPanel:before{display:inline-block;vertical-align:middle;height:100%;content:""}.cesium-widget-errorPanel-content{width:75%;max-width:500px;display:inline-block;text-align:left;vertical-align:middle;border:1px solid #510c00;border-radius:7px;background-color:#f0d9d5;font-size:14px;color:#510c00}.cesium-widget-errorPanel-content.expanded{max-width:75%}.cesium-widget-errorPanel-header{font-size:18px;font-family:"Open Sans",Verdana,Geneva,sans-serif;background:#d69d93;border-bottom:2px solid #510c00;padding-bottom:10px;border-radius:3px 3px 0 0;padding:15px}.cesium-widget-errorPanel-scroll{overflow:auto;font-family:"Open Sans",Verdana,Geneva,sans-serif;white-space:pre-wrap;padding:0 15px;margin:10px 0 20px 0}.cesium-widget-errorPanel-buttonPanel{padding:0 15px;margin:10px 0 20px 0;text-align:right}.cesium-widget-errorPanel-buttonPanel button{border-color:#510c00;background:#d69d93;color:#202020;margin:0}.cesium-widget-errorPanel-buttonPanel button:focus{border-color:#510c00;background:#f0d9d5;color:#510c00}.cesium-widget-errorPanel-buttonPanel button:hover{border-color:#510c00;background:#f0d9d5;color:#510c00}.cesium-widget-errorPanel-buttonPanel button:active{border-color:#510c00;background:#b17b72;color:#510c00}.cesium-widget-errorPanel-more-details{text-decoration:underline;cursor:pointer}.cesium-widget-errorPanel-more-details:hover{color:#2b0700}.cesium-cesiumInspector{border-radius:5px;transition:width ease-in-out .25s;background:rgba(48,51,54,.8);border:1px solid #444;color:#edffff;display:inline-block;position:relative;padding:4px 12px;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden}.cesium-cesiumInspector-button{text-align:center;font-size:11pt}.cesium-cesiumInspector-visible .cesium-cesiumInspector-button{border-bottom:1px solid #aaa;padding-bottom:3px}.cesium-cesiumInspector input:enabled,.cesium-cesiumInspector-button{cursor:pointer}.cesium-cesiumInspector-visible{width:185px;height:auto}.cesium-cesiumInspector-hidden{width:122px;height:17px}.cesium-cesiumInspector-sectionContent{max-height:500px}.cesium-cesiumInspector-section-collapsed .cesium-cesiumInspector-sectionContent{max-height:0;padding:0!important;overflow:hidden}.cesium-cesiumInspector-dropDown{margin:5px 0;font-family:sans-serif;font-size:10pt;width:185px}.cesium-cesiumInspector-frustumStatistics{padding-left:10px;padding:5px;background-color:rgba(80,80,80,.75)}.cesium-cesiumInspector-pickButton{background-color:rgba(0,0,0,.3);border:1px solid #444;color:#edffff;border-radius:5px;padding:3px 7px;cursor:pointer;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none;margin:0 auto}.cesium-cesiumInspector-pickButton:focus{outline:0}.cesium-cesiumInspector-pickButton:active,.cesium-cesiumInspector-pickButtonHighlight{color:#000;background:#adf;border-color:#fff;box-shadow:0 0 8px #fff}.cesium-cesiumInspector-center{text-align:center}.cesium-cesiumInspector-sectionHeader{font-weight:700;font-size:10pt;margin:0;cursor:pointer}.cesium-cesiumInspector-pickSection{border:1px solid #aaa;border-radius:5px;padding:3px;margin-bottom:5px}.cesium-cesiumInspector-sectionContent{margin-bottom:10px;transition:max-height .25s}.cesium-cesiumInspector-tileText{padding-bottom:10px;border-bottom:1px solid #aaa}.cesium-cesiumInspector-relativeText{padding-top:10px}.cesium-cesiumInspector-sectionHeader::before{margin-right:5px;content:"-";width:1ch;display:inline-block}.cesium-cesiumInspector-section-collapsed .cesium-cesiumInspector-sectionHeader::before{content:"+"}ul.cesium-cesiumInspector-statistics{margin:0;padding-top:3px;padding-bottom:3px}ul.cesium-cesiumInspector-statistics+ul.cesium-cesiumInspector-statistics{border-top:1px solid #aaa}.cesium-cesiumInspector-slider{margin-top:5px}.cesium-cesiumInspector-slider input[type=number]{text-align:left;background-color:#222;outline:0;border:1px solid #444;color:#edffff;width:100px;border-radius:3px;padding:1px;margin-left:10px;cursor:auto}.cesium-cesiumInspector-slider input[type=number]::-webkit-inner-spin-button,.cesium-cesiumInspector-slider input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.cesium-cesiumInspector-slider input[type=range]{margin-left:5px;vertical-align:middle}.cesium-cesiumInspector-hide .cesium-cesiumInspector-styleEditor{display:none}.cesium-cesiumInspector-styleEditor{padding:10px;border-radius:5px;background:rgba(48,51,54,.8);border:1px solid #444}.cesium-cesiumInspector-styleEditor textarea{width:100%;height:300px;background:0 0;color:#edffff;border:none;padding:0;white-space:pre;overflow-wrap:normal;overflow-x:auto}.cesium-3DTilesInspector{width:300px;pointer-events:all}.cesium-3DTilesInspector-statistics{font-size:11px}.cesium-3DTilesInspector div,.cesium-3DTilesInspector input[type=range]{width:100%;box-sizing:border-box}.cesium-cesiumInspector-error{color:#ff9e9e;overflow:auto}.cesium-3DTilesInspector .cesium-cesiumInspector-section{margin-top:3px}.cesium-3DTilesInspector .cesium-cesiumInspector-sectionHeader+.cesium-cesiumInspector-show{border-top:1px solid #fff}input.cesium-cesiumInspector-url{overflow:hidden;white-space:nowrap;overflow-x:scroll;background-color:transparent;color:#fff;outline:0;border:none;height:1em;width:100%}.cesium-cesiumInspector .field-group{display:table}.cesium-cesiumInspector .field-group>label{display:table-cell;font-weight:700}.cesium-cesiumInspector .field-group>.field{display:table-cell;width:100%}.cesium-button.cesium-fullscreenButton{display:block;width:100%;height:100%;margin:0;border-radius:0}.cesium-button.cesium-vrButton{display:block;width:100%;height:100%;margin:0;border-radius:0}.cesium-viewer-geocoderContainer .cesium-geocoder-input{border:solid 1px #444;background-color:rgba(40,40,40,.7);color:#fff;display:inline-block;vertical-align:middle;width:0;height:32px;margin:0;padding:0 32px 0 0;border-radius:0;box-sizing:border-box;transition:width ease-in-out .25s,background-color .2s ease-in-out;-webkit-appearance:none}.cesium-viewer-geocoderContainer:hover .cesium-geocoder-input{border-color:#aef;box-shadow:0 0 8px #fff}.cesium-viewer-geocoderContainer .cesium-geocoder-input:focus{border-color:#ea4;background-color:rgba(15,15,15,.9);box-shadow:none;outline:0}.cesium-viewer-geocoderContainer .cesium-geocoder-input-wide,.cesium-viewer-geocoderContainer .cesium-geocoder-input:focus,.cesium-viewer-geocoderContainer:hover .cesium-geocoder-input{padding-left:4px;width:250px}.cesium-viewer-geocoderContainer .search-results{position:absolute;background-color:#000;color:#eee;overflow-y:auto;opacity:.8;width:100%}.cesium-viewer-geocoderContainer .search-results ul{list-style-type:none;margin:0;padding:0}.cesium-viewer-geocoderContainer .search-results ul li{font-size:14px;padding:3px 10px}.cesium-viewer-geocoderContainer .search-results ul li:hover{cursor:pointer}.cesium-viewer-geocoderContainer .search-results ul li.active{background:#48b}.cesium-geocoder-searchButton{background-color:#303336;display:inline-block;position:absolute;cursor:pointer;width:32px;top:1px;right:1px;height:30px;vertical-align:middle;fill:#edffff}.cesium-geocoder-searchButton:hover{background-color:#48b}.cesium-infoBox{display:block;position:absolute;top:50px;right:0;width:40%;max-width:480px;background:rgba(38,38,38,.95);color:#edffff;border:1px solid #444;border-right:none;border-top-left-radius:7px;border-bottom-left-radius:7px;box-shadow:0 0 10px 1px #000;transform:translate(100%,0);visibility:hidden;opacity:0;transition:visibility 0s .2s,opacity .2s ease-in,transform .2s ease-in}.cesium-infoBox-visible{transform:translate(0,0);visibility:visible;opacity:1;transition:opacity .2s ease-out,transform .2s ease-out}.cesium-infoBox-title{display:block;height:20px;padding:5px 30px 5px 25px;background:#545454;border-top-left-radius:7px;text-align:center;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;box-sizing:content-box}.cesium-infoBox-bodyless .cesium-infoBox-title{border-bottom-left-radius:7px}button.cesium-infoBox-camera{display:block;position:absolute;top:4px;left:4px;width:22px;height:22px;background:0 0;border-color:transparent;border-radius:3px;padding:0 5px;margin:0}button.cesium-infoBox-close{display:block;position:absolute;top:5px;right:5px;height:20px;background:0 0;border:none;border-radius:2px;font-weight:700;font-size:16px;padding:0 5px;margin:0;color:#edffff}button.cesium-infoBox-close:focus{background:rgba(238,136,0,.44);outline:0}button.cesium-infoBox-close:hover{background:#888;color:#000}button.cesium-infoBox-close:active{background:#a00;color:#000}.cesium-infoBox-bodyless .cesium-infoBox-iframe{display:none}.cesium-infoBox-iframe{border:none;width:100%;width:calc(100% - 2px)}span.cesium-sceneModePicker-wrapper{display:inline-block;position:relative;margin:0 3px}.cesium-sceneModePicker-visible{visibility:visible;opacity:1;transition:opacity .25s linear}.cesium-sceneModePicker-hidden{visibility:hidden;opacity:0;transition:visibility 0s .25s,opacity .25s linear}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-none{display:none}.cesium-sceneModePicker-slide-svg{transition:left 2s;top:0;left:0}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-dropDown-icon{box-sizing:border-box;padding:0;margin:3px 0}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button2D,.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button3D,.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-buttonColumbusView{margin:0 0 3px 0}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button3D .cesium-sceneModePicker-icon2D{left:100%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button3D .cesium-sceneModePicker-iconColumbusView{left:200%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-buttonColumbusView .cesium-sceneModePicker-icon3D{left:-200%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-buttonColumbusView .cesium-sceneModePicker-icon2D{left:-100%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button2D .cesium-sceneModePicker-icon3D{left:-100%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-button2D .cesium-sceneModePicker-iconColumbusView{left:100%}.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-selected{border-color:#2e2;box-shadow:0 0 8px #fff,0 0 8px #fff}span.cesium-projectionPicker-wrapper{display:inline-block;position:relative;margin:0 3px}.cesium-projectionPicker-visible{visibility:visible;opacity:1;transition:opacity .25s linear}.cesium-projectionPicker-hidden{visibility:hidden;opacity:0;transition:visibility 0s .25s,opacity .25s linear}.cesium-projectionPicker-wrapper .cesium-projectionPicker-none{display:none}.cesium-projectionPicker-wrapper .cesium-projectionPicker-dropDown-icon{box-sizing:border-box;padding:0;margin:3px 0}.cesium-projectionPicker-wrapper .cesium-projectionPicker-buttonOrthographic,.cesium-projectionPicker-wrapper .cesium-projectionPicker-buttonPerspective{margin:0 0 3px 0}.cesium-projectionPicker-wrapper .cesium-projectionPicker-buttonPerspective .cesium-projectionPicker-iconOrthographic{left:100%}.cesium-projectionPicker-wrapper .cesium-projectionPicker-buttonOrthographic .cesium-projectionPicker-iconPerspective{left:-100%}.cesium-projectionPicker-wrapper .cesium-projectionPicker-selected{border-color:#2e2;box-shadow:0 0 8px #fff,0 0 8px #fff}.cesium-performance-watchdog-message-area{position:relative;background-color:#ff0;color:#000;padding:10px}.cesium-performance-watchdog-message{margin-right:30px}.cesium-performance-watchdog-message-dismiss{position:absolute;right:0;margin:0 10px 0 0}.cesium-navigationHelpButton-wrapper{position:relative;display:inline-block}.cesium-navigation-help{visibility:hidden;position:absolute;top:38px;right:2px;width:250px;border-radius:10px;transform:scale(.01);transform-origin:234px -10px;transition:visibility 0s .25s,transform .25s ease-in}.cesium-navigation-help-visible{visibility:visible;transform:scale(1);transition:transform .25s ease-out}.cesium-navigation-help-instructions{border:1px solid #444;background-color:rgba(38,38,38,.75);padding-bottom:5px;border-radius:0 0 10px 10px}.cesium-click-navigation-help{display:none}.cesium-touch-navigation-help{display:none;padding-top:5px}.cesium-click-navigation-help-visible{display:block}.cesium-touch-navigation-help-visible{display:block}.cesium-navigation-help-pan{color:#6cf;font-weight:700}.cesium-navigation-help-zoom{color:#65fd00;font-weight:700}.cesium-navigation-help-rotate{color:#ffd800;font-weight:700}.cesium-navigation-help-tilt{color:#d800d8;font-weight:700}.cesium-navigation-help-details{color:#fff}.cesium-navigation-button{color:#fff;background-color:transparent;border-bottom:none;border-top:1px solid #444;border-right:1px solid #444;margin:0;width:50%;cursor:pointer}.cesium-navigation-button-icon{vertical-align:middle;padding:5px 1px}.cesium-navigation-button:focus{outline:0}.cesium-navigation-button-left{border-radius:10px 0 0 0;border-left:1px solid #444}.cesium-navigation-button-right{border-radius:0 10px 0 0;border-left:none}.cesium-navigation-button-selected{background-color:rgba(38,38,38,.75)}.cesium-navigation-button-unselected{background-color:rgba(0,0,0,.75)}.cesium-navigation-button-unselected:hover{background-color:rgba(76,76,76,.75)}.cesium-selection-wrapper{position:absolute;width:160px;height:160px;pointer-events:none;visibility:hidden;opacity:0;transition:visibility 0s .2s,opacity .2s ease-in}.cesium-selection-wrapper-visible{visibility:visible;opacity:1;transition:opacity .2s ease-out}.cesium-selection-wrapper svg{fill:#2e2;stroke:#000;stroke-width:1.1px}.cesium-timeline-main{position:relative;left:0;bottom:0;overflow:hidden;border:solid 1px #888}.cesium-timeline-trackContainer{width:100%;overflow:auto;border-top:solid 1px #888;position:relative;top:0;left:0}.cesium-timeline-tracks{position:absolute;top:0;left:0;width:100%}.cesium-timeline-needle{position:absolute;left:0;top:1.7em;bottom:0;width:1px;background:red}.cesium-timeline-bar{position:relative;left:0;top:0;overflow:hidden;cursor:pointer;width:100%;height:1.7em;background:linear-gradient(to bottom,rgba(116,117,119,.8) 0,rgba(58,68,82,.8) 11%,rgba(46,50,56,.8) 46%,rgba(53,53,53,.8) 81%,rgba(53,53,53,.8) 100%)}.cesium-timeline-ruler{visibility:hidden;white-space:nowrap;font-size:80%;z-index:-200}.cesium-timeline-highlight{position:absolute;bottom:0;left:0;background:#08f}.cesium-timeline-ticLabel{position:absolute;top:0;left:0;white-space:nowrap;font-size:80%;color:#eee}.cesium-timeline-ticMain{position:absolute;bottom:0;left:0;width:1px;height:50%;background:#eee}.cesium-timeline-ticSub{position:absolute;bottom:0;left:0;width:1px;height:33%;background:#aaa}.cesium-timeline-ticTiny{position:absolute;bottom:0;left:0;width:1px;height:25%;background:#888}.cesium-timeline-icon16{display:block;position:absolute;width:16px;height:16px;background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAQCAYAAAB3AH1ZAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9sIDBITKIVzLEMAAAKNSURBVEjHxdXNSxRhHAfw7zzrqhuoWJnSkrippUVSEKsHI9BTUYdAJA/RoYMREV26rAdn6tAfUARi16hQqkOBQRgUEYFWEC3OwczMjdZd92VmdWfmeelgTjO7q7gb0VzmmZnn85vvPPPMM8B/3qTcE2PPpuTZKB1eWuUQACgXYACYwVFbCTTVeZXB/i55o4LFelcAZfStYD4vpAoPGAGo4GBcQEgSOAUMQyAezwK6iQfDPXnhS/FkHZ+/8VLMWxxqWkfH3gbMRNOYi2roavbja0zHQmoFPYf8ED4Ko4aivm9MOG/u9I8mwrafeK7a/tVrNc/bARYN5noadeq7q0342vXw9CIMU6BmW8rVP9cPBPe52uu+v3O/y9sB4gkTWs6Qsk0mj5ExXMelejvA8WafYmkmGPHanTijdtvif8rx5RiCjdWKs2Cp3jWRDl96KhrbqlBeJqBOLyLQXg0IgbkZDS0dO8EZxZfPSTA9jvDDK3mT0OmP1FXh3XwEEAKdTX5MRWLgjCK4pwH3xt/YnjgLHAv4lHTCAKMMu/wV+KZGob6PoKyMQ0+sgBpZVJZn0NterxQaVqef/DRn+/EXYds/mZx2eVeAW9d65dhCEsaKCb7K8HH0gqTevyh9GDkn0VULRiaLzJKGBu9swfdaiie5RVo9ESURN8E8BE0n7ggACJy8KzghSCzp6DmwWxkaCm24EBXr8wI8Hrkq06QBiRC0t24HALS11IBTCyJl4vb1AXmzpbVYTwoVOXN0h7L8Mwtm8bXPybIQ/5FCX3dA2cr6XowvGCA02CvztAnz9+JiZk1AMxG6fEreSoBiPNmoyNnuWiWVzAIAtISO08E6pZi/3N96AIDn4E3h3P8L/wshP+txtEs4JAAAAABJRU5ErkJggg==");background-repeat:no-repeat}.cesium-viewer{font-family:sans-serif;font-size:16px;overflow:hidden;display:block;position:relative;top:0;left:0;width:100%;height:100%}.cesium-viewer-cesiumWidgetContainer{width:100%;height:100%}.cesium-viewer-bottom{display:block;position:absolute;bottom:0;left:0;padding-right:5px}.cesium-viewer .cesium-widget-credits{display:inline;position:static;bottom:auto;left:auto;padding-right:0;color:#fff;font-size:10px;text-shadow:0 0 2px #000}.cesium-viewer-timelineContainer{position:absolute;bottom:0;left:169px;right:29px;height:27px;padding:0;margin:0;overflow:hidden;font-size:14px}.cesium-viewer-animationContainer{position:absolute;bottom:0;left:0;padding:0;width:169px;height:112px}.cesium-viewer-fullscreenContainer{position:absolute;bottom:0;right:0;padding:0;width:29px;height:29px;overflow:hidden}.cesium-viewer-vrContainer{position:absolute;bottom:0;right:0;padding:0;width:29px;height:29px;overflow:hidden}.cesium-viewer-toolbar{display:block;position:absolute;top:5px;right:5px}.cesium-viewer-cesiumInspectorContainer{display:block;position:absolute;top:50px;right:10px}.cesium-viewer-geocoderContainer{position:relative;display:inline-block;margin:0 3px}.cesium-viewer-cesium3DTilesInspectorContainer{display:block;position:absolute;top:50px;right:10px;max-height:calc(100% - 120px);box-sizing:border-box;overflow-y:auto;overflow-x:hidden}.cesium-viewer-bottom{z-index:10000}';function UDe(t,e){let n=document.head||document.getElementsByTagName("head")[0],i=document.createElement("style");i.innerText=FDe,n.appendChild(i)}var vrt=UDe;var MAa=b(W(),1);var oO,w2t;function GDe(){let t=180/Math.PI*Math.atan2(oO.scene.camera.position.x,oO.scene.camera.position.y),e=t>0?t:360+t;console.log(`Azimuth: ${e}`),console.log(`Pointing: ${(e+180)%360}`)}function ADe(t,e={autosave:!1,interval:1e3}){oO=t;let{view:n}=t.storage.queryOptions;if(c(n)){let i=n.split(/[ ,]+/);if(i.length>1){let o=isNaN(+i[0])?0:+i[0],a=isNaN(+i[1])?0:+i[1],s=i.length>2&&!isNaN(+i[2])?+i[2]:300,l=i.length>3&&!isNaN(+i[3])?k.toRadians(+i[3]):void 0,r=i.length>4&&!isNaN(+i[4])?k.toRadians(+i[4]):void 0,d=i.length>5&&!isNaN(+i[5])?k.toRadians(+i[5]):void 0;oO.camera.setView({destination:p.fromDegrees(o,a,s),orientation:{heading:l,pitch:r,roll:d}})}}e.autosave&&oO.camera.changed.addEventListener(()=>{window.clearTimeout(w2t),w2t=window.setTimeout(GDe,1e3)})}var Krt=ADe;var OAa=b(W(),1);function SDe(t){let e=document.createElement("div");e.className="cesium-viewer-cesium3DTilesInspectorContainer",t.container.appendChild(e);let n=new fD(e,t.scene);Object.defineProperties(t,{cesium3DTilesInspector:{get:function(){return n}}})}var zrt=SDe;var PAa=b(W(),1);function TDe(t){let e=document.createElement("div");e.className="cesium-viewer-cesiumInspectorContainer",t.container.appendChild(e);let n=new ND(e,t.scene);Object.defineProperties(t,{cesiumInspector:{get:function(){return n}}})}var jrt=TDe;var jAa=b(W(),1);function gDe(t,e){e=f(e,f.EMPTY_OBJECT);let n=!0,i=f(e.flyToOnDrop,!0),o=new It,a=f(e.clearOnDrop,!0),s=f(e.dropTarget,t.container),l=f(e.clampToGround,!0),r=e.proxy;s=Ui(s),Object.defineProperties(t,{dropTarget:{get:function(){return s},set:function(m){P2t(s,d),s=m,qrt(s,d)}},dropEnabled:{get:function(){return n},set:function(m){m!==n&&(m?qrt(s,d):P2t(s,d),n=m)}},dropError:{get:function(){return o}},clearOnDrop:{get:function(){return a},set:function(m){a=m}},flyToOnDrop:{get:function(){return i},set:function(m){i=m}},proxy:{get:function(){return r},set:function(m){r=m}},clampToGround:{get:function(){return l},set:function(m){l=m}}});function d(m){hg(m),a&&(t.entities.removeAll(),t.dataSources.removeAll());let h=m.dataTransfer.files,u=h.length;for(let R=0;R<u;R++){let V=h[R],F=new FileReader;F.onload=EDe(t,V,r,l),F.onerror=CDe(t,V),F.readAsText(V)}}qrt(s,d),t.destroy=Y5(t,t.destroy,function(){t.dropEnabled=!1}),t._handleDrop=d}function hg(t){t.stopPropagation(),t.preventDefault()}function P2t(t,e){let n=t;c(n)&&(n.removeEventListener("drop",e,!1),n.removeEventListener("dragenter",hg,!1),n.removeEventListener("dragover",hg,!1),n.removeEventListener("dragexit",hg,!1))}function qrt(t,e){t.addEventListener("drop",e,!1),t.addEventListener("dragenter",hg,!1),t.addEventListener("dragover",hg,!1),t.addEventListener("dragexit",hg,!1)}function EDe(t,e,n,i){let o=t.scene;return function(a){let s=e.name;try{let l;if(/\.czml$/i.test(s))l=O0.load(JSON.parse(a.target.result),{sourceUri:s});else if(/\.geojson$/i.test(s)||/\.json$/i.test(s)||/\.topojson$/i.test(s))l=gL.load(JSON.parse(a.target.result),{sourceUri:s,clampToGround:i});else if(/\.(kml|kmz)$/i.test(s))l=iM.load(e,{sourceUri:s,proxy:n,camera:o.camera,canvas:o.canvas,clampToGround:i,screenOverlayContainer:t.container});else if(/\.gpx$/i.test(s))l=NL.load(e,{sourceUri:s,proxy:n});else{t.dropError.raiseEvent(t,s,`Unrecognized file: ${s}`);return}c(l)&&t.dataSources.add(l).then(function(r){t.flyToOnDrop&&t.flyTo(r)}).catch(function(r){t.dropError.raiseEvent(t,s,r)})}catch(l){t.dropError.raiseEvent(t,s,l)}}}function CDe(t,e){return function(n){t.dropError.raiseEvent(t,e.name,n.target.error)}}var $rt=gDe;var iSa=b(W(),1);function IDe(t,e){e=f(e,f.EMPTY_OBJECT);let n=new OD({scene:t.scene,container:t.bottomContainer,lowFrameRateMessage:e.lowFrameRateMessage});Object.defineProperties(t,{performanceWatchdog:{get:function(){return n}}})}var tdt=IDe;var sSa=b(W(),1);function NDe(t){if(t.scene.mode!==Vt.SCENE3D)return;let e=t.scene,n=t.clock.currentTime,i=e.camera,o=p.clone(i.position);if(t.referenceFrame===ri.INERTIAL&&!t.trackedEntity){let a=Pe.computeIcrfToFixedMatrix(n);if(c(a)){let s=L.fromRotationTranslation(a);i.lookAtTransform(s,o)}}else t.trackedEntity||i.lookAtTransform(L.IDENTITY)}function yDe(t){Object.defineProperty(t,"referenceFrame",{get:function(){return this._referenceFrame},set:function(e){this._referenceFrame=e,this.scene.referenceFrame=e,this.eventBus&&this.eventBus.emit("referenceFrame",this._referenceFrame);let n=this.dataSources._dataSources;for(let i=0;i<n.length;i++)n[i]._entityCollection.referenceFrame=e}}),t.dataSources.dataSourceAdded.addEventListener(function(e,n){n._viewer=t,n._entityCollection.referenceFrame=t.referenceFrame}),t.scene.preRender.addEventListener(function(){NDe(t)})}var edt=yDe;var dSa=b(W(),1);function ndt(t,e){t.storage={},t.storage.queryOptions=Sc(window.location.search.substring(1))}var ASa=b(W(),1);var FSa=b(W(),1);var VSa=b(W(),1);function v2t(t){let e=t.split(` `),n;for(n=0;n<e.length&&!e[n].match(/\S/);n++);if(n===e.length)return"";let i="",o=/^\s*/,s=e[n].match(o)[0].length;for(let l=n;l<e.length;l++){let r=e[l];r.match(o)[0].length>=s&&(r=r.slice(s)),i+=`${r} -`}return i}function Xu(t){this._scene=t,this._voxelPrimitive=void 0,this._customShaderCompilationRemoveCallback=void 0,this._definedProperties=[],this._getPrimitiveFunctions=[],this._modelMatrixReady=!1;let e=this;function n(o){let{name:a,initialValue:s}=o;e._definedProperties.push(a);let l=o.setPrimitiveFunction;l===!0&&(l=function(m){e._voxelPrimitive[a]=m});let r=o.getPrimitiveFunction;r===!0&&(r=function(){e[a]=e._voxelPrimitive[a]}),c(r)&&e._getPrimitiveFunctions.push(r);let d=Lt.observable();return Lt.defineProperty(e,a,{get:function(){return d()},set:function(m){typeof s=="number"&&typeof m=="string"&&(m=Number(m),isNaN(m)&&(m=s)),typeof s=="boolean"&&typeof m=="number"&&(m=m===1),d(m),c(l)&&c(e._voxelPrimitive)&&(l(m),t.requestRender())}}),e[a]=s,d}function i(o,a){return function(s){let l=e._voxelPrimitive[o].clone();l[a]=s,e._voxelPrimitive[o]=l}}n({name:"inspectorVisible",initialValue:!0}),n({name:"displayVisible",initialValue:!1}),n({name:"transformVisible",initialValue:!1}),n({name:"boundsVisible",initialValue:!1}),n({name:"clippingVisible",initialValue:!1}),n({name:"shaderVisible",initialValue:!1}),n({name:"shaderString",initialValue:"",getPrimitiveFunction:function(){let o=e._voxelPrimitive.customShader.fragmentShaderText;e.shaderString=vkt(o)}}),n({name:"shaderCompilationMessage",initialValue:""}),n({name:"shaderCompilationSuccess",initialValue:!0}),n({name:"depthTest",initialValue:!1,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"show",initialValue:!0,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"disableUpdate",initialValue:!1,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"debugDraw",initialValue:!1,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"jitter",initialValue:!0,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"nearestSampling",initialValue:!0,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"screenSpaceError",initialValue:4,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"stepSize",initialValue:1,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"shapeIsBox",getPrimitiveFunction:function(){let o=e._voxelPrimitive.shape;e.shapeIsBox=o===_o.BOX}}),n({name:"shapeIsEllipsoid",getPrimitiveFunction:function(){let o=e._voxelPrimitive.shape;e.shapeIsEllipsoid=o===_o.ELLIPSOID}}),n({name:"shapeIsCylinder",getPrimitiveFunction:function(){let o=e._voxelPrimitive.shape;e.shapeIsCylinder=o===_o.CYLINDER}}),n({name:"boundsBoxMaxX",initialValue:0,setPrimitiveFunction:i("maxBounds","x"),getPrimitiveFunction:function(){e.boundsBoxMaxX=e._voxelPrimitive.maxBounds.x}}),n({name:"boundsBoxMinX",initialValue:0,setPrimitiveFunction:i("minBounds","x"),getPrimitiveFunction:function(){e.boundsBoxMinX=e._voxelPrimitive.minBounds.x}}),n({name:"boundsBoxMaxY",initialValue:0,setPrimitiveFunction:i("maxBounds","y"),getPrimitiveFunction:function(){e.boundsBoxMaxY=e._voxelPrimitive.maxBounds.y}}),n({name:"boundsBoxMinY",initialValue:0,setPrimitiveFunction:i("minBounds","y"),getPrimitiveFunction:function(){e.boundsBoxMinY=e._voxelPrimitive.minBounds.y}}),n({name:"boundsBoxMaxZ",initialValue:0,setPrimitiveFunction:i("maxBounds","z"),getPrimitiveFunction:function(){e.boundsBoxMaxZ=e._voxelPrimitive.maxBounds.z}}),n({name:"boundsBoxMinZ",initialValue:0,setPrimitiveFunction:i("minBounds","z"),getPrimitiveFunction:function(){e.boundsBoxMinZ=e._voxelPrimitive.minBounds.z}}),n({name:"boundsEllipsoidMaxLongitude",initialValue:0,setPrimitiveFunction:i("maxBounds","x"),getPrimitiveFunction:function(){e.boundsEllipsoidMaxLongitude=e._voxelPrimitive.maxBounds.x}}),n({name:"boundsEllipsoidMinLongitude",initialValue:0,setPrimitiveFunction:i("minBounds","x"),getPrimitiveFunction:function(){e.boundsEllipsoidMinLongitude=e._voxelPrimitive.minBounds.x}}),n({name:"boundsEllipsoidMaxLatitude",initialValue:0,setPrimitiveFunction:i("maxBounds","y"),getPrimitiveFunction:function(){e.boundsEllipsoidMaxLatitude=e._voxelPrimitive.maxBounds.y}}),n({name:"boundsEllipsoidMinLatitude",initialValue:0,setPrimitiveFunction:i("minBounds","y"),getPrimitiveFunction:function(){e.boundsEllipsoidMinLatitude=e._voxelPrimitive.minBounds.y}}),n({name:"boundsEllipsoidMaxHeight",initialValue:0,setPrimitiveFunction:i("maxBounds","z"),getPrimitiveFunction:function(){e.boundsEllipsoidMaxHeight=e._voxelPrimitive.maxBounds.z}}),n({name:"boundsEllipsoidMinHeight",initialValue:0,setPrimitiveFunction:i("minBounds","z"),getPrimitiveFunction:function(){e.boundsEllipsoidMinHeight=e._voxelPrimitive.minBounds.z}}),n({name:"boundsCylinderMaxRadius",initialValue:0,setPrimitiveFunction:i("maxBounds","x"),getPrimitiveFunction:function(){e.boundsCylinderMaxRadius=e._voxelPrimitive.maxBounds.x}}),n({name:"boundsCylinderMinRadius",initialValue:0,setPrimitiveFunction:i("minBounds","x"),getPrimitiveFunction:function(){e.boundsCylinderMinRadius=e._voxelPrimitive.minBounds.x}}),n({name:"boundsCylinderMaxHeight",initialValue:0,setPrimitiveFunction:i("maxBounds","y"),getPrimitiveFunction:function(){e.boundsCylinderMaxHeight=e._voxelPrimitive.maxBounds.y}}),n({name:"boundsCylinderMinHeight",initialValue:0,setPrimitiveFunction:i("minBounds","y"),getPrimitiveFunction:function(){e.boundsCylinderMinHeight=e._voxelPrimitive.minBounds.y}}),n({name:"boundsCylinderMaxAngle",initialValue:0,setPrimitiveFunction:i("maxBounds","z"),getPrimitiveFunction:function(){e.boundsCylinderMaxAngle=e._voxelPrimitive.maxBounds.z}}),n({name:"boundsCylinderMinAngle",initialValue:0,setPrimitiveFunction:i("minBounds","z"),getPrimitiveFunction:function(){e.boundsCylinderMinAngle=e._voxelPrimitive.minBounds.z}}),n({name:"clippingBoxMaxX",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","x"),getPrimitiveFunction:function(){e.clippingBoxMaxX=e._voxelPrimitive.maxClippingBounds.x}}),n({name:"clippingBoxMinX",initialValue:0,setPrimitiveFunction:i("minClippingBounds","x"),getPrimitiveFunction:function(){e.clippingBoxMinX=e._voxelPrimitive.minClippingBounds.x}}),n({name:"clippingBoxMaxY",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","y"),getPrimitiveFunction:function(){e.clippingBoxMaxY=e._voxelPrimitive.maxClippingBounds.y}}),n({name:"clippingBoxMinY",initialValue:0,setPrimitiveFunction:i("minClippingBounds","y"),getPrimitiveFunction:function(){e.clippingBoxMinY=e._voxelPrimitive.minClippingBounds.y}}),n({name:"clippingBoxMaxZ",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","z"),getPrimitiveFunction:function(){e.clippingBoxMaxZ=e._voxelPrimitive.maxClippingBounds.z}}),n({name:"clippingBoxMinZ",initialValue:0,setPrimitiveFunction:i("minClippingBounds","z"),getPrimitiveFunction:function(){e.clippingBoxMinZ=e._voxelPrimitive.minClippingBounds.z}}),n({name:"clippingEllipsoidMaxLongitude",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","x"),getPrimitiveFunction:function(){e.clippingEllipsoidMaxLongitude=e._voxelPrimitive.maxClippingBounds.x}}),n({name:"clippingEllipsoidMinLongitude",initialValue:0,setPrimitiveFunction:i("minClippingBounds","x"),getPrimitiveFunction:function(){e.clippingEllipsoidMinLongitude=e._voxelPrimitive.minClippingBounds.x}}),n({name:"clippingEllipsoidMaxLatitude",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","y"),getPrimitiveFunction:function(){e.clippingEllipsoidMaxLatitude=e._voxelPrimitive.maxClippingBounds.y}}),n({name:"clippingEllipsoidMinLatitude",initialValue:0,setPrimitiveFunction:i("minClippingBounds","y"),getPrimitiveFunction:function(){e.clippingEllipsoidMinLatitude=e._voxelPrimitive.minClippingBounds.y}}),n({name:"clippingEllipsoidMaxHeight",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","z"),getPrimitiveFunction:function(){e.clippingEllipsoidMaxHeight=e._voxelPrimitive.maxClippingBounds.z}}),n({name:"clippingEllipsoidMinHeight",initialValue:0,setPrimitiveFunction:i("minClippingBounds","z"),getPrimitiveFunction:function(){e.clippingEllipsoidMinHeight=e._voxelPrimitive.minClippingBounds.z}}),n({name:"clippingCylinderMaxRadius",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","x"),getPrimitiveFunction:function(){e.clippingCylinderMaxRadius=e._voxelPrimitive.maxClippingBounds.x}}),n({name:"clippingCylinderMinRadius",initialValue:0,setPrimitiveFunction:i("minClippingBounds","x"),getPrimitiveFunction:function(){e.clippingCylinderMinRadius=e._voxelPrimitive.minClippingBounds.x}}),n({name:"clippingCylinderMaxHeight",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","y"),getPrimitiveFunction:function(){e.clippingCylinderMaxHeight=e._voxelPrimitive.maxClippingBounds.y}}),n({name:"clippingCylinderMinHeight",initialValue:0,setPrimitiveFunction:i("minClippingBounds","y"),getPrimitiveFunction:function(){e.clippingCylinderMinHeight=e._voxelPrimitive.minClippingBounds.y}}),n({name:"clippingCylinderMaxAngle",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","z"),getPrimitiveFunction:function(){e.clippingCylinderMaxAngle=e._voxelPrimitive.maxClippingBounds.z}}),n({name:"clippingCylinderMinAngle",initialValue:0,setPrimitiveFunction:i("minClippingBounds","z"),getPrimitiveFunction:function(){e.clippingCylinderMinAngle=e._voxelPrimitive.minClippingBounds.z}}),n({name:"translationX",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qb(e)},getPrimitiveFunction:function(){e.translationX=L.getTranslation(e._voxelPrimitive.modelMatrix,new p).x}}),n({name:"translationY",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qb(e)},getPrimitiveFunction:function(){e.translationY=L.getTranslation(e._voxelPrimitive.modelMatrix,new p).y}}),n({name:"translationZ",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qb(e)},getPrimitiveFunction:function(){e.translationZ=L.getTranslation(e._voxelPrimitive.modelMatrix,new p).z}}),n({name:"scaleX",initialValue:1,setPrimitiveFunction:function(){e._modelMatrixReady&&qb(e)},getPrimitiveFunction:function(){e.scaleX=L.getScale(e._voxelPrimitive.modelMatrix,new p).x}}),n({name:"scaleY",initialValue:1,setPrimitiveFunction:function(){e._modelMatrixReady&&qb(e)},getPrimitiveFunction:function(){e.scaleY=L.getScale(e._voxelPrimitive.modelMatrix,new p).y}}),n({name:"scaleZ",initialValue:1,setPrimitiveFunction:function(){e._modelMatrixReady&&qb(e)},getPrimitiveFunction:function(){e.scaleZ=L.getScale(e._voxelPrimitive.modelMatrix,new p).z}}),n({name:"angleX",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qb(e)}}),n({name:"angleY",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qb(e)}}),n({name:"angleZ",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qb(e)}})}var BDe=new p,QDe=new p,kDe=new Jr,YDe=new ot;function qb(t){let e=p.fromElements(t.translationX,t.translationY,t.translationZ,BDe),n=p.fromElements(t.scaleX,t.scaleY,t.scaleZ,QDe),i=kDe;i.heading=t.angleX,i.pitch=t.angleY,i.roll=t.angleZ;let o=ot.fromHeadingPitchRoll(i,YDe),a=ot.multiplyByScale(o,n,o);t._voxelPrimitive.modelMatrix=L.fromRotationTranslation(a,e,t._voxelPrimitive.modelMatrix)}Object.defineProperties(Xu.prototype,{scene:{get:function(){return this._scene}},voxelPrimitive:{get:function(){return this._voxelPrimitive},set:function(t){if(c(this._customShaderCompilationRemoveCallback)&&this._customShaderCompilationRemoveCallback(),c(t)){this._voxelPrimitive=t;let e=this;e._customShaderCompilationRemoveCallback=e._voxelPrimitive.customShaderCompilationEvent.addEventListener(function(n){let i=e._voxelPrimitive.customShader.fragmentShaderText;e.shaderString=vkt(i),c(n)?(e.shaderCompilationMessage=n.message,e.shaderCompilationSuccess=!1):(e.shaderCompilationMessage="Shader compiled successfully!",e.shaderCompilationSuccess=!0)}),e._modelMatrixReady=!1;for(let n=0;n<e._getPrimitiveFunctions.length;n++)e._getPrimitiveFunctions[n]();e._modelMatrixReady=!0,qb(e)}}}});Xu.prototype.toggleInspector=function(){this.inspectorVisible=!this.inspectorVisible};Xu.prototype.toggleDisplay=function(){this.displayVisible=!this.displayVisible};Xu.prototype.toggleTransform=function(){this.transformVisible=!this.transformVisible};Xu.prototype.toggleBounds=function(){this.boundsVisible=!this.boundsVisible};Xu.prototype.toggleClipping=function(){this.clippingVisible=!this.clippingVisible};Xu.prototype.toggleShader=function(){this.shaderVisible=!this.shaderVisible};Xu.prototype.compileShader=function(){c(this._voxelPrimitive)&&(this._voxelPrimitive.customShader=new JS({fragmentShaderText:this.shaderString,uniforms:this._voxelPrimitive.customShader.uniforms}))};Xu.prototype.shaderEditorKeyPress=function(t,e){if(e.keyCode===9){e.preventDefault();let n=e.target,i=n.selectionStart,o=n.selectionEnd,a=o,l=n.value.slice(i,o).split(` +`}return i}function XV(t){this._scene=t,this._voxelPrimitive=void 0,this._customShaderCompilationRemoveCallback=void 0,this._definedProperties=[],this._getPrimitiveFunctions=[],this._modelMatrixReady=!1;let e=this;function n(o){let{name:a,initialValue:s}=o;e._definedProperties.push(a);let l=o.setPrimitiveFunction;l===!0&&(l=function(m){e._voxelPrimitive[a]=m});let r=o.getPrimitiveFunction;r===!0&&(r=function(){e[a]=e._voxelPrimitive[a]}),c(r)&&e._getPrimitiveFunctions.push(r);let d=Lt.observable();return Lt.defineProperty(e,a,{get:function(){return d()},set:function(m){typeof s=="number"&&typeof m=="string"&&(m=Number(m),isNaN(m)&&(m=s)),typeof s=="boolean"&&typeof m=="number"&&(m=m===1),d(m),c(l)&&c(e._voxelPrimitive)&&(l(m),t.requestRender())}}),e[a]=s,d}function i(o,a){return function(s){let l=e._voxelPrimitive[o].clone();l[a]=s,e._voxelPrimitive[o]=l}}n({name:"inspectorVisible",initialValue:!0}),n({name:"displayVisible",initialValue:!1}),n({name:"transformVisible",initialValue:!1}),n({name:"boundsVisible",initialValue:!1}),n({name:"clippingVisible",initialValue:!1}),n({name:"shaderVisible",initialValue:!1}),n({name:"shaderString",initialValue:"",getPrimitiveFunction:function(){let o=e._voxelPrimitive.customShader.fragmentShaderText;e.shaderString=v2t(o)}}),n({name:"shaderCompilationMessage",initialValue:""}),n({name:"shaderCompilationSuccess",initialValue:!0}),n({name:"depthTest",initialValue:!1,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"show",initialValue:!0,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"disableUpdate",initialValue:!1,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"debugDraw",initialValue:!1,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"jitter",initialValue:!0,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"nearestSampling",initialValue:!0,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"screenSpaceError",initialValue:4,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"stepSize",initialValue:1,setPrimitiveFunction:!0,getPrimitiveFunction:!0}),n({name:"shapeIsBox",getPrimitiveFunction:function(){let o=e._voxelPrimitive.shape;e.shapeIsBox=o===_o.BOX}}),n({name:"shapeIsEllipsoid",getPrimitiveFunction:function(){let o=e._voxelPrimitive.shape;e.shapeIsEllipsoid=o===_o.ELLIPSOID}}),n({name:"shapeIsCylinder",getPrimitiveFunction:function(){let o=e._voxelPrimitive.shape;e.shapeIsCylinder=o===_o.CYLINDER}}),n({name:"boundsBoxMaxX",initialValue:0,setPrimitiveFunction:i("maxBounds","x"),getPrimitiveFunction:function(){e.boundsBoxMaxX=e._voxelPrimitive.maxBounds.x}}),n({name:"boundsBoxMinX",initialValue:0,setPrimitiveFunction:i("minBounds","x"),getPrimitiveFunction:function(){e.boundsBoxMinX=e._voxelPrimitive.minBounds.x}}),n({name:"boundsBoxMaxY",initialValue:0,setPrimitiveFunction:i("maxBounds","y"),getPrimitiveFunction:function(){e.boundsBoxMaxY=e._voxelPrimitive.maxBounds.y}}),n({name:"boundsBoxMinY",initialValue:0,setPrimitiveFunction:i("minBounds","y"),getPrimitiveFunction:function(){e.boundsBoxMinY=e._voxelPrimitive.minBounds.y}}),n({name:"boundsBoxMaxZ",initialValue:0,setPrimitiveFunction:i("maxBounds","z"),getPrimitiveFunction:function(){e.boundsBoxMaxZ=e._voxelPrimitive.maxBounds.z}}),n({name:"boundsBoxMinZ",initialValue:0,setPrimitiveFunction:i("minBounds","z"),getPrimitiveFunction:function(){e.boundsBoxMinZ=e._voxelPrimitive.minBounds.z}}),n({name:"boundsEllipsoidMaxLongitude",initialValue:0,setPrimitiveFunction:i("maxBounds","x"),getPrimitiveFunction:function(){e.boundsEllipsoidMaxLongitude=e._voxelPrimitive.maxBounds.x}}),n({name:"boundsEllipsoidMinLongitude",initialValue:0,setPrimitiveFunction:i("minBounds","x"),getPrimitiveFunction:function(){e.boundsEllipsoidMinLongitude=e._voxelPrimitive.minBounds.x}}),n({name:"boundsEllipsoidMaxLatitude",initialValue:0,setPrimitiveFunction:i("maxBounds","y"),getPrimitiveFunction:function(){e.boundsEllipsoidMaxLatitude=e._voxelPrimitive.maxBounds.y}}),n({name:"boundsEllipsoidMinLatitude",initialValue:0,setPrimitiveFunction:i("minBounds","y"),getPrimitiveFunction:function(){e.boundsEllipsoidMinLatitude=e._voxelPrimitive.minBounds.y}}),n({name:"boundsEllipsoidMaxHeight",initialValue:0,setPrimitiveFunction:i("maxBounds","z"),getPrimitiveFunction:function(){e.boundsEllipsoidMaxHeight=e._voxelPrimitive.maxBounds.z}}),n({name:"boundsEllipsoidMinHeight",initialValue:0,setPrimitiveFunction:i("minBounds","z"),getPrimitiveFunction:function(){e.boundsEllipsoidMinHeight=e._voxelPrimitive.minBounds.z}}),n({name:"boundsCylinderMaxRadius",initialValue:0,setPrimitiveFunction:i("maxBounds","x"),getPrimitiveFunction:function(){e.boundsCylinderMaxRadius=e._voxelPrimitive.maxBounds.x}}),n({name:"boundsCylinderMinRadius",initialValue:0,setPrimitiveFunction:i("minBounds","x"),getPrimitiveFunction:function(){e.boundsCylinderMinRadius=e._voxelPrimitive.minBounds.x}}),n({name:"boundsCylinderMaxHeight",initialValue:0,setPrimitiveFunction:i("maxBounds","y"),getPrimitiveFunction:function(){e.boundsCylinderMaxHeight=e._voxelPrimitive.maxBounds.y}}),n({name:"boundsCylinderMinHeight",initialValue:0,setPrimitiveFunction:i("minBounds","y"),getPrimitiveFunction:function(){e.boundsCylinderMinHeight=e._voxelPrimitive.minBounds.y}}),n({name:"boundsCylinderMaxAngle",initialValue:0,setPrimitiveFunction:i("maxBounds","z"),getPrimitiveFunction:function(){e.boundsCylinderMaxAngle=e._voxelPrimitive.maxBounds.z}}),n({name:"boundsCylinderMinAngle",initialValue:0,setPrimitiveFunction:i("minBounds","z"),getPrimitiveFunction:function(){e.boundsCylinderMinAngle=e._voxelPrimitive.minBounds.z}}),n({name:"clippingBoxMaxX",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","x"),getPrimitiveFunction:function(){e.clippingBoxMaxX=e._voxelPrimitive.maxClippingBounds.x}}),n({name:"clippingBoxMinX",initialValue:0,setPrimitiveFunction:i("minClippingBounds","x"),getPrimitiveFunction:function(){e.clippingBoxMinX=e._voxelPrimitive.minClippingBounds.x}}),n({name:"clippingBoxMaxY",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","y"),getPrimitiveFunction:function(){e.clippingBoxMaxY=e._voxelPrimitive.maxClippingBounds.y}}),n({name:"clippingBoxMinY",initialValue:0,setPrimitiveFunction:i("minClippingBounds","y"),getPrimitiveFunction:function(){e.clippingBoxMinY=e._voxelPrimitive.minClippingBounds.y}}),n({name:"clippingBoxMaxZ",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","z"),getPrimitiveFunction:function(){e.clippingBoxMaxZ=e._voxelPrimitive.maxClippingBounds.z}}),n({name:"clippingBoxMinZ",initialValue:0,setPrimitiveFunction:i("minClippingBounds","z"),getPrimitiveFunction:function(){e.clippingBoxMinZ=e._voxelPrimitive.minClippingBounds.z}}),n({name:"clippingEllipsoidMaxLongitude",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","x"),getPrimitiveFunction:function(){e.clippingEllipsoidMaxLongitude=e._voxelPrimitive.maxClippingBounds.x}}),n({name:"clippingEllipsoidMinLongitude",initialValue:0,setPrimitiveFunction:i("minClippingBounds","x"),getPrimitiveFunction:function(){e.clippingEllipsoidMinLongitude=e._voxelPrimitive.minClippingBounds.x}}),n({name:"clippingEllipsoidMaxLatitude",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","y"),getPrimitiveFunction:function(){e.clippingEllipsoidMaxLatitude=e._voxelPrimitive.maxClippingBounds.y}}),n({name:"clippingEllipsoidMinLatitude",initialValue:0,setPrimitiveFunction:i("minClippingBounds","y"),getPrimitiveFunction:function(){e.clippingEllipsoidMinLatitude=e._voxelPrimitive.minClippingBounds.y}}),n({name:"clippingEllipsoidMaxHeight",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","z"),getPrimitiveFunction:function(){e.clippingEllipsoidMaxHeight=e._voxelPrimitive.maxClippingBounds.z}}),n({name:"clippingEllipsoidMinHeight",initialValue:0,setPrimitiveFunction:i("minClippingBounds","z"),getPrimitiveFunction:function(){e.clippingEllipsoidMinHeight=e._voxelPrimitive.minClippingBounds.z}}),n({name:"clippingCylinderMaxRadius",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","x"),getPrimitiveFunction:function(){e.clippingCylinderMaxRadius=e._voxelPrimitive.maxClippingBounds.x}}),n({name:"clippingCylinderMinRadius",initialValue:0,setPrimitiveFunction:i("minClippingBounds","x"),getPrimitiveFunction:function(){e.clippingCylinderMinRadius=e._voxelPrimitive.minClippingBounds.x}}),n({name:"clippingCylinderMaxHeight",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","y"),getPrimitiveFunction:function(){e.clippingCylinderMaxHeight=e._voxelPrimitive.maxClippingBounds.y}}),n({name:"clippingCylinderMinHeight",initialValue:0,setPrimitiveFunction:i("minClippingBounds","y"),getPrimitiveFunction:function(){e.clippingCylinderMinHeight=e._voxelPrimitive.minClippingBounds.y}}),n({name:"clippingCylinderMaxAngle",initialValue:0,setPrimitiveFunction:i("maxClippingBounds","z"),getPrimitiveFunction:function(){e.clippingCylinderMaxAngle=e._voxelPrimitive.maxClippingBounds.z}}),n({name:"clippingCylinderMinAngle",initialValue:0,setPrimitiveFunction:i("minClippingBounds","z"),getPrimitiveFunction:function(){e.clippingCylinderMinAngle=e._voxelPrimitive.minClippingBounds.z}}),n({name:"translationX",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qR(e)},getPrimitiveFunction:function(){e.translationX=L.getTranslation(e._voxelPrimitive.modelMatrix,new p).x}}),n({name:"translationY",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qR(e)},getPrimitiveFunction:function(){e.translationY=L.getTranslation(e._voxelPrimitive.modelMatrix,new p).y}}),n({name:"translationZ",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qR(e)},getPrimitiveFunction:function(){e.translationZ=L.getTranslation(e._voxelPrimitive.modelMatrix,new p).z}}),n({name:"scaleX",initialValue:1,setPrimitiveFunction:function(){e._modelMatrixReady&&qR(e)},getPrimitiveFunction:function(){e.scaleX=L.getScale(e._voxelPrimitive.modelMatrix,new p).x}}),n({name:"scaleY",initialValue:1,setPrimitiveFunction:function(){e._modelMatrixReady&&qR(e)},getPrimitiveFunction:function(){e.scaleY=L.getScale(e._voxelPrimitive.modelMatrix,new p).y}}),n({name:"scaleZ",initialValue:1,setPrimitiveFunction:function(){e._modelMatrixReady&&qR(e)},getPrimitiveFunction:function(){e.scaleZ=L.getScale(e._voxelPrimitive.modelMatrix,new p).z}}),n({name:"angleX",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qR(e)}}),n({name:"angleY",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qR(e)}}),n({name:"angleZ",initialValue:0,setPrimitiveFunction:function(){e._modelMatrixReady&&qR(e)}})}var BDe=new p,QDe=new p,kDe=new Jr,YDe=new ot;function qR(t){let e=p.fromElements(t.translationX,t.translationY,t.translationZ,BDe),n=p.fromElements(t.scaleX,t.scaleY,t.scaleZ,QDe),i=kDe;i.heading=t.angleX,i.pitch=t.angleY,i.roll=t.angleZ;let o=ot.fromHeadingPitchRoll(i,YDe),a=ot.multiplyByScale(o,n,o);t._voxelPrimitive.modelMatrix=L.fromRotationTranslation(a,e,t._voxelPrimitive.modelMatrix)}Object.defineProperties(XV.prototype,{scene:{get:function(){return this._scene}},voxelPrimitive:{get:function(){return this._voxelPrimitive},set:function(t){if(c(this._customShaderCompilationRemoveCallback)&&this._customShaderCompilationRemoveCallback(),c(t)){this._voxelPrimitive=t;let e=this;e._customShaderCompilationRemoveCallback=e._voxelPrimitive.customShaderCompilationEvent.addEventListener(function(n){let i=e._voxelPrimitive.customShader.fragmentShaderText;e.shaderString=v2t(i),c(n)?(e.shaderCompilationMessage=n.message,e.shaderCompilationSuccess=!1):(e.shaderCompilationMessage="Shader compiled successfully!",e.shaderCompilationSuccess=!0)}),e._modelMatrixReady=!1;for(let n=0;n<e._getPrimitiveFunctions.length;n++)e._getPrimitiveFunctions[n]();e._modelMatrixReady=!0,qR(e)}}}});XV.prototype.toggleInspector=function(){this.inspectorVisible=!this.inspectorVisible};XV.prototype.toggleDisplay=function(){this.displayVisible=!this.displayVisible};XV.prototype.toggleTransform=function(){this.transformVisible=!this.transformVisible};XV.prototype.toggleBounds=function(){this.boundsVisible=!this.boundsVisible};XV.prototype.toggleClipping=function(){this.clippingVisible=!this.clippingVisible};XV.prototype.toggleShader=function(){this.shaderVisible=!this.shaderVisible};XV.prototype.compileShader=function(){c(this._voxelPrimitive)&&(this._voxelPrimitive.customShader=new JT({fragmentShaderText:this.shaderString,uniforms:this._voxelPrimitive.customShader.uniforms}))};XV.prototype.shaderEditorKeyPress=function(t,e){if(e.keyCode===9){e.preventDefault();let n=e.target,i=n.selectionStart,o=n.selectionEnd,a=o,l=n.value.slice(i,o).split(` `),r=l.length,d;if(e.shiftKey)for(d=0;d<r;++d)l[d][0]===" "&&(l[d][1]===" "?(l[d]=l[d].substr(2),a-=2):(l[d]=l[d].substr(1),a-=1));else for(d=0;d<r;++d)l[d]=` ${l[d]}`,a+=2;let m=l.join(` -`);n.value=n.value.slice(0,i)+m+n.value.slice(o),n.selectionStart=i!==o?i:a,n.selectionEnd=a}else e.ctrlKey&&(e.keyCode===10||e.keyCode===13)&&this.compileShader();return!0};Xu.prototype.isDestroyed=function(){return!1};Xu.prototype.destroy=function(){let t=this;return this._definedProperties.forEach(function(e){Lt.getObservable(t,e).dispose()}),At(this)};var aO=Xu;function N4(t,e){t=Ui(t);let n=document.createElement("div"),i=new aO(e);this._viewModel=i,this._container=t,this._element=n;let o=document.createElement("div");o.textContent="Voxel Inspector",o.className="cesium-cesiumInspector-button",o.setAttribute("data-bind","click: toggleInspector"),n.appendChild(o),n.className="cesium-cesiumInspector cesium-VoxelInspector",n.setAttribute("data-bind",'css: { "cesium-cesiumInspector-visible" : inspectorVisible, "cesium-cesiumInspector-hidden" : !inspectorVisible}'),t.appendChild(n);let a=document.createElement("div");a.className="cesium-cesiumInspector-dropDown",n.appendChild(a);let s=gd.createSection,l=gd.createCheckbox,r=gd.createRangeInput,d=gd.createButton,m=s(a,"Display","displayVisible","toggleDisplay"),h=s(a,"Transform","transformVisible","toggleTransform"),Z=s(a,"Bounds","boundsVisible","toggleBounds"),b=s(a,"Clipping","clippingVisible","toggleClipping"),u=s(a,"Shader","shaderVisible","toggleShader");m.appendChild(l("Depth Test","depthTest")),m.appendChild(l("Show","show")),m.appendChild(l("Disable Update","disableUpdate")),m.appendChild(l("Debug Draw","debugDraw")),m.appendChild(l("Jitter","jitter")),m.appendChild(l("Nearest Sampling","nearestSampling")),m.appendChild(r("Screen Space Error","screenSpaceError",0,128)),m.appendChild(r("Step Size","stepSize",0,2));let F=10,U=10,G=k.PI;h.appendChild(r("Translation X","translationX",-F,+F)),h.appendChild(r("Translation Y","translationY",-F,+F)),h.appendChild(r("Translation Z","translationZ",-F,+F)),h.appendChild(r("Scale X","scaleX",0,+U)),h.appendChild(r("Scale Y","scaleY",0,+U)),h.appendChild(r("Scale Z","scaleZ",0,+U)),h.appendChild(r("Heading","angleX",-G,+G)),h.appendChild(r("Pitch","angleY",-G,+G)),h.appendChild(r("Roll","angleZ",-G,+G));let A=_o.getMinBounds(_o.BOX),T=_o.getMaxBounds(_o.BOX),g=p.fromElements(_o.getMinBounds(_o.ELLIPSOID).x,_o.getMinBounds(_o.ELLIPSOID).y,-mt.WGS84.maximumRadius,new p),C=p.fromElements(_o.getMaxBounds(_o.ELLIPSOID).x,_o.getMaxBounds(_o.ELLIPSOID).y,1e7,new p),y=_o.getMinBounds(_o.CYLINDER),Y=_o.getMaxBounds(_o.CYLINDER);TN("Max X","Min X","Max Y","Min Y","Max Z","Min Z","boundsBoxMaxX","boundsBoxMinX","boundsBoxMaxY","boundsBoxMinY","boundsBoxMaxZ","boundsBoxMinZ",A,T,"shapeIsBox",Z),TN("Max Longitude","Min Longitude","Max Latitude","Min Latitude","Max Height","Min Height","boundsEllipsoidMaxLongitude","boundsEllipsoidMinLongitude","boundsEllipsoidMaxLatitude","boundsEllipsoidMinLatitude","boundsEllipsoidMaxHeight","boundsEllipsoidMinHeight",g,C,"shapeIsEllipsoid",Z),TN("Max Radius","Min Radius","Max Height","Min Height","Max Angle","Min Angle","boundsCylinderMaxRadius","boundsCylinderMinRadius","boundsCylinderMaxHeight","boundsCylinderMinHeight","boundsCylinderMaxAngle","boundsCylinderMinAngle",y,Y,"shapeIsCylinder",Z),TN("Max X","Min X","Max Y","Min Y","Max Z","Min Z","clippingBoxMaxX","clippingBoxMinX","clippingBoxMaxY","clippingBoxMinY","clippingBoxMaxZ","clippingBoxMinZ",A,T,"shapeIsBox",b),TN("Max Longitude","Min Longitude","Max Latitude","Min Latitude","Max Height","Min Height","clippingEllipsoidMaxLongitude","clippingEllipsoidMinLongitude","clippingEllipsoidMaxLatitude","clippingEllipsoidMinLatitude","clippingEllipsoidMaxHeight","clippingEllipsoidMinHeight",g,C,"shapeIsEllipsoid",b),TN("Max Radius","Min Radius","Max Height","Min Height","Max Angle","Min Angle","clippingCylinderMaxRadius","clippingCylinderMinRadius","clippingCylinderMaxHeight","clippingCylinderMinHeight","clippingCylinderMaxAngle","clippingCylinderMinAngle",y,Y,"shapeIsCylinder",b);let Q=document.createElement("div");u.appendChild(Q);let J=document.createElement("textarea");J.setAttribute("data-bind","textInput: shaderString, event: { keydown: shaderEditorKeyPress }"),Q.className="cesium-cesiumInspector-styleEditor",Q.appendChild(J);let M=d("Compile (Ctrl+Enter)","compileShader");Q.appendChild(M);let V=document.createElement("label");V.style.display="block",V.setAttribute("data-bind","text: shaderCompilationMessage, style: {color: shaderCompilationSuccess ? 'green' : 'red'}"),Q.appendChild(V),Lt.applyBindings(i,n)}Object.defineProperties(N4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});N4.prototype.isDestroyed=function(){return!1};N4.prototype.destroy=function(){return Lt.cleanNode(this._element),this._container.removeChild(this._element),this.viewModel.destroy(),At(this)};function TN(t,e,n,i,o,a,s,l,r,d,m,h,Z,b,u,F){let U=gd.createRangeInput,G=Z,A=b,T=F.appendChild(document.createElement("div"));T.setAttribute("data-bind",`if: ${u}`),T.appendChild(U(t,s,G.x,A.x)),T.appendChild(U(e,l,G.x,A.x)),T.appendChild(U(n,r,G.y,A.y)),T.appendChild(U(i,d,G.y,A.y)),T.appendChild(U(o,m,G.z,A.z)),T.appendChild(U(a,h,G.z,A.z))}var sO=N4;function xDe(t){let e=document.createElement("div");e.className="cesium-viewer-voxelInspectorContainer",t.container.appendChild(e);let n=new sO(e,t.scene);Object.defineProperties(t,{voxelInspector:{get:function(){return n}}})}var idt=xDe;globalThis.CESIUM_VERSION="1.116";var XDe="1.116";return RMt(JDe);})(); +`);n.value=n.value.slice(0,i)+m+n.value.slice(o),n.selectionStart=i!==o?i:a,n.selectionEnd=a}else e.ctrlKey&&(e.keyCode===10||e.keyCode===13)&&this.compileShader();return!0};XV.prototype.isDestroyed=function(){return!1};XV.prototype.destroy=function(){let t=this;return this._definedProperties.forEach(function(e){Lt.getObservable(t,e).dispose()}),At(this)};var aO=XV;function N4(t,e){t=Ui(t);let n=document.createElement("div"),i=new aO(e);this._viewModel=i,this._container=t,this._element=n;let o=document.createElement("div");o.textContent="Voxel Inspector",o.className="cesium-cesiumInspector-button",o.setAttribute("data-bind","click: toggleInspector"),n.appendChild(o),n.className="cesium-cesiumInspector cesium-VoxelInspector",n.setAttribute("data-bind",'css: { "cesium-cesiumInspector-visible" : inspectorVisible, "cesium-cesiumInspector-hidden" : !inspectorVisible}'),t.appendChild(n);let a=document.createElement("div");a.className="cesium-cesiumInspector-dropDown",n.appendChild(a);let s=gd.createSection,l=gd.createCheckbox,r=gd.createRangeInput,d=gd.createButton,m=s(a,"Display","displayVisible","toggleDisplay"),h=s(a,"Transform","transformVisible","toggleTransform"),u=s(a,"Bounds","boundsVisible","toggleBounds"),R=s(a,"Clipping","clippingVisible","toggleClipping"),V=s(a,"Shader","shaderVisible","toggleShader");m.appendChild(l("Depth Test","depthTest")),m.appendChild(l("Show","show")),m.appendChild(l("Disable Update","disableUpdate")),m.appendChild(l("Debug Draw","debugDraw")),m.appendChild(l("Jitter","jitter")),m.appendChild(l("Nearest Sampling","nearestSampling")),m.appendChild(r("Screen Space Error","screenSpaceError",0,128)),m.appendChild(r("Step Size","stepSize",0,2));let F=10,U=10,G=k.PI;h.appendChild(r("Translation X","translationX",-F,+F)),h.appendChild(r("Translation Y","translationY",-F,+F)),h.appendChild(r("Translation Z","translationZ",-F,+F)),h.appendChild(r("Scale X","scaleX",0,+U)),h.appendChild(r("Scale Y","scaleY",0,+U)),h.appendChild(r("Scale Z","scaleZ",0,+U)),h.appendChild(r("Heading","angleX",-G,+G)),h.appendChild(r("Pitch","angleY",-G,+G)),h.appendChild(r("Roll","angleZ",-G,+G));let A=_o.getMinBounds(_o.BOX),S=_o.getMaxBounds(_o.BOX),g=p.fromElements(_o.getMinBounds(_o.ELLIPSOID).x,_o.getMinBounds(_o.ELLIPSOID).y,-mt.WGS84.maximumRadius,new p),C=p.fromElements(_o.getMaxBounds(_o.ELLIPSOID).x,_o.getMaxBounds(_o.ELLIPSOID).y,1e7,new p),y=_o.getMinBounds(_o.CYLINDER),Y=_o.getMaxBounds(_o.CYLINDER);SN("Max X","Min X","Max Y","Min Y","Max Z","Min Z","boundsBoxMaxX","boundsBoxMinX","boundsBoxMaxY","boundsBoxMinY","boundsBoxMaxZ","boundsBoxMinZ",A,S,"shapeIsBox",u),SN("Max Longitude","Min Longitude","Max Latitude","Min Latitude","Max Height","Min Height","boundsEllipsoidMaxLongitude","boundsEllipsoidMinLongitude","boundsEllipsoidMaxLatitude","boundsEllipsoidMinLatitude","boundsEllipsoidMaxHeight","boundsEllipsoidMinHeight",g,C,"shapeIsEllipsoid",u),SN("Max Radius","Min Radius","Max Height","Min Height","Max Angle","Min Angle","boundsCylinderMaxRadius","boundsCylinderMinRadius","boundsCylinderMaxHeight","boundsCylinderMinHeight","boundsCylinderMaxAngle","boundsCylinderMinAngle",y,Y,"shapeIsCylinder",u),SN("Max X","Min X","Max Y","Min Y","Max Z","Min Z","clippingBoxMaxX","clippingBoxMinX","clippingBoxMaxY","clippingBoxMinY","clippingBoxMaxZ","clippingBoxMinZ",A,S,"shapeIsBox",R),SN("Max Longitude","Min Longitude","Max Latitude","Min Latitude","Max Height","Min Height","clippingEllipsoidMaxLongitude","clippingEllipsoidMinLongitude","clippingEllipsoidMaxLatitude","clippingEllipsoidMinLatitude","clippingEllipsoidMaxHeight","clippingEllipsoidMinHeight",g,C,"shapeIsEllipsoid",R),SN("Max Radius","Min Radius","Max Height","Min Height","Max Angle","Min Angle","clippingCylinderMaxRadius","clippingCylinderMinRadius","clippingCylinderMaxHeight","clippingCylinderMinHeight","clippingCylinderMaxAngle","clippingCylinderMinAngle",y,Y,"shapeIsCylinder",R);let Q=document.createElement("div");V.appendChild(Q);let J=document.createElement("textarea");J.setAttribute("data-bind","textInput: shaderString, event: { keydown: shaderEditorKeyPress }"),Q.className="cesium-cesiumInspector-styleEditor",Q.appendChild(J);let M=d("Compile (Ctrl+Enter)","compileShader");Q.appendChild(M);let Z=document.createElement("label");Z.style.display="block",Z.setAttribute("data-bind","text: shaderCompilationMessage, style: {color: shaderCompilationSuccess ? 'green' : 'red'}"),Q.appendChild(Z),Lt.applyBindings(i,n)}Object.defineProperties(N4.prototype,{container:{get:function(){return this._container}},viewModel:{get:function(){return this._viewModel}}});N4.prototype.isDestroyed=function(){return!1};N4.prototype.destroy=function(){return Lt.cleanNode(this._element),this._container.removeChild(this._element),this.viewModel.destroy(),At(this)};function SN(t,e,n,i,o,a,s,l,r,d,m,h,u,R,V,F){let U=gd.createRangeInput,G=u,A=R,S=F.appendChild(document.createElement("div"));S.setAttribute("data-bind",`if: ${V}`),S.appendChild(U(t,s,G.x,A.x)),S.appendChild(U(e,l,G.x,A.x)),S.appendChild(U(n,r,G.y,A.y)),S.appendChild(U(i,d,G.y,A.y)),S.appendChild(U(o,m,G.z,A.z)),S.appendChild(U(a,h,G.z,A.z))}var sO=N4;function xDe(t){let e=document.createElement("div");e.className="cesium-viewer-voxelInspectorContainer",t.container.appendChild(e);let n=new sO(e,t.scene);Object.defineProperties(t,{voxelInspector:{get:function(){return n}}})}var idt=xDe;globalThis.CESIUM_VERSION="1.116";var XDe="1.116";return bMt(JDe);})();